commit de464b937dec83762d6417391d37ab7902ec4059 Author: Tóth Ádám Date: Tue Nov 19 19:04:02 2024 +0100 first commit diff --git a/Programozás/API/main.py b/Programozás/API/main.py new file mode 100644 index 0000000..e69de29 diff --git a/Programozás/Bot b/Programozás/Bot new file mode 160000 index 0000000..252d279 --- /dev/null +++ b/Programozás/Bot @@ -0,0 +1 @@ +Subproject commit 252d279d67ad4e2564688fa43f335b71bf805bfd diff --git a/Programozás/Datapack b/Programozás/Datapack new file mode 160000 index 0000000..7cf4473 --- /dev/null +++ b/Programozás/Datapack @@ -0,0 +1 @@ +Subproject commit 7cf4473669d3a638261338816a9bd51c63829e61 diff --git a/Programozás/Roblox/Practise.rbxl b/Programozás/Roblox/Practise.rbxl new file mode 100644 index 0000000..ebcd14b Binary files /dev/null and b/Programozás/Roblox/Practise.rbxl differ diff --git a/Screenshots/Képernyőkép 2023-10-12 115759.png b/Screenshots/Képernyőkép 2023-10-12 115759.png new file mode 100644 index 0000000..13a0a7f Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 115759.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 115907.png b/Screenshots/Képernyőkép 2023-10-12 115907.png new file mode 100644 index 0000000..577ca2f Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 115907.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 120045.png b/Screenshots/Képernyőkép 2023-10-12 120045.png new file mode 100644 index 0000000..4b8a61d Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 120045.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 120236.png b/Screenshots/Képernyőkép 2023-10-12 120236.png new file mode 100644 index 0000000..2fd7534 Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 120236.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 120810.png b/Screenshots/Képernyőkép 2023-10-12 120810.png new file mode 100644 index 0000000..339c71e Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 120810.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 120816.png b/Screenshots/Képernyőkép 2023-10-12 120816.png new file mode 100644 index 0000000..4b85a30 Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 120816.png differ diff --git a/Screenshots/Képernyőkép 2023-10-12 120825.png b/Screenshots/Képernyőkép 2023-10-12 120825.png new file mode 100644 index 0000000..42b4ad7 Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-12 120825.png differ diff --git a/Screenshots/Képernyőkép 2023-10-25 131619.png b/Screenshots/Képernyőkép 2023-10-25 131619.png new file mode 100644 index 0000000..64ef3f8 Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-25 131619.png differ diff --git a/Screenshots/Képernyőkép 2023-10-25 131655.png b/Screenshots/Képernyőkép 2023-10-25 131655.png new file mode 100644 index 0000000..d27bec4 Binary files /dev/null and b/Screenshots/Képernyőkép 2023-10-25 131655.png differ diff --git a/Screenshots/Screenshot (1).png b/Screenshots/Screenshot (1).png new file mode 100644 index 0000000..264d3c4 Binary files /dev/null and b/Screenshots/Screenshot (1).png differ diff --git a/Screenshots/Screenshot (2).png b/Screenshots/Screenshot (2).png new file mode 100644 index 0000000..264d3c4 Binary files /dev/null and b/Screenshots/Screenshot (2).png differ diff --git a/Screenshots/Screenshot (3).png b/Screenshots/Screenshot (3).png new file mode 100644 index 0000000..264d3c4 Binary files /dev/null and b/Screenshots/Screenshot (3).png differ diff --git a/Screenshots/Screenshot (4).png b/Screenshots/Screenshot (4).png new file mode 100644 index 0000000..264d3c4 Binary files /dev/null and b/Screenshots/Screenshot (4).png differ diff --git a/Screenshots/Screenshot (5).png b/Screenshots/Screenshot (5).png new file mode 100644 index 0000000..264d3c4 Binary files /dev/null and b/Screenshots/Screenshot (5).png differ diff --git a/Screenshots/Screenshot 2023-10-26 115100.png b/Screenshots/Screenshot 2023-10-26 115100.png new file mode 100644 index 0000000..5344c07 Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115100.png differ diff --git a/Screenshots/Screenshot 2023-10-26 115105.png b/Screenshots/Screenshot 2023-10-26 115105.png new file mode 100644 index 0000000..802055b Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115105.png differ diff --git a/Screenshots/Screenshot 2023-10-26 115159.png b/Screenshots/Screenshot 2023-10-26 115159.png new file mode 100644 index 0000000..9d3d34b Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115159.png differ diff --git a/Screenshots/Screenshot 2023-10-26 115656.png b/Screenshots/Screenshot 2023-10-26 115656.png new file mode 100644 index 0000000..82647c7 Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115656.png differ diff --git a/Screenshots/Screenshot 2023-10-26 115706.png b/Screenshots/Screenshot 2023-10-26 115706.png new file mode 100644 index 0000000..8929f5b Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115706.png differ diff --git a/Screenshots/Screenshot 2023-10-26 115816.png b/Screenshots/Screenshot 2023-10-26 115816.png new file mode 100644 index 0000000..8f034a9 Binary files /dev/null and b/Screenshots/Screenshot 2023-10-26 115816.png differ diff --git a/Screenshots/Screenshot 2023-11-28 114007.png b/Screenshots/Screenshot 2023-11-28 114007.png new file mode 100644 index 0000000..b570690 Binary files /dev/null and b/Screenshots/Screenshot 2023-11-28 114007.png differ diff --git a/Screenshots/Screenshot 2023-11-28 114055.png b/Screenshots/Screenshot 2023-11-28 114055.png new file mode 100644 index 0000000..276efaa Binary files /dev/null and b/Screenshots/Screenshot 2023-11-28 114055.png differ diff --git a/Screenshots/Screenshot 2023-11-28 114102.png b/Screenshots/Screenshot 2023-11-28 114102.png new file mode 100644 index 0000000..3919c99 Binary files /dev/null and b/Screenshots/Screenshot 2023-11-28 114102.png differ diff --git a/Screenshots/Screenshot 2023-12-01 132529.png b/Screenshots/Screenshot 2023-12-01 132529.png new file mode 100644 index 0000000..a8d687b Binary files /dev/null and b/Screenshots/Screenshot 2023-12-01 132529.png differ diff --git a/Screenshots/Screenshot 2023-12-01 132725.png b/Screenshots/Screenshot 2023-12-01 132725.png new file mode 100644 index 0000000..0335855 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-01 132725.png differ diff --git a/Screenshots/Screenshot 2023-12-05 114629.png b/Screenshots/Screenshot 2023-12-05 114629.png new file mode 100644 index 0000000..ae009b5 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 114629.png differ diff --git a/Screenshots/Screenshot 2023-12-05 115110.png b/Screenshots/Screenshot 2023-12-05 115110.png new file mode 100644 index 0000000..c9aa35a Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 115110.png differ diff --git a/Screenshots/Screenshot 2023-12-05 115119.png b/Screenshots/Screenshot 2023-12-05 115119.png new file mode 100644 index 0000000..11a53d1 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 115119.png differ diff --git a/Screenshots/Screenshot 2023-12-05 115322.png b/Screenshots/Screenshot 2023-12-05 115322.png new file mode 100644 index 0000000..ad4b713 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 115322.png differ diff --git a/Screenshots/Screenshot 2023-12-05 120313.png b/Screenshots/Screenshot 2023-12-05 120313.png new file mode 100644 index 0000000..19174c4 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 120313.png differ diff --git a/Screenshots/Screenshot 2023-12-05 120328.png b/Screenshots/Screenshot 2023-12-05 120328.png new file mode 100644 index 0000000..1154664 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-05 120328.png differ diff --git a/Screenshots/Screenshot 2023-12-07 113933.png b/Screenshots/Screenshot 2023-12-07 113933.png new file mode 100644 index 0000000..62e1477 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-07 113933.png differ diff --git a/Screenshots/Screenshot 2023-12-07 153222.png b/Screenshots/Screenshot 2023-12-07 153222.png new file mode 100644 index 0000000..60b58f1 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-07 153222.png differ diff --git a/Screenshots/Screenshot 2023-12-07 153333.png b/Screenshots/Screenshot 2023-12-07 153333.png new file mode 100644 index 0000000..518fc5e Binary files /dev/null and b/Screenshots/Screenshot 2023-12-07 153333.png differ diff --git a/Screenshots/Screenshot 2023-12-07 153345.png b/Screenshots/Screenshot 2023-12-07 153345.png new file mode 100644 index 0000000..a2131a0 Binary files /dev/null and b/Screenshots/Screenshot 2023-12-07 153345.png differ diff --git a/Screenshots/Screenshot 2024-01-09 114710.png b/Screenshots/Screenshot 2024-01-09 114710.png new file mode 100644 index 0000000..bb6781d Binary files /dev/null and b/Screenshots/Screenshot 2024-01-09 114710.png differ diff --git a/Screenshots/Screenshot 2024-02-16 091908.png b/Screenshots/Screenshot 2024-02-16 091908.png new file mode 100644 index 0000000..7f63867 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-16 091908.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115547.png b/Screenshots/Screenshot 2024-02-22 115547.png new file mode 100644 index 0000000..3731904 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115547.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115600.png b/Screenshots/Screenshot 2024-02-22 115600.png new file mode 100644 index 0000000..fe09cfd Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115600.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115606.png b/Screenshots/Screenshot 2024-02-22 115606.png new file mode 100644 index 0000000..5e98f8c Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115606.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115714.png b/Screenshots/Screenshot 2024-02-22 115714.png new file mode 100644 index 0000000..2638e1b Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115714.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115724.png b/Screenshots/Screenshot 2024-02-22 115724.png new file mode 100644 index 0000000..6017710 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115724.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115812.png b/Screenshots/Screenshot 2024-02-22 115812.png new file mode 100644 index 0000000..3326618 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115812.png differ diff --git a/Screenshots/Screenshot 2024-02-22 115925.png b/Screenshots/Screenshot 2024-02-22 115925.png new file mode 100644 index 0000000..0a362ae Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 115925.png differ diff --git a/Screenshots/Screenshot 2024-02-22 120003.png b/Screenshots/Screenshot 2024-02-22 120003.png new file mode 100644 index 0000000..043dabd Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 120003.png differ diff --git a/Screenshots/Screenshot 2024-02-22 120152.png b/Screenshots/Screenshot 2024-02-22 120152.png new file mode 100644 index 0000000..e0ef6df Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 120152.png differ diff --git a/Screenshots/Screenshot 2024-02-22 120158.png b/Screenshots/Screenshot 2024-02-22 120158.png new file mode 100644 index 0000000..3d41295 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 120158.png differ diff --git a/Screenshots/Screenshot 2024-02-22 120243.png b/Screenshots/Screenshot 2024-02-22 120243.png new file mode 100644 index 0000000..f789f88 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 120243.png differ diff --git a/Screenshots/Screenshot 2024-02-22 120250.png b/Screenshots/Screenshot 2024-02-22 120250.png new file mode 100644 index 0000000..8f8e437 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 120250.png differ diff --git a/Screenshots/Screenshot 2024-02-22 121008.png b/Screenshots/Screenshot 2024-02-22 121008.png new file mode 100644 index 0000000..b4842ee Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 121008.png differ diff --git a/Screenshots/Screenshot 2024-02-22 121030.png b/Screenshots/Screenshot 2024-02-22 121030.png new file mode 100644 index 0000000..446143c Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 121030.png differ diff --git a/Screenshots/Screenshot 2024-02-22 124652.png b/Screenshots/Screenshot 2024-02-22 124652.png new file mode 100644 index 0000000..9e7c7c3 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 124652.png differ diff --git a/Screenshots/Screenshot 2024-02-22 125621.png b/Screenshots/Screenshot 2024-02-22 125621.png new file mode 100644 index 0000000..0adcb45 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 125621.png differ diff --git a/Screenshots/Screenshot 2024-02-22 125643.png b/Screenshots/Screenshot 2024-02-22 125643.png new file mode 100644 index 0000000..3cacb8c Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 125643.png differ diff --git a/Screenshots/Screenshot 2024-02-22 125945.png b/Screenshots/Screenshot 2024-02-22 125945.png new file mode 100644 index 0000000..ff745dc Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 125945.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130004.png b/Screenshots/Screenshot 2024-02-22 130004.png new file mode 100644 index 0000000..776ca94 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130004.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130033.png b/Screenshots/Screenshot 2024-02-22 130033.png new file mode 100644 index 0000000..ff7f1df Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130033.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130508.png b/Screenshots/Screenshot 2024-02-22 130508.png new file mode 100644 index 0000000..e3b631d Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130508.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130515.png b/Screenshots/Screenshot 2024-02-22 130515.png new file mode 100644 index 0000000..c787b69 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130515.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130536.png b/Screenshots/Screenshot 2024-02-22 130536.png new file mode 100644 index 0000000..cfef1d8 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130536.png differ diff --git a/Screenshots/Screenshot 2024-02-22 130541.png b/Screenshots/Screenshot 2024-02-22 130541.png new file mode 100644 index 0000000..cb2ce03 Binary files /dev/null and b/Screenshots/Screenshot 2024-02-22 130541.png differ diff --git a/Screenshots/Screenshot 2024-03-14 115826.png b/Screenshots/Screenshot 2024-03-14 115826.png new file mode 100644 index 0000000..53325d9 Binary files /dev/null and b/Screenshots/Screenshot 2024-03-14 115826.png differ diff --git a/Screenshots/Screenshot 2024-03-14 120145.png b/Screenshots/Screenshot 2024-03-14 120145.png new file mode 100644 index 0000000..e01c59a Binary files /dev/null and b/Screenshots/Screenshot 2024-03-14 120145.png differ diff --git a/Screenshots/Screenshot 2024-04-11 114750.png b/Screenshots/Screenshot 2024-04-11 114750.png new file mode 100644 index 0000000..34e6f6e Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 114750.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120043.png b/Screenshots/Screenshot 2024-04-11 120043.png new file mode 100644 index 0000000..125747c Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120043.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120051.png b/Screenshots/Screenshot 2024-04-11 120051.png new file mode 100644 index 0000000..40460f0 Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120051.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120111.png b/Screenshots/Screenshot 2024-04-11 120111.png new file mode 100644 index 0000000..9958429 Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120111.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120118.png b/Screenshots/Screenshot 2024-04-11 120118.png new file mode 100644 index 0000000..2c13a5f Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120118.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120138.png b/Screenshots/Screenshot 2024-04-11 120138.png new file mode 100644 index 0000000..66b5d3c Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120138.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120144.png b/Screenshots/Screenshot 2024-04-11 120144.png new file mode 100644 index 0000000..6e9866d Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120144.png differ diff --git a/Screenshots/Screenshot 2024-04-11 120150.png b/Screenshots/Screenshot 2024-04-11 120150.png new file mode 100644 index 0000000..c6bbbc5 Binary files /dev/null and b/Screenshots/Screenshot 2024-04-11 120150.png differ diff --git a/Screenshots/Screenshot 2024-09-15 140057.png b/Screenshots/Screenshot 2024-09-15 140057.png new file mode 100644 index 0000000..7177932 Binary files /dev/null and b/Screenshots/Screenshot 2024-09-15 140057.png differ diff --git a/Screenshots/desktop.ini b/Screenshots/desktop.ini new file mode 100644 index 0000000..8f7031a --- /dev/null +++ b/Screenshots/desktop.ini @@ -0,0 +1,2 @@ +[.ShellClassInfo] +LocalizedResourceName=@%SystemRoot%\system32\windows.storage.dll,-21823 diff --git a/Suli/11.b/Adatbázis/Érettségi/Forma-1/adatok.sql b/Suli/11.b/Adatbázis/Érettségi/Forma-1/adatok.sql new file mode 100644 index 0000000..cb05f87 --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Forma-1/adatok.sql @@ -0,0 +1,478 @@ +INSERT INTO csapatok (csazon, csnev) VALUES +(1, 'Ferrari'), +(2, 'Force India Mercedes'), +(3, 'Lotus Mercedes'), +(4, 'Marussia Ferrari'), +(5, 'McLaren Honda'), +(6, 'Mercedes'), +(7, 'Red Bull Renault'), +(8, 'Sauber Ferrari'), +(9, 'STR Renault'), +(10, 'Williams Mercedes'); + +INSERT INTO pilotak (pazon, pnev, szev, csapat) VALUES +(1, 'Alexander Rossi', 1991, 4), +(2, 'Carlos Sainz Jnr', 1994, 9), +(3, 'Daniel Ricciardo', 1989, 7), +(4, 'Daniil Kvyat', 1994, 7), +(5, 'Felipe Massa', 1981, 10), +(6, 'Felipe Nasr', 1992, 8), +(7, 'Fernando Alonso', 1981, 5), +(8, 'Jenson Button', 1980, 5), +(9, 'Kevin Magnussen', 1992, 5), +(10, 'Kimi Raikkonen', 1979, 1), +(11, 'Lewis Hamilton', 1985, 6), +(12, 'Marcus Ericsson', 1990, 8), +(13, 'Max Verstappen', 1997, 9), +(14, 'Nico Hulkenberg', 1987, 2), +(15, 'Nico Rosberg', 1985, 6), +(16, 'Pastor Maldonado', 1985, 3), +(17, 'Roberto Merhi', 1991, 4), +(18, 'Romain Grosjean', 1986, 3), +(19, 'Sebastian Vettel', 1987, 1), +(20, 'Sergio Perez', 1990, 2), +(21, 'Valtteri Bottas', 1989, 10), +(22, 'Will Stevens', 1991, 4); + +INSERT INTO versenyek (vkod, datum, vnev, hely, kor, hossz) VALUES +('AUS', '2015-03-15', 'Ausztrál Nagydíj', 'Melbourne', 58, 5303), +('MAL', '2015-03-29', 'Maláj Nagydíj', 'Szepang', 56, 5543), +('CHI', '2015-04-12', 'Kínai Nagydíj', 'Shanghai', 56, 5451), +('BAH', '2015-04-19', 'Bahreini Nagydíj', 'Szahír', 57, 5412), +('SPA', '2015-05-10', 'Spanyol Nagydíj', 'Barcelona', 66, 4655), +('MON', '2015-05-24', 'Monacói Nagydíj', 'Monte Carlo', 78, 3340), +('CAN', '2015-06-07', 'Kanadai Nagydíj', 'Montreal', 70, 4361), +('OST', '2015-06-21', 'Osztrák Nagydíj', 'Spielberg', 71, 4326), +('BRI', '2015-07-05', 'Brit Nagydíj', 'Silverstone', 52, 5891), +('GER', '2015-07-19', 'Német Nagydíj', 'TBD', 67, 4574), +('HUN', '2015-07-26', 'Magyar Nagydíj', 'Mogyoród', 70, 4381), +('BEL', '2015-08-23', 'Belga Nagydíj', 'Francorchamps', 44, 7004), +('ITA', '2015-09-06', 'Olasz Nagydíj', 'Monza', 53, 5793), +('SIN', '2015-09-20', 'Szingapúri Nagydíj', 'Szingapúr', 61, 5073), +('JAP', '2015-09-27', 'Japán Nagydíj', 'Szuzuka', 53, 5807), +('RUS', '2015-10-11', 'Orosz Nagydíj', 'Sochi', 52, 5853), +('UNI', '2015-10-25', 'Amerikai Nagydíj', 'Austin', 56, 5472), +('MEX', '2015-11-01', 'Mexikói Nagydíj', 'Mexico City', 69, 4580), +('BRA', '2015-11-15', 'Brazil Nagydíj', 'Rio de Janeiro', 71, 4309), +('ABU', '2015-11-29', 'Abu Dhabi Nagydíj', 'Abu Dhabi', 55, 5554); + +INSERT INTO eredmenyek (pilota, nagydij, startpoz, celpoz) VALUES +(1, 'AUS', NULL, NULL), +(1, 'MAL', NULL, NULL), +(1, 'CHI', NULL, NULL), +(1, 'BAH', NULL, NULL), +(1, 'SPA', NULL, NULL), +(1, 'MON', NULL, NULL), +(1, 'CAN', NULL, NULL), +(1, 'OST', NULL, NULL), +(1, 'BRI', NULL, NULL), +(1, 'HUN', NULL, NULL), +(1, 'BEL', NULL, NULL), +(1, 'ITA', NULL, NULL), +(1, 'SIN', 14, 20), +(1, 'JAP', 18, 19), +(1, 'RUS', NULL, NULL), +(1, 'UNI', 12, 17), +(1, 'MEX', 15, 16), +(1, 'BRA', 18, 17), +(1, 'ABU', NULL, NULL), +(2, 'AUS', 9, 7), +(2, 'MAL', 8, 15), +(2, 'CHI', 13, 14), +(2, 'BAH', NULL, 9), +(2, 'SPA', 9, 5), +(2, 'MON', 10, 20), +(2, 'CAN', 12, 11), +(2, 'OST', NULL, 12), +(2, 'BRI', NULL, 8), +(2, 'HUN', NULL, 12), +(2, 'BEL', NULL, 10), +(2, 'ITA', 11, 17), +(2, 'SIN', 9, 14), +(2, 'JAP', 10, 10), +(2, 'RUS', NULL, 20), +(2, 'UNI', 7, 20), +(2, 'MEX', 13, 11), +(2, 'BRA', NULL, 10), +(2, 'ABU', 11, 10), +(3, 'AUS', 6, 6), +(3, 'MAL', 10, 4), +(3, 'CHI', 9, 7), +(3, 'BAH', 6, 7), +(3, 'SPA', 7, 10), +(3, 'MON', 5, 4), +(3, 'CAN', 13, 9), +(3, 'OST', 10, 18), +(3, 'BRI', NULL, 10), +(3, 'HUN', 3, 4), +(3, 'BEL', NULL, 5), +(3, 'ITA', 8, 19), +(3, 'SIN', 2, 2), +(3, 'JAP', 15, 7), +(3, 'RUS', 15, 10), +(3, 'UNI', 10, 3), +(3, 'MEX', 5, 5), +(3, 'BRA', 11, 19), +(3, 'ABU', 6, 5), +(4, 'AUS', NULL, 12), +(4, 'MAL', 9, 5), +(4, 'CHI', NULL, 12), +(4, 'BAH', 9, 17), +(4, 'SPA', 10, 8), +(4, 'MON', 4, 5), +(4, 'CAN', 9, 8), +(4, 'OST', 12, 15), +(4, 'BRI', 6, 7), +(4, 'HUN', 2, 7), +(4, 'BEL', 4, 12), +(4, 'ITA', 10, 18), +(4, 'SIN', 6, 4), +(4, 'JAP', 13, 20), +(4, 'RUS', 5, 11), +(4, 'UNI', NULL, 4), +(4, 'MEX', 4, 4), +(4, 'BRA', 7, 6), +(4, 'ABU', 10, 9), +(5, 'AUS', 4, 3), +(5, 'MAL', 6, 7), +(5, 'CHI', 5, 4), +(5, 'BAH', 10, 6), +(5, 'SPA', 6, 9), +(5, 'MON', 15, 12), +(5, 'CAN', 6, 15), +(5, 'OST', 3, 4), +(5, 'BRI', 4, 3), +(5, 'HUN', 12, 8), +(5, 'BEL', 6, 6), +(5, 'ITA', 3, 5), +(5, 'SIN', NULL, 9), +(5, 'JAP', 17, 5), +(5, 'RUS', 4, 15), +(5, 'UNI', NULL, 7), +(5, 'MEX', 6, 7), +(5, 'BRA', NULL, 8), +(5, 'ABU', 8, 8), +(6, 'AUS', 5, 10), +(6, 'MAL', 12, 16), +(6, 'CHI', 8, 9), +(6, 'BAH', 12, 12), +(6, 'SPA', 12, 15), +(6, 'MON', 9, 14), +(6, 'CAN', 16, 14), +(6, 'OST', 11, 8), +(6, 'BRI', NULL, 16), +(6, 'HUN', 11, 18), +(6, 'BEL', 11, 14), +(6, 'ITA', 13, 11), +(6, 'SIN', 10, 16), +(6, 'JAP', 20, 16), +(6, 'RUS', 6, 12), +(6, 'UNI', 9, 15), +(6, 'MEX', NULL, 15), +(6, 'BRA', 13, 13), +(6, 'ABU', 15, 14), +(7, 'AUS', NULL, NULL), +(7, 'MAL', NULL, 18), +(7, 'CHI', 12, 18), +(7, 'BAH', 11, 14), +(7, 'SPA', NULL, 13), +(7, 'MON', NULL, 13), +(7, 'CAN', NULL, 13), +(7, 'OST', NULL, 19), +(7, 'BRI', 10, 17), +(7, 'HUN', 5, 15), +(7, 'BEL', 13, 20), +(7, 'ITA', 18, 16), +(7, 'SIN', NULL, 12), +(7, 'JAP', 11, 12), +(7, 'RUS', 11, 19), +(7, 'UNI', 11, 9), +(7, 'MEX', NULL, 18), +(7, 'BRA', 15, 20), +(7, 'ABU', 17, 16), +(8, 'AUS', 11, 16), +(8, 'MAL', NULL, 17), +(8, 'CHI', 14, 17), +(8, 'BAH', NULL, 20), +(8, 'SPA', 16, 14), +(8, 'MON', 8, 10), +(8, 'CAN', NULL, 20), +(8, 'OST', NULL, 20), +(8, 'BRI', NULL, 18), +(8, 'HUN', 9, 16), +(8, 'BEL', 14, 19), +(8, 'ITA', 14, 15), +(8, 'SIN', NULL, 15), +(8, 'JAP', 16, 14), +(8, 'RUS', 9, 13), +(8, 'UNI', 6, 11), +(8, 'MEX', 14, 20), +(8, 'BRA', 14, 16), +(8, 'ABU', 12, 12), +(9, 'AUS', NULL, 17), +(9, 'MAL', NULL, NULL), +(9, 'CHI', NULL, NULL), +(9, 'BAH', NULL, NULL), +(9, 'SPA', NULL, NULL), +(9, 'MON', NULL, NULL), +(9, 'CAN', NULL, NULL), +(9, 'OST', NULL, NULL), +(9, 'BRI', NULL, NULL), +(9, 'HUN', NULL, NULL), +(9, 'BEL', NULL, NULL), +(9, 'ITA', NULL, NULL), +(9, 'SIN', NULL, NULL), +(9, 'JAP', NULL, NULL), +(9, 'RUS', NULL, NULL), +(9, 'UNI', NULL, NULL), +(9, 'MEX', NULL, NULL), +(9, 'BRA', NULL, NULL), +(9, 'ABU', NULL, NULL), +(10, 'AUS', NULL, 5), +(10, 'MAL', 4, 11), +(10, 'CHI', 4, 6), +(10, 'BAH', 2, 4), +(10, 'SPA', 5, 7), +(10, 'MON', 6, 6), +(10, 'CAN', 4, 3), +(10, 'OST', NULL, 14), +(10, 'BRI', 8, 5), +(10, 'HUN', NULL, 5), +(10, 'BEL', 7, 16), +(10, 'ITA', 5, 2), +(10, 'SIN', 3, 3), +(10, 'JAP', 4, 6), +(10, 'RUS', 8, 5), +(10, 'UNI', NULL, 18), +(10, 'MEX', NULL, 19), +(10, 'BRA', 4, 4), +(10, 'ABU', 3, 3), +(11, 'AUS', 1, 1), +(11, 'MAL', 2, 1), +(11, 'CHI', 1, 1), +(11, 'BAH', 1, 1), +(11, 'SPA', 2, 2), +(11, 'MON', 3, 1), +(11, 'CAN', 1, 1), +(11, 'OST', 2, 1), +(11, 'BRI', 1, 1), +(11, 'HUN', 6, 1), +(11, 'BEL', 1, 1), +(11, 'ITA', 1, 1), +(11, 'SIN', NULL, 5), +(11, 'JAP', 1, 2), +(11, 'RUS', 1, 2), +(11, 'UNI', 1, 2), +(11, 'MEX', 2, 2), +(11, 'BRA', 2, 2), +(11, 'ABU', 2, 2), +(12, 'AUS', 8, 15), +(12, 'MAL', NULL, 9), +(12, 'CHI', 10, 10), +(12, 'BAH', 14, 13), +(12, 'SPA', 14, 16), +(12, 'MON', 13, 17), +(12, 'CAN', 14, 12), +(12, 'OST', 13, 11), +(12, 'BRI', 11, 15), +(12, 'HUN', 10, 17), +(12, 'BEL', 10, 13), +(12, 'ITA', 9, 12), +(12, 'SIN', 11, 17), +(12, 'JAP', 14, 15), +(12, 'RUS', NULL, 16), +(12, 'UNI', NULL, 14), +(12, 'MEX', 12, 14), +(12, 'BRA', 16, 12), +(12, 'ABU', 14, 17), +(13, 'AUS', NULL, 11), +(13, 'MAL', 7, 6), +(13, 'CHI', 17, 13), +(13, 'BAH', NULL, 15), +(13, 'SPA', 11, 6), +(13, 'MON', NULL, 9), +(13, 'CAN', 15, 19), +(13, 'OST', 8, 7), +(13, 'BRI', NULL, 13), +(13, 'HUN', 4, 9), +(13, 'BEL', 8, 18), +(13, 'ITA', 12, 20), +(13, 'SIN', 8, 8), +(13, 'JAP', 9, 17), +(13, 'RUS', 10, 9), +(13, 'UNI', 4, 8), +(13, 'MEX', 9, 8), +(13, 'BRA', 9, 9), +(13, 'ABU', 16, 11), +(14, 'AUS', 7, 13), +(14, 'MAL', 14, 13), +(14, 'CHI', NULL, 16), +(14, 'BAH', 13, 8), +(14, 'SPA', 15, 17), +(14, 'MON', 11, 11), +(14, 'CAN', 8, 7), +(14, 'OST', 6, 5), +(14, 'BRI', 7, 9), +(14, 'HUN', NULL, 11), +(14, 'BEL', NULL, 11), +(14, 'ITA', 7, 9), +(14, 'SIN', NULL, 11), +(14, 'JAP', 6, 13), +(14, 'RUS', NULL, 6), +(14, 'UNI', NULL, 6), +(14, 'MEX', 7, 10), +(14, 'BRA', 6, 5), +(14, 'ABU', 7, 7), +(15, 'AUS', 2, 2), +(15, 'MAL', 3, 3), +(15, 'CHI', 2, 2), +(15, 'BAH', 3, 3), +(15, 'SPA', 1, 1), +(15, 'MON', 1, 2), +(15, 'CAN', 2, 2), +(15, 'OST', 1, 2), +(15, 'BRI', 2, 2), +(15, 'HUN', 8, 2), +(15, 'BEL', 2, 2), +(15, 'ITA', 17, 4), +(15, 'SIN', 4, 6), +(15, 'JAP', 2, 1), +(15, 'RUS', NULL, 1), +(15, 'UNI', 2, 1), +(15, 'MEX', 1, 1), +(15, 'BRA', 1, 1), +(15, 'ABU', 1, 1), +(16, 'AUS', NULL, 9), +(16, 'MAL', NULL, 12), +(16, 'CHI', NULL, 11), +(16, 'BAH', 15, 16), +(16, 'SPA', NULL, 12), +(16, 'MON', NULL, 8), +(16, 'CAN', 7, 6), +(16, 'OST', 7, 10), +(16, 'BRI', NULL, 14), +(16, 'HUN', 14, 14), +(16, 'BEL', NULL, 7), +(16, 'ITA', NULL, 10), +(16, 'SIN', 12, 18), +(16, 'JAP', 8, 11), +(16, 'RUS', 7, 14), +(16, 'UNI', 8, 12), +(16, 'MEX', 11, 13), +(16, 'BRA', 10, 15), +(16, 'ABU', NULL, 13), +(17, 'AUS', NULL, NULL), +(17, 'MAL', 15, 19), +(17, 'CHI', 16, 20), +(17, 'BAH', 17, 19), +(17, 'SPA', 18, 20), +(17, 'MON', 16, 19), +(17, 'CAN', NULL, 16), +(17, 'OST', 14, 16), +(17, 'BRI', 12, 20), +(17, 'HUN', 15, 19), +(17, 'BEL', 15, 17), +(17, 'ITA', 16, 14), +(17, 'SIN', NULL, NULL), +(17, 'JAP', NULL, NULL), +(17, 'RUS', 13, 18), +(17, 'UNI', NULL, NULL), +(17, 'MEX', NULL, NULL), +(17, 'BRA', NULL, NULL), +(17, 'ABU', 19, 20), +(18, 'AUS', NULL, 8), +(18, 'MAL', 11, 10), +(18, 'CHI', 7, 8), +(18, 'BAH', 7, 10), +(18, 'SPA', 8, 11), +(18, 'MON', 12, 15), +(18, 'CAN', 10, 5), +(18, 'OST', NULL, 9), +(18, 'BRI', NULL, 12), +(18, 'HUN', 7, 10), +(18, 'BEL', 3, 9), +(18, 'ITA', NULL, 8), +(18, 'SIN', 13, 10), +(18, 'JAP', 7, 8), +(18, 'RUS', NULL, 8), +(18, 'UNI', NULL, 10), +(18, 'MEX', 10, 12), +(18, 'BRA', 8, 14), +(18, 'ABU', 9, 18), +(19, 'AUS', 3, 4), +(19, 'MAL', 1, 2), +(19, 'CHI', 3, 3), +(19, 'BAH', 5, 2), +(19, 'SPA', 3, 3), +(19, 'MON', 2, 3), +(19, 'CAN', 5, 18), +(19, 'OST', 4, 3), +(19, 'BRI', 3, 6), +(19, 'HUN', 1, 3), +(19, 'BEL', 12, 8), +(19, 'ITA', 2, 3), +(19, 'SIN', 1, 1), +(19, 'JAP', 3, 4), +(19, 'RUS', 2, 4), +(19, 'UNI', 3, 13), +(19, 'MEX', NULL, 3), +(19, 'BRA', 3, 3), +(19, 'ABU', 4, 15), +(20, 'AUS', 10, 14), +(20, 'MAL', 13, 14), +(20, 'CHI', 11, 15), +(20, 'BAH', 8, 11), +(20, 'SPA', 13, 18), +(20, 'MON', 7, 7), +(20, 'CAN', 11, 10), +(20, 'OST', 9, 13), +(20, 'BRI', 9, 11), +(20, 'HUN', NULL, 13), +(20, 'BEL', 5, 4), +(20, 'ITA', 6, 7), +(20, 'SIN', 7, 13), +(20, 'JAP', 12, 9), +(20, 'RUS', 3, 7), +(20, 'UNI', 5, 5), +(20, 'MEX', 8, 9), +(20, 'BRA', 12, 11), +(20, 'ABU', 5, 4), +(21, 'AUS', NULL, 6), +(21, 'MAL', 5, 8), +(21, 'CHI', 6, 5), +(21, 'BAH', 4, 5), +(21, 'SPA', 4, 4), +(21, 'MON', 14, 16), +(21, 'CAN', 3, 4), +(21, 'OST', 5, 6), +(21, 'BRI', 5, 4), +(21, 'HUN', 13, 6), +(21, 'BEL', 9, 3), +(21, 'ITA', 4, 6), +(21, 'SIN', 5, 7), +(21, 'JAP', 5, 3), +(21, 'RUS', 12, 3), +(21, 'UNI', NULL, 16), +(21, 'MEX', 3, 6), +(21, 'BRA', 5, 7), +(21, 'ABU', 13, 6), +(22, 'AUS', NULL, NULL), +(22, 'MAL', NULL, 20), +(22, 'CHI', 15, 19), +(22, 'BAH', 16, 18), +(22, 'SPA', 17, 19), +(22, 'MON', 17, 18), +(22, 'CAN', 17, 17), +(22, 'OST', NULL, 17), +(22, 'BRI', 13, 19), +(22, 'HUN', 16, 20), +(22, 'BEL', 16, 15), +(22, 'ITA', 15, 13), +(22, 'SIN', 15, 19), +(22, 'JAP', 19, 18), +(22, 'RUS', 14, 17), +(22, 'UNI', NULL, 19), +(22, 'MEX', 16, 17), +(22, 'BRA', 17, 18), +(22, 'ABU', 18, 19); + diff --git a/Suli/11.b/Adatbázis/Érettségi/Forma-1/megoldasok.sql b/Suli/11.b/Adatbázis/Érettségi/Forma-1/megoldasok.sql new file mode 100644 index 0000000..afe0c3d --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Forma-1/megoldasok.sql @@ -0,0 +1,27 @@ +A feladatok megoldására elkészített SQL parancsokat illessze be a feladat sorszáma után! + + +-- 1. feladat: +CREATE DATABASE forma1 CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + +-- 3. feladat: +SELECT pnev FROM `pilotak` + +-- 4. feladat: +ALTER TABLE pilotak +ADD CONSTRAINT fk_csapat FOREIGN KEY csapat REFERENCES csapatok(csazon) + +-- 5. feladat: + + +-- 6. feladat: + + +-- 7. feladat: + + +-- 8. feladat: + + +-- 9. feladat: + diff --git a/Suli/11.b/Adatbázis/Érettségi/Forma-1/tablak.sql b/Suli/11.b/Adatbázis/Érettségi/Forma-1/tablak.sql new file mode 100644 index 0000000..31a031d --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Forma-1/tablak.sql @@ -0,0 +1,33 @@ +CREATE TABLE csapatok ( + csazon int, + csnev varchar(20), + CONSTRAINT pk_csapatok PRIMARY KEY (csazon) +); + + +CREATE TABLE pilotak ( + pazon int, + pnev varchar(16), + szev int, + csapat int, + CONSTRAINT pk_pilotak PRIMARY KEY (pazon) +); + +CREATE TABLE versenyek ( + vkod varchar(3), + datum date, + vnev varchar(18), + hely varchar(14), + kor int, + hossz int, + CONSTRAINT pk_versenyek PRIMARY KEY (vkod) +); + +CREATE TABLE eredmenyek ( + pilota int, + nagydij varchar(3), + startpoz int, + celpoz int, + CONSTRAINT pk_eredmenyek PRIMARY KEY (pilota, nagydij) +); + diff --git a/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/adatbazis.sql b/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/adatbazis.sql new file mode 100644 index 0000000..3208d9d --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/adatbazis.sql @@ -0,0 +1,333 @@ +-- Szobák +CREATE TABLE szobak ( + `id` int(11) NOT NULL, + `emelet` int(2) NOT NULL, + `szobaszam` int(8) NOT NULL UNIQUE, + `ferohelyek` int(3) NOT NULL, + `ar` decimal(10,2) DEFAULT NULL, + `megjegyzes` varchar(255) DEFAULT NULL +); + +ALTER TABLE szobak + ADD PRIMARY KEY (`id`); + +INSERT INTO `szobak` (`id`, `emelet`, `szobaszam`, `ferohelyek`, `ar`, `megjegyzes`) VALUES +(1, 0, 1, 2, 20000, 'mozgáskorlátozott-barát'), +(2, 0, 2, 2, 20000, 'mozgáskorlátozott-barát'), +(3, 0, 3, 2, 20000, null), +(4, 0, 4, 2, 35000, 'luxus lakosztály'), +(5, 0, 5, 4, 20000, null), +(6, 0, 6, 4, 20000, null), +(7, 0, 7, 4, 40000, null), +(8, 0, 8, 4, 40000, null), +(9, 0, 9, 4, 40000, null), +(10, 0, 10, 4, 40000, null), +(11, 0, 11, 4, 40000, 'mozgáskorlátozott-barát'), +(12, 0, 12, 4, 55000, 'luxus lakosztály'), +(13, 1, 101, 2, 20000, null), +(14, 1, 102, 2, 20000, null), +(15, 1, 103, 2, 20000, null), +(16, 1, 104, 2, 25000, 'luxus lakosztály'), +(17, 1, 105, 2, 25000, 'luxus lakosztály'), +(18, 1, 106, 2, 27500, 'luxus lakosztály panorámás kilátás'), +(19, 1, 107, 4, 57500, 'luxus lakosztály panorámás kilátás'), +(20, 1, 108, 4, 40000, null), +(21, 1, 109, 4, 40000, null), +(22, 1, 110, 6, 60000, null), +(23, 1, 111, 6, 60000, 'pótágyazható'), +(24, 1, 112, 6, 60000, 'pótágyazható'), +(25, 2, 201, 2, 20000, null), +(26, 2, 202, 2, 20000, null), +(27, 2, 203, 2, 20000, null), +(28, 2, 204, 2, 20000, null), +(29, 2, 206, 2, 22000, 'panorámás kilátás'), +(30, 2, 207, 2, 22000, 'panorámás kilátás'), +(31, 2, 208, 2, 22000, 'panorámás kilátás'), +(32, 2, 209, 4, 40000, null), +(33, 2, 210, 4, 40000, null), +(34, 2, 211, 4, 40000, null), +(35, 2, 212, 4, 55000, 'luxus lakosztály'), +(36, 2, 213, 6, 60000, null), +(37, 2, 214, 6, 60000, 'pótágyazható'), +(38, 2, 215, 6, 80000, 'luxus lakosztály panorámás kilátás'); + +ALTER TABLE `szobak` + MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=39; + +-- Vendégek +CREATE TABLE vendegek ( + `id` int(11) NOT NULL, + `nev` varchar(255) not null, + `eletkor` int(4) NOT NULL +); + +ALTER TABLE vendegek + ADD PRIMARY KEY (`id`); + +INSERT INTO `vendegek` (`id`, `nev`, `eletkor`) VALUES +(1, 'Kovács András', 23), +(2, 'Botond Attila', 40), +(3, 'Kiss Balázs', 29), +(4, 'Pálmai Nóra', 26), +(5, 'Németh Péter', 62), +(6, 'Falusi Krisztina', 19), +(7, 'Kiss Károly', 62), +(8, 'Tököli Ferenc', 60), +(9, 'Török Éva', 42), +(10, 'Kisnánai Józsefné', 35), +(11,'Cukorhegyi Márk', 35), +(12, 'Soós András', 26), +(13, 'John Edward', 41), +(14, 'Malik András', 60), +(15, 'Kovácsné Zentai Illdikó', 55), +(16, 'Maróthi Béla', 31), +(17, 'Orosz Szilárd', 39), +(18, 'Kocsis Zoltánné Erika', 42), +(19, 'Alföldi Zoltán', 40), +(20, 'Zente Ferenc', 29), +(21, 'Nagy Gáspár', 46), +(22, 'Lelkes Bálint', 34), +(23, 'Mérész Dániel', 55), +(24, 'Pardavi Balázs', 38), +(25, 'Szedmák Bálint', 31), +(26, 'Fűtő Ildikó', 40), +(27, 'Nefelejts Sándor', 45), +(28, 'Kővári Ferenc', 43), +(29, 'Csalami Krisztián', 49), +(30, 'Lugosi Béla', 50), +(31, 'Kovács András Bendegúz', 40), +(32, 'Nagy-Bandó Andrea', 40), +(33, 'Csóró Csanád', 38); + +ALTER TABLE `vendegek` + MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=34; + + +-- Foglalások +CREATE TABLE foglalasok ( + `id` int(11) NOT NULL, + `szobaId` int(11) NOT NULL, + `vendegId` int(11) NOT NULL, + `napok` int(4) NOT NULL, + `datum` datetime NOT NULL +); + +ALTER TABLE foglalasok + ADD PRIMARY KEY (`id`), + ADD KEY `szobaId` (`szobaId`), + ADD KEY `vendegId` (`vendegId`); + +ALTER TABLE foglalasok + ADD CONSTRAINT FK_szobak_szobaId FOREIGN KEY (szobaId) + REFERENCES szobak (id); + +ALTER TABLE foglalasok + ADD CONSTRAINT FK_vendegek_vendegId FOREIGN KEY (vendegId) + REFERENCES vendegek (id); + +INSERT INTO `foglalasok` (`id`, `szobaId`, `vendegId`, `napok`, `datum`) VALUES +(1, 19, 10, 2, '2020-08-29'), +(2, 26, 26, 10, '2020-07-26'), +(3, 9, 15, 10, '2020-11-17'), +(4, 26, 12, 8, '2020-02-19'), +(5, 3, 6, 6, '2020-11-01'), +(6, 36, 16, 6, '2020-01-23'), +(7, 11, 18, 4, '2020-12-13'), +(8, 8, 30, 1, '2020-08-07'), +(9, 14, 20, 2, '2020-06-29'), +(10, 7, 10, 4, '2020-05-04'), +(11, 20, 30, 4, '2020-01-30'), +(12, 15, 15, 1, '2020-12-09'), +(13, 20, 21, 1, '2020-12-23'), +(14, 9, 4, 9, '2020-07-08'), +(15, 22, 11, 1, '2020-04-10'), +(16, 21, 24, 1, '2020-01-02'), +(17, 35, 31, 9, '2020-01-25'), +(18, 21, 15, 8, '2020-09-21'), +(19, 23, 2, 8, '2020-12-30'), +(20, 32, 24, 5, '2020-03-18'), +(21, 32, 12, 1, '2020-09-22'), +(22, 37, 10, 10, '2020-05-05'), +(23, 3, 25, 7, '2020-09-23'), +(24, 27, 8, 10, '2020-08-23'), +(25, 6, 30, 3, '2020-12-11'), +(26, 7, 3, 5, '2020-08-17'), +(27, 14, 3, 5, '2020-03-26'), +(28, 14, 11, 3, '2020-04-15'), +(29, 28, 17, 5, '2020-09-27'), +(30, 7, 18, 9, '2020-11-30'), +(31, 22, 6, 8, '2020-06-19'), +(32, 14, 1, 9, '2020-06-05'), +(33, 28, 30, 4, '2020-04-23'), +(34, 15, 10, 3, '2020-04-05'), +(35, 19, 29, 9, '2020-04-24'), +(36, 17, 11, 8, '2020-06-11'), +(37, 34, 18, 1, '2020-04-04'), +(38, 19, 13, 10, '2020-10-07'), +(39, 36, 27, 4, '2020-10-25'), +(40, 3, 12, 8, '2020-06-09'), +(41, 7, 7, 8, '2020-07-17'), +(42, 25, 10, 4, '2020-02-09'), +(43, 5, 16, 2, '2020-09-10'), +(44, 25, 8, 8, '2020-09-24'), +(45, 4, 15, 5, '2020-11-01'), +(46, 38, 20, 10, '2020-03-09'), +(47, 10, 2, 10, '2020-05-29'), +(48, 22, 12, 8, '2020-09-15'), +(49, 30, 22, 1, '2020-11-17'), +(50, 3, 5, 5, '2020-12-07'), +(51, 14, 25, 2, '2020-08-26'), +(52, 36, 11, 8, '2020-06-12'), +(53, 26, 14, 1, '2020-08-27'), +(54, 38, 28, 5, '2020-11-04'), +(55, 19, 18, 3, '2020-01-02'), +(56, 29, 9, 1, '2020-06-04'), +(57, 26, 4, 7, '2020-04-17'), +(58, 33, 4, 5, '2020-02-21'), +(59, 17, 24, 8, '2020-06-19'), +(60, 7, 7, 10, '2020-06-25'), +(61, 25, 17, 1, '2020-11-23'), +(62, 25, 4, 9, '2020-05-15'), +(63, 22, 19, 8, '2020-05-30'), +(64, 24, 28, 2, '2020-03-14'), +(65, 34, 7, 1, '2020-12-28'), +(66, 23, 30, 10, '2020-05-18'), +(67, 12, 23, 2, '2020-03-21'), +(68, 26, 29, 8, '2020-06-06'), +(69, 14, 14, 9, '2020-06-09'), +(70, 4, 14, 6, '2020-03-01'), +(71, 37, 10, 9, '2020-10-13'), +(72, 29, 5, 1, '2020-12-19'), +(73, 37, 16, 3, '2020-05-23'), +(74, 29, 25, 6, '2020-04-02'), +(75, 26, 24, 2, '2020-05-14'), +(76, 32, 18, 6, '2020-11-19'), +(77, 5, 20, 5, '2020-03-24'), +(78, 26, 26, 3, '2020-01-09'), +(79, 8, 30, 8, '2020-03-07'), +(80, 4, 26, 5, '2020-05-24'), +(81, 16, 4, 1, '2020-02-08'), +(82, 21, 17, 3, '2020-03-29'), +(83, 8, 10, 7, '2020-04-17'), +(84, 10, 32, 9, '2020-02-13'), +(85, 9, 22, 4, '2020-11-04'), +(86, 10, 3, 1, '2020-08-30'), +(87, 5, 3, 2, '2020-12-28'), +(88, 23, 18, 7, '2020-04-07'), +(89, 9, 32, 9, '2020-03-16'), +(90, 13, 10, 4, '2020-10-13'), +(91, 4, 21, 4, '2020-04-23'), +(92, 20, 11, 1, '2020-06-08'), +(93, 23, 1, 5, '2020-01-02'), +(94, 11, 11, 4, '2020-09-28'), +(95, 11, 19, 7, '2020-12-06'), +(96, 31, 25, 8, '2020-12-15'), +(97, 10, 7, 9, '2020-10-20'), +(98, 27, 28, 1, '2020-02-25'), +(99, 34, 28, 7, '2020-04-30'), +(100, 38, 3, 6, '2020-03-21'), +(101, 15, 14, 4, '2020-09-02'), +(102, 33, 6, 4, '2020-12-26'), +(103, 17, 2, 4, '2020-03-06'), +(104, 25, 7, 10, '2020-07-05'), +(105, 31, 8, 10, '2020-04-27'), +(106, 14, 32, 4, '2020-09-03'), +(107, 3, 17, 4, '2020-10-21'), +(108, 33, 4, 2, '2020-06-09'), +(109, 2, 28, 9, '2020-03-01'), +(110, 8, 1, 8, '2020-02-08'), +(111, 23, 16, 4, '2020-11-08'), +(112, 38, 31, 5, '2020-02-04'), +(113, 30, 19, 9, '2020-06-03'), +(114, 4, 26, 6, '2020-05-02'), +(115, 29, 20, 6, '2020-07-16'), +(116, 37, 32, 9, '2020-08-08'), +(117, 24, 6, 9, '2020-08-28'), +(118, 10, 31, 5, '2020-10-09'), +(119, 7, 29, 10, '2020-10-20'), +(120, 24, 1, 2, '2020-08-17'), +(121, 31, 8, 9, '2020-01-22'), +(122, 16, 29, 5, '2020-08-08'), +(123, 8, 15, 9, '2020-12-01'), +(124, 32, 20, 8, '2020-04-26'), +(125, 8, 22, 10, '2020-08-15'), +(126, 6, 23, 2, '2020-02-08'), +(127, 36, 21, 5, '2020-11-20'), +(128, 18, 23, 10, '2020-05-19'), +(129, 22, 4, 2, '2020-10-17'), +(130, 17, 25, 5, '2020-03-22'), +(131, 29, 10, 7, '2020-02-08'), +(132, 34, 21, 7, '2020-07-30'), +(133, 34, 24, 10, '2020-03-10'), +(134, 24, 32, 1, '2020-08-12'), +(135, 19, 21, 4, '2020-10-07'), +(136, 5, 27, 2, '2020-01-09'), +(137, 38, 13, 6, '2020-01-18'), +(138, 33, 7, 2, '2020-10-13'), +(139, 20, 27, 3, '2020-05-25'), +(140, 1, 26, 4, '2020-02-28'), +(141, 17, 16, 2, '2020-01-02'), +(142, 1, 26, 9, '2020-11-04'), +(143, 15, 14, 3, '2020-06-29'), +(144, 38, 20, 5, '2020-06-27'), +(145, 11, 30, 10, '2020-06-13'), +(146, 37, 15, 6, '2020-09-27'), +(147, 15, 6, 1, '2020-06-24'), +(148, 35, 6, 2, '2020-11-06'), +(149, 12, 1, 5, '2020-12-22'), +(150, 20, 9, 2, '2020-11-12'), +(151, 3, 11, 9, '2020-08-04'), +(152, 22, 22, 1, '2020-06-21'), +(153, 38, 32, 3, '2020-09-15'), +(154, 13, 7, 5, '2020-09-21'), +(155, 27, 26, 8, '2020-05-10'), +(156, 3, 29, 5, '2020-09-04'), +(157, 29, 2, 8, '2020-04-08'), +(158, 31, 6, 4, '2020-04-29'), +(159, 21, 25, 5, '2020-05-05'), +(160, 7, 3, 2, '2020-02-05'), +(161, 22, 16, 8, '2020-10-01'), +(162, 32, 27, 3, '2020-04-29'), +(163, 22, 19, 4, '2020-12-01'), +(164, 26, 9, 1, '2020-12-15'), +(165, 19, 4, 10, '2020-09-29'), +(166, 2, 24, 10, '2020-07-06'), +(167, 14, 14, 10, '2020-08-15'), +(168, 1, 9, 7, '2020-11-13'), +(169, 1, 31, 9, '2020-09-07'), +(170, 31, 15, 3, '2020-07-04'), +(171, 33, 8, 6, '2020-01-03'), +(172, 15, 23, 7, '2020-11-26'), +(173, 15, 4, 8, '2020-01-09'), +(174, 14, 16, 5, '2020-05-21'), +(175, 17, 16, 1, '2020-05-27'), +(176, 38, 31, 10, '2020-11-20'), +(177, 38, 25, 5, '2020-12-02'), +(178, 20, 5, 10, '2020-08-04'), +(179, 28, 18, 2, '2020-04-22'), +(180, 15, 28, 8, '2020-04-10'), +(181, 36, 24, 9, '2020-04-07'), +(182, 21, 2, 6, '2020-11-12'), +(183, 4, 27, 10, '2020-04-13'), +(184, 1, 14, 10, '2020-12-06'), +(185, 38, 27, 5, '2020-04-16'), +(186, 34, 17, 6, '2020-01-31'), +(187, 2, 9, 6, '2020-09-15'), +(188, 24, 11, 6, '2020-09-09'), +(189, 7, 17, 6, '2020-07-08'), +(190, 4, 29, 9, '2020-10-18'), +(191, 6, 1, 9, '2020-05-21'), +(192, 33, 16, 1, '2020-10-08'), +(193, 30, 10, 1, '2020-05-18'), +(194, 35, 9, 2, '2020-10-20'), +(195, 12, 31, 10, '2020-08-29'), +(196, 20, 8, 4, '2020-12-04'), +(197, 8, 5, 4, '2020-05-13'), +(198, 7, 14, 7, '2020-04-11'), +(199, 12, 33, 1, '2020-03-07'); + +ALTER TABLE `foglalasok` + MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=200; + + + diff --git a/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/megoldasok.sql b/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/megoldasok.sql new file mode 100644 index 0000000..3f80949 --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Kékhegy szálló/megoldasok.sql @@ -0,0 +1,18 @@ +-- 14. feladat: +CREATE DATABASE kekhegy CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + +-- 16. feladat: +SELECT COUNT(szobak.id) AS `masodik_emeleti_szobak_szama` FROM `szobak` WHERE szobak.emelet = 2; + +-- 17. feladat: +SELECT foglalasok.szobaId, foglalasok.napok FROM `foglalasok` INNER JOIN vendegek On foglalasok.vendegId = vendegek.id WHERE vendegek.nev = "Lugosi Béla"; + +-- 18. feladat: +INSERT INTO szobak(emelet, szobaszam, ferohelyek, ar, megjegyzes) VALUES(3, 301, 2, 15000, "Tetőtéri szoba") + +--19. feladat: +SELECT szobak.id, szobak.szobaszam, szobak.megjegyzes, SUM(foglalasok.napok) AS `szumma_nap` FROM `foglalasok` INNER JOIN szobak ON foglalasok.szobaId = szobak.id GROUP BY szobak.id ORDER BY SUM(foglalasok.napok) DESC LIMIT 5; + +-- 20. feladat: +SELECT vendegek.nev AS `foglalo_neve`, szobak.ar * foglalasok.napok AS `szumma_ar` FROM `foglalasok` INNER JOIN szobak ON foglalasok.szobaId = szobak.id INNER JOIN vendegek ON foglalasok.vendegId = vendegek.id GROUP BY vendegek.nev ORDER BY szobak.ar * foglalasok.napok DESC LIMIT 1; + diff --git a/Suli/11.b/Adatbázis/Érettségi/Mozi/adatbazis.sql b/Suli/11.b/Adatbázis/Érettségi/Mozi/adatbazis.sql new file mode 100644 index 0000000..aa41661 --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Mozi/adatbazis.sql @@ -0,0 +1,2719 @@ +-- Film stílusok +CREATE TABLE filmtipus +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(32) NOT NULL, + primary key (id) +); + +-- Vendégek +CREATE TABLE vendeg +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL, + primary key (id) +); + +-- Filmek +create TABLE film +( + id int NOT NULL, + cim varchar(64) NOT NULL, + filmtipusId int NOT NULL, + jegyar int NOT NULL, + primary key (id), + key filmtipusId (filmtipusId), + CONSTRAINT FK_film_filmtipusId FOREIGN KEY (filmtipusId) + REFERENCES filmtipus (id) +); + +-- Vetítések +create TABLE vetites +( + id int NOT NULL, + filmId int NOT NULL, + datum date NOT NULL, + kezdes time NOT NULL, + primary key (id), + key filmId (filmId), + CONSTRAINT FK_vetites_filmId FOREIGN KEY (filmId) + REFERENCES film (id) +); + +-- Eladott jegyek +create TABLE jegy +( + id int NOT NULL AUTO_INCREMENT, + kedvezmeny int NOT NULL, + vetitesId int NOT NULL, + vendegId int NOT NULL, + primary key (id), + key vetitesId (vetitesId), + CONSTRAINT FK_jegy_vetitesId FOREIGN KEY (vetitesId) + REFERENCES vetites (id), + key vendegId (vendegId), + CONSTRAINT FK_jegy_vendegId FOREIGN KEY (vendegId) + REFERENCES vendeg (id) +); + + +-- Adatok beszúrása + + +INSERT INTO vendeg (id, nev) +VALUES (1, 'Nagy Bence'), + (2, 'Kovács Máté'), + (3, 'Tóth Levente'), + (4, 'Szabó Dominik'), + (5, 'Horváth Marcell'), + (6, 'Varga Noel'), + (7, 'Kiss Ádám'), + (8, 'Molnár Dániel'), + (9, 'Németh Dávid'), + (10, 'Farkas Olivér'), + (11, 'Balogh Milán'), + (12, 'Papp Zalán'), + (13, 'Lakatos Botond'), + (14, 'Takács Benett'), + (15, 'Juhász Zsombor'), + (16, 'Mészáros Balázs'), + (17, 'Oláh Áron'), + (18, 'Simon Péter'), + (19, 'Rácz Kristóf'), + (20, 'Fekete Tamás'), + (21, 'Szilágyi Márk'), + (22, 'Török Benedek'), + (23, 'Fehér Gergő'), + (24, 'Balázs László'), + (25, 'Gál Nimród'), + (26, 'Kis Bálint'), + (27, 'Szűcs Zétény'), + (28, 'Kocsis Ákos'), + (29, 'Orsós Patrik'), + (30, 'Pintér Zoltán'), + (31, 'Fodor András'), + (32, 'Szalai Attila'), + (33, 'Sipos Hunor'), + (34, 'Magyar Barnabás'), + (35, 'Lukács Márton'), + (36, 'Gulyás Gábor'), + (37, 'Biró Alex'), + (38, 'Király Martin'), + (39, 'László István'), + (40, 'Balog Kornél'), + (41, 'Katona Vince'), + (42, 'Bogdán József'), + (43, 'Jakab János'), + (44, 'Sándor Krisztián'), + (45, 'Boros Zsolt'), + (46, 'Váradi Zente'), + (47, 'Fazekas Sándor'), + (48, 'Kelemen Erik'), + (49, 'Antal Bendegúz'), + (50, 'Orosz Roland'), + (51, 'Somogyi Richárd'), + (52, 'Fülöp Ábel'), + (53, 'Veres Csaba'), + (54, 'Vincze Róbert'), + (55, 'Budai Kevin'), + (56, 'Hegedűs Nolen'), + (57, 'Deák Soma'), + (58, 'Pap Ármin'), + (59, 'Bálint Mihály'), + (60, 'Illés Vencel'), + (61, 'Pál Norbert'), + (62, 'Vass Mátyás'), + (63, 'Szőke Ferenc'), + (64, 'Fábián Tibor'), + (65, 'Vörös Nándor'), + (66, 'Lengyel Benjámin'), + (67, 'Bognár Szabolcs'), + (68, 'Bodnár Benjamin'), + (69, 'Jónás Simon'), + (70, 'Szücs Gergely'), + (71, 'Hajdu Csongor'), + (72, 'Halász Viktor'), + (73, 'Máté Miklós'), + (74, 'Székely Nikolasz'), + (75, 'Kozma Vilmos'), + (76, 'Gáspár Boldizsár'), + (77, 'Pásztor Kende'), + (78, 'Bakos Imre'), + (79, 'Dudás Bertalan'), + (80, 'Major Brendon'), + (81, 'Orbán Zénó'), + (82, 'Virág Adrián'), + (83, 'Hegedüs Dorián'), + (84, 'Barna Krisztofer'), + (85, 'Novák György'), + (86, 'Soós Alexander'), + (87, 'Tamás Lajos'), + (88, 'Nemes Dénes'), + (89, 'Pataki Félix'), + (90, 'Balla Sámuel'), + (91, 'Faragó Denisz'), + (92, 'Kerekes Bende'), + (93, 'Borbély Noé'), + (94, 'Barta Károly'), + (95, 'Péter Donát'), + (96, 'Csonka Gyula'), + (97, 'Mezei Gellért'), + (98, 'Sárközi Mirkó'), + (99, 'Szekeres Vendel'), + (100, 'Márton Brájen'), + (101, 'Nagy Hanna'), + (102, 'Kovács Anna'), + (103, 'Tóth Zoé'), + (104, 'Szabó Luca'), + (105, 'Horváth Léna'), + (106, 'Varga Emma'), + (107, 'Kiss Zsófia'), + (108, 'Molnár Lili'), + (109, 'Németh Boglárka'), + (110, 'Farkas Mira'), + (111, 'Balogh Lilien'), + (112, 'Papp Nóra'), + (113, 'Lakatos Jázmin'), + (114, 'Takács Laura'), + (115, 'Juhász Maja'), + (116, 'Mészáros Sára'), + (117, 'Oláh Lara'), + (118, 'Simon Lilla'), + (119, 'Rácz Izabella'), + (120, 'Fekete Gréta'), + (121, 'Szilágyi Alíz'), + (122, 'Török Fanni'), + (123, 'Fehér Adél'), + (124, 'Balázs Flóra'), + (125, 'Gál Csenge'), + (126, 'Kis Dóra'), + (127, 'Szűcs Dorina'), + (128, 'Kocsis Zselyke'), + (129, 'Orsós Réka'), + (130, 'Pintér Dorka'), + (131, 'Fodor Liza'), + (132, 'Szalai Janka'), + (133, 'Sipos Liliána'), + (134, 'Magyar Olívia'), + (135, 'Lukács Viktória'), + (136, 'Gulyás Eszter'), + (137, 'Biró Natasa'), + (138, 'Király Noémi'), + (139, 'László Petra'), + (140, 'Balog Bianka'), + (141, 'Katona Szofia'), + (142, 'Bogdán Panna'), + (143, 'Jakab Vivien'), + (144, 'Sándor Emília'), + (145, 'Boros Szófia'), + (146, 'Váradi Rebeka'), + (147, 'Fazekas Kamilla'), + (148, 'Kelemen Blanka'); + +INSERT INTO filmtipus (id, nev) +VALUES (1, 'Dokumentumfilm'), + (2, 'Űropera'), + (3, 'Művész'), + (4, 'Képregény'); + +INSERT INTO film (id, cim, filmtipusId, jegyar) +VALUES (1, 'A kozmosz', 1, 1300), + (2, 'A Mars generáció', 1, 1300), + (3, 'Star Wars: Egy új remény', 2, 890), + (4, 'Avatar', 2, 1300), + (5, 'Dűne', 2, 890), + (6, 'Interstellar', 2, 1300), + (7, 'La Jetéé', 3, 890), + (8, 'Solaris',3, 890), + (9, 'A földre pottyant férfi',3,890 ), + (10, '2001: Űrodüsszeia', 3, 990), + (11, 'Az ötödik elem', 4, 690), + (12, 'A galaxis űrzői', 4, 1300), + (13, 'Thor: Ragnarök', 4, 1300); + +INSERT INTO vetites(id, filmId, datum, kezdes) +VALUES(1, 3, '2021.03.01.', '10:00'), + (2, 3, '2021.03.01.', '12:00'), + (3, 3, '2021.03.01.', '16:00'), + (4, 5, '2021.03.01.', '20:00'), + (5, 7, '2021.03.02.', '10:00'), + (6, 1, '2021.03.03.', '10:00'), + (7, 1, '2021.03.03.', '12:00'), + (8, 1, '2021.03.04.', '10:00'), + (9, 3, '2021.03.04.', '12:00'), + (10, 12, '2021.03.05.', '10:00'), + (11, 11, '2021.03.05.', '12:00'), + (12, 12, '2021.03.05.', '16:00'), + (13, 12, '2021.03.05.', '20:00'), + (14, 1, '2021.03.06.', '10:00'), + (15, 1, '2021.03.06.', '12:00'), + (16, 5, '2021.03.06.', '16:00'), + (17, 5, '2021.03.06.', '20:00'), + (18, 6, '2021.03.07.', '10:00'), + (19, 6, '2021.03.07.', '12:00'), + (20, 8, '2021.03.07.', '16:00'), + (21, 1, '2021.03.08.', '10:00'), + (22, 10, '2021.03.09.', '10:00'), + (23, 10, '2021.03.09.', '12:00'), + (24, 10, '2021.03.09.', '16:00'), + (25, 6, '2021.03.09.', '20:00'), + (26, 10, '2021.03.10.', '10:00'), + (27, 10, '2021.03.10.', '12:00'), + (28, 10, '2021.03.10.', '16:00'), + (29, 10, '2021.03.10.', '20:00'), + (30, 11, '2021.03.11.', '10:00'), + (31, 11, '2021.03.11.', '12:00'), + (32, 3, '2021.03.12.', '10:00'), + (33, 3, '2021.03.12.', '12:00'), + (34, 3, '2021.03.12.', '16:00'), + (35, 6, '2021.03.12.', '20:00'), + (36, 13, '2021.03.13.', '10:00'), + (37, 9, '2021.03.13.', '12:00'), + (38, 13, '2021.03.13.', '16:00'), + (39, 4, '2021.03.14.', '10:00'), + (40, 4, '2021.03.14.', '12:00'), + (41, 4, '2021.03.14.', '16:00'), + (42, 13, '2021.03.15.', '10:00'), + (43, 13, '2021.03.15.', '12:00'), + (44, 11, '2021.03.15.', '16:00'), + (45, 4, '2021.03.16.', '10:00'), + (46, 13, '2021.03.16.', '12:00'), + (47, 13, '2021.03.16.', '16:00'), + (48, 4, '2021.03.16.', '20:00'), + (49, 3, '2021.03.17.', '10:00'), + (50, 7, '2021.03.18.', '10:00'), + (51, 4, '2021.03.18.', '12:00'), + (52, 4, '2021.03.18.', '16:00'), + (53, 8, '2021.03.19.', '10:00'), + (54, 4, '2021.03.20.', '10:00'), + (55, 6, '2021.03.20.', '12:00'), + (56, 10, '2021.03.21.', '10:00'), + (57, 10, '2021.03.21.', '12:00'), + (58, 4, '2021.03.22.', '10:00'), + (59, 2, '2021.03.22.', '12:00'), + (60, 2, '2021.03.22.', '16:00'), + (61, 2, '2021.03.23.', '10:00'), + (62, 2, '2021.03.23.', '12:00'), + (63, 8, '2021.03.24.', '10:00'), + (64, 6, '2021.03.24.', '12:00'), + (65, 8, '2021.03.24.', '16:00'), + (66, 6, '2021.03.25.', '10:00'), + (67, 5, '2021.03.25.', '12:00'), + (68, 5, '2021.03.25.', '16:00'), + (69, 12, '2021.03.26.', '10:00'), + (70, 8, '2021.03.27.', '10:00'), + (71, 10, '2021.03.27.', '12:00'), + (72, 10, '2021.03.27.', '16:00'), + (73, 3, '2021.03.28.', '10:00'), + (74, 3, '2021.03.28.', '12:00'), + (75, 8, '2021.03.28.', '16:00'), + (76, 8, '2021.03.28.', '20:00'), + (77, 11, '2021.03.29.', '10:00'), + (78, 11, '2021.03.29.', '12:00'), + (79, 11, '2021.03.29.', '16:00'), + (80, 11, '2021.03.29.', '20:00'), + (81, 10, '2021.03.30.', '10:00'), + (82, 11, '2021.03.31.', '10:00'), + (83, 8, '2021.03.31.', '12:00'), + (84, 8, '2021.03.31.', '16:00'), + (85, 8, '2021.03.31.', '20:00'); + +INSERT INTO jegy(id, kedvezmeny, vetitesId, vendegId) +VALUES (1, 0, 1, 86), + (2, 0, 1, 5), + (3, 0, 1, 118), + (4, 0, 1, 14), + (5, 50, 1, 26), + (6, 0, 1, 84), + (7, 50, 1, 147), + (8, 25, 1, 44), + (9, 0, 1, 69), + (10, 50, 1, 147), + (11, 50, 1, 31), + (12, 0, 1, 118), + (13, 0, 1, 99), + (14, 0, 1, 113), + (15, 25, 1, 94), + (16, 50, 1, 94), + (17, 0, 1, 88), + (18, 50, 1, 85), + (19, 25, 1, 55), + (20, 50, 1, 36), + (21, 0, 1, 141), + (22, 0, 1, 124), + (23, 0, 1, 96), + (24, 25, 1, 95), + (25, 25, 2, 30), + (26, 0, 2, 49), + (27, 0, 2, 139), + (28, 50, 2, 13), + (29, 50, 2, 52), + (30, 0, 2, 119), + (31, 25, 2, 125), + (32, 0, 2, 100), + (33, 25, 2, 86), + (34, 50, 2, 58), + (35, 50, 2, 1), + (37, 25, 2, 79), + (38, 25, 2, 124), + (39, 0, 2, 88), + (40, 50, 2, 102), + (41, 0, 2, 109), + (42, 0, 2, 98), + (43, 0, 3, 143), + (44, 25, 3, 10), + (45, 0, 3, 101), + (46, 50, 3, 14), + (47, 0, 3, 114), + (48, 0, 3, 137), + (49, 0, 3, 7), + (50, 0, 3, 35), + (51, 0, 3, 92), + (52, 50, 3, 58), + (53, 50, 3, 72), + (54, 0, 3, 8), + (55, 0, 3, 30), + (56, 0, 3, 122), + (57, 50, 3, 110), + (58, 0, 3, 125), + (59, 0, 3, 60), + (60, 0, 3, 146), + (61, 0, 3, 72), + (62, 0, 3, 88), + (63, 0, 3, 56), + (64, 0, 4, 61), + (65, 0, 4, 61), + (66, 0, 4, 29), + (67, 50, 4, 34), + (68, 25, 4, 123), + (69, 0, 4, 145), + (70, 0, 4, 87), + (71, 0, 4, 131), + (72, 50, 4, 76), + (73, 0, 4, 96), + (74, 0, 4, 35), + (75, 0, 4, 120), + (76, 0, 4, 50), + (77, 0, 4, 114), + (78, 0, 4, 40), + (79, 25, 4, 35), + (80, 25, 4, 94), + (81, 25, 4, 79), + (82, 25, 5, 146), + (83, 0, 5, 136), + (84, 0, 5, 41), + (85, 0, 5, 91), + (86, 50, 5, 137), + (87, 0, 5, 87), + (88, 0, 5, 56), + (89, 50, 5, 98), + (90, 0, 5, 71), + (91, 0, 5, 126), + (92, 50, 5, 50), + (93, 50, 5, 64), + (94, 0, 5, 127), + (95, 0, 5, 112), + (96, 0, 5, 88), + (97, 0, 5, 1), + (98, 0, 5, 80), + (99, 50, 5, 67), + (100, 0, 5, 106), + (101, 50, 6, 75), + (102, 0, 6, 31), + (103, 0, 6, 58), + (104, 0, 6, 126), + (105, 0, 6, 114), + (106, 0, 6, 20), + (107, 50, 6, 69), + (108, 50, 6, 1), + (109, 0, 6, 59), + (110, 50, 6, 147), + (111, 0, 6, 24), + (112, 50, 6, 45), + (113, 0, 6, 120), + (114, 0, 6, 31), + (115, 0, 6, 148), + (116, 0, 6, 148), + (117, 50, 6, 35), + (118, 0, 6, 10), + (119, 0, 6, 104), + (120, 0, 6, 54), + (121, 0, 6, 33), + (122, 50, 6, 73), + (123, 50, 6, 79), + (124, 50, 6, 140), + (125, 0, 6, 142), + (126, 50, 6, 1), + (127, 50, 6, 77), + (128, 50, 6, 99), + (129, 0, 6, 24), + (130, 25, 6, 123), + (131, 50, 6, 82), + (132, 25, 6, 132), + (133, 0, 6, 121), + (134, 0, 6, 29), + (135, 0, 6, 128), + (136, 50, 6, 102), + (137, 0, 6, 139), + (138, 0, 6, 52), + (139, 0, 6, 131), + (140, 0, 6, 110), + (141, 50, 6, 91), + (142, 0, 6, 53), + (143, 0, 7, 95), + (144, 0, 7, 145), + (145, 0, 7, 85), + (146, 50, 7, 122), + (147, 0, 7, 108), + (148, 50, 7, 48), + (149, 0, 7, 23), + (150, 50, 7, 41), + (151, 0, 7, 32), + (152, 0, 7, 90), + (153, 50, 7, 96), + (154, 0, 7, 58), + (155, 0, 7, 12), + (156, 50, 7, 98), + (157, 50, 7, 103), + (158, 0, 7, 18), + (159, 50, 7, 25), + (160, 25, 7, 148), + (161, 50, 7, 8), + (162, 0, 7, 31), + (163, 0, 7, 71), + (164, 0, 7, 93), + (165, 0, 7, 117), + (166, 0, 7, 122), + (167, 0, 7, 1), + (168, 25, 7, 20), + (169, 0, 7, 58), + (170, 50, 7, 30), + (171, 0, 8, 5), + (172, 0, 8, 69), + (173, 0, 8, 32), + (174, 0, 8, 106), + (175, 0, 8, 30), + (176, 0, 8, 103), + (177, 0, 8, 85), + (178, 50, 8, 68), + (179, 0, 8, 96), + (180, 0, 8, 23), + (181, 50, 8, 58), + (182, 25, 8, 34), + (183, 50, 8, 74), + (184, 0, 8, 1), + (185, 0, 8, 20), + (186, 0, 8, 108), + (187, 0, 8, 23), + (188, 0, 8, 48), + (189, 0, 8, 80), + (190, 0, 8, 96), + (191, 50, 8, 97), + (192, 0, 8, 124), + (193, 50, 8, 91), + (194, 0, 8, 59), + (195, 0, 8, 49), + (196, 0, 8, 141), + (197, 0, 8, 73), + (198, 50, 8, 139), + (199, 0, 8, 63), + (200, 0, 9, 135), + (201, 0, 9, 132), + (202, 50, 9, 105), + (203, 50, 9, 71), + (204, 50, 9, 96), + (205, 25, 9, 53), + (206, 0, 9, 116), + (207, 25, 9, 53), + (208, 0, 9, 114), + (209, 50, 9, 87), + (210, 50, 9, 126), + (211, 0, 9, 52), + (212, 0, 9, 97), + (213, 0, 9, 71), + (214, 0, 9, 77), + (215, 50, 9, 90), + (216, 0, 9, 24), + (217, 0, 9, 4), + (218, 0, 9, 114), + (219, 0, 9, 135), + (220, 50, 9, 123), + (221, 0, 9, 83), + (222, 50, 9, 73), + (223, 0, 9, 50), + (224, 0, 10, 85), + (225, 0, 10, 111), + (226, 0, 10, 116), + (227, 0, 10, 97), + (228, 0, 10, 97), + (229, 0, 10, 140), + (230, 0, 10, 75), + (231, 50, 10, 25), + (232, 0, 10, 138), + (233, 0, 10, 13), + (234, 0, 10, 131), + (235, 50, 10, 87), + (236, 0, 10, 56), + (237, 25, 10, 107), + (238, 0, 10, 51), + (239, 0, 10, 1), + (240, 50, 11, 36), + (241, 0, 11, 131), + (242, 0, 11, 113), + (243, 0, 11, 116), + (244, 0, 11, 132), + (245, 0, 11, 23), + (246, 0, 11, 2), + (247, 0, 11, 89), + (248, 50, 11, 58), + (249, 50, 11, 95), + (250, 50, 11, 55), + (251, 50, 11, 71), + (252, 0, 11, 53), + (253, 50, 11, 71), + (254, 50, 11, 4), + (255, 0, 11, 33), + (256, 25, 11, 113), + (257, 50, 11, 1), + (258, 0, 11, 120), + (259, 50, 11, 137), + (260, 50, 11, 31), + (261, 0, 11, 131), + (262, 25, 11, 24), + (263, 0, 11, 64), + (264, 50, 11, 130), + (265, 0, 12, 61), + (266, 50, 12, 83), + (267, 50, 12, 105), + (268, 0, 12, 26), + (269, 50, 12, 140), + (270, 0, 12, 57), + (271, 0, 12, 43), + (272, 50, 12, 36), + (273, 0, 12, 70), + (274, 0, 12, 120), + (275, 0, 12, 77), + (276, 50, 12, 121), + (277, 50, 12, 114), + (278, 50, 12, 31), + (279, 50, 12, 7), + (280, 0, 12, 98), + (281, 50, 12, 32), + (282, 25, 12, 113), + (283, 0, 12, 49), + (284, 25, 12, 81), + (285, 25, 12, 105), + (286, 50, 13, 55), + (287, 0, 13, 82), + (288, 0, 13, 44), + (289, 50, 13, 40), + (290, 50, 13, 118), + (291, 0, 13, 69), + (292, 50, 13, 52), + (293, 25, 13, 86), + (294, 50, 13, 131), + (295, 0, 13, 10), + (296, 50, 13, 115), + (297, 0, 13, 58), + (298, 0, 13, 19), + (299, 0, 13, 99), + (300, 50, 14, 37), + (301, 0, 14, 67), + (302, 25, 14, 108), + (303, 50, 14, 64), + (304, 0, 14, 143), + (305, 0, 14, 82), + (306, 50, 14, 104), + (307, 25, 14, 44), + (308, 0, 14, 18), + (309, 0, 14, 119), + (310, 0, 14, 107), + (311, 50, 14, 5), + (312, 0, 14, 129), + (313, 0, 14, 58), + (314, 0, 14, 106), + (315, 0, 14, 110), + (316, 50, 14, 17), + (317, 0, 14, 106), + (318, 25, 14, 52), + (319, 50, 14, 29), + (320, 0, 14, 59), + (321, 0, 14, 113), + (322, 50, 14, 60), + (323, 0, 14, 21), + (324, 0, 14, 137), + (325, 0, 15, 110), + (326, 0, 15, 57), + (327, 0, 15, 28), + (328, 0, 15, 131), + (329, 0, 15, 20), + (330, 50, 15, 49), + (331, 0, 15, 42), + (332, 0, 15, 70), + (333, 0, 15, 106), + (334, 0, 15, 2), + (335, 25, 15, 125), + (336, 0, 15, 131), + (337, 0, 15, 109), + (338, 50, 15, 109), + (339, 0, 15, 119), + (340, 50, 15, 108), + (341, 0, 15, 70), + (342, 0, 15, 15), + (343, 0, 15, 80), + (344, 50, 15, 116), + (345, 50, 15, 135), + (346, 50, 15, 31), + (347, 0, 15, 67), + (348, 0, 15, 17), + (349, 0, 15, 19), + (350, 50, 15, 96), + (351, 50, 15, 129), + (352, 0, 15, 12), + (353, 0, 15, 74), + (354, 0, 15, 100), + (355, 25, 15, 41), + (356, 0, 15, 45), + (357, 50, 15, 84), + (358, 25, 15, 53), + (359, 0, 15, 51), + (360, 0, 16, 6), + (361, 0, 16, 29), + (362, 50, 16, 7), + (363, 0, 16, 87), + (364, 50, 16, 134), + (365, 0, 16, 22), + (366, 0, 16, 55), + (367, 0, 16, 144), + (368, 0, 16, 11), + (369, 0, 16, 41), + (370, 25, 16, 84), + (371, 50, 16, 7), + (372, 50, 16, 127), + (373, 25, 16, 81), + (374, 25, 16, 9), + (375, 50, 16, 5), + (376, 0, 16, 52), + (377, 0, 16, 32), + (378, 0, 16, 33), + (379, 0, 16, 134), + (380, 0, 16, 6), + (381, 0, 16, 114), + (382, 0, 16, 104), + (383, 0, 16, 83), + (384, 0, 16, 72), + (385, 0, 16, 11), + (386, 50, 16, 125), + (387, 0, 16, 73), + (388, 50, 16, 47), + (389, 0, 16, 51), + (390, 50, 16, 147), + (391, 50, 17, 63), + (392, 0, 17, 22), + (393, 50, 17, 51), + (394, 0, 17, 140), + (395, 0, 17, 31), + (396, 50, 17, 121), + (397, 0, 17, 127), + (398, 0, 17, 102), + (399, 0, 17, 96), + (400, 0, 17, 53), + (401, 0, 17, 109), + (402, 0, 17, 125), + (403, 0, 17, 82), + (404, 25, 17, 76), + (405, 0, 17, 1), + (406, 50, 17, 124), + (407, 0, 17, 81), + (408, 0, 17, 142), + (409, 25, 17, 116), + (410, 0, 17, 94), + (411, 50, 17, 5), + (412, 0, 17, 34), + (413, 25, 17, 111), + (414, 50, 17, 20), + (415, 0, 17, 84), + (416, 0, 17, 20), + (417, 0, 17, 25), + (418, 0, 17, 49), + (419, 0, 17, 65), + (420, 0, 17, 135), + (421, 25, 17, 33), + (422, 0, 17, 56), + (423, 50, 17, 132), + (424, 0, 17, 138), + (425, 0, 17, 48), + (426, 0, 17, 104), + (427, 0, 17, 120), + (428, 50, 17, 127), + (429, 0, 18, 91), + (430, 0, 18, 42), + (431, 50, 18, 135), + (432, 0, 18, 77), + (433, 0, 18, 99), + (434, 50, 18, 19), + (435, 0, 18, 56), + (436, 25, 18, 83), + (437, 0, 18, 8), + (438, 50, 18, 109), + (439, 0, 18, 14), + (440, 25, 18, 105), + (441, 25, 18, 79), + (442, 50, 18, 111), + (443, 0, 18, 3), + (444, 0, 18, 132), + (445, 50, 18, 2), + (446, 0, 18, 80), + (447, 0, 18, 95), + (448, 0, 18, 57), + (449, 0, 18, 38), + (450, 0, 18, 102), + (451, 0, 18, 120), + (452, 0, 18, 133), + (453, 50, 18, 66), + (454, 0, 18, 98), + (455, 0, 18, 6), + (456, 0, 18, 118), + (457, 0, 19, 38), + (458, 50, 19, 22), + (459, 0, 19, 144), + (460, 0, 19, 29), + (461, 25, 19, 47), + (462, 50, 19, 51), + (463, 25, 19, 9), + (464, 50, 19, 20), + (465, 50, 19, 67), + (466, 50, 19, 5), + (467, 0, 19, 80), + (468, 0, 19, 51), + (469, 50, 19, 121), + (470, 0, 19, 136), + (471, 50, 19, 112), + (472, 0, 20, 29), + (473, 0, 20, 94), + (474, 0, 20, 136), + (475, 0, 20, 141), + (476, 0, 20, 42), + (477, 0, 20, 45), + (478, 50, 20, 118), + (479, 0, 20, 128), + (480, 0, 20, 99), + (481, 25, 20, 144), + (482, 0, 20, 67), + (483, 0, 20, 47), + (484, 50, 20, 66), + (485, 0, 20, 47), + (486, 0, 20, 99), + (487, 25, 20, 97), + (488, 50, 20, 12), + (489, 0, 20, 34), + (490, 50, 20, 140), + (491, 0, 20, 113), + (492, 0, 20, 86), + (493, 50, 20, 116), + (494, 50, 20, 34), + (495, 0, 20, 64), + (496, 0, 20, 146), + (497, 0, 20, 130), + (498, 0, 20, 91), + (499, 50, 20, 133), + (500, 0, 20, 12), + (501, 50, 20, 103), + (502, 0, 20, 90), + (503, 0, 20, 66), + (504, 0, 20, 23), + (505, 25, 20, 19), + (506, 50, 20, 119), + (507, 0, 20, 116), + (508, 0, 20, 62), + (509, 0, 20, 24), + (510, 0, 21, 51), + (511, 25, 21, 119), + (512, 0, 21, 40), + (513, 50, 21, 46), + (514, 0, 21, 46), + (515, 0, 21, 97), + (516, 0, 21, 122), + (517, 0, 21, 55), + (518, 0, 21, 145), + (519, 0, 21, 99), + (520, 25, 21, 27), + (521, 0, 21, 78), + (522, 25, 21, 114), + (523, 0, 21, 132), + (524, 50, 21, 37), + (525, 0, 21, 47), + (526, 50, 21, 59), + (527, 0, 21, 15), + (528, 50, 21, 112), + (529, 0, 22, 47), + (530, 0, 22, 113), + (531, 25, 22, 88), + (532, 50, 22, 116), + (533, 0, 22, 129), + (534, 50, 22, 117), + (535, 0, 22, 101), + (536, 0, 22, 16), + (537, 0, 22, 117), + (538, 0, 22, 3), + (539, 0, 22, 101), + (540, 0, 22, 118), + (541, 50, 22, 42), + (542, 0, 22, 31), + (543, 0, 22, 79), + (544, 50, 22, 73), + (545, 0, 22, 127), + (546, 0, 22, 85), + (547, 50, 22, 121), + (548, 0, 22, 72), + (549, 50, 22, 34), + (550, 0, 22, 106), + (551, 0, 22, 122), + (552, 0, 22, 99), + (553, 0, 22, 4), + (554, 0, 22, 144), + (555, 50, 22, 49), + (556, 25, 22, 72), + (557, 0, 22, 45), + (558, 0, 22, 122), + (559, 0, 22, 71), + (560, 0, 22, 29), + (561, 0, 22, 143), + (562, 0, 22, 86), + (563, 0, 22, 18), + (564, 0, 23, 16), + (565, 0, 23, 86), + (566, 50, 23, 60), + (567, 0, 23, 47), + (568, 0, 23, 81), + (569, 0, 23, 61), + (570, 25, 23, 84), + (571, 0, 23, 126), + (572, 0, 23, 130), + (573, 0, 23, 78), + (574, 50, 23, 18), + (575, 50, 23, 132), + (576, 25, 23, 44), + (577, 50, 23, 120), + (578, 50, 23, 145), + (579, 0, 23, 116), + (580, 25, 23, 44), + (581, 0, 23, 87), + (582, 0, 23, 55), + (583, 50, 23, 125), + (584, 0, 23, 18), + (585, 25, 23, 97), + (586, 25, 23, 63), + (587, 0, 23, 122), + (588, 50, 23, 102), + (589, 0, 23, 141), + (590, 50, 23, 106), + (591, 0, 23, 67), + (592, 0, 23, 24), + (593, 50, 23, 128), + (594, 50, 23, 54), + (595, 50, 23, 78), + (596, 50, 23, 145), + (597, 0, 23, 61), + (598, 50, 23, 127), + (599, 0, 23, 106), + (600, 0, 24, 147), + (601, 0, 24, 105), + (602, 50, 24, 49), + (603, 50, 24, 126), + (604, 0, 24, 13), + (605, 50, 24, 139), + (606, 50, 24, 38), + (607, 0, 24, 98), + (608, 50, 24, 61), + (609, 50, 24, 146), + (610, 0, 24, 14), + (611, 0, 24, 39), + (612, 50, 24, 11), + (613, 25, 24, 77), + (614, 50, 24, 30), + (615, 0, 24, 95), + (616, 0, 24, 98), + (617, 0, 24, 88), + (618, 0, 24, 94), + (619, 0, 24, 2), + (620, 50, 24, 127), + (621, 50, 24, 63), + (622, 0, 24, 68), + (623, 25, 24, 12), + (624, 0, 24, 78), + (625, 0, 24, 66), + (626, 0, 24, 67), + (627, 0, 24, 44), + (628, 0, 24, 35), + (629, 0, 24, 72), + (630, 0, 24, 87), + (631, 0, 25, 3), + (632, 0, 25, 96), + (633, 50, 25, 44), + (634, 0, 25, 51), + (635, 0, 25, 73), + (636, 0, 25, 85), + (637, 0, 25, 138), + (638, 50, 25, 49), + (639, 0, 25, 101), + (640, 0, 25, 50), + (641, 50, 25, 62), + (642, 0, 25, 102), + (643, 50, 25, 115), + (644, 0, 25, 110), + (645, 0, 25, 118), + (646, 50, 25, 8), + (647, 0, 25, 95), + (648, 0, 25, 87), + (649, 0, 25, 141), + (650, 25, 25, 103), + (651, 0, 26, 26), + (652, 0, 26, 24), + (653, 50, 26, 138), + (654, 0, 26, 1), + (655, 0, 26, 119), + (656, 50, 26, 52), + (657, 0, 26, 26), + (658, 50, 26, 47), + (659, 50, 26, 59), + (660, 50, 26, 1), + (661, 50, 26, 135), + (662, 0, 26, 80), + (663, 25, 26, 45), + (664, 0, 26, 29), + (665, 50, 26, 82), + (666, 0, 26, 118), + (667, 0, 26, 41), + (668, 0, 26, 48), + (669, 50, 26, 73), + (670, 0, 26, 64), + (671, 0, 26, 68), + (672, 0, 26, 18), + (673, 0, 26, 17), + (674, 25, 26, 95), + (675, 50, 26, 105), + (676, 0, 27, 136), + (677, 25, 27, 72), + (678, 0, 27, 138), + (679, 0, 27, 15), + (680, 0, 27, 43), + (681, 50, 27, 112), + (682, 50, 27, 20), + (683, 0, 27, 86), + (684, 0, 27, 61), + (685, 50, 27, 3), + (686, 0, 27, 81), + (687, 25, 27, 47), + (688, 0, 27, 144), + (689, 50, 27, 40), + (690, 0, 27, 112), + (691, 0, 27, 25), + (692, 25, 27, 26), + (693, 0, 27, 57), + (694, 0, 27, 57), + (695, 50, 27, 126), + (696, 0, 27, 45), + (697, 0, 27, 97), + (698, 0, 27, 18), + (699, 50, 27, 89), + (700, 0, 27, 139), + (701, 50, 27, 108), + (702, 50, 27, 36), + (703, 50, 27, 84), + (704, 0, 27, 119), + (705, 0, 27, 7), + (706, 50, 27, 92), + (707, 25, 27, 44), + (708, 0, 27, 33), + (709, 50, 27, 22), + (710, 50, 27, 29), + (711, 0, 27, 32), + (712, 25, 27, 54), + (713, 50, 27, 9), + (714, 0, 27, 127), + (715, 0, 27, 22), + (716, 50, 27, 143), + (717, 0, 27, 42), + (718, 25, 27, 84), + (719, 25, 27, 61), + (720, 0, 27, 26), + (721, 0, 28, 14), + (722, 50, 28, 71), + (723, 25, 28, 19), + (724, 0, 28, 68), + (725, 50, 28, 42), + (726, 50, 28, 18), + (727, 25, 28, 67), + (728, 0, 28, 32), + (729, 50, 28, 105), + (730, 50, 28, 33), + (731, 0, 28, 90), + (732, 25, 28, 43), + (733, 0, 28, 94), + (734, 50, 28, 51), + (735, 0, 28, 5), + (736, 50, 28, 36), + (737, 0, 28, 87), + (738, 0, 28, 5), + (739, 50, 28, 100), + (740, 0, 28, 124), + (741, 50, 28, 118), + (742, 50, 28, 31), + (743, 0, 28, 49), + (744, 0, 28, 1), + (745, 0, 29, 144), + (746, 0, 29, 100), + (747, 0, 29, 89), + (748, 0, 29, 58), + (749, 0, 29, 83), + (750, 0, 29, 70), + (751, 0, 29, 97), + (752, 0, 29, 133), + (753, 0, 29, 71), + (754, 0, 29, 141), + (755, 50, 29, 22), + (756, 25, 29, 30), + (757, 25, 29, 31), + (758, 50, 29, 134), + (759, 0, 29, 10), + (760, 0, 29, 56), + (761, 0, 29, 73), + (762, 50, 29, 18), + (763, 0, 29, 27), + (764, 50, 29, 145), + (765, 0, 29, 21), + (766, 0, 29, 99), + (767, 50, 29, 23), + (768, 0, 29, 144), + (769, 50, 29, 47), + (770, 0, 29, 34), + (771, 50, 29, 117), + (772, 0, 29, 8), + (773, 0, 29, 145), + (774, 0, 29, 100), + (775, 0, 29, 15), + (776, 25, 29, 54), + (777, 50, 29, 87), + (778, 0, 29, 69), + (779, 50, 29, 119), + (780, 50, 30, 112), + (781, 0, 30, 68), + (782, 0, 30, 98), + (783, 0, 30, 75), + (784, 0, 30, 4), + (785, 50, 30, 95), + (786, 50, 30, 102), + (787, 0, 30, 146), + (788, 0, 30, 48), + (789, 0, 30, 108), + (790, 0, 30, 91), + (791, 50, 30, 63), + (792, 0, 30, 120), + (793, 0, 30, 15), + (794, 0, 30, 106), + (795, 0, 30, 83), + (796, 50, 30, 53), + (797, 0, 30, 121), + (798, 50, 30, 63), + (799, 0, 30, 65), + (800, 0, 30, 62), + (801, 50, 30, 32), + (802, 0, 30, 17), + (803, 0, 30, 148), + (804, 0, 30, 134), + (805, 50, 30, 61), + (806, 0, 30, 4), + (807, 50, 30, 80), + (808, 50, 30, 121), + (809, 50, 31, 41), + (810, 50, 31, 20), + (811, 0, 31, 5), + (812, 0, 31, 124), + (813, 50, 31, 75), + (814, 50, 31, 80), + (815, 0, 31, 30), + (816, 50, 31, 34), + (817, 25, 31, 14), + (818, 50, 31, 48), + (819, 0, 31, 96), + (820, 50, 31, 107), + (821, 0, 31, 77), + (822, 0, 31, 72), + (823, 0, 31, 104), + (824, 0, 31, 128), + (825, 50, 31, 121), + (826, 0, 31, 141), + (827, 0, 31, 124), + (828, 25, 31, 2), + (829, 25, 31, 6), + (830, 25, 31, 25), + (831, 0, 31, 90), + (832, 25, 31, 127), + (833, 0, 31, 4), + (834, 0, 31, 87), + (835, 0, 31, 34), + (836, 0, 31, 19), + (837, 0, 31, 46), + (838, 0, 31, 47), + (839, 25, 31, 81), + (840, 0, 31, 115), + (841, 0, 31, 55), + (842, 0, 31, 38), + (843, 0, 31, 87), + (844, 0, 31, 74), + (845, 0, 31, 19), + (846, 0, 31, 117), + (847, 0, 31, 22), + (848, 25, 31, 32), + (849, 0, 31, 71), + (850, 0, 31, 76), + (851, 50, 31, 16), + (852, 50, 31, 102), + (853, 0, 31, 31), + (854, 50, 31, 137), + (855, 25, 31, 60), + (856, 0, 31, 128), + (857, 0, 32, 110), + (858, 25, 32, 93), + (859, 50, 32, 65), + (860, 0, 32, 13), + (861, 25, 32, 24), + (862, 25, 32, 7), + (863, 0, 32, 25), + (864, 50, 32, 72), + (865, 25, 32, 91), + (866, 50, 32, 1), + (867, 25, 32, 138), + (868, 25, 33, 116), + (869, 0, 33, 4), + (870, 0, 33, 113), + (871, 0, 33, 12), + (872, 50, 33, 86), + (873, 0, 33, 88), + (874, 0, 33, 135), + (875, 0, 33, 18), + (876, 25, 33, 24), + (877, 0, 33, 120), + (878, 0, 33, 76), + (879, 50, 33, 109), + (880, 50, 33, 89), + (881, 25, 33, 82), + (882, 0, 33, 117), + (883, 0, 33, 55), + (884, 50, 33, 14), + (885, 50, 33, 89), + (886, 0, 33, 123), + (887, 0, 33, 60), + (888, 0, 33, 18), + (889, 0, 33, 130), + (890, 50, 33, 106), + (891, 0, 33, 72), + (892, 50, 33, 118), + (893, 0, 33, 58), + (894, 50, 33, 74), + (895, 0, 33, 3), + (896, 0, 33, 49), + (897, 0, 33, 91), + (898, 0, 33, 30), + (899, 0, 33, 116), + (900, 0, 33, 44), + (901, 0, 33, 71), + (902, 25, 33, 87), + (903, 50, 33, 91), + (904, 50, 33, 136), + (905, 50, 33, 145), + (906, 50, 33, 60), + (907, 0, 33, 124), + (908, 25, 33, 58), + (909, 0, 33, 66), + (910, 0, 33, 88), + (911, 0, 34, 4), + (912, 0, 34, 102), + (913, 50, 34, 103), + (914, 50, 34, 124), + (915, 25, 34, 110), + (916, 50, 34, 43), + (917, 0, 34, 35), + (918, 0, 34, 72), + (919, 50, 34, 146), + (920, 0, 34, 64), + (921, 50, 34, 64), + (922, 25, 34, 5), + (923, 0, 34, 113), + (924, 0, 34, 45), + (925, 25, 34, 12), + (926, 0, 34, 3), + (927, 0, 34, 126), + (928, 0, 34, 75), + (929, 0, 34, 55), + (930, 0, 34, 124), + (931, 0, 34, 133), + (932, 0, 34, 135), + (933, 0, 34, 21), + (934, 50, 34, 109), + (935, 0, 34, 36), + (936, 0, 34, 110), + (937, 25, 34, 63), + (938, 0, 34, 40), + (939, 50, 34, 41), + (940, 0, 34, 32), + (941, 50, 35, 141), + (942, 50, 35, 115), + (943, 0, 35, 129), + (944, 0, 35, 80), + (945, 0, 35, 70), + (946, 0, 35, 62), + (947, 0, 35, 56), + (948, 0, 35, 104), + (949, 0, 35, 3), + (950, 0, 35, 91), + (951, 25, 35, 51), + (952, 0, 35, 146), + (953, 50, 35, 31), + (954, 0, 35, 3), + (955, 0, 35, 96), + (956, 0, 35, 23), + (957, 50, 35, 58), + (958, 0, 35, 134), + (959, 0, 35, 9), + (960, 25, 35, 88), + (961, 25, 35, 100), + (962, 0, 35, 32), + (963, 0, 35, 131), + (964, 0, 35, 144), + (965, 50, 35, 112), + (966, 25, 35, 20), + (967, 0, 35, 142), + (968, 50, 35, 69), + (969, 0, 35, 18), + (970, 50, 35, 93), + (971, 50, 35, 53), + (972, 0, 35, 59), + (973, 25, 35, 30), + (974, 50, 35, 69), + (975, 0, 35, 77), + (976, 0, 35, 109), + (977, 0, 35, 134), + (978, 50, 35, 14), + (979, 50, 35, 99), + (980, 0, 35, 124), + (981, 0, 35, 83), + (982, 25, 35, 68), + (983, 50, 35, 109), + (984, 25, 35, 98), + (985, 0, 36, 64), + (986, 0, 36, 65), + (987, 0, 36, 144), + (988, 0, 36, 17), + (989, 0, 36, 79), + (990, 50, 36, 123), + (991, 50, 36, 116), + (992, 0, 36, 62), + (993, 0, 36, 114), + (994, 0, 36, 39), + (995, 0, 36, 34), + (996, 0, 36, 3), + (997, 0, 36, 80), + (998, 0, 36, 85), + (999, 0, 36, 74), + (1000, 0, 36, 114), + (1001, 50, 37, 34), + (1002, 50, 37, 95), + (1003, 25, 37, 34), + (1004, 0, 37, 28), + (1005, 0, 37, 52), + (1006, 0, 37, 43), + (1007, 0, 37, 46), + (1008, 50, 37, 59), + (1009, 25, 37, 51), + (1010, 0, 37, 135), + (1011, 0, 37, 124), + (1012, 0, 37, 96), + (1013, 25, 37, 98), + (1014, 25, 37, 103), + (1015, 0, 37, 139), + (1016, 0, 37, 85), + (1017, 50, 37, 57), + (1018, 0, 37, 95), + (1019, 0, 37, 93), + (1020, 0, 37, 69), + (1021, 0, 37, 30), + (1022, 0, 37, 125), + (1023, 25, 37, 59), + (1024, 0, 37, 37), + (1025, 0, 38, 44), + (1026, 0, 38, 36), + (1027, 50, 38, 132), + (1028, 25, 38, 44), + (1029, 25, 38, 120), + (1030, 50, 38, 78), + (1031, 50, 38, 108), + (1032, 0, 38, 2), + (1033, 25, 38, 103), + (1034, 0, 38, 91), + (1035, 0, 38, 135), + (1036, 0, 38, 130), + (1037, 0, 38, 130), + (1038, 0, 39, 42), + (1039, 0, 39, 72), + (1040, 50, 39, 101), + (1041, 0, 39, 45), + (1042, 0, 39, 142), + (1043, 25, 39, 17), + (1044, 0, 39, 131), + (1045, 50, 39, 113), + (1046, 0, 39, 121), + (1047, 25, 39, 106), + (1048, 0, 39, 18), + (1049, 50, 39, 127), + (1050, 0, 39, 3), + (1051, 50, 39, 12), + (1052, 0, 40, 42), + (1053, 0, 40, 91), + (1054, 0, 40, 63), + (1055, 50, 40, 59), + (1056, 0, 40, 66), + (1057, 50, 40, 67), + (1058, 50, 40, 51), + (1059, 50, 40, 41), + (1060, 0, 40, 87), + (1061, 0, 40, 98), + (1062, 50, 40, 56), + (1063, 0, 40, 9), + (1064, 50, 40, 114), + (1065, 0, 40, 95), + (1066, 0, 40, 48), + (1067, 0, 40, 70), + (1068, 0, 40, 81), + (1069, 50, 41, 103), + (1070, 50, 41, 68), + (1071, 0, 41, 78), + (1072, 0, 41, 112), + (1073, 0, 41, 132), + (1074, 25, 41, 142), + (1075, 50, 41, 84), + (1076, 25, 41, 147), + (1077, 0, 41, 33), + (1078, 50, 41, 70), + (1079, 50, 41, 136), + (1080, 25, 41, 68), + (1081, 50, 41, 28), + (1082, 50, 41, 110), + (1083, 0, 41, 135), + (1084, 0, 41, 28), + (1085, 50, 42, 25), + (1086, 0, 42, 103), + (1087, 0, 42, 112), + (1088, 50, 42, 136), + (1089, 25, 42, 35), + (1090, 0, 42, 97), + (1091, 50, 42, 12), + (1092, 50, 42, 119), + (1093, 0, 42, 137), + (1094, 0, 42, 143), + (1095, 0, 42, 132), + (1096, 0, 42, 137), + (1097, 0, 42, 139), + (1098, 50, 42, 72), + (1099, 50, 42, 47), + (1100, 0, 42, 76), + (1101, 0, 42, 60), + (1102, 0, 43, 143), + (1103, 0, 43, 34), + (1104, 50, 43, 130), + (1105, 0, 43, 73), + (1106, 0, 43, 75), + (1107, 50, 43, 17), + (1108, 0, 43, 132), + (1109, 50, 43, 86), + (1110, 0, 43, 102), + (1111, 0, 43, 133), + (1112, 25, 43, 27), + (1113, 0, 43, 73), + (1114, 50, 43, 119), + (1115, 0, 43, 99), + (1116, 0, 43, 76), + (1117, 0, 43, 130), + (1118, 0, 43, 38), + (1119, 50, 43, 56), + (1120, 0, 43, 30), + (1121, 0, 43, 41), + (1122, 50, 43, 73), + (1123, 0, 43, 95), + (1124, 50, 43, 53), + (1125, 0, 43, 36), + (1126, 50, 43, 91), + (1127, 50, 43, 65), + (1128, 50, 43, 31), + (1129, 0, 43, 91), + (1130, 0, 43, 26), + (1131, 50, 44, 57), + (1132, 50, 44, 30), + (1133, 50, 44, 14), + (1134, 50, 44, 128), + (1135, 0, 44, 2), + (1136, 50, 44, 38), + (1137, 0, 44, 50), + (1138, 50, 44, 72), + (1139, 0, 44, 39), + (1140, 0, 44, 51), + (1141, 50, 44, 62), + (1142, 0, 44, 56), + (1143, 50, 44, 64), + (1144, 50, 44, 60), + (1145, 0, 44, 67), + (1146, 0, 44, 139), + (1147, 25, 44, 115), + (1148, 0, 44, 80), + (1149, 50, 45, 51), + (1150, 0, 45, 107), + (1151, 50, 45, 137), + (1152, 50, 45, 101), + (1153, 0, 45, 16), + (1154, 0, 45, 146), + (1155, 0, 45, 82), + (1156, 0, 45, 112), + (1157, 0, 45, 17), + (1158, 0, 45, 93), + (1159, 25, 45, 116), + (1160, 0, 45, 30), + (1161, 0, 45, 148), + (1162, 0, 45, 78), + (1163, 25, 45, 83), + (1164, 0, 45, 137), + (1165, 0, 45, 106), + (1166, 0, 46, 11), + (1167, 50, 46, 121), + (1168, 0, 46, 56), + (1169, 0, 46, 84), + (1170, 0, 46, 52), + (1171, 50, 46, 34), + (1172, 0, 46, 24), + (1173, 0, 46, 110), + (1174, 50, 46, 2), + (1175, 25, 46, 123), + (1176, 50, 46, 116), + (1177, 0, 46, 66), + (1178, 0, 46, 142), + (1179, 50, 46, 27), + (1180, 50, 46, 85), + (1181, 0, 46, 101), + (1182, 50, 46, 47), + (1183, 0, 46, 10), + (1184, 25, 47, 41), + (1185, 50, 47, 7), + (1186, 0, 47, 52), + (1187, 50, 47, 44), + (1188, 0, 47, 58), + (1189, 0, 47, 20), + (1190, 25, 47, 117), + (1191, 0, 47, 138), + (1192, 0, 47, 91), + (1193, 0, 47, 2), + (1194, 0, 47, 67), + (1195, 25, 47, 56), + (1196, 0, 47, 148), + (1197, 0, 47, 87), + (1198, 50, 47, 26), + (1199, 25, 47, 116), + (1200, 25, 47, 136), + (1201, 50, 47, 5), + (1202, 50, 47, 145), + (1203, 25, 47, 141), + (1204, 0, 47, 27), + (1205, 0, 47, 19), + (1206, 0, 47, 96), + (1207, 0, 47, 56), + (1208, 0, 47, 15), + (1209, 0, 47, 102), + (1210, 0, 47, 11), + (1211, 25, 47, 56), + (1212, 50, 47, 20), + (1213, 50, 47, 53), + (1214, 0, 47, 139), + (1215, 50, 47, 104), + (1216, 50, 47, 68), + (1217, 50, 48, 82), + (1218, 50, 48, 9), + (1219, 0, 48, 141), + (1220, 0, 48, 88), + (1221, 50, 48, 10), + (1222, 50, 48, 60), + (1223, 0, 48, 56), + (1224, 0, 48, 10), + (1225, 0, 48, 124), + (1226, 0, 48, 125), + (1227, 0, 48, 66), + (1228, 0, 48, 81), + (1229, 0, 48, 82), + (1230, 0, 48, 2), + (1231, 25, 48, 93), + (1232, 0, 48, 146), + (1233, 0, 48, 38), + (1234, 50, 48, 144), + (1235, 50, 48, 86), + (1236, 0, 48, 43), + (1237, 50, 48, 12), + (1238, 0, 48, 108), + (1239, 0, 48, 94), + (1240, 0, 48, 34), + (1241, 50, 48, 49), + (1242, 0, 48, 57), + (1243, 50, 48, 134), + (1244, 0, 48, 133), + (1245, 0, 48, 148), + (1246, 0, 48, 45), + (1247, 0, 48, 25), + (1248, 0, 48, 95), + (1249, 25, 48, 87), + (1250, 0, 48, 15), + (1251, 50, 48, 48), + (1252, 0, 48, 75), + (1253, 50, 48, 37), + (1254, 0, 48, 18), + (1255, 0, 48, 25), + (1256, 50, 48, 24), + (1257, 50, 48, 1), + (1258, 50, 48, 84), + (1259, 50, 48, 87), + (1260, 25, 48, 139), + (1261, 0, 48, 24), + (1262, 0, 49, 93), + (1263, 0, 49, 69), + (1264, 0, 49, 52), + (1265, 0, 49, 111), + (1266, 0, 49, 7), + (1267, 25, 49, 130), + (1268, 0, 49, 60), + (1269, 0, 49, 125), + (1270, 0, 49, 113), + (1271, 25, 49, 79), + (1272, 50, 49, 25), + (1273, 0, 49, 124), + (1274, 25, 49, 132), + (1275, 0, 50, 45), + (1276, 0, 50, 116), + (1277, 50, 50, 93), + (1278, 50, 50, 125), + (1279, 25, 50, 130), + (1280, 50, 50, 25), + (1281, 0, 50, 134), + (1282, 0, 50, 77), + (1283, 50, 50, 6), + (1284, 0, 50, 26), + (1285, 50, 50, 51), + (1286, 0, 50, 13), + (1287, 0, 50, 132), + (1288, 50, 50, 15), + (1289, 0, 50, 90), + (1290, 50, 50, 118), + (1291, 0, 50, 49), + (1292, 0, 50, 85), + (1293, 0, 50, 86), + (1294, 50, 50, 30), + (1295, 0, 50, 16), + (1296, 50, 50, 65), + (1297, 25, 51, 11), + (1298, 50, 51, 125), + (1299, 0, 51, 123), + (1300, 0, 51, 104), + (1301, 50, 51, 146), + (1302, 0, 51, 52), + (1303, 50, 51, 58), + (1304, 50, 51, 22), + (1305, 50, 51, 16), + (1306, 0, 51, 109), + (1307, 0, 51, 85), + (1308, 0, 51, 100), + (1309, 0, 51, 44), + (1310, 0, 51, 33), + (1311, 50, 51, 20), + (1312, 50, 51, 31), + (1313, 50, 51, 67), + (1314, 25, 51, 87), + (1315, 0, 51, 34), + (1316, 50, 51, 95), + (1317, 0, 51, 32), + (1318, 0, 51, 9), + (1319, 50, 51, 124), + (1320, 25, 51, 73), + (1321, 0, 51, 89), + (1322, 0, 51, 94), + (1323, 0, 51, 109), + (1324, 0, 51, 12), + (1325, 0, 52, 64), + (1326, 50, 52, 36), + (1327, 0, 52, 65), + (1328, 0, 52, 70), + (1329, 0, 52, 83), + (1330, 0, 52, 51), + (1331, 0, 52, 4), + (1332, 25, 52, 109), + (1333, 50, 52, 100), + (1334, 50, 52, 71), + (1335, 0, 52, 78), + (1336, 0, 52, 132), + (1337, 0, 52, 110), + (1338, 0, 52, 143), + (1339, 25, 52, 86), + (1340, 50, 52, 72), + (1341, 0, 52, 33), + (1342, 50, 52, 38), + (1343, 0, 52, 72), + (1344, 0, 53, 117), + (1345, 50, 53, 106), + (1346, 0, 53, 133), + (1347, 0, 53, 121), + (1348, 0, 53, 18), + (1349, 0, 53, 68), + (1350, 25, 53, 44), + (1351, 0, 53, 97), + (1352, 0, 53, 86), + (1353, 0, 53, 37), + (1354, 0, 53, 47), + (1355, 0, 53, 64), + (1356, 50, 53, 92), + (1357, 25, 53, 3), + (1358, 0, 53, 17), + (1359, 0, 53, 42), + (1360, 0, 53, 122), + (1361, 0, 53, 79), + (1362, 50, 53, 70), + (1363, 0, 53, 44), + (1364, 50, 53, 12), + (1365, 50, 53, 5), + (1366, 0, 54, 83), + (1367, 50, 54, 80), + (1368, 0, 54, 30), + (1369, 0, 54, 112), + (1370, 0, 54, 18), + (1371, 25, 54, 117), + (1372, 50, 54, 110), + (1373, 0, 54, 21), + (1374, 0, 54, 68), + (1375, 0, 54, 29), + (1376, 0, 54, 41), + (1377, 50, 54, 31), + (1378, 0, 54, 2), + (1379, 50, 54, 17), + (1380, 50, 54, 59), + (1381, 0, 54, 148), + (1382, 0, 54, 83), + (1383, 50, 54, 29), + (1384, 0, 54, 36), + (1385, 50, 54, 45), + (1386, 0, 54, 84), + (1387, 50, 54, 67), + (1388, 0, 54, 99), + (1389, 50, 54, 86), + (1390, 0, 54, 109), + (1391, 50, 54, 131), + (1392, 0, 54, 88), + (1393, 50, 54, 67), + (1394, 50, 54, 53), + (1395, 0, 54, 11), + (1396, 0, 54, 81), + (1397, 0, 54, 7), + (1398, 0, 54, 27), + (1399, 25, 54, 101), + (1400, 0, 54, 42), + (1401, 0, 54, 67), + (1402, 50, 54, 127), + (1403, 0, 54, 104), + (1404, 0, 54, 62), + (1405, 0, 54, 61), + (1406, 0, 54, 85), + (1407, 0, 54, 5), + (1408, 50, 54, 141), + (1409, 50, 54, 89), + (1410, 0, 54, 145), + (1411, 0, 54, 114), + (1412, 50, 54, 146), + (1413, 0, 54, 3), + (1414, 0, 54, 140), + (1415, 0, 55, 125), + (1416, 0, 55, 145), + (1417, 0, 55, 69), + (1418, 50, 55, 41), + (1419, 25, 55, 144), + (1420, 50, 55, 10), + (1421, 50, 55, 96), + (1422, 25, 55, 29), + (1423, 50, 55, 10), + (1424, 25, 55, 78), + (1425, 0, 55, 80), + (1426, 0, 55, 123), + (1427, 50, 55, 126), + (1428, 0, 55, 7), + (1429, 0, 55, 16), + (1430, 0, 55, 42), + (1431, 50, 55, 126), + (1432, 50, 55, 59), + (1433, 0, 55, 12), + (1434, 0, 55, 51), + (1435, 0, 55, 33), + (1436, 0, 55, 16), + (1437, 0, 55, 75), + (1438, 25, 55, 120), + (1439, 0, 55, 31), + (1440, 0, 55, 120), + (1441, 25, 55, 124), + (1442, 25, 55, 118), + (1443, 50, 55, 148), + (1444, 0, 55, 105), + (1445, 0, 55, 72), + (1446, 0, 55, 65), + (1447, 50, 55, 90), + (1448, 0, 55, 101), + (1449, 0, 55, 134), + (1450, 50, 55, 102), + (1451, 0, 55, 132), + (1452, 0, 55, 131), + (1453, 0, 55, 105), + (1454, 50, 55, 83), + (1455, 50, 55, 22), + (1456, 50, 55, 46), + (1457, 0, 55, 143), + (1458, 0, 55, 16), + (1459, 0, 55, 112), + (1460, 0, 55, 96), + (1461, 50, 55, 28), + (1462, 25, 55, 102), + (1463, 0, 55, 111), + (1464, 0, 56, 71), + (1465, 0, 56, 5), + (1466, 0, 56, 118), + (1467, 50, 56, 21), + (1468, 50, 56, 31), + (1469, 50, 56, 125), + (1470, 0, 56, 21), + (1471, 50, 56, 86), + (1472, 0, 56, 119), + (1473, 0, 56, 68), + (1474, 0, 56, 52), + (1475, 0, 56, 35), + (1476, 0, 56, 95), + (1477, 0, 56, 113), + (1478, 50, 56, 35), + (1479, 0, 56, 42), + (1480, 0, 56, 103), + (1481, 0, 56, 91), + (1482, 50, 56, 42), + (1483, 0, 56, 89), + (1484, 0, 56, 104), + (1485, 50, 56, 133), + (1486, 0, 56, 16), + (1487, 50, 56, 57), + (1488, 0, 56, 39), + (1489, 0, 56, 136), + (1490, 50, 56, 111), + (1491, 0, 56, 111), + (1492, 0, 56, 103), + (1493, 0, 56, 24), + (1494, 0, 56, 107), + (1495, 0, 56, 55), + (1496, 50, 56, 138), + (1497, 50, 56, 59), + (1498, 50, 56, 23), + (1499, 0, 56, 72), + (1500, 0, 56, 56), + (1501, 0, 56, 90), + (1502, 25, 56, 147), + (1503, 50, 56, 23), + (1504, 50, 56, 113), + (1505, 0, 56, 48), + (1506, 50, 56, 69), + (1507, 0, 56, 30), + (1508, 0, 56, 75), + (1509, 50, 56, 32), + (1510, 0, 57, 53), + (1511, 0, 57, 35), + (1512, 0, 57, 120), + (1513, 50, 57, 17), + (1514, 0, 57, 70), + (1515, 0, 57, 87), + (1516, 0, 57, 100), + (1517, 0, 57, 105), + (1518, 0, 57, 57), + (1519, 0, 57, 146), + (1520, 25, 57, 11), + (1521, 50, 57, 9), + (1522, 0, 57, 46), + (1523, 0, 57, 41), + (1524, 50, 57, 83), + (1525, 0, 57, 50), + (1526, 0, 57, 117), + (1527, 0, 57, 63), + (1528, 50, 57, 142), + (1529, 50, 57, 115), + (1530, 25, 57, 98), + (1531, 50, 57, 17), + (1532, 25, 57, 83), + (1533, 0, 57, 112), + (1534, 50, 57, 53), + (1535, 0, 57, 47), + (1536, 0, 57, 76), + (1537, 50, 57, 147), + (1538, 0, 57, 37), + (1539, 0, 57, 143), + (1540, 50, 57, 118), + (1541, 50, 57, 114), + (1542, 0, 57, 39), + (1543, 0, 57, 53), + (1544, 0, 57, 28), + (1545, 0, 57, 43), + (1546, 0, 57, 67), + (1547, 0, 57, 79), + (1548, 50, 57, 98), + (1549, 0, 57, 20), + (1550, 0, 57, 36), + (1551, 50, 57, 29), + (1552, 25, 57, 44), + (1553, 0, 57, 93), + (1554, 0, 57, 86), + (1555, 0, 58, 45), + (1556, 0, 58, 4), + (1557, 0, 58, 71), + (1558, 0, 58, 128), + (1559, 0, 58, 69), + (1560, 0, 58, 95), + (1561, 0, 58, 23), + (1562, 0, 58, 143), + (1563, 25, 58, 133), + (1564, 0, 58, 148), + (1565, 50, 58, 14), + (1566, 50, 58, 128), + (1567, 0, 58, 12), + (1568, 0, 58, 38), + (1569, 0, 58, 130), + (1570, 50, 59, 54), + (1571, 0, 59, 136), + (1572, 0, 59, 88), + (1573, 0, 59, 129), + (1574, 0, 59, 44), + (1575, 0, 59, 97), + (1576, 50, 59, 104), + (1577, 0, 59, 144), + (1578, 0, 59, 99), + (1579, 0, 59, 135), + (1580, 0, 59, 33), + (1581, 0, 59, 142), + (1582, 0, 59, 125), + (1583, 50, 59, 44), + (1584, 0, 59, 94), + (1585, 0, 59, 52), + (1586, 0, 59, 72), + (1587, 50, 59, 82), + (1588, 0, 59, 100), + (1589, 0, 59, 71), + (1590, 0, 59, 140), + (1591, 50, 59, 105), + (1592, 50, 59, 2), + (1593, 0, 59, 46), + (1594, 0, 59, 138), + (1595, 50, 59, 31), + (1596, 50, 60, 28), + (1597, 50, 60, 104), + (1598, 0, 60, 127), + (1599, 0, 60, 89), + (1600, 50, 60, 100), + (1601, 50, 60, 120), + (1602, 50, 60, 43), + (1603, 0, 60, 23), + (1604, 0, 60, 5), + (1605, 0, 60, 65), + (1606, 0, 60, 141), + (1607, 0, 60, 37), + (1608, 0, 60, 76), + (1609, 50, 60, 82), + (1610, 0, 60, 89), + (1611, 0, 60, 16), + (1612, 0, 60, 66), + (1613, 50, 60, 63), + (1614, 25, 60, 78), + (1615, 0, 60, 148), + (1616, 50, 60, 35), + (1617, 0, 60, 116), + (1618, 50, 60, 67), + (1619, 0, 60, 72), + (1620, 50, 60, 85), + (1621, 0, 60, 54), + (1622, 50, 60, 12), + (1623, 25, 60, 24), + (1624, 0, 60, 104), + (1625, 50, 60, 15), + (1626, 0, 60, 101), + (1627, 0, 60, 94), + (1628, 0, 60, 90), + (1629, 50, 60, 3), + (1630, 50, 60, 78), + (1631, 0, 61, 3), + (1632, 25, 61, 29), + (1633, 50, 61, 80), + (1634, 0, 61, 124), + (1635, 0, 61, 83), + (1636, 0, 61, 66), + (1637, 0, 61, 123), + (1638, 0, 61, 128), + (1639, 50, 61, 35), + (1640, 0, 61, 139), + (1641, 0, 61, 112), + (1642, 0, 61, 5), + (1643, 0, 61, 31), + (1644, 50, 61, 131), + (1645, 0, 61, 134), + (1646, 0, 61, 84), + (1647, 50, 61, 47), + (1648, 0, 61, 89), + (1649, 0, 61, 105), + (1650, 0, 61, 70), + (1651, 0, 61, 146), + (1652, 0, 62, 124), + (1653, 0, 62, 126), + (1654, 50, 62, 72), + (1655, 0, 62, 40), + (1656, 0, 62, 110), + (1657, 50, 62, 65), + (1658, 0, 62, 48), + (1659, 50, 62, 7), + (1660, 0, 62, 12), + (1661, 0, 62, 48), + (1662, 0, 62, 25), + (1663, 25, 62, 69), + (1664, 25, 62, 111), + (1665, 0, 62, 23), + (1666, 50, 62, 140), + (1667, 50, 62, 105), + (1668, 50, 62, 72), + (1669, 50, 62, 51), + (1670, 0, 62, 12), + (1671, 0, 62, 70), + (1672, 25, 62, 143), + (1673, 0, 62, 75), + (1674, 0, 62, 110), + (1675, 0, 62, 136), + (1676, 0, 62, 102), + (1677, 0, 62, 67), + (1678, 50, 62, 63), + (1679, 0, 62, 14), + (1680, 0, 62, 124), + (1681, 0, 62, 27), + (1682, 0, 62, 140), + (1683, 0, 62, 122), + (1684, 50, 62, 38), + (1685, 0, 62, 137), + (1686, 25, 62, 86), + (1687, 50, 62, 148), + (1688, 50, 62, 114), + (1689, 0, 62, 86), + (1690, 0, 62, 86), + (1691, 0, 62, 78), + (1692, 0, 62, 77), + (1693, 0, 63, 131), + (1694, 0, 63, 137), + (1695, 50, 63, 139), + (1696, 50, 63, 124), + (1697, 50, 63, 120), + (1698, 0, 63, 99), + (1699, 0, 63, 100), + (1700, 0, 63, 39), + (1701, 0, 63, 87), + (1702, 50, 63, 11), + (1703, 0, 63, 20), + (1704, 0, 63, 117), + (1705, 25, 63, 56), + (1706, 0, 63, 100), + (1707, 0, 63, 10), + (1708, 50, 63, 103), + (1709, 50, 63, 61), + (1710, 0, 63, 120), + (1711, 25, 63, 60), + (1712, 0, 63, 9), + (1713, 0, 63, 56), + (1714, 25, 63, 132), + (1715, 0, 63, 19), + (1716, 50, 63, 142), + (1717, 25, 63, 72), + (1718, 0, 63, 36), + (1719, 0, 63, 129), + (1720, 0, 63, 91), + (1721, 50, 63, 134), + (1722, 0, 63, 31), + (1723, 0, 63, 142), + (1724, 0, 63, 70), + (1725, 50, 63, 64), + (1726, 50, 63, 100), + (1727, 0, 63, 91), + (1728, 50, 63, 31), + (1729, 0, 63, 110), + (1730, 0, 63, 104), + (1731, 50, 63, 29), + (1732, 0, 63, 111), + (1733, 0, 63, 86), + (1734, 0, 63, 77), + (1735, 0, 63, 36), + (1736, 0, 63, 92), + (1737, 0, 63, 147), + (1738, 0, 63, 44), + (1739, 0, 63, 130), + (1740, 0, 63, 41), + (1741, 0, 64, 131), + (1742, 0, 64, 104), + (1743, 50, 64, 51), + (1744, 0, 64, 88), + (1745, 50, 64, 32), + (1746, 50, 64, 52), + (1747, 0, 64, 74), + (1748, 0, 64, 31), + (1749, 50, 64, 140), + (1750, 50, 64, 101), + (1751, 0, 64, 88), + (1752, 0, 64, 115), + (1753, 0, 64, 65), + (1754, 50, 64, 43), + (1755, 25, 64, 61), + (1756, 50, 64, 129), + (1757, 0, 64, 128), + (1758, 0, 64, 148), + (1759, 50, 64, 56), + (1760, 25, 64, 31), + (1761, 0, 64, 62), + (1762, 25, 64, 35), + (1763, 50, 64, 47), + (1764, 0, 64, 94), + (1765, 25, 64, 46), + (1766, 0, 64, 67), + (1767, 0, 64, 88), + (1768, 50, 64, 99), + (1769, 50, 64, 71), + (1770, 0, 64, 64), + (1771, 0, 64, 88), + (1772, 0, 64, 80), + (1773, 0, 64, 14), + (1774, 0, 64, 123), + (1775, 0, 64, 39), + (1776, 0, 65, 18), + (1777, 0, 65, 29), + (1778, 25, 65, 128), + (1779, 25, 65, 43), + (1780, 0, 65, 18), + (1781, 50, 65, 34), + (1782, 25, 65, 38), + (1783, 0, 65, 134), + (1784, 50, 65, 72), + (1785, 50, 65, 61), + (1786, 25, 65, 76), + (1787, 50, 65, 87), + (1788, 0, 65, 30), + (1789, 0, 65, 63), + (1790, 0, 65, 140), + (1791, 50, 65, 20), + (1792, 0, 65, 77), + (1793, 0, 65, 1), + (1794, 0, 65, 74), + (1795, 0, 65, 47), + (1796, 0, 65, 52), + (1797, 0, 65, 8), + (1798, 50, 65, 144), + (1799, 0, 65, 67), + (1800, 25, 65, 147), + (1801, 0, 65, 1), + (1802, 50, 65, 105), + (1803, 0, 65, 110), + (1804, 0, 65, 3), + (1805, 0, 65, 32), + (1806, 0, 65, 116), + (1807, 50, 65, 90), + (1808, 50, 65, 140), + (1809, 0, 65, 92), + (1810, 25, 65, 29), + (1811, 0, 65, 65), + (1812, 50, 65, 143), + (1813, 25, 65, 82), + (1814, 0, 65, 119), + (1815, 0, 65, 99), + (1816, 50, 65, 141), + (1817, 0, 65, 114), + (1818, 50, 65, 97), + (1819, 0, 65, 145), + (1820, 0, 66, 105), + (1821, 0, 66, 126), + (1822, 0, 66, 135), + (1823, 50, 66, 48), + (1824, 0, 66, 114), + (1825, 50, 66, 96), + (1826, 0, 66, 21), + (1827, 50, 66, 57), + (1828, 50, 66, 11), + (1829, 25, 66, 130), + (1830, 0, 66, 55), + (1831, 0, 66, 9), + (1832, 0, 66, 2), + (1833, 0, 66, 80), + (1834, 50, 66, 51), + (1835, 50, 66, 137), + (1836, 25, 66, 15), + (1837, 25, 66, 81), + (1838, 50, 66, 1), + (1839, 0, 66, 80), + (1840, 0, 66, 32), + (1841, 0, 66, 27), + (1842, 0, 66, 96), + (1843, 50, 66, 136), + (1844, 0, 66, 20), + (1845, 50, 66, 143), + (1846, 0, 66, 65), + (1847, 50, 66, 73), + (1848, 50, 66, 104), + (1849, 50, 66, 60), + (1850, 50, 66, 146), + (1851, 50, 66, 27), + (1852, 50, 66, 20), + (1853, 0, 67, 12), + (1854, 0, 67, 130), + (1855, 0, 67, 54), + (1856, 50, 67, 21), + (1857, 0, 67, 41), + (1858, 0, 67, 142), + (1859, 0, 67, 105), + (1860, 50, 67, 30), + (1861, 0, 67, 96), + (1862, 0, 67, 125), + (1863, 25, 67, 51), + (1864, 0, 67, 111), + (1865, 50, 67, 22), + (1866, 0, 67, 19), + (1867, 0, 67, 32), + (1868, 0, 67, 58), + (1869, 0, 67, 18), + (1870, 0, 67, 145), + (1871, 25, 67, 9), + (1872, 0, 67, 113), + (1873, 0, 67, 53), + (1874, 0, 67, 71), + (1875, 0, 67, 55), + (1876, 0, 67, 122), + (1877, 0, 67, 5), + (1878, 0, 67, 57), + (1879, 0, 67, 115), + (1880, 0, 67, 90), + (1881, 0, 67, 21), + (1882, 0, 67, 71), + (1883, 0, 67, 69), + (1884, 50, 68, 40), + (1885, 50, 68, 55), + (1886, 0, 68, 61), + (1887, 25, 68, 67), + (1888, 0, 68, 106), + (1889, 50, 68, 36), + (1890, 25, 68, 63), + (1891, 50, 68, 120), + (1892, 0, 68, 9), + (1893, 0, 68, 88), + (1894, 0, 68, 76), + (1895, 0, 68, 11), + (1896, 50, 68, 56), + (1897, 50, 69, 44), + (1898, 50, 69, 105), + (1899, 50, 69, 28), + (1900, 50, 69, 23), + (1901, 0, 69, 115), + (1902, 0, 69, 127), + (1903, 0, 69, 22), + (1904, 0, 69, 40), + (1905, 25, 69, 78), + (1906, 0, 69, 21), + (1907, 50, 69, 33), + (1908, 0, 69, 118), + (1909, 25, 69, 132), + (1910, 0, 69, 32), + (1911, 50, 70, 80), + (1912, 50, 70, 31), + (1913, 0, 70, 143), + (1914, 0, 70, 86), + (1915, 50, 70, 143), + (1916, 50, 70, 116), + (1917, 0, 70, 147), + (1918, 50, 70, 114), + (1919, 0, 70, 148), + (1920, 50, 70, 30), + (1921, 0, 70, 28), + (1922, 0, 70, 111), + (1923, 0, 70, 115), + (1924, 50, 70, 32), + (1925, 0, 70, 65), + (1926, 50, 70, 42), + (1927, 50, 70, 108), + (1928, 0, 70, 83), + (1929, 0, 70, 124), + (1930, 0, 70, 102), + (1931, 50, 70, 124), + (1932, 0, 70, 53), + (1933, 0, 70, 28), + (1934, 50, 70, 90), + (1935, 0, 70, 52), + (1936, 50, 70, 82), + (1937, 0, 70, 20), + (1938, 0, 70, 61), + (1939, 0, 70, 143), + (1940, 0, 70, 92), + (1941, 50, 70, 105), + (1942, 50, 70, 145), + (1943, 50, 70, 85), + (1944, 0, 70, 68), + (1945, 0, 70, 113), + (1946, 50, 70, 137), + (1947, 50, 70, 108), + (1948, 50, 70, 12), + (1949, 50, 71, 25), + (1950, 0, 71, 11), + (1951, 25, 71, 59), + (1952, 25, 71, 13), + (1953, 50, 71, 58), + (1954, 0, 71, 110), + (1955, 0, 71, 93), + (1956, 25, 71, 112), + (1957, 50, 71, 114), + (1958, 0, 71, 120), + (1959, 0, 71, 92), + (1960, 0, 71, 2), + (1961, 25, 71, 94), + (1962, 50, 71, 89), + (1963, 0, 71, 43), + (1964, 25, 72, 6), + (1965, 50, 72, 52), + (1966, 0, 72, 84), + (1967, 50, 72, 121), + (1968, 50, 72, 119), + (1969, 50, 72, 143), + (1970, 0, 72, 94), + (1971, 0, 72, 115), + (1972, 25, 72, 122), + (1973, 0, 72, 72), + (1974, 50, 72, 96), + (1975, 50, 72, 43), + (1976, 0, 72, 115), + (1977, 0, 72, 12), + (1978, 50, 72, 93), + (1979, 25, 72, 70), + (1980, 50, 72, 23), + (1981, 50, 72, 43), + (1982, 0, 72, 43), + (1983, 50, 72, 65), + (1984, 0, 72, 83), + (1985, 0, 72, 88), + (1986, 0, 72, 49), + (1987, 50, 72, 33), + (1988, 0, 72, 30), + (1989, 0, 72, 28), + (1990, 50, 72, 131), + (1991, 0, 72, 105), + (1992, 50, 72, 101), + (1993, 0, 72, 26), + (1994, 50, 72, 7), + (1995, 25, 73, 112), + (1996, 50, 73, 135), + (1997, 50, 73, 111), + (1998, 50, 73, 101), + (1999, 0, 73, 32), + (2000, 50, 73, 125), + (2001, 50, 73, 91), + (2002, 0, 73, 85), + (2003, 0, 73, 11), + (2004, 50, 73, 115), + (2005, 0, 73, 132), + (2006, 0, 73, 107), + (2007, 0, 73, 12), + (2008, 50, 73, 95), + (2009, 50, 74, 38), + (2010, 50, 74, 1), + (2011, 50, 74, 106), + (2012, 0, 74, 19), + (2013, 50, 74, 143), + (2014, 0, 74, 48), + (2015, 0, 74, 46), + (2016, 50, 74, 96), + (2017, 0, 74, 147), + (2018, 0, 74, 25), + (2019, 0, 74, 3), + (2020, 50, 74, 116), + (2021, 0, 74, 130), + (2022, 0, 74, 139), + (2023, 0, 74, 70), + (2024, 50, 74, 125), + (2025, 0, 74, 83), + (2026, 25, 74, 37), + (2027, 50, 74, 26), + (2028, 0, 74, 145), + (2029, 25, 74, 134), + (2030, 0, 74, 90), + (2031, 0, 74, 107), + (2032, 0, 74, 124), + (2033, 50, 74, 145), + (2034, 0, 74, 65), + (2035, 0, 74, 7), + (2036, 50, 74, 56), + (2037, 0, 74, 118), + (2038, 0, 74, 79), + (2039, 50, 74, 110), + (2040, 0, 74, 14), + (2041, 0, 74, 76), + (2042, 0, 74, 35), + (2043, 0, 74, 87), + (2044, 50, 74, 78), + (2045, 50, 74, 19), + (2046, 50, 74, 98), + (2047, 0, 74, 34), + (2048, 0, 74, 133), + (2049, 50, 74, 8), + (2050, 0, 74, 12), + (2051, 0, 74, 71), + (2052, 50, 74, 75), + (2053, 0, 74, 36), + (2054, 25, 74, 1), + (2055, 0, 74, 85), + (2056, 0, 74, 27), + (2057, 50, 74, 78), + (2058, 0, 75, 52), + (2059, 50, 75, 82), + (2060, 0, 75, 2), + (2061, 50, 75, 129), + (2062, 0, 75, 78), + (2063, 25, 75, 130), + (2064, 0, 75, 127), + (2065, 50, 75, 14), + (2066, 50, 75, 103), + (2067, 50, 75, 59), + (2068, 0, 75, 136), + (2069, 50, 75, 60), + (2070, 50, 75, 45), + (2071, 50, 75, 30), + (2072, 0, 75, 94), + (2073, 0, 75, 141), + (2074, 0, 75, 51), + (2075, 25, 75, 29), + (2076, 0, 75, 126), + (2077, 0, 75, 97), + (2078, 0, 75, 92), + (2079, 0, 75, 27), + (2080, 50, 75, 40), + (2081, 50, 75, 120), + (2082, 0, 75, 101), + (2083, 50, 75, 127), + (2084, 0, 75, 130), + (2085, 50, 75, 110), + (2086, 0, 75, 128), + (2087, 0, 75, 63), + (2088, 50, 75, 70), + (2089, 0, 75, 25), + (2090, 50, 75, 16), + (2091, 0, 75, 147), + (2092, 50, 75, 141), + (2093, 0, 75, 81), + (2094, 0, 76, 107), + (2095, 25, 76, 62), + (2096, 0, 76, 51), + (2097, 50, 76, 105), + (2098, 0, 76, 31), + (2099, 50, 76, 123), + (2100, 0, 76, 119), + (2101, 25, 76, 82), + (2102, 50, 76, 71), + (2103, 25, 76, 75), + (2104, 25, 76, 23), + (2105, 25, 76, 94), + (2106, 0, 76, 67), + (2107, 0, 76, 147), + (2108, 50, 77, 122), + (2109, 0, 77, 83), + (2110, 0, 77, 105), + (2111, 0, 77, 51), + (2112, 0, 77, 16), + (2113, 0, 77, 50), + (2114, 50, 77, 144), + (2115, 0, 77, 65), + (2116, 0, 77, 72), + (2117, 0, 77, 36), + (2118, 0, 77, 18), + (2119, 0, 77, 99), + (2120, 0, 77, 126), + (2121, 0, 77, 55), + (2122, 0, 77, 7), + (2123, 0, 77, 11), + (2124, 0, 77, 143), + (2125, 50, 77, 44), + (2126, 50, 77, 1), + (2127, 0, 77, 46), + (2128, 0, 77, 97), + (2129, 50, 77, 48), + (2130, 50, 77, 101), + (2131, 0, 77, 10), + (2132, 0, 77, 140), + (2133, 0, 77, 103), + (2134, 0, 77, 72), + (2135, 50, 77, 34), + (2136, 50, 77, 51), + (2137, 50, 77, 113), + (2138, 50, 77, 94), + (2139, 50, 77, 123), + (2140, 25, 77, 80), + (2141, 0, 78, 15), + (2142, 25, 78, 145), + (2143, 50, 78, 117), + (2144, 0, 78, 5), + (2145, 50, 78, 41), + (2146, 0, 78, 133), + (2147, 0, 78, 104), + (2148, 50, 78, 129), + (2149, 50, 78, 9), + (2150, 0, 78, 59), + (2151, 50, 78, 102), + (2152, 0, 78, 64), + (2153, 0, 78, 45), + (2154, 50, 78, 92), + (2155, 25, 78, 135), + (2156, 0, 78, 142), + (2157, 25, 78, 144), + (2158, 0, 78, 147), + (2159, 50, 78, 59), + (2160, 50, 78, 91), + (2161, 0, 78, 99), + (2162, 0, 78, 90), + (2163, 0, 78, 93), + (2164, 0, 78, 35), + (2165, 0, 78, 91), + (2166, 0, 78, 77), + (2167, 0, 78, 79), + (2168, 25, 78, 57), + (2169, 0, 78, 134), + (2170, 25, 78, 25), + (2171, 0, 78, 14), + (2172, 0, 78, 68), + (2173, 50, 79, 133), + (2174, 0, 79, 79), + (2175, 0, 79, 54), + (2176, 0, 79, 104), + (2177, 25, 79, 25), + (2178, 0, 79, 49), + (2179, 50, 79, 29), + (2180, 0, 79, 72), + (2181, 0, 79, 31), + (2182, 50, 79, 139), + (2183, 0, 79, 3), + (2184, 0, 79, 38), + (2185, 0, 79, 87), + (2186, 0, 79, 131), + (2187, 50, 79, 54), + (2188, 0, 79, 31), + (2189, 50, 79, 81), + (2190, 25, 79, 71), + (2191, 25, 79, 120), + (2192, 50, 79, 113), + (2193, 50, 79, 14), + (2194, 25, 79, 73), + (2195, 50, 79, 132), + (2196, 50, 79, 138), + (2197, 50, 79, 34), + (2198, 50, 79, 96), + (2199, 0, 79, 123), + (2200, 0, 79, 14), + (2201, 50, 79, 146), + (2202, 50, 79, 96), + (2203, 50, 79, 140), + (2204, 0, 79, 89), + (2205, 50, 79, 77), + (2206, 50, 80, 13), + (2207, 0, 80, 121), + (2208, 25, 80, 66), + (2209, 50, 80, 20), + (2210, 0, 80, 27), + (2211, 0, 80, 8), + (2212, 25, 80, 41), + (2213, 0, 80, 107), + (2214, 25, 80, 37), + (2215, 50, 80, 75), + (2216, 25, 80, 37), + (2217, 50, 80, 85), + (2218, 0, 80, 113), + (2219, 50, 80, 35), + (2220, 0, 80, 12), + (2221, 0, 80, 30), + (2222, 0, 80, 7), + (2223, 50, 80, 49), + (2224, 0, 80, 20), + (2225, 0, 80, 144), + (2226, 0, 80, 110), + (2227, 0, 80, 119), + (2228, 0, 80, 31), + (2229, 0, 80, 120), + (2230, 0, 80, 44), + (2231, 0, 80, 87), + (2232, 0, 80, 146), + (2233, 0, 80, 44), + (2234, 0, 80, 107), + (2235, 50, 80, 121), + (2236, 0, 80, 14), + (2237, 0, 80, 31), + (2238, 50, 80, 49), + (2239, 0, 80, 36), + (2240, 0, 81, 24), + (2241, 0, 81, 24), + (2242, 0, 81, 66), + (2243, 0, 81, 67), + (2244, 0, 81, 115), + (2245, 0, 81, 102), + (2246, 0, 81, 39), + (2247, 0, 81, 145), + (2248, 25, 81, 130), + (2249, 0, 81, 73), + (2250, 50, 81, 133), + (2251, 50, 81, 136), + (2252, 0, 81, 139), + (2253, 0, 81, 24), + (2254, 50, 81, 2), + (2255, 25, 81, 30), + (2256, 25, 81, 19), + (2257, 0, 81, 130), + (2258, 0, 81, 43), + (2259, 0, 81, 145), + (2260, 0, 81, 121), + (2261, 0, 81, 9), + (2262, 50, 81, 122), + (2263, 50, 81, 89), + (2264, 0, 81, 119), + (2265, 0, 81, 61), + (2266, 0, 81, 50), + (2267, 0, 81, 122), + (2268, 0, 81, 86), + (2269, 50, 81, 64), + (2270, 50, 81, 7), + (2271, 0, 81, 130), + (2272, 0, 81, 114), + (2273, 0, 81, 37), + (2274, 50, 81, 128), + (2275, 0, 81, 16), + (2276, 50, 81, 38), + (2277, 0, 81, 22), + (2278, 50, 81, 86), + (2279, 0, 81, 147), + (2280, 0, 81, 134), + (2281, 0, 81, 113), + (2282, 0, 81, 123), + (2283, 0, 81, 111), + (2284, 25, 81, 24), + (2285, 50, 81, 89), + (2286, 0, 81, 21), + (2287, 50, 82, 93), + (2288, 50, 82, 44), + (2289, 0, 82, 61), + (2290, 50, 82, 127), + (2291, 50, 82, 106), + (2292, 0, 82, 119), + (2293, 0, 82, 3), + (2294, 0, 82, 71), + (2295, 50, 82, 146), + (2296, 50, 82, 137), + (2297, 50, 82, 138), + (2298, 0, 82, 107), + (2299, 25, 82, 5), + (2300, 0, 82, 7), + (2301, 25, 82, 80), + (2302, 0, 82, 80), + (2303, 0, 82, 88), + (2304, 0, 82, 33), + (2305, 0, 82, 90), + (2306, 50, 82, 62), + (2307, 50, 82, 35), + (2308, 0, 82, 35), + (2309, 50, 82, 16), + (2310, 0, 82, 46), + (2311, 25, 82, 112), + (2312, 0, 82, 136), + (2313, 25, 82, 130), + (2314, 0, 82, 111), + (2315, 0, 82, 96), + (2316, 0, 82, 53), + (2317, 0, 82, 99), + (2318, 0, 82, 10), + (2319, 50, 82, 126), + (2320, 50, 82, 107), + (2321, 0, 82, 9), + (2322, 0, 83, 48), + (2323, 0, 83, 92), + (2324, 50, 83, 124), + (2325, 0, 83, 65), + (2326, 0, 83, 133), + (2327, 0, 83, 95), + (2328, 0, 83, 145), + (2329, 0, 83, 138), + (2330, 25, 83, 124), + (2331, 0, 83, 105), + (2332, 50, 83, 47), + (2333, 0, 83, 51), + (2334, 0, 83, 123), + (2335, 0, 83, 102), + (2336, 0, 83, 14), + (2337, 0, 83, 23), + (2338, 50, 83, 138), + (2339, 25, 83, 94), + (2340, 0, 83, 31), + (2341, 0, 83, 82), + (2342, 0, 83, 44), + (2343, 50, 83, 27), + (2344, 0, 83, 127), + (2345, 50, 83, 18), + (2346, 0, 83, 29), + (2347, 0, 83, 125), + (2348, 0, 84, 62), + (2349, 0, 84, 44), + (2350, 0, 84, 89), + (2351, 50, 84, 15), + (2352, 0, 84, 1), + (2353, 50, 84, 14), + (2354, 0, 84, 117), + (2355, 0, 84, 127), + (2356, 0, 84, 52), + (2357, 0, 84, 53), + (2358, 0, 84, 38), + (2359, 50, 84, 148), + (2360, 0, 84, 100), + (2361, 50, 84, 137), + (2362, 0, 84, 137), + (2363, 50, 84, 58), + (2364, 25, 84, 27), + (2365, 0, 84, 60), + (2366, 0, 84, 103), + (2367, 0, 84, 140), + (2368, 0, 84, 106), + (2369, 0, 84, 46), + (2370, 0, 84, 80), + (2371, 25, 84, 46), + (2372, 0, 84, 36), + (2373, 50, 84, 50), + (2374, 50, 84, 131), + (2375, 0, 84, 120), + (2376, 0, 85, 50), + (2377, 0, 85, 26), + (2378, 50, 85, 94), + (2379, 0, 85, 148), + (2380, 0, 85, 123), + (2381, 50, 85, 4), + (2382, 0, 85, 9), + (2383, 0, 85, 90), + (2384, 0, 85, 40), + (2385, 25, 85, 47), + (2386, 50, 85, 3), + (2387, 0, 85, 35), + (2388, 50, 85, 40), + (2389, 0, 85, 12), + (2390, 0, 85, 73), + (2391, 0, 85, 31), + (2392, 50, 85, 121), + (2393, 0, 85, 51), + (2394, 0, 85, 143), + (2395, 0, 85, 131), + (2396, 0, 85, 147), + (2397, 0, 85, 39); + + diff --git a/Suli/11.b/Adatbázis/Érettségi/Mozi/kártya.txt b/Suli/11.b/Adatbázis/Érettségi/Mozi/kártya.txt new file mode 100644 index 0000000..206439c --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Mozi/kártya.txt @@ -0,0 +1,22 @@ +Kép: +assets/images/martian.jpg + +Kép helyettesítő szöveg: +A Marsi moziplakát + +Cím: +A marsi + +Leírás: +Andy Wair regénye alapján készült mű az egyik legpontosabb leírás a jelenkori tudomány állása szerint az űrutazás viszontagságairól. +A történet középpontjában Mark Watney amerikai asztronauta áll, aki egyedül marad a Marson, így rögtönöznie kell a túlélése érdekében. + +Következő vetítések: +- Szerda, 20:00 +- Csütörtök 8:00, 12:00 + +badge szöveg: +Újdonság + +badge extra stílusosztály: +bg-danger diff --git a/Suli/11.b/Adatbázis/Érettségi/Mozi/megoldasok.sql b/Suli/11.b/Adatbázis/Érettségi/Mozi/megoldasok.sql new file mode 100644 index 0000000..e68d98d --- /dev/null +++ b/Suli/11.b/Adatbázis/Érettségi/Mozi/megoldasok.sql @@ -0,0 +1,20 @@ +-- 13. feladat: +CREATE DATABASE mozi CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + +-- 15. feladat: +SELECT COUNT(id) AS `vetitesek_szama` FROM `vetites` WHERE vetites.kezdes = "20:00:00"; + +-- 16. feladat: +SELECT vendeg.nev AS `vendeg_nev`, COUNT(jegy.id) AS `jegy_darab` FROM `jegy` INNER JOIN vendeg ON jegy.vendegId = vendeg.id GROUP BY vendeg.nev ORDER BY COUNT(jegy.id) DESC LIMIT 5; + +-- 17. feladat: +UPDATE film SET cim = "Csillagok között" WHERE cim = "Interstellar" + +-- 18. feladat: +INSERT INTO filmtipus(nev) VALUES("Animációs") + +-- 19. feladat: +SELECT vendeg.nev AS `nev`, COUNT(jegy.id) AS `teljes_aru_jegy_db` FROM `jegy` INNER JOIN vendeg ON jegy.vendegId = vendeg.id WHERE vendeg.nev = "Fodor András" AND jegy.kedvezmeny = 0 GROUP BY vendeg.nev; + +-- 20. feladat: +SELECT film.cim AS `film_neve`, COUNT(jegy.id) AS `jegy_darabszam`, SUM(film.jegyar - film.jegyar * jegy.kedvezmeny / 100) AS `teljes_bevetel` FROM `jegy` INNER JOIN vetites ON jegy.vetitesId = vetites.id INNER JOIN film ON vetites.filmId = film.id GROUP BY film.cim ORDER BY SUM(film.jegyar - film.jegyar * jegy.kedvezmeny / 100) DESC LIMIT 1; \ No newline at end of file diff --git a/Suli/11.b/Adatbázis/Érettségi/Mozi/mozi.zip b/Suli/11.b/Adatbázis/Érettségi/Mozi/mozi.zip new file mode 100644 index 0000000..1a99163 Binary files /dev/null and b/Suli/11.b/Adatbázis/Érettségi/Mozi/mozi.zip differ diff --git a/Suli/11.b/IKT II/C# projekt/menopoly b/Suli/11.b/IKT II/C# projekt/menopoly new file mode 160000 index 0000000..a6dcfcc --- /dev/null +++ b/Suli/11.b/IKT II/C# projekt/menopoly @@ -0,0 +1 @@ +Subproject commit a6dcfcc5a96cc621e89fa0cdac1b0e587d9da173 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 02. 05.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 02. 05.txt new file mode 100644 index 0000000..ccbbd44 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 02. 05.txt @@ -0,0 +1 @@ +Finally: A finally blokk minden esetben lefut, csakis fatal error esetében nem fog. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 16.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 16.txt new file mode 100644 index 0000000..6ab5e0f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 16.txt @@ -0,0 +1,5 @@ +Függvények, eljárások: + +Eljárások: static void kulcsszavakkal hozzuk létre. Ezután neve, majd (). Az utasításokat az utasításblokkok között adjuk meg {}. Meghívni a nevével, és az üres zárójelekkel hívjuk meg. + +Függvények: Olyan eljárás, aminek van visszatérési értéke. A void kulcsszó helyére a függvény visszatérési értékének típusát kell írni. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 23.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 23.txt new file mode 100644 index 0000000..eda7cce --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 23.txt @@ -0,0 +1,10 @@ + Programozási tételek + +Egyszerű programozási tételek: + + +Összegzés tétele: Ebben az esetben a bemenő sorozat elemeinek összegét akarjuk meghatározni. + +Megszámlálás tétele: A megszámlálás során egy sorozat bizonyos feltételeinek megfelelő elemeinek számát határozzuk meg. Gyakorlatilag végigmegyünk a sorozat elemein, és közben, ha az aktuális elem megfelel a feltételnek, akkor a számlálónkat továbbléptetjük. + +Eldöntés tétele: Az eldöntés tétele azt adja meg, hogy a sorozat tartalmaz-e adott tulajdonságnak megfelelő elemet. A megoldás során addig vizsgáljuk a sorozat elemeit, amíg nem találunk adott tulajdonságnak megfelelő elemet, vagy amíg a sorozat végére érünk. Ez a tétel eredményként egy logikai változót ad meg, mely igaz, ha a sorozatnak volt adott tulajdonságú eleme, és hamis, ha nem volt. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 30.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 30.txt new file mode 100644 index 0000000..b757467 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 05. 30.txt @@ -0,0 +1,3 @@ +Maximumkiválasztás tétele: Ezzel az algoritmussal egy tetszőleges x tömb elemei közül a legnagyobb értéket tudjuk kiválasztani. Abban az esetben, ha nem csak a legnagyobb elem van az x tömbben, ez az algoritmus az első ilyen elem sorszámával tér vissza. Fontos, hogy Max változóban található érték nem az x tömbben található legnagíobb érték, hanem annak sorszáma. Megírhatjuk, hogí a legnagyobb értéket kapjuk meg eredményül, de a sorszámos jobb megoldás. + +Kiválasztás tétele: Biztosan tudjuk, hogy az x tömb tartalmazza a t tulajdonságú elemet, csak azt nem tudjuk, hányadik az. Ez az algoritmus megkeresi nekünk, és eredményül az elem sorszámával tér vissza. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 06.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 06.txt new file mode 100644 index 0000000..9dd789c --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 06.txt @@ -0,0 +1,3 @@ +Kiválogatás tétele: Ezzel az algoritmussal egy tetszőleges tömb (X) elemei közül T tulajdonságokat kiválogathatjuk egy másik (Y) tömbbe. Fenti okból az Y tömb számossága ugyan az, mint X tömbbé. Ennek az algoritmusnak van egy módosított változata, amelyben az Y tömb nem az X tömb T tulajdonságú elemeinek értékét, hanem azon elmeke sorszámát tartalmazza. Ebben az esetben az Y tömb nem az elemtip típusú elemeket tárol, hanem egész számokat, illetve Y(DB) = X(i) sort kell kicserélni Y(DB) = i sorra. (Ha pl. Az X tömbből ki akarjuk válogatni a 10-nél nagyobb értékűeket, akkor a T(X(i)) helyett X(i) > 10 feltételt kell írni.) + +Lineáris keresés tétele: Nem tudjuk, hogy az X tömbnek van-e T tulajdonságú elem , de ha van, akkor a lenti algoritmus eredményül a megtalált elem sorszámát is megadja. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 13.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 13.txt new file mode 100644 index 0000000..51ee8ab --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Elmélet/2023. 06. 13.txt @@ -0,0 +1,3 @@ +Egyszerű cserés rendezés: A legegyszerűbb rendezésre használt algoritmus, működés elvéből a leglassabb, és kevés adat rendezésére jó. Alapgondolat: Hasonlítsuk össze az első elemet a sorozat összes többi mögötte levő elemével, s ha valamelyik kisebb nála, akkor cseréljük meg azzal. Így elérjük, hogy a sorozat első helyére a legkisebb elem kerül. Folytassuk ugyanezen elven a sorozat második elemével, utoljára az utolsó előttivel. + +Buborékos rendezés: Alapgondolata: HasonlÍtsuk egymással a szomszédos elemeket, ha a sorrendjük nem jó, akkor cseréljük meg őket. Egy cikluslépés lefutása alatt a legnagyobb elem biztosan a sorozat végére kerül, és a nagyobb értékű elemek hátrafelé, a kisebbek előre mozdulnak el. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Eredmenyek.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Eredmenyek.txt new file mode 100644 index 0000000..18628bc --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Eredmenyek.txt @@ -0,0 +1,94 @@ +brahm Richrd;1998;159;f;16-17;00:24:03;00:01:54;00:45:15;00:01:15;00:25:15 +Anheuer Kristf;1994;101;f;elit;00:12:42;00:00:34;00:31:41;00:00:29;00:17:22 +Ardelean Jnos Tibor;1984;102;f;30-34;00:17:01;00:01:04;00:35:19;00:00:48;00:21:25 +Bres Lvia;1967;220;n;45-49;00:27:02;00:02:57;00:44:19;00:01:38;00:23:56 +Bicsk Bence;1995;1;f;elit junior;00:12:46;00:00:37;00:31:35;00:00:27;00:15:42 +Bicsk Flra;1997;219;n;16-17;00:13:11;00:00:48;00:38:43;00:00:29;00:17:56 +Bojtor Szabolcs;1990;103;f;20-24;00:23:49;00:07:52;00:43:25;00:01:19;00:21:29 +Bokor Zoltn;1984;104;f;30-34;00:22:46;00:03:04;00:42:53;00:00:47;00:27:30 +Boronkay Pter;1981;105;f;30-34;00:16:49;00:01:18;00:34:17;00:00:49;00:19:40 +Boros Gbor;1968;107;f;45-49;00:22:43;00:01:21;00:38:06;00:00:57;00:22:55 +Boros Sndor;1966;106;f;45-49;00:17:03;00:02:06;00:34:05;00:00:38;00:19:50 +Borsnyi Dniel;1990;137;f;20-24;00:30:03;00:02:33;00:39:57;00:01:09;00:24:00 +Blecz Zoltn;1970;108;f;40-44;00:21:06;00:03:04;00:40:10;00:01:32;00:26:28 +Brcz Bence;1996;2;f;elit junior;00:15:06;00:00:55;00:31:33;00:00:28;00:18:04 +Bruzsa Katalin;1980;218;n;30-34;00:19:46;00:03:03;00:41:41;00:00:36;00:22:50 +Bujdos Ferenc Smuel;1996;147;f;18-19;00:12:45;00:00:35;00:31:46;00:00:26;00:18:56 +Czigny Andrs;1993;109;f;elit;00:12:43;00:00:32;00:31:42;00:00:23;00:16:37 +Czigny Rbert;1968;168;f;45-49;00:15:23;00:01:24;00:34:04;00:00:37;00:18:13 +Csk Panna;1998;217;n;16-17;00:12:56;00:00:39;00:34:29;00:00:27;00:18:33 +Csermk Istvn;1963;110;f;50-54;00:24:10;00:01:39;00:40:45;00:02:17;00:24:45 +Dvay Mrk;1996;167;f;elit junior;00:12:07;00:00:45;00:32:06;00:00:25;00:16:07 +Dr. Fents Adrienn;1977;215;n;35-39;00:19:06;00:01:52;00:40:49;00:00:49;00:23:33 +Dr. Rkos Alexandra;1986;216;n;25-29;00:24:21;00:01:52;00:44:20;00:01:20;00:23:26 +Dr. Zsigmond Rka;1973;214;n;40-44;00:16:17;00:02:21;00:42:45;00:01:20;00:27:42 +Duds Eszter;1992;213;n;elit;00:12:59;00:00:44;00:34:26;00:00:30;00:18:24 +Erdlyi Dniel;1988;163;f;25-29;00:18:46;00:01:41;00:53:48;00:01:06;00:23:23 +Fejes Zoltn;1976;113;f;35-39;00:26:37;00:01:15;00:37:45;00:01:09;00:22:39 +Fokvri Gbor;1965;123;f;45-49;00:20:47;00:02:14;00:38:42;00:01:13;00:24:38 +Fuchs Dra;1997;212;n;16-17;00:12:50;00:00:47;00:34:26;00:00:30;00:18:23 +Fuchs Renta;1995;60;n;elit junior;00:12:55;00:00:41;00:34:30;00:00:32;00:19:43 +Gergely Andras;1976;211;f;35-39;00:23:44;00:02:28;00:44:00;00:01:37;00:23:09 +Glavaski Milan;1970;115;f;40-44;00:22:43;00:02:50;00:44:53;00:00:37;00:28:28 +Hajd Kristf;1996;165;f;elit junior;00:12:44;00:00:35;00:31:46;00:00:26;00:19:16 +Hargitai Henrietta;1995;59;n;elit junior;00:12:47;00:00:43;00:34:40;00:00:29;00:19:14 +Horvath Tamas;1967;117;f;45-49;00:20:31;00:02:40;00:35:58;00:01:22;00:24:23 +Horvth Zsolt;1966;118;f;45-49;00:18:05;00:01:07;00:34:37;00:00:50;00:22:59 +Ivkovic Ivn;1997;119;f;16-17;00:14:59;00:00:50;00:34:33;00:00:40;00:21:51 +Jakubovics Istvn;1996;155;f;18-19;00:15:15;00:01:25;00:34:13;00:00:51;00:19:09 +Juhsz Attila;1961;120;f;50-54;00:24:56;00:02:19;00:49:16;00:00:42;00:24:50 +Kassai Piroska;1986;210;n;25-29;00:23:31;00:02:23;00:43:20;00:01:17;00:26:01 +Kasza Pter;1982;121;f;30-34;00:24:30;00:02:39;00:44:22;00:02:33;00:31:09 +Katona Norbert;1990;122;f;20-24;00:16:57;00:02:07;00:34:08;00:01:26;00:20:43 +Kirly Andrs;1996;8;f;elit junior;00:14:39;00:01:09;00:34:33;00:00:34;00:18:39 +Koller Kata;1994;164;n;20-24;00:19:19;00:02:40;00:43:43;00:00:44;00:25:53 +Kovcshegyi Bence;1995;10;f;18-19;00:16:17;00:01:14;00:35:50;00:00:34;00:23:12 +Lelk Attila;1962;169;f;50-54;00:18:25;00:02:00;00:35:58;00:00:56;00:21:31 +Lelk Roland;1985;127;f;25-29;00:25:09;00:01:58;00:41:39;00:01:10;00:28:47 +Lendvai Eszter;1981;209;n;30-34;00:18:59;00:02:55;00:42:40;00:00:48;00:31:47 +Liptk Marcell;1992;128;f;20-24;00:20:48;00:03:08;00:41:55;00:02:34;00:26:18 +Macsik Aron;1976;129;f;35-39;00:30:08;00:02:24;00:41:01;00:01:30;00:25:11 +Major Gbor;1981;158;f;30-34;00:16:26;00:01:14;00:32:40;00:00:26;00:18:20 +Maracsk Sndor;1970;131;f;40-44;00:27:20;00:02:05;00:42:39;00:01:08;00:22:08 +Marton Eld;1995;3;f;elit junior;00:12:44;00:00:38;00:31:39;00:00:25;00:17:04 +Marx Tams;1997;132;f;16-17;00:16:18;00:00:45;00:33:58;00:00:30;00:17:10 +Mayer Tams;1975;134;f;35-39;00:27:29;00:01:42;00:38:04;00:01:31;00:24:00 +Meleg Andrs;1996;9;f;18-19;00:16:23;00:00:46;00:33:42;00:00:28;00:18:30 +Mercs Pter;1982;114;f;30-34;00:29:19;00:02:14;00:43:30;00:01:14;00:27:25 +Mester Dra;1995;58;n;elit junior;00:12:55;00:00:48;00:36:02;00:00:31;00:20:36 +Mszros Judit;1986;170;n;25-29;00:22:30;00:01:36;00:39:57;00:00:53;00:25:38 +Mihly Benjmin;1997;204;f;16-17;00:21:31;00:01:24;00:38:25;00:00:38;00:19:30 +Molnr Jlia;1996;57;n;elit junior;00:14:57;00:00:45;00:38:36;00:00:31;00:20:10 +Mricz Vilmos;1977;136;f;35-39;00:20:57;00:02:24;00:36:16;00:01:15;00:21:41 +Nagy Csaba;1984;138;f;30-34;00:30:42;00:02:44;00:39:19;00:02:02;00:29:36 +Nagy Krisztina;1996;56;n;18-19;00:14:16;00:00:46;00:39:18;00:00:34;00:21:19 +Nagy Mt;1996;4;f;18-19;00:12:47;00:00:34;00:31:40;00:00:26;00:17:42 +Nehz Jnos-Michael;1977;139;f;35-39;00:21:21;00:02:02;00:35:21;00:01:07;00:25:40 +Olh Bence;1978;141;f;35-39;00:16:28;00:00:49;00:36:08;00:00:37;00:19:50 +Pk Dorottya;1979;207;n;35-39;00:24:51;00:04:23;00:51:41;00:01:51;00:31:39 +Pter Brn;1998;157;f;16-17;00:14:10;00:00:57;00:34:52;00:00:29;00:17:50 +Petresevics Rbert;1969;142;f;45-49;00:13:44;00:00:54;00:32:50;00:00:34;00:16:10 +Pincsi Balzs;1981;160;f;30-34;00:15:58;00:00:56;00:36:21;00:00:47;00:20:34 +Por Viktor;1981;143;f;30-34;00:25:46;00:03:48;00:44:28;00:01:04;00:25:32 +Princzkel Jozef;1980;144;f;30-34;00:25:29;00:02:34;00:42:23;00:02:38;00:22:18 +Pusztavmi Mrton;1978;145;f;35-39;00:28:07;00:03:06;00:40:48;00:01:59;00:27:52 +Saj Pter;1977;146;f;35-39;00:19:45;00:02:27;00:40:18;00:01:09;00:23:49 +Sndor Judit;1987;206;n;25-29;00:21:52;00:03:52;00:43:31;00:01:09;00:31:15 +Srszegi Nomi;1996;52;n;elit junior;00:13:04;00:00:38;00:34:21;00:00:27;00:19:57 +Syposs Zoltan;1970;149;f;40-44;00:25:58;00:02:04;00:36:40;00:01:21;00:23:29 +Szalay Gbor;1981;150;f;30-34;00:26:01;00:03:21;00:42:18;00:02:19;00:25:35 +Szatmri Botond;1997;151;f;16-17;00:13:26;00:00:50;00:33:00;00:00:36;00:17:23 +Szatmri Levente;1995;5;f;elit junior;00:12:46;00:00:39;00:31:33;00:00:24;00:16:03 +Szuhn Dra;1996;55;n;18-19;00:15:18;00:01:13;00:41:31;00:00:41;00:28:05 +Telek Blint;1981;161;f;30-34;00:24:12;00:01:36;00:44:02;00:00:50;00:25:40 +Tmea Hubai;1982;124;n;30-34;00:16:15;00:01:01;00:37:05;00:00:50;00:21:40 +Tth Mt;1996;6;f;elit junior;00:14:08;00:00:42;00:32:37;00:00:24;00:18:08 +Vajth Lszl;1968;152;f;45-49;00:28:10;00:02:55;00:46:46;00:00:42;00:22:51 +Varga Zsolt;1969;153;f;45-49;00:34:44;00:04:27;00:46:48;00:00:50;00:25:05 +Vaska Klmn;1972;154;f;40-44;00:24:19;00:02:39;00:35:13;00:01:12;00:20:48 +Vass Benedek;1995;7;f;18-19;00:14:55;00:00:49;00:34:44;00:00:39;00:18:07 +Vizi Viktria;1995;54;n;18-19;00:12:57;00:00:39;00:34:26;00:00:29;00:21:11 +Wolfram Christian;1974;156;f;40-44;00:27:27;00:01:42;00:37:57;00:01:47;00:26:55 +Zkny Nagy Patrik;1996;166;f;elit junior;00:12:42;00:00:31;00:31:46;00:00:26;00:16:50 +Zelovics Dra;1996;53;n;elit junior;00:12:55;00:00:45;00:34:26;00:00:32;00:20:41 +Zubornyk Gyrgy;1981;111;f;30-34;00:20:37;00:02:27;00:36:37;00:01:12;00:23:04 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/London2012.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/London2012.txt new file mode 100644 index 0000000..d0011b5 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/London2012.txt @@ -0,0 +1,29 @@ +Asztalitenisz;0;0;0;0;1;1;0;0;0;0;1;1;0;0;0;0 +Atlétika;0;0;0;0;0;0;2;5;7;5;4;4;5;6;8;1 +Birkózás;0;0;0;0;0;0;0;0;2;3;2;2;2;2;3;2 +Cselgáncs;2;2;2;2;2;2;2;0;0;0;0;0;0;0;0;0 +Evezés;0;0;0;0;3;3;4;4;0;0;0;0;0;0;0;0 +Gyeplabda;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1;0 +Íjászat;1;1;0;0;0;1;1;0;0;0;0;0;0;0;0;0 +Kajak-kenu;0;0;0;1;1;2;0;0;0;0;0;4;4;0;4;0 +Kerékpár;1;1;0;0;2;2;2;1;1;1;3;0;0;2;1;1 +Kézilabda;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Kosárlabda;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Labdarúgás;0;0;0;0;0;0;0;0;0;0;0;0;1;0;1;0 +Lovaglás;0;0;0;2;0;0;0;0;0;1;1;2;0;0;0;0 +Műugrás;0;1;1;1;1;0;0;0;1;0;1;0;1;0;1;0 +Ökölvívás;0;0;0;0;0;0;0;0;0;0;0;0;3;0;5;5 +Öttusa;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Röplabda;0;0;0;0;0;0;0;0;0;0;0;1;1;0;1;1 +Sportlövészet;2;2;1;1;1;1;2;2;1;2;0;0;0;0;0;0 +Súlyemelés;1;2;2;2;2;0;2;1;1;1;1;0;0;0;0;0 +Szinkronúszás;0;0;0;0;0;0;0;0;0;0;1;0;0;1;0;0 +Taekwondo;0;0;0;0;0;0;0;0;0;0;0;2;2;2;2;0 +Tenisz;0;0;0;0;0;0;0;2;3;0;0;0;0;0;0;0 +Tollaslabda;0;0;0;0;0;0;1;2;2;0;0;0;0;0;0;0 +Torna;0;0;1;1;1;1;1;1;3;3;4;0;0;0;1;1 +Triatlon;0;0;0;0;0;0;0;1;0;0;1;0;0;0;0;0 +Úszás;4;4;4;4;4;4;4;4;0;0;0;0;1;1;0;0 +Vitorlázás;0;0;0;0;0;0;0;0;2;2;2;1;1;1;1;0 +Vívás;1;1;1;1;2;1;1;1;1;0;0;0;0;0;0;0 +Vízilabda;0;0;0;0;0;0;0;0;0;0;0;0;1;0;0;1 \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Vtabla.dat b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Vtabla.dat new file mode 100644 index 0000000..98e5eec --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/Vtabla.dat @@ -0,0 +1,26 @@ +ABCDEFGHIJKLMNOPQRSTUVWXYZ +BCDEFGHIJKLMNOPQRSTUVWXYZA +CDEFGHIJKLMNOPQRSTUVWXYZAB +DEFGHIJKLMNOPQRSTUVWXYZABC +EFGHIJKLMNOPQRSTUVWXYZABCD +FGHIJKLMNOPQRSTUVWXYZABCDE +GHIJKLMNOPQRSTUVWXYZABCDEF +HIJKLMNOPQRSTUVWXYZABCDEFG +IJKLMNOPQRSTUVWXYZABCDEFGH +JKLMNOPQRSTUVWXYZABCDEFGHI +KLMNOPQRSTUVWXYZABCDEFGHIJ +LMNOPQRSTUVWXYZABCDEFGHIJK +MNOPQRSTUVWXYZABCDEFGHIJKL +NOPQRSTUVWXYZABCDEFGHIJKLM +OPQRSTUVWXYZABCDEFGHIJKLMN +PQRSTUVWXYZABCDEFGHIJKLMNO +QRSTUVWXYZABCDEFGHIJKLMNOP +RSTUVWXYZABCDEFGHIJKLMNOPQ +STUVWXYZABCDEFGHIJKLMNOPQR +TUVWXYZABCDEFGHIJKLMNOPQRS +UVWXYZABCDEFGHIJKLMNOPQRST +VWXYZABCDEFGHIJKLMNOPQRSTU +WXYZABCDEFGHIJKLMNOPQRSTUV +XYZABCDEFGHIJKLMNOPQRSTUVW +YZABCDEFGHIJKLMNOPQRSTUVWX +ZABCDEFGHIJKLMNOPQRSTUVWXY \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/be.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/be.txt new file mode 100644 index 0000000..c3fe88d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/be.txt @@ -0,0 +1,43 @@ +12 +345 +765 +87 +34 +213 +34 +57 +75 +467 +44 +765 +76 +89 +98 +645 +87 +34 +65 +324 +89 +30 +45 +31 +90 +89 +65 +32 +1 +86 +99 +44 +25 +90 +7 +3 +98 +54 +33 +938 +97 +845 +975 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/csapadék.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/csapadék.txt new file mode 100644 index 0000000..28346db --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/csapadék.txt @@ -0,0 +1 @@ +6 1 2 1 6 0 0 0 1 4 1 3 0 0 0 2 3 1 2 2 0 0 0 0 4 10 0 0 3 4 9 3 0 6 2 0 4 2 4 4 5 1 4 5 0 3 7 5 6 4 \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/diákok.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/diákok.txt new file mode 100644 index 0000000..2842e0b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/diákok.txt @@ -0,0 +1,100 @@ +Verebes Fruzsina 149 54,4 lány +Borsodi Attila 167 51,1 fiú +Major Liza 155 52 lány +Varga Ernő 173 46,5 fiú +Lendvai Vera 165 46,7 lány +Kulcsár Antal 172 55,7 fiú +Petróczi Virág 169 41,3 lány +Pais Károly 155 55,5 fiú +Horváth Adél 157 56,5 lány +Kiss Balázs 163 54,5 fiú +Orosz Ingrid 172 41,9 lány +Pelikán Tamás 172 48,9 fiú +Zalai Elvira 147 57,4 lány +Papp Lilla 169 56 lány +Huszár Dorina 151 48,1 lány +Kiss Krisztián 145 59,3 fiú +Sipos Zsolt 173 57,6 fiú +Pongrácz Karina 175 42,1 lány +Vissi Klaudia 166 59 lány +Gellén Bea 188 47,9 lány +Ferencz Ivett 171 51 lány +Ujj Mihály 188 55,6 fiú +Kovács Gergely 147 42 fiú +Felföldi Judit 145 52,3 lány +Bartal Zsolt 169 49,9 fiú +Simon Erik 171 46,7 fiú +Csiszár Alexandra 170 52,8 lány +Pesti Milán 188 53,3 fiú +Simon Rita 166 46 lány +Somogyi Dezső 177 46,3 fiú +Magyar Magdolna 150 56,8 lány +Gombos Kinga 149 56,7 lány +Egerszegi Kristóf 162 52,2 fiú +Somogyi Tamás 172 59,7 fiú +Varga Anna 188 58,3 lány +Csondor Anikó 159 45,3 lány +Vass Szabolcs 188 54,2 fiú +Szabó Csilla 163 59,6 lány +Pass Flóra 177 45,6 lány +Agg Judit 145 51,1 lány +Gyenese Oszkár 157 43 fiú +Hardi Boglárka 159 60 lány +Kuti Lehel 163 53,8 fiú +Domján Hermina 165 41,3 lány +Tompa Krisztina 172 51,9 lány +Radics Betti 171 42,9 lány +Balla Ibolya 180 43 lány +Csontos Janka 151 56,2 lány +Radics Zsuzsa 159 46,4 lány +Vajda Klára 172 41,9 lány +Simon Marcell 171 46,6 fiú +Salamon Laura 162 48,3 lány +Bakony Ilona 145 46,7 lány +Hantos Bence 147 59 fiú +Kovács Erika 167 59,6 lány +Csiszár Bella 168 48,6 lány +Simon Dorina 169 46,3 lány +Bicsák Hilda 173 44 lány +Varga Rozália 156 44,1 lány +Lengyel Viktor 188 53,3 fiú +Molnár Zsombor 172 48,8 fiú +Hajba Soma 178 48,8 fiú +Bocskor Henrik 154 54,5 fiú +Hajdu Szilvia 157 47,2 lány +Csalló Aliz 159 53 lány +Kelemen Gergő 163 44,9 fiú +Kaczor Jenő 167 44,5 fiú +Bujtor Erzsébet 167 52,1 lány +Gombos Olivér 168 42,5 fiú +Varga Cili 172 49,7 lány +Gulyás Katalin 171 58,2 lány +Vass Vera 155 46 lány +Salamon András 177 55,9 fiú +Elekes Elza 177 48,2 lány +Nagy Melinda 145 46,5 lány +Kovács Vivien 160 58,5 lány +Kaszás Ferenc 149 53 fiú +Balogh Borbála 166 52,9 lány +Horváth Barbara 153 49,1 lány +Dobos Vilma 180 42,9 lány +Nagy Miklós 156 51,7 fiú +Kovács Ambrus 173 54,2 fiú +Paksa Csilla 141 58,4 lány +Bende Natália 145 56,9 lány +Czigány Judit 161 41,4 lány +Simon Edina 167 51,3 lány +Monok Gabriella 168 58,4 lány +Jakab Etelka 169 49,2 lány +Vig Viola 159 53,9 lány +Szegleti Tamás 160 50,5 fiú +Pataki Viktória 149 50,8 lány +Vass Ildikó 171 49,8 lány +Farsang Jakab 168 47,7 fiú +Vajda István 163 48,7 fiú +Marosvári Krisztina 162 46,1 lány +Horváth Kamilla 159 42,1 lány +Koller Tamás 171 45,6 fiú +Kocsis Tamara 170 59,6 lány +Molnár Vera 155 42,2 lány +Hegyi Csaba 152 48,4 fiú \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/forras.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/forras.txt new file mode 100644 index 0000000..9350251 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/forras.txt @@ -0,0 +1,13 @@ +Szent-Gyrgyi Albert +Az egyetlen magyar tuds, aki szlhazjban rdemelte ki a Nobel-djat +Budapesten szletett 1893. szeptember 16-n. Tanulmnyait a Lnyai utcai reformtus gimnziumban vgezte, majd a budapesti tudomnyegyetemen folytatta, ahol 1917-ben orvosi oklevelet szerzett. Az els vilghborban medikusknt vett rszt, de megsebeslt, s hamarosan leszereltk. Ezutn klfldn: Pozsonyban, Prgban, Berlinben, Leidenben, Groningenben folytatott tanulmnyokat, a biolgia, az lettan, a gygyszertan, a bakteriolgia, majd a fizikai-kmia tern. Ezt kveten Cambridge-ben, F.G. Hopkins biokmiai tanszkn megszerezte msodik doktortust, ezttal kmibl, majd E.C. Kendall tmogatsval egy vig az Egyeslt llamokban dolgozott. +Klebelsberg kultuszminiszter hvsra hazajtt, s 1931-tl 1945-ig a szegedi tudomnyegyetem orvosi vegyszeti intzetnek professzora, 1945 s 1947 kztt a budapesti tudomnyegyetem orvos karnak biokmia professzora volt. Az 1920-as vek vgn Szent-Gyrgyi ismeretlen anyagot tallt a mellkvesben. Megllaptotta sszettelt s hexuronsavnak nevezte el (1928). Hazatrve, Szegeden olyan nvnyi forrst keresett, melybl nagyobb mennyisgben lehet kivonni hexuronsavat. Erre a clra a szegedi paradicsompaprika kivlan megfelelt: 10 liter prsnedvbl 6,5 gramm hexuronsavat lltottak el. 1932-ben Szent-Gyrgyi a hexuronsavat azonostotta a C-vitaminnal. Javaslatra a hexuronsavat a skorbut elleni hatsra utalva aszkorbinsavnak neveztk el. Szegeden a paprikbl kiindul C-vitamin gyrts mdszert is kidolgoztk. +Az 1937-es lettani-orvosi Nobel-djat Szent-Gyrgyi Albert nyerte el "a biolgiai gsfolyamatok, klnskppen a C-vitamin s a fumrsavkatalzis szerepnek tern tett felfedezseirt". +1947 vgn elhagyta az orszgot, s a Boston melletti Woods-Hole-ban telepedett le, ahol 1947 s 1962 kztt az Egyeslt llamok Izomkutat Tudomnyos Intzete tengerbiolgiai laboratriumnak igazgatja, 1962 s 1971 kztt a Darthmouth-i Egyetem professzora volt. +Mr Szegeden kezdett foglalkozni az izom mkdsvel, s sikeresen vizsglta az izom fehrjinek szerept az izom-sszehzdsban (1940-42). A szubmolekulris vizsglatok utn rdekldse ksbb a rosszindulat daganatok fel fordult. Kt vtizeden t foglalkozott a sejtszint szablyozs jelensgeivel. +A Magyar Tudomnyos Akadmia levelez (1935), rendes (1938), majd 1945. mjus 30-n tiszteleti tagjnak vlasztotta. Kapcsolatait Magyarorszggal mindig fenntartotta, az 1960-as vektl rendszeresen hazaltogatott. 1986. oktber 22-n halt meg Woods Hall-ban. +1987-ben a Szegedi Orvostudomnyi Egyetem felvette nevt. + + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/neptun.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/neptun.txt new file mode 100644 index 0000000..f535550 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/neptun.txt @@ -0,0 +1,13 @@ +NEPTUNUSZ +Naprendszernk 8. bolygja: - a Naptl legtvolavbb kering risbolyg. Mintegy 165 fldi v alatt kerli meg a Napot, sajt tengelye krl nem egszen 11 s 1/4 ra alatt fordul meg: azaz ezen a bolygn ennyi ideig tart egy teljes nap. tmrje 4-szer, tmege tbb mint 17-szer akkora, mint Fldnk. Ltezst elszr matematikai (gi mechanikai) szmtsok valsznstettk, majd 1846. szeptember 23-n jjel tallta meg s azonostotta bolygknt a berlini kirlyi obszervatriumban Johann Gottfried Galle. +A Neptunusznak a mai kor technikai eszkzeivel kszlt felvtelein lthat lenygz kk szne a lgkr 2%-t alkot metn okozza, amely elnyeli a vrs fnyt. A bolygnak jelenleg 8 holdjt ismerjk. Ezek kzl a legnagyobb mret Tritont mr a bolyg azonostst kvet hetekben felfedeztk. E hold egyik klnlegessge, hogy a tbbi holddal ellenttes irnyban kering a Neptunusz krl. +A Neptunusz holdjainak elnevezse (a bolygtl tvolodva) s sugara: +Naiad (29 km) +Thalassa (40 km) +Despina (74 km) +Galatea (79 km) +Larissa (96 km) +Proteus (209 km) +Triton (1350 km) +Nereid (170 km) +A Neptunuszt eddig csupn a Voyager-2 rszonda ltogatta meg. A "tallkozra" 1989. augusztus 25-n kerlt sor. A Neptunuszhoz kzelebb kering, kisebb mret holdakrl csak felvtelei alapjn szereztnk tudomst. A legkls holdat Kuiper fedezte fel mg 1949-ben. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/petőfi.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/petőfi.txt new file mode 100644 index 0000000..2a3097f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/petőfi.txt @@ -0,0 +1,66 @@ +Petfi Sndor + +Szletskori neve Petrovics Sndor +Szletett Kiskrs +1823. janur 1.? +Elhunyt Segesvr +1849. jlius 31.? (26 vesen) +Nemzetisge magyar +Hzastrsa Szendrey Jlia +Gyermekei Petfi Zoltn +Szlei Petrovics Istvn, Hrz Mria +Foglalkozsa klt +Iskoli Kiskunflegyhza, Kecskemt, Szabadszlls, Srszentlrinc, Pest, Aszd, Selmecbnyai Lceum +Fontosabb munki Petfi kltszete szakasz +A klt szlei. Orlai Petrich Soma festmnye +A klt szlei. Orlai Petrich Soma rajza +Franz Kollar: Petfi apotheosisa + +Petfi Sndor (Kiskrs, 1822. december 31. vagy 1823. janur 1. Segesvr, 1849. jlius 31.?) magyar klt, forradalmr, nemzeti hs, a magyar kltszet egyik legismertebb s legkiemelkedbb alakja. Kzel ezer verset rt rvid lete alatt, ebbl kb. nyolcszztven maradt rnk. + +Klfldn Petfi a legismertebb magyar klt mindmig. az istenek magyar kedvence. Mindent megkapott, hogy nagy klt lehessen: tehetsget, trtnelmet, sorsot. Huszonhat vet lt, s vilgirodalmi rang s mret letm maradt utna, mely korfordult jelentett nemzete irodalmban. + +letrajz +Szrmazsa, gyermekkora + +desapja, Petrovics Istvn (Kartal, 1791. augusztus 15. Pest, 1849. mrcius 21.) mszrosmester, a kzhiedelem szerint szerb, jabb kutatsok alapjn szlovk csaldbl szrmazott[2], de magyarnak vallotta magt. Apjnak szlovk szrmazst valsznsti annak evanglikus vallsa (a szerbek ltalban ortodoxok), illetve Kiss Jzsef s Jakus Lajos kutatsai, akik apai gon 1685-ig, a Nyitra vrmegyei Vagycig vezettk vissza Petfi szrmazst. Vagyis a Petrovicsok csakgy Felvidkrl szrmaznak, mint az anyai g, amely a Turc vrmegyei Necpl kzsgbl ered.[3] + +Anyai nagyapja, Hrz Mihly, tehets redemptus, aki Kecskemt vros tekintlyes polgra volt.[4] desanyja, Hrz Mria (Necpl, 1791. augusztus 26. Pest, 1849. mjus 17.) frjhezmenetele eltt mosnknt s cseldknt dolgozott a magldi evanglikus lelksznl, Martiny Mihlynl. Szlovk anyanyelv volt, a magyar nyelv hasznlatra csak asszonykorban trt t.[5] +Petfi szlhza Kiskrsn + +Petrovics Istvn s Hrz Mria valsznleg Magldon ismerkedtek meg, m 1818. szeptember 15-n Aszdon ktttek hzassgot, Mikuls Dniel evanglikus lelksz eskette ket, nejvel mindketten az evanglikus vallst gyakoroltk. Petrovics ekkor szabadszllsi szkbrl volt, majd 1821-ben Kiskrsre kltztek. 1822-24-re a csaldf kibrelte a kiskrsi mszrszket s ott lakott nejvel egytt, gy szletett ott meg tdfl vi hzassguk utn els gyermekk, Sndor. + +Petfi Sndor az 1822. december 31-rl 1823. janur 1-jre virrad jszakn szletett Kiskrsn, ahol janur 1-jn kereszteltk meg az evanglikus valls szerint.[6] A gyermek szletsekor oly gyengcske volt, hogy egy emlkez szerint spirituszban frdettk, hogy megmaradjon. Egyetlen ccse, Petfi Istvn 1825-ben szletett. + +Apjnak a kiskrsi brlet elg jl jvedelmezett. A 3 vi ciklus leteltvel, 1824. oktber 14-n a nagyobb kiskunflegyhzi szkbrletre vllalkozott s ez v oktberben csaldjval egytt oda is kltztt. A csald jlte itt mg inkbb fllendlt s Petfi vidm s boldog gyermeksget lt, melynek emlkei ksbb is mindig des rzssel tltttk el szvt. Petfi e vrost Szlfldemen (1848) cm kltemnyben szletse helynek nevezte, e szavai ksbb sok vitra adtak okot a kt telepls, Kiskrs s Kiskunflegyhza, illetve a klt letrajznak kutati kztt is. A csald elszr meglehetsen j anyagi krlmnyek kztt lt. Petrovics Istvn gyes vllalkoz volt, a mszrszk mellett kocsmt brelt s mkdtetett. A csald anyagi felemelkedsnek helyszne egy ideig Kiskunflegyhza volt. A csaldf fenntartott kt mszrszket Kiskunflegyhzn, illetve Szabadszllson, tbb ingatlan tulajdonosa volt, sajt fldjeiken s brelt fldeken is gazdlkodott. +Tanulvei +Az jszltt Alexander Petrovics keresztelsi bejegyzse a Kiskrsi Evanglikus Egyhzkzsg keresztelsi anyaknyvben (IV. ktet /18141838/, 127. oldal) + +Petfi eleven, elms, kiss makacs, de jszv gyermek volt. Kemny apja szigorsggal, anyja gyngdsgvel vezette. desapja lehetsgeihez mrten megprblta a legjobb iskolztatst biztostani gyermekeinek. Az ifj Petfi sszesen kilenc iskolban tanult, mr tvesen koptatta az iskolapadot. Flegyhzn ment elszr iskolba, itt azonban inkbb csak vendgknt jrt be a rmai katolikus elemi iskolba egy ideig 1828 elejn, mivel mr ezt megelzen oktattk olvassra[7] s rajzra, a rajzhoz ksbb is kedvet mutatott. Ezutn hrom vig Kecskemten tanult, 1828. mjus 10-n vitte apja az evanglikus npiskolba, itt iratta be 1829. mjus 10-n, illetve 1830. mjus 15-n. Az intzmnyben mr nmi latint is tanult. Szllson Habel Jzsefnl volt, aki akkor az reg Petrovics flegyhzi s kecskemti mszrszkeinek haszonbrl-trsa volt. Vakcizni haza, vagy kiskrsi rokonaihoz jrt. + +1830-ban szlei Flegyhzrl 6 vi ott laks utn Szabadszllsra kltztek vissza, ahol flegyhzi keresmnykbl meglehetsen szp vagyont, hzat s fldet szereztek. A harmadik iskolai vet nem is fejezte be Petfi Kecskemten, atyja 1831 elejn haza vitte Szabadszllsra, ahol akkor Ujlaky Istvn reformtus rektor algimnziumra ksztette fel a fikat. + +1831. szeptember 28-n atyja a dunntli Srszentlrincre kldte fit az evanglikus algimnziumba, ott kt vet tlttt mint donatista tanul. Tanra, Lehr Andrs fleg a latin nyelvet s szprst tantotta nagy kedvvel, s Petfi mindkettben kitnt. Szerette ezt az iskolt, s boldog gyermekkora volt: szlei gondosan ellttk, szllson a kzsg legjobb csaldjainl volt, s br mr ekkor szeretett rzelmeibe merlni, szvesen rszt vett diktrsainak, fleg a kiss nagyobbaknak jtkaiban is. A msodik vben Nmeth Ferenc nptantnl lakott. + +1833-ban a nmet nyelv tanulsa cljbl Pestre vitte apja, s augusztus 27-n beiratta az evanglikus nmet gimnziumba, ahol a II. donatista osztlyba jrt. Egy Petrovics nev lovashajd rokonnl lakott. Ekkor mr nem volt olyan j tanul. Apja emiatt 1834-ben a piaristkhoz vitte, ahol az I. grammatikai osztlyban a tbbnyire nmet tanulk kzt leginkbb a magyar nyelvben volt j, illetve osztlytrsai kzl rt s rajzolt a legszebben. Itt sem tanult jobban s az els osztlyt 1835 nyarn csak elsrend bizonytvnnyal vgezte. rdekldse mr ekkor a sznszet fel fordult, ezenkvl osztlyban tlsgosan sokan voltak. Pesten sokat volt alkalma gyakorolni a nmet nyelvet. A sznid nagy rszt keresztapja, Martiny Kroly gyvd hznl tlttte Kiskrsn. + +Apja mr azon gondolkodott, hogy kiveszi az iskolbl, de 1835-ben jra beadta felekezetnek aszdi algimnziumba, a II. grammatikai osztlyba. A kis vrosban, a kevsb npes osztlyban Petfi megint kitnt rendes magaviseletvel s szorgalmval, mely a 2. s 3. vben mg jobban fokozdott. Mint szintaxista mr nagy kedvvel gyakorolta a latin versformkat. Kedlylete fejlett, klti ambcii bredeztek; szvesen olvasta a kis knyvtr klti s trtneti mveit, elssorban Horatius dit szerette. Mikor azonban Aszdon sznitrsulat jrt, sznsznek akart felcsapni. Emiatt apja, akit Petfi tanra, Koren Istvn sietett rtesteni, meg is fenytette fit. Szllsa Neumannnl volt, a kt utols vben ccsvel egytt. + +Itt lobbant fel els szerelme Cancriny Emilia irnt, akihez szerelmes verset rt. Itt bartkozott ssze Neumann Krollyal, Dmk Elekkel s Eszterglyi Mihllyal. Rszt vett egy pr rtatlan dikcsnyben is. 1837 karcsonyra hrom iskolatrsval Pencre (ma: Pest megye) ment, ahol nagynnjt, Hrz Annt ltogatta meg, aki Kosztolnyi gyvdnl volt hzvezetn. + +Petfi mint els eminens tanul hagyta el 1838. jnius 30-n az aszdi algimnziumot. Jl beszlt nmetl s latinul; klnsen kitnt a magyar fogalmazsban, s az v vgi bcsvers elksztst, melyet mskor Koren tanr rt, ezttal r bztk. Az 54 hexameterbl ll vers fennmaradt s ez Petfinek legrgibb ismert kltemnye, cme: Bcszs 1838-ik vben. +Gyermekkornak szntere Kiskunflegyhzn + +Aszdi veirl az ti jegyzetekben gy emlkezik meg: + +Aszd! Csak egyszer kellene ezt a szt tlem hallnod, s azonnal kitallnd, hogy n itt hrom esztendig tanultam akarom mondani: jrtam iskolba. S mily esemnyds hrom esztend! 1. Itt kezdtem verseket csinlni. 2. Itt voltam elszr szerelmes. 3. Itt akartam elszr szinssz lenni. A versels a szerelem eredmnye volt. A szinssz lenni akarsnak pedig nem annyira eredete, mint kvetkezmnye nevezetes. Nevezetes s szomor.[8] + +Az 1845-ben rt ti jegyzetekben emltett els szerelme a tizent ves Cancrinyi Emlia volt, egy zvegy evanglikus lelksz lenya, aki Aszdon diktrsa volt. Emilia kisasszony nagyjbl egyids volt a kltvel, s ids korban kellemetlenl rintette, hogy az emlkezetben nyilvnvalan megkopott aszdi dik krl olyan nagy felhajtst csaptak a korabeli jsgok, nem szvesen beszlt Petfirl. Csak abban hasonltott a legtbb mzshoz, hogy sem szerette a verseket. Petfinek hozzrt nvnapi kszntjt azonban megrizte, br egyltaln nem tartotta becsben, mert vgl elkalldott.[9] Srja a tpiszelei temetben van. + +Ezzel azonban a boldog gyermekkor vget is rt, s a serdl Petfire a hnyattats s szenveds slyos vei vrtak. Apjt, ki az 1830-as vekben Szabadszllson is vrl-vre vagyonosodott, 1838-tl kezdve egymsutn slyos csapsok rtk; az 1838. vi rvz elnttte fldjt s elvitte hzt, egy megbizottja htlenl kezelte egyik brlett, st peres ton megkrostotta s birtokai egy rszt 1839-ben elrvereztk. Egy rokona, akinek klcsnpnzt adott s akirt jtllott, megbukott, gy hogy Petrovicsot is magval rntotta, emiatt 1840-ben mr gyszlvn semmije sem maradt. A sok csaps csak ingerltt tette a klnben is szigor apt, aki finak legcseklyebb tvedst sem tudta elnzni. Hozzjrult ehhez, hogy vrl-vre mind kevesebbet tudott rte ldozni is. A fira nzve pedig ezek az vek rendes krlmnyek kzt is vlsgosak lettek volna, mert fnyes szellemi tehetsgei kezdtek kinni az iskolai szk keretbl s bizonytalan clok utn sztnztk. + +Petfi 1838. augusztus 31-tl a Selmecbnyai Lceumba jrt, ahol az 5. osztlyba, els ves rtornak iratkozott be. Mr itt rdekldni kezdett a korabeli nemzeti s irodalmi kzdelmek irnt, s a vegyes nemzetisg ifjsg kzt, melyben ahogy a tanrok kzt is pnszlv trekvsek is megnyilvnultak, magyarnak vallotta magt s lelkesen csatlakozott az ifjsg kebelben fennllt Nemes Magyar Trsasg nev nkpzkrhz, melybe els ves rtor ltre nem kezd, hanem rendes tagknt vettk fel. E trsasgban elemben rezte magt, versekkel s brlatokkal tbbszr fellpett. Itt szavalta oktber 31-n a Cskot, november 7-n A htelenhez cm kltemnyt (mely elveszett); 1839. februr 16-n felolvastk A klt keserve cm kltemnyt (az rdemknyvbl kitpve). Bolemann ekkor megjsolta, hogy ebbl a fibl mg klt lesz. Tehetsgt sztotta a pr vvel idsebb Szebernyi Lajos, a trsasg elnke, akivel Petfi bartsgot kttt. Boleman Istvn s Lichard Dniel voltak tanrai, elbbi kltszettant, latin fordtst, stlusgyakorlatokat s fldrajzot tantott, az utbbi pedig hittanra, rgisgtanra s magyar trtnelemre oktatta az ifjsgot latinul, mivel magyarul nem tudott. Ezenkvl a nmet nyelvet is gyakoroltk. + +Az iskolban azonban rohamosan hanyatlott, fleg egyes trgyak tanulsra adta magt s nmvelsnek lt. Szegnysge is nyomaszt volt r nzve, az alumneumban ebdelt. Hogy eljrhasson a sznhzba, amelyrt rajongott, egy s ms holmijt eladta. Ezrt rszeges hzigazdja[10] korhelysggel vdolta tanrai, utbb atyja eltt. Ezrt megharagudott gazdjra s 1839 elejn Szebernyi kzelben, zv. Fedknnl fogadott lakst. + +A flvi vizsglat is rosszul sikerlt, s egyik szlv rzelm tanrtl, Lichard Dnieltl magyar trtnelembl elgtelent kapott. Apja erre megrta neki, hogy mint rdemetlen firl leveszi rla kezt, mire Petfi 1839. februr 15-n elhagyta a selmeci lceumot. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szavak.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szavak.txt new file mode 100644 index 0000000..c530483 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szavak.txt @@ -0,0 +1,33523 @@ +a +abba +abbahagy +abbahagyat +abbamarad +abesszin +ablak +ablakkeret +ablakmászás +ablakmélyedés +ablakocska +ablakpárkány +ablakrács +ablaksor +ablaktábla +ablaktalan +ablaktörlő +ablakú +ablaküveg +abrak +abrakostarisznya +abrosz +abroszos +abszolút +absztrahál +absztrakt +abszurd +abszurdum +acat +acél +acélcső +acélerős +acélfal +acélfogsor +acélgömb +acélkar +acélkék +acélkeretű +acéllemez +acélmennyezet +acélos +acélosítás +acélosság +acélprés +acélszínű +acéltömb +acélüzem +achátszivárványos +acsarkodik +acsarog +ad +ad-vesz +adás +adás-vétel +adag +adakozás +adakozó +adalék +adat +adatfeldolgozó +adatgyűjtés +adatszolgáltatás +addig +addigi +adjonisten +adjunktus +adminisztráció +adminisztrál +adminisztrálás +adminisztrátor +adminisztratív +adó +adó-vevő +adóbevallás +adócsalás +adódik +adófelügyelő +adómentes +adómentesség +adórovás +adós +adósság +adószedő +adótartozás +adózik +adogat +adomány +adományoz +adoptál +adott +adottság +adu +aeronautika +afelett +afeletti +afelől +afféle +affrikáta +afrikai +afrikansz +agár +agancs +agg +aggály +aggályos +aggályoskodás +aggályoskodik +aggastyán +aggaszt +aggasztó +aggat +aggkori +agglegény +aggódás +aggódik +aggodalmas +aggodalmaskodás +aggodalom +aggregátor +aggszűz +agilis +agitáció +agitál +agitátor +agitatív +agonizálás +agrár +agráregyetem +agrárpolitika +agrárproletár +agrárproletariátus +agrártudomány +agresszív +agronómus +agronómusság +agy +agyafúrt +agyag +agyagdomb +agyagedény +agyagkorsó +agyagos +agyagréteg +agyalágyult +agyalkat +agyar +agyba-főbe +agyérelmeszesedés +agykéreg +agyő +agyonás +agyonbarázdált +agyonbüntet +agyoncivilizál +agyoncsap +agyoncsíp +agyondagaszt +agyondédelget +agyonetet +agyonfagy +agyonhasznál +agyonistenít +agyonjár +agyonkínoz +agyonkövezés +agyonlapít +agyonlő +agyonmos +agyonnyom +agyonölelget +agyonpöttyöz +agyonszorít +agyonüt +agyonvág +agyonver +agyonveret +agyonzsúfol +agyrázkódás +agysebész +agysejtállomány +agytérkép +agytröszt +agytumor +agyú +agyvérzés +agyvelő +ah +aha +ahány +ahányszor +aham +ahelyett +ahogy +ahogyan +ahol +ahonnan +ahova +aj +ajándék +ajándékoz +ajándékozás +ajánl +ajánlat +ajánlatos +ajánlgat +ajánlkozik +ajánló +ajánlólevél +ajaj +ajak +ajjaj +ajkbiggyesztve +ajnároz +ajókagyűrű +ajtó +ajtóbetét +ajtócsapódás +ajtócsukás +ajtófél +ajtókulcs +ajtólap +ajtónagyságú +ajtónyitás +ajtóragaszték +ajtórés +ajtószárny +akác +akácbokor +akácerdő +akácfa +akácfarönk +akácméz +akácos +akáctörzs +akáctuskó +akár +akárcsak +akárhányszor +akárhogy +akárhogyan +akárhol +akárhonnan +akárhova +akárki +akármeddig +akármelyik +akármennyire +akármerre +akármi +akármiféle +akármikor +akármilyen +akármint +akad +akadály +akadályoz +akadálytalan +akadékoskodás +akadékoskodik +akadémia +akadémikus +akadozik +akar +akarás +akarat +akaratátvitel +akaraterő +akaratlan +akaratos +akaratoskodás +akaratú +akarnok +akarnokság +akaródzik +akarom +akarva-akaratlanul +akaszkodik +akaszt +akasztás +akasztanivaló +akasztófa +akceleráció +akció +akciócsoport +akciósablon +aki +akként +akképpen +akklimatizálódás +akkor +akkora +akkorára +akkord +akkori +akkoriban +akkornap +akkortájban +akkortájt +akkurátuskodás +akna +aknász +aknamező +aknamunka +aknatűz +aknavető +aknazápor +aközben +akol +akrobataugrás +akt +akta +aktatáska +aktatáskás +aktfotó +aktfotós +aktív +aktor +aktuális +aktus +akut +alá +aláás +aláad +aláaknáz +alább +alábbhagy +alábbi +alábocsát +alábújik +alácsúsztat +aládúcol +aláejt +aláereszkedik +aláfalaztat +aláfest +aláfutásos +alágyűr +aláhúz +aláhull +aláhuzigál +aláír +aláírás +aláírat +alája +alákérdez +aláleng +alámerül +alámos +alárendel +alássan +alászáll +alászolgája +alátámaszt +alátét +alátesz +alávaló +alávalóság +alávet +aláz +alázat +alázatos +alázkodás +alázkodik +alacsony +alagsor +alagsori +alagút +alagútépítő +alagútfúrás +alagútszerű +alak +alakít +alakítás +alakítgatás +alakos +alakoskodás +alakoskodik +alaktalan +alakú +alakul +alakulás +alakulat +alakzat +alamizsna +alant +alantas +alany +alap +alapállás +alapanyag-differenciáltság +alapelv +alaphang +alaphazugság +alapít +alapítás +alapítási +alapító +alapján +alapméret +alapötlet +alapos +alapoz +alapozás +alaptalan +alapterület +alaptörvény +alapú +alapul +alapvető +alapvicc +alapvizsgázik +alapzat +alatt +alatta +alatti +alattomos +alattvaló +albán +albérlet +albérleteskedik +albérleti +albérlő +albérlői +album +alélt +alezredes +alezredesi +alfaj +alfél +alföldi +alga +algyői +alhadnagy +alibi +alibi-termelés +alibizik +alig +alig-alig +aligha +alighanem +alighogy +aligség-alig +alj +aljakő +aljas +aljasság +alkalmas +alkalmatlan +alkalmatlankodik +alkalmatos +alkalmaz +alkalmazás +alkalmazható +alkalmazhatóság +alkalmazkodás +alkalmazkodik +alkalmazkodó +alkalmazott +alkalmazotti +alkalmi +alkalom +alkalomadtán +alkat +alkati +alkatrész +alkatú +alkohol +alkoholadag +alkoholfogyasztás +alkoholillat +alkoholista +alkoholizmus +alkoholmámor +alkony +alkonyat +alkonyattájt +alkonyi +alkonyodás +alkonyodik +alkot +alkotás +alkotmány +alkotmányjog +alkotó +alkotóerő +alkotóképesség +alkotókedv +alkotóművész +alkotómunka +alkotórész +alku +alkudozás +alkudozik +alkuszik +allergiás +alma +almás +almáskert +almásláda +almásszürke +almafényű +almahalom +almamosolygós +almaszagú +almazöld +alól +alóla +alom +alorvos +alosztály +alpesi +alpinista +alsó +alsóbbrendű +alsóbbrendűségi +alsógatya +alsónadrág +alsónemű +alsóruha +alsószoknya +alsótelepi +alsótest +alszik +alt +alta +altábornagy +altat +altatás +altatásos +altató +alternatíva +altiszt +altiszti +aludttej +alul +aluli +aluljáró +alulmarad +alulnézet +alumínium +aluszékonyság +alvás +alvásszagú +alvadt +alvatlanság +alvezér +alvidék +alvilág +alvilági +alvó +amarra +amatőr +amaz +ambíció +ambiciózus +ambrózia +ameddig +amekkora +amellett +amely +amelyik +amennyi +amennyiben +amennyire +amerikai +amerre +amerről +ami +amíg +amiatt +amidőn +amiért +amiként +amiképpen +amikor +amily +amilyen +aminő +amint +aminthogy +amióta +amire +ammóniák +ammóniákszag +amnesztia +amögött +amoda +amoly +amolyan +amonnan +amorf +amott +amputáció +amszterdami +amúgy +amulett +anakronizmus +analfabéta +analitikus +analóg +anamnézis +ananász +anarchikus +anarchista +anatómia +anatómiai +andalgás +andalog +anélkül +anekdota +anekdotázás +angliai +angol +angolbarát +angolos +angolság +angolszász +angyal +angyali +angyalka +annál +annektálás +annyi +annyi-annyi +annyiban +annyiféle +annyifelé +annyira +annyiszor +anomália +anomális +antanthatalom +antantintervenció +antantmintájú +antenna +antennájú +antifasiszta +antik +antikrisztus +antikvárium +antiszemita +antiszemitizmus +antul +anya +anyás +anyáskodik +anyátlan +anyaarc +anyacsászárnő +anyaföld +anyag +anyagcsere +anyagerő-háború +anyagerő-robbantás +anyaghalmaz +anyagi +anyagkészlet +anyagmennyiség +anyagmozgatás +anyagmozgató +anyagpazarlás +anyagráfordítás +anyagraktár +anyagrészecske +anyagú +anyagyilkos +anyaház +anyai +anyajegy +anyajogú +anyakönyvi +anyakönyvvezető +anyaméh +anyamell +anyanyelv +anyaország +anyaszentegyház +anyaszerű +anyaszült +anyaszülte +anyatej +anyatermészet +anyós +anyóstárs +anyu +anyuci +anyuék +anyuka +anyusék +apa +apáca +apácanövendék +apácarend +apácazárda +apácska +apás +apátia +apacsinges +apad +apadás +apafej +apagyilkos +apahiány +apai +apellál +apelláta +apó +apóék +apóka +após +apósék +apokrif +apolitikus +apostol +apparátus +apránként +apraja +apraja-nagyja +aprít +apró +aprócska +apródkard +apródonként +apróhirdetés +aprójószág +apróka +aprólék +aprólékleves +aprólékos +aprómunka +aprópénz +apróra +apróság +aprósütemény +aprószemű +aprószentek +apróvad +apszis +apu +apuék +apuka +apus +apusék +apuska +arány +aránylag +arányos +arányszám +aránytalan +aránytalanság +arányú +arab +arab-néger +arabeszk +arany +aranyásó +aranybányász +aranybarna +aranyborjú +aranybulla +aranycsatos +aranycsillám +aranydísz +aranydukát +aranyedény +aranyember +aranyeső +aranyfiú +aranyfoglalatú +aranyfogú +aranyfüggő +aranyfűz +aranygomb +aranygombos +aranygyűrű +aranyhal +aranyhegedű +aranyhegy +aranyifjú +aranykalászos +aranykarika +aranykezű +aranykor +aranykorona +aranylánc +aranyláz +aranylemezke +aranyló +aranymálinkó +aranymúmia +aranyos +aranyoska +aranyoz +aranyozott +aranyperec +aranypor +aranyrög +aranyrügy +aranysárga +aranyszínű +aranyszőke +aranyszőrű +aranytapintású +aranyzsinóros +arasz +arasznyi +araszolgat +araszoló +arat +aratás +aratási +aratógép +arc +arcbőr +arcél +arcélmény +arcélű +archívum +arcizom +arcjáték +arckép +arckifejezés +arcmás +arcmemória +arcösszedörzsölés +arcocska +arcszesz +arcszínű +arcú +arcüreg +arculat +arcvonás +arcvonású +arcvonal +argó +ariánus +arisztokrácia +arisztokrata +aritmiás +aromás +arra +arrább +arrafelé +arravaló +arról +artéria +artézi +artikulációs +artikulálatlan +artista +arzenál +aspektus +aspiránsi +aspirantúra +aspirantúra-időszak +asszisztál +asszisztens +asszisztensnő +asszociáció +asszony +asszonyember +asszonyféle +asszonyi +asszonyka +asszonylány +asszonynév +asszonyos +asszonyság +asszonysors +asszonytárs +asszonytörpe +aszály +aszalt +aszerint +aszfalt +aszfaltos +aszkétaarc +aszkézis +aszketikus +aszódi +aszondja +aszott +aszparágusz +aszpik +aszpirin +asztag +asztal +asztalféle +asztalfiók +asztalfő +asztali +asztalka +asztallap +asztalnyi +asztalos +asztalosmester +asztalosrészleg +asztalossegéd +asztalosszerszám +asztaltárs +asztaltársaság +asztalterítő +asztalvég +asztmás +asztrahánprémes +ateista +atlétaszerű +atlétatermetű +atlétatrikó +atlétatrikós +atmoszféra +atmoszférátlanság +atmoszféranyomás +atom +atom-időszámítás +atombomba +atomenergia +atomkor +atomtitok +attasé +attól +attrakció +atya +atyafi +atyafia +atyafiság +atyai +atyaúristen +atyó +atyóka +augusztus +augusztusi +auktor +aula +auszi +ausztrál +ausztráliai +autentikus +autó +autóbusz +autóbuszmegálló +autócilinder +autófolyam +autójavító +autómárka +autómoraj +autópárna +autórádió +autós +autószerelő +autószerencsétlenség +autóút +autóüveg +autóvezetés +autózik +autodidakta +autogénhegesztő +autogejzír +automata +automatika +automatikus +automatizál +automatizálás +automatizmus +autonómia +avagy +avar +avas +avasfejű +avatag +avatatlan +avatkozik +avatott +avult +az +azáltal +azalatt +azaz +azért +azelőtt +aznap +aznapi +azóta +azon +azonban +azonfelül +azonkívül +azonmód +azonnal +azonnali +azonos +azonosít +azonosság +azonosul +azontúl +aztán +azúr +azután +azzal +á +ábécé +ábra +ábránd +ábrándos +ábrándozás +ábrándozik +ábrázat +ábrázol +ábrázolás +ábrahámhegyi +ács +ácsmunka +ácsol +ácsolat +ácsorog +ádámcsutka +ádámcsutkájú +ádáz +áfonya +ág +ágál +ágacska +ágas-bogas +ágaskodik +ágazik +ágú +ágy +ágyás +ágyacska +ágyas +ágyaz +ágyazás +ágybontás +ágyék +ágyhuzat +ágynemű +ágyrajáró +ágytál +ágytakaró +ágyterítő +ágyú +ágyúcső +ágyúdörgés +ágyúlövés +ágyúöntő +ágyúz +ágyúzás +áh +áhít +áhítat +áhítatgyakorlat +áhítatgyakorlati +áhítatos +áhítozik +ájtatos +ájtatosság +ájulás +ájult +ál +álarc +álca +álcáz +áld +áldás +áldatlan +áldó +áldott +áldoz +áldozás +áldozat +áldozathozatal +áldozati +áldozatos +áldozatvállalás +áldozik +álhír +álkulcs +áll +állás +állásfoglalás +álláspont +állástalan +állású +állag +állam +állambiztonsági +államérdek +államerdészet +államférfi +államfő +államfői +államháztartás +államhatalom +állami +államkincstár +államminiszter +állammonopolista +államosítás +állampolgár +állampolgárság +államrendőrség +államszervezet +államszövetség +államtitkár +államtitok +állandó +állandóság +állandósul +állapot +állapotos +állat +állatgondozó +állati +állatka +állatkert +állatkiállítás +állatnév +állatocska +állatorvos +állatszem +állattenyésztő +állatvilág +álldogál +álldogálás +állékonyság +állhatatlan +állhatatos +állhatatosság +állít +állítás +állítható +állítmány +állító +állítólag +állítólagos +állkapcsos +állkapocs +álló +állólámpa +állótükör +állóvíz +állomány +állomás +állomáselöljáró +állomásfőnök +állomáshely +állomásozik +állott +állvány +állványos +állványzat +álmatag +álmatlan +álmatlanság +álmélkodás +álmélkodik +álmélkodó +álmodik +álmodozás +álmodozik +álmodozó +álmos +álmosít +álmosság +álnév +álnok +álnokság +álnyakkendő +álom +álombeli +álomkép +álomszerű +álomtalan +álruha +álság +álságos +álszerény +álszerénység +által +általa +általában +általános +általánosít +általánosítás +általánosítható +általánosság +általi +általmegy +általszalad +áltat +ám +ámbár +ámbátor +ámde +ámen +ámolygás +ámul +ámulás +ámulat +ámuldozik +ánizsos +ápol +ápolás +ápolatlan +ápoló +ápolónő +ápolónőképző +ápolónővér +ápolószemélyzet +ápolt +áporodott +április +áprilisi +ár +árad +áradás +áradat +áradozik +áram +áramgyűjtő +áramkör +áramlás +áramlat +áramlik +áramtalanító +áramütés +áramütéses +árapály +áraszt +árboc +árendál +árfolyam +árgus +árhullám +ária +áriázik +árja +árja-párja +árkád +árkádos +árkász +árkászalakulat +árkon-bokron +árkos +árkülönbség +ármádia +ármányos +árny +árnyalak +árnyalat +árnyalatnyi +árnyalatú +árnyas +árnyék +árnyékol +árnyékos +árnyéksáv +árnyékszék +árnyékú +árnyszerű +árok +árokásó +árokpart +árokrendszer +árpa +árpád-féle +árrendszer +árrendszer-kérdés +árt +ártány +ártalmas +ártalmatlan +ártalom +ártatlan +ártatlanság +áru +árucikk +áruház +árukészlet +árul +árulás +árulkodik +árulkodó +áruló +árus +árusít +áruszállító +árutérítés +árva +árvaház +árvaházi +árvaság +árvédelmi +árvíz +árvízvédelem +árvízvédelmi +árvízveszély +ás +ásás +ásat +ásít +ásítás +ásítozik +áskálódik +ásó +áspiskígyó +ásvány +ásványtani +ásványvizes +ász +át +átállít +átázik +átabotában +átad +átadás +átalakít +átalakítás +átalakul +átalakulás +átall +átalszik +átbámul +átbeszélget +átböngész +átbújik +átcaplat +átcsap +átcsatol +átcsavar +átcserél +átcsorog +átcsúszik +átcuppog +átdob +átdug +átél +átélés +átépítés +átépül +átér +átérez +átérzés +átejt +átellenben +átellenében +átenged +áteresz +átereszt +átesik +átevez +átfázik +átfényesít +átfénylik +átfektet +átfeszít +átfog +átfogalmaz +átfogható +átfogó +átfon +átfordít +átfordul +átfúr +átfűlik +átfűrészel +átfurakodik +átfut +átgázol +átgördül +átgondol +átgondolt +átgyakorlatozik +áthárít +áthajlik +áthajózik +áthajol +áthalad +áthallatszik +áthangol +átharap +áthasít +áthat +átható +áthatol +áthatolhatatlan +áthelyez +áthelyezés +áthelyeztet +áthív +áthívat +áthidal +áthoz +áthúz +áthurkol +átír +átírás +átível +átigazol +átigazolás +átigazolási +átirat +átitat +átitatódik +átjár +átjárás +átjáró +átjavít +átjön +átjut +átkarol +átképzés +átképzős +átkér +átkel +átkelés +átkelő +átkelőhajó +átkerül +átkígyózik +átkísér +átködlik +átköltözik +átköt +átkos +átkoz +átkozódik +átkozott +átküld +átkulcsol +átkutat +átlábol +átlát +átlátszó +átlag +átlagember +átlagos +átlagosztályzat +átlapoz +átlényegít +átlényegül +átlép +átlépés +átlépeget +átlendül +átleng +átló +átlós +átlő +átlovagol +átlyuggat +átmászik +átmérőjű +átmegy +átmelegedik +átmelegít +átmenet +átmeneti +átment +átmetsz +átmetszés +átnéz +átnedvesedik +átnevelés +átnyalábol +átnyit +átnyomódik +átnyomul +átnyújt +átnyúl +átölel +átöltözés +átöltözik +átömlik +átok +átpásztáz +átpasszol +átpattan +átplántál +átpöfög +átrámol +átrándul +átráz +átragad +átragyog +átrajzolódik +átrak +átrakosgat +átrendezés +átrepül +átrepülés +átrezzen +átrobog +átrohan +átsétál +átsegít +átsettenkedik +átsiet +átsiklik +átsüt +átsugárzik +átsuhan +átszáll +átszállás +átszálló +átszámít +átszakít +átszalad +átszel +átszellemül +átszenved +átszervezés +átszerveződik +átszínez +átszíneződik +átszivárgás +átszivárog +átszól +átszökik +átszökken +átsző +átszúr +átszüremlik +átszűr +áttanulmányoz +áttérés +áttekint +áttekintés +áttekinthetetlen +áttekinthető +áttekinthetőség +áttelefonál +átteleltet +áttelepedik +áttelepít +áttelepítés +áttelepitett +áttelepült +áttesz +áttetszik +áttetsző +áttör +áttördel +áttörés +áttol +áttüzesedik +átúszik +átül +átültet +átüt +átütő +átüzen +átugrál +átugrik +átutal +átutazó +átvág +átvált +átváltozik +átváltoztat +átvándorol +átvérzik +átvészel +átvétel +átvedlik +átvegetál +átver +átvergődik +átvesz +átvet +átvetődés +átvezet +átvilágít +átvillan +átvirraszt +átvisz +átvizel +átvizsgál +átvizsgálás +átvonszol +átvonszolódik +átvonul +átvonulás +átzsírosodik +átzúdul +ávós +ázalék +ázik +ázsiai +ázsió +áztat +áztatgat +b-kategóriájú +ba-ba-ba-ba-ba +báb +bába +bábaasszony +bábaház +bábamesterség +bábaoklevél +bábaság +bábatábla +bábcsoport +bábelőadó +bábjáték +bábu +bácsi +bácsiék +bácsika +bácskai +bádogbódé +bádogdísz +bádogdoboz +bádogeresz +bádoghordó +bádogláda +bádoglemez +bádogmaszk +bádogmosdó +bádogpult +bádogrész +bádogsárkány +bádogtányér +bádogtest +bádogváza +bágyadt +bágyadtság +bágyasztó +báj +bájos +bál +báli +bálna +bálnafaj +bálterem +bálvány +bálványimádó +bálványozás +bámész +bámészkodás +bámészkodik +bámészkodó +bámul +bámulat +bámulatos +bámultat +bán +bánásmód +bánat +bánatos +bánik +bánkódás +bánkódik +bánt +bántás +bántalom +bántatlan +bántó +bántódás +bánya +bányász +bányászati +bányászik +bányászsztrájk +bányaiskola +bányamentő +bányaművelési +bányarém +bányatársaság +bányatanácsos +bányaterület +bányatűz +bányaüzem +bár +bárány +báránybőr +bárányfelhő +bárányhimlős +bárányka +bárasztal +bárcsak +bárd +bárdolatlan +bárgyú +bárha +bárhogy +bárhogyan +bárhol +bárhova +bárka +bárki +bármeddig +bármely +bármelyik +bármennyi +bármennyire +bármerre +bármi +bármiféle +bármikor +bármily +bármilyen +báró +bárónő +bárpult +bársony +bársonyfüggöny +bársonyfüggönyös +bársonyhüvely +bársonymellényféle +bársonymellényke +bársonyszalag +bársonyszék +bárszék +bárszekrény +bártulaj +bástya +bástyaféle +bástyamaradvány +bástyaszerű +bátor +bátorít +bátorítás +bátorító +bátorkodik +bátorodik +bátorság +bátortalan +bátortalankodik +bátya +bátyus +bátyuska +bávatag +bázeli +bázis +bázisterület +bázisú +bázisüzem +bab +baba +babaarc +babaarcú +babahajtű +babér +babérlevél +babgulyás +bableves +babona +babonás +babrál +babramunka +babszem +babusgat +babusgatás +bacchusi +bacilus +bacilusgazda +bacilyuk +badarság +bagaria +bagó +bagószagú +bagózik +bagoly +bagolypárti +bah +baj +bajai +bajbajutott +bajkeverő +bajlódik +bajmolódás +bajmolódik +bajnok +bajnokcsapat +bajnoknő +bajnokság +bajomi +bajor +bajos +bajoskodik +bajszos +bajszú +bajtárs +bajtársiasság +bajusz +bajuszos +bajusztalan +bajuszú +bak +baka +bakafántos +bakalódik +bakancs +bakancsléptek +bakancsnyom +bakancsos +bakhát +baklövés +bakonyi +bakszakáll +baktat +baktérium +bakter +bakterház +bakterházi +bal +balatoni +baldachinszerű +balegyenes +baleset +balesetbiztosítás +balesetelhárítási +balesetelháritó +baleseti +balesetmentes +balesetoktatás +balesetveszély +balfácán +balga +balgatag +balhé +balhézik +baljós +baljóslat +balkáni +balkon +balkonajtó +ballada +balladai +ballag +ballon +ballonkabát +ballonugrás +ballusztrád-motívum +baloldal +baloldali +baloldaliság +baloldalt +balos +balpriuszos +balsejtelem +balsiker +balsikerű +balsors +balszerencse +balta +baltikumi +balvélemény +balzsam +balzsamoz +balzsamozás +balzsamozási +balzsamozott +bamba +bambaság +bambulás +bambulási +bamm +banális +banán +banda +bandaharc +bandita +banditagazda +bandukol +bandzsa +bandzsít +bank +bankárné +bankelnök +bankett +bankhivatalnok +banki +bankigazgató +bankjegy +banklevél +bankó +bankrablás +banktisztviselő +bankvállalat +barát +baráti +barátkozás +barátkozik +barátnő +barátocska +barátság +barátságos +barátságtalan +barázda +barázdál +barázdás +barack +barackfa +barackos +barackpálinka +barackpálinkás +barakk +barakkablak +barakklakás +barakklakó +barakksor +barangol +barbár +barcsi +barett +barikád +barka +barkácsol +barkochba +barlang +barlangvasút +barna +barnás +barnáspiros +barnásvöröses +barnamedve +barnapiros +barnaszén +barnul +barokk +barokkos +barom +baromfi +baromorvos +baromság +baromvásár +basa +basáskodás +basszus +batár +batári-féle +batiszt +batisztruha +batisztzsebkendő +batyu +bauxit +bazár +bazári +bazalt +bazaltkeménységű +bazaltkő +bazedovos +bazen +bazsarózsa +bazsi +be +be-becsap +be-benéz +bécsi +bécsies +bég +béget +béka +békaember-felszerelés +békalencsés +béke +békés +békéscsabai +békétlenkedik +békebeli +békecsók +békeév +békeidő +békejobb +békesség +békességes +béketárgyalás +béketűrő +békít +békítés +békítget +béklyó +békülés +békülési +bél +bélés +bélel +bélelt +bélmosóasszony +bélrendszer +bélű +bélyeg +bélyegbolt +bélyegez +bélyegkereskedés +bélyegző +béna +bénaság +bénít +bénul +bénult +bénultság +bényei +bér +bérbefogadás +bérel +bérelszámoló +béremelés +bérenc +béres +bérfizetési +bérház +bérlemény +bérleményi +bérlethirdetés +bérlő +beáll +beállít +beállítás +beállítottságú +beállványoz +beárad +beáramlás +beárnyékol +beárul +beázik +beáztat +bead +beadvány +beakad +bealkonyodik +bearanyoz +beavat +beavatkozás +beavatkozik +beavatódik +beavatott +bebábozódik +bebámul +bebaktat +beballag +bebalzsamoz +bebalzsamozás +bebarangol +bebeszélés +bebizonyít +bebizonyítható +bebizonyosodik +bebiztosít +bebörtönöz +bebocsát +bebocsátás +beborít +beborul +bebújik +bebútoroz +bebugyolál +bebukik +beburkol +becéz +becézés +becézgetés +becenév +becibál +becipel +becsajoz +becsap +becsapódás +becsapódási +becsapódik +becsavar +becsavarodik +becsempész +becsenget +becserkel +becses +becsiccsent +becsinál +becsinált +becsmérel +becsörtet +becsomagol +becsomagoltat +becsordul +becsorgat +becsorog +becstelen +becsúszik +becsúsztat +becsül +becsület +becsületes +becsületesség +becsületszó +becsűr +becsuk +becsukás +becsukódik +becsusszan +becsvágy +bedagad +bedagaszt +bedeszkáz +bedöglik +bedől +bedob +bedobál +bedobás +bedolgozás +bedudál +bedug +bedugul +beduin +bee +beékelődik +beépít +beépítés +beépítési +beépítetlen +beépített +beér +beérik +beérkezés +beérkezik +beejt +beemel +beenged +beereszkedik +beereszt +beesett +beesik +beesteledik +beexponálás +befárad +befagy +befagyaszt +befalaz +befér +befészkel +befecskendez +befed +befejez +befejezés +befejezetlen +befejezett +befejeződik +befejezte +befektet +befektetés +befelé +befeléfordulás +befellegzik +befest +befirkant +befizet +befőtt +befőttesüveg +befőz +befőzőgumi +befog +befogad +befoltosodik +befolyás +befolyásol +befolyásolható +befolyásoltat +befolyásos +befolyású +befordul +befúr +befűt +befűz +befűzetlen +befullad +befullaszt +befut +befutóegyenes +befuttat +begázol +begazol +begerjed +begerjeszt +begónia +begóniatő +begöngyöl +begördül +begőzöl +begombol +begorombulás +begurigázik +begurul +begy +begyakorol +begyakoroltat +begyalogol +begyes +begyógyul +begyömöszöl +begyújt +begyűjt +begyűjtési +begyűr +begyullad +behálóz +behátrál +behajít +behajlít +behajol +behajt +behallatszik +beharangoz +beharap +behatol +behatolás +behavaz +beheged +behív +behívat +behívó +behízelgő +behint +behódolás +behorpad +behorpaszt +behoz +behúz +behúzódik +behűt +behuny +behuppan +beígér +beír +beírat +beidéz +beidegzett +beidegzettség +beidegződik +beigazít +beijed +beiktat +beilleszkedés +beilleszkedik +beillik +beindít +beindul +beinkasszál +beinvitál +beirányít +beiratkozás +beiratkozik +beismer +beismerés +bejár +bejárat +bejárati +bejáratos +bejáratú +bejáró +bejárogat +bejegyez +bejegyzés +bejelent +bejelentés +bejelentkezik +bejelentő +bejelentőlap +bejön +bejötte +bejövet +bejut +bejuttat +bekacsint +bekalkulál +bekandikál +bekanyarodik +bekap +bekapar +bekapcsol +bekapcsolás +bekapcsolódás +bekapcsolódik +bekarikázik +bekattint +bekényszerül +bekéredzkedik +bekéret +bekebelez +bekecs +beken +bekeretez +bekerít +bekerül +bekerülés +bekezdés +bekísér +bekiált +bekiabál +beköltözik +beköp +beköszön +beköszönt +beköszöntés +beköt +bekötöz +bekötő +bekövetkezik +bekövetkezte +bekopog +bekopogtat +bekormányoz +bekrepál +bekúszik +beküld +bekubikol +bekukkant +bekukucskál +belát +belátás +beláthatatlan +belátogat +belakik +belapátol +belapul +bele +bele-belecsíp +beléje +belép +belépés +belépési +belépet +belépő +belépődíj +belépőjegy +beleáll +beleállít +belead +beleakad +beleavatkozik +belebámul +belebeszél +belebetegszik +belebokszol +belebonyolódik +beleborzong +belebotlik +belebújik +belebukik +belecsap +belecsenget +belecsimpaszkodik +belecsókol +belecsorgat +belecsúszik +beledagad +beledöf +beledöglik +beledönt +beledob +beledug +beledugdos +beledumál +beleél +beleér +beleért +beleérzés +beleegyesül +beleegyezés +beleegyezik +beleejt +beleesik +belefárad +belefásul +belefér +belefekszik +belefog +belefojt +belefolyik +belefordít +belefúj +belefúr +belefúródik +belefülled +belefullad +belegázol +belegabalyodik +belegondol +belegügyül +belegubancolódik +belegyömöszöl +belegyorsít +belehal +belehallatszik +beleharap +belehelyez +belehelyezkedik +belehempereg +belehülyül +beleír +beleilleszkedés +beleilleszkedik +beleillik +beleivódik +beleizzad +belejavít +belejön +belejut +belekalkulál +belekap +belekapál +belekapaszkodik +belekapcsolódik +belekarol +belekaszál +belekavar +belekékül +belekerget +belekerül +belekeseredik +belekever +belekeveredik +belekezd +belekóstol +beleköp +beleköpdös +beleköt +belekontárkodik +belekotyog +belekucorodik +belelát +belelapoz +belelép +belelendül +beleles +belelök +belelő +beleloval +belemászik +belemarkol +belemélyed +belemélyeszt +belemegy +belemelegedik +belemered +belemerül +belemormog +belenéz +belenevel +beleng +belenő +belenyargal +belenyikordul +belenyom +belenyúl +belenyugszik +belenyugvás +beleöl +beleömlik +beleönt +beleőrül +beleolvad +beleolvas +belep +belepillant +belepirul +belepofázik +beleprésel +belepusztul +belerág +belerándul +belerángat +beleragad +belerak +belerecseg +belerohan +belerokkan +belerúg +belerugdal +beles +belesápad +belesárgul +belesimul +belesóhajt +belesüllyed +belesüpped +belesuhint +beleszámít +beleszánt +beleszagol +beleszakít +beleszalad +beleszédül +beleszeret +beleszól +beleszólás +beleszólási +belesző +beleszokik +beleszúr +beleszületik +beleszuggerál +beletalál +beletanul +beletapogatódzik +beletapos +beletart +beletartozik +beletép +beletéved +beletekint +beletelepedik +beletelik +beletemet +beletemetkezik +beletesz +beletömköd +beletöröl +beletörődés +beletörődik +beletorkollik +beletűr +beleül +beleüt +beleütközik +beleugrik +beleun +belevág +belevakul +belevaló +belevés +belevésődik +belevegyül +belever +belevesz +belevet +belevezet +belevigyorog +belevisz +belevörösödik +belevonít +belezápul +belezabál +belezavarodik +belezökken +belezsibbad +belföldi +belfogyasztás +belga +belgrádi +belgyógyászat +belgyógyászati +belharc +belibben +belibeg +beljebb +belletrista +belök +belövöldöz +belő +belőle +belop +belopakodik +belső +belsőség +beltenger +belterjes +belterjesség +belterület +belügyi +belügyminiszter +belül +belüli +belváros +belvárosi +belvíz +bemászik +bemászkál +bemázol +bemasíroztat +bemaszatolódik +bemélyül +bemér +bemérő +bemegy +bemelegít +bemelegszik +bemenet +bemerészkedik +bemesél +bemocskol +bemocskolódik +bemond +bemondás +bemondó +bemutat +bemutatás +bemutatkozás +bemutatkozik +bemutató +bendő +benépesít +benépesül +benéz +benedvez +benevez +benn +benne +benneteket +bennfentes +bennszülött +bennünket +benő +benső +bensőséges +benyálaz +benyíló +benyilaz +benyit +benyom +benyomás +benyomul +benyújt +benyúl +benyúlik +benzin +benzineskanna +benzinköltség +benzinmotor +benzinszag +beöltözik +beöltöztet +beolajoz +beolt +beolvas +beolvaszt +beolvasztás +beomlik +beoson +beoszt +beosztás +beosztási +beosztású +beosztott +bepárásodik +bepanaszol +beperel +bepettyez +bepiszkít +bepiszkol +bepólyál +bepótol +bepörög +bepokrócoz +beprogramoz +beprogramozás +beránt +beragad +beragaszt +beragyog +berajzol +berak +berakás +berakosgat +berber +beregi +berek +berekeszt +berekeszthetetlen +berendel +berendez +berendezés +berendezési +berendezésű +berendezkedik +berepül +bereteszel +berezel +berliner +berlineres +berlini +berobban +berobog +berohan +berohanta +beront +beroskad +berozsdásodik +berreg +berregés +berúg +berúgat +beruházás +beruházó +berzenkedik +besározódik +besajtol +besatíroz +besavanyít +besétál +besiet +beslisszel +besmurkál +besóz +besöpör +besötétedik +besötétít +besorakozik +besorol +bespájzol +bespriccel +beste +bestia +bestoppol +besúgó +besüpped +besüt +besűrűsödik +besugárzás +besurran +besuttyan +beszáll +beszállás +beszállásolás +beszállít +beszálló +beszámít +beszámol +beszámoló +beszárad +beszagol +beszakad +beszalad +beszaladgál +beszappanoz +beszari +beszariság +beszéd +beszédes +beszédmodor +beszédtéma +beszédű +beszél +beszélés +beszélget +beszélgetés +beszélgetésfoszlány +beszélnivaló +beszélő +beszéltet +beszed +beszegez +beszentel +beszentelés +beszerel +beszerez +beszervez +beszerzés +beszerzőút +beszív +beszívódik +beszimatol +beszipog +beszippant +beszivárog +beszól +beszór +besző +beszorít +beszorul +beszúr +beszüntet +beszüntetés +beszüremlik +beszürkül +beszűkül +beszűrődik +betájol +betámaszt +betáplál +betársul +betagosít +betakar +betakargat +betakarítási +betakarózik +betalál +betanít +betanított +betart +betartás +betaszít +beténfereg +betér +betét +betétes +betétkönyv +betéved +beteg +betegágy +betegállomány +betegápolás +beteges +betegeskedik +betegség +betegségfolyamat +betegszabadság +betekint +betekintés +betelefonál +betelepedik +betelepít +betelepülés +betelhetetlen +betelik +beteljesít +beteljesül +betemet +betemetés +beterel +beterelget +beterjeszt +betervez +betessékel +betesz +betevő +betimsóz +betlehemi +betli +betódul +betökél +betölt +betöltés +betöltődik +betöm +betömés +betömődik +betömül +betör +betörés +betöréssorozat +betörik +betörő +betörülközik +betojik +betol +beton +betonágy +betonalj +betonbunker +betoncölöp +betonduzzanat +betonépület +betonfal +betonfolyosó +betongyűrű +betonhelyiség +betonhíd +betonjárda +betonkád +betonkerítés +betonkürtő +betonlap +betonlépcső +betonoldal +betonos +betonoszlop +betonoz +betonpadló +betonszoba +betontörmelék +betonút +betonudvar +betonutca +betonvályú +betoppan +betű +betűr +betűvetés +betűz +betudható +betuszkol +betyár +betyárbimbó +betyárbútor +betyárkodás +betyárvér +beúszik +beügyeskedik +beül +beüt +beütés +beüzen +beugrál +beugrat +beugratás +beugrik +beugró +beutal +beutalás +beutaló +beutalt +beutazik +bevág +bevágás +bevágódik +bevágtat +beválaszt +beválik +bevált +bevánszorog +bevár +bevásárlás +bevásárlókosár +bevásárol +bevagoníroz +bevagonírozás +bevagonoz +bevall +bevarr +bevégez +bevégeztetik +bevérez +bevétel +bevehetetlen +bever +bevesz +bevet +bevetés +bevezet +bevezetés +bevezető +bevezettet +beviharzik +bevilágít +bevillamosozik +bevisz +bevizel +bevon +bevonatú +bevonszol +bevontat +bevonul +bevonulás +bezár +bezárhatatlan +bezárkózik +bezárólag +bezárul +bezörget +bezsong +bezsúfol +bezúdul +bezuhan +bezupál +bezzeg +bíbelődik +bíbor +bíborköntös +bíboros +bíborosi +bíborpalást +bíborpalástos +bíborszegélyes +bíborszín +bíborvörös +bír +bírál +bírálat +bíráló +bíráskodás +bíró +bírói +bíróság +bírósági +bíz +bízik +bibi +bibircs +bibircsók +bibliai +biblikus +biccent +biccentés +biceg +bicegős +bicikli +bicikliabroncs +biciklikormány +biciklilánc +biciklipumpa +biciklista +biciklitúra +biciklizik +bicsaklik +bicska +bicskás +biggyedt +biggyeszt +bigyó +bika +bikaakol +bikaerős +bikahang +bikavér +bikini +bilgericsizma +biliárd +biliárdasztal +biliárdgolyó +bilincs +billeg +billeget +billen +billent +billenthető +billentyű +billió +bilux +bimbamoz +bimbó +bimbózik +bimm +biológia +biológiai +birizgál +birka +birkanyáj +birkózás +birkózik +birkózó +birodalmi +birodalom +birskörte +birtok +birtoklás +birtoklási +birtokol +birtokos +bisztró +bitang +bitófa +bitorló +bitorol +bivaly +bizánci +bizakodás +bizakodik +bizalmas +bizalmaskodás +bizalmasság +bizalmatlan +bizalmatlankodik +bizalmatlanság +bizalmi +bizalom +bizalomgerjesztő +bizalomkeltő +bizalomteremtés +bizarr +bizgat +bizományi +bizományos +bizonnyal +bizony +bizonyára +bizonygat +bizonyít +bizonyítás +bizonyíték +bizonyíthatatlan +bizonyítható +bizonyítvány +bizonyisten +bizonykodik +bizonylat +bizonyos +bizonyosan +bizonyosodik +bizonyosság +bizonyság +bizonyságkeresés +bizonytalan +bizonytalanság +bizonyul +bizottság +bizottsági +bizottságosdi +bizsereg +bizsergés +bizserget +bizsu +biztat +biztatás +biztató +biztonság +biztonsági +biztonságos +biztonságú +biztos +biztosan +biztosít +biztosítás +biztosíték +biztosító +biztosítószeg +biztosítótű +biztosítózár +blanketta +blaszfém +blaszfémia +blatt +blazírt +blende +blikkfangos +blöff +blöff-barokk +blöki +blokád +blokk +blokkol +blúz +bóbiskol +bódé +bódi +bódít +bódulat +bódult +bógnizik +bók +bóklászik +bókol +bókolgat +bólé +bólingat +bólint +bólintás +bólogat +bólogatás +bólongász +bólongat +bóna +bóra +bödön +bödöntúró +böffen +böfög +bögre +böhömnagy +böjt +böjtidő +bök +bökdös +bökkenő +bököd +bölcs +bölcsészdoktorátus +bölcsészkar +bölcsészkedik +bölcselem +bölcselet +bölcseleti +bölcselkedik +bölcsesség +bölcső +bölcsőde +bölcsőhely +bölény +bömböl +bömböltet +böngész +böngő +börtön +börtönbüntetés +börtönév +börtönőr +börtöntöltelék +bő +bőbeszédű +bőbeszédűség +bőg +bőgőbrummogásos +bőgőcsiga +bőgőmasina +bőkezű +bőkezűség +bőr +bőrbetegség +bőrbuborék +bőrdívány +bőrfarkas +bőrfotel +bőrgallér +bőrgalléros +bőrhajú +bőrkabát +bőrkabátos +bőrkeményedés +bőrkesztyű +bőrkötény +bőrlebeny +bőrmellény +bőrnadrág +bőrönd +bőrös +bőrruha +bőrsapka +bőrsaru +bőrszagú +bőrszék +bőrszíj +bőrszövet +bőrtárca +bőrtáska +bőrtalpú +bőrülés +bőrű +bőrzeke +bőrzekés +bőrzsák +bőrzubbony +bőség +bőséges +bőségszaru +bőszárú +bőszít +bőszoknyás +bőszült +bővérű +bővelkedik +bőven +bővít +bővítés +bővül +boci +bocsánat +bocsánatkérés +bocsánatkérő +bocsát +bocsátkozik +bocskor +bodor +bodorít +bodros +bodrozódik +bodza +bodzás +bodzabokor +bodzafa +bog +bogáncs +bogár +bogarászgat +bogarászik +bogarasság +boglya +bognár +bogrács +bográcsgulyás +bogyiszlói +bogyó +bohém +bohémség +bohóckodás +bohóckodik +bohócos +bohókás +bojnyik +bojtos +boka +bokázik +bokacsattogtatva +bokaösszerántás +bokaszíj +bokor +bokorhegyi +bokros-füves +bokrosodik +boksz +bokszer +bokszkesztyű +bokszol +bokszoló +bokszpáholy +boldog +boldog-boldogtalan +boldogít +boldogság +boldogtalan +boldogtalanság +boldogul +boldogulás +boldogult +bolgár +bolgárföld +bolgárkertész +bolha +bolhás +bolhaugrás +bolond +bolondéria +bolondforma +bolondgomba +bolondít +bolondokháza +bolondos +bolondozik +bolondság +bolondul +bolsevik +bolsevista +bolsiszag +bolt +boltajtó +bolti +boltív +boltos +boltosné +boltozat +boltozatos +boltozatú +boltsüveg +boltvezető +boly +bolygat +bolygó +bolyhos +bolyong +bolyongás +bomba +bombáz +bombázás +bombaköpeny +bombarepesz +bombarobbanás +bombatámadás +bombatalálat +bombaüzlet +bombazápor +bomlás +bomlik +bomlófélben +bonapartista +bonbonmeggy +bonc +boncmester +boncol +boncolás +boncolási +boncolgat +boncolgatás +boncolóorvos +bont +bontás +bontat +bontogat +bonyodalmas +bonyodalom +bonyolít +bonyolódik +bonyolult +bor +borbély +borbélymester +borbélyműhely +borbélysegéd +borbélyüzlet +borda +bordás +bordázat +bordacsont +bordatörés +bordély +bordélyház +bordó +bordói +bordóvörös +borít +boríték +borítékú +borító +borítólap +borítóvászon +borízű +borissza +borivó +borjú +borjúhús +borjúnyi +borjúpaprikás +borjúszegy +borkereskedő +borogat +borogatás +borong +borongás +borongós +boros +borosgazda +boroskorsó +borospalack +borosszakma +borosta +borostás +borostyán +borostyánlevél +borostyánszín +borostyánszínű +borosüveg +borotva +borotvál +borotválás +borotválkozás +borotválkozik +borotvapamacs +borotvapenge +borozás +borozgatás +borozik +borpince +borravaló +bors +borsószár +borszag +borszakértő +bortócsa +borús +borul +borulás +borulat +borult +borulta +borzad +borzadozik +borzalmas +borzalom +borzas +borzasztó +borzlyuk +borzol +borzolgat +borzong +borzongás +borzongat +borzsák +bosnyák +bosszankodás +bosszankodik +bosszant +bosszantó +bosszú +bosszúállás +bosszúálló +bosszús +bosszúság +bosszúvágy +bosszúvágyó +boszorka +boszorkány +boszorkányfű +boszorkányos +boszorkányság +bot +botanika +botanikus +botcsinálta +botlás +botladozik +botlik +botorkál +botoz +botránkozás +botrány +bozót +bozótos +bozontos +brancs +bratyizik +bravózik +bravúr +bravúros +brekeg +brennel +breviárium +bricsesznadrág +bridzsezik +bridzsrejtvény +brigád +brigádvezető +brigádvezetői +brigadéros +briliáns +briliánsgyűrű +brit +brokát +brokátfüggöny +brokátköntös +bronzfejedelem +bronzfigura +bronzszínű +bronztest +bronztestű +bronzvörös +bross +brosúra +brosúraszöveg +brr +brügecsi +brummog +brutális +bú +búb +búbánat +búbos +búbosdaru +búcsú +búcsúbeszélgetés +búcsújáró +búcsújelenet +búcsús +búcsúvacsora +búcsúzás +búcsúzik +búcsúzkodás +búcsúzkodik +búcsúzó +búcsúztat +búcsúztatás +búg +búgás +búj +búja-baja +bújik +bújócskaóra +bújtat +bújtatgat +bújtatott +búr +bús +búsképű +búskomor +búslakodik +búsul +bútor +bútorasztalos +bútordarab +bútorgyár +bútorkárpit +bútorozott +bútorú +bútorzat +bútorzatú +búvár +búvárszemüveg +búvóhely +búza +búzaillat +búzakalász +búzakék +búzaszál +búzatábla +búzavetés +búzavirág +büdös +büdösség +büfé +büféasztal +bükk +bükkfa +bükkönyféle +büntet +büntetés +büntetési +büntetett +büntetlen +büntető +büntetőbíróság +büntetőszázad +büntetőtábor +bürokrácia +bürokrata +büszke +büszkélkedik +büszkeség +bütykös +bütyök +bűbáj +bűbájos +bűn +bűnbánat +bűnbánó +bűnbeesés +bűnbeesik +bűncselekmény +bűnhődik +bűnjel +bűnlajstrom +bűnös +bűnösség +bűnözés +bűnözési +bűnöző +bűnper +bűnrészesség +bűnsegéd +bűntárs +bűntanya +bűntény +bűntelen +bűntett +bűntudat +bűntudatos +bűnügy +bűnügyi +bűnüldözési +bűnvádi +bűvésztányér +bűvöl +bűvölet +bűvös +bűz +bűzös +bűzpatak +buborék +budafoki +budai +budaörsi +budapesti +buddhista +budi +buga +buggyan +buggyos +bugris +bugyborékol +bugyborékolás +bugyelláris +bugyi +bugyibuli +bugyog +bugyolál +bugyor +bugyuta +buja +bujaság +bujdokol +bujdosás +bujdosik +bujdosó +bujkál +bujkálás +bukás +bukdácsol +bukfenc +bukfencezik +bukik +bukkan +bukórepülés +bukósisak +bukott +buksi +buksza +bukta +buktató +buli +bulizik +bulla +bulldózer +bulvár +bumm +bunda +bundás +bundabélés +bungaló +bunker +bunkó +bunkósodik +bura +burgonya +burgonyafúró +burjánzás +burjánzik +burkol +burkolat +burkolóanyag +burkolódzik +burkolt +burok +burran +bursi +burukkolás +burzsoá +busa +busás +busz +buszállomás +buszmegálló +buta +butáskodik +butaság +buton +butuska +buzdít +buzdítás +buzeráns +buzgár +buzgalom +buzgó +buzgólkodik +buzgóság +buzi +buzikölni +buzog +buzogány +buzogányos +c-kategóriájú +c-pavilon +cábár +cáfolat +cáfolhatatlan +cájgruha +cápa +cár +cári +cafat +cafka +cafrangos +cakk +cakkos +cammog +cappadóciai +cécó +cédrus +cédula +cég +cégér +cégéres +cégjelzés +cégtábla +cékla +céklaleves +cél +célegyenes +célfal +célfotó +célkitűzés +céllövölde +céllövöldés +céloz +célozgat +célpont +célravezető +célszerű +célszerűség +céltalan +céltudatos +célvonal +célzás +célzatos +cérna +cérnaember +cézár +cézárkodik +cefreszagú +cekker +cella +cellulóz +celofán +celsius-fokos +cement +cementgyár +cent +center +centi +centiméter +centiméternyi +centis +centralizálás +centralizált +centralizmus +centrifuga +centrum +ceremónia +ceremóniás +ceruza +ceruzavég +cetli +cetteg +cezaromániás +cezúra +cím +címbetű +címer +címeres +címernövény +címeroroszlán +címez +címlap +címnyilvántartó +címszerep +címszó +címtábla +című +címzés +címzett +cívis +ciánkáli +cibál +cibere +cica +cicomás +cidris +cifra +cifráz +cifranyomorúság-terv +cifraság +cifraszűr +cifraszűrös +cigány +cigányasszony +cigánybanda +cigányélet +cigányfekete +cigányfiú +cigánygyerek +cigányház +cigánykerék +cigánylány +cigánylegénység +cigánymuzsika +cigányos +cigányprímás +cigányvicc +cigányzab +cigányzene +cigaretta +cigarettásdoboz +cigarettázik +cigarettacsomag +cigarettafajta +cigarettafüst +cigarettagyújtás +cigarettapapír +cigarettatárca +cigarettavég +cigi +ciha +cikázás +cikázik +cikcakk +cikcakkos +cikk +cikkely +ciklámen +ciklámenzakó +cilinder +cilinderes +cimbalom +cimbalomhúr +cimbora +cimborál +cimpa +cimpácska +cincog +cingár +cinikus +cinizmus +cinkel +cinkos +cinkosi +cinkosság +cinkostárs +cipész +cipészmesterség +cipészüzlet +cipekedés +cipekedik +cipel +cipelmény +cipő +cipő-harisnya +cipőfazon +cipőfelsőrész-készítő +cipőfűző +cipőorr +cipőpertli +cipősarok +cipőszag +cipőtalp +cipruság +cipzár +cipzáras +ciráda +cirill +ciripel +cirkál +cirkáló +cirkusz +cirkuszi +cirkuszosló +cirmos +cirmoskodik +cirógat +cirógatás +cirokseprű +cirokvetés +cirom +ciszter +cisztercita +ciszterna +citátum +citera +citológia +citológus +citrom +citromarc +citromfa +citromlepke +citromos +civil +civilizáció +civilizálás +civilizálatlan +civilizált +civilruhás +civódás +civódás-öröm +cókmók +cölöp +cölöpvár +cövek +cövekel +coki +colos +comb +combközép +combtő +combú +compó +copf +copfos +csáberő +csábít +csábítás +csábító +csábos +csákány +csákigorbói +csámcsog +csámpás +csáp +csápol +csárda +csárdás +csárdaféle +császár +császárhús +császári +császári-királyi +császárkori +császárság +császkál +csabai +csacsi +csacsog +csacsogás +csahol +csahos +csaj +csajkarendszer +csak +csakhamar +csakhogy +csakis +csaknem +csakúgy +csakugyan +csal +család +családalapítás +családanya +családapa +családépítő +családfő +családi +családias +családnév +családos +családtag +csalános +csalánrengeteg +csalás +csalafintaság +csalétek +csalhatatlan +csalisíp +csallóközi +csaló +csalódás +csalódik +csalóka +csalogat +csap +csapágy +csapás +csapadék +csapat +csapattiszt +csapatvezető +csapda +csapdaállítás +csapdos +csapkod +csapkodás +csapláros +csapnivaló +csapóajtó +csapódik +csapodár +csapol +csapolt +csapong +csapos +csapott +csapszék +csaptelep +csapzott +csarnok +csarnokszerű +csat +csata +csatár +csatározás +csatározik +csatársor +csatabárd +csatakos +csatangol +csatangolás +csatasor +csatatárs +csatatér +csatlakozás +csatlakozik +csatlakozó +csatlós +csatol +csatorna +csatornamunkás +csatos +csattan +csattanás +csattanó +csattanós +csattant +csattog +csattogás +csattogtat +csavar +csavarás +csavargás +csavargat +csavargó +csavarhúzó +csavarmenet +csavaró +csavarodik +csavarog +csavaros +csavart +csavarvonal +csépel +cséplés +cséplőgép +csésze +csévél +csecsefia +csecsemő +csecsemőarcú +csecsszopó +cseh +csehszlovák +csekély +csekélyke +csekélység +csekk +csekkfüzet +csel +cseléd +cselédeskedik +cselédfiú +cselédház +cselédházi +cselédlány +cselédlépcső +cselédszoba +cselekedet +cselekedik +cselekmény +cselekvés +cselekvőkészség +cselekvőleges +cseles +cselgáncsozik +cselleng +cselszövés +cselszövő +csemege +csemegeáru +csemegeáruház +csemegebolt +csemegekukorica +csemete +csempe +csempész +csempészügy +csempézett +csempefal +csempekád +csen-csen-gyűrű +csend +csendbiztos +csendes +csendes-álmos +csendes-óceáni +csendesít +csendeske +csendesség +csendfoszlány +csendkamra +csendkamrabeli +csendőr +csendőrcsapat +csendőrfőhadnagy +csendőrjárőr +csendőrkéz +csendőrkerület +csendőrlaktanya +csendőrnyomozó +csendőrőrs +csendőrparancsnokság +csendőrség +csendőrségi +csendőrtiszt +csendőrtiszti +csendül +csendülés +csenevész +cseng +cseng-bong +csengésű +csenget +csengetés +csengettyű +csengő +csengőgomb +csengőszó +csepeg +csepeg-csurran +csepegés +csepegő +csepegtet +cseperedik +csepereg +csepeszke +csepp +cseppen +cseppfolyós +cseppfolyósít +cseppnyi +csepű +cser +cserbenhagy +csere +cserél +cserélget +cserélődik +cseréltet +cserép +cserépkályha +cserépkalapos +cseréptál +cserépváza +cserebogár +csereforgalom +cseregyerek +cserepes +cseresznye +cseresznyés +cseresznyemag +cseresznyeszem +cseresznyeszemű +csereüzlet +cserfa +cserge +cserje +cserkészcsapat +cserkészik +cserkészpacifizmus +cserreg +csertölgy +cserzett +csetepaté +csetresz +csetten +csettenés +csettint +cseveg +csevegés +csík +csíkos +csíkoz +csín +csíny +csínytevő +csíp +csípő +csípőméret +csípőolló +csípős +csíra +csíz +csízió +csibe +csibész +csibészes +csibukol +csicsereg +csicskás +csiga +csigás +csigáz +csigázás +csigacsinálni +csigaház +csigalassúság +csigalépcső +csigavonal +csigolya +csihorít +csikar +csikk +csiklandós +csiklandoz +csiklandozás +csikó +csikordul +csikorgás +csikorgat +csikorgatás +csikorgó +csikorog +csilingel +csillám +csillámlik +csillár +csillag +csillagász +csillagászat +csillagászati +csillagászattan +csillagbolygó +csillagfény +csillagfényes +csillagkép +csillaglakó +csillagos +csillagpaszuly +csillagrendszer +csillagszóró +csillagtalan +csillagvizsgáló +csillagzat +csillan +csillapít +csillapítgat +csillapító +csillapítószer +csillapodás +csillapodik +csillapul +csille +csillés +csilléz +csilli-villi +csillog +csillog-ragyog +csillogás +csillogású +csillogó +csillogtat +csimbókos +csimpaszkodik +csimpolyaszó +csinál +csináló +csináltat +csingilingi +csinnadratta +csinos +csinosítás +csinosodik +csinosság +csip-csup +csipeget +csiperkegomba +csipet +csipke +csipkés +csipkebogyó +csipked +csipkefodor +csipkefodros +csipkefüggöny +csipkegallér +csipkekendő +csipkeruha +csipketerítő +csipog +csippent +csiribí-csiribá +csirke +csirkebél +csirkecomb +csirkefogó +csirkehús +csirkeláb +csirkemetszés +csirkeölés +csirkepaprikás +csirkepörkölt +csirkepusztító +csiszol +csiszolgat +csiszolódás +csiszolódik +csiszolt +csitít +csitítgat +csitri +csitt +csitul +csivitel +csivitelés +csizma +csizmás +csizmadiamester +csizmadiaszín +csizmanadrág +csizmapatkó +csizmasarok +csizmaszár +csók +csóka +csókol +csókolgat +csókolódzik +csókolózás +csókolodzik +csónak +csónakázás +csónakázgat +csónakázik +csónakázópark +csónakház +csónakkirándulás +csónakmester +csónakos +csórás +csóró +csótány +csóva +csóvál +csökevény-eretnek +csökken +csökkenés +csökkent +csökönyös +csömör +csörgés +csörgedezik +csörget +csörgősipka +csörgőzik +csörlő +csörög +csörömpöl +csörömpölés +csörren +csörrenés +csörtet +csöves +csövez +csövezés +cső +csőbútor +csőcselék +csőd +csődarab +csődör +csődület +csőhálózat +csőkorlát +csőposta +csőr +csőrű +csőstül +csősz +csőszerelés +csőszkalap +csobban +csobbanás +csobog +csobogás +csoda +csodál +csodálat +csodálatos +csodálkozás +csodálkozik +csodálkoznivaló +csodás +csodabunker +csodafegyver +csodakávé +csodaló +csodamód +csodanász +csodaparaszt +csodaragasztó +csodaszép +csodaszer +csodatétel +csodatevő +csodatükör +csodavárás +csodaváró +csoki +csokoládé +csokoládébarna +csokoládéfolt +csokoládémáz +csokoládémaradvány +csokoládés +csokor +csokornyakkendő +csokornyakkendős +csomag +csomagol +csomagolás +csomagolópapír +csomagolópapiros +csomagtartó +csombolygat +csomó +csomós +csomósodik +csomóz +csongrádi +csonk +csonka +csonkít +csont +csont-maradék +csontfaragás +csontgombos +csontkemény +csontkocka +csontkoponyájú +csontos +csontosodik +csontpart +csontrepedés +csontsejt +csonttuberkulózis +csontú +csontváz +csoport +csoportfőnök +csoportkép +csoportos +csoportosítás +csoportosul +csoportvezető +csorba +csorda +csordakiverés +csordanyomás +csordogál +csordul +csordultig +csorgás +csorgat +csorog +csosszan +csoszog +csoszogás +csúcs +csúcsértekezlet +csúcsforgalom +csúcsíves +csúcsos +csúcsszerv +csúf +csúfol +csúfolódik +csúfondáros +csúfság +csúnya +csúnyácska +csúnyaság +csúnyuska +csúszik +csúszkál +csúszkálás +csúszós +csúsztat +csücsök +csücsörít +csücsül +csügged +csüggedés +csüggedt +csüggeszt +csülök +csüng +csüngős +csütörtök +csűr +csuha +csuhaj +csuk +csuka +csuklik +csukló +csuklóharc +csuklya +csuklyás +csukódik +csukogat +csukott +csula +csupa +csupa-csipa +csupa-csupa +csupán +csupasz +csupor +csuromvizes +csusszan +csuszamlós +csutak +csutkakóró +csutkakúp +cucc +cudar +cukor +cukorfokmérő +cukorgyári +cukorpor +cukrász +cukrászda +cukrászdás +cukrászdázik +cukrászsütemény +cupfol +cuppan +cuppanós +cuppant +cuppog +cvikker +cvikli +dákó +dália +dáma +dámvad +dámvadcsapat +dárda +dáridó +dátum +dac +dacol +dacos +dada +dadog +dadogó +dafkeség +dagály +dagad +dagadás +dagadó +dagadós +dagadt +daganat +dagaszt +dal +dalia +daliás +dallam +dallamfoszlány +dallamos +dallamtörmelék +dalmatanémet +dalol +dalolgat +dalos +damasztabrosz +dara +darál +darálás +darázs +darázsderék +darázsfészek +darab +darabka +daraboló +darabos +darabosság +daru +darutollas +datolyapálma +de +dédanya +dédapa +dédelget +dédelgetés +dédelgetett +dédkolomp +dédmama +dédszülő +dédunoka +dél +dél-ázsiai +dél-amerikai +dél-dunántúli +dél-somogyi +délceg +déldunántúli +délelőtt +délelőtti +délelőttös +délfelé +déli +délidő +délies +déligyümölcs +déligyümölcs-kereskedés +délkelet +délnyugat +déltájban +délután +délutáni +délutános +délvidéki +démon +dér +dévér +dézsa +dézsi-féle +deákember +debella +debreceni +debrői +december +decemberi +deci +decsi +dedós +defenzív +deficit-elvtárs +definíció +definiál +deformálódik +degesz +degradál +dehogy +dehogyis +dehogyisnem +dehogynem +deka +dekácska +dekád +dekás +dekadens +dekompenzál +dekoráció +dekorátor +delegáció +delfin +delíriumos +delta +demagnetizál +demagóg +demizson +demokrácia +demokrata +demokratikus +demokratizmus +demonstráció +demoralizál +depós +deportált +depressziós +derék +derékalj +derékaljhuzat +derékbőség +derékfájás +derékmájer +derékmagas +deréknyílás +derékszíj +derékszög +deréktáj +derekas +derekegyházi +derelye +dereng +derengés +deres +dermed +dermedt +dermedtség +dermesztő +derogál +derül +derülátó +derült +derültség +derű +derűlátás +derűs +dervis +destrukció +deszka +deszkájú +deszkás +deszkaajtó +deszkaalkotmány +deszkabódé +deszkadarab +deszkafal +deszkakabin +deszkakapu +deszkakerítés +deszkakikötő +deszkakoporsó +deszkamennyezet +deszkapalánk +deszkapalló +deszkapolc +desztillál +detektív +devalvál +devalválódás +deviáns +díj +díjaz +díjazás +díjbeszedő +díjmérkőzés +dísz +díszasztal +díszbokor +díszcserje +díszegyenruha +díszeleg +díszes +díszfüggő +díszít +díszítés +díszjel +díszkiadás +díszlet +díszlettervező +díszlik +díszlövedék +dísznövény +dísznő +díszoklevél +díszpáholy +díszpárna +díszsírhely +díszszemle +dísztelen +dísztök +díszű +dívány +dívik +diák +diákcsemege +diákélet +diákév +diákflört +diákkor +diákkori +diáklány +diákos +diákszálló +diáktárs +diákviselet +diadal +diadalmas +diadalmaskodik +diadalmenet +diadalordítás +diadalüvöltés +diadém +diagnózis +diagram +dialektika +dialektikus +dialógus +dianásüveg +diavetítő +dicsér +dicséret +dicséretes +dicsérget +dicsekedik +dicsekvés +dicsekvő +dicső +dicsőség +dicsőségvágy +didereg +didergés +diderget +diéta +diétás +diétázik +digitálisz +digó +dikó +diktál +diktálás +diktátor +diktatórium +diktatúra +dilemma +dilettáns +dilettantizmus +dili +diliflepni +dilis +dimenzió +dinamikus +dinamit +dinamizmus +dinasztia +dinnye +dinnyézik +dinnyeföld +dinnyehalom +dinnyeportás +dinnyeszagú +dió +dióbarna +diódaráló +diófa +dióhéj-cirkáló +diólikőr +diós +dióverő +diploma +diplomácia +diplomáciai +diplomás +diplomázik +diplomakoncert +diplomata +diplomatikus +diplomavizsga +direkt +direktíva +direktor +direktorné +diri +dirigál +diskurál +diskurálás +disputa +disputál +disszertáció +disszidál +disszidálás +disszidens +diszharmónia +diszkontinuitás +diszkoszvetés +diszkréció +diszkrét +disznó +disznóbőr +disznófülű +disznóhajtás +disznóhúsillat +disznóól +disznóölés +disznóölő +disznóság +disznószag +disznótoros +disznóvályú +disznóvese +disznózsír +diszpécsernő +diszpozíció +disztinkció +divat +divatárubolt +divatbábu +divatjamúlt +divatlap +divatművészet +divatos +divattervező +dizőz +döbbenet +döbbenetes +döbbent +döccen +döccenés +döcög +döcögés +döf +döfés +dög +dögcédula +dögész +döghalál +döghús +dögivel +dögkeselyű +dögletes +döglik +döglött +dögönyöz +dömés +dömper +döndül +döng +dönget +döngöl +döngölt +dönög +dönt +döntés +döntetlen +döntő +dörgés +dörgöl +dörgölődzik +dörgő +dörmög +dörög +dörömböl +dörömbölés +dörren +dörrenés +dörzsöl +dörzsölget +dörzsölt +dörzspapír +dől +dob +dobál +dobálgat +dobálódzik +dobálózás +dobás +dobaj +dobban +dobbanás +dobbant +doberdói +dobhártya +dobkályha +dobkályhácska +dobókocka +dobog +dobogás +dobogó +dobol +dobos +doboz +dobozgyár +dobtáras +dodonai +dogma +dogmatikus +dohány +dohányfüst +dohánygyári +dohánymorzsalék +dohányosdoboz +dohánypakli +dohányszálacska +dohányszagú +dohányzás +dohányzik +dohányzó +dohányzóasztal +dohányzógarnitúra +dohog +dohogás +dohos +dohszagú +doki +dokkmunkás +doktor +doktori +doktorné +doktornő +doktriner +dokumentáció +dokumentál +dokumentum +dokumentumfilm +dolgos +dolgozás +dolgozat +dolgozik +dolgozó +dolgozószoba +dolgoztat +dollár +dollárcsekk +dollárforrás +dolmányos +dolog +dologidő +dologtalan +dologtalanság +domb +dombhát +dombocska +domboldal +dombormű +domborodik +domború +domborzati +domborzatos +dombos +dombosodik +dombtető +dombvonulat +domínium +dominál +domináns +dominó +dominózik +donátor +dongás +dongakút +donjános +donor +dorbézol +dorogi +dorong +dorongfa +dorozsmai +dosszié +doszt +drága +drágáll +drágakő +drágalátos +drágasági +dráma +drámázik +drámai +drámaíró +drávafai +drabális +dragon +dragony +dragonyos +dramatizál +dramaturg +dramaturgiai +drapéria +drapp +drazsé +dressz +drezdai +drót +drót-élet +drótháló +dróthaj +dróthajú +drótkeretes +drótkeretű +drótkerítés +drótkötél +drótos +drótoz +drótsövény +drótszál +drugány +drukker +drukkol +dúdol +dúdolás +dúdolgat +dúl +dúltság +dúr +dús +dúsgazdag +dúsul +dúvad +dübörgés +dübörög +düh +dühhörrenés +dühít +dühítő +dühkitörés +dühödt +dühöng +dühöngés +dühöngő +dühös +düledezik +dülled +dülledt +dülöng +dülöngél +dünnyög +dünnyögés +dűlő +dűlőnév +dűlőút +dublé +duda +dudál +dudálás +dudorászás +dudorászik +dudos +dug +dugdos +dughely +dugig +dugó +dugóhúzó +duhaj +dukál +dukát +dukkó +dulakodás +dulakodik +duma +dumál +duna-kavics +duna-parti +duna-víz +dunántúli +dunai +dunaújvárosi +dundi +dunszt +dunsztosüveg +dunyha +dupla +duplácska +duplatárcsa +duránci +durcás +durcáskodik +durchmars +durr +durran +durranás +durrog +duruzsol +duruzsolás +durva +durváskodik +duzzad +duzzadt +duzzadtság +duzzanat +duzzaszt +duzzasztógát +duzzog +duzzogás +dzsem +dzsungel +e +e-hang +eb +ebéd +ebédel +ebédhordó +ebédidő +ebédjegy +ebédlő +ebédlőasztal +ebédlőkredenc +ebédlőszekrény +ebédlőterítő +ebédosztás +ebédvivés +ebebe +ebrúd +ecet +ecetes +ecetfa +ecset +ecsetel +eddig +eddigi +edény +edénybolt +edénycsörömpölés +edényrajzoló +edz +edzés +edzési +edzett +edző +edzősködik +efelől +effajta +efféle +egér +egérfogó +egérürülék +egész +egészen +egésznapos +egészség +egészséges +egészségház +egészségi +egészségtelen +egészségügyi +egerészőjáték +egetlen +egoizmus +egres +egri +egy +egy-egy +egy-füles +egy-két +egy-kettő +egy-más +egy-másfél +egyáltalában +egyáltalán +egyaránt +egyarcú +egyazon +egybeáll +egybeesik +egybefényképez +egybefolyik +egybegyűlik +egybekapcsol +egybekelés +egybekeveredik +egybemosódik +egyben +egybenő +egybeönt +egybeolvad +egybesötétít +egybeszámol +egybeszikrázik +egybetart +egybetekeredik +egybevet +egyből +egyéb +egyébként +egyén +egyéni +egyéniség +egyéniségű +egyértelmű +egyéves +egyed +egyedi +egyedül +egyedülálló +egyedüli +egyedüllét +egyeduralom +egyelőre +egyemeletes +egyenértékű +egyenes +egyenesen +egyenest +egyenetlen +egyenetlenség +egyenget +egyengetés +egyenjogúság +egyenként +egyenletes +egyenlít +egyenlítő +egyenlítői +egyenlő +egyenlőségjel +egyenrangú +egyenruha +egyenruhás +egyenruhásít +egyensapka +egyensúly +egyensúlyoz +egyes +egyes-egyedül +egyesít +egyesítés +egyesül +egyesülés +egyesület +egyesült +egyesztendős +egyetért +egyetértés +egyetem +egyetemben +egyetemesség +egyetemi +egyetemista +egyetemleges +egyetlen +egyetlenegy +egyetlenke +egyetlenség +egyezik +egyezkedik +egyezség +egyeztet +egyeztető +egyfajta +egyféle +egyfelé +egyfolytában +egyforma +egyformaság +egyház +egyházfi +egyházhatósági +egyházi +egyházmegye +egyhamar +egyhangú +egyhangúság +egyharmad +egyhatvan +egyhavi +egyhetes +egyheti +egyhónapi +egyhónapos +egyhuzamban +egyidejű +egyidős +egyik +egyik-másik +egyikfajta +egyiptológus +egyiptomi +egyke +egykedvű +egykeség +egykettőre +egykilós +egykönnyen +egykor +egykori +egykorú +egylet +egylovas +egymás +egymásgyötrés +egymásrautaltság +egymásután +egymaga +egymilliárd +egymillió +egynapi +egynapos +egynéhány +egynémely +egynegyed +egyórás +egyöntetű +egyötven +egyoldalas +egyoldalú +egyoldalúság +egypár +egyre +egyre-másra +egyrészes +egyrészt +egység +egységes +egységfront +egyszemélyes +egyszer +egyszer-egyszer +egyszer-kétszer +egyszeri +egyszeriben +egyszerre +egyszersmind +egyszerű +egyszerűen +egyszerűség +egyszerűsít +egyszerűsítés +egyszínű +egyszólamú +egyszóval +egyszoba-hallos +egyszobás +egyszülött +egyúttal +együgyű +együgyűség +együtt +együttélés +együttérzés +együttérző +együttes +együttlélegzés +együttlét +együttműködés +együttműködik +együttrezgés +együttvéve +együvé +egyujjnyi +egyutcás +egyvalaki +egyvalami +egyvégből +egyvér +egzakt +egzisztál +egzisztencia +egzotikus +eh +ehelyett +ehető +ej +ejde +ejej +ejha +ejnye +ejt +ejtőernyő +ejtőernyős +ejtőzik +eke +ekekapa +ekevas +ekképpen +ekkor +ekkora +ekkori +ekkoriban +eközben +eksztázis +el +el-elakad +el-elcsíp +el-elgyönyörködik +el-elhalkul +el-eltakar +elábrándozik +elácsorog +elágazás +elágazik +elájul +eláld +eláll +elálldogál +elálmosít +elálmosodik +elámul +eláraszt +elárul +elárulás +elárusító +elárusítónő +elárvul +elás +elátkozott +elázik +eláztat +elad +eladás +eladdig +eladó +eladódik +eladományoz +elaggott +elakad +elalél +elaljasodik +elalszik +elalvás +elandalít +elapad +elavult +elbágyad +elbámészkodik +elbámul +elbánik +elbazilikáz +elbeszél +elbeszélés +elbeszélget +elbír +elbíz +elbiceg +elbiciklizik +elbiggyeszt +elbizonytalankodik +elbizonytalanodás +elbizonytalanodik +elbóbiskol +elbódorog +elbődül +elbőg +elbocsát +elbocsátó +elbolondít +elbolondozik +elbont +elborít +elborul +elbotlik +elbotorkál +elbúcsúzik +elbúcsúztat +elbújik +elbújtat +elbűvöl +elbűvölő +elbujdosik +elbukás +elbukik +elbutul +elcaflat +elcsábít +elcsalás +elcsatol +elcsattan +elcsavar +elcsavarog +elcsépelt +elcsen +elcsendesedik +elcsendesít +elcsendesül +elcsendesülés +elcseppen +elcserél +elcsesz +elcseveg +elcsíp +elcsigázott +elcsirkefogósodik +elcsitít +elcsitul +elcsónakázik +elcsór +elcsörömpöl +elcsörtet +elcsodálkozik +elcsúfít +elcsúszik +elcsúszkál +elcsuklik +eldajkál +eldarál +eldicsekedik +eldiskurál +eldöcög +eldönget +eldönt +eldöntés +eldörgöl +eldörren +eldől +eldob +eldohog +eldübörög +eldug +eldugdos +eldugít +eldugul +eldurvul +elé +elébe +elég +elégedetlen +elégedetlenkedik +elégedetlenség +elégedett +elégedettség +eléget +elégetés +eléggé +elégia +elégséges +elégtétel +elégtelen +elégtelenség +elégült +eléje +eléktelenít +elél +elénekel +elér +elérés +elérhetetlen +elérhető +elérkezik +elért +elérzékenyedik +elérzékenyül +elérzékenyülés +elévült +eledel +elefánt +elefántcsont +elefántcsonttorony +elegáns +elegancia +elegendő +elegyedik +elegyenget +elegyít +elei +eleinte +eleje +eleji +elejt +elejtés +elejtett +elejtő +elejtődik +elektrifikáló +elektróda +elektrokardiogram +elektromérnök +elektromos +elektromosság +elektronikus +elektrotechnikai +elem +elemészt +elemez +elemezhető +elemi +elemista +elemózsia +elemzés +elenged +elengedhetetlen +elenyészik +elenyésző +eleped +elered +elereszt +elernyed +elernyedés +elernyeszt +eleség +elesett +elesettség +elesik +eleste +eleszik +eleve +eleven +elevenség +elfárad +elfáradás +elfásul +elfagy +elfakul +elfal +elfér +elfészkelődik +elfecsérel +elfed +elfehéredik +elfekszik +elfeled +elfeledkezik +elfeledtet +elfelejt +elfelejtkezik +elferdít +elferdül +elfintorít +elfintorodik +elföldel +elföldelés +elfocizik +elfog +elfogás +elfogad +elfogadás +elfogadhatatlan +elfogadható +elfogatás +elfogatási +elfoglal +elfoglalatoskodik +elfoglalt +elfoglaltság +elfogódott +elfogódottság +elfogulatlan +elfogult +elfogultság +elfogy +elfogyaszt +elfogyasztás +elfojt +elfojthatatlan +elfolyik +elfonnyad +elfordít +elfordul +elforgat +elfoszlik +elfúj +elfúl +elfüggönyöz +elfüstölög +elfütyül +elfűrészel +elfullad +elfut +elgáncsol +elgázol +elgazdálkodik +elgémberedik +elgörbít +elgondol +elgondolás +elgondolható +elgondolkodik +elgondolkodtató +elgondolkozik +elgondolkoztat +elgondolkoztató +elgurul +elgyávul +elgyalogol +elgyengül +elgyengülés +elgyökerezik +elgyönyörködik +elgyötört +elhány +elhárít +elhárítás +elhárító +elhadar +elhagy +elhagyás +elhagyatott +elhagyott +elhajít +elhajigál +elhajlás +elhajol +elhajszol +elhajt +elhajtogat +elhal +elhalálozás +elhalálozik +elhalás +elhalászik +elhalad +elhalaszt +elhalkul +elhallatszik +elhallgat +elhallgatás +elhallgattat +elhalmoz +elhalványít +elhalványodik +elhalványul +elhamarkodik +elhamarkodott +elhamarkodottság +elhamvad +elhangzik +elhanyagol +elhanyagolható +elhanyagolt +elhanyagoltság +elhanyatlik +elharangoz +elharap +elharapódzás +elharapódzik +elhasít +elhasznál +elhatároz +elhatározás +elhatalmasodik +elhatol +elhazudik +elhelyez +elhelyezés +elhelyezkedés +elhelyezkedik +elhemperedik +elhengerítés +elherdál +elhervad +elhesseget +elhessent +elheveredik +elhív +elhízik +elhibáz +elhidegedik +elhidegül +elhihető +elhisz +elhiszterizál +elhitet +elhivatalnokoskodás +elhódít +elhömpölyög +elhomályosít +elhomályosodik +elhomályosul +elhord +elhoz +elhúz +elhúzat +elhúzódik +elhülyül +elhülyülés +elhűl +elhull +elhuny +elhurcol +elígérkezik +elítél +elítélt +elíziumi +elidegenedik +elidegenít +elidőzik +eligazít +eligazítás +eligazító +eligazodik +elillan +elindít +elindítás +elindul +elindulás +elintéz +elintéznivaló +elintéződik +elirányít +eliramodik +elismétel +elismer +elismerés +elismerő +elismert +eliszaposodik +eliszik +eliszkol +elit +elixír +eljár +eljárás +eljátszik +eljegyzés +eljön +eljövendő +eljövet +eljövetel +eljut +eljuttat +elkábít +elkábul +elkámpicsorodik +elkápráztat +elkáromkodik +elkalandozik +elkallódik +elkanyarodik +elkap +elkapat +elkapkodás +elkattan +elkékül +elkényelmesedik +elkényeztet +elkényeztetettség +elképed +elképedés +elképeszt +elképesztő +elképzel +elképzelés +elképzelhetetlen +elképzelhető +elkér +elkéseget +elkésik +elkészít +elkészítés +elkészítő +elkészül +elkedvetlenedik +elkedvetlenít +elkel +elkerékpározik +elkerekedik +elkerekezik +elkerget +elkerít +elkerül +elkerülés +elkerülhetetlen +elkerültet +elkeseredés +elkeseredett +elkeseredik +elkeserít +elkeskenyedik +elkeskenyül +elkezd +elkezdés +elkezdődik +elkígyózik +elkínzott +elkísér +elkíváncsiskodik +elkiált +elkiabál +elkókad +elkószál +elkótyavetyél +elködösül +elköltözik +elköltöztet +elkönyvel +elköszön +elkötelez +elkövet +elkövetés +elkövetkezik +elkövetkező +elkoboz +elkobozhatatlan +elkobzás +elkomolyodik +elkomorodik +elkomorul +elkonspirál +elkopik +elkoptat +elkorcsosul +elkorhad +elkormányoz +elkotyog +elkozmál +elkúszik +elküld +elküldés +elkülönít +elkülönítés +elkülönül +elkunyerál +elkuszál +ellágyít +ellágyul +ellát +ellátás +ellátogat +ellabdázgat +ellakik +ellankadás +ellanyhul +ellapátol +ellavíroz +ellazul +ellép +ellebben +ellen +ellenáll +ellenállás +ellenállási +ellenállhatatlan +ellenálló +ellenállóképesség +ellenakció +ellenautó +ellenben +ellene +ellenébe +ellenében +ellenére +ellenérv +ellenez +ellenfél +ellenforradalmár +ellenforradalmi +ellenforradalom +elleni +ellenkezés +ellenkezik +ellenkező +ellenkezőleg +ellenőr +ellenőriz +ellenőrzés +ellenőrzés-igazoltatás +ellenőrző +ellenpólus +ellenpropaganda +ellenség +ellenséges +ellenségeskedik +ellensúlyoz +ellenszenv +ellenszenves +ellenszolgáltatás +ellentét +ellentétes +ellentmond +ellentmondás +ellentmondásos +ellentmondásosság +ellenvélemény +ellenvet +ellenvetés +ellenzék +ellenzéki +ellenzés +ellenző +ellep +elles +ellhallgat +ellik +ellipszis +ellóg +ellök +ellötyög +ellop +ellustul +elmázol +elmázolódik +elmacskásodik +elmagyaráz +elmajszol +elmar +elmarad +elmaradhatatlan +elmaradott +elmaradottság +elmaradozik +elmarasztal +elmarasztalás +elme +elméjű +elméláz +elmélázás +elmélet +elméleti +elmélkedés +elmélkedik +elmélyül +elmélyült +elmélyültség +elmérgesedik +elmés +elméskedik +elmésség +elmebaj +elmebeteg +elmegy +elmegyógyintézet +elmenekül +elmenő +elmente +elmereng +elmerül +elmerülés +elmesél +elmeséltet +elmetsz +elmezavar +elmismásol +elmocsarasodik +elmond +elmondat +elmondott +elmorzsol +elmos +elmosódik +elmosogat +elmosolyint +elmosolyodik +elmosolyog +elmozdít +elmozdítás +elmozdíthatatlan +elmozdítható +elmozdul +elmúlás +elmúlik +elmúlt +elmúlta +elmulaszt +elmulat +elmutat +elnémít +elnémul +elnéptelenedik +elnéz +elnézés +elnézeget +elnéző +elnehezedik +elnehezül +elnevet +elnevez +elnevezés +elnevezésű +elnök +elnökasszony +elnökhelyettes +elnöki +elnökminiszter +elnökné +elnökség +elnöktárs +elnyargal +elnyel +elnyer +elnyerés +elnyom +elnyomás +elnyomatás +elnyomó +elnyomott +elnyújt +elnyújtózik +elnyúlik +elnyű +elnyűtt +elnyűvődik +elóvakodik +elöljáró +elöljáróban +elöljárói +elöljáróné +elöljáróság +elömlik +elönt +elözönöl +elözvegyül +elő +előáll +előállít +előad +előadás +előadássorozat +előadó +előadódik +előadói +előadóterem +előbb +előbb-utóbb +előbbi +előbújik +előbuggyan +előbukkan +előcibál +előcsal +előcsapat +előcsarnok +előcsúszik +előd +elődug +előéletű +előérzet +előétel-hal +előeste +előfittyent +előfordul +előfut +előgördül +előgőzölés +előhajladozik +előhalászik +előhírnök +előhívás +előhívódik +előhoz +előhozakodik +előhúz +előír +előírás +előírásos +előírt +előítélet +előidéz +előidézés +előidéző +előimádkozó +előirányoz +előjegyzési +előjel +előjön +előjog +előkap +előkapar +előkészít +előkészítés +előkészítő +előkészül +előkészület +előkelő +előkelőség +előkeres +előkerít +előkerítés +előkerül +előkerülés +előkeveredik +előkotor +előkrémez +elől +előle +előlép +előléptet +előleg +előlegez +előlibeg +előmászik +előmenetel +előmunkálat +előnevelés +előny +előnyös +előnytelen +előnyújtózik +előnyúl +előőrs +előpark +előrángat +előránt +előrajzik +előre +előre-hátra +előreáll +előrebiggyed +előrebocsát +előrebocsátás +előrebukik +előrecsapódik +előrecsoszog +előredöf +előredől +előredobban +előreduzzad +előreejt +előreenged +előrefeszít +előrefut +előregörnyed +előrehajol +előrehajt +előrehalad +előrehaladás +előrehömpölyög +előrehullik +előreindul +előrejön +előrejut +előrekarajlik +előreküld +előrelátás +előrelátható +előreláthatólag +előrelátó +előrelép +előrelök +előrelopózik +előremászik +előremegy +előremered +előrenéz +előrenyomakodik +előrenyomul +előrenyomulás +előrenyújt +előrenyúl +előrerohan +előresiet +előreszalad +előreszól +előretart +előretör +előretörekszik +előreugrik +előrevet +előrevisz +előrohan +előrukkol +elősegít +előszed +előszivárog +először +előszoba +előszobázó +előszobaajtó +előszobaasztal +előszobaszék +előtár +előtér +előtétlencse +előteremt +előteremtés +előterjeszt +előterjesztés +előtör +előtotyog +előtt +előtte +előtti +előtűnik +elővágás +elővéd +elővesz +elővezet +elővigyázatos +elővigyázatosság +elővigyorog +elővillan +előzékeny +előzékenység +előzetes +előzmény +előző +előzőleg +eloldalog +elolt +elolvad +elolvas +elolvasás +elolvastat +elomlik +elordít +eloroz +eloszlat +eloszlik +eloszt +elosztó +elosztófej +elpárolog +elpártol +elpásztorol +elpanaszol +elpatkol +elpattan +elpattant +elpazarol +elpepecsel +elpilled +elpirul +elpiszkál +elpityeredik +elpocsékol +elpofoz +elposhad +elpüföltet +elpucol +elpuhult +elpusztít +elpusztítás +elpusztíthatatlan +elpusztul +elrágódik +elrángat +elránt +elrabol +elragad +elragadó +elragadtat +elragadtatás +elragadtatott +elrak +elrakodik +elraktároz +elrémül +elrebben +elrebbent +elrejt +elrejtőzik +elrejtőzködik +elreked +elrendel +elrendeltség +elrendez +elrendezés +elrendezettség +elrendeződés +elrendeződik +elrepül +elrestell +elrettentő +elriad +elriaszt +elrikkant +elringat +elröhög +elröppen +elrobog +elrohad +elrohan +elromlik +elront +elrozsdásul +elrúg +elsáncol +elsápad +elsárgul +elsajátít +elsavanyodik +elsétál +elseje +elsejei +elsír +elsiet +elsikkaszt +elsiklik +elsikolt +elsimít +elsirat +elsöpör +elsötétedik +elsötétít +elsötétítő +elsötétül +első +elsőbb +elsőbben +elsőbbség +elsődleges +elsőéves +elsőhetes +elsőrendű +elsőség +elsősegély +elsősorban +elsőszülött +elsőszülöttség +elsodor +elsokall +elsorol +elsorvasztás +elspórol +elsüllyed +elsüllyeszt +elsüt +elsüvít +elsuhan +elsurran +elsuttog +elszáguld +elszáll +elszállásol +elszállít +elszállítás +elszállítható +elszámol +elszámolás +elszán +elszánás +elszánt +elszántság +elszab +elszabadít +elszabadul +elszabotál +elszakad +elszakadás +elszakadási +elszakít +elszalad +elszalajt +elszalaszt +elszaporodik +elszaval +elszédít +elszédül +elszégyell +elszéled +elszed +elszegényedik +elszegődik +elszellent +elszenderedik +elszennyesedik +elszenved +elszeret +elszíneződik +elszíntelenedik +elszív +elszívás +elszigetel +elszigetelt +elszivárog +elszól +elszólít +elszór +elszórakozik +elszórt +elszótlanodik +elszökik +elszörnyedés +elszokik +elszomorít +elszomorodik +elszopogat +elszorul +elszúr +elszürkít +elszürkül +elszunnyad +elszunyókál +eltáncol +eltántorít +eltát +eltávolít +eltávolítás +eltávolíttat +eltávolodás +eltávolodik +eltávozás +eltávozik +eltagadtat +eltakar +eltakarít +eltalál +eltanácsol +eltanul +eltapos +eltart +eltartás +eltékozol +elténfereg +eltép +eltér +eltérés +eltérít +eltérő +eltéved +eltévedez +eltéveszt +eltekint +eltelik +eltelte +eltemet +eltemetés +eltemettet +elterebélyesedik +elterel +elterjed +elterjeszt +elterpeszkedik +elterül +eltervez +eltesz +eltilt +eltiltás +eltipor +eltitkol +eltökéltség +eltölt +eltömődik +eltöpreng +eltör +eltörik +eltörlés +eltöröl +eltörölhetetlen +eltörődik +eltörpül +eltol +eltolódik +eltompul +eltorlaszol +eltorzít +eltorzul +eltorzulás +eltotyog +eltréfálkozik +eltúloz +eltünedezik +eltüntet +eltüntetés +eltűnés +eltűnik +eltűnődik +eltűnt +eltűr +eltulajdonít +eltussolhatatlan +elújságol +elúszik +elücsörög +elül +elüldögél +elüldöz +elülső +elültet +elüt +elüvölt +elűz +elugrik +elun +eluralkodik +elutasít +elutasítás +elutasító +elutazás +elutazik +elv +elvág +elvágás +elvágódik +elvágtat +elvágyakozás +elvágyódás +elválás +elválaszt +elválasztódás +elválik +elvállal +elvált +elváltozik +elváltoztat +elvándorol +elvánszorog +elvár +elvárás +elvadul +elvakkant +elvakult +elvarázsol +elvégez +elvégeztet +elvégre +elvégzés +elvégzetlen +elvékonyodik +elvérzik +elvét +elvétve +elvegyül +elver +elvergődik +elvermel +elvesz +elveszett +elveszít +elveszt +elvesztés +elveszteget +elvet +elvetemült +elvetemültség +elvetődik +elvevés +elvezényel +elvezet +elvezetés +elvhű +elvhűség +elvi +elvi-eszmei +elviccelődik +elvigyorodik +elviharzik +elvihog +elvileg +elvirul +elvisel +elviselés +elviselhetetlen +elviselhetetlenség +elviselhető +elvisz +elvitathatatlan +elvitet +elvörösödik +elvon +elvonatkoztat +elvonókúra +elvont +elvontat +elvonul +elvonulás +elvtárs +elvtársaz +elvtársnő +elvtestvér +elvtike +elzálogosít +elzár +elzárás +elzárkózás +elzárkózik +elzarándokol +elzavar +elzörög +elzsibbad +elzsibbadtság +elzsongít +elzúg +ember +emberáldozat +emberállat +emberanyag +emberarc +emberavatás +emberbaráti +embercsempész +embercsoport +emberdugó +emberélet +emberemlékezet +embereszmény +emberevő +emberfaj +emberféle +emberfej +emberfia +emberfölötti +emberformáló +emberformálta +embergyártás +embergyűrű +emberhalál +emberi +emberiség +emberismerő +emberkatona +emberke +emberkéz +emberkígyó +embermagas +embernyi +emberölés +emberölő +emberöltő +emberpár +emberség +emberséges +emberszegy +emberszemlélet +emberszeretet +emberszó +embertárs +embertelen +embertestvér +embertestvériség +embertípus +embertömeg +embrió +embrionális +emészt +emésztés +emésztési +emésztetlen +emésztő +emésztőcső +emésztőgödör +emel +emelés +emelet +emeletes +emeleti +emeletnyi +emelget +emelhető +emelkedés +emelkedettség +emelkedik +emelkedő +emellett +emelőszerkezet +emelt +emelvény +emez +emiatt +emigráció +emigráns +emilyen +eminens +emitt +emlék +emlékcserép +emlékérem +emlékezés +emlékezési +emlékezet +emlékezetes +emlékezettelen +emlékezetű +emlékezik +emlékezőtehetség +emlékeztet +emlékeztető +emlékkő +emlékmű +emléknyom +emlékű +emlékvilág +emleget +emlegetés +említ +említés +emlősállat +empíria +emulziós +enciklika +enélkül +energia +energiafeltöltő +energiaigényes +energiamennyiség +energiapáncél +energiaparancsnok +energiaparancsnoki +energiapótlás +energiaráfordítás +energiarészecske +energiaszükséglet +energiatartalékolás +energiatelep +energiatermelő +energiazárlat +energikus +enged +engedékeny +engedély +engedélyez +engedelem +engedelmes +engedelmeskedik +engedelmesség +engedetlen +engedmény +engedményes +engesztel +engesztelés +engesztelhetetlen +ennélfogva +enni-innivaló +ennivaló +ennyi +ennyire +enyém +enyészet +enyészik +enyeleg +enyelgő +enyhe +enyhely +enyhes +enyhít +enyhül +enyhülés +enyingi +enyv +enzim +epés +epéskedik +epebaj +epebajos +epekedés +epekedik +epeköves +eper +eperfa +epika +epizód +epres +ercsi +erdélyi +erdész +erdészeti +erdészház +erdei +erdő +erdő-mező +erdőbeli +erdőborította +erdőféle +erdőgazdaság +erdőmérnök +erdőőri +erdős +erdős-dombos-tanyás +erdősarok +erdőség +erdőszél +erdősziget +erdővidék +erély +erélyes +erény +erecske +ered +eredendő +eredet +eredeti +eredetileg +eredetű +eredmény +eredményes +eredményesség +eredményez +eredményhirdetés +eredményhirdető +eredménylista +eredménytábla +eredménytelen +ereget +erejű +ereklye +eres +eresz +ereszalja +ereszcsatorna +ereszkedik +ereszt +ereszték +eresztés +eretnek +eretnekség +erez +erezet +erjed +erkély +erkélyajtó +erkölcs +erkölcsi +erkölcsiség +erkölcsös +erkölcsrendészet +erkölcstelen +erkölcstelenség +erkölcsű +ernyedetlen +ernyedt +ernyedtség +ernyő +ernyőjű +ernyős +ernyőtér +ernyőz +erő +erőcsatorna +erőd +erődemonstráció +erődítés +erődítményszerű +erődszektor +erődvonal +erőfeszítés +erőgép +erőkifejtés +erőlködés +erőlködik +erőltet +erőltetés +erőltetett +erőmennyiség +erőmű +erőnlét +erőpróba +erős +erősít +erősítés +erősítő +erősködés +erősködik +erősödik +erősség +erőszak +erőszakmentes +erőszakol +erőszakolt +erőszakos +erőszakoskodás +erőszakoskodik +erőszakosság +erőszaktétel +erőtérlokátor +erőteljes +erőtlen +erőviszony +erővonal +erotika +erotikus +erre +erre-arra +errefelé +erzsébet-napi +erzsébeti +esdekel +esély +esélyes +esélytelen +esés +esedékes +esedezik +esemény +eseménynapló +eseménysor +esernyő +esernyőnyél +eset +esetén +esetleg +esetleges +esetlen +esetlenség +esett +eshetőség +esik +eskü +esküdözik +esküdt +esküdtper +esküszik +esküvő +esküvői +eső +esőáztatta +esőcsepp +esőfüggöny +esőkabát +esőköpeny +esőkopogás +esőlék +esőmarta +esős +esőszag +esővíz +esővizes +esőzés +est +este +estéli +estélyi +esténként +estefelé +esteledik +estelente +esthajnali +esti +estike +esz +eszeget +eszelős +eszem-iszom +eszerint +eszes +eszeveszett +eszik +eszik-fal +eszik-iszik +eszköz +eszközöl +eszközölhető +eszme +eszmél +eszmélés +eszmélet +eszméletlen +eszmélkedés +eszmény +eszményi +eszménykép +eszmecsere +eszmefuttatás +eszmei +eszmetársítás +eszperantó +eszpresszó +eszpresszósnő +eszpresszószék +esztétika +esztétikai +esztelen +esztendő +esztendős +esztergál +esztergályos +esztergályoz +esztergapad +esztergom-tábori +esztergomi +eszterhéj +eszű +etet +etetés +etető +etika +etikett +ettől +etűd +etyetyety +eufória +európa-bajnok +európai +evangélista +evangélium +evés +evez +evezés +evező +evezőcsobbanás +evezős +evidencia +evidens +evőeszköz +evőkanál +exkluzív +exkuzál +exmenyasszony +expanzió +expedíció +expediál +explicit +exponált +export +export-import +exportál +exportkertészet +expozíciójú +expozíciós +expressz +expresszflört +extéglagyári +extrauterális +ez +ez-az +ez-ez +ezáltal +ezalatt +ezért +ezért-azért +ezelőtt +ezelőtti +ezen +ezenfelül +ezenkívül +ezennel +ezentúl +ezer +ezerév +ezeregy +ezerféle +ezerfiókos +ezerharmadik +ezerhatszáz +ezerhatszáznegyven +ezerhét +ezerhétszázhatvan +ezerhétszáznyolcvanhat +ezerkétszáz +ezerkettő +ezerkilencszáz +ezerkilencszázharminc +ezerkilencszázharminchárom +ezerkilencszázharminckettő +ezerkilencszázharmincnyolc +ezerkilencszázhatvan +ezerkilencszázhatvanegy +ezerkilencszázhatvanhárom +ezerkilencszázhatvanhét +ezerkilencszázhatvankilenc +ezerkilencszázhatvannyolc +ezerkilencszázhatvanöt +ezerkilencszázhetven +ezerkilencszázhúsz +ezerkilencszázhúszas +ezerkilencszázhuszonegyedik +ezerkilencszázhuszonhat +ezerkilencszázhuszonnégy +ezerkilencszázhuszonnyolc +ezerkilencszázhuszonöt +ezerkilencszázkettő +ezerkilencszázkilenc +ezerkilencszázkilencvenhat +ezerkilencszázkilencvennégy +ezerkilencszázkilencvennegyedi +ezerkilencszázkilencvenöt +ezerkilencszáznegyven +ezerkilencszáznegyvenegy +ezerkilencszáznegyvenhárom +ezerkilencszáznegyvenhat +ezerkilencszáznegyvenkettő +ezerkilencszáznegyvennégy +ezerkilencszáznegyvennégyes +ezerkilencszáznegyvennyolcas +ezerkilencszáznegyvenöt +ezerkilencszáznyegyvennyolc +ezerkilencszáznyolcvanas +ezerkilencszáznyolcvanegy +ezerkilencszáznyolcvannyolc +ezerkilencszázötven +ezerkilencszázötvenegy +ezerkilencszázötvenhat +ezerkilencszázötvenhét +ezerkilencszázötvenkilenc +ezerkilencszázötvennégy +ezerkilencszázötvennyolcas +ezerkilencszáztízes +ezerkilencszáztizenhét +ezerkilencszáztizenkettő +ezerkilencszáztizenkilenc +ezerkilencszáztizenkilences +ezerkilencszáztizennyolc +ezerkilencszáztizenöt +ezerkilenszázötven +ezermester +ezermesterség +ezernégyszázötvenhármas +ezernyi +ezernyolcszázharminchárom +ezernyolcszázhatvannégy +ezernyolcszázhetvenegy +ezernyolcszázkilencvenhét +ezernyolcszázkilencvenötös +ezernyolcszáznegyvenkilenc +ezernyolcszáznegyvennyolc +ezerötszáz +ezerötszázhármas +ezerötszázhatos +ezerötszázhetes +ezerötszáznégyes +ezerötszázötös +ezerszáznégyes +ezerszerte +eziránt +ezóta +ezred +ezredes +ezredik +ezredparancsnok +ezres +eztán +ezúton +ezúttal +ezüst +ezüstbetűs +ezüstceruza +ezüstcsengő +ezüstedény +ezüstfényű +ezüstfehér +ezüstfogantyús +ezüstfonal +ezüstfütyülő +ezüstgomb +ezüsthajú +ezüsthas +ezüstkalászos +ezüstkereszt +ezüstlánc +ezüstnyárfás +ezüstnyakú +ezüstös +ezüstpáncél +ezüstpáncélos +ezüstpor +ezüstszínű +ezüstszőke +ezüstszürke +ezüsttálca +ezüstveretű +ezután +ezzel +ében +éber +éber-álom +éber-nagy +éberség +éberszolgálat +ébred +ébredés +ébredezik +ébren +ébrenlét +ébrenléti +ébrentartás +ébreszt +ébresztget +ébresztő +ébresztőóra +édeni +édenkerti +édes +édes-édes +édes-kesernyés +édesanya +édesapa +édesbácsi +édeskés +édeslány +édesmindegy +édesség +ég +ég-föld +égbekiáltó +égbolt +égés +égési +égéstermék +éget +égetés +égető +égett +éghajlat +éghajlati +égi +égitest +égövi +égő +égszínkék +égvilágon +égzengés +éhcsitító +éhen +éhes +éhezés +éhezik +éhező +éhgyomor +éhség +éhségféle +éhségmorranás +éhségroham +éj +éjfél +éjfekete +éji +éjjel +éjjel-nappal +éjjeli +éjjeliedény +éjjeliőr +éjjeliszekrény +éjjeliszekrényke +éjszaka +éjszakás +éjszakázás +éjszakázik +éjszakai +ék +ékalak +ékelődik +ékes +ékesít +ékeskedik +ékesszólás +ékít +ékítmény +ékszer +ékszerbolt +ékszerdoboz +ékszerész +ékszeres +ékszíj +éktelen +éktelenkedik +él +élcelődés +élcsapat +élénk +élénkít +élénkpiros +élénkség +élés +éled +élelem +élelemraktár +élelmes +élelmez +élelmiszer +élelmiszerbolt +élelmiszercsomag +élelmiszerellátás +élelmiszersegély +élelmiszerüzlet +élenjár +éles +élesedik +éleseszűség +éleskedik +éleslátás +élesség +éleszt +élesztget +élesztőgyár +élet +életáram +életbevágó +életbiztonsági +életbölcsesség +életcél +életcsúcs +életdolog +életérzés +életév +életerő +életerős +életfogytig +életfogytiglan +életfogytiglani +életforma +élethalálharc +élethű +életjel +életkérdés +életkedv +életkörülmény +életkor +életlen +életmentő +életmód +életnagyság +életnagyságú +életöröm +életrajz +életre-halálra +életrevaló +életritmus +életstílus +életszemlélet +életszentség +életszínvonal +élettárs +élettani +élettapasztalat +élettér +élettelen +élettelenség +élettörténet +életút +életütem +életű +életveszély +életveszélyes +életveszedelem +életviszonylat +életvitel +élezés +élhetetlen +éljen +éljenez +éljenzés +élmény +élménybeszámoló +élménykereső +élő +élőbeszéd +élőhalott +élőlény +élősdi +élősövény +élősövény-kerítés +élővilág +éltet +élveteg +élvez +élvezet +émelyeg +émelygés +émelygős +émelyít +émelyítő +én +én-te-ő +én-tudat +ének +énekel +énekeltet +énekes +énekesmadár +énekesnő +énekhang +éneklés +éneklő +énekszó +énekszöveg +ép +épít +építés +építési +építész +építészet +építészeti +építészhallgató +építészmérnöknő +építget +építkezés +építkezési +építkezik +építmény +építő +építőanyag +építőautomata +építőkocka +építőmester +építőművészeti +építőmunka +építőmunkás +építtet +épit +épitészet +épitészeti +éppen +éppenséggel +éppígy +éppily +éppoly +éppolyan +éppúgy +épség +épül +épület +épületalapozás +épületcsoport +épületfa +épületlakatos +épületmaradvány +épületóriás +épületszárny +ér +éralj +érc +érces +ércesedik +ércesség +ércféleség +ércoszlop +érctulok +érdek +érdekében +érdekel +érdekelt +érdekeltség +érdekes +érdekesség +érdekfeszítő +érdekközösség +érdeklődés +érdeklődési +érdeklődik +érdeklődő +érdektelen +érdektelenség +érdem +érdemérem +érdemel +érdemes +érdemi +érdemkoszorú +érdemleges +érdemtelen +érdes +érés +érem +éretlen +éretlenkedik +érett +érettségi +érettségizik +érez +érezhető +éreztet +érfonat +érik +érint +érintés +érintetlen +érintett +érintget +érinthetetlenség +érintkezés +érintkezik +érintő +érkezés +érkezget +érkezik +érkező +érlel +érlelődik +érme +érő +éroldal +érosz +érpart +érparti +érrendszer +érsek +érsekség +ért +érte +érték +értékel +értékelés +értékes +értékesít +értékesítés +értékpapír +értékrendszer +értéktelen +értéktörvény +értékű +értés +értekezés +értekezik +értekezlet +értekezleti +értelem +értelmes +értelmes-hangos +értelmetlen +értelmetlenség +értelmez +értelmi +értelmi-érzelmi +értelmiség +értelmiségellenes +értelmiségi +értelmű +értesít +értesítés +értesül +értesülés +értetlen +értetlenkedik +értetlenség +értetődik +értetődő +érthetetlen +érthetetlenség +érthető +érthetőség +értő +érv +érvágás +érvény +érvényes +érvényesít +érvényesítés +érvényesül +érvényesülés +érvényesülési +érvénytelen +érvénytelenít +érvényű +érvel +érvelés +érzék +érzékel +érzékelés +érzékelhető +érzékeltet +érzékeltetés +érzékeny +érzékenykedik +érzékenység +érzéketlen +érzéketlenség +érzéki +érzékszerv +érzés +érzésfegyverzet +érzéstelenítés +érzésű +érzelem +érzelgős +érzelmes +érzelmeskedés +érzelmi +érzelmű +érzet +érzik +érző +érződik +érzület +és +éspedig +ésszerű +ésszerűség +ésszerűtlen +ész +észak +északi +északkelet +északkeleti +északnyugat +északvidéki +észbontó +észjárás +észjárású +észlel +észlelhető +észrevétel +észrevétlen +észrevehetetlen +észrevehető +észrevesz +észvesztő +észvesztve +étek +étel +étel-ital +ételhordó +ételhulladék +ételínyencség +ételillat +ételkiadó +ételminta +ételnemű +ételnyom +ételosztás +ételrecept +ételszag +éter +éterszag +étkészlet +étkezés +étkezik +étkező +étkezőkocsi +étkezőterem +étkeztetési +étlen-szomjan +étrend +étterem +éttermi +étvágy +étvágygerjesztő +étvágytalan +év +évad +évenként +évenkénti +évente +éves +évezred +évezredes +évfolyam +évfolyamtárs +évforduló +évi +évjárat +évjáratú +évkönyv +évődik +évszám +évszázad +évszázados +évszak +évtized +évtizedes +fa +fácán +fácános +fácántoll +fácska +fáj +fájdalmas +fájdalom +fájdalomcsillapító +fájin +fájlal +fájó +fájós +fáklya +fáklyásmenet +fáklyászene +fárad +fáradalom +fáradhatatlan +fáradozás +fáradozik +fáradság +fáradságos +fáradt +fáradt-vörös +fáradtság +fáramászás +fáraó +fáraói +fáraszt +fárasztó +fás +fásli +fásliz +fásszín +fásult +fásultság +fátlan +fátyol +fátyolfelhő +fátyolkönnyű +fátyolos +fátyolosság +fátyolozott +fátyolruha +fátyolszerű +fázik +fázis +fázisingadozás +fázós +faábrázat +faág +faágy +faállomány +faarc +faasztal +fababa +fabódé +faboltozatos +faburkolat +faburkolatú +facér +facsar +facsarás +facsoport +fadarab +fadepó +faderék +fadoboz +faépítmény +faecet +faedény +faeke +fafejű +fafülű +fagally +fagerenda +fagerendás +faggat +faggatás +faggatózik +faggyú +faggyús +fagörgő +fagy +fagyás +fagyaszt +fagylalt +fagylaltos +fagyos +fagyott +faház +faházikó +fahéj +fahéjbarna +fahelyettesítő +fahíd +fahusáng +faj +fajankó +fajgyártó +faji +fajlagos +fajmagyar +fajsúly +fajsúlyos +fajsúlyú +fajta +fajtájabeli +fajtájú +fajtalankodás +fajul +fajzat +fakad +fakanál +fakaszt +fakép +fakéreg +fakerék +fakereszt +faketrec +fakezű +fakír +fakitermelő +fakó +fakókék +fakószekér +fakószürke +faködmön +fakocka +fakoponyájú +fakorlátos +fakul +fakultás +fal +falánk +falánkság +falás +falabda +falat +falatnyi +falatozás +falatozik +falaz +falazás +falbontás +falbontó +faldöntő +falépcső +falépítés +falelem +falevél +falfehér +falhézag +fali +falív +falikép +falinaptár +falióra +faliszekrény +falka +falnivaló +falomb +falragasz +falrakó +falrész +fals +faltörő +falu +falu-tanya-tanyaközpont +falú +falubeli +falucska +faluhely +falumag +falunév +falurész +falusi +falusias +faluszél +faluszéli +faluszervezés +faluvég +faluvégi +faluzik +falvédő +família +familiáris +famulus +fanagykereskedő +fanatizmus +fantázia +fantáziájú +fantáziál +fantáziálás +fantáziátlan +fantasztikus +fanyalgás +fanyalog +fanyar +fanyarkás +fanyél +faóriás +faoszlop +fapad +fapofa +fapohár +far +farag +faragás +faragószék +faragószín +faragott +farba +farekesz +farigcsál +farizeus +farkas +farkas-barkas +farkasétvágy +farkasfogó +farkasharapás +farkaskutya +farkasmosoly +farkasszag +farkasszem +farkastekintet +farkasüvöltés +farktoll +farkú +farm +farmakológiai +farmer +farmernadrág +farok +farokuszony +farol +farostlemez +farsang +farsangi +fasaru +fasiszta +fasisztaféle +fasizmus +fasor +fasori +faszén +faszénparázs +fatábla +fateknő +fatelep +fatelepes +fatelepiek +fater +faterka +fatető +fatörzs +fattyú +fattyúszó +faun +fauna +faunos +faunszerű +favágás +favágó +favicc +fazék +fazetta +fék +fékállítás +fékcsikorgás +fékez +fékezhetetlen +fékezhetetlenség +fékezőfülke +féknyom +féktelen +féktelenség +fél +fél-estély +fél-fél +félájult +félálom +félakkora +félbehagy +félbemarad +félbeszakad +félbeszakít +félbetép +félbolond +féldeci +félénk +félénkség +félévenkénti +féléves +félelem +félelemérzet +félelmes +félelmetes +féleszmélet +félezer +félgömb +félhalott +félhang +félhangos +félhold +félhomály +félhomályos +félidő +félig +félig-meddig +féligformán +félisten +félisten-király +félkabát +félkarú +félkész +félkészraktár +félkéz-fejsze +félkegyelmű +félkilós +félkör +félkörívű +félkörös +félkomfortos +féllábú +féllépésnyi +félliteres +félmeztelen +félmondat +félmosoly +félmozdulat +félmúlt +félműveltség +félnapos +félnivaló +félóra +félórás +félő +féloldalas +féloldalaz +féloldalt +félpillantás +félre +félrészeg +félreáll +félreállás +félreállít +félrecsap +félrecsúszik +félredob +félreért +félreértés +félreérthetetlen +félreeső +félrefordít +félrefordulás +félregördít +félregördül +félregondol +félrehány +félrehajol +félrehajt +félrehív +félrehúz +félrehúzódik +félrelök +félrenéz +félreránt +félresikerül +félresöpör +félretakarít +félretapos +félretart +félretesz +félretol +félreugrik +félrevezet +félrevon +félrevonul +félsivatag +félsor +félszázados +félszeg +félszegség +félszem +félszemű +félszó +félt +féltáblányi +féltégla +féltékeny +féltékenykedés +féltékenykedik +féltékenység +féltés +félteke +féltestvér +féltett +féltő +félút +félujjnyi +félváll +félvállas +félzsold +fém +fémalkatrész +fémbújtató +fémburkolat +fémdarab +fémes +fémgomb +fémhideg +fémkar +fémlap +fémpénz +fémszerkezet +fémtest +fémtok +fény +fényáradat +fénybetű +fénycső +fénydárda +fényévnyi +fényelem +fényerejű +fényes +fényes-fekete +fényeskedik +fényesség +fényez +fényhalmaz +fényhatás +fényíró +fényjáték +fényjelenség +fénykép +fényképalbum +fényképész +fényképésznő +fényképez +fényképezőgép +fényképfelvétel +fényképsorozat +fénykör +fénylik +fénynyaláb +fényözön +fénypászma +fényreklám +fényrózsa +fényrobbanás +fénysáv +fénysugár +fénysugár-gyorsaságú +fényszóró +fénytábla +fénytelen +fénytünemény +fényű +fényűzés +fényűző +fényvédő +fényvihar +fér +fércelés +féreg +férfi +férfialak +férfiarc +férfias +férfiaskodik +férfiasság +férfiatlan +férficipő +férfiember +férfierő +férfigőz +férfihang +férfihulla +férfikéz +férfikor +férfimulatság +férfinem +férfinyak +férfiönhittség +férfipulóver +férfiricsaj +férfirokon +férfiruha +férfiszépség +férfiszív +férfitag +férfitérd +férfitenyér +férfiú +férfivilág +férfizakó +férges +férj +férj-feleség +férjeura +férjtípus +férjura +férkőzik +férőhely +férőhelyes +fésül +fésületlen +fésülködik +fésű +fészek +fészer +fészerszerű +fészkel +fészkelődés +fészkelődik +február +februári +fecni +fecsérel +fecseg +fecsegés +fecsegő +fecserészik +fecske +fecskefarkú +fecskefészek +fecskendez +fecskeugrás +fed +fedd +feddő +fedél +fedélzet +fedélzeti +fedeles +fedelű +fedetlen +fedett +fedez +fedezék +fedezet +fedőfoglalkozás +fedőlemez +fegyelem +fegyelmez +fegyelmezetlen +fegyelmezett +fegyelmezettség +fegyelmi +fegyenc +fegyencmunka +fegyház +fegyőr +fegyver +fegyverállvány +fegyveres +fegyvergyár +fegyverhasználat +fegyverletétel +fegyvernem +fegyverolaj +fegyverraktár +fegyverszünet +fegyverszüneti +fegyvertárs +fegyvertelen +fegyverzet +fegyverzetű +fehér +fehércsíkos +fehéredik +fehéregér +fehérgalléros +fehérít +fehérje +fehérjéjű +fehérjeszintézis +fehérlik +fehérnép +fehérnemű +fehérneműs +fehérrépa +fehérség +fehérségű +fehérszőke +fehérterrorista +fehértiszt +fehérvári +fej +fejbólintó +fejbőr +fejcsóválás +fejcsóváló +fejcsóválva +fejében +fejecske +fejedelem +fejedelemség +fejedelmi +fejel +fejelés +fejelget +fejelőmeccs +fejenként +fejes +fejesel +fejetlen +fejetlenség +fejezet +fejfa +fejfájás +fejforgás +fejforma +fejgörcs +fejhang +fejhossz +fejingatva +fejjáték +fejkendő +fejkendős +fejlemény +fejleszt +fejlesztés +fejlesztési +fejletlen +fejlett +fejlettség +fejlettségi +fejlettségű +fejlövés +fejlődés +fejlődési +fejlődik +fejlődő +fejmagasság +fejmozdulat +fejőnő +fejőstehén +fejpárna +fejrepesztő +fejszaggatás +fejsze +fejt +fejtartás +fejtartó +fejtés +fejteget +fejtegetés +fejtermés +fejtörés +fejű +fejvadász +fekély +fekélyes +fekete +fekete-fehér +fekete-tengeri +fekete-vörös +feketéllik +feketés +feketéscsésze +feketéspohár +feketézik +feketedik +feketekávé +feketekávé-reggeli +feketekávés +feketelista +feketepiac +feketeruhás +feketeség +fekhely +fekszik +fekte +fektet +fekvés +fekvésű +fekvőhely +fekvőtámasz +fel +fel-alá +fel-feldübörög +fel-felkap +fel-felnéz +fel-felnyílik +fel-felnyög +fel-felugat +fel-felvillant +felágaskodik +feláldoz +feláldozás +feláll +felállás +felállít +felállítás +felár +felás +felázik +felad +feladás +feladat +feladatkör +feladatvállalás +feladó +felajánl +felajánlás +felajz +felajzottság +felakaszt +felakasztat +felaprít +felaprítás +felbámul +felbátorodik +felbaktat +felballag +felbérel +felbecsül +felbillen +felbiztat +felbőg +felbőszít +felbőszül +felbocsátás +felbolydít +felbolydul +felbolydulás +felbomlik +felbont +felbontás +felborít +felborul +felborzol +felborzolódik +felbosszant +felbúg +felbuffant +felbujtás +felbujtó +felbukik +felbukkan +felbukkanás +felbuzdít +felbuzdul +felcipel +felcsap +felcsattan +felcsavar +felcsendül +felcseng +felcsenget +felcseperedik +felcser +felcserél +felcsernő +felcsíp +felcsillan +felcsókol +felcsuklik +felcukkol +feldarabol +feldereng +felderít +felderítés +felderíthető +felderítő +felderítő-kutató +felderül +feldíszít +feldönt +feldől +feldob +feldolgoz +feldolgozás +feldolgozatlan +feldúl +feldúlt +feldühít +feldühödik +felduzzad +felduzzaszt +fele +felé +felébred +felébredés +felébreszt +feléget +feléje +felél +feléled +felélesztés +felémelyedik +felénekel +felényi +felépít +felépítés +felépítmény +felépül +felér +felérkezik +felebarát +feled +feledékeny +feledhetetlen +feledkezés +feledtet +felegyenesedik +felejt +felejtés +felejthetetlen +felejtődik +felekezet +felel +felelés +felelet +felelevenedik +felelevenít +felelget +felelős +felelősség +felelősségérzet +felelősségféle +felelősségteljes +felelőtlen +felelőtlenség +felemás +felemásság +felemészt +felemel +felemelkedés +felemelkedési +felemelkedik +felemelő +felemelt +felenged +felereszt +felerősít +felerősödik +feles +feleség +feleséghiány +felesel +feleselés +felesküdik +felesküdt +feleszik +feleszmél +feletet +felett +felette +felettébb +felettes +felettesi +feletti +felevez +felez +felfakad +felfakaszt +felfal +felfénylik +felfed +felfedez +felfedezés +felfedezőút +felfedeztetés +felfegyverez +felfegyverkezési +felfegyverkezik +felfekszik +felfelé +felfest +felfeszít +felfigyel +felfirkál +felfog +felfogás +felfogású +felfogad +felfoghatatlan +felfokozódás +felfordít +felfordul +felfordulás +felforgat +felforgatás +felforr +felforral +felforrósodik +felfortyan +felfrissít +felfrissül +felfúj +felfújt +felfúvódik +felfüggeszt +felfűrészel +felfűt +felfűz +felfut +felfuvalkodott +felgerjed +felgöngyöl +felgöngyölítés +felgombostűz +felgyorsul +felgyújt +felgyúl +felgyülemlik +felgyűr +felgyűrődik +felgyullad +felháborít +felháborító +felháborodás +felháborodik +felhám +felhánytorgat +felhagy +felhajózik +felhajt +felhajtás +felhallatszik +felhalmoz +felhalmozás +felhalmozódik +felhangzik +felharsan +felhasad +felhasít +felhasogat +felhasznál +felhasználás +felhatalmazás +felhérc +felheccel +felhevül +felhevülés +felhív +felhívás +felhint +felhólyagzik +felhördül +felhördülés +felhő +felhőbogár +felhőfodor +felhőfüggöny +felhőgomoly +felhőjárás +felhőkarcoló +felhőkarcoló-boly +felhőnyi +felhőpárkány +felhőrés +felhős +felhőszakadás +felhőtakaró +felhőtlen +felhord +felhorkan +felhoz +felhúz +felhúzat +felhúzó +felhúzódik +felhullámzik +felír +felírás +felível +felidéz +felidézés +felidéződik +felidegesedik +felidegesít +felijed +felindul +felindulás +felindult +felingerel +felirat +feliratos +feliratú +felismer +felismerés +felismerhetetlen +felismerhető +feliszik +felitat +felizgat +felizzik +feljár +feljáró +feljajdít +feljajdul +feljavít +feljebb +feljebbvaló +feljegyez +feljegyzés +feljelent +feljelentés +feljelentő +feljön +feljogosít +feljut +felkacag +felkanyarodik +felkap +felkapar +felkapaszkodik +felkapcsol +felkaptat +felkarol +felkattint +felkavar +felkavarodik +felkér +felkészít +felkészítés +felkészül +felkészülés +felkészült +felkészültség +felkel +felkelés +felkelő +felkelt +felkeltés +felken +felkerekedik +felkeres +felkerül +felkever +felkeveredik +felkínál +felkínlódik +felkísér +felkiált +felkiáltás +felkiáltójel +felkiáltójeles +felkiabál +felködlik +felköltözik +felkönyököl +felköszönt +felköszöntés +felköszöntő +felköt +felkötöz +felkondul +felkúszik +felküld +felküzd +felkunkorodik +felkutat +felkutatás +fellármáz +fellázad +fellapoz +fellazít +fellazul +fellélegzés +fellélegzik +fellép +fellépés +fellépked +fellebbent +fellebbez +fellebbezés +fellebbviteli +felleg +felleges +fellegvár +fellelhető +fellelkesít +fellelkesül +fellendülés +fellengzés +fellódít +fellök +fellő +fellobban +fellobbanás +fellobbant +fellobog +fellobogóz +fellocsol +felmászik +felmagasodik +felmagasztosulás +felmagzik +felmarkol +felmélázik +felmér +felmérés +felmérgesedik +felmegy +felmelegedés +felmelegedik +felmelegít +felment +felmentés +felmenthetetlen +felmentő +felmerészkedik +felmerül +felmetsz +felmond +felmondólevél +felmorajlik +felmorzsol +felmos +felmosórongy +felmutat +felnagyít +felnéz +felnevel +felnevet +felnövés +felnövekedik +felnő +felnőtt +felnőttes +felnőttség +felnyalábol +felnyílik +felnyír +felnyihanás +felnyit +felnyom +felnyomul +felnyújt +felnyújtózik +felnyúlik +felnyurgul +felölel +felölt +felöltözik +felöltöztet +felöltő +felöntöz +felötlik +felől +felőle +felőli +felocsúdik +felold +feloldhatatlan +feloldódik +feloldozás +felolvas +felolvastat +felordít +feloson +feloszlat +feloszlik +feloszt +felosztás +felpártol +felpadlóztat +felpakol +felparázslik +felparcelláz +felpattan +felpattant +felpillant +felpiroslik +felpislant +felpislog +felpiszkál +felplankol +felpótol +felpöccent +felpörget +felpörög +felpróbál +felpúposodik +felpumpál +felráncigál +felrándul +felránt +felráz +felragad +felragaszt +felragyog +felrajzol +felrajzolódik +felrak +felrakosgat +felrémlik +felrendel +felrepít +felrepül +felretten +felrezeg +felrezzen +felriad +felriaszt +felrikkant +felröhög +felröppen +felrobban +felrobbant +felrohan +felrúg +felrugdos +felruház +felség +felséges +felsebez +felsegít +felserken +felsír +felsiet +felsikál +felsikít +felsikolt +felsivít +felsóhajt +felső +felsőajak +felsőbbrendű +felsőbbségi +felsőház +felsőőrsi +felsőruha +felsőtest +felsővidék +felsodródik +felsorakozik +felsorakoztat +felsorol +felsorolás +felspurizik +felsurran +felszáguld +felszálkásodik +felszáll +felszámol +felszámolás +felszánt +felszabadít +felszabadítás +felszabadító +felszabadul +felszabadulás +felszabadult +felszabadultság +felszabdal +felszaggat +felszakad +felszakít +felszalad +felszalagoz +felszaporodik +felszed +felszedeget +felszeg +felszegez +felszentel +felszerel +felszerelés +felszerelésű +felszín +felszínes +felszíni +felszív +felszívódik +felszikrázik +felszisszen +felszól +felszólal +felszólalás +felszólaló +felszólít +felszólítás +felszólító +felszór +felszökik +felszökken +felszolgál +felszolgáló +felszúr +felszűrődik +felszurkáltat +feltámad +feltámadás +feltámaszt +feltámasztás +feltápászkodik +feltár +feltárás +feltárcsáz +feltárul +feltalál +feltaláló +feltart +feltartóztat +feltartóztathatatlan +feltép +feltérdepel +feltérképezés +feltétel +feltételes +feltételez +feltételezés +feltételezett +feltételezhető +feltétlen +feltétlenül +feltéve +feltehető +felteker +feltekint +feltekintés +feltelefonál +felterjeszt +feltesz +feltett +feltevés +feltölt +feltöltődik +feltör +feltörés +feltöröl +feltol +feltolul +feltornyosodik +feltornyoz +feltúr +feltündöklik +feltüntet +feltüremlik +feltűnés +feltűnési +feltűnik +feltűnő +feltűnő-elszánt +feltűr +feltűz +felújít +felújítás +felúszik +felüdül +felüdültet +felügyel +felügyelet +felügyeletes +felügyeleti +felügyelő +felül +felület +felületes +felületesség +felületsík +felületű +felüli +felülkerekedik +felülkerül +felülmarad +felülmúl +felülmúlhatatlan +felültet +felülvizsgálat +felüt +felüvölt +felugrál +felugrik +felujjong +felutazik +felvág +felvágós +felvágott +felvállal +felvált +felváltva +felvásárol +felvázol +felvarr +felvérez +felvétel +felvételi +felvételiző +felver +felvesz +felvet +felvetés +felvetődik +felvevés +felvevő +felvevőgép +felvevőkamera +felvezet +felvidámodik +felvidít +felvidul +felvihog +felvilágosít +felvilágosítás +felvilágosult +felvillan +felvillanyoz +felvirágoz +felvirágzás +felvirágzik +felvirrad +felvisít +felvisz +felvon +felvonó +felvonóhíd +felvonul +felvonulás +felvonulási +felzárkózik +felzabál +felzaklat +felzargat +felzavar +felzendül +felzokog +felzúg +fen +fene +fenék +feneketlen +fenekű +fenemód +fenevad +fenn +fennáll +fennálló +fennakad +fennebb +fennen +fennforog +fennhagy +fennhangon +fennhatóság +fennhéjázás +fennmarad +fennmaradás +fennsík +fenntart +fenntartás +fenőkő +fenomenális +fenség +fenséges +fenséges-komor +fensőbbség +fensőbbséges +fenti +fenyeget +fenyegetés +fenyegető +fenyegetőzik +fenyegettetés +fenyítés +fenyő +fenyőerdő +fenyőfa +fenyőillat +fenyőpikkely +fenyőszag +fenyőszagú +fenyőtű +fenyves +ferde +ferences +ferencvárosi +fertőtlenít +fertőtlenítő +fertőtlenitő +fertőtlenitős +fertőz +fertőzés +fertőző +fess +fest +festék +festékréteg +festékszag +festés +festészet +festet +festetlen +festett +festmény +festő +festőállvány +festőanyag +festői +festőiség +festőműhely +festőművész +festőszék +feszélyez +feszélyezetlen +feszélyezett +feszélyezettség +feszeget +feszeng +feszes +feszít +fesztelen +fesztivál +feszül +feszület +feszült +feszültség +feszültségteremtő +fetreng +feudálkapitalista +fia +fiacska +fiatal +fiatalasszony +fiatalember +fiatalkor +fiatalkori +fiatalkorú +fiatalodik +fiatalos +fiatalság +fiatalúr +ficánkol +fickándozik +fickó +ficsúr +figura +figurázik +figyel +figyelés +figyelem +figyelembevétel +figyelmes +figyelmesség +figyelmetlen +figyelmeztet +figyelmeztetés +figyelmeztető +figyelő +figyeltet +fikció +filctoll +filigrán +filiszter +fillér +filléres +fillérnyi +film +filmcsillag +filmes +filmez +filmezik +filmfelvevő +filmfőszerep +filmgyár +filmgyári +filmgyártás +filmhét +filmhíradó +filmhíradós +filmművészet +filmrendező +filmszínész +filmszínésznő +filmvászon +filmvígjáték +filológia +filológiai +filosz +filozófia +filozófiai +filozófus +filozófusszakáll +filozofál +finálé +fináncláb +finánclábas +fincsi +finesz +finn +finnyás +finnyás-kényes +finom +finomít +finomkodik +finomkodó +finomság +fintor +fintorgás +fintorog +fiók +fiók-kutatóintézet +fiókos +fiókpárt +fiókraktár +fiókvezető +firkál +firkálás +firkálmány +firkátum +firtat +firtatás +fitogtat +fitty +fityeg +fitymál +fityula +fiú +fiúcska +fiúgyermek +fiúkíséret +fiúkiáltás +fiúnevelő +fiús +fiúzás +fivér +fixíroz +fizet +fizetés +fizetésemelés +fizetéses +fizetésosztás +fizetőpincér +fizikai +fizikaszertár +fizikoterápiás +fizikum +fizikus +flakon +flamand +flancol +flanelling +flasztervirág +flegma +flekkes +flekktífusz +flotta +flottakörút +fluktuáció +fluoreszkál +fóbia +fókabunda +fóliakorong +fór +fórum +födém +föl +föl-le +föld +földalatti +földbirtokos +földdarab +földecske +földes +földeskonyha +földfelszín +földgömb +földgolyó +földhányás +földhajlás +földi +földieper +földjáradék +földkérdés +földkerekség +földművelő +földműves +földmunka +földmunkásság +földnélküli +földönfutó +földöntúli +földosztás +földpadló +földrajz +földrajzi +földrajzkönyv +földrész +földrengés +földsáv +földszag +földszakadék +földszelet +földszint +földszintes +földszinti +földteke +földtelen +földterület +földtöltés +földtömeg +földtulajdonos +fölé +fölébe +föléje +fölény +fölényes +fölényeskedik +fölös +fölösleg +fölösleges +fölrezeg +fölül +fölüle +föníciai +förgeteges +förmed +förtelmes +förtelmeskedés +fösvény +fösvénység +fötyöl +föveny +fövenyi +fövetlen +fő +fő-fő +főagronómus +főalak +főbérlet +főbérlő +főbérlőnő +főbejárat +főbiccentés +főbizalmi +főbólogató +főbűn +főcím +főcsoport +fődiszpécser +főépület +főember +főfal +főfelügyelő +főfoglalkozás +főfoglalkozású +főfront +főgazda +főgépész +főgenerális +főgóré +főhadiszállás +főhadnagy +főhadnagyi +főhajónagy +főhajtás +főhatalom +főhely +főhős +főigazgatóság +főiskola +főispán +főjegyző +főkamarás +főkapitányi +főkapitányság +főkapu +főként +főképpen +főkérdés +főkertészi +főkönyvelő +főkörzet +főkötő +főkomornyik +főlakáj +főlépcső +főleg +főmérnök +főnök +főnökféle +főnökség +főnökszabású +főnővér +főorvos +főorvosnő +főosztály +főosztályvezető +főpásztor +főpásztorság +főpap +főpapnő +főparancsnok +főpincér +főpolgármester +főportás +főposta +főrangú +főrendező +főrevizor +fősereg +főszemély +főszempont +főszerep +főszereplő +főszerkesztő +főszolgabíró +főszolgabíróné +főtárgyalás +főtanácsosi +főtér +főtéri +főtendencia +főtiszt +főtlen +főtolmács +főtt +főúr +főúri +főút +főútvonal +főügyész +főütőér +főudvarmester +főutca +fővádlott +főváros +fővárosi +fővadász +fővezér +fővezéri +fővonal +főz +főzés +főzelék +főzet +főzőfülke +főzőkanál +főzőszekrény +főztje +focista +fodor +fodrász +fodrászsegéd +fodrászszalon +fodrászüzlet +fodroz +fodrozás +fodrozódik +fog +fogás +fogású +fogász +fogad +fogadás +fogadási +fogadalmas +fogadalmi +fogadalom +fogadatlan +fogadkozik +fogadó +fogadóóra +fogadós +fogadtatás +fogalmaz +fogalmazás +fogalmazvány +fogalom +fogan +foganat +foganatosít +foganosít +fogantyú +fogantyús +fogas +fogaskerék +fogaskerék-pontos +fogaskerekű +fogat +fogatváltás +fogazat +fogcsikorgató +fogda +fogdos +fogékony +fogház +fogházigazgató +fogható +foghegyről +foghíj +foghíjas +foghíjbeépítési +foghíjház +foghíjlétesítési +foghúzás +fogkefe +fogkrém +foglal +foglalás +foglalat +foglalatoskodik +foglalatosság +foglalkozás +foglalkozású +foglalkozik +foglalkoztat +foglaló +foglalt +foglyos +fogmosás +fogműtét +fogó +fogócska +fogócskázik +fogódzik +fogódzkodik +fogódzó +fogós +fogoly +fogolytábor +fogolytársulat +fogorvos +fogság +fogsor +fogszabályozó +fogú +fogva +fogy +fogyaszt +fogyasztás +fogyasztó +fogyasztóközönség +fogyatékos +fogyatékosság +fogyatkozik +fogyó +fogyta +fohász +fohászkodás +fohászkodik +fojt +fojtás +fojtógáz +fojtogat +fojtott +fok +fokhagyma +fokhagymás +fokhagymázás +foknyi +fokos +fokoz +fokozás +fokozat +fokozatos +fokozatosság +fokozódik +fokozott +fokú +foldozgat +folklór +folklorista +folt +foltos +foltos-piszkos +foltoz +folyás +folyadék +folyam +folyamán +folyamat +folyamatos +folyamatosság +folyamodás +folyamodik +folydogál +folyékony +folyik +folyó +folyócska +folyóirat +folyóirattár +folyópart +folyósít +folyóvíz +folyosó +folyosórész +folyosószerű +folytán +folytat +folytatás +folytatható +folytatódik +folytatólagos +folyton +folyton-folyvást +folytonos +folytonosság +folyvást +fon +fonák +fonal +fonal-előkészítő +fonat +fonatú +foncsoroz +foncsorozású +fondor +fondorlat +fondorlatos +fonendoszkóp +fonnyad +fonnyadozik +fonnyadt +fonódik +fonott +font +fontolgat +fontolgatás +fontoló +fontos +fontoskodás +fontoskodik +fontosság +fonyódi +fordít +fordítás +fordítható +fordító +fordítói +fordított +fordítva +fordul +fordulás +fordulási +fordulat +forduló +fordulópont +forgács +forgácsjancsi +forgás +forgalmas +forgalmi +forgalmú +forgalom +forgat +forgatag +forgatócsoport +forgatószerkezet +forgattyú +forgó +forgóajtó +forgócsont +forgolódás +forgolódik +forint +forintkiajánlás +forintocska +forintos +forma +formájú +formál +formálás +formálgat +formálódik +formás +formátlan +formáz +formaalakítás +formagazdagító +formai +formakereső +formalista +formaruha +formaság +formavilág +formula +forog +forog-zenél +forpaszos +forr +forrás +forrásvíz +forradás +forradalmár +forradalmi +forradalmiság +forradalom +forral +forralt +forraszt +forró +forrófejű +forróság +forrósodik +forrong +forrpont +fortélyos +fortyog +foszforeszkál +foszforos +foszlány +foszlik +fosztogatás +fotel +fotó +fotós +fotoalkatrész +fotocellás +fotofelszerelés +fotográfia +fotográfus +fotonerőmű +fotoriporter +fotoújság +foxi +frász +frászkarika +fráter +frázis +frázisos +frakció +frakciózás +frakk +frakkos +frakkszárny +franc +francia +franciakrémes +franciaság +frankfurti +frankó +frappáns +fraternizálás +frazeológia +freccsen +fregatt +fregattkapitány +fregoli +frekvencia +freskó +freskófestés +freskótöredék +fricskáz +frigysátor +friss +frissiben +frivol +frizsider +frizura +frizurás +fröccs +fröccsen +fröcsköl +fröcskölődés +fröcsög +front +frontátvonulás +frontismeretség +frontkatona +frontmester +frontszolgálat +frottír +frottírköpeny +frottírpongyola +frottírtörülköző +frufru +fúj +fújás +fújdogál +fújkál +fújtat +fújtatás +fúl +fúr +fúrás +fúria +fúró +fúródik +fúrómester +fúrós +fúróslegény +fúrótelep +fúrótorony +fúvat +fúvódik +fúvóka +fúvószenekar +fügebólé +fügebokor +függ +függélyes +függelék +függeszt +független +függetlenít +függetlenség +függetlenségi +függöny +függönyhúzó +függönyöz +függő +függőágy +függőfolyosó +függőhíd +függőleges +függvény +fül +fülbesúgás +fülbevaló +fülcimpa +füldugós +fülecske +fülel +fülemüle +füles +fülhallgató +fülke +fülledt +fülledtség +fülsértő +fülsiketítő +fülszöveg +fültépő +fürdés +fürdet +fürdetlenség +fürdik +fürdő +fürdőfülke +fürdőház +fürdőhely +fürdőigazgató +fürdőkád +fürdőkályha +fürdőköpeny +fürdőlepedő +fürdőnadrág +fürdőorvos +fürdőruha +fürdőszoba +fürdőszobás +fürdőszobaajtó +fürdőtrikó +fürdővendég +fürdőzik +fürge +fürgeség +fürj +fürkész +fürkészés +fürkésző +füröszt +fürt +füst +füstfelhő +füstfelleg +füstfúvó +füstkarika +füstkígyó +füstködös +füstöl +füstölög +füstölt +füstös +füstpántlika +füstpénz +füstszuronyos +fütty +füttyent +füttyentget +füttyszó +fütykös +fütyörész +fütyörészés +fütyül +fütyülés +füves +füves-bozótos +füvesít +füzér +füzes +füzesgyarmati +füzet +füzetlap +fű +fű-fa +fűlik +fűrész +fűrészbak +fűrészel +fűrészelget +fűrészes +fűrészféle +fűrészfog +fűrészfogú +fűrészmalom +fűrészpor +fűrészporos +fűrésztelep +fűszál +fűszálnyi +fűszerbolt +fűszeres +fűszerüzlet +fűt +fűtés +fűtési +fűtésű +fűtenger +fűtő +fűtőanyag +fűtőcső +fűtőház +fűtőtest +fűvű +fűz +fűzbokor +fűzfa +fűzfaág +fűzfagally +fűzfakas +fűzfakosár +fűző +fűzőcske +fűződik +fűzős +fuj +fukar +fuldoklik +fullánkos +fullad +fulladásos +fulladozik +fullasztó +fundál +fundamentum +fungál +funkció +funkcionál +funkcionális +funkcionárius +fura +furakodik +furcsa +furcsálkodik +furcsáll +furcsaság +furdal +furfang +furfangos +furkál +furkósbot +furulya +fusermunka +fusimunka +fusizik +fut +futár +futárszolgálat +futás +futam +futamodik +futball +futball-labda +futballcsapat +futballista +futballozás +futballpálya +futballpápa +futballszakértő +futkározik +futkos +futó +futóbetyár +futóhomok +futólag +futólagos +futólépés +futószalag +futótréning +futta +futtában +futtat +futtató +fuvallat +fuvar +fuvaros +fuvaroz +fuvarozás +fuvarozási +fuvolázik +g-moll +gádzsó +gágog +gálya +gályarab +gáncs +gányó +gárda +gát +gátlás +gátlásos +gátlástalan +gátló +gátol +gátoltság +gátrendszer +gátszakadás +gáttest +gáz +gázcsap +gázkitörés +gázkitörés-veszélyes +gázlámpa +gázló +gázmérgezés +gázmolekula +gázművek +gázöngyújtó +gázol +gázoszlop +gázresó +gázsi +gázszag +gázszagú +gázszűrőbetét +gáztartály +gáztűzhely +gázvezeték +gabalyodás +gabalyodik +gabona +gabonaár +gabonamag +gagarászik +galamb +galambocska +galcsi +galcsitag +galéria +galeri +galiba +gall +gallér +gallérú +gally +galopp +galoppozás +galuska +galuskacsomó +galvanizál +gamós +ganéj +gang +gangos +gangrács +garázda +garázdálkodás +garázdálkodik +garázs +garázshelyiség +garázsmester +garabonciás +garancia +garancialevél +garantál +garantálható +garas +garasoskodik +garat +garatüreg +gardróbszekrény +garmada +garnitúra +gatya +gatyázik +gavallér +gavalléria +gavalléros +gaz +gazda +gazdálkodás +gazdálkodik +gazdálkodó +gazdátlan +gazdaasszony +gazdacsalád +gazdag +gazdag-paraszt +gazdagodik +gazdagság +gazdagságú +gazdagyerek +gazdaság +gazdasági +gazdaságos +gazdaságosság +gazdaságpolitika +gazdaságszervezeti +gazdaságtan +gazdaságvezetés +gazdasszony +gazdatiszti +gazdi +gazdika +gazduram +gazella +gazember +gazfickó +gazos +gazság +gazsulál +gazszál +gaztenger +gaztett +gébics +gége +gégész +géhá +géhás +gém +gémberedett +gémberít +gémeskút +géniusz +gép +gépágyú +gépagy +gépcsoda +gépész +gépész-szakács +gépészmérnök +gépésztechnikus +gépel +gépelt +gépesít +gépezet +gépgyártási +gépház +géphang +gépi +gépírás +gépírásos +gépíró +gépírónő +gépies +gépjavító +gépkatona +gépkezelőnő +gépkocsi +gépkocsiforgalom +gépkocsigarázs +gépkocsiipari +gépkocsivezető +géplakatos +gépolaj +géppisztoly +géppisztolyos +géppisztolysorozat +géppuska +géppuskás +géprész +gépsonka +gépsor +gépszerkezet +gépszíj +gépterem +gépzene +gépzúgás +gézcsík +gézengúz +gebe +gebin +gemkapocs +generáció +generálberendezés +generális +generálisféle +generálkulcs +gengszter +gennyesedik +gennygóc +geológus +geometriai +geometrikus +gereblye +gereblyél +gereblyéz +gerelyvetés +gerenda +gerendalabirintus +gerezd +gerezdes +gerilla +gerinc +gerinckopás +gerincű +gerjed +gerjeszt +germán +gesztenye +gesztenyebarna +gesztenyefa +gesztenyefalevél +gesztenyefasor +gesztenyehaj +gesztenyeszín +gesztikuláció +gesztikulál +gesztus +gesztuselmaradás +gettó +giccs +giccses +gigantikus +giliszta +gilisztadíszes +gimnázium +gimnasztyorka +gimnazista +gipsz +gipszágyékkötő +gipszatlasz +gipszcímer +gipszciráda +gipszkirály +girhes +girland +gitár +gizda +gleccser +globális +gnóm +góc +gócpont +gógyi +gól +gólhelyzet +góliát +gólszerző +gólya +gólyaléptek +góré +gót +gótika +gótikus +gödölye +gödör +gödröcskés +gödrös +gömb +gömbhajó +gömböc +gömbölyít +gömbölyödik +gömbölyű +gömbölyűség +gömörödik +gönci +göndör +göndör-borzas +göndörödik +göngyöl +görbe +görbít +görbül +görcs +görcsös +görcstelen +görcsű +gördít +gördül +görény +görénybűzű +görget +görkorcsolyapálya +görnyed +görnyedés +görnyedt +görög +görögdinnye +görögös +göröngy +göröngyzuhatag +gőg +gőgös +gőz +gőz-folyadék +gőzbárka +gőzfelhő +gőzfürdő +gőzfűrész +gőzhajó +gőzhajózás +gőzmozdony +gőzölög +gőzös +golfnadrág +golyó +golyóbis +golyócska +golyófogó +golyóstoll +golyószóró +golyószórós +golyózápor +golyózik +gomb +gomba +gombás +gombalámpa +gombgyáros +gomblyuk +gombnyomás +gombóc +gombocska +gombol +gombolatlan +gombolgat +gombos +gombostű +gombostűfej +gombszem +gombszög +gombüzlet +gomoly +gomolyag +gomolyasajt +gomolyfelhő +gomolyog +gond +gondatlan +gondbeszélgetés +gondnok +gondol +gondola +gondolat +gondolatátvitel +gondolatbénító +gondolatfelvillanás +gondolatmenet +gondolatolvasó +gondolatparancs +gondolatsor +gondolattársítás +gondolattalan +gondolattömeg +gondolatvilág +gondolkodás +gondolkodási +gondolkodásmód +gondolkodású +gondolkodik +gondolkodó +gondolkozás +gondolkozik +gondolkozó +gondos +gondoskodás +gondoskodik +gondosság +gondoz +gondozás +gondozatlan +gondozott +gondtalan +gondterhelt +gondűző +gondviselés +gondviselő +gong +gonosz +gonoszkodik +gonoszság +gordonka +goromba +gorombáskodás +gorombáskodik +gorombáz +gorombaság +grácia +gránát +gránátalma +gránátszilánk +gránitkövezet +gránitszikla +grabanc +grafikon +grafikus +grafikusék +grafit +grafológia +grafológus +gramm +grammatikus +gramofon +grand +grandiózus +gratuláció +gratulál +gravírozó +graviditás +gravitáció +gravitációs +grenadinruha +grill +grimasz +grimaszol +gróf +grófi +grófné +grófnő +groteszk +grúz +grund +gúla +gúny +gúnya +gúnyol +gúnyolódik +gúnyos +gúzs +gúzsbakötés +gügyög +gügyögés +gürcöl +guba +gubacs +gubancos +gubbaszt +guggol +guggolás +gukker +gukkerszíj +gulya +gulyás +gulyás-fokos-romantika +gulyáságyú +gulyásbojtár +gulyanyomás +gumi +gumírozott +gumiarc +gumibelső +gumibot +gumibotütleg +gumicsizma +gumicsónak +gumicsöves +gumikerekű +gumikesztyű +gumilabda +gumimatrac +gumipapucs +gumipitypang +gumipitypang-terület +gumipumpa +gumisarok +gumislag +gumiszőnyeg +gumitalp +gumitalpú +gumiút +gumivasaló +gumó +gunyoros +gurguláz +gurít +gurigál +gurul +guszta +gusztus +gusztusos +gusztustalan +gusztustalankodik +gutaütés +gvárdián +gyám +gyámkodás +gyámkodik +gyámolít +gyámolító +gyámolt +gyámoltalan +gyámoltalanság +gyámügyi +gyár +gyári +gyárigazgató +gyárkémény +gyáros +gyárt +gyártás +gyártelep +gyártmány +gyártmányú +gyártulajdonos +gyász +gyászének +gyászfátyol +gyászhír +gyászjelentés +gyászkeretes +gyászlobogó +gyászmise +gyászol +gyászoló +gyászorkeszter +gyászos +gyászruha +gyászszalag +gyászszertartás +gyászszónoklat +gyászzene +gyáva +gyávaság +gyakori +gyakorlás +gyakorlat +gyakorlati +gyakorlatlan +gyakorlatozik +gyakorlott +gyakornok +gyakorol +gyakorta +gyakran +gyaláz +gyalázat +gyalázatos +gyalázatosság +gyalázkodik +gyalog +gyalogasztal +gyalogezred +gyaloghintó +gyalogjáró +gyaloglás +gyalogösvény +gyalogol +gyalogos +gyalogság +gyalogsági +gyalogszeder +gyalogszerrel +gyalogút +gyalulás +gyalulatlan +gyanánt +gyanakodik +gyanakvás +gyanakvó +gyanakvó-kutató +gyanít +gyanta +gyantás +gyanú +gyanúkeltés +gyanús +gyanúsít +gyanúsítgat +gyanúsítható +gyanúsított +gyanútlan +gyapjú +gyapjúpulóver +gyapjútakaró +gyarapít +gyarapodik +gyarló +gyarmat +gyarmatárubolt +gyarmati +gyatra +gyékény +gyékényheverő +gyémánt +gyémántbuton +gyér +gyérül +gyenge +gyengécske +gyengéd +gyengédség +gyengélkedik +gyengeelméjű +gyengeség +gyengít +gyengül +gyengülés +gyep +gyepes +gyephokipálya +gyeplő +gyere +gyerek +gyerekágy +gyerekarc +gyerekbolond +gyerekcsoport +gyerekelőadás +gyerekes +gyerekeskedik +gyerekfej +gyerekhang +gyerekhistória +gyerekholmi +gyerekjáték +gyerekjátszótér +gyerekképű +gyerekkéz +gyerekkönyv +gyerekkocsi +gyerekkoporsó +gyerekkor +gyerekkori +gyereknapszám +gyereknépség +gyerekotthon +gyerekpizsama +gyereksivalkodás +gyerekszem +gyerektartás +gyerektenyérnyi +gyerkőc +gyermek +gyermekarc +gyermekbetegség +gyermekcipő +gyermekév +gyermekes +gyermekfej +gyermeki +gyermekjáték +gyermekkor +gyermekkori +gyermeknevelés +gyermekség +gyermekszem +gyermektartás +gyermektelen +gyermekvadászat +gyermeteg +gyertya +gyertyán +gyertyacsonk +gyertyafény +gyertyafényes +gyertyaláng +gyertyaszál +gyertyatartó +gyertyavallatás +gyí +gyík +gyilkol +gyilkolás +gyilkos +gyilkosság +gyilkossági +gyógyfürdő +gyógyhatású +gyógyír +gyógyít +gyógyítás +gyógyíthatatlan +gyógykezeltet +gyógymód +gyógypedagógusnő +gyógyszer +gyógyszerész +gyógyszertár +gyógyszertári +gyógyszervegyészeti +gyógyüdülő +gyógyul +gyógyulás +gyógyvíz +gyógyvíz-reklámfilm +gyón +gyónás +gyóntató +gyökér +gyökérkefe +gyökérvésés +gyökerezik +gyökerű +gyömköd +gyömöszöl +gyöngy +gyöngyfog +gyöngyház +gyöngyhalászat +gyöngyözik +gyöngysor +gyöngytenger +gyöngytyúk +gyöngyvirág +gyönyör +gyönyörködik +gyönyörködtet +gyönyörű +gyönyörűség +gyönyörűséges +gyötör +gyötrelem +gyötrelmes +gyötrődés +gyötrődik +győz +győzedelmeskedik +győzelem +győzelmes +győzelmi +győzhetetlen +győzködik +győztes +gyolcsgatya +gyolcsing +gyom +gyomai +gyomor +gyomorbajos +gyomorfekély +gyomorfelforgató +gyomorgörcs +gyomorkeserűs +gyomormosás +gyomorsav +gyomorsüllyedés +gyomorszáj +gyomorvérzés +gyomos +gyors +gyorsaság +gyorsfutár +gyorsíró +gyorsít +gyorslift +gyorsnyelvű +gyorstalpaló +gyorstüzelő +gyorsul +gyorsulás +gyorsvonat +gyújt +gyújtópont +gyújtós +gyújtogatás +gyúl +gyúr +gyüdi +gyülekezet +gyülekezik +gyülevész +gyümölcs +gyümölcsfa +gyümölcsfaág +gyümölcshegy +gyümölcskertész +gyümölcsös +gyümölcsszag +gyüremlik +gyürmöl +gyűjt +gyűjtés +gyűjtemény +gyűjteményes +gyűjtő +gyűlés +gyűlésterem +gyűlik +gyűlöl +gyűlölet +gyűlöletes +gyűlölködés +gyűlölködik +gyűlölség +gyűr +gyűretlen +gyűrött +gyűröttség +gyűrődés +gyűrődik +gyűrű +gyűrűkovács +gyűrűtlen +gyűrűz +gyűrűzik +gyufa +gyufásdoboz +gyufagyújtás +gyufaoldat +gyufaskatulya +gyufaszál +gyufazörgés +gyugyurigyuuu +gyullad +gyulladás +gyulladt +ha +ha-ha-ha +háborgat +háborítatlan +háborog +háború +háborús +háborúskodás +háborúzik +hágó +háj +hájas +hájtömeg +hál +hála +hálás +hálátlan +hálaistennek +hálanyilvánítás +hálatelt +háló +hálóing +hálóköntös +hálószoba +hálószobaablak +hálószobabútor +hálótárs +hálóterem +hálóvendég +hálózat +hályog +hám +hámlik +hámoz +hámozás +háncs +háncsfüggöny +háncsszoknyácska +háncsú +hány +hányad +hányadán +hányadik +hányadszor +hányattatás +hányaveti +hányféle +hányinger +hánykolódás +hánykolódik +hányódik +hányszor +hánytorgat +hápog +hárem +hárfa +hárít +hármas +hármashegyi +három +három-négy +három-négyszáz +háromágú +háromaknás +háromcsillagos +háromdimenziós +háromévenként +hároméves +háromemeletes +háromesztendős +háromezer +háromezer-háromszázkilenc +háromezer-hatszázötvennégy +háromezerkétszáz +háromfelé +háromgyerekes +háromhetenként +háromlábú +háromliteres +háromméteres +háromnegyed +háromnegyedes +háromnyelvű +háromórás +háromoktávos +háromszáz +háromszázhatvanöt +háromszázhúsz +háromszázhuszonhét +háromszáznyolcvan +háromszázötven +háromszög +háromszögletű +háromszögű +háromszoba +háromszobás +háromszori +háromszoros +háromtagú +hárs +hársfa +hársfatea +hárul +háryjános +hát +hátbavágás +hátegyenesítő +hátgerinc +hátgerinc-daganat +hátha +háti +hátizsák +hátjáték +hátlap +hátmenet +hátra +hátrább +hátrál +hátrány +hátrányos +hátracsap +hátracsapódik +hátracsavar +hátradönt +hátradől +hátradob +hátraesik +hátrafelé +hátrafeszít +hátrafordít +hátrafordul +hátragurít +hátrahagy +hátrahajít +hátrahajol +hátrahúz +hátrahúzódik +hátrakönyököl +hátraköt +hátrakulcsol +hátralép +hátralevő +hátralök +hátralopódzik +hátramarad +hátramaradott +hátramegy +hátranéz +hátranézés +hátranyújt +hátranyúl +hátraperdül +hátrapillant +hátraránt +hátrasimít +hátrasimul +hátraszalad +hátraszeg +hátraszól +hátraszorít +hátratántorodik +hátratekint +hátraterjeszkedik +hátratesz +hátratol +hátratúr +hátraugrik +hátravan +hátravet +hátravezet +hátravisz +hátravonul +hátsó +háttér +hátú +hátul +hátulja +hátulsó +hátvéd +ház +házacska +házas +házasélet +házasember +házasodik +házaspár +házasság +házassági +házasságkötés +házasságkötő +házasságszédelgés +házasságszédelgő +házastárs +házfal +házfelügyelő +házfoglaló +házgazda +házgondnok +házi +háziállat +háziasszony +háziasszonyi +házibuli +házigazda +házikabát +házikó +háziköntös +házimunkás +házinyúl +háziorvos +házirend +háziúr +házkutatás +házmester +házmester-házaspár +házmesterné +házőrző +házrengeteg +házsártos +házsor +házszám +háztáji +háztartás +háztartási +háztető +háztömb +háztűznéző +háztulajdonos +házú +házvezetőnő +haa +hab +habár +habarcs +habarcskozmetika +habkönnyű +habos +habosodik +haboz +habozás +habozik +habozó +habzik +habzsol +habzsolás +hacsak +had +hadállás +hadakozás +hadakozik +hadar +hadarás +hadarászik +hadbíró +hadd +haderő +hadfi +hadgyakorlat +hadi +hadibázis +hadidicsőség +hadifogoly +hadifogolytábor +hadifogság +hadihajó +hadiipar +hadijel +hadijelentés +hadipénztár +hadirokkant +hadisarc +hadisegély +hadiszergyáros +haditanács +haditengerész +haditengerészet +haditengerésztiszt +haditerv +hadititok +haditudomány +hadiút +hadiüzem +hadizsákmány +hadjárat +hadkiegészítési +hadkiegészítő +hadmozdulat +hadművelet +hadműveleti +hadnagy +hadnagyforma +hadnagyocska +hadnagyság +hadonászás +hadonászik +hadosztály +hadrálás +hadrend +hadsegéd +hadsereg +hadszíntér +hadtest +hadúr +hadügyminisztérium +hadvezér +hadvezéri +hadvezető +hadvezetőség +hagy +hagyás +hagyaték +hagyján +hagyma +hagymászsák +hagymaszagú +hagyomány +hagyományos +hagyományosság +hagyományoz +haha +hahota +hahotázik +haj +hajadonfőtt +hajaj +hajaz +hajbóbita +hajbókol +hajcihő +hajcsár +hajcsat +hajcsomó +hajdan +hajdanán +hajdani +hajdú +hajdúfő +hajdúnánási +hajerdő +hajfürt +hajít +hajigál +hajkorona +hajkoszorú +hajkupac +hajkurász +hajlás +hajlású +hajladozik +hajlam +hajlamos +hajlamú +hajlandó +hajlandóság +hajlat +hajlék +hajlékony +hajléktalan +hajlevágás +hajlít +hajlított +hajlik +hajlong +hajlongás +hajlott +hajmeresztő +hajnal +hajnalhasadási +hajnali +hajnalodik +hajnyírási +hajó +hajóállomás +hajógyár +hajógyári +hajóhad +hajóhíd +hajóhinta +hajójegy +hajókabin +hajókürt +hajólámpás +hajónagy +hajópadló +hajórakomány +hajós +hajóstiszt +hajóstörténet +hajószobor +hajótörött +hajózás +hajózó +hajol +hajpihe +hajrá +hajsza +hajszál +hajszálnyi +hajszálpontos +hajszálvékony +hajszol +hajszolás +hajt +hajtás +hajtat +hajthatatlan +hajtható +hajtó +hajtóerő +hajtóka +hajtókar +hajtórúd +hajtóvadászat +hajtömeg +hajtogat +hajtornyos +hajtű +hajú +hajvágás +hajviselet +hajzat +hajzuhatag +hajzuhatag-kerítés +hal +halál +halálbiztos +halálbüntetés +haláleset +halálfélelem +halálfej +halálfejes +halállista +halálos +halálozási +halálpofa +halálsápadt +halálsikoly +halánték +halántékér +halápi +halász +halászat +halászati +halászcsárda +halászember +halászforma +halászlé +halacska +halad +haladás +haladék +haladéktalan +haladó +halandzsa +halastó +halaszt +halaszthatatlan +halbelezés +haldoklás +haldoklik +haldokló +halhatatlan +halhatatlanság +halk +halkít +halkonzerv +halkul +halkupac +hall +hallás +hallajtó +hallanivaló +hallat +hallata +hallatlan +hallatszik +hallféle +hallgat +hallgatás +hallgatag +hallgatagság +hallgató +hallgatódzik +hallgatólag +hallgatólagos +hallgatóság +hallható +hallik +halló +hallóka +hallóz +hallomás +hallucinál +halmoz +halódik +halogat +halogatás +halom +halott +halottasszoba +halottlátó +halottsápadt +halpaprikás +halpiac +halszem +haltetű +halvány +halványbarna +halványkék +halványpiros +halványsárga +halványszínű +halványul +halványzöld +halvérű +hamar +hamarjában +hamarosan +hamis +hamisít +hamisítatlan +hamiskás +hamiskodik +hamisság +hamm +hamu +hamueső +hamuréteg +hamuszürke +hamutál +hamutálca +hamutartó +hamuzik +hamvas +hamvasság +hamvazószerdai +hancúrozás +hancúrozik +handabandázás +handabandázik +hanem +hang +hangadó +hangerő +hangfal +hangfogós +hangfoszlány +hanghatás +hanghordozás +hangjegy +hanglavina +hanglejtés +hangnem +hangocska +hangol +hangoló +hangorkán +hangos +hangosanbeszélő +hangosbeszélő +hangoskodás +hangoskodik +hangosság +hangoztat +hangoztatás +hangregiszter +hangsúly +hangsúlyoz +hangszál +hangszalag +hangszer +hangszín +hangszigetelt +hangszóró +hangtalan +hangtompítós +hangú +hangulat +hangulatélet +hangulatlámpa +hangulatos +hangulatú +hangulatvilág +hangulatvilágítás +hangváltás +hangverseny +hangversenyiroda +hangvihar +hangvilla +hangya +hangyaboly +hangzás +hangzású +hangzatos +hangzavar +hangzik +hangzócsoport +hant +hantolás +hanyag +hanyagol +hanyagság +hanyatlás +hanyatlik +hanyatt +hanyatt-homlok +harácsol +harácsoló +harákol +harag +haragít +haragkitörés +haragos +haragoszöld +haragszik +haragú +harakiri +harang +harangkötél +harangoz +harangozás +harangozó +harangszó +harangszoknya +harangvirág +harap +harapás +harapdál +harapófogó +harapós +harc +harcálláspont +harcászati +harcedzett +harci +harcias +harciasság +harciszekér +harciszekércsapat +harckocsi +harcmodor +harcol +harcos +harcsabajuszú +harcsaszáj +harctér +harisnya +harisnyás +harisnyahúzogatás +harisnyatartó +harkai +harmad +harmad-negyedéves +harmadév +harmadfél +harmadfokú +harmadik +harmadikutas +harmadmagával +harmadnap +harmadnapos +harmadolás +harmadrendű +harmat +harmatos +harminc +harminc-negyven +harmincad +harmincadik +harmincas +harmincéves +harmincegy +harmincegynéhány +harmincesztendős +harmincezer +harmincféle +harminchárom +harminchat +harminchat-negyven +harminchatezer +harminchét +harminckét +harminckét-harminchárom +harminckettő +harminckilenc +harmincnégy +harmincnyolc +harmincnyolcadik +harmincöt +harmincöt-harminchét +harmincöt-harmincnyolc +harmónia +harmonika +harmonikázik +harmonikus +harsány +harsan +harsanás +harsog +harsogás +harsona +harsonázás +has +hasábburgonya +hasacska +hasad +hasadás +hasadék +hasadozik +hasal +hasas +hascsikarás +hasfal +hasi +hasít +hasított +hasis +hasizom +hasmánt +hasogat +hasonlat +hasonlatos +hasonlatosság +hasonlít +hasonlíthatatlan +hasonlítható +hasonló +hasonlóképpen +hasonlóság +hasonszőrű +hasüreg +használ +használat +használati +használatlan +használatos +használhatatlan +használható +használhatóság +használt +hasznos +hasznosít +hasznosítható +haszon +haszonfa +haszonkulcs +haszonleső +haszontalan +haszontalanság +hasztalan +hat +hat-hét +hat-hétszáz +hat-húsz +hat-tíz +hatálytalanít +határ +határcsonkítás +határidő +határőr +határőrség +határőrség-parancsnokság +határol +határos +határoz +határozat +határozatlan +határozatlanság +határozott +határozottság +határper +határpont +határszél +határtalan +határvadász +határvadászsapka +határvidék +határvonal +hatás +hatásfok +hatásfokú +hatáskör +hatásos +hatásszünet +hatástalan +hatású +hatalmas +hatalmi +hatalmú +hatalom +hatalomátvétel +hatalomgyakorlás +hatalomszó +hatalomtudomány +hatalomvágy +hatékony +hatékonyság +hatéves +hatemeletes +hatezer +hatnapos +hatókör +hatórás +hatóság +hatósági +hatökör +hatökrös +hatodik +hatodmagával +hatodrangú +hatol +hatos +hatszáz +hatszázas +hatszázhuszonnégy +hatszáznegyvenkét +hattyú +hattyúdal +hatvan +hatvan-nyolcvanezer +hatvanas +hatvanéves +hatvanezer +hatvanféle +hatvanhárom +hatvanharmadik +hatvanhat +hatvanhét +hatvankét +hatvankilenc +hatvankilós +hatvannégy +hatvannyolc +hatvanöt +hatvanoldalas +havas +havasi +havazás +havazik +haver +haverozás +havi +havonta +haza +haza-hazatelefonál +hazaáruló +hazacsempész +hazaér +hazaérkezés +hazaérkezik +hazaenged +hazafelé +hazafi +hazafias +hazafiatlan +hazafuvaroz +hazagyalogol +hazahív +hazahord +hazahoz +hazahozat +hazai +hazaindul +hazajár +hazajárogat +hazajön +hazajövetel +hazajut +hazakészül +hazakészülődik +hazakerget +hazakerül +hazakísér +hazaköltözik +hazaküld +hazaküldöz +hazalátogat +hazamegy +hazamenés +hazamenekülés +hazamenetel +hazarohan +hazasétál +hazasiet +hazaszállít +hazaszabadul +hazaszalad +hazaszeretet +hazaszökik +hazatalál +hazatér +hazatérés +hazatérő +hazatelefonál +hazaugrik +hazautazik +hazavágyik +hazavár +hazavergődik +hazavetődik +hazavezet +hazavillamosozik +hazavisz +hazudik +hazudozás +hazudozik +hazudozó +hazug +hazugság +hazulról +he +hé +hébe-hóba +héber +héj +héjú +hékás +hélium +hérész +hét +hét-nyolc +hétéves +hétezer +hétfő +héthónapos +hétköznap +hétköznapi +hétpróbás +hétrét +hétszáz +hétszázadik +hétszázhúsz +hétszázötvenhat +hétvége +hétvégi +hév +hézag +hézagos +hebeg +hebehurgya +hebrencs +hecc +heccel +hederít +hedonista +heg +hegedül +hegedű +hegedű-zongora +hegedűgyakorlás +hegedűhúr +hegedűjáték +hegedűművész +hegedűs +hegedűtok +hegeszt +hegesztő +hegesztőapparátus +hegy +hegy-félkör +hegy-völgy +hegycsúcs +hegyén-hátán +hegyecske +hegyes +hegyesedik +hegyez +hegygerinc +hegyi +hegyibeszéd +hegyibeszédez +hegyláncolat +hegyoldal +hegyrajzi +hegység +hegyszagú +hegytető +hegyű +hegyvonulat +hehe +hehehe +heherészés +heherészget +heherészik +hej +hektó +hekus +helikoni +helikopter +helviai +hely +helybeli +helyben +helyben-tánc +helybenhagy +helycsere +helyénvaló +helyenként +helyes +helyesbít +helyesbítés +helyesel +helyesírás +helyesírási +helyeslés +helyesség +helyett +helyette +helyettes +helyettesi +helyettesít +helyez +helyezés +helyezett +helyezkedés +helyezkedik +helyeztet +helyi +helyiség +helyismeret +helykínálás +helynyi +helyőrség +helyőrségi +helyrajz +helyre +helyreáll +helyreállít +helyreállítás +helyrehoz +helyrehozhatatlan +helyreigazít +helyrerak +helység +helyszerző +helyszín +helyszínel +helyszínelés +helyszíni +helytáll +helytállás +helytálló +helytartó +helytelen +helytelenség +helyváltoztatás +helyzet +helyzeti +helyzetmegítélés +hemzseg +henceg +hencegés +hendikeppelés +henger +hengerelt +hentes +hentesbárd +hentesmester +hentesművész +hentessegéd +hepaj +hepciáskodás +hepehupás +herceg +hercegi +hercegné +hercegnő +hercehurca +here +herél +herélt +herendi +hergel +hering +hermelin +hermetikus +hernyó +hernyórágta +hernyótalp +hernyótalpas +hernyótest +hernyótestű +herseg +hersegtet +hervad +hervadt +hess +hesseget +hessentget +hetedíziglen +hetedik +hetenként +hetente +hetes +heti +hetilap +hetipiac +hetven +hetvenéves +hetvenezer +hetvenhat +hetvenhét +hetvenkét +hetvenkedik +hetvenkettő +hetvenöt +hetyeg +hetyke +heveder +hevederszíj +heveny +hevenyész +hevenyészett +hever +heverészik +heverő +heverőhely +heverőpléd +heves +hevesi +heveskedik +hevesség +hevít +hevül +hexensussz +híd +hídépítés +hídépítő +hídelem +hídfő +híg +hígeszű +hígítás +híja +híján +hím +hímez +hímnemű +hímzés +hímzőráma +hír +híradás +híradósautó +híranyag +híre-hamva +híres +híresség +híresztel +híresztelés +hírhálózat +hírhedt +hírközlés +hírközlő +hírlap +hírmondó +hírnév +hírneves +hírnök +hírszerzés +hírszerző +hírszolgálat +hírszolgáltatás +hírű +hírvétel +hírverés +hív +hívás +hívási +hívat +hívatlan +hívó +hívogat +hívogató +hívság +hívságos +hízás +hízeleg +hízelgő +hízik +hízlal +hízó +hízott +hiába +hiábavaló +hiábavalóság +hiány +hiánycikk +hiányérzet +hiányol +hiányos +hiányosság +hiányzik +hiányzó +hiba +hibás +hibátlan +hibázik +hibáztat +hibiszkusz +hibrid +hibridizációs +hideg +hideg-meleg +hidegfejű +hidegkonyha +hideglelős +hidegrázás +hidegség +hidegtál +hidegvér +hidegvérű +hidegvízű +hidrogén +hierarchia +hieroglifa +higany +higanyfény +higanymozgékonyságú +higgadt +higgadtság +higiénia +higiénikus +hihetetlen +hihetetlenség +hihető +hihi +himbál +himbálódzás +himbálódzik +himnusz +hindu +hint +hinta +hintás +hintázik +hintáztat +hintalánc +hintaszék +hintó +hipertrófia +hipertrófiás +hipnózis +hipnotizál +hipotézis +hipp-hopp +hirdet +hirdetés +hirdetmény +hirdető +hirdetőoszlop +hirdetőtábla +hirhedt +hirtelen +hirtelen-váratlan +hirtelenében +hirtelenség +história +históriai +hisz +hiszékeny +hiszem +hiszen +hisztéria +hisztériás +hisztériázik +hisztérikus +hit +hitbuzgalmi +hitélet +hitel +hiteles +hitelesít +hitelesség +hitelező +hitelrontás +hites +hitetlen +hitetlenkedik +hitetlenség +hitfél +hitközség +hitleri +hittani +hitvány +hitvallás +hitvédelem +hitves +hitvesi +hiú +hiúság +hivalkodás +hivalkodó +hivat +hivatás +hivatásos +hivatású +hivatal +hivatalból +hivatali +hivatalnok +hivatalnokember +hivatalnoki +hivatalos +hivatalsegéd +hivatkozás +hivatkozik +hivatva +hivő +hizlal +hizlaltat +hja +hm +hó +hóakadály +hóbagoly +hóborította +hóbort +hóbortos +hódít +hódítás +hódító +hódol +hódolat +hóesés +hófal +hófedte +hófehér +hófogsor +hófolyosó +hófúvásos +hógolyó +hóha +hóhér +hóhérpofájú +hóhérszerzet +hóhem +hóhemség +hóka +hókunyhó +hókupac +hókuszpókusz +hókuszpókuszol +hólé +hólepett +hólepte +hólyag +hólyagos +hólyagszerű +hómező +hón +hónalj +hónap +hónapi +hónapnyi +hónapos +hóolvadás +hópehely +hópihe +hórihorgas +hórukk +hótaraj +hótenger +hózentráger +höhö +hölgy +hölgyecske +hölgykutya +hölgyválasz +hömpölyög +hörböl +hörcsög +hördül +hörgés +hörgésszerű +hörög +hörpint +hörpöl +hő +hőbörgés +hőbörög +hőfok +hőhullám +hőigény +hőmérő +hőmérséklet +hőmérséklet-ingadozás +hőmérsékletbeli +hőmérsékletváltozás +hős +hőség +hősi +hősies +hősiesség +hősködik +hősnő +hőzöng +hodály +hogy +hogyan +hogyha +hogyhogy +hogyisne +hogyne +hogysem +hohó +hokedli +hokedliszerű +hol +hold +hold-éjjel +hold-expedíció +hold-magma +hold-nappal +holdacska +holdas +holdfény +holdfényszín +holdkráter +holdnyi +holdrakéta +holdsarló +holdtalan +holdvilág +holdvilágszín +holland +hollandi +hollandus +hollét +holló +hollóhaj +holmi +holnap +holnapi +holnapután +holott +holt +holta +holtág +holtbiztos +holtfáradt +holtpont +holtrészeg +holtsápadt +holttengeri +holttest +homály +homályos +homályosodik +homályosul +hombárszerű +homéroszi +homlok +homlokbőr +homlokfal +homloklebeny +homlokráncolás +homlokseb +homlokú +homlokzat +homok +homokbucka +homokdomb +homokdombvonulat +homokfutó +homokhegy +homoki +homokkő +homokos +homokozó +homokpart +homokpatak +homokréteg +homokszelídítő +homokszem +homokszemcse +homoktábla +homokút +homokzsák +homorít +hon +honalapító +honfitárs +honfitársnő +honfoglalás +honi +honn +honnan +honnét +honol +honorárium +honos +honosodik +hontalan +honvágy +honvéd +honvéd-munkaszolgálatos +honvédkerület +honvédő +honvédség +honvédtiszt +honvédtiszti +hopp +hoppá +hord +horda +hordár +hordás +hordalékmennyiség +hordat +hordó +hordómosó +hordoz +hordozórakéta +horgász +horgászás +horgászbot +horgászház +horgászik +horgásztanya +horganylemezes +horgol +horhos +horizont +horkan +horkanás +horkant +horkol +horkolás +hormon +hormontermelés +horog +horogkeresztes +horogütés +horony +horpadás +horpadékony +horpadt +horthy-csendőr +horthysta +hortobágyi +hortyog +hortyogás +horvát +horzsol +horzsolás +horzsolásszerű +hossz +hosszában +hosszabb-rövidebb +hosszabbítás +hosszadalmas +hosszan +hosszas +hosszat +hosszít +hosszú +hosszúkás +hosszúnap +hosszúság +hotel +hova +hová +hovatovább +hoz +hoz-visz +hozamú +hozat +hozatal +hozható +hozomány +hozományvadász +hozsannázik +hozzá +hozzáállás +hozzáad +hozzábiggyeszt +hozzábújik +hozzádörzsöl +hozzádől +hozzádrótoz +hozzáér +hozzáért +hozzáértés +hozzáértő +hozzáfér +hozzáférhetetlen +hozzáférhetetlenség +hozzáfog +hozzáfordul +hozzáfűz +hozzájárul +hozzájárulás +hozzájut +hozzákezd +hozzákötődik +hozzálát +hozzálép +hozzámegy +hozzámond +hozzánő +hozzányúl +hozzáperdül +hozzápótol +hozzáragad +hozzárajzol +hozzásegít +hozzászól +hozzászólás +hozzászokik +hozzászoktat +hozzátapad +hozzátartozik +hozzátartozó +hozzátesz +hozzátold +hozzávág +hozzávaló +hozzávesz +hú +húg +húgocska +húgy +húgyszag +húr +hús +húscsík +húshegy +húsleves +húsmennyiség +húsmentes +húsmező +húsos +húspiros +hússeb +hússzínű +hústalan +hústorony +húsú +húsvadász +húsvét +húsvéti +húsz +húsz-harminc +húsz-harmincéves +húsz-huszonegy +húsz-huszonkét +húsz-huszonöt +húszas +húszcentis +húszéves +húszezer +húszholdas +húz +húzás +húzat +húzgál +húzkod +húzódik +húzódozik +húzós +húzogat +hüledezik +hüllő +hüllőbőr +hülye +hülyéskedés +hülyéskedik +hülyeség +hümget +hümmög +hüppög +hüvely +hüvelyk +hüvelykujj +hű +hűbérúri +hűhó +hűl +hűlt +hűs +hűség +hűséges +hűségeskü +hűsöl +hűt +hűtés +hűtlen +hűtlenség +hűtőház +hűtőszekrény +hűtővíz +hűvös +hűvösödik +hűvösség +hugenotta +huhogás +huj +hujjogatás +hulcsi +huligán +huligánbanda +hull +hulla +hullám +hullámgép +hullámhossz +hullámos +hullámoztat +hullámpala +hullámszerű +hullámtaraj +hullámtér +hullámverés +hullámvonal +hullámzás +hullámzik +hulladék +hulladékfa +hulladékgyűjtő +hulladéktelep +hullafolt +hullajt +hullaszag +hullaszürke +hullatánc +hulldogál +hullott +humán +humánus +humanista +humanizmus +humor +humorizál +humoros +hun +huncut +huncutkodik +huncutság +hungarizálás +huny +hunyorgás +hunyorít +hunyorítás +hunyorog +hunyt +huppan +huppanós +hurcol +hurcolász +hurcolkodik +hurka +hurkatöltő +hurkol +hurok +hurrázik +husika +huszár +huszárarc +huszárszázad +huszártiszti +huszadik +huszadikai +huszita +huszonegy +huszonegyedik +huszonhárom +huszonharmadik +huszonhat +huszonhatodik +huszonhét +huszonhetedik +huszonkét +huszonkettedik +huszonkettedikei +huszonkettes +huszonkettő +huszonkilenc +huszonkilencedik +huszonnégy +huszonnégy-negyvenöt +huszonnégyezer +huszonnegyedik +huszonnyolc +huszonnyolcadik +huszonöt +huszonöt-harminc +huszonöt-negyvenöt +huszonötezer +huszonötödik +huszonötös +huzakodás +huzakodik +huzal +huzalka +huzamos +huzat +huzatos +huzatú +huzavona +huzigál +ibolya +ibolyakölni +ibusz-csoport +ibusz-út +icipici +idáig +ide +ide-oda +idén +idétlen +idéz +idézés +idézet +idézettöredék +idéző +idézőjeles +idea +ideál +ideális +ideáll +ideát +idead +idealista +idealizmus +ideapplikál +idebenn +ideér +ideérkezik +ideerőltet +idefigyel +ideg +idegbaj +idegborzoló +idegcsillapító +idegélet +idegen +idegenföldi +idegenforgalom +idegenkedés +idegenkedik +idegenség +idegenszerű +idegenvezető +ideges +ideges-izmos +idegesít +idegeskedés +idegeskedik +idegesség +idegfeszítő +idegfeszültség +ideggyógyász +ideggyógyászat +ideggyógyászati +idegi +idegkimerülés +idegláz +idegölő +idegösszeomlás +idegok +idegorvos +idegosztály +idegrendszer +idegrendszer-átültetés +idegrendszeri +idegroham +idegspecialista +idegszál +idegszanatórium +idegvégződés +idegzet +idehallatszik +idehallgat +idehallik +idehangzik +idehaza +idehelyez +idehív +idehord +idehoz +idei +ideír +ideig-óráig +ideiglenes +ideiktat +idejár +idején +idejegyez +idejekorán +idejön +idekészít +idekerül +idekinn +ideköltözés +ideköltözik +idekúszik +ideküld +ideküldet +idelátogat +idelátszik +idemegy +idenéz +ideológia +ideológus +idepiroslik +idepofátlankodik +iderohan +ideszámít +ideszabadul +ideszorul +ideszúr +idetalál +idetartozás +idetelepedik +idetesz +ideül +ideutazik +idevaló +idevalósi +idevesz +idillikus +idióta +idő +időhatár +időhúzás +időjárás +időköz +időközben +időlopás +időnként +időntúli +időpont +időrabló +időrend +idős +idősödik +időszámításunk +időszak +időszakos +időszerű +időtartam +időtlen +időtöltés +időutas +idővel +időveszteség +időzik +idomít +idomítás +idomtalan +idus +ifi +ifiasszony +ifibajnokság +ificsoport +ifiúr +ifjonc +ifjú +ifjúi +ifjúkor +ifjúkori +ifjúmunkás +ifjúság +ifjúsági +iga +igásállat +igásló +igaz +igazában +igazából +igazán +igazgat +igazgatás +igazgató +igazgatóék +igazgatóhelyettes +igazgatói +igazgatóné +igazgatónő +igazgatóság +igazgatósági +igazi +igazít +igazlátó +igazodás +igazodik +igazol +igazolás +igazoltat +igazoltatás +igazolvány +igazság +igazságos +igazságszolgáltatás +igazságtalan +igazságtalanság +igazságügyi +igaztalan +igazvadász +ige +igény +igénybevétel +igényel +igénylő +igénytelen +igénytelenség +igényű +igézet +igéző +igehirdető +igen +igen-igen +igencsak +igenel +igenis +igenlő +igric +igyekezet +igyekezik +ihaja +iható +ihlet +ihletett +ihol +ijed +ijedelem +ijedezik +ijedség +ijedt +ijedtében +ijedtség +ijeszt +ijesztés +ijesztget +ijesztő +iker +ikerlány +ikertestvér +ikon +ikrás +iksz +iksz-lábú +iktat +illat +illat-manöken +illatatom +illatfelhő +illatfolt +illathatás +illatos +illatosít +illatozik +illatrészecske +illatszer +illatszercég +illatszeres +illatú +illedelmes +illeg +illegális +illegalitás +illeget +illem +illemhely +illemtudó +illendő +illendőség +illeszkedik +illeszt +illesztget +illet +illetékes +illetéktelen +illetlen +illetlenség +illető +illetőleg +illetőségű +illetve +illír-kelta +illik +illóolaj +illő +illőképpen +illúzió +illusztráció +illusztrál +illusztris +ily +ilyen +ilyenfajta +ilyenféle +ilyenforma +ilyenformán +ilyenképpen +ilyenkor +ilyesfajta +ilyesféle +ilyesféleképpen +ilyesmi +ilyesvalami +ilyképpen +ima +imád +imádás +imádat +imádkozás +imádkozik +imádság +imágó +imaház +imakönyv +imaszíj +imaszövegféle +imazsák +imbolygás +imbolyog +imént +iménti +imitt-amott +immár +immúnis +imperátor +imperialista +imperializmus +imponál +imponáló +importál +impotens +impozáns +impresszió +impresszionista +impulzus +inas +inasiskola +inaskodik +inaszakadt +incidens +inda +indít +indítás +indíték +indítható +indító +indítógomb +indítókar +indítvány +indítványoz +indián +indiáner +indiánordítás +indiai +indigó +indikál +indiszkréció +indiszponált +indok +indoklás +indokol +indokolás +indokolatlan +indokolt +indokroham +indul +indulás +indulási +indulat +indulathullám +indulatos +indulatosság +indulatú +induló +infantilis +infarktus +infláció +influenza +influenzajárvány +információ +információháló +információs +informál +infrahang +infrapisztoly +infrastruktúra +infúzió +ing +ing-leng +inga +ingázik +ingázó +ingadozik +ingat +ingatag +ingatlankezelő +ingblúz +inger +ingerel +ingerkedik +ingerlés +ingerlő +ingerület +ingerült +ingerültség +inges +inggallér +inggomb +ingóság +ingoványos +ingujj +ingváll +ingyen +ingyenes +ingyengabona-osztás +ingyengabona-törvény +ingyensírhelyes +injekció +inkább +inkasszó +inkognitó +inkvizíció +inkvizíciós +inkvizítor +innen +innen-onnan +innenső +innivaló +inspekciós +int +intarzia +intés +intéz +intézés +intézet +intézeti +intézkedés +intézkedik +intézmény +intézményesít +intéző +integet +integetés +intelem +intellektuális +intellektualitás +intellektualizmus +intelligenciájú +intelligens +intenció +intenzív +intenzitás +interjú +interjú-módszer +interjúalany +intermezzo +internál +internáló +internet +interurbán +intim +intimitás +intő +intonáció +intrika +intuíció +intuitív +invázió +invenció +invitál +ionoszféra +ipar +iparág +iparági +iparcikkáruda +iparcikkbolt +iparengedély +iparfejlesztés +ipari +iparkodik +iparművészi +iparos +iparosítás +iparosmester +iparszerű +ipicsapacs +ipse +iránt +iránta +iránti +irány +irányadó +irányít +irányítás +irányítási +irányítgat +irányító +irányítórakéta +irányigazítás +irányoz +iránytű +irányú +irányul +irányulás +irányváltás +irányváltoztatás +irányvonal +irányzat +irányzék +iram +iramodás +iramodik +iramú +irat +iratcsomó +iratkozik +irattárca +irattartó +irdatlan +irgalmas +irgalmasság +irgalmatlan +irgalmatlanság +irgalmaz +irgalom +irha +irigy +irigyel +irigykedés +irigykedik +irigység +irinyó-pirinyó +irkál +irónia +iroda +irodaépület +irodaház +irodai +irodakisasszony +irodalmi +irodalmias +irodalom +irodalomkedvelő +irodalomtörténeti +irodaszemélyzet +irodavezető +irodista +irogat +iromány +ironikus +irt +irtó +irtózat +irtózatos +irtózik +irtóztat +is +isa +iskola +iskolás +iskolázott +iskolaépítés +iskolai +iskolaigazgató +iskolakerülés +iskolanap +iskolapénz +iskolatárs +iskolatársi +iskolatáska +ismét +ismétel +ismételget +ismételt +ismétlés +ismétlődik +ismer +ismerés +ismeret +ismeretanyag +ismeretes +ismeretlen +ismeretség +ismeretségi +ismeretszerzés +ismeretterjesztő +ismerkedés +ismerkedik +ismerő +ismerős +ismert +ismertet +ismertetés +ismertetőjel +ispán +istálló +istállóajtó +istállótulajdonos +istápol +istápolatlan +isten +isten-báránya +istenáldotta +istenasszony +istenbizony +istencsodája +istenfélő +istengömb +istenhivő +isteni +istenít +istenítés +istenigazában +istenigazából +istenkáromlás +istenkáromló +istenke +istenkereső +istenmadár +istennő +istenség +istentagadás +istentelen +istentisztelet +istenülés +istenverte +istenvitéz +iszákos +iszákosság +iszamós +iszap +iszapháború +iszapláva +iszaplepény +iszapolás +iszapos +iszapvezeték +iszik +iszogat +iszony +iszonyat +iszonyatos +iszonyodik +iszonytató +iszonyú +itáliai +ital +italbolt +italínyencség +italos +italozás +itat +itatás +itató +itt +itt-ott +ittas +itteni +itthagy +itthon +itthoni +ittlevő +ittmarad +iváni +ivás +ivadék +ivó +ivócimbora +ivópult +izé +izél +izélget +izeg-mozog +izgága +izgalmas +izgalom +izgat +izgató +izgatott +izgatottság +izgi +izgul +izmos +izom +izomcsomócska +izomláz +izommunka +izommutogató +izompacsirta +izomzat +izotóp +izraelita +izület +izületű +izzás +izzad +izzadság +izzadságfolt +izzadságszag +izzadságszagú +izzadt +izzít +izzik +izzó +ígér +ígéret +ígéretes +ígérget +ígérkezik +ígérő +így +így-úgy +íj +íjas +íjverseny +íme +ímmel-ámmal +ín +íny +ínycsiklandozó +ínyencfalat +ínyencség +ínyű +ír +ír-olvas +írás +írásjel +írásos +írástudó +írat +íratlan +írható +írisz +írnok +írnoki +író +író-fejedelem +író-olvasó +íróasztal +íródeák +írógép +írógép-zakatolás +írói +írós +írószer +írogat +ítél +ítélet +ítélethirdetés +ítéletű +ítélkezés +ítélkezik +ítélőképesség +ítélőszék +ív +ível +ívelés +ívelt +ívhosszúság +ívlámpa +ívszerű +ívű +íz +ízben +ízelt +ízeltlábú +ízes +ízes-magyaros +ízetlenség +ízig-vérig +ízlés +ízléses +ízléstelen +ízlésű +ízlel +ízlelget +ízletes +ízlik +ízű +ja +jácint +jámbor +jámborság +jánosáldás +jánoshegyi +jánus-szobor +jár +jár-kel +járás +járási +járásmód +járású +járadék +járat +járatlan +járatos +járatú +járda +járdaszegély +járdasziget +járdasziget-trükk +járgány +járhatatlan +járható +járkál +járkálás +jármű +járműváltás +járnivaló +járóföld +járóképtelen +járókelő +járőr +járogat +járszalag +járt +járta +jártányi +jártas +jártasság +jártató +járul +járulék +járulékos +járvány +jászol +játék +játékcica +játékkatona +játékmozdony +játékos +játékostárs +játékszabály +játékszer +játszadozik +játszik +játszma +játszódik +játszónap +játszónő +játszópajtás +játszótárs +játszótér +játszótéri +játszva +jabranc +jaguár +jaj +jajdul +jajgat +jajgatás +jajkiáltás +jajong +jajongás +jajszó +jajveszékel +jajveszékelés +jakobinus +január +januári +japán +japánujjú +jasszlegény +java +javában +javadalmaz +javak +javakorabeli +javall +javarészt +javasasszony +javaslat +javasol +javcsis +javít +javítás +javítgat +javítóintézet +javítóintézeti +javítós +javíttat +javul +jé +jég +jégcsap +jégdarab +jégeralsó +jégeralsós +jégeső +jéghideg +jéghintó +jéghokizik +jégkocka +jégkorong-szurkoló +jégkorongozó +jégkrém +jégoszlop +jégszekrény +jégtükör +jégverés +jégvirágos +jérce +jércetojásnyi +jézus +jézusisten +jézusmária +jézusom +jegenye +jegenyefa +jegenyefasor +jegenyesor +jeges +jegesmedve +jegy +jegyajándék +jegyellenőrző +jegyes +jegyesség +jegyez +jegyezget +jegygyűrű +jegypénztár +jegytelen +jegyzék +jegyzet +jegyzetblokk +jegyzetel +jegyzettömb +jegyző +jegyzőfüzet +jegyzőkönyv +jegyzőkönyvnyi +jegyzőkönyvvezetőnő +jehovista +jel +jeladás +jelen +jelenés +jelenet +jelenlét +jelenleg +jelenlegi +jelenlevő +jelenség +jelent +jelentékeny +jelentéktelen +jelentés +jelentésféle +jelentéstétel +jelentéstelen +jelentéstömb +jelentenivaló +jelentget +jelentkezés +jelentkezik +jelentkező +jelentő +jelentős +jelentőség +jelentőségteljes +jelentőségű +jeles +jelez +jelfogó +jelige +jelkép +jelképes +jelképesség +jelképez +jelképkutatás +jelképszerű +jelleg +jellegtelen +jellegű +jellegzetes +jellegzetesség +jellem +jellembeli +jellemerő +jellemez +jellemezget +jellemvonás +jellemző +jelmez +jelmondat +jelöl +jelölt +jelöltet +jelszó +jeltelen +jelvény +jelzálog +jelzés +jelzésű +jelzett +jelző +jelzőfény +jelzőharang +jelzőkészülék +jelzőrendszer +jelzőszám +jelzőszó +jelzőtábla +jelzőzászló +jerke +jeruzsálemi +jó +jóakarat +jóakaratú +jóakaró +jóarcú +jóbarát +jócselekedet +jócskán +jódszagú +jóéjszakát +jóérzés +jóember +jóféle +jófejű +jófiú +jóformán +jógázik +jóhiszemű +jóhiszeműség +jóízű +jóindulat +jóindulatú +jóisten +jóképű +jókedélyű +jókedv +jókedvű +jókívánság +jókor +jókora +jól +jól-rosszul +jólélek +jólét +jólelkű +jólelkűség +jólesik +jóleső +jóllakat +jóllakik +jóllakott +jóllakottság +jóllehet +jólnevelt +jómód +jómódú +jónapot +jónapotozik +jópofa +jóravaló +jórész +jórészt +jós +jóság +jóságos +jóslat +jósnő +jósol +jósoltat +jószág +jószágállomány +jószágcsereberélés +jószágtenyésztés +jószántából +jószagú +jószerencse +jószerint +jószerivel +jószívű +jószívűség +jótáll +jótanács +jótartású +jótékony +jótékonysági +jótét +jótett +jótevő +jóváhagy +jóváhagyás +jóvátétel +jóvátehetetlen +jóvátesz +jóval +jóvoltából +józan +józanít +józanodik +józanság +józsefvárosi +jöhető +jön +jön-megy +jött +jötte +jöttment +jövés-menés +jövedelem +jövedelmez +jövedelmező +jövendöl +jövendölés +jövendő +jövendőbeli +jövesztés +jövet +jövetel +jövevény +jövevényszó +jövő +jövőjű +jövőre +jobb +jobbágy +jobbára +jobbadán +jobban +jobbegyenes +jobbfajta +jobbösszekötő +jobboldal +jobboldali +jobbra-balra +jobbrafordulás +jobbulás +jog +jogász +jogar +jogegyenlőség +jogerő +jogfosztás +jogi +jogos +jogosít +jogosítvány +jogosság +jogosulatlan +jogosultság +jogsi +jogszabály +jogszokás +jogtalan +jogtalanság +jogtanácsos +jogtudós +jogtudomány +jogtudor +jogú +jonatán +jottányi +joviális +július +júliusi +június +júniusi +jubileum +jubileumi +jugoszláv +juh +juhász +juhászat +juhar +juhartermés +juhnyáj +juj +jurista +jut +jutányos +jutalék +jutalmaz +jutalom +juttat +juttatási +kába +kábel +kábít +kábítószer +kábítószeres +kábulat +kábult +kád +kádas +káder +káderszállás +káderutánpótlási +kállay-kormány +kálvária +kálvinista +kályha +kályhaajtó +kámzsa +kámzsás +kánai +kánikula +kápolna +káposzta +káposztás +káposztáshordó +káposztacsík +káposztafej +káposztalé +káposztalepke +káposztatábla +káposztatorzsa +káprázat +káprázik +kápráztató +kár +kárérték +kárhozat +kárhozik +káricsolás +kárminszájú +káröröm +kárörvendés +kárörvendezik +kárörvendő +károg +károgás +káromkodás +káromkodik +káromlás +káros +kárpitos +kárpitosmester +kárpitoz +kárpótlás +kárpótol +kártékony +kártérítés +kártevő +kártya +kártyás +kártyázás +kártyázgat +kártyázik +kártyatrükk +kátrány +kátránybetű +kátránylemez +kátránypapír +kátránypapíros +kátrányszagú +kátyú +kávé +kávébarna +kávécska +kávédaráló +kávéfőző +kávéfőzőgép +kávéház +kávéházi +kávémasina +kávésbögre +kávéscsésze +kávéskannácska +kávézik +kávézó +kabát +kabátgallér +kabátgomb +kabáthajtóka +kabátos +kabátszárny +kabáttalanodás +kabáttorony +kabátujj +kabátzseb +kabaré +kabasólyom +kabin +kabinos +kacag +kacagás +kacaj +kacarászik +kacat +kaccant +kacér +kacérkodik +kacérság +kackiás +kacsa +kacsázik +kacsahang +kacsaláb +kacsingat +kacsint +kacskaringó +kacskaringós +kacsó +kafeditó +kafferbivaly-hajtás +kaftán +kagyló +kagylóformájú +kagylófoteles +kagylóhéj +kagylóhintó +kagylóhosszabbító +kagylós +kaja +kaján +kajak +kajakozik +kajakversenyző +kajla +kajszibarack +kaka +kakál +kakaó +kakas +kakaskodik +kakaskukorékolás +kakasszó +kakastaraj +kakastollas +kakecos +kaktusz +kaktuszdália +kalács +kalácska +kaland +kalandornő +kalandos +kalandozik +kalandsorozat +kalandvágyó +kalap +kalapács +kalapácsnyi +kalapál +kalaplengetés +kalaplevéve +kalapos +kalauz +kalauz-egyenruha +kalauzkabát +kalauznő +kalauzol +kalauztáska +kaleidoszkóp +kaliba +kaliber +kaliberű +kalimpál +kalitka +kalkulál +kallantyú +kalligrafál +kallódik +kalmár +kalmárság +kalmopyrin +kalmük +kalózélet +kalocsai +kaloda +kamasz +kamasz-képzet +kamaszgyerek +kamaszkor +kamaszölelés +kamaszodik +kamaszos +kamaszos-bizalmas +kamaszvigyor +kamat +kamatmentes +kamatoztat +kambodzsai +kamera +kampány +kampánylelkű +kampec +kampó +kampósbot +kamra +kamraajtó +kamzsi +kamzsinyél +kan +kanál +kanális +kanálka +kanálnyi +kanári +kanárimadár +kanászcsalád +kanászkodik +kanadai +kanalas +kanalasgém +kanalaz +kanalazás +kanalazgat +kanapé +kanca +kancacsikó +kancellár +kancellária +kancellista +kancellistaszoba +kancsalít +kancsi +kancsó +kandalló +kandeláber +kandi +kandít +kandidál +kandidátus +kandidátusi +kandidatúra +kankós +kanna +kannibál +kanóc +kanonok +kanonokarckép +kanonoki +kantár +kantalupdinnye +kantin +kanyar +kanyargó +kanyargós +kanyarít +kanyarodik +kanyarodó +kanyarog +kanyarulat +kap +kapa +kapál +kapálás +kapálódzik +kapás +kapacitál +kapacitálható +kapacitás +kapafog +kapanyél +kapar +kaparás +kaparász +kaparászás +kapargál +kapargat +kaparint +kapaszkodik +kapaszkodó +kapaszkodóvas +kapatos +kapavágás +kapavágásnyi +kapca +kapcsán +kapcsol +kapcsolás +kapcsolat +kapcsolatfelvétel +kapcsolatos +kapcsoló +kapcsolódik +kapdos +kapható +kapirgál +kapiskál +kapitális +kapitány +kapitalista +kapitalizmus +kapituláció +kapitulál +kapitulálás +kapkod +kapni +kapó +kapós +kapocs +kapricpárna +kaptár +kaptafa +kapu +kapualj +kapubejárat +kapubolt +kapufa +kapufélfa +kapuhíd +kapukilincs +kapunyitás +kapunyitó +kapuőrség +kapuoszlop +kapus +kapusfráter +kapuügyelet +kapuzárás +kapzsi +kapzsiság +kar +kar-láb +karácsony +karácsonyeste +karácsonyfa +karácsonyfaégős +karácsonyi +karám +karabély +karaj +karakán +karakter +karakterjegy +karalábétábla +karambol +karambolozik +karaván +karbantart +karbantartás +karbantartási +karbantartó +karbid +karbidfény +karburátor +karcol +karcolás +karcsú +karcsúság +kard +kardbojt +kardigán +kardinális +kardiológus +kardos +kardvágás +karéj +karéjnyi +karfa +karfás +karhatalom +karhossznyi +karicsál +karika +karikás +karikagyűrű +karikalábú +karizom +karlendítés +karmantyú +karmazsinvörös +karmocska +karmos +karmozdulat +karnagy +karnevál +karnyújtásnyi +karó +karóra +karórás +karol +karom +karonfogva +karos +karosszék +karosszériájú +karpaszományos +karperec +karrier +karrierista +karriervágy +karszalagos +karsztos +kartárs +kartársnő +kartávolságnyi +karter +karton +kartonlap +kartonlapocska +kartonruha +kartonszerű +karú +karvastagságú +karzat +karzati +kas +kasa +kaska +kasmír +kassai +kassza +kasszírnő +kastély +kasza +kaszál +kaszálatlan +kaszáló +kaszáltat +kaszárnya +kaszárnyaszerű +kaszárnyatömb +kaszanyél +kaszavágás +kaszavágásnyi +kaszinó +kaszinótag +kaszt +katángkóró +kataklizma +katakomba +katalán +katalizátor +katapultterem +katasztrófa +katasztrófaszerű +katéterezés +katedra +katedrális +katedrálüveg +kategória +katlan +katódcső +katolikus +katona +katonás +katonásdi +katonáskodik +katonaarisztokrácia +katonabajtárs +katonacimbora +katonaélet +katonafénykép +katonafeleség +katonahumor +katonai +katonaidő +katonainduló +katonaing +katonakar +katonaköpeny +katonalány +katonalélek +katonaság +katonaszökevény +katonatárs +katonatiszt +katonatiszti +katonavicc +katonavonat +katonazene +katonazenekar +katonazubbony +kattan +kattanás +kattint +kattog +kavar +kavargás +kavargat +kavarodás +kavarog +kaviár +kaviáros +kaviárosdoboz +kavics +kavicsos +kazán +kazánajtó +kazánház +kazánkovács +kazal +kazetta +kégli +kéj +kéjes +kéjnő +kéjvágy +kék +kék-fehér +kék-zöld +kékcsíkos +kékes +kékesfehér +kékesfekete +kékesszürke +kékesszürkés +kékeszöld +kéklik +kékmintás +kékség +kékzubbonyos +kém +kémény +kéményes +kéményfüst +kéménylyuk +kémelhárítás +kémelhárító +kémelhárító-tiszt +kémiai +kémkedik +kémlel +kémnő +kénes +kénköves +kénsav +kénszínű +kénye-kedve +kényelem +kényelmes +kényelmeskedés +kényelmetlen +kényelmetlenség +kényelmi +kényes +kényeskedik +kényeztet +kényeztetési +kényszer +kényszercsevegés +kényszeredett +kényszeregyezség +kényszerháború +kényszerhelyzet +kényszerít +kényszerítő +kényszerképzet +kényszermosoly +kényszermunka +kényszermunkás +kényszerül +kényszerű +kényszerűség +kényszerzubbony +kénytelen +kénytelen-kelletlen +kényúr +kép +kép-isten +képadás +képernyő +képernyő-térkép +képernyős +képes +képesít +képesítés +képeskönyv +képeslap +képesség +képességű +képest +képez +képfelvevő +képfolyam +képgyűjtemény +képhangadó +képírómester +képkeret +képkeretező +képkísérő +képlékeny +képleadás +képlet +képletes +képmás +képmező +képmutatás +képmutató +képsor +képtelen +képtelenség +képű +képvisel +képviselet +képviselő +képviselő-testület +képviselőjelölt +képzés +képzel +képzelem +képzelet +képzeletbeli +képzeletfelhő +képzeletszülte +képzeletzavaró +képzelgés +képzelődés +képzelődik +képzelőerő +képzet +képzettség +képzettségű +képző +képződik +képződmény +képzőművész +képzőművészeti +kér +kérd +kérdés +kérdéses +kérdészuhatag +kérdez +kérdezés +kérdezetlen +kérdezett +kérdezget +kérdeznivaló +kérdező +kérdezősködés +kérdezősködik +kérdő +kérdőív +kérdőjel +kérés +kéredzkedik +kéreg +kéregető +kérelem +kérem +kéret +kéretlen +kérges +kéricsgél +kérkedik +kérlek +kérlel +kérlelhetetlen +kérlelő +kérő +kérő-mosolygó +kérődzik +kérvény +kés +kés-villa +késés +késedelem +kései +késik +késlekedik +késleltet +késnyél +késő +később +későbbi +későn +kész +készakarva +készenlét +készenléti +készít +készítés +készítmény +készíttet +készlet +készpénz +készség +készséges +késztet +készül +készülék +készülő +készülődés +készülődik +készültség +két +két-három +két-háromszáz +két-két +kétágú +kétágyas +kétarcú +kétbalkezes +kétcentis +kétcsúcsú +kétdecis +kétéltű +kétértelmű +kétértelműség +kétévenként +kétéves +kétévi +kételkedés +kételkedik +kétell +kétely +kétemeletes +kétes +kétesztendei +kétezer +kétezer-egyszáz +kétezer-egyszázas +kétezer-hatvan +kétezer-kétszáz +kétezer-százharmincnyolc +kétezer-tizedik +kétezerötszáz +kétezredik +kétfázisú +kétféle +kétféleképpen +kétfelé +kétforintos +kétharmad +kéthetenként +kéthetes +kétkedés +kétkedik +kétkerekű +kétkezi +kétkilós +kétkötetes +kétlábú +kétlépcsős +kétméteres +kétnaponként +kétnapos +kétnyelvű +kétórás +kétoldali +kétoldalra +kétoldalt +kétoldalú +kétrét +kétség +kétségbeejt +kétségbeejtő +kétségbeesés +kétségbeesett +kétségbeesik +kétségbevonhatatlan +kétséges +kétségkívül +kétségtelen +kétségtelenül +kétsoros +kétszárnyas +kétszárnyú +kétszáz +kétszáz-kétszázötven +kétszázéves +kétszázhatvan +kétszázhúsz +kétszázhuszonkét +kétszáznyolc +kétszázötven +kétszemélyes +kétszeres +kétszeri +kétszersült +kétszersültadag +kétszínű +kétszobás +kéttizedes +kétujjas +kéve +kéz +kézbentartó +kézbesítő +kézcsók +kézelő +kézenfekvő +kézenfogva +kézfej +kézfogás +kézi +kézírás +kézírásos +kézifegyver +kézigránát +kézikönyvtár +kézilabdázik +kézimunka +kézimunkázik +kézimunkaóra +kézirat +kézirosta +kézitáska +kézjegy +kézlenyomós +kézmosás +kézmozdulat +kézműves +kézmunka +kézrázás +kézről-kézre +kézujj +kézzel-lábbal +kézzelfogható +kebel +kebelbeli +keblű +kecsegtet +kecses +kecske +kecskebőr +kecskeláb +kecskelábú +kecskeméti +kecskerágó +kedd +keddi +kedély +kedélybeteg +kedélyes +kedélyeskedik +kedélyfenntartó +kedélykiegyenlítési +kedélytelen +kedélytelenség +kedélyű +kedélyváltozás +kedv +kedvderítő +kedvel +kedvelt +kedvenc +kedves +kedveske +kedveskedik +kedvesség +kedvetlen +kedvetlenség +kedvezmény +kedvező +kedvezőtlen +kedvtelés +kedvtelve +kedvű +kefe +kefél +kefebajusz +kefefrizura +kegy +kegydíj +kegyed +kegyelem +kegyelemdöfés +kegyelemteljes +kegyelet +kegyeletes +kegyelmed +kegyelmes +kegyelmez +kegyes +kegyeskedik +kegyesség +kegyességed +kegyetlen +kegyetlenkedik +kegyetlenség +kegyvesztés +kehely +kehes +kehhent +keksz +kel +kelés +kelengye +kelengyekészítés +kelepce +kelepel +kelet +kelet-európai +kelet-római +keleti +keleties +keletkezik +keletnémet +keletrómai +keletű +kelevény +kelevéz +kelkáposzta +kell +kellék +kellemes +kellemesség +kellemetes +kellemetlen +kellemetlenség +kellet +kellete +kelletlen +kelletlenség +kelletlenségérzés +kellő +kellős +kelmefestő +kelt +keltezésű +kelyhes +kemény +keményfa +keményfedelű +keménygallér +keményít +keményített +keményítő +keménykalap +keménykötésű +keménypapír +keménység +keménységű +keményszívűség +keménytojás +kemping +kempingasztal +kempingnadrág +ken +kend +kender +kenderáztatás +kenderáztató +kenderpozdorjalemez +kendő +kendős +keneget +kenet +kenetes +kenetesdoboz +kenetlen +kenetteljes +kengyel +kengyelvas +kenyér +kenyérdagasztás +kenyérhéj +kenyérkereset +kenyérládás +kenyérlepény +kenyérmaradvány +kenyérpirítás +kenyérpirító +kenyérszelet +kenyérszeletke +kenyérzsák +kenyereslány +kenyerespajtás +kerámia +keramikus +keramitkocka +kerék +kerékgyártó +kerékkötő +keréknyom +kerékpár +kerékpárlánc +kerékpáros +kerékpározik +kerékpártartó +kerékvágás +kerékvető +kerékvetőkő +kerek +kerekecske +kerekedik +kerekes +kerekít +kerekség +kerekű +kereng +kerepel +keres +keresés +kereset +kereseti +keresetlenség +keresetű +keresgél +keresgélés +kereskedelem +kereskedelmi +kereskedik +kereskedő +kereskedőember +kereskedősegéd +keresnivaló +kereső +kerestet +kereszt +keresztanya +keresztapa +keresztbe +keresztbe-hosszába +keresztbe-kasba +keresztbefektet +keresztben +keresztben-hosszában +keresztcsíkos +keresztcsont +keresztény +keresztényi +kereszténység +keresztel +keresztelő +keresztez +kereszteződés +keresztfa +keresztfiú +keresztfolyosó +keresztgyerek +keresztmetszet +keresztnév +keresztnevű +keresztpánt +keresztránc +keresztrejtvény +keresztség +keresztszülő +kereszttűz +keresztút +keresztül +keresztül-kasul +keresztülballag +keresztülfolyik +keresztülfon +keresztülfut +keresztülgázol +keresztülhalad +keresztülhúz +keresztüljön +keresztüllyukaszt +keresztülmegy +keresztülnéz +keresztülszánt +keresztülszel +keresztülszúr +keresztülüt +keresztülvág +keresztülver +keresztülvezet +keresztülvisz +keresztülzúdul +keresztutca +keresztvas +keresztvíz +keret +keretez +keretű +kerge +kergekóros +kerget +kergetőzik +kerít +kerítés +kerítésbástya +kerítésdrót +kerítésléc +kering +keringél +keringő +kert +kertajtó +kertész +kertészet +kertészeti +kertészkedés +kertészkedik +kertel +kertelés +kertes +kertfal +kerthelyiség +kerti +kertkapu +kertkultúra +kerül +kerület +kerületi +kerületparancsnok +kerületparancsnokság +kerülget +kerülgetés +kerülő +kerülőút +kerubalak +kese +keselyű +keselyűcsapat +keserédes +kesereg +kesergés +kesergő +keserít +kesernyés +keserű +keserű-szomorú +keserűség +keserv +keserves +keskeny +keskenyedik +keszeg +keszonszerű +keszthelyi +kesztyű +kesztyűs +kesztyűtartó +ketrec +kettéhasít +kettéoszt +kettéosztottság +kettészakad +kettészakít +kettészel +kettétör +kettétörik +kettévág +kettéválás +kettéválaszt +kettéválik +kettes +kettes-hármas +kettő +kettő-három +kettőhat +kettős +kettősség +kettőszázkilencvenkilenc +kettőszáznyolc +ketyeg +ketyegés +kevély +kevélység +kevés +kevésbé +kevéske +kevéssé +kever +keverék +keverés +keveredés +keveredik +keverget +kevert +kevesell +kezd +kezdés +kezdeményez +kezdeményezés +kezdeményező +kezdet +kezdeti +kezdetleges +kezdő +kezdőbetű +kezdődik +kezdve +keze-lába +kezel +kezelés +kezelési +kezelőorvos +kezelőszemélyzet +kezeltet +kezeslábas +kezicsókolom +kezű +khaki +ki +ki-be +ki-ki +ki-kifröccsen +ki-kihagy +ki-kijön +ki-kilépeget +ki-kimozdul +ki-kinéz +ki-kiránt +ki-kitöröl +kígyó +kígyóméreg +kígyószáj +kígyószerű +kígyózik +kíl +kímél +kímélet +kíméletes +kíméletlen +kíméletlenség +kín +kínál +kínálás +kínálgat +kínálkozik +kínai +kínaisárkány-repedés +kínhalál +kínlódás +kínlódik +kínos +kínos-keserves +kínosság +kínoz +kínozgat +kínoztat +kínszenvedés +kínzás +kínzó +kísér +kíséret +kísérget +kísérlet +kísérletezik +kísérleti +kísérő +kísért +kísértés +kísértet +kísérteties +kíván +kívánalom +kívánatos +kíváncsi +kíváncsiság +kíváncsiskodik +kívánkozás +kívánkozik +kívánság +kívánt +kívántat +kívül +kívül-belül +kívüle +kívüleső +kívüli +kiábrándít +kiábrándul +kiábrándulás +kiábrándult +kiágaskodik +kiáll +kiállás +kiállású +kiállhatatlan +kiállít +kiállítás +kiállítási +kiállító +kiállíttat +kiált +kiáltás +kiáltásváltás +kiáltható +kiáltó +kiáltoz +kiáltozás +kiáltvány +kiárad +kiáramlik +kiáraszt +kiárusít +kiárusítás +kiás +kiáztat +kiabál +kiabálás +kiabálhatnék +kiad +kiadás +kiadható +kiadó +kiadós +kiadvány +kiaggat +kiagyal +kiakaszt +kiaknáz +kialakít +kialakítás +kialakul +kialszik +kiapadhatatlan +kiaszik +kib +kib-história +kibámul +kibányász +kibabrál +kiballag +kibékül +kibélel +kibérel +kibelez +kibernerosz +kibernerosz-história +kibernetika +kibernetikai +kibernetikus +kibeszél +kibeszélget +kibetűz +kibír +kibírhatatlan +kibírható +kibic +kibicel +kibiciklizik +kibillen +kibiztosít +kiböjtöl +kibök +kiböngész +kibővít +kibocsát +kibombáz +kibombázás +kibomlik +kibont +kibontakozás +kibontakozik +kiborít +kiborogat +kiborotvál +kiborul +kibotorkál +kibújik +kibújtat +kibúvó +kibuggyan +kibugyog +kibukik +kibukkan +kicibál +kicipel +kicirkalmaz +kicsal +kicsap +kicsapódik +kicsapongás +kicsapongó +kicsattan +kicsavar +kicsendül +kicserél +kicserélődés +kicsi +kicsírázik +kicsihol +kicsikar +kicsike +kicsikét +kicsinál +kicsiny +kicsinyég +kicsinyes +kicsinyeskedik +kicsinyesség +kicsinyít +kicsinylő +kicsinység +kicsipeget +kicsit +kicsoda +kicsomagol +kicsordul +kicsorog +kicsoszog +kicsúfol +kicsúszik +kicsüng +kicsusszan +kidagad +kidekorálás +kiderít +kiderítetlen +kideríthetetlen +kiderül +kidöglik +kidönt +kidörgöl +kidörzsöl +kidől +kidob +kidobál +kidohányoz +kidolgoz +kidolgozott +kidomborodik +kidribliz +kidühöng +kidülled +kidug +kiég +kiégett +kiéhezett +kiéhezik +kiélesedik +kiélesít +kiélez +kiéleződés +kiélt +kiélvez +kiépít +kiépül +kiér +kiérdemel +kiérez +kiérkezik +kiérzik +kiérződik +kiegészít +kiegészítés +kiegészítő +kiegészül +kiegyenesedik +kiegyenesít +kiegyengetés +kiegyenlít +kiegyensúlyoz +kiegyensúlyozatlan +kiegyensúlyozott +kiegyensúlyozottság +kiejt +kiejtés +kielégít +kielégítés +kielégíthetetlen +kielégíthető +kielégítő +kielégítődik +kielégülés +kielégülésnyugalom +kielégületlen +kiemel +kiemelés +kiemelkedik +kiemelkedő +kienged +kiengesztel +kiereszt +kierőszakol +kies +kiesés +kiesik +kieszel +kietlen +kievickél +kifárad +kifáraszt +kifacsar +kifaggat +kifagy +kifakad +kifakadás +kifarag +kiféle-miféle +kifényesedik +kifényesít +kifényesül +kifér +kifésül +kifehéredik +kifejez +kifejezés +kifejezésmód +kifejezéstelen +kifejezett +kifejező +kifejleszt +kifejlődik +kifejt +kifejtetlen +kifekszik +kifelé +kifelejt +kifeslik +kifest +kifestet +kifeszít +kifeszül +kifiguráz +kifigyel +kifinomul +kifizet +kifizető +kifli +kiflimaradék +kifőz +kifog +kifogás +kifogásol +kifogástalan +kifogy +kifogyhatatlan +kifolyat +kifolyik +kifolyólag +kifordít +kifordul +kiforgat +kiformál +kiforráz +kiforratlan +kifoszt +kifúj +kifúr +kifüggeszt +kifürkész +kifürkészhetetlen +kifüstöl +kifűrészel +kifűz +kifullad +kifut +kifutó +kifutópálya +kigaloppozik +kigömbölyödik +kigördül +kigőzölgés +kigombol +kigondol +kigúnyol +kigurul +kigyógyul +kigyötrődik +kigyúl +kigyullad +kihámoz +kihány +kihátrál +kihagy +kihagyás +kihajít +kihajlik +kihajol +kihajt +kihajtogat +kihal +kihalász +kihallatszik +kihallgat +kihallgatás +kihallgatóterem +kihallgatott +kihalt +kiharcol +kihasad +kihasít +kihasznál +kihasználás +kihasználatlan +kihasználódik +kihat +kihatású +kihegyez +kihever +kihevül +kihímez +kihív +kihívó +kihízlal +kihirdet +kihirdetés +kihord +kihoz +kihozat +kihúz +kihűl +kihűlés +kihull +kihuny +kihunyás +kihurcol +kiír +kiigazít +kiigazodik +kiindul +kiindulási +kiindulópont +kiiratkozik +kiirt +kiirtat +kiismer +kiismerhetetlen +kiismerhető +kiiszamodik +kiiszik +kiizzad +kijár +kijárási +kijárat +kijárati +kijátszik +kijavít +kijavítható +kijegyez +kijelent +kijelentés +kijelentőlap +kijelöl +kijózanodik +kijön +kijövet +kijut +kikászálódik +kikandikál +kikanyarodik +kikap +kikapar +kikapaszkodik +kikapcsol +kikapcsolódás +kikapkod +kikémlel +kikényszerít +kiképez +kiképzés +kiképzési +kiképzett +kiképző +kiképzőtiszt +kikér +kikérdez +kikérő +kikészít +kikészítés +kikészül +kikefél +kikel +kikeményít +kikerekedik +kikeres +kikerget +kikerül +kikerülés +kikerülget +kikerülhetetlen +kikerülhető +kikeveredik +kikezd +kikísér +kikísérletez +kikiált +kikiáltás +kikiabál +kiköltözik +kikönyököl +kikönyörög +kiköp +kiköt +kikötés +kikötöz +kikötő +kikötőforgalom +kikötői +kikötőstég +kikövetkeztet +kiközösít +kikocsikázik +kikocsizik +kikopik +kikopogtat +kikortyol +kikosaraz +kikotol +kikotor +kikristályosodik +kiküld +kiküszöböl +kiküszöbölhető +kiküzd +kikukkant +kikukucskál +kikunyerál +kilábal +kilát +kilátás +kilátástalan +kilátástalanság +kilátó +kilátóablak +kilátóhely +kilátszik +kilakkoz +kilép +kilépés +kilét +kilehel +kilenc +kilenc-tíz +kilenc-tizenegy +kilencéves +kilencedik +kilences +kilenclyukú +kilencmilliméteres +kilencszáz +kilencszázhuszonegyes +kilencszáznegyven +kilencszáznegyvenöt +kilencszáznegyvenötös +kilencszázötven +kilenctized +kilencven +kilencvenegy +kilencvenes +kilencvenkettő +kilencvenkilenc +kilencvennégy +kilencvennégyes +kilencvennyolc +kilencvenöt +kilencvenöt-száz +kilencvenötös +kiles +kileskel +kilibben +kilincs +kilincsel +kilincselés +kiló +kilócska +kilódít +kilóg +kilógat +kilós +kilök +kilökdös +kilökődik +kilötyögtetés +kilő +kiloccsan +kilométer +kilométeres +kilométerkő +kilométernyi +kilop +kilottyan +kilovagol +kilowattos +kilyukad +kilyukaszt +kimásolás +kimászik +kimagaslik +kimagasló +kimagasodik +kimagyaráz +kimagyarázkodik +kimar +kimarad +kimaradozás +kimarkol +kimélyít +kimér +kiméreget +kimért +kimegy +kimenekül +kimenet +kimenetelű +kimeneti +kimenő +kiment +kimered +kimereget +kimereszt +kimerít +kimeríthetetlen +kimerítő +kimerül +kimerült +kimerültség +kimetsz +kimond +kimondás +kimondat +kimondatlan +kimondhatatlan +kimondott +kimonó +kimos +kimozdul +kimozgat +kimúlik +kiművel +kiművelés +kimulat +kimunkál +kimutat +kimutatás +kimutatható +kincs +kincsesláda +kincstár +kincstári +kinéz +kinézésű +kinevet +kinevez +kinevezés +kinn +kinnfelejt +kinő +kinti +kinyaklik +kinyal +kinyílik +kinyír +kinyiffantás +kinyiladozik +kinyilatkoztat +kinyilatkoztatás +kinyilvánít +kinyit +kinyithatatlan +kinyitható +kinyög +kinyom +kinyomat +kinyomoz +kinyomtat +kinyomul +kinyújt +kinyújtózik +kinyújtóztat +kinyúl +kinyúlik +kiöblít +kiöblösödik +kiömlik +kiönt +kiöntés +kiöntő +kiöregedik +kiokád +kiokosít +kiokoskodik +kioktat +kioktatás +kioktató +kiold +kioldódik +kioldozgat +kiollóz +kiolt +kiolvas +kioperál +kioson +kioszk +kioszt +kipárolgás +kipadoz +kipakol +kipattan +kipeckel +kipenderít +kipereg +kipihen +kipihent +kipillant +kipingál +kipirul +kipislant +kipiszkál +kipofoz +kipofoztat +kiporol +kipotyog +kiprésel +kipreparál +kipróbál +kipróbálás +kipúderoz +kipucol +kipufogó +kipufogócső +kipufogógáz +kipuhatol +kipuhatol-tapogat +kipukkan +kipusztít +kipusztul +kipusztulás +király +királyasszony +királydinnye +királyfi +királyi +királyka +királykondor +királyné +királynéi +királynő +királynői +királyság +királysági +királytigris +királyválasztó +kirámol +kirándul +kirándulás +kirándulóhely +kirángat +kiránt +kiráz +kirabol +kiragad +kirajzol +kirajzolódik +kirajzszegez +kirak +kirakat +kirakatablak +kirakatbaba +kirakodik +kirakodóvásár +kirekeszt +kirendel +kirendeltség +kirepül +kirepülés +kirívó +kiröhög +kiröppen +kirobban +kirobbanás +kirobbanható +kirobbant +kirohan +kiront +kirostál +kirothad +kirothaszt +kirúg +kirúgat +kirúgatási +kiruccanás +kiruházkodik +kirukkol +kis +kiságy +kisárgul +kisázsiai +kisablak +kisajátít +kisajtó +kisangyal +kisanya +kisapa +kisasszony +kisasztal +kisbaba +kisbalta +kisbirtokos +kiscsirke +kisded +kisdiák +kisétál +kisebb-nagyobb +kisebbedik +kisebbfajta +kisebbít +kisebbrendű +kisebbség +kisebbségi +kisebesedik +kisegít +kisegítő +kiselőadás +kisember +kiserked +kiserken +kisesti +kisfia +kisfiú +kisfiús +kisfröccs +kisgazda +kisgazdapárt +kisgazdapárti +kisgyerek +kisgyerekkor +kisgyermek +kisír +kisiet +kisiklás +kisiklik +kisilabizál +kisimít +kisimul +kisipari +kisiparosi +kiskabát +kiskanál +kiskanna +kiskapu +kiskatona +kiskereskedő +kiskörzet +kiskörzeti +kiskoma +kiskosár +kiskutya +kislámpa +kislány +kislánykor +kislánykori +kislányos +kisliba +kismacska +kisméretű +kismester +kismiska +kisnemes +kisnyilas +kisöcs +kisöpör +kisöreg +kisodor +kisodródik +kisomfordál +kispárna +kispad +kispajtás +kisparaszt +kisparaszti +kisparasztság +kispekulál +kispesti +kispohár +kispolgár +kispolgári +kisportolt +kissé +kisszoba +kistányér +kisteknő +kistermetű +kistestvér +kistisztviselő +kistőkés +kistükör +kisújszállási +kisúr +kisül +kisüsti +kisüt +kisüzem +kisugárzás +kisugárzik +kisuhan +kisujj +kisurran +kisuvikszol +kisváros +kisvárosi +kisvártatva +kisvacsora +kisvasút +kisvasutazik +kisvendéglő +kisvonat +kiszáll +kiszállás +kiszámít +kiszámíthatatlan +kiszámítható +kiszámol +kiszárad +kiszab +kiszabás +kiszabadít +kiszabadul +kiszaggat +kiszagol +kiszakad +kiszakít +kiszakítás +kiszalad +kiszaladgál +kiszélesedik +kiszélesít +kiszélesítés +kiszed +kiszedeget +kiszedhető +kiszekál +kiszellőztet +kiszemel +kiszenved +kiszerel +kiszív +kiszikkad +kiszikkasztás +kiszimatolás +kiszista +kiszivárgás +kiszivárog +kiszivattyúz +kiszól +kiszólás +kiszór +kiszögez +kiszökik +kiszolgál +kiszolgálás +kiszolgáló +kiszolgálónő +kiszolgáltat +kiszolgáltatás +kiszolgáltatott +kiszolgáltatottság +kiszorít +kiszorítás +kiszorul +kiszorulás +kiszúr +kiszűr +kiszűrődik +kiszusszant +kitágít +kitágul +kitálal +kitámaszt +kitámogat +kitámolyog +kitár +kitárt +kitárul +kitárulkozás +kitárulkozik +kitát +kitakar +kitakarít +kitakarózik +kitalál +kitaníttat +kitanul +kitanulmányoz +kitapasztal +kitapétáz +kitapint +kitapogat +kitapos +kitart +kitartás +kitartó +kitép +kitér +kitérés +kitérít +kitérő +kiteker +kitekerődzik +kitekint +kitelepít +kitelepítés +kitelik +kiteljesedés +kiteljesít +kitenyészt +kiterebélyesedik +kitereget +kiterelget +kiterít +kiterítkezik +kiterjed +kiterjedésű +kiterjeszkedik +kiterjeszt +kitermelhető +kitervel +kitervez +kitervező +kitessékel +kitesz +kitilt +kitipeg +kitisztít +kitisztíttatás +kitisztul +kitódul +kitölt +kitöm +kitör +kitörés +kitörik +kitöröl +kitörölhetetlen +kitörő +kitörőfélben +kitol +kitolás +kitolakodik +kitold +kitolódik +kitoloncol +kitoloncoltat +kitüntet +kitüntetés +kitüntetéses +kitüntetett +kitüntető +kitűnik +kitűnő +kitűnőség +kitűz +kiújul +kiúszik +kiút +kiügyeskedik +kiül +kiültet +kiüresedik +kiürít +kiüríttet +kiürül +kiüt +kiütés +kiütközik +kiüzen +kiűz +kiugrat +kiugrik +kiugró +kiutál +kiutal +kiutalás +kiutasít +kiutasítás +kiutazik +kivág +kivágás +kivágat +kivágódik +kivágott +kivágtat +kiváj +kiválaszt +kiválasztás +kiválasztódás +kiválasztott +kiválasztottság +kiválik +kiváló +kiválóság +kiválogat +kivált +kiváltképpen +kiváltság +kiváltságos +kivándorlás +kivándorló +kivándorol +kivánszorog +kivár +kivackolódik +kivagdal +kivagyiság +kivakar +kivall +kivan +kivarr +kivasal +kivasalt +kivéd +kivédhetetlen +kivégez +kivégeztet +kivégzés +kivénhedt +kivétel +kivételes +kivételez +kivéve +kivehetetlen +kivehető +kiver +kiverődik +kivesz +kivet +kivetett +kivetít +kivetkőztet +kivetnivaló +kivezet +kivív +kivibrál +kivicsorít +kivihetetlen +kivilágít +kivilágítatlan +kiviláglik +kivilágosodik +kivillamosozik +kivillan +kivillant +kivillog +kivirágzik +kivirrad +kivirul +kivirulás +kivisz +kivitel +kivitelezés +kivitelező +kiviteli +kivitelű +kivitet +kivizsgál +kivörösödik +kivon +kivonat +kivonatozik +kivontat +kivonul +kivonulás +kizár +kizárás +kizárásos +kizárólag +kizárólagos +kizárt +kizakatol +kizökken +kizökkent +kizöldül +kizötyög +kizsákmányol +kizsákmányolás +kizsarol +kizsebel +kizsuppol +kizúdul +kizuhan +kizuhog +klapka-induló +klassz +klasszicista +klasszikus +klastrom +klaviatúra +klerikális +klienskirály +klienskirályság +klikk +klimaxos +klinika +klinikai +klór +klottnadrágos +klozett +klub +klubtárs +klubterem +kóbor +kóborlás +kóborló +kóborog +kóborol +kócmadzag +kócol +kócos +kódex +kókadt +kókusz +kónuszos +kópé +kór +kórház +kórházbarakk +kórházépület +kórházfelszerelés +kórházi +kóringyál +kórisme +kórképző +kórlefolyás +kóró +kórókerítés +kórószáraz +kórokozó +kóros +kórterem +kórtermi +kórus +kóser +kóstol +kóstolgat +kóstoló +kószál +kószálás +kótyagos +kótyavetye +kóvályog +köbdeciméter +köblös +köbméter +köcsög +köcsögfa +köcsögkészítő +köd +ködfolt +ködfoltocska +ködgomoly +ködhullám +ködkacskaringózta +ködmön +ködmönös +ködös +ködszagú +ködszerű +ködzsák +ködzuhatag +köhécsel +köhint +köhög +köhögés +köhögéscsillapító +kökény +kölcsön +kölcsönad +kölcsönhatás +kölcsönkap +kölcsönkér +kölcsönlakás +kölcsönös +kölcsönöz +kölcsönvesz +köldöknyílás +köldökzsinór +köleskása +kölni +kölniillat +kölnisüveg +kölniszag +kölnivíz +költ +költészet +költekező +költemény +költöget +költözés +költözik +költöztetés +költő +költő-filozófus +költő-lét +költői +költőpénz +költség +költséges +költségvetés +kölyök +kölyökcsapat +kölyökkor +köménymag +köménymagos +könny +könnycsepp +könnyebbség +könnyed +könnyedén +könnyedség +könnyelmű +könnyelműség +könnyen +könnyes +könnyezik +könnyít +könnytelen +könnyű +könnyűfém +könnyűség +könnyűsúlyú +könnyűszerrel +köntös +könyök +könyökhajlat +könyöklő +könyököl +könyöradomány +könyörgés +könyörög +könyörtelen +könyörület +könyv +könyvbarát +könyvcím +könyvecske +könyvel +könyvelés +könyvelő +könyvelőnő +könyvelőség +könyves +könyvespavilon +könyvespolc +könyvkereskedés +könyvkiadó +könyvkötő +könyvpiac +könyvszekrény +könyvtár +könyvtáros +könyvtárszoba +könyvügynök +könyvvitel +köp +köpcös +köpdös +köpés +köpésnyi +köpeny +köpenyes +köpenygomb +köpköd +köpködés +köpönyegű +kör +körbe +körbeáll +körbefog +körbefordul +körbefut +körbehord +körbeint +körbejár +körbekacsázik +körbekerget +körbekínál +körbelakik +körbemutat +körben +körbenéz +körbenézeget +körbepillant +körberak +körberohan +körbesétál +körbeszaglász +körbeszalad +körbeszar +körbeül +köré +körébe +köréje +körfésű +körfolyosó +körforgás +körgát +körhintás +körít +körítés +körív +körlet +körletvezető +körlevél +körmenet +körmödzik +körmöl +körmondat +körmű +környék +környékbeli +környékez +környéki +környezet +környezettanulmány +környezetváltozás +környező +köröm +körömcipő +körömlakk +körömpassz +körönd +körös-körül +körötte +köröz +körözés +körözvény +körorvos +körpálya +körséta +körte +körtebefőtt +körtefa +körút +körúti +körül +körüláll +körülárkol +körülbámészkodik +körülbelül +körülcsavar +körüldong +körülevez +körülfog +körülfolyik +körülfon +körülfut +körülgyűrűz +körülhatárol +körülhatárolható +körülhatároltság +körülhordoz +körüli +körülír +körüljár +körüljártat +körülkémlel +körülkerít +körülkoszorúz +körülleng +körülles +körülmagyaráz +körülmény +körülményes +körülmosolyog +körülmutat +körülnéz +körülölel +körülötte +körülötte-fölötte +körülözönlik +körülpárnáz +körülpillant +körülpólyáz +körülrajzol +körülrak +körülrekeszt +körülsétál +körülszaglász +körülszagol +körültámaszt +körültáncol +körültapogat +körülteker +körültekint +körültekintés +körültekintő +körülül +körüludvarol +körülugrál +körülvesz +körülvezet +körülzár +körű +körutazás +körvonal +körzet +körzeti +kösz +köszön +köszönés +köszönésféle +köszönet +köszönget +köszönő +köszönőember +köszönőlevél +köszönt +köszöntés +köszörül +köszvény +köt +kötél +kötélpálya +kötéltánc +kötéltáncos +kötény +kötényes +kötényke +kötényzseb +kötés +köteg +kötekedik +kötekedő +kötelék +kötelem +köteles +kötelesség +kötelez +kötelezettség +kötelező +kötet +kötetlen +kötetlenség +kötetnyi +kötött +kötöttfogású +kötöttség +kötöz +kötözés +kötözködés +kötözködik +kötözött +kötöző +kötözőhely +kötőanyag +kötődés +kötődik +kötőfék +kötszer +kötvény +kövér +kövérke +kövérkés +kövérszerű +kövérzöld +köves +kövesút +követ +követés +követel +követelés +követelmény +követelődzés +követelődzik +követhető +követi +következésképpen +következetes +következetesség +következetlen +következetlenség +következik +következmény +következményű +következő +következőképpen +következtében +következtet +következtetés +követő +követség +követségi +kövezet +kövezetlen +kövidinka +kövül +kövület +köz +közbe +közbeavatkozik +közbeeső +közbegáncsol +közbejön +közbelép +közbelépés +közbemordul +közben +közbenjár +közbenjárás +közbenjáró +közberikkant +közbeszól +közbeszúr +közbeszurkál +közbevág +közbevet +közbizalom +közé +közéje +közélet +közéleti +közép +középember +középen +középgomb +középiskola +középiskolás +középiskolai +középkezdés +középkor +középkori +középkorú +középosztály +középparaszt +középparaszti +középpont +középponti +középrerántás +középső +középtáj +középtermetű +középület +középütt +közérdeklődés +közérdekű +közért +közérthető +közérzés +közérzet +közeg +közegészségügyi +közegellenállás +közel +közelálló +közelebbről +közeledés +közeledik +közeledte +közeleg +közelharc +közeli +közelít +közellátási +közellakó +közelmúlt +közelség +közember +közepes +közepette +közepű +közerő +közfigyelem +közgazdász +közgazdasági +közgazdaságtan +közgazdaságtudomány +közgyűlés +közhasználat +közhasználatú +közhasznú +közhely +közhír +közhit +közhivatal +közhivatalnok +közízlés +közibe +közibecsap +közigazgatási +közintézmény +közismert +közkatona +közkeletű +közkincs +közkórház +közlator +közlékeny +közlés +közlésvágy +közlegény +közlekedés +közlekedési +közlekedésrendészet +közlekedik +közlemény +közlendő +közmegelégedés +közmondásos +közmű +közművesít +közmulatság +köznap +köznapi +köznyelv +közöl +közölnivaló +közömbös +közömbösít +közömbösség +közönség +közönséges +közöny +közönyös +közönyösség +közös +közösség +közösségi +közösülés +között +közötti +közoktatásügyi +közpark +központ +központbeli +központi +közread +közrecsíp +közrefog +közrejátszik +közreműködés +közreműködik +közrend +közreszorít +közröhej +község +községháza +községi +közszáj +közszabadság +közszükségleti +köztársaság +köztársasági +közte +köztér +köztermészetű +közti +köztisztelet +köztörvényes +köztudomású +közúti +közügyvéd +közül +közüle +közüzemi +közvélemény +közvéleményalakító +közveszélyes +közvetett +közvetít +közvetítés +közvetítő +közvetlen +közvetlenkedik +közvetlenség +közvetve +közvilágítás +kő +kőábrázat +kőakna +kőangyal +kőbánya +kőbányász +kőbányai +kőbalta +kőbolygó +kődarab +kődézsa +kődobálás +kődobásnyi +kőfal +kőfaragás +kőfaragó +kőfej +kőfűrész +kőgörgeteg +kőház +kőhajításnyi +kőhalmaz +kőhalom +kőhasáb +kőhegyű +kőírási +kőkemény +kőkocka +kőkút +kőlap +kőlépcső +kőműves +kőműves-bizalmi +kőművesbanda +kőnehezék +kőóriás +kőolajfúrási +kőoroszlán +kőoszlop +kőpáncél +kőpadló +kőpadozat +kőpart +kőpor +kőrakás +kőrengeteg +kőrises +kősír +kőszegi +kőszikla +kőszilánk +kőszörny +kőszobor +kőtaraj +kőtenger +kőtömb +kőtömeg +kőtörés +kőtojás +kőttes +kőút +kőzápor +kőzet +kőzetfelület +kőzetviszony +kőzúzalék +koalíció +koalíciós +kobak +koca +kocavisítás +koccan +koccanás +koccint +koccintás +kocka +kockás +kockázat +kockázatos +kockázik +kockázó +kockáztat +kockáztatás +kockacukor +kockakő +kocog +kocogtat +kocsány +kocsányápoló +kocsi +kocsiajtó +kocsibak +kocsifényező +kocsiforgalom +kocsigyár +kocsigyártó +kocsikázik +kocsikáztat +kocsikaraván +kocsikísérő +kocsimosás +kocsioldal +kocsirádió +kocsis +kocsisor +kocsiút +kocsma +kocsmáros +kocsmázik +kocsmaajtó +kocsmaféle +kocsmai +kocsmatöltelék +kocsmazaj +kocsonyás +kofa +kofa-kávéház +kofálkodás +koffer +kohézió +kohó +kohómérnök +koholt +kokott +kokszagiz +koktél +kolbász +kolbászkarika +koldul +koldulás +kolduló +koldus +koldus-senki +koldusasszony +koldusbarát +koleszterin-háztartás +kolk +kolléga +kolléganő +kollégista +kollégistatalálkozó +kollégium +kollégiumi +kollégiumos +kollegina +kollektív +kollektíva +kollektivista +kollektivizálás +kollerjáratos +kolónia-gömbhajó +kolomp +kolompszó +kolostor +kolozsvári +koma +komál +komámasszony +komáromi +kombináció +kombinációs +kombinál +kombinált +kombinatorika +kombiné +kombinérészlet +kombinés +komédia +komédiázás +komfortos +komikum +komikus +komisz +komiszkodik +komité +komló +komlói +komlóinda +kommandíroz +kommendál +kommentál +kommersz +kommün +kommunista +kommunizmus +komód +komoly +komolyodik +komolyság +komolytalan +komondor +komor +komornyik +komorság +komp +kompetencia +komplé +komplett +komplexum +komplikáció +komplikált +kompót +komposzttalaj +kompozíció +kompromisszum +kompromittál +komputer +koncentrációs +koncentrál +koncentrált +koncert +kondás +kondér +kondi +kondíció +kondoleál +kondor +kondul +kondulás +konfekció +konfekcióipar +konfekcióruha +konfliktus +konflis +konformizmus +konfúzió +konfúzus +kong +kongás +kongat +kongatás +kongó +kongói +kongresszus +konkrét +konkrétum +konkretizál +konkurrencia +konnektor +konok +konokság +konspiráció +konspirál +konspiratív +konstantinápolyi +konstruál +konstruktív +konstruktivista +konstruktivitás +kontár +kontárkodik +kontinens +kontinuitás +kontó +kontráz +kontraktus +kontraszelekciós +kontraszt +kontroll +kontrollál +konty +kontyos +konvenció +konvent +konventképviselő +konvoj +konyak +konyakocska +konyakos +konyakospohár +konyakosüveg +konyakozik +konyakrendelés +konyha +konyhaablak +konyhaajtó +konyhaasztal +konyhabeli +konyhafelszerelés +konyhai +konyhakés +konyhakert +konyhakredenc +konyhalány +konyhasó +konyhasóoldat +konyhaszék +konyhaszekrény +konyhaszemélyzet +konyít +konzekvencia +konzerv +konzerváció +konzervál +konzerválódás +konzervátor +konzervátori +konzervatív +konzervdoboz +konzervgyár +konzul +konzulválasztás +konzulviselt +kooperáció +koordinál +kopár +kopárzöld +kopás +kopasz +kopaszodik +kopaszos +kopaszság +kopaszt +kopasztás +kopik +kopisztol +koplalás +koplaló +kopó +kopog +kopogás +kopogós +kopogtat +kopogtatás +koponya +koponyájú +koponyaalkat +koponyacsont +koporsó +koporsókészítő +koporsós +kopott +kopottruhás +koppan +koppanás +koptat +kor +kora +korábbi +korán +korántsem +korát-múlta +korátlag +korabeli +koraérett +korai +koraöreg +korbács +korbácsol +korcol +korcsolya +korda +kordbársony +kordé +koreai +koreográfia +korhad +korhadozik +korhadt +korhatár +korhatag +korhelyleves +korhol +kori +kork +korkülönbség +korlát +korlátolt +korlátoltság +korlátoz +korlátozódik +korlátozott +kormány +kormánybiztosféle +kormányellenes +kormányférfi +kormánykerék +kormánynegyed +kormányospad +kormányoz +kormányoztat +kormányrendelet +kormányszerv +kormányzás +kormányzat +kormányzó +kormányzói +kormos +kornyadozik +kornyikál +kornyikálás +korog +korom +koromfekete +koromsötét +korona +koronás +koronáz +koronakérő +korong +koros +korosztály +korpa +korpás +korrekt +korrektor +korrektúra +korrepetálás +korrespondál +korrigál +korrigálás +korrigálhatatlan +korrumpál +korsó +korsós +korszak +korszakbeli +korszellem +korszerű +korszerűtlen +kortárs +korteher +korteskedik +korty +kortynyi +kortyol +kortyolgat +korú +korzó +korzóbetyár +korzózik +kos +kosár +kosárfonó +kosárka +kossuth-bányai +kossuth-díjas +kossuth-párti +kosz +koszlott +koszorú +koszos +koszt +kosztkamat +kosztol +kosztos +kosztüm +kosztümkabát +kosztümös +kotlik +kotlós +kotor +kotorászik +kotta +kottatartó +kotyog +kotyvalék +kotyvaszt +kovács +kovácsműhely +kovácsol +kovácsolt +kovácsoltvas +kovakő +kozák +kozáking +kozmetika +kozmetikál +kozmikus +kozmikussugár-gyűjtő +kozmopolitizmus +kozmosz +krá +krákog +kráter +kráterszerű +krajcár +krajnai +krapek +krapekol +krém +krémes +krémeskorszak +krémfagylalt +krémkereső +kréta +krétáz +kredenc +kredencfia +kreol +krepelicai +krepp +krízis +kricsmi +krigli +krikszkraksz +krimi +krinolinos +kripta +kriptanyomaték +kristály +kristálycukor +kristályforma +kristályos +kristályosodik +kristálypohár +kristályragyogású +kristályrendszer +kristálytiszta +kristályvíz +krisztus-ikon +krisztusi +kritérium +kritika +kritikai +kritikus +kritizál +krizantém +króm +krómoz +krónikás +krónikaíró +krőzusi +kroá +krokodil +krokodilpáncél +krokodilus +kromofág +kromoszóma +krumpli +krumpliorr +krumplisaláta +krumplisverem +krumpliszsák +ktsz-elnök +kúp +kúra +kúszik +kúszik-mászik +kúszónövény +kút +kútágas +kútgém +kútmély +kútvíz +küld +küldés +küldemény +küldetés +küldönc +küldött +küldöttség +küldözget +külföld +külföldi +külkapcsolat +külker +külkeres +külkereskedelmi +küllem +küllő +küllős +külön +külön-külön +külön-magyar +különállás +különálló +különb +különben +különbözik +különböző +különbözőség +különbség +különc +különcködés +különféle +különítmény +különítményes +különkiadás +különleges +különmunka +különös +különös-halk +különösen +különösképpen +különösség +különszám +különszenzáció +különszoba +különterem +különválás +különválik +külország +külországi +külpolitika +külpolitikai +külpolitikus +külsejű +külső +külsőség +külsőséges +kültelki +külterjes +külügyminiszter +külváros +külvárosi +külvilág +küraszír +küret +küret-téma +kürt +kürtöl +kürtös +kürtszó +küszködés +küszködik +küszöb +küzd +küzdelem +küzdelmes +küzdő +küzdőképesség +küzdőtér +kubikol +kubikolás +kubikos +kubikostárs +kuckó +kucorodik +kucorog +kucsma +kucsmás +kudarc +kuka +kukacoskodás +kukacoskodik +kukacosodás +kukacvirág +kukk +kukorékol +kukorica +kukoricás +kukoricacső +kukoricaföld +kukoricalevél +kukoricamorzsolás +kukoricaszem +kukoricatábla +kukoricatörés +kuksol +kukta +kukucskál +kukucskáló +kukucskalyuk +kulák +kulákfajta +kuláklista +kulákvilág +kulacs +kulcs +kulcscsomó +kulcscsont +kulcslyuk +kulcsol +kulcspozíció +kulcstömeg +kulissza +kullog +kultikus +kultivál +kultúra +kultúrbotrány +kultúrcsoport +kultúrdokumentum +kultúrélmény +kultúrember +kultúrfilm +kultúrforradalom +kultúrház +kultúrnép +kultúrnövény +kultúrpalota +kultúrsalak +kultúrterem +kultúrtörténet +kulturális +kulturált +kulturáltság +kultusz +kultuszépítő +kumulusz +kun +kuncog +kuncogás +kuncsaft +kuncsorog +kuncsorogtat +kunkorodik +kunsági +kunszentmártoni +kunyhó +kupa +kupac +kupak +kupaktanács +kupamérkőzés +kupé +kupec +kupeckedik +kupecparaszt +kupica +kupleráj +kupolás +kupolacsarnok +kuporodik +kuporog +kuporogta +kurjant +kurjantás +kurjongat +kurjongatás +kurrog +kurta +kurtán-furcsán +kurtít +kuruc +kurucos +kurva +kurvuci +kuss +kusza +kuszálék +kuszálódik +kuszált +kutat +kutatás +kutatási +kutató +kutatóberendezés +kutatócsoport +kutatóintézet +kutatóintézeti +kutatóorvos +kutatóosztály +kutatótevékenység +kutya +kutya-macska +kutyálkodás +kutyás +kutyabaj +kutyabőr +kutyafejű +kutyafüle +kutyagol +kutyaház +kutyaiskola +kutyapedigré +kutyapofa +kutyapofájú +kutyaszán +kutyaszorító +kutyavalag +kvantummechanika +kvarc +kvarclámpa +kvóta +la +láb +lábad +lábadozik +lábadozó +lábas +lábasjószág +lábatlankodik +lábbeli +lábdobogás +lábfej +lábfürdő +lábizom +lábmozgás +lábmunka +lábnyi +lábnyom +lábszár +lábszárcsont +lábtenisz +lábtörlő +lábú +lábujj +lábujjhegy +lábujjköz +lábvíz +lábzsámoly +láda +ládácska +ládahalom +ládika +ládikó +láger +lágerlakó +lágernyelv +lágerszínház +lágy +lágykezű +lágymányosi +lágyság +lágyszívű +lágytojás +lám +lámcsak +lámpa +lámpácska +lámpás +lámpabél +lámpabűz +lámpafény +lámpaláz +lámpaoltás +lámpasor +lámpasugár +lámpatest +lámpaüveg +lánc +láncdarab +lánchíd +lánchinta +lánckereskedő +láncol +láncolat +láncszem +lánctalpas +lándzsa +láng +lángcsóva +lángész +lángözön +lángol +lángolás +lángoló +lángos +lángú +lángvégű +lány +lánygimnázium +lányhang +lányiskola +lányka +lánykérés +lánykórus +lánykor +lánykori +lánynév +lányos +lánypajtás +lánytükör +láp +lárifári +lárma +lármás +lármázik +lárva +lárvaarcú +lárvahéj +lát +látás +látási +látatlan +látcső +láthatár +láthatatlan +látható +látkép +látlelet +látnivaló +látnok +látóhatár +látókörű +látómező +látogat +látogatás +látogatási +látogató +látomány +látomás +látott +látszat +látszatember +látszateredmény +látszik +látszó +látszódik +látszólag +látszólagos +látta +láttamoztat +láttat +látvány +látvány-élmény +látványos +látványosság +láva +lávakitörés +láz +lázálom +lázad +lázadás +lázadó +lázas +lázít +lázong +lázongó +lázroham +labanc +labda +labdacs +labdarúgó +labirintus +labor +laborálás +laboráns +laboránslány +laboratórium +laboratóriumfőnök +laboratóriumi +laboratóriumterem +lacikonyha +lacikonyhás +ladik +ladikos +lagzi +laikus +lajstrom +lajstromoz +lajtos +lak +lakályos +lakályosság +lakás +lakásadó +lakásajtó +lakásdúlás +lakáshivatal +lakáshivatal-vezető +lakáskérdés +lakáskérelmező +lakásosztály +lakásromboló +lakásszentelő +lakásszűke +lakásügy +lakat +lakatféle +lakatlan +lakatos +lakatoslegény +lakatosműhely +lakbér +lakbérhátralék +lakcím +lakhatatlan +lakható +lakhely +lakik +lakkos +lakkoz +lakktopános +lakmározik +lakó +lakóbizottsági +lakóház +lakóhely +lakókocsi +lakónegyed +lakószoba +lakótárs +lakótelep +lakodalmas +lakodalmi +lakodalom +lakoma +lakos +lakosság +lakosú +lakosztály +lakott +lakozik +laktanya +laktanyaudvar +laktatós +lampion +langy +langyos +langyosság +lanka +lankás +lankadt +lant +lantos +lantszarvú +lap +lapály +lapát +lapátkéz +lapátnyi +lapátol +lapátolás +lapátos +lapít +lapidáris +lapkiadó +lapkonszern +lapocka +lapocska +lapos +laposfejű +lapostányér +lapoz +lapozás +lapozgat +lappang +lappangás +lapul +lapulás +lassacskán +lassan +lassanként +lassít +lassítás +lassú +lassúság +lassul +lasztex +lasztexnadrág +lat +latin +latolgat +latolgatás +lator +latrina +latrinadeszka +latyak +latyakos +lavírozik +lavór +laza +lazac +lazaság +lazít +le +le-föl +le-lecsukódik +le-leles +lé +léc +léckerítés +lég +légáramlás +légáramlat +légajtó +légcsőhurut +légelhárító +léggömb +léghajó +légi +légies +légiflotta +légifolyosó +légikisasszony +légió +légipoggyász +légiriadó +légitámadás +légitársaság +légköbméter +légkör +légköri +légkörű +légkondicionáló +légkondicionált +légmentes +légmozgás +légnyomás +légnyomás-differencia +légópince +légószolgálat +légörvény +légoltalmi +légpárna +légpárnás +légszomj +légtornász +légvonal +légy +légycsapó +légyraj +légyszaros +légzés +légzésű +légzsilip +léha +lékel +lélegzés +lélegzet +lélegzetelállító +lélegzetszakító +lélegzetvétel +lélegzetvételnyi +lélegzik +lélek +lélekbúvár +lélekféleség +lélekharang +lélekszakadva +lélektan +lélektani +lélektelen +lélekváltás +lélekveszedelem +lélekvesztő +léniáz +lény +lényeg +lényegében +lényeges +lényegileg +lényegtelen +lép +lépcső +lépcsőfeljáró +lépcsőfok +lépcsőforduló +lépcsőház +lépcsőházi +lépcsős +lépcsőzetes +lépdel +lépés +lépésnyi +lépeget +lépfene +lépked +lépte +léptek +lépten-nyomon +léptet +léptű +lépzúzódás +lét +létbizonytalanság +létérdek +létére +létesít +létesítés +létesítmény +létesül +létezés +létezik +létfeltétel +létfenntartás +létfontosság +léthajnal +létjogosultság +létkérdés +létminimum +létra +létrácska +létrafok +létraszerű +létrehoz +létrejön +létszám +létszámigénylés +létszámú +létszemlélet +lézeng +lézer +lézerrendszer +leáldozik +leáll +leállít +leány +leányálom +leányalak +leányfej +leánygyermek +leányholttest +leányiskola +leányismerős +leányka +leánykérő +leánykori +leányzó +leás +lead +leadás +leakaszt +lealázás +lealacsonyít +lealszik +learat +lebámul +leballag +lebarnul +lebben +lebbenés +lebbenéstelen +lebélyegez +lebecsül +lebecsülés +lebeg +lebegés +lebegő +lebegtet +lebeszél +lebetonoz +lebiggyed +lebilincselő +lebillen +lebőgés +lebocsát +lebombáz +lebombázás +lebont +lebontás +lebontat +lebonyolít +lebonyolítás +lebonyolódik +leborít +leborul +lebotorkál +lebújik +lebüntet +lebukás +lebukfencezik +lebukik +lebuktat +lebzsel +lecke +leckéztet +leckéztetés +lecövekel +lecsap +lecsapolás +lecsatol +lecsavar +lecsendesedik +lecsíp +lecsillapít +lecsillapodik +lecsitul +lecsószag +lecsordul +lecsorog +lecsúszik +lecsúszott +lecsúsztat +lecsuk +lecsukódik +lecsurran +lediktál +ledöf +ledöglik +ledönt +ledörzsöl +ledörzsölés +ledől +ledob +ledoktorál +ledolgozik +ledurrant +leég +leéget +leél +leépítés +leér +leérettségizik +leegyszerűsít +leegyszerűsödik +leejt +leellenőriz +leemel +leendő +leenged +leereszkedik +leereszkedő +leereszt +leesik +leevez +lefarag +lefékez +lefényképez +lefegyverez +lefejez +lefejt +lefejtés +lefekszik +lefektet +lefekvés +lefelé +lefest +leffeg +leffen +lefittyed +lefittyen +lefitymál +lefizet +lefölöz +lefog +lefogad +lefogat +lefoglal +lefogy +lefokoz +lefolyás +lefolyik +lefolyó +lefolytat +lefonnyaszt +lefordít +lefordítás +leforgás +leforráz +lefoszlik +lefotóz +lefröcsköl +lefúj +lefüggönyöz +lefülel +lefűrészel +lefullad +lefut +lefutás +legáció +legális +legázol +legalább +legalábbis +legalizál +legalja +legény +legényember +legényes +legényke +legénykedik +legénykor +legénység +legénységi +legépel +legel +legelész +legeleje +legelő +legelőgazdálkodás +legeltet +legeltetés +legeltetési +legenda +legendás +legendaszövő +legfeljebb +legjava +legközelebb +legömbölyít +legöngyöl +legörbül +legördít +legördül +legombol +legott +leguggol +legurul +legutóbb +legutóbbi +legyengül +legyeskedik +legyez +legyező +legyezőforma +legyilkol +legyilkoltat +legyint +legyintés +legyőz +legyőzés +legyőzhetetlen +legyőzött +legyűr +legyűrhetetlen +lehánt +lehántolódik +lehagy +lehajigál +lehajlás +lehajlik +lehajol +lehajt +lehalász +lehalkít +lehalkul +lehallgat +lehallgató +lehamuz +lehangol +lehangolódik +lehangoltság +lehanyatlik +leharap +lehel +lehelet +lehelet-tányér +leheletnyi +leheletű +lehengerel +lehervad +lehet +lehetetlen +lehetetlenség +lehető +lehetőleg +lehetőség +lehetséges +leheveredik +lehint +lehord +lehorgad +lehorgaszt +lehorgonyoz +lehorzsol +lehoz +lehúz +lehúzkod +lehúzódik +lehűl +lehűlés +lehűt +lehugyoz +lehull +lehullat +lehullta +lehuny +lehuppan +lehurrog +leír +leírás +leírhatatlan +leigáz +leint +leirat +leiszik +leitat +lejár +lejárat +lejáró +lejárt +lejátszás +lejátszik +lejátszódik +lejattol +lejjebb +lejmol +lejön +lejt +lejtés +lejtésfok +lejtő +lejtős +lejtősödik +lejut +lekászálódik +lekanyarít +lekap +lekapcsol +lekaszál +lekattan +lekavarint +lekérés +lekéset +lekésik +lekerül +lekever +lekezel +lekísér +lekiált +lekiabál +leköltözik +leköp +leköpköd +leköszön +leköt +lekötelez +leközöl +lekonyul +lekopaszítás +lekopik +lekúszik +leküld +leküldet +leküzd +leküzdés +leküzdhetetlen +lekucorodik +lekuporodik +lekurváz +lekurvázás +lekushad +lekuttyogtat +lekvár +lekváros +lel +lelát +lelakatol +lelandol +lelappaszt +lelassít +lelassul +lelazít +lelécel +lelép +lelépeget +lelépked +leléptet +leledzik +lelegel +lelejmol +lelemény +leleményesség +lelenc +lelencházi +leleplez +lelepleződés +lelet +lelibeg +lelkész +lelkendez +lelkendezés +lelkes +lelkesedés +lelkesedik +lelkesít +lelkesül +lelkesült +lelki +lelki-alkati +lelki-szellemi +lelkiállapot +lelkiatya +lelkierő +lelkifurdalás +lelkigyakorlatszerű +lelkiismeret +lelkiismeret-furdalás +lelkiismeretes +lelkiismeretlen +lelkivilág +lelkület +lelkű +lelóg +lelógat +lelök +lelövés +lelövöldöz +lelő +lelohad +leltár +leltároz +lemásol +lemászik +lemarad +lemér +lemegy +lemerül +lemeszel +lemetél +lemez +lemezjátszó +lemezsorozat +lemeztelenít +lemond +lemondás +lemondó +lemorzsol +lemos +lemosakodik +lemosdat +lemosolygás +lemosolyog +lemutat +lencse +lencseleves +lendít +lendítget +lendül +lendülés +lendület +lendületes +lendületű +lenéz +lenézet +leng +lenge +lengés +lengedez +lenget +lengőajtó +lengyel +lenin-fiú +lenini +lenn +lenő +lenti +lenyal +lenyel +lenyergelés +lenyes +lenyír +lenyisszant +lenyom +lenyomogat +lenyomoz +lenyúl +lenyúz +lenyűgöz +lenyűgöző +leöblít +leöl +leöldöklés +leölet +leömlik +leönt +leolt +leolvad +leolvas +leolvasható +leomlik +leordít +leoszt +lep +lepakol +leparoláz +lepattan +lepattogzik +lepény +lepecsétel +lepedék +lepedő +lepedődarab +lepedőnyi +lepel +lepereg +lepihen +lepillant +lepislant +lepke +lepkészet +lepkekönnyű +lepkesúlyú +lepkeszárny +lepkevadászat +lepkevilág +leplez +leplezés +leplezetlen +leplezhető +lepöccent +lepődik +lepocskondiáz +leporol +leporolgat +lepottyan +leprás +leprafolt +lepratelep +leprésel +lepuffant +lerág +lerángat +leránt +leráz +leragad +lerajzol +lerak +lerakás +lerakódás +lerakódik +lerakodik +lerepül +lereszel +lerí +leró +leröppen +lerövidít +lerobban +lerobbant +lerogy +lerohan +lerokkan +lerombol +lerombolódik +leromlik +leroskad +leruccan +les +lesajnál +lesajnáló +lesétál +lesegít +lesekedik +leselkedés +leselkedik +leseprűz +leshely +lesimít +lesimítás +lesimogat +leskelődés +leskelődik +lesóz +lesöpör +lesodor +lesoványodik +lestoppol +lesújt +lesújtó +lesül +lesüt +lesz +leszáll +leszállás +leszállít +leszállítás +leszállóhely +leszállta +leszámít +leszámol +leszánkázik +leszármazott +leszázalékol +leszakad +leszakít +leszalad +leszalajt +leszar +leszavaz +leszed +leszeg +leszel +leszerel +leszereltet +leszerepel +leszerződik +leszív +leszid +leszivárgás +leszól +leszólít +leszór +leszögez +leszokik +leszoktat +leszorít +leszúr +leszűr +letáboroz +letárgyal +letagad +letaglóz +letakar +letakarít +letakarítatlan +letakarodás +letarol +letartóztat +letartóztatás +letartóztatási +letartóztatott +letaszít +letép +letéphető +letér +letérdel +letétel +letegez +letekerget +letekint +letelepedik +letelik +leteper +leterít +letesz +letipor +letisztít +letölt +letör +letördel +letörik +letörlés +letörleszt +letöröl +letörölhetetlen +letört +letocsog +letol +letompultság +letorkol +letottyan +letűr +leül +leülés +leülepedik +leültet +leüt +leugrál +leugrik +leutazik +levág +levágás +levágat +levágódik +levájkál +leválaszt +leválik +levált +leváltás +levackolódik +levakar +levél +levélarc +levélcenzor +levélhalom +levélírás +levélnyílás +levélszekrény +levéltáros +levénsüketez +levés +levegő +levegőellátás +levegőjű +levegőszekrény +levegőtlen +levegőzik +levelez +levelezés +levelezési +levelezget +levelező +levelezőlap +levelű +levendula +lever +leverés +levert +levertség +leves +levesestányér +levesestányérnyi +levestészta +levesz +levet +levetet +levetít +levetkőzés +levetkőzik +levetkőztet +levezet +levezetés +levezetődik +levízibuszozik +levisz +levitézlett +levon +levonul +lexikon +lexikonszerű +lezár +lezárás +lezárhatatlan +lezárul +lezajlik +lezavar +lezökken +lezser +lezúdul +lezüllik +lezuhan +lezuhanyozik +líra +lítium +liánköteg +liász +liba +libás +libabőrös +libacomb +libalegelő +libamájexportőr +libasor +libatömés +libazsíros +libben +libbenés +libeg +libegés +libegős +liberalizmus +licitálás +lidérc +lift +liftajtó +liftakna +liget +ligetes +ligeti +lignin +liheg +lihegés +likőr +likőrgyáros +likvidál +likvidálás +likvidálódik +lila +lila-szürke +lilás +liláskék +lilaság +liliom +liliomtiprás +liliputi +limlom +limonádé +link +linkóci +linóleum +liptói +lista +liszt +liszt-mű +lisztes +liszteszsák +litánia +litániaparafrázis +liter +literátor +literátus +ló +lóarcú +lóbál +lóbetű +lóca +lócsere +lócsiszár +lódenkabát +lódít +lódul +lófej +lófog +lófogatos +lófogú +lófuttatás +lóg +lógás +lógáz +lógat +lógerezés +lógó +lóhát +lóhere +lóistálló +lókereskedő +lókupec +lópata +lópatkó +lópofájú +lópokróc +lósóska +lószemű +lószerszám-fényesítő +lót-fut +lótás-futás +lótrágya +lótúró +lótuszvirág +lóvásár +lóvé +lóverseny +lóverseny-szaklap +lóversenytér +lóversenyújság-szerkesztő +lök +lökdös +lökdösés +lökdösődés +lökdösődik +lökés +lökésszerű +lökhajtásos +löttyen +löttyint +lötyköl +lötyög +lötyögős +lövés +lövész +lövészárok +lövészteknő +lövedék +löveg +lövegtorony +lövell +lövöldöz +lövöldözés +lövőtudomány +lő +lőárok +lődörög +lőfegyver +lőfegyverállás +lőpor +lőporos +lőre +lőrés +lőrésnyi +lőrinci +lőszer +lőszerellátás +lőszeres +lőszeresláda +lőtávol +lobban +lobbanékony +lobbant +lobog +lobogás +lobogó +lobogós +lobogtat +loboncos +lobos +loccsan +loccsant +loccsint +locskolás +locsog +locsogás +locsol +locsolás +locsolgat +locsolókanna +logika +logikátlan +logikai +logikus +lohad +lohol +loholás +loholó-lázas +lojális +lokál +loknis +lokomotív +lom +lomb +lombard +lombbolt +lombik +lombikélet +lombikember +lombikolás +lombikos +lombkoszorúzta +lombos +lombosodik +lomboz +lombú +lomha +lompos +lonc +loncsos +londoni +lop +lopás +lopakodik +lopótök +lopott +lopva +lottócédula +lottózik +lovász +lovacska +lovag +lovagi +lovagiasság +lovaglócsizma +lovaglólecke +lovagol +lovagoltatás +lovagrend +lovagtípus +lovagtörténet +lovardaszerű +lovas +lovascsoport +lovasember +lovaskocsi +lovasmenet +lovasrendőr +lovasroham +lovasság +lovassereg +lovasszázad +lovastiszt +lovasvezér +lúdbőrözik +lüktet +lüktetés +lubickol +lubickolás +lucerna +lucernás +lucskos +lucsok +ludas +ludovikás +lugas +lump +lumpen +lusta +lustálkodás +lustálkodik +lustaság +lutheránus +luxus +luxusadó +luxusétterem +luxusfrunzsi +lyuggat +lyuk +lyukablak +lyukacsos +lyukacsosodik +lyukas +ma +mágikus +máglya +mágnás +mágnásfertály +mágnes +mágneses +mágneskristály +máj +májbaj +májfolt +májgombóc +májszínű +májtömb +május +májusfa +májusi +májzúzódás +mák +mákony +mákos +mákszem +mállik +mállott +málna +málnás +málnáspohár +málnatöves +málnatő +mályva +mályvalila +mámor +mámorító +mámoros +mándli +mánia +mániákus +mániás +már +már-már +március +márciusi +máriás +máriaüveg +máris +márka +márkás +mármint +mármost +márpedig +márt +mártíromság +mártogat +márvány +márványasztal +márványasztalka +márványcsarnok +márványerezet +márványgolyó +márványkemény +márványlap +márványos +márványoszlop +márványsárga +márványszobor +márványtábla +márványtömb +más +más-más +mása +másfajta +másfél +másfél-kétórás +másféle +másfelé +másfelől +másforma +máshol +máshova +másítás +másik +másikfajta +másként +másképpen +máskor +máskülönben +másmilyen +másnap +másnapi +másnapos +másnaposság +másnemű +másod +másodállás +második +másodlagos +másodmagával +másodnap +másodnaponként +másodosztály +másodosztályú +másodpéldány +másodperc +másodperces +másodpercmutató +másodpilóta +másodszülött +másolat +másrészt +másszor +másunnan +másutt +másvalaki +mászik +mászkál +mászkálás +mátkapár +mátraszentimrei +mázas +mázli +mázol +mázoló +mázsa +mázsás +machiavellizmus +mackó +mackófelsőrész +mackós +macska +macskafejes +macskahere +macskaköves +macskakő +macskamosdás +macskanyelv +madár +madárcsípte +madárfejű +madárfütty +madáritató +madárka +madárkalitka +madárpiszok +madárraj +madársaláta +madártest +madártetem +madártömő +madártojás +madártoll +madárüveg +madarász +madaracska +madonna +madzag +madzagol +mag +maga +magában +magánakció +magánbeszélgetés +magánbeteg +magándetektív +magánélet +magánember +magángazdálkodás +magánházacska +magánhangzó +magánhasználat +magánjelenet +magánkórház +magánlakás +magános +magánpacientúra +magántanítvány +magántermészetű +magánügy +magánvád +magánvállalkozó +magánvallatás +magány +magányos +magányoskodik +magányosság +magánzárka +magánzó +magárahagyottság +magától +magáz +magabízó +magabiztos +magabiztosság +magafajta +magafeledt +magafelejtve +magaforma +magamaga +magamutogató +magas +magasfeszültségű +magasföldszintes +magasiskola +magaslat +magaslati +magasles +magaslik +magasodik +magasrangú +magasság +magasságú +magasztal +magasztos +magatartás +magatartás-norma +magatartású +magatehetetlen +magaválasztotta +magazin +magfizikus +magnetofon +magnó +magnószalag +magomobil +magtár +magtörő +magvatlan +magvetés +magvető +magyar +magyar-lengyel +magyar-német +magyarán +magyaráz +magyarázat +magyarázható +magyarázkodás +magyarázkodik +magyarbarát +magyarhoni +magyarkodik +magyarországi +magyaros +magyarosít +magyarul +magzat +magzatmáz +mahagóni +maharadzsa +maholnap +mai +majális +majd +majd-majd +majdani +majdhogy +majdhogynem +majdnem +majdnem-sikoly +majmol +majom +majom-mozgás +majomfarka-kaktusz +majomkodik +majompóz +majompofájú +majomügyesség +major +majori +majorság +majrés +majrézik +majszol +makacs +makacskodik +makacsság +makadámút +makk +makkegészséges +makói +makog +makrancos +maláji +malac +malacka +malacképű +malackodás +malacpofa +malacság +mallér +malőr +malom +malomkő +malomvezető +malter +malterlelkű +malteros +mama +mamlasz +mamuska +manapság +mancs +mandula +mandulafa +mandzsetta +manierista +manikűröz +mankó +mankós +manó +manőver +manőverez +manőverezési +manzárd +manzárdszoba +mar +marás +marad +maradás +maradási +maradandó +maradék +maradéktalan +maradi +maradiság +maradvány +marakodik +marasztal +marcangol +marciális +marcona +marék +margarétás +margitszigeti +margitvirág +margó +marha +marháskodik +marhaerő +marhahús +marhapörkölt +marhaság +marhavagon +marian-ügy +markáns +markíroz +markol +markolász +markolat +markoló +maró +maródi +marok +maroknyi +marokszedés +marokszedő +maros-parti +mars +marsall +martinász +martinkemenceszerű +marx-levél +marxista +marxizmus +masina +masiniszta +maskarádé +masni +massza +masszázs +masszív +masszőr +maszatos +maszek +maszk +maszkíroz +maszlag +matat +matek +matematika +matematikai +matematikus +materializmus +matrac +matrac-hajó +matracos +matracú +matring +matróna +matróz +matrózblúzos +matrózruha +matróztüzér +matuzsálemi +mauzóleum +maximális +maximum +mazsolás +mbah +mécs +mécses +még +méghozzá +mégis +mégiscsak +mégoly +mégpedig +mégsem +mégúgy +méh +méhészet +méhészkedés +méhészkedik +méhike +méhpempő +méla +méláz +mélabú +mélabús +méltán +méltányol +méltányos +méltánytalan +méltat +méltatlan +méltatlankodás +méltatlankodik +méltó +méltóság +méltóságkeltő +méltóságos +méltóságteljes +méltóztatik +mély +mély-proli +mély-tábla +mélyépítési +mélyed +mélyedés +mélyhűtött +mélyít +mélykék +mélypont +mélyréteg +mélység +mélységes +mélységű +mélysötét +mélytányér +mélytenger +mélytüzű +mélytudati +mélyül +mélyvíz +mélyzöld +mémoszista +mén +ménes +méntelep +mér +mérce +mérés +méreg +méregcsepp +méregerős +méreget +méregfog +méregkeverő +méregraktár +méret +méretez +méretkezik +méretű +mérföld +mérföldes +mérföldlépő +mérgelődik +mérges +mérgez +mérgeződik +mérhetetlen +mérhető +mérkőzés +mérkőzik +mérleg +mérlegel +mérlegelés +mérleghiányos +mérlegképes +mérmondó +mérnök +mérnökék +mérnökfiú +mérnökgyakornok +mérnöki +mérnökjelölt +mérnöknő +mérőeszköz +mérsékel +mérsékelt +mérséklet +mért +mértan +mértani +mérték +mértékegység +mértékletes +mértékletesség +mértékrendszer +mértéktartás +mértéktartó +mértéktelen +mértékű +mész +mészárlás +mészáros +mészároslegény +mészárszék +mészégető +mészfolt +mészkőszikla +mészpor +mészréteg +mészszag +mészváz +métely +méter +méteres +méternyi +méterrúd +méz +mézes +mézeshetek +mézeskalács +mézgás +meccs +mecénás +mechanika +mechanikai +mechanikus +mechanizmus +mecseki +medalion +meddig +meddő +medence +meder +medika +medikus +medikuslány +meditáció +meditál +medúza +medve +medve-bedve +medvemormogás +medveölelés +meg +meg-megáll +meg-megállás +meg-megborzongat +meg-megcéloz +meg-megcsúszik +meg-megcsuklik +meg-megforgat +meg-megkeres +meg-meglebben +meg-meglepődik +meg-megragad +meg-megrebben +meg-megrogyik +meg-megszippant +meg-megszólal +meg-megszúr +meg-megszűkül +meg-megtorlódik +meg-megújul +megácsol +megágyaz +megáld +megáll +megállás +megállapít +megállapítás +megállapító +megállapodás +megállapodik +megállapodottság +megállít +megállíthatatlan +megállítható +megállj +megálló +megállóhely +megárad +megárt +megás +megátalkodott +megátalkodottság +megázás +megázik +megad +megadás +megadó +megafon +megagitálás +megajándékoz +megakad +megakadályoz +megakadályozás +megakaszt +megaláz +megalázás +megalázkodik +megalázó +megalázott +megalázottság +megaláztatás +megalakul +megalakulás +megalapít +megalapoz +megalapozás +megalapozott +megalkot +megalkotás +megalkuszik +megalkuvás +megalszik +megalvad +megannyi +megaranyoz +megbámul +megbán +megbánás +megbánt +megbántódás +megbántódik +megbántott +megbántottság +megbabonáz +megbarátkozik +megbarnít +megbarnul +megbékél +megbékélés +megbékít +megbékül +megbélyegez +megbénít +megbénul +megbecsül +megbecsülés +megbecsült +megbeszél +megbeszélés +megbeszélnivaló +megbetegedik +megbírságoltat +megbíz +megbízás +megbízatás +megbízhatatlan +megbízható +megbízhatóság +megbízik +megbízó +megbízólevél +megbízott +megbicsaklik +megbilincsel +megbillen +megbillent +megbirkózik +megbizonyosodik +megbódul +megbök +megbocsát +megbocsátás +megbocsáthatatlan +megbocsátható +megbocsátó +megbokrosodik +megboldogult +megbolondít +megbolondul +megbolydul +megbolygat +megbomlik +megbont +megbonthatatlan +megborotválkozik +megborzad +megborzol +megborzong +megborzongat +megbotlik +megbotránkozás +megbotránkozik +megbújik +megbüntet +megbűvöl +megbugáz +megbukik +megbuktat +megcáfol +megcáfolhatatlan +megcéloz +megcímez +megcibál +megcirógat +megcsal +megcsalatkozik +megcsap +megcsapkod +megcsappan +megcsavar +megcsavarodik +megcselekedik +megcsendesedik +megcsendül +megcserélődik +megcsíp +megcsikordít +megcsikordul +megcsillan +megcsinál +megcsináltat +megcsipked +megcsókol +megcsóvál +megcsömörlik +megcsörget +megcsörren +megcsodál +megcsodáltat +megcsonkul +megcsontosodik +megcsúfol +megcsúfolás +megcsúnyul +megcsúszik +megcsúzliz +megcsuklik +megdagad +megdermed +megdermeszt +megdicsér +megdicsőül +megdicsőülés +megdöbben +megdöbbenés +megdöbbent +megdöbbentő +megdögleszt +megdöglik +megdöndül +megdönget +megdönt +megdördül +megdörzsöl +megdől +megdobál +megdobban +megdobogtat +megdolgoz +megdolgozik +megdolgoztat +megdorgál +megdrótoztat +megdübörög +megdühödik +megdurran +megduzzad +megébred +megég +megéget +megéhezik +megél +megélénkül +megélés +megélesedik +megéljenzés +megélt +megépít +megépül +megépülés +megér +megérdemel +megérez +megérezhető +megérik +megérint +megérkezés +megérkezik +megért +megértés +megértet +megértő +megebédel +megedz +megegyezés +megegyezik +megegyeztet +megejt +megejtet +megejtő +megelégedés +megelégedett +megelégedettség +megelégedik +megelégel +megelevenedik +megelevenül +megelőz +megelőzés +megelőző +megemberel +megemészt +megemel +megemlékezik +megemlít +megemlítés +megenged +megengedett +megengedhető +megenyhül +megered +megereszkedik +megereszt +megerőltet +megerőltetés +megerőltető +megerősít +megerősítés +megerősödik +megerőszakol +megesik +megesküszik +megesz +megeszik +megetet +megfájdul +megfáradt +megfásul +megfázik +megfaggyúz +megfagy +megfakul +megfarag +megfarol +megfékez +megfélemlítés +megfér +megférfiasodik +megfésülködik +megfehéredik +megfejt +megfejtés +megfejtetlen +megfejthetetlen +megfeketedik +megfekszik +megfeledkezik +megfelel +megfelelő +megfellebbezhetetlen +megfeneklik +megfenyeget +megfenyít +megfertőz +megfertőztet +megfest +megfeszít +megfeszítés +megfeszül +megfeszülés +megfiatalít +megfigyel +megfigyelés +megfigyelhető +megfigyelő +megfizet +megfő +megfőz +megfog +megfogad +megfogadás +megfogalmaz +megfogalmazás +megfogalmazható +megfogamzik +megfogdos +megfoghatatlan +megfogható +megfogódzkodik +megfogyatkozik +megfojt +megfokhagymáz +megfontol +megfontolás +megfontolt +megfontoltság +megfordít +megfordul +megfordulás +megforgat +megformál +megformálás +megformálódik +megforrósodik +megfoszt +megfricskáz +megfúj +megfúr +megfürdet +megfürdik +megfullad +megfullaszt +megfut +megfutamodik +meggátol +meggazdagodik +meggörbül +meggördül +meggörnyed +meggondol +meggondolás +meggondolatlan +meggondolatlanság +meggondolkoztat +meggondolt +megguggol +meggy +meggyág +meggyászol +meggyérül +meggyfa +meggyil +meggyilkol +meggyilkolás +meggyógyít +meggyógyul +meggyón +meggyötör +meggyötörtetés +meggyőz +meggyőzés +meggyőző +meggyőződés +meggyőződésbeli +meggyőződéses +meggyőződik +meggyőzős +meggyorsít +meggyorsul +meggypiros +meggyszínű +meggyújt +meggyúr +meggyűlik +meggyűlöl +meggyullad +megháborodik +meghág +meghálál +meghámoz +meghány-vet +meghátrál +megházasodik +meghagy +meghajlás +meghajlít +meghajlik +meghajol +meghajt +meghajtás +meghal +meghalás +meghalad +meghalkul +meghall +meghallgat +meghalványodik +megharagít +megharagszik +megharap +meghasít +meghat +meghatároz +meghatározás +meghatározatlan +meghatározhatatlan +meghatározó +meghatározott +megható +meghatódik +meghatódottság +meghatott +meghatottság +meghazudtol +meghektikásodik +meghempergőzik +meghígul +meghív +meghívás +meghívandó +meghívó +meghívott +meghízik +meghidegedik +meghimbál +meghint +meghintáztat +meghirdet +meghirdetés +meghisz +meghitt +meghittség +meghódít +meghódítás +meghökken +meghökkenés +meghökkent +meghökkentő +megholtak +meghonosít +meghonosítás +meghord +meghordoz +meghosszabbít +meghosszabbítás +meghosszabbító +meghosszabít +meghosszabítás +meghoz +meghozat +meghúz +meghúzgál +meghúzódik +meghúzogat +meghülyít +meghülyül +meghűl +meghűt +meghűvösödik +meghunyászkodás +meghunyászkodik +meghurcol +megígér +megír +megírás +megírnivaló +megítél +megítélés +megízlel +megidéz +megideologizál +megigazgat +megigazít +megijed +megijeszt +megillatosodik +megillet +megilletődés +megilletődik +megindít +megindító +megindokol +megindul +megindulás +megindultság +megingás +megingat +megingathatatlan +meginog +megint +megiramodik +megirtózik +megismétel +megismétlődik +megismer +megismerés +megismerkedés +megismerkedik +megismerszik +megismertet +megiszik +megitat +megizzad +megizzaszt +megjár +megjátszás +megjátszik +megjavít +megjavíthatatlan +megjavul +megjegyez +megjegyezhető +megjegyzés +megjelenés +megjelenési +megjelenik +megjelent +megjelentet +megjelöl +megjelölés +megjósol +megjön +megjuhászodik +megjutalmaz +megkap +megkapál +megkapar +megkaparint +megkapaszkodik +megkapható +megkér +megkérd +megkérdez +megkérdőjelez +megkésik +megkétszerez +megkedvel +megkefél +megkegyelmez +megkeményedik +megkeményít +megken +megkenet +megkeres +megkeresés +megkeresztelkedik +megkerget +megkergül +megkerül +megkeseredik +megkettőződik +megkever +megkeveredik +megkezd +megkezdés +megkezdődik +megkímél +megkínál +megkínoz +megkísérel +megkísért +megkísértés +megkíván +megkóstol +megkönnyebbedik +megkönnyebbül +megkönnyebbülés +megkönnyít +megkönyököl +megkönyörül +megköp +megkörnyékez +megköszön +megköszörül +megköt +megkötés +megkötöz +megkövesedik +megkövetel +megkövült +megközelít +megközelítés +megközelítési +megközelíthetetlen +megkoccan +megkockáztat +megkocogtat +megkomolyodik +megkondul +megkopaszodik +megkopik +megkoplal +megkopogtat +megkorbácsol +megkoszorúz +megkotor +megkotorász +megkottyan +megkotyogtat +megküld +megkülönböztet +megkülönböztetés +megkülönböztetett +megküzd +megkuszálódik +meglát +meglátás +meglátogat +meglátszik +meglangyosodik +meglassúdik +meglazít +meglazul +meglékel +meglép +meglebben +meglebbent +meglegyint +meglehet +meglehetős +meglel +meglendül +megleng +meglenget +meglep +meglepetés +meglepetésszerű +meglepő +meglepődés +meglepődik +megles +meglesz +meglett +meglevő +meglódul +meglóg +meglök +meglő +meglőhető +meglobban +meglobogtat +meglocsol +meglop +meglovagolható +megmárt +megmártózik +megmásíthatatlan +megmászik +megmagyaráz +megmagyarázhatatlan +megmagyarázható +megmakacsol +megmar +megmarad +megmaradás +megmarkol +megmarkolászik +megmér +megméreget +megmérgez +megmelegedik +megmelegít +megmenekít +megmenekül +megmenekülés +megment +megmentés +megmentett +megmentő +megmered +megmerevedik +megmerevít +megmerevítés +megmerít +megmoccan +megmoccant +megmocorog +megmond +megmondható +megmondó +megmos +megmosakodik +megmosdat +megmosdik +megmosolyog +megmozdít +megmozdul +megmozdulás +megmozgat +megmozgatás +megművel +megművelés +megműveltet +megmukkan +megmunkál +megmutat +megmutatás +megmutatkozik +megmutogat +megnéz +megnézeget +megnézet +megnedvesít +megneheztel +megneszel +megnevettet +megnevez +megnevezés +megnövekedik +megnövel +megnő +megnősül +megnyal +megnyalás +megnyekken +megnyer +megnyes +megnyílik +megnyír +megnyikkan +megnyikordul +megnyilatkozás +megnyilatkozik +megnyilvánul +megnyilvánulás +megnyit +megnyitás +megnyitó +megnyom +megnyomkod +megnyomódik +megnyomogat +megnyújt +megnyúlik +megnyúz +megnyugszik +megnyugtat +megnyugtatás +megnyugtató +megnyugvás +megóv +megöl +megölel +megöletés +megöngyilkol +megöregedik +megörökít +megörökítés +megörül +megörvendeztet +megőriz +megőrjít +megőröl +megőrül +megőrzés +megőrző +megőrződik +megőszül +megokol +megokolt +megolajoz +megold +megoldás +megoldhatatlan +megoldható +megoldódik +megolvad +megoperál +megoperáltat +megorrol +megoszt +megosztozik +megpályáz +megpárnásodik +megpásztáz +megpacskol +megpakol +megparázslik +megparancsol +megpaskol +megpatkol +megpecsétel +megpendít +megpendül +megperdül +megperzsel +megpihen +megpihentet +megpillant +megpillantás +megpiszkál +megpöcköl +megpörget +megpofoz +megposhad +megpróbál +megpróbálkozik +megpróbáltatás +megpucol +megpuhít +megpuszil +megrág +megrágalmaz +megrándít +megrándul +megráng +megránt +megráz +megrázkódik +megrázkódtatás +megragad +megrajzol +megrak +megrakodik +megrémít +megrémül +megrészegedik +megrebben +megreccsen +megrecsegtet +megreked +megremeg +megrendel +megrendelés +megrendez +megrendít +megrendítő +megrendül +megrendülés +megrendültség +megrenget +megreped +megrepedezik +megreszel +megreszket +megreszkettet +megretten +megrettent +megrezdül +megrezget +megrezzen +megrezzent +megríkat +megriad +megriaszt +megringat +megriposztoz +megritkul +megró +megrögzít +megrögzött +megrögzül +megrökönyödés +megrökönyödik +megrövidít +megroggyan +megrohad +megrohamoz +megrohan +megrohanás +megrokkan +megromlik +megrongál +megrongálódik +megront +megropogtat +megroppan +megroskad +megrozsdásodik +megrúg +megrühesedik +megrugdos +megsárgul +megsajdul +megsajnál +megsavanyodik +megsért +megsértés +megsértődik +megsérül +megsétáltat +megsebesít +megsebesül +megsebez +megsegít +megsegítés +megsejt +megsemmisít +megsemmisítés +megsemmisíthetetlen +megsemmisítő +megsemmisül +megsemmisülés +megsíkosodik +megsínyli +megsikál +megsimít +megsimogat +megsirat +megsóz +megsötétedik +megsodor +megsokall +megsokasodik +megsokszoroz +megsokszorozás +megsokszorozódik +megsoroz +megsoványodik +megspórol +megsúg +megsüt +megsűrűsödik +megsuhogtat +megszáll +megszállás +megszálló +megszállott +megszámít +megszámlál +megszámlálhatatlan +megszámol +megszán +megszárad +megszárít +megszárítgat +megszázszoroz +megszab +megszabadít +megszabadul +megszaggat +megszagol +megszakállasodik +megszakad +megszakít +megszakítás +megszalad +megszavaz +megszavazás +megszavaztat +megszavaztatás +megszédít +megszédül +megszégyenít +megszégyenítés +megszépül +megszed +megszeg +megszegés +megszelel +megszelídít +megszelídül +megszemélyesít +megszemlél +megszenved +megszeppen +megszeret +megszerez +megszerezhetetlen +megszerezhető +megszerkeszt +megszervez +megszerzés +megszív +megszilárdítás +megszilárdulás +megszimatol +megszippant +megszól +megszólal +megszólaltat +megszólít +megszólítás +megszólítgat +megszór +megszökik +megszöktet +megszövegez +megszokás +megszokhatatlan +megszokik +megszokott +megszokottság +megszolgál +megszomjazik +megszomorít +megszoptat +megszorít +megszorul +megszúr +megszül +megszületés +megszületik +megszüntet +megszüntetés +megszűnés +megszűnik +megszűr +megtáltosodik +megtámad +megtámaszt +megtámogat +megtáncoltat +megtántorodik +megtárgyal +megtárgyalás +megtagad +megtakarít +megtakarítás +megtalál +megtalálás +megtalálható +megtaláló +megtanácskozik +megtanít +megtanul +megtapad +megtapasztal +megtapint +megtapogat +megtapos +megtapsikolás +megtapsol +megtart +megtartás +megtartat +megtartóztat +megtaszít +megtébolyodik +megtép +megtépáz +megtépdes +megtér +megtérés +megtérít +megtérülés +megtésztásodik +megtévelyedik +megtéveszt +megtévesztés +megtekint +megtekintés +megtelepedés +megtelepedik +megtelepül +megtelik +megterebélyesedik +megterem +megteremt +megteremtés +megterhel +megterít +megtermékenyít +megtermékenyítés +megtermel +megtervez +megtervezés +megtestesít +megtestesítő +megtestesül +megtesz +megtetszik +megtilt +megtippel +megtisztel +megtisztelő +megtiszteltetés +megtisztít +megtisztogat +megtisztulás +megtöbbszöröz +megtölt +megtöltés +megtöltekezik +megtöltődik +megtöm +megtör +megtörés +megtörik +megtöröl +megtörténik +megtörténte +megtörülközik +megtold +megtorlás +megtorlódik +megtornáztat +megtorol +megtorpan +megtorpedóz +megtrágyáz +megtüzesít +megtűr +megtud +megtudakol +megújhodás +megújításszerű +megújul +megújulás +megúszik +megül +megülepszik +megünnepel +megüresedik +megürül +megüt +megütközés +megütközik +megütődik +megüzen +megugrik +megun +megutál +megvádol +megvág +megválaszolatlan +megválaszt +megválasztás +megválasztat +megválik +megválogat +megvált +megváltás +megváltó +megváltozik +megváltoztat +megváltoztatás +megvár +megvárakoztat +megvásárol +megvásároltatás +megvacsorázik +megvadul +megvakar +megvakargat +megvall +megvalósít +megvalósítás +megvalósítható +megvalósul +megvalósulás +megvan +megvarr +megvasal +megvéd +megvékonyodik +megvénül +megvétel +megvendégel +megver +megvereget +megveret +megvertség +megvesz +megveszekedett +megveszteget +megvesztegető +megvet +megvetés +megvetemedik +megvetendő +megvető +megvív +megvigasztal +megvigasztalódik +megvilágít +megvilágítás +megvilágosodik +megvilágosul +megvillan +megvillant +megvirrad +megvisel +megviselt +megvisz +megvitat +megvitatás +megvizitíroz +megvizsgál +megvizsgálható +megvizsgáltat +megvon +megvonogat +megy +megye +megyebeli +megyei +megyeri +megyjegyzés +megzabál +megzaboláz +megzavar +megzavarodás +megzavarodik +megzilál +megzöldül +megzörget +megzörren +megzsarol +mehetnék +mehosszabbíttat +mekegés +mekkora +melasz +meleg +melegedik +melegházi +melegít +melegítő +melegség +melegszívű +melenget +mell +mell-lövés +mellbedobás +mellbőség +mellé +melléáll +mellébeszél +mellédob +melléír +melléje +mellék +mellékág +mellékállomás +mellékajtó +mellékalak +melléképület +mellékel +mellékes +mellékhelyiség +melléki +mellékkereset +mellékkörülmény +melléklet +mellékút +mellékutca +mellékutcácska +mellékzönge +mellélép +mellélő +mellény +mellényke +mellényzseb +melléül +mellesleg +mellett +mellette +melletti +mellkas +mellől +mellőle +mellőz +mellpáncél +mellső +melltartó +mellű +mellvéd +mellvért +meló +melós +melózik +mely +melyik +memória +memorandum +memoriter +mendegél +menedék +menedékes +menedékhely +menedzser +menekedik +menekít +menekül +menekülés +menekülő +menekülőkészülék +menekült +menekvés +menet +menetel +menetelés +menetgyakorlat +menetirány +menetlevél +menetrend +menetszázad +menetvázlat +menhely +menlevél +menny +mennybevitel +mennydörgés +mennydörög +mennyezet +mennyezeti +mennyi +mennyiben +mennyire +mennyiség +mennyiségi +mennyiségű +mennyország +menő +ment +mente +mentén +mentés +menteget +mentegetés +mentegetődzés +mentegetődzik +menten +mentes +mentesít +mentesítés +mentesítő +mentesség +mentességi +mentesül +menthetetlen +menthető +menti +mentő +mentőállomás +mentőkészülék +mentőkocsi +mentől +mentőműszak +mentőöv +mentőszolgálat +mentség +meny +menyasszony +menyasszonyi +menyét +menyecske +menyecskés +menyegző +menyegzői +menza +menzapénz +meós +mer +merénylet +merénylő +merész +merészel +merészkedik +merészség +mered +meredek +meredezik +meredt +mereget +mereng +mereszt +meresztget +merev +merevedik +merevít +merevítő +merevség +merevül +merít +merő +merőben +merőkanál +merőleges +merre +merről +mersz +mert +merthogy +merül +mese +mesél +mesélés +mesélget +mesés +mesebeli +mesekönyv +mesemondás +mesemotívum +meseszép +mesevároska +messianisztikus +messianizmus +messze +messzelátó +messzemenő +messzeség +messzi +mester +mesterember +mesterember-szoba +mesterfogás +mesteri +mesterkélt +mesterkéltség +mesterkedik +mesterlegényes +mesterlövész +mestermű +mesterművű +mesterség +mesterséges +mestertárs +meszel +meszelés +meszelő +meszelt +meszes +meszes-agyú +metán +metánkeverék +metafizika +metafizikai +metaforikus +metél +metélt +meteor +meteorhullás +metodikai +metróállomás +metronóm +metsz +metszett +metsző +metszőfog +mezei +mezítláb +mezítlábas +mező +mezőgazdaság +mezőgazdasági +mezőőr +mezőség +mezőváros +mezopotámiai +meztelen +meztelenkedés +meztelenség +mi +míder +míg +mígnem +mímel +míniumos +mínusz +mítosz +mialatt +miatt +miatta +miatyánk +micisapka +micisapkás +micsoda +midőn +miért +miegyéb +miegymás +mielőbb +mielőtt +mienk +miféle +mifene +mihamar +mihelyt +miként +miképpen +miközben +mikor +mikorára +mikrobusz +mikrofilmtár +mikrofon +mikrokamera +mikrokristály +mikroporózus +mikroszkóp +mikroszkopikus +mikszáth-regény +milánói +milliárd +milliméter +millió +milliom +milliomos +mily +milyen +mimikrinyájaskodás +mimóza +minap +mind +mind-mind +mindaddig +mindamellett +mindannyi +mindannyiszor +mindaz +mindazáltal +mindazonáltal +mindeddig +mindegy +mindegyaránt +mindegyik +mindegyre +mindemellett +minden +mindenáron +mindenekelőtt +mindenekfölött +mindenesetre +mindenestül +mindenevő +mindenfajta +mindenféle +mindenfelé +mindenfelől +mindenható +mindenhol +mindenhova +mindenik +mindenképpen +mindenki +mindenkor +mindennap +mindennapi +mindennapos +mindennemű +mindenség +mindenszentek +mindenteszik +mindentudó +mindenünnen +mindenütt +mindenüvé +mindez +mindhárom +mindhalálig +mindig +mindinkább +mindjárt +mindjobban +mindkét +mindkettő +mindmáig +mindnyája +mindnyájan +mindörökké +mindörökre +mindössze +minduntalan +mindvégig +minél +minek +mini +miniatúra +miniatűr +miniatűrfestő +minimális +minimum +ministráns +minisztérium +minisztériumi +miniszter +miniszterelnök +miniszterelnöki +miniszterelnökség +miniszterelnökségi +miniszterhelyettes +minisztermama +minőség +minőségi +minőségű +minősít +minősítés +minősítő +minorita +mint +minta +mintájú +mintás +mintáz +mintababa +mintajáték +mintakép +mintaszerű +mintegy +mintha +minthogy +mintsem +minuta +mióta +mire +mirelit +mise +misézik +misecsengő +misekehely +miseruha +miskárol +miskolci +misszió +misszionárius +miszerint +miszlik +misztérium +misztériumjáték +misztifikálás +mit +mitevő +mitológia +mitugrász +miután +mivel +mivelhogy +mivolta +mixernő +mizantropikus +mócsing +mód +módfelett +módi +módos +módosít +módozat +módszer +módszeres +módszertani +módú +móka +mókás +mókuci +mókus +mókusarcú +móló +mór +móres +móring +mögé +mögéje +mögött +mögötte +mögötti +mögül +mögüle +moccan +moccanás +moccanásnyi +moccanatlan +mocorgás +mocorog +mocsár +mocsári +mocsaras +mocskos +mocsok +modell +modellforma +modern +modernség +modor +modorú +modulátor +mogorva +mogyoró +mogyoróhab +mogyorókrémtorta +mogyorós +mogyorószín +mogyorószínű +moha +mohácsi +mohamedán +mohó +mohóság +mohos +molekula +molett +molibdénbánya +moll +molnár +molyette +molyirtó +molypille +molyrágott +molyrágta +monarchia +monarchiabeli +mond +monda +mondás +mondandó +mondanivaló +mondat +mondavilág +mondhatatlan +mondható +mondóka +mondogat +mondvacsinált +mongol +mongolka +mongolos +monitor +monográfia +monoklis +monológ +monologizál +monostor +monoszkóp +monoton +monotonság +monstrum +monumentális +mopszliarc +morális +moraj +morajlás +morc +morcos +mordály +mordul +morfondíroz +morgás +morgóéri +morgolódik +mormog +mormol +mormolás +morózus +morog +morran +morzsa +morzsányi +morzsalékos +morzsol +morzsolgat +morzsoló +morzsolódik +mos +mosás +mosakodás +mosakodik +mosat +mosatlan +mosdás +mosdat +mosdatlan +mosdik +mosdó +mosdóállvány +mosdóhely +mosdókagyló +mosdószer +mosdóvíz +moslék +mosódik +mosófazék +mosógép +mosókonyha +mosóteknő +mosogat +mosogatás +mosogató +mosogatólé +mosogatórongy +mosogatóvájdling +mosogatóvíz +mosoly +mosolyféle +mosolygás +mosolygós +mosolyintás +mosolyog +mosolyreflex +mosolytalan +most +mostanában +mostanáig +mostani +mostanság +mostoha +mostohaanya +mostohaapa +mostohagyerek +mostohalány +moszat +moszkvai +motalkó +motalkószag +motívum +motollagyors +motor +motorbicikli +motorcsattogás +motorcsónak +motorgyertya +motorház +motorháztető +motorkerékpár +motorkerékpáros +motorlánc +motoros +motoroshajó +motorozik +motorravaló +motortulajdonos +motorzaj +motorzúgás +motoszkál +motoz +motozás +motyó +motyog +motyogás +move-gondnok +mozaik +mozaikkép +mozdít +mozdítás +mozdító-mozgató +mozdony +mozdonyvezető +mozdul +mozdulás +mozdulat +mozdulatlan +mozdulatlanság +mozdulattevő +mozgás +mozgás-működés +mozgáskészség +mozgáspálya +mozgásszabadság +mozgástér +mozgású +mozgalmas +mozgalmi +mozgalom +mozgat +mozgatás +mozgatóideg +mozgékony +mozgólépcső +mozgólépcső-fok +mozgósít +mozgósítás +mozgósul +mozgolódás +mozgolódik +mozi +mozilátogatás +mozipénz +mozivászon +mozog +mozsár +mozzanat +múlás +múlhatatlan +múlik +múló +múlt +múlta +múltán +múltbeli +múltidéző +múltkor +múltkori +múltkoriban +múlva +múmia +múmiafazon +múmiaplasztika +múzeum +múzeumi +múzsa +múzsakergető +mű +műalkotás +műanyag +műanyag-vegyészet +műanyagos +műbőr +műdal +műélvezet +műértő +műemlék +műfaj +műfelháborodás +műfogsor +műgond +műhaj +műhely +műhelyajtó +műhelyfőnök +műhelyiroda +műhelyszoba +műhelyudvar +műhímző +műintézet +működés +működési +működik +működtet +működtetés +műláb +műmárvány +műpapagáj +műremek +műselyem +műsor +műsorlap +műszak +műszaki +műszakos +műszakváltás +műszer +műszerasztal +műszerdoboz +műszerész +műszerkocsi +műszó +műtét +műterem +műteremtulajdonos +műtő +műtőasztal +műtrágyaelosztó +műút +művész +művészbejáró +művészest +művészet +művészetfelfogás +művészeti +művészettörténet +művészi +művésznép +művésznő +művésztelep +művel +művelés +művelet +műveletlen +műveletlenség +művelhetetlen +művelhető +művelő +művelődési +művelt +műveltség +művezető +mucsai +muflon +mufloncsapat +muki +mukk +mukkan +mukkanás +mulandóság +mulaszt +mulasztás +mulat +mulató +mulatós +mulatozás +mulatság +mulatságos +mulatt +mulattat +mulyaság +mumus +mundér +muníció +munka +munkál +munkálat +munkálkodás +munkálkodik +munkáltató +munkás +munkáscsalád +munkásegység +munkásember +munkásféle +munkásfelvétel +munkásfigura +munkáshatalom +munkáskérdés +munkáskéz +munkáslakta +munkáslégkör +munkásmozgalmi +munkásmozgalom +munkásnő +munkásőr +munkásőrség +munkásosztály +munkásotthon +munkáspárt +munkásság +munkásséma +munkásszállás +munkásszálló +munkásszázad +munkásszakma +munkástanács +munkásvédelem +munkátlan +munkaadó +munkaalkalom +munkabér +munkacsapat +munkaegység +munkaerő +munkaerőváltás +munkafázis +munkafolyamat +munkahely +munkahelyiség +munkaidő +munkaképes +munkakereső +munkakerülés +munkakezdés +munkakönyv +munkakör +munkakörülmény +munkaközösség +munkaközösségi +munkalap +munkalehetőség +munkamenet +munkanélküli +munkanélküliség +munkaóra +munkaoverall +munkaprogram +munkarend +munkaruha +munkaszín +munkaszolgálat +munkaszolgálatos +munkatábor +munkatárs +munkaterület +munkaügyi +munkaügyis +munkavállalási +munkavezető +murci +muri +muris +muskátli +muskátlibokor +muskátlis +muskátlitő +muskotály +must +mustár +mustárospohár +mustárpohár +mustra +mustrálgat +muszáj +mutat +mutatkozik +mutató +mutatós +mutatóujj +mutatvány +muter +mutogat +mutyi +muzsika +muzsikál +muzsikáltatás +muzsikás +na +na-na +nában +náci +náció +nád +nádas +náderesz +nádfal +nádfonat +nádfonatú +nádi +nádor +nádorispán +nádpalló-rakás +nádpernye +nádrengeteg +nádsíp +nádszál +nádszálvékony +nádszék +nádszéli +nádszedő +nádtető +nála +nápolyi +nász +nászajándék +násznagy +násznagyné +násznép +nászút +nátha +náthás +nacionalista +nacionalizmus +nadrág +nadrággomb +nadrágszíj +nadrágtartó +nadrágzseb +nadragulya +naftalinszag +nagy +nagy-nagy +nagyállomás +nagyária +nagyáruház +nagyanya +nagyapa +nagyapamellény +nagyarányú +nagyasszony +nagyasszonyi +nagyasztal +nagybácsi +nagybátya +nagybérlő +nagybeteg +nagybetű +nagybetűs +nagybirtokos +nagyböjt +nagybőgő +nagycsizmás +nagydarab +nagydíj +nagydob +nagydumás +nagyétkű +nagyerdő +nagyfamília +nagyfejű +nagyfilm +nagyfiú +nagyfőnök +nagyfotel +nagyfülű +nagygazda +nagygazdafiú +nagygazdaporta +nagygyűlés +nagyházas +nagyhangú +nagyhatalom +nagyít +nagyítás +nagyító +nagyipar +nagyjában +nagyjában-egészében +nagyjából +nagykabát +nagykapu +nagykarimájú +nagyképű +nagyképűség +nagyképűsködik +nagykendő +nagykereskedelmi +nagykereskedő +nagykövet +nagykövetség +nagylány +nagylányos +nagylelkű +nagymama +nagymami +nagymarosi +nagyméretű +nagymértékben +nagymenő +nagymester +nagymosás +nagymuter +nagymuterék +nagynéni +nagynénike +nagynevű +nagyöntő +nagyöntvény +nagyocska +nagyokos +nagyolás +nagyolvasztó +nagyon +nagyon-nagyon +nagyothall +nagyothalló +nagypapa +nagypénteki +nagypénzű +nagypolgár +nagyponyva +nagyravágyás +nagyravágyó +nagyrészt +nagyság +nagysága +nagyságáék +nagyságos +nagyságrend +nagyságú +nagysokára +nagyszabású +nagyszerű +nagyszerűség +nagyszoba +nagyszülő +nagytányérú +nagytakarít +nagytakarítás +nagytakarító +nagyteknő +nagyterem +nagytermészetű +nagytermetű +nagytükör +nagyúr +nagyúri +nagyüzem +nagyüzemi +nagyujj +nagyvállalat +nagyváradi +nagyváros +nagyvárosi +nagyvásár +nagyvacsora +nagyvad +nagyvasúti +nagyvendéglő +nagyvevő +nagyvezér +nagyvilág +nagyvilági +nagyvilágiasság +nagyvonalú +nagyvonalúság +nagyzási +nahát +naiv +naivság +nana +naná +nanü +nap +napbarnított +napcserzette +napernyő +napestig +napfény +napfényátalakító +napfényenergia +napfényenergia-átalakító +napfényes +napfeljötte +napfelkelte +napfolttevékenység +napfordulás +naphosszat +napi +napidíj +napilap +napiparancs +napirend +napkeleti +napkelte +napkitörés +napközben +napközi +napkorong +naplemente +napló +naplójegyzet +napnyugta +napocska +napolajmárka +naponként +naponkénti +naponta +napos +napozik +napozó +nappal +nappali +napraforgó +napraforgószár +naprendszer +napsütés +napsütéses +napsütötte +napsugár +napsugárzás +napszállta +napszám +napszámol +napszámos +napszemüveg +napszítta +naptár +napvilág +narancs +narancsárus +narancslekvár +narancsos +narancssárga +narancsszín +narkotizál +narodnyik +naturalista +navigátor +nazálistalan +ne +néger +négy +négy-öt +négyágyas +négyéves +négyemeletes +négyes +négyes-ötös +négyesztendős +négyezer +négyezer-hétszáztizenegyes +négyezer-nyolcszázötven +négyezres +négyféle +négyfelől +négyhónapos +négykézláb +négymotoros +négynapi +négyötöd +négyszáz +négyszázezer +négyszázhúsz +négyszázhuszonnyolc +négyszázmillió +négyszázötven +négyszáztizenegyes +négyszemközt +négyszög +négyszöglépés +négyszögletes +négyszögletű +négyszögű +négyszobás +négytagú +négyzet +négyzetméter +négyzetméternyi +négyzetmilliméter +néha +néha-néha +néhány +néhányad +néhányszor +néhai +néhanap +néhol +nélkül +nélküle +nélküli +nélkülöz +nélkülözés +nélkülözhetetlen +nélkülözhető +néma +némafilm +némaság +némber +némely +némelyik +némelykor +német +német-magyar +németbarát +németellenes +németországi +németség +némi +némiképpen +némileg +néne +nénémasszony +néni +néniék +nénike +néniz +nép +népbutítás +népdal +népdalkutatás +népérdek +népes +népfőiskolás +népfront +népfronttaktika +népgazdasági +népgyűlés +néphadsereg +néphumor +népi +népi-nemzeti +népítélet +népjóléti +népköztársaság +népkormány +népmese +népnevelő +néprajzi +néprajzkutató +népség +népszenvedés +népszerű +népszerűség +népszokás +néptelen +néptribunus +néptribunus-diktátor +néptribunusi +népünnepély +népünnepélyi +népvándorlás +népvándorláskori +népvezér +név +névelő +névjegy +névjegykártya +névkeletkezés +névleges +névmemória +névnap +névsor +névsorolvasás +névtábla +névtelen +néz +nézés +nézésű +nézeget +nézelődik +nézelődő +nézet +nézeteltérés +nézgelődik +néznivaló +néző +nézőközönség +nézőpont +nézősereg +nézőtér +nézve +nézvést +neandervölgyi +nebuló +nedű +nedv +nedves +nedvesség +nefelejcs +negatív +negatívum +negédes +neglizsé +negyed +negyedév +negyedéves +negyedévi +negyedhold +negyedik +negyedikei +negyedikes +negyedmagával +negyednap +negyedóra +negyedórás +negyedrész +negyedrét +negyedrendű +negyedszázad +negyven +negyven-hatvan +negyven-negyvenkét +negyven-negyvenöt +negyven-ötven +negyvenéves +negyvenévi +negyvenegy +negyvenes +negyvenezer +negyvenhárom +negyvenhat +negyvenhét +negyvenkét +negyvenkettő +negyvenkilenc +negyvennégy +negyvennyolc +negyvenöt +negyvenötezer +negyvenpercnyi +nehéz +nehézfejű +nehézkes +nehézkesség +nehézség +nehézsúlyú +nehéztank +nehezék +nehezedik +nehezít +neheztel +neheztelés +nehogy +neje +nejlonbili +neki +nekiáll +nekibátorodik +nekibúsul +nekibuzdulás +nekicsapódik +nekidől +nekidühödik +nekiesik +nekifekszik +nekifeszül +nekifog +nekifohászkodik +nekifut +nekigyürkőzik +nekihettyent +nekihevülés +nekiindít +nekiindul +nekiiramodik +nekikészül +nekikezd +nekilát +nekilendül +nekilódul +nekilök +nekimegy +nekinyom +nekiöltözködik +nekirohan +nekiront +nekirúg +nekirugaszkodás +nekisimul +nekiszalad +nekitámad +nekitámaszkodik +nekitámaszt +nekiüt +nekiütközik +nekiütődik +nekiugrik +nekiuszít +nekivág +nekivadul +nekiverődik +nekivet +nektár +nem +nem-kiválasztott +nem-mosdás +nemcsak +nemde +nemegyszer +nemes +nemesasszony +nemesedik +nemesember +nemesgáz +nemesi +nemesít +nemesítés +nemesség +nemhiába +nemhogy +nemi +nemigen +nemiség +nemjóját +nemkívánatos +nemkülönben +nemlét +nemleges +nemrég +nemrégen +nemrégiben +nemsokára +nemtelen +nemtetszés +nemtörődöm +nemtörődömség +nemű +nemz +nemzedék +nemzet +nemzetbomlasztó +nemzetes +nemzetgazdaság +nemzetgyalázó +nemzeti +nemzetiségi +nemzetiségű +nemzetiszín +nemzetközi +nemzetmegváltó +nemzetség +nemzette +nemzőszerv +neon +neonbetű +neoncsillag +neonfalú +neonlámpa +neonos +neonreklám +neonsugár +neontraverz +nesz +nesze +neszezés +nesztelen +netalán +netovább +neurózis +neurotikus +nevel +nevelés +nevelési +neveletlen +nevelhető +nevelkedik +nevelő +nevelőanya +nevelőapa +nevelőhatás +nevelői +nevelőnő +nevelőszülő +neveltetés +neves +nevesincs +nevet +nevetés +nevetgél +nevetgélés +nevethetnék +nevetnivaló +nevetőkényszer +nevetős +nevetség +nevetséges +nevez +nevezetes +nevezetesség +nevezetű +nevezhető +nevező +nevű +ni +nigériai +nihil +nikkel-csukló +nikkelbánya +nikkelcső +nikkelez +nikotin +nikotinrágott +nimfa +nimfás +nimfománia +nimfomániás +nincs +nincstelen +nitromin +nitrum +nivellál +nivellálógép +no +nógat +nógatás +nóta +nótárius +növény +növényfajta +növényi +növénykultúra +növénynemesítő +növénysor +növénytankönyv +növénytermesztés +növényvilág +növényzet +növés +növésű +növekedés +növekedési +növekedik +növekvő +növel +növendék +növendékgárda +növendékkakas +növeszt +nő +nőcske +nőember +nőgyógyász +női +nőies +nőiesség +nőpárti +nőportré +nőrokon +nős +nőség +nőstény +nősténykacaj +nősténytest +nősül +nősülés +nősülési +nőszemély +nőtársadalom +nőtag +nőtanács +nőtípus +nőtlen +nőttön-nő +nőügy +nővér +nővérke +nocsak +noha +nohát +nono +nonszensz +norma +normál +normális +normandi +normatíva +nos +noszogat +nosztalgia +nosztalgikus +notesz +notórius +novella +november +novemberi +nukleáris +nulla +nullás +nuncius +nyáj +nyájas +nyájasság +nyál +nyáladzik +nyálas +nyálka +nyálkás +nyápic +nyár +nyáréjszakai +nyárfa +nyárfaerdő +nyári +nyárias +nyárs +nyársal +nyárspolgár +nyárspolgári +nyafog +nyafogás +nyaggat +nyaggatás +nyak +nyakal +nyakasság +nyakatört +nyakcsigolya +nyakhajlás +nyakhossz +nyakkendő +nyakkendőtlen +nyaklánc +nyakleves +nyakló +nyakörv +nyakra-főre +nyakravaló +nyakszirt +nyaktörő +nyakú +nyal +nyaláb +nyalánkság +nyaldos +nyalka +nyalókázás +nyalogat +nyamvadt +nyaral +nyaralás +nyaraló +nyaralócska +nyaralóház +nyaranta +nyargal +nyargalászik +nyavalya +nyavalyás +nyavalygás +nyavalyog +nyél +nyegle +nyegleség +nyekereg +nyekerget +nyel +nyeldekel +nyeldeklés +nyeldeklő +nyeldes +nyeleget +nyelőcső +nyelű +nyelv +nyelvatlaszos +nyelvcsere +nyelvészet +nyelvészkongresszus +nyelvecske +nyelvi +nyelvóra +nyelvtan +nyelvtanár +nyelvtanfolyam +nyelvtudás +nyelvtudomány +nyelvű +nyer +nyerés +nyereg +nyeregtáska +nyereség +nyereségrészesedés +nyergeletlen +nyergelő +nyerges +nyerít +nyerő +nyers +nyers-durva +nyersáru +nyersanyag +nyersanyagellátás +nyersanyagmennyiség +nyersfordítás +nyersgumi +nyersgyapjú +nyerstégla +nyest +nyeszlett +nyíl +nyílás +nyílegyenes +nyílik +nyílik-csukódik +nyíllövésnyi +nyílt +nyíltság +nyílvessző +nyír +nyírás +nyírat +nyíratlan +nyírbotondi +nyíregyházi +nyíres +nyírfa +nyírfaseprő +nyikkan +nyikordulás +nyikorgás +nyikorog +nyilall +nyilas +nyilaskeresztes +nyilasvezér +nyilatkozat +nyilatkozik +nyilaz +nyilván +nyilvánít +nyilvános +nyilvánosság +nyilvántart +nyilvántartás +nyilvántartási +nyilvántartó +nyilvánvaló +nyiratkozik +nyirkos +nyirkosság +nyiszorgás +nyiszorog +nyit +nyitány +nyitás +nyitogat +nyitott +nyivákol +nylondarabka +nylonfolt +nylonharisnya +nyloning +nylonzacskó +nyög +nyögdécsel +nyögés +nyöszörgés +nyöszörgetés +nyöszörög +nyolc +nyolc-kilenc +nyolc-tíz +nyolcad +nyolcadik +nyolcas +nyolcéves +nyolcévi +nyolcesztendős +nyolcezer +nyolcezer-kétszázharmincas +nyolcfelé +nyolchetes +nyolchónapos +nyolckötetes +nyolcszáz +nyolcszáz-ezer +nyolcszázhatvan +nyolcszázkilencvennégyes +nyolcvan +nyolcvanadik +nyolcvanéves +nyolcvanezer +nyolcvanhármas +nyolcvanhat +nyolcvanhatos +nyolcvanhét +nyolcvankét +nyolcvankilenc +nyolcvanöt +nyolcvanöt-kilencven +nyolcvanszázalékos +nyom +nyomán +nyomás +nyomású +nyomakodik +nyomaszt +nyomasztó +nyomaték +nyomatékos +nyomban +nyomda +nyomdász +nyomdaigazgató +nyomdok +nyomjelző +nyomkod +nyomódik +nyomóerő +nyomós +nyomogat +nyomor +nyomorék +nyomorog +nyomorúság +nyomorúságos +nyomorult +nyomorultság +nyomott +nyomoz +nyomozás +nyomozó +nyomozótiszt +nyomtalan +nyomtat +nyomtatás +nyomtatott +nyomtatvány +nyomul +nyoszolya +nyújt +nyújtó +nyújtózik +nyújtózkodik +nyújtogat +nyúl +nyúlánk +nyúlbőr +nyúlfi +nyúlgát +nyúlik +nyúlkál +nyúlketrec +nyúlós +nyúz +nyúzott +nyüszít +nyüzsgés +nyüzsög +nyű +nyűg +nyűgös +nyűgösködik +nyűtt +nyugágy +nyugállományú +nyugalmas +nyugalmazott +nyugalom +nyugalom-kielégülés +nyugat +nyugat-magyarországi +nyugat-ukrajnai +nyugati +nyugatnémet +nyugatrómai +nyugdíj +nyugdíjas +nyugdíjasság +nyugdíjaz +nyugdíjazás +nyugdíjaztatás +nyugdíjigénylő +nyugdíjjogosultság +nyughatatlan +nyugi +nyugodalmas +nyugodt +nyugovó +nyugszik +nyugta +nyugtáz +nyugtalan +nyugtalanít +nyugtalankodás +nyugtalankodik +nyugtalanság +nyugtat +nyugtatgat +nyugtató +nyugton +nyugvás +nyulas +nyurga +oázás +oázis +objektív +objektum +oboás +oboazene +obsitos +obszcén +ocsmány +ocsmányság +ocsúdik +oda +oda-odavet +oda-vissza +odább +odábbáll +odábbhajt +odáig +odaáll +odaállít +odaát +odaáti +odaad +odaadás +odaadó +odaadogat +odaakaszt +odaballag +odabe +odabenn +odabiccent +odabiceg +odabök +odabotorkál +odabújik +odacsap +odacselez +odacsíp +odacsörtet +odadöcög +odadob +odadünnyög +odadug +odaég +odaépít +odaér +odaérkezik +odaenged +odafér +odafektet +odafenn +odafigyel +odafordul +odafurakodik +odafut +odagömbölyödik +odagombostűz +odaguggol +odahagy +odahajol +odahajt +odahallgat +odahaza +odahelyez +odahímez +odahív +odahordat +odahoz +odahúz +odahúzódik +odaígér +odaír +odaigazít +odailleszt +odaint +odainvitál +odajár +odajön +odajut +odakacsint +odakap +odakészít +odakerül +odakínál +odakiált +odakiabál +odakinn +odakönyököl +odakönyörög +odaköszön +odakoccan +odakozmál +odaküld +odalátszik +odalép +odalépked +odalenn +odalenti +odalesz +odalibben +odalopódzik +odamázol +odamadzagol +odamegy +odamond +odamutat +odanéz +odanyom +odanyújt +odanyúl +odapillant +odapörög +odaragad +odaragaszt +odarendel +odarendez +odarögződik +odarohan +odasétál +odasiet +odaslalomoz +odasodor +odasomfordál +odasorol +odasúg +odasurran +odaszalad +odaszegődik +odaszól +odaszorít +odatámaszt +odatalál +odatapad +odatapaszt +odatart +odatartozik +odataszigál +odatérdepel +odatelefonál +odatelepedik +odatelepít +odatelepszik +odaterel +odatesz +odatömörül +odatol +odatolat +odaül +odaugrik +odautasít +odautazik +odavág +odavár +odavaló +odavalósi +odavan +odavesz +odavet +odavezérel +odavezet +odavezettet +odavisz +odavizel +odavon +odavonz +odú +odvas +ohó +ok +okádhatnék +okfejtés +okít +okirat +oklevél +okleveles +okmány +okol +okorcai +okos +okoskodás +okoskodik +okosság +okoz +okozó +oktáv +oktalan +oktat +oktatás +oktatgat +oktató +oktatói +oktatótábla +október +októberi +oktondi +okul +okuláré +okulás +okvetetlenkedik +okvetlen +okvetlenül +oláh +olaj +olajbányászat +olajbogyó +olajcsere +olajfa +olajfestmény +olajipar +olajkapcsoló +olajmalom +olajmérnök +olajmező +olajos +olajosbarna +olajoz +olajozatlan +olajozott +olasz +olaszországi +olaszos +olcsó +old +oldal +oldalág +oldalas +oldalaz +oldalcsarnok +oldalfal +oldalfél +oldalfegyver +oldalfegyveres +oldalfülke +oldali +oldalirány +oldalkocsi +oldalnézet +oldalog +oldalpillantás +oldalrekesz +oldalsó +oldalszakáll +oldalszakállas +oldalt +oldaltáska +oldaltarisznya +oldalú +oldalvást +oldalzsák +oldalzseb +oldat +oldhatatlan +oldódás +oldódik +oldott +oldoz +olíva +oligarchia +olló +ollócsattogtatva +ollóz +olt +oltár +oltári +oltalmaz +oltalom +olthatatlan +oltogat +oltott +olvad +olvadás +olvas +olvasás +olvasatlan +olvasgat +olvasható +olvasmány +olvasó +olvasókönyv +olvasólámpa +olvasólap +olvasott +olvasta +olvaszt +olvasztó +olvasztókohó +oly +olyan +olyanféle +olyanformán +olyankor +olyannyira +olyasféle +olyasmi +olyasvalami +olyha +olykor +olykor-olykor +ombolyos +omlás +omlásszerű +omladék +omladozik +omlaszt +omlatag +omlékony +omlik +omlós +ondolál +onnan +ont +opál +opálkék +opállemez +opálos +opálszínű +opáltábla +opera +operáció +operál +operálás +operabuzi +operaénekes +operatív +operatőr +operett +operettfinálé +operettmelódia +operettprimadonna +operettszínpad +opportunista +opportunizmus +optimális +optimista +optimizmus +opus +orangután +oratórium +orca +orcácska +ordas +ordít +ordítás +ordító +ordítozás +ordítozik +ordináré +organizál +organizmus +orgazda +orgia +orgiázás +orgona +orgonabokor +orgonabúgás +orgonasíp +orgonaszó +orgyilkosság +orientálódás +orkán +orkánkabát +ormányos +ormótlan +ornamentika +orom +oromzatos +orosházi +orosz +oroszlán +oroszlánfej +oroszlányi +oroszországi +orr +orrcimpa +orrdeszka +orrfacsaró +orrhang +orrhegy +orrhossz +orrlyuk +orrnyereg +orrú +orsó +orsózónő +ország +országbeli +országgyűlés +országgyűlési +országhatár +országjárás +országocska +országos +országrész +országút +országúti +ort +ortopéd +orvos +orvosdoktor +orvosgépészet +orvosgyűlölet +orvosi +orvosi-nővéri +orvosnő +orvosol +orvosprofesszor +orvosság +orvosszakértő +orvostáska +orvostanhallgató +orvostudomány +orvostudor +orvul +osj +oson +ostoba +ostobaság +ostor +ostoroz +ostrom +ostrom-felszerelés +ostromgyűrű +ostromol +ostromtábor +ostya +ostyasütő +oszlik +oszló +oszlop +oszlopcsarnok +oszlopos +oszlopszent +oszol +oszt +osztály +osztályfeletti +osztályfőnök +osztályfőnöknő +osztályharc +osztályidegen +osztályigazgató +osztálylétszám +osztályösztön +osztályos +osztályrész +osztálytárs +osztálytársnő +osztálytitkár +osztályú +osztályvezető +osztályvezetői +osztályzat +osztályzengésű +osztás +osztag +osztalék +osztatlan +osztják +osztogat +osztozkodás +osztozkodik +osztrák +otellóbor +otp-beugró +otp-kölcsön +otromba +ott +ott-tartózkodás +ottan +ottani +ottfelejt +otthagy +otthon +otthoni +otthonias +otthonos +otthonosság +otthontalanság +otthonvezető +ottmarad +ottomán +ottveszik +ovális +overall +overallos +oxigén +oxigénhiány +oxigénpalack +ó +óbégat +óbégatás +óbudai +óceán +ócsárol +ócska +ócskaság +ócskavas +ódivatú +ódon +ódzkodik +ófrancia +óhaj +óhajt +óhatatlan +ókapu +ókor +ókori +ókút +ól +ólálkodik +ólbeli +ólmos +ólmos-fenséges +ólom +ólomdarab +ólomláb +ólomnehéz +ólomszürke +ónpohár +óra +órácska +órányi +órás +órásmester +órabér +óradíj +órafityegő +óragyűjtő +óralánc +óramutató +óraszerkezet +óratorony +óriás +óriásgömb +óriási +óriáslepke +óriásrakéta +ósdi +ószer +ószeres +óta +ótestamentumi +ótvaros +óv +óváros +óvás +óvakodik +óvatlan +óvatos +óvatoskodik +óvatosság +óvilági +óvóhely +óvóhelyablak +óvóhelynyílás +óvoda +óvodás +óvszer +ózon +ózondús +öblöget +öblös +öböl +öbölszerű +öcs +öcsémuram +öcsike +öklendezés +öklendezik +öklömnyi +öklöz +öklözés +ököl +ökölcsapás +ökölnyi +ökölszorító +ökölvívás +ökölvívó +ökör +ökörcsorda +ökörfarkkóró +ököriga +ökörnyál +ökonómia +ökrösszekér +öl +öldöklés +öldöklő +ölel +ölelés +ölelget +ölelgetés +ölelkezés +ölelkezik +öles +ölet +ölnyi +ölt +öltöny +öltözék +öltözet +öltözetecske +öltözik +öltözködés +öltözködik +öltöző +öltözőbódé +öltöztet +ölyv +ömleszt +ömlik +ön +önálló +önállóság +önállósít +önállósodási +önállósulás +önalakítás +önalakító +önbíráló +önbizalom +önbiztosító +önborotva +öncélú +öncenzúra +öncsalás +önéletrajz +önérdek +önérzet +önérzetes +önelégültség +önelemzés +önellátó +önerő +önfegyelem +önfejű +önfejűség +önfeláldoz +önfeláldozás +önfeláldozó +önfeledt +öngúny +öngyilkos +öngyilkosság +öngyilkosságvágy +öngyújtó +önigazolás +önirónia +önként +önkéntelen +önkéntes +önkény +önkényes +önkényeskedés +önkényesség +önkínzás +önkívület +önkifejezési +önköltségi +önmaga +önmérgezés +önmentő +önműködő +önnön +önnönmaga +önpusztító +önsajnálás +önsajnálat +önszántából +önszobor +önt +öntés +öntelt +önteltség +öntetszelgés +öntevékeny +öntöde +öntöget +öntörvény +öntöttvas +öntöttvas-üzem +öntöz +öntözés +öntözéses +öntözőcsődarab +öntözőkanna +öntözőkocsi +öntözőrendszer +öntudat +öntudatfoszlány +öntudatlan +öntudatos +önuralom +önvád +önvédelem +önvédelmi +önvédő +önvezérlő +önvigasztalás +önvizsgálat +önzés +önzetlen +önzetlenség +önző +ördög +ördögi +ördögszekér +ördögűzés +ördöngös +ördöngösség +öreg +öreganya +öregasszony +öregecske +öregedés +öregedik +öregedő +öregember +öreges +öregfater +öregfiú +öregkor +öregkori +öreglány +öreglegény +öregség +öregség-szag +öregségi +öregúr +öreguras +örmény +örök +örökéletű +örökhagyó +örökké +örökkévalóság +örökkön +öröklakás +öröklés +öröklét +örökletes +öröklődik +örököl +örökös +örökösödés +örökre +örökség +örökvirágzó +örökzöld +öröm +örömhír +örömmegnyilvánulás +örömtanya +örömtelen +örömtűz +örül +örvény +örvénylik +örvend +örvendetes +örvendezés +örvendezik +összbüntetés +össze +össze-összenéz +összébb +összeáll +összeállít +összeázik +összeakad +összeakaszt +összebalhézik +összebarátkozik +összebeszél +összebilincsel +összebonyolódik +összeborul +összeborzad +összeborzol +összebotlik +összebújik +összebütyköl +összecsacsog +összecsap +összecsapás +összecsapkod +összecsattogtat +összecsendül +összecsíp +összecsikorgat +összecsinál +összecsókol +összecsődít +összecsomagol +összecsomósodik +összecsomóz +összecsücsörít +összecsuk +összecsukható +összecsuklik +összecsukódik +összedörzsöl +összedől +összedob +összedobál +összedolgozik +összedrótoz +összedug +összeég +összeéget +összeér +összeegyeztethetetlen +összeenged +összeerőlködik +összeesik +összeesküvés +összeesküvő +összeeszkábál +összefércel +összeférhetetlen +összeférhetetlenség +összefekszik +összefen +összefog +összefogás +összefogdos +összefoglal +összefoglaló +összefolyik +összefon +összefonnyad +összefonódik +összeforr +összeforraszt +összefos +összefügg +összefüggés +összefüggéstelen +összefüggő +összefűz +összefurikázik +összefut +összeg +összegabalyodik +összegereblyéz +összegez +összegezés +összegömbölyödik +összegombol +összegürizik +összegubbaszkodik +összegyűjt +összegyűjtöget +összegyűlik +összegyűlt +összegyűr +összegyűrődik +összegzés +összeházasodás +összeházasodik +összehajol +összehajt +összehajtogat +összehangol +összehangolódik +összeharap +összehasonlít +összehasonlítás +összehasonlítási +összehasonlítgat +összehasonlíthatatlan +összehasonlítható +összehasonlító +összehív +összehord +összehoz +összehúz +összehúzat +összehúzódik +összehúzódik-kitágul +összehunyorít +összeír +összeírás +összeírat +összeírt +összeilleszt +összeillesztés +összeillő +összeismerkedik +összejár +összejátszás +összejön +összejövetel +összekacsint +összekalapál +összekap +összekapar +összekapaszkodik +összekapcsol +összekapcsolódik +összekapkod +összekarol +összekaszabol +összekattint +összeken +összekerül +összekever +összekeveredik +összekócol +összeköltöztet +összeköt +összekötöz +összekötő +összekötődik +összeköttetés +összekoccan +összekoccanás +összekoccant +összekoccint +összekopíroz +összekovácsol +összekulcsol +összekunkorodik +összekuszál +összekuszálódik +összemaszatol +összemér +összemelegedik +összemelegít +összemos +összemosódik +összemosolyintás +összemosolyog +összenéz +összenyálaz +összenyom +összeölelkezik +összeolvad +összeolvadás +összeomlik +összepakol +összepasszol +összepofoz +összeprésel +összeráncol +összerándul +összeránt +összeráz +összerázkódik +összeragad +összerak +összerakás +összerakodik +összerezzen +összeröhög +összerogy +összeroppan +összeroskad +összerugdal +összes +összesen +összeseper +összesereglik +összesít +összesküvés +összesség +összesúg +összesúrlódik +összeszámít +összeszámol +összeszalad +összeszélhámoskodik +összeszed +összeszerel +összeszerez +összeszid +összeszólalkozik +összeszövődés +összeszokik +összeszorít +összeszorul +összeszűkül +összetákol +összetalálkozás +összetalálkozik +összetapad +összetapos +összetart +összetartozás +összetép +összetétel +összetéveszt +összetéveszthető +összeterel +összetesz +összetett +összetevő +összetevődik +összetöpped +összetör +összetördel +összetörik +összetört +összetorlódik +összeturkál +összeül +összeüt +összeütközés +összeütközik +összeugrik +összevág +összeválogat +összevásárol +összevagdal +összevagdos +összevarr +összevegyít +összevegyül +összever +összeverbuválás +összeverekedik +összeverődik +összevesz +összevillan +összevissza +összevisszaság +összevon +összevont +összezár +összezáródik +összezárul +összezavar +összezavarodik +összezördül +összezsúfol +összezsúfolódik +összezsugorodik +összezúz +összfüggés +összhang +összjáték +összkép +összkomfort +összkomfortos +összmosoly +össznépi +összpontosít +összpontosul +össztánc +ösvény +ösvényszél +ösztökél +ösztön +ösztön-ész +ösztöndíj +ösztönfegyverzet +ösztönös +ösztönöz +ösztönrugó +ösztönszárny +ösztönszerű +ösztönű +ösztönzés +ösztönző +ösztövér +öszvér +öszvérszerű +öt +öt-hat +öt-hatéves +öt-hatezer +öt-tíz +ötágú +ötbetűs +ötévenkénti +ötéves +ötemeletes +ötezer +öthónapos +ötkilós +ötkilométeres +ötkupolás +ötlépcsős +ötlet +ötletes +ötlik +ötliteres +ötöd +ötödik +ötös +ötszáz +ötszázhúsz +ötszáznyolcvan +ötszöri +ötszörös +ötszobás +ötvehét +ötven +ötven-hatvan +ötvencentes +ötvenéves +ötvenedik +ötvenegy +ötvenegyes +ötvenes +ötvenesztendei +ötvenezer +ötvenhárom +ötvenhat +ötvenhatos +ötvenhét +ötvenhetes +ötvenkét +ötvenkettő +ötvenkilenc +ötvennégy +ötvennyolc +ötvenöt +ötvenszázalékos +ötvös +öv +övé +övez +övezet +özön +özönlik +özönvíz +özvegy +özvegyasszony +özvegyi +ő +őbele +őbelőle +őbenne +ődöng +őérte +őellene +őelőtte +őfeléje +őfelsége +őfensége +őfőméltósága +őgyeleg +őhelyette +őhozzá +őkegyelmessége +őközte +őmellé +őmellette +őmiatta +őnála +őnagysága +őneki +őnfeledt +őr +őrá +őrajta +őrház +őrhely +őriz +őrizet +őrizetes +őrizget +őriztet +őrjítő +őrjöng +őrjöngés +őrködik +őrlánc +őrlet +őrmester +őrmester-mocskolódás +őrnagy +őrnagyi +őróla +őröl +őrs +őrség +őrsparancsnok +őrsvezető +őrszolgálat +őrtorony +őrület +őrületes +őrült +őrültség +őrvezető +őrzés +őrző +ős +ősállat +ősanya +ősatya +ősegyiptomi +őselem +ősember +őserdei +őserdő +őseredetű +ősfa +ősféreg +ősforma +ősgermán +őshalom +őshüllő +ősi +ősidő +őskőzet +őskőzetfelület +őskor +őskori +őslakó +őslény +őslénytani +őspark +ősprimitív +ősrémület +ősszel-tavasszal +őstehetség +őstelepes +ősz +őszes +őszes-szürke +őszi +őszibarack +őszibarackkompót +őszies +őszilevélarc +őszinte +őszinteség +őszirózsa +őszirózsás +őszül +őszülő +őtőle +őutána +ővele +őz +őzbak +őzcomb +őzszem +páciens +páciensjelölt +pácol +páholy +pájsli +pálca +pálcás +pálinka +pálinkáskupica +pálinkáspohár +pálinkásüveg +pálinkatócsa +pállik +pállott +pálma +pálmabor +pálmafa +pálmalevél +pálya +pályázat +pályázik +pályafutás +pályaőr +pályatárs +pályaudvar +pályaudvari +páncél +páncélos +páncélszekrény +páncéltörő +páncélzat +páni +pánik +pánt +pápa +pápai +pápaszem +pár +pára +párállik +párás +párásság +párabefutotta +párafelhő +párafolt +páratelt +páratlan +párbeszéd +párduc +párducos +párhuzam +párhuzamos +pária +párizsi +párkány +párna +párnás +párnaciha +párnacsata +párolódik +párolog +páros +párosodás +párosodik +párosul +párt +párta +pártapparátus +pártatlan +pártbizottság +pártbizottsági +pártélet +pártellenes +pártember +pártfogás +pártfogó +pártfogói +pártfogol +pártfunkcionárius +párthelyiség +párthíve +pártigazolvány +pártköszönés +pártközpont +pártmegbízott +pártmunka +pártnap +pártönzés +pártol +pártszerű +pártszerűség +pártszervezet +pártszolgálatos +párttag +párttagság +párttisztogatás +párttitkár +párttitkári +párttitkárság +párttörténet +pártütő +pártvezér +pártvezetés +pártvezető +párviadal +páskom +pászma +pásztáz +pásztor +pásztortűz +páter +páternoszter +pátosz +pátriárka +páva +pávás +páváskodik +pázsit +pacák +pacal +pacientúra +pacifikál +pacika +pacni +pacsirta +pacskol +pacuha +pad +padka +padlás +padlásablak +padláserkély +padlásfeljáró +padlásszoba +padló +padlódeszka +padlójú +padlórés +padlózat +padsor +pajkos +pajta +pajtás +pajtáskodik +pajtika +pajzán +pajzánság +pajzs +pakk +pakli +pakol +paktálás +palánk +palánkfal +palánta +palást +palástol +palack +palackos +palacsinta +palacsintasütő +palafedél +palaszürke +pali +palkonyai +pallér +pallérozás +pallérozatlan +pallérozott +palló +palota +palotás +palotai +pamacs +pamutharisnya +panasz +panaszkönyv +panaszkodás +panaszkodik +panaszol +panaszos +pancsol +pancsolás +pandúr +pandúros +paníroz +pankráció +pannóniai +panoptikumi +panoráma +panteisztikus +panyóka +panzió +pap +papa +papagáj +papagájszín +papaverin +papi +papír +papír-ceruza +papírbankó +papírcsomó +papírdarab +papírdarabka +papírforma +papírgyár +papírkatona +papírkosár +papírlap +papírpénz +papírpohár +papírrepülő +papírszalvéta +papírszelet +papírszeletke +papírtekercs +papírtrombita +papírvágó +papírvékony +papírzacskó +papiros +papirusz +paplak +paplan +papnövendék +papnő +papol +papos +paprika +paprikás +paprikásdoboz +paprikahalom +paprikapalánta +paprikaügy +paprikavörös +papucs +papucscsosszanás +papundekli +papuska +parádé +parádézik +parány +parányi +parázna +paráználkodik +paráznaság +parázs +parázslik +paradicsom +paradicsomi +paradicsomkaró +paradicsomkert +paradicsomos +paradicsompalánta +paradicsomrészleg +paradicsomügy +parafrázis +paragrafus +parancs +parancskiadás +parancsmegtagadás +parancsnok +parancsnokhelyettes +parancsnoki +parancsnokság +parancsol +parancsolat +parancsoló +parancsszegés +parancsszó +paranoiás +paraszpárti +paraszt +paraszt-képlet +paraszt-kispolgári +parasztarc +parasztasszony +parasztbor +parasztember +parasztfiú +parasztgyerek +parasztház +paraszthajszálnyi +paraszti +parasztlány +parasztnábob +parasztöntudat +parasztos +parasztpárt +parasztpárti +parasztpolitika +parasztruha +parasztruhás +parasztság +parasztszekér +paraván +parcella +pardon +pardonozik +parfümös +parfümszag +parízer +paripa +park +parkett +parkett-tánc +parketta +parkettviasz +parkíroz +parkol +parkosítási +parlag +parlament +parlamentáris +parlamenti +paróka +parókakészítő +parodista +parodizál +parolázik +paroli +parolis +part +parti +partizán +partizánköztársaság +partizánkodik +partizánlány +partizántiszt +partner +partoldal +partsáv +partszakasz +partszegély +parttető +partvíz +partvidék +partvis +pasa +pasas +pasi +paskol +passz +passzíroz +passzív +passzió +passzivitás +passzol +passzolgat +passzus +pasziánsz +pasztőrtej +pata +patak +patakocska +patakpart +pataktorkolat +patakzik +patentzár +patetikus +paticsfal +paticsfalú +patika +patikárius +patikamérleg +patikaszer +patikus +patikusék +patikusné +patina +patinás +patkány +patkánydög +patkányüldözés +patkó +patkószeg +patkol +patkolatlan +patkolóvas +patrícius +patríciusi +patrónus +patron +patronál +pattan +pattanás +pattanásos +pattantyús +pattint +pattog +pattogás +pattogató +pattogó +pattogós +pattogtat +patyolat +pauza +pavilon +pazar +pazarlás +pazarol +pécsi +pék +pékmester +példa +példány +példátlan +például +példáz +példázat +példabeszéd +példakép +példamutatás +példamutató +péntek +pénteki +pénz +pénzbüntetés +pénzcsinálás +pénzdarab +pénzecske +pénzember +pénzemésztő +pénzes +pénzeszsák +pénzharácsolási +pénzkérdés +pénznem +pénzpocsékolás +pénztár +pénztárablak +pénztárbelég +pénztárblokk +pénztárca +pénztárkönyv +pénztáros +pénztáros-kisasszony +pénztárosnő +pénzügy +pénzügyi +pénzügylet +pénzvilág +pép +peca +pecázás +pecázik +pecázó +pecabot +pecek +pech +peckes +pecsét +pecsétes +pecsétgyűrű +pecsétgyűrűs +pecsenye +pecsenyeliba +pecsenyeszín +pecsenyevadász +pedál +pedáns +pedagógia +pedagógiai +pedagógus +pedig +pedikűrös +pedikűrszalon +pedrő +pedz +pehely +pehelysúly +pehelysúlyú +pej +pelenka +pelenkaszegés +pelikán +pelyhedzik +pendely +pendelykémény +pendül +pendülés +penész +penészgombatelep +penészpofa +penészvirág +peng +penge +pengés +penget +pengetős +pengő +pengős +penna +penzió +penzió-dolog +peónia +pepepe +pepszin +per +perc +percéltű +perceg +percegés +perces +percmutató +percnyi +perdít +perdül +perdülés +perec +pereg +perel +perem +peremű +peresítés +pereskedés +perfekt +perforáció +pergamen +pergamenlapos +pergamenpállott +pergamentekercs +pergés +perget +pergőtűz +periódus +periódusezred +periódusmillió +periódusszázad +periódustized +peripatetikus +perlekedik +permet +permetez +permetezés +permetezik +permetezőgép +pernye +peron +perspektíva +persze +pertu +perverz +perverzitás +perzsa +perzsakabát +perzsalábkucsma +perzsaverő +perzsel +pesszimizmus +pesti +pestszentlőrinci +pestújhelyi +pesztra +petárda +petrencényi +petróleumlámpa +petróleumoshordó +petty +pettyes +petyhedt +petyhüdt +petyhüdt-édeskés +pezsgő +pezsgős +pezsgőspalack +pezsgőspohár +pezsgősüveg +pfű +pfuj +píp +pír +pia +piál +piás +piásüveg +piac +piaci +piackutatás +piacol +piacozik +piactér +pianó +pici +picike +piciny +picit +pihe +pihés +piheg +pihekönnyű +pihen +pihenés +pihenési +pihenő +pihenőhely +pihenőidő +pihenőóra +pihenőszoba +pihentet +pikáns +piké +pikémellény +pikíroz +pikkely +pikkelyes +pikszis +pilács +pilis +pilisi +pilisszentiváni +pilla +pillájú +pillátlan +pillanat +pillanatfelvétel +pillanatnyi +pillanatnyilag +pillangó +pillangónyakkendő +pillangószerű +pillant +pillantás +pillantgat +pille +pillér +pilléroszlop +pillog +pilóta +pimasz +pimaszkodik +pimaszság +pince +pincér +pincérfiú +pincérkabát +pincérlány +pincérnő +pincézik +pinceablak +pinceajtó +pinceboltozat +pincefal +pincehideg +pincelépcső +pincelejárat +pincelevegő +pincelyuk +pinceszag +pincsi +pingál +pingpongasztal +pingpongozik +pingvin +pintes +pióca +pionír +pipa +pipál +pipázik +pipacs +pipafüst +pipaszár +piperézkedik +piperecikk +piperezacskó +pipi +pipil +pipiske +pipiskedik +pipitér +pipogya +piramis +pirgál +pirít +pirítós +pirított +pirinyó +pirongat +pirongatás +pironkodik +piros +piros-fényes +piros-fehér +piroscserepes +piroscsíkos +piroslik +pirosodik +pirospaprika +pirospozsgás +pirul +pirula +pisil +pisis +piskóta +pislákol +pislant +pislog +pisszeg +pisszegés +pisze +piszkál +piszkálgat +piszkálódás +piszkafa +piszke +piszkos +piszkosfehér +piszkosság +piszkosszőke +piszkosszürke +piszlicsáré +piszmog +piszok +piszokul +pisztoly +pisztolycső +pisztolylövedék +pisztolytáska +pisztolytok +pitvar +pitvarajtó +pitvari +pitvarláb +pitvaros +pitye +pityereg +pityókos +pizsama +pizsamás +pláne +placc +plafon +plakát +plasztikgyáros +plasztikus +platán +platina +platinagyűrű +platinahaj +plató +platonisztikus +plazma +plébánia +plébániahivatal +plébános +pléd +pléh +pléhcsikó +pléhló +pléhpofa +plénum +plebejus +pletyka +pletykál +pletykás +pletykázik +pletykázó +pletykafészek +plomba +plüss +plüssfotel +plüssterítő +plusz +pluszadag +plutokrata +pneumatikus +pócgém +pócsmegyeri +pódium +pódiumművész +pók +pókerezik +pókháló +pókhálócsomó +pókhálós +pókhálószedés +pólus +pólya +pólyás +pópa +póráz +pórul +pórus +pórusú +pótapa +pótkávé +pótkocsi +pótkocsis +pótlás +pótlék +pótlólag +pótműszak +pótol +pótolhatatlan +pótsúly +pótszer +póz +pózna +pózolás +pöcegödör +pöcögtet +pödör +pöfékel +pöffeszkedik +pöfög +pöfögés +pökhendi +pökhendiség +pörget +pörgető +pörköl +pörkölt +pörköltmaradék +pörlekedik +pörög +pöröl +pörölycsapás +pörölyszerű +pörsenéses +pösze +pötyög +pötyögtet +pőre +pocak +pocakos +pocakszerű +pocsék +pocséta +pocsolya +pocsolyaíz +poén +pofa +pofás +pofátlan +pofázik +pofacsont +pofacsontú +pofafürdő +pofika +pofon +pofonegyszerű +pofonüt +pofonvág +pofoz +pogácsa +pogácsás +pogány +pogánykor +pogányság +poggyász +poggyászos +pohár +pohárka +pohárköszöntő +pohárszék +poharacska +pojáca +pokol +pokoli +pokróc +polarizáció +polc +polgár +polgárasszony +polgárellenesség +polgárháború +polgári +polgárjog +polgárjogi +polgármester +polgármesterné +polgárosul +polgárság +polgártárs +polgazd +polihisztor +polip +politechnikai +politika +politikai +politikai-társadalmi +politikus +politizál +politúrozás +politúrú +polivízió +pollák-eset +poloska +poloskás +pompa +pompájú +pompás +pompázik +pompakedvelő +pondró +pongyola +pongyolás +pont +pontatlan +pontocska +pontos +pontosan +pontosság +pontosságú +pontozóbíró +pontszám +ponty +ponyva +ponyvás +ponyvafüzet +por +porbasújtás +porc +porcelán +porceláncserép +porcika +porcogás +porcukor +porfelhő +porfelleg +porfírkád +porgörgeteg +porhüvely +porlad +porlatag +porlepte +porlik +porol +porolgat +poronty +poros +porosodik +porosz +poroszkál +porozás +porpehely +porréteg +porrongy +porszem +porszívó +porta +portás +portásfülke +portalanít +portéka +portenger +portré +portugál +portya +portyázik +poshadt +posta +postás +postáz +postakezelő +postaláda +postamester +postatiszt +posványosít +poszt +posztó +posztóféle +posztópapucs +posztóruha +potentát +potroh +pottyan +potya +potyautas +potyka +potyog +pozdorja +pozíció +pozitív +pozőr +pozsgás +pozsonyi +prágai +praktikus +praktizál +pram-pram +pravaz +praxis +préda +prédaság +prédikáció +prédikál +prédikátor +prém +prémdarabka +prémes +prémium +prémiumrendszer +prémvadász +prépost +prés +présel +préselődik +présház +precíz +precizitás +predelírium +prelátus +preparálás +preparátor +prepotens +presszó +presszó-csárda +presszóasztal +presszóasztalka +presszógép +presszósnő +presztízs +presztízsnövekedés +príma +prímás +prímási +priapusz-síp +pribék +pribékgúny +priccs +primitív +primőráru +priusz +priuszkönyv +priuszos +privátim +privilégiumlevél +prizma +próba +próbál +próbálgat +próbálkozás +próbálkozik +próbált +próbáltat +próbázás +próbaidő +próbaszolgálat +próféta +prófétai +prókátor +próza +probléma +problémázik +problémakör +problematika +problematikus +produkál +produkció +prof +proféta +professzionista +professzor +profetikus +profi +profil +profilú +profitál +prognózis +program +programbeszéd +programozó +programszerű +progresszív +proklamáció +prokurista +proletár +proletárbázis +proletárdiktatúra +proletárelem +proletáriátus +proletariátus +proli +propaganda +prostituált +prostitulált +protézis +protestáns +protokoll +protonerőmű +protonotárius +provincia +provokáció +provokál +provokáló +provokatív +prüsszög +prüszköl +prüszkölés +pruszlik +psziché +pszichózis +pszichológiai +pszichológus +pszichotikus +pszt +púder +púderozás +púp +púpos +púposodik +púpoz +púpozott +püffed +püffedt +püföl +pünkösd +püspök +püspöki +püspökkalap +püspökkenyérszerű +püspöklila +püspökség +püspökvár +pubertás +publikáció +publikálás +puccoskodik +puccs +pucér +pucol +pucolás +pucolkodik +pufajka +pufajkás +puff +puffad +puffadt +puffan +puffanás +pufók +pufog +pufogó +puha +puha-sárga +puhány +puhatestű +puhatolódzik +puhít +puhul +pukkad +pukkadozik +pukkantyú +puli +pulóver +pulóveres +pult +pulyka +pulykástál +pulykasült +pulzus +pumpa +pumpál +pumpálás +pumpaarc +pumpol +pupilla +puplinselyem +purdé +puska +puskás +puskacső +puskapor +puskatus-ütleg +pusmog +pusmogás +puszi +puszta +pusztán +pusztagazda +pusztagazdáné +pusztai +pusztaság +pusztít +pusztítás +pusztító +pusztul +pusztulás +putri +puttony +rá +rá-ráröffen +rááll +ráállít +ráad +ráadás +ráakad +ráb +rábámul +rábeszél +rábeszélő +rábír +rábíz +rábiccent +rábizonyít +rábólint +rábök +ráborít +ráborul +rábukkan +rác +rács +rácsap +rácsavarodik +rácsodálkozik +rácsos +rácsozat +rácsszerkezet +rácsúszik +rádió +rádióadás +rádióadó +rádióhívás +rádióhullám +rádiókészülék +rádiólámpa +rádiónyilatkozat +rádiórendszer +rádiós +rádiószolgálat +rádiótelefon +rádiótorony +rádióvevő +rádöbben +rádől +rádob +rádupláz +ráébred +ráébreszt +ráéhezik +ráépít +ráépül +ráér +ráérés +ráérő +ráérős +ráemel +ráereszkedik +ráerősít +ráesik +ráeszmél +ráfanyalodik +ráfér +ráfekszik +ráfelel +ráfest +ráfigyel +ráfintorít +ráfizet +ráfizetés +ráförmed +ráfonódik +ráfordítás +ráfordul +ráfúj +ráfut +ráfuttat +rág +rágalmaz +rágalmazás +rágalom +rágcsál +rágódik +rágondol +rágyújt +ráhagy +ráhajlik +ráhajol +ráharap +ráhederít +ráheveredik +ráhörög +ráhúz +ráhull +ráhurkol +ráír +ráírat +ráigazít +ráijeszt +ráirányul +ráismer +ráismerés +rájön +rák +rákacsint +rákapcsol +rákényszerít +rákérdez +rákerül +rákezd +rákínlódik +rákiált +rákkutatás +rákölt +rákönyököl +ráköszön +ráköszönt +ráköt +rákötöz +rákövetkező +rákoppint +rálép +rálehel +rálicitálás +rálök +rálő +ráma +rámás +rámagyaráz +rámegy +rámelegszik +rámenős +rámered +rámeszel +rámol +rámond +rámordul +rámosolyog +rámpa +rámutat +ránc +ráncigál +ráncol +ráncos +ránctalan +rándít +rándul +rándulás +ránéz +ránehezedik +ránevet +ráng +rángás +rángat +rángatás +rángatódzik +ránt +rántás +rántott +rántotta +rányílik +rányit +rányom +rányomtat +ráölt +ráömlik +ráönt +ráomlik +ráordít +ráparancsol +rápaskol +rápillant +rápillantás +rápingáltat +rápislog +ráránt +ráragad +ráragaszt +rárakódik +ráripakodik +rárivall +ráröhög +rárohan +ráront +rároskad +rásegít +rásimul +ráspolyoz +rásrófol +rásül +rásüt +rászáll +rászámít +rászán +rászárad +rászabadít +rászakad +rászed +rászegeződik +rászól +rászór +rászoktat +rászolgál +rászorít +rászorul +rászoruló +rátámad +rátámaszkodik +rátámaszt +rátalál +rátapad +rátapaszt +rátapos +rátarti +rátékozol +rátér +rátekint +rátenyerel +ráterít +rátermettség +rátestál +rátesz +rátör +rátűz +ráül +ráüt +ráüvölt +ráugrik +ráun +rávág +rávágtat +rávarr +ráver +rávesz +rávet +rávetít +rávetődik +rávezet +rávicsorog +rávigyorog +rávilágít +rávisz +ráz +rázár +rázás +rázendít +rázkódik +rázódik +rázogat +rázúdít +rázúdul +rázuhan +rab +rabbinus +rablánc +rablás +rabló +rablóbanda +rablógazdálkodás +rablógyilkos +rablóulti +rabol +raboskodik +rabruha +rabság +rabszolga +rabszolgafiú +rabszolgalány +rabszolgamunka +rabszolgatartás +rabszolgatartó +rabtárs +racionális +racionalizálás +racionalizálódás +racionalizmus +radar +radarberendezés +radír +radiátor +radikális +rafia +rafinált +ragály +ragályos +ragacs +ragacsos +ragad +ragadós +ragadozás +ragadozó +ragadtat +ragaszkodás +ragaszkodik +ragaszt +ragasztás +raglán +ragyás +ragyaábra +ragyog +ragyog-szikrázik +ragyogás +ragyogó +raj +rajong +rajongás +rajongó +rajparancsnok +rajta +rajtacsíp +rajtakap +rajtaveszt +rajz +rajzasztal +rajzfigura +rajzik +rajzlap +rajzol +rajzolás +rajzolat +rajzoló +rajzolóasztal +rajzolódik +rajzoltat +rajztanár +rajzú +rak +rakás +rakat +rakéta +rakétajármű +rakétanyomás +rakétatechnika +rakétatelep +rakétatömeg +rakia +rakódik +rakodás +rakodik +rakodó +rakodómunkás +rakodótárs +rakomány +rakosgat +rakott +rakpart +rakparti +raktár +raktárablak +raktárajtó +raktárépület +raktárfülke +raktárhelyiség +raktárkészlet +raktárkulcs +raktáros +raktározási +rampa +randalíroz +randevú +randevúzik +randi +randizik +rang +rangfokozat +rangidős +rangjelzés +rangkülönbség +ranglétra +rangos +rangsor +rangsorol +rangsorrend +rangszerzés +rangú +rapid +rapszódia +ravasz +ravaszcsattanás +ravaszkás +ravaszkodik +ravaszság +ravatal +ravatalozó +razol +razzia +re +rég +régész +régen +réges-régen +régi +régidő +régies +régiesség +régifajta +régimódi +régió +régiség +régiségi +régóta +rékli +rém +rémdráma +rémes +rémhírterjesztő +rémít +rémítgetés +rémiszt +rémkép +rémlik +rémül +rémüldözik +rémület +rémületes +rémült +rémuralom +répa +répaföld +répalevél +rés +réselőgép +résnyi +rész +részanyag +részben +részére +részéről +részecske +részeg +részeges +részegeskedik +részegség +részegültség +részes +részesedés +részesedik +részesít +részesül +részint +részleg +részlegvezető +részlet +részletes +részletesség +részletez +részletezés +részletfelismerés +részletfizetés +részletgyőzelem +részletkérdés +részletvázlat +résztvevő +részvény +részvényköteg +részvénytársaság +részvét +részvétel +részvétlen +részvétteljes +rét +réteg +réteges +rétegű +rétes +réti +rétoriskola +rétség +rév +révén +révész +réveteg +révetegség +réz +rézcsat +rézcső +rézdárda +rézfényű +rézfúvós +rézgálic +rézgomb +rézgombos +rézgyűrű +rézhegyű +rézhenger +rézkarika +rézkilincs +rézlemez +réznehezék +rézpénz +rézpor +rézsas +rézsút +rézsű +réztábla +réztányér +rézüst +rézveret +rézvörös +reálbér +reális +reagál +reagálás +reakció +reakcióképtelenség +reakciós +realitás +realizál +realizmus +rebben +rebbenés +rebeg +rebellió +rebesget +reccsen +reccsenés +recés +recéz +recepció +recept +receptblokk +receptpapír +recitál +recseg +recsegés +recsegő +redő +redőny +redves +referáda +referál +referátum +reflektor +reflektorfény +reflex +reform +reformáció +református +refrén +regéci +regény +regényes +regényhős +regényírói +reggel +reggelenként +reggelente +reggeli +reggelizés +reggelizik +reggelt +regiszter +regisztrálás +reglama +regruta +regula +rejlik +rejt +rejtély +rejtélyes +rejtélyeskedik +rejteget +rejtek +rejtekajtó +rejtekhely +rejtekút +rejtelem +rejtelmes +rejtett +rejtettség +rejtőzés +rejtőzik +rejtőzködik +rejtvény +rekamié +reked +rekedt +rekedtes +rekesz +rekkenő +reklám +reklámcél +reklámfigura +reklámötlet +reklamáció +reklamál +rekonstruál +rekviem +rekviemes +rekvirál +relatív +relatíve +rembrandt-film +remél +remélhető +remény +reménybeli +reménykedés +reménykedik +reménység +reménytelen +reménytelenség +remeg +remegés +remegtet +remek +remekmű +remeteélet +remeteség +remíz +rend +rendbehoz +rendbehozás +rendben +rendbentartás +rendbeszed +rendbetétel +rendbontás +rendbontó +rendcsinálás +rendcsináló +rendész +rendel +rendelés +rendelet +rendelkezés +rendelkezik +rendelkező +rendellenes +rendellenesség +rendelmény +rendelő +rendeltetés +rendeltetésű +rendes +rendetlen +rendetlenkedik +rendetlenség +rendez +rendezés +rendezetlen +rendezett +rendezettség +rendezget +rendezkedik +rendező +rendeződik +rendezői +rendezőképesség +rendezőség +rendezvény +rendfokozat +rendfokozatú +rendház +rendhagyó +rendíthetetlen +rendje-módja +rendjeles +rendkívül +rendkívüli +rendőr +rendőrautó +rendőrcilinder +rendőrezredes +rendőrfőkapitányság +rendőri +rendőrkapitány +rendőrközeg +rendőrkordon +rendőrlegény +rendőrminisztérium +rendőrminiszter +rendőrmunkás +rendőrőrs +rendőrorvos +rendőrség +rendőrségi +rendőrspicli +rendőrtiszt +rendőrtiszti +rendre +rendre-rendre +rendreutasít +rendszám +rendszámú +rendszer +rendszeres +rendszeresít +rendszerez +rendszerezés +rendszerint +rendszertelen +rendszerű +rendületlen +rendű +rendű-rangú +rendzavarás +renegát +reneszánsz +reneszánszkodás +reng +rengeteg +repdes +reped +repedés +repedezik +repedt +repeget +repes +repesz +repeszt +repít +repkény +repkényfüggöny +repked +replika +reprezentáció +reprezentációs +reprezentál +reprezentatív +reprodukálás +reprodukció +reprodukciómelléklet +reprogram +repül +repülés +repülő +repülő-főparancsnok +repülőakadémia +repülőbomba +repülőbrigád +repülőgép +repülőgép-szerelő +repülőgépmotor +repülőgépszerű +repülőgépzúgás +repülőkötelék +repülőszázad +repülőszerencsétlenség +repülőtér +repülőtérszag +repülőút +resó +rest +restancia +restauráció +restaurál +restaurálás +restelkedés +restelkedik +restell +restellnivaló +reszel +reszelő +reszelős +reszket +reszketés +reszketeg +resztel +retek +retesz +retikül +retteg +rettegés +rettegő +rettegtetés +rettenet +rettenetes +rettenthetetlen +rettentő +retusál +reuma +revanzsál +reverenda +reverendás +revolver +revolverdörrenés +revolvergolyó +rexasztal +rezdül +rezdülés +rezeg +rezegtet +rezervátum +rezesbanda +rezgés +rezgő +rezignált +rezonál +rezsi +rezsim +rezzen +rezzenés +rezzenéstelen +rezzenetlen +rf +rí +rímel +riad +riadalom +riadó +riadóautó +riadozik +riadt +riaszt +riasztás +riasztó +riasztócsengő +ribanc +ribizli +ribizlibokor +rideg +ridegség +rigmus +rigó +rigóölő +rikácsol +rikácsolás +rikító +rikkancs +rikkancs-jelmondat +rikkant +rikkantás +rikolt +rikoltozás +rikoltozik +rikoltozó +rimánkodás +rimánkodik +ring +ringás +ringat +ringatózik +ringlispil +ringlófa +ringsegéd +ringyó +ripityára +riport +riporter +riporteri +riportmérgezés +riposztozik +riszál +ritka +ritkás +ritkaság +ritkít +ritkul +ritmikus +ritmus +ritmusos +ritmusú +rituálé +rivális +rivalda +rizs +rizskása +rizsporos +rizsporoz +ró +róka +rókázik +rókaképű +rókalyuk +rókaorr +róla +róma-ellenes +római +róna +rózsa +rózsás +rózsacsokor +rózsadombi +rózsafa +rózsafüzér +rózsafüzéres +rózsafüzérszem +rózsakert +rózsaláng +rózsaszál +rózsaszín +rózsaszín-kék +rózsaszínű +rózsaszirom +rózsatő +röfög +röfögésszerű +röfögő +rög +rögdarab +rögeszme +röghegység +rögös +rögtön +rögtöni +rögtönöz +rögtönzés +rögvest +rögzít +rögzíthetetlen +röhej +röhejes +röhincsél +röhög +röhögés +röpcédulázás +röpirat +röpke +röplabda +röplap +röppálya +röppen +röppenős +röpte +röptér +rövid +rövidesen +rövidhullám +rövidhullámú +rövidít +rövidítés +rövidke +rövidlátó +rövidnadrág +rövidség +rövidzárlat +rőt +rőzse +robaj +robajlik +robban +robbanás +robbanó +robbant +robbantás +robbantási +robog +robot +robotember +robotol +robusztus +rocska +rogy +rogyás +rogyadozik +rogyaszt +rohad +rohadás +rohadt +roham +rohamoz +rohampálya +rohamsisak +rohamsisakos +rohamtempó +rohan +rohanás +rohangál +rohaszt +rojalista +rojt +rojtos +rokka +rokkant +rokon +rokoni +rokonlátogatás +rokonlélek +rokonság +rokonsorsú +rokonszenv +rokonszenves +rokonszenvez +rokonszenvezés +rokonszenvező +roller +rom +román +románkori +romantika +romantikus +rombol +rombolás +romboló +rombusz +romház +romhalmaz +romlás +romlatlan +romlik +romlott +romlottság +romos +roncs +roncskupac +ronda +rondírásos +rondít +rongál +rongy +rongybaba +rongycsomó +rongydarab +rongyocska +rongyos +rongyoskodás +rongyrázás +rongyszedés +rongyszerű +rongyszőnyeg +rongyterítő +ront +rop +ropog +ropogás +ropogós +ropogtat +roppan +roppanás +roppant +roskad +roskadás +roskadozik +roskatag +rosseb +rossz +rossz-szabású +rosszakarat +rosszakaratú +rosszakaró +rosszall +rosszallás +rosszalló +rosszarcú +rosszízű +rosszindulat +rosszindulatú +rosszkedv +rosszkedvű +rosszkor +rosszmájúság +rossznézésű +rosszullét +rost +rosta +rostély +rostélyos +roszog +rothad +rothadás +rotyog +rovás +rovátka +rovar +rovarforma +rovargyűjtemény +rovat +rozetta +rozoga +rozs +rozsda +rozsdás +rozsdásodik +rozsdafoltos +rozsdamarta +rozsdaszínű +rozsdavörös +rozzant +rúd +rúg +rúgás +rúgkapálózás +rúgtat +rút +rúzs +rúzsoz +rúzstalan +rücskös +rügy +rügyezik +rühell +rubin +rubrika +rudizik +rugalmas +ruganyos +ruganyosság +rugdal +rugdos +rugdosás +rugó +rugózik +ruha +ruhácska +ruhájú +ruhás +ruháskosár +ruhátlan +ruház +ruházat +ruházati +ruházkodás +ruhadarab +ruhaféle +ruhagyár +ruhakölcsönző +ruhanemű +ruhasor +ruhaszag +ruhaszekrény +ruhatár +ruhatári +ruhatáros +ruhatároskodik +ruhatárosnő +ruhaüzlet +ruhonyai +rulett +rulettasztal +rulettfelszerelés +rum +rumbázik +rumcsika +rumli +rumocska +rumoshordó +rupó +ruszinszkói +ruszki +rutin +rutinhülyéskedés +rutinmunka +rutinos +ság +sági +sál +sámán +sámli +sánc +sánta +sántaság +sántít +sántítás +sántikál +sáp +sápadozik +sápadt +sápadtság +sápítozik +sár +sárcsimbók +sárfészek +sárga +sárgája +sárgállik +sárgás +sárgásbarna +sárgáskék +sárgástarka +sárgásvörös +sárgászöld +sárgabarack +sárgadinnye +sárgamintás +sárgarépa +sárgaréz +sárgarigó +sárgarigófészek +sárgul +sárkány +sárkánylábú +sárkánymozdonyos +sárkányos +sárkányzászló +sárkolonc +sáros +sárréteg +sárréti +sás +sáska +sásos +sátán +sátáni +sátor +sátorfa +sátorfelszerelés +sátorlap +sátorpalota +sáv +sávos +sablon +sablonos +saccol +sadal +saját +sajátos +sajátosság +sajátság +sajátságos +sajgás +sajgó +sajka +sajnál +sajnálat +sajnálatos +sajnálatraméltó +sajnálkozás +sajnálkozik +sajnos +sajog +sajt +sajtár +sajtkereskedés +sajtkereskedő +sajtó +sajtószabadság +sajtótermék +sajtóvonal +sajtol +sajtos +sakál +sakálcsapat +sakk +sakk-készlet +sakkfigura +sakkozik +sakkrejtvényfejtés +sakktábla +saláta +salátástál +salak +salakos +salétrom +salétromábrás +salfény +sanda +sandít +sansz +sanyargat +sanyarú +sapka +sapkás +sarjad +sarjerdő +sarkall +sarkantyú +sarki +sarkos +sarkú +sarkvidék +sarló +saroglya +sarok +sarokasztal +saroknyi +sarokvas +saru +sas +sasmadár +sasszem +satíroz +satnya +satöbbi +satu +satupad +savanykás +savanyú +savanyúság +savanyúvízforrás +savó +savószemű +savószínű +séf +séma +sérelem +sérelmes +sért +sértés +sérteget +sértegető +sértetlen +sértett +sértettség +sérthetetlen +sértő +sértődékeny +sértődés +sértődött +sértődöttség +sérülés +sérült +séta +sétál +sétálás +sétálgat +sétálgatás +sétáló +sétáltat +sétány +sétatér +sétaút +seb +sebész +sebészfőorvos +sebes +sebesedik +sebesség +sebesül +sebesülés +sebesülési +sebesült +sebez +sebezhetetlen +sebezhető +sebhely +sebhelyes +sebláz +sebtében +sebzett +segéd +segédcsapat +segédelőadó +segéderő +segédjegyző +segédkezik +segédlet +segédlevelező +segédmunkás +segédmunkási +segédorvos +segédszervezet +segédtanár +segédtiszt +segél +segély +segélyez +segélykérő +segélykiáltás +segg +seggű +segít +segítő +segítőkész +segítőkészség +segítség +segítségkérő +sehogy +sehogyan +sehol +sehonnan +sehova +sej +sejehuja +sejt +sejtés +sejtelem +sejtelmes +sejtet +sejthető +sekély +selényi-féle +selejtezés +sellő +selyem +selyemanyag +selyemernyőjű +selyemfényű +selyemhernyógubó +selyemkárpitos +selyemkendő +selyemkereskedés +selyemöv +selyempapír +selyempapiros +selyemruha +selyemsál +selyemszalag +selyemszoknya +selyemvánkos +selyemzsinór +selymes +sem +sematikus +semennyi +semhogy +semleges +semmi +semmiféle +semmiképpen +semmilyen +semminemű +semminő +semmint +semmirevaló +semmiség +semmittevés +senki +senyved +seppeg +seprő +seprős +seprű +seprűnyél +serceg +sercegés +sercegő +sercen +serdül +serdülő +serénykedik +sereg +seregélyraj +sereglés +sereglik +seregszemle +serke +serken +serkent +serpenyő +sertés +sertésgondozó +sertésmáj +sertésól +sertéspörkölt +sertésvágási +seszínű +settenkedik +sezlon +síel +sík +síkos +síkság +sín +sínadrág +sínadrágos +sínjavítás +sínjavító +sínkalapács +sínpár +sínrengeteg +síp +sípcsont +sípol +sípolás +sír +sír-nevet +sírás +sírásó +sírású +sírbolt +sírdogál +sírdomb +sírfedőlap +sírgondozó +sírhatnék +sírhely +sírkamra +sírkő +sírógörcs +sírós +sírós-nyikorgós +sírontúli +sítalp +sítúra +sívó +siet +sietős +sietség +siettet +siheder +sikál +sikátor +sikankó +siker +sikeres +sikersorozat +sikertelenség +sikerül +sikerült +siketfajd +sikít +sikítás +sikítoz +sikkaszt +sikkasztás +siklás +siklik +sikló +siklózik +sikolt +sikoltás +sikoltoz +sikoly +sikong +sikongat +silány +silányság +sild +siller +sima +simabőrű +simít +simítás +simítgat +simogat +simogatás +simul +simulékony +simuló +sincs +sintér +siófoki +sipít +sirály +sirám +siránkozik +siralmas +siralomház +siralomházi +siralomvölgy +sirat +sirató +sisak +sisakos +sistereg +sistergés +sittyen +sivár +sivárság +sivalkodás +sivalkodik +sivatag +sivatagi +sivít +sivítás +skála +skalp +skandál +skandináv +skarlátfolt +skatulya +skatulyaház +skicc +skót +skorpió +skurc +sláger +slafrok +slampos +slepp +slicc +slingel +slukk +slusszkulcs +slusszlánc +smaragd +smaragdzöld +sminkréteg +smirgli +smonca +smonculi +smucig +snájdig +snassz +só +sóbánya +sóder +sóderes +sóderos +sógor +sógorasszony +sógornő +sóhaj +sóhajt +sóhajtás +sóhajtásszerű +sóhajtozás +sóhajtozik +sóher +sókereskedő +sólet +sólyom +sós +sósav +sóska +sóskifli +sósperec +sóstó +sótartó +sóvár +sóvárgás +sóvárgás-színezet +sóvárgós +sóvárog +sóz +söntés +söntéspult +söpör +söpörget +söprés +söpröget +sör +sörét +sörerdős +sörfürdő +sörgyár +sörgyári +sörház +sörhiány +sörital +sörivás +sörkampány +sörnyitó +sörös +söröscsap +söröshordó +söröskocsi +söröskorsó +söröskrigli +sörösüveg +sörözik +söröző +sörpocsolya +sörszag +sörte +sörtés +sörteforma +sörtermelés +sörteszerű +sötét +sötétbarna +sötétedés +sötétedik +sötétítő +sötétkék +sötétlik +sötétlila +sötétpej +sötétpiros +sötétség +sötétszőke +sötétszürke +sötétül +sötétvörös +sötétzöld +sövény +sövényfal +sőt +sodor +sodrás +sodrású +sodró +sodródik +sodrony +sodronykötél +sodronyos +sofőr +sofőrülés +soha +sohasem +sok +sok-sok +soká +sokáig +sokára +sokadalom +sokadik +sokadmagával +sokall +sokaság +sokasodik +sokatmondó +sokbeszédű +sokdioptriás +sokfajta +sokféle +sokféleség +sokfejű +sokfelé +sokgyermekes +sokk +soknyelvű +sokoldalú +sokráncú +sokszínű +sokszoros +sokszorosít +sokszorosító +sokszorosítógép +sokszoroz +soktornyú +solymári +somfa +somogyi +somolyog +sompolyog +sonka +sonkás +sonkaforma +sopánkodás +sopánkodik +soproni +sopronszerte +sor +során +sorakozik +sorakozó +sorakoztat +sorbanállás +sorfal +sorjában +sorjáz +sorjázik +sorjáztat +sorkatona +soroksári +sorol +sorompó +soros +soroz +sorozás +sorozat +sorozatos +sorozatvető +sorra +sorravesz +sorrend +sors +sorscsapás +sorsfordulat +sorsforduló +sorshúzás +sorsszerű +sorstárs +sorsú +sorsüldözött +sorsverte +sortűz +sorvad +sorvadozás +sorvaszt +sorvég +sorvégjelző +sovány +soványodik +soványság +spájz +spájzol +spárga +spártai +spagetti +spalettás +spanyol +spanyolfal +spanyolországi +sparhert +spén +speciális +specialista +specialitás +specializál +specifikum +specifikus +spekuláció +spekuláns +sperhakni +spermai +spicces +spicli +spirál +spirálcsúszda +spirálkar +spirálvonulat +spiritualitás +spiritualizmus +spór +spórol +spongya +spontán +spontaneitás +sport +sportbarát +sportcsarnok +sportegyesület +sportember +sportesemény +sportfiú +sporthír +sportkabát +sportklub +sportkocsi +sportnadrág +sportol +sportoló +sportpálya +sportruhás +sportsapka +sportszatyor +sportszenvedély +sportszerűség +sportszerűtlen +sportszínvonal +sporttárs +sporttelep +sportújság +sportújságírónő +sportzakó +sportzakós +spriccel +srác +sróf +ssss +stáció +stádium +státus +státusbővítés +stabilizál +stafírung +stallum +stampedli +stand +standardmunka +stanicli +start +start-sorrend +starter +startgép +starthely +statáriális +statikai +statisztaszerep +statisztika +statisztikai +statisztikus +stb +stég +stekkoló +stencil +steril +stílszerű +stílus +stílusos +stílusú +stich +stiches +stikkelés +stilizált +stimmel +stóla +stop +stopper +stoppol +stráfkocsi +strázsál +stramm +strand +strandbója +strandélet +strandfotográfus +strandfürdő +strandfürdői +strandolás +strandoló +strandpapucs +strandszezon +strandtáska +strapa +strapál +stratégia +strici +strigó +strucctoll +strucctollas +stúdium +stuccol +stuccoltat +súg +súg-búg +sújt +sújtás +sújtólégrobbanás +súly +súlyarány +súlyos +súlyosodik +súlyoz +súlypont +súlytalan +súlytalanság +súlyviszony +súlyzó +súrlódás +súrlódik +súrol +süket +süketítő +süketnéma +süketség +sül +sül-fő +süldő +sületlen +sületlenség +süllyed +süllyeszt +süllyesztő +sült +sülve-főve +sün +sündisznó +süpped +süppedékes +sürget +sürgetés +sürgető +sürgölődés +sürgölődik +sürgöny +sürgönykihordó +sürgős +sürög +sürög-forog +süt +sütemény +süteményes +süteményespult +sütkérezik +sütnivaló +sütöget +sütő +sütőlapát +sütőmunkás +süttet +süveg +süvegű +süvít +süvölt +süvölvény +sűrít +sűrű +sűrűség +sűrűségviszony +sűrűsödik +suba +subernyák +sublót +sudár +sugár +sugárfegyver +sugárgerenda +sugárkéve +sugármentesítő +sugárözön +sugároz +sugárpisztoly +sugárút +sugárzás +sugárzásveszély +sugárzik +sugárzó +sugárzóna +sugall +sugallat +sugalmaz +sugaras +sugarú +sugdolódzás +sugdolódzik +sugdos +suhan +suhanás +suhanc +suhancgyűrű +suhog +suli +sulykol +sumér +summa +summáskodik +summáz +sunyi +sunyít +surmó +surrog +surrogás +susmog +susmusol +susog +sustorgás +sustorog +suszter +suszterlegény +suszterség +sut +suta +sutaság +sutavad +suttog +suttogás +suttogó +suttyó +suttyókor +suttyomban +sváb +svábozik +sváda +svádájú +svájci +svájcisapka +svéd +száguld +száguldás +száguldozás +száguldozik +száj +szájahúzott +szájcsücsök +szájíz +szájmozgás +szájpadlás +szájszél +szájszöglet +szájú +szál +szálas +szálegyenes +szálfa +szálkás +száll +szállás +szálláshely +szálldogál +szálldos +szállít +szállítás +szállítási +szállítmány +szállító +szállítóeszköz +szállítógép +szállítókocsi +szállítómunkás +szállingózik +szálló +szállóigazolvány +szállóige +szállóvendég +szálloda +szállodás +szállodabeli +szállodai +szállodaszoba +szállong +szálú +szám +számára +számadás +számadó +számba +számbavétel +számít +számítás +számítási +számítgat +számítható +számítógép +számjegy +számkivetett +számkülönbség +számla +számlál +számlálhatatlan +számlapos +számol +számolgat +számoló +számoló-rács +számológép +számonkérés +számos +számottevő +számotvetés +számozás +számrendszer +számszerű +számtalan +számtalanféle +számtan +számtanácsos +számú +száműz +száműzetés +száműzött +szán +szánakozás +szánakozik +szánalmas +szánalom +szándék +szándékol +szándékos +szándékosság +szándékozik +szándékú +szánkázik +szánkó +szánt +szántás +szántásos +szántai +szántatlan +szántó +szántóföld +szántóföldi +szántság +szár +szárad +száradás +száraz +szárazbejáró +szárazdajka +szárazföldi +szárazság +szárítgat +szárítkozik +szárítóbura +szárított +származás +származási +származású +származék +származékú +származik +szárny +szárnyacska +szárnyal +szárnyalású +szárnyas +szárnyaszegett +szárnycsapás +szárnycsapkodás +szárnyék +szárnysegéd +szárnysuhogás +szárnyú +szárú +szász +száz +száz-kétszáz +száz-száz +száz-százöt +század +századbeli +századbiztos +századeleji +századforduló +századi +századik +százados +századosi +századparancsnok +századrész +százalék +százalékos +százas +százéves +százegy +százegyedik +százegynéhány +százesztendős +százezer +százféle +százforintos +százhármas +százharminc +százharmincezer +százharmincféle +százharminchárom +százhatvan +százhatvanezer +százhetvenegyes +százhetvenharmadik +százhetvenkét +százholdas +százhúsz +százhuszonnyolc +százkettes +százkilencvenhat +százkilós +százméteres +százmillió +száznegyven +száznegyvenezer +száznyolcvan +százötven +százötven-kétszáz +százszázalékos +százszoros +százszorta +száztagú +száztíz +száztizennégy +szab +szabály +szabályellenes +szabálykönyv +szabályos +szabályoz +szabályozás +szabálysértés +szabályszerű +szabálytalan +szabálytalanság +szabályzat +szabás +szabású +szabad +szabadalom +szabadegyetemi +szabadfoglalkozás +szabadít +szabadítás +szabadjára +szabadkőműves +szabadkozás +szabadkozik +szabadlábon +szabadlábra +szabadnap +szabadnapos +szabados +szabadrúgás +szabadság +szabadság-hegyi +szabadságharc +szabadságharcos +szabadsághős +szabadságidő +szabadságjog +szabadságvesztés +szabadszájú +szabadtéri +szabadul +szabadulás +szabatos +szabdal +szablya +szabó +szabóság +szabolcsi +szabotál +szabotázs +szabvány +szabványeset +szadista +szadizmus +szaft +szaftos +szag +szagfelhő +szaggat +szaggatott +szaglás +szaglász +szaglászás +szaglik +szagol +szagolgat +szagosbükköny +szagosszappan-vásárlás +szagú +szagzuhatag +szajha +szajkó +szajkóz +szajna-parti +szajré +szak +szakács +szakácskönyv +szakácsmester +szakácsné +szakácsnő +szakáll +szakállas +szakálltorzs +szakállú +szakad +szakadás +szakadásos +szakadatlan +szakadék +szakadozik +szakadozott +szakadt +szakadta +szakajtó +szakasz +szakaszparancsnok +szakasztott +szakaszvezető +szakdolgozat +szakérettségi +szakérettségis +szakérettségiző +szakértelem +szakértő +szakértői +szakember +szakfolyóirat +szakgimnázium +szaki +szakít +szakirodalom +szakképesítés +szakképzettség +szakkönyv +szakkör +szaklexikon +szakma +szakmabeli +szakmai +szakmunkás +szakmunkásvizsga +szakorvos +szakos +szakozik +szakrális +szakramentum +szakszerű +szakszervezet +szakszervezeti +szakszókincs +szakszövetkezet +szaktárs +szaktanács +szaktudású +szalámi +szalámis +szalámivég +szalámizás +szalad +szaladgál +szaladjlányom-féle +szalag +szalagos +szalajt +szalaszt +szalma +szalmacsóva +szalmakalap +szalmakalapos +szalmakazal +szalmakupac +szalmaláng +szalmaszál +szalmatető +szalmatetős +szalmatörek +szalmazsák +szalon +szaloncukor +szalongarnitúra +szalonkabát +szalonképes +szalonmunka +szalonna +szalonnázik +szalonnaadag +szalonnabőr +szalonnadarabka +szalonvicc +szalonzene +szalonzenekar +szaltó +szalutál +szalvéta +szamár +szamárkóró +szamárság +szamaras +szamóca +szamócadzsem +szamovár +szanál +szanálás +szanaszét +szanatórium +szandál +szapora +szaporáz +szaporaság +szaporít +szaporodik +szappan +szappanbuborék +szappanfolt +szappanoz +szapul +szar +szarás +szardínia +szardíniásdoboz +szarevő +szarfaló +szarházi +szarka +szarkóma +szarkofág +szaros +szarság +szaruhártya +szarukeretes +szarusodik +szarv +szarvas +szarvasagancs +szarvasbika +szarvasbőgés +szarvasbőr +szarvasmarha +szarvastehén +szaténpongyola +szatmári +szatócs +szatócsbolt +szattyán +szattyánbőr +szattyánpiros +szatyor +szavahihető +szavajárása +szaval +szavalás +szavaló +szavalókórus +szavalóverseny +szavatosság +szavaz +szavazati +szavazó +szavú +szaxofon +szédeleg +szédelgő +szédít +szédítő +szédül +szédülés +szédület +szédületes +szédült +széf +szégyell +szégyellnivaló +szégyen +szégyenbélyeg +szégyenérzet +szégyenkezés +szégyenkezik +szégyenletes +szégyenlős +szégyenteljes +széjjel +széjjelfut +széjjelnéz +széjjelolvad +széjjelrág +széjjelsugárzik +széjjelszór +széjjeltép +széjjelzavar +szék +székel +székely +székesegyház +székesfehérvári +székház +székhely +székhuzigálás +széklet +széksor +széktámla +szél +szélárnyék +szélcserzett +széles +szélesarcú +szélesedik +szélesít +szélhámos +szélhordta +széljárás +széljegyzet +szélkakas +szélmalom +szélrózsa +szélről +szélroham +szélsebes +szélső +szélsőséges +szélsuttogás +széltében +széltében-hosszában +széltére +szélütés +szélütött +szélű +szélvédett +szélvédő +szélvésszerű +szélvihar +szén +széna +szénásszekér +szénaillatú +szénakazal +szénalétra +szénatartó +szénfal +szénfekete +szénhalom +szénhegy +szénhordás +szénmonoxid +szénnagykereskedő +szénporrobbanás +szénrakás +szénrakodás +széntüzelésű +szép +szépapa +szépasszony +szépérzék +széphistória +szépírás +szépít +szépítés +szépítkezés +szépirodalom +szépség +szépséges +szépségeszmény +szépséghiba +szépségideál +szépségű +szépségverseny +szér +széria +szérű +szérűskert +szérumgyár +szétágazik +szétárad +szétbomlik +szétbont +szétbontogat +szétcsap +szétcsattan +szétdarabol +szétdörzsöl +szétdob +szétdobál +szétesik +szétfejt +szétfekszik +szétfeszít +szétfolyik +szétfolyó +szétfoszlik +szétfröccsen +szétfut +szétgöngyöl +szétgurul +széthány +széthasad +széthasít +széthord +széthordanivaló +széthúz +széthúzódás +széthúzódik +széthull +szétken +szétkenődik +szétkerül +szétköpdös +szétküld +szétküldözget +szétkuszál +szétlapít +szétlapult +szétlök +szétlő +szétmállaszt +szétmállik +szétmarcangol +szétmegy +szétmutat +szétnéz +szétnyílik +szétnyit +szétnyom +szétolvad +szétolvadás +szétoszlat +szétoszlik +szétoszlódik +szétoszt +szétosztás +szétpattogzik +szétpazarol +szétporladozik +szétporlik +szétporlódik +szétrebben +szétrebbenés +szétreped +szétrepedezik +szétrepeszt +szétrepít +szétrobban +szétrobbant +szétroncsol +szétroppant +szétrúg +szétsimít +szétsugárzik +szétsuhan +szétszállingózik +szétszaggat +szétszakad +szétszakít +szétszalad +szétszéled +szétszed +szétszedhető +szétszilánkol +szétszór +szétszóródik +szétszórt +széttár +széttaglalás +széttartólagos +széttép +széttekint +széttereget +szétterít +szétterjed +szétterpeszt +szétterül +szétterülő +széttölt +széttör +széttörik +széttrancsíroz +szétugraszt +szétugrik +szétvág +szétválaszt +szétválik +szétver +szétvet +szétzavar +szétzilálás +szétzúzás +szed +szedés +szedeget +szedelőzködik +szeder +szederfa +szederjes +szedet +szedett-vedett +szedres +szefárd +szeg +szegély +szegélyez +szegélykötél +szegény +szegényember-kölcsön +szegényes +szegényke +szegénylegény +szegényparaszt +szegényparasztság +szegénység +szegénységi +szegényszag +szegényvidéki +szegecs +szegedi +szeges +szegez +szegeződik +szegfű +szegfűcsokros +szegfűszeg +szeghalmi +szeglet +szegődik +szegődtet +szegről-végről +szegy +szekér +szekéralj +szekércsapat +szekérderék +szekéroldal +szekéroszlop +szekérrúd +szekérsor +szekérút +szekeres +szekerez +szekrény +szekrényajtó +szekrényke +szekretárius +szekszárdi +szekta +szektás +szektásság +szektor +szel +szeleburdi +szelecske +szelektál +szelence +szelep +szeles +szelet +szeletel +szeletke +szelíd +szelídít +szelídség +szelídül +szellem +szellemes +szellemeskedik +szellemesség +szellemi +szellemi-lelki +szellemű +szellentés +szellő +szellős +szellőzködés +szellőzködik +szellőzőkészülék +szellőzőnyílás +szellőztetés +szellőztetési +szem +szemafor +szembe +szembe-szembetalálkozik +szembeállít +szembefordul +szembejön +szembekerül +szembekerülés +szembemegy +szemben +szembenáll +szembenállás +szembenéz +szembenyíló +szembesít +szembesítés +szembeszáll +szembeszegez +szembeszegül +szembeszökő +szembetalál +szembetűnő +szemből +szembogár +szemcsés +szemcsenagyság +személy +személyautó +személyautó-forgalom +személyazonosság +személycsere +személyes +személygépkocsi +személyi +személyiség +személyiségváltozás +személykocsi +személyszállító +személytelen +személytelenség +személyvonat +személyzet +személyzet-néger +személyzeti +személyzetis +szemérem +szeméremajak +szemérmes +szemérmesség +szemérmetes +szemérmetlen +szemét +szemétdomb +szemétgyűjtő +szeméthalom +szeméthegy +szemétkedik +szemétkosár +szemétkupac +szemétláda +szemétmontázs +szeméttartó +szemefénye +szemenszedett +szemerkél +szemernyi +szemes +szemetes +szemetesvödör +szemez +szemezget +szemfényvesztés +szemfedél +szemfedő +szemfehér +szemfog +szemforgató +szemfüles +szemgödör +szemgödrű +szemgolyó +szemhatár +szemhéj +szemhunyorítás +szeminárium +szemináriumi +szemita +szemjáték +szemjegy +szemközt +szemközti +szemlátomást +szemle +szemlél +szemlélet +szemléletes +szemlélget +szemlélő +szemlélődés +szemlélődik +szemlélődő +szemlencse +szemölcs +szemölcsféle +szemöldök +szemöldökcsont +szemöldökfa +szemöldökű +szempár +szempilla +szempillantás +szempont +szemrés +szemrebbenés +szemrehányás +szemrehányó +szemrevételez +szemrontó +szemszög +szemtanú +szemtaraj +szemtelen +szemtelenkedés +szemtelenkedik +szemtelenség +szemtermés +szemügyre +szemüveg +szemüveges +szemüvegtok +szemű +szemvillanás +szemvillanásnyi +szenátor +szenátus +szende +szender +szendereg +szendvics +szendvicses +szendvicstál +szenel +szenes +szenespince +szenesvödör +szenilis +szenny +szennyes +szennyesláda +szennyez +szennyvíz +szent +szentatya +szentbeszéd +szentély +szentel +szentelget +szenteltvíztartó +szentesi +szentesít +szenteste +szentimentális +szentjánoskenyérfa +szentkép +szentmise +szentség +szentségel +szentséges +szentségit +szentségtörés +szentségtörő +szenved +szenvedély +szenvedélyes +szenvedélyesség +szenvedélytelen +szenvedés +szenvedő +szenveleg +szenvtelen +szenzáció +szenzációhajhászás +szenzációs +szenzi +szenzi-dömping +szeparálható +szeparátor +szeparatista +szeplős +szeplőtlen +szeptember +szeptemberi +szer +szeráf +szerb +szerda +szerdai +szerény +szerénykedik +szerénység +szerénytelen +szerénytelenség +szerecsen +szerel +szerelde +szerelés +szerelem +szerelmes +szerelmesedik +szerelmeslevél +szerelmespár +szerelmetes +szerelmi +szerelő +szerelőműhely +szerelőmunkás +szereltet +szerelvény +szerencse +szerencsére +szerencsés +szerencsétlen +szerencsétlenség +szerencsejáték +szerencsejátékos +szerep +szerepel +szerepeltetés +szerepjátszás +szereplés +szereplő +szeret +szeretet +szeretetlakoma +szeretetlen +szeretetreméltó +szeretetroham +szeretett +szeretetteljes +szeretkezés +szeretkezésízű +szeretkezik +szeretnivaló +szerető +szeretői +szerette +szerez +szerfölött +szerint +szerinte +szerinti +szerivel +szerkeszt +szerkesztés +szerkesztési +szerkesztő +szerkesztőjelölt +szerkesztőség +szerkesztőségi +szerkezet +szerkezetszerű +szerkó +szerláda +szerpentin +szerszám +szerszámláda +szerszámoskamra +szerszámosláda +szerszámraktár +szertár +szertartás +szertartásos +szertartásosság +szertartástan +szerte +szerteágazó +szerteáll +szertefoszlik +szertefúj +szertehagy +szertelen +szertelenség +szertelibeg +szertemászik +szerterepül +szerteszét +szerv +szervbank +szervcsere +szerves +szervetlen +szervez +szervezés +szervezési +szervezet +szervezeti +szervezetlenség +szervezett +szervezkedés +szervezkedik +szervező +szerveződik +szervi +szervíroz +szerviz +szervusz +szerzés +szerzemény +szerzet +szerzetesrend +szerző +szerződés +szerződik +szerződtet +szerződtetés +szerzőtehetség +szesz +szeszély +szeszélyes +szeszes +szeszfőzde +szeszkrumpli +szeszreklám +szesztartalmú +szesztilalom +szexuális +szexus +szezon +szférikus +szi +szíj +szíjas +szíjfülecske +szín +színárnyalat +színcsomó +színdarab +színe-java +színész +színészi +színészkedés +színészkedik +színészkolléga +színésznő +színehagyott +színes +színes-mintás +színevesztett +színez +színezet +színfolt +színház +színházbarakk +színházi +színházlátogatás +színhely +színigazgató +színigazság +színjáték +színjátszás +színjátszó +színjátszóné +színjeles +színjózan +színképelemzés +színköltemény +színleg +színlel +színművészetis +színpad +színpadi +színpadias +színpompa +színpróba +színtér +színtelen +színtiszta +színültig +színű +színvak +színvallás +színvonal +színvonalkülönbség +színvonaltalanság +szíriai +szít +szív +szívás +szívbaj +szívbeli +szívdobogás +szíve-lelke +szívélyes +szívélyesség +szível +szívenütő +szíves +szívesen +szíveskedik +szívesség +szívgyengeség +szívkatéterezés +szívkórház +szívlel +szívódik +szívós +szívóskodik +szívósság +szívpezsdítő +szívremegtető +szívroham +szívszaggató +szívszélhűdés +szívszorító +szívszorongató +szívtelen +szívtrombózis +szívügy +szívű +szívvel-lélekkel +szívverés +szia +szibériai +szid +szidás +szidalom +szidoloz +szieszta +sziget +szigetelés +szigetelőanyag +szigeti +szigetlakó +szigetmonostori +szignifikáns +szignó +szignum +szigony +szigor +szigorít +szigorított +szigorlat +szigorú +szigorúság +szikár +szikárság +szikes +szikkadt +szikla +sziklás +sziklaalap +szikladarab +sziklaportenger +sziklatömb +szikra +szikrányi +szikrázik +szikrázó +szil +szilánk +szilánkos +szilárd +szilárdság +szilárdságú +szilárdul +szilaj +szilikózis +szillogizmus +szilva +szilvás +szilvaaszaló +szilvafa +szilvalekvár +szilvamag +szilvatermés +szilveszter +szilveszterezik +szilveszteri +szimat +szimatol +szimatolgatás +szimatolószerv +szimatsztár +szimbólum +szimbolikus +szimfónia +szimpatizál +szimpla +szinkron +szint +szint-azonosság +szinte +szintén +szintézis +szintemelkedés +szintez +szintúgy +szipákol +szipirtyó +szipka +szipog +sziporkázik +szippant +szippantás +szippantgat +szirén +sziréna +szirénáz +szirénahang +szirmos +szirmú +szirom +szirt +szirup +szirupos +szisszenés +szisszent +sziszeg +sziszegés +szisztéma +szisztematikus +szita +szitál +szitakötő +szitavászon +szitkozódik +szitok +szittya +szittyós +szituáció +szivárog +szivárvány +szivárványos +szivárványszín +szivacs +szivacsos +szivar +szivarhamu +szivarka +szivarozik +szivarvég +szivarzseb +szivattyú +szivattyúz +szkeptikus +szkizofréniás +szláv +szladi +szlavóniai +szlovák +szmoking +szmokingos +sznob +sznoboskodik +szó +szóáradat +szóalakító +szóbeli +szóbeszéd +szóbőség +szócsata +szócséplés +szócsere +szócska +szócső +szóda +szódácska +szódavíz +szófogadatlan +szófogadó +szófoszlány +szóhasználat +szójártatás +szójáték +szójelzés +szókapcsolat +szókimondó +szókincs +szól +szólás +szólam +szólít +szólongat +szómalom +szónok +szónoki +szónoklás +szónoklat +szónokol +szóözön +szór +szórás +szórakozás +szórakozási +szórakozik +szórakozóhely +szórakozott +szórakoztat +szórakoztató +szóródik +szórókészülék +szórt +szórványos +szósz +szószék +szótár +szótértés +szótlan +szótöbbség +szótölcsér +szóváltás +szóval +szóvégi +szóvirág +szózat +szöcske +szög +szögesdrót +szögesdrótos +szöglet +szögletes +szögletesség +szökdécsel +szökés +szökési +szökell +szökevény +szökevényvadászat +szökik +szökken +szökkenés +szökkent +szökőár +szökőkút +szöktet +szörny +szörnyeteg +szörnyethal +szörnyülködik +szörnyülködő +szörnyű +szörnyűség +szörnyűséges +szöszmötöl +szöszmötölés +szövés +szöveg +szövegel +szövet +szövetanyag +szövetfoszlány +szövetkezés +szövetkezet +szövetkezetfejlesztés +szövetkezeti +szövetkezik +szövetnadrág +szövetpapucs +szövetruha +szövetség +szövetséges +szövetségi +szövetszoknya +szövetű +szövevény +szövevényes +szövődik +szövőgyár +sző +szőke +szőkeség +szőlész +szőlő +szőlőbeli +szőlőbirtokos +szőlődarab +szőlőfürt +szőlőhegy +szőlőhegyi +szőlőlevél +szőlőlugas +szőlőméz +szőlőművelő +szőlős +szőlősgazdai +szőlőskert +szőlősor +szőlőtelepítés +szőlőtermelő +szőlővessző +szőnyeg +szőr +szőrcsomó +szőrkereszt +szőrmók +szőrös +szőröstül-bőröstül +szőröz +szőrözés +szőrszál +szőrszálhasogató +szőrsziget +szőrű +szőrzet +szőttes +szoba +szoba-alkóvos +szoba-hallos +szoba-konyha +szoba-konyhás +szobácska +szobaajtó +szobaasszony +szobabérlő +szobacím +szobaféle +szobafestő +szobafestősegéd +szobagarnitúra +szobakonyhás +szobakulcs +szobalány +szobapincér +szobasarok +szobatárs +szobatársi +szobatudós +szobor +szoboratléta +szobormerev +szobrász +szobrászművészet +szobrocska +szocdem +szociáldemokrata +szociális +szocialista +szocializmus +szocio-doktorbácsi +szociológus +szocreál +szokás +szokásos +szokat +szokatlan +szokatlanság +szokik +szokli +szoknya +szoknyaanyag +szokott +szoktat +szokványos +szolga +szolgál +szolgálat +szolgálati +szolgálatkész +szolgálatkészség +szolgálatteljesítés +szolgálattevő +szolgálatvezető +szolgáló +szolgálólány +szolgáltat +szolgabíró +szolgafélelem +szolgafiú +szolgai +szolgalélek +szolgalegény +szolgaság +szolid +szolidság +szolnoki +szombat +szombathelyi +szombati +szombatonta +szomj +szomjas +szomjazik +szomjúság +szomorkás +szomorkodik +szomorú +szomorúfűz +szomorúság +szomszéd +szomszédasszony +szomszédi +szomszédlány +szomszédnő +szomszédos +szomszédság +szonáta +szonda +szonett +szopás +szopik +szopókás +szopogat +szoptat +szoptatós +szordínós +szorgalmas +szorgalmaskodik +szorgalmaz +szorgalmú +szorgalom +szorgos +szorgoskodik +szorít +szorítás +szorítkozik +szorító +szorong +szorongás +szorongásos +szorongat +szorongó +szoros +szortíroz +szortyog +szorul +szoruló +szorult +szorultság +szorzat +szottyan +szotyorgós +szovjet +szovjetparancsnokság +szputnyik +sztahanovista +sztentori +sztereo-fényképezőgép +sztereó +sztereotípia +sztetoszkóp +sztk-ellenőr +sztori +sztrájk +sztrájkbizottság +sztrájkol +sztrájkoló +sztrájksegély +sztreha +szúette +szúnyog +szúnyogdongás +szúr +szúrágta +szúrás +szúrat +szúrható +szúrós +szügy +szükség +szükségel +szükséges +szükségesség +szükséglakás +szükséglet +szükségszerű +szükségszerűség +szükségtelen +szül +szüle +szülés +szülési +születés +születési +születésnap +születésű +született +születik +szülött +szülő +szülőfalu +szülőföld +szülőhely +szülői +szülőváros +szünet +szünetel +szünetjel +szünidő +szünnap +szüntelen +szürcsöl +szürcsölés +szürcsölget +szüret +szüretel +szüretelő +szürke +szürke-fehér +szürkéllik +szürkés +szürkésbarna +szürkésfehér +szürkésfekete +szürkéskék +szürkehajú +szürkeség +szürkevörös +szürkül +szürkület +szürrealista +szüzesség +szüzességi +szűk +szűkít +szűkmarkú +szűköl +szűkölés +szűkölködő +szűkös +szűkösség +szűkrésű +szűkszavú +szűkül +szűkület +szűnik +szűr +szűrő +szűrődik +szűrujj +szűz +szűzföld +szűzhártya +szűzlány +szubjektív +szubjektivista +szubjektum +szubkulturális +szublimát +szubrett +szuggerál +szuggesztív +szukcesszive +szultán +szundi +szundít +szundikál +szunnyad +szuperál +szurdék +szurdok +szurkál +szurkáltat +szurkol +szurkolás +szurok +szurokfáklya +szurokfű +szurokszínű +szurony +szuronyos +szuronyú +szurtos +szusszanás +szusszanásnyi +szusz +szuszék +szuszog +szuszogás +szuszogtat +szuterénlakás +szuverén +szuverenitás +szvetter +tá +tábla +táblácska +táblázat +táblabíró +tábor +táborélet +táborhely +tábori +táborjárvány +táborlakó +tábornagy +tábornok +tábornoki +tábornokkormány +táborozás +táborozik +táborparancsnok +táborrend +tábortartás +tábortartó +tábortűz +tág +tágas +tágít +tágítás +tágul +táj +táján +tájban +tájbeszéd +tájék +tájékozatlan +tájékozható +tájékozódás +tájékozódik +tájékozott +tájékozottság +tájékoztat +tájékoztatás +tájkép +tájnyelv +tájszólás +tájt +tákol +tákolmány +tál +tálal +tálaló +tálalóablak +tálalóasztal +tálca +tálcás +tálka +táltos +tályog +támad +támadás +támadható +támadó +támadóállás +támasz +támaszkérő +támaszkodik +támaszkodó +támaszpont +támaszt +támaszték +támasztókaró +támasztópillér +támgerenda +támla +támlány +támogat +támogatás +támogató +támolyog +támpont +tánc +tánccsoport +táncdalénekesnő +tánchely +tánchelyiség +tánciskola +tánckettős +tánclépés +táncmulatság +táncol +táncoló +táncoltat +táncorkán +táncos +táncoskomikus +táncosnő +táncospár +táncszám +tánctudás +tánczene +tántorodik +tántorog +tányér +tányércsörgés +tányérsapka +tányérsapkás +tápászkodás +tápászkodik +táplál +táplálás +táplálék +táplálkozás +táplálkozik +tápláló +táppénz +tápszerreklám +táptelep +tár +tárca +tárcaíró +tárcsa +tárcsáz +tárgy +tárgyal +tárgyalás +tárgyalási +tárgyalófél +tárgyalóterem +tárgyi +tárgyilagos +tárgyilagosság +tárgysorozat +tárgyú +tárház +tárlat +táró +tárol +tárolás +társ +társadalmi +társadalom +társadalomkritika +társalgás +társalgási +társalgó +társalog +társas +társaság +társasági +társasjáték +társasüdülő +társasutazás +társasvadászat +társbérlő +társcsászár +társelnökség +társkereső +társnő +társtalan +társtalanság +társul +társulat +társzekér +tárul +tárulkozik +tárva-nyitva +táska +táskaféle +táskarádió +tát +tátika +tátog +tátong +tátrai +táv +távcső +távírógép +távirányítás +távirányítású +távirányító +távirat +távirati +táviratozik +távlat +távlati +távol +távoleső +távoli +távollét +távolmaradás +távolodik +távolodó +távolság +távolsági +távolságtartás +távozás +távozik +távozó +tabletta +tabló +tabu +tacskó +taft +taftruha +tag +tagállam +tagad +tagadás +tagadhatatlan +tagadható +tagadó +tagbaszakadt +taggyűlés +taglal +taglalás +taglétszám +taglejtés +tagol +tagolás +tagolatlan +tagolt +tagország +tagozat +tagozódik +tagság +tagú +tahi +tajték +tajtékos +tajtékzik +tak-tak +takar +takarás +takarék +takarékbetétkönyv +takarékkönyv +takarékos +takarékoskodás +takarékoskodik +takarékosság +takarékossági +takargat +takarít +takarítás +takarítási +takarítgat +takarítóasszony +takarítóbrigád +takarítóeszköz +takarítónő +takaríttat +takarmány +takaró +takaródzás +takaródzik +takarodik +takaros +taknyos +takony +taksál +taktika +taktikai +taktus +talál +találás +találat +találékony +találékonyság +találgat +találgatás +található +találka +találkozás +találkozási +találkozik +találkozó +találkozóhely +találmány +találó +találomra +talált +talán +talán-talán +talány +talányos +taláris +talaj +talajfelszín +talajmaró +talajrengés +talajvíz +talajviszony +talapzat +talicska +talicskázik +talon +talp +talpalás +talpalatnyi +talpas +talpfa +talpnyalás +talpnyaló +talpnyom +talponálló +talpraesett +talpszedés +talpú +tamáshegyi +tamáskodik +tamtam +tan +tanács +tanácsadás +tanácsadó +tanácsbeli +tanácselnök +tanácsház +tanácsháza +tanácsi +tanácskérő +tanácskozás +tanácskozik +tanácskozóterem +tanácsol +tanácsos +tanácsosi +tanácstalan +tanácstalanság +tanácsterem +tanácstitkár +tanácstitkárkodik +tanácsülés +tanácsvezető +tanár +tanárember +tanárfamília +tanári +tanárnő +tanáros +tanakodás +tanakodik +tananyag +tandíjmentes +tanfolyam +tangép +tangó +tanít +tanítás +tanítási +tanítgat +tanító +tanítói +tanítómester +tanítóné +tanítónő +tanítóskodik +taníttat +tanítvány +tank +tankakadály +tankcsapda +tankönyvraktár +tankötelezettség +tanmese +tannin +tanonc +tanonciskola +tanonckodik +tanonckor +tanszék +tanszéki +tantárgy +tanterem +tanú +tanújel +tanúkihallgatás +tanúság +tanúsít +tanúskodik +tanúvallomás +tanúzás +tanügyi +tanul +tanulás +tanulékony +tanulgat +tanulmány +tanulmányfej +tanulmányoz +tanulmányozás +tanulmányút +tanulnivaló +tanuló +tanulóév +tanulólány +tanulópár +tanulság +tanulságos +tanult +tanultság +tanya +tanyás +tanyás-erdős +tanyázgat +tanyázik +tanyabokor +tanyaépület +tanyahely +tanyakérdés +tanyakörzet +tanyaközpont +tanyalakó +tanyasi +tanyaudvar +tanyavilág +tapad +tapadós +tapaszt +tapasztal +tapasztalás +tapasztalat +tapasztalatcsere +tapasztalatlan +tapasztalatlanság +tapasztalható +tapasztalt +tapéta +tapétás +tapétázatú +tapicskál +tapint +tapintás +tapintású +tapintat +tapintatos +tapiskál +tapod +tapogat +tapogatódzik +tapos +taps +tapsol +tapsorkán +taraj +tarajos +tarfejű +targonca +tarisznya +tarka +tarkállik +tarkabab +tarkaságú +tarkít +tarkó +tarló +tarlótorzs +tarnai-féle +tarsoly +tart +tartály +tartás +tartású +tartalék +tartalékol +tartalékos +tartaléktörvény +tartalmas +tartalmatlan +tartalmaz +tartalmi +tartalom +tartalomvilág +tartam +tartat +tarthatatlan +tarthatatlanság +tartó +tartóoszlop +tartós +tartósít +tartózkodás +tartózkodási +tartózkodik +tartózkodó +tartózkodóhelyiség +tartóztat +tartogat +tartomány +tartozás +tartozék +tartozik +tasak +taszít +taszítás +taszigál +tatár +tatárjárás +tatai +tataroz +tatarozás +tavacska +tavaly +tavalyelőtt +tavalyi +tavasz +tavasz-ősz +tavaszi +taxi +taxiállomás +taxiköltség +taximegálló +taxis +taxisofőr +taxiszámla +taxiügy +taxizás +te +tébécé +téblábol +téboly +tébolyult +téesz +téesz-pár +téeszelnök +téeszközpont +téeszközség +téesznagysága +téeszszervező +tégla +téglás +téglaarcú +téglabástya +téglaépület +téglafal +téglagyár +téglagyári +téglahulladék +téglajárda +téglakészítő +téglapadlós +téglarakás +téglavetés +téka +tékozló +tél +télbe-nyárba +téli +télidő +télikabát +télikert +télire +téma +témahiány +témakör +témaötlet +témaosztás +témaszabadság +tématerv +ténfereg +ténsasszony +tény +tényállás +tényező +tényközlés +tényleg +tényleges +ténymegállapítás +tényszerű +tényvázlat +tép +tépáz +tépdes +tépelődés +tépelődik +tépelődő +tépetlen +tépett +tépked +tér +tér-idő +téráthidaló +térbeli +térd +térdel +térdepel +térdhajlat +térdharisnya +térdkalács +térdnadrágos +térérzék +térerőd +térhajó +térhajós +térhódítás +téri +térít +tériszony +térkép +térképcsináló +térképmakett +térképszerű +térképzet +térmértan +térség +térségű +térszalag +térszerű +tészta +tésztástál +tésztaarcú +tésztakupac +tét +tétel +tételes +tétlen +tétlenkedik +tétlenség +tétova +tétovázás +tétovázik +tévé +tévéhíradó +téved +tévedés +tévedhetetlen +tévedhetetlenség +tévelyeg +tévelygés +téves +téveszt +tévtan +tézis +tea +teásbögre +teátrista +teátrum +teázik +teakonyha +teatralitás +teavíz +technika +technikás +technikai +technikum +technikus +technológiai +teendő +tegez +tegeződés +tegeződik +tegnap +tegnapelőtt +tegnapelőtti +tegnapi +tehát +tehén +tehéntartás +tehenész +tehenes +teher +teherautó +teherbírás +teherfuvarozás +tehergépkocsi +teherkocsi +teherpályaudvar +teherszállítás +teherszállító +tehervagon +tehervonat +tehet +tehetetlen +tehetetlenség +tehetős +tehetség +tehetséges +tehetségtelen +tehetségű +tej +tejberizs +tejes +tejesbolt +tejescsupor +tejeskanna +tejesszürkeség +tejesüveg +tejfehér +tejfelesszájú +tejföl +tejfölös +tejhordó +tejpor +tejszerű +tejszínes +tejszínhab +tejszínhabos +tejüveg +tejüzem +teker +tekercs +tekerget +tekergős +tekerődzik +tekervényes +teketória +teketóriázik +tekinget +tekint +tekintély +tekintélyes +tekintélyrendszer +tekintet +tekintetes +tekintetű +tekinthető +tekintve +teknő +teknősbéka +teknőszerű +tektonikus +tele +telebeszél +telecigarettáz +teleesz +telefarag +telefon +telefonál +telefonálás +telefonáltat +telefonbeszélgetés +telefonérme +telefonfülke +telefonkagyló +telefonkészülék +telefonkönyv +telefonközpont +telefonos +telefonozik +telefonszám +telefut +telehint +telehord +teleír +telejesít +telek +telekár +telekkönyvvezető +teleköpköd +telekügy +telel +telelármáz +telelget +telemér +telep +telepátia +telepedik +telephely +telepít +telepítés +telepingál +telepőr +teleporciózgat +települ +település +települési +telepvezető +teleragaszt +telerak +teleszalad +teleszív +teleszór +teletetovál +teletölt +teletöm +teletömődik +televízió +televíziós +televíziószoba +televíziótorony +telezabál +telhetetlen +telhető +teli +telít +telítettségű +telihold +telik +telik-múlik +telitalálat +telje +teljes +teljesít +teljesítés +teljesítmény +teljesítményű +teljesítőképesség +teljesség +teljesül +teljesülés +teljesületlen +telt +telte +telve +tematikai +tematikus +temesvári +temet +temetés +temetési +temetésrendező +temetetlen +temetkezési +temetkezőhely +temető +temetőhely +temetői +temetőkultusz +temperál +temperamentum +templom +templomépítés +templomhegy +templomi +templomtér +templomtorony +templomudvar +tempó +tempós +tendencia +teng-leng +tengely +tenger +tengerész +tengerészarc +tengerészgyalogság +tengerészöltöny +tengerészsapka +tengerésztiszt +tengerésztiszti +tengerentúl +tengerentúli +tengeri +tengeribetegség +tengeriföld +tengeritábla +tengeritörés +tengerjáró +tengerkék +tengernagy +tengernyi +tengerpart +tengerszem +tengerszín +tenget +tengődik +teniszbajnok +teniszezik +teniszütő +tennivaló +tenor +tenyér +tenyérnyi +tenyészet +tenyészik +tenyészmén +tenyerű +teológia +teológiai +tepertő +tepertős +tepsi +terápia +terasz +terézvárosi +terebélyes +terefere +tereget +terel +terelés +terelődik +terem +teremt +teremtés +teremtésmítosz +teremtetik +teremtmény +teremtő +teremtődik +terep +terepjáró +tereptan +terhel +terhelés +terhes +terhesruha +terhesség +terhű +terít +terítékes +terítés +terítő +terítőjű +terjed +terjedelem +terjedelmes +terjeng +terjeszkedik +terjeszt +terjesztés +termáljegyvásárlás +termék +termékeny +terméketlen +terményforgalmi +termés +terméskő +természet +természetátalakító +természetellenes +természetes +természetesen +természetesség +természetfeletti +természeti +természetrajz +természetszerű +természetszerűleg +természettudás +természettudomány +természettudományos +természetű +termel +termelés +termelési +termelő +termelői +termelőszövetkezet +termelőszövetkezeti +termelőüzem +termesz +termet +termetes +termetű +termő +termőföld +termosz +terpeszállás +terpeszkedik +terror +terrorista +terül +terület +területi +területrész +területű +terv +terves +tervez +tervezés +tervezet +tervezget +tervezgetés +tervező +tervezőiroda +tervfelbontás +tervgazdálkodás +tervkutatás +tervmódosítás +tervosztály +tervpályázat +tervpályázati +tervrajz +tervszerűség +tervszerűtlen +tervutasítás +tesped +tespedés +tessék +tessék-lássék +tessékel +test +test-lélek +testál +testalkatú +testes +testestül-lelkestül +testetlen +testfej +testhelyzet +testi +testi-lelki +testízű +testkultúra +testnedv +testnevelő +testőr +testőrség +testrész +testszagú +testtartás +testtelen +testület +testületi +testű +testvér +testvérbátya +testvérhiány +testvéri +testvéries +testvériség +testvériskola +testvérke +tesz +tesz-vesz +teszt +tetanusz +tetejébe +tetejű +tetem +tetemes +tető +tetőgerenda +tetőgerinc +tetőpont +tetőterasz +tetőteraszos +tetőzés +tetőzet +tetőzik +tetőzsindely +tetovál +tetoválás +tetováltat +tetszés +tetszeleg +tetszetős +tetszhalott +tetszik +tett +tettenérés +tettes +tettet +tettetett +tetthely +tettlegesség +tettrekészség +tettvágy +tetű +tetves +teve +tevékeny +tevékenykedik +tevékenység +tevékenységű +teveszőr +tevő +textília +textil +textus +ti +tífuszbacilus +típus +típusú +tíz +tíz-húsz +tíz-húsz-harminc +tíz-tizenkét +tíz-tizenkettő +tíz-tizenöt +tízéves +tízegynéhány +tízes +tízezer +tízezernyi +tízezred +tízezres +tízfilléres +tízholdas +tízméteres +tízmillió +tízmilliós +tíznapos +tízórai +tízszemélyes +tied +tigrisfej +tikett +tikkadt +tikkasztó +tiktakol +tilalmaz +tilalom +tilos +tilt +tiltakozás +tiltakozik +tiltott +timsó +tincs +tinédzser +tinó +tinta +tintájú +tintaceruza +tintaceruzás +tintafolt +tintafoltos +tintanyaló +tintatartó +tintatócsa +tipeg +tipegő +tipikus +tipor +tippel +tipródik +tiroli +tisza-parti +tiszántúli +tiszt +tiszta +tisztálkodás +tisztálkodási +tisztálkodik +tisztán +tisztánlátás +tisztára +tisztás +tisztátalan +tisztátlan +tisztáz +tisztázás +tisztázatlan +tisztázható +tisztázódik +tisztaság +tisztasági +tisztaságú +tisztel +tiszteleg +tisztelendő +tisztelet +tiszteletadás +tiszteletbeli +tiszteletdíj +tiszteletem +tiszteletkör +tiszteletreméltó +tisztelettudó +tisztelgés +tisztelő +tisztelt +tisztes +tisztesség +tisztességes +tisztességszobor +tisztességtelen +tisztességtelenség +tisztességtudó +tiszthelyettes +tiszti +tisztít +tisztítás +tisztítóberendezés +tisztítótűz +tisztítóüzem-tulajdonos +tisztiiskola +tisztiorvos +tisztogat +tisztség +tisztul +tisztviselő +tisztviselőféle +tisztviselői +tisztviselőtelep +titáni +titkár +titkári +titkárnő +titkárnői +titkároskodik +titkárság +titkol +titkolódzás +titkolódzik +titkon +titkos +titkosszolgálat +titok +titoktartás +titoktartó +titokzatos +titulál +tivornya +tized +tizedannyi +tizedes +tizedik +tizedrész +tizenegy +tizenegyedik +tizenegyes +tizenhárom +tizenhárom-tizennégy +tizenharmadik +tizenhat +tizenhatéves +tizenhatodik +tizenhatos +tizenhét +tizenhetedik +tizenhetes +tizenkét +tizenkétezer +tizenkétféle +tizenkettedik +tizenkettes +tizenkettő +tizenkilenc +tizenkilenc-huszonegy +tizenkilencedik +tizenkilences +tizennégy +tizennegyedik +tizennyolc +tizennyolc-húsz +tizennyolcadik +tizennyolcezer +tizenöt +tizenöt-húsz +tizenötezer +tizenötödik +tizenötös +tó +tócsa +tódul +tódulás +tófenék +tóga +tógátlan +tónus +tónusú +tópart +tószt +tótfalusi +több +többé +többé-kevésbé +többedmagával +többes +többesszám +többet +többféle +többfelé +többi +többlet +többnyire +többrétűség +többség +többször +többszöri +többszörös +töfög +tök +tökbél +tökéletes +tökéletesedik +tökéletesít +tökéletesítés +tökéletesség +tökéletlenség +tökély +tökfilkó +tökmindegy +tökrészeg +tökű +tölcsér +tölcsérszerű +tölgy +tölgyfa +tölt +töltény +tölténytár +tölténytáska +töltés +töltésoldal +töltelék +töltöget +töltött +töltőtoll +töm +tömb +töméntelen +tömény +tömérdek +tömés +tömeg +tömeges +tömegjelenség +tömeglés +tömegpusztító +tömegruházati +tömegszállás +tömegverekedés +tömegviszony +tömjénfüst +tömkeleg +tömköd +tömlöc +tömlő +tömör +tömörül +tömött +tömpe +tömzsi +tönk +tönkremegy +tönkremenés +tönkrement +tönkresilányít +tönkretesz +töpörödött +töppedt +töpreng +töprengés +tör +tördel +törékeny +törés +töredék +töredékes +töredelmes +töredezett +töredezik +törek +törekedik +törekhord +törekvés +törekvő +töret +töretlen +törik +törleszt +törlőruha +törmelék +török +törökbarát +törökszentmiklósi +törökülés +töröl +törölget +töröltet +törött +törődik +törődött +törődöttség +törpe +törpeagy +törpebirtok +törpebirtokos +törpefenyő +törpegép +törpeharcsa +tört +történés +történész +történelem +történelembölcselet +történelemkönyv +történelemszak +történelemtudós +történelmi +történet +történetesen +történeti +történetíró +történik +történtek +törtet +törülközik +törülköző +törülközőtartó +törvény +törvénycikk +törvényes +törvényhatósági +törvényjavaslat +törvénykönyv +törvényszék +törvényszéki +törvényszerű +törvényszerűség +törvénytelen +törvénytelenség +törzs +törzsfőnök +törzsi +törzsiroda +törzsök +törzsökös +törzsőrmester +törzsparancsnok +törzsszázad +törzstiszt +törzsű +törzsvendég +töviről +tövis +tövű +tő +tődött +tőgy +tőgyű +tőke +tőkés +tőkegazdag +tőkepénzes +tőle +tőmondat +tőr +tőrőlmetszett +tőzeg +tőzsde +tőzsdés +tőzsdeügynök +toaletthelyiség +toboroz +toborzás +toborzó +toboz +tobzódik +toccsan +tocsog +tocsogó +tohonya +tojás +tojásdad +tojásexportőr +tojásnagykereskedő +tojásrántotta +tojástánc +tojik +tok +toka +tokány +tol +tolakodás +tolakodik +tolat +tolatómozdony +toldozgat +toll +tollászkodik +tollas +tollazat +tollazatú +tollbóbitás +tollforgató +tollpihe +tollseprű +tollseprűárus +tollú +tollvonás +tolmács +tolmácsol +tolóajtó +tolódik +tolóka +tolókocsi +tolószékes +tologat +toloncutca +tolong +tolongás +tolul +tolvaj +tolvajszerkó +tombol +tombolás +tomboló +tompa +tompít +tompor +tomporú +tonna +tonnás +topáz +topog +topogás +topolyafa +toporgás +toporog +toporzékol +toppan +toprongyos +torkaszakadtából +torkolat +torkolattűz +torkollik +torlasz +torlódás +torlódik +torma +tornác +tornácágas +tornáclépcső +tornácos-oszlopos +tornász +tornászik +tornászmozdulat +tornacipő +tornacipős +tornaóra +tornatanár +tornaterem +tornyosodás +tornyosodik +tornyosul +tornyozódik +torok +torokfojtogató +torokgyík +torokgyulladás +torokhang +torokmetszés +torony +toronyablak +toronybelső +toronydaru +toronyház +toronyiránt +toronymászás +toronymagas +toronymagasság +toronysarok +toros +torreádor +torta +torz +torzít +torzkép +torzonborz +torzsa +torzsalkodás +torzsalkodik +torzszülött +torzul +torzulás +torzulat +totál +totális +totojázik +tova +tovább +tovább-ballag +továbbá +továbbáll +továbbad +továbbcsalinkázik +továbbcsúszik +továbbél +továbbfejleszt +továbbfejlődik +továbbfolyik +továbbfolytat +továbbfut +továbbgördít +továbbgyűrűzik +továbbhajt +továbbhalad +további +továbbít +továbbító +továbbindul +továbbjut +továbbképző +továbblapoz +továbblép +továbblépés +továbblépeget +továbblendít +továbblök +továbbmegy +továbbmond +továbbra +továbbsettenkedik +továbbsiet +továbbsodor +továbbszöktet +továbbszolgálat +továbbterjed +továbbterjedés +továbbtol +továbbutazás +továbbvánszorog +továbbvisz +továbbvonul +továbbzakatol +tovafut +tovagördíthető +tovagomolyog +tovahömpölyög +tovalépdel +tovalebben +tovaragad +tovarebbent +tovarepül +tovarohan +tovasiet +tovasiklik +tovaszáll +tovatűnik +tovavonul +tra-ta-ta-ta-tam +trágár +trágárkodik +trágárság +trágya +trágyahordás +trágyasöprés +tradíció +trafik +trafikos +trafórobbanás +tragacs +tragédia +tragikum +tragikus +traktál +traktor +traktorista +traktoros +traktus +trambulin +transzcendencia +transzparens +transzport +transzportőr +tranzitutas +trapéz +trapp +trappol +traverz +traverzrácsozat +trécselés +tréfa +tréfál +tréfálkozás +tréfálkozik +tréfálkozó +tréfálódzik +tréfás +tréfadolog +tréfamester +tréfaröppentyű +tréner +tréning +tréningmaci +tréningruha +tréningruhás +trehány +tribün +trikó +trikós +trikolór +trilláz +trillázik +tritonkürt +trófea +trófeagyűjtemény +tróger +trón +trónörökös +trónus +trópus +trópusi +tröszt +trolibusz +trombita +trombitál +trombózis +trombózisos +tromfol +trükk +trükkös +tszcs +túl +túlad +túladagolás +túlbecsül +túlbecsülés +túlbonyolítás +túlcsap +túlcsapódik +túlcsordul +túldramatizálás +túléget +túlél +túlélő +túlér +túlérett +túlerő +túlesik +túlfelől +túlfeszültség +túlfűtött +túlfűtöttség +túlhajtott +túlharsog +túli +túljár +túljut +túlkapás +túlkiált +túlkompenzál +túllép +túllendül +túlmegy +túlmutat +túlnani +túlnyomás +túlnyomó +túlnyomórészt +túlóra +túlórázás +túlórázik +túlöltözött +túloldal +túloz +túlpart +túlparti +túlság +túlságos +túlsó +túlsúly +túlszámlál +túlszalad +túltápláltság +túltekint +túlterhel +túlterhelés +túlterjed +túltesz +túlvilág +túlvilági +túlzás +túlzott +túr +túra +túró +túrós +túsz-tanuló +tücsök +tücsök-bogár +tücsökzene +tüdejű +tüdő +tüdőbaj +tüdőbajos +tüdőbeteg +tüdőcsúcs +tüdőcsúcshurut +tüdőgyulladás +tüdős +tüdőszűrés +tüdővész +tüdővészes +tükör +tükörablakos +tükörbeli +tükörírásforma +tükörkép +tükörmás +tükörsima +tükrös +tükröz +tükrözés +tükrözik +tükröződik +tükrű +tülekedés +tülekedik +tülköl +tüllbetét +tüllfátyol +tülökszó +tündér +tündéri +tündérjáték +tündérmese +tündebaba +tündöklés +tündökletes +tündöklik +tünékeny +tünemény +tüneményes +tünet +tüntet +tüntetés +tüntető +türelem +türelmes +türelmetlen +türelmetlenkedik +türelmetlenség +türelmi +türkiz +türtőztet +tüske +tüskés +tüskés-sötét +tüskeborona +tüstént +tüzér +tüzérség +tüzérségi +tüzel +tüzelés +tüzelő +tüzes +tüzetes +tű +tűhegyes +tűhegynyi +tűnik +tűnődés +tűnődik +tűnődözik +tűnődőforma +tűr +tűrés +tűrés-tagadás +tűrhetetlen +tűrhetetlenség +tűrhető +tűsarkú +tűz +tűz-víz +tűzeső +tűzfal +tűzfegyver +tűzharc +tűzhely +tűzhelyajtó +tűzhelyes +tűzhelymaradvány +tűzifavágó +tűzijáték +tűzijátékgyáros +tűzköd +tűzkő +tűzlándzsa +tűznyelő +tűzön-vízen +tűzözön +tűző +tűzokádó +tűzoltó +tűzoltóruha +tűzoltóság +tűzpiros +tűzrendészeti +tűzrevaló +tűzsugár +tűzvonal +tubarózsa +tuberkulotikus +tucat +tucatnyi +tud +tudálékos +tudás +tudásvágy +tudakol +tudakolódzik +tudat +tudatalatti +tudatfunkció +tudathasadásos +tudatlanság +tudatos +tudatosodik +tudatosság +tudattalan +tudható +tudniillik +tudnivaló +tudó +tudós +tudósgárda +tudósít +tudósítás +tudósító +tudósítócsoport +tudósitó +tudósképző +tudóskollektíva +tudósság +tudóstárs +tudóstípus +tudomány +tudományos +tudománytörténet +tudomás +tudomásulvétel +tudomistenem +tudsz +tudta +tudvalevő +tulajdon +tulajdonít +tulajdonjog +tulajdonképpen +tulajdonképpeni +tulajdonos +tulajdonosnő +tulajdonság +tulipán +tulipánfa +tulipános +tulipánpiros +tulizik +tulok +tumultus +tundra +tunika +tunya +tupíroz +turbán +turbékol +turista +turistacsoport +turistaruha +turistaút +turisztikai +turizmus +turkál +turkálgat +turmix +turnürös +turpisság +tusázik +tusakodás +tusakodik +tuskó +tusoló +tuszkol +tuti +tviszt +tvisztel +tyúk +tyúkász +tyúkfarm +tyúkhúsleves +tyúkól +tyúkocska +tyúkszem +tyúkszemirtó +tyúkszemviszketés +tyűha +u-alak +u-asztal +uborka +uborkásüveg +uborkasaláta +uborkaszezon +udvar +udvarhölgy +udvari +udvarias +udvariaskodik +udvariasság +udvariassági +udvariatlan +udvariatlanság +udvarlás +udvarló +udvarnok +udvarol +udvarolgat +udvaronc +udvartartás +ugat +ugatás +ugor +ugrál +ugrálás +ugrándozás +ugrándozik +ugrás +ugrásnyi +ugrásszerű +ugrabugrál +ugrabugráltat +ugraszt +ugrat +ugratás +ugrifüles +ugrik +ugyan +ugyanakkor +ugyanannyi +ugyanaz +ugyanazon +ugyancsak +ugyanekkor +ugyanekkora +ugyanennyi +ugyanez +ugyanezen +ugyanígy +ugyanilyen +ugyanis +ugyanitt +ugyanoly +ugyanolyan +ugyanott +ugyanúgy +ugye +ugyebár +uhu +ujj +ujjas +ujjatlan +ujjhegy +ujjlenyomat +ujjlenyomat-készítő +ujjnyi +ujjong +ujjongás +ujjongtat +ujjropogtatás +ujjú +ukmukfukk +ukrán +ukrajnai +ulánus +ulti +ultizás +ultizik +ultramodern +ultrarojalista +ultraszeptil-tabletta +un +unalmas +unalmaskodik +unalom +unatkozik +undok +undor +undorító +undorodik +uniformis +uniformizmus +unikum +univerzális +unoka +unokabátya +unokahúg +unokaöcs +unokatestvér +unokatestvérség +unos-untalan +unott +unszol +unszolás +untat +uradalmi +uradalom +urahagyott +ural +uralkodás +uralkodik +uralkodó +uralkodói +uralom +uralomvágy +uramisten +uraság +urasági +uraskodik +uraz +urbanizáció +urbanizálódás +urizál +uszály +uszályméretű +uszályos +uszít +uszoda +uszony +usztasa +utál +utálatos +utálkozás +utálkozik +után +utána +utánabámul +utánaballag +utánacsap +utánafordul +utánafut +utánagázol +utánagondol +utánagurul +utánahajít +utánahajol +utánaindul +utánajár +utánajön +utánakap +utánaképzel +utánakiált +utánaküld +utánalép +utánamegy +utánanéz +utánanyúl +utánarohan +utánaszalad +utánaszól +utánatöltöget +utánaugrik +utánavet +utánazúdul +utánfolyó +utánfutó +utáni +utánoz +utánozhatatlan +utánpótlás +utánzás +utánzat +utász +utászcsizma +utacska +utal +utalás +utalvány +utalványoz +utas +utasáradat +utasít +utasítás +utasítgatás +utastér +utazás +utazási +utazgat +utazgatás +utazik +utazó +utazókosár +utazószatyor +utca +utcácska +utcájú +utcaajtó +utcafront +utcai +utcalámpa +utcalány +utcasarok +utcasor +utcatábla +utilitarisztikus +utóbb +utóbbi +utód +utóhatás +utóirat +utója +utókor +utólag +utólagos +utómanipulátorozás +utópia +utópisztikus +utóvéd +utóvédharc +utóvégre +utolér +utolérhetetlen +utoljára +utolsó +utolsósorban +uzsgyi +uzsonna +uzsonnázik +uzsorakamat +úgy +úgy-ahogy +úgy-úgy +úgyhogy +úgyis +úgymint +úgymond +úgynevezett +úgysem +úgysincs +úgyszólván +új +újabban +újból +újbóli +újdonság +újdonsült +újév +újévi +újesztendő +újfajta +újfent +újgazda +újhold +újít +újítás +újjáformálás +újjászervezés +újjászületés +újjászületik +újonc +újonctárs +újonnan +újpesti +újra +újraéled +újrafelfegyverzés +újrafelvétel +újraformálás +újrakezd +újrakezdődik +újraolvas +újraperget +újratanul +újrateremt +újratöltődés +újság +újságárus +újságcikk +újságcsomó +újsághír +újságíró +újságírói +újságírónő +újságkioszk +újságkivágás +újságol +újságos +újságpapír +újságpapiros +újszerű +újszerűség +újszülött +újul +úr +úrasztala +úrék +úrféle +úrfelmutatás +úrfi +úri +úri-polgári +úriasszony +úriember +úriház +úrinő +úristen +úristenit +úrnő +úszás +úszik +úszkál +úszó +úszómedence +úszónadrág +úsztat +út +útbaigazít +útburkolat +útcsinálás +útcsináló +útépítés +útépítő +úthálózat +úti +útibőrönd +úticél +útikalauz +útiköltség +útikönyv +útimars +útirány +útitárs +útitársnő +útján +útjai +útjelzőtábla +útkanyar +útkaparó +útkefélőgép +útkereső +útközben +útlevél +útlevélkérelem +útlevélosztály +útlevélvizsgálat +úton-módon +úton-útfélen +útpart +útrakész +útrakel +útravaló +útrész +útszakasz +útszél +útszéli +úttest +úttöltés +úttörés +úttörő +útvesztő +útvonal +ücsörög +üde +üdezöld +üdítő +üdülés +üdülő +üdülőféle +üdülőház +üdülőhely +üdülőtelep +üdv +üdvhadsereg +üdvös +üdvösség +üdvözítő +üdvözlégy +üdvözlés +üdvözlet +üdvözlő +üdvözlőféle +üdvözöl +üdvözül +üdvözült +üdvrivalgás +üget +üggyel-bajjal +ügy +ügybuzgalom +ügybuzgó +ügydarab +ügyész +ügyészség +ügyefogyott +ügyel +ügyelet +ügyeletes +ügyeleti +ügyelget +ügyes +ügyes-bajos +ügyesforma +ügyeskedik +ügyeskedő +ügyesség +ügyetlen +ügyetlenkedik +ügyfél +ügyintézés +ügyirat +ügyismeret +ügykör +ügylet +ügymenet +ügynök +ügyvéd +ügyvédék +ügyvédi +ügyvédné +ügyvezető +ühüm +ükapa +ül +üldögél +üldögélés +üldöz +üldözés +üldözési +üldözendő +üldözött +üldöző +üldöztetés +ülés +ülésezik +ülésterem +ülep +üllő +ülnök +ülő +ülőbútor +ülődeszka +ülőfogyasztás +ülőhely +ülőizom +ülőke +ülte +ültet +ültetés +ülve-emésztés +ünnep +ünnepély +ünnepélyes +ünnepélyesség +ünnepel +ünnepi +ünnepies +ünneplés +ünneplő +ünnepnap +ünnepség +ünnepségrendező +ünő +üreg +üreges +üregfal +üres +üresség +ürge +ürgeöntés +ürít +ürrakétarobbanás +ürügy +ürülék +üstök +üstökös +üstökösgém +üstökű +üszkös +üszkösödik +üsző +üt +üt-vág +ütés +üteg +ütem +ütemes +ütemez +ütközet +ütközik +ütköző +ütlegel +ütöget +ütött-kopott +ütő +ütődött +üttet +üveg +üvegablak +üvegajtó +üvegasztal +üvegasztalka +üvegcsarnok +üvegcse +üvegcserép +üvegdarab +üvegelőtetős +üveges +üvegez +üvegfal +üvegfalú +üveggömbös +üveggolyó +üveggyár +üveggyöngyös +üvegház +üvegházi +üveghalom +üveghangú +üvegillúzió +üvegkalitka +üvegkék +üvegköves +üvegkocka +üvegkupola +üveglap +üvegmeggy +üvegpohár +üvegpusztulás +üvegszekrény +üvegszerű +üvegszilánk +üvegtábla +üvegű +üvegváza +üvegveranda +üvegverandás +üvegvirágzó +üvölt +üvöltés +üvöltözés +üvöltözik +üvöltő +üzér +üzekedik +üzelmek +üzem +üzemanyag +üzemanyagpótlás +üzembiztos +üzemegység +üzemegység-iroda +üzemegység-vezető +üzemel +üzemi +üzemi-gyakorlati +üzemiroda +üzemképes +üzemszervezési +üzemtechnikusi +üzemvezető +üzemvezető-helyettes +üzemzavar +üzen +üzenet +üzlet +üzletajtó +üzletasszony +üzletember +üzletfél +üzlethálózat +üzletház +üzlethelyiség +üzleti +üzletkötés +üzletkötő +üzletvezető +üzletvitel +űr +űrállomás +űrbeli +űrgép +űrháttér +űrhajó +űrhajós +űrközlekedés-tudományi +űrközlekedési +űrkutatás +űrlap +űrmámor +űrméret +űröltözet +űrrakéta +űrruha +űrszanatórium +űrtáv-hajózási +űz +váci +vád +vádaskodás +vádaskodik +vádló +vádlott +vádol +vág +vágány +vágás +vágástér +vágású +vágat +vágódik +vágóhíd +vágott +vágta +vágtázik +vágtat +vágy +vágyálom +vágyás +vágyakozás +vágyakozik +vágyik +vágyódás +vágyódik +vágyott-álmodott +vágyú +váj +vájár +vájári +vájat +vájdling +vájkál +vájvég +vákáncsos +válás +váladék +válasz +válaszadás +válaszol +válaszolgat +választ +választás +választávirat +választék +választékos +választípus +választmány +választott +válaszút +válfaj +válható +válik +váll +vállal +vállalás +vállalat +vállalati +vállalatvezető +vállalkozás +vállalkozik +vállalkozó +vállalkozókedv +vállas +vállfa +vállizom +vállmagaság +vállpántos +vállrándítás +vállrojt +vállú +vállvonás +vállvonogatás +vállvonogatva +válófélben +válóper +válóperi +válogat +válogatás +válogatós +válogatott +válság +válságos +vált +váltás +váltakozás +váltakozik +váltakozó +váltig +váltó +váltóőr +váltóügyvéd +váltogat +változás +változat +változatlan +változatlanság +változatos +változatosság +változékony +változékonyság +változik +változó +változtat +változtatás +váltság +vályog +vályogfal +vályogház +vályogkerítés +vályogkunyhó +vályú +vám +vámőr +vámtisztviselő +vámvizsgálat +vándor +vándorcirkuszos +vándorkomédiás +vándorlás +vándorol +vándorpap +vándorút +vánkos +vánkosciha +vánkosszínű +vánszorog +ványai +vár +várás +várakozás +várakozásteljes +várakozik +várakozó +várakoztat +várakoztatás +váralja +várandós +várat +váratlan +váratlanság +várbeli +várfal +várfogság-büntetés +várható +várkastély +vármegye +vármegyei +várnagy +váró +várócsarnok +várószoba +váróterem +város +városállam +városcímer +városépítés +városfal +városfantom +városfejlesztési +városház +városháza +városházi +városi +városias +városiasodás +városirtó +városka +városlakó +városligeti +városnegyed +városrész +városrendezés +városszéli +városszerte +várostorony +városúr +várpince +várrom +várt +várudvar +vásár +vásárcsarnok +vásári +vásárlás +vásárlási +vásárló +vásárol +vásárolhatnék +vásáros +vásározó +vásártér +vásott +vászon +vászonbetétes +vászonblúz +vászonhuzat +vászonkalap +vászonnadrág +vászonredőny +vászonroló +vászonruha +vászonsapka +vászontasak +vászontetős +vászonzacskó +vászonzsák +vászonzubbony +váz +váza +vázlat +vázlatos +vacak +vacakol +vacog +vacogás +vacok +vacsora +vacsora-kenyér +vacsorál +vacsorázás +vacsorázik +vacsoráztat +vacsoracsillag +vacsoraidő +vad +vadállat +vadász +vadászat +vadászati +vadászbarátság +vadászetika +vadászfegyver +vadászgat +vadászház +vadászidő +vadászik +vadászkutya +vadászlak +vadászpuska +vadászrész +vadászrepülő +vadászszenvedély +vadásztársaság +vadásztanya +vadászterület +vadásztörténet +vadászvacsora +vadászvér +vadalma +vadbarom +vadborsó +vaddisznó +vademberi +vadgazdálkodó +vadgesztenyefa +vadhajtás +vadízű +vadidegen +vadkereskedelem +vadkutya +vadliba +vadlúdcsapat +vadmacska +vadmadár +vadmagyarság +vadmarha +vadméh +vadmeggy +vadmeggyfa +vadnövény +vadőr +vadon +vadonatúj +vadréce +vadság +vadszőlő +vadszőlőbokor +vadszőlős +vadul +vadvíz +vadvirág +vagány +vagdal +vagdos +vagina +vagon +vagonablak +vagonajtó +vagongyár +vagonrakás +vagy +vagyis +vagyishogy +vagyon +vagyongyűjtés +vagyoni +vagyonka +vagyonos +vagyonreménység +vaj +vajákos +vajas +vajaskifliszerű +vajaz +vajda +vajfehér +vajha +vajmi +vajon +vajsárga +vajszínű +vajúdás +vak +vakáció +vakar +vakarás +vakarcs +vakargat +vakaródzik +vakbuzgó +vakfoltos +vakít +vakítás +vakító +vakkanásszerű +vakkant +vaklárma +vakmerő +vakmerőség +vakol +vakolat +vakolatdarab +vakolatú +vakondok +vakoskodik +vakráma +vakremény +vakság +vaksi +vaksötét +vaktában +vaktöltény +vakulás +vakvágány +vakvágat +vala +valaha +valahány +valahányszor +valahai +valahogy +valahol +valahonnan +valahova +valaki +valameddig +valamely +valamelyes +valamelyest +valamelyik +valamennyi +valamennyire +valamerre +valami +valamicske +valamifajta +valamiféle +valamiként +valamiképpen +valamikor +valamilyen +valaminő +valamint +valamirevaló +vall +vallás +vallási +vallásos +vallásszabadság +vallásügy +vallat +vallatás +vallató +vallomás +való +valóban +valódi +valójában +valóság +valóságértékű +valósággal +valóságos +valószerűség +valószerűtlen +valószínű +valószínűleg +valószínűség +valószínűsít +valószínűtlen +valuta +valutaügy +vamzer +vamzerolás +van +vanília +varázs +varázsamulett +varázserő +varázseszköz +varázsháló +varázslat +varázslatos +varázsló +varázsol +varázsos +varázsütés +varázsüveg +varas +varga +varga-féle +vargabetű +variáció +variál +varjú +varjúféle +varjúleves +varkocs +varr +varrás +varrat +varróleány +varrónő +varroda +varrogat +varsa +varsányi +vartyogás +vas +vaságy +vasárnap +vasárnapi +vasajtó +vasal +vasalatlan +vasalkatrész +vasaló +vasalt +vasas +vasbánya +vasbeton +vasbot +vascső +vasék +vasfokos +vasfüggöny +vasfű +vasgálya +vasgolyó +vasgyár +vashágcsó +vashinta +vashomlokú +vashuzal +vasipari +vaskályha +vaskampó +vaskapu +vaskarika +vaskéz +vaskereskedés +vaskereskedő +vaskeretes +vaskerítés +vaskesztyűs +vaskezű +vaskos +vaslépcső +vaslétra +vaslemez +vaslogika +vasmarok +vasorrú +vaspánt +vaspántos +vaspajszer +vaspillér +vaspor +vasrács +vasrácsos +vasreszelék +vasretesz +vasrúd +vassúly +vasszerkezet +vastag +vastagbél +vastartó +vastorkú +vastragacs +vasút +vasútállomás +vasúti +vasútoldal +vasútrészvény +vasútüzlet +vasútvonal +vasutas +vasutastiszt +vasutazik +vasvázas +vasvilla +vasvillaszem +vatikáni +vattacsomó +vattaréteg +vau +vb-titkár +vb-ülés +vécé +véd +védekezés +védekezési +védekezik +védelem +védelmez +védelmező +védelmi +védenc +véderő +védetlen +védett +védettség +védhetetlen +védőberendezés +védőgát +védőköpeny +védőkupola +védőmű +védőszárny +védőügyvéd +védővám +védtelen +védtelenség +vég +végállomás +végbél +végbélrákos +végbemegy +végcél +végérvényes +végeérhetetlen +végeláthatatlan +végelgyengülés +végeredmény +véges +véges-végig +végeszakadhatatlan +végetér +végett +végez +végezet +végezetlen +végezetül +végezhető +végezte +végeztet +végi +végítélet +végig +végigaraszol +végigballag +végigböngész +végigbolyong +végigcaftat +végigcammog +végigcirógat +végigcsámcsog +végigcsapkod +végigcsépel +végigcsepegtet +végigcsinál +végigcsorog +végigcsúszik +végigcsúsztat +végigcuppog +végigdidereg +végigdöng +végigdönget +végigdől +végigdrukkol +végigdübörög +végigél +végigeszik +végigfekszik +végigfolyik +végigfut +végigfuttat +végiggondol +végiggurul +végiggyalogol +végighajtat +végighalad +végighallgat +végighasad +végighemperedik +végigheveredik +végighordoz +végighúz +végighúzódik +végighurcol +végigjár +végigkérdez +végigkerget +végigkísér +végigkocogtat +végigkommandíroz +végigkopog +végigkopogtat +végigkúszik +végigküzd +végigkutat +végiglát +végiglátogat +végiglapoz +végiglépdel +végiglépeget +végiglopódzik +végigmászik +végigmarháskodik +végigmér +végigmegy +végigmond +végignéz +végignyúl +végignyúlik +végigolvas +végigoson +végigpásztáz +végigreped +végigrobog +végigrohan +végigropogtat +végigsandít +végigsétál +végigsiet +végigsiklat +végigsimít +végigsimogat +végigskálázik +végigsöpör +végigspriccel +végigsuhan +végigszáguld +végigszámol +végigszánt +végigszalad +végigszimatol +végigtántorog +végigtapint +végigtapogat +végigtipor +végigtöröl +végigtol +végigül +végigutazik +végigvág +végigvágódik +végigvándorol +végigvár +végigvadászik +végigver +végigvet +végigvezényel +végigviharzik +végigvisz +végigvizslat +végigvonszol +végigvonul +végigzongoráz +végigzuhan +végképpen +végkielégítés +végkövetkeztetés +véglény +végleg +végleges +véglet +végletes +végletesség +végnap +végösszeg +végpont +végpusztulás +végre +végre-valahára +végrehajt +végrehajtás +végrehajtó +végrendelet +végső +végszó +végtag +végtére +végtelen +végtelenség +végtisztelet +végtisztesség +végül +végű +végzet +végzetes +végzetszerű +végzett +végzettség +végződik +véka +vékony +vékonyka +vékonyodik +vél +vélekedés +vélekedik +vélemény +véleményez +véleménykülönbség +véletlen +véletlenség +véletlenszerű +véletlenül +vélt +vén +véna +vénasszony +vénasszonyos +vénember +vénlány +vénlányság +vénség +vénül +vér +vérátömlesztés +vérbeli +vérbő +vércse +vércsepp +véreb +vérellátó +vérengzés +vérengzik +vérengző +véres +véreshurka +vérhas +vérhullám +vérittas +vérivó +vérkeringés +vérkeveredés +vérlázító +vérmérsékletű +vérmes +vérnarancsszállítmány +vérnyomás +vérnyomásmérő +vérontás +vérpiros +vérrokon +vérsejt +vérszag +vérszegény +vérszem +vérszerződés +vérszínű +vérszívó +vérszomjas +vértanú +vértelen +vérvétel +vérvörös +vérzés +vérzik +vés +véső +vésődik +vésőhenger +vész +vészbíróság +vészes +vészfelhő +vészjel +vészjósló +vészkijárat +vét +vétek +vétel +vételez +vétkes +vétő +vétség +vézna +vedlett +vegetáció +vegetál +vegetálás +vegyész +vegyelemzés +vegyelemző +vegyes +vegyest +vegyi +vegyít +vegyszer +vegyszerszekrény +vegytan +vegyül +vegyület +vehető +vekker +vekkeróra +vele +velebeli +velejáró +velencei +veleszületett +velő +vemhe +vendég +vendégbarátság +vendégeskedik +vendégjárás +vendégkaréj +vendégkör +vendéglátás +vendéglátó +vendéglátó-ipari +vendéglátóhely +vendéglő +vendéglői +vendéglős +vendégoldal +vendégoldalrúd +vendégpüspök +vendégség +vendégsereg +vendégszerepel +vendégszereplés +vendégszeretet +vendégszerető +vendégszoba +vendégvadász +ventillátor +venyige +venyigeszár +ver +veranda +verbéna +verdes +verdesés +veréb +verébfióka +verébszínű +verés +vereget +verejték +verejtékcsepp +verejtékes +verejtékezik +verekedés +verekedik +verekedő +verem +vereség +veret +vergődés +vergődik +verhetetlenség +verkli +verniszázs +verőce +verődik +vers +verseng +versengés +verseny +versenyez +versenyképes +versenyló-comb +versenynap +versenytárs +versenytapasztalat +versenyző +verses +verseskönyv +versgyűjtemény +verssor +vert +vertikális +vertikalitás +verzió +vese +vesebaj +vesemedence +vesepecsenye +vessző +vesszőcsokor +vesszőfutás +vesszőgóré +vesszőkosár +vesz +veszély +veszélyes +veszélyeztet +veszélyeztetett +veszélyeztetettség +veszélytelen +veszedelem +veszedelmes +veszekedés +veszekedett +veszekedik +veszendő +veszett +veszettség +veszít +veszítenivaló +veszkődik +vesződés +vesződik +vesződség +veszprémi +veszt +veszte +vesztés +vesztési +vesztegel +veszteget +vesztegetés +vesztenivaló +vesztes +veszteség +vesztett +vesztőhely +vet +vetélkedés +vetélytárs +vetélytársnő +vetés +vetési +vetekedik +vetemény +veteményes +vetemedik +veterán +vetetlen +vetít +vetítés +vetítő +vetítőterem +vetkezés +vetkezik +vetkeztet +vetkőzés +vetkőzik +vetkőztet +vetődik +vetőmag +vetül +vetület +vevő +vevődik +vevőernyő +vevőtér +vezényel +vezényszó +vezér +vezércikk +vezércikkíró +vezérel +vezérezredes +vezérfarkas +vezérgép +vezéri +vezérigazgató +vezérkar +vezérkari +vezérlés +vezérlésű +vezérlőasztal +vezérlőpult +vezérlőterem +vezérség +vezérszólam +vezekel +vezeklés +vezet +vezeték +vezetékes +vezetéknév +vezetés +vezető +vezetőbíró +vezetőfülke +vezetőgárda +vezetői +vezetőség +vezetőségi +vezetőszerv +víg +víg-lakás +víkend +víkendház +víkendtelek +vírus +vív +vívás +vívmány +vívó +vívódik +víz +vízállás +vízálló +vízbefúl +vízcsap +vízcsepp +vízcseppnyi +vízcsobogás +vízellátás +vízelvezető +vízesés +vízfelhő +vízfesték +vízfolyás +vízforrás +vízhatlan +vízi +víziállat +vízibuszmegálló +víziló +vízimalom +vízió +vízipálma +vízipuska +vízitetű +vízivás +vízkék +vízkereszt +vízkitörés +vízlefolyás +vízlevezető +vízlocsogás +vízmosás +vízművek +vízoszlop +vízpart +vízparti +vízrajzi +vízsugár +vízszagú +vízszint +vízszintes +víztároló +víztartalom +víztócsa +víztömeg +víztorony +víztükör +vízügyi +vízum +vízvessző +vízvezeték +vízvezeték-pumpa +vízvezetékszerelő +vízzubogás +vízzuhatag +viadal +viaskodás +viaskodik +viaszliliom +viaszosvászon +viaszpanoptikum +viaszszínű +vibrál +vibrálás +vicc +viccel +viccelődik +vicces +vicclap +vicelakás +vicinális +vicsor +vicsorgat +vicsorít +vicsorog +vidám +vidámság +vidék +vidéki +vidékies +vidor +vidra +vigad +vigalom +vigasz +vigasztal +vigasztalás +vigasztalan +vigasztaló +vigasztalódik +vigyáz +vigyázat +vigyázatlan +vigyázz +vigyor +vigyorgás +vigyori +vigyorog +viháncol +viháncolás +vihar +viharálló +viharfelhő +viharfelhős +viharfelhőszerű +viharkabát +viharkabátos +viharlámpa +viharos +viharzik +viharzó +vihog +vihogás +vihorászás +vijjog +vijjogás +vikárius +vikszel +vikszol +világ +világalkony +világbajnok +világbajnokság +világbíró +világbirodalom +világcsászárság +világcsavargó +világéletében +világegyetem +világfi +világgazdaság +világháború +világháborús +világhatalom +világhír +világhírű +világi +világít +világítás +világító +világítós +világítóudvar +világirodalom +világjáró +világjárt +világkép +világképű +világközvélemény +világméretű +világmindenség +világnagy +világnap +világnézet +világnézeti +világnyelv +világos +világosbarna +világosító +világoskék +világosodás +világosodik +világosság +világosszürke +világoszöld +világpiaci +világpolitika +világprotézis +világraszóló +világrekord +világszenzáció +világszerte +világszínvonal +világszövetkezés +világtáj +világtalan +világtér +világtérkép +világtörténelem +világüresség +világűr +világuralmi +világváros +világvárosi +világvége +világverseny +világvevő +világviszonylat +villa +villám +villámcsapás +villámgyors +villámgyorsaság +villámvágta +villaavatás +villakupac +villamos +villamosbérlet +villamoskalauz +villamoskocsi +villamosmegálló +villamosremíz +villamossín +villamosutazás +villamosvezető +villan +villanás +villanásnyi +villanó +villant +villany +villanyáram +villanybojler +villanyborotva +villanyégő +villanyfény +villanyfényes +villanyfőző +villanygyertya +villanygyújtás +villanykályha +villanykapcsoló +villanyköd +villanykörte +villanymelegítő +villanyóra +villanypózna +villanyszámla +villanyszámlás +villanyszerelő +villanytelep +villanyvasaló +villaszerű +villatelep +villódzás +villódzik +villog +villogás +villogó +vinkó +vinnivaló +vinnyog +vinnyogásszerű +viola +vipera +viplafog +virág +virágágy +virágágyás +virágárus +virágbóbita +virágcsokor +virágerdő +virágfüzér +virághernyó +virágillat +virágillatos +virágillatú +virágkereskedés +virágkosár +virágkoszorús +virágkultusz +virágmag +virágnév +virágözön +virágos +virágoskert +virágpalánta +virágpiac +virágsziget +virágtartó +virágtenger +virágtő +virágú +virágüzlet +virágváza +virágvadász +virágzás +virágzik +virágzó +virgonc +virgoncság +virít +virilista +virrad +virradat +virraszt +virrasztás +virsli +virtus +virul +visel +viselés +viselet +viselkedés +viselkedésforma +viselkedési +viselkedik +viselő +viselt +viseltes +visít +viskó +visong +visongat +vissza +vissza-visszacsillan +vissza-visszafordul +vissza-visszales +vissza-visszaszáll +vissza-visszatér +visszája +visszás +visszaáll +visszaállít +visszaad +visszaadat +visszabarnul +visszabiccent +visszabotorkál +visszacsatol +visszacsendül +visszacseng +visszacsíp +visszacsinál +visszacsinálhatatlan +visszacsókol +visszacsomagol +visszacsúszik +visszadöccen +visszadől +visszadob +visszadug +visszaédesget +visszaél +visszaélés +visszaépít +visszaépítés +visszaér +visszaérkezés +visszaérkezik +visszaejt +visszaemel +visszaemlékezik +visszaenged +visszaereszkedik +visszaeső +visszafejlődik +visszafekszik +visszafektet +visszafelé +visszafizet +visszafizetés +visszafog +visszafoglal +visszafojt +visszafordít +visszafordul +visszafordulás +visszafordulta +visszafut +visszagondol +visszagurul +visszagyűr +visszahány +visszahajt +visszahajtogat +visszahall +visszahat +visszahelyez +visszahesseget +visszaheveredik +visszahív +visszahőköl +visszahord +visszahoz +visszahozhatatlan +visszahúz +visszahúzódás +visszahúzódik +visszahúzódta +visszahull +visszahullámzik +visszahurcol +visszaír +visszailleszt +visszaindul +visszaindulás +visszainteget +visszairányít +visszajár +visszajáró +visszajön +visszajövet +visszajut +visszajuttat +visszakanyarodik +visszakap +visszakapaszkodik +visszakapcsol +visszakattint +visszakényszerít +visszakér +visszakérdez +visszakéz +visszakecmereg +visszakerül +visszakísér +visszakísértet +visszakiált +visszakiabál +visszaköltözik +visszaköszön +visszakocsikázik +visszakozik +visszakúszik +visszaküld +visszakuporodik +visszalapoz +visszalép +visszalépdel +visszales +visszalóg +visszalök +visszalövell +visszalop +visszalopakodik +visszamászik +visszamázsálás +visszamarad +visszamegy +visszamerészkedik +visszamerül +visszaminősít +visszamond +visszamosolyog +visszanéz +visszanyel +visszanyelvel +visszanyer +visszanyom +visszanyúl +visszanyúlik +visszaönt +visszaomlik +visszaordít +visszaoson +visszaparancsol +visszapattan +visszaperdül +visszaperget +visszapillant +visszapillantó +visszapörget +visszapörög +visszaprésel +visszarabol +visszarak +visszarecseg +visszarendel +visszarepül +visszariad +visszariaszt +visszarobog +visszarohan +visszasétál +visszasereglik +visszasír +visszasiet +visszaslattyog +visszasüllyed +visszasurran +visszaszájal +visszaszáll +visszaszállít +visszaszállingózik +visszaszámlálás +visszaszerel +visszaszerez +visszaszól +visszaszökik +visszaszolgáltat +visszaszorít +visszatámaszt +visszatáviratozik +visszatalál +visszatart +visszataszító +visszatér +visszatérés +visszatérít +visszatérő +visszateker +visszatekint +visszatelepedik +visszatesz +visszatetsző +visszatiszteleg +visszatöm +visszatol +visszatűz +visszaúszik +visszaút +visszaül +visszaüt +visszaüvölt +visszaugrik +visszautasít +visszautasítás +visszautasító +visszautazik +visszavág +visszavágódik +visszavágtat +visszavágyik +visszavált +visszaváltozik +visszavár +visszavarázsol +visszavarázsolódik +visszaver +visszaverődik +visszavesz +visszavet +visszavezet +visszavezethető +visszavigyorog +visszavisz +visszavon +visszavonás +visszavonhatatlan +visszavontat +visszavonul +visszavonulás +visszavonuló +visszavonult +visszavonultság +visszavonz +visszazár +visszazökken +visszazökkent +visszazuhan +visszér +visszeres +visszfény +visszhang +visszhangos +visszhangoz +visszhangzik +visz +visz-mos +viszály +viszket +viszketés +viszketeg +viszlát +viszolygás +viszolyog +viszolyogtat +viszonoz +viszont +viszontagság +viszontagságos +viszontlát +viszontlátás +viszontlátásra +viszontszeret +viszony +viszonyít +viszonylag +viszonylagos +viszonylat +viszonzás +vita +vitályosi +vitás +vitázik +vitalehetőség +vitalitás +vitamin +vitaminhiány +vitapartner +vitat +vitatható +vitatkozgat +vitatkozik +vitatott +vitéz +vitézi +vitézlő +vitézség +vitézségi +vitel +vitet +vitorla +vitorlás +vitorlázik +vitorlabontás +vitorlavászon +vitrin +vitriol +vityilló +vizelde +vizenyős +vizes +vizesárok +vizesbögre +vizesdézsa +vizeskancsó +vizeskék +vizesnyolcas +vizespohár +vizez +vizigót +vizit +vizitel +vizsga +vizsgál +vizsgálat +vizsgálati +vizsgálgat +vizsgálóbíró +vizsgálódás +vizsgálódik +vizsgázik +vizsgáztatás +vizsgaszünet +vizsla +vizslat +vizű +vödör +völgy +völgyecske +völgyhajlat +vörhenyes +vörös +vörös-borostás +vörös-fehér +vörös-fekete +vörösbarna +vöröses +vörösesbarna +vöröseslila +vörösesszőke +vörösfenyő +vörösgárda +vörösgém +vöröshagyma +vöröskatona +vöröskeresztes +vöröslábú +vöröslámpás +vöröslik +vörösödik +vörösőrség +vöröstéglás +vő +vőfély +vőlegény +vőlegényék +vodka +vodkásüveg +vogul +vokális +voks +volán +volna +volt +volta +voltaképpen +voltaképpeni +volumen +voluntarista +von +vonás +vonású +vonaglik +vonakodik +vonal +vonalbeli +vonalszakasz +vonalú +vonalvezetés +vonalzó +vonat +vonatablak +vonatérkezés +vonatindulás +vonatjegy +vonatkozás +vonatkozik +vonatkozó +vonatkoztat +vonható +vonít +vonításszerű +vonó +vonóhorog +vonogat +vonszol +vontat +vontató +vontatógőzös +vontatott +vonul +vonulás +vonz +vonzás +vonzáskör +vonzású +vonzalom +vonzó +vonzódik +vonzóerő +vonzókör +vulgáris +vulgarizál +vulkanikus +watt +wattos +web +webáruház +webhely +weblap +webszolgáltató +xilofon +xilofonművész +zágrábi +zákányi +zálog +zálogház +zápor +záporoz +zár +zárándi +zárás +záradék +zárat +zárda +zárka +zárkatárs +zárkózik +zárkózott +zárkózottság +zárlat +záródísz +záródik +zárójel +zárójelentés +záróra +zárótűz +záróünnepély +zárt +zártkörű +zártság +zárul +zászló +zászlóalj +zászlóalj-segédtiszt +zászlóaljparancsnok +zászlócska +zászlónyél +zászlónyelv +zászlós +zászlótartó +zátony +zab +zabál +zabáltat +zabfőzet +zabigyerek +zabikál +zabla +zabolázható +zabos +zacskó +zafírkő +zagyvaság +zaj +zaj-fény +zaj-kvantum +zajgás +zajlás +zajlik +zajong +zajongás +zajos +zajtalan +zakatol +zakatolás +zaklat +zaklatott +zaklatottság +zakó +zalai +zamat +zarándok +zarándokol +zarándokvonat +zavar +zavarás +zavargás +zavarkeltő +zavarkodik +zavaró +zavarodott +zavarodottság +zavaros +zavart +zavartalan +zavartalanság +zavartat +zavartság +zebra +zebracsíkos +zegzug +zegzugos +zeke +zeller +zempléni +zendülés +zene +zenél +zenélőóra +zenés +zenész +zenebona +zenei +zeneiskola +zenekar +zeneszám +zeneszerző +zeneutánzat +zeng +zengés +zengésű +zerge +zetoros +zihál +zihálás +zilál +zilált +zilahi +zimankós +zivatar +zizeg +zizzen +zóna +zökken +zökkenés +zöld +zöld-barna +zöld-ezüst +zöld-fehér +zöldbab +zöldell +zöldes +zöldfülű +zöldinges +zöldkeretes +zöldköves +zöldpaprika +zöldruhás +zöldség +zöldséges +zöldségestábla +zöldségféle +zöldségpiac +zöldségszag +zöldségtermesztés +zöldselyem +zöm +zömök +zörej +zörgés +zörget +zörgetés +zörgős +zörög +zörren +zörrenés +zöttyen +zötyköl +zötykölődik +zötyög +zokni +zokog +zokogás +zokon +zokszó +zománc +zománcos +zománcozott +zománcú +zongora +zongorázás +zongorázik +zongorapartner +zongoraszó +zongorista +zord +zordon +zríkol +zúdít +zúdul +zúg +zúgás +zúgat +zúgolódik +zúz +zúzódás +züllik +züm-züm +züm-züm-züm +zümi-zümi +zümmög +zümmögés +zűr +zűrös +zűrzavar +zubbony +zubbonynyak +zubog +zubogás +zug +zugfelcserkedés +zuhan +zuhanás +zuhanó-emelkedő +zuhany +zuhanyozó +zuhatag +zuhog +zuhogás +zuhogó +zs +zsák +zsákdarab +zsákhálóing +zsákmány +zsákmányol +zsákmányszerző +zsákszerű +zsákutca +zsálya +zsámoly +zsakett +zsalu +zsalugáter +zsandár +zsarát +zsarnok +zsarnok-kakas +zsarnoki +zsarnokság +zsarol +zsaroló +zsaru +zseb +zsebes +zsebkés +zsebkendő +zsebkendőnyi +zsebkiadás +zseblámpa +zsebmetsző +zsebnaptár +zsebóra +zsebpénz +zsebpénzprobléma +zsebrádió +zsebtükör +zsemle +zsenge +zseni +zseníroz +zseniális +zsenialitás +zserbó +zsír +zsírbontó +zsírfolt +zsírfoltos +zsírfolyó +zsírgolyó +zsírgulyás +zsírmaszat +zsíros +zsírosbödön +zsírosodó +zsíroz +zsírpacni +zsírpecsét +zsírpuszta +zsírtartalék +zsírtemplom +zsírtócsa +zsírtömb +zsibbad +zsibbadás +zsibbadt +zsibong +zsibongás +zsidó +zsidóasszony +zsidóság +zsidótörvény +zsiger +zsigeri +zsilett +zsilip +zsinagóga +zsinat +zsindelyes +zsineg +zsinór +zsiradék +zsivaj +zsivajgás +zsivajog +zsivajos +zsöllye +zsörtölődés +zsörtölődik +zsörtös +zsoké +zsokésapka +zsokésapkás +zsold +zsoldfizetés +zsoldos +zsoldpénz +zsoltár +zsoltárkönyv +zsoltároskönyv +zsombék +zsombékos +zsong +zsongás +zsongít +zsonglőrködés +zsorzsettfátyol +zsúfol +zsúfolás +zsúfolódik +zsúfolt +zsúfoltság +zsúp +zsúpfedél +zsúpfedeles +zsúpos +zsúptetős +zsugázik +zsugori +zsugorodik +zsumók +zsupsz \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szo.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szo.txt new file mode 100644 index 0000000..cd61d6e --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/szo.txt @@ -0,0 +1,5 @@ +orvostudomnyi + + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/zemplen.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/zemplen.txt new file mode 100644 index 0000000..a673483 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/Források/zemplen.txt @@ -0,0 +1,6 @@ +ZEMPLN +Ahol a tj llandan vltozik +Milyen vidk ez? Nehz lenne nhny szval jellemezni a sokarc, vibrl, mgis fensges nyugalmat raszt tjat, ahol az ember s a termszet vszzadok ta l szeld harmniban. A Zemplni-hegysg s a Bodrogkz tallkozsnl formldott terleten ezernyi mdjt tallja az ember akr az utaz, akr az itt l - , hogy megismerje a termszetet, hogy kzel kerljn csodihoz. Az svnygyjt, a madarak letre kvncsi ornitolgus, a vadak csapsait jr erdszeret ember, a vzparton csendesen ldgl horgsz ppgy megtallja az rmt, mint a tjat gyalogosan, kenuval vagy kerkprral bebarangol turista. +A Zemplni-hegysg terletn a miocn kor, 15-20 milli ve mkdtt tzhnyk vulkanizmusnak anyaga s a hajdani vulknok lepuszttott, a termszet eri ltal alaktott formakincse uralkodik. Itt tallhat a mai Magyarorszg legmagasabb, legpebben megmaradt tzhny kpja, a tokaji Nagy-Kopasz, mely bszke vdbstyaknt rzi a Zemplni hegyvidket s a Tisza-Bodrog sszefolys trtnelmileg igen jelents terlett. A drmai hats csoportba rendezdtt Stor-hegyek is egy hajdani tzhny kalderjnak lepusztult maradvnyai, melynek mretei taln az Etna mai mreteivel vetekedtek. +A hegysget ltrehoz vulkanizmus a trsg mai kpre is rnyomja blyegt. A kzetek bnyszhat nyersanyagokban val gazdagsga s a vulkanikus talajokon term kivl minsg szl mindmig meghatrozza a tj embernek lett. A hegysg felsznt a szegly lejtin s szoknyjn a szl uralja, mg a hegyvidk bels terletein rintetlen erdk, kzpkori eredet fs legelk s rtek vltakoznak. +Az ide ltogat turista szinte napokig gyalogolhat anlkl, hogy a mai iparosodott trsadalom brmi jelt is tapasztalnia kellene. Olyan vidk ez, ahol a dli melegkedvel flra s a Krptok magashegyi nvnyei randevznak egymssal, ahol mg ma is viszonylagos zavartalansgban lhet az orszgosan is kiemelked vadllomny, ahol visszatelepltnek mondhat a hiz s a farkas s ahol vilgels muflon- s gmtrfek jellemzik az llomny minsgt. A terlet termszeti rtkeinek, gazdag nvny- s llatvilgnak vdelmben hoztk ltre a Zemplni Tjvdelmi Krzetet. \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Feladatok/Dolgozat2.pdf b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Feladatok/Dolgozat2.pdf new file mode 100644 index 0000000..b6cd8f3 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Feladatok/Dolgozat2.pdf differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/2023. 04. 25.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/2023. 04. 25.csproj new file mode 100644 index 0000000..956a45f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/2023. 04. 25.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._04._25 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/Program.cs new file mode 100644 index 0000000..40c5071 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/Program.cs @@ -0,0 +1,42 @@ +using System; +using System.IO; + +namespace _2023._04._25 +{ + class Program + { + static void Feladat() + { + Random rng = new Random(); + List szamok = new List(); + int szam; + + for(int i = 0; i < 100; i++) + { + szam = rng.Next(50, 751); + szamok.Add(szam); + } + + using(StreamWriter sw1 = new StreamWriter("szamok.txt")) + { + foreach(int i in szamok) + { + sw1.WriteLine(i); + } + } + + using(StreamWriter sw2 = new StreamWriter("statisztika.txt")) + { + sw2.WriteLine($"A számok összege: {szamok.Sum()}"); + sw2.WriteLine($"A számok átlaga: {szamok.Average()}"); + sw2.WriteLine($"A számok minimuma: {szamok.Min()}"); + sw2.WriteLine($"A számok maximuma: {szamok.Max()}"); + } + } + + static void Main(string[] args) + { + Feladat(); + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json new file mode 100644 index 0000000..65a6033 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 04. 25/1.0.0": { + "runtime": { + "2023. 04. 25.dll": {} + } + } + } + }, + "libraries": { + "2023. 04. 25/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll new file mode 100644 index 0000000..3647167 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe new file mode 100644 index 0000000..dd1d283 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb new file mode 100644 index 0000000..76e1a13 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json new file mode 100644 index 0000000..4d9acfe --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj", + "projectName": "2023. 04. 25", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs new file mode 100644 index 0000000..e610725 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache new file mode 100644 index 0000000..33db146 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +0b7d1d7eafc9ce761538b0b6304c854bb036bc32 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d2dc8be --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._04._25 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache new file mode 100644 index 0000000..669cf1c Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..7919cad --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +5d2ec81f481a0768c27241c6a7e03451d373a5e2 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..4ce5ae7 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt @@ -0,0 +1,30 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\refint\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\2023. 04. 25\obj\Debug\net7.0\ref\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\refint\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Dolgozat\Kódok\2023. 04. 25\obj\Debug\net7.0\ref\2023. 04. 25.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll new file mode 100644 index 0000000..3647167 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache new file mode 100644 index 0000000..800426b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache @@ -0,0 +1 @@ +b6703b8151fac2b75d9e94038e25758ad394e6f5 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb new file mode 100644 index 0000000..76e1a13 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..dd1d283 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll new file mode 100644 index 0000000..6a5351a Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll new file mode 100644 index 0000000..6a5351a Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.assets.json new file mode 100644 index 0000000..c8b2b54 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj", + "projectName": "2023. 04. 25", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.nuget.cache new file mode 100644 index 0000000..8617170 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "O+V6+o8UW5bCp+eZ1fE16zbBQGUBTsFh72bhH8bkHhzUuzJKvxVUrlCGMEHCC6wyPb1KhXBoSrYL+PL1kS5qLQ==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Dolgozat\\Kódok\\2023. 04. 25\\2023. 04. 25.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/statisztika.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/statisztika.txt new file mode 100644 index 0000000..0ab39f3 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/statisztika.txt @@ -0,0 +1,4 @@ +A számok összege: 37268 +A számok átlaga: 372,68 +A számok minimuma: 56 +A számok maximuma: 745 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/szamok.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/szamok.txt new file mode 100644 index 0000000..42c0f23 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Dolgozat/Kódok/2023. 04. 25/szamok.txt @@ -0,0 +1,100 @@ +534 +644 +109 +595 +463 +174 +65 +323 +159 +426 +185 +241 +266 +277 +540 +108 +473 +651 +104 +589 +469 +708 +205 +638 +144 +541 +384 +229 +148 +86 +79 +287 +448 +458 +455 +642 +148 +300 +414 +324 +138 +305 +101 +568 +705 +89 +409 +527 +490 +370 +223 +622 +588 +393 +111 +122 +472 +294 +719 +203 +723 +73 +525 +101 +506 +346 +137 +626 +745 +525 +246 +89 +257 +700 +213 +121 +527 +432 +313 +434 +417 +285 +156 +56 +713 +693 +705 +351 +236 +286 +618 +422 +407 +269 +577 +62 +693 +61 +428 +712 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/2023. 04. 25.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/2023. 04. 25.csproj new file mode 100644 index 0000000..956a45f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/2023. 04. 25.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._04._25 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/Program.cs new file mode 100644 index 0000000..679cebe --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/Program.cs @@ -0,0 +1,23 @@ +using System; +using System.IO; + +namespace _2023._04._25 +{ + class Program + { + static void Main(string[] args) + { + try + { + int oszto = 0; + System.Console.WriteLine(10/oszto); + } + + catch (DivideByZeroException ar) + { + System.Console.WriteLine(ar.Message); + } + } + } +} + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json new file mode 100644 index 0000000..65a6033 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 04. 25/1.0.0": { + "runtime": { + "2023. 04. 25.dll": {} + } + } + } + }, + "libraries": { + "2023. 04. 25/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll new file mode 100644 index 0000000..7869ce2 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe new file mode 100644 index 0000000..dd1d283 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb new file mode 100644 index 0000000..741c45c Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/bin/Debug/net7.0/2023. 04. 25.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json new file mode 100644 index 0000000..ded5858 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.dgspec.json @@ -0,0 +1,61 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj", + "projectName": "2023. 04. 25", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/2023. 04. 25.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs new file mode 100644 index 0000000..e610725 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 04. 25")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache new file mode 100644 index 0000000..33db146 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +0b7d1d7eafc9ce761538b0b6304c854bb036bc32 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..e758b9b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._04._25 +build_property.ProjectDir = e:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache new file mode 100644 index 0000000..41b84d9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..7919cad --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +5d2ec81f481a0768c27241c6a7e03451d373a5e2 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..501c5cf --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\bin\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\refint\2023. 04. 25.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\2023. 04. 25.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 04. 25\obj\Debug\net7.0\ref\2023. 04. 25.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll new file mode 100644 index 0000000..7869ce2 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache new file mode 100644 index 0000000..367f7bb --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.genruntimeconfig.cache @@ -0,0 +1 @@ +f7518b34dc7533b10dd5a7341a3f66b7469a6f7e diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb new file mode 100644 index 0000000..741c45c Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/2023. 04. 25.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..dd1d283 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll new file mode 100644 index 0000000..6a5351a Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/ref/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll new file mode 100644 index 0000000..6a5351a Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/Debug/net7.0/refint/2023. 04. 25.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.assets.json new file mode 100644 index 0000000..969c3e6 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.assets.json @@ -0,0 +1,66 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj", + "projectName": "2023. 04. 25", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.nuget.cache new file mode 100644 index 0000000..ff79579 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 04. 25/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "WL8IxbPb1DXuriJ3qNI5fXoLBbwZLXRxSluFhlZhQ1ahjIBXtARPfS/DKRLKZjrLb2QuiTYyCIMIDyrpBxuuzQ==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 04. 25\\2023. 04. 25.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/2023. 05. 02.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/2023. 05. 02.csproj new file mode 100644 index 0000000..f32809b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/2023. 05. 02.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._05._02 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/Program.cs new file mode 100644 index 0000000..eca68b3 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/Program.cs @@ -0,0 +1,167 @@ +using System; +using System.IO; + +namespace _2023._05._02 +{ + class Program + { + static void Pelda1() + { + try + { + throw new System.Exception(); + } + + catch (System.Exception e) + { + System.Console.WriteLine(e.Message); + } + } + + static void Pelda2() + { + int oszto = 0; + double hanyados; + + try + { + hanyados = 10 / oszto; + } + + catch (ArithmeticException) + { + // MessageBox.Show(Convert.ToString(ar)); + } + + finally + { + // MessageBox.Show("A program ezen része mindenképpen lefut"); + } + } + + static void Pelda3() + { + try + { + string szoveg = "valami szoveg"; + int szam = Convert.ToInt32(szoveg); + System.Console.WriteLine(szam); + } + + catch (FormatException ex) + { + System.Console.WriteLine($"Valami hiba történt {{0}}: {ex.Message}"); + } + } + + static void Pelda4() + { + try + { + string szoveg = "valami szoveg"; + int szam = Convert.ToInt32(szoveg); + System.Console.WriteLine(szam); + } + + catch (Exception ex) + { + System.Console.WriteLine($"Valami hiba történt {{0}}: {ex.Message}"); + throw; + } + } + + static void Pelda5() + { + System.Console.WriteLine("Kettővel szorzunk v. 1.0"); + System.Console.WriteLine("Adjon egy egész páros számot!"); + + try + { + var bevitel = Console.ReadLine(); + int szam = Convert.ToInt32(bevitel); + + if (szam % 2 != 0) + { + throw new Exception("A szám nem páros!"); + } + System.Console.WriteLine($"A szorzás eredménye: {szam * 2}"); + } + + catch (Exception ex) + { + System.Console.WriteLine("HIBA történt"); + System.Console.WriteLine(ex.Message); + } + + finally + { + System.Console.WriteLine("Program vége. Nyomjon egy gombot a kilépéshez"); + } + } + + static void Feladat() + { + int szamlalo_a = 0; + int szamlalo_e = 0; + int szamlalo_i = 0; + int szamlalo_o = 0; + int szamlalo_u = 0; + + using (StreamReader sr = new StreamReader(@"E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\Források\szavak.txt")) + { + string content = sr.ReadToEnd(); + + for (int i = 0; i < content.Length; i++) + { + if(content[i] == 'a') + { + szamlalo_a++; + } + + if(content[i] == 'e') + { + szamlalo_e++; + } + + if(content[i] == 'i') + { + szamlalo_i++; + } + + if(content[i] == 'o') + { + szamlalo_o++; + } + + if(content[i] == 'u') + { + szamlalo_u++; + } + } + } + + if (File.Exists("eredmenyek.txt")) + { + using (StreamWriter sw = new StreamWriter("eredmenyek.txt")) + { + sw.WriteLine($"Az \"a\" karakterek száma: {szamlalo_a}"); + sw.WriteLine($"Az \"e\" karakterek száma: {szamlalo_e}"); + sw.WriteLine($"Az \"i\" karakterek száma: {szamlalo_i}"); + sw.WriteLine($"Az \"o\" karakterek száma: {szamlalo_o}"); + sw.WriteLine($"Az \"u\" karakterek száma: {szamlalo_u}"); + } + + System.Console.WriteLine("Sikeres kiírás!"); + } + + else + { + throw new FileNotFoundException("A fájl nem létezik te kutya!"); + } + } + static void Main(string[] args) + { + Feladat(); + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.deps.json new file mode 100644 index 0000000..e58a1b0 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 05. 02/1.0.0": { + "runtime": { + "2023. 05. 02.dll": {} + } + } + } + }, + "libraries": { + "2023. 05. 02/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.dll new file mode 100644 index 0000000..7c6a745 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.exe new file mode 100644 index 0000000..3161635 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.pdb new file mode 100644 index 0000000..f6e7fd3 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/bin/Debug/net7.0/2023. 05. 02.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.dgspec.json new file mode 100644 index 0000000..a7f9a9b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj", + "projectName": "2023. 05. 02", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/2023. 05. 02.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfo.cs new file mode 100644 index 0000000..b6dee09 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 05. 02")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 05. 02")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 05. 02")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfoInputs.cache new file mode 100644 index 0000000..00369c6 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +0d6241037f073c426cec30ddaa989187bb0876d9 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..24b3173 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._05._02 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.assets.cache new file mode 100644 index 0000000..440bc3b Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..1de10d0 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +eab0a847ec9f3228b9f7cf05856255e6305b5d47 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..bf45a85 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\bin\Debug\net7.0\2023. 05. 02.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\bin\Debug\net7.0\2023. 05. 02.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\bin\Debug\net7.0\2023. 05. 02.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\bin\Debug\net7.0\2023. 05. 02.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\bin\Debug\net7.0\2023. 05. 02.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\refint\2023. 05. 02.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\2023. 05. 02.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 02\obj\Debug\net7.0\ref\2023. 05. 02.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.dll new file mode 100644 index 0000000..7c6a745 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.genruntimeconfig.cache new file mode 100644 index 0000000..67c7b19 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.genruntimeconfig.cache @@ -0,0 +1 @@ +78928027a87e9995676e2e55a98ab03757530538 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.pdb new file mode 100644 index 0000000..f6e7fd3 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/2023. 05. 02.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..3161635 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/ref/2023. 05. 02.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/ref/2023. 05. 02.dll new file mode 100644 index 0000000..eb3db58 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/ref/2023. 05. 02.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/refint/2023. 05. 02.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/refint/2023. 05. 02.dll new file mode 100644 index 0000000..eb3db58 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/Debug/net7.0/refint/2023. 05. 02.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.assets.json new file mode 100644 index 0000000..1ad65e2 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj", + "projectName": "2023. 05. 02", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.nuget.cache new file mode 100644 index 0000000..56d8198 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 02/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "k4Mcv09yZS4I9wulJ22psndZVOAIdQ/qEEOcDXK93qm5D74KhJ6MzmLruW39E68E87szp+62MYu33KlKlHHxWA==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 02\\2023. 05. 02.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/2023. 05. 16.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/2023. 05. 16.csproj new file mode 100644 index 0000000..7d7d9ba --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/2023. 05. 16.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._05._16 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/Program.cs new file mode 100644 index 0000000..e864217 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/Program.cs @@ -0,0 +1,33 @@ +using System; + +namespace _2023._05._16 +{ + class Program + { + static void Eljaras(int a, int b) + { + System.Console.WriteLine($"A téglalap területe: {a} * {b} = {a * b}"); + } + + static int Fuggveny(int szam) + { + int db = 0; + do + { + szam /= 10; + db++; + System.Console.WriteLine(szam); + } + while(szam != 0); + return db; + } + + static void Main(string[] args) + { + System.Console.WriteLine("Kérek egy számot"); + int szam = Convert.ToInt32(Console.ReadLine()); + System.Console.WriteLine($"A számjegyek száma: {Fuggveny(szam)} db."); + } + } +} + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.deps.json new file mode 100644 index 0000000..1dfa9bb --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 05. 16/1.0.0": { + "runtime": { + "2023. 05. 16.dll": {} + } + } + } + }, + "libraries": { + "2023. 05. 16/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.dll new file mode 100644 index 0000000..931b207 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.exe new file mode 100644 index 0000000..8bde2aa Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.pdb new file mode 100644 index 0000000..4bdb33c Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/bin/Debug/net7.0/2023. 05. 16.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.dgspec.json new file mode 100644 index 0000000..2034e0b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj", + "projectName": "2023. 05. 16", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/2023. 05. 16.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfo.cs new file mode 100644 index 0000000..27e22d6 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 05. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 05. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 05. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfoInputs.cache new file mode 100644 index 0000000..f756dcd --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +cfe013ea4554c496775d84e4d88530a5cfc42e3a diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..9244232 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._05._16 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.assets.cache new file mode 100644 index 0000000..5996d43 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..5b9f437 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +377bd9df574b99130a6c57f286f9ddbb754cda71 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..37708f6 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\bin\Debug\net7.0\2023. 05. 16.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\bin\Debug\net7.0\2023. 05. 16.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\bin\Debug\net7.0\2023. 05. 16.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\bin\Debug\net7.0\2023. 05. 16.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\bin\Debug\net7.0\2023. 05. 16.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\refint\2023. 05. 16.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\2023. 05. 16.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 16\obj\Debug\net7.0\ref\2023. 05. 16.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.dll new file mode 100644 index 0000000..931b207 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.genruntimeconfig.cache new file mode 100644 index 0000000..ad1776c --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.genruntimeconfig.cache @@ -0,0 +1 @@ +8e8089894bdab790fa8a750d7fd7224a24f9ea49 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.pdb new file mode 100644 index 0000000..4bdb33c Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/2023. 05. 16.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..8bde2aa Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/ref/2023. 05. 16.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/ref/2023. 05. 16.dll new file mode 100644 index 0000000..75390d4 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/ref/2023. 05. 16.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/refint/2023. 05. 16.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/refint/2023. 05. 16.dll new file mode 100644 index 0000000..75390d4 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/Debug/net7.0/refint/2023. 05. 16.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.assets.json new file mode 100644 index 0000000..c2de956 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj", + "projectName": "2023. 05. 16", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.nuget.cache new file mode 100644 index 0000000..677cb4d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 16/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "NbDqdrc11AMTtiqABqQZoXjCLfuMM96oVMw6reFFddKvMFNG6qeb1LtGTl30J30Gu1vKFZttEstlBZBMFB0Y+Q==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 16\\2023. 05. 16.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/2023, 05, 23.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/2023, 05, 23.csproj new file mode 100644 index 0000000..285a121 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/2023, 05, 23.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023__05__23 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/Program.cs new file mode 100644 index 0000000..6943050 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/Program.cs @@ -0,0 +1,111 @@ +using System; +using System.Linq; + +namespace _2023__05__23 +{ + class Program + { + + static void Osszegzes() + { + int[] tomb = {8, 9, 5, 4, 1}; + int n = tomb.Length; + int osszeg = 0; + + for (int i = 0; i < n; i++) + { + osszeg += tomb[i]; + } + System.Console.WriteLine($"Összeg: {osszeg}"); + } + + static void Megszamlalas() + { + int[] t = {9, 7, 3, 5, 4, 2, 6}; + int n = t.Length; + int db = 0; + + for (int i = 0; i < n; i++) + { + if (t[i] < 5) + { + db++; + } + } + + System.Console.WriteLine($"5-nél kisebb számok darabszáma: {db}"); + } + + static void Eldontes() + { + int[] t = {9, 7, 3, 5, 4, 2, 5}; + int n = t.Length; + int ker = 5; + bool van = false; + + for (int i = 0; i < n; i++) + { + if (t[i] == ker) + { + van = true; + break; + } + } + System.Console.WriteLine($"Igaz-e, hogy van 5-ös a tömbben?: {van}"); + } + + static void Feladat1() + { + Random rng = new Random(); + int[] tomb = new int[10]; + bool van = false; + int szam; + + for (int i = 0; i < tomb.Length; i++) + { + szam = tomb[i] = rng.Next(1, 7); + System.Console.WriteLine(szam); + } + + foreach (int i in tomb) + { + if (i == 6) + { + van = true; + break; + } + } + + System.Console.WriteLine($"Van-e 6-os a tömbben?: {van}"); + } + + static void Feladat2() + { + char[] tomb = {'a', 'e', 'i', 'o', 'u'}; + System.Console.WriteLine("Írj be egy angol szó!"); + string szo = Console.ReadLine(); + bool van = false; + + foreach (char i in szo) + { + if (tomb.Contains(i)) + { + System.Console.WriteLine("Van benne magánhangzó"); + van = true; + break; + } + } + + if (van is not true) + { + System.Console.WriteLine("Nincs benne magánhangzó"); + } + } + + static void Main(string[] args) + { + Feladat2(); + } + } + +} diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.deps.json new file mode 100644 index 0000000..3e2a648 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023, 05, 23/1.0.0": { + "runtime": { + "2023, 05, 23.dll": {} + } + } + } + }, + "libraries": { + "2023, 05, 23/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.dll new file mode 100644 index 0000000..a0a908e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.exe new file mode 100644 index 0000000..605374e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.pdb new file mode 100644 index 0000000..75dc520 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/bin/Debug/net7.0/2023, 05, 23.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.dgspec.json new file mode 100644 index 0000000..f80875e --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj", + "projectName": "2023, 05, 23", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/2023, 05, 23.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfo.cs new file mode 100644 index 0000000..44786f0 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023, 05, 23")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023, 05, 23")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023, 05, 23")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfoInputs.cache new file mode 100644 index 0000000..7c98f1a --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e1b5a1dc6588e91d023e8c9f4f69bc065ca843a4 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b7b2e5f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023__05__23 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.assets.cache new file mode 100644 index 0000000..3f8e1b7 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..51d8b51 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +10a0a2c6fca7b408749e8b0507fa161ee6ba46c2 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..8c6dd24 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\bin\Debug\net7.0\2023, 05, 23.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\bin\Debug\net7.0\2023, 05, 23.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\bin\Debug\net7.0\2023, 05, 23.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\bin\Debug\net7.0\2023, 05, 23.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\bin\Debug\net7.0\2023, 05, 23.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\refint\2023, 05, 23.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\2023, 05, 23.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023, 05, 23\obj\Debug\net7.0\ref\2023, 05, 23.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.dll new file mode 100644 index 0000000..a0a908e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.genruntimeconfig.cache new file mode 100644 index 0000000..58a173d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.genruntimeconfig.cache @@ -0,0 +1 @@ +8b86e617051964f8e112e2b679ac0afb3438d38c diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.pdb new file mode 100644 index 0000000..75dc520 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/2023, 05, 23.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..605374e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/ref/2023, 05, 23.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/ref/2023, 05, 23.dll new file mode 100644 index 0000000..4be0089 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/ref/2023, 05, 23.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/refint/2023, 05, 23.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/refint/2023, 05, 23.dll new file mode 100644 index 0000000..4be0089 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/Debug/net7.0/refint/2023, 05, 23.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.assets.json new file mode 100644 index 0000000..b72310e --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj", + "projectName": "2023, 05, 23", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.nuget.cache new file mode 100644 index 0000000..a802972 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 23/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "N79sXGuV+htAO0oK415ilnqztj54x8VO/ghL1cTLyGGICFGeOI3lQ2uDQ1LJWHgk12cbhT2JSm5HpsVbxEwyZw==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023, 05, 23\\2023, 05, 23.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/2023. 05. 30.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/2023. 05. 30.csproj new file mode 100644 index 0000000..b1e3fe1 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/2023. 05. 30.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._05._30 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/Program.cs new file mode 100644 index 0000000..ae0cf83 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/Program.cs @@ -0,0 +1,73 @@ +using System; +using System.IO; +using System.Linq; + +namespace _2023._05._30 +{ + class Program + { + static void Gyakorlas1() + { + int index = 0; + int[] tomb = {100, 2, 3, 4}; + int max = tomb[0]; + + for(int i = 1; i < tomb.Length; i++) + { + if(tomb[i] < max) + { + max = tomb[i]; + index = i; + } + } + System.Console.WriteLine($"Legnagyobb érték: {max}"); + System.Console.WriteLine($"Legnagyobb érték indexe: {index}"); + } + + static void Gyakorlas2() + { + int[] tomb = {1, 5, 4, 9, 30, 20, 43, 1}; + int ker = 1; + + for(int i = 0; i < tomb.Length; i++) + { + if(tomb[i] == ker) + { + System.Console.WriteLine($"A keresett elem indexe: {i}"); + break; + } + } + } + + static void Feladat1() + { + string path = @"E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\Források\szavak.txt"; + + StreamReader r = new StreamReader(path); + string szo = r.ReadLine(); + string leghosszabb = szo; + string legrovidebb = szo; + + while(szo != null) + { + if(szo.Length > leghosszabb.Length) + { + leghosszabb = szo; + } + + if(szo.Length < legrovidebb.Length) + { + legrovidebb = szo; + } + szo = r.ReadLine(); + } + System.Console.WriteLine($"A legrövidebb szó: {legrovidebb}"); + System.Console.WriteLine($"A leghosszabb szó: {leghosszabb}"); + } + static void Main(string[] args) + { + Gyakorlas2(); + } + } + +} diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.deps.json new file mode 100644 index 0000000..af1e861 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 05. 30/1.0.0": { + "runtime": { + "2023. 05. 30.dll": {} + } + } + } + }, + "libraries": { + "2023. 05. 30/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.dll new file mode 100644 index 0000000..5c7d214 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.exe new file mode 100644 index 0000000..9b3a0a7 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.pdb new file mode 100644 index 0000000..0c10322 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/bin/Debug/net7.0/2023. 05. 30.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.dgspec.json new file mode 100644 index 0000000..14fde8d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj", + "projectName": "2023. 05. 30", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/2023. 05. 30.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfo.cs new file mode 100644 index 0000000..538af6f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 05. 30")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 05. 30")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 05. 30")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfoInputs.cache new file mode 100644 index 0000000..5d60b04 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +21c92e0c5c48d5df2b68e6dc43efe3ec4dcb84ae diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d82a39c --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._05._30 +build_property.ProjectDir = e:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.assets.cache new file mode 100644 index 0000000..0b1f971 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..1afb0da --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +cf92e8e30f0c279f020bbe5c31d22c9bf01dd698 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..b036cf7 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\bin\Debug\net7.0\2023. 05. 30.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\bin\Debug\net7.0\2023. 05. 30.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\bin\Debug\net7.0\2023. 05. 30.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\bin\Debug\net7.0\2023. 05. 30.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\bin\Debug\net7.0\2023. 05. 30.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\refint\2023. 05. 30.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\2023. 05. 30.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 05. 30\obj\Debug\net7.0\ref\2023. 05. 30.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.dll new file mode 100644 index 0000000..5c7d214 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.genruntimeconfig.cache new file mode 100644 index 0000000..a9946dd --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.genruntimeconfig.cache @@ -0,0 +1 @@ +0f1d09c3dc9c963e369d8a1d9cda808a173dec15 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.pdb new file mode 100644 index 0000000..0c10322 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/2023. 05. 30.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..9b3a0a7 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/ref/2023. 05. 30.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/ref/2023. 05. 30.dll new file mode 100644 index 0000000..2a6e296 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/ref/2023. 05. 30.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/refint/2023. 05. 30.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/refint/2023. 05. 30.dll new file mode 100644 index 0000000..2a6e296 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/Debug/net7.0/refint/2023. 05. 30.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.assets.json new file mode 100644 index 0000000..676817f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj", + "projectName": "2023. 05. 30", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.nuget.cache new file mode 100644 index 0000000..be1dfe1 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 05. 30/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "XdutwcKNDXcBc9XV144q4kMMhldCVXOWHQpx4qc/1rfUXKpfWbCtPuBsUkImdfr+wmAJpqDp5tQ3NAAlvID/kA==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 05. 30\\2023. 05. 30.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/2023. 06. 06.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/2023. 06. 06.csproj new file mode 100644 index 0000000..1bdf349 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/2023. 06. 06.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._06._06 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/Program.cs new file mode 100644 index 0000000..a88bd14 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/Program.cs @@ -0,0 +1,80 @@ +namespace _2023._06._06 +{ + class Program + { + static void kivalogatas() + { + int[] a = {9, 7, 3, 5, 4, 2, 6}; + int n = a.Length; + int[] b = new int[n]; + int j = 0; + for(int i = 0; i < n; i++) + { + if (a[i] < 5) + { + b[j] = a[i]; + j++; + } + } + System.Console.WriteLine("Eredeti:"); + for(int i = 0; i < n; i++) + { + System.Console.WriteLine(a[i]); + } + System.Console.WriteLine(); + System.Console.WriteLine("Kiválogatott:"); + for(int i = 0; i < j; i++) + { + System.Console.WriteLine(b[i]); + } + System.Console.WriteLine(); + } + + public static int LinearisKereses(int[] tomb, int elem) + { + int index = -1; + for(int i = 0; i < tomb.Length; i++) + { + if(tomb[i] == elem) + { + index = i; + break; + } + } + return index; + } + + static void lineartomb() + { + var tomb = new int[] {9, 6, 0, 0, 1, 2, 2, 2, 3, 1, 5, 4, 8, 2, 8, 6}; + int poz = LinearisKereses(tomb, 8); + System.Console.WriteLine($"A nyolcas indexe: {poz}"); + } + + static void lineartomb2() + { + int[] T = {101, 7, 8, 11, 255, 321}; + int n = T.Length; + int ker = 101; + int i = 0; + while(i < n && T[i] != ker) + { + i++; + } + if (i < n) + { + System.Console.WriteLine($"Indexe: {i}"); + } + else + { + System.Console.WriteLine("Nincs benne!"); + } + string tomb = string.Join(", ", T); + System.Console.Write(tomb); + } + static void Main(string[] args) + { + lineartomb2(); + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.deps.json new file mode 100644 index 0000000..7ecd4e0 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 06. 06/1.0.0": { + "runtime": { + "2023. 06. 06.dll": {} + } + } + } + }, + "libraries": { + "2023. 06. 06/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.dll new file mode 100644 index 0000000..eafa923 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.exe new file mode 100644 index 0000000..a6ec1c5 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.pdb new file mode 100644 index 0000000..590353e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/bin/Debug/net7.0/2023. 06. 06.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.dgspec.json new file mode 100644 index 0000000..08128dc --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj", + "projectName": "2023. 06. 06", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/2023. 06. 06.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfo.cs new file mode 100644 index 0000000..1037337 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 06. 06")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 06. 06")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 06. 06")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfoInputs.cache new file mode 100644 index 0000000..3510c2d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3d953af476e26dea0903dc3fa15035f358f107a2 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d48df6a --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._06._06 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.assets.cache new file mode 100644 index 0000000..2384f53 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..4b8e19c --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +1f7c7468c232c460d7b3113fd8339f263d51be39 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..bda42e6 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\bin\Debug\net7.0\2023. 06. 06.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\bin\Debug\net7.0\2023. 06. 06.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\bin\Debug\net7.0\2023. 06. 06.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\bin\Debug\net7.0\2023. 06. 06.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\bin\Debug\net7.0\2023. 06. 06.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\refint\2023. 06. 06.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\2023. 06. 06.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 06\obj\Debug\net7.0\ref\2023. 06. 06.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.dll new file mode 100644 index 0000000..eafa923 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.genruntimeconfig.cache new file mode 100644 index 0000000..9847215 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.genruntimeconfig.cache @@ -0,0 +1 @@ +9c23c65420fe1a094e0c407758a1a749fb4d4d0c diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.pdb new file mode 100644 index 0000000..590353e Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/2023. 06. 06.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..a6ec1c5 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/ref/2023. 06. 06.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/ref/2023. 06. 06.dll new file mode 100644 index 0000000..bee2843 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/ref/2023. 06. 06.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/refint/2023. 06. 06.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/refint/2023. 06. 06.dll new file mode 100644 index 0000000..bee2843 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/Debug/net7.0/refint/2023. 06. 06.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.assets.json new file mode 100644 index 0000000..72580d3 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj", + "projectName": "2023. 06. 06", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.nuget.cache new file mode 100644 index 0000000..8977a49 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 06/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "sBlaVIPxjB8r8JVW8oa+tkOqCVM3008hK/icozd3B+dyBmbyAT53NuOi/MV4spvcs/NKJdANH38IxLT0+btLAw==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 06\\2023. 06. 06.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/2023. 06. 13.csproj b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/2023. 06. 13.csproj new file mode 100644 index 0000000..7d1cc6f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/2023. 06. 13.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._06._13 + enable + enable + + + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/Program.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/Program.cs new file mode 100644 index 0000000..18c1b59 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/Program.cs @@ -0,0 +1,74 @@ +using System; + +namespace _2023._06._13 +{ + class Program + { + static void cseresrendezes() + { + int[] t = {22, -5, 4, 33, 9, -3, 7, 15, 0, 20}; + int n = t.Length; + + for (int i = 0; i < n; i++) + { + System.Console.WriteLine(t[i]); + } + System.Console.WriteLine(); + + for (int i = 0; i < n - 1; i++) + { + for (int j = i + 1; j < n; j++) + { + if (t[i] > t[j]) + { + int swap = t[j]; + t[j] = t[i]; + t[i] = swap; + } + } + } + + for (int i = 0; i < n; i++) + { + System.Console.WriteLine(t[i]); + } + System.Console.WriteLine(); + } + + static void buborek() + { + int[] t = {5, 14, 9, -3, 7, 0, -11, 12}; + int n = t.Length; + + for (int i = 0; i < n; i++) + { + System.Console.WriteLine(t[i]); + } + System.Console.WriteLine(); + + for (int i = n - 1; i > 0; i++) + { + for (int j = 1; j < i; j++) + { + if (t[j] > t[j + 1]) + { + int tmp = t[j + 1]; + t[j + 1] = t[j]; + t[j] = tmp; + } + } + } + + for (int i = 0; i < n; i++) + { + System.Console.WriteLine(t[i]); + } + System.Console.WriteLine(); + } + + static void Main(string[] args) + { + buborek(); + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.deps.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.deps.json new file mode 100644 index 0000000..4f2f730 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 06. 13/1.0.0": { + "runtime": { + "2023. 06. 13.dll": {} + } + } + } + }, + "libraries": { + "2023. 06. 13/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.dll new file mode 100644 index 0000000..2afe372 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.exe new file mode 100644 index 0000000..2725145 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.pdb new file mode 100644 index 0000000..9bc0a38 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.runtimeconfig.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/bin/Debug/net7.0/2023. 06. 13.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.dgspec.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d1f47c1 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj": {} + }, + "projects": { + "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj", + "projectName": "2023. 06. 13", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.props b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.props new file mode 100644 index 0000000..8d51ce8 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádi\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.targets b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/2023. 06. 13.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfo.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfo.cs new file mode 100644 index 0000000..906a254 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 06. 13")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 06. 13")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 06. 13")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfoInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfoInputs.cache new file mode 100644 index 0000000..2d0ec39 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +266b826b2ee261de74ea90338a587bd756b2ed8e diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GeneratedMSBuildEditorConfig.editorconfig b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..a2c5b33 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._06._13 +build_property.ProjectDir = E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GlobalUsings.g.cs b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.assets.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.assets.cache new file mode 100644 index 0000000..8484051 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.assets.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.AssemblyReference.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.AssemblyReference.cache differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.CoreCompileInputs.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..64d4b12 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +dc5107f84cd072402bf1c504d1e046e09dbd49f9 diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.FileListAbsolute.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..88e5202 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\bin\Debug\net7.0\2023. 06. 13.exe +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\bin\Debug\net7.0\2023. 06. 13.deps.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\bin\Debug\net7.0\2023. 06. 13.runtimeconfig.json +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\bin\Debug\net7.0\2023. 06. 13.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\bin\Debug\net7.0\2023. 06. 13.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.csproj.AssemblyReference.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.AssemblyInfoInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.AssemblyInfo.cs +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.csproj.CoreCompileInputs.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\refint\2023. 06. 13.dll +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.pdb +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\2023. 06. 13.genruntimeconfig.cache +E:\Suli\11.b\Programozás (Tusjak Brigitta)\C#\repos\Gyakorlás\2023. 06. 13\obj\Debug\net7.0\ref\2023. 06. 13.dll diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.dll new file mode 100644 index 0000000..2afe372 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.genruntimeconfig.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.genruntimeconfig.cache new file mode 100644 index 0000000..a222e5f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.genruntimeconfig.cache @@ -0,0 +1 @@ +8fb9bc227bddb88b4450373df1ddb8df1457646c diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.pdb b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.pdb new file mode 100644 index 0000000..9bc0a38 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/2023. 06. 13.pdb differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/apphost.exe b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..2725145 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/ref/2023. 06. 13.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/ref/2023. 06. 13.dll new file mode 100644 index 0000000..ace1bb2 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/ref/2023. 06. 13.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/refint/2023. 06. 13.dll b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/refint/2023. 06. 13.dll new file mode 100644 index 0000000..ace1bb2 Binary files /dev/null and b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/Debug/net7.0/refint/2023. 06. 13.dll differ diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.assets.json b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.assets.json new file mode 100644 index 0000000..448a26c --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádi\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj", + "projectName": "2023. 06. 13", + "projectPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj", + "packagesPath": "C:\\Users\\Ádi\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádi\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.nuget.cache b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.nuget.cache new file mode 100644 index 0000000..ac543b4 --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Gyakorlás/2023. 06. 13/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "e5kSp+0IpT6cJqz4K+Bw7WkqYJR1fOVLBBsNcPQhdHad3UAef4BMK9sUHF9qYme2oy/TlcxzLw31e9hpkNUNVg==", + "success": true, + "projectFilePath": "E:\\Suli\\11.b\\Programozás (Tusjak Brigitta)\\C#\\repos\\Gyakorlás\\2023. 06. 13\\2023. 06. 13.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Use program main/useprogrammain.txt b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Use program main/useprogrammain.txt new file mode 100644 index 0000000..6351e9f --- /dev/null +++ b/Suli/11.b/Programozás (Tusjak Brigitta)/C#/repos/Use program main/useprogrammain.txt @@ -0,0 +1 @@ +dotnet new console --use-program-main \ No newline at end of file diff --git a/Suli/11.b/Szakmai angol/Discord_bot.pptx b/Suli/11.b/Szakmai angol/Discord_bot.pptx new file mode 100644 index 0000000..540f98c Binary files /dev/null and b/Suli/11.b/Szakmai angol/Discord_bot.pptx differ diff --git a/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/index.html b/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/index.html new file mode 100644 index 0000000..9e4fa95 --- /dev/null +++ b/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/index.html @@ -0,0 +1,26 @@ + + + + + + + Jegyzettömb + + + + +

Jegyzettömb

+
+
+

+
+

+

+ +

+
+
+ +
+ + \ No newline at end of file diff --git a/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/script.js b/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/script.js new file mode 100644 index 0000000..3373097 --- /dev/null +++ b/Suli/11.b/Webprogramozás/tothadam_JavascriptNotes/script.js @@ -0,0 +1,40 @@ +const button = document.getElementById("addbtn") +const notes = document.getElementById("notes") +const msg = document.getElementById("msg") +let idnum = 1 + + +button.addEventListener("click", ()=>{ + let inphead = document.getElementById("inphead") + let inptext = document.getElementById("inptext") + console.log(inphead.value); + if (inphead.value != "" && inptext.value != ""){ + let newnote = document.createElement("div") + newnote.innerHTML = `

${inphead.value}

` + newnote.innerHTML += `

${inptext.value}

` + newnote.classList.add("notescss") + newnote.setAttribute("id", `note-${idnum++}`) + newnote.setAttribute("title", "Kattintásra törölheted a jegyzetedet...") + newnote.style.background = document.getElementById("notecolor").value + notes.appendChild(newnote) + msg.innerHTML = "" + msg.innerHTML = "Üzenet hozzáadva!" + inphead.value = "" + inptext.value = "" + + newnote.onclick = function(){ + // this.parentElement.removeChild(this) + + } + + notes.appendChild(newnote) + + msg.innerHTML = 'Üzenet hozzáadva! + + + Exe + net7.0 + _2023._09._14 + enable + enable + + + diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/Program.cs b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/Program.cs new file mode 100644 index 0000000..dfdd231 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/Program.cs @@ -0,0 +1,9 @@ +namespace _2023._09._14; + +class Program +{ + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.deps.json b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.deps.json new file mode 100644 index 0000000..60fe81c --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 14/1.0.0": { + "runtime": { + "2023. 09. 14.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 14/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.dll b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.dll new file mode 100644 index 0000000..fd0b50f Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.dll differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.exe b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.exe new file mode 100644 index 0000000..d660552 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.exe differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.pdb b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.pdb new file mode 100644 index 0000000..8fe5e56 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.pdb differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.runtimeconfig.json b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/bin/Debug/net7.0/2023. 09. 14.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.dgspec.json b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.dgspec.json new file mode 100644 index 0000000..3998f9e --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj", + "projectName": "2023. 09. 14", + "projectPath": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.props b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.targets b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/2023. 09. 14.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfo.cs b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfo.cs new file mode 100644 index 0000000..7b4f7b8 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 14")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 14")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 14")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfoInputs.cache b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6106ae7 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +72cd6eb4755519ee17f5ed97e0efa1ea6ba8bf94 diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d08575a --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._14 +build_property.ProjectDir = E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GlobalUsings.g.cs b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.assets.cache b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.assets.cache new file mode 100644 index 0000000..13c14a8 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.assets.cache differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.CoreCompileInputs.cache b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..d4a3bd2 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +0569bdf074045bdf87fbec0cb8d01e6deac25e50 diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.FileListAbsolute.txt b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..ffc44a7 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\bin\Debug\net7.0\2023. 09. 14.exe +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\bin\Debug\net7.0\2023. 09. 14.deps.json +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\bin\Debug\net7.0\2023. 09. 14.runtimeconfig.json +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\bin\Debug\net7.0\2023. 09. 14.dll +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\bin\Debug\net7.0\2023. 09. 14.pdb +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.AssemblyInfoInputs.cache +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.AssemblyInfo.cs +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.dll +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\refint\2023. 09. 14.dll +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.pdb +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\2023. 09. 14.genruntimeconfig.cache +E:\Suli\12.b\Modern informatika\C#\repos\2023. 09. 14\obj\Debug\net7.0\ref\2023. 09. 14.dll diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.dll b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.dll new file mode 100644 index 0000000..fd0b50f Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.dll differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.genruntimeconfig.cache b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.genruntimeconfig.cache new file mode 100644 index 0000000..acf18f0 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.genruntimeconfig.cache @@ -0,0 +1 @@ +a90f2edd6f60e90c5e73140369913fdebead6646 diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.pdb b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.pdb new file mode 100644 index 0000000..8fe5e56 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/2023. 09. 14.pdb differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..d660552 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/ref/2023. 09. 14.dll b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/ref/2023. 09. 14.dll new file mode 100644 index 0000000..649e811 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/ref/2023. 09. 14.dll differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/refint/2023. 09. 14.dll b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/refint/2023. 09. 14.dll new file mode 100644 index 0000000..649e811 Binary files /dev/null and b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/Debug/net7.0/refint/2023. 09. 14.dll differ diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.assets.json b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.assets.json new file mode 100644 index 0000000..dcb3929 --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj", + "projectName": "2023. 09. 14", + "projectPath": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.nuget.cache b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.nuget.cache new file mode 100644 index 0000000..9b861fa --- /dev/null +++ b/Suli/12.b/Modern informatika/C#/repos/2023. 09. 14/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "EulRibpfBAwzg91mD3U2zGK33W6jxKTFI4te2Gel26F99gLeJKu/M/LAudz8uasmCt0LInBLNBO5MHN2i00/+g==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Modern informatika\\C#\\repos\\2023. 09. 14\\2023. 09. 14.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Modern informatika/feladat.pdf b/Suli/12.b/Modern informatika/feladat.pdf new file mode 100644 index 0000000..905bd2c Binary files /dev/null and b/Suli/12.b/Modern informatika/feladat.pdf differ diff --git a/Suli/12.b/Modern informatika/projekt_20240530.zip b/Suli/12.b/Modern informatika/projekt_20240530.zip new file mode 100644 index 0000000..fc5d86a Binary files /dev/null and b/Suli/12.b/Modern informatika/projekt_20240530.zip differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 04.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 04.txt new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 18.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 18.txt new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 20.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 20.txt new file mode 100644 index 0000000..4929c3a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 20.txt @@ -0,0 +1,33 @@ +ArrayList olyan objektumok nem általános gyűjteménye, amelyek mérete dinamikusan növekszik. ArrayList használható ismeretlen adatok hozzáadására, ahol nem ismeri az adatok típusát, és méretét. Az ArrayList osztály szerepel a System.Collections névtérben. + +ArrayList létrehozása: +ArrayList arlist = new ArrayList(); +var arlist = new ArrayList(); + +Elemek hozzáadása az ArrayList-hez: elemek hozzáadása ArrayList.Add() + arlist.Add(1) + +Elemek hozzáadása az objektum inicializáló szintaxisa segítségével + +Hozzáférés az egyes elemekhez az indexelő használatával: +arlist[0]; +Elemek frissítése: +arlist[0] = "Steve"; +arlist[0] = 100; + +Az ArrayList Count tulajdonsága visszaadja az ArrayList elemének számát: +for (int i = 0; i < arlist.Count; i++) + Console.WriteLine($"{arlist[i], "} +foreach (var item in arlist) + Console.WriteLine($"{item, "} + +Az Insert() metódussal illesszen be egy új elemet a megadott indexbe egy ArrayList-be: +arlist.Insert(1, "2"); + +Az ArrayList elemek eltávolítása a Remove(), a RemoveAt() vagy a RemoveRange() metódussal: +arlist:Remove(null) //Eltávolítja a null első előfordulását +arlist.RemoveAt(4) //Elem eltávolítása a 4. indexből +arlist.RemoveRange(0, 2) //Két elem eltávolít 1. elemből kezdve (0. index) + +Contains() metódust annak megállapításához, hogy a megadott elem létezik-e az ArrayList-ben vagy sem: +Console.WriteLine(arlist.Contains(300)) \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 25.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 25.txt new file mode 100644 index 0000000..2337db5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 25.txt @@ -0,0 +1,20 @@ +ArrayList tulajdonságai: +Capacity: Megadja, vagy beállítja az ArrayList által tartalmazó elemek számát. +Count: Megadja az ArrayList valójában tartalmazott elemek számát. +Sort(): Rendezi az ArrayList teljes elemeit. +Reverse(): Megfordítja az elemek sorrendjét a teljes ArrayList-ben. +Contains(): Ellenőrzi, hogy az ArrayList tertalmaz-e megadott elemet, vagy sem. +Clear: Eltávolítja az ArrayList összes elemét. +CopyTo: Az összes elemet vagy elemtartományt kompatibilis tömbbe másolja. +GetRange: Az ArrayList megadott indexéből megadott számú elemet ad vissza. + +Split függvény: +A Split függvény sztringkészletek táblázatára oszt fel egy szöveges sztringet. A Split függvény használható a vesszővel elválasztott listák, vagy a dátum részei között perjelekkel + +Szintaxis: +Split(Szöveg, Elválasztó) +Szöveg - Kötelező. A felosztandó szöveg. +Elválasztó - Kötelező. A sztring felosztásához használt elválasztó. Állhat nulla, egy, vagy több karakterből. + +string sor = "alma:körte:barack:szilva" +string[] tomb = sor.Split(":") \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 27.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 09. 27.txt new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 11.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 11.txt new file mode 100644 index 0000000..b1df757 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 11.txt @@ -0,0 +1,20 @@ +Láthatósági szintek + +public: Korlátlan +protected: Adott osztály és leszármazottai +internal: Adott program, adott osztály +protected internal: Adott program, adott osztály és leszármazottai +private: Adott osztály + +A névterek láthatósága mindig public +A típusok (osztályok) láthatósága public vagy internal +Az osztályok tagjainak láthatósága tetszőlegesen megválasztható + A tagok láthatósága alapértelmezésben mindig private + A beágyazott típusok (osztályok) láthatóság szempontjából normál tagoknak minősülnek (láthatóságuk tetszőlegesen megadható, alapértelmezésben private) + A felsorolások elemeinek és az interfészek tagjainak láthatósága mindig public + + +Az absztrakt osztályból konkrét példány nem hozható létre, ezért elssősorban az öröklés kikényszerítésére jó. Egy absztrakt tagok célja (akár az absztrak osztályoké), hogy közös funkcionalitást írjanak elő a leszármazottak számára. + +get: A get kulcsszóval ellátott tulajdonság egy olvasható tulajdonságot jelent. Ezen keresztül lehetőség van elérni az adatot vagy információt egy osztályban, de nem lehet megváltoztatni (csak olvasni). +set: A set kulcsszóval ellátott tulajdonság egy írható tulajdonságot jelent. Ezen keresztül lehetőség van beállítani az adatot vagy információt egy osztályban, így módosítani lehet az értékét. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 16.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 16.txt new file mode 100644 index 0000000..451dfa9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 16.txt @@ -0,0 +1,6 @@ +A példába szereplő objektumok hű társaid maradnak, amíg a Garbage Collector ki nem űzi őket a memőriából. A szemétgyűjtő (angolul Garbage Collector vagy röviden GC) megkísérli eltávolítani a memóriából azokat az objektumokat, amelyeket az alkalmazás már nem használ. + +Konstruktor- és destruktor függvények +Adatok, adatszerkezetek használata esetén gyakori igény, hogy bizonyos kezdeti értékadási műveleteket, kezdőértékállításokat el kell végezni. Osztályok esetén ez a kezdőértékadás nem biztos, hogy olyan egyszerű, mint volt elemi típusok esetén, ezért ebben az esetben egy függvény kapja meg az osztály inicializálásával járó feladatot. Ez a függvény az osztálypéldány (objektum) "születésének" pillanatában automatikusan végrehajtódik, és konstruktoroknak vagy konstruktor függvényeknek nevezzük. + +A konstruktor neve mindig az osztály nevével azonos. Ha ilyet nem definiálunk, a keretrendszer egy paraméter nélküli automatikus konstruktort definiál az osztály számára. A konstruktor egy szabályos függvény, így mint minden függvényből, ebből is több lehet, ha mások a paraméterei. Az osztály referencia típusú változó, egy egy osztálypéldány létrehozásához kötelező a new operátort használni, ami egyúttal a konstruktor függvény meghívását végzi el. Ha a konstruktornak vannak paraméterei, akkor azt a típus-név után a zárójelek között kell megadni. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 18.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 18.txt new file mode 100644 index 0000000..a05d906 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 18.txt @@ -0,0 +1,8 @@ +Statikus konstruktor + +Egy osztály tartalmazhat statikus adat- és függvénymezőket is. Ezen akadálymezők a dinamikusan létrejövő objektum-példányoktól függetlenül jönnek létre. Ezeknek a mezőknek az inicializálását végezheti a statikus konstruktor. Statikus konstruktor elé nem kell hozzáférési módosítót, visszatérési típust írni. Ennek a konstruktornak nem lehet paramétere sem. A statikus konstruktor egy speciális konstruktor, amely csak egyszer fut le, amikor először hozzáférünk egy osztályhoz, vagy példány nélkül hívjuk meg. + + +Statikus osztály + +Definiálhatunk olyan osztályt is, ami maga is statikus. Ilyen osztálynak csak statikus mezői lehetnek. Ilyen mező lehet akár egy statikus konstruktor is! Az ilyen osztályokból nem készíthetünk példányokat, nem származtathatunk belőlük újabb típusokat. A könytári szolgáltatások között talán a leggyakrabban használt osztályunk (System.Console) is statikus. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 25.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 25.txt new file mode 100644 index 0000000..55b4077 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 25.txt @@ -0,0 +1,18 @@ +Függvények kiterjesztései (Extension methods) + +Egy statikus osztály csak statikus tagokkal (adat vagy függvény) rendelkezhet. Ez a programunk számára azt jelenti, hogy ezen adatok, függvények, ha publikusak, bárki számára elérhetők. Ilyen statikus osztályban megengedett az a függvénydefiníciós forma is, mikor az első paramétert megelőzi a this kulcsszó. + +public static típus függvénynév (this típus, név, tov.paraméterek) +{ + +függvénytörzs; + +}; + +Az így definiált függvény meghívhatjuk "hagyományos" módon is, de úgy is, mint az első paraméternek mint objektumnak egy függvényt! + + +A this kulcsszó használatával a függvénykiterjesztésekben az objektum, amelyre alkalmazni szeretnénk a kiterjesztett metódust, paraméterként jut át a metódusnak. Ez a példa egy egyszerű függvénykiterjesztés az int típushoz, amely a szám faktoriálisát számítja ki. + + +A throw kulcsszót hiba vagy kivétel dobása céljából használhatjuk. Amikor egy kivételt dobunk (throw-val), akkor valamilyen előre definiált kivételosztály egy példányát kaphatjuk vissza, vagy saját magunk által definált kivételosztályt. A throw tehát lehetővé teszi számunkra, hogy megállítsuk a program futását és jelezzük, hogy valamilyen probléma vagy kivételes helyzet áll fenn, amely kezelést igényel. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 06.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 06.txt new file mode 100644 index 0000000..d7e3715 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 06.txt @@ -0,0 +1,44 @@ +Privát konstruktor + +Szükség lehet arra is - ha nem is gyakran -, hogy az osztályból ne tudjunk egyetlen példányt sem létrehozni. Privát konstruktort definiálunk, ami semmit sem csinál (de azt jól), de ha formálisan csinál is valamit, nem sok értelme van, hiszen nem tudja senki kívülről meghívni! Ebben az esetben természetesen minden tagja az osztálynak statikus. A privát konstruktorokat gyakran használjuk, hogy meggátoljuk egy osztály példányosítását kívülről, és csak a saját osztályon belül létrehozhassunk példányokat. A következő példában az osztály egy olyan példányát hozzuk létre, amely csak egyetlen példányban hordoz információt az alkalmazás futása során. + +Ebben a példában az AlkalmazasBeall egy privát konstruktorral rendelkezik, amely inicializálja az alkalmazás beállításait, például az alkalmazás nevét és verzióját. Az egyetlen példányt egy statikus mező (pl) és egy statikus metódus (GetPl) segítségével hozzuk létre és adunk vissza. Ezáltal az alkalmazás egyetlen példányban tárolja az alkalmazás beállításait. + + +Saját destruktor + +Ahogy egy osztály definiálásakor szükségünk lehet bizonyos inicalizáló kezdeti lépésekre, úgy az osztály vagy objektum "elmúlásakor" is sok esetben bizonyos lépéseket kell tennünk. Például, ha az osztályunk dinamikusan foglal magának memóriát, akkor azt használat után célszerű felszabadítani. Azt a függvényt, amelyik az osztály megszűnésekor szükséges feladatokat elvégzi, destruktornak, vagy destruktor függvénynek nevezzük. A destruktor meghívása automatikusan történik, és miután az objeuktumot nem használjuk, a keretrendszer automatikusan lefuttatja, és a felszabaduló memóriát visszaadja az operációs rendszernek. Konstruktornak és destruktornak nem lehet visszaadott értéke. A destruktornak mindig publikus osztálymezőnek kell lennie. Ha egy osztályhoz nem definiálunk konstruktort, vagy destruktort, akkor a rendszer automatikusan egy alapértelmezett, paraméter nélküli konstruktort, illetve destruktort definiál hozzá. Ha viszont van saját konstruktorunk, akkor nem 'készül' automatikus. A destruktor automatikus meghívásának a folyamatát szemétgyűjtési algoritmusnak nevezzük (Garbage Collection, GC). Ez az algoritmus nem azonnal, az objektum blokkjának, élettartamának a végén hívja meg a destruktort, hanem akkor, amikor az algoritmus "begyűjti" ezt a szabad memóriaterületet. Ha nem írunk saját destruktor függvényt, akkor is a Garbage Collector minden, az objektum által már nem használt memóriát felszabadít az automatikusan definiált destruktor függvény segítségével. Ez azt jelenti, hgy nincs túlzottan nagy kényszer saját definiálására. A Garbage Collector vakójában az osztály Finaize függvényét hívja meg. + +Példa: + + class osztály + { + ~osztály() + { + .... + //destruktor függványtörzs + } + } + +Ezt generálja: + + protected override void Finalize() + { + try + { + ... + //destruktor függvénytörzs + } + + finally + { + base.Finalize(); + } + } + + +Tulajdonság, property függvény + +A C# nyelv a tulajdonság (property) függvénydefiniálási lehetőségével kínál egyszerű és kényelmes adathozzátérési és módosítási eszközt. Ez egy olyan speciális függvény, amelynek nem jelölhetünk paramétereket, még a zárójeleket sm (), és a függvény törzsében egy get és set blokkot definiálunk. Használata egyszerű értékadásként jelenik meg. Ha a tulajdonság függvényének csak get blokkja van, akkor csak olvasható tulajdonságnak (readonly) nevezzük. Ha a tulajdonság függvényének csak set blokkja van, akkor csak írható tulajdonságnak (writeonly) nevezzük. + +Ebben a példában a Szemely osztály két privát adattagot tartalmaz: nev és kor. Az osztályban két property-t definiálunk, amelyek lehetővé teszik a név és az életkor értékeinek beállítását (set) és lekérdezését (get). A Nev property egyszerűen beállítja és lekérdezi a név értékét, a Kor property egy ellenőrzést tartalmaz az életkorra, hogy ne lehessen negatív értéket beállítani.A Main metódusban példányosítunk egy Szemely objektumot, beállítjuk az értékeket a property-k segítségével, majd kiírjuk az értékeket a konzolra. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 13.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 13.txt new file mode 100644 index 0000000..0403f53 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 13.txt @@ -0,0 +1,8 @@ +Index függvény (indexer) + +Az indexer függvény definiálása valójában a vektorhasználat és a tulajdonság függvány kombinációja. Gyakran előfordul, hogy egy osztálynak olyan adatához szeretnénk hozzáférni, egy indexérték segítségével tudjuk megomdani, hogy melyik is a keresett érték. Az indexer függvény esetében lényeges különbség, hogy van egy index paraméter, amit szögletes zárójelek között kell jelölni, és nincs neve, pontosabban a this kulcsszó a neve, ugyanis az aktuális típust mint vektort indexeli. Mivel az indexer az aktuális típust, a létező példányt indexeli, ezért az indexer függvény nem lehet statikus. Az indexer esetében is, hasonlóan a tulajdonság definíció használatához, nem feltétlen mindkét (get, set) ágat definiálni. Ha csak a get blokk definiált, akkor csak olvasható, ha csak a set blokk definiált, akkor csak írható indexer függvényről beszélünk. + + +Osztályok függvényparaméterként + +Egy függvény paraméterei más egyszerű adattípushoz hasonlóan lehetnek osztálytípusok is. Alapértelmezés szerint az osztálytípusú változó is érték szerint adódik át. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 27.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 27.txt new file mode 100644 index 0000000..2be3df2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 11. 27.txt @@ -0,0 +1,47 @@ +Osztályok öröklődése + +Az öröklődés az objektumorientált programozás elsődleges jellemzője. Egy osztályt származtathatunk egy ősosztálybók, és ekkor az utódosztály az ősosztály tulajdonságait (függvények...) is sajátjának tudhatja. Az örökölt függvények közül a változtatásra szorulókat újradefiniálhatjuk. Öröklés esetén az osztály definiációjának formája a következő: + +class utódnév: ősnév +{ +... +} + +Minden mező automatikusan, mintha publikus öröklés lenne, megtartja osztálybeli jelentését. Ekkor az ősosztály publikus mezői az utódosztályban is publikus mezők, és a protected mezők az utódosztályban is protected mezők lesznek. Az ősosztály privát mezői az utódosztályban is privát mezők maradnak az ősosztályra nézve is, így az ősosztály privát mezői közvetlenül az utódosztályból sem érhetők el. AZ elérésük például publikus, ún. "közvetítő" függvény segítségével valósítható meg. Egy őstípusú referencia bármely utódtípusra hivatkozhat. + +Az elérési módok gyakorlati jelentését nézzük meg egy sematikus példán keresztül: + +class ős +{ +private int i; +protected int j; +public int k; +public void f (int j) +{ + i=j +} +} + +class utód: ős +{ +... +} + +Ekkor az utódosztálynak "helyből" lesz egy protected mezője, egy j egész változó, és lesz két publikus mezője, a k egész változó és az f függvény. Természetesen az utódosztálynak lesz egy i egészmezője is, csak az közvetlenül nem lesz elérhető. + +A C# nyelvben nincs lehetőségünk többszörös öröklés segítségével egyszerre több ősosztályból egy utódosztályt származtatni. Helyette viszont tetszőleges számú interface-t implementálhat minden osztály. + +class utód: ős, interface1, ... { +... +} + +Konstruktorok és destruktorok használata öröklés esetén is megengedett. Egy típus definiálásakor a konstruktor függvény kerül meghívásra, és ekkor először az ősosztály konstruktora, majd utána az utódosztály konstruktora kerül meghívásra, míg destruktor esetén fordítva, először az utódosztály, majd az ősosztály destruktorát hÍvja meg a rendszer. Természetesen a destruktor hívására az igaz, hogy a keretrendszer hívja meg valamikor azután, hogy az obbjektumok élettartama megszűnik. + +Paraméteres konstruktorok esetén az utódkonstruktor alakja: + +utód (paraméterek): base (paraméterek) +{ + ... +} + +Többszíntű öröklés esetén először az őskonstruktorok kerülnek a definíció sorrendjében végrehajtásra, majd az utódbeli tagosztályok konstruktorai és legvégül az utódkonstruktor következik. A destruktorok hívásának sorrendje a konstruktorsorrendhez képest fordított. Ha nincs az utódban direkt őshívás, akkor a rendszer a paraméter nélküli őskonstruktorát hívja meg. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 12. 04.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 12. 04.txt new file mode 100644 index 0000000..6bd8238 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 12. 04.txt @@ -0,0 +1 @@ +A virtual kulcsszó azt jelzi, hogy egy adott metódust felül lehet definiálni (override) a leszármazott osztályokban. Ez az az elv, amely az osztályok öröklődésének és a polimorfizmusnak a lényegét alkotja. Amikor a virtual kulcsszóval jelöljük meg a metódust a szülőosztályban, akkor azt jelentjük, hogy a leszármazott osztályokban ez a metódus felüldefiniálható, vagyis az ottani metódusimplementáció lesz meghívva, nem pedig a szülőosztályé. A virtual kulcsszó lehetővé teszi a leszármazott osztályok számára, hogy felülírják (override) a metódust, és sajátos viselkedést adjanak hozzá. A virtual metódust a szülőosztályban az alapértelmezett viselkedés implementálására használjuk, míg a leszármazott osztályokban (amelyek az adott metódust az override-olják) a specifikus viselkedést lehet megvalósítani. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 14.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 14.txt new file mode 100644 index 0000000..26ab574 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 14.txt @@ -0,0 +1,28 @@ +Ismerkedés az általános vezérlőkkel +A vezérlők a tulajdonságaik segítségével változtathatjuk meg, tehetjük egyedivé. + + + +Az űrlap +A vizuális alkalmazások a felhasználóval a kapcsolatot az ablakokban elhelyezett vezérlők segítik. A futásidőben megjelenő ablaknak a tervezési időben a Form (Űrlap) felel meg. Amikor egy projektet létrehozunk, ahhoz alapértelmezetten létrejön egy üres Form is. Ez az üres ablak tartalmaz előre megírt tulajdonságokat és eseményeket. + +Vezérlőgombok, ikonok, szegély +Az ablak kisméretűvé és nagyméretűvé állítást a MinimizeBox és MaximizeBox tulajdonságok False-ra állításával tilthatjuk le. Az ablak futás közbeni legynagyobb és legkisebb mérete a MaximumSize és a MinimumSize értékekkel adhatjuk meg. + +A FormBoderStyle tulajdonság előre beállított értékekkel rendelkezik: + Sizeable: Alapértelmezett érték. Az alapértelmezett szegély méretet adja, és a címsor megjelenik. Az ablak futás közben mréetezhető. + FixedSingle: Vékony szegély, és a címsor megjelenik. Az ablak futás közben nem méretezhető át. + None: Nincs szegély, a címsor sem jelenik meg. Az ablak futás közben nem méretezhető át. + + + +Háttérszín és háttérkép +A háttérszín a BackColor tulajdonssággal állíthatjuk be. Itt 3 fülön választhatunk színeket. Form háttérként képet is be tudunk állítani. Ha ezt szeretnénk, akkor a BackgroundImage tulajdonség beállításánál importálnunk kell a képet. A kép elhelyezésében a BackgroundImageLayout tulajdonság segít. + Tile: A képet a Form méretéhez igazítja. Ha az ablak méretét is változtatjuk, akkor a képet ismétli. + Center: A kéept a Form közepére helyezi. Ha az ablak méretét futás közben változtatjuk, akkor a képet mindig az ablak közepére helyezi, a kimaradó rész kitöltetlen marad. + Stretch: A képet mindig a Form méretéhez igazítja. + + + +Események +A Formhoz is számos esemény tartozik, melyek közül néhány eseményt tartalmaz a következő táblázat. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 19.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 19.txt new file mode 100644 index 0000000..d17109b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 19.txt @@ -0,0 +1,49 @@ +Load: Az esemény akkor aktivizálódik, amikor az űrlap betöltődik. +Click: Az esemény akkor aktivizálódik, amikor az egérgombot megnyomjuk, vagy az Enter billentyűt lenyomjuk. +MouseEnter: Az esemény akkor aktivizálódik, amikor az egeret behúzzuk a Form területére. +MouseLeave: Az esemény akkor aktivizálódik, amikor az egér elhagyja a Form területét. +MouseHover: Az esemény akkor aktivizálódik, amikor az egér mozgása megáll a Formon. +MouseMove: Az esemény akkor aktivizálódik, amikor az egér mozog a Formon. Az esemény paramétereként lekérdezhető az egéeként azr pozíciója. +MouseClick: Az esemény akkor aktivizálódik, amikor az egér bal gombját lenyomjuk a Formon. Az esemény paraméterként lekérdezhető az egér pozíciója. +MouseDown: Az esemény akkor aktivizálódik, amikor az egér egy gombját lenyomjuk a Formon. Az esemény egyik paramétereként az is lekérdezhető, hogy az egér melyik gombját nyomták le, illetve, hogy mi volt az egér pozíciója. +MouseUp: Az esemény akkor aktivizálódik, amikor az egér egy gombját felengedjük a Formon. Az esemény egyik paramétereként az is lekérdezhető, hogy az egér melyik gombját engedték fel, illetve, hogy mi volt az egér pozíciója. + + + +A nyomógomb (Button) + +A tulajdonságai és eseményei között rengeteg közös van a Form-mal. + +Text: A nyomógomb felirata. (Szöveg) +Enabled: A nyomógomb látható, de nem aktív, azaz nem lehet rákattintani. (True/False) +Visible: A nyomógomb nem látható futás közben. (True/False) +TextAlign: A nyomógombona a feliratot vízszintesen és függőlegesen a megadott pozíciókba igazítja. Az alapértelmezett beállítás a vízszintesen és függőlegesen is középre helyezés. (TopLeft, TopCenter,TopRight, MiddleLeft, MiddleCenter, MiddleRight, BottomLeft, BottomCenter, BottomRight) +ForeColor: A felirat színe. Beállítása a BckColorhoz hasonó módon történik. +Font: A felirat betűtípusát, stílusát és méretét lehet meghatározni. A beállítás egyenként is vagy párbeszédpanel segítségével megtehető. +TabIndex: Ha tömb nyomógomb (egyéb vezérlő) van fenn a Form-on, akkor az aktív nyomógombot (vagy vezérlőt) a tabulátor lenyomásával választhatjuk meg. A TabIndex tulajdonság a "bejárási sorrendet" határozza meg. (Egész szám, ami 0-tól indul) +TabStop: Azt határozza meg, hogy a tabulátor lenyomásával az aktivitás erre a nyomógombra kerüljön vagy sem. (True/False) +Image: A nyomógombon megjeleníthetünk egy ikonképet is. A képfájlt kell itt megadni. +ImageAlign: Az ikonkép igazítása a nyomógombon. (Ugyanaz, mint a TextAlign tulajdonságnál.) +TextImageRelation: A kép és a felirat igazítását lehet beállítani a megadott értékekkel. Alapértelmezett az Overlay érték, ami azonos méretet hagy a kép és a szöveg számára a vezérlőn. (Overlay, ImageBeforeText, TextBeforeImage, ImageAboveText, TextAboveImage) + + + +Label (Címke) + +A címke szöveg megjelenítésre használt vezérlő. A Labelben lévő szöveg futás közben csak olvasható, azaz a felhasználó közvetlen nem szerkesztheti. Ezt persze nem jelenti azt, hogy a program futása során a programozó nem módosíthatja a tartalmát. A címkét elsősorban egyéb vezérlők címkézésére szoktuk használni, de alkamnas akár többszörös szöveg megjelenítésére is. A legfontosabb tulajdonsága a Text, amely tervezési időben módosítható, futási időben csak közvetve módosítható. + +AutoSize: True érték esetén a Label mérete automatikusan igazodik a benne lévő szöveghez. (True/False) +BorderStyle: A szövegmező szegélyét adhatjuk meg. Alapértelmezett a None érték. Ekkor nincs szegélye a Label-nek. (None, FixedSingle, Fixed3D) + + + +TextBox (Szövegmező) + +A TextBox vezérlő a szöveg megjelenítésére és bevitelére is alkalmas. A vezérlő legfontosabb tulajdonsága a Text, amely mind a tervezéskor, mind a futás időben tudunk módosítani. Alapértelmezetten a Text tulajdonság értéke üres. + +Readonly: True érték esetén a felhasználó futás időben nem tudja a szöveget módosítani. (True/False) +MaxLength: A szövegmezőbe írható karakterek maximális száma. +CharacterCasing: Meghatározza, hogy a szövegmezőbe beírt karakterek hogyan jelenjenek meg (csupa kisbetűs, vagy nagybetűs). A Normal érték az alapértelmezett. Ekkor leeht kis- és nagybetűs is a beírás. (Normal, Upper, Lower) +PasswordChar: Beíráskor az itt megadott karakterek jelennek meg a beírt karakterek helyett. Jelszó megadásakor használjuk. +UseSystemPassWordChar: A beíráskor a rendszer által aalapértelmezetten használt jelszó karakter jelenik meg a beírt karakterek helyett. +MultiLine: A szövegmező többsoros vagy egysoros megjelenítését állíthatjuk be. (Ha csak ezt a tulajdonságot állitjuk be, híába növeljük a TextBox magasságát, a szöveget egy sorban írjuk tovább.) (True/False) \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 21.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 21.txt new file mode 100644 index 0000000..4d6b224 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 21.txt @@ -0,0 +1,22 @@ +ScrollBars: Ezzel a beállítással megadhatjuk, hogy melyik görgetősáv jelenjen meg a TextBoxnál. Alapértelmezett a None. A megjelenítéseknek akkor van értelme, ha a MultiLine tulajdonság True. (None, Horizontal, Vertical) +TextAlign: A textboxban megjelenő szöveg elhelyezését adja. + + + +Események + +A Button, Label, TextBox vezérlőhöz tartozó események hasonlóak a Form-hoz. + +KeyDown: Az esemény akkor aktivizálódik, ha egy billentyűt lenyomunk. A lenyomott billentyűt le tudjuk kérdezni. A KeyDown érzékeli a nem nyomtatható karakterek lenyomását is (Tab, Alt, Shift stb...). +KeyPress: Az esemény akkor aktivizálódik, ha egy billentyűt lenyomunk. A lenyomott bíllentyűt le tudjuk kérdezni. Nem érzékeli a nem nyomtatható karaktereket. +KeyUp: Az esemény akkor aktivizálódik, ha a lenyomott billentyűt felengedjük. A lenyomott billentyűt le tudjuk kérdezni. Érzékeli a nem nyomhatható karakterek lenyomását is (Tab, Alt, Shift stb...). +TextChanged: Az esemény akkor aktivizálódik, amikor a vezérlőben a szöveget megváltoztatjuk. + + + +Üzenetdoboz (MessageBox) + +A MessageBox üzenetdoboz nem vezérlő, de rendkívüli hasznos eszköz, mely segítségével egszerű üzeneteket, vagy figyelmeztetéseket írhatunk ki a felhasználókat. +Egyszerű kiírás: MessageBox.Show("Üzenet a képernyőn!") +A MessageBox-ot használhatjuk egy nyomógomb eseménykezelőjéhez kötve is. +Az első paraméter az üzenetdobozban megjelenő szöveg. A második paraméter az üzenetdoboz címsorában megjelenő szöveg. A harmadik paraméter az üzenetablak alján megjeleő nyomógomb(ok) (előre beállított értékek. A negydedik paraméter az üzenetdobozban megjelenő ikon típusa (előre beállított érték). \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 26.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 26.txt new file mode 100644 index 0000000..8ad162f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 02. 26.txt @@ -0,0 +1,35 @@ +Választógomb (RadioButton) + +A RadioButton vezérlőt akkor használjuk, ha lehetséges esetek közül csak egyet választhatunk ki. Minden RadioButton vezérlőnek 2 állapota lehet: vagy be van jelölve, vagy nincs. A fejlesztőkörnyezet pedig azrt is kezeli, hogy ha több RadioButton vezérlőt teszünk ki az űrlapra, akkor azok közül csak egyet tudjunk kijelölni. + +Checked: Ez a tulajdonság tárolja, hogy a RadioButton-t bejelölték vagy sem. (True/False) +Appearance: A RadioButton megjelenése a hagyományos forma vagy az ún. beragadó gomb. (Normal/Button) +FlatStyle: Ezzel a tulajdonsággal módosíthatjuk, hogy a RadioButton hogyan viselkedjen, ha az egeret a vezérlő fölé visszük. (Flat, Popup, Standard, System) +CheckAlign: A váalsztógomb helyét lehet megadni. AZ alapértelmezett a MiddleLeft. (Szoki) +Appearance: A RadioButton feliratának megjelenését szabályozza. Akkor érdemes használni, ha az AutoSize tulajdonság ki van kapcsolva. Ilyenkor, ha a felirat nem fér el a megadott szélességen, akkor True érték esetén ,,.." jelöléssel jelzi ezt. (True/False) + + + +Jelölőnégyzet (CheckBox) + +A jelölőnégyzet szintén használhatjuk választási lehetőségek felsorolására és annak kiválasztása. Ez viszont különbözik a RadioButton-tól abban, hogy itt a lehetőséges esetek közül akár többet is jelölhetünk, nemcsak egyet. A jelölőnégyzetnek két vagy három állapota lehet. A két alapállapoton kívül (kiválasztva, nincs kiválasztva) létezik egy harmadik állapota is, közömbös (Inderdeterminate). Ha a jelölőnégyzetet kétállapotúként szeretnénk használni, akkor a RadioButton-hoz hasonlóan a Checked tulajdonságával tudjuk megállapítani, hogy a jelölőnégyzetet bejelölték-e. Ha a jelölőnégyzet harmadik állapotát is szeretnénk használni, akkor a ThreeState tulajdonságot True-ra kell állítani. Ezek után a CheckState tulajdonságnál tudjuk az állapotot beállítani. + +Checked: Ez a tulajdonság tárolja, hogy a kétállapotú jeölőnégyzetet bejelölték, vagy sem. (True/False) +ThreeState: A jelölőnégyzet három- vagy kétállapotú legyen. Alapértelmezett a kétállapotú (False). +CheckState: A háromállapotú jelölőnégyzet állapotainak megkülönböztetésére használt tulajdonság. (Unchecked, Checked, Inderdeterminate) + +A CheckBox vezérlő legtöbb tulajdonsága a RadioButton-éval megegyezik. Mindkét vezérlő esetén az alapértelmezett és legfontosabb esemény a CheckChanged. Ez az esemény akkor aktivizálódik, amikor az adott RadioButton vagy CheckBox állapotát megváltoztatjuk. + + + +Csoportmező (GroupBox), panel (Panel) + +Ha az űrlapon akarunk bizonyos objektumokat csoportosítani vagy egységbe foglalni, akkor erre az ún. konténereket használjuk. A konténerekkel megjelenésükben és még működésükben is egységesíthetük a bennük lévő objektumokat. Két ilyen vezérlő a groupBox és a Panel. Ezeknek a konténereknek a segítségével csoportosíthatjuk például a választógombokat és a jelölőnégyzeteket. A választógomboknál nagyon hasznos a konténer. Ha például kétféle dologgal kapcsolatosan kínálunk választási lehetőséget. +A csoportmező és a panel leginkább megjelenésében különbözik egymástól. A csoportmezőnek alapértelmezetten van felirata és szegélye. A panelnek nincs felirata és szegélye sincs, bár ez beállítható. A panelnél van lehetőség a görgetősáv használatára, míg a csoportmezőnél nincs. + +Tulajdonság GroupBox Panel +Text Van Nincs +BorderStyle Nincs Alapértelmezetten None az értéke (nincs keret). + De alapértelmezetten + van szegély +AutoScroll Nincs Van \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 11.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 11.txt new file mode 100644 index 0000000..a66cec5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 11.txt @@ -0,0 +1,3 @@ +Dátum, idő és az időzítő + +A dátum és az idő tárolására és kezelésére a C# nyelv külön típusokat hozott létre. Ezekkel az idő egy adott pontját vagy egy időszeletet tudjuk ábrázolni illetve tárolni. Ezenfelül van egy időzítőnk is, amivel pedig adott időközönként tetszőleges eseménykezelőt tudunk lefuttatni. Az eltelt idő tárolására a TimeSpan struktúrát használjuk. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 18.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 18.txt new file mode 100644 index 0000000..36abc1d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 18.txt @@ -0,0 +1,16 @@ +A görgetősáv vezérlő + + +A görgetősáv (ScrollBar) vezérlőt általában az ablak jobb oldalán találjuk meg. + +A görgetősávon lévő görgetőnégyzet által kijelölt hely egy egész számot ad vissza, amit a Value tulajdonság tárol. A C# nyelvben két görgetősáv vezérlő van. A ScrollBar a vízszintes görgetősáv, a VScrollBar pedig a függőleges görgetősáv. A görgetősávok alapeseménye a Scroll esemény, amely a görgetősáv értékének módosításakor aktivizálódik. Ezek legfontosabb tulajdonságait foglalja össze a következő táblázat: + +Value: Ez a tulajdonság tárolja a görgetőnégyzet által a sávon kijelölt hely értékét. (Egész szám) +Minimum: A görgetősáv szélső pozíciójához tartozó legkisebb érték. (Egész szám) +Maximum: A görgetősáv szélső pozíciójához tartozó legnagyobb érték. (Egész szám) +SmallChange: Ha a görgetősáv végén lévő nyilakra kattintunk, ezzel az értékkel fog növekedni vagy csökkenni a Value értéke. (Egész szám) +LargeChange: Ha a görgetősávon a görgetőnégyzet elé vagy mögé kattintunk, akkor a megadott értékkel növekszik vagy csökken a Value értéke. (Egész szám) + + +Készítsünk egy programot, amellyel a három alapszínből kikeverjük a többi színt! Az egyes színek értékét göregtősávval fogjuk beállítani (3 címke, 3 vízszintes görgetősáv, 3 szövegmező és egy panel) +-Görgetősávok Maximum értéke 255, Minimum 0 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 20.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 20.txt new file mode 100644 index 0000000..8025c6d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 03. 20.txt @@ -0,0 +1,26 @@ +Képdoboz (PictureBox) vezérlő +A képdoboz vezérlő segítségével képeket jeleníthetünk meg az űrlapon. A képdobozba kerülő képet a tervezés során hozzáadhatjuk, vagy akár futás közben is hozzárendelhetjük. Ha a tervezési időben rendeljük hozzá a képet a dobozhoz, akkor kétféleképpen járhatunk el. Előszörn is kattintsunk az image tulajdonság melleti ikonra. A megjelenő párbeszédablakban két választási lehetőségünk van. Az első a lokális forrás (Local resource). Ebben az esetben a kép csak az adott űrlapről vagy vezérlőről lesz elérhető. Második lehetőség a projekt forrás (Project resource). Ekkor a kép a projekthez tartoző összes vezérlőről és űrlapról elérhető lesz. Ebben az esetben a kép a program könyvtárának Resource mappájába is bemásolódik. + +Image: A képdobozban megjelenítendő kép. +InitialImage: A képdobozban megjelenő alapértelmezett kép. Ez akkor jelenik meg, ha egy másik kép töltődik be. +ImageLocation: A kép elérési útját lehet lekérdezni vagy beállítani. Ez lehet akár URL is. (String) +ErrorImage: Az itt megadott kép jelenik meg, ha az Image-ben megadott képet nem lehet megjeleníteni. + +A SizeMode tulajdonságnál lévő beállításoktól függ, hogy a kép milyen formában jelenik meg a képdobozban. + +Normal: A kép a képdoboz bal felső sarkához lesz igazítva. A kép levágásra kerül, ha a mérete nagyobb, mint a képdoboz. +CenterImage: A kép a képdoboz közepén jelenik meg. A kép szélei levágásra kerülnek, ha a mérete nagyobb, mint a képdoboz. +AutoSize: A képdoboz mérete automatikusan felveszi a kép méreteit. + + +A lista és a lenyíló lista vezérlők +A lista (ListBox) és a lenyíló lista (ComboBox) vezérlő segítségével kiválasztható elemek listáját kezelhetjük. A listából lehetőségünk van egy vagy több elemet kiválasztani. A vezérlők kezelése nagyon rugalmas. Tervezés és a pogram futása közben is rengeteg lehetőségünk van a listák kezelésére. + + +Lista (ListBox) +A lista vezérlő alkalmas arra, hogy több elemet váalsszunk ki az elemek közül. A listában lévő elemeket egy vagy több oszlopba is megjeleníthetjük. A listához hozzáadhatunk elemeket, és törölhetünk is. A lista elemei a listában a felhasználó számára nem szerkeszthetőek, azt csak további vezérlőkkel tudjuk megoldani. + +Items: A lista elemeit tartalmazza. Akár tervezési, akár futási időben módosítható. Az elemek String tipusúak. +Sorted: A listában lévő elemek alfabetikus sorrendjét állítja be a True érték esetén. (True/False) +MultiColumn: A lista többoszlopos megjelenítésének elrendezése. (True/False) +SelectionMode: Az elemek kiválaszthatóságát. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 04. 08.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 04. 08.txt new file mode 100644 index 0000000..4563a31 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 04. 08.txt @@ -0,0 +1,4 @@ +A lista elemeit a tervezési menüben az Items tulajdonság melletti ... ikonra kattintva tudjuk feltölteni a megjelenő szerkeztőablakban. A listában lévő elemekre futásidőben is tudunk hivatkozni a sorszámuk (index) megadásával. A listában lévő elemek felülről lefelé haladva sorszámozzuk 0-tól kezdve. A lista egy adott elemére a listbox1.Items[szorszám] formában tudunk hivatkozni. A következő metódusok segítik a ListBox kezelését: + +A lenyíló lista (ComboBox) +A lenyíló lista tulajdonképpen egy szövegmező és egy lista keresztezéséből jött létre. Ezért a tulajdonságai és vezérlői is többnyire ettől a két vezérlőtől öröklődnek. A lenyíló listából csak egy elemet lehet kiválasztani és csak egyoszlopos megjelenítés van. Ha a lista elemeinek száma több, mint az egyszerre megjeleníthető sorok száma, akkor a görgetősáv automatikusan megjelenik. Azt, hogy a lenyíló lista milyen stílusú legyen, a DropDownStyle tulajdonság határozza meg. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Feladat.pdf b/Suli/12.b/Programozás (Tusjak Brigitta)/Feladat.pdf new file mode 100644 index 0000000..e768b27 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Feladat.pdf differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/B csoport.pdf b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/B csoport.pdf new file mode 100644 index 0000000..5a8602f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/B csoport.pdf differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Eredmenyek.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Eredmenyek.txt new file mode 100644 index 0000000..18628bc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Eredmenyek.txt @@ -0,0 +1,94 @@ +brahm Richrd;1998;159;f;16-17;00:24:03;00:01:54;00:45:15;00:01:15;00:25:15 +Anheuer Kristf;1994;101;f;elit;00:12:42;00:00:34;00:31:41;00:00:29;00:17:22 +Ardelean Jnos Tibor;1984;102;f;30-34;00:17:01;00:01:04;00:35:19;00:00:48;00:21:25 +Bres Lvia;1967;220;n;45-49;00:27:02;00:02:57;00:44:19;00:01:38;00:23:56 +Bicsk Bence;1995;1;f;elit junior;00:12:46;00:00:37;00:31:35;00:00:27;00:15:42 +Bicsk Flra;1997;219;n;16-17;00:13:11;00:00:48;00:38:43;00:00:29;00:17:56 +Bojtor Szabolcs;1990;103;f;20-24;00:23:49;00:07:52;00:43:25;00:01:19;00:21:29 +Bokor Zoltn;1984;104;f;30-34;00:22:46;00:03:04;00:42:53;00:00:47;00:27:30 +Boronkay Pter;1981;105;f;30-34;00:16:49;00:01:18;00:34:17;00:00:49;00:19:40 +Boros Gbor;1968;107;f;45-49;00:22:43;00:01:21;00:38:06;00:00:57;00:22:55 +Boros Sndor;1966;106;f;45-49;00:17:03;00:02:06;00:34:05;00:00:38;00:19:50 +Borsnyi Dniel;1990;137;f;20-24;00:30:03;00:02:33;00:39:57;00:01:09;00:24:00 +Blecz Zoltn;1970;108;f;40-44;00:21:06;00:03:04;00:40:10;00:01:32;00:26:28 +Brcz Bence;1996;2;f;elit junior;00:15:06;00:00:55;00:31:33;00:00:28;00:18:04 +Bruzsa Katalin;1980;218;n;30-34;00:19:46;00:03:03;00:41:41;00:00:36;00:22:50 +Bujdos Ferenc Smuel;1996;147;f;18-19;00:12:45;00:00:35;00:31:46;00:00:26;00:18:56 +Czigny Andrs;1993;109;f;elit;00:12:43;00:00:32;00:31:42;00:00:23;00:16:37 +Czigny Rbert;1968;168;f;45-49;00:15:23;00:01:24;00:34:04;00:00:37;00:18:13 +Csk Panna;1998;217;n;16-17;00:12:56;00:00:39;00:34:29;00:00:27;00:18:33 +Csermk Istvn;1963;110;f;50-54;00:24:10;00:01:39;00:40:45;00:02:17;00:24:45 +Dvay Mrk;1996;167;f;elit junior;00:12:07;00:00:45;00:32:06;00:00:25;00:16:07 +Dr. Fents Adrienn;1977;215;n;35-39;00:19:06;00:01:52;00:40:49;00:00:49;00:23:33 +Dr. Rkos Alexandra;1986;216;n;25-29;00:24:21;00:01:52;00:44:20;00:01:20;00:23:26 +Dr. Zsigmond Rka;1973;214;n;40-44;00:16:17;00:02:21;00:42:45;00:01:20;00:27:42 +Duds Eszter;1992;213;n;elit;00:12:59;00:00:44;00:34:26;00:00:30;00:18:24 +Erdlyi Dniel;1988;163;f;25-29;00:18:46;00:01:41;00:53:48;00:01:06;00:23:23 +Fejes Zoltn;1976;113;f;35-39;00:26:37;00:01:15;00:37:45;00:01:09;00:22:39 +Fokvri Gbor;1965;123;f;45-49;00:20:47;00:02:14;00:38:42;00:01:13;00:24:38 +Fuchs Dra;1997;212;n;16-17;00:12:50;00:00:47;00:34:26;00:00:30;00:18:23 +Fuchs Renta;1995;60;n;elit junior;00:12:55;00:00:41;00:34:30;00:00:32;00:19:43 +Gergely Andras;1976;211;f;35-39;00:23:44;00:02:28;00:44:00;00:01:37;00:23:09 +Glavaski Milan;1970;115;f;40-44;00:22:43;00:02:50;00:44:53;00:00:37;00:28:28 +Hajd Kristf;1996;165;f;elit junior;00:12:44;00:00:35;00:31:46;00:00:26;00:19:16 +Hargitai Henrietta;1995;59;n;elit junior;00:12:47;00:00:43;00:34:40;00:00:29;00:19:14 +Horvath Tamas;1967;117;f;45-49;00:20:31;00:02:40;00:35:58;00:01:22;00:24:23 +Horvth Zsolt;1966;118;f;45-49;00:18:05;00:01:07;00:34:37;00:00:50;00:22:59 +Ivkovic Ivn;1997;119;f;16-17;00:14:59;00:00:50;00:34:33;00:00:40;00:21:51 +Jakubovics Istvn;1996;155;f;18-19;00:15:15;00:01:25;00:34:13;00:00:51;00:19:09 +Juhsz Attila;1961;120;f;50-54;00:24:56;00:02:19;00:49:16;00:00:42;00:24:50 +Kassai Piroska;1986;210;n;25-29;00:23:31;00:02:23;00:43:20;00:01:17;00:26:01 +Kasza Pter;1982;121;f;30-34;00:24:30;00:02:39;00:44:22;00:02:33;00:31:09 +Katona Norbert;1990;122;f;20-24;00:16:57;00:02:07;00:34:08;00:01:26;00:20:43 +Kirly Andrs;1996;8;f;elit junior;00:14:39;00:01:09;00:34:33;00:00:34;00:18:39 +Koller Kata;1994;164;n;20-24;00:19:19;00:02:40;00:43:43;00:00:44;00:25:53 +Kovcshegyi Bence;1995;10;f;18-19;00:16:17;00:01:14;00:35:50;00:00:34;00:23:12 +Lelk Attila;1962;169;f;50-54;00:18:25;00:02:00;00:35:58;00:00:56;00:21:31 +Lelk Roland;1985;127;f;25-29;00:25:09;00:01:58;00:41:39;00:01:10;00:28:47 +Lendvai Eszter;1981;209;n;30-34;00:18:59;00:02:55;00:42:40;00:00:48;00:31:47 +Liptk Marcell;1992;128;f;20-24;00:20:48;00:03:08;00:41:55;00:02:34;00:26:18 +Macsik Aron;1976;129;f;35-39;00:30:08;00:02:24;00:41:01;00:01:30;00:25:11 +Major Gbor;1981;158;f;30-34;00:16:26;00:01:14;00:32:40;00:00:26;00:18:20 +Maracsk Sndor;1970;131;f;40-44;00:27:20;00:02:05;00:42:39;00:01:08;00:22:08 +Marton Eld;1995;3;f;elit junior;00:12:44;00:00:38;00:31:39;00:00:25;00:17:04 +Marx Tams;1997;132;f;16-17;00:16:18;00:00:45;00:33:58;00:00:30;00:17:10 +Mayer Tams;1975;134;f;35-39;00:27:29;00:01:42;00:38:04;00:01:31;00:24:00 +Meleg Andrs;1996;9;f;18-19;00:16:23;00:00:46;00:33:42;00:00:28;00:18:30 +Mercs Pter;1982;114;f;30-34;00:29:19;00:02:14;00:43:30;00:01:14;00:27:25 +Mester Dra;1995;58;n;elit junior;00:12:55;00:00:48;00:36:02;00:00:31;00:20:36 +Mszros Judit;1986;170;n;25-29;00:22:30;00:01:36;00:39:57;00:00:53;00:25:38 +Mihly Benjmin;1997;204;f;16-17;00:21:31;00:01:24;00:38:25;00:00:38;00:19:30 +Molnr Jlia;1996;57;n;elit junior;00:14:57;00:00:45;00:38:36;00:00:31;00:20:10 +Mricz Vilmos;1977;136;f;35-39;00:20:57;00:02:24;00:36:16;00:01:15;00:21:41 +Nagy Csaba;1984;138;f;30-34;00:30:42;00:02:44;00:39:19;00:02:02;00:29:36 +Nagy Krisztina;1996;56;n;18-19;00:14:16;00:00:46;00:39:18;00:00:34;00:21:19 +Nagy Mt;1996;4;f;18-19;00:12:47;00:00:34;00:31:40;00:00:26;00:17:42 +Nehz Jnos-Michael;1977;139;f;35-39;00:21:21;00:02:02;00:35:21;00:01:07;00:25:40 +Olh Bence;1978;141;f;35-39;00:16:28;00:00:49;00:36:08;00:00:37;00:19:50 +Pk Dorottya;1979;207;n;35-39;00:24:51;00:04:23;00:51:41;00:01:51;00:31:39 +Pter Brn;1998;157;f;16-17;00:14:10;00:00:57;00:34:52;00:00:29;00:17:50 +Petresevics Rbert;1969;142;f;45-49;00:13:44;00:00:54;00:32:50;00:00:34;00:16:10 +Pincsi Balzs;1981;160;f;30-34;00:15:58;00:00:56;00:36:21;00:00:47;00:20:34 +Por Viktor;1981;143;f;30-34;00:25:46;00:03:48;00:44:28;00:01:04;00:25:32 +Princzkel Jozef;1980;144;f;30-34;00:25:29;00:02:34;00:42:23;00:02:38;00:22:18 +Pusztavmi Mrton;1978;145;f;35-39;00:28:07;00:03:06;00:40:48;00:01:59;00:27:52 +Saj Pter;1977;146;f;35-39;00:19:45;00:02:27;00:40:18;00:01:09;00:23:49 +Sndor Judit;1987;206;n;25-29;00:21:52;00:03:52;00:43:31;00:01:09;00:31:15 +Srszegi Nomi;1996;52;n;elit junior;00:13:04;00:00:38;00:34:21;00:00:27;00:19:57 +Syposs Zoltan;1970;149;f;40-44;00:25:58;00:02:04;00:36:40;00:01:21;00:23:29 +Szalay Gbor;1981;150;f;30-34;00:26:01;00:03:21;00:42:18;00:02:19;00:25:35 +Szatmri Botond;1997;151;f;16-17;00:13:26;00:00:50;00:33:00;00:00:36;00:17:23 +Szatmri Levente;1995;5;f;elit junior;00:12:46;00:00:39;00:31:33;00:00:24;00:16:03 +Szuhn Dra;1996;55;n;18-19;00:15:18;00:01:13;00:41:31;00:00:41;00:28:05 +Telek Blint;1981;161;f;30-34;00:24:12;00:01:36;00:44:02;00:00:50;00:25:40 +Tmea Hubai;1982;124;n;30-34;00:16:15;00:01:01;00:37:05;00:00:50;00:21:40 +Tth Mt;1996;6;f;elit junior;00:14:08;00:00:42;00:32:37;00:00:24;00:18:08 +Vajth Lszl;1968;152;f;45-49;00:28:10;00:02:55;00:46:46;00:00:42;00:22:51 +Varga Zsolt;1969;153;f;45-49;00:34:44;00:04:27;00:46:48;00:00:50;00:25:05 +Vaska Klmn;1972;154;f;40-44;00:24:19;00:02:39;00:35:13;00:01:12;00:20:48 +Vass Benedek;1995;7;f;18-19;00:14:55;00:00:49;00:34:44;00:00:39;00:18:07 +Vizi Viktria;1995;54;n;18-19;00:12:57;00:00:39;00:34:26;00:00:29;00:21:11 +Wolfram Christian;1974;156;f;40-44;00:27:27;00:01:42;00:37:57;00:01:47;00:26:55 +Zkny Nagy Patrik;1996;166;f;elit junior;00:12:42;00:00:31;00:31:46;00:00:26;00:16:50 +Zelovics Dra;1996;53;n;elit junior;00:12:55;00:00:45;00:34:26;00:00:32;00:20:41 +Zubornyk Gyrgy;1981;111;f;30-34;00:20:37;00:02:27;00:36:37;00:01:12;00:23:04 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Feladatok.pdf b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Feladatok.pdf new file mode 100644 index 0000000..27cfd06 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Feladatok.pdf differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/London2012.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/London2012.txt new file mode 100644 index 0000000..d0011b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/London2012.txt @@ -0,0 +1,29 @@ +Asztalitenisz;0;0;0;0;1;1;0;0;0;0;1;1;0;0;0;0 +Atlétika;0;0;0;0;0;0;2;5;7;5;4;4;5;6;8;1 +Birkózás;0;0;0;0;0;0;0;0;2;3;2;2;2;2;3;2 +Cselgáncs;2;2;2;2;2;2;2;0;0;0;0;0;0;0;0;0 +Evezés;0;0;0;0;3;3;4;4;0;0;0;0;0;0;0;0 +Gyeplabda;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1;0 +Íjászat;1;1;0;0;0;1;1;0;0;0;0;0;0;0;0;0 +Kajak-kenu;0;0;0;1;1;2;0;0;0;0;0;4;4;0;4;0 +Kerékpár;1;1;0;0;2;2;2;1;1;1;3;0;0;2;1;1 +Kézilabda;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Kosárlabda;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Labdarúgás;0;0;0;0;0;0;0;0;0;0;0;0;1;0;1;0 +Lovaglás;0;0;0;2;0;0;0;0;0;1;1;2;0;0;0;0 +Műugrás;0;1;1;1;1;0;0;0;1;0;1;0;1;0;1;0 +Ökölvívás;0;0;0;0;0;0;0;0;0;0;0;0;3;0;5;5 +Öttusa;0;0;0;0;0;0;0;0;0;0;0;0;0;0;1;1 +Röplabda;0;0;0;0;0;0;0;0;0;0;0;1;1;0;1;1 +Sportlövészet;2;2;1;1;1;1;2;2;1;2;0;0;0;0;0;0 +Súlyemelés;1;2;2;2;2;0;2;1;1;1;1;0;0;0;0;0 +Szinkronúszás;0;0;0;0;0;0;0;0;0;0;1;0;0;1;0;0 +Taekwondo;0;0;0;0;0;0;0;0;0;0;0;2;2;2;2;0 +Tenisz;0;0;0;0;0;0;0;2;3;0;0;0;0;0;0;0 +Tollaslabda;0;0;0;0;0;0;1;2;2;0;0;0;0;0;0;0 +Torna;0;0;1;1;1;1;1;1;3;3;4;0;0;0;1;1 +Triatlon;0;0;0;0;0;0;0;1;0;0;1;0;0;0;0;0 +Úszás;4;4;4;4;4;4;4;4;0;0;0;0;1;1;0;0 +Vitorlázás;0;0;0;0;0;0;0;0;2;2;2;1;1;1;1;0 +Vívás;1;1;1;1;2;1;1;1;1;0;0;0;0;0;0;0 +Vízilabda;0;0;0;0;0;0;0;0;0;0;0;0;1;0;0;1 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/PotloDolgozat/DolgozatPotlas.pdf b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/PotloDolgozat/DolgozatPotlas.pdf new file mode 100644 index 0000000..0e09292 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/PotloDolgozat/DolgozatPotlas.pdf differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Vtabla.dat b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Vtabla.dat new file mode 100644 index 0000000..98e5eec --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/Vtabla.dat @@ -0,0 +1,26 @@ +ABCDEFGHIJKLMNOPQRSTUVWXYZ +BCDEFGHIJKLMNOPQRSTUVWXYZA +CDEFGHIJKLMNOPQRSTUVWXYZAB +DEFGHIJKLMNOPQRSTUVWXYZABC +EFGHIJKLMNOPQRSTUVWXYZABCD +FGHIJKLMNOPQRSTUVWXYZABCDE +GHIJKLMNOPQRSTUVWXYZABCDEF +HIJKLMNOPQRSTUVWXYZABCDEFG +IJKLMNOPQRSTUVWXYZABCDEFGH +JKLMNOPQRSTUVWXYZABCDEFGHI +KLMNOPQRSTUVWXYZABCDEFGHIJ +LMNOPQRSTUVWXYZABCDEFGHIJK +MNOPQRSTUVWXYZABCDEFGHIJKL +NOPQRSTUVWXYZABCDEFGHIJKLM +OPQRSTUVWXYZABCDEFGHIJKLMN +PQRSTUVWXYZABCDEFGHIJKLMNO +QRSTUVWXYZABCDEFGHIJKLMNOP +RSTUVWXYZABCDEFGHIJKLMNOPQ +STUVWXYZABCDEFGHIJKLMNOPQR +TUVWXYZABCDEFGHIJKLMNOPQRS +UVWXYZABCDEFGHIJKLMNOPQRST +VWXYZABCDEFGHIJKLMNOPQRSTU +WXYZABCDEFGHIJKLMNOPQRSTUV +XYZABCDEFGHIJKLMNOPQRSTUVW +YZABCDEFGHIJKLMNOPQRSTUVWX +ZABCDEFGHIJKLMNOPQRSTUVWXY \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/be.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/be.txt new file mode 100644 index 0000000..c3fe88d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/be.txt @@ -0,0 +1,43 @@ +12 +345 +765 +87 +34 +213 +34 +57 +75 +467 +44 +765 +76 +89 +98 +645 +87 +34 +65 +324 +89 +30 +45 +31 +90 +89 +65 +32 +1 +86 +99 +44 +25 +90 +7 +3 +98 +54 +33 +938 +97 +845 +975 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/csapadék.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/csapadék.txt new file mode 100644 index 0000000..28346db --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/csapadék.txt @@ -0,0 +1 @@ +6 1 2 1 6 0 0 0 1 4 1 3 0 0 0 2 3 1 2 2 0 0 0 0 4 10 0 0 3 4 9 3 0 6 2 0 4 2 4 4 5 1 4 5 0 3 7 5 6 4 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/diákok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/diákok.txt new file mode 100644 index 0000000..2842e0b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/diákok.txt @@ -0,0 +1,100 @@ +Verebes Fruzsina 149 54,4 lány +Borsodi Attila 167 51,1 fiú +Major Liza 155 52 lány +Varga Ernő 173 46,5 fiú +Lendvai Vera 165 46,7 lány +Kulcsár Antal 172 55,7 fiú +Petróczi Virág 169 41,3 lány +Pais Károly 155 55,5 fiú +Horváth Adél 157 56,5 lány +Kiss Balázs 163 54,5 fiú +Orosz Ingrid 172 41,9 lány +Pelikán Tamás 172 48,9 fiú +Zalai Elvira 147 57,4 lány +Papp Lilla 169 56 lány +Huszár Dorina 151 48,1 lány +Kiss Krisztián 145 59,3 fiú +Sipos Zsolt 173 57,6 fiú +Pongrácz Karina 175 42,1 lány +Vissi Klaudia 166 59 lány +Gellén Bea 188 47,9 lány +Ferencz Ivett 171 51 lány +Ujj Mihály 188 55,6 fiú +Kovács Gergely 147 42 fiú +Felföldi Judit 145 52,3 lány +Bartal Zsolt 169 49,9 fiú +Simon Erik 171 46,7 fiú +Csiszár Alexandra 170 52,8 lány +Pesti Milán 188 53,3 fiú +Simon Rita 166 46 lány +Somogyi Dezső 177 46,3 fiú +Magyar Magdolna 150 56,8 lány +Gombos Kinga 149 56,7 lány +Egerszegi Kristóf 162 52,2 fiú +Somogyi Tamás 172 59,7 fiú +Varga Anna 188 58,3 lány +Csondor Anikó 159 45,3 lány +Vass Szabolcs 188 54,2 fiú +Szabó Csilla 163 59,6 lány +Pass Flóra 177 45,6 lány +Agg Judit 145 51,1 lány +Gyenese Oszkár 157 43 fiú +Hardi Boglárka 159 60 lány +Kuti Lehel 163 53,8 fiú +Domján Hermina 165 41,3 lány +Tompa Krisztina 172 51,9 lány +Radics Betti 171 42,9 lány +Balla Ibolya 180 43 lány +Csontos Janka 151 56,2 lány +Radics Zsuzsa 159 46,4 lány +Vajda Klára 172 41,9 lány +Simon Marcell 171 46,6 fiú +Salamon Laura 162 48,3 lány +Bakony Ilona 145 46,7 lány +Hantos Bence 147 59 fiú +Kovács Erika 167 59,6 lány +Csiszár Bella 168 48,6 lány +Simon Dorina 169 46,3 lány +Bicsák Hilda 173 44 lány +Varga Rozália 156 44,1 lány +Lengyel Viktor 188 53,3 fiú +Molnár Zsombor 172 48,8 fiú +Hajba Soma 178 48,8 fiú +Bocskor Henrik 154 54,5 fiú +Hajdu Szilvia 157 47,2 lány +Csalló Aliz 159 53 lány +Kelemen Gergő 163 44,9 fiú +Kaczor Jenő 167 44,5 fiú +Bujtor Erzsébet 167 52,1 lány +Gombos Olivér 168 42,5 fiú +Varga Cili 172 49,7 lány +Gulyás Katalin 171 58,2 lány +Vass Vera 155 46 lány +Salamon András 177 55,9 fiú +Elekes Elza 177 48,2 lány +Nagy Melinda 145 46,5 lány +Kovács Vivien 160 58,5 lány +Kaszás Ferenc 149 53 fiú +Balogh Borbála 166 52,9 lány +Horváth Barbara 153 49,1 lány +Dobos Vilma 180 42,9 lány +Nagy Miklós 156 51,7 fiú +Kovács Ambrus 173 54,2 fiú +Paksa Csilla 141 58,4 lány +Bende Natália 145 56,9 lány +Czigány Judit 161 41,4 lány +Simon Edina 167 51,3 lány +Monok Gabriella 168 58,4 lány +Jakab Etelka 169 49,2 lány +Vig Viola 159 53,9 lány +Szegleti Tamás 160 50,5 fiú +Pataki Viktória 149 50,8 lány +Vass Ildikó 171 49,8 lány +Farsang Jakab 168 47,7 fiú +Vajda István 163 48,7 fiú +Marosvári Krisztina 162 46,1 lány +Horváth Kamilla 159 42,1 lány +Koller Tamás 171 45,6 fiú +Kocsis Tamara 170 59,6 lány +Molnár Vera 155 42,2 lány +Hegyi Csaba 152 48,4 fiú \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/forras.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/forras.txt new file mode 100644 index 0000000..9350251 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/forras.txt @@ -0,0 +1,13 @@ +Szent-Gyrgyi Albert +Az egyetlen magyar tuds, aki szlhazjban rdemelte ki a Nobel-djat +Budapesten szletett 1893. szeptember 16-n. Tanulmnyait a Lnyai utcai reformtus gimnziumban vgezte, majd a budapesti tudomnyegyetemen folytatta, ahol 1917-ben orvosi oklevelet szerzett. Az els vilghborban medikusknt vett rszt, de megsebeslt, s hamarosan leszereltk. Ezutn klfldn: Pozsonyban, Prgban, Berlinben, Leidenben, Groningenben folytatott tanulmnyokat, a biolgia, az lettan, a gygyszertan, a bakteriolgia, majd a fizikai-kmia tern. Ezt kveten Cambridge-ben, F.G. Hopkins biokmiai tanszkn megszerezte msodik doktortust, ezttal kmibl, majd E.C. Kendall tmogatsval egy vig az Egyeslt llamokban dolgozott. +Klebelsberg kultuszminiszter hvsra hazajtt, s 1931-tl 1945-ig a szegedi tudomnyegyetem orvosi vegyszeti intzetnek professzora, 1945 s 1947 kztt a budapesti tudomnyegyetem orvos karnak biokmia professzora volt. Az 1920-as vek vgn Szent-Gyrgyi ismeretlen anyagot tallt a mellkvesben. Megllaptotta sszettelt s hexuronsavnak nevezte el (1928). Hazatrve, Szegeden olyan nvnyi forrst keresett, melybl nagyobb mennyisgben lehet kivonni hexuronsavat. Erre a clra a szegedi paradicsompaprika kivlan megfelelt: 10 liter prsnedvbl 6,5 gramm hexuronsavat lltottak el. 1932-ben Szent-Gyrgyi a hexuronsavat azonostotta a C-vitaminnal. Javaslatra a hexuronsavat a skorbut elleni hatsra utalva aszkorbinsavnak neveztk el. Szegeden a paprikbl kiindul C-vitamin gyrts mdszert is kidolgoztk. +Az 1937-es lettani-orvosi Nobel-djat Szent-Gyrgyi Albert nyerte el "a biolgiai gsfolyamatok, klnskppen a C-vitamin s a fumrsavkatalzis szerepnek tern tett felfedezseirt". +1947 vgn elhagyta az orszgot, s a Boston melletti Woods-Hole-ban telepedett le, ahol 1947 s 1962 kztt az Egyeslt llamok Izomkutat Tudomnyos Intzete tengerbiolgiai laboratriumnak igazgatja, 1962 s 1971 kztt a Darthmouth-i Egyetem professzora volt. +Mr Szegeden kezdett foglalkozni az izom mkdsvel, s sikeresen vizsglta az izom fehrjinek szerept az izom-sszehzdsban (1940-42). A szubmolekulris vizsglatok utn rdekldse ksbb a rosszindulat daganatok fel fordult. Kt vtizeden t foglalkozott a sejtszint szablyozs jelensgeivel. +A Magyar Tudomnyos Akadmia levelez (1935), rendes (1938), majd 1945. mjus 30-n tiszteleti tagjnak vlasztotta. Kapcsolatait Magyarorszggal mindig fenntartotta, az 1960-as vektl rendszeresen hazaltogatott. 1986. oktber 22-n halt meg Woods Hall-ban. +1987-ben a Szegedi Orvostudomnyi Egyetem felvette nevt. + + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/neptun.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/neptun.txt new file mode 100644 index 0000000..f535550 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/neptun.txt @@ -0,0 +1,13 @@ +NEPTUNUSZ +Naprendszernk 8. bolygja: - a Naptl legtvolavbb kering risbolyg. Mintegy 165 fldi v alatt kerli meg a Napot, sajt tengelye krl nem egszen 11 s 1/4 ra alatt fordul meg: azaz ezen a bolygn ennyi ideig tart egy teljes nap. tmrje 4-szer, tmege tbb mint 17-szer akkora, mint Fldnk. Ltezst elszr matematikai (gi mechanikai) szmtsok valsznstettk, majd 1846. szeptember 23-n jjel tallta meg s azonostotta bolygknt a berlini kirlyi obszervatriumban Johann Gottfried Galle. +A Neptunusznak a mai kor technikai eszkzeivel kszlt felvtelein lthat lenygz kk szne a lgkr 2%-t alkot metn okozza, amely elnyeli a vrs fnyt. A bolygnak jelenleg 8 holdjt ismerjk. Ezek kzl a legnagyobb mret Tritont mr a bolyg azonostst kvet hetekben felfedeztk. E hold egyik klnlegessge, hogy a tbbi holddal ellenttes irnyban kering a Neptunusz krl. +A Neptunusz holdjainak elnevezse (a bolygtl tvolodva) s sugara: +Naiad (29 km) +Thalassa (40 km) +Despina (74 km) +Galatea (79 km) +Larissa (96 km) +Proteus (209 km) +Triton (1350 km) +Nereid (170 km) +A Neptunuszt eddig csupn a Voyager-2 rszonda ltogatta meg. A "tallkozra" 1989. augusztus 25-n kerlt sor. A Neptunuszhoz kzelebb kering, kisebb mret holdakrl csak felvtelei alapjn szereztnk tudomst. A legkls holdat Kuiper fedezte fel mg 1949-ben. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/petőfi.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/petőfi.txt new file mode 100644 index 0000000..701789d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/petőfi.txt @@ -0,0 +1,66 @@ +Petőfi Sándor + +Születéskori neve Petrovics Sándor +Született Kiskőrös +1823. január 1.? +Elhunyt Segesvár +1849. július 31.? (26 évesen) +Nemzetisége magyar +Házastársa Szendrey Júlia +Gyermekei Petőfi Zoltán +Szülei Petrovics István, Hrúz Mária +Foglalkozása költő +Iskolái Kiskunfélegyháza, Kecskemét, Szabadszállás, Sárszentlőrinc, Pest, Aszód, Selmecbányai Líceum +Fontosabb munkái Petőfi költészete szakasz +A költő szülei. Orlai Petrich Soma festménye +A költő szülei. Orlai Petrich Soma rajza +Franz Kollarž: Petőfi apotheosisa + +Petőfi Sándor (Kiskőrös, 1822. december 31. vagy 1823. január 1. – Segesvár, 1849. július 31.?) magyar költő, forradalmár, nemzeti hős, a magyar költészet egyik legismertebb és legkiemelkedőbb alakja. Közel ezer verset írt rövid élete alatt, ebből kb. nyolcszázötven maradt ránk. + +„Külföldön Petőfi a legismertebb magyar költő mindmáig. Ő az istenek magyar kedvence. Mindent megkapott, hogy nagy költő lehessen: tehetséget, történelmet, sorsot. Huszonhat évet élt, s világirodalmi rangú s méretű életmű maradt utána, mely korfordulót jelentett nemzete irodalmában.” + +Életrajz +Származása, gyermekkora + +Édesapja, Petrovics István (Kartal, 1791. augusztus 15. – Pest, 1849. március 21.) mészárosmester, a közhiedelem szerint szerb, újabb kutatások alapján szlovák családból származott[2], de magyarnak vallotta magát. Apjának szlovák származását valószínűsíti annak evangélikus vallása (a szerbek általában ortodoxok), illetve Kiss József és Jakus Lajos kutatásai, akik apai ágon 1685-ig, a Nyitra vármegyei Vagyócig vezették vissza Petőfi származását. Vagyis a Petrovicsok csakúgy Felvidékről származnak, mint az anyai ág, amely a Turóc vármegyei Necpál községből ered.[3] + +Anyai nagyapja, Hrúz Mihály, tehetős redemptus, aki Kecskemét város tekintélyes polgára volt.[4] Édesanyja, Hrúz Mária (Necpál, 1791. augusztus 26. – Pest, 1849. május 17.) férjhezmenetele előtt mosónőként és cselédként dolgozott a maglódi evangélikus lelkésznél, Martiny Mihálynál. Szlovák anyanyelvű volt, a magyar nyelv használatára csak asszonykorában tért át.[5] +Petőfi szülőháza Kiskőrösön + +Petrovics István és Hrúz Mária valószínűleg Maglódon ismerkedtek meg, ám 1818. szeptember 15-én Aszódon kötöttek házasságot, Mikulás Dániel evangélikus lelkész eskette őket, nejével mindketten az evangélikus vallást gyakorolták. Petrovics ekkor szabadszállási székbérlő volt, majd 1821-ben Kiskőrösre költöztek. 1822-24-re a családfő kibérelte a kiskőrösi mészárszéket és ott lakott nejével együtt, így született ott meg ötödfél évi házasságuk után első gyermekük, Sándor. + +Petőfi Sándor az 1822. december 31-éről 1823. január 1-jére virradó éjszakán született Kiskőrösön, ahol január 1-jén keresztelték meg az evangélikus vallás szerint.[6] A gyermek születésekor oly gyengécske volt, hogy egy emlékező szerint „spirituszban fürdették, hogy megmaradjon”. Egyetlen öccse, Petőfi István 1825-ben született. + +Apjának a kiskőrösi bérlet elég jól jövedelmezett. A 3 évi ciklus leteltével, 1824. október 14-én a nagyobb kiskunfélegyházi székbérletre vállalkozott és ez év októberében családjával együtt oda is költözött. A család jóléte itt még inkább föllendült és Petőfi vidám és boldog gyermekséget élt, melynek emlékei később is mindig édes érzéssel töltötték el szívét. Petőfi e várost Szülőföldemen (1848) című költeményében születése helyének nevezte, e szavai később sok vitára adtak okot a két település, Kiskőrös és Kiskunfélegyháza, illetve a költő életrajzának kutatói között is. A család először meglehetősen jó anyagi körülmények között élt. Petrovics István ügyes vállalkozó volt, a mészárszék mellett kocsmát bérelt és működtetett. A család anyagi felemelkedésének helyszíne egy ideig Kiskunfélegyháza volt. A családfő fenntartott két mészárszéket Kiskunfélegyházán, illetve Szabadszálláson, több ingatlan tulajdonosa volt, saját földjeiken és bérelt földeken is gazdálkodott. +Tanulóévei +Az újszülött Alexander Petrovics keresztelési bejegyzése a Kiskőrösi Evangélikus Egyházközség keresztelési anyakönyvében (IV. kötet /1814–1838/, 127. oldal) + +Petőfi eleven, elmés, kissé makacs, de jószívű gyermek volt. Kemény apja szigorúsággal, anyja gyöngédségével vezette. Édesapja lehetőségeihez mérten megpróbálta a legjobb iskoláztatást biztosítani gyermekeinek. Az ifjú Petőfi összesen kilenc iskolában tanult, már ötévesen koptatta az iskolapadot. Félegyházán ment először iskolába, itt azonban inkább csak vendégként járt be a római katolikus elemi iskolába egy ideig 1828 elején, mivel már ezt megelőzően oktatták olvasásra[7] és rajzra, a rajzhoz később is kedvet mutatott. Ezután három évig Kecskeméten tanult, 1828. május 10-én vitte apja az evangélikus népiskolába, itt iratta be 1829. május 10-én, illetve 1830. május 15-én. Az intézményben már némi latint is tanult. Szálláson Habel Józsefnél volt, aki akkor az öreg Petrovics félegyházi és kecskeméti mészárszékeinek haszonbérlő-társa volt. Vakációzni haza, vagy kiskőrösi rokonaihoz járt. + +1830-ban szülei Félegyházáról 6 évi ott lakás után Szabadszállásra költöztek vissza, ahol félegyházi keresményükből meglehetősen szép vagyont, házat és földet szereztek. A harmadik iskolai évet nem is fejezte be Petőfi Kecskeméten, atyja 1831 elején haza vitte Szabadszállásra, ahol akkor Ujlaky István református rektor algimnáziumra készítette fel a fiúkat. + +1831. szeptember 28-án atyja a dunántúli Sárszentlőrincre küldte fiát az evangélikus algimnáziumba, ott két évet töltött mint donatista tanuló. Tanára, Lehr András főleg a latin nyelvet és szépírást tanította nagy kedvvel, és Petőfi mindkettőben kitűnt. Szerette ezt az iskolát, és boldog gyermekkora volt: szülei gondosan ellátták, szálláson a község legjobb családjainál volt, és bár már ekkor szeretett érzelmeibe merülni, szívesen részt vett diáktársainak, főleg a kissé nagyobbaknak játékaiban is. A második évben Németh Ferenc néptanítónál lakott. + +1833-ban a német nyelv tanulása céljából Pestre vitte apja, és augusztus 27-én beiratta az evangélikus német gimnáziumba, ahol a II. donatista osztályba járt. Egy Petrovics nevű lovashajdú rokonánál lakott. Ekkor már nem volt olyan jó tanuló. Apja emiatt 1834-ben a piaristákhoz vitte, ahol az I. grammatikai osztályban a többnyire német tanulók közt leginkább a magyar nyelvben volt jó, illetve osztálytársai közül ő írt és rajzolt a legszebben. Itt sem tanult jobban és az első osztályt 1835 nyarán csak elsőrendű bizonyítvánnyal végezte. Érdeklődése már ekkor a színészet felé fordult, ezenkívül osztályában túlságosan sokan voltak. Pesten sokat volt alkalma gyakorolni a német nyelvet. A szünidő nagy részét keresztapja, Martiny Károly ügyvéd házánál töltötte Kiskőrösön. + +Apja már azon gondolkodott, hogy kiveszi az iskolából, de 1835-ben újra beadta felekezetének aszódi algimnáziumába, a II. grammatikai osztályba. A kis városban, a kevésbé népes osztályban Petőfi megint kitűnt rendes magaviseletével és szorgalmával, mely a 2. és 3. évben még jobban fokozódott. Mint szintaxista már nagy kedvvel gyakorolta a latin versformákat. Kedélyélete fejlett, költői ambíciói ébredeztek; szívesen olvasta a kis könyvtár költői és történeti műveit, elsősorban Horatius ódáit szerette. Mikor azonban Aszódon színitársulat járt, színésznek akart felcsapni. Emiatt apja, akit Petőfi tanára, Koren István sietett értesíteni, meg is fenyítette fiát. Szállása Neumannénál volt, a két utolsó évben öccsével együtt. + +Itt lobbant fel első szerelme Cancriny Emilia iránt, akihez szerelmes verset írt. Itt barátkozott össze Neumann Károllyal, Dömök Elekkel és Esztergályi Mihállyal. Részt vett egy pár ártatlan diákcsínyben is. 1837 karácsonyára három iskolatársával Pencre (ma: Pest megye) ment, ahol nagynénjét, Hrúz Annát látogatta meg, aki Kosztolányi ügyvédnél volt házvezetőnő. + +Petőfi mint első eminens tanuló hagyta el 1838. június 30-án az aszódi algimnáziumot. Jól beszélt németül és latinul; különösen kitűnt a magyar fogalmazásban, és az év végi búcsúvers elkészítését, melyet máskor Koren tanár írt, ezúttal őrá bízták. Az 54 hexameterből álló vers fennmaradt és ez Petőfinek legrégibb ismert költeménye, címe: Búcsúzás 1838-ik évben. +Gyermekkorának színtere Kiskunfélegyházán + +Aszódi éveiről az Úti jegyzetekben így emlékezik meg: + +„Aszód! Csak egyszer kellene ezt a szót tőlem hallnod, s azonnal kitalálnád, hogy én itt három esztendőig tanultam… akarom mondani: jártam iskolába. S mily eseménydús három esztendő! 1. Itt kezdtem verseket csinálni. 2. Itt voltam először szerelmes. 3. Itt akartam először szinésszé lenni. A verselés a szerelem eredménye volt. A szinésszé lenni akarásnak pedig nem annyira eredete, mint következménye nevezetes. Nevezetes és szomorú.”[8] + +Az 1845-ben írt Úti jegyzetekben említett első szerelme a tizenöt éves Cancrinyi Emília volt, egy özvegy evangélikus lelkész leánya, aki Aszódon diáktársa volt. Emilia kisasszony nagyjából egyidős volt a költővel, és idős korában kellemetlenül érintette, hogy az emlékezetében nyilvánvalóan megkopott aszódi diák körül olyan nagy felhajtást csaptak a korabeli újságok, nem szívesen beszélt Petőfiről. Csak abban hasonlított a legtöbb múzsához, hogy ő sem szerette a verseket. Petőfinek hozzáírt névnapi köszöntőjét azonban megőrizte, bár egyáltalán nem tartotta becsben, mert végül elkallódott.[9] Sírja a tápiószelei temetőben van. + +Ezzel azonban a boldog gyermekkor véget is ért, és a serdülő Petőfire a hányattatás és szenvedés súlyos évei vártak. Apját, ki az 1830-as években Szabadszálláson is évről-évre vagyonosodott, 1838-tól kezdve egymásután súlyos csapások érték; az 1838. évi árvíz elöntötte földjét és elvitte házát, egy megbizottja hűtlenül kezelte egyik bérletét, sőt peres úton megkárosította és birtokai egy részét 1839-ben elárverezték. Egy rokona, akinek kölcsönpénzt adott és akiért jótállott, megbukott, úgy hogy Petrovicsot is magával rántotta, emiatt 1840-ben már úgyszólván semmije sem maradt. A sok csapás csak ingerültté tette a különben is szigorú apát, aki fiának legcsekélyebb tévedését sem tudta elnézni. Hozzájárult ehhez, hogy évről-évre mind kevesebbet tudott érte áldozni is. A fiúra nézve pedig ezek az évek rendes körülmények közt is válságosak lettek volna, mert fényes szellemi tehetségei kezdtek kinőni az iskolai szűk keretből és bizonytalan célok után ösztönözték. + +Petőfi 1838. augusztus 31-étől a Selmecbányai Líceumba járt, ahol az 5. osztályba, első éves rétornak iratkozott be. Már itt érdeklődni kezdett a korabeli nemzeti és irodalmi küzdelmek iránt, és a vegyes nemzetiségű ifjúság közt, melyben – ahogy a tanárok közt is – pánszláv törekvések is megnyilvánultak, ő magyarnak vallotta magát és lelkesen csatlakozott az ifjúság kebelében fennállt Nemes Magyar Társaság nevű önképzőkörhöz, melybe első éves rétor létére nem kezdő, hanem rendes tagként vették fel. E társaságban elemében érezte magát, versekkel és bírálatokkal többször fellépett. Itt szavalta október 31-én a Csákot, november 7-én A hűtelenhez című költeményét (mely elveszett); 1839. február 16-án felolvasták A költő keserve című költeményét (az érdemkönyvből kitépve). Bolemann ekkor megjósolta, hogy ebből a fiúból még költő lesz. Tehetségét szította a pár évvel idősebb Szeberényi Lajos, a társaság elnöke, akivel Petőfi barátságot kötött. Boleman István és Lichard Dániel voltak tanárai, előbbi költészettant, latin fordítást, stílusgyakorlatokat és földrajzot tanított, az utóbbi pedig hittanra, régiségtanra és magyar történelemre oktatta az ifjúságot latinul, mivel magyarul nem tudott. Ezenkívül a német nyelvet is gyakorolták. + +Az iskolában azonban rohamosan hanyatlott, főleg egyes tárgyak tanulására adta magát és önművelésének élt. Szegénysége is nyomasztó volt rá nézve, az alumneumban ebédelt. Hogy eljárhasson a színházba, amelyért rajongott, egy és más holmiját eladta. Ezért részeges házigazdája[10] korhelységgel vádolta tanárai, utóbb atyja előtt. Ezért megharagudott gazdájára és 1839 elején Szeberényi közelében, özv. Fedáknénál fogadott lakást. + +A félévi vizsgálat is rosszul sikerült, s egyik szláv érzelmű tanárától, Lichard Dánieltől magyar történelemből elégtelent kapott. Apja erre megírta neki, hogy mint érdemetlen fiúról leveszi róla kezét, mire Petőfi 1839. február 15-én elhagyta a selmeci líceumot. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/sorok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/sorok.txt new file mode 100644 index 0000000..83b2a16 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/sorok.txt @@ -0,0 +1,9 @@ +1 +2 +3 +4 +5 +6 +7 +8 +9 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika.txt new file mode 100644 index 0000000..4b410fc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika.txt @@ -0,0 +1,81 @@ +' ' karakter: 10 db +' +' karakter: 65 db +' ' karakter: 65 db +'!' karakter: 2 db +'(' karakter: 10 db +')' karakter: 10 db +',' karakter: 161 db +'-' karakter: 34 db +'.' karakter: 142 db +'/' karakter: 2 db +'0' karakter: 8 db +'1' karakter: 74 db +'2' karakter: 25 db +'3' karakter: 35 db +'4' karakter: 14 db +'5' karakter: 12 db +'6' karakter: 6 db +'7' karakter: 8 db +'8' karakter: 54 db +'9' karakter: 12 db +':' karakter: 7 db +';' karakter: 4 db +'?' karakter: 3 db +'A' karakter: 41 db +'B' karakter: 3 db +'C' karakter: 5 db +'D' karakter: 4 db +'E' karakter: 19 db +'F' karakter: 8 db +'G' karakter: 2 db +'H' karakter: 11 db +'I' karakter: 22 db +'J' karakter: 5 db +'K' karakter: 29 db +'L' karakter: 7 db +'M' karakter: 15 db +'N' karakter: 9 db +'O' karakter: 2 db +'P' karakter: 46 db +'R' karakter: 1 db +'S' karakter: 33 db +'T' karakter: 5 db +'U' karakter: 1 db +'V' karakter: 4 db +'Z' karakter: 1 db +'[' karakter: 9 db +']' karakter: 9 db +'a' karakter: 717 db +'b' karakter: 209 db +'c' karakter: 85 db +'d' karakter: 177 db +'e' karakter: 984 db +'f' karakter: 93 db +'g' karakter: 264 db +'h' karakter: 102 db +'i' karakter: 443 db +'j' karakter: 108 db +'k' karakter: 428 db +'l' karakter: 627 db +'m' karakter: 293 db +'n' karakter: 535 db +'o' karakter: 357 db +'p' karakter: 55 db +'r' karakter: 436 db +'s' karakter: 629 db +'t' karakter: 867 db +'u' karakter: 109 db +'v' karakter: 237 db +'x' karakter: 4 db +'y' karakter: 214 db +'z' karakter: 391 db +'É' karakter: 5 db +'Ú' karakter: 2 db +'á' karakter: 368 db +'é' karakter: 361 db +'í' karakter: 55 db +'ó' karakter: 66 db +'ö' karakter: 132 db +'ú' karakter: 41 db +'ü' karakter: 46 db diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika2.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika2.txt new file mode 100644 index 0000000..2fe2e36 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/statisztika2.txt @@ -0,0 +1,61 @@ +' +' karakter: 12 db +' ' karakter: 12 db +'"' karakter: 2 db +'%' karakter: 1 db +'(' karakter: 10 db +')' karakter: 10 db +',' karakter: 7 db +'-' karakter: 8 db +'.' karakter: 15 db +'/' karakter: 1 db +'0' karakter: 4 db +'1' karakter: 10 db +'2' karakter: 6 db +'3' karakter: 2 db +'4' karakter: 6 db +'5' karakter: 3 db +'6' karakter: 3 db +'7' karakter: 4 db +'8' karakter: 4 db +'9' karakter: 8 db +':' karakter: 3 db +'A' karakter: 7 db +'D' karakter: 1 db +'E' karakter: 3 db +'F' karakter: 1 db +'G' karakter: 3 db +'J' karakter: 1 db +'K' karakter: 1 db +'L' karakter: 2 db +'M' karakter: 1 db +'N' karakter: 12 db +'P' karakter: 2 db +'S' karakter: 1 db +'T' karakter: 4 db +'U' karakter: 2 db +'V' karakter: 1 db +'Z' karakter: 1 db +'a' karakter: 85 db +'b' karakter: 26 db +'c' karakter: 4 db +'d' karakter: 23 db +'e' karakter: 110 db +'f' karakter: 10 db +'g' karakter: 38 db +'h' karakter: 14 db +'i' karakter: 44 db +'j' karakter: 12 db +'k' karakter: 52 db +'l' karakter: 73 db +'m' karakter: 33 db +'n' karakter: 59 db +'o' karakter: 44 db +'p' karakter: 14 db +'r' karakter: 45 db +'s' karakter: 52 db +'t' karakter: 81 db +'u' karakter: 20 db +'v' karakter: 13 db +'y' karakter: 21 db +'z' karakter: 39 db diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szavak.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szavak.txt new file mode 100644 index 0000000..c530483 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szavak.txt @@ -0,0 +1,33523 @@ +a +abba +abbahagy +abbahagyat +abbamarad +abesszin +ablak +ablakkeret +ablakmászás +ablakmélyedés +ablakocska +ablakpárkány +ablakrács +ablaksor +ablaktábla +ablaktalan +ablaktörlő +ablakú +ablaküveg +abrak +abrakostarisznya +abrosz +abroszos +abszolút +absztrahál +absztrakt +abszurd +abszurdum +acat +acél +acélcső +acélerős +acélfal +acélfogsor +acélgömb +acélkar +acélkék +acélkeretű +acéllemez +acélmennyezet +acélos +acélosítás +acélosság +acélprés +acélszínű +acéltömb +acélüzem +achátszivárványos +acsarkodik +acsarog +ad +ad-vesz +adás +adás-vétel +adag +adakozás +adakozó +adalék +adat +adatfeldolgozó +adatgyűjtés +adatszolgáltatás +addig +addigi +adjonisten +adjunktus +adminisztráció +adminisztrál +adminisztrálás +adminisztrátor +adminisztratív +adó +adó-vevő +adóbevallás +adócsalás +adódik +adófelügyelő +adómentes +adómentesség +adórovás +adós +adósság +adószedő +adótartozás +adózik +adogat +adomány +adományoz +adoptál +adott +adottság +adu +aeronautika +afelett +afeletti +afelől +afféle +affrikáta +afrikai +afrikansz +agár +agancs +agg +aggály +aggályos +aggályoskodás +aggályoskodik +aggastyán +aggaszt +aggasztó +aggat +aggkori +agglegény +aggódás +aggódik +aggodalmas +aggodalmaskodás +aggodalom +aggregátor +aggszűz +agilis +agitáció +agitál +agitátor +agitatív +agonizálás +agrár +agráregyetem +agrárpolitika +agrárproletár +agrárproletariátus +agrártudomány +agresszív +agronómus +agronómusság +agy +agyafúrt +agyag +agyagdomb +agyagedény +agyagkorsó +agyagos +agyagréteg +agyalágyult +agyalkat +agyar +agyba-főbe +agyérelmeszesedés +agykéreg +agyő +agyonás +agyonbarázdált +agyonbüntet +agyoncivilizál +agyoncsap +agyoncsíp +agyondagaszt +agyondédelget +agyonetet +agyonfagy +agyonhasznál +agyonistenít +agyonjár +agyonkínoz +agyonkövezés +agyonlapít +agyonlő +agyonmos +agyonnyom +agyonölelget +agyonpöttyöz +agyonszorít +agyonüt +agyonvág +agyonver +agyonveret +agyonzsúfol +agyrázkódás +agysebész +agysejtállomány +agytérkép +agytröszt +agytumor +agyú +agyvérzés +agyvelő +ah +aha +ahány +ahányszor +aham +ahelyett +ahogy +ahogyan +ahol +ahonnan +ahova +aj +ajándék +ajándékoz +ajándékozás +ajánl +ajánlat +ajánlatos +ajánlgat +ajánlkozik +ajánló +ajánlólevél +ajaj +ajak +ajjaj +ajkbiggyesztve +ajnároz +ajókagyűrű +ajtó +ajtóbetét +ajtócsapódás +ajtócsukás +ajtófél +ajtókulcs +ajtólap +ajtónagyságú +ajtónyitás +ajtóragaszték +ajtórés +ajtószárny +akác +akácbokor +akácerdő +akácfa +akácfarönk +akácméz +akácos +akáctörzs +akáctuskó +akár +akárcsak +akárhányszor +akárhogy +akárhogyan +akárhol +akárhonnan +akárhova +akárki +akármeddig +akármelyik +akármennyire +akármerre +akármi +akármiféle +akármikor +akármilyen +akármint +akad +akadály +akadályoz +akadálytalan +akadékoskodás +akadékoskodik +akadémia +akadémikus +akadozik +akar +akarás +akarat +akaratátvitel +akaraterő +akaratlan +akaratos +akaratoskodás +akaratú +akarnok +akarnokság +akaródzik +akarom +akarva-akaratlanul +akaszkodik +akaszt +akasztás +akasztanivaló +akasztófa +akceleráció +akció +akciócsoport +akciósablon +aki +akként +akképpen +akklimatizálódás +akkor +akkora +akkorára +akkord +akkori +akkoriban +akkornap +akkortájban +akkortájt +akkurátuskodás +akna +aknász +aknamező +aknamunka +aknatűz +aknavető +aknazápor +aközben +akol +akrobataugrás +akt +akta +aktatáska +aktatáskás +aktfotó +aktfotós +aktív +aktor +aktuális +aktus +akut +alá +aláás +aláad +aláaknáz +alább +alábbhagy +alábbi +alábocsát +alábújik +alácsúsztat +aládúcol +aláejt +aláereszkedik +aláfalaztat +aláfest +aláfutásos +alágyűr +aláhúz +aláhull +aláhuzigál +aláír +aláírás +aláírat +alája +alákérdez +aláleng +alámerül +alámos +alárendel +alássan +alászáll +alászolgája +alátámaszt +alátét +alátesz +alávaló +alávalóság +alávet +aláz +alázat +alázatos +alázkodás +alázkodik +alacsony +alagsor +alagsori +alagút +alagútépítő +alagútfúrás +alagútszerű +alak +alakít +alakítás +alakítgatás +alakos +alakoskodás +alakoskodik +alaktalan +alakú +alakul +alakulás +alakulat +alakzat +alamizsna +alant +alantas +alany +alap +alapállás +alapanyag-differenciáltság +alapelv +alaphang +alaphazugság +alapít +alapítás +alapítási +alapító +alapján +alapméret +alapötlet +alapos +alapoz +alapozás +alaptalan +alapterület +alaptörvény +alapú +alapul +alapvető +alapvicc +alapvizsgázik +alapzat +alatt +alatta +alatti +alattomos +alattvaló +albán +albérlet +albérleteskedik +albérleti +albérlő +albérlői +album +alélt +alezredes +alezredesi +alfaj +alfél +alföldi +alga +algyői +alhadnagy +alibi +alibi-termelés +alibizik +alig +alig-alig +aligha +alighanem +alighogy +aligség-alig +alj +aljakő +aljas +aljasság +alkalmas +alkalmatlan +alkalmatlankodik +alkalmatos +alkalmaz +alkalmazás +alkalmazható +alkalmazhatóság +alkalmazkodás +alkalmazkodik +alkalmazkodó +alkalmazott +alkalmazotti +alkalmi +alkalom +alkalomadtán +alkat +alkati +alkatrész +alkatú +alkohol +alkoholadag +alkoholfogyasztás +alkoholillat +alkoholista +alkoholizmus +alkoholmámor +alkony +alkonyat +alkonyattájt +alkonyi +alkonyodás +alkonyodik +alkot +alkotás +alkotmány +alkotmányjog +alkotó +alkotóerő +alkotóképesség +alkotókedv +alkotóművész +alkotómunka +alkotórész +alku +alkudozás +alkudozik +alkuszik +allergiás +alma +almás +almáskert +almásláda +almásszürke +almafényű +almahalom +almamosolygós +almaszagú +almazöld +alól +alóla +alom +alorvos +alosztály +alpesi +alpinista +alsó +alsóbbrendű +alsóbbrendűségi +alsógatya +alsónadrág +alsónemű +alsóruha +alsószoknya +alsótelepi +alsótest +alszik +alt +alta +altábornagy +altat +altatás +altatásos +altató +alternatíva +altiszt +altiszti +aludttej +alul +aluli +aluljáró +alulmarad +alulnézet +alumínium +aluszékonyság +alvás +alvásszagú +alvadt +alvatlanság +alvezér +alvidék +alvilág +alvilági +alvó +amarra +amatőr +amaz +ambíció +ambiciózus +ambrózia +ameddig +amekkora +amellett +amely +amelyik +amennyi +amennyiben +amennyire +amerikai +amerre +amerről +ami +amíg +amiatt +amidőn +amiért +amiként +amiképpen +amikor +amily +amilyen +aminő +amint +aminthogy +amióta +amire +ammóniák +ammóniákszag +amnesztia +amögött +amoda +amoly +amolyan +amonnan +amorf +amott +amputáció +amszterdami +amúgy +amulett +anakronizmus +analfabéta +analitikus +analóg +anamnézis +ananász +anarchikus +anarchista +anatómia +anatómiai +andalgás +andalog +anélkül +anekdota +anekdotázás +angliai +angol +angolbarát +angolos +angolság +angolszász +angyal +angyali +angyalka +annál +annektálás +annyi +annyi-annyi +annyiban +annyiféle +annyifelé +annyira +annyiszor +anomália +anomális +antanthatalom +antantintervenció +antantmintájú +antenna +antennájú +antifasiszta +antik +antikrisztus +antikvárium +antiszemita +antiszemitizmus +antul +anya +anyás +anyáskodik +anyátlan +anyaarc +anyacsászárnő +anyaföld +anyag +anyagcsere +anyagerő-háború +anyagerő-robbantás +anyaghalmaz +anyagi +anyagkészlet +anyagmennyiség +anyagmozgatás +anyagmozgató +anyagpazarlás +anyagráfordítás +anyagraktár +anyagrészecske +anyagú +anyagyilkos +anyaház +anyai +anyajegy +anyajogú +anyakönyvi +anyakönyvvezető +anyaméh +anyamell +anyanyelv +anyaország +anyaszentegyház +anyaszerű +anyaszült +anyaszülte +anyatej +anyatermészet +anyós +anyóstárs +anyu +anyuci +anyuék +anyuka +anyusék +apa +apáca +apácanövendék +apácarend +apácazárda +apácska +apás +apátia +apacsinges +apad +apadás +apafej +apagyilkos +apahiány +apai +apellál +apelláta +apó +apóék +apóka +após +apósék +apokrif +apolitikus +apostol +apparátus +apránként +apraja +apraja-nagyja +aprít +apró +aprócska +apródkard +apródonként +apróhirdetés +aprójószág +apróka +aprólék +aprólékleves +aprólékos +aprómunka +aprópénz +apróra +apróság +aprósütemény +aprószemű +aprószentek +apróvad +apszis +apu +apuék +apuka +apus +apusék +apuska +arány +aránylag +arányos +arányszám +aránytalan +aránytalanság +arányú +arab +arab-néger +arabeszk +arany +aranyásó +aranybányász +aranybarna +aranyborjú +aranybulla +aranycsatos +aranycsillám +aranydísz +aranydukát +aranyedény +aranyember +aranyeső +aranyfiú +aranyfoglalatú +aranyfogú +aranyfüggő +aranyfűz +aranygomb +aranygombos +aranygyűrű +aranyhal +aranyhegedű +aranyhegy +aranyifjú +aranykalászos +aranykarika +aranykezű +aranykor +aranykorona +aranylánc +aranyláz +aranylemezke +aranyló +aranymálinkó +aranymúmia +aranyos +aranyoska +aranyoz +aranyozott +aranyperec +aranypor +aranyrög +aranyrügy +aranysárga +aranyszínű +aranyszőke +aranyszőrű +aranytapintású +aranyzsinóros +arasz +arasznyi +araszolgat +araszoló +arat +aratás +aratási +aratógép +arc +arcbőr +arcél +arcélmény +arcélű +archívum +arcizom +arcjáték +arckép +arckifejezés +arcmás +arcmemória +arcösszedörzsölés +arcocska +arcszesz +arcszínű +arcú +arcüreg +arculat +arcvonás +arcvonású +arcvonal +argó +ariánus +arisztokrácia +arisztokrata +aritmiás +aromás +arra +arrább +arrafelé +arravaló +arról +artéria +artézi +artikulációs +artikulálatlan +artista +arzenál +aspektus +aspiránsi +aspirantúra +aspirantúra-időszak +asszisztál +asszisztens +asszisztensnő +asszociáció +asszony +asszonyember +asszonyféle +asszonyi +asszonyka +asszonylány +asszonynév +asszonyos +asszonyság +asszonysors +asszonytárs +asszonytörpe +aszály +aszalt +aszerint +aszfalt +aszfaltos +aszkétaarc +aszkézis +aszketikus +aszódi +aszondja +aszott +aszparágusz +aszpik +aszpirin +asztag +asztal +asztalféle +asztalfiók +asztalfő +asztali +asztalka +asztallap +asztalnyi +asztalos +asztalosmester +asztalosrészleg +asztalossegéd +asztalosszerszám +asztaltárs +asztaltársaság +asztalterítő +asztalvég +asztmás +asztrahánprémes +ateista +atlétaszerű +atlétatermetű +atlétatrikó +atlétatrikós +atmoszféra +atmoszférátlanság +atmoszféranyomás +atom +atom-időszámítás +atombomba +atomenergia +atomkor +atomtitok +attasé +attól +attrakció +atya +atyafi +atyafia +atyafiság +atyai +atyaúristen +atyó +atyóka +augusztus +augusztusi +auktor +aula +auszi +ausztrál +ausztráliai +autentikus +autó +autóbusz +autóbuszmegálló +autócilinder +autófolyam +autójavító +autómárka +autómoraj +autópárna +autórádió +autós +autószerelő +autószerencsétlenség +autóút +autóüveg +autóvezetés +autózik +autodidakta +autogénhegesztő +autogejzír +automata +automatika +automatikus +automatizál +automatizálás +automatizmus +autonómia +avagy +avar +avas +avasfejű +avatag +avatatlan +avatkozik +avatott +avult +az +azáltal +azalatt +azaz +azért +azelőtt +aznap +aznapi +azóta +azon +azonban +azonfelül +azonkívül +azonmód +azonnal +azonnali +azonos +azonosít +azonosság +azonosul +azontúl +aztán +azúr +azután +azzal +á +ábécé +ábra +ábránd +ábrándos +ábrándozás +ábrándozik +ábrázat +ábrázol +ábrázolás +ábrahámhegyi +ács +ácsmunka +ácsol +ácsolat +ácsorog +ádámcsutka +ádámcsutkájú +ádáz +áfonya +ág +ágál +ágacska +ágas-bogas +ágaskodik +ágazik +ágú +ágy +ágyás +ágyacska +ágyas +ágyaz +ágyazás +ágybontás +ágyék +ágyhuzat +ágynemű +ágyrajáró +ágytál +ágytakaró +ágyterítő +ágyú +ágyúcső +ágyúdörgés +ágyúlövés +ágyúöntő +ágyúz +ágyúzás +áh +áhít +áhítat +áhítatgyakorlat +áhítatgyakorlati +áhítatos +áhítozik +ájtatos +ájtatosság +ájulás +ájult +ál +álarc +álca +álcáz +áld +áldás +áldatlan +áldó +áldott +áldoz +áldozás +áldozat +áldozathozatal +áldozati +áldozatos +áldozatvállalás +áldozik +álhír +álkulcs +áll +állás +állásfoglalás +álláspont +állástalan +állású +állag +állam +állambiztonsági +államérdek +államerdészet +államférfi +államfő +államfői +államháztartás +államhatalom +állami +államkincstár +államminiszter +állammonopolista +államosítás +állampolgár +állampolgárság +államrendőrség +államszervezet +államszövetség +államtitkár +államtitok +állandó +állandóság +állandósul +állapot +állapotos +állat +állatgondozó +állati +állatka +állatkert +állatkiállítás +állatnév +állatocska +állatorvos +állatszem +állattenyésztő +állatvilág +álldogál +álldogálás +állékonyság +állhatatlan +állhatatos +állhatatosság +állít +állítás +állítható +állítmány +állító +állítólag +állítólagos +állkapcsos +állkapocs +álló +állólámpa +állótükör +állóvíz +állomány +állomás +állomáselöljáró +állomásfőnök +állomáshely +állomásozik +állott +állvány +állványos +állványzat +álmatag +álmatlan +álmatlanság +álmélkodás +álmélkodik +álmélkodó +álmodik +álmodozás +álmodozik +álmodozó +álmos +álmosít +álmosság +álnév +álnok +álnokság +álnyakkendő +álom +álombeli +álomkép +álomszerű +álomtalan +álruha +álság +álságos +álszerény +álszerénység +által +általa +általában +általános +általánosít +általánosítás +általánosítható +általánosság +általi +általmegy +általszalad +áltat +ám +ámbár +ámbátor +ámde +ámen +ámolygás +ámul +ámulás +ámulat +ámuldozik +ánizsos +ápol +ápolás +ápolatlan +ápoló +ápolónő +ápolónőképző +ápolónővér +ápolószemélyzet +ápolt +áporodott +április +áprilisi +ár +árad +áradás +áradat +áradozik +áram +áramgyűjtő +áramkör +áramlás +áramlat +áramlik +áramtalanító +áramütés +áramütéses +árapály +áraszt +árboc +árendál +árfolyam +árgus +árhullám +ária +áriázik +árja +árja-párja +árkád +árkádos +árkász +árkászalakulat +árkon-bokron +árkos +árkülönbség +ármádia +ármányos +árny +árnyalak +árnyalat +árnyalatnyi +árnyalatú +árnyas +árnyék +árnyékol +árnyékos +árnyéksáv +árnyékszék +árnyékú +árnyszerű +árok +árokásó +árokpart +árokrendszer +árpa +árpád-féle +árrendszer +árrendszer-kérdés +árt +ártány +ártalmas +ártalmatlan +ártalom +ártatlan +ártatlanság +áru +árucikk +áruház +árukészlet +árul +árulás +árulkodik +árulkodó +áruló +árus +árusít +áruszállító +árutérítés +árva +árvaház +árvaházi +árvaság +árvédelmi +árvíz +árvízvédelem +árvízvédelmi +árvízveszély +ás +ásás +ásat +ásít +ásítás +ásítozik +áskálódik +ásó +áspiskígyó +ásvány +ásványtani +ásványvizes +ász +át +átállít +átázik +átabotában +átad +átadás +átalakít +átalakítás +átalakul +átalakulás +átall +átalszik +átbámul +átbeszélget +átböngész +átbújik +átcaplat +átcsap +átcsatol +átcsavar +átcserél +átcsorog +átcsúszik +átcuppog +átdob +átdug +átél +átélés +átépítés +átépül +átér +átérez +átérzés +átejt +átellenben +átellenében +átenged +áteresz +átereszt +átesik +átevez +átfázik +átfényesít +átfénylik +átfektet +átfeszít +átfog +átfogalmaz +átfogható +átfogó +átfon +átfordít +átfordul +átfúr +átfűlik +átfűrészel +átfurakodik +átfut +átgázol +átgördül +átgondol +átgondolt +átgyakorlatozik +áthárít +áthajlik +áthajózik +áthajol +áthalad +áthallatszik +áthangol +átharap +áthasít +áthat +átható +áthatol +áthatolhatatlan +áthelyez +áthelyezés +áthelyeztet +áthív +áthívat +áthidal +áthoz +áthúz +áthurkol +átír +átírás +átível +átigazol +átigazolás +átigazolási +átirat +átitat +átitatódik +átjár +átjárás +átjáró +átjavít +átjön +átjut +átkarol +átképzés +átképzős +átkér +átkel +átkelés +átkelő +átkelőhajó +átkerül +átkígyózik +átkísér +átködlik +átköltözik +átköt +átkos +átkoz +átkozódik +átkozott +átküld +átkulcsol +átkutat +átlábol +átlát +átlátszó +átlag +átlagember +átlagos +átlagosztályzat +átlapoz +átlényegít +átlényegül +átlép +átlépés +átlépeget +átlendül +átleng +átló +átlós +átlő +átlovagol +átlyuggat +átmászik +átmérőjű +átmegy +átmelegedik +átmelegít +átmenet +átmeneti +átment +átmetsz +átmetszés +átnéz +átnedvesedik +átnevelés +átnyalábol +átnyit +átnyomódik +átnyomul +átnyújt +átnyúl +átölel +átöltözés +átöltözik +átömlik +átok +átpásztáz +átpasszol +átpattan +átplántál +átpöfög +átrámol +átrándul +átráz +átragad +átragyog +átrajzolódik +átrak +átrakosgat +átrendezés +átrepül +átrepülés +átrezzen +átrobog +átrohan +átsétál +átsegít +átsettenkedik +átsiet +átsiklik +átsüt +átsugárzik +átsuhan +átszáll +átszállás +átszálló +átszámít +átszakít +átszalad +átszel +átszellemül +átszenved +átszervezés +átszerveződik +átszínez +átszíneződik +átszivárgás +átszivárog +átszól +átszökik +átszökken +átsző +átszúr +átszüremlik +átszűr +áttanulmányoz +áttérés +áttekint +áttekintés +áttekinthetetlen +áttekinthető +áttekinthetőség +áttelefonál +átteleltet +áttelepedik +áttelepít +áttelepítés +áttelepitett +áttelepült +áttesz +áttetszik +áttetsző +áttör +áttördel +áttörés +áttol +áttüzesedik +átúszik +átül +átültet +átüt +átütő +átüzen +átugrál +átugrik +átutal +átutazó +átvág +átvált +átváltozik +átváltoztat +átvándorol +átvérzik +átvészel +átvétel +átvedlik +átvegetál +átver +átvergődik +átvesz +átvet +átvetődés +átvezet +átvilágít +átvillan +átvirraszt +átvisz +átvizel +átvizsgál +átvizsgálás +átvonszol +átvonszolódik +átvonul +átvonulás +átzsírosodik +átzúdul +ávós +ázalék +ázik +ázsiai +ázsió +áztat +áztatgat +b-kategóriájú +ba-ba-ba-ba-ba +báb +bába +bábaasszony +bábaház +bábamesterség +bábaoklevél +bábaság +bábatábla +bábcsoport +bábelőadó +bábjáték +bábu +bácsi +bácsiék +bácsika +bácskai +bádogbódé +bádogdísz +bádogdoboz +bádogeresz +bádoghordó +bádogláda +bádoglemez +bádogmaszk +bádogmosdó +bádogpult +bádogrész +bádogsárkány +bádogtányér +bádogtest +bádogváza +bágyadt +bágyadtság +bágyasztó +báj +bájos +bál +báli +bálna +bálnafaj +bálterem +bálvány +bálványimádó +bálványozás +bámész +bámészkodás +bámészkodik +bámészkodó +bámul +bámulat +bámulatos +bámultat +bán +bánásmód +bánat +bánatos +bánik +bánkódás +bánkódik +bánt +bántás +bántalom +bántatlan +bántó +bántódás +bánya +bányász +bányászati +bányászik +bányászsztrájk +bányaiskola +bányamentő +bányaművelési +bányarém +bányatársaság +bányatanácsos +bányaterület +bányatűz +bányaüzem +bár +bárány +báránybőr +bárányfelhő +bárányhimlős +bárányka +bárasztal +bárcsak +bárd +bárdolatlan +bárgyú +bárha +bárhogy +bárhogyan +bárhol +bárhova +bárka +bárki +bármeddig +bármely +bármelyik +bármennyi +bármennyire +bármerre +bármi +bármiféle +bármikor +bármily +bármilyen +báró +bárónő +bárpult +bársony +bársonyfüggöny +bársonyfüggönyös +bársonyhüvely +bársonymellényféle +bársonymellényke +bársonyszalag +bársonyszék +bárszék +bárszekrény +bártulaj +bástya +bástyaféle +bástyamaradvány +bástyaszerű +bátor +bátorít +bátorítás +bátorító +bátorkodik +bátorodik +bátorság +bátortalan +bátortalankodik +bátya +bátyus +bátyuska +bávatag +bázeli +bázis +bázisterület +bázisú +bázisüzem +bab +baba +babaarc +babaarcú +babahajtű +babér +babérlevél +babgulyás +bableves +babona +babonás +babrál +babramunka +babszem +babusgat +babusgatás +bacchusi +bacilus +bacilusgazda +bacilyuk +badarság +bagaria +bagó +bagószagú +bagózik +bagoly +bagolypárti +bah +baj +bajai +bajbajutott +bajkeverő +bajlódik +bajmolódás +bajmolódik +bajnok +bajnokcsapat +bajnoknő +bajnokság +bajomi +bajor +bajos +bajoskodik +bajszos +bajszú +bajtárs +bajtársiasság +bajusz +bajuszos +bajusztalan +bajuszú +bak +baka +bakafántos +bakalódik +bakancs +bakancsléptek +bakancsnyom +bakancsos +bakhát +baklövés +bakonyi +bakszakáll +baktat +baktérium +bakter +bakterház +bakterházi +bal +balatoni +baldachinszerű +balegyenes +baleset +balesetbiztosítás +balesetelhárítási +balesetelháritó +baleseti +balesetmentes +balesetoktatás +balesetveszély +balfácán +balga +balgatag +balhé +balhézik +baljós +baljóslat +balkáni +balkon +balkonajtó +ballada +balladai +ballag +ballon +ballonkabát +ballonugrás +ballusztrád-motívum +baloldal +baloldali +baloldaliság +baloldalt +balos +balpriuszos +balsejtelem +balsiker +balsikerű +balsors +balszerencse +balta +baltikumi +balvélemény +balzsam +balzsamoz +balzsamozás +balzsamozási +balzsamozott +bamba +bambaság +bambulás +bambulási +bamm +banális +banán +banda +bandaharc +bandita +banditagazda +bandukol +bandzsa +bandzsít +bank +bankárné +bankelnök +bankett +bankhivatalnok +banki +bankigazgató +bankjegy +banklevél +bankó +bankrablás +banktisztviselő +bankvállalat +barát +baráti +barátkozás +barátkozik +barátnő +barátocska +barátság +barátságos +barátságtalan +barázda +barázdál +barázdás +barack +barackfa +barackos +barackpálinka +barackpálinkás +barakk +barakkablak +barakklakás +barakklakó +barakksor +barangol +barbár +barcsi +barett +barikád +barka +barkácsol +barkochba +barlang +barlangvasút +barna +barnás +barnáspiros +barnásvöröses +barnamedve +barnapiros +barnaszén +barnul +barokk +barokkos +barom +baromfi +baromorvos +baromság +baromvásár +basa +basáskodás +basszus +batár +batári-féle +batiszt +batisztruha +batisztzsebkendő +batyu +bauxit +bazár +bazári +bazalt +bazaltkeménységű +bazaltkő +bazedovos +bazen +bazsarózsa +bazsi +be +be-becsap +be-benéz +bécsi +bécsies +bég +béget +béka +békaember-felszerelés +békalencsés +béke +békés +békéscsabai +békétlenkedik +békebeli +békecsók +békeév +békeidő +békejobb +békesség +békességes +béketárgyalás +béketűrő +békít +békítés +békítget +béklyó +békülés +békülési +bél +bélés +bélel +bélelt +bélmosóasszony +bélrendszer +bélű +bélyeg +bélyegbolt +bélyegez +bélyegkereskedés +bélyegző +béna +bénaság +bénít +bénul +bénult +bénultság +bényei +bér +bérbefogadás +bérel +bérelszámoló +béremelés +bérenc +béres +bérfizetési +bérház +bérlemény +bérleményi +bérlethirdetés +bérlő +beáll +beállít +beállítás +beállítottságú +beállványoz +beárad +beáramlás +beárnyékol +beárul +beázik +beáztat +bead +beadvány +beakad +bealkonyodik +bearanyoz +beavat +beavatkozás +beavatkozik +beavatódik +beavatott +bebábozódik +bebámul +bebaktat +beballag +bebalzsamoz +bebalzsamozás +bebarangol +bebeszélés +bebizonyít +bebizonyítható +bebizonyosodik +bebiztosít +bebörtönöz +bebocsát +bebocsátás +beborít +beborul +bebújik +bebútoroz +bebugyolál +bebukik +beburkol +becéz +becézés +becézgetés +becenév +becibál +becipel +becsajoz +becsap +becsapódás +becsapódási +becsapódik +becsavar +becsavarodik +becsempész +becsenget +becserkel +becses +becsiccsent +becsinál +becsinált +becsmérel +becsörtet +becsomagol +becsomagoltat +becsordul +becsorgat +becsorog +becstelen +becsúszik +becsúsztat +becsül +becsület +becsületes +becsületesség +becsületszó +becsűr +becsuk +becsukás +becsukódik +becsusszan +becsvágy +bedagad +bedagaszt +bedeszkáz +bedöglik +bedől +bedob +bedobál +bedobás +bedolgozás +bedudál +bedug +bedugul +beduin +bee +beékelődik +beépít +beépítés +beépítési +beépítetlen +beépített +beér +beérik +beérkezés +beérkezik +beejt +beemel +beenged +beereszkedik +beereszt +beesett +beesik +beesteledik +beexponálás +befárad +befagy +befagyaszt +befalaz +befér +befészkel +befecskendez +befed +befejez +befejezés +befejezetlen +befejezett +befejeződik +befejezte +befektet +befektetés +befelé +befeléfordulás +befellegzik +befest +befirkant +befizet +befőtt +befőttesüveg +befőz +befőzőgumi +befog +befogad +befoltosodik +befolyás +befolyásol +befolyásolható +befolyásoltat +befolyásos +befolyású +befordul +befúr +befűt +befűz +befűzetlen +befullad +befullaszt +befut +befutóegyenes +befuttat +begázol +begazol +begerjed +begerjeszt +begónia +begóniatő +begöngyöl +begördül +begőzöl +begombol +begorombulás +begurigázik +begurul +begy +begyakorol +begyakoroltat +begyalogol +begyes +begyógyul +begyömöszöl +begyújt +begyűjt +begyűjtési +begyűr +begyullad +behálóz +behátrál +behajít +behajlít +behajol +behajt +behallatszik +beharangoz +beharap +behatol +behatolás +behavaz +beheged +behív +behívat +behívó +behízelgő +behint +behódolás +behorpad +behorpaszt +behoz +behúz +behúzódik +behűt +behuny +behuppan +beígér +beír +beírat +beidéz +beidegzett +beidegzettség +beidegződik +beigazít +beijed +beiktat +beilleszkedés +beilleszkedik +beillik +beindít +beindul +beinkasszál +beinvitál +beirányít +beiratkozás +beiratkozik +beismer +beismerés +bejár +bejárat +bejárati +bejáratos +bejáratú +bejáró +bejárogat +bejegyez +bejegyzés +bejelent +bejelentés +bejelentkezik +bejelentő +bejelentőlap +bejön +bejötte +bejövet +bejut +bejuttat +bekacsint +bekalkulál +bekandikál +bekanyarodik +bekap +bekapar +bekapcsol +bekapcsolás +bekapcsolódás +bekapcsolódik +bekarikázik +bekattint +bekényszerül +bekéredzkedik +bekéret +bekebelez +bekecs +beken +bekeretez +bekerít +bekerül +bekerülés +bekezdés +bekísér +bekiált +bekiabál +beköltözik +beköp +beköszön +beköszönt +beköszöntés +beköt +bekötöz +bekötő +bekövetkezik +bekövetkezte +bekopog +bekopogtat +bekormányoz +bekrepál +bekúszik +beküld +bekubikol +bekukkant +bekukucskál +belát +belátás +beláthatatlan +belátogat +belakik +belapátol +belapul +bele +bele-belecsíp +beléje +belép +belépés +belépési +belépet +belépő +belépődíj +belépőjegy +beleáll +beleállít +belead +beleakad +beleavatkozik +belebámul +belebeszél +belebetegszik +belebokszol +belebonyolódik +beleborzong +belebotlik +belebújik +belebukik +belecsap +belecsenget +belecsimpaszkodik +belecsókol +belecsorgat +belecsúszik +beledagad +beledöf +beledöglik +beledönt +beledob +beledug +beledugdos +beledumál +beleél +beleér +beleért +beleérzés +beleegyesül +beleegyezés +beleegyezik +beleejt +beleesik +belefárad +belefásul +belefér +belefekszik +belefog +belefojt +belefolyik +belefordít +belefúj +belefúr +belefúródik +belefülled +belefullad +belegázol +belegabalyodik +belegondol +belegügyül +belegubancolódik +belegyömöszöl +belegyorsít +belehal +belehallatszik +beleharap +belehelyez +belehelyezkedik +belehempereg +belehülyül +beleír +beleilleszkedés +beleilleszkedik +beleillik +beleivódik +beleizzad +belejavít +belejön +belejut +belekalkulál +belekap +belekapál +belekapaszkodik +belekapcsolódik +belekarol +belekaszál +belekavar +belekékül +belekerget +belekerül +belekeseredik +belekever +belekeveredik +belekezd +belekóstol +beleköp +beleköpdös +beleköt +belekontárkodik +belekotyog +belekucorodik +belelát +belelapoz +belelép +belelendül +beleles +belelök +belelő +beleloval +belemászik +belemarkol +belemélyed +belemélyeszt +belemegy +belemelegedik +belemered +belemerül +belemormog +belenéz +belenevel +beleng +belenő +belenyargal +belenyikordul +belenyom +belenyúl +belenyugszik +belenyugvás +beleöl +beleömlik +beleönt +beleőrül +beleolvad +beleolvas +belep +belepillant +belepirul +belepofázik +beleprésel +belepusztul +belerág +belerándul +belerángat +beleragad +belerak +belerecseg +belerohan +belerokkan +belerúg +belerugdal +beles +belesápad +belesárgul +belesimul +belesóhajt +belesüllyed +belesüpped +belesuhint +beleszámít +beleszánt +beleszagol +beleszakít +beleszalad +beleszédül +beleszeret +beleszól +beleszólás +beleszólási +belesző +beleszokik +beleszúr +beleszületik +beleszuggerál +beletalál +beletanul +beletapogatódzik +beletapos +beletart +beletartozik +beletép +beletéved +beletekint +beletelepedik +beletelik +beletemet +beletemetkezik +beletesz +beletömköd +beletöröl +beletörődés +beletörődik +beletorkollik +beletűr +beleül +beleüt +beleütközik +beleugrik +beleun +belevág +belevakul +belevaló +belevés +belevésődik +belevegyül +belever +belevesz +belevet +belevezet +belevigyorog +belevisz +belevörösödik +belevonít +belezápul +belezabál +belezavarodik +belezökken +belezsibbad +belföldi +belfogyasztás +belga +belgrádi +belgyógyászat +belgyógyászati +belharc +belibben +belibeg +beljebb +belletrista +belök +belövöldöz +belő +belőle +belop +belopakodik +belső +belsőség +beltenger +belterjes +belterjesség +belterület +belügyi +belügyminiszter +belül +belüli +belváros +belvárosi +belvíz +bemászik +bemászkál +bemázol +bemasíroztat +bemaszatolódik +bemélyül +bemér +bemérő +bemegy +bemelegít +bemelegszik +bemenet +bemerészkedik +bemesél +bemocskol +bemocskolódik +bemond +bemondás +bemondó +bemutat +bemutatás +bemutatkozás +bemutatkozik +bemutató +bendő +benépesít +benépesül +benéz +benedvez +benevez +benn +benne +benneteket +bennfentes +bennszülött +bennünket +benő +benső +bensőséges +benyálaz +benyíló +benyilaz +benyit +benyom +benyomás +benyomul +benyújt +benyúl +benyúlik +benzin +benzineskanna +benzinköltség +benzinmotor +benzinszag +beöltözik +beöltöztet +beolajoz +beolt +beolvas +beolvaszt +beolvasztás +beomlik +beoson +beoszt +beosztás +beosztási +beosztású +beosztott +bepárásodik +bepanaszol +beperel +bepettyez +bepiszkít +bepiszkol +bepólyál +bepótol +bepörög +bepokrócoz +beprogramoz +beprogramozás +beránt +beragad +beragaszt +beragyog +berajzol +berak +berakás +berakosgat +berber +beregi +berek +berekeszt +berekeszthetetlen +berendel +berendez +berendezés +berendezési +berendezésű +berendezkedik +berepül +bereteszel +berezel +berliner +berlineres +berlini +berobban +berobog +berohan +berohanta +beront +beroskad +berozsdásodik +berreg +berregés +berúg +berúgat +beruházás +beruházó +berzenkedik +besározódik +besajtol +besatíroz +besavanyít +besétál +besiet +beslisszel +besmurkál +besóz +besöpör +besötétedik +besötétít +besorakozik +besorol +bespájzol +bespriccel +beste +bestia +bestoppol +besúgó +besüpped +besüt +besűrűsödik +besugárzás +besurran +besuttyan +beszáll +beszállás +beszállásolás +beszállít +beszálló +beszámít +beszámol +beszámoló +beszárad +beszagol +beszakad +beszalad +beszaladgál +beszappanoz +beszari +beszariság +beszéd +beszédes +beszédmodor +beszédtéma +beszédű +beszél +beszélés +beszélget +beszélgetés +beszélgetésfoszlány +beszélnivaló +beszélő +beszéltet +beszed +beszegez +beszentel +beszentelés +beszerel +beszerez +beszervez +beszerzés +beszerzőút +beszív +beszívódik +beszimatol +beszipog +beszippant +beszivárog +beszól +beszór +besző +beszorít +beszorul +beszúr +beszüntet +beszüntetés +beszüremlik +beszürkül +beszűkül +beszűrődik +betájol +betámaszt +betáplál +betársul +betagosít +betakar +betakargat +betakarítási +betakarózik +betalál +betanít +betanított +betart +betartás +betaszít +beténfereg +betér +betét +betétes +betétkönyv +betéved +beteg +betegágy +betegállomány +betegápolás +beteges +betegeskedik +betegség +betegségfolyamat +betegszabadság +betekint +betekintés +betelefonál +betelepedik +betelepít +betelepülés +betelhetetlen +betelik +beteljesít +beteljesül +betemet +betemetés +beterel +beterelget +beterjeszt +betervez +betessékel +betesz +betevő +betimsóz +betlehemi +betli +betódul +betökél +betölt +betöltés +betöltődik +betöm +betömés +betömődik +betömül +betör +betörés +betöréssorozat +betörik +betörő +betörülközik +betojik +betol +beton +betonágy +betonalj +betonbunker +betoncölöp +betonduzzanat +betonépület +betonfal +betonfolyosó +betongyűrű +betonhelyiség +betonhíd +betonjárda +betonkád +betonkerítés +betonkürtő +betonlap +betonlépcső +betonoldal +betonos +betonoszlop +betonoz +betonpadló +betonszoba +betontörmelék +betonút +betonudvar +betonutca +betonvályú +betoppan +betű +betűr +betűvetés +betűz +betudható +betuszkol +betyár +betyárbimbó +betyárbútor +betyárkodás +betyárvér +beúszik +beügyeskedik +beül +beüt +beütés +beüzen +beugrál +beugrat +beugratás +beugrik +beugró +beutal +beutalás +beutaló +beutalt +beutazik +bevág +bevágás +bevágódik +bevágtat +beválaszt +beválik +bevált +bevánszorog +bevár +bevásárlás +bevásárlókosár +bevásárol +bevagoníroz +bevagonírozás +bevagonoz +bevall +bevarr +bevégez +bevégeztetik +bevérez +bevétel +bevehetetlen +bever +bevesz +bevet +bevetés +bevezet +bevezetés +bevezető +bevezettet +beviharzik +bevilágít +bevillamosozik +bevisz +bevizel +bevon +bevonatú +bevonszol +bevontat +bevonul +bevonulás +bezár +bezárhatatlan +bezárkózik +bezárólag +bezárul +bezörget +bezsong +bezsúfol +bezúdul +bezuhan +bezupál +bezzeg +bíbelődik +bíbor +bíborköntös +bíboros +bíborosi +bíborpalást +bíborpalástos +bíborszegélyes +bíborszín +bíborvörös +bír +bírál +bírálat +bíráló +bíráskodás +bíró +bírói +bíróság +bírósági +bíz +bízik +bibi +bibircs +bibircsók +bibliai +biblikus +biccent +biccentés +biceg +bicegős +bicikli +bicikliabroncs +biciklikormány +biciklilánc +biciklipumpa +biciklista +biciklitúra +biciklizik +bicsaklik +bicska +bicskás +biggyedt +biggyeszt +bigyó +bika +bikaakol +bikaerős +bikahang +bikavér +bikini +bilgericsizma +biliárd +biliárdasztal +biliárdgolyó +bilincs +billeg +billeget +billen +billent +billenthető +billentyű +billió +bilux +bimbamoz +bimbó +bimbózik +bimm +biológia +biológiai +birizgál +birka +birkanyáj +birkózás +birkózik +birkózó +birodalmi +birodalom +birskörte +birtok +birtoklás +birtoklási +birtokol +birtokos +bisztró +bitang +bitófa +bitorló +bitorol +bivaly +bizánci +bizakodás +bizakodik +bizalmas +bizalmaskodás +bizalmasság +bizalmatlan +bizalmatlankodik +bizalmatlanság +bizalmi +bizalom +bizalomgerjesztő +bizalomkeltő +bizalomteremtés +bizarr +bizgat +bizományi +bizományos +bizonnyal +bizony +bizonyára +bizonygat +bizonyít +bizonyítás +bizonyíték +bizonyíthatatlan +bizonyítható +bizonyítvány +bizonyisten +bizonykodik +bizonylat +bizonyos +bizonyosan +bizonyosodik +bizonyosság +bizonyság +bizonyságkeresés +bizonytalan +bizonytalanság +bizonyul +bizottság +bizottsági +bizottságosdi +bizsereg +bizsergés +bizserget +bizsu +biztat +biztatás +biztató +biztonság +biztonsági +biztonságos +biztonságú +biztos +biztosan +biztosít +biztosítás +biztosíték +biztosító +biztosítószeg +biztosítótű +biztosítózár +blanketta +blaszfém +blaszfémia +blatt +blazírt +blende +blikkfangos +blöff +blöff-barokk +blöki +blokád +blokk +blokkol +blúz +bóbiskol +bódé +bódi +bódít +bódulat +bódult +bógnizik +bók +bóklászik +bókol +bókolgat +bólé +bólingat +bólint +bólintás +bólogat +bólogatás +bólongász +bólongat +bóna +bóra +bödön +bödöntúró +böffen +böfög +bögre +böhömnagy +böjt +böjtidő +bök +bökdös +bökkenő +bököd +bölcs +bölcsészdoktorátus +bölcsészkar +bölcsészkedik +bölcselem +bölcselet +bölcseleti +bölcselkedik +bölcsesség +bölcső +bölcsőde +bölcsőhely +bölény +bömböl +bömböltet +böngész +böngő +börtön +börtönbüntetés +börtönév +börtönőr +börtöntöltelék +bő +bőbeszédű +bőbeszédűség +bőg +bőgőbrummogásos +bőgőcsiga +bőgőmasina +bőkezű +bőkezűség +bőr +bőrbetegség +bőrbuborék +bőrdívány +bőrfarkas +bőrfotel +bőrgallér +bőrgalléros +bőrhajú +bőrkabát +bőrkabátos +bőrkeményedés +bőrkesztyű +bőrkötény +bőrlebeny +bőrmellény +bőrnadrág +bőrönd +bőrös +bőrruha +bőrsapka +bőrsaru +bőrszagú +bőrszék +bőrszíj +bőrszövet +bőrtárca +bőrtáska +bőrtalpú +bőrülés +bőrű +bőrzeke +bőrzekés +bőrzsák +bőrzubbony +bőség +bőséges +bőségszaru +bőszárú +bőszít +bőszoknyás +bőszült +bővérű +bővelkedik +bőven +bővít +bővítés +bővül +boci +bocsánat +bocsánatkérés +bocsánatkérő +bocsát +bocsátkozik +bocskor +bodor +bodorít +bodros +bodrozódik +bodza +bodzás +bodzabokor +bodzafa +bog +bogáncs +bogár +bogarászgat +bogarászik +bogarasság +boglya +bognár +bogrács +bográcsgulyás +bogyiszlói +bogyó +bohém +bohémség +bohóckodás +bohóckodik +bohócos +bohókás +bojnyik +bojtos +boka +bokázik +bokacsattogtatva +bokaösszerántás +bokaszíj +bokor +bokorhegyi +bokros-füves +bokrosodik +boksz +bokszer +bokszkesztyű +bokszol +bokszoló +bokszpáholy +boldog +boldog-boldogtalan +boldogít +boldogság +boldogtalan +boldogtalanság +boldogul +boldogulás +boldogult +bolgár +bolgárföld +bolgárkertész +bolha +bolhás +bolhaugrás +bolond +bolondéria +bolondforma +bolondgomba +bolondít +bolondokháza +bolondos +bolondozik +bolondság +bolondul +bolsevik +bolsevista +bolsiszag +bolt +boltajtó +bolti +boltív +boltos +boltosné +boltozat +boltozatos +boltozatú +boltsüveg +boltvezető +boly +bolygat +bolygó +bolyhos +bolyong +bolyongás +bomba +bombáz +bombázás +bombaköpeny +bombarepesz +bombarobbanás +bombatámadás +bombatalálat +bombaüzlet +bombazápor +bomlás +bomlik +bomlófélben +bonapartista +bonbonmeggy +bonc +boncmester +boncol +boncolás +boncolási +boncolgat +boncolgatás +boncolóorvos +bont +bontás +bontat +bontogat +bonyodalmas +bonyodalom +bonyolít +bonyolódik +bonyolult +bor +borbély +borbélymester +borbélyműhely +borbélysegéd +borbélyüzlet +borda +bordás +bordázat +bordacsont +bordatörés +bordély +bordélyház +bordó +bordói +bordóvörös +borít +boríték +borítékú +borító +borítólap +borítóvászon +borízű +borissza +borivó +borjú +borjúhús +borjúnyi +borjúpaprikás +borjúszegy +borkereskedő +borogat +borogatás +borong +borongás +borongós +boros +borosgazda +boroskorsó +borospalack +borosszakma +borosta +borostás +borostyán +borostyánlevél +borostyánszín +borostyánszínű +borosüveg +borotva +borotvál +borotválás +borotválkozás +borotválkozik +borotvapamacs +borotvapenge +borozás +borozgatás +borozik +borpince +borravaló +bors +borsószár +borszag +borszakértő +bortócsa +borús +borul +borulás +borulat +borult +borulta +borzad +borzadozik +borzalmas +borzalom +borzas +borzasztó +borzlyuk +borzol +borzolgat +borzong +borzongás +borzongat +borzsák +bosnyák +bosszankodás +bosszankodik +bosszant +bosszantó +bosszú +bosszúállás +bosszúálló +bosszús +bosszúság +bosszúvágy +bosszúvágyó +boszorka +boszorkány +boszorkányfű +boszorkányos +boszorkányság +bot +botanika +botanikus +botcsinálta +botlás +botladozik +botlik +botorkál +botoz +botránkozás +botrány +bozót +bozótos +bozontos +brancs +bratyizik +bravózik +bravúr +bravúros +brekeg +brennel +breviárium +bricsesznadrág +bridzsezik +bridzsrejtvény +brigád +brigádvezető +brigádvezetői +brigadéros +briliáns +briliánsgyűrű +brit +brokát +brokátfüggöny +brokátköntös +bronzfejedelem +bronzfigura +bronzszínű +bronztest +bronztestű +bronzvörös +bross +brosúra +brosúraszöveg +brr +brügecsi +brummog +brutális +bú +búb +búbánat +búbos +búbosdaru +búcsú +búcsúbeszélgetés +búcsújáró +búcsújelenet +búcsús +búcsúvacsora +búcsúzás +búcsúzik +búcsúzkodás +búcsúzkodik +búcsúzó +búcsúztat +búcsúztatás +búg +búgás +búj +búja-baja +bújik +bújócskaóra +bújtat +bújtatgat +bújtatott +búr +bús +búsképű +búskomor +búslakodik +búsul +bútor +bútorasztalos +bútordarab +bútorgyár +bútorkárpit +bútorozott +bútorú +bútorzat +bútorzatú +búvár +búvárszemüveg +búvóhely +búza +búzaillat +búzakalász +búzakék +búzaszál +búzatábla +búzavetés +búzavirág +büdös +büdösség +büfé +büféasztal +bükk +bükkfa +bükkönyféle +büntet +büntetés +büntetési +büntetett +büntetlen +büntető +büntetőbíróság +büntetőszázad +büntetőtábor +bürokrácia +bürokrata +büszke +büszkélkedik +büszkeség +bütykös +bütyök +bűbáj +bűbájos +bűn +bűnbánat +bűnbánó +bűnbeesés +bűnbeesik +bűncselekmény +bűnhődik +bűnjel +bűnlajstrom +bűnös +bűnösség +bűnözés +bűnözési +bűnöző +bűnper +bűnrészesség +bűnsegéd +bűntárs +bűntanya +bűntény +bűntelen +bűntett +bűntudat +bűntudatos +bűnügy +bűnügyi +bűnüldözési +bűnvádi +bűvésztányér +bűvöl +bűvölet +bűvös +bűz +bűzös +bűzpatak +buborék +budafoki +budai +budaörsi +budapesti +buddhista +budi +buga +buggyan +buggyos +bugris +bugyborékol +bugyborékolás +bugyelláris +bugyi +bugyibuli +bugyog +bugyolál +bugyor +bugyuta +buja +bujaság +bujdokol +bujdosás +bujdosik +bujdosó +bujkál +bujkálás +bukás +bukdácsol +bukfenc +bukfencezik +bukik +bukkan +bukórepülés +bukósisak +bukott +buksi +buksza +bukta +buktató +buli +bulizik +bulla +bulldózer +bulvár +bumm +bunda +bundás +bundabélés +bungaló +bunker +bunkó +bunkósodik +bura +burgonya +burgonyafúró +burjánzás +burjánzik +burkol +burkolat +burkolóanyag +burkolódzik +burkolt +burok +burran +bursi +burukkolás +burzsoá +busa +busás +busz +buszállomás +buszmegálló +buta +butáskodik +butaság +buton +butuska +buzdít +buzdítás +buzeráns +buzgár +buzgalom +buzgó +buzgólkodik +buzgóság +buzi +buzikölni +buzog +buzogány +buzogányos +c-kategóriájú +c-pavilon +cábár +cáfolat +cáfolhatatlan +cájgruha +cápa +cár +cári +cafat +cafka +cafrangos +cakk +cakkos +cammog +cappadóciai +cécó +cédrus +cédula +cég +cégér +cégéres +cégjelzés +cégtábla +cékla +céklaleves +cél +célegyenes +célfal +célfotó +célkitűzés +céllövölde +céllövöldés +céloz +célozgat +célpont +célravezető +célszerű +célszerűség +céltalan +céltudatos +célvonal +célzás +célzatos +cérna +cérnaember +cézár +cézárkodik +cefreszagú +cekker +cella +cellulóz +celofán +celsius-fokos +cement +cementgyár +cent +center +centi +centiméter +centiméternyi +centis +centralizálás +centralizált +centralizmus +centrifuga +centrum +ceremónia +ceremóniás +ceruza +ceruzavég +cetli +cetteg +cezaromániás +cezúra +cím +címbetű +címer +címeres +címernövény +címeroroszlán +címez +címlap +címnyilvántartó +címszerep +címszó +címtábla +című +címzés +címzett +cívis +ciánkáli +cibál +cibere +cica +cicomás +cidris +cifra +cifráz +cifranyomorúság-terv +cifraság +cifraszűr +cifraszűrös +cigány +cigányasszony +cigánybanda +cigányélet +cigányfekete +cigányfiú +cigánygyerek +cigányház +cigánykerék +cigánylány +cigánylegénység +cigánymuzsika +cigányos +cigányprímás +cigányvicc +cigányzab +cigányzene +cigaretta +cigarettásdoboz +cigarettázik +cigarettacsomag +cigarettafajta +cigarettafüst +cigarettagyújtás +cigarettapapír +cigarettatárca +cigarettavég +cigi +ciha +cikázás +cikázik +cikcakk +cikcakkos +cikk +cikkely +ciklámen +ciklámenzakó +cilinder +cilinderes +cimbalom +cimbalomhúr +cimbora +cimborál +cimpa +cimpácska +cincog +cingár +cinikus +cinizmus +cinkel +cinkos +cinkosi +cinkosság +cinkostárs +cipész +cipészmesterség +cipészüzlet +cipekedés +cipekedik +cipel +cipelmény +cipő +cipő-harisnya +cipőfazon +cipőfelsőrész-készítő +cipőfűző +cipőorr +cipőpertli +cipősarok +cipőszag +cipőtalp +cipruság +cipzár +cipzáras +ciráda +cirill +ciripel +cirkál +cirkáló +cirkusz +cirkuszi +cirkuszosló +cirmos +cirmoskodik +cirógat +cirógatás +cirokseprű +cirokvetés +cirom +ciszter +cisztercita +ciszterna +citátum +citera +citológia +citológus +citrom +citromarc +citromfa +citromlepke +citromos +civil +civilizáció +civilizálás +civilizálatlan +civilizált +civilruhás +civódás +civódás-öröm +cókmók +cölöp +cölöpvár +cövek +cövekel +coki +colos +comb +combközép +combtő +combú +compó +copf +copfos +csáberő +csábít +csábítás +csábító +csábos +csákány +csákigorbói +csámcsog +csámpás +csáp +csápol +csárda +csárdás +csárdaféle +császár +császárhús +császári +császári-királyi +császárkori +császárság +császkál +csabai +csacsi +csacsog +csacsogás +csahol +csahos +csaj +csajkarendszer +csak +csakhamar +csakhogy +csakis +csaknem +csakúgy +csakugyan +csal +család +családalapítás +családanya +családapa +családépítő +családfő +családi +családias +családnév +családos +családtag +csalános +csalánrengeteg +csalás +csalafintaság +csalétek +csalhatatlan +csalisíp +csallóközi +csaló +csalódás +csalódik +csalóka +csalogat +csap +csapágy +csapás +csapadék +csapat +csapattiszt +csapatvezető +csapda +csapdaállítás +csapdos +csapkod +csapkodás +csapláros +csapnivaló +csapóajtó +csapódik +csapodár +csapol +csapolt +csapong +csapos +csapott +csapszék +csaptelep +csapzott +csarnok +csarnokszerű +csat +csata +csatár +csatározás +csatározik +csatársor +csatabárd +csatakos +csatangol +csatangolás +csatasor +csatatárs +csatatér +csatlakozás +csatlakozik +csatlakozó +csatlós +csatol +csatorna +csatornamunkás +csatos +csattan +csattanás +csattanó +csattanós +csattant +csattog +csattogás +csattogtat +csavar +csavarás +csavargás +csavargat +csavargó +csavarhúzó +csavarmenet +csavaró +csavarodik +csavarog +csavaros +csavart +csavarvonal +csépel +cséplés +cséplőgép +csésze +csévél +csecsefia +csecsemő +csecsemőarcú +csecsszopó +cseh +csehszlovák +csekély +csekélyke +csekélység +csekk +csekkfüzet +csel +cseléd +cselédeskedik +cselédfiú +cselédház +cselédházi +cselédlány +cselédlépcső +cselédszoba +cselekedet +cselekedik +cselekmény +cselekvés +cselekvőkészség +cselekvőleges +cseles +cselgáncsozik +cselleng +cselszövés +cselszövő +csemege +csemegeáru +csemegeáruház +csemegebolt +csemegekukorica +csemete +csempe +csempész +csempészügy +csempézett +csempefal +csempekád +csen-csen-gyűrű +csend +csendbiztos +csendes +csendes-álmos +csendes-óceáni +csendesít +csendeske +csendesség +csendfoszlány +csendkamra +csendkamrabeli +csendőr +csendőrcsapat +csendőrfőhadnagy +csendőrjárőr +csendőrkéz +csendőrkerület +csendőrlaktanya +csendőrnyomozó +csendőrőrs +csendőrparancsnokság +csendőrség +csendőrségi +csendőrtiszt +csendőrtiszti +csendül +csendülés +csenevész +cseng +cseng-bong +csengésű +csenget +csengetés +csengettyű +csengő +csengőgomb +csengőszó +csepeg +csepeg-csurran +csepegés +csepegő +csepegtet +cseperedik +csepereg +csepeszke +csepp +cseppen +cseppfolyós +cseppfolyósít +cseppnyi +csepű +cser +cserbenhagy +csere +cserél +cserélget +cserélődik +cseréltet +cserép +cserépkályha +cserépkalapos +cseréptál +cserépváza +cserebogár +csereforgalom +cseregyerek +cserepes +cseresznye +cseresznyés +cseresznyemag +cseresznyeszem +cseresznyeszemű +csereüzlet +cserfa +cserge +cserje +cserkészcsapat +cserkészik +cserkészpacifizmus +cserreg +csertölgy +cserzett +csetepaté +csetresz +csetten +csettenés +csettint +cseveg +csevegés +csík +csíkos +csíkoz +csín +csíny +csínytevő +csíp +csípő +csípőméret +csípőolló +csípős +csíra +csíz +csízió +csibe +csibész +csibészes +csibukol +csicsereg +csicskás +csiga +csigás +csigáz +csigázás +csigacsinálni +csigaház +csigalassúság +csigalépcső +csigavonal +csigolya +csihorít +csikar +csikk +csiklandós +csiklandoz +csiklandozás +csikó +csikordul +csikorgás +csikorgat +csikorgatás +csikorgó +csikorog +csilingel +csillám +csillámlik +csillár +csillag +csillagász +csillagászat +csillagászati +csillagászattan +csillagbolygó +csillagfény +csillagfényes +csillagkép +csillaglakó +csillagos +csillagpaszuly +csillagrendszer +csillagszóró +csillagtalan +csillagvizsgáló +csillagzat +csillan +csillapít +csillapítgat +csillapító +csillapítószer +csillapodás +csillapodik +csillapul +csille +csillés +csilléz +csilli-villi +csillog +csillog-ragyog +csillogás +csillogású +csillogó +csillogtat +csimbókos +csimpaszkodik +csimpolyaszó +csinál +csináló +csináltat +csingilingi +csinnadratta +csinos +csinosítás +csinosodik +csinosság +csip-csup +csipeget +csiperkegomba +csipet +csipke +csipkés +csipkebogyó +csipked +csipkefodor +csipkefodros +csipkefüggöny +csipkegallér +csipkekendő +csipkeruha +csipketerítő +csipog +csippent +csiribí-csiribá +csirke +csirkebél +csirkecomb +csirkefogó +csirkehús +csirkeláb +csirkemetszés +csirkeölés +csirkepaprikás +csirkepörkölt +csirkepusztító +csiszol +csiszolgat +csiszolódás +csiszolódik +csiszolt +csitít +csitítgat +csitri +csitt +csitul +csivitel +csivitelés +csizma +csizmás +csizmadiamester +csizmadiaszín +csizmanadrág +csizmapatkó +csizmasarok +csizmaszár +csók +csóka +csókol +csókolgat +csókolódzik +csókolózás +csókolodzik +csónak +csónakázás +csónakázgat +csónakázik +csónakázópark +csónakház +csónakkirándulás +csónakmester +csónakos +csórás +csóró +csótány +csóva +csóvál +csökevény-eretnek +csökken +csökkenés +csökkent +csökönyös +csömör +csörgés +csörgedezik +csörget +csörgősipka +csörgőzik +csörlő +csörög +csörömpöl +csörömpölés +csörren +csörrenés +csörtet +csöves +csövez +csövezés +cső +csőbútor +csőcselék +csőd +csődarab +csődör +csődület +csőhálózat +csőkorlát +csőposta +csőr +csőrű +csőstül +csősz +csőszerelés +csőszkalap +csobban +csobbanás +csobog +csobogás +csoda +csodál +csodálat +csodálatos +csodálkozás +csodálkozik +csodálkoznivaló +csodás +csodabunker +csodafegyver +csodakávé +csodaló +csodamód +csodanász +csodaparaszt +csodaragasztó +csodaszép +csodaszer +csodatétel +csodatevő +csodatükör +csodavárás +csodaváró +csoki +csokoládé +csokoládébarna +csokoládéfolt +csokoládémáz +csokoládémaradvány +csokoládés +csokor +csokornyakkendő +csokornyakkendős +csomag +csomagol +csomagolás +csomagolópapír +csomagolópapiros +csomagtartó +csombolygat +csomó +csomós +csomósodik +csomóz +csongrádi +csonk +csonka +csonkít +csont +csont-maradék +csontfaragás +csontgombos +csontkemény +csontkocka +csontkoponyájú +csontos +csontosodik +csontpart +csontrepedés +csontsejt +csonttuberkulózis +csontú +csontváz +csoport +csoportfőnök +csoportkép +csoportos +csoportosítás +csoportosul +csoportvezető +csorba +csorda +csordakiverés +csordanyomás +csordogál +csordul +csordultig +csorgás +csorgat +csorog +csosszan +csoszog +csoszogás +csúcs +csúcsértekezlet +csúcsforgalom +csúcsíves +csúcsos +csúcsszerv +csúf +csúfol +csúfolódik +csúfondáros +csúfság +csúnya +csúnyácska +csúnyaság +csúnyuska +csúszik +csúszkál +csúszkálás +csúszós +csúsztat +csücsök +csücsörít +csücsül +csügged +csüggedés +csüggedt +csüggeszt +csülök +csüng +csüngős +csütörtök +csűr +csuha +csuhaj +csuk +csuka +csuklik +csukló +csuklóharc +csuklya +csuklyás +csukódik +csukogat +csukott +csula +csupa +csupa-csipa +csupa-csupa +csupán +csupasz +csupor +csuromvizes +csusszan +csuszamlós +csutak +csutkakóró +csutkakúp +cucc +cudar +cukor +cukorfokmérő +cukorgyári +cukorpor +cukrász +cukrászda +cukrászdás +cukrászdázik +cukrászsütemény +cupfol +cuppan +cuppanós +cuppant +cuppog +cvikker +cvikli +dákó +dália +dáma +dámvad +dámvadcsapat +dárda +dáridó +dátum +dac +dacol +dacos +dada +dadog +dadogó +dafkeség +dagály +dagad +dagadás +dagadó +dagadós +dagadt +daganat +dagaszt +dal +dalia +daliás +dallam +dallamfoszlány +dallamos +dallamtörmelék +dalmatanémet +dalol +dalolgat +dalos +damasztabrosz +dara +darál +darálás +darázs +darázsderék +darázsfészek +darab +darabka +daraboló +darabos +darabosság +daru +darutollas +datolyapálma +de +dédanya +dédapa +dédelget +dédelgetés +dédelgetett +dédkolomp +dédmama +dédszülő +dédunoka +dél +dél-ázsiai +dél-amerikai +dél-dunántúli +dél-somogyi +délceg +déldunántúli +délelőtt +délelőtti +délelőttös +délfelé +déli +délidő +délies +déligyümölcs +déligyümölcs-kereskedés +délkelet +délnyugat +déltájban +délután +délutáni +délutános +délvidéki +démon +dér +dévér +dézsa +dézsi-féle +deákember +debella +debreceni +debrői +december +decemberi +deci +decsi +dedós +defenzív +deficit-elvtárs +definíció +definiál +deformálódik +degesz +degradál +dehogy +dehogyis +dehogyisnem +dehogynem +deka +dekácska +dekád +dekás +dekadens +dekompenzál +dekoráció +dekorátor +delegáció +delfin +delíriumos +delta +demagnetizál +demagóg +demizson +demokrácia +demokrata +demokratikus +demokratizmus +demonstráció +demoralizál +depós +deportált +depressziós +derék +derékalj +derékaljhuzat +derékbőség +derékfájás +derékmájer +derékmagas +deréknyílás +derékszíj +derékszög +deréktáj +derekas +derekegyházi +derelye +dereng +derengés +deres +dermed +dermedt +dermedtség +dermesztő +derogál +derül +derülátó +derült +derültség +derű +derűlátás +derűs +dervis +destrukció +deszka +deszkájú +deszkás +deszkaajtó +deszkaalkotmány +deszkabódé +deszkadarab +deszkafal +deszkakabin +deszkakapu +deszkakerítés +deszkakikötő +deszkakoporsó +deszkamennyezet +deszkapalánk +deszkapalló +deszkapolc +desztillál +detektív +devalvál +devalválódás +deviáns +díj +díjaz +díjazás +díjbeszedő +díjmérkőzés +dísz +díszasztal +díszbokor +díszcserje +díszegyenruha +díszeleg +díszes +díszfüggő +díszít +díszítés +díszjel +díszkiadás +díszlet +díszlettervező +díszlik +díszlövedék +dísznövény +dísznő +díszoklevél +díszpáholy +díszpárna +díszsírhely +díszszemle +dísztelen +dísztök +díszű +dívány +dívik +diák +diákcsemege +diákélet +diákév +diákflört +diákkor +diákkori +diáklány +diákos +diákszálló +diáktárs +diákviselet +diadal +diadalmas +diadalmaskodik +diadalmenet +diadalordítás +diadalüvöltés +diadém +diagnózis +diagram +dialektika +dialektikus +dialógus +dianásüveg +diavetítő +dicsér +dicséret +dicséretes +dicsérget +dicsekedik +dicsekvés +dicsekvő +dicső +dicsőség +dicsőségvágy +didereg +didergés +diderget +diéta +diétás +diétázik +digitálisz +digó +dikó +diktál +diktálás +diktátor +diktatórium +diktatúra +dilemma +dilettáns +dilettantizmus +dili +diliflepni +dilis +dimenzió +dinamikus +dinamit +dinamizmus +dinasztia +dinnye +dinnyézik +dinnyeföld +dinnyehalom +dinnyeportás +dinnyeszagú +dió +dióbarna +diódaráló +diófa +dióhéj-cirkáló +diólikőr +diós +dióverő +diploma +diplomácia +diplomáciai +diplomás +diplomázik +diplomakoncert +diplomata +diplomatikus +diplomavizsga +direkt +direktíva +direktor +direktorné +diri +dirigál +diskurál +diskurálás +disputa +disputál +disszertáció +disszidál +disszidálás +disszidens +diszharmónia +diszkontinuitás +diszkoszvetés +diszkréció +diszkrét +disznó +disznóbőr +disznófülű +disznóhajtás +disznóhúsillat +disznóól +disznóölés +disznóölő +disznóság +disznószag +disznótoros +disznóvályú +disznóvese +disznózsír +diszpécsernő +diszpozíció +disztinkció +divat +divatárubolt +divatbábu +divatjamúlt +divatlap +divatművészet +divatos +divattervező +dizőz +döbbenet +döbbenetes +döbbent +döccen +döccenés +döcög +döcögés +döf +döfés +dög +dögcédula +dögész +döghalál +döghús +dögivel +dögkeselyű +dögletes +döglik +döglött +dögönyöz +dömés +dömper +döndül +döng +dönget +döngöl +döngölt +dönög +dönt +döntés +döntetlen +döntő +dörgés +dörgöl +dörgölődzik +dörgő +dörmög +dörög +dörömböl +dörömbölés +dörren +dörrenés +dörzsöl +dörzsölget +dörzsölt +dörzspapír +dől +dob +dobál +dobálgat +dobálódzik +dobálózás +dobás +dobaj +dobban +dobbanás +dobbant +doberdói +dobhártya +dobkályha +dobkályhácska +dobókocka +dobog +dobogás +dobogó +dobol +dobos +doboz +dobozgyár +dobtáras +dodonai +dogma +dogmatikus +dohány +dohányfüst +dohánygyári +dohánymorzsalék +dohányosdoboz +dohánypakli +dohányszálacska +dohányszagú +dohányzás +dohányzik +dohányzó +dohányzóasztal +dohányzógarnitúra +dohog +dohogás +dohos +dohszagú +doki +dokkmunkás +doktor +doktori +doktorné +doktornő +doktriner +dokumentáció +dokumentál +dokumentum +dokumentumfilm +dolgos +dolgozás +dolgozat +dolgozik +dolgozó +dolgozószoba +dolgoztat +dollár +dollárcsekk +dollárforrás +dolmányos +dolog +dologidő +dologtalan +dologtalanság +domb +dombhát +dombocska +domboldal +dombormű +domborodik +domború +domborzati +domborzatos +dombos +dombosodik +dombtető +dombvonulat +domínium +dominál +domináns +dominó +dominózik +donátor +dongás +dongakút +donjános +donor +dorbézol +dorogi +dorong +dorongfa +dorozsmai +dosszié +doszt +drága +drágáll +drágakő +drágalátos +drágasági +dráma +drámázik +drámai +drámaíró +drávafai +drabális +dragon +dragony +dragonyos +dramatizál +dramaturg +dramaturgiai +drapéria +drapp +drazsé +dressz +drezdai +drót +drót-élet +drótháló +dróthaj +dróthajú +drótkeretes +drótkeretű +drótkerítés +drótkötél +drótos +drótoz +drótsövény +drótszál +drugány +drukker +drukkol +dúdol +dúdolás +dúdolgat +dúl +dúltság +dúr +dús +dúsgazdag +dúsul +dúvad +dübörgés +dübörög +düh +dühhörrenés +dühít +dühítő +dühkitörés +dühödt +dühöng +dühöngés +dühöngő +dühös +düledezik +dülled +dülledt +dülöng +dülöngél +dünnyög +dünnyögés +dűlő +dűlőnév +dűlőút +dublé +duda +dudál +dudálás +dudorászás +dudorászik +dudos +dug +dugdos +dughely +dugig +dugó +dugóhúzó +duhaj +dukál +dukát +dukkó +dulakodás +dulakodik +duma +dumál +duna-kavics +duna-parti +duna-víz +dunántúli +dunai +dunaújvárosi +dundi +dunszt +dunsztosüveg +dunyha +dupla +duplácska +duplatárcsa +duránci +durcás +durcáskodik +durchmars +durr +durran +durranás +durrog +duruzsol +duruzsolás +durva +durváskodik +duzzad +duzzadt +duzzadtság +duzzanat +duzzaszt +duzzasztógát +duzzog +duzzogás +dzsem +dzsungel +e +e-hang +eb +ebéd +ebédel +ebédhordó +ebédidő +ebédjegy +ebédlő +ebédlőasztal +ebédlőkredenc +ebédlőszekrény +ebédlőterítő +ebédosztás +ebédvivés +ebebe +ebrúd +ecet +ecetes +ecetfa +ecset +ecsetel +eddig +eddigi +edény +edénybolt +edénycsörömpölés +edényrajzoló +edz +edzés +edzési +edzett +edző +edzősködik +efelől +effajta +efféle +egér +egérfogó +egérürülék +egész +egészen +egésznapos +egészség +egészséges +egészségház +egészségi +egészségtelen +egészségügyi +egerészőjáték +egetlen +egoizmus +egres +egri +egy +egy-egy +egy-füles +egy-két +egy-kettő +egy-más +egy-másfél +egyáltalában +egyáltalán +egyaránt +egyarcú +egyazon +egybeáll +egybeesik +egybefényképez +egybefolyik +egybegyűlik +egybekapcsol +egybekelés +egybekeveredik +egybemosódik +egyben +egybenő +egybeönt +egybeolvad +egybesötétít +egybeszámol +egybeszikrázik +egybetart +egybetekeredik +egybevet +egyből +egyéb +egyébként +egyén +egyéni +egyéniség +egyéniségű +egyértelmű +egyéves +egyed +egyedi +egyedül +egyedülálló +egyedüli +egyedüllét +egyeduralom +egyelőre +egyemeletes +egyenértékű +egyenes +egyenesen +egyenest +egyenetlen +egyenetlenség +egyenget +egyengetés +egyenjogúság +egyenként +egyenletes +egyenlít +egyenlítő +egyenlítői +egyenlő +egyenlőségjel +egyenrangú +egyenruha +egyenruhás +egyenruhásít +egyensapka +egyensúly +egyensúlyoz +egyes +egyes-egyedül +egyesít +egyesítés +egyesül +egyesülés +egyesület +egyesült +egyesztendős +egyetért +egyetértés +egyetem +egyetemben +egyetemesség +egyetemi +egyetemista +egyetemleges +egyetlen +egyetlenegy +egyetlenke +egyetlenség +egyezik +egyezkedik +egyezség +egyeztet +egyeztető +egyfajta +egyféle +egyfelé +egyfolytában +egyforma +egyformaság +egyház +egyházfi +egyházhatósági +egyházi +egyházmegye +egyhamar +egyhangú +egyhangúság +egyharmad +egyhatvan +egyhavi +egyhetes +egyheti +egyhónapi +egyhónapos +egyhuzamban +egyidejű +egyidős +egyik +egyik-másik +egyikfajta +egyiptológus +egyiptomi +egyke +egykedvű +egykeség +egykettőre +egykilós +egykönnyen +egykor +egykori +egykorú +egylet +egylovas +egymás +egymásgyötrés +egymásrautaltság +egymásután +egymaga +egymilliárd +egymillió +egynapi +egynapos +egynéhány +egynémely +egynegyed +egyórás +egyöntetű +egyötven +egyoldalas +egyoldalú +egyoldalúság +egypár +egyre +egyre-másra +egyrészes +egyrészt +egység +egységes +egységfront +egyszemélyes +egyszer +egyszer-egyszer +egyszer-kétszer +egyszeri +egyszeriben +egyszerre +egyszersmind +egyszerű +egyszerűen +egyszerűség +egyszerűsít +egyszerűsítés +egyszínű +egyszólamú +egyszóval +egyszoba-hallos +egyszobás +egyszülött +egyúttal +együgyű +együgyűség +együtt +együttélés +együttérzés +együttérző +együttes +együttlélegzés +együttlét +együttműködés +együttműködik +együttrezgés +együttvéve +együvé +egyujjnyi +egyutcás +egyvalaki +egyvalami +egyvégből +egyvér +egzakt +egzisztál +egzisztencia +egzotikus +eh +ehelyett +ehető +ej +ejde +ejej +ejha +ejnye +ejt +ejtőernyő +ejtőernyős +ejtőzik +eke +ekekapa +ekevas +ekképpen +ekkor +ekkora +ekkori +ekkoriban +eközben +eksztázis +el +el-elakad +el-elcsíp +el-elgyönyörködik +el-elhalkul +el-eltakar +elábrándozik +elácsorog +elágazás +elágazik +elájul +eláld +eláll +elálldogál +elálmosít +elálmosodik +elámul +eláraszt +elárul +elárulás +elárusító +elárusítónő +elárvul +elás +elátkozott +elázik +eláztat +elad +eladás +eladdig +eladó +eladódik +eladományoz +elaggott +elakad +elalél +elaljasodik +elalszik +elalvás +elandalít +elapad +elavult +elbágyad +elbámészkodik +elbámul +elbánik +elbazilikáz +elbeszél +elbeszélés +elbeszélget +elbír +elbíz +elbiceg +elbiciklizik +elbiggyeszt +elbizonytalankodik +elbizonytalanodás +elbizonytalanodik +elbóbiskol +elbódorog +elbődül +elbőg +elbocsát +elbocsátó +elbolondít +elbolondozik +elbont +elborít +elborul +elbotlik +elbotorkál +elbúcsúzik +elbúcsúztat +elbújik +elbújtat +elbűvöl +elbűvölő +elbujdosik +elbukás +elbukik +elbutul +elcaflat +elcsábít +elcsalás +elcsatol +elcsattan +elcsavar +elcsavarog +elcsépelt +elcsen +elcsendesedik +elcsendesít +elcsendesül +elcsendesülés +elcseppen +elcserél +elcsesz +elcseveg +elcsíp +elcsigázott +elcsirkefogósodik +elcsitít +elcsitul +elcsónakázik +elcsór +elcsörömpöl +elcsörtet +elcsodálkozik +elcsúfít +elcsúszik +elcsúszkál +elcsuklik +eldajkál +eldarál +eldicsekedik +eldiskurál +eldöcög +eldönget +eldönt +eldöntés +eldörgöl +eldörren +eldől +eldob +eldohog +eldübörög +eldug +eldugdos +eldugít +eldugul +eldurvul +elé +elébe +elég +elégedetlen +elégedetlenkedik +elégedetlenség +elégedett +elégedettség +eléget +elégetés +eléggé +elégia +elégséges +elégtétel +elégtelen +elégtelenség +elégült +eléje +eléktelenít +elél +elénekel +elér +elérés +elérhetetlen +elérhető +elérkezik +elért +elérzékenyedik +elérzékenyül +elérzékenyülés +elévült +eledel +elefánt +elefántcsont +elefántcsonttorony +elegáns +elegancia +elegendő +elegyedik +elegyenget +elegyít +elei +eleinte +eleje +eleji +elejt +elejtés +elejtett +elejtő +elejtődik +elektrifikáló +elektróda +elektrokardiogram +elektromérnök +elektromos +elektromosság +elektronikus +elektrotechnikai +elem +elemészt +elemez +elemezhető +elemi +elemista +elemózsia +elemzés +elenged +elengedhetetlen +elenyészik +elenyésző +eleped +elered +elereszt +elernyed +elernyedés +elernyeszt +eleség +elesett +elesettség +elesik +eleste +eleszik +eleve +eleven +elevenség +elfárad +elfáradás +elfásul +elfagy +elfakul +elfal +elfér +elfészkelődik +elfecsérel +elfed +elfehéredik +elfekszik +elfeled +elfeledkezik +elfeledtet +elfelejt +elfelejtkezik +elferdít +elferdül +elfintorít +elfintorodik +elföldel +elföldelés +elfocizik +elfog +elfogás +elfogad +elfogadás +elfogadhatatlan +elfogadható +elfogatás +elfogatási +elfoglal +elfoglalatoskodik +elfoglalt +elfoglaltság +elfogódott +elfogódottság +elfogulatlan +elfogult +elfogultság +elfogy +elfogyaszt +elfogyasztás +elfojt +elfojthatatlan +elfolyik +elfonnyad +elfordít +elfordul +elforgat +elfoszlik +elfúj +elfúl +elfüggönyöz +elfüstölög +elfütyül +elfűrészel +elfullad +elfut +elgáncsol +elgázol +elgazdálkodik +elgémberedik +elgörbít +elgondol +elgondolás +elgondolható +elgondolkodik +elgondolkodtató +elgondolkozik +elgondolkoztat +elgondolkoztató +elgurul +elgyávul +elgyalogol +elgyengül +elgyengülés +elgyökerezik +elgyönyörködik +elgyötört +elhány +elhárít +elhárítás +elhárító +elhadar +elhagy +elhagyás +elhagyatott +elhagyott +elhajít +elhajigál +elhajlás +elhajol +elhajszol +elhajt +elhajtogat +elhal +elhalálozás +elhalálozik +elhalás +elhalászik +elhalad +elhalaszt +elhalkul +elhallatszik +elhallgat +elhallgatás +elhallgattat +elhalmoz +elhalványít +elhalványodik +elhalványul +elhamarkodik +elhamarkodott +elhamarkodottság +elhamvad +elhangzik +elhanyagol +elhanyagolható +elhanyagolt +elhanyagoltság +elhanyatlik +elharangoz +elharap +elharapódzás +elharapódzik +elhasít +elhasznál +elhatároz +elhatározás +elhatalmasodik +elhatol +elhazudik +elhelyez +elhelyezés +elhelyezkedés +elhelyezkedik +elhemperedik +elhengerítés +elherdál +elhervad +elhesseget +elhessent +elheveredik +elhív +elhízik +elhibáz +elhidegedik +elhidegül +elhihető +elhisz +elhiszterizál +elhitet +elhivatalnokoskodás +elhódít +elhömpölyög +elhomályosít +elhomályosodik +elhomályosul +elhord +elhoz +elhúz +elhúzat +elhúzódik +elhülyül +elhülyülés +elhűl +elhull +elhuny +elhurcol +elígérkezik +elítél +elítélt +elíziumi +elidegenedik +elidegenít +elidőzik +eligazít +eligazítás +eligazító +eligazodik +elillan +elindít +elindítás +elindul +elindulás +elintéz +elintéznivaló +elintéződik +elirányít +eliramodik +elismétel +elismer +elismerés +elismerő +elismert +eliszaposodik +eliszik +eliszkol +elit +elixír +eljár +eljárás +eljátszik +eljegyzés +eljön +eljövendő +eljövet +eljövetel +eljut +eljuttat +elkábít +elkábul +elkámpicsorodik +elkápráztat +elkáromkodik +elkalandozik +elkallódik +elkanyarodik +elkap +elkapat +elkapkodás +elkattan +elkékül +elkényelmesedik +elkényeztet +elkényeztetettség +elképed +elképedés +elképeszt +elképesztő +elképzel +elképzelés +elképzelhetetlen +elképzelhető +elkér +elkéseget +elkésik +elkészít +elkészítés +elkészítő +elkészül +elkedvetlenedik +elkedvetlenít +elkel +elkerékpározik +elkerekedik +elkerekezik +elkerget +elkerít +elkerül +elkerülés +elkerülhetetlen +elkerültet +elkeseredés +elkeseredett +elkeseredik +elkeserít +elkeskenyedik +elkeskenyül +elkezd +elkezdés +elkezdődik +elkígyózik +elkínzott +elkísér +elkíváncsiskodik +elkiált +elkiabál +elkókad +elkószál +elkótyavetyél +elködösül +elköltözik +elköltöztet +elkönyvel +elköszön +elkötelez +elkövet +elkövetés +elkövetkezik +elkövetkező +elkoboz +elkobozhatatlan +elkobzás +elkomolyodik +elkomorodik +elkomorul +elkonspirál +elkopik +elkoptat +elkorcsosul +elkorhad +elkormányoz +elkotyog +elkozmál +elkúszik +elküld +elküldés +elkülönít +elkülönítés +elkülönül +elkunyerál +elkuszál +ellágyít +ellágyul +ellát +ellátás +ellátogat +ellabdázgat +ellakik +ellankadás +ellanyhul +ellapátol +ellavíroz +ellazul +ellép +ellebben +ellen +ellenáll +ellenállás +ellenállási +ellenállhatatlan +ellenálló +ellenállóképesség +ellenakció +ellenautó +ellenben +ellene +ellenébe +ellenében +ellenére +ellenérv +ellenez +ellenfél +ellenforradalmár +ellenforradalmi +ellenforradalom +elleni +ellenkezés +ellenkezik +ellenkező +ellenkezőleg +ellenőr +ellenőriz +ellenőrzés +ellenőrzés-igazoltatás +ellenőrző +ellenpólus +ellenpropaganda +ellenség +ellenséges +ellenségeskedik +ellensúlyoz +ellenszenv +ellenszenves +ellenszolgáltatás +ellentét +ellentétes +ellentmond +ellentmondás +ellentmondásos +ellentmondásosság +ellenvélemény +ellenvet +ellenvetés +ellenzék +ellenzéki +ellenzés +ellenző +ellep +elles +ellhallgat +ellik +ellipszis +ellóg +ellök +ellötyög +ellop +ellustul +elmázol +elmázolódik +elmacskásodik +elmagyaráz +elmajszol +elmar +elmarad +elmaradhatatlan +elmaradott +elmaradottság +elmaradozik +elmarasztal +elmarasztalás +elme +elméjű +elméláz +elmélázás +elmélet +elméleti +elmélkedés +elmélkedik +elmélyül +elmélyült +elmélyültség +elmérgesedik +elmés +elméskedik +elmésség +elmebaj +elmebeteg +elmegy +elmegyógyintézet +elmenekül +elmenő +elmente +elmereng +elmerül +elmerülés +elmesél +elmeséltet +elmetsz +elmezavar +elmismásol +elmocsarasodik +elmond +elmondat +elmondott +elmorzsol +elmos +elmosódik +elmosogat +elmosolyint +elmosolyodik +elmosolyog +elmozdít +elmozdítás +elmozdíthatatlan +elmozdítható +elmozdul +elmúlás +elmúlik +elmúlt +elmúlta +elmulaszt +elmulat +elmutat +elnémít +elnémul +elnéptelenedik +elnéz +elnézés +elnézeget +elnéző +elnehezedik +elnehezül +elnevet +elnevez +elnevezés +elnevezésű +elnök +elnökasszony +elnökhelyettes +elnöki +elnökminiszter +elnökné +elnökség +elnöktárs +elnyargal +elnyel +elnyer +elnyerés +elnyom +elnyomás +elnyomatás +elnyomó +elnyomott +elnyújt +elnyújtózik +elnyúlik +elnyű +elnyűtt +elnyűvődik +elóvakodik +elöljáró +elöljáróban +elöljárói +elöljáróné +elöljáróság +elömlik +elönt +elözönöl +elözvegyül +elő +előáll +előállít +előad +előadás +előadássorozat +előadó +előadódik +előadói +előadóterem +előbb +előbb-utóbb +előbbi +előbújik +előbuggyan +előbukkan +előcibál +előcsal +előcsapat +előcsarnok +előcsúszik +előd +elődug +előéletű +előérzet +előétel-hal +előeste +előfittyent +előfordul +előfut +előgördül +előgőzölés +előhajladozik +előhalászik +előhírnök +előhívás +előhívódik +előhoz +előhozakodik +előhúz +előír +előírás +előírásos +előírt +előítélet +előidéz +előidézés +előidéző +előimádkozó +előirányoz +előjegyzési +előjel +előjön +előjog +előkap +előkapar +előkészít +előkészítés +előkészítő +előkészül +előkészület +előkelő +előkelőség +előkeres +előkerít +előkerítés +előkerül +előkerülés +előkeveredik +előkotor +előkrémez +elől +előle +előlép +előléptet +előleg +előlegez +előlibeg +előmászik +előmenetel +előmunkálat +előnevelés +előny +előnyös +előnytelen +előnyújtózik +előnyúl +előőrs +előpark +előrángat +előránt +előrajzik +előre +előre-hátra +előreáll +előrebiggyed +előrebocsát +előrebocsátás +előrebukik +előrecsapódik +előrecsoszog +előredöf +előredől +előredobban +előreduzzad +előreejt +előreenged +előrefeszít +előrefut +előregörnyed +előrehajol +előrehajt +előrehalad +előrehaladás +előrehömpölyög +előrehullik +előreindul +előrejön +előrejut +előrekarajlik +előreküld +előrelátás +előrelátható +előreláthatólag +előrelátó +előrelép +előrelök +előrelopózik +előremászik +előremegy +előremered +előrenéz +előrenyomakodik +előrenyomul +előrenyomulás +előrenyújt +előrenyúl +előrerohan +előresiet +előreszalad +előreszól +előretart +előretör +előretörekszik +előreugrik +előrevet +előrevisz +előrohan +előrukkol +elősegít +előszed +előszivárog +először +előszoba +előszobázó +előszobaajtó +előszobaasztal +előszobaszék +előtár +előtér +előtétlencse +előteremt +előteremtés +előterjeszt +előterjesztés +előtör +előtotyog +előtt +előtte +előtti +előtűnik +elővágás +elővéd +elővesz +elővezet +elővigyázatos +elővigyázatosság +elővigyorog +elővillan +előzékeny +előzékenység +előzetes +előzmény +előző +előzőleg +eloldalog +elolt +elolvad +elolvas +elolvasás +elolvastat +elomlik +elordít +eloroz +eloszlat +eloszlik +eloszt +elosztó +elosztófej +elpárolog +elpártol +elpásztorol +elpanaszol +elpatkol +elpattan +elpattant +elpazarol +elpepecsel +elpilled +elpirul +elpiszkál +elpityeredik +elpocsékol +elpofoz +elposhad +elpüföltet +elpucol +elpuhult +elpusztít +elpusztítás +elpusztíthatatlan +elpusztul +elrágódik +elrángat +elránt +elrabol +elragad +elragadó +elragadtat +elragadtatás +elragadtatott +elrak +elrakodik +elraktároz +elrémül +elrebben +elrebbent +elrejt +elrejtőzik +elrejtőzködik +elreked +elrendel +elrendeltség +elrendez +elrendezés +elrendezettség +elrendeződés +elrendeződik +elrepül +elrestell +elrettentő +elriad +elriaszt +elrikkant +elringat +elröhög +elröppen +elrobog +elrohad +elrohan +elromlik +elront +elrozsdásul +elrúg +elsáncol +elsápad +elsárgul +elsajátít +elsavanyodik +elsétál +elseje +elsejei +elsír +elsiet +elsikkaszt +elsiklik +elsikolt +elsimít +elsirat +elsöpör +elsötétedik +elsötétít +elsötétítő +elsötétül +első +elsőbb +elsőbben +elsőbbség +elsődleges +elsőéves +elsőhetes +elsőrendű +elsőség +elsősegély +elsősorban +elsőszülött +elsőszülöttség +elsodor +elsokall +elsorol +elsorvasztás +elspórol +elsüllyed +elsüllyeszt +elsüt +elsüvít +elsuhan +elsurran +elsuttog +elszáguld +elszáll +elszállásol +elszállít +elszállítás +elszállítható +elszámol +elszámolás +elszán +elszánás +elszánt +elszántság +elszab +elszabadít +elszabadul +elszabotál +elszakad +elszakadás +elszakadási +elszakít +elszalad +elszalajt +elszalaszt +elszaporodik +elszaval +elszédít +elszédül +elszégyell +elszéled +elszed +elszegényedik +elszegődik +elszellent +elszenderedik +elszennyesedik +elszenved +elszeret +elszíneződik +elszíntelenedik +elszív +elszívás +elszigetel +elszigetelt +elszivárog +elszól +elszólít +elszór +elszórakozik +elszórt +elszótlanodik +elszökik +elszörnyedés +elszokik +elszomorít +elszomorodik +elszopogat +elszorul +elszúr +elszürkít +elszürkül +elszunnyad +elszunyókál +eltáncol +eltántorít +eltát +eltávolít +eltávolítás +eltávolíttat +eltávolodás +eltávolodik +eltávozás +eltávozik +eltagadtat +eltakar +eltakarít +eltalál +eltanácsol +eltanul +eltapos +eltart +eltartás +eltékozol +elténfereg +eltép +eltér +eltérés +eltérít +eltérő +eltéved +eltévedez +eltéveszt +eltekint +eltelik +eltelte +eltemet +eltemetés +eltemettet +elterebélyesedik +elterel +elterjed +elterjeszt +elterpeszkedik +elterül +eltervez +eltesz +eltilt +eltiltás +eltipor +eltitkol +eltökéltség +eltölt +eltömődik +eltöpreng +eltör +eltörik +eltörlés +eltöröl +eltörölhetetlen +eltörődik +eltörpül +eltol +eltolódik +eltompul +eltorlaszol +eltorzít +eltorzul +eltorzulás +eltotyog +eltréfálkozik +eltúloz +eltünedezik +eltüntet +eltüntetés +eltűnés +eltűnik +eltűnődik +eltűnt +eltűr +eltulajdonít +eltussolhatatlan +elújságol +elúszik +elücsörög +elül +elüldögél +elüldöz +elülső +elültet +elüt +elüvölt +elűz +elugrik +elun +eluralkodik +elutasít +elutasítás +elutasító +elutazás +elutazik +elv +elvág +elvágás +elvágódik +elvágtat +elvágyakozás +elvágyódás +elválás +elválaszt +elválasztódás +elválik +elvállal +elvált +elváltozik +elváltoztat +elvándorol +elvánszorog +elvár +elvárás +elvadul +elvakkant +elvakult +elvarázsol +elvégez +elvégeztet +elvégre +elvégzés +elvégzetlen +elvékonyodik +elvérzik +elvét +elvétve +elvegyül +elver +elvergődik +elvermel +elvesz +elveszett +elveszít +elveszt +elvesztés +elveszteget +elvet +elvetemült +elvetemültség +elvetődik +elvevés +elvezényel +elvezet +elvezetés +elvhű +elvhűség +elvi +elvi-eszmei +elviccelődik +elvigyorodik +elviharzik +elvihog +elvileg +elvirul +elvisel +elviselés +elviselhetetlen +elviselhetetlenség +elviselhető +elvisz +elvitathatatlan +elvitet +elvörösödik +elvon +elvonatkoztat +elvonókúra +elvont +elvontat +elvonul +elvonulás +elvtárs +elvtársaz +elvtársnő +elvtestvér +elvtike +elzálogosít +elzár +elzárás +elzárkózás +elzárkózik +elzarándokol +elzavar +elzörög +elzsibbad +elzsibbadtság +elzsongít +elzúg +ember +emberáldozat +emberállat +emberanyag +emberarc +emberavatás +emberbaráti +embercsempész +embercsoport +emberdugó +emberélet +emberemlékezet +embereszmény +emberevő +emberfaj +emberféle +emberfej +emberfia +emberfölötti +emberformáló +emberformálta +embergyártás +embergyűrű +emberhalál +emberi +emberiség +emberismerő +emberkatona +emberke +emberkéz +emberkígyó +embermagas +embernyi +emberölés +emberölő +emberöltő +emberpár +emberség +emberséges +emberszegy +emberszemlélet +emberszeretet +emberszó +embertárs +embertelen +embertestvér +embertestvériség +embertípus +embertömeg +embrió +embrionális +emészt +emésztés +emésztési +emésztetlen +emésztő +emésztőcső +emésztőgödör +emel +emelés +emelet +emeletes +emeleti +emeletnyi +emelget +emelhető +emelkedés +emelkedettség +emelkedik +emelkedő +emellett +emelőszerkezet +emelt +emelvény +emez +emiatt +emigráció +emigráns +emilyen +eminens +emitt +emlék +emlékcserép +emlékérem +emlékezés +emlékezési +emlékezet +emlékezetes +emlékezettelen +emlékezetű +emlékezik +emlékezőtehetség +emlékeztet +emlékeztető +emlékkő +emlékmű +emléknyom +emlékű +emlékvilág +emleget +emlegetés +említ +említés +emlősállat +empíria +emulziós +enciklika +enélkül +energia +energiafeltöltő +energiaigényes +energiamennyiség +energiapáncél +energiaparancsnok +energiaparancsnoki +energiapótlás +energiaráfordítás +energiarészecske +energiaszükséglet +energiatartalékolás +energiatelep +energiatermelő +energiazárlat +energikus +enged +engedékeny +engedély +engedélyez +engedelem +engedelmes +engedelmeskedik +engedelmesség +engedetlen +engedmény +engedményes +engesztel +engesztelés +engesztelhetetlen +ennélfogva +enni-innivaló +ennivaló +ennyi +ennyire +enyém +enyészet +enyészik +enyeleg +enyelgő +enyhe +enyhely +enyhes +enyhít +enyhül +enyhülés +enyingi +enyv +enzim +epés +epéskedik +epebaj +epebajos +epekedés +epekedik +epeköves +eper +eperfa +epika +epizód +epres +ercsi +erdélyi +erdész +erdészeti +erdészház +erdei +erdő +erdő-mező +erdőbeli +erdőborította +erdőféle +erdőgazdaság +erdőmérnök +erdőőri +erdős +erdős-dombos-tanyás +erdősarok +erdőség +erdőszél +erdősziget +erdővidék +erély +erélyes +erény +erecske +ered +eredendő +eredet +eredeti +eredetileg +eredetű +eredmény +eredményes +eredményesség +eredményez +eredményhirdetés +eredményhirdető +eredménylista +eredménytábla +eredménytelen +ereget +erejű +ereklye +eres +eresz +ereszalja +ereszcsatorna +ereszkedik +ereszt +ereszték +eresztés +eretnek +eretnekség +erez +erezet +erjed +erkély +erkélyajtó +erkölcs +erkölcsi +erkölcsiség +erkölcsös +erkölcsrendészet +erkölcstelen +erkölcstelenség +erkölcsű +ernyedetlen +ernyedt +ernyedtség +ernyő +ernyőjű +ernyős +ernyőtér +ernyőz +erő +erőcsatorna +erőd +erődemonstráció +erődítés +erődítményszerű +erődszektor +erődvonal +erőfeszítés +erőgép +erőkifejtés +erőlködés +erőlködik +erőltet +erőltetés +erőltetett +erőmennyiség +erőmű +erőnlét +erőpróba +erős +erősít +erősítés +erősítő +erősködés +erősködik +erősödik +erősség +erőszak +erőszakmentes +erőszakol +erőszakolt +erőszakos +erőszakoskodás +erőszakoskodik +erőszakosság +erőszaktétel +erőtérlokátor +erőteljes +erőtlen +erőviszony +erővonal +erotika +erotikus +erre +erre-arra +errefelé +erzsébet-napi +erzsébeti +esdekel +esély +esélyes +esélytelen +esés +esedékes +esedezik +esemény +eseménynapló +eseménysor +esernyő +esernyőnyél +eset +esetén +esetleg +esetleges +esetlen +esetlenség +esett +eshetőség +esik +eskü +esküdözik +esküdt +esküdtper +esküszik +esküvő +esküvői +eső +esőáztatta +esőcsepp +esőfüggöny +esőkabát +esőköpeny +esőkopogás +esőlék +esőmarta +esős +esőszag +esővíz +esővizes +esőzés +est +este +estéli +estélyi +esténként +estefelé +esteledik +estelente +esthajnali +esti +estike +esz +eszeget +eszelős +eszem-iszom +eszerint +eszes +eszeveszett +eszik +eszik-fal +eszik-iszik +eszköz +eszközöl +eszközölhető +eszme +eszmél +eszmélés +eszmélet +eszméletlen +eszmélkedés +eszmény +eszményi +eszménykép +eszmecsere +eszmefuttatás +eszmei +eszmetársítás +eszperantó +eszpresszó +eszpresszósnő +eszpresszószék +esztétika +esztétikai +esztelen +esztendő +esztendős +esztergál +esztergályos +esztergályoz +esztergapad +esztergom-tábori +esztergomi +eszterhéj +eszű +etet +etetés +etető +etika +etikett +ettől +etűd +etyetyety +eufória +európa-bajnok +európai +evangélista +evangélium +evés +evez +evezés +evező +evezőcsobbanás +evezős +evidencia +evidens +evőeszköz +evőkanál +exkluzív +exkuzál +exmenyasszony +expanzió +expedíció +expediál +explicit +exponált +export +export-import +exportál +exportkertészet +expozíciójú +expozíciós +expressz +expresszflört +extéglagyári +extrauterális +ez +ez-az +ez-ez +ezáltal +ezalatt +ezért +ezért-azért +ezelőtt +ezelőtti +ezen +ezenfelül +ezenkívül +ezennel +ezentúl +ezer +ezerév +ezeregy +ezerféle +ezerfiókos +ezerharmadik +ezerhatszáz +ezerhatszáznegyven +ezerhét +ezerhétszázhatvan +ezerhétszáznyolcvanhat +ezerkétszáz +ezerkettő +ezerkilencszáz +ezerkilencszázharminc +ezerkilencszázharminchárom +ezerkilencszázharminckettő +ezerkilencszázharmincnyolc +ezerkilencszázhatvan +ezerkilencszázhatvanegy +ezerkilencszázhatvanhárom +ezerkilencszázhatvanhét +ezerkilencszázhatvankilenc +ezerkilencszázhatvannyolc +ezerkilencszázhatvanöt +ezerkilencszázhetven +ezerkilencszázhúsz +ezerkilencszázhúszas +ezerkilencszázhuszonegyedik +ezerkilencszázhuszonhat +ezerkilencszázhuszonnégy +ezerkilencszázhuszonnyolc +ezerkilencszázhuszonöt +ezerkilencszázkettő +ezerkilencszázkilenc +ezerkilencszázkilencvenhat +ezerkilencszázkilencvennégy +ezerkilencszázkilencvennegyedi +ezerkilencszázkilencvenöt +ezerkilencszáznegyven +ezerkilencszáznegyvenegy +ezerkilencszáznegyvenhárom +ezerkilencszáznegyvenhat +ezerkilencszáznegyvenkettő +ezerkilencszáznegyvennégy +ezerkilencszáznegyvennégyes +ezerkilencszáznegyvennyolcas +ezerkilencszáznegyvenöt +ezerkilencszáznyegyvennyolc +ezerkilencszáznyolcvanas +ezerkilencszáznyolcvanegy +ezerkilencszáznyolcvannyolc +ezerkilencszázötven +ezerkilencszázötvenegy +ezerkilencszázötvenhat +ezerkilencszázötvenhét +ezerkilencszázötvenkilenc +ezerkilencszázötvennégy +ezerkilencszázötvennyolcas +ezerkilencszáztízes +ezerkilencszáztizenhét +ezerkilencszáztizenkettő +ezerkilencszáztizenkilenc +ezerkilencszáztizenkilences +ezerkilencszáztizennyolc +ezerkilencszáztizenöt +ezerkilenszázötven +ezermester +ezermesterség +ezernégyszázötvenhármas +ezernyi +ezernyolcszázharminchárom +ezernyolcszázhatvannégy +ezernyolcszázhetvenegy +ezernyolcszázkilencvenhét +ezernyolcszázkilencvenötös +ezernyolcszáznegyvenkilenc +ezernyolcszáznegyvennyolc +ezerötszáz +ezerötszázhármas +ezerötszázhatos +ezerötszázhetes +ezerötszáznégyes +ezerötszázötös +ezerszáznégyes +ezerszerte +eziránt +ezóta +ezred +ezredes +ezredik +ezredparancsnok +ezres +eztán +ezúton +ezúttal +ezüst +ezüstbetűs +ezüstceruza +ezüstcsengő +ezüstedény +ezüstfényű +ezüstfehér +ezüstfogantyús +ezüstfonal +ezüstfütyülő +ezüstgomb +ezüsthajú +ezüsthas +ezüstkalászos +ezüstkereszt +ezüstlánc +ezüstnyárfás +ezüstnyakú +ezüstös +ezüstpáncél +ezüstpáncélos +ezüstpor +ezüstszínű +ezüstszőke +ezüstszürke +ezüsttálca +ezüstveretű +ezután +ezzel +ében +éber +éber-álom +éber-nagy +éberség +éberszolgálat +ébred +ébredés +ébredezik +ébren +ébrenlét +ébrenléti +ébrentartás +ébreszt +ébresztget +ébresztő +ébresztőóra +édeni +édenkerti +édes +édes-édes +édes-kesernyés +édesanya +édesapa +édesbácsi +édeskés +édeslány +édesmindegy +édesség +ég +ég-föld +égbekiáltó +égbolt +égés +égési +égéstermék +éget +égetés +égető +égett +éghajlat +éghajlati +égi +égitest +égövi +égő +égszínkék +égvilágon +égzengés +éhcsitító +éhen +éhes +éhezés +éhezik +éhező +éhgyomor +éhség +éhségféle +éhségmorranás +éhségroham +éj +éjfél +éjfekete +éji +éjjel +éjjel-nappal +éjjeli +éjjeliedény +éjjeliőr +éjjeliszekrény +éjjeliszekrényke +éjszaka +éjszakás +éjszakázás +éjszakázik +éjszakai +ék +ékalak +ékelődik +ékes +ékesít +ékeskedik +ékesszólás +ékít +ékítmény +ékszer +ékszerbolt +ékszerdoboz +ékszerész +ékszeres +ékszíj +éktelen +éktelenkedik +él +élcelődés +élcsapat +élénk +élénkít +élénkpiros +élénkség +élés +éled +élelem +élelemraktár +élelmes +élelmez +élelmiszer +élelmiszerbolt +élelmiszercsomag +élelmiszerellátás +élelmiszersegély +élelmiszerüzlet +élenjár +éles +élesedik +éleseszűség +éleskedik +éleslátás +élesség +éleszt +élesztget +élesztőgyár +élet +életáram +életbevágó +életbiztonsági +életbölcsesség +életcél +életcsúcs +életdolog +életérzés +életév +életerő +életerős +életfogytig +életfogytiglan +életfogytiglani +életforma +élethalálharc +élethű +életjel +életkérdés +életkedv +életkörülmény +életkor +életlen +életmentő +életmód +életnagyság +életnagyságú +életöröm +életrajz +életre-halálra +életrevaló +életritmus +életstílus +életszemlélet +életszentség +életszínvonal +élettárs +élettani +élettapasztalat +élettér +élettelen +élettelenség +élettörténet +életút +életütem +életű +életveszély +életveszélyes +életveszedelem +életviszonylat +életvitel +élezés +élhetetlen +éljen +éljenez +éljenzés +élmény +élménybeszámoló +élménykereső +élő +élőbeszéd +élőhalott +élőlény +élősdi +élősövény +élősövény-kerítés +élővilág +éltet +élveteg +élvez +élvezet +émelyeg +émelygés +émelygős +émelyít +émelyítő +én +én-te-ő +én-tudat +ének +énekel +énekeltet +énekes +énekesmadár +énekesnő +énekhang +éneklés +éneklő +énekszó +énekszöveg +ép +épít +építés +építési +építész +építészet +építészeti +építészhallgató +építészmérnöknő +építget +építkezés +építkezési +építkezik +építmény +építő +építőanyag +építőautomata +építőkocka +építőmester +építőművészeti +építőmunka +építőmunkás +építtet +épit +épitészet +épitészeti +éppen +éppenséggel +éppígy +éppily +éppoly +éppolyan +éppúgy +épség +épül +épület +épületalapozás +épületcsoport +épületfa +épületlakatos +épületmaradvány +épületóriás +épületszárny +ér +éralj +érc +érces +ércesedik +ércesség +ércféleség +ércoszlop +érctulok +érdek +érdekében +érdekel +érdekelt +érdekeltség +érdekes +érdekesség +érdekfeszítő +érdekközösség +érdeklődés +érdeklődési +érdeklődik +érdeklődő +érdektelen +érdektelenség +érdem +érdemérem +érdemel +érdemes +érdemi +érdemkoszorú +érdemleges +érdemtelen +érdes +érés +érem +éretlen +éretlenkedik +érett +érettségi +érettségizik +érez +érezhető +éreztet +érfonat +érik +érint +érintés +érintetlen +érintett +érintget +érinthetetlenség +érintkezés +érintkezik +érintő +érkezés +érkezget +érkezik +érkező +érlel +érlelődik +érme +érő +éroldal +érosz +érpart +érparti +érrendszer +érsek +érsekség +ért +érte +érték +értékel +értékelés +értékes +értékesít +értékesítés +értékpapír +értékrendszer +értéktelen +értéktörvény +értékű +értés +értekezés +értekezik +értekezlet +értekezleti +értelem +értelmes +értelmes-hangos +értelmetlen +értelmetlenség +értelmez +értelmi +értelmi-érzelmi +értelmiség +értelmiségellenes +értelmiségi +értelmű +értesít +értesítés +értesül +értesülés +értetlen +értetlenkedik +értetlenség +értetődik +értetődő +érthetetlen +érthetetlenség +érthető +érthetőség +értő +érv +érvágás +érvény +érvényes +érvényesít +érvényesítés +érvényesül +érvényesülés +érvényesülési +érvénytelen +érvénytelenít +érvényű +érvel +érvelés +érzék +érzékel +érzékelés +érzékelhető +érzékeltet +érzékeltetés +érzékeny +érzékenykedik +érzékenység +érzéketlen +érzéketlenség +érzéki +érzékszerv +érzés +érzésfegyverzet +érzéstelenítés +érzésű +érzelem +érzelgős +érzelmes +érzelmeskedés +érzelmi +érzelmű +érzet +érzik +érző +érződik +érzület +és +éspedig +ésszerű +ésszerűség +ésszerűtlen +ész +észak +északi +északkelet +északkeleti +északnyugat +északvidéki +észbontó +észjárás +észjárású +észlel +észlelhető +észrevétel +észrevétlen +észrevehetetlen +észrevehető +észrevesz +észvesztő +észvesztve +étek +étel +étel-ital +ételhordó +ételhulladék +ételínyencség +ételillat +ételkiadó +ételminta +ételnemű +ételnyom +ételosztás +ételrecept +ételszag +éter +éterszag +étkészlet +étkezés +étkezik +étkező +étkezőkocsi +étkezőterem +étkeztetési +étlen-szomjan +étrend +étterem +éttermi +étvágy +étvágygerjesztő +étvágytalan +év +évad +évenként +évenkénti +évente +éves +évezred +évezredes +évfolyam +évfolyamtárs +évforduló +évi +évjárat +évjáratú +évkönyv +évődik +évszám +évszázad +évszázados +évszak +évtized +évtizedes +fa +fácán +fácános +fácántoll +fácska +fáj +fájdalmas +fájdalom +fájdalomcsillapító +fájin +fájlal +fájó +fájós +fáklya +fáklyásmenet +fáklyászene +fárad +fáradalom +fáradhatatlan +fáradozás +fáradozik +fáradság +fáradságos +fáradt +fáradt-vörös +fáradtság +fáramászás +fáraó +fáraói +fáraszt +fárasztó +fás +fásli +fásliz +fásszín +fásult +fásultság +fátlan +fátyol +fátyolfelhő +fátyolkönnyű +fátyolos +fátyolosság +fátyolozott +fátyolruha +fátyolszerű +fázik +fázis +fázisingadozás +fázós +faábrázat +faág +faágy +faállomány +faarc +faasztal +fababa +fabódé +faboltozatos +faburkolat +faburkolatú +facér +facsar +facsarás +facsoport +fadarab +fadepó +faderék +fadoboz +faépítmény +faecet +faedény +faeke +fafejű +fafülű +fagally +fagerenda +fagerendás +faggat +faggatás +faggatózik +faggyú +faggyús +fagörgő +fagy +fagyás +fagyaszt +fagylalt +fagylaltos +fagyos +fagyott +faház +faházikó +fahéj +fahéjbarna +fahelyettesítő +fahíd +fahusáng +faj +fajankó +fajgyártó +faji +fajlagos +fajmagyar +fajsúly +fajsúlyos +fajsúlyú +fajta +fajtájabeli +fajtájú +fajtalankodás +fajul +fajzat +fakad +fakanál +fakaszt +fakép +fakéreg +fakerék +fakereszt +faketrec +fakezű +fakír +fakitermelő +fakó +fakókék +fakószekér +fakószürke +faködmön +fakocka +fakoponyájú +fakorlátos +fakul +fakultás +fal +falánk +falánkság +falás +falabda +falat +falatnyi +falatozás +falatozik +falaz +falazás +falbontás +falbontó +faldöntő +falépcső +falépítés +falelem +falevél +falfehér +falhézag +fali +falív +falikép +falinaptár +falióra +faliszekrény +falka +falnivaló +falomb +falragasz +falrakó +falrész +fals +faltörő +falu +falu-tanya-tanyaközpont +falú +falubeli +falucska +faluhely +falumag +falunév +falurész +falusi +falusias +faluszél +faluszéli +faluszervezés +faluvég +faluvégi +faluzik +falvédő +família +familiáris +famulus +fanagykereskedő +fanatizmus +fantázia +fantáziájú +fantáziál +fantáziálás +fantáziátlan +fantasztikus +fanyalgás +fanyalog +fanyar +fanyarkás +fanyél +faóriás +faoszlop +fapad +fapofa +fapohár +far +farag +faragás +faragószék +faragószín +faragott +farba +farekesz +farigcsál +farizeus +farkas +farkas-barkas +farkasétvágy +farkasfogó +farkasharapás +farkaskutya +farkasmosoly +farkasszag +farkasszem +farkastekintet +farkasüvöltés +farktoll +farkú +farm +farmakológiai +farmer +farmernadrág +farok +farokuszony +farol +farostlemez +farsang +farsangi +fasaru +fasiszta +fasisztaféle +fasizmus +fasor +fasori +faszén +faszénparázs +fatábla +fateknő +fatelep +fatelepes +fatelepiek +fater +faterka +fatető +fatörzs +fattyú +fattyúszó +faun +fauna +faunos +faunszerű +favágás +favágó +favicc +fazék +fazetta +fék +fékállítás +fékcsikorgás +fékez +fékezhetetlen +fékezhetetlenség +fékezőfülke +féknyom +féktelen +féktelenség +fél +fél-estély +fél-fél +félájult +félálom +félakkora +félbehagy +félbemarad +félbeszakad +félbeszakít +félbetép +félbolond +féldeci +félénk +félénkség +félévenkénti +féléves +félelem +félelemérzet +félelmes +félelmetes +féleszmélet +félezer +félgömb +félhalott +félhang +félhangos +félhold +félhomály +félhomályos +félidő +félig +félig-meddig +féligformán +félisten +félisten-király +félkabát +félkarú +félkész +félkészraktár +félkéz-fejsze +félkegyelmű +félkilós +félkör +félkörívű +félkörös +félkomfortos +féllábú +féllépésnyi +félliteres +félmeztelen +félmondat +félmosoly +félmozdulat +félmúlt +félműveltség +félnapos +félnivaló +félóra +félórás +félő +féloldalas +féloldalaz +féloldalt +félpillantás +félre +félrészeg +félreáll +félreállás +félreállít +félrecsap +félrecsúszik +félredob +félreért +félreértés +félreérthetetlen +félreeső +félrefordít +félrefordulás +félregördít +félregördül +félregondol +félrehány +félrehajol +félrehajt +félrehív +félrehúz +félrehúzódik +félrelök +félrenéz +félreránt +félresikerül +félresöpör +félretakarít +félretapos +félretart +félretesz +félretol +félreugrik +félrevezet +félrevon +félrevonul +félsivatag +félsor +félszázados +félszeg +félszegség +félszem +félszemű +félszó +félt +féltáblányi +féltégla +féltékeny +féltékenykedés +féltékenykedik +féltékenység +féltés +félteke +féltestvér +féltett +féltő +félút +félujjnyi +félváll +félvállas +félzsold +fém +fémalkatrész +fémbújtató +fémburkolat +fémdarab +fémes +fémgomb +fémhideg +fémkar +fémlap +fémpénz +fémszerkezet +fémtest +fémtok +fény +fényáradat +fénybetű +fénycső +fénydárda +fényévnyi +fényelem +fényerejű +fényes +fényes-fekete +fényeskedik +fényesség +fényez +fényhalmaz +fényhatás +fényíró +fényjáték +fényjelenség +fénykép +fényképalbum +fényképész +fényképésznő +fényképez +fényképezőgép +fényképfelvétel +fényképsorozat +fénykör +fénylik +fénynyaláb +fényözön +fénypászma +fényreklám +fényrózsa +fényrobbanás +fénysáv +fénysugár +fénysugár-gyorsaságú +fényszóró +fénytábla +fénytelen +fénytünemény +fényű +fényűzés +fényűző +fényvédő +fényvihar +fér +fércelés +féreg +férfi +férfialak +férfiarc +férfias +férfiaskodik +férfiasság +férfiatlan +férficipő +férfiember +férfierő +férfigőz +férfihang +férfihulla +férfikéz +férfikor +férfimulatság +férfinem +férfinyak +férfiönhittség +férfipulóver +férfiricsaj +férfirokon +férfiruha +férfiszépség +férfiszív +férfitag +férfitérd +férfitenyér +férfiú +férfivilág +férfizakó +férges +férj +férj-feleség +férjeura +férjtípus +férjura +férkőzik +férőhely +férőhelyes +fésül +fésületlen +fésülködik +fésű +fészek +fészer +fészerszerű +fészkel +fészkelődés +fészkelődik +február +februári +fecni +fecsérel +fecseg +fecsegés +fecsegő +fecserészik +fecske +fecskefarkú +fecskefészek +fecskendez +fecskeugrás +fed +fedd +feddő +fedél +fedélzet +fedélzeti +fedeles +fedelű +fedetlen +fedett +fedez +fedezék +fedezet +fedőfoglalkozás +fedőlemez +fegyelem +fegyelmez +fegyelmezetlen +fegyelmezett +fegyelmezettség +fegyelmi +fegyenc +fegyencmunka +fegyház +fegyőr +fegyver +fegyverállvány +fegyveres +fegyvergyár +fegyverhasználat +fegyverletétel +fegyvernem +fegyverolaj +fegyverraktár +fegyverszünet +fegyverszüneti +fegyvertárs +fegyvertelen +fegyverzet +fegyverzetű +fehér +fehércsíkos +fehéredik +fehéregér +fehérgalléros +fehérít +fehérje +fehérjéjű +fehérjeszintézis +fehérlik +fehérnép +fehérnemű +fehérneműs +fehérrépa +fehérség +fehérségű +fehérszőke +fehérterrorista +fehértiszt +fehérvári +fej +fejbólintó +fejbőr +fejcsóválás +fejcsóváló +fejcsóválva +fejében +fejecske +fejedelem +fejedelemség +fejedelmi +fejel +fejelés +fejelget +fejelőmeccs +fejenként +fejes +fejesel +fejetlen +fejetlenség +fejezet +fejfa +fejfájás +fejforgás +fejforma +fejgörcs +fejhang +fejhossz +fejingatva +fejjáték +fejkendő +fejkendős +fejlemény +fejleszt +fejlesztés +fejlesztési +fejletlen +fejlett +fejlettség +fejlettségi +fejlettségű +fejlövés +fejlődés +fejlődési +fejlődik +fejlődő +fejmagasság +fejmozdulat +fejőnő +fejőstehén +fejpárna +fejrepesztő +fejszaggatás +fejsze +fejt +fejtartás +fejtartó +fejtés +fejteget +fejtegetés +fejtermés +fejtörés +fejű +fejvadász +fekély +fekélyes +fekete +fekete-fehér +fekete-tengeri +fekete-vörös +feketéllik +feketés +feketéscsésze +feketéspohár +feketézik +feketedik +feketekávé +feketekávé-reggeli +feketekávés +feketelista +feketepiac +feketeruhás +feketeség +fekhely +fekszik +fekte +fektet +fekvés +fekvésű +fekvőhely +fekvőtámasz +fel +fel-alá +fel-feldübörög +fel-felkap +fel-felnéz +fel-felnyílik +fel-felnyög +fel-felugat +fel-felvillant +felágaskodik +feláldoz +feláldozás +feláll +felállás +felállít +felállítás +felár +felás +felázik +felad +feladás +feladat +feladatkör +feladatvállalás +feladó +felajánl +felajánlás +felajz +felajzottság +felakaszt +felakasztat +felaprít +felaprítás +felbámul +felbátorodik +felbaktat +felballag +felbérel +felbecsül +felbillen +felbiztat +felbőg +felbőszít +felbőszül +felbocsátás +felbolydít +felbolydul +felbolydulás +felbomlik +felbont +felbontás +felborít +felborul +felborzol +felborzolódik +felbosszant +felbúg +felbuffant +felbujtás +felbujtó +felbukik +felbukkan +felbukkanás +felbuzdít +felbuzdul +felcipel +felcsap +felcsattan +felcsavar +felcsendül +felcseng +felcsenget +felcseperedik +felcser +felcserél +felcsernő +felcsíp +felcsillan +felcsókol +felcsuklik +felcukkol +feldarabol +feldereng +felderít +felderítés +felderíthető +felderítő +felderítő-kutató +felderül +feldíszít +feldönt +feldől +feldob +feldolgoz +feldolgozás +feldolgozatlan +feldúl +feldúlt +feldühít +feldühödik +felduzzad +felduzzaszt +fele +felé +felébred +felébredés +felébreszt +feléget +feléje +felél +feléled +felélesztés +felémelyedik +felénekel +felényi +felépít +felépítés +felépítmény +felépül +felér +felérkezik +felebarát +feled +feledékeny +feledhetetlen +feledkezés +feledtet +felegyenesedik +felejt +felejtés +felejthetetlen +felejtődik +felekezet +felel +felelés +felelet +felelevenedik +felelevenít +felelget +felelős +felelősség +felelősségérzet +felelősségféle +felelősségteljes +felelőtlen +felelőtlenség +felemás +felemásság +felemészt +felemel +felemelkedés +felemelkedési +felemelkedik +felemelő +felemelt +felenged +felereszt +felerősít +felerősödik +feles +feleség +feleséghiány +felesel +feleselés +felesküdik +felesküdt +feleszik +feleszmél +feletet +felett +felette +felettébb +felettes +felettesi +feletti +felevez +felez +felfakad +felfakaszt +felfal +felfénylik +felfed +felfedez +felfedezés +felfedezőút +felfedeztetés +felfegyverez +felfegyverkezési +felfegyverkezik +felfekszik +felfelé +felfest +felfeszít +felfigyel +felfirkál +felfog +felfogás +felfogású +felfogad +felfoghatatlan +felfokozódás +felfordít +felfordul +felfordulás +felforgat +felforgatás +felforr +felforral +felforrósodik +felfortyan +felfrissít +felfrissül +felfúj +felfújt +felfúvódik +felfüggeszt +felfűrészel +felfűt +felfűz +felfut +felfuvalkodott +felgerjed +felgöngyöl +felgöngyölítés +felgombostűz +felgyorsul +felgyújt +felgyúl +felgyülemlik +felgyűr +felgyűrődik +felgyullad +felháborít +felháborító +felháborodás +felháborodik +felhám +felhánytorgat +felhagy +felhajózik +felhajt +felhajtás +felhallatszik +felhalmoz +felhalmozás +felhalmozódik +felhangzik +felharsan +felhasad +felhasít +felhasogat +felhasznál +felhasználás +felhatalmazás +felhérc +felheccel +felhevül +felhevülés +felhív +felhívás +felhint +felhólyagzik +felhördül +felhördülés +felhő +felhőbogár +felhőfodor +felhőfüggöny +felhőgomoly +felhőjárás +felhőkarcoló +felhőkarcoló-boly +felhőnyi +felhőpárkány +felhőrés +felhős +felhőszakadás +felhőtakaró +felhőtlen +felhord +felhorkan +felhoz +felhúz +felhúzat +felhúzó +felhúzódik +felhullámzik +felír +felírás +felível +felidéz +felidézés +felidéződik +felidegesedik +felidegesít +felijed +felindul +felindulás +felindult +felingerel +felirat +feliratos +feliratú +felismer +felismerés +felismerhetetlen +felismerhető +feliszik +felitat +felizgat +felizzik +feljár +feljáró +feljajdít +feljajdul +feljavít +feljebb +feljebbvaló +feljegyez +feljegyzés +feljelent +feljelentés +feljelentő +feljön +feljogosít +feljut +felkacag +felkanyarodik +felkap +felkapar +felkapaszkodik +felkapcsol +felkaptat +felkarol +felkattint +felkavar +felkavarodik +felkér +felkészít +felkészítés +felkészül +felkészülés +felkészült +felkészültség +felkel +felkelés +felkelő +felkelt +felkeltés +felken +felkerekedik +felkeres +felkerül +felkever +felkeveredik +felkínál +felkínlódik +felkísér +felkiált +felkiáltás +felkiáltójel +felkiáltójeles +felkiabál +felködlik +felköltözik +felkönyököl +felköszönt +felköszöntés +felköszöntő +felköt +felkötöz +felkondul +felkúszik +felküld +felküzd +felkunkorodik +felkutat +felkutatás +fellármáz +fellázad +fellapoz +fellazít +fellazul +fellélegzés +fellélegzik +fellép +fellépés +fellépked +fellebbent +fellebbez +fellebbezés +fellebbviteli +felleg +felleges +fellegvár +fellelhető +fellelkesít +fellelkesül +fellendülés +fellengzés +fellódít +fellök +fellő +fellobban +fellobbanás +fellobbant +fellobog +fellobogóz +fellocsol +felmászik +felmagasodik +felmagasztosulás +felmagzik +felmarkol +felmélázik +felmér +felmérés +felmérgesedik +felmegy +felmelegedés +felmelegedik +felmelegít +felment +felmentés +felmenthetetlen +felmentő +felmerészkedik +felmerül +felmetsz +felmond +felmondólevél +felmorajlik +felmorzsol +felmos +felmosórongy +felmutat +felnagyít +felnéz +felnevel +felnevet +felnövés +felnövekedik +felnő +felnőtt +felnőttes +felnőttség +felnyalábol +felnyílik +felnyír +felnyihanás +felnyit +felnyom +felnyomul +felnyújt +felnyújtózik +felnyúlik +felnyurgul +felölel +felölt +felöltözik +felöltöztet +felöltő +felöntöz +felötlik +felől +felőle +felőli +felocsúdik +felold +feloldhatatlan +feloldódik +feloldozás +felolvas +felolvastat +felordít +feloson +feloszlat +feloszlik +feloszt +felosztás +felpártol +felpadlóztat +felpakol +felparázslik +felparcelláz +felpattan +felpattant +felpillant +felpiroslik +felpislant +felpislog +felpiszkál +felplankol +felpótol +felpöccent +felpörget +felpörög +felpróbál +felpúposodik +felpumpál +felráncigál +felrándul +felránt +felráz +felragad +felragaszt +felragyog +felrajzol +felrajzolódik +felrak +felrakosgat +felrémlik +felrendel +felrepít +felrepül +felretten +felrezeg +felrezzen +felriad +felriaszt +felrikkant +felröhög +felröppen +felrobban +felrobbant +felrohan +felrúg +felrugdos +felruház +felség +felséges +felsebez +felsegít +felserken +felsír +felsiet +felsikál +felsikít +felsikolt +felsivít +felsóhajt +felső +felsőajak +felsőbbrendű +felsőbbségi +felsőház +felsőőrsi +felsőruha +felsőtest +felsővidék +felsodródik +felsorakozik +felsorakoztat +felsorol +felsorolás +felspurizik +felsurran +felszáguld +felszálkásodik +felszáll +felszámol +felszámolás +felszánt +felszabadít +felszabadítás +felszabadító +felszabadul +felszabadulás +felszabadult +felszabadultság +felszabdal +felszaggat +felszakad +felszakít +felszalad +felszalagoz +felszaporodik +felszed +felszedeget +felszeg +felszegez +felszentel +felszerel +felszerelés +felszerelésű +felszín +felszínes +felszíni +felszív +felszívódik +felszikrázik +felszisszen +felszól +felszólal +felszólalás +felszólaló +felszólít +felszólítás +felszólító +felszór +felszökik +felszökken +felszolgál +felszolgáló +felszúr +felszűrődik +felszurkáltat +feltámad +feltámadás +feltámaszt +feltámasztás +feltápászkodik +feltár +feltárás +feltárcsáz +feltárul +feltalál +feltaláló +feltart +feltartóztat +feltartóztathatatlan +feltép +feltérdepel +feltérképezés +feltétel +feltételes +feltételez +feltételezés +feltételezett +feltételezhető +feltétlen +feltétlenül +feltéve +feltehető +felteker +feltekint +feltekintés +feltelefonál +felterjeszt +feltesz +feltett +feltevés +feltölt +feltöltődik +feltör +feltörés +feltöröl +feltol +feltolul +feltornyosodik +feltornyoz +feltúr +feltündöklik +feltüntet +feltüremlik +feltűnés +feltűnési +feltűnik +feltűnő +feltűnő-elszánt +feltűr +feltűz +felújít +felújítás +felúszik +felüdül +felüdültet +felügyel +felügyelet +felügyeletes +felügyeleti +felügyelő +felül +felület +felületes +felületesség +felületsík +felületű +felüli +felülkerekedik +felülkerül +felülmarad +felülmúl +felülmúlhatatlan +felültet +felülvizsgálat +felüt +felüvölt +felugrál +felugrik +felujjong +felutazik +felvág +felvágós +felvágott +felvállal +felvált +felváltva +felvásárol +felvázol +felvarr +felvérez +felvétel +felvételi +felvételiző +felver +felvesz +felvet +felvetés +felvetődik +felvevés +felvevő +felvevőgép +felvevőkamera +felvezet +felvidámodik +felvidít +felvidul +felvihog +felvilágosít +felvilágosítás +felvilágosult +felvillan +felvillanyoz +felvirágoz +felvirágzás +felvirágzik +felvirrad +felvisít +felvisz +felvon +felvonó +felvonóhíd +felvonul +felvonulás +felvonulási +felzárkózik +felzabál +felzaklat +felzargat +felzavar +felzendül +felzokog +felzúg +fen +fene +fenék +feneketlen +fenekű +fenemód +fenevad +fenn +fennáll +fennálló +fennakad +fennebb +fennen +fennforog +fennhagy +fennhangon +fennhatóság +fennhéjázás +fennmarad +fennmaradás +fennsík +fenntart +fenntartás +fenőkő +fenomenális +fenség +fenséges +fenséges-komor +fensőbbség +fensőbbséges +fenti +fenyeget +fenyegetés +fenyegető +fenyegetőzik +fenyegettetés +fenyítés +fenyő +fenyőerdő +fenyőfa +fenyőillat +fenyőpikkely +fenyőszag +fenyőszagú +fenyőtű +fenyves +ferde +ferences +ferencvárosi +fertőtlenít +fertőtlenítő +fertőtlenitő +fertőtlenitős +fertőz +fertőzés +fertőző +fess +fest +festék +festékréteg +festékszag +festés +festészet +festet +festetlen +festett +festmény +festő +festőállvány +festőanyag +festői +festőiség +festőműhely +festőművész +festőszék +feszélyez +feszélyezetlen +feszélyezett +feszélyezettség +feszeget +feszeng +feszes +feszít +fesztelen +fesztivál +feszül +feszület +feszült +feszültség +feszültségteremtő +fetreng +feudálkapitalista +fia +fiacska +fiatal +fiatalasszony +fiatalember +fiatalkor +fiatalkori +fiatalkorú +fiatalodik +fiatalos +fiatalság +fiatalúr +ficánkol +fickándozik +fickó +ficsúr +figura +figurázik +figyel +figyelés +figyelem +figyelembevétel +figyelmes +figyelmesség +figyelmetlen +figyelmeztet +figyelmeztetés +figyelmeztető +figyelő +figyeltet +fikció +filctoll +filigrán +filiszter +fillér +filléres +fillérnyi +film +filmcsillag +filmes +filmez +filmezik +filmfelvevő +filmfőszerep +filmgyár +filmgyári +filmgyártás +filmhét +filmhíradó +filmhíradós +filmművészet +filmrendező +filmszínész +filmszínésznő +filmvászon +filmvígjáték +filológia +filológiai +filosz +filozófia +filozófiai +filozófus +filozófusszakáll +filozofál +finálé +fináncláb +finánclábas +fincsi +finesz +finn +finnyás +finnyás-kényes +finom +finomít +finomkodik +finomkodó +finomság +fintor +fintorgás +fintorog +fiók +fiók-kutatóintézet +fiókos +fiókpárt +fiókraktár +fiókvezető +firkál +firkálás +firkálmány +firkátum +firtat +firtatás +fitogtat +fitty +fityeg +fitymál +fityula +fiú +fiúcska +fiúgyermek +fiúkíséret +fiúkiáltás +fiúnevelő +fiús +fiúzás +fivér +fixíroz +fizet +fizetés +fizetésemelés +fizetéses +fizetésosztás +fizetőpincér +fizikai +fizikaszertár +fizikoterápiás +fizikum +fizikus +flakon +flamand +flancol +flanelling +flasztervirág +flegma +flekkes +flekktífusz +flotta +flottakörút +fluktuáció +fluoreszkál +fóbia +fókabunda +fóliakorong +fór +fórum +födém +föl +föl-le +föld +földalatti +földbirtokos +földdarab +földecske +földes +földeskonyha +földfelszín +földgömb +földgolyó +földhányás +földhajlás +földi +földieper +földjáradék +földkérdés +földkerekség +földművelő +földműves +földmunka +földmunkásság +földnélküli +földönfutó +földöntúli +földosztás +földpadló +földrajz +földrajzi +földrajzkönyv +földrész +földrengés +földsáv +földszag +földszakadék +földszelet +földszint +földszintes +földszinti +földteke +földtelen +földterület +földtöltés +földtömeg +földtulajdonos +fölé +fölébe +föléje +fölény +fölényes +fölényeskedik +fölös +fölösleg +fölösleges +fölrezeg +fölül +fölüle +föníciai +förgeteges +förmed +förtelmes +förtelmeskedés +fösvény +fösvénység +fötyöl +föveny +fövenyi +fövetlen +fő +fő-fő +főagronómus +főalak +főbérlet +főbérlő +főbérlőnő +főbejárat +főbiccentés +főbizalmi +főbólogató +főbűn +főcím +főcsoport +fődiszpécser +főépület +főember +főfal +főfelügyelő +főfoglalkozás +főfoglalkozású +főfront +főgazda +főgépész +főgenerális +főgóré +főhadiszállás +főhadnagy +főhadnagyi +főhajónagy +főhajtás +főhatalom +főhely +főhős +főigazgatóság +főiskola +főispán +főjegyző +főkamarás +főkapitányi +főkapitányság +főkapu +főként +főképpen +főkérdés +főkertészi +főkönyvelő +főkörzet +főkötő +főkomornyik +főlakáj +főlépcső +főleg +főmérnök +főnök +főnökféle +főnökség +főnökszabású +főnővér +főorvos +főorvosnő +főosztály +főosztályvezető +főpásztor +főpásztorság +főpap +főpapnő +főparancsnok +főpincér +főpolgármester +főportás +főposta +főrangú +főrendező +főrevizor +fősereg +főszemély +főszempont +főszerep +főszereplő +főszerkesztő +főszolgabíró +főszolgabíróné +főtárgyalás +főtanácsosi +főtér +főtéri +főtendencia +főtiszt +főtlen +főtolmács +főtt +főúr +főúri +főút +főútvonal +főügyész +főütőér +főudvarmester +főutca +fővádlott +főváros +fővárosi +fővadász +fővezér +fővezéri +fővonal +főz +főzés +főzelék +főzet +főzőfülke +főzőkanál +főzőszekrény +főztje +focista +fodor +fodrász +fodrászsegéd +fodrászszalon +fodrászüzlet +fodroz +fodrozás +fodrozódik +fog +fogás +fogású +fogász +fogad +fogadás +fogadási +fogadalmas +fogadalmi +fogadalom +fogadatlan +fogadkozik +fogadó +fogadóóra +fogadós +fogadtatás +fogalmaz +fogalmazás +fogalmazvány +fogalom +fogan +foganat +foganatosít +foganosít +fogantyú +fogantyús +fogas +fogaskerék +fogaskerék-pontos +fogaskerekű +fogat +fogatváltás +fogazat +fogcsikorgató +fogda +fogdos +fogékony +fogház +fogházigazgató +fogható +foghegyről +foghíj +foghíjas +foghíjbeépítési +foghíjház +foghíjlétesítési +foghúzás +fogkefe +fogkrém +foglal +foglalás +foglalat +foglalatoskodik +foglalatosság +foglalkozás +foglalkozású +foglalkozik +foglalkoztat +foglaló +foglalt +foglyos +fogmosás +fogműtét +fogó +fogócska +fogócskázik +fogódzik +fogódzkodik +fogódzó +fogós +fogoly +fogolytábor +fogolytársulat +fogorvos +fogság +fogsor +fogszabályozó +fogú +fogva +fogy +fogyaszt +fogyasztás +fogyasztó +fogyasztóközönség +fogyatékos +fogyatékosság +fogyatkozik +fogyó +fogyta +fohász +fohászkodás +fohászkodik +fojt +fojtás +fojtógáz +fojtogat +fojtott +fok +fokhagyma +fokhagymás +fokhagymázás +foknyi +fokos +fokoz +fokozás +fokozat +fokozatos +fokozatosság +fokozódik +fokozott +fokú +foldozgat +folklór +folklorista +folt +foltos +foltos-piszkos +foltoz +folyás +folyadék +folyam +folyamán +folyamat +folyamatos +folyamatosság +folyamodás +folyamodik +folydogál +folyékony +folyik +folyó +folyócska +folyóirat +folyóirattár +folyópart +folyósít +folyóvíz +folyosó +folyosórész +folyosószerű +folytán +folytat +folytatás +folytatható +folytatódik +folytatólagos +folyton +folyton-folyvást +folytonos +folytonosság +folyvást +fon +fonák +fonal +fonal-előkészítő +fonat +fonatú +foncsoroz +foncsorozású +fondor +fondorlat +fondorlatos +fonendoszkóp +fonnyad +fonnyadozik +fonnyadt +fonódik +fonott +font +fontolgat +fontolgatás +fontoló +fontos +fontoskodás +fontoskodik +fontosság +fonyódi +fordít +fordítás +fordítható +fordító +fordítói +fordított +fordítva +fordul +fordulás +fordulási +fordulat +forduló +fordulópont +forgács +forgácsjancsi +forgás +forgalmas +forgalmi +forgalmú +forgalom +forgat +forgatag +forgatócsoport +forgatószerkezet +forgattyú +forgó +forgóajtó +forgócsont +forgolódás +forgolódik +forint +forintkiajánlás +forintocska +forintos +forma +formájú +formál +formálás +formálgat +formálódik +formás +formátlan +formáz +formaalakítás +formagazdagító +formai +formakereső +formalista +formaruha +formaság +formavilág +formula +forog +forog-zenél +forpaszos +forr +forrás +forrásvíz +forradás +forradalmár +forradalmi +forradalmiság +forradalom +forral +forralt +forraszt +forró +forrófejű +forróság +forrósodik +forrong +forrpont +fortélyos +fortyog +foszforeszkál +foszforos +foszlány +foszlik +fosztogatás +fotel +fotó +fotós +fotoalkatrész +fotocellás +fotofelszerelés +fotográfia +fotográfus +fotonerőmű +fotoriporter +fotoújság +foxi +frász +frászkarika +fráter +frázis +frázisos +frakció +frakciózás +frakk +frakkos +frakkszárny +franc +francia +franciakrémes +franciaság +frankfurti +frankó +frappáns +fraternizálás +frazeológia +freccsen +fregatt +fregattkapitány +fregoli +frekvencia +freskó +freskófestés +freskótöredék +fricskáz +frigysátor +friss +frissiben +frivol +frizsider +frizura +frizurás +fröccs +fröccsen +fröcsköl +fröcskölődés +fröcsög +front +frontátvonulás +frontismeretség +frontkatona +frontmester +frontszolgálat +frottír +frottírköpeny +frottírpongyola +frottírtörülköző +frufru +fúj +fújás +fújdogál +fújkál +fújtat +fújtatás +fúl +fúr +fúrás +fúria +fúró +fúródik +fúrómester +fúrós +fúróslegény +fúrótelep +fúrótorony +fúvat +fúvódik +fúvóka +fúvószenekar +fügebólé +fügebokor +függ +függélyes +függelék +függeszt +független +függetlenít +függetlenség +függetlenségi +függöny +függönyhúzó +függönyöz +függő +függőágy +függőfolyosó +függőhíd +függőleges +függvény +fül +fülbesúgás +fülbevaló +fülcimpa +füldugós +fülecske +fülel +fülemüle +füles +fülhallgató +fülke +fülledt +fülledtség +fülsértő +fülsiketítő +fülszöveg +fültépő +fürdés +fürdet +fürdetlenség +fürdik +fürdő +fürdőfülke +fürdőház +fürdőhely +fürdőigazgató +fürdőkád +fürdőkályha +fürdőköpeny +fürdőlepedő +fürdőnadrág +fürdőorvos +fürdőruha +fürdőszoba +fürdőszobás +fürdőszobaajtó +fürdőtrikó +fürdővendég +fürdőzik +fürge +fürgeség +fürj +fürkész +fürkészés +fürkésző +füröszt +fürt +füst +füstfelhő +füstfelleg +füstfúvó +füstkarika +füstkígyó +füstködös +füstöl +füstölög +füstölt +füstös +füstpántlika +füstpénz +füstszuronyos +fütty +füttyent +füttyentget +füttyszó +fütykös +fütyörész +fütyörészés +fütyül +fütyülés +füves +füves-bozótos +füvesít +füzér +füzes +füzesgyarmati +füzet +füzetlap +fű +fű-fa +fűlik +fűrész +fűrészbak +fűrészel +fűrészelget +fűrészes +fűrészféle +fűrészfog +fűrészfogú +fűrészmalom +fűrészpor +fűrészporos +fűrésztelep +fűszál +fűszálnyi +fűszerbolt +fűszeres +fűszerüzlet +fűt +fűtés +fűtési +fűtésű +fűtenger +fűtő +fűtőanyag +fűtőcső +fűtőház +fűtőtest +fűvű +fűz +fűzbokor +fűzfa +fűzfaág +fűzfagally +fűzfakas +fűzfakosár +fűző +fűzőcske +fűződik +fűzős +fuj +fukar +fuldoklik +fullánkos +fullad +fulladásos +fulladozik +fullasztó +fundál +fundamentum +fungál +funkció +funkcionál +funkcionális +funkcionárius +fura +furakodik +furcsa +furcsálkodik +furcsáll +furcsaság +furdal +furfang +furfangos +furkál +furkósbot +furulya +fusermunka +fusimunka +fusizik +fut +futár +futárszolgálat +futás +futam +futamodik +futball +futball-labda +futballcsapat +futballista +futballozás +futballpálya +futballpápa +futballszakértő +futkározik +futkos +futó +futóbetyár +futóhomok +futólag +futólagos +futólépés +futószalag +futótréning +futta +futtában +futtat +futtató +fuvallat +fuvar +fuvaros +fuvaroz +fuvarozás +fuvarozási +fuvolázik +g-moll +gádzsó +gágog +gálya +gályarab +gáncs +gányó +gárda +gát +gátlás +gátlásos +gátlástalan +gátló +gátol +gátoltság +gátrendszer +gátszakadás +gáttest +gáz +gázcsap +gázkitörés +gázkitörés-veszélyes +gázlámpa +gázló +gázmérgezés +gázmolekula +gázművek +gázöngyújtó +gázol +gázoszlop +gázresó +gázsi +gázszag +gázszagú +gázszűrőbetét +gáztartály +gáztűzhely +gázvezeték +gabalyodás +gabalyodik +gabona +gabonaár +gabonamag +gagarászik +galamb +galambocska +galcsi +galcsitag +galéria +galeri +galiba +gall +gallér +gallérú +gally +galopp +galoppozás +galuska +galuskacsomó +galvanizál +gamós +ganéj +gang +gangos +gangrács +garázda +garázdálkodás +garázdálkodik +garázs +garázshelyiség +garázsmester +garabonciás +garancia +garancialevél +garantál +garantálható +garas +garasoskodik +garat +garatüreg +gardróbszekrény +garmada +garnitúra +gatya +gatyázik +gavallér +gavalléria +gavalléros +gaz +gazda +gazdálkodás +gazdálkodik +gazdálkodó +gazdátlan +gazdaasszony +gazdacsalád +gazdag +gazdag-paraszt +gazdagodik +gazdagság +gazdagságú +gazdagyerek +gazdaság +gazdasági +gazdaságos +gazdaságosság +gazdaságpolitika +gazdaságszervezeti +gazdaságtan +gazdaságvezetés +gazdasszony +gazdatiszti +gazdi +gazdika +gazduram +gazella +gazember +gazfickó +gazos +gazság +gazsulál +gazszál +gaztenger +gaztett +gébics +gége +gégész +géhá +géhás +gém +gémberedett +gémberít +gémeskút +géniusz +gép +gépágyú +gépagy +gépcsoda +gépész +gépész-szakács +gépészmérnök +gépésztechnikus +gépel +gépelt +gépesít +gépezet +gépgyártási +gépház +géphang +gépi +gépírás +gépírásos +gépíró +gépírónő +gépies +gépjavító +gépkatona +gépkezelőnő +gépkocsi +gépkocsiforgalom +gépkocsigarázs +gépkocsiipari +gépkocsivezető +géplakatos +gépolaj +géppisztoly +géppisztolyos +géppisztolysorozat +géppuska +géppuskás +géprész +gépsonka +gépsor +gépszerkezet +gépszíj +gépterem +gépzene +gépzúgás +gézcsík +gézengúz +gebe +gebin +gemkapocs +generáció +generálberendezés +generális +generálisféle +generálkulcs +gengszter +gennyesedik +gennygóc +geológus +geometriai +geometrikus +gereblye +gereblyél +gereblyéz +gerelyvetés +gerenda +gerendalabirintus +gerezd +gerezdes +gerilla +gerinc +gerinckopás +gerincű +gerjed +gerjeszt +germán +gesztenye +gesztenyebarna +gesztenyefa +gesztenyefalevél +gesztenyefasor +gesztenyehaj +gesztenyeszín +gesztikuláció +gesztikulál +gesztus +gesztuselmaradás +gettó +giccs +giccses +gigantikus +giliszta +gilisztadíszes +gimnázium +gimnasztyorka +gimnazista +gipsz +gipszágyékkötő +gipszatlasz +gipszcímer +gipszciráda +gipszkirály +girhes +girland +gitár +gizda +gleccser +globális +gnóm +góc +gócpont +gógyi +gól +gólhelyzet +góliát +gólszerző +gólya +gólyaléptek +góré +gót +gótika +gótikus +gödölye +gödör +gödröcskés +gödrös +gömb +gömbhajó +gömböc +gömbölyít +gömbölyödik +gömbölyű +gömbölyűség +gömörödik +gönci +göndör +göndör-borzas +göndörödik +göngyöl +görbe +görbít +görbül +görcs +görcsös +görcstelen +görcsű +gördít +gördül +görény +görénybűzű +görget +görkorcsolyapálya +görnyed +görnyedés +görnyedt +görög +görögdinnye +görögös +göröngy +göröngyzuhatag +gőg +gőgös +gőz +gőz-folyadék +gőzbárka +gőzfelhő +gőzfürdő +gőzfűrész +gőzhajó +gőzhajózás +gőzmozdony +gőzölög +gőzös +golfnadrág +golyó +golyóbis +golyócska +golyófogó +golyóstoll +golyószóró +golyószórós +golyózápor +golyózik +gomb +gomba +gombás +gombalámpa +gombgyáros +gomblyuk +gombnyomás +gombóc +gombocska +gombol +gombolatlan +gombolgat +gombos +gombostű +gombostűfej +gombszem +gombszög +gombüzlet +gomoly +gomolyag +gomolyasajt +gomolyfelhő +gomolyog +gond +gondatlan +gondbeszélgetés +gondnok +gondol +gondola +gondolat +gondolatátvitel +gondolatbénító +gondolatfelvillanás +gondolatmenet +gondolatolvasó +gondolatparancs +gondolatsor +gondolattársítás +gondolattalan +gondolattömeg +gondolatvilág +gondolkodás +gondolkodási +gondolkodásmód +gondolkodású +gondolkodik +gondolkodó +gondolkozás +gondolkozik +gondolkozó +gondos +gondoskodás +gondoskodik +gondosság +gondoz +gondozás +gondozatlan +gondozott +gondtalan +gondterhelt +gondűző +gondviselés +gondviselő +gong +gonosz +gonoszkodik +gonoszság +gordonka +goromba +gorombáskodás +gorombáskodik +gorombáz +gorombaság +grácia +gránát +gránátalma +gránátszilánk +gránitkövezet +gránitszikla +grabanc +grafikon +grafikus +grafikusék +grafit +grafológia +grafológus +gramm +grammatikus +gramofon +grand +grandiózus +gratuláció +gratulál +gravírozó +graviditás +gravitáció +gravitációs +grenadinruha +grill +grimasz +grimaszol +gróf +grófi +grófné +grófnő +groteszk +grúz +grund +gúla +gúny +gúnya +gúnyol +gúnyolódik +gúnyos +gúzs +gúzsbakötés +gügyög +gügyögés +gürcöl +guba +gubacs +gubancos +gubbaszt +guggol +guggolás +gukker +gukkerszíj +gulya +gulyás +gulyás-fokos-romantika +gulyáságyú +gulyásbojtár +gulyanyomás +gumi +gumírozott +gumiarc +gumibelső +gumibot +gumibotütleg +gumicsizma +gumicsónak +gumicsöves +gumikerekű +gumikesztyű +gumilabda +gumimatrac +gumipapucs +gumipitypang +gumipitypang-terület +gumipumpa +gumisarok +gumislag +gumiszőnyeg +gumitalp +gumitalpú +gumiút +gumivasaló +gumó +gunyoros +gurguláz +gurít +gurigál +gurul +guszta +gusztus +gusztusos +gusztustalan +gusztustalankodik +gutaütés +gvárdián +gyám +gyámkodás +gyámkodik +gyámolít +gyámolító +gyámolt +gyámoltalan +gyámoltalanság +gyámügyi +gyár +gyári +gyárigazgató +gyárkémény +gyáros +gyárt +gyártás +gyártelep +gyártmány +gyártmányú +gyártulajdonos +gyász +gyászének +gyászfátyol +gyászhír +gyászjelentés +gyászkeretes +gyászlobogó +gyászmise +gyászol +gyászoló +gyászorkeszter +gyászos +gyászruha +gyászszalag +gyászszertartás +gyászszónoklat +gyászzene +gyáva +gyávaság +gyakori +gyakorlás +gyakorlat +gyakorlati +gyakorlatlan +gyakorlatozik +gyakorlott +gyakornok +gyakorol +gyakorta +gyakran +gyaláz +gyalázat +gyalázatos +gyalázatosság +gyalázkodik +gyalog +gyalogasztal +gyalogezred +gyaloghintó +gyalogjáró +gyaloglás +gyalogösvény +gyalogol +gyalogos +gyalogság +gyalogsági +gyalogszeder +gyalogszerrel +gyalogút +gyalulás +gyalulatlan +gyanánt +gyanakodik +gyanakvás +gyanakvó +gyanakvó-kutató +gyanít +gyanta +gyantás +gyanú +gyanúkeltés +gyanús +gyanúsít +gyanúsítgat +gyanúsítható +gyanúsított +gyanútlan +gyapjú +gyapjúpulóver +gyapjútakaró +gyarapít +gyarapodik +gyarló +gyarmat +gyarmatárubolt +gyarmati +gyatra +gyékény +gyékényheverő +gyémánt +gyémántbuton +gyér +gyérül +gyenge +gyengécske +gyengéd +gyengédség +gyengélkedik +gyengeelméjű +gyengeség +gyengít +gyengül +gyengülés +gyep +gyepes +gyephokipálya +gyeplő +gyere +gyerek +gyerekágy +gyerekarc +gyerekbolond +gyerekcsoport +gyerekelőadás +gyerekes +gyerekeskedik +gyerekfej +gyerekhang +gyerekhistória +gyerekholmi +gyerekjáték +gyerekjátszótér +gyerekképű +gyerekkéz +gyerekkönyv +gyerekkocsi +gyerekkoporsó +gyerekkor +gyerekkori +gyereknapszám +gyereknépség +gyerekotthon +gyerekpizsama +gyereksivalkodás +gyerekszem +gyerektartás +gyerektenyérnyi +gyerkőc +gyermek +gyermekarc +gyermekbetegség +gyermekcipő +gyermekév +gyermekes +gyermekfej +gyermeki +gyermekjáték +gyermekkor +gyermekkori +gyermeknevelés +gyermekség +gyermekszem +gyermektartás +gyermektelen +gyermekvadászat +gyermeteg +gyertya +gyertyán +gyertyacsonk +gyertyafény +gyertyafényes +gyertyaláng +gyertyaszál +gyertyatartó +gyertyavallatás +gyí +gyík +gyilkol +gyilkolás +gyilkos +gyilkosság +gyilkossági +gyógyfürdő +gyógyhatású +gyógyír +gyógyít +gyógyítás +gyógyíthatatlan +gyógykezeltet +gyógymód +gyógypedagógusnő +gyógyszer +gyógyszerész +gyógyszertár +gyógyszertári +gyógyszervegyészeti +gyógyüdülő +gyógyul +gyógyulás +gyógyvíz +gyógyvíz-reklámfilm +gyón +gyónás +gyóntató +gyökér +gyökérkefe +gyökérvésés +gyökerezik +gyökerű +gyömköd +gyömöszöl +gyöngy +gyöngyfog +gyöngyház +gyöngyhalászat +gyöngyözik +gyöngysor +gyöngytenger +gyöngytyúk +gyöngyvirág +gyönyör +gyönyörködik +gyönyörködtet +gyönyörű +gyönyörűség +gyönyörűséges +gyötör +gyötrelem +gyötrelmes +gyötrődés +gyötrődik +győz +győzedelmeskedik +győzelem +győzelmes +győzelmi +győzhetetlen +győzködik +győztes +gyolcsgatya +gyolcsing +gyom +gyomai +gyomor +gyomorbajos +gyomorfekély +gyomorfelforgató +gyomorgörcs +gyomorkeserűs +gyomormosás +gyomorsav +gyomorsüllyedés +gyomorszáj +gyomorvérzés +gyomos +gyors +gyorsaság +gyorsfutár +gyorsíró +gyorsít +gyorslift +gyorsnyelvű +gyorstalpaló +gyorstüzelő +gyorsul +gyorsulás +gyorsvonat +gyújt +gyújtópont +gyújtós +gyújtogatás +gyúl +gyúr +gyüdi +gyülekezet +gyülekezik +gyülevész +gyümölcs +gyümölcsfa +gyümölcsfaág +gyümölcshegy +gyümölcskertész +gyümölcsös +gyümölcsszag +gyüremlik +gyürmöl +gyűjt +gyűjtés +gyűjtemény +gyűjteményes +gyűjtő +gyűlés +gyűlésterem +gyűlik +gyűlöl +gyűlölet +gyűlöletes +gyűlölködés +gyűlölködik +gyűlölség +gyűr +gyűretlen +gyűrött +gyűröttség +gyűrődés +gyűrődik +gyűrű +gyűrűkovács +gyűrűtlen +gyűrűz +gyűrűzik +gyufa +gyufásdoboz +gyufagyújtás +gyufaoldat +gyufaskatulya +gyufaszál +gyufazörgés +gyugyurigyuuu +gyullad +gyulladás +gyulladt +ha +ha-ha-ha +háborgat +háborítatlan +háborog +háború +háborús +háborúskodás +háborúzik +hágó +háj +hájas +hájtömeg +hál +hála +hálás +hálátlan +hálaistennek +hálanyilvánítás +hálatelt +háló +hálóing +hálóköntös +hálószoba +hálószobaablak +hálószobabútor +hálótárs +hálóterem +hálóvendég +hálózat +hályog +hám +hámlik +hámoz +hámozás +háncs +háncsfüggöny +háncsszoknyácska +háncsú +hány +hányad +hányadán +hányadik +hányadszor +hányattatás +hányaveti +hányféle +hányinger +hánykolódás +hánykolódik +hányódik +hányszor +hánytorgat +hápog +hárem +hárfa +hárít +hármas +hármashegyi +három +három-négy +három-négyszáz +háromágú +háromaknás +háromcsillagos +háromdimenziós +háromévenként +hároméves +háromemeletes +háromesztendős +háromezer +háromezer-háromszázkilenc +háromezer-hatszázötvennégy +háromezerkétszáz +háromfelé +háromgyerekes +háromhetenként +háromlábú +háromliteres +háromméteres +háromnegyed +háromnegyedes +háromnyelvű +háromórás +háromoktávos +háromszáz +háromszázhatvanöt +háromszázhúsz +háromszázhuszonhét +háromszáznyolcvan +háromszázötven +háromszög +háromszögletű +háromszögű +háromszoba +háromszobás +háromszori +háromszoros +háromtagú +hárs +hársfa +hársfatea +hárul +háryjános +hát +hátbavágás +hátegyenesítő +hátgerinc +hátgerinc-daganat +hátha +háti +hátizsák +hátjáték +hátlap +hátmenet +hátra +hátrább +hátrál +hátrány +hátrányos +hátracsap +hátracsapódik +hátracsavar +hátradönt +hátradől +hátradob +hátraesik +hátrafelé +hátrafeszít +hátrafordít +hátrafordul +hátragurít +hátrahagy +hátrahajít +hátrahajol +hátrahúz +hátrahúzódik +hátrakönyököl +hátraköt +hátrakulcsol +hátralép +hátralevő +hátralök +hátralopódzik +hátramarad +hátramaradott +hátramegy +hátranéz +hátranézés +hátranyújt +hátranyúl +hátraperdül +hátrapillant +hátraránt +hátrasimít +hátrasimul +hátraszalad +hátraszeg +hátraszól +hátraszorít +hátratántorodik +hátratekint +hátraterjeszkedik +hátratesz +hátratol +hátratúr +hátraugrik +hátravan +hátravet +hátravezet +hátravisz +hátravonul +hátsó +háttér +hátú +hátul +hátulja +hátulsó +hátvéd +ház +házacska +házas +házasélet +házasember +házasodik +házaspár +házasság +házassági +házasságkötés +házasságkötő +házasságszédelgés +házasságszédelgő +házastárs +házfal +házfelügyelő +házfoglaló +házgazda +házgondnok +házi +háziállat +háziasszony +háziasszonyi +házibuli +házigazda +házikabát +házikó +háziköntös +házimunkás +házinyúl +háziorvos +házirend +háziúr +házkutatás +házmester +házmester-házaspár +házmesterné +házőrző +házrengeteg +házsártos +házsor +házszám +háztáji +háztartás +háztartási +háztető +háztömb +háztűznéző +háztulajdonos +házú +házvezetőnő +haa +hab +habár +habarcs +habarcskozmetika +habkönnyű +habos +habosodik +haboz +habozás +habozik +habozó +habzik +habzsol +habzsolás +hacsak +had +hadállás +hadakozás +hadakozik +hadar +hadarás +hadarászik +hadbíró +hadd +haderő +hadfi +hadgyakorlat +hadi +hadibázis +hadidicsőség +hadifogoly +hadifogolytábor +hadifogság +hadihajó +hadiipar +hadijel +hadijelentés +hadipénztár +hadirokkant +hadisarc +hadisegély +hadiszergyáros +haditanács +haditengerész +haditengerészet +haditengerésztiszt +haditerv +hadititok +haditudomány +hadiút +hadiüzem +hadizsákmány +hadjárat +hadkiegészítési +hadkiegészítő +hadmozdulat +hadművelet +hadműveleti +hadnagy +hadnagyforma +hadnagyocska +hadnagyság +hadonászás +hadonászik +hadosztály +hadrálás +hadrend +hadsegéd +hadsereg +hadszíntér +hadtest +hadúr +hadügyminisztérium +hadvezér +hadvezéri +hadvezető +hadvezetőség +hagy +hagyás +hagyaték +hagyján +hagyma +hagymászsák +hagymaszagú +hagyomány +hagyományos +hagyományosság +hagyományoz +haha +hahota +hahotázik +haj +hajadonfőtt +hajaj +hajaz +hajbóbita +hajbókol +hajcihő +hajcsár +hajcsat +hajcsomó +hajdan +hajdanán +hajdani +hajdú +hajdúfő +hajdúnánási +hajerdő +hajfürt +hajít +hajigál +hajkorona +hajkoszorú +hajkupac +hajkurász +hajlás +hajlású +hajladozik +hajlam +hajlamos +hajlamú +hajlandó +hajlandóság +hajlat +hajlék +hajlékony +hajléktalan +hajlevágás +hajlít +hajlított +hajlik +hajlong +hajlongás +hajlott +hajmeresztő +hajnal +hajnalhasadási +hajnali +hajnalodik +hajnyírási +hajó +hajóállomás +hajógyár +hajógyári +hajóhad +hajóhíd +hajóhinta +hajójegy +hajókabin +hajókürt +hajólámpás +hajónagy +hajópadló +hajórakomány +hajós +hajóstiszt +hajóstörténet +hajószobor +hajótörött +hajózás +hajózó +hajol +hajpihe +hajrá +hajsza +hajszál +hajszálnyi +hajszálpontos +hajszálvékony +hajszol +hajszolás +hajt +hajtás +hajtat +hajthatatlan +hajtható +hajtó +hajtóerő +hajtóka +hajtókar +hajtórúd +hajtóvadászat +hajtömeg +hajtogat +hajtornyos +hajtű +hajú +hajvágás +hajviselet +hajzat +hajzuhatag +hajzuhatag-kerítés +hal +halál +halálbiztos +halálbüntetés +haláleset +halálfélelem +halálfej +halálfejes +halállista +halálos +halálozási +halálpofa +halálsápadt +halálsikoly +halánték +halántékér +halápi +halász +halászat +halászati +halászcsárda +halászember +halászforma +halászlé +halacska +halad +haladás +haladék +haladéktalan +haladó +halandzsa +halastó +halaszt +halaszthatatlan +halbelezés +haldoklás +haldoklik +haldokló +halhatatlan +halhatatlanság +halk +halkít +halkonzerv +halkul +halkupac +hall +hallás +hallajtó +hallanivaló +hallat +hallata +hallatlan +hallatszik +hallféle +hallgat +hallgatás +hallgatag +hallgatagság +hallgató +hallgatódzik +hallgatólag +hallgatólagos +hallgatóság +hallható +hallik +halló +hallóka +hallóz +hallomás +hallucinál +halmoz +halódik +halogat +halogatás +halom +halott +halottasszoba +halottlátó +halottsápadt +halpaprikás +halpiac +halszem +haltetű +halvány +halványbarna +halványkék +halványpiros +halványsárga +halványszínű +halványul +halványzöld +halvérű +hamar +hamarjában +hamarosan +hamis +hamisít +hamisítatlan +hamiskás +hamiskodik +hamisság +hamm +hamu +hamueső +hamuréteg +hamuszürke +hamutál +hamutálca +hamutartó +hamuzik +hamvas +hamvasság +hamvazószerdai +hancúrozás +hancúrozik +handabandázás +handabandázik +hanem +hang +hangadó +hangerő +hangfal +hangfogós +hangfoszlány +hanghatás +hanghordozás +hangjegy +hanglavina +hanglejtés +hangnem +hangocska +hangol +hangoló +hangorkán +hangos +hangosanbeszélő +hangosbeszélő +hangoskodás +hangoskodik +hangosság +hangoztat +hangoztatás +hangregiszter +hangsúly +hangsúlyoz +hangszál +hangszalag +hangszer +hangszín +hangszigetelt +hangszóró +hangtalan +hangtompítós +hangú +hangulat +hangulatélet +hangulatlámpa +hangulatos +hangulatú +hangulatvilág +hangulatvilágítás +hangváltás +hangverseny +hangversenyiroda +hangvihar +hangvilla +hangya +hangyaboly +hangzás +hangzású +hangzatos +hangzavar +hangzik +hangzócsoport +hant +hantolás +hanyag +hanyagol +hanyagság +hanyatlás +hanyatlik +hanyatt +hanyatt-homlok +harácsol +harácsoló +harákol +harag +haragít +haragkitörés +haragos +haragoszöld +haragszik +haragú +harakiri +harang +harangkötél +harangoz +harangozás +harangozó +harangszó +harangszoknya +harangvirág +harap +harapás +harapdál +harapófogó +harapós +harc +harcálláspont +harcászati +harcedzett +harci +harcias +harciasság +harciszekér +harciszekércsapat +harckocsi +harcmodor +harcol +harcos +harcsabajuszú +harcsaszáj +harctér +harisnya +harisnyás +harisnyahúzogatás +harisnyatartó +harkai +harmad +harmad-negyedéves +harmadév +harmadfél +harmadfokú +harmadik +harmadikutas +harmadmagával +harmadnap +harmadnapos +harmadolás +harmadrendű +harmat +harmatos +harminc +harminc-negyven +harmincad +harmincadik +harmincas +harmincéves +harmincegy +harmincegynéhány +harmincesztendős +harmincezer +harmincféle +harminchárom +harminchat +harminchat-negyven +harminchatezer +harminchét +harminckét +harminckét-harminchárom +harminckettő +harminckilenc +harmincnégy +harmincnyolc +harmincnyolcadik +harmincöt +harmincöt-harminchét +harmincöt-harmincnyolc +harmónia +harmonika +harmonikázik +harmonikus +harsány +harsan +harsanás +harsog +harsogás +harsona +harsonázás +has +hasábburgonya +hasacska +hasad +hasadás +hasadék +hasadozik +hasal +hasas +hascsikarás +hasfal +hasi +hasít +hasított +hasis +hasizom +hasmánt +hasogat +hasonlat +hasonlatos +hasonlatosság +hasonlít +hasonlíthatatlan +hasonlítható +hasonló +hasonlóképpen +hasonlóság +hasonszőrű +hasüreg +használ +használat +használati +használatlan +használatos +használhatatlan +használható +használhatóság +használt +hasznos +hasznosít +hasznosítható +haszon +haszonfa +haszonkulcs +haszonleső +haszontalan +haszontalanság +hasztalan +hat +hat-hét +hat-hétszáz +hat-húsz +hat-tíz +hatálytalanít +határ +határcsonkítás +határidő +határőr +határőrség +határőrség-parancsnokság +határol +határos +határoz +határozat +határozatlan +határozatlanság +határozott +határozottság +határper +határpont +határszél +határtalan +határvadász +határvadászsapka +határvidék +határvonal +hatás +hatásfok +hatásfokú +hatáskör +hatásos +hatásszünet +hatástalan +hatású +hatalmas +hatalmi +hatalmú +hatalom +hatalomátvétel +hatalomgyakorlás +hatalomszó +hatalomtudomány +hatalomvágy +hatékony +hatékonyság +hatéves +hatemeletes +hatezer +hatnapos +hatókör +hatórás +hatóság +hatósági +hatökör +hatökrös +hatodik +hatodmagával +hatodrangú +hatol +hatos +hatszáz +hatszázas +hatszázhuszonnégy +hatszáznegyvenkét +hattyú +hattyúdal +hatvan +hatvan-nyolcvanezer +hatvanas +hatvanéves +hatvanezer +hatvanféle +hatvanhárom +hatvanharmadik +hatvanhat +hatvanhét +hatvankét +hatvankilenc +hatvankilós +hatvannégy +hatvannyolc +hatvanöt +hatvanoldalas +havas +havasi +havazás +havazik +haver +haverozás +havi +havonta +haza +haza-hazatelefonál +hazaáruló +hazacsempész +hazaér +hazaérkezés +hazaérkezik +hazaenged +hazafelé +hazafi +hazafias +hazafiatlan +hazafuvaroz +hazagyalogol +hazahív +hazahord +hazahoz +hazahozat +hazai +hazaindul +hazajár +hazajárogat +hazajön +hazajövetel +hazajut +hazakészül +hazakészülődik +hazakerget +hazakerül +hazakísér +hazaköltözik +hazaküld +hazaküldöz +hazalátogat +hazamegy +hazamenés +hazamenekülés +hazamenetel +hazarohan +hazasétál +hazasiet +hazaszállít +hazaszabadul +hazaszalad +hazaszeretet +hazaszökik +hazatalál +hazatér +hazatérés +hazatérő +hazatelefonál +hazaugrik +hazautazik +hazavágyik +hazavár +hazavergődik +hazavetődik +hazavezet +hazavillamosozik +hazavisz +hazudik +hazudozás +hazudozik +hazudozó +hazug +hazugság +hazulról +he +hé +hébe-hóba +héber +héj +héjú +hékás +hélium +hérész +hét +hét-nyolc +hétéves +hétezer +hétfő +héthónapos +hétköznap +hétköznapi +hétpróbás +hétrét +hétszáz +hétszázadik +hétszázhúsz +hétszázötvenhat +hétvége +hétvégi +hév +hézag +hézagos +hebeg +hebehurgya +hebrencs +hecc +heccel +hederít +hedonista +heg +hegedül +hegedű +hegedű-zongora +hegedűgyakorlás +hegedűhúr +hegedűjáték +hegedűművész +hegedűs +hegedűtok +hegeszt +hegesztő +hegesztőapparátus +hegy +hegy-félkör +hegy-völgy +hegycsúcs +hegyén-hátán +hegyecske +hegyes +hegyesedik +hegyez +hegygerinc +hegyi +hegyibeszéd +hegyibeszédez +hegyláncolat +hegyoldal +hegyrajzi +hegység +hegyszagú +hegytető +hegyű +hegyvonulat +hehe +hehehe +heherészés +heherészget +heherészik +hej +hektó +hekus +helikoni +helikopter +helviai +hely +helybeli +helyben +helyben-tánc +helybenhagy +helycsere +helyénvaló +helyenként +helyes +helyesbít +helyesbítés +helyesel +helyesírás +helyesírási +helyeslés +helyesség +helyett +helyette +helyettes +helyettesi +helyettesít +helyez +helyezés +helyezett +helyezkedés +helyezkedik +helyeztet +helyi +helyiség +helyismeret +helykínálás +helynyi +helyőrség +helyőrségi +helyrajz +helyre +helyreáll +helyreállít +helyreállítás +helyrehoz +helyrehozhatatlan +helyreigazít +helyrerak +helység +helyszerző +helyszín +helyszínel +helyszínelés +helyszíni +helytáll +helytállás +helytálló +helytartó +helytelen +helytelenség +helyváltoztatás +helyzet +helyzeti +helyzetmegítélés +hemzseg +henceg +hencegés +hendikeppelés +henger +hengerelt +hentes +hentesbárd +hentesmester +hentesművész +hentessegéd +hepaj +hepciáskodás +hepehupás +herceg +hercegi +hercegné +hercegnő +hercehurca +here +herél +herélt +herendi +hergel +hering +hermelin +hermetikus +hernyó +hernyórágta +hernyótalp +hernyótalpas +hernyótest +hernyótestű +herseg +hersegtet +hervad +hervadt +hess +hesseget +hessentget +hetedíziglen +hetedik +hetenként +hetente +hetes +heti +hetilap +hetipiac +hetven +hetvenéves +hetvenezer +hetvenhat +hetvenhét +hetvenkét +hetvenkedik +hetvenkettő +hetvenöt +hetyeg +hetyke +heveder +hevederszíj +heveny +hevenyész +hevenyészett +hever +heverészik +heverő +heverőhely +heverőpléd +heves +hevesi +heveskedik +hevesség +hevít +hevül +hexensussz +híd +hídépítés +hídépítő +hídelem +hídfő +híg +hígeszű +hígítás +híja +híján +hím +hímez +hímnemű +hímzés +hímzőráma +hír +híradás +híradósautó +híranyag +híre-hamva +híres +híresség +híresztel +híresztelés +hírhálózat +hírhedt +hírközlés +hírközlő +hírlap +hírmondó +hírnév +hírneves +hírnök +hírszerzés +hírszerző +hírszolgálat +hírszolgáltatás +hírű +hírvétel +hírverés +hív +hívás +hívási +hívat +hívatlan +hívó +hívogat +hívogató +hívság +hívságos +hízás +hízeleg +hízelgő +hízik +hízlal +hízó +hízott +hiába +hiábavaló +hiábavalóság +hiány +hiánycikk +hiányérzet +hiányol +hiányos +hiányosság +hiányzik +hiányzó +hiba +hibás +hibátlan +hibázik +hibáztat +hibiszkusz +hibrid +hibridizációs +hideg +hideg-meleg +hidegfejű +hidegkonyha +hideglelős +hidegrázás +hidegség +hidegtál +hidegvér +hidegvérű +hidegvízű +hidrogén +hierarchia +hieroglifa +higany +higanyfény +higanymozgékonyságú +higgadt +higgadtság +higiénia +higiénikus +hihetetlen +hihetetlenség +hihető +hihi +himbál +himbálódzás +himbálódzik +himnusz +hindu +hint +hinta +hintás +hintázik +hintáztat +hintalánc +hintaszék +hintó +hipertrófia +hipertrófiás +hipnózis +hipnotizál +hipotézis +hipp-hopp +hirdet +hirdetés +hirdetmény +hirdető +hirdetőoszlop +hirdetőtábla +hirhedt +hirtelen +hirtelen-váratlan +hirtelenében +hirtelenség +história +históriai +hisz +hiszékeny +hiszem +hiszen +hisztéria +hisztériás +hisztériázik +hisztérikus +hit +hitbuzgalmi +hitélet +hitel +hiteles +hitelesít +hitelesség +hitelező +hitelrontás +hites +hitetlen +hitetlenkedik +hitetlenség +hitfél +hitközség +hitleri +hittani +hitvány +hitvallás +hitvédelem +hitves +hitvesi +hiú +hiúság +hivalkodás +hivalkodó +hivat +hivatás +hivatásos +hivatású +hivatal +hivatalból +hivatali +hivatalnok +hivatalnokember +hivatalnoki +hivatalos +hivatalsegéd +hivatkozás +hivatkozik +hivatva +hivő +hizlal +hizlaltat +hja +hm +hó +hóakadály +hóbagoly +hóborította +hóbort +hóbortos +hódít +hódítás +hódító +hódol +hódolat +hóesés +hófal +hófedte +hófehér +hófogsor +hófolyosó +hófúvásos +hógolyó +hóha +hóhér +hóhérpofájú +hóhérszerzet +hóhem +hóhemség +hóka +hókunyhó +hókupac +hókuszpókusz +hókuszpókuszol +hólé +hólepett +hólepte +hólyag +hólyagos +hólyagszerű +hómező +hón +hónalj +hónap +hónapi +hónapnyi +hónapos +hóolvadás +hópehely +hópihe +hórihorgas +hórukk +hótaraj +hótenger +hózentráger +höhö +hölgy +hölgyecske +hölgykutya +hölgyválasz +hömpölyög +hörböl +hörcsög +hördül +hörgés +hörgésszerű +hörög +hörpint +hörpöl +hő +hőbörgés +hőbörög +hőfok +hőhullám +hőigény +hőmérő +hőmérséklet +hőmérséklet-ingadozás +hőmérsékletbeli +hőmérsékletváltozás +hős +hőség +hősi +hősies +hősiesség +hősködik +hősnő +hőzöng +hodály +hogy +hogyan +hogyha +hogyhogy +hogyisne +hogyne +hogysem +hohó +hokedli +hokedliszerű +hol +hold +hold-éjjel +hold-expedíció +hold-magma +hold-nappal +holdacska +holdas +holdfény +holdfényszín +holdkráter +holdnyi +holdrakéta +holdsarló +holdtalan +holdvilág +holdvilágszín +holland +hollandi +hollandus +hollét +holló +hollóhaj +holmi +holnap +holnapi +holnapután +holott +holt +holta +holtág +holtbiztos +holtfáradt +holtpont +holtrészeg +holtsápadt +holttengeri +holttest +homály +homályos +homályosodik +homályosul +hombárszerű +homéroszi +homlok +homlokbőr +homlokfal +homloklebeny +homlokráncolás +homlokseb +homlokú +homlokzat +homok +homokbucka +homokdomb +homokdombvonulat +homokfutó +homokhegy +homoki +homokkő +homokos +homokozó +homokpart +homokpatak +homokréteg +homokszelídítő +homokszem +homokszemcse +homoktábla +homokút +homokzsák +homorít +hon +honalapító +honfitárs +honfitársnő +honfoglalás +honi +honn +honnan +honnét +honol +honorárium +honos +honosodik +hontalan +honvágy +honvéd +honvéd-munkaszolgálatos +honvédkerület +honvédő +honvédség +honvédtiszt +honvédtiszti +hopp +hoppá +hord +horda +hordár +hordás +hordalékmennyiség +hordat +hordó +hordómosó +hordoz +hordozórakéta +horgász +horgászás +horgászbot +horgászház +horgászik +horgásztanya +horganylemezes +horgol +horhos +horizont +horkan +horkanás +horkant +horkol +horkolás +hormon +hormontermelés +horog +horogkeresztes +horogütés +horony +horpadás +horpadékony +horpadt +horthy-csendőr +horthysta +hortobágyi +hortyog +hortyogás +horvát +horzsol +horzsolás +horzsolásszerű +hossz +hosszában +hosszabb-rövidebb +hosszabbítás +hosszadalmas +hosszan +hosszas +hosszat +hosszít +hosszú +hosszúkás +hosszúnap +hosszúság +hotel +hova +hová +hovatovább +hoz +hoz-visz +hozamú +hozat +hozatal +hozható +hozomány +hozományvadász +hozsannázik +hozzá +hozzáállás +hozzáad +hozzábiggyeszt +hozzábújik +hozzádörzsöl +hozzádől +hozzádrótoz +hozzáér +hozzáért +hozzáértés +hozzáértő +hozzáfér +hozzáférhetetlen +hozzáférhetetlenség +hozzáfog +hozzáfordul +hozzáfűz +hozzájárul +hozzájárulás +hozzájut +hozzákezd +hozzákötődik +hozzálát +hozzálép +hozzámegy +hozzámond +hozzánő +hozzányúl +hozzáperdül +hozzápótol +hozzáragad +hozzárajzol +hozzásegít +hozzászól +hozzászólás +hozzászokik +hozzászoktat +hozzátapad +hozzátartozik +hozzátartozó +hozzátesz +hozzátold +hozzávág +hozzávaló +hozzávesz +hú +húg +húgocska +húgy +húgyszag +húr +hús +húscsík +húshegy +húsleves +húsmennyiség +húsmentes +húsmező +húsos +húspiros +hússeb +hússzínű +hústalan +hústorony +húsú +húsvadász +húsvét +húsvéti +húsz +húsz-harminc +húsz-harmincéves +húsz-huszonegy +húsz-huszonkét +húsz-huszonöt +húszas +húszcentis +húszéves +húszezer +húszholdas +húz +húzás +húzat +húzgál +húzkod +húzódik +húzódozik +húzós +húzogat +hüledezik +hüllő +hüllőbőr +hülye +hülyéskedés +hülyéskedik +hülyeség +hümget +hümmög +hüppög +hüvely +hüvelyk +hüvelykujj +hű +hűbérúri +hűhó +hűl +hűlt +hűs +hűség +hűséges +hűségeskü +hűsöl +hűt +hűtés +hűtlen +hűtlenség +hűtőház +hűtőszekrény +hűtővíz +hűvös +hűvösödik +hűvösség +hugenotta +huhogás +huj +hujjogatás +hulcsi +huligán +huligánbanda +hull +hulla +hullám +hullámgép +hullámhossz +hullámos +hullámoztat +hullámpala +hullámszerű +hullámtaraj +hullámtér +hullámverés +hullámvonal +hullámzás +hullámzik +hulladék +hulladékfa +hulladékgyűjtő +hulladéktelep +hullafolt +hullajt +hullaszag +hullaszürke +hullatánc +hulldogál +hullott +humán +humánus +humanista +humanizmus +humor +humorizál +humoros +hun +huncut +huncutkodik +huncutság +hungarizálás +huny +hunyorgás +hunyorít +hunyorítás +hunyorog +hunyt +huppan +huppanós +hurcol +hurcolász +hurcolkodik +hurka +hurkatöltő +hurkol +hurok +hurrázik +husika +huszár +huszárarc +huszárszázad +huszártiszti +huszadik +huszadikai +huszita +huszonegy +huszonegyedik +huszonhárom +huszonharmadik +huszonhat +huszonhatodik +huszonhét +huszonhetedik +huszonkét +huszonkettedik +huszonkettedikei +huszonkettes +huszonkettő +huszonkilenc +huszonkilencedik +huszonnégy +huszonnégy-negyvenöt +huszonnégyezer +huszonnegyedik +huszonnyolc +huszonnyolcadik +huszonöt +huszonöt-harminc +huszonöt-negyvenöt +huszonötezer +huszonötödik +huszonötös +huzakodás +huzakodik +huzal +huzalka +huzamos +huzat +huzatos +huzatú +huzavona +huzigál +ibolya +ibolyakölni +ibusz-csoport +ibusz-út +icipici +idáig +ide +ide-oda +idén +idétlen +idéz +idézés +idézet +idézettöredék +idéző +idézőjeles +idea +ideál +ideális +ideáll +ideát +idead +idealista +idealizmus +ideapplikál +idebenn +ideér +ideérkezik +ideerőltet +idefigyel +ideg +idegbaj +idegborzoló +idegcsillapító +idegélet +idegen +idegenföldi +idegenforgalom +idegenkedés +idegenkedik +idegenség +idegenszerű +idegenvezető +ideges +ideges-izmos +idegesít +idegeskedés +idegeskedik +idegesség +idegfeszítő +idegfeszültség +ideggyógyász +ideggyógyászat +ideggyógyászati +idegi +idegkimerülés +idegláz +idegölő +idegösszeomlás +idegok +idegorvos +idegosztály +idegrendszer +idegrendszer-átültetés +idegrendszeri +idegroham +idegspecialista +idegszál +idegszanatórium +idegvégződés +idegzet +idehallatszik +idehallgat +idehallik +idehangzik +idehaza +idehelyez +idehív +idehord +idehoz +idei +ideír +ideig-óráig +ideiglenes +ideiktat +idejár +idején +idejegyez +idejekorán +idejön +idekészít +idekerül +idekinn +ideköltözés +ideköltözik +idekúszik +ideküld +ideküldet +idelátogat +idelátszik +idemegy +idenéz +ideológia +ideológus +idepiroslik +idepofátlankodik +iderohan +ideszámít +ideszabadul +ideszorul +ideszúr +idetalál +idetartozás +idetelepedik +idetesz +ideül +ideutazik +idevaló +idevalósi +idevesz +idillikus +idióta +idő +időhatár +időhúzás +időjárás +időköz +időközben +időlopás +időnként +időntúli +időpont +időrabló +időrend +idős +idősödik +időszámításunk +időszak +időszakos +időszerű +időtartam +időtlen +időtöltés +időutas +idővel +időveszteség +időzik +idomít +idomítás +idomtalan +idus +ifi +ifiasszony +ifibajnokság +ificsoport +ifiúr +ifjonc +ifjú +ifjúi +ifjúkor +ifjúkori +ifjúmunkás +ifjúság +ifjúsági +iga +igásállat +igásló +igaz +igazában +igazából +igazán +igazgat +igazgatás +igazgató +igazgatóék +igazgatóhelyettes +igazgatói +igazgatóné +igazgatónő +igazgatóság +igazgatósági +igazi +igazít +igazlátó +igazodás +igazodik +igazol +igazolás +igazoltat +igazoltatás +igazolvány +igazság +igazságos +igazságszolgáltatás +igazságtalan +igazságtalanság +igazságügyi +igaztalan +igazvadász +ige +igény +igénybevétel +igényel +igénylő +igénytelen +igénytelenség +igényű +igézet +igéző +igehirdető +igen +igen-igen +igencsak +igenel +igenis +igenlő +igric +igyekezet +igyekezik +ihaja +iható +ihlet +ihletett +ihol +ijed +ijedelem +ijedezik +ijedség +ijedt +ijedtében +ijedtség +ijeszt +ijesztés +ijesztget +ijesztő +iker +ikerlány +ikertestvér +ikon +ikrás +iksz +iksz-lábú +iktat +illat +illat-manöken +illatatom +illatfelhő +illatfolt +illathatás +illatos +illatosít +illatozik +illatrészecske +illatszer +illatszercég +illatszeres +illatú +illedelmes +illeg +illegális +illegalitás +illeget +illem +illemhely +illemtudó +illendő +illendőség +illeszkedik +illeszt +illesztget +illet +illetékes +illetéktelen +illetlen +illetlenség +illető +illetőleg +illetőségű +illetve +illír-kelta +illik +illóolaj +illő +illőképpen +illúzió +illusztráció +illusztrál +illusztris +ily +ilyen +ilyenfajta +ilyenféle +ilyenforma +ilyenformán +ilyenképpen +ilyenkor +ilyesfajta +ilyesféle +ilyesféleképpen +ilyesmi +ilyesvalami +ilyképpen +ima +imád +imádás +imádat +imádkozás +imádkozik +imádság +imágó +imaház +imakönyv +imaszíj +imaszövegféle +imazsák +imbolygás +imbolyog +imént +iménti +imitt-amott +immár +immúnis +imperátor +imperialista +imperializmus +imponál +imponáló +importál +impotens +impozáns +impresszió +impresszionista +impulzus +inas +inasiskola +inaskodik +inaszakadt +incidens +inda +indít +indítás +indíték +indítható +indító +indítógomb +indítókar +indítvány +indítványoz +indián +indiáner +indiánordítás +indiai +indigó +indikál +indiszkréció +indiszponált +indok +indoklás +indokol +indokolás +indokolatlan +indokolt +indokroham +indul +indulás +indulási +indulat +indulathullám +indulatos +indulatosság +indulatú +induló +infantilis +infarktus +infláció +influenza +influenzajárvány +információ +információháló +információs +informál +infrahang +infrapisztoly +infrastruktúra +infúzió +ing +ing-leng +inga +ingázik +ingázó +ingadozik +ingat +ingatag +ingatlankezelő +ingblúz +inger +ingerel +ingerkedik +ingerlés +ingerlő +ingerület +ingerült +ingerültség +inges +inggallér +inggomb +ingóság +ingoványos +ingujj +ingváll +ingyen +ingyenes +ingyengabona-osztás +ingyengabona-törvény +ingyensírhelyes +injekció +inkább +inkasszó +inkognitó +inkvizíció +inkvizíciós +inkvizítor +innen +innen-onnan +innenső +innivaló +inspekciós +int +intarzia +intés +intéz +intézés +intézet +intézeti +intézkedés +intézkedik +intézmény +intézményesít +intéző +integet +integetés +intelem +intellektuális +intellektualitás +intellektualizmus +intelligenciájú +intelligens +intenció +intenzív +intenzitás +interjú +interjú-módszer +interjúalany +intermezzo +internál +internáló +internet +interurbán +intim +intimitás +intő +intonáció +intrika +intuíció +intuitív +invázió +invenció +invitál +ionoszféra +ipar +iparág +iparági +iparcikkáruda +iparcikkbolt +iparengedély +iparfejlesztés +ipari +iparkodik +iparművészi +iparos +iparosítás +iparosmester +iparszerű +ipicsapacs +ipse +iránt +iránta +iránti +irány +irányadó +irányít +irányítás +irányítási +irányítgat +irányító +irányítórakéta +irányigazítás +irányoz +iránytű +irányú +irányul +irányulás +irányváltás +irányváltoztatás +irányvonal +irányzat +irányzék +iram +iramodás +iramodik +iramú +irat +iratcsomó +iratkozik +irattárca +irattartó +irdatlan +irgalmas +irgalmasság +irgalmatlan +irgalmatlanság +irgalmaz +irgalom +irha +irigy +irigyel +irigykedés +irigykedik +irigység +irinyó-pirinyó +irkál +irónia +iroda +irodaépület +irodaház +irodai +irodakisasszony +irodalmi +irodalmias +irodalom +irodalomkedvelő +irodalomtörténeti +irodaszemélyzet +irodavezető +irodista +irogat +iromány +ironikus +irt +irtó +irtózat +irtózatos +irtózik +irtóztat +is +isa +iskola +iskolás +iskolázott +iskolaépítés +iskolai +iskolaigazgató +iskolakerülés +iskolanap +iskolapénz +iskolatárs +iskolatársi +iskolatáska +ismét +ismétel +ismételget +ismételt +ismétlés +ismétlődik +ismer +ismerés +ismeret +ismeretanyag +ismeretes +ismeretlen +ismeretség +ismeretségi +ismeretszerzés +ismeretterjesztő +ismerkedés +ismerkedik +ismerő +ismerős +ismert +ismertet +ismertetés +ismertetőjel +ispán +istálló +istállóajtó +istállótulajdonos +istápol +istápolatlan +isten +isten-báránya +istenáldotta +istenasszony +istenbizony +istencsodája +istenfélő +istengömb +istenhivő +isteni +istenít +istenítés +istenigazában +istenigazából +istenkáromlás +istenkáromló +istenke +istenkereső +istenmadár +istennő +istenség +istentagadás +istentelen +istentisztelet +istenülés +istenverte +istenvitéz +iszákos +iszákosság +iszamós +iszap +iszapháború +iszapláva +iszaplepény +iszapolás +iszapos +iszapvezeték +iszik +iszogat +iszony +iszonyat +iszonyatos +iszonyodik +iszonytató +iszonyú +itáliai +ital +italbolt +italínyencség +italos +italozás +itat +itatás +itató +itt +itt-ott +ittas +itteni +itthagy +itthon +itthoni +ittlevő +ittmarad +iváni +ivás +ivadék +ivó +ivócimbora +ivópult +izé +izél +izélget +izeg-mozog +izgága +izgalmas +izgalom +izgat +izgató +izgatott +izgatottság +izgi +izgul +izmos +izom +izomcsomócska +izomláz +izommunka +izommutogató +izompacsirta +izomzat +izotóp +izraelita +izület +izületű +izzás +izzad +izzadság +izzadságfolt +izzadságszag +izzadságszagú +izzadt +izzít +izzik +izzó +ígér +ígéret +ígéretes +ígérget +ígérkezik +ígérő +így +így-úgy +íj +íjas +íjverseny +íme +ímmel-ámmal +ín +íny +ínycsiklandozó +ínyencfalat +ínyencség +ínyű +ír +ír-olvas +írás +írásjel +írásos +írástudó +írat +íratlan +írható +írisz +írnok +írnoki +író +író-fejedelem +író-olvasó +íróasztal +íródeák +írógép +írógép-zakatolás +írói +írós +írószer +írogat +ítél +ítélet +ítélethirdetés +ítéletű +ítélkezés +ítélkezik +ítélőképesség +ítélőszék +ív +ível +ívelés +ívelt +ívhosszúság +ívlámpa +ívszerű +ívű +íz +ízben +ízelt +ízeltlábú +ízes +ízes-magyaros +ízetlenség +ízig-vérig +ízlés +ízléses +ízléstelen +ízlésű +ízlel +ízlelget +ízletes +ízlik +ízű +ja +jácint +jámbor +jámborság +jánosáldás +jánoshegyi +jánus-szobor +jár +jár-kel +járás +járási +járásmód +járású +járadék +járat +járatlan +járatos +járatú +járda +járdaszegély +járdasziget +járdasziget-trükk +járgány +járhatatlan +járható +járkál +járkálás +jármű +járműváltás +járnivaló +járóföld +járóképtelen +járókelő +járőr +járogat +járszalag +járt +járta +jártányi +jártas +jártasság +jártató +járul +járulék +járulékos +járvány +jászol +játék +játékcica +játékkatona +játékmozdony +játékos +játékostárs +játékszabály +játékszer +játszadozik +játszik +játszma +játszódik +játszónap +játszónő +játszópajtás +játszótárs +játszótér +játszótéri +játszva +jabranc +jaguár +jaj +jajdul +jajgat +jajgatás +jajkiáltás +jajong +jajongás +jajszó +jajveszékel +jajveszékelés +jakobinus +január +januári +japán +japánujjú +jasszlegény +java +javában +javadalmaz +javak +javakorabeli +javall +javarészt +javasasszony +javaslat +javasol +javcsis +javít +javítás +javítgat +javítóintézet +javítóintézeti +javítós +javíttat +javul +jé +jég +jégcsap +jégdarab +jégeralsó +jégeralsós +jégeső +jéghideg +jéghintó +jéghokizik +jégkocka +jégkorong-szurkoló +jégkorongozó +jégkrém +jégoszlop +jégszekrény +jégtükör +jégverés +jégvirágos +jérce +jércetojásnyi +jézus +jézusisten +jézusmária +jézusom +jegenye +jegenyefa +jegenyefasor +jegenyesor +jeges +jegesmedve +jegy +jegyajándék +jegyellenőrző +jegyes +jegyesség +jegyez +jegyezget +jegygyűrű +jegypénztár +jegytelen +jegyzék +jegyzet +jegyzetblokk +jegyzetel +jegyzettömb +jegyző +jegyzőfüzet +jegyzőkönyv +jegyzőkönyvnyi +jegyzőkönyvvezetőnő +jehovista +jel +jeladás +jelen +jelenés +jelenet +jelenlét +jelenleg +jelenlegi +jelenlevő +jelenség +jelent +jelentékeny +jelentéktelen +jelentés +jelentésféle +jelentéstétel +jelentéstelen +jelentéstömb +jelentenivaló +jelentget +jelentkezés +jelentkezik +jelentkező +jelentő +jelentős +jelentőség +jelentőségteljes +jelentőségű +jeles +jelez +jelfogó +jelige +jelkép +jelképes +jelképesség +jelképez +jelképkutatás +jelképszerű +jelleg +jellegtelen +jellegű +jellegzetes +jellegzetesség +jellem +jellembeli +jellemerő +jellemez +jellemezget +jellemvonás +jellemző +jelmez +jelmondat +jelöl +jelölt +jelöltet +jelszó +jeltelen +jelvény +jelzálog +jelzés +jelzésű +jelzett +jelző +jelzőfény +jelzőharang +jelzőkészülék +jelzőrendszer +jelzőszám +jelzőszó +jelzőtábla +jelzőzászló +jerke +jeruzsálemi +jó +jóakarat +jóakaratú +jóakaró +jóarcú +jóbarát +jócselekedet +jócskán +jódszagú +jóéjszakát +jóérzés +jóember +jóféle +jófejű +jófiú +jóformán +jógázik +jóhiszemű +jóhiszeműség +jóízű +jóindulat +jóindulatú +jóisten +jóképű +jókedélyű +jókedv +jókedvű +jókívánság +jókor +jókora +jól +jól-rosszul +jólélek +jólét +jólelkű +jólelkűség +jólesik +jóleső +jóllakat +jóllakik +jóllakott +jóllakottság +jóllehet +jólnevelt +jómód +jómódú +jónapot +jónapotozik +jópofa +jóravaló +jórész +jórészt +jós +jóság +jóságos +jóslat +jósnő +jósol +jósoltat +jószág +jószágállomány +jószágcsereberélés +jószágtenyésztés +jószántából +jószagú +jószerencse +jószerint +jószerivel +jószívű +jószívűség +jótáll +jótanács +jótartású +jótékony +jótékonysági +jótét +jótett +jótevő +jóváhagy +jóváhagyás +jóvátétel +jóvátehetetlen +jóvátesz +jóval +jóvoltából +józan +józanít +józanodik +józanság +józsefvárosi +jöhető +jön +jön-megy +jött +jötte +jöttment +jövés-menés +jövedelem +jövedelmez +jövedelmező +jövendöl +jövendölés +jövendő +jövendőbeli +jövesztés +jövet +jövetel +jövevény +jövevényszó +jövő +jövőjű +jövőre +jobb +jobbágy +jobbára +jobbadán +jobban +jobbegyenes +jobbfajta +jobbösszekötő +jobboldal +jobboldali +jobbra-balra +jobbrafordulás +jobbulás +jog +jogász +jogar +jogegyenlőség +jogerő +jogfosztás +jogi +jogos +jogosít +jogosítvány +jogosság +jogosulatlan +jogosultság +jogsi +jogszabály +jogszokás +jogtalan +jogtalanság +jogtanácsos +jogtudós +jogtudomány +jogtudor +jogú +jonatán +jottányi +joviális +július +júliusi +június +júniusi +jubileum +jubileumi +jugoszláv +juh +juhász +juhászat +juhar +juhartermés +juhnyáj +juj +jurista +jut +jutányos +jutalék +jutalmaz +jutalom +juttat +juttatási +kába +kábel +kábít +kábítószer +kábítószeres +kábulat +kábult +kád +kádas +káder +káderszállás +káderutánpótlási +kállay-kormány +kálvária +kálvinista +kályha +kályhaajtó +kámzsa +kámzsás +kánai +kánikula +kápolna +káposzta +káposztás +káposztáshordó +káposztacsík +káposztafej +káposztalé +káposztalepke +káposztatábla +káposztatorzsa +káprázat +káprázik +kápráztató +kár +kárérték +kárhozat +kárhozik +káricsolás +kárminszájú +káröröm +kárörvendés +kárörvendezik +kárörvendő +károg +károgás +káromkodás +káromkodik +káromlás +káros +kárpitos +kárpitosmester +kárpitoz +kárpótlás +kárpótol +kártékony +kártérítés +kártevő +kártya +kártyás +kártyázás +kártyázgat +kártyázik +kártyatrükk +kátrány +kátránybetű +kátránylemez +kátránypapír +kátránypapíros +kátrányszagú +kátyú +kávé +kávébarna +kávécska +kávédaráló +kávéfőző +kávéfőzőgép +kávéház +kávéházi +kávémasina +kávésbögre +kávéscsésze +kávéskannácska +kávézik +kávézó +kabát +kabátgallér +kabátgomb +kabáthajtóka +kabátos +kabátszárny +kabáttalanodás +kabáttorony +kabátujj +kabátzseb +kabaré +kabasólyom +kabin +kabinos +kacag +kacagás +kacaj +kacarászik +kacat +kaccant +kacér +kacérkodik +kacérság +kackiás +kacsa +kacsázik +kacsahang +kacsaláb +kacsingat +kacsint +kacskaringó +kacskaringós +kacsó +kafeditó +kafferbivaly-hajtás +kaftán +kagyló +kagylóformájú +kagylófoteles +kagylóhéj +kagylóhintó +kagylóhosszabbító +kagylós +kaja +kaján +kajak +kajakozik +kajakversenyző +kajla +kajszibarack +kaka +kakál +kakaó +kakas +kakaskodik +kakaskukorékolás +kakasszó +kakastaraj +kakastollas +kakecos +kaktusz +kaktuszdália +kalács +kalácska +kaland +kalandornő +kalandos +kalandozik +kalandsorozat +kalandvágyó +kalap +kalapács +kalapácsnyi +kalapál +kalaplengetés +kalaplevéve +kalapos +kalauz +kalauz-egyenruha +kalauzkabát +kalauznő +kalauzol +kalauztáska +kaleidoszkóp +kaliba +kaliber +kaliberű +kalimpál +kalitka +kalkulál +kallantyú +kalligrafál +kallódik +kalmár +kalmárság +kalmopyrin +kalmük +kalózélet +kalocsai +kaloda +kamasz +kamasz-képzet +kamaszgyerek +kamaszkor +kamaszölelés +kamaszodik +kamaszos +kamaszos-bizalmas +kamaszvigyor +kamat +kamatmentes +kamatoztat +kambodzsai +kamera +kampány +kampánylelkű +kampec +kampó +kampósbot +kamra +kamraajtó +kamzsi +kamzsinyél +kan +kanál +kanális +kanálka +kanálnyi +kanári +kanárimadár +kanászcsalád +kanászkodik +kanadai +kanalas +kanalasgém +kanalaz +kanalazás +kanalazgat +kanapé +kanca +kancacsikó +kancellár +kancellária +kancellista +kancellistaszoba +kancsalít +kancsi +kancsó +kandalló +kandeláber +kandi +kandít +kandidál +kandidátus +kandidátusi +kandidatúra +kankós +kanna +kannibál +kanóc +kanonok +kanonokarckép +kanonoki +kantár +kantalupdinnye +kantin +kanyar +kanyargó +kanyargós +kanyarít +kanyarodik +kanyarodó +kanyarog +kanyarulat +kap +kapa +kapál +kapálás +kapálódzik +kapás +kapacitál +kapacitálható +kapacitás +kapafog +kapanyél +kapar +kaparás +kaparász +kaparászás +kapargál +kapargat +kaparint +kapaszkodik +kapaszkodó +kapaszkodóvas +kapatos +kapavágás +kapavágásnyi +kapca +kapcsán +kapcsol +kapcsolás +kapcsolat +kapcsolatfelvétel +kapcsolatos +kapcsoló +kapcsolódik +kapdos +kapható +kapirgál +kapiskál +kapitális +kapitány +kapitalista +kapitalizmus +kapituláció +kapitulál +kapitulálás +kapkod +kapni +kapó +kapós +kapocs +kapricpárna +kaptár +kaptafa +kapu +kapualj +kapubejárat +kapubolt +kapufa +kapufélfa +kapuhíd +kapukilincs +kapunyitás +kapunyitó +kapuőrség +kapuoszlop +kapus +kapusfráter +kapuügyelet +kapuzárás +kapzsi +kapzsiság +kar +kar-láb +karácsony +karácsonyeste +karácsonyfa +karácsonyfaégős +karácsonyi +karám +karabély +karaj +karakán +karakter +karakterjegy +karalábétábla +karambol +karambolozik +karaván +karbantart +karbantartás +karbantartási +karbantartó +karbid +karbidfény +karburátor +karcol +karcolás +karcsú +karcsúság +kard +kardbojt +kardigán +kardinális +kardiológus +kardos +kardvágás +karéj +karéjnyi +karfa +karfás +karhatalom +karhossznyi +karicsál +karika +karikás +karikagyűrű +karikalábú +karizom +karlendítés +karmantyú +karmazsinvörös +karmocska +karmos +karmozdulat +karnagy +karnevál +karnyújtásnyi +karó +karóra +karórás +karol +karom +karonfogva +karos +karosszék +karosszériájú +karpaszományos +karperec +karrier +karrierista +karriervágy +karszalagos +karsztos +kartárs +kartársnő +kartávolságnyi +karter +karton +kartonlap +kartonlapocska +kartonruha +kartonszerű +karú +karvastagságú +karzat +karzati +kas +kasa +kaska +kasmír +kassai +kassza +kasszírnő +kastély +kasza +kaszál +kaszálatlan +kaszáló +kaszáltat +kaszárnya +kaszárnyaszerű +kaszárnyatömb +kaszanyél +kaszavágás +kaszavágásnyi +kaszinó +kaszinótag +kaszt +katángkóró +kataklizma +katakomba +katalán +katalizátor +katapultterem +katasztrófa +katasztrófaszerű +katéterezés +katedra +katedrális +katedrálüveg +kategória +katlan +katódcső +katolikus +katona +katonás +katonásdi +katonáskodik +katonaarisztokrácia +katonabajtárs +katonacimbora +katonaélet +katonafénykép +katonafeleség +katonahumor +katonai +katonaidő +katonainduló +katonaing +katonakar +katonaköpeny +katonalány +katonalélek +katonaság +katonaszökevény +katonatárs +katonatiszt +katonatiszti +katonavicc +katonavonat +katonazene +katonazenekar +katonazubbony +kattan +kattanás +kattint +kattog +kavar +kavargás +kavargat +kavarodás +kavarog +kaviár +kaviáros +kaviárosdoboz +kavics +kavicsos +kazán +kazánajtó +kazánház +kazánkovács +kazal +kazetta +kégli +kéj +kéjes +kéjnő +kéjvágy +kék +kék-fehér +kék-zöld +kékcsíkos +kékes +kékesfehér +kékesfekete +kékesszürke +kékesszürkés +kékeszöld +kéklik +kékmintás +kékség +kékzubbonyos +kém +kémény +kéményes +kéményfüst +kéménylyuk +kémelhárítás +kémelhárító +kémelhárító-tiszt +kémiai +kémkedik +kémlel +kémnő +kénes +kénköves +kénsav +kénszínű +kénye-kedve +kényelem +kényelmes +kényelmeskedés +kényelmetlen +kényelmetlenség +kényelmi +kényes +kényeskedik +kényeztet +kényeztetési +kényszer +kényszercsevegés +kényszeredett +kényszeregyezség +kényszerháború +kényszerhelyzet +kényszerít +kényszerítő +kényszerképzet +kényszermosoly +kényszermunka +kényszermunkás +kényszerül +kényszerű +kényszerűség +kényszerzubbony +kénytelen +kénytelen-kelletlen +kényúr +kép +kép-isten +képadás +képernyő +képernyő-térkép +képernyős +képes +képesít +képesítés +képeskönyv +képeslap +képesség +képességű +képest +képez +képfelvevő +képfolyam +képgyűjtemény +képhangadó +képírómester +képkeret +képkeretező +képkísérő +képlékeny +képleadás +képlet +képletes +képmás +képmező +képmutatás +képmutató +képsor +képtelen +képtelenség +képű +képvisel +képviselet +képviselő +képviselő-testület +képviselőjelölt +képzés +képzel +képzelem +képzelet +képzeletbeli +képzeletfelhő +képzeletszülte +képzeletzavaró +képzelgés +képzelődés +képzelődik +képzelőerő +képzet +képzettség +képzettségű +képző +képződik +képződmény +képzőművész +képzőművészeti +kér +kérd +kérdés +kérdéses +kérdészuhatag +kérdez +kérdezés +kérdezetlen +kérdezett +kérdezget +kérdeznivaló +kérdező +kérdezősködés +kérdezősködik +kérdő +kérdőív +kérdőjel +kérés +kéredzkedik +kéreg +kéregető +kérelem +kérem +kéret +kéretlen +kérges +kéricsgél +kérkedik +kérlek +kérlel +kérlelhetetlen +kérlelő +kérő +kérő-mosolygó +kérődzik +kérvény +kés +kés-villa +késés +késedelem +kései +késik +késlekedik +késleltet +késnyél +késő +később +későbbi +későn +kész +készakarva +készenlét +készenléti +készít +készítés +készítmény +készíttet +készlet +készpénz +készség +készséges +késztet +készül +készülék +készülő +készülődés +készülődik +készültség +két +két-három +két-háromszáz +két-két +kétágú +kétágyas +kétarcú +kétbalkezes +kétcentis +kétcsúcsú +kétdecis +kétéltű +kétértelmű +kétértelműség +kétévenként +kétéves +kétévi +kételkedés +kételkedik +kétell +kétely +kétemeletes +kétes +kétesztendei +kétezer +kétezer-egyszáz +kétezer-egyszázas +kétezer-hatvan +kétezer-kétszáz +kétezer-százharmincnyolc +kétezer-tizedik +kétezerötszáz +kétezredik +kétfázisú +kétféle +kétféleképpen +kétfelé +kétforintos +kétharmad +kéthetenként +kéthetes +kétkedés +kétkedik +kétkerekű +kétkezi +kétkilós +kétkötetes +kétlábú +kétlépcsős +kétméteres +kétnaponként +kétnapos +kétnyelvű +kétórás +kétoldali +kétoldalra +kétoldalt +kétoldalú +kétrét +kétség +kétségbeejt +kétségbeejtő +kétségbeesés +kétségbeesett +kétségbeesik +kétségbevonhatatlan +kétséges +kétségkívül +kétségtelen +kétségtelenül +kétsoros +kétszárnyas +kétszárnyú +kétszáz +kétszáz-kétszázötven +kétszázéves +kétszázhatvan +kétszázhúsz +kétszázhuszonkét +kétszáznyolc +kétszázötven +kétszemélyes +kétszeres +kétszeri +kétszersült +kétszersültadag +kétszínű +kétszobás +kéttizedes +kétujjas +kéve +kéz +kézbentartó +kézbesítő +kézcsók +kézelő +kézenfekvő +kézenfogva +kézfej +kézfogás +kézi +kézírás +kézírásos +kézifegyver +kézigránát +kézikönyvtár +kézilabdázik +kézimunka +kézimunkázik +kézimunkaóra +kézirat +kézirosta +kézitáska +kézjegy +kézlenyomós +kézmosás +kézmozdulat +kézműves +kézmunka +kézrázás +kézről-kézre +kézujj +kézzel-lábbal +kézzelfogható +kebel +kebelbeli +keblű +kecsegtet +kecses +kecske +kecskebőr +kecskeláb +kecskelábú +kecskeméti +kecskerágó +kedd +keddi +kedély +kedélybeteg +kedélyes +kedélyeskedik +kedélyfenntartó +kedélykiegyenlítési +kedélytelen +kedélytelenség +kedélyű +kedélyváltozás +kedv +kedvderítő +kedvel +kedvelt +kedvenc +kedves +kedveske +kedveskedik +kedvesség +kedvetlen +kedvetlenség +kedvezmény +kedvező +kedvezőtlen +kedvtelés +kedvtelve +kedvű +kefe +kefél +kefebajusz +kefefrizura +kegy +kegydíj +kegyed +kegyelem +kegyelemdöfés +kegyelemteljes +kegyelet +kegyeletes +kegyelmed +kegyelmes +kegyelmez +kegyes +kegyeskedik +kegyesség +kegyességed +kegyetlen +kegyetlenkedik +kegyetlenség +kegyvesztés +kehely +kehes +kehhent +keksz +kel +kelés +kelengye +kelengyekészítés +kelepce +kelepel +kelet +kelet-európai +kelet-római +keleti +keleties +keletkezik +keletnémet +keletrómai +keletű +kelevény +kelevéz +kelkáposzta +kell +kellék +kellemes +kellemesség +kellemetes +kellemetlen +kellemetlenség +kellet +kellete +kelletlen +kelletlenség +kelletlenségérzés +kellő +kellős +kelmefestő +kelt +keltezésű +kelyhes +kemény +keményfa +keményfedelű +keménygallér +keményít +keményített +keményítő +keménykalap +keménykötésű +keménypapír +keménység +keménységű +keményszívűség +keménytojás +kemping +kempingasztal +kempingnadrág +ken +kend +kender +kenderáztatás +kenderáztató +kenderpozdorjalemez +kendő +kendős +keneget +kenet +kenetes +kenetesdoboz +kenetlen +kenetteljes +kengyel +kengyelvas +kenyér +kenyérdagasztás +kenyérhéj +kenyérkereset +kenyérládás +kenyérlepény +kenyérmaradvány +kenyérpirítás +kenyérpirító +kenyérszelet +kenyérszeletke +kenyérzsák +kenyereslány +kenyerespajtás +kerámia +keramikus +keramitkocka +kerék +kerékgyártó +kerékkötő +keréknyom +kerékpár +kerékpárlánc +kerékpáros +kerékpározik +kerékpártartó +kerékvágás +kerékvető +kerékvetőkő +kerek +kerekecske +kerekedik +kerekes +kerekít +kerekség +kerekű +kereng +kerepel +keres +keresés +kereset +kereseti +keresetlenség +keresetű +keresgél +keresgélés +kereskedelem +kereskedelmi +kereskedik +kereskedő +kereskedőember +kereskedősegéd +keresnivaló +kereső +kerestet +kereszt +keresztanya +keresztapa +keresztbe +keresztbe-hosszába +keresztbe-kasba +keresztbefektet +keresztben +keresztben-hosszában +keresztcsíkos +keresztcsont +keresztény +keresztényi +kereszténység +keresztel +keresztelő +keresztez +kereszteződés +keresztfa +keresztfiú +keresztfolyosó +keresztgyerek +keresztmetszet +keresztnév +keresztnevű +keresztpánt +keresztránc +keresztrejtvény +keresztség +keresztszülő +kereszttűz +keresztút +keresztül +keresztül-kasul +keresztülballag +keresztülfolyik +keresztülfon +keresztülfut +keresztülgázol +keresztülhalad +keresztülhúz +keresztüljön +keresztüllyukaszt +keresztülmegy +keresztülnéz +keresztülszánt +keresztülszel +keresztülszúr +keresztülüt +keresztülvág +keresztülver +keresztülvezet +keresztülvisz +keresztülzúdul +keresztutca +keresztvas +keresztvíz +keret +keretez +keretű +kerge +kergekóros +kerget +kergetőzik +kerít +kerítés +kerítésbástya +kerítésdrót +kerítésléc +kering +keringél +keringő +kert +kertajtó +kertész +kertészet +kertészeti +kertészkedés +kertészkedik +kertel +kertelés +kertes +kertfal +kerthelyiség +kerti +kertkapu +kertkultúra +kerül +kerület +kerületi +kerületparancsnok +kerületparancsnokság +kerülget +kerülgetés +kerülő +kerülőút +kerubalak +kese +keselyű +keselyűcsapat +keserédes +kesereg +kesergés +kesergő +keserít +kesernyés +keserű +keserű-szomorú +keserűség +keserv +keserves +keskeny +keskenyedik +keszeg +keszonszerű +keszthelyi +kesztyű +kesztyűs +kesztyűtartó +ketrec +kettéhasít +kettéoszt +kettéosztottság +kettészakad +kettészakít +kettészel +kettétör +kettétörik +kettévág +kettéválás +kettéválaszt +kettéválik +kettes +kettes-hármas +kettő +kettő-három +kettőhat +kettős +kettősség +kettőszázkilencvenkilenc +kettőszáznyolc +ketyeg +ketyegés +kevély +kevélység +kevés +kevésbé +kevéske +kevéssé +kever +keverék +keverés +keveredés +keveredik +keverget +kevert +kevesell +kezd +kezdés +kezdeményez +kezdeményezés +kezdeményező +kezdet +kezdeti +kezdetleges +kezdő +kezdőbetű +kezdődik +kezdve +keze-lába +kezel +kezelés +kezelési +kezelőorvos +kezelőszemélyzet +kezeltet +kezeslábas +kezicsókolom +kezű +khaki +ki +ki-be +ki-ki +ki-kifröccsen +ki-kihagy +ki-kijön +ki-kilépeget +ki-kimozdul +ki-kinéz +ki-kiránt +ki-kitöröl +kígyó +kígyóméreg +kígyószáj +kígyószerű +kígyózik +kíl +kímél +kímélet +kíméletes +kíméletlen +kíméletlenség +kín +kínál +kínálás +kínálgat +kínálkozik +kínai +kínaisárkány-repedés +kínhalál +kínlódás +kínlódik +kínos +kínos-keserves +kínosság +kínoz +kínozgat +kínoztat +kínszenvedés +kínzás +kínzó +kísér +kíséret +kísérget +kísérlet +kísérletezik +kísérleti +kísérő +kísért +kísértés +kísértet +kísérteties +kíván +kívánalom +kívánatos +kíváncsi +kíváncsiság +kíváncsiskodik +kívánkozás +kívánkozik +kívánság +kívánt +kívántat +kívül +kívül-belül +kívüle +kívüleső +kívüli +kiábrándít +kiábrándul +kiábrándulás +kiábrándult +kiágaskodik +kiáll +kiállás +kiállású +kiállhatatlan +kiállít +kiállítás +kiállítási +kiállító +kiállíttat +kiált +kiáltás +kiáltásváltás +kiáltható +kiáltó +kiáltoz +kiáltozás +kiáltvány +kiárad +kiáramlik +kiáraszt +kiárusít +kiárusítás +kiás +kiáztat +kiabál +kiabálás +kiabálhatnék +kiad +kiadás +kiadható +kiadó +kiadós +kiadvány +kiaggat +kiagyal +kiakaszt +kiaknáz +kialakít +kialakítás +kialakul +kialszik +kiapadhatatlan +kiaszik +kib +kib-história +kibámul +kibányász +kibabrál +kiballag +kibékül +kibélel +kibérel +kibelez +kibernerosz +kibernerosz-história +kibernetika +kibernetikai +kibernetikus +kibeszél +kibeszélget +kibetűz +kibír +kibírhatatlan +kibírható +kibic +kibicel +kibiciklizik +kibillen +kibiztosít +kiböjtöl +kibök +kiböngész +kibővít +kibocsát +kibombáz +kibombázás +kibomlik +kibont +kibontakozás +kibontakozik +kiborít +kiborogat +kiborotvál +kiborul +kibotorkál +kibújik +kibújtat +kibúvó +kibuggyan +kibugyog +kibukik +kibukkan +kicibál +kicipel +kicirkalmaz +kicsal +kicsap +kicsapódik +kicsapongás +kicsapongó +kicsattan +kicsavar +kicsendül +kicserél +kicserélődés +kicsi +kicsírázik +kicsihol +kicsikar +kicsike +kicsikét +kicsinál +kicsiny +kicsinyég +kicsinyes +kicsinyeskedik +kicsinyesség +kicsinyít +kicsinylő +kicsinység +kicsipeget +kicsit +kicsoda +kicsomagol +kicsordul +kicsorog +kicsoszog +kicsúfol +kicsúszik +kicsüng +kicsusszan +kidagad +kidekorálás +kiderít +kiderítetlen +kideríthetetlen +kiderül +kidöglik +kidönt +kidörgöl +kidörzsöl +kidől +kidob +kidobál +kidohányoz +kidolgoz +kidolgozott +kidomborodik +kidribliz +kidühöng +kidülled +kidug +kiég +kiégett +kiéhezett +kiéhezik +kiélesedik +kiélesít +kiélez +kiéleződés +kiélt +kiélvez +kiépít +kiépül +kiér +kiérdemel +kiérez +kiérkezik +kiérzik +kiérződik +kiegészít +kiegészítés +kiegészítő +kiegészül +kiegyenesedik +kiegyenesít +kiegyengetés +kiegyenlít +kiegyensúlyoz +kiegyensúlyozatlan +kiegyensúlyozott +kiegyensúlyozottság +kiejt +kiejtés +kielégít +kielégítés +kielégíthetetlen +kielégíthető +kielégítő +kielégítődik +kielégülés +kielégülésnyugalom +kielégületlen +kiemel +kiemelés +kiemelkedik +kiemelkedő +kienged +kiengesztel +kiereszt +kierőszakol +kies +kiesés +kiesik +kieszel +kietlen +kievickél +kifárad +kifáraszt +kifacsar +kifaggat +kifagy +kifakad +kifakadás +kifarag +kiféle-miféle +kifényesedik +kifényesít +kifényesül +kifér +kifésül +kifehéredik +kifejez +kifejezés +kifejezésmód +kifejezéstelen +kifejezett +kifejező +kifejleszt +kifejlődik +kifejt +kifejtetlen +kifekszik +kifelé +kifelejt +kifeslik +kifest +kifestet +kifeszít +kifeszül +kifiguráz +kifigyel +kifinomul +kifizet +kifizető +kifli +kiflimaradék +kifőz +kifog +kifogás +kifogásol +kifogástalan +kifogy +kifogyhatatlan +kifolyat +kifolyik +kifolyólag +kifordít +kifordul +kiforgat +kiformál +kiforráz +kiforratlan +kifoszt +kifúj +kifúr +kifüggeszt +kifürkész +kifürkészhetetlen +kifüstöl +kifűrészel +kifűz +kifullad +kifut +kifutó +kifutópálya +kigaloppozik +kigömbölyödik +kigördül +kigőzölgés +kigombol +kigondol +kigúnyol +kigurul +kigyógyul +kigyötrődik +kigyúl +kigyullad +kihámoz +kihány +kihátrál +kihagy +kihagyás +kihajít +kihajlik +kihajol +kihajt +kihajtogat +kihal +kihalász +kihallatszik +kihallgat +kihallgatás +kihallgatóterem +kihallgatott +kihalt +kiharcol +kihasad +kihasít +kihasznál +kihasználás +kihasználatlan +kihasználódik +kihat +kihatású +kihegyez +kihever +kihevül +kihímez +kihív +kihívó +kihízlal +kihirdet +kihirdetés +kihord +kihoz +kihozat +kihúz +kihűl +kihűlés +kihull +kihuny +kihunyás +kihurcol +kiír +kiigazít +kiigazodik +kiindul +kiindulási +kiindulópont +kiiratkozik +kiirt +kiirtat +kiismer +kiismerhetetlen +kiismerhető +kiiszamodik +kiiszik +kiizzad +kijár +kijárási +kijárat +kijárati +kijátszik +kijavít +kijavítható +kijegyez +kijelent +kijelentés +kijelentőlap +kijelöl +kijózanodik +kijön +kijövet +kijut +kikászálódik +kikandikál +kikanyarodik +kikap +kikapar +kikapaszkodik +kikapcsol +kikapcsolódás +kikapkod +kikémlel +kikényszerít +kiképez +kiképzés +kiképzési +kiképzett +kiképző +kiképzőtiszt +kikér +kikérdez +kikérő +kikészít +kikészítés +kikészül +kikefél +kikel +kikeményít +kikerekedik +kikeres +kikerget +kikerül +kikerülés +kikerülget +kikerülhetetlen +kikerülhető +kikeveredik +kikezd +kikísér +kikísérletez +kikiált +kikiáltás +kikiabál +kiköltözik +kikönyököl +kikönyörög +kiköp +kiköt +kikötés +kikötöz +kikötő +kikötőforgalom +kikötői +kikötőstég +kikövetkeztet +kiközösít +kikocsikázik +kikocsizik +kikopik +kikopogtat +kikortyol +kikosaraz +kikotol +kikotor +kikristályosodik +kiküld +kiküszöböl +kiküszöbölhető +kiküzd +kikukkant +kikukucskál +kikunyerál +kilábal +kilát +kilátás +kilátástalan +kilátástalanság +kilátó +kilátóablak +kilátóhely +kilátszik +kilakkoz +kilép +kilépés +kilét +kilehel +kilenc +kilenc-tíz +kilenc-tizenegy +kilencéves +kilencedik +kilences +kilenclyukú +kilencmilliméteres +kilencszáz +kilencszázhuszonegyes +kilencszáznegyven +kilencszáznegyvenöt +kilencszáznegyvenötös +kilencszázötven +kilenctized +kilencven +kilencvenegy +kilencvenes +kilencvenkettő +kilencvenkilenc +kilencvennégy +kilencvennégyes +kilencvennyolc +kilencvenöt +kilencvenöt-száz +kilencvenötös +kiles +kileskel +kilibben +kilincs +kilincsel +kilincselés +kiló +kilócska +kilódít +kilóg +kilógat +kilós +kilök +kilökdös +kilökődik +kilötyögtetés +kilő +kiloccsan +kilométer +kilométeres +kilométerkő +kilométernyi +kilop +kilottyan +kilovagol +kilowattos +kilyukad +kilyukaszt +kimásolás +kimászik +kimagaslik +kimagasló +kimagasodik +kimagyaráz +kimagyarázkodik +kimar +kimarad +kimaradozás +kimarkol +kimélyít +kimér +kiméreget +kimért +kimegy +kimenekül +kimenet +kimenetelű +kimeneti +kimenő +kiment +kimered +kimereget +kimereszt +kimerít +kimeríthetetlen +kimerítő +kimerül +kimerült +kimerültség +kimetsz +kimond +kimondás +kimondat +kimondatlan +kimondhatatlan +kimondott +kimonó +kimos +kimozdul +kimozgat +kimúlik +kiművel +kiművelés +kimulat +kimunkál +kimutat +kimutatás +kimutatható +kincs +kincsesláda +kincstár +kincstári +kinéz +kinézésű +kinevet +kinevez +kinevezés +kinn +kinnfelejt +kinő +kinti +kinyaklik +kinyal +kinyílik +kinyír +kinyiffantás +kinyiladozik +kinyilatkoztat +kinyilatkoztatás +kinyilvánít +kinyit +kinyithatatlan +kinyitható +kinyög +kinyom +kinyomat +kinyomoz +kinyomtat +kinyomul +kinyújt +kinyújtózik +kinyújtóztat +kinyúl +kinyúlik +kiöblít +kiöblösödik +kiömlik +kiönt +kiöntés +kiöntő +kiöregedik +kiokád +kiokosít +kiokoskodik +kioktat +kioktatás +kioktató +kiold +kioldódik +kioldozgat +kiollóz +kiolt +kiolvas +kioperál +kioson +kioszk +kioszt +kipárolgás +kipadoz +kipakol +kipattan +kipeckel +kipenderít +kipereg +kipihen +kipihent +kipillant +kipingál +kipirul +kipislant +kipiszkál +kipofoz +kipofoztat +kiporol +kipotyog +kiprésel +kipreparál +kipróbál +kipróbálás +kipúderoz +kipucol +kipufogó +kipufogócső +kipufogógáz +kipuhatol +kipuhatol-tapogat +kipukkan +kipusztít +kipusztul +kipusztulás +király +királyasszony +királydinnye +királyfi +királyi +királyka +királykondor +királyné +királynéi +királynő +királynői +királyság +királysági +királytigris +királyválasztó +kirámol +kirándul +kirándulás +kirándulóhely +kirángat +kiránt +kiráz +kirabol +kiragad +kirajzol +kirajzolódik +kirajzszegez +kirak +kirakat +kirakatablak +kirakatbaba +kirakodik +kirakodóvásár +kirekeszt +kirendel +kirendeltség +kirepül +kirepülés +kirívó +kiröhög +kiröppen +kirobban +kirobbanás +kirobbanható +kirobbant +kirohan +kiront +kirostál +kirothad +kirothaszt +kirúg +kirúgat +kirúgatási +kiruccanás +kiruházkodik +kirukkol +kis +kiságy +kisárgul +kisázsiai +kisablak +kisajátít +kisajtó +kisangyal +kisanya +kisapa +kisasszony +kisasztal +kisbaba +kisbalta +kisbirtokos +kiscsirke +kisded +kisdiák +kisétál +kisebb-nagyobb +kisebbedik +kisebbfajta +kisebbít +kisebbrendű +kisebbség +kisebbségi +kisebesedik +kisegít +kisegítő +kiselőadás +kisember +kiserked +kiserken +kisesti +kisfia +kisfiú +kisfiús +kisfröccs +kisgazda +kisgazdapárt +kisgazdapárti +kisgyerek +kisgyerekkor +kisgyermek +kisír +kisiet +kisiklás +kisiklik +kisilabizál +kisimít +kisimul +kisipari +kisiparosi +kiskabát +kiskanál +kiskanna +kiskapu +kiskatona +kiskereskedő +kiskörzet +kiskörzeti +kiskoma +kiskosár +kiskutya +kislámpa +kislány +kislánykor +kislánykori +kislányos +kisliba +kismacska +kisméretű +kismester +kismiska +kisnemes +kisnyilas +kisöcs +kisöpör +kisöreg +kisodor +kisodródik +kisomfordál +kispárna +kispad +kispajtás +kisparaszt +kisparaszti +kisparasztság +kispekulál +kispesti +kispohár +kispolgár +kispolgári +kisportolt +kissé +kisszoba +kistányér +kisteknő +kistermetű +kistestvér +kistisztviselő +kistőkés +kistükör +kisújszállási +kisúr +kisül +kisüsti +kisüt +kisüzem +kisugárzás +kisugárzik +kisuhan +kisujj +kisurran +kisuvikszol +kisváros +kisvárosi +kisvártatva +kisvacsora +kisvasút +kisvasutazik +kisvendéglő +kisvonat +kiszáll +kiszállás +kiszámít +kiszámíthatatlan +kiszámítható +kiszámol +kiszárad +kiszab +kiszabás +kiszabadít +kiszabadul +kiszaggat +kiszagol +kiszakad +kiszakít +kiszakítás +kiszalad +kiszaladgál +kiszélesedik +kiszélesít +kiszélesítés +kiszed +kiszedeget +kiszedhető +kiszekál +kiszellőztet +kiszemel +kiszenved +kiszerel +kiszív +kiszikkad +kiszikkasztás +kiszimatolás +kiszista +kiszivárgás +kiszivárog +kiszivattyúz +kiszól +kiszólás +kiszór +kiszögez +kiszökik +kiszolgál +kiszolgálás +kiszolgáló +kiszolgálónő +kiszolgáltat +kiszolgáltatás +kiszolgáltatott +kiszolgáltatottság +kiszorít +kiszorítás +kiszorul +kiszorulás +kiszúr +kiszűr +kiszűrődik +kiszusszant +kitágít +kitágul +kitálal +kitámaszt +kitámogat +kitámolyog +kitár +kitárt +kitárul +kitárulkozás +kitárulkozik +kitát +kitakar +kitakarít +kitakarózik +kitalál +kitaníttat +kitanul +kitanulmányoz +kitapasztal +kitapétáz +kitapint +kitapogat +kitapos +kitart +kitartás +kitartó +kitép +kitér +kitérés +kitérít +kitérő +kiteker +kitekerődzik +kitekint +kitelepít +kitelepítés +kitelik +kiteljesedés +kiteljesít +kitenyészt +kiterebélyesedik +kitereget +kiterelget +kiterít +kiterítkezik +kiterjed +kiterjedésű +kiterjeszkedik +kiterjeszt +kitermelhető +kitervel +kitervez +kitervező +kitessékel +kitesz +kitilt +kitipeg +kitisztít +kitisztíttatás +kitisztul +kitódul +kitölt +kitöm +kitör +kitörés +kitörik +kitöröl +kitörölhetetlen +kitörő +kitörőfélben +kitol +kitolás +kitolakodik +kitold +kitolódik +kitoloncol +kitoloncoltat +kitüntet +kitüntetés +kitüntetéses +kitüntetett +kitüntető +kitűnik +kitűnő +kitűnőség +kitűz +kiújul +kiúszik +kiút +kiügyeskedik +kiül +kiültet +kiüresedik +kiürít +kiüríttet +kiürül +kiüt +kiütés +kiütközik +kiüzen +kiűz +kiugrat +kiugrik +kiugró +kiutál +kiutal +kiutalás +kiutasít +kiutasítás +kiutazik +kivág +kivágás +kivágat +kivágódik +kivágott +kivágtat +kiváj +kiválaszt +kiválasztás +kiválasztódás +kiválasztott +kiválasztottság +kiválik +kiváló +kiválóság +kiválogat +kivált +kiváltképpen +kiváltság +kiváltságos +kivándorlás +kivándorló +kivándorol +kivánszorog +kivár +kivackolódik +kivagdal +kivagyiság +kivakar +kivall +kivan +kivarr +kivasal +kivasalt +kivéd +kivédhetetlen +kivégez +kivégeztet +kivégzés +kivénhedt +kivétel +kivételes +kivételez +kivéve +kivehetetlen +kivehető +kiver +kiverődik +kivesz +kivet +kivetett +kivetít +kivetkőztet +kivetnivaló +kivezet +kivív +kivibrál +kivicsorít +kivihetetlen +kivilágít +kivilágítatlan +kiviláglik +kivilágosodik +kivillamosozik +kivillan +kivillant +kivillog +kivirágzik +kivirrad +kivirul +kivirulás +kivisz +kivitel +kivitelezés +kivitelező +kiviteli +kivitelű +kivitet +kivizsgál +kivörösödik +kivon +kivonat +kivonatozik +kivontat +kivonul +kivonulás +kizár +kizárás +kizárásos +kizárólag +kizárólagos +kizárt +kizakatol +kizökken +kizökkent +kizöldül +kizötyög +kizsákmányol +kizsákmányolás +kizsarol +kizsebel +kizsuppol +kizúdul +kizuhan +kizuhog +klapka-induló +klassz +klasszicista +klasszikus +klastrom +klaviatúra +klerikális +klienskirály +klienskirályság +klikk +klimaxos +klinika +klinikai +klór +klottnadrágos +klozett +klub +klubtárs +klubterem +kóbor +kóborlás +kóborló +kóborog +kóborol +kócmadzag +kócol +kócos +kódex +kókadt +kókusz +kónuszos +kópé +kór +kórház +kórházbarakk +kórházépület +kórházfelszerelés +kórházi +kóringyál +kórisme +kórképző +kórlefolyás +kóró +kórókerítés +kórószáraz +kórokozó +kóros +kórterem +kórtermi +kórus +kóser +kóstol +kóstolgat +kóstoló +kószál +kószálás +kótyagos +kótyavetye +kóvályog +köbdeciméter +köblös +köbméter +köcsög +köcsögfa +köcsögkészítő +köd +ködfolt +ködfoltocska +ködgomoly +ködhullám +ködkacskaringózta +ködmön +ködmönös +ködös +ködszagú +ködszerű +ködzsák +ködzuhatag +köhécsel +köhint +köhög +köhögés +köhögéscsillapító +kökény +kölcsön +kölcsönad +kölcsönhatás +kölcsönkap +kölcsönkér +kölcsönlakás +kölcsönös +kölcsönöz +kölcsönvesz +köldöknyílás +köldökzsinór +köleskása +kölni +kölniillat +kölnisüveg +kölniszag +kölnivíz +költ +költészet +költekező +költemény +költöget +költözés +költözik +költöztetés +költő +költő-filozófus +költő-lét +költői +költőpénz +költség +költséges +költségvetés +kölyök +kölyökcsapat +kölyökkor +köménymag +köménymagos +könny +könnycsepp +könnyebbség +könnyed +könnyedén +könnyedség +könnyelmű +könnyelműség +könnyen +könnyes +könnyezik +könnyít +könnytelen +könnyű +könnyűfém +könnyűség +könnyűsúlyú +könnyűszerrel +köntös +könyök +könyökhajlat +könyöklő +könyököl +könyöradomány +könyörgés +könyörög +könyörtelen +könyörület +könyv +könyvbarát +könyvcím +könyvecske +könyvel +könyvelés +könyvelő +könyvelőnő +könyvelőség +könyves +könyvespavilon +könyvespolc +könyvkereskedés +könyvkiadó +könyvkötő +könyvpiac +könyvszekrény +könyvtár +könyvtáros +könyvtárszoba +könyvügynök +könyvvitel +köp +köpcös +köpdös +köpés +köpésnyi +köpeny +köpenyes +köpenygomb +köpköd +köpködés +köpönyegű +kör +körbe +körbeáll +körbefog +körbefordul +körbefut +körbehord +körbeint +körbejár +körbekacsázik +körbekerget +körbekínál +körbelakik +körbemutat +körben +körbenéz +körbenézeget +körbepillant +körberak +körberohan +körbesétál +körbeszaglász +körbeszalad +körbeszar +körbeül +köré +körébe +köréje +körfésű +körfolyosó +körforgás +körgát +körhintás +körít +körítés +körív +körlet +körletvezető +körlevél +körmenet +körmödzik +körmöl +körmondat +körmű +környék +környékbeli +környékez +környéki +környezet +környezettanulmány +környezetváltozás +környező +köröm +körömcipő +körömlakk +körömpassz +körönd +körös-körül +körötte +köröz +körözés +körözvény +körorvos +körpálya +körséta +körte +körtebefőtt +körtefa +körút +körúti +körül +körüláll +körülárkol +körülbámészkodik +körülbelül +körülcsavar +körüldong +körülevez +körülfog +körülfolyik +körülfon +körülfut +körülgyűrűz +körülhatárol +körülhatárolható +körülhatároltság +körülhordoz +körüli +körülír +körüljár +körüljártat +körülkémlel +körülkerít +körülkoszorúz +körülleng +körülles +körülmagyaráz +körülmény +körülményes +körülmosolyog +körülmutat +körülnéz +körülölel +körülötte +körülötte-fölötte +körülözönlik +körülpárnáz +körülpillant +körülpólyáz +körülrajzol +körülrak +körülrekeszt +körülsétál +körülszaglász +körülszagol +körültámaszt +körültáncol +körültapogat +körülteker +körültekint +körültekintés +körültekintő +körülül +körüludvarol +körülugrál +körülvesz +körülvezet +körülzár +körű +körutazás +körvonal +körzet +körzeti +kösz +köszön +köszönés +köszönésféle +köszönet +köszönget +köszönő +köszönőember +köszönőlevél +köszönt +köszöntés +köszörül +köszvény +köt +kötél +kötélpálya +kötéltánc +kötéltáncos +kötény +kötényes +kötényke +kötényzseb +kötés +köteg +kötekedik +kötekedő +kötelék +kötelem +köteles +kötelesség +kötelez +kötelezettség +kötelező +kötet +kötetlen +kötetlenség +kötetnyi +kötött +kötöttfogású +kötöttség +kötöz +kötözés +kötözködés +kötözködik +kötözött +kötöző +kötözőhely +kötőanyag +kötődés +kötődik +kötőfék +kötszer +kötvény +kövér +kövérke +kövérkés +kövérszerű +kövérzöld +köves +kövesút +követ +követés +követel +követelés +követelmény +követelődzés +követelődzik +követhető +követi +következésképpen +következetes +következetesség +következetlen +következetlenség +következik +következmény +következményű +következő +következőképpen +következtében +következtet +következtetés +követő +követség +követségi +kövezet +kövezetlen +kövidinka +kövül +kövület +köz +közbe +közbeavatkozik +közbeeső +közbegáncsol +közbejön +közbelép +közbelépés +közbemordul +közben +közbenjár +közbenjárás +közbenjáró +közberikkant +közbeszól +közbeszúr +közbeszurkál +közbevág +közbevet +közbizalom +közé +közéje +közélet +közéleti +közép +középember +középen +középgomb +középiskola +középiskolás +középiskolai +középkezdés +középkor +középkori +középkorú +középosztály +középparaszt +középparaszti +középpont +középponti +középrerántás +középső +középtáj +középtermetű +középület +középütt +közérdeklődés +közérdekű +közért +közérthető +közérzés +közérzet +közeg +közegészségügyi +közegellenállás +közel +közelálló +közelebbről +közeledés +közeledik +közeledte +közeleg +közelharc +közeli +közelít +közellátási +közellakó +közelmúlt +közelség +közember +közepes +közepette +közepű +közerő +közfigyelem +közgazdász +közgazdasági +közgazdaságtan +közgazdaságtudomány +közgyűlés +közhasználat +közhasználatú +közhasznú +közhely +közhír +közhit +közhivatal +közhivatalnok +közízlés +közibe +közibecsap +közigazgatási +közintézmény +közismert +közkatona +közkeletű +közkincs +közkórház +közlator +közlékeny +közlés +közlésvágy +közlegény +közlekedés +közlekedési +közlekedésrendészet +közlekedik +közlemény +közlendő +közmegelégedés +közmondásos +közmű +közművesít +közmulatság +köznap +köznapi +köznyelv +közöl +közölnivaló +közömbös +közömbösít +közömbösség +közönség +közönséges +közöny +közönyös +közönyösség +közös +közösség +közösségi +közösülés +között +közötti +közoktatásügyi +közpark +központ +központbeli +központi +közread +közrecsíp +közrefog +közrejátszik +közreműködés +közreműködik +közrend +közreszorít +közröhej +község +községháza +községi +közszáj +közszabadság +közszükségleti +köztársaság +köztársasági +közte +köztér +köztermészetű +közti +köztisztelet +köztörvényes +köztudomású +közúti +közügyvéd +közül +közüle +közüzemi +közvélemény +közvéleményalakító +közveszélyes +közvetett +közvetít +közvetítés +közvetítő +közvetlen +közvetlenkedik +közvetlenség +közvetve +közvilágítás +kő +kőábrázat +kőakna +kőangyal +kőbánya +kőbányász +kőbányai +kőbalta +kőbolygó +kődarab +kődézsa +kődobálás +kődobásnyi +kőfal +kőfaragás +kőfaragó +kőfej +kőfűrész +kőgörgeteg +kőház +kőhajításnyi +kőhalmaz +kőhalom +kőhasáb +kőhegyű +kőírási +kőkemény +kőkocka +kőkút +kőlap +kőlépcső +kőműves +kőműves-bizalmi +kőművesbanda +kőnehezék +kőóriás +kőolajfúrási +kőoroszlán +kőoszlop +kőpáncél +kőpadló +kőpadozat +kőpart +kőpor +kőrakás +kőrengeteg +kőrises +kősír +kőszegi +kőszikla +kőszilánk +kőszörny +kőszobor +kőtaraj +kőtenger +kőtömb +kőtömeg +kőtörés +kőtojás +kőttes +kőút +kőzápor +kőzet +kőzetfelület +kőzetviszony +kőzúzalék +koalíció +koalíciós +kobak +koca +kocavisítás +koccan +koccanás +koccint +koccintás +kocka +kockás +kockázat +kockázatos +kockázik +kockázó +kockáztat +kockáztatás +kockacukor +kockakő +kocog +kocogtat +kocsány +kocsányápoló +kocsi +kocsiajtó +kocsibak +kocsifényező +kocsiforgalom +kocsigyár +kocsigyártó +kocsikázik +kocsikáztat +kocsikaraván +kocsikísérő +kocsimosás +kocsioldal +kocsirádió +kocsis +kocsisor +kocsiút +kocsma +kocsmáros +kocsmázik +kocsmaajtó +kocsmaféle +kocsmai +kocsmatöltelék +kocsmazaj +kocsonyás +kofa +kofa-kávéház +kofálkodás +koffer +kohézió +kohó +kohómérnök +koholt +kokott +kokszagiz +koktél +kolbász +kolbászkarika +koldul +koldulás +kolduló +koldus +koldus-senki +koldusasszony +koldusbarát +koleszterin-háztartás +kolk +kolléga +kolléganő +kollégista +kollégistatalálkozó +kollégium +kollégiumi +kollégiumos +kollegina +kollektív +kollektíva +kollektivista +kollektivizálás +kollerjáratos +kolónia-gömbhajó +kolomp +kolompszó +kolostor +kolozsvári +koma +komál +komámasszony +komáromi +kombináció +kombinációs +kombinál +kombinált +kombinatorika +kombiné +kombinérészlet +kombinés +komédia +komédiázás +komfortos +komikum +komikus +komisz +komiszkodik +komité +komló +komlói +komlóinda +kommandíroz +kommendál +kommentál +kommersz +kommün +kommunista +kommunizmus +komód +komoly +komolyodik +komolyság +komolytalan +komondor +komor +komornyik +komorság +komp +kompetencia +komplé +komplett +komplexum +komplikáció +komplikált +kompót +komposzttalaj +kompozíció +kompromisszum +kompromittál +komputer +koncentrációs +koncentrál +koncentrált +koncert +kondás +kondér +kondi +kondíció +kondoleál +kondor +kondul +kondulás +konfekció +konfekcióipar +konfekcióruha +konfliktus +konflis +konformizmus +konfúzió +konfúzus +kong +kongás +kongat +kongatás +kongó +kongói +kongresszus +konkrét +konkrétum +konkretizál +konkurrencia +konnektor +konok +konokság +konspiráció +konspirál +konspiratív +konstantinápolyi +konstruál +konstruktív +konstruktivista +konstruktivitás +kontár +kontárkodik +kontinens +kontinuitás +kontó +kontráz +kontraktus +kontraszelekciós +kontraszt +kontroll +kontrollál +konty +kontyos +konvenció +konvent +konventképviselő +konvoj +konyak +konyakocska +konyakos +konyakospohár +konyakosüveg +konyakozik +konyakrendelés +konyha +konyhaablak +konyhaajtó +konyhaasztal +konyhabeli +konyhafelszerelés +konyhai +konyhakés +konyhakert +konyhakredenc +konyhalány +konyhasó +konyhasóoldat +konyhaszék +konyhaszekrény +konyhaszemélyzet +konyít +konzekvencia +konzerv +konzerváció +konzervál +konzerválódás +konzervátor +konzervátori +konzervatív +konzervdoboz +konzervgyár +konzul +konzulválasztás +konzulviselt +kooperáció +koordinál +kopár +kopárzöld +kopás +kopasz +kopaszodik +kopaszos +kopaszság +kopaszt +kopasztás +kopik +kopisztol +koplalás +koplaló +kopó +kopog +kopogás +kopogós +kopogtat +kopogtatás +koponya +koponyájú +koponyaalkat +koponyacsont +koporsó +koporsókészítő +koporsós +kopott +kopottruhás +koppan +koppanás +koptat +kor +kora +korábbi +korán +korántsem +korát-múlta +korátlag +korabeli +koraérett +korai +koraöreg +korbács +korbácsol +korcol +korcsolya +korda +kordbársony +kordé +koreai +koreográfia +korhad +korhadozik +korhadt +korhatár +korhatag +korhelyleves +korhol +kori +kork +korkülönbség +korlát +korlátolt +korlátoltság +korlátoz +korlátozódik +korlátozott +kormány +kormánybiztosféle +kormányellenes +kormányférfi +kormánykerék +kormánynegyed +kormányospad +kormányoz +kormányoztat +kormányrendelet +kormányszerv +kormányzás +kormányzat +kormányzó +kormányzói +kormos +kornyadozik +kornyikál +kornyikálás +korog +korom +koromfekete +koromsötét +korona +koronás +koronáz +koronakérő +korong +koros +korosztály +korpa +korpás +korrekt +korrektor +korrektúra +korrepetálás +korrespondál +korrigál +korrigálás +korrigálhatatlan +korrumpál +korsó +korsós +korszak +korszakbeli +korszellem +korszerű +korszerűtlen +kortárs +korteher +korteskedik +korty +kortynyi +kortyol +kortyolgat +korú +korzó +korzóbetyár +korzózik +kos +kosár +kosárfonó +kosárka +kossuth-bányai +kossuth-díjas +kossuth-párti +kosz +koszlott +koszorú +koszos +koszt +kosztkamat +kosztol +kosztos +kosztüm +kosztümkabát +kosztümös +kotlik +kotlós +kotor +kotorászik +kotta +kottatartó +kotyog +kotyvalék +kotyvaszt +kovács +kovácsműhely +kovácsol +kovácsolt +kovácsoltvas +kovakő +kozák +kozáking +kozmetika +kozmetikál +kozmikus +kozmikussugár-gyűjtő +kozmopolitizmus +kozmosz +krá +krákog +kráter +kráterszerű +krajcár +krajnai +krapek +krapekol +krém +krémes +krémeskorszak +krémfagylalt +krémkereső +kréta +krétáz +kredenc +kredencfia +kreol +krepelicai +krepp +krízis +kricsmi +krigli +krikszkraksz +krimi +krinolinos +kripta +kriptanyomaték +kristály +kristálycukor +kristályforma +kristályos +kristályosodik +kristálypohár +kristályragyogású +kristályrendszer +kristálytiszta +kristályvíz +krisztus-ikon +krisztusi +kritérium +kritika +kritikai +kritikus +kritizál +krizantém +króm +krómoz +krónikás +krónikaíró +krőzusi +kroá +krokodil +krokodilpáncél +krokodilus +kromofág +kromoszóma +krumpli +krumpliorr +krumplisaláta +krumplisverem +krumpliszsák +ktsz-elnök +kúp +kúra +kúszik +kúszik-mászik +kúszónövény +kút +kútágas +kútgém +kútmély +kútvíz +küld +küldés +küldemény +küldetés +küldönc +küldött +küldöttség +küldözget +külföld +külföldi +külkapcsolat +külker +külkeres +külkereskedelmi +küllem +küllő +küllős +külön +külön-külön +külön-magyar +különállás +különálló +különb +különben +különbözik +különböző +különbözőség +különbség +különc +különcködés +különféle +különítmény +különítményes +különkiadás +különleges +különmunka +különös +különös-halk +különösen +különösképpen +különösség +különszám +különszenzáció +különszoba +különterem +különválás +különválik +külország +külországi +külpolitika +külpolitikai +külpolitikus +külsejű +külső +külsőség +külsőséges +kültelki +külterjes +külügyminiszter +külváros +külvárosi +külvilág +küraszír +küret +küret-téma +kürt +kürtöl +kürtös +kürtszó +küszködés +küszködik +küszöb +küzd +küzdelem +küzdelmes +küzdő +küzdőképesség +küzdőtér +kubikol +kubikolás +kubikos +kubikostárs +kuckó +kucorodik +kucorog +kucsma +kucsmás +kudarc +kuka +kukacoskodás +kukacoskodik +kukacosodás +kukacvirág +kukk +kukorékol +kukorica +kukoricás +kukoricacső +kukoricaföld +kukoricalevél +kukoricamorzsolás +kukoricaszem +kukoricatábla +kukoricatörés +kuksol +kukta +kukucskál +kukucskáló +kukucskalyuk +kulák +kulákfajta +kuláklista +kulákvilág +kulacs +kulcs +kulcscsomó +kulcscsont +kulcslyuk +kulcsol +kulcspozíció +kulcstömeg +kulissza +kullog +kultikus +kultivál +kultúra +kultúrbotrány +kultúrcsoport +kultúrdokumentum +kultúrélmény +kultúrember +kultúrfilm +kultúrforradalom +kultúrház +kultúrnép +kultúrnövény +kultúrpalota +kultúrsalak +kultúrterem +kultúrtörténet +kulturális +kulturált +kulturáltság +kultusz +kultuszépítő +kumulusz +kun +kuncog +kuncogás +kuncsaft +kuncsorog +kuncsorogtat +kunkorodik +kunsági +kunszentmártoni +kunyhó +kupa +kupac +kupak +kupaktanács +kupamérkőzés +kupé +kupec +kupeckedik +kupecparaszt +kupica +kupleráj +kupolás +kupolacsarnok +kuporodik +kuporog +kuporogta +kurjant +kurjantás +kurjongat +kurjongatás +kurrog +kurta +kurtán-furcsán +kurtít +kuruc +kurucos +kurva +kurvuci +kuss +kusza +kuszálék +kuszálódik +kuszált +kutat +kutatás +kutatási +kutató +kutatóberendezés +kutatócsoport +kutatóintézet +kutatóintézeti +kutatóorvos +kutatóosztály +kutatótevékenység +kutya +kutya-macska +kutyálkodás +kutyás +kutyabaj +kutyabőr +kutyafejű +kutyafüle +kutyagol +kutyaház +kutyaiskola +kutyapedigré +kutyapofa +kutyapofájú +kutyaszán +kutyaszorító +kutyavalag +kvantummechanika +kvarc +kvarclámpa +kvóta +la +láb +lábad +lábadozik +lábadozó +lábas +lábasjószág +lábatlankodik +lábbeli +lábdobogás +lábfej +lábfürdő +lábizom +lábmozgás +lábmunka +lábnyi +lábnyom +lábszár +lábszárcsont +lábtenisz +lábtörlő +lábú +lábujj +lábujjhegy +lábujjköz +lábvíz +lábzsámoly +láda +ládácska +ládahalom +ládika +ládikó +láger +lágerlakó +lágernyelv +lágerszínház +lágy +lágykezű +lágymányosi +lágyság +lágyszívű +lágytojás +lám +lámcsak +lámpa +lámpácska +lámpás +lámpabél +lámpabűz +lámpafény +lámpaláz +lámpaoltás +lámpasor +lámpasugár +lámpatest +lámpaüveg +lánc +láncdarab +lánchíd +lánchinta +lánckereskedő +láncol +láncolat +láncszem +lánctalpas +lándzsa +láng +lángcsóva +lángész +lángözön +lángol +lángolás +lángoló +lángos +lángú +lángvégű +lány +lánygimnázium +lányhang +lányiskola +lányka +lánykérés +lánykórus +lánykor +lánykori +lánynév +lányos +lánypajtás +lánytükör +láp +lárifári +lárma +lármás +lármázik +lárva +lárvaarcú +lárvahéj +lát +látás +látási +látatlan +látcső +láthatár +láthatatlan +látható +látkép +látlelet +látnivaló +látnok +látóhatár +látókörű +látómező +látogat +látogatás +látogatási +látogató +látomány +látomás +látott +látszat +látszatember +látszateredmény +látszik +látszó +látszódik +látszólag +látszólagos +látta +láttamoztat +láttat +látvány +látvány-élmény +látványos +látványosság +láva +lávakitörés +láz +lázálom +lázad +lázadás +lázadó +lázas +lázít +lázong +lázongó +lázroham +labanc +labda +labdacs +labdarúgó +labirintus +labor +laborálás +laboráns +laboránslány +laboratórium +laboratóriumfőnök +laboratóriumi +laboratóriumterem +lacikonyha +lacikonyhás +ladik +ladikos +lagzi +laikus +lajstrom +lajstromoz +lajtos +lak +lakályos +lakályosság +lakás +lakásadó +lakásajtó +lakásdúlás +lakáshivatal +lakáshivatal-vezető +lakáskérdés +lakáskérelmező +lakásosztály +lakásromboló +lakásszentelő +lakásszűke +lakásügy +lakat +lakatféle +lakatlan +lakatos +lakatoslegény +lakatosműhely +lakbér +lakbérhátralék +lakcím +lakhatatlan +lakható +lakhely +lakik +lakkos +lakkoz +lakktopános +lakmározik +lakó +lakóbizottsági +lakóház +lakóhely +lakókocsi +lakónegyed +lakószoba +lakótárs +lakótelep +lakodalmas +lakodalmi +lakodalom +lakoma +lakos +lakosság +lakosú +lakosztály +lakott +lakozik +laktanya +laktanyaudvar +laktatós +lampion +langy +langyos +langyosság +lanka +lankás +lankadt +lant +lantos +lantszarvú +lap +lapály +lapát +lapátkéz +lapátnyi +lapátol +lapátolás +lapátos +lapít +lapidáris +lapkiadó +lapkonszern +lapocka +lapocska +lapos +laposfejű +lapostányér +lapoz +lapozás +lapozgat +lappang +lappangás +lapul +lapulás +lassacskán +lassan +lassanként +lassít +lassítás +lassú +lassúság +lassul +lasztex +lasztexnadrág +lat +latin +latolgat +latolgatás +lator +latrina +latrinadeszka +latyak +latyakos +lavírozik +lavór +laza +lazac +lazaság +lazít +le +le-föl +le-lecsukódik +le-leles +lé +léc +léckerítés +lég +légáramlás +légáramlat +légajtó +légcsőhurut +légelhárító +léggömb +léghajó +légi +légies +légiflotta +légifolyosó +légikisasszony +légió +légipoggyász +légiriadó +légitámadás +légitársaság +légköbméter +légkör +légköri +légkörű +légkondicionáló +légkondicionált +légmentes +légmozgás +légnyomás +légnyomás-differencia +légópince +légószolgálat +légörvény +légoltalmi +légpárna +légpárnás +légszomj +légtornász +légvonal +légy +légycsapó +légyraj +légyszaros +légzés +légzésű +légzsilip +léha +lékel +lélegzés +lélegzet +lélegzetelállító +lélegzetszakító +lélegzetvétel +lélegzetvételnyi +lélegzik +lélek +lélekbúvár +lélekféleség +lélekharang +lélekszakadva +lélektan +lélektani +lélektelen +lélekváltás +lélekveszedelem +lélekvesztő +léniáz +lény +lényeg +lényegében +lényeges +lényegileg +lényegtelen +lép +lépcső +lépcsőfeljáró +lépcsőfok +lépcsőforduló +lépcsőház +lépcsőházi +lépcsős +lépcsőzetes +lépdel +lépés +lépésnyi +lépeget +lépfene +lépked +lépte +léptek +lépten-nyomon +léptet +léptű +lépzúzódás +lét +létbizonytalanság +létérdek +létére +létesít +létesítés +létesítmény +létesül +létezés +létezik +létfeltétel +létfenntartás +létfontosság +léthajnal +létjogosultság +létkérdés +létminimum +létra +létrácska +létrafok +létraszerű +létrehoz +létrejön +létszám +létszámigénylés +létszámú +létszemlélet +lézeng +lézer +lézerrendszer +leáldozik +leáll +leállít +leány +leányálom +leányalak +leányfej +leánygyermek +leányholttest +leányiskola +leányismerős +leányka +leánykérő +leánykori +leányzó +leás +lead +leadás +leakaszt +lealázás +lealacsonyít +lealszik +learat +lebámul +leballag +lebarnul +lebben +lebbenés +lebbenéstelen +lebélyegez +lebecsül +lebecsülés +lebeg +lebegés +lebegő +lebegtet +lebeszél +lebetonoz +lebiggyed +lebilincselő +lebillen +lebőgés +lebocsát +lebombáz +lebombázás +lebont +lebontás +lebontat +lebonyolít +lebonyolítás +lebonyolódik +leborít +leborul +lebotorkál +lebújik +lebüntet +lebukás +lebukfencezik +lebukik +lebuktat +lebzsel +lecke +leckéztet +leckéztetés +lecövekel +lecsap +lecsapolás +lecsatol +lecsavar +lecsendesedik +lecsíp +lecsillapít +lecsillapodik +lecsitul +lecsószag +lecsordul +lecsorog +lecsúszik +lecsúszott +lecsúsztat +lecsuk +lecsukódik +lecsurran +lediktál +ledöf +ledöglik +ledönt +ledörzsöl +ledörzsölés +ledől +ledob +ledoktorál +ledolgozik +ledurrant +leég +leéget +leél +leépítés +leér +leérettségizik +leegyszerűsít +leegyszerűsödik +leejt +leellenőriz +leemel +leendő +leenged +leereszkedik +leereszkedő +leereszt +leesik +leevez +lefarag +lefékez +lefényképez +lefegyverez +lefejez +lefejt +lefejtés +lefekszik +lefektet +lefekvés +lefelé +lefest +leffeg +leffen +lefittyed +lefittyen +lefitymál +lefizet +lefölöz +lefog +lefogad +lefogat +lefoglal +lefogy +lefokoz +lefolyás +lefolyik +lefolyó +lefolytat +lefonnyaszt +lefordít +lefordítás +leforgás +leforráz +lefoszlik +lefotóz +lefröcsköl +lefúj +lefüggönyöz +lefülel +lefűrészel +lefullad +lefut +lefutás +legáció +legális +legázol +legalább +legalábbis +legalizál +legalja +legény +legényember +legényes +legényke +legénykedik +legénykor +legénység +legénységi +legépel +legel +legelész +legeleje +legelő +legelőgazdálkodás +legeltet +legeltetés +legeltetési +legenda +legendás +legendaszövő +legfeljebb +legjava +legközelebb +legömbölyít +legöngyöl +legörbül +legördít +legördül +legombol +legott +leguggol +legurul +legutóbb +legutóbbi +legyengül +legyeskedik +legyez +legyező +legyezőforma +legyilkol +legyilkoltat +legyint +legyintés +legyőz +legyőzés +legyőzhetetlen +legyőzött +legyűr +legyűrhetetlen +lehánt +lehántolódik +lehagy +lehajigál +lehajlás +lehajlik +lehajol +lehajt +lehalász +lehalkít +lehalkul +lehallgat +lehallgató +lehamuz +lehangol +lehangolódik +lehangoltság +lehanyatlik +leharap +lehel +lehelet +lehelet-tányér +leheletnyi +leheletű +lehengerel +lehervad +lehet +lehetetlen +lehetetlenség +lehető +lehetőleg +lehetőség +lehetséges +leheveredik +lehint +lehord +lehorgad +lehorgaszt +lehorgonyoz +lehorzsol +lehoz +lehúz +lehúzkod +lehúzódik +lehűl +lehűlés +lehűt +lehugyoz +lehull +lehullat +lehullta +lehuny +lehuppan +lehurrog +leír +leírás +leírhatatlan +leigáz +leint +leirat +leiszik +leitat +lejár +lejárat +lejáró +lejárt +lejátszás +lejátszik +lejátszódik +lejattol +lejjebb +lejmol +lejön +lejt +lejtés +lejtésfok +lejtő +lejtős +lejtősödik +lejut +lekászálódik +lekanyarít +lekap +lekapcsol +lekaszál +lekattan +lekavarint +lekérés +lekéset +lekésik +lekerül +lekever +lekezel +lekísér +lekiált +lekiabál +leköltözik +leköp +leköpköd +leköszön +leköt +lekötelez +leközöl +lekonyul +lekopaszítás +lekopik +lekúszik +leküld +leküldet +leküzd +leküzdés +leküzdhetetlen +lekucorodik +lekuporodik +lekurváz +lekurvázás +lekushad +lekuttyogtat +lekvár +lekváros +lel +lelát +lelakatol +lelandol +lelappaszt +lelassít +lelassul +lelazít +lelécel +lelép +lelépeget +lelépked +leléptet +leledzik +lelegel +lelejmol +lelemény +leleményesség +lelenc +lelencházi +leleplez +lelepleződés +lelet +lelibeg +lelkész +lelkendez +lelkendezés +lelkes +lelkesedés +lelkesedik +lelkesít +lelkesül +lelkesült +lelki +lelki-alkati +lelki-szellemi +lelkiállapot +lelkiatya +lelkierő +lelkifurdalás +lelkigyakorlatszerű +lelkiismeret +lelkiismeret-furdalás +lelkiismeretes +lelkiismeretlen +lelkivilág +lelkület +lelkű +lelóg +lelógat +lelök +lelövés +lelövöldöz +lelő +lelohad +leltár +leltároz +lemásol +lemászik +lemarad +lemér +lemegy +lemerül +lemeszel +lemetél +lemez +lemezjátszó +lemezsorozat +lemeztelenít +lemond +lemondás +lemondó +lemorzsol +lemos +lemosakodik +lemosdat +lemosolygás +lemosolyog +lemutat +lencse +lencseleves +lendít +lendítget +lendül +lendülés +lendület +lendületes +lendületű +lenéz +lenézet +leng +lenge +lengés +lengedez +lenget +lengőajtó +lengyel +lenin-fiú +lenini +lenn +lenő +lenti +lenyal +lenyel +lenyergelés +lenyes +lenyír +lenyisszant +lenyom +lenyomogat +lenyomoz +lenyúl +lenyúz +lenyűgöz +lenyűgöző +leöblít +leöl +leöldöklés +leölet +leömlik +leönt +leolt +leolvad +leolvas +leolvasható +leomlik +leordít +leoszt +lep +lepakol +leparoláz +lepattan +lepattogzik +lepény +lepecsétel +lepedék +lepedő +lepedődarab +lepedőnyi +lepel +lepereg +lepihen +lepillant +lepislant +lepke +lepkészet +lepkekönnyű +lepkesúlyú +lepkeszárny +lepkevadászat +lepkevilág +leplez +leplezés +leplezetlen +leplezhető +lepöccent +lepődik +lepocskondiáz +leporol +leporolgat +lepottyan +leprás +leprafolt +lepratelep +leprésel +lepuffant +lerág +lerángat +leránt +leráz +leragad +lerajzol +lerak +lerakás +lerakódás +lerakódik +lerakodik +lerepül +lereszel +lerí +leró +leröppen +lerövidít +lerobban +lerobbant +lerogy +lerohan +lerokkan +lerombol +lerombolódik +leromlik +leroskad +leruccan +les +lesajnál +lesajnáló +lesétál +lesegít +lesekedik +leselkedés +leselkedik +leseprűz +leshely +lesimít +lesimítás +lesimogat +leskelődés +leskelődik +lesóz +lesöpör +lesodor +lesoványodik +lestoppol +lesújt +lesújtó +lesül +lesüt +lesz +leszáll +leszállás +leszállít +leszállítás +leszállóhely +leszállta +leszámít +leszámol +leszánkázik +leszármazott +leszázalékol +leszakad +leszakít +leszalad +leszalajt +leszar +leszavaz +leszed +leszeg +leszel +leszerel +leszereltet +leszerepel +leszerződik +leszív +leszid +leszivárgás +leszól +leszólít +leszór +leszögez +leszokik +leszoktat +leszorít +leszúr +leszűr +letáboroz +letárgyal +letagad +letaglóz +letakar +letakarít +letakarítatlan +letakarodás +letarol +letartóztat +letartóztatás +letartóztatási +letartóztatott +letaszít +letép +letéphető +letér +letérdel +letétel +letegez +letekerget +letekint +letelepedik +letelik +leteper +leterít +letesz +letipor +letisztít +letölt +letör +letördel +letörik +letörlés +letörleszt +letöröl +letörölhetetlen +letört +letocsog +letol +letompultság +letorkol +letottyan +letűr +leül +leülés +leülepedik +leültet +leüt +leugrál +leugrik +leutazik +levág +levágás +levágat +levágódik +levájkál +leválaszt +leválik +levált +leváltás +levackolódik +levakar +levél +levélarc +levélcenzor +levélhalom +levélírás +levélnyílás +levélszekrény +levéltáros +levénsüketez +levés +levegő +levegőellátás +levegőjű +levegőszekrény +levegőtlen +levegőzik +levelez +levelezés +levelezési +levelezget +levelező +levelezőlap +levelű +levendula +lever +leverés +levert +levertség +leves +levesestányér +levesestányérnyi +levestészta +levesz +levet +levetet +levetít +levetkőzés +levetkőzik +levetkőztet +levezet +levezetés +levezetődik +levízibuszozik +levisz +levitézlett +levon +levonul +lexikon +lexikonszerű +lezár +lezárás +lezárhatatlan +lezárul +lezajlik +lezavar +lezökken +lezser +lezúdul +lezüllik +lezuhan +lezuhanyozik +líra +lítium +liánköteg +liász +liba +libás +libabőrös +libacomb +libalegelő +libamájexportőr +libasor +libatömés +libazsíros +libben +libbenés +libeg +libegés +libegős +liberalizmus +licitálás +lidérc +lift +liftajtó +liftakna +liget +ligetes +ligeti +lignin +liheg +lihegés +likőr +likőrgyáros +likvidál +likvidálás +likvidálódik +lila +lila-szürke +lilás +liláskék +lilaság +liliom +liliomtiprás +liliputi +limlom +limonádé +link +linkóci +linóleum +liptói +lista +liszt +liszt-mű +lisztes +liszteszsák +litánia +litániaparafrázis +liter +literátor +literátus +ló +lóarcú +lóbál +lóbetű +lóca +lócsere +lócsiszár +lódenkabát +lódít +lódul +lófej +lófog +lófogatos +lófogú +lófuttatás +lóg +lógás +lógáz +lógat +lógerezés +lógó +lóhát +lóhere +lóistálló +lókereskedő +lókupec +lópata +lópatkó +lópofájú +lópokróc +lósóska +lószemű +lószerszám-fényesítő +lót-fut +lótás-futás +lótrágya +lótúró +lótuszvirág +lóvásár +lóvé +lóverseny +lóverseny-szaklap +lóversenytér +lóversenyújság-szerkesztő +lök +lökdös +lökdösés +lökdösődés +lökdösődik +lökés +lökésszerű +lökhajtásos +löttyen +löttyint +lötyköl +lötyög +lötyögős +lövés +lövész +lövészárok +lövészteknő +lövedék +löveg +lövegtorony +lövell +lövöldöz +lövöldözés +lövőtudomány +lő +lőárok +lődörög +lőfegyver +lőfegyverállás +lőpor +lőporos +lőre +lőrés +lőrésnyi +lőrinci +lőszer +lőszerellátás +lőszeres +lőszeresláda +lőtávol +lobban +lobbanékony +lobbant +lobog +lobogás +lobogó +lobogós +lobogtat +loboncos +lobos +loccsan +loccsant +loccsint +locskolás +locsog +locsogás +locsol +locsolás +locsolgat +locsolókanna +logika +logikátlan +logikai +logikus +lohad +lohol +loholás +loholó-lázas +lojális +lokál +loknis +lokomotív +lom +lomb +lombard +lombbolt +lombik +lombikélet +lombikember +lombikolás +lombikos +lombkoszorúzta +lombos +lombosodik +lomboz +lombú +lomha +lompos +lonc +loncsos +londoni +lop +lopás +lopakodik +lopótök +lopott +lopva +lottócédula +lottózik +lovász +lovacska +lovag +lovagi +lovagiasság +lovaglócsizma +lovaglólecke +lovagol +lovagoltatás +lovagrend +lovagtípus +lovagtörténet +lovardaszerű +lovas +lovascsoport +lovasember +lovaskocsi +lovasmenet +lovasrendőr +lovasroham +lovasság +lovassereg +lovasszázad +lovastiszt +lovasvezér +lúdbőrözik +lüktet +lüktetés +lubickol +lubickolás +lucerna +lucernás +lucskos +lucsok +ludas +ludovikás +lugas +lump +lumpen +lusta +lustálkodás +lustálkodik +lustaság +lutheránus +luxus +luxusadó +luxusétterem +luxusfrunzsi +lyuggat +lyuk +lyukablak +lyukacsos +lyukacsosodik +lyukas +ma +mágikus +máglya +mágnás +mágnásfertály +mágnes +mágneses +mágneskristály +máj +májbaj +májfolt +májgombóc +májszínű +májtömb +május +májusfa +májusi +májzúzódás +mák +mákony +mákos +mákszem +mállik +mállott +málna +málnás +málnáspohár +málnatöves +málnatő +mályva +mályvalila +mámor +mámorító +mámoros +mándli +mánia +mániákus +mániás +már +már-már +március +márciusi +máriás +máriaüveg +máris +márka +márkás +mármint +mármost +márpedig +márt +mártíromság +mártogat +márvány +márványasztal +márványasztalka +márványcsarnok +márványerezet +márványgolyó +márványkemény +márványlap +márványos +márványoszlop +márványsárga +márványszobor +márványtábla +márványtömb +más +más-más +mása +másfajta +másfél +másfél-kétórás +másféle +másfelé +másfelől +másforma +máshol +máshova +másítás +másik +másikfajta +másként +másképpen +máskor +máskülönben +másmilyen +másnap +másnapi +másnapos +másnaposság +másnemű +másod +másodállás +második +másodlagos +másodmagával +másodnap +másodnaponként +másodosztály +másodosztályú +másodpéldány +másodperc +másodperces +másodpercmutató +másodpilóta +másodszülött +másolat +másrészt +másszor +másunnan +másutt +másvalaki +mászik +mászkál +mászkálás +mátkapár +mátraszentimrei +mázas +mázli +mázol +mázoló +mázsa +mázsás +machiavellizmus +mackó +mackófelsőrész +mackós +macska +macskafejes +macskahere +macskaköves +macskakő +macskamosdás +macskanyelv +madár +madárcsípte +madárfejű +madárfütty +madáritató +madárka +madárkalitka +madárpiszok +madárraj +madársaláta +madártest +madártetem +madártömő +madártojás +madártoll +madárüveg +madarász +madaracska +madonna +madzag +madzagol +mag +maga +magában +magánakció +magánbeszélgetés +magánbeteg +magándetektív +magánélet +magánember +magángazdálkodás +magánházacska +magánhangzó +magánhasználat +magánjelenet +magánkórház +magánlakás +magános +magánpacientúra +magántanítvány +magántermészetű +magánügy +magánvád +magánvállalkozó +magánvallatás +magány +magányos +magányoskodik +magányosság +magánzárka +magánzó +magárahagyottság +magától +magáz +magabízó +magabiztos +magabiztosság +magafajta +magafeledt +magafelejtve +magaforma +magamaga +magamutogató +magas +magasfeszültségű +magasföldszintes +magasiskola +magaslat +magaslati +magasles +magaslik +magasodik +magasrangú +magasság +magasságú +magasztal +magasztos +magatartás +magatartás-norma +magatartású +magatehetetlen +magaválasztotta +magazin +magfizikus +magnetofon +magnó +magnószalag +magomobil +magtár +magtörő +magvatlan +magvetés +magvető +magyar +magyar-lengyel +magyar-német +magyarán +magyaráz +magyarázat +magyarázható +magyarázkodás +magyarázkodik +magyarbarát +magyarhoni +magyarkodik +magyarországi +magyaros +magyarosít +magyarul +magzat +magzatmáz +mahagóni +maharadzsa +maholnap +mai +majális +majd +majd-majd +majdani +majdhogy +majdhogynem +majdnem +majdnem-sikoly +majmol +majom +majom-mozgás +majomfarka-kaktusz +majomkodik +majompóz +majompofájú +majomügyesség +major +majori +majorság +majrés +majrézik +majszol +makacs +makacskodik +makacsság +makadámút +makk +makkegészséges +makói +makog +makrancos +maláji +malac +malacka +malacképű +malackodás +malacpofa +malacság +mallér +malőr +malom +malomkő +malomvezető +malter +malterlelkű +malteros +mama +mamlasz +mamuska +manapság +mancs +mandula +mandulafa +mandzsetta +manierista +manikűröz +mankó +mankós +manó +manőver +manőverez +manőverezési +manzárd +manzárdszoba +mar +marás +marad +maradás +maradási +maradandó +maradék +maradéktalan +maradi +maradiság +maradvány +marakodik +marasztal +marcangol +marciális +marcona +marék +margarétás +margitszigeti +margitvirág +margó +marha +marháskodik +marhaerő +marhahús +marhapörkölt +marhaság +marhavagon +marian-ügy +markáns +markíroz +markol +markolász +markolat +markoló +maró +maródi +marok +maroknyi +marokszedés +marokszedő +maros-parti +mars +marsall +martinász +martinkemenceszerű +marx-levél +marxista +marxizmus +masina +masiniszta +maskarádé +masni +massza +masszázs +masszív +masszőr +maszatos +maszek +maszk +maszkíroz +maszlag +matat +matek +matematika +matematikai +matematikus +materializmus +matrac +matrac-hajó +matracos +matracú +matring +matróna +matróz +matrózblúzos +matrózruha +matróztüzér +matuzsálemi +mauzóleum +maximális +maximum +mazsolás +mbah +mécs +mécses +még +méghozzá +mégis +mégiscsak +mégoly +mégpedig +mégsem +mégúgy +méh +méhészet +méhészkedés +méhészkedik +méhike +méhpempő +méla +méláz +mélabú +mélabús +méltán +méltányol +méltányos +méltánytalan +méltat +méltatlan +méltatlankodás +méltatlankodik +méltó +méltóság +méltóságkeltő +méltóságos +méltóságteljes +méltóztatik +mély +mély-proli +mély-tábla +mélyépítési +mélyed +mélyedés +mélyhűtött +mélyít +mélykék +mélypont +mélyréteg +mélység +mélységes +mélységű +mélysötét +mélytányér +mélytenger +mélytüzű +mélytudati +mélyül +mélyvíz +mélyzöld +mémoszista +mén +ménes +méntelep +mér +mérce +mérés +méreg +méregcsepp +méregerős +méreget +méregfog +méregkeverő +méregraktár +méret +méretez +méretkezik +méretű +mérföld +mérföldes +mérföldlépő +mérgelődik +mérges +mérgez +mérgeződik +mérhetetlen +mérhető +mérkőzés +mérkőzik +mérleg +mérlegel +mérlegelés +mérleghiányos +mérlegképes +mérmondó +mérnök +mérnökék +mérnökfiú +mérnökgyakornok +mérnöki +mérnökjelölt +mérnöknő +mérőeszköz +mérsékel +mérsékelt +mérséklet +mért +mértan +mértani +mérték +mértékegység +mértékletes +mértékletesség +mértékrendszer +mértéktartás +mértéktartó +mértéktelen +mértékű +mész +mészárlás +mészáros +mészároslegény +mészárszék +mészégető +mészfolt +mészkőszikla +mészpor +mészréteg +mészszag +mészváz +métely +méter +méteres +méternyi +méterrúd +méz +mézes +mézeshetek +mézeskalács +mézgás +meccs +mecénás +mechanika +mechanikai +mechanikus +mechanizmus +mecseki +medalion +meddig +meddő +medence +meder +medika +medikus +medikuslány +meditáció +meditál +medúza +medve +medve-bedve +medvemormogás +medveölelés +meg +meg-megáll +meg-megállás +meg-megborzongat +meg-megcéloz +meg-megcsúszik +meg-megcsuklik +meg-megforgat +meg-megkeres +meg-meglebben +meg-meglepődik +meg-megragad +meg-megrebben +meg-megrogyik +meg-megszippant +meg-megszólal +meg-megszúr +meg-megszűkül +meg-megtorlódik +meg-megújul +megácsol +megágyaz +megáld +megáll +megállás +megállapít +megállapítás +megállapító +megállapodás +megállapodik +megállapodottság +megállít +megállíthatatlan +megállítható +megállj +megálló +megállóhely +megárad +megárt +megás +megátalkodott +megátalkodottság +megázás +megázik +megad +megadás +megadó +megafon +megagitálás +megajándékoz +megakad +megakadályoz +megakadályozás +megakaszt +megaláz +megalázás +megalázkodik +megalázó +megalázott +megalázottság +megaláztatás +megalakul +megalakulás +megalapít +megalapoz +megalapozás +megalapozott +megalkot +megalkotás +megalkuszik +megalkuvás +megalszik +megalvad +megannyi +megaranyoz +megbámul +megbán +megbánás +megbánt +megbántódás +megbántódik +megbántott +megbántottság +megbabonáz +megbarátkozik +megbarnít +megbarnul +megbékél +megbékélés +megbékít +megbékül +megbélyegez +megbénít +megbénul +megbecsül +megbecsülés +megbecsült +megbeszél +megbeszélés +megbeszélnivaló +megbetegedik +megbírságoltat +megbíz +megbízás +megbízatás +megbízhatatlan +megbízható +megbízhatóság +megbízik +megbízó +megbízólevél +megbízott +megbicsaklik +megbilincsel +megbillen +megbillent +megbirkózik +megbizonyosodik +megbódul +megbök +megbocsát +megbocsátás +megbocsáthatatlan +megbocsátható +megbocsátó +megbokrosodik +megboldogult +megbolondít +megbolondul +megbolydul +megbolygat +megbomlik +megbont +megbonthatatlan +megborotválkozik +megborzad +megborzol +megborzong +megborzongat +megbotlik +megbotránkozás +megbotránkozik +megbújik +megbüntet +megbűvöl +megbugáz +megbukik +megbuktat +megcáfol +megcáfolhatatlan +megcéloz +megcímez +megcibál +megcirógat +megcsal +megcsalatkozik +megcsap +megcsapkod +megcsappan +megcsavar +megcsavarodik +megcselekedik +megcsendesedik +megcsendül +megcserélődik +megcsíp +megcsikordít +megcsikordul +megcsillan +megcsinál +megcsináltat +megcsipked +megcsókol +megcsóvál +megcsömörlik +megcsörget +megcsörren +megcsodál +megcsodáltat +megcsonkul +megcsontosodik +megcsúfol +megcsúfolás +megcsúnyul +megcsúszik +megcsúzliz +megcsuklik +megdagad +megdermed +megdermeszt +megdicsér +megdicsőül +megdicsőülés +megdöbben +megdöbbenés +megdöbbent +megdöbbentő +megdögleszt +megdöglik +megdöndül +megdönget +megdönt +megdördül +megdörzsöl +megdől +megdobál +megdobban +megdobogtat +megdolgoz +megdolgozik +megdolgoztat +megdorgál +megdrótoztat +megdübörög +megdühödik +megdurran +megduzzad +megébred +megég +megéget +megéhezik +megél +megélénkül +megélés +megélesedik +megéljenzés +megélt +megépít +megépül +megépülés +megér +megérdemel +megérez +megérezhető +megérik +megérint +megérkezés +megérkezik +megért +megértés +megértet +megértő +megebédel +megedz +megegyezés +megegyezik +megegyeztet +megejt +megejtet +megejtő +megelégedés +megelégedett +megelégedettség +megelégedik +megelégel +megelevenedik +megelevenül +megelőz +megelőzés +megelőző +megemberel +megemészt +megemel +megemlékezik +megemlít +megemlítés +megenged +megengedett +megengedhető +megenyhül +megered +megereszkedik +megereszt +megerőltet +megerőltetés +megerőltető +megerősít +megerősítés +megerősödik +megerőszakol +megesik +megesküszik +megesz +megeszik +megetet +megfájdul +megfáradt +megfásul +megfázik +megfaggyúz +megfagy +megfakul +megfarag +megfarol +megfékez +megfélemlítés +megfér +megférfiasodik +megfésülködik +megfehéredik +megfejt +megfejtés +megfejtetlen +megfejthetetlen +megfeketedik +megfekszik +megfeledkezik +megfelel +megfelelő +megfellebbezhetetlen +megfeneklik +megfenyeget +megfenyít +megfertőz +megfertőztet +megfest +megfeszít +megfeszítés +megfeszül +megfeszülés +megfiatalít +megfigyel +megfigyelés +megfigyelhető +megfigyelő +megfizet +megfő +megfőz +megfog +megfogad +megfogadás +megfogalmaz +megfogalmazás +megfogalmazható +megfogamzik +megfogdos +megfoghatatlan +megfogható +megfogódzkodik +megfogyatkozik +megfojt +megfokhagymáz +megfontol +megfontolás +megfontolt +megfontoltság +megfordít +megfordul +megfordulás +megforgat +megformál +megformálás +megformálódik +megforrósodik +megfoszt +megfricskáz +megfúj +megfúr +megfürdet +megfürdik +megfullad +megfullaszt +megfut +megfutamodik +meggátol +meggazdagodik +meggörbül +meggördül +meggörnyed +meggondol +meggondolás +meggondolatlan +meggondolatlanság +meggondolkoztat +meggondolt +megguggol +meggy +meggyág +meggyászol +meggyérül +meggyfa +meggyil +meggyilkol +meggyilkolás +meggyógyít +meggyógyul +meggyón +meggyötör +meggyötörtetés +meggyőz +meggyőzés +meggyőző +meggyőződés +meggyőződésbeli +meggyőződéses +meggyőződik +meggyőzős +meggyorsít +meggyorsul +meggypiros +meggyszínű +meggyújt +meggyúr +meggyűlik +meggyűlöl +meggyullad +megháborodik +meghág +meghálál +meghámoz +meghány-vet +meghátrál +megházasodik +meghagy +meghajlás +meghajlít +meghajlik +meghajol +meghajt +meghajtás +meghal +meghalás +meghalad +meghalkul +meghall +meghallgat +meghalványodik +megharagít +megharagszik +megharap +meghasít +meghat +meghatároz +meghatározás +meghatározatlan +meghatározhatatlan +meghatározó +meghatározott +megható +meghatódik +meghatódottság +meghatott +meghatottság +meghazudtol +meghektikásodik +meghempergőzik +meghígul +meghív +meghívás +meghívandó +meghívó +meghívott +meghízik +meghidegedik +meghimbál +meghint +meghintáztat +meghirdet +meghirdetés +meghisz +meghitt +meghittség +meghódít +meghódítás +meghökken +meghökkenés +meghökkent +meghökkentő +megholtak +meghonosít +meghonosítás +meghord +meghordoz +meghosszabbít +meghosszabbítás +meghosszabbító +meghosszabít +meghosszabítás +meghoz +meghozat +meghúz +meghúzgál +meghúzódik +meghúzogat +meghülyít +meghülyül +meghűl +meghűt +meghűvösödik +meghunyászkodás +meghunyászkodik +meghurcol +megígér +megír +megírás +megírnivaló +megítél +megítélés +megízlel +megidéz +megideologizál +megigazgat +megigazít +megijed +megijeszt +megillatosodik +megillet +megilletődés +megilletődik +megindít +megindító +megindokol +megindul +megindulás +megindultság +megingás +megingat +megingathatatlan +meginog +megint +megiramodik +megirtózik +megismétel +megismétlődik +megismer +megismerés +megismerkedés +megismerkedik +megismerszik +megismertet +megiszik +megitat +megizzad +megizzaszt +megjár +megjátszás +megjátszik +megjavít +megjavíthatatlan +megjavul +megjegyez +megjegyezhető +megjegyzés +megjelenés +megjelenési +megjelenik +megjelent +megjelentet +megjelöl +megjelölés +megjósol +megjön +megjuhászodik +megjutalmaz +megkap +megkapál +megkapar +megkaparint +megkapaszkodik +megkapható +megkér +megkérd +megkérdez +megkérdőjelez +megkésik +megkétszerez +megkedvel +megkefél +megkegyelmez +megkeményedik +megkeményít +megken +megkenet +megkeres +megkeresés +megkeresztelkedik +megkerget +megkergül +megkerül +megkeseredik +megkettőződik +megkever +megkeveredik +megkezd +megkezdés +megkezdődik +megkímél +megkínál +megkínoz +megkísérel +megkísért +megkísértés +megkíván +megkóstol +megkönnyebbedik +megkönnyebbül +megkönnyebbülés +megkönnyít +megkönyököl +megkönyörül +megköp +megkörnyékez +megköszön +megköszörül +megköt +megkötés +megkötöz +megkövesedik +megkövetel +megkövült +megközelít +megközelítés +megközelítési +megközelíthetetlen +megkoccan +megkockáztat +megkocogtat +megkomolyodik +megkondul +megkopaszodik +megkopik +megkoplal +megkopogtat +megkorbácsol +megkoszorúz +megkotor +megkotorász +megkottyan +megkotyogtat +megküld +megkülönböztet +megkülönböztetés +megkülönböztetett +megküzd +megkuszálódik +meglát +meglátás +meglátogat +meglátszik +meglangyosodik +meglassúdik +meglazít +meglazul +meglékel +meglép +meglebben +meglebbent +meglegyint +meglehet +meglehetős +meglel +meglendül +megleng +meglenget +meglep +meglepetés +meglepetésszerű +meglepő +meglepődés +meglepődik +megles +meglesz +meglett +meglevő +meglódul +meglóg +meglök +meglő +meglőhető +meglobban +meglobogtat +meglocsol +meglop +meglovagolható +megmárt +megmártózik +megmásíthatatlan +megmászik +megmagyaráz +megmagyarázhatatlan +megmagyarázható +megmakacsol +megmar +megmarad +megmaradás +megmarkol +megmarkolászik +megmér +megméreget +megmérgez +megmelegedik +megmelegít +megmenekít +megmenekül +megmenekülés +megment +megmentés +megmentett +megmentő +megmered +megmerevedik +megmerevít +megmerevítés +megmerít +megmoccan +megmoccant +megmocorog +megmond +megmondható +megmondó +megmos +megmosakodik +megmosdat +megmosdik +megmosolyog +megmozdít +megmozdul +megmozdulás +megmozgat +megmozgatás +megművel +megművelés +megműveltet +megmukkan +megmunkál +megmutat +megmutatás +megmutatkozik +megmutogat +megnéz +megnézeget +megnézet +megnedvesít +megneheztel +megneszel +megnevettet +megnevez +megnevezés +megnövekedik +megnövel +megnő +megnősül +megnyal +megnyalás +megnyekken +megnyer +megnyes +megnyílik +megnyír +megnyikkan +megnyikordul +megnyilatkozás +megnyilatkozik +megnyilvánul +megnyilvánulás +megnyit +megnyitás +megnyitó +megnyom +megnyomkod +megnyomódik +megnyomogat +megnyújt +megnyúlik +megnyúz +megnyugszik +megnyugtat +megnyugtatás +megnyugtató +megnyugvás +megóv +megöl +megölel +megöletés +megöngyilkol +megöregedik +megörökít +megörökítés +megörül +megörvendeztet +megőriz +megőrjít +megőröl +megőrül +megőrzés +megőrző +megőrződik +megőszül +megokol +megokolt +megolajoz +megold +megoldás +megoldhatatlan +megoldható +megoldódik +megolvad +megoperál +megoperáltat +megorrol +megoszt +megosztozik +megpályáz +megpárnásodik +megpásztáz +megpacskol +megpakol +megparázslik +megparancsol +megpaskol +megpatkol +megpecsétel +megpendít +megpendül +megperdül +megperzsel +megpihen +megpihentet +megpillant +megpillantás +megpiszkál +megpöcköl +megpörget +megpofoz +megposhad +megpróbál +megpróbálkozik +megpróbáltatás +megpucol +megpuhít +megpuszil +megrág +megrágalmaz +megrándít +megrándul +megráng +megránt +megráz +megrázkódik +megrázkódtatás +megragad +megrajzol +megrak +megrakodik +megrémít +megrémül +megrészegedik +megrebben +megreccsen +megrecsegtet +megreked +megremeg +megrendel +megrendelés +megrendez +megrendít +megrendítő +megrendül +megrendülés +megrendültség +megrenget +megreped +megrepedezik +megreszel +megreszket +megreszkettet +megretten +megrettent +megrezdül +megrezget +megrezzen +megrezzent +megríkat +megriad +megriaszt +megringat +megriposztoz +megritkul +megró +megrögzít +megrögzött +megrögzül +megrökönyödés +megrökönyödik +megrövidít +megroggyan +megrohad +megrohamoz +megrohan +megrohanás +megrokkan +megromlik +megrongál +megrongálódik +megront +megropogtat +megroppan +megroskad +megrozsdásodik +megrúg +megrühesedik +megrugdos +megsárgul +megsajdul +megsajnál +megsavanyodik +megsért +megsértés +megsértődik +megsérül +megsétáltat +megsebesít +megsebesül +megsebez +megsegít +megsegítés +megsejt +megsemmisít +megsemmisítés +megsemmisíthetetlen +megsemmisítő +megsemmisül +megsemmisülés +megsíkosodik +megsínyli +megsikál +megsimít +megsimogat +megsirat +megsóz +megsötétedik +megsodor +megsokall +megsokasodik +megsokszoroz +megsokszorozás +megsokszorozódik +megsoroz +megsoványodik +megspórol +megsúg +megsüt +megsűrűsödik +megsuhogtat +megszáll +megszállás +megszálló +megszállott +megszámít +megszámlál +megszámlálhatatlan +megszámol +megszán +megszárad +megszárít +megszárítgat +megszázszoroz +megszab +megszabadít +megszabadul +megszaggat +megszagol +megszakállasodik +megszakad +megszakít +megszakítás +megszalad +megszavaz +megszavazás +megszavaztat +megszavaztatás +megszédít +megszédül +megszégyenít +megszégyenítés +megszépül +megszed +megszeg +megszegés +megszelel +megszelídít +megszelídül +megszemélyesít +megszemlél +megszenved +megszeppen +megszeret +megszerez +megszerezhetetlen +megszerezhető +megszerkeszt +megszervez +megszerzés +megszív +megszilárdítás +megszilárdulás +megszimatol +megszippant +megszól +megszólal +megszólaltat +megszólít +megszólítás +megszólítgat +megszór +megszökik +megszöktet +megszövegez +megszokás +megszokhatatlan +megszokik +megszokott +megszokottság +megszolgál +megszomjazik +megszomorít +megszoptat +megszorít +megszorul +megszúr +megszül +megszületés +megszületik +megszüntet +megszüntetés +megszűnés +megszűnik +megszűr +megtáltosodik +megtámad +megtámaszt +megtámogat +megtáncoltat +megtántorodik +megtárgyal +megtárgyalás +megtagad +megtakarít +megtakarítás +megtalál +megtalálás +megtalálható +megtaláló +megtanácskozik +megtanít +megtanul +megtapad +megtapasztal +megtapint +megtapogat +megtapos +megtapsikolás +megtapsol +megtart +megtartás +megtartat +megtartóztat +megtaszít +megtébolyodik +megtép +megtépáz +megtépdes +megtér +megtérés +megtérít +megtérülés +megtésztásodik +megtévelyedik +megtéveszt +megtévesztés +megtekint +megtekintés +megtelepedés +megtelepedik +megtelepül +megtelik +megterebélyesedik +megterem +megteremt +megteremtés +megterhel +megterít +megtermékenyít +megtermékenyítés +megtermel +megtervez +megtervezés +megtestesít +megtestesítő +megtestesül +megtesz +megtetszik +megtilt +megtippel +megtisztel +megtisztelő +megtiszteltetés +megtisztít +megtisztogat +megtisztulás +megtöbbszöröz +megtölt +megtöltés +megtöltekezik +megtöltődik +megtöm +megtör +megtörés +megtörik +megtöröl +megtörténik +megtörténte +megtörülközik +megtold +megtorlás +megtorlódik +megtornáztat +megtorol +megtorpan +megtorpedóz +megtrágyáz +megtüzesít +megtűr +megtud +megtudakol +megújhodás +megújításszerű +megújul +megújulás +megúszik +megül +megülepszik +megünnepel +megüresedik +megürül +megüt +megütközés +megütközik +megütődik +megüzen +megugrik +megun +megutál +megvádol +megvág +megválaszolatlan +megválaszt +megválasztás +megválasztat +megválik +megválogat +megvált +megváltás +megváltó +megváltozik +megváltoztat +megváltoztatás +megvár +megvárakoztat +megvásárol +megvásároltatás +megvacsorázik +megvadul +megvakar +megvakargat +megvall +megvalósít +megvalósítás +megvalósítható +megvalósul +megvalósulás +megvan +megvarr +megvasal +megvéd +megvékonyodik +megvénül +megvétel +megvendégel +megver +megvereget +megveret +megvertség +megvesz +megveszekedett +megveszteget +megvesztegető +megvet +megvetés +megvetemedik +megvetendő +megvető +megvív +megvigasztal +megvigasztalódik +megvilágít +megvilágítás +megvilágosodik +megvilágosul +megvillan +megvillant +megvirrad +megvisel +megviselt +megvisz +megvitat +megvitatás +megvizitíroz +megvizsgál +megvizsgálható +megvizsgáltat +megvon +megvonogat +megy +megye +megyebeli +megyei +megyeri +megyjegyzés +megzabál +megzaboláz +megzavar +megzavarodás +megzavarodik +megzilál +megzöldül +megzörget +megzörren +megzsarol +mehetnék +mehosszabbíttat +mekegés +mekkora +melasz +meleg +melegedik +melegházi +melegít +melegítő +melegség +melegszívű +melenget +mell +mell-lövés +mellbedobás +mellbőség +mellé +melléáll +mellébeszél +mellédob +melléír +melléje +mellék +mellékág +mellékállomás +mellékajtó +mellékalak +melléképület +mellékel +mellékes +mellékhelyiség +melléki +mellékkereset +mellékkörülmény +melléklet +mellékút +mellékutca +mellékutcácska +mellékzönge +mellélép +mellélő +mellény +mellényke +mellényzseb +melléül +mellesleg +mellett +mellette +melletti +mellkas +mellől +mellőle +mellőz +mellpáncél +mellső +melltartó +mellű +mellvéd +mellvért +meló +melós +melózik +mely +melyik +memória +memorandum +memoriter +mendegél +menedék +menedékes +menedékhely +menedzser +menekedik +menekít +menekül +menekülés +menekülő +menekülőkészülék +menekült +menekvés +menet +menetel +menetelés +menetgyakorlat +menetirány +menetlevél +menetrend +menetszázad +menetvázlat +menhely +menlevél +menny +mennybevitel +mennydörgés +mennydörög +mennyezet +mennyezeti +mennyi +mennyiben +mennyire +mennyiség +mennyiségi +mennyiségű +mennyország +menő +ment +mente +mentén +mentés +menteget +mentegetés +mentegetődzés +mentegetődzik +menten +mentes +mentesít +mentesítés +mentesítő +mentesség +mentességi +mentesül +menthetetlen +menthető +menti +mentő +mentőállomás +mentőkészülék +mentőkocsi +mentől +mentőműszak +mentőöv +mentőszolgálat +mentség +meny +menyasszony +menyasszonyi +menyét +menyecske +menyecskés +menyegző +menyegzői +menza +menzapénz +meós +mer +merénylet +merénylő +merész +merészel +merészkedik +merészség +mered +meredek +meredezik +meredt +mereget +mereng +mereszt +meresztget +merev +merevedik +merevít +merevítő +merevség +merevül +merít +merő +merőben +merőkanál +merőleges +merre +merről +mersz +mert +merthogy +merül +mese +mesél +mesélés +mesélget +mesés +mesebeli +mesekönyv +mesemondás +mesemotívum +meseszép +mesevároska +messianisztikus +messianizmus +messze +messzelátó +messzemenő +messzeség +messzi +mester +mesterember +mesterember-szoba +mesterfogás +mesteri +mesterkélt +mesterkéltség +mesterkedik +mesterlegényes +mesterlövész +mestermű +mesterművű +mesterség +mesterséges +mestertárs +meszel +meszelés +meszelő +meszelt +meszes +meszes-agyú +metán +metánkeverék +metafizika +metafizikai +metaforikus +metél +metélt +meteor +meteorhullás +metodikai +metróállomás +metronóm +metsz +metszett +metsző +metszőfog +mezei +mezítláb +mezítlábas +mező +mezőgazdaság +mezőgazdasági +mezőőr +mezőség +mezőváros +mezopotámiai +meztelen +meztelenkedés +meztelenség +mi +míder +míg +mígnem +mímel +míniumos +mínusz +mítosz +mialatt +miatt +miatta +miatyánk +micisapka +micisapkás +micsoda +midőn +miért +miegyéb +miegymás +mielőbb +mielőtt +mienk +miféle +mifene +mihamar +mihelyt +miként +miképpen +miközben +mikor +mikorára +mikrobusz +mikrofilmtár +mikrofon +mikrokamera +mikrokristály +mikroporózus +mikroszkóp +mikroszkopikus +mikszáth-regény +milánói +milliárd +milliméter +millió +milliom +milliomos +mily +milyen +mimikrinyájaskodás +mimóza +minap +mind +mind-mind +mindaddig +mindamellett +mindannyi +mindannyiszor +mindaz +mindazáltal +mindazonáltal +mindeddig +mindegy +mindegyaránt +mindegyik +mindegyre +mindemellett +minden +mindenáron +mindenekelőtt +mindenekfölött +mindenesetre +mindenestül +mindenevő +mindenfajta +mindenféle +mindenfelé +mindenfelől +mindenható +mindenhol +mindenhova +mindenik +mindenképpen +mindenki +mindenkor +mindennap +mindennapi +mindennapos +mindennemű +mindenség +mindenszentek +mindenteszik +mindentudó +mindenünnen +mindenütt +mindenüvé +mindez +mindhárom +mindhalálig +mindig +mindinkább +mindjárt +mindjobban +mindkét +mindkettő +mindmáig +mindnyája +mindnyájan +mindörökké +mindörökre +mindössze +minduntalan +mindvégig +minél +minek +mini +miniatúra +miniatűr +miniatűrfestő +minimális +minimum +ministráns +minisztérium +minisztériumi +miniszter +miniszterelnök +miniszterelnöki +miniszterelnökség +miniszterelnökségi +miniszterhelyettes +minisztermama +minőség +minőségi +minőségű +minősít +minősítés +minősítő +minorita +mint +minta +mintájú +mintás +mintáz +mintababa +mintajáték +mintakép +mintaszerű +mintegy +mintha +minthogy +mintsem +minuta +mióta +mire +mirelit +mise +misézik +misecsengő +misekehely +miseruha +miskárol +miskolci +misszió +misszionárius +miszerint +miszlik +misztérium +misztériumjáték +misztifikálás +mit +mitevő +mitológia +mitugrász +miután +mivel +mivelhogy +mivolta +mixernő +mizantropikus +mócsing +mód +módfelett +módi +módos +módosít +módozat +módszer +módszeres +módszertani +módú +móka +mókás +mókuci +mókus +mókusarcú +móló +mór +móres +móring +mögé +mögéje +mögött +mögötte +mögötti +mögül +mögüle +moccan +moccanás +moccanásnyi +moccanatlan +mocorgás +mocorog +mocsár +mocsári +mocsaras +mocskos +mocsok +modell +modellforma +modern +modernség +modor +modorú +modulátor +mogorva +mogyoró +mogyoróhab +mogyorókrémtorta +mogyorós +mogyorószín +mogyorószínű +moha +mohácsi +mohamedán +mohó +mohóság +mohos +molekula +molett +molibdénbánya +moll +molnár +molyette +molyirtó +molypille +molyrágott +molyrágta +monarchia +monarchiabeli +mond +monda +mondás +mondandó +mondanivaló +mondat +mondavilág +mondhatatlan +mondható +mondóka +mondogat +mondvacsinált +mongol +mongolka +mongolos +monitor +monográfia +monoklis +monológ +monologizál +monostor +monoszkóp +monoton +monotonság +monstrum +monumentális +mopszliarc +morális +moraj +morajlás +morc +morcos +mordály +mordul +morfondíroz +morgás +morgóéri +morgolódik +mormog +mormol +mormolás +morózus +morog +morran +morzsa +morzsányi +morzsalékos +morzsol +morzsolgat +morzsoló +morzsolódik +mos +mosás +mosakodás +mosakodik +mosat +mosatlan +mosdás +mosdat +mosdatlan +mosdik +mosdó +mosdóállvány +mosdóhely +mosdókagyló +mosdószer +mosdóvíz +moslék +mosódik +mosófazék +mosógép +mosókonyha +mosóteknő +mosogat +mosogatás +mosogató +mosogatólé +mosogatórongy +mosogatóvájdling +mosogatóvíz +mosoly +mosolyféle +mosolygás +mosolygós +mosolyintás +mosolyog +mosolyreflex +mosolytalan +most +mostanában +mostanáig +mostani +mostanság +mostoha +mostohaanya +mostohaapa +mostohagyerek +mostohalány +moszat +moszkvai +motalkó +motalkószag +motívum +motollagyors +motor +motorbicikli +motorcsattogás +motorcsónak +motorgyertya +motorház +motorháztető +motorkerékpár +motorkerékpáros +motorlánc +motoros +motoroshajó +motorozik +motorravaló +motortulajdonos +motorzaj +motorzúgás +motoszkál +motoz +motozás +motyó +motyog +motyogás +move-gondnok +mozaik +mozaikkép +mozdít +mozdítás +mozdító-mozgató +mozdony +mozdonyvezető +mozdul +mozdulás +mozdulat +mozdulatlan +mozdulatlanság +mozdulattevő +mozgás +mozgás-működés +mozgáskészség +mozgáspálya +mozgásszabadság +mozgástér +mozgású +mozgalmas +mozgalmi +mozgalom +mozgat +mozgatás +mozgatóideg +mozgékony +mozgólépcső +mozgólépcső-fok +mozgósít +mozgósítás +mozgósul +mozgolódás +mozgolódik +mozi +mozilátogatás +mozipénz +mozivászon +mozog +mozsár +mozzanat +múlás +múlhatatlan +múlik +múló +múlt +múlta +múltán +múltbeli +múltidéző +múltkor +múltkori +múltkoriban +múlva +múmia +múmiafazon +múmiaplasztika +múzeum +múzeumi +múzsa +múzsakergető +mű +műalkotás +műanyag +műanyag-vegyészet +műanyagos +műbőr +műdal +műélvezet +műértő +műemlék +műfaj +műfelháborodás +műfogsor +műgond +műhaj +műhely +műhelyajtó +műhelyfőnök +műhelyiroda +műhelyszoba +műhelyudvar +műhímző +műintézet +működés +működési +működik +működtet +működtetés +műláb +műmárvány +műpapagáj +műremek +műselyem +műsor +műsorlap +műszak +műszaki +műszakos +műszakváltás +műszer +műszerasztal +műszerdoboz +műszerész +műszerkocsi +műszó +műtét +műterem +műteremtulajdonos +műtő +műtőasztal +műtrágyaelosztó +műút +művész +művészbejáró +művészest +művészet +művészetfelfogás +művészeti +művészettörténet +művészi +művésznép +művésznő +művésztelep +művel +művelés +művelet +műveletlen +műveletlenség +művelhetetlen +művelhető +művelő +művelődési +művelt +műveltség +művezető +mucsai +muflon +mufloncsapat +muki +mukk +mukkan +mukkanás +mulandóság +mulaszt +mulasztás +mulat +mulató +mulatós +mulatozás +mulatság +mulatságos +mulatt +mulattat +mulyaság +mumus +mundér +muníció +munka +munkál +munkálat +munkálkodás +munkálkodik +munkáltató +munkás +munkáscsalád +munkásegység +munkásember +munkásféle +munkásfelvétel +munkásfigura +munkáshatalom +munkáskérdés +munkáskéz +munkáslakta +munkáslégkör +munkásmozgalmi +munkásmozgalom +munkásnő +munkásőr +munkásőrség +munkásosztály +munkásotthon +munkáspárt +munkásság +munkásséma +munkásszállás +munkásszálló +munkásszázad +munkásszakma +munkástanács +munkásvédelem +munkátlan +munkaadó +munkaalkalom +munkabér +munkacsapat +munkaegység +munkaerő +munkaerőváltás +munkafázis +munkafolyamat +munkahely +munkahelyiség +munkaidő +munkaképes +munkakereső +munkakerülés +munkakezdés +munkakönyv +munkakör +munkakörülmény +munkaközösség +munkaközösségi +munkalap +munkalehetőség +munkamenet +munkanélküli +munkanélküliség +munkaóra +munkaoverall +munkaprogram +munkarend +munkaruha +munkaszín +munkaszolgálat +munkaszolgálatos +munkatábor +munkatárs +munkaterület +munkaügyi +munkaügyis +munkavállalási +munkavezető +murci +muri +muris +muskátli +muskátlibokor +muskátlis +muskátlitő +muskotály +must +mustár +mustárospohár +mustárpohár +mustra +mustrálgat +muszáj +mutat +mutatkozik +mutató +mutatós +mutatóujj +mutatvány +muter +mutogat +mutyi +muzsika +muzsikál +muzsikáltatás +muzsikás +na +na-na +nában +náci +náció +nád +nádas +náderesz +nádfal +nádfonat +nádfonatú +nádi +nádor +nádorispán +nádpalló-rakás +nádpernye +nádrengeteg +nádsíp +nádszál +nádszálvékony +nádszék +nádszéli +nádszedő +nádtető +nála +nápolyi +nász +nászajándék +násznagy +násznagyné +násznép +nászút +nátha +náthás +nacionalista +nacionalizmus +nadrág +nadrággomb +nadrágszíj +nadrágtartó +nadrágzseb +nadragulya +naftalinszag +nagy +nagy-nagy +nagyállomás +nagyária +nagyáruház +nagyanya +nagyapa +nagyapamellény +nagyarányú +nagyasszony +nagyasszonyi +nagyasztal +nagybácsi +nagybátya +nagybérlő +nagybeteg +nagybetű +nagybetűs +nagybirtokos +nagyböjt +nagybőgő +nagycsizmás +nagydarab +nagydíj +nagydob +nagydumás +nagyétkű +nagyerdő +nagyfamília +nagyfejű +nagyfilm +nagyfiú +nagyfőnök +nagyfotel +nagyfülű +nagygazda +nagygazdafiú +nagygazdaporta +nagygyűlés +nagyházas +nagyhangú +nagyhatalom +nagyít +nagyítás +nagyító +nagyipar +nagyjában +nagyjában-egészében +nagyjából +nagykabát +nagykapu +nagykarimájú +nagyképű +nagyképűség +nagyképűsködik +nagykendő +nagykereskedelmi +nagykereskedő +nagykövet +nagykövetség +nagylány +nagylányos +nagylelkű +nagymama +nagymami +nagymarosi +nagyméretű +nagymértékben +nagymenő +nagymester +nagymosás +nagymuter +nagymuterék +nagynéni +nagynénike +nagynevű +nagyöntő +nagyöntvény +nagyocska +nagyokos +nagyolás +nagyolvasztó +nagyon +nagyon-nagyon +nagyothall +nagyothalló +nagypapa +nagypénteki +nagypénzű +nagypolgár +nagyponyva +nagyravágyás +nagyravágyó +nagyrészt +nagyság +nagysága +nagyságáék +nagyságos +nagyságrend +nagyságú +nagysokára +nagyszabású +nagyszerű +nagyszerűség +nagyszoba +nagyszülő +nagytányérú +nagytakarít +nagytakarítás +nagytakarító +nagyteknő +nagyterem +nagytermészetű +nagytermetű +nagytükör +nagyúr +nagyúri +nagyüzem +nagyüzemi +nagyujj +nagyvállalat +nagyváradi +nagyváros +nagyvárosi +nagyvásár +nagyvacsora +nagyvad +nagyvasúti +nagyvendéglő +nagyvevő +nagyvezér +nagyvilág +nagyvilági +nagyvilágiasság +nagyvonalú +nagyvonalúság +nagyzási +nahát +naiv +naivság +nana +naná +nanü +nap +napbarnított +napcserzette +napernyő +napestig +napfény +napfényátalakító +napfényenergia +napfényenergia-átalakító +napfényes +napfeljötte +napfelkelte +napfolttevékenység +napfordulás +naphosszat +napi +napidíj +napilap +napiparancs +napirend +napkeleti +napkelte +napkitörés +napközben +napközi +napkorong +naplemente +napló +naplójegyzet +napnyugta +napocska +napolajmárka +naponként +naponkénti +naponta +napos +napozik +napozó +nappal +nappali +napraforgó +napraforgószár +naprendszer +napsütés +napsütéses +napsütötte +napsugár +napsugárzás +napszállta +napszám +napszámol +napszámos +napszemüveg +napszítta +naptár +napvilág +narancs +narancsárus +narancslekvár +narancsos +narancssárga +narancsszín +narkotizál +narodnyik +naturalista +navigátor +nazálistalan +ne +néger +négy +négy-öt +négyágyas +négyéves +négyemeletes +négyes +négyes-ötös +négyesztendős +négyezer +négyezer-hétszáztizenegyes +négyezer-nyolcszázötven +négyezres +négyféle +négyfelől +négyhónapos +négykézláb +négymotoros +négynapi +négyötöd +négyszáz +négyszázezer +négyszázhúsz +négyszázhuszonnyolc +négyszázmillió +négyszázötven +négyszáztizenegyes +négyszemközt +négyszög +négyszöglépés +négyszögletes +négyszögletű +négyszögű +négyszobás +négytagú +négyzet +négyzetméter +négyzetméternyi +négyzetmilliméter +néha +néha-néha +néhány +néhányad +néhányszor +néhai +néhanap +néhol +nélkül +nélküle +nélküli +nélkülöz +nélkülözés +nélkülözhetetlen +nélkülözhető +néma +némafilm +némaság +némber +némely +némelyik +némelykor +német +német-magyar +németbarát +németellenes +németországi +németség +némi +némiképpen +némileg +néne +nénémasszony +néni +néniék +nénike +néniz +nép +népbutítás +népdal +népdalkutatás +népérdek +népes +népfőiskolás +népfront +népfronttaktika +népgazdasági +népgyűlés +néphadsereg +néphumor +népi +népi-nemzeti +népítélet +népjóléti +népköztársaság +népkormány +népmese +népnevelő +néprajzi +néprajzkutató +népség +népszenvedés +népszerű +népszerűség +népszokás +néptelen +néptribunus +néptribunus-diktátor +néptribunusi +népünnepély +népünnepélyi +népvándorlás +népvándorláskori +népvezér +név +névelő +névjegy +névjegykártya +névkeletkezés +névleges +névmemória +névnap +névsor +névsorolvasás +névtábla +névtelen +néz +nézés +nézésű +nézeget +nézelődik +nézelődő +nézet +nézeteltérés +nézgelődik +néznivaló +néző +nézőközönség +nézőpont +nézősereg +nézőtér +nézve +nézvést +neandervölgyi +nebuló +nedű +nedv +nedves +nedvesség +nefelejcs +negatív +negatívum +negédes +neglizsé +negyed +negyedév +negyedéves +negyedévi +negyedhold +negyedik +negyedikei +negyedikes +negyedmagával +negyednap +negyedóra +negyedórás +negyedrész +negyedrét +negyedrendű +negyedszázad +negyven +negyven-hatvan +negyven-negyvenkét +negyven-negyvenöt +negyven-ötven +negyvenéves +negyvenévi +negyvenegy +negyvenes +negyvenezer +negyvenhárom +negyvenhat +negyvenhét +negyvenkét +negyvenkettő +negyvenkilenc +negyvennégy +negyvennyolc +negyvenöt +negyvenötezer +negyvenpercnyi +nehéz +nehézfejű +nehézkes +nehézkesség +nehézség +nehézsúlyú +nehéztank +nehezék +nehezedik +nehezít +neheztel +neheztelés +nehogy +neje +nejlonbili +neki +nekiáll +nekibátorodik +nekibúsul +nekibuzdulás +nekicsapódik +nekidől +nekidühödik +nekiesik +nekifekszik +nekifeszül +nekifog +nekifohászkodik +nekifut +nekigyürkőzik +nekihettyent +nekihevülés +nekiindít +nekiindul +nekiiramodik +nekikészül +nekikezd +nekilát +nekilendül +nekilódul +nekilök +nekimegy +nekinyom +nekiöltözködik +nekirohan +nekiront +nekirúg +nekirugaszkodás +nekisimul +nekiszalad +nekitámad +nekitámaszkodik +nekitámaszt +nekiüt +nekiütközik +nekiütődik +nekiugrik +nekiuszít +nekivág +nekivadul +nekiverődik +nekivet +nektár +nem +nem-kiválasztott +nem-mosdás +nemcsak +nemde +nemegyszer +nemes +nemesasszony +nemesedik +nemesember +nemesgáz +nemesi +nemesít +nemesítés +nemesség +nemhiába +nemhogy +nemi +nemigen +nemiség +nemjóját +nemkívánatos +nemkülönben +nemlét +nemleges +nemrég +nemrégen +nemrégiben +nemsokára +nemtelen +nemtetszés +nemtörődöm +nemtörődömség +nemű +nemz +nemzedék +nemzet +nemzetbomlasztó +nemzetes +nemzetgazdaság +nemzetgyalázó +nemzeti +nemzetiségi +nemzetiségű +nemzetiszín +nemzetközi +nemzetmegváltó +nemzetség +nemzette +nemzőszerv +neon +neonbetű +neoncsillag +neonfalú +neonlámpa +neonos +neonreklám +neonsugár +neontraverz +nesz +nesze +neszezés +nesztelen +netalán +netovább +neurózis +neurotikus +nevel +nevelés +nevelési +neveletlen +nevelhető +nevelkedik +nevelő +nevelőanya +nevelőapa +nevelőhatás +nevelői +nevelőnő +nevelőszülő +neveltetés +neves +nevesincs +nevet +nevetés +nevetgél +nevetgélés +nevethetnék +nevetnivaló +nevetőkényszer +nevetős +nevetség +nevetséges +nevez +nevezetes +nevezetesség +nevezetű +nevezhető +nevező +nevű +ni +nigériai +nihil +nikkel-csukló +nikkelbánya +nikkelcső +nikkelez +nikotin +nikotinrágott +nimfa +nimfás +nimfománia +nimfomániás +nincs +nincstelen +nitromin +nitrum +nivellál +nivellálógép +no +nógat +nógatás +nóta +nótárius +növény +növényfajta +növényi +növénykultúra +növénynemesítő +növénysor +növénytankönyv +növénytermesztés +növényvilág +növényzet +növés +növésű +növekedés +növekedési +növekedik +növekvő +növel +növendék +növendékgárda +növendékkakas +növeszt +nő +nőcske +nőember +nőgyógyász +női +nőies +nőiesség +nőpárti +nőportré +nőrokon +nős +nőség +nőstény +nősténykacaj +nősténytest +nősül +nősülés +nősülési +nőszemély +nőtársadalom +nőtag +nőtanács +nőtípus +nőtlen +nőttön-nő +nőügy +nővér +nővérke +nocsak +noha +nohát +nono +nonszensz +norma +normál +normális +normandi +normatíva +nos +noszogat +nosztalgia +nosztalgikus +notesz +notórius +novella +november +novemberi +nukleáris +nulla +nullás +nuncius +nyáj +nyájas +nyájasság +nyál +nyáladzik +nyálas +nyálka +nyálkás +nyápic +nyár +nyáréjszakai +nyárfa +nyárfaerdő +nyári +nyárias +nyárs +nyársal +nyárspolgár +nyárspolgári +nyafog +nyafogás +nyaggat +nyaggatás +nyak +nyakal +nyakasság +nyakatört +nyakcsigolya +nyakhajlás +nyakhossz +nyakkendő +nyakkendőtlen +nyaklánc +nyakleves +nyakló +nyakörv +nyakra-főre +nyakravaló +nyakszirt +nyaktörő +nyakú +nyal +nyaláb +nyalánkság +nyaldos +nyalka +nyalókázás +nyalogat +nyamvadt +nyaral +nyaralás +nyaraló +nyaralócska +nyaralóház +nyaranta +nyargal +nyargalászik +nyavalya +nyavalyás +nyavalygás +nyavalyog +nyél +nyegle +nyegleség +nyekereg +nyekerget +nyel +nyeldekel +nyeldeklés +nyeldeklő +nyeldes +nyeleget +nyelőcső +nyelű +nyelv +nyelvatlaszos +nyelvcsere +nyelvészet +nyelvészkongresszus +nyelvecske +nyelvi +nyelvóra +nyelvtan +nyelvtanár +nyelvtanfolyam +nyelvtudás +nyelvtudomány +nyelvű +nyer +nyerés +nyereg +nyeregtáska +nyereség +nyereségrészesedés +nyergeletlen +nyergelő +nyerges +nyerít +nyerő +nyers +nyers-durva +nyersáru +nyersanyag +nyersanyagellátás +nyersanyagmennyiség +nyersfordítás +nyersgumi +nyersgyapjú +nyerstégla +nyest +nyeszlett +nyíl +nyílás +nyílegyenes +nyílik +nyílik-csukódik +nyíllövésnyi +nyílt +nyíltság +nyílvessző +nyír +nyírás +nyírat +nyíratlan +nyírbotondi +nyíregyházi +nyíres +nyírfa +nyírfaseprő +nyikkan +nyikordulás +nyikorgás +nyikorog +nyilall +nyilas +nyilaskeresztes +nyilasvezér +nyilatkozat +nyilatkozik +nyilaz +nyilván +nyilvánít +nyilvános +nyilvánosság +nyilvántart +nyilvántartás +nyilvántartási +nyilvántartó +nyilvánvaló +nyiratkozik +nyirkos +nyirkosság +nyiszorgás +nyiszorog +nyit +nyitány +nyitás +nyitogat +nyitott +nyivákol +nylondarabka +nylonfolt +nylonharisnya +nyloning +nylonzacskó +nyög +nyögdécsel +nyögés +nyöszörgés +nyöszörgetés +nyöszörög +nyolc +nyolc-kilenc +nyolc-tíz +nyolcad +nyolcadik +nyolcas +nyolcéves +nyolcévi +nyolcesztendős +nyolcezer +nyolcezer-kétszázharmincas +nyolcfelé +nyolchetes +nyolchónapos +nyolckötetes +nyolcszáz +nyolcszáz-ezer +nyolcszázhatvan +nyolcszázkilencvennégyes +nyolcvan +nyolcvanadik +nyolcvanéves +nyolcvanezer +nyolcvanhármas +nyolcvanhat +nyolcvanhatos +nyolcvanhét +nyolcvankét +nyolcvankilenc +nyolcvanöt +nyolcvanöt-kilencven +nyolcvanszázalékos +nyom +nyomán +nyomás +nyomású +nyomakodik +nyomaszt +nyomasztó +nyomaték +nyomatékos +nyomban +nyomda +nyomdász +nyomdaigazgató +nyomdok +nyomjelző +nyomkod +nyomódik +nyomóerő +nyomós +nyomogat +nyomor +nyomorék +nyomorog +nyomorúság +nyomorúságos +nyomorult +nyomorultság +nyomott +nyomoz +nyomozás +nyomozó +nyomozótiszt +nyomtalan +nyomtat +nyomtatás +nyomtatott +nyomtatvány +nyomul +nyoszolya +nyújt +nyújtó +nyújtózik +nyújtózkodik +nyújtogat +nyúl +nyúlánk +nyúlbőr +nyúlfi +nyúlgát +nyúlik +nyúlkál +nyúlketrec +nyúlós +nyúz +nyúzott +nyüszít +nyüzsgés +nyüzsög +nyű +nyűg +nyűgös +nyűgösködik +nyűtt +nyugágy +nyugállományú +nyugalmas +nyugalmazott +nyugalom +nyugalom-kielégülés +nyugat +nyugat-magyarországi +nyugat-ukrajnai +nyugati +nyugatnémet +nyugatrómai +nyugdíj +nyugdíjas +nyugdíjasság +nyugdíjaz +nyugdíjazás +nyugdíjaztatás +nyugdíjigénylő +nyugdíjjogosultság +nyughatatlan +nyugi +nyugodalmas +nyugodt +nyugovó +nyugszik +nyugta +nyugtáz +nyugtalan +nyugtalanít +nyugtalankodás +nyugtalankodik +nyugtalanság +nyugtat +nyugtatgat +nyugtató +nyugton +nyugvás +nyulas +nyurga +oázás +oázis +objektív +objektum +oboás +oboazene +obsitos +obszcén +ocsmány +ocsmányság +ocsúdik +oda +oda-odavet +oda-vissza +odább +odábbáll +odábbhajt +odáig +odaáll +odaállít +odaát +odaáti +odaad +odaadás +odaadó +odaadogat +odaakaszt +odaballag +odabe +odabenn +odabiccent +odabiceg +odabök +odabotorkál +odabújik +odacsap +odacselez +odacsíp +odacsörtet +odadöcög +odadob +odadünnyög +odadug +odaég +odaépít +odaér +odaérkezik +odaenged +odafér +odafektet +odafenn +odafigyel +odafordul +odafurakodik +odafut +odagömbölyödik +odagombostűz +odaguggol +odahagy +odahajol +odahajt +odahallgat +odahaza +odahelyez +odahímez +odahív +odahordat +odahoz +odahúz +odahúzódik +odaígér +odaír +odaigazít +odailleszt +odaint +odainvitál +odajár +odajön +odajut +odakacsint +odakap +odakészít +odakerül +odakínál +odakiált +odakiabál +odakinn +odakönyököl +odakönyörög +odaköszön +odakoccan +odakozmál +odaküld +odalátszik +odalép +odalépked +odalenn +odalenti +odalesz +odalibben +odalopódzik +odamázol +odamadzagol +odamegy +odamond +odamutat +odanéz +odanyom +odanyújt +odanyúl +odapillant +odapörög +odaragad +odaragaszt +odarendel +odarendez +odarögződik +odarohan +odasétál +odasiet +odaslalomoz +odasodor +odasomfordál +odasorol +odasúg +odasurran +odaszalad +odaszegődik +odaszól +odaszorít +odatámaszt +odatalál +odatapad +odatapaszt +odatart +odatartozik +odataszigál +odatérdepel +odatelefonál +odatelepedik +odatelepít +odatelepszik +odaterel +odatesz +odatömörül +odatol +odatolat +odaül +odaugrik +odautasít +odautazik +odavág +odavár +odavaló +odavalósi +odavan +odavesz +odavet +odavezérel +odavezet +odavezettet +odavisz +odavizel +odavon +odavonz +odú +odvas +ohó +ok +okádhatnék +okfejtés +okít +okirat +oklevél +okleveles +okmány +okol +okorcai +okos +okoskodás +okoskodik +okosság +okoz +okozó +oktáv +oktalan +oktat +oktatás +oktatgat +oktató +oktatói +oktatótábla +október +októberi +oktondi +okul +okuláré +okulás +okvetetlenkedik +okvetlen +okvetlenül +oláh +olaj +olajbányászat +olajbogyó +olajcsere +olajfa +olajfestmény +olajipar +olajkapcsoló +olajmalom +olajmérnök +olajmező +olajos +olajosbarna +olajoz +olajozatlan +olajozott +olasz +olaszországi +olaszos +olcsó +old +oldal +oldalág +oldalas +oldalaz +oldalcsarnok +oldalfal +oldalfél +oldalfegyver +oldalfegyveres +oldalfülke +oldali +oldalirány +oldalkocsi +oldalnézet +oldalog +oldalpillantás +oldalrekesz +oldalsó +oldalszakáll +oldalszakállas +oldalt +oldaltáska +oldaltarisznya +oldalú +oldalvást +oldalzsák +oldalzseb +oldat +oldhatatlan +oldódás +oldódik +oldott +oldoz +olíva +oligarchia +olló +ollócsattogtatva +ollóz +olt +oltár +oltári +oltalmaz +oltalom +olthatatlan +oltogat +oltott +olvad +olvadás +olvas +olvasás +olvasatlan +olvasgat +olvasható +olvasmány +olvasó +olvasókönyv +olvasólámpa +olvasólap +olvasott +olvasta +olvaszt +olvasztó +olvasztókohó +oly +olyan +olyanféle +olyanformán +olyankor +olyannyira +olyasféle +olyasmi +olyasvalami +olyha +olykor +olykor-olykor +ombolyos +omlás +omlásszerű +omladék +omladozik +omlaszt +omlatag +omlékony +omlik +omlós +ondolál +onnan +ont +opál +opálkék +opállemez +opálos +opálszínű +opáltábla +opera +operáció +operál +operálás +operabuzi +operaénekes +operatív +operatőr +operett +operettfinálé +operettmelódia +operettprimadonna +operettszínpad +opportunista +opportunizmus +optimális +optimista +optimizmus +opus +orangután +oratórium +orca +orcácska +ordas +ordít +ordítás +ordító +ordítozás +ordítozik +ordináré +organizál +organizmus +orgazda +orgia +orgiázás +orgona +orgonabokor +orgonabúgás +orgonasíp +orgonaszó +orgyilkosság +orientálódás +orkán +orkánkabát +ormányos +ormótlan +ornamentika +orom +oromzatos +orosházi +orosz +oroszlán +oroszlánfej +oroszlányi +oroszországi +orr +orrcimpa +orrdeszka +orrfacsaró +orrhang +orrhegy +orrhossz +orrlyuk +orrnyereg +orrú +orsó +orsózónő +ország +országbeli +országgyűlés +országgyűlési +országhatár +országjárás +országocska +országos +országrész +országút +országúti +ort +ortopéd +orvos +orvosdoktor +orvosgépészet +orvosgyűlölet +orvosi +orvosi-nővéri +orvosnő +orvosol +orvosprofesszor +orvosság +orvosszakértő +orvostáska +orvostanhallgató +orvostudomány +orvostudor +orvul +osj +oson +ostoba +ostobaság +ostor +ostoroz +ostrom +ostrom-felszerelés +ostromgyűrű +ostromol +ostromtábor +ostya +ostyasütő +oszlik +oszló +oszlop +oszlopcsarnok +oszlopos +oszlopszent +oszol +oszt +osztály +osztályfeletti +osztályfőnök +osztályfőnöknő +osztályharc +osztályidegen +osztályigazgató +osztálylétszám +osztályösztön +osztályos +osztályrész +osztálytárs +osztálytársnő +osztálytitkár +osztályú +osztályvezető +osztályvezetői +osztályzat +osztályzengésű +osztás +osztag +osztalék +osztatlan +osztják +osztogat +osztozkodás +osztozkodik +osztrák +otellóbor +otp-beugró +otp-kölcsön +otromba +ott +ott-tartózkodás +ottan +ottani +ottfelejt +otthagy +otthon +otthoni +otthonias +otthonos +otthonosság +otthontalanság +otthonvezető +ottmarad +ottomán +ottveszik +ovális +overall +overallos +oxigén +oxigénhiány +oxigénpalack +ó +óbégat +óbégatás +óbudai +óceán +ócsárol +ócska +ócskaság +ócskavas +ódivatú +ódon +ódzkodik +ófrancia +óhaj +óhajt +óhatatlan +ókapu +ókor +ókori +ókút +ól +ólálkodik +ólbeli +ólmos +ólmos-fenséges +ólom +ólomdarab +ólomláb +ólomnehéz +ólomszürke +ónpohár +óra +órácska +órányi +órás +órásmester +órabér +óradíj +órafityegő +óragyűjtő +óralánc +óramutató +óraszerkezet +óratorony +óriás +óriásgömb +óriási +óriáslepke +óriásrakéta +ósdi +ószer +ószeres +óta +ótestamentumi +ótvaros +óv +óváros +óvás +óvakodik +óvatlan +óvatos +óvatoskodik +óvatosság +óvilági +óvóhely +óvóhelyablak +óvóhelynyílás +óvoda +óvodás +óvszer +ózon +ózondús +öblöget +öblös +öböl +öbölszerű +öcs +öcsémuram +öcsike +öklendezés +öklendezik +öklömnyi +öklöz +öklözés +ököl +ökölcsapás +ökölnyi +ökölszorító +ökölvívás +ökölvívó +ökör +ökörcsorda +ökörfarkkóró +ököriga +ökörnyál +ökonómia +ökrösszekér +öl +öldöklés +öldöklő +ölel +ölelés +ölelget +ölelgetés +ölelkezés +ölelkezik +öles +ölet +ölnyi +ölt +öltöny +öltözék +öltözet +öltözetecske +öltözik +öltözködés +öltözködik +öltöző +öltözőbódé +öltöztet +ölyv +ömleszt +ömlik +ön +önálló +önállóság +önállósít +önállósodási +önállósulás +önalakítás +önalakító +önbíráló +önbizalom +önbiztosító +önborotva +öncélú +öncenzúra +öncsalás +önéletrajz +önérdek +önérzet +önérzetes +önelégültség +önelemzés +önellátó +önerő +önfegyelem +önfejű +önfejűség +önfeláldoz +önfeláldozás +önfeláldozó +önfeledt +öngúny +öngyilkos +öngyilkosság +öngyilkosságvágy +öngyújtó +önigazolás +önirónia +önként +önkéntelen +önkéntes +önkény +önkényes +önkényeskedés +önkényesség +önkínzás +önkívület +önkifejezési +önköltségi +önmaga +önmérgezés +önmentő +önműködő +önnön +önnönmaga +önpusztító +önsajnálás +önsajnálat +önszántából +önszobor +önt +öntés +öntelt +önteltség +öntetszelgés +öntevékeny +öntöde +öntöget +öntörvény +öntöttvas +öntöttvas-üzem +öntöz +öntözés +öntözéses +öntözőcsődarab +öntözőkanna +öntözőkocsi +öntözőrendszer +öntudat +öntudatfoszlány +öntudatlan +öntudatos +önuralom +önvád +önvédelem +önvédelmi +önvédő +önvezérlő +önvigasztalás +önvizsgálat +önzés +önzetlen +önzetlenség +önző +ördög +ördögi +ördögszekér +ördögűzés +ördöngös +ördöngösség +öreg +öreganya +öregasszony +öregecske +öregedés +öregedik +öregedő +öregember +öreges +öregfater +öregfiú +öregkor +öregkori +öreglány +öreglegény +öregség +öregség-szag +öregségi +öregúr +öreguras +örmény +örök +örökéletű +örökhagyó +örökké +örökkévalóság +örökkön +öröklakás +öröklés +öröklét +örökletes +öröklődik +örököl +örökös +örökösödés +örökre +örökség +örökvirágzó +örökzöld +öröm +örömhír +örömmegnyilvánulás +örömtanya +örömtelen +örömtűz +örül +örvény +örvénylik +örvend +örvendetes +örvendezés +örvendezik +összbüntetés +össze +össze-összenéz +összébb +összeáll +összeállít +összeázik +összeakad +összeakaszt +összebalhézik +összebarátkozik +összebeszél +összebilincsel +összebonyolódik +összeborul +összeborzad +összeborzol +összebotlik +összebújik +összebütyköl +összecsacsog +összecsap +összecsapás +összecsapkod +összecsattogtat +összecsendül +összecsíp +összecsikorgat +összecsinál +összecsókol +összecsődít +összecsomagol +összecsomósodik +összecsomóz +összecsücsörít +összecsuk +összecsukható +összecsuklik +összecsukódik +összedörzsöl +összedől +összedob +összedobál +összedolgozik +összedrótoz +összedug +összeég +összeéget +összeér +összeegyeztethetetlen +összeenged +összeerőlködik +összeesik +összeesküvés +összeesküvő +összeeszkábál +összefércel +összeférhetetlen +összeférhetetlenség +összefekszik +összefen +összefog +összefogás +összefogdos +összefoglal +összefoglaló +összefolyik +összefon +összefonnyad +összefonódik +összeforr +összeforraszt +összefos +összefügg +összefüggés +összefüggéstelen +összefüggő +összefűz +összefurikázik +összefut +összeg +összegabalyodik +összegereblyéz +összegez +összegezés +összegömbölyödik +összegombol +összegürizik +összegubbaszkodik +összegyűjt +összegyűjtöget +összegyűlik +összegyűlt +összegyűr +összegyűrődik +összegzés +összeházasodás +összeházasodik +összehajol +összehajt +összehajtogat +összehangol +összehangolódik +összeharap +összehasonlít +összehasonlítás +összehasonlítási +összehasonlítgat +összehasonlíthatatlan +összehasonlítható +összehasonlító +összehív +összehord +összehoz +összehúz +összehúzat +összehúzódik +összehúzódik-kitágul +összehunyorít +összeír +összeírás +összeírat +összeírt +összeilleszt +összeillesztés +összeillő +összeismerkedik +összejár +összejátszás +összejön +összejövetel +összekacsint +összekalapál +összekap +összekapar +összekapaszkodik +összekapcsol +összekapcsolódik +összekapkod +összekarol +összekaszabol +összekattint +összeken +összekerül +összekever +összekeveredik +összekócol +összeköltöztet +összeköt +összekötöz +összekötő +összekötődik +összeköttetés +összekoccan +összekoccanás +összekoccant +összekoccint +összekopíroz +összekovácsol +összekulcsol +összekunkorodik +összekuszál +összekuszálódik +összemaszatol +összemér +összemelegedik +összemelegít +összemos +összemosódik +összemosolyintás +összemosolyog +összenéz +összenyálaz +összenyom +összeölelkezik +összeolvad +összeolvadás +összeomlik +összepakol +összepasszol +összepofoz +összeprésel +összeráncol +összerándul +összeránt +összeráz +összerázkódik +összeragad +összerak +összerakás +összerakodik +összerezzen +összeröhög +összerogy +összeroppan +összeroskad +összerugdal +összes +összesen +összeseper +összesereglik +összesít +összesküvés +összesség +összesúg +összesúrlódik +összeszámít +összeszámol +összeszalad +összeszélhámoskodik +összeszed +összeszerel +összeszerez +összeszid +összeszólalkozik +összeszövődés +összeszokik +összeszorít +összeszorul +összeszűkül +összetákol +összetalálkozás +összetalálkozik +összetapad +összetapos +összetart +összetartozás +összetép +összetétel +összetéveszt +összetéveszthető +összeterel +összetesz +összetett +összetevő +összetevődik +összetöpped +összetör +összetördel +összetörik +összetört +összetorlódik +összeturkál +összeül +összeüt +összeütközés +összeütközik +összeugrik +összevág +összeválogat +összevásárol +összevagdal +összevagdos +összevarr +összevegyít +összevegyül +összever +összeverbuválás +összeverekedik +összeverődik +összevesz +összevillan +összevissza +összevisszaság +összevon +összevont +összezár +összezáródik +összezárul +összezavar +összezavarodik +összezördül +összezsúfol +összezsúfolódik +összezsugorodik +összezúz +összfüggés +összhang +összjáték +összkép +összkomfort +összkomfortos +összmosoly +össznépi +összpontosít +összpontosul +össztánc +ösvény +ösvényszél +ösztökél +ösztön +ösztön-ész +ösztöndíj +ösztönfegyverzet +ösztönös +ösztönöz +ösztönrugó +ösztönszárny +ösztönszerű +ösztönű +ösztönzés +ösztönző +ösztövér +öszvér +öszvérszerű +öt +öt-hat +öt-hatéves +öt-hatezer +öt-tíz +ötágú +ötbetűs +ötévenkénti +ötéves +ötemeletes +ötezer +öthónapos +ötkilós +ötkilométeres +ötkupolás +ötlépcsős +ötlet +ötletes +ötlik +ötliteres +ötöd +ötödik +ötös +ötszáz +ötszázhúsz +ötszáznyolcvan +ötszöri +ötszörös +ötszobás +ötvehét +ötven +ötven-hatvan +ötvencentes +ötvenéves +ötvenedik +ötvenegy +ötvenegyes +ötvenes +ötvenesztendei +ötvenezer +ötvenhárom +ötvenhat +ötvenhatos +ötvenhét +ötvenhetes +ötvenkét +ötvenkettő +ötvenkilenc +ötvennégy +ötvennyolc +ötvenöt +ötvenszázalékos +ötvös +öv +övé +övez +övezet +özön +özönlik +özönvíz +özvegy +özvegyasszony +özvegyi +ő +őbele +őbelőle +őbenne +ődöng +őérte +őellene +őelőtte +őfeléje +őfelsége +őfensége +őfőméltósága +őgyeleg +őhelyette +őhozzá +őkegyelmessége +őközte +őmellé +őmellette +őmiatta +őnála +őnagysága +őneki +őnfeledt +őr +őrá +őrajta +őrház +őrhely +őriz +őrizet +őrizetes +őrizget +őriztet +őrjítő +őrjöng +őrjöngés +őrködik +őrlánc +őrlet +őrmester +őrmester-mocskolódás +őrnagy +őrnagyi +őróla +őröl +őrs +őrség +őrsparancsnok +őrsvezető +őrszolgálat +őrtorony +őrület +őrületes +őrült +őrültség +őrvezető +őrzés +őrző +ős +ősállat +ősanya +ősatya +ősegyiptomi +őselem +ősember +őserdei +őserdő +őseredetű +ősfa +ősféreg +ősforma +ősgermán +őshalom +őshüllő +ősi +ősidő +őskőzet +őskőzetfelület +őskor +őskori +őslakó +őslény +őslénytani +őspark +ősprimitív +ősrémület +ősszel-tavasszal +őstehetség +őstelepes +ősz +őszes +őszes-szürke +őszi +őszibarack +őszibarackkompót +őszies +őszilevélarc +őszinte +őszinteség +őszirózsa +őszirózsás +őszül +őszülő +őtőle +őutána +ővele +őz +őzbak +őzcomb +őzszem +páciens +páciensjelölt +pácol +páholy +pájsli +pálca +pálcás +pálinka +pálinkáskupica +pálinkáspohár +pálinkásüveg +pálinkatócsa +pállik +pállott +pálma +pálmabor +pálmafa +pálmalevél +pálya +pályázat +pályázik +pályafutás +pályaőr +pályatárs +pályaudvar +pályaudvari +páncél +páncélos +páncélszekrény +páncéltörő +páncélzat +páni +pánik +pánt +pápa +pápai +pápaszem +pár +pára +párállik +párás +párásság +párabefutotta +párafelhő +párafolt +páratelt +páratlan +párbeszéd +párduc +párducos +párhuzam +párhuzamos +pária +párizsi +párkány +párna +párnás +párnaciha +párnacsata +párolódik +párolog +páros +párosodás +párosodik +párosul +párt +párta +pártapparátus +pártatlan +pártbizottság +pártbizottsági +pártélet +pártellenes +pártember +pártfogás +pártfogó +pártfogói +pártfogol +pártfunkcionárius +párthelyiség +párthíve +pártigazolvány +pártköszönés +pártközpont +pártmegbízott +pártmunka +pártnap +pártönzés +pártol +pártszerű +pártszerűség +pártszervezet +pártszolgálatos +párttag +párttagság +párttisztogatás +párttitkár +párttitkári +párttitkárság +párttörténet +pártütő +pártvezér +pártvezetés +pártvezető +párviadal +páskom +pászma +pásztáz +pásztor +pásztortűz +páter +páternoszter +pátosz +pátriárka +páva +pávás +páváskodik +pázsit +pacák +pacal +pacientúra +pacifikál +pacika +pacni +pacsirta +pacskol +pacuha +pad +padka +padlás +padlásablak +padláserkély +padlásfeljáró +padlásszoba +padló +padlódeszka +padlójú +padlórés +padlózat +padsor +pajkos +pajta +pajtás +pajtáskodik +pajtika +pajzán +pajzánság +pajzs +pakk +pakli +pakol +paktálás +palánk +palánkfal +palánta +palást +palástol +palack +palackos +palacsinta +palacsintasütő +palafedél +palaszürke +pali +palkonyai +pallér +pallérozás +pallérozatlan +pallérozott +palló +palota +palotás +palotai +pamacs +pamutharisnya +panasz +panaszkönyv +panaszkodás +panaszkodik +panaszol +panaszos +pancsol +pancsolás +pandúr +pandúros +paníroz +pankráció +pannóniai +panoptikumi +panoráma +panteisztikus +panyóka +panzió +pap +papa +papagáj +papagájszín +papaverin +papi +papír +papír-ceruza +papírbankó +papírcsomó +papírdarab +papírdarabka +papírforma +papírgyár +papírkatona +papírkosár +papírlap +papírpénz +papírpohár +papírrepülő +papírszalvéta +papírszelet +papírszeletke +papírtekercs +papírtrombita +papírvágó +papírvékony +papírzacskó +papiros +papirusz +paplak +paplan +papnövendék +papnő +papol +papos +paprika +paprikás +paprikásdoboz +paprikahalom +paprikapalánta +paprikaügy +paprikavörös +papucs +papucscsosszanás +papundekli +papuska +parádé +parádézik +parány +parányi +parázna +paráználkodik +paráznaság +parázs +parázslik +paradicsom +paradicsomi +paradicsomkaró +paradicsomkert +paradicsomos +paradicsompalánta +paradicsomrészleg +paradicsomügy +parafrázis +paragrafus +parancs +parancskiadás +parancsmegtagadás +parancsnok +parancsnokhelyettes +parancsnoki +parancsnokság +parancsol +parancsolat +parancsoló +parancsszegés +parancsszó +paranoiás +paraszpárti +paraszt +paraszt-képlet +paraszt-kispolgári +parasztarc +parasztasszony +parasztbor +parasztember +parasztfiú +parasztgyerek +parasztház +paraszthajszálnyi +paraszti +parasztlány +parasztnábob +parasztöntudat +parasztos +parasztpárt +parasztpárti +parasztpolitika +parasztruha +parasztruhás +parasztság +parasztszekér +paraván +parcella +pardon +pardonozik +parfümös +parfümszag +parízer +paripa +park +parkett +parkett-tánc +parketta +parkettviasz +parkíroz +parkol +parkosítási +parlag +parlament +parlamentáris +parlamenti +paróka +parókakészítő +parodista +parodizál +parolázik +paroli +parolis +part +parti +partizán +partizánköztársaság +partizánkodik +partizánlány +partizántiszt +partner +partoldal +partsáv +partszakasz +partszegély +parttető +partvíz +partvidék +partvis +pasa +pasas +pasi +paskol +passz +passzíroz +passzív +passzió +passzivitás +passzol +passzolgat +passzus +pasziánsz +pasztőrtej +pata +patak +patakocska +patakpart +pataktorkolat +patakzik +patentzár +patetikus +paticsfal +paticsfalú +patika +patikárius +patikamérleg +patikaszer +patikus +patikusék +patikusné +patina +patinás +patkány +patkánydög +patkányüldözés +patkó +patkószeg +patkol +patkolatlan +patkolóvas +patrícius +patríciusi +patrónus +patron +patronál +pattan +pattanás +pattanásos +pattantyús +pattint +pattog +pattogás +pattogató +pattogó +pattogós +pattogtat +patyolat +pauza +pavilon +pazar +pazarlás +pazarol +pécsi +pék +pékmester +példa +példány +példátlan +például +példáz +példázat +példabeszéd +példakép +példamutatás +példamutató +péntek +pénteki +pénz +pénzbüntetés +pénzcsinálás +pénzdarab +pénzecske +pénzember +pénzemésztő +pénzes +pénzeszsák +pénzharácsolási +pénzkérdés +pénznem +pénzpocsékolás +pénztár +pénztárablak +pénztárbelég +pénztárblokk +pénztárca +pénztárkönyv +pénztáros +pénztáros-kisasszony +pénztárosnő +pénzügy +pénzügyi +pénzügylet +pénzvilág +pép +peca +pecázás +pecázik +pecázó +pecabot +pecek +pech +peckes +pecsét +pecsétes +pecsétgyűrű +pecsétgyűrűs +pecsenye +pecsenyeliba +pecsenyeszín +pecsenyevadász +pedál +pedáns +pedagógia +pedagógiai +pedagógus +pedig +pedikűrös +pedikűrszalon +pedrő +pedz +pehely +pehelysúly +pehelysúlyú +pej +pelenka +pelenkaszegés +pelikán +pelyhedzik +pendely +pendelykémény +pendül +pendülés +penész +penészgombatelep +penészpofa +penészvirág +peng +penge +pengés +penget +pengetős +pengő +pengős +penna +penzió +penzió-dolog +peónia +pepepe +pepszin +per +perc +percéltű +perceg +percegés +perces +percmutató +percnyi +perdít +perdül +perdülés +perec +pereg +perel +perem +peremű +peresítés +pereskedés +perfekt +perforáció +pergamen +pergamenlapos +pergamenpállott +pergamentekercs +pergés +perget +pergőtűz +periódus +periódusezred +periódusmillió +periódusszázad +periódustized +peripatetikus +perlekedik +permet +permetez +permetezés +permetezik +permetezőgép +pernye +peron +perspektíva +persze +pertu +perverz +perverzitás +perzsa +perzsakabát +perzsalábkucsma +perzsaverő +perzsel +pesszimizmus +pesti +pestszentlőrinci +pestújhelyi +pesztra +petárda +petrencényi +petróleumlámpa +petróleumoshordó +petty +pettyes +petyhedt +petyhüdt +petyhüdt-édeskés +pezsgő +pezsgős +pezsgőspalack +pezsgőspohár +pezsgősüveg +pfű +pfuj +píp +pír +pia +piál +piás +piásüveg +piac +piaci +piackutatás +piacol +piacozik +piactér +pianó +pici +picike +piciny +picit +pihe +pihés +piheg +pihekönnyű +pihen +pihenés +pihenési +pihenő +pihenőhely +pihenőidő +pihenőóra +pihenőszoba +pihentet +pikáns +piké +pikémellény +pikíroz +pikkely +pikkelyes +pikszis +pilács +pilis +pilisi +pilisszentiváni +pilla +pillájú +pillátlan +pillanat +pillanatfelvétel +pillanatnyi +pillanatnyilag +pillangó +pillangónyakkendő +pillangószerű +pillant +pillantás +pillantgat +pille +pillér +pilléroszlop +pillog +pilóta +pimasz +pimaszkodik +pimaszság +pince +pincér +pincérfiú +pincérkabát +pincérlány +pincérnő +pincézik +pinceablak +pinceajtó +pinceboltozat +pincefal +pincehideg +pincelépcső +pincelejárat +pincelevegő +pincelyuk +pinceszag +pincsi +pingál +pingpongasztal +pingpongozik +pingvin +pintes +pióca +pionír +pipa +pipál +pipázik +pipacs +pipafüst +pipaszár +piperézkedik +piperecikk +piperezacskó +pipi +pipil +pipiske +pipiskedik +pipitér +pipogya +piramis +pirgál +pirít +pirítós +pirított +pirinyó +pirongat +pirongatás +pironkodik +piros +piros-fényes +piros-fehér +piroscserepes +piroscsíkos +piroslik +pirosodik +pirospaprika +pirospozsgás +pirul +pirula +pisil +pisis +piskóta +pislákol +pislant +pislog +pisszeg +pisszegés +pisze +piszkál +piszkálgat +piszkálódás +piszkafa +piszke +piszkos +piszkosfehér +piszkosság +piszkosszőke +piszkosszürke +piszlicsáré +piszmog +piszok +piszokul +pisztoly +pisztolycső +pisztolylövedék +pisztolytáska +pisztolytok +pitvar +pitvarajtó +pitvari +pitvarláb +pitvaros +pitye +pityereg +pityókos +pizsama +pizsamás +pláne +placc +plafon +plakát +plasztikgyáros +plasztikus +platán +platina +platinagyűrű +platinahaj +plató +platonisztikus +plazma +plébánia +plébániahivatal +plébános +pléd +pléh +pléhcsikó +pléhló +pléhpofa +plénum +plebejus +pletyka +pletykál +pletykás +pletykázik +pletykázó +pletykafészek +plomba +plüss +plüssfotel +plüssterítő +plusz +pluszadag +plutokrata +pneumatikus +pócgém +pócsmegyeri +pódium +pódiumművész +pók +pókerezik +pókháló +pókhálócsomó +pókhálós +pókhálószedés +pólus +pólya +pólyás +pópa +póráz +pórul +pórus +pórusú +pótapa +pótkávé +pótkocsi +pótkocsis +pótlás +pótlék +pótlólag +pótműszak +pótol +pótolhatatlan +pótsúly +pótszer +póz +pózna +pózolás +pöcegödör +pöcögtet +pödör +pöfékel +pöffeszkedik +pöfög +pöfögés +pökhendi +pökhendiség +pörget +pörgető +pörköl +pörkölt +pörköltmaradék +pörlekedik +pörög +pöröl +pörölycsapás +pörölyszerű +pörsenéses +pösze +pötyög +pötyögtet +pőre +pocak +pocakos +pocakszerű +pocsék +pocséta +pocsolya +pocsolyaíz +poén +pofa +pofás +pofátlan +pofázik +pofacsont +pofacsontú +pofafürdő +pofika +pofon +pofonegyszerű +pofonüt +pofonvág +pofoz +pogácsa +pogácsás +pogány +pogánykor +pogányság +poggyász +poggyászos +pohár +pohárka +pohárköszöntő +pohárszék +poharacska +pojáca +pokol +pokoli +pokróc +polarizáció +polc +polgár +polgárasszony +polgárellenesség +polgárháború +polgári +polgárjog +polgárjogi +polgármester +polgármesterné +polgárosul +polgárság +polgártárs +polgazd +polihisztor +polip +politechnikai +politika +politikai +politikai-társadalmi +politikus +politizál +politúrozás +politúrú +polivízió +pollák-eset +poloska +poloskás +pompa +pompájú +pompás +pompázik +pompakedvelő +pondró +pongyola +pongyolás +pont +pontatlan +pontocska +pontos +pontosan +pontosság +pontosságú +pontozóbíró +pontszám +ponty +ponyva +ponyvás +ponyvafüzet +por +porbasújtás +porc +porcelán +porceláncserép +porcika +porcogás +porcukor +porfelhő +porfelleg +porfírkád +porgörgeteg +porhüvely +porlad +porlatag +porlepte +porlik +porol +porolgat +poronty +poros +porosodik +porosz +poroszkál +porozás +porpehely +porréteg +porrongy +porszem +porszívó +porta +portás +portásfülke +portalanít +portéka +portenger +portré +portugál +portya +portyázik +poshadt +posta +postás +postáz +postakezelő +postaláda +postamester +postatiszt +posványosít +poszt +posztó +posztóféle +posztópapucs +posztóruha +potentát +potroh +pottyan +potya +potyautas +potyka +potyog +pozdorja +pozíció +pozitív +pozőr +pozsgás +pozsonyi +prágai +praktikus +praktizál +pram-pram +pravaz +praxis +préda +prédaság +prédikáció +prédikál +prédikátor +prém +prémdarabka +prémes +prémium +prémiumrendszer +prémvadász +prépost +prés +présel +préselődik +présház +precíz +precizitás +predelírium +prelátus +preparálás +preparátor +prepotens +presszó +presszó-csárda +presszóasztal +presszóasztalka +presszógép +presszósnő +presztízs +presztízsnövekedés +príma +prímás +prímási +priapusz-síp +pribék +pribékgúny +priccs +primitív +primőráru +priusz +priuszkönyv +priuszos +privátim +privilégiumlevél +prizma +próba +próbál +próbálgat +próbálkozás +próbálkozik +próbált +próbáltat +próbázás +próbaidő +próbaszolgálat +próféta +prófétai +prókátor +próza +probléma +problémázik +problémakör +problematika +problematikus +produkál +produkció +prof +proféta +professzionista +professzor +profetikus +profi +profil +profilú +profitál +prognózis +program +programbeszéd +programozó +programszerű +progresszív +proklamáció +prokurista +proletár +proletárbázis +proletárdiktatúra +proletárelem +proletáriátus +proletariátus +proli +propaganda +prostituált +prostitulált +protézis +protestáns +protokoll +protonerőmű +protonotárius +provincia +provokáció +provokál +provokáló +provokatív +prüsszög +prüszköl +prüszkölés +pruszlik +psziché +pszichózis +pszichológiai +pszichológus +pszichotikus +pszt +púder +púderozás +púp +púpos +púposodik +púpoz +púpozott +püffed +püffedt +püföl +pünkösd +püspök +püspöki +püspökkalap +püspökkenyérszerű +püspöklila +püspökség +püspökvár +pubertás +publikáció +publikálás +puccoskodik +puccs +pucér +pucol +pucolás +pucolkodik +pufajka +pufajkás +puff +puffad +puffadt +puffan +puffanás +pufók +pufog +pufogó +puha +puha-sárga +puhány +puhatestű +puhatolódzik +puhít +puhul +pukkad +pukkadozik +pukkantyú +puli +pulóver +pulóveres +pult +pulyka +pulykástál +pulykasült +pulzus +pumpa +pumpál +pumpálás +pumpaarc +pumpol +pupilla +puplinselyem +purdé +puska +puskás +puskacső +puskapor +puskatus-ütleg +pusmog +pusmogás +puszi +puszta +pusztán +pusztagazda +pusztagazdáné +pusztai +pusztaság +pusztít +pusztítás +pusztító +pusztul +pusztulás +putri +puttony +rá +rá-ráröffen +rááll +ráállít +ráad +ráadás +ráakad +ráb +rábámul +rábeszél +rábeszélő +rábír +rábíz +rábiccent +rábizonyít +rábólint +rábök +ráborít +ráborul +rábukkan +rác +rács +rácsap +rácsavarodik +rácsodálkozik +rácsos +rácsozat +rácsszerkezet +rácsúszik +rádió +rádióadás +rádióadó +rádióhívás +rádióhullám +rádiókészülék +rádiólámpa +rádiónyilatkozat +rádiórendszer +rádiós +rádiószolgálat +rádiótelefon +rádiótorony +rádióvevő +rádöbben +rádől +rádob +rádupláz +ráébred +ráébreszt +ráéhezik +ráépít +ráépül +ráér +ráérés +ráérő +ráérős +ráemel +ráereszkedik +ráerősít +ráesik +ráeszmél +ráfanyalodik +ráfér +ráfekszik +ráfelel +ráfest +ráfigyel +ráfintorít +ráfizet +ráfizetés +ráförmed +ráfonódik +ráfordítás +ráfordul +ráfúj +ráfut +ráfuttat +rág +rágalmaz +rágalmazás +rágalom +rágcsál +rágódik +rágondol +rágyújt +ráhagy +ráhajlik +ráhajol +ráharap +ráhederít +ráheveredik +ráhörög +ráhúz +ráhull +ráhurkol +ráír +ráírat +ráigazít +ráijeszt +ráirányul +ráismer +ráismerés +rájön +rák +rákacsint +rákapcsol +rákényszerít +rákérdez +rákerül +rákezd +rákínlódik +rákiált +rákkutatás +rákölt +rákönyököl +ráköszön +ráköszönt +ráköt +rákötöz +rákövetkező +rákoppint +rálép +rálehel +rálicitálás +rálök +rálő +ráma +rámás +rámagyaráz +rámegy +rámelegszik +rámenős +rámered +rámeszel +rámol +rámond +rámordul +rámosolyog +rámpa +rámutat +ránc +ráncigál +ráncol +ráncos +ránctalan +rándít +rándul +rándulás +ránéz +ránehezedik +ránevet +ráng +rángás +rángat +rángatás +rángatódzik +ránt +rántás +rántott +rántotta +rányílik +rányit +rányom +rányomtat +ráölt +ráömlik +ráönt +ráomlik +ráordít +ráparancsol +rápaskol +rápillant +rápillantás +rápingáltat +rápislog +ráránt +ráragad +ráragaszt +rárakódik +ráripakodik +rárivall +ráröhög +rárohan +ráront +rároskad +rásegít +rásimul +ráspolyoz +rásrófol +rásül +rásüt +rászáll +rászámít +rászán +rászárad +rászabadít +rászakad +rászed +rászegeződik +rászól +rászór +rászoktat +rászolgál +rászorít +rászorul +rászoruló +rátámad +rátámaszkodik +rátámaszt +rátalál +rátapad +rátapaszt +rátapos +rátarti +rátékozol +rátér +rátekint +rátenyerel +ráterít +rátermettség +rátestál +rátesz +rátör +rátűz +ráül +ráüt +ráüvölt +ráugrik +ráun +rávág +rávágtat +rávarr +ráver +rávesz +rávet +rávetít +rávetődik +rávezet +rávicsorog +rávigyorog +rávilágít +rávisz +ráz +rázár +rázás +rázendít +rázkódik +rázódik +rázogat +rázúdít +rázúdul +rázuhan +rab +rabbinus +rablánc +rablás +rabló +rablóbanda +rablógazdálkodás +rablógyilkos +rablóulti +rabol +raboskodik +rabruha +rabság +rabszolga +rabszolgafiú +rabszolgalány +rabszolgamunka +rabszolgatartás +rabszolgatartó +rabtárs +racionális +racionalizálás +racionalizálódás +racionalizmus +radar +radarberendezés +radír +radiátor +radikális +rafia +rafinált +ragály +ragályos +ragacs +ragacsos +ragad +ragadós +ragadozás +ragadozó +ragadtat +ragaszkodás +ragaszkodik +ragaszt +ragasztás +raglán +ragyás +ragyaábra +ragyog +ragyog-szikrázik +ragyogás +ragyogó +raj +rajong +rajongás +rajongó +rajparancsnok +rajta +rajtacsíp +rajtakap +rajtaveszt +rajz +rajzasztal +rajzfigura +rajzik +rajzlap +rajzol +rajzolás +rajzolat +rajzoló +rajzolóasztal +rajzolódik +rajzoltat +rajztanár +rajzú +rak +rakás +rakat +rakéta +rakétajármű +rakétanyomás +rakétatechnika +rakétatelep +rakétatömeg +rakia +rakódik +rakodás +rakodik +rakodó +rakodómunkás +rakodótárs +rakomány +rakosgat +rakott +rakpart +rakparti +raktár +raktárablak +raktárajtó +raktárépület +raktárfülke +raktárhelyiség +raktárkészlet +raktárkulcs +raktáros +raktározási +rampa +randalíroz +randevú +randevúzik +randi +randizik +rang +rangfokozat +rangidős +rangjelzés +rangkülönbség +ranglétra +rangos +rangsor +rangsorol +rangsorrend +rangszerzés +rangú +rapid +rapszódia +ravasz +ravaszcsattanás +ravaszkás +ravaszkodik +ravaszság +ravatal +ravatalozó +razol +razzia +re +rég +régész +régen +réges-régen +régi +régidő +régies +régiesség +régifajta +régimódi +régió +régiség +régiségi +régóta +rékli +rém +rémdráma +rémes +rémhírterjesztő +rémít +rémítgetés +rémiszt +rémkép +rémlik +rémül +rémüldözik +rémület +rémületes +rémült +rémuralom +répa +répaföld +répalevél +rés +réselőgép +résnyi +rész +részanyag +részben +részére +részéről +részecske +részeg +részeges +részegeskedik +részegség +részegültség +részes +részesedés +részesedik +részesít +részesül +részint +részleg +részlegvezető +részlet +részletes +részletesség +részletez +részletezés +részletfelismerés +részletfizetés +részletgyőzelem +részletkérdés +részletvázlat +résztvevő +részvény +részvényköteg +részvénytársaság +részvét +részvétel +részvétlen +részvétteljes +rét +réteg +réteges +rétegű +rétes +réti +rétoriskola +rétség +rév +révén +révész +réveteg +révetegség +réz +rézcsat +rézcső +rézdárda +rézfényű +rézfúvós +rézgálic +rézgomb +rézgombos +rézgyűrű +rézhegyű +rézhenger +rézkarika +rézkilincs +rézlemez +réznehezék +rézpénz +rézpor +rézsas +rézsút +rézsű +réztábla +réztányér +rézüst +rézveret +rézvörös +reálbér +reális +reagál +reagálás +reakció +reakcióképtelenség +reakciós +realitás +realizál +realizmus +rebben +rebbenés +rebeg +rebellió +rebesget +reccsen +reccsenés +recés +recéz +recepció +recept +receptblokk +receptpapír +recitál +recseg +recsegés +recsegő +redő +redőny +redves +referáda +referál +referátum +reflektor +reflektorfény +reflex +reform +reformáció +református +refrén +regéci +regény +regényes +regényhős +regényírói +reggel +reggelenként +reggelente +reggeli +reggelizés +reggelizik +reggelt +regiszter +regisztrálás +reglama +regruta +regula +rejlik +rejt +rejtély +rejtélyes +rejtélyeskedik +rejteget +rejtek +rejtekajtó +rejtekhely +rejtekút +rejtelem +rejtelmes +rejtett +rejtettség +rejtőzés +rejtőzik +rejtőzködik +rejtvény +rekamié +reked +rekedt +rekedtes +rekesz +rekkenő +reklám +reklámcél +reklámfigura +reklámötlet +reklamáció +reklamál +rekonstruál +rekviem +rekviemes +rekvirál +relatív +relatíve +rembrandt-film +remél +remélhető +remény +reménybeli +reménykedés +reménykedik +reménység +reménytelen +reménytelenség +remeg +remegés +remegtet +remek +remekmű +remeteélet +remeteség +remíz +rend +rendbehoz +rendbehozás +rendben +rendbentartás +rendbeszed +rendbetétel +rendbontás +rendbontó +rendcsinálás +rendcsináló +rendész +rendel +rendelés +rendelet +rendelkezés +rendelkezik +rendelkező +rendellenes +rendellenesség +rendelmény +rendelő +rendeltetés +rendeltetésű +rendes +rendetlen +rendetlenkedik +rendetlenség +rendez +rendezés +rendezetlen +rendezett +rendezettség +rendezget +rendezkedik +rendező +rendeződik +rendezői +rendezőképesség +rendezőség +rendezvény +rendfokozat +rendfokozatú +rendház +rendhagyó +rendíthetetlen +rendje-módja +rendjeles +rendkívül +rendkívüli +rendőr +rendőrautó +rendőrcilinder +rendőrezredes +rendőrfőkapitányság +rendőri +rendőrkapitány +rendőrközeg +rendőrkordon +rendőrlegény +rendőrminisztérium +rendőrminiszter +rendőrmunkás +rendőrőrs +rendőrorvos +rendőrség +rendőrségi +rendőrspicli +rendőrtiszt +rendőrtiszti +rendre +rendre-rendre +rendreutasít +rendszám +rendszámú +rendszer +rendszeres +rendszeresít +rendszerez +rendszerezés +rendszerint +rendszertelen +rendszerű +rendületlen +rendű +rendű-rangú +rendzavarás +renegát +reneszánsz +reneszánszkodás +reng +rengeteg +repdes +reped +repedés +repedezik +repedt +repeget +repes +repesz +repeszt +repít +repkény +repkényfüggöny +repked +replika +reprezentáció +reprezentációs +reprezentál +reprezentatív +reprodukálás +reprodukció +reprodukciómelléklet +reprogram +repül +repülés +repülő +repülő-főparancsnok +repülőakadémia +repülőbomba +repülőbrigád +repülőgép +repülőgép-szerelő +repülőgépmotor +repülőgépszerű +repülőgépzúgás +repülőkötelék +repülőszázad +repülőszerencsétlenség +repülőtér +repülőtérszag +repülőút +resó +rest +restancia +restauráció +restaurál +restaurálás +restelkedés +restelkedik +restell +restellnivaló +reszel +reszelő +reszelős +reszket +reszketés +reszketeg +resztel +retek +retesz +retikül +retteg +rettegés +rettegő +rettegtetés +rettenet +rettenetes +rettenthetetlen +rettentő +retusál +reuma +revanzsál +reverenda +reverendás +revolver +revolverdörrenés +revolvergolyó +rexasztal +rezdül +rezdülés +rezeg +rezegtet +rezervátum +rezesbanda +rezgés +rezgő +rezignált +rezonál +rezsi +rezsim +rezzen +rezzenés +rezzenéstelen +rezzenetlen +rf +rí +rímel +riad +riadalom +riadó +riadóautó +riadozik +riadt +riaszt +riasztás +riasztó +riasztócsengő +ribanc +ribizli +ribizlibokor +rideg +ridegség +rigmus +rigó +rigóölő +rikácsol +rikácsolás +rikító +rikkancs +rikkancs-jelmondat +rikkant +rikkantás +rikolt +rikoltozás +rikoltozik +rikoltozó +rimánkodás +rimánkodik +ring +ringás +ringat +ringatózik +ringlispil +ringlófa +ringsegéd +ringyó +ripityára +riport +riporter +riporteri +riportmérgezés +riposztozik +riszál +ritka +ritkás +ritkaság +ritkít +ritkul +ritmikus +ritmus +ritmusos +ritmusú +rituálé +rivális +rivalda +rizs +rizskása +rizsporos +rizsporoz +ró +róka +rókázik +rókaképű +rókalyuk +rókaorr +róla +róma-ellenes +római +róna +rózsa +rózsás +rózsacsokor +rózsadombi +rózsafa +rózsafüzér +rózsafüzéres +rózsafüzérszem +rózsakert +rózsaláng +rózsaszál +rózsaszín +rózsaszín-kék +rózsaszínű +rózsaszirom +rózsatő +röfög +röfögésszerű +röfögő +rög +rögdarab +rögeszme +röghegység +rögös +rögtön +rögtöni +rögtönöz +rögtönzés +rögvest +rögzít +rögzíthetetlen +röhej +röhejes +röhincsél +röhög +röhögés +röpcédulázás +röpirat +röpke +röplabda +röplap +röppálya +röppen +röppenős +röpte +röptér +rövid +rövidesen +rövidhullám +rövidhullámú +rövidít +rövidítés +rövidke +rövidlátó +rövidnadrág +rövidség +rövidzárlat +rőt +rőzse +robaj +robajlik +robban +robbanás +robbanó +robbant +robbantás +robbantási +robog +robot +robotember +robotol +robusztus +rocska +rogy +rogyás +rogyadozik +rogyaszt +rohad +rohadás +rohadt +roham +rohamoz +rohampálya +rohamsisak +rohamsisakos +rohamtempó +rohan +rohanás +rohangál +rohaszt +rojalista +rojt +rojtos +rokka +rokkant +rokon +rokoni +rokonlátogatás +rokonlélek +rokonság +rokonsorsú +rokonszenv +rokonszenves +rokonszenvez +rokonszenvezés +rokonszenvező +roller +rom +román +románkori +romantika +romantikus +rombol +rombolás +romboló +rombusz +romház +romhalmaz +romlás +romlatlan +romlik +romlott +romlottság +romos +roncs +roncskupac +ronda +rondírásos +rondít +rongál +rongy +rongybaba +rongycsomó +rongydarab +rongyocska +rongyos +rongyoskodás +rongyrázás +rongyszedés +rongyszerű +rongyszőnyeg +rongyterítő +ront +rop +ropog +ropogás +ropogós +ropogtat +roppan +roppanás +roppant +roskad +roskadás +roskadozik +roskatag +rosseb +rossz +rossz-szabású +rosszakarat +rosszakaratú +rosszakaró +rosszall +rosszallás +rosszalló +rosszarcú +rosszízű +rosszindulat +rosszindulatú +rosszkedv +rosszkedvű +rosszkor +rosszmájúság +rossznézésű +rosszullét +rost +rosta +rostély +rostélyos +roszog +rothad +rothadás +rotyog +rovás +rovátka +rovar +rovarforma +rovargyűjtemény +rovat +rozetta +rozoga +rozs +rozsda +rozsdás +rozsdásodik +rozsdafoltos +rozsdamarta +rozsdaszínű +rozsdavörös +rozzant +rúd +rúg +rúgás +rúgkapálózás +rúgtat +rút +rúzs +rúzsoz +rúzstalan +rücskös +rügy +rügyezik +rühell +rubin +rubrika +rudizik +rugalmas +ruganyos +ruganyosság +rugdal +rugdos +rugdosás +rugó +rugózik +ruha +ruhácska +ruhájú +ruhás +ruháskosár +ruhátlan +ruház +ruházat +ruházati +ruházkodás +ruhadarab +ruhaféle +ruhagyár +ruhakölcsönző +ruhanemű +ruhasor +ruhaszag +ruhaszekrény +ruhatár +ruhatári +ruhatáros +ruhatároskodik +ruhatárosnő +ruhaüzlet +ruhonyai +rulett +rulettasztal +rulettfelszerelés +rum +rumbázik +rumcsika +rumli +rumocska +rumoshordó +rupó +ruszinszkói +ruszki +rutin +rutinhülyéskedés +rutinmunka +rutinos +ság +sági +sál +sámán +sámli +sánc +sánta +sántaság +sántít +sántítás +sántikál +sáp +sápadozik +sápadt +sápadtság +sápítozik +sár +sárcsimbók +sárfészek +sárga +sárgája +sárgállik +sárgás +sárgásbarna +sárgáskék +sárgástarka +sárgásvörös +sárgászöld +sárgabarack +sárgadinnye +sárgamintás +sárgarépa +sárgaréz +sárgarigó +sárgarigófészek +sárgul +sárkány +sárkánylábú +sárkánymozdonyos +sárkányos +sárkányzászló +sárkolonc +sáros +sárréteg +sárréti +sás +sáska +sásos +sátán +sátáni +sátor +sátorfa +sátorfelszerelés +sátorlap +sátorpalota +sáv +sávos +sablon +sablonos +saccol +sadal +saját +sajátos +sajátosság +sajátság +sajátságos +sajgás +sajgó +sajka +sajnál +sajnálat +sajnálatos +sajnálatraméltó +sajnálkozás +sajnálkozik +sajnos +sajog +sajt +sajtár +sajtkereskedés +sajtkereskedő +sajtó +sajtószabadság +sajtótermék +sajtóvonal +sajtol +sajtos +sakál +sakálcsapat +sakk +sakk-készlet +sakkfigura +sakkozik +sakkrejtvényfejtés +sakktábla +saláta +salátástál +salak +salakos +salétrom +salétromábrás +salfény +sanda +sandít +sansz +sanyargat +sanyarú +sapka +sapkás +sarjad +sarjerdő +sarkall +sarkantyú +sarki +sarkos +sarkú +sarkvidék +sarló +saroglya +sarok +sarokasztal +saroknyi +sarokvas +saru +sas +sasmadár +sasszem +satíroz +satnya +satöbbi +satu +satupad +savanykás +savanyú +savanyúság +savanyúvízforrás +savó +savószemű +savószínű +séf +séma +sérelem +sérelmes +sért +sértés +sérteget +sértegető +sértetlen +sértett +sértettség +sérthetetlen +sértő +sértődékeny +sértődés +sértődött +sértődöttség +sérülés +sérült +séta +sétál +sétálás +sétálgat +sétálgatás +sétáló +sétáltat +sétány +sétatér +sétaút +seb +sebész +sebészfőorvos +sebes +sebesedik +sebesség +sebesül +sebesülés +sebesülési +sebesült +sebez +sebezhetetlen +sebezhető +sebhely +sebhelyes +sebláz +sebtében +sebzett +segéd +segédcsapat +segédelőadó +segéderő +segédjegyző +segédkezik +segédlet +segédlevelező +segédmunkás +segédmunkási +segédorvos +segédszervezet +segédtanár +segédtiszt +segél +segély +segélyez +segélykérő +segélykiáltás +segg +seggű +segít +segítő +segítőkész +segítőkészség +segítség +segítségkérő +sehogy +sehogyan +sehol +sehonnan +sehova +sej +sejehuja +sejt +sejtés +sejtelem +sejtelmes +sejtet +sejthető +sekély +selényi-féle +selejtezés +sellő +selyem +selyemanyag +selyemernyőjű +selyemfényű +selyemhernyógubó +selyemkárpitos +selyemkendő +selyemkereskedés +selyemöv +selyempapír +selyempapiros +selyemruha +selyemsál +selyemszalag +selyemszoknya +selyemvánkos +selyemzsinór +selymes +sem +sematikus +semennyi +semhogy +semleges +semmi +semmiféle +semmiképpen +semmilyen +semminemű +semminő +semmint +semmirevaló +semmiség +semmittevés +senki +senyved +seppeg +seprő +seprős +seprű +seprűnyél +serceg +sercegés +sercegő +sercen +serdül +serdülő +serénykedik +sereg +seregélyraj +sereglés +sereglik +seregszemle +serke +serken +serkent +serpenyő +sertés +sertésgondozó +sertésmáj +sertésól +sertéspörkölt +sertésvágási +seszínű +settenkedik +sezlon +síel +sík +síkos +síkság +sín +sínadrág +sínadrágos +sínjavítás +sínjavító +sínkalapács +sínpár +sínrengeteg +síp +sípcsont +sípol +sípolás +sír +sír-nevet +sírás +sírásó +sírású +sírbolt +sírdogál +sírdomb +sírfedőlap +sírgondozó +sírhatnék +sírhely +sírkamra +sírkő +sírógörcs +sírós +sírós-nyikorgós +sírontúli +sítalp +sítúra +sívó +siet +sietős +sietség +siettet +siheder +sikál +sikátor +sikankó +siker +sikeres +sikersorozat +sikertelenség +sikerül +sikerült +siketfajd +sikít +sikítás +sikítoz +sikkaszt +sikkasztás +siklás +siklik +sikló +siklózik +sikolt +sikoltás +sikoltoz +sikoly +sikong +sikongat +silány +silányság +sild +siller +sima +simabőrű +simít +simítás +simítgat +simogat +simogatás +simul +simulékony +simuló +sincs +sintér +siófoki +sipít +sirály +sirám +siránkozik +siralmas +siralomház +siralomházi +siralomvölgy +sirat +sirató +sisak +sisakos +sistereg +sistergés +sittyen +sivár +sivárság +sivalkodás +sivalkodik +sivatag +sivatagi +sivít +sivítás +skála +skalp +skandál +skandináv +skarlátfolt +skatulya +skatulyaház +skicc +skót +skorpió +skurc +sláger +slafrok +slampos +slepp +slicc +slingel +slukk +slusszkulcs +slusszlánc +smaragd +smaragdzöld +sminkréteg +smirgli +smonca +smonculi +smucig +snájdig +snassz +só +sóbánya +sóder +sóderes +sóderos +sógor +sógorasszony +sógornő +sóhaj +sóhajt +sóhajtás +sóhajtásszerű +sóhajtozás +sóhajtozik +sóher +sókereskedő +sólet +sólyom +sós +sósav +sóska +sóskifli +sósperec +sóstó +sótartó +sóvár +sóvárgás +sóvárgás-színezet +sóvárgós +sóvárog +sóz +söntés +söntéspult +söpör +söpörget +söprés +söpröget +sör +sörét +sörerdős +sörfürdő +sörgyár +sörgyári +sörház +sörhiány +sörital +sörivás +sörkampány +sörnyitó +sörös +söröscsap +söröshordó +söröskocsi +söröskorsó +söröskrigli +sörösüveg +sörözik +söröző +sörpocsolya +sörszag +sörte +sörtés +sörteforma +sörtermelés +sörteszerű +sötét +sötétbarna +sötétedés +sötétedik +sötétítő +sötétkék +sötétlik +sötétlila +sötétpej +sötétpiros +sötétség +sötétszőke +sötétszürke +sötétül +sötétvörös +sötétzöld +sövény +sövényfal +sőt +sodor +sodrás +sodrású +sodró +sodródik +sodrony +sodronykötél +sodronyos +sofőr +sofőrülés +soha +sohasem +sok +sok-sok +soká +sokáig +sokára +sokadalom +sokadik +sokadmagával +sokall +sokaság +sokasodik +sokatmondó +sokbeszédű +sokdioptriás +sokfajta +sokféle +sokféleség +sokfejű +sokfelé +sokgyermekes +sokk +soknyelvű +sokoldalú +sokráncú +sokszínű +sokszoros +sokszorosít +sokszorosító +sokszorosítógép +sokszoroz +soktornyú +solymári +somfa +somogyi +somolyog +sompolyog +sonka +sonkás +sonkaforma +sopánkodás +sopánkodik +soproni +sopronszerte +sor +során +sorakozik +sorakozó +sorakoztat +sorbanállás +sorfal +sorjában +sorjáz +sorjázik +sorjáztat +sorkatona +soroksári +sorol +sorompó +soros +soroz +sorozás +sorozat +sorozatos +sorozatvető +sorra +sorravesz +sorrend +sors +sorscsapás +sorsfordulat +sorsforduló +sorshúzás +sorsszerű +sorstárs +sorsú +sorsüldözött +sorsverte +sortűz +sorvad +sorvadozás +sorvaszt +sorvég +sorvégjelző +sovány +soványodik +soványság +spájz +spájzol +spárga +spártai +spagetti +spalettás +spanyol +spanyolfal +spanyolországi +sparhert +spén +speciális +specialista +specialitás +specializál +specifikum +specifikus +spekuláció +spekuláns +sperhakni +spermai +spicces +spicli +spirál +spirálcsúszda +spirálkar +spirálvonulat +spiritualitás +spiritualizmus +spór +spórol +spongya +spontán +spontaneitás +sport +sportbarát +sportcsarnok +sportegyesület +sportember +sportesemény +sportfiú +sporthír +sportkabát +sportklub +sportkocsi +sportnadrág +sportol +sportoló +sportpálya +sportruhás +sportsapka +sportszatyor +sportszenvedély +sportszerűség +sportszerűtlen +sportszínvonal +sporttárs +sporttelep +sportújság +sportújságírónő +sportzakó +sportzakós +spriccel +srác +sróf +ssss +stáció +stádium +státus +státusbővítés +stabilizál +stafírung +stallum +stampedli +stand +standardmunka +stanicli +start +start-sorrend +starter +startgép +starthely +statáriális +statikai +statisztaszerep +statisztika +statisztikai +statisztikus +stb +stég +stekkoló +stencil +steril +stílszerű +stílus +stílusos +stílusú +stich +stiches +stikkelés +stilizált +stimmel +stóla +stop +stopper +stoppol +stráfkocsi +strázsál +stramm +strand +strandbója +strandélet +strandfotográfus +strandfürdő +strandfürdői +strandolás +strandoló +strandpapucs +strandszezon +strandtáska +strapa +strapál +stratégia +strici +strigó +strucctoll +strucctollas +stúdium +stuccol +stuccoltat +súg +súg-búg +sújt +sújtás +sújtólégrobbanás +súly +súlyarány +súlyos +súlyosodik +súlyoz +súlypont +súlytalan +súlytalanság +súlyviszony +súlyzó +súrlódás +súrlódik +súrol +süket +süketítő +süketnéma +süketség +sül +sül-fő +süldő +sületlen +sületlenség +süllyed +süllyeszt +süllyesztő +sült +sülve-főve +sün +sündisznó +süpped +süppedékes +sürget +sürgetés +sürgető +sürgölődés +sürgölődik +sürgöny +sürgönykihordó +sürgős +sürög +sürög-forog +süt +sütemény +süteményes +süteményespult +sütkérezik +sütnivaló +sütöget +sütő +sütőlapát +sütőmunkás +süttet +süveg +süvegű +süvít +süvölt +süvölvény +sűrít +sűrű +sűrűség +sűrűségviszony +sűrűsödik +suba +subernyák +sublót +sudár +sugár +sugárfegyver +sugárgerenda +sugárkéve +sugármentesítő +sugárözön +sugároz +sugárpisztoly +sugárút +sugárzás +sugárzásveszély +sugárzik +sugárzó +sugárzóna +sugall +sugallat +sugalmaz +sugaras +sugarú +sugdolódzás +sugdolódzik +sugdos +suhan +suhanás +suhanc +suhancgyűrű +suhog +suli +sulykol +sumér +summa +summáskodik +summáz +sunyi +sunyít +surmó +surrog +surrogás +susmog +susmusol +susog +sustorgás +sustorog +suszter +suszterlegény +suszterség +sut +suta +sutaság +sutavad +suttog +suttogás +suttogó +suttyó +suttyókor +suttyomban +sváb +svábozik +sváda +svádájú +svájci +svájcisapka +svéd +száguld +száguldás +száguldozás +száguldozik +száj +szájahúzott +szájcsücsök +szájíz +szájmozgás +szájpadlás +szájszél +szájszöglet +szájú +szál +szálas +szálegyenes +szálfa +szálkás +száll +szállás +szálláshely +szálldogál +szálldos +szállít +szállítás +szállítási +szállítmány +szállító +szállítóeszköz +szállítógép +szállítókocsi +szállítómunkás +szállingózik +szálló +szállóigazolvány +szállóige +szállóvendég +szálloda +szállodás +szállodabeli +szállodai +szállodaszoba +szállong +szálú +szám +számára +számadás +számadó +számba +számbavétel +számít +számítás +számítási +számítgat +számítható +számítógép +számjegy +számkivetett +számkülönbség +számla +számlál +számlálhatatlan +számlapos +számol +számolgat +számoló +számoló-rács +számológép +számonkérés +számos +számottevő +számotvetés +számozás +számrendszer +számszerű +számtalan +számtalanféle +számtan +számtanácsos +számú +száműz +száműzetés +száműzött +szán +szánakozás +szánakozik +szánalmas +szánalom +szándék +szándékol +szándékos +szándékosság +szándékozik +szándékú +szánkázik +szánkó +szánt +szántás +szántásos +szántai +szántatlan +szántó +szántóföld +szántóföldi +szántság +szár +szárad +száradás +száraz +szárazbejáró +szárazdajka +szárazföldi +szárazság +szárítgat +szárítkozik +szárítóbura +szárított +származás +származási +származású +származék +származékú +származik +szárny +szárnyacska +szárnyal +szárnyalású +szárnyas +szárnyaszegett +szárnycsapás +szárnycsapkodás +szárnyék +szárnysegéd +szárnysuhogás +szárnyú +szárú +szász +száz +száz-kétszáz +száz-száz +száz-százöt +század +századbeli +századbiztos +századeleji +századforduló +századi +századik +százados +századosi +századparancsnok +századrész +százalék +százalékos +százas +százéves +százegy +százegyedik +százegynéhány +százesztendős +százezer +százféle +százforintos +százhármas +százharminc +százharmincezer +százharmincféle +százharminchárom +százhatvan +százhatvanezer +százhetvenegyes +százhetvenharmadik +százhetvenkét +százholdas +százhúsz +százhuszonnyolc +százkettes +százkilencvenhat +százkilós +százméteres +százmillió +száznegyven +száznegyvenezer +száznyolcvan +százötven +százötven-kétszáz +százszázalékos +százszoros +százszorta +száztagú +száztíz +száztizennégy +szab +szabály +szabályellenes +szabálykönyv +szabályos +szabályoz +szabályozás +szabálysértés +szabályszerű +szabálytalan +szabálytalanság +szabályzat +szabás +szabású +szabad +szabadalom +szabadegyetemi +szabadfoglalkozás +szabadít +szabadítás +szabadjára +szabadkőműves +szabadkozás +szabadkozik +szabadlábon +szabadlábra +szabadnap +szabadnapos +szabados +szabadrúgás +szabadság +szabadság-hegyi +szabadságharc +szabadságharcos +szabadsághős +szabadságidő +szabadságjog +szabadságvesztés +szabadszájú +szabadtéri +szabadul +szabadulás +szabatos +szabdal +szablya +szabó +szabóság +szabolcsi +szabotál +szabotázs +szabvány +szabványeset +szadista +szadizmus +szaft +szaftos +szag +szagfelhő +szaggat +szaggatott +szaglás +szaglász +szaglászás +szaglik +szagol +szagolgat +szagosbükköny +szagosszappan-vásárlás +szagú +szagzuhatag +szajha +szajkó +szajkóz +szajna-parti +szajré +szak +szakács +szakácskönyv +szakácsmester +szakácsné +szakácsnő +szakáll +szakállas +szakálltorzs +szakállú +szakad +szakadás +szakadásos +szakadatlan +szakadék +szakadozik +szakadozott +szakadt +szakadta +szakajtó +szakasz +szakaszparancsnok +szakasztott +szakaszvezető +szakdolgozat +szakérettségi +szakérettségis +szakérettségiző +szakértelem +szakértő +szakértői +szakember +szakfolyóirat +szakgimnázium +szaki +szakít +szakirodalom +szakképesítés +szakképzettség +szakkönyv +szakkör +szaklexikon +szakma +szakmabeli +szakmai +szakmunkás +szakmunkásvizsga +szakorvos +szakos +szakozik +szakrális +szakramentum +szakszerű +szakszervezet +szakszervezeti +szakszókincs +szakszövetkezet +szaktárs +szaktanács +szaktudású +szalámi +szalámis +szalámivég +szalámizás +szalad +szaladgál +szaladjlányom-féle +szalag +szalagos +szalajt +szalaszt +szalma +szalmacsóva +szalmakalap +szalmakalapos +szalmakazal +szalmakupac +szalmaláng +szalmaszál +szalmatető +szalmatetős +szalmatörek +szalmazsák +szalon +szaloncukor +szalongarnitúra +szalonkabát +szalonképes +szalonmunka +szalonna +szalonnázik +szalonnaadag +szalonnabőr +szalonnadarabka +szalonvicc +szalonzene +szalonzenekar +szaltó +szalutál +szalvéta +szamár +szamárkóró +szamárság +szamaras +szamóca +szamócadzsem +szamovár +szanál +szanálás +szanaszét +szanatórium +szandál +szapora +szaporáz +szaporaság +szaporít +szaporodik +szappan +szappanbuborék +szappanfolt +szappanoz +szapul +szar +szarás +szardínia +szardíniásdoboz +szarevő +szarfaló +szarházi +szarka +szarkóma +szarkofág +szaros +szarság +szaruhártya +szarukeretes +szarusodik +szarv +szarvas +szarvasagancs +szarvasbika +szarvasbőgés +szarvasbőr +szarvasmarha +szarvastehén +szaténpongyola +szatmári +szatócs +szatócsbolt +szattyán +szattyánbőr +szattyánpiros +szatyor +szavahihető +szavajárása +szaval +szavalás +szavaló +szavalókórus +szavalóverseny +szavatosság +szavaz +szavazati +szavazó +szavú +szaxofon +szédeleg +szédelgő +szédít +szédítő +szédül +szédülés +szédület +szédületes +szédült +széf +szégyell +szégyellnivaló +szégyen +szégyenbélyeg +szégyenérzet +szégyenkezés +szégyenkezik +szégyenletes +szégyenlős +szégyenteljes +széjjel +széjjelfut +széjjelnéz +széjjelolvad +széjjelrág +széjjelsugárzik +széjjelszór +széjjeltép +széjjelzavar +szék +székel +székely +székesegyház +székesfehérvári +székház +székhely +székhuzigálás +széklet +széksor +széktámla +szél +szélárnyék +szélcserzett +széles +szélesarcú +szélesedik +szélesít +szélhámos +szélhordta +széljárás +széljegyzet +szélkakas +szélmalom +szélrózsa +szélről +szélroham +szélsebes +szélső +szélsőséges +szélsuttogás +széltében +széltében-hosszában +széltére +szélütés +szélütött +szélű +szélvédett +szélvédő +szélvésszerű +szélvihar +szén +széna +szénásszekér +szénaillatú +szénakazal +szénalétra +szénatartó +szénfal +szénfekete +szénhalom +szénhegy +szénhordás +szénmonoxid +szénnagykereskedő +szénporrobbanás +szénrakás +szénrakodás +széntüzelésű +szép +szépapa +szépasszony +szépérzék +széphistória +szépírás +szépít +szépítés +szépítkezés +szépirodalom +szépség +szépséges +szépségeszmény +szépséghiba +szépségideál +szépségű +szépségverseny +szér +széria +szérű +szérűskert +szérumgyár +szétágazik +szétárad +szétbomlik +szétbont +szétbontogat +szétcsap +szétcsattan +szétdarabol +szétdörzsöl +szétdob +szétdobál +szétesik +szétfejt +szétfekszik +szétfeszít +szétfolyik +szétfolyó +szétfoszlik +szétfröccsen +szétfut +szétgöngyöl +szétgurul +széthány +széthasad +széthasít +széthord +széthordanivaló +széthúz +széthúzódás +széthúzódik +széthull +szétken +szétkenődik +szétkerül +szétköpdös +szétküld +szétküldözget +szétkuszál +szétlapít +szétlapult +szétlök +szétlő +szétmállaszt +szétmállik +szétmarcangol +szétmegy +szétmutat +szétnéz +szétnyílik +szétnyit +szétnyom +szétolvad +szétolvadás +szétoszlat +szétoszlik +szétoszlódik +szétoszt +szétosztás +szétpattogzik +szétpazarol +szétporladozik +szétporlik +szétporlódik +szétrebben +szétrebbenés +szétreped +szétrepedezik +szétrepeszt +szétrepít +szétrobban +szétrobbant +szétroncsol +szétroppant +szétrúg +szétsimít +szétsugárzik +szétsuhan +szétszállingózik +szétszaggat +szétszakad +szétszakít +szétszalad +szétszéled +szétszed +szétszedhető +szétszilánkol +szétszór +szétszóródik +szétszórt +széttár +széttaglalás +széttartólagos +széttép +széttekint +széttereget +szétterít +szétterjed +szétterpeszt +szétterül +szétterülő +széttölt +széttör +széttörik +széttrancsíroz +szétugraszt +szétugrik +szétvág +szétválaszt +szétválik +szétver +szétvet +szétzavar +szétzilálás +szétzúzás +szed +szedés +szedeget +szedelőzködik +szeder +szederfa +szederjes +szedet +szedett-vedett +szedres +szefárd +szeg +szegély +szegélyez +szegélykötél +szegény +szegényember-kölcsön +szegényes +szegényke +szegénylegény +szegényparaszt +szegényparasztság +szegénység +szegénységi +szegényszag +szegényvidéki +szegecs +szegedi +szeges +szegez +szegeződik +szegfű +szegfűcsokros +szegfűszeg +szeghalmi +szeglet +szegődik +szegődtet +szegről-végről +szegy +szekér +szekéralj +szekércsapat +szekérderék +szekéroldal +szekéroszlop +szekérrúd +szekérsor +szekérút +szekeres +szekerez +szekrény +szekrényajtó +szekrényke +szekretárius +szekszárdi +szekta +szektás +szektásság +szektor +szel +szeleburdi +szelecske +szelektál +szelence +szelep +szeles +szelet +szeletel +szeletke +szelíd +szelídít +szelídség +szelídül +szellem +szellemes +szellemeskedik +szellemesség +szellemi +szellemi-lelki +szellemű +szellentés +szellő +szellős +szellőzködés +szellőzködik +szellőzőkészülék +szellőzőnyílás +szellőztetés +szellőztetési +szem +szemafor +szembe +szembe-szembetalálkozik +szembeállít +szembefordul +szembejön +szembekerül +szembekerülés +szembemegy +szemben +szembenáll +szembenállás +szembenéz +szembenyíló +szembesít +szembesítés +szembeszáll +szembeszegez +szembeszegül +szembeszökő +szembetalál +szembetűnő +szemből +szembogár +szemcsés +szemcsenagyság +személy +személyautó +személyautó-forgalom +személyazonosság +személycsere +személyes +személygépkocsi +személyi +személyiség +személyiségváltozás +személykocsi +személyszállító +személytelen +személytelenség +személyvonat +személyzet +személyzet-néger +személyzeti +személyzetis +szemérem +szeméremajak +szemérmes +szemérmesség +szemérmetes +szemérmetlen +szemét +szemétdomb +szemétgyűjtő +szeméthalom +szeméthegy +szemétkedik +szemétkosár +szemétkupac +szemétláda +szemétmontázs +szeméttartó +szemefénye +szemenszedett +szemerkél +szemernyi +szemes +szemetes +szemetesvödör +szemez +szemezget +szemfényvesztés +szemfedél +szemfedő +szemfehér +szemfog +szemforgató +szemfüles +szemgödör +szemgödrű +szemgolyó +szemhatár +szemhéj +szemhunyorítás +szeminárium +szemináriumi +szemita +szemjáték +szemjegy +szemközt +szemközti +szemlátomást +szemle +szemlél +szemlélet +szemléletes +szemlélget +szemlélő +szemlélődés +szemlélődik +szemlélődő +szemlencse +szemölcs +szemölcsféle +szemöldök +szemöldökcsont +szemöldökfa +szemöldökű +szempár +szempilla +szempillantás +szempont +szemrés +szemrebbenés +szemrehányás +szemrehányó +szemrevételez +szemrontó +szemszög +szemtanú +szemtaraj +szemtelen +szemtelenkedés +szemtelenkedik +szemtelenség +szemtermés +szemügyre +szemüveg +szemüveges +szemüvegtok +szemű +szemvillanás +szemvillanásnyi +szenátor +szenátus +szende +szender +szendereg +szendvics +szendvicses +szendvicstál +szenel +szenes +szenespince +szenesvödör +szenilis +szenny +szennyes +szennyesláda +szennyez +szennyvíz +szent +szentatya +szentbeszéd +szentély +szentel +szentelget +szenteltvíztartó +szentesi +szentesít +szenteste +szentimentális +szentjánoskenyérfa +szentkép +szentmise +szentség +szentségel +szentséges +szentségit +szentségtörés +szentségtörő +szenved +szenvedély +szenvedélyes +szenvedélyesség +szenvedélytelen +szenvedés +szenvedő +szenveleg +szenvtelen +szenzáció +szenzációhajhászás +szenzációs +szenzi +szenzi-dömping +szeparálható +szeparátor +szeparatista +szeplős +szeplőtlen +szeptember +szeptemberi +szer +szeráf +szerb +szerda +szerdai +szerény +szerénykedik +szerénység +szerénytelen +szerénytelenség +szerecsen +szerel +szerelde +szerelés +szerelem +szerelmes +szerelmesedik +szerelmeslevél +szerelmespár +szerelmetes +szerelmi +szerelő +szerelőműhely +szerelőmunkás +szereltet +szerelvény +szerencse +szerencsére +szerencsés +szerencsétlen +szerencsétlenség +szerencsejáték +szerencsejátékos +szerep +szerepel +szerepeltetés +szerepjátszás +szereplés +szereplő +szeret +szeretet +szeretetlakoma +szeretetlen +szeretetreméltó +szeretetroham +szeretett +szeretetteljes +szeretkezés +szeretkezésízű +szeretkezik +szeretnivaló +szerető +szeretői +szerette +szerez +szerfölött +szerint +szerinte +szerinti +szerivel +szerkeszt +szerkesztés +szerkesztési +szerkesztő +szerkesztőjelölt +szerkesztőség +szerkesztőségi +szerkezet +szerkezetszerű +szerkó +szerláda +szerpentin +szerszám +szerszámláda +szerszámoskamra +szerszámosláda +szerszámraktár +szertár +szertartás +szertartásos +szertartásosság +szertartástan +szerte +szerteágazó +szerteáll +szertefoszlik +szertefúj +szertehagy +szertelen +szertelenség +szertelibeg +szertemászik +szerterepül +szerteszét +szerv +szervbank +szervcsere +szerves +szervetlen +szervez +szervezés +szervezési +szervezet +szervezeti +szervezetlenség +szervezett +szervezkedés +szervezkedik +szervező +szerveződik +szervi +szervíroz +szerviz +szervusz +szerzés +szerzemény +szerzet +szerzetesrend +szerző +szerződés +szerződik +szerződtet +szerződtetés +szerzőtehetség +szesz +szeszély +szeszélyes +szeszes +szeszfőzde +szeszkrumpli +szeszreklám +szesztartalmú +szesztilalom +szexuális +szexus +szezon +szférikus +szi +szíj +szíjas +szíjfülecske +szín +színárnyalat +színcsomó +színdarab +színe-java +színész +színészi +színészkedés +színészkedik +színészkolléga +színésznő +színehagyott +színes +színes-mintás +színevesztett +színez +színezet +színfolt +színház +színházbarakk +színházi +színházlátogatás +színhely +színigazgató +színigazság +színjáték +színjátszás +színjátszó +színjátszóné +színjeles +színjózan +színképelemzés +színköltemény +színleg +színlel +színművészetis +színpad +színpadi +színpadias +színpompa +színpróba +színtér +színtelen +színtiszta +színültig +színű +színvak +színvallás +színvonal +színvonalkülönbség +színvonaltalanság +szíriai +szít +szív +szívás +szívbaj +szívbeli +szívdobogás +szíve-lelke +szívélyes +szívélyesség +szível +szívenütő +szíves +szívesen +szíveskedik +szívesség +szívgyengeség +szívkatéterezés +szívkórház +szívlel +szívódik +szívós +szívóskodik +szívósság +szívpezsdítő +szívremegtető +szívroham +szívszaggató +szívszélhűdés +szívszorító +szívszorongató +szívtelen +szívtrombózis +szívügy +szívű +szívvel-lélekkel +szívverés +szia +szibériai +szid +szidás +szidalom +szidoloz +szieszta +sziget +szigetelés +szigetelőanyag +szigeti +szigetlakó +szigetmonostori +szignifikáns +szignó +szignum +szigony +szigor +szigorít +szigorított +szigorlat +szigorú +szigorúság +szikár +szikárság +szikes +szikkadt +szikla +sziklás +sziklaalap +szikladarab +sziklaportenger +sziklatömb +szikra +szikrányi +szikrázik +szikrázó +szil +szilánk +szilánkos +szilárd +szilárdság +szilárdságú +szilárdul +szilaj +szilikózis +szillogizmus +szilva +szilvás +szilvaaszaló +szilvafa +szilvalekvár +szilvamag +szilvatermés +szilveszter +szilveszterezik +szilveszteri +szimat +szimatol +szimatolgatás +szimatolószerv +szimatsztár +szimbólum +szimbolikus +szimfónia +szimpatizál +szimpla +szinkron +szint +szint-azonosság +szinte +szintén +szintézis +szintemelkedés +szintez +szintúgy +szipákol +szipirtyó +szipka +szipog +sziporkázik +szippant +szippantás +szippantgat +szirén +sziréna +szirénáz +szirénahang +szirmos +szirmú +szirom +szirt +szirup +szirupos +szisszenés +szisszent +sziszeg +sziszegés +szisztéma +szisztematikus +szita +szitál +szitakötő +szitavászon +szitkozódik +szitok +szittya +szittyós +szituáció +szivárog +szivárvány +szivárványos +szivárványszín +szivacs +szivacsos +szivar +szivarhamu +szivarka +szivarozik +szivarvég +szivarzseb +szivattyú +szivattyúz +szkeptikus +szkizofréniás +szláv +szladi +szlavóniai +szlovák +szmoking +szmokingos +sznob +sznoboskodik +szó +szóáradat +szóalakító +szóbeli +szóbeszéd +szóbőség +szócsata +szócséplés +szócsere +szócska +szócső +szóda +szódácska +szódavíz +szófogadatlan +szófogadó +szófoszlány +szóhasználat +szójártatás +szójáték +szójelzés +szókapcsolat +szókimondó +szókincs +szól +szólás +szólam +szólít +szólongat +szómalom +szónok +szónoki +szónoklás +szónoklat +szónokol +szóözön +szór +szórás +szórakozás +szórakozási +szórakozik +szórakozóhely +szórakozott +szórakoztat +szórakoztató +szóródik +szórókészülék +szórt +szórványos +szósz +szószék +szótár +szótértés +szótlan +szótöbbség +szótölcsér +szóváltás +szóval +szóvégi +szóvirág +szózat +szöcske +szög +szögesdrót +szögesdrótos +szöglet +szögletes +szögletesség +szökdécsel +szökés +szökési +szökell +szökevény +szökevényvadászat +szökik +szökken +szökkenés +szökkent +szökőár +szökőkút +szöktet +szörny +szörnyeteg +szörnyethal +szörnyülködik +szörnyülködő +szörnyű +szörnyűség +szörnyűséges +szöszmötöl +szöszmötölés +szövés +szöveg +szövegel +szövet +szövetanyag +szövetfoszlány +szövetkezés +szövetkezet +szövetkezetfejlesztés +szövetkezeti +szövetkezik +szövetnadrág +szövetpapucs +szövetruha +szövetség +szövetséges +szövetségi +szövetszoknya +szövetű +szövevény +szövevényes +szövődik +szövőgyár +sző +szőke +szőkeség +szőlész +szőlő +szőlőbeli +szőlőbirtokos +szőlődarab +szőlőfürt +szőlőhegy +szőlőhegyi +szőlőlevél +szőlőlugas +szőlőméz +szőlőművelő +szőlős +szőlősgazdai +szőlőskert +szőlősor +szőlőtelepítés +szőlőtermelő +szőlővessző +szőnyeg +szőr +szőrcsomó +szőrkereszt +szőrmók +szőrös +szőröstül-bőröstül +szőröz +szőrözés +szőrszál +szőrszálhasogató +szőrsziget +szőrű +szőrzet +szőttes +szoba +szoba-alkóvos +szoba-hallos +szoba-konyha +szoba-konyhás +szobácska +szobaajtó +szobaasszony +szobabérlő +szobacím +szobaféle +szobafestő +szobafestősegéd +szobagarnitúra +szobakonyhás +szobakulcs +szobalány +szobapincér +szobasarok +szobatárs +szobatársi +szobatudós +szobor +szoboratléta +szobormerev +szobrász +szobrászművészet +szobrocska +szocdem +szociáldemokrata +szociális +szocialista +szocializmus +szocio-doktorbácsi +szociológus +szocreál +szokás +szokásos +szokat +szokatlan +szokatlanság +szokik +szokli +szoknya +szoknyaanyag +szokott +szoktat +szokványos +szolga +szolgál +szolgálat +szolgálati +szolgálatkész +szolgálatkészség +szolgálatteljesítés +szolgálattevő +szolgálatvezető +szolgáló +szolgálólány +szolgáltat +szolgabíró +szolgafélelem +szolgafiú +szolgai +szolgalélek +szolgalegény +szolgaság +szolid +szolidság +szolnoki +szombat +szombathelyi +szombati +szombatonta +szomj +szomjas +szomjazik +szomjúság +szomorkás +szomorkodik +szomorú +szomorúfűz +szomorúság +szomszéd +szomszédasszony +szomszédi +szomszédlány +szomszédnő +szomszédos +szomszédság +szonáta +szonda +szonett +szopás +szopik +szopókás +szopogat +szoptat +szoptatós +szordínós +szorgalmas +szorgalmaskodik +szorgalmaz +szorgalmú +szorgalom +szorgos +szorgoskodik +szorít +szorítás +szorítkozik +szorító +szorong +szorongás +szorongásos +szorongat +szorongó +szoros +szortíroz +szortyog +szorul +szoruló +szorult +szorultság +szorzat +szottyan +szotyorgós +szovjet +szovjetparancsnokság +szputnyik +sztahanovista +sztentori +sztereo-fényképezőgép +sztereó +sztereotípia +sztetoszkóp +sztk-ellenőr +sztori +sztrájk +sztrájkbizottság +sztrájkol +sztrájkoló +sztrájksegély +sztreha +szúette +szúnyog +szúnyogdongás +szúr +szúrágta +szúrás +szúrat +szúrható +szúrós +szügy +szükség +szükségel +szükséges +szükségesség +szükséglakás +szükséglet +szükségszerű +szükségszerűség +szükségtelen +szül +szüle +szülés +szülési +születés +születési +születésnap +születésű +született +születik +szülött +szülő +szülőfalu +szülőföld +szülőhely +szülői +szülőváros +szünet +szünetel +szünetjel +szünidő +szünnap +szüntelen +szürcsöl +szürcsölés +szürcsölget +szüret +szüretel +szüretelő +szürke +szürke-fehér +szürkéllik +szürkés +szürkésbarna +szürkésfehér +szürkésfekete +szürkéskék +szürkehajú +szürkeség +szürkevörös +szürkül +szürkület +szürrealista +szüzesség +szüzességi +szűk +szűkít +szűkmarkú +szűköl +szűkölés +szűkölködő +szűkös +szűkösség +szűkrésű +szűkszavú +szűkül +szűkület +szűnik +szűr +szűrő +szűrődik +szűrujj +szűz +szűzföld +szűzhártya +szűzlány +szubjektív +szubjektivista +szubjektum +szubkulturális +szublimát +szubrett +szuggerál +szuggesztív +szukcesszive +szultán +szundi +szundít +szundikál +szunnyad +szuperál +szurdék +szurdok +szurkál +szurkáltat +szurkol +szurkolás +szurok +szurokfáklya +szurokfű +szurokszínű +szurony +szuronyos +szuronyú +szurtos +szusszanás +szusszanásnyi +szusz +szuszék +szuszog +szuszogás +szuszogtat +szuterénlakás +szuverén +szuverenitás +szvetter +tá +tábla +táblácska +táblázat +táblabíró +tábor +táborélet +táborhely +tábori +táborjárvány +táborlakó +tábornagy +tábornok +tábornoki +tábornokkormány +táborozás +táborozik +táborparancsnok +táborrend +tábortartás +tábortartó +tábortűz +tág +tágas +tágít +tágítás +tágul +táj +táján +tájban +tájbeszéd +tájék +tájékozatlan +tájékozható +tájékozódás +tájékozódik +tájékozott +tájékozottság +tájékoztat +tájékoztatás +tájkép +tájnyelv +tájszólás +tájt +tákol +tákolmány +tál +tálal +tálaló +tálalóablak +tálalóasztal +tálca +tálcás +tálka +táltos +tályog +támad +támadás +támadható +támadó +támadóállás +támasz +támaszkérő +támaszkodik +támaszkodó +támaszpont +támaszt +támaszték +támasztókaró +támasztópillér +támgerenda +támla +támlány +támogat +támogatás +támogató +támolyog +támpont +tánc +tánccsoport +táncdalénekesnő +tánchely +tánchelyiség +tánciskola +tánckettős +tánclépés +táncmulatság +táncol +táncoló +táncoltat +táncorkán +táncos +táncoskomikus +táncosnő +táncospár +táncszám +tánctudás +tánczene +tántorodik +tántorog +tányér +tányércsörgés +tányérsapka +tányérsapkás +tápászkodás +tápászkodik +táplál +táplálás +táplálék +táplálkozás +táplálkozik +tápláló +táppénz +tápszerreklám +táptelep +tár +tárca +tárcaíró +tárcsa +tárcsáz +tárgy +tárgyal +tárgyalás +tárgyalási +tárgyalófél +tárgyalóterem +tárgyi +tárgyilagos +tárgyilagosság +tárgysorozat +tárgyú +tárház +tárlat +táró +tárol +tárolás +társ +társadalmi +társadalom +társadalomkritika +társalgás +társalgási +társalgó +társalog +társas +társaság +társasági +társasjáték +társasüdülő +társasutazás +társasvadászat +társbérlő +társcsászár +társelnökség +társkereső +társnő +társtalan +társtalanság +társul +társulat +társzekér +tárul +tárulkozik +tárva-nyitva +táska +táskaféle +táskarádió +tát +tátika +tátog +tátong +tátrai +táv +távcső +távírógép +távirányítás +távirányítású +távirányító +távirat +távirati +táviratozik +távlat +távlati +távol +távoleső +távoli +távollét +távolmaradás +távolodik +távolodó +távolság +távolsági +távolságtartás +távozás +távozik +távozó +tabletta +tabló +tabu +tacskó +taft +taftruha +tag +tagállam +tagad +tagadás +tagadhatatlan +tagadható +tagadó +tagbaszakadt +taggyűlés +taglal +taglalás +taglétszám +taglejtés +tagol +tagolás +tagolatlan +tagolt +tagország +tagozat +tagozódik +tagság +tagú +tahi +tajték +tajtékos +tajtékzik +tak-tak +takar +takarás +takarék +takarékbetétkönyv +takarékkönyv +takarékos +takarékoskodás +takarékoskodik +takarékosság +takarékossági +takargat +takarít +takarítás +takarítási +takarítgat +takarítóasszony +takarítóbrigád +takarítóeszköz +takarítónő +takaríttat +takarmány +takaró +takaródzás +takaródzik +takarodik +takaros +taknyos +takony +taksál +taktika +taktikai +taktus +talál +találás +találat +találékony +találékonyság +találgat +találgatás +található +találka +találkozás +találkozási +találkozik +találkozó +találkozóhely +találmány +találó +találomra +talált +talán +talán-talán +talány +talányos +taláris +talaj +talajfelszín +talajmaró +talajrengés +talajvíz +talajviszony +talapzat +talicska +talicskázik +talon +talp +talpalás +talpalatnyi +talpas +talpfa +talpnyalás +talpnyaló +talpnyom +talponálló +talpraesett +talpszedés +talpú +tamáshegyi +tamáskodik +tamtam +tan +tanács +tanácsadás +tanácsadó +tanácsbeli +tanácselnök +tanácsház +tanácsháza +tanácsi +tanácskérő +tanácskozás +tanácskozik +tanácskozóterem +tanácsol +tanácsos +tanácsosi +tanácstalan +tanácstalanság +tanácsterem +tanácstitkár +tanácstitkárkodik +tanácsülés +tanácsvezető +tanár +tanárember +tanárfamília +tanári +tanárnő +tanáros +tanakodás +tanakodik +tananyag +tandíjmentes +tanfolyam +tangép +tangó +tanít +tanítás +tanítási +tanítgat +tanító +tanítói +tanítómester +tanítóné +tanítónő +tanítóskodik +taníttat +tanítvány +tank +tankakadály +tankcsapda +tankönyvraktár +tankötelezettség +tanmese +tannin +tanonc +tanonciskola +tanonckodik +tanonckor +tanszék +tanszéki +tantárgy +tanterem +tanú +tanújel +tanúkihallgatás +tanúság +tanúsít +tanúskodik +tanúvallomás +tanúzás +tanügyi +tanul +tanulás +tanulékony +tanulgat +tanulmány +tanulmányfej +tanulmányoz +tanulmányozás +tanulmányút +tanulnivaló +tanuló +tanulóév +tanulólány +tanulópár +tanulság +tanulságos +tanult +tanultság +tanya +tanyás +tanyás-erdős +tanyázgat +tanyázik +tanyabokor +tanyaépület +tanyahely +tanyakérdés +tanyakörzet +tanyaközpont +tanyalakó +tanyasi +tanyaudvar +tanyavilág +tapad +tapadós +tapaszt +tapasztal +tapasztalás +tapasztalat +tapasztalatcsere +tapasztalatlan +tapasztalatlanság +tapasztalható +tapasztalt +tapéta +tapétás +tapétázatú +tapicskál +tapint +tapintás +tapintású +tapintat +tapintatos +tapiskál +tapod +tapogat +tapogatódzik +tapos +taps +tapsol +tapsorkán +taraj +tarajos +tarfejű +targonca +tarisznya +tarka +tarkállik +tarkabab +tarkaságú +tarkít +tarkó +tarló +tarlótorzs +tarnai-féle +tarsoly +tart +tartály +tartás +tartású +tartalék +tartalékol +tartalékos +tartaléktörvény +tartalmas +tartalmatlan +tartalmaz +tartalmi +tartalom +tartalomvilág +tartam +tartat +tarthatatlan +tarthatatlanság +tartó +tartóoszlop +tartós +tartósít +tartózkodás +tartózkodási +tartózkodik +tartózkodó +tartózkodóhelyiség +tartóztat +tartogat +tartomány +tartozás +tartozék +tartozik +tasak +taszít +taszítás +taszigál +tatár +tatárjárás +tatai +tataroz +tatarozás +tavacska +tavaly +tavalyelőtt +tavalyi +tavasz +tavasz-ősz +tavaszi +taxi +taxiállomás +taxiköltség +taximegálló +taxis +taxisofőr +taxiszámla +taxiügy +taxizás +te +tébécé +téblábol +téboly +tébolyult +téesz +téesz-pár +téeszelnök +téeszközpont +téeszközség +téesznagysága +téeszszervező +tégla +téglás +téglaarcú +téglabástya +téglaépület +téglafal +téglagyár +téglagyári +téglahulladék +téglajárda +téglakészítő +téglapadlós +téglarakás +téglavetés +téka +tékozló +tél +télbe-nyárba +téli +télidő +télikabát +télikert +télire +téma +témahiány +témakör +témaötlet +témaosztás +témaszabadság +tématerv +ténfereg +ténsasszony +tény +tényállás +tényező +tényközlés +tényleg +tényleges +ténymegállapítás +tényszerű +tényvázlat +tép +tépáz +tépdes +tépelődés +tépelődik +tépelődő +tépetlen +tépett +tépked +tér +tér-idő +téráthidaló +térbeli +térd +térdel +térdepel +térdhajlat +térdharisnya +térdkalács +térdnadrágos +térérzék +térerőd +térhajó +térhajós +térhódítás +téri +térít +tériszony +térkép +térképcsináló +térképmakett +térképszerű +térképzet +térmértan +térség +térségű +térszalag +térszerű +tészta +tésztástál +tésztaarcú +tésztakupac +tét +tétel +tételes +tétlen +tétlenkedik +tétlenség +tétova +tétovázás +tétovázik +tévé +tévéhíradó +téved +tévedés +tévedhetetlen +tévedhetetlenség +tévelyeg +tévelygés +téves +téveszt +tévtan +tézis +tea +teásbögre +teátrista +teátrum +teázik +teakonyha +teatralitás +teavíz +technika +technikás +technikai +technikum +technikus +technológiai +teendő +tegez +tegeződés +tegeződik +tegnap +tegnapelőtt +tegnapelőtti +tegnapi +tehát +tehén +tehéntartás +tehenész +tehenes +teher +teherautó +teherbírás +teherfuvarozás +tehergépkocsi +teherkocsi +teherpályaudvar +teherszállítás +teherszállító +tehervagon +tehervonat +tehet +tehetetlen +tehetetlenség +tehetős +tehetség +tehetséges +tehetségtelen +tehetségű +tej +tejberizs +tejes +tejesbolt +tejescsupor +tejeskanna +tejesszürkeség +tejesüveg +tejfehér +tejfelesszájú +tejföl +tejfölös +tejhordó +tejpor +tejszerű +tejszínes +tejszínhab +tejszínhabos +tejüveg +tejüzem +teker +tekercs +tekerget +tekergős +tekerődzik +tekervényes +teketória +teketóriázik +tekinget +tekint +tekintély +tekintélyes +tekintélyrendszer +tekintet +tekintetes +tekintetű +tekinthető +tekintve +teknő +teknősbéka +teknőszerű +tektonikus +tele +telebeszél +telecigarettáz +teleesz +telefarag +telefon +telefonál +telefonálás +telefonáltat +telefonbeszélgetés +telefonérme +telefonfülke +telefonkagyló +telefonkészülék +telefonkönyv +telefonközpont +telefonos +telefonozik +telefonszám +telefut +telehint +telehord +teleír +telejesít +telek +telekár +telekkönyvvezető +teleköpköd +telekügy +telel +telelármáz +telelget +telemér +telep +telepátia +telepedik +telephely +telepít +telepítés +telepingál +telepőr +teleporciózgat +települ +település +települési +telepvezető +teleragaszt +telerak +teleszalad +teleszív +teleszór +teletetovál +teletölt +teletöm +teletömődik +televízió +televíziós +televíziószoba +televíziótorony +telezabál +telhetetlen +telhető +teli +telít +telítettségű +telihold +telik +telik-múlik +telitalálat +telje +teljes +teljesít +teljesítés +teljesítmény +teljesítményű +teljesítőképesség +teljesség +teljesül +teljesülés +teljesületlen +telt +telte +telve +tematikai +tematikus +temesvári +temet +temetés +temetési +temetésrendező +temetetlen +temetkezési +temetkezőhely +temető +temetőhely +temetői +temetőkultusz +temperál +temperamentum +templom +templomépítés +templomhegy +templomi +templomtér +templomtorony +templomudvar +tempó +tempós +tendencia +teng-leng +tengely +tenger +tengerész +tengerészarc +tengerészgyalogság +tengerészöltöny +tengerészsapka +tengerésztiszt +tengerésztiszti +tengerentúl +tengerentúli +tengeri +tengeribetegség +tengeriföld +tengeritábla +tengeritörés +tengerjáró +tengerkék +tengernagy +tengernyi +tengerpart +tengerszem +tengerszín +tenget +tengődik +teniszbajnok +teniszezik +teniszütő +tennivaló +tenor +tenyér +tenyérnyi +tenyészet +tenyészik +tenyészmén +tenyerű +teológia +teológiai +tepertő +tepertős +tepsi +terápia +terasz +terézvárosi +terebélyes +terefere +tereget +terel +terelés +terelődik +terem +teremt +teremtés +teremtésmítosz +teremtetik +teremtmény +teremtő +teremtődik +terep +terepjáró +tereptan +terhel +terhelés +terhes +terhesruha +terhesség +terhű +terít +terítékes +terítés +terítő +terítőjű +terjed +terjedelem +terjedelmes +terjeng +terjeszkedik +terjeszt +terjesztés +termáljegyvásárlás +termék +termékeny +terméketlen +terményforgalmi +termés +terméskő +természet +természetátalakító +természetellenes +természetes +természetesen +természetesség +természetfeletti +természeti +természetrajz +természetszerű +természetszerűleg +természettudás +természettudomány +természettudományos +természetű +termel +termelés +termelési +termelő +termelői +termelőszövetkezet +termelőszövetkezeti +termelőüzem +termesz +termet +termetes +termetű +termő +termőföld +termosz +terpeszállás +terpeszkedik +terror +terrorista +terül +terület +területi +területrész +területű +terv +terves +tervez +tervezés +tervezet +tervezget +tervezgetés +tervező +tervezőiroda +tervfelbontás +tervgazdálkodás +tervkutatás +tervmódosítás +tervosztály +tervpályázat +tervpályázati +tervrajz +tervszerűség +tervszerűtlen +tervutasítás +tesped +tespedés +tessék +tessék-lássék +tessékel +test +test-lélek +testál +testalkatú +testes +testestül-lelkestül +testetlen +testfej +testhelyzet +testi +testi-lelki +testízű +testkultúra +testnedv +testnevelő +testőr +testőrség +testrész +testszagú +testtartás +testtelen +testület +testületi +testű +testvér +testvérbátya +testvérhiány +testvéri +testvéries +testvériség +testvériskola +testvérke +tesz +tesz-vesz +teszt +tetanusz +tetejébe +tetejű +tetem +tetemes +tető +tetőgerenda +tetőgerinc +tetőpont +tetőterasz +tetőteraszos +tetőzés +tetőzet +tetőzik +tetőzsindely +tetovál +tetoválás +tetováltat +tetszés +tetszeleg +tetszetős +tetszhalott +tetszik +tett +tettenérés +tettes +tettet +tettetett +tetthely +tettlegesség +tettrekészség +tettvágy +tetű +tetves +teve +tevékeny +tevékenykedik +tevékenység +tevékenységű +teveszőr +tevő +textília +textil +textus +ti +tífuszbacilus +típus +típusú +tíz +tíz-húsz +tíz-húsz-harminc +tíz-tizenkét +tíz-tizenkettő +tíz-tizenöt +tízéves +tízegynéhány +tízes +tízezer +tízezernyi +tízezred +tízezres +tízfilléres +tízholdas +tízméteres +tízmillió +tízmilliós +tíznapos +tízórai +tízszemélyes +tied +tigrisfej +tikett +tikkadt +tikkasztó +tiktakol +tilalmaz +tilalom +tilos +tilt +tiltakozás +tiltakozik +tiltott +timsó +tincs +tinédzser +tinó +tinta +tintájú +tintaceruza +tintaceruzás +tintafolt +tintafoltos +tintanyaló +tintatartó +tintatócsa +tipeg +tipegő +tipikus +tipor +tippel +tipródik +tiroli +tisza-parti +tiszántúli +tiszt +tiszta +tisztálkodás +tisztálkodási +tisztálkodik +tisztán +tisztánlátás +tisztára +tisztás +tisztátalan +tisztátlan +tisztáz +tisztázás +tisztázatlan +tisztázható +tisztázódik +tisztaság +tisztasági +tisztaságú +tisztel +tiszteleg +tisztelendő +tisztelet +tiszteletadás +tiszteletbeli +tiszteletdíj +tiszteletem +tiszteletkör +tiszteletreméltó +tisztelettudó +tisztelgés +tisztelő +tisztelt +tisztes +tisztesség +tisztességes +tisztességszobor +tisztességtelen +tisztességtelenség +tisztességtudó +tiszthelyettes +tiszti +tisztít +tisztítás +tisztítóberendezés +tisztítótűz +tisztítóüzem-tulajdonos +tisztiiskola +tisztiorvos +tisztogat +tisztség +tisztul +tisztviselő +tisztviselőféle +tisztviselői +tisztviselőtelep +titáni +titkár +titkári +titkárnő +titkárnői +titkároskodik +titkárság +titkol +titkolódzás +titkolódzik +titkon +titkos +titkosszolgálat +titok +titoktartás +titoktartó +titokzatos +titulál +tivornya +tized +tizedannyi +tizedes +tizedik +tizedrész +tizenegy +tizenegyedik +tizenegyes +tizenhárom +tizenhárom-tizennégy +tizenharmadik +tizenhat +tizenhatéves +tizenhatodik +tizenhatos +tizenhét +tizenhetedik +tizenhetes +tizenkét +tizenkétezer +tizenkétféle +tizenkettedik +tizenkettes +tizenkettő +tizenkilenc +tizenkilenc-huszonegy +tizenkilencedik +tizenkilences +tizennégy +tizennegyedik +tizennyolc +tizennyolc-húsz +tizennyolcadik +tizennyolcezer +tizenöt +tizenöt-húsz +tizenötezer +tizenötödik +tizenötös +tó +tócsa +tódul +tódulás +tófenék +tóga +tógátlan +tónus +tónusú +tópart +tószt +tótfalusi +több +többé +többé-kevésbé +többedmagával +többes +többesszám +többet +többféle +többfelé +többi +többlet +többnyire +többrétűség +többség +többször +többszöri +többszörös +töfög +tök +tökbél +tökéletes +tökéletesedik +tökéletesít +tökéletesítés +tökéletesség +tökéletlenség +tökély +tökfilkó +tökmindegy +tökrészeg +tökű +tölcsér +tölcsérszerű +tölgy +tölgyfa +tölt +töltény +tölténytár +tölténytáska +töltés +töltésoldal +töltelék +töltöget +töltött +töltőtoll +töm +tömb +töméntelen +tömény +tömérdek +tömés +tömeg +tömeges +tömegjelenség +tömeglés +tömegpusztító +tömegruházati +tömegszállás +tömegverekedés +tömegviszony +tömjénfüst +tömkeleg +tömköd +tömlöc +tömlő +tömör +tömörül +tömött +tömpe +tömzsi +tönk +tönkremegy +tönkremenés +tönkrement +tönkresilányít +tönkretesz +töpörödött +töppedt +töpreng +töprengés +tör +tördel +törékeny +törés +töredék +töredékes +töredelmes +töredezett +töredezik +törek +törekedik +törekhord +törekvés +törekvő +töret +töretlen +törik +törleszt +törlőruha +törmelék +török +törökbarát +törökszentmiklósi +törökülés +töröl +törölget +töröltet +törött +törődik +törődött +törődöttség +törpe +törpeagy +törpebirtok +törpebirtokos +törpefenyő +törpegép +törpeharcsa +tört +történés +történész +történelem +történelembölcselet +történelemkönyv +történelemszak +történelemtudós +történelmi +történet +történetesen +történeti +történetíró +történik +történtek +törtet +törülközik +törülköző +törülközőtartó +törvény +törvénycikk +törvényes +törvényhatósági +törvényjavaslat +törvénykönyv +törvényszék +törvényszéki +törvényszerű +törvényszerűség +törvénytelen +törvénytelenség +törzs +törzsfőnök +törzsi +törzsiroda +törzsök +törzsökös +törzsőrmester +törzsparancsnok +törzsszázad +törzstiszt +törzsű +törzsvendég +töviről +tövis +tövű +tő +tődött +tőgy +tőgyű +tőke +tőkés +tőkegazdag +tőkepénzes +tőle +tőmondat +tőr +tőrőlmetszett +tőzeg +tőzsde +tőzsdés +tőzsdeügynök +toaletthelyiség +toboroz +toborzás +toborzó +toboz +tobzódik +toccsan +tocsog +tocsogó +tohonya +tojás +tojásdad +tojásexportőr +tojásnagykereskedő +tojásrántotta +tojástánc +tojik +tok +toka +tokány +tol +tolakodás +tolakodik +tolat +tolatómozdony +toldozgat +toll +tollászkodik +tollas +tollazat +tollazatú +tollbóbitás +tollforgató +tollpihe +tollseprű +tollseprűárus +tollú +tollvonás +tolmács +tolmácsol +tolóajtó +tolódik +tolóka +tolókocsi +tolószékes +tologat +toloncutca +tolong +tolongás +tolul +tolvaj +tolvajszerkó +tombol +tombolás +tomboló +tompa +tompít +tompor +tomporú +tonna +tonnás +topáz +topog +topogás +topolyafa +toporgás +toporog +toporzékol +toppan +toprongyos +torkaszakadtából +torkolat +torkolattűz +torkollik +torlasz +torlódás +torlódik +torma +tornác +tornácágas +tornáclépcső +tornácos-oszlopos +tornász +tornászik +tornászmozdulat +tornacipő +tornacipős +tornaóra +tornatanár +tornaterem +tornyosodás +tornyosodik +tornyosul +tornyozódik +torok +torokfojtogató +torokgyík +torokgyulladás +torokhang +torokmetszés +torony +toronyablak +toronybelső +toronydaru +toronyház +toronyiránt +toronymászás +toronymagas +toronymagasság +toronysarok +toros +torreádor +torta +torz +torzít +torzkép +torzonborz +torzsa +torzsalkodás +torzsalkodik +torzszülött +torzul +torzulás +torzulat +totál +totális +totojázik +tova +tovább +tovább-ballag +továbbá +továbbáll +továbbad +továbbcsalinkázik +továbbcsúszik +továbbél +továbbfejleszt +továbbfejlődik +továbbfolyik +továbbfolytat +továbbfut +továbbgördít +továbbgyűrűzik +továbbhajt +továbbhalad +további +továbbít +továbbító +továbbindul +továbbjut +továbbképző +továbblapoz +továbblép +továbblépés +továbblépeget +továbblendít +továbblök +továbbmegy +továbbmond +továbbra +továbbsettenkedik +továbbsiet +továbbsodor +továbbszöktet +továbbszolgálat +továbbterjed +továbbterjedés +továbbtol +továbbutazás +továbbvánszorog +továbbvisz +továbbvonul +továbbzakatol +tovafut +tovagördíthető +tovagomolyog +tovahömpölyög +tovalépdel +tovalebben +tovaragad +tovarebbent +tovarepül +tovarohan +tovasiet +tovasiklik +tovaszáll +tovatűnik +tovavonul +tra-ta-ta-ta-tam +trágár +trágárkodik +trágárság +trágya +trágyahordás +trágyasöprés +tradíció +trafik +trafikos +trafórobbanás +tragacs +tragédia +tragikum +tragikus +traktál +traktor +traktorista +traktoros +traktus +trambulin +transzcendencia +transzparens +transzport +transzportőr +tranzitutas +trapéz +trapp +trappol +traverz +traverzrácsozat +trécselés +tréfa +tréfál +tréfálkozás +tréfálkozik +tréfálkozó +tréfálódzik +tréfás +tréfadolog +tréfamester +tréfaröppentyű +tréner +tréning +tréningmaci +tréningruha +tréningruhás +trehány +tribün +trikó +trikós +trikolór +trilláz +trillázik +tritonkürt +trófea +trófeagyűjtemény +tróger +trón +trónörökös +trónus +trópus +trópusi +tröszt +trolibusz +trombita +trombitál +trombózis +trombózisos +tromfol +trükk +trükkös +tszcs +túl +túlad +túladagolás +túlbecsül +túlbecsülés +túlbonyolítás +túlcsap +túlcsapódik +túlcsordul +túldramatizálás +túléget +túlél +túlélő +túlér +túlérett +túlerő +túlesik +túlfelől +túlfeszültség +túlfűtött +túlfűtöttség +túlhajtott +túlharsog +túli +túljár +túljut +túlkapás +túlkiált +túlkompenzál +túllép +túllendül +túlmegy +túlmutat +túlnani +túlnyomás +túlnyomó +túlnyomórészt +túlóra +túlórázás +túlórázik +túlöltözött +túloldal +túloz +túlpart +túlparti +túlság +túlságos +túlsó +túlsúly +túlszámlál +túlszalad +túltápláltság +túltekint +túlterhel +túlterhelés +túlterjed +túltesz +túlvilág +túlvilági +túlzás +túlzott +túr +túra +túró +túrós +túsz-tanuló +tücsök +tücsök-bogár +tücsökzene +tüdejű +tüdő +tüdőbaj +tüdőbajos +tüdőbeteg +tüdőcsúcs +tüdőcsúcshurut +tüdőgyulladás +tüdős +tüdőszűrés +tüdővész +tüdővészes +tükör +tükörablakos +tükörbeli +tükörírásforma +tükörkép +tükörmás +tükörsima +tükrös +tükröz +tükrözés +tükrözik +tükröződik +tükrű +tülekedés +tülekedik +tülköl +tüllbetét +tüllfátyol +tülökszó +tündér +tündéri +tündérjáték +tündérmese +tündebaba +tündöklés +tündökletes +tündöklik +tünékeny +tünemény +tüneményes +tünet +tüntet +tüntetés +tüntető +türelem +türelmes +türelmetlen +türelmetlenkedik +türelmetlenség +türelmi +türkiz +türtőztet +tüske +tüskés +tüskés-sötét +tüskeborona +tüstént +tüzér +tüzérség +tüzérségi +tüzel +tüzelés +tüzelő +tüzes +tüzetes +tű +tűhegyes +tűhegynyi +tűnik +tűnődés +tűnődik +tűnődözik +tűnődőforma +tűr +tűrés +tűrés-tagadás +tűrhetetlen +tűrhetetlenség +tűrhető +tűsarkú +tűz +tűz-víz +tűzeső +tűzfal +tűzfegyver +tűzharc +tűzhely +tűzhelyajtó +tűzhelyes +tűzhelymaradvány +tűzifavágó +tűzijáték +tűzijátékgyáros +tűzköd +tűzkő +tűzlándzsa +tűznyelő +tűzön-vízen +tűzözön +tűző +tűzokádó +tűzoltó +tűzoltóruha +tűzoltóság +tűzpiros +tűzrendészeti +tűzrevaló +tűzsugár +tűzvonal +tubarózsa +tuberkulotikus +tucat +tucatnyi +tud +tudálékos +tudás +tudásvágy +tudakol +tudakolódzik +tudat +tudatalatti +tudatfunkció +tudathasadásos +tudatlanság +tudatos +tudatosodik +tudatosság +tudattalan +tudható +tudniillik +tudnivaló +tudó +tudós +tudósgárda +tudósít +tudósítás +tudósító +tudósítócsoport +tudósitó +tudósképző +tudóskollektíva +tudósság +tudóstárs +tudóstípus +tudomány +tudományos +tudománytörténet +tudomás +tudomásulvétel +tudomistenem +tudsz +tudta +tudvalevő +tulajdon +tulajdonít +tulajdonjog +tulajdonképpen +tulajdonképpeni +tulajdonos +tulajdonosnő +tulajdonság +tulipán +tulipánfa +tulipános +tulipánpiros +tulizik +tulok +tumultus +tundra +tunika +tunya +tupíroz +turbán +turbékol +turista +turistacsoport +turistaruha +turistaút +turisztikai +turizmus +turkál +turkálgat +turmix +turnürös +turpisság +tusázik +tusakodás +tusakodik +tuskó +tusoló +tuszkol +tuti +tviszt +tvisztel +tyúk +tyúkász +tyúkfarm +tyúkhúsleves +tyúkól +tyúkocska +tyúkszem +tyúkszemirtó +tyúkszemviszketés +tyűha +u-alak +u-asztal +uborka +uborkásüveg +uborkasaláta +uborkaszezon +udvar +udvarhölgy +udvari +udvarias +udvariaskodik +udvariasság +udvariassági +udvariatlan +udvariatlanság +udvarlás +udvarló +udvarnok +udvarol +udvarolgat +udvaronc +udvartartás +ugat +ugatás +ugor +ugrál +ugrálás +ugrándozás +ugrándozik +ugrás +ugrásnyi +ugrásszerű +ugrabugrál +ugrabugráltat +ugraszt +ugrat +ugratás +ugrifüles +ugrik +ugyan +ugyanakkor +ugyanannyi +ugyanaz +ugyanazon +ugyancsak +ugyanekkor +ugyanekkora +ugyanennyi +ugyanez +ugyanezen +ugyanígy +ugyanilyen +ugyanis +ugyanitt +ugyanoly +ugyanolyan +ugyanott +ugyanúgy +ugye +ugyebár +uhu +ujj +ujjas +ujjatlan +ujjhegy +ujjlenyomat +ujjlenyomat-készítő +ujjnyi +ujjong +ujjongás +ujjongtat +ujjropogtatás +ujjú +ukmukfukk +ukrán +ukrajnai +ulánus +ulti +ultizás +ultizik +ultramodern +ultrarojalista +ultraszeptil-tabletta +un +unalmas +unalmaskodik +unalom +unatkozik +undok +undor +undorító +undorodik +uniformis +uniformizmus +unikum +univerzális +unoka +unokabátya +unokahúg +unokaöcs +unokatestvér +unokatestvérség +unos-untalan +unott +unszol +unszolás +untat +uradalmi +uradalom +urahagyott +ural +uralkodás +uralkodik +uralkodó +uralkodói +uralom +uralomvágy +uramisten +uraság +urasági +uraskodik +uraz +urbanizáció +urbanizálódás +urizál +uszály +uszályméretű +uszályos +uszít +uszoda +uszony +usztasa +utál +utálatos +utálkozás +utálkozik +után +utána +utánabámul +utánaballag +utánacsap +utánafordul +utánafut +utánagázol +utánagondol +utánagurul +utánahajít +utánahajol +utánaindul +utánajár +utánajön +utánakap +utánaképzel +utánakiált +utánaküld +utánalép +utánamegy +utánanéz +utánanyúl +utánarohan +utánaszalad +utánaszól +utánatöltöget +utánaugrik +utánavet +utánazúdul +utánfolyó +utánfutó +utáni +utánoz +utánozhatatlan +utánpótlás +utánzás +utánzat +utász +utászcsizma +utacska +utal +utalás +utalvány +utalványoz +utas +utasáradat +utasít +utasítás +utasítgatás +utastér +utazás +utazási +utazgat +utazgatás +utazik +utazó +utazókosár +utazószatyor +utca +utcácska +utcájú +utcaajtó +utcafront +utcai +utcalámpa +utcalány +utcasarok +utcasor +utcatábla +utilitarisztikus +utóbb +utóbbi +utód +utóhatás +utóirat +utója +utókor +utólag +utólagos +utómanipulátorozás +utópia +utópisztikus +utóvéd +utóvédharc +utóvégre +utolér +utolérhetetlen +utoljára +utolsó +utolsósorban +uzsgyi +uzsonna +uzsonnázik +uzsorakamat +úgy +úgy-ahogy +úgy-úgy +úgyhogy +úgyis +úgymint +úgymond +úgynevezett +úgysem +úgysincs +úgyszólván +új +újabban +újból +újbóli +újdonság +újdonsült +újév +újévi +újesztendő +újfajta +újfent +újgazda +újhold +újít +újítás +újjáformálás +újjászervezés +újjászületés +újjászületik +újonc +újonctárs +újonnan +újpesti +újra +újraéled +újrafelfegyverzés +újrafelvétel +újraformálás +újrakezd +újrakezdődik +újraolvas +újraperget +újratanul +újrateremt +újratöltődés +újság +újságárus +újságcikk +újságcsomó +újsághír +újságíró +újságírói +újságírónő +újságkioszk +újságkivágás +újságol +újságos +újságpapír +újságpapiros +újszerű +újszerűség +újszülött +újul +úr +úrasztala +úrék +úrféle +úrfelmutatás +úrfi +úri +úri-polgári +úriasszony +úriember +úriház +úrinő +úristen +úristenit +úrnő +úszás +úszik +úszkál +úszó +úszómedence +úszónadrág +úsztat +út +útbaigazít +útburkolat +útcsinálás +útcsináló +útépítés +útépítő +úthálózat +úti +útibőrönd +úticél +útikalauz +útiköltség +útikönyv +útimars +útirány +útitárs +útitársnő +útján +útjai +útjelzőtábla +útkanyar +útkaparó +útkefélőgép +útkereső +útközben +útlevél +útlevélkérelem +útlevélosztály +útlevélvizsgálat +úton-módon +úton-útfélen +útpart +útrakész +útrakel +útravaló +útrész +útszakasz +útszél +útszéli +úttest +úttöltés +úttörés +úttörő +útvesztő +útvonal +ücsörög +üde +üdezöld +üdítő +üdülés +üdülő +üdülőféle +üdülőház +üdülőhely +üdülőtelep +üdv +üdvhadsereg +üdvös +üdvösség +üdvözítő +üdvözlégy +üdvözlés +üdvözlet +üdvözlő +üdvözlőféle +üdvözöl +üdvözül +üdvözült +üdvrivalgás +üget +üggyel-bajjal +ügy +ügybuzgalom +ügybuzgó +ügydarab +ügyész +ügyészség +ügyefogyott +ügyel +ügyelet +ügyeletes +ügyeleti +ügyelget +ügyes +ügyes-bajos +ügyesforma +ügyeskedik +ügyeskedő +ügyesség +ügyetlen +ügyetlenkedik +ügyfél +ügyintézés +ügyirat +ügyismeret +ügykör +ügylet +ügymenet +ügynök +ügyvéd +ügyvédék +ügyvédi +ügyvédné +ügyvezető +ühüm +ükapa +ül +üldögél +üldögélés +üldöz +üldözés +üldözési +üldözendő +üldözött +üldöző +üldöztetés +ülés +ülésezik +ülésterem +ülep +üllő +ülnök +ülő +ülőbútor +ülődeszka +ülőfogyasztás +ülőhely +ülőizom +ülőke +ülte +ültet +ültetés +ülve-emésztés +ünnep +ünnepély +ünnepélyes +ünnepélyesség +ünnepel +ünnepi +ünnepies +ünneplés +ünneplő +ünnepnap +ünnepség +ünnepségrendező +ünő +üreg +üreges +üregfal +üres +üresség +ürge +ürgeöntés +ürít +ürrakétarobbanás +ürügy +ürülék +üstök +üstökös +üstökösgém +üstökű +üszkös +üszkösödik +üsző +üt +üt-vág +ütés +üteg +ütem +ütemes +ütemez +ütközet +ütközik +ütköző +ütlegel +ütöget +ütött-kopott +ütő +ütődött +üttet +üveg +üvegablak +üvegajtó +üvegasztal +üvegasztalka +üvegcsarnok +üvegcse +üvegcserép +üvegdarab +üvegelőtetős +üveges +üvegez +üvegfal +üvegfalú +üveggömbös +üveggolyó +üveggyár +üveggyöngyös +üvegház +üvegházi +üveghalom +üveghangú +üvegillúzió +üvegkalitka +üvegkék +üvegköves +üvegkocka +üvegkupola +üveglap +üvegmeggy +üvegpohár +üvegpusztulás +üvegszekrény +üvegszerű +üvegszilánk +üvegtábla +üvegű +üvegváza +üvegveranda +üvegverandás +üvegvirágzó +üvölt +üvöltés +üvöltözés +üvöltözik +üvöltő +üzér +üzekedik +üzelmek +üzem +üzemanyag +üzemanyagpótlás +üzembiztos +üzemegység +üzemegység-iroda +üzemegység-vezető +üzemel +üzemi +üzemi-gyakorlati +üzemiroda +üzemképes +üzemszervezési +üzemtechnikusi +üzemvezető +üzemvezető-helyettes +üzemzavar +üzen +üzenet +üzlet +üzletajtó +üzletasszony +üzletember +üzletfél +üzlethálózat +üzletház +üzlethelyiség +üzleti +üzletkötés +üzletkötő +üzletvezető +üzletvitel +űr +űrállomás +űrbeli +űrgép +űrháttér +űrhajó +űrhajós +űrközlekedés-tudományi +űrközlekedési +űrkutatás +űrlap +űrmámor +űrméret +űröltözet +űrrakéta +űrruha +űrszanatórium +űrtáv-hajózási +űz +váci +vád +vádaskodás +vádaskodik +vádló +vádlott +vádol +vág +vágány +vágás +vágástér +vágású +vágat +vágódik +vágóhíd +vágott +vágta +vágtázik +vágtat +vágy +vágyálom +vágyás +vágyakozás +vágyakozik +vágyik +vágyódás +vágyódik +vágyott-álmodott +vágyú +váj +vájár +vájári +vájat +vájdling +vájkál +vájvég +vákáncsos +válás +váladék +válasz +válaszadás +válaszol +válaszolgat +választ +választás +választávirat +választék +választékos +választípus +választmány +választott +válaszút +válfaj +válható +válik +váll +vállal +vállalás +vállalat +vállalati +vállalatvezető +vállalkozás +vállalkozik +vállalkozó +vállalkozókedv +vállas +vállfa +vállizom +vállmagaság +vállpántos +vállrándítás +vállrojt +vállú +vállvonás +vállvonogatás +vállvonogatva +válófélben +válóper +válóperi +válogat +válogatás +válogatós +válogatott +válság +válságos +vált +váltás +váltakozás +váltakozik +váltakozó +váltig +váltó +váltóőr +váltóügyvéd +váltogat +változás +változat +változatlan +változatlanság +változatos +változatosság +változékony +változékonyság +változik +változó +változtat +változtatás +váltság +vályog +vályogfal +vályogház +vályogkerítés +vályogkunyhó +vályú +vám +vámőr +vámtisztviselő +vámvizsgálat +vándor +vándorcirkuszos +vándorkomédiás +vándorlás +vándorol +vándorpap +vándorút +vánkos +vánkosciha +vánkosszínű +vánszorog +ványai +vár +várás +várakozás +várakozásteljes +várakozik +várakozó +várakoztat +várakoztatás +váralja +várandós +várat +váratlan +váratlanság +várbeli +várfal +várfogság-büntetés +várható +várkastély +vármegye +vármegyei +várnagy +váró +várócsarnok +várószoba +váróterem +város +városállam +városcímer +városépítés +városfal +városfantom +városfejlesztési +városház +városháza +városházi +városi +városias +városiasodás +városirtó +városka +városlakó +városligeti +városnegyed +városrész +városrendezés +városszéli +városszerte +várostorony +városúr +várpince +várrom +várt +várudvar +vásár +vásárcsarnok +vásári +vásárlás +vásárlási +vásárló +vásárol +vásárolhatnék +vásáros +vásározó +vásártér +vásott +vászon +vászonbetétes +vászonblúz +vászonhuzat +vászonkalap +vászonnadrág +vászonredőny +vászonroló +vászonruha +vászonsapka +vászontasak +vászontetős +vászonzacskó +vászonzsák +vászonzubbony +váz +váza +vázlat +vázlatos +vacak +vacakol +vacog +vacogás +vacok +vacsora +vacsora-kenyér +vacsorál +vacsorázás +vacsorázik +vacsoráztat +vacsoracsillag +vacsoraidő +vad +vadállat +vadász +vadászat +vadászati +vadászbarátság +vadászetika +vadászfegyver +vadászgat +vadászház +vadászidő +vadászik +vadászkutya +vadászlak +vadászpuska +vadászrész +vadászrepülő +vadászszenvedély +vadásztársaság +vadásztanya +vadászterület +vadásztörténet +vadászvacsora +vadászvér +vadalma +vadbarom +vadborsó +vaddisznó +vademberi +vadgazdálkodó +vadgesztenyefa +vadhajtás +vadízű +vadidegen +vadkereskedelem +vadkutya +vadliba +vadlúdcsapat +vadmacska +vadmadár +vadmagyarság +vadmarha +vadméh +vadmeggy +vadmeggyfa +vadnövény +vadőr +vadon +vadonatúj +vadréce +vadság +vadszőlő +vadszőlőbokor +vadszőlős +vadul +vadvíz +vadvirág +vagány +vagdal +vagdos +vagina +vagon +vagonablak +vagonajtó +vagongyár +vagonrakás +vagy +vagyis +vagyishogy +vagyon +vagyongyűjtés +vagyoni +vagyonka +vagyonos +vagyonreménység +vaj +vajákos +vajas +vajaskifliszerű +vajaz +vajda +vajfehér +vajha +vajmi +vajon +vajsárga +vajszínű +vajúdás +vak +vakáció +vakar +vakarás +vakarcs +vakargat +vakaródzik +vakbuzgó +vakfoltos +vakít +vakítás +vakító +vakkanásszerű +vakkant +vaklárma +vakmerő +vakmerőség +vakol +vakolat +vakolatdarab +vakolatú +vakondok +vakoskodik +vakráma +vakremény +vakság +vaksi +vaksötét +vaktában +vaktöltény +vakulás +vakvágány +vakvágat +vala +valaha +valahány +valahányszor +valahai +valahogy +valahol +valahonnan +valahova +valaki +valameddig +valamely +valamelyes +valamelyest +valamelyik +valamennyi +valamennyire +valamerre +valami +valamicske +valamifajta +valamiféle +valamiként +valamiképpen +valamikor +valamilyen +valaminő +valamint +valamirevaló +vall +vallás +vallási +vallásos +vallásszabadság +vallásügy +vallat +vallatás +vallató +vallomás +való +valóban +valódi +valójában +valóság +valóságértékű +valósággal +valóságos +valószerűség +valószerűtlen +valószínű +valószínűleg +valószínűség +valószínűsít +valószínűtlen +valuta +valutaügy +vamzer +vamzerolás +van +vanília +varázs +varázsamulett +varázserő +varázseszköz +varázsháló +varázslat +varázslatos +varázsló +varázsol +varázsos +varázsütés +varázsüveg +varas +varga +varga-féle +vargabetű +variáció +variál +varjú +varjúféle +varjúleves +varkocs +varr +varrás +varrat +varróleány +varrónő +varroda +varrogat +varsa +varsányi +vartyogás +vas +vaságy +vasárnap +vasárnapi +vasajtó +vasal +vasalatlan +vasalkatrész +vasaló +vasalt +vasas +vasbánya +vasbeton +vasbot +vascső +vasék +vasfokos +vasfüggöny +vasfű +vasgálya +vasgolyó +vasgyár +vashágcsó +vashinta +vashomlokú +vashuzal +vasipari +vaskályha +vaskampó +vaskapu +vaskarika +vaskéz +vaskereskedés +vaskereskedő +vaskeretes +vaskerítés +vaskesztyűs +vaskezű +vaskos +vaslépcső +vaslétra +vaslemez +vaslogika +vasmarok +vasorrú +vaspánt +vaspántos +vaspajszer +vaspillér +vaspor +vasrács +vasrácsos +vasreszelék +vasretesz +vasrúd +vassúly +vasszerkezet +vastag +vastagbél +vastartó +vastorkú +vastragacs +vasút +vasútállomás +vasúti +vasútoldal +vasútrészvény +vasútüzlet +vasútvonal +vasutas +vasutastiszt +vasutazik +vasvázas +vasvilla +vasvillaszem +vatikáni +vattacsomó +vattaréteg +vau +vb-titkár +vb-ülés +vécé +véd +védekezés +védekezési +védekezik +védelem +védelmez +védelmező +védelmi +védenc +véderő +védetlen +védett +védettség +védhetetlen +védőberendezés +védőgát +védőköpeny +védőkupola +védőmű +védőszárny +védőügyvéd +védővám +védtelen +védtelenség +vég +végállomás +végbél +végbélrákos +végbemegy +végcél +végérvényes +végeérhetetlen +végeláthatatlan +végelgyengülés +végeredmény +véges +véges-végig +végeszakadhatatlan +végetér +végett +végez +végezet +végezetlen +végezetül +végezhető +végezte +végeztet +végi +végítélet +végig +végigaraszol +végigballag +végigböngész +végigbolyong +végigcaftat +végigcammog +végigcirógat +végigcsámcsog +végigcsapkod +végigcsépel +végigcsepegtet +végigcsinál +végigcsorog +végigcsúszik +végigcsúsztat +végigcuppog +végigdidereg +végigdöng +végigdönget +végigdől +végigdrukkol +végigdübörög +végigél +végigeszik +végigfekszik +végigfolyik +végigfut +végigfuttat +végiggondol +végiggurul +végiggyalogol +végighajtat +végighalad +végighallgat +végighasad +végighemperedik +végigheveredik +végighordoz +végighúz +végighúzódik +végighurcol +végigjár +végigkérdez +végigkerget +végigkísér +végigkocogtat +végigkommandíroz +végigkopog +végigkopogtat +végigkúszik +végigküzd +végigkutat +végiglát +végiglátogat +végiglapoz +végiglépdel +végiglépeget +végiglopódzik +végigmászik +végigmarháskodik +végigmér +végigmegy +végigmond +végignéz +végignyúl +végignyúlik +végigolvas +végigoson +végigpásztáz +végigreped +végigrobog +végigrohan +végigropogtat +végigsandít +végigsétál +végigsiet +végigsiklat +végigsimít +végigsimogat +végigskálázik +végigsöpör +végigspriccel +végigsuhan +végigszáguld +végigszámol +végigszánt +végigszalad +végigszimatol +végigtántorog +végigtapint +végigtapogat +végigtipor +végigtöröl +végigtol +végigül +végigutazik +végigvág +végigvágódik +végigvándorol +végigvár +végigvadászik +végigver +végigvet +végigvezényel +végigviharzik +végigvisz +végigvizslat +végigvonszol +végigvonul +végigzongoráz +végigzuhan +végképpen +végkielégítés +végkövetkeztetés +véglény +végleg +végleges +véglet +végletes +végletesség +végnap +végösszeg +végpont +végpusztulás +végre +végre-valahára +végrehajt +végrehajtás +végrehajtó +végrendelet +végső +végszó +végtag +végtére +végtelen +végtelenség +végtisztelet +végtisztesség +végül +végű +végzet +végzetes +végzetszerű +végzett +végzettség +végződik +véka +vékony +vékonyka +vékonyodik +vél +vélekedés +vélekedik +vélemény +véleményez +véleménykülönbség +véletlen +véletlenség +véletlenszerű +véletlenül +vélt +vén +véna +vénasszony +vénasszonyos +vénember +vénlány +vénlányság +vénség +vénül +vér +vérátömlesztés +vérbeli +vérbő +vércse +vércsepp +véreb +vérellátó +vérengzés +vérengzik +vérengző +véres +véreshurka +vérhas +vérhullám +vérittas +vérivó +vérkeringés +vérkeveredés +vérlázító +vérmérsékletű +vérmes +vérnarancsszállítmány +vérnyomás +vérnyomásmérő +vérontás +vérpiros +vérrokon +vérsejt +vérszag +vérszegény +vérszem +vérszerződés +vérszínű +vérszívó +vérszomjas +vértanú +vértelen +vérvétel +vérvörös +vérzés +vérzik +vés +véső +vésődik +vésőhenger +vész +vészbíróság +vészes +vészfelhő +vészjel +vészjósló +vészkijárat +vét +vétek +vétel +vételez +vétkes +vétő +vétség +vézna +vedlett +vegetáció +vegetál +vegetálás +vegyész +vegyelemzés +vegyelemző +vegyes +vegyest +vegyi +vegyít +vegyszer +vegyszerszekrény +vegytan +vegyül +vegyület +vehető +vekker +vekkeróra +vele +velebeli +velejáró +velencei +veleszületett +velő +vemhe +vendég +vendégbarátság +vendégeskedik +vendégjárás +vendégkaréj +vendégkör +vendéglátás +vendéglátó +vendéglátó-ipari +vendéglátóhely +vendéglő +vendéglői +vendéglős +vendégoldal +vendégoldalrúd +vendégpüspök +vendégség +vendégsereg +vendégszerepel +vendégszereplés +vendégszeretet +vendégszerető +vendégszoba +vendégvadász +ventillátor +venyige +venyigeszár +ver +veranda +verbéna +verdes +verdesés +veréb +verébfióka +verébszínű +verés +vereget +verejték +verejtékcsepp +verejtékes +verejtékezik +verekedés +verekedik +verekedő +verem +vereség +veret +vergődés +vergődik +verhetetlenség +verkli +verniszázs +verőce +verődik +vers +verseng +versengés +verseny +versenyez +versenyképes +versenyló-comb +versenynap +versenytárs +versenytapasztalat +versenyző +verses +verseskönyv +versgyűjtemény +verssor +vert +vertikális +vertikalitás +verzió +vese +vesebaj +vesemedence +vesepecsenye +vessző +vesszőcsokor +vesszőfutás +vesszőgóré +vesszőkosár +vesz +veszély +veszélyes +veszélyeztet +veszélyeztetett +veszélyeztetettség +veszélytelen +veszedelem +veszedelmes +veszekedés +veszekedett +veszekedik +veszendő +veszett +veszettség +veszít +veszítenivaló +veszkődik +vesződés +vesződik +vesződség +veszprémi +veszt +veszte +vesztés +vesztési +vesztegel +veszteget +vesztegetés +vesztenivaló +vesztes +veszteség +vesztett +vesztőhely +vet +vetélkedés +vetélytárs +vetélytársnő +vetés +vetési +vetekedik +vetemény +veteményes +vetemedik +veterán +vetetlen +vetít +vetítés +vetítő +vetítőterem +vetkezés +vetkezik +vetkeztet +vetkőzés +vetkőzik +vetkőztet +vetődik +vetőmag +vetül +vetület +vevő +vevődik +vevőernyő +vevőtér +vezényel +vezényszó +vezér +vezércikk +vezércikkíró +vezérel +vezérezredes +vezérfarkas +vezérgép +vezéri +vezérigazgató +vezérkar +vezérkari +vezérlés +vezérlésű +vezérlőasztal +vezérlőpult +vezérlőterem +vezérség +vezérszólam +vezekel +vezeklés +vezet +vezeték +vezetékes +vezetéknév +vezetés +vezető +vezetőbíró +vezetőfülke +vezetőgárda +vezetői +vezetőség +vezetőségi +vezetőszerv +víg +víg-lakás +víkend +víkendház +víkendtelek +vírus +vív +vívás +vívmány +vívó +vívódik +víz +vízállás +vízálló +vízbefúl +vízcsap +vízcsepp +vízcseppnyi +vízcsobogás +vízellátás +vízelvezető +vízesés +vízfelhő +vízfesték +vízfolyás +vízforrás +vízhatlan +vízi +víziállat +vízibuszmegálló +víziló +vízimalom +vízió +vízipálma +vízipuska +vízitetű +vízivás +vízkék +vízkereszt +vízkitörés +vízlefolyás +vízlevezető +vízlocsogás +vízmosás +vízművek +vízoszlop +vízpart +vízparti +vízrajzi +vízsugár +vízszagú +vízszint +vízszintes +víztároló +víztartalom +víztócsa +víztömeg +víztorony +víztükör +vízügyi +vízum +vízvessző +vízvezeték +vízvezeték-pumpa +vízvezetékszerelő +vízzubogás +vízzuhatag +viadal +viaskodás +viaskodik +viaszliliom +viaszosvászon +viaszpanoptikum +viaszszínű +vibrál +vibrálás +vicc +viccel +viccelődik +vicces +vicclap +vicelakás +vicinális +vicsor +vicsorgat +vicsorít +vicsorog +vidám +vidámság +vidék +vidéki +vidékies +vidor +vidra +vigad +vigalom +vigasz +vigasztal +vigasztalás +vigasztalan +vigasztaló +vigasztalódik +vigyáz +vigyázat +vigyázatlan +vigyázz +vigyor +vigyorgás +vigyori +vigyorog +viháncol +viháncolás +vihar +viharálló +viharfelhő +viharfelhős +viharfelhőszerű +viharkabát +viharkabátos +viharlámpa +viharos +viharzik +viharzó +vihog +vihogás +vihorászás +vijjog +vijjogás +vikárius +vikszel +vikszol +világ +világalkony +világbajnok +világbajnokság +világbíró +világbirodalom +világcsászárság +világcsavargó +világéletében +világegyetem +világfi +világgazdaság +világháború +világháborús +világhatalom +világhír +világhírű +világi +világít +világítás +világító +világítós +világítóudvar +világirodalom +világjáró +világjárt +világkép +világképű +világközvélemény +világméretű +világmindenség +világnagy +világnap +világnézet +világnézeti +világnyelv +világos +világosbarna +világosító +világoskék +világosodás +világosodik +világosság +világosszürke +világoszöld +világpiaci +világpolitika +világprotézis +világraszóló +világrekord +világszenzáció +világszerte +világszínvonal +világszövetkezés +világtáj +világtalan +világtér +világtérkép +világtörténelem +világüresség +világűr +világuralmi +világváros +világvárosi +világvége +világverseny +világvevő +világviszonylat +villa +villám +villámcsapás +villámgyors +villámgyorsaság +villámvágta +villaavatás +villakupac +villamos +villamosbérlet +villamoskalauz +villamoskocsi +villamosmegálló +villamosremíz +villamossín +villamosutazás +villamosvezető +villan +villanás +villanásnyi +villanó +villant +villany +villanyáram +villanybojler +villanyborotva +villanyégő +villanyfény +villanyfényes +villanyfőző +villanygyertya +villanygyújtás +villanykályha +villanykapcsoló +villanyköd +villanykörte +villanymelegítő +villanyóra +villanypózna +villanyszámla +villanyszámlás +villanyszerelő +villanytelep +villanyvasaló +villaszerű +villatelep +villódzás +villódzik +villog +villogás +villogó +vinkó +vinnivaló +vinnyog +vinnyogásszerű +viola +vipera +viplafog +virág +virágágy +virágágyás +virágárus +virágbóbita +virágcsokor +virágerdő +virágfüzér +virághernyó +virágillat +virágillatos +virágillatú +virágkereskedés +virágkosár +virágkoszorús +virágkultusz +virágmag +virágnév +virágözön +virágos +virágoskert +virágpalánta +virágpiac +virágsziget +virágtartó +virágtenger +virágtő +virágú +virágüzlet +virágváza +virágvadász +virágzás +virágzik +virágzó +virgonc +virgoncság +virít +virilista +virrad +virradat +virraszt +virrasztás +virsli +virtus +virul +visel +viselés +viselet +viselkedés +viselkedésforma +viselkedési +viselkedik +viselő +viselt +viseltes +visít +viskó +visong +visongat +vissza +vissza-visszacsillan +vissza-visszafordul +vissza-visszales +vissza-visszaszáll +vissza-visszatér +visszája +visszás +visszaáll +visszaállít +visszaad +visszaadat +visszabarnul +visszabiccent +visszabotorkál +visszacsatol +visszacsendül +visszacseng +visszacsíp +visszacsinál +visszacsinálhatatlan +visszacsókol +visszacsomagol +visszacsúszik +visszadöccen +visszadől +visszadob +visszadug +visszaédesget +visszaél +visszaélés +visszaépít +visszaépítés +visszaér +visszaérkezés +visszaérkezik +visszaejt +visszaemel +visszaemlékezik +visszaenged +visszaereszkedik +visszaeső +visszafejlődik +visszafekszik +visszafektet +visszafelé +visszafizet +visszafizetés +visszafog +visszafoglal +visszafojt +visszafordít +visszafordul +visszafordulás +visszafordulta +visszafut +visszagondol +visszagurul +visszagyűr +visszahány +visszahajt +visszahajtogat +visszahall +visszahat +visszahelyez +visszahesseget +visszaheveredik +visszahív +visszahőköl +visszahord +visszahoz +visszahozhatatlan +visszahúz +visszahúzódás +visszahúzódik +visszahúzódta +visszahull +visszahullámzik +visszahurcol +visszaír +visszailleszt +visszaindul +visszaindulás +visszainteget +visszairányít +visszajár +visszajáró +visszajön +visszajövet +visszajut +visszajuttat +visszakanyarodik +visszakap +visszakapaszkodik +visszakapcsol +visszakattint +visszakényszerít +visszakér +visszakérdez +visszakéz +visszakecmereg +visszakerül +visszakísér +visszakísértet +visszakiált +visszakiabál +visszaköltözik +visszaköszön +visszakocsikázik +visszakozik +visszakúszik +visszaküld +visszakuporodik +visszalapoz +visszalép +visszalépdel +visszales +visszalóg +visszalök +visszalövell +visszalop +visszalopakodik +visszamászik +visszamázsálás +visszamarad +visszamegy +visszamerészkedik +visszamerül +visszaminősít +visszamond +visszamosolyog +visszanéz +visszanyel +visszanyelvel +visszanyer +visszanyom +visszanyúl +visszanyúlik +visszaönt +visszaomlik +visszaordít +visszaoson +visszaparancsol +visszapattan +visszaperdül +visszaperget +visszapillant +visszapillantó +visszapörget +visszapörög +visszaprésel +visszarabol +visszarak +visszarecseg +visszarendel +visszarepül +visszariad +visszariaszt +visszarobog +visszarohan +visszasétál +visszasereglik +visszasír +visszasiet +visszaslattyog +visszasüllyed +visszasurran +visszaszájal +visszaszáll +visszaszállít +visszaszállingózik +visszaszámlálás +visszaszerel +visszaszerez +visszaszól +visszaszökik +visszaszolgáltat +visszaszorít +visszatámaszt +visszatáviratozik +visszatalál +visszatart +visszataszító +visszatér +visszatérés +visszatérít +visszatérő +visszateker +visszatekint +visszatelepedik +visszatesz +visszatetsző +visszatiszteleg +visszatöm +visszatol +visszatűz +visszaúszik +visszaút +visszaül +visszaüt +visszaüvölt +visszaugrik +visszautasít +visszautasítás +visszautasító +visszautazik +visszavág +visszavágódik +visszavágtat +visszavágyik +visszavált +visszaváltozik +visszavár +visszavarázsol +visszavarázsolódik +visszaver +visszaverődik +visszavesz +visszavet +visszavezet +visszavezethető +visszavigyorog +visszavisz +visszavon +visszavonás +visszavonhatatlan +visszavontat +visszavonul +visszavonulás +visszavonuló +visszavonult +visszavonultság +visszavonz +visszazár +visszazökken +visszazökkent +visszazuhan +visszér +visszeres +visszfény +visszhang +visszhangos +visszhangoz +visszhangzik +visz +visz-mos +viszály +viszket +viszketés +viszketeg +viszlát +viszolygás +viszolyog +viszolyogtat +viszonoz +viszont +viszontagság +viszontagságos +viszontlát +viszontlátás +viszontlátásra +viszontszeret +viszony +viszonyít +viszonylag +viszonylagos +viszonylat +viszonzás +vita +vitályosi +vitás +vitázik +vitalehetőség +vitalitás +vitamin +vitaminhiány +vitapartner +vitat +vitatható +vitatkozgat +vitatkozik +vitatott +vitéz +vitézi +vitézlő +vitézség +vitézségi +vitel +vitet +vitorla +vitorlás +vitorlázik +vitorlabontás +vitorlavászon +vitrin +vitriol +vityilló +vizelde +vizenyős +vizes +vizesárok +vizesbögre +vizesdézsa +vizeskancsó +vizeskék +vizesnyolcas +vizespohár +vizez +vizigót +vizit +vizitel +vizsga +vizsgál +vizsgálat +vizsgálati +vizsgálgat +vizsgálóbíró +vizsgálódás +vizsgálódik +vizsgázik +vizsgáztatás +vizsgaszünet +vizsla +vizslat +vizű +vödör +völgy +völgyecske +völgyhajlat +vörhenyes +vörös +vörös-borostás +vörös-fehér +vörös-fekete +vörösbarna +vöröses +vörösesbarna +vöröseslila +vörösesszőke +vörösfenyő +vörösgárda +vörösgém +vöröshagyma +vöröskatona +vöröskeresztes +vöröslábú +vöröslámpás +vöröslik +vörösödik +vörösőrség +vöröstéglás +vő +vőfély +vőlegény +vőlegényék +vodka +vodkásüveg +vogul +vokális +voks +volán +volna +volt +volta +voltaképpen +voltaképpeni +volumen +voluntarista +von +vonás +vonású +vonaglik +vonakodik +vonal +vonalbeli +vonalszakasz +vonalú +vonalvezetés +vonalzó +vonat +vonatablak +vonatérkezés +vonatindulás +vonatjegy +vonatkozás +vonatkozik +vonatkozó +vonatkoztat +vonható +vonít +vonításszerű +vonó +vonóhorog +vonogat +vonszol +vontat +vontató +vontatógőzös +vontatott +vonul +vonulás +vonz +vonzás +vonzáskör +vonzású +vonzalom +vonzó +vonzódik +vonzóerő +vonzókör +vulgáris +vulgarizál +vulkanikus +watt +wattos +web +webáruház +webhely +weblap +webszolgáltató +xilofon +xilofonművész +zágrábi +zákányi +zálog +zálogház +zápor +záporoz +zár +zárándi +zárás +záradék +zárat +zárda +zárka +zárkatárs +zárkózik +zárkózott +zárkózottság +zárlat +záródísz +záródik +zárójel +zárójelentés +záróra +zárótűz +záróünnepély +zárt +zártkörű +zártság +zárul +zászló +zászlóalj +zászlóalj-segédtiszt +zászlóaljparancsnok +zászlócska +zászlónyél +zászlónyelv +zászlós +zászlótartó +zátony +zab +zabál +zabáltat +zabfőzet +zabigyerek +zabikál +zabla +zabolázható +zabos +zacskó +zafírkő +zagyvaság +zaj +zaj-fény +zaj-kvantum +zajgás +zajlás +zajlik +zajong +zajongás +zajos +zajtalan +zakatol +zakatolás +zaklat +zaklatott +zaklatottság +zakó +zalai +zamat +zarándok +zarándokol +zarándokvonat +zavar +zavarás +zavargás +zavarkeltő +zavarkodik +zavaró +zavarodott +zavarodottság +zavaros +zavart +zavartalan +zavartalanság +zavartat +zavartság +zebra +zebracsíkos +zegzug +zegzugos +zeke +zeller +zempléni +zendülés +zene +zenél +zenélőóra +zenés +zenész +zenebona +zenei +zeneiskola +zenekar +zeneszám +zeneszerző +zeneutánzat +zeng +zengés +zengésű +zerge +zetoros +zihál +zihálás +zilál +zilált +zilahi +zimankós +zivatar +zizeg +zizzen +zóna +zökken +zökkenés +zöld +zöld-barna +zöld-ezüst +zöld-fehér +zöldbab +zöldell +zöldes +zöldfülű +zöldinges +zöldkeretes +zöldköves +zöldpaprika +zöldruhás +zöldség +zöldséges +zöldségestábla +zöldségféle +zöldségpiac +zöldségszag +zöldségtermesztés +zöldselyem +zöm +zömök +zörej +zörgés +zörget +zörgetés +zörgős +zörög +zörren +zörrenés +zöttyen +zötyköl +zötykölődik +zötyög +zokni +zokog +zokogás +zokon +zokszó +zománc +zománcos +zománcozott +zománcú +zongora +zongorázás +zongorázik +zongorapartner +zongoraszó +zongorista +zord +zordon +zríkol +zúdít +zúdul +zúg +zúgás +zúgat +zúgolódik +zúz +zúzódás +züllik +züm-züm +züm-züm-züm +zümi-zümi +zümmög +zümmögés +zűr +zűrös +zűrzavar +zubbony +zubbonynyak +zubog +zubogás +zug +zugfelcserkedés +zuhan +zuhanás +zuhanó-emelkedő +zuhany +zuhanyozó +zuhatag +zuhog +zuhogás +zuhogó +zs +zsák +zsákdarab +zsákhálóing +zsákmány +zsákmányol +zsákmányszerző +zsákszerű +zsákutca +zsálya +zsámoly +zsakett +zsalu +zsalugáter +zsandár +zsarát +zsarnok +zsarnok-kakas +zsarnoki +zsarnokság +zsarol +zsaroló +zsaru +zseb +zsebes +zsebkés +zsebkendő +zsebkendőnyi +zsebkiadás +zseblámpa +zsebmetsző +zsebnaptár +zsebóra +zsebpénz +zsebpénzprobléma +zsebrádió +zsebtükör +zsemle +zsenge +zseni +zseníroz +zseniális +zsenialitás +zserbó +zsír +zsírbontó +zsírfolt +zsírfoltos +zsírfolyó +zsírgolyó +zsírgulyás +zsírmaszat +zsíros +zsírosbödön +zsírosodó +zsíroz +zsírpacni +zsírpecsét +zsírpuszta +zsírtartalék +zsírtemplom +zsírtócsa +zsírtömb +zsibbad +zsibbadás +zsibbadt +zsibong +zsibongás +zsidó +zsidóasszony +zsidóság +zsidótörvény +zsiger +zsigeri +zsilett +zsilip +zsinagóga +zsinat +zsindelyes +zsineg +zsinór +zsiradék +zsivaj +zsivajgás +zsivajog +zsivajos +zsöllye +zsörtölődés +zsörtölődik +zsörtös +zsoké +zsokésapka +zsokésapkás +zsold +zsoldfizetés +zsoldos +zsoldpénz +zsoltár +zsoltárkönyv +zsoltároskönyv +zsombék +zsombékos +zsong +zsongás +zsongít +zsonglőrködés +zsorzsettfátyol +zsúfol +zsúfolás +zsúfolódik +zsúfolt +zsúfoltság +zsúp +zsúpfedél +zsúpfedeles +zsúpos +zsúptetős +zsugázik +zsugori +zsugorodik +zsumók +zsupsz \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szo.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szo.txt new file mode 100644 index 0000000..cd61d6e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/szo.txt @@ -0,0 +1,5 @@ +orvostudomnyi + + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/tanulók.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/tanulók.txt new file mode 100644 index 0000000..605bd65 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/tanulók.txt @@ -0,0 +1,100 @@ +Verebes;Fruzsina;149;54.4;lány +Borsodi;Attila;167;51.1;fiú +Major;Liza;155;52;lány +Varga;Ernő;173;46.5;fiú +Lendvai;Vera;165;46.7;lány +Kulcsár;Antal;172;55.7;fiú +Petróczi;Virág;169;41.3;lány +Pais;Károly;155;55.5;fiú +Horváth;Adél;157;56.5;lány +Kiss;Balázs;163;54.5;fiú +Orosz;Ingrid;172;41.9;lány +Pelikán;Tamás;172;48.9;fiú +Zalai;Elvira;147;57.4;lány +Papp;Lilla;169;56;lány +Huszár;Dorina;151;48.1;lány +Kiss;Krisztián;145;59.3;fiú +Sipos;Zsolt;173;57.6;fiú +Pongrácz;Karina;175;42.1;lány +Vissi;Klaudia;166;59;lány +Gellén;Bea;188;47.9;lány +Ferencz;Ivett;171;51;lány +Ujj;Mihály;188;55.6;fiú +Kovács;Gergely;147;42;fiú +Felföldi;Judit;145;52.3;lány +Bartal;Zsolt;169;49.9;fiú +Simon;Erik;171;46.7;fiú +Csiszár;Alexandra;170;52.8;lány +Pesti;Milán;188;53.3;fiú +Simon;Rita;166;46;lány +Somogyi;Dezső;177;46.3;fiú +Magyar;Magdolna;150;56.8;lány +Gombos;Kinga;149;56.7;lány +Egerszegi;Kristóf;162;52.2;fiú +Somogyi;Tamás;172;59.7;fiú +Varga;Anna;188;58.3;lány +Csondor;Anikó;159;45.3;lány +Vass;Szabolcs;188;54.2;fiú +Szabó;Csilla;163;59.6;lány +Pass;Flóra;177;45.6;lány +Agg;Judit;145;51.1;lány +Gyenese;Oszkár;157;43;fiú +Hardi;Boglárka;159;60;lány +Kuti;Lehel;163;53.8;fiú +Domján;Hermina;165;41.3;lány +Tompa;Krisztina;172;51.9;lány +Radics;Betti;171;42.9;lány +Balla;Ibolya;180;43;lány +Csontos;Janka;151;56.2;lány +Radics;Zsuzsa;159;46.4;lány +Vajda;Klára;172;41.9;lány +Simon;Marcell;171;46.6;fiú +Salamon;Laura;162;48.3;lány +Bakony;Ilona;145;46.7;lány +Hantos;Bence;147;59;fiú +Kovács;Erika;167;59.6;lány +Csiszár;Bella;168;48.6;lány +Simon;Dorina;169;46.3;lány +Bicsák;Hilda;173;44;lány +Varga;Rozália;156;44.1;lány +Lengyel;Viktor;188;53.3;fiú +Molnár;Zsombor;172;48.8;fiú +Hajba;Soma;178;48.8;fiú +Bocskor;Henrik;154;54.5;fiú +Hajdu;Szilvia;157;47.2;lány +Csalló;Aliz;159;53;lány +Kelemen;Gergő;163;44.9;fiú +Kaczor;Jenő;167;44.5;fiú +Bujtor;Erzsébet;167;52.1;lány +Gombos;Olivér;168;42.5;fiú +Varga;Cili;172;49.7;lány +Gulyás;Katalin;171;58.2;lány +Vass;Vera;155;46;lány +Salamon;András;177;55.9;fiú +Elekes;Elza;177;48.2;lány +Nagy;Melinda;145;46.5;lány +Kovács;Vivien;160;58.5;lány +Kaszás;Ferenc;149;53;fiú +Balogh;Borbála;166;52.9;lány +Horváth;Barbara;153;49.1;lány +Dobos;Vilma;180;42.9;lány +Nagy;Miklós;156;51.7;fiú +Kovács;Ambrus;173;54.2;fiú +Paksa;Csilla;141;58.4;lány +Bende;Natália;145;56.9;lány +Czigány;Judit;161;41.4;lány +Simon;Edina;167;51.3;lány +Monok;Gabriella;168;58.4;lány +Jakab;Etelka;169;49.2;lány +Vig;Viola;159;53.9;lány +Szegleti;Tamás;160;50.5;fiú +Pataki;Viktória;149;50.8;lány +Vass;Ildikó;171;49.8;lány +Farsang;Jakab;168;47.7;fiú +Vajda;István;163;48.7;fiú +Marosvári;Krisztina;162;46.1;lány +Horváth;Kamilla;159;42.1;lány +Koller;Tamás;171;45.6;fiú +Kocsis;Tamara;170;59.6;lány +Molnár;Vera;155;42.2;lány +Hegyi;Csaba;152;48.4;fiú \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Források/zemplen.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/zemplen.txt new file mode 100644 index 0000000..a673483 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Források/zemplen.txt @@ -0,0 +1,6 @@ +ZEMPLN +Ahol a tj llandan vltozik +Milyen vidk ez? Nehz lenne nhny szval jellemezni a sokarc, vibrl, mgis fensges nyugalmat raszt tjat, ahol az ember s a termszet vszzadok ta l szeld harmniban. A Zemplni-hegysg s a Bodrogkz tallkozsnl formldott terleten ezernyi mdjt tallja az ember akr az utaz, akr az itt l - , hogy megismerje a termszetet, hogy kzel kerljn csodihoz. Az svnygyjt, a madarak letre kvncsi ornitolgus, a vadak csapsait jr erdszeret ember, a vzparton csendesen ldgl horgsz ppgy megtallja az rmt, mint a tjat gyalogosan, kenuval vagy kerkprral bebarangol turista. +A Zemplni-hegysg terletn a miocn kor, 15-20 milli ve mkdtt tzhnyk vulkanizmusnak anyaga s a hajdani vulknok lepuszttott, a termszet eri ltal alaktott formakincse uralkodik. Itt tallhat a mai Magyarorszg legmagasabb, legpebben megmaradt tzhny kpja, a tokaji Nagy-Kopasz, mely bszke vdbstyaknt rzi a Zemplni hegyvidket s a Tisza-Bodrog sszefolys trtnelmileg igen jelents terlett. A drmai hats csoportba rendezdtt Stor-hegyek is egy hajdani tzhny kalderjnak lepusztult maradvnyai, melynek mretei taln az Etna mai mreteivel vetekedtek. +A hegysget ltrehoz vulkanizmus a trsg mai kpre is rnyomja blyegt. A kzetek bnyszhat nyersanyagokban val gazdagsga s a vulkanikus talajokon term kivl minsg szl mindmig meghatrozza a tj embernek lett. A hegysg felsznt a szegly lejtin s szoknyjn a szl uralja, mg a hegyvidk bels terletein rintetlen erdk, kzpkori eredet fs legelk s rtek vltakoznak. +Az ide ltogat turista szinte napokig gyalogolhat anlkl, hogy a mai iparosodott trsadalom brmi jelt is tapasztalnia kellene. Olyan vidk ez, ahol a dli melegkedvel flra s a Krptok magashegyi nvnyei randevznak egymssal, ahol mg ma is viszonylagos zavartalansgban lhet az orszgosan is kiemelked vadllomny, ahol visszatelepltnek mondhat a hiz s a farkas s ahol vilgels muflon- s gmtrfek jellemzik az llomny minsgt. A terlet termszeti rtkeinek, gazdag nvny- s llatvilgnak vdelmben hoztk ltre a Zemplni Tjvdelmi Krzetet. \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.csproj new file mode 100644 index 0000000..491d697 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._20 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.sln new file mode 100644 index 0000000..4a24aac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/2023. 11. 20.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 20", "2023. 11. 20.csproj", "{ED572DB9-982B-4319-A176-034CB7B5303E}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {ED572DB9-982B-4319-A176-034CB7B5303E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {ED572DB9-982B-4319-A176-034CB7B5303E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {ED572DB9-982B-4319-A176-034CB7B5303E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {ED572DB9-982B-4319-A176-034CB7B5303E}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {9AD7C93C-B06A-4029-BF41-1B8352E29AEF} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Haromszog.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Haromszog.cs new file mode 100644 index 0000000..1f9a3dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Haromszog.cs @@ -0,0 +1,82 @@ +namespace _2023._11._20; + +class Haromszog +{ + private string csucsA; + private string csucsB; + private string csucsC; + + public Haromszog(string csucsA, string csucsB, string csucsC) + { + this.csucsA = csucsA; + this.csucsB = csucsB; + this.csucsC = csucsC; + } + + public double OldalA() + { + string[] koordinataB = csucsB.Split(","); + string[] koordinataC = csucsC.Split(","); + + if (true) + { + return Math.Round(Math.Sqrt(Math.Pow(double.Parse(koordinataB[0]) - double.Parse(koordinataC[0]), 2) + Math.Pow(double.Parse(koordinataB[1]) - double.Parse(koordinataC[1]), 2)), 2); + } + + } + + public double OldalB() + { + string[] koordinataA = csucsA.Split(","); + string[] koordinataC = csucsC.Split(","); + + return Math.Round(Math.Sqrt(Math.Pow(double.Parse(koordinataA[0]) - double.Parse(koordinataC[0]), 2) + Math.Pow(double.Parse(koordinataA[1]) - double.Parse(koordinataC[1]), 2)), 2); + } + + public double OldalC() + { + string[] koordinataA = csucsA.Split(","); + string[] koordinataB = csucsB.Split(","); + + return Math.Round(Math.Sqrt(Math.Pow(double.Parse(koordinataA[0]) - double.Parse(koordinataB[0]), 2) + Math.Pow(double.Parse(koordinataA[1]) - double.Parse(koordinataB[1]), 2)), 2); + } + + public double Kerulet() + { + return Math.Round(OldalA() + OldalB() + OldalC(), 2); + } + + public double Terulet() + { + double S = (OldalA() + OldalB() + OldalC()) / 2; + return Math.Round(Math.Sqrt(S * (S - OldalA()) * (S - OldalB()) * (S - OldalC())), 2); + } + + public string Szabalyos() + { + if (OldalA() == OldalB() || OldalA() == OldalC() || OldalB() == OldalC()) + { + return "egyenlőszárú!"; + } + + else if (OldalA() == OldalB() && OldalB() == OldalC()) + { + return "szabályos!"; + } + + else + { + return "nem szabályos, és nem is egyenlőszárú!"; + } + } + + public void Kiiras() + { + System.Console.WriteLine($"A(z) 'a' oldal hossza: {OldalA()}"); + System.Console.WriteLine($"A(z) 'b' oldal hossza: {OldalB()}"); + System.Console.WriteLine($"A(z) 'c' oldal hossza: {OldalC()}"); + System.Console.WriteLine($"A kerület hossza: {Kerulet()}"); + System.Console.WriteLine($"A terület hossza: {Terulet()}"); + System.Console.WriteLine($"A háromszög: {Szabalyos()}"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Program.cs new file mode 100644 index 0000000..1dbfd83 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/Program.cs @@ -0,0 +1,20 @@ +namespace _2023._11._20; + +class Program +{ + static void Main(string[] args) + { + System.Console.WriteLine("\nÍrd be a háromszög koordinátáit:"); + System.Console.WriteLine("Írd be a háromszög 'A' csúcsának koordinátáit:"); + string csucsA = Console.ReadLine(); + + System.Console.WriteLine("Írd be a háromszög 'B' csúcsának koordinátáit:"); + string csucsB = Console.ReadLine(); + + System.Console.WriteLine("Írd be a háromszög 'C' csúcsának koordinátáit:"); + string csucsC = Console.ReadLine(); + + Haromszog csucsok = new Haromszog(csucsA, csucsB, csucsC); + csucsok.Kiiras(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.deps.json new file mode 100644 index 0000000..79e7b57 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 20/1.0.0": { + "runtime": { + "2023. 11. 20.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 20/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.dll new file mode 100644 index 0000000..c0767b7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.exe new file mode 100644 index 0000000..f39fc88 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.pdb new file mode 100644 index 0000000..12e270b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/bin/Debug/net7.0/2023. 11. 20.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.dgspec.json new file mode 100644 index 0000000..c640a23 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj", + "projectName": "2023. 11. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/2023. 11. 20.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfo.cs new file mode 100644 index 0000000..b12b137 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 20")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 20")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 20")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfoInputs.cache new file mode 100644 index 0000000..1f949c4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +eae704a0b99bc3347d3f0cd9ffe4b3b79f6bc8e7 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..13e981f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._20 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.assets.cache new file mode 100644 index 0000000..cefbf91 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..9a80dae --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +8b43343076609e708deb4af569e23a003e2f1ba0 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..c0b3da4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\bin\Debug\net7.0\2023. 11. 20.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\bin\Debug\net7.0\2023. 11. 20.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\bin\Debug\net7.0\2023. 11. 20.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\bin\Debug\net7.0\2023. 11. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\bin\Debug\net7.0\2023. 11. 20.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\refint\2023. 11. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\2023. 11. 20.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 11. 20\obj\Debug\net7.0\ref\2023. 11. 20.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.dll new file mode 100644 index 0000000..c0767b7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.genruntimeconfig.cache new file mode 100644 index 0000000..fa64cf1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.genruntimeconfig.cache @@ -0,0 +1 @@ +b59e4099bde6dad39b4ea0184357f0081a8c9109 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.pdb new file mode 100644 index 0000000..12e270b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/2023. 11. 20.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..f39fc88 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/ref/2023. 11. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/ref/2023. 11. 20.dll new file mode 100644 index 0000000..a6e70b0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/ref/2023. 11. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/refint/2023. 11. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/refint/2023. 11. 20.dll new file mode 100644 index 0000000..a6e70b0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/Debug/net7.0/refint/2023. 11. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.assets.json new file mode 100644 index 0000000..d2e60bf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj", + "projectName": "2023. 11. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.nuget.cache new file mode 100644 index 0000000..025a286 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 11. 20/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "yKyvveEXptn2Xntkmjg7VdHrt5Amm2n56v5pyXah0+Eshs+jcAHQK/QLkodhf4ZpIj/aze6dxEgJBRjwsB3Jpw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 11. 20\\2023. 11. 20.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.csproj new file mode 100644 index 0000000..ba715ea --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._12._11 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.sln new file mode 100644 index 0000000..c0cd6c6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/2023. 12. 11.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 12. 11", "2023. 12. 11.csproj", "{68826B4E-97E5-4B0A-90CC-56C26D4D12A9}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {68826B4E-97E5-4B0A-90CC-56C26D4D12A9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {68826B4E-97E5-4B0A-90CC-56C26D4D12A9}.Debug|Any CPU.Build.0 = Debug|Any CPU + {68826B4E-97E5-4B0A-90CC-56C26D4D12A9}.Release|Any CPU.ActiveCfg = Release|Any CPU + {68826B4E-97E5-4B0A-90CC-56C26D4D12A9}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {D8C043BB-F5B0-4417-9E9E-8679805C8CAB} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Kor.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Kor.cs new file mode 100644 index 0000000..a854046 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Kor.cs @@ -0,0 +1,71 @@ +namespace _2023._12._11; + +public class Kor +{ + private double sugar; + private double x; + private double y; + + public Kor(double sugar, double x = 0, double y = 0) + { + this.sugar = sugar; + this.x = x; + this.y = y; + } + + public void nagyitas(double nagyit) + { + sugar = sugar * nagyit; + } + + public void kicsinyites(double kicsinyit) + { + sugar = sugar / kicsinyit; + } + + public double Kerulet() + { + return 2 * sugar * Math.PI; + } + + public double Terulet() + { + return Math.Pow(sugar, 2) * Math.PI; + } + + public double Sugar + { + get {return sugar;} + } + + public double X + { + get {return x;} + } + + public double Y + { + get {return Y;} + } +} + +public class Tesztelo +{ + public void Tesztelo() + { + Kor kor = new Kor(Math.PI); + System.Console.WriteLine($"Sugár: {kor.Sugar}"); + System.Console.WriteLine($"Középpont koordinátái: {kor.X}; {kor.Y}"); + System.Console.WriteLine($"Kerület: {kor.Kerulet} cm"); + System.Console.WriteLine($"Terület: {kor.Terulet} cm2"); + + kor.nagyitas(Math.E); + System.Console.WriteLine("Nagyítás:"); + System.Console.WriteLine($"Sugár: {kor.Sugar}"); + System.Console.WriteLine($"Középpont koordinátái: {kor.X}; {kor.Y}"); + System.Console.WriteLine($"Kerület: {kor} cm"); + System.Console.WriteLine($"Terület: {kor.Terulet} cm2"); + + + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Program.cs new file mode 100644 index 0000000..7d8c60d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/Program.cs @@ -0,0 +1,9 @@ +namespace _2023._12._11; + +class Program +{ + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..580b2c9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj", + "projectName": "2023. 12. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs new file mode 100644 index 0000000..cc6b27e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..c75a8a2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +144ede2bc384ea6c788ee1a4bc3859a259b7cd74 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b167736 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._12._11 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2023. 12. 11\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache new file mode 100644 index 0000000..1faf682 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.assets.json new file mode 100644 index 0000000..bf7e029 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj", + "projectName": "2023. 12. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.nuget.cache new file mode 100644 index 0000000..2b0306b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2023. 12. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "tarQdwp9bR4vDcMMMl91J31RQHdjZFumXmNtOtZwYA7C4Q/vx+YGmL5rosceAIc6Xs0DoQg9vQWjQQiftg0Fzw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2023. 12. 11\\2023. 12. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06.rar b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06.rar new file mode 100644 index 0000000..be8ecf3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06.rar differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.csproj new file mode 100644 index 0000000..0b750b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._01._06 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.sln new file mode 100644 index 0000000..a5c45c6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/2024. 01. 06.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 01. 06", "2024. 01. 06.csproj", "{DD6B52D0-B2BE-4C06-B195-EE41C0324817}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {DD6B52D0-B2BE-4C06-B195-EE41C0324817}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {DD6B52D0-B2BE-4C06-B195-EE41C0324817}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DD6B52D0-B2BE-4C06-B195-EE41C0324817}.Release|Any CPU.ActiveCfg = Release|Any CPU + {DD6B52D0-B2BE-4C06-B195-EE41C0324817}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {6738155D-30EE-4F10-B8C3-7CABE63CD6CD} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Felhasznalo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Felhasznalo.cs new file mode 100644 index 0000000..243fd70 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Felhasznalo.cs @@ -0,0 +1,25 @@ +namespace _2024._01._06; + +class Felhasznalo +{ + public string Felhasznalonev { get; set; } + public string Email { get; set; } + public string Jelszo { get; set; } + public string Szerep { get; set; } + + public Felhasznalo(string felhasznalonev, string email, string jelszo, string szerep) + { + Felhasznalonev = felhasznalonev; + Email = email; + Jelszo = jelszo; + Szerep = szerep; + } + + public void KiirAdatok() + { + Console.WriteLine($"Felhasználónév: {Felhasznalonev}"); + Console.WriteLine($"E-mail: {Email}"); + Console.WriteLine($"Jelszó: {Jelszo}"); + System.Console.WriteLine($"Szerep: {Szerep}"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Program.cs new file mode 100644 index 0000000..7978423 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Program.cs @@ -0,0 +1,151 @@ +namespace _2024._01._06; + +class Program +{ + static void Main(string[] args) + { + // System.Console.WriteLine("Adj meg egy felhasználónevet!"); + // string felhasznalonev = Console.ReadLine(); + + // System.Console.WriteLine("Adj meg egy email címet!"); + // string email = Console.ReadLine(); + + // System.Console.WriteLine("Adj meg egy jelszót!"); + // string jelszo = Console.ReadLine(); + + // System.Console.WriteLine("Adj hozzá egy szerepet! (Admin/Felhasználó)"); + // string szerep = Console.ReadLine(); + + // Felhasznalo felhasznalo = new Felhasznalo(felhasznalonev, email, jelszo, szerep); + + // felhasznalo.KiirAdatok(); + + // List termekeklist = new List(); + // List kglist = new List(); + + // System.Console.WriteLine("Adj meg egy terméket (alma, banán, körte, répa, burgonya)"); + // string termek = Console.ReadLine(); + // termekeklist.Add(termek); + + // System.Console.WriteLine("Hány kilót szeretnél venni belóle?"); + // double kg = double.Parse(Console.ReadLine()); + // kglist.Add(kg); + + // System.Console.WriteLine("Ennyit szeretnél venni (igen/nem)"); + // string valasz = Console.ReadLine(); + + + // if (valasz.ToLower() == "nem") + // { + // while (valasz.ToLower() == "nem") + // { + // System.Console.WriteLine("Adj meg egy terméket (alma, banán, körte, répa, burgonya)"); + // termek = Console.ReadLine(); + // termekeklist.Add(termek); + + // System.Console.WriteLine("Hány kilót szeretnél venni belóle?"); + // kg = double.Parse(Console.ReadLine()); + // kglist.Add(kg); + + // System.Console.WriteLine("Ennyit szeretnél venni? (igen/nem)"); + // valasz = Console.ReadLine(); + // if (valasz.ToLower() == "igen") + // { + // break; + // } + // } + // } + + // Termek termekek = new Termek(termekeklist, kglist); + // termekek.Kiiras(); + + + Dictionary> eremenyek = new Dictionary>(); + Dictionary belsodict = new Dictionary(); + + + + System.Console.WriteLine("Mi a tanuló keresztneve?"); + string tanulo = Console.ReadLine(); + + System.Console.WriteLine("Melyik tantárgyból érte el a jegyet?"); + string tantargy = Console.ReadLine(); + + System.Console.WriteLine("Hanyast ért el?"); + string jegy = Console.ReadLine(); + + System.Console.WriteLine("Ennyi tantárgyat szeretnél hozzáadni? (igen/nem)"); + string valasztantargy = Console.ReadLine(); + + belsodict.Add(tantargy, jegy); + + + while (valasztantargy.ToLower() == "nem") + { + System.Console.WriteLine("Melyik tantárgyból érte el a jegyet?"); + tantargy = Console.ReadLine(); + + System.Console.WriteLine("Hanyast ért el?"); + jegy = Console.ReadLine(); + + System.Console.WriteLine("Ennyi tantárgyat szeretnél hozzáadni? (igen/nem)"); + valasztantargy = Console.ReadLine(); + + belsodict.Add(tantargy, jegy); + } + + System.Console.WriteLine("Ennyi diákot szeretnél hozzáadni? (igen/nem)"); + string valasztanulo = Console.ReadLine(); + + Dictionary belsodictmasolat = new Dictionary(belsodict); + + eremenyek.Add(tanulo, belsodictmasolat); + belsodict.Clear(); + + foreach (var kvp in belsodict) + { + Console.WriteLine($"{kvp.Key}: {kvp.Value}"); + } + while (valasztanulo.ToLower() != "igen") + { + + System.Console.WriteLine("Mi a tanuló keresztneve?"); + tanulo = Console.ReadLine(); + + System.Console.WriteLine("Melyik tantárgyból érte el a jegyet?"); + tantargy = Console.ReadLine(); + + System.Console.WriteLine("Hanyast ért el?"); + jegy = Console.ReadLine(); + + System.Console.WriteLine("Ennyi tantárgyat szeretnél hozzáadni? (igen/nem)"); + valasztantargy = Console.ReadLine(); + + belsodict.Add(tantargy, jegy); + + while (valasztantargy.ToLower() == "nem") + { + System.Console.WriteLine("Melyik tantárgyból érte el a jegyet?"); + tantargy = Console.ReadLine(); + + System.Console.WriteLine("Hanyast ért el?"); + jegy = Console.ReadLine(); + + System.Console.WriteLine("Ennyi tantárgyat szeretnél hozzáadni? (igen/nem)"); + valasztantargy = Console.ReadLine(); + + belsodict.Add(tantargy, jegy); + } + + System.Console.WriteLine("Ennyi diákot szeretnél hozzáadni? (igen/nem)"); + valasztanulo = Console.ReadLine(); + + belsodictmasolat = new Dictionary(belsodict); + + eremenyek.Add(tanulo, belsodictmasolat); + } + + Tanulo tanulok = new Tanulo(eremenyek); + tanulok.Kiiras(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Termek.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Termek.cs new file mode 100644 index 0000000..8ac7d1f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/Termek.cs @@ -0,0 +1,27 @@ +namespace _2024._01._06; + +class Termek +{ + private List Termekek { get; set;} + private List Kg { get; set; } + + public Termek(List termekek, List kg) + { + Termekek = termekek; + Kg = kg; + } + + public void Kiiras() + { + string[] termekeklista = {"alma", "banán", "körte", "répa", "burgonya"}; + int [] arak = {350, 650, 500, 550, 280}; + int index = 0; + + foreach (var i in Termekek) + { + double ar = arak[Array.IndexOf(termekeklista, i)] * Kg[index]; + System.Console.WriteLine($"{i} ára: {ar} Ft"); + index++; + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.deps.json new file mode 100644 index 0000000..5f7b648 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 01. 06/1.0.0": { + "runtime": { + "2024. 01. 06.dll": {} + } + } + } + }, + "libraries": { + "2024. 01. 06/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.dll new file mode 100644 index 0000000..ebb39c9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.exe new file mode 100644 index 0000000..73d649f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.pdb new file mode 100644 index 0000000..b2ff170 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/bin/Debug/net7.0/2024. 01. 06.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.dgspec.json new file mode 100644 index 0000000..1674760 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj", + "projectName": "2024. 01. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/2024. 01. 06.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfo.cs new file mode 100644 index 0000000..1756578 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 01. 06")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 01. 06")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 01. 06")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfoInputs.cache new file mode 100644 index 0000000..5b67814 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +47268d890f55eadfcc4f4d6f9285b7b63f77a307 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..a895e5d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._01._06 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.assets.cache new file mode 100644 index 0000000..564c453 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..98bff20 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +02c345667ab657055f5ea7fbc5b83730265a3435 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..67d7b1f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\bin\Debug\net7.0\2024. 01. 06.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\bin\Debug\net7.0\2024. 01. 06.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\bin\Debug\net7.0\2024. 01. 06.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\bin\Debug\net7.0\2024. 01. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\bin\Debug\net7.0\2024. 01. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\refint\2024. 01. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\2024. 01. 06.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 01. 06\obj\Debug\net7.0\ref\2024. 01. 06.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.dll new file mode 100644 index 0000000..ebb39c9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.genruntimeconfig.cache new file mode 100644 index 0000000..df42d0e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.genruntimeconfig.cache @@ -0,0 +1 @@ +8b5b09a3ecda472ad7b240972554643c16cfa9af diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.pdb new file mode 100644 index 0000000..b2ff170 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/2024. 01. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..73d649f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/ref/2024. 01. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/ref/2024. 01. 06.dll new file mode 100644 index 0000000..6e3e036 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/ref/2024. 01. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/refint/2024. 01. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/refint/2024. 01. 06.dll new file mode 100644 index 0000000..6e3e036 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/Debug/net7.0/refint/2024. 01. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.assets.json new file mode 100644 index 0000000..c5d336f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj", + "projectName": "2024. 01. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.nuget.cache new file mode 100644 index 0000000..517a6dd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "UQj9ZpOchCz2x5LC39QjrAVOWStTuIUODZ1yKO4x9BLVIur/N1DUemyQBlPBkbmh+WXvNDrECEFgO74oVCoHgA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 01. 06\\2024. 01. 06.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/tanulo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/tanulo.cs new file mode 100644 index 0000000..b725a7d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 01. 06/tanulo.cs @@ -0,0 +1,23 @@ +namespace _2024._01._06; + +class Tanulo +{ + private Dictionary> Tanulok { get; set; } + + public Tanulo(Dictionary> tanulok) + { + Tanulok = tanulok; + } + + public void Kiiras() + { + foreach (var i in Tanulok.Keys) + { + foreach(var j in Tanulok[i].Keys) + { + System.Console.WriteLine($"{i} tanuló {j} tantárgyból elért jegye: {Tanulok[i][j]}"); + } + System.Console.WriteLine("------------------------------------------------------"); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/2023. 09. 04.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/2023. 09. 04.csproj new file mode 100644 index 0000000..c30fd23 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/2023. 09. 04.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._04 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/Program.cs new file mode 100644 index 0000000..84afa10 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/Program.cs @@ -0,0 +1,154 @@ +namespace _2023._09._04; +using System; + +class Program +{ + static void Main(string[] args) + { + Gyak4(); + } + + static void Gyak1() + { + int szam = 0; + int osszeg = 0; + int szorzat = 1; + + while (szam < 10) + { + if (szam % 2 == 0) + { + osszeg += szam; + } + + else + { + szorzat *= szam; + } + szam++; + } + System.Console.WriteLine($"A páros számok összege: {osszeg}"); + System.Console.WriteLine($"A páratlan számok szorzata: {szorzat}"); + } + + static void Gyak2() + { + System.Console.WriteLine("Írj egy számot!"); + int szam = int.Parse(Console.ReadLine()); + int jegy = 0; + + while (szam >= 1) + { + szam = szam / 10; + jegy++; + } + System.Console.WriteLine($"A szám jegyeinek száma: {jegy}"); + + } + + static void Gyak3() + { + int[] tomb = { }; + + for (int i = 1; i <= 20; i++) + { + if (i % 2 == 0) + { + tomb = tomb.Append(i).ToArray(); + } + } + foreach (int szam in tomb) + { + System.Console.WriteLine(szam); + } + } + + static void Gyak4() + { + System.Console.WriteLine("Mi a nemed? (f/n)"); + string nem = Console.ReadLine(); + + System.Console.WriteLine("Mekkora a testtömeged? (kg)"); + int tomeg = int.Parse(Console.ReadLine()); + + System.Console.WriteLine("Hány cm magas vagy?"); + double magassag = int.Parse(Console.ReadLine()); + + magassag = magassag / 100; + magassag = Math.Pow(magassag, 2); + double testomegindex = Math.Round(tomeg / magassag, 1); + System.Console.WriteLine(testomegindex); + + switch (nem.ToLower()) + { + case "f": + if (testomegindex < 18.1) + { + System.Console.WriteLine("Ön kórosan sovány. Javasoljuk, hogy keresse fel kezelőorvosát, aki mérlegelni fogja, hogy szükséges-e részletes kivizsgálás annak eldöntésére, hogy áll-e komolyabb betegség a kóros soványság hátterében."); + } + + else if (testomegindex >= 18.1 && testomegindex < 20.1) + { + System.Console.WriteLine("Ön sovány (avagy gracilis), ez leggyakrabban alkati sajátság, az átlagosnál vékonyabb csontozat és kisebb izomtömeg következménye."); + } + + else if (testomegindex >= 20.1 && testomegindex < 25.1) + { + System.Console.WriteLine("A mért érték alapján az Ön alkata normális, testsúlyfölöslege nincs. Fontos azonban tisztában lennie azzal, hogy az életkor előrehaladtával a test zsírtartalma nő, évente átlagosan 1/2 kg hízással számolhatunk. Ennek elkerülésére javasoljuk a rendszeres testmozgást és (legalább havonta) a testsúlymérést."); + } + + else if (testomegindex >= 25.1 && testomegindex < 30.1) + { + System.Console.WriteLine("Ön túlsúlyos: Lehet, hogy még egészségesnek érzi magát, azonban fokozott a kockázata a szív- és érrendszeri megbetegedések (magas vérnyomás, koszorúérbetegség, szívizominfarktus stb.), az agyi érbetegségek, az ízületi bántalmak, bizonyos rosszindulatú daganatok, valamint a csontritkulás és még számos más betegség kialakulásának."); + } + + else if (testomegindex >= 30.1 && testomegindex < 35.1) + { + System.Console.WriteLine("Ön el van hízva, fogynia kell. Az aerob sportok (úszás, kerékpározás egyértelműen javasoltak, az ízületeket túlzottan igénybevevő sportokat (pl. súlyemelés) kerülni kell."); + } + + else + { + System.Console.WriteLine("Ön súlyosan elhízott: kötelező fogyókúráznia. A fogyókúra mellett könnyű, fizikai sportokat javasolunk, szükség esetén gyógyszeres kezelés is szóba jön."); + } + break; + + case "n": + if (testomegindex < 16.6) + { + System.Console.WriteLine("Ön kórosan sovány. Javasoljuk, hogy keresse fel kezelőorvosát, aki mérlegelni fogja, hogy szükséges-e részletes kivizsgálás annak eldöntésére, hogy áll-e komolyabb betegség a kóros soványság hátterében."); + } + + else if (testomegindex >= 16.6 && testomegindex < 18.7) + { + System.Console.WriteLine("Ön sovány (avagy gracilis), ez leggyakrabban alkati sajátság, az átlagosnál vékonyabb csontozat és kisebb izomtömeg következménye."); + } + + else if (testomegindex >= 18.7 && testomegindex < 23.8) + { + System.Console.WriteLine("A mért érték alapján az Ön alkata normális, testsúlyfölöslege nincs. Fontos azonban tisztában lennie azzal, hogy az életkor előrehaladtával a test zsírtartalma nő, évente átlagosan 1/2 kg hízással számolhatunk. Ennek elkerülésére javasoljuk a rendszeres testmozgást és (legalább havonta) a testsúlymérést."); + } + + else if (testomegindex >= 23.8 && testomegindex < 28.8) + { + System.Console.WriteLine("Ön túlsúlyos: Lehet, hogy még egészségesnek érzi magát, azonban fokozott a kockázata a szív- és érrendszeri megbetegedések (magas vérnyomás, koszorúérbetegség, szívizominfarktus stb.), az agyi érbetegségek, az ízületi bántalmak, bizonyos rosszindulatú daganatok, valamint a csontritkulás és még számos más betegség kialakulásának."); + } + + else if (testomegindex >= 28.8 && testomegindex < 33.8) + { + System.Console.WriteLine("Ön el van hízva, fogynia kell. Az aerob sportok (úszás, kerékpározás egyértelműen javasoltak, az ízületeket túlzottan igénybevevő sportokat (pl. súlyemelés) kerülni kell."); + } + + else + { + System.Console.WriteLine("Ön súlyosan elhízott: kötelező fogyókúráznia. A fogyókúra mellett könnyű, fizikai sportokat javasolunk, szükség esetén gyógyszeres kezelés is szóba jön."); + } + break; + + default: + System.Console.WriteLine("Nem adtál meg megfelelő nemet!"); + break; + } + + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.deps.json new file mode 100644 index 0000000..80f0bdb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 04/1.0.0": { + "runtime": { + "2023. 09. 04.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 04/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.dll new file mode 100644 index 0000000..b944263 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.exe new file mode 100644 index 0000000..d2a0a46 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.pdb new file mode 100644 index 0000000..742ef42 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/bin/Debug/net7.0/2023. 09. 04.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.dgspec.json new file mode 100644 index 0000000..e907667 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj", + "projectName": "2023. 09. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/2023. 09. 04.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfo.cs new file mode 100644 index 0000000..f70b0ad --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 04")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 04")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 04")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfoInputs.cache new file mode 100644 index 0000000..469505f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +b5c17c5ddeb799e4ec8d951e78916d370f9ad98f diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5c16cf4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._04 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.assets.cache new file mode 100644 index 0000000..62926ff Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..0285886 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +b58ee91675d03eff6fd4080cf59b359a05a4562a diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..6c42dcc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\bin\Debug\net7.0\2023. 09. 04.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\bin\Debug\net7.0\2023. 09. 04.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\bin\Debug\net7.0\2023. 09. 04.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\bin\Debug\net7.0\2023. 09. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\bin\Debug\net7.0\2023. 09. 04.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\refint\2023. 09. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\2023. 09. 04.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 04\obj\Debug\net7.0\ref\2023. 09. 04.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.dll new file mode 100644 index 0000000..b944263 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.genruntimeconfig.cache new file mode 100644 index 0000000..83aa672 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.genruntimeconfig.cache @@ -0,0 +1 @@ +563d300c6c8844efa6be3b3d5ae1c3751ee4b591 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.pdb new file mode 100644 index 0000000..742ef42 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/2023. 09. 04.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..d2a0a46 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/ref/2023. 09. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/ref/2023. 09. 04.dll new file mode 100644 index 0000000..5f7d66a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/ref/2023. 09. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/refint/2023. 09. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/refint/2023. 09. 04.dll new file mode 100644 index 0000000..5f7d66a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/Debug/net7.0/refint/2023. 09. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.assets.json new file mode 100644 index 0000000..a1a5996 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj", + "projectName": "2023. 09. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.nuget.cache new file mode 100644 index 0000000..0f75dca --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 04/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "ysVSdmi6KddCYAf5nO1Omq5iBZBshTIL57en8RvDSXfxN877szIqyzQ8FZnTBhsOtqnVz998RZqUW9lEvoS4QA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 04\\2023. 09. 04.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/2023. 09. 06.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/2023. 09. 06.csproj new file mode 100644 index 0000000..1617fac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/2023. 09. 06.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._06 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/Program.cs new file mode 100644 index 0000000..9484cd9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/Program.cs @@ -0,0 +1,79 @@ +namespace _2023._09._06; +using System; +using System.Linq; + +class Program +{ + static void Feladat1() + { + const int m = 4; + const int n = 4; + + int[,] matrix = new int[m, n]; + Random r = new Random(); + for (int i = 0; i < m; i++) + { + for (int j = 0; j < n; j++) + { + matrix[i, j] = r.Next(1, 100); + } + } + System.Console.WriteLine("Az eredeti mátrix: "); + for (int i = 0; i < m; i++) + { + for (int j = 0; j < n; j++) + { + System.Console.SetCursorPosition(i * 10, 2 + (j * 2)); + System.Console.WriteLine(matrix[i, j]); + } + } + } + + static void Feladat2() + { + int[] tomb = new int[10]; + Random r = new Random(); + + for (int i = 0; i < 10; i++) + { + int szam = r.Next(1, 101); + tomb[i] = szam; + } + + Array.Sort(tomb); + + foreach (int elem in tomb) + { + System.Console.WriteLine(elem); + } + } + + static void Feladat3() + { + int[] tomb = {}; + + System.Console.WriteLine("Írj be számokat! Kilépni a nulla szám leütésével tudsz!"); + int szam = Convert.ToInt32(System.Console.ReadLine()); + do + { + tomb.Append(szam).ToArray(); + szam = Convert.ToInt32(System.Console.ReadLine()); + + } + + while (szam != 0); + + foreach (int elem in tomb) + { + System.Console.WriteLine(elem); + } + + System.Console.WriteLine($"A számok összege: {tomb.Sum()}"); + System.Console.WriteLine($"A számok átlaga: {tomb.Average()}"); + } + + static void Main(string[] args) + { + Feladat3(); + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.deps.json new file mode 100644 index 0000000..1c1bb47 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 06/1.0.0": { + "runtime": { + "2023. 09. 06.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 06/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.dll new file mode 100644 index 0000000..523ce9e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.exe new file mode 100644 index 0000000..e71b5c5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.pdb new file mode 100644 index 0000000..2c063d2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/bin/Debug/net7.0/2023. 09. 06.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.dgspec.json new file mode 100644 index 0000000..0790df0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj", + "projectName": "2023. 09. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/2023. 09. 06.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfo.cs new file mode 100644 index 0000000..270df5d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 06")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 06")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 06")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfoInputs.cache new file mode 100644 index 0000000..1d30bd3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a92eca796cf8e9c06648fbce3f889e2cb31dc223 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..c5e219c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._06 +build_property.ProjectDir = e:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.assets.cache new file mode 100644 index 0000000..82118f8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..baf6553 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +4522b1484706785d6d98a988b7de947b2e71b6db diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..c6a5000 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\bin\Debug\net7.0\2023. 09. 06.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\bin\Debug\net7.0\2023. 09. 06.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\bin\Debug\net7.0\2023. 09. 06.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\bin\Debug\net7.0\2023. 09. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\bin\Debug\net7.0\2023. 09. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\refint\2023. 09. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\2023. 09. 06.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 06\obj\Debug\net7.0\ref\2023. 09. 06.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.dll new file mode 100644 index 0000000..523ce9e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.genruntimeconfig.cache new file mode 100644 index 0000000..12e1ea4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.genruntimeconfig.cache @@ -0,0 +1 @@ +a29a64a6cdf6f45e441e71a5d3f27f6e2f21f6c9 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.pdb new file mode 100644 index 0000000..2c063d2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/2023. 09. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..e71b5c5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/ref/2023. 09. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/ref/2023. 09. 06.dll new file mode 100644 index 0000000..6d0df0e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/ref/2023. 09. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/refint/2023. 09. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/refint/2023. 09. 06.dll new file mode 100644 index 0000000..6d0df0e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/Debug/net7.0/refint/2023. 09. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.assets.json new file mode 100644 index 0000000..f91c2e7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj", + "projectName": "2023. 09. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.nuget.cache new file mode 100644 index 0000000..f6ccff0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 06/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "ym6Y0vvWPWW8W+6Tg5w+timp7L/4kRwJWsrD4Uo00Sczvd8nro8JTIwp8mrc+R0ajaWMz7bTbN4XMR2qeN3hXg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 06\\2023. 09. 06.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/2023. 09. 11.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/2023. 09. 11.csproj new file mode 100644 index 0000000..5330688 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/2023. 09. 11.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._11 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/Program.cs new file mode 100644 index 0000000..1a7d4f6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/Program.cs @@ -0,0 +1,87 @@ +namespace _2023._09._11; +using System; +using System.IO; +using System.Text; + +class Program +{ + + static void Feladat1() + { + char[] maganhangzok = { 'a', 'á', 'e', 'é', 'i', 'í', 'o', 'ó', 'ö', 'ő', 'u', 'ú', 'ü', 'ű' }; + char[] massalhangzok = { 'b', 'c', 'd', 'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'p', 'q', 'r', 's', 't', 'v', 'w', 'x', 'y', 'z' }; + char[] maganhangzok_n = { 'A', 'Á', 'E', 'É', 'I', 'Í', 'O', 'Ó', 'Ö', 'Ő', 'U', 'Ú', 'Ü', 'Ű' }; + char[] massalhangzok_n = { 'B', 'C', 'D', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'V', 'W', 'X', 'Y', 'Z' }; + char[] irasjelek = { '.', ',', '!', '?', ':', ';', '-', '_', '\"', '\'', '(', ')', '[', ']', '{', '}', '<', '>', '/', '\\', '|', '@', '#', '$', '%', '^', '&', '*' }; + char[] szamok = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' }; + + int[] betuSzamlalo = new int[256]; + // int maganhangzok_sz = 0; + // int massalhangzok_sz = 0; + // int irasjelek_sz = 0; + // int szamok_sz = 0; + + + string source_file = @"E:\Suli\12.b\Programozás (Tusjak Brigitta)\Források\neptun.txt"; + string new_file = @"E:\Suli\12.b\Programozás (Tusjak Brigitta)\Források\statisztika2.txt"; + + string text = File.ReadAllText(source_file); + // foreach (char i in text) + // { + // if (maganhangzok.Contains(i) || maganhangzok_n.Contains(i)) + // { + // maganhangzok_sz++; + // } + + // else if (massalhangzok.Contains(i) || massalhangzok_n.Contains(i)) + // { + // massalhangzok_sz++; + // } + + // else if (irasjelek.Contains(i)) + // { + // irasjelek_sz++; + // } + + // else if (szamok.Contains(i)) + // { + // szamok_sz++; + // } + // } + + foreach (char kar in text) + { + int asciiKod = (int)kar; + if (asciiKod < betuSzamlalo.Length) + { + betuSzamlalo[asciiKod]++; + } + } + + for (int i = 0; i < betuSzamlalo.Length; i++) + { + if (betuSzamlalo[i] > 0 && i != 32) + { + using(FileStream f = new FileStream(new_file, FileMode.Append, FileAccess.Write)) + { + StreamWriter w = new StreamWriter(f); + w.WriteLine($"'{(char)i}' karakter: {betuSzamlalo[i]} db"); + w.Close(); + } + } + } + + System.Console.WriteLine("Kész!"); + + // System.Console.WriteLine($"A magánhangzók száma: {maganhangzok_sz}"); + // System.Console.WriteLine($"A mássalhangzók száma: {massalhangzok_sz}"); + // System.Console.WriteLine($"A írásjelek száma: {irasjelek_sz}"); + // System.Console.WriteLine($"A számok száma: {szamok_sz}"); + + } + + static void Main(string[] args) + { + Feladat1(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.deps.json new file mode 100644 index 0000000..93d5190 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 11/1.0.0": { + "runtime": { + "2023. 09. 11.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 11/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.dll new file mode 100644 index 0000000..6e64bae Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.exe new file mode 100644 index 0000000..80db531 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.pdb new file mode 100644 index 0000000..04f9b91 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/bin/Debug/net7.0/2023. 09. 11.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..c402796 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj", + "projectName": "2023. 09. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/2023. 09. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfo.cs new file mode 100644 index 0000000..8dfc6e1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..51faa34 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +7b4608a76f68109d2d04fbbb7aa35c4c88bde338 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..1633340 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._11 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.assets.cache new file mode 100644 index 0000000..097b8f3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..0d637f1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +dc7e1d1482573579574ca4aa4911e9116c032121 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..dfeb8a5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\bin\Debug\net7.0\2023. 09. 11.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\bin\Debug\net7.0\2023. 09. 11.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\bin\Debug\net7.0\2023. 09. 11.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\bin\Debug\net7.0\2023. 09. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\bin\Debug\net7.0\2023. 09. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\refint\2023. 09. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\2023. 09. 11.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 11\obj\Debug\net7.0\ref\2023. 09. 11.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.dll new file mode 100644 index 0000000..6e64bae Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.genruntimeconfig.cache new file mode 100644 index 0000000..a95765b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.genruntimeconfig.cache @@ -0,0 +1 @@ +d701f0e679fc3ce0606f334f849d688434d75f18 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.pdb new file mode 100644 index 0000000..04f9b91 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/2023. 09. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..80db531 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/ref/2023. 09. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/ref/2023. 09. 11.dll new file mode 100644 index 0000000..7bef6a8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/ref/2023. 09. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/refint/2023. 09. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/refint/2023. 09. 11.dll new file mode 100644 index 0000000..7bef6a8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/Debug/net7.0/refint/2023. 09. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.assets.json new file mode 100644 index 0000000..bc9977d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj", + "projectName": "2023. 09. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.nuget.cache new file mode 100644 index 0000000..7f21fc6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "5+19Tz2qwvQoeUqTcU1eE8Fds4D5aAQSRE6Q1DEaQZfPMwvHuHrd3rrK8tL6nQHDJwv2i1O/Mxy/gQwsqjD/lw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 11\\2023. 09. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/2023. 09. 12.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/2023. 09. 12.csproj new file mode 100644 index 0000000..a0f57e4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/2023. 09. 12.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._12 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/Program.cs new file mode 100644 index 0000000..c8187f0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/Program.cs @@ -0,0 +1,32 @@ +namespace _2023._09._12; +using System; +using System.IO; + +class Program +{ + + static void Feladat1() + { + int sor = 0; + using (FileStream f = new FileStream(@"E:\Suli\12.b\Programozás (Tusjak Brigitta)\Források\sorok.txt", FileMode.Open, FileAccess.Read)) + { + StreamReader r = new StreamReader(f); + string text = r.ReadLine(); + System.Console.WriteLine(text); + + while(text != null) + { + text = r.ReadLine(); + sor++; + } + } + + System.Console.WriteLine($"A fájl sorainak száma: {sor}"); + + } + + static void Main(string[] args) + { + Feladat1(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.deps.json new file mode 100644 index 0000000..562adf2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 12/1.0.0": { + "runtime": { + "2023. 09. 12.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 12/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.dll new file mode 100644 index 0000000..147a1f7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.exe new file mode 100644 index 0000000..1a6a477 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.pdb new file mode 100644 index 0000000..5f1bad0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/bin/Debug/net7.0/2023. 09. 12.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.dgspec.json new file mode 100644 index 0000000..e94fd4f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj", + "projectName": "2023. 09. 12", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/2023. 09. 12.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfo.cs new file mode 100644 index 0000000..54c008e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 12")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 12")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 12")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfoInputs.cache new file mode 100644 index 0000000..dea3829 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +54bc35d3c0ebea3fd5f227a0a0f1eb84a6e8a432 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0c7db8c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._12 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.assets.cache new file mode 100644 index 0000000..bd63f90 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..cc88e8e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +ea689777b31651475219716a471d88a6e6fac617 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..4a22137 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\bin\Debug\net7.0\2023. 09. 12.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\bin\Debug\net7.0\2023. 09. 12.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\bin\Debug\net7.0\2023. 09. 12.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\bin\Debug\net7.0\2023. 09. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\bin\Debug\net7.0\2023. 09. 12.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\refint\2023. 09. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\2023. 09. 12.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 12\obj\Debug\net7.0\ref\2023. 09. 12.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.dll new file mode 100644 index 0000000..147a1f7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.genruntimeconfig.cache new file mode 100644 index 0000000..796f306 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.genruntimeconfig.cache @@ -0,0 +1 @@ +b144f4dce4d3510eb937100d2745a1d3703bd7b1 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.pdb new file mode 100644 index 0000000..5f1bad0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/2023. 09. 12.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..1a6a477 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/ref/2023. 09. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/ref/2023. 09. 12.dll new file mode 100644 index 0000000..fef4184 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/ref/2023. 09. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/refint/2023. 09. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/refint/2023. 09. 12.dll new file mode 100644 index 0000000..fef4184 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/Debug/net7.0/refint/2023. 09. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.assets.json new file mode 100644 index 0000000..06217c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj", + "projectName": "2023. 09. 12", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.nuget.cache new file mode 100644 index 0000000..85150f1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 12/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "xZy5pXEph/AzqCGsxVhOLJaEqMjDmqJ9qbN/Q58qlhQlZXaX53yNbNFKSUWVor/48LANCk5h6ZFf5tFKXlwNvw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 12\\2023. 09. 12.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/2023. 09. 18.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/2023. 09. 18.csproj new file mode 100644 index 0000000..51e7fa0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/2023. 09. 18.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._18 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/Program.cs new file mode 100644 index 0000000..53c9e4a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/Program.cs @@ -0,0 +1,133 @@ +namespace _2023._09._18; + +class Program +{ + + public static class GlobalData + { + public static int[] szamok = new int[100]; + } + + static void Feladat1() + { + Random rnd = new Random(); + int szam; + + for (int i = 0; i < GlobalData.szamok.Length; i++) + { + szam = rnd.Next(1, 501); + GlobalData.szamok[i] = szam; + } + } + + static void Osszeg() + { + int osszeg = 0; + + + foreach (int n in GlobalData.szamok) + { + osszeg += n; + } + + System.Console.WriteLine($"A tömb eleminek összege: {osszeg}."); + } + + static void Eldontes() + { + bool van100 = false; + + foreach(int n in GlobalData.szamok) + { + if (n == 100) + { + van100 = true; + } + } + + if (van100) + { + System.Console.WriteLine($"Van 100."); + } + + else + { + System.Console.WriteLine($"Nincs 100."); + } + } + + static void MaxMin() + { + int max = GlobalData.szamok[0]; + foreach(int n in GlobalData.szamok) + { + if (n > max) + { + max = n; + } + } + + System.Console.WriteLine($"A legnagyobb szám: {max}."); + + int min = GlobalData.szamok[0]; + foreach(int n in GlobalData.szamok) + { + if (n < max) + { + min = n; + } + } + + System.Console.WriteLine($"A legkisebb szám: {min}."); + } + + static void Kivalogatas() + { + foreach (int n in GlobalData.szamok) + { + if (n < 250) + { + System.Console.Write($"{n}, "); + } + } + } + + static void Egyszeru() + { + int szam = GlobalData.szamok[0]; + int indexn; + int indexszam; + int index = 0; + + foreach (int n in GlobalData.szamok) + { + + if (n < szam) + { + indexn = Array.IndexOf(GlobalData.szamok, n); + indexszam = Array.IndexOf(GlobalData.szamok, szam); + + GlobalData.szamok[indexszam] = n; + GlobalData.szamok[indexn] = szam; + + } + } + + foreach (int m in GlobalData.szamok) + { + System.Console.Write($"{m}, "); + } + + System.Console.WriteLine($"Kaka: {GlobalData.szamok.Min()}"); + } + + static void Main(string[] args) + { + Feladat1(); + // Osszeg(); + // Eldontes(); + // MaxMin(); + // Kivalogatas(); + Egyszeru(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.deps.json new file mode 100644 index 0000000..6897315 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 18/1.0.0": { + "runtime": { + "2023. 09. 18.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 18/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.dll new file mode 100644 index 0000000..a67f43d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.exe new file mode 100644 index 0000000..dee5b2f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.pdb new file mode 100644 index 0000000..98eb685 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/bin/Debug/net7.0/2023. 09. 18.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8410681 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj", + "projectName": "2023. 09. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/2023. 09. 18.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfo.cs new file mode 100644 index 0000000..b3511f4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfoInputs.cache new file mode 100644 index 0000000..ef2002d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +82c3cd5a98573bbd8d6338abaea789d437b95f00 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bf6eb9f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._18 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.assets.cache new file mode 100644 index 0000000..20f9521 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..ccd05da --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +dbbcb0938b3815a0b72428c6ea01525139cdc7bf diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..182a48e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\bin\Debug\net7.0\2023. 09. 18.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\bin\Debug\net7.0\2023. 09. 18.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\bin\Debug\net7.0\2023. 09. 18.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\bin\Debug\net7.0\2023. 09. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\bin\Debug\net7.0\2023. 09. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\refint\2023. 09. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\2023. 09. 18.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 18\obj\Debug\net7.0\ref\2023. 09. 18.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.dll new file mode 100644 index 0000000..a67f43d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.genruntimeconfig.cache new file mode 100644 index 0000000..d36d81e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.genruntimeconfig.cache @@ -0,0 +1 @@ +4f13fa020fa4645ec413e5581ed14353a1fe6011 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.pdb new file mode 100644 index 0000000..98eb685 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/2023. 09. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..dee5b2f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/ref/2023. 09. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/ref/2023. 09. 18.dll new file mode 100644 index 0000000..aab5ae2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/ref/2023. 09. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/refint/2023. 09. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/refint/2023. 09. 18.dll new file mode 100644 index 0000000..aab5ae2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/Debug/net7.0/refint/2023. 09. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.assets.json new file mode 100644 index 0000000..9991526 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj", + "projectName": "2023. 09. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.nuget.cache new file mode 100644 index 0000000..c51a26e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 18/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "Jk8fRrYtvsDv1WCA7VkMbHNkPklnvTWCHb2pFrKIFerPwW/e369EJzU0fsD73EqqxBIWpSKuLXB1yiyKuFThsw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 18\\2023. 09. 18.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/2023. 09. 20.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/2023. 09. 20.csproj new file mode 100644 index 0000000..0bd84a8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/2023. 09. 20.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._20 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/Program.cs new file mode 100644 index 0000000..cc20470 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/Program.cs @@ -0,0 +1,15 @@ +namespace _2023._09._20; + +class Program +{ + + static void Feladat() + { + + } + + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.dgspec.json new file mode 100644 index 0000000..64da7ed --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj", + "projectName": "2023. 09. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/2023. 09. 20.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfo.cs new file mode 100644 index 0000000..4f0c458 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 20")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 20")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 20")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfoInputs.cache new file mode 100644 index 0000000..355f936 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +b0833c2d6fab43141546aa3725d99ae18917264e diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..a158674 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._20 +build_property.ProjectDir = e:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 20\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.assets.cache new file mode 100644 index 0000000..2b2ef8f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/Debug/net7.0/2023. 09. 20.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.assets.json new file mode 100644 index 0000000..033cdb7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj", + "projectName": "2023. 09. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.nuget.cache new file mode 100644 index 0000000..85fab23 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 20/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "mxcqsAg/cEtmAXlsfocdyItl1qZcf7d2iQ0C9QLTh+mtWpD3pzD25ofFXjue4sci6TXGeUt7p7AuTE0Ry5x58A==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 20\\2023. 09. 20.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/2023. 09. 25.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/2023. 09. 25.csproj new file mode 100644 index 0000000..3e6b846 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/2023. 09. 25.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._25 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/Program.cs new file mode 100644 index 0000000..e739634 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/Program.cs @@ -0,0 +1,75 @@ +using System.Collections; + +namespace _2023._09._25; + +class Program +{ + + static void Feladat1() + { + ArrayList szamok = new ArrayList(); + Random rnd = new Random(); + + for (int i = 0; i < 100; i++) + { + szamok.Add(rnd.Next(1, 1001)); + } + + System.Console.WriteLine(szamok.Capacity); + System.Console.WriteLine(szamok.Count); + szamok.Sort(); + System.Console.WriteLine("-------------------------------"); + + foreach (int item in szamok) + { + System.Console.WriteLine(item); + } + + szamok.Reverse(); + System.Console.WriteLine("-------------------------------"); + + foreach (int item in szamok) + { + System.Console.WriteLine(item); + } + } + + static void Feladat2() + { + ArrayList ev = new ArrayList(); + ArrayList ho = new ArrayList(); + ArrayList nap = new ArrayList(); + ArrayList ora = new ArrayList(); + ArrayList perc = new ArrayList(); + + System.Console.WriteLine("Adja meg a dátumot:"); + string datum = Console.ReadLine(); + + do + { + try + { + Console.Clear(); + string[] elemek = datum.Split(":"); + ev.Add(elemek[0]); + ho.Add(elemek[1]); + nap.Add(elemek[2]); + ora.Add(elemek[3]); + perc.Add(elemek[4]); + + } + + catch (Exception e) + { + + } + } + + + } + + static void Main(string[] args) + { + Feladat2(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.deps.json new file mode 100644 index 0000000..e05886e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 25/1.0.0": { + "runtime": { + "2023. 09. 25.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 25/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.dll new file mode 100644 index 0000000..4026b71 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.exe new file mode 100644 index 0000000..43ed843 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.pdb new file mode 100644 index 0000000..29b07a9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/bin/Debug/net7.0/2023. 09. 25.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.dgspec.json new file mode 100644 index 0000000..fb665a1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj", + "projectName": "2023. 09. 25", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/2023. 09. 25.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfo.cs new file mode 100644 index 0000000..f36aa26 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 25")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 25")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 25")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfoInputs.cache new file mode 100644 index 0000000..3bee215 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c538ed79de2f06043f4e1fe9f4ad42d6b7ff73a6 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..13513ca --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._25 +build_property.ProjectDir = e:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.assets.cache new file mode 100644 index 0000000..53ef087 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..bb18a0f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +642c96842a0314524cbf988e7a5aa075bf73db1a diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..94707f7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\bin\Debug\net7.0\2023. 09. 25.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\bin\Debug\net7.0\2023. 09. 25.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\bin\Debug\net7.0\2023. 09. 25.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\bin\Debug\net7.0\2023. 09. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\bin\Debug\net7.0\2023. 09. 25.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\refint\2023. 09. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\2023. 09. 25.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 25\obj\Debug\net7.0\ref\2023. 09. 25.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.dll new file mode 100644 index 0000000..4026b71 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.genruntimeconfig.cache new file mode 100644 index 0000000..a7c4e45 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.genruntimeconfig.cache @@ -0,0 +1 @@ +2b906433bcd5643001cf9c32a397eb7c5fd6f134 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.pdb new file mode 100644 index 0000000..29b07a9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/2023. 09. 25.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..43ed843 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/ref/2023. 09. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/ref/2023. 09. 25.dll new file mode 100644 index 0000000..8175f02 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/ref/2023. 09. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/refint/2023. 09. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/refint/2023. 09. 25.dll new file mode 100644 index 0000000..8175f02 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/Debug/net7.0/refint/2023. 09. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.assets.json new file mode 100644 index 0000000..3654cad --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj", + "projectName": "2023. 09. 25", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.nuget.cache new file mode 100644 index 0000000..b7a41e9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 25/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "o1kKd0ku5uIP5u81/OZsTZ0O/2BogxGJXgLUcFpwsTrCYYAeRSTIkQNPsZMuR3AeVd9pMuVNzcu6FMmO4oYTrg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 25\\2023. 09. 25.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/2023. 09. 27.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/2023. 09. 27.csproj new file mode 100644 index 0000000..1e51e1c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/2023. 09. 27.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._27 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/Program.cs new file mode 100644 index 0000000..41b2218 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/Program.cs @@ -0,0 +1,43 @@ +using System.Collections; +using System.Linq; + +namespace _2023._09._27; + +class Program +{ + + static void Feladat() + { + string path = @"E:\Suli\12.b\Programozás (Tusjak Brigitta)\Források\tanulók.txt"; + List vnev = new List(); + List knev = new List(); + List magassag = new List(); + List suly = new List(); + List nem = new List(); + + using (FileStream f = new FileStream(path, FileMode.Open, FileAccess.Read)) + { + StreamReader r = new StreamReader(f); + string sor = r.ReadLine(); + + while (sor != null) + { + string[] elemek = sor.Split(";"); + vnev.Add(elemek[0]); + knev.Add(elemek[1]); + magassag.Add(elemek[2]); + suly.Add(elemek[3]); + nem.Add(elemek[4]); + sor = r.ReadLine(); + } + System.Console.WriteLine("Kész!"); + + } + + } + + static void Main(string[] args) + { + Feladat(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.deps.json new file mode 100644 index 0000000..b6cd401 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 27/1.0.0": { + "runtime": { + "2023. 09. 27.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 27/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.dll new file mode 100644 index 0000000..5cb2bdc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.exe new file mode 100644 index 0000000..f13296c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.pdb new file mode 100644 index 0000000..83dab80 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/bin/Debug/net7.0/2023. 09. 27.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.dgspec.json new file mode 100644 index 0000000..6dd51a2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj", + "projectName": "2023. 09. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/2023. 09. 27.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfo.cs new file mode 100644 index 0000000..48daccf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 27")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 27")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 27")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfoInputs.cache new file mode 100644 index 0000000..4bff0f3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +410c8256cc25565029bc3a7ce320a21553f75915 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3b06aa2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._27 +build_property.ProjectDir = e:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.assets.cache new file mode 100644 index 0000000..a2fab0c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..aad2e38 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +5a436c9c9c6d673188a9363211ff88bc87015250 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..96bf002 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\bin\Debug\net7.0\2023. 09. 27.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\bin\Debug\net7.0\2023. 09. 27.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\bin\Debug\net7.0\2023. 09. 27.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\bin\Debug\net7.0\2023. 09. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\bin\Debug\net7.0\2023. 09. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\refint\2023. 09. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\2023. 09. 27.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 27\obj\Debug\net7.0\ref\2023. 09. 27.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.dll new file mode 100644 index 0000000..5cb2bdc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.genruntimeconfig.cache new file mode 100644 index 0000000..d681ba8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.genruntimeconfig.cache @@ -0,0 +1 @@ +c7570b96b4cc739388605883c8964489ae6dc9b5 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.pdb new file mode 100644 index 0000000..83dab80 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/2023. 09. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..f13296c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/ref/2023. 09. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/ref/2023. 09. 27.dll new file mode 100644 index 0000000..48b6eec Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/ref/2023. 09. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/refint/2023. 09. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/refint/2023. 09. 27.dll new file mode 100644 index 0000000..48b6eec Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/Debug/net7.0/refint/2023. 09. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.assets.json new file mode 100644 index 0000000..0d4812b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj", + "projectName": "2023. 09. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.nuget.cache new file mode 100644 index 0000000..93d2fe0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 27/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "IgUj2P7QtLgH/PgTJ8RI0d3EVWzzy0gbVGwK7IeQYf3w2FcTRPmnmje8Djs2diE4R5zjnprVZ5eCTo3SbFDudg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 27\\2023. 09. 27.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/2023. 09. 30.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/2023. 09. 30.csproj new file mode 100644 index 0000000..addc13a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/2023. 09. 30.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._09._30 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/Program.cs new file mode 100644 index 0000000..4b1a4e3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/Program.cs @@ -0,0 +1,59 @@ +using System; +using System.Collections; +using System.Linq; + +namespace _2023._09._30; +class Program +{ + + static void Feladat() + { + string path = @"D:\Suli\12.b\Programozás (Tusjak Brigitta)\Források\tanulok.txt"; + + List vnev = new List(); + List knev = new List(); + List magassag = new List(); + List tomeg = new List(); + List fiu = new List(); + List lany = new List(); + + using(FileStream f = new FileStream(path, FileMode.Open, FileAccess.Read)) + { + StreamReader r = new StreamReader(f); + string sor = r.ReadLine(); + + while (sor != null) + { + string[] adat = sor.Split(";"); + vnev.Add(adat[0]); + knev.Add(adat[1]); + magassag.Add(Convert.ToInt32(adat[2])); + tomeg.Add(double.Parse(adat[3])); + if (adat[4] == "fiú") + { + fiu.Add(adat[4]); + } + + else + { + lany.Add(adat[4]); + } + sor = r.ReadLine(); + } + + System.Console.WriteLine($"A legducibb ember: {vnev[tomeg.IndexOf(tomeg.Max())]} {knev[tomeg.IndexOf(tomeg.Max())]}, tömege: {tomeg.Max()} kg."); + System.Console.WriteLine($"A legsoványabb ember: {vnev[tomeg.IndexOf(tomeg.Min())]} {knev[tomeg.IndexOf(tomeg.Min())]}, tömege: {tomeg.Min()} kg."); + System.Console.WriteLine($"A legmagasabb ember: {vnev[magassag.IndexOf(magassag.Max())]} {knev[magassag.IndexOf(magassag.Max())]}, tömege: {magassag.Max()} kg."); + System.Console.WriteLine($"A legalacsonyabb ember: {vnev[magassag.IndexOf(magassag.Min())]} {knev[magassag.IndexOf(magassag.Min())]}, tömege: {magassag.Min()} kg."); + System.Console.WriteLine($"A fiú tanulók száma: {fiu.Count}"); + System.Console.WriteLine($"A lány tanulók száma: {lany.Count}"); + + } + + } + + static void Main(string[] args) + { + Feladat(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.deps.json new file mode 100644 index 0000000..c5188b0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 09. 30/1.0.0": { + "runtime": { + "2023. 09. 30.dll": {} + } + } + } + }, + "libraries": { + "2023. 09. 30/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.dll new file mode 100644 index 0000000..655a47d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.exe new file mode 100644 index 0000000..142789e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.pdb new file mode 100644 index 0000000..3ad6108 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/bin/Debug/net7.0/2023. 09. 30.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.dgspec.json new file mode 100644 index 0000000..5bd32de --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.dgspec.json @@ -0,0 +1,61 @@ +{ + "format": 1, + "restore": { + "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj": {} + }, + "projects": { + "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj", + "projectName": "2023. 09. 30", + "projectPath": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj", + "packagesPath": "C:\\Users\\Ádám\\.nuget\\packages\\", + "outputPath": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádám\\AppData\\Roaming\\NuGet\\NuGet.Config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.props new file mode 100644 index 0000000..f84da73 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádám\.nuget\packages\ + PackageReference + 6.5.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/2023. 09. 30.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfo.cs new file mode 100644 index 0000000..279e7d9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 09. 30")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 09. 30")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 09. 30")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfoInputs.cache new file mode 100644 index 0000000..ec62667 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a00335135ea9fb7f60b713a854535e0721861988 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..de590a9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._09._30 +build_property.ProjectDir = D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.assets.cache new file mode 100644 index 0000000..6b742d6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.AssemblyReference.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.AssemblyReference.cache new file mode 100644 index 0000000..91a74f9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.AssemblyReference.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..fe0297d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +527fc72906dec4a24965a4ce6761f82100071d78 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..dbeb6c9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.csproj.FileListAbsolute.txt @@ -0,0 +1,15 @@ +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\bin\Debug\net7.0\2023. 09. 30.exe +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\bin\Debug\net7.0\2023. 09. 30.deps.json +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\bin\Debug\net7.0\2023. 09. 30.runtimeconfig.json +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\bin\Debug\net7.0\2023. 09. 30.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\bin\Debug\net7.0\2023. 09. 30.pdb +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.csproj.AssemblyReference.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.GeneratedMSBuildEditorConfig.editorconfig +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.AssemblyInfoInputs.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.AssemblyInfo.cs +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.csproj.CoreCompileInputs.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\refint\2023. 09. 30.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.pdb +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\2023. 09. 30.genruntimeconfig.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 09. 30\obj\Debug\net7.0\ref\2023. 09. 30.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.dll new file mode 100644 index 0000000..655a47d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.genruntimeconfig.cache new file mode 100644 index 0000000..30e735b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.genruntimeconfig.cache @@ -0,0 +1 @@ +1cc6796c9a832d4be291d1e4cdc71b920ee78736 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.pdb new file mode 100644 index 0000000..3ad6108 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/2023. 09. 30.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..142789e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/ref/2023. 09. 30.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/ref/2023. 09. 30.dll new file mode 100644 index 0000000..840a5d7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/ref/2023. 09. 30.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/refint/2023. 09. 30.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/refint/2023. 09. 30.dll new file mode 100644 index 0000000..840a5d7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/Debug/net7.0/refint/2023. 09. 30.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.assets.json new file mode 100644 index 0000000..e5b0236 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.assets.json @@ -0,0 +1,66 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádám\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj", + "projectName": "2023. 09. 30", + "projectPath": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj", + "packagesPath": "C:\\Users\\Ádám\\.nuget\\packages\\", + "outputPath": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádám\\AppData\\Roaming\\NuGet\\NuGet.Config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.203\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.nuget.cache new file mode 100644 index 0000000..c581cf1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 09. 30/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "S8bT2q2iWnvSOZy/LY9xK/GrfSx87HVCL0cgH3pYpmbz4VyTHBexcImTKT1EmsYYN0qpdvOc/3bnvnedvPNmzA==", + "success": true, + "projectFilePath": "D:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 09. 30\\2023. 09. 30.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/2023. 10. 11.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/2023. 10. 11.csproj new file mode 100644 index 0000000..7d81852 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/2023. 10. 11.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._10._11 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/Program.cs new file mode 100644 index 0000000..2dd2b23 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/Program.cs @@ -0,0 +1,40 @@ +// Első lépésnek hozzuk létre egy absztrakt Jarmu osztályt, amely tartalmazza a jármű általános tulajdonságait és metódusait + + +namespace _2023._10._11; + +abstract class Jarmu +{ + public string Marka {get; set;} + public int Ev {get; set;} + public abstract void Vezeto(); +} + +class Auto : Jarmu +{ + public int Loero {get; set;} + public override void Vezeto() + { + System.Console.WriteLine($"Az autó vezetés: {Marka}, Év: {Ev}, Lóerő: {Loero}"); + } +} + +class Kerekpar : Jarmu +{ + public int Sebesseg {get; set;} + public override void Vezeto() + { + System.Console.WriteLine($"Kerékpározás: {Marka}, Év: {Ev}, Sebesség: {Sebesseg}"); + } +} + +class Program +{ + static void Main(string[] args) + { + Auto auto1 = new Auto {Marka = "Suzuki", Ev = 2002, Loero = 997}; + auto1.Vezeto(); + Kerekpar bic1 = new Kerekpar {Marka = "Csepel", Ev = 2020, Sebesseg = 5}; + bic1.Vezeto(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.deps.json new file mode 100644 index 0000000..6b3fcb0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 10. 11/1.0.0": { + "runtime": { + "2023. 10. 11.dll": {} + } + } + } + }, + "libraries": { + "2023. 10. 11/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.dll new file mode 100644 index 0000000..5b2ce09 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.exe new file mode 100644 index 0000000..8389894 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.pdb new file mode 100644 index 0000000..0cdbe79 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/bin/Debug/net7.0/2023. 10. 11.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..e71fe82 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj", + "projectName": "2023. 10. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/2023. 10. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfo.cs new file mode 100644 index 0000000..d0a4de0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 10. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 10. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 10. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..323de40 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +5801008787abf3c72e66bd2a3e47f5b1eef6ce10 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..ec32257 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._10._11 +build_property.ProjectDir = e:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.assets.cache new file mode 100644 index 0000000..819b27d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..4ccbbc7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +55db85d17498f85c026c4f2b83a3c84bbd8b9e17 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..3793d02 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\bin\Debug\net7.0\2023. 10. 11.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\bin\Debug\net7.0\2023. 10. 11.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\bin\Debug\net7.0\2023. 10. 11.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\bin\Debug\net7.0\2023. 10. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\bin\Debug\net7.0\2023. 10. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\refint\2023. 10. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\2023. 10. 11.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 11\obj\Debug\net7.0\ref\2023. 10. 11.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.dll new file mode 100644 index 0000000..5b2ce09 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.genruntimeconfig.cache new file mode 100644 index 0000000..d725555 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.genruntimeconfig.cache @@ -0,0 +1 @@ +8b99b7abb2623a04786f86e76a5ba100c3fa9169 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.pdb new file mode 100644 index 0000000..0cdbe79 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/2023. 10. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..8389894 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/ref/2023. 10. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/ref/2023. 10. 11.dll new file mode 100644 index 0000000..1b28690 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/ref/2023. 10. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/refint/2023. 10. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/refint/2023. 10. 11.dll new file mode 100644 index 0000000..1b28690 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/Debug/net7.0/refint/2023. 10. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.assets.json new file mode 100644 index 0000000..9d919ea --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj", + "projectName": "2023. 10. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.nuget.cache new file mode 100644 index 0000000..5e635cd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "4qx2+uyHWwZrhaXbqOXD8iEL21wrEbkzHIsAmLbD12CNVzvfrebuHFMKjpfJqtnmcAlHJQmeLPalcLlZPNDXmA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 11\\2023. 10. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..8045513 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/FileContentIndex/21ae3126-bb20-49bd-abc7-c78230c9bbfd.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/FileContentIndex/21ae3126-bb20-49bd-abc7-c78230c9bbfd.vsidx new file mode 100644 index 0000000..4cc93d8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/FileContentIndex/21ae3126-bb20-49bd-abc7-c78230c9bbfd.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.futdcache.v2 new file mode 100644 index 0000000..9b21682 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.suo new file mode 100644 index 0000000..1fa78a3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/2023. 10. 16/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.metadata.v7.bin new file mode 100644 index 0000000..acf5547 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.projects.v7.bin new file mode 100644 index 0000000..0c3da00 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/.vs/ProjectEvaluation/2023. 10. 16.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.csproj new file mode 100644 index 0000000..3f8b280 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._10._16 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.sln new file mode 100644 index 0000000..c565b56 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/2023. 10. 16.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 10. 16", "2023. 10. 16.csproj", "{50314998-D2CC-4C55-A149-1C6B74F1ACEF}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {50314998-D2CC-4C55-A149-1C6B74F1ACEF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {50314998-D2CC-4C55-A149-1C6B74F1ACEF}.Debug|Any CPU.Build.0 = Debug|Any CPU + {50314998-D2CC-4C55-A149-1C6B74F1ACEF}.Release|Any CPU.ActiveCfg = Release|Any CPU + {50314998-D2CC-4C55-A149-1C6B74F1ACEF}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2A59DC3E-880B-4CF2-8B76-B84E4CCBF206} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/Program.cs new file mode 100644 index 0000000..9b77413 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/Program.cs @@ -0,0 +1,40 @@ +namespace _2023._10._16; + +public class MyClass +{ + private string message; + + //Paraméter nélküli konstruktor + + public MyClass() + { + message = "Üdvözöllek a MyClass osztályban!"; + } + + //Paraméteres konstruktor + + public MyClass(string customMessage) + { + message = customMessage; + } + + //Metódus, amely kiírja az üzenetet + + public void Uzenet() + { + System.Console.WriteLine($"Az üzenet: {message}"); + } +} +class Program +{ + static void Main(string[] args) + { + //Példány létrehozása a paraméter nélküli konstruktorral + MyClass mc1 = new MyClass(); + mc1.Uzenet(); + + //Példány létrehozása a paraméteres konstruktorral + MyClass mc2 = new MyClass("Ez egy egyedi üzenet!"); + mc2.Uzenet(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.deps.json new file mode 100644 index 0000000..4f23c08 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 10. 16/1.0.0": { + "runtime": { + "2023. 10. 16.dll": {} + } + } + } + }, + "libraries": { + "2023. 10. 16/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.dll new file mode 100644 index 0000000..c6e91a5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.exe new file mode 100644 index 0000000..f7123b5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.pdb new file mode 100644 index 0000000..cfe614c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/bin/Debug/net7.0/2023. 10. 16.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.dgspec.json new file mode 100644 index 0000000..00a7ad7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj", + "projectName": "2023. 10. 16", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/2023. 10. 16.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfo.cs new file mode 100644 index 0000000..86df2d5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfoInputs.cache new file mode 100644 index 0000000..705ee29 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +5da6775dc811de1c4cd83bfda5cb3131e6d71e9e diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cd2c556 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._10._16 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.assets.cache new file mode 100644 index 0000000..56e7d30 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..23dbf69 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +2df2730b3cbfac229936cd32e3823c1f19901f45 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..024a83b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.csproj.FileListAbsolute.txt @@ -0,0 +1,28 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\refint\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 16\obj\Debug\net7.0\ref\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\bin\Debug\net7.0\2023. 10. 16.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\refint\2023. 10. 16.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\2023. 10. 16.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 10. 16\obj\Debug\net7.0\ref\2023. 10. 16.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.dll new file mode 100644 index 0000000..c6e91a5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.genruntimeconfig.cache new file mode 100644 index 0000000..1f125fc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.genruntimeconfig.cache @@ -0,0 +1 @@ +b0462b752f979efccf88e01eac3fac0ca1627726 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.pdb new file mode 100644 index 0000000..cfe614c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/2023. 10. 16.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..f7123b5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/ref/2023. 10. 16.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/ref/2023. 10. 16.dll new file mode 100644 index 0000000..cd0df1a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/ref/2023. 10. 16.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/refint/2023. 10. 16.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/refint/2023. 10. 16.dll new file mode 100644 index 0000000..cd0df1a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/Debug/net7.0/refint/2023. 10. 16.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.assets.json new file mode 100644 index 0000000..3778315 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj", + "projectName": "2023. 10. 16", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.nuget.cache new file mode 100644 index 0000000..b262b61 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 16/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "8LhLn0rKcb4d+5y+xW99VIW0kvkLQPDxfFDvsAmfNITI2aDj28uomblZXLvexfRF9BJpoOq2CuofjVXcqXsiOQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 10. 16\\2023. 10. 16.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.csproj new file mode 100644 index 0000000..93af7dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._10._18 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.sln new file mode 100644 index 0000000..a5fbdb1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/2023. 10. 18.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 10. 18", "2023. 10. 18.csproj", "{9E5E8E7E-E583-49C4-9A10-DAA74E3F6B40}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {9E5E8E7E-E583-49C4-9A10-DAA74E3F6B40}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {9E5E8E7E-E583-49C4-9A10-DAA74E3F6B40}.Debug|Any CPU.Build.0 = Debug|Any CPU + {9E5E8E7E-E583-49C4-9A10-DAA74E3F6B40}.Release|Any CPU.ActiveCfg = Release|Any CPU + {9E5E8E7E-E583-49C4-9A10-DAA74E3F6B40}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {EC5E8CBE-7683-4037-A707-E9B8FCFC8C92} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/Program.cs new file mode 100644 index 0000000..f9c9efd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/Program.cs @@ -0,0 +1,33 @@ +namespace _2023._10._18; + +public class Gyak +{ + private static int gyakCount = 0; + + public Gyak() + { + gyakCount++; + } + + public static int getGyakCount() + { + return gyakCount; + } + + static Gyak() + { + System.Console.WriteLine("Statikus kontstruktor meghívva."); + } +} + +class Program +{ + static void Main(string[] args) + { + Gyak gyak1 = new Gyak(); + Gyak gyak2 = new Gyak(); + + int count = Gyak.getGyakCount(); + System.Console.WriteLine($"Az osztály példányainak száma: {count}"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.deps.json new file mode 100644 index 0000000..6b14690 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 10. 18/1.0.0": { + "runtime": { + "2023. 10. 18.dll": {} + } + } + } + }, + "libraries": { + "2023. 10. 18/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.dll new file mode 100644 index 0000000..10199e6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.exe new file mode 100644 index 0000000..934adeb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.pdb new file mode 100644 index 0000000..602d361 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/bin/Debug/net7.0/2023. 10. 18.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.dgspec.json new file mode 100644 index 0000000..08c78f9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj", + "projectName": "2023. 10. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/2023. 10. 18.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfo.cs new file mode 100644 index 0000000..2318789 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfoInputs.cache new file mode 100644 index 0000000..b44262f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +19507361081b83b72a6e28ebd43deef5f594d7b2 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..166f474 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._10._18 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.assets.cache new file mode 100644 index 0000000..b7426de Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..cc6eafd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +3730a5907385d92174f69f5ab48f5358159fb9e6 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..95967a0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\bin\Debug\net7.0\2023. 10. 18.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\bin\Debug\net7.0\2023. 10. 18.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\bin\Debug\net7.0\2023. 10. 18.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\bin\Debug\net7.0\2023. 10. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\bin\Debug\net7.0\2023. 10. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\refint\2023. 10. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\2023. 10. 18.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 18\obj\Debug\net7.0\ref\2023. 10. 18.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.dll new file mode 100644 index 0000000..10199e6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.genruntimeconfig.cache new file mode 100644 index 0000000..76ecaa0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.genruntimeconfig.cache @@ -0,0 +1 @@ +8ac8771c663607ca63fffa5f6272c1518ebe87ff diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.pdb new file mode 100644 index 0000000..602d361 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/2023. 10. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..934adeb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/ref/2023. 10. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/ref/2023. 10. 18.dll new file mode 100644 index 0000000..bc01ab5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/ref/2023. 10. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/refint/2023. 10. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/refint/2023. 10. 18.dll new file mode 100644 index 0000000..bc01ab5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/Debug/net7.0/refint/2023. 10. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.assets.json new file mode 100644 index 0000000..dfcdc16 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj", + "projectName": "2023. 10. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.nuget.cache new file mode 100644 index 0000000..802cae4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 18/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "pcGv/yMs9xG62iSTXVDrR337w8CJN7L5SinhImMIWN8fRuAOso7j+3qjUOGFGIVLdngraQHx8d70PAPGIqe3eQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 18\\2023. 10. 18.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.csproj new file mode 100644 index 0000000..b6d15d9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._10._25 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.sln new file mode 100644 index 0000000..8cd3426 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/2023. 10. 25.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 10. 25", "2023. 10. 25.csproj", "{C0F3DCE6-BA8D-48CE-A52A-EF14084BA936}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {C0F3DCE6-BA8D-48CE-A52A-EF14084BA936}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C0F3DCE6-BA8D-48CE-A52A-EF14084BA936}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C0F3DCE6-BA8D-48CE-A52A-EF14084BA936}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C0F3DCE6-BA8D-48CE-A52A-EF14084BA936}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {4CD1D6D2-FBDE-4035-8A2A-D4A28AD53DD1} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/Program.cs new file mode 100644 index 0000000..6b412a7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/Program.cs @@ -0,0 +1,30 @@ +namespace _2023._10._25; + +public static class IntKiterjesztesek +{ + public static int Factorial(this int szam) + { + if (szam < 0) + throw new ArgumentException("A negatív számoknak nincs faktoriálisa!"); + if (szam == 0 || szam == 1) + return 1; + + int result = 1; + for (int i = 2; i <= szam; i++) + { + result *= i; + } + return result; + } +} + +class Program +{ + static void Main(string[] args) + { + int szam = 5; + + int factorial = szam.Factorial(); + System.Console.WriteLine($"{szam} faktoriálisa {factorial}"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.deps.json new file mode 100644 index 0000000..d2fb842 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 10. 25/1.0.0": { + "runtime": { + "2023. 10. 25.dll": {} + } + } + } + }, + "libraries": { + "2023. 10. 25/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.dll new file mode 100644 index 0000000..ccd73cb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.exe new file mode 100644 index 0000000..eec084e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.pdb new file mode 100644 index 0000000..11cabcd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/bin/Debug/net7.0/2023. 10. 25.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.dgspec.json new file mode 100644 index 0000000..5e25be2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj", + "projectName": "2023. 10. 25", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/2023. 10. 25.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfo.cs new file mode 100644 index 0000000..8deb156 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 10. 25")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 10. 25")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 10. 25")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfoInputs.cache new file mode 100644 index 0000000..190e1af --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +b1d2e8aa7f24d9d01b4d74eaa457ef2d9122d654 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..4b59f94 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._10._25 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.assets.cache new file mode 100644 index 0000000..b40244b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..2539404 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +41c2f2c9c6b6fa443c6c4a7978fc0826efb18d93 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..4924224 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\bin\Debug\net7.0\2023. 10. 25.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\bin\Debug\net7.0\2023. 10. 25.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\bin\Debug\net7.0\2023. 10. 25.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\bin\Debug\net7.0\2023. 10. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\bin\Debug\net7.0\2023. 10. 25.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\refint\2023. 10. 25.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\2023. 10. 25.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 10. 25\obj\Debug\net7.0\ref\2023. 10. 25.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.dll new file mode 100644 index 0000000..ccd73cb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.genruntimeconfig.cache new file mode 100644 index 0000000..27df66f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.genruntimeconfig.cache @@ -0,0 +1 @@ +5814e195417eb5d33827907bc1d34a96b03d2ad7 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.pdb new file mode 100644 index 0000000..11cabcd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/2023. 10. 25.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..eec084e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/ref/2023. 10. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/ref/2023. 10. 25.dll new file mode 100644 index 0000000..87db820 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/ref/2023. 10. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/refint/2023. 10. 25.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/refint/2023. 10. 25.dll new file mode 100644 index 0000000..87db820 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/Debug/net7.0/refint/2023. 10. 25.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.assets.json new file mode 100644 index 0000000..26d9d4e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj", + "projectName": "2023. 10. 25", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.nuget.cache new file mode 100644 index 0000000..9cd1a8a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 10. 25/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "AKtNkRzkb0Jd4Z/6TSfpYmib0pFsBE10ZXF7S3xErN96GzhiVeanMND2P04YoHXgNyH2V+bBlso8iXJPLBEHyw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 10. 25\\2023. 10. 25.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..96d5a55 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/FileContentIndex/9685abb3-e672-4924-b5fa-9a83ea4a2901.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/FileContentIndex/9685abb3-e672-4924-b5fa-9a83ea4a2901.vsidx new file mode 100644 index 0000000..138ff64 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/FileContentIndex/9685abb3-e672-4924-b5fa-9a83ea4a2901.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.futdcache.v2 new file mode 100644 index 0000000..45d7461 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.suo new file mode 100644 index 0000000..23dae10 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/2023. 11. 06/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.metadata.v7.bin new file mode 100644 index 0000000..7ca67cc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.projects.v7.bin new file mode 100644 index 0000000..a97a757 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/.vs/ProjectEvaluation/2023. 11. 06.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.csproj new file mode 100644 index 0000000..37bcd23 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._06 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.sln new file mode 100644 index 0000000..abfda92 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/2023. 11. 06.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 06", "2023. 11. 06.csproj", "{99C8D92B-8277-4A17-99CE-822A86CCEE56}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {99C8D92B-8277-4A17-99CE-822A86CCEE56}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {99C8D92B-8277-4A17-99CE-822A86CCEE56}.Debug|Any CPU.Build.0 = Debug|Any CPU + {99C8D92B-8277-4A17-99CE-822A86CCEE56}.Release|Any CPU.ActiveCfg = Release|Any CPU + {99C8D92B-8277-4A17-99CE-822A86CCEE56}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {41DE16B2-D364-449D-AC2D-5403A9E0E0AE} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Program.cs new file mode 100644 index 0000000..3235a1b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Program.cs @@ -0,0 +1,48 @@ +namespace _2023._11._06; + +// public class AlkalmazasBeall +// { +// public string AppNev {get; private set;} +// public string Version {get; private set;} + +// private AlkalmazasBeall() +// { +// AppNev = "MyApp"; +// Version = "1.0"; +// } + +// private static AlkalmazásBeall pl; + +// public static AlkalmazasBeall GetPl() +// { +// if (pl == null) +// { +// pl = new AlkalmazasBeall(); +// } +// return pl; +// } +// } + + + + + +class Program +{ + static void Main(string[] args) + { + // AlkalmazasBeall settings = AlkalmazasBeall.GetPl(); + // System.Console.WriteLine($"Alkalmazás neve: {settings.AppNev}"); + // System.Console.WriteLine($"Verzió: {settings.Version}"); + + Szemely szemely = new Szemely(); + + szemely.Nev = "John"; + szemely.Kor = 30; + + System.Console.WriteLine($"Név: {szemely.Nev}"); + System.Console.WriteLine($"Életkor: {szemely.Kor}"); + + szemely.Kor = -5; + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Szemely.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Szemely.cs new file mode 100644 index 0000000..6f535c2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/Szemely.cs @@ -0,0 +1,30 @@ +namespace _2023._11._06; + +class Szemely +{ + private string nev; + private int kor; + + public string Nev + { + get {return nev;} + set {nev = value;} + } + + public int Kor + { + get {return kor;} + set + { + if (value >= 0) + { + kor = value; + } + + else + { + System.Console.WriteLine("Az életkor nem lehet negatív!"); + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.deps.json new file mode 100644 index 0000000..20ef839 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 06/1.0.0": { + "runtime": { + "2023. 11. 06.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 06/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.dll new file mode 100644 index 0000000..a46dd44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.exe new file mode 100644 index 0000000..20d9379 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.pdb new file mode 100644 index 0000000..7fae3c2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/bin/Debug/net7.0/2023. 11. 06.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.dgspec.json new file mode 100644 index 0000000..674bcb8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj", + "projectName": "2023. 11. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/2023. 11. 06.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfo.cs new file mode 100644 index 0000000..d4b7aee --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 06")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 06")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 06")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfoInputs.cache new file mode 100644 index 0000000..1681522 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +01ea31027ebea2d8f8a46d29be07d0ebdc9ba9f5 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..e30e237 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._06 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 06\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.assets.cache new file mode 100644 index 0000000..bbb0a9a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..6601580 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +b3b80e9fb8031a53fb5d7965367c75be1f5ca14d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..93d6707 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\bin\Debug\net7.0\2023. 11. 06.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\bin\Debug\net7.0\2023. 11. 06.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\bin\Debug\net7.0\2023. 11. 06.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\bin\Debug\net7.0\2023. 11. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\bin\Debug\net7.0\2023. 11. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\refint\2023. 11. 06.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\2023. 11. 06.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 06\obj\Debug\net7.0\ref\2023. 11. 06.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.dll new file mode 100644 index 0000000..a46dd44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.genruntimeconfig.cache new file mode 100644 index 0000000..5ce90f3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.genruntimeconfig.cache @@ -0,0 +1 @@ +b3195c8a38279bfa2d313ded4eacd975bb0d3a1a diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.pdb new file mode 100644 index 0000000..7fae3c2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/2023. 11. 06.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..20d9379 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/ref/2023. 11. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/ref/2023. 11. 06.dll new file mode 100644 index 0000000..58e7689 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/ref/2023. 11. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/refint/2023. 11. 06.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/refint/2023. 11. 06.dll new file mode 100644 index 0000000..58e7689 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/Debug/net7.0/refint/2023. 11. 06.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.assets.json new file mode 100644 index 0000000..e4cf0d6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj", + "projectName": "2023. 11. 06", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.nuget.cache new file mode 100644 index 0000000..bba83f4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 06/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "gHOe6t/mL4XNrJwNFzetcowVpNj2XhwRzqUSvOvnKJUNoFx7PJhWFL68ms8Kv2mTH2LtJR7+Osmsj9pGzrU9Lw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 06\\2023. 11. 06.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.csproj new file mode 100644 index 0000000..a77c7f7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._13 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.sln new file mode 100644 index 0000000..45ff969 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/2023. 11. 13.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 13", "2023. 11. 13.csproj", "{CA66D991-536C-4238-8939-90EB859B1CAF}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {CA66D991-536C-4238-8939-90EB859B1CAF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {CA66D991-536C-4238-8939-90EB859B1CAF}.Debug|Any CPU.Build.0 = Debug|Any CPU + {CA66D991-536C-4238-8939-90EB859B1CAF}.Release|Any CPU.ActiveCfg = Release|Any CPU + {CA66D991-536C-4238-8939-90EB859B1CAF}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {EC70693A-2A75-4DF0-851D-15CAAB69579F} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Adatok.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Adatok.cs new file mode 100644 index 0000000..931d83b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Adatok.cs @@ -0,0 +1,47 @@ +namespace _2023._11._13; + +class Adatok +{ + private string[] adat; + + //Konstruktor az osztály inicializálásához + public Adatok() + { + //Példányváltozó inicializálása + + adat = new string[5]; + } + + public string this[int index] + { + get + { + //Ellenőrzés, hogy az index a megfelelő taartományban van-e + + if (index >= 0 && index < adat.Length) + { + return adat[index]; + } + + else + { + return "Érvénytelen index"; + } + } + + set + { + //Ellenőrzés, hogy az index a megfelelő taartományban van-e + + if (index >= 0 && index < adat.Length) + { + adat[index] = value; + } + + else + { + System.Console.WriteLine("Érvénytelen index"); + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Program.cs new file mode 100644 index 0000000..3df4632 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Program.cs @@ -0,0 +1,58 @@ +namespace _2023._11._13; +class Program +{ + static void KiirasEgyen(Szemely person) + { + System.Console.WriteLine("Szeméy adatai:"); + person.Kiiras(); + } + + + static void Main(string[] args) + { + //Objektum létrehozása + + Adatok elemek = new Adatok(); + + + //Indexelés és érték beállítása + + // elemek[0] = "Első elem"; + // elemek[1] = "Második elem"; + // elemek[2] = "Harmadik elem"; + + + //Indexelés és érték kiolvasása + + // System.Console.WriteLine(elemek[0]); //Kiírja: Első elem + // System.Console.WriteLine(elemek[1]); //Kiírja: Második elem + // System.Console.WriteLine(elemek[2]); //Kiírja: Harmadik elem + // System.Console.WriteLine(elemek[5]); //Kiírja: Érvénytelen elem + + + //Példányosítunk egy Person objektumot + + Szemely egyen1 = new Szemely + { + Name = "Horváth Kálmán", + Age = 30 + }; + + //Hívjuk a függvényt és adjuk át a Person objektumot paraméterként + + KiirasEgyen(egyen1); + } +} + + +/* +Ebben a példában az Adatok osztály egy egyszerű adatszerkezetet modellez és tartalmaz egy indexdelő (indexer) függvényt +(this kulcsszóval), amely lehetővé teszi az osztály példányait, mintegy "tömbként" kezeli. Az indexelő függvényt lehetővé teszi az +értékek beállítását (set) és lekérdezését (get) az Adatok objektumon keresztül, mintha egy tömb lenne. +*/ + +/* +Ebben a példában van egy Szemely osztály, amely egy személyt reprezentál. Az osztálynak van egy Kiiras metódusa, amely kiírja a +személy adatait a konzolra. Ezen felül van egy KiirasEgyen függvény, amely egy Szemely típusú paramétert vár. A függvény egyszerűen +hívja a Kiiras metódust a kapott Szemely objektumon, így megjelenítve az adatokat. +*/ \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Szemely.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Szemely.cs new file mode 100644 index 0000000..ffd3b9f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/Szemely.cs @@ -0,0 +1,13 @@ +namespace _2023._11._13; + +class Szemely +{ + public string Name {get; set;} + + public int Age {get; set;} + + public void Kiiras() + { + System.Console.WriteLine($"Név: {Name}, Életkor: {Age}"); + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.deps.json new file mode 100644 index 0000000..9089e32 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 13/1.0.0": { + "runtime": { + "2023. 11. 13.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 13/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.dll new file mode 100644 index 0000000..04dbac7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.exe new file mode 100644 index 0000000..24cbfac Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.pdb new file mode 100644 index 0000000..756084c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/bin/Debug/net7.0/2023. 11. 13.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.dgspec.json new file mode 100644 index 0000000..3a9b443 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj", + "projectName": "2023. 11. 13", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/2023. 11. 13.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfo.cs new file mode 100644 index 0000000..354fb2f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 13")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 13")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 13")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfoInputs.cache new file mode 100644 index 0000000..e8d6f9f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +800825a5285bc4005a72f76102f245cb8a220190 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..1175a43 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._13 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.assets.cache new file mode 100644 index 0000000..6d52ad6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..81d5346 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +a700fb643cda0a166a361854624eca6aa50dc1c4 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..16cfb6b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\bin\Debug\net7.0\2023. 11. 13.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\bin\Debug\net7.0\2023. 11. 13.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\bin\Debug\net7.0\2023. 11. 13.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\bin\Debug\net7.0\2023. 11. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\bin\Debug\net7.0\2023. 11. 13.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\refint\2023. 11. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\2023. 11. 13.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 13\obj\Debug\net7.0\ref\2023. 11. 13.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.dll new file mode 100644 index 0000000..04dbac7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.genruntimeconfig.cache new file mode 100644 index 0000000..e74c614 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.genruntimeconfig.cache @@ -0,0 +1 @@ +4e0a5f087a3843c5deaa4485117171b03e6c3c6f diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.pdb new file mode 100644 index 0000000..756084c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/2023. 11. 13.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..24cbfac Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/ref/2023. 11. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/ref/2023. 11. 13.dll new file mode 100644 index 0000000..5fabe3a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/ref/2023. 11. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/refint/2023. 11. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/refint/2023. 11. 13.dll new file mode 100644 index 0000000..5fabe3a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/Debug/net7.0/refint/2023. 11. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.assets.json new file mode 100644 index 0000000..f2267c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj", + "projectName": "2023. 11. 13", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.nuget.cache new file mode 100644 index 0000000..dac479f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 13/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "khrXFeLQVsxqbxX2JePhiWNYdTiIT6Y2+L6iM3x59Cw1HJjMOgsKg6ptgRsNrScQ9rj4298Bbq70NEP+uM6XWA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 13\\2023. 11. 13.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.csproj new file mode 100644 index 0000000..427c3c5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._15 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.sln new file mode 100644 index 0000000..b1ce1b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/2023. 11. 15.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 15", "2023. 11. 15.csproj", "{D85DA576-FABE-4F21-ABE2-04BE67F45EFE}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {D85DA576-FABE-4F21-ABE2-04BE67F45EFE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D85DA576-FABE-4F21-ABE2-04BE67F45EFE}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D85DA576-FABE-4F21-ABE2-04BE67F45EFE}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D85DA576-FABE-4F21-ABE2-04BE67F45EFE}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {5D77486C-1BD3-42E5-A022-AB6C4CC642C3} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Lakas.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Lakas.cs new file mode 100644 index 0000000..d1977b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Lakas.cs @@ -0,0 +1,12 @@ +/* +Készítsen osztályt, mely lakóhelyiségek alapterületét, falfelütetét és a mennyezet méretét számolja ki a helyiség hossza, szélessége +és belmagassága alapján. Az osztály teszteléseként kérje be, hogy hány helyiségben szeretne az illető csempézni és festeni, majd kérje +be a helyiségek adatait. Végül adja meg, hogy mennyi csempére és falfestékre lesz szükség (az ajtók és ablakok méretét elhanyagoljuk) +*/ + +namespace _2023._11._15; + +class Lakas +{ + +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Program.cs new file mode 100644 index 0000000..a979914 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Program.cs @@ -0,0 +1,28 @@ +namespace _2023._11._15; + +class Program +{ + static void Main(string[] args) + { + // System.Console.WriteLine("Kérem adja meg az első operandust!"); + // double operand1 = double.Parse(Console.ReadLine()); + // System.Console.WriteLine("Kérem adja meg a második operandust!"); + // double operand2 = double.Parse(Console.ReadLine()); + // System.Console.WriteLine("Kérem adja meg az operátort!"); + // char operatorCode = char.Parse(Console.ReadLine()); + + // Szamolo szamolo = new Szamolo(operand1, operand2); + + // try + // { + // double eredmeny = szamolo.Kalk(operatorCode); + // Console.WriteLine($"Az eredmény: {eredmeny}"); + // } + + // catch (Exception ex) + // { + // System.Console.WriteLine($"Hiba történt: {ex.Message}"); + // } + + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Szamolo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Szamolo.cs new file mode 100644 index 0000000..44084a3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/Szamolo.cs @@ -0,0 +1,46 @@ +/* +Készítsünk egy Szamolo osztályt, mely tartalmazzon egy Kalk metódust, amely adott műveleti kódra elvégzi a két operandus +között a megfelelő műveleteket. A Kalk metódust az adatokat az osztály adattagjaiból vegye; ezeket a főprogram közvetlenül érje el. +A főprorgam ebből készítsen egy Kiszamol nevű példányt, kérjen be két operandust és egy műveleti kódot, végeztesse el a műveleteket, +majd írja ki az eredményt. +*/ + + +namespace _2023._11._15; + +class Szamolo +{ + private double operand1; + private double operand2; + + public Szamolo(double operand1, double operand2) + { + this.operand1 = operand1; + this.operand2 = operand2; + } + + public double Kalk(char operatorCode) + { + switch(operatorCode) + { + case '+': + return operand1 + operand2; + case '-': + return operand1 + operand2; + case '*': + return operand1 * operand2; + case '/': + if (operand2 != 0) + { + return operand1 / operand2; + } + + else + { + throw new DivideByZeroException("Nem értelmezhető a nullával való osztás!"); + } + default: + throw new ArgumentException("Nincs ilyen operátor!"); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.deps.json new file mode 100644 index 0000000..448b0d7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 15/1.0.0": { + "runtime": { + "2023. 11. 15.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 15/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.dll new file mode 100644 index 0000000..ee7453d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.exe new file mode 100644 index 0000000..f715e52 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.pdb new file mode 100644 index 0000000..fd74d33 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/bin/Debug/net7.0/2023. 11. 15.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.dgspec.json new file mode 100644 index 0000000..14429c9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj", + "projectName": "2023. 11. 15", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/2023. 11. 15.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfo.cs new file mode 100644 index 0000000..56fa528 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 15")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 15")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 15")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfoInputs.cache new file mode 100644 index 0000000..50b41ca --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +53ccaf7564cb86c5d9e34845b57d80d12e77a573 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d99fc39 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._15 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.assets.cache new file mode 100644 index 0000000..ca15787 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..d2867d9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +c8c8e5307be2a3d785b9b137901ea6d9d043320f diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..f20ac34 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\bin\Debug\net7.0\2023. 11. 15.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\bin\Debug\net7.0\2023. 11. 15.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\bin\Debug\net7.0\2023. 11. 15.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\bin\Debug\net7.0\2023. 11. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\bin\Debug\net7.0\2023. 11. 15.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\refint\2023. 11. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\2023. 11. 15.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\2023. 11. 15\obj\Debug\net7.0\ref\2023. 11. 15.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.dll new file mode 100644 index 0000000..ee7453d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.genruntimeconfig.cache new file mode 100644 index 0000000..a8c2c9d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.genruntimeconfig.cache @@ -0,0 +1 @@ +5ee426ac0e4b7b703d6d10d4f778d5ca5ae30e73 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.pdb new file mode 100644 index 0000000..fd74d33 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/2023. 11. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..f715e52 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/ref/2023. 11. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/ref/2023. 11. 15.dll new file mode 100644 index 0000000..380bf44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/ref/2023. 11. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/refint/2023. 11. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/refint/2023. 11. 15.dll new file mode 100644 index 0000000..380bf44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/Debug/net7.0/refint/2023. 11. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.assets.json new file mode 100644 index 0000000..395d0f3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj", + "projectName": "2023. 11. 15", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.nuget.cache new file mode 100644 index 0000000..ca62474 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 15/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "zEk57aYPqFPYz/Fhc3HeAQgEh019zn/K3ZGOBvnPOztthpkj23FlsCaOeK2O1AwLXioiz5V7QegiAai/JgRsZw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\2023. 11. 15\\2023. 11. 15.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.csproj new file mode 100644 index 0000000..b203534 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._27 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.sln new file mode 100644 index 0000000..58132f2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/2023. 11. 27.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 27", "2023. 11. 27.csproj", "{4B282A4B-AB33-4822-A7E8-6255DB9F632B}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {4B282A4B-AB33-4822-A7E8-6255DB9F632B}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {4B282A4B-AB33-4822-A7E8-6255DB9F632B}.Debug|Any CPU.Build.0 = Debug|Any CPU + {4B282A4B-AB33-4822-A7E8-6255DB9F632B}.Release|Any CPU.ActiveCfg = Release|Any CPU + {4B282A4B-AB33-4822-A7E8-6255DB9F632B}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {E7ECF36B-E6DC-4C7C-BF1E-7CCFF723D915} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Allat.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Allat.cs new file mode 100644 index 0000000..bb0d278 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Allat.cs @@ -0,0 +1,33 @@ +namespace _2023._11._27; + +class Allat +{ + public class Allatok + { + public void Eszik() + { + System.Console.WriteLine("Az állat eszik."); + } + + public void Alszik() + { + System.Console.WriteLine("Az állat alszik."); + } + } + + public class Kutya: Allatok + { + public void Ugat() + { + System.Console.WriteLine("A kutya ugat."); + } + } + + public class Cica: Allatok + { + public void Nyavog() + { + System.Console.WriteLine("A macska nyávog."); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Program.cs new file mode 100644 index 0000000..3a4ecf0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/Program.cs @@ -0,0 +1,18 @@ +namespace _2023._11._27; + + + +class Program +{ + static void Main(string[] args) + { + Allat.Kutya kutya = new Allat.Kutya(); + Allat.Cica macska = new Allat.Cica(); + + kutya.Eszik(); + macska.Alszik(); + + kutya.Ugat(); + macska.Nyavog(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.deps.json new file mode 100644 index 0000000..c8583bb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 27/1.0.0": { + "runtime": { + "2023. 11. 27.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 27/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.dll new file mode 100644 index 0000000..2b37bda Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.exe new file mode 100644 index 0000000..4427095 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.pdb new file mode 100644 index 0000000..f739fd5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/bin/Debug/net7.0/2023. 11. 27.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.dgspec.json new file mode 100644 index 0000000..b24f957 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj", + "projectName": "2023. 11. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/2023. 11. 27.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfo.cs new file mode 100644 index 0000000..f72cbef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 27")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 27")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 27")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfoInputs.cache new file mode 100644 index 0000000..b7219f6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +982bceef332c0ec36b5177bf53f3cb9878bfe5fd diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5464fcd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._27 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.assets.cache new file mode 100644 index 0000000..11cdd88 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..69f88de --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +7fc672d76925e460422ac5568caa8ac71d11ab2b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..5f2dabd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\bin\Debug\net7.0\2023. 11. 27.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\bin\Debug\net7.0\2023. 11. 27.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\bin\Debug\net7.0\2023. 11. 27.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\bin\Debug\net7.0\2023. 11. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\bin\Debug\net7.0\2023. 11. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\refint\2023. 11. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\2023. 11. 27.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 27\obj\Debug\net7.0\ref\2023. 11. 27.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.dll new file mode 100644 index 0000000..2b37bda Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.genruntimeconfig.cache new file mode 100644 index 0000000..5cf3d36 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.genruntimeconfig.cache @@ -0,0 +1 @@ +3688fbfe1fa4e517bb96a1a5f5219227dd10a655 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.pdb new file mode 100644 index 0000000..f739fd5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/2023. 11. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..4427095 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/ref/2023. 11. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/ref/2023. 11. 27.dll new file mode 100644 index 0000000..0041d09 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/ref/2023. 11. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/refint/2023. 11. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/refint/2023. 11. 27.dll new file mode 100644 index 0000000..0041d09 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/Debug/net7.0/refint/2023. 11. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.assets.json new file mode 100644 index 0000000..98c009b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj", + "projectName": "2023. 11. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.nuget.cache new file mode 100644 index 0000000..f6132ac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 27/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "aCE+CMq2mLIzic2x4LYo1pbL3eZihrKOSe6hSfUYZ9LkB+oOfkGhiw3AbYj/YneaOV0F97uBcq+TNeRSWC0XjQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 27\\2023. 11. 27.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..18c0038 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/FileContentIndex/62143e88-ecb6-42cc-85ba-6d1be546f7b7.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/FileContentIndex/62143e88-ecb6-42cc-85ba-6d1be546f7b7.vsidx new file mode 100644 index 0000000..339fcde Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/FileContentIndex/62143e88-ecb6-42cc-85ba-6d1be546f7b7.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.futdcache.v2 new file mode 100644 index 0000000..57c165d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.suo new file mode 100644 index 0000000..f509120 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/2023. 11. 29/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.metadata.v7.bin new file mode 100644 index 0000000..ec61c26 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.projects.v7.bin new file mode 100644 index 0000000..cbfdada Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/.vs/ProjectEvaluation/2023. 11. 29.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.csproj new file mode 100644 index 0000000..eb8dad2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._11._29 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.sln new file mode 100644 index 0000000..52af321 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/2023. 11. 29.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 11. 29", "2023. 11. 29.csproj", "{69998774-A794-4B0F-899F-4C31B61F140C}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {69998774-A794-4B0F-899F-4C31B61F140C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {69998774-A794-4B0F-899F-4C31B61F140C}.Debug|Any CPU.Build.0 = Debug|Any CPU + {69998774-A794-4B0F-899F-4C31B61F140C}.Release|Any CPU.ActiveCfg = Release|Any CPU + {69998774-A794-4B0F-899F-4C31B61F140C}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {5B10781E-7237-402C-8087-01483C604D3B} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Alak.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Alak.cs new file mode 100644 index 0000000..b0e31f7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Alak.cs @@ -0,0 +1,33 @@ +namespace _2023._11._29; + +public class Alak +{ + public virtual void Rajzol() + { + System.Console.WriteLine("Alakzat rajzolása."); + } +} + +public class Kor: Alak +{ + public override void Rajzol() + { + System.Console.WriteLine("Kör rajzolása."); + } +} + +public class Teglalap: Alak +{ + public override void Rajzol() + { + System.Console.WriteLine("Téglalap rajzolása."); + } +} + +/* +Ebben a példában az Alak szülőosztály tartalmaz egy Rajzol metódust, amely a virtual kulcsszóval lett megjelölve. A Kor és Teglalap +osztályok felülírják (override) ezt a metódust, és saját specifikus rajzolási műveletet végeznek. + +A Main metódusban példányosítunk egy Alak, egy Kor, és egy Teglalap objektumot + +*/ \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Program.cs new file mode 100644 index 0000000..7d2f073 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/Program.cs @@ -0,0 +1,15 @@ +namespace _2023._11._29; + +class Program +{ + static void Main(string[] args) + { + Alak alak = new Alak(); + Kor kor = new Kor(); + Teglalap teglalap = new Teglalap(); + + alak.Rajzol(); + kor.Rajzol(); + teglalap.Rajzol(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.deps.json new file mode 100644 index 0000000..a5d3e25 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2023. 11. 29/1.0.0": { + "runtime": { + "2023. 11. 29.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 29/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.dll new file mode 100644 index 0000000..03be42d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.exe new file mode 100644 index 0000000..e82fb20 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.pdb new file mode 100644 index 0000000..4b12ee9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/bin/Debug/net7.0/2023. 11. 29.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.dgspec.json new file mode 100644 index 0000000..1b0a2ce --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj", + "projectName": "2023. 11. 29", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/2023. 11. 29.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfo.cs new file mode 100644 index 0000000..3aa5e2f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 29")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 29")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 29")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfoInputs.cache new file mode 100644 index 0000000..e529e24 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c2839e1615b8caefc8879c7804c841a0706e6450 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..a2c56c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._29 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.assets.cache new file mode 100644 index 0000000..e051387 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..ab12e7b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +8b944032a6180cfc22c56462fbe33e03a5e47bb2 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..8c748e2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\bin\Debug\net7.0\2023. 11. 29.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\bin\Debug\net7.0\2023. 11. 29.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\bin\Debug\net7.0\2023. 11. 29.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\bin\Debug\net7.0\2023. 11. 29.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\bin\Debug\net7.0\2023. 11. 29.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\refint\2023. 11. 29.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\2023. 11. 29.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 29\obj\Debug\net7.0\ref\2023. 11. 29.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.dll new file mode 100644 index 0000000..03be42d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.genruntimeconfig.cache new file mode 100644 index 0000000..28c7f1c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.genruntimeconfig.cache @@ -0,0 +1 @@ +4588f2d20203ff50a9ef5728da2dff0deceb5e76 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.pdb new file mode 100644 index 0000000..4b12ee9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/2023. 11. 29.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..e82fb20 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/ref/2023. 11. 29.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/ref/2023. 11. 29.dll new file mode 100644 index 0000000..12f2432 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/ref/2023. 11. 29.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/refint/2023. 11. 29.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/refint/2023. 11. 29.dll new file mode 100644 index 0000000..12f2432 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/Debug/net7.0/refint/2023. 11. 29.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.assets.json new file mode 100644 index 0000000..e5b3dee --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj", + "projectName": "2023. 11. 29", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.nuget.cache new file mode 100644 index 0000000..3a21ab1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 29/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "J6oUdIaAQKs14ll+DKA2AtHUUX/MGatRchvUY3DflLtWljEFmB0FygTw8dm6aggMsNoSbLoicJWKuqGJ5t/xCA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 29\\2023. 11. 29.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..56969d4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/FileContentIndex/95823fcd-9e84-4966-91a5-3277b6e57c14.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/FileContentIndex/95823fcd-9e84-4966-91a5-3277b6e57c14.vsidx new file mode 100644 index 0000000..405d420 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/FileContentIndex/95823fcd-9e84-4966-91a5-3277b6e57c14.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.futdcache.v2 new file mode 100644 index 0000000..b726de4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.suo new file mode 100644 index 0000000..40edc8c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/2023. 12. 04/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.metadata.v7.bin new file mode 100644 index 0000000..fdee4c2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.projects.v7.bin new file mode 100644 index 0000000..e669221 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/.vs/ProjectEvaluation/2023. 12. 04.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.csproj new file mode 100644 index 0000000..009b201 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._12._04 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.sln new file mode 100644 index 0000000..507674b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/2023. 12. 04.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 12. 04", "2023. 12. 04.csproj", "{E3A213AF-19DE-4144-9723-DE6334AC39A3}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {E3A213AF-19DE-4144-9723-DE6334AC39A3}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E3A213AF-19DE-4144-9723-DE6334AC39A3}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E3A213AF-19DE-4144-9723-DE6334AC39A3}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E3A213AF-19DE-4144-9723-DE6334AC39A3}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {B5F2D106-9AE3-4188-AF9D-1390D6FA423F} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/Program.cs new file mode 100644 index 0000000..e442c01 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/Program.cs @@ -0,0 +1,9 @@ +namespace _2023._12._04; + +class Program +{ + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.dgspec.json new file mode 100644 index 0000000..7839f4e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj", + "projectName": "2023. 12. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/2023. 12. 04.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfo.cs new file mode 100644 index 0000000..c730f40 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 12. 04")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 12. 04")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 12. 04")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfoInputs.cache new file mode 100644 index 0000000..d9d58c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +84d347b0551854f1b198626f4c7bb6da01d15540 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..9f07d71 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._12._04 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 12. 04\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.assets.cache new file mode 100644 index 0000000..c130744 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/Debug/net7.0/2023. 12. 04.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.assets.json new file mode 100644 index 0000000..a815cf4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj", + "projectName": "2023. 12. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.nuget.cache new file mode 100644 index 0000000..d6dabd3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "3SLgK8jM1KfGref6NmKzJzVEzJN+MiT80OLCnIg0D2OgeOoF+S0WNq9qbeXj9B18rgwhbsjNaEQzzt9CT/3Hnw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 04\\2023. 12. 04.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/proga_hazi.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/proga_hazi.txt new file mode 100644 index 0000000..0276802 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 04/proga_hazi.txt @@ -0,0 +1,195 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Runtime.InteropServices; +using System.Runtime.Remoting.Metadata.W3cXsd2001; +using System.Text; +using System.Threading.Tasks; + +namespace hazi_generator +{ + internal class Program + { + static void eldontes(char valasz) + { + if (valasz == 'a') + { + alapSIM(); + } + else + { + PUKosSIM(); + } + } + + static void PUKosSIM() + { + PUK[] listaPUK = new PUK[3]; + Random r = new Random(); + + for (int i = 0; i < 3; i++) + { + int Sorszam = r.Next(10000000, 99999999); + PUK PUKosSIM = new PUK(); + PUKosSIM.AlapSim(Sorszam); + listaPUK.SetValue(value: PUKosSIM, index: i); + } + + foreach (SIM item in listaPUK) + { + Console.WriteLine(item.Sorszam); + Console.WriteLine(item.Pinkod); + Console.WriteLine(); + } + + for (int i = 0; i < listaPUK.Length; i++) + { + Console.WriteLine("Kérem adja meg a PIN kódot (3 lehetőség)"); + for (int j = 0; j < 3; j++) + { + listaPUK[i].SimLetiltas(listaPUK[i].Sorszam, listaPUK[i].Pinkod); + if (listaPUK[i].Tudta) + { + break; + } + } + if (listaPUK[i].Tudta) + { + Console.WriteLine("A SIM feloldva"); + } + else + { + Console.WriteLine("A SIM letiltva"); + string puk = Convert.ToString(r.Next(1000, 9999)); + Console.WriteLine($"A PUK-kódja: {puk}"); + listaPUK[i].Puk(puk); + } + } + + Console.ReadKey(); + + } + + static void alapSIM() + { + SIM[] listaSIM = new SIM[3]; + Random r = new Random(); + + for (int i = 0; i < 3; i++) + { + int Sorszam = r.Next(10000000, 99999999); + SIM alapSim = new SIM(); + alapSim.AlapSim(Sorszam); + listaSIM.SetValue(value: alapSim, index: i); + } + + foreach (SIM item in listaSIM) + { + Console.WriteLine(item.Sorszam); + Console.WriteLine(item.Pinkod); + Console.WriteLine(); + } + + for (int i = 0; i < listaSIM.Length; i++) + { + Console.WriteLine("Kérem adja meg a PIN kódot (3 lehetőség)"); + for (int j = 0; j < 3; j++) + { + listaSIM[i].SimLetiltas(listaSIM[i].Sorszam, listaSIM[i].Pinkod); + if (listaSIM[i].Tudta) + { + break; + } + } + if (listaSIM[i].Tudta) + { + Console.WriteLine("A SIM feloldva"); + } + else + { + Console.WriteLine("A SIM letiltva"); + } + } + + Console.ReadKey(); + } + + static void Main() + { + Console.WriteLine("Milyen típusú SIM kártyákat szeretne létrehozni (Alap -> a / PUK-kóddal rendelkezőt -> p): "); + char valasz = Convert.ToChar(Console.ReadLine()); + eldontes(valasz); + } + } +} + +using System; +using System.Collections.Generic; +using System.Linq; +using System.Runtime.InteropServices; +using System.Text; +using System.Threading.Tasks; + +namespace hazi_generator +{ + public class SIM + { + public int Sorszam; + public string Pinkod; + public bool Tudta; + public void AlapSim(int Szam) + { + Sorszam = Szam; + + Console.WriteLine($"A {Sorszam} sorszámú SIM aktiválásához adja meg a pinkódot"); + Pinkod = Console.ReadLine(); + if (Pinkod.Length != 4) + { + throw new Exception("A pinkódnak pontosan 4 jegyűnek kell lennie."); + } + else + { + Console.WriteLine("SIM elmentve."); + } + } + + public void SimLetiltas(int sorszam, string pin) + { + Tudta = false; + Console.WriteLine($"Adja meg a {sorszam} sorszámú SIM pink kódját: "); + string beirtPin = Console.ReadLine(); + if (beirtPin != pin) + { + Console.WriteLine("Helytelen PIN kód"); + } + else + { + Tudta = true; + Console.WriteLine("SIM feloldva"); + } + } + } + + public class PUK : SIM + { + public void Puk(string puk) + { + if (!Tudta) + { + Console.WriteLine("Adja meg a PUK kódot:"); + string beirtpuk = Console.ReadLine(); + if (beirtpuk == puk) + { + Tudta = true; + Console.WriteLine("A SIM feloldva, ismét próbálkozhat a PIN kóddal"); + SimLetiltas(Sorszam,Pinkod); + } + else + { + Console.WriteLine("A SIM kártyát megsemmisítettük"); + } + } + } + } +} + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..f585baf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/FileContentIndex/82896b87-fd83-4b04-970f-aa45ec045e55.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/FileContentIndex/82896b87-fd83-4b04-970f-aa45ec045e55.vsidx new file mode 100644 index 0000000..36c6f98 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/FileContentIndex/82896b87-fd83-4b04-970f-aa45ec045e55.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.futdcache.v2 new file mode 100644 index 0000000..81edac3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.suo new file mode 100644 index 0000000..9303ba1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/2023. 12. 11/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.metadata.v7.bin new file mode 100644 index 0000000..bf34949 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.projects.v7.bin new file mode 100644 index 0000000..cd6ab99 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/.vs/ProjectEvaluation/2023. 12. 11.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.csproj new file mode 100644 index 0000000..ba715ea --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2023._12._11 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.sln new file mode 100644 index 0000000..45aee74 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/2023. 12. 11.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2023. 12. 11", "2023. 12. 11.csproj", "{A3972D66-D31C-4C4D-97A0-461A301EC95E}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A3972D66-D31C-4C4D-97A0-461A301EC95E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A3972D66-D31C-4C4D-97A0-461A301EC95E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A3972D66-D31C-4C4D-97A0-461A301EC95E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A3972D66-D31C-4C4D-97A0-461A301EC95E}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {1BC35CD4-6C03-40E7-9B28-D7F3B2113BDC} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Felhasznalo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Felhasznalo.cs new file mode 100644 index 0000000..1b92287 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Felhasznalo.cs @@ -0,0 +1,20 @@ +namespace _2023._12._11; + +public class Felhasznalo +{ + private string felhasznalonev; + private string email; + private string jelszo; + + public Felhasznalo(string felhasznalonev, string email, string jelszo) + { + this.felhasznalonev = felhasznalonev; + this.email = email; + this.jelszo = jelszo; + } + + public void Hozzaad() + { + + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Program.cs new file mode 100644 index 0000000..7d8c60d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Program.cs @@ -0,0 +1,9 @@ +namespace _2023._12._11; + +class Program +{ + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Termek.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Termek.cs new file mode 100644 index 0000000..35edb84 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/Termek.cs @@ -0,0 +1,15 @@ +namespace _2023._12._11; + +public class Termek +{ + private string nev; + private int mennyiseg; + + string[,] termekek = {{"tej", "369", "10"}, {"alma", "319", "8"}, {"banán", "389", "15"}, {"uborka", "449", "20"}, {"répa", "399", "6"}}; + + public Termek(string nev, int mennyiseg) + { + this.nev = nev; + this.mennyiseg = mennyiseg; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..218184c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj", + "projectName": "2023. 12. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/2023. 12. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs new file mode 100644 index 0000000..cc6b27e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 12. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..c75a8a2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +144ede2bc384ea6c788ee1a4bc3859a259b7cd74 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..916ba5c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._12._11 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 12. 11\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache new file mode 100644 index 0000000..6c2c4a7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/Debug/net7.0/2023. 12. 11.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.assets.json new file mode 100644 index 0000000..c8793d8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj", + "projectName": "2023. 12. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.nuget.cache new file mode 100644 index 0000000..c1682f4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 12. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "Tq+DQAZLRF6yZVrgesO20UYs77fiZRVd0uJ2biBjeTabTUfQzIyhOgWBAkt01s376NxN/BdzFIEpW63AOvu9ag==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 12. 11\\2023. 12. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..7c185b0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/FileContentIndex/2109b29a-ea21-42ba-9366-536585c87bf3.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/FileContentIndex/2109b29a-ea21-42ba-9366-536585c87bf3.vsidx new file mode 100644 index 0000000..34457a1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/FileContentIndex/2109b29a-ea21-42ba-9366-536585c87bf3.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.futdcache.v2 new file mode 100644 index 0000000..cc043cf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.suo new file mode 100644 index 0000000..95d2007 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/2024. 01. 03/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.metadata.v7.bin new file mode 100644 index 0000000..7bee647 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.projects.v7.bin new file mode 100644 index 0000000..4ea9de1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/.vs/ProjectEvaluation/2024. 01. 03.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.csproj new file mode 100644 index 0000000..63d3dae --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._01._03 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.sln new file mode 100644 index 0000000..bef305a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/2024. 01. 03.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 01. 03", "2024. 01. 03.csproj", "{FC5F22E3-2134-41E8-BBA5-26FD7E01C2D6}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {FC5F22E3-2134-41E8-BBA5-26FD7E01C2D6}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {FC5F22E3-2134-41E8-BBA5-26FD7E01C2D6}.Debug|Any CPU.Build.0 = Debug|Any CPU + {FC5F22E3-2134-41E8-BBA5-26FD7E01C2D6}.Release|Any CPU.ActiveCfg = Release|Any CPU + {FC5F22E3-2134-41E8-BBA5-26FD7E01C2D6}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {0877919C-5D75-4744-8837-B9CFEEAE9CBB} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Dal.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Dal.cs new file mode 100644 index 0000000..5f34870 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Dal.cs @@ -0,0 +1,26 @@ +namespace _2024._01._03; + +public class Dal +{ + private string cim; + private string eloado; + private List cimek; + + + public Dal(string cim, string eloado) + { + this.cim = cim; + this.eloado = eloado; + } + + public void Lista() + { + cimek.Add(cim); + } + + public void Kiiras() + { + System.Console.WriteLine($"A zene címe: {cimek[1]}"); + System.Console.WriteLine($"A zene elődaója: {eloado}"); + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Program.cs new file mode 100644 index 0000000..78e5326 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/Program.cs @@ -0,0 +1,26 @@ +namespace _2024._01._03; + +class Program +{ + static void Main(string[] args) + { + System.Console.WriteLine("Add meg a dal címét!"); + string cim = Console.ReadLine(); + System.Console.WriteLine("Add meg a dal előadóját!"); + string eloado = Console.ReadLine(); + Dal dal = new Dal(cim, eloado); + dal.Lista(); + + while (cim != "Elég") + { + System.Console.WriteLine("Add meg a dal címét!"); + cim = Console.ReadLine(); + System.Console.WriteLine("Add meg a dal előadóját!"); + eloado = Console.ReadLine(); + dal = new Dal(cim, eloado); + dal.Lista(); + } + + dal.Kiiras(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.deps.json new file mode 100644 index 0000000..7fcc685 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 01. 03/1.0.0": { + "runtime": { + "2024. 01. 03.dll": {} + } + } + } + }, + "libraries": { + "2024. 01. 03/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.dll new file mode 100644 index 0000000..b473092 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.exe new file mode 100644 index 0000000..8f4e647 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.pdb new file mode 100644 index 0000000..b56ff0e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/bin/Debug/net7.0/2024. 01. 03.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.dgspec.json new file mode 100644 index 0000000..aac052b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj", + "projectName": "2024. 01. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/2024. 01. 03.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfo.cs new file mode 100644 index 0000000..4895d4c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 01. 03")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 01. 03")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 01. 03")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfoInputs.cache new file mode 100644 index 0000000..f30eb45 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +4434210263d2ec11bd067d13b1c5a0e3ba60d899 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d5abcc6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._01._03 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.assets.cache new file mode 100644 index 0000000..2071196 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..868c799 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +caab543219c3005ad7c63e20a2f7c6fb0f3c22fd diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..a834a54 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\bin\Debug\net7.0\2024. 01. 03.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\bin\Debug\net7.0\2024. 01. 03.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\bin\Debug\net7.0\2024. 01. 03.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\bin\Debug\net7.0\2024. 01. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\bin\Debug\net7.0\2024. 01. 03.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\refint\2024. 01. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\2024. 01. 03.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 03\obj\Debug\net7.0\ref\2024. 01. 03.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.dll new file mode 100644 index 0000000..b473092 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.genruntimeconfig.cache new file mode 100644 index 0000000..bded01c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.genruntimeconfig.cache @@ -0,0 +1 @@ +93efa6a6eed2a2c42e758cef967042ea4ddffc43 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.pdb new file mode 100644 index 0000000..b56ff0e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/2024. 01. 03.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..8f4e647 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/ref/2024. 01. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/ref/2024. 01. 03.dll new file mode 100644 index 0000000..eec1fcd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/ref/2024. 01. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/refint/2024. 01. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/refint/2024. 01. 03.dll new file mode 100644 index 0000000..eec1fcd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/Debug/net7.0/refint/2024. 01. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.assets.json new file mode 100644 index 0000000..ad63581 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj", + "projectName": "2024. 01. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.nuget.cache new file mode 100644 index 0000000..3e51d8d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 03/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "5EnKNHkORwjWFfwDjAK/BvA9KhyWFswjb6u3ypj4BEoJxEVmKNqc6C1lCn76PVDlEAdQhyrJjhN6y+MaKAoE1A==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 03\\2024. 01. 03.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..9a32cd2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/FileContentIndex/481672a6-3122-40d9-82b8-a8043b911e27.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/FileContentIndex/481672a6-3122-40d9-82b8-a8043b911e27.vsidx new file mode 100644 index 0000000..42b328c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/FileContentIndex/481672a6-3122-40d9-82b8-a8043b911e27.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.futdcache.v2 new file mode 100644 index 0000000..d33d4f9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.suo new file mode 100644 index 0000000..c7e3548 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/2024. 01. 10/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.metadata.v7.bin new file mode 100644 index 0000000..5b23ca0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.projects.v7.bin new file mode 100644 index 0000000..279fa1f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/.vs/ProjectEvaluation/2024. 01. 10.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.csproj new file mode 100644 index 0000000..0da44a5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._01._10 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.sln new file mode 100644 index 0000000..d5ba46b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/2024. 01. 10.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 01. 10", "2024. 01. 10.csproj", "{B22D4FC9-C861-4FF5-9D10-1367EDAD3804}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {B22D4FC9-C861-4FF5-9D10-1367EDAD3804}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {B22D4FC9-C861-4FF5-9D10-1367EDAD3804}.Debug|Any CPU.Build.0 = Debug|Any CPU + {B22D4FC9-C861-4FF5-9D10-1367EDAD3804}.Release|Any CPU.ActiveCfg = Release|Any CPU + {B22D4FC9-C861-4FF5-9D10-1367EDAD3804}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {42379E73-9822-4DEA-BFF5-7DC9F9863C20} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Program.cs new file mode 100644 index 0000000..106f589 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Program.cs @@ -0,0 +1,9 @@ +namespace _2024._01._10; + +class Program +{ + static void Main(string[] args) + { + Console.WriteLine("Hello, World!"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Rendeles.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Rendeles.cs new file mode 100644 index 0000000..3f56b37 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Rendeles.cs @@ -0,0 +1,28 @@ +namespace _2024._01._10; + + + +class Rendeles : Termek +{ + private List Rendeles_lista; + + public Rendeles(List rendeles_lista) + { + Rendeles_lista = rendeles_lista; + } + + public void Uj_termek(string uj_termek) + { + System.Console.WriteLine($"Hozzáadott új termék: {uj_termek}"); + } + + public void Kiiras() + { + double vegosszeg = 1; + + foreach (var i in Rendeles_lista) + { + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Termek.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Termek.cs new file mode 100644 index 0000000..50a7bf0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/Termek.cs @@ -0,0 +1,17 @@ +namespace _2024._01._10; + +class Termek +{ + private List Termek_lista; + private Dictionary, double> Termek_arak; + private Dictionary, double> Termek_db; + + + + public Termek(List termek_lista, Dictionary, double> termek_arak, Dictionary, double> termek_db) + { + Termek_lista = termek_lista; + Termek_arak = termek_arak; + Termek_db = termek_db; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.dgspec.json new file mode 100644 index 0000000..43a509a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj", + "projectName": "2024. 01. 10", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/2024. 01. 10.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfo.cs new file mode 100644 index 0000000..b9e2fae --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 01. 10")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 01. 10")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 01. 10")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfoInputs.cache new file mode 100644 index 0000000..dd94c60 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ace08a51106b8dbb7804150aa7d4e3f1df0ea53 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..fbb5735 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._01._10 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 10\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.assets.cache new file mode 100644 index 0000000..bd027d6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/Debug/net7.0/2024. 01. 10.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.assets.json new file mode 100644 index 0000000..a1b6b59 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj", + "projectName": "2024. 01. 10", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.nuget.cache new file mode 100644 index 0000000..3cb88fe --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 10/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "gtw8VsokYzIfIx0CX7kuVoJD2lqI+u/XfoZBYjfMN2FozlTXcUjd0buE6CAFpaVQoJ9B1WwZqUfaxJEJ9ApXkQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 10\\2024. 01. 10.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.csproj new file mode 100644 index 0000000..2c65c47 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._01._15 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.sln new file mode 100644 index 0000000..2d57662 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/2024. 01. 15.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 01. 15", "2024. 01. 15.csproj", "{E7C58951-8A23-4D5A-8EEA-1A03617CAA2D}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {E7C58951-8A23-4D5A-8EEA-1A03617CAA2D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E7C58951-8A23-4D5A-8EEA-1A03617CAA2D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E7C58951-8A23-4D5A-8EEA-1A03617CAA2D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E7C58951-8A23-4D5A-8EEA-1A03617CAA2D}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {A5324493-DC93-48EE-BE58-46942320C049} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/IDK.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/IDK.cs new file mode 100644 index 0000000..36323b1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/IDK.cs @@ -0,0 +1,35 @@ +class EredmenyElemzo +{ + private string Eredmenyek; + + private int DontetlenekSzama + { + get + { + return Megszamol('X'); + } + } + + private int Megszamol(char kimenet) + { + int darab = 0; + foreach (var i in Eredmenyek) + { + if (i == kimenet) darab++; + } + return darab; + } + + public bool NemvoltDontetlenMerkozes + { + get + { + return DontetlenekSzama == 0; + } + } + + public EredmenyElemzo(string eredmenyek) // konstruktor + { + Eredmenyek = eredmenyek; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Program.cs new file mode 100644 index 0000000..b0ede8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Program.cs @@ -0,0 +1,15 @@ +namespace _2024._01._15; +using System; +using System.IO; + +class Program +{ + static void Main(string[] args) + { + FileStream fs = new FileStream("toto.txt", FileMode.Open, FileAccess.Read); + Toto t = new Toto(fs); + + // t.Feladat3(); + t.Feladat4(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Toto.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Toto.cs new file mode 100644 index 0000000..808d903 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/Toto.cs @@ -0,0 +1,52 @@ +namespace _2024._01._15; + +class Toto +{ + private FileStream Fs; + + public Toto(FileStream fs) + { + Fs = fs; + } + + // public void Feladat3() + // { + // StreamReader r = new StreamReader(Fs); + // string sor = r.ReadLine(); + // int fordulok = 0; + + // while (sor != null) + // { + // sor = r.ReadLine(); + // fordulok++; + // } + + // System.Console.WriteLine($"Fordulók száma: {fordulok - 1}"); + // } + + public void Feladat4() + { + StreamReader r = new StreamReader(Fs); + string sor = r.ReadLine(); + int sor_szama = 0; + int telitalalatok = 0; + + while (sor != null) + { + sor = r.ReadLine(); + sor_szama++; + string[] lista = sor.Split(';'); + if (sor_szama == 1) + { + continue; + } + else + { + telitalalatok += int.Parse(lista[3]); + System.Console.WriteLine(lista[3]); + } + sor = r.ReadLine(); + } + System.Console.WriteLine($"Telitalálatok száma: {telitalalatok} db"); + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.deps.json new file mode 100644 index 0000000..bdbfc25 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 01. 15/1.0.0": { + "runtime": { + "2024. 01. 15.dll": {} + } + } + } + }, + "libraries": { + "2024. 01. 15/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.dll new file mode 100644 index 0000000..0f1a314 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.exe new file mode 100644 index 0000000..9f6910d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.pdb new file mode 100644 index 0000000..f58f7c5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/bin/Debug/net7.0/2024. 01. 15.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.dgspec.json new file mode 100644 index 0000000..4af4871 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj": {} + }, + "projects": { + "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj", + "projectName": "2024. 01. 15", + "projectPath": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/2024. 01. 15.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfo.cs new file mode 100644 index 0000000..38a5b05 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 01. 15")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 01. 15")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 01. 15")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bb82024 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +83517322b7b851bf75ad0ffd53587736da5d1aa8 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..9a085dd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._01._15 +build_property.ProjectDir = C:\Users\gamin\Desktop\2024. 01. 15\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.assets.cache new file mode 100644 index 0000000..0f6b96d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..1efcb6d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +8b764b80f1ef2660e9d664ddb2d39002adf7fc4e diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..3216dc4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +C:\Users\gamin\Desktop\2024. 01. 15\bin\Debug\net7.0\2024. 01. 15.exe +C:\Users\gamin\Desktop\2024. 01. 15\bin\Debug\net7.0\2024. 01. 15.deps.json +C:\Users\gamin\Desktop\2024. 01. 15\bin\Debug\net7.0\2024. 01. 15.runtimeconfig.json +C:\Users\gamin\Desktop\2024. 01. 15\bin\Debug\net7.0\2024. 01. 15.dll +C:\Users\gamin\Desktop\2024. 01. 15\bin\Debug\net7.0\2024. 01. 15.pdb +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.GeneratedMSBuildEditorConfig.editorconfig +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.AssemblyInfoInputs.cache +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.AssemblyInfo.cs +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.csproj.CoreCompileInputs.cache +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.dll +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\refint\2024. 01. 15.dll +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.pdb +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\2024. 01. 15.genruntimeconfig.cache +C:\Users\gamin\Desktop\2024. 01. 15\obj\Debug\net7.0\ref\2024. 01. 15.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.dll new file mode 100644 index 0000000..0f1a314 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.genruntimeconfig.cache new file mode 100644 index 0000000..ecb66a5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.genruntimeconfig.cache @@ -0,0 +1 @@ +a12ef70ecaf5d444394c0c82704f86f82cb603e9 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.pdb new file mode 100644 index 0000000..f58f7c5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/2024. 01. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..9f6910d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/ref/2024. 01. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/ref/2024. 01. 15.dll new file mode 100644 index 0000000..b6e1f07 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/ref/2024. 01. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/refint/2024. 01. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/refint/2024. 01. 15.dll new file mode 100644 index 0000000..b6e1f07 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/Debug/net7.0/refint/2024. 01. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.assets.json new file mode 100644 index 0000000..028e900 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj", + "projectName": "2024. 01. 15", + "projectPath": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.nuget.cache new file mode 100644 index 0000000..ab9eba7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "9yIMIlCOGU+3q8og/9k3r5Cy/XC2V6eSQWQwRISIAsL7D95W38Cp6+djzlu32klBpH8UxGv0x3bYVVXDQt7i0Q==", + "success": true, + "projectFilePath": "C:\\Users\\gamin\\Desktop\\2024. 01. 15\\2024. 01. 15.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/toto.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/toto.txt new file mode 100644 index 0000000..5aad735 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 15/toto.txt @@ -0,0 +1,1631 @@ +Év;Hét;Forduló;T13p1;Ny13p1;Eredmények +2020;18;1;0;0;2X22211X1X11X1 +2020;17;1;0;0;2221XX12222121 +2020;16;2;0;0;1111XX11X12X1X +2020;16;1;0;0;112X1XXX1221X1 +2020;15;2;0;0;X11X112112X222 +2020;15;1;0;0;222211111X11X1 +2020;14;1;0;0;X121121XXXX121 +2020;13;1;0;0;1X112X221X1111 +2020;12;1;0;0;111X1X212X1X11 +2020;11;2;112;13900;2111X21XXX1122 +2020;11;1;1;6058510;121121122121XX +2020;10;2;0;0;X1XX21X112X111 +2020;10;1;0;0;2111X212XX1122 +2020;9;2;3;3485930;122122111XX121 +2020;9;1;0;0;2X1222X1221X1X +2020;8;2;0;0;12X222112X2211 +2020;8;1;1;1366420;11121211X12112 +2020;7;2;12;853730;11212122X11221 +2020;7;1;0;0;X1X2X121X22212 +2020;6;2;0;0;2121X2X12X1221 +2020;6;1;0;0;XX2XX111XXX221 +2020;5;2;1;11022635;1211X2211XX121 +2020;5;1;0;0;X121X221211212 +2020;4;2;0;0;1112211X1X2XX1 +2020;4;1;0;0;X112X21122X211 +2020;3;2;2;1461505;222112221X2111 +2020;3;1;23;67905;111121111212X2 +2020;2;2;2;13359780;12X111121222X2 +2020;2;1;0;0;2X1122X111X122 +2020;1;2;0;0;21X12XX22122X1 +2020;1;1;0;0;2111X1221212X1 +2019;52;2;0;0;2X1X2211222222 +2019;52;1;0;0;X1211X1XXXX1X2 +2019;51;2;0;0;112X1X1112112X +2019;51;1;0;0;X22122X21222XX +2019;50;2;1;2601045;21121122X11X2X +2019;50;1;15;307880;2112X121222121 +2019;49;2;0;0;21111111X11X22 +2019;49;1;13;805145;111111X2211X11 +2019;48;2;0;0;2X22122X121222 +2019;48;1;0;0;X211X11X22X2X1 +2019;47;2;0;0;21X22122X2121X +2019;47;1;2;680355;11111112221X11 +2019;46;2;2;2127980;2211X12122212X +2019;46;1;28;151725;X1112111X1111X +2019;45;2;0;0;1X21211221X111 +2019;45;1;4;1054955;X1X11112112XX1 +2019;44;2;0;0;XX211112X12222 +2019;44;1;2;2095890;X21X111X22X112 +2019;43;2;0;0;X1211XX12XXX12 +2019;43;1;212;21160;22211112X22211 +2019;42;2;0;0;1XXXX111112XXX +2019;42;1;4;263765;111X11222121XX +2019;41;2;16;153500;11X1222122XX11 +2019;41;1;1;4510050;XX112X112111X1 +2019;40;2;0;0;X2X2X1X121XXX2 +2019;40;1;4;368815;212121X2112221 +2019;39;2;1;3996400;X2222X21221122 +2019;39;1;0;0;221X12211X2X11 +2019;38;2;2;1157830;2212X1121XX222 +2019;38;1;1;1389265;1XX1X221XX22X1 +2019;37;2;1;3810205;X21112X1121122 +2019;37;1;0;0;212212X11XX112 +2019;36;2;1;2145575;21121111X11XX2 +2019;36;1;8;545095;112XX12X21X112 +2019;35;2;0;0;11X221X1111XXX +2019;35;1;4;971675;11122XX1221111 +2019;34;2;0;0;122212221X2112 +2019;34;1;1;7708905;1X1X12X1111112 +2019;33;2;0;0;X2X2X211112X12 +2019;33;1;0;0;2XX1112212221X +2019;32;2;1;9365220;1X1X2X2XX11X11 +2019;32;1;0;0;XX21X22222111X +2019;31;2;0;0;1XX1121112221X +2019;31;1;0;0;X1111112XX2111 +2019;30;2;0;0;11221X2X2122X1 +2019;30;1;18;284040;1111X1X1112111 +2019;29;2;0;0;1X11212122X212 +2019;29;1;0;0;212X1221X1X21X +2019;28;2;1;9385310;11111111X21221 +2019;28;1;0;0;12XX2X2112121X +2019;27;2;0;0;12X212111X2111 +2019;27;1;0;0;X22X2XX2121211 +2019;26;2;0;0;XXX2121121XXX2 +2019;26;1;2;445190;11XX11X111X1X2 +2019;25;2;78;26910;2221X11121X111 +2019;25;1;1;4923860;21222211212X1X +2019;24;2;0;0;X2X111112X1111 +2019;24;1;0;0;12111121222111 +2019;23;2;11;1241030;211211121122X1 +2019;23;1;0;0;1X2111X11X211X +2019;22;2;0;0;2211XX1X1222X1 +2019;22;1;0;0;11XX21X111XX2X +2019;21;2;0;0;22X22121X11111 +2019;21;1;0;0;X12211122XX2X2 +2019;20;2;4;2322945;121211112X11X1 +2019;20;1;0;0;1121112X122XX2 +2019;19;2;0;0;2X1X1X22XX2212 +2019;19;1;0;0;122X121X1112X2 +2019;18;2;1;15174970;1X11XX1X12XX1X +2019;18;1;0;0;212X21XX1121X1 +2019;17;2;0;0;1X2X112XX1X221 +2019;17;1;0;0;21212X12221X12 +2019;16;2;0;0;1X112221122X1X +2019;16;1;0;0;1221211X111112 +2019;15;2;45;64845;1X212112211221 +2019;15;1;1;10088050;11X21122XX2211 +2019;14;2;0;0;12222X12112XXX +2019;14;1;0;0;12221X2111X2X1 +2019;13;2;0;0;111X1221111X22 +2019;13;1;2;615320;X1X1X221XX2112 +2019;12;2;28;84820;11111212121X12 +2019;12;1;25;311765;11112X11X1122X +2019;11;2;0;0;2X122111121112 +2019;11;1;0;0;1112212X111X12 +2019;10;2;6;1168750;2X11X1212121XX +2019;10;1;0;0;2212XXXX121111 +2019;9;2;3;1055800;221212X11X1112 +2019;9;1;9;159575;XX211111121122 +2019;8;2;19;1529005;11212111222XXX +2019;8;1;0;0;XX2122X12X1X11 +2019;7;2;0;0;2X11XX1122111X +2019;7;1;0;0;2121XXX1111121 +2019;6;2;0;0;X2X2XX111X2211 +2019;6;1;0;0;X221X111X2121X +2019;5;2;0;0;1X2X2XX11X2X11 +2019;5;1;0;0;1111121X11XX11 +2019;4;2;26;403145;1122X12122XX12 +2019;4;1;0;0;2X121222121111 +2019;3;2;0;0;1112XXX2122211 +2019;3;1;0;0;1XX21X2XX1X111 +2019;2;2;106;164120;X2112X22111112 +2019;2;1;0;0;111X2X2111X1X1 +2019;1;2;0;0;12X2X11111XX22 +2019;1;1;0;0;2XX2X2111112X1 +2018;52;2;0;0;X2X22111221221 +2018;52;1;0;0;11112X2X221111 +2018;51;2;6;814415;11222112211XX1 +2018;51;1;0;0;11X12XXXX2X212 +2018;50;2;107;117565;12XX1111122111 +2018;50;1;0;0;12XXX212X1111X +2018;49;2;0;0;2111X11111XXXX +2018;49;1;0;0;1112X1112XX11X +2018;48;2;35;75515;122X12111X111X +2018;48;1;1;5103620;21X21111X21111 +2018;47;2;0;0;X1X2X11X11XXXX +2018;47;1;22;455100;X11211X1111221 +2018;46;2;0;0;X12121212X2111 +2018;46;1;0;0;111XX222X11211 +2018;45;2;0;0;112122111211X2 +2018;45;1;1;6290265;X2111X1121XX22 +2018;44;2;0;0;12X2X1221X1122 +2018;44;1;0;0;XXXX1211111112 +2018;43;2;2;1393315;X21XX22XXX1X21 +2018;43;1;1;6022225;2X212X1XX1X2X1 +2018;42;2;0;0;12XX222X12X2X1 +2018;42;1;0;0;1X1XX121221X11 +2018;41;2;5;2426720;11X11XX1XX2122 +2018;41;1;0;0;X122212X12X212 +2018;40;2;0;0;X2X12X2122111X +2018;40;1;0;0;2XX11X22111212 +2018;39;2;4;4097535;1111111121X2XX +2018;39;1;0;0;121111X11121X1 +2018;38;2;0;0;X1221X12211X21 +2018;38;1;0;0;11122XX12X2212 +2018;37;2;0;0;21111X121X112X +2018;37;1;0;0;12111X21X1112X +2018;36;2;86;90565;11122111111111 +2018;36;1;0;0;X2X121X11X1121 +2018;35;2;0;0;XX212X2X222111 +2018;35;1;0;0;XX21X212222112 +2018;34;2;5;1677030;1211X11111111X +2018;34;1;0;0;21X1X2XX1XX11X +2018;33;2;0;0;X11111222X2X11 +2018;33;1;0;0;XX1X11XX2X1X1X +2018;32;2;32;114295;2112X212X1X221 +2018;32;1;0;0;XXXX11X21121X1 +2018;31;2;2;1662100;121X11X112X112 +2018;31;1;0;0;122X2211X1X12X +2018;30;2;2;3921125;XXX1X12X121222 +2018;30;1;0;0;XX11212111X212 +2018;29;2;0;0;21111221212XX1 +2018;29;1;0;0;11112222X111X1 +2018;28;2;3;3841245;1X2211121111X1 +2018;28;1;0;0;1212211X1X211X +2018;27;2;0;0;212121XX11111X +2018;27;1;0;0;X2111122X112X1 +2018;26;2;0;0;11XXX12211111X +2018;26;1;0;0;22212X222XXX12 +2018;25;2;17;133205;1211X1X2111X12 +2018;25;1;14;885895;1112X111XXX122 +2018;24;2;0;0;1X212212X1212X +2018;24;1;0;0;X2XX1X111211X1 +2018;23;2;0;0;2X1X1X2111XX12 +2018;23;1;0;0;X11X11X1X1X22X +2018;22;2;0;0;11X2X12112111X +2018;22;1;1;10180510;11X112111X111X +2018;21;1;0;0;XX11221112XX21 +2018;20;2;0;0;X2122111111122 +2018;20;1;104;41260;1221111X111112 +2018;19;2;0;0;2112121112XX2X +2018;19;1;1;9393155;X21XX111211111 +2018;18;2;0;0;X22111X12XX21X +2018;18;1;0;0;11X22122222111 +2018;17;2;0;0;1XX221X1222112 +2018;17;1;1;6350040;121111X2X2121X +2018;16;2;0;0;112221X1122212 +2018;16;1;0;0;122X21X1X12221 +2018;15;2;1;7936830;X11111XXXX1X21 +2018;15;1;0;0;21X21X1112X111 +2018;14;2;0;0;212X11X22X12XX +2018;14;1;10;1859030;2211121XX11111 +2018;13;2;0;0;XX1X1X1211X1X2 +2018;13;1;0;0;2X12121XX11221 +2018;12;2;0;0;2211X221221122 +2018;12;1;0;0;22X222X2211121 +2018;11;2;0;0;2X2112X2122X11 +2018;11;1;0;0;2121122221XX21 +2018;10;2;1;8343820;12X11X1212X12X +2018;10;1;0;0;2X2211122111X2 +2018;9;2;0;0;1X1122X2112221 +2018;9;1;1;7312955;1XX1211XX111X2 +2018;8;2;0;0;11X2X221121212 +2018;8;1;0;0;X1X1112X12121X +2018;7;2;2;2545605;2X2112221211X1 +2018;7;1;0;0;X22112222X1122 +2018;6;2;15;229695;21111111111112 +2018;6;1;35;1058195;X112X1112X1211 +2018;5;2;0;0;22XX2X221X2X11 +2018;5;1;0;0;2X211X221XX1X1 +2018;4;2;0;0;21XX2X122X112X +2018;4;1;0;0;11XXX1X11XX221 +2018;3;2;0;0;2111221X2112X1 +2018;3;1;0;0;X121X2X111X211 +2018;2;2;0;0;1X11X11X2XX111 +2018;2;1;1;29007200;1111X2122XXX2X +2018;1;2;0;0;111212212111XX +2018;1;1;0;0;X1222X1X2222XX +2017;51;2;0;0;222XXX22X11121 +2017;51;1;0;0;1X111121X121X1 +2017;50;2;0;0;21XX1X2122112X +2017;50;1;14;1503735;2111111222X11X +2017;49;2;0;0;22XXX21XXXX1X2 +2017;49;1;0;0;11221X12111211 +2017;48;2;0;0;112X11X21X1X12 +2017;48;1;0;0;1X2X2111112122 +2017;47;2;0;0;X2112X2XX2X12X +2017;47;1;57;184570;X221122111211X +2017;46;2;0;0;212XX1X2111X11 +2017;46;1;0;0;1X211XXXX21111 +2017;45;1;2;3645660;22221211111221 +2017;44;2;0;0;1X1222X2XX2X11 +2017;44;1;0;0;1X212XX112X1X1 +2017;43;2;2;1526335;11X1212X221211 +2017;43;1;3;4843425;1211212122211X +2017;42;1;0;0;XX21121X21211X +2017;41;2;0;0;X1122X2X222111 +2017;41;1;1;1715120;111X1122X11211 +2017;40;2;70;121780;12X22221XX12X1 +2017;40;1;0;0;222211XXXX1221 +2017;39;2;0;0;22X22X1X2121X2 +2017;39;1;1;1636755;22112X22212121 +2017;38;2;54;88655;1X1211211111X1 +2017;38;1;0;0;21X2221XX21122 +2017;37;2;1;10923145;212XX11X2121X2 +2017;37;1;0;0;121221XXX212X1 +2017;36;2;0;0;1X12X1X1111212 +2017;36;1;0;0;1121X2X2X1X2X2 +2017;35;2;6;762330;1X111212111222 +2017;35;1;0;0;1111XX2X111122 +2017;34;2;2;1277190;2X111222121211 +2017;34;1;3;520760;1112XX1X1111X2 +2017;33;2;13;573750;22111X12122X21 +2017;33;1;0;0;1111211122XX1X +2017;32;1;5;219630;111X111111221X +2017;31;2;5;2152065;X11X2111X12X1X +2017;31;1;0;0;111112121X1X2X +2017;30;2;0;0;2212121X1XX11X +2017;30;1;0;0;12X1211X111XXX +2017;29;2;0;0;X2X21211122X11 +2017;29;1;1;13975660;22X21X1111X1X2 +2017;28;2;0;0;X212XX2X1X2211 +2017;28;1;0;0;1X2X212X22222X +2017;27;2;0;0;X1X222X21X1X11 +2017;27;1;0;0;2212XXXX221211 +2017;26;1;31;43100;X1212111111X21 +2017;25;2;1;4382150;12X212111X1211 +2017;25;1;1;1212670;2111211X12112X +2017;24;2;14;936460;1X1112121X1XX2 +2017;24;1;0;0;X1111X121X1111 +2017;23;1;0;0;1X111212X2111X +2017;22;2;0;0;2111X1111X11XX +2017;22;1;0;0;X21X21X11121X2 +2017;21;2;48;63305;12112211121112 +2017;21;1;1;1060955;X2X12X11112X12 +2017;20;2;4;782645;12211X11X21112 +2017;20;1;1;37543370;221X2X12122XX2 +2017;19;2;0;0;2XXX22121X2211 +2017;19;1;0;0;1122111X12X11X +2017;18;2;0;0;1X2X2X11XX11X2 +2017;18;1;0;0;121211121X1122 +2017;17;2;0;0;1X2X2111X21X21 +2017;17;1;0;0;2122X11121112X +2017;16;2;0;0;1X121X1X2111X2 +2017;16;1;0;0;2X1XX1X1XX1XX1 +2017;15;2;0;0;2XXX11111111X2 +2017;15;1;1;6946610;121221X111111X +2017;14;2;0;0;121111X21X1212 +2017;14;1;0;0;X211112212X1X1 +2017;13;2;1;6747775;11X11XXX2211XX +2017;13;1;0;0;2X222121112X12 +2017;12;2;7;717220;111XX12111221X +2017;12;1;0;0;1X2112X22111X2 +2017;11;2;10;487080;1111X22X121X21 +2017;11;1;0;0;111X2X12X1111X +2017;10;2;1;5125850;112XX112211112 +2017;10;1;0;0;2211XX21XX2X11 +2017;9;2;1;4987770;2112112121X2X2 +2017;9;1;0;0;1121211XX1X212 +2017;8;2;10;1262765;X1121X21122212 +2017;8;1;0;0;211X1122112XX2 +2017;7;2;0;0;X112X2X222X211 +2017;7;1;0;0;11122121X12212 +2017;6;2;3;1190210;12121211112112 +2017;6;1;18;836320;X1122X21111X12 +2017;5;2;0;0;X1111111X12221 +2017;5;1;0;0;X221XX12XXX222 +2017;4;2;0;0;21221X2XXX112X +2017;4;1;0;0;1121X111221XX1 +2017;3;2;13;350280;X21X211X221121 +2017;3;1;0;0;X1XX1X11121122 +2017;2;2;2;2455230;221X21111X2111 +2017;2;1;0;0;1X112XX1111221 +2017;1;2;5;1771780;21111222X1X11X +2017;1;1;0;0;22X2X11X21XX11 +2016;52;2;24;388330;11121212211122 +2016;52;1;0;0;11111222XXX2X1 +2016;51;1;0;0;11XX21111XXX2X +2016;50;2;0;0;11X1221X121221 +2016;50;1;3;2582640;112XX22121X111 +2016;49;1;0;0;XX11212X222X21 +2016;48;2;1;8495675;X2X1121121121X +2016;48;1;0;0;1X1X1X221X1X12 +2016;47;2;1;13311015;11XXXX11122112 +2016;47;1;0;0;221X121XXXX21X +2016;46;2;0;0;X212X2X221111X +2016;46;1;0;0;21XXX2XX111211 +2016;45;2;28;123335;12X1X21211211X +2016;45;1;1;2364400;1121X111111212 +2016;44;2;7;553545;X212111X22X112 +2016;44;1;1;5777715;1221X1211XX1X2 +2016;43;2;0;0;2X222X11211X11 +2016;43;1;1;5561175;1X11112222X111 +2016;42;2;0;0;12X1111111XX11 +2016;42;1;3;3358515;22221XX1222121 +2016;41;2;0;0;1X1XXX112212X2 +2016;41;1;0;0;X121X11XX21X22 +2016;40;2;1;3054765;11X1112X212221 +2016;40;1;36;193470;XXX11121X11112 +2016;39;2;0;0;X11X1X12212111 +2016;39;1;3;2883855;X1X21121212XX1 +2016;38;2;0;0;X211X221X211XX +2016;38;1;0;0;X1X2X2212X1XXX +2016;37;2;2;1742375;211112X1211111 +2016;37;1;3;3152410;X11122XX2212XX +2016;36;2;0;0;11211X11122112 +2016;36;1;0;0;X1XX211X1111XX +2016;35;2;4;897905;2111121XX2XX22 +2016;35;1;1;13187240;12XX1122211211 +2016;34;2;0;0;11211X21X1X12X +2016;34;1;0;0;21X1XX11X22XX1 +2016;33;2;0;0;12212X111112X1 +2016;33;1;9;5791915;2X1X21221X1211 +2016;32;2;0;0;21X111X22XX122 +2016;32;1;0;0;X21XXX1XXX1112 +2016;31;2;0;0;X22222112X21X2 +2016;31;1;0;0;12X11111211X21 +2016;30;2;0;0;1X111XX12212XX +2016;30;1;0;0;XX2XXX11X1X2X1 +2016;29;2;0;0;122XXX12221211 +2016;29;1;0;0;21XX11121121XX +2016;28;2;0;0;X11X112XXXXX11 +2016;28;1;1;9642410;2111X211X12XX2 +2016;27;2;0;0;212112X11X121X +2016;27;1;0;0;12221X111122X2 +2016;26;2;0;0;XX1X211111X111 +2016;26;1;7;799775;1111111221221X +2016;25;2;0;0;X1X1121112212X +2016;25;1;1;23578790;X22121221X1222 +2016;24;2;0;0;X1X21111211X1X +2016;24;1;0;0;2XX121211X1X2X +2016;23;2;0;0;21X2112121X111 +2016;23;1;0;0;21111X1121X112 +2016;22;2;0;0;12X1211X2X2X21 +2016;22;1;0;0;2X11121122X211 +2016;21;2;4;7489335;X1121211212111 +2016;21;1;0;0;21X211XXXX1111 +2016;20;2;0;0;XXX2XX1XXX1X2X +2016;20;1;0;0;21122X22X221X2 +2016;19;2;0;0;X1X12221121212 +2016;19;1;0;0;111221221121XX +2016;18;2;0;0;2212X12121X21X +2016;18;1;1;7063640;1111111X2X1X11 +2016;17;2;0;0;X1X22112X1X1X1 +2016;17;1;1;7080855;X1XX2XX11121X1 +2016;16;2;0;0;222211X1211212 +2016;16;1;41;77835;21111111X21121 +2016;15;2;3;6559150;111111221X1112 +2016;15;1;0;0;111XX212X12121 +2016;14;2;0;0;2122XX22111212 +2016;14;1;0;0;11X1X121X1212X +2016;13;2;0;0;21112X11X111X2 +2016;13;1;1;4962200;12X211X211112X +2016;12;2;0;0;X1112X21212X1X +2016;12;1;3;3142145;1111X11112XXX2 +2016;11;2;0;0;221XX1222X2X1X +2016;11;1;0;0;X1XX11X121212X +2016;10;2;2;2350950;1121111X1XX212 +2016;10;1;7;983575;1122XX1X1111X1 +2016;9;2;0;0;X2XX111X11X211 +2016;9;1;1;9296115;12212112121111 +2016;8;2;0;0;222XX11X21X1X1 +2016;8;1;1;2757215;X22XXX1211X112 +2016;7;2;1;8564995;X11112X212X211 +2016;7;1;0;0;1122X1111XX2X2 +2016;6;2;3;4836825;1211X112112121 +2016;6;1;0;0;222XXX1XX222X1 +2016;5;2;0;0;X212XXXXX21XX1 +2016;5;1;24;98500;X12211X2111X22 +2016;4;2;29;516530;1X11X2XX12X1X1 +2016;4;1;0;0;21XX11X12X2121 +2016;3;2;0;0;X2X2122X1X1211 +2016;3;1;0;0;21X1121121X2X2 +2016;2;2;1;21485675;X1111X2X1XX211 +2016;2;1;0;0;X21XX11221221X +2016;1;2;0;0;12X22222211122 +2016;1;1;0;0;21X1X22X211221 +2015;53;2;0;0;1X111122XX112X +2015;53;1;1;5746795;X21X12121X2112 +2015;52;1;0;0;1XXX1112111111 +2015;51;2;2;11273435;21221112112222 +2015;51;1;0;0;122X221X212111 +2015;50;2;0;0;2121X111X2XX11 +2015;50;1;0;0;1111X211XX2221 +2015;49;2;0;0;12X212X22X111X +2015;49;1;1;8254370;1X222112112222 +2015;48;2;0;0;111X21XX121X12 +2015;48;1;0;0;111222X222X111 +2015;47;2;4;5114995;2211221X12X1X1 +2015;47;1;0;0;XX222X112211X1 +2015;46;2;0;0;1111221112X122 +2015;46;1;0;0;2211X1111111X2 +2015;45;2;0;0;12X1XX1X212121 +2015;45;1;26;285835;11111X21112121 +2015;44;2;0;0;2XXX21121111X2 +2015;44;1;23;76500;21112221211112 +2015;43;2;99;164630;112211X11212X1 +2015;43;1;0;0;12XX1111X11X1X +2015;42;2;0;0;212X12211X111X +2015;42;1;0;0;1221121111221X +2015;41;2;1;24141375;1X222121222X11 +2015;41;1;0;0;11X1X211221122 +2015;40;2;0;0;111X1X2112X11X +2015;40;1;0;0;11211122211212 +2015;39;2;0;0;222X22XX111222 +2015;39;1;0;0;112111X21X1X11 +2015;38;2;3;4039335;21X1221112X221 +2015;38;1;0;0;2111211112X2XX +2015;37;2;0;0;212X2111212XX1 +2015;37;1;1;2223205;122X11221XX1X2 +2015;36;2;10;752605;11111X2112X111 +2015;36;1;0;0;X21X122122X112 +2015;35;2;1;9949240;1121X2111112X2 +2015;35;1;0;0;1X11X1122X12X1 +2015;34;2;0;0;2XXX21222X1211 +2015;34;1;2;17496525;11111X22XXX111 +2015;33;2;0;0;212X2112XX1221 +2015;33;1;0;0;XXX1XX1XX11222 +2015;32;2;0;0;2112X12112X11X +2015;32;1;0;0;1111121121X211 +2015;31;2;0;0;X1222111X21X21 +2015;31;1;0;0;2X1XX1122X1112 +2015;30;2;0;0;X221X21111X222 +2015;30;1;0;0;2X211222X212X1 +2015;29;2;0;0;X1XXXX1211X121 +2015;29;1;4;2829460;212112X121XX11 +2015;28;2;0;0;X111X1X2112X22 +2015;28;1;0;0;2X1XXX1X121221 +2015;27;2;0;0;1X112X1X11X1XX +2015;27;1;2;3047110;1X11121111112X +2015;26;2;0;0;X11XX12XX21121 +2015;26;1;0;0;2X2X1X11111211 +2015;25;2;1;8510095;212XX2XX12X1X1 +2015;25;1;0;0;1X111X2X2X1212 +2015;24;2;0;0;2X21X122211X21 +2015;24;1;1;1701700;X2X1XX1X1XX112 +2015;23;2;1;4188310;21X122X211XX11 +2015;23;1;2;8583265;12111X11X222XX +2015;22;2;0;0;121112211X11X2 +2015;22;1;0;0;2X22121111XX2X +2015;21;2;0;0;12111112X211X1 +2015;21;1;0;0;11X11111X121XX +2015;20;2;1;41033915;11211X112221X1 +2015;20;1;0;0;11121X2X11122X +2015;19;2;0;0;X1211X21X122X2 +2015;19;1;0;0;111X1X12X11121 +2015;18;2;0;0;11XX22X2211XX1 +2015;18;1;0;0;X212212XX2X122 +2015;17;2;0;0;1X112XX1111XX1 +2015;17;1;1;5932945;11X121XX212211 +2015;16;2;0;0;211X211X111X2X +2015;16;1;1;1878270;X11X12111X2212 +2015;15;2;1;6581165;X11X22112X111X +2015;15;1;0;0;XX122221111X2X +2015;14;2;39;519890;21X21XX12X2112 +2015;14;1;0;0;X1X2XX12121121 +2015;13;2;0;0;1X12X1X1211X1X +2015;13;1;0;0;1X1112X2X12111 +2015;12;2;0;0;212X21121X1X21 +2015;12;1;1;14121985;2112X2XX121122 +2015;11;2;0;0;2X121X112X1X1X +2015;11;1;0;0;21X1111111X211 +2015;10;2;0;0;21X12X12XX1X1X +2015;10;1;4;2331155;2121121212X122 +2015;9;2;0;0;111112X22111XX +2015;9;1;0;0;211111122122X2 +2015;8;2;2;2315530;2XX1XXX111X12X +2015;8;1;3;2872655;2XX2X2121X11XX +2015;7;2;0;0;121111221XX222 +2015;7;1;6;383150;111211X21X111X +2015;6;2;23;2631810;1222111XX1211X +2015;6;1;0;0;22X1XXX2222211 +2015;5;2;0;0;X122X11XX1X211 +2015;5;1;0;0;222X11X1XXX222 +2015;4;2;0;0;22222XX21221XX +2015;4;1;0;0;X11111X11111X1 +2015;3;2;0;0;22212XX22XX222 +2015;3;1;0;0;1121X1XX121112 +2015;2;2;0;0;X12XX11111XXX1 +2015;2;1;0;0;X2X1X12XX21111 +2015;1;2;2;4508655;12X2111X121111 +2015;1;1;0;0;XX1X1XX1X11211 +2014;52;2;0;0;XXX2XX122X2111 +2014;52;1;5;1734145;12222121221121 +2014;51;2;0;0;1X1XX12XXX1XX2 +2014;51;1;56;198770;X1X22211112XX1 +2014;50;2;0;0;212XXX1XX22211 +2014;50;1;1;9711885;XX1XX211X12112 +2014;49;2;0;0;12212X111XX212 +2014;49;1;0;0;1X2121X22X2XX1 +2014;48;2;52;90680;2111111X121122 +2014;48;1;2;5141605;1212121122X211 +2014;47;2;0;0;2121X2X12222XX +2014;47;1;0;0;2212211X112122 +2014;46;2;108;57400;112211X1X2111X +2014;46;1;0;0;X122111222111X +2014;45;2;1;5213200;2X112111X12X11 +2014;45;1;2;1634285;11121X11221X12 +2014;44;2;1;3884400;12112112112112 +2014;44;1;1;9839945;X2221111XX1111 +2014;43;2;0;0;1221111XX121XX +2014;43;1;33;779245;221121111X1222 +2014;42;2;0;0;11122X1X11X22X +2014;42;1;0;0;2X2221X1212X2X +2014;41;2;0;0;X1X11XX121X212 +2014;41;1;0;0;21211X21111X2X +2014;40;2;2;16032580;1X211X11X21111 +2014;40;1;0;0;1XXX2X1X121121 +2014;39;2;0;0;21X112122XX2X2 +2014;39;1;0;0;X1111X211X12XX +2014;38;2;0;0;XX211X211212XX +2014;38;1;0;0;11111121XXX111 +2014;37;2;3;5899850;112111221X1122 +2014;37;1;0;0;2112112X112122 +2014;36;2;0;0;2211222XX1112X +2014;36;1;17;435520;22211111112221 +2014;35;2;0;0;122XXXX22211X2 +2014;35;1;6;1717920;11111212X22X11 +2014;34;2;0;0;21X1X1XX12X1X2 +2014;34;1;0;0;XXX211XXX22122 +2014;33;2;1;20908305;X22X211211X211 +2014;33;1;0;0;112122X2X2X121 +2014;32;2;0;0;21XX222121XX12 +2014;32;1;0;0;12XX11X1112X2X +2014;31;2;0;0;XX11X1XX12XXX1 +2014;31;1;0;0;X11XX22X2111XX +2014;30;2;4;5723610;12112X11121X21 +2014;30;1;0;0;21222112222XX2 +2014;29;2;0;0;1121XX1X2XX111 +2014;29;1;0;0;X2X22X2111X212 +2014;28;2;0;0;2X2X2X1X1XXX1X +2014;28;1;2;16283820;2X2X2X221122X1 +2014;27;2;0;0;1XXX11112222X1 +2014;27;1;0;0;XX2X112X1XX11X +2014;26;2;0;0;X1122X1121212X +2014;26;1;0;0;21X212X2222212 +2014;25;2;0;0;1X11212222211X +2014;25;1;0;0;1XX22XX21X2222 +2014;24;2;1;10796225;12211111111221 +2014;24;1;0;0;1X12X2XXX1212X +2014;23;2;0;0;111X111XX2122X +2014;23;1;1;30589480;21X2112XX11111 +2014;22;2;0;0;X111XX1X1X21XX +2014;22;1;0;0;1X11X2212X11X1 +2014;21;2;0;0;X21X1X1XX2122X +2014;21;1;0;0;111X112121XXX1 +2014;20;2;0;0;XXX111X111112X +2014;20;1;0;0;X1X2222X11111X +2014;19;2;216;106800;11111121111222 +2014;19;1;0;0;111X21X111X111 +2014;18;2;0;0;212122212211X1 +2014;18;1;0;0;22211222XX1221 +2014;17;2;0;0;1X1XX122X12212 +2014;17;1;0;0;11X112X1111211 +2014;16;2;4;2196625;1XX21221X12211 +2014;16;1;0;0;11X112X1X22112 +2014;15;2;31;478795;X1111211121211 +2014;15;1;0;0;1111212221X121 +2014;14;2;0;0;1211X1X2X11211 +2014;14;1;6;1946475;11X2211X112112 +2014;13;2;0;0;XX12112121XX11 +2014;13;1;1;43825380;112X1212111111 +2014;12;2;0;0;2211X1222222X2 +2014;12;1;0;0;12X1X1X211X22X +2014;11;2;0;0;222X1122221222 +2014;11;1;0;0;11X2X1X211122X +2014;10;2;0;0;21XXX222111121 +2014;10;1;0;0;221XXXX1221111 +2014;9;2;0;0;211XX111XX21X2 +2014;9;1;1;25202260;2X2XX111XX2112 +2014;8;2;0;0;1X21X22X2X1111 +2014;8;1;0;0;22X122122XXX2X +2014;7;2;0;0;11111X2221X121 +2014;7;1;0;0;2XX22X1XX12X2X +2014;6;2;13;451480;21X1222111XX1X +2014;6;1;3;3247775;1X22122XX21111 +2014;5;2;0;0;1112121X12111X +2014;5;1;0;0;1XX111X1121221 +2014;4;2;1;17008970;X12212XX22X1X1 +2014;4;1;0;0;12212121122212 +2014;3;2;0;0;1112X211121X21 +2014;3;1;288;8895;11111211211112 +2014;2;2;31;377905;X2111122XX1221 +2014;2;1;0;0;1121122X111X11 +2014;1;2;0;0;12X12211212X11 +2014;1;1;1;2935825;1X112X21X221X2 +2013;52;2;35;208360;12X1X121XX1211 +2013;52;1;0;0;2221212X11XXX1 +2013;51;2;1;17653090;2211XXX121X221 +2013;51;1;0;0;212X21111121X2 +2013;50;2;0;0;11XXX112211121 +2013;50;1;1;8426035;1122112112111X +2013;49;2;0;0;21212222XXX11X +2013;49;1;1;11423190;21121122X21212 +2013;48;2;0;0;21XX111XX2XXX1 +2013;48;1;7;3076015;11X11222111112 +2013;47;2;0;0;2XX1212X2X121X +2013;47;1;0;0;X1211X1X221222 +2013;46;2;0;0;X1111121X2XXXX +2013;46;1;1;1674030;21111111X12121 +2013;45;2;2;7592625;111121121XX111 +2013;45;1;0;0;XXX1X21X111112 +2013;44;2;0;0;1221221122122X +2013;44;1;1;2889445;21XXX2X111X2X1 +2013;43;2;28;218915;21121211111121 +2013;43;1;3;4136515;22222X12111X21 +2013;42;2;0;0;112XX1X211111X +2013;42;1;0;0;21X1X21X2X1111 +2013;41;2;426;29905;11X22111111X11 +2013;41;1;0;0;12212X2221112X +2013;40;2;0;0;X11X2X21X1XX21 +2013;40;1;2;1362765;211222X12XX112 +2013;39;2;4;6786720;1111XXX2212XX2 +2013;39;1;0;0;111121X12XX21X +2013;38;2;0;0;2X22XX211211X2 +2013;38;1;0;0;1122X222121111 +2013;37;2;0;0;21112111XX1X12 +2013;37;1;25;424690;2212111X2121X1 +2013;36;2;0;0;1X22XX2211XX22 +2013;36;1;0;0;XXX11X12111X21 +2013;35;2;521;14430;11111221111122 +2013;35;1;0;0;1112X22XX11222 +2013;34;2;4;1437930;1111211212111X +2013;34;1;0;0;212XX222XX1X1X +2013;33;2;1;7658355;2122121X122112 +2013;33;1;0;0;XX112X211X1X12 +2013;32;2;8;838485;2111X21X211112 +2013;32;1;0;0;1X2XX1X212X2X1 +2013;31;2;1;2956180;1121221X12X222 +2013;31;1;2;22168780;XX1X122XX11211 +2013;30;2;0;0;1X1211211X11X2 +2013;30;1;0;0;11X11121X2222X +2013;29;2;0;0;12XXX2122121X1 +2013;29;1;0;0;2122X12X2X1112 +2013;28;2;0;0;1121X1122XX2X1 +2013;28;1;0;0;X1211XX1221212 +2013;27;2;0;0;1X122X2121121X +2013;27;1;0;0;22XXX12222122X +2013;26;2;0;0;12111X2X1X11X1 +2013;26;1;0;0;1X1121122X111X +2013;25;2;5;1184815;12111X21X112X2 +2013;25;1;0;0;11111112XX2222 +2013;24;2;6;2200140;11XX11X1221121 +2013;24;1;0;0;X21X21X1111X21 +2013;23;2;0;0;2XX21X1221X21X +2013;23;1;1;2363840;11211X12121111 +2013;22;2;1;4525310;11121X1X11211X +2013;22;1;1;37798765;21X212X21211X2 +2013;21;2;0;0;222XX111X1112X +2013;21;1;0;0;12111XX1X21121 +2013;20;2;0;0;221X212X222111 +2013;20;1;0;0;22X11211112X21 +2013;19;2;0;0;11222XX21X1X22 +2013;19;1;0;0;2222X22X12X211 +2013;18;2;0;0;2X2XXX12111X21 +2013;18;1;5;445420;12X1X1112X2211 +2013;17;2;12;3369780;1112X1X21221X1 +2013;17;1;0;0;1121111211XX12 +2013;16;2;0;0;21112111X11X21 +2013;16;1;0;0;11X111X1X222X2 +2013;15;2;0;0;1X22XX11212X2X +2013;15;1;0;0;11X22X21122X1X +2013;14;2;0;0;22X1121X1XX112 +2013;14;1;0;0;X112X22X1211X1 +2013;13;2;2;2892680;21X11X2X122112 +2013;13;1;3;4250130;X1X112X1X2X11X +2013;12;2;0;0;X122X112X2211X +2013;12;1;0;0;21XX122X21X21X +2013;11;2;4;8789465;11XX2212112111 +2013;11;1;0;0;12211X1X12X111 +2013;10;2;0;0;1112XX2X1121X2 +2013;10;1;0;0;211XX1X21211X1 +2013;9;2;0;0;1122X12X12121X +2013;9;1;0;0;221112111122XX +2013;8;2;3;1794275;11X1X1XX12X11X +2013;8;1;1;57145865;1X2222X11X1X11 +2013;7;2;0;0;X11121X2X11X11 +2013;7;1;0;0;XX11222X2X1XX1 +2013;6;2;0;0;2X212X1X1XX111 +2013;6;1;0;0;1211X2X2111112 +2013;5;2;0;0;221121212111X1 +2013;5;1;0;0;1XXX2X1X11X11X +2013;4;2;0;0;X211X122XX122X +2013;4;1;0;0;X1X1X11XX11X1X +2013;3;2;28;205550;111XX2XX1X11XX +2013;3;1;0;0;1X22X2X211XXXX +2013;2;2;5;951425;2X11211X1111X2 +2013;2;1;5;267050;1121111211111X +2013;1;2;1;4726460;12XXX111211121 +2013;1;1;10;93050;1X11221X11111X +2012;52;2;1;5753060;12221XX2211X11 +2012;52;1;0;0;121X2X1211X221 +2012;51;2;3;1798265;2X221121X12111 +2012;51;1;0;0;22211111X1X222 +2012;50;2;2;3611755;111222X1111121 +2012;50;1;0;0;222X1111X21X21 +2012;49;2;5;1220970;22111111122211 +2012;49;1;0;0;1X12X11112122X +2012;48;2;13;652385;1X112X2X11211X +2012;48;1;0;0;X21121121XX121 +2012;47;2;0;0;21XXX1X21X21X1 +2012;47;1;25;343470;12X111X221112X +2012;46;2;0;0;X12112112XXXX1 +2012;46;1;0;0;221X22X12222XX +2012;45;2;1;26595620;1121221X2X2211 +2012;45;1;0;0;XXX1XX11111112 +2012;44;2;0;0;X1X11211121XX1 +2012;44;1;0;0;11111X1X1X112X +2012;43;2;0;0;211X1221221X22 +2012;43;1;0;0;1211122111XX11 +2012;42;2;0;0;22X121X2111112 +2012;42;1;0;0;12X221211X1X12 +2012;41;2;1;5669400;22X2X2X2X12111 +2012;41;1;0;0;112XX1221211X2 +2012;40;2;20;157880;112111XX12122X +2012;40;1;1;2598185;22X1122211X2X1 +2012;39;2;2;7796475;221111222X1121 +2012;39;1;0;0;X212221XXX1122 +2012;38;2;0;0;211XX1121XX2X2 +2012;38;1;4;1223835;12122X111X112X +2012;37;2;0;0;1121X211222122 +2012;37;1;2;976360;211112X1X12X2X +2012;36;2;1;3386170;12X22X2221X111 +2012;36;1;0;0;XX2121X2X112X1 +2012;35;2;7;1355555;1X11X212211221 +2012;35;1;0;0;1X2XX112X12121 +2012;34;2;0;0;122212XX12X222 +2012;34;1;4;4712635;1111111XX1111X +2012;33;2;0;0;2111X112X1121X +2012;33;1;0;0;X22X22112X11X2 +2012;32;2;0;0;11X1122X222221 +2012;32;1;0;0;221222X21122X2 +2012;31;2;0;0;221X1122112X12 +2012;31;1;0;0;X21XX2111XXXX1 +2012;30;2;0;0;X21222X1111121 +2012;30;1;1;7406830;111X111221X12X +2012;29;2;0;0;212212X1X22121 +2012;29;1;0;0;111111X2X1X112 +2012;28;2;0;0;11X121XX2X2112 +2012;28;1;4;5702540;X2X1X1111X1111 +2012;27;2;0;0;1XX12211XX1111 +2012;27;1;0;0;1X21X11XXX1122 +2012;26;2;0;0;21211X21122211 +2012;26;1;0;0;X1X112X1X12112 +2012;25;2;0;0;11211X2X222XXX +2012;25;1;0;0;1221111X22121X +2012;24;2;0;0;212112111X1111 +2012;24;1;0;0;2X22X1X12X2121 +2012;23;2;0;0;21X2212X111211 +2012;23;1;1;4365570;11X11121X111XX +2012;22;2;0;0;11X121X2XXX212 +2012;22;1;9;709000;1121211111X211 +2012;21;2;0;0;211X11121X22X1 +2012;21;1;0;0;X1X11X11X11222 +2012;20;2;1;4989465;X1122212112212 +2012;20;1;0;0;X122111211XX2X +2012;19;2;116;46945;1X111211211121 +2012;19;1;0;0;1X11112X221122 +2012;18;2;4;1333275;221211121X1211 +2012;18;1;0;0;121212222XXX11 +2012;17;2;18;1129685;21X11X121X2121 +2012;17;1;0;0;X122111X222221 +2012;16;2;0;0;222XX21X11X22X +2012;16;1;0;0;11X11XXX2111X1 +2012;15;2;0;0;2X12X12X112X22 +2012;15;1;1;8677335;11111X11121122 +2012;14;2;0;0;2X121X112X1X1X +2012;14;1;6;2057765;1111221111X1X2 +2012;13;2;0;0;2222121XX11111 +2012;13;1;0;0;22212XX21X212X +2012;12;2;0;0;1221X1121XX1X1 +2012;12;1;0;0;1222X1221X211X +2012;11;2;1;3196965;112222212221XX +2012;11;1;22;964175;11111111X11122 +2012;10;2;0;0;11X1X1111211X2 +2012;10;1;0;0;11121X1XXXXXX1 +2012;9;2;0;0;1XX112112X222X +2012;9;1;0;0;XX22X2222XXX12 +2012;8;2;0;0;2112211X112112 +2012;8;1;0;0;11112212121X12 +2012;7;2;2;5044360;21221X11221X11 +2012;7;1;0;0;2111XX1212X21X +2012;6;2;0;0;111XX121212221 +2012;6;1;4;3852865;2X222212X11122 +2012;5;2;0;0;XX2XXXX2211XXX +2012;5;1;0;0;X1X1X1X12112XX +2012;4;2;0;0;112XX2121X1112 +2012;4;1;0;0;1211X1X111112X +2012;3;2;765;12235;111X211212X211 +2012;3;1;0;0;212X1X112XX112 +2012;2;2;1;5661790;1X1XX111121X12 +2012;2;1;3;588625;1X211211211211 +2012;1;2;1;3580880;111121122221XX +2012;1;1;1;10512720;X11111X1112121 +2011;52;1;0;0;1X2XXX2111X211 +2011;51;2;0;0;12X1XX21X121XX +2011;51;1;2;7731015;1112X1XX112X22 +2011;50;2;0;0;2X21X1X111212X +2011;50;1;0;0;X21X11121X2121 +2011;49;2;0;0;111X2XX2221X1X +2011;49;1;0;0;1X21X1X212X122 +2011;48;2;3;2695415;1XXXXX1122111X +2011;48;1;0;0;212XXX11XX2122 +2011;47;2;2;11095065;1X11X111X2121X +2011;47;1;0;0;11X2XX1X111222 +2011;46;2;0;0;112X21121XX112 +2011;46;1;0;0;1112121XXX2X12 +2011;45;2;0;0;X21212XX12X1X1 +2011;45;1;0;0;1XX122X122X121 +2011;44;2;2;1744145;112X2XX2211112 +2011;44;1;4;592830;211XX1121X1111 +2011;43;2;2;1963030;11X2121X212112 +2011;43;1;3;1924950;1X211X1X122X1X +2011;42;2;0;0;XX1212X2X211X2 +2011;42;1;11;725035;1X22221112X111 +2011;41;2;0;0;1X211221112XX1 +2011;41;1;0;0;X1121111121X12 +2011;40;2;21;275090;22X21X121X1112 +2011;40;1;0;0;X21XX2X21X1X1X +2011;39;2;1;4113010;11X1X112122111 +2011;39;1;1;1799150;11X11X112111XX +2011;38;2;38;302280;11211112X1XXX2 +2011;38;1;0;0;X11221X1X211XX +2011;37;2;0;0;X22X11121X2121 +2011;37;1;0;0;1XX211X2X2XX2X +2011;36;2;1;4076475;12211121112221 +2011;36;1;67;28205;22111XXX11111X +2011;35;2;2;2771145;1212X22121221X +2011;35;1;0;0;2XXX11X2X22211 +2011;34;2;5;1016090;21212XX1111221 +2011;34;1;2;12201740;11211X11222212 +2011;33;2;0;0;12121X22122X2X +2011;33;1;0;0;1X2X111111X221 +2011;32;2;0;0;2X1212XX1XX21X +2011;32;1;0;0;112211X1X2X1XX +2011;31;2;0;0;2X11121222XX21 +2011;31;1;0;0;X11211XXX2X2X1 +2011;30;2;0;0;X2XX1112121212 +2011;30;1;1;15733595;1X1X122XXXX1X1 +2011;29;2;0;0;21XX2X2X2X2121 +2011;29;1;0;0;1111X2121XX111 +2011;28;2;0;0;1211122X111111 +2011;28;1;31;343795;112X11X1211XX2 +2011;27;2;0;0;X11X1X121X1X11 +2011;27;1;0;0;1111X22211X1X2 +2011;26;2;0;0;21X1X11111212X +2011;26;1;2;5097410;X121121X211221 +2011;25;2;0;0;1111221211X21X +2011;25;1;0;0;1XX211X21X1XX1 +2011;24;2;0;0;222221X22X11X1 +2011;24;1;2;2270385;11111X12111122 +2011;23;2;0;0;XXX1112112X1X1 +2011;23;1;25;65675;21121X112XX11X +2011;22;2;1;3522690;2122XX1XX221X2 +2011;22;1;0;0;11X11XX2121X11 +2011;21;2;11;547115;1221X121X21112 +2011;21;1;0;0;2122X11X22111X +2011;20;2;2;8502935;2121X11112X2XX +2011;20;1;0;0;1121X2111111X1 +2011;19;2;0;0;1112X12112111X +2011;19;1;0;0;X1111XX1XX11X1 +2011;18;2;0;0;1X2221212X1111 +2011;18;1;0;0;X21X211X21X111 +2011;17;2;7;659140;11222112111111 +2011;17;1;41;362825;22112111211111 +2011;16;2;0;0;1122X221X2111X +2011;16;1;0;0;22X1X1222XX12X +2011;15;2;0;0;2X2X11211XX1X2 +2011;15;1;0;0;121221X2X22X2X +2011;14;2;8;2400400;11X1X211121122 +2011;14;1;0;0;21211111X11X11 +2011;13;2;0;0;1X12XX1X111X12 +2011;13;1;0;0;1XX22X222XX1X2 +2011;12;2;0;0;22121X2X1X1XXX +2011;12;1;0;0;1X1X12X2X11X21 +2011;11;2;12;1289070;21112X1X11X111 +2011;11;1;0;0;21X1X211X112X1 +2011;10;2;0;0;11112X221XX212 +2011;10;1;0;0;111X2X22X12111 +2011;9;2;1;8819760;X1111122211X11 +2011;9;1;0;0;1211121XXX1112 +2011;8;2;2;4552095;122XX22X2XX122 +2011;8;1;0;0;2X2X11211X11X2 +2011;7;2;9;926410;1111X2111121X1 +2011;7;1;0;0;2X2122212XX2XX +2011;6;1;1;18959630;12122X1X122211 +2011;5;1;0;0;11X112XX12XX21 +2011;4;1;0;0;21212222122112 +2011;3;1;0;0;1XX221211X21XX +2011;2;1;1;13338195;11X22XX11121XX +2011;1;1;0;0;121X122XX12X21 +2010;52;1;13;1594100;21111112X11122 +2010;51;1;0;0;22X1X122111122 +2010;50;1;0;0;2111X2X221X111 +2010;49;1;0;0;12XX11121XX21X +2010;48;1;8;644790;112XX112X11212 +2010;47;1;2;9767920;11X111XXX1X111 +2010;46;1;0;0;221221X21121XX +2010;45;1;0;0;X2X2X2211X11X2 +2010;44;1;0;0;111X121X212111 +2010;43;1;2;5274225;21121221222211 +2010;42;1;0;0;X1121X21XX112X +2010;41;1;40;1386730;1121X221121111 +2010;40;1;0;0;122XX211221112 +2010;39;1;0;0;111X121X2X211X +2010;38;1;0;0;212X2112XX1X22 +2010;37;1;0;0;X2X11XX22X2212 +2010;36;1;0;0;11XX2X1111111X +2010;35;1;0;0;121222X2X11XX2 +2010;34;1;0;0;122222222X1X11 +2010;33;1;0;0;11112X111221X2 +2010;32;1;40;166360;122222211XX11X +2010;31;1;0;0;122122122X21X1 +2010;30;1;1;6921055;111XX11X1XX11X +2010;29;1;0;0;2212211X222X12 +2010;28;1;1;13290615;X2111XX11XX211 +2010;27;1;0;0;X21221XXX22212 +2010;26;1;0;0;2211X221X12122 +2010;25;1;1;11264620;1X111X2X2X21X2 +2010;24;1;0;0;1X22X222X11111 +2010;23;1;0;0;11X222122111X1 +2010;22;1;143;24305;111111X1X11X11 +2010;21;1;1;5522905;2X1111111XXX12 +2010;20;1;6;752125;22XX11212XX11X +2010;19;1;56;218220;2221X12111121X +2010;18;1;0;0;2X12XXX111121X +2010;17;1;1;22323975;1X211XX2X12X22 +2010;16;1;0;0;21XX21111121X2 +2010;15;1;0;0;121121XXX12112 +2010;14;1;0;0;11221X222X11X1 +2010;13;1;3;13474560;112211221XX11X +2010;12;1;0;0;212X22X11X1111 +2010;11;1;0;0;111X11X21X1X11 +2010;10;1;0;0;221212121X2X11 +2010;9;1;0;0;X21X11122X111X +2010;8;1;0;0;X22X1X21X1X122 +2010;7;1;0;0;1X2X2X11X211X2 +2010;6;1;29;372760;12X1211111112X +2010;5;1;0;0;XX1X2212XX1112 +2010;4;1;1;15126710;12X1111XXX212X +2010;3;1;0;0;X21X1X222X2121 +2010;2;1;1;5340475;1121211X112112 +2010;1;1;4;2456160;XXXX11211111X2 +2009;53;1;0;0;1211X1221X1X1X +2009;52;1;22;1802690;XX1X1XX11X1112 +2009;51;1;0;0;11X21111112111 +2009;50;1;0;0;22X12X21X1122X +2009;49;1;0;0;11XXXXX1111111 +2009;48;1;0;0;X22X1121211222 +2009;47;1;0;0;221X2XX2221X11 +2009;46;1;2;2998620;X21111XX221211 +2009;45;1;1;18014240;X221XXX221221X +2009;44;1;0;0;22XXXX221121X1 +2009;43;1;0;0;111X2X11212212 +2009;42;1;46;107070;112X11211X2X11 +2009;41;1;8;2351060;1111212121111X +2009;40;1;0;0;XX1112221XX111 +2009;39;1;0;0;122211112XXX11 +2009;38;1;3;1929535;1X22X2XX2X1111 +2009;37;1;1;5293855;122211121X12X2 +2009;36;1;6;3759720;2X1XX211X122X2 +2009;35;1;0;0;11X212X2122211 +2009;34;1;0;0;1X2X12122X1111 +2009;33;1;0;0;XX1X2111122211 +2009;32;1;0;0;211XX2XX121X1X +2009;31;1;11;811465;22222X2X222112 +2009;30;1;0;0;X121221111XX21 +2009;29;1;1;16865450;1X12112212111X +2009;28;1;0;0;11XXX1112X2221 +2009;27;1;0;0;111XX22212XX11 +2009;26;1;0;0;11X12X1XX122X2 +2009;25;1;1;8772870;22XX111XXXX122 +2009;24;1;0;0;12111X211XX1X2 +2009;23;1;7;879945;222X21XX2X1212 +2009;22;1;68;260225;12121111XX11X1 +2009;21;1;0;0;1X121XX211X222 +2009;20;1;0;0;12122XX1111XX1 +2009;19;1;2;2351130;21111112X2X21X +2009;18;1;1;21294400;1X2211X121XX11 +2009;17;1;0;0;21112111121XX1 +2009;16;1;0;0;2222X1112X111X +2009;15;1;1;13193530;21X1X1111212X1 +2009;14;1;0;0;2112112X2X1X12 +2009;13;1;1;8732715;22XX1X2222X211 +2009;12;1;1;7112785;121XX12121112X +2009;11;1;12;4271020;2XX11112XX2121 +2009;10;1;0;0;12X111XXX22212 +2009;9;1;0;0;X211X2211X21XX +2009;8;1;0;0;2121X121221212 +2009;7;1;0;0;1X2X1XX1X1XXX1 +2009;6;1;0;0;X12X11112X211X +2009;5;1;0;0;X111X12X21XX12 +2009;4;1;1;24625090;X1XX212X2X2111 +2009;3;1;0;0;2122111121222X +2009;2;1;0;0;1XX11XX21112XX +2009;1;1;0;0;1XXX2X2X211112 +2008;52;1;1;14475770;2121X11X11X1XX +2008;51;1;0;0;12X1122X12X211 +2008;50;1;1;4919340;211X1XXX111XX1 +2008;49;1;8;1785500;X2112121222122 +2008;48;1;0;0;11122XX1111221 +2008;47;1;0;0;121211111XX2XX +2008;46;1;1;10616350;11111XX1211121 +2008;45;1;0;0;2X1X1X121X211X +2008;44;1;1;12176930;112112X22111X1 +2008;43;1;0;0;12XXX1112X2122 +2008;42;1;3;2142295;X212121X211111 +2008;41;1;263;53835;1X11121XX1X1X1 +2008;40;1;0;0;X2212XX121212X +2008;39;1;1;7239005;211112X1X12121 +2008;38;1;8;736595;21211111212XX1 +2008;37;1;2;9152310;12X1XX11111111 +2008;36;1;0;0;XX2XX12111X1X2 +2008;35;1;0;0;22111X111X22XX +2008;34;1;0;0;XX1X12XX12121X +2008;33;1;1;5516205;X22112211211X2 +2008;32;1;55;86640;2221X121X22112 +2008;31;1;3;1014255;121XX11X111112 +2008;30;1;8;439415;2X1112111112X1 +2008;29;1;3;1338020;X12X1112112111 +2008;28;1;2;8254645;211X1222221XX1 +2008;27;1;0;0;2212XX2XX12111 +2008;26;1;0;0;11212211XXX212 +2008;25;1;0;0;XX121X2212X2XX +2008;24;1;2;4191315;2211122X11X111 +2008;23;1;0;0;2121X12211X111 +2008;22;1;10;878880;11XX11X11X2X1X +2008;21;1;0;0;1111X121XX2222 +2008;20;1;4;5730555;12211122XXX221 +2008;19;1;0;0;X112122112XX11 +2008;18;1;0;0;1112X11121211X +2008;17;1;6;3542530;X12XXXXX112X11 +2008;16;1;0;0;X2X1X121112122 +2008;15;1;0;0;X11212111X1211 +2008;14;1;26;899005;122111111121X1 +2008;13;1;0;0;X2XX2XXXX22211 +2008;12;1;0;0;1XX1XX21212211 +2008;11;1;0;0;X11X2X21X11111 +2008;10;1;6;2981245;12X111XX212212 +2008;9;1;0;0;1111X2111X2X11 +2008;8;1;0;0;21111XXX1121X1 +2008;7;1;94;206160;1221X11X112112 +2008;6;1;0;0;XXX212XX1112X2 +2008;5;1;0;0;22XX21211X11X2 +2008;4;1;21;330300;X2X111X1X21XX2 +2008;3;1;10;2856260;22211XX21122X2 +2008;2;1;0;0;1X1XX222212221 +2008;1;1;0;0;222X122X1X22XX +2007;52;1;0;0;X12111222X2XXX +2007;51;1;36;196710;11111XXX1XX112 +2007;50;1;2;9667040;11XX11212XX212 +2007;49;1;0;0;XXXX1111111X11 +2007;48;1;2;3643615;11212X1X21X212 +2007;47;1;2;3018343;11222112122XX1 +2007;46;1;2;18382203;12121X11111121 +2007;45;1;0;0;1X11X111221XX2 +2007;44;1;0;0;X11112112X2XXX +2007;43;1;0;0;X1XX11X21122XX +2007;42;1;0;0;211X1XXX2122XX +2007;41;1;2;4074760;1X12XX1X1221X1 +2007;40;1;1;40877715;22X22111X1X212 +2007;39;1;0;0;1XX12112122X12 +2007;38;1;0;0;111122X122XX1X +2007;37;1;0;0;X111X122X1XX22 +2007;36;1;0;0;12XXXX211XX21X +2007;35;1;1;4392526;1X1112X121212X +2007;34;1;19;703931;1111211XX12X22 +2007;33;1;0;0;X22121212XX1X2 +2007;32;1;0;0;1X12X2222X2221 +2007;31;1;4;1382737;X1XXX22X221222 +2007;30;1;5;4187772;111111X212X11X +2007;29;1;0;0;12112111XX2XXX +2007;28;1;0;0;1112221X221221 +2007;27;1;0;0;211221XX21X121 +2007;26;1;0;0;112222X2121X11 +2007;25;1;2;2294309;112XX211112112 +2007;24;1;3;4287161;112222X2X12211 +2007;23;1;0;0;2X2221XX11X21X +2007;22;1;25;247219;112221X2212221 +2007;21;1;66;102542;X1111111112111 +2007;20;1;2;5702257;X12121211221XX +2007;19;1;0;0;X122212121X121 +2007;18;1;1;14206896;12X11222112X2X +2007;17;1;0;0;22122X1112X221 +2007;16;1;0;0;221112X1112122 +2007;15;1;5;2136216;2212111X1X2122 +2007;14;1;0;0;21X1X2222X1121 +2007;13;1;16;347582;1X2X1111XX1X2X +2007;12;1;3;2374328;12122221X2XX11 +2007;11;1;56;214456;1X1X11111X211X +2007;10;1;0;0;12X11XXXXX21X1 +2007;9;1;3;2069012;11121112X12111 +2007;8;1;5;2806932;1X11112X22111X +2007;7;1;0;0;12122X21X11X22 +2007;6;1;1;15438944;1X1X1112X21211 +2007;5;1;0;0;22XX11221XX212 +2007;4;1;12;1197618;X2121121221112 +2007;3;1;0;0;2X211X1111XX1X +2007;2;1;2;6908635;12111X11X21X2X +2007;1;1;0;0;XXX211X21X121X +2006;52;1;0;0;111X11121X1212 +2006;51;1;107;60591;1111X211X21221 +2006;50;1;49;390031;X2X12112X11X21 +2006;49;1;0;0;12XXX112122XX1 +2006;48;1;0;0;XX1121211X12XX +2006;47;1;129;116878;1X211X11112XX2 +2006;46;1;0;0;X122X12X1X211X +2006;45;1;2;3293450;2XX21XX2121112 +2006;44;1;1;32503845;2XX1X11XX1X111 +2006;43;1;0;0;121X2X12212X11 +2006;42;1;0;0;21121XX1111XX1 +2006;41;1;0;0;122X11X21X21X2 +2006;40;1;0;0;2X11121XX11X11 +2006;39;1;1;6868793;111XX112XX211X +2006;38;1;4;1021060;1XXX1X1XX112X1 +2006;37;1;1;35212158;1121111X212212 +2006;36;1;0;0;21XXXXX1121XX1 +2006;35;1;0;0;22222X112XX1X1 +2006;34;1;0;0;X22X12XX122121 +2006;33;1;5;3381878;21XXX12X111112 +2006;32;1;0;0;X111X2X11XX212 +2006;31;1;0;0;21X112X111122X +2006;30;1;2;2420390;X1212212111111 +2006;29;1;1;18376631;XXX12212X12211 +2006;28;1;0;0;X111X21XX121X2 +2006;27;1;0;0;X111XX121X2212 +2006;26;1;0;0;X2X21X11111121 +2006;25;1;1;7405739;1X12X111211121 +2006;24;1;0;0;12XX11122XX1XX +2006;23;1;1;18077092;1X121X1XXXX222 +2006;22;1;0;0;X211111112X112 +2006;21;1;0;0;221X1XX11X212X +2006;20;1;4;1114835;21X111111X22X2 +2006;19;1;5;2446825;12X2X11XX21112 +2006;18;1;0;0;221XXX1X12X121 +2006;17;1;11;978870;21X1X11111X2X2 +2006;16;1;0;0;21211X2XX12XXX +2006;15;1;2;2974153;12XX1XX1XX1X22 +2006;14;1;5;4188707;11221X1X12121X +2006;13;1;0;0;X21111X221XX11 +2006;12;1;0;0;122XXX2X1X1111 +2006;11;1;2;14912713;1112X1212122X1 +2006;10;1;0;0;121XX11112121X +2006;9;1;0;0;2X221X1X12X11X +2006;8;1;8;809552;11122111221212 +2006;7;1;7;1652897;2X211111XX1212 +2006;6;1;0;0;12X211X1XX1222 +2006;5;1;107;128936;11XX1XXX12111X +2006;4;1;0;0;1X1112222X21X2 +2006;3;1;1;6876359;1X21X111X11221 +2006;2;1;3;3573259;12112X1111XXX1 +2006;1;1;0;0;2X22X1X2112X21 +2005;52;1;1;4627759;X11111X12121X2 +2005;51;1;4;2255812;211112XX122121 +2005;50;1;2;4155754;121XX11XXXX2X2 +2005;49;1;6;4222579;1X11XX12121X21 +2005;48;1;0;0;X1222112X2112X +2005;47;1;0;0;X2X1221XXX122X +2005;46;1;0;0;222112XXX1211X +2005;45;1;2;2875239;211X122X2X12X2 +2005;44;1;14;351919;1211111XX2X212 +2005;43;1;9;570980;1111X2X11X111X +2005;42;1;74;172774;11X112XXX1212X +2005;41;1;0;0;112X1XX2221112 +2005;40;1;127;113793;112112X1121222 +2005;39;1;0;0;1X112X21X22211 +2005;38;1;12;1893253;2XX2111X1121X2 +2005;37;1;0;0;X2XX112X2X111X +2005;36;1;0;0;12X212X1X12121 +2005;35;1;16;644366;1212XX1XX22111 +2005;34;1;0;0;X1221X1X2X11X2 +2005;33;1;5;862900;22X112111X1121 +2005;32;1;1;6855568;22112XX2XXX122 +2005;31;1;1;8206030;21X11X1X1X1122 +2005;30;1;0;0;1X2221121XX2X2 +2005;29;1;11;410027;111X11X2XX112X +2005;28;1;1;28507689;2X1X2XX122X112 +2005;27;1;0;0;X2212122X2XX21 +2005;26;1;0;0;22X2X111111122 +2005;25;1;0;0;11122211X21XX1 +2005;24;1;0;0;X221222221X111 +2005;23;1;188;25246;21111111211112 +2005;22;1;86;81693;2211X1X1XX2X11 +2005;21;1;4;1475675;X1X1XXXX1X2X22 +2005;20;1;7;1406235;1112222X1XXXX2 +2005;19;1;0;0;1X1111X2X11XXX +2005;18;1;3;4413383;21211X2X22211X +2005;17;1;0;0;2121X211X11X12 +2005;16;1;3;7847318;11211111X1X112 +2005;15;1;0;0;122X2212221112 +2005;14;1;0;0;X11212212122X2 +2005;13;1;0;0;X212X21211XXX1 +2005;12;1;74;99752;122121221XX111 +2005;11;1;76;94269;11211121111112 +2005;10;1;1;10007401;2X21X1112X1122 +2005;9;1;1;7623373;121211X221112X +2005;8;1;36;177651;11121XXX12X112 +2005;7;1;58;133164;1112X212X1X211 +2005;6;1;215;200908;11X11111111112 +2005;5;1;0;0;1X222XX1211XX1 +2005;4;1;0;0;2X11112X112112 +2005;3;1;0;0;212X12X21X1212 +2005;2;1;0;0;21X1XXXX2111XX +2005;1;1;3;3097985;X2111211X1121X +2004;53;1;0;0;211X211X122212 +2004;52;1;22;319814;X112X112121222 +2004;51;1;23;677483;1X11121X1X2121 +2004;50;1;0;0;X2X22XXX121XX2 +2004;49;1;15;453337;X2211X11211112 +2004;48;1;114;55638;1111222X12211X +2004;47;1;2;8473007;X2111X21112112 +2004;46;1;0;0;X2111212X21X12 +2004;45;1;0;0;111X1X1X1211XX +2004;44;1;1;6056019;212X1211112X11 +2004;43;1;1;5420968;2112X211121XXX +2004;42;1;3;2001352;2121111121212X +2004;41;1;1;9859514;11211X22XXX1X1 +2004;40;1;0;0;X122X21121XX2X +2004;39;1;1;27910016;12121111X12XX2 +2004;38;1;0;0;12X1X1X21XX211 +2004;37;1;0;0;112X11X112X212 +2004;36;1;0;0;12XX2X2X1X2112 +2004;35;1;0;0;11X12X1X2122X1 +2004;34;1;24;1183580;2X11X2121121X1 +2004;33;1;0;0;2XX12X21X21X21 +2004;32;1;0;0;21222X2X21X1X1 +2004;31;1;0;0;21X1X1111XXX1X +2004;30;1;0;0;1X122X121X112X +2004;29;1;8;420354;2XX1211211XXXX +2004;28;1;6;951244;12X1X111211112 +2004;27;1;0;0;21111X2X122X2X +2004;26;1;2;4530240;222121X1111121 +2004;25;1;0;0;X21112111X1X12 +2004;24;1;1;7791455;21XX12X1XX21X1 +2004;23;1;0;0;221211XXX12X1X +2004;22;1;2;1826296;2111X2X1121222 +2004;21;1;23;421079;1111X111X11X12 +2004;20;1;0;0;22211XX11212X1 +2004;19;1;9;1077812;21111111111121 +2004;18;1;0;0;X2212XX111112X +2004;17;1;12;396807;1211121X11X1XX +2004;16;1;5;988016;121X211X22111X +2004;15;1;446;12080;1121121211X122 +2004;14;1;6;822695;XX1X2X121212X1 +2004;13;1;1;17267105;X2212X1111X22X +2004;12;1;0;0;1XXX12XX2X121X +2004;11;1;0;0;X1X1121111XXX2 +2004;10;1;6;824231;XXX2X1212X2X11 +2004;9;1;1;14005753;1X1112X2112112 +2004;8;1;0;0;112X1X12122X11 +2004;7;1;1;11234567;1X21X2X12X2X21 +2004;6;1;0;0;X1221X211212X1 +2004;5;1;8;1941983;11X11111121X11 +2004;4;1;0;0;11212X1112XXXX +2004;3;1;0;0;2X112XXX121212 +2004;2;1;2;2218957;12212X1121221X +2004;1;1;1;3762554;11X11222X21X12 +2003;52;1;1;11739646;121X12122112XX +2003;51;1;0;0;XX212221X2XXX1 +2003;50;1;8;622702;11X22X11X221X1 +2003;49;1;1;21987918;XXX12X11X21212 +2003;48;1;0;0;1X2X1XX11121X2 +2003;47;1;0;0;X1X1X221212212 +2003;46;1;0;0;12X221XX112X12 +2003;45;1;167;54765;X2X211211X1X21 +2003;44;1;0;0;121X1111X2X222 +2003;43;1;23;291032;1XX2X211121X2X +2003;42;1;2;2239079;122212X122XX11 +2003;41;1;18;305979;2221111X12XX12 +2003;40;1;6;739375;211111212111X2 +2003;39;1;5;2793414;111X2X21X222XX +2003;38;1;0;0;22XX11121212XX +2003;37;1;0;0;121121X222122X +2003;36;1;7;650288;2X122X22X11112 +2003;35;1;1;3826346;1X1111XX222X12 +2003;34;1;1;6178312;11112X11X11112 +2003;33;1;53;247563;11X212111111X2 +2003;32;1;0;0;X1X21XX1XX2X2X +2003;31;1;0;0;2X22221X112211 +2003;30;1;3;1006730;21X12X12112122 +2003;29;1;1;3026804;22121X12122111 +2003;28;1;1;3061202;X2X1111XXX2X11 +2003;27;1;1;2997616;11X11X1221111X +2003;26;1;1;2941880;XX11X1XX2X1112 +2003;25;1;1;9685586;XX12X111211222 +2003;24;1;0;0;111X11X212X1X2 +2003;23;1;2;2196196;1X1112X212X11X +2003;22;1;1;3664138;1X121X1211XXXX +2003;21;1;4;1265380;12122X12121111 +2003;20;1;4;7309563;21X1XX11X12211 +2003;19;1;0;0;212XXX111212X2 +2003;18;1;0;0;2X1X1XX2XX222X +2003;17;1;0;0;121XX2X11XXXXX +2003;16;1;0;0;1112211121X212 +2003;15;1;1;4838119;21X1111121X1XX +2003;14;1;1;9799002;21X22X1X1111XX +2003;13;1;0;0;X2X111X2111211 +2003;12;1;1;4904852;XX211X11111111 +2003;11;1;1;4331542;12221X12X11212 +2003;10;1;4;5829331;11111X112XXX2X +2003;9;1;0;0;21XXX21X1XX111 +2003;8;1;0;0;221XXX2211X111 +2003;7;1;0;0;X1221121XX21XX +2003;6;1;2;2504909;121111X1XXXX1X +2003;5;1;2;5305601;XXX1111221XX12 +2003;4;1;0;0;XX1222121XX111 +2003;3;1;1;4940615;2121111111X1X2 +2003;2;1;1;4532483;XX2X1X2XX12X12 +2003;1;1;1;11558336;21X2X111111112 +2002;52;1;0;0;1X1X2111112X2X +2002;51;1;2;11663039;22X1XX211111X2 +2002;50;1;0;0;X1X2X2X12212X2 +2002;49;1;0;0;11X2XX21X1111X +2002;48;1;0;0;211221222XX22X +2002;47;1;1;5156287;111X22XX1X1X11 +2002;46;1;4;5722258;X1112X2X1X2112 +2002;45;1;0;0;X111122112XX11 +2002;44;1;0;0;12X121X1X22221 +2002;43;1;0;0;X1112X2XX1111X +2002;42;1;145;95370;11221X1212X211 +2002;41;1;0;0;X212222122XX1X +2002;40;1;105;86483;X1X21211111121 +2002;39;1;0;0;11121112XX211X +2002;38;1;1;8778074;211111X1X22111 +2002;37;1;0;0;2112122X2XX221 +2002;36;1;2;6063120;2X22X12X122212 +2002;35;1;0;0;11X1121X1X11X2 +2002;34;1;0;0;1X2X12122111XX +2002;33;1;9;1284668;X111112X2X1112 +2002;32;1;0;0;2211X2X1X11121 +2002;31;1;0;0;1X1XX22121XX21 +2002;30;1;1;3037903;1X1X11XX1X1X21 +2002;29;1;6;985319;1122111X112X21 +2002;28;1;0;0;21XX11X221X122 +2002;27;1;58;217225;1221X111111111 +2002;26;1;0;0;X11X221X1X1X22 +2002;25;1;0;0;211121XX221221 +2002;24;1;1;10316722;XXX1112112XX11 +2002;23;1;0;0;1X12112X12X11X +2002;22;1;0;0;XX11X122122X21 +2002;21;1;1;3784457;1121211X112121 +2002;20;1;7;1272516;111XX11X1XX111 +2002;19;1;0;0;112111X1X1X121 +2002;18;1;11;4257170;11112121111222 +2002;17;1;0;0;21X2X2X1211122 +2002;16;1;0;0;X1X21XX1X1X21X +2002;15;1;0;0;2121X221X22111 +2002;14;1;0;0;2X111X2XXXX122 +2002;13;1;0;0;2X11X21121X12X +2002;12;1;0;0;1X1X2221111221 +2002;11;1;2;2437909;112XX1222XX2X1 +2002;10;1;8;1366253;XX1112111X1X12 +2002;9;1;0;0;211X2X11X21X12 +2002;8;1;1;31833810;1X21X1221X122X +2002;7;1;0;0;2121XXXXX2122X +2002;6;1;0;0;X1111112X1XX1X +2002;5;1;0;0;1212XX1X2XXX1X +2002;4;1;0;0;12111111211X12 +2002;3;1;18;280404;21111XX11X11XX +2002;2;1;1;5673229;XXXX111211112X +2002;1;1;11;1998996;22121121XXXX22 +2001;52;1;0;0;1X2X2122X21212 +2001;51;1;0;0;2X2111222X1X12 +2001;50;1;0;0;XXX111X211X111 +2001;49;1;3;1597154;21222XX121122X +2001;48;1;3;6771515;XX12122122111X +2001;47;1;0;0;X12X12XX211221 +2001;46;1;0;0;222211X2X121X1 +2001;45;1;0;0;122X1X12XXX111 +2001;44;1;11;1465811;X1X11111XX2X11 +2001;43;1;0;0;2X1X222X1XX122 +2001;42;1;0;0;X12211112X21X2 +2001;41;1;3;1390782;1X121212X1XXX2 +2001;40;1;3;2927875;1X112212X1XX2X +2001;39;1;0;0;12X11121121X21 +2001;38;1;2;4220839;12X12211XX2121 +2001;37;1;0;0;1X21XX22111X11 +2001;36;1;1;20351926;2XX12XX2121XX2 +2001;35;1;0;0;2221112212XXX1 +2001;34;1;0;0;2X11X1X211XXXX +2001;33;1;0;0;21X212222XX222 +2001;32;1;2;1890774;1X2X112X1XX2X1 +2001;31;1;61;58779;1112121X121112 +2001;30;1;1;3444703;2112111112XX21 +2001;29;1;1;3290823;1XX12X2X1222X1 +2001;28;1;2;4850359;1211XX21122111 +2001;27;1;0;0;112X1X12X2X222 +2001;26;1;0;0;1X11X211111112 +2001;25;1;4;743068;12112211111XX2 +2001;24;1;725;12793;21121121111211 +2001;23;1;0;0;21122X1XX2X2XX +2001;22;1;36;125119;1XX22112X1XXX2 +2001;21;1;13;328818;2X1111X121XX1X +2001;20;1;10;501566;X11X1X1212211X +2001;19;1;3;6242864;X2X211212XX211 +2001;18;1;0;0;2111XX1X2111X1 +2001;17;1;0;0;X11X121X12X11X +2001;16;1;8;618381;212X111111XX2X +2001;15;1;2;2619833;2221XX22111211 +2001;14;1;11;2199469;21XXX111112X2X +2001;13;1;0;0;2211221XXX2XX1 +2001;12;1;0;0;X2XX12X2XX11X2 +2001;11;1;0;0;21XX2X21X2X2X1 +2001;10;1;26;1637125;12X1X1X1111X1X +2001;9;1;0;0;121111221XX211 +2001;8;1;0;0;X21X22XX111121 +2001;7;1;0;0;1121X122X212X1 +2001;6;1;0;0;112111X21X11X2 +2001;5;1;0;0;12122122122221 +2001;4;1;19;245998;11X121X2X21122 +2001;3;1;1;15019299;2X11X12X2X1221 +2001;2;1;0;0;X2211111X2122X +2001;1;1;0;0;1X2121211222XX +2000;52;1;1;8147319;X1212X1111XXXX +2000;51;1;0;0;112111XX12X112 +2000;50;1;1;4356614;21XX21211222X2 +2000;49;1;106;89775;1111X11X1X1121 +2000;48;1;0;0;1X1211111XX21X +2000;47;1;1;4436234;21X12111121X11 +2000;46;1;3;4546144;2X21X1X11X1X21 +2000;45;1;0;0;1X2X1111X2XXXX +2000;44;1;11;1928029;1111X1XX22221X +2000;43;1;0;0;X21X1X211X111X +2000;42;1;0;0;1X11121X2X2211 +2000;41;1;0;0;12X11X211X1X22 +2000;40;1;6;665086;21X2XX2X222111 +2000;39;1;1;7230157;1X2X21XX111X11 +2000;38;1;0;0;XX2X2222XXX11X +2000;37;1;1;7227304;2111X121XX1211 +2000;36;1;0;0;2211XXXX2X22X1 +2000;35;1;1;7372953;X12212222X2X2X +2000;34;1;0;0;1XX1221XXXX221 +2000;33;1;1;3257261;X1211X1122X111 +2000;32;1;1;9720434;1211X1112X1112 +2000;31;1;0;0;121X2XX11121XX +2000;30;1;0;0;2XXXX221XX1X12 +2000;29;1;1;3085471;22112211X21X21 +2000;28;1;6;990021;122X11XX1112XX +2000;27;1;0;0;X21X1211X1112X +2000;26;1;2;1289631;112X111X2X2212 +2000;25;1;1;2568324;XX11221X1121XX +2000;24;1;1;2737191;122221X1XX1122 +2000;23;1;4;895979;1211XXX12X2111 +2000;22;1;18;195869;111X11X121122X +2000;21;1;346;23485;1121111111XX1X +2000;20;1;0;0;11X2X2X1121212 +2000;19;1;3;1532546;2X121X211111X1 +2000;18;1;2;2054949;2211XXX12XX112 +2000;17;1;9;488424;12X21XX111X211 +2000;16;1;39;250738;211X111122XXX2 +2000;15;1;0;0;X11X2X1211XX22 +2000;14;1;2;2494620;121221221X11X2 +2000;13;1;1;17086097;211X2X211XX121 +2000;12;1;0;0;121221X21X11X1 +2000;11;1;0;0;X22112X1212112 +2000;10;1;2;2736451;121XX11X1X2X12 +2000;9;1;9;2023277;12111X12112X12 +2000;8;1;0;0;X1121XXXXX1211 +2000;7;1;0;0;X121XX2X121112 +2000;6;1;1;5400138;XX21112XX1X1X2 +2000;5;1;9;540653;12211111X21XXX +2000;4;1;4;5175187;211X12XX11XX11 +2000;3;1;0;0;X211XX1X211122 +2000;2;1;30;153410;1X1X2X111X2X12 +2000;1;1;3;2693562;111XX22X1XX111 +1999;52;1;0;0;112XX111XX221X +1999;51;1;4;3450052;211X121X1XX121 +1999;50;1;0;0;11X1111XX112X2 +1999;49;1;0;0;XX2211X111XX21 +1999;48;1;13;706900;11X2XX11111121 +1999;47;1;0;0;21X212X211222X +1999;46;1;4;7230177;X21X11X1111X21 +1999;45;1;0;0;2X211XX212X1X2 +1999;44;1;0;0;X1221X11X122X1 +1999;43;1;0;0;XX21X1XXX22X1X +1999;42;1;0;0;XXX2121XX21X2X +1999;41;1;0;0;112X12X2221X11 +1999;40;1;5;808653;X2221X1X11XX11 +1999;39;1;9;1232784;2X1111X1X211X1 +1999;38;1;0;0;X1XXX11X11222X +1999;37;1;5;808159;X2111212X11X21 +1999;36;1;61;67048;12111XX21X111X +1999;35;1;238;16973;12X12112222112 +1999;34;1;2;1995768;X1212XX11XXXX1 +1999;33;1;2;1780244;1112121X121112 +1999;32;1;1;13937871;X1XX1X112111X1 +1999;31;1;0;0;211112X22221XX +1999;30;1;0;0;X2111212112112 +1999;29;1;0;0;1222X122221X2X +1999;28;1;1;3223688;2X211122221212 +1999;27;1;3;1042957;11X1211X12X1X1 +1999;26;1;3;1033323;2221X122222222 +1999;25;1;1;6371952;11X1111X22211X +1999;24;1;0;0;2211222X2112X1 +1999;23;1;5;812564;11112X12X1112X +1999;22;1;1;4319577;X11211X222XXX2 +1999;21;1;2;2435025;2111X211112222 +1999;20;1;19;1663380;1212X1212XX212 +1999;19;1;0;0;12X12X1122X11X +1999;18;1;0;0;X211211X122122 +1999;17;1;0;0;121X11X2111122 +1999;16;1;0;0;22X1122211122X +1999;15;1;0;0;112X11221XX2X1 +1999;14;1;10;918773;11111111211X11 +1999;13;1;0;0;2X2X1X221XX111 +1999;12;1;2;2129421;1212X22X21XX1X +1999;11;1;1;10230448;2211X1212X1112 +1999;10;1;0;0;11XX1111122X2X +1999;9;1;23;224481;2X11111111112X +1999;8;1;3;1637907;X1211XX12X211X +1999;7;1;954;5403;1211X1112111X2 +1999;6;1;6;2496454;XX112121111X1X +1999;5;1;0;0;X1211X1XXX11X2 +1999;4;1;0;0;1X1211112XX211 +1999;3;1;2;2275746;2XX211111X1111 +1999;2;1;6;1648883;1122X1111XX2X2 +1999;1;1;0;0;X1X21X1122X1X1 +1998;53;1;15;488991;2111111211212X +1998;52;1;0;0;11XX122211X212 +1998;51;1;1;4585209;1X1XX2211XXX11 +1998;50;1;69;133620;1X1X112X1X1111 +1998;49;1;0;0;X221112221XXXX +1998;48;1;17;589324;211211111X11XX +1998;47;1;0;0;11X1211XX11XX1 +1998;46;1;2;2436169;2X111122111121 +1998;45;1;26;216082;111211X12XXXXX +1998;44;1;1;40264978;2X212X1111X111 +1998;43;1;0;0;21111XXX211X12 +1998;42;1;0;0;12X22X22X1X1X1 +1998;41;1;0;0;1X211122222XX2 +1998;40;1;0;0;1X2X2XX11XX12X +1998;39;1;0;0;X11X222XX212X1 +1998;38;1;0;0;XX212X2X21XX21 +1998;37;1;13;927276;2111X211X2X1X1 +1998;36;1;0;0;22XXX211121211 +1998;35;1;0;0;211X1X2X2X2222 +1998;34;1;43;241298;1X1211112X1111 +1998;33;1;0;0;X221211XX222X2 +1998;32;1;0;0;211X11XX1121X1 +1998;31;1;143;21576;22211112X11221 +1998;30;1;2;1435474;222X211111X111 +1998;29;1;13;219322;21111XX12211X2 +1998;28;1;1;8820135;22X2211X221111 +1998;27;1;0;0;11X21X211XX121 +1998;26;1;0;0;1221XX2121X12X +1998;25;1;13;239640;X1X112221211X2 +1998;24;1;220;17994;X122X11XX2X112 +1998;23;1;1;3577003;X111X222111X1X +1998;22;1;1;25706480;2X21XX1122121X +1998;21;1;0;0;211111X222121X +1998;20;1;0;0;12X1X112X1222X +1998;19;1;0;0;XX112X121112XX +1998;18;1;0;0;2122X1121X1X21 +1998;17;1;1;5054298;1X21X12X121212 +1998;16;1;1;23932349;21XXX111221XXX +1998;15;1;0;0;X21211X2211XX1 +1998;14;1;0;0;21121X1X2122X2 +1998;13;1;0;0;X2211X11XX12X1 +1998;12;1;1;10461707;X1XX1X1212XX12 +1998;11;1;0;0;21XXX12X1X11X2 +1998;10;1;1;10468576;1121XXX11X1XX1 +1998;9;1;0;0;2X112XXX2211XX +1998;8;1;2;2527169;1X1X1112211X2X +1998;7;1;1;5466543;11X2212X1X1X22 +1998;6;1;9;593967;11X1221211X111 +1998;5;1;50;102994;1111X212X1X22X +1998;4;1;2;5527284;1X112111X11XX1 +1998;3;1;0;0;X22222X1X111X1 +1998;2;1;2;6889159;X2X1X212X21XX1 +1998;1;1;0;0;X1XX2X221X1XX1 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..3f2acec Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/FileContentIndex/91689c28-999b-4eb5-b4d6-381b396f3da5.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/FileContentIndex/91689c28-999b-4eb5-b4d6-381b396f3da5.vsidx new file mode 100644 index 0000000..d0c7b0d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/FileContentIndex/91689c28-999b-4eb5-b4d6-381b396f3da5.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.futdcache.v2 new file mode 100644 index 0000000..8ec046b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.suo new file mode 100644 index 0000000..51dcdbe Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/2024. 01. 22/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.metadata.v7.bin new file mode 100644 index 0000000..4cca1bc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.projects.v7.bin new file mode 100644 index 0000000..de5b393 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/.vs/ProjectEvaluation/2024. 01. 22.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.csproj new file mode 100644 index 0000000..0d76f06 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._01._22 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.sln new file mode 100644 index 0000000..f972553 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/2024. 01. 22.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 01. 22", "2024. 01. 22.csproj", "{6EED3419-5D37-4477-8762-B9886E16A7B2}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {6EED3419-5D37-4477-8762-B9886E16A7B2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {6EED3419-5D37-4477-8762-B9886E16A7B2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {6EED3419-5D37-4477-8762-B9886E16A7B2}.Release|Any CPU.ActiveCfg = Release|Any CPU + {6EED3419-5D37-4477-8762-B9886E16A7B2}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {0CD8D0CC-F5C0-42A0-8A0B-CA4A6840CB97} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Helsinki.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Helsinki.cs new file mode 100644 index 0000000..c8282af --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Helsinki.cs @@ -0,0 +1,147 @@ +namespace _2024._01._22; +using System.IO; + +class Helsinki +{ + private FileStream F; + + public Helsinki(FileStream f) + { + F = f; + } + + // public void Feladat1() + // { + // StreamReader r = new StreamReader(F); + // string line = r.ReadLine(); + // int helyezes = 0; + // while(line != null) + // { + // line = r.ReadLine(); + // helyezes++; + // } + + // System.Console.WriteLine($"Pontszerző helyezések száma: {helyezes}"); + // } + + // public void Feladat2() + // { + // StreamReader r = new StreamReader(F); + // string line = r.ReadLine(); + // int arany = 0; + // int ezust = 0; + // int bronz = 0; + + // while(line != null) + // { + // switch (line[0]) + // { + // case '1': + // arany++; + // break; + // case '2': + // ezust++; + // break; + // case '3': + // bronz++; + // break; + // } + // line = r.ReadLine(); + // } + // System.Console.WriteLine($"Arany: {arany}"); + // System.Console.WriteLine($"Ezüst: {ezust}"); + // System.Console.WriteLine($"Bronz: {bronz}"); + // System.Console.WriteLine($"Összesen: {arany + ezust + bronz}"); + // } + + // public void Feladat3() + // { + // StreamReader r = new StreamReader(F); + // string line = r.ReadLine(); + // int pontszam = 0; + + // while (line != null) + // { + // switch(line[0]) + // { + // case '1': + // pontszam += 7; + // break; + // case '2': + // pontszam += 5; + // break; + // case '3': + // pontszam += 4; + // break; + // case '4': + // pontszam += 3; + // break; + // case '5': + // pontszam += 2; + // break; + // case '6': + // pontszam += 1; + // break; + // } + // line = r.ReadLine(); + // } + // System.Console.WriteLine($"Olimpiai pontok száma: {pontszam}"); + // } + + // public void Feladat4() + // { + // StreamReader r = new StreamReader(F); + // string line = r.ReadLine(); + // int uszas = 0; + // int torna = 0; + + // while (line != null) + // { + // string[] line_list = line.Split(' '); + // if ((line[0] == '1' || line[0] == '2' || line[0] == '3') && line_list[2].Equals("uszas")) + // { + // uszas++; + // } + // else if ((line[0] == '1' || line[0] == '2' || line[0] == '3') && line_list[2].Equals("torna")) + // { + // torna++; + // } + // line = r.ReadLine(); + // } + + // if (uszas > torna) + // { + // System.Console.WriteLine($"Úszás sportágban szereztek több érmet. ({uszas})"); + // } + + // else if (torna > uszas) + // { + // System.Console.WriteLine($"Torna sportágban szereztek több érmet. ({torna})"); + // } + + // else + // { + // System.Console.WriteLine("Egyenlő volt az érmek száma."); + // } + // } + + public void Feladat5() + { + StreamReader r = new StreamReader(F); + string line = r.ReadLine(); + + while (line != null) + { + string[] line_list = line.Split(' '); + FileStream f2 = new FileStream("helsinki2.txt", FileMode.OpenOrCreate, FileAccess.Write); + StreamWriter w2 = new StreamWriter(f2); + if (line_list[2].Equals("kajakkenu")) + { + line_list[2] = "kajak_kenu"; + } + w2.WriteLine(String.Join(' ', line_list)); + w2.Close(); + line = r.ReadLine(); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Program.cs new file mode 100644 index 0000000..f3f0766 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/Program.cs @@ -0,0 +1,11 @@ +namespace _2024._01._22; + +class Program +{ + static void Main(string[] args) + { + FileStream f = new FileStream("helsinki.txt", FileMode.Open, FileAccess.Read); + Helsinki h = new Helsinki(f); + h.Feladat5(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.deps.json new file mode 100644 index 0000000..f359d1e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 01. 22/1.0.0": { + "runtime": { + "2024. 01. 22.dll": {} + } + } + } + }, + "libraries": { + "2024. 01. 22/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.dll new file mode 100644 index 0000000..ddd0c31 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.exe new file mode 100644 index 0000000..be268e9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.pdb new file mode 100644 index 0000000..2f47f45 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/bin/Debug/net7.0/2024. 01. 22.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki.txt new file mode 100644 index 0000000..ead15c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki.txt @@ -0,0 +1,64 @@ +1 1 atletika kalapacsvetes +1 1 uszas 400m_gyorsuszas +1 1 birkozas kotott_fogas_legsuly +1 1 torna talajtorna +1 1 torna felemas_korlat +1 1 vivas kardvivas_egyeni +1 1 okolvivas nagyvaltosuly +1 1 uszas 200m_melluszas +1 1 birkozas kotott_fogas_valtosuly +1 1 uszas 100m_gyorsuszas +1 1 sportloveszet onmukodo_sportpisztoly +1 15 labdarugas ferfi_csapat +1 3 ottusa ferfi_csapat +1 6 vivas kardvivas_csapat +1 5 uszas 4x100m_gyorsuszo_valto +1 13 vizilabda ferfi_csapat +2 1 ottusa ottusa_egyeni +2 1 vivas torvivas_egyeni +2 1 vivas kardvivas_egyeni +2 1 sportloveszet onmukodo_sportpisztoly +2 1 uszas 400m_gyorsuszas +2 1 uszas 200m_melluszas +2 1 kajakkenu kenu_egyes_10000m +2 1 kajakkenu kajak_egyes_1000m +2 1 birkozas kotott_fogas_pehelysuly +2 8 torna noi_osszetett_csapat +3 1 sportloveszet sportpisztoly +3 1 vivas kardvivas_egyeni +3 1 atletika tavolugras +3 1 birkozas szabad_fogas_kozepsuly +3 1 torna felemas_korlat +3 1 torna osszetett_egyeni +3 1 torna gerenda +3 1 torna talajtorna +3 1 atletika kalapacsvetes +3 1 atletika 50km_gyaloglas +3 1 ottusa ottusa_egyeni +3 1 uszas 100m_gyorsuszas +3 4 atletika 4x100m_valtofutas +3 2 kajakkenu kenu_kettes_10000m +3 8 torna keziszer_csapat +3 6 vivas torvivas_csapat +4 1 torna gerenda +4 1 uszas 200m_mell +4 1 birkozas kotottfogas_felnehezsuly +4 1 torna talaj +4 1 birkozas kotottfogas_kozepsuly +4 1 birkozas kotottfogas_konnyusuly +5 1 okolvivas pehelysuly +5 1 okolvivas konnyusuly +5 1 uszas 100m_gyors +5 1 atletika diszkoszvetes +5 1 vivas parbajtor_egyeni +5 2 kajakkenu kenu_kettes_1000m +5 2 kerekparozas ketuleses_verseny +5 4 uszas 4�200m_gyorsvalto +5 5 vivas parbajtor_csapat +6 1 birkozas kotottfogas_legsuly +6 1 kajakkenu kajak_egyes_500m +6 1 torna osszetett_egyeni +6 1 kerekparozas repuloverseny +6 1 uszas 400m_gyors +6 1 torna felemaskorlat +6 8 torna osszetett_csapat \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki2.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki2.txt new file mode 100644 index 0000000..0c1cd17 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/helsinki2.txt @@ -0,0 +1,8 @@ +6 8 torna osszetett_csapat +ny + + + + + +y diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.dgspec.json new file mode 100644 index 0000000..114553b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj", + "projectName": "2024. 01. 22", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/2024. 01. 22.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfo.cs new file mode 100644 index 0000000..98d333b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 01. 22")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 01. 22")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 01. 22")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfoInputs.cache new file mode 100644 index 0000000..ea7427a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +50daa3a604f03fc596081f0563268dae99853ac6 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..9cd0bde --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._01._22 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.assets.cache new file mode 100644 index 0000000..46bcfba Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..40af62e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +e6b2a6710c198f13db0ae0431f1e86b998d33edd diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..3eb30e5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\bin\Debug\net7.0\2024. 01. 22.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\bin\Debug\net7.0\2024. 01. 22.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\bin\Debug\net7.0\2024. 01. 22.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\bin\Debug\net7.0\2024. 01. 22.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\bin\Debug\net7.0\2024. 01. 22.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\refint\2024. 01. 22.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\2024. 01. 22.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 01. 22\obj\Debug\net7.0\ref\2024. 01. 22.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.dll new file mode 100644 index 0000000..ddd0c31 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.genruntimeconfig.cache new file mode 100644 index 0000000..c203db8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.genruntimeconfig.cache @@ -0,0 +1 @@ +5406dc91198855b179eb37b8be96dd2f41f73d09 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.pdb new file mode 100644 index 0000000..2f47f45 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/2024. 01. 22.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..be268e9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/ref/2024. 01. 22.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/ref/2024. 01. 22.dll new file mode 100644 index 0000000..3d55f8b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/ref/2024. 01. 22.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/refint/2024. 01. 22.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/refint/2024. 01. 22.dll new file mode 100644 index 0000000..3d55f8b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/Debug/net7.0/refint/2024. 01. 22.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.assets.json new file mode 100644 index 0000000..381ccd2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj", + "projectName": "2024. 01. 22", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.nuget.cache new file mode 100644 index 0000000..57eef27 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 01. 22/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "XuWgXwNugwxph8QZS0+SXOgyhvvANkTxuzR+wwO5shJmDnKW8sLSlMbpmMj3tbjjWV3k05qfd4hn8jwLJt52eg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 01. 22\\2024. 01. 22.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.csproj new file mode 100644 index 0000000..63aa12a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._02._05 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.sln new file mode 100644 index 0000000..367393f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/2024. 02. 05.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 02. 05", "2024. 02. 05.csproj", "{227C4698-AAD4-4E76-8D71-B695259EA630}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {227C4698-AAD4-4E76-8D71-B695259EA630}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {227C4698-AAD4-4E76-8D71-B695259EA630}.Debug|Any CPU.Build.0 = Debug|Any CPU + {227C4698-AAD4-4E76-8D71-B695259EA630}.Release|Any CPU.ActiveCfg = Release|Any CPU + {227C4698-AAD4-4E76-8D71-B695259EA630}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {0582A35E-6E13-4688-A3C9-CC79B9DB9502} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Karacsony.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Karacsony.cs new file mode 100644 index 0000000..aa9457a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Karacsony.cs @@ -0,0 +1,32 @@ +namespace _2024._02._05; + +class NapiMunka +{ + public static int KeszultDb { get; private set; } + public int Nap { get; private set; } + public int HarangKesz { get; private set; } + public int HarangEladott { get; private set; } + public int AngyalkaKesz { get; private set; } + public int AngyalkaEladott { get; private set; } + public int FenyofaKesz { get; private set; } + public int FenyofaEladott { get; private set; } + + public NapiMunka(string sor) + { + string[] s = sor.Split(';'); + Nap = Convert.ToInt32(s[0]); + HarangKesz = Convert.ToInt32(s[1]); + HarangEladott = Convert.ToInt32(s[2]); + AngyalkaKesz = Convert.ToInt32(s[3]); + AngyalkaEladott = Convert.ToInt32(s[4]); + FenyofaKesz = Convert.ToInt32(s[5]); + FenyofaEladott = Convert.ToInt32(s[6]); + + NapiMunka.KeszultDb += HarangKesz + AngyalkaKesz + FenyofaKesz; + } + + public int NapiBevetel() + { + return -(HarangEladott * 1000 + AngyalkaEladott * 1350 + FenyofaEladott * 1500); + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Program.cs new file mode 100644 index 0000000..00551ee --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/Program.cs @@ -0,0 +1,76 @@ +namespace _2024._02._05; +using System.Text; + +class Program +{ + static void Main(string[] args) + { + var lines = File.ReadLines("diszek.txt"); + + // 4. feladat + foreach(string line in lines) + { + NapiMunka np = new NapiMunka(line); + } + + System.Console.WriteLine($"Összesen {NapiMunka.KeszultDb} darab dísz készült."); + + + // 5. feladat + foreach(string line in lines) + { + NapiMunka np = new NapiMunka(line); + if (np.HarangKesz == 0 && np.AngyalkaKesz == 0 && np.FenyofaKesz == 0) + { + System.Console.WriteLine("Volt olyan nap, amikor egyetlen dísz sem készült."); + break; + } + } + + + // 6. feladat + System.Console.WriteLine("Adja meg a keresett napot [1 ... 40]!"); + int day = Convert.ToInt32(Console.ReadLine()); + + while (day < 1 || day > 40) + { + System.Console.WriteLine("Adja meg a keresett napot [1 ... 40]!"); + day = Convert.ToInt32(Console.ReadLine()); + } + + int harang = 0; + int angyalka = 0; + int fenyofa = 0; + + foreach(string line in lines) + { + NapiMunka np = new NapiMunka(line); + harang += np.HarangKesz + np.HarangEladott; + angyalka += np.AngyalkaKesz + np.AngyalkaEladott; + fenyofa += np.FenyofaKesz + np.FenyofaEladott; + + if (np.Nap == day) + { + System.Console.WriteLine($"A(z) {np.Nap} nap végén {harang} harang, {angyalka} angyalka és {fenyofa} fenyőfa maradt készleten."); + } + } + + + // 7. feladat + + int harangEl = 0; + int angyalkaEl = 0; + int fenyofaEl = 0; + + foreach(string line in lines) + { + NapiMunka np = new NapiMunka(line); + harangEl += + np.HarangEladott; + angyalkaEl += + np.AngyalkaEladott; + fenyofaEl += + np.FenyofaEladott; + } + + int[] diszek = { Math.Abs(harangEl), Math.Abs(angyalkaEl), Math.Abs(fenyofaEl) }; + System.Console.WriteLine($"Legtöbbet eladott dísz: {diszek.Max()}"); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.deps.json new file mode 100644 index 0000000..28b4e0d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 02. 05/1.0.0": { + "runtime": { + "2024. 02. 05.dll": {} + } + } + } + }, + "libraries": { + "2024. 02. 05/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.dll new file mode 100644 index 0000000..730f202 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.exe new file mode 100644 index 0000000..0651b15 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.pdb new file mode 100644 index 0000000..7a7a27e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/bin/Debug/net7.0/2024. 02. 05.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/diszek.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/diszek.txt new file mode 100644 index 0000000..39b1db5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/diszek.txt @@ -0,0 +1,40 @@ +1;3;0;0;0;4;0 +2;4;0;5;-2;1;0 +3;1;-2;4;-3;0;0 +4;0;0;3;-1;0;0 +5;0;0;0;-2;3;-2 +6;0;-5;6;-5;0;-1 +7;3;0;3;0;1;-3 +8;2;-3;0;0;3;0 +9;5;0;6;-4;2;-3 +10;0;-3;0;0;8;-4 +11;2;-5;0;-3;1;-3 +12;0;-1;0;-2;0;0 +13;8;-3;0;-4;8;0 +14;0;0;0;-1;3;-6 +15;0;0;3;0;5;-4 +16;4;-6;2;-1;6;-5 +17;2;-4;8;-6;0;0 +18;0;-1;4;-5;3;-6 +19;0;0;1;-6;0;0 +20;2;-3;0;0;2;-4 +21;7;0;5;0;3;-3 +22;3;0;0;0;4;-4 +23;4;-6;5;-3;7;-2 +24;0;0;0;-5;8;-7 +25;0;0;6;-2;9;-4 +26;0;0;0;-4;5;0 +27;4;0;3;-2;0;0 +28;0;-6;2;-3;2;-4 +29;0;-4;4;-6;1;-6 +30;0;0;7;-2;0;-12 +31;0;-2;8;-6;0;-5 +32;10;0;0;-3;4;-2 +33;0;0;0;-4;3;-4 +34;5;-8;0;0;4;0 +35;2;0;9;-3;6;0 +36;0;-3;0;-2;8;-4 +37;0;0;6;-4;3;-2 +38;0;0;8;-5;6;-3 +39;3;-2;0;-5;5;-4 +40;2;-4;4;-3;2;0 \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.dgspec.json new file mode 100644 index 0000000..420b84c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj", + "projectName": "2024. 02. 05", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/2024. 02. 05.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfo.cs new file mode 100644 index 0000000..cf0d40c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 02. 05")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 02. 05")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 02. 05")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfoInputs.cache new file mode 100644 index 0000000..3fc79dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c9e6c835806f34f81e4990d273d939f468c96a58 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..1483485 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._02._05 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.assets.cache new file mode 100644 index 0000000..eedbe0a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..a871822 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +337b987d100295e5c7536c29c96687d2cefb3c4d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..1096545 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\bin\Debug\net7.0\2024. 02. 05.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\bin\Debug\net7.0\2024. 02. 05.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\bin\Debug\net7.0\2024. 02. 05.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\bin\Debug\net7.0\2024. 02. 05.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\bin\Debug\net7.0\2024. 02. 05.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\refint\2024. 02. 05.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\2024. 02. 05.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 05\obj\Debug\net7.0\ref\2024. 02. 05.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.dll new file mode 100644 index 0000000..730f202 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.genruntimeconfig.cache new file mode 100644 index 0000000..078e8dd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.genruntimeconfig.cache @@ -0,0 +1 @@ +3a29f970e6c6a26026e43ca8ff4a3416424f4cfc diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.pdb new file mode 100644 index 0000000..7a7a27e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/2024. 02. 05.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..0651b15 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/ref/2024. 02. 05.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/ref/2024. 02. 05.dll new file mode 100644 index 0000000..2d7d3e2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/ref/2024. 02. 05.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/refint/2024. 02. 05.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/refint/2024. 02. 05.dll new file mode 100644 index 0000000..2d7d3e2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/Debug/net7.0/refint/2024. 02. 05.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.assets.json new file mode 100644 index 0000000..ea5b30a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj", + "projectName": "2024. 02. 05", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.nuget.cache new file mode 100644 index 0000000..ab16db1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 05/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "4drJxRDH29GPyelbFp2snN6CIhNG8XfOPshMuj6EZfMWrD756mxV57N4DXzqe2WPB/s4vPnu5O6CKGKQkaixsQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 05\\2024. 02. 05.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.csproj new file mode 100644 index 0000000..fc2e01e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.csproj @@ -0,0 +1,11 @@ + + + + Exe + net7.0 + _2024._02._12 + enable + enable + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.sln new file mode 100644 index 0000000..56325a3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/2024. 02. 12.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.5.002.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "2024. 02. 12", "2024. 02. 12.csproj", "{6460B716-F0A0-4188-BA64-3E137CB159B9}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {6460B716-F0A0-4188-BA64-3E137CB159B9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {6460B716-F0A0-4188-BA64-3E137CB159B9}.Debug|Any CPU.Build.0 = Debug|Any CPU + {6460B716-F0A0-4188-BA64-3E137CB159B9}.Release|Any CPU.ActiveCfg = Release|Any CPU + {6460B716-F0A0-4188-BA64-3E137CB159B9}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2809F864-6BF0-4273-972E-800297CDA487} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Program.cs new file mode 100644 index 0000000..c94a397 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Program.cs @@ -0,0 +1,20 @@ +namespace _2024._02._12; + +class Program +{ + static void Main(string[] args) + { + var lines = File.ReadLines("szavazatok.txt"); + List veglegesLines = new List(); + foreach (var line in lines) + { + veglegesLines.Add(line); + } + + Szavazatok szavazatok = new Szavazatok(veglegesLines); + szavazatok.Feladat2(); + szavazatok.Feladat3(); + szavazatok.Feladat4(); + szavazatok.Feladat5(); + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Szavazatok.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Szavazatok.cs new file mode 100644 index 0000000..bdcaaf4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/Szavazatok.cs @@ -0,0 +1,114 @@ +namespace _2024._02._12; + +class Szavazatok +{ + public List Szavazat; + + public Szavazatok(List szavazat) + { + Szavazat = szavazat; + } + + public void Feladat2() + { + System.Console.WriteLine($"A helyhatósági választáson {Szavazat.Count()} képviselőjelölt indult."); + } + + public void Feladat3() + { + System.Console.WriteLine("Kérek egy vezetéknevet"); + string vnev = Console.ReadLine(); + + System.Console.WriteLine("Kérek egy keresztnevet"); + string knev = Console.ReadLine(); + + string teljesnev = $"{vnev} {knev}"; + + bool response = false; + + string[] line = {}; + + foreach(var data in Szavazat) + { + if(data.Contains(teljesnev)) + { + line = data.Split(' '); + response = true; + break; + } + } + + if(response) + { + System.Console.WriteLine($"{teljesnev} képviselőjelölt {line[1]} szavazatot kapott."); + } + + else + { + System.Console.WriteLine("Ilyen nevű képviselőjelölt nem szerepel a nyilvántartásban."); + } + } + + public void Feladat4() + { + double allampolgar = 0; + foreach(var data in Szavazat) + { + string[] line = data.Split(' '); + allampolgar += Convert.ToInt32(line[1]); + } + + double szazalek = Math.Round(allampolgar / 12345 * 100, 2); + + System.Console.WriteLine($"A választáson {allampolgar} állampolgár, a jogosultak {szazalek}%-a vett részt."); + } + + public void Feladat5() + { + double gyep = 0; + double hep = 0; + double tisz = 0; + double zep = 0; + double fuggetlen = 0; + + foreach(var data in Szavazat) + { + string[] line = data.Split(' '); + if(String.Equals(line[4], "GYEP")) + { + gyep += Convert.ToInt32(line[1]); + } + + else if(String.Equals(line[4], "HEP")) + { + hep += Convert.ToInt32(line[1]); + } + + else if(String.Equals(line[4], "TISZ")) + { + tisz += Convert.ToInt32(line[1]); + } + + else if(String.Equals(line[4], "ZEP")) + { + zep += Convert.ToInt32(line[1]); + } + + else + { + fuggetlen += Convert.ToInt32(line[1]); + } + } + + System.Console.WriteLine($"Gyümölcsevők Pártja: {Math.Round(gyep / 12345 * 100, 2)}%"); + System.Console.WriteLine($"Húsevők Pártja: {Math.Round(hep / 12345 * 100, 2)}%"); + System.Console.WriteLine($"Tejivók Szövetsége: {Math.Round(tisz / 12345 * 100, 2)}%"); + System.Console.WriteLine($"Zöldségevők Pártja: {Math.Round(zep / 12345 * 100, 2)}%"); + System.Console.WriteLine($"Független jelöltek: {Math.Round(fuggetlen / 12345 * 100, 2)}%"); + } + + public void Feladat6() + { + + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.deps.json new file mode 100644 index 0000000..780d301 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v7.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v7.0": { + "2024. 02. 12/1.0.0": { + "runtime": { + "2024. 02. 12.dll": {} + } + } + } + }, + "libraries": { + "2024. 02. 12/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.dll new file mode 100644 index 0000000..5bd6d44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.exe new file mode 100644 index 0000000..5a56ea8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.pdb new file mode 100644 index 0000000..da8ae5e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.runtimeconfig.json new file mode 100644 index 0000000..184be8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/bin/Debug/net7.0/2024. 02. 12.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net7.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "7.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.dgspec.json new file mode 100644 index 0000000..a998fdf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj", + "projectName": "2024. 02. 12", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/2024. 02. 12.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs new file mode 100644 index 0000000..4257f4b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/.NETCoreApp,Version=v7.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v7.0", FrameworkDisplayName = ".NET 7.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfo.cs new file mode 100644 index 0000000..34f669b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfo.cs @@ -0,0 +1,22 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 02. 12")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 02. 12")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 02. 12")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfoInputs.cache new file mode 100644 index 0000000..31e9843 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +81cfae384f95e339a1fb45854d10bb7498e4ed61 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..966241a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net7.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._02._12 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.assets.cache new file mode 100644 index 0000000..41ca1de Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..2f3cf8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +4e4ca6a1f5e1dc1ec838ff4e595f95a008fbcb4f diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..9471159 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\bin\Debug\net7.0\2024. 02. 12.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\bin\Debug\net7.0\2024. 02. 12.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\bin\Debug\net7.0\2024. 02. 12.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\bin\Debug\net7.0\2024. 02. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\bin\Debug\net7.0\2024. 02. 12.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\refint\2024. 02. 12.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\2024. 02. 12.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 12\obj\Debug\net7.0\ref\2024. 02. 12.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.dll new file mode 100644 index 0000000..5bd6d44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.genruntimeconfig.cache new file mode 100644 index 0000000..a12c2af --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.genruntimeconfig.cache @@ -0,0 +1 @@ +dc29d4413c341671b9379e8e38920877124265db diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.pdb new file mode 100644 index 0000000..da8ae5e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/2024. 02. 12.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/apphost.exe new file mode 100644 index 0000000..5a56ea8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/ref/2024. 02. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/ref/2024. 02. 12.dll new file mode 100644 index 0000000..e4be04f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/ref/2024. 02. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/refint/2024. 02. 12.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/refint/2024. 02. 12.dll new file mode 100644 index 0000000..e4be04f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/Debug/net7.0/refint/2024. 02. 12.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.assets.json new file mode 100644 index 0000000..2d7ba87 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj", + "projectName": "2024. 02. 12", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net7.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net7.0": { + "targetAlias": "net7.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.nuget.cache new file mode 100644 index 0000000..535f1c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "pmEHLujqYGkxqq5q1kVc6tMFR5ZpSd6pRzrb+mxpNcaugIGetpKyNywkH1qJ4+UL/eZxqEKj+X9qrmYozZsdew==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 12\\2024. 02. 12.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/szavazatok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/szavazatok.txt new file mode 100644 index 0000000..75ee250 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 12/szavazatok.txt @@ -0,0 +1,40 @@ +5 19 Ablak Antal - +1 120 Alma Dalma GYEP +7 162 Bab Zsuzsanna ZEP +2 59 Barack Barna GYEP +6 73 Birs Helga GYEP +1 154 Bors Botond HEP +5 188 Brokkoli Gyula ZEP +6 29 Ceruza Zsombor - +4 143 Fasirt Ferenc HEP +8 157 Gomba Gitta TISZ +3 13 Halmi Helga - +2 66 Hold Ferenc - +7 34 Hurka Herold HEP +5 288 Joghurt Jakab TISZ +4 77 Kajszi Kolos GYEP +2 187 Kapor Karola ZEP +6 13 Karfiol Ede ZEP +6 187 Kefir Ilona TISZ +7 130 Kupa Huba - +8 98 Languszta Auguszta - +1 34 Lila Lilla - +1 56 Medve Rudolf - +5 67 Meggy Csilla GYEP +3 45 Moly Piroska - +4 221 Monitor Tibor - +8 288 Narancs Edmond GYEP +2 220 Oldalas Olga HEP +3 185 Pacal Kata HEP +1 199 Petrezselyem Petra ZEP +8 77 Pokol Vidor - +8 67 Ragu Ida HEP +3 156 Retek Etelka ZEP +7 129 Sajt Hajnalka TISZ +4 38 Simon Simon - +3 87 Szilva Szilvia GYEP +3 187 Tejes Attila TISZ +2 65 Tejfel Edit TISZ +4 39 Uborka Ubul ZEP +6 288 Vadas Marcell HEP +5 68 Vagdalt Edit HEP \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.metadata.v7.bin new file mode 100644 index 0000000..6989a3b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.projects.v7.bin new file mode 100644 index 0000000..94e5900 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/ProjectEvaluation/winformsapp1.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/VSWorkspaceState.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/VSWorkspaceState.json new file mode 100644 index 0000000..6b61141 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/VSWorkspaceState.json @@ -0,0 +1,6 @@ +{ + "ExpandedNodes": [ + "" + ], + "PreviewInSolutionExplorer": false +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..da83f2b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ddbb86ce-fd8a-41b5-b06e-e92a9d4a8ffe.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ddbb86ce-fd8a-41b5-b06e-e92a9d4a8ffe.vsidx new file mode 100644 index 0000000..ba6fab0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ddbb86ce-fd8a-41b5-b06e-e92a9d4a8ffe.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ef65e8e3-2679-4e1e-9f33-3eabe6911800.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ef65e8e3-2679-4e1e-9f33-3eabe6911800.vsidx new file mode 100644 index 0000000..412213c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/ef65e8e3-2679-4e1e-9f33-3eabe6911800.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/fd473fd4-cd55-4504-b774-68045624e792.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/fd473fd4-cd55-4504-b774-68045624e792.vsidx new file mode 100644 index 0000000..322f78e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/FileContentIndex/fd473fd4-cd55-4504-b774-68045624e792.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.futdcache.v2 new file mode 100644 index 0000000..528e735 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.suo new file mode 100644 index 0000000..94e7279 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/WinFormsApp1/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/slnx.sqlite b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/slnx.sqlite new file mode 100644 index 0000000..71ad1de Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/.vs/slnx.sqlite differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1.sln new file mode 100644 index 0000000..c5f2471 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "WinFormsApp1", "WinFormsApp1\WinFormsApp1.csproj", "{C61AAF29-A8C9-48D5-83F6-9A127081C06C}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {C61AAF29-A8C9-48D5-83F6-9A127081C06C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C61AAF29-A8C9-48D5-83F6-9A127081C06C}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C61AAF29-A8C9-48D5-83F6-9A127081C06C}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C61AAF29-A8C9-48D5-83F6-9A127081C06C}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {FDC2CB78-289B-4B93-BEBA-0BF943787B60} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.Designer.cs new file mode 100644 index 0000000..dc5620a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.Designer.cs @@ -0,0 +1,49 @@ +namespace WinFormsApp1 +{ + partial class Form1 + { + ///

+ /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(Form1)); + SuspendLayout(); + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackgroundImage = (Image)resources.GetObject("$this.BackgroundImage"); + BackgroundImageLayout = ImageLayout.Zoom; + ClientSize = new Size(800, 450); + Name = "Form1"; + Text = "Form1"; + Load += Form1_Load; + ResumeLayout(false); + } + + #endregion + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.cs new file mode 100644 index 0000000..cd6f0b3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.cs @@ -0,0 +1,15 @@ +namespace WinFormsApp1 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void Form1_Load(object sender, EventArgs e) + { + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.resx new file mode 100644 index 0000000..77d33a0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Form1.resx @@ -0,0 +1,306 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + + + 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 + wBiBSpVoJclfc1IUkFmY9Ses5pUqVUbH/9k= + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Program.cs new file mode 100644 index 0000000..1e39c2a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Program.cs @@ -0,0 +1,17 @@ +namespace WinFormsApp1 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.Designer.cs new file mode 100644 index 0000000..8507202 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace WinFormsApp1.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("WinFormsApp1.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.resx new file mode 100644 index 0000000..1af7de1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/Properties/Resources.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj new file mode 100644 index 0000000..13ee123 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj @@ -0,0 +1,26 @@ + + + + WinExe + net6.0-windows + enable + true + enable + + + + + True + True + Resources.resx + + + + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/WinFormsApp1.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.deps.json new file mode 100644 index 0000000..103c3d4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "WinFormsApp1/1.0.0": { + "runtime": { + "WinFormsApp1.dll": {} + } + } + } + }, + "libraries": { + "WinFormsApp1/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.dll new file mode 100644 index 0000000..05f5c5b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.exe new file mode 100644 index 0000000..85ce4f7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.pdb new file mode 100644 index 0000000..b38f608 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/bin/Debug/net6.0-windows/WinFormsApp1.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfo.cs new file mode 100644 index 0000000..6b216dd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyTitleAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bbf5d47 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +d77c1e181078950104e447609764b620d3b0b9c8 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Form1.resources new file mode 100644 index 0000000..db4381b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5656c32 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = WinFormsApp1 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Properties.Resources.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Properties.Resources.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.Properties.Resources.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.assets.cache new file mode 100644 index 0000000..70a88d8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..92dbebd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +9cf9ded2c6a9f317919234f89059da823a48ab84 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..7b29bd1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.FileListAbsolute.txt @@ -0,0 +1,17 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\bin\Debug\net6.0-windows\WinFormsApp1.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\bin\Debug\net6.0-windows\WinFormsApp1.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\bin\Debug\net6.0-windows\WinFormsApp1.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\bin\Debug\net6.0-windows\WinFormsApp1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\bin\Debug\net6.0-windows\WinFormsApp1.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.Properties.Resources.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\refint\WinFormsApp1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\WinFormsApp1.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\obj\Debug\net6.0-windows\ref\WinFormsApp1.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.GenerateResource.cache new file mode 100644 index 0000000..86d8b63 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.dll new file mode 100644 index 0000000..05f5c5b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.genruntimeconfig.cache new file mode 100644 index 0000000..fabe816 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.genruntimeconfig.cache @@ -0,0 +1 @@ +1add4521c562f81fca17996004f86b54e5343ffb diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.pdb new file mode 100644 index 0000000..b38f608 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/WinFormsApp1.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..85ce4f7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/ref/WinFormsApp1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/ref/WinFormsApp1.dll new file mode 100644 index 0000000..0f963c0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/ref/WinFormsApp1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/refint/WinFormsApp1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/refint/WinFormsApp1.dll new file mode 100644 index 0000000..0f963c0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Debug/net6.0-windows/refint/WinFormsApp1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfo.cs new file mode 100644 index 0000000..a170079 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Release")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyTitleAttribute("WinFormsApp1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache new file mode 100644 index 0000000..764aa14 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +7719ebe8deb29a4313bc4152a1208bcee9e2092d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5656c32 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = WinFormsApp1 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 14\WinFormsApp1\WinFormsApp1\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.assets.cache new file mode 100644 index 0000000..79d8750 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/Release/net6.0-windows/WinFormsApp1.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.dgspec.json new file mode 100644 index 0000000..29f3a70 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj", + "projectName": "WinFormsApp1", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/WinFormsApp1.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.assets.json new file mode 100644 index 0000000..b2371b7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj", + "projectName": "WinFormsApp1", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.nuget.cache new file mode 100644 index 0000000..31e23dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 14/WinFormsApp1/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "xA0kCJIldjyDLWVNF/eWCV9AMGaL363vpHe8hDkClnw8qWJmwpL1hZgSE4ziM4R/SZQOBm46QheEyyM3+OCHmg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 14\\WinFormsApp1\\WinFormsApp1\\WinFormsApp1.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..9bbd34c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/207d79a4-964e-4eca-8be7-28ad9ac2a22a.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/207d79a4-964e-4eca-8be7-28ad9ac2a22a.vsidx new file mode 100644 index 0000000..66409df Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/207d79a4-964e-4eca-8be7-28ad9ac2a22a.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/b6fec893-75df-4ecc-a20b-b0cfbdfa1aa8.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/b6fec893-75df-4ecc-a20b-b0cfbdfa1aa8.vsidx new file mode 100644 index 0000000..0ca095c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/FileContentIndex/b6fec893-75df-4ecc-a20b-b0cfbdfa1aa8.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.futdcache.v2 new file mode 100644 index 0000000..c9aecdd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.suo new file mode 100644 index 0000000..8465757 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/2024. 02. 21/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.metadata.v7.bin new file mode 100644 index 0000000..48ea313 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.projects.v7.bin new file mode 100644 index 0000000..76a98ee Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/.vs/ProjectEvaluation/2024. 02. 21.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21.sln new file mode 100644 index 0000000..dfe081d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 02. 21", "2024. 02. 21\2024. 02. 21.csproj", "{5C643288-8066-483F-91EC-58F4E91A2E92}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {5C643288-8066-483F-91EC-58F4E91A2E92}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {5C643288-8066-483F-91EC-58F4E91A2E92}.Debug|Any CPU.Build.0 = Debug|Any CPU + {5C643288-8066-483F-91EC-58F4E91A2E92}.Release|Any CPU.ActiveCfg = Release|Any CPU + {5C643288-8066-483F-91EC-58F4E91A2E92}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {711D2A6C-0D89-43CD-9F0E-18DECE6C0E9A} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj new file mode 100644 index 0000000..b76dbee --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._02._21 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/2024. 02. 21.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.Designer.cs new file mode 100644 index 0000000..296db35 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.Designer.cs @@ -0,0 +1,60 @@ +namespace _2024._02._21 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + button1 = new Button(); + SuspendLayout(); + // + // button1 + // + button1.Font = new Font("Snap ITC", 18F, FontStyle.Regular, GraphicsUnit.Point); + button1.Location = new Point(236, 160); + button1.Name = "button1"; + button1.Size = new Size(304, 96); + button1.TabIndex = 0; + button1.Text = "Kattints ide!"; + button1.UseVisualStyleBackColor = true; + button1.Click += button1_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(button1); + Name = "Form1"; + Text = "Üzenetdoboz"; + ResumeLayout(false); + } + + #endregion + + private Button button1; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.cs new file mode 100644 index 0000000..773b2dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.cs @@ -0,0 +1,15 @@ +namespace _2024._02._21 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void button1_Click(object sender, EventArgs e) + { + MessageBox.Show("Sikerlt!", "dvzlet", MessageBoxButtons.RetryCancel, MessageBoxIcon.Error); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Program.cs new file mode 100644 index 0000000..01b4fdf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._02._21 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.deps.json new file mode 100644 index 0000000..67abab8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 02. 21/1.0.0": { + "runtime": { + "2024. 02. 21.dll": {} + } + } + } + }, + "libraries": { + "2024. 02. 21/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.dll new file mode 100644 index 0000000..f13b9cd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.exe new file mode 100644 index 0000000..0cb676d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.pdb new file mode 100644 index 0000000..d2cd071 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/bin/Debug/net6.0-windows/2024. 02. 21.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.dgspec.json new file mode 100644 index 0000000..a7e6fb1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj", + "projectName": "2024. 02. 21", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/2024. 02. 21.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfo.cs new file mode 100644 index 0000000..dcf5c4c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 02. 21")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 02. 21")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 02. 21")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfoInputs.cache new file mode 100644 index 0000000..551ed37 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a9cad0392b4726886e3174cf19f1e7e48f40f119 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b879357 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._02._21 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.assets.cache new file mode 100644 index 0000000..314cb50 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..ad86959 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +4494a9c061256d52559979e47daab4390ebddc0b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..f293e15 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\bin\Debug\net6.0-windows\2024. 02. 21.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\bin\Debug\net6.0-windows\2024. 02. 21.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\bin\Debug\net6.0-windows\2024. 02. 21.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\bin\Debug\net6.0-windows\2024. 02. 21.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\bin\Debug\net6.0-windows\2024. 02. 21.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\_2024._02._21.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\refint\2024. 02. 21.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\2024. 02. 21.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 21\2024. 02. 21\obj\Debug\net6.0-windows\ref\2024. 02. 21.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.GenerateResource.cache new file mode 100644 index 0000000..0424891 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.dll new file mode 100644 index 0000000..f13b9cd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.genruntimeconfig.cache new file mode 100644 index 0000000..7f6c054 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.genruntimeconfig.cache @@ -0,0 +1 @@ +b36a28fd595c55cd50feac989b64039c940825b3 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.pdb new file mode 100644 index 0000000..d2cd071 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/2024. 02. 21.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/_2024._02._21.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/_2024._02._21.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/_2024._02._21.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..0cb676d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/ref/2024. 02. 21.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/ref/2024. 02. 21.dll new file mode 100644 index 0000000..6d961cb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/ref/2024. 02. 21.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/refint/2024. 02. 21.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/refint/2024. 02. 21.dll new file mode 100644 index 0000000..6d961cb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/Debug/net6.0-windows/refint/2024. 02. 21.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.assets.json new file mode 100644 index 0000000..121bb47 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj", + "projectName": "2024. 02. 21", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.nuget.cache new file mode 100644 index 0000000..c655fd8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 21/2024. 02. 21/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "HieV4ppo/h0U5YIYx7EI0UM4lutLgU/VYkE0Sxi08P6qp1fYmV/Q9RhqQhRsX0u/GmQm1En/KTw5u2uW9N5BMA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 21\\2024. 02. 21\\2024. 02. 21.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..ed48591 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e4cb55c2-40da-49f9-9d84-44c02c9d82a9.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e4cb55c2-40da-49f9-9d84-44c02c9d82a9.vsidx new file mode 100644 index 0000000..4a0c25c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e4cb55c2-40da-49f9-9d84-44c02c9d82a9.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e92db410-c681-421b-8af9-f94c0c5e9b3c.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e92db410-c681-421b-8af9-f94c0c5e9b3c.vsidx new file mode 100644 index 0000000..58c8266 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/FileContentIndex/e92db410-c681-421b-8af9-f94c0c5e9b3c.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.futdcache.v2 new file mode 100644 index 0000000..69ac756 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.suo new file mode 100644 index 0000000..f096495 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/2024. 02. 26 - 2/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.metadata.v7.bin new file mode 100644 index 0000000..43b11b0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.projects.v7.bin new file mode 100644 index 0000000..d5c26e3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/.vs/ProjectEvaluation/2024. 02. 26 - 2.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2.sln new file mode 100644 index 0000000..171f2b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 02. 26 - 2", "2024. 02. 26 - 2\2024. 02. 26 - 2.csproj", "{9D6340E5-4641-44DB-8A66-4207C5DAD37C}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {9D6340E5-4641-44DB-8A66-4207C5DAD37C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {9D6340E5-4641-44DB-8A66-4207C5DAD37C}.Debug|Any CPU.Build.0 = Debug|Any CPU + {9D6340E5-4641-44DB-8A66-4207C5DAD37C}.Release|Any CPU.ActiveCfg = Release|Any CPU + {9D6340E5-4641-44DB-8A66-4207C5DAD37C}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {BFA8579B-EC1E-4AA8-A681-F64455BF57E7} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj new file mode 100644 index 0000000..5c6c386 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._02._26___2 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/2024. 02. 26 - 2.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.Designer.cs new file mode 100644 index 0000000..79a9d1b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.Designer.cs @@ -0,0 +1,74 @@ +namespace _2024._02._26___2 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + checkBox1 = new CheckBox(); + radioButton1 = new RadioButton(); + SuspendLayout(); + // + // checkBox1 + // + checkBox1.AutoSize = true; + checkBox1.Location = new Point(320, 183); + checkBox1.Name = "checkBox1"; + checkBox1.Size = new Size(101, 24); + checkBox1.TabIndex = 0; + checkBox1.Text = "checkBox1"; + checkBox1.TextAlign = ContentAlignment.MiddleCenter; + checkBox1.UseVisualStyleBackColor = true; + // + // radioButton1 + // + radioButton1.AutoSize = true; + radioButton1.Location = new Point(320, 213); + radioButton1.Name = "radioButton1"; + radioButton1.Size = new Size(117, 24); + radioButton1.TabIndex = 1; + radioButton1.Text = "radioButton1"; + radioButton1.UseVisualStyleBackColor = true; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(radioButton1); + Controls.Add(checkBox1); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private CheckBox checkBox1; + private RadioButton radioButton1; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.cs new file mode 100644 index 0000000..74f75c9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.cs @@ -0,0 +1,10 @@ +namespace _2024._02._26___2 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Program.cs new file mode 100644 index 0000000..eab7c6a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._02._26___2 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..cba493f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj", + "projectName": "2024. 02. 26 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/2024. 02. 26 - 2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfo.cs new file mode 100644 index 0000000..3aa9f43 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 02. 26 - 2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 02. 26 - 2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 02. 26 - 2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..8b585c5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +1a0635fd4b2199cbe817f3c2527bdac6334242e2 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d7c4b36 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._02._26___2 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26 - 2\2024. 02. 26 - 2\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.assets.cache new file mode 100644 index 0000000..010c717 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/Debug/net6.0-windows/2024. 02. 26 - 2.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.assets.json new file mode 100644 index 0000000..7ab86ec --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj", + "projectName": "2024. 02. 26 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.nuget.cache new file mode 100644 index 0000000..fb0e766 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26 - 2/2024. 02. 26 - 2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "UbQei4njixbr0qK+ZYH0Twr1uSOdjpFPeArqzsGZJGkmoC317zRee/acY/NMp3RU+X3nb0Ubq08gvHiOFDTKLA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26 - 2\\2024. 02. 26 - 2\\2024. 02. 26 - 2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..03b531d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/6aa6a0d1-28a8-45ce-8a16-87d42076e771.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/6aa6a0d1-28a8-45ce-8a16-87d42076e771.vsidx new file mode 100644 index 0000000..4f7e140 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/6aa6a0d1-28a8-45ce-8a16-87d42076e771.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/81855b8c-3ebb-450f-94e8-1acc97e1c4d6.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/81855b8c-3ebb-450f-94e8-1acc97e1c4d6.vsidx new file mode 100644 index 0000000..22ffb7c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/81855b8c-3ebb-450f-94e8-1acc97e1c4d6.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/fcde24e2-b13a-494b-8b37-d0e66aa800a3.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/fcde24e2-b13a-494b-8b37-d0e66aa800a3.vsidx new file mode 100644 index 0000000..3796d44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/FileContentIndex/fcde24e2-b13a-494b-8b37-d0e66aa800a3.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.futdcache.v2 new file mode 100644 index 0000000..7b4e50b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.suo new file mode 100644 index 0000000..24b1720 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/2024. 02. 26/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.metadata.v7.bin new file mode 100644 index 0000000..8f1134b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.projects.v7.bin new file mode 100644 index 0000000..72c835b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/.vs/ProjectEvaluation/2024. 02. 26.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26.sln new file mode 100644 index 0000000..ca53559 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 02. 26", "2024. 02. 26\2024. 02. 26.csproj", "{92ED4FB4-23AA-48FD-875D-4B7E8F2A5EC4}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {92ED4FB4-23AA-48FD-875D-4B7E8F2A5EC4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {92ED4FB4-23AA-48FD-875D-4B7E8F2A5EC4}.Debug|Any CPU.Build.0 = Debug|Any CPU + {92ED4FB4-23AA-48FD-875D-4B7E8F2A5EC4}.Release|Any CPU.ActiveCfg = Release|Any CPU + {92ED4FB4-23AA-48FD-875D-4B7E8F2A5EC4}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {08F27AE2-085E-44FE-8CAF-BD440BF0677E} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj new file mode 100644 index 0000000..03b546f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj @@ -0,0 +1,27 @@ + + + + WinExe + net6.0-windows + _2024._02._26 + enable + true + enable + + + + + True + True + Resources.resx + + + + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/2024. 02. 26.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.Designer.cs new file mode 100644 index 0000000..31a9737 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.Designer.cs @@ -0,0 +1,115 @@ +namespace _2024._02._26 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + KorSugarLabel = new Label(); + KorSugarTextBox = new TextBox(); + Szamol = new Button(); + KorKerulet = new Label(); + KorTerulet = new Label(); + SuspendLayout(); + // + // KorSugarLabel + // + KorSugarLabel.AutoSize = true; + KorSugarLabel.Font = new Font("Trebuchet MS", 12F, FontStyle.Bold, GraphicsUnit.Point); + KorSugarLabel.Location = new Point(48, 72); + KorSugarLabel.Name = "KorSugarLabel"; + KorSugarLabel.Size = new Size(128, 26); + KorSugarLabel.TabIndex = 0; + KorSugarLabel.Text = "A kör sugara"; + // + // KorSugarTextBox + // + KorSugarTextBox.BackColor = SystemColors.ActiveCaption; + KorSugarTextBox.Location = new Point(48, 142); + KorSugarTextBox.Name = "KorSugarTextBox"; + KorSugarTextBox.Size = new Size(125, 27); + KorSugarTextBox.TabIndex = 1; + // + // Szamol + // + Szamol.BackColor = SystemColors.ScrollBar; + Szamol.Font = new Font("Segoe UI Historic", 12F, FontStyle.Bold, GraphicsUnit.Point); + Szamol.Location = new Point(48, 205); + Szamol.Name = "Szamol"; + Szamol.Size = new Size(122, 56); + Szamol.TabIndex = 2; + Szamol.Text = "Kiszámol"; + Szamol.UseVisualStyleBackColor = false; + Szamol.Click += Szamol_Click; + // + // KorKerulet + // + KorKerulet.AutoSize = true; + KorKerulet.Font = new Font("Tahoma", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + KorKerulet.Location = new Point(490, 72); + KorKerulet.Name = "KorKerulet"; + KorKerulet.Size = new Size(167, 28); + KorKerulet.TabIndex = 3; + KorKerulet.Text = "A kör kerülete: "; + // + // KorTerulet + // + KorTerulet.AutoSize = true; + KorTerulet.Font = new Font("Tahoma", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + KorTerulet.Location = new Point(490, 119); + KorTerulet.Name = "KorTerulet"; + KorTerulet.Size = new Size(164, 28); + KorTerulet.TabIndex = 4; + KorTerulet.Text = "A kör területe: "; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackgroundImage = Properties.Resources.Screenshot_2023_12_05_115119; + BackgroundImageLayout = ImageLayout.Stretch; + ClientSize = new Size(800, 450); + Controls.Add(KorTerulet); + Controls.Add(KorKerulet); + Controls.Add(Szamol); + Controls.Add(KorSugarTextBox); + Controls.Add(KorSugarLabel); + DoubleBuffered = true; + Name = "Form1"; + Text = "A kör"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label KorSugarLabel; + private TextBox KorSugarTextBox; + private Button Szamol; + private Label KorKerulet; + private Label KorTerulet; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.cs new file mode 100644 index 0000000..12069b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.cs @@ -0,0 +1,20 @@ +namespace _2024._02._26 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void Szamol_Click(object sender, EventArgs e) + { + double r = double.Parse(KorSugarTextBox.Text); + double k = 2 * r * Math.PI; + double t = r * r * Math.PI; + KorKerulet.Text = $"A kr kerlete: {k.ToString()}"; + KorTerulet.Text = $"A kr terlete: {t.ToString()}"; + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Program.cs new file mode 100644 index 0000000..4c2e6f2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._02._26 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.Designer.cs new file mode 100644 index 0000000..65fa9e3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.Designer.cs @@ -0,0 +1,73 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace _2024._02._26.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("_2024._02._26.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + + /// + /// Looks up a localized resource of type System.Drawing.Bitmap. + /// + internal static System.Drawing.Bitmap Screenshot_2023_12_05_115119 { + get { + object obj = ResourceManager.GetObject("Screenshot 2023-12-05 115119", resourceCulture); + return ((System.Drawing.Bitmap)(obj)); + } + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.resx new file mode 100644 index 0000000..da802ac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Properties/Resources.resx @@ -0,0 +1,124 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + + ..\Resources\Screenshot 2023-12-05 115119.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Resources/Screenshot 2023-12-05 115119.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Resources/Screenshot 2023-12-05 115119.png new file mode 100644 index 0000000..11a53d1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/Resources/Screenshot 2023-12-05 115119.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.deps.json new file mode 100644 index 0000000..62f055f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 02. 26/1.0.0": { + "runtime": { + "2024. 02. 26.dll": {} + } + } + } + }, + "libraries": { + "2024. 02. 26/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.dll new file mode 100644 index 0000000..40e52c3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.exe new file mode 100644 index 0000000..5a452a9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.pdb new file mode 100644 index 0000000..230cce4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/bin/Debug/net6.0-windows/2024. 02. 26.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.dgspec.json new file mode 100644 index 0000000..c52dc46 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj", + "projectName": "2024. 02. 26", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/2024. 02. 26.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfo.cs new file mode 100644 index 0000000..c765b3f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 02. 26")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 02. 26")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 02. 26")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfoInputs.cache new file mode 100644 index 0000000..fda1cda --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +1bd92da53476adbdd02a8abdf689df9456a03db4 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5fb9ff8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._02._26 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.assets.cache new file mode 100644 index 0000000..6dcc396 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..39ce3b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +1ba3d5ea1da114f9cd69b56ca0fe367436cbc556 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..6ebfa06 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.FileListAbsolute.txt @@ -0,0 +1,17 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\bin\Debug\net6.0-windows\2024. 02. 26.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\bin\Debug\net6.0-windows\2024. 02. 26.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\bin\Debug\net6.0-windows\2024. 02. 26.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\bin\Debug\net6.0-windows\2024. 02. 26.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\bin\Debug\net6.0-windows\2024. 02. 26.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\_2024._02._26.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\_2024._02._26.Properties.Resources.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\refint\2024. 02. 26.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\2024. 02. 26.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 02. 26\2024. 02. 26\obj\Debug\net6.0-windows\ref\2024. 02. 26.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.GenerateResource.cache new file mode 100644 index 0000000..c5f0997 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.dll new file mode 100644 index 0000000..40e52c3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.genruntimeconfig.cache new file mode 100644 index 0000000..5df2373 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.genruntimeconfig.cache @@ -0,0 +1 @@ +79245c6b6512c93cd4fcacecd87e7df78d41bef7 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.pdb new file mode 100644 index 0000000..230cce4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/2024. 02. 26.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Properties.Resources.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Properties.Resources.resources new file mode 100644 index 0000000..6a3c1dc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/_2024._02._26.Properties.Resources.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..5a452a9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/ref/2024. 02. 26.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/ref/2024. 02. 26.dll new file mode 100644 index 0000000..0d73065 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/ref/2024. 02. 26.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/refint/2024. 02. 26.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/refint/2024. 02. 26.dll new file mode 100644 index 0000000..0d73065 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/Debug/net6.0-windows/refint/2024. 02. 26.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.assets.json new file mode 100644 index 0000000..53fa2ab --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj", + "projectName": "2024. 02. 26", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.nuget.cache new file mode 100644 index 0000000..cb6a853 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 02. 26/2024. 02. 26/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "bVdqFveGZoKIdRiLJqmSFx6pVAXVmImjapTtl/lebbBRK/DDaKweS4YI4OCf4k8VVt3v8OVTKJJqdz2WdCQ2ng==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 02. 26\\2024. 02. 26\\2024. 02. 26.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..4acb205 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/7b82778e-9f07-46e1-a8a2-085366ecef31.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/7b82778e-9f07-46e1-a8a2-085366ecef31.vsidx new file mode 100644 index 0000000..be5ba62 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/7b82778e-9f07-46e1-a8a2-085366ecef31.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/f9e22b03-1769-4908-80df-c604f303c2dd.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/f9e22b03-1769-4908-80df-c604f303c2dd.vsidx new file mode 100644 index 0000000..0fb5b8d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/FileContentIndex/f9e22b03-1769-4908-80df-c604f303c2dd.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.futdcache.v2 new file mode 100644 index 0000000..b37be7e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.suo new file mode 100644 index 0000000..3b3918d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/2024. 03. 04 - 2/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.metadata.v7.bin new file mode 100644 index 0000000..5f1728f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.projects.v7.bin new file mode 100644 index 0000000..0697b8a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/.vs/ProjectEvaluation/2024. 03. 04 - 2.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2.sln new file mode 100644 index 0000000..5947d5d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 04 - 2", "2024. 03. 04 - 2\2024. 03. 04 - 2.csproj", "{04F4C99B-3A0A-44CB-AFD7-85A7219C577B}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {04F4C99B-3A0A-44CB-AFD7-85A7219C577B}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {04F4C99B-3A0A-44CB-AFD7-85A7219C577B}.Debug|Any CPU.Build.0 = Debug|Any CPU + {04F4C99B-3A0A-44CB-AFD7-85A7219C577B}.Release|Any CPU.ActiveCfg = Release|Any CPU + {04F4C99B-3A0A-44CB-AFD7-85A7219C577B}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2984B319-5B0D-4852-A5ED-69B2C1700C23} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj new file mode 100644 index 0000000..62d6c5c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._04___2 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/2024. 03. 04 - 2.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.Designer.cs new file mode 100644 index 0000000..e910727 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.Designer.cs @@ -0,0 +1,114 @@ +namespace _2024._03._04___2 +{ + partial class Szokoev + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + H1 = new Label(); + AskerLabel = new Label(); + Ev = new TextBox(); + Check = new Button(); + Eredmeny = new Label(); + SuspendLayout(); + // + // H1 + // + H1.AutoSize = true; + H1.Font = new Font("Tw Cen MT Condensed Extra Bold", 22.2F, FontStyle.Regular, GraphicsUnit.Point); + H1.Location = new Point(144, 67); + H1.Name = "H1"; + H1.Size = new Size(265, 44); + H1.TabIndex = 0; + H1.Text = "Szökőév program"; + // + // AskerLabel + // + AskerLabel.AutoSize = true; + AskerLabel.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + AskerLabel.Location = new Point(89, 211); + AskerLabel.Name = "AskerLabel"; + AskerLabel.Size = new Size(177, 28); + AskerLabel.TabIndex = 1; + AskerLabel.Text = "Add meg az évet: "; + // + // Ev + // + Ev.BackColor = SystemColors.AppWorkspace; + Ev.Font = new Font("Segoe UI", 14.2F, FontStyle.Regular, GraphicsUnit.Point); + Ev.ForeColor = Color.Black; + Ev.Location = new Point(293, 201); + Ev.Name = "Ev"; + Ev.Size = new Size(125, 39); + Ev.TabIndex = 2; + // + // Check + // + Check.Font = new Font("Tw Cen MT Condensed", 12F, FontStyle.Bold, GraphicsUnit.Point); + Check.Location = new Point(208, 294); + Check.Name = "Check"; + Check.Size = new Size(118, 39); + Check.TabIndex = 3; + Check.Text = "Lássuk!"; + Check.UseVisualStyleBackColor = true; + Check.Click += Check_Click; + // + // Eredmeny + // + Eredmeny.AutoSize = true; + Eredmeny.Font = new Font("Segoe UI", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + Eredmeny.Location = new Point(187, 375); + Eredmeny.Name = "Eredmeny"; + Eredmeny.Size = new Size(79, 31); + Eredmeny.TabIndex = 4; + Eredmeny.Text = "Az év: "; + // + // Szokoev + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackColor = Color.Magenta; + ClientSize = new Size(544, 450); + Controls.Add(Eredmeny); + Controls.Add(Check); + Controls.Add(Ev); + Controls.Add(AskerLabel); + Controls.Add(H1); + Name = "Szokoev"; + Text = "Szökőév"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label H1; + private Label AskerLabel; + private TextBox Ev; + private Button Check; + private Label Eredmeny; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.cs new file mode 100644 index 0000000..238bb19 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.cs @@ -0,0 +1,25 @@ +namespace _2024._03._04___2 +{ + public partial class Szokoev : Form + { + public Szokoev() + { + InitializeComponent(); + } + + private void Check_Click(object sender, EventArgs e) + { + int year = Convert.ToInt32(Ev.Text); + + if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) + { + Eredmeny.Text = "Az v: szkv!"; + } + + else + { + Eredmeny.Text = "Az v: nem szkv!"; + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Program.cs new file mode 100644 index 0000000..07119a4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._04___2 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Szokoev()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.deps.json new file mode 100644 index 0000000..6a8e07a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 04 - 2/1.0.0": { + "runtime": { + "2024. 03. 04 - 2.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 04 - 2/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.dll new file mode 100644 index 0000000..ee709d2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.exe new file mode 100644 index 0000000..c904f21 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.pdb new file mode 100644 index 0000000..3e7012b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/bin/Debug/net6.0-windows/2024. 03. 04 - 2.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..13ae218 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj", + "projectName": "2024. 03. 04 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/2024. 03. 04 - 2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfo.cs new file mode 100644 index 0000000..7df5504 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 04 - 2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 04 - 2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 04 - 2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..004df41 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +8900704c5cabbfff2a5ad044d275691aef4c2ce4 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..a370927 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._04___2 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.assets.cache new file mode 100644 index 0000000..a119685 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..0cf5ced --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +f05474878ee6fb657a014736ea57126cf3100182 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..bee9c42 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\bin\Debug\net6.0-windows\2024. 03. 04 - 2.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\bin\Debug\net6.0-windows\2024. 03. 04 - 2.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\bin\Debug\net6.0-windows\2024. 03. 04 - 2.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\bin\Debug\net6.0-windows\2024. 03. 04 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\bin\Debug\net6.0-windows\2024. 03. 04 - 2.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\_2024._03._04___2.Szokoev.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\refint\2024. 03. 04 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\2024. 03. 04 - 2.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 2\2024. 03. 04 - 2\obj\Debug\net6.0-windows\ref\2024. 03. 04 - 2.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.GenerateResource.cache new file mode 100644 index 0000000..b50bfed Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.dll new file mode 100644 index 0000000..ee709d2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.genruntimeconfig.cache new file mode 100644 index 0000000..ab90d60 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.genruntimeconfig.cache @@ -0,0 +1 @@ +a2d1cb3dc67cfc709936cb215f8f8a3fe207cf9d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.pdb new file mode 100644 index 0000000..3e7012b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/2024. 03. 04 - 2.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/_2024._03._04___2.Szokoev.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/_2024._03._04___2.Szokoev.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/_2024._03._04___2.Szokoev.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..c904f21 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 2.dll new file mode 100644 index 0000000..0152a0f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 2.dll new file mode 100644 index 0000000..0152a0f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.assets.json new file mode 100644 index 0000000..c0c9c1c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj", + "projectName": "2024. 03. 04 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.nuget.cache new file mode 100644 index 0000000..e4d1fde --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 2/2024. 03. 04 - 2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "P0wCqPt90s2bbl07vhfMLBJ8oaN56TbhVfde/0dv+Wb8E8NJNaZkCHIN4zICbmF8tV7KHCRDzJ66UPGwlbIEdg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 2\\2024. 03. 04 - 2\\2024. 03. 04 - 2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..2f12e83 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/311f6aee-f5f6-430b-811b-873b872918a5.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/311f6aee-f5f6-430b-811b-873b872918a5.vsidx new file mode 100644 index 0000000..e74bd31 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/311f6aee-f5f6-430b-811b-873b872918a5.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/bedaf45d-21a3-4ea8-af03-c862b39d270b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/bedaf45d-21a3-4ea8-af03-c862b39d270b.vsidx new file mode 100644 index 0000000..fbc6301 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/FileContentIndex/bedaf45d-21a3-4ea8-af03-c862b39d270b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.futdcache.v2 new file mode 100644 index 0000000..d5ff831 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.suo new file mode 100644 index 0000000..e0be849 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/2024. 03. 04 - 3/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.metadata.v7.bin new file mode 100644 index 0000000..02ea71d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.projects.v7.bin new file mode 100644 index 0000000..b1bcda1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/.vs/ProjectEvaluation/2024. 03. 04 - 3.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3.sln new file mode 100644 index 0000000..0ad41df --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 04 - 3", "2024. 03. 04 - 3\2024. 03. 04 - 3.csproj", "{DCFAC109-613E-4E70-B880-3216B9A3FE44}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {DCFAC109-613E-4E70-B880-3216B9A3FE44}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {DCFAC109-613E-4E70-B880-3216B9A3FE44}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DCFAC109-613E-4E70-B880-3216B9A3FE44}.Release|Any CPU.ActiveCfg = Release|Any CPU + {DCFAC109-613E-4E70-B880-3216B9A3FE44}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {A51C7B00-16A3-4AC4-A758-57C4D2390D8E} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj new file mode 100644 index 0000000..32fb5a1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._04___3 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/2024. 03. 04 - 3.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.Designer.cs new file mode 100644 index 0000000..24788ca --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.Designer.cs @@ -0,0 +1,114 @@ +namespace _2024._03._04___3 +{ + partial class Alkohol + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + H1 = new Label(); + AskerLabel = new Label(); + AlcoholLevel = new TextBox(); + Eredmeny = new Label(); + Check = new Button(); + SuspendLayout(); + // + // H1 + // + H1.AutoSize = true; + H1.Font = new Font("Segoe UI", 22.2F, FontStyle.Regular, GraphicsUnit.Point); + H1.Location = new Point(126, 39); + H1.Name = "H1"; + H1.Size = new Size(319, 50); + H1.TabIndex = 0; + H1.Text = "Alkohol szintmérő"; + // + // AskerLabel + // + AskerLabel.AutoSize = true; + AskerLabel.Font = new Font("Segoe UI Semibold", 12.8F, FontStyle.Bold, GraphicsUnit.Point); + AskerLabel.Location = new Point(79, 190); + AskerLabel.Name = "AskerLabel"; + AskerLabel.Size = new Size(215, 30); + AskerLabel.TabIndex = 1; + AskerLabel.Text = "A véralkoholszinted:"; + // + // AlcoholLevel + // + AlcoholLevel.Font = new Font("Segoe UI", 11F, FontStyle.Regular, GraphicsUnit.Point); + AlcoholLevel.Location = new Point(337, 188); + AlcoholLevel.Name = "AlcoholLevel"; + AlcoholLevel.Size = new Size(125, 32); + AlcoholLevel.TabIndex = 2; + // + // Eredmeny + // + Eredmeny.AutoSize = true; + Eredmeny.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + Eredmeny.ForeColor = Color.Black; + Eredmeny.Location = new Point(158, 343); + Eredmeny.Name = "Eredmeny"; + Eredmeny.Size = new Size(125, 28); + Eredmeny.TabIndex = 3; + Eredmeny.Text = "A te szinted:"; + // + // Check + // + Check.Font = new Font("Verdana", 12.8F, FontStyle.Regular, GraphicsUnit.Point); + Check.ForeColor = SystemColors.ControlText; + Check.Location = new Point(213, 263); + Check.Name = "Check"; + Check.Size = new Size(128, 41); + Check.TabIndex = 4; + Check.Text = "Lássuk!"; + Check.UseVisualStyleBackColor = true; + Check.Click += Check_Click; + // + // Alkohol + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackColor = Color.DeepPink; + ClientSize = new Size(548, 450); + Controls.Add(Check); + Controls.Add(Eredmeny); + Controls.Add(AlcoholLevel); + Controls.Add(AskerLabel); + Controls.Add(H1); + Name = "Alkohol"; + Text = "Alkohol"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label H1; + private Label AskerLabel; + private TextBox AlcoholLevel; + private Label Eredmeny; + private Button Check; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.cs new file mode 100644 index 0000000..bffed3d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.cs @@ -0,0 +1,35 @@ +namespace _2024._03._04___3 +{ + public partial class Alkohol : Form + { + public Alkohol() + { + InitializeComponent(); + } + + private void Check_Click(object sender, EventArgs e) + { + double level = Convert.ToDouble(AlcoholLevel.Text); + + if (level >= 0.5 && level < 1.5) + { + Eredmeny.Text = "A te szinted: Ittassg!"; + } + + else if (level >= 1.5 && level < 2.5) + { + Eredmeny.Text = "A te szinted: Rszegsg!"; + } + + else if (level >= 2.5) + { + Eredmeny.Text = "A te szinted: Alkoholmrgezs!"; + } + + else + { + Eredmeny.Text = "Helytelen rtket adtl meg!"; + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Program.cs new file mode 100644 index 0000000..9903d3e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._04___3 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Alkohol()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.deps.json new file mode 100644 index 0000000..7654431 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 04 - 3/1.0.0": { + "runtime": { + "2024. 03. 04 - 3.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 04 - 3/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.dll new file mode 100644 index 0000000..3057f44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.exe new file mode 100644 index 0000000..de85d24 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.pdb new file mode 100644 index 0000000..f580034 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/bin/Debug/net6.0-windows/2024. 03. 04 - 3.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.dgspec.json new file mode 100644 index 0000000..08a45a8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj", + "projectName": "2024. 03. 04 - 3", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/2024. 03. 04 - 3.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfo.cs new file mode 100644 index 0000000..b01fd06 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 04 - 3")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 04 - 3")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 04 - 3")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfoInputs.cache new file mode 100644 index 0000000..72e717d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +5272b76b2772c9298c864fb537cac61c4307568d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..ea227db --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._04___3 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.assets.cache new file mode 100644 index 0000000..6f228fb Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..7c93769 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +68c07b171054ddd4b91790f0ef8d6f3cdf50a225 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..71a68da --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\bin\Debug\net6.0-windows\2024. 03. 04 - 3.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\bin\Debug\net6.0-windows\2024. 03. 04 - 3.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\bin\Debug\net6.0-windows\2024. 03. 04 - 3.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\bin\Debug\net6.0-windows\2024. 03. 04 - 3.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\bin\Debug\net6.0-windows\2024. 03. 04 - 3.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\_2024._03._04___3.Alkohol.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\refint\2024. 03. 04 - 3.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\2024. 03. 04 - 3.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04 - 3\2024. 03. 04 - 3\obj\Debug\net6.0-windows\ref\2024. 03. 04 - 3.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.GenerateResource.cache new file mode 100644 index 0000000..cc3bb5b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.dll new file mode 100644 index 0000000..3057f44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.genruntimeconfig.cache new file mode 100644 index 0000000..ac6e16c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.genruntimeconfig.cache @@ -0,0 +1 @@ +5555cec305ab2437846f59bafa7d083162fdab38 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.pdb new file mode 100644 index 0000000..f580034 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/2024. 03. 04 - 3.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/_2024._03._04___3.Alkohol.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/_2024._03._04___3.Alkohol.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/_2024._03._04___3.Alkohol.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..de85d24 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 3.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 3.dll new file mode 100644 index 0000000..0558dad Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/ref/2024. 03. 04 - 3.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 3.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 3.dll new file mode 100644 index 0000000..0558dad Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/Debug/net6.0-windows/refint/2024. 03. 04 - 3.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.assets.json new file mode 100644 index 0000000..90e5b04 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj", + "projectName": "2024. 03. 04 - 3", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.nuget.cache new file mode 100644 index 0000000..5f1c786 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04 - 3/2024. 03. 04 - 3/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "oyRDIcXLr36sKLJ395SOro6xM90cirBUl2O5RAmMRo7xxpdSr82D63bi3TViQj5MUnrs0B5+FSHp+zMqM/XXFw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04 - 3\\2024. 03. 04 - 3\\2024. 03. 04 - 3.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..1c35fc9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/94167ec0-16d0-4d34-aa51-4db4c62502bf.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/94167ec0-16d0-4d34-aa51-4db4c62502bf.vsidx new file mode 100644 index 0000000..6cabe1b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/94167ec0-16d0-4d34-aa51-4db4c62502bf.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/a1d62d3c-0c79-4398-a76d-4b46ca210618.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/a1d62d3c-0c79-4398-a76d-4b46ca210618.vsidx new file mode 100644 index 0000000..64a32a5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/FileContentIndex/a1d62d3c-0c79-4398-a76d-4b46ca210618.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.futdcache.v2 new file mode 100644 index 0000000..f35a59a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.suo new file mode 100644 index 0000000..c6a84ff Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/2024. 03. 04/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.metadata.v7.bin new file mode 100644 index 0000000..83a053e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.projects.v7.bin new file mode 100644 index 0000000..5047466 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/.vs/ProjectEvaluation/2024. 03. 04.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04.sln new file mode 100644 index 0000000..5291885 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 04", "2024. 03. 04\2024. 03. 04.csproj", "{ADE5DB97-2458-446E-B582-6EF056B35738}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {ADE5DB97-2458-446E-B582-6EF056B35738}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {ADE5DB97-2458-446E-B582-6EF056B35738}.Debug|Any CPU.Build.0 = Debug|Any CPU + {ADE5DB97-2458-446E-B582-6EF056B35738}.Release|Any CPU.ActiveCfg = Release|Any CPU + {ADE5DB97-2458-446E-B582-6EF056B35738}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {99A53AD1-A996-48A6-8091-980943E6E8CA} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj new file mode 100644 index 0000000..75404b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._04 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/2024. 03. 04.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.Designer.cs new file mode 100644 index 0000000..65106d4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.Designer.cs @@ -0,0 +1,204 @@ +namespace _2024._03._04 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + Oldal1 = new TextBox(); + Oldal2 = new TextBox(); + Oldal3 = new TextBox(); + H1 = new Label(); + Button = new Button(); + label1 = new Label(); + label2 = new Label(); + label3 = new Label(); + label4 = new Label(); + label5 = new Label(); + label6 = new Label(); + Eredmeny = new Label(); + SuspendLayout(); + // + // Oldal1 + // + Oldal1.BackColor = SystemColors.GrayText; + Oldal1.Font = new Font("Segoe UI", 10.8F, FontStyle.Regular, GraphicsUnit.Point); + Oldal1.ForeColor = SystemColors.Window; + Oldal1.Location = new Point(86, 148); + Oldal1.Name = "Oldal1"; + Oldal1.Size = new Size(127, 31); + Oldal1.TabIndex = 0; + // + // Oldal2 + // + Oldal2.BackColor = SystemColors.GrayText; + Oldal2.Font = new Font("Segoe UI", 10.8F, FontStyle.Regular, GraphicsUnit.Point); + Oldal2.ForeColor = SystemColors.Window; + Oldal2.Location = new Point(324, 148); + Oldal2.Name = "Oldal2"; + Oldal2.Size = new Size(127, 31); + Oldal2.TabIndex = 1; + // + // Oldal3 + // + Oldal3.BackColor = SystemColors.GrayText; + Oldal3.Font = new Font("Segoe UI", 10.8F, FontStyle.Regular, GraphicsUnit.Point); + Oldal3.ForeColor = SystemColors.Window; + Oldal3.Location = new Point(572, 148); + Oldal3.Name = "Oldal3"; + Oldal3.Size = new Size(127, 31); + Oldal3.TabIndex = 2; + // + // H1 + // + H1.AutoSize = true; + H1.Font = new Font("Segoe Print", 22.2F, FontStyle.Regular, GraphicsUnit.Point); + H1.Location = new Point(108, 45); + H1.Name = "H1"; + H1.Size = new Size(591, 64); + H1.TabIndex = 3; + H1.Text = "A háromszög szerkezthetősége"; + // + // Button + // + Button.BackColor = SystemColors.GradientActiveCaption; + Button.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + Button.Location = new Point(314, 272); + Button.Name = "Button"; + Button.Size = new Size(137, 54); + Button.TabIndex = 4; + Button.Text = "Nézzük!"; + Button.UseVisualStyleBackColor = false; + Button.Click += Button_Click; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Tempus Sans ITC", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + label1.Location = new Point(79, 208); + label1.Name = "label1"; + label1.Size = new Size(134, 23); + label1.TabIndex = 5; + label1.Text = "1. oldal hossza"; + // + // label2 + // + label2.AutoSize = true; + label2.Font = new Font("Tempus Sans ITC", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + label2.Location = new Point(324, 208); + label2.Name = "label2"; + label2.Size = new Size(137, 23); + label2.TabIndex = 6; + label2.Text = "2. oldal hossza"; + // + // label3 + // + label3.AutoSize = true; + label3.Font = new Font("Tempus Sans ITC", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + label3.Location = new Point(572, 208); + label3.Name = "label3"; + label3.Size = new Size(136, 23); + label3.TabIndex = 7; + label3.Text = "3. oldal hossza"; + // + // label4 + // + label4.AutoSize = true; + label4.Font = new Font("Times New Roman", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + label4.Location = new Point(324, 387); + label4.Name = "label4"; + label4.Size = new Size(0, 26); + label4.TabIndex = 8; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(366, 385); + label5.Name = "label5"; + label5.Size = new Size(0, 20); + label5.TabIndex = 9; + // + // label6 + // + label6.AutoSize = true; + label6.Font = new Font("Times New Roman", 16.2F, FontStyle.Regular, GraphicsUnit.Point); + label6.Location = new Point(227, 363); + label6.Name = "label6"; + label6.Size = new Size(22, 33); + label6.TabIndex = 10; + label6.Text = " "; + // + // Eredmeny + // + Eredmeny.AutoSize = true; + Eredmeny.Font = new Font("Times New Roman", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + Eredmeny.Location = new Point(255, 367); + Eredmeny.Name = "Eredmeny"; + Eredmeny.Size = new Size(218, 26); + Eredmeny.TabIndex = 11; + Eredmeny.Text = "Várunk a bemenetre..."; + Eredmeny.TextAlign = ContentAlignment.MiddleCenter; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackColor = Color.Violet; + ClientSize = new Size(791, 450); + Controls.Add(Eredmeny); + Controls.Add(label6); + Controls.Add(label5); + Controls.Add(label4); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(label1); + Controls.Add(Button); + Controls.Add(H1); + Controls.Add(Oldal3); + Controls.Add(Oldal2); + Controls.Add(Oldal1); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private TextBox Oldal1; + private TextBox Oldal2; + private TextBox Oldal3; + private Label H1; + private Button Button; + private Label label1; + private Label label2; + private Label label3; + private Label label4; + private Label label5; + private Label label6; + private Label Eredmeny; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.cs new file mode 100644 index 0000000..4ecdf14 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.cs @@ -0,0 +1,28 @@ +namespace _2024._03._04 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void Button_Click(object sender, EventArgs e) + { + int oldal1 = Convert.ToInt32(Oldal1.Text); + int oldal2 = Convert.ToInt32(Oldal2.Text); + int oldal3 = Convert.ToInt32(Oldal3.Text); + + if (oldal1 + oldal2 > oldal3 && oldal1 + oldal3 > oldal2 && oldal2 + oldal3 > oldal1) + { + Eredmeny.Text = "A hromszg szerkezthet!"; + } + + else + { + Eredmeny.Text = "A hromszg nem szerkezthet!"; + } + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Program.cs new file mode 100644 index 0000000..16b7828 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._04 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.deps.json new file mode 100644 index 0000000..b1dc603 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 04/1.0.0": { + "runtime": { + "2024. 03. 04.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 04/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.dll new file mode 100644 index 0000000..3834d05 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.exe new file mode 100644 index 0000000..7363af7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.pdb new file mode 100644 index 0000000..cc6f399 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/bin/Debug/net6.0-windows/2024. 03. 04.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.dgspec.json new file mode 100644 index 0000000..98e8ea7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj", + "projectName": "2024. 03. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/2024. 03. 04.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfo.cs new file mode 100644 index 0000000..390d9d4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 04")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 04")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 04")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfoInputs.cache new file mode 100644 index 0000000..da024cb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +f67f45e2daf86fc53fad0c9ceebb60f59d1ab425 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0789dd9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._04 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.assets.cache new file mode 100644 index 0000000..5eeccd7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..86635b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +5cac470ca0d83950d2829daa5593f309bc029ad8 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..665e7b7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\bin\Debug\net6.0-windows\2024. 03. 04.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\bin\Debug\net6.0-windows\2024. 03. 04.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\bin\Debug\net6.0-windows\2024. 03. 04.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\bin\Debug\net6.0-windows\2024. 03. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\bin\Debug\net6.0-windows\2024. 03. 04.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\_2024._03._04.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\refint\2024. 03. 04.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\2024. 03. 04.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 04\2024. 03. 04\obj\Debug\net6.0-windows\ref\2024. 03. 04.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.GenerateResource.cache new file mode 100644 index 0000000..e5e32ee Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.dll new file mode 100644 index 0000000..3834d05 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.genruntimeconfig.cache new file mode 100644 index 0000000..4a1d381 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.genruntimeconfig.cache @@ -0,0 +1 @@ +f7f80c61e8f612bdd2f0d67587383735cea56dc9 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.pdb new file mode 100644 index 0000000..cc6f399 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/2024. 03. 04.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/_2024._03._04.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/_2024._03._04.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/_2024._03._04.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..7363af7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/ref/2024. 03. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/ref/2024. 03. 04.dll new file mode 100644 index 0000000..a069b7e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/ref/2024. 03. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/refint/2024. 03. 04.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/refint/2024. 03. 04.dll new file mode 100644 index 0000000..a069b7e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/Debug/net6.0-windows/refint/2024. 03. 04.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.assets.json new file mode 100644 index 0000000..75fbb41 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj", + "projectName": "2024. 03. 04", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.nuget.cache new file mode 100644 index 0000000..bb91a36 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 04/2024. 03. 04/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "6zDGCtbcuUgqjd+6fmkVtvpSQIHr4AKOjALK5TH+RqZ0IqtlP3t8MevynEjIqCSQMg3kpUDs3ua9IenyCDw28A==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 04\\2024. 03. 04\\2024. 03. 04.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..d2a48ef Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/63a28371-a873-4e6f-a729-989c9c564535.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/63a28371-a873-4e6f-a729-989c9c564535.vsidx new file mode 100644 index 0000000..694834f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/63a28371-a873-4e6f-a729-989c9c564535.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/de6fc312-6d46-4805-9b36-dfef4c14f938.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/de6fc312-6d46-4805-9b36-dfef4c14f938.vsidx new file mode 100644 index 0000000..51d4dd0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/FileContentIndex/de6fc312-6d46-4805-9b36-dfef4c14f938.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.futdcache.v2 new file mode 100644 index 0000000..fe9f73f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.suo new file mode 100644 index 0000000..f36d8f8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/2024. 03. 11/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.metadata.v7.bin new file mode 100644 index 0000000..abaff8e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.projects.v7.bin new file mode 100644 index 0000000..1d64d8e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/.vs/ProjectEvaluation/2024. 03. 11.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11.sln new file mode 100644 index 0000000..b3d1e2b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 11", "2024. 03. 11\2024. 03. 11.csproj", "{41A7245B-AD30-4806-A8C3-7BC2ADA914C8}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {41A7245B-AD30-4806-A8C3-7BC2ADA914C8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {41A7245B-AD30-4806-A8C3-7BC2ADA914C8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {41A7245B-AD30-4806-A8C3-7BC2ADA914C8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {41A7245B-AD30-4806-A8C3-7BC2ADA914C8}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {978C2390-6AA4-4132-98D5-48A2950AEA81} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj new file mode 100644 index 0000000..1a73882 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._11 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/2024. 03. 11.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.Designer.cs new file mode 100644 index 0000000..152461d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.Designer.cs @@ -0,0 +1,97 @@ +namespace _2024._03._11 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + TimeText = new TextBox(); + StartBtn = new Button(); + StopBtn = new Button(); + label1 = new Label(); + SuspendLayout(); + // + // TimeText + // + TimeText.Location = new Point(241, 150); + TimeText.Name = "TimeText"; + TimeText.Size = new Size(299, 27); + TimeText.TabIndex = 0; + TimeText.TextAlign = HorizontalAlignment.Center; + TimeText.TextChanged += TimeText_TextChanged; + // + // StartBtn + // + StartBtn.Location = new Point(155, 279); + StartBtn.Name = "StartBtn"; + StartBtn.Size = new Size(94, 29); + StartBtn.TabIndex = 1; + StartBtn.Text = "START"; + StartBtn.UseVisualStyleBackColor = true; + StartBtn.Click += StartBtn_Click; + // + // StopBtn + // + StopBtn.Location = new Point(476, 279); + StopBtn.Name = "StopBtn"; + StopBtn.Size = new Size(94, 29); + StopBtn.TabIndex = 2; + StopBtn.Text = "STOP"; + StopBtn.UseVisualStyleBackColor = true; + StopBtn.Click += StopBtn_Click; + // + // label1 + // + label1.AutoSize = true; + label1.Location = new Point(338, 346); + label1.Name = "label1"; + label1.Size = new Size(50, 20); + label1.TabIndex = 3; + label1.Text = "label1"; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(label1); + Controls.Add(StopBtn); + Controls.Add(StartBtn); + Controls.Add(TimeText); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private TextBox TimeText; + private Button StartBtn; + private Button StopBtn; + private Label label1; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.cs new file mode 100644 index 0000000..045ff19 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.cs @@ -0,0 +1,33 @@ +using System.Timers; +namespace _2024._03._11 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + System.Timers.Timer Timer; + + private void TimeText_TextChanged(object sender, EventArgs e) + { + Timer = new System.Timers.Timer(); + Timer.Interval = 1000; + Timer.Elapsed += StartBtn_Click; + } + + private void StartBtn_Click(object sender, EventArgs e) + { + Timer.Enabled = true; + StartBtn.Enabled = false; + label1.Text = "{0:HH:mm:ss.fff}"; + } + + private void StopBtn_Click(object sender, EventArgs e) + { + Timer.Enabled = false; + StartBtn.Enabled = true; + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Program.cs new file mode 100644 index 0000000..7c66f1f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._11 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.deps.json new file mode 100644 index 0000000..2719e88 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 11/1.0.0": { + "runtime": { + "2024. 03. 11.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 11/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.dll new file mode 100644 index 0000000..1b7c567 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.exe new file mode 100644 index 0000000..918d203 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.pdb new file mode 100644 index 0000000..5d70d8c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/bin/Debug/net6.0-windows/2024. 03. 11.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..e85f472 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj", + "projectName": "2024. 03. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/2024. 03. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfo.cs new file mode 100644 index 0000000..5da8a6a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..5785db1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +91a12275f5d11d24212106d9d2a7b5cb8e350616 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..6e20d56 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._11 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.assets.cache new file mode 100644 index 0000000..7100848 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..4610ccd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +02afc9ea509ac3acacdc58f4ed276315d5b3d6a8 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..16d21cf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\bin\Debug\net6.0-windows\2024. 03. 11.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\bin\Debug\net6.0-windows\2024. 03. 11.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\bin\Debug\net6.0-windows\2024. 03. 11.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\bin\Debug\net6.0-windows\2024. 03. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\bin\Debug\net6.0-windows\2024. 03. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\_2024._03._11.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\refint\2024. 03. 11.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\2024. 03. 11.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 11\2024. 03. 11\obj\Debug\net6.0-windows\ref\2024. 03. 11.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.GenerateResource.cache new file mode 100644 index 0000000..1b6913e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.dll new file mode 100644 index 0000000..1b7c567 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.genruntimeconfig.cache new file mode 100644 index 0000000..948c693 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.genruntimeconfig.cache @@ -0,0 +1 @@ +04f683ac397f0b43a36975c71a0631f131e7af54 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.pdb new file mode 100644 index 0000000..5d70d8c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/2024. 03. 11.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/_2024._03._11.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/_2024._03._11.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/_2024._03._11.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..918d203 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/ref/2024. 03. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/ref/2024. 03. 11.dll new file mode 100644 index 0000000..edf2e04 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/ref/2024. 03. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/refint/2024. 03. 11.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/refint/2024. 03. 11.dll new file mode 100644 index 0000000..edf2e04 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/Debug/net6.0-windows/refint/2024. 03. 11.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.assets.json new file mode 100644 index 0000000..7bbc00e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj", + "projectName": "2024. 03. 11", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.nuget.cache new file mode 100644 index 0000000..8387436 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 11/2024. 03. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "UbIhRUWrbXlOR8378M2Ve4xQrMEzinDTc4mChNeo6PQn+uBEfBbpCF0lVtR6S4r80y8fBhfF3c5krOWj0lQm5Q==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 11\\2024. 03. 11\\2024. 03. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..747e29a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/77ccbea7-14fb-4157-9afd-0ba541baf70b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/77ccbea7-14fb-4157-9afd-0ba541baf70b.vsidx new file mode 100644 index 0000000..785c2db Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/77ccbea7-14fb-4157-9afd-0ba541baf70b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/b4995d98-77a9-40f7-86fe-fd722295f5d7.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/b4995d98-77a9-40f7-86fe-fd722295f5d7.vsidx new file mode 100644 index 0000000..ea18190 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/FileContentIndex/b4995d98-77a9-40f7-86fe-fd722295f5d7.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.futdcache.v2 new file mode 100644 index 0000000..ba7393c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.suo new file mode 100644 index 0000000..04e7583 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/2024. 03. 13 - 1/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.metadata.v7.bin new file mode 100644 index 0000000..2efddc5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.projects.v7.bin new file mode 100644 index 0000000..556bdbf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/.vs/ProjectEvaluation/2024. 03. 13 - 1.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1.sln new file mode 100644 index 0000000..8833324 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 13 - 1", "2024. 03. 13 - 1\2024. 03. 13 - 1.csproj", "{0A436A09-C667-4F0B-BC76-ADD1358B40E9}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {0A436A09-C667-4F0B-BC76-ADD1358B40E9}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {0A436A09-C667-4F0B-BC76-ADD1358B40E9}.Debug|Any CPU.Build.0 = Debug|Any CPU + {0A436A09-C667-4F0B-BC76-ADD1358B40E9}.Release|Any CPU.ActiveCfg = Release|Any CPU + {0A436A09-C667-4F0B-BC76-ADD1358B40E9}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2E970A26-7B8C-46DA-AF83-49974B64A8E8} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj new file mode 100644 index 0000000..6f8c039 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._13___1 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/2024. 03. 13 - 1.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.Designer.cs new file mode 100644 index 0000000..9a240c5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.Designer.cs @@ -0,0 +1,122 @@ +namespace _2024._03._13___1 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + H1 = new Label(); + TimeL = new Label(); + StartBtn = new Button(); + StopBtn = new Button(); + StoreL = new Label(); + KoridoBtn = new Button(); + SuspendLayout(); + // + // H1 + // + H1.AutoSize = true; + H1.Location = new Point(362, 53); + H1.Name = "H1"; + H1.Size = new Size(62, 20); + H1.TabIndex = 0; + H1.Text = "Stopper"; + // + // TimeL + // + TimeL.AutoSize = true; + TimeL.Location = new Point(369, 166); + TimeL.Name = "TimeL"; + TimeL.Size = new Size(45, 20); + TimeL.TabIndex = 1; + TimeL.Text = "Time:"; + // + // StartBtn + // + StartBtn.Location = new Point(159, 277); + StartBtn.Name = "StartBtn"; + StartBtn.Size = new Size(94, 29); + StartBtn.TabIndex = 2; + StartBtn.Text = "Start"; + StartBtn.UseVisualStyleBackColor = true; + StartBtn.Click += StartBtn_Click; + // + // StopBtn + // + StopBtn.Location = new Point(540, 277); + StopBtn.Name = "StopBtn"; + StopBtn.Size = new Size(94, 29); + StopBtn.TabIndex = 3; + StopBtn.Text = "Stop"; + StopBtn.UseVisualStyleBackColor = true; + StopBtn.Click += StopBtn_Click; + // + // StoreL + // + StoreL.AutoSize = true; + StoreL.Location = new Point(374, 240); + StoreL.Name = "StoreL"; + StoreL.Size = new Size(53, 20); + StoreL.TabIndex = 4; + StoreL.Text = "Stored"; + // + // KoridoBtn + // + KoridoBtn.Location = new Point(351, 277); + KoridoBtn.Name = "KoridoBtn"; + KoridoBtn.Size = new Size(94, 29); + KoridoBtn.TabIndex = 5; + KoridoBtn.Text = "Köridő"; + KoridoBtn.UseVisualStyleBackColor = true; + KoridoBtn.Click += KoridoBtn_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(KoridoBtn); + Controls.Add(StoreL); + Controls.Add(StopBtn); + Controls.Add(StartBtn); + Controls.Add(TimeL); + Controls.Add(H1); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label H1; + private Label TimeL; + private Button StartBtn; + private Button StopBtn; + private Label StoreL; + private Button KoridoBtn; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.cs new file mode 100644 index 0000000..759a106 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.cs @@ -0,0 +1,37 @@ +namespace _2024._03._13___1 +{ + public partial class Form1 : Form + { + TimeSpan timespan = TimeSpan.Zero; + System.Windows.Forms.Timer myTimer = new System.Windows.Forms.Timer(); + public Form1() + { + InitializeComponent(); + myTimer.Interval = 1; + myTimer.Tick += Tick; + } + + private void Tick(object sender, EventArgs e) + { + timespan = timespan.Add(TimeSpan.FromSeconds(1)); + timespan = timespan.Add(TimeSpan.FromMilliseconds(1)); + TimeL.Text = $"Time: {timespan.ToString(@"hh\:mm\:ss")}"; + myTimer.Interval = 1000; + } + + private void StartBtn_Click(object sender, EventArgs e) + { + myTimer.Start(); + } + + private void StopBtn_Click(object sender, EventArgs e) + { + myTimer.Stop(); + } + + private void KoridoBtn_Click(object sender, EventArgs e) + { + StoreL.Text += $"\n{timespan.ToString(@"hh\:mm\:ss\:f")}"; + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Program.cs new file mode 100644 index 0000000..5d5bb1a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._13___1 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.deps.json new file mode 100644 index 0000000..a514092 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 13 - 1/1.0.0": { + "runtime": { + "2024. 03. 13 - 1.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 13 - 1/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.dll new file mode 100644 index 0000000..aaf719b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.exe new file mode 100644 index 0000000..34b872d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.pdb new file mode 100644 index 0000000..6af21c3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/bin/Debug/net6.0-windows/2024. 03. 13 - 1.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.dgspec.json new file mode 100644 index 0000000..168e723 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj", + "projectName": "2024. 03. 13 - 1", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/2024. 03. 13 - 1.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfo.cs new file mode 100644 index 0000000..6bf659a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 13 - 1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 13 - 1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 13 - 1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfoInputs.cache new file mode 100644 index 0000000..57c0f03 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e12506b5ea576e7d8972103d307ece6ba1e80b68 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..48281a7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._13___1 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.assets.cache new file mode 100644 index 0000000..178e259 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..1524d0f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +6c976f7732b77006c70d59a26f0c71730fa50f02 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..5f346cf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\bin\Debug\net6.0-windows\2024. 03. 13 - 1.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\bin\Debug\net6.0-windows\2024. 03. 13 - 1.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\bin\Debug\net6.0-windows\2024. 03. 13 - 1.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\bin\Debug\net6.0-windows\2024. 03. 13 - 1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\bin\Debug\net6.0-windows\2024. 03. 13 - 1.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\_2024._03._13___1.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\refint\2024. 03. 13 - 1.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\2024. 03. 13 - 1.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 13 - 1\2024. 03. 13 - 1\obj\Debug\net6.0-windows\ref\2024. 03. 13 - 1.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.GenerateResource.cache new file mode 100644 index 0000000..17fad8a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.dll new file mode 100644 index 0000000..aaf719b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.genruntimeconfig.cache new file mode 100644 index 0000000..959343b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.genruntimeconfig.cache @@ -0,0 +1 @@ +358786a122adf7ec7f6e351e68571600bc3ffb2d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.pdb new file mode 100644 index 0000000..6af21c3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/2024. 03. 13 - 1.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/_2024._03._13___1.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/_2024._03._13___1.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/_2024._03._13___1.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..34b872d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/ref/2024. 03. 13 - 1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/ref/2024. 03. 13 - 1.dll new file mode 100644 index 0000000..aed443c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/ref/2024. 03. 13 - 1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/refint/2024. 03. 13 - 1.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/refint/2024. 03. 13 - 1.dll new file mode 100644 index 0000000..aed443c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/Debug/net6.0-windows/refint/2024. 03. 13 - 1.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.assets.json new file mode 100644 index 0000000..4f63cda --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj", + "projectName": "2024. 03. 13 - 1", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.nuget.cache new file mode 100644 index 0000000..38ef869 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 13 - 1/2024. 03. 13 - 1/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "PEzcQi7oELoalU8byoIIlPybNZD8K5QI9JdDsKuyXphus5e3YpgXRWpCdNs1AF6kA3c7cmmmc6l8ttE7AHYpdA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 13 - 1\\2024. 03. 13 - 1\\2024. 03. 13 - 1.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..f0cf9b6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/3e34ac2b-8fdf-4d1a-a691-b1cd27140e65.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/3e34ac2b-8fdf-4d1a-a691-b1cd27140e65.vsidx new file mode 100644 index 0000000..231a80e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/3e34ac2b-8fdf-4d1a-a691-b1cd27140e65.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/fbfc4c9e-bcd5-4779-9220-820f98e7739f.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/fbfc4c9e-bcd5-4779-9220-820f98e7739f.vsidx new file mode 100644 index 0000000..fec3c22 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/FileContentIndex/fbfc4c9e-bcd5-4779-9220-820f98e7739f.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.futdcache.v2 new file mode 100644 index 0000000..1d0f703 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.suo new file mode 100644 index 0000000..605ba18 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/2024. 03. 18/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.metadata.v7.bin new file mode 100644 index 0000000..b322ab4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.projects.v7.bin new file mode 100644 index 0000000..bbbe4d8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/.vs/ProjectEvaluation/2024. 03. 18.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18.sln new file mode 100644 index 0000000..054f2de --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 18", "2024. 03. 18\2024. 03. 18.csproj", "{81E3BBFF-E49D-4076-9522-8717FEF65AB2}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {81E3BBFF-E49D-4076-9522-8717FEF65AB2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {81E3BBFF-E49D-4076-9522-8717FEF65AB2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {81E3BBFF-E49D-4076-9522-8717FEF65AB2}.Release|Any CPU.ActiveCfg = Release|Any CPU + {81E3BBFF-E49D-4076-9522-8717FEF65AB2}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {5A93DBA5-9232-4F44-9158-68F1FDB3D30A} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj new file mode 100644 index 0000000..e3dfd75 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._18 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/2024. 03. 18.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.Designer.cs new file mode 100644 index 0000000..f02bb71 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.Designer.cs @@ -0,0 +1,168 @@ +namespace _2024._03._18 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + RScrollBar = new HScrollBar(); + GScrollBar = new HScrollBar(); + BScrollBar = new HScrollBar(); + RLabel = new Label(); + GLabel = new Label(); + label3 = new Label(); + RTextBox = new TextBox(); + GTextBox = new TextBox(); + BTextBox = new TextBox(); + panel1 = new Panel(); + SuspendLayout(); + // + // RScrollBar + // + RScrollBar.Location = new Point(136, 132); + RScrollBar.Maximum = 255; + RScrollBar.Name = "RScrollBar"; + RScrollBar.Size = new Size(266, 33); + RScrollBar.TabIndex = 0; + RScrollBar.Scroll += RScrollBar_Scroll; + // + // GScrollBar + // + GScrollBar.Location = new Point(136, 224); + GScrollBar.Maximum = 255; + GScrollBar.Name = "GScrollBar"; + GScrollBar.Size = new Size(266, 33); + GScrollBar.TabIndex = 2; + GScrollBar.Scroll += GScrollBar_Scroll; + // + // BScrollBar + // + BScrollBar.Location = new Point(136, 308); + BScrollBar.Maximum = 255; + BScrollBar.Name = "BScrollBar"; + BScrollBar.Size = new Size(266, 33); + BScrollBar.TabIndex = 3; + BScrollBar.Scroll += BScrollBar_Scroll; + // + // RLabel + // + RLabel.AutoSize = true; + RLabel.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + RLabel.Location = new Point(56, 132); + RLabel.Name = "RLabel"; + RLabel.Size = new Size(32, 33); + RLabel.TabIndex = 4; + RLabel.Text = "R"; + // + // GLabel + // + GLabel.AutoSize = true; + GLabel.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + GLabel.Location = new Point(55, 224); + GLabel.Name = "GLabel"; + GLabel.Size = new Size(33, 33); + GLabel.TabIndex = 5; + GLabel.Text = "G"; + // + // label3 + // + label3.AutoSize = true; + label3.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + label3.Location = new Point(55, 308); + label3.Name = "label3"; + label3.Size = new Size(32, 33); + label3.TabIndex = 6; + label3.Text = "B"; + // + // RTextBox + // + RTextBox.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + RTextBox.Location = new Point(425, 132); + RTextBox.Name = "RTextBox"; + RTextBox.Size = new Size(90, 38); + RTextBox.TabIndex = 7; + RTextBox.TextChanged += RTextBox_TextChanged; + // + // GTextBox + // + GTextBox.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + GTextBox.Location = new Point(425, 219); + GTextBox.Name = "GTextBox"; + GTextBox.Size = new Size(90, 38); + GTextBox.TabIndex = 8; + GTextBox.TextChanged += GTextBox_TextChanged; + // + // BTextBox + // + BTextBox.Font = new Font("Arial Narrow", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + BTextBox.Location = new Point(425, 308); + BTextBox.Name = "BTextBox"; + BTextBox.Size = new Size(90, 38); + BTextBox.TabIndex = 9; + BTextBox.TextChanged += BTextBox_TextChanged; + // + // panel1 + // + panel1.Location = new Point(538, 178); + panel1.Name = "panel1"; + panel1.Size = new Size(250, 125); + panel1.TabIndex = 10; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(panel1); + Controls.Add(BTextBox); + Controls.Add(GTextBox); + Controls.Add(RTextBox); + Controls.Add(label3); + Controls.Add(GLabel); + Controls.Add(RLabel); + Controls.Add(BScrollBar); + Controls.Add(GScrollBar); + Controls.Add(RScrollBar); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private HScrollBar RScrollBar; + private HScrollBar GScrollBar; + private HScrollBar BScrollBar; + private Label RLabel; + private Label GLabel; + private Label label3; + private TextBox RTextBox; + private TextBox GTextBox; + private TextBox BTextBox; + private Panel panel1; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.cs new file mode 100644 index 0000000..9f25e8b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.cs @@ -0,0 +1,52 @@ +namespace _2024._03._18 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void RScrollBar_Scroll(object sender, ScrollEventArgs e) + { + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + RTextBox.Text = RScrollBar.Value.ToString(); + } + + private void GScrollBar_Scroll(object sender, ScrollEventArgs e) + { + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + GTextBox.Text = GScrollBar.Value.ToString(); + } + + private void BScrollBar_Scroll(object sender, ScrollEventArgs e) + { + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + BTextBox.Text = BScrollBar.Value.ToString(); + } + + private void RTextBox_TextChanged(object sender, EventArgs e) + { + if (RTextBox.Text == "-") RTextBox.Text = "0"; + if (int.Parse(RTextBox.Text) > 255) RTextBox.Text = "255"; + RScrollBar.Value = int.Parse(RTextBox.Text); + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + } + + private void GTextBox_TextChanged(object sender, EventArgs e) + { + if (GTextBox.Text == "-") GTextBox.Text = "0"; + if (int.Parse(GTextBox.Text) > 255) GTextBox.Text = "255"; + GScrollBar.Value = int.Parse(GTextBox.Text); + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + } + + private void BTextBox_TextChanged(object sender, EventArgs e) + { + if (BTextBox.Text == "-") BTextBox.Text = "0"; + if (int.Parse(BTextBox.Text) > 255) BTextBox.Text = "255"; + BScrollBar.Value = int.Parse(BTextBox.Text); + panel1.BackColor = Color.FromArgb(RScrollBar.Value, GScrollBar.Value, BScrollBar.Value); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Program.cs new file mode 100644 index 0000000..1f1fec2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._18 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.deps.json new file mode 100644 index 0000000..13aa9d4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 18/1.0.0": { + "runtime": { + "2024. 03. 18.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 18/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.dll new file mode 100644 index 0000000..512e026 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.exe new file mode 100644 index 0000000..76274e2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.pdb new file mode 100644 index 0000000..f12f60d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/bin/Debug/net6.0-windows/2024. 03. 18.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.dgspec.json new file mode 100644 index 0000000..9dd87a9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj", + "projectName": "2024. 03. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/2024. 03. 18.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfo.cs new file mode 100644 index 0000000..1bc466c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfoInputs.cache new file mode 100644 index 0000000..5c63a61 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +f7fe6f49c9a5b515d38ad093e13443e0e749396c diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..e6667b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._18 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.assets.cache new file mode 100644 index 0000000..a1cd843 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..b8a2993 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +adc789fabb215ae8cf78b3631e128186badab972 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..08d09a6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\bin\Debug\net6.0-windows\2024. 03. 18.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\bin\Debug\net6.0-windows\2024. 03. 18.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\bin\Debug\net6.0-windows\2024. 03. 18.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\bin\Debug\net6.0-windows\2024. 03. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\bin\Debug\net6.0-windows\2024. 03. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\_2024._03._18.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\refint\2024. 03. 18.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\2024. 03. 18.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 18\2024. 03. 18\obj\Debug\net6.0-windows\ref\2024. 03. 18.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.GenerateResource.cache new file mode 100644 index 0000000..8a82190 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.dll new file mode 100644 index 0000000..512e026 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.genruntimeconfig.cache new file mode 100644 index 0000000..10e24cb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.genruntimeconfig.cache @@ -0,0 +1 @@ +2aea6be1606b5f036fe6a575d0f77d109b95676b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.pdb new file mode 100644 index 0000000..f12f60d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/2024. 03. 18.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/_2024._03._18.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/_2024._03._18.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/_2024._03._18.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..76274e2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/ref/2024. 03. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/ref/2024. 03. 18.dll new file mode 100644 index 0000000..8d27612 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/ref/2024. 03. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/refint/2024. 03. 18.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/refint/2024. 03. 18.dll new file mode 100644 index 0000000..8d27612 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/Debug/net6.0-windows/refint/2024. 03. 18.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.assets.json new file mode 100644 index 0000000..985167a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj", + "projectName": "2024. 03. 18", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.nuget.cache new file mode 100644 index 0000000..d45b316 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 18/2024. 03. 18/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "7+Or0+pemJQvPuqv3mibMRRIgEXkTovVRNytQ40C+koFVL2N5a8aOAV/+UBilnLC/tXFanciDLJyRWkTKbDmyw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 18\\2024. 03. 18\\2024. 03. 18.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..86cae6e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/53341605-128e-47e6-b02b-1c1909d9eafa.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/53341605-128e-47e6-b02b-1c1909d9eafa.vsidx new file mode 100644 index 0000000..d09fc6b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/53341605-128e-47e6-b02b-1c1909d9eafa.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/5ea5f6f6-fe84-455b-b4c6-8d4b9169758b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/5ea5f6f6-fe84-455b-b4c6-8d4b9169758b.vsidx new file mode 100644 index 0000000..15c406f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/5ea5f6f6-fe84-455b-b4c6-8d4b9169758b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/cb751918-8e67-4b88-9ebf-de21eb4207ea.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/cb751918-8e67-4b88-9ebf-de21eb4207ea.vsidx new file mode 100644 index 0000000..ecc7dd5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/FileContentIndex/cb751918-8e67-4b88-9ebf-de21eb4207ea.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.futdcache.v2 new file mode 100644 index 0000000..4c14463 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.suo new file mode 100644 index 0000000..328b8d0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/2024. 03. 20/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.metadata.v7.bin new file mode 100644 index 0000000..e00ab0a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.projects.v7.bin new file mode 100644 index 0000000..e98dd06 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/.vs/ProjectEvaluation/2024. 03. 20.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20.sln new file mode 100644 index 0000000..ca766a0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 20", "2024. 03. 20\2024. 03. 20.csproj", "{F934E9B0-30AF-45E9-AF74-ED959B220536}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {F934E9B0-30AF-45E9-AF74-ED959B220536}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {F934E9B0-30AF-45E9-AF74-ED959B220536}.Debug|Any CPU.Build.0 = Debug|Any CPU + {F934E9B0-30AF-45E9-AF74-ED959B220536}.Release|Any CPU.ActiveCfg = Release|Any CPU + {F934E9B0-30AF-45E9-AF74-ED959B220536}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {DBDD2208-E442-4526-9B8D-8457A870ACE9} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj new file mode 100644 index 0000000..a049ea0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj @@ -0,0 +1,27 @@ + + + + WinExe + net6.0-windows + _2024._03._20 + enable + true + enable + + + + + True + True + Resources.resx + + + + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/2024. 03. 20.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.Designer.cs new file mode 100644 index 0000000..58968ce --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.Designer.cs @@ -0,0 +1,86 @@ +namespace _2024._03._20 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + pictureBox1 = new PictureBox(); + button1 = new Button(); + textBox1 = new TextBox(); + ((System.ComponentModel.ISupportInitialize)pictureBox1).BeginInit(); + SuspendLayout(); + // + // pictureBox1 + // + pictureBox1.BorderStyle = BorderStyle.FixedSingle; + pictureBox1.ImageLocation = ""; + pictureBox1.Location = new Point(93, 115); + pictureBox1.Name = "pictureBox1"; + pictureBox1.Size = new Size(589, 323); + pictureBox1.SizeMode = PictureBoxSizeMode.Zoom; + pictureBox1.TabIndex = 0; + pictureBox1.TabStop = false; + // + // button1 + // + button1.Location = new Point(588, 41); + button1.Name = "button1"; + button1.Size = new Size(94, 29); + button1.TabIndex = 2; + button1.Text = "Mutasd"; + button1.UseVisualStyleBackColor = true; + button1.Click += button1_Click; + // + // textBox1 + // + textBox1.Location = new Point(42, 43); + textBox1.Name = "textBox1"; + textBox1.Size = new Size(171, 27); + textBox1.TabIndex = 3; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(textBox1); + Controls.Add(button1); + Controls.Add(pictureBox1); + Name = "Form1"; + Text = "Form1"; + ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private PictureBox pictureBox1; + private Button button1; + private TextBox textBox1; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.cs new file mode 100644 index 0000000..b551a14 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.cs @@ -0,0 +1,23 @@ +namespace _2024._03._20 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void button1_Click(object sender, EventArgs e) + { + if (pictureBox1.ImageLocation == "") + { + string imagepath = textBox1.Text; + pictureBox1.ImageLocation = imagepath; + } + else + { + pictureBox1.ImageLocation = ""; + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Program.cs new file mode 100644 index 0000000..28d17a0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._20 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.Designer.cs new file mode 100644 index 0000000..d9ead68 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace _2024._03._20.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("_2024._03._20.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.resx new file mode 100644 index 0000000..1af7de1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/Properties/Resources.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.deps.json new file mode 100644 index 0000000..5f9183b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 20/1.0.0": { + "runtime": { + "2024. 03. 20.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 20/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.dll new file mode 100644 index 0000000..90dbbe8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.exe new file mode 100644 index 0000000..ef660dd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.pdb new file mode 100644 index 0000000..08f8e73 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/bin/Debug/net6.0-windows/2024. 03. 20.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.dgspec.json new file mode 100644 index 0000000..b784ddb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj", + "projectName": "2024. 03. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/2024. 03. 20.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfo.cs new file mode 100644 index 0000000..cd747ac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 20")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 20")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 20")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfoInputs.cache new file mode 100644 index 0000000..f084e78 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +7e4ea6e2339a4ca4b1d04e7e51ca58085f4dfa07 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..fcf987f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._20 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.assets.cache new file mode 100644 index 0000000..6490bbd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..c9c8768 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +9483fd893120bc5be27952ce42da7cf1716cf20d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..1014c41 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.FileListAbsolute.txt @@ -0,0 +1,17 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\bin\Debug\net6.0-windows\2024. 03. 20.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\bin\Debug\net6.0-windows\2024. 03. 20.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\bin\Debug\net6.0-windows\2024. 03. 20.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\bin\Debug\net6.0-windows\2024. 03. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\bin\Debug\net6.0-windows\2024. 03. 20.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\_2024._03._20.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\_2024._03._20.Properties.Resources.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\refint\2024. 03. 20.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\2024. 03. 20.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 20\2024. 03. 20\obj\Debug\net6.0-windows\ref\2024. 03. 20.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.GenerateResource.cache new file mode 100644 index 0000000..b953f84 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.dll new file mode 100644 index 0000000..90dbbe8 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.genruntimeconfig.cache new file mode 100644 index 0000000..1f5c8b7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.genruntimeconfig.cache @@ -0,0 +1 @@ +0976a05c1fad6edd4611d27005a04acdd6e990db diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.pdb new file mode 100644 index 0000000..08f8e73 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/2024. 03. 20.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Properties.Resources.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Properties.Resources.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/_2024._03._20.Properties.Resources.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..ef660dd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/ref/2024. 03. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/ref/2024. 03. 20.dll new file mode 100644 index 0000000..395dacd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/ref/2024. 03. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/refint/2024. 03. 20.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/refint/2024. 03. 20.dll new file mode 100644 index 0000000..395dacd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/Debug/net6.0-windows/refint/2024. 03. 20.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.assets.json new file mode 100644 index 0000000..34d7d31 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj", + "projectName": "2024. 03. 20", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.nuget.cache new file mode 100644 index 0000000..d61144a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 20/2024. 03. 20/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "G9xcmZUu0Ab429MfE5u/6kKYVKzqQn5VxuU/k1YK8Ja2IkjXzgsFU15sO0LiGZhCpV668mepX5MYqqCMzzBVsg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 20\\2024. 03. 20\\2024. 03. 20.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..6cd0aba Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/3247a5d5-9b62-407d-803f-2a1ba2b04f27.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/3247a5d5-9b62-407d-803f-2a1ba2b04f27.vsidx new file mode 100644 index 0000000..f43ed07 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/3247a5d5-9b62-407d-803f-2a1ba2b04f27.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/97a45bf5-e849-4700-aa13-7468364dbe71.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/97a45bf5-e849-4700-aa13-7468364dbe71.vsidx new file mode 100644 index 0000000..669fc57 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/FileContentIndex/97a45bf5-e849-4700-aa13-7468364dbe71.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.futdcache.v2 new file mode 100644 index 0000000..da893b0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.suo new file mode 100644 index 0000000..e7d73ea Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/2024. 03. 27/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.metadata.v7.bin new file mode 100644 index 0000000..99819fe Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.projects.v7.bin new file mode 100644 index 0000000..4c08548 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/.vs/ProjectEvaluation/2024. 03. 27.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27.sln new file mode 100644 index 0000000..4ba39a4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 03. 27", "2024. 03. 27\2024. 03. 27.csproj", "{B75577E4-0A6D-4DBD-866B-960F1B140BCD}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {B75577E4-0A6D-4DBD-866B-960F1B140BCD}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {B75577E4-0A6D-4DBD-866B-960F1B140BCD}.Debug|Any CPU.Build.0 = Debug|Any CPU + {B75577E4-0A6D-4DBD-866B-960F1B140BCD}.Release|Any CPU.ActiveCfg = Release|Any CPU + {B75577E4-0A6D-4DBD-866B-960F1B140BCD}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {96AA8667-7D31-46DC-986E-334B98BFC721} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj new file mode 100644 index 0000000..1dd584a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._03._27 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/2024. 03. 27.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.Designer.cs new file mode 100644 index 0000000..1cdf981 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.Designer.cs @@ -0,0 +1,193 @@ +namespace _2024._03._27 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + MaleRadioButton = new RadioButton(); + FemaleRadioButton = new RadioButton(); + H1 = new Label(); + label1 = new Label(); + label2 = new Label(); + WeightTextBox = new TextBox(); + HeightTextBox = new TextBox(); + label3 = new Label(); + BMIValueLabel = new Label(); + ConditionLabel = new Label(); + CheckButton = new Button(); + SuspendLayout(); + // + // MaleRadioButton + // + MaleRadioButton.AutoSize = true; + MaleRadioButton.Font = new Font("Segoe UI Semibold", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + MaleRadioButton.ForeColor = SystemColors.ControlText; + MaleRadioButton.Location = new Point(431, 120); + MaleRadioButton.Name = "MaleRadioButton"; + MaleRadioButton.Size = new Size(70, 29); + MaleRadioButton.TabIndex = 0; + MaleRadioButton.Text = "Férfi"; + MaleRadioButton.UseVisualStyleBackColor = true; + // + // FemaleRadioButton + // + FemaleRadioButton.AutoSize = true; + FemaleRadioButton.Font = new Font("Segoe UI Semibold", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + FemaleRadioButton.Location = new Point(431, 158); + FemaleRadioButton.Name = "FemaleRadioButton"; + FemaleRadioButton.Size = new Size(58, 29); + FemaleRadioButton.TabIndex = 1; + FemaleRadioButton.Text = "Nő"; + FemaleRadioButton.UseVisualStyleBackColor = true; + // + // H1 + // + H1.AutoSize = true; + H1.Font = new Font("Verdana", 19.8000011F, FontStyle.Bold, GraphicsUnit.Point); + H1.Location = new Point(258, 32); + H1.Name = "H1"; + H1.Size = new Size(305, 41); + H1.TabIndex = 2; + H1.Text = "BMI Kalkulátor"; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + label1.Location = new Point(57, 140); + label1.Name = "label1"; + label1.Size = new Size(211, 28); + label1.TabIndex = 3; + label1.Text = "Válaszd ki a nemedet!"; + // + // label2 + // + label2.AutoSize = true; + label2.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + label2.Location = new Point(57, 229); + label2.Name = "label2"; + label2.Size = new Size(279, 28); + label2.TabIndex = 4; + label2.Text = "Add meg a testsúlyodat! (Kg)"; + // + // WeightTextBox + // + WeightTextBox.BackColor = SystemColors.ControlLight; + WeightTextBox.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + WeightTextBox.Location = new Point(431, 229); + WeightTextBox.Name = "WeightTextBox"; + WeightTextBox.Size = new Size(125, 34); + WeightTextBox.TabIndex = 5; + // + // HeightTextBox + // + HeightTextBox.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + HeightTextBox.Location = new Point(431, 301); + HeightTextBox.Name = "HeightTextBox"; + HeightTextBox.Size = new Size(125, 34); + HeightTextBox.TabIndex = 6; + // + // label3 + // + label3.AutoSize = true; + label3.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + label3.Location = new Point(57, 301); + label3.Name = "label3"; + label3.Size = new Size(336, 28); + label3.TabIndex = 7; + label3.Text = "Add meg a testmagasságodat! (cm)"; + // + // BMIValueLabel + // + BMIValueLabel.AutoSize = true; + BMIValueLabel.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + BMIValueLabel.Location = new Point(113, 404); + BMIValueLabel.Name = "BMIValueLabel"; + BMIValueLabel.Size = new Size(155, 28); + BMIValueLabel.TabIndex = 8; + BMIValueLabel.Text = "A BMI értéked: "; + // + // ConditionLabel + // + ConditionLabel.AutoSize = true; + ConditionLabel.Font = new Font("Segoe UI Semibold", 12F, FontStyle.Bold, GraphicsUnit.Point); + ConditionLabel.Location = new Point(461, 404); + ConditionLabel.Name = "ConditionLabel"; + ConditionLabel.Size = new Size(111, 28); + ConditionLabel.TabIndex = 9; + ConditionLabel.Text = "Állapotod: "; + // + // CheckButton + // + CheckButton.Font = new Font("Segoe UI Semibold", 10.8F, FontStyle.Bold, GraphicsUnit.Point); + CheckButton.Location = new Point(328, 364); + CheckButton.Name = "CheckButton"; + CheckButton.Size = new Size(97, 36); + CheckButton.TabIndex = 10; + CheckButton.Text = "Számítás"; + CheckButton.UseVisualStyleBackColor = true; + CheckButton.Click += CheckButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackColor = Color.DarkSeaGreen; + ClientSize = new Size(800, 450); + Controls.Add(CheckButton); + Controls.Add(ConditionLabel); + Controls.Add(BMIValueLabel); + Controls.Add(label3); + Controls.Add(HeightTextBox); + Controls.Add(WeightTextBox); + Controls.Add(label2); + Controls.Add(label1); + Controls.Add(H1); + Controls.Add(FemaleRadioButton); + Controls.Add(MaleRadioButton); + ForeColor = SystemColors.ControlText; + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private RadioButton MaleRadioButton; + private RadioButton FemaleRadioButton; + private Label H1; + private Label label1; + private Label label2; + private TextBox WeightTextBox; + private TextBox HeightTextBox; + private Label label3; + private Label BMIValueLabel; + private Label ConditionLabel; + private Button CheckButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.cs new file mode 100644 index 0000000..ddef9a7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.cs @@ -0,0 +1,28 @@ +namespace _2024._03._27 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void CheckButton_Click(object sender, EventArgs e) + { + if (MaleRadioButton.Checked) + { + double kg = Convert.ToDouble(WeightTextBox.Text); + double m = Convert.ToDouble(HeightTextBox.Text) / 100; + double bmivalue = Math.Round(kg / (Math.Pow(m, 2)), 2); + BMIValueLabel.Text = $"A BMI rtked: {bmivalue}"; + + switch (bmivalue) + { + case double n when n < 18.1: + ConditionLabel.Text = "llapotod: Sovny"; + break; + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Program.cs new file mode 100644 index 0000000..59ad11b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._03._27 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.deps.json new file mode 100644 index 0000000..242515c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 03. 27/1.0.0": { + "runtime": { + "2024. 03. 27.dll": {} + } + } + } + }, + "libraries": { + "2024. 03. 27/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.dll new file mode 100644 index 0000000..925b3fc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.exe new file mode 100644 index 0000000..71936ce Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.pdb new file mode 100644 index 0000000..d5f1e67 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/bin/Debug/net6.0-windows/2024. 03. 27.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d85739a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj", + "projectName": "2024. 03. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/2024. 03. 27.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfo.cs new file mode 100644 index 0000000..2cb1199 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 03. 27")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 03. 27")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 03. 27")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfoInputs.cache new file mode 100644 index 0000000..a34039b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +da57610e1c287a29cf3e0163b3e8694cba6014a9 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cf04229 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._03._27 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.assets.cache new file mode 100644 index 0000000..a878dac Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..499be27 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +84a17c85f4a08eb7fbb7c08b07bc4eb4339aa33b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..d2eb9d4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\bin\Debug\net6.0-windows\2024. 03. 27.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\bin\Debug\net6.0-windows\2024. 03. 27.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\bin\Debug\net6.0-windows\2024. 03. 27.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\bin\Debug\net6.0-windows\2024. 03. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\bin\Debug\net6.0-windows\2024. 03. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\_2024._03._27.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\refint\2024. 03. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\2024. 03. 27.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 03. 27\2024. 03. 27\obj\Debug\net6.0-windows\ref\2024. 03. 27.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.GenerateResource.cache new file mode 100644 index 0000000..876a62d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.dll new file mode 100644 index 0000000..925b3fc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.genruntimeconfig.cache new file mode 100644 index 0000000..76ec867 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.genruntimeconfig.cache @@ -0,0 +1 @@ +80994920920c2d36dbb51c42498dc03170431ac8 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.pdb new file mode 100644 index 0000000..d5f1e67 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/2024. 03. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/_2024._03._27.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/_2024._03._27.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/_2024._03._27.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..71936ce Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/ref/2024. 03. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/ref/2024. 03. 27.dll new file mode 100644 index 0000000..4a3a935 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/ref/2024. 03. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/refint/2024. 03. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/refint/2024. 03. 27.dll new file mode 100644 index 0000000..4a3a935 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/Debug/net6.0-windows/refint/2024. 03. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.assets.json new file mode 100644 index 0000000..9b0e0a8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj", + "projectName": "2024. 03. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.nuget.cache new file mode 100644 index 0000000..fc81a92 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 03. 27/2024. 03. 27/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "wAQZRlvBbSmf2jTryVuWsCQ89yQu5R0LvR3qSMklDdAPG9c6wd9wo97fMtZ9vI1rUmHti4z44TavUmmTak6tMA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 03. 27\\2024. 03. 27\\2024. 03. 27.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..7d7613d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/06e8b440-f4c7-45dc-a0cc-1b2f68612197.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/06e8b440-f4c7-45dc-a0cc-1b2f68612197.vsidx new file mode 100644 index 0000000..facbf3b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/06e8b440-f4c7-45dc-a0cc-1b2f68612197.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/377624d3-31a1-4603-9881-e2190afdb8fc.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/377624d3-31a1-4603-9881-e2190afdb8fc.vsidx new file mode 100644 index 0000000..a9bf96c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/377624d3-31a1-4603-9881-e2190afdb8fc.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/3dceba3a-fff9-46d4-8fcc-dc698674bd9d.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/3dceba3a-fff9-46d4-8fcc-dc698674bd9d.vsidx new file mode 100644 index 0000000..1723df2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/FileContentIndex/3dceba3a-fff9-46d4-8fcc-dc698674bd9d.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.futdcache.v2 new file mode 100644 index 0000000..f404d59 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.suo new file mode 100644 index 0000000..0ab056f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/2024. 04. 03/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.metadata.v7.bin new file mode 100644 index 0000000..eecad72 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.projects.v7.bin new file mode 100644 index 0000000..6c30087 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/.vs/ProjectEvaluation/2024. 04. 03.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03.sln new file mode 100644 index 0000000..9db25dd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 03", "2024. 04. 03\2024. 04. 03.csproj", "{796C3A62-7AD3-43FC-A743-79A1B868679D}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {796C3A62-7AD3-43FC-A743-79A1B868679D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {796C3A62-7AD3-43FC-A743-79A1B868679D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {796C3A62-7AD3-43FC-A743-79A1B868679D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {796C3A62-7AD3-43FC-A743-79A1B868679D}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {C8E2E995-F65F-4E51-B7C4-FB01554162FF} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj new file mode 100644 index 0000000..c8ef34f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj @@ -0,0 +1,27 @@ + + + + WinExe + net6.0-windows + _2024._04._03 + enable + true + enable + + + + + True + True + Resources.resx + + + + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/2024. 04. 03.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.Designer.cs new file mode 100644 index 0000000..623711f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.Designer.cs @@ -0,0 +1,217 @@ +namespace _2024._04._03 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(Form1)); + pictureBox1 = new PictureBox(); + pictureBox2 = new PictureBox(); + pictureBox3 = new PictureBox(); + pictureBox4 = new PictureBox(); + pictureBox5 = new PictureBox(); + label1 = new Label(); + this.Number1Label = new Label(); + this.Number3Label = new Label(); + this.Number5Label = new Label(); + this.Number2Label = new Label(); + Number4Label = new Label(); + GenerateButton = new Button(); + ((System.ComponentModel.ISupportInitialize)pictureBox1).BeginInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox2).BeginInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox3).BeginInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox4).BeginInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox5).BeginInit(); + SuspendLayout(); + // + // pictureBox1 + // + pictureBox1.Image = (Image)resources.GetObject("pictureBox1.Image"); + pictureBox1.Location = new Point(25, 156); + pictureBox1.Name = "pictureBox1"; + pictureBox1.Size = new Size(145, 139); + pictureBox1.TabIndex = 0; + pictureBox1.TabStop = false; + // + // pictureBox2 + // + pictureBox2.Image = (Image)resources.GetObject("pictureBox2.Image"); + pictureBox2.Location = new Point(327, 156); + pictureBox2.Name = "pictureBox2"; + pictureBox2.Size = new Size(145, 139); + pictureBox2.TabIndex = 1; + pictureBox2.TabStop = false; + // + // pictureBox3 + // + pictureBox3.Image = (Image)resources.GetObject("pictureBox3.Image"); + pictureBox3.Location = new Point(478, 156); + pictureBox3.Name = "pictureBox3"; + pictureBox3.Size = new Size(145, 139); + pictureBox3.TabIndex = 2; + pictureBox3.TabStop = false; + // + // pictureBox4 + // + pictureBox4.Image = (Image)resources.GetObject("pictureBox4.Image"); + pictureBox4.Location = new Point(176, 156); + pictureBox4.Name = "pictureBox4"; + pictureBox4.Size = new Size(145, 139); + pictureBox4.TabIndex = 3; + pictureBox4.TabStop = false; + // + // pictureBox5 + // + pictureBox5.Image = (Image)resources.GetObject("pictureBox5.Image"); + pictureBox5.Location = new Point(629, 156); + pictureBox5.Name = "pictureBox5"; + pictureBox5.Size = new Size(145, 139); + pictureBox5.TabIndex = 4; + pictureBox5.TabStop = false; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI Variable Display", 28.2F, FontStyle.Bold, GraphicsUnit.Point); + label1.Location = new Point(236, 26); + label1.Name = "label1"; + label1.Size = new Size(312, 63); + label1.TabIndex = 5; + label1.Text = "Lottószámok"; + // + // Number1Label + // + this.Number1Label.AutoSize = true; + this.Number1Label.BackColor = Color.Transparent; + this.Number1Label.Font = new Font("Yu Gothic", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + this.Number1Label.Location = new Point(86, 212); + this.Number1Label.Name = "Number1Label"; + this.Number1Label.Size = new Size(26, 30); + this.Number1Label.TabIndex = 6; + this.Number1Label.Text = "0"; + // + // Number3Label + // + this.Number3Label.AutoSize = true; + this.Number3Label.BackColor = Color.Transparent; + this.Number3Label.Font = new Font("Yu Gothic", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + this.Number3Label.Location = new Point(387, 210); + this.Number3Label.Name = "Number3Label"; + this.Number3Label.Size = new Size(26, 30); + this.Number3Label.TabIndex = 7; + this.Number3Label.Text = "0"; + // + // Number5Label + // + this.Number5Label.AutoSize = true; + this.Number5Label.BackColor = Color.Transparent; + this.Number5Label.Font = new Font("Yu Gothic", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + this.Number5Label.Location = new Point(688, 210); + this.Number5Label.Name = "Number5Label"; + this.Number5Label.Size = new Size(26, 30); + this.Number5Label.TabIndex = 9; + this.Number5Label.Text = "0"; + // + // Number2Label + // + this.Number2Label.AutoSize = true; + this.Number2Label.BackColor = Color.Transparent; + this.Number2Label.Font = new Font("Yu Gothic", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + this.Number2Label.Location = new Point(236, 210); + this.Number2Label.Name = "Number2Label"; + this.Number2Label.Size = new Size(26, 30); + this.Number2Label.TabIndex = 10; + this.Number2Label.Text = "0"; + // + // Number4Label + // + Number4Label.AutoSize = true; + Number4Label.BackColor = Color.Transparent; + Number4Label.Font = new Font("Yu Gothic", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + Number4Label.Location = new Point(537, 210); + Number4Label.Name = "Number4Label"; + Number4Label.Size = new Size(26, 30); + Number4Label.TabIndex = 11; + Number4Label.Text = "0"; + // + // GenerateButton + // + GenerateButton.Font = new Font("Microsoft PhagsPa", 18F, FontStyle.Bold, GraphicsUnit.Point); + GenerateButton.Location = new Point(302, 344); + GenerateButton.Name = "GenerateButton"; + GenerateButton.Size = new Size(195, 48); + GenerateButton.TabIndex = 12; + GenerateButton.Text = "Generálás"; + GenerateButton.UseVisualStyleBackColor = true; + GenerateButton.Click += GenerateButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + BackColor = Color.DarkGray; + ClientSize = new Size(800, 450); + Controls.Add(GenerateButton); + Controls.Add(Number4Label); + Controls.Add(this.Number2Label); + Controls.Add(this.Number5Label); + Controls.Add(this.Number3Label); + Controls.Add(this.Number1Label); + Controls.Add(label1); + Controls.Add(pictureBox5); + Controls.Add(pictureBox4); + Controls.Add(pictureBox3); + Controls.Add(pictureBox2); + Controls.Add(pictureBox1); + Name = "Form1"; + Text = "Lottószámok"; + ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox2).EndInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox3).EndInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox4).EndInit(); + ((System.ComponentModel.ISupportInitialize)pictureBox5).EndInit(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private PictureBox pictureBox1; + private PictureBox pictureBox2; + private PictureBox pictureBox3; + private PictureBox pictureBox4; + private PictureBox pictureBox5; + private Label label1; + private Label label2; + private Label label3; + private Label label4; + private Label label5; + private Label label6; + private Label Number4Label; + private Button GenerateButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.cs new file mode 100644 index 0000000..62ac14a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.cs @@ -0,0 +1,15 @@ +namespace _2024._04._03 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void GenerateButton_Click(object sender, EventArgs e) + { + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.resx new file mode 100644 index 0000000..9448a4e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Form1.resx @@ -0,0 +1,1051 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + + + /9j/4AAQSkZJRgABAQEAYABgAAD/4QC6RXhpZgAATU0AKgAAAAgAAgESAAMAAAABAAEAAIdpAAQAAAAB + AAAAJgAAAAAAAZKGAAcAAAB6AAAAOAAAAABVTklDT0RFAABDAFIARQBBAFQATwBSADoAIABnAGQALQBq + AHAAZQBnACAAdgAxAC4AMAAgACgAdQBzAGkAbgBnACAASQBKAEcAIABKAFAARQBHACAAdgA5ADAAKQAs + ACAAcQB1AGEAbABpAHQAeQAgAD0AIAA5ADAACv/bAEMAAgEBAgEBAgICAgICAgIDBQMDAwMDBgQEAwUH + BgcHBwYHBwgJCwkICAoIBwcKDQoKCwwMDAwHCQ4PDQwOCwwMDP/bAEMBAgICAwMDBgMDBgwIBwgMDAwM + DAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDP/AABEIAIcAjwMBIgAC + EQEDEQH/xAAfAAABBQEBAQEBAQAAAAAAAAAAAQIDBAUGBwgJCgv/xAC1EAACAQMDAgQDBQUEBAAAAX0B + AgMABBEFEiExQQYTUWEHInEUMoGRoQgjQrHBFVLR8CQzYnKCCQoWFxgZGiUmJygpKjQ1Njc4OTpDREVG + R0hJSlNUVVZXWFlaY2RlZmdoaWpzdHV2d3h5eoOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 + uLm6wsPExcbHyMnK0tPU1dbX2Nna4eLj5OXm5+jp6vHy8/T19vf4+fr/xAAfAQADAQEBAQEBAQEBAAAA + AAAAAQIDBAUGBwgJCgv/xAC1EQACAQIEBAMEBwUEBAABAncAAQIDEQQFITEGEkFRB2FxEyIygQgUQpGh + scEJIzNS8BVictEKFiQ04SXxFxgZGiYnKCkqNTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1 + dnd4eXqCg4SFhoeIiYqSk5SVlpeYmZqio6Slpqeoqaqys7S1tre4ubrCw8TFxsfIycrS09TV1tfY2dri + 4+Tl5ufo6ery8/T19vf4+fr/2gAMAwEAAhEDEQA/AP36+Wj5aAf92g8/3aAD5aPlo7fw00nYNzMu0cmg + B3y02SVIvvEfTPNQiV7v/V/u4/7xHLfQf41JFAsQ4+9/ePJP40AIJHf7sZX3Y/0oKSMeZNvsq1Jj/dox + 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 + 3oooA9q8B+M7jCBmY16z4X8TNcRjr0oooA//2Q== + + + + + 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 + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Program.cs new file mode 100644 index 0000000..37783cc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._03 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.Designer.cs new file mode 100644 index 0000000..5fcb911 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace _2024._04._03.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("_2024._04._03.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.resx new file mode 100644 index 0000000..1af7de1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/Properties/Resources.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.dgspec.json new file mode 100644 index 0000000..9b6b404 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj", + "projectName": "2024. 04. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/2024. 04. 03.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfo.cs new file mode 100644 index 0000000..e2c0191 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 03")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 03")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 03")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfoInputs.cache new file mode 100644 index 0000000..11d413d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a6a4c455d1393333ad8917275b4b1858754de152 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..23b576d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._03 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.assets.cache new file mode 100644 index 0000000..4fa7922 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..b84b98a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +80a0aa7132255af680e3c82528353b636e284018 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..5c172fc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.FileListAbsolute.txt @@ -0,0 +1,7 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\_2024._04._03.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\_2024._04._03.Properties.Resources.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\2024. 04. 03.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\2024. 04. 03.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\2024. 04. 03.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\2024. 04. 03.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 03\2024. 04. 03\obj\Debug\net6.0-windows\2024. 04. 03.csproj.CoreCompileInputs.cache diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.GenerateResource.cache new file mode 100644 index 0000000..9d50d7c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/2024. 04. 03.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Form1.resources new file mode 100644 index 0000000..0ce1231 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Properties.Resources.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Properties.Resources.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/Debug/net6.0-windows/_2024._04._03.Properties.Resources.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.assets.json new file mode 100644 index 0000000..5910498 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj", + "projectName": "2024. 04. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.nuget.cache new file mode 100644 index 0000000..8826337 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 03/2024. 04. 03/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "GaCT56GKSWMvz28KrrHTWZb99aomOczyMIvYgFDNfXsj/ZFFNvCGQS3cMM2KF6DhRTTeprtvYM8KMPW2BcfrDA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 03\\2024. 04. 03\\2024. 04. 03.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..bec27db Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/0ae87da9-76c2-4dad-b860-4dad00f8572b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/0ae87da9-76c2-4dad-b860-4dad00f8572b.vsidx new file mode 100644 index 0000000..6e48b4d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/0ae87da9-76c2-4dad-b860-4dad00f8572b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/cb30c8e8-d407-4b1a-b637-bbac7ea41704.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/cb30c8e8-d407-4b1a-b637-bbac7ea41704.vsidx new file mode 100644 index 0000000..c70354f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/FileContentIndex/cb30c8e8-d407-4b1a-b637-bbac7ea41704.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.futdcache.v2 new file mode 100644 index 0000000..2e03773 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.suo new file mode 100644 index 0000000..30aa53e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/2024. 04. 08 - 2/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.metadata.v7.bin new file mode 100644 index 0000000..94d284f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.projects.v7.bin new file mode 100644 index 0000000..bffdcdf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/.vs/ProjectEvaluation/2024. 04. 08 - 2.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2.sln new file mode 100644 index 0000000..8a0835f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 08 - 2", "2024. 04. 08 - 2\2024. 04. 08 - 2.csproj", "{4A74E523-78CC-44E6-91B8-1EAB91E1F997}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {4A74E523-78CC-44E6-91B8-1EAB91E1F997}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {4A74E523-78CC-44E6-91B8-1EAB91E1F997}.Debug|Any CPU.Build.0 = Debug|Any CPU + {4A74E523-78CC-44E6-91B8-1EAB91E1F997}.Release|Any CPU.ActiveCfg = Release|Any CPU + {4A74E523-78CC-44E6-91B8-1EAB91E1F997}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {B36F9CC4-D284-4423-84DD-54738ECB0470} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj new file mode 100644 index 0000000..ccb6d56 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._04._08___2 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/2024. 04. 08 - 2.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.Designer.cs new file mode 100644 index 0000000..96cac65 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.Designer.cs @@ -0,0 +1,124 @@ +namespace _2024._04._08___2 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + ParosListBox = new ListBox(); + ParatlanListBox = new ListBox(); + label1 = new Label(); + label2 = new Label(); + ReadButton = new Button(); + WriteButton = new Button(); + SuspendLayout(); + // + // ParosListBox + // + ParosListBox.FormattingEnabled = true; + ParosListBox.ItemHeight = 20; + ParosListBox.Location = new Point(116, 84); + ParosListBox.Name = "ParosListBox"; + ParosListBox.Size = new Size(157, 264); + ParosListBox.TabIndex = 0; + // + // ParatlanListBox + // + ParatlanListBox.FormattingEnabled = true; + ParatlanListBox.ItemHeight = 20; + ParatlanListBox.Location = new Point(429, 84); + ParatlanListBox.Name = "ParatlanListBox"; + ParatlanListBox.Size = new Size(151, 264); + ParatlanListBox.TabIndex = 1; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI", 9F, FontStyle.Bold, GraphicsUnit.Point); + label1.Location = new Point(116, 46); + label1.Name = "label1"; + label1.Size = new Size(69, 20); + label1.TabIndex = 2; + label1.Text = "Párosak:"; + // + // label2 + // + label2.AutoSize = true; + label2.Font = new Font("Segoe UI", 9F, FontStyle.Bold, GraphicsUnit.Point); + label2.Location = new Point(429, 46); + label2.Name = "label2"; + label2.Size = new Size(89, 20); + label2.TabIndex = 3; + label2.Text = "Páratlanok:"; + // + // ReadButton + // + ReadButton.Location = new Point(116, 381); + ReadButton.Name = "ReadButton"; + ReadButton.Size = new Size(157, 57); + ReadButton.TabIndex = 4; + ReadButton.Text = "Beolvasás fájlból!"; + ReadButton.UseVisualStyleBackColor = true; + ReadButton.Click += ReadButton_Click; + // + // WriteButton + // + WriteButton.Enabled = false; + WriteButton.Location = new Point(423, 381); + WriteButton.Name = "WriteButton"; + WriteButton.Size = new Size(157, 57); + WriteButton.TabIndex = 5; + WriteButton.Text = "Kiírás a fájlba!"; + WriteButton.UseVisualStyleBackColor = true; + WriteButton.Click += WriteButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(WriteButton); + Controls.Add(ReadButton); + Controls.Add(label2); + Controls.Add(label1); + Controls.Add(ParatlanListBox); + Controls.Add(ParosListBox); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private ListBox ParosListBox; + private ListBox ParatlanListBox; + private Label label1; + private Label label2; + private Button ReadButton; + private Button WriteButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.cs new file mode 100644 index 0000000..8ff4879 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.cs @@ -0,0 +1,56 @@ +namespace _2024._04._08___2 +{ + public partial class Form1 : Form + { + const int MAX = 100; + int[] szamok = new int[MAX]; + int n; + + public Form1() + { + InitializeComponent(); + } + + private void ReadButton_Click(object sender, EventArgs e) + { + n = 0; + string fnev = "szamok.txt"; + if (File.Exists(fnev)) + { + StreamReader f = File.OpenText(fnev); + while (!f.EndOfStream && n < MAX) + { + string sor = f.ReadLine(); + szamok[n] = int.Parse(sor); + if (szamok[n] % 2 == 0) + { + ParosListBox.Items.Add(szamok[n]); + } + else + { + ParatlanListBox.Items.Add(szamok[n]); + } + n++; + } + f.Close(); + WriteButton.Enabled = true; + } + else + { + MessageBox.Show("A megadott fjl nem ltezik!"); + } + } + + private void WriteButton_Click(object sender, EventArgs e) + { + string fnev = "paros.txt"; + StreamWriter f = File.CreateText(fnev); + for (int i = 0; i < ParosListBox.Items.Count; i++) + { + f.WriteLine(ParosListBox.Items[i]); + } + f.Close(); + MessageBox.Show("A pros szmok kirva a fjlba!"); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Program.cs new file mode 100644 index 0000000..eee21b6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._08___2 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.deps.json new file mode 100644 index 0000000..11fab60 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 04. 08 - 2/1.0.0": { + "runtime": { + "2024. 04. 08 - 2.dll": {} + } + } + } + }, + "libraries": { + "2024. 04. 08 - 2/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.dll new file mode 100644 index 0000000..a07cbf3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.exe new file mode 100644 index 0000000..f6fe55f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.pdb new file mode 100644 index 0000000..a777242 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/2024. 04. 08 - 2.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/paros.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/paros.txt new file mode 100644 index 0000000..0d8184f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/paros.txt @@ -0,0 +1,10 @@ +22 +44 +66 +88 +100 +2 +4 +6 +8 +10 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/szamok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/szamok.txt new file mode 100644 index 0000000..851cc9e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/bin/Debug/net6.0-windows/szamok.txt @@ -0,0 +1,20 @@ +11 +22 +33 +44 +55 +66 +77 +88 +99 +100 +1 +2 +3 +4 +5 +6 +7 +8 +9 +10 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..fdf3b6e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj", + "projectName": "2024. 04. 08 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/2024. 04. 08 - 2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfo.cs new file mode 100644 index 0000000..3a2c580 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 08 - 2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 08 - 2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 08 - 2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..577a4d3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +aa7e26edd3c302ca3704d9b85f9b3101922391ec diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..8f7adc7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._08___2 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.assets.cache new file mode 100644 index 0000000..ea96023 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..9a2b91a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +69deb896aef1ec2556d4c40a470d07b6a92b42b2 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..f13c910 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\bin\Debug\net6.0-windows\2024. 04. 08 - 2.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\bin\Debug\net6.0-windows\2024. 04. 08 - 2.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\bin\Debug\net6.0-windows\2024. 04. 08 - 2.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\bin\Debug\net6.0-windows\2024. 04. 08 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\bin\Debug\net6.0-windows\2024. 04. 08 - 2.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\_2024._04._08___2.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\refint\2024. 04. 08 - 2.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\2024. 04. 08 - 2.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08 - 2\2024. 04. 08 - 2\obj\Debug\net6.0-windows\ref\2024. 04. 08 - 2.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.GenerateResource.cache new file mode 100644 index 0000000..0e1d199 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.dll new file mode 100644 index 0000000..a07cbf3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.genruntimeconfig.cache new file mode 100644 index 0000000..21f574f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.genruntimeconfig.cache @@ -0,0 +1 @@ +080cf8c287051a09ec7673ba125589f3dd125f83 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.pdb new file mode 100644 index 0000000..a777242 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/2024. 04. 08 - 2.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/_2024._04._08___2.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/_2024._04._08___2.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/_2024._04._08___2.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..f6fe55f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/ref/2024. 04. 08 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/ref/2024. 04. 08 - 2.dll new file mode 100644 index 0000000..ca91e2e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/ref/2024. 04. 08 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/refint/2024. 04. 08 - 2.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/refint/2024. 04. 08 - 2.dll new file mode 100644 index 0000000..ca91e2e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/Debug/net6.0-windows/refint/2024. 04. 08 - 2.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.assets.json new file mode 100644 index 0000000..fb35af5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj", + "projectName": "2024. 04. 08 - 2", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.nuget.cache new file mode 100644 index 0000000..c705995 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08 - 2/2024. 04. 08 - 2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "N70SfOS/9xB71D848rOP8pSIMtziu5NTcYRQaSIh6sbWLLtuvkOYv3WMofgnvygZ0pUAnTMR1g+FWCY3JihVEQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08 - 2\\2024. 04. 08 - 2\\2024. 04. 08 - 2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..d274919 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/5b81fff2-3410-458c-9c61-9978a5362be0.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/5b81fff2-3410-458c-9c61-9978a5362be0.vsidx new file mode 100644 index 0000000..62bb59e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/5b81fff2-3410-458c-9c61-9978a5362be0.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/f400a184-4168-4dca-91b9-7db20b337abf.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/f400a184-4168-4dca-91b9-7db20b337abf.vsidx new file mode 100644 index 0000000..332f92f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/FileContentIndex/f400a184-4168-4dca-91b9-7db20b337abf.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.futdcache.v2 new file mode 100644 index 0000000..bcd7b99 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.suo new file mode 100644 index 0000000..693b4f3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/2024. 04. 08/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.metadata.v7.bin new file mode 100644 index 0000000..cbf261b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.projects.v7.bin new file mode 100644 index 0000000..c7f6da1 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/.vs/ProjectEvaluation/2024. 04. 08.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08.sln new file mode 100644 index 0000000..56ebc28 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 08", "2024. 04. 08\2024. 04. 08.csproj", "{A98A44F5-A199-469C-9A3F-9D7A2F2AC3E0}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A98A44F5-A199-469C-9A3F-9D7A2F2AC3E0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A98A44F5-A199-469C-9A3F-9D7A2F2AC3E0}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A98A44F5-A199-469C-9A3F-9D7A2F2AC3E0}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A98A44F5-A199-469C-9A3F-9D7A2F2AC3E0}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {0534A507-7E63-4E13-BBD7-C23FA1C35AA2} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj new file mode 100644 index 0000000..edd0e62 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._04._08 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/2024. 04. 08.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.Designer.cs new file mode 100644 index 0000000..841b25d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.Designer.cs @@ -0,0 +1,108 @@ +namespace _2024._04._08 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + ListBox = new ListBox(); + AddButton = new Button(); + AddTextBox = new TextBox(); + DeleteButton = new Button(); + ClearButton = new Button(); + SuspendLayout(); + // + // ListBox + // + ListBox.FormattingEnabled = true; + ListBox.ItemHeight = 20; + ListBox.Location = new Point(178, 77); + ListBox.Name = "ListBox"; + ListBox.Size = new Size(240, 304); + ListBox.TabIndex = 0; + // + // AddButton + // + AddButton.Location = new Point(453, 42); + AddButton.Name = "AddButton"; + AddButton.Size = new Size(130, 29); + AddButton.TabIndex = 1; + AddButton.Text = "Hozzáad"; + AddButton.UseVisualStyleBackColor = true; + AddButton.Click += AddButton_Click; + // + // AddTextBox + // + AddTextBox.Location = new Point(178, 44); + AddTextBox.Name = "AddTextBox"; + AddTextBox.Size = new Size(240, 27); + AddTextBox.TabIndex = 2; + // + // DeleteButton + // + DeleteButton.Location = new Point(453, 77); + DeleteButton.Name = "DeleteButton"; + DeleteButton.Size = new Size(130, 29); + DeleteButton.TabIndex = 3; + DeleteButton.Text = "Kijelölt törlése"; + DeleteButton.UseVisualStyleBackColor = true; + DeleteButton.Click += DeleteButton_Click; + // + // ClearButton + // + ClearButton.Location = new Point(453, 112); + ClearButton.Name = "ClearButton"; + ClearButton.Size = new Size(130, 29); + ClearButton.TabIndex = 4; + ClearButton.Text = "Összes törlése"; + ClearButton.UseVisualStyleBackColor = true; + ClearButton.Click += ClearButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(ClearButton); + Controls.Add(DeleteButton); + Controls.Add(AddTextBox); + Controls.Add(AddButton); + Controls.Add(ListBox); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private ListBox ListBox; + private Button AddButton; + private TextBox AddTextBox; + private Button DeleteButton; + private Button ClearButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.cs new file mode 100644 index 0000000..0d6ba45 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.cs @@ -0,0 +1,26 @@ +namespace _2024._04._08 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void AddButton_Click(object sender, EventArgs e) + { + ListBox.Items.Add(AddTextBox.Text); + } + + private void DeleteButton_Click(object sender, EventArgs e) + { + int index = ListBox.SelectedIndex; + ListBox.Items.RemoveAt(index); + } + + private void ClearButton_Click(object sender, EventArgs e) + { + ListBox.Items.Clear(); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Program.cs new file mode 100644 index 0000000..0a34665 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._08 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.deps.json new file mode 100644 index 0000000..52a3792 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 04. 08/1.0.0": { + "runtime": { + "2024. 04. 08.dll": {} + } + } + } + }, + "libraries": { + "2024. 04. 08/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.dll new file mode 100644 index 0000000..35c3f4b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.exe new file mode 100644 index 0000000..f7e94a2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.pdb new file mode 100644 index 0000000..de9db86 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/bin/Debug/net6.0-windows/2024. 04. 08.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.dgspec.json new file mode 100644 index 0000000..0cd8328 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj", + "projectName": "2024. 04. 08", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/2024. 04. 08.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfo.cs new file mode 100644 index 0000000..5e4abae --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 08")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 08")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 08")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfoInputs.cache new file mode 100644 index 0000000..1aa848b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a07d155429b9b74761de3e05d8f58808b08f924b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..db73e04 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._08 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.assets.cache new file mode 100644 index 0000000..8a8c2b6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..0dd9be9 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +65dddf16049cecb21a7e323dc8a2c077d15413ab diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..bcf3f77 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\bin\Debug\net6.0-windows\2024. 04. 08.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\bin\Debug\net6.0-windows\2024. 04. 08.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\bin\Debug\net6.0-windows\2024. 04. 08.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\bin\Debug\net6.0-windows\2024. 04. 08.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\bin\Debug\net6.0-windows\2024. 04. 08.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\_2024._04._08.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\refint\2024. 04. 08.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\2024. 04. 08.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 08\2024. 04. 08\obj\Debug\net6.0-windows\ref\2024. 04. 08.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.GenerateResource.cache new file mode 100644 index 0000000..8b0fe14 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.dll new file mode 100644 index 0000000..35c3f4b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.genruntimeconfig.cache new file mode 100644 index 0000000..108a2c0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.genruntimeconfig.cache @@ -0,0 +1 @@ +b2f77bee85881d2c9c4589f7a4efb7a5d6737e99 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.pdb new file mode 100644 index 0000000..de9db86 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/2024. 04. 08.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/_2024._04._08.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/_2024._04._08.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/_2024._04._08.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..f7e94a2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/ref/2024. 04. 08.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/ref/2024. 04. 08.dll new file mode 100644 index 0000000..b901285 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/ref/2024. 04. 08.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/refint/2024. 04. 08.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/refint/2024. 04. 08.dll new file mode 100644 index 0000000..b901285 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/Debug/net6.0-windows/refint/2024. 04. 08.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.assets.json new file mode 100644 index 0000000..67f8bfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj", + "projectName": "2024. 04. 08", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.nuget.cache new file mode 100644 index 0000000..3df2a40 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 08/2024. 04. 08/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "wueSv3VLt7qE9Ai5ZXVLQTav2AKkHNelbSXP6szQFWjkXLLfeco+Cuw7tR1JX4s9Fiospd6r+9isiVZ1yYeH2A==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 08\\2024. 04. 08\\2024. 04. 08.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..4578dfa Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/49183258-8bde-4fdd-a404-e2dbe72bb682.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/49183258-8bde-4fdd-a404-e2dbe72bb682.vsidx new file mode 100644 index 0000000..18379e7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/49183258-8bde-4fdd-a404-e2dbe72bb682.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/608d5dcc-a59e-4851-8287-1117a98c1fd9.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/608d5dcc-a59e-4851-8287-1117a98c1fd9.vsidx new file mode 100644 index 0000000..12d1804 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/FileContentIndex/608d5dcc-a59e-4851-8287-1117a98c1fd9.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.futdcache.v2 new file mode 100644 index 0000000..cbb4dec Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.suo new file mode 100644 index 0000000..4746316 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/2024. 04. 10/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.metadata.v7.bin new file mode 100644 index 0000000..bdbba46 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.projects.v7.bin new file mode 100644 index 0000000..20586a3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/.vs/ProjectEvaluation/2024. 04. 10.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10.sln new file mode 100644 index 0000000..d171786 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 10", "2024. 04. 10\2024. 04. 10.csproj", "{C02FCBC3-CB92-4714-A538-935B02A03A0D}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {C02FCBC3-CB92-4714-A538-935B02A03A0D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C02FCBC3-CB92-4714-A538-935B02A03A0D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C02FCBC3-CB92-4714-A538-935B02A03A0D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C02FCBC3-CB92-4714-A538-935B02A03A0D}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {E92CDF46-32AD-4216-AF9A-F409AFDCCD86} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj new file mode 100644 index 0000000..cd0ba77 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._04._10 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/2024. 04. 10.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.Designer.cs new file mode 100644 index 0000000..f3d8715 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.Designer.cs @@ -0,0 +1,116 @@ +namespace _2024._04._10 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + ArabicLabel = new Label(); + RomanLabel = new Label(); + SwitchButton = new Button(); + ArabicTextBox = new TextBox(); + RomanTextBox = new TextBox(); + ExchangeButton = new Button(); + SuspendLayout(); + // + // ArabicLabel + // + ArabicLabel.AutoSize = true; + ArabicLabel.Location = new Point(149, 112); + ArabicLabel.Name = "ArabicLabel"; + ArabicLabel.Size = new Size(41, 20); + ArabicLabel.TabIndex = 0; + ArabicLabel.Text = "Arab"; + // + // RomanLabel + // + RomanLabel.AutoSize = true; + RomanLabel.Location = new Point(577, 112); + RomanLabel.Name = "RomanLabel"; + RomanLabel.Size = new Size(52, 20); + RomanLabel.TabIndex = 1; + RomanLabel.Text = "Római"; + // + // SwitchButton + // + SwitchButton.Location = new Point(333, 150); + SwitchButton.Name = "SwitchButton"; + SwitchButton.Size = new Size(94, 29); + SwitchButton.TabIndex = 2; + SwitchButton.Text = "--->"; + SwitchButton.UseVisualStyleBackColor = true; + // + // ArabicTextBox + // + ArabicTextBox.Location = new Point(120, 150); + ArabicTextBox.Name = "ArabicTextBox"; + ArabicTextBox.Size = new Size(99, 27); + ArabicTextBox.TabIndex = 3; + // + // RomanTextBox + // + RomanTextBox.Enabled = false; + RomanTextBox.Location = new Point(550, 150); + RomanTextBox.Name = "RomanTextBox"; + RomanTextBox.Size = new Size(99, 27); + RomanTextBox.TabIndex = 4; + // + // ExchangeButton + // + ExchangeButton.Location = new Point(333, 246); + ExchangeButton.Name = "ExchangeButton"; + ExchangeButton.Size = new Size(94, 29); + ExchangeButton.TabIndex = 5; + ExchangeButton.Text = "Átvált"; + ExchangeButton.UseVisualStyleBackColor = true; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(ExchangeButton); + Controls.Add(RomanTextBox); + Controls.Add(ArabicTextBox); + Controls.Add(SwitchButton); + Controls.Add(RomanLabel); + Controls.Add(ArabicLabel); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label ArabicLabel; + private Label RomanLabel; + private Button SwitchButton; + private TextBox ArabicTextBox; + private TextBox RomanTextBox; + private Button ExchangeButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.cs new file mode 100644 index 0000000..ec29a59 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.cs @@ -0,0 +1,10 @@ +namespace _2024._04._10 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Program.cs new file mode 100644 index 0000000..6328011 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._10 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.dgspec.json new file mode 100644 index 0000000..b1f3921 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj", + "projectName": "2024. 04. 10", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/2024. 04. 10.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfo.cs new file mode 100644 index 0000000..47bccff --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 10")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 10")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 10")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfoInputs.cache new file mode 100644 index 0000000..07c978c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c8d78a7234a591f1e5dee6ad00f06b38d792f013 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..51ce28f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._10 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 10\2024. 04. 10\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.assets.cache new file mode 100644 index 0000000..5c823a2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/Debug/net6.0-windows/2024. 04. 10.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.assets.json new file mode 100644 index 0000000..2f96556 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj", + "projectName": "2024. 04. 10", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.nuget.cache new file mode 100644 index 0000000..62834be --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 10/2024. 04. 10/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "SfF2GfaKwS08DldMrynQnb1sTF4+aG23uHwWKLe3wM/bPbB4/T9695c6rnv4C+yVjjIkSsXjv+l236++NLSjpw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 10\\2024. 04. 10\\2024. 04. 10.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..f4d2df0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/FileContentIndex/668c4825-6c9d-4911-9c1c-47abff7f3cbd.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/FileContentIndex/668c4825-6c9d-4911-9c1c-47abff7f3cbd.vsidx new file mode 100644 index 0000000..2d1cdfd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/FileContentIndex/668c4825-6c9d-4911-9c1c-47abff7f3cbd.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.futdcache.v2 new file mode 100644 index 0000000..a2d6f47 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.suo new file mode 100644 index 0000000..3d63bdf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/DocumentLayout.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/DocumentLayout.json new file mode 100644 index 0000000..3ef9ebb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/2024. 04. 15/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "C:\\Users\\\u00C1d\u00E1m\\Desktop\\2024. 04. 15\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}|2024. 04. 15\\2024. 04. 15.csproj|c:\\users\\\u00E1d\u00E1m\\desktop\\2024. 04. 15\\2024. 04. 15\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}|2024. 04. 15\\2024. 04. 15.csproj|solutionrelative:2024. 04. 15\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + }, + { + "AbsoluteMoniker": "D:0:0:{5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}|2024. 04. 15\\2024. 04. 15.csproj|c:\\users\\\u00E1d\u00E1m\\desktop\\2024. 04. 15\\2024. 04. 15\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}|2024. 04. 15\\2024. 04. 15.csproj|solutionrelative:2024. 04. 15\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Form1.cs", + "DocumentMoniker": "C:\\Users\\\u00C1d\u00E1m\\Desktop\\2024. 04. 15\\2024. 04. 15\\Form1.cs", + "RelativeDocumentMoniker": "2024. 04. 15\\Form1.cs", + "ToolTip": "C:\\Users\\\u00C1d\u00E1m\\Desktop\\2024. 04. 15\\2024. 04. 15\\Form1.cs", + "RelativeToolTip": "2024. 04. 15\\Form1.cs", + "ViewState": "AQIAAAAAAAAAAAAAAAAAACkAAAAAAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-15T21:08:37.405Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Form1.cs [Design]", + "DocumentMoniker": "C:\\Users\\\u00C1d\u00E1m\\Desktop\\2024. 04. 15\\2024. 04. 15\\Form1.cs", + "RelativeDocumentMoniker": "2024. 04. 15\\Form1.cs", + "ToolTip": "C:\\Users\\\u00C1d\u00E1m\\Desktop\\2024. 04. 15\\2024. 04. 15\\Form1.cs [Design]", + "RelativeToolTip": "2024. 04. 15\\Form1.cs [Design]", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-15T21:08:13.704Z", + "EditorCaption": " [Design]" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.metadata.v7.bin new file mode 100644 index 0000000..9abce2d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.projects.v7.bin new file mode 100644 index 0000000..86df97c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/.vs/ProjectEvaluation/2024. 04. 15.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15.sln new file mode 100644 index 0000000..7e1ce87 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 15", "2024. 04. 15\2024. 04. 15.csproj", "{5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}.Debug|Any CPU.Build.0 = Debug|Any CPU + {5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}.Release|Any CPU.ActiveCfg = Release|Any CPU + {5E766968-0AC8-4B0F-8EC3-CCD10FF69BF0}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {9EA7C83A-9DAD-46CA-8C04-FB8D48F95777} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj new file mode 100644 index 0000000..7208b74 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj @@ -0,0 +1,27 @@ + + + + WinExe + net6.0-windows + _2024._04._15 + enable + true + enable + + + + + True + True + Resources.resx + + + + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/2024. 04. 15.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.Designer.cs new file mode 100644 index 0000000..3c88b1d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.Designer.cs @@ -0,0 +1,185 @@ +namespace _2024._04._15 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + pictureBox1 = new PictureBox(); + LetterButton = new Button(); + LetterTextBox = new TextBox(); + Letter5TextBox = new TextBox(); + Letter4TextBox = new TextBox(); + Letter3TextBox = new TextBox(); + Letter2TextBox = new TextBox(); + Letter1TextBox = new TextBox(); + RetryButton = new Button(); + ((System.ComponentModel.ISupportInitialize)pictureBox1).BeginInit(); + SuspendLayout(); + // + // pictureBox1 + // + pictureBox1.Location = new Point(54, 92); + pictureBox1.Margin = new Padding(3, 2, 3, 2); + pictureBox1.Name = "pictureBox1"; + pictureBox1.Size = new Size(202, 188); + pictureBox1.TabIndex = 0; + pictureBox1.TabStop = false; + // + // LetterButton + // + LetterButton.Font = new Font("Segoe UI Semibold", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + LetterButton.Location = new Point(527, 232); + LetterButton.Margin = new Padding(3, 2, 3, 2); + LetterButton.Name = "LetterButton"; + LetterButton.Size = new Size(134, 35); + LetterButton.TabIndex = 6; + LetterButton.Text = "Beadás"; + LetterButton.UseVisualStyleBackColor = true; + LetterButton.Click += button1_Click; + // + // LetterTextBox + // + LetterTextBox.Font = new Font("Tahoma", 12F, FontStyle.Regular, GraphicsUnit.Point); + LetterTextBox.Location = new Point(496, 195); + LetterTextBox.Margin = new Padding(3, 2, 3, 2); + LetterTextBox.MaxLength = 1; + LetterTextBox.Name = "LetterTextBox"; + LetterTextBox.Size = new Size(188, 27); + LetterTextBox.TabIndex = 7; + // + // Letter5TextBox + // + Letter5TextBox.BackColor = SystemColors.GrayText; + Letter5TextBox.Enabled = false; + Letter5TextBox.Font = new Font("Tahoma", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + Letter5TextBox.ForeColor = Color.White; + Letter5TextBox.Location = new Point(689, 92); + Letter5TextBox.Margin = new Padding(3, 2, 3, 2); + Letter5TextBox.Name = "Letter5TextBox"; + Letter5TextBox.Size = new Size(70, 34); + Letter5TextBox.TabIndex = 5; + Letter5TextBox.TextAlign = HorizontalAlignment.Center; + // + // Letter4TextBox + // + Letter4TextBox.BackColor = SystemColors.GrayText; + Letter4TextBox.Enabled = false; + Letter4TextBox.Font = new Font("Tahoma", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + Letter4TextBox.ForeColor = Color.White; + Letter4TextBox.Location = new Point(613, 92); + Letter4TextBox.Margin = new Padding(3, 2, 3, 2); + Letter4TextBox.Name = "Letter4TextBox"; + Letter4TextBox.Size = new Size(70, 34); + Letter4TextBox.TabIndex = 3; + Letter4TextBox.TextAlign = HorizontalAlignment.Center; + // + // Letter3TextBox + // + Letter3TextBox.BackColor = SystemColors.GrayText; + Letter3TextBox.Enabled = false; + Letter3TextBox.Font = new Font("Tahoma", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + Letter3TextBox.ForeColor = Color.White; + Letter3TextBox.Location = new Point(538, 92); + Letter3TextBox.Margin = new Padding(3, 2, 3, 2); + Letter3TextBox.Name = "Letter3TextBox"; + Letter3TextBox.Size = new Size(70, 34); + Letter3TextBox.TabIndex = 2; + Letter3TextBox.TextAlign = HorizontalAlignment.Center; + // + // Letter2TextBox + // + Letter2TextBox.BackColor = SystemColors.GrayText; + Letter2TextBox.Enabled = false; + Letter2TextBox.Font = new Font("Tahoma", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + Letter2TextBox.ForeColor = Color.White; + Letter2TextBox.Location = new Point(463, 92); + Letter2TextBox.Margin = new Padding(3, 2, 3, 2); + Letter2TextBox.Name = "Letter2TextBox"; + Letter2TextBox.Size = new Size(70, 34); + Letter2TextBox.TabIndex = 1; + Letter2TextBox.TextAlign = HorizontalAlignment.Center; + // + // Letter1TextBox + // + Letter1TextBox.BackColor = SystemColors.GrayText; + Letter1TextBox.Enabled = false; + Letter1TextBox.Font = new Font("Tahoma", 16.2F, FontStyle.Bold, GraphicsUnit.Point); + Letter1TextBox.ForeColor = Color.White; + Letter1TextBox.Location = new Point(388, 92); + Letter1TextBox.Margin = new Padding(3, 2, 3, 2); + Letter1TextBox.Name = "Letter1TextBox"; + Letter1TextBox.Size = new Size(70, 34); + Letter1TextBox.TabIndex = 4; + Letter1TextBox.TextAlign = HorizontalAlignment.Center; + // + // RetryButton + // + RetryButton.Font = new Font("Segoe UI Semibold", 13.8F, FontStyle.Bold, GraphicsUnit.Point); + RetryButton.Location = new Point(527, 292); + RetryButton.Margin = new Padding(3, 2, 3, 2); + RetryButton.Name = "RetryButton"; + RetryButton.Size = new Size(134, 35); + RetryButton.TabIndex = 9; + RetryButton.Text = "Újra"; + RetryButton.UseVisualStyleBackColor = true; + RetryButton.Click += RetryButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(7F, 15F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(788, 374); + Controls.Add(RetryButton); + Controls.Add(LetterTextBox); + Controls.Add(LetterButton); + Controls.Add(Letter5TextBox); + Controls.Add(Letter1TextBox); + Controls.Add(Letter4TextBox); + Controls.Add(Letter3TextBox); + Controls.Add(Letter2TextBox); + Controls.Add(pictureBox1); + Margin = new Padding(3, 2, 3, 2); + Name = "Form1"; + Text = "Form1"; + ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private PictureBox pictureBox1; + private Button LetterButton; + private TextBox LetterTextBox; + private TextBox Letter5TextBox; + private TextBox Letter4TextBox; + private TextBox Letter3TextBox; + private TextBox Letter2TextBox; + private TextBox Letter1TextBox; + private Button RetryButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.cs new file mode 100644 index 0000000..29b2b96 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.cs @@ -0,0 +1,93 @@ +namespace _2024._04._15 +{ + public partial class Form1 : Form + { + private string word; + private List TextBoxes; + private int wrong = 0; + private int good = 0; + private string[] words = { "akci", "vros", "vidm", "majom", "brka" }; + + + public Form1() + { + InitializeComponent(); + TextBoxes = new List { Letter1TextBox, Letter2TextBox, Letter3TextBox, Letter4TextBox, Letter5TextBox }; + + Random rng = new Random(); + word = words[rng.Next(0, 5)]; + } + + private void button1_Click(object sender, EventArgs e) + { + string currentWord = word; + bool found = false; + + for (int i = 0; i < currentWord.Length; i++) + { + if (char.Equals(Convert.ToChar(LetterTextBox.Text), currentWord[i])) + { + TextBoxes[i].Text = LetterTextBox.Text; + found = true; + good++; + } + + for (int j = 1; j < 5; j++) + { + if (char.Equals(Convert.ToChar(TextBoxes[0].Text), TextBoxes[j] { + + } + } + } + + if (good == 5) + { + MessageBox.Show("Nyertl!!", "Sikeres!", MessageBoxButtons.OK, MessageBoxIcon.Information); + LetterTextBox.Enabled = false; + LetterButton.Enabled = false; + good = 0; + } + + if (!found) + { + wrong += 1; + + pictureBox1.Image = Image.FromFile($@"E:\Suli\12.b\Programozs (Tusjak Brigitta)\Gyakorlat\rai\2024. 04. 15\Akasztfa\{wrong}.png"); + //pictureBox1.Image = Image.FromFile(@$"C:\Users\dm\Desktop\2024. 04. 15\Akasztfa\{wrong}.png"); + + if (wrong == 11) + { + MessageBox.Show("Vesztettl!!", "Sikertelen!", MessageBoxButtons.OK, MessageBoxIcon.Information); + LetterTextBox.Enabled = false; + LetterButton.Enabled = false; + wrong = 0; + + for (int i = 0; i < TextBoxes.Count; i++) + { + TextBoxes[i].Text = Convert.ToString(word[i]); + } + } + } + + LetterTextBox.Text = ""; + } + + private void RetryButton_Click(object sender, EventArgs e) + { + Random rng = new Random(); + word = words[rng.Next(0, 5)]; + + LetterTextBox.Enabled = true; + LetterButton.Enabled = true; + + wrong = 0; + + pictureBox1.Image = null; + + foreach(var i in TextBoxes) + { + i.Text = ""; + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Program.cs new file mode 100644 index 0000000..32edc5d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._15 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.Designer.cs new file mode 100644 index 0000000..e8ad446 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace _2024._04._15.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "17.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("_2024._04._15.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.resx new file mode 100644 index 0000000..1af7de1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/Properties/Resources.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.deps.json new file mode 100644 index 0000000..935d8b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 04. 15/1.0.0": { + "runtime": { + "2024. 04. 15.dll": {} + } + } + } + }, + "libraries": { + "2024. 04. 15/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.dll new file mode 100644 index 0000000..e5af002 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.exe new file mode 100644 index 0000000..30fdb08 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.pdb new file mode 100644 index 0000000..c4715cd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/bin/Debug/net6.0-windows/2024. 04. 15.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.dgspec.json new file mode 100644 index 0000000..032dea6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj", + "projectName": "2024. 04. 15", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/2024. 04. 15.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfo.cs new file mode 100644 index 0000000..0562731 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 15")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 15")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 15")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfoInputs.cache new file mode 100644 index 0000000..a2c7277 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +81c83ef5fe3148917dd0c1200a0036be08770237 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..4e55181 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._15 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.assets.cache new file mode 100644 index 0000000..02f4b5c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..e34d3ba --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +6c51c9d8e31e081f85852c578893b70d49da0832 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..14c98a5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.FileListAbsolute.txt @@ -0,0 +1,34 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\_2024._04._15.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\_2024._04._15.Properties.Resources.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\refint\2024. 04. 15.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\ref\2024. 04. 15.dll +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\_2024._04._15.Form1.resources +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\_2024._04._15.Properties.Resources.resources +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.csproj.GenerateResource.cache +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.GeneratedMSBuildEditorConfig.editorconfig +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.AssemblyInfoInputs.cache +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.AssemblyInfo.cs +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.csproj.CoreCompileInputs.cache +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.dll +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\refint\2024. 04. 15.dll +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.pdb +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.exe +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.deps.json +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.runtimeconfig.json +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.dll +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\bin\Debug\net6.0-windows\2024. 04. 15.pdb +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\2024. 04. 15.genruntimeconfig.cache +C:\Users\Ádám\Desktop\2024. 04. 15\2024. 04. 15\obj\Debug\net6.0-windows\ref\2024. 04. 15.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.GenerateResource.cache new file mode 100644 index 0000000..d1ebb1d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.dll new file mode 100644 index 0000000..e5af002 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.genruntimeconfig.cache new file mode 100644 index 0000000..146d77d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.genruntimeconfig.cache @@ -0,0 +1 @@ +13224faeb5ad18849c9ee79f36d23875c8c08d94 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.pdb new file mode 100644 index 0000000..c4715cd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/2024. 04. 15.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/TempPE/Properties.Resources.Designer.cs.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/TempPE/Properties.Resources.Designer.cs.dll new file mode 100644 index 0000000..db004df Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/TempPE/Properties.Resources.Designer.cs.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Properties.Resources.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Properties.Resources.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/_2024._04._15.Properties.Resources.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..30fdb08 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/ref/2024. 04. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/ref/2024. 04. 15.dll new file mode 100644 index 0000000..2d97c0d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/ref/2024. 04. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/refint/2024. 04. 15.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/refint/2024. 04. 15.dll new file mode 100644 index 0000000..2d97c0d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/Debug/net6.0-windows/refint/2024. 04. 15.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.assets.json new file mode 100644 index 0000000..1a2d560 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj", + "projectName": "2024. 04. 15", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.nuget.cache new file mode 100644 index 0000000..fbe38a3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/2024. 04. 15/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "aX9AGPVNuyLmBUxPG9kjZ9AiHpIuBDGgoaNdfaEsq4E3C8ojaPy2P3DMi/Rl3CnjP9ivzFnPqhJlEdi60Eb2LQ==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 04. 15\\2024. 04. 15\\2024. 04. 15.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/1.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/1.png new file mode 100644 index 0000000..f576d2d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/1.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/10.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/10.png new file mode 100644 index 0000000..f51e02f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/10.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/11.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/11.png new file mode 100644 index 0000000..8b583c3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/11.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/2.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/2.png new file mode 100644 index 0000000..8debbbf Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/2.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/3.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/3.png new file mode 100644 index 0000000..80c58a7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/3.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/4.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/4.png new file mode 100644 index 0000000..0ca395d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/4.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/5.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/5.png new file mode 100644 index 0000000..6c2a0a9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/5.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/6.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/6.png new file mode 100644 index 0000000..a5d1261 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/6.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/7.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/7.png new file mode 100644 index 0000000..b2b7764 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/7.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/8.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/8.png new file mode 100644 index 0000000..2509402 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/8.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/9.png b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/9.png new file mode 100644 index 0000000..8814c3c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 15/Akasztófa/9.png differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..3ab731b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/4ac50d5e-b744-4bde-b8e8-5672d79d3c8b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/4ac50d5e-b744-4bde-b8e8-5672d79d3c8b.vsidx new file mode 100644 index 0000000..a6a3e54 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/4ac50d5e-b744-4bde-b8e8-5672d79d3c8b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/6a049a8f-1090-4da4-806f-9dc23adc9a82.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/6a049a8f-1090-4da4-806f-9dc23adc9a82.vsidx new file mode 100644 index 0000000..eb71478 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/6a049a8f-1090-4da4-806f-9dc23adc9a82.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ca2a4610-481e-4975-9ceb-ea2f20b91866.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ca2a4610-481e-4975-9ceb-ea2f20b91866.vsidx new file mode 100644 index 0000000..c0b5757 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ca2a4610-481e-4975-9ceb-ea2f20b91866.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ff984b98-d83c-44d5-9e4c-3e7cd70dbf61.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ff984b98-d83c-44d5-9e4c-3e7cd70dbf61.vsidx new file mode 100644 index 0000000..5ff9d50 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/FileContentIndex/ff984b98-d83c-44d5-9e4c-3e7cd70dbf61.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.futdcache.v2 new file mode 100644 index 0000000..1b47394 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.suo new file mode 100644 index 0000000..d2f001c Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/DocumentLayout.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/DocumentLayout.json new file mode 100644 index 0000000..d90a1b5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/2024. 04. 28/v17/DocumentLayout.json @@ -0,0 +1,88 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\2024. 04. 28\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|e:\\2024. 04. 28\\2024. 04. 28\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|solutionrelative:2024. 04. 28\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|E:\\2024. 04. 28\\2024. 04. 28\\form2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|solutionrelative:2024. 04. 28\\form2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|E:\\2024. 04. 28\\2024. 04. 28\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|solutionrelative:2024. 04. 28\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + }, + { + "AbsoluteMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|E:\\2024. 04. 28\\2024. 04. 28\\form2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{C8FBC60E-20CD-49F6-8649-179BD3A69051}|2024. 04. 28\\2024. 04. 28.csproj|solutionrelative:2024. 04. 28\\form2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{b1e99781-ab81-11d0-b683-00aa00a3ee26}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Form1.cs", + "DocumentMoniker": "E:\\2024. 04. 28\\2024. 04. 28\\Form1.cs", + "RelativeDocumentMoniker": "2024. 04. 28\\Form1.cs", + "ToolTip": "E:\\2024. 04. 28\\2024. 04. 28\\Form1.cs", + "RelativeToolTip": "2024. 04. 28\\Form1.cs", + "ViewState": "AQIAAGIAAAAAAAAAAAA2wKsAAAARAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-28T13:05:40.06Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 2, + "Title": "Form1.cs [Design]", + "DocumentMoniker": "E:\\2024. 04. 28\\2024. 04. 28\\Form1.cs", + "RelativeDocumentMoniker": "2024. 04. 28\\Form1.cs", + "ToolTip": "D:\\Suli\\12.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\Gyakorl\u00E1s\\2024. 04. 28\\2024. 04. 28\\Form1.cs [Design]*", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-28T13:05:35.674Z" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Form2.cs", + "DocumentMoniker": "E:\\2024. 04. 28\\2024. 04. 28\\Form2.cs", + "RelativeDocumentMoniker": "2024. 04. 28\\Form2.cs", + "ToolTip": "E:\\2024. 04. 28\\2024. 04. 28\\Form2.cs", + "RelativeToolTip": "2024. 04. 28\\Form2.cs", + "ViewState": "AQIAACUAAAAAAAAAAAA4wBUAAAAjAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-28T12:14:19.413Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 3, + "Title": "Form2.cs [Design]", + "DocumentMoniker": "E:\\2024. 04. 28\\2024. 04. 28\\Form2.cs", + "RelativeDocumentMoniker": "2024. 04. 28\\Form2.cs", + "ToolTip": "E:\\2024. 04. 28\\2024. 04. 28\\Form2.cs [Design]", + "RelativeToolTip": "2024. 04. 28\\Form2.cs [Design]", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-04-28T12:03:54.813Z", + "EditorCaption": " [Design]" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.metadata.v7.bin new file mode 100644 index 0000000..ad831bc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.projects.v7.bin new file mode 100644 index 0000000..5790cb6 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/.vs/ProjectEvaluation/2024. 04. 28.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28.sln new file mode 100644 index 0000000..fe01752 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.9.34622.214 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 04. 28", "2024. 04. 28\2024. 04. 28.csproj", "{C8FBC60E-20CD-49F6-8649-179BD3A69051}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {C8FBC60E-20CD-49F6-8649-179BD3A69051}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C8FBC60E-20CD-49F6-8649-179BD3A69051}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C8FBC60E-20CD-49F6-8649-179BD3A69051}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C8FBC60E-20CD-49F6-8649-179BD3A69051}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {80F7EC58-019C-4A2D-9151-D3E1CAC0F961} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj new file mode 100644 index 0000000..09d91e3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._04._28 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj.user new file mode 100644 index 0000000..5d5d15b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/2024. 04. 28.csproj.user @@ -0,0 +1,11 @@ + + + + + Form + + + Form + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.Designer.cs new file mode 100644 index 0000000..721957f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.Designer.cs @@ -0,0 +1,303 @@ +namespace _2024._04._28 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + menuStrip1 = new MenuStrip(); + fájlToolStripMenuItem = new ToolStripMenuItem(); + megnyitásToolStripMenuItem = new ToolStripMenuItem(); + kilépésToolStripMenuItem = new ToolStripMenuItem(); + műveletekToolStripMenuItem = new ToolStripMenuItem(); + statisztikaToolStripMenuItem = new ToolStripMenuItem(); + nyertesekToolStripMenuItem = new ToolStripMenuItem(); + súgóToolStripMenuItem = new ToolStripMenuItem(); + névjegyToolStripMenuItem = new ToolStripMenuItem(); + label1 = new Label(); + listBox1 = new ListBox(); + label2 = new Label(); + groupBox1 = new GroupBox(); + NumberSzavazatTextBox = new TextBox(); + PartTextBox = new TextBox(); + NumberPlaceTextBox = new TextBox(); + NameTextBox = new TextBox(); + label6 = new Label(); + label5 = new Label(); + label4 = new Label(); + label3 = new Label(); + button1 = new Button(); + listBox2 = new ListBox(); + menuStrip1.SuspendLayout(); + groupBox1.SuspendLayout(); + SuspendLayout(); + // + // menuStrip1 + // + menuStrip1.Items.AddRange(new ToolStripItem[] { fájlToolStripMenuItem, műveletekToolStripMenuItem, súgóToolStripMenuItem }); + menuStrip1.Location = new Point(0, 0); + menuStrip1.Name = "menuStrip1"; + menuStrip1.Size = new Size(634, 24); + menuStrip1.TabIndex = 0; + menuStrip1.Text = "menuStrip1"; + // + // fájlToolStripMenuItem + // + fájlToolStripMenuItem.DropDownItems.AddRange(new ToolStripItem[] { megnyitásToolStripMenuItem, kilépésToolStripMenuItem }); + fájlToolStripMenuItem.Name = "fájlToolStripMenuItem"; + fájlToolStripMenuItem.Size = new Size(37, 20); + fájlToolStripMenuItem.Text = "Fájl"; + // + // megnyitásToolStripMenuItem + // + megnyitásToolStripMenuItem.Name = "megnyitásToolStripMenuItem"; + megnyitásToolStripMenuItem.Size = new Size(129, 22); + megnyitásToolStripMenuItem.Text = "Megnyitás"; + megnyitásToolStripMenuItem.Click += megnyitásToolStripMenuItem_Click; + // + // kilépésToolStripMenuItem + // + kilépésToolStripMenuItem.Name = "kilépésToolStripMenuItem"; + kilépésToolStripMenuItem.Size = new Size(129, 22); + kilépésToolStripMenuItem.Text = "Kilépés"; + kilépésToolStripMenuItem.Click += kilépésToolStripMenuItem_Click; + // + // műveletekToolStripMenuItem + // + műveletekToolStripMenuItem.DropDownItems.AddRange(new ToolStripItem[] { statisztikaToolStripMenuItem, nyertesekToolStripMenuItem }); + műveletekToolStripMenuItem.Name = "műveletekToolStripMenuItem"; + műveletekToolStripMenuItem.Size = new Size(74, 20); + műveletekToolStripMenuItem.Text = "Műveletek"; + // + // statisztikaToolStripMenuItem + // + statisztikaToolStripMenuItem.Name = "statisztikaToolStripMenuItem"; + statisztikaToolStripMenuItem.Size = new Size(126, 22); + statisztikaToolStripMenuItem.Text = "Statisztika"; + statisztikaToolStripMenuItem.Click += statisztikaToolStripMenuItem_Click; + // + // nyertesekToolStripMenuItem + // + nyertesekToolStripMenuItem.Name = "nyertesekToolStripMenuItem"; + nyertesekToolStripMenuItem.Size = new Size(126, 22); + nyertesekToolStripMenuItem.Text = "Nyertesek"; + nyertesekToolStripMenuItem.Click += nyertesekToolStripMenuItem_Click; + // + // súgóToolStripMenuItem + // + súgóToolStripMenuItem.DropDownItems.AddRange(new ToolStripItem[] { névjegyToolStripMenuItem }); + súgóToolStripMenuItem.Name = "súgóToolStripMenuItem"; + súgóToolStripMenuItem.Size = new Size(46, 20); + súgóToolStripMenuItem.Text = "Súgó"; + // + // névjegyToolStripMenuItem + // + névjegyToolStripMenuItem.Name = "névjegyToolStripMenuItem"; + névjegyToolStripMenuItem.Size = new Size(117, 22); + névjegyToolStripMenuItem.Text = "Névjegy"; + névjegyToolStripMenuItem.Click += névjegyToolStripMenuItem_Click; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI", 24F, FontStyle.Bold, GraphicsUnit.Point, 238); + label1.ForeColor = Color.FromArgb(0, 0, 192); + label1.Location = new Point(141, 37); + label1.Name = "label1"; + label1.Size = new Size(356, 45); + label1.TabIndex = 1; + label1.Text = "Választási eredmények"; + // + // listBox1 + // + listBox1.FormattingEnabled = true; + listBox1.ItemHeight = 15; + listBox1.Location = new Point(37, 129); + listBox1.Name = "listBox1"; + listBox1.Size = new Size(249, 319); + listBox1.TabIndex = 2; + listBox1.SelectedIndexChanged += listBox1_SelectedIndexChanged; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(37, 101); + label2.Name = "label2"; + label2.Size = new Size(79, 15); + label2.TabIndex = 3; + label2.Text = "Jelöltek listája"; + // + // groupBox1 + // + groupBox1.Controls.Add(NumberSzavazatTextBox); + groupBox1.Controls.Add(PartTextBox); + groupBox1.Controls.Add(NumberPlaceTextBox); + groupBox1.Controls.Add(NameTextBox); + groupBox1.Controls.Add(label6); + groupBox1.Controls.Add(label5); + groupBox1.Controls.Add(label4); + groupBox1.Controls.Add(label3); + groupBox1.Location = new Point(314, 101); + groupBox1.Name = "groupBox1"; + groupBox1.Size = new Size(302, 188); + groupBox1.TabIndex = 4; + groupBox1.TabStop = false; + groupBox1.Text = "Kiválasztott jelölt adatai"; + // + // NumberSzavazatTextBox + // + NumberSzavazatTextBox.Location = new Point(168, 145); + NumberSzavazatTextBox.Name = "NumberSzavazatTextBox"; + NumberSzavazatTextBox.Size = new Size(118, 23); + NumberSzavazatTextBox.TabIndex = 7; + // + // PartTextBox + // + PartTextBox.Location = new Point(62, 110); + PartTextBox.Name = "PartTextBox"; + PartTextBox.Size = new Size(224, 23); + PartTextBox.TabIndex = 6; + // + // NumberPlaceTextBox + // + NumberPlaceTextBox.Location = new Point(168, 74); + NumberPlaceTextBox.Name = "NumberPlaceTextBox"; + NumberPlaceTextBox.Size = new Size(118, 23); + NumberPlaceTextBox.TabIndex = 5; + // + // NameTextBox + // + NameTextBox.Location = new Point(62, 37); + NameTextBox.Name = "NameTextBox"; + NameTextBox.Size = new Size(224, 23); + NameTextBox.TabIndex = 4; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(6, 148); + label6.Name = "label6"; + label6.Size = new Size(103, 15); + label6.TabIndex = 3; + label6.Text = "Szavazatok száma:"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(6, 113); + label5.Name = "label5"; + label5.Size = new Size(31, 15); + label5.TabIndex = 2; + label5.Text = "Párt:"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(6, 77); + label4.Name = "label4"; + label4.Size = new Size(124, 15); + label4.TabIndex = 1; + label4.Text = "Választókerület száma:"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(6, 40); + label3.Name = "label3"; + label3.Size = new Size(31, 15); + label3.TabIndex = 0; + label3.Text = "Név:"; + // + // button1 + // + button1.Location = new Point(349, 307); + button1.Name = "button1"; + button1.Size = new Size(233, 23); + button1.TabIndex = 5; + button1.Text = "Ebben a kerületben voltak még:"; + button1.UseVisualStyleBackColor = true; + button1.Click += button1_Click; + // + // listBox2 + // + listBox2.FormattingEnabled = true; + listBox2.ItemHeight = 15; + listBox2.Location = new Point(314, 344); + listBox2.Name = "listBox2"; + listBox2.Size = new Size(302, 109); + listBox2.TabIndex = 6; + // + // Form1 + // + AutoScaleDimensions = new SizeF(7F, 15F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(634, 465); + Controls.Add(listBox2); + Controls.Add(button1); + Controls.Add(groupBox1); + Controls.Add(label2); + Controls.Add(listBox1); + Controls.Add(label1); + Controls.Add(menuStrip1); + ForeColor = SystemColors.ControlText; + MainMenuStrip = menuStrip1; + Name = "Form1"; + Text = "Helyhatósági választások"; + menuStrip1.ResumeLayout(false); + menuStrip1.PerformLayout(); + groupBox1.ResumeLayout(false); + groupBox1.PerformLayout(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private MenuStrip menuStrip1; + private ToolStripMenuItem fájlToolStripMenuItem; + private ToolStripMenuItem megnyitásToolStripMenuItem; + private ToolStripMenuItem kilépésToolStripMenuItem; + private ToolStripMenuItem műveletekToolStripMenuItem; + private ToolStripMenuItem statisztikaToolStripMenuItem; + private ToolStripMenuItem nyertesekToolStripMenuItem; + private ToolStripMenuItem súgóToolStripMenuItem; + private ToolStripMenuItem névjegyToolStripMenuItem; + private Label label1; + private ListBox listBox1; + private Label label2; + private GroupBox groupBox1; + private Label label4; + private Label label3; + private Label label5; + private TextBox NumberSzavazatTextBox; + private TextBox PartTextBox; + private TextBox NumberPlaceTextBox; + private TextBox NameTextBox; + private Label label6; + private Button button1; + private ListBox listBox2; + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.cs new file mode 100644 index 0000000..dfaf3ba --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.cs @@ -0,0 +1,193 @@ +using System.Windows.Forms; + +namespace _2024._04._28 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void megnyitsToolStripMenuItem_Click(object sender, EventArgs e) + { + OpenFileDialog openFileDialog = new OpenFileDialog(); + + openFileDialog.Filter = "Szveges fjlok (*.txt)|*.txt|All files (*.*)|*.*"; + + if (openFileDialog.ShowDialog() == DialogResult.OK) + { + StreamReader fileContent = new StreamReader(openFileDialog.FileName); + string line = fileContent.ReadLine(); + + while (line != null) + { + string[] currentLine = line.Split(" "); + listBox1.Items.Add($"{currentLine[2]} {currentLine[3]}"); + + line = fileContent.ReadLine(); + } + + fileContent.Close(); + } + } + + private void kilpsToolStripMenuItem_Click(object sender, EventArgs e) + { + this.Close(); + } + + private void listBox1_SelectedIndexChanged(object sender, EventArgs e) + { + if (listBox1.SelectedIndex != -1) + { + List lines = new List(); + StreamReader file = new StreamReader("szavazatok.txt"); + string line = file.ReadLine(); + + while (line != null) + { + lines.Add(line); + line = file.ReadLine(); + } + + file.Close(); + + foreach (var i in lines) + { + string[] currentLine = i.Split(" "); + + if ($"{currentLine[2]} {currentLine[3]}".Equals(listBox1.SelectedItem)) + { + NameTextBox.Text = $"{currentLine[2]} {currentLine[3]}"; + NumberPlaceTextBox.Text = currentLine[0]; + + if (currentLine[4].Equals("GYEP")) + { + PartTextBox.Text = "Gymlcsevk Prtja"; + } + + else if (currentLine[4].Equals("HEP")) + { + PartTextBox.Text = "Hsevk Prtja"; + } + + else if (currentLine[4].Equals("TISZ")) + { + PartTextBox.Text = "Tejivk szvetsge"; + } + + else if (currentLine[4].Equals("ZEP")) + { + PartTextBox.Text = "Zldsgevk Prtja"; + } + + else + { + PartTextBox.Text = currentLine[4]; + } + + NumberSzavazatTextBox.Text = currentLine[1]; + } + } + } + } + + private void button1_Click(object sender, EventArgs e) + { + if (listBox1.SelectedIndex == -1) + { + MessageBox.Show("Nincs kivlasztott kpvisel!", "Hiba", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + + else + { + listBox2.Items.Clear(); + + List lines = new List(); + StreamReader file = new StreamReader("szavazatok.txt"); + string line = file.ReadLine(); + + while (line != null) + { + lines.Add(line); + line = file.ReadLine(); + } + + file.Close(); + + foreach (var i in lines) + { + string[] currentLine = i.Split(" "); + + if (currentLine[0].Equals(NumberPlaceTextBox.Text) && !string.Equals($"{currentLine[2]} {currentLine[3]}", NameTextBox.Text)) + { + listBox2.Items.Add($"{currentLine[2]} {currentLine[3]} ({currentLine[1]} szavazat)"); + } + } + } + } + + private void statisztikaToolStripMenuItem_Click(object sender, EventArgs e) + { + if (listBox1.Items.Count == 0) + { + MessageBox.Show("Nincsenek kpvisel adatok!", "Hiba", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + + else + { + Form2 form2 = new Form2(); + form2.Show(); + } + } + + private void nyertesekToolStripMenuItem_Click(object sender, EventArgs e) + { + List lines = new List(); + StreamReader file = new StreamReader("szavazatok.txt"); + string line = file.ReadLine(); + Dictionary winners = new Dictionary(); + + while (line != null) + { + lines.Add(line); + line = file.ReadLine(); + } + + file.Close(); + + foreach (var i in lines) + { + string[] currentLine = i.Split(" "); + + int district = Convert.ToInt32(currentLine[0]); + string name = $"{currentLine[2]} {currentLine[3]}"; + int votes = Convert.ToInt32(currentLine[1]); + string party = currentLine[4]; + + if (!winners.ContainsKey(district) || votes > Convert.ToInt32(winners[district].Split(" ")[0])) + { + winners[district] = $"{votes} {name} {party}"; + } + } + + StreamWriter w = new StreamWriter("nyertesek.txt"); + + for (int i = 1; i <= winners.Count; i++) + { + string[] currentWinner = winners[i].Split(" "); + w.WriteLine($"{i} {currentWinner[1]} {currentWinner[2]} {currentWinner[3]}"); + } + + w.Close(); + + MessageBox.Show("A vlasztkerletek nyertesei sikeresen meghatrozva!", "rtests", MessageBoxButtons.OK, MessageBoxIcon.Information); + } + + private void nvjegyToolStripMenuItem_Click(object sender, EventArgs e) + { + MessageBox.Show("Helyhatsgi vlasztsokat elemz program", "Nvjegy", MessageBoxButtons.OK, MessageBoxIcon.Information); + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.resx new file mode 100644 index 0000000..a0623c8 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form1.resx @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + 17, 17 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.Designer.cs new file mode 100644 index 0000000..dc09797 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.Designer.cs @@ -0,0 +1,211 @@ +namespace _2024._04._28 +{ + partial class Form2 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + pictureBox1 = new PictureBox(); + label1 = new Label(); + AllCitizenTextBox = new TextBox(); + StatisticFillButton = new Button(); + AllRepresentativeTextBox = new TextBox(); + label2 = new Label(); + label3 = new Label(); + AllVotedPeopleTextBox = new TextBox(); + label4 = new Label(); + RatioTextBox = new TextBox(); + label5 = new Label(); + CloseButton = new Button(); + listBox1 = new ListBox(); + label6 = new Label(); + ((System.ComponentModel.ISupportInitialize)pictureBox1).BeginInit(); + SuspendLayout(); + // + // pictureBox1 + // + pictureBox1.Location = new Point(22, 23); + pictureBox1.Name = "pictureBox1"; + pictureBox1.Size = new Size(110, 105); + pictureBox1.TabIndex = 0; + pictureBox1.TabStop = false; + // + // label1 + // + label1.AutoSize = true; + label1.Location = new Point(138, 35); + label1.Name = "label1"; + label1.Size = new Size(224, 15); + label1.TabIndex = 1; + label1.Text = "Összes szavazásra jogosult polgár száma: "; + // + // AllCitizenTextBox + // + AllCitizenTextBox.Location = new Point(375, 32); + AllCitizenTextBox.Name = "AllCitizenTextBox"; + AllCitizenTextBox.Size = new Size(84, 23); + AllCitizenTextBox.TabIndex = 2; + AllCitizenTextBox.Text = "12345"; + // + // StatisticFillButton + // + StatisticFillButton.Location = new Point(327, 72); + StatisticFillButton.Name = "StatisticFillButton"; + StatisticFillButton.Size = new Size(141, 23); + StatisticFillButton.TabIndex = 3; + StatisticFillButton.Text = "Statisztika kitöltése"; + StatisticFillButton.UseVisualStyleBackColor = true; + StatisticFillButton.Click += StatisticFillButton_Click; + // + // AllRepresentativeTextBox + // + AllRepresentativeTextBox.Location = new Point(375, 119); + AllRepresentativeTextBox.Name = "AllRepresentativeTextBox"; + AllRepresentativeTextBox.Size = new Size(84, 23); + AllRepresentativeTextBox.TabIndex = 4; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(166, 122); + label2.Name = "label2"; + label2.Size = new Size(186, 15); + label2.TabIndex = 5; + label2.Text = "Az induló képviselőjelöltek száma:"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(31, 153); + label3.Name = "label3"; + label3.Size = new Size(154, 15); + label3.TabIndex = 6; + label3.Text = "A választáson szavazott (fő):"; + // + // AllVotedPeopleTextBox + // + AllVotedPeopleTextBox.Location = new Point(191, 150); + AllVotedPeopleTextBox.Name = "AllVotedPeopleTextBox"; + AllVotedPeopleTextBox.Size = new Size(58, 23); + AllVotedPeopleTextBox.TabIndex = 7; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(267, 153); + label4.Name = "label4"; + label4.Size = new Size(85, 15); + label4.TabIndex = 8; + label4.Text = "ez a jogosultak"; + // + // RatioTextBox + // + RatioTextBox.Location = new Point(375, 153); + RatioTextBox.Name = "RatioTextBox"; + RatioTextBox.Size = new Size(48, 23); + RatioTextBox.TabIndex = 9; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(431, 158); + label5.Name = "label5"; + label5.Size = new Size(28, 15); + label5.TabIndex = 10; + label5.Text = "%-a"; + // + // CloseButton + // + CloseButton.Location = new Point(217, 398); + CloseButton.Name = "CloseButton"; + CloseButton.Size = new Size(75, 23); + CloseButton.TabIndex = 12; + CloseButton.Text = "Bezár"; + CloseButton.UseVisualStyleBackColor = true; + CloseButton.Click += CloseButton_Click; + // + // listBox1 + // + listBox1.FormattingEnabled = true; + listBox1.ItemHeight = 15; + listBox1.Location = new Point(31, 263); + listBox1.Name = "listBox1"; + listBox1.Size = new Size(243, 94); + listBox1.TabIndex = 13; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(31, 224); + label6.Name = "label6"; + label6.Size = new Size(236, 15); + label6.TabIndex = 14; + label6.Text = "Az egyes párokra leadott szavazatok aránya:"; + // + // Form2 + // + AutoScaleDimensions = new SizeF(7F, 15F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(495, 450); + Controls.Add(label6); + Controls.Add(listBox1); + Controls.Add(CloseButton); + Controls.Add(label5); + Controls.Add(RatioTextBox); + Controls.Add(label4); + Controls.Add(AllVotedPeopleTextBox); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(AllRepresentativeTextBox); + Controls.Add(StatisticFillButton); + Controls.Add(AllCitizenTextBox); + Controls.Add(label1); + Controls.Add(pictureBox1); + Name = "Form2"; + Text = "Választási statisztika"; + ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private PictureBox pictureBox1; + private Label label1; + private TextBox AllCitizenTextBox; + private Button StatisticFillButton; + private TextBox AllRepresentativeTextBox; + private Label label2; + private Label label3; + private TextBox AllVotedPeopleTextBox; + private Label label4; + private TextBox RatioTextBox; + private Label label5; + private Button CloseButton; + private ListBox listBox1; + private Label label6; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.cs new file mode 100644 index 0000000..d8bfe1d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.cs @@ -0,0 +1,88 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Data; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace _2024._04._28 +{ + public partial class Form2 : Form + { + public Form2() + { + InitializeComponent(); + } + + private void StatisticFillButton_Click(object sender, EventArgs e) + { + listBox1.Items.Clear(); + + List lines = new List(); + StreamReader file = new StreamReader("szavazatok.txt"); + string line = file.ReadLine(); + double voted = 0; + + double hep = 0; + double gyep = 0; + double tisz = 0; + double zep = 0; + double independent = 0; + + while (line != null) + { + lines.Add(line); + line = file.ReadLine(); + } + + foreach (var i in lines) + { + string[] currentLine = i.Split(" "); + voted += Convert.ToInt32(currentLine[1]); + + if (currentLine[4].Equals("HEP")) + { + hep += Convert.ToInt32(currentLine[1]); + } + + else if (currentLine[4].Equals("GYEP")) + { + gyep += Convert.ToInt32(currentLine[1]); + } + + else if (currentLine[4].Equals("TISZ")) + { + tisz += Convert.ToInt32(currentLine[1]); + } + + else if (currentLine[4].Equals("ZEP")) + { + zep += Convert.ToInt32(currentLine[1]); + } + + else + { + independent += Convert.ToInt32(currentLine[1]); + } + + } + + AllRepresentativeTextBox.Text = lines.Count.ToString(); + AllVotedPeopleTextBox.Text = voted.ToString(); + RatioTextBox.Text = Math.Round(voted / Convert.ToDouble(AllCitizenTextBox.Text) * 100, 2).ToString(); + listBox1.Items.Add($"Húsevők Pártja {Math.Round(hep / voted * 100, 2)} %"); + listBox1.Items.Add($"Gyümölcsevők Pártja {Math.Round(gyep / voted * 100, 2)} %"); + listBox1.Items.Add($"Tejivók Szövetsége {Math.Round(tisz / voted * 100, 2)} %"); + listBox1.Items.Add($"Zöldségevők Pártja {Math.Round(zep / voted * 100, 2)} %"); + listBox1.Items.Add($"Független jelölt {Math.Round(independent / voted * 100, 2)} %"); + } + + private void CloseButton_Click(object sender, EventArgs e) + { + this.Close(); + } + } +} diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Form2.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Program.cs new file mode 100644 index 0000000..2634213 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._04._28 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.deps.json new file mode 100644 index 0000000..fe865de --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 04. 28/1.0.0": { + "runtime": { + "2024. 04. 28.dll": {} + } + } + } + }, + "libraries": { + "2024. 04. 28/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.dll new file mode 100644 index 0000000..fedac85 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.exe new file mode 100644 index 0000000..0f5efe4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.pdb new file mode 100644 index 0000000..758b65e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/2024. 04. 28.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/nyertesek.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/nyertesek.txt new file mode 100644 index 0000000..c3af3ce --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/nyertesek.txt @@ -0,0 +1,8 @@ +1 Petrezselyem Petra ZEP +2 Oldalas Olga HEP +3 Tejes Attila TISZ +4 Monitor Tibor - +5 Joghurt Jakab TISZ +6 Vadas Marcell HEP +7 Bab Zsuzsanna ZEP +8 Narancs Edmond GYEP diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/szavazatok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/szavazatok.txt new file mode 100644 index 0000000..848297f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/bin/Debug/net8.0-windows/szavazatok.txt @@ -0,0 +1,40 @@ +5 19 Ablak Antal - +1 120 Alma Dalma GYEP +7 162 Bab Zsuzsanna ZEP +2 59 Barack Barna GYEP +6 73 Birs Helga GYEP +1 154 Bors Botond HEP +5 188 Brokkoli Gyula ZEP +6 29 Ceruza Zsombor - +4 143 Fasirt Ferenc HEP +8 157 Gomba Gitta TISZ +3 13 Halmi Helga - +2 66 Hold Ferenc - +7 34 Hurka Herold HEP +5 288 Joghurt Jakab TISZ +4 77 Kajszi Kolos GYEP +2 187 Kapor Karola ZEP +6 13 Karfiol Ede ZEP +6 187 Kefir Ilona TISZ +7 130 Kupa Huba - +8 98 Languszta Auguszta - +1 34 Lila Lilla - +1 56 Medve Rudolf - +5 67 Meggy Csilla GYEP +3 45 Moly Piroska - +4 221 Monitor Tibor - +8 288 Narancs Edmond GYEP +2 220 Oldalas Olga HEP +3 185 Pacal Kata HEP +1 199 Petrezselyem Petra ZEP +8 77 Pokol Vidor - +8 67 Ragu Ida HEP +3 156 Retek Etelka ZEP +7 129 Sajt Hajnalka TISZ +4 38 Simon Simon - +3 87 Szilva Szilvia GYEP +3 187 Tejes Attila TISZ +2 65 Tejfel Edit TISZ +4 39 Uborka Ubul ZEP +6 288 Vadas Marcell HEP +5 68 Vagdalt Edit HEP diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.dgspec.json new file mode 100644 index 0000000..9816588 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj": {} + }, + "projects": { + "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj", + "projectName": "2024. 04. 28", + "projectPath": "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj", + "packagesPath": "C:\\Users\\Ádám\\.nuget\\packages\\", + "outputPath": "E:\\2024. 04. 28\\2024. 04. 28\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádám\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.200/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.props new file mode 100644 index 0000000..7f70043 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Ádám\.nuget\packages\ + PackageReference + 6.9.1 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/2024. 04. 28.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfo.cs new file mode 100644 index 0000000..fd50c55 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 04. 28")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 04. 28")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 04. 28")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfoInputs.cache new file mode 100644 index 0000000..17f71b4 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +150a0beb2dc9208acfc735725585f7f3d4cd9433910dd52b501045b295a28b1a diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..f3b7e20 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,19 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._04._28 +build_property.ProjectDir = E:\2024. 04. 28\2024. 04. 28\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.assets.cache new file mode 100644 index 0000000..47580c2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..bbb8a2c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +3f8b7a548e415d843f9aa9e6a8fe7037dc8ebaba49271a04a1e80d5b1b06753d diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..f21528e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.FileListAbsolute.txt @@ -0,0 +1,34 @@ +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.exe +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.deps.json +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.runtimeconfig.json +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.pdb +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\_2024._04._28.Form1.resources +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\_2024._04._28.Form2.resources +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.csproj.GenerateResource.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.GeneratedMSBuildEditorConfig.editorconfig +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.AssemblyInfoInputs.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.AssemblyInfo.cs +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.csproj.CoreCompileInputs.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\refint\2024. 04. 28.dll +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.pdb +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.genruntimeconfig.cache +D:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Gyakorlás\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\ref\2024. 04. 28.dll +E:\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.exe +E:\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.deps.json +E:\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.runtimeconfig.json +E:\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.dll +E:\2024. 04. 28\2024. 04. 28\bin\Debug\net8.0-windows\2024. 04. 28.pdb +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\_2024._04._28.Form1.resources +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\_2024._04._28.Form2.resources +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.csproj.GenerateResource.cache +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.GeneratedMSBuildEditorConfig.editorconfig +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.AssemblyInfoInputs.cache +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.AssemblyInfo.cs +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.csproj.CoreCompileInputs.cache +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.dll +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\refint\2024. 04. 28.dll +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.pdb +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\2024. 04. 28.genruntimeconfig.cache +E:\2024. 04. 28\2024. 04. 28\obj\Debug\net8.0-windows\ref\2024. 04. 28.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.GenerateResource.cache new file mode 100644 index 0000000..18ae1bd Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.runtimeconfig.json new file mode 100644 index 0000000..6f66f90 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Ádám\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Ádám\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.dll new file mode 100644 index 0000000..fedac85 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.genruntimeconfig.cache new file mode 100644 index 0000000..278d9ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.genruntimeconfig.cache @@ -0,0 +1 @@ +7c0460e9955615b57c58ff26e31c7571e848baeb88971d3b02c16e2402996fe2 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.pdb new file mode 100644 index 0000000..758b65e Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/2024. 04. 28.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form2.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form2.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/_2024._04._28.Form2.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..0f5efe4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/ref/2024. 04. 28.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/ref/2024. 04. 28.dll new file mode 100644 index 0000000..a02092b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/ref/2024. 04. 28.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/refint/2024. 04. 28.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/refint/2024. 04. 28.dll new file mode 100644 index 0000000..a02092b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/Debug/net8.0-windows/refint/2024. 04. 28.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.assets.json new file mode 100644 index 0000000..e2c0977 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Ádám\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj", + "projectName": "2024. 04. 28", + "projectPath": "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj", + "packagesPath": "C:\\Users\\Ádám\\.nuget\\packages\\", + "outputPath": "E:\\2024. 04. 28\\2024. 04. 28\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Ádám\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.200/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.nuget.cache new file mode 100644 index 0000000..066eb49 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 04. 28/2024. 04. 28/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "IpOYcTZi6hefQFjfJeTmh8wZhPy1o2aeXz5SjdipoF2H7fE3AqMc6dPhvu1g3iDbPk9lntLODIT8rq8TqRBOjw==", + "success": true, + "projectFilePath": "E:\\2024. 04. 28\\2024. 04. 28\\2024. 04. 28.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..ba36c55 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/76cc56d1-bc5d-4957-976c-82968814d55b.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/76cc56d1-bc5d-4957-976c-82968814d55b.vsidx new file mode 100644 index 0000000..6ef5e21 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/76cc56d1-bc5d-4957-976c-82968814d55b.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/fa576e19-9350-4e0e-a2ba-92e1948ce096.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/fa576e19-9350-4e0e-a2ba-92e1948ce096.vsidx new file mode 100644 index 0000000..cc60124 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/FileContentIndex/fa576e19-9350-4e0e-a2ba-92e1948ce096.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.futdcache.v2 new file mode 100644 index 0000000..17dd04d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.suo new file mode 100644 index 0000000..546f97f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/2024. 05. 13/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.metadata.v7.bin new file mode 100644 index 0000000..97fe33d Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.projects.v7.bin new file mode 100644 index 0000000..f14ed36 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/.vs/ProjectEvaluation/2024. 05. 13.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13.sln new file mode 100644 index 0000000..a0e192e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 05. 13", "2024. 05. 13\2024. 05. 13.csproj", "{A14207F5-3236-4DA1-9D2F-D7E1A518DC4A}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A14207F5-3236-4DA1-9D2F-D7E1A518DC4A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A14207F5-3236-4DA1-9D2F-D7E1A518DC4A}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A14207F5-3236-4DA1-9D2F-D7E1A518DC4A}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A14207F5-3236-4DA1-9D2F-D7E1A518DC4A}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {97F24B25-3CD4-4DFA-9A90-41499F875472} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj new file mode 100644 index 0000000..a509d5f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._05._13 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/2024. 05. 13.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.Designer.cs new file mode 100644 index 0000000..eb7efbb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.Designer.cs @@ -0,0 +1,294 @@ +namespace _2024._05._13 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + SpecialTextBox = new TextBox(); + WinnerTextBox = new TextBox(); + pictureBox1 = new PictureBox(); + label1 = new Label(); + label2 = new Label(); + label3 = new Label(); + ExpensiveTextBox = new TextBox(); + CheapTextBox = new TextBox(); + ValueExpensiveTextBox = new TextBox(); + ValueCheapTextBox = new TextBox(); + TypeTextBox = new TextBox(); + SaveButton = new Button(); + label4 = new Label(); + label5 = new Label(); + label6 = new Label(); + label7 = new Label(); + WinnerCheckBox = new CheckBox(); + NameTextBox = new TextBox(); + TypeCreateTextBox = new TextBox(); + UnitTextBox = new TextBox(); + ValueTextBox = new TextBox(); + CreateButton = new Button(); + ((System.ComponentModel.ISupportInitialize)pictureBox1).BeginInit(); + SuspendLayout(); + // + // SpecialTextBox + // + SpecialTextBox.Location = new Point(47, 70); + SpecialTextBox.Name = "SpecialTextBox"; + SpecialTextBox.Size = new Size(316, 27); + SpecialTextBox.TabIndex = 0; + // + // WinnerTextBox + // + WinnerTextBox.Location = new Point(47, 124); + WinnerTextBox.Name = "WinnerTextBox"; + WinnerTextBox.Size = new Size(316, 27); + WinnerTextBox.TabIndex = 1; + // + // pictureBox1 + // + pictureBox1.Location = new Point(402, 70); + pictureBox1.Name = "pictureBox1"; + pictureBox1.Size = new Size(133, 114); + pictureBox1.TabIndex = 2; + pictureBox1.TabStop = false; + // + // label1 + // + label1.AutoSize = true; + label1.Location = new Point(57, 211); + label1.Name = "label1"; + label1.Size = new Size(180, 20); + label1.TabIndex = 3; + label1.Text = "Legdrágább süteményünk"; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(57, 317); + label2.Name = "label2"; + label2.Size = new Size(176, 20); + label2.TabIndex = 4; + label2.Text = "Legolcsóbb süteményünk"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(57, 437); + label3.Name = "label3"; + label3.Size = new Size(78, 20); + label3.TabIndex = 5; + label3.Text = "Süti típusa"; + // + // ExpensiveTextBox + // + ExpensiveTextBox.Location = new Point(21, 250); + ExpensiveTextBox.Name = "ExpensiveTextBox"; + ExpensiveTextBox.Size = new Size(305, 27); + ExpensiveTextBox.TabIndex = 6; + // + // CheapTextBox + // + CheapTextBox.Location = new Point(21, 361); + CheapTextBox.Name = "CheapTextBox"; + CheapTextBox.Size = new Size(305, 27); + CheapTextBox.TabIndex = 7; + // + // ValueExpensiveTextBox + // + ValueExpensiveTextBox.Location = new Point(385, 250); + ValueExpensiveTextBox.Name = "ValueExpensiveTextBox"; + ValueExpensiveTextBox.Size = new Size(150, 27); + ValueExpensiveTextBox.TabIndex = 8; + // + // ValueCheapTextBox + // + ValueCheapTextBox.Location = new Point(385, 361); + ValueCheapTextBox.Name = "ValueCheapTextBox"; + ValueCheapTextBox.Size = new Size(150, 27); + ValueCheapTextBox.TabIndex = 9; + // + // TypeTextBox + // + TypeTextBox.Location = new Point(204, 430); + TypeTextBox.Name = "TypeTextBox"; + TypeTextBox.Size = new Size(331, 27); + TypeTextBox.TabIndex = 10; + // + // SaveButton + // + SaveButton.Location = new Point(168, 488); + SaveButton.Name = "SaveButton"; + SaveButton.Size = new Size(210, 39); + SaveButton.TabIndex = 11; + SaveButton.Text = "Árajánlat mentése"; + SaveButton.UseVisualStyleBackColor = true; + SaveButton.Click += SaveButton_Click; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(629, 164); + label4.Name = "label4"; + label4.Size = new Size(81, 20); + label4.TabIndex = 12; + label4.Text = "Süti típusa:"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(629, 90); + label5.Name = "label5"; + label5.Size = new Size(72, 20); + label5.TabIndex = 13; + label5.Text = "Süti neve:"; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(629, 236); + label6.Name = "label6"; + label6.Size = new Size(59, 20); + label6.TabIndex = 14; + label6.Text = "Egység:"; + // + // label7 + // + label7.AutoSize = true; + label7.Location = new Point(629, 310); + label7.Name = "label7"; + label7.Size = new Size(27, 20); + label7.TabIndex = 15; + label7.Text = "Ár:"; + // + // WinnerCheckBox + // + WinnerCheckBox.AutoSize = true; + WinnerCheckBox.Location = new Point(629, 385); + WinnerCheckBox.Name = "WinnerCheckBox"; + WinnerCheckBox.Size = new Size(84, 24); + WinnerCheckBox.TabIndex = 16; + WinnerCheckBox.Text = "Díjazott"; + WinnerCheckBox.UseVisualStyleBackColor = true; + // + // NameTextBox + // + NameTextBox.Location = new Point(765, 87); + NameTextBox.Name = "NameTextBox"; + NameTextBox.Size = new Size(235, 27); + NameTextBox.TabIndex = 17; + // + // TypeCreateTextBox + // + TypeCreateTextBox.Location = new Point(765, 157); + TypeCreateTextBox.Name = "TypeCreateTextBox"; + TypeCreateTextBox.Size = new Size(235, 27); + TypeCreateTextBox.TabIndex = 18; + // + // UnitTextBox + // + UnitTextBox.Location = new Point(765, 233); + UnitTextBox.Name = "UnitTextBox"; + UnitTextBox.Size = new Size(235, 27); + UnitTextBox.TabIndex = 19; + // + // ValueTextBox + // + ValueTextBox.Location = new Point(765, 310); + ValueTextBox.Name = "ValueTextBox"; + ValueTextBox.Size = new Size(235, 27); + ValueTextBox.TabIndex = 20; + // + // CreateButton + // + CreateButton.Location = new Point(733, 437); + CreateButton.Name = "CreateButton"; + CreateButton.Size = new Size(210, 39); + CreateButton.TabIndex = 21; + CreateButton.Text = "Új süti felvétele"; + CreateButton.UseVisualStyleBackColor = true; + CreateButton.Click += CreateButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(1057, 545); + Controls.Add(CreateButton); + Controls.Add(ValueTextBox); + Controls.Add(UnitTextBox); + Controls.Add(TypeCreateTextBox); + Controls.Add(NameTextBox); + Controls.Add(WinnerCheckBox); + Controls.Add(label7); + Controls.Add(label6); + Controls.Add(label5); + Controls.Add(label4); + Controls.Add(SaveButton); + Controls.Add(TypeTextBox); + Controls.Add(ValueCheapTextBox); + Controls.Add(ValueExpensiveTextBox); + Controls.Add(CheapTextBox); + Controls.Add(ExpensiveTextBox); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(label1); + Controls.Add(pictureBox1); + Controls.Add(WinnerTextBox); + Controls.Add(SpecialTextBox); + Name = "Form1"; + Text = "Form1"; + Load += Form1_Load; + ((System.ComponentModel.ISupportInitialize)pictureBox1).EndInit(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private TextBox SpecialTextBox; + private TextBox WinnerTextBox; + private PictureBox pictureBox1; + private Label label1; + private Label label2; + private Label label3; + private TextBox ExpensiveTextBox; + private TextBox CheapTextBox; + private TextBox ValueExpensiveTextBox; + private TextBox ValueCheapTextBox; + private TextBox TypeTextBox; + private Button SaveButton; + private Label label4; + private Label label5; + private Label label6; + private Label label7; + private CheckBox WinnerCheckBox; + private TextBox NameTextBox; + private TextBox TypeCreateTextBox; + private TextBox UnitTextBox; + private TextBox ValueTextBox; + private Button CreateButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.cs new file mode 100644 index 0000000..ca20e28 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.cs @@ -0,0 +1,147 @@ +using System.Xml.Linq; + +namespace _2024._05._13 +{ + public partial class Form1 : Form + { + private List lines = new List(); + public Form1() + { + InitializeComponent(); + } + + private void Form1_Load(object sender, EventArgs e) + { + StreamReader sr = new StreamReader("cuki.txt"); + string line = sr.ReadLine(); + + while (line != null) + { + lines.Add(line); + line = sr.ReadLine(); + } + + sr.Close(); + + List expensive = new List() { "Hello", "0", "db" }; + List cheap = new List() { "Hello", "18400", "db" }; + + int db = 0; + + Random rng = new Random(); + string[] randomLine = lines[rng.Next(0, lines.Count)].Split(";"); + SpecialTextBox.Text = $"Mai ajnlatunk: {randomLine[0]}"; + + foreach (var i in lines) + { + string[] currentLine = i.Split(";"); + + if (currentLine[2].Equals("true")) + { + db += 1; + } + + if (Convert.ToInt32(currentLine[3]) > Convert.ToInt32(expensive[1])) + { + expensive[0] = currentLine[0]; + expensive[1] = currentLine[3]; + expensive[2] = currentLine[4]; + } + + if (Convert.ToInt32(currentLine[3]) < Convert.ToInt32(cheap[1])) + { + cheap[0] = currentLine[0]; + cheap[1] = currentLine[3]; + cheap[2] = currentLine[4]; + } + } + + WinnerTextBox.Text = $"{db} fle djnyertes dessgbl vlaszthat."; + + ExpensiveTextBox.Text = expensive[0].ToString(); + ValueExpensiveTextBox.Text = $"{expensive[1]} Ft/{expensive[2]}"; + CheapTextBox.Text = cheap[0].ToString(); + ValueCheapTextBox.Text = $"{cheap[1]} Ft/{cheap[2]}"; + } + + private void SaveButton_Click(object sender, EventArgs e) + { + double count = 0; + double value = 0; + + if (TypeTextBox.Text.Equals("")) + { + MessageBox.Show("Nem rtl be stemnynevet!"); + } + + else + { + lines.Clear(); + StreamReader sr = new StreamReader("cuki.txt"); + string line = sr.ReadLine(); + + while (line != null) + { + lines.Add(line); + line = sr.ReadLine(); + } + + sr.Close(); + + StreamWriter sw = new StreamWriter("ajanlat.txt"); + foreach (var i in lines) + { + string[] currentLine = i.Split(";"); + + if (currentLine[1].Equals(TypeTextBox.Text)) + { + sw.WriteLine($"{currentLine[0]};{currentLine[3]};{currentLine[4]}"); + count += 1; + value += int.Parse(currentLine[3]); + } + } + + sw.Close(); + + if (count == 0) + { + MessageBox.Show("Nincs megfelel stink. Krjk, vlassz mst!"); + } + + else + { + MessageBox.Show($"{count} db stit rtam az ajanlat.txt-be\ntlagr: {value / count} Ft"); + } + } + } + + private void CreateButton_Click(object sender, EventArgs e) + { + if (NameTextBox.Text.Equals("") || TypeCreateTextBox.Text.Equals("") || UnitTextBox.Text.Equals("") || ValueTextBox.Text.Equals("")) + { + MessageBox.Show("Nem adtl meg minden adatot!"); + } + + else + { + try + { + int value = int.Parse(ValueTextBox.Text); + + using (StreamWriter sw = File.AppendText("cuki.txt")) + { + sw.WriteLine($"{NameTextBox.Text};{TypeCreateTextBox.Text};{WinnerCheckBox.Checked};{ValueTextBox.Text};{UnitTextBox.Text}"); + } + + MessageBox.Show("Az llomny bvtse sikeres volt!"); + + } + + catch + { + MessageBox.Show("Az j stemny ra nem szm!"); + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Program.cs new file mode 100644 index 0000000..c549a33 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._05._13 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.deps.json new file mode 100644 index 0000000..fce9cf7 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 05. 13/1.0.0": { + "runtime": { + "2024. 05. 13.dll": {} + } + } + } + }, + "libraries": { + "2024. 05. 13/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.dll new file mode 100644 index 0000000..dd42bf4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.exe new file mode 100644 index 0000000..c204c48 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.pdb new file mode 100644 index 0000000..47ae279 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/2024. 05. 13.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/ajanlat.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/ajanlat.txt new file mode 100644 index 0000000..04f2fe1 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/ajanlat.txt @@ -0,0 +1,107 @@ +Sajttorta (málnás);9000;12 szeletes +Citrom;3900;8 szeletes +Citrom;7400;16 szeletes +Citrom;11400;24 szeletes +Legényfogó;12100;24 szeletes +Legényfogó;4300;8 szeletes +Legényfogó;8200;16 szeletes +Három kívánság;5700;8 szeletes +Három kívánság;5700;8 szeletes +Dobos;9000;16 szeletes +Dobos;13200;24 szeletes +Dobos;4700;8 szeletes +Csokoládémousse;11400;24 szeletes +Csokoládémousse;3900;8 szeletes +Csokoládémousse;7400;16 szeletes +Oroszkrém;8200;16 szeletes +Oroszkrém;4300;8 szeletes +Oroszkrém;12100;24 szeletes +Trüffel;15400;24 szeletes +Trüffel;10400;16 szeletes +Trüffel;5400;8 szeletes +Tejszínes gyümölcsös (meggy);8200;16 szeletes +Tejszínes gyümölcsös (meggy);4300;8 szeletes +Tejszínes gyümölcsös (meggy);12100;24 szeletes +Sós karamella;4700;8 szeletes +Sós karamella;13200;24 szeletes +Sós karamella;9000;16 szeletes +Rigó Jancsi;3900;8 szeletes +Rigó Jancsi;7400;16 szeletes +Rigó Jancsi;11400;24 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);4300;8 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);8200;16 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);12100;24 szeletes +Ez+Az (csokoládé és gesztenye);13200;24 szeletes +Ez+Az (csokoládé és gesztenye);9000;16 szeletes +Ez+Az (csokoládé és gesztenye);4700;8 szeletes +Málnás mascarpone;5700;8 szeletes +Málnás mascarpone;16200;24 szeletes +Málnás mascarpone;10900;16 szeletes +Ferrero;16200;24 szeletes +Ferrero;10900;16 szeletes +Ferrero;5700;8 szeletes +Csokoládémousse fényes csokoládéval;13400;24 szeletes +Csokoládémousse fényes csokoládéval;9200;16 szeletes +Csokoládémousse fényes csokoládéval;4900;8 szeletes +Lúdláb;13200;24 szeletes +Lúdláb;9000;16 szeletes +Lúdláb;4700;8 szeletes +Sacher;8200;16 szeletes +Sacher;12100;24 szeletes +Sacher;4300;8 szeletes +Eszterházy;8400;16 szeletes +Eszterházy;12200;24 szeletes +Eszterházy;4500;8 szeletes +Pisztáciás-málnás mascarpone;18400;24 szeletes +Pisztáciás-málnás mascarpone;6400;8 szeletes +Pisztáciás-málnás mascarpone;12400;16 szeletes +Túrókrém gyümölccsel;7400;16 szeletes +Túrókrém gyümölccsel;3900;8 szeletes +Túrókrém gyümölccsel;11400;24 szeletes +Somlói;5400;8 szeletes +Palermo;7400;16 szeletes +Palermo;3900;8 szeletes +Palermo;11400;24 szeletes +Ünnepi diótorta grillázzsal;10900;16 szeletes +Ünnepi diótorta grillázzsal;5700;8 szeletes +Ünnepi diótorta grillázzsal;16200;24 szeletes +Tejszínes gyümölcsös (málna);8200;16 szeletes +Tejszínes gyümölcsös (málna);4300;8 szeletes +Tejszínes gyümölcsös (málna);12100;24 szeletes +Marcipános csokoládé;5700;8 szeletes +Marcipános csokoládé;16200;24 szeletes +Marcipános csokoládé;10900;16 szeletes +Szedres csokoládé;13200;24 szeletes +Szedres csokoládé;9000;16 szeletes +Szedres csokoládé;4700;8 szeletes +Mézeskalács;16200;24 szeletes +Mézeskalács;5700;8 szeletes +Mézeskalács;10900;16 szeletes +Tiramisu;10400;16 szeletes +Tiramisu;15400;24 szeletes +Tiramisu;5400;8 szeletes +Zalavári gesztenye;10900;16 szeletes +Zalavári gesztenye;5700;8 szeletes +Danubius;4300;8 szeletes +Danubius;12100;24 szeletes +Danubius;8200;16 szeletes +Alpesi karamell;12200;24 szeletes +Alpesi karamell;8400;16 szeletes +Alpesi karamell;4500;8 szeletes +Puncs;11400;24 szeletes +Puncs;3900;8 szeletes +Puncs;7400;16 szeletes +Oreo;16200;24 szeletes +Oreo;5700;8 szeletes +Oreo;10900;16 szeletes +Vintage;9900;16 szeletes +Feketeerdő;9000;16 szeletes +Feketeerdő;13200;24 szeletes +Feketeerdő;4700;8 szeletes +Rákóczi-túrós;3900;8 szeletes +Rákóczi-túrós;7400;16 szeletes +Rákóczi-túrós;11400;24 szeletes +Dió;4700;8 szeletes +Dió;9000;16 szeletes +Dió;13200;24 szeletes +Mákos guba;4700;8 szeletes diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/cuki.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/cuki.txt new file mode 100644 index 0000000..7364072 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/bin/Debug/net6.0-windows/cuki.txt @@ -0,0 +1,208 @@ +Süni;vegyes;false;300;db +Gesztenyealagút;vegyes;false;500;db +Sajtos pogácsa;sós teasütemény;false;3300;kg +Diós-mákos;bejgli;false;3500;koszorú +Sajttorta (málnás);torta;false;9000;12 szeletes +Citrom;torta;false;3900;8 szeletes +Citrom;torta;false;7400;16 szeletes +Citrom;torta;false;11400;24 szeletes +Eszterházy;tortaszelet;false;490;db +Rákóczi-túrós;pite;false;400;db +Meggyes kocka;tejszínes sütemény;false;450;db +Legényfogó;torta;true;12100;24 szeletes +Legényfogó;torta;true;4300;8 szeletes +Legényfogó;torta;true;8200;16 szeletes +Alpesi karamell;tortaszelet;false;490;db +Kókuszcsók;édes teasütemény;false;3400;kg +Habos mákos;pite;false;400;db +Szilvás;pite;false;350;db +Juhtúrós párna;sós teasütemény;false;5000;kg +Mákos guba;tortaszelet;false;530;db +Néró;édes teasütemény;false;3400;kg +Sacher;tortaszelet;false;490;db +Citrom;tortaszelet;false;450;db +Ribizlihabos-almás réteges;különleges torta;true;4700;8 szeletes +Három kívánság;torta;true;5700;8 szeletes +Három kívánság;torta;true;5700;8 szeletes +Dobos;torta;false;9000;16 szeletes +Dobos;torta;false;13200;24 szeletes +Dobos;torta;false;4700;8 szeletes +Epres mascarpone;tortaszelet;false;550;db +Csokoládémousse;torta;false;11400;24 szeletes +Csokoládémousse;torta;false;3900;8 szeletes +Csokoládémousse;torta;false;7400;16 szeletes +Oroszkrém;torta;false;8200;16 szeletes +Oroszkrém;torta;false;4300;8 szeletes +Oroszkrém;torta;false;12100;24 szeletes +Medvetalp;vegyes;false;400;db +Trüffel;torta;false;15400;24 szeletes +Trüffel;torta;false;10400;16 szeletes +Trüffel;torta;false;5400;8 szeletes +Tejszínes gyümölcsös (meggy);torta;false;8200;16 szeletes +Tejszínes gyümölcsös (meggy);torta;false;4300;8 szeletes +Tejszínes gyümölcsös (meggy);torta;false;12100;24 szeletes +Mákos-szilvalekváros;bejgli;false;3500;koszorú +Ribizlihabos-almás réteges tortaszelet;tortaszelet;false;530;db +Marcipános vágott;édes teasütemény;false;5200;kg +Indiáner;vegyes;false;500;db +Meggyes;pite;false;350;db +Mákos;bejgli;false;1700;rúd +Sós karamella;torta;false;4700;8 szeletes +Sós karamella;torta;false;13200;24 szeletes +Sós karamella;torta;false;9000;16 szeletes +Legényfogó;tortaszelet;false;490;db +Rigó Jancsi;torta;false;3900;8 szeletes +Rigó Jancsi;torta;false;7400;16 szeletes +Rigó Jancsi;torta;false;11400;24 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);torta;false;4300;8 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);torta;false;8200;16 szeletes +Tejszínes gyümölcsös (erdei gyümölcs);torta;false;12100;24 szeletes +Ez+Az (csokoládé és gesztenye);torta;false;13200;24 szeletes +Ez+Az (csokoládé és gesztenye);torta;false;9000;16 szeletes +Ez+Az (csokoládé és gesztenye);torta;false;4700;8 szeletes +Málnás mascarpone;torta;false;5700;8 szeletes +Málnás mascarpone;torta;false;16200;24 szeletes +Málnás mascarpone;torta;false;10900;16 szeletes +Dobos;tortaszelet;false;530;db +Ferrero;torta;false;16200;24 szeletes +Ferrero;torta;false;10900;16 szeletes +Ferrero;torta;false;5700;8 szeletes +Vegyes házi pite falatok;pite;false;4200;kg +Ökörszem;édes teasütemény;false;3800;kg +Danubius kocka;tejszínes sütemény;false;450;db +Sajtkrémmel töltött fánkocska;sós teasütemény;false;5200;kg +Túrókrém gyümölccsel díszítve;tortaszelet;false;490;db +Almás;pite;false;350;db +Mignon;vegyes;false;250;db +Csokoládémousse fényes csokoládéval;torta;false;13400;24 szeletes +Csokoládémousse fényes csokoládéval;torta;false;9200;16 szeletes +Csokoládémousse fényes csokoládéval;torta;false;4900;8 szeletes +Vágott sós (sós omlós);sós teasütemény;false;4000;kg +Nagyi sós;sós teasütemény;false;5000;kg +Vegyes sós;sós teasütemény;false;4200;kg +Somlói;tortaszelet;false;580;db +Tiramisu;tortaszelet;false;600;db +Hegyvidék;tortaszelet;false;600;db +Szedres csokoládé;tortaszelet;false;530;db +Pogácsák vegyesen;sós teasütemény;false;3200;kg +Lúdláb;torta;false;13200;24 szeletes +Lúdláb;torta;false;9000;16 szeletes +Lúdláb;torta;false;4700;8 szeletes +Sacher;torta;false;8200;16 szeletes +Sacher;torta;false;12100;24 szeletes +Sacher;torta;false;4300;8 szeletes +Eszterházy;torta;false;8400;16 szeletes +Eszterházy;torta;false;12200;24 szeletes +Eszterházy;torta;false;4500;8 szeletes +Zalavári gesztenye;tortaszelet;false;600;db +Gesztenyegolyó;vegyes;false;350;db +Pisztáciás-málnás mascarpone;tortaszelet;false;750;db +Habos mákos;vegyes;false;400;db +Franciakrémes;krémes;false;350; +Gesztenye kocka;tejszínes sütemény;false;500;db +Pisztáciás-málnás mascarpone;torta;false;18400;24 szeletes +Pisztáciás-málnás mascarpone;torta;false;6400;8 szeletes +Pisztáciás-málnás mascarpone;torta;false;12400;16 szeletes +Málnás kocka;tejszínes sütemény;false;450;db +Sajttorta (málnás);tortaszelet;false;700;db +Túrókrém gyümölccsel;torta;false;7400;16 szeletes +Túrókrém gyümölccsel;torta;false;3900;8 szeletes +Túrókrém gyümölccsel;torta;false;11400;24 szeletes +Csokis kaland;különleges torta;true;5700;8 szeletes +Somlói;torta;false;5400;8 szeletes +Palermo;torta;false;7400;16 szeletes +Palermo;torta;false;3900;8 szeletes +Palermo;torta;false;11400;24 szeletes +Szilvalekváros;bejgli;false;2100;rúd +Ünnepi diótorta grillázzsal;torta;false;10900;16 szeletes +Ünnepi diótorta grillázzsal;torta;false;5700;8 szeletes +Ünnepi diótorta grillázzsal;torta;false;16200;24 szeletes +Oroszkrém;tortaszelet;false;490;db +Mini zserbó;édes teasütemény;false;4200;kg +Sajtos masni;sós teasütemény;false;4000;kg +Zserbó;pite;false;350;db +Tejszínes gyümölcsös (málna);torta;false;8200;16 szeletes +Tejszínes gyümölcsös (málna);torta;false;4300;8 szeletes +Tejszínes gyümölcsös (málna);torta;false;12100;24 szeletes +Marcipános csokoládé;torta;false;5700;8 szeletes +Marcipános csokoládé;torta;false;16200;24 szeletes +Marcipános csokoládé;torta;false;10900;16 szeletes +Csokis kaland;tortaszelet;false;650;db +Marcipán tekercs;édes teasütemény;false;5200;kg +Képviselőfánk;vegyes;false;500;db +Epres omlett;vegyes;false;600;db +Mini linzer;édes teasütemény;false;3400;kg +Linzerkarika;vegyes;false;300;db +Szedres csokoládé;torta;false;13200;24 szeletes +Szedres csokoládé;torta;false;9000;16 szeletes +Szedres csokoládé;torta;false;4700;8 szeletes +Narancsív;édes teasütemény;false;5200;kg +Gesztenyepüré;vegyes;false;800;20 dkg +Palermo;tejszínes sütemény;false;450;db +Csokis néró;édes teasütemény;false;4200;kg +Flódni;pite;false;400;db +Mézeskalács;torta;false;16200;24 szeletes +Mézeskalács;torta;false;5700;8 szeletes +Mézeskalács;torta;false;10900;16 szeletes +Olívás pogácsa;sós teasütemény;false;3300;kg ​​ +Florentin;édes teasütemény;false;5200;kg +Tiramisu;torta;false;10400;16 szeletes +Tiramisu;torta;false;15400;24 szeletes +Tiramisu;torta;false;5400;8 szeletes +Zoli kedvence (vágott édes tea);édes teasütemény;false;4600;kg +Erdei gyümölcs kocka;tejszínes sütemény;false;450;db +Rákóczi-túrós;tortaszelet;false;400;db +Mézeskrémes;pite;false;330;db +Trüffel;tortaszelet;false;650;db +Szilvás papucs;édes teasütemény;false;4200;kg +Zalavári gesztenye;torta;true;10900;16 szeletes +Zalavári gesztenye;torta;true;5700;8 szeletes +Danubius;torta;false;4300;8 szeletes +Danubius;torta;false;12100;24 szeletes +Danubius;torta;false;8200;16 szeletes +Alpesi karamell;torta;false;12200;24 szeletes +Alpesi karamell;torta;false;8400;16 szeletes +Alpesi karamell;torta;false;4500;8 szeletes +Puncs;torta;false;11400;24 szeletes +Puncs;torta;false;3900;8 szeletes +Puncs;torta;false;7400;16 szeletes +Gesztenye szív;vegyes;false;300;db +Ez+Az (csokoládé és gesztenye);tortaszelet;false;530;db +Tökmagos félhold;sós teasütemény;false;3300;kg +Burgonyás pogácsa;sós teasütemény;false;2900;kg +Somlói galuska;vegyes;false;850;db +Puncs;tortaszelet;false;450;db +Lekváros vágott;édes teasütemény;false;3600;kg +Oreo;torta;false;16200;24 szeletes +Oreo;torta;false;5700;8 szeletes +Oreo;torta;false;10900;16 szeletes +Vintage;torta;false;9900;16 szeletes +Rigó Jancsi;tejszínes sütemény;false;450;db +Feketeerdő;torta;false;9000;16 szeletes +Feketeerdő;torta;false;13200;24 szeletes +Feketeerdő;torta;false;4700;8 szeletes +Kókuszos vágott;édes teasütemény;false;3400;kg +Feketeerdő;tortaszelet;false;530;db +Moscauer;édes teasütemény;false;5200;kg +Diós;bejgli;false;1800;rúd +Rákóczi-túrós;torta;false;3900;8 szeletes +Rákóczi-túrós;torta;false;7400;16 szeletes +Rákóczi-túrós;torta;false;11400;24 szeletes +Három kívánság;különleges torta;false;5700;8 szeletes +Gesztenyés-karamellás;bejgli;false;2100;rúd +Gesztenyés szív;édes teasütemény;false;4400;kg +Ropi;sós teasütemény;false;4000;kg +Paleolit étcsokoládé;különleges torta;false;5300;8 szeletes +Túrós;pite;false;350;db +Ischler;vegyes;false;250;db +Lúdláb;tortaszelet;false;530;db +Csokoládémousse;tortaszelet;false;450;db +Dió;torta;false;4700;8 szeletes +Dió;torta;false;9000;16 szeletes +Dió;torta;false;13200;24 szeletes +Krémes;krémes;false;250;db +Krémes;krémes;false;400;db +Mini ischler;édes teasütemény;false;3400;kg +Paleolit étcsokoládé;tortaszelet;false;600;db +Tejfölös túrós hajtogatott;sós teasütemény;false;4400;kg +Mákos guba;torta;false;4700;8 szeletes diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.dgspec.json new file mode 100644 index 0000000..fe05e7f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj", + "projectName": "2024. 05. 13", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/2024. 05. 13.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfo.cs new file mode 100644 index 0000000..32b45f2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 05. 13")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 05. 13")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 05. 13")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfoInputs.cache new file mode 100644 index 0000000..445193e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +ffe656d5197ba5156abe9d8d9bc9664e831ab0d7 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0dd4bba --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._05._13 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.assets.cache new file mode 100644 index 0000000..cc041a5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..749925b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +14ee8eced02308b2143693e6de721e85a368087b diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..2224e82 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\bin\Debug\net6.0-windows\2024. 05. 13.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\bin\Debug\net6.0-windows\2024. 05. 13.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\bin\Debug\net6.0-windows\2024. 05. 13.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\bin\Debug\net6.0-windows\2024. 05. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\bin\Debug\net6.0-windows\2024. 05. 13.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\_2024._05._13.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\refint\2024. 05. 13.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\2024. 05. 13.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 13\2024. 05. 13\obj\Debug\net6.0-windows\ref\2024. 05. 13.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.GenerateResource.cache new file mode 100644 index 0000000..14f7ea2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.dll new file mode 100644 index 0000000..dd42bf4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.genruntimeconfig.cache new file mode 100644 index 0000000..59b5540 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.genruntimeconfig.cache @@ -0,0 +1 @@ +bb9a24740abe2fee750395704ce35965aa666029 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.pdb new file mode 100644 index 0000000..47ae279 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/2024. 05. 13.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/_2024._05._13.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/_2024._05._13.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/_2024._05._13.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..c204c48 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/ref/2024. 05. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/ref/2024. 05. 13.dll new file mode 100644 index 0000000..d86d986 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/ref/2024. 05. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/refint/2024. 05. 13.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/refint/2024. 05. 13.dll new file mode 100644 index 0000000..d86d986 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/Debug/net6.0-windows/refint/2024. 05. 13.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.assets.json new file mode 100644 index 0000000..db3de44 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj", + "projectName": "2024. 05. 13", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.nuget.cache new file mode 100644 index 0000000..996766f --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 13/2024. 05. 13/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "Na3+bQgHEr6UNXroq3yUjZYdh5vruA/SHLv/fH4H54STaLiEu8Lngp03PS74yLKCbimLer4YxAq29gWoB3Zetg==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 13\\2024. 05. 13\\2024. 05. 13.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..fab7acc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/c6a10b6c-b9de-47f1-9ee2-a0ad3d6189ba.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/c6a10b6c-b9de-47f1-9ee2-a0ad3d6189ba.vsidx new file mode 100644 index 0000000..17ef6ef Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/c6a10b6c-b9de-47f1-9ee2-a0ad3d6189ba.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/f80231ed-019a-4750-9b1d-434491c896b7.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/f80231ed-019a-4750-9b1d-434491c896b7.vsidx new file mode 100644 index 0000000..98547bc Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/FileContentIndex/f80231ed-019a-4750-9b1d-434491c896b7.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.futdcache.v2 new file mode 100644 index 0000000..5558022 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.suo new file mode 100644 index 0000000..a96a47b Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/2024. 05. 27/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.metadata.v7.bin new file mode 100644 index 0000000..70f19b9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.projects.v7.bin new file mode 100644 index 0000000..4961e86 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/.vs/ProjectEvaluation/2024. 05. 27.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27.sln new file mode 100644 index 0000000..e6ff482 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 05. 27", "2024. 05. 27\2024. 05. 27.csproj", "{A8B55DCB-919D-4827-AA23-97B2B4F10B73}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A8B55DCB-919D-4827-AA23-97B2B4F10B73}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A8B55DCB-919D-4827-AA23-97B2B4F10B73}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A8B55DCB-919D-4827-AA23-97B2B4F10B73}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A8B55DCB-919D-4827-AA23-97B2B4F10B73}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {E42D8C9D-C447-48AE-9488-58D1C6B56109} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj new file mode 100644 index 0000000..71f0847 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._05._27 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/2024. 05. 27.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.Designer.cs new file mode 100644 index 0000000..3a849cb --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.Designer.cs @@ -0,0 +1,266 @@ +namespace _2024._05._27 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + label1 = new Label(); + label2 = new Label(); + label3 = new Label(); + label4 = new Label(); + label5 = new Label(); + label6 = new Label(); + label7 = new Label(); + OscarAwardFilmsListBox = new ListBox(); + NameTextBox = new TextBox(); + textBox2 = new TextBox(); + listBox2 = new ListBox(); + YearTextBox = new TextBox(); + JelolesekTextBox = new TextBox(); + AwardTextBox = new TextBox(); + NewFilmButton = new Button(); + MostAwardFilmButton = new Button(); + textBox6 = new TextBox(); + SearhButton = new Button(); + ListButton = new Button(); + SuspendLayout(); + // + // label1 + // + label1.AutoSize = true; + label1.Location = new Point(31, 41); + label1.Name = "label1"; + label1.Size = new Size(126, 20); + label1.TabIndex = 0; + label1.Text = "Oscar díjas filmek"; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(341, 41); + label2.Name = "label2"; + label2.Size = new Size(43, 20); + label2.TabIndex = 1; + label2.Text = "Címe"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(341, 100); + label3.Name = "label3"; + label3.Size = new Size(24, 20); + label3.TabIndex = 2; + label3.Text = "Év"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(341, 170); + label4.Name = "label4"; + label4.Size = new Size(114, 20); + label4.TabIndex = 3; + label4.Text = "Jelölések száma"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(341, 248); + label5.Name = "label5"; + label5.Size = new Size(89, 20); + label5.TabIndex = 4; + label5.Text = "Díjak száma"; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(341, 405); + label6.Name = "label6"; + label6.Size = new Size(76, 20); + label6.TabIndex = 5; + label6.Text = "Film címe:"; + // + // label7 + // + label7.AutoSize = true; + label7.Location = new Point(341, 547); + label7.Name = "label7"; + label7.Size = new Size(98, 20); + label7.TabIndex = 6; + label7.Text = "Találat kiírása"; + // + // OscarAwardFilmsListBox + // + OscarAwardFilmsListBox.FormattingEnabled = true; + OscarAwardFilmsListBox.ItemHeight = 20; + OscarAwardFilmsListBox.Location = new Point(31, 83); + OscarAwardFilmsListBox.Name = "OscarAwardFilmsListBox"; + OscarAwardFilmsListBox.Size = new Size(254, 484); + OscarAwardFilmsListBox.TabIndex = 7; + // + // NameTextBox + // + NameTextBox.Location = new Point(496, 34); + NameTextBox.Name = "NameTextBox"; + NameTextBox.Size = new Size(268, 27); + NameTextBox.TabIndex = 8; + // + // textBox2 + // + textBox2.Location = new Point(839, 34); + textBox2.Name = "textBox2"; + textBox2.Size = new Size(223, 27); + textBox2.TabIndex = 9; + // + // listBox2 + // + listBox2.FormattingEnabled = true; + listBox2.ItemHeight = 20; + listBox2.Location = new Point(839, 100); + listBox2.Name = "listBox2"; + listBox2.Size = new Size(223, 424); + listBox2.TabIndex = 10; + // + // YearTextBox + // + YearTextBox.Location = new Point(496, 100); + YearTextBox.Name = "YearTextBox"; + YearTextBox.Size = new Size(268, 27); + YearTextBox.TabIndex = 11; + // + // JelolesekTextBox + // + JelolesekTextBox.Location = new Point(496, 167); + JelolesekTextBox.Name = "JelolesekTextBox"; + JelolesekTextBox.Size = new Size(268, 27); + JelolesekTextBox.TabIndex = 12; + // + // AwardTextBox + // + AwardTextBox.Location = new Point(496, 248); + AwardTextBox.Name = "AwardTextBox"; + AwardTextBox.Size = new Size(268, 27); + AwardTextBox.TabIndex = 13; + // + // NewFilmButton + // + NewFilmButton.Location = new Point(341, 312); + NewFilmButton.Name = "NewFilmButton"; + NewFilmButton.Size = new Size(423, 46); + NewFilmButton.TabIndex = 14; + NewFilmButton.Text = "Új film felvétele"; + NewFilmButton.UseVisualStyleBackColor = true; + NewFilmButton.Click += NewFilmButton_Click; + // + // MostAwardFilmButton + // + MostAwardFilmButton.Location = new Point(582, 399); + MostAwardFilmButton.Name = "MostAwardFilmButton"; + MostAwardFilmButton.Size = new Size(182, 36); + MostAwardFilmButton.TabIndex = 15; + MostAwardFilmButton.Text = "Legtöbb díjat kapta"; + MostAwardFilmButton.UseVisualStyleBackColor = true; + MostAwardFilmButton.Click += MostAwardFilmButton_Click; + // + // textBox6 + // + textBox6.Location = new Point(341, 474); + textBox6.Name = "textBox6"; + textBox6.Size = new Size(234, 27); + textBox6.TabIndex = 16; + // + // SearhButton + // + SearhButton.Location = new Point(649, 472); + SearhButton.Name = "SearhButton"; + SearhButton.Size = new Size(94, 29); + SearhButton.TabIndex = 17; + SearhButton.Text = "Keres"; + SearhButton.UseVisualStyleBackColor = true; + // + // ListButton + // + ListButton.Location = new Point(910, 547); + ListButton.Name = "ListButton"; + ListButton.Size = new Size(94, 29); + ListButton.TabIndex = 18; + ListButton.Text = "Listázz"; + ListButton.UseVisualStyleBackColor = true; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(1085, 610); + Controls.Add(ListButton); + Controls.Add(SearhButton); + Controls.Add(textBox6); + Controls.Add(MostAwardFilmButton); + Controls.Add(NewFilmButton); + Controls.Add(AwardTextBox); + Controls.Add(JelolesekTextBox); + Controls.Add(YearTextBox); + Controls.Add(listBox2); + Controls.Add(textBox2); + Controls.Add(NameTextBox); + Controls.Add(OscarAwardFilmsListBox); + Controls.Add(label7); + Controls.Add(label6); + Controls.Add(label5); + Controls.Add(label4); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(label1); + Name = "Form1"; + Text = "Form1"; + Load += Form1_Load; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label label1; + private Label label2; + private Label label3; + private Label label4; + private Label label5; + private Label label6; + private Label label7; + private ListBox OscarAwardFilmsListBox; + private TextBox NameTextBox; + private TextBox textBox2; + private ListBox listBox2; + private TextBox YearTextBox; + private TextBox JelolesekTextBox; + private TextBox AwardTextBox; + private Button NewFilmButton; + private Button MostAwardFilmButton; + private TextBox textBox6; + private Button SearhButton; + private Button ListButton; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.cs new file mode 100644 index 0000000..e182334 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.cs @@ -0,0 +1,70 @@ +namespace _2024._05._27 +{ + public partial class Form1 : Form + { + private List list = new List(); + public Form1() + { + InitializeComponent(); + } + + private void Form1_Load(object sender, EventArgs e) + { + List listABC = new List(); + StreamReader sr = new StreamReader("oscar.csv"); + string line = sr.ReadLine(); + + while (line != null) + { + list.Add(line); + listABC.Add(line.Split(";")[1]); + + line = sr.ReadLine(); + } + + sr.Close(); + + listABC.Sort(); + + foreach (var i in listABC) + { + OscarAwardFilmsListBox.Items.Add(i); + } + } + + private async void NewFilmButton_Click(object sender, EventArgs e) + { + try + { + string name = NameTextBox.Text; + int year = int.Parse(YearTextBox.Text); + int jeloles = int.Parse(JelolesekTextBox.Text); + int award = int.Parse(AwardTextBox.Text); + + using (StreamWriter w = File.AppendText("oscar.csv")) + { + w.WriteLine($"{name};{year};{award};{jeloles}"); + } + + OscarAwardFilmsListBox.Items.Add(name); + list.Add($"{name};{year};{award};{jeloles}"); + } + + catch + { + MessageBox.Show("Valamelyik adat hibs!"); + } + } + + private void MostAwardFilmButton_Click(object sender, EventArgs e) + { + Dictionary award = new Dictionary(); + + foreach (var i in list) + { + string[] currrentLine = i.Split(";"); + award.Add(currrentLine[1], int.Parse(currrentLine[3])); + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Program.cs new file mode 100644 index 0000000..62259e2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._05._27 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.deps.json new file mode 100644 index 0000000..861fa46 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 05. 27/1.0.0": { + "runtime": { + "2024. 05. 27.dll": {} + } + } + } + }, + "libraries": { + "2024. 05. 27/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.dll new file mode 100644 index 0000000..c49fd15 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.exe new file mode 100644 index 0000000..a200525 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.pdb new file mode 100644 index 0000000..15a8ce9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/2024. 05. 27.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/oscar.csv b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/oscar.csv new file mode 100644 index 0000000..9ba515a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/bin/Debug/net6.0-windows/oscar.csv @@ -0,0 +1,182 @@ +azon;cim;ev;dij;jelol +Ark81;Raiders of the Lost Ark;1981;4;8 +Day91;Terminator 2: Judgment Day;1991;4;6 +End92;Howards End;1992;3;9 +Kid69;Butch Cassidy and the Sundance Kid;1969;4;7 +Man88;Rain Man;1988;4;8 +Men07;No Country for Old Men;2007;4;8 +Men49;All the King's Men;1949;3;7 +Men76;All the President's Men;1976;4;8 +War02;The Fog of War;2002;6;13 +Way44;Going My Way;1944;7;10 +Won63;How the West Was Won;1963;3;8 +abia62;Lawrence of Arabia;1962;7;10 +acus60;Spartacus;1960;4;6 +adre48;The Treasure of the Sierra Madre;1948;3;4 +agon00;Crouching Tiger, Hidden Dragon;2000;4;10 +aire08;Slumdog Millionaire;2008;8;10 +aisy89;Driving Miss Daisy;1989;4;9 +ambs91;The Silence of the Lambs;1991;5;7 +amer79;Kramer vs. Kramer;1979;5;9 +anca43;Casablanca;1943;3;8 +andy42;Yankee Doodle Dandy;1942;3;8 +anic97;Titanic;1997;11;14 +aret72;Cabaret;1972;8;10 +Argo12;Argo;2012;3;7 +aris51;An American in Paris;1951;6;8 +arty55;Marty;1955;4;8 +atar09;Avatar;2009;3;9 +ator00;Gladiator;2000;5;12 +ator04;The Aviator;2004;5;11 +atra63;Cleopatra;1963;4;9 +atum07;The Bourne Ultimatum;2007;3;3 +auty99;American Beauty;1999;5;8 +aven27;7th Heaven;1927;3;5 +Baby04;Million Dollar Baby;2004;4;7 +bbit88;Who Framed Roger Rabbit;1988;3;6 +bird62;To Kill a Mockingbird;1962;3;8 +bles12;Les Mis‚rables;2012;3;8 +cade33;Cavalcade;1933;3;4 +cago02;Chicago;2002;6;13 +cker09;The Hurt Locker;2009;6;9 +Club13;Dallas Buyers Club;2013;3;6 +cula92;Bram Stoker's Dracula;1992;3;4 +Days56;Around the World in Eighty Days;1956;5;8 +der 83;Fanny & Alexander ;1983;4;6 +deus84;Amadeus;1984;8;11 +dman14;Birdman;2014;4;9 +eart95;Braveheart;1995;5;10 +eech10;The King's Speech;2010;4;12 +elds84;The Killing Fields;1984;3;7 +elot67;Camelot;1967;3;5 +erno74;The Towering Inferno;1974;3;8 +eror87;The Last Emperor;1987;9;9 +erse36;Anthony Adverse;1936;4;7 +ette43;The Song of Bernadette;1943;4;12 +Eve50;All About Eve;1950;6;14 +f Pi12;Life of Pi;2012;4;11 +feld36;The Great Ziegfeld;1936;3;7 +ffic00;Traffic;2000;4;5 +Fire81;Chariots of Fire;1981;4;7 +ful 98;Life Is Beautiful ;1998;3;7 +gdad40;The Thief of Bagdad;1940;3;4 +Gigi58;Gigi;1958;9;9 +Gump94;Forrest Gump;1994;6;13 +Hall77;Annie Hall;1977;4;5 +hing55;Love Is a Many-Splendored Thing;1955;3;8 +Home78;Coming Home;1978;3;8 +Hood38;The Adventures of Robin Hood;1938;3;4 +Hud63;Hud;1963;3;7 +Hugo11;Hugo;2011;5;11 +Hur59;Ben-Hur;1959;11;12 +iano93;The Piano;1993;3;8 +iday53;Roman Holiday;1953;3;10 +ient96;The English Patient;1996;9;12 +iful52;The Bad and the Beautiful;1952;5;6 +ight16;Moonlight;2016;3;8 +ight34;It Happened One Night;1934;5;5 +ight67;In the Heat of the Night;1967;5;7 +inth06;Pan's Labyrinth;2006;3;6 +isha05;Memoirs of a Geisha;2005;3;6 +iven92;Unforgiven;1992;4;9 +iver42;Mrs. Miniver;1942;6;12 +ives46;The Best Years of Our Lives;1946;7;8 +Jaws75;Jaws;1975;3;4 +Jazz79;All That Jazz;1979;4;9 +kend45;The Lost Weekend;1945;4;7 +King03;The Lord of the Rings: The Return of the King;2003;11;11 +Kong05;King Kong;2005;3;4 +Kwai57;The Bridge on the River Kwai;1957;7;8 +Lady64;My Fair Lady;1964;8;12 +Land16;La La Land;2016;6;14 +lash14;Whiplash;2014;3;5 +lave13;12 Years a Slave;2013;3;9 +ling65;Darling;1965;3;5 +List93;Schindler's List;1993;7;12 +lley41;How Green Was My Valley;1941;5;10 +lory89;Glory;1989;3;5 +Love98;Shakespeare in Love;1998;7;13 +lson44;Wilson;1944;5;10 +lves90;Dances with Wolves;1990;7;12 +lly!69;Hello, Dolly!;1969;3;7 +ment47;Gentleman's Agreement;1947;3;8 +ment60;The Apartment;1960;5;10 +ment83;Terms of Endearment;1983;5;11 +Mind01;A Beautiful Mind;2001;4;8 +mlet48;Hamlet;1948;4;7 +nant15;The Revenant;2015;3;12 +nara57;Sayonara;1957;4;10 +nd I56;The King and I;1956;5;9 +ndhi82;Gandhi;1982;8;11 +ndon75;Barry Lyndon;1975;4;7 +Nest75;One Flew over the Cuckoo's Nest;1975;5;9 +nist02;The Pianist;2002;3;7 +nity53;From Here to Eternity;1953;8;13 +Noon52;High Noon;1952;4;7 +nter68;The Lion in Winter;1968;3;7 +nter78;The Deer Hunter;1978;5;9 +ntry60;Elmer Gantry;1960;3;5 +ocky76;Rocky;1976;3;10 +olf?66;Who's Afraid of Virginia Woolf?;1966;5;13 +ones63;Tom Jones;1963;4;10 +ople80;Ordinary People;1980;4;6 +otel14;The Grand Budapest Hotel;2014;4;9 +Park93;Jurassic Park;1993;3;3 +pins64;Mary Poppins;1964;5;13 +Pond81;On Golden Pond;1981;3;10 +Prix66;Grand Prix;1966;3;3 +racy90;Dick Tracy;1990;3;7 +rank59;The Diary of Anne Frank;1959;3;8 +rash05;Crash;2005;3;6 +Reds81;Reds;1981;3;12 +reek64;Zorba the Greek;1964;3;7 +reet47;Miracle on 34th Street;1947;3;4 +ress49;The Heiress;1949;4;8 +rial82;E.T.: The Extra-Terrestrial;1982;4;9 +rica85;Out of Africa;1985;7;11 +Ring01;The Lord of the Rings: The Fellowship of the Ring;2001;4;13 +rise27;Sunrise;1927;3;4 +rmer35;The Informer;1935;4;6 +Road15;Mad Max: Fury Road;2015;6;10 +ront54;On the Waterfront;1954;8;12 +Roof71;Fiddler on the Roof;1971;3;8 +rron31;Cimarron;1931;3;7 +rted06;The Departed;2006;4;5 +ruck87;Moonstruck;1987;3;6 +Ryan98;Saving Private Ryan;1998;5;11 +sire51;A Streetcar Named Desire;1951;4;12 +sons66;A Man for All Seasons;1966;6;8 +sons88;Dangerous Liaisons;1988;3;7 +Sun51;A Place in the Sun;1951;6;9 +t II74;The Godfather Part II;1974;6;11 +tain05;Brokeback Mountain;2005;3;8 +ters86;Hannah and Her Sisters;1986;3;7 +Tess80;Tess;1980;3;6 +teur36;The Story of Louis Pasteur;1936;3;4 +ther72;The Godfather;1972;3;10 +ting73;The Sting;1973;7;10 +tion10;Inception;2010;4;8 +tion71;The French Connection;1971;5;8 +tist11;The Artist;2011;5;10 +toon86;Platoon;1986;4;8 +tory61;West Side Story;1961;10;11 +trix99;The Matrix;1999;4;4 +tton08;The Curious Case of Benjamin Button;2008;3;13 +tton70;Patton;1970;7;10 +ttoo55;The Rose Tattoo;1955;3;8 +tuff83;The Right Stuff;1983;4;8 +ulia77;Julia;1977;3;11 +usic65;The Sound of Music;1965;5;10 +vago65;Doctor Zhivago;1965;5;10 +vard50;Sunset Boulevard;1950;3;11 +ver!68;Oliver!;1968;5;11 +View86;A Room with a View;1986;3;8 +vity13;Gravity;2013;7;10 +Wars77;Star Wars;1977;6;10 +wboy69;Midnight Cowboy;1969;3;7 +Wind39;Gone with the Wind;1939;8;13 +work10;The Social Network;2010;3;8 +work76;Network;1976;4;10 +Zola37;The Life of Emile Zola;1937;3;10 +9699;Avatar;2020;5;5 +Sorok ura;2021;2;1 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.dgspec.json new file mode 100644 index 0000000..b19c4cf --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj", + "projectName": "2024. 05. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/2024. 05. 27.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfo.cs new file mode 100644 index 0000000..d2d9e81 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 05. 27")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 05. 27")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 05. 27")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfoInputs.cache new file mode 100644 index 0000000..dc30108 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +bc2d7d4e92672b9077516c82738d7253c4ca3da0 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..6675508 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._05._27 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.assets.cache new file mode 100644 index 0000000..860f6f2 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..fb6c69a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +edeeac2e842a2fe2ae05d71b277a973187455234 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..81a19c6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\bin\Debug\net6.0-windows\2024. 05. 27.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\bin\Debug\net6.0-windows\2024. 05. 27.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\bin\Debug\net6.0-windows\2024. 05. 27.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\bin\Debug\net6.0-windows\2024. 05. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\bin\Debug\net6.0-windows\2024. 05. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\_2024._05._27.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\refint\2024. 05. 27.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\2024. 05. 27.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 05. 27\2024. 05. 27\obj\Debug\net6.0-windows\ref\2024. 05. 27.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.GenerateResource.cache new file mode 100644 index 0000000..673ce41 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.dll new file mode 100644 index 0000000..c49fd15 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.genruntimeconfig.cache new file mode 100644 index 0000000..56c1890 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.genruntimeconfig.cache @@ -0,0 +1 @@ +1ff9b343c58985a14a4df1a7564a4d703ce14b64 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.pdb new file mode 100644 index 0000000..15a8ce9 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/2024. 05. 27.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/_2024._05._27.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/_2024._05._27.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/_2024._05._27.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..a200525 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/ref/2024. 05. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/ref/2024. 05. 27.dll new file mode 100644 index 0000000..2a39073 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/ref/2024. 05. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/refint/2024. 05. 27.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/refint/2024. 05. 27.dll new file mode 100644 index 0000000..2a39073 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/Debug/net6.0-windows/refint/2024. 05. 27.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.assets.json new file mode 100644 index 0000000..072ae24 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj", + "projectName": "2024. 05. 27", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.nuget.cache new file mode 100644 index 0000000..b4df46a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 05. 27/2024. 05. 27/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "8DiNcxGFxP4yORvTEBB4wDxawUaLw5e2PZU/TP01aktAId8CCii7HVnaGTE3byYQowyTpM13z1hfmQi4xhHUNw==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 05. 27\\2024. 05. 27\\2024. 05. 27.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/DesignTimeBuild/.dtbcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..abcba44 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/306753a5-088d-4518-be51-27c657c260d3.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/306753a5-088d-4518-be51-27c657c260d3.vsidx new file mode 100644 index 0000000..11c5d28 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/306753a5-088d-4518-be51-27c657c260d3.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/a829110f-a951-46aa-b126-f9c844eb5dcc.vsidx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/a829110f-a951-46aa-b126-f9c844eb5dcc.vsidx new file mode 100644 index 0000000..2470525 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/FileContentIndex/a829110f-a951-46aa-b126-f9c844eb5dcc.vsidx differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.futdcache.v2 b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.futdcache.v2 new file mode 100644 index 0000000..9fdfb7a Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.futdcache.v2 differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.suo b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.suo new file mode 100644 index 0000000..cb76ec4 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/2024. 06. 03/v17/.suo differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.metadata.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.metadata.v7.bin new file mode 100644 index 0000000..9d6da7f Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.metadata.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.projects.v7.bin b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.projects.v7.bin new file mode 100644 index 0000000..31552f0 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/.vs/ProjectEvaluation/2024. 06. 03.projects.v7.bin differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03.sln b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03.sln new file mode 100644 index 0000000..29263ac --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 06. 03", "2024. 06. 03\2024. 06. 03.csproj", "{E7EF7A0E-9F5A-48DD-9675-FABC8EA07803}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {E7EF7A0E-9F5A-48DD-9675-FABC8EA07803}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E7EF7A0E-9F5A-48DD-9675-FABC8EA07803}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E7EF7A0E-9F5A-48DD-9675-FABC8EA07803}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E7EF7A0E-9F5A-48DD-9675-FABC8EA07803}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {B46A7B0F-3E69-4DE8-B2F8-457132EAFA19} + EndGlobalSection +EndGlobal diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj new file mode 100644 index 0000000..20b866d --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._06._03 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj.user b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/2024. 06. 03.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.Designer.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.Designer.cs new file mode 100644 index 0000000..65b776c --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.Designer.cs @@ -0,0 +1,195 @@ +namespace _2024._06._03 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + label1 = new Label(); + label2 = new Label(); + label3 = new Label(); + label4 = new Label(); + label5 = new Label(); + NameTextBox = new TextBox(); + MissedLessonTextBox = new TextBox(); + LastDayTextBox = new TextBox(); + FirstDayTextBox = new TextBox(); + ClassTextBox = new TextBox(); + DoneButton = new Button(); + ListBox = new ListBox(); + label6 = new Label(); + SuspendLayout(); + // + // label1 + // + label1.AutoSize = true; + label1.Location = new Point(51, 72); + label1.Name = "label1"; + label1.Size = new Size(35, 20); + label1.TabIndex = 0; + label1.Text = "Név"; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(51, 135); + label2.Name = "label2"; + label2.Size = new Size(57, 20); + label2.TabIndex = 1; + label2.Text = "Osztály"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(51, 196); + label3.Name = "label3"; + label3.Size = new Size(65, 20); + label3.TabIndex = 2; + label3.Text = "Első nap"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(51, 260); + label4.Name = "label4"; + label4.Size = new Size(81, 20); + label4.TabIndex = 3; + label4.Text = "Utolsó nap"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(51, 319); + label5.Name = "label5"; + label5.Size = new Size(112, 20); + label5.TabIndex = 4; + label5.Text = "Mulasztott órák"; + // + // NameTextBox + // + NameTextBox.Location = new Point(203, 65); + NameTextBox.Name = "NameTextBox"; + NameTextBox.Size = new Size(298, 27); + NameTextBox.TabIndex = 5; + // + // MissedLessonTextBox + // + MissedLessonTextBox.Location = new Point(203, 316); + MissedLessonTextBox.Name = "MissedLessonTextBox"; + MissedLessonTextBox.Size = new Size(298, 27); + MissedLessonTextBox.TabIndex = 6; + // + // LastDayTextBox + // + LastDayTextBox.Location = new Point(203, 253); + LastDayTextBox.Name = "LastDayTextBox"; + LastDayTextBox.Size = new Size(298, 27); + LastDayTextBox.TabIndex = 7; + // + // FirstDayTextBox + // + FirstDayTextBox.Location = new Point(203, 189); + FirstDayTextBox.Name = "FirstDayTextBox"; + FirstDayTextBox.Size = new Size(298, 27); + FirstDayTextBox.TabIndex = 8; + // + // ClassTextBox + // + ClassTextBox.Location = new Point(203, 128); + ClassTextBox.Name = "ClassTextBox"; + ClassTextBox.Size = new Size(298, 27); + ClassTextBox.TabIndex = 9; + // + // DoneButton + // + DoneButton.Location = new Point(203, 410); + DoneButton.Name = "DoneButton"; + DoneButton.Size = new Size(298, 41); + DoneButton.TabIndex = 10; + DoneButton.Text = "Hiányzás rögzítése a szeptember.csv-be"; + DoneButton.UseVisualStyleBackColor = true; + DoneButton.Click += DoneButton_Click; + // + // ListBox + // + ListBox.FormattingEnabled = true; + ListBox.ItemHeight = 20; + ListBox.Location = new Point(616, 89); + ListBox.Name = "ListBox"; + ListBox.Size = new Size(545, 484); + ListBox.TabIndex = 11; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(616, 43); + label6.Name = "label6"; + label6.Size = new Size(246, 20); + label6.TabIndex = 12; + label6.Text = "2017 szeptemberi hiányzások listája"; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(1213, 616); + Controls.Add(label6); + Controls.Add(ListBox); + Controls.Add(DoneButton); + Controls.Add(ClassTextBox); + Controls.Add(FirstDayTextBox); + Controls.Add(LastDayTextBox); + Controls.Add(MissedLessonTextBox); + Controls.Add(NameTextBox); + Controls.Add(label5); + Controls.Add(label4); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(label1); + Name = "Form1"; + Text = "Form1"; + Load += Form1_Load; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label label1; + private Label label2; + private Label label3; + private Label label4; + private Label label5; + private TextBox NameTextBox; + private TextBox MissedLessonTextBox; + private TextBox LastDayTextBox; + private TextBox FirstDayTextBox; + private TextBox ClassTextBox; + private Button DoneButton; + private ListBox ListBox; + private Label label6; + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.cs new file mode 100644 index 0000000..61780e3 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.cs @@ -0,0 +1,75 @@ +using System.Diagnostics.Eventing.Reader; + +namespace _2024._06._03 +{ + public partial class Form1 : Form + { + List list = new List(); + public Form1() + { + InitializeComponent(); + } + + private void Form1_Load(object sender, EventArgs e) + { + StreamReader sr = new StreamReader("szeptember.csv"); + string line = sr.ReadLine(); + + while (line != null) + { + list.Add(line); + line = sr.ReadLine(); + } + + sr.Close(); + + foreach (var i in list) + { + string[] currentLine = i.Split(";"); + ListBox.Items.Add($"{currentLine[0]} {currentLine[1]} {currentLine[2]} {currentLine[3]} {currentLine[4]}"); + } + } + + private void DoneButton_Click(object sender, EventArgs e) + { + if (NameTextBox.Text.Equals("") || ClassTextBox.Text.Equals("") || FirstDayTextBox.Text.Equals("") || LastDayTextBox.Text.Equals("") || MissedLessonTextBox.Text.Equals("")) + { + MessageBox.Show("Minden mezt ki kell tlteni"); + } + + try + { + int firstDay = Convert.ToInt32(FirstDayTextBox.Text); + int lastDay = Convert.ToInt32(LastDayTextBox.Text); + int missedLesson = Convert.ToInt32(MissedLessonTextBox.Text); + + if (firstDay > 30 || lastDay > 30) + { + MessageBox.Show("Hibs adat! Csak 1 s 30 kztti rtk lehet"); + } + + else if (firstDay > lastDay) + { + MessageBox.Show("Az utols nap nagyobb legyen, mint az els nap"); + } + + else + { + using (StreamWriter sw = File.AppendText("szeptember.csv")) + { + sw.WriteLine($"{NameTextBox.Text};{ClassTextBox.Text};{firstDay};{lastDay};{missedLesson}"); + } + + MessageBox.Show("Az llomny bvtse sikeres volt!", "zenet"); + } + } + + catch + { + MessageBox.Show("Nem szmot adtl meg"); + } + + + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.resx b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Program.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Program.cs new file mode 100644 index 0000000..6fa049e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._06._03 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.deps.json new file mode 100644 index 0000000..e12f0c6 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 06. 03/1.0.0": { + "runtime": { + "2024. 06. 03.dll": {} + } + } + } + }, + "libraries": { + "2024. 06. 03/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.dll new file mode 100644 index 0000000..a67e171 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.exe new file mode 100644 index 0000000..0ba48df Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.pdb new file mode 100644 index 0000000..79e53a3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/2024. 06. 03.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/szeptember.csv b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/szeptember.csv new file mode 100644 index 0000000..b6fa218 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/bin/Debug/net6.0-windows/szeptember.csv @@ -0,0 +1,101 @@ +Név;Osztály;Első nap;Utolsó nap;Mulasztott órák +Balogh Péter;6a;1;1;5 +Horváth Judit;5a;1;1;5 +Juhász János;6a;1;1;5 +Lengyel Krisztina;6b;1;1;6 +Török Béla;3b;1;1;6 +László Péter;4b;1;1;6 +Török Béla;3b;4;4;6 +László Péter;4b;4;4;5 +Magyar Nóra;8a;4;4;6 +Nagy András;5b;4;4;5 +Gyüre István;8b;5;5;6 +Kiss Tamás;3b;5;5;5 +Nagy Eszter;5b;5;5;6 +Tóth Ádám;7b;5;5;5 +Arnóczki István;4a;6;6;6 +Gyüre István;8b;6;6;6 +Kiss Tamás;3b;6;6;5 +Szabó Dalma;7a;6;6;6 +Bakajsza Ferenc;3a;7;7;6 +Lippai Tibor;3b;7;7;5 +Tóth Tibor;4b;7;7;5 +Balogh József;8a;8;8;5 +Barabás Attila;8b;8;8;7 +Hamza Dezső;1a;8;8;5 +Szilágyi Tibor;8b;8;8;5 +Fehér Virág;1a;11;11;6 +Kis Katalin;8a;11;11;7 +Kovács Imre;2a;11;11;6 +Novák Sándor;1b;11;11;5 +Tirpák Ferenc;2b;11;11;5 +Arnóczki István;4a;12;12;6 +Bakajsza Ferenc;3a;12;12;6 +Lippai Tibor;3b;12;12;5 +Nagy Emese;5a;12;12;6 +Tóth Tibor;4b;12;12;5 +Magyari Ildikó;6b;14;14;5 +Sajtos Enikő;6a;14;14;6 +Soltész Anna;5b;14;14;5 +Bodnár Tímea;6a;15;15;6 +Csimbók Ernő;7b;15;15;5 +Kropkó Áron;7a;15;15;5 +Németh Anna;8a;15;15;7 +Balogh József;8a;18;18;5 +Barabás Attila;8b;18;18;7 +Hamza Dezső;1a;18;18;4 +Horváth Gergely;1b;18;18;5 +Szilágyi Tibor;8b;18;18;5 +Fekete Viktória;3a;19;19;5 +Fekete Zsolt;4a;19;19;5 +Fodor Éva;4a;19;19;6 +Hegedűs Andrea;6b;19;19;6 +Katona Ágnes;7b;19;19;7 +Lukács Eszter;5a;19;19;5 +Nagy Mihály;6b;19;19;6 +Pintér Ferenc;3a;19;19;5 +Szilágyi Ildikó;3a;19;19;6 +Török Viktória;6a;19;19;5 +Lengyel Krisztina;6b;20;20;5 +Nagy Emese;5a;20;20;5 +Soltész Anna;5b;20;20;6 +Barabás Attila;8b;21;21;5 +Barna Mátyás;8b;21;21;6 +Szilágyi Ildikó;3a;21;21;5 +Barna Mátyás;8b;22;22;7 +Bogdán Anna;5b;22;22;6 +Márta Ádám;8b;22;22;6 +Somogyi Dániel;5a;22;22;5 +Balla Rajmund;2b;25;25;5 +Budai Csab;6b;25;25;6 +Molnár Hanna;4a;25;25;6 +Németh Gergely;7a;25;25;7 +Novák Donát;5a;25;25;5 +Soós Csenge;4a;25;25;6 +Szilágyi Tibor;8b;25;25;5 +Balla Rajmund;2b;26;26;5 +Katona Ágnes;7b;26;26;5 +Kis Katalin;8a;26;26;6 +Lakatos Viktória;3a;26;26;6 +Szilágyi Ildikó;3a;26;26;5 +Török Viktória;6a;26;26;5 +Vörös Ágnes;4b;26;26;5 +Balla Rajmund;2b;27;27;4 +Borbély Csaba;2b;27;27;5 +Farkas Nándor;6a;27;27;6 +Fekete Noel;3a;27;27;5 +Halász Jakab;3b;27;27;6 +Kelemen Béla;4a;27;27;6 +Kozma Viktor;5a;27;27;5 +Molnár Hanna;4a;27;27;6 +Tamás Klaudia;4b;27;27;5 +Dobos Benedek;8a;28;28;6 +Gulyás Veronika;4b;28;28;5 +Katona Ágnes;7b;28;28;6 +Márton Blanka;8b;28;28;5 +Miksa Fruzsina;2b;28;28;5 +Szekeres Márió;2b;28;28;4 +Kocsis Panna;7a;29;29;5 +Molnár Hanna;4a;29;29;5 +Szilágyi Ildikó;3a;29;29;5 +Török Adél;2a;29;29;6 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.dgspec.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.dgspec.json new file mode 100644 index 0000000..f98e08a --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj": {} + }, + "projects": { + "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj", + "projectName": "2024. 06. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.props b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.targets b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/2024. 06. 03.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfo.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfo.cs new file mode 100644 index 0000000..4bcfe8e --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 06. 03")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 06. 03")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 06. 03")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfoInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfoInputs.cache new file mode 100644 index 0000000..548a94b --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +879d58cb9e29524751e794c07900e48dc6283f96 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GeneratedMSBuildEditorConfig.editorconfig b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..e55cc72 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._06._03 +build_property.ProjectDir = E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GlobalUsings.g.cs b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.assets.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.assets.cache new file mode 100644 index 0000000..03a5b83 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.assets.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.BuildWithSkipAnalyzers b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.CoreCompileInputs.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..d617283 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +c5d5ed310262bdfa74b0b382136b225006b9b29f diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.FileListAbsolute.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..a7faccc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\bin\Debug\net6.0-windows\2024. 06. 03.exe +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\bin\Debug\net6.0-windows\2024. 06. 03.deps.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\bin\Debug\net6.0-windows\2024. 06. 03.runtimeconfig.json +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\bin\Debug\net6.0-windows\2024. 06. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\bin\Debug\net6.0-windows\2024. 06. 03.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\_2024._06._03.Form1.resources +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.csproj.GenerateResource.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.AssemblyInfoInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.AssemblyInfo.cs +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.csproj.CoreCompileInputs.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\refint\2024. 06. 03.dll +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.pdb +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\2024. 06. 03.genruntimeconfig.cache +E:\Suli\12.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 06. 03\2024. 06. 03\obj\Debug\net6.0-windows\ref\2024. 06. 03.dll diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.GenerateResource.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.GenerateResource.cache new file mode 100644 index 0000000..2125ae7 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.csproj.GenerateResource.cache differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.deps.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.runtimeconfig.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.dll new file mode 100644 index 0000000..a67e171 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.genruntimeconfig.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.genruntimeconfig.cache new file mode 100644 index 0000000..30034dc --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.genruntimeconfig.cache @@ -0,0 +1 @@ +b61a3ad257459f2098d6a838123c2a9df90f328c diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.pdb b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.pdb new file mode 100644 index 0000000..79e53a3 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/2024. 06. 03.pdb differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/_2024._06._03.Form1.resources b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/_2024._06._03.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/_2024._06._03.Form1.resources differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/apphost.exe b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..0ba48df Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/ref/2024. 06. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/ref/2024. 06. 03.dll new file mode 100644 index 0000000..02a0bc5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/ref/2024. 06. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/refint/2024. 06. 03.dll b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/refint/2024. 06. 03.dll new file mode 100644 index 0000000..02a0bc5 Binary files /dev/null and b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/Debug/net6.0-windows/refint/2024. 06. 03.dll differ diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.assets.json b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.assets.json new file mode 100644 index 0000000..f5283d5 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj", + "projectName": "2024. 06. 03", + "projectPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.nuget.cache b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.nuget.cache new file mode 100644 index 0000000..854bcd0 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 06. 03/2024. 06. 03/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "NlPpvb/At33cBUjWPknbevOVVgNMnV1plDHmGQ7MZZ632+RIRwLkmS5QG7sE6VGHKyZ4f6zlFywvZQXzD/aHQA==", + "success": true, + "projectFilePath": "E:\\Suli\\12.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 06. 03\\2024. 06. 03\\2024. 06. 03.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/proga_hazi.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/proga_hazi.txt new file mode 100644 index 0000000..0276802 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/proga_hazi.txt @@ -0,0 +1,195 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Runtime.InteropServices; +using System.Runtime.Remoting.Metadata.W3cXsd2001; +using System.Text; +using System.Threading.Tasks; + +namespace hazi_generator +{ + internal class Program + { + static void eldontes(char valasz) + { + if (valasz == 'a') + { + alapSIM(); + } + else + { + PUKosSIM(); + } + } + + static void PUKosSIM() + { + PUK[] listaPUK = new PUK[3]; + Random r = new Random(); + + for (int i = 0; i < 3; i++) + { + int Sorszam = r.Next(10000000, 99999999); + PUK PUKosSIM = new PUK(); + PUKosSIM.AlapSim(Sorszam); + listaPUK.SetValue(value: PUKosSIM, index: i); + } + + foreach (SIM item in listaPUK) + { + Console.WriteLine(item.Sorszam); + Console.WriteLine(item.Pinkod); + Console.WriteLine(); + } + + for (int i = 0; i < listaPUK.Length; i++) + { + Console.WriteLine("Kérem adja meg a PIN kódot (3 lehetőség)"); + for (int j = 0; j < 3; j++) + { + listaPUK[i].SimLetiltas(listaPUK[i].Sorszam, listaPUK[i].Pinkod); + if (listaPUK[i].Tudta) + { + break; + } + } + if (listaPUK[i].Tudta) + { + Console.WriteLine("A SIM feloldva"); + } + else + { + Console.WriteLine("A SIM letiltva"); + string puk = Convert.ToString(r.Next(1000, 9999)); + Console.WriteLine($"A PUK-kódja: {puk}"); + listaPUK[i].Puk(puk); + } + } + + Console.ReadKey(); + + } + + static void alapSIM() + { + SIM[] listaSIM = new SIM[3]; + Random r = new Random(); + + for (int i = 0; i < 3; i++) + { + int Sorszam = r.Next(10000000, 99999999); + SIM alapSim = new SIM(); + alapSim.AlapSim(Sorszam); + listaSIM.SetValue(value: alapSim, index: i); + } + + foreach (SIM item in listaSIM) + { + Console.WriteLine(item.Sorszam); + Console.WriteLine(item.Pinkod); + Console.WriteLine(); + } + + for (int i = 0; i < listaSIM.Length; i++) + { + Console.WriteLine("Kérem adja meg a PIN kódot (3 lehetőség)"); + for (int j = 0; j < 3; j++) + { + listaSIM[i].SimLetiltas(listaSIM[i].Sorszam, listaSIM[i].Pinkod); + if (listaSIM[i].Tudta) + { + break; + } + } + if (listaSIM[i].Tudta) + { + Console.WriteLine("A SIM feloldva"); + } + else + { + Console.WriteLine("A SIM letiltva"); + } + } + + Console.ReadKey(); + } + + static void Main() + { + Console.WriteLine("Milyen típusú SIM kártyákat szeretne létrehozni (Alap -> a / PUK-kóddal rendelkezőt -> p): "); + char valasz = Convert.ToChar(Console.ReadLine()); + eldontes(valasz); + } + } +} + +using System; +using System.Collections.Generic; +using System.Linq; +using System.Runtime.InteropServices; +using System.Text; +using System.Threading.Tasks; + +namespace hazi_generator +{ + public class SIM + { + public int Sorszam; + public string Pinkod; + public bool Tudta; + public void AlapSim(int Szam) + { + Sorszam = Szam; + + Console.WriteLine($"A {Sorszam} sorszámú SIM aktiválásához adja meg a pinkódot"); + Pinkod = Console.ReadLine(); + if (Pinkod.Length != 4) + { + throw new Exception("A pinkódnak pontosan 4 jegyűnek kell lennie."); + } + else + { + Console.WriteLine("SIM elmentve."); + } + } + + public void SimLetiltas(int sorszam, string pin) + { + Tudta = false; + Console.WriteLine($"Adja meg a {sorszam} sorszámú SIM pink kódját: "); + string beirtPin = Console.ReadLine(); + if (beirtPin != pin) + { + Console.WriteLine("Helytelen PIN kód"); + } + else + { + Tudta = true; + Console.WriteLine("SIM feloldva"); + } + } + } + + public class PUK : SIM + { + public void Puk(string puk) + { + if (!Tudta) + { + Console.WriteLine("Adja meg a PUK kódot:"); + string beirtpuk = Console.ReadLine(); + if (beirtpuk == puk) + { + Tudta = true; + Console.WriteLine("A SIM feloldva, ismét próbálkozhat a PIN kóddal"); + SimLetiltas(Sorszam,Pinkod); + } + else + { + Console.WriteLine("A SIM kártyát megsemmisítettük"); + } + } + } + } +} + diff --git a/Suli/12.b/Programozás (Tusjak Brigitta)/szamok.txt b/Suli/12.b/Programozás (Tusjak Brigitta)/szamok.txt new file mode 100644 index 0000000..302d980 --- /dev/null +++ b/Suli/12.b/Programozás (Tusjak Brigitta)/szamok.txt @@ -0,0 +1,20 @@ +11 +22 +33 +44 +55 +66 +77 +88 +99 +100 +1 +2 +3 +4 +5 +6 +7 +8 +9 +10 \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szoftvertesztelo_statikus.xlsx b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szoftvertesztelo_statikus.xlsx new file mode 100644 index 0000000..76ef10e Binary files /dev/null and b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szoftvertesztelo_statikus.xlsx differ diff --git a/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szupermarket.pdf b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szupermarket.pdf new file mode 100644 index 0000000..ac016d0 Binary files /dev/null and b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 09/szupermarket.pdf differ diff --git a/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 16/Szoftverteszteles-Regisztracio.xlsx b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 16/Szoftverteszteles-Regisztracio.xlsx new file mode 100644 index 0000000..f7812e1 Binary files /dev/null and b/Suli/12.b/Szoftvertesztelés/Dolgozat/2024. 02. 16/Szoftverteszteles-Regisztracio.xlsx differ diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/Szokoev.xlsx b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/Szokoev.xlsx new file mode 100644 index 0000000..8331828 Binary files /dev/null and b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/Szokoev.xlsx differ diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/index.html b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/index.html new file mode 100644 index 0000000..b22d516 --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/index.html @@ -0,0 +1,15 @@ + + + + + + Szökőév + + + +

Szökőév eldöntő szoftver

+ Évszám: + +

+ + \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/szokoev.js b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/szokoev.js new file mode 100644 index 0000000..f200e83 --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 06/szokoev.js @@ -0,0 +1,19 @@ +const button = document.getElementById("gomb") +let szokoev = false +button.addEventListener("click", () =>{ + const ev = parseInt(document.getElementById("ev").value) + if (ev > 0){ + if (ev % 4 === 0 && ev % 100 != 0 || ev % 400 === 0){ + szokoev = true + } + + if (szokoev){ + document.getElementById("eredmeny").innerHTML = "Szökőév!" + } + + else{ + document.getElementById("eredmeny").innerHTML = "Nem szökőév!" + } + } + +}) \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/ajax.js b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/ajax.js new file mode 100644 index 0000000..b82c18e --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/ajax.js @@ -0,0 +1,25 @@ +const button = document.getElementById("getcucc") +button.addEventListener("click", () =>{ + let xhr = new XMLHttpRequest() + + xhr.onreadystatechange = () =>{ + if (xhr.readyState === 4 && xhr.status === 200){ + let adat = JSON.parse(xhr.responseText) + console.log(adat) + + let tohtml = "" + + for (let user of adat.data){ + tohtml += `

${user.first_name}

` + tohtml += `
` + tohtml += `

${user.email}

` + } + + document.getElementById("cucc").innerHTML = tohtml + + } + } + + xhr.open("GET", "https://reqres.in/api/users?page=2") + xhr.send() +}) \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/index.html b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/index.html new file mode 100644 index 0000000..dbede27 --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 10. 20/index.html @@ -0,0 +1,13 @@ + + + + + + Ajax hívások + + + + +

+ + \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.html b/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.html new file mode 100644 index 0000000..f144b65 --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.html @@ -0,0 +1,13 @@ + + + + + + Ajax még mindig + + + + +
+ + \ No newline at end of file diff --git a/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.js b/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.js new file mode 100644 index 0000000..d2b9ffc --- /dev/null +++ b/Suli/12.b/Szoftvertesztelés/Órai/2023. 11. 17/ajax2.js @@ -0,0 +1,29 @@ +document.getElementById("btnajax").onclick = function() { + let xhr = new XMLHttpRequest + + xhr.onreadystatechange = function() { + if (xhr.readyState == 4 && xhr.status == 200) { + let users = JSON.parse(xhr.responseText) + let htmlcucc = "" + + for (let egy of users.data) { + htmlcucc += `

${egy.first_name} ${egy.last_name}

` + htmlcucc += `` + } + + document.getElementById("msg").innerHTML = htmlcucc + + document.querySelectorAll("h3").forEach(a => a.addEventListener("click", e => { + if (document.getElementById(`p${e.target.id}`).style.display == "block") { + document.getElementById(`p${e.target.id}`).style.display = "none" + } + + else { + document.getElementById(`p${e.target.id}`).style.display = "block" + } + })) + } + } + xhr.open("GET", "https://reqres.in/api/users?page=2", true) + xhr.send() +} diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás.rar b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás.rar new file mode 100644 index 0000000..4ce7865 Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás.rar differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/ectomorph.jpg b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/ectomorph.jpg new file mode 100644 index 0000000..94cea0f Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/ectomorph.jpg differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/endomorph.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/endomorph.png new file mode 100644 index 0000000..ae283cf Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/endomorph.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/mesomorph.jpg b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/mesomorph.jpg new file mode 100644 index 0000000..692279f Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/imgs/mesomorph.jpg differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/index.html b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/index.html new file mode 100644 index 0000000..4377700 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/index.html @@ -0,0 +1,38 @@ + + + + + + Testtömegindex + + + + + + + + + + + + + + + + + + + + + + + + +
Testsúlyod: kg
Magasságod: cm
Testtömegindexed: kg/m2
Súlytöbbleted: kg
+
+ + + + + + \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/script.js b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/script.js new file mode 100644 index 0000000..60c3cc5 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/script.js @@ -0,0 +1,26 @@ +const testsuly = document.getElementById("testsuly") +const magassag = document.getElementById("magassag") +const index = document.getElementById("testomeg") +const sulytobblet = document.getElementById("sulytobblet") +const button = document.querySelector("button") + +button.addEventListener("click", ()=>{ + console.log(sulytobblet); + let magassag_m = magassag.value / 100 + let eredmeny = Math.round(testsuly.value / Math.pow(magassag_m, 2) * 100) / 100 + index.value = eredmeny + sulytobblet.value = Math.round(testsuly.value - 25 * Math.pow((magassag.value / 100), 2) * 100) / 100 + if (eredmeny < 18) + { + index.style.backgroundColor = "yellow" + } + + else if (eredmeny > 18 && eredmeny <= 25) + { + index.style.backgroundColor = "green" + } + + else{ + index.style.backgroundColor = "red" + } +}) \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/style.css b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/style.css new file mode 100644 index 0000000..05c31dc --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 10. 10 - Testtömegindex számító alkalmazás/style.css @@ -0,0 +1,26 @@ +body{ + display: flex; + flex-direction: column; + justify-content: space-around; + align-items: center; + background: linear-gradient(to right, hsl(200, 50%, 50%), hsl(30, 40%, 30%)); +} + +table{ + border: 4px black solid; + font-size: 1.5rem; +} + +td{ + border: 2px black solid; + padding: 5px; +} + +button{ + font-size: 2rem; + border-radius: 10px; +} + +input{ + width: 60px; +} \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések.rar b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések.rar new file mode 100644 index 0000000..4ca50be Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések.rar differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/android-chrome-192x192.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/android-chrome-192x192.png new file mode 100644 index 0000000..b36b456 Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/android-chrome-192x192.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/apple-touch-icon.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/apple-touch-icon.png new file mode 100644 index 0000000..4720111 Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/apple-touch-icon.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/browserconfig.xml b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/browserconfig.xml new file mode 100644 index 0000000..b3930d0 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/browserconfig.xml @@ -0,0 +1,9 @@ + + + + + + #da532c + + + diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-16x16.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-16x16.png new file mode 100644 index 0000000..19073c3 Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-16x16.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-32x32.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-32x32.png new file mode 100644 index 0000000..2912152 Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon-32x32.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon.ico b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon.ico new file mode 100644 index 0000000..2d7b47b Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/favicon.ico differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/index.html b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/index.html new file mode 100644 index 0000000..b3276e6 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/index.html @@ -0,0 +1,24 @@ + + + + + + Ajax lekérések + + + + + + + + +
+ + +
+ +
+ +
+ + \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/mstile-150x150.png b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/mstile-150x150.png new file mode 100644 index 0000000..9e3aa0a Binary files /dev/null and b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/mstile-150x150.png differ diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/safari-pinned-tab.svg b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/safari-pinned-tab.svg new file mode 100644 index 0000000..7418bd6 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/safari-pinned-tab.svg @@ -0,0 +1,50 @@ + + + + +Created by potrace 1.14, written by Peter Selinger 2001-2017 + + + + + + + + + + diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/script.js b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/script.js new file mode 100644 index 0000000..30796ea --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/script.js @@ -0,0 +1,33 @@ +buttons = document.querySelectorAll("button") + +buttons[0].addEventListener("click", ()=>{ + const response = document.querySelector(".response") + response.innerHTML = "" + const xhttp = new XMLHttpRequest() + xhttp.onload = function() { + const jsonfile = JSON.parse(this.responseText) + response.innerHTML = `${jsonfile["setup"]}
` + response.innerHTML += jsonfile["delivery"] + } + xhttp.open("GET", "https://v2.jokeapi.dev/joke/Any?type=twopart", true) + xhttp.send() +}) + +buttons[1].addEventListener("click", ()=>{ + const response = document.querySelector(".response") + response.innerHTML = "" + let responsetext = "" + const xhttp = new XMLHttpRequest() + xhttp.onload = function() { + const jsonfile = JSON.parse(this.responseText) + for (let i of jsonfile.jokes) { + responsetext += `${i["setup"]}
` + responsetext += `${i["delivery"]}` + } + + response.innerHTML = responsetext + } + xhttp.open("GET", "https://v2.jokeapi.dev/joke/Any?type=twopart&amount=10", true) + xhttp.send() +}) + diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/site.webmanifest b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/site.webmanifest new file mode 100644 index 0000000..0e0e858 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/site.webmanifest @@ -0,0 +1,14 @@ +{ + "name": "", + "short_name": "", + "icons": [ + { + "src": "/android-chrome-192x192.png", + "sizes": "192x192", + "type": "image/png" + } + ], + "theme_color": "#ffffff", + "background_color": "#ffffff", + "display": "standalone" +} diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/style.css b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/style.css new file mode 100644 index 0000000..43f8187 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Dolgozat/2023. 12. 12 - Ajax lekérések/style.css @@ -0,0 +1,35 @@ +@import url('https://fonts.googleapis.com/css2?family=Silkscreen:wght@400;700&display=swap'); +@import url('https://fonts.googleapis.com/css2?family=Dhurjati&display=swap'); + +body { + display: flex; + justify-content: center; + align-items: center; + flex-direction: column; + min-height: 100vh; + background: linear-gradient(#e66465, #9198e5); +} + +.content { + border: 4px black solid; + border-radius: 10px; + padding: 1.3rem; +} + +button { + font-size: 2rem; + cursor: pointer; + border: 2px black solid; + font-family: "Silkscreen"; + border-radius: 20px; +} + +.response { + display: flex; + justify-content: center; + align-items: center; + margin-top: 10px; + border: 4px black solid; + font-family: "Dhurjati"; + font-size: 1.5rem; +} \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.css b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.css new file mode 100644 index 0000000..0eef4a8 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.css @@ -0,0 +1,25 @@ +table{ + border-collapse: collapse; +} + +td{ + width: 150px; + height: 150px; + border: 2px black solid; + text-align: center; + vertical-align: middle; + font-size: 120px; +} + +.o{ + color: red; +} + +.x{ + color: blue; +} + +#nyertes{ + font-weight: bold; + font-size: larger; +} \ No newline at end of file diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.js b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.js new file mode 100644 index 0000000..55434e8 --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/amoba.js @@ -0,0 +1,39 @@ +let symbol = "X" +let matrix = [-1, -1, -1, -1, -1, -1, -1, -1, -1] +let num = 0 +let wincombo = [[0, 1, 2], [3, 4, 5], [6, 7, 8], [0, 3, 6], [1, 4, 7], [2, 5, 8], [0, 4, 8], [2, 4, 6]] + +for (let i = 0; i < 9; i++){ + document.getElementById(i.toString()).addEventListener("click", function(){ + if (this.innerHTML == ""){ + this.innerHTML = symbol + num = this.id + if (symbol.toLowerCase() === "x") + matrix[num] = 1 + else + matrix[num] = 0 + this.classList.add(symbol.toLowerCase()) + let nyertes = CheckWin() + if (nyertes == 1 || nyertes == 0) + document.getElementById("nyertes").innerHTML = `Nyertes játékos: ${symbol}` + else{ + if (symbol === "X") + symbol = "O" + else symbol = "X" + document.getElementById("nyertes").innerHTML = `Folyamatban a játék, ${symbol} játékos következik.` + } + } + }) +} + +function CheckWin(){ + for (let ind of wincombo){ + if (matrix[ind[0]] == matrix[ind[1]] && matrix[ind[2]] == matrix[ind[1]] && matrix[ind[0]] != -1) + return matrix[ind[0]] + } + return -1 +} + +function ujra(){ + location.reload() +} diff --git a/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/index.html b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/index.html new file mode 100644 index 0000000..9a254ed --- /dev/null +++ b/Suli/12.b/Webprogramozás/Gyakorlat/Órai munka/Tic Tac Toe/index.html @@ -0,0 +1,33 @@ + + + + + + Amőba + + + + +

Amőba

+

Táblázat

+ + + + + + + + + + + + + + + + +
+

Első játékos kezd.

+ + + \ No newline at end of file diff --git a/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pdf b/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pdf new file mode 100644 index 0000000..f207093 Binary files /dev/null and b/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pdf differ diff --git a/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pptx b/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pptx new file mode 100644 index 0000000..1986362 Binary files /dev/null and b/Suli/12.b/Állapolg. ismeretek/Alex Állatvédő Egyesület - Tóth Ádám.pptx differ diff --git a/Suli/12.b/Állapolg. ismeretek/~$Alex Állatvédő Egyesület.pptx b/Suli/12.b/Állapolg. ismeretek/~$Alex Állatvédő Egyesület.pptx new file mode 100644 index 0000000..175a343 Binary files /dev/null and b/Suli/12.b/Állapolg. ismeretek/~$Alex Állatvédő Egyesület.pptx differ diff --git a/Suli/13.b/Adatbázis/20240904/adatbazis.sql b/Suli/13.b/Adatbázis/20240904/adatbazis.sql new file mode 100644 index 0000000..55ba3fa --- /dev/null +++ b/Suli/13.b/Adatbázis/20240904/adatbazis.sql @@ -0,0 +1,3432 @@ +use parkolohaz; + +-- Járműtípusok +CREATE TABLE jarmutipus +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(32) NOT NULL, + primary key (id) +); + +-- Emelet +CREATE TABLE emelet +( + id int NOT NULL, + nev varchar(64) NOT NULL, + primary key (id) +); + +-- Felhasználók +CREATE TABLE felhasznalo +( + id int NOT NULL, + nev varchar(64) NOT NULL, + primary key (id) +); + +-- Parkolóhelyek +CREATE TABLE parkolohely +( + id int NOT NULL, + jarmutipusId int NOT NULL, + emeletId int NOT NULL, + felirat varchar(32) NOT NULL, + szelesseg double NOT NULL, + primary key (id), + key jarmutipusId (jarmutipusId), + CONSTRAINT FK_jarmutipus_jarmutipusId FOREIGN KEY (jarmutipusId) + REFERENCES jarmutipus (id), + key emeletId(emeletId), + CONSTRAINT FK_emelet_emeletId FOREIGN KEY (emeletId) + REFERENCES emelet (id) +); + +-- Foglalások +CREATE TABLE foglalas +( + id int NOT NULL, + parkolohelyId int NOT NULL, + felhasznaloId int NOT NULL, + ar int NOT NULL, + datum date NOT NULL, + fizetve boolean default false, + primary key (id), + key parkolohelyId(parkolohelyId), + CONSTRAINT FK_parkolohely_parkolohelyId FOREIGN KEY (parkolohelyId) + REFERENCES parkolohely (id), + key felhasznaloId(felhasznaloId), + CONSTRAINT FK_felhasznalo_felhasznaloId FOREIGN KEY (felhasznaloId) + REFERENCES felhasznalo (id) +); + + +-- Adatok beszúrása +INSERT INTO jarmutipus (id, nev) +VALUES (1, 'Gépkocsi'), + (2, 'Motorkerékpár'), + (3, 'Bicikli'); + +INSERT INTO emelet (id, nev) +VALUES (1, 'Földszint'), + (2, '1. Emelet'), + (3, '2. Emelet'), + (4, '3. Emelet'), + (5, '4. Emelet'); + + +INSERT INTO felhasznalo (id, nev) +VALUES (1, 'Nagy Bence'), + (2, 'Kovács Máté'), + (3, 'Tóth Levente'), + (4, 'Szabó Dominik'), + (5, 'Horváth Marcell'), + (6, 'Varga Noel'), + (7, 'Kiss Ádám'), + (8, 'Molnár Dániel'), + (9, 'Németh Dávid'), + (10, 'Farkas Olivér'), + (11, 'Balogh Milán'), + (12, 'Papp Zalán'), + (13, 'Lakatos Botond'), + (14, 'Takács Benett'), + (15, 'Juhász Zsombor'), + (16, 'Mészáros Balázs'), + (17, 'Oláh Áron'), + (18, 'Simon Péter'), + (19, 'Rácz Kristóf'), + (20, 'Fekete Tamás'), + (21, 'Szilágyi Márk'), + (22, 'Török Benedek'), + (23, 'Fehér Gergő'), + (24, 'Balázs László'), + (25, 'Gál Nimród'), + (26, 'Kis Bálint'), + (27, 'Szűcs Zétény'), + (28, 'Kocsis Ákos'), + (29, 'Orsós Patrik'), + (30, 'Pintér Zoltán'), + (31, 'Fodor András'), + (32, 'Szalai Attila'), + (33, 'Sipos Hunor'), + (34, 'Magyar Barnabás'), + (35, 'Lukács Márton'), + (36, 'Gulyás Gábor'), + (37, 'Biró Alex'), + (38, 'Király Martin'), + (39, 'László István'), + (40, 'Balog Kornél'), + (41, 'Katona Vince'), + (42, 'Bogdán József'), + (43, 'Jakab János'), + (44, 'Sándor Krisztián'), + (45, 'Boros Zsolt'), + (46, 'Váradi Zente'), + (47, 'Fazekas Sándor'), + (48, 'Kelemen Erik'), + (49, 'Antal Bendegúz'), + (50, 'Orosz Roland'), + (51, 'Somogyi Richárd'), + (52, 'Fülöp Ábel'), + (53, 'Veres Csaba'), + (54, 'Vincze Róbert'), + (55, 'Budai Kevin'), + (56, 'Hegedűs Nolen'), + (57, 'Deák Soma'), + (58, 'Pap Ármin'), + (59, 'Bálint Mihály'), + (60, 'Illés Vencel'), + (61, 'Pál Norbert'), + (62, 'Vass Mátyás'), + (63, 'Szőke Ferenc'), + (64, 'Fábián Tibor'), + (65, 'Vörös Nándor'), + (66, 'Lengyel Benjámin'), + (67, 'Bognár Szabolcs'), + (68, 'Bodnár Benjamin'), + (69, 'Jónás Simon'), + (70, 'Szücs Gergely'), + (71, 'Hajdu Csongor'), + (72, 'Halász Viktor'), + (73, 'Máté Miklós'), + (74, 'Székely Nikolasz'), + (75, 'Kozma Vilmos'), + (76, 'Gáspár Boldizsár'), + (77, 'Pásztor Kende'), + (78, 'Bakos Imre'), + (79, 'Dudás Bertalan'), + (80, 'Major Brendon'), + (81, 'Orbán Zénó'), + (82, 'Virág Adrián'), + (83, 'Hegedüs Dorián'), + (84, 'Barna Krisztofer'), + (85, 'Novák György'), + (86, 'Soós Alexander'), + (87, 'Tamás Lajos'), + (88, 'Nemes Dénes'), + (89, 'Pataki Félix'), + (90, 'Balla Sámuel'), + (91, 'Faragó Denisz'), + (92, 'Kerekes Bende'), + (93, 'Borbély Noé'), + (94, 'Barta Károly'), + (95, 'Péter Donát'), + (96, 'Csonka Gyula'), + (97, 'Mezei Gellért'), + (98, 'Sárközi Mirkó'), + (99, 'Szekeres Vendel'), + (100, 'Márton Brájen'), + (101, 'Nagy Hanna'), + (102, 'Kovács Anna'), + (103, 'Tóth Zoé'), + (104, 'Szabó Luca'), + (105, 'Horváth Léna'), + (106, 'Varga Emma'), + (107, 'Kiss Zsófia'), + (108, 'Molnár Lili'), + (109, 'Németh Boglárka'), + (110, 'Farkas Mira'), + (111, 'Balogh Lilien'), + (112, 'Papp Nóra'), + (113, 'Lakatos Jázmin'), + (114, 'Takács Laura'), + (115, 'Juhász Maja'), + (116, 'Mészáros Sára'), + (117, 'Oláh Lara'), + (118, 'Simon Lilla'), + (119, 'Rácz Izabella'), + (120, 'Fekete Gréta'), + (121, 'Szilágyi Alíz'), + (122, 'Török Fanni'), + (123, 'Fehér Adél'), + (124, 'Balázs Flóra'), + (125, 'Gál Csenge'), + (126, 'Kis Dóra'), + (127, 'Szűcs Dorina'), + (128, 'Kocsis Zselyke'), + (129, 'Orsós Réka'), + (130, 'Pintér Dorka'), + (131, 'Fodor Liza'), + (132, 'Szalai Janka'), + (133, 'Sipos Liliána'), + (134, 'Magyar Olívia'), + (135, 'Lukács Viktória'), + (136, 'Gulyás Eszter'), + (137, 'Biró Natasa'), + (138, 'Király Noémi'), + (139, 'László Petra'), + (140, 'Balog Bianka'), + (141, 'Katona Szofia'), + (142, 'Bogdán Panna'), + (143, 'Jakab Vivien'), + (144, 'Sándor Emília'), + (145, 'Boros Szófia'), + (146, 'Váradi Rebeka'), + (147, 'Fazekas Kamilla'), + (148, 'Kelemen Blanka'); + +INSERT INTO parkolohely (id, jarmutipusId, emeletId, felirat, szelesseg) +VALUES (1, 1, 1, 'P001', 1.9), + (2, 1, 1, 'P002', 1.7), + (3, 1, 1, 'P003', 1.9), + (4, 1, 1, 'P004', 1.9), + (5, 1, 1, 'P005', 1.7), + (6, 1, 1, 'P006', 1.9), + (7, 1, 1, 'P007', 1.5), + (8, 1, 1, 'P008', 1.7), + (9, 1, 1, 'P009', 1.7), + (10, 1, 1, 'P010', 1.9), + (11, 1, 1, 'P011', 1.9), + (12, 1, 1, 'P012', 1.7), + (13, 1, 1, 'P013', 1.9), + (14, 1, 1, 'P014', 1.5), + (15, 1, 1, 'P015', 1.7), + (16, 1, 1, 'P016', 1.7), + (17, 2, 1, 'P017', 1.5), + (18, 2, 1, 'P018', 1.5), + (19, 2, 1, 'P019', 1.7), + (20, 2, 1, 'P020', 1.5), + (21, 3, 1, 'P021', 1.9), + (22, 3, 1, 'P022', 1.5), + (23, 3, 1, 'P023', 1.9), + (24, 3, 1, 'P024', 1.5), + (25, 3, 1, 'P025', 1.9), + (26, 3, 1, 'P026', 1.9), + (27, 3, 1, 'P027', 1.7), + (28, 3, 1, 'P028', 1.7), + (29, 3, 1, 'P029', 1.9), + (30, 3, 1, 'P030', 1.9), -- Földszint eddig. Van 10 kerékpár tárolója pluszban. + (31, 1, 2, 'P031', 1.5), + (32, 1, 2, 'P032', 1.7), + (33, 1, 2, 'P033', 1.5), + (34, 1, 2, 'P034', 1.7), + (35, 1, 2, 'P035', 1.9), + (36, 1, 2, 'P036', 1.7), + (37, 1, 2, 'P037', 1.5), + (38, 1, 2, 'P038', 1.9), + (39, 1, 2, 'P039', 1.5), + (40, 1, 2, 'P040', 1.9), + (41, 1, 2, 'P041', 1.9), + (42, 1, 2, 'P042', 1.5), + (43, 1, 2, 'P043', 1.9), + (44, 1, 2, 'P044', 1.9), + (45, 1, 2, 'P045', 1.7), + (46, 1, 2, 'P046', 1.5), + (47, 2, 2, 'P047', 1.9), + (48, 2, 2, 'P048', 1.7), + (49, 2, 2, 'P049', 1.7), + (50, 2, 2, 'P050', 1.9), + (51, 1, 3, 'P051', 1.5), + (52, 1, 3, 'P052', 1.5), + (53, 1, 3, 'P053', 1.9), + (54, 1, 3, 'P054', 1.9), + (55, 1, 3, 'P055', 1.5), + (56, 1, 3, 'P056', 1.5), + (57, 1, 3, 'P057', 1.9), + (58, 1, 3, 'P058', 1.7), + (59, 1, 3, 'P059', 1.9), + (60, 1, 3, 'P060', 1.5), + (61, 1, 3, 'P061', 1.7), + (62, 1, 3, 'P062', 1.7), + (63, 1, 3, 'P063', 1.5), + (64, 1, 3, 'P064', 1.9), + (65, 1, 3, 'P065', 1.9), + (66, 1, 3, 'P066', 1.7), + (67, 2, 3, 'P067', 1.7), + (68, 2, 3, 'P068', 1.5), + (69, 2, 3, 'P069', 1.9), + (70, 2, 3, 'P070', 1.7), + (71, 1, 4, 'P071', 1.9), + (72, 1, 4, 'P072', 1.9), + (73, 1, 4, 'P073', 1.5), + (74, 1, 4, 'P074', 1.9), + (75, 1, 4, 'P075', 1.5), + (76, 1, 4, 'P076', 1.7), + (77, 1, 4, 'P077', 1.5), + (78, 1, 4, 'P078', 1.5), + (79, 1, 4, 'P079', 1.9), + (80, 1, 4, 'P080', 1.9), + (81, 1, 4, 'P081', 1.9), + (82, 1, 4, 'P082', 1.7), + (83, 1, 4, 'P083', 1.9), + (84, 1, 4, 'P084', 1.5), + (85, 1, 4, 'P085', 1.9), + (86, 1, 4, 'P086', 1.5), + (87, 2, 4, 'P087', 1.5), + (88, 2, 4, 'P088', 1.5), + (89, 2, 4, 'P089', 1.7), + (90, 2, 4, 'P090', 1.5), + (91, 2, 5, 'P091', 1.7), + (92, 2, 5, 'P092', 1.9), + (93, 2, 5, 'P093', 1.9), + (94, 2, 5, 'P094', 1.7), + (95, 2, 5, 'P095', 1.9), + (96, 2, 5, 'P096', 1.7), + (97, 2, 5, 'P097', 1.5), + (98, 2, 5, 'P098', 1.7), + (99, 2, 5, 'P099', 1.7), + (100, 2, 5, 'P100', 1.7); + +INSERT INTO foglalas (id, ar, datum, fizetve, parkolohelyId, felhasznaloId) +values (1, 1500, '2021-01-01', true, 1, 74), + (2, 1000, '2021-01-02', false, 1, 74), + (3, 1000, '2021-01-03', false, 1, 74), + (4, 1000, '2021-01-04', false, 1, 74), + (5, 1000, '2021-01-05', false, 1, 74), + (6, 1000, '2021-01-06', true, 1, 74), + (7, 1500, '2021-01-07', true, 1, 74), + (8, 1500, '2021-01-08', false, 1, 74), + (9, 1000, '2021-01-09', false, 1, 74), + (10, 1000, '2021-01-10', false, 1, 74), + (11, 1000, '2021-01-11', false, 1, 74), + (12, 1000, '2021-01-12', false, 1, 74), + (13, 1000, '2021-01-13', true, 1, 74), + (14, 1500, '2021-01-14', true, 1, 74), + (15, 1500, '2021-01-15', true, 1, 74), + (16, 1000, '2021-01-16', false, 1, 74), + (17, 1000, '2021-01-17', true, 1, 74), + (18, 1000, '2021-01-18', false, 1, 74), + (19, 1000, '2021-01-19', false, 1, 74), + (20, 1000, '2021-01-20', false, 1, 74), + (21, 1500, '2021-01-21', false, 1, 74), + (22, 1500, '2021-01-22', false, 1, 74), + (23, 1000, '2021-01-23', true, 1, 74), + (24, 1000, '2021-01-24', false, 1, 74), + (25, 1000, '2021-01-25', false, 1, 74), + (26, 1000, '2021-01-26', true, 1, 74), + (27, 1000, '2021-01-27', false, 1, 74), + (28, 1500, '2021-01-28', true, 1, 74), + (29, 1500, '2021-01-29', false, 1, 74), + (30, 1000, '2021-01-30', false, 1, 74), + (31, 1000, '2021-01-31', true, 1, 74), + (32, 1500, '2021-01-01', false, 2, 37), + (33, 1000, '2021-01-02', true, 2, 37), + (34, 1000, '2021-01-03', false, 2, 37), + (35, 1000, '2021-01-04', true, 2, 37), + (36, 1000, '2021-01-05', false, 2, 37), + (37, 1000, '2021-01-06', false, 2, 37), + (38, 1500, '2021-01-07', false, 2, 37), + (39, 1500, '2021-01-08', false, 2, 37), + (40, 1000, '2021-01-09', false, 2, 37), + (41, 1000, '2021-01-10', true, 2, 37), + (42, 1000, '2021-01-11', false, 2, 37), + (43, 1000, '2021-01-12', false, 2, 37), + (44, 1000, '2021-01-13', true, 2, 37), + (45, 1500, '2021-01-14', false, 2, 37), + (46, 1500, '2021-01-15', false, 2, 37), + (47, 1000, '2021-01-16', false, 2, 37), + (48, 1000, '2021-01-17', false, 2, 37), + (49, 1000, '2021-01-18', false, 2, 37), + (50, 1000, '2021-01-19', true, 2, 37), + (51, 1000, '2021-01-20', false, 2, 37), + (52, 1500, '2021-01-21', false, 2, 37), + (53, 1500, '2021-01-22', true, 2, 37), + (54, 1000, '2021-01-23', false, 2, 37), + (55, 1000, '2021-01-24', true, 2, 37), + (56, 1000, '2021-01-25', false, 2, 37), + (57, 1000, '2021-01-26', true, 2, 37), + (58, 1000, '2021-01-27', false, 2, 37), + (59, 1500, '2021-01-28', false, 2, 37), + (60, 1500, '2021-01-29', false, 2, 37), + (61, 1000, '2021-01-30', true, 2, 37), + (62, 1000, '2021-01-31', true, 2, 37), + (63, 1500, '2021-01-01', true, 3, 28), + (64, 1000, '2021-01-02', false, 3, 28), + (65, 1000, '2021-01-03', true, 3, 28), + (66, 1000, '2021-01-04', false, 3, 28), + (67, 1000, '2021-01-05', false, 3, 28), + (68, 1000, '2021-01-06', false, 3, 28), + (69, 1500, '2021-01-07', false, 3, 28), + (70, 1500, '2021-01-08', true, 3, 28), + (71, 1000, '2021-01-09', false, 3, 28), + (72, 1000, '2021-01-10', true, 3, 28), + (73, 1000, '2021-01-11', true, 3, 28), + (74, 1000, '2021-01-12', false, 3, 28), + (75, 1000, '2021-01-13', true, 3, 28), + (76, 1500, '2021-01-14', true, 3, 28), + (77, 1500, '2021-01-15', false, 3, 28), + (78, 1000, '2021-01-16', false, 3, 28), + (79, 1000, '2021-01-17', true, 3, 28), + (80, 1000, '2021-01-18', false, 3, 28), + (81, 1000, '2021-01-19', false, 3, 28), + (82, 1000, '2021-01-20', true, 3, 28), + (83, 1500, '2021-01-21', false, 3, 28), + (84, 1500, '2021-01-22', false, 3, 28), + (85, 1000, '2021-01-23', true, 3, 28), + (86, 1000, '2021-01-24', false, 3, 28), + (87, 1000, '2021-01-25', false, 3, 28), + (88, 1000, '2021-01-26', false, 3, 28), + (89, 1000, '2021-01-27', false, 3, 28), + (90, 1500, '2021-01-28', false, 3, 28), + (91, 1500, '2021-01-29', false, 3, 28), + (92, 1000, '2021-01-30', false, 3, 28), + (93, 1000, '2021-01-31', false, 3, 28), + (94, 1500, '2021-01-01', true, 4, 78), + (95, 1000, '2021-01-02', true, 4, 78), + (96, 1000, '2021-01-03', false, 4, 78), + (97, 1000, '2021-01-04', false, 4, 78), + (98, 1000, '2021-01-05', true, 4, 78), + (99, 1000, '2021-01-06', false, 4, 78), + (100, 1500, '2021-01-07', true, 4, 78), + (101, 1500, '2021-01-08', false, 4, 78), + (102, 1000, '2021-01-09', false, 4, 78), + (103, 1000, '2021-01-10', false, 4, 78), + (104, 1000, '2021-01-11', false, 4, 78), + (105, 1000, '2021-01-12', false, 4, 78), + (106, 1000, '2021-01-13', false, 4, 78), + (107, 1500, '2021-01-14', false, 4, 78), + (108, 1500, '2021-01-15', false, 4, 78), + (109, 1000, '2021-01-16', false, 4, 78), + (110, 1000, '2021-01-17', false, 4, 78), + (111, 1000, '2021-01-18', false, 4, 78), + (112, 1000, '2021-01-19', false, 4, 78), + (113, 1000, '2021-01-20', false, 4, 78), + (114, 1500, '2021-01-21', false, 4, 78), + (115, 1500, '2021-01-22', false, 4, 78), + (116, 1000, '2021-01-23', false, 4, 78), + (117, 1000, '2021-01-24', false, 4, 78), + (118, 1000, '2021-01-25', false, 4, 78), + (119, 1000, '2021-01-26', false, 4, 78), + (120, 1000, '2021-01-27', false, 4, 78), + (121, 1500, '2021-01-28', false, 4, 78), + (122, 1500, '2021-01-29', false, 4, 78), + (123, 1000, '2021-01-30', true, 4, 78), + (124, 1000, '2021-01-31', true, 4, 78), + (125, 1500, '2021-01-01', false, 5, 6), + (126, 1000, '2021-01-02', false, 5, 6), + (127, 1000, '2021-01-03', true, 5, 6), + (128, 1000, '2021-01-04', false, 5, 6), + (129, 1000, '2021-01-05', false, 5, 6), + (130, 1000, '2021-01-06', false, 5, 6), + (131, 1500, '2021-01-07', false, 5, 6), + (132, 1500, '2021-01-08', false, 5, 6), + (133, 1000, '2021-01-09', false, 5, 6), + (134, 1000, '2021-01-10', false, 5, 6), + (135, 1000, '2021-01-11', false, 5, 6), + (136, 1000, '2021-01-12', false, 5, 6), + (137, 1000, '2021-01-13', false, 5, 6), + (138, 1500, '2021-01-14', true, 5, 6), + (139, 1500, '2021-01-15', false, 5, 6), + (140, 1000, '2021-01-16', false, 5, 6), + (141, 1000, '2021-01-17', false, 5, 6), + (142, 1000, '2021-01-18', false, 5, 6), + (143, 1000, '2021-01-19', false, 5, 6), + (144, 1000, '2021-01-20', false, 5, 6), + (145, 1500, '2021-01-21', false, 5, 6), + (146, 1500, '2021-01-22', false, 5, 6), + (147, 1000, '2021-01-23', false, 5, 6), + (148, 1000, '2021-01-24', false, 5, 6), + (149, 1000, '2021-01-25', false, 5, 6), + (150, 1000, '2021-01-26', false, 5, 6), + (151, 1000, '2021-01-27', false, 5, 6), + (152, 1500, '2021-01-28', false, 5, 6), + (153, 1500, '2021-01-29', false, 5, 6), + (154, 1000, '2021-01-30', false, 5, 6), + (155, 1000, '2021-01-31', false, 5, 6), + (156, 1500, '2021-01-01', false, 6, 38), + (157, 1000, '2021-01-02', false, 6, 38), + (158, 1000, '2021-01-03', false, 6, 38), + (159, 1000, '2021-01-04', false, 6, 38), + (160, 1000, '2021-01-05', false, 6, 38), + (161, 1000, '2021-01-06', false, 6, 38), + (162, 1500, '2021-01-07', false, 6, 38), + (163, 1500, '2021-01-08', false, 6, 38), + (164, 1000, '2021-01-09', true, 6, 38), + (165, 1000, '2021-01-10', false, 6, 38), + (166, 1000, '2021-01-11', false, 6, 38), + (167, 1000, '2021-01-12', true, 6, 38), + (168, 1000, '2021-01-13', false, 6, 38), + (169, 1500, '2021-01-14', false, 6, 38), + (170, 1500, '2021-01-15', false, 6, 38), + (171, 1000, '2021-01-16', false, 6, 38), + (172, 1000, '2021-01-17', false, 6, 38), + (173, 1000, '2021-01-18', false, 6, 38), + (174, 1000, '2021-01-19', true, 6, 38), + (175, 1000, '2021-01-20', false, 6, 38), + (176, 1500, '2021-01-21', false, 6, 38), + (177, 1500, '2021-01-22', false, 6, 38), + (178, 1000, '2021-01-23', true, 6, 38), + (179, 1000, '2021-01-24', true, 6, 38), + (180, 1000, '2021-01-25', false, 6, 38), + (181, 1000, '2021-01-26', false, 6, 38), + (182, 1000, '2021-01-27', false, 6, 38), + (183, 1500, '2021-01-28', true, 6, 38), + (184, 1500, '2021-01-29', false, 6, 38), + (185, 1000, '2021-01-30', true, 6, 38), + (186, 1000, '2021-01-31', true, 6, 38), + (187, 1500, '2021-01-01', true, 7, 55), + (188, 1000, '2021-01-02', false, 7, 55), + (189, 1000, '2021-01-03', false, 7, 55), + (190, 1000, '2021-01-04', false, 7, 55), + (191, 1000, '2021-01-05', false, 7, 55), + (192, 1000, '2021-01-06', true, 7, 55), + (193, 1500, '2021-01-07', false, 7, 55), + (194, 1500, '2021-01-08', false, 7, 55), + (195, 1000, '2021-01-09', false, 7, 55), + (196, 1000, '2021-01-10', false, 7, 55), + (197, 1000, '2021-01-11', true, 7, 55), + (198, 1000, '2021-01-12', false, 7, 55), + (199, 1000, '2021-01-13', true, 7, 55), + (200, 1500, '2021-01-14', false, 7, 55), + (201, 1500, '2021-01-15', false, 7, 55), + (202, 1000, '2021-01-16', false, 7, 55), + (203, 1000, '2021-01-17', false, 7, 55), + (204, 1000, '2021-01-18', true, 7, 55), + (205, 1000, '2021-01-19', false, 7, 55), + (206, 1000, '2021-01-20', false, 7, 55), + (207, 1500, '2021-01-21', false, 7, 55), + (208, 1500, '2021-01-22', false, 7, 55), + (209, 1000, '2021-01-23', false, 7, 55), + (210, 1000, '2021-01-24', false, 7, 55), + (211, 1000, '2021-01-25', false, 7, 55), + (212, 1000, '2021-01-26', false, 7, 55), + (213, 1000, '2021-01-27', true, 7, 55), + (214, 1500, '2021-01-28', false, 7, 55), + (215, 1500, '2021-01-29', false, 7, 55), + (216, 1000, '2021-01-30', false, 7, 55), + (217, 1000, '2021-01-31', false, 7, 55), + (218, 1500, '2021-01-01', true, 8, 85), + (219, 1000, '2021-01-02', true, 8, 85), + (220, 1000, '2021-01-03', false, 8, 85), + (221, 1000, '2021-01-04', false, 8, 85), + (222, 1000, '2021-01-05', false, 8, 85), + (223, 1000, '2021-01-06', false, 8, 85), + (224, 1500, '2021-01-07', true, 8, 85), + (225, 1500, '2021-01-08', false, 8, 85), + (226, 1000, '2021-01-09', false, 8, 85), + (227, 1000, '2021-01-10', false, 8, 85), + (228, 1000, '2021-01-11', true, 8, 85), + (229, 1000, '2021-01-12', false, 8, 85), + (230, 1000, '2021-01-13', false, 8, 85), + (231, 1500, '2021-01-14', false, 8, 85), + (232, 1500, '2021-01-15', false, 8, 85), + (233, 1000, '2021-01-16', true, 8, 85), + (234, 1000, '2021-01-17', false, 8, 85), + (235, 1000, '2021-01-18', false, 8, 85), + (236, 1000, '2021-01-19', false, 8, 85), + (237, 1000, '2021-01-20', true, 8, 85), + (238, 1500, '2021-01-21', false, 8, 85), + (239, 1500, '2021-01-22', false, 8, 85), + (240, 1000, '2021-01-23', false, 8, 85), + (241, 1000, '2021-01-24', false, 8, 85), + (242, 1000, '2021-01-25', false, 8, 85), + (243, 1000, '2021-01-26', false, 8, 85), + (244, 1000, '2021-01-27', true, 8, 85), + (245, 1500, '2021-01-28', false, 8, 85), + (246, 1500, '2021-01-29', false, 8, 85), + (247, 1000, '2021-01-30', true, 8, 85), + (248, 1000, '2021-01-31', false, 8, 85), + (249, 1500, '2021-01-01', false, 9, 5), + (250, 1000, '2021-01-02', false, 9, 5), + (251, 1000, '2021-01-03', false, 9, 5), + (252, 1000, '2021-01-04', false, 9, 5), + (253, 1000, '2021-01-05', false, 9, 5), + (254, 1000, '2021-01-06', false, 9, 5), + (255, 1500, '2021-01-07', false, 9, 5), + (256, 1500, '2021-01-08', false, 9, 5), + (257, 1000, '2021-01-09', false, 9, 5), + (258, 1000, '2021-01-10', false, 9, 5), + (259, 1000, '2021-01-11', false, 9, 5), + (260, 1000, '2021-01-12', true, 9, 5), + (261, 1000, '2021-01-13', false, 9, 5), + (262, 1500, '2021-01-14', false, 9, 5), + (263, 1500, '2021-01-15', true, 9, 5), + (264, 1000, '2021-01-16', false, 9, 5), + (265, 1000, '2021-01-17', false, 9, 5), + (266, 1000, '2021-01-18', false, 9, 5), + (267, 1000, '2021-01-19', false, 9, 5), + (268, 1000, '2021-01-20', false, 9, 5), + (269, 1500, '2021-01-21', false, 9, 5), + (270, 1500, '2021-01-22', false, 9, 5), + (271, 1000, '2021-01-23', false, 9, 5), + (272, 1000, '2021-01-24', false, 9, 5), + (273, 1000, '2021-01-25', true, 9, 5), + (274, 1000, '2021-01-26', false, 9, 5), + (275, 1000, '2021-01-27', false, 9, 5), + (276, 1500, '2021-01-28', false, 9, 5), + (277, 1500, '2021-01-29', true, 9, 5), + (278, 1000, '2021-01-30', false, 9, 5), + (279, 1000, '2021-01-31', true, 9, 5), + (280, 1500, '2021-01-01', true, 10, 18), + (281, 1000, '2021-01-02', false, 10, 18), + (282, 1000, '2021-01-03', true, 10, 18), + (283, 1000, '2021-01-04', false, 10, 18), + (284, 1000, '2021-01-05', false, 10, 18), + (285, 1000, '2021-01-06', true, 10, 18), + (286, 1500, '2021-01-07', false, 10, 18), + (287, 1500, '2021-01-08', false, 10, 18), + (288, 1000, '2021-01-09', true, 10, 18), + (289, 1000, '2021-01-10', false, 10, 18), + (290, 1000, '2021-01-11', false, 10, 18), + (291, 1000, '2021-01-12', true, 10, 18), + (292, 1000, '2021-01-13', false, 10, 18), + (293, 1500, '2021-01-14', false, 10, 18), + (294, 1500, '2021-01-15', false, 10, 18), + (295, 1000, '2021-01-16', false, 10, 18), + (296, 1000, '2021-01-17', true, 10, 18), + (297, 1000, '2021-01-18', true, 10, 18), + (298, 1000, '2021-01-19', false, 10, 18), + (299, 1000, '2021-01-20', true, 10, 18), + (300, 1500, '2021-01-21', true, 10, 18), + (301, 1500, '2021-01-22', false, 10, 18), + (302, 1000, '2021-01-23', false, 10, 18), + (303, 1000, '2021-01-24', false, 10, 18), + (304, 1000, '2021-01-25', false, 10, 18), + (305, 1000, '2021-01-26', false, 10, 18), + (306, 1000, '2021-01-27', false, 10, 18), + (307, 1500, '2021-01-28', false, 10, 18), + (308, 1500, '2021-01-29', false, 10, 18), + (309, 1000, '2021-01-30', false, 10, 18), + (310, 1000, '2021-01-31', false, 10, 18), + (311, 1500, '2021-01-01', false, 11, 45), + (312, 1000, '2021-01-02', false, 11, 45), + (313, 1000, '2021-01-03', false, 11, 45), + (314, 1000, '2021-01-04', false, 11, 45), + (315, 1000, '2021-01-05', true, 11, 45), + (316, 1000, '2021-01-06', false, 11, 45), + (317, 1500, '2021-01-07', false, 11, 45), + (318, 1500, '2021-01-08', false, 11, 45), + (319, 1000, '2021-01-09', false, 11, 45), + (320, 1000, '2021-01-10', false, 11, 45), + (321, 1000, '2021-01-11', true, 11, 45), + (322, 1000, '2021-01-12', false, 11, 45), + (323, 1000, '2021-01-13', false, 11, 45), + (324, 1500, '2021-01-14', false, 11, 45), + (325, 1500, '2021-01-15', true, 11, 45), + (326, 1000, '2021-01-16', true, 11, 45), + (327, 1000, '2021-01-17', true, 11, 45), + (328, 1000, '2021-01-18', false, 11, 45), + (329, 1000, '2021-01-19', false, 11, 45), + (330, 1000, '2021-01-20', false, 11, 45), + (331, 1500, '2021-01-21', false, 11, 45), + (332, 1500, '2021-01-22', false, 11, 45), + (333, 1000, '2021-01-23', true, 11, 45), + (334, 1000, '2021-01-24', false, 11, 45), + (335, 1000, '2021-01-25', false, 11, 45), + (336, 1000, '2021-01-26', false, 11, 45), + (337, 1000, '2021-01-27', false, 11, 45), + (338, 1500, '2021-01-28', false, 11, 45), + (339, 1500, '2021-01-29', false, 11, 45), + (340, 1000, '2021-01-30', true, 11, 45), + (341, 1000, '2021-01-31', true, 11, 45), + (342, 1500, '2021-01-01', false, 12, 35), + (343, 1000, '2021-01-02', false, 12, 35), + (344, 1000, '2021-01-03', false, 12, 35), + (345, 1000, '2021-01-04', false, 12, 35), + (346, 1000, '2021-01-05', false, 12, 35), + (347, 1000, '2021-01-06', false, 12, 35), + (348, 1500, '2021-01-07', false, 12, 35), + (349, 1500, '2021-01-08', false, 12, 35), + (350, 1000, '2021-01-09', false, 12, 35), + (351, 1000, '2021-01-10', true, 12, 35), + (352, 1000, '2021-01-11', true, 12, 35), + (353, 1000, '2021-01-12', false, 12, 35), + (354, 1000, '2021-01-13', false, 12, 35), + (355, 1500, '2021-01-14', true, 12, 35), + (356, 1500, '2021-01-15', false, 12, 35), + (357, 1000, '2021-01-16', false, 12, 35), + (358, 1000, '2021-01-17', false, 12, 35), + (359, 1000, '2021-01-18', true, 12, 35), + (360, 1000, '2021-01-19', false, 12, 35), + (361, 1000, '2021-01-20', false, 12, 35), + (362, 1500, '2021-01-21', false, 12, 35), + (363, 1500, '2021-01-22', false, 12, 35), + (364, 1000, '2021-01-23', true, 12, 35), + (365, 1000, '2021-01-24', false, 12, 35), + (366, 1000, '2021-01-25', true, 12, 35), + (367, 1000, '2021-01-26', true, 12, 35), + (368, 1000, '2021-01-27', false, 12, 35), + (369, 1500, '2021-01-28', false, 12, 35), + (370, 1500, '2021-01-29', false, 12, 35), + (371, 1000, '2021-01-30', false, 12, 35), + (372, 1000, '2021-01-31', false, 12, 35), + (373, 1500, '2021-01-01', false, 13, 13), + (374, 1000, '2021-01-02', true, 13, 13), + (375, 1000, '2021-01-03', false, 13, 13), + (376, 1000, '2021-01-04', false, 13, 13), + (377, 1000, '2021-01-05', false, 13, 13), + (378, 1000, '2021-01-06', false, 13, 13), + (379, 1500, '2021-01-07', false, 13, 13), + (380, 1500, '2021-01-08', false, 13, 13), + (381, 1000, '2021-01-09', false, 13, 13), + (382, 1000, '2021-01-10', true, 13, 13), + (383, 1000, '2021-01-11', false, 13, 13), + (384, 1000, '2021-01-12', true, 13, 13), + (385, 1000, '2021-01-13', false, 13, 13), + (386, 1500, '2021-01-14', false, 13, 13), + (387, 1500, '2021-01-15', false, 13, 13), + (388, 1000, '2021-01-16', true, 13, 13), + (389, 1000, '2021-01-17', false, 13, 13), + (390, 1000, '2021-01-18', false, 13, 13), + (391, 1000, '2021-01-19', false, 13, 13), + (392, 1000, '2021-01-20', false, 13, 13), + (393, 1500, '2021-01-21', false, 13, 13), + (394, 1500, '2021-01-22', false, 13, 13), + (395, 1000, '2021-01-23', false, 13, 13), + (396, 1000, '2021-01-24', false, 13, 13), + (397, 1000, '2021-01-25', true, 13, 13), + (398, 1000, '2021-01-26', false, 13, 13), + (399, 1000, '2021-01-27', false, 13, 13), + (400, 1500, '2021-01-28', true, 13, 13), + (401, 1500, '2021-01-29', false, 13, 13), + (402, 1000, '2021-01-30', false, 13, 13), + (403, 1000, '2021-01-31', true, 13, 13), + (404, 1500, '2021-01-01', false, 14, 82), + (405, 1000, '2021-01-02', false, 14, 82), + (406, 1000, '2021-01-03', true, 14, 82), + (407, 1000, '2021-01-04', true, 14, 82), + (408, 1000, '2021-01-05', true, 14, 82), + (409, 1000, '2021-01-06', true, 14, 82), + (410, 1500, '2021-01-07', true, 14, 82), + (411, 1500, '2021-01-08', false, 14, 82), + (412, 1000, '2021-01-09', false, 14, 82), + (413, 1000, '2021-01-10', true, 14, 82), + (414, 1000, '2021-01-11', false, 14, 82), + (415, 1000, '2021-01-12', false, 14, 82), + (416, 1000, '2021-01-13', false, 14, 82), + (417, 1500, '2021-01-14', false, 14, 82), + (418, 1500, '2021-01-15', false, 14, 82), + (419, 1000, '2021-01-16', true, 14, 82), + (420, 1000, '2021-01-17', false, 14, 82), + (421, 1000, '2021-01-18', false, 14, 82), + (422, 1000, '2021-01-19', false, 14, 82), + (423, 1000, '2021-01-20', false, 14, 82), + (424, 1500, '2021-01-21', false, 14, 82), + (425, 1500, '2021-01-22', false, 14, 82), + (426, 1000, '2021-01-23', true, 14, 82), + (427, 1000, '2021-01-24', false, 14, 82), + (428, 1000, '2021-01-25', false, 14, 82), + (429, 1000, '2021-01-26', false, 14, 82), + (430, 1000, '2021-01-27', false, 14, 82), + (431, 1500, '2021-01-28', false, 14, 82), + (432, 1500, '2021-01-29', false, 14, 82), + (433, 1000, '2021-01-30', true, 14, 82), + (434, 1000, '2021-01-31', false, 14, 82), + (435, 1500, '2021-01-01', false, 15, 64), + (436, 1000, '2021-01-02', false, 15, 64), + (437, 1000, '2021-01-03', false, 15, 64), + (438, 1000, '2021-01-04', false, 15, 64), + (439, 1000, '2021-01-05', false, 15, 64), + (440, 1000, '2021-01-06', false, 15, 64), + (441, 1500, '2021-01-07', false, 15, 64), + (442, 1500, '2021-01-08', false, 15, 64), + (443, 1000, '2021-01-09', false, 15, 64), + (444, 1000, '2021-01-10', true, 15, 64), + (445, 1000, '2021-01-11', false, 15, 64), + (446, 1000, '2021-01-12', false, 15, 64), + (447, 1000, '2021-01-13', false, 15, 64), + (448, 1500, '2021-01-14', true, 15, 64), + (449, 1500, '2021-01-15', true, 15, 64), + (450, 1000, '2021-01-16', false, 15, 64), + (451, 1000, '2021-01-17', false, 15, 64), + (452, 1000, '2021-01-18', true, 15, 64), + (453, 1000, '2021-01-19', true, 15, 64), + (454, 1000, '2021-01-20', true, 15, 64), + (455, 1500, '2021-01-21', false, 15, 64), + (456, 1500, '2021-01-22', false, 15, 64), + (457, 1000, '2021-01-23', false, 15, 64), + (458, 1000, '2021-01-24', false, 15, 64), + (459, 1000, '2021-01-25', false, 15, 64), + (460, 1000, '2021-01-26', false, 15, 64), + (461, 1000, '2021-01-27', true, 15, 64), + (462, 1500, '2021-01-28', false, 15, 64), + (463, 1500, '2021-01-29', false, 15, 64), + (464, 1000, '2021-01-30', false, 15, 64), + (465, 1000, '2021-01-31', true, 15, 64), + (466, 1500, '2021-01-01', false, 16, 45), + (467, 1000, '2021-01-02', false, 16, 45), + (468, 1000, '2021-01-03', true, 16, 45), + (469, 1000, '2021-01-04', true, 16, 45), + (470, 1000, '2021-01-05', false, 16, 45), + (471, 1000, '2021-01-06', false, 16, 45), + (472, 1500, '2021-01-07', false, 16, 45), + (473, 1500, '2021-01-08', false, 16, 45), + (474, 1000, '2021-01-09', false, 16, 45), + (475, 1000, '2021-01-10', false, 16, 45), + (476, 1000, '2021-01-11', false, 16, 45), + (477, 1000, '2021-01-12', false, 16, 45), + (478, 1000, '2021-01-13', true, 16, 45), + (479, 1500, '2021-01-14', true, 16, 45), + (480, 1500, '2021-01-15', true, 16, 45), + (481, 1000, '2021-01-16', true, 16, 45), + (482, 1000, '2021-01-17', false, 16, 45), + (483, 1000, '2021-01-18', false, 16, 45), + (484, 1000, '2021-01-19', false, 16, 45), + (485, 1000, '2021-01-20', false, 16, 45), + (486, 1500, '2021-01-21', false, 16, 45), + (487, 1500, '2021-01-22', false, 16, 45), + (488, 1000, '2021-01-23', true, 16, 45), + (489, 1000, '2021-01-24', false, 16, 45), + (490, 1000, '2021-01-25', true, 16, 45), + (491, 1000, '2021-01-26', false, 16, 45), + (492, 1000, '2021-01-27', false, 16, 45), + (493, 1500, '2021-01-28', true, 16, 45), + (494, 1500, '2021-01-29', false, 16, 45), + (495, 1000, '2021-01-30', false, 16, 45), + (496, 1000, '2021-01-31', false, 16, 45), + (497, 1500, '2021-01-01', true, 17, 9), + (498, 1000, '2021-01-02', false, 17, 9), + (499, 1000, '2021-01-03', true, 17, 9), + (500, 1000, '2021-01-04', true, 17, 9), + (501, 1000, '2021-01-05', true, 17, 9), + (502, 1000, '2021-01-06', false, 17, 9), + (503, 1500, '2021-01-07', true, 17, 9), + (504, 1500, '2021-01-08', false, 17, 9), + (505, 1000, '2021-01-09', false, 17, 9), + (506, 1000, '2021-01-10', false, 17, 9), + (507, 1000, '2021-01-11', false, 17, 9), + (508, 1000, '2021-01-12', false, 17, 9), + (509, 1000, '2021-01-13', true, 17, 9), + (510, 1500, '2021-01-14', false, 17, 9), + (511, 1500, '2021-01-15', false, 17, 9), + (512, 1000, '2021-01-16', false, 17, 9), + (513, 1000, '2021-01-17', false, 17, 9), + (514, 1000, '2021-01-18', false, 17, 9), + (515, 1000, '2021-01-19', true, 17, 9), + (516, 1000, '2021-01-20', false, 17, 9), + (517, 1500, '2021-01-21', false, 17, 9), + (518, 1500, '2021-01-22', false, 17, 9), + (519, 1000, '2021-01-23', false, 17, 9), + (520, 1000, '2021-01-24', false, 17, 9), + (521, 1000, '2021-01-25', false, 17, 9), + (522, 1000, '2021-01-26', false, 17, 9), + (523, 1000, '2021-01-27', true, 17, 9), + (524, 1500, '2021-01-28', true, 17, 9), + (525, 1500, '2021-01-29', true, 17, 9), + (526, 1000, '2021-01-30', false, 17, 9), + (527, 1000, '2021-01-31', false, 17, 9), + (528, 1500, '2021-01-01', true, 18, 62), + (529, 1000, '2021-01-02', false, 18, 62), + (530, 1000, '2021-01-03', false, 18, 62), + (531, 1000, '2021-01-04', false, 18, 62), + (532, 1000, '2021-01-05', true, 18, 62), + (533, 1000, '2021-01-06', false, 18, 62), + (534, 1500, '2021-01-07', false, 18, 62), + (535, 1500, '2021-01-08', false, 18, 62), + (536, 1000, '2021-01-09', false, 18, 62), + (537, 1000, '2021-01-10', false, 18, 62), + (538, 1000, '2021-01-11', false, 18, 62), + (539, 1000, '2021-01-12', false, 18, 62), + (540, 1000, '2021-01-13', true, 18, 62), + (541, 1500, '2021-01-14', false, 18, 62), + (542, 1500, '2021-01-15', false, 18, 62), + (543, 1000, '2021-01-16', false, 18, 62), + (544, 1000, '2021-01-17', false, 18, 62), + (545, 1000, '2021-01-18', false, 18, 62), + (546, 1000, '2021-01-19', false, 18, 62), + (547, 1000, '2021-01-20', true, 18, 62), + (548, 1500, '2021-01-21', false, 18, 62), + (549, 1500, '2021-01-22', false, 18, 62), + (550, 1000, '2021-01-23', false, 18, 62), + (551, 1000, '2021-01-24', false, 18, 62), + (552, 1000, '2021-01-25', false, 18, 62), + (553, 1000, '2021-01-26', true, 18, 62), + (554, 1000, '2021-01-27', false, 18, 62), + (555, 1500, '2021-01-28', false, 18, 62), + (556, 1500, '2021-01-29', true, 18, 62), + (557, 1000, '2021-01-30', false, 18, 62), + (558, 1000, '2021-01-31', true, 18, 62), + (559, 1500, '2021-01-01', true, 19, 68), + (560, 1000, '2021-01-02', true, 19, 68), + (561, 1000, '2021-01-03', false, 19, 68), + (562, 1000, '2021-01-04', false, 19, 68), + (563, 1000, '2021-01-05', false, 19, 68), + (564, 1000, '2021-01-06', false, 19, 68), + (565, 1500, '2021-01-07', false, 19, 68), + (566, 1500, '2021-01-08', false, 19, 68), + (567, 1000, '2021-01-09', true, 19, 68), + (568, 1000, '2021-01-10', false, 19, 68), + (569, 1000, '2021-01-11', false, 19, 68), + (570, 1000, '2021-01-12', true, 19, 68), + (571, 1000, '2021-01-13', false, 19, 68), + (572, 1500, '2021-01-14', true, 19, 68), + (573, 1500, '2021-01-15', false, 19, 68), + (574, 1000, '2021-01-16', false, 19, 68), + (575, 1000, '2021-01-17', false, 19, 68), + (576, 1000, '2021-01-18', false, 19, 68), + (577, 1000, '2021-01-19', false, 19, 68), + (578, 1000, '2021-01-20', false, 19, 68), + (579, 1500, '2021-01-21', false, 19, 68), + (580, 1500, '2021-01-22', false, 19, 68), + (581, 1000, '2021-01-23', true, 19, 68), + (582, 1000, '2021-01-24', false, 19, 68), + (583, 1000, '2021-01-25', false, 19, 68), + (584, 1000, '2021-01-26', true, 19, 68), + (585, 1000, '2021-01-27', true, 19, 68), + (586, 1500, '2021-01-28', false, 19, 68), + (587, 1500, '2021-01-29', false, 19, 68), + (588, 1000, '2021-01-30', false, 19, 68), + (589, 1000, '2021-01-31', false, 19, 68), + (590, 1500, '2021-01-01', false, 20, 7), + (591, 1000, '2021-01-02', false, 20, 7), + (592, 1000, '2021-01-03', false, 20, 7), + (593, 1000, '2021-01-04', false, 20, 7), + (594, 1000, '2021-01-05', false, 20, 7), + (595, 1000, '2021-01-06', false, 20, 7), + (596, 1500, '2021-01-07', false, 20, 7), + (597, 1500, '2021-01-08', true, 20, 7), + (598, 1000, '2021-01-09', false, 20, 7), + (599, 1000, '2021-01-10', false, 20, 7), + (600, 1000, '2021-01-11', false, 20, 7), + (601, 1000, '2021-01-12', false, 20, 7), + (602, 1000, '2021-01-13', false, 20, 7), + (603, 1500, '2021-01-14', true, 20, 7), + (604, 1500, '2021-01-15', true, 20, 7), + (605, 1000, '2021-01-16', true, 20, 7), + (606, 1000, '2021-01-17', false, 20, 7), + (607, 1000, '2021-01-18', false, 20, 7), + (608, 1000, '2021-01-19', true, 20, 7), + (609, 1000, '2021-01-20', false, 20, 7), + (610, 1500, '2021-01-21', true, 20, 7), + (611, 1500, '2021-01-22', false, 20, 7), + (612, 1000, '2021-01-23', false, 20, 7), + (613, 1000, '2021-01-24', true, 20, 7), + (614, 1000, '2021-01-25', false, 20, 7), + (615, 1000, '2021-01-26', false, 20, 7), + (616, 1000, '2021-01-27', false, 20, 7), + (617, 1500, '2021-01-28', true, 20, 7), + (618, 1500, '2021-01-29', false, 20, 7), + (619, 1000, '2021-01-30', false, 20, 7), + (620, 1000, '2021-01-31', false, 20, 7), + (621, 1500, '2021-01-01', false, 21, 43), + (622, 1000, '2021-01-02', false, 21, 43), + (623, 1000, '2021-01-03', false, 21, 43), + (624, 1000, '2021-01-04', false, 21, 43), + (625, 1000, '2021-01-05', false, 21, 43), + (626, 1000, '2021-01-06', false, 21, 43), + (627, 1500, '2021-01-07', false, 21, 43), + (628, 1500, '2021-01-08', false, 21, 43), + (629, 1000, '2021-01-09', true, 21, 43), + (630, 1000, '2021-01-10', true, 21, 43), + (631, 1000, '2021-01-11', true, 21, 43), + (632, 1000, '2021-01-12', false, 21, 43), + (633, 1000, '2021-01-13', true, 21, 43), + (634, 1500, '2021-01-14', false, 21, 43), + (635, 1500, '2021-01-15', false, 21, 43), + (636, 1000, '2021-01-16', false, 21, 43), + (637, 1000, '2021-01-17', true, 21, 43), + (638, 1000, '2021-01-18', false, 21, 43), + (639, 1000, '2021-01-19', false, 21, 43), + (640, 1000, '2021-01-20', false, 21, 43), + (641, 1500, '2021-01-21', true, 21, 43), + (642, 1500, '2021-01-22', false, 21, 43), + (643, 1000, '2021-01-23', false, 21, 43), + (644, 1000, '2021-01-24', true, 21, 43), + (645, 1000, '2021-01-25', false, 21, 43), + (646, 1000, '2021-01-26', true, 21, 43), + (647, 1000, '2021-01-27', false, 21, 43), + (648, 1500, '2021-01-28', false, 21, 43), + (649, 1500, '2021-01-29', false, 21, 43), + (650, 1000, '2021-01-30', false, 21, 43), + (651, 1000, '2021-01-31', false, 21, 43), + (652, 1500, '2021-01-01', false, 22, 41), + (653, 1000, '2021-01-02', false, 22, 41), + (654, 1000, '2021-01-03', false, 22, 41), + (655, 1000, '2021-01-04', false, 22, 41), + (656, 1000, '2021-01-05', false, 22, 41), + (657, 1000, '2021-01-06', false, 22, 41), + (658, 1500, '2021-01-07', false, 22, 41), + (659, 1500, '2021-01-08', false, 22, 41), + (660, 1000, '2021-01-09', false, 22, 41), + (661, 1000, '2021-01-10', false, 22, 41), + (662, 1000, '2021-01-11', false, 22, 41), + (663, 1000, '2021-01-12', false, 22, 41), + (664, 1000, '2021-01-13', false, 22, 41), + (665, 1500, '2021-01-14', false, 22, 41), + (666, 1500, '2021-01-15', false, 22, 41), + (667, 1000, '2021-01-16', false, 22, 41), + (668, 1000, '2021-01-17', false, 22, 41), + (669, 1000, '2021-01-18', false, 22, 41), + (670, 1000, '2021-01-19', true, 22, 41), + (671, 1000, '2021-01-20', false, 22, 41), + (672, 1500, '2021-01-21', true, 22, 41), + (673, 1500, '2021-01-22', false, 22, 41), + (674, 1000, '2021-01-23', false, 22, 41), + (675, 1000, '2021-01-24', false, 22, 41), + (676, 1000, '2021-01-25', false, 22, 41), + (677, 1000, '2021-01-26', true, 22, 41), + (678, 1000, '2021-01-27', false, 22, 41), + (679, 1500, '2021-01-28', false, 22, 41), + (680, 1500, '2021-01-29', false, 22, 41), + (681, 1000, '2021-01-30', true, 22, 41), + (682, 1000, '2021-01-31', false, 22, 41), + (683, 1500, '2021-01-01', true, 23, 36), + (684, 1000, '2021-01-02', false, 23, 36), + (685, 1000, '2021-01-03', false, 23, 36), + (686, 1000, '2021-01-04', false, 23, 36), + (687, 1000, '2021-01-05', false, 23, 36), + (688, 1000, '2021-01-06', true, 23, 36), + (689, 1500, '2021-01-07', false, 23, 36), + (690, 1500, '2021-01-08', false, 23, 36), + (691, 1000, '2021-01-09', false, 23, 36), + (692, 1000, '2021-01-10', false, 23, 36), + (693, 1000, '2021-01-11', false, 23, 36), + (694, 1000, '2021-01-12', false, 23, 36), + (695, 1000, '2021-01-13', false, 23, 36), + (696, 1500, '2021-01-14', false, 23, 36), + (697, 1500, '2021-01-15', false, 23, 36), + (698, 1000, '2021-01-16', false, 23, 36), + (699, 1000, '2021-01-17', false, 23, 36), + (700, 1000, '2021-01-18', false, 23, 36), + (701, 1000, '2021-01-19', true, 23, 36), + (702, 1000, '2021-01-20', false, 23, 36), + (703, 1500, '2021-01-21', false, 23, 36), + (704, 1500, '2021-01-22', true, 23, 36), + (705, 1000, '2021-01-23', false, 23, 36), + (706, 1000, '2021-01-24', true, 23, 36), + (707, 1000, '2021-01-25', false, 23, 36), + (708, 1000, '2021-01-26', true, 23, 36), + (709, 1000, '2021-01-27', false, 23, 36), + (710, 1500, '2021-01-28', false, 23, 36), + (711, 1500, '2021-01-29', false, 23, 36), + (712, 1000, '2021-01-30', false, 23, 36), + (713, 1000, '2021-01-31', false, 23, 36), + (714, 1500, '2021-01-01', false, 24, 20), + (715, 1000, '2021-01-02', false, 24, 20), + (716, 1000, '2021-01-03', false, 24, 20), + (717, 1000, '2021-01-04', false, 24, 20), + (718, 1000, '2021-01-05', false, 24, 20), + (719, 1000, '2021-01-06', false, 24, 20), + (720, 1500, '2021-01-07', false, 24, 20), + (721, 1500, '2021-01-08', true, 24, 20), + (722, 1000, '2021-01-09', false, 24, 20), + (723, 1000, '2021-01-10', false, 24, 20), + (724, 1000, '2021-01-11', false, 24, 20), + (725, 1000, '2021-01-12', false, 24, 20), + (726, 1000, '2021-01-13', false, 24, 20), + (727, 1500, '2021-01-14', false, 24, 20), + (728, 1500, '2021-01-15', true, 24, 20), + (729, 1000, '2021-01-16', true, 24, 20), + (730, 1000, '2021-01-17', false, 24, 20), + (731, 1000, '2021-01-18', false, 24, 20), + (732, 1000, '2021-01-19', false, 24, 20), + (733, 1000, '2021-01-20', false, 24, 20), + (734, 1500, '2021-01-21', false, 24, 20), + (735, 1500, '2021-01-22', false, 24, 20), + (736, 1000, '2021-01-23', false, 24, 20), + (737, 1000, '2021-01-24', false, 24, 20), + (738, 1000, '2021-01-25', false, 24, 20), + (739, 1000, '2021-01-26', true, 24, 20), + (740, 1000, '2021-01-27', false, 24, 20), + (741, 1500, '2021-01-28', true, 24, 20), + (742, 1500, '2021-01-29', false, 24, 20), + (743, 1000, '2021-01-30', false, 24, 20), + (744, 1000, '2021-01-31', false, 24, 20), + (745, 1500, '2021-01-01', false, 25, 25), + (746, 1000, '2021-01-02', true, 25, 25), + (747, 1000, '2021-01-03', false, 25, 25), + (748, 1000, '2021-01-04', false, 25, 25), + (749, 1000, '2021-01-05', false, 25, 25), + (750, 1000, '2021-01-06', true, 25, 25), + (751, 1500, '2021-01-07', false, 25, 25), + (752, 1500, '2021-01-08', true, 25, 25), + (753, 1000, '2021-01-09', false, 25, 25), + (754, 1000, '2021-01-10', true, 25, 25), + (755, 1000, '2021-01-11', false, 25, 25), + (756, 1000, '2021-01-12', true, 25, 25), + (757, 1000, '2021-01-13', false, 25, 25), + (758, 1500, '2021-01-14', false, 25, 25), + (759, 1500, '2021-01-15', false, 25, 25), + (760, 1000, '2021-01-16', false, 25, 25), + (761, 1000, '2021-01-17', false, 25, 25), + (762, 1000, '2021-01-18', false, 25, 25), + (763, 1000, '2021-01-19', false, 25, 25), + (764, 1000, '2021-01-20', true, 25, 25), + (765, 1500, '2021-01-21', true, 25, 25), + (766, 1500, '2021-01-22', false, 25, 25), + (767, 1000, '2021-01-23', false, 25, 25), + (768, 1000, '2021-01-24', false, 25, 25), + (769, 1000, '2021-01-25', false, 25, 25), + (770, 1000, '2021-01-26', false, 25, 25), + (771, 1000, '2021-01-27', false, 25, 25), + (772, 1500, '2021-01-28', false, 25, 25), + (773, 1500, '2021-01-29', false, 25, 25), + (774, 1000, '2021-01-30', false, 25, 25), + (775, 1000, '2021-01-31', true, 25, 25), + (776, 1500, '2021-01-01', false, 26, 16), + (777, 1000, '2021-01-02', true, 26, 16), + (778, 1000, '2021-01-03', false, 26, 16), + (779, 1000, '2021-01-04', false, 26, 16), + (780, 1000, '2021-01-05', true, 26, 16), + (781, 1000, '2021-01-06', false, 26, 16), + (782, 1500, '2021-01-07', false, 26, 16), + (783, 1500, '2021-01-08', true, 26, 16), + (784, 1000, '2021-01-09', false, 26, 16), + (785, 1000, '2021-01-10', false, 26, 16), + (786, 1000, '2021-01-11', false, 26, 16), + (787, 1000, '2021-01-12', false, 26, 16), + (788, 1000, '2021-01-13', true, 26, 16), + (789, 1500, '2021-01-14', false, 26, 16), + (790, 1500, '2021-01-15', true, 26, 16), + (791, 1000, '2021-01-16', true, 26, 16), + (792, 1000, '2021-01-17', false, 26, 16), + (793, 1000, '2021-01-18', false, 26, 16), + (794, 1000, '2021-01-19', true, 26, 16), + (795, 1000, '2021-01-20', true, 26, 16), + (796, 1500, '2021-01-21', false, 26, 16), + (797, 1500, '2021-01-22', true, 26, 16), + (798, 1000, '2021-01-23', true, 26, 16), + (799, 1000, '2021-01-24', false, 26, 16), + (800, 1000, '2021-01-25', true, 26, 16), + (801, 1000, '2021-01-26', false, 26, 16), + (802, 1000, '2021-01-27', false, 26, 16), + (803, 1500, '2021-01-28', true, 26, 16), + (804, 1500, '2021-01-29', false, 26, 16), + (805, 1000, '2021-01-30', true, 26, 16), + (806, 1000, '2021-01-31', true, 26, 16), + (807, 1500, '2021-01-01', false, 27, 8), + (808, 1000, '2021-01-02', false, 27, 8), + (809, 1000, '2021-01-03', false, 27, 8), + (810, 1000, '2021-01-04', true, 27, 8), + (811, 1000, '2021-01-05', false, 27, 8), + (812, 1000, '2021-01-06', true, 27, 8), + (813, 1500, '2021-01-07', false, 27, 8), + (814, 1500, '2021-01-08', false, 27, 8), + (815, 1000, '2021-01-09', false, 27, 8), + (816, 1000, '2021-01-10', false, 27, 8), + (817, 1000, '2021-01-11', false, 27, 8), + (818, 1000, '2021-01-12', false, 27, 8), + (819, 1000, '2021-01-13', true, 27, 8), + (820, 1500, '2021-01-14', false, 27, 8), + (821, 1500, '2021-01-15', false, 27, 8), + (822, 1000, '2021-01-16', true, 27, 8), + (823, 1000, '2021-01-17', false, 27, 8), + (824, 1000, '2021-01-18', false, 27, 8), + (825, 1000, '2021-01-19', true, 27, 8), + (826, 1000, '2021-01-20', false, 27, 8), + (827, 1500, '2021-01-21', false, 27, 8), + (828, 1500, '2021-01-22', true, 27, 8), + (829, 1000, '2021-01-23', false, 27, 8), + (830, 1000, '2021-01-24', true, 27, 8), + (831, 1000, '2021-01-25', true, 27, 8), + (832, 1000, '2021-01-26', false, 27, 8), + (833, 1000, '2021-01-27', false, 27, 8), + (834, 1500, '2021-01-28', false, 27, 8), + (835, 1500, '2021-01-29', false, 27, 8), + (836, 1000, '2021-01-30', false, 27, 8), + (837, 1000, '2021-01-31', true, 27, 8), + (838, 1500, '2021-01-01', false, 28, 64), + (839, 1000, '2021-01-02', true, 28, 64), + (840, 1000, '2021-01-03', false, 28, 64), + (841, 1000, '2021-01-04', true, 28, 64), + (842, 1000, '2021-01-05', false, 28, 64), + (843, 1000, '2021-01-06', false, 28, 64), + (844, 1500, '2021-01-07', false, 28, 64), + (845, 1500, '2021-01-08', false, 28, 64), + (846, 1000, '2021-01-09', false, 28, 64), + (847, 1000, '2021-01-10', false, 28, 64), + (848, 1000, '2021-01-11', false, 28, 64), + (849, 1000, '2021-01-12', true, 28, 64), + (850, 1000, '2021-01-13', false, 28, 64), + (851, 1500, '2021-01-14', false, 28, 64), + (852, 1500, '2021-01-15', false, 28, 64), + (853, 1000, '2021-01-16', false, 28, 64), + (854, 1000, '2021-01-17', false, 28, 64), + (855, 1000, '2021-01-18', false, 28, 64), + (856, 1000, '2021-01-19', true, 28, 64), + (857, 1000, '2021-01-20', false, 28, 64), + (858, 1500, '2021-01-21', false, 28, 64), + (859, 1500, '2021-01-22', false, 28, 64), + (860, 1000, '2021-01-23', false, 28, 64), + (861, 1000, '2021-01-24', false, 28, 64), + (862, 1000, '2021-01-25', false, 28, 64), + (863, 1000, '2021-01-26', false, 28, 64), + (864, 1000, '2021-01-27', true, 28, 64), + (865, 1500, '2021-01-28', true, 28, 64), + (866, 1500, '2021-01-29', false, 28, 64), + (867, 1000, '2021-01-30', false, 28, 64), + (868, 1000, '2021-01-31', false, 28, 64), + (869, 1500, '2021-01-01', true, 29, 81), + (870, 1000, '2021-01-02', false, 29, 81), + (871, 1000, '2021-01-03', false, 29, 81), + (872, 1000, '2021-01-04', false, 29, 81), + (873, 1000, '2021-01-05', false, 29, 81), + (874, 1000, '2021-01-06', false, 29, 81), + (875, 1500, '2021-01-07', true, 29, 81), + (876, 1500, '2021-01-08', false, 29, 81), + (877, 1000, '2021-01-09', false, 29, 81), + (878, 1000, '2021-01-10', false, 29, 81), + (879, 1000, '2021-01-11', false, 29, 81), + (880, 1000, '2021-01-12', false, 29, 81), + (881, 1000, '2021-01-13', false, 29, 81), + (882, 1500, '2021-01-14', false, 29, 81), + (883, 1500, '2021-01-15', false, 29, 81), + (884, 1000, '2021-01-16', true, 29, 81), + (885, 1000, '2021-01-17', false, 29, 81), + (886, 1000, '2021-01-18', false, 29, 81), + (887, 1000, '2021-01-19', true, 29, 81), + (888, 1000, '2021-01-20', true, 29, 81), + (889, 1500, '2021-01-21', false, 29, 81), + (890, 1500, '2021-01-22', false, 29, 81), + (891, 1000, '2021-01-23', false, 29, 81), + (892, 1000, '2021-01-24', false, 29, 81), + (893, 1000, '2021-01-25', false, 29, 81), + (894, 1000, '2021-01-26', false, 29, 81), + (895, 1000, '2021-01-27', false, 29, 81), + (896, 1500, '2021-01-28', false, 29, 81), + (897, 1500, '2021-01-29', false, 29, 81), + (898, 1000, '2021-01-30', true, 29, 81), + (899, 1000, '2021-01-31', false, 29, 81), + (900, 1500, '2021-01-01', true, 30, 15), + (901, 1000, '2021-01-02', false, 30, 15), + (902, 1000, '2021-01-03', false, 30, 15), + (903, 1000, '2021-01-04', true, 30, 15), + (904, 1000, '2021-01-05', false, 30, 15), + (905, 1000, '2021-01-06', false, 30, 15), + (906, 1500, '2021-01-07', false, 30, 15), + (907, 1500, '2021-01-08', false, 30, 15), + (908, 1000, '2021-01-09', false, 30, 15), + (909, 1000, '2021-01-10', false, 30, 15), + (910, 1000, '2021-01-11', false, 30, 15), + (911, 1000, '2021-01-12', false, 30, 15), + (912, 1000, '2021-01-13', true, 30, 15), + (913, 1500, '2021-01-14', false, 30, 15), + (914, 1500, '2021-01-15', true, 30, 15), + (915, 1000, '2021-01-16', false, 30, 15), + (916, 1000, '2021-01-17', false, 30, 15), + (917, 1000, '2021-01-18', false, 30, 15), + (918, 1000, '2021-01-19', false, 30, 15), + (919, 1000, '2021-01-20', true, 30, 15), + (920, 1500, '2021-01-21', true, 30, 15), + (921, 1500, '2021-01-22', false, 30, 15), + (922, 1000, '2021-01-23', false, 30, 15), + (923, 1000, '2021-01-24', false, 30, 15), + (924, 1000, '2021-01-25', false, 30, 15), + (925, 1000, '2021-01-26', false, 30, 15), + (926, 1000, '2021-01-27', true, 30, 15), + (927, 1500, '2021-01-28', false, 30, 15), + (928, 1500, '2021-01-29', false, 30, 15), + (929, 1000, '2021-01-30', false, 30, 15), + (930, 1000, '2021-01-31', false, 30, 15), + (931, 1500, '2021-01-01', false, 31, 28), + (932, 1000, '2021-01-02', false, 31, 28), + (933, 1000, '2021-01-03', false, 31, 28), + (934, 1000, '2021-01-04', false, 31, 28), + (935, 1000, '2021-01-05', true, 31, 28), + (936, 1000, '2021-01-06', false, 31, 28), + (937, 1500, '2021-01-07', true, 31, 28), + (938, 1500, '2021-01-08', false, 31, 28), + (939, 1000, '2021-01-09', false, 31, 28), + (940, 1000, '2021-01-10', false, 31, 28), + (941, 1000, '2021-01-11', false, 31, 28), + (942, 1000, '2021-01-12', false, 31, 28), + (943, 1000, '2021-01-13', false, 31, 28), + (944, 1500, '2021-01-14', false, 31, 28), + (945, 1500, '2021-01-15', false, 31, 28), + (946, 1000, '2021-01-16', false, 31, 28), + (947, 1000, '2021-01-17', false, 31, 28), + (948, 1000, '2021-01-18', false, 31, 28), + (949, 1000, '2021-01-19', false, 31, 28), + (950, 1000, '2021-01-20', false, 31, 28), + (951, 1500, '2021-01-21', false, 31, 28), + (952, 1500, '2021-01-22', false, 31, 28), + (953, 1000, '2021-01-23', false, 31, 28), + (954, 1000, '2021-01-24', false, 31, 28), + (955, 1000, '2021-01-25', true, 31, 28), + (956, 1000, '2021-01-26', false, 31, 28), + (957, 1000, '2021-01-27', false, 31, 28), + (958, 1500, '2021-01-28', false, 31, 28), + (959, 1500, '2021-01-29', true, 31, 28), + (960, 1000, '2021-01-30', true, 31, 28), + (961, 1000, '2021-01-31', false, 31, 28), + (962, 1500, '2021-01-01', false, 32, 71), + (963, 1000, '2021-01-02', false, 32, 71), + (964, 1000, '2021-01-03', false, 32, 71), + (965, 1000, '2021-01-04', false, 32, 71), + (966, 1000, '2021-01-05', false, 32, 71), + (967, 1000, '2021-01-06', false, 32, 71), + (968, 1500, '2021-01-07', true, 32, 71), + (969, 1500, '2021-01-08', true, 32, 71), + (970, 1000, '2021-01-09', true, 32, 71), + (971, 1000, '2021-01-10', false, 32, 71), + (972, 1000, '2021-01-11', true, 32, 71), + (973, 1000, '2021-01-12', false, 32, 71), + (974, 1000, '2021-01-13', false, 32, 71), + (975, 1500, '2021-01-14', false, 32, 71), + (976, 1500, '2021-01-15', false, 32, 71), + (977, 1000, '2021-01-16', false, 32, 71), + (978, 1000, '2021-01-17', false, 32, 71), + (979, 1000, '2021-01-18', false, 32, 71), + (980, 1000, '2021-01-19', false, 32, 71), + (981, 1000, '2021-01-20', true, 32, 71), + (982, 1500, '2021-01-21', true, 32, 71), + (983, 1500, '2021-01-22', true, 32, 71), + (984, 1000, '2021-01-23', false, 32, 71), + (985, 1000, '2021-01-24', true, 32, 71), + (986, 1000, '2021-01-25', true, 32, 71), + (987, 1000, '2021-01-26', false, 32, 71), + (988, 1000, '2021-01-27', true, 32, 71), + (989, 1500, '2021-01-28', true, 32, 71), + (990, 1500, '2021-01-29', false, 32, 71), + (991, 1000, '2021-01-30', false, 32, 71), + (992, 1000, '2021-01-31', false, 32, 71), + (993, 1500, '2021-01-01', false, 33, 81), + (994, 1000, '2021-01-02', false, 33, 81), + (995, 1000, '2021-01-03', true, 33, 81), + (996, 1000, '2021-01-04', true, 33, 81), + (997, 1000, '2021-01-05', false, 33, 81), + (998, 1000, '2021-01-06', false, 33, 81), + (999, 1500, '2021-01-07', true, 33, 81), + (1000, 1500, '2021-01-08', true, 33, 81), + (1001, 1000, '2021-01-09', false, 33, 81), + (1002, 1000, '2021-01-10', false, 33, 81), + (1003, 1000, '2021-01-11', false, 33, 81), + (1004, 1000, '2021-01-12', false, 33, 81), + (1005, 1000, '2021-01-13', false, 33, 81), + (1006, 1500, '2021-01-14', false, 33, 81), + (1007, 1500, '2021-01-15', true, 33, 81), + (1008, 1000, '2021-01-16', false, 33, 81), + (1009, 1000, '2021-01-17', true, 33, 81), + (1010, 1000, '2021-01-18', false, 33, 81), + (1011, 1000, '2021-01-19', false, 33, 81), + (1012, 1000, '2021-01-20', true, 33, 81), + (1013, 1500, '2021-01-21', false, 33, 81), + (1014, 1500, '2021-01-22', false, 33, 81), + (1015, 1000, '2021-01-23', false, 33, 81), + (1016, 1000, '2021-01-24', false, 33, 81), + (1017, 1000, '2021-01-25', false, 33, 81), + (1018, 1000, '2021-01-26', false, 33, 81), + (1019, 1000, '2021-01-27', true, 33, 81), + (1020, 1500, '2021-01-28', false, 33, 81), + (1021, 1500, '2021-01-29', false, 33, 81), + (1022, 1000, '2021-01-30', false, 33, 81), + (1023, 1000, '2021-01-31', false, 33, 81), + (1024, 1500, '2021-01-01', false, 34, 8), + (1025, 1000, '2021-01-02', false, 34, 8), + (1026, 1000, '2021-01-03', true, 34, 8), + (1027, 1000, '2021-01-04', false, 34, 8), + (1028, 1000, '2021-01-05', false, 34, 8), + (1029, 1000, '2021-01-06', false, 34, 8), + (1030, 1500, '2021-01-07', false, 34, 8), + (1031, 1500, '2021-01-08', true, 34, 8), + (1032, 1000, '2021-01-09', false, 34, 8), + (1033, 1000, '2021-01-10', true, 34, 8), + (1034, 1000, '2021-01-11', false, 34, 8), + (1035, 1000, '2021-01-12', false, 34, 8), + (1036, 1000, '2021-01-13', true, 34, 8), + (1037, 1500, '2021-01-14', false, 34, 8), + (1038, 1500, '2021-01-15', false, 34, 8), + (1039, 1000, '2021-01-16', false, 34, 8), + (1040, 1000, '2021-01-17', false, 34, 8), + (1041, 1000, '2021-01-18', false, 34, 8), + (1042, 1000, '2021-01-19', true, 34, 8), + (1043, 1000, '2021-01-20', false, 34, 8), + (1044, 1500, '2021-01-21', false, 34, 8), + (1045, 1500, '2021-01-22', false, 34, 8), + (1046, 1000, '2021-01-23', true, 34, 8), + (1047, 1000, '2021-01-24', false, 34, 8), + (1048, 1000, '2021-01-25', false, 34, 8), + (1049, 1000, '2021-01-26', false, 34, 8), + (1050, 1000, '2021-01-27', true, 34, 8), + (1051, 1500, '2021-01-28', true, 34, 8), + (1052, 1500, '2021-01-29', true, 34, 8), + (1053, 1000, '2021-01-30', false, 34, 8), + (1054, 1000, '2021-01-31', false, 34, 8), + (1055, 1500, '2021-01-01', false, 35, 3), + (1056, 1000, '2021-01-02', false, 35, 3), + (1057, 1000, '2021-01-03', false, 35, 3), + (1058, 1000, '2021-01-04', true, 35, 3), + (1059, 1000, '2021-01-05', false, 35, 3), + (1060, 1000, '2021-01-06', false, 35, 3), + (1061, 1500, '2021-01-07', false, 35, 3), + (1062, 1500, '2021-01-08', true, 35, 3), + (1063, 1000, '2021-01-09', false, 35, 3), + (1064, 1000, '2021-01-10', false, 35, 3), + (1065, 1000, '2021-01-11', false, 35, 3), + (1066, 1000, '2021-01-12', false, 35, 3), + (1067, 1000, '2021-01-13', false, 35, 3), + (1068, 1500, '2021-01-14', false, 35, 3), + (1069, 1500, '2021-01-15', false, 35, 3), + (1070, 1000, '2021-01-16', false, 35, 3), + (1071, 1000, '2021-01-17', false, 35, 3), + (1072, 1000, '2021-01-18', true, 35, 3), + (1073, 1000, '2021-01-19', true, 35, 3), + (1074, 1000, '2021-01-20', false, 35, 3), + (1075, 1500, '2021-01-21', false, 35, 3), + (1076, 1500, '2021-01-22', false, 35, 3), + (1077, 1000, '2021-01-23', false, 35, 3), + (1078, 1000, '2021-01-24', false, 35, 3), + (1079, 1000, '2021-01-25', true, 35, 3), + (1080, 1000, '2021-01-26', false, 35, 3), + (1081, 1000, '2021-01-27', false, 35, 3), + (1082, 1500, '2021-01-28', false, 35, 3), + (1083, 1500, '2021-01-29', false, 35, 3), + (1084, 1000, '2021-01-30', false, 35, 3), + (1085, 1000, '2021-01-31', false, 35, 3), + (1086, 1500, '2021-01-01', false, 36, 51), + (1087, 1000, '2021-01-02', false, 36, 51), + (1088, 1000, '2021-01-03', false, 36, 51), + (1089, 1000, '2021-01-04', false, 36, 51), + (1090, 1000, '2021-01-05', true, 36, 51), + (1091, 1000, '2021-01-06', false, 36, 51), + (1092, 1500, '2021-01-07', false, 36, 51), + (1093, 1500, '2021-01-08', false, 36, 51), + (1094, 1000, '2021-01-09', false, 36, 51), + (1095, 1000, '2021-01-10', false, 36, 51), + (1096, 1000, '2021-01-11', false, 36, 51), + (1097, 1000, '2021-01-12', false, 36, 51), + (1098, 1000, '2021-01-13', false, 36, 51), + (1099, 1500, '2021-01-14', false, 36, 51), + (1100, 1500, '2021-01-15', false, 36, 51), + (1101, 1000, '2021-01-16', false, 36, 51), + (1102, 1000, '2021-01-17', false, 36, 51), + (1103, 1000, '2021-01-18', true, 36, 51), + (1104, 1000, '2021-01-19', true, 36, 51), + (1105, 1000, '2021-01-20', false, 36, 51), + (1106, 1500, '2021-01-21', false, 36, 51), + (1107, 1500, '2021-01-22', true, 36, 51), + (1108, 1000, '2021-01-23', true, 36, 51), + (1109, 1000, '2021-01-24', false, 36, 51), + (1110, 1000, '2021-01-25', false, 36, 51), + (1111, 1000, '2021-01-26', false, 36, 51), + (1112, 1000, '2021-01-27', false, 36, 51), + (1113, 1500, '2021-01-28', false, 36, 51), + (1114, 1500, '2021-01-29', true, 36, 51), + (1115, 1000, '2021-01-30', false, 36, 51), + (1116, 1000, '2021-01-31', false, 36, 51), + (1117, 1500, '2021-01-01', false, 37, 73), + (1118, 1000, '2021-01-02', false, 37, 73), + (1119, 1000, '2021-01-03', false, 37, 73), + (1120, 1000, '2021-01-04', false, 37, 73), + (1121, 1000, '2021-01-05', false, 37, 73), + (1122, 1000, '2021-01-06', false, 37, 73), + (1123, 1500, '2021-01-07', false, 37, 73), + (1124, 1500, '2021-01-08', false, 37, 73), + (1125, 1000, '2021-01-09', false, 37, 73), + (1126, 1000, '2021-01-10', false, 37, 73), + (1127, 1000, '2021-01-11', false, 37, 73), + (1128, 1000, '2021-01-12', false, 37, 73), + (1129, 1000, '2021-01-13', false, 37, 73), + (1130, 1500, '2021-01-14', false, 37, 73), + (1131, 1500, '2021-01-15', false, 37, 73), + (1132, 1000, '2021-01-16', true, 37, 73), + (1133, 1000, '2021-01-17', false, 37, 73), + (1134, 1000, '2021-01-18', false, 37, 73), + (1135, 1000, '2021-01-19', false, 37, 73), + (1136, 1000, '2021-01-20', false, 37, 73), + (1137, 1500, '2021-01-21', false, 37, 73), + (1138, 1500, '2021-01-22', false, 37, 73), + (1139, 1000, '2021-01-23', false, 37, 73), + (1140, 1000, '2021-01-24', false, 37, 73), + (1141, 1000, '2021-01-25', false, 37, 73), + (1142, 1000, '2021-01-26', false, 37, 73), + (1143, 1000, '2021-01-27', false, 37, 73), + (1144, 1500, '2021-01-28', false, 37, 73), + (1145, 1500, '2021-01-29', false, 37, 73), + (1146, 1000, '2021-01-30', false, 37, 73), + (1147, 1000, '2021-01-31', false, 37, 73), + (1148, 1500, '2021-01-01', false, 38, 32), + (1149, 1000, '2021-01-02', true, 38, 32), + (1150, 1000, '2021-01-03', false, 38, 32), + (1151, 1000, '2021-01-04', false, 38, 32), + (1152, 1000, '2021-01-05', false, 38, 32), + (1153, 1000, '2021-01-06', true, 38, 32), + (1154, 1500, '2021-01-07', false, 38, 32), + (1155, 1500, '2021-01-08', true, 38, 32), + (1156, 1000, '2021-01-09', true, 38, 32), + (1157, 1000, '2021-01-10', true, 38, 32), + (1158, 1000, '2021-01-11', false, 38, 32), + (1159, 1000, '2021-01-12', false, 38, 32), + (1160, 1000, '2021-01-13', true, 38, 32), + (1161, 1500, '2021-01-14', false, 38, 32), + (1162, 1500, '2021-01-15', false, 38, 32), + (1163, 1000, '2021-01-16', false, 38, 32), + (1164, 1000, '2021-01-17', false, 38, 32), + (1165, 1000, '2021-01-18', false, 38, 32), + (1166, 1000, '2021-01-19', false, 38, 32), + (1167, 1000, '2021-01-20', false, 38, 32), + (1168, 1500, '2021-01-21', false, 38, 32), + (1169, 1500, '2021-01-22', false, 38, 32), + (1170, 1000, '2021-01-23', false, 38, 32), + (1171, 1000, '2021-01-24', true, 38, 32), + (1172, 1000, '2021-01-25', true, 38, 32), + (1173, 1000, '2021-01-26', false, 38, 32), + (1174, 1000, '2021-01-27', false, 38, 32), + (1175, 1500, '2021-01-28', false, 38, 32), + (1176, 1500, '2021-01-29', false, 38, 32), + (1177, 1000, '2021-01-30', true, 38, 32), + (1178, 1000, '2021-01-31', false, 38, 32), + (1179, 1500, '2021-01-01', false, 39, 55), + (1180, 1000, '2021-01-02', false, 39, 55), + (1181, 1000, '2021-01-03', false, 39, 55), + (1182, 1000, '2021-01-04', false, 39, 55), + (1183, 1000, '2021-01-05', true, 39, 55), + (1184, 1000, '2021-01-06', false, 39, 55), + (1185, 1500, '2021-01-07', true, 39, 55), + (1186, 1500, '2021-01-08', false, 39, 55), + (1187, 1000, '2021-01-09', false, 39, 55), + (1188, 1000, '2021-01-10', true, 39, 55), + (1189, 1000, '2021-01-11', false, 39, 55), + (1190, 1000, '2021-01-12', false, 39, 55), + (1191, 1000, '2021-01-13', false, 39, 55), + (1192, 1500, '2021-01-14', false, 39, 55), + (1193, 1500, '2021-01-15', false, 39, 55), + (1194, 1000, '2021-01-16', false, 39, 55), + (1195, 1000, '2021-01-17', false, 39, 55), + (1196, 1000, '2021-01-18', false, 39, 55), + (1197, 1000, '2021-01-19', false, 39, 55), + (1198, 1000, '2021-01-20', false, 39, 55), + (1199, 1500, '2021-01-21', false, 39, 55), + (1200, 1500, '2021-01-22', false, 39, 55), + (1201, 1000, '2021-01-23', true, 39, 55), + (1202, 1000, '2021-01-24', true, 39, 55), + (1203, 1000, '2021-01-25', false, 39, 55), + (1204, 1000, '2021-01-26', false, 39, 55), + (1205, 1000, '2021-01-27', true, 39, 55), + (1206, 1500, '2021-01-28', false, 39, 55), + (1207, 1500, '2021-01-29', false, 39, 55), + (1208, 1000, '2021-01-30', false, 39, 55), + (1209, 1000, '2021-01-31', false, 39, 55), + (1210, 1500, '2021-01-01', false, 40, 53), + (1211, 1000, '2021-01-02', false, 40, 53), + (1212, 1000, '2021-01-03', false, 40, 53), + (1213, 1000, '2021-01-04', false, 40, 53), + (1214, 1000, '2021-01-05', true, 40, 53), + (1215, 1000, '2021-01-06', false, 40, 53), + (1216, 1500, '2021-01-07', false, 40, 53), + (1217, 1500, '2021-01-08', false, 40, 53), + (1218, 1000, '2021-01-09', false, 40, 53), + (1219, 1000, '2021-01-10', false, 40, 53), + (1220, 1000, '2021-01-11', false, 40, 53), + (1221, 1000, '2021-01-12', false, 40, 53), + (1222, 1000, '2021-01-13', false, 40, 53), + (1223, 1500, '2021-01-14', true, 40, 53), + (1224, 1500, '2021-01-15', false, 40, 53), + (1225, 1000, '2021-01-16', false, 40, 53), + (1226, 1000, '2021-01-17', false, 40, 53), + (1227, 1000, '2021-01-18', false, 40, 53), + (1228, 1000, '2021-01-19', true, 40, 53), + (1229, 1000, '2021-01-20', true, 40, 53), + (1230, 1500, '2021-01-21', false, 40, 53), + (1231, 1500, '2021-01-22', true, 40, 53), + (1232, 1000, '2021-01-23', false, 40, 53), + (1233, 1000, '2021-01-24', false, 40, 53), + (1234, 1000, '2021-01-25', false, 40, 53), + (1235, 1000, '2021-01-26', false, 40, 53), + (1236, 1000, '2021-01-27', true, 40, 53), + (1237, 1500, '2021-01-28', false, 40, 53), + (1238, 1500, '2021-01-29', false, 40, 53), + (1239, 1000, '2021-01-30', false, 40, 53), + (1240, 1000, '2021-01-31', false, 40, 53), + (1241, 1500, '2021-01-01', false, 41, 27), + (1242, 1000, '2021-01-02', false, 41, 27), + (1243, 1000, '2021-01-03', false, 41, 27), + (1244, 1000, '2021-01-04', false, 41, 27), + (1245, 1000, '2021-01-05', false, 41, 27), + (1246, 1000, '2021-01-06', true, 41, 27), + (1247, 1500, '2021-01-07', true, 41, 27), + (1248, 1500, '2021-01-08', true, 41, 27), + (1249, 1000, '2021-01-09', false, 41, 27), + (1250, 1000, '2021-01-10', false, 41, 27), + (1251, 1000, '2021-01-11', false, 41, 27), + (1252, 1000, '2021-01-12', false, 41, 27), + (1253, 1000, '2021-01-13', false, 41, 27), + (1254, 1500, '2021-01-14', false, 41, 27), + (1255, 1500, '2021-01-15', true, 41, 27), + (1256, 1000, '2021-01-16', false, 41, 27), + (1257, 1000, '2021-01-17', true, 41, 27), + (1258, 1000, '2021-01-18', true, 41, 27), + (1259, 1000, '2021-01-19', false, 41, 27), + (1260, 1000, '2021-01-20', false, 41, 27), + (1261, 1500, '2021-01-21', true, 41, 27), + (1262, 1500, '2021-01-22', false, 41, 27), + (1263, 1000, '2021-01-23', false, 41, 27), + (1264, 1000, '2021-01-24', false, 41, 27), + (1265, 1000, '2021-01-25', false, 41, 27), + (1266, 1000, '2021-01-26', false, 41, 27), + (1267, 1000, '2021-01-27', false, 41, 27), + (1268, 1500, '2021-01-28', false, 41, 27), + (1269, 1500, '2021-01-29', false, 41, 27), + (1270, 1000, '2021-01-30', false, 41, 27), + (1271, 1000, '2021-01-31', false, 41, 27), + (1272, 1500, '2021-01-01', true, 42, 71), + (1273, 1000, '2021-01-02', false, 42, 71), + (1274, 1000, '2021-01-03', false, 42, 71), + (1275, 1000, '2021-01-04', true, 42, 71), + (1276, 1000, '2021-01-05', true, 42, 71), + (1277, 1000, '2021-01-06', false, 42, 71), + (1278, 1500, '2021-01-07', false, 42, 71), + (1279, 1500, '2021-01-08', false, 42, 71), + (1280, 1000, '2021-01-09', true, 42, 71), + (1281, 1000, '2021-01-10', false, 42, 71), + (1282, 1000, '2021-01-11', false, 42, 71), + (1283, 1000, '2021-01-12', false, 42, 71), + (1284, 1000, '2021-01-13', true, 42, 71), + (1285, 1500, '2021-01-14', false, 42, 71), + (1286, 1500, '2021-01-15', true, 42, 71), + (1287, 1000, '2021-01-16', true, 42, 71), + (1288, 1000, '2021-01-17', true, 42, 71), + (1289, 1000, '2021-01-18', false, 42, 71), + (1290, 1000, '2021-01-19', true, 42, 71), + (1291, 1000, '2021-01-20', false, 42, 71), + (1292, 1500, '2021-01-21', true, 42, 71), + (1293, 1500, '2021-01-22', false, 42, 71), + (1294, 1000, '2021-01-23', true, 42, 71), + (1295, 1000, '2021-01-24', true, 42, 71), + (1296, 1000, '2021-01-25', false, 42, 71), + (1297, 1000, '2021-01-26', true, 42, 71), + (1298, 1000, '2021-01-27', false, 42, 71), + (1299, 1500, '2021-01-28', false, 42, 71), + (1300, 1500, '2021-01-29', false, 42, 71), + (1301, 1000, '2021-01-30', true, 42, 71), + (1302, 1000, '2021-01-31', false, 42, 71), + (1303, 1500, '2021-01-01', false, 43, 10), + (1304, 1000, '2021-01-02', false, 43, 10), + (1305, 1000, '2021-01-03', false, 43, 10), + (1306, 1000, '2021-01-04', false, 43, 10), + (1307, 1000, '2021-01-05', false, 43, 10), + (1308, 1000, '2021-01-06', false, 43, 10), + (1309, 1500, '2021-01-07', false, 43, 10), + (1310, 1500, '2021-01-08', false, 43, 10), + (1311, 1000, '2021-01-09', false, 43, 10), + (1312, 1000, '2021-01-10', false, 43, 10), + (1313, 1000, '2021-01-11', true, 43, 10), + (1314, 1000, '2021-01-12', true, 43, 10), + (1315, 1000, '2021-01-13', false, 43, 10), + (1316, 1500, '2021-01-14', true, 43, 10), + (1317, 1500, '2021-01-15', true, 43, 10), + (1318, 1000, '2021-01-16', false, 43, 10), + (1319, 1000, '2021-01-17', false, 43, 10), + (1320, 1000, '2021-01-18', false, 43, 10), + (1321, 1000, '2021-01-19', false, 43, 10), + (1322, 1000, '2021-01-20', false, 43, 10), + (1323, 1500, '2021-01-21', false, 43, 10), + (1324, 1500, '2021-01-22', false, 43, 10), + (1325, 1000, '2021-01-23', false, 43, 10), + (1326, 1000, '2021-01-24', false, 43, 10), + (1327, 1000, '2021-01-25', true, 43, 10), + (1328, 1000, '2021-01-26', false, 43, 10), + (1329, 1000, '2021-01-27', false, 43, 10), + (1330, 1500, '2021-01-28', true, 43, 10), + (1331, 1500, '2021-01-29', false, 43, 10), + (1332, 1000, '2021-01-30', false, 43, 10), + (1333, 1000, '2021-01-31', false, 43, 10), + (1334, 1500, '2021-01-01', false, 44, 73), + (1335, 1000, '2021-01-02', false, 44, 73), + (1336, 1000, '2021-01-03', false, 44, 73), + (1337, 1000, '2021-01-04', false, 44, 73), + (1338, 1000, '2021-01-05', false, 44, 73), + (1339, 1000, '2021-01-06', true, 44, 73), + (1340, 1500, '2021-01-07', false, 44, 73), + (1341, 1500, '2021-01-08', false, 44, 73), + (1342, 1000, '2021-01-09', false, 44, 73), + (1343, 1000, '2021-01-10', false, 44, 73), + (1344, 1000, '2021-01-11', false, 44, 73), + (1345, 1000, '2021-01-12', false, 44, 73), + (1346, 1000, '2021-01-13', false, 44, 73), + (1347, 1500, '2021-01-14', false, 44, 73), + (1348, 1500, '2021-01-15', false, 44, 73), + (1349, 1000, '2021-01-16', true, 44, 73), + (1350, 1000, '2021-01-17', true, 44, 73), + (1351, 1000, '2021-01-18', false, 44, 73), + (1352, 1000, '2021-01-19', false, 44, 73), + (1353, 1000, '2021-01-20', false, 44, 73), + (1354, 1500, '2021-01-21', false, 44, 73), + (1355, 1500, '2021-01-22', false, 44, 73), + (1356, 1000, '2021-01-23', false, 44, 73), + (1357, 1000, '2021-01-24', false, 44, 73), + (1358, 1000, '2021-01-25', false, 44, 73), + (1359, 1000, '2021-01-26', false, 44, 73), + (1360, 1000, '2021-01-27', false, 44, 73), + (1361, 1500, '2021-01-28', true, 44, 73), + (1362, 1500, '2021-01-29', false, 44, 73), + (1363, 1000, '2021-01-30', false, 44, 73), + (1364, 1000, '2021-01-31', true, 44, 73), + (1365, 1500, '2021-01-01', false, 45, 40), + (1366, 1000, '2021-01-02', false, 45, 40), + (1367, 1000, '2021-01-03', false, 45, 40), + (1368, 1000, '2021-01-04', false, 45, 40), + (1369, 1000, '2021-01-05', false, 45, 40), + (1370, 1000, '2021-01-06', true, 45, 40), + (1371, 1500, '2021-01-07', false, 45, 40), + (1372, 1500, '2021-01-08', false, 45, 40), + (1373, 1000, '2021-01-09', false, 45, 40), + (1374, 1000, '2021-01-10', true, 45, 40), + (1375, 1000, '2021-01-11', false, 45, 40), + (1376, 1000, '2021-01-12', false, 45, 40), + (1377, 1000, '2021-01-13', false, 45, 40), + (1378, 1500, '2021-01-14', true, 45, 40), + (1379, 1500, '2021-01-15', false, 45, 40), + (1380, 1000, '2021-01-16', false, 45, 40), + (1381, 1000, '2021-01-17', true, 45, 40), + (1382, 1000, '2021-01-18', false, 45, 40), + (1383, 1000, '2021-01-19', true, 45, 40), + (1384, 1000, '2021-01-20', false, 45, 40), + (1385, 1500, '2021-01-21', false, 45, 40), + (1386, 1500, '2021-01-22', true, 45, 40), + (1387, 1000, '2021-01-23', false, 45, 40), + (1388, 1000, '2021-01-24', false, 45, 40), + (1389, 1000, '2021-01-25', false, 45, 40), + (1390, 1000, '2021-01-26', false, 45, 40), + (1391, 1000, '2021-01-27', false, 45, 40), + (1392, 1500, '2021-01-28', true, 45, 40), + (1393, 1500, '2021-01-29', false, 45, 40), + (1394, 1000, '2021-01-30', false, 45, 40), + (1395, 1000, '2021-01-31', false, 45, 40), + (1396, 1500, '2021-01-01', false, 46, 48), + (1397, 1000, '2021-01-02', false, 46, 48), + (1398, 1000, '2021-01-03', false, 46, 48), + (1399, 1000, '2021-01-04', true, 46, 48), + (1400, 1000, '2021-01-05', false, 46, 48), + (1401, 1000, '2021-01-06', false, 46, 48), + (1402, 1500, '2021-01-07', false, 46, 48), + (1403, 1500, '2021-01-08', false, 46, 48), + (1404, 1000, '2021-01-09', false, 46, 48), + (1405, 1000, '2021-01-10', false, 46, 48), + (1406, 1000, '2021-01-11', true, 46, 48), + (1407, 1000, '2021-01-12', false, 46, 48), + (1408, 1000, '2021-01-13', false, 46, 48), + (1409, 1500, '2021-01-14', false, 46, 48), + (1410, 1500, '2021-01-15', false, 46, 48), + (1411, 1000, '2021-01-16', false, 46, 48), + (1412, 1000, '2021-01-17', false, 46, 48), + (1413, 1000, '2021-01-18', false, 46, 48), + (1414, 1000, '2021-01-19', false, 46, 48), + (1415, 1000, '2021-01-20', false, 46, 48), + (1416, 1500, '2021-01-21', false, 46, 48), + (1417, 1500, '2021-01-22', true, 46, 48), + (1418, 1000, '2021-01-23', false, 46, 48), + (1419, 1000, '2021-01-24', false, 46, 48), + (1420, 1000, '2021-01-25', false, 46, 48), + (1421, 1000, '2021-01-26', false, 46, 48), + (1422, 1000, '2021-01-27', false, 46, 48), + (1423, 1500, '2021-01-28', false, 46, 48), + (1424, 1500, '2021-01-29', false, 46, 48), + (1425, 1000, '2021-01-30', false, 46, 48), + (1426, 1000, '2021-01-31', false, 46, 48), + (1427, 1500, '2021-01-01', false, 47, 42), + (1428, 1000, '2021-01-02', false, 47, 42), + (1429, 1000, '2021-01-03', false, 47, 42), + (1430, 1000, '2021-01-04', false, 47, 42), + (1431, 1000, '2021-01-05', false, 47, 42), + (1432, 1000, '2021-01-06', true, 47, 42), + (1433, 1500, '2021-01-07', false, 47, 42), + (1434, 1500, '2021-01-08', false, 47, 42), + (1435, 1000, '2021-01-09', true, 47, 42), + (1436, 1000, '2021-01-10', false, 47, 42), + (1437, 1000, '2021-01-11', false, 47, 42), + (1438, 1000, '2021-01-12', false, 47, 42), + (1439, 1000, '2021-01-13', false, 47, 42), + (1440, 1500, '2021-01-14', false, 47, 42), + (1441, 1500, '2021-01-15', true, 47, 42), + (1442, 1000, '2021-01-16', false, 47, 42), + (1443, 1000, '2021-01-17', true, 47, 42), + (1444, 1000, '2021-01-18', false, 47, 42), + (1445, 1000, '2021-01-19', false, 47, 42), + (1446, 1000, '2021-01-20', true, 47, 42), + (1447, 1500, '2021-01-21', false, 47, 42), + (1448, 1500, '2021-01-22', true, 47, 42), + (1449, 1000, '2021-01-23', false, 47, 42), + (1450, 1000, '2021-01-24', true, 47, 42), + (1451, 1000, '2021-01-25', false, 47, 42), + (1452, 1000, '2021-01-26', false, 47, 42), + (1453, 1000, '2021-01-27', true, 47, 42), + (1454, 1500, '2021-01-28', false, 47, 42), + (1455, 1500, '2021-01-29', true, 47, 42), + (1456, 1000, '2021-01-30', false, 47, 42), + (1457, 1000, '2021-01-31', false, 47, 42), + (1458, 1500, '2021-01-01', false, 48, 46), + (1459, 1000, '2021-01-02', true, 48, 46), + (1460, 1000, '2021-01-03', true, 48, 46), + (1461, 1000, '2021-01-04', false, 48, 46), + (1462, 1000, '2021-01-05', true, 48, 46), + (1463, 1000, '2021-01-06', false, 48, 46), + (1464, 1500, '2021-01-07', false, 48, 46), + (1465, 1500, '2021-01-08', true, 48, 46), + (1466, 1000, '2021-01-09', true, 48, 46), + (1467, 1000, '2021-01-10', false, 48, 46), + (1468, 1000, '2021-01-11', false, 48, 46), + (1469, 1000, '2021-01-12', true, 48, 46), + (1470, 1000, '2021-01-13', false, 48, 46), + (1471, 1500, '2021-01-14', false, 48, 46), + (1472, 1500, '2021-01-15', false, 48, 46), + (1473, 1000, '2021-01-16', false, 48, 46), + (1474, 1000, '2021-01-17', true, 48, 46), + (1475, 1000, '2021-01-18', true, 48, 46), + (1476, 1000, '2021-01-19', true, 48, 46), + (1477, 1000, '2021-01-20', false, 48, 46), + (1478, 1500, '2021-01-21', false, 48, 46), + (1479, 1500, '2021-01-22', false, 48, 46), + (1480, 1000, '2021-01-23', false, 48, 46), + (1481, 1000, '2021-01-24', false, 48, 46), + (1482, 1000, '2021-01-25', false, 48, 46), + (1483, 1000, '2021-01-26', true, 48, 46), + (1484, 1000, '2021-01-27', false, 48, 46), + (1485, 1500, '2021-01-28', true, 48, 46), + (1486, 1500, '2021-01-29', false, 48, 46), + (1487, 1000, '2021-01-30', false, 48, 46), + (1488, 1000, '2021-01-31', false, 48, 46), + (1489, 1500, '2021-01-01', true, 49, 4), + (1490, 1000, '2021-01-02', false, 49, 4), + (1491, 1000, '2021-01-03', false, 49, 4), + (1492, 1000, '2021-01-04', false, 49, 4), + (1493, 1000, '2021-01-05', false, 49, 4), + (1494, 1000, '2021-01-06', false, 49, 4), + (1495, 1500, '2021-01-07', false, 49, 4), + (1496, 1500, '2021-01-08', false, 49, 4), + (1497, 1000, '2021-01-09', false, 49, 4), + (1498, 1000, '2021-01-10', false, 49, 4), + (1499, 1000, '2021-01-11', false, 49, 4), + (1500, 1000, '2021-01-12', true, 49, 4), + (1501, 1000, '2021-01-13', false, 49, 4), + (1502, 1500, '2021-01-14', false, 49, 4), + (1503, 1500, '2021-01-15', false, 49, 4), + (1504, 1000, '2021-01-16', false, 49, 4), + (1505, 1000, '2021-01-17', false, 49, 4), + (1506, 1000, '2021-01-18', false, 49, 4), + (1507, 1000, '2021-01-19', false, 49, 4), + (1508, 1000, '2021-01-20', false, 49, 4), + (1509, 1500, '2021-01-21', true, 49, 4), + (1510, 1500, '2021-01-22', false, 49, 4), + (1511, 1000, '2021-01-23', false, 49, 4), + (1512, 1000, '2021-01-24', true, 49, 4), + (1513, 1000, '2021-01-25', false, 49, 4), + (1514, 1000, '2021-01-26', true, 49, 4), + (1515, 1000, '2021-01-27', true, 49, 4), + (1516, 1500, '2021-01-28', false, 49, 4), + (1517, 1500, '2021-01-29', true, 49, 4), + (1518, 1000, '2021-01-30', true, 49, 4), + (1519, 1000, '2021-01-31', false, 49, 4), + (1520, 1500, '2021-01-01', false, 50, 1), + (1521, 1000, '2021-01-02', true, 50, 1), + (1522, 1000, '2021-01-03', true, 50, 1), + (1523, 1000, '2021-01-04', true, 50, 1), + (1524, 1000, '2021-01-05', false, 50, 1), + (1525, 1000, '2021-01-06', false, 50, 1), + (1526, 1500, '2021-01-07', false, 50, 1), + (1527, 1500, '2021-01-08', false, 50, 1), + (1528, 1000, '2021-01-09', false, 50, 1), + (1529, 1000, '2021-01-10', false, 50, 1), + (1530, 1000, '2021-01-11', false, 50, 1), + (1531, 1000, '2021-01-12', false, 50, 1), + (1532, 1000, '2021-01-13', false, 50, 1), + (1533, 1500, '2021-01-14', false, 50, 1), + (1534, 1500, '2021-01-15', false, 50, 1), + (1535, 1000, '2021-01-16', false, 50, 1), + (1536, 1000, '2021-01-17', false, 50, 1), + (1537, 1000, '2021-01-18', false, 50, 1), + (1538, 1000, '2021-01-19', false, 50, 1), + (1539, 1000, '2021-01-20', true, 50, 1), + (1540, 1500, '2021-01-21', false, 50, 1), + (1541, 1500, '2021-01-22', false, 50, 1), + (1542, 1000, '2021-01-23', false, 50, 1), + (1543, 1000, '2021-01-24', true, 50, 1), + (1544, 1000, '2021-01-25', false, 50, 1), + (1545, 1000, '2021-01-26', false, 50, 1), + (1546, 1000, '2021-01-27', false, 50, 1), + (1547, 1500, '2021-01-28', false, 50, 1), + (1548, 1500, '2021-01-29', false, 50, 1), + (1549, 1000, '2021-01-30', false, 50, 1), + (1550, 1000, '2021-01-31', false, 50, 1), + (1551, 1500, '2021-01-01', true, 51, 5), + (1552, 1000, '2021-01-02', true, 51, 5), + (1553, 1000, '2021-01-03', false, 51, 5), + (1554, 1000, '2021-01-04', true, 51, 5), + (1555, 1000, '2021-01-05', false, 51, 5), + (1556, 1000, '2021-01-06', true, 51, 5), + (1557, 1500, '2021-01-07', false, 51, 5), + (1558, 1500, '2021-01-08', false, 51, 5), + (1559, 1000, '2021-01-09', true, 51, 5), + (1560, 1000, '2021-01-10', false, 51, 5), + (1561, 1000, '2021-01-11', false, 51, 5), + (1562, 1000, '2021-01-12', true, 51, 5), + (1563, 1000, '2021-01-13', true, 51, 5), + (1564, 1500, '2021-01-14', false, 51, 5), + (1565, 1500, '2021-01-15', false, 51, 5), + (1566, 1000, '2021-01-16', true, 51, 5), + (1567, 1000, '2021-01-17', false, 51, 5), + (1568, 1000, '2021-01-18', true, 51, 5), + (1569, 1000, '2021-01-19', false, 51, 5), + (1570, 1000, '2021-01-20', false, 51, 5), + (1571, 1500, '2021-01-21', false, 51, 5), + (1572, 1500, '2021-01-22', false, 51, 5), + (1573, 1000, '2021-01-23', false, 51, 5), + (1574, 1000, '2021-01-24', false, 51, 5), + (1575, 1000, '2021-01-25', false, 51, 5), + (1576, 1000, '2021-01-26', false, 51, 5), + (1577, 1000, '2021-01-27', false, 51, 5), + (1578, 1500, '2021-01-28', true, 51, 5), + (1579, 1500, '2021-01-29', true, 51, 5), + (1580, 1000, '2021-01-30', false, 51, 5), + (1581, 1000, '2021-01-31', true, 51, 5), + (1582, 1500, '2021-01-01', false, 52, 15), + (1583, 1000, '2021-01-02', true, 52, 15), + (1584, 1000, '2021-01-03', false, 52, 15), + (1585, 1000, '2021-01-04', false, 52, 15), + (1586, 1000, '2021-01-05', true, 52, 15), + (1587, 1000, '2021-01-06', true, 52, 15), + (1588, 1500, '2021-01-07', false, 52, 15), + (1589, 1500, '2021-01-08', false, 52, 15), + (1590, 1000, '2021-01-09', true, 52, 15), + (1591, 1000, '2021-01-10', true, 52, 15), + (1592, 1000, '2021-01-11', false, 52, 15), + (1593, 1000, '2021-01-12', false, 52, 15), + (1594, 1000, '2021-01-13', false, 52, 15), + (1595, 1500, '2021-01-14', false, 52, 15), + (1596, 1500, '2021-01-15', false, 52, 15), + (1597, 1000, '2021-01-16', true, 52, 15), + (1598, 1000, '2021-01-17', false, 52, 15), + (1599, 1000, '2021-01-18', true, 52, 15), + (1600, 1000, '2021-01-19', false, 52, 15), + (1601, 1000, '2021-01-20', false, 52, 15), + (1602, 1500, '2021-01-21', false, 52, 15), + (1603, 1500, '2021-01-22', true, 52, 15), + (1604, 1000, '2021-01-23', false, 52, 15), + (1605, 1000, '2021-01-24', false, 52, 15), + (1606, 1000, '2021-01-25', true, 52, 15), + (1607, 1000, '2021-01-26', false, 52, 15), + (1608, 1000, '2021-01-27', false, 52, 15), + (1609, 1500, '2021-01-28', false, 52, 15), + (1610, 1500, '2021-01-29', false, 52, 15), + (1611, 1000, '2021-01-30', false, 52, 15), + (1612, 1000, '2021-01-31', false, 52, 15), + (1613, 1500, '2021-01-01', false, 53, 47), + (1614, 1000, '2021-01-02', false, 53, 47), + (1615, 1000, '2021-01-03', true, 53, 47), + (1616, 1000, '2021-01-04', false, 53, 47), + (1617, 1000, '2021-01-05', true, 53, 47), + (1618, 1000, '2021-01-06', false, 53, 47), + (1619, 1500, '2021-01-07', false, 53, 47), + (1620, 1500, '2021-01-08', true, 53, 47), + (1621, 1000, '2021-01-09', true, 53, 47), + (1622, 1000, '2021-01-10', true, 53, 47), + (1623, 1000, '2021-01-11', false, 53, 47), + (1624, 1000, '2021-01-12', false, 53, 47), + (1625, 1000, '2021-01-13', false, 53, 47), + (1626, 1500, '2021-01-14', false, 53, 47), + (1627, 1500, '2021-01-15', true, 53, 47), + (1628, 1000, '2021-01-16', false, 53, 47), + (1629, 1000, '2021-01-17', false, 53, 47), + (1630, 1000, '2021-01-18', false, 53, 47), + (1631, 1000, '2021-01-19', false, 53, 47), + (1632, 1000, '2021-01-20', false, 53, 47), + (1633, 1500, '2021-01-21', false, 53, 47), + (1634, 1500, '2021-01-22', false, 53, 47), + (1635, 1000, '2021-01-23', false, 53, 47), + (1636, 1000, '2021-01-24', false, 53, 47), + (1637, 1000, '2021-01-25', false, 53, 47), + (1638, 1000, '2021-01-26', false, 53, 47), + (1639, 1000, '2021-01-27', false, 53, 47), + (1640, 1500, '2021-01-28', false, 53, 47), + (1641, 1500, '2021-01-29', false, 53, 47), + (1642, 1000, '2021-01-30', false, 53, 47), + (1643, 1000, '2021-01-31', false, 53, 47), + (1644, 1500, '2021-01-01', false, 54, 24), + (1645, 1000, '2021-01-02', false, 54, 24), + (1646, 1000, '2021-01-03', false, 54, 24), + (1647, 1000, '2021-01-04', false, 54, 24), + (1648, 1000, '2021-01-05', true, 54, 24), + (1649, 1000, '2021-01-06', true, 54, 24), + (1650, 1500, '2021-01-07', false, 54, 24), + (1651, 1500, '2021-01-08', false, 54, 24), + (1652, 1000, '2021-01-09', true, 54, 24), + (1653, 1000, '2021-01-10', false, 54, 24), + (1654, 1000, '2021-01-11', false, 54, 24), + (1655, 1000, '2021-01-12', false, 54, 24), + (1656, 1000, '2021-01-13', false, 54, 24), + (1657, 1500, '2021-01-14', true, 54, 24), + (1658, 1500, '2021-01-15', false, 54, 24), + (1659, 1000, '2021-01-16', false, 54, 24), + (1660, 1000, '2021-01-17', false, 54, 24), + (1661, 1000, '2021-01-18', false, 54, 24), + (1662, 1000, '2021-01-19', false, 54, 24), + (1663, 1000, '2021-01-20', false, 54, 24), + (1664, 1500, '2021-01-21', false, 54, 24), + (1665, 1500, '2021-01-22', false, 54, 24), + (1666, 1000, '2021-01-23', true, 54, 24), + (1667, 1000, '2021-01-24', true, 54, 24), + (1668, 1000, '2021-01-25', true, 54, 24), + (1669, 1000, '2021-01-26', false, 54, 24), + (1670, 1000, '2021-01-27', true, 54, 24), + (1671, 1500, '2021-01-28', true, 54, 24), + (1672, 1500, '2021-01-29', false, 54, 24), + (1673, 1000, '2021-01-30', false, 54, 24), + (1674, 1000, '2021-01-31', false, 54, 24), + (1675, 1500, '2021-01-01', false, 55, 10), + (1676, 1000, '2021-01-02', false, 55, 10), + (1677, 1000, '2021-01-03', false, 55, 10), + (1678, 1000, '2021-01-04', true, 55, 10), + (1679, 1000, '2021-01-05', false, 55, 10), + (1680, 1000, '2021-01-06', false, 55, 10), + (1681, 1500, '2021-01-07', false, 55, 10), + (1682, 1500, '2021-01-08', false, 55, 10), + (1683, 1000, '2021-01-09', false, 55, 10), + (1684, 1000, '2021-01-10', false, 55, 10), + (1685, 1000, '2021-01-11', false, 55, 10), + (1686, 1000, '2021-01-12', false, 55, 10), + (1687, 1000, '2021-01-13', false, 55, 10), + (1688, 1500, '2021-01-14', false, 55, 10), + (1689, 1500, '2021-01-15', false, 55, 10), + (1690, 1000, '2021-01-16', true, 55, 10), + (1691, 1000, '2021-01-17', false, 55, 10), + (1692, 1000, '2021-01-18', false, 55, 10), + (1693, 1000, '2021-01-19', false, 55, 10), + (1694, 1000, '2021-01-20', false, 55, 10), + (1695, 1500, '2021-01-21', false, 55, 10), + (1696, 1500, '2021-01-22', false, 55, 10), + (1697, 1000, '2021-01-23', true, 55, 10), + (1698, 1000, '2021-01-24', false, 55, 10), + (1699, 1000, '2021-01-25', false, 55, 10), + (1700, 1000, '2021-01-26', false, 55, 10), + (1701, 1000, '2021-01-27', false, 55, 10), + (1702, 1500, '2021-01-28', false, 55, 10), + (1703, 1500, '2021-01-29', false, 55, 10), + (1704, 1000, '2021-01-30', true, 55, 10), + (1705, 1000, '2021-01-31', false, 55, 10), + (1706, 1500, '2021-01-01', false, 56, 57), + (1707, 1000, '2021-01-02', false, 56, 57), + (1708, 1000, '2021-01-03', true, 56, 57), + (1709, 1000, '2021-01-04', false, 56, 57), + (1710, 1000, '2021-01-05', true, 56, 57), + (1711, 1000, '2021-01-06', false, 56, 57), + (1712, 1500, '2021-01-07', true, 56, 57), + (1713, 1500, '2021-01-08', false, 56, 57), + (1714, 1000, '2021-01-09', false, 56, 57), + (1715, 1000, '2021-01-10', false, 56, 57), + (1716, 1000, '2021-01-11', false, 56, 57), + (1717, 1000, '2021-01-12', false, 56, 57), + (1718, 1000, '2021-01-13', true, 56, 57), + (1719, 1500, '2021-01-14', true, 56, 57), + (1720, 1500, '2021-01-15', false, 56, 57), + (1721, 1000, '2021-01-16', false, 56, 57), + (1722, 1000, '2021-01-17', true, 56, 57), + (1723, 1000, '2021-01-18', false, 56, 57), + (1724, 1000, '2021-01-19', false, 56, 57), + (1725, 1000, '2021-01-20', true, 56, 57), + (1726, 1500, '2021-01-21', true, 56, 57), + (1727, 1500, '2021-01-22', true, 56, 57), + (1728, 1000, '2021-01-23', false, 56, 57), + (1729, 1000, '2021-01-24', false, 56, 57), + (1730, 1000, '2021-01-25', false, 56, 57), + (1731, 1000, '2021-01-26', false, 56, 57), + (1732, 1000, '2021-01-27', false, 56, 57), + (1733, 1500, '2021-01-28', false, 56, 57), + (1734, 1500, '2021-01-29', false, 56, 57), + (1735, 1000, '2021-01-30', true, 56, 57), + (1736, 1000, '2021-01-31', true, 56, 57), + (1737, 1500, '2021-01-01', true, 57, 76), + (1738, 1000, '2021-01-02', false, 57, 76), + (1739, 1000, '2021-01-03', false, 57, 76), + (1740, 1000, '2021-01-04', false, 57, 76), + (1741, 1000, '2021-01-05', true, 57, 76), + (1742, 1000, '2021-01-06', true, 57, 76), + (1743, 1500, '2021-01-07', false, 57, 76), + (1744, 1500, '2021-01-08', false, 57, 76), + (1745, 1000, '2021-01-09', false, 57, 76), + (1746, 1000, '2021-01-10', false, 57, 76), + (1747, 1000, '2021-01-11', false, 57, 76), + (1748, 1000, '2021-01-12', false, 57, 76), + (1749, 1000, '2021-01-13', false, 57, 76), + (1750, 1500, '2021-01-14', false, 57, 76), + (1751, 1500, '2021-01-15', false, 57, 76), + (1752, 1000, '2021-01-16', true, 57, 76), + (1753, 1000, '2021-01-17', true, 57, 76), + (1754, 1000, '2021-01-18', true, 57, 76), + (1755, 1000, '2021-01-19', true, 57, 76), + (1756, 1000, '2021-01-20', false, 57, 76), + (1757, 1500, '2021-01-21', false, 57, 76), + (1758, 1500, '2021-01-22', true, 57, 76), + (1759, 1000, '2021-01-23', false, 57, 76), + (1760, 1000, '2021-01-24', false, 57, 76), + (1761, 1000, '2021-01-25', false, 57, 76), + (1762, 1000, '2021-01-26', true, 57, 76), + (1763, 1000, '2021-01-27', false, 57, 76), + (1764, 1500, '2021-01-28', true, 57, 76), + (1765, 1500, '2021-01-29', false, 57, 76), + (1766, 1000, '2021-01-30', false, 57, 76), + (1767, 1000, '2021-01-31', false, 57, 76), + (1768, 1500, '2021-01-01', false, 58, 49), + (1769, 1000, '2021-01-02', false, 58, 49), + (1770, 1000, '2021-01-03', true, 58, 49), + (1771, 1000, '2021-01-04', true, 58, 49), + (1772, 1000, '2021-01-05', true, 58, 49), + (1773, 1000, '2021-01-06', false, 58, 49), + (1774, 1500, '2021-01-07', true, 58, 49), + (1775, 1500, '2021-01-08', true, 58, 49), + (1776, 1000, '2021-01-09', false, 58, 49), + (1777, 1000, '2021-01-10', false, 58, 49), + (1778, 1000, '2021-01-11', false, 58, 49), + (1779, 1000, '2021-01-12', false, 58, 49), + (1780, 1000, '2021-01-13', true, 58, 49), + (1781, 1500, '2021-01-14', false, 58, 49), + (1782, 1500, '2021-01-15', false, 58, 49), + (1783, 1000, '2021-01-16', false, 58, 49), + (1784, 1000, '2021-01-17', true, 58, 49), + (1785, 1000, '2021-01-18', false, 58, 49), + (1786, 1000, '2021-01-19', true, 58, 49), + (1787, 1000, '2021-01-20', false, 58, 49), + (1788, 1500, '2021-01-21', false, 58, 49), + (1789, 1500, '2021-01-22', false, 58, 49), + (1790, 1000, '2021-01-23', false, 58, 49), + (1791, 1000, '2021-01-24', true, 58, 49), + (1792, 1000, '2021-01-25', false, 58, 49), + (1793, 1000, '2021-01-26', false, 58, 49), + (1794, 1000, '2021-01-27', false, 58, 49), + (1795, 1500, '2021-01-28', true, 58, 49), + (1796, 1500, '2021-01-29', false, 58, 49), + (1797, 1000, '2021-01-30', false, 58, 49), + (1798, 1000, '2021-01-31', false, 58, 49), + (1799, 1500, '2021-01-01', false, 59, 68), + (1800, 1000, '2021-01-02', false, 59, 68), + (1801, 1000, '2021-01-03', false, 59, 68), + (1802, 1000, '2021-01-04', false, 59, 68), + (1803, 1000, '2021-01-05', false, 59, 68), + (1804, 1000, '2021-01-06', true, 59, 68), + (1805, 1500, '2021-01-07', false, 59, 68), + (1806, 1500, '2021-01-08', false, 59, 68), + (1807, 1000, '2021-01-09', false, 59, 68), + (1808, 1000, '2021-01-10', true, 59, 68), + (1809, 1000, '2021-01-11', false, 59, 68), + (1810, 1000, '2021-01-12', true, 59, 68), + (1811, 1000, '2021-01-13', false, 59, 68), + (1812, 1500, '2021-01-14', false, 59, 68), + (1813, 1500, '2021-01-15', true, 59, 68), + (1814, 1000, '2021-01-16', false, 59, 68), + (1815, 1000, '2021-01-17', true, 59, 68), + (1816, 1000, '2021-01-18', false, 59, 68), + (1817, 1000, '2021-01-19', false, 59, 68), + (1818, 1000, '2021-01-20', false, 59, 68), + (1819, 1500, '2021-01-21', false, 59, 68), + (1820, 1500, '2021-01-22', false, 59, 68), + (1821, 1000, '2021-01-23', false, 59, 68), + (1822, 1000, '2021-01-24', false, 59, 68), + (1823, 1000, '2021-01-25', false, 59, 68), + (1824, 1000, '2021-01-26', true, 59, 68), + (1825, 1000, '2021-01-27', true, 59, 68), + (1826, 1500, '2021-01-28', true, 59, 68), + (1827, 1500, '2021-01-29', false, 59, 68), + (1828, 1000, '2021-01-30', false, 59, 68), + (1829, 1000, '2021-01-31', false, 59, 68), + (1830, 1500, '2021-01-01', false, 60, 51), + (1831, 1000, '2021-01-02', true, 60, 51), + (1832, 1000, '2021-01-03', false, 60, 51), + (1833, 1000, '2021-01-04', false, 60, 51), + (1834, 1000, '2021-01-05', false, 60, 51), + (1835, 1000, '2021-01-06', false, 60, 51), + (1836, 1500, '2021-01-07', false, 60, 51), + (1837, 1500, '2021-01-08', false, 60, 51), + (1838, 1000, '2021-01-09', false, 60, 51), + (1839, 1000, '2021-01-10', false, 60, 51), + (1840, 1000, '2021-01-11', false, 60, 51), + (1841, 1000, '2021-01-12', false, 60, 51), + (1842, 1000, '2021-01-13', false, 60, 51), + (1843, 1500, '2021-01-14', false, 60, 51), + (1844, 1500, '2021-01-15', false, 60, 51), + (1845, 1000, '2021-01-16', false, 60, 51), + (1846, 1000, '2021-01-17', false, 60, 51), + (1847, 1000, '2021-01-18', false, 60, 51), + (1848, 1000, '2021-01-19', true, 60, 51), + (1849, 1000, '2021-01-20', false, 60, 51), + (1850, 1500, '2021-01-21', true, 60, 51), + (1851, 1500, '2021-01-22', false, 60, 51), + (1852, 1000, '2021-01-23', true, 60, 51), + (1853, 1000, '2021-01-24', false, 60, 51), + (1854, 1000, '2021-01-25', true, 60, 51), + (1855, 1000, '2021-01-26', false, 60, 51), + (1856, 1000, '2021-01-27', false, 60, 51), + (1857, 1500, '2021-01-28', false, 60, 51), + (1858, 1500, '2021-01-29', false, 60, 51), + (1859, 1000, '2021-01-30', false, 60, 51), + (1860, 1000, '2021-01-31', true, 60, 51), + (1861, 1500, '2021-01-01', false, 61, 18), + (1862, 1000, '2021-01-02', false, 61, 18), + (1863, 1000, '2021-01-03', true, 61, 18), + (1864, 1000, '2021-01-04', false, 61, 18), + (1865, 1000, '2021-01-05', false, 61, 18), + (1866, 1000, '2021-01-06', false, 61, 18), + (1867, 1500, '2021-01-07', false, 61, 18), + (1868, 1500, '2021-01-08', false, 61, 18), + (1869, 1000, '2021-01-09', false, 61, 18), + (1870, 1000, '2021-01-10', false, 61, 18), + (1871, 1000, '2021-01-11', false, 61, 18), + (1872, 1000, '2021-01-12', true, 61, 18), + (1873, 1000, '2021-01-13', false, 61, 18), + (1874, 1500, '2021-01-14', true, 61, 18), + (1875, 1500, '2021-01-15', false, 61, 18), + (1876, 1000, '2021-01-16', false, 61, 18), + (1877, 1000, '2021-01-17', true, 61, 18), + (1878, 1000, '2021-01-18', false, 61, 18), + (1879, 1000, '2021-01-19', true, 61, 18), + (1880, 1000, '2021-01-20', false, 61, 18), + (1881, 1500, '2021-01-21', false, 61, 18), + (1882, 1500, '2021-01-22', false, 61, 18), + (1883, 1000, '2021-01-23', false, 61, 18), + (1884, 1000, '2021-01-24', false, 61, 18), + (1885, 1000, '2021-01-25', false, 61, 18), + (1886, 1000, '2021-01-26', true, 61, 18), + (1887, 1000, '2021-01-27', false, 61, 18), + (1888, 1500, '2021-01-28', true, 61, 18), + (1889, 1500, '2021-01-29', true, 61, 18), + (1890, 1000, '2021-01-30', true, 61, 18), + (1891, 1000, '2021-01-31', false, 61, 18), + (1892, 1500, '2021-01-01', false, 62, 11), + (1893, 1000, '2021-01-02', false, 62, 11), + (1894, 1000, '2021-01-03', false, 62, 11), + (1895, 1000, '2021-01-04', true, 62, 11), + (1896, 1000, '2021-01-05', false, 62, 11), + (1897, 1000, '2021-01-06', true, 62, 11), + (1898, 1500, '2021-01-07', false, 62, 11), + (1899, 1500, '2021-01-08', false, 62, 11), + (1900, 1000, '2021-01-09', false, 62, 11), + (1901, 1000, '2021-01-10', true, 62, 11), + (1902, 1000, '2021-01-11', false, 62, 11), + (1903, 1000, '2021-01-12', false, 62, 11), + (1904, 1000, '2021-01-13', false, 62, 11), + (1905, 1500, '2021-01-14', false, 62, 11), + (1906, 1500, '2021-01-15', false, 62, 11), + (1907, 1000, '2021-01-16', false, 62, 11), + (1908, 1000, '2021-01-17', false, 62, 11), + (1909, 1000, '2021-01-18', false, 62, 11), + (1910, 1000, '2021-01-19', false, 62, 11), + (1911, 1000, '2021-01-20', true, 62, 11), + (1912, 1500, '2021-01-21', true, 62, 11), + (1913, 1500, '2021-01-22', false, 62, 11), + (1914, 1000, '2021-01-23', false, 62, 11), + (1915, 1000, '2021-01-24', false, 62, 11), + (1916, 1000, '2021-01-25', false, 62, 11), + (1917, 1000, '2021-01-26', false, 62, 11), + (1918, 1000, '2021-01-27', false, 62, 11), + (1919, 1500, '2021-01-28', false, 62, 11), + (1920, 1500, '2021-01-29', false, 62, 11), + (1921, 1000, '2021-01-30', false, 62, 11), + (1922, 1000, '2021-01-31', false, 62, 11), + (1923, 1500, '2021-01-01', false, 63, 36), + (1924, 1000, '2021-01-02', false, 63, 36), + (1925, 1000, '2021-01-03', false, 63, 36), + (1926, 1000, '2021-01-04', false, 63, 36), + (1927, 1000, '2021-01-05', false, 63, 36), + (1928, 1000, '2021-01-06', false, 63, 36), + (1929, 1500, '2021-01-07', false, 63, 36), + (1930, 1500, '2021-01-08', true, 63, 36), + (1931, 1000, '2021-01-09', false, 63, 36), + (1932, 1000, '2021-01-10', false, 63, 36), + (1933, 1000, '2021-01-11', false, 63, 36), + (1934, 1000, '2021-01-12', true, 63, 36), + (1935, 1000, '2021-01-13', false, 63, 36), + (1936, 1500, '2021-01-14', true, 63, 36), + (1937, 1500, '2021-01-15', false, 63, 36), + (1938, 1000, '2021-01-16', false, 63, 36), + (1939, 1000, '2021-01-17', true, 63, 36), + (1940, 1000, '2021-01-18', false, 63, 36), + (1941, 1000, '2021-01-19', false, 63, 36), + (1942, 1000, '2021-01-20', false, 63, 36), + (1943, 1500, '2021-01-21', false, 63, 36), + (1944, 1500, '2021-01-22', false, 63, 36), + (1945, 1000, '2021-01-23', true, 63, 36), + (1946, 1000, '2021-01-24', true, 63, 36), + (1947, 1000, '2021-01-25', false, 63, 36), + (1948, 1000, '2021-01-26', false, 63, 36), + (1949, 1000, '2021-01-27', false, 63, 36), + (1950, 1500, '2021-01-28', false, 63, 36), + (1951, 1500, '2021-01-29', true, 63, 36), + (1952, 1000, '2021-01-30', false, 63, 36), + (1953, 1000, '2021-01-31', false, 63, 36), + (1954, 1500, '2021-01-01', false, 64, 19), + (1955, 1000, '2021-01-02', false, 64, 19), + (1956, 1000, '2021-01-03', false, 64, 19), + (1957, 1000, '2021-01-04', false, 64, 19), + (1958, 1000, '2021-01-05', true, 64, 19), + (1959, 1000, '2021-01-06', false, 64, 19), + (1960, 1500, '2021-01-07', false, 64, 19), + (1961, 1500, '2021-01-08', false, 64, 19), + (1962, 1000, '2021-01-09', true, 64, 19), + (1963, 1000, '2021-01-10', false, 64, 19), + (1964, 1000, '2021-01-11', false, 64, 19), + (1965, 1000, '2021-01-12', false, 64, 19), + (1966, 1000, '2021-01-13', false, 64, 19), + (1967, 1500, '2021-01-14', false, 64, 19), + (1968, 1500, '2021-01-15', false, 64, 19), + (1969, 1000, '2021-01-16', false, 64, 19), + (1970, 1000, '2021-01-17', false, 64, 19), + (1971, 1000, '2021-01-18', true, 64, 19), + (1972, 1000, '2021-01-19', false, 64, 19), + (1973, 1000, '2021-01-20', false, 64, 19), + (1974, 1500, '2021-01-21', false, 64, 19), + (1975, 1500, '2021-01-22', true, 64, 19), + (1976, 1000, '2021-01-23', true, 64, 19), + (1977, 1000, '2021-01-24', false, 64, 19), + (1978, 1000, '2021-01-25', false, 64, 19), + (1979, 1000, '2021-01-26', false, 64, 19), + (1980, 1000, '2021-01-27', false, 64, 19), + (1981, 1500, '2021-01-28', false, 64, 19), + (1982, 1500, '2021-01-29', false, 64, 19), + (1983, 1000, '2021-01-30', false, 64, 19), + (1984, 1000, '2021-01-31', false, 64, 19), + (1985, 1500, '2021-01-01', false, 65, 62), + (1986, 1000, '2021-01-02', false, 65, 62), + (1987, 1000, '2021-01-03', true, 65, 62), + (1988, 1000, '2021-01-04', false, 65, 62), + (1989, 1000, '2021-01-05', false, 65, 62), + (1990, 1000, '2021-01-06', true, 65, 62), + (1991, 1500, '2021-01-07', false, 65, 62), + (1992, 1500, '2021-01-08', false, 65, 62), + (1993, 1000, '2021-01-09', false, 65, 62), + (1994, 1000, '2021-01-10', false, 65, 62), + (1995, 1000, '2021-01-11', false, 65, 62), + (1996, 1000, '2021-01-12', true, 65, 62), + (1997, 1000, '2021-01-13', false, 65, 62), + (1998, 1500, '2021-01-14', false, 65, 62), + (1999, 1500, '2021-01-15', true, 65, 62), + (2000, 1000, '2021-01-16', false, 65, 62), + (2001, 1000, '2021-01-17', false, 65, 62), + (2002, 1000, '2021-01-18', false, 65, 62), + (2003, 1000, '2021-01-19', false, 65, 62), + (2004, 1000, '2021-01-20', true, 65, 62), + (2005, 1500, '2021-01-21', false, 65, 62), + (2006, 1500, '2021-01-22', true, 65, 62), + (2007, 1000, '2021-01-23', false, 65, 62), + (2008, 1000, '2021-01-24', false, 65, 62), + (2009, 1000, '2021-01-25', false, 65, 62), + (2010, 1000, '2021-01-26', false, 65, 62), + (2011, 1000, '2021-01-27', false, 65, 62), + (2012, 1500, '2021-01-28', false, 65, 62), + (2013, 1500, '2021-01-29', false, 65, 62), + (2014, 1000, '2021-01-30', false, 65, 62), + (2015, 1000, '2021-01-31', false, 65, 62), + (2016, 1500, '2021-01-01', false, 66, 12), + (2017, 1000, '2021-01-02', false, 66, 12), + (2018, 1000, '2021-01-03', true, 66, 12), + (2019, 1000, '2021-01-04', true, 66, 12), + (2020, 1000, '2021-01-05', false, 66, 12), + (2021, 1000, '2021-01-06', true, 66, 12), + (2022, 1500, '2021-01-07', true, 66, 12), + (2023, 1500, '2021-01-08', false, 66, 12), + (2024, 1000, '2021-01-09', false, 66, 12), + (2025, 1000, '2021-01-10', false, 66, 12), + (2026, 1000, '2021-01-11', false, 66, 12), + (2027, 1000, '2021-01-12', false, 66, 12), + (2028, 1000, '2021-01-13', false, 66, 12), + (2029, 1500, '2021-01-14', false, 66, 12), + (2030, 1500, '2021-01-15', false, 66, 12), + (2031, 1000, '2021-01-16', false, 66, 12), + (2032, 1000, '2021-01-17', false, 66, 12), + (2033, 1000, '2021-01-18', true, 66, 12), + (2034, 1000, '2021-01-19', false, 66, 12), + (2035, 1000, '2021-01-20', true, 66, 12), + (2036, 1500, '2021-01-21', false, 66, 12), + (2037, 1500, '2021-01-22', false, 66, 12), + (2038, 1000, '2021-01-23', false, 66, 12), + (2039, 1000, '2021-01-24', false, 66, 12), + (2040, 1000, '2021-01-25', false, 66, 12), + (2041, 1000, '2021-01-26', true, 66, 12), + (2042, 1000, '2021-01-27', false, 66, 12), + (2043, 1500, '2021-01-28', false, 66, 12), + (2044, 1500, '2021-01-29', true, 66, 12), + (2045, 1000, '2021-01-30', false, 66, 12), + (2046, 1000, '2021-01-31', false, 66, 12), + (2047, 1500, '2021-01-01', false, 67, 8), + (2048, 1000, '2021-01-02', false, 67, 8), + (2049, 1000, '2021-01-03', false, 67, 8), + (2050, 1000, '2021-01-04', true, 67, 8), + (2051, 1000, '2021-01-05', true, 67, 8), + (2052, 1000, '2021-01-06', true, 67, 8), + (2053, 1500, '2021-01-07', false, 67, 8), + (2054, 1500, '2021-01-08', true, 67, 8), + (2055, 1000, '2021-01-09', true, 67, 8), + (2056, 1000, '2021-01-10', true, 67, 8), + (2057, 1000, '2021-01-11', false, 67, 8), + (2058, 1000, '2021-01-12', false, 67, 8), + (2059, 1000, '2021-01-13', false, 67, 8), + (2060, 1500, '2021-01-14', false, 67, 8), + (2061, 1500, '2021-01-15', true, 67, 8), + (2062, 1000, '2021-01-16', false, 67, 8), + (2063, 1000, '2021-01-17', false, 67, 8), + (2064, 1000, '2021-01-18', false, 67, 8), + (2065, 1000, '2021-01-19', false, 67, 8), + (2066, 1000, '2021-01-20', true, 67, 8), + (2067, 1500, '2021-01-21', false, 67, 8), + (2068, 1500, '2021-01-22', false, 67, 8), + (2069, 1000, '2021-01-23', false, 67, 8), + (2070, 1000, '2021-01-24', false, 67, 8), + (2071, 1000, '2021-01-25', false, 67, 8), + (2072, 1000, '2021-01-26', false, 67, 8), + (2073, 1000, '2021-01-27', false, 67, 8), + (2074, 1500, '2021-01-28', false, 67, 8), + (2075, 1500, '2021-01-29', false, 67, 8), + (2076, 1000, '2021-01-30', true, 67, 8), + (2077, 1000, '2021-01-31', false, 67, 8), + (2078, 1500, '2021-01-01', false, 68, 15), + (2079, 1000, '2021-01-02', false, 68, 15), + (2080, 1000, '2021-01-03', false, 68, 15), + (2081, 1000, '2021-01-04', false, 68, 15), + (2082, 1000, '2021-01-05', false, 68, 15), + (2083, 1000, '2021-01-06', false, 68, 15), + (2084, 1500, '2021-01-07', true, 68, 15), + (2085, 1500, '2021-01-08', false, 68, 15), + (2086, 1000, '2021-01-09', true, 68, 15), + (2087, 1000, '2021-01-10', false, 68, 15), + (2088, 1000, '2021-01-11', true, 68, 15), + (2089, 1000, '2021-01-12', true, 68, 15), + (2090, 1000, '2021-01-13', true, 68, 15), + (2091, 1500, '2021-01-14', true, 68, 15), + (2092, 1500, '2021-01-15', false, 68, 15), + (2093, 1000, '2021-01-16', false, 68, 15), + (2094, 1000, '2021-01-17', false, 68, 15), + (2095, 1000, '2021-01-18', false, 68, 15), + (2096, 1000, '2021-01-19', true, 68, 15), + (2097, 1000, '2021-01-20', false, 68, 15), + (2098, 1500, '2021-01-21', false, 68, 15), + (2099, 1500, '2021-01-22', true, 68, 15), + (2100, 1000, '2021-01-23', false, 68, 15), + (2101, 1000, '2021-01-24', true, 68, 15), + (2102, 1000, '2021-01-25', false, 68, 15), + (2103, 1000, '2021-01-26', false, 68, 15), + (2104, 1000, '2021-01-27', true, 68, 15), + (2105, 1500, '2021-01-28', false, 68, 15), + (2106, 1500, '2021-01-29', true, 68, 15), + (2107, 1000, '2021-01-30', false, 68, 15), + (2108, 1000, '2021-01-31', false, 68, 15), + (2109, 1500, '2021-01-01', true, 69, 74), + (2110, 1000, '2021-01-02', false, 69, 74), + (2111, 1000, '2021-01-03', false, 69, 74), + (2112, 1000, '2021-01-04', true, 69, 74), + (2113, 1000, '2021-01-05', true, 69, 74), + (2114, 1000, '2021-01-06', false, 69, 74), + (2115, 1500, '2021-01-07', false, 69, 74), + (2116, 1500, '2021-01-08', false, 69, 74), + (2117, 1000, '2021-01-09', false, 69, 74), + (2118, 1000, '2021-01-10', false, 69, 74), + (2119, 1000, '2021-01-11', false, 69, 74), + (2120, 1000, '2021-01-12', false, 69, 74), + (2121, 1000, '2021-01-13', false, 69, 74), + (2122, 1500, '2021-01-14', true, 69, 74), + (2123, 1500, '2021-01-15', false, 69, 74), + (2124, 1000, '2021-01-16', true, 69, 74), + (2125, 1000, '2021-01-17', false, 69, 74), + (2126, 1000, '2021-01-18', true, 69, 74), + (2127, 1000, '2021-01-19', false, 69, 74), + (2128, 1000, '2021-01-20', false, 69, 74), + (2129, 1500, '2021-01-21', false, 69, 74), + (2130, 1500, '2021-01-22', false, 69, 74), + (2131, 1000, '2021-01-23', true, 69, 74), + (2132, 1000, '2021-01-24', false, 69, 74), + (2133, 1000, '2021-01-25', false, 69, 74), + (2134, 1000, '2021-01-26', false, 69, 74), + (2135, 1000, '2021-01-27', false, 69, 74), + (2136, 1500, '2021-01-28', false, 69, 74), + (2137, 1500, '2021-01-29', true, 69, 74), + (2138, 1000, '2021-01-30', true, 69, 74), + (2139, 1000, '2021-01-31', true, 69, 74), + (2140, 1500, '2021-01-01', true, 70, 58), + (2141, 1000, '2021-01-02', false, 70, 58), + (2142, 1000, '2021-01-03', false, 70, 58), + (2143, 1000, '2021-01-04', false, 70, 58), + (2144, 1000, '2021-01-05', false, 70, 58), + (2145, 1000, '2021-01-06', false, 70, 58), + (2146, 1500, '2021-01-07', false, 70, 58), + (2147, 1500, '2021-01-08', false, 70, 58), + (2148, 1000, '2021-01-09', false, 70, 58), + (2149, 1000, '2021-01-10', false, 70, 58), + (2150, 1000, '2021-01-11', false, 70, 58), + (2151, 1000, '2021-01-12', false, 70, 58), + (2152, 1000, '2021-01-13', false, 70, 58), + (2153, 1500, '2021-01-14', false, 70, 58), + (2154, 1500, '2021-01-15', true, 70, 58), + (2155, 1000, '2021-01-16', true, 70, 58), + (2156, 1000, '2021-01-17', false, 70, 58), + (2157, 1000, '2021-01-18', false, 70, 58), + (2158, 1000, '2021-01-19', false, 70, 58), + (2159, 1000, '2021-01-20', false, 70, 58), + (2160, 1500, '2021-01-21', true, 70, 58), + (2161, 1500, '2021-01-22', false, 70, 58), + (2162, 1000, '2021-01-23', false, 70, 58), + (2163, 1000, '2021-01-24', false, 70, 58), + (2164, 1000, '2021-01-25', true, 70, 58), + (2165, 1000, '2021-01-26', false, 70, 58), + (2166, 1000, '2021-01-27', false, 70, 58), + (2167, 1500, '2021-01-28', false, 70, 58), + (2168, 1500, '2021-01-29', false, 70, 58), + (2169, 1000, '2021-01-30', false, 70, 58), + (2170, 1000, '2021-01-31', false, 70, 58), + (2171, 1500, '2021-01-01', false, 71, 45), + (2172, 1000, '2021-01-02', false, 71, 45), + (2173, 1000, '2021-01-03', false, 71, 45), + (2174, 1000, '2021-01-04', false, 71, 45), + (2175, 1000, '2021-01-05', false, 71, 45), + (2176, 1000, '2021-01-06', false, 71, 45), + (2177, 1500, '2021-01-07', true, 71, 45), + (2178, 1500, '2021-01-08', false, 71, 45), + (2179, 1000, '2021-01-09', true, 71, 45), + (2180, 1000, '2021-01-10', true, 71, 45), + (2181, 1000, '2021-01-11', false, 71, 45), + (2182, 1000, '2021-01-12', true, 71, 45), + (2183, 1000, '2021-01-13', false, 71, 45), + (2184, 1500, '2021-01-14', false, 71, 45), + (2185, 1500, '2021-01-15', false, 71, 45), + (2186, 1000, '2021-01-16', false, 71, 45), + (2187, 1000, '2021-01-17', false, 71, 45), + (2188, 1000, '2021-01-18', false, 71, 45), + (2189, 1000, '2021-01-19', false, 71, 45), + (2190, 1000, '2021-01-20', false, 71, 45), + (2191, 1500, '2021-01-21', false, 71, 45), + (2192, 1500, '2021-01-22', false, 71, 45), + (2193, 1000, '2021-01-23', false, 71, 45), + (2194, 1000, '2021-01-24', false, 71, 45), + (2195, 1000, '2021-01-25', false, 71, 45), + (2196, 1000, '2021-01-26', true, 71, 45), + (2197, 1000, '2021-01-27', true, 71, 45), + (2198, 1500, '2021-01-28', true, 71, 45), + (2199, 1500, '2021-01-29', false, 71, 45), + (2200, 1000, '2021-01-30', false, 71, 45), + (2201, 1000, '2021-01-31', false, 71, 45), + (2202, 1500, '2021-01-01', false, 72, 5), + (2203, 1000, '2021-01-02', false, 72, 5), + (2204, 1000, '2021-01-03', false, 72, 5), + (2205, 1000, '2021-01-04', true, 72, 5), + (2206, 1000, '2021-01-05', false, 72, 5), + (2207, 1000, '2021-01-06', true, 72, 5), + (2208, 1500, '2021-01-07', false, 72, 5), + (2209, 1500, '2021-01-08', false, 72, 5), + (2210, 1000, '2021-01-09', false, 72, 5), + (2211, 1000, '2021-01-10', false, 72, 5), + (2212, 1000, '2021-01-11', false, 72, 5), + (2213, 1000, '2021-01-12', false, 72, 5), + (2214, 1000, '2021-01-13', false, 72, 5), + (2215, 1500, '2021-01-14', true, 72, 5), + (2216, 1500, '2021-01-15', false, 72, 5), + (2217, 1000, '2021-01-16', true, 72, 5), + (2218, 1000, '2021-01-17', false, 72, 5), + (2219, 1000, '2021-01-18', true, 72, 5), + (2220, 1000, '2021-01-19', false, 72, 5), + (2221, 1000, '2021-01-20', false, 72, 5), + (2222, 1500, '2021-01-21', false, 72, 5), + (2223, 1500, '2021-01-22', true, 72, 5), + (2224, 1000, '2021-01-23', false, 72, 5), + (2225, 1000, '2021-01-24', false, 72, 5), + (2226, 1000, '2021-01-25', false, 72, 5), + (2227, 1000, '2021-01-26', true, 72, 5), + (2228, 1000, '2021-01-27', false, 72, 5), + (2229, 1500, '2021-01-28', false, 72, 5), + (2230, 1500, '2021-01-29', true, 72, 5), + (2231, 1000, '2021-01-30', true, 72, 5), + (2232, 1000, '2021-01-31', false, 72, 5), + (2233, 1500, '2021-01-01', false, 73, 54), + (2234, 1000, '2021-01-02', false, 73, 54), + (2235, 1000, '2021-01-03', true, 73, 54), + (2236, 1000, '2021-01-04', true, 73, 54), + (2237, 1000, '2021-01-05', false, 73, 54), + (2238, 1000, '2021-01-06', false, 73, 54), + (2239, 1500, '2021-01-07', false, 73, 54), + (2240, 1500, '2021-01-08', false, 73, 54), + (2241, 1000, '2021-01-09', false, 73, 54), + (2242, 1000, '2021-01-10', false, 73, 54), + (2243, 1000, '2021-01-11', false, 73, 54), + (2244, 1000, '2021-01-12', false, 73, 54), + (2245, 1000, '2021-01-13', false, 73, 54), + (2246, 1500, '2021-01-14', false, 73, 54), + (2247, 1500, '2021-01-15', false, 73, 54), + (2248, 1000, '2021-01-16', false, 73, 54), + (2249, 1000, '2021-01-17', true, 73, 54), + (2250, 1000, '2021-01-18', false, 73, 54), + (2251, 1000, '2021-01-19', true, 73, 54), + (2252, 1000, '2021-01-20', true, 73, 54), + (2253, 1500, '2021-01-21', false, 73, 54), + (2254, 1500, '2021-01-22', false, 73, 54), + (2255, 1000, '2021-01-23', false, 73, 54), + (2256, 1000, '2021-01-24', false, 73, 54), + (2257, 1000, '2021-01-25', false, 73, 54), + (2258, 1000, '2021-01-26', true, 73, 54), + (2259, 1000, '2021-01-27', false, 73, 54), + (2260, 1500, '2021-01-28', true, 73, 54), + (2261, 1500, '2021-01-29', false, 73, 54), + (2262, 1000, '2021-01-30', false, 73, 54), + (2263, 1000, '2021-01-31', false, 73, 54), + (2264, 1500, '2021-01-01', false, 74, 75), + (2265, 1000, '2021-01-02', true, 74, 75), + (2266, 1000, '2021-01-03', false, 74, 75), + (2267, 1000, '2021-01-04', false, 74, 75), + (2268, 1000, '2021-01-05', false, 74, 75), + (2269, 1000, '2021-01-06', true, 74, 75), + (2270, 1500, '2021-01-07', false, 74, 75), + (2271, 1500, '2021-01-08', false, 74, 75), + (2272, 1000, '2021-01-09', true, 74, 75), + (2273, 1000, '2021-01-10', false, 74, 75), + (2274, 1000, '2021-01-11', false, 74, 75), + (2275, 1000, '2021-01-12', false, 74, 75), + (2276, 1000, '2021-01-13', true, 74, 75), + (2277, 1500, '2021-01-14', false, 74, 75), + (2278, 1500, '2021-01-15', true, 74, 75), + (2279, 1000, '2021-01-16', false, 74, 75), + (2280, 1000, '2021-01-17', true, 74, 75), + (2281, 1000, '2021-01-18', false, 74, 75), + (2282, 1000, '2021-01-19', true, 74, 75), + (2283, 1000, '2021-01-20', false, 74, 75), + (2284, 1500, '2021-01-21', false, 74, 75), + (2285, 1500, '2021-01-22', false, 74, 75), + (2286, 1000, '2021-01-23', false, 74, 75), + (2287, 1000, '2021-01-24', false, 74, 75), + (2288, 1000, '2021-01-25', true, 74, 75), + (2289, 1000, '2021-01-26', false, 74, 75), + (2290, 1000, '2021-01-27', false, 74, 75), + (2291, 1500, '2021-01-28', true, 74, 75), + (2292, 1500, '2021-01-29', false, 74, 75), + (2293, 1000, '2021-01-30', true, 74, 75), + (2294, 1000, '2021-01-31', false, 74, 75), + (2295, 1500, '2021-01-01', true, 75, 83), + (2296, 1000, '2021-01-02', false, 75, 83), + (2297, 1000, '2021-01-03', false, 75, 83), + (2298, 1000, '2021-01-04', false, 75, 83), + (2299, 1000, '2021-01-05', false, 75, 83), + (2300, 1000, '2021-01-06', false, 75, 83), + (2301, 1500, '2021-01-07', true, 75, 83), + (2302, 1500, '2021-01-08', false, 75, 83), + (2303, 1000, '2021-01-09', false, 75, 83), + (2304, 1000, '2021-01-10', false, 75, 83), + (2305, 1000, '2021-01-11', false, 75, 83), + (2306, 1000, '2021-01-12', false, 75, 83), + (2307, 1000, '2021-01-13', false, 75, 83), + (2308, 1500, '2021-01-14', false, 75, 83), + (2309, 1500, '2021-01-15', true, 75, 83), + (2310, 1000, '2021-01-16', false, 75, 83), + (2311, 1000, '2021-01-17', true, 75, 83), + (2312, 1000, '2021-01-18', false, 75, 83), + (2313, 1000, '2021-01-19', false, 75, 83), + (2314, 1000, '2021-01-20', false, 75, 83), + (2315, 1500, '2021-01-21', false, 75, 83), + (2316, 1500, '2021-01-22', false, 75, 83), + (2317, 1000, '2021-01-23', true, 75, 83), + (2318, 1000, '2021-01-24', false, 75, 83), + (2319, 1000, '2021-01-25', false, 75, 83), + (2320, 1000, '2021-01-26', false, 75, 83), + (2321, 1000, '2021-01-27', false, 75, 83), + (2322, 1500, '2021-01-28', false, 75, 83), + (2323, 1500, '2021-01-29', false, 75, 83), + (2324, 1000, '2021-01-30', false, 75, 83), + (2325, 1000, '2021-01-31', false, 75, 83), + (2326, 1500, '2021-01-01', true, 76, 71), + (2327, 1000, '2021-01-02', false, 76, 71), + (2328, 1000, '2021-01-03', false, 76, 71), + (2329, 1000, '2021-01-04', false, 76, 71), + (2330, 1000, '2021-01-05', true, 76, 71), + (2331, 1000, '2021-01-06', false, 76, 71), + (2332, 1500, '2021-01-07', false, 76, 71), + (2333, 1500, '2021-01-08', true, 76, 71), + (2334, 1000, '2021-01-09', true, 76, 71), + (2335, 1000, '2021-01-10', false, 76, 71), + (2336, 1000, '2021-01-11', false, 76, 71), + (2337, 1000, '2021-01-12', false, 76, 71), + (2338, 1000, '2021-01-13', true, 76, 71), + (2339, 1500, '2021-01-14', false, 76, 71), + (2340, 1500, '2021-01-15', false, 76, 71), + (2341, 1000, '2021-01-16', true, 76, 71), + (2342, 1000, '2021-01-17', true, 76, 71), + (2343, 1000, '2021-01-18', false, 76, 71), + (2344, 1000, '2021-01-19', false, 76, 71), + (2345, 1000, '2021-01-20', false, 76, 71), + (2346, 1500, '2021-01-21', false, 76, 71), + (2347, 1500, '2021-01-22', false, 76, 71), + (2348, 1000, '2021-01-23', false, 76, 71), + (2349, 1000, '2021-01-24', false, 76, 71), + (2350, 1000, '2021-01-25', false, 76, 71), + (2351, 1000, '2021-01-26', true, 76, 71), + (2352, 1000, '2021-01-27', false, 76, 71), + (2353, 1500, '2021-01-28', false, 76, 71), + (2354, 1500, '2021-01-29', false, 76, 71), + (2355, 1000, '2021-01-30', false, 76, 71), + (2356, 1000, '2021-01-31', true, 76, 71), + (2357, 1500, '2021-01-01', false, 77, 79), + (2358, 1000, '2021-01-02', true, 77, 79), + (2359, 1000, '2021-01-03', true, 77, 79), + (2360, 1000, '2021-01-04', false, 77, 79), + (2361, 1000, '2021-01-05', false, 77, 79), + (2362, 1000, '2021-01-06', false, 77, 79), + (2363, 1500, '2021-01-07', false, 77, 79), + (2364, 1500, '2021-01-08', false, 77, 79), + (2365, 1000, '2021-01-09', false, 77, 79), + (2366, 1000, '2021-01-10', false, 77, 79), + (2367, 1000, '2021-01-11', false, 77, 79), + (2368, 1000, '2021-01-12', false, 77, 79), + (2369, 1000, '2021-01-13', false, 77, 79), + (2370, 1500, '2021-01-14', true, 77, 79), + (2371, 1500, '2021-01-15', false, 77, 79), + (2372, 1000, '2021-01-16', false, 77, 79), + (2373, 1000, '2021-01-17', false, 77, 79), + (2374, 1000, '2021-01-18', true, 77, 79), + (2375, 1000, '2021-01-19', false, 77, 79), + (2376, 1000, '2021-01-20', true, 77, 79), + (2377, 1500, '2021-01-21', true, 77, 79), + (2378, 1500, '2021-01-22', false, 77, 79), + (2379, 1000, '2021-01-23', false, 77, 79), + (2380, 1000, '2021-01-24', false, 77, 79), + (2381, 1000, '2021-01-25', true, 77, 79), + (2382, 1000, '2021-01-26', true, 77, 79), + (2383, 1000, '2021-01-27', true, 77, 79), + (2384, 1500, '2021-01-28', false, 77, 79), + (2385, 1500, '2021-01-29', false, 77, 79), + (2386, 1000, '2021-01-30', false, 77, 79), + (2387, 1000, '2021-01-31', true, 77, 79), + (2388, 1500, '2021-01-01', false, 78, 26), + (2389, 1000, '2021-01-02', false, 78, 26), + (2390, 1000, '2021-01-03', true, 78, 26), + (2391, 1000, '2021-01-04', false, 78, 26), + (2392, 1000, '2021-01-05', false, 78, 26), + (2393, 1000, '2021-01-06', false, 78, 26), + (2394, 1500, '2021-01-07', true, 78, 26), + (2395, 1500, '2021-01-08', false, 78, 26), + (2396, 1000, '2021-01-09', false, 78, 26), + (2397, 1000, '2021-01-10', true, 78, 26), + (2398, 1000, '2021-01-11', false, 78, 26), + (2399, 1000, '2021-01-12', true, 78, 26), + (2400, 1000, '2021-01-13', true, 78, 26), + (2401, 1500, '2021-01-14', true, 78, 26), + (2402, 1500, '2021-01-15', false, 78, 26), + (2403, 1000, '2021-01-16', false, 78, 26), + (2404, 1000, '2021-01-17', false, 78, 26), + (2405, 1000, '2021-01-18', true, 78, 26), + (2406, 1000, '2021-01-19', false, 78, 26), + (2407, 1000, '2021-01-20', true, 78, 26), + (2408, 1500, '2021-01-21', false, 78, 26), + (2409, 1500, '2021-01-22', false, 78, 26), + (2410, 1000, '2021-01-23', false, 78, 26), + (2411, 1000, '2021-01-24', false, 78, 26), + (2412, 1000, '2021-01-25', true, 78, 26), + (2413, 1000, '2021-01-26', true, 78, 26), + (2414, 1000, '2021-01-27', false, 78, 26), + (2415, 1500, '2021-01-28', false, 78, 26), + (2416, 1500, '2021-01-29', true, 78, 26), + (2417, 1000, '2021-01-30', false, 78, 26), + (2418, 1000, '2021-01-31', true, 78, 26), + (2419, 1500, '2021-01-01', false, 79, 67), + (2420, 1000, '2021-01-02', false, 79, 67), + (2421, 1000, '2021-01-03', false, 79, 67), + (2422, 1000, '2021-01-04', true, 79, 67), + (2423, 1000, '2021-01-05', false, 79, 67), + (2424, 1000, '2021-01-06', true, 79, 67), + (2425, 1500, '2021-01-07', false, 79, 67), + (2426, 1500, '2021-01-08', false, 79, 67), + (2427, 1000, '2021-01-09', true, 79, 67), + (2428, 1000, '2021-01-10', false, 79, 67), + (2429, 1000, '2021-01-11', false, 79, 67), + (2430, 1000, '2021-01-12', false, 79, 67), + (2431, 1000, '2021-01-13', false, 79, 67), + (2432, 1500, '2021-01-14', false, 79, 67), + (2433, 1500, '2021-01-15', false, 79, 67), + (2434, 1000, '2021-01-16', false, 79, 67), + (2435, 1000, '2021-01-17', false, 79, 67), + (2436, 1000, '2021-01-18', false, 79, 67), + (2437, 1000, '2021-01-19', false, 79, 67), + (2438, 1000, '2021-01-20', true, 79, 67), + (2439, 1500, '2021-01-21', false, 79, 67), + (2440, 1500, '2021-01-22', true, 79, 67), + (2441, 1000, '2021-01-23', true, 79, 67), + (2442, 1000, '2021-01-24', true, 79, 67), + (2443, 1000, '2021-01-25', false, 79, 67), + (2444, 1000, '2021-01-26', false, 79, 67), + (2445, 1000, '2021-01-27', false, 79, 67), + (2446, 1500, '2021-01-28', false, 79, 67), + (2447, 1500, '2021-01-29', true, 79, 67), + (2448, 1000, '2021-01-30', false, 79, 67), + (2449, 1000, '2021-01-31', false, 79, 67), + (2450, 1500, '2021-01-01', false, 80, 79), + (2451, 1000, '2021-01-02', false, 80, 79), + (2452, 1000, '2021-01-03', true, 80, 79), + (2453, 1000, '2021-01-04', true, 80, 79), + (2454, 1000, '2021-01-05', false, 80, 79), + (2455, 1000, '2021-01-06', false, 80, 79), + (2456, 1500, '2021-01-07', false, 80, 79), + (2457, 1500, '2021-01-08', false, 80, 79), + (2458, 1000, '2021-01-09', false, 80, 79), + (2459, 1000, '2021-01-10', false, 80, 79), + (2460, 1000, '2021-01-11', false, 80, 79), + (2461, 1000, '2021-01-12', false, 80, 79), + (2462, 1000, '2021-01-13', false, 80, 79), + (2463, 1500, '2021-01-14', false, 80, 79), + (2464, 1500, '2021-01-15', true, 80, 79), + (2465, 1000, '2021-01-16', false, 80, 79), + (2466, 1000, '2021-01-17', true, 80, 79), + (2467, 1000, '2021-01-18', false, 80, 79), + (2468, 1000, '2021-01-19', false, 80, 79), + (2469, 1000, '2021-01-20', false, 80, 79), + (2470, 1500, '2021-01-21', false, 80, 79), + (2471, 1500, '2021-01-22', false, 80, 79), + (2472, 1000, '2021-01-23', false, 80, 79), + (2473, 1000, '2021-01-24', false, 80, 79), + (2474, 1000, '2021-01-25', false, 80, 79), + (2475, 1000, '2021-01-26', false, 80, 79), + (2476, 1000, '2021-01-27', true, 80, 79), + (2477, 1500, '2021-01-28', false, 80, 79), + (2478, 1500, '2021-01-29', false, 80, 79), + (2479, 1000, '2021-01-30', false, 80, 79), + (2480, 1000, '2021-01-31', false, 80, 79), + (2481, 1500, '2021-01-01', false, 81, 75), + (2482, 1000, '2021-01-02', true, 81, 75), + (2483, 1000, '2021-01-03', false, 81, 75), + (2484, 1000, '2021-01-04', false, 81, 75), + (2485, 1000, '2021-01-05', false, 81, 75), + (2486, 1000, '2021-01-06', false, 81, 75), + (2487, 1500, '2021-01-07', false, 81, 75), + (2488, 1500, '2021-01-08', false, 81, 75), + (2489, 1000, '2021-01-09', false, 81, 75), + (2490, 1000, '2021-01-10', false, 81, 75), + (2491, 1000, '2021-01-11', false, 81, 75), + (2492, 1000, '2021-01-12', false, 81, 75), + (2493, 1000, '2021-01-13', false, 81, 75), + (2494, 1500, '2021-01-14', false, 81, 75), + (2495, 1500, '2021-01-15', false, 81, 75), + (2496, 1000, '2021-01-16', false, 81, 75), + (2497, 1000, '2021-01-17', false, 81, 75), + (2498, 1000, '2021-01-18', false, 81, 75), + (2499, 1000, '2021-01-19', false, 81, 75), + (2500, 1000, '2021-01-20', false, 81, 75), + (2501, 1500, '2021-01-21', false, 81, 75), + (2502, 1500, '2021-01-22', true, 81, 75), + (2503, 1000, '2021-01-23', false, 81, 75), + (2504, 1000, '2021-01-24', false, 81, 75), + (2505, 1000, '2021-01-25', true, 81, 75), + (2506, 1000, '2021-01-26', false, 81, 75), + (2507, 1000, '2021-01-27', false, 81, 75), + (2508, 1500, '2021-01-28', false, 81, 75), + (2509, 1500, '2021-01-29', true, 81, 75), + (2510, 1000, '2021-01-30', false, 81, 75), + (2511, 1000, '2021-01-31', false, 81, 75), + (2512, 1500, '2021-01-01', false, 82, 10), + (2513, 1000, '2021-01-02', false, 82, 10), + (2514, 1000, '2021-01-03', true, 82, 10), + (2515, 1000, '2021-01-04', false, 82, 10), + (2516, 1000, '2021-01-05', true, 82, 10), + (2517, 1000, '2021-01-06', false, 82, 10), + (2518, 1500, '2021-01-07', true, 82, 10), + (2519, 1500, '2021-01-08', false, 82, 10), + (2520, 1000, '2021-01-09', false, 82, 10), + (2521, 1000, '2021-01-10', false, 82, 10), + (2522, 1000, '2021-01-11', true, 82, 10), + (2523, 1000, '2021-01-12', false, 82, 10), + (2524, 1000, '2021-01-13', false, 82, 10), + (2525, 1500, '2021-01-14', true, 82, 10), + (2526, 1500, '2021-01-15', false, 82, 10), + (2527, 1000, '2021-01-16', false, 82, 10), + (2528, 1000, '2021-01-17', false, 82, 10), + (2529, 1000, '2021-01-18', false, 82, 10), + (2530, 1000, '2021-01-19', false, 82, 10), + (2531, 1000, '2021-01-20', false, 82, 10), + (2532, 1500, '2021-01-21', true, 82, 10), + (2533, 1500, '2021-01-22', false, 82, 10), + (2534, 1000, '2021-01-23', false, 82, 10), + (2535, 1000, '2021-01-24', true, 82, 10), + (2536, 1000, '2021-01-25', false, 82, 10), + (2537, 1000, '2021-01-26', false, 82, 10), + (2538, 1000, '2021-01-27', true, 82, 10), + (2539, 1500, '2021-01-28', false, 82, 10), + (2540, 1500, '2021-01-29', true, 82, 10), + (2541, 1000, '2021-01-30', false, 82, 10), + (2542, 1000, '2021-01-31', true, 82, 10), + (2543, 1500, '2021-01-01', false, 83, 57), + (2544, 1000, '2021-01-02', false, 83, 57), + (2545, 1000, '2021-01-03', false, 83, 57), + (2546, 1000, '2021-01-04', true, 83, 57), + (2547, 1000, '2021-01-05', false, 83, 57), + (2548, 1000, '2021-01-06', false, 83, 57), + (2549, 1500, '2021-01-07', false, 83, 57), + (2550, 1500, '2021-01-08', false, 83, 57), + (2551, 1000, '2021-01-09', false, 83, 57), + (2552, 1000, '2021-01-10', true, 83, 57), + (2553, 1000, '2021-01-11', false, 83, 57), + (2554, 1000, '2021-01-12', false, 83, 57), + (2555, 1000, '2021-01-13', false, 83, 57), + (2556, 1500, '2021-01-14', true, 83, 57), + (2557, 1500, '2021-01-15', false, 83, 57), + (2558, 1000, '2021-01-16', false, 83, 57), + (2559, 1000, '2021-01-17', false, 83, 57), + (2560, 1000, '2021-01-18', true, 83, 57), + (2561, 1000, '2021-01-19', true, 83, 57), + (2562, 1000, '2021-01-20', false, 83, 57), + (2563, 1500, '2021-01-21', false, 83, 57), + (2564, 1500, '2021-01-22', false, 83, 57), + (2565, 1000, '2021-01-23', false, 83, 57), + (2566, 1000, '2021-01-24', true, 83, 57), + (2567, 1000, '2021-01-25', false, 83, 57), + (2568, 1000, '2021-01-26', false, 83, 57), + (2569, 1000, '2021-01-27', true, 83, 57), + (2570, 1500, '2021-01-28', false, 83, 57), + (2571, 1500, '2021-01-29', true, 83, 57), + (2572, 1000, '2021-01-30', true, 83, 57), + (2573, 1000, '2021-01-31', false, 83, 57), + (2574, 1500, '2021-01-01', true, 84, 8), + (2575, 1000, '2021-01-02', true, 84, 8), + (2576, 1000, '2021-01-03', false, 84, 8), + (2577, 1000, '2021-01-04', false, 84, 8), + (2578, 1000, '2021-01-05', false, 84, 8), + (2579, 1000, '2021-01-06', false, 84, 8), + (2580, 1500, '2021-01-07', false, 84, 8), + (2581, 1500, '2021-01-08', false, 84, 8), + (2582, 1000, '2021-01-09', false, 84, 8), + (2583, 1000, '2021-01-10', true, 84, 8), + (2584, 1000, '2021-01-11', false, 84, 8), + (2585, 1000, '2021-01-12', false, 84, 8), + (2586, 1000, '2021-01-13', false, 84, 8), + (2587, 1500, '2021-01-14', false, 84, 8), + (2588, 1500, '2021-01-15', false, 84, 8), + (2589, 1000, '2021-01-16', true, 84, 8), + (2590, 1000, '2021-01-17', true, 84, 8), + (2591, 1000, '2021-01-18', false, 84, 8), + (2592, 1000, '2021-01-19', false, 84, 8), + (2593, 1000, '2021-01-20', false, 84, 8), + (2594, 1500, '2021-01-21', true, 84, 8), + (2595, 1500, '2021-01-22', false, 84, 8), + (2596, 1000, '2021-01-23', false, 84, 8), + (2597, 1000, '2021-01-24', false, 84, 8), + (2598, 1000, '2021-01-25', false, 84, 8), + (2599, 1000, '2021-01-26', false, 84, 8), + (2600, 1000, '2021-01-27', false, 84, 8), + (2601, 1500, '2021-01-28', true, 84, 8), + (2602, 1500, '2021-01-29', false, 84, 8), + (2603, 1000, '2021-01-30', true, 84, 8), + (2604, 1000, '2021-01-31', true, 84, 8), + (2605, 1500, '2021-01-01', false, 85, 37), + (2606, 1000, '2021-01-02', false, 85, 37), + (2607, 1000, '2021-01-03', true, 85, 37), + (2608, 1000, '2021-01-04', true, 85, 37), + (2609, 1000, '2021-01-05', true, 85, 37), + (2610, 1000, '2021-01-06', false, 85, 37), + (2611, 1500, '2021-01-07', true, 85, 37), + (2612, 1500, '2021-01-08', false, 85, 37), + (2613, 1000, '2021-01-09', false, 85, 37), + (2614, 1000, '2021-01-10', false, 85, 37), + (2615, 1000, '2021-01-11', true, 85, 37), + (2616, 1000, '2021-01-12', false, 85, 37), + (2617, 1000, '2021-01-13', false, 85, 37), + (2618, 1500, '2021-01-14', false, 85, 37), + (2619, 1500, '2021-01-15', false, 85, 37), + (2620, 1000, '2021-01-16', false, 85, 37), + (2621, 1000, '2021-01-17', false, 85, 37), + (2622, 1000, '2021-01-18', false, 85, 37), + (2623, 1000, '2021-01-19', true, 85, 37), + (2624, 1000, '2021-01-20', true, 85, 37), + (2625, 1500, '2021-01-21', false, 85, 37), + (2626, 1500, '2021-01-22', false, 85, 37), + (2627, 1000, '2021-01-23', false, 85, 37), + (2628, 1000, '2021-01-24', false, 85, 37), + (2629, 1000, '2021-01-25', false, 85, 37), + (2630, 1000, '2021-01-26', false, 85, 37), + (2631, 1000, '2021-01-27', false, 85, 37), + (2632, 1500, '2021-01-28', false, 85, 37), + (2633, 1500, '2021-01-29', false, 85, 37), + (2634, 1000, '2021-01-30', false, 85, 37), + (2635, 1000, '2021-01-31', true, 85, 37), + (2636, 1500, '2021-01-01', false, 86, 70), + (2637, 1000, '2021-01-02', true, 86, 70), + (2638, 1000, '2021-01-03', false, 86, 70), + (2639, 1000, '2021-01-04', false, 86, 70), + (2640, 1000, '2021-01-05', false, 86, 70), + (2641, 1000, '2021-01-06', false, 86, 70), + (2642, 1500, '2021-01-07', false, 86, 70), + (2643, 1500, '2021-01-08', false, 86, 70), + (2644, 1000, '2021-01-09', true, 86, 70), + (2645, 1000, '2021-01-10', true, 86, 70), + (2646, 1000, '2021-01-11', false, 86, 70), + (2647, 1000, '2021-01-12', false, 86, 70), + (2648, 1000, '2021-01-13', true, 86, 70), + (2649, 1500, '2021-01-14', true, 86, 70), + (2650, 1500, '2021-01-15', false, 86, 70), + (2651, 1000, '2021-01-16', false, 86, 70), + (2652, 1000, '2021-01-17', false, 86, 70), + (2653, 1000, '2021-01-18', false, 86, 70), + (2654, 1000, '2021-01-19', false, 86, 70), + (2655, 1000, '2021-01-20', false, 86, 70), + (2656, 1500, '2021-01-21', true, 86, 70), + (2657, 1500, '2021-01-22', false, 86, 70), + (2658, 1000, '2021-01-23', false, 86, 70), + (2659, 1000, '2021-01-24', false, 86, 70), + (2660, 1000, '2021-01-25', false, 86, 70), + (2661, 1000, '2021-01-26', false, 86, 70), + (2662, 1000, '2021-01-27', false, 86, 70), + (2663, 1500, '2021-01-28', true, 86, 70), + (2664, 1500, '2021-01-29', false, 86, 70), + (2665, 1000, '2021-01-30', true, 86, 70), + (2666, 1000, '2021-01-31', false, 86, 70), + (2667, 1500, '2021-01-01', false, 87, 29), + (2668, 1000, '2021-01-02', false, 87, 29), + (2669, 1000, '2021-01-03', false, 87, 29), + (2670, 1000, '2021-01-04', false, 87, 29), + (2671, 1000, '2021-01-05', true, 87, 29), + (2672, 1000, '2021-01-06', true, 87, 29), + (2673, 1500, '2021-01-07', false, 87, 29), + (2674, 1500, '2021-01-08', false, 87, 29), + (2675, 1000, '2021-01-09', false, 87, 29), + (2676, 1000, '2021-01-10', true, 87, 29), + (2677, 1000, '2021-01-11', false, 87, 29), + (2678, 1000, '2021-01-12', false, 87, 29), + (2679, 1000, '2021-01-13', true, 87, 29), + (2680, 1500, '2021-01-14', true, 87, 29), + (2681, 1500, '2021-01-15', true, 87, 29), + (2682, 1000, '2021-01-16', false, 87, 29), + (2683, 1000, '2021-01-17', false, 87, 29), + (2684, 1000, '2021-01-18', false, 87, 29), + (2685, 1000, '2021-01-19', false, 87, 29), + (2686, 1000, '2021-01-20', false, 87, 29), + (2687, 1500, '2021-01-21', false, 87, 29), + (2688, 1500, '2021-01-22', false, 87, 29), + (2689, 1000, '2021-01-23', false, 87, 29), + (2690, 1000, '2021-01-24', false, 87, 29), + (2691, 1000, '2021-01-25', false, 87, 29), + (2692, 1000, '2021-01-26', true, 87, 29), + (2693, 1000, '2021-01-27', false, 87, 29), + (2694, 1500, '2021-01-28', true, 87, 29), + (2695, 1500, '2021-01-29', false, 87, 29), + (2696, 1000, '2021-01-30', false, 87, 29), + (2697, 1000, '2021-01-31', false, 87, 29), + (2698, 1500, '2021-01-01', false, 88, 2), + (2699, 1000, '2021-01-02', false, 88, 2), + (2700, 1000, '2021-01-03', false, 88, 2), + (2701, 1000, '2021-01-04', false, 88, 2), + (2702, 1000, '2021-01-05', false, 88, 2), + (2703, 1000, '2021-01-06', false, 88, 2), + (2704, 1500, '2021-01-07', false, 88, 2), + (2705, 1500, '2021-01-08', false, 88, 2), + (2706, 1000, '2021-01-09', false, 88, 2), + (2707, 1000, '2021-01-10', false, 88, 2), + (2708, 1000, '2021-01-11', false, 88, 2), + (2709, 1000, '2021-01-12', false, 88, 2), + (2710, 1000, '2021-01-13', false, 88, 2), + (2711, 1500, '2021-01-14', false, 88, 2), + (2712, 1500, '2021-01-15', true, 88, 2), + (2713, 1000, '2021-01-16', false, 88, 2), + (2714, 1000, '2021-01-17', true, 88, 2), + (2715, 1000, '2021-01-18', false, 88, 2), + (2716, 1000, '2021-01-19', false, 88, 2), + (2717, 1000, '2021-01-20', false, 88, 2), + (2718, 1500, '2021-01-21', false, 88, 2), + (2719, 1500, '2021-01-22', false, 88, 2), + (2720, 1000, '2021-01-23', false, 88, 2), + (2721, 1000, '2021-01-24', true, 88, 2), + (2722, 1000, '2021-01-25', true, 88, 2), + (2723, 1000, '2021-01-26', false, 88, 2), + (2724, 1000, '2021-01-27', false, 88, 2), + (2725, 1500, '2021-01-28', false, 88, 2), + (2726, 1500, '2021-01-29', false, 88, 2), + (2727, 1000, '2021-01-30', false, 88, 2), + (2728, 1000, '2021-01-31', true, 88, 2), + (2729, 1500, '2021-01-01', false, 89, 74), + (2730, 1000, '2021-01-02', false, 89, 74), + (2731, 1000, '2021-01-03', false, 89, 74), + (2732, 1000, '2021-01-04', false, 89, 74), + (2733, 1000, '2021-01-05', false, 89, 74), + (2734, 1000, '2021-01-06', true, 89, 74), + (2735, 1500, '2021-01-07', false, 89, 74), + (2736, 1500, '2021-01-08', true, 89, 74), + (2737, 1000, '2021-01-09', true, 89, 74), + (2738, 1000, '2021-01-10', true, 89, 74), + (2739, 1000, '2021-01-11', false, 89, 74), + (2740, 1000, '2021-01-12', false, 89, 74), + (2741, 1000, '2021-01-13', false, 89, 74), + (2742, 1500, '2021-01-14', true, 89, 74), + (2743, 1500, '2021-01-15', false, 89, 74), + (2744, 1000, '2021-01-16', false, 89, 74), + (2745, 1000, '2021-01-17', false, 89, 74), + (2746, 1000, '2021-01-18', true, 89, 74), + (2747, 1000, '2021-01-19', false, 89, 74), + (2748, 1000, '2021-01-20', false, 89, 74), + (2749, 1500, '2021-01-21', false, 89, 74), + (2750, 1500, '2021-01-22', true, 89, 74), + (2751, 1000, '2021-01-23', true, 89, 74), + (2752, 1000, '2021-01-24', false, 89, 74), + (2753, 1000, '2021-01-25', true, 89, 74), + (2754, 1000, '2021-01-26', false, 89, 74), + (2755, 1000, '2021-01-27', true, 89, 74), + (2756, 1500, '2021-01-28', false, 89, 74), + (2757, 1500, '2021-01-29', false, 89, 74), + (2758, 1000, '2021-01-30', false, 89, 74), + (2759, 1000, '2021-01-31', false, 89, 74), + (2760, 1500, '2021-01-01', false, 90, 47), + (2761, 1000, '2021-01-02', false, 90, 47), + (2762, 1000, '2021-01-03', false, 90, 47), + (2763, 1000, '2021-01-04', true, 90, 47), + (2764, 1000, '2021-01-05', false, 90, 47), + (2765, 1000, '2021-01-06', false, 90, 47), + (2766, 1500, '2021-01-07', true, 90, 47), + (2767, 1500, '2021-01-08', false, 90, 47), + (2768, 1000, '2021-01-09', false, 90, 47), + (2769, 1000, '2021-01-10', false, 90, 47), + (2770, 1000, '2021-01-11', false, 90, 47), + (2771, 1000, '2021-01-12', false, 90, 47), + (2772, 1000, '2021-01-13', false, 90, 47), + (2773, 1500, '2021-01-14', false, 90, 47), + (2774, 1500, '2021-01-15', false, 90, 47), + (2775, 1000, '2021-01-16', true, 90, 47), + (2776, 1000, '2021-01-17', false, 90, 47), + (2777, 1000, '2021-01-18', false, 90, 47), + (2778, 1000, '2021-01-19', false, 90, 47), + (2779, 1000, '2021-01-20', false, 90, 47), + (2780, 1500, '2021-01-21', false, 90, 47), + (2781, 1500, '2021-01-22', true, 90, 47), + (2782, 1000, '2021-01-23', false, 90, 47), + (2783, 1000, '2021-01-24', false, 90, 47), + (2784, 1000, '2021-01-25', false, 90, 47), + (2785, 1000, '2021-01-26', true, 90, 47), + (2786, 1000, '2021-01-27', false, 90, 47), + (2787, 1500, '2021-01-28', false, 90, 47), + (2788, 1500, '2021-01-29', false, 90, 47), + (2789, 1000, '2021-01-30', true, 90, 47), + (2790, 1000, '2021-01-31', false, 90, 47), + + (5000, 3000, '2021-01-01', false, 91, 123), + (5001, 2000, '2021-01-02', false, 91, 119), + (5002, 2000, '2021-01-03', true, 91, 84), + (5003, 2000, '2021-01-04', true, 91, 97), + (5004, 2000, '2021-01-05', false, 91, 97), + (5005, 2000, '2021-01-06', false, 91, 96), + (5006, 3000, '2021-01-07', true, 91, 90), + (5007, 3000, '2021-01-08', false, 91, 137), + (5008, 2000, '2021-01-09', false, 91, 88), + (5009, 2000, '2021-01-10', false, 91, 86), + (5010, 2000, '2021-01-11', false, 91, 116), + (5011, 2000, '2021-01-12', false, 91, 119), + (5012, 2000, '2021-01-13', false, 91, 102), + (5013, 3000, '2021-01-14', false, 91, 90), + (5014, 3000, '2021-01-15', false, 91, 92), + (5015, 2000, '2021-01-16', false, 91, 121), + (5016, 2000, '2021-01-17', true, 91, 76), + (5017, 2000, '2021-01-18', true, 91, 137), + (5018, 2000, '2021-01-19', false, 91, 122), + (5019, 2000, '2021-01-20', false, 91, 111), + (5020, 3000, '2021-01-21', false, 91, 85), + (5021, 3000, '2021-01-22', false, 91, 101), + (5022, 2000, '2021-01-23', false, 91, 91), + (5023, 2000, '2021-01-24', false, 91, 104), + (5024, 2000, '2021-01-25', true, 91, 130), + (5025, 2000, '2021-01-26', false, 91, 83), + (5026, 2000, '2021-01-27', false, 91, 121), + (5027, 3000, '2021-01-28', false, 91, 104), + (5028, 3000, '2021-01-29', false, 91, 125), + (5029, 2000, '2021-01-30', false, 91, 131), + (5030, 2000, '2021-01-31', true, 91, 114), + (5031, 3000, '2021-01-01', false, 92, 124), + (5032, 2000, '2021-01-02', false, 92, 75), + (5033, 2000, '2021-01-03', false, 92, 71), + (5034, 2000, '2021-01-04', false, 92, 78), + (5035, 2000, '2021-01-05', false, 92, 112), + (5036, 2000, '2021-01-06', false, 92, 140), + (5037, 3000, '2021-01-07', false, 92, 94), + (5038, 3000, '2021-01-08', false, 92, 120), + (5039, 2000, '2021-01-09', false, 92, 76), + (5040, 2000, '2021-01-10', false, 92, 98), + (5041, 2000, '2021-01-11', false, 92, 74), + (5042, 2000, '2021-01-12', true, 92, 101), + (5043, 2000, '2021-01-13', false, 92, 137), + (5044, 3000, '2021-01-14', false, 92, 120), + (5045, 3000, '2021-01-15', false, 92, 96), + (5046, 2000, '2021-01-16', false, 92, 106), + (5047, 2000, '2021-01-17', false, 92, 121), + (5048, 2000, '2021-01-18', false, 92, 100), + (5049, 2000, '2021-01-19', false, 92, 88), + (5050, 2000, '2021-01-20', false, 92, 134), + (5051, 3000, '2021-01-21', false, 92, 135), + (5052, 3000, '2021-01-22', false, 92, 94), + (5053, 2000, '2021-01-23', false, 92, 103), + (5054, 2000, '2021-01-24', false, 92, 123), + (5055, 2000, '2021-01-25', false, 92, 104), + (5056, 2000, '2021-01-26', false, 92, 96), + (5057, 2000, '2021-01-27', false, 92, 79), + (5058, 3000, '2021-01-28', true, 92, 126), + (5059, 3000, '2021-01-29', false, 92, 77), + (5060, 2000, '2021-01-30', false, 92, 102), + (5061, 2000, '2021-01-31', false, 92, 116), + (5062, 3000, '2021-01-01', false, 93, 118), + (5063, 2000, '2021-01-02', false, 93, 122), + (5064, 2000, '2021-01-03', false, 93, 119), + (5065, 2000, '2021-01-04', false, 93, 127), + (5066, 2000, '2021-01-05', false, 93, 95), + (5067, 2000, '2021-01-06', false, 93, 78), + (5068, 3000, '2021-01-07', false, 93, 128), + (5069, 3000, '2021-01-08', true, 93, 82), + (5070, 2000, '2021-01-09', false, 93, 132), + (5071, 2000, '2021-01-10', true, 93, 109), + (5072, 2000, '2021-01-11', false, 93, 140), + (5073, 2000, '2021-01-12', false, 93, 104), + (5074, 2000, '2021-01-13', false, 93, 132), + (5075, 3000, '2021-01-14', false, 93, 75), + (5076, 3000, '2021-01-15', false, 93, 124), + (5077, 2000, '2021-01-16', false, 93, 134), + (5078, 2000, '2021-01-17', true, 93, 73), + (5079, 2000, '2021-01-18', false, 93, 77), + (5080, 2000, '2021-01-19', false, 93, 102), + (5081, 2000, '2021-01-20', false, 93, 88), + (5082, 3000, '2021-01-21', false, 93, 112), + (5083, 3000, '2021-01-22', true, 93, 119), + (5084, 2000, '2021-01-23', false, 93, 91), + (5085, 2000, '2021-01-24', true, 93, 114), + (5086, 2000, '2021-01-25', false, 93, 107), + (5087, 2000, '2021-01-26', false, 93, 89), + (5088, 2000, '2021-01-27', false, 93, 115), + (5089, 3000, '2021-01-28', false, 93, 111), + (5090, 3000, '2021-01-29', false, 93, 116), + (5091, 2000, '2021-01-30', false, 93, 135), + (5092, 2000, '2021-01-31', false, 93, 129), + (5093, 3000, '2021-01-01', false, 94, 79), + (5094, 2000, '2021-01-02', false, 94, 81), + (5095, 2000, '2021-01-03', false, 94, 93), + (5096, 2000, '2021-01-04', false, 94, 102), + (5097, 2000, '2021-01-05', false, 94, 111), + (5098, 2000, '2021-01-06', false, 94, 93), + (5099, 3000, '2021-01-07', false, 94, 72), + (5100, 3000, '2021-01-08', false, 94, 110), + (5101, 2000, '2021-01-09', false, 94, 130), + (5102, 2000, '2021-01-10', true, 94, 89), + (5103, 2000, '2021-01-11', false, 94, 103), + (5104, 2000, '2021-01-12', false, 94, 91), + (5105, 2000, '2021-01-13', false, 94, 95), + (5106, 3000, '2021-01-14', false, 94, 81), + (5107, 3000, '2021-01-15', false, 94, 118), + (5108, 2000, '2021-01-16', false, 94, 118), + (5109, 2000, '2021-01-17', false, 94, 112), + (5110, 2000, '2021-01-18', false, 94, 112), + (5111, 2000, '2021-01-19', false, 94, 101), + (5112, 2000, '2021-01-20', false, 94, 79), + (5113, 3000, '2021-01-21', false, 94, 90), + (5114, 3000, '2021-01-22', false, 94, 108), + (5115, 2000, '2021-01-23', false, 94, 111), + (5116, 2000, '2021-01-24', false, 94, 103), + (5117, 2000, '2021-01-25', false, 94, 76), + (5118, 2000, '2021-01-26', false, 94, 132), + (5119, 2000, '2021-01-27', false, 94, 109), + (5120, 3000, '2021-01-28', true, 94, 133), + (5121, 3000, '2021-01-29', false, 94, 112), + (5122, 2000, '2021-01-30', false, 94, 96), + (5123, 2000, '2021-01-31', false, 94, 93), + (5124, 3000, '2021-01-01', false, 95, 92), + (5125, 2000, '2021-01-02', false, 95, 78), + (5126, 2000, '2021-01-03', false, 95, 96), + (5127, 2000, '2021-01-04', false, 95, 90), + (5128, 2000, '2021-01-05', true, 95, 139), + (5129, 2000, '2021-01-06', false, 95, 84), + (5130, 3000, '2021-01-07', false, 95, 79), + (5131, 3000, '2021-01-08', false, 95, 95), + (5132, 2000, '2021-01-09', false, 95, 106), + (5133, 2000, '2021-01-10', true, 95, 117), + (5134, 2000, '2021-01-11', false, 95, 99), + (5135, 2000, '2021-01-12', false, 95, 126), + (5136, 2000, '2021-01-13', false, 95, 103), + (5137, 3000, '2021-01-14', true, 95, 104), + (5138, 3000, '2021-01-15', false, 95, 74), + (5139, 2000, '2021-01-16', false, 95, 138), + (5140, 2000, '2021-01-17', false, 95, 108), + (5141, 2000, '2021-01-18', false, 95, 108), + (5142, 2000, '2021-01-19', false, 95, 119), + (5143, 2000, '2021-01-20', false, 95, 73), + (5144, 3000, '2021-01-21', false, 95, 121), + (5145, 3000, '2021-01-22', true, 95, 108), + (5146, 2000, '2021-01-23', false, 95, 119), + (5147, 2000, '2021-01-24', false, 95, 118), + (5148, 2000, '2021-01-25', false, 95, 75), + (5149, 2000, '2021-01-26', false, 95, 132), + (5150, 2000, '2021-01-27', true, 95, 83), + (5151, 3000, '2021-01-28', false, 95, 81), + (5152, 3000, '2021-01-29', false, 95, 128), + (5153, 2000, '2021-01-30', false, 95, 76), + (5154, 2000, '2021-01-31', false, 95, 98), + (5155, 3000, '2021-01-01', false, 96, 79), + (5156, 2000, '2021-01-02', false, 96, 79), + (5157, 2000, '2021-01-03', false, 96, 93), + (5158, 2000, '2021-01-04', false, 96, 128), + (5159, 2000, '2021-01-05', false, 96, 111), + (5160, 2000, '2021-01-06', false, 96, 92), + (5161, 3000, '2021-01-07', false, 96, 140), + (5162, 3000, '2021-01-08', false, 96, 87), + (5163, 2000, '2021-01-09', false, 96, 116), + (5164, 2000, '2021-01-10', true, 96, 114), + (5165, 2000, '2021-01-11', false, 96, 81), + (5166, 2000, '2021-01-12', false, 96, 71), + (5167, 2000, '2021-01-13', true, 96, 84), + (5168, 3000, '2021-01-14', false, 96, 101), + (5169, 3000, '2021-01-15', false, 96, 124), + (5170, 2000, '2021-01-16', false, 96, 138), + (5171, 2000, '2021-01-17', true, 96, 82), + (5172, 2000, '2021-01-18', false, 96, 117), + (5173, 2000, '2021-01-19', false, 96, 74), + (5174, 2000, '2021-01-20', false, 96, 138), + (5175, 3000, '2021-01-21', false, 96, 82), + (5176, 3000, '2021-01-22', false, 96, 99), + (5177, 2000, '2021-01-23', false, 96, 133), + (5178, 2000, '2021-01-24', false, 96, 71), + (5179, 2000, '2021-01-25', false, 96, 100), + (5180, 2000, '2021-01-26', true, 96, 127), + (5181, 2000, '2021-01-27', false, 96, 110), + (5182, 3000, '2021-01-28', false, 96, 73), + (5183, 3000, '2021-01-29', false, 96, 109), + (5184, 2000, '2021-01-30', false, 96, 125), + (5185, 2000, '2021-01-31', false, 96, 77), + (5186, 3000, '2021-01-01', false, 97, 136), + (5187, 2000, '2021-01-02', false, 97, 128), + (5188, 2000, '2021-01-03', false, 97, 80), + (5189, 2000, '2021-01-04', false, 97, 118), + (5190, 2000, '2021-01-05', false, 97, 103), + (5191, 2000, '2021-01-06', false, 97, 120), + (5192, 3000, '2021-01-07', false, 97, 119), + (5193, 3000, '2021-01-08', false, 97, 106), + (5194, 2000, '2021-01-09', false, 97, 74), + (5195, 2000, '2021-01-10', false, 97, 98), + (5196, 2000, '2021-01-11', true, 97, 100), + (5197, 2000, '2021-01-12', true, 97, 122), + (5198, 2000, '2021-01-13', false, 97, 89), + (5199, 3000, '2021-01-14', false, 97, 126), + (5200, 3000, '2021-01-15', false, 97, 85), + (5201, 2000, '2021-01-16', false, 97, 123), + (5202, 2000, '2021-01-17', false, 97, 118), + (5203, 2000, '2021-01-18', false, 97, 139), + (5204, 2000, '2021-01-19', false, 97, 76), + (5205, 2000, '2021-01-20', false, 97, 86), + (5206, 3000, '2021-01-21', false, 97, 117), + (5207, 3000, '2021-01-22', false, 97, 129), + (5208, 2000, '2021-01-23', false, 97, 81), + (5209, 2000, '2021-01-24', false, 97, 130), + (5210, 2000, '2021-01-25', false, 97, 81), + (5211, 2000, '2021-01-26', true, 97, 94), + (5212, 2000, '2021-01-27', false, 97, 116), + (5213, 3000, '2021-01-28', false, 97, 114), + (5214, 3000, '2021-01-29', false, 97, 125), + (5215, 2000, '2021-01-30', false, 97, 85), + (5216, 2000, '2021-01-31', false, 97, 110), + (5217, 3000, '2021-01-01', false, 98, 94), + (5218, 2000, '2021-01-02', false, 98, 82), + (5219, 2000, '2021-01-03', false, 98, 84), + (5220, 2000, '2021-01-04', false, 98, 76), + (5221, 2000, '2021-01-05', false, 98, 71), + (5222, 2000, '2021-01-06', false, 98, 83), + (5223, 3000, '2021-01-07', false, 98, 134), + (5224, 3000, '2021-01-08', false, 98, 105), + (5225, 2000, '2021-01-09', false, 98, 76), + (5226, 2000, '2021-01-10', false, 98, 98), + (5227, 2000, '2021-01-11', true, 98, 94), + (5228, 2000, '2021-01-12', false, 98, 137), + (5229, 2000, '2021-01-13', false, 98, 133), + (5230, 3000, '2021-01-14', false, 98, 128), + (5231, 3000, '2021-01-15', false, 98, 138), + (5232, 2000, '2021-01-16', false, 98, 71), + (5233, 2000, '2021-01-17', false, 98, 97), + (5234, 2000, '2021-01-18', false, 98, 137), + (5235, 2000, '2021-01-19', false, 98, 118), + (5236, 2000, '2021-01-20', false, 98, 132), + (5237, 3000, '2021-01-21', false, 98, 95), + (5238, 3000, '2021-01-22', false, 98, 137), + (5239, 2000, '2021-01-23', false, 98, 104), + (5240, 2000, '2021-01-24', false, 98, 137), + (5241, 2000, '2021-01-25', false, 98, 125), + (5242, 2000, '2021-01-26', false, 98, 112), + (5243, 2000, '2021-01-27', false, 98, 101), + (5244, 3000, '2021-01-28', false, 98, 77), + (5245, 3000, '2021-01-29', true, 98, 74), + (5246, 2000, '2021-01-30', false, 98, 82), + (5247, 2000, '2021-01-31', false, 98, 96), + (5248, 3000, '2021-01-01', false, 99, 83), + (5249, 2000, '2021-01-02', false, 99, 124), + (5250, 2000, '2021-01-03', false, 99, 87), + (5251, 2000, '2021-01-04', false, 99, 93), + (5252, 2000, '2021-01-05', false, 99, 77), + (5253, 2000, '2021-01-06', false, 99, 96), + (5254, 3000, '2021-01-07', true, 99, 138), + (5255, 3000, '2021-01-08', false, 99, 121), + (5256, 2000, '2021-01-09', true, 99, 74), + (5257, 2000, '2021-01-10', false, 99, 83), + (5258, 2000, '2021-01-11', false, 99, 103), + (5259, 2000, '2021-01-12', false, 99, 124), + (5260, 2000, '2021-01-13', false, 99, 117), + (5261, 3000, '2021-01-14', false, 99, 74), + (5262, 3000, '2021-01-15', false, 99, 88), + (5263, 2000, '2021-01-16', false, 99, 98), + (5264, 2000, '2021-01-17', false, 99, 99), + (5265, 2000, '2021-01-18', false, 99, 83), + (5266, 2000, '2021-01-19', false, 99, 114), + (5267, 2000, '2021-01-20', false, 99, 115), + (5268, 3000, '2021-01-21', false, 99, 109), + (5269, 3000, '2021-01-22', false, 99, 80), + (5270, 2000, '2021-01-23', false, 99, 129), + (5271, 2000, '2021-01-24', false, 99, 137), + (5272, 2000, '2021-01-25', false, 99, 114), + (5273, 2000, '2021-01-26', false, 99, 71), + (5274, 2000, '2021-01-27', false, 99, 129), + (5275, 3000, '2021-01-28', true, 99, 121), + (5276, 3000, '2021-01-29', false, 99, 97), + (5277, 2000, '2021-01-30', false, 99, 115), + (5278, 2000, '2021-01-31', false, 99, 120), + (5279, 3000, '2021-01-01', false, 100, 71), + (5280, 2000, '2021-01-02', true, 100, 127), + (5281, 2000, '2021-01-03', false, 100, 100), + (5282, 2000, '2021-01-04', false, 100, 115), + (5283, 2000, '2021-01-05', false, 100, 100), + (5284, 2000, '2021-01-06', false, 100, 89), + (5285, 3000, '2021-01-07', false, 100, 78), + (5286, 3000, '2021-01-08', false, 100, 81), + (5287, 2000, '2021-01-09', true, 100, 131), + (5288, 2000, '2021-01-10', true, 100, 115), + (5289, 2000, '2021-01-11', false, 100, 126), + (5290, 2000, '2021-01-12', false, 100, 118), + (5291, 2000, '2021-01-13', false, 100, 76), + (5292, 3000, '2021-01-14', false, 100, 75), + (5293, 3000, '2021-01-15', false, 100, 138), + (5294, 2000, '2021-01-16', false, 100, 126), + (5295, 2000, '2021-01-17', false, 100, 138), + (5296, 2000, '2021-01-18', false, 100, 132), + (5297, 2000, '2021-01-19', false, 100, 99), + (5298, 2000, '2021-01-20', false, 100, 100), + (5299, 3000, '2021-01-21', true, 100, 133), + (5300, 3000, '2021-01-22', false, 100, 129), + (5301, 2000, '2021-01-23', false, 100, 75), + (5302, 2000, '2021-01-24', false, 100, 78), + (5303, 2000, '2021-01-25', false, 100, 129), + (5304, 2000, '2021-01-26', false, 100, 135), + (5305, 2000, '2021-01-27', false, 100, 134), + (5306, 3000, '2021-01-28', false, 100, 94), + (5307, 3000, '2021-01-29', false, 100, 138), + (5308, 2000, '2021-01-30', false, 100, 126), + (5309, 2000, '2021-01-31', false, 100, 77); + + diff --git a/Suli/13.b/Adatbázis/20240904/feladat.PNG b/Suli/13.b/Adatbázis/20240904/feladat.PNG new file mode 100644 index 0000000..b6d3ea8 Binary files /dev/null and b/Suli/13.b/Adatbázis/20240904/feladat.PNG differ diff --git a/Suli/13.b/Adatbázis/20240904/megoldas.txt b/Suli/13.b/Adatbázis/20240904/megoldas.txt new file mode 100644 index 0000000..47b5b03 --- /dev/null +++ b/Suli/13.b/Adatbázis/20240904/megoldas.txt @@ -0,0 +1,12 @@ +13.: CREATE DATABASE parkolohely CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + +15.: SELECT COUNT(szelesseg) as `masfeles_parkolohelyek_szama` FROM `parkolohely` WHERE szelesseg=1.5; + +16.: INSERT INTO jarmutipus VALUES(4, "Elektromos gépjármű"); +UPDATE parkolohely SET jarmutipusId = 4 WHERE felirat = "P001"; + +17.: SELECT foglalas.datum, foglalas.ar FROM `foglalas` INNER JOIN felhasznalo ON felhasznalo.id = foglalas.felhasznaloId WHERE felhasznalo.nev="Kovács Anna"; + +18.: SELECT felhasznalo.nev, SUM(foglalas.ar) AS `szumma_tartozas` FROM foglalas INNER JOIN felhasznalo ON felhasznalo.id = foglalas.felhasznaloId WHERE foglalas.fizetve = 0; + +19.: SELECT felhasznalo.nev, SUM(foglalas.ar) AS `szumma_tartozas` FROM foglalas INNER JOIN felhasznalo ON felhasznalo.id = foglalas.felhasznaloId INNER JOIN parkolohely ON parkolohely.id = foglalas.parkolohelyId INNER JOIN jarmutipus on jarmutipus.id = parkolohely.jarmutipusId WHERE foglalas.fizetve = 0 AND jarmutipus.nev = "Motorkerékpár" GROUP BY felhasznalo.nev ORDER BY `szumma_tartozas` DESC LIMIT 1; diff --git a/Suli/13.b/Adatbázis/20240911/E-R diagram feladat.docx b/Suli/13.b/Adatbázis/20240911/E-R diagram feladat.docx new file mode 100644 index 0000000..e151358 Binary files /dev/null and b/Suli/13.b/Adatbázis/20240911/E-R diagram feladat.docx differ diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/adatbazis.sql b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/adatbazis.sql new file mode 100644 index 0000000..1648bb7 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/adatbazis.sql @@ -0,0 +1,87 @@ +-- Táblák létrehozása + +-- Rendezvénytípusok +CREATE TABLE tipus +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + primary key (id) +); + +CREATE TABLE helyszin +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + primary key (id) +); + +CREATE TABLE kapcsolat +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + telefon varchar(30) NOT NULL, + email varchar(50) NOT NULL, + cegnev varchar(50), + primary key (id) +); + +CREATE TABLE rendezveny +( + id int NOT NULL AUTO_INCREMENT, + kapcsolatId int NOT NULL, + idopont date NOT NULL, + napokszama int NOT NULL, + helyszinId int NOT NULL, + letszam int NOT NULL, + tipusId int NOT NULL, + primary key (id), + key kapcsolatId (kapcsolatId), + CONSTRAINT FK_kapcsolat_kapcsolatId FOREIGN KEY (kapcsolatId) REFERENCES kapcsolat (id), + key helyszinId (helyszinId), + CONSTRAINT FK_helyszin_helyszinId FOREIGN KEY (helyszinId) REFERENCES helyszin (id), + key tipusId (tipusId), + CONSTRAINT FK_tipus_tipusId FOREIGN KEY (tipusId) REFERENCES tipus (id) +); + +-- Adatok beszúrása +INSERT INTO tipus (id, nev) +VALUES (1, 'szabadtéri'), + (2, 'beltéri'), + (3, 'online'), + (4, 'tréning'), + (5, 'céges rendezvény'); + +INSERT INTO helyszin (id, nev) +VALUES (1, 'Megrendelő telephelye'), + (2, 'Budapest'), + (3, 'Szeged'), + (4, 'Debrecen'), + (5, 'Pécs'), + (6, 'Balaton'), + (7, 'Velencei tó'), + (8, 'Egyéb'); + +INSERT INTO kapcsolat (id, nev, telefon, email, cegnev) +VALUES (1, 'Kiss Piroska', '+3620123456', 'kiss.piroska@paprika.hu', 'Paprika Paradicsom'), + (2, 'Nagy Béla', '+3670523456', 'nagy.bela@bugfix.hu', NULL), + (3, 'Vass Alajos', '+36309998877', 'vass.alajos@vaskalapos.hu', 'Vaskalapos Hulladékhasznosító'), + (4, 'Nagy Lilla', '+36308768768', 'nagy.lilla@szoke-ciklon.hu', 'Szőke Ciklon Illatszergyár'), + (5, 'Major Anna', '+36201347761', 'major.anna@organic.hu', 'Organic Gyógyszergyár'), + (6, 'Balogh Béla', '+36304673753', 'balogh.bela@nadpalca.hu', 'Nádpálca Oktatástechnikai Kereskelem'), + (7, 'Szabó Krisztina', '+36205049928', 'szabo.krisztina@kaqkk.hu', 'Kaqkk Kft.'), + (8, 'Hanta Balázs', '+36705463728', 'hanta.balazs@hanta.hu', 'Hanta Pályázatíró Kft.'), + (9, 'Mekk Elek', '+36305161721', 'mekk.elek@talan-holnap.hu', 'Talán Holnap Karbantartás'); + +INSERT INTO rendezveny (id, kapcsolatId, idopont, napokszama, helyszinId, letszam, tipusID) +VALUES (1, 5, '2023-12-01', 3, 3, 100, 4), + (2, 3, '2023-12-01', 1, 1, 120, 5), + (3, 1, '2023-12-06', 1, 1, 40, 5), + (4, 7, '2023-12-07', 3, 3, 20, 4), + (5, 4, '2023-12-08', 1, 2, 70, 2), + (6, 6, '2023-12-09', 1, 1, 30, 3), + (7, 8, '2023-12-11', 3, 4, 10, 4), + (8, 9, '2023-12-12', 1, 1, 30, 2), + (9, 2, '2023-12-13', 5, 5, 30, 4), + (10, 5, '2023-12-14', 1, 2, 230, 5), + (11, 7, '2023-12-15', 1, 1, 65, 5), + (12, 8, '2023-12-15', 1, 2, 40, 5); \ No newline at end of file diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/feladatleírás.pdf b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/feladatleírás.pdf new file mode 100644 index 0000000..35d5510 Binary files /dev/null and b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/feladatleírás.pdf differ diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/megoldasok_1.txt b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/megoldasok_1.txt new file mode 100644 index 0000000..d06b162 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/1.feladat/megoldasok_1.txt @@ -0,0 +1,27 @@ +-- 12. feladat: +CREATE DATABASE mozaik CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + + +-- 14. feladat: +SELECT COUNT(rendezveny.id) AS `nagyrendezvények száma` FROM `rendezveny` WHERE rendezveny.letszam >= 100; + + +-- 15. feladat: +SELECT helyszin.nev, rendezveny.idopont, rendezveny.napokszama, rendezveny.letszam FROM `rendezveny` INNER JOIN helyszin ON rendezveny.helyszinId = helyszin.id WHERE helyszin.nev = "Szeged"; + + +-- 16. feladat: +UPDATE `kapcsolat` SET `cegnev`= "BugFix IT" WHERE kapcsolat.nev = "Nagy Béla"; + + +-- 17. feladat: +SELECT tipus.nev AS `típus`, AVG(rendezveny.letszam) AS `átlaglétszám` FROM `rendezveny` INNER JOIN tipus ON rendezveny.tipusId = tipus.id GROUP BY tipus.nev ORDER BY `átlaglétszám` DESC LIMIT 2; + + +-- 18. feladat: +SELECT helyszin.nev FROM `helyszin` LEFT JOIN rendezveny ON helyszin.id = rendezveny.helyszinId WHERE rendezveny.helyszinId IS NULL; + + +-- 19. feladat: +SELECT kapcsolat.nev, kapcsolat.email, (rendezveny.napokszama * 20000) + (rendezveny.letszam * 1000) AS `szervezési díj` FROM `rendezveny` INNER JOIN kapcsolat ON rendezveny.kapcsolatId = kapcsolat.id INNER JOIN tipus ON rendezveny.tipusId = tipus.id WHERE tipus.nev = "tréning"; + diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/adatbazis.sql b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/adatbazis.sql new file mode 100644 index 0000000..5cc2001 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/adatbazis.sql @@ -0,0 +1,2728 @@ +-- Táblák létrehozása + +-- Rendelő felhasználók +CREATE TABLE felhasznalo +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + primary key (id) +); + +-- Ételkategóriák +CREATE TABLE etelkategoria +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + primary key (id) +); + +-- Menütételek +CREATE TABLE menutetel +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + ar int NOT NULL, + etelkatId int NOT NULL, + primary key (id), + key etelkatId (etelkatId), + CONSTRAINT FK_menu_etelkatId FOREIGN KEY (etelkatId) REFERENCES etelkategoria (id) +); + +-- Rendelések +CREATE TABLE rendeles +( + id int NOT NULL AUTO_INCREMENT, + felhasznaloId int NOT NULL, + idopont time NOT NULL, + primary key (id), + key felhasznaloId (felhasznaloId), + CONSTRAINT FK_rendeles_felhasznaloId FOREIGN KEY (felhasznaloId) REFERENCES felhasznalo (id) +); + +-- Rendeléselemek +CREATE TABLE rendeleselem +( + id int NOT NULL AUTO_INCREMENT, + mennyiseg int NOT NULL, + menutetelId int NOT NULL, + rendelesId int NOT NULL, + primary key (id), + key menutetelId (menutetelId), + CONSTRAINT FK_rendeleselem_menutetelId FOREIGN KEY (menutetelId) REFERENCES menutetel (id), + key rendelesId (rendelesId), + CONSTRAINT FK_rendeleselem_rendeles FOREIGN KEY (rendelesId) REFERENCES rendeles (id) +); + +-- Adatok beszúrása +INSERT INTO felhasznalo (id, nev) +VALUES (1, 'Nagy Bence'), + (2, 'Kovács Máté'), + (3, 'Tóth Levente'), + (4, 'Szabó Dominik'), + (5, 'Horváth Marcell'), + (6, 'Varga Noel'), + (7, 'Kiss Ádám'), + (8, 'Molnár Dániel'), + (9, 'Németh Dávid'), + (10, 'Farkas Olivér'), + (11, 'Balogh Milán'), + (12, 'Papp Zalán'), + (13, 'Lakatos Botond'), + (14, 'Takács Benett'), + (15, 'Juhász Zsombor'), + (16, 'Mészáros Balázs'), + (17, 'Oláh Áron'), + (18, 'Simon Péter'), + (19, 'Rácz Kristóf'), + (20, 'Fekete Tamás'), + (21, 'Szilágyi Márk'), + (22, 'Török Benedek'), + (23, 'Fehér Gergő'), + (24, 'Balázs László'), + (25, 'Gál Nimród'), + (26, 'Kis Bálint'), + (27, 'Szűcs Zétény'), + (28, 'Kocsis Ákos'), + (29, 'Orsós Patrik'), + (30, 'Pintér Zoltán'), + (31, 'Fodor András'), + (32, 'Szalai Attila'), + (33, 'Sipos Hunor'), + (34, 'Magyar Barnabás'), + (35, 'Lukács Márton'), + (36, 'Gulyás Gábor'), + (37, 'Biró Alex'), + (38, 'Király Martin'), + (39, 'László István'), + (40, 'Balog Kornél'), + (41, 'Katona Vince'), + (42, 'Bogdán József'), + (43, 'Jakab János'), + (44, 'Sándor Krisztián'), + (45, 'Boros Zsolt'), + (46, 'Váradi Zente'), + (47, 'Fazekas Sándor'), + (48, 'Kelemen Erik'), + (49, 'Antal Bendegúz'), + (50, 'Orosz Roland'), + (51, 'Somogyi Richárd'), + (52, 'Fülöp Ábel'), + (53, 'Veres Csaba'), + (54, 'Vincze Róbert'), + (55, 'Budai Kevin'), + (56, 'Hegedűs Nolen'), + (57, 'Deák Soma'), + (58, 'Pap Ármin'), + (59, 'Bálint Mihály'), + (60, 'Illés Vencel'), + (61, 'Pál Norbert'), + (62, 'Vass Mátyás'), + (63, 'Szőke Ferenc'), + (64, 'Fábián Tibor'), + (65, 'Vörös Nándor'), + (66, 'Lengyel Benjámin'), + (67, 'Bognár Szabolcs'), + (68, 'Bodnár Benjamin'), + (69, 'Jónás Simon'), + (70, 'Szücs Gergely'), + (71, 'Hajdu Csongor'), + (72, 'Halász Viktor'), + (73, 'Máté Miklós'), + (74, 'Székely Nikolasz'), + (75, 'Kozma Vilmos'), + (76, 'Gáspár Boldizsár'), + (77, 'Pásztor Kende'), + (78, 'Bakos Imre'), + (79, 'Dudás Bertalan'), + (80, 'Major Brendon'), + (81, 'Orbán Zénó'), + (82, 'Virág Adrián'), + (83, 'Hegedüs Dorián'), + (84, 'Barna Krisztofer'), + (85, 'Novák György'), + (86, 'Soós Alexander'), + (87, 'Tamás Lajos'), + (88, 'Nemes Dénes'), + (89, 'Pataki Félix'), + (90, 'Balla Sámuel'), + (91, 'Faragó Denisz'), + (92, 'Kerekes Bende'), + (93, 'Borbély Noé'), + (94, 'Barta Károly'), + (95, 'Péter Donát'), + (96, 'Csonka Gyula'), + (97, 'Mezei Gellért'), + (98, 'Sárközi Mirkó'), + (99, 'Szekeres Vendel'), + (100, 'Márton Brájen'), + (101, 'Nagy Hanna'), + (102, 'Kovács Anna'), + (103, 'Tóth Zoé'), + (104, 'Szabó Luca'), + (105, 'Horváth Léna'), + (106, 'Varga Emma'), + (107, 'Kiss Zsófia'), + (108, 'Molnár Lili'), + (109, 'Németh Boglárka'), + (110, 'Farkas Mira'), + (111, 'Balogh Lilien'), + (112, 'Papp Nóra'), + (113, 'Lakatos Jázmin'), + (114, 'Takács Laura'), + (115, 'Juhász Maja'), + (116, 'Mészáros Sára'), + (117, 'Oláh Lara'), + (118, 'Simon Lilla'), + (119, 'Rácz Izabella'), + (120, 'Fekete Gréta'), + (121, 'Szilágyi Alíz'), + (122, 'Török Fanni'), + (123, 'Fehér Adél'), + (124, 'Balázs Flóra'), + (125, 'Gál Csenge'); + +INSERT INTO etelkategoria(id, nev) +VALUES (1, 'hamburger'), + (2, 'pizza'), + (3, 'teszta'), + (4, 'koret'), + (5, 'szosz'), + (6, 'udito'), + (7, 'desszert'); + +INSERT INTO menutetel(id, nev, ar, etelkatId) +VALUES (1, 'Boston burger', 2500, 1), + (2, 'Csibe burger', 2200, 1), + (3, 'Impossible burger', 3200, 1), + (4, 'Camambert burger', 2500, 1), + (5, 'Dupla burger', 3100, 1), + (6, 'Halas burger', 2500, 1), + (7, 'Boston pizza 32cm', 2200, 2), + (8, 'Boston pizza 45cm', 4500, 2), + (9, 'Húsimádó pizza 32cm', 2500, 2), + (10, 'Húsimádó pizza 45cm', 5000, 2), + (11, 'Vega pizza 32cm', 2100, 2), + (12, 'Vega pizza 45cm', 4200, 2), + (13, 'SonGoKu 32cm', 2200, 2), + (14, 'SonGoKu 45cm', 4400, 2), + (15, 'Grill pizza 32cm', 23000, 2), + (16, 'Grill pizza 45cm', 2700, 2), + (17, 'Brooklyn Tészta', 2000, 3), + (18, 'Bolognese Tészta', 1800, 3), + (19, 'Con Salmone', 2200, 3), + (20, 'Al Pollo', 2600, 3), + (21, 'Alla chef', 2990, 3), + (22, 'Pesto tészta', 2490, 3), + (23, 'Csirke Pesto', 2690, 3), + (24, 'Pomodoro', 1890, 3), + (25, 'Quattro formaggi gnocchi', 2490, 3), + (26, 'Lasagne', 2690, 3), + (27, 'Tortellini', 2890, 3), + (28, 'Sültkrumpli', 1100, 4), + (29, 'Rizs', 890, 4), + (30, 'Rizibizi', 990, 4), + (31, 'Kukoricasaláta', 1590, 4), + (32, 'Tésztasaláta', 1590, 4), + (33, 'Coleslaw', 1490, 4), + (34, 'Fokahgymás', 450, 5), + (35, 'Kapros', 450, 5), + (36, 'Majonéz', 350, 5), + (37, 'Mustár', 250, 5), + (38, 'Ketchup', 250, 5), + (39, 'Tartár', 350, 5), + (40, 'Édes BBQ', 400, 5), + (41, 'Csípős BBQ', 450, 5), + (42, 'Extra füstös BBQ', 420, 5), + (43, 'Mézes mustár', 400, 5), + (44, 'Coca cola', 450, 6), + (45, 'Pepsi', 450, 6), + (46, 'Fanta', 450, 6), + (47, 'Sprite', 470, 6), + (48, 'Coca cola light', 450, 6), + (49, 'Pepsi zero', 450, 6), + (50, 'Sprite zero', 470, 6), + (51, 'Monsta Energy', 550, 6), + (52, 'Naturaqua', 250, 6), + (53, 'Somlói', 800, 7), + (54, 'Palacsinta mix', 990, 7), + (55, 'Tiramisu', 890, 7); + +insert into rendeles(felhasznaloId, idopont) +VALUES (34, '08:01'), + (39, '08:01'), + (119, '08:01'), + (21, '08:03'), + (105, '08:05'), + (99, '08:10'), + (20, '08:16'), + (104, '08:16'), + (9, '08:17'), + (52, '08:17'), + (73, '08:18'), + (42, '08:26'), + (49, '08:26'), + (71, '08:28'), + (104, '08:30'), + (123, '08:33'), + (61, '08:35'), + (74, '08:35'), + (36, '08:38'), + (79, '08:40'), + (45, '08:40'), + (83, '08:40'), + (88, '08:41'), + (101, '08:41'), + (118, '08:42'), + (74, '08:42'), + (93, '08:42'), + (41, '08:44'), + (124, '08:45'), + (21, '08:45'), + (121, '08:46'), + (116, '08:46'), + (111, '08:48'), + (35, '08:51'), + (43, '08:51'), + (39, '08:53'), + (75, '08:53'), + (123, '08:55'), + (99, '08:56'), + (47, '08:56'), + (86, '08:56'), + (122, '08:57'), + (35, '08:57'), + (12, '08:58'), + (72, '09:01'), + (117, '09:02'), + (110, '09:02'), + (97, '09:06'), + (10, '09:07'), + (106, '09:13'), + (100, '09:14'), + (7, '09:16'), + (26, '09:18'), + (121, '09:19'), + (117, '09:19'), + (2, '09:20'), + (104, '09:22'), + (77, '09:23'), + (95, '09:25'), + (119, '09:32'), + (79, '09:32'), + (19, '09:35'), + (67, '09:39'), + (72, '09:41'), + (86, '09:42'), + (14, '09:46'), + (59, '09:47'), + (20, '09:47'), + (49, '09:48'), + (89, '09:48'), + (19, '09:50'), + (53, '09:52'), + (118, '09:53'), + (89, '09:53'), + (111, '09:53'), + (24, '09:54'), + (30, '09:58'), + (82, '10:03'), + (2, '10:04'), + (49, '10:08'), + (64, '10:15'), + (104, '10:19'), + (93, '10:22'), + (13, '10:22'), + (81, '10:23'), + (36, '10:24'), + (124, '10:25'), + (92, '10:25'), + (56, '10:27'), + (26, '10:28'), + (62, '10:28'), + (28, '10:32'), + (87, '10:37'), + (81, '10:37'), + (37, '10:39'), + (22, '10:41'), + (30, '10:44'), + (60, '10:44'), + (102, '10:45'), + (32, '10:46'), + (86, '10:48'), + (45, '10:48'), + (1, '10:49'), + (41, '10:50'), + (63, '10:51'), + (93, '10:52'), + (95, '10:53'), + (19, '10:53'), + (82, '10:55'), + (31, '10:55'), + (102, '10:56'), + (1, '10:57'), + (61, '10:58'), + (79, '10:59'), + (9, '10:59'), + (98, '11:01'), + (119, '11:04'), + (38, '11:04'), + (106, '11:05'), + (37, '11:07'), + (15, '11:12'), + (41, '11:14'), + (24, '11:14'), + (88, '11:14'), + (32, '11:18'), + (49, '11:18'), + (104, '11:20'), + (75, '11:20'), + (112, '11:20'), + (56, '11:27'), + (36, '11:28'), + (27, '11:29'), + (68, '11:30'), + (72, '11:31'), + (121, '11:34'), + (104, '11:35'), + (105, '11:38'), + (51, '11:42'), + (89, '11:43'), + (22, '11:43'), + (101, '11:43'), + (11, '11:44'), + (62, '11:44'), + (80, '11:45'), + (59, '11:51'), + (98, '11:51'), + (15, '11:54'), + (84, '11:54'), + (58, '11:55'), + (1, '11:55'), + (87, '11:58'), + (96, '11:58'), + (74, '11:59'), + (65, '12:02'), + (86, '12:02'), + (17, '12:02'), + (88, '12:03'), + (69, '12:04'), + (34, '12:05'), + (2, '12:05'), + (29, '12:05'), + (72, '12:06'), + (40, '12:07'), + (26, '12:07'), + (59, '12:08'), + (6, '12:09'), + (92, '12:11'), + (120, '12:11'), + (89, '12:14'), + (8, '12:14'), + (61, '12:15'), + (32, '12:16'), + (2, '12:16'), + (49, '12:17'), + (22, '12:17'), + (102, '12:18'), + (13, '12:19'), + (63, '12:21'), + (119, '12:21'), + (25, '12:23'), + (92, '12:24'), + (120, '12:25'), + (35, '12:26'), + (65, '12:27'), + (16, '12:28'), + (73, '12:29'), + (78, '12:29'), + (30, '12:30'), + (47, '12:31'), + (67, '12:31'), + (6, '12:32'), + (94, '12:33'), + (121, '12:34'), + (45, '12:36'), + (17, '12:37'), + (96, '12:40'), + (97, '12:41'), + (25, '12:41'), + (54, '12:41'), + (110, '12:42'), + (36, '12:42'), + (52, '12:42'), + (36, '12:43'), + (112, '12:44'), + (107, '12:44'), + (110, '12:45'), + (2, '12:45'), + (22, '12:49'), + (58, '12:50'), + (34, '12:50'), + (26, '12:51'), + (49, '12:51'), + (61, '12:52'), + (53, '12:53'), + (6, '12:54'), + (85, '12:54'), + (31, '12:55'), + (118, '12:55'), + (18, '12:57'), + (68, '12:57'), + (106, '12:57'), + (6, '12:58'), + (8, '12:58'), + (67, '12:58'), + (56, '12:58'), + (24, '13:01'), + (84, '13:03'), + (70, '13:04'), + (76, '13:08'), + (10, '13:09'), + (117, '13:10'), + (6, '13:10'), + (44, '13:17'), + (67, '13:18'), + (116, '13:19'), + (37, '13:19'), + (58, '13:21'), + (51, '13:23'), + (21, '13:23'), + (35, '13:24'), + (68, '13:26'), + (66, '13:28'), + (86, '13:30'), + (85, '13:30'), + (1, '13:31'), + (82, '13:33'), + (89, '13:34'), + (5, '13:35'), + (74, '13:39'), + (2, '13:40'), + (1, '13:43'), + (45, '13:44'), + (15, '13:45'), + (82, '13:46'), + (7, '13:46'), + (82, '13:46'), + (55, '13:46'), + (75, '13:49'), + (51, '13:49'), + (92, '13:50'), + (42, '13:50'), + (81, '13:52'), + (109, '13:52'), + (117, '13:52'), + (13, '13:55'), + (120, '13:57'), + (79, '13:57'), + (70, '13:59'), + (97, '14:01'), + (61, '14:02'), + (94, '14:03'), + (63, '14:04'), + (86, '14:07'), + (17, '14:09'), + (105, '14:11'), + (122, '14:12'), + (44, '14:13'), + (63, '14:13'), + (75, '14:14'), + (90, '14:16'), + (23, '14:17'), + (72, '14:19'), + (39, '14:19'), + (27, '14:20'), + (37, '14:24'), + (28, '14:24'), + (81, '14:30'), + (53, '14:32'), + (39, '14:32'), + (84, '14:33'), + (59, '14:34'), + (90, '14:36'), + (104, '14:39'), + (98, '14:40'), + (32, '14:40'), + (105, '14:40'), + (44, '14:43'), + (55, '14:45'), + (91, '14:45'), + (76, '14:45'), + (102, '14:47'), + (82, '14:48'), + (117, '14:52'), + (45, '14:56'), + (43, '14:59'), + (64, '15:01'), + (96, '15:02'), + (82, '15:03'), + (76, '15:04'), + (104, '15:09'), + (58, '15:11'), + (125, '15:11'), + (54, '15:12'), + (32, '15:16'), + (49, '15:17'), + (60, '15:18'), + (103, '15:22'), + (82, '15:22'), + (11, '15:23'), + (54, '15:23'), + (48, '15:24'), + (17, '15:26'), + (88, '15:26'), + (19, '15:29'), + (118, '15:30'), + (18, '15:31'), + (14, '15:31'), + (60, '15:32'), + (49, '15:32'), + (114, '15:37'), + (72, '15:39'), + (35, '15:39'), + (25, '15:40'), + (45, '15:40'), + (64, '15:40'), + (31, '15:41'), + (41, '15:41'), + (101, '15:43'), + (15, '15:43'), + (66, '15:47'), + (107, '15:48'), + (13, '15:52'), + (93, '15:52'), + (21, '15:52'), + (44, '15:54'), + (15, '15:54'), + (46, '15:58'), + (103, '15:59'), + (43, '16:01'), + (88, '16:02'), + (81, '16:05'), + (97, '16:06'), + (68, '16:07'), + (28, '16:09'), + (48, '16:10'), + (66, '16:18'), + (40, '16:19'), + (59, '16:19'), + (6, '16:22'), + (17, '16:22'), + (45, '16:22'), + (119, '16:24'), + (15, '16:26'), + (25, '16:28'), + (110, '16:28'), + (61, '16:32'), + (24, '16:36'), + (121, '16:38'), + (116, '16:40'), + (104, '16:40'), + (44, '16:42'), + (53, '16:44'), + (82, '16:44'), + (109, '16:44'), + (33, '16:45'), + (37, '16:47'), + (8, '16:48'), + (20, '16:51'), + (63, '16:51'), + (50, '16:55'), + (51, '16:55'), + (117, '16:57'), + (15, '16:59'), + (119, '16:59'), + (114, '17:01'), + (102, '17:01'), + (7, '17:02'), + (50, '17:04'), + (21, '17:08'), + (93, '17:10'), + (56, '17:11'), + (33, '17:11'), + (5, '17:12'), + (53, '17:13'), + (95, '17:13'), + (124, '17:14'), + (20, '17:16'), + (94, '17:18'), + (6, '17:19'), + (26, '17:20'), + (78, '17:22'), + (114, '17:22'), + (63, '17:24'), + (3, '17:24'), + (95, '17:25'), + (9, '17:25'), + (76, '17:30'), + (67, '17:31'), + (69, '17:31'), + (15, '17:32'), + (75, '17:32'), + (113, '17:39'), + (42, '17:40'), + (31, '17:42'), + (123, '17:43'), + (88, '17:43'), + (54, '17:45'), + (65, '17:50'), + (45, '17:53'), + (106, '17:54'), + (106, '17:54'), + (11, '17:55'), + (83, '17:56'), + (110, '17:57'), + (105, '18:01'), + (76, '18:04'), + (35, '18:04'), + (26, '18:05'), + (18, '18:08'), + (2, '18:09'), + (34, '18:14'), + (49, '18:16'), + (115, '18:18'), + (21, '18:21'), + (24, '18:22'), + (105, '18:23'), + (62, '18:25'), + (45, '18:26'), + (64, '18:28'), + (56, '18:28'), + (117, '18:30'), + (122, '18:30'), + (122, '18:32'), + (4, '18:32'), + (86, '18:35'), + (6, '18:35'), + (36, '18:35'), + (101, '18:36'), + (80, '18:37'), + (46, '18:38'), + (99, '18:41'), + (124, '18:45'), + (14, '18:47'), + (119, '18:49'), + (41, '18:49'), + (34, '18:53'), + (124, '18:54'), + (9, '18:57'), + (17, '19:03'), + (84, '19:04'), + (96, '19:06'), + (1, '19:06'), + (106, '19:08'), + (123, '19:09'), + (47, '19:09'), + (86, '19:10'), + (112, '19:14'), + (82, '19:15'), + (118, '19:16'), + (12, '19:16'), + (90, '19:17'), + (92, '19:17'), + (58, '19:20'), + (30, '19:21'), + (12, '19:21'), + (18, '19:22'), + (93, '19:22'), + (120, '19:26'), + (6, '19:29'), + (34, '19:30'), + (94, '19:30'), + (4, '19:33'), + (114, '19:34'), + (78, '19:37'), + (64, '19:37'), + (116, '19:40'), + (25, '19:40'), + (108, '19:42'), + (52, '19:43'), + (107, '19:49'), + (73, '19:50'), + (57, '19:50'), + (123, '19:52'), + (28, '19:52'), + (63, '19:53'), + (105, '19:54'), + (92, '19:55'), + (66, '19:56'), + (2, '19:57'), + (119, '19:58'); + +insert into rendeleselem(rendelesId, menutetelId, mennyiseg) +VALUES (1, 52, 1), + (1, 28, 2), + (1, 25, 2), + (2, 37, 1), + (2, 21, 2), + (2, 3, 1), + (2, 19, 2), + (2, 7, 2), + (3, 25, 1), + (3, 20, 2), + (4, 16, 2), + (4, 22, 1), + (4, 30, 1), + (5, 47, 1), + (5, 29, 2), + (5, 16, 2), + (5, 3, 1), + (6, 44, 2), + (6, 18, 1), + (6, 33, 1), + (7, 23, 1), + (7, 29, 2), + (7, 45, 1), + (8, 5, 1), + (8, 3, 2), + (8, 15, 1), + (8, 28, 1), + (8, 5, 1), + (8, 46, 1), + (9, 37, 2), + (9, 8, 1), + (9, 17, 2), + (9, 35, 2), + (10, 39, 2), + (10, 46, 1), + (10, 52, 1), + (10, 20, 2), + (10, 11, 1), + (10, 19, 1), + (11, 48, 2), + (11, 17, 1), + (11, 40, 1), + (11, 7, 1), + (11, 46, 1), + (12, 51, 2), + (12, 14, 1), + (12, 22, 1), + (13, 8, 1), + (13, 5, 1), + (13, 3, 1), + (13, 21, 1), + (14, 11, 1), + (14, 40, 1), + (14, 9, 1), + (14, 6, 1), + (15, 28, 2), + (15, 33, 1), + (15, 18, 1), + (15, 22, 2), + (16, 42, 1), + (16, 26, 2), + (16, 37, 2), + (16, 18, 1), + (16, 12, 1), + (17, 4, 1), + (17, 51, 1), + (17, 30, 2), + (18, 9, 1), + (18, 47, 2), + (18, 33, 1), + (18, 51, 3), + (19, 36, 2), + (19, 2, 2), + (19, 45, 2), + (19, 52, 1), + (19, 2, 1), + (20, 27, 1), + (20, 33, 2), + (20, 28, 2), + (20, 29, 1), + (21, 46, 1), + (21, 39, 1), + (21, 16, 1), + (21, 44, 2), + (22, 32, 1), + (22, 32, 1), + (22, 27, 1), + (22, 4, 2), + (23, 46, 1), + (23, 1, 1), + (23, 18, 1), + (23, 11, 1), + (23, 19, 1), + (24, 12, 1), + (24, 48, 2), + (24, 13, 1), + (24, 10, 1), + (25, 52, 3), + (25, 12, 1), + (25, 40, 2), + (25, 12, 1), + (25, 13, 1), + (26, 9, 1), + (26, 27, 1), + (26, 33, 1), + (26, 33, 1), + (26, 36, 1), + (27, 7, 1), + (27, 24, 1), + (27, 27, 2), + (28, 17, 2), + (28, 42, 1), + (28, 15, 1), + (28, 29, 2), + (29, 48, 1), + (29, 39, 1), + (29, 52, 1), + (29, 45, 1), + (30, 17, 2), + (30, 27, 3), + (30, 31, 2), + (30, 30, 2), + (31, 19, 1), + (31, 53, 2), + (31, 5, 1), + (31, 30, 1), + (32, 27, 2), + (32, 44, 2), + (32, 28, 1), + (32, 20, 2), + (33, 20, 2), + (33, 17, 1), + (34, 37, 2), + (34, 4, 1), + (34, 52, 2), + (34, 49, 1), + (35, 19, 3), + (35, 28, 1), + (35, 42, 1), + (36, 29, 1), + (36, 18, 1), + (36, 9, 1), + (36, 53, 1), + (36, 30, 1), + (37, 18, 1), + (37, 12, 2), + (37, 35, 2), + (37, 19, 1), + (38, 15, 1), + (38, 41, 3), + (38, 45, 1), + (38, 1, 1), + (39, 33, 2), + (39, 8, 2), + (40, 30, 1), + (40, 41, 1), + (40, 31, 1), + (40, 20, 1), + (41, 48, 1), + (41, 17, 1), + (41, 13, 3), + (41, 52, 1), + (41, 41, 1), + (42, 12, 2), + (42, 40, 1), + (42, 33, 3), + (42, 6, 2), + (43, 13, 2), + (43, 52, 1), + (43, 52, 1), + (43, 6, 2), + (44, 27, 1), + (44, 20, 2), + (44, 16, 2), + (44, 33, 2), + (45, 1, 1), + (45, 51, 1), + (45, 53, 1), + (45, 15, 1), + (45, 33, 1), + (45, 38, 1), + (45, 45, 1), + (45, 24, 1), + (46, 12, 2), + (46, 23, 1), + (46, 34, 1), + (46, 19, 1), + (47, 14, 1), + (47, 49, 1), + (47, 45, 1), + (47, 41, 2), + (48, 9, 1), + (48, 3, 1), + (48, 15, 1), + (49, 39, 1), + (49, 17, 1), + (49, 20, 3), + (49, 14, 1), + (50, 27, 1), + (50, 2, 1), + (50, 27, 1), + (50, 21, 1), + (51, 39, 1), + (51, 8, 1), + (51, 48, 1), + (51, 23, 1), + (52, 38, 1), + (52, 17, 1), + (52, 43, 1), + (52, 3, 1), + (52, 36, 1), + (53, 39, 1), + (53, 46, 1), + (53, 7, 2), + (53, 13, 1), + (53, 9, 1), + (53, 36, 1), + (54, 41, 1), + (54, 34, 1), + (54, 33, 2), + (54, 24, 1), + (54, 2, 2), + (55, 2, 1), + (55, 52, 2), + (55, 24, 2), + (55, 5, 1), + (56, 22, 1), + (56, 3, 1), + (56, 1, 1), + (57, 12, 1), + (57, 49, 3), + (57, 7, 1), + (57, 51, 1), + (57, 47, 1), + (58, 20, 1), + (58, 45, 2), + (58, 52, 1), + (58, 51, 1), + (58, 16, 1), + (59, 10, 2), + (59, 53, 1), + (59, 22, 1), + (59, 19, 1), + (60, 4, 1), + (60, 36, 2), + (60, 35, 1), + (60, 19, 1), + (61, 26, 1), + (61, 3, 1), + (61, 19, 2), + (61, 14, 2), + (61, 18, 2), + (62, 10, 2), + (62, 6, 2), + (62, 16, 1), + (62, 26, 2), + (63, 41, 1), + (63, 34, 2), + (63, 23, 1), + (63, 7, 1), + (64, 32, 1), + (64, 45, 1), + (64, 31, 2), + (64, 28, 3), + (65, 22, 1), + (65, 16, 1), + (65, 3, 1), + (66, 15, 2), + (66, 52, 3), + (66, 19, 3), + (66, 14, 1), + (67, 52, 1), + (67, 35, 1), + (67, 19, 1), + (67, 37, 2), + (68, 5, 1), + (68, 1, 2), + (68, 22, 2), + (69, 34, 1), + (69, 36, 1), + (69, 12, 1), + (69, 45, 1), + (70, 31, 1), + (70, 37, 1), + (70, 31, 2), + (71, 15, 1), + (71, 35, 1), + (71, 9, 2), + (71, 41, 1), + (71, 41, 1), + (72, 27, 1), + (72, 53, 2), + (72, 1, 1), + (73, 14, 1), + (73, 10, 1), + (73, 22, 1), + (74, 10, 1), + (74, 12, 1), + (74, 16, 1), + (74, 29, 1), + (75, 19, 1), + (75, 20, 1), + (75, 21, 2), + (75, 1, 2), + (75, 25, 1), + (76, 40, 1), + (76, 26, 1), + (76, 50, 2), + (76, 4, 2), + (76, 43, 1), + (77, 32, 1), + (77, 31, 2), + (77, 36, 3), + (78, 5, 1), + (78, 5, 1), + (79, 10, 2), + (79, 23, 1), + (79, 10, 1), + (79, 39, 1), + (79, 44, 2), + (79, 4, 1), + (79, 47, 1), + (80, 5, 2), + (80, 20, 2), + (80, 25, 1), + (80, 49, 1), + (81, 33, 1), + (81, 5, 1), + (81, 25, 2), + (81, 45, 1), + (81, 44, 1), + (82, 13, 2), + (82, 35, 2), + (82, 24, 1), + (83, 36, 2), + (83, 49, 1), + (83, 37, 2), + (84, 10, 1), + (84, 32, 3), + (84, 52, 1), + (85, 36, 1), + (85, 28, 1), + (85, 19, 1), + (85, 48, 2), + (86, 47, 1), + (86, 29, 1), + (86, 45, 1), + (86, 39, 2), + (87, 27, 1), + (87, 26, 1), + (87, 38, 1), + (87, 6, 1), + (87, 46, 2), + (87, 36, 2), + (88, 15, 2), + (88, 35, 2), + (88, 41, 1), + (88, 52, 2), + (88, 27, 1), + (89, 50, 1), + (89, 26, 2), + (89, 35, 1), + (90, 31, 1), + (90, 12, 1), + (90, 47, 1), + (90, 46, 2), + (91, 23, 1), + (91, 49, 2), + (91, 18, 2), + (91, 17, 1), + (92, 22, 1), + (92, 44, 1), + (92, 17, 1), + (93, 37, 1), + (93, 13, 1), + (93, 32, 2), + (94, 28, 1), + (94, 36, 2), + (94, 52, 1), + (94, 39, 1), + (94, 18, 1), + (95, 45, 2), + (95, 31, 1), + (95, 34, 1), + (95, 51, 1), + (96, 28, 1), + (96, 7, 3), + (96, 46, 1), + (96, 53, 1), + (96, 23, 2), + (97, 6, 2), + (97, 30, 1), + (97, 49, 1), + (98, 18, 2), + (98, 15, 3), + (98, 50, 1), + (98, 18, 1), + (98, 12, 1), + (99, 44, 2), + (99, 29, 1), + (99, 1, 2), + (100, 48, 2), + (100, 42, 1), + (100, 46, 1), + (100, 2, 2), + (101, 33, 1), + (101, 5, 1), + (101, 5, 2), + (101, 29, 1), + (102, 19, 1), + (102, 12, 1), + (102, 35, 2), + (102, 9, 2), + (102, 34, 1), + (102, 1, 1), + (102, 36, 1), + (103, 41, 1), + (103, 18, 2), + (103, 46, 1), + (103, 51, 1), + (104, 48, 2), + (104, 34, 1), + (105, 24, 1), + (105, 31, 1), + (105, 6, 2), + (105, 33, 2), + (106, 16, 1), + (106, 42, 1), + (106, 7, 1), + (107, 45, 1), + (107, 14, 1), + (107, 5, 1), + (107, 2, 1), + (108, 43, 1), + (108, 42, 1), + (108, 38, 1), + (108, 41, 1), + (109, 30, 2), + (109, 40, 1), + (109, 33, 1), + (110, 4, 1), + (110, 53, 1), + (110, 17, 1), + (111, 36, 2), + (111, 11, 1), + (111, 11, 2), + (111, 29, 1), + (112, 19, 1), + (112, 1, 1), + (112, 4, 1), + (113, 51, 2), + (113, 49, 1), + (113, 50, 1), + (113, 28, 1), + (113, 19, 1), + (113, 35, 1), + (114, 7, 2), + (114, 34, 1), + (114, 29, 1), + (114, 5, 2), + (115, 33, 1), + (115, 7, 1), + (115, 48, 2), + (115, 33, 1), + (116, 38, 2), + (116, 27, 1), + (116, 27, 2), + (117, 35, 1), + (117, 44, 2), + (117, 37, 1), + (118, 9, 2), + (118, 27, 2), + (118, 33, 1), + (118, 41, 2), + (119, 3, 1), + (119, 27, 2), + (119, 51, 2), + (120, 7, 1), + (120, 36, 1), + (121, 32, 1), + (121, 31, 1), + (121, 10, 1), + (121, 16, 1), + (122, 40, 1), + (122, 13, 2), + (122, 49, 1), + (123, 41, 1), + (123, 49, 2), + (123, 37, 1), + (123, 44, 2), + (123, 49, 2), + (124, 39, 1), + (124, 39, 1), + (124, 28, 1), + (125, 24, 1), + (125, 4, 3), + (125, 34, 2), + (125, 30, 1), + (126, 3, 2), + (126, 40, 3), + (126, 31, 2), + (126, 3, 2), + (127, 38, 1), + (127, 9, 2), + (127, 53, 1), + (127, 45, 2), + (128, 7, 1), + (128, 41, 1), + (128, 25, 1), + (129, 49, 1), + (129, 28, 1), + (129, 19, 2), + (130, 26, 1), + (130, 43, 2), + (131, 42, 2), + (131, 16, 1), + (131, 10, 1), + (131, 26, 1), + (131, 34, 2), + (132, 49, 1), + (132, 20, 2), + (133, 17, 1), + (133, 34, 1), + (133, 7, 1), + (133, 38, 2), + (134, 12, 2), + (134, 31, 2), + (134, 8, 1), + (134, 3, 1), + (135, 38, 1), + (135, 38, 2), + (135, 18, 1), + (135, 36, 2), + (135, 40, 1), + (135, 19, 2), + (136, 25, 1), + (136, 3, 2), + (136, 43, 1), + (136, 41, 2), + (136, 19, 1), + (137, 38, 1), + (137, 36, 1), + (137, 22, 1), + (137, 50, 2), + (138, 7, 1), + (138, 29, 1), + (138, 28, 1), + (139, 6, 1), + (139, 10, 1), + (139, 18, 2), + (139, 9, 1), + (140, 24, 2), + (140, 37, 1), + (140, 31, 1), + (140, 51, 2), + (141, 2, 1), + (141, 47, 1), + (141, 35, 1), + (141, 44, 1), + (142, 15, 2), + (142, 31, 1), + (142, 45, 3), + (142, 47, 1), + (142, 15, 1), + (143, 43, 1), + (143, 21, 2), + (143, 19, 1), + (143, 27, 1), + (144, 16, 1), + (144, 48, 1), + (144, 51, 1), + (144, 13, 1), + (145, 1, 3), + (145, 2, 1), + (145, 37, 1), + (145, 52, 1), + (146, 7, 3), + (146, 45, 1), + (146, 40, 1), + (146, 19, 1), + (146, 39, 2), + (147, 20, 1), + (147, 7, 1), + (147, 35, 2), + (148, 44, 2), + (148, 36, 1), + (148, 53, 1), + (148, 7, 1), + (149, 3, 1), + (149, 43, 1), + (149, 47, 1), + (149, 33, 1), + (150, 22, 2), + (150, 14, 1), + (150, 7, 1), + (150, 19, 2), + (151, 43, 3), + (151, 3, 2), + (151, 37, 1), + (151, 35, 1), + (152, 1, 1), + (152, 2, 3), + (152, 6, 2), + (152, 51, 1), + (153, 29, 2), + (153, 28, 1), + (153, 14, 1), + (153, 50, 2), + (154, 32, 1), + (154, 1, 1), + (154, 41, 2), + (154, 15, 1), + (155, 15, 2), + (155, 25, 1), + (155, 45, 1), + (156, 27, 1), + (156, 36, 1), + (156, 6, 1), + (156, 26, 2), + (156, 18, 1), + (157, 31, 2), + (157, 25, 1), + (157, 10, 1), + (157, 24, 1), + (158, 34, 2), + (158, 24, 2), + (158, 46, 2), + (158, 24, 2), + (159, 26, 1), + (159, 12, 1), + (159, 51, 2), + (160, 15, 1), + (160, 47, 2), + (160, 50, 1), + (161, 50, 2), + (161, 25, 1), + (161, 14, 2), + (161, 7, 1), + (162, 14, 1), + (162, 51, 1), + (162, 23, 2), + (163, 42, 1), + (163, 33, 1), + (163, 8, 1), + (163, 22, 2), + (164, 45, 1), + (164, 39, 2), + (164, 18, 2), + (164, 15, 1), + (165, 37, 1), + (165, 26, 1), + (165, 1, 1), + (166, 22, 2), + (166, 19, 2), + (166, 36, 1), + (167, 9, 1), + (167, 28, 1), + (167, 40, 2), + (167, 37, 1), + (168, 38, 1), + (168, 33, 1), + (168, 45, 3), + (168, 12, 2), + (169, 20, 1), + (169, 2, 1), + (169, 49, 1), + (169, 43, 1), + (170, 5, 2), + (170, 23, 1), + (170, 26, 2), + (171, 16, 1), + (171, 7, 2), + (171, 19, 1), + (171, 24, 2), + (171, 10, 1), + (172, 48, 2), + (172, 11, 2), + (172, 1, 1), + (173, 12, 3), + (173, 6, 1), + (173, 26, 1), + (174, 31, 1), + (174, 32, 1), + (174, 45, 1), + (174, 1, 1), + (174, 22, 2), + (175, 53, 1), + (175, 8, 2), + (175, 25, 1), + (176, 23, 1), + (176, 11, 1), + (176, 43, 1), + (177, 1, 2), + (177, 13, 3), + (177, 18, 2), + (177, 14, 2), + (178, 3, 1), + (178, 25, 1), + (178, 36, 1), + (178, 19, 4), + (179, 31, 2), + (179, 18, 1), + (179, 13, 1), + (180, 32, 1), + (180, 25, 1), + (180, 2, 1), + (181, 43, 2), + (181, 16, 1), + (181, 45, 1), + (181, 4, 1), + (182, 12, 1), + (182, 22, 2), + (183, 3, 1), + (183, 1, 2), + (183, 23, 1), + (183, 5, 2), + (184, 19, 2), + (184, 7, 1), + (184, 31, 1), + (184, 40, 1), + (184, 5, 2), + (184, 16, 1), + (185, 7, 1), + (185, 11, 1), + (185, 22, 2), + (185, 49, 1), + (185, 15, 1), + (185, 7, 1), + (186, 1, 1), + (186, 15, 2), + (186, 42, 1), + (187, 9, 2), + (187, 27, 1), + (187, 44, 1), + (187, 52, 1), + (188, 4, 1), + (188, 16, 1), + (188, 43, 2), + (188, 26, 1), + (189, 24, 2), + (189, 32, 1), + (189, 34, 1), + (189, 2, 1), + (190, 35, 2), + (190, 23, 1), + (190, 33, 1), + (190, 45, 1), + (191, 29, 1), + (191, 6, 2), + (191, 25, 2), + (192, 47, 1), + (192, 44, 1), + (192, 21, 2), + (192, 34, 2), + (193, 10, 1), + (193, 36, 2), + (193, 38, 1), + (193, 13, 1), + (194, 17, 2), + (194, 2, 1), + (194, 25, 1), + (194, 17, 1), + (195, 19, 2), + (195, 49, 1), + (195, 3, 1), + (195, 4, 2), + (196, 29, 1), + (196, 13, 1), + (196, 12, 1), + (196, 42, 1), + (197, 47, 1), + (197, 44, 1), + (197, 41, 1), + (197, 1, 1), + (197, 35, 2), + (198, 17, 2), + (198, 50, 1), + (198, 10, 1), + (199, 6, 1), + (199, 45, 1), + (199, 35, 2), + (199, 5, 1), + (200, 7, 1), + (200, 18, 2), + (200, 42, 1), + (201, 35, 1), + (201, 45, 1), + (202, 50, 1), + (202, 17, 1), + (202, 37, 2), + (202, 46, 1), + (203, 44, 1), + (203, 41, 2), + (203, 47, 1), + (203, 26, 2), + (203, 26, 1), + (204, 19, 2), + (204, 49, 2), + (204, 26, 2), + (205, 16, 2), + (205, 42, 1), + (205, 40, 2), + (205, 16, 1), + (206, 13, 2), + (206, 6, 1), + (206, 37, 1), + (207, 1, 1), + (207, 5, 1), + (207, 34, 1), + (208, 26, 1), + (208, 30, 1), + (208, 38, 1), + (209, 14, 1), + (209, 12, 1), + (209, 1, 1), + (209, 36, 1), + (209, 5, 2), + (210, 29, 1), + (210, 41, 1), + (210, 6, 2), + (210, 20, 2), + (210, 18, 1), + (211, 31, 2), + (211, 38, 1), + (211, 15, 1), + (211, 11, 1), + (212, 46, 1), + (212, 46, 1), + (212, 18, 1), + (212, 35, 1), + (213, 53, 1), + (213, 43, 1), + (213, 44, 1), + (213, 31, 1), + (214, 43, 1), + (214, 36, 2), + (214, 19, 1), + (214, 48, 1), + (215, 42, 2), + (215, 27, 2), + (215, 37, 2), + (215, 12, 3), + (216, 1, 1), + (216, 49, 1), + (216, 13, 1), + (216, 16, 1), + (216, 28, 1), + (217, 49, 1), + (217, 5, 1), + (217, 34, 1), + (218, 4, 1), + (218, 29, 1), + (218, 4, 2), + (219, 29, 2), + (219, 21, 1), + (219, 19, 1), + (219, 11, 1), + (220, 31, 1), + (220, 1, 2), + (220, 18, 1), + (220, 43, 2), + (221, 43, 1), + (221, 18, 2), + (221, 26, 2), + (221, 51, 1), + (222, 19, 2), + (222, 10, 2), + (222, 36, 2), + (222, 38, 2), + (223, 12, 1), + (223, 22, 1), + (223, 51, 1), + (224, 1, 2), + (224, 53, 1), + (224, 51, 2), + (224, 37, 1), + (224, 41, 1), + (225, 20, 1), + (225, 30, 2), + (225, 41, 1), + (225, 36, 1), + (225, 27, 1), + (226, 11, 1), + (226, 47, 2), + (226, 47, 1), + (226, 22, 1), + (227, 32, 1), + (227, 7, 2), + (227, 41, 2), + (227, 42, 2), + (228, 28, 1), + (228, 25, 1), + (228, 43, 1), + (228, 29, 1), + (229, 6, 3), + (229, 29, 2), + (229, 3, 2), + (229, 43, 1), + (230, 42, 1), + (230, 8, 1), + (230, 40, 1), + (230, 53, 2), + (231, 8, 3), + (231, 45, 1), + (231, 47, 1), + (231, 30, 2), + (231, 30, 1), + (232, 34, 1), + (232, 31, 2), + (232, 25, 2), + (232, 14, 1), + (232, 32, 2), + (233, 34, 1), + (233, 53, 1), + (234, 35, 1), + (234, 15, 2), + (234, 3, 1), + (234, 31, 2), + (234, 38, 1), + (234, 10, 2), + (234, 29, 2), + (235, 37, 1), + (235, 20, 1), + (235, 48, 2), + (235, 38, 1), + (236, 35, 1), + (236, 18, 1), + (236, 9, 1), + (236, 7, 2), + (236, 19, 1), + (237, 40, 1), + (237, 10, 2), + (237, 47, 1), + (238, 28, 2), + (238, 49, 1), + (238, 3, 1), + (238, 48, 1), + (238, 40, 1), + (239, 17, 2), + (239, 33, 1), + (239, 52, 1), + (240, 5, 1), + (240, 47, 1), + (240, 7, 1), + (240, 25, 1), + (241, 10, 1), + (241, 51, 1), + (241, 28, 1), + (241, 31, 1), + (241, 10, 1), + (242, 47, 1), + (242, 12, 1), + (242, 47, 1), + (242, 46, 1), + (243, 5, 2), + (243, 5, 1), + (243, 8, 1), + (243, 23, 1), + (244, 39, 2), + (244, 29, 1), + (244, 25, 1), + (244, 16, 1), + (245, 51, 1), + (245, 7, 1), + (245, 12, 1), + (245, 18, 1), + (245, 40, 1), + (246, 13, 1), + (246, 1, 1), + (246, 2, 3), + (246, 26, 1), + (247, 41, 2), + (247, 53, 1), + (247, 7, 2), + (247, 51, 1), + (248, 14, 1), + (248, 10, 2), + (248, 23, 1), + (248, 4, 1), + (248, 32, 1), + (249, 11, 2), + (249, 17, 1), + (249, 2, 1), + (249, 27, 2), + (249, 45, 2), + (250, 21, 1), + (250, 46, 1), + (250, 39, 1), + (250, 6, 2), + (251, 37, 1), + (251, 23, 1), + (251, 50, 1), + (251, 25, 1), + (252, 11, 1), + (252, 15, 1), + (252, 46, 1), + (253, 25, 1), + (253, 25, 1), + (253, 18, 1), + (253, 43, 1), + (253, 11, 1), + (253, 12, 1), + (254, 17, 1), + (254, 42, 1), + (254, 27, 1), + (254, 36, 1), + (255, 21, 1), + (255, 13, 1), + (255, 15, 1), + (255, 40, 1), + (255, 48, 1), + (256, 48, 1), + (256, 8, 1), + (256, 38, 1), + (257, 42, 1), + (257, 48, 1), + (257, 52, 2), + (258, 20, 2), + (258, 1, 1), + (258, 39, 1), + (259, 16, 2), + (259, 38, 2), + (259, 7, 1), + (259, 39, 2), + (259, 44, 1), + (259, 22, 1), + (260, 1, 3), + (260, 10, 1), + (260, 27, 2), + (260, 26, 1), + (260, 36, 1), + (261, 26, 1), + (261, 5, 1), + (261, 40, 2), + (261, 16, 2), + (262, 11, 1), + (262, 38, 1), + (262, 47, 1), + (262, 53, 1), + (263, 39, 2), + (263, 9, 1), + (263, 41, 1), + (263, 43, 1), + (264, 49, 1), + (264, 31, 2), + (264, 53, 1), + (265, 46, 1), + (265, 27, 2), + (265, 52, 1), + (266, 11, 1), + (266, 22, 2), + (266, 30, 2), + (266, 26, 1), + (267, 17, 1), + (267, 36, 1), + (267, 10, 1), + (267, 3, 1), + (268, 21, 3), + (268, 19, 1), + (268, 23, 3), + (268, 9, 1), + (269, 41, 1), + (269, 50, 1), + (269, 13, 1), + (269, 33, 1), + (270, 34, 2), + (270, 51, 1), + (270, 5, 2), + (271, 52, 1), + (271, 41, 1), + (271, 44, 2), + (272, 53, 1), + (272, 10, 2), + (272, 4, 1), + (272, 35, 1), + (273, 30, 1), + (273, 39, 2), + (273, 34, 2), + (274, 42, 1), + (274, 49, 1), + (274, 14, 2), + (275, 52, 2), + (275, 39, 1), + (275, 30, 2), + (275, 22, 1), + (276, 19, 1), + (276, 30, 1), + (276, 21, 1), + (276, 32, 1), + (277, 3, 1), + (277, 13, 2), + (277, 26, 2), + (278, 6, 1), + (278, 37, 1), + (278, 20, 3), + (278, 47, 1), + (279, 33, 1), + (279, 40, 1), + (279, 43, 1), + (280, 46, 1), + (280, 13, 2), + (280, 12, 2), + (281, 4, 1), + (281, 8, 1), + (281, 44, 2), + (281, 27, 1), + (281, 48, 1), + (281, 48, 1), + (281, 48, 2), + (282, 35, 1), + (282, 24, 2), + (282, 17, 2), + (282, 2, 1), + (283, 9, 2), + (283, 53, 2), + (283, 35, 2), + (283, 30, 1), + (283, 17, 1), + (284, 17, 1), + (284, 39, 1), + (284, 7, 2), + (284, 18, 1), + (285, 28, 1), + (285, 27, 2), + (285, 28, 2), + (286, 39, 1), + (286, 8, 1), + (286, 16, 2), + (286, 13, 1), + (287, 30, 1), + (287, 4, 1), + (287, 51, 1), + (287, 5, 1), + (288, 15, 2), + (288, 5, 1), + (288, 18, 2), + (288, 53, 2), + (288, 25, 1), + (289, 23, 1), + (289, 46, 2), + (289, 36, 1), + (289, 52, 1), + (289, 3, 1), + (290, 53, 1), + (290, 22, 1), + (290, 16, 1), + (290, 19, 1), + (290, 34, 1), + (291, 34, 1), + (291, 42, 1), + (291, 36, 1), + (291, 45, 2), + (291, 11, 1), + (292, 15, 1), + (292, 14, 1), + (292, 47, 1), + (293, 52, 3), + (293, 8, 1), + (293, 46, 1), + (294, 21, 1), + (294, 44, 1), + (294, 22, 1), + (294, 19, 1), + (295, 13, 1), + (295, 48, 1), + (295, 40, 1), + (295, 3, 2), + (296, 24, 1), + (296, 42, 1), + (296, 50, 1), + (296, 27, 1), + (296, 37, 2), + (296, 47, 1), + (297, 6, 2), + (297, 29, 1), + (297, 30, 1), + (297, 28, 1), + (298, 40, 1), + (298, 6, 2), + (298, 39, 2), + (298, 24, 1), + (298, 29, 1), + (298, 46, 1), + (299, 12, 2), + (299, 43, 1), + (300, 7, 1), + (300, 26, 1), + (300, 3, 2), + (301, 27, 2), + (301, 11, 1), + (301, 49, 2), + (301, 31, 1), + (302, 27, 1), + (302, 9, 1), + (302, 1, 2), + (303, 28, 2), + (303, 6, 1), + (303, 29, 1), + (304, 29, 1), + (304, 20, 1), + (304, 44, 1), + (304, 21, 2), + (305, 28, 2), + (305, 4, 2), + (305, 26, 2), + (306, 43, 1), + (306, 51, 1), + (306, 23, 1), + (307, 6, 1), + (307, 42, 1), + (307, 30, 3), + (308, 1, 2), + (308, 42, 2), + (308, 27, 1), + (308, 3, 1), + (309, 30, 1), + (309, 43, 1), + (309, 27, 2), + (309, 46, 3), + (310, 53, 1), + (310, 48, 4), + (310, 49, 1), + (311, 13, 2), + (311, 16, 1), + (311, 42, 2), + (311, 47, 2), + (312, 37, 1), + (312, 45, 1), + (312, 50, 1), + (312, 40, 1), + (312, 3, 2), + (313, 47, 1), + (313, 15, 2), + (313, 35, 2), + (313, 31, 2), + (314, 20, 1), + (314, 13, 1), + (315, 5, 1), + (315, 12, 1), + (315, 17, 1), + (316, 47, 2), + (316, 44, 1), + (316, 25, 1), + (317, 42, 1), + (317, 8, 1), + (317, 6, 1), + (317, 49, 1), + (318, 36, 2), + (318, 11, 2), + (318, 34, 1), + (319, 6, 2), + (319, 24, 1), + (319, 42, 3), + (320, 42, 1), + (320, 34, 1), + (320, 14, 1), + (320, 7, 1), + (320, 39, 1), + (321, 27, 1), + (321, 11, 2), + (321, 43, 2), + (321, 31, 1), + (322, 3, 1), + (322, 44, 2), + (322, 4, 1), + (322, 27, 1), + (323, 8, 2), + (323, 35, 2), + (323, 39, 1), + (323, 49, 2), + (324, 2, 2), + (324, 19, 1), + (324, 34, 2), + (325, 43, 1), + (325, 44, 1), + (325, 38, 2), + (325, 44, 1), + (325, 2, 3), + (325, 10, 2), + (326, 25, 1), + (326, 12, 1), + (326, 28, 2), + (326, 8, 1), + (327, 16, 1), + (327, 3, 2), + (327, 14, 1), + (328, 47, 1), + (328, 32, 1), + (328, 28, 2), + (328, 38, 1), + (328, 8, 1), + (329, 43, 1), + (329, 14, 1), + (329, 18, 1), + (329, 38, 1), + (330, 25, 2), + (330, 29, 2), + (330, 7, 1), + (331, 19, 1), + (331, 10, 3), + (331, 11, 1), + (331, 19, 1), + (332, 45, 1), + (332, 8, 1), + (333, 19, 1), + (333, 53, 1), + (333, 16, 2), + (333, 53, 1), + (333, 5, 1), + (334, 5, 1), + (334, 16, 1), + (334, 46, 1), + (334, 11, 2), + (335, 51, 1), + (335, 30, 1), + (335, 4, 1), + (336, 48, 1), + (336, 24, 1), + (336, 28, 1), + (336, 7, 1), + (337, 1, 1), + (337, 3, 1), + (337, 30, 1), + (337, 14, 1), + (338, 29, 1), + (338, 9, 1), + (338, 36, 1), + (338, 41, 2), + (338, 34, 2), + (338, 4, 2), + (339, 26, 1), + (339, 16, 1), + (339, 50, 1), + (339, 16, 1), + (340, 42, 1), + (340, 28, 1), + (340, 47, 1), + (341, 31, 1), + (341, 12, 1), + (341, 6, 1), + (341, 16, 1), + (342, 10, 2), + (342, 10, 2), + (342, 45, 2), + (343, 51, 1), + (343, 24, 2), + (343, 31, 1), + (343, 2, 1), + (344, 41, 1), + (344, 41, 1), + (344, 1, 1), + (344, 4, 1), + (344, 7, 1), + (344, 5, 1), + (345, 41, 1), + (345, 14, 1), + (345, 31, 1), + (345, 20, 1), + (346, 29, 1), + (346, 17, 1), + (346, 36, 1), + (347, 46, 1), + (347, 12, 1), + (347, 49, 1), + (347, 24, 1), + (347, 23, 1), + (347, 50, 1), + (348, 49, 1), + (348, 35, 1), + (348, 25, 2), + (348, 30, 1), + (348, 35, 2), + (348, 18, 1), + (349, 45, 2), + (349, 40, 1), + (349, 26, 2), + (349, 42, 1), + (350, 16, 3), + (350, 22, 1), + (351, 51, 2), + (351, 31, 1), + (351, 21, 2), + (351, 6, 1), + (351, 53, 1), + (352, 34, 1), + (352, 41, 1), + (352, 6, 1), + (352, 2, 1), + (352, 2, 2), + (353, 36, 2), + (353, 47, 1), + (354, 24, 1), + (354, 43, 1), + (354, 48, 1), + (355, 17, 1), + (355, 30, 2), + (355, 39, 1), + (355, 30, 2), + (356, 50, 2), + (356, 4, 1), + (356, 42, 1), + (356, 52, 1), + (357, 38, 1), + (357, 18, 1), + (357, 52, 3), + (357, 29, 1), + (357, 47, 1), + (358, 24, 2), + (358, 31, 1), + (358, 52, 1), + (359, 41, 2), + (359, 40, 1), + (359, 31, 1), + (360, 32, 1), + (360, 47, 1), + (360, 18, 1), + (361, 10, 1), + (361, 51, 1), + (361, 25, 1), + (361, 23, 2), + (361, 47, 2), + (362, 29, 1), + (362, 38, 1), + (362, 32, 1), + (362, 42, 1), + (363, 43, 1), + (363, 39, 1), + (363, 38, 1), + (364, 26, 1), + (364, 21, 1), + (364, 1, 1), + (365, 43, 1), + (365, 21, 1), + (365, 15, 2), + (365, 39, 1), + (366, 17, 1), + (366, 30, 2), + (366, 53, 1), + (367, 34, 1), + (367, 41, 1), + (367, 38, 1), + (368, 41, 1), + (368, 6, 1), + (368, 28, 1), + (368, 18, 2), + (369, 36, 1), + (369, 14, 1), + (369, 46, 2), + (369, 8, 2), + (370, 42, 1), + (370, 24, 2), + (370, 3, 2), + (370, 37, 1), + (370, 18, 2), + (371, 40, 2), + (371, 25, 1), + (371, 14, 2), + (371, 46, 1), + (371, 3, 2), + (372, 14, 1), + (372, 26, 1), + (372, 3, 1), + (372, 43, 1), + (373, 30, 1), + (373, 15, 1), + (373, 38, 1), + (374, 10, 1), + (374, 49, 1), + (374, 40, 1), + (374, 18, 2), + (374, 22, 1), + (375, 37, 1), + (375, 15, 1), + (375, 10, 1), + (375, 42, 1), + (375, 35, 1), + (376, 8, 1), + (376, 4, 1), + (376, 34, 2), + (376, 13, 1), + (376, 15, 2), + (376, 3, 2), + (376, 2, 1), + (377, 31, 1), + (377, 12, 1), + (377, 50, 2), + (377, 49, 1), + (378, 15, 2), + (378, 48, 2), + (379, 25, 2), + (379, 43, 2), + (379, 23, 1), + (379, 39, 1), + (380, 32, 1), + (380, 50, 1), + (380, 49, 1), + (380, 12, 1), + (381, 9, 1), + (381, 6, 2), + (381, 28, 1), + (381, 49, 2), + (382, 49, 1), + (382, 25, 2), + (382, 8, 1), + (383, 25, 1), + (383, 8, 2), + (383, 24, 1), + (384, 42, 2), + (384, 31, 2), + (384, 11, 1), + (384, 31, 1), + (385, 51, 2), + (385, 43, 1), + (385, 10, 1), + (385, 51, 1), + (386, 33, 2), + (386, 15, 1), + (386, 40, 1), + (386, 10, 1), + (387, 26, 1), + (387, 32, 1), + (387, 3, 1), + (388, 15, 1), + (388, 20, 1), + (388, 16, 1), + (388, 42, 1), + (388, 20, 1), + (389, 51, 2), + (389, 7, 1), + (389, 9, 2), + (389, 7, 1), + (390, 44, 1), + (390, 10, 2), + (390, 25, 1), + (390, 12, 2), + (390, 1, 2), + (391, 33, 2), + (391, 5, 1), + (391, 19, 2), + (391, 20, 1), + (391, 29, 1), + (391, 39, 1), + (392, 30, 3), + (392, 7, 1), + (392, 20, 1), + (393, 36, 2), + (393, 6, 1), + (393, 10, 2), + (393, 2, 1), + (393, 10, 2), + (394, 37, 2), + (394, 21, 1), + (394, 18, 2), + (394, 37, 2), + (394, 32, 2), + (395, 13, 1), + (395, 35, 1), + (395, 14, 1), + (395, 20, 1), + (396, 22, 1), + (396, 4, 1), + (396, 11, 2), + (396, 29, 1), + (396, 17, 1), + (397, 23, 1), + (397, 23, 1), + (397, 52, 1), + (397, 45, 1), + (398, 14, 1), + (398, 19, 1), + (398, 13, 1), + (398, 12, 1), + (399, 13, 2), + (399, 42, 2), + (399, 23, 1), + (400, 53, 1), + (400, 9, 1), + (400, 17, 1), + (401, 41, 1), + (401, 51, 1), + (401, 10, 1), + (401, 44, 1), + (401, 48, 1), + (401, 47, 1), + (402, 37, 1), + (402, 19, 1), + (402, 6, 1), + (402, 34, 2), + (403, 25, 1), + (403, 18, 1), + (403, 3, 2), + (403, 29, 3), + (404, 5, 2), + (404, 37, 2), + (404, 40, 1), + (404, 12, 1), + (405, 48, 1), + (405, 11, 1), + (405, 40, 2), + (405, 50, 1), + (406, 36, 2), + (406, 6, 2), + (406, 6, 2), + (406, 14, 1), + (406, 39, 2), + (407, 3, 3), + (407, 11, 2), + (407, 6, 1), + (408, 12, 1), + (408, 13, 2), + (408, 4, 2), + (408, 50, 1), + (409, 48, 1), + (409, 20, 2), + (409, 19, 1), + (410, 22, 1), + (410, 48, 1), + (410, 17, 1), + (411, 16, 1), + (411, 2, 2), + (411, 49, 1), + (412, 41, 1), + (412, 1, 2), + (412, 31, 1), + (412, 50, 1), + (413, 5, 1), + (413, 6, 2), + (413, 32, 1), + (413, 43, 3), + (414, 32, 1), + (414, 36, 1), + (414, 5, 1), + (414, 11, 2), + (414, 11, 2), + (415, 9, 1), + (415, 11, 2), + (415, 36, 2), + (415, 18, 1), + (415, 12, 1), + (416, 40, 1), + (416, 33, 1), + (416, 7, 1), + (417, 13, 1), + (417, 31, 1), + (417, 40, 2), + (418, 8, 1), + (418, 26, 2), + (418, 8, 1), + (418, 18, 1), + (419, 44, 2), + (419, 46, 1), + (419, 2, 1), + (419, 39, 1), + (420, 35, 1), + (420, 29, 1), + (420, 21, 1), + (420, 9, 1), + (421, 13, 1), + (421, 16, 1), + (421, 13, 1), + (421, 22, 1), + (422, 9, 1), + (422, 20, 2), + (422, 5, 1), + (422, 50, 1), + (423, 7, 1), + (423, 4, 1), + (424, 52, 1), + (424, 38, 1), + (424, 37, 1), + (425, 7, 2), + (425, 17, 2), + (425, 48, 2), + (426, 22, 1), + (426, 15, 2), + (426, 10, 1), + (426, 41, 2), + (427, 45, 2), + (427, 22, 1), + (427, 8, 1), + (428, 50, 2), + (428, 37, 1), + (428, 7, 1), + (428, 23, 1), + (429, 2, 1), + (429, 24, 1), + (429, 24, 1), + (429, 49, 2), + (429, 20, 1), + (430, 22, 2), + (430, 7, 1), + (431, 43, 1), + (431, 37, 2), + (431, 48, 2), + (431, 24, 2), + (432, 29, 2), + (432, 14, 1), + (432, 1, 1), + (433, 41, 2), + (433, 24, 1), + (433, 49, 1), + (433, 2, 1), + (434, 34, 2), + (434, 49, 1), + (434, 30, 2), + (434, 31, 1), + (435, 40, 2), + (435, 38, 1), + (435, 37, 3), + (436, 38, 1), + (436, 49, 1), + (436, 39, 1), + (437, 28, 1), + (437, 20, 1), + (437, 42, 1), + (437, 34, 1), + (437, 12, 1), + (437, 46, 1), + (438, 43, 1), + (438, 20, 1), + (438, 8, 1), + (438, 11, 1), + (438, 3, 1), + (439, 42, 1), + (439, 14, 2), + (439, 6, 1), + (439, 34, 2), + (440, 1, 1), + (440, 9, 2), + (440, 45, 2), + (440, 27, 1), + (441, 15, 1), + (441, 34, 1), + (441, 27, 2), + (441, 30, 1), + (441, 50, 1), + (441, 37, 2), + (442, 33, 1), + (442, 26, 1), + (442, 48, 1), + (443, 2, 1), + (443, 50, 2), + (443, 12, 1), + (444, 7, 1), + (444, 42, 1), + (444, 32, 2), + (444, 18, 2), + (445, 25, 1), + (445, 3, 2), + (445, 5, 1), + (446, 16, 2), + (446, 17, 1), + (446, 52, 4), + (446, 47, 1), + (447, 28, 1), + (447, 48, 1), + (447, 46, 2), + (448, 37, 1), + (448, 10, 1), + (448, 31, 1), + (449, 23, 1), + (449, 26, 1), + (449, 36, 1), + (449, 53, 1), + (449, 40, 2), + (450, 43, 1), + (450, 47, 1), + (450, 22, 1), + (450, 9, 3), + (451, 52, 2), + (451, 32, 2), + (451, 28, 2), + (451, 2, 3), + (452, 29, 1), + (452, 41, 2), + (452, 50, 1), + (453, 49, 2), + (453, 15, 1), + (453, 51, 1), + (453, 47, 1), + (454, 20, 2), + (454, 47, 1), + (454, 9, 1), + (454, 11, 1), + (455, 16, 1), + (455, 17, 1), + (456, 12, 1), + (456, 45, 1), + (456, 35, 1), + (456, 22, 1), + (457, 35, 1), + (457, 13, 1), + (457, 47, 1), + (457, 8, 1), + (458, 28, 1), + (458, 32, 1), + (458, 7, 2), + (458, 15, 1), + (459, 24, 2), + (459, 1, 1), + (459, 2, 2), + (459, 24, 2), + (460, 43, 1), + (460, 14, 1), + (460, 49, 1), + (461, 49, 1), + (461, 44, 2), + (461, 49, 1), + (461, 48, 2), + (462, 53, 1), + (462, 6, 2), + (462, 12, 1), + (463, 40, 1), + (463, 40, 1), + (463, 20, 3), + (463, 9, 1), + (463, 46, 1), + (464, 36, 1), + (464, 9, 1), + (464, 16, 1), + (465, 36, 1), + (465, 25, 2), + (465, 34, 1), + (465, 49, 1), + (466, 9, 1), + (466, 26, 1), + (466, 43, 1), + (466, 14, 1), + (466, 38, 2), + (467, 18, 1), + (467, 52, 1), + (467, 53, 1), + (467, 43, 1), + (468, 20, 1), + (468, 43, 1), + (468, 21, 1), + (469, 18, 1), + (469, 53, 2), + (469, 25, 1), + (469, 28, 1), + (470, 1, 1), + (470, 8, 1), + (470, 9, 1), + (470, 50, 2), + (471, 4, 1), + (471, 35, 1), + (471, 29, 1), + (471, 27, 1), + (472, 32, 1), + (472, 7, 1), + (472, 10, 1), + (472, 40, 2), + (473, 1, 1), + (473, 29, 1), + (473, 5, 1), + (473, 16, 1), + (473, 10, 1), + (474, 33, 1), + (474, 16, 1), + (474, 27, 2), + (474, 9, 1), + (474, 53, 1), + (475, 30, 1), + (475, 1, 2), + (475, 1, 1), + (475, 4, 2), + (476, 6, 2), + (476, 22, 2), + (476, 18, 1), + (477, 49, 1), + (477, 20, 2), + (477, 44, 1), + (478, 20, 1), + (478, 44, 2), + (478, 33, 2), + (478, 11, 2), + (479, 4, 1), + (479, 41, 2), + (480, 2, 1), + (480, 42, 1), + (480, 27, 1), + (481, 47, 1), + (481, 46, 2), + (481, 22, 1), + (481, 39, 1), + (482, 13, 2), + (482, 30, 2), + (482, 52, 2), + (482, 50, 1), + (482, 6, 2), + (482, 48, 1), + (483, 3, 1), + (483, 5, 1), + (483, 35, 1), + (484, 36, 2), + (484, 19, 1), + (484, 50, 2), + (484, 25, 1), + (485, 13, 1), + (485, 53, 2), + (485, 53, 1), + (485, 11, 1), + (486, 17, 2), + (486, 50, 1), + (486, 19, 1), + (487, 5, 1), + (487, 52, 2), + (487, 6, 1), + (487, 47, 1), + (487, 45, 1), + (487, 5, 1), + (488, 6, 1), + (488, 10, 2), + (488, 20, 1), + (488, 19, 1), + (488, 6, 1), + (488, 46, 1), + (489, 45, 1), + (489, 25, 2), + (489, 41, 1), + (490, 14, 2), + (490, 18, 1), + (490, 47, 1), + (490, 5, 1), + (490, 29, 2), + (491, 46, 1), + (491, 52, 2), + (491, 8, 2), + (491, 39, 1), + (492, 52, 1), + (492, 52, 1), + (492, 41, 2), + (492, 1, 2), + (492, 11, 1), + (493, 46, 1), + (493, 38, 1), + (493, 14, 2), + (494, 30, 1), + (494, 24, 1), + (494, 43, 1), + (495, 24, 1), + (495, 37, 1), + (495, 25, 1), + (496, 4, 1), + (496, 24, 2), + (496, 43, 2), + (496, 10, 1), + (497, 45, 1), + (497, 24, 1), + (497, 16, 2), + (498, 21, 1), + (498, 24, 1), + (498, 38, 2), + (499, 15, 1), + (499, 36, 1), + (499, 8, 1), + (499, 15, 1), + (499, 52, 1), + (500, 20, 1), + (500, 39, 1), + (500, 6, 2), + (500, 7, 1), + (500, 21, 1), + (500, 39, 2), + (500, 32, 2); + + + + + + + + + + + diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/feladatleírás.pdf b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/feladatleírás.pdf new file mode 100644 index 0000000..27a9a8f Binary files /dev/null and b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/feladatleírás.pdf differ diff --git a/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/megoldasok_2.txt b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/megoldasok_2.txt new file mode 100644 index 0000000..c36c916 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241009/adatb2feladatok/2.feladat/megoldasok_2.txt @@ -0,0 +1,27 @@ +-- 10. feladat: +CREATE DATABASE hamburger CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + + +-- 12. feladat: +SELECT * FROM `menutetel` WHERE menutetel.ar = 2500; + + +-- 13. feladat: +UPDATE `menutetel` SET `ar`= 2300 WHERE menutetel.nev = "Grill pizza 32cm"; + + +-- 14. feladat: +SELECT felhasznalo.nev AS `vendeg_nev`, COUNT(rendeles.felhasznaloId) AS `rendeles_db` FROM `rendeles` INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id GROUP BY rendeles.felhasznaloId ORDER BY `rendeles_db` DESC LIMIT 9; + + +-- 15. feladat: +INSERT INTO `menutetel`(`nev`, `ar`, `etelkatId`) VALUES ("Boston tészta", 2300, 3); + + +-- 16. feladat: +SELECT rendeles.id AS `rendeles_azon`, rendeleselem.id AS `rendeleselem_azon`, menutetel.nev AS `menutetel_neve` FROM `rendeleselem` INNER JOIN rendeles ON rendeleselem.rendelesId = rendeles.id INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id INNER JOIN menutetel ON rendeleselem.menutetelId = menutetel.id WHERE felhasznalo.nev = "Balázs Flóra"; + + +-- 17. feladat: +SELECT felhasznalo.nev, SUM(rendeleselem.mennyiseg * menutetel.ar) * 1.10 AS `osszesen` FROM `rendeleselem` INNER JOIN rendeles ON rendeleselem.rendelesId = rendeles.id INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id INNER JOIN menutetel ON rendeleselem.menutetelId = menutetel.id GROUP BY rendeles.felhasznaloId ORDER BY `osszesen` DESC LIMIT 1; + diff --git a/Suli/13.b/Adatbázis/20241016/adatbazis.sql b/Suli/13.b/Adatbázis/20241016/adatbazis.sql new file mode 100644 index 0000000..aa41661 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241016/adatbazis.sql @@ -0,0 +1,2719 @@ +-- Film stílusok +CREATE TABLE filmtipus +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(32) NOT NULL, + primary key (id) +); + +-- Vendégek +CREATE TABLE vendeg +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL, + primary key (id) +); + +-- Filmek +create TABLE film +( + id int NOT NULL, + cim varchar(64) NOT NULL, + filmtipusId int NOT NULL, + jegyar int NOT NULL, + primary key (id), + key filmtipusId (filmtipusId), + CONSTRAINT FK_film_filmtipusId FOREIGN KEY (filmtipusId) + REFERENCES filmtipus (id) +); + +-- Vetítések +create TABLE vetites +( + id int NOT NULL, + filmId int NOT NULL, + datum date NOT NULL, + kezdes time NOT NULL, + primary key (id), + key filmId (filmId), + CONSTRAINT FK_vetites_filmId FOREIGN KEY (filmId) + REFERENCES film (id) +); + +-- Eladott jegyek +create TABLE jegy +( + id int NOT NULL AUTO_INCREMENT, + kedvezmeny int NOT NULL, + vetitesId int NOT NULL, + vendegId int NOT NULL, + primary key (id), + key vetitesId (vetitesId), + CONSTRAINT FK_jegy_vetitesId FOREIGN KEY (vetitesId) + REFERENCES vetites (id), + key vendegId (vendegId), + CONSTRAINT FK_jegy_vendegId FOREIGN KEY (vendegId) + REFERENCES vendeg (id) +); + + +-- Adatok beszúrása + + +INSERT INTO vendeg (id, nev) +VALUES (1, 'Nagy Bence'), + (2, 'Kovács Máté'), + (3, 'Tóth Levente'), + (4, 'Szabó Dominik'), + (5, 'Horváth Marcell'), + (6, 'Varga Noel'), + (7, 'Kiss Ádám'), + (8, 'Molnár Dániel'), + (9, 'Németh Dávid'), + (10, 'Farkas Olivér'), + (11, 'Balogh Milán'), + (12, 'Papp Zalán'), + (13, 'Lakatos Botond'), + (14, 'Takács Benett'), + (15, 'Juhász Zsombor'), + (16, 'Mészáros Balázs'), + (17, 'Oláh Áron'), + (18, 'Simon Péter'), + (19, 'Rácz Kristóf'), + (20, 'Fekete Tamás'), + (21, 'Szilágyi Márk'), + (22, 'Török Benedek'), + (23, 'Fehér Gergő'), + (24, 'Balázs László'), + (25, 'Gál Nimród'), + (26, 'Kis Bálint'), + (27, 'Szűcs Zétény'), + (28, 'Kocsis Ákos'), + (29, 'Orsós Patrik'), + (30, 'Pintér Zoltán'), + (31, 'Fodor András'), + (32, 'Szalai Attila'), + (33, 'Sipos Hunor'), + (34, 'Magyar Barnabás'), + (35, 'Lukács Márton'), + (36, 'Gulyás Gábor'), + (37, 'Biró Alex'), + (38, 'Király Martin'), + (39, 'László István'), + (40, 'Balog Kornél'), + (41, 'Katona Vince'), + (42, 'Bogdán József'), + (43, 'Jakab János'), + (44, 'Sándor Krisztián'), + (45, 'Boros Zsolt'), + (46, 'Váradi Zente'), + (47, 'Fazekas Sándor'), + (48, 'Kelemen Erik'), + (49, 'Antal Bendegúz'), + (50, 'Orosz Roland'), + (51, 'Somogyi Richárd'), + (52, 'Fülöp Ábel'), + (53, 'Veres Csaba'), + (54, 'Vincze Róbert'), + (55, 'Budai Kevin'), + (56, 'Hegedűs Nolen'), + (57, 'Deák Soma'), + (58, 'Pap Ármin'), + (59, 'Bálint Mihály'), + (60, 'Illés Vencel'), + (61, 'Pál Norbert'), + (62, 'Vass Mátyás'), + (63, 'Szőke Ferenc'), + (64, 'Fábián Tibor'), + (65, 'Vörös Nándor'), + (66, 'Lengyel Benjámin'), + (67, 'Bognár Szabolcs'), + (68, 'Bodnár Benjamin'), + (69, 'Jónás Simon'), + (70, 'Szücs Gergely'), + (71, 'Hajdu Csongor'), + (72, 'Halász Viktor'), + (73, 'Máté Miklós'), + (74, 'Székely Nikolasz'), + (75, 'Kozma Vilmos'), + (76, 'Gáspár Boldizsár'), + (77, 'Pásztor Kende'), + (78, 'Bakos Imre'), + (79, 'Dudás Bertalan'), + (80, 'Major Brendon'), + (81, 'Orbán Zénó'), + (82, 'Virág Adrián'), + (83, 'Hegedüs Dorián'), + (84, 'Barna Krisztofer'), + (85, 'Novák György'), + (86, 'Soós Alexander'), + (87, 'Tamás Lajos'), + (88, 'Nemes Dénes'), + (89, 'Pataki Félix'), + (90, 'Balla Sámuel'), + (91, 'Faragó Denisz'), + (92, 'Kerekes Bende'), + (93, 'Borbély Noé'), + (94, 'Barta Károly'), + (95, 'Péter Donát'), + (96, 'Csonka Gyula'), + (97, 'Mezei Gellért'), + (98, 'Sárközi Mirkó'), + (99, 'Szekeres Vendel'), + (100, 'Márton Brájen'), + (101, 'Nagy Hanna'), + (102, 'Kovács Anna'), + (103, 'Tóth Zoé'), + (104, 'Szabó Luca'), + (105, 'Horváth Léna'), + (106, 'Varga Emma'), + (107, 'Kiss Zsófia'), + (108, 'Molnár Lili'), + (109, 'Németh Boglárka'), + (110, 'Farkas Mira'), + (111, 'Balogh Lilien'), + (112, 'Papp Nóra'), + (113, 'Lakatos Jázmin'), + (114, 'Takács Laura'), + (115, 'Juhász Maja'), + (116, 'Mészáros Sára'), + (117, 'Oláh Lara'), + (118, 'Simon Lilla'), + (119, 'Rácz Izabella'), + (120, 'Fekete Gréta'), + (121, 'Szilágyi Alíz'), + (122, 'Török Fanni'), + (123, 'Fehér Adél'), + (124, 'Balázs Flóra'), + (125, 'Gál Csenge'), + (126, 'Kis Dóra'), + (127, 'Szűcs Dorina'), + (128, 'Kocsis Zselyke'), + (129, 'Orsós Réka'), + (130, 'Pintér Dorka'), + (131, 'Fodor Liza'), + (132, 'Szalai Janka'), + (133, 'Sipos Liliána'), + (134, 'Magyar Olívia'), + (135, 'Lukács Viktória'), + (136, 'Gulyás Eszter'), + (137, 'Biró Natasa'), + (138, 'Király Noémi'), + (139, 'László Petra'), + (140, 'Balog Bianka'), + (141, 'Katona Szofia'), + (142, 'Bogdán Panna'), + (143, 'Jakab Vivien'), + (144, 'Sándor Emília'), + (145, 'Boros Szófia'), + (146, 'Váradi Rebeka'), + (147, 'Fazekas Kamilla'), + (148, 'Kelemen Blanka'); + +INSERT INTO filmtipus (id, nev) +VALUES (1, 'Dokumentumfilm'), + (2, 'Űropera'), + (3, 'Művész'), + (4, 'Képregény'); + +INSERT INTO film (id, cim, filmtipusId, jegyar) +VALUES (1, 'A kozmosz', 1, 1300), + (2, 'A Mars generáció', 1, 1300), + (3, 'Star Wars: Egy új remény', 2, 890), + (4, 'Avatar', 2, 1300), + (5, 'Dűne', 2, 890), + (6, 'Interstellar', 2, 1300), + (7, 'La Jetéé', 3, 890), + (8, 'Solaris',3, 890), + (9, 'A földre pottyant férfi',3,890 ), + (10, '2001: Űrodüsszeia', 3, 990), + (11, 'Az ötödik elem', 4, 690), + (12, 'A galaxis űrzői', 4, 1300), + (13, 'Thor: Ragnarök', 4, 1300); + +INSERT INTO vetites(id, filmId, datum, kezdes) +VALUES(1, 3, '2021.03.01.', '10:00'), + (2, 3, '2021.03.01.', '12:00'), + (3, 3, '2021.03.01.', '16:00'), + (4, 5, '2021.03.01.', '20:00'), + (5, 7, '2021.03.02.', '10:00'), + (6, 1, '2021.03.03.', '10:00'), + (7, 1, '2021.03.03.', '12:00'), + (8, 1, '2021.03.04.', '10:00'), + (9, 3, '2021.03.04.', '12:00'), + (10, 12, '2021.03.05.', '10:00'), + (11, 11, '2021.03.05.', '12:00'), + (12, 12, '2021.03.05.', '16:00'), + (13, 12, '2021.03.05.', '20:00'), + (14, 1, '2021.03.06.', '10:00'), + (15, 1, '2021.03.06.', '12:00'), + (16, 5, '2021.03.06.', '16:00'), + (17, 5, '2021.03.06.', '20:00'), + (18, 6, '2021.03.07.', '10:00'), + (19, 6, '2021.03.07.', '12:00'), + (20, 8, '2021.03.07.', '16:00'), + (21, 1, '2021.03.08.', '10:00'), + (22, 10, '2021.03.09.', '10:00'), + (23, 10, '2021.03.09.', '12:00'), + (24, 10, '2021.03.09.', '16:00'), + (25, 6, '2021.03.09.', '20:00'), + (26, 10, '2021.03.10.', '10:00'), + (27, 10, '2021.03.10.', '12:00'), + (28, 10, '2021.03.10.', '16:00'), + (29, 10, '2021.03.10.', '20:00'), + (30, 11, '2021.03.11.', '10:00'), + (31, 11, '2021.03.11.', '12:00'), + (32, 3, '2021.03.12.', '10:00'), + (33, 3, '2021.03.12.', '12:00'), + (34, 3, '2021.03.12.', '16:00'), + (35, 6, '2021.03.12.', '20:00'), + (36, 13, '2021.03.13.', '10:00'), + (37, 9, '2021.03.13.', '12:00'), + (38, 13, '2021.03.13.', '16:00'), + (39, 4, '2021.03.14.', '10:00'), + (40, 4, '2021.03.14.', '12:00'), + (41, 4, '2021.03.14.', '16:00'), + (42, 13, '2021.03.15.', '10:00'), + (43, 13, '2021.03.15.', '12:00'), + (44, 11, '2021.03.15.', '16:00'), + (45, 4, '2021.03.16.', '10:00'), + (46, 13, '2021.03.16.', '12:00'), + (47, 13, '2021.03.16.', '16:00'), + (48, 4, '2021.03.16.', '20:00'), + (49, 3, '2021.03.17.', '10:00'), + (50, 7, '2021.03.18.', '10:00'), + (51, 4, '2021.03.18.', '12:00'), + (52, 4, '2021.03.18.', '16:00'), + (53, 8, '2021.03.19.', '10:00'), + (54, 4, '2021.03.20.', '10:00'), + (55, 6, '2021.03.20.', '12:00'), + (56, 10, '2021.03.21.', '10:00'), + (57, 10, '2021.03.21.', '12:00'), + (58, 4, '2021.03.22.', '10:00'), + (59, 2, '2021.03.22.', '12:00'), + (60, 2, '2021.03.22.', '16:00'), + (61, 2, '2021.03.23.', '10:00'), + (62, 2, '2021.03.23.', '12:00'), + (63, 8, '2021.03.24.', '10:00'), + (64, 6, '2021.03.24.', '12:00'), + (65, 8, '2021.03.24.', '16:00'), + (66, 6, '2021.03.25.', '10:00'), + (67, 5, '2021.03.25.', '12:00'), + (68, 5, '2021.03.25.', '16:00'), + (69, 12, '2021.03.26.', '10:00'), + (70, 8, '2021.03.27.', '10:00'), + (71, 10, '2021.03.27.', '12:00'), + (72, 10, '2021.03.27.', '16:00'), + (73, 3, '2021.03.28.', '10:00'), + (74, 3, '2021.03.28.', '12:00'), + (75, 8, '2021.03.28.', '16:00'), + (76, 8, '2021.03.28.', '20:00'), + (77, 11, '2021.03.29.', '10:00'), + (78, 11, '2021.03.29.', '12:00'), + (79, 11, '2021.03.29.', '16:00'), + (80, 11, '2021.03.29.', '20:00'), + (81, 10, '2021.03.30.', '10:00'), + (82, 11, '2021.03.31.', '10:00'), + (83, 8, '2021.03.31.', '12:00'), + (84, 8, '2021.03.31.', '16:00'), + (85, 8, '2021.03.31.', '20:00'); + +INSERT INTO jegy(id, kedvezmeny, vetitesId, vendegId) +VALUES (1, 0, 1, 86), + (2, 0, 1, 5), + (3, 0, 1, 118), + (4, 0, 1, 14), + (5, 50, 1, 26), + (6, 0, 1, 84), + (7, 50, 1, 147), + (8, 25, 1, 44), + (9, 0, 1, 69), + (10, 50, 1, 147), + (11, 50, 1, 31), + (12, 0, 1, 118), + (13, 0, 1, 99), + (14, 0, 1, 113), + (15, 25, 1, 94), + (16, 50, 1, 94), + (17, 0, 1, 88), + (18, 50, 1, 85), + (19, 25, 1, 55), + (20, 50, 1, 36), + (21, 0, 1, 141), + (22, 0, 1, 124), + (23, 0, 1, 96), + (24, 25, 1, 95), + (25, 25, 2, 30), + (26, 0, 2, 49), + (27, 0, 2, 139), + (28, 50, 2, 13), + (29, 50, 2, 52), + (30, 0, 2, 119), + (31, 25, 2, 125), + (32, 0, 2, 100), + (33, 25, 2, 86), + (34, 50, 2, 58), + (35, 50, 2, 1), + (37, 25, 2, 79), + (38, 25, 2, 124), + (39, 0, 2, 88), + (40, 50, 2, 102), + (41, 0, 2, 109), + (42, 0, 2, 98), + (43, 0, 3, 143), + (44, 25, 3, 10), + (45, 0, 3, 101), + (46, 50, 3, 14), + (47, 0, 3, 114), + (48, 0, 3, 137), + (49, 0, 3, 7), + (50, 0, 3, 35), + (51, 0, 3, 92), + (52, 50, 3, 58), + (53, 50, 3, 72), + (54, 0, 3, 8), + (55, 0, 3, 30), + (56, 0, 3, 122), + (57, 50, 3, 110), + (58, 0, 3, 125), + (59, 0, 3, 60), + (60, 0, 3, 146), + (61, 0, 3, 72), + (62, 0, 3, 88), + (63, 0, 3, 56), + (64, 0, 4, 61), + (65, 0, 4, 61), + (66, 0, 4, 29), + (67, 50, 4, 34), + (68, 25, 4, 123), + (69, 0, 4, 145), + (70, 0, 4, 87), + (71, 0, 4, 131), + (72, 50, 4, 76), + (73, 0, 4, 96), + (74, 0, 4, 35), + (75, 0, 4, 120), + (76, 0, 4, 50), + (77, 0, 4, 114), + (78, 0, 4, 40), + (79, 25, 4, 35), + (80, 25, 4, 94), + (81, 25, 4, 79), + (82, 25, 5, 146), + (83, 0, 5, 136), + (84, 0, 5, 41), + (85, 0, 5, 91), + (86, 50, 5, 137), + (87, 0, 5, 87), + (88, 0, 5, 56), + (89, 50, 5, 98), + (90, 0, 5, 71), + (91, 0, 5, 126), + (92, 50, 5, 50), + (93, 50, 5, 64), + (94, 0, 5, 127), + (95, 0, 5, 112), + (96, 0, 5, 88), + (97, 0, 5, 1), + (98, 0, 5, 80), + (99, 50, 5, 67), + (100, 0, 5, 106), + (101, 50, 6, 75), + (102, 0, 6, 31), + (103, 0, 6, 58), + (104, 0, 6, 126), + (105, 0, 6, 114), + (106, 0, 6, 20), + (107, 50, 6, 69), + (108, 50, 6, 1), + (109, 0, 6, 59), + (110, 50, 6, 147), + (111, 0, 6, 24), + (112, 50, 6, 45), + (113, 0, 6, 120), + (114, 0, 6, 31), + (115, 0, 6, 148), + (116, 0, 6, 148), + (117, 50, 6, 35), + (118, 0, 6, 10), + (119, 0, 6, 104), + (120, 0, 6, 54), + (121, 0, 6, 33), + (122, 50, 6, 73), + (123, 50, 6, 79), + (124, 50, 6, 140), + (125, 0, 6, 142), + (126, 50, 6, 1), + (127, 50, 6, 77), + (128, 50, 6, 99), + (129, 0, 6, 24), + (130, 25, 6, 123), + (131, 50, 6, 82), + (132, 25, 6, 132), + (133, 0, 6, 121), + (134, 0, 6, 29), + (135, 0, 6, 128), + (136, 50, 6, 102), + (137, 0, 6, 139), + (138, 0, 6, 52), + (139, 0, 6, 131), + (140, 0, 6, 110), + (141, 50, 6, 91), + (142, 0, 6, 53), + (143, 0, 7, 95), + (144, 0, 7, 145), + (145, 0, 7, 85), + (146, 50, 7, 122), + (147, 0, 7, 108), + (148, 50, 7, 48), + (149, 0, 7, 23), + (150, 50, 7, 41), + (151, 0, 7, 32), + (152, 0, 7, 90), + (153, 50, 7, 96), + (154, 0, 7, 58), + (155, 0, 7, 12), + (156, 50, 7, 98), + (157, 50, 7, 103), + (158, 0, 7, 18), + (159, 50, 7, 25), + (160, 25, 7, 148), + (161, 50, 7, 8), + (162, 0, 7, 31), + (163, 0, 7, 71), + (164, 0, 7, 93), + (165, 0, 7, 117), + (166, 0, 7, 122), + (167, 0, 7, 1), + (168, 25, 7, 20), + (169, 0, 7, 58), + (170, 50, 7, 30), + (171, 0, 8, 5), + (172, 0, 8, 69), + (173, 0, 8, 32), + (174, 0, 8, 106), + (175, 0, 8, 30), + (176, 0, 8, 103), + (177, 0, 8, 85), + (178, 50, 8, 68), + (179, 0, 8, 96), + (180, 0, 8, 23), + (181, 50, 8, 58), + (182, 25, 8, 34), + (183, 50, 8, 74), + (184, 0, 8, 1), + (185, 0, 8, 20), + (186, 0, 8, 108), + (187, 0, 8, 23), + (188, 0, 8, 48), + (189, 0, 8, 80), + (190, 0, 8, 96), + (191, 50, 8, 97), + (192, 0, 8, 124), + (193, 50, 8, 91), + (194, 0, 8, 59), + (195, 0, 8, 49), + (196, 0, 8, 141), + (197, 0, 8, 73), + (198, 50, 8, 139), + (199, 0, 8, 63), + (200, 0, 9, 135), + (201, 0, 9, 132), + (202, 50, 9, 105), + (203, 50, 9, 71), + (204, 50, 9, 96), + (205, 25, 9, 53), + (206, 0, 9, 116), + (207, 25, 9, 53), + (208, 0, 9, 114), + (209, 50, 9, 87), + (210, 50, 9, 126), + (211, 0, 9, 52), + (212, 0, 9, 97), + (213, 0, 9, 71), + (214, 0, 9, 77), + (215, 50, 9, 90), + (216, 0, 9, 24), + (217, 0, 9, 4), + (218, 0, 9, 114), + (219, 0, 9, 135), + (220, 50, 9, 123), + (221, 0, 9, 83), + (222, 50, 9, 73), + (223, 0, 9, 50), + (224, 0, 10, 85), + (225, 0, 10, 111), + (226, 0, 10, 116), + (227, 0, 10, 97), + (228, 0, 10, 97), + (229, 0, 10, 140), + (230, 0, 10, 75), + (231, 50, 10, 25), + (232, 0, 10, 138), + (233, 0, 10, 13), + (234, 0, 10, 131), + (235, 50, 10, 87), + (236, 0, 10, 56), + (237, 25, 10, 107), + (238, 0, 10, 51), + (239, 0, 10, 1), + (240, 50, 11, 36), + (241, 0, 11, 131), + (242, 0, 11, 113), + (243, 0, 11, 116), + (244, 0, 11, 132), + (245, 0, 11, 23), + (246, 0, 11, 2), + (247, 0, 11, 89), + (248, 50, 11, 58), + (249, 50, 11, 95), + (250, 50, 11, 55), + (251, 50, 11, 71), + (252, 0, 11, 53), + (253, 50, 11, 71), + (254, 50, 11, 4), + (255, 0, 11, 33), + (256, 25, 11, 113), + (257, 50, 11, 1), + (258, 0, 11, 120), + (259, 50, 11, 137), + (260, 50, 11, 31), + (261, 0, 11, 131), + (262, 25, 11, 24), + (263, 0, 11, 64), + (264, 50, 11, 130), + (265, 0, 12, 61), + (266, 50, 12, 83), + (267, 50, 12, 105), + (268, 0, 12, 26), + (269, 50, 12, 140), + (270, 0, 12, 57), + (271, 0, 12, 43), + (272, 50, 12, 36), + (273, 0, 12, 70), + (274, 0, 12, 120), + (275, 0, 12, 77), + (276, 50, 12, 121), + (277, 50, 12, 114), + (278, 50, 12, 31), + (279, 50, 12, 7), + (280, 0, 12, 98), + (281, 50, 12, 32), + (282, 25, 12, 113), + (283, 0, 12, 49), + (284, 25, 12, 81), + (285, 25, 12, 105), + (286, 50, 13, 55), + (287, 0, 13, 82), + (288, 0, 13, 44), + (289, 50, 13, 40), + (290, 50, 13, 118), + (291, 0, 13, 69), + (292, 50, 13, 52), + (293, 25, 13, 86), + (294, 50, 13, 131), + (295, 0, 13, 10), + (296, 50, 13, 115), + (297, 0, 13, 58), + (298, 0, 13, 19), + (299, 0, 13, 99), + (300, 50, 14, 37), + (301, 0, 14, 67), + (302, 25, 14, 108), + (303, 50, 14, 64), + (304, 0, 14, 143), + (305, 0, 14, 82), + (306, 50, 14, 104), + (307, 25, 14, 44), + (308, 0, 14, 18), + (309, 0, 14, 119), + (310, 0, 14, 107), + (311, 50, 14, 5), + (312, 0, 14, 129), + (313, 0, 14, 58), + (314, 0, 14, 106), + (315, 0, 14, 110), + (316, 50, 14, 17), + (317, 0, 14, 106), + (318, 25, 14, 52), + (319, 50, 14, 29), + (320, 0, 14, 59), + (321, 0, 14, 113), + (322, 50, 14, 60), + (323, 0, 14, 21), + (324, 0, 14, 137), + (325, 0, 15, 110), + (326, 0, 15, 57), + (327, 0, 15, 28), + (328, 0, 15, 131), + (329, 0, 15, 20), + (330, 50, 15, 49), + (331, 0, 15, 42), + (332, 0, 15, 70), + (333, 0, 15, 106), + (334, 0, 15, 2), + (335, 25, 15, 125), + (336, 0, 15, 131), + (337, 0, 15, 109), + (338, 50, 15, 109), + (339, 0, 15, 119), + (340, 50, 15, 108), + (341, 0, 15, 70), + (342, 0, 15, 15), + (343, 0, 15, 80), + (344, 50, 15, 116), + (345, 50, 15, 135), + (346, 50, 15, 31), + (347, 0, 15, 67), + (348, 0, 15, 17), + (349, 0, 15, 19), + (350, 50, 15, 96), + (351, 50, 15, 129), + (352, 0, 15, 12), + (353, 0, 15, 74), + (354, 0, 15, 100), + (355, 25, 15, 41), + (356, 0, 15, 45), + (357, 50, 15, 84), + (358, 25, 15, 53), + (359, 0, 15, 51), + (360, 0, 16, 6), + (361, 0, 16, 29), + (362, 50, 16, 7), + (363, 0, 16, 87), + (364, 50, 16, 134), + (365, 0, 16, 22), + (366, 0, 16, 55), + (367, 0, 16, 144), + (368, 0, 16, 11), + (369, 0, 16, 41), + (370, 25, 16, 84), + (371, 50, 16, 7), + (372, 50, 16, 127), + (373, 25, 16, 81), + (374, 25, 16, 9), + (375, 50, 16, 5), + (376, 0, 16, 52), + (377, 0, 16, 32), + (378, 0, 16, 33), + (379, 0, 16, 134), + (380, 0, 16, 6), + (381, 0, 16, 114), + (382, 0, 16, 104), + (383, 0, 16, 83), + (384, 0, 16, 72), + (385, 0, 16, 11), + (386, 50, 16, 125), + (387, 0, 16, 73), + (388, 50, 16, 47), + (389, 0, 16, 51), + (390, 50, 16, 147), + (391, 50, 17, 63), + (392, 0, 17, 22), + (393, 50, 17, 51), + (394, 0, 17, 140), + (395, 0, 17, 31), + (396, 50, 17, 121), + (397, 0, 17, 127), + (398, 0, 17, 102), + (399, 0, 17, 96), + (400, 0, 17, 53), + (401, 0, 17, 109), + (402, 0, 17, 125), + (403, 0, 17, 82), + (404, 25, 17, 76), + (405, 0, 17, 1), + (406, 50, 17, 124), + (407, 0, 17, 81), + (408, 0, 17, 142), + (409, 25, 17, 116), + (410, 0, 17, 94), + (411, 50, 17, 5), + (412, 0, 17, 34), + (413, 25, 17, 111), + (414, 50, 17, 20), + (415, 0, 17, 84), + (416, 0, 17, 20), + (417, 0, 17, 25), + (418, 0, 17, 49), + (419, 0, 17, 65), + (420, 0, 17, 135), + (421, 25, 17, 33), + (422, 0, 17, 56), + (423, 50, 17, 132), + (424, 0, 17, 138), + (425, 0, 17, 48), + (426, 0, 17, 104), + (427, 0, 17, 120), + (428, 50, 17, 127), + (429, 0, 18, 91), + (430, 0, 18, 42), + (431, 50, 18, 135), + (432, 0, 18, 77), + (433, 0, 18, 99), + (434, 50, 18, 19), + (435, 0, 18, 56), + (436, 25, 18, 83), + (437, 0, 18, 8), + (438, 50, 18, 109), + (439, 0, 18, 14), + (440, 25, 18, 105), + (441, 25, 18, 79), + (442, 50, 18, 111), + (443, 0, 18, 3), + (444, 0, 18, 132), + (445, 50, 18, 2), + (446, 0, 18, 80), + (447, 0, 18, 95), + (448, 0, 18, 57), + (449, 0, 18, 38), + (450, 0, 18, 102), + (451, 0, 18, 120), + (452, 0, 18, 133), + (453, 50, 18, 66), + (454, 0, 18, 98), + (455, 0, 18, 6), + (456, 0, 18, 118), + (457, 0, 19, 38), + (458, 50, 19, 22), + (459, 0, 19, 144), + (460, 0, 19, 29), + (461, 25, 19, 47), + (462, 50, 19, 51), + (463, 25, 19, 9), + (464, 50, 19, 20), + (465, 50, 19, 67), + (466, 50, 19, 5), + (467, 0, 19, 80), + (468, 0, 19, 51), + (469, 50, 19, 121), + (470, 0, 19, 136), + (471, 50, 19, 112), + (472, 0, 20, 29), + (473, 0, 20, 94), + (474, 0, 20, 136), + (475, 0, 20, 141), + (476, 0, 20, 42), + (477, 0, 20, 45), + (478, 50, 20, 118), + (479, 0, 20, 128), + (480, 0, 20, 99), + (481, 25, 20, 144), + (482, 0, 20, 67), + (483, 0, 20, 47), + (484, 50, 20, 66), + (485, 0, 20, 47), + (486, 0, 20, 99), + (487, 25, 20, 97), + (488, 50, 20, 12), + (489, 0, 20, 34), + (490, 50, 20, 140), + (491, 0, 20, 113), + (492, 0, 20, 86), + (493, 50, 20, 116), + (494, 50, 20, 34), + (495, 0, 20, 64), + (496, 0, 20, 146), + (497, 0, 20, 130), + (498, 0, 20, 91), + (499, 50, 20, 133), + (500, 0, 20, 12), + (501, 50, 20, 103), + (502, 0, 20, 90), + (503, 0, 20, 66), + (504, 0, 20, 23), + (505, 25, 20, 19), + (506, 50, 20, 119), + (507, 0, 20, 116), + (508, 0, 20, 62), + (509, 0, 20, 24), + (510, 0, 21, 51), + (511, 25, 21, 119), + (512, 0, 21, 40), + (513, 50, 21, 46), + (514, 0, 21, 46), + (515, 0, 21, 97), + (516, 0, 21, 122), + (517, 0, 21, 55), + (518, 0, 21, 145), + (519, 0, 21, 99), + (520, 25, 21, 27), + (521, 0, 21, 78), + (522, 25, 21, 114), + (523, 0, 21, 132), + (524, 50, 21, 37), + (525, 0, 21, 47), + (526, 50, 21, 59), + (527, 0, 21, 15), + (528, 50, 21, 112), + (529, 0, 22, 47), + (530, 0, 22, 113), + (531, 25, 22, 88), + (532, 50, 22, 116), + (533, 0, 22, 129), + (534, 50, 22, 117), + (535, 0, 22, 101), + (536, 0, 22, 16), + (537, 0, 22, 117), + (538, 0, 22, 3), + (539, 0, 22, 101), + (540, 0, 22, 118), + (541, 50, 22, 42), + (542, 0, 22, 31), + (543, 0, 22, 79), + (544, 50, 22, 73), + (545, 0, 22, 127), + (546, 0, 22, 85), + (547, 50, 22, 121), + (548, 0, 22, 72), + (549, 50, 22, 34), + (550, 0, 22, 106), + (551, 0, 22, 122), + (552, 0, 22, 99), + (553, 0, 22, 4), + (554, 0, 22, 144), + (555, 50, 22, 49), + (556, 25, 22, 72), + (557, 0, 22, 45), + (558, 0, 22, 122), + (559, 0, 22, 71), + (560, 0, 22, 29), + (561, 0, 22, 143), + (562, 0, 22, 86), + (563, 0, 22, 18), + (564, 0, 23, 16), + (565, 0, 23, 86), + (566, 50, 23, 60), + (567, 0, 23, 47), + (568, 0, 23, 81), + (569, 0, 23, 61), + (570, 25, 23, 84), + (571, 0, 23, 126), + (572, 0, 23, 130), + (573, 0, 23, 78), + (574, 50, 23, 18), + (575, 50, 23, 132), + (576, 25, 23, 44), + (577, 50, 23, 120), + (578, 50, 23, 145), + (579, 0, 23, 116), + (580, 25, 23, 44), + (581, 0, 23, 87), + (582, 0, 23, 55), + (583, 50, 23, 125), + (584, 0, 23, 18), + (585, 25, 23, 97), + (586, 25, 23, 63), + (587, 0, 23, 122), + (588, 50, 23, 102), + (589, 0, 23, 141), + (590, 50, 23, 106), + (591, 0, 23, 67), + (592, 0, 23, 24), + (593, 50, 23, 128), + (594, 50, 23, 54), + (595, 50, 23, 78), + (596, 50, 23, 145), + (597, 0, 23, 61), + (598, 50, 23, 127), + (599, 0, 23, 106), + (600, 0, 24, 147), + (601, 0, 24, 105), + (602, 50, 24, 49), + (603, 50, 24, 126), + (604, 0, 24, 13), + (605, 50, 24, 139), + (606, 50, 24, 38), + (607, 0, 24, 98), + (608, 50, 24, 61), + (609, 50, 24, 146), + (610, 0, 24, 14), + (611, 0, 24, 39), + (612, 50, 24, 11), + (613, 25, 24, 77), + (614, 50, 24, 30), + (615, 0, 24, 95), + (616, 0, 24, 98), + (617, 0, 24, 88), + (618, 0, 24, 94), + (619, 0, 24, 2), + (620, 50, 24, 127), + (621, 50, 24, 63), + (622, 0, 24, 68), + (623, 25, 24, 12), + (624, 0, 24, 78), + (625, 0, 24, 66), + (626, 0, 24, 67), + (627, 0, 24, 44), + (628, 0, 24, 35), + (629, 0, 24, 72), + (630, 0, 24, 87), + (631, 0, 25, 3), + (632, 0, 25, 96), + (633, 50, 25, 44), + (634, 0, 25, 51), + (635, 0, 25, 73), + (636, 0, 25, 85), + (637, 0, 25, 138), + (638, 50, 25, 49), + (639, 0, 25, 101), + (640, 0, 25, 50), + (641, 50, 25, 62), + (642, 0, 25, 102), + (643, 50, 25, 115), + (644, 0, 25, 110), + (645, 0, 25, 118), + (646, 50, 25, 8), + (647, 0, 25, 95), + (648, 0, 25, 87), + (649, 0, 25, 141), + (650, 25, 25, 103), + (651, 0, 26, 26), + (652, 0, 26, 24), + (653, 50, 26, 138), + (654, 0, 26, 1), + (655, 0, 26, 119), + (656, 50, 26, 52), + (657, 0, 26, 26), + (658, 50, 26, 47), + (659, 50, 26, 59), + (660, 50, 26, 1), + (661, 50, 26, 135), + (662, 0, 26, 80), + (663, 25, 26, 45), + (664, 0, 26, 29), + (665, 50, 26, 82), + (666, 0, 26, 118), + (667, 0, 26, 41), + (668, 0, 26, 48), + (669, 50, 26, 73), + (670, 0, 26, 64), + (671, 0, 26, 68), + (672, 0, 26, 18), + (673, 0, 26, 17), + (674, 25, 26, 95), + (675, 50, 26, 105), + (676, 0, 27, 136), + (677, 25, 27, 72), + (678, 0, 27, 138), + (679, 0, 27, 15), + (680, 0, 27, 43), + (681, 50, 27, 112), + (682, 50, 27, 20), + (683, 0, 27, 86), + (684, 0, 27, 61), + (685, 50, 27, 3), + (686, 0, 27, 81), + (687, 25, 27, 47), + (688, 0, 27, 144), + (689, 50, 27, 40), + (690, 0, 27, 112), + (691, 0, 27, 25), + (692, 25, 27, 26), + (693, 0, 27, 57), + (694, 0, 27, 57), + (695, 50, 27, 126), + (696, 0, 27, 45), + (697, 0, 27, 97), + (698, 0, 27, 18), + (699, 50, 27, 89), + (700, 0, 27, 139), + (701, 50, 27, 108), + (702, 50, 27, 36), + (703, 50, 27, 84), + (704, 0, 27, 119), + (705, 0, 27, 7), + (706, 50, 27, 92), + (707, 25, 27, 44), + (708, 0, 27, 33), + (709, 50, 27, 22), + (710, 50, 27, 29), + (711, 0, 27, 32), + (712, 25, 27, 54), + (713, 50, 27, 9), + (714, 0, 27, 127), + (715, 0, 27, 22), + (716, 50, 27, 143), + (717, 0, 27, 42), + (718, 25, 27, 84), + (719, 25, 27, 61), + (720, 0, 27, 26), + (721, 0, 28, 14), + (722, 50, 28, 71), + (723, 25, 28, 19), + (724, 0, 28, 68), + (725, 50, 28, 42), + (726, 50, 28, 18), + (727, 25, 28, 67), + (728, 0, 28, 32), + (729, 50, 28, 105), + (730, 50, 28, 33), + (731, 0, 28, 90), + (732, 25, 28, 43), + (733, 0, 28, 94), + (734, 50, 28, 51), + (735, 0, 28, 5), + (736, 50, 28, 36), + (737, 0, 28, 87), + (738, 0, 28, 5), + (739, 50, 28, 100), + (740, 0, 28, 124), + (741, 50, 28, 118), + (742, 50, 28, 31), + (743, 0, 28, 49), + (744, 0, 28, 1), + (745, 0, 29, 144), + (746, 0, 29, 100), + (747, 0, 29, 89), + (748, 0, 29, 58), + (749, 0, 29, 83), + (750, 0, 29, 70), + (751, 0, 29, 97), + (752, 0, 29, 133), + (753, 0, 29, 71), + (754, 0, 29, 141), + (755, 50, 29, 22), + (756, 25, 29, 30), + (757, 25, 29, 31), + (758, 50, 29, 134), + (759, 0, 29, 10), + (760, 0, 29, 56), + (761, 0, 29, 73), + (762, 50, 29, 18), + (763, 0, 29, 27), + (764, 50, 29, 145), + (765, 0, 29, 21), + (766, 0, 29, 99), + (767, 50, 29, 23), + (768, 0, 29, 144), + (769, 50, 29, 47), + (770, 0, 29, 34), + (771, 50, 29, 117), + (772, 0, 29, 8), + (773, 0, 29, 145), + (774, 0, 29, 100), + (775, 0, 29, 15), + (776, 25, 29, 54), + (777, 50, 29, 87), + (778, 0, 29, 69), + (779, 50, 29, 119), + (780, 50, 30, 112), + (781, 0, 30, 68), + (782, 0, 30, 98), + (783, 0, 30, 75), + (784, 0, 30, 4), + (785, 50, 30, 95), + (786, 50, 30, 102), + (787, 0, 30, 146), + (788, 0, 30, 48), + (789, 0, 30, 108), + (790, 0, 30, 91), + (791, 50, 30, 63), + (792, 0, 30, 120), + (793, 0, 30, 15), + (794, 0, 30, 106), + (795, 0, 30, 83), + (796, 50, 30, 53), + (797, 0, 30, 121), + (798, 50, 30, 63), + (799, 0, 30, 65), + (800, 0, 30, 62), + (801, 50, 30, 32), + (802, 0, 30, 17), + (803, 0, 30, 148), + (804, 0, 30, 134), + (805, 50, 30, 61), + (806, 0, 30, 4), + (807, 50, 30, 80), + (808, 50, 30, 121), + (809, 50, 31, 41), + (810, 50, 31, 20), + (811, 0, 31, 5), + (812, 0, 31, 124), + (813, 50, 31, 75), + (814, 50, 31, 80), + (815, 0, 31, 30), + (816, 50, 31, 34), + (817, 25, 31, 14), + (818, 50, 31, 48), + (819, 0, 31, 96), + (820, 50, 31, 107), + (821, 0, 31, 77), + (822, 0, 31, 72), + (823, 0, 31, 104), + (824, 0, 31, 128), + (825, 50, 31, 121), + (826, 0, 31, 141), + (827, 0, 31, 124), + (828, 25, 31, 2), + (829, 25, 31, 6), + (830, 25, 31, 25), + (831, 0, 31, 90), + (832, 25, 31, 127), + (833, 0, 31, 4), + (834, 0, 31, 87), + (835, 0, 31, 34), + (836, 0, 31, 19), + (837, 0, 31, 46), + (838, 0, 31, 47), + (839, 25, 31, 81), + (840, 0, 31, 115), + (841, 0, 31, 55), + (842, 0, 31, 38), + (843, 0, 31, 87), + (844, 0, 31, 74), + (845, 0, 31, 19), + (846, 0, 31, 117), + (847, 0, 31, 22), + (848, 25, 31, 32), + (849, 0, 31, 71), + (850, 0, 31, 76), + (851, 50, 31, 16), + (852, 50, 31, 102), + (853, 0, 31, 31), + (854, 50, 31, 137), + (855, 25, 31, 60), + (856, 0, 31, 128), + (857, 0, 32, 110), + (858, 25, 32, 93), + (859, 50, 32, 65), + (860, 0, 32, 13), + (861, 25, 32, 24), + (862, 25, 32, 7), + (863, 0, 32, 25), + (864, 50, 32, 72), + (865, 25, 32, 91), + (866, 50, 32, 1), + (867, 25, 32, 138), + (868, 25, 33, 116), + (869, 0, 33, 4), + (870, 0, 33, 113), + (871, 0, 33, 12), + (872, 50, 33, 86), + (873, 0, 33, 88), + (874, 0, 33, 135), + (875, 0, 33, 18), + (876, 25, 33, 24), + (877, 0, 33, 120), + (878, 0, 33, 76), + (879, 50, 33, 109), + (880, 50, 33, 89), + (881, 25, 33, 82), + (882, 0, 33, 117), + (883, 0, 33, 55), + (884, 50, 33, 14), + (885, 50, 33, 89), + (886, 0, 33, 123), + (887, 0, 33, 60), + (888, 0, 33, 18), + (889, 0, 33, 130), + (890, 50, 33, 106), + (891, 0, 33, 72), + (892, 50, 33, 118), + (893, 0, 33, 58), + (894, 50, 33, 74), + (895, 0, 33, 3), + (896, 0, 33, 49), + (897, 0, 33, 91), + (898, 0, 33, 30), + (899, 0, 33, 116), + (900, 0, 33, 44), + (901, 0, 33, 71), + (902, 25, 33, 87), + (903, 50, 33, 91), + (904, 50, 33, 136), + (905, 50, 33, 145), + (906, 50, 33, 60), + (907, 0, 33, 124), + (908, 25, 33, 58), + (909, 0, 33, 66), + (910, 0, 33, 88), + (911, 0, 34, 4), + (912, 0, 34, 102), + (913, 50, 34, 103), + (914, 50, 34, 124), + (915, 25, 34, 110), + (916, 50, 34, 43), + (917, 0, 34, 35), + (918, 0, 34, 72), + (919, 50, 34, 146), + (920, 0, 34, 64), + (921, 50, 34, 64), + (922, 25, 34, 5), + (923, 0, 34, 113), + (924, 0, 34, 45), + (925, 25, 34, 12), + (926, 0, 34, 3), + (927, 0, 34, 126), + (928, 0, 34, 75), + (929, 0, 34, 55), + (930, 0, 34, 124), + (931, 0, 34, 133), + (932, 0, 34, 135), + (933, 0, 34, 21), + (934, 50, 34, 109), + (935, 0, 34, 36), + (936, 0, 34, 110), + (937, 25, 34, 63), + (938, 0, 34, 40), + (939, 50, 34, 41), + (940, 0, 34, 32), + (941, 50, 35, 141), + (942, 50, 35, 115), + (943, 0, 35, 129), + (944, 0, 35, 80), + (945, 0, 35, 70), + (946, 0, 35, 62), + (947, 0, 35, 56), + (948, 0, 35, 104), + (949, 0, 35, 3), + (950, 0, 35, 91), + (951, 25, 35, 51), + (952, 0, 35, 146), + (953, 50, 35, 31), + (954, 0, 35, 3), + (955, 0, 35, 96), + (956, 0, 35, 23), + (957, 50, 35, 58), + (958, 0, 35, 134), + (959, 0, 35, 9), + (960, 25, 35, 88), + (961, 25, 35, 100), + (962, 0, 35, 32), + (963, 0, 35, 131), + (964, 0, 35, 144), + (965, 50, 35, 112), + (966, 25, 35, 20), + (967, 0, 35, 142), + (968, 50, 35, 69), + (969, 0, 35, 18), + (970, 50, 35, 93), + (971, 50, 35, 53), + (972, 0, 35, 59), + (973, 25, 35, 30), + (974, 50, 35, 69), + (975, 0, 35, 77), + (976, 0, 35, 109), + (977, 0, 35, 134), + (978, 50, 35, 14), + (979, 50, 35, 99), + (980, 0, 35, 124), + (981, 0, 35, 83), + (982, 25, 35, 68), + (983, 50, 35, 109), + (984, 25, 35, 98), + (985, 0, 36, 64), + (986, 0, 36, 65), + (987, 0, 36, 144), + (988, 0, 36, 17), + (989, 0, 36, 79), + (990, 50, 36, 123), + (991, 50, 36, 116), + (992, 0, 36, 62), + (993, 0, 36, 114), + (994, 0, 36, 39), + (995, 0, 36, 34), + (996, 0, 36, 3), + (997, 0, 36, 80), + (998, 0, 36, 85), + (999, 0, 36, 74), + (1000, 0, 36, 114), + (1001, 50, 37, 34), + (1002, 50, 37, 95), + (1003, 25, 37, 34), + (1004, 0, 37, 28), + (1005, 0, 37, 52), + (1006, 0, 37, 43), + (1007, 0, 37, 46), + (1008, 50, 37, 59), + (1009, 25, 37, 51), + (1010, 0, 37, 135), + (1011, 0, 37, 124), + (1012, 0, 37, 96), + (1013, 25, 37, 98), + (1014, 25, 37, 103), + (1015, 0, 37, 139), + (1016, 0, 37, 85), + (1017, 50, 37, 57), + (1018, 0, 37, 95), + (1019, 0, 37, 93), + (1020, 0, 37, 69), + (1021, 0, 37, 30), + (1022, 0, 37, 125), + (1023, 25, 37, 59), + (1024, 0, 37, 37), + (1025, 0, 38, 44), + (1026, 0, 38, 36), + (1027, 50, 38, 132), + (1028, 25, 38, 44), + (1029, 25, 38, 120), + (1030, 50, 38, 78), + (1031, 50, 38, 108), + (1032, 0, 38, 2), + (1033, 25, 38, 103), + (1034, 0, 38, 91), + (1035, 0, 38, 135), + (1036, 0, 38, 130), + (1037, 0, 38, 130), + (1038, 0, 39, 42), + (1039, 0, 39, 72), + (1040, 50, 39, 101), + (1041, 0, 39, 45), + (1042, 0, 39, 142), + (1043, 25, 39, 17), + (1044, 0, 39, 131), + (1045, 50, 39, 113), + (1046, 0, 39, 121), + (1047, 25, 39, 106), + (1048, 0, 39, 18), + (1049, 50, 39, 127), + (1050, 0, 39, 3), + (1051, 50, 39, 12), + (1052, 0, 40, 42), + (1053, 0, 40, 91), + (1054, 0, 40, 63), + (1055, 50, 40, 59), + (1056, 0, 40, 66), + (1057, 50, 40, 67), + (1058, 50, 40, 51), + (1059, 50, 40, 41), + (1060, 0, 40, 87), + (1061, 0, 40, 98), + (1062, 50, 40, 56), + (1063, 0, 40, 9), + (1064, 50, 40, 114), + (1065, 0, 40, 95), + (1066, 0, 40, 48), + (1067, 0, 40, 70), + (1068, 0, 40, 81), + (1069, 50, 41, 103), + (1070, 50, 41, 68), + (1071, 0, 41, 78), + (1072, 0, 41, 112), + (1073, 0, 41, 132), + (1074, 25, 41, 142), + (1075, 50, 41, 84), + (1076, 25, 41, 147), + (1077, 0, 41, 33), + (1078, 50, 41, 70), + (1079, 50, 41, 136), + (1080, 25, 41, 68), + (1081, 50, 41, 28), + (1082, 50, 41, 110), + (1083, 0, 41, 135), + (1084, 0, 41, 28), + (1085, 50, 42, 25), + (1086, 0, 42, 103), + (1087, 0, 42, 112), + (1088, 50, 42, 136), + (1089, 25, 42, 35), + (1090, 0, 42, 97), + (1091, 50, 42, 12), + (1092, 50, 42, 119), + (1093, 0, 42, 137), + (1094, 0, 42, 143), + (1095, 0, 42, 132), + (1096, 0, 42, 137), + (1097, 0, 42, 139), + (1098, 50, 42, 72), + (1099, 50, 42, 47), + (1100, 0, 42, 76), + (1101, 0, 42, 60), + (1102, 0, 43, 143), + (1103, 0, 43, 34), + (1104, 50, 43, 130), + (1105, 0, 43, 73), + (1106, 0, 43, 75), + (1107, 50, 43, 17), + (1108, 0, 43, 132), + (1109, 50, 43, 86), + (1110, 0, 43, 102), + (1111, 0, 43, 133), + (1112, 25, 43, 27), + (1113, 0, 43, 73), + (1114, 50, 43, 119), + (1115, 0, 43, 99), + (1116, 0, 43, 76), + (1117, 0, 43, 130), + (1118, 0, 43, 38), + (1119, 50, 43, 56), + (1120, 0, 43, 30), + (1121, 0, 43, 41), + (1122, 50, 43, 73), + (1123, 0, 43, 95), + (1124, 50, 43, 53), + (1125, 0, 43, 36), + (1126, 50, 43, 91), + (1127, 50, 43, 65), + (1128, 50, 43, 31), + (1129, 0, 43, 91), + (1130, 0, 43, 26), + (1131, 50, 44, 57), + (1132, 50, 44, 30), + (1133, 50, 44, 14), + (1134, 50, 44, 128), + (1135, 0, 44, 2), + (1136, 50, 44, 38), + (1137, 0, 44, 50), + (1138, 50, 44, 72), + (1139, 0, 44, 39), + (1140, 0, 44, 51), + (1141, 50, 44, 62), + (1142, 0, 44, 56), + (1143, 50, 44, 64), + (1144, 50, 44, 60), + (1145, 0, 44, 67), + (1146, 0, 44, 139), + (1147, 25, 44, 115), + (1148, 0, 44, 80), + (1149, 50, 45, 51), + (1150, 0, 45, 107), + (1151, 50, 45, 137), + (1152, 50, 45, 101), + (1153, 0, 45, 16), + (1154, 0, 45, 146), + (1155, 0, 45, 82), + (1156, 0, 45, 112), + (1157, 0, 45, 17), + (1158, 0, 45, 93), + (1159, 25, 45, 116), + (1160, 0, 45, 30), + (1161, 0, 45, 148), + (1162, 0, 45, 78), + (1163, 25, 45, 83), + (1164, 0, 45, 137), + (1165, 0, 45, 106), + (1166, 0, 46, 11), + (1167, 50, 46, 121), + (1168, 0, 46, 56), + (1169, 0, 46, 84), + (1170, 0, 46, 52), + (1171, 50, 46, 34), + (1172, 0, 46, 24), + (1173, 0, 46, 110), + (1174, 50, 46, 2), + (1175, 25, 46, 123), + (1176, 50, 46, 116), + (1177, 0, 46, 66), + (1178, 0, 46, 142), + (1179, 50, 46, 27), + (1180, 50, 46, 85), + (1181, 0, 46, 101), + (1182, 50, 46, 47), + (1183, 0, 46, 10), + (1184, 25, 47, 41), + (1185, 50, 47, 7), + (1186, 0, 47, 52), + (1187, 50, 47, 44), + (1188, 0, 47, 58), + (1189, 0, 47, 20), + (1190, 25, 47, 117), + (1191, 0, 47, 138), + (1192, 0, 47, 91), + (1193, 0, 47, 2), + (1194, 0, 47, 67), + (1195, 25, 47, 56), + (1196, 0, 47, 148), + (1197, 0, 47, 87), + (1198, 50, 47, 26), + (1199, 25, 47, 116), + (1200, 25, 47, 136), + (1201, 50, 47, 5), + (1202, 50, 47, 145), + (1203, 25, 47, 141), + (1204, 0, 47, 27), + (1205, 0, 47, 19), + (1206, 0, 47, 96), + (1207, 0, 47, 56), + (1208, 0, 47, 15), + (1209, 0, 47, 102), + (1210, 0, 47, 11), + (1211, 25, 47, 56), + (1212, 50, 47, 20), + (1213, 50, 47, 53), + (1214, 0, 47, 139), + (1215, 50, 47, 104), + (1216, 50, 47, 68), + (1217, 50, 48, 82), + (1218, 50, 48, 9), + (1219, 0, 48, 141), + (1220, 0, 48, 88), + (1221, 50, 48, 10), + (1222, 50, 48, 60), + (1223, 0, 48, 56), + (1224, 0, 48, 10), + (1225, 0, 48, 124), + (1226, 0, 48, 125), + (1227, 0, 48, 66), + (1228, 0, 48, 81), + (1229, 0, 48, 82), + (1230, 0, 48, 2), + (1231, 25, 48, 93), + (1232, 0, 48, 146), + (1233, 0, 48, 38), + (1234, 50, 48, 144), + (1235, 50, 48, 86), + (1236, 0, 48, 43), + (1237, 50, 48, 12), + (1238, 0, 48, 108), + (1239, 0, 48, 94), + (1240, 0, 48, 34), + (1241, 50, 48, 49), + (1242, 0, 48, 57), + (1243, 50, 48, 134), + (1244, 0, 48, 133), + (1245, 0, 48, 148), + (1246, 0, 48, 45), + (1247, 0, 48, 25), + (1248, 0, 48, 95), + (1249, 25, 48, 87), + (1250, 0, 48, 15), + (1251, 50, 48, 48), + (1252, 0, 48, 75), + (1253, 50, 48, 37), + (1254, 0, 48, 18), + (1255, 0, 48, 25), + (1256, 50, 48, 24), + (1257, 50, 48, 1), + (1258, 50, 48, 84), + (1259, 50, 48, 87), + (1260, 25, 48, 139), + (1261, 0, 48, 24), + (1262, 0, 49, 93), + (1263, 0, 49, 69), + (1264, 0, 49, 52), + (1265, 0, 49, 111), + (1266, 0, 49, 7), + (1267, 25, 49, 130), + (1268, 0, 49, 60), + (1269, 0, 49, 125), + (1270, 0, 49, 113), + (1271, 25, 49, 79), + (1272, 50, 49, 25), + (1273, 0, 49, 124), + (1274, 25, 49, 132), + (1275, 0, 50, 45), + (1276, 0, 50, 116), + (1277, 50, 50, 93), + (1278, 50, 50, 125), + (1279, 25, 50, 130), + (1280, 50, 50, 25), + (1281, 0, 50, 134), + (1282, 0, 50, 77), + (1283, 50, 50, 6), + (1284, 0, 50, 26), + (1285, 50, 50, 51), + (1286, 0, 50, 13), + (1287, 0, 50, 132), + (1288, 50, 50, 15), + (1289, 0, 50, 90), + (1290, 50, 50, 118), + (1291, 0, 50, 49), + (1292, 0, 50, 85), + (1293, 0, 50, 86), + (1294, 50, 50, 30), + (1295, 0, 50, 16), + (1296, 50, 50, 65), + (1297, 25, 51, 11), + (1298, 50, 51, 125), + (1299, 0, 51, 123), + (1300, 0, 51, 104), + (1301, 50, 51, 146), + (1302, 0, 51, 52), + (1303, 50, 51, 58), + (1304, 50, 51, 22), + (1305, 50, 51, 16), + (1306, 0, 51, 109), + (1307, 0, 51, 85), + (1308, 0, 51, 100), + (1309, 0, 51, 44), + (1310, 0, 51, 33), + (1311, 50, 51, 20), + (1312, 50, 51, 31), + (1313, 50, 51, 67), + (1314, 25, 51, 87), + (1315, 0, 51, 34), + (1316, 50, 51, 95), + (1317, 0, 51, 32), + (1318, 0, 51, 9), + (1319, 50, 51, 124), + (1320, 25, 51, 73), + (1321, 0, 51, 89), + (1322, 0, 51, 94), + (1323, 0, 51, 109), + (1324, 0, 51, 12), + (1325, 0, 52, 64), + (1326, 50, 52, 36), + (1327, 0, 52, 65), + (1328, 0, 52, 70), + (1329, 0, 52, 83), + (1330, 0, 52, 51), + (1331, 0, 52, 4), + (1332, 25, 52, 109), + (1333, 50, 52, 100), + (1334, 50, 52, 71), + (1335, 0, 52, 78), + (1336, 0, 52, 132), + (1337, 0, 52, 110), + (1338, 0, 52, 143), + (1339, 25, 52, 86), + (1340, 50, 52, 72), + (1341, 0, 52, 33), + (1342, 50, 52, 38), + (1343, 0, 52, 72), + (1344, 0, 53, 117), + (1345, 50, 53, 106), + (1346, 0, 53, 133), + (1347, 0, 53, 121), + (1348, 0, 53, 18), + (1349, 0, 53, 68), + (1350, 25, 53, 44), + (1351, 0, 53, 97), + (1352, 0, 53, 86), + (1353, 0, 53, 37), + (1354, 0, 53, 47), + (1355, 0, 53, 64), + (1356, 50, 53, 92), + (1357, 25, 53, 3), + (1358, 0, 53, 17), + (1359, 0, 53, 42), + (1360, 0, 53, 122), + (1361, 0, 53, 79), + (1362, 50, 53, 70), + (1363, 0, 53, 44), + (1364, 50, 53, 12), + (1365, 50, 53, 5), + (1366, 0, 54, 83), + (1367, 50, 54, 80), + (1368, 0, 54, 30), + (1369, 0, 54, 112), + (1370, 0, 54, 18), + (1371, 25, 54, 117), + (1372, 50, 54, 110), + (1373, 0, 54, 21), + (1374, 0, 54, 68), + (1375, 0, 54, 29), + (1376, 0, 54, 41), + (1377, 50, 54, 31), + (1378, 0, 54, 2), + (1379, 50, 54, 17), + (1380, 50, 54, 59), + (1381, 0, 54, 148), + (1382, 0, 54, 83), + (1383, 50, 54, 29), + (1384, 0, 54, 36), + (1385, 50, 54, 45), + (1386, 0, 54, 84), + (1387, 50, 54, 67), + (1388, 0, 54, 99), + (1389, 50, 54, 86), + (1390, 0, 54, 109), + (1391, 50, 54, 131), + (1392, 0, 54, 88), + (1393, 50, 54, 67), + (1394, 50, 54, 53), + (1395, 0, 54, 11), + (1396, 0, 54, 81), + (1397, 0, 54, 7), + (1398, 0, 54, 27), + (1399, 25, 54, 101), + (1400, 0, 54, 42), + (1401, 0, 54, 67), + (1402, 50, 54, 127), + (1403, 0, 54, 104), + (1404, 0, 54, 62), + (1405, 0, 54, 61), + (1406, 0, 54, 85), + (1407, 0, 54, 5), + (1408, 50, 54, 141), + (1409, 50, 54, 89), + (1410, 0, 54, 145), + (1411, 0, 54, 114), + (1412, 50, 54, 146), + (1413, 0, 54, 3), + (1414, 0, 54, 140), + (1415, 0, 55, 125), + (1416, 0, 55, 145), + (1417, 0, 55, 69), + (1418, 50, 55, 41), + (1419, 25, 55, 144), + (1420, 50, 55, 10), + (1421, 50, 55, 96), + (1422, 25, 55, 29), + (1423, 50, 55, 10), + (1424, 25, 55, 78), + (1425, 0, 55, 80), + (1426, 0, 55, 123), + (1427, 50, 55, 126), + (1428, 0, 55, 7), + (1429, 0, 55, 16), + (1430, 0, 55, 42), + (1431, 50, 55, 126), + (1432, 50, 55, 59), + (1433, 0, 55, 12), + (1434, 0, 55, 51), + (1435, 0, 55, 33), + (1436, 0, 55, 16), + (1437, 0, 55, 75), + (1438, 25, 55, 120), + (1439, 0, 55, 31), + (1440, 0, 55, 120), + (1441, 25, 55, 124), + (1442, 25, 55, 118), + (1443, 50, 55, 148), + (1444, 0, 55, 105), + (1445, 0, 55, 72), + (1446, 0, 55, 65), + (1447, 50, 55, 90), + (1448, 0, 55, 101), + (1449, 0, 55, 134), + (1450, 50, 55, 102), + (1451, 0, 55, 132), + (1452, 0, 55, 131), + (1453, 0, 55, 105), + (1454, 50, 55, 83), + (1455, 50, 55, 22), + (1456, 50, 55, 46), + (1457, 0, 55, 143), + (1458, 0, 55, 16), + (1459, 0, 55, 112), + (1460, 0, 55, 96), + (1461, 50, 55, 28), + (1462, 25, 55, 102), + (1463, 0, 55, 111), + (1464, 0, 56, 71), + (1465, 0, 56, 5), + (1466, 0, 56, 118), + (1467, 50, 56, 21), + (1468, 50, 56, 31), + (1469, 50, 56, 125), + (1470, 0, 56, 21), + (1471, 50, 56, 86), + (1472, 0, 56, 119), + (1473, 0, 56, 68), + (1474, 0, 56, 52), + (1475, 0, 56, 35), + (1476, 0, 56, 95), + (1477, 0, 56, 113), + (1478, 50, 56, 35), + (1479, 0, 56, 42), + (1480, 0, 56, 103), + (1481, 0, 56, 91), + (1482, 50, 56, 42), + (1483, 0, 56, 89), + (1484, 0, 56, 104), + (1485, 50, 56, 133), + (1486, 0, 56, 16), + (1487, 50, 56, 57), + (1488, 0, 56, 39), + (1489, 0, 56, 136), + (1490, 50, 56, 111), + (1491, 0, 56, 111), + (1492, 0, 56, 103), + (1493, 0, 56, 24), + (1494, 0, 56, 107), + (1495, 0, 56, 55), + (1496, 50, 56, 138), + (1497, 50, 56, 59), + (1498, 50, 56, 23), + (1499, 0, 56, 72), + (1500, 0, 56, 56), + (1501, 0, 56, 90), + (1502, 25, 56, 147), + (1503, 50, 56, 23), + (1504, 50, 56, 113), + (1505, 0, 56, 48), + (1506, 50, 56, 69), + (1507, 0, 56, 30), + (1508, 0, 56, 75), + (1509, 50, 56, 32), + (1510, 0, 57, 53), + (1511, 0, 57, 35), + (1512, 0, 57, 120), + (1513, 50, 57, 17), + (1514, 0, 57, 70), + (1515, 0, 57, 87), + (1516, 0, 57, 100), + (1517, 0, 57, 105), + (1518, 0, 57, 57), + (1519, 0, 57, 146), + (1520, 25, 57, 11), + (1521, 50, 57, 9), + (1522, 0, 57, 46), + (1523, 0, 57, 41), + (1524, 50, 57, 83), + (1525, 0, 57, 50), + (1526, 0, 57, 117), + (1527, 0, 57, 63), + (1528, 50, 57, 142), + (1529, 50, 57, 115), + (1530, 25, 57, 98), + (1531, 50, 57, 17), + (1532, 25, 57, 83), + (1533, 0, 57, 112), + (1534, 50, 57, 53), + (1535, 0, 57, 47), + (1536, 0, 57, 76), + (1537, 50, 57, 147), + (1538, 0, 57, 37), + (1539, 0, 57, 143), + (1540, 50, 57, 118), + (1541, 50, 57, 114), + (1542, 0, 57, 39), + (1543, 0, 57, 53), + (1544, 0, 57, 28), + (1545, 0, 57, 43), + (1546, 0, 57, 67), + (1547, 0, 57, 79), + (1548, 50, 57, 98), + (1549, 0, 57, 20), + (1550, 0, 57, 36), + (1551, 50, 57, 29), + (1552, 25, 57, 44), + (1553, 0, 57, 93), + (1554, 0, 57, 86), + (1555, 0, 58, 45), + (1556, 0, 58, 4), + (1557, 0, 58, 71), + (1558, 0, 58, 128), + (1559, 0, 58, 69), + (1560, 0, 58, 95), + (1561, 0, 58, 23), + (1562, 0, 58, 143), + (1563, 25, 58, 133), + (1564, 0, 58, 148), + (1565, 50, 58, 14), + (1566, 50, 58, 128), + (1567, 0, 58, 12), + (1568, 0, 58, 38), + (1569, 0, 58, 130), + (1570, 50, 59, 54), + (1571, 0, 59, 136), + (1572, 0, 59, 88), + (1573, 0, 59, 129), + (1574, 0, 59, 44), + (1575, 0, 59, 97), + (1576, 50, 59, 104), + (1577, 0, 59, 144), + (1578, 0, 59, 99), + (1579, 0, 59, 135), + (1580, 0, 59, 33), + (1581, 0, 59, 142), + (1582, 0, 59, 125), + (1583, 50, 59, 44), + (1584, 0, 59, 94), + (1585, 0, 59, 52), + (1586, 0, 59, 72), + (1587, 50, 59, 82), + (1588, 0, 59, 100), + (1589, 0, 59, 71), + (1590, 0, 59, 140), + (1591, 50, 59, 105), + (1592, 50, 59, 2), + (1593, 0, 59, 46), + (1594, 0, 59, 138), + (1595, 50, 59, 31), + (1596, 50, 60, 28), + (1597, 50, 60, 104), + (1598, 0, 60, 127), + (1599, 0, 60, 89), + (1600, 50, 60, 100), + (1601, 50, 60, 120), + (1602, 50, 60, 43), + (1603, 0, 60, 23), + (1604, 0, 60, 5), + (1605, 0, 60, 65), + (1606, 0, 60, 141), + (1607, 0, 60, 37), + (1608, 0, 60, 76), + (1609, 50, 60, 82), + (1610, 0, 60, 89), + (1611, 0, 60, 16), + (1612, 0, 60, 66), + (1613, 50, 60, 63), + (1614, 25, 60, 78), + (1615, 0, 60, 148), + (1616, 50, 60, 35), + (1617, 0, 60, 116), + (1618, 50, 60, 67), + (1619, 0, 60, 72), + (1620, 50, 60, 85), + (1621, 0, 60, 54), + (1622, 50, 60, 12), + (1623, 25, 60, 24), + (1624, 0, 60, 104), + (1625, 50, 60, 15), + (1626, 0, 60, 101), + (1627, 0, 60, 94), + (1628, 0, 60, 90), + (1629, 50, 60, 3), + (1630, 50, 60, 78), + (1631, 0, 61, 3), + (1632, 25, 61, 29), + (1633, 50, 61, 80), + (1634, 0, 61, 124), + (1635, 0, 61, 83), + (1636, 0, 61, 66), + (1637, 0, 61, 123), + (1638, 0, 61, 128), + (1639, 50, 61, 35), + (1640, 0, 61, 139), + (1641, 0, 61, 112), + (1642, 0, 61, 5), + (1643, 0, 61, 31), + (1644, 50, 61, 131), + (1645, 0, 61, 134), + (1646, 0, 61, 84), + (1647, 50, 61, 47), + (1648, 0, 61, 89), + (1649, 0, 61, 105), + (1650, 0, 61, 70), + (1651, 0, 61, 146), + (1652, 0, 62, 124), + (1653, 0, 62, 126), + (1654, 50, 62, 72), + (1655, 0, 62, 40), + (1656, 0, 62, 110), + (1657, 50, 62, 65), + (1658, 0, 62, 48), + (1659, 50, 62, 7), + (1660, 0, 62, 12), + (1661, 0, 62, 48), + (1662, 0, 62, 25), + (1663, 25, 62, 69), + (1664, 25, 62, 111), + (1665, 0, 62, 23), + (1666, 50, 62, 140), + (1667, 50, 62, 105), + (1668, 50, 62, 72), + (1669, 50, 62, 51), + (1670, 0, 62, 12), + (1671, 0, 62, 70), + (1672, 25, 62, 143), + (1673, 0, 62, 75), + (1674, 0, 62, 110), + (1675, 0, 62, 136), + (1676, 0, 62, 102), + (1677, 0, 62, 67), + (1678, 50, 62, 63), + (1679, 0, 62, 14), + (1680, 0, 62, 124), + (1681, 0, 62, 27), + (1682, 0, 62, 140), + (1683, 0, 62, 122), + (1684, 50, 62, 38), + (1685, 0, 62, 137), + (1686, 25, 62, 86), + (1687, 50, 62, 148), + (1688, 50, 62, 114), + (1689, 0, 62, 86), + (1690, 0, 62, 86), + (1691, 0, 62, 78), + (1692, 0, 62, 77), + (1693, 0, 63, 131), + (1694, 0, 63, 137), + (1695, 50, 63, 139), + (1696, 50, 63, 124), + (1697, 50, 63, 120), + (1698, 0, 63, 99), + (1699, 0, 63, 100), + (1700, 0, 63, 39), + (1701, 0, 63, 87), + (1702, 50, 63, 11), + (1703, 0, 63, 20), + (1704, 0, 63, 117), + (1705, 25, 63, 56), + (1706, 0, 63, 100), + (1707, 0, 63, 10), + (1708, 50, 63, 103), + (1709, 50, 63, 61), + (1710, 0, 63, 120), + (1711, 25, 63, 60), + (1712, 0, 63, 9), + (1713, 0, 63, 56), + (1714, 25, 63, 132), + (1715, 0, 63, 19), + (1716, 50, 63, 142), + (1717, 25, 63, 72), + (1718, 0, 63, 36), + (1719, 0, 63, 129), + (1720, 0, 63, 91), + (1721, 50, 63, 134), + (1722, 0, 63, 31), + (1723, 0, 63, 142), + (1724, 0, 63, 70), + (1725, 50, 63, 64), + (1726, 50, 63, 100), + (1727, 0, 63, 91), + (1728, 50, 63, 31), + (1729, 0, 63, 110), + (1730, 0, 63, 104), + (1731, 50, 63, 29), + (1732, 0, 63, 111), + (1733, 0, 63, 86), + (1734, 0, 63, 77), + (1735, 0, 63, 36), + (1736, 0, 63, 92), + (1737, 0, 63, 147), + (1738, 0, 63, 44), + (1739, 0, 63, 130), + (1740, 0, 63, 41), + (1741, 0, 64, 131), + (1742, 0, 64, 104), + (1743, 50, 64, 51), + (1744, 0, 64, 88), + (1745, 50, 64, 32), + (1746, 50, 64, 52), + (1747, 0, 64, 74), + (1748, 0, 64, 31), + (1749, 50, 64, 140), + (1750, 50, 64, 101), + (1751, 0, 64, 88), + (1752, 0, 64, 115), + (1753, 0, 64, 65), + (1754, 50, 64, 43), + (1755, 25, 64, 61), + (1756, 50, 64, 129), + (1757, 0, 64, 128), + (1758, 0, 64, 148), + (1759, 50, 64, 56), + (1760, 25, 64, 31), + (1761, 0, 64, 62), + (1762, 25, 64, 35), + (1763, 50, 64, 47), + (1764, 0, 64, 94), + (1765, 25, 64, 46), + (1766, 0, 64, 67), + (1767, 0, 64, 88), + (1768, 50, 64, 99), + (1769, 50, 64, 71), + (1770, 0, 64, 64), + (1771, 0, 64, 88), + (1772, 0, 64, 80), + (1773, 0, 64, 14), + (1774, 0, 64, 123), + (1775, 0, 64, 39), + (1776, 0, 65, 18), + (1777, 0, 65, 29), + (1778, 25, 65, 128), + (1779, 25, 65, 43), + (1780, 0, 65, 18), + (1781, 50, 65, 34), + (1782, 25, 65, 38), + (1783, 0, 65, 134), + (1784, 50, 65, 72), + (1785, 50, 65, 61), + (1786, 25, 65, 76), + (1787, 50, 65, 87), + (1788, 0, 65, 30), + (1789, 0, 65, 63), + (1790, 0, 65, 140), + (1791, 50, 65, 20), + (1792, 0, 65, 77), + (1793, 0, 65, 1), + (1794, 0, 65, 74), + (1795, 0, 65, 47), + (1796, 0, 65, 52), + (1797, 0, 65, 8), + (1798, 50, 65, 144), + (1799, 0, 65, 67), + (1800, 25, 65, 147), + (1801, 0, 65, 1), + (1802, 50, 65, 105), + (1803, 0, 65, 110), + (1804, 0, 65, 3), + (1805, 0, 65, 32), + (1806, 0, 65, 116), + (1807, 50, 65, 90), + (1808, 50, 65, 140), + (1809, 0, 65, 92), + (1810, 25, 65, 29), + (1811, 0, 65, 65), + (1812, 50, 65, 143), + (1813, 25, 65, 82), + (1814, 0, 65, 119), + (1815, 0, 65, 99), + (1816, 50, 65, 141), + (1817, 0, 65, 114), + (1818, 50, 65, 97), + (1819, 0, 65, 145), + (1820, 0, 66, 105), + (1821, 0, 66, 126), + (1822, 0, 66, 135), + (1823, 50, 66, 48), + (1824, 0, 66, 114), + (1825, 50, 66, 96), + (1826, 0, 66, 21), + (1827, 50, 66, 57), + (1828, 50, 66, 11), + (1829, 25, 66, 130), + (1830, 0, 66, 55), + (1831, 0, 66, 9), + (1832, 0, 66, 2), + (1833, 0, 66, 80), + (1834, 50, 66, 51), + (1835, 50, 66, 137), + (1836, 25, 66, 15), + (1837, 25, 66, 81), + (1838, 50, 66, 1), + (1839, 0, 66, 80), + (1840, 0, 66, 32), + (1841, 0, 66, 27), + (1842, 0, 66, 96), + (1843, 50, 66, 136), + (1844, 0, 66, 20), + (1845, 50, 66, 143), + (1846, 0, 66, 65), + (1847, 50, 66, 73), + (1848, 50, 66, 104), + (1849, 50, 66, 60), + (1850, 50, 66, 146), + (1851, 50, 66, 27), + (1852, 50, 66, 20), + (1853, 0, 67, 12), + (1854, 0, 67, 130), + (1855, 0, 67, 54), + (1856, 50, 67, 21), + (1857, 0, 67, 41), + (1858, 0, 67, 142), + (1859, 0, 67, 105), + (1860, 50, 67, 30), + (1861, 0, 67, 96), + (1862, 0, 67, 125), + (1863, 25, 67, 51), + (1864, 0, 67, 111), + (1865, 50, 67, 22), + (1866, 0, 67, 19), + (1867, 0, 67, 32), + (1868, 0, 67, 58), + (1869, 0, 67, 18), + (1870, 0, 67, 145), + (1871, 25, 67, 9), + (1872, 0, 67, 113), + (1873, 0, 67, 53), + (1874, 0, 67, 71), + (1875, 0, 67, 55), + (1876, 0, 67, 122), + (1877, 0, 67, 5), + (1878, 0, 67, 57), + (1879, 0, 67, 115), + (1880, 0, 67, 90), + (1881, 0, 67, 21), + (1882, 0, 67, 71), + (1883, 0, 67, 69), + (1884, 50, 68, 40), + (1885, 50, 68, 55), + (1886, 0, 68, 61), + (1887, 25, 68, 67), + (1888, 0, 68, 106), + (1889, 50, 68, 36), + (1890, 25, 68, 63), + (1891, 50, 68, 120), + (1892, 0, 68, 9), + (1893, 0, 68, 88), + (1894, 0, 68, 76), + (1895, 0, 68, 11), + (1896, 50, 68, 56), + (1897, 50, 69, 44), + (1898, 50, 69, 105), + (1899, 50, 69, 28), + (1900, 50, 69, 23), + (1901, 0, 69, 115), + (1902, 0, 69, 127), + (1903, 0, 69, 22), + (1904, 0, 69, 40), + (1905, 25, 69, 78), + (1906, 0, 69, 21), + (1907, 50, 69, 33), + (1908, 0, 69, 118), + (1909, 25, 69, 132), + (1910, 0, 69, 32), + (1911, 50, 70, 80), + (1912, 50, 70, 31), + (1913, 0, 70, 143), + (1914, 0, 70, 86), + (1915, 50, 70, 143), + (1916, 50, 70, 116), + (1917, 0, 70, 147), + (1918, 50, 70, 114), + (1919, 0, 70, 148), + (1920, 50, 70, 30), + (1921, 0, 70, 28), + (1922, 0, 70, 111), + (1923, 0, 70, 115), + (1924, 50, 70, 32), + (1925, 0, 70, 65), + (1926, 50, 70, 42), + (1927, 50, 70, 108), + (1928, 0, 70, 83), + (1929, 0, 70, 124), + (1930, 0, 70, 102), + (1931, 50, 70, 124), + (1932, 0, 70, 53), + (1933, 0, 70, 28), + (1934, 50, 70, 90), + (1935, 0, 70, 52), + (1936, 50, 70, 82), + (1937, 0, 70, 20), + (1938, 0, 70, 61), + (1939, 0, 70, 143), + (1940, 0, 70, 92), + (1941, 50, 70, 105), + (1942, 50, 70, 145), + (1943, 50, 70, 85), + (1944, 0, 70, 68), + (1945, 0, 70, 113), + (1946, 50, 70, 137), + (1947, 50, 70, 108), + (1948, 50, 70, 12), + (1949, 50, 71, 25), + (1950, 0, 71, 11), + (1951, 25, 71, 59), + (1952, 25, 71, 13), + (1953, 50, 71, 58), + (1954, 0, 71, 110), + (1955, 0, 71, 93), + (1956, 25, 71, 112), + (1957, 50, 71, 114), + (1958, 0, 71, 120), + (1959, 0, 71, 92), + (1960, 0, 71, 2), + (1961, 25, 71, 94), + (1962, 50, 71, 89), + (1963, 0, 71, 43), + (1964, 25, 72, 6), + (1965, 50, 72, 52), + (1966, 0, 72, 84), + (1967, 50, 72, 121), + (1968, 50, 72, 119), + (1969, 50, 72, 143), + (1970, 0, 72, 94), + (1971, 0, 72, 115), + (1972, 25, 72, 122), + (1973, 0, 72, 72), + (1974, 50, 72, 96), + (1975, 50, 72, 43), + (1976, 0, 72, 115), + (1977, 0, 72, 12), + (1978, 50, 72, 93), + (1979, 25, 72, 70), + (1980, 50, 72, 23), + (1981, 50, 72, 43), + (1982, 0, 72, 43), + (1983, 50, 72, 65), + (1984, 0, 72, 83), + (1985, 0, 72, 88), + (1986, 0, 72, 49), + (1987, 50, 72, 33), + (1988, 0, 72, 30), + (1989, 0, 72, 28), + (1990, 50, 72, 131), + (1991, 0, 72, 105), + (1992, 50, 72, 101), + (1993, 0, 72, 26), + (1994, 50, 72, 7), + (1995, 25, 73, 112), + (1996, 50, 73, 135), + (1997, 50, 73, 111), + (1998, 50, 73, 101), + (1999, 0, 73, 32), + (2000, 50, 73, 125), + (2001, 50, 73, 91), + (2002, 0, 73, 85), + (2003, 0, 73, 11), + (2004, 50, 73, 115), + (2005, 0, 73, 132), + (2006, 0, 73, 107), + (2007, 0, 73, 12), + (2008, 50, 73, 95), + (2009, 50, 74, 38), + (2010, 50, 74, 1), + (2011, 50, 74, 106), + (2012, 0, 74, 19), + (2013, 50, 74, 143), + (2014, 0, 74, 48), + (2015, 0, 74, 46), + (2016, 50, 74, 96), + (2017, 0, 74, 147), + (2018, 0, 74, 25), + (2019, 0, 74, 3), + (2020, 50, 74, 116), + (2021, 0, 74, 130), + (2022, 0, 74, 139), + (2023, 0, 74, 70), + (2024, 50, 74, 125), + (2025, 0, 74, 83), + (2026, 25, 74, 37), + (2027, 50, 74, 26), + (2028, 0, 74, 145), + (2029, 25, 74, 134), + (2030, 0, 74, 90), + (2031, 0, 74, 107), + (2032, 0, 74, 124), + (2033, 50, 74, 145), + (2034, 0, 74, 65), + (2035, 0, 74, 7), + (2036, 50, 74, 56), + (2037, 0, 74, 118), + (2038, 0, 74, 79), + (2039, 50, 74, 110), + (2040, 0, 74, 14), + (2041, 0, 74, 76), + (2042, 0, 74, 35), + (2043, 0, 74, 87), + (2044, 50, 74, 78), + (2045, 50, 74, 19), + (2046, 50, 74, 98), + (2047, 0, 74, 34), + (2048, 0, 74, 133), + (2049, 50, 74, 8), + (2050, 0, 74, 12), + (2051, 0, 74, 71), + (2052, 50, 74, 75), + (2053, 0, 74, 36), + (2054, 25, 74, 1), + (2055, 0, 74, 85), + (2056, 0, 74, 27), + (2057, 50, 74, 78), + (2058, 0, 75, 52), + (2059, 50, 75, 82), + (2060, 0, 75, 2), + (2061, 50, 75, 129), + (2062, 0, 75, 78), + (2063, 25, 75, 130), + (2064, 0, 75, 127), + (2065, 50, 75, 14), + (2066, 50, 75, 103), + (2067, 50, 75, 59), + (2068, 0, 75, 136), + (2069, 50, 75, 60), + (2070, 50, 75, 45), + (2071, 50, 75, 30), + (2072, 0, 75, 94), + (2073, 0, 75, 141), + (2074, 0, 75, 51), + (2075, 25, 75, 29), + (2076, 0, 75, 126), + (2077, 0, 75, 97), + (2078, 0, 75, 92), + (2079, 0, 75, 27), + (2080, 50, 75, 40), + (2081, 50, 75, 120), + (2082, 0, 75, 101), + (2083, 50, 75, 127), + (2084, 0, 75, 130), + (2085, 50, 75, 110), + (2086, 0, 75, 128), + (2087, 0, 75, 63), + (2088, 50, 75, 70), + (2089, 0, 75, 25), + (2090, 50, 75, 16), + (2091, 0, 75, 147), + (2092, 50, 75, 141), + (2093, 0, 75, 81), + (2094, 0, 76, 107), + (2095, 25, 76, 62), + (2096, 0, 76, 51), + (2097, 50, 76, 105), + (2098, 0, 76, 31), + (2099, 50, 76, 123), + (2100, 0, 76, 119), + (2101, 25, 76, 82), + (2102, 50, 76, 71), + (2103, 25, 76, 75), + (2104, 25, 76, 23), + (2105, 25, 76, 94), + (2106, 0, 76, 67), + (2107, 0, 76, 147), + (2108, 50, 77, 122), + (2109, 0, 77, 83), + (2110, 0, 77, 105), + (2111, 0, 77, 51), + (2112, 0, 77, 16), + (2113, 0, 77, 50), + (2114, 50, 77, 144), + (2115, 0, 77, 65), + (2116, 0, 77, 72), + (2117, 0, 77, 36), + (2118, 0, 77, 18), + (2119, 0, 77, 99), + (2120, 0, 77, 126), + (2121, 0, 77, 55), + (2122, 0, 77, 7), + (2123, 0, 77, 11), + (2124, 0, 77, 143), + (2125, 50, 77, 44), + (2126, 50, 77, 1), + (2127, 0, 77, 46), + (2128, 0, 77, 97), + (2129, 50, 77, 48), + (2130, 50, 77, 101), + (2131, 0, 77, 10), + (2132, 0, 77, 140), + (2133, 0, 77, 103), + (2134, 0, 77, 72), + (2135, 50, 77, 34), + (2136, 50, 77, 51), + (2137, 50, 77, 113), + (2138, 50, 77, 94), + (2139, 50, 77, 123), + (2140, 25, 77, 80), + (2141, 0, 78, 15), + (2142, 25, 78, 145), + (2143, 50, 78, 117), + (2144, 0, 78, 5), + (2145, 50, 78, 41), + (2146, 0, 78, 133), + (2147, 0, 78, 104), + (2148, 50, 78, 129), + (2149, 50, 78, 9), + (2150, 0, 78, 59), + (2151, 50, 78, 102), + (2152, 0, 78, 64), + (2153, 0, 78, 45), + (2154, 50, 78, 92), + (2155, 25, 78, 135), + (2156, 0, 78, 142), + (2157, 25, 78, 144), + (2158, 0, 78, 147), + (2159, 50, 78, 59), + (2160, 50, 78, 91), + (2161, 0, 78, 99), + (2162, 0, 78, 90), + (2163, 0, 78, 93), + (2164, 0, 78, 35), + (2165, 0, 78, 91), + (2166, 0, 78, 77), + (2167, 0, 78, 79), + (2168, 25, 78, 57), + (2169, 0, 78, 134), + (2170, 25, 78, 25), + (2171, 0, 78, 14), + (2172, 0, 78, 68), + (2173, 50, 79, 133), + (2174, 0, 79, 79), + (2175, 0, 79, 54), + (2176, 0, 79, 104), + (2177, 25, 79, 25), + (2178, 0, 79, 49), + (2179, 50, 79, 29), + (2180, 0, 79, 72), + (2181, 0, 79, 31), + (2182, 50, 79, 139), + (2183, 0, 79, 3), + (2184, 0, 79, 38), + (2185, 0, 79, 87), + (2186, 0, 79, 131), + (2187, 50, 79, 54), + (2188, 0, 79, 31), + (2189, 50, 79, 81), + (2190, 25, 79, 71), + (2191, 25, 79, 120), + (2192, 50, 79, 113), + (2193, 50, 79, 14), + (2194, 25, 79, 73), + (2195, 50, 79, 132), + (2196, 50, 79, 138), + (2197, 50, 79, 34), + (2198, 50, 79, 96), + (2199, 0, 79, 123), + (2200, 0, 79, 14), + (2201, 50, 79, 146), + (2202, 50, 79, 96), + (2203, 50, 79, 140), + (2204, 0, 79, 89), + (2205, 50, 79, 77), + (2206, 50, 80, 13), + (2207, 0, 80, 121), + (2208, 25, 80, 66), + (2209, 50, 80, 20), + (2210, 0, 80, 27), + (2211, 0, 80, 8), + (2212, 25, 80, 41), + (2213, 0, 80, 107), + (2214, 25, 80, 37), + (2215, 50, 80, 75), + (2216, 25, 80, 37), + (2217, 50, 80, 85), + (2218, 0, 80, 113), + (2219, 50, 80, 35), + (2220, 0, 80, 12), + (2221, 0, 80, 30), + (2222, 0, 80, 7), + (2223, 50, 80, 49), + (2224, 0, 80, 20), + (2225, 0, 80, 144), + (2226, 0, 80, 110), + (2227, 0, 80, 119), + (2228, 0, 80, 31), + (2229, 0, 80, 120), + (2230, 0, 80, 44), + (2231, 0, 80, 87), + (2232, 0, 80, 146), + (2233, 0, 80, 44), + (2234, 0, 80, 107), + (2235, 50, 80, 121), + (2236, 0, 80, 14), + (2237, 0, 80, 31), + (2238, 50, 80, 49), + (2239, 0, 80, 36), + (2240, 0, 81, 24), + (2241, 0, 81, 24), + (2242, 0, 81, 66), + (2243, 0, 81, 67), + (2244, 0, 81, 115), + (2245, 0, 81, 102), + (2246, 0, 81, 39), + (2247, 0, 81, 145), + (2248, 25, 81, 130), + (2249, 0, 81, 73), + (2250, 50, 81, 133), + (2251, 50, 81, 136), + (2252, 0, 81, 139), + (2253, 0, 81, 24), + (2254, 50, 81, 2), + (2255, 25, 81, 30), + (2256, 25, 81, 19), + (2257, 0, 81, 130), + (2258, 0, 81, 43), + (2259, 0, 81, 145), + (2260, 0, 81, 121), + (2261, 0, 81, 9), + (2262, 50, 81, 122), + (2263, 50, 81, 89), + (2264, 0, 81, 119), + (2265, 0, 81, 61), + (2266, 0, 81, 50), + (2267, 0, 81, 122), + (2268, 0, 81, 86), + (2269, 50, 81, 64), + (2270, 50, 81, 7), + (2271, 0, 81, 130), + (2272, 0, 81, 114), + (2273, 0, 81, 37), + (2274, 50, 81, 128), + (2275, 0, 81, 16), + (2276, 50, 81, 38), + (2277, 0, 81, 22), + (2278, 50, 81, 86), + (2279, 0, 81, 147), + (2280, 0, 81, 134), + (2281, 0, 81, 113), + (2282, 0, 81, 123), + (2283, 0, 81, 111), + (2284, 25, 81, 24), + (2285, 50, 81, 89), + (2286, 0, 81, 21), + (2287, 50, 82, 93), + (2288, 50, 82, 44), + (2289, 0, 82, 61), + (2290, 50, 82, 127), + (2291, 50, 82, 106), + (2292, 0, 82, 119), + (2293, 0, 82, 3), + (2294, 0, 82, 71), + (2295, 50, 82, 146), + (2296, 50, 82, 137), + (2297, 50, 82, 138), + (2298, 0, 82, 107), + (2299, 25, 82, 5), + (2300, 0, 82, 7), + (2301, 25, 82, 80), + (2302, 0, 82, 80), + (2303, 0, 82, 88), + (2304, 0, 82, 33), + (2305, 0, 82, 90), + (2306, 50, 82, 62), + (2307, 50, 82, 35), + (2308, 0, 82, 35), + (2309, 50, 82, 16), + (2310, 0, 82, 46), + (2311, 25, 82, 112), + (2312, 0, 82, 136), + (2313, 25, 82, 130), + (2314, 0, 82, 111), + (2315, 0, 82, 96), + (2316, 0, 82, 53), + (2317, 0, 82, 99), + (2318, 0, 82, 10), + (2319, 50, 82, 126), + (2320, 50, 82, 107), + (2321, 0, 82, 9), + (2322, 0, 83, 48), + (2323, 0, 83, 92), + (2324, 50, 83, 124), + (2325, 0, 83, 65), + (2326, 0, 83, 133), + (2327, 0, 83, 95), + (2328, 0, 83, 145), + (2329, 0, 83, 138), + (2330, 25, 83, 124), + (2331, 0, 83, 105), + (2332, 50, 83, 47), + (2333, 0, 83, 51), + (2334, 0, 83, 123), + (2335, 0, 83, 102), + (2336, 0, 83, 14), + (2337, 0, 83, 23), + (2338, 50, 83, 138), + (2339, 25, 83, 94), + (2340, 0, 83, 31), + (2341, 0, 83, 82), + (2342, 0, 83, 44), + (2343, 50, 83, 27), + (2344, 0, 83, 127), + (2345, 50, 83, 18), + (2346, 0, 83, 29), + (2347, 0, 83, 125), + (2348, 0, 84, 62), + (2349, 0, 84, 44), + (2350, 0, 84, 89), + (2351, 50, 84, 15), + (2352, 0, 84, 1), + (2353, 50, 84, 14), + (2354, 0, 84, 117), + (2355, 0, 84, 127), + (2356, 0, 84, 52), + (2357, 0, 84, 53), + (2358, 0, 84, 38), + (2359, 50, 84, 148), + (2360, 0, 84, 100), + (2361, 50, 84, 137), + (2362, 0, 84, 137), + (2363, 50, 84, 58), + (2364, 25, 84, 27), + (2365, 0, 84, 60), + (2366, 0, 84, 103), + (2367, 0, 84, 140), + (2368, 0, 84, 106), + (2369, 0, 84, 46), + (2370, 0, 84, 80), + (2371, 25, 84, 46), + (2372, 0, 84, 36), + (2373, 50, 84, 50), + (2374, 50, 84, 131), + (2375, 0, 84, 120), + (2376, 0, 85, 50), + (2377, 0, 85, 26), + (2378, 50, 85, 94), + (2379, 0, 85, 148), + (2380, 0, 85, 123), + (2381, 50, 85, 4), + (2382, 0, 85, 9), + (2383, 0, 85, 90), + (2384, 0, 85, 40), + (2385, 25, 85, 47), + (2386, 50, 85, 3), + (2387, 0, 85, 35), + (2388, 50, 85, 40), + (2389, 0, 85, 12), + (2390, 0, 85, 73), + (2391, 0, 85, 31), + (2392, 50, 85, 121), + (2393, 0, 85, 51), + (2394, 0, 85, 143), + (2395, 0, 85, 131), + (2396, 0, 85, 147), + (2397, 0, 85, 39); + + diff --git a/Suli/13.b/Adatbázis/20241016/megoldasok.txt b/Suli/13.b/Adatbázis/20241016/megoldasok.txt new file mode 100644 index 0000000..e3cd4aa --- /dev/null +++ b/Suli/13.b/Adatbázis/20241016/megoldasok.txt @@ -0,0 +1,27 @@ +-- 13. feladat: +CREATE DATABASE mozi CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + + +-- 15. feladat: +SELECT COUNT(vetites.id) AS `vetitesek_szama` FROM `vetites` WHERE vetites.kezdes = "20:00:00"; + + +-- 16. feladat: +SELECT vendeg.nev AS `vendeg_nev`, COUNT(jegy.id) AS `jegy_db` FROM `jegy` INNER JOIN vendeg ON jegy.vendegId = vendeg.id GROUP BY jegy.vendegId ORDER BY `jegy_db` DESC LIMIT 5; + + +-- 17. feladat: +UPDATE `film` SET `cim` = "Csillagok között" WHERE film.cim = "Interstellar"; + + +-- 18. feladat: +INSERT INTO `filmtipus`(`nev`) VALUES ("Animációs"); + + +-- 19. feladat: +SELECT vendeg.nev AS `nev`, COUNT(jegy.id) AS `teljes_aru_jegy_db` FROM `jegy` INNER JOIN vendeg ON jegy.vendegId = vendeg.id WHERE jegy.kedvezmeny = 0 GROUP BY jegy.vendegId HAVING vendeg.nev = "Fodor András"; + + +-- 20. feladat: +SELECT film.cim AS `film_neve`, COUNT(jegy.id) AS `jegy_darabszam`, SUM(film.jegyar - film.jegyar * jegy.kedvezmeny / 100) AS `teljes_bevetel` FROM `jegy` INNER JOIN vetites ON jegy.vetitesId = vetites.id INNER JOIN film ON vetites.filmId = film.id GROUP BY film.cim ORDER BY `teljes_bevetel` DESC LIMIT 1; + diff --git a/Suli/13.b/Adatbázis/20241106/2023okt/2023_okt_megoldasok.txt b/Suli/13.b/Adatbázis/20241106/2023okt/2023_okt_megoldasok.txt new file mode 100644 index 0000000..c36c916 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241106/2023okt/2023_okt_megoldasok.txt @@ -0,0 +1,27 @@ +-- 10. feladat: +CREATE DATABASE hamburger CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + + +-- 12. feladat: +SELECT * FROM `menutetel` WHERE menutetel.ar = 2500; + + +-- 13. feladat: +UPDATE `menutetel` SET `ar`= 2300 WHERE menutetel.nev = "Grill pizza 32cm"; + + +-- 14. feladat: +SELECT felhasznalo.nev AS `vendeg_nev`, COUNT(rendeles.felhasznaloId) AS `rendeles_db` FROM `rendeles` INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id GROUP BY rendeles.felhasznaloId ORDER BY `rendeles_db` DESC LIMIT 9; + + +-- 15. feladat: +INSERT INTO `menutetel`(`nev`, `ar`, `etelkatId`) VALUES ("Boston tészta", 2300, 3); + + +-- 16. feladat: +SELECT rendeles.id AS `rendeles_azon`, rendeleselem.id AS `rendeleselem_azon`, menutetel.nev AS `menutetel_neve` FROM `rendeleselem` INNER JOIN rendeles ON rendeleselem.rendelesId = rendeles.id INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id INNER JOIN menutetel ON rendeleselem.menutetelId = menutetel.id WHERE felhasznalo.nev = "Balázs Flóra"; + + +-- 17. feladat: +SELECT felhasznalo.nev, SUM(rendeleselem.mennyiseg * menutetel.ar) * 1.10 AS `osszesen` FROM `rendeleselem` INNER JOIN rendeles ON rendeleselem.rendelesId = rendeles.id INNER JOIN felhasznalo ON rendeles.felhasznaloId = felhasznalo.id INNER JOIN menutetel ON rendeleselem.menutetelId = menutetel.id GROUP BY rendeles.felhasznaloId ORDER BY `osszesen` DESC LIMIT 1; + diff --git a/Suli/13.b/Adatbázis/20241106/2023okt/adatbazis.sql b/Suli/13.b/Adatbázis/20241106/2023okt/adatbazis.sql new file mode 100644 index 0000000..5cc2001 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241106/2023okt/adatbazis.sql @@ -0,0 +1,2728 @@ +-- Táblák létrehozása + +-- Rendelő felhasználók +CREATE TABLE felhasznalo +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + primary key (id) +); + +-- Ételkategóriák +CREATE TABLE etelkategoria +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + primary key (id) +); + +-- Menütételek +CREATE TABLE menutetel +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(64) NOT NULL UNIQUE, + ar int NOT NULL, + etelkatId int NOT NULL, + primary key (id), + key etelkatId (etelkatId), + CONSTRAINT FK_menu_etelkatId FOREIGN KEY (etelkatId) REFERENCES etelkategoria (id) +); + +-- Rendelések +CREATE TABLE rendeles +( + id int NOT NULL AUTO_INCREMENT, + felhasznaloId int NOT NULL, + idopont time NOT NULL, + primary key (id), + key felhasznaloId (felhasznaloId), + CONSTRAINT FK_rendeles_felhasznaloId FOREIGN KEY (felhasznaloId) REFERENCES felhasznalo (id) +); + +-- Rendeléselemek +CREATE TABLE rendeleselem +( + id int NOT NULL AUTO_INCREMENT, + mennyiseg int NOT NULL, + menutetelId int NOT NULL, + rendelesId int NOT NULL, + primary key (id), + key menutetelId (menutetelId), + CONSTRAINT FK_rendeleselem_menutetelId FOREIGN KEY (menutetelId) REFERENCES menutetel (id), + key rendelesId (rendelesId), + CONSTRAINT FK_rendeleselem_rendeles FOREIGN KEY (rendelesId) REFERENCES rendeles (id) +); + +-- Adatok beszúrása +INSERT INTO felhasznalo (id, nev) +VALUES (1, 'Nagy Bence'), + (2, 'Kovács Máté'), + (3, 'Tóth Levente'), + (4, 'Szabó Dominik'), + (5, 'Horváth Marcell'), + (6, 'Varga Noel'), + (7, 'Kiss Ádám'), + (8, 'Molnár Dániel'), + (9, 'Németh Dávid'), + (10, 'Farkas Olivér'), + (11, 'Balogh Milán'), + (12, 'Papp Zalán'), + (13, 'Lakatos Botond'), + (14, 'Takács Benett'), + (15, 'Juhász Zsombor'), + (16, 'Mészáros Balázs'), + (17, 'Oláh Áron'), + (18, 'Simon Péter'), + (19, 'Rácz Kristóf'), + (20, 'Fekete Tamás'), + (21, 'Szilágyi Márk'), + (22, 'Török Benedek'), + (23, 'Fehér Gergő'), + (24, 'Balázs László'), + (25, 'Gál Nimród'), + (26, 'Kis Bálint'), + (27, 'Szűcs Zétény'), + (28, 'Kocsis Ákos'), + (29, 'Orsós Patrik'), + (30, 'Pintér Zoltán'), + (31, 'Fodor András'), + (32, 'Szalai Attila'), + (33, 'Sipos Hunor'), + (34, 'Magyar Barnabás'), + (35, 'Lukács Márton'), + (36, 'Gulyás Gábor'), + (37, 'Biró Alex'), + (38, 'Király Martin'), + (39, 'László István'), + (40, 'Balog Kornél'), + (41, 'Katona Vince'), + (42, 'Bogdán József'), + (43, 'Jakab János'), + (44, 'Sándor Krisztián'), + (45, 'Boros Zsolt'), + (46, 'Váradi Zente'), + (47, 'Fazekas Sándor'), + (48, 'Kelemen Erik'), + (49, 'Antal Bendegúz'), + (50, 'Orosz Roland'), + (51, 'Somogyi Richárd'), + (52, 'Fülöp Ábel'), + (53, 'Veres Csaba'), + (54, 'Vincze Róbert'), + (55, 'Budai Kevin'), + (56, 'Hegedűs Nolen'), + (57, 'Deák Soma'), + (58, 'Pap Ármin'), + (59, 'Bálint Mihály'), + (60, 'Illés Vencel'), + (61, 'Pál Norbert'), + (62, 'Vass Mátyás'), + (63, 'Szőke Ferenc'), + (64, 'Fábián Tibor'), + (65, 'Vörös Nándor'), + (66, 'Lengyel Benjámin'), + (67, 'Bognár Szabolcs'), + (68, 'Bodnár Benjamin'), + (69, 'Jónás Simon'), + (70, 'Szücs Gergely'), + (71, 'Hajdu Csongor'), + (72, 'Halász Viktor'), + (73, 'Máté Miklós'), + (74, 'Székely Nikolasz'), + (75, 'Kozma Vilmos'), + (76, 'Gáspár Boldizsár'), + (77, 'Pásztor Kende'), + (78, 'Bakos Imre'), + (79, 'Dudás Bertalan'), + (80, 'Major Brendon'), + (81, 'Orbán Zénó'), + (82, 'Virág Adrián'), + (83, 'Hegedüs Dorián'), + (84, 'Barna Krisztofer'), + (85, 'Novák György'), + (86, 'Soós Alexander'), + (87, 'Tamás Lajos'), + (88, 'Nemes Dénes'), + (89, 'Pataki Félix'), + (90, 'Balla Sámuel'), + (91, 'Faragó Denisz'), + (92, 'Kerekes Bende'), + (93, 'Borbély Noé'), + (94, 'Barta Károly'), + (95, 'Péter Donát'), + (96, 'Csonka Gyula'), + (97, 'Mezei Gellért'), + (98, 'Sárközi Mirkó'), + (99, 'Szekeres Vendel'), + (100, 'Márton Brájen'), + (101, 'Nagy Hanna'), + (102, 'Kovács Anna'), + (103, 'Tóth Zoé'), + (104, 'Szabó Luca'), + (105, 'Horváth Léna'), + (106, 'Varga Emma'), + (107, 'Kiss Zsófia'), + (108, 'Molnár Lili'), + (109, 'Németh Boglárka'), + (110, 'Farkas Mira'), + (111, 'Balogh Lilien'), + (112, 'Papp Nóra'), + (113, 'Lakatos Jázmin'), + (114, 'Takács Laura'), + (115, 'Juhász Maja'), + (116, 'Mészáros Sára'), + (117, 'Oláh Lara'), + (118, 'Simon Lilla'), + (119, 'Rácz Izabella'), + (120, 'Fekete Gréta'), + (121, 'Szilágyi Alíz'), + (122, 'Török Fanni'), + (123, 'Fehér Adél'), + (124, 'Balázs Flóra'), + (125, 'Gál Csenge'); + +INSERT INTO etelkategoria(id, nev) +VALUES (1, 'hamburger'), + (2, 'pizza'), + (3, 'teszta'), + (4, 'koret'), + (5, 'szosz'), + (6, 'udito'), + (7, 'desszert'); + +INSERT INTO menutetel(id, nev, ar, etelkatId) +VALUES (1, 'Boston burger', 2500, 1), + (2, 'Csibe burger', 2200, 1), + (3, 'Impossible burger', 3200, 1), + (4, 'Camambert burger', 2500, 1), + (5, 'Dupla burger', 3100, 1), + (6, 'Halas burger', 2500, 1), + (7, 'Boston pizza 32cm', 2200, 2), + (8, 'Boston pizza 45cm', 4500, 2), + (9, 'Húsimádó pizza 32cm', 2500, 2), + (10, 'Húsimádó pizza 45cm', 5000, 2), + (11, 'Vega pizza 32cm', 2100, 2), + (12, 'Vega pizza 45cm', 4200, 2), + (13, 'SonGoKu 32cm', 2200, 2), + (14, 'SonGoKu 45cm', 4400, 2), + (15, 'Grill pizza 32cm', 23000, 2), + (16, 'Grill pizza 45cm', 2700, 2), + (17, 'Brooklyn Tészta', 2000, 3), + (18, 'Bolognese Tészta', 1800, 3), + (19, 'Con Salmone', 2200, 3), + (20, 'Al Pollo', 2600, 3), + (21, 'Alla chef', 2990, 3), + (22, 'Pesto tészta', 2490, 3), + (23, 'Csirke Pesto', 2690, 3), + (24, 'Pomodoro', 1890, 3), + (25, 'Quattro formaggi gnocchi', 2490, 3), + (26, 'Lasagne', 2690, 3), + (27, 'Tortellini', 2890, 3), + (28, 'Sültkrumpli', 1100, 4), + (29, 'Rizs', 890, 4), + (30, 'Rizibizi', 990, 4), + (31, 'Kukoricasaláta', 1590, 4), + (32, 'Tésztasaláta', 1590, 4), + (33, 'Coleslaw', 1490, 4), + (34, 'Fokahgymás', 450, 5), + (35, 'Kapros', 450, 5), + (36, 'Majonéz', 350, 5), + (37, 'Mustár', 250, 5), + (38, 'Ketchup', 250, 5), + (39, 'Tartár', 350, 5), + (40, 'Édes BBQ', 400, 5), + (41, 'Csípős BBQ', 450, 5), + (42, 'Extra füstös BBQ', 420, 5), + (43, 'Mézes mustár', 400, 5), + (44, 'Coca cola', 450, 6), + (45, 'Pepsi', 450, 6), + (46, 'Fanta', 450, 6), + (47, 'Sprite', 470, 6), + (48, 'Coca cola light', 450, 6), + (49, 'Pepsi zero', 450, 6), + (50, 'Sprite zero', 470, 6), + (51, 'Monsta Energy', 550, 6), + (52, 'Naturaqua', 250, 6), + (53, 'Somlói', 800, 7), + (54, 'Palacsinta mix', 990, 7), + (55, 'Tiramisu', 890, 7); + +insert into rendeles(felhasznaloId, idopont) +VALUES (34, '08:01'), + (39, '08:01'), + (119, '08:01'), + (21, '08:03'), + (105, '08:05'), + (99, '08:10'), + (20, '08:16'), + (104, '08:16'), + (9, '08:17'), + (52, '08:17'), + (73, '08:18'), + (42, '08:26'), + (49, '08:26'), + (71, '08:28'), + (104, '08:30'), + (123, '08:33'), + (61, '08:35'), + (74, '08:35'), + (36, '08:38'), + (79, '08:40'), + (45, '08:40'), + (83, '08:40'), + (88, '08:41'), + (101, '08:41'), + (118, '08:42'), + (74, '08:42'), + (93, '08:42'), + (41, '08:44'), + (124, '08:45'), + (21, '08:45'), + (121, '08:46'), + (116, '08:46'), + (111, '08:48'), + (35, '08:51'), + (43, '08:51'), + (39, '08:53'), + (75, '08:53'), + (123, '08:55'), + (99, '08:56'), + (47, '08:56'), + (86, '08:56'), + (122, '08:57'), + (35, '08:57'), + (12, '08:58'), + (72, '09:01'), + (117, '09:02'), + (110, '09:02'), + (97, '09:06'), + (10, '09:07'), + (106, '09:13'), + (100, '09:14'), + (7, '09:16'), + (26, '09:18'), + (121, '09:19'), + (117, '09:19'), + (2, '09:20'), + (104, '09:22'), + (77, '09:23'), + (95, '09:25'), + (119, '09:32'), + (79, '09:32'), + (19, '09:35'), + (67, '09:39'), + (72, '09:41'), + (86, '09:42'), + (14, '09:46'), + (59, '09:47'), + (20, '09:47'), + (49, '09:48'), + (89, '09:48'), + (19, '09:50'), + (53, '09:52'), + (118, '09:53'), + (89, '09:53'), + (111, '09:53'), + (24, '09:54'), + (30, '09:58'), + (82, '10:03'), + (2, '10:04'), + (49, '10:08'), + (64, '10:15'), + (104, '10:19'), + (93, '10:22'), + (13, '10:22'), + (81, '10:23'), + (36, '10:24'), + (124, '10:25'), + (92, '10:25'), + (56, '10:27'), + (26, '10:28'), + (62, '10:28'), + (28, '10:32'), + (87, '10:37'), + (81, '10:37'), + (37, '10:39'), + (22, '10:41'), + (30, '10:44'), + (60, '10:44'), + (102, '10:45'), + (32, '10:46'), + (86, '10:48'), + (45, '10:48'), + (1, '10:49'), + (41, '10:50'), + (63, '10:51'), + (93, '10:52'), + (95, '10:53'), + (19, '10:53'), + (82, '10:55'), + (31, '10:55'), + (102, '10:56'), + (1, '10:57'), + (61, '10:58'), + (79, '10:59'), + (9, '10:59'), + (98, '11:01'), + (119, '11:04'), + (38, '11:04'), + (106, '11:05'), + (37, '11:07'), + (15, '11:12'), + (41, '11:14'), + (24, '11:14'), + (88, '11:14'), + (32, '11:18'), + (49, '11:18'), + (104, '11:20'), + (75, '11:20'), + (112, '11:20'), + (56, '11:27'), + (36, '11:28'), + (27, '11:29'), + (68, '11:30'), + (72, '11:31'), + (121, '11:34'), + (104, '11:35'), + (105, '11:38'), + (51, '11:42'), + (89, '11:43'), + (22, '11:43'), + (101, '11:43'), + (11, '11:44'), + (62, '11:44'), + (80, '11:45'), + (59, '11:51'), + (98, '11:51'), + (15, '11:54'), + (84, '11:54'), + (58, '11:55'), + (1, '11:55'), + (87, '11:58'), + (96, '11:58'), + (74, '11:59'), + (65, '12:02'), + (86, '12:02'), + (17, '12:02'), + (88, '12:03'), + (69, '12:04'), + (34, '12:05'), + (2, '12:05'), + (29, '12:05'), + (72, '12:06'), + (40, '12:07'), + (26, '12:07'), + (59, '12:08'), + (6, '12:09'), + (92, '12:11'), + (120, '12:11'), + (89, '12:14'), + (8, '12:14'), + (61, '12:15'), + (32, '12:16'), + (2, '12:16'), + (49, '12:17'), + (22, '12:17'), + (102, '12:18'), + (13, '12:19'), + (63, '12:21'), + (119, '12:21'), + (25, '12:23'), + (92, '12:24'), + (120, '12:25'), + (35, '12:26'), + (65, '12:27'), + (16, '12:28'), + (73, '12:29'), + (78, '12:29'), + (30, '12:30'), + (47, '12:31'), + (67, '12:31'), + (6, '12:32'), + (94, '12:33'), + (121, '12:34'), + (45, '12:36'), + (17, '12:37'), + (96, '12:40'), + (97, '12:41'), + (25, '12:41'), + (54, '12:41'), + (110, '12:42'), + (36, '12:42'), + (52, '12:42'), + (36, '12:43'), + (112, '12:44'), + (107, '12:44'), + (110, '12:45'), + (2, '12:45'), + (22, '12:49'), + (58, '12:50'), + (34, '12:50'), + (26, '12:51'), + (49, '12:51'), + (61, '12:52'), + (53, '12:53'), + (6, '12:54'), + (85, '12:54'), + (31, '12:55'), + (118, '12:55'), + (18, '12:57'), + (68, '12:57'), + (106, '12:57'), + (6, '12:58'), + (8, '12:58'), + (67, '12:58'), + (56, '12:58'), + (24, '13:01'), + (84, '13:03'), + (70, '13:04'), + (76, '13:08'), + (10, '13:09'), + (117, '13:10'), + (6, '13:10'), + (44, '13:17'), + (67, '13:18'), + (116, '13:19'), + (37, '13:19'), + (58, '13:21'), + (51, '13:23'), + (21, '13:23'), + (35, '13:24'), + (68, '13:26'), + (66, '13:28'), + (86, '13:30'), + (85, '13:30'), + (1, '13:31'), + (82, '13:33'), + (89, '13:34'), + (5, '13:35'), + (74, '13:39'), + (2, '13:40'), + (1, '13:43'), + (45, '13:44'), + (15, '13:45'), + (82, '13:46'), + (7, '13:46'), + (82, '13:46'), + (55, '13:46'), + (75, '13:49'), + (51, '13:49'), + (92, '13:50'), + (42, '13:50'), + (81, '13:52'), + (109, '13:52'), + (117, '13:52'), + (13, '13:55'), + (120, '13:57'), + (79, '13:57'), + (70, '13:59'), + (97, '14:01'), + (61, '14:02'), + (94, '14:03'), + (63, '14:04'), + (86, '14:07'), + (17, '14:09'), + (105, '14:11'), + (122, '14:12'), + (44, '14:13'), + (63, '14:13'), + (75, '14:14'), + (90, '14:16'), + (23, '14:17'), + (72, '14:19'), + (39, '14:19'), + (27, '14:20'), + (37, '14:24'), + (28, '14:24'), + (81, '14:30'), + (53, '14:32'), + (39, '14:32'), + (84, '14:33'), + (59, '14:34'), + (90, '14:36'), + (104, '14:39'), + (98, '14:40'), + (32, '14:40'), + (105, '14:40'), + (44, '14:43'), + (55, '14:45'), + (91, '14:45'), + (76, '14:45'), + (102, '14:47'), + (82, '14:48'), + (117, '14:52'), + (45, '14:56'), + (43, '14:59'), + (64, '15:01'), + (96, '15:02'), + (82, '15:03'), + (76, '15:04'), + (104, '15:09'), + (58, '15:11'), + (125, '15:11'), + (54, '15:12'), + (32, '15:16'), + (49, '15:17'), + (60, '15:18'), + (103, '15:22'), + (82, '15:22'), + (11, '15:23'), + (54, '15:23'), + (48, '15:24'), + (17, '15:26'), + (88, '15:26'), + (19, '15:29'), + (118, '15:30'), + (18, '15:31'), + (14, '15:31'), + (60, '15:32'), + (49, '15:32'), + (114, '15:37'), + (72, '15:39'), + (35, '15:39'), + (25, '15:40'), + (45, '15:40'), + (64, '15:40'), + (31, '15:41'), + (41, '15:41'), + (101, '15:43'), + (15, '15:43'), + (66, '15:47'), + (107, '15:48'), + (13, '15:52'), + (93, '15:52'), + (21, '15:52'), + (44, '15:54'), + (15, '15:54'), + (46, '15:58'), + (103, '15:59'), + (43, '16:01'), + (88, '16:02'), + (81, '16:05'), + (97, '16:06'), + (68, '16:07'), + (28, '16:09'), + (48, '16:10'), + (66, '16:18'), + (40, '16:19'), + (59, '16:19'), + (6, '16:22'), + (17, '16:22'), + (45, '16:22'), + (119, '16:24'), + (15, '16:26'), + (25, '16:28'), + (110, '16:28'), + (61, '16:32'), + (24, '16:36'), + (121, '16:38'), + (116, '16:40'), + (104, '16:40'), + (44, '16:42'), + (53, '16:44'), + (82, '16:44'), + (109, '16:44'), + (33, '16:45'), + (37, '16:47'), + (8, '16:48'), + (20, '16:51'), + (63, '16:51'), + (50, '16:55'), + (51, '16:55'), + (117, '16:57'), + (15, '16:59'), + (119, '16:59'), + (114, '17:01'), + (102, '17:01'), + (7, '17:02'), + (50, '17:04'), + (21, '17:08'), + (93, '17:10'), + (56, '17:11'), + (33, '17:11'), + (5, '17:12'), + (53, '17:13'), + (95, '17:13'), + (124, '17:14'), + (20, '17:16'), + (94, '17:18'), + (6, '17:19'), + (26, '17:20'), + (78, '17:22'), + (114, '17:22'), + (63, '17:24'), + (3, '17:24'), + (95, '17:25'), + (9, '17:25'), + (76, '17:30'), + (67, '17:31'), + (69, '17:31'), + (15, '17:32'), + (75, '17:32'), + (113, '17:39'), + (42, '17:40'), + (31, '17:42'), + (123, '17:43'), + (88, '17:43'), + (54, '17:45'), + (65, '17:50'), + (45, '17:53'), + (106, '17:54'), + (106, '17:54'), + (11, '17:55'), + (83, '17:56'), + (110, '17:57'), + (105, '18:01'), + (76, '18:04'), + (35, '18:04'), + (26, '18:05'), + (18, '18:08'), + (2, '18:09'), + (34, '18:14'), + (49, '18:16'), + (115, '18:18'), + (21, '18:21'), + (24, '18:22'), + (105, '18:23'), + (62, '18:25'), + (45, '18:26'), + (64, '18:28'), + (56, '18:28'), + (117, '18:30'), + (122, '18:30'), + (122, '18:32'), + (4, '18:32'), + (86, '18:35'), + (6, '18:35'), + (36, '18:35'), + (101, '18:36'), + (80, '18:37'), + (46, '18:38'), + (99, '18:41'), + (124, '18:45'), + (14, '18:47'), + (119, '18:49'), + (41, '18:49'), + (34, '18:53'), + (124, '18:54'), + (9, '18:57'), + (17, '19:03'), + (84, '19:04'), + (96, '19:06'), + (1, '19:06'), + (106, '19:08'), + (123, '19:09'), + (47, '19:09'), + (86, '19:10'), + (112, '19:14'), + (82, '19:15'), + (118, '19:16'), + (12, '19:16'), + (90, '19:17'), + (92, '19:17'), + (58, '19:20'), + (30, '19:21'), + (12, '19:21'), + (18, '19:22'), + (93, '19:22'), + (120, '19:26'), + (6, '19:29'), + (34, '19:30'), + (94, '19:30'), + (4, '19:33'), + (114, '19:34'), + (78, '19:37'), + (64, '19:37'), + (116, '19:40'), + (25, '19:40'), + (108, '19:42'), + (52, '19:43'), + (107, '19:49'), + (73, '19:50'), + (57, '19:50'), + (123, '19:52'), + (28, '19:52'), + (63, '19:53'), + (105, '19:54'), + (92, '19:55'), + (66, '19:56'), + (2, '19:57'), + (119, '19:58'); + +insert into rendeleselem(rendelesId, menutetelId, mennyiseg) +VALUES (1, 52, 1), + (1, 28, 2), + (1, 25, 2), + (2, 37, 1), + (2, 21, 2), + (2, 3, 1), + (2, 19, 2), + (2, 7, 2), + (3, 25, 1), + (3, 20, 2), + (4, 16, 2), + (4, 22, 1), + (4, 30, 1), + (5, 47, 1), + (5, 29, 2), + (5, 16, 2), + (5, 3, 1), + (6, 44, 2), + (6, 18, 1), + (6, 33, 1), + (7, 23, 1), + (7, 29, 2), + (7, 45, 1), + (8, 5, 1), + (8, 3, 2), + (8, 15, 1), + (8, 28, 1), + (8, 5, 1), + (8, 46, 1), + (9, 37, 2), + (9, 8, 1), + (9, 17, 2), + (9, 35, 2), + (10, 39, 2), + (10, 46, 1), + (10, 52, 1), + (10, 20, 2), + (10, 11, 1), + (10, 19, 1), + (11, 48, 2), + (11, 17, 1), + (11, 40, 1), + (11, 7, 1), + (11, 46, 1), + (12, 51, 2), + (12, 14, 1), + (12, 22, 1), + (13, 8, 1), + (13, 5, 1), + (13, 3, 1), + (13, 21, 1), + (14, 11, 1), + (14, 40, 1), + (14, 9, 1), + (14, 6, 1), + (15, 28, 2), + (15, 33, 1), + (15, 18, 1), + (15, 22, 2), + (16, 42, 1), + (16, 26, 2), + (16, 37, 2), + (16, 18, 1), + (16, 12, 1), + (17, 4, 1), + (17, 51, 1), + (17, 30, 2), + (18, 9, 1), + (18, 47, 2), + (18, 33, 1), + (18, 51, 3), + (19, 36, 2), + (19, 2, 2), + (19, 45, 2), + (19, 52, 1), + (19, 2, 1), + (20, 27, 1), + (20, 33, 2), + (20, 28, 2), + (20, 29, 1), + (21, 46, 1), + (21, 39, 1), + (21, 16, 1), + (21, 44, 2), + (22, 32, 1), + (22, 32, 1), + (22, 27, 1), + (22, 4, 2), + (23, 46, 1), + (23, 1, 1), + (23, 18, 1), + (23, 11, 1), + (23, 19, 1), + (24, 12, 1), + (24, 48, 2), + (24, 13, 1), + (24, 10, 1), + (25, 52, 3), + (25, 12, 1), + (25, 40, 2), + (25, 12, 1), + (25, 13, 1), + (26, 9, 1), + (26, 27, 1), + (26, 33, 1), + (26, 33, 1), + (26, 36, 1), + (27, 7, 1), + (27, 24, 1), + (27, 27, 2), + (28, 17, 2), + (28, 42, 1), + (28, 15, 1), + (28, 29, 2), + (29, 48, 1), + (29, 39, 1), + (29, 52, 1), + (29, 45, 1), + (30, 17, 2), + (30, 27, 3), + (30, 31, 2), + (30, 30, 2), + (31, 19, 1), + (31, 53, 2), + (31, 5, 1), + (31, 30, 1), + (32, 27, 2), + (32, 44, 2), + (32, 28, 1), + (32, 20, 2), + (33, 20, 2), + (33, 17, 1), + (34, 37, 2), + (34, 4, 1), + (34, 52, 2), + (34, 49, 1), + (35, 19, 3), + (35, 28, 1), + (35, 42, 1), + (36, 29, 1), + (36, 18, 1), + (36, 9, 1), + (36, 53, 1), + (36, 30, 1), + (37, 18, 1), + (37, 12, 2), + (37, 35, 2), + (37, 19, 1), + (38, 15, 1), + (38, 41, 3), + (38, 45, 1), + (38, 1, 1), + (39, 33, 2), + (39, 8, 2), + (40, 30, 1), + (40, 41, 1), + (40, 31, 1), + (40, 20, 1), + (41, 48, 1), + (41, 17, 1), + (41, 13, 3), + (41, 52, 1), + (41, 41, 1), + (42, 12, 2), + (42, 40, 1), + (42, 33, 3), + (42, 6, 2), + (43, 13, 2), + (43, 52, 1), + (43, 52, 1), + (43, 6, 2), + (44, 27, 1), + (44, 20, 2), + (44, 16, 2), + (44, 33, 2), + (45, 1, 1), + (45, 51, 1), + (45, 53, 1), + (45, 15, 1), + (45, 33, 1), + (45, 38, 1), + (45, 45, 1), + (45, 24, 1), + (46, 12, 2), + (46, 23, 1), + (46, 34, 1), + (46, 19, 1), + (47, 14, 1), + (47, 49, 1), + (47, 45, 1), + (47, 41, 2), + (48, 9, 1), + (48, 3, 1), + (48, 15, 1), + (49, 39, 1), + (49, 17, 1), + (49, 20, 3), + (49, 14, 1), + (50, 27, 1), + (50, 2, 1), + (50, 27, 1), + (50, 21, 1), + (51, 39, 1), + (51, 8, 1), + (51, 48, 1), + (51, 23, 1), + (52, 38, 1), + (52, 17, 1), + (52, 43, 1), + (52, 3, 1), + (52, 36, 1), + (53, 39, 1), + (53, 46, 1), + (53, 7, 2), + (53, 13, 1), + (53, 9, 1), + (53, 36, 1), + (54, 41, 1), + (54, 34, 1), + (54, 33, 2), + (54, 24, 1), + (54, 2, 2), + (55, 2, 1), + (55, 52, 2), + (55, 24, 2), + (55, 5, 1), + (56, 22, 1), + (56, 3, 1), + (56, 1, 1), + (57, 12, 1), + (57, 49, 3), + (57, 7, 1), + (57, 51, 1), + (57, 47, 1), + (58, 20, 1), + (58, 45, 2), + (58, 52, 1), + (58, 51, 1), + (58, 16, 1), + (59, 10, 2), + (59, 53, 1), + (59, 22, 1), + (59, 19, 1), + (60, 4, 1), + (60, 36, 2), + (60, 35, 1), + (60, 19, 1), + (61, 26, 1), + (61, 3, 1), + (61, 19, 2), + (61, 14, 2), + (61, 18, 2), + (62, 10, 2), + (62, 6, 2), + (62, 16, 1), + (62, 26, 2), + (63, 41, 1), + (63, 34, 2), + (63, 23, 1), + (63, 7, 1), + (64, 32, 1), + (64, 45, 1), + (64, 31, 2), + (64, 28, 3), + (65, 22, 1), + (65, 16, 1), + (65, 3, 1), + (66, 15, 2), + (66, 52, 3), + (66, 19, 3), + (66, 14, 1), + (67, 52, 1), + (67, 35, 1), + (67, 19, 1), + (67, 37, 2), + (68, 5, 1), + (68, 1, 2), + (68, 22, 2), + (69, 34, 1), + (69, 36, 1), + (69, 12, 1), + (69, 45, 1), + (70, 31, 1), + (70, 37, 1), + (70, 31, 2), + (71, 15, 1), + (71, 35, 1), + (71, 9, 2), + (71, 41, 1), + (71, 41, 1), + (72, 27, 1), + (72, 53, 2), + (72, 1, 1), + (73, 14, 1), + (73, 10, 1), + (73, 22, 1), + (74, 10, 1), + (74, 12, 1), + (74, 16, 1), + (74, 29, 1), + (75, 19, 1), + (75, 20, 1), + (75, 21, 2), + (75, 1, 2), + (75, 25, 1), + (76, 40, 1), + (76, 26, 1), + (76, 50, 2), + (76, 4, 2), + (76, 43, 1), + (77, 32, 1), + (77, 31, 2), + (77, 36, 3), + (78, 5, 1), + (78, 5, 1), + (79, 10, 2), + (79, 23, 1), + (79, 10, 1), + (79, 39, 1), + (79, 44, 2), + (79, 4, 1), + (79, 47, 1), + (80, 5, 2), + (80, 20, 2), + (80, 25, 1), + (80, 49, 1), + (81, 33, 1), + (81, 5, 1), + (81, 25, 2), + (81, 45, 1), + (81, 44, 1), + (82, 13, 2), + (82, 35, 2), + (82, 24, 1), + (83, 36, 2), + (83, 49, 1), + (83, 37, 2), + (84, 10, 1), + (84, 32, 3), + (84, 52, 1), + (85, 36, 1), + (85, 28, 1), + (85, 19, 1), + (85, 48, 2), + (86, 47, 1), + (86, 29, 1), + (86, 45, 1), + (86, 39, 2), + (87, 27, 1), + (87, 26, 1), + (87, 38, 1), + (87, 6, 1), + (87, 46, 2), + (87, 36, 2), + (88, 15, 2), + (88, 35, 2), + (88, 41, 1), + (88, 52, 2), + (88, 27, 1), + (89, 50, 1), + (89, 26, 2), + (89, 35, 1), + (90, 31, 1), + (90, 12, 1), + (90, 47, 1), + (90, 46, 2), + (91, 23, 1), + (91, 49, 2), + (91, 18, 2), + (91, 17, 1), + (92, 22, 1), + (92, 44, 1), + (92, 17, 1), + (93, 37, 1), + (93, 13, 1), + (93, 32, 2), + (94, 28, 1), + (94, 36, 2), + (94, 52, 1), + (94, 39, 1), + (94, 18, 1), + (95, 45, 2), + (95, 31, 1), + (95, 34, 1), + (95, 51, 1), + (96, 28, 1), + (96, 7, 3), + (96, 46, 1), + (96, 53, 1), + (96, 23, 2), + (97, 6, 2), + (97, 30, 1), + (97, 49, 1), + (98, 18, 2), + (98, 15, 3), + (98, 50, 1), + (98, 18, 1), + (98, 12, 1), + (99, 44, 2), + (99, 29, 1), + (99, 1, 2), + (100, 48, 2), + (100, 42, 1), + (100, 46, 1), + (100, 2, 2), + (101, 33, 1), + (101, 5, 1), + (101, 5, 2), + (101, 29, 1), + (102, 19, 1), + (102, 12, 1), + (102, 35, 2), + (102, 9, 2), + (102, 34, 1), + (102, 1, 1), + (102, 36, 1), + (103, 41, 1), + (103, 18, 2), + (103, 46, 1), + (103, 51, 1), + (104, 48, 2), + (104, 34, 1), + (105, 24, 1), + (105, 31, 1), + (105, 6, 2), + (105, 33, 2), + (106, 16, 1), + (106, 42, 1), + (106, 7, 1), + (107, 45, 1), + (107, 14, 1), + (107, 5, 1), + (107, 2, 1), + (108, 43, 1), + (108, 42, 1), + (108, 38, 1), + (108, 41, 1), + (109, 30, 2), + (109, 40, 1), + (109, 33, 1), + (110, 4, 1), + (110, 53, 1), + (110, 17, 1), + (111, 36, 2), + (111, 11, 1), + (111, 11, 2), + (111, 29, 1), + (112, 19, 1), + (112, 1, 1), + (112, 4, 1), + (113, 51, 2), + (113, 49, 1), + (113, 50, 1), + (113, 28, 1), + (113, 19, 1), + (113, 35, 1), + (114, 7, 2), + (114, 34, 1), + (114, 29, 1), + (114, 5, 2), + (115, 33, 1), + (115, 7, 1), + (115, 48, 2), + (115, 33, 1), + (116, 38, 2), + (116, 27, 1), + (116, 27, 2), + (117, 35, 1), + (117, 44, 2), + (117, 37, 1), + (118, 9, 2), + (118, 27, 2), + (118, 33, 1), + (118, 41, 2), + (119, 3, 1), + (119, 27, 2), + (119, 51, 2), + (120, 7, 1), + (120, 36, 1), + (121, 32, 1), + (121, 31, 1), + (121, 10, 1), + (121, 16, 1), + (122, 40, 1), + (122, 13, 2), + (122, 49, 1), + (123, 41, 1), + (123, 49, 2), + (123, 37, 1), + (123, 44, 2), + (123, 49, 2), + (124, 39, 1), + (124, 39, 1), + (124, 28, 1), + (125, 24, 1), + (125, 4, 3), + (125, 34, 2), + (125, 30, 1), + (126, 3, 2), + (126, 40, 3), + (126, 31, 2), + (126, 3, 2), + (127, 38, 1), + (127, 9, 2), + (127, 53, 1), + (127, 45, 2), + (128, 7, 1), + (128, 41, 1), + (128, 25, 1), + (129, 49, 1), + (129, 28, 1), + (129, 19, 2), + (130, 26, 1), + (130, 43, 2), + (131, 42, 2), + (131, 16, 1), + (131, 10, 1), + (131, 26, 1), + (131, 34, 2), + (132, 49, 1), + (132, 20, 2), + (133, 17, 1), + (133, 34, 1), + (133, 7, 1), + (133, 38, 2), + (134, 12, 2), + (134, 31, 2), + (134, 8, 1), + (134, 3, 1), + (135, 38, 1), + (135, 38, 2), + (135, 18, 1), + (135, 36, 2), + (135, 40, 1), + (135, 19, 2), + (136, 25, 1), + (136, 3, 2), + (136, 43, 1), + (136, 41, 2), + (136, 19, 1), + (137, 38, 1), + (137, 36, 1), + (137, 22, 1), + (137, 50, 2), + (138, 7, 1), + (138, 29, 1), + (138, 28, 1), + (139, 6, 1), + (139, 10, 1), + (139, 18, 2), + (139, 9, 1), + (140, 24, 2), + (140, 37, 1), + (140, 31, 1), + (140, 51, 2), + (141, 2, 1), + (141, 47, 1), + (141, 35, 1), + (141, 44, 1), + (142, 15, 2), + (142, 31, 1), + (142, 45, 3), + (142, 47, 1), + (142, 15, 1), + (143, 43, 1), + (143, 21, 2), + (143, 19, 1), + (143, 27, 1), + (144, 16, 1), + (144, 48, 1), + (144, 51, 1), + (144, 13, 1), + (145, 1, 3), + (145, 2, 1), + (145, 37, 1), + (145, 52, 1), + (146, 7, 3), + (146, 45, 1), + (146, 40, 1), + (146, 19, 1), + (146, 39, 2), + (147, 20, 1), + (147, 7, 1), + (147, 35, 2), + (148, 44, 2), + (148, 36, 1), + (148, 53, 1), + (148, 7, 1), + (149, 3, 1), + (149, 43, 1), + (149, 47, 1), + (149, 33, 1), + (150, 22, 2), + (150, 14, 1), + (150, 7, 1), + (150, 19, 2), + (151, 43, 3), + (151, 3, 2), + (151, 37, 1), + (151, 35, 1), + (152, 1, 1), + (152, 2, 3), + (152, 6, 2), + (152, 51, 1), + (153, 29, 2), + (153, 28, 1), + (153, 14, 1), + (153, 50, 2), + (154, 32, 1), + (154, 1, 1), + (154, 41, 2), + (154, 15, 1), + (155, 15, 2), + (155, 25, 1), + (155, 45, 1), + (156, 27, 1), + (156, 36, 1), + (156, 6, 1), + (156, 26, 2), + (156, 18, 1), + (157, 31, 2), + (157, 25, 1), + (157, 10, 1), + (157, 24, 1), + (158, 34, 2), + (158, 24, 2), + (158, 46, 2), + (158, 24, 2), + (159, 26, 1), + (159, 12, 1), + (159, 51, 2), + (160, 15, 1), + (160, 47, 2), + (160, 50, 1), + (161, 50, 2), + (161, 25, 1), + (161, 14, 2), + (161, 7, 1), + (162, 14, 1), + (162, 51, 1), + (162, 23, 2), + (163, 42, 1), + (163, 33, 1), + (163, 8, 1), + (163, 22, 2), + (164, 45, 1), + (164, 39, 2), + (164, 18, 2), + (164, 15, 1), + (165, 37, 1), + (165, 26, 1), + (165, 1, 1), + (166, 22, 2), + (166, 19, 2), + (166, 36, 1), + (167, 9, 1), + (167, 28, 1), + (167, 40, 2), + (167, 37, 1), + (168, 38, 1), + (168, 33, 1), + (168, 45, 3), + (168, 12, 2), + (169, 20, 1), + (169, 2, 1), + (169, 49, 1), + (169, 43, 1), + (170, 5, 2), + (170, 23, 1), + (170, 26, 2), + (171, 16, 1), + (171, 7, 2), + (171, 19, 1), + (171, 24, 2), + (171, 10, 1), + (172, 48, 2), + (172, 11, 2), + (172, 1, 1), + (173, 12, 3), + (173, 6, 1), + (173, 26, 1), + (174, 31, 1), + (174, 32, 1), + (174, 45, 1), + (174, 1, 1), + (174, 22, 2), + (175, 53, 1), + (175, 8, 2), + (175, 25, 1), + (176, 23, 1), + (176, 11, 1), + (176, 43, 1), + (177, 1, 2), + (177, 13, 3), + (177, 18, 2), + (177, 14, 2), + (178, 3, 1), + (178, 25, 1), + (178, 36, 1), + (178, 19, 4), + (179, 31, 2), + (179, 18, 1), + (179, 13, 1), + (180, 32, 1), + (180, 25, 1), + (180, 2, 1), + (181, 43, 2), + (181, 16, 1), + (181, 45, 1), + (181, 4, 1), + (182, 12, 1), + (182, 22, 2), + (183, 3, 1), + (183, 1, 2), + (183, 23, 1), + (183, 5, 2), + (184, 19, 2), + (184, 7, 1), + (184, 31, 1), + (184, 40, 1), + (184, 5, 2), + (184, 16, 1), + (185, 7, 1), + (185, 11, 1), + (185, 22, 2), + (185, 49, 1), + (185, 15, 1), + (185, 7, 1), + (186, 1, 1), + (186, 15, 2), + (186, 42, 1), + (187, 9, 2), + (187, 27, 1), + (187, 44, 1), + (187, 52, 1), + (188, 4, 1), + (188, 16, 1), + (188, 43, 2), + (188, 26, 1), + (189, 24, 2), + (189, 32, 1), + (189, 34, 1), + (189, 2, 1), + (190, 35, 2), + (190, 23, 1), + (190, 33, 1), + (190, 45, 1), + (191, 29, 1), + (191, 6, 2), + (191, 25, 2), + (192, 47, 1), + (192, 44, 1), + (192, 21, 2), + (192, 34, 2), + (193, 10, 1), + (193, 36, 2), + (193, 38, 1), + (193, 13, 1), + (194, 17, 2), + (194, 2, 1), + (194, 25, 1), + (194, 17, 1), + (195, 19, 2), + (195, 49, 1), + (195, 3, 1), + (195, 4, 2), + (196, 29, 1), + (196, 13, 1), + (196, 12, 1), + (196, 42, 1), + (197, 47, 1), + (197, 44, 1), + (197, 41, 1), + (197, 1, 1), + (197, 35, 2), + (198, 17, 2), + (198, 50, 1), + (198, 10, 1), + (199, 6, 1), + (199, 45, 1), + (199, 35, 2), + (199, 5, 1), + (200, 7, 1), + (200, 18, 2), + (200, 42, 1), + (201, 35, 1), + (201, 45, 1), + (202, 50, 1), + (202, 17, 1), + (202, 37, 2), + (202, 46, 1), + (203, 44, 1), + (203, 41, 2), + (203, 47, 1), + (203, 26, 2), + (203, 26, 1), + (204, 19, 2), + (204, 49, 2), + (204, 26, 2), + (205, 16, 2), + (205, 42, 1), + (205, 40, 2), + (205, 16, 1), + (206, 13, 2), + (206, 6, 1), + (206, 37, 1), + (207, 1, 1), + (207, 5, 1), + (207, 34, 1), + (208, 26, 1), + (208, 30, 1), + (208, 38, 1), + (209, 14, 1), + (209, 12, 1), + (209, 1, 1), + (209, 36, 1), + (209, 5, 2), + (210, 29, 1), + (210, 41, 1), + (210, 6, 2), + (210, 20, 2), + (210, 18, 1), + (211, 31, 2), + (211, 38, 1), + (211, 15, 1), + (211, 11, 1), + (212, 46, 1), + (212, 46, 1), + (212, 18, 1), + (212, 35, 1), + (213, 53, 1), + (213, 43, 1), + (213, 44, 1), + (213, 31, 1), + (214, 43, 1), + (214, 36, 2), + (214, 19, 1), + (214, 48, 1), + (215, 42, 2), + (215, 27, 2), + (215, 37, 2), + (215, 12, 3), + (216, 1, 1), + (216, 49, 1), + (216, 13, 1), + (216, 16, 1), + (216, 28, 1), + (217, 49, 1), + (217, 5, 1), + (217, 34, 1), + (218, 4, 1), + (218, 29, 1), + (218, 4, 2), + (219, 29, 2), + (219, 21, 1), + (219, 19, 1), + (219, 11, 1), + (220, 31, 1), + (220, 1, 2), + (220, 18, 1), + (220, 43, 2), + (221, 43, 1), + (221, 18, 2), + (221, 26, 2), + (221, 51, 1), + (222, 19, 2), + (222, 10, 2), + (222, 36, 2), + (222, 38, 2), + (223, 12, 1), + (223, 22, 1), + (223, 51, 1), + (224, 1, 2), + (224, 53, 1), + (224, 51, 2), + (224, 37, 1), + (224, 41, 1), + (225, 20, 1), + (225, 30, 2), + (225, 41, 1), + (225, 36, 1), + (225, 27, 1), + (226, 11, 1), + (226, 47, 2), + (226, 47, 1), + (226, 22, 1), + (227, 32, 1), + (227, 7, 2), + (227, 41, 2), + (227, 42, 2), + (228, 28, 1), + (228, 25, 1), + (228, 43, 1), + (228, 29, 1), + (229, 6, 3), + (229, 29, 2), + (229, 3, 2), + (229, 43, 1), + (230, 42, 1), + (230, 8, 1), + (230, 40, 1), + (230, 53, 2), + (231, 8, 3), + (231, 45, 1), + (231, 47, 1), + (231, 30, 2), + (231, 30, 1), + (232, 34, 1), + (232, 31, 2), + (232, 25, 2), + (232, 14, 1), + (232, 32, 2), + (233, 34, 1), + (233, 53, 1), + (234, 35, 1), + (234, 15, 2), + (234, 3, 1), + (234, 31, 2), + (234, 38, 1), + (234, 10, 2), + (234, 29, 2), + (235, 37, 1), + (235, 20, 1), + (235, 48, 2), + (235, 38, 1), + (236, 35, 1), + (236, 18, 1), + (236, 9, 1), + (236, 7, 2), + (236, 19, 1), + (237, 40, 1), + (237, 10, 2), + (237, 47, 1), + (238, 28, 2), + (238, 49, 1), + (238, 3, 1), + (238, 48, 1), + (238, 40, 1), + (239, 17, 2), + (239, 33, 1), + (239, 52, 1), + (240, 5, 1), + (240, 47, 1), + (240, 7, 1), + (240, 25, 1), + (241, 10, 1), + (241, 51, 1), + (241, 28, 1), + (241, 31, 1), + (241, 10, 1), + (242, 47, 1), + (242, 12, 1), + (242, 47, 1), + (242, 46, 1), + (243, 5, 2), + (243, 5, 1), + (243, 8, 1), + (243, 23, 1), + (244, 39, 2), + (244, 29, 1), + (244, 25, 1), + (244, 16, 1), + (245, 51, 1), + (245, 7, 1), + (245, 12, 1), + (245, 18, 1), + (245, 40, 1), + (246, 13, 1), + (246, 1, 1), + (246, 2, 3), + (246, 26, 1), + (247, 41, 2), + (247, 53, 1), + (247, 7, 2), + (247, 51, 1), + (248, 14, 1), + (248, 10, 2), + (248, 23, 1), + (248, 4, 1), + (248, 32, 1), + (249, 11, 2), + (249, 17, 1), + (249, 2, 1), + (249, 27, 2), + (249, 45, 2), + (250, 21, 1), + (250, 46, 1), + (250, 39, 1), + (250, 6, 2), + (251, 37, 1), + (251, 23, 1), + (251, 50, 1), + (251, 25, 1), + (252, 11, 1), + (252, 15, 1), + (252, 46, 1), + (253, 25, 1), + (253, 25, 1), + (253, 18, 1), + (253, 43, 1), + (253, 11, 1), + (253, 12, 1), + (254, 17, 1), + (254, 42, 1), + (254, 27, 1), + (254, 36, 1), + (255, 21, 1), + (255, 13, 1), + (255, 15, 1), + (255, 40, 1), + (255, 48, 1), + (256, 48, 1), + (256, 8, 1), + (256, 38, 1), + (257, 42, 1), + (257, 48, 1), + (257, 52, 2), + (258, 20, 2), + (258, 1, 1), + (258, 39, 1), + (259, 16, 2), + (259, 38, 2), + (259, 7, 1), + (259, 39, 2), + (259, 44, 1), + (259, 22, 1), + (260, 1, 3), + (260, 10, 1), + (260, 27, 2), + (260, 26, 1), + (260, 36, 1), + (261, 26, 1), + (261, 5, 1), + (261, 40, 2), + (261, 16, 2), + (262, 11, 1), + (262, 38, 1), + (262, 47, 1), + (262, 53, 1), + (263, 39, 2), + (263, 9, 1), + (263, 41, 1), + (263, 43, 1), + (264, 49, 1), + (264, 31, 2), + (264, 53, 1), + (265, 46, 1), + (265, 27, 2), + (265, 52, 1), + (266, 11, 1), + (266, 22, 2), + (266, 30, 2), + (266, 26, 1), + (267, 17, 1), + (267, 36, 1), + (267, 10, 1), + (267, 3, 1), + (268, 21, 3), + (268, 19, 1), + (268, 23, 3), + (268, 9, 1), + (269, 41, 1), + (269, 50, 1), + (269, 13, 1), + (269, 33, 1), + (270, 34, 2), + (270, 51, 1), + (270, 5, 2), + (271, 52, 1), + (271, 41, 1), + (271, 44, 2), + (272, 53, 1), + (272, 10, 2), + (272, 4, 1), + (272, 35, 1), + (273, 30, 1), + (273, 39, 2), + (273, 34, 2), + (274, 42, 1), + (274, 49, 1), + (274, 14, 2), + (275, 52, 2), + (275, 39, 1), + (275, 30, 2), + (275, 22, 1), + (276, 19, 1), + (276, 30, 1), + (276, 21, 1), + (276, 32, 1), + (277, 3, 1), + (277, 13, 2), + (277, 26, 2), + (278, 6, 1), + (278, 37, 1), + (278, 20, 3), + (278, 47, 1), + (279, 33, 1), + (279, 40, 1), + (279, 43, 1), + (280, 46, 1), + (280, 13, 2), + (280, 12, 2), + (281, 4, 1), + (281, 8, 1), + (281, 44, 2), + (281, 27, 1), + (281, 48, 1), + (281, 48, 1), + (281, 48, 2), + (282, 35, 1), + (282, 24, 2), + (282, 17, 2), + (282, 2, 1), + (283, 9, 2), + (283, 53, 2), + (283, 35, 2), + (283, 30, 1), + (283, 17, 1), + (284, 17, 1), + (284, 39, 1), + (284, 7, 2), + (284, 18, 1), + (285, 28, 1), + (285, 27, 2), + (285, 28, 2), + (286, 39, 1), + (286, 8, 1), + (286, 16, 2), + (286, 13, 1), + (287, 30, 1), + (287, 4, 1), + (287, 51, 1), + (287, 5, 1), + (288, 15, 2), + (288, 5, 1), + (288, 18, 2), + (288, 53, 2), + (288, 25, 1), + (289, 23, 1), + (289, 46, 2), + (289, 36, 1), + (289, 52, 1), + (289, 3, 1), + (290, 53, 1), + (290, 22, 1), + (290, 16, 1), + (290, 19, 1), + (290, 34, 1), + (291, 34, 1), + (291, 42, 1), + (291, 36, 1), + (291, 45, 2), + (291, 11, 1), + (292, 15, 1), + (292, 14, 1), + (292, 47, 1), + (293, 52, 3), + (293, 8, 1), + (293, 46, 1), + (294, 21, 1), + (294, 44, 1), + (294, 22, 1), + (294, 19, 1), + (295, 13, 1), + (295, 48, 1), + (295, 40, 1), + (295, 3, 2), + (296, 24, 1), + (296, 42, 1), + (296, 50, 1), + (296, 27, 1), + (296, 37, 2), + (296, 47, 1), + (297, 6, 2), + (297, 29, 1), + (297, 30, 1), + (297, 28, 1), + (298, 40, 1), + (298, 6, 2), + (298, 39, 2), + (298, 24, 1), + (298, 29, 1), + (298, 46, 1), + (299, 12, 2), + (299, 43, 1), + (300, 7, 1), + (300, 26, 1), + (300, 3, 2), + (301, 27, 2), + (301, 11, 1), + (301, 49, 2), + (301, 31, 1), + (302, 27, 1), + (302, 9, 1), + (302, 1, 2), + (303, 28, 2), + (303, 6, 1), + (303, 29, 1), + (304, 29, 1), + (304, 20, 1), + (304, 44, 1), + (304, 21, 2), + (305, 28, 2), + (305, 4, 2), + (305, 26, 2), + (306, 43, 1), + (306, 51, 1), + (306, 23, 1), + (307, 6, 1), + (307, 42, 1), + (307, 30, 3), + (308, 1, 2), + (308, 42, 2), + (308, 27, 1), + (308, 3, 1), + (309, 30, 1), + (309, 43, 1), + (309, 27, 2), + (309, 46, 3), + (310, 53, 1), + (310, 48, 4), + (310, 49, 1), + (311, 13, 2), + (311, 16, 1), + (311, 42, 2), + (311, 47, 2), + (312, 37, 1), + (312, 45, 1), + (312, 50, 1), + (312, 40, 1), + (312, 3, 2), + (313, 47, 1), + (313, 15, 2), + (313, 35, 2), + (313, 31, 2), + (314, 20, 1), + (314, 13, 1), + (315, 5, 1), + (315, 12, 1), + (315, 17, 1), + (316, 47, 2), + (316, 44, 1), + (316, 25, 1), + (317, 42, 1), + (317, 8, 1), + (317, 6, 1), + (317, 49, 1), + (318, 36, 2), + (318, 11, 2), + (318, 34, 1), + (319, 6, 2), + (319, 24, 1), + (319, 42, 3), + (320, 42, 1), + (320, 34, 1), + (320, 14, 1), + (320, 7, 1), + (320, 39, 1), + (321, 27, 1), + (321, 11, 2), + (321, 43, 2), + (321, 31, 1), + (322, 3, 1), + (322, 44, 2), + (322, 4, 1), + (322, 27, 1), + (323, 8, 2), + (323, 35, 2), + (323, 39, 1), + (323, 49, 2), + (324, 2, 2), + (324, 19, 1), + (324, 34, 2), + (325, 43, 1), + (325, 44, 1), + (325, 38, 2), + (325, 44, 1), + (325, 2, 3), + (325, 10, 2), + (326, 25, 1), + (326, 12, 1), + (326, 28, 2), + (326, 8, 1), + (327, 16, 1), + (327, 3, 2), + (327, 14, 1), + (328, 47, 1), + (328, 32, 1), + (328, 28, 2), + (328, 38, 1), + (328, 8, 1), + (329, 43, 1), + (329, 14, 1), + (329, 18, 1), + (329, 38, 1), + (330, 25, 2), + (330, 29, 2), + (330, 7, 1), + (331, 19, 1), + (331, 10, 3), + (331, 11, 1), + (331, 19, 1), + (332, 45, 1), + (332, 8, 1), + (333, 19, 1), + (333, 53, 1), + (333, 16, 2), + (333, 53, 1), + (333, 5, 1), + (334, 5, 1), + (334, 16, 1), + (334, 46, 1), + (334, 11, 2), + (335, 51, 1), + (335, 30, 1), + (335, 4, 1), + (336, 48, 1), + (336, 24, 1), + (336, 28, 1), + (336, 7, 1), + (337, 1, 1), + (337, 3, 1), + (337, 30, 1), + (337, 14, 1), + (338, 29, 1), + (338, 9, 1), + (338, 36, 1), + (338, 41, 2), + (338, 34, 2), + (338, 4, 2), + (339, 26, 1), + (339, 16, 1), + (339, 50, 1), + (339, 16, 1), + (340, 42, 1), + (340, 28, 1), + (340, 47, 1), + (341, 31, 1), + (341, 12, 1), + (341, 6, 1), + (341, 16, 1), + (342, 10, 2), + (342, 10, 2), + (342, 45, 2), + (343, 51, 1), + (343, 24, 2), + (343, 31, 1), + (343, 2, 1), + (344, 41, 1), + (344, 41, 1), + (344, 1, 1), + (344, 4, 1), + (344, 7, 1), + (344, 5, 1), + (345, 41, 1), + (345, 14, 1), + (345, 31, 1), + (345, 20, 1), + (346, 29, 1), + (346, 17, 1), + (346, 36, 1), + (347, 46, 1), + (347, 12, 1), + (347, 49, 1), + (347, 24, 1), + (347, 23, 1), + (347, 50, 1), + (348, 49, 1), + (348, 35, 1), + (348, 25, 2), + (348, 30, 1), + (348, 35, 2), + (348, 18, 1), + (349, 45, 2), + (349, 40, 1), + (349, 26, 2), + (349, 42, 1), + (350, 16, 3), + (350, 22, 1), + (351, 51, 2), + (351, 31, 1), + (351, 21, 2), + (351, 6, 1), + (351, 53, 1), + (352, 34, 1), + (352, 41, 1), + (352, 6, 1), + (352, 2, 1), + (352, 2, 2), + (353, 36, 2), + (353, 47, 1), + (354, 24, 1), + (354, 43, 1), + (354, 48, 1), + (355, 17, 1), + (355, 30, 2), + (355, 39, 1), + (355, 30, 2), + (356, 50, 2), + (356, 4, 1), + (356, 42, 1), + (356, 52, 1), + (357, 38, 1), + (357, 18, 1), + (357, 52, 3), + (357, 29, 1), + (357, 47, 1), + (358, 24, 2), + (358, 31, 1), + (358, 52, 1), + (359, 41, 2), + (359, 40, 1), + (359, 31, 1), + (360, 32, 1), + (360, 47, 1), + (360, 18, 1), + (361, 10, 1), + (361, 51, 1), + (361, 25, 1), + (361, 23, 2), + (361, 47, 2), + (362, 29, 1), + (362, 38, 1), + (362, 32, 1), + (362, 42, 1), + (363, 43, 1), + (363, 39, 1), + (363, 38, 1), + (364, 26, 1), + (364, 21, 1), + (364, 1, 1), + (365, 43, 1), + (365, 21, 1), + (365, 15, 2), + (365, 39, 1), + (366, 17, 1), + (366, 30, 2), + (366, 53, 1), + (367, 34, 1), + (367, 41, 1), + (367, 38, 1), + (368, 41, 1), + (368, 6, 1), + (368, 28, 1), + (368, 18, 2), + (369, 36, 1), + (369, 14, 1), + (369, 46, 2), + (369, 8, 2), + (370, 42, 1), + (370, 24, 2), + (370, 3, 2), + (370, 37, 1), + (370, 18, 2), + (371, 40, 2), + (371, 25, 1), + (371, 14, 2), + (371, 46, 1), + (371, 3, 2), + (372, 14, 1), + (372, 26, 1), + (372, 3, 1), + (372, 43, 1), + (373, 30, 1), + (373, 15, 1), + (373, 38, 1), + (374, 10, 1), + (374, 49, 1), + (374, 40, 1), + (374, 18, 2), + (374, 22, 1), + (375, 37, 1), + (375, 15, 1), + (375, 10, 1), + (375, 42, 1), + (375, 35, 1), + (376, 8, 1), + (376, 4, 1), + (376, 34, 2), + (376, 13, 1), + (376, 15, 2), + (376, 3, 2), + (376, 2, 1), + (377, 31, 1), + (377, 12, 1), + (377, 50, 2), + (377, 49, 1), + (378, 15, 2), + (378, 48, 2), + (379, 25, 2), + (379, 43, 2), + (379, 23, 1), + (379, 39, 1), + (380, 32, 1), + (380, 50, 1), + (380, 49, 1), + (380, 12, 1), + (381, 9, 1), + (381, 6, 2), + (381, 28, 1), + (381, 49, 2), + (382, 49, 1), + (382, 25, 2), + (382, 8, 1), + (383, 25, 1), + (383, 8, 2), + (383, 24, 1), + (384, 42, 2), + (384, 31, 2), + (384, 11, 1), + (384, 31, 1), + (385, 51, 2), + (385, 43, 1), + (385, 10, 1), + (385, 51, 1), + (386, 33, 2), + (386, 15, 1), + (386, 40, 1), + (386, 10, 1), + (387, 26, 1), + (387, 32, 1), + (387, 3, 1), + (388, 15, 1), + (388, 20, 1), + (388, 16, 1), + (388, 42, 1), + (388, 20, 1), + (389, 51, 2), + (389, 7, 1), + (389, 9, 2), + (389, 7, 1), + (390, 44, 1), + (390, 10, 2), + (390, 25, 1), + (390, 12, 2), + (390, 1, 2), + (391, 33, 2), + (391, 5, 1), + (391, 19, 2), + (391, 20, 1), + (391, 29, 1), + (391, 39, 1), + (392, 30, 3), + (392, 7, 1), + (392, 20, 1), + (393, 36, 2), + (393, 6, 1), + (393, 10, 2), + (393, 2, 1), + (393, 10, 2), + (394, 37, 2), + (394, 21, 1), + (394, 18, 2), + (394, 37, 2), + (394, 32, 2), + (395, 13, 1), + (395, 35, 1), + (395, 14, 1), + (395, 20, 1), + (396, 22, 1), + (396, 4, 1), + (396, 11, 2), + (396, 29, 1), + (396, 17, 1), + (397, 23, 1), + (397, 23, 1), + (397, 52, 1), + (397, 45, 1), + (398, 14, 1), + (398, 19, 1), + (398, 13, 1), + (398, 12, 1), + (399, 13, 2), + (399, 42, 2), + (399, 23, 1), + (400, 53, 1), + (400, 9, 1), + (400, 17, 1), + (401, 41, 1), + (401, 51, 1), + (401, 10, 1), + (401, 44, 1), + (401, 48, 1), + (401, 47, 1), + (402, 37, 1), + (402, 19, 1), + (402, 6, 1), + (402, 34, 2), + (403, 25, 1), + (403, 18, 1), + (403, 3, 2), + (403, 29, 3), + (404, 5, 2), + (404, 37, 2), + (404, 40, 1), + (404, 12, 1), + (405, 48, 1), + (405, 11, 1), + (405, 40, 2), + (405, 50, 1), + (406, 36, 2), + (406, 6, 2), + (406, 6, 2), + (406, 14, 1), + (406, 39, 2), + (407, 3, 3), + (407, 11, 2), + (407, 6, 1), + (408, 12, 1), + (408, 13, 2), + (408, 4, 2), + (408, 50, 1), + (409, 48, 1), + (409, 20, 2), + (409, 19, 1), + (410, 22, 1), + (410, 48, 1), + (410, 17, 1), + (411, 16, 1), + (411, 2, 2), + (411, 49, 1), + (412, 41, 1), + (412, 1, 2), + (412, 31, 1), + (412, 50, 1), + (413, 5, 1), + (413, 6, 2), + (413, 32, 1), + (413, 43, 3), + (414, 32, 1), + (414, 36, 1), + (414, 5, 1), + (414, 11, 2), + (414, 11, 2), + (415, 9, 1), + (415, 11, 2), + (415, 36, 2), + (415, 18, 1), + (415, 12, 1), + (416, 40, 1), + (416, 33, 1), + (416, 7, 1), + (417, 13, 1), + (417, 31, 1), + (417, 40, 2), + (418, 8, 1), + (418, 26, 2), + (418, 8, 1), + (418, 18, 1), + (419, 44, 2), + (419, 46, 1), + (419, 2, 1), + (419, 39, 1), + (420, 35, 1), + (420, 29, 1), + (420, 21, 1), + (420, 9, 1), + (421, 13, 1), + (421, 16, 1), + (421, 13, 1), + (421, 22, 1), + (422, 9, 1), + (422, 20, 2), + (422, 5, 1), + (422, 50, 1), + (423, 7, 1), + (423, 4, 1), + (424, 52, 1), + (424, 38, 1), + (424, 37, 1), + (425, 7, 2), + (425, 17, 2), + (425, 48, 2), + (426, 22, 1), + (426, 15, 2), + (426, 10, 1), + (426, 41, 2), + (427, 45, 2), + (427, 22, 1), + (427, 8, 1), + (428, 50, 2), + (428, 37, 1), + (428, 7, 1), + (428, 23, 1), + (429, 2, 1), + (429, 24, 1), + (429, 24, 1), + (429, 49, 2), + (429, 20, 1), + (430, 22, 2), + (430, 7, 1), + (431, 43, 1), + (431, 37, 2), + (431, 48, 2), + (431, 24, 2), + (432, 29, 2), + (432, 14, 1), + (432, 1, 1), + (433, 41, 2), + (433, 24, 1), + (433, 49, 1), + (433, 2, 1), + (434, 34, 2), + (434, 49, 1), + (434, 30, 2), + (434, 31, 1), + (435, 40, 2), + (435, 38, 1), + (435, 37, 3), + (436, 38, 1), + (436, 49, 1), + (436, 39, 1), + (437, 28, 1), + (437, 20, 1), + (437, 42, 1), + (437, 34, 1), + (437, 12, 1), + (437, 46, 1), + (438, 43, 1), + (438, 20, 1), + (438, 8, 1), + (438, 11, 1), + (438, 3, 1), + (439, 42, 1), + (439, 14, 2), + (439, 6, 1), + (439, 34, 2), + (440, 1, 1), + (440, 9, 2), + (440, 45, 2), + (440, 27, 1), + (441, 15, 1), + (441, 34, 1), + (441, 27, 2), + (441, 30, 1), + (441, 50, 1), + (441, 37, 2), + (442, 33, 1), + (442, 26, 1), + (442, 48, 1), + (443, 2, 1), + (443, 50, 2), + (443, 12, 1), + (444, 7, 1), + (444, 42, 1), + (444, 32, 2), + (444, 18, 2), + (445, 25, 1), + (445, 3, 2), + (445, 5, 1), + (446, 16, 2), + (446, 17, 1), + (446, 52, 4), + (446, 47, 1), + (447, 28, 1), + (447, 48, 1), + (447, 46, 2), + (448, 37, 1), + (448, 10, 1), + (448, 31, 1), + (449, 23, 1), + (449, 26, 1), + (449, 36, 1), + (449, 53, 1), + (449, 40, 2), + (450, 43, 1), + (450, 47, 1), + (450, 22, 1), + (450, 9, 3), + (451, 52, 2), + (451, 32, 2), + (451, 28, 2), + (451, 2, 3), + (452, 29, 1), + (452, 41, 2), + (452, 50, 1), + (453, 49, 2), + (453, 15, 1), + (453, 51, 1), + (453, 47, 1), + (454, 20, 2), + (454, 47, 1), + (454, 9, 1), + (454, 11, 1), + (455, 16, 1), + (455, 17, 1), + (456, 12, 1), + (456, 45, 1), + (456, 35, 1), + (456, 22, 1), + (457, 35, 1), + (457, 13, 1), + (457, 47, 1), + (457, 8, 1), + (458, 28, 1), + (458, 32, 1), + (458, 7, 2), + (458, 15, 1), + (459, 24, 2), + (459, 1, 1), + (459, 2, 2), + (459, 24, 2), + (460, 43, 1), + (460, 14, 1), + (460, 49, 1), + (461, 49, 1), + (461, 44, 2), + (461, 49, 1), + (461, 48, 2), + (462, 53, 1), + (462, 6, 2), + (462, 12, 1), + (463, 40, 1), + (463, 40, 1), + (463, 20, 3), + (463, 9, 1), + (463, 46, 1), + (464, 36, 1), + (464, 9, 1), + (464, 16, 1), + (465, 36, 1), + (465, 25, 2), + (465, 34, 1), + (465, 49, 1), + (466, 9, 1), + (466, 26, 1), + (466, 43, 1), + (466, 14, 1), + (466, 38, 2), + (467, 18, 1), + (467, 52, 1), + (467, 53, 1), + (467, 43, 1), + (468, 20, 1), + (468, 43, 1), + (468, 21, 1), + (469, 18, 1), + (469, 53, 2), + (469, 25, 1), + (469, 28, 1), + (470, 1, 1), + (470, 8, 1), + (470, 9, 1), + (470, 50, 2), + (471, 4, 1), + (471, 35, 1), + (471, 29, 1), + (471, 27, 1), + (472, 32, 1), + (472, 7, 1), + (472, 10, 1), + (472, 40, 2), + (473, 1, 1), + (473, 29, 1), + (473, 5, 1), + (473, 16, 1), + (473, 10, 1), + (474, 33, 1), + (474, 16, 1), + (474, 27, 2), + (474, 9, 1), + (474, 53, 1), + (475, 30, 1), + (475, 1, 2), + (475, 1, 1), + (475, 4, 2), + (476, 6, 2), + (476, 22, 2), + (476, 18, 1), + (477, 49, 1), + (477, 20, 2), + (477, 44, 1), + (478, 20, 1), + (478, 44, 2), + (478, 33, 2), + (478, 11, 2), + (479, 4, 1), + (479, 41, 2), + (480, 2, 1), + (480, 42, 1), + (480, 27, 1), + (481, 47, 1), + (481, 46, 2), + (481, 22, 1), + (481, 39, 1), + (482, 13, 2), + (482, 30, 2), + (482, 52, 2), + (482, 50, 1), + (482, 6, 2), + (482, 48, 1), + (483, 3, 1), + (483, 5, 1), + (483, 35, 1), + (484, 36, 2), + (484, 19, 1), + (484, 50, 2), + (484, 25, 1), + (485, 13, 1), + (485, 53, 2), + (485, 53, 1), + (485, 11, 1), + (486, 17, 2), + (486, 50, 1), + (486, 19, 1), + (487, 5, 1), + (487, 52, 2), + (487, 6, 1), + (487, 47, 1), + (487, 45, 1), + (487, 5, 1), + (488, 6, 1), + (488, 10, 2), + (488, 20, 1), + (488, 19, 1), + (488, 6, 1), + (488, 46, 1), + (489, 45, 1), + (489, 25, 2), + (489, 41, 1), + (490, 14, 2), + (490, 18, 1), + (490, 47, 1), + (490, 5, 1), + (490, 29, 2), + (491, 46, 1), + (491, 52, 2), + (491, 8, 2), + (491, 39, 1), + (492, 52, 1), + (492, 52, 1), + (492, 41, 2), + (492, 1, 2), + (492, 11, 1), + (493, 46, 1), + (493, 38, 1), + (493, 14, 2), + (494, 30, 1), + (494, 24, 1), + (494, 43, 1), + (495, 24, 1), + (495, 37, 1), + (495, 25, 1), + (496, 4, 1), + (496, 24, 2), + (496, 43, 2), + (496, 10, 1), + (497, 45, 1), + (497, 24, 1), + (497, 16, 2), + (498, 21, 1), + (498, 24, 1), + (498, 38, 2), + (499, 15, 1), + (499, 36, 1), + (499, 8, 1), + (499, 15, 1), + (499, 52, 1), + (500, 20, 1), + (500, 39, 1), + (500, 6, 2), + (500, 7, 1), + (500, 21, 1), + (500, 39, 2), + (500, 32, 2); + + + + + + + + + + + diff --git a/Suli/13.b/Adatbázis/20241106/2024majus/2024_majus_megoldasok.txt b/Suli/13.b/Adatbázis/20241106/2024majus/2024_majus_megoldasok.txt new file mode 100644 index 0000000..54b46bd --- /dev/null +++ b/Suli/13.b/Adatbázis/20241106/2024majus/2024_majus_megoldasok.txt @@ -0,0 +1,27 @@ +-- 12. feladat: +CREATE DATABASE mozaik CHARACTER SET="utf8" COLLATE="utf8_hungarian_ci"; + + +-- 14. feladat: +SELECT COUNT(letszam) AS `nagyrendezvények száma` FROM `rendezveny` WHERE letszam >= 100; + + +-- 15. feladat: +SELECT helyszin.nev, rendezveny.idopont, rendezveny.napokszama, rendezveny.letszam FROM `rendezveny` INNER JOIN helyszin ON rendezveny.helyszinId = helyszin.id WHERE helyszin.nev = "Szeged"; + + +-- 16. feladat: +UPDATE `kapcsolat` SET `cegnev`= "BugFix IT" WHERE kapcsolat.nev = "Nagy Béla"; + + +-- 17. feladat: +SELECT tipus.nev AS `típus`, AVG(rendezveny.letszam) AS `átlaglétszám` FROM `rendezveny` INNER JOIN tipus ON rendezveny.tipusId = tipus.id GROUP BY tipus.nev ORDER BY `átlaglétszám` DESC LIMIT 2; + + +-- 18. feladat: +SELECT helyszin.nev FROM `helyszin` LEFT JOIN rendezveny ON helyszin.id = rendezveny.helyszinId WHERE rendezveny.helyszinId IS NULL; + + +-- 19. feladat: +SELECT kapcsolat.nev, kapcsolat.email, (rendezveny.napokszama * 20000) + (rendezveny.letszam * 1000) AS `szervezési díj` FROM `rendezveny` INNER JOIN kapcsolat ON rendezveny.kapcsolatId = kapcsolat.id INNER JOIN tipus ON rendezveny.tipusId = tipus.id WHERE tipus.nev = "tréning"; + diff --git a/Suli/13.b/Adatbázis/20241106/2024majus/adatbazis.sql b/Suli/13.b/Adatbázis/20241106/2024majus/adatbazis.sql new file mode 100644 index 0000000..1648bb7 --- /dev/null +++ b/Suli/13.b/Adatbázis/20241106/2024majus/adatbazis.sql @@ -0,0 +1,87 @@ +-- Táblák létrehozása + +-- Rendezvénytípusok +CREATE TABLE tipus +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + primary key (id) +); + +CREATE TABLE helyszin +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + primary key (id) +); + +CREATE TABLE kapcsolat +( + id int NOT NULL AUTO_INCREMENT, + nev varchar(50) NOT NULL UNIQUE, + telefon varchar(30) NOT NULL, + email varchar(50) NOT NULL, + cegnev varchar(50), + primary key (id) +); + +CREATE TABLE rendezveny +( + id int NOT NULL AUTO_INCREMENT, + kapcsolatId int NOT NULL, + idopont date NOT NULL, + napokszama int NOT NULL, + helyszinId int NOT NULL, + letszam int NOT NULL, + tipusId int NOT NULL, + primary key (id), + key kapcsolatId (kapcsolatId), + CONSTRAINT FK_kapcsolat_kapcsolatId FOREIGN KEY (kapcsolatId) REFERENCES kapcsolat (id), + key helyszinId (helyszinId), + CONSTRAINT FK_helyszin_helyszinId FOREIGN KEY (helyszinId) REFERENCES helyszin (id), + key tipusId (tipusId), + CONSTRAINT FK_tipus_tipusId FOREIGN KEY (tipusId) REFERENCES tipus (id) +); + +-- Adatok beszúrása +INSERT INTO tipus (id, nev) +VALUES (1, 'szabadtéri'), + (2, 'beltéri'), + (3, 'online'), + (4, 'tréning'), + (5, 'céges rendezvény'); + +INSERT INTO helyszin (id, nev) +VALUES (1, 'Megrendelő telephelye'), + (2, 'Budapest'), + (3, 'Szeged'), + (4, 'Debrecen'), + (5, 'Pécs'), + (6, 'Balaton'), + (7, 'Velencei tó'), + (8, 'Egyéb'); + +INSERT INTO kapcsolat (id, nev, telefon, email, cegnev) +VALUES (1, 'Kiss Piroska', '+3620123456', 'kiss.piroska@paprika.hu', 'Paprika Paradicsom'), + (2, 'Nagy Béla', '+3670523456', 'nagy.bela@bugfix.hu', NULL), + (3, 'Vass Alajos', '+36309998877', 'vass.alajos@vaskalapos.hu', 'Vaskalapos Hulladékhasznosító'), + (4, 'Nagy Lilla', '+36308768768', 'nagy.lilla@szoke-ciklon.hu', 'Szőke Ciklon Illatszergyár'), + (5, 'Major Anna', '+36201347761', 'major.anna@organic.hu', 'Organic Gyógyszergyár'), + (6, 'Balogh Béla', '+36304673753', 'balogh.bela@nadpalca.hu', 'Nádpálca Oktatástechnikai Kereskelem'), + (7, 'Szabó Krisztina', '+36205049928', 'szabo.krisztina@kaqkk.hu', 'Kaqkk Kft.'), + (8, 'Hanta Balázs', '+36705463728', 'hanta.balazs@hanta.hu', 'Hanta Pályázatíró Kft.'), + (9, 'Mekk Elek', '+36305161721', 'mekk.elek@talan-holnap.hu', 'Talán Holnap Karbantartás'); + +INSERT INTO rendezveny (id, kapcsolatId, idopont, napokszama, helyszinId, letszam, tipusID) +VALUES (1, 5, '2023-12-01', 3, 3, 100, 4), + (2, 3, '2023-12-01', 1, 1, 120, 5), + (3, 1, '2023-12-06', 1, 1, 40, 5), + (4, 7, '2023-12-07', 3, 3, 20, 4), + (5, 4, '2023-12-08', 1, 2, 70, 2), + (6, 6, '2023-12-09', 1, 1, 30, 3), + (7, 8, '2023-12-11', 3, 4, 10, 4), + (8, 9, '2023-12-12', 1, 1, 30, 2), + (9, 2, '2023-12-13', 5, 5, 30, 4), + (10, 5, '2023-12-14', 1, 2, 230, 5), + (11, 7, '2023-12-15', 1, 1, 65, 5), + (12, 8, '2023-12-15', 1, 2, 40, 5); \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 06/elso.php b/Suli/13.b/Backend/2024. 09. 06/elso.php new file mode 100644 index 0000000..883ebdf --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 06/elso.php @@ -0,0 +1,23 @@ +"; + echo $kiirando; + $kiirando = "It's PHP
"; + echo $kiirando; + $kiirando = 12; + echo $kiirando * 3; + $cim = "Kaka" +?> + + + + + + PHP-s html + + +

+ + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 09/masodik.php b/Suli/13.b/Backend/2024. 09. 09/masodik.php new file mode 100644 index 0000000..f8d7982 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 09/masodik.php @@ -0,0 +1,53 @@ +"; + + $tomb = array("hétfő", "kedd", "szerda", "csütörtök", "péntek"); + + var_dump($tomb); + + echo "
Az első elem a tömbben: ".$tomb[0]; + echo "
A tömb elemeinek a száma: ".count($tomb); + $tomb[] = "szombat"; + echo "
Az utolsó elem: ".$tomb[count($tomb) - 1]; + echo "Tömb elemének törlése...
"; + unset($tomb[1]); + var_dump($tomb); + echo "
"; + foreach ($tomb as $elem) { + echo $elem. "
"; + } + + // foreach ($_SERVER as $key => $value) { + // echo $key. " értéke: ".$value."
"; + // } + + $atomb = array(); + + $atomb["elso"] = "matyi"; + $atomb["masodik"] = "dani"; + + echo $atomb["elso"]."
"; + + foreach ($atomb as $key => $value) { + echo $key. " értéke: ".$value."
"; + } + + echo "Név: ".$_GET["nev"]."
"; + echo "Jelszó: ".$_GET["jelszo"]."
"; + echo "Született: ".$_GET["szul"]."
"; + + + if ($_GET["nev"] == "Jani") + { + echo "Belépés engedélyezve Janinak"; + } + + else + { + echo "Nincs jogosultság"; + } + +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 12/harmadik.php b/Suli/13.b/Backend/2024. 09. 12/harmadik.php new file mode 100644 index 0000000..d39a72f --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 12/harmadik.php @@ -0,0 +1,30 @@ + + + + + + + + + PHP form + + + +
+
+
+ +
+ + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 16/footer.php b/Suli/13.b/Backend/2024. 09. 16/footer.php new file mode 100644 index 0000000..8faf96d --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 16/footer.php @@ -0,0 +1,8 @@ + + Készítette: Tóth Ádám (c)2024. + '; + + +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 16/loginform.php b/Suli/13.b/Backend/2024. 09. 16/loginform.php new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Backend/2024. 09. 16/negy.php b/Suli/13.b/Backend/2024. 09. 16/negy.php new file mode 100644 index 0000000..8c0bcd3 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 16/negy.php @@ -0,0 +1,19 @@ + + + + + + + + Alap web valami + + +

POST használata

+
+
+
+ +
+ + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 16/negy1.php b/Suli/13.b/Backend/2024. 09. 16/negy1.php new file mode 100644 index 0000000..cabfaf5 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 16/negy1.php @@ -0,0 +1,14 @@ + 3 && strlen($jelszo) > 4) { + if ($nev == "admin" && $jelszo == "admin") { + $islogin = true; + } + } + } +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 19/ot.php b/Suli/13.b/Backend/2024. 09. 19/ot.php new file mode 100644 index 0000000..96c3c2a --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 19/ot.php @@ -0,0 +1,28 @@ + + + + + + + + Document + + +

Szöveges

+
+ +
+ +
+ Szerepel benne az alma szó!"; + } + else { + echo "

Nem szerepel benne az alma szó!

"; + } + ?> + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 19/ot1.php b/Suli/13.b/Backend/2024. 09. 19/ot1.php new file mode 100644 index 0000000..c2e7710 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 19/ot1.php @@ -0,0 +1,9 @@ += 5) { + if (strpos($szov, "alma") != false) { + $vane = true; + } + } +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 26/index.php b/Suli/13.b/Backend/2024. 09. 26/index.php new file mode 100644 index 0000000..40594a4 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 26/index.php @@ -0,0 +1,11 @@ + + + + + + Játék + + + + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 26/szokitalalas.php b/Suli/13.b/Backend/2024. 09. 26/szokitalalas.php new file mode 100644 index 0000000..cdf3e38 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 26/szokitalalas.php @@ -0,0 +1,6 @@ +
+ +
+ +
+ \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 26/szokitalalas_vizsgalas.php b/Suli/13.b/Backend/2024. 09. 26/szokitalalas_vizsgalas.php new file mode 100644 index 0000000..9b0d781 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 26/szokitalalas_vizsgalas.php @@ -0,0 +1,5 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 26/szomegadas.php b/Suli/13.b/Backend/2024. 09. 26/szomegadas.php new file mode 100644 index 0000000..0cb0ee3 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 26/szomegadas.php @@ -0,0 +1,5 @@ +
+ +
+ +
\ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 09. 26/szomegadas_vizsgalas.php b/Suli/13.b/Backend/2024. 09. 26/szomegadas_vizsgalas.php new file mode 100644 index 0000000..aa773e1 --- /dev/null +++ b/Suli/13.b/Backend/2024. 09. 26/szomegadas_vizsgalas.php @@ -0,0 +1,14 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 10/hat01.php b/Suli/13.b/Backend/2024. 10. 10/hat01.php new file mode 100644 index 0000000..0f44870 --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 10/hat01.php @@ -0,0 +1,33 @@ + + + + + + + + + + + Sütik és munkamenetek + + +

Bejelentkezés

+
+ Név:
+ Jelszó:
+ +
+ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 10/hat02.php b/Suli/13.b/Backend/2024. 10. 10/hat02.php new file mode 100644 index 0000000..6f4ac5b --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 10/hat02.php @@ -0,0 +1,24 @@ +'; + echo ''; + echo ''; + echo ''; +} + +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 14/func.php b/Suli/13.b/Backend/2024. 10. 14/func.php new file mode 100644 index 0000000..ad8155c --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 14/func.php @@ -0,0 +1,38 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 14/index.php b/Suli/13.b/Backend/2024. 10. 14/index.php new file mode 100644 index 0000000..c80fd15 --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 14/index.php @@ -0,0 +1,32 @@ + + + + + + + + Munkamenet + + + +

Bejelentkezés

+
+ Név:
+ Jelszó:
+ +
+ + + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 17/func.php b/Suli/13.b/Backend/2024. 10. 17/func.php new file mode 100644 index 0000000..6d2429a --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 17/func.php @@ -0,0 +1,25 @@ + 0 && $num2 > 0) { + return true; + } + else { + return false; + } + } + else { + return false; + } + } + + function add($szam1, $szam2) { + return $szam1 + $szam2; + } + +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 17/html.php b/Suli/13.b/Backend/2024. 10. 17/html.php new file mode 100644 index 0000000..86d57e3 --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 17/html.php @@ -0,0 +1,15 @@ + + + + + + Fügvények + + +
+ + + + +
+ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 17/nyolc.php b/Suli/13.b/Backend/2024. 10. 17/nyolc.php new file mode 100644 index 0000000..4464dc7 --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 17/nyolc.php @@ -0,0 +1,8 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 24/head.php b/Suli/13.b/Backend/2024. 10. 24/head.php new file mode 100644 index 0000000..510b44f --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 24/head.php @@ -0,0 +1,56 @@ + $maxmeret) { + $uploadOK = 0; + echo "Túl nagy állomány!"; + } + + if ($kepkiterjesztes != "jpg" && $kepkiterjesztes != "png") { + $uploadOK = 0; + echo "Nem megengedett képformátum"; + } + + if ($uploadOK == 1) { + $vanmar = 0; + if (file_exists($celfajl)) { + $vanmar = 1; + } + + if (move_uploaded_file($_FILES["kepfajl"]["tmp_name"], $celfajl) == true) { + if ($vanmar == 0) { + $_SESSION["kepek"][] = $celfajl; + } + } + } + } + + $kepek = glob($celkonyvtar."*"); + + foreach ($kepek as $img) { + echo ''; + } + + // if (isset($_SESSION["kepek"])) { + // foreach ($_SESSION["kepek"] as $value) { + // echo ''; + // } + // } +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 24/html.php b/Suli/13.b/Backend/2024. 10. 24/html.php new file mode 100644 index 0000000..909420c --- /dev/null +++ b/Suli/13.b/Backend/2024. 10. 24/html.php @@ -0,0 +1,21 @@ + + + + + + + + + Document + + +

Képek feltöltése PHP-val

+
+ Név:
+
+ +
+ + \ No newline at end of file diff --git a/Suli/13.b/Backend/2024. 10. 24/kepek/red_panda.jpg b/Suli/13.b/Backend/2024. 10. 24/kepek/red_panda.jpg new file mode 100644 index 0000000..3c097c3 Binary files /dev/null and b/Suli/13.b/Backend/2024. 10. 24/kepek/red_panda.jpg differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21.zip b/Suli/13.b/Backend/Dolgozat_2024. 10. 21.zip new file mode 100644 index 0000000..debe35c Binary files /dev/null and b/Suli/13.b/Backend/Dolgozat_2024. 10. 21.zip differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/bejelentkezes.php b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/bejelentkezes.php new file mode 100644 index 0000000..4f9ed80 --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/bejelentkezes.php @@ -0,0 +1,10 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/css/style.css b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/css/style.css new file mode 100644 index 0000000..33cd2d0 --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/css/style.css @@ -0,0 +1,12 @@ +body { + display: flex; + align-items: center; + justify-content: center; + min-height: 100vh; + flex-direction: column; +} + +.container { + display: flex; + margin-bottom: 20px; +} \ No newline at end of file diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/form.php b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/form.php new file mode 100644 index 0000000..a640b09 --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/form.php @@ -0,0 +1,21 @@ + + + + + + Bejelentkezés + + + +
+
+
+ +
+ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/Dolgozat_2024. 10. 21.zip b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/Dolgozat_2024. 10. 21.zip new file mode 100644 index 0000000..debe35c Binary files /dev/null and b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/Dolgozat_2024. 10. 21.zip differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/baranyhus.png b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/baranyhus.png new file mode 100644 index 0000000..6beded8 Binary files /dev/null and b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/baranyhus.png differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/ribeye.png b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/ribeye.png new file mode 100644 index 0000000..a876bb1 Binary files /dev/null and b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/ribeye.png differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/tbone.png b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/tbone.png new file mode 100644 index 0000000..cab6f9e Binary files /dev/null and b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/img/tbone.png differ diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kiertekeles.php b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kiertekeles.php new file mode 100644 index 0000000..690fff7 --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kiertekeles.php @@ -0,0 +1,14 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kijelentkezes.php b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kijelentkezes.php new file mode 100644 index 0000000..595d94b --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/kijelentkezes.php @@ -0,0 +1,10 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Dolgozat_2024. 10. 21/termekek.php b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/termekek.php new file mode 100644 index 0000000..e84f135 --- /dev/null +++ b/Suli/13.b/Backend/Dolgozat_2024. 10. 21/termekek.php @@ -0,0 +1,44 @@ + + + + + + Document + + + + +

Vásárlás

+
+
+
+

Bárány hátsó csülök

+

7900 Ft/kg

+ +
+
+
+

T-bone steak

+

7500 Ft/kg

+ +
+
+
+

Ribeye steak

+

6500 Ft/kg

+ +

+ +
+ Kijelentkezés + + + \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index.php b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index.php new file mode 100644 index 0000000..967b004 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index.php @@ -0,0 +1,19 @@ + + + + + + + Document + + + + + \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index1.php b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index1.php new file mode 100644 index 0000000..47c1f09 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/index1.php @@ -0,0 +1,9 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/logged.php b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/logged.php new file mode 100644 index 0000000..cd54809 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/logged.php @@ -0,0 +1 @@ +

Üdvözöllek,

diff --git a/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/login.php b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/login.php new file mode 100644 index 0000000..ad5ae54 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/DogaGyak_2024. 09. 19/login.php @@ -0,0 +1,7 @@ +
+ +
+ +
+ +
\ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/elso.php b/Suli/13.b/Backend/Fölki/elso.php new file mode 100644 index 0000000..4b6d1b8 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/elso.php @@ -0,0 +1,34 @@ +'; + echo $kiirando; + $kiirando = "It's PHP
"; + echo $kiirando; + $kiirando = 12; + echo $kiirando*3; + + // phpinfo(); +/* + $html = ' + + PHP-s html + + +

Ez cím

+

Blah blah blah

+ + '; + + echo $html; +*/ +$cim = "Most más a cím"; +?> + + + PHP-s html + + +

+

Blah blah blah

+ + + diff --git a/Suli/13.b/Backend/Fölki/harmadik.php b/Suli/13.b/Backend/Fölki/harmadik.php new file mode 100644 index 0000000..d0157f5 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/harmadik.php @@ -0,0 +1,54 @@ + + + + + + + PHP form + + + + +
+
+
+ +
+ Üdvözöllek ".$_POST["nev"].""; + echo "Kijelentkezés"; + } + ?> + + + + diff --git a/Suli/13.b/Backend/Fölki/masodik.php b/Suli/13.b/Backend/Fölki/masodik.php new file mode 100644 index 0000000..43f81d7 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/masodik.php @@ -0,0 +1,53 @@ +"; + +$tomb = array("hétfő","kedd","szerda","csütörtök","péntek"); + +var_dump($tomb); + +echo "
Az első elem a tömbben: ".$tomb[0]; +echo "
A tömb elemeinek a száma: ".count($tomb); +$tomb[] = "szombat"; +echo "
Az utolsó elem: ".$tomb[count($tomb)-1]; +echo "Tömb elemének a törlése...
"; +unset($tomb[1]); +var_dump($tomb); +echo "
"; +foreach ($tomb as $egyelem) { + echo $egyelem."
"; +} + +foreach ($_SERVER as $key => $value) { + echo $key." értéke: ".$value."
"; + +} + +echo "Asszociatív tömb:
"; + +$atomb = array(); + +$atomb["elso"] = "matyi"; +$atomb["masodik"] = "dani"; + +echo $atomb["elso"]."
"; + +foreach ($atomb as $kulcs => $ertek) { + echo $kulcs." értéke: ".$ertek."
"; +} + +echo "Név: ".$_GET["nev"]."
"; +echo "Jelszó: ".$_GET["jelszo"]."
"; +echo "Született: ".$_GET["szul"]."
"; + +if ($_GET["nev"]=="Jani") +{ + echo "Belépés engedélyezve Janinak"; +} +else +{ + echo "Nincs jogosultság"; +} +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/negy/footer.php b/Suli/13.b/Backend/Fölki/negy/footer.php new file mode 100644 index 0000000..bedecb3 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/negy/footer.php @@ -0,0 +1,8 @@ + + Készítette: Fölker Csaba (c)2024. + '; + + +?> diff --git a/Suli/13.b/Backend/Fölki/negy/logged.php b/Suli/13.b/Backend/Fölki/negy/logged.php new file mode 100644 index 0000000..28394f6 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/negy/logged.php @@ -0,0 +1,2 @@ +

Üdvözöllek

+Kijelentkezés \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/negy/loginform.php b/Suli/13.b/Backend/Fölki/negy/loginform.php new file mode 100644 index 0000000..4ca2816 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/negy/loginform.php @@ -0,0 +1,5 @@ +
+ Login:
+ Jelszó:
+ +
\ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/negy/negy.php b/Suli/13.b/Backend/Fölki/negy/negy.php new file mode 100644 index 0000000..5ba5b15 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/negy/negy.php @@ -0,0 +1,21 @@ + + + + + + + + Alap web valami + + + +

POST használata

+ + + + \ No newline at end of file diff --git a/Suli/13.b/Backend/Fölki/negy/negy1.php b/Suli/13.b/Backend/Fölki/negy/negy1.php new file mode 100644 index 0000000..2835815 --- /dev/null +++ b/Suli/13.b/Backend/Fölki/negy/negy1.php @@ -0,0 +1,16 @@ +3 && strlen($jelszo)>4) + if ($nev == 'admin' && $jelszo=='admin') + { + $islogin = true; + } +} + + +?> \ No newline at end of file diff --git a/Suli/13.b/Backend/Tóth Ádám_Feladat.zip b/Suli/13.b/Backend/Tóth Ádám_Feladat.zip new file mode 100644 index 0000000..026a90d Binary files /dev/null and b/Suli/13.b/Backend/Tóth Ádám_Feladat.zip differ diff --git a/Suli/13.b/Backend/Órai feladat_2024. 10. 15.zip b/Suli/13.b/Backend/Órai feladat_2024. 10. 15.zip new file mode 100644 index 0000000..e554911 Binary files /dev/null and b/Suli/13.b/Backend/Órai feladat_2024. 10. 15.zip differ diff --git a/Suli/13.b/Backend/Órai feladat_2024. 10. 15/login.php b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/login.php new file mode 100644 index 0000000..fe110d3 --- /dev/null +++ b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/login.php @@ -0,0 +1,25 @@ + + + + + + + + Bejelentkezés + + +

Bejelentkezés

+
+
+
+
+ +
+ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Órai feladat_2024. 10. 15/logout.php b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/logout.php new file mode 100644 index 0000000..ce909f9 --- /dev/null +++ b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/logout.php @@ -0,0 +1,6 @@ + \ No newline at end of file diff --git a/Suli/13.b/Backend/Órai feladat_2024. 10. 15/profile.php b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/profile.php new file mode 100644 index 0000000..bb3d366 --- /dev/null +++ b/Suli/13.b/Backend/Órai feladat_2024. 10. 15/profile.php @@ -0,0 +1,38 @@ + + + + + + + + Profil + + + + "; + echo "Választott szín: ". $szin; + ?> +
Kijelentkezés + + \ No newline at end of file diff --git a/Suli/13.b/DevOps/Dolgozat_2024. 10. 24/TóthÁdám_DevOps_Dolgozat_24_10.txt b/Suli/13.b/DevOps/Dolgozat_2024. 10. 24/TóthÁdám_DevOps_Dolgozat_24_10.txt new file mode 100644 index 0000000..03eec68 --- /dev/null +++ b/Suli/13.b/DevOps/Dolgozat_2024. 10. 24/TóthÁdám_DevOps_Dolgozat_24_10.txt @@ -0,0 +1,47 @@ +-- 1. feladat: +pwd + + +-- 2. feladat: +mkdir projekt_konyvtar + + +-- 3. feladat: +cd projekt_konyvtar + + +-- 4. feladat: +mkdir ujKonyvtar + + +-- 5. feladat: +cp -r ujKonyvtar /home/adamtoth + + +-- 6. feladat: +rmdir ujKonyvtar + + +-- 7. feladat: +touch jegyzet.txt +echo "Hello világ" > jegyzet.txt + + +-- 8. feladat: +locate jegyzet.txt + + +-- 9. feladat: +touch /tmp/abs_fajl.txt + + +-- 10. feladat: +ls -l + + +-- 11. feladat: +cat jegyzet.txt + + +-- 12 feladat: +rm -i jegyzet.txt diff --git a/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/24_10_11 - Frontend - Dolgozat.pdf b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/24_10_11 - Frontend - Dolgozat.pdf new file mode 100644 index 0000000..c0395f9 Binary files /dev/null and b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/24_10_11 - Frontend - Dolgozat.pdf differ diff --git a/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/UjevFeladat.html b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/UjevFeladat.html new file mode 100644 index 0000000..0cc639d --- /dev/null +++ b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/UjevFeladat.html @@ -0,0 +1,16 @@ + + + + + + Újév + + + +

Új évi visszaszámlálás

+ + + +

+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/UjevFeladat.js b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/UjevFeladat.js new file mode 100644 index 0000000..c849109 --- /dev/null +++ b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/UjevFeladat.js @@ -0,0 +1,37 @@ +const button = document.querySelector("button") +const input = document.getElementById("kezdoertek") +const p = document.querySelector("p") +let myInterval + +button.addEventListener("click", () => { + let kezdoertek = Number(input.value) + myInterval = setInterval(() => { + let myPromise = new Promise((resolve, reject) => { + if (kezdoertek >= 0) { + resolve(`Visszaszámlálás: ${kezdoertek}`) + kezdoertek-- + } else { + reject("Boldog Új Évet!") + clearInterval(myInterval) + } + }) + + myPromise + .then(result => { + p.innerHTML = result + }) + .catch(error => { + p.innerHTML = error + }) + }, 1000) +}) + +fetch('https://name-day.onrender.com/', { + method: 'GET', + headers: { + 'Content-Type': 'application/json', + }, +}) + .then(response => response.json()) + .then(data => console.log(data)) + .catch((error) => console.error('Error:', error)); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/todo.js b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/todo.js new file mode 100644 index 0000000..dea318d --- /dev/null +++ b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/js/todo.js @@ -0,0 +1,49 @@ +const feladatHozzaadasa = document.getElementById("hozzaadGomb") +const feladatok = document.getElementById("feladatok") +const feladatNev = document.getElementById("feladatNev") +const hatarido = document.getElementById("hatarido") +let modositasGombok = document.getElementsByClassName("modositasGomb") +let keszGombok = document.getElementsByClassName("keszGomb") +feladatHozzaadasa.addEventListener("click", () => { + if (feladatNev.value == "" || hatarido.value == "") { + alert("Nincs minden mező kitöltve!") + return + } + + const feladat = document.createElement("div") + feladat.innerHTML = `Feladat: ${feladatNev.value}
` + feladat.innerHTML += `Határidő: ${hatarido.value}` + feladat.classList.add("feladat") + feladatok.appendChild(feladat) + + + const modositas = document.createElement("button") + modositas.innerHTML = "Módosítás" + modositas.classList.add("modositasGomb") + feladat.appendChild(modositas) + + + const kesz = document.createElement("button") + kesz.innerHTML = "Kész" + kesz.classList.add("keszGomb") + feladat.appendChild(kesz) + + feladatNev.value = "" + hatarido.value = "" + + Array.from(modositasGombok).forEach(gomb => { + gomb.addEventListener("click", () => { + let ujNev = prompt("Adja meg az új feladat nevét:") + let ujDatum = prompt("Adj meg az új határidőt:") + + gomb.parentElement.children[0].innerHTML = `Feladat: ${ujNev}` + gomb.parentElement.children[2].innerHTML = `Határidő ${ujDatum}` + }) + }) + + Array.from(keszGombok).forEach(gomb => { + gomb.addEventListener("click", () => { + gomb.parentElement.remove() + }) + }) +}) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/todo.html b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/todo.html new file mode 100644 index 0000000..54f308c --- /dev/null +++ b/Suli/13.b/Frontend/Dolgozatok/Dolgozat_2024. 10. 11/todo.html @@ -0,0 +1,38 @@ + + + + + + Feladatlista + + + + +

To Do lista

+ + + + + + +
+ + diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 06/karacsonyfa.js b/Suli/13.b/Frontend/Javascript/2024. 09. 06/karacsonyfa.js new file mode 100644 index 0000000..eae2d30 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 06/karacsonyfa.js @@ -0,0 +1,3 @@ +for (let i = 0; i < 2; i++) { + console.log(" |||"); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 06/script.js b/Suli/13.b/Frontend/Javascript/2024. 09. 06/script.js new file mode 100644 index 0000000..27e62d8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 06/script.js @@ -0,0 +1,46 @@ +// function Person(name, age) { +// this.name = name +// this.age = age +// } + +// let person1 = new Person("Janos", 19) +// let person2 = new Person("Benedek", 22) +// console.log(person1.name); +// console.log(person2.age); + + +// let jatek = { +// nev: "Minecraft", +// fejleszto: "Mojang", +// megjelenes: "2009" +// } +// console.log(jatek.nev); + + +// let nums = [1, 2, 3, 4, 5] +// console.log(nums); + + +// let userMap = new Map() +// userMap.set("name", "Kristof") + + +// let numSet = new Set([1, 2, 2, 3, 4]) +// console.log(numSet); + + +// let x = 25 +// let y = "25" +// console.log(x === y) + + +// let num = 35 +// let text = "szoveg" +// console.log(`${text}${num}`); + + +// let num = 35 +// console.log(typeof(num)); + +// const tomb = new Array(1, 2, 3, 4, 5) +// console.log(tomb instanceof Array); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 09/IntervallumFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 09/IntervallumFeladat.html new file mode 100644 index 0000000..e69c92d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 09/IntervallumFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 09/SzamoloFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 09/SzamoloFeladat.html new file mode 100644 index 0000000..64f8edb --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 09/SzamoloFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/IntervallumFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/IntervallumFeladat.js new file mode 100644 index 0000000..9464099 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/IntervallumFeladat.js @@ -0,0 +1,23 @@ +let number1 = Number(prompt("Add meg az intervallum elejét:")) +let number2 = Number(prompt("Add meg az intervallum végét:")) +let listaSzamok = [] + + +if (number1 < number2) { + for (; number1 <= number2; number1++) { + listaSzamok.push(number1) + } +} else { + for (; number1 >= number2; number1--) { + listaSzamok.push(number1) + } +} + +console.log(listaSzamok); + +let sum = listaSzamok.reduce((accumulator, currentValue) => { + return accumulator + currentValue +}) + +console.log(sum); +console.log(listaSzamok.length); diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/SzamoloFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/SzamoloFeladat.js new file mode 100644 index 0000000..e834127 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 09/js/SzamoloFeladat.js @@ -0,0 +1,22 @@ +let number1 = parseFloat(prompt("Add meg az első számot:")) +let number2 = parseFloat(prompt("Add meg a második számot:")) + +if (!isNaN(number1) && !isNaN(number2)) { + console.log((number1 + number2).toFixed(2)); + console.log((number1 - number2).toFixed(2)); + console.log((number1 * number2).toFixed(2)); + if (number2 == 0) { + console.log("Nem lehet nullával osztani!"); + } else { + console.log((number1 / number2).toFixed(2)); + } + + if (number2 == 0) { + console.log("Nem lehet nullával osztani!"); + } else { + console.log((number1 % number2).toFixed(2)); + } + console.log(((number1 + number2) ** 2).toFixed(2)); +} else { + console.log("Érvénytelen bemeneti adat!"); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 09/ora.html b/Suli/13.b/Frontend/Javascript/2024. 09. 09/ora.html new file mode 100644 index 0000000..77f18de --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 09/ora.html @@ -0,0 +1,15 @@ + + + + + + Document + + +

+ + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szokoev.html b/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szokoev.html new file mode 100644 index 0000000..dc1f07b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szokoev.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szovegmanipulacio.html b/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szovegmanipulacio.html new file mode 100644 index 0000000..961eec0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/Szovegmanipulacio.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/Szovegmanipulacio.js b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/Szovegmanipulacio.js new file mode 100644 index 0000000..68c30b5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/Szovegmanipulacio.js @@ -0,0 +1,21 @@ +let mondat = prompt("Add meg a nevedet, életkorodat és hogy melyik iskolába jársz:") +console.log(mondat); + +if (mondat.includes("Nemes")) { + console.log("Tartalmazza a 'Nemes' szót!"); +} else { + console.log("Nem tartalmazza a 'Nemes' szót!"); +} + +let mondatMinusz5Karakter = mondat.substring(0, mondat.length - 5) +console.log(mondatMinusz5Karakter); + +let mondatSlice = mondat.split(" ") +console.log(mondatSlice); + +mondatSlice.forEach(element => { + console.log(element); + +}); + +console.log(mondat.charAt(0)); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/ora.js b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/ora.js new file mode 100644 index 0000000..170cac5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/ora.js @@ -0,0 +1,17 @@ +function fuggvenyNeve(param1, param2) { + return param1 + param2 + console.log("Sosem fut le ez a kódsor!"); +} + +function ParameterNelkulifg() { + return "Nem kaptunk paramétert!" +} + +function returnNelkulifg() { + console.log("Nincs return ennél a függvénynél"); +} + + +console.log(fuggvenyNeve(5, 20)); +console.log(ParameterNelkulifg()); +returnNelkulifg() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/szokoev.js b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/szokoev.js new file mode 100644 index 0000000..50a0351 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/js/szokoev.js @@ -0,0 +1,11 @@ +let evszam = Number(prompt("Adj meg egy évszámot:")) + +function Szokoev(evszam) { + if ((evszam % 4 == 0 && evszam % 100 != 0) || evszam % 400 == 0) { + return "Szökőév!" + } else { + return "NEM szökőév!" + } +} + +console.log(Szokoev(evszam)); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 10/ora.html b/Suli/13.b/Frontend/Javascript/2024. 09. 10/ora.html new file mode 100644 index 0000000..ce57dec --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 10/ora.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 13/KoPapirOllo.html b/Suli/13.b/Frontend/Javascript/2024. 09. 13/KoPapirOllo.html new file mode 100644 index 0000000..4c2c0f4 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 13/KoPapirOllo.html @@ -0,0 +1,12 @@ + + + + + + Kő, papír, olló + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/KoPapirOllo.js b/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/KoPapirOllo.js new file mode 100644 index 0000000..472cf09 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/KoPapirOllo.js @@ -0,0 +1,29 @@ +let emberValasztas = prompt("Kő, papír vagy olló?: ") +let lehetosegek = ["kő", "papír", "olló"] +let randomValasztas = lehetosegek[Math.floor(Math.random() * 3)] + +const eldontes = { + kő: { + kő: "Döntetlen!", + papír: "Vesztettél!", + olló: "Nyertél!" + }, + papír: { + kő: "Nyertél!", + papír: "Döntetlen!", + olló: "Vesztettél!" + }, + olló: { + kő: "Vesztettél!", + papír: "Nyertél!", + olló: "Döntetlen!" + } +} + +function KoPapirOllo(ember, gep) { + eredmeny = eldontes[ember][gep] + console.log(eredmeny); + console.log(`${ember}, ${gep}`); +} + +KoPapirOllo(emberValasztas, randomValasztas) diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/script.js b/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/script.js new file mode 100644 index 0000000..cf47ebb --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 13/js/script.js @@ -0,0 +1,45 @@ +let car = { + + name: "Fiat", + model: "500", + engine: { + horsepower: "110", + fuel: "benzin" + }, + + start: function() { + return "Autó elindult" + }, + + drive: function() { + return "Autó megy" + }, + + carInfo: function() { + return `${this.name}, ${this.model}` + } +} + + +let tombNeve = ["alma", "cseresznye"] +console.log(tombNeve[tombNeve.length - 1]); + + +tombNeve.forEach(item => { + console.log(item); +}) + +console.log(new Date().getTime() / (1000)); + + + + +// let car2 = new Object() +// car2.name = "Fiat" +// car2.model = "500" +// car2.start = function() { +// return "Autó elindult" +// } +// car2.drive = function() { +// return "Autó megy" +// } diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 13/ora.html b/Suli/13.b/Frontend/Javascript/2024. 09. 13/ora.html new file mode 100644 index 0000000..3e6cfc4 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 13/ora.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/KonyvtarObjektumFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 16/KonyvtarObjektumFeladat.html new file mode 100644 index 0000000..d7a5b44 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/KonyvtarObjektumFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + +

+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/Polobolt.html b/Suli/13.b/Frontend/Javascript/2024. 09. 16/Polobolt.html new file mode 100644 index 0000000..49d3ae8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/Polobolt.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/TanfolyamArrayFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 16/TanfolyamArrayFeladat.html new file mode 100644 index 0000000..1645653 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/TanfolyamArrayFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/KonyvtarObjektumFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/KonyvtarObjektumFeladat.js new file mode 100644 index 0000000..d883290 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/KonyvtarObjektumFeladat.js @@ -0,0 +1,25 @@ +let gyurukUra = { + cim: "Gyűrűk ura", + szerzo: "Tolkein", + megjelenesEve: 1966, + elerheto: true, + kolcsonzoNeve: undefined, + kikolcsonzes: function(kolcsonzoNeve) { + if (this.elerheto) { + this.kolcsonzoNeve = kolcsonzoNeve + this.elerheto = false + return `A ${this.cim} kikölcsönözve ${this.kolcsonzoNeve} által.` + } else { + return "A könyv nem elérhető jelenleg!" + } + }, + visszahozas: function() { + this.kolcsonzoNeve = undefined + this.elerheto = true + }, + informacio: function() { + return `A köny címe: ${this.cim}, szerzője: ${this.szerzo}, megjelenésének éve: ${this.megjelenesEve}, elérhetősége: ${this.elerheto ? "elérhető" : "nem elérhető"}, kölcsönzője ${this.kolcsonzoNeve}` + } +} + +document.getElementById("kiiratas").innerHTML = gyurukUra.informacio() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/Polobolt.js b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/Polobolt.js new file mode 100644 index 0000000..5cd7d4f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/Polobolt.js @@ -0,0 +1,7 @@ +let polo = { + meret: 107, + szin: "kék", + meretvaltas: function() { + if (this.meret >= 84 && this.meret <= 88) + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/TanfolyamArrayfeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/TanfolyamArrayfeladat.js new file mode 100644 index 0000000..a475e9c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 16/js/TanfolyamArrayfeladat.js @@ -0,0 +1,26 @@ +let tagok = ["Példa Péter", "Fájl Ferenc", "Metódus Mária", "Mező Mihály"] +let utolagJelentkeztek = ["Média Mónika", "Kiterjesztés Kitti", "Típus Tímea"] + +tagok.sort() +console.log(tagok); + +tagok.unshift("Adat Aranka") +console.log(tagok); + +console.log(`A tömb hossza ${tagok.length}`); +console.log(tagok.at(-2)); + +tagok.pop() +console.log(tagok); + +let osszes = tagok.concat(utolagJelentkeztek) +console.log(osszes); + +osszes.shift() +console.log(osszes); + +osszes.push("Objektum Ottó") +console.log(osszes); + +osszes.reverse() +console.log(osszes.join("; ")); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 17/AllatkertObjektumFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 17/AllatkertObjektumFeladat.html new file mode 100644 index 0000000..63ef1ad --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 17/AllatkertObjektumFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 17/MaganhangzoSzamolas.html b/Suli/13.b/Frontend/Javascript/2024. 09. 17/MaganhangzoSzamolas.html new file mode 100644 index 0000000..0a38e38 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 17/MaganhangzoSzamolas.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/AllatkertObjektumFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/AllatkertObjektumFeladat.js new file mode 100644 index 0000000..0b58f8b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/AllatkertObjektumFeladat.js @@ -0,0 +1,51 @@ +let allatok = { + fajta: "kutya", + szin: "fekete", + kor: 6, + etelallergia: ["gabona", "csoki"], + fiu: true, + eves: function(etel) { + if (!this.etelallergia.includes(etel)) { + return `A(z) ${this.fajta} megeheti az alábbi ételt: ${etel}` + } else { + return `A(z) ${this.fajta} nem eheti meg az alábbi ételt: ${etel}` + } + }, + informacio: function() { + return `A(z) ${this.fajta}, aki ${this.szin} színű, ${this.kor} éves és az alábbi ételekre allergiás: ${allatok.etelallergia.join(", ")}` + }, + alszik: function(ora) { + if (ora < 0) { + return `A(z) ${this.fajta} nem tud negatív órát aludni!` + } else if (this.kor <= 5) { + if (ora >= 6 && ora <= 8) { + return `A fiatal ${this.fajta} eleget aludt!` + } else { + return `A fiatal ${this.fajta} nem aludt eleget!` + } + } else if (this.kor >= 5) { + if (ora >= 8 && ora <= 10) { + return `Az idős ${this.fajta} eleget aludt!` + } else { + return `Az idős ${this.fajta} nem aludt eleget!` + } + } + }, + hozzaad: function(etel) { + this.etelallergia.push(etel) + return `A(z) ${this.fajta} ezekre az ételekre allergiás: ${this.etelallergia.join(", ")}` + }, + eletkor: function() { + if (this.fajta == "kutya") { + return `A kutya életkora kutyaévekben: ${this.kor * 7}` + } + }, + allergiaABC: function() { + this.etelallergia.sort() + return `A(z) ${this.fajta} allergiás ételei ABC sorrendben: ${this.etelallergia.join(", ")}` + } + +} + +console.log(allatok.allergiaABC()); + diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/MaganhangzoSzamolas.js b/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/MaganhangzoSzamolas.js new file mode 100644 index 0000000..a79975e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 17/js/MaganhangzoSzamolas.js @@ -0,0 +1,25 @@ +const maganhangzok = ["a", "á", "e", "é", "i", "í", "o", "ó", "ö", "ő", "u", "ú", "ü", "ű"] +let maganhangzokSzamolva = {} + +let text = prompt("Adj meg egy szót:") + +function maganhangzokSzamolasa(text) { + const betuk = text.split("") + betuk.forEach(element => { + if (!maganhangzok.includes(element.toLowerCase())){ + return + } + if (Object.keys(maganhangzokSzamolva).includes(element.toLowerCase())) { + maganhangzokSzamolva[element.toLowerCase()] += 1 + } else { + maganhangzokSzamolva[element.toLowerCase()] = 1 + } + }); +} + +maganhangzokSzamolasa(text) + +console.log(`A "${text}" szó magánhangzói:`); +Object.keys(maganhangzokSzamolva).forEach(element => { + console.log(`\t${element}: ${maganhangzokSzamolva[element]}`); +}) diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 20/index.html b/Suli/13.b/Frontend/Javascript/2024. 09. 20/index.html new file mode 100644 index 0000000..eb2df54 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 20/index.html @@ -0,0 +1,13 @@ + + + + + + Document + + + +

+

+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 20/script.js b/Suli/13.b/Frontend/Javascript/2024. 09. 20/script.js new file mode 100644 index 0000000..5586773 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 20/script.js @@ -0,0 +1 @@ +let elem = document.querySelectorAll("h1") \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 23/UzenetkezeloFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 23/UzenetkezeloFeladat.html new file mode 100644 index 0000000..fdd0797 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 23/UzenetkezeloFeladat.html @@ -0,0 +1,13 @@ + + + + + + Document + + + +

Üzenetkezelő

+
+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 23/index.html b/Suli/13.b/Frontend/Javascript/2024. 09. 23/index.html new file mode 100644 index 0000000..b17dc50 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 23/index.html @@ -0,0 +1,22 @@ + + + + + + Document + + +

ihufsf

+ + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 23/js/UzenetkezeloFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 23/js/UzenetkezeloFeladat.js new file mode 100644 index 0000000..5122d33 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 23/js/UzenetkezeloFeladat.js @@ -0,0 +1,36 @@ +const uzenetek = document.getElementById("uzenetek") + +let uzenet1 = document.createElement("div") +uzenet1.setAttribute("class", "uzenet") +uzenet1.innerHTML = "Ez az első üzenet tartalma!" +uzenetek.appendChild(uzenet1) + + +let uzenet2 = document.createElement("div") +uzenet2.setAttribute("class", "uzenet") +uzenet2.setAttribute("id", "masodikUzenet") +uzenet2.innerHTML = "Ez a második üzenet tartalma!" +uzenetek.appendChild(uzenet2) + + +let uzenet3 = document.createElement("div") +uzenet3.setAttribute("class", uzenet2.getAttribute("class")) +uzenet3.setAttribute("name", "harmadikUzenet") +uzenet3.innerHTML = "Ez a harmadik üzenet tartalma!" +uzenetek.appendChild(uzenet3) + + +let valaszUzenet = document.createElement("div") +valaszUzenet.setAttribute("class", uzenet3.getAttribute("class")) +valaszUzenet.innerHTML = "


Ez a harmadik üzenetre egy válaszüzenet!" +uzenet3.appendChild(valaszUzenet) + + +uzenetek.removeChild(uzenet1) + + +let uzenet2Replace = document.createElement("p") +uzenet2Replace.setAttribute("class", "uzenet") +uzenet2Replace.setAttribute("id", "masodikUzenet") +uzenet2Replace.innerHTML = "Ez a második üzenet tartalma!" +uzenetek.replaceChild(uzenet2Replace, uzenet2) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 24/HatterSzinValtozasFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 09. 24/HatterSzinValtozasFeladat.html new file mode 100644 index 0000000..cfd327c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 24/HatterSzinValtozasFeladat.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 09. 24/js/HatterSzinValtozasFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 09. 24/js/HatterSzinValtozasFeladat.js new file mode 100644 index 0000000..f4fd437 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 09. 24/js/HatterSzinValtozasFeladat.js @@ -0,0 +1,9 @@ +const button = document.querySelector("button") + +button.addEventListener("click", () => { + if (document.body.style.backgroundColor == "aqua") { + document.body.style.backgroundColor = "brown" + } else { + document.body.style.backgroundColor = "aqua" + } +}) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 01/DiakFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 01/DiakFeladat.html new file mode 100644 index 0000000..149db28 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 01/DiakFeladat.html @@ -0,0 +1,12 @@ + + + + + + Diák + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 01/index.html b/Suli/13.b/Frontend/Javascript/2024. 10. 01/index.html new file mode 100644 index 0000000..ecc7b5d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 01/index.html @@ -0,0 +1,15 @@ + + + + + + Document + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 01/js/DiakFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 01/js/DiakFeladat.js new file mode 100644 index 0000000..ea46faf --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 01/js/DiakFeladat.js @@ -0,0 +1,5 @@ +let diak = {nev: "Kovács Jancsika", eletkor: 16, szak: "informatika"} + +let kivalasztas = ({ nev, eletkor, szak }) => `A nevem ${nev}, ${eletkor} éves vagyok, és a választott szakom: ${szak}.` + +console.log(kivalasztas(diak)); diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 01/kaka.py b/Suli/13.b/Frontend/Javascript/2024. 10. 01/kaka.py new file mode 100644 index 0000000..0655473 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 01/kaka.py @@ -0,0 +1,12 @@ +import random +from datetime import datetime, timedelta +# Jegyek szimulálása +entries = ["Alice"] * 6 + ["Bob"] * 5 + ["Charlie"] * 4 + ["Dave"] * 4 + ["Eve"] * 4 + ["kaka"] * 3 + ["fos"] * 1 +random.shuffle(entries) +# Véletlenszerű nyertes kiválasztása +winner = random.choice(entries) + +print(winner) + + +now = now() diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 07/AnonimFuggvenyekFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 07/AnonimFuggvenyekFeladat.html new file mode 100644 index 0000000..28ca3a1 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 07/AnonimFuggvenyekFeladat.html @@ -0,0 +1,16 @@ + + + + + + Document + + + +

Egyszerű összeadás

+ Első szám:
+ Második szám:
+ +

Eredmény:

+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/AnonimFuggvenyekFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/AnonimFuggvenyekFeladat.js new file mode 100644 index 0000000..2a6f3b3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/AnonimFuggvenyekFeladat.js @@ -0,0 +1,14 @@ +const button = document.querySelector("button") +const eredmeny = document.getElementById("eredmeny") + +button.addEventListener("click", () => { + let szam1 = document.getElementById("szam1") + let szam2 = document.getElementById("szam2") + + if (isNaN(szam1.value) || isNaN(szam2.value)) { + eredmeny.innerHTML += "Hibás adatok!" + return + } + + eredmeny.innerHTML = `Eredmény: ${Number(szam1.value) + Number(szam2.value)}` +}) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/CallbackFuggvenyFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/CallbackFuggvenyFeladat.js new file mode 100644 index 0000000..1a190db --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/CallbackFuggvenyFeladat.js @@ -0,0 +1,41 @@ +const szamok = [1, 20, -10, -2, -4, 6, -5, 5, 8, 2] +let negativ_szamok_lista = [] +let pozitiv_szamok_lista = [] + +function kiiras(negativ_osszeg, pozitiv_osszeg) { + console.log(`A pozitív számok összege: ${pozitiv_osszeg}`); + console.log(`A negatív számok összege: ${negativ_osszeg}`); + +} + +function negativak() { + szamok.forEach(szam => { + if (szam < 0) { + negativ_szamok_lista.push(szam) + } + }) +} + +function pozitivak() { + szamok.forEach(szam => { + if (szam > 0) { + pozitiv_szamok_lista.push(szam) + } + }) +} + +function vegrehajtas(callbackKiiras) { + negativak() + pozitivak() + var negativ_osszeg = negativ_szamok_lista.reduce((accumulator, currentValue) => { + return accumulator + currentValue + }) + + var pozitiv_osszeg = pozitiv_szamok_lista.reduce((accumulator, currentValue) => { + return accumulator + currentValue + }) + + callbackKiiras(negativ_osszeg, pozitiv_osszeg) +} + +vegrehajtas(kiiras) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/script.js b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/script.js new file mode 100644 index 0000000..52f5d9f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 07/js/script.js @@ -0,0 +1,7 @@ +let inkr = 0 +let kiiras = () => { + inkr += 1 + console.log(inkr); +} + +setInterval(kiiras, 3000) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 08/RandomSzamFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 08/RandomSzamFeladat.html new file mode 100644 index 0000000..d4eabc6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 08/RandomSzamFeladat.html @@ -0,0 +1,19 @@ + + + + + + Random Szám Generálása + + + + +

Szám Generáló

+
+ + + +
+
+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 08/SzamitasFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 08/SzamitasFeladat.html new file mode 100644 index 0000000..82fe044 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 08/SzamitasFeladat.html @@ -0,0 +1,22 @@ + + + + + + Számítás + + + + +

Számítás

+
+ +
+ +
+ +
+
+
+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 08/css/style.css b/Suli/13.b/Frontend/Javascript/2024. 10. 08/css/style.css new file mode 100644 index 0000000..a220fb7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 08/css/style.css @@ -0,0 +1,7 @@ +body { + display: flex; + align-items: center; + justify-content: center; + min-height: 100vh; + flex-direction: column; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/RandomSzamFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/RandomSzamFeladat.js new file mode 100644 index 0000000..dd1df51 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/RandomSzamFeladat.js @@ -0,0 +1,44 @@ +const randomSzamInput = document.getElementById("randomSzam") +const generaltSzamok = document.getElementById("generaltSzamok") +const button = document.querySelector("button") + +button.addEventListener("click", () => { + const randomSzamok = [] + let generaltSzamokChildren = Array.from(generaltSzamok.children) + generaltSzamokChildren.forEach(child => { + generaltSzamok.removeChild(child) + }) + + let myPromise = new Promise((resolve, reject) => { + let success + if (Number.isInteger(Number(randomSzamInput.value))) { + success = true + } else { + success = false + } + + setTimeout(() => { + if (success) { + for (let i = 0; i < Number(randomSzamInput.value); i++) { + let randomSzam = Math.floor(Math.random() * 100) + randomSzamok.push(randomSzam) + } + resolve(randomSzamok) + } else { + reject("Probléma volt a kód futásával!") + } + }, 2000) + }) + + myPromise + .then(result => { + let generaltSzamokP = document.createElement("p") + generaltSzamokP.innerHTML = `Generált számok: ${result.join(", ")}` + generaltSzamok.appendChild(generaltSzamokP) + }) + .catch(error => { + let generaltSzamokP = document.createElement("p") + generaltSzamokP.innerHTML = error + generaltSzamok.appendChild(generaltSzamokP) + }) +}) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/SzamitasFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/SzamitasFeladat.js new file mode 100644 index 0000000..be516e8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 08/js/SzamitasFeladat.js @@ -0,0 +1,55 @@ +const button = document.querySelector("button") +const elsoSzam = document.getElementById("elsoSzam") +const masodikSzam = document.getElementById("masodikSzam") +const eredmenyekDiv = document.getElementById("eredmenyek") +console.log(eredmenyekDiv.children); + + +button.addEventListener("click", () => { + const elsoSzamValue = Number(elsoSzam.value) + const masodikSzamValue = Number(masodikSzam.value) + + if (isNaN(elsoSzamValue) && isNaN(masodikSzamValue)) { + alert("Nem számot adott meg valamelyik mezőben!") + return + } + + let eredmenyekDivChildren = Array.from(eredmenyekDiv.children) + eredmenyekDivChildren.forEach(child => { + eredmenyekDiv.removeChild(child) + }) + + + let eredmenyekH1 = document.createElement("h1") + eredmenyekH1.innerHTML = "Eredmények" + eredmenyekDiv.appendChild(eredmenyekH1) + + + let osszegP = document.createElement("p") + osszegP.innerHTML = `Összeg: ${elsoSzamValue + masodikSzamValue}` + eredmenyekDiv.appendChild(osszegP) + + + let kulonbsegP = document.createElement("p") + kulonbsegP.innerHTML = `Különbség: ${elsoSzamValue - masodikSzamValue}` + eredmenyekDiv.appendChild(kulonbsegP) + + + let szorzatP = document.createElement("p") + szorzatP.innerHTML = `Szorzat: ${elsoSzamValue * masodikSzamValue}` + eredmenyekDiv.appendChild(szorzatP) + + + let hanyadosP = document.createElement("p") + if (masodikSzamValue == 0) { + hanyadosP.innerHTML = `Hányados: Nem lehetséges nullával osztani!` + eredmenyekDiv.appendChild(hanyadosP) + return + } + hanyadosP.innerHTML = `Hányados: ${elsoSzamValue / masodikSzamValue}` + eredmenyekDiv.appendChild(hanyadosP) + + + elsoSzam.value = "" + masodikSzam.value = "" +}) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/KepmegjelenitesFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 21/KepmegjelenitesFeladat.html new file mode 100644 index 0000000..c90b562 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/KepmegjelenitesFeladat.html @@ -0,0 +1,12 @@ + + + + + + Képmegjelenítés + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/index.html b/Suli/13.b/Frontend/Javascript/2024. 10. 21/index.html new file mode 100644 index 0000000..3e6cfc4 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/index.html @@ -0,0 +1,12 @@ + + + + + + Document + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/DuplazasFeladatModule.mjs b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/DuplazasFeladatModule.mjs new file mode 100644 index 0000000..2d29dd8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/DuplazasFeladatModule.mjs @@ -0,0 +1,5 @@ +function duplaz(szam) { + return szam * 2 +} + +export {duplaz} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KepmegjelenitesFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KepmegjelenitesFeladat.js new file mode 100644 index 0000000..5d1ce63 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KepmegjelenitesFeladat.js @@ -0,0 +1,21 @@ +async function adatlekeres() { + let valasz = await fetch("https://jsonplaceholder.typicode.com/photos") + let JSadatkereses = await valasz.json() + JSadatkereses.forEach(element => { + // if (element.id != 3) { + // document.body.innerHTML += element.title + // document.body.innerHTML += element.thumbnailUrl + // document.body.innerHTML += element.url + // } + // console.log(element.id); + + }); + + // for (let i = 0; i < 3; i++) { + // document.body.innerHTML += JSadatkereses[i].title + // document.body.innerHTML += JSadatkereses[i].thumbnailUrl + // document.body.innerHTML += JSadatkereses[i].url + // } +} + +adatlekeres() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesDuplazasFeladat.mjs b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesDuplazasFeladat.mjs new file mode 100644 index 0000000..7529894 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesDuplazasFeladat.mjs @@ -0,0 +1,5 @@ +import { duplaz } from "./DuplazasFeladatModule.mjs"; +import { koszontesDuplazas } from "./KoszontesFeladatModule.mjs"; + +console.log(duplaz(3)); +console.log(koszontesDuplazas("Ádám", 37632762)); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesFeladatModule.mjs b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesFeladatModule.mjs new file mode 100644 index 0000000..5e8e34b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/KoszontesFeladatModule.mjs @@ -0,0 +1,5 @@ +function koszontesDuplazas(nev, szam) { + return `${nev}, ${szam * 2}` +} + +export {koszontesDuplazas} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/script.js b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/script.js new file mode 100644 index 0000000..a791191 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/js/script.js @@ -0,0 +1,14 @@ +async function adatlekeres() { + try { + let valasz = await fetch("https://jsonplaceholder.typicode.com/todos") + let JSadatkereses = await valasz.json() + console.log(JSadatkereses); + + } + catch (error) { + console.log(error); + + } +} + +adatlekeres() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 10. 21/koszontesDuplazasFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 10. 21/koszontesDuplazasFeladat.html new file mode 100644 index 0000000..71e3d23 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 10. 21/koszontesDuplazasFeladat.html @@ -0,0 +1,12 @@ + + + + + + Köszöntés és duplázás + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 04/24_11_04 - Frontend.pptx b/Suli/13.b/Frontend/Javascript/2024. 11. 04/24_11_04 - Frontend.pptx new file mode 100644 index 0000000..9817bc5 Binary files /dev/null and b/Suli/13.b/Frontend/Javascript/2024. 11. 04/24_11_04 - Frontend.pptx differ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 04/index.html b/Suli/13.b/Frontend/Javascript/2024. 11. 04/index.html new file mode 100644 index 0000000..b96981d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 04/index.html @@ -0,0 +1,65 @@ + + + + + + + Document + + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 04/~$24_11_04 - Frontend.pptx b/Suli/13.b/Frontend/Javascript/2024. 11. 04/~$24_11_04 - Frontend.pptx new file mode 100644 index 0000000..d700147 Binary files /dev/null and b/Suli/13.b/Frontend/Javascript/2024. 11. 04/~$24_11_04 - Frontend.pptx differ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat1.js b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat1.js new file mode 100644 index 0000000..3a3d72b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat1.js @@ -0,0 +1,28 @@ +class Szemely { + constructor(nev, kor) { + this.nev = nev + this.kor = kor + } + + bemutatkozas() { + return `A nevem ${this.nev} és ${this.kor} éves vagyok!` + } +} + +class Diak extends Szemely { + static diakszam = 0 + constructor(nev, kor, osztaly) { + super(nev, kor) + Diak.diakszam++ + this.osztaly = osztaly + } + + bemutatkozas() { + return `${super.bemutatkozas()} és az ${this.osztaly}-ba/be járok.` + } +} + +const diak1 = new Diak("Tóth Ádám", 19, "13.B") +const diak2 = new Diak("Tóth Ádámm", 191, "12.B") +console.log(diak1.bemutatkozas()); +console.log(`Jelenleg ${Diak.diakszam} tanuló van a rendszerben`); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat2.js b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat2.js new file mode 100644 index 0000000..3fa588d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat2.js @@ -0,0 +1,57 @@ +class Szallitas { + constructor(felado, cimzett, suly, azonosito) { + this.felado = felado + this.cimzett = cimzett + this.suly = suly + this.azonosito = azonosito + } + + informacio() { + return `A feladó ${this.felado}, a címzett ${this.cimzett}, a csomag súlya ${this.suly} és az azonosítója ${this.azonosito}` + } +} + +class Csomag extends Szallitas { + static csomagSzam = 0 + constructor(felado, cimzett, suly, azonosito, meret) { + super(felado, cimzett, suly, azonosito) + this.meret = meret + Csomag.csomagSzam++ + } + + informacio() { + return `${super.informacio()}, valamint a cosmag mérete ${this.meret}.` + } + + static osszesCsomag() { + return Csomag.csomagSzam + } +} + +class Teherauto extends Szallitas { + static autoSzam = 0 + constructor(felado, cimzett, suly, azonosito, maxTerheles) { + super(felado, cimzett, suly, azonosito) + this.maxTerheles = maxTerheles + } + + informacio() { + return `${super.informacio()}, valamint a terhelhetősége ${this.maxTerheles}.` + } + + static osszesAuto() { + return Teherauto.autoSzam + } +} + + +const csomag1 = new Csomag("Kutya", "Macska", "15kg", 1) +const csomag2 = new Csomag("Disznaj", "Kecske", "20kg", 2) +console.log(csomag1.informacio()); +console.log(Csomag.osszesCsomag()) + + +const teherauto1 = new Teherauto("Kutya", "Macska", "15kg", 1, "250kg") +const teherauto2 = new Teherauto("500kg") +console.log(teherauto1.informacio()); +console.log(Teherauto.osszesAuto()) \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat3.js b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat3.js new file mode 100644 index 0000000..37700d8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 05/OOPFeladat3.js @@ -0,0 +1,86 @@ +class Termek { + constructor(nev, ar, mennyiseg, azonosito) { + this.nev = nev + this.ar = ar + this.mennyiseg = mennyiseg + this.azonosito = azonosito + } + + adatok() { + return `A termék neve ${this.nev}, a termék ára ${this.ar}, a termék mennyisége ${this.mennyiseg} és azonosítója ${this.azonosito}` + } +} + +class Elelmiszer extends Termek { + static elelmiszerSzam = 0 + constructor(nev, ar, mennyiseg, azonosito, szavatossagiIdo) { + super(nev, ar, mennyiseg, azonosito) + this.szavatossagiIdo = szavatossagiIdo + Elelmiszer.elelmiszerSzam++ + } + + adatok() { + return `${super.adatok()}, valamint a szavatossági idő ${this.szavatossagiIdo}` + } + + osszesElelmiszer() { + return Elelmiszer.elelmiszerSzam + } +} + +class ElektronikaiTermek extends Termek { + static elektronikaSzam = 0 + constructor(nev, ar, mennyiseg, azonosito, garancia) { + super(nev, ar, mennyiseg, azonosito) + this.garancia = garancia + ElektronikaiTermek.elektronikaSzam++ + } + + adatok() { + return `${super.adatok()}, valamint a garancia időtartama ${this.garancia}.` + } + + osszesElektronikaiTermek() { + return ElektronikaiTermek.elektronikaSzam + } +} + +class Raktar { + constructor(termekek) { + this.termekek = termekek + } + + hozzaadTermek(termek) { + this.termekek.push(termek) + } + + eltavolitTermek(azonosito) { + this.termekek.forEach(element => { + if (element.azonosito == azonosito) { + this.termekek.splice(element) + } + }); + } + + keszletKimutatas() { + this.termekek.forEach(element => { + console.log(element.adatok()); + }) + console.log(this.termekek.length); + } + + keresettTermek(nev) { + this.termekek.forEach(element => { + if (element.nev == nev) { + element. + } + }) + } +} + + +const raktar1 = new Raktar([]) +const elektronikaiTermek1 = new ElektronikaiTermek("Monitor", "85.000 Ft", 2, 1, "2 év") +raktar1.hozzaadTermek(elektronikaiTermek1) +console.log(raktar1.termekek); +raktar1.keszletKimutatas() diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/AszinkronFetchAPIFeladat.html b/Suli/13.b/Frontend/Javascript/2024. 11. 08/AszinkronFetchAPIFeladat.html new file mode 100644 index 0000000..b393e06 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 08/AszinkronFetchAPIFeladat.html @@ -0,0 +1,14 @@ + + + + + + FetchAPI + + + +
+ +
+ + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/Feladatok.docx b/Suli/13.b/Frontend/Javascript/2024. 11. 08/Feladatok.docx new file mode 100644 index 0000000..5f56a07 Binary files /dev/null and b/Suli/13.b/Frontend/Javascript/2024. 11. 08/Feladatok.docx differ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/AszinkronFetchAPIFeladat.mjs b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/AszinkronFetchAPIFeladat.mjs new file mode 100644 index 0000000..153eefc --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/AszinkronFetchAPIFeladat.mjs @@ -0,0 +1,50 @@ +import Bejegyzes from "./Bejegyzes.mjs"; +import BejegyzesLista from "./BejegyzesLista.mjs"; + +async function fetchAdatok(apiUrl) { + let valasz = await fetch(apiUrl) + + try { + if (!valasz.ok) { + throw new Error("Hibás lekérés!") + } + + let JSadatszerkezet = await valasz.json() + + document.querySelector("div").innerHTML = JSON.stringify(JSadatszerkezet, null, 2) + } + + catch (hiba) { + console.log(hiba); + } +} + +// fetchAdatok("https://jsonplaceholder.typicode.com/posts") + + +async function fetchAdatok2(apiUrl) { + let valasz = await fetch(apiUrl) + + try { + if (!valasz.ok) { + throw new Error("Hibás lekérés!") + } + + let JSadatszerkezet = await valasz.json() + + const bejegyzesek = new BejegyzesLista([]) + + JSadatszerkezet.forEach(element => { + let bejegyzes = new Bejegyzes(element["id"], element["title"], element["body"]) + bejegyzesek.hozzaadBejegyzes(bejegyzes) + }); + + bejegyzesek.megjelenitBejegyzesek() + } + + catch (hiba) { + console.log(hiba); + } +} + +fetchAdatok2("https://jsonplaceholder.typicode.com/posts") diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/Bejegyzes.mjs b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/Bejegyzes.mjs new file mode 100644 index 0000000..27759f0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/Bejegyzes.mjs @@ -0,0 +1,13 @@ +class Bejegyzes { + constructor(id, cim, tartalom) { + this.id = id + this.cim = cim + this.tartalom = tartalom + } + + getReszletek() { + return `${this.id}, ${this.cim}, ${this.tartalom}` + } +} + +export default Bejegyzes; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/BejegyzesLista.mjs b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/BejegyzesLista.mjs new file mode 100644 index 0000000..27b7b34 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/BejegyzesLista.mjs @@ -0,0 +1,19 @@ +class BejegyzesLista { + constructor(tomb) { + this.tomb = tomb + } + + hozzaadBejegyzes(bejegyzes) { + this.tomb.push(bejegyzes) + } + + megjelenitBejegyzesek() { + this.tomb.forEach(element => { + document.querySelector("div").innerHTML += element.id + document.querySelector("div").innerHTML += element.cim + document.querySelector("div").innerHTML += element.tartalom + }) + } +} + +export default BejegyzesLista \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/OOPFeladat.js b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/OOPFeladat.js new file mode 100644 index 0000000..b2cafe3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 08/js/OOPFeladat.js @@ -0,0 +1,51 @@ +class Termek { + constructor(nev, ar, darabszam) { + this.nev = nev + this.ar = ar + this.darabszam = darabszam + } + + toSzoveg() { + return `${this.nev}, ${this.ar}, ${this.darabszam}` + } +} + +class Raktar { + static termekLista = [] + + static termekHozzaad(ujTermek) { + Raktar.termekLista.push(ujTermek) + } + + static termekTorles(nev) { + Raktar.termekLista.forEach(element => { + if (element.nev.toLowerCase() == nev.toLowerCase()) { + Raktar.termekLista.splice(element, 1) + } + }) + } + + static termekKeres(nev) { + Raktar.termekLista.forEach(element => { + if (element.nev.toLowerCase() == nev.toLowerCase()) { + console.log(element); + } + }) + } + + static osszesTermekListaz() { + console.log(Raktar.termekLista); + } +} + +termek1 = new Termek("Monitor", "85.000 Ft", 100) +termek2 = new Termek("Billentyűzet", "10.000 Ft", 20) + +Raktar.termekHozzaad(termek1) +Raktar.termekHozzaad(termek2) + + +Raktar.termekKeres("Monitor") +Raktar.osszesTermekListaz() +Raktar.termekTorles("Billentyűzet") +Raktar.osszesTermekListaz() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 12/index.html b/Suli/13.b/Frontend/Javascript/2024. 11. 12/index.html new file mode 100644 index 0000000..f771d0b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 12/index.html @@ -0,0 +1,12 @@ + + + + + + AJAX + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 12/js/script.js b/Suli/13.b/Frontend/Javascript/2024. 11. 12/js/script.js new file mode 100644 index 0000000..448df62 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 12/js/script.js @@ -0,0 +1,25 @@ +let xhttp = new XMLHttpRequest() +xhttp.open("GET", "https://jsonplaceholder.typicode.com/posts", true) + +xhttp.onreadystatechange = function() { + if (xhttp.readyState === 4) { + if (xhttp.status === 200) { + console.log(`Az eredmény: ${JSON.parse(xhttp.responseText)}`) + // const kaka = JSON.parse(xhttp.responseText) + // kaka.forEach(element => { + // console.log(element); + + // }); + } + + else if (xhttp.status === 404) { + console.log("Erőforrás nem található! - 404-es hibakód") + } + + else { + console.error(`Hiba történt, státuszkód: ${xhttp.status}`) + } + } +} + +xhttp.send() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 15/index.html b/Suli/13.b/Frontend/Javascript/2024. 11. 15/index.html new file mode 100644 index 0000000..3b11da3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 15/index.html @@ -0,0 +1,12 @@ + + + + + + AJAX Lekérés + + + + + + \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 15/js/script.js b/Suli/13.b/Frontend/Javascript/2024. 11. 15/js/script.js new file mode 100644 index 0000000..c885426 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 15/js/script.js @@ -0,0 +1,21 @@ +let xhttp = new XMLHttpRequest() +xhttp.open("GET", "https://jsonplaceholder.typicode.com/posts", true) + +xhttp.onreadystatechange = function() { + if (xhttp.readyState === 4) { + if (xhttp.status === 200) { + console.log("Sikeres kérés:") + + let response = JSON.parse(xhttp.responseText) + for (let i = 0; i < 3; i++) { + console.log(response[i]); + } + } else if (xhttp.status === 404) { + console.log("Erőforrás nem található - 404-es hibakód.") + } else { + console.log(`Hiba történt: ${xhttp.status}`) + } + } +} + +xhttp.send() \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/24_11_18 - Frontend.pptx b/Suli/13.b/Frontend/Javascript/2024. 11. 18/24_11_18 - Frontend.pptx new file mode 100644 index 0000000..723aec0 Binary files /dev/null and b/Suli/13.b/Frontend/Javascript/2024. 11. 18/24_11_18 - Frontend.pptx differ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs new file mode 100644 index 0000000..ec3bd4c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../ejs/bin/cli.js" "$@" +else + exec node "$basedir/../ejs/bin/cli.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.cmd new file mode 100644 index 0000000..7cc2b56 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\ejs\bin\cli.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.ps1 new file mode 100644 index 0000000..f31305e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/ejs.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../ejs/bin/cli.js" $args + } else { + & "$basedir/node$exe" "$basedir/../ejs/bin/cli.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../ejs/bin/cli.js" $args + } else { + & "node$exe" "$basedir/../ejs/bin/cli.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake new file mode 100644 index 0000000..b92bfba --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../jake/bin/cli.js" "$@" +else + exec node "$basedir/../jake/bin/cli.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.cmd new file mode 100644 index 0000000..1ccccef --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\jake\bin\cli.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.ps1 new file mode 100644 index 0000000..d86e1bd --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/jake.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../jake/bin/cli.js" $args + } else { + & "$basedir/node$exe" "$basedir/../jake/bin/cli.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../jake/bin/cli.js" $args + } else { + & "node$exe" "$basedir/../jake/bin/cli.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime new file mode 100644 index 0000000..7751de3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../mime/cli.js" "$@" +else + exec node "$basedir/../mime/cli.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.cmd new file mode 100644 index 0000000..54491f1 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\mime\cli.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.ps1 new file mode 100644 index 0000000..2222f40 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/mime.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../mime/cli.js" $args + } else { + & "$basedir/node$exe" "$basedir/../mime/cli.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../mime/cli.js" $args + } else { + & "node$exe" "$basedir/../mime/cli.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon new file mode 100644 index 0000000..c477a18 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../nodemon/bin/nodemon.js" "$@" +else + exec node "$basedir/../nodemon/bin/nodemon.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.cmd new file mode 100644 index 0000000..55acf8a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\nodemon\bin\nodemon.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.ps1 new file mode 100644 index 0000000..d4e3f5d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodemon.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../nodemon/bin/nodemon.js" $args + } else { + & "$basedir/node$exe" "$basedir/../nodemon/bin/nodemon.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../nodemon/bin/nodemon.js" $args + } else { + & "node$exe" "$basedir/../nodemon/bin/nodemon.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch new file mode 100644 index 0000000..3e146b4 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../touch/bin/nodetouch.js" "$@" +else + exec node "$basedir/../touch/bin/nodetouch.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.cmd new file mode 100644 index 0000000..8298b91 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\touch\bin\nodetouch.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.ps1 new file mode 100644 index 0000000..5f68b4c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/nodetouch.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../touch/bin/nodetouch.js" $args + } else { + & "$basedir/node$exe" "$basedir/../touch/bin/nodetouch.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../touch/bin/nodetouch.js" $args + } else { + & "node$exe" "$basedir/../touch/bin/nodetouch.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver new file mode 100644 index 0000000..97c5327 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver @@ -0,0 +1,16 @@ +#!/bin/sh +basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')") + +case `uname` in + *CYGWIN*|*MINGW*|*MSYS*) + if command -v cygpath > /dev/null 2>&1; then + basedir=`cygpath -w "$basedir"` + fi + ;; +esac + +if [ -x "$basedir/node" ]; then + exec "$basedir/node" "$basedir/../semver/bin/semver.js" "$@" +else + exec node "$basedir/../semver/bin/semver.js" "$@" +fi diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.cmd b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.cmd new file mode 100644 index 0000000..9913fa9 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.cmd @@ -0,0 +1,17 @@ +@ECHO off +GOTO start +:find_dp0 +SET dp0=%~dp0 +EXIT /b +:start +SETLOCAL +CALL :find_dp0 + +IF EXIST "%dp0%\node.exe" ( + SET "_prog=%dp0%\node.exe" +) ELSE ( + SET "_prog=node" + SET PATHEXT=%PATHEXT:;.JS;=;% +) + +endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\semver\bin\semver.js" %* diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.ps1 b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.ps1 new file mode 100644 index 0000000..314717a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.bin/semver.ps1 @@ -0,0 +1,28 @@ +#!/usr/bin/env pwsh +$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent + +$exe="" +if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) { + # Fix case when both the Windows and Linux builds of Node + # are installed in the same directory + $exe=".exe" +} +$ret=0 +if (Test-Path "$basedir/node$exe") { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args + } else { + & "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args + } + $ret=$LASTEXITCODE +} else { + # Support pipeline input + if ($MyInvocation.ExpectingInput) { + $input | & "node$exe" "$basedir/../semver/bin/semver.js" $args + } else { + & "node$exe" "$basedir/../semver/bin/semver.js" $args + } + $ret=$LASTEXITCODE +} +exit $ret diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.package-lock.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.package-lock.json new file mode 100644 index 0000000..8b10165 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/.package-lock.json @@ -0,0 +1,1267 @@ +{ + "name": "2024.-11.-18", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "node_modules/accepts": { + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", + "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", + "license": "MIT", + "dependencies": { + "mime-types": "~2.1.34", + "negotiator": "0.6.3" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "license": "ISC", + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==", + "license": "MIT" + }, + "node_modules/async": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz", + "integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==", + "license": "MIT" + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "license": "MIT" + }, + "node_modules/binary-extensions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/body-parser": { + "version": "1.20.3", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", + "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", + "license": "MIT", + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.5", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.13.0", + "raw-body": "2.5.2", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", + "license": "MIT", + "dependencies": { + "fill-range": "^7.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/chalk/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/chalk/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", + "license": "MIT", + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "license": "MIT" + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "license": "MIT" + }, + "node_modules/content-disposition": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", + "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", + "license": "MIT", + "dependencies": { + "safe-buffer": "5.2.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.1.tgz", + "integrity": "sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==", + "license": "MIT" + }, + "node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "license": "MIT", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "license": "MIT", + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "license": "MIT" + }, + "node_modules/ejs": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", + "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", + "license": "Apache-2.0", + "dependencies": { + "jake": "^10.8.5" + }, + "bin": { + "ejs": "bin/cli.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/encodeurl": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", + "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "license": "MIT" + }, + "node_modules/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/express": { + "version": "4.21.1", + "resolved": "https://registry.npmjs.org/express/-/express-4.21.1.tgz", + "integrity": "sha512-YSFlK1Ee0/GC8QaO91tHcDxJiE/X4FbpAyQWkxAvG6AXCuR65YzK8ua6D9hvi/TzUfZMpc+BwuM1IPw8fmQBiQ==", + "license": "MIT", + "dependencies": { + "accepts": "~1.3.8", + "array-flatten": "1.1.1", + "body-parser": "1.20.3", + "content-disposition": "0.5.4", + "content-type": "~1.0.4", + "cookie": "0.7.1", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "2.0.0", + "encodeurl": "~2.0.0", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "1.3.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "merge-descriptors": "1.0.3", + "methods": "~1.1.2", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.10", + "proxy-addr": "~2.0.7", + "qs": "6.13.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.2.1", + "send": "0.19.0", + "serve-static": "1.16.2", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/filelist": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", + "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==", + "license": "Apache-2.0", + "dependencies": { + "minimatch": "^5.0.1" + } + }, + "node_modules/filelist/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/filelist/node_modules/minimatch": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", + "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "license": "MIT", + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/finalhandler": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.3.1.tgz", + "integrity": "sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==", + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~2.0.0", + "escape-html": "~1.0.3", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "statuses": "2.0.1", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "license": "MIT", + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ignore-by-default": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", + "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", + "license": "ISC" + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "license": "ISC" + }, + "node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "license": "MIT", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "license": "MIT", + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/jake": { + "version": "10.9.2", + "resolved": "https://registry.npmjs.org/jake/-/jake-10.9.2.tgz", + "integrity": "sha512-2P4SQ0HrLQ+fw6llpLnOaGAvN2Zu6778SJMrCUwns4fOoG9ayrTiZk3VV8sCPkVZF8ab0zksVpS8FDY5pRCNBA==", + "license": "Apache-2.0", + "dependencies": { + "async": "^3.2.3", + "chalk": "^4.0.2", + "filelist": "^1.0.4", + "minimatch": "^3.1.2" + }, + "bin": { + "jake": "bin/cli.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/merge-descriptors": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz", + "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "license": "MIT", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "license": "MIT" + }, + "node_modules/negotiator": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", + "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/nodemon": { + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.7.tgz", + "integrity": "sha512-hLj7fuMow6f0lbB0cD14Lz2xNjwsyruH251Pk4t/yIitCFJbmY1myuLlHm/q06aST4jg6EgAh74PIBBrRqpVAQ==", + "license": "MIT", + "dependencies": { + "chokidar": "^3.5.2", + "debug": "^4", + "ignore-by-default": "^1.0.1", + "minimatch": "^3.1.2", + "pstree.remy": "^1.1.8", + "semver": "^7.5.3", + "simple-update-notifier": "^2.0.0", + "supports-color": "^5.5.0", + "touch": "^3.1.0", + "undefsafe": "^2.0.5" + }, + "bin": { + "nodemon": "bin/nodemon.js" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/nodemon" + } + }, + "node_modules/nodemon/node_modules/debug": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", + "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/nodemon/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.3.tgz", + "integrity": "sha512-kDCGIbxkDSXE3euJZZXzc6to7fCrKHNI/hSRQnRuQ+BWjFNzZwiFF8fj/6o2t2G9/jTj8PSIYTfCLelLZEeRpA==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "license": "MIT", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/path": { + "version": "0.12.7", + "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz", + "integrity": "sha512-aXXC6s+1w7otVF9UletFkFcDsJeO7lSZBPUQhtb5O0xJe8LtYhj/GxldoL09bBj9+ZmE2hNoHqQSFMN5fikh4Q==", + "license": "MIT", + "dependencies": { + "process": "^0.11.1", + "util": "^0.10.3" + } + }, + "node_modules/path-to-regexp": { + "version": "0.1.10", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.10.tgz", + "integrity": "sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==", + "license": "MIT" + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "license": "MIT", + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==", + "license": "MIT", + "engines": { + "node": ">= 0.6.0" + } + }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "license": "MIT", + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/pstree.remy": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", + "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", + "license": "MIT" + }, + "node_modules/qs": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", + "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", + "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", + "license": "MIT", + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "license": "MIT", + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "license": "MIT" + }, + "node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/send": { + "version": "0.19.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz", + "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==", + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "2.4.1", + "range-parser": "~1.2.1", + "statuses": "2.0.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/send/node_modules/encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/send/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, + "node_modules/serve-static": { + "version": "1.16.2", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.2.tgz", + "integrity": "sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==", + "license": "MIT", + "dependencies": { + "encodeurl": "~2.0.0", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.19.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "license": "ISC" + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/simple-update-notifier": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", + "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", + "license": "MIT", + "dependencies": { + "semver": "^7.5.3" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "license": "MIT", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "license": "MIT", + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "license": "MIT", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/touch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.1.tgz", + "integrity": "sha512-r0eojU4bI8MnHr8c5bNo7lJDdI2qXlWWJk6a9EAFG7vbhTjElYhBVS3/miuE0uOuoLdb8Mc/rVfsmm6eo5o9GA==", + "license": "ISC", + "bin": { + "nodetouch": "bin/nodetouch.js" + } + }, + "node_modules/type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "license": "MIT", + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/undefsafe": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", + "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", + "license": "MIT" + }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/util": { + "version": "0.10.4", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", + "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", + "license": "MIT", + "dependencies": { + "inherits": "2.0.3" + } + }, + "node_modules/util/node_modules/inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", + "license": "ISC" + }, + "node_modules/utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", + "license": "MIT", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + } + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/HISTORY.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/HISTORY.md new file mode 100644 index 0000000..cb5990c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/HISTORY.md @@ -0,0 +1,243 @@ +1.3.8 / 2022-02-02 +================== + + * deps: mime-types@~2.1.34 + - deps: mime-db@~1.51.0 + * deps: negotiator@0.6.3 + +1.3.7 / 2019-04-29 +================== + + * deps: negotiator@0.6.2 + - Fix sorting charset, encoding, and language with extra parameters + +1.3.6 / 2019-04-28 +================== + + * deps: mime-types@~2.1.24 + - deps: mime-db@~1.40.0 + +1.3.5 / 2018-02-28 +================== + + * deps: mime-types@~2.1.18 + - deps: mime-db@~1.33.0 + +1.3.4 / 2017-08-22 +================== + + * deps: mime-types@~2.1.16 + - deps: mime-db@~1.29.0 + +1.3.3 / 2016-05-02 +================== + + * deps: mime-types@~2.1.11 + - deps: mime-db@~1.23.0 + * deps: negotiator@0.6.1 + - perf: improve `Accept` parsing speed + - perf: improve `Accept-Charset` parsing speed + - perf: improve `Accept-Encoding` parsing speed + - perf: improve `Accept-Language` parsing speed + +1.3.2 / 2016-03-08 +================== + + * deps: mime-types@~2.1.10 + - Fix extension of `application/dash+xml` + - Update primary extension for `audio/mp4` + - deps: mime-db@~1.22.0 + +1.3.1 / 2016-01-19 +================== + + * deps: mime-types@~2.1.9 + - deps: mime-db@~1.21.0 + +1.3.0 / 2015-09-29 +================== + + * deps: mime-types@~2.1.7 + - deps: mime-db@~1.19.0 + * deps: negotiator@0.6.0 + - Fix including type extensions in parameters in `Accept` parsing + - Fix parsing `Accept` parameters with quoted equals + - Fix parsing `Accept` parameters with quoted semicolons + - Lazy-load modules from main entry point + - perf: delay type concatenation until needed + - perf: enable strict mode + - perf: hoist regular expressions + - perf: remove closures getting spec properties + - perf: remove a closure from media type parsing + - perf: remove property delete from media type parsing + +1.2.13 / 2015-09-06 +=================== + + * deps: mime-types@~2.1.6 + - deps: mime-db@~1.18.0 + +1.2.12 / 2015-07-30 +=================== + + * deps: mime-types@~2.1.4 + - deps: mime-db@~1.16.0 + +1.2.11 / 2015-07-16 +=================== + + * deps: mime-types@~2.1.3 + - deps: mime-db@~1.15.0 + +1.2.10 / 2015-07-01 +=================== + + * deps: mime-types@~2.1.2 + - deps: mime-db@~1.14.0 + +1.2.9 / 2015-06-08 +================== + + * deps: mime-types@~2.1.1 + - perf: fix deopt during mapping + +1.2.8 / 2015-06-07 +================== + + * deps: mime-types@~2.1.0 + - deps: mime-db@~1.13.0 + * perf: avoid argument reassignment & argument slice + * perf: avoid negotiator recursive construction + * perf: enable strict mode + * perf: remove unnecessary bitwise operator + +1.2.7 / 2015-05-10 +================== + + * deps: negotiator@0.5.3 + - Fix media type parameter matching to be case-insensitive + +1.2.6 / 2015-05-07 +================== + + * deps: mime-types@~2.0.11 + - deps: mime-db@~1.9.1 + * deps: negotiator@0.5.2 + - Fix comparing media types with quoted values + - Fix splitting media types with quoted commas + +1.2.5 / 2015-03-13 +================== + + * deps: mime-types@~2.0.10 + - deps: mime-db@~1.8.0 + +1.2.4 / 2015-02-14 +================== + + * Support Node.js 0.6 + * deps: mime-types@~2.0.9 + - deps: mime-db@~1.7.0 + * deps: negotiator@0.5.1 + - Fix preference sorting to be stable for long acceptable lists + +1.2.3 / 2015-01-31 +================== + + * deps: mime-types@~2.0.8 + - deps: mime-db@~1.6.0 + +1.2.2 / 2014-12-30 +================== + + * deps: mime-types@~2.0.7 + - deps: mime-db@~1.5.0 + +1.2.1 / 2014-12-30 +================== + + * deps: mime-types@~2.0.5 + - deps: mime-db@~1.3.1 + +1.2.0 / 2014-12-19 +================== + + * deps: negotiator@0.5.0 + - Fix list return order when large accepted list + - Fix missing identity encoding when q=0 exists + - Remove dynamic building of Negotiator class + +1.1.4 / 2014-12-10 +================== + + * deps: mime-types@~2.0.4 + - deps: mime-db@~1.3.0 + +1.1.3 / 2014-11-09 +================== + + * deps: mime-types@~2.0.3 + - deps: mime-db@~1.2.0 + +1.1.2 / 2014-10-14 +================== + + * deps: negotiator@0.4.9 + - Fix error when media type has invalid parameter + +1.1.1 / 2014-09-28 +================== + + * deps: mime-types@~2.0.2 + - deps: mime-db@~1.1.0 + * deps: negotiator@0.4.8 + - Fix all negotiations to be case-insensitive + - Stable sort preferences of same quality according to client order + +1.1.0 / 2014-09-02 +================== + + * update `mime-types` + +1.0.7 / 2014-07-04 +================== + + * Fix wrong type returned from `type` when match after unknown extension + +1.0.6 / 2014-06-24 +================== + + * deps: negotiator@0.4.7 + +1.0.5 / 2014-06-20 +================== + + * fix crash when unknown extension given + +1.0.4 / 2014-06-19 +================== + + * use `mime-types` + +1.0.3 / 2014-06-11 +================== + + * deps: negotiator@0.4.6 + - Order by specificity when quality is the same + +1.0.2 / 2014-05-29 +================== + + * Fix interpretation when header not in request + * deps: pin negotiator@0.4.5 + +1.0.1 / 2014-01-18 +================== + + * Identity encoding isn't always acceptable + * deps: negotiator@~0.4.0 + +1.0.0 / 2013-12-27 +================== + + * Genesis diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/LICENSE new file mode 100644 index 0000000..0616607 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/README.md new file mode 100644 index 0000000..82680c5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/README.md @@ -0,0 +1,140 @@ +# accepts + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Node.js Version][node-version-image]][node-version-url] +[![Build Status][github-actions-ci-image]][github-actions-ci-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Higher level content negotiation based on [negotiator](https://www.npmjs.com/package/negotiator). +Extracted from [koa](https://www.npmjs.com/package/koa) for general use. + +In addition to negotiator, it allows: + +- Allows types as an array or arguments list, ie `(['text/html', 'application/json'])` + as well as `('text/html', 'application/json')`. +- Allows type shorthands such as `json`. +- Returns `false` when no types match +- Treats non-existent headers as `*` + +## Installation + +This is a [Node.js](https://nodejs.org/en/) module available through the +[npm registry](https://www.npmjs.com/). Installation is done using the +[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally): + +```sh +$ npm install accepts +``` + +## API + +```js +var accepts = require('accepts') +``` + +### accepts(req) + +Create a new `Accepts` object for the given `req`. + +#### .charset(charsets) + +Return the first accepted charset. If nothing in `charsets` is accepted, +then `false` is returned. + +#### .charsets() + +Return the charsets that the request accepts, in the order of the client's +preference (most preferred first). + +#### .encoding(encodings) + +Return the first accepted encoding. If nothing in `encodings` is accepted, +then `false` is returned. + +#### .encodings() + +Return the encodings that the request accepts, in the order of the client's +preference (most preferred first). + +#### .language(languages) + +Return the first accepted language. If nothing in `languages` is accepted, +then `false` is returned. + +#### .languages() + +Return the languages that the request accepts, in the order of the client's +preference (most preferred first). + +#### .type(types) + +Return the first accepted type (and it is returned as the same text as what +appears in the `types` array). If nothing in `types` is accepted, then `false` +is returned. + +The `types` array can contain full MIME types or file extensions. Any value +that is not a full MIME types is passed to `require('mime-types').lookup`. + +#### .types() + +Return the types that the request accepts, in the order of the client's +preference (most preferred first). + +## Examples + +### Simple type negotiation + +This simple example shows how to use `accepts` to return a different typed +respond body based on what the client wants to accept. The server lists it's +preferences in order and will get back the best match between the client and +server. + +```js +var accepts = require('accepts') +var http = require('http') + +function app (req, res) { + var accept = accepts(req) + + // the order of this list is significant; should be server preferred order + switch (accept.type(['json', 'html'])) { + case 'json': + res.setHeader('Content-Type', 'application/json') + res.write('{"hello":"world!"}') + break + case 'html': + res.setHeader('Content-Type', 'text/html') + res.write('hello, world!') + break + default: + // the fallback is text/plain, so no need to specify it above + res.setHeader('Content-Type', 'text/plain') + res.write('hello, world!') + break + } + + res.end() +} + +http.createServer(app).listen(3000) +``` + +You can test this out with the cURL program: +```sh +curl -I -H'Accept: text/html' http://localhost:3000/ +``` + +## License + +[MIT](LICENSE) + +[coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/accepts/master +[coveralls-url]: https://coveralls.io/r/jshttp/accepts?branch=master +[github-actions-ci-image]: https://badgen.net/github/checks/jshttp/accepts/master?label=ci +[github-actions-ci-url]: https://github.com/jshttp/accepts/actions/workflows/ci.yml +[node-version-image]: https://badgen.net/npm/node/accepts +[node-version-url]: https://nodejs.org/en/download +[npm-downloads-image]: https://badgen.net/npm/dm/accepts +[npm-url]: https://npmjs.org/package/accepts +[npm-version-image]: https://badgen.net/npm/v/accepts diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/index.js new file mode 100644 index 0000000..e9b2f63 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/index.js @@ -0,0 +1,238 @@ +/*! + * accepts + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var Negotiator = require('negotiator') +var mime = require('mime-types') + +/** + * Module exports. + * @public + */ + +module.exports = Accepts + +/** + * Create a new Accepts object for the given req. + * + * @param {object} req + * @public + */ + +function Accepts (req) { + if (!(this instanceof Accepts)) { + return new Accepts(req) + } + + this.headers = req.headers + this.negotiator = new Negotiator(req) +} + +/** + * Check if the given `type(s)` is acceptable, returning + * the best match when true, otherwise `undefined`, in which + * case you should respond with 406 "Not Acceptable". + * + * The `type` value may be a single mime type string + * such as "application/json", the extension name + * such as "json" or an array `["json", "html", "text/plain"]`. When a list + * or array is given the _best_ match, if any is returned. + * + * Examples: + * + * // Accept: text/html + * this.types('html'); + * // => "html" + * + * // Accept: text/*, application/json + * this.types('html'); + * // => "html" + * this.types('text/html'); + * // => "text/html" + * this.types('json', 'text'); + * // => "json" + * this.types('application/json'); + * // => "application/json" + * + * // Accept: text/*, application/json + * this.types('image/png'); + * this.types('png'); + * // => undefined + * + * // Accept: text/*;q=.5, application/json + * this.types(['html', 'json']); + * this.types('html', 'json'); + * // => "json" + * + * @param {String|Array} types... + * @return {String|Array|Boolean} + * @public + */ + +Accepts.prototype.type = +Accepts.prototype.types = function (types_) { + var types = types_ + + // support flattened arguments + if (types && !Array.isArray(types)) { + types = new Array(arguments.length) + for (var i = 0; i < types.length; i++) { + types[i] = arguments[i] + } + } + + // no types, return all requested types + if (!types || types.length === 0) { + return this.negotiator.mediaTypes() + } + + // no accept header, return first given type + if (!this.headers.accept) { + return types[0] + } + + var mimes = types.map(extToMime) + var accepts = this.negotiator.mediaTypes(mimes.filter(validMime)) + var first = accepts[0] + + return first + ? types[mimes.indexOf(first)] + : false +} + +/** + * Return accepted encodings or best fit based on `encodings`. + * + * Given `Accept-Encoding: gzip, deflate` + * an array sorted by quality is returned: + * + * ['gzip', 'deflate'] + * + * @param {String|Array} encodings... + * @return {String|Array} + * @public + */ + +Accepts.prototype.encoding = +Accepts.prototype.encodings = function (encodings_) { + var encodings = encodings_ + + // support flattened arguments + if (encodings && !Array.isArray(encodings)) { + encodings = new Array(arguments.length) + for (var i = 0; i < encodings.length; i++) { + encodings[i] = arguments[i] + } + } + + // no encodings, return all requested encodings + if (!encodings || encodings.length === 0) { + return this.negotiator.encodings() + } + + return this.negotiator.encodings(encodings)[0] || false +} + +/** + * Return accepted charsets or best fit based on `charsets`. + * + * Given `Accept-Charset: utf-8, iso-8859-1;q=0.2, utf-7;q=0.5` + * an array sorted by quality is returned: + * + * ['utf-8', 'utf-7', 'iso-8859-1'] + * + * @param {String|Array} charsets... + * @return {String|Array} + * @public + */ + +Accepts.prototype.charset = +Accepts.prototype.charsets = function (charsets_) { + var charsets = charsets_ + + // support flattened arguments + if (charsets && !Array.isArray(charsets)) { + charsets = new Array(arguments.length) + for (var i = 0; i < charsets.length; i++) { + charsets[i] = arguments[i] + } + } + + // no charsets, return all requested charsets + if (!charsets || charsets.length === 0) { + return this.negotiator.charsets() + } + + return this.negotiator.charsets(charsets)[0] || false +} + +/** + * Return accepted languages or best fit based on `langs`. + * + * Given `Accept-Language: en;q=0.8, es, pt` + * an array sorted by quality is returned: + * + * ['es', 'pt', 'en'] + * + * @param {String|Array} langs... + * @return {Array|String} + * @public + */ + +Accepts.prototype.lang = +Accepts.prototype.langs = +Accepts.prototype.language = +Accepts.prototype.languages = function (languages_) { + var languages = languages_ + + // support flattened arguments + if (languages && !Array.isArray(languages)) { + languages = new Array(arguments.length) + for (var i = 0; i < languages.length; i++) { + languages[i] = arguments[i] + } + } + + // no languages, return all requested languages + if (!languages || languages.length === 0) { + return this.negotiator.languages() + } + + return this.negotiator.languages(languages)[0] || false +} + +/** + * Convert extnames to mime. + * + * @param {String} type + * @return {String} + * @private + */ + +function extToMime (type) { + return type.indexOf('/') === -1 + ? mime.lookup(type) + : type +} + +/** + * Check if mime is valid. + * + * @param {String} type + * @return {String} + * @private + */ + +function validMime (type) { + return typeof type === 'string' +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/package.json new file mode 100644 index 0000000..0f2d15d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/accepts/package.json @@ -0,0 +1,47 @@ +{ + "name": "accepts", + "description": "Higher-level content negotiation", + "version": "1.3.8", + "contributors": [ + "Douglas Christopher Wilson ", + "Jonathan Ong (http://jongleberry.com)" + ], + "license": "MIT", + "repository": "jshttp/accepts", + "dependencies": { + "mime-types": "~2.1.34", + "negotiator": "0.6.3" + }, + "devDependencies": { + "deep-equal": "1.0.1", + "eslint": "7.32.0", + "eslint-config-standard": "14.1.1", + "eslint-plugin-import": "2.25.4", + "eslint-plugin-markdown": "2.2.1", + "eslint-plugin-node": "11.1.0", + "eslint-plugin-promise": "4.3.1", + "eslint-plugin-standard": "4.1.0", + "mocha": "9.2.0", + "nyc": "15.1.0" + }, + "files": [ + "LICENSE", + "HISTORY.md", + "index.js" + ], + "engines": { + "node": ">= 0.6" + }, + "scripts": { + "lint": "eslint .", + "test": "mocha --reporter spec --check-leaks --bail test/", + "test-ci": "nyc --reporter=lcov --reporter=text npm test", + "test-cov": "nyc --reporter=html --reporter=text npm test" + }, + "keywords": [ + "content", + "negotiation", + "accept", + "accepts" + ] +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.d.ts new file mode 100644 index 0000000..44a907e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.d.ts @@ -0,0 +1,345 @@ +declare type CSSColor = + | 'aliceblue' + | 'antiquewhite' + | 'aqua' + | 'aquamarine' + | 'azure' + | 'beige' + | 'bisque' + | 'black' + | 'blanchedalmond' + | 'blue' + | 'blueviolet' + | 'brown' + | 'burlywood' + | 'cadetblue' + | 'chartreuse' + | 'chocolate' + | 'coral' + | 'cornflowerblue' + | 'cornsilk' + | 'crimson' + | 'cyan' + | 'darkblue' + | 'darkcyan' + | 'darkgoldenrod' + | 'darkgray' + | 'darkgreen' + | 'darkgrey' + | 'darkkhaki' + | 'darkmagenta' + | 'darkolivegreen' + | 'darkorange' + | 'darkorchid' + | 'darkred' + | 'darksalmon' + | 'darkseagreen' + | 'darkslateblue' + | 'darkslategray' + | 'darkslategrey' + | 'darkturquoise' + | 'darkviolet' + | 'deeppink' + | 'deepskyblue' + | 'dimgray' + | 'dimgrey' + | 'dodgerblue' + | 'firebrick' + | 'floralwhite' + | 'forestgreen' + | 'fuchsia' + | 'gainsboro' + | 'ghostwhite' + | 'gold' + | 'goldenrod' + | 'gray' + | 'green' + | 'greenyellow' + | 'grey' + | 'honeydew' + | 'hotpink' + | 'indianred' + | 'indigo' + | 'ivory' + | 'khaki' + | 'lavender' + | 'lavenderblush' + | 'lawngreen' + | 'lemonchiffon' + | 'lightblue' + | 'lightcoral' + | 'lightcyan' + | 'lightgoldenrodyellow' + | 'lightgray' + | 'lightgreen' + | 'lightgrey' + | 'lightpink' + | 'lightsalmon' + | 'lightseagreen' + | 'lightskyblue' + | 'lightslategray' + | 'lightslategrey' + | 'lightsteelblue' + | 'lightyellow' + | 'lime' + | 'limegreen' + | 'linen' + | 'magenta' + | 'maroon' + | 'mediumaquamarine' + | 'mediumblue' + | 'mediumorchid' + | 'mediumpurple' + | 'mediumseagreen' + | 'mediumslateblue' + | 'mediumspringgreen' + | 'mediumturquoise' + | 'mediumvioletred' + | 'midnightblue' + | 'mintcream' + | 'mistyrose' + | 'moccasin' + | 'navajowhite' + | 'navy' + | 'oldlace' + | 'olive' + | 'olivedrab' + | 'orange' + | 'orangered' + | 'orchid' + | 'palegoldenrod' + | 'palegreen' + | 'paleturquoise' + | 'palevioletred' + | 'papayawhip' + | 'peachpuff' + | 'peru' + | 'pink' + | 'plum' + | 'powderblue' + | 'purple' + | 'rebeccapurple' + | 'red' + | 'rosybrown' + | 'royalblue' + | 'saddlebrown' + | 'salmon' + | 'sandybrown' + | 'seagreen' + | 'seashell' + | 'sienna' + | 'silver' + | 'skyblue' + | 'slateblue' + | 'slategray' + | 'slategrey' + | 'snow' + | 'springgreen' + | 'steelblue' + | 'tan' + | 'teal' + | 'thistle' + | 'tomato' + | 'turquoise' + | 'violet' + | 'wheat' + | 'white' + | 'whitesmoke' + | 'yellow' + | 'yellowgreen'; + +declare namespace ansiStyles { + interface ColorConvert { + /** + The RGB color space. + + @param red - (`0`-`255`) + @param green - (`0`-`255`) + @param blue - (`0`-`255`) + */ + rgb(red: number, green: number, blue: number): string; + + /** + The RGB HEX color space. + + @param hex - A hexadecimal string containing RGB data. + */ + hex(hex: string): string; + + /** + @param keyword - A CSS color name. + */ + keyword(keyword: CSSColor): string; + + /** + The HSL color space. + + @param hue - (`0`-`360`) + @param saturation - (`0`-`100`) + @param lightness - (`0`-`100`) + */ + hsl(hue: number, saturation: number, lightness: number): string; + + /** + The HSV color space. + + @param hue - (`0`-`360`) + @param saturation - (`0`-`100`) + @param value - (`0`-`100`) + */ + hsv(hue: number, saturation: number, value: number): string; + + /** + The HSV color space. + + @param hue - (`0`-`360`) + @param whiteness - (`0`-`100`) + @param blackness - (`0`-`100`) + */ + hwb(hue: number, whiteness: number, blackness: number): string; + + /** + Use a [4-bit unsigned number](https://en.wikipedia.org/wiki/ANSI_escape_code#3/4-bit) to set text color. + */ + ansi(ansi: number): string; + + /** + Use an [8-bit unsigned number](https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit) to set text color. + */ + ansi256(ansi: number): string; + } + + interface CSPair { + /** + The ANSI terminal control sequence for starting this style. + */ + readonly open: string; + + /** + The ANSI terminal control sequence for ending this style. + */ + readonly close: string; + } + + interface ColorBase { + readonly ansi: ColorConvert; + readonly ansi256: ColorConvert; + readonly ansi16m: ColorConvert; + + /** + The ANSI terminal control sequence for ending this color. + */ + readonly close: string; + } + + interface Modifier { + /** + Resets the current color chain. + */ + readonly reset: CSPair; + + /** + Make text bold. + */ + readonly bold: CSPair; + + /** + Emitting only a small amount of light. + */ + readonly dim: CSPair; + + /** + Make text italic. (Not widely supported) + */ + readonly italic: CSPair; + + /** + Make text underline. (Not widely supported) + */ + readonly underline: CSPair; + + /** + Inverse background and foreground colors. + */ + readonly inverse: CSPair; + + /** + Prints the text, but makes it invisible. + */ + readonly hidden: CSPair; + + /** + Puts a horizontal line through the center of the text. (Not widely supported) + */ + readonly strikethrough: CSPair; + } + + interface ForegroundColor { + readonly black: CSPair; + readonly red: CSPair; + readonly green: CSPair; + readonly yellow: CSPair; + readonly blue: CSPair; + readonly cyan: CSPair; + readonly magenta: CSPair; + readonly white: CSPair; + + /** + Alias for `blackBright`. + */ + readonly gray: CSPair; + + /** + Alias for `blackBright`. + */ + readonly grey: CSPair; + + readonly blackBright: CSPair; + readonly redBright: CSPair; + readonly greenBright: CSPair; + readonly yellowBright: CSPair; + readonly blueBright: CSPair; + readonly cyanBright: CSPair; + readonly magentaBright: CSPair; + readonly whiteBright: CSPair; + } + + interface BackgroundColor { + readonly bgBlack: CSPair; + readonly bgRed: CSPair; + readonly bgGreen: CSPair; + readonly bgYellow: CSPair; + readonly bgBlue: CSPair; + readonly bgCyan: CSPair; + readonly bgMagenta: CSPair; + readonly bgWhite: CSPair; + + /** + Alias for `bgBlackBright`. + */ + readonly bgGray: CSPair; + + /** + Alias for `bgBlackBright`. + */ + readonly bgGrey: CSPair; + + readonly bgBlackBright: CSPair; + readonly bgRedBright: CSPair; + readonly bgGreenBright: CSPair; + readonly bgYellowBright: CSPair; + readonly bgBlueBright: CSPair; + readonly bgCyanBright: CSPair; + readonly bgMagentaBright: CSPair; + readonly bgWhiteBright: CSPair; + } +} + +declare const ansiStyles: { + readonly modifier: ansiStyles.Modifier; + readonly color: ansiStyles.ForegroundColor & ansiStyles.ColorBase; + readonly bgColor: ansiStyles.BackgroundColor & ansiStyles.ColorBase; + readonly codes: ReadonlyMap; +} & ansiStyles.BackgroundColor & ansiStyles.ForegroundColor & ansiStyles.Modifier; + +export = ansiStyles; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.js new file mode 100644 index 0000000..5d82581 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/index.js @@ -0,0 +1,163 @@ +'use strict'; + +const wrapAnsi16 = (fn, offset) => (...args) => { + const code = fn(...args); + return `\u001B[${code + offset}m`; +}; + +const wrapAnsi256 = (fn, offset) => (...args) => { + const code = fn(...args); + return `\u001B[${38 + offset};5;${code}m`; +}; + +const wrapAnsi16m = (fn, offset) => (...args) => { + const rgb = fn(...args); + return `\u001B[${38 + offset};2;${rgb[0]};${rgb[1]};${rgb[2]}m`; +}; + +const ansi2ansi = n => n; +const rgb2rgb = (r, g, b) => [r, g, b]; + +const setLazyProperty = (object, property, get) => { + Object.defineProperty(object, property, { + get: () => { + const value = get(); + + Object.defineProperty(object, property, { + value, + enumerable: true, + configurable: true + }); + + return value; + }, + enumerable: true, + configurable: true + }); +}; + +/** @type {typeof import('color-convert')} */ +let colorConvert; +const makeDynamicStyles = (wrap, targetSpace, identity, isBackground) => { + if (colorConvert === undefined) { + colorConvert = require('color-convert'); + } + + const offset = isBackground ? 10 : 0; + const styles = {}; + + for (const [sourceSpace, suite] of Object.entries(colorConvert)) { + const name = sourceSpace === 'ansi16' ? 'ansi' : sourceSpace; + if (sourceSpace === targetSpace) { + styles[name] = wrap(identity, offset); + } else if (typeof suite === 'object') { + styles[name] = wrap(suite[targetSpace], offset); + } + } + + return styles; +}; + +function assembleStyles() { + const codes = new Map(); + const styles = { + modifier: { + reset: [0, 0], + // 21 isn't widely supported and 22 does the same thing + bold: [1, 22], + dim: [2, 22], + italic: [3, 23], + underline: [4, 24], + inverse: [7, 27], + hidden: [8, 28], + strikethrough: [9, 29] + }, + color: { + black: [30, 39], + red: [31, 39], + green: [32, 39], + yellow: [33, 39], + blue: [34, 39], + magenta: [35, 39], + cyan: [36, 39], + white: [37, 39], + + // Bright color + blackBright: [90, 39], + redBright: [91, 39], + greenBright: [92, 39], + yellowBright: [93, 39], + blueBright: [94, 39], + magentaBright: [95, 39], + cyanBright: [96, 39], + whiteBright: [97, 39] + }, + bgColor: { + bgBlack: [40, 49], + bgRed: [41, 49], + bgGreen: [42, 49], + bgYellow: [43, 49], + bgBlue: [44, 49], + bgMagenta: [45, 49], + bgCyan: [46, 49], + bgWhite: [47, 49], + + // Bright color + bgBlackBright: [100, 49], + bgRedBright: [101, 49], + bgGreenBright: [102, 49], + bgYellowBright: [103, 49], + bgBlueBright: [104, 49], + bgMagentaBright: [105, 49], + bgCyanBright: [106, 49], + bgWhiteBright: [107, 49] + } + }; + + // Alias bright black as gray (and grey) + styles.color.gray = styles.color.blackBright; + styles.bgColor.bgGray = styles.bgColor.bgBlackBright; + styles.color.grey = styles.color.blackBright; + styles.bgColor.bgGrey = styles.bgColor.bgBlackBright; + + for (const [groupName, group] of Object.entries(styles)) { + for (const [styleName, style] of Object.entries(group)) { + styles[styleName] = { + open: `\u001B[${style[0]}m`, + close: `\u001B[${style[1]}m` + }; + + group[styleName] = styles[styleName]; + + codes.set(style[0], style[1]); + } + + Object.defineProperty(styles, groupName, { + value: group, + enumerable: false + }); + } + + Object.defineProperty(styles, 'codes', { + value: codes, + enumerable: false + }); + + styles.color.close = '\u001B[39m'; + styles.bgColor.close = '\u001B[49m'; + + setLazyProperty(styles.color, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, false)); + setLazyProperty(styles.color, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, false)); + setLazyProperty(styles.color, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, false)); + setLazyProperty(styles.bgColor, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, true)); + setLazyProperty(styles.bgColor, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, true)); + setLazyProperty(styles.bgColor, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, true)); + + return styles; +} + +// Make the export immutable +Object.defineProperty(module, 'exports', { + enumerable: true, + get: assembleStyles +}); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/license b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/license new file mode 100644 index 0000000..e7af2f7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/package.json new file mode 100644 index 0000000..7539328 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/package.json @@ -0,0 +1,56 @@ +{ + "name": "ansi-styles", + "version": "4.3.0", + "description": "ANSI escape codes for styling strings in the terminal", + "license": "MIT", + "repository": "chalk/ansi-styles", + "funding": "https://github.com/chalk/ansi-styles?sponsor=1", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "sindresorhus.com" + }, + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "xo && ava && tsd", + "screenshot": "svg-term --command='node screenshot' --out=screenshot.svg --padding=3 --width=55 --height=3 --at=1000 --no-cursor" + }, + "files": [ + "index.js", + "index.d.ts" + ], + "keywords": [ + "ansi", + "styles", + "color", + "colour", + "colors", + "terminal", + "console", + "cli", + "string", + "tty", + "escape", + "formatting", + "rgb", + "256", + "shell", + "xterm", + "log", + "logging", + "command-line", + "text" + ], + "dependencies": { + "color-convert": "^2.0.1" + }, + "devDependencies": { + "@types/color-convert": "^1.9.0", + "ava": "^2.3.0", + "svg-term-cli": "^2.1.1", + "tsd": "^0.11.0", + "xo": "^0.25.3" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/readme.md new file mode 100644 index 0000000..24883de --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/ansi-styles/readme.md @@ -0,0 +1,152 @@ +# ansi-styles [![Build Status](https://travis-ci.org/chalk/ansi-styles.svg?branch=master)](https://travis-ci.org/chalk/ansi-styles) + +> [ANSI escape codes](https://en.wikipedia.org/wiki/ANSI_escape_code#Colors_and_Styles) for styling strings in the terminal + +You probably want the higher-level [chalk](https://github.com/chalk/chalk) module for styling your strings. + + + +## Install + +``` +$ npm install ansi-styles +``` + +## Usage + +```js +const style = require('ansi-styles'); + +console.log(`${style.green.open}Hello world!${style.green.close}`); + + +// Color conversion between 16/256/truecolor +// NOTE: If conversion goes to 16 colors or 256 colors, the original color +// may be degraded to fit that color palette. This means terminals +// that do not support 16 million colors will best-match the +// original color. +console.log(style.bgColor.ansi.hsl(120, 80, 72) + 'Hello world!' + style.bgColor.close); +console.log(style.color.ansi256.rgb(199, 20, 250) + 'Hello world!' + style.color.close); +console.log(style.color.ansi16m.hex('#abcdef') + 'Hello world!' + style.color.close); +``` + +## API + +Each style has an `open` and `close` property. + +## Styles + +### Modifiers + +- `reset` +- `bold` +- `dim` +- `italic` *(Not widely supported)* +- `underline` +- `inverse` +- `hidden` +- `strikethrough` *(Not widely supported)* + +### Colors + +- `black` +- `red` +- `green` +- `yellow` +- `blue` +- `magenta` +- `cyan` +- `white` +- `blackBright` (alias: `gray`, `grey`) +- `redBright` +- `greenBright` +- `yellowBright` +- `blueBright` +- `magentaBright` +- `cyanBright` +- `whiteBright` + +### Background colors + +- `bgBlack` +- `bgRed` +- `bgGreen` +- `bgYellow` +- `bgBlue` +- `bgMagenta` +- `bgCyan` +- `bgWhite` +- `bgBlackBright` (alias: `bgGray`, `bgGrey`) +- `bgRedBright` +- `bgGreenBright` +- `bgYellowBright` +- `bgBlueBright` +- `bgMagentaBright` +- `bgCyanBright` +- `bgWhiteBright` + +## Advanced usage + +By default, you get a map of styles, but the styles are also available as groups. They are non-enumerable so they don't show up unless you access them explicitly. This makes it easier to expose only a subset in a higher-level module. + +- `style.modifier` +- `style.color` +- `style.bgColor` + +###### Example + +```js +console.log(style.color.green.open); +``` + +Raw escape codes (i.e. without the CSI escape prefix `\u001B[` and render mode postfix `m`) are available under `style.codes`, which returns a `Map` with the open codes as keys and close codes as values. + +###### Example + +```js +console.log(style.codes.get(36)); +//=> 39 +``` + +## [256 / 16 million (TrueColor) support](https://gist.github.com/XVilka/8346728) + +`ansi-styles` uses the [`color-convert`](https://github.com/Qix-/color-convert) package to allow for converting between various colors and ANSI escapes, with support for 256 and 16 million colors. + +The following color spaces from `color-convert` are supported: + +- `rgb` +- `hex` +- `keyword` +- `hsl` +- `hsv` +- `hwb` +- `ansi` +- `ansi256` + +To use these, call the associated conversion function with the intended output, for example: + +```js +style.color.ansi.rgb(100, 200, 15); // RGB to 16 color ansi foreground code +style.bgColor.ansi.rgb(100, 200, 15); // RGB to 16 color ansi background code + +style.color.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code +style.bgColor.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code + +style.color.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color foreground code +style.bgColor.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color background code +``` + +## Related + +- [ansi-escapes](https://github.com/sindresorhus/ansi-escapes) - ANSI escape codes for manipulating the terminal + +## Maintainers + +- [Sindre Sorhus](https://github.com/sindresorhus) +- [Josh Junon](https://github.com/qix-) + +## For enterprise + +Available as part of the Tidelift Subscription. + +The maintainers of `ansi-styles` and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. [Learn more.](https://tidelift.com/subscription/pkg/npm-ansi-styles?utm_source=npm-ansi-styles&utm_medium=referral&utm_campaign=enterprise&utm_term=repo) diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/LICENSE new file mode 100644 index 0000000..491766c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/LICENSE @@ -0,0 +1,15 @@ +The ISC License + +Copyright (c) 2019 Elan Shanker, Paul Miller (https://paulmillr.com) + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR +IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/README.md new file mode 100644 index 0000000..1dd67f5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/README.md @@ -0,0 +1,87 @@ +anymatch [![Build Status](https://travis-ci.org/micromatch/anymatch.svg?branch=master)](https://travis-ci.org/micromatch/anymatch) [![Coverage Status](https://img.shields.io/coveralls/micromatch/anymatch.svg?branch=master)](https://coveralls.io/r/micromatch/anymatch?branch=master) +====== +Javascript module to match a string against a regular expression, glob, string, +or function that takes the string as an argument and returns a truthy or falsy +value. The matcher can also be an array of any or all of these. Useful for +allowing a very flexible user-defined config to define things like file paths. + +__Note: This module has Bash-parity, please be aware that Windows-style backslashes are not supported as separators. See https://github.com/micromatch/micromatch#backslashes for more information.__ + + +Usage +----- +```sh +npm install anymatch +``` + +#### anymatch(matchers, testString, [returnIndex], [options]) +* __matchers__: (_Array|String|RegExp|Function_) +String to be directly matched, string with glob patterns, regular expression +test, function that takes the testString as an argument and returns a truthy +value if it should be matched, or an array of any number and mix of these types. +* __testString__: (_String|Array_) The string to test against the matchers. If +passed as an array, the first element of the array will be used as the +`testString` for non-function matchers, while the entire array will be applied +as the arguments for function matchers. +* __options__: (_Object_ [optional]_) Any of the [picomatch](https://github.com/micromatch/picomatch#options) options. + * __returnIndex__: (_Boolean [optional]_) If true, return the array index of +the first matcher that that testString matched, or -1 if no match, instead of a +boolean result. + +```js +const anymatch = require('anymatch'); + +const matchers = [ 'path/to/file.js', 'path/anyjs/**/*.js', /foo.js$/, string => string.includes('bar') && string.length > 10 ] ; + +anymatch(matchers, 'path/to/file.js'); // true +anymatch(matchers, 'path/anyjs/baz.js'); // true +anymatch(matchers, 'path/to/foo.js'); // true +anymatch(matchers, 'path/to/bar.js'); // true +anymatch(matchers, 'bar.js'); // false + +// returnIndex = true +anymatch(matchers, 'foo.js', {returnIndex: true}); // 2 +anymatch(matchers, 'path/anyjs/foo.js', {returnIndex: true}); // 1 + +// any picomatc + +// using globs to match directories and their children +anymatch('node_modules', 'node_modules'); // true +anymatch('node_modules', 'node_modules/somelib/index.js'); // false +anymatch('node_modules/**', 'node_modules/somelib/index.js'); // true +anymatch('node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // false +anymatch('**/node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // true + +const matcher = anymatch(matchers); +['foo.js', 'bar.js'].filter(matcher); // [ 'foo.js' ] +anymatch master* ❯ + +``` + +#### anymatch(matchers) +You can also pass in only your matcher(s) to get a curried function that has +already been bound to the provided matching criteria. This can be used as an +`Array#filter` callback. + +```js +var matcher = anymatch(matchers); + +matcher('path/to/file.js'); // true +matcher('path/anyjs/baz.js', true); // 1 + +['foo.js', 'bar.js'].filter(matcher); // ['foo.js'] +``` + +Changelog +---------- +[See release notes page on GitHub](https://github.com/micromatch/anymatch/releases) + +- **v3.0:** Removed `startIndex` and `endIndex` arguments. Node 8.x-only. +- **v2.0:** [micromatch](https://github.com/jonschlinkert/micromatch) moves away from minimatch-parity and inline with Bash. This includes handling backslashes differently (see https://github.com/micromatch/micromatch#backslashes for more information). +- **v1.2:** anymatch uses [micromatch](https://github.com/jonschlinkert/micromatch) +for glob pattern matching. Issues with glob pattern matching should be +reported directly to the [micromatch issue tracker](https://github.com/jonschlinkert/micromatch/issues). + +License +------- +[ISC](https://raw.github.com/micromatch/anymatch/master/LICENSE) diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.d.ts new file mode 100644 index 0000000..3ef7eaa --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.d.ts @@ -0,0 +1,20 @@ +type AnymatchFn = (testString: string) => boolean; +type AnymatchPattern = string|RegExp|AnymatchFn; +type AnymatchMatcher = AnymatchPattern|AnymatchPattern[] +type AnymatchTester = { + (testString: string|any[], returnIndex: true): number; + (testString: string|any[]): boolean; +} + +type PicomatchOptions = {dot: boolean}; + +declare const anymatch: { + (matchers: AnymatchMatcher): AnymatchTester; + (matchers: AnymatchMatcher, testString: null, returnIndex: true | PicomatchOptions): AnymatchTester; + (matchers: AnymatchMatcher, testString: string|any[], returnIndex: true | PicomatchOptions): number; + (matchers: AnymatchMatcher, testString: string|any[]): boolean; +} + +export {AnymatchMatcher as Matcher} +export {AnymatchTester as Tester} +export default anymatch diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.js new file mode 100644 index 0000000..8eb73e9 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/index.js @@ -0,0 +1,104 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { value: true }); + +const picomatch = require('picomatch'); +const normalizePath = require('normalize-path'); + +/** + * @typedef {(testString: string) => boolean} AnymatchFn + * @typedef {string|RegExp|AnymatchFn} AnymatchPattern + * @typedef {AnymatchPattern|AnymatchPattern[]} AnymatchMatcher + */ +const BANG = '!'; +const DEFAULT_OPTIONS = {returnIndex: false}; +const arrify = (item) => Array.isArray(item) ? item : [item]; + +/** + * @param {AnymatchPattern} matcher + * @param {object} options + * @returns {AnymatchFn} + */ +const createPattern = (matcher, options) => { + if (typeof matcher === 'function') { + return matcher; + } + if (typeof matcher === 'string') { + const glob = picomatch(matcher, options); + return (string) => matcher === string || glob(string); + } + if (matcher instanceof RegExp) { + return (string) => matcher.test(string); + } + return (string) => false; +}; + +/** + * @param {Array} patterns + * @param {Array} negPatterns + * @param {String|Array} args + * @param {Boolean} returnIndex + * @returns {boolean|number} + */ +const matchPatterns = (patterns, negPatterns, args, returnIndex) => { + const isList = Array.isArray(args); + const _path = isList ? args[0] : args; + if (!isList && typeof _path !== 'string') { + throw new TypeError('anymatch: second argument must be a string: got ' + + Object.prototype.toString.call(_path)) + } + const path = normalizePath(_path, false); + + for (let index = 0; index < negPatterns.length; index++) { + const nglob = negPatterns[index]; + if (nglob(path)) { + return returnIndex ? -1 : false; + } + } + + const applied = isList && [path].concat(args.slice(1)); + for (let index = 0; index < patterns.length; index++) { + const pattern = patterns[index]; + if (isList ? pattern(...applied) : pattern(path)) { + return returnIndex ? index : true; + } + } + + return returnIndex ? -1 : false; +}; + +/** + * @param {AnymatchMatcher} matchers + * @param {Array|string} testString + * @param {object} options + * @returns {boolean|number|Function} + */ +const anymatch = (matchers, testString, options = DEFAULT_OPTIONS) => { + if (matchers == null) { + throw new TypeError('anymatch: specify first argument'); + } + const opts = typeof options === 'boolean' ? {returnIndex: options} : options; + const returnIndex = opts.returnIndex || false; + + // Early cache for matchers. + const mtchers = arrify(matchers); + const negatedGlobs = mtchers + .filter(item => typeof item === 'string' && item.charAt(0) === BANG) + .map(item => item.slice(1)) + .map(item => picomatch(item, opts)); + const patterns = mtchers + .filter(item => typeof item !== 'string' || (typeof item === 'string' && item.charAt(0) !== BANG)) + .map(matcher => createPattern(matcher, opts)); + + if (testString == null) { + return (testString, ri = false) => { + const returnIndex = typeof ri === 'boolean' ? ri : false; + return matchPatterns(patterns, negatedGlobs, testString, returnIndex); + } + } + + return matchPatterns(patterns, negatedGlobs, testString, returnIndex); +}; + +anymatch.default = anymatch; +module.exports = anymatch; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/package.json new file mode 100644 index 0000000..2cb2307 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/anymatch/package.json @@ -0,0 +1,48 @@ +{ + "name": "anymatch", + "version": "3.1.3", + "description": "Matches strings against configurable strings, globs, regular expressions, and/or functions", + "files": [ + "index.js", + "index.d.ts" + ], + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "author": { + "name": "Elan Shanker", + "url": "https://github.com/es128" + }, + "license": "ISC", + "homepage": "https://github.com/micromatch/anymatch", + "repository": { + "type": "git", + "url": "https://github.com/micromatch/anymatch" + }, + "keywords": [ + "match", + "any", + "string", + "file", + "fs", + "list", + "glob", + "regex", + "regexp", + "regular", + "expression", + "function" + ], + "scripts": { + "test": "nyc mocha", + "mocha": "mocha" + }, + "devDependencies": { + "mocha": "^6.1.3", + "nyc": "^14.0.0" + }, + "engines": { + "node": ">= 8" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/LICENSE new file mode 100644 index 0000000..983fbe8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/README.md new file mode 100644 index 0000000..91fa5b6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/README.md @@ -0,0 +1,43 @@ +# Array Flatten + +[![NPM version][npm-image]][npm-url] +[![NPM downloads][downloads-image]][downloads-url] +[![Build status][travis-image]][travis-url] +[![Test coverage][coveralls-image]][coveralls-url] + +> Flatten an array of nested arrays into a single flat array. Accepts an optional depth. + +## Installation + +``` +npm install array-flatten --save +``` + +## Usage + +```javascript +var flatten = require('array-flatten') + +flatten([1, [2, [3, [4, [5], 6], 7], 8], 9]) +//=> [1, 2, 3, 4, 5, 6, 7, 8, 9] + +flatten([1, [2, [3, [4, [5], 6], 7], 8], 9], 2) +//=> [1, 2, 3, [4, [5], 6], 7, 8, 9] + +(function () { + flatten(arguments) //=> [1, 2, 3] +})(1, [2, 3]) +``` + +## License + +MIT + +[npm-image]: https://img.shields.io/npm/v/array-flatten.svg?style=flat +[npm-url]: https://npmjs.org/package/array-flatten +[downloads-image]: https://img.shields.io/npm/dm/array-flatten.svg?style=flat +[downloads-url]: https://npmjs.org/package/array-flatten +[travis-image]: https://img.shields.io/travis/blakeembrey/array-flatten.svg?style=flat +[travis-url]: https://travis-ci.org/blakeembrey/array-flatten +[coveralls-image]: https://img.shields.io/coveralls/blakeembrey/array-flatten.svg?style=flat +[coveralls-url]: https://coveralls.io/r/blakeembrey/array-flatten?branch=master diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/array-flatten.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/array-flatten.js new file mode 100644 index 0000000..089117b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/array-flatten.js @@ -0,0 +1,64 @@ +'use strict' + +/** + * Expose `arrayFlatten`. + */ +module.exports = arrayFlatten + +/** + * Recursive flatten function with depth. + * + * @param {Array} array + * @param {Array} result + * @param {Number} depth + * @return {Array} + */ +function flattenWithDepth (array, result, depth) { + for (var i = 0; i < array.length; i++) { + var value = array[i] + + if (depth > 0 && Array.isArray(value)) { + flattenWithDepth(value, result, depth - 1) + } else { + result.push(value) + } + } + + return result +} + +/** + * Recursive flatten function. Omitting depth is slightly faster. + * + * @param {Array} array + * @param {Array} result + * @return {Array} + */ +function flattenForever (array, result) { + for (var i = 0; i < array.length; i++) { + var value = array[i] + + if (Array.isArray(value)) { + flattenForever(value, result) + } else { + result.push(value) + } + } + + return result +} + +/** + * Flatten an array, with the ability to define a depth. + * + * @param {Array} array + * @param {Number} depth + * @return {Array} + */ +function arrayFlatten (array, depth) { + if (depth == null) { + return flattenForever(array, []) + } + + return flattenWithDepth(array, [], depth) +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/package.json new file mode 100644 index 0000000..1a24e2a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/array-flatten/package.json @@ -0,0 +1,39 @@ +{ + "name": "array-flatten", + "version": "1.1.1", + "description": "Flatten an array of nested arrays into a single flat array", + "main": "array-flatten.js", + "files": [ + "array-flatten.js", + "LICENSE" + ], + "scripts": { + "test": "istanbul cover _mocha -- -R spec" + }, + "repository": { + "type": "git", + "url": "git://github.com/blakeembrey/array-flatten.git" + }, + "keywords": [ + "array", + "flatten", + "arguments", + "depth" + ], + "author": { + "name": "Blake Embrey", + "email": "hello@blakeembrey.com", + "url": "http://blakeembrey.me" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/blakeembrey/array-flatten/issues" + }, + "homepage": "https://github.com/blakeembrey/array-flatten", + "devDependencies": { + "istanbul": "^0.3.13", + "mocha": "^2.2.4", + "pre-commit": "^1.0.7", + "standard": "^3.7.3" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/CHANGELOG.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/CHANGELOG.md new file mode 100644 index 0000000..ce990a5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/CHANGELOG.md @@ -0,0 +1,351 @@ +# v3.2.5 +- Ensure `Error` objects such as `AggregateError` are propagated without modification (#1920) + +# v3.2.4 +- Fix a bug in `priorityQueue` where it didn't wait for the result. (#1725) +- Fix a bug where `unshiftAsync` was included in `priorityQueue`. (#1790) + +# v3.2.3 +- Fix bugs in comment parsing in `autoInject`. (#1767, #1780) + +# v3.2.2 +- Fix potential prototype pollution exploit + +# v3.2.1 +- Use `queueMicrotask` if available to the environment (#1761) +- Minor perf improvement in `priorityQueue` (#1727) +- More examples in documentation (#1726) +- Various doc fixes (#1708, #1712, #1717, #1740, #1739, #1749, #1756) +- Improved test coverage (#1754) + +# v3.2.0 +- Fix a bug in Safari related to overwriting `func.name` +- Remove built-in browserify configuration (#1653) +- Varios doc fixes (#1688, #1703, #1704) + +# v3.1.1 +- Allow redefining `name` property on wrapped functions. + +# v3.1.0 + +- Added `q.pushAsync` and `q.unshiftAsync`, analagous to `q.push` and `q.unshift`, except they always do not accept a callback, and reject if processing the task errors. (#1659) +- Promises returned from `q.push` and `q.unshift` when a callback is not passed now resolve even if an error ocurred. (#1659) +- Fixed a parsing bug in `autoInject` with complicated function bodies (#1663) +- Added ES6+ configuration for Browserify bundlers (#1653) +- Various doc fixes (#1664, #1658, #1665, #1652) + +# v3.0.1 + +## Bug fixes +- Fixed a regression where arrays passed to `queue` and `cargo` would be completely flattened. (#1645) +- Clarified Async's browser support (#1643) + + +# v3.0.0 + +The `async`/`await` release! + +There are a lot of new features and subtle breaking changes in this major version, but the biggest feature is that most Async methods return a Promise if you omit the callback, meaning you can `await` them from within an `async` function. + +```js +const results = await async.mapLimit(urls, 5, async url => { + const resp = await fetch(url) + return resp.body +}) +``` + +## Breaking Changes +- Most Async methods return a Promise when the final callback is omitted, making them `await`-able! (#1572) +- We are now making heavy use of ES2015 features, this means we have dropped out-of-the-box support for Node 4 and earlier, and many old versions of browsers. (#1541, #1553) +- In `queue`, `priorityQueue`, `cargo` and `cargoQueue`, the "event"-style methods, like `q.drain` and `q.saturated` are now methods that register a callback, rather than properties you assign a callback to. They are now of the form `q.drain(callback)`. If you do not pass a callback a Promise will be returned for the next occurrence of the event, making them `await`-able, e.g. `await q.drain()`. (#1586, #1641) +- Calling `callback(false)` will cancel an async method, preventing further iteration and callback calls. This is useful for preventing memory leaks when you break out of an async flow by calling an outer callback. (#1064, #1542) +- `during` and `doDuring` have been removed, and instead `whilst`, `doWhilst`, `until` and `doUntil` now have asynchronous `test` functions. (#850, #1557) +- `limits` of less than 1 now cause an error to be thrown in queues and collection methods. (#1249, #1552) +- `memoize` no longer memoizes errors (#1465, #1466) +- `applyEach`/`applyEachSeries` have a simpler interface, to make them more easily type-able. It always returns a function that takes in a single callback argument. If that callback is omitted, a promise is returned, making it awaitable. (#1228, #1640) + +## New Features +- Async generators are now supported in all the Collection methods. (#1560) +- Added `cargoQueue`, a queue with both `concurrency` and `payload` size parameters. (#1567) +- Queue objects returned from `queue` now have a `Symbol.iterator` method, meaning they can be iterated over to inspect the current list of items in the queue. (#1459, #1556) +- A ESM-flavored `async.mjs` is included in the `async` package. This is described in the `package.json` `"module"` field, meaning it should be automatically used by Webpack and other compatible bundlers. + +## Bug fixes +- Better handle arbitrary error objects in `asyncify` (#1568, #1569) + +## Other +- Removed Lodash as a dependency (#1283, #1528) +- Miscellaneous docs fixes (#1393, #1501, #1540, #1543, #1558, #1563, #1564, #1579, #1581) +- Miscellaneous test fixes (#1538) + +------- + +# v2.6.1 +- Updated lodash to prevent `npm audit` warnings. (#1532, #1533) +- Made `async-es` more optimized for webpack users (#1517) +- Fixed a stack overflow with large collections and a synchronous iterator (#1514) +- Various small fixes/chores (#1505, #1511, #1527, #1530) + +# v2.6.0 +- Added missing aliases for many methods. Previously, you could not (e.g.) `require('async/find')` or use `async.anyLimit`. (#1483) +- Improved `queue` performance. (#1448, #1454) +- Add missing sourcemap (#1452, #1453) +- Various doc updates (#1448, #1471, #1483) + +# v2.5.0 +- Added `concatLimit`, the `Limit` equivalent of [`concat`](https://caolan.github.io/async/docs.html#concat) ([#1426](https://github.com/caolan/async/issues/1426), [#1430](https://github.com/caolan/async/pull/1430)) +- `concat` improvements: it now preserves order, handles falsy values and the `iteratee` callback takes a variable number of arguments ([#1437](https://github.com/caolan/async/issues/1437), [#1436](https://github.com/caolan/async/pull/1436)) +- Fixed an issue in `queue` where there was a size discrepancy between `workersList().length` and `running()` ([#1428](https://github.com/caolan/async/issues/1428), [#1429](https://github.com/caolan/async/pull/1429)) +- Various doc fixes ([#1422](https://github.com/caolan/async/issues/1422), [#1424](https://github.com/caolan/async/pull/1424)) + +# v2.4.1 +- Fixed a bug preventing functions wrapped with `timeout()` from being re-used. ([#1418](https://github.com/caolan/async/issues/1418), [#1419](https://github.com/caolan/async/issues/1419)) + +# v2.4.0 +- Added `tryEach`, for running async functions in parallel, where you only expect one to succeed. ([#1365](https://github.com/caolan/async/issues/1365), [#687](https://github.com/caolan/async/issues/687)) +- Improved performance, most notably in `parallel` and `waterfall` ([#1395](https://github.com/caolan/async/issues/1395)) +- Added `queue.remove()`, for removing items in a `queue` ([#1397](https://github.com/caolan/async/issues/1397), [#1391](https://github.com/caolan/async/issues/1391)) +- Fixed using `eval`, preventing Async from running in pages with Content Security Policy ([#1404](https://github.com/caolan/async/issues/1404), [#1403](https://github.com/caolan/async/issues/1403)) +- Fixed errors thrown in an `asyncify`ed function's callback being caught by the underlying Promise ([#1408](https://github.com/caolan/async/issues/1408)) +- Fixed timing of `queue.empty()` ([#1367](https://github.com/caolan/async/issues/1367)) +- Various doc fixes ([#1314](https://github.com/caolan/async/issues/1314), [#1394](https://github.com/caolan/async/issues/1394), [#1412](https://github.com/caolan/async/issues/1412)) + +# v2.3.0 +- Added support for ES2017 `async` functions. Wherever you can pass a Node-style/CPS function that uses a callback, you can also pass an `async` function. Previously, you had to wrap `async` functions with `asyncify`. The caveat is that it will only work if `async` functions are supported natively in your environment, transpiled implementations can't be detected. ([#1386](https://github.com/caolan/async/issues/1386), [#1390](https://github.com/caolan/async/issues/1390)) +- Small doc fix ([#1392](https://github.com/caolan/async/issues/1392)) + +# v2.2.0 +- Added `groupBy`, and the `Series`/`Limit` equivalents, analogous to [`_.groupBy`](http://lodash.com/docs#groupBy) ([#1364](https://github.com/caolan/async/issues/1364)) +- Fixed `transform` bug when `callback` was not passed ([#1381](https://github.com/caolan/async/issues/1381)) +- Added note about `reflect` to `parallel` docs ([#1385](https://github.com/caolan/async/issues/1385)) + +# v2.1.5 +- Fix `auto` bug when function names collided with Array.prototype ([#1358](https://github.com/caolan/async/issues/1358)) +- Improve some error messages ([#1349](https://github.com/caolan/async/issues/1349)) +- Avoid stack overflow case in queue +- Fixed an issue in `some`, `every` and `find` where processing would continue after the result was determined. +- Cleanup implementations of `some`, `every` and `find` + +# v2.1.3 +- Make bundle size smaller +- Create optimized hotpath for `filter` in array case. + +# v2.1.2 +- Fixed a stackoverflow bug with `detect`, `some`, `every` on large inputs ([#1293](https://github.com/caolan/async/issues/1293)). + +# v2.1.0 + +- `retry` and `retryable` now support an optional `errorFilter` function that determines if the `task` should retry on the error ([#1256](https://github.com/caolan/async/issues/1256), [#1261](https://github.com/caolan/async/issues/1261)) +- Optimized array iteration in `race`, `cargo`, `queue`, and `priorityQueue` ([#1253](https://github.com/caolan/async/issues/1253)) +- Added alias documentation to doc site ([#1251](https://github.com/caolan/async/issues/1251), [#1254](https://github.com/caolan/async/issues/1254)) +- Added [BootStrap scrollspy](http://getbootstrap.com/javascript/#scrollspy) to docs to highlight in the sidebar the current method being viewed ([#1289](https://github.com/caolan/async/issues/1289), [#1300](https://github.com/caolan/async/issues/1300)) +- Various minor doc fixes ([#1263](https://github.com/caolan/async/issues/1263), [#1264](https://github.com/caolan/async/issues/1264), [#1271](https://github.com/caolan/async/issues/1271), [#1278](https://github.com/caolan/async/issues/1278), [#1280](https://github.com/caolan/async/issues/1280), [#1282](https://github.com/caolan/async/issues/1282), [#1302](https://github.com/caolan/async/issues/1302)) + +# v2.0.1 + +- Significantly optimized all iteration based collection methods such as `each`, `map`, `filter`, etc ([#1245](https://github.com/caolan/async/issues/1245), [#1246](https://github.com/caolan/async/issues/1246), [#1247](https://github.com/caolan/async/issues/1247)). + +# v2.0.0 + +Lots of changes here! + +First and foremost, we have a slick new [site for docs](https://caolan.github.io/async/). Special thanks to [**@hargasinski**](https://github.com/hargasinski) for his work converting our old docs to `jsdoc` format and implementing the new website. Also huge ups to [**@ivanseidel**](https://github.com/ivanseidel) for designing our new logo. It was a long process for both of these tasks, but I think these changes turned out extraordinary well. + +The biggest feature is modularization. You can now `require("async/series")` to only require the `series` function. Every Async library function is available this way. You still can `require("async")` to require the entire library, like you could do before. + +We also provide Async as a collection of ES2015 modules. You can now `import {each} from 'async-es'` or `import waterfall from 'async-es/waterfall'`. If you are using only a few Async functions, and are using a ES bundler such as Rollup, this can significantly lower your build size. + +Major thanks to [**@Kikobeats**](github.com/Kikobeats), [**@aearly**](github.com/aearly) and [**@megawac**](github.com/megawac) for doing the majority of the modularization work, as well as [**@jdalton**](github.com/jdalton) and [**@Rich-Harris**](github.com/Rich-Harris) for advisory work on the general modularization strategy. + +Another one of the general themes of the 2.0 release is standardization of what an "async" function is. We are now more strictly following the node-style continuation passing style. That is, an async function is a function that: + +1. Takes a variable number of arguments +2. The last argument is always a callback +3. The callback can accept any number of arguments +4. The first argument passed to the callback will be treated as an error result, if the argument is truthy +5. Any number of result arguments can be passed after the "error" argument +6. The callback is called once and exactly once, either on the same tick or later tick of the JavaScript event loop. + +There were several cases where Async accepted some functions that did not strictly have these properties, most notably `auto`, `every`, `some`, `filter`, `reject` and `detect`. + +Another theme is performance. We have eliminated internal deferrals in all cases where they make sense. For example, in `waterfall` and `auto`, there was a `setImmediate` between each task -- these deferrals have been removed. A `setImmediate` call can add up to 1ms of delay. This might not seem like a lot, but it can add up if you are using many Async functions in the course of processing a HTTP request, for example. Nearly all asynchronous functions that do I/O already have some sort of deferral built in, so the extra deferral is unnecessary. The trade-off of this change is removing our built-in stack-overflow defense. Many synchronous callback calls in series can quickly overflow the JS call stack. If you do have a function that is sometimes synchronous (calling its callback on the same tick), and are running into stack overflows, wrap it with `async.ensureAsync()`. + +Another big performance win has been re-implementing `queue`, `cargo`, and `priorityQueue` with [doubly linked lists](https://en.wikipedia.org/wiki/Doubly_linked_list) instead of arrays. This has lead to queues being an order of [magnitude faster on large sets of tasks](https://github.com/caolan/async/pull/1205). + +## New Features + +- Async is now modularized. Individual functions can be `require()`d from the main package. (`require('async/auto')`) ([#984](https://github.com/caolan/async/issues/984), [#996](https://github.com/caolan/async/issues/996)) +- Async is also available as a collection of ES2015 modules in the new `async-es` package. (`import {forEachSeries} from 'async-es'`) ([#984](https://github.com/caolan/async/issues/984), [#996](https://github.com/caolan/async/issues/996)) +- Added `race`, analogous to `Promise.race()`. It will run an array of async tasks in parallel and will call its callback with the result of the first task to respond. ([#568](https://github.com/caolan/async/issues/568), [#1038](https://github.com/caolan/async/issues/1038)) +- Collection methods now accept ES2015 iterators. Maps, Sets, and anything that implements the iterator spec can now be passed directly to `each`, `map`, `parallel`, etc.. ([#579](https://github.com/caolan/async/issues/579), [#839](https://github.com/caolan/async/issues/839), [#1074](https://github.com/caolan/async/issues/1074)) +- Added `mapValues`, for mapping over the properties of an object and returning an object with the same keys. ([#1157](https://github.com/caolan/async/issues/1157), [#1177](https://github.com/caolan/async/issues/1177)) +- Added `timeout`, a wrapper for an async function that will make the task time-out after the specified time. ([#1007](https://github.com/caolan/async/issues/1007), [#1027](https://github.com/caolan/async/issues/1027)) +- Added `reflect` and `reflectAll`, analagous to [`Promise.reflect()`](http://bluebirdjs.com/docs/api/reflect.html), a wrapper for async tasks that always succeeds, by gathering results and errors into an object. ([#942](https://github.com/caolan/async/issues/942), [#1012](https://github.com/caolan/async/issues/1012), [#1095](https://github.com/caolan/async/issues/1095)) +- `constant` supports dynamic arguments -- it will now always use its last argument as the callback. ([#1016](https://github.com/caolan/async/issues/1016), [#1052](https://github.com/caolan/async/issues/1052)) +- `setImmediate` and `nextTick` now support arguments to partially apply to the deferred function, like the node-native versions do. ([#940](https://github.com/caolan/async/issues/940), [#1053](https://github.com/caolan/async/issues/1053)) +- `auto` now supports resolving cyclic dependencies using [Kahn's algorithm](https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm) ([#1140](https://github.com/caolan/async/issues/1140)). +- Added `autoInject`, a relative of `auto` that automatically spreads a task's dependencies as arguments to the task function. ([#608](https://github.com/caolan/async/issues/608), [#1055](https://github.com/caolan/async/issues/1055), [#1099](https://github.com/caolan/async/issues/1099), [#1100](https://github.com/caolan/async/issues/1100)) +- You can now limit the concurrency of `auto` tasks. ([#635](https://github.com/caolan/async/issues/635), [#637](https://github.com/caolan/async/issues/637)) +- Added `retryable`, a relative of `retry` that wraps an async function, making it retry when called. ([#1058](https://github.com/caolan/async/issues/1058)) +- `retry` now supports specifying a function that determines the next time interval, useful for exponential backoff, logging and other retry strategies. ([#1161](https://github.com/caolan/async/issues/1161)) +- `retry` will now pass all of the arguments the task function was resolved with to the callback ([#1231](https://github.com/caolan/async/issues/1231)). +- Added `q.unsaturated` -- callback called when a `queue`'s number of running workers falls below a threshold. ([#868](https://github.com/caolan/async/issues/868), [#1030](https://github.com/caolan/async/issues/1030), [#1033](https://github.com/caolan/async/issues/1033), [#1034](https://github.com/caolan/async/issues/1034)) +- Added `q.error` -- a callback called whenever a `queue` task calls its callback with an error. ([#1170](https://github.com/caolan/async/issues/1170)) +- `applyEach` and `applyEachSeries` now pass results to the final callback. ([#1088](https://github.com/caolan/async/issues/1088)) + +## Breaking changes + +- Calling a callback more than once is considered an error, and an error will be thrown. This had an explicit breaking change in `waterfall`. If you were relying on this behavior, you should more accurately represent your control flow as an event emitter or stream. ([#814](https://github.com/caolan/async/issues/814), [#815](https://github.com/caolan/async/issues/815), [#1048](https://github.com/caolan/async/issues/1048), [#1050](https://github.com/caolan/async/issues/1050)) +- `auto` task functions now always take the callback as the last argument. If a task has dependencies, the `results` object will be passed as the first argument. To migrate old task functions, wrap them with [`_.flip`](https://lodash.com/docs#flip) ([#1036](https://github.com/caolan/async/issues/1036), [#1042](https://github.com/caolan/async/issues/1042)) +- Internal `setImmediate` calls have been refactored away. This may make existing flows vulnerable to stack overflows if you use many synchronous functions in series. Use `ensureAsync` to work around this. ([#696](https://github.com/caolan/async/issues/696), [#704](https://github.com/caolan/async/issues/704), [#1049](https://github.com/caolan/async/issues/1049), [#1050](https://github.com/caolan/async/issues/1050)) +- `map` used to return an object when iterating over an object. `map` now always returns an array, like in other libraries. The previous object behavior has been split out into `mapValues`. ([#1157](https://github.com/caolan/async/issues/1157), [#1177](https://github.com/caolan/async/issues/1177)) +- `filter`, `reject`, `some`, `every`, `detect` and their families like `{METHOD}Series` and `{METHOD}Limit` now expect an error as the first callback argument, rather than just a simple boolean. Pass `null` as the first argument, or use `fs.access` instead of `fs.exists`. ([#118](https://github.com/caolan/async/issues/118), [#774](https://github.com/caolan/async/issues/774), [#1028](https://github.com/caolan/async/issues/1028), [#1041](https://github.com/caolan/async/issues/1041)) +- `{METHOD}` and `{METHOD}Series` are now implemented in terms of `{METHOD}Limit`. This is a major internal simplification, and is not expected to cause many problems, but it does subtly affect how functions execute internally. ([#778](https://github.com/caolan/async/issues/778), [#847](https://github.com/caolan/async/issues/847)) +- `retry`'s callback is now optional. Previously, omitting the callback would partially apply the function, meaning it could be passed directly as a task to `series` or `auto`. The partially applied "control-flow" behavior has been separated out into `retryable`. ([#1054](https://github.com/caolan/async/issues/1054), [#1058](https://github.com/caolan/async/issues/1058)) +- The test function for `whilst`, `until`, and `during` used to be passed non-error args from the iteratee function's callback, but this led to weirdness where the first call of the test function would be passed no args. We have made it so the test function is never passed extra arguments, and only the `doWhilst`, `doUntil`, and `doDuring` functions pass iteratee callback arguments to the test function ([#1217](https://github.com/caolan/async/issues/1217), [#1224](https://github.com/caolan/async/issues/1224)) +- The `q.tasks` array has been renamed `q._tasks` and is now implemented as a doubly linked list (DLL). Any code that used to interact with this array will need to be updated to either use the provided helpers or support DLLs ([#1205](https://github.com/caolan/async/issues/1205)). +- The timing of the `q.saturated()` callback in a `queue` has been modified to better reflect when tasks pushed to the queue will start queueing. ([#724](https://github.com/caolan/async/issues/724), [#1078](https://github.com/caolan/async/issues/1078)) +- Removed `iterator` method in favour of [ES2015 iterator protocol](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators ) which natively supports arrays ([#1237](https://github.com/caolan/async/issues/1237)) +- Dropped support for Component, Jam, SPM, and Volo ([#1175](https://github.com/caolan/async/issues/1175), #[#176](https://github.com/caolan/async/issues/176)) + +## Bug Fixes + +- Improved handling of no dependency cases in `auto` & `autoInject` ([#1147](https://github.com/caolan/async/issues/1147)). +- Fixed a bug where the callback generated by `asyncify` with `Promises` could resolve twice ([#1197](https://github.com/caolan/async/issues/1197)). +- Fixed several documented optional callbacks not actually being optional ([#1223](https://github.com/caolan/async/issues/1223)). + +## Other + +- Added `someSeries` and `everySeries` for symmetry, as well as a complete set of `any`/`anyLimit`/`anySeries` and `all`/`/allLmit`/`allSeries` aliases. +- Added `find` as an alias for `detect. (as well as `findLimit` and `findSeries`). +- Various doc fixes ([#1005](https://github.com/caolan/async/issues/1005), [#1008](https://github.com/caolan/async/issues/1008), [#1010](https://github.com/caolan/async/issues/1010), [#1015](https://github.com/caolan/async/issues/1015), [#1021](https://github.com/caolan/async/issues/1021), [#1037](https://github.com/caolan/async/issues/1037), [#1039](https://github.com/caolan/async/issues/1039), [#1051](https://github.com/caolan/async/issues/1051), [#1102](https://github.com/caolan/async/issues/1102), [#1107](https://github.com/caolan/async/issues/1107), [#1121](https://github.com/caolan/async/issues/1121), [#1123](https://github.com/caolan/async/issues/1123), [#1129](https://github.com/caolan/async/issues/1129), [#1135](https://github.com/caolan/async/issues/1135), [#1138](https://github.com/caolan/async/issues/1138), [#1141](https://github.com/caolan/async/issues/1141), [#1153](https://github.com/caolan/async/issues/1153), [#1216](https://github.com/caolan/async/issues/1216), [#1217](https://github.com/caolan/async/issues/1217), [#1232](https://github.com/caolan/async/issues/1232), [#1233](https://github.com/caolan/async/issues/1233), [#1236](https://github.com/caolan/async/issues/1236), [#1238](https://github.com/caolan/async/issues/1238)) + +Thank you [**@aearly**](github.com/aearly) and [**@megawac**](github.com/megawac) for taking the lead on version 2 of async. + +------------------------------------------ + +# v1.5.2 +- Allow using `"constructor"` as an argument in `memoize` ([#998](https://github.com/caolan/async/issues/998)) +- Give a better error messsage when `auto` dependency checking fails ([#994](https://github.com/caolan/async/issues/994)) +- Various doc updates ([#936](https://github.com/caolan/async/issues/936), [#956](https://github.com/caolan/async/issues/956), [#979](https://github.com/caolan/async/issues/979), [#1002](https://github.com/caolan/async/issues/1002)) + +# v1.5.1 +- Fix issue with `pause` in `queue` with concurrency enabled ([#946](https://github.com/caolan/async/issues/946)) +- `while` and `until` now pass the final result to callback ([#963](https://github.com/caolan/async/issues/963)) +- `auto` will properly handle concurrency when there is no callback ([#966](https://github.com/caolan/async/issues/966)) +- `auto` will no. properly stop execution when an error occurs ([#988](https://github.com/caolan/async/issues/988), [#993](https://github.com/caolan/async/issues/993)) +- Various doc fixes ([#971](https://github.com/caolan/async/issues/971), [#980](https://github.com/caolan/async/issues/980)) + +# v1.5.0 + +- Added `transform`, analogous to [`_.transform`](http://lodash.com/docs#transform) ([#892](https://github.com/caolan/async/issues/892)) +- `map` now returns an object when an object is passed in, rather than array with non-numeric keys. `map` will begin always returning an array with numeric indexes in the next major release. ([#873](https://github.com/caolan/async/issues/873)) +- `auto` now accepts an optional `concurrency` argument to limit the number o. running tasks ([#637](https://github.com/caolan/async/issues/637)) +- Added `queue#workersList()`, to retrieve the lis. of currently running tasks. ([#891](https://github.com/caolan/async/issues/891)) +- Various code simplifications ([#896](https://github.com/caolan/async/issues/896), [#904](https://github.com/caolan/async/issues/904)) +- Various doc fixes :scroll: ([#890](https://github.com/caolan/async/issues/890), [#894](https://github.com/caolan/async/issues/894), [#903](https://github.com/caolan/async/issues/903), [#905](https://github.com/caolan/async/issues/905), [#912](https://github.com/caolan/async/issues/912)) + +# v1.4.2 + +- Ensure coverage files don't get published on npm ([#879](https://github.com/caolan/async/issues/879)) + +# v1.4.1 + +- Add in overlooked `detectLimit` method ([#866](https://github.com/caolan/async/issues/866)) +- Removed unnecessary files from npm releases ([#861](https://github.com/caolan/async/issues/861)) +- Removed usage of a reserved word to prevent :boom: in older environments ([#870](https://github.com/caolan/async/issues/870)) + +# v1.4.0 + +- `asyncify` now supports promises ([#840](https://github.com/caolan/async/issues/840)) +- Added `Limit` versions of `filter` and `reject` ([#836](https://github.com/caolan/async/issues/836)) +- Add `Limit` versions of `detect`, `some` and `every` ([#828](https://github.com/caolan/async/issues/828), [#829](https://github.com/caolan/async/issues/829)) +- `some`, `every` and `detect` now short circuit early ([#828](https://github.com/caolan/async/issues/828), [#829](https://github.com/caolan/async/issues/829)) +- Improve detection of the global object ([#804](https://github.com/caolan/async/issues/804)), enabling use in WebWorkers +- `whilst` now called with arguments from iterator ([#823](https://github.com/caolan/async/issues/823)) +- `during` now gets called with arguments from iterator ([#824](https://github.com/caolan/async/issues/824)) +- Code simplifications and optimizations aplenty ([diff](https://github.com/caolan/async/compare/v1.3.0...v1.4.0)) + + +# v1.3.0 + +New Features: +- Added `constant` +- Added `asyncify`/`wrapSync` for making sync functions work with callbacks. ([#671](https://github.com/caolan/async/issues/671), [#806](https://github.com/caolan/async/issues/806)) +- Added `during` and `doDuring`, which are like `whilst` with an async truth test. ([#800](https://github.com/caolan/async/issues/800)) +- `retry` now accepts an `interval` parameter to specify a delay between retries. ([#793](https://github.com/caolan/async/issues/793)) +- `async` should work better in Web Workers due to better `root` detection ([#804](https://github.com/caolan/async/issues/804)) +- Callbacks are now optional in `whilst`, `doWhilst`, `until`, and `doUntil` ([#642](https://github.com/caolan/async/issues/642)) +- Various internal updates ([#786](https://github.com/caolan/async/issues/786), [#801](https://github.com/caolan/async/issues/801), [#802](https://github.com/caolan/async/issues/802), [#803](https://github.com/caolan/async/issues/803)) +- Various doc fixes ([#790](https://github.com/caolan/async/issues/790), [#794](https://github.com/caolan/async/issues/794)) + +Bug Fixes: +- `cargo` now exposes the `payload` size, and `cargo.payload` can be changed on the fly after the `cargo` is created. ([#740](https://github.com/caolan/async/issues/740), [#744](https://github.com/caolan/async/issues/744), [#783](https://github.com/caolan/async/issues/783)) + + +# v1.2.1 + +Bug Fix: + +- Small regression with synchronous iterator behavior in `eachSeries` with a 1-element array. Before 1.1.0, `eachSeries`'s callback was called on the same tick, which this patch restores. In 2.0.0, it will be called on the next tick. ([#782](https://github.com/caolan/async/issues/782)) + + +# v1.2.0 + +New Features: + +- Added `timesLimit` ([#743](https://github.com/caolan/async/issues/743)) +- `concurrency` can be changed after initialization in `queue` by setting `q.concurrency`. The new concurrency will be reflected the next time a task is processed. ([#747](https://github.com/caolan/async/issues/747), [#772](https://github.com/caolan/async/issues/772)) + +Bug Fixes: + +- Fixed a regression in `each` and family with empty arrays that have additional properties. ([#775](https://github.com/caolan/async/issues/775), [#777](https://github.com/caolan/async/issues/777)) + + +# v1.1.1 + +Bug Fix: + +- Small regression with synchronous iterator behavior in `eachSeries` with a 1-element array. Before 1.1.0, `eachSeries`'s callback was called on the same tick, which this patch restores. In 2.0.0, it will be called on the next tick. ([#782](https://github.com/caolan/async/issues/782)) + + +# v1.1.0 + +New Features: + +- `cargo` now supports all of the same methods and event callbacks as `queue`. +- Added `ensureAsync` - A wrapper that ensures an async function calls its callback on a later tick. ([#769](https://github.com/caolan/async/issues/769)) +- Optimized `map`, `eachOf`, and `waterfall` families of functions +- Passing a `null` or `undefined` array to `map`, `each`, `parallel` and families will be treated as an empty array ([#667](https://github.com/caolan/async/issues/667)). +- The callback is now optional for the composed results of `compose` and `seq`. ([#618](https://github.com/caolan/async/issues/618)) +- Reduced file size by 4kb, (minified version by 1kb) +- Added code coverage through `nyc` and `coveralls` ([#768](https://github.com/caolan/async/issues/768)) + +Bug Fixes: + +- `forever` will no longer stack overflow with a synchronous iterator ([#622](https://github.com/caolan/async/issues/622)) +- `eachLimit` and other limit functions will stop iterating once an error occurs ([#754](https://github.com/caolan/async/issues/754)) +- Always pass `null` in callbacks when there is no error ([#439](https://github.com/caolan/async/issues/439)) +- Ensure proper conditions when calling `drain()` after pushing an empty data set to a queue ([#668](https://github.com/caolan/async/issues/668)) +- `each` and family will properly handle an empty array ([#578](https://github.com/caolan/async/issues/578)) +- `eachSeries` and family will finish if the underlying array is modified during execution ([#557](https://github.com/caolan/async/issues/557)) +- `queue` will throw if a non-function is passed to `q.push()` ([#593](https://github.com/caolan/async/issues/593)) +- Doc fixes ([#629](https://github.com/caolan/async/issues/629), [#766](https://github.com/caolan/async/issues/766)) + + +# v1.0.0 + +No known breaking changes, we are simply complying with semver from here on out. + +Changes: + +- Start using a changelog! +- Add `forEachOf` for iterating over Objects (or to iterate Arrays with indexes available) ([#168](https://github.com/caolan/async/issues/168) [#704](https://github.com/caolan/async/issues/704) [#321](https://github.com/caolan/async/issues/321)) +- Detect deadlocks in `auto` ([#663](https://github.com/caolan/async/issues/663)) +- Better support for require.js ([#527](https://github.com/caolan/async/issues/527)) +- Throw if queue created with concurrency `0` ([#714](https://github.com/caolan/async/issues/714)) +- Fix unneeded iteration in `queue.resume()` ([#758](https://github.com/caolan/async/issues/758)) +- Guard against timer mocking overriding `setImmediate` ([#609](https://github.com/caolan/async/issues/609) [#611](https://github.com/caolan/async/issues/611)) +- Miscellaneous doc fixes ([#542](https://github.com/caolan/async/issues/542) [#596](https://github.com/caolan/async/issues/596) [#615](https://github.com/caolan/async/issues/615) [#628](https://github.com/caolan/async/issues/628) [#631](https://github.com/caolan/async/issues/631) [#690](https://github.com/caolan/async/issues/690) [#729](https://github.com/caolan/async/issues/729)) +- Use single noop function internally ([#546](https://github.com/caolan/async/issues/546)) +- Optimize internal `_each`, `_map` and `_keys` functions. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/LICENSE new file mode 100644 index 0000000..b18aed6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2010-2018 Caolan McMahon + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/README.md new file mode 100644 index 0000000..55a0626 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/README.md @@ -0,0 +1,59 @@ +![Async Logo](https://raw.githubusercontent.com/caolan/async/master/logo/async-logo_readme.jpg) + +![Github Actions CI status](https://github.com/caolan/async/actions/workflows/ci.yml/badge.svg) +[![NPM version](https://img.shields.io/npm/v/async.svg)](https://www.npmjs.com/package/async) +[![Coverage Status](https://coveralls.io/repos/caolan/async/badge.svg?branch=master)](https://coveralls.io/r/caolan/async?branch=master) +[![Join the chat at https://gitter.im/caolan/async](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/caolan/async?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) +[![jsDelivr Hits](https://data.jsdelivr.com/v1/package/npm/async/badge?style=rounded)](https://www.jsdelivr.com/package/npm/async) + + + +Async is a utility module which provides straight-forward, powerful functions for working with [asynchronous JavaScript](http://caolan.github.io/async/v3/global.html). Although originally designed for use with [Node.js](https://nodejs.org/) and installable via `npm i async`, it can also be used directly in the browser. An ESM/MJS version is included in the main `async` package that should automatically be used with compatible bundlers such as Webpack and Rollup. + +A pure ESM version of Async is available as [`async-es`](https://www.npmjs.com/package/async-es). + +For Documentation, visit + +*For Async v1.5.x documentation, go [HERE](https://github.com/caolan/async/blob/v1.5.2/README.md)* + + +```javascript +// for use with Node-style callbacks... +var async = require("async"); + +var obj = {dev: "/dev.json", test: "/test.json", prod: "/prod.json"}; +var configs = {}; + +async.forEachOf(obj, (value, key, callback) => { + fs.readFile(__dirname + value, "utf8", (err, data) => { + if (err) return callback(err); + try { + configs[key] = JSON.parse(data); + } catch (e) { + return callback(e); + } + callback(); + }); +}, err => { + if (err) console.error(err.message); + // configs is now a map of JSON data + doSomethingWith(configs); +}); +``` + +```javascript +var async = require("async"); + +// ...or ES2017 async functions +async.mapLimit(urls, 5, async function(url) { + const response = await fetch(url) + return response.body +}, (err, results) => { + if (err) throw err + // results is now an array of the response bodies + console.log(results) +}) +``` diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/all.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/all.js new file mode 100644 index 0000000..622b301 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/all.js @@ -0,0 +1,119 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file5.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.every(fileList, fileExists, function(err, result) { + * console.log(result); + * // true + * // result is true since every file exists + * }); + * + * async.every(withMissingFileList, fileExists, function(err, result) { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }); + * + * // Using Promises + * async.every(fileList, fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.every(withMissingFileList, fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.every(fileList, fileExists); + * console.log(result); + * // true + * // result is true since every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.every(withMissingFileList, fileExists); + * console.log(result); + * // false + * // result is false since NOT every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function every(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(every, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allLimit.js new file mode 100644 index 0000000..375e126 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allLimit.js @@ -0,0 +1,46 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everyLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(everyLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allSeries.js new file mode 100644 index 0000000..9a6bf7d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/allSeries.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in series. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everySeries(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(everySeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/any.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/any.js new file mode 100644 index 0000000..a5bd328 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/any.js @@ -0,0 +1,122 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns `true` if at least one element in the `coll` satisfies an async test. + * If any iteratee call returns `true`, the main `callback` is immediately + * called. + * + * @name some + * @static + * @memberOf module:Collections + * @method + * @alias any + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + *); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // false + * // result is false since none of the files exists + * } + *); + * + * // Using Promises + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since some file in the list exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since none of the files exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists); + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists); + * console.log(result); + * // false + * // result is false since none of the files exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function some(coll, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(some, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anyLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anyLimit.js new file mode 100644 index 0000000..3a8096f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anyLimit.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time. + * + * @name someLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anyLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(someLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anySeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anySeries.js new file mode 100644 index 0000000..51aad19 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/anySeries.js @@ -0,0 +1,46 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time. + * + * @name someSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anySeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in series. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someSeries(coll, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(someSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/apply.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/apply.js new file mode 100644 index 0000000..d40784f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/apply.js @@ -0,0 +1,11 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (fn, ...args) { + return (...callArgs) => fn(...args, ...callArgs); +}; + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEach.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEach.js new file mode 100644 index 0000000..841842c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEach.js @@ -0,0 +1,57 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _applyEach = require('./internal/applyEach.js'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _map = require('./map.js'); + +var _map2 = _interopRequireDefault(_map); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies the provided arguments to each function in the array, calling + * `callback` after all functions have completed. If you only provide the first + * argument, `fns`, then it will return a function which lets you pass in the + * arguments as if it were a single function call. If more arguments are + * provided, `callback` is required while `args` is still optional. The results + * for each of the applied async functions are passed to the final callback + * as an array. + * + * @name applyEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s + * to all call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - Returns a function that takes no args other than + * an optional callback, that is the result of applying the `args` to each + * of the functions. + * @example + * + * const appliedFn = async.applyEach([enableSearch, updateSchema], 'bucket') + * + * appliedFn((err, results) => { + * // results[0] is the results for `enableSearch` + * // results[1] is the results for `updateSchema` + * }); + * + * // partial application example: + * async.each( + * buckets, + * async (bucket) => async.applyEach([enableSearch, updateSchema], bucket)(), + * callback + * ); + */ +exports.default = (0, _applyEach2.default)(_map2.default); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEachSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEachSeries.js new file mode 100644 index 0000000..f5267f6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/applyEachSeries.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _applyEach = require('./internal/applyEach.js'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _mapSeries = require('./mapSeries.js'); + +var _mapSeries2 = _interopRequireDefault(_mapSeries); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time. + * + * @name applyEachSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.applyEach]{@link module:ControlFlow.applyEach} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - A function, that when called, is the result of + * appling the `args` to the list of functions. It takes no args, other than + * a callback. + */ +exports.default = (0, _applyEach2.default)(_mapSeries2.default); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/asyncify.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/asyncify.js new file mode 100644 index 0000000..ddc3f02 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/asyncify.js @@ -0,0 +1,118 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = asyncify; + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _setImmediate = require('./internal/setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2017 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function, or Promise-returning + * function to convert to an {@link AsyncFunction}. + * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be + * invoked with `(args..., callback)`. + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es2017 example, though `asyncify` is not needed if your JS environment + * // supports async functions out of the box + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ +function asyncify(func) { + if ((0, _wrapAsync.isAsync)(func)) { + return function (...args /*, callback*/) { + const callback = args.pop(); + const promise = func.apply(this, args); + return handlePromise(promise, callback); + }; + } + + return (0, _initialParams2.default)(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if (result && typeof result.then === 'function') { + return handlePromise(result, callback); + } else { + callback(null, result); + } + }); +} + +function handlePromise(promise, callback) { + return promise.then(value => { + invokeCallback(callback, null, value); + }, err => { + invokeCallback(callback, err && (err instanceof Error || err.message) ? err : new Error(err)); + }); +} + +function invokeCallback(callback, error, value) { + try { + callback(error, value); + } catch (err) { + (0, _setImmediate2.default)(e => { + throw e; + }, err); + } +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/auto.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/auto.js new file mode 100644 index 0000000..163c4f2 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/auto.js @@ -0,0 +1,333 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = auto; + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _promiseCallback = require('./internal/promiseCallback.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Determines the best order for running the {@link AsyncFunction}s in `tasks`, based on + * their requirements. Each function can optionally depend on other functions + * being completed first, and each function is run as soon as its requirements + * are satisfied. + * + * If any of the {@link AsyncFunction}s pass an error to their callback, the `auto` sequence + * will stop. Further tasks will not execute (so any other functions depending + * on it will not run), and the main `callback` is immediately called with the + * error. + * + * {@link AsyncFunction}s also receive an object containing the results of functions which + * have completed so far as the first argument, if they have dependencies. If a + * task function has no dependencies, it will only be passed a callback. + * + * @name auto + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object} tasks - An object. Each of its properties is either a + * function or an array of requirements, with the {@link AsyncFunction} itself the last item + * in the array. The object's key of a property serves as the name of the task + * defined by that property, i.e. can be used when specifying requirements for + * other tasks. The function receives one or two arguments: + * * a `results` object, containing the results of the previously executed + * functions, only passed if the task has any dependencies, + * * a `callback(err, result)` function, which must be called when finished, + * passing an `error` (which can be `null`) and the result of the function's + * execution. + * @param {number} [concurrency=Infinity] - An optional `integer` for + * determining the maximum number of tasks that can be run in parallel. By + * default, as many as possible. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback. Results are always returned; however, if an + * error occurs, no further `tasks` will be performed, and the results object + * will only contain partial results. Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * @example + * + * //Using Callbacks + * async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }, function(err, results) { + * if (err) { + * console.log('err = ', err); + * } + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }); + * + * //Using Promises + * async.auto({ + * get_data: function(callback) { + * console.log('in get_data'); + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * console.log('in make_folder'); + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }).then(results => { + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }).catch(err => { + * console.log('err = ', err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }); + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function auto(tasks, concurrency, callback) { + if (typeof concurrency !== 'number') { + // concurrency is optional, shift the args. + callback = concurrency; + concurrency = null; + } + callback = (0, _once2.default)(callback || (0, _promiseCallback.promiseCallback)()); + var numTasks = Object.keys(tasks).length; + if (!numTasks) { + return callback(null); + } + if (!concurrency) { + concurrency = numTasks; + } + + var results = {}; + var runningTasks = 0; + var canceled = false; + var hasError = false; + + var listeners = Object.create(null); + + var readyTasks = []; + + // for cycle detection: + var readyToCheck = []; // tasks that have been identified as reachable + // without the possibility of returning to an ancestor task + var uncheckedDependencies = {}; + + Object.keys(tasks).forEach(key => { + var task = tasks[key]; + if (!Array.isArray(task)) { + // no dependencies + enqueueTask(key, [task]); + readyToCheck.push(key); + return; + } + + var dependencies = task.slice(0, task.length - 1); + var remainingDependencies = dependencies.length; + if (remainingDependencies === 0) { + enqueueTask(key, task); + readyToCheck.push(key); + return; + } + uncheckedDependencies[key] = remainingDependencies; + + dependencies.forEach(dependencyName => { + if (!tasks[dependencyName]) { + throw new Error('async.auto task `' + key + '` has a non-existent dependency `' + dependencyName + '` in ' + dependencies.join(', ')); + } + addListener(dependencyName, () => { + remainingDependencies--; + if (remainingDependencies === 0) { + enqueueTask(key, task); + } + }); + }); + }); + + checkForDeadlocks(); + processQueue(); + + function enqueueTask(key, task) { + readyTasks.push(() => runTask(key, task)); + } + + function processQueue() { + if (canceled) return; + if (readyTasks.length === 0 && runningTasks === 0) { + return callback(null, results); + } + while (readyTasks.length && runningTasks < concurrency) { + var run = readyTasks.shift(); + run(); + } + } + + function addListener(taskName, fn) { + var taskListeners = listeners[taskName]; + if (!taskListeners) { + taskListeners = listeners[taskName] = []; + } + + taskListeners.push(fn); + } + + function taskComplete(taskName) { + var taskListeners = listeners[taskName] || []; + taskListeners.forEach(fn => fn()); + processQueue(); + } + + function runTask(key, task) { + if (hasError) return; + + var taskCallback = (0, _onlyOnce2.default)((err, ...result) => { + runningTasks--; + if (err === false) { + canceled = true; + return; + } + if (result.length < 2) { + [result] = result; + } + if (err) { + var safeResults = {}; + Object.keys(results).forEach(rkey => { + safeResults[rkey] = results[rkey]; + }); + safeResults[key] = result; + hasError = true; + listeners = Object.create(null); + if (canceled) return; + callback(err, safeResults); + } else { + results[key] = result; + taskComplete(key); + } + }); + + runningTasks++; + var taskFn = (0, _wrapAsync2.default)(task[task.length - 1]); + if (task.length > 1) { + taskFn(results, taskCallback); + } else { + taskFn(taskCallback); + } + } + + function checkForDeadlocks() { + // Kahn's algorithm + // https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm + // http://connalle.blogspot.com/2013/10/topological-sortingkahn-algorithm.html + var currentTask; + var counter = 0; + while (readyToCheck.length) { + currentTask = readyToCheck.pop(); + counter++; + getDependents(currentTask).forEach(dependent => { + if (--uncheckedDependencies[dependent] === 0) { + readyToCheck.push(dependent); + } + }); + } + + if (counter !== numTasks) { + throw new Error('async.auto cannot execute tasks due to a recursive dependency'); + } + } + + function getDependents(taskName) { + var result = []; + Object.keys(tasks).forEach(key => { + const task = tasks[key]; + if (Array.isArray(task) && task.indexOf(taskName) >= 0) { + result.push(key); + } + }); + return result; + } + + return callback[_promiseCallback.PROMISE_SYMBOL]; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/autoInject.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/autoInject.js new file mode 100644 index 0000000..5db2653 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/autoInject.js @@ -0,0 +1,182 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = autoInject; + +var _auto = require('./auto.js'); + +var _auto2 = _interopRequireDefault(_auto); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var FN_ARGS = /^(?:async\s)?(?:function)?\s*(?:\w+\s*)?\(([^)]+)\)(?:\s*{)/; +var ARROW_FN_ARGS = /^(?:async\s)?\s*(?:\(\s*)?((?:[^)=\s]\s*)*)(?:\)\s*)?=>/; +var FN_ARG_SPLIT = /,/; +var FN_ARG = /(=.+)?(\s*)$/; + +function stripComments(string) { + let stripped = ''; + let index = 0; + let endBlockComment = string.indexOf('*/'); + while (index < string.length) { + if (string[index] === '/' && string[index + 1] === '/') { + // inline comment + let endIndex = string.indexOf('\n', index); + index = endIndex === -1 ? string.length : endIndex; + } else if (endBlockComment !== -1 && string[index] === '/' && string[index + 1] === '*') { + // block comment + let endIndex = string.indexOf('*/', index); + if (endIndex !== -1) { + index = endIndex + 2; + endBlockComment = string.indexOf('*/', index); + } else { + stripped += string[index]; + index++; + } + } else { + stripped += string[index]; + index++; + } + } + return stripped; +} + +function parseParams(func) { + const src = stripComments(func.toString()); + let match = src.match(FN_ARGS); + if (!match) { + match = src.match(ARROW_FN_ARGS); + } + if (!match) throw new Error('could not parse args in autoInject\nSource:\n' + src); + let [, args] = match; + return args.replace(/\s/g, '').split(FN_ARG_SPLIT).map(arg => arg.replace(FN_ARG, '').trim()); +} + +/** + * A dependency-injected version of the [async.auto]{@link module:ControlFlow.auto} function. Dependent + * tasks are specified as parameters to the function, after the usual callback + * parameter, with the parameter names matching the names of the tasks it + * depends on. This can provide even more readable task graphs which can be + * easier to maintain. + * + * If a final callback is specified, the task results are similarly injected, + * specified as named parameters after the initial error parameter. + * + * The autoInject function is purely syntactic sugar and its semantics are + * otherwise equivalent to [async.auto]{@link module:ControlFlow.auto}. + * + * @name autoInject + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.auto]{@link module:ControlFlow.auto} + * @category Control Flow + * @param {Object} tasks - An object, each of whose properties is an {@link AsyncFunction} of + * the form 'func([dependencies...], callback). The object's key of a property + * serves as the name of the task defined by that property, i.e. can be used + * when specifying requirements for other tasks. + * * The `callback` parameter is a `callback(err, result)` which must be called + * when finished, passing an `error` (which can be `null`) and the result of + * the function's execution. The remaining parameters name other tasks on + * which the task is dependent, and the results from those tasks are the + * arguments of those parameters. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback, and a `results` object with any completed + * task results, similar to `auto`. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // The example from `auto` can be rewritten as follows: + * async.autoInject({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: function(get_data, make_folder, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }, + * email_link: function(write_file, callback) { + * // once the file is written let's email a link to it... + * // write_file contains the filename returned by write_file. + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * } + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + * + * // If you are using a JS minifier that mangles parameter names, `autoInject` + * // will not work with plain functions, since the parameter names will be + * // collapsed to a single letter identifier. To work around this, you can + * // explicitly specify the names of the parameters your task function needs + * // in an array, similar to Angular.js dependency injection. + * + * // This still has an advantage over plain `auto`, since the results a task + * // depends on are still spread into arguments. + * async.autoInject({ + * //... + * write_file: ['get_data', 'make_folder', function(get_data, make_folder, callback) { + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(write_file, callback) { + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * }] + * //... + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + */ +function autoInject(tasks, callback) { + var newTasks = {}; + + Object.keys(tasks).forEach(key => { + var taskFn = tasks[key]; + var params; + var fnIsAsync = (0, _wrapAsync.isAsync)(taskFn); + var hasNoDeps = !fnIsAsync && taskFn.length === 1 || fnIsAsync && taskFn.length === 0; + + if (Array.isArray(taskFn)) { + params = [...taskFn]; + taskFn = params.pop(); + + newTasks[key] = params.concat(params.length > 0 ? newTask : taskFn); + } else if (hasNoDeps) { + // no dependencies, use the function as-is + newTasks[key] = taskFn; + } else { + params = parseParams(taskFn); + if (taskFn.length === 0 && !fnIsAsync && params.length === 0) { + throw new Error("autoInject task functions require explicit parameters."); + } + + // remove callback param + if (!fnIsAsync) params.pop(); + + newTasks[key] = params.concat(newTask); + } + + function newTask(results, taskCb) { + var newArgs = params.map(name => results[name]); + newArgs.push(taskCb); + (0, _wrapAsync2.default)(taskFn)(...newArgs); + } + }); + + return (0, _auto2.default)(newTasks, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/bower.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/bower.json new file mode 100644 index 0000000..390c650 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/bower.json @@ -0,0 +1,17 @@ +{ + "name": "async", + "main": "dist/async.js", + "ignore": [ + "bower_components", + "lib", + "test", + "node_modules", + "perf", + "support", + "**/.*", + "*.config.js", + "*.json", + "index.js", + "Makefile" + ] +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/cargo.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/cargo.js new file mode 100644 index 0000000..d4abd21 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/cargo.js @@ -0,0 +1,63 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = cargo; + +var _queue = require('./internal/queue.js'); + +var _queue2 = _interopRequireDefault(_queue); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Creates a `cargo` object with the specified payload. Tasks added to the + * cargo will be processed altogether (up to the `payload` limit). If the + * `worker` is in progress, the task is queued until it becomes available. Once + * the `worker` has completed some tasks, each callback of those tasks is + * called. Check out [these](https://camo.githubusercontent.com/6bbd36f4cf5b35a0f11a96dcd2e97711ffc2fb37/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130382f62626330636662302d356632392d313165322d393734662d3333393763363464633835382e676966) [animations](https://camo.githubusercontent.com/f4810e00e1c5f5f8addbe3e9f49064fd5d102699/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130312f38346339323036362d356632392d313165322d383134662d3964336430323431336266642e676966) + * for how `cargo` and `queue` work. + * + * While [`queue`]{@link module:ControlFlow.queue} passes only one task to one of a group of workers + * at a time, cargo passes an array of tasks to a single worker, repeating + * when the worker is finished. + * + * @name cargo + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {AsyncFunction} worker - An asynchronous function for processing an array + * of queued tasks. Invoked with `(tasks, callback)`. + * @param {number} [payload=Infinity] - An optional `integer` for determining + * how many tasks should be processed per round; if omitted, the default is + * unlimited. + * @returns {module:ControlFlow.QueueObject} A cargo object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the cargo and inner queue. + * @example + * + * // create a cargo object with payload 2 + * var cargo = async.cargo(function(tasks, callback) { + * for (var i=0; i { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir) + * .then(results => { + * console.log(results); + * }).catch(err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.concat(directoryList, fs.readdir); + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.concat(withMissingDirectoryList, fs.readdir); + * console.log(results); + * } catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } + * } + * + */ +function concat(coll, iteratee, callback) { + return (0, _concatLimit2.default)(coll, Infinity, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(concat, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatLimit.js new file mode 100644 index 0000000..a27cc7d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatLimit.js @@ -0,0 +1,60 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _mapLimit = require('./mapLimit.js'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs a maximum of `limit` async operations at a time. + * + * @name concatLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapLimit + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatLimit(coll, limit, iteratee, callback) { + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _mapLimit2.default)(coll, limit, (val, iterCb) => { + _iteratee(val, (err, ...args) => { + if (err) return iterCb(err); + return iterCb(err, args); + }); + }, (err, mapResults) => { + var result = []; + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + result = result.concat(...mapResults[i]); + } + } + + return callback(err, result); + }); +} +exports.default = (0, _awaitify2.default)(concatLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatSeries.js new file mode 100644 index 0000000..332de3f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/concatSeries.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _concatLimit = require('./concatLimit.js'); + +var _concatLimit2 = _interopRequireDefault(_concatLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs only a single async operation at a time. + * + * @name concatSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapSeries + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`. + * The iteratee should complete with an array an array of results. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatSeries(coll, iteratee, callback) { + return (0, _concatLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(concatSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/constant.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/constant.js new file mode 100644 index 0000000..ea406f6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/constant.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (...args) { + return function (...ignoredArgs /*, callback*/) { + var callback = ignoredArgs.pop(); + return callback(null, ...args); + }; +}; + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detect.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detect.js new file mode 100644 index 0000000..d5896ef --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detect.js @@ -0,0 +1,96 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns the first value in `coll` that passes an async truth test. The + * `iteratee` is applied in parallel, meaning the first iteratee to return + * `true` will fire the detect `callback` with that result. That means the + * result might not be the first item in the original `coll` (in terms of order) + * that passes the test. + + * If order within the original `coll` is important, then look at + * [`detectSeries`]{@link module:Collections.detectSeries}. + * + * @name detect + * @static + * @memberOf module:Collections + * @method + * @alias find + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * } + *); + * + * // Using Promises + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists) + * .then(result => { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists); + * console.log(result); + * // dir1/file1.txt + * // result now equals the file in the list that exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function detect(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(detect, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectLimit.js new file mode 100644 index 0000000..c59843b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectLimit.js @@ -0,0 +1,48 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a + * time. + * + * @name detectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findLimit + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(detectLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectSeries.js new file mode 100644 index 0000000..b486899 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/detectSeries.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time. + * + * @name detectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findSeries + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectSeries(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)((0, _eachOfLimit2.default)(1), coll, iteratee, callback); +} + +exports.default = (0, _awaitify2.default)(detectSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dir.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dir.js new file mode 100644 index 0000000..8e9fafd --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dir.js @@ -0,0 +1,43 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _consoleFunc = require('./internal/consoleFunc.js'); + +var _consoleFunc2 = _interopRequireDefault(_consoleFunc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Logs the result of an [`async` function]{@link AsyncFunction} to the + * `console` using `console.dir` to display the properties of the resulting object. + * Only works in Node.js or in browsers that support `console.dir` and + * `console.error` (such as FF and Chrome). + * If multiple arguments are returned from the async function, + * `console.dir` is called on each argument in order. + * + * @name dir + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, {hello: name}); + * }, 1000); + * }; + * + * // in the node repl + * node> async.dir(hello, 'world'); + * {hello: 'world'} + */ +exports.default = (0, _consoleFunc2.default)('dir'); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.js new file mode 100644 index 0000000..d7b7918 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.js @@ -0,0 +1,6061 @@ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : + typeof define === 'function' && define.amd ? define(['exports'], factory) : + (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.async = {})); +})(this, (function (exports) { 'use strict'; + + /** + * Creates a continuation function with some arguments already applied. + * + * Useful as a shorthand when combined with other control flow functions. Any + * arguments passed to the returned function are added to the arguments + * originally passed to apply. + * + * @name apply + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - The function you want to eventually apply all + * arguments to. Invokes with (arguments...). + * @param {...*} arguments... - Any number of arguments to automatically apply + * when the continuation is called. + * @returns {Function} the partially-applied function + * @example + * + * // using apply + * async.parallel([ + * async.apply(fs.writeFile, 'testfile1', 'test1'), + * async.apply(fs.writeFile, 'testfile2', 'test2') + * ]); + * + * + * // the same process without using apply + * async.parallel([ + * function(callback) { + * fs.writeFile('testfile1', 'test1', callback); + * }, + * function(callback) { + * fs.writeFile('testfile2', 'test2', callback); + * } + * ]); + * + * // It's possible to pass any number of additional arguments when calling the + * // continuation: + * + * node> var fn = async.apply(sys.puts, 'one'); + * node> fn('two', 'three'); + * one + * two + * three + */ + function apply(fn, ...args) { + return (...callArgs) => fn(...args,...callArgs); + } + + function initialParams (fn) { + return function (...args/*, callback*/) { + var callback = args.pop(); + return fn.call(this, args, callback); + }; + } + + /* istanbul ignore file */ + + var hasQueueMicrotask = typeof queueMicrotask === 'function' && queueMicrotask; + var hasSetImmediate = typeof setImmediate === 'function' && setImmediate; + var hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function'; + + function fallback(fn) { + setTimeout(fn, 0); + } + + function wrap(defer) { + return (fn, ...args) => defer(() => fn(...args)); + } + + var _defer$1; + + if (hasQueueMicrotask) { + _defer$1 = queueMicrotask; + } else if (hasSetImmediate) { + _defer$1 = setImmediate; + } else if (hasNextTick) { + _defer$1 = process.nextTick; + } else { + _defer$1 = fallback; + } + + var setImmediate$1 = wrap(_defer$1); + + /** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2017 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function, or Promise-returning + * function to convert to an {@link AsyncFunction}. + * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be + * invoked with `(args..., callback)`. + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es2017 example, though `asyncify` is not needed if your JS environment + * // supports async functions out of the box + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ + function asyncify(func) { + if (isAsync(func)) { + return function (...args/*, callback*/) { + const callback = args.pop(); + const promise = func.apply(this, args); + return handlePromise(promise, callback) + } + } + + return initialParams(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if (result && typeof result.then === 'function') { + return handlePromise(result, callback) + } else { + callback(null, result); + } + }); + } + + function handlePromise(promise, callback) { + return promise.then(value => { + invokeCallback(callback, null, value); + }, err => { + invokeCallback(callback, err && (err instanceof Error || err.message) ? err : new Error(err)); + }); + } + + function invokeCallback(callback, error, value) { + try { + callback(error, value); + } catch (err) { + setImmediate$1(e => { throw e }, err); + } + } + + function isAsync(fn) { + return fn[Symbol.toStringTag] === 'AsyncFunction'; + } + + function isAsyncGenerator(fn) { + return fn[Symbol.toStringTag] === 'AsyncGenerator'; + } + + function isAsyncIterable(obj) { + return typeof obj[Symbol.asyncIterator] === 'function'; + } + + function wrapAsync(asyncFn) { + if (typeof asyncFn !== 'function') throw new Error('expected a function') + return isAsync(asyncFn) ? asyncify(asyncFn) : asyncFn; + } + + // conditionally promisify a function. + // only return a promise if a callback is omitted + function awaitify (asyncFn, arity) { + if (!arity) arity = asyncFn.length; + if (!arity) throw new Error('arity is undefined') + function awaitable (...args) { + if (typeof args[arity - 1] === 'function') { + return asyncFn.apply(this, args) + } + + return new Promise((resolve, reject) => { + args[arity - 1] = (err, ...cbArgs) => { + if (err) return reject(err) + resolve(cbArgs.length > 1 ? cbArgs : cbArgs[0]); + }; + asyncFn.apply(this, args); + }) + } + + return awaitable + } + + function applyEach$1 (eachfn) { + return function applyEach(fns, ...callArgs) { + const go = awaitify(function (callback) { + var that = this; + return eachfn(fns, (fn, cb) => { + wrapAsync(fn).apply(that, callArgs.concat(cb)); + }, callback); + }); + return go; + }; + } + + function _asyncMap(eachfn, arr, iteratee, callback) { + arr = arr || []; + var results = []; + var counter = 0; + var _iteratee = wrapAsync(iteratee); + + return eachfn(arr, (value, _, iterCb) => { + var index = counter++; + _iteratee(value, (err, v) => { + results[index] = v; + iterCb(err); + }); + }, err => { + callback(err, results); + }); + } + + function isArrayLike(value) { + return value && + typeof value.length === 'number' && + value.length >= 0 && + value.length % 1 === 0; + } + + // A temporary value used to identify if the loop should be broken. + // See #1064, #1293 + const breakLoop = {}; + + function once(fn) { + function wrapper (...args) { + if (fn === null) return; + var callFn = fn; + fn = null; + callFn.apply(this, args); + } + Object.assign(wrapper, fn); + return wrapper + } + + function getIterator (coll) { + return coll[Symbol.iterator] && coll[Symbol.iterator](); + } + + function createArrayIterator(coll) { + var i = -1; + var len = coll.length; + return function next() { + return ++i < len ? {value: coll[i], key: i} : null; + } + } + + function createES2015Iterator(iterator) { + var i = -1; + return function next() { + var item = iterator.next(); + if (item.done) + return null; + i++; + return {value: item.value, key: i}; + } + } + + function createObjectIterator(obj) { + var okeys = obj ? Object.keys(obj) : []; + var i = -1; + var len = okeys.length; + return function next() { + var key = okeys[++i]; + if (key === '__proto__') { + return next(); + } + return i < len ? {value: obj[key], key} : null; + }; + } + + function createIterator(coll) { + if (isArrayLike(coll)) { + return createArrayIterator(coll); + } + + var iterator = getIterator(coll); + return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll); + } + + function onlyOnce(fn) { + return function (...args) { + if (fn === null) throw new Error("Callback was already called."); + var callFn = fn; + fn = null; + callFn.apply(this, args); + }; + } + + // for async generators + function asyncEachOfLimit(generator, limit, iteratee, callback) { + let done = false; + let canceled = false; + let awaiting = false; + let running = 0; + let idx = 0; + + function replenish() { + //console.log('replenish') + if (running >= limit || awaiting || done) return + //console.log('replenish awaiting') + awaiting = true; + generator.next().then(({value, done: iterDone}) => { + //console.log('got value', value) + if (canceled || done) return + awaiting = false; + if (iterDone) { + done = true; + if (running <= 0) { + //console.log('done nextCb') + callback(null); + } + return; + } + running++; + iteratee(value, idx, iterateeCallback); + idx++; + replenish(); + }).catch(handleError); + } + + function iterateeCallback(err, result) { + //console.log('iterateeCallback') + running -= 1; + if (canceled) return + if (err) return handleError(err) + + if (err === false) { + done = true; + canceled = true; + return + } + + if (result === breakLoop || (done && running <= 0)) { + done = true; + //console.log('done iterCb') + return callback(null); + } + replenish(); + } + + function handleError(err) { + if (canceled) return + awaiting = false; + done = true; + callback(err); + } + + replenish(); + } + + var eachOfLimit$2 = (limit) => { + return (obj, iteratee, callback) => { + callback = once(callback); + if (limit <= 0) { + throw new RangeError('concurrency limit cannot be less than 1') + } + if (!obj) { + return callback(null); + } + if (isAsyncGenerator(obj)) { + return asyncEachOfLimit(obj, limit, iteratee, callback) + } + if (isAsyncIterable(obj)) { + return asyncEachOfLimit(obj[Symbol.asyncIterator](), limit, iteratee, callback) + } + var nextElem = createIterator(obj); + var done = false; + var canceled = false; + var running = 0; + var looping = false; + + function iterateeCallback(err, value) { + if (canceled) return + running -= 1; + if (err) { + done = true; + callback(err); + } + else if (err === false) { + done = true; + canceled = true; + } + else if (value === breakLoop || (done && running <= 0)) { + done = true; + return callback(null); + } + else if (!looping) { + replenish(); + } + } + + function replenish () { + looping = true; + while (running < limit && !done) { + var elem = nextElem(); + if (elem === null) { + done = true; + if (running <= 0) { + callback(null); + } + return; + } + running += 1; + iteratee(elem.value, elem.key, onlyOnce(iterateeCallback)); + } + looping = false; + } + + replenish(); + }; + }; + + /** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ + function eachOfLimit(coll, limit, iteratee, callback) { + return eachOfLimit$2(limit)(coll, wrapAsync(iteratee), callback); + } + + var eachOfLimit$1 = awaitify(eachOfLimit, 4); + + // eachOf implementation optimized for array-likes + function eachOfArrayLike(coll, iteratee, callback) { + callback = once(callback); + var index = 0, + completed = 0, + {length} = coll, + canceled = false; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err, value) { + if (err === false) { + canceled = true; + } + if (canceled === true) return + if (err) { + callback(err); + } else if ((++completed === length) || value === breakLoop) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, onlyOnce(iteratorCallback)); + } + } + + // a generic version of eachOf which can handle array, object, and iterator cases. + function eachOfGeneric (coll, iteratee, callback) { + return eachOfLimit$1(coll, Infinity, iteratee, callback); + } + + /** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each + * item in `coll`. + * The `key` is the item's key, or index in the case of an array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dev.json is a file containing a valid json object config for dev environment + * // dev.json is a file containing a valid json object config for test environment + * // prod.json is a file containing a valid json object config for prod environment + * // invalid.json is a file with a malformed json object + * + * let configs = {}; //global variable + * let validConfigFileMap = {dev: 'dev.json', test: 'test.json', prod: 'prod.json'}; + * let invalidConfigFileMap = {dev: 'dev.json', test: 'test.json', invalid: 'invalid.json'}; + * + * // asynchronous function that reads a json file and parses the contents as json object + * function parseFile(file, key, callback) { + * fs.readFile(file, "utf8", function(err, data) { + * if (err) return calback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * } + * + * // Using callbacks + * async.forEachOf(validConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * } else { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * // JSON parse error exception + * } else { + * console.log(configs); + * } + * }); + * + * // Using Promises + * async.forEachOf(validConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * }).catch( err => { + * console.error(err); + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * }).catch( err => { + * console.error(err); + * // JSON parse error exception + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.forEachOf(validConfigFileMap, parseFile); + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * catch (err) { + * console.log(err); + * } + * } + * + * //Error handing + * async () => { + * try { + * let result = await async.forEachOf(invalidConfigFileMap, parseFile); + * console.log(configs); + * } + * catch (err) { + * console.log(err); + * // JSON parse error exception + * } + * } + * + */ + function eachOf(coll, iteratee, callback) { + var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric; + return eachOfImplementation(coll, wrapAsync(iteratee), callback); + } + + var eachOf$1 = awaitify(eachOf, 3); + + /** + * Produces a new collection of values by mapping each value in `coll` through + * the `iteratee` function. The `iteratee` is called with an item from `coll` + * and a callback for when it has finished processing. Each of these callbacks + * takes 2 arguments: an `error`, and the transformed item from `coll`. If + * `iteratee` passes an error to its callback, the main `callback` (for the + * `map` function) is immediately called with the error. + * + * Note, that since this function applies the `iteratee` to each item in + * parallel, there is no guarantee that the `iteratee` functions will complete + * in order. However, the results array will be in the same order as the + * original `coll`. + * + * If `map` is passed an Object, the results will be an Array. The results + * will roughly be in the order of the original Objects' keys (but this can + * vary across JavaScript engines). + * + * @name map + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an Array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.map(fileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.map(fileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.map(fileList, getFileSizeInBytes); + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.map(withMissingFileList, getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ + function map (coll, iteratee, callback) { + return _asyncMap(eachOf$1, coll, iteratee, callback) + } + var map$1 = awaitify(map, 3); + + /** + * Applies the provided arguments to each function in the array, calling + * `callback` after all functions have completed. If you only provide the first + * argument, `fns`, then it will return a function which lets you pass in the + * arguments as if it were a single function call. If more arguments are + * provided, `callback` is required while `args` is still optional. The results + * for each of the applied async functions are passed to the final callback + * as an array. + * + * @name applyEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s + * to all call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - Returns a function that takes no args other than + * an optional callback, that is the result of applying the `args` to each + * of the functions. + * @example + * + * const appliedFn = async.applyEach([enableSearch, updateSchema], 'bucket') + * + * appliedFn((err, results) => { + * // results[0] is the results for `enableSearch` + * // results[1] is the results for `updateSchema` + * }); + * + * // partial application example: + * async.each( + * buckets, + * async (bucket) => async.applyEach([enableSearch, updateSchema], bucket)(), + * callback + * ); + */ + var applyEach = applyEach$1(map$1); + + /** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time. + * + * @name eachOfSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ + function eachOfSeries(coll, iteratee, callback) { + return eachOfLimit$1(coll, 1, iteratee, callback) + } + var eachOfSeries$1 = awaitify(eachOfSeries, 3); + + /** + * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time. + * + * @name mapSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ + function mapSeries (coll, iteratee, callback) { + return _asyncMap(eachOfSeries$1, coll, iteratee, callback) + } + var mapSeries$1 = awaitify(mapSeries, 3); + + /** + * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time. + * + * @name applyEachSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.applyEach]{@link module:ControlFlow.applyEach} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - A function, that when called, is the result of + * appling the `args` to the list of functions. It takes no args, other than + * a callback. + */ + var applyEachSeries = applyEach$1(mapSeries$1); + + const PROMISE_SYMBOL = Symbol('promiseCallback'); + + function promiseCallback () { + let resolve, reject; + function callback (err, ...args) { + if (err) return reject(err) + resolve(args.length > 1 ? args : args[0]); + } + + callback[PROMISE_SYMBOL] = new Promise((res, rej) => { + resolve = res, + reject = rej; + }); + + return callback + } + + /** + * Determines the best order for running the {@link AsyncFunction}s in `tasks`, based on + * their requirements. Each function can optionally depend on other functions + * being completed first, and each function is run as soon as its requirements + * are satisfied. + * + * If any of the {@link AsyncFunction}s pass an error to their callback, the `auto` sequence + * will stop. Further tasks will not execute (so any other functions depending + * on it will not run), and the main `callback` is immediately called with the + * error. + * + * {@link AsyncFunction}s also receive an object containing the results of functions which + * have completed so far as the first argument, if they have dependencies. If a + * task function has no dependencies, it will only be passed a callback. + * + * @name auto + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object} tasks - An object. Each of its properties is either a + * function or an array of requirements, with the {@link AsyncFunction} itself the last item + * in the array. The object's key of a property serves as the name of the task + * defined by that property, i.e. can be used when specifying requirements for + * other tasks. The function receives one or two arguments: + * * a `results` object, containing the results of the previously executed + * functions, only passed if the task has any dependencies, + * * a `callback(err, result)` function, which must be called when finished, + * passing an `error` (which can be `null`) and the result of the function's + * execution. + * @param {number} [concurrency=Infinity] - An optional `integer` for + * determining the maximum number of tasks that can be run in parallel. By + * default, as many as possible. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback. Results are always returned; however, if an + * error occurs, no further `tasks` will be performed, and the results object + * will only contain partial results. Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * @example + * + * //Using Callbacks + * async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }, function(err, results) { + * if (err) { + * console.log('err = ', err); + * } + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }); + * + * //Using Promises + * async.auto({ + * get_data: function(callback) { + * console.log('in get_data'); + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * console.log('in make_folder'); + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }).then(results => { + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }).catch(err => { + * console.log('err = ', err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }); + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function auto(tasks, concurrency, callback) { + if (typeof concurrency !== 'number') { + // concurrency is optional, shift the args. + callback = concurrency; + concurrency = null; + } + callback = once(callback || promiseCallback()); + var numTasks = Object.keys(tasks).length; + if (!numTasks) { + return callback(null); + } + if (!concurrency) { + concurrency = numTasks; + } + + var results = {}; + var runningTasks = 0; + var canceled = false; + var hasError = false; + + var listeners = Object.create(null); + + var readyTasks = []; + + // for cycle detection: + var readyToCheck = []; // tasks that have been identified as reachable + // without the possibility of returning to an ancestor task + var uncheckedDependencies = {}; + + Object.keys(tasks).forEach(key => { + var task = tasks[key]; + if (!Array.isArray(task)) { + // no dependencies + enqueueTask(key, [task]); + readyToCheck.push(key); + return; + } + + var dependencies = task.slice(0, task.length - 1); + var remainingDependencies = dependencies.length; + if (remainingDependencies === 0) { + enqueueTask(key, task); + readyToCheck.push(key); + return; + } + uncheckedDependencies[key] = remainingDependencies; + + dependencies.forEach(dependencyName => { + if (!tasks[dependencyName]) { + throw new Error('async.auto task `' + key + + '` has a non-existent dependency `' + + dependencyName + '` in ' + + dependencies.join(', ')); + } + addListener(dependencyName, () => { + remainingDependencies--; + if (remainingDependencies === 0) { + enqueueTask(key, task); + } + }); + }); + }); + + checkForDeadlocks(); + processQueue(); + + function enqueueTask(key, task) { + readyTasks.push(() => runTask(key, task)); + } + + function processQueue() { + if (canceled) return + if (readyTasks.length === 0 && runningTasks === 0) { + return callback(null, results); + } + while(readyTasks.length && runningTasks < concurrency) { + var run = readyTasks.shift(); + run(); + } + + } + + function addListener(taskName, fn) { + var taskListeners = listeners[taskName]; + if (!taskListeners) { + taskListeners = listeners[taskName] = []; + } + + taskListeners.push(fn); + } + + function taskComplete(taskName) { + var taskListeners = listeners[taskName] || []; + taskListeners.forEach(fn => fn()); + processQueue(); + } + + + function runTask(key, task) { + if (hasError) return; + + var taskCallback = onlyOnce((err, ...result) => { + runningTasks--; + if (err === false) { + canceled = true; + return + } + if (result.length < 2) { + [result] = result; + } + if (err) { + var safeResults = {}; + Object.keys(results).forEach(rkey => { + safeResults[rkey] = results[rkey]; + }); + safeResults[key] = result; + hasError = true; + listeners = Object.create(null); + if (canceled) return + callback(err, safeResults); + } else { + results[key] = result; + taskComplete(key); + } + }); + + runningTasks++; + var taskFn = wrapAsync(task[task.length - 1]); + if (task.length > 1) { + taskFn(results, taskCallback); + } else { + taskFn(taskCallback); + } + } + + function checkForDeadlocks() { + // Kahn's algorithm + // https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm + // http://connalle.blogspot.com/2013/10/topological-sortingkahn-algorithm.html + var currentTask; + var counter = 0; + while (readyToCheck.length) { + currentTask = readyToCheck.pop(); + counter++; + getDependents(currentTask).forEach(dependent => { + if (--uncheckedDependencies[dependent] === 0) { + readyToCheck.push(dependent); + } + }); + } + + if (counter !== numTasks) { + throw new Error( + 'async.auto cannot execute tasks due to a recursive dependency' + ); + } + } + + function getDependents(taskName) { + var result = []; + Object.keys(tasks).forEach(key => { + const task = tasks[key]; + if (Array.isArray(task) && task.indexOf(taskName) >= 0) { + result.push(key); + } + }); + return result; + } + + return callback[PROMISE_SYMBOL] + } + + var FN_ARGS = /^(?:async\s)?(?:function)?\s*(?:\w+\s*)?\(([^)]+)\)(?:\s*{)/; + var ARROW_FN_ARGS = /^(?:async\s)?\s*(?:\(\s*)?((?:[^)=\s]\s*)*)(?:\)\s*)?=>/; + var FN_ARG_SPLIT = /,/; + var FN_ARG = /(=.+)?(\s*)$/; + + function stripComments(string) { + let stripped = ''; + let index = 0; + let endBlockComment = string.indexOf('*/'); + while (index < string.length) { + if (string[index] === '/' && string[index+1] === '/') { + // inline comment + let endIndex = string.indexOf('\n', index); + index = (endIndex === -1) ? string.length : endIndex; + } else if ((endBlockComment !== -1) && (string[index] === '/') && (string[index+1] === '*')) { + // block comment + let endIndex = string.indexOf('*/', index); + if (endIndex !== -1) { + index = endIndex + 2; + endBlockComment = string.indexOf('*/', index); + } else { + stripped += string[index]; + index++; + } + } else { + stripped += string[index]; + index++; + } + } + return stripped; + } + + function parseParams(func) { + const src = stripComments(func.toString()); + let match = src.match(FN_ARGS); + if (!match) { + match = src.match(ARROW_FN_ARGS); + } + if (!match) throw new Error('could not parse args in autoInject\nSource:\n' + src) + let [, args] = match; + return args + .replace(/\s/g, '') + .split(FN_ARG_SPLIT) + .map((arg) => arg.replace(FN_ARG, '').trim()); + } + + /** + * A dependency-injected version of the [async.auto]{@link module:ControlFlow.auto} function. Dependent + * tasks are specified as parameters to the function, after the usual callback + * parameter, with the parameter names matching the names of the tasks it + * depends on. This can provide even more readable task graphs which can be + * easier to maintain. + * + * If a final callback is specified, the task results are similarly injected, + * specified as named parameters after the initial error parameter. + * + * The autoInject function is purely syntactic sugar and its semantics are + * otherwise equivalent to [async.auto]{@link module:ControlFlow.auto}. + * + * @name autoInject + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.auto]{@link module:ControlFlow.auto} + * @category Control Flow + * @param {Object} tasks - An object, each of whose properties is an {@link AsyncFunction} of + * the form 'func([dependencies...], callback). The object's key of a property + * serves as the name of the task defined by that property, i.e. can be used + * when specifying requirements for other tasks. + * * The `callback` parameter is a `callback(err, result)` which must be called + * when finished, passing an `error` (which can be `null`) and the result of + * the function's execution. The remaining parameters name other tasks on + * which the task is dependent, and the results from those tasks are the + * arguments of those parameters. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback, and a `results` object with any completed + * task results, similar to `auto`. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // The example from `auto` can be rewritten as follows: + * async.autoInject({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: function(get_data, make_folder, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }, + * email_link: function(write_file, callback) { + * // once the file is written let's email a link to it... + * // write_file contains the filename returned by write_file. + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * } + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + * + * // If you are using a JS minifier that mangles parameter names, `autoInject` + * // will not work with plain functions, since the parameter names will be + * // collapsed to a single letter identifier. To work around this, you can + * // explicitly specify the names of the parameters your task function needs + * // in an array, similar to Angular.js dependency injection. + * + * // This still has an advantage over plain `auto`, since the results a task + * // depends on are still spread into arguments. + * async.autoInject({ + * //... + * write_file: ['get_data', 'make_folder', function(get_data, make_folder, callback) { + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(write_file, callback) { + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * }] + * //... + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + */ + function autoInject(tasks, callback) { + var newTasks = {}; + + Object.keys(tasks).forEach(key => { + var taskFn = tasks[key]; + var params; + var fnIsAsync = isAsync(taskFn); + var hasNoDeps = + (!fnIsAsync && taskFn.length === 1) || + (fnIsAsync && taskFn.length === 0); + + if (Array.isArray(taskFn)) { + params = [...taskFn]; + taskFn = params.pop(); + + newTasks[key] = params.concat(params.length > 0 ? newTask : taskFn); + } else if (hasNoDeps) { + // no dependencies, use the function as-is + newTasks[key] = taskFn; + } else { + params = parseParams(taskFn); + if ((taskFn.length === 0 && !fnIsAsync) && params.length === 0) { + throw new Error("autoInject task functions require explicit parameters."); + } + + // remove callback param + if (!fnIsAsync) params.pop(); + + newTasks[key] = params.concat(newTask); + } + + function newTask(results, taskCb) { + var newArgs = params.map(name => results[name]); + newArgs.push(taskCb); + wrapAsync(taskFn)(...newArgs); + } + }); + + return auto(newTasks, callback); + } + + // Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation + // used for queues. This implementation assumes that the node provided by the user can be modified + // to adjust the next and last properties. We implement only the minimal functionality + // for queue support. + class DLL { + constructor() { + this.head = this.tail = null; + this.length = 0; + } + + removeLink(node) { + if (node.prev) node.prev.next = node.next; + else this.head = node.next; + if (node.next) node.next.prev = node.prev; + else this.tail = node.prev; + + node.prev = node.next = null; + this.length -= 1; + return node; + } + + empty () { + while(this.head) this.shift(); + return this; + } + + insertAfter(node, newNode) { + newNode.prev = node; + newNode.next = node.next; + if (node.next) node.next.prev = newNode; + else this.tail = newNode; + node.next = newNode; + this.length += 1; + } + + insertBefore(node, newNode) { + newNode.prev = node.prev; + newNode.next = node; + if (node.prev) node.prev.next = newNode; + else this.head = newNode; + node.prev = newNode; + this.length += 1; + } + + unshift(node) { + if (this.head) this.insertBefore(this.head, node); + else setInitial(this, node); + } + + push(node) { + if (this.tail) this.insertAfter(this.tail, node); + else setInitial(this, node); + } + + shift() { + return this.head && this.removeLink(this.head); + } + + pop() { + return this.tail && this.removeLink(this.tail); + } + + toArray() { + return [...this] + } + + *[Symbol.iterator] () { + var cur = this.head; + while (cur) { + yield cur.data; + cur = cur.next; + } + } + + remove (testFn) { + var curr = this.head; + while(curr) { + var {next} = curr; + if (testFn(curr)) { + this.removeLink(curr); + } + curr = next; + } + return this; + } + } + + function setInitial(dll, node) { + dll.length = 1; + dll.head = dll.tail = node; + } + + function queue$1(worker, concurrency, payload) { + if (concurrency == null) { + concurrency = 1; + } + else if(concurrency === 0) { + throw new RangeError('Concurrency must not be zero'); + } + + var _worker = wrapAsync(worker); + var numRunning = 0; + var workersList = []; + const events = { + error: [], + drain: [], + saturated: [], + unsaturated: [], + empty: [] + }; + + function on (event, handler) { + events[event].push(handler); + } + + function once (event, handler) { + const handleAndRemove = (...args) => { + off(event, handleAndRemove); + handler(...args); + }; + events[event].push(handleAndRemove); + } + + function off (event, handler) { + if (!event) return Object.keys(events).forEach(ev => events[ev] = []) + if (!handler) return events[event] = [] + events[event] = events[event].filter(ev => ev !== handler); + } + + function trigger (event, ...args) { + events[event].forEach(handler => handler(...args)); + } + + var processingScheduled = false; + function _insert(data, insertAtFront, rejectOnError, callback) { + if (callback != null && typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + + var res, rej; + function promiseCallback (err, ...args) { + // we don't care about the error, let the global error handler + // deal with it + if (err) return rejectOnError ? rej(err) : res() + if (args.length <= 1) return res(args[0]) + res(args); + } + + var item = q._createTaskItem( + data, + rejectOnError ? promiseCallback : + (callback || promiseCallback) + ); + + if (insertAtFront) { + q._tasks.unshift(item); + } else { + q._tasks.push(item); + } + + if (!processingScheduled) { + processingScheduled = true; + setImmediate$1(() => { + processingScheduled = false; + q.process(); + }); + } + + if (rejectOnError || !callback) { + return new Promise((resolve, reject) => { + res = resolve; + rej = reject; + }) + } + } + + function _createCB(tasks) { + return function (err, ...args) { + numRunning -= 1; + + for (var i = 0, l = tasks.length; i < l; i++) { + var task = tasks[i]; + + var index = workersList.indexOf(task); + if (index === 0) { + workersList.shift(); + } else if (index > 0) { + workersList.splice(index, 1); + } + + task.callback(err, ...args); + + if (err != null) { + trigger('error', err, task.data); + } + } + + if (numRunning <= (q.concurrency - q.buffer) ) { + trigger('unsaturated'); + } + + if (q.idle()) { + trigger('drain'); + } + q.process(); + }; + } + + function _maybeDrain(data) { + if (data.length === 0 && q.idle()) { + // call drain immediately if there are no tasks + setImmediate$1(() => trigger('drain')); + return true + } + return false + } + + const eventMethod = (name) => (handler) => { + if (!handler) { + return new Promise((resolve, reject) => { + once(name, (err, data) => { + if (err) return reject(err) + resolve(data); + }); + }) + } + off(name); + on(name, handler); + + }; + + var isProcessing = false; + var q = { + _tasks: new DLL(), + _createTaskItem (data, callback) { + return { + data, + callback + }; + }, + *[Symbol.iterator] () { + yield* q._tasks[Symbol.iterator](); + }, + concurrency, + payload, + buffer: concurrency / 4, + started: false, + paused: false, + push (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, false, false, callback)) + } + return _insert(data, false, false, callback); + }, + pushAsync (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, false, true, callback)) + } + return _insert(data, false, true, callback); + }, + kill () { + off(); + q._tasks.empty(); + }, + unshift (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, true, false, callback)) + } + return _insert(data, true, false, callback); + }, + unshiftAsync (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, true, true, callback)) + } + return _insert(data, true, true, callback); + }, + remove (testFn) { + q._tasks.remove(testFn); + }, + process () { + // Avoid trying to start too many processing operations. This can occur + // when callbacks resolve synchronously (#1267). + if (isProcessing) { + return; + } + isProcessing = true; + while(!q.paused && numRunning < q.concurrency && q._tasks.length){ + var tasks = [], data = []; + var l = q._tasks.length; + if (q.payload) l = Math.min(l, q.payload); + for (var i = 0; i < l; i++) { + var node = q._tasks.shift(); + tasks.push(node); + workersList.push(node); + data.push(node.data); + } + + numRunning += 1; + + if (q._tasks.length === 0) { + trigger('empty'); + } + + if (numRunning === q.concurrency) { + trigger('saturated'); + } + + var cb = onlyOnce(_createCB(tasks)); + _worker(data, cb); + } + isProcessing = false; + }, + length () { + return q._tasks.length; + }, + running () { + return numRunning; + }, + workersList () { + return workersList; + }, + idle() { + return q._tasks.length + numRunning === 0; + }, + pause () { + q.paused = true; + }, + resume () { + if (q.paused === false) { return; } + q.paused = false; + setImmediate$1(q.process); + } + }; + // define these as fixed properties, so people get useful errors when updating + Object.defineProperties(q, { + saturated: { + writable: false, + value: eventMethod('saturated') + }, + unsaturated: { + writable: false, + value: eventMethod('unsaturated') + }, + empty: { + writable: false, + value: eventMethod('empty') + }, + drain: { + writable: false, + value: eventMethod('drain') + }, + error: { + writable: false, + value: eventMethod('error') + }, + }); + return q; + } + + /** + * Creates a `cargo` object with the specified payload. Tasks added to the + * cargo will be processed altogether (up to the `payload` limit). If the + * `worker` is in progress, the task is queued until it becomes available. Once + * the `worker` has completed some tasks, each callback of those tasks is + * called. Check out [these](https://camo.githubusercontent.com/6bbd36f4cf5b35a0f11a96dcd2e97711ffc2fb37/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130382f62626330636662302d356632392d313165322d393734662d3333393763363464633835382e676966) [animations](https://camo.githubusercontent.com/f4810e00e1c5f5f8addbe3e9f49064fd5d102699/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130312f38346339323036362d356632392d313165322d383134662d3964336430323431336266642e676966) + * for how `cargo` and `queue` work. + * + * While [`queue`]{@link module:ControlFlow.queue} passes only one task to one of a group of workers + * at a time, cargo passes an array of tasks to a single worker, repeating + * when the worker is finished. + * + * @name cargo + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {AsyncFunction} worker - An asynchronous function for processing an array + * of queued tasks. Invoked with `(tasks, callback)`. + * @param {number} [payload=Infinity] - An optional `integer` for determining + * how many tasks should be processed per round; if omitted, the default is + * unlimited. + * @returns {module:ControlFlow.QueueObject} A cargo object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the cargo and inner queue. + * @example + * + * // create a cargo object with payload 2 + * var cargo = async.cargo(function(tasks, callback) { + * for (var i=0; i { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.reduce(fileList, 0, getFileSizeInBytes); + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.reduce(withMissingFileList, 0, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ + function reduce(coll, memo, iteratee, callback) { + callback = once(callback); + var _iteratee = wrapAsync(iteratee); + return eachOfSeries$1(coll, (x, i, iterCb) => { + _iteratee(memo, x, (err, v) => { + memo = v; + iterCb(err); + }); + }, err => callback(err, memo)); + } + var reduce$1 = awaitify(reduce, 4); + + /** + * Version of the compose function that is more natural to read. Each function + * consumes the return value of the previous function. It is the equivalent of + * [compose]{@link module:ControlFlow.compose} with the arguments reversed. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name seq + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.compose]{@link module:ControlFlow.compose} + * @category Control Flow + * @param {...AsyncFunction} functions - the asynchronous functions to compose + * @returns {Function} a function that composes the `functions` in order + * @example + * + * // Requires lodash (or underscore), express3 and dresende's orm2. + * // Part of an app, that fetches cats of the logged user. + * // This example uses `seq` function to avoid overnesting and error + * // handling clutter. + * app.get('/cats', function(request, response) { + * var User = request.models.User; + * async.seq( + * User.get.bind(User), // 'User.get' has signature (id, callback(err, data)) + * function(user, fn) { + * user.getCats(fn); // 'getCats' has signature (callback(err, data)) + * } + * )(req.session.user_id, function (err, cats) { + * if (err) { + * console.error(err); + * response.json({ status: 'error', message: err.message }); + * } else { + * response.json({ status: 'ok', message: 'Cats found', data: cats }); + * } + * }); + * }); + */ + function seq(...functions) { + var _functions = functions.map(wrapAsync); + return function (...args) { + var that = this; + + var cb = args[args.length - 1]; + if (typeof cb == 'function') { + args.pop(); + } else { + cb = promiseCallback(); + } + + reduce$1(_functions, args, (newargs, fn, iterCb) => { + fn.apply(that, newargs.concat((err, ...nextargs) => { + iterCb(err, nextargs); + })); + }, + (err, results) => cb(err, ...results)); + + return cb[PROMISE_SYMBOL] + }; + } + + /** + * Creates a function which is a composition of the passed asynchronous + * functions. Each function consumes the return value of the function that + * follows. Composing functions `f()`, `g()`, and `h()` would produce the result + * of `f(g(h()))`, only this version uses callbacks to obtain the return values. + * + * If the last argument to the composed function is not a function, a promise + * is returned when you call it. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name compose + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {...AsyncFunction} functions - the asynchronous functions to compose + * @returns {Function} an asynchronous function that is the composed + * asynchronous `functions` + * @example + * + * function add1(n, callback) { + * setTimeout(function () { + * callback(null, n + 1); + * }, 10); + * } + * + * function mul3(n, callback) { + * setTimeout(function () { + * callback(null, n * 3); + * }, 10); + * } + * + * var add1mul3 = async.compose(mul3, add1); + * add1mul3(4, function (err, result) { + * // result now equals 15 + * }); + */ + function compose(...args) { + return seq(...args.reverse()); + } + + /** + * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time. + * + * @name mapLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ + function mapLimit (coll, limit, iteratee, callback) { + return _asyncMap(eachOfLimit$2(limit), coll, iteratee, callback) + } + var mapLimit$1 = awaitify(mapLimit, 4); + + /** + * The same as [`concat`]{@link module:Collections.concat} but runs a maximum of `limit` async operations at a time. + * + * @name concatLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapLimit + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ + function concatLimit(coll, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(coll, limit, (val, iterCb) => { + _iteratee(val, (err, ...args) => { + if (err) return iterCb(err); + return iterCb(err, args); + }); + }, (err, mapResults) => { + var result = []; + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + result = result.concat(...mapResults[i]); + } + } + + return callback(err, result); + }); + } + var concatLimit$1 = awaitify(concatLimit, 4); + + /** + * Applies `iteratee` to each item in `coll`, concatenating the results. Returns + * the concatenated list. The `iteratee`s are called in parallel, and the + * results are concatenated as they return. The results array will be returned in + * the original order of `coll` passed to the `iteratee` function. + * + * @name concat + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @alias flatMap + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * let directoryList = ['dir1','dir2','dir3']; + * let withMissingDirectoryList = ['dir1','dir2','dir3', 'dir4']; + * + * // Using callbacks + * async.concat(directoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.concat(directoryList, fs.readdir) + * .then(results => { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir) + * .then(results => { + * console.log(results); + * }).catch(err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.concat(directoryList, fs.readdir); + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.concat(withMissingDirectoryList, fs.readdir); + * console.log(results); + * } catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } + * } + * + */ + function concat(coll, iteratee, callback) { + return concatLimit$1(coll, Infinity, iteratee, callback) + } + var concat$1 = awaitify(concat, 3); + + /** + * The same as [`concat`]{@link module:Collections.concat} but runs only a single async operation at a time. + * + * @name concatSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapSeries + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`. + * The iteratee should complete with an array an array of results. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ + function concatSeries(coll, iteratee, callback) { + return concatLimit$1(coll, 1, iteratee, callback) + } + var concatSeries$1 = awaitify(concatSeries, 3); + + /** + * Returns a function that when called, calls-back with the values provided. + * Useful as the first function in a [`waterfall`]{@link module:ControlFlow.waterfall}, or for plugging values in to + * [`auto`]{@link module:ControlFlow.auto}. + * + * @name constant + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {...*} arguments... - Any number of arguments to automatically invoke + * callback with. + * @returns {AsyncFunction} Returns a function that when invoked, automatically + * invokes the callback with the previous given arguments. + * @example + * + * async.waterfall([ + * async.constant(42), + * function (value, next) { + * // value === 42 + * }, + * //... + * ], callback); + * + * async.waterfall([ + * async.constant(filename, "utf8"), + * fs.readFile, + * function (fileData, next) { + * //... + * } + * //... + * ], callback); + * + * async.auto({ + * hostname: async.constant("https://server.net/"), + * port: findFreePort, + * launchServer: ["hostname", "port", function (options, cb) { + * startServer(options, cb); + * }], + * //... + * }, callback); + */ + function constant$1(...args) { + return function (...ignoredArgs/*, callback*/) { + var callback = ignoredArgs.pop(); + return callback(null, ...args); + }; + } + + function _createTester(check, getResult) { + return (eachfn, arr, _iteratee, cb) => { + var testPassed = false; + var testResult; + const iteratee = wrapAsync(_iteratee); + eachfn(arr, (value, _, callback) => { + iteratee(value, (err, result) => { + if (err || err === false) return callback(err); + + if (check(result) && !testResult) { + testPassed = true; + testResult = getResult(true, value); + return callback(null, breakLoop); + } + callback(); + }); + }, err => { + if (err) return cb(err); + cb(null, testPassed ? testResult : getResult(false)); + }); + }; + } + + /** + * Returns the first value in `coll` that passes an async truth test. The + * `iteratee` is applied in parallel, meaning the first iteratee to return + * `true` will fire the detect `callback` with that result. That means the + * result might not be the first item in the original `coll` (in terms of order) + * that passes the test. + + * If order within the original `coll` is important, then look at + * [`detectSeries`]{@link module:Collections.detectSeries}. + * + * @name detect + * @static + * @memberOf module:Collections + * @method + * @alias find + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * } + *); + * + * // Using Promises + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists) + * .then(result => { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists); + * console.log(result); + * // dir1/file1.txt + * // result now equals the file in the list that exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function detect(coll, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOf$1, coll, iteratee, callback) + } + var detect$1 = awaitify(detect, 3); + + /** + * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a + * time. + * + * @name detectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findLimit + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ + function detectLimit(coll, limit, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOfLimit$2(limit), coll, iteratee, callback) + } + var detectLimit$1 = awaitify(detectLimit, 4); + + /** + * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time. + * + * @name detectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findSeries + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ + function detectSeries(coll, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOfLimit$2(1), coll, iteratee, callback) + } + + var detectSeries$1 = awaitify(detectSeries, 3); + + function consoleFunc(name) { + return (fn, ...args) => wrapAsync(fn)(...args, (err, ...resultArgs) => { + /* istanbul ignore else */ + if (typeof console === 'object') { + /* istanbul ignore else */ + if (err) { + /* istanbul ignore else */ + if (console.error) { + console.error(err); + } + } else if (console[name]) { /* istanbul ignore else */ + resultArgs.forEach(x => console[name](x)); + } + } + }) + } + + /** + * Logs the result of an [`async` function]{@link AsyncFunction} to the + * `console` using `console.dir` to display the properties of the resulting object. + * Only works in Node.js or in browsers that support `console.dir` and + * `console.error` (such as FF and Chrome). + * If multiple arguments are returned from the async function, + * `console.dir` is called on each argument in order. + * + * @name dir + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, {hello: name}); + * }, 1000); + * }; + * + * // in the node repl + * node> async.dir(hello, 'world'); + * {hello: 'world'} + */ + var dir = consoleFunc('dir'); + + /** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - A function which is called each time `test` + * passes. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ + function doWhilst(iteratee, test, callback) { + callback = onlyOnce(callback); + var _fn = wrapAsync(iteratee); + var _test = wrapAsync(test); + var results; + + function next(err, ...args) { + if (err) return callback(err); + if (err === false) return; + results = args; + _test(...args, check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return check(null, true); + } + + var doWhilst$1 = awaitify(doWhilst, 3); + + /** + * Like ['doWhilst']{@link module:ControlFlow.doWhilst}, except the `test` is inverted. Note the + * argument ordering differs from `until`. + * + * @name doUntil + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.doWhilst]{@link module:ControlFlow.doWhilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee` + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ + function doUntil(iteratee, test, callback) { + const _test = wrapAsync(test); + return doWhilst$1(iteratee, (...args) => { + const cb = args.pop(); + _test(...args, (err, truth) => cb (err, !truth)); + }, callback); + } + + function _withoutIndex(iteratee) { + return (value, index, callback) => iteratee(value, callback); + } + + /** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to + * each item in `coll`. Invoked with (item, callback). + * The array index is not passed to the iteratee. + * If you need the index, use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = [ 'dir1/file2.txt', 'dir2/file3.txt', 'dir/file5.txt']; + * const withMissingFileList = ['dir1/file1.txt', 'dir4/file2.txt']; + * + * // asynchronous function that deletes a file + * const deleteFile = function(file, callback) { + * fs.unlink(file, callback); + * }; + * + * // Using callbacks + * async.each(fileList, deleteFile, function(err) { + * if( err ) { + * console.log(err); + * } else { + * console.log('All files have been deleted successfully'); + * } + * }); + * + * // Error Handling + * async.each(withMissingFileList, deleteFile, function(err){ + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using Promises + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using async/await + * async () => { + * try { + * await async.each(files, deleteFile); + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * await async.each(withMissingFileList, deleteFile); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * } + * } + * + */ + function eachLimit$2(coll, iteratee, callback) { + return eachOf$1(coll, _withoutIndex(wrapAsync(iteratee)), callback); + } + + var each = awaitify(eachLimit$2, 3); + + /** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfLimit`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ + function eachLimit(coll, limit, iteratee, callback) { + return eachOfLimit$2(limit)(coll, _withoutIndex(wrapAsync(iteratee)), callback); + } + var eachLimit$1 = awaitify(eachLimit, 4); + + /** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * Note, that unlike [`each`]{@link module:Collections.each}, this function applies iteratee to each item + * in series and therefore the iteratee functions will complete in order. + + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfSeries`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ + function eachSeries(coll, iteratee, callback) { + return eachLimit$1(coll, 1, iteratee, callback) + } + var eachSeries$1 = awaitify(eachSeries, 3); + + /** + * Wrap an async function and ensure it calls its callback on a later tick of + * the event loop. If the function already calls its callback on a next tick, + * no extra deferral is added. This is useful for preventing stack overflows + * (`RangeError: Maximum call stack size exceeded`) and generally keeping + * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) + * contained. ES2017 `async` functions are returned as-is -- they are immune + * to Zalgo's corrupting influences, as they always resolve on a later tick. + * + * @name ensureAsync + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - an async function, one that expects a node-style + * callback as its last argument. + * @returns {AsyncFunction} Returns a wrapped function with the exact same call + * signature as the function passed in. + * @example + * + * function sometimesAsync(arg, callback) { + * if (cache[arg]) { + * return callback(null, cache[arg]); // this would be synchronous!! + * } else { + * doSomeIO(arg, callback); // this IO would be asynchronous + * } + * } + * + * // this has a risk of stack overflows if many results are cached in a row + * async.mapSeries(args, sometimesAsync, done); + * + * // this will defer sometimesAsync's callback if necessary, + * // preventing stack overflows + * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); + */ + function ensureAsync(fn) { + if (isAsync(fn)) return fn; + return function (...args/*, callback*/) { + var callback = args.pop(); + var sync = true; + args.push((...innerArgs) => { + if (sync) { + setImmediate$1(() => callback(...innerArgs)); + } else { + callback(...innerArgs); + } + }); + fn.apply(this, args); + sync = false; + }; + } + + /** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file5.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.every(fileList, fileExists, function(err, result) { + * console.log(result); + * // true + * // result is true since every file exists + * }); + * + * async.every(withMissingFileList, fileExists, function(err, result) { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }); + * + * // Using Promises + * async.every(fileList, fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.every(withMissingFileList, fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.every(fileList, fileExists); + * console.log(result); + * // true + * // result is true since every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.every(withMissingFileList, fileExists); + * console.log(result); + * // false + * // result is false since NOT every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function every(coll, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOf$1, coll, iteratee, callback) + } + var every$1 = awaitify(every, 3); + + /** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ + function everyLimit(coll, limit, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOfLimit$2(limit), coll, iteratee, callback) + } + var everyLimit$1 = awaitify(everyLimit, 4); + + /** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in series. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ + function everySeries(coll, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOfSeries$1, coll, iteratee, callback) + } + var everySeries$1 = awaitify(everySeries, 3); + + function filterArray(eachfn, arr, iteratee, callback) { + var truthValues = new Array(arr.length); + eachfn(arr, (x, index, iterCb) => { + iteratee(x, (err, v) => { + truthValues[index] = !!v; + iterCb(err); + }); + }, err => { + if (err) return callback(err); + var results = []; + for (var i = 0; i < arr.length; i++) { + if (truthValues[i]) results.push(arr[i]); + } + callback(null, results); + }); + } + + function filterGeneric(eachfn, coll, iteratee, callback) { + var results = []; + eachfn(coll, (x, index, iterCb) => { + iteratee(x, (err, v) => { + if (err) return iterCb(err); + if (v) { + results.push({index, value: x}); + } + iterCb(err); + }); + }, err => { + if (err) return callback(err); + callback(null, results + .sort((a, b) => a.index - b.index) + .map(v => v.value)); + }); + } + + function _filter(eachfn, coll, iteratee, callback) { + var filter = isArrayLike(coll) ? filterArray : filterGeneric; + return filter(eachfn, coll, wrapAsync(iteratee), callback); + } + + /** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const files = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.filter(files, fileExists, function(err, results) { + * if(err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * }); + * + * // Using Promises + * async.filter(files, fileExists) + * .then(results => { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.filter(files, fileExists); + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function filter (coll, iteratee, callback) { + return _filter(eachOf$1, coll, iteratee, callback) + } + var filter$1 = awaitify(filter, 3); + + /** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + */ + function filterLimit (coll, limit, iteratee, callback) { + return _filter(eachOfLimit$2(limit), coll, iteratee, callback) + } + var filterLimit$1 = awaitify(filterLimit, 4); + + /** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + * @returns {Promise} a promise, if no callback provided + */ + function filterSeries (coll, iteratee, callback) { + return _filter(eachOfSeries$1, coll, iteratee, callback) + } + var filterSeries$1 = awaitify(filterSeries, 3); + + /** + * Calls the asynchronous function `fn` with a callback parameter that allows it + * to call itself again, in series, indefinitely. + + * If an error is passed to the callback then `errback` is called with the + * error, and execution stops, otherwise it will never be called. + * + * @name forever + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} fn - an async function to call repeatedly. + * Invoked with (next). + * @param {Function} [errback] - when `fn` passes an error to it's callback, + * this function will be called, and execution stops. Invoked with (err). + * @returns {Promise} a promise that rejects if an error occurs and an errback + * is not passed + * @example + * + * async.forever( + * function(next) { + * // next is suitable for passing to things that need a callback(err [, whatever]); + * // it will result in this function being called again. + * }, + * function(err) { + * // if next is called with a value in its first parameter, it will appear + * // in here as 'err', and execution will stop. + * } + * ); + */ + function forever(fn, errback) { + var done = onlyOnce(errback); + var task = wrapAsync(ensureAsync(fn)); + + function next(err) { + if (err) return done(err); + if (err === false) return; + task(next); + } + return next(); + } + var forever$1 = awaitify(forever, 2); + + /** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs a maximum of `limit` async operations at a time. + * + * @name groupByLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ + function groupByLimit(coll, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(coll, limit, (val, iterCb) => { + _iteratee(val, (err, key) => { + if (err) return iterCb(err); + return iterCb(err, {key, val}); + }); + }, (err, mapResults) => { + var result = {}; + // from MDN, handle object having an `hasOwnProperty` prop + var {hasOwnProperty} = Object.prototype; + + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + var {key} = mapResults[i]; + var {val} = mapResults[i]; + + if (hasOwnProperty.call(result, key)) { + result[key].push(val); + } else { + result[key] = [val]; + } + } + } + + return callback(err, result); + }); + } + + var groupByLimit$1 = awaitify(groupByLimit, 4); + + /** + * Returns a new object, where each value corresponds to an array of items, from + * `coll`, that returned the corresponding key. That is, the keys of the object + * correspond to the values passed to the `iteratee` callback. + * + * Note: Since this function applies the `iteratee` to each item in parallel, + * there is no guarantee that the `iteratee` functions will complete in order. + * However, the values for each key in the `result` will be in the same order as + * the original `coll`. For Objects, the values will roughly be in the order of + * the original Objects' keys (but this can vary across JavaScript engines). + * + * @name groupBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const files = ['dir1/file1.txt','dir2','dir4'] + * + * // asynchronous function that detects file type as none, file, or directory + * function detectFile(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(null, 'none'); + * } + * callback(null, stat.isDirectory() ? 'directory' : 'file'); + * }); + * } + * + * //Using callbacks + * async.groupBy(files, detectFile, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * }); + * + * // Using Promises + * async.groupBy(files, detectFile) + * .then( result => { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.groupBy(files, detectFile); + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function groupBy (coll, iteratee, callback) { + return groupByLimit$1(coll, Infinity, iteratee, callback) + } + + /** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs only a single async operation at a time. + * + * @name groupBySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whose + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ + function groupBySeries (coll, iteratee, callback) { + return groupByLimit$1(coll, 1, iteratee, callback) + } + + /** + * Logs the result of an `async` function to the `console`. Only works in + * Node.js or in browsers that support `console.log` and `console.error` (such + * as FF and Chrome). If multiple arguments are returned from the async + * function, `console.log` is called on each argument in order. + * + * @name log + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, 'hello ' + name); + * }, 1000); + * }; + * + * // in the node repl + * node> async.log(hello, 'world'); + * 'hello world' + */ + var log = consoleFunc('log'); + + /** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs a maximum of `limit` async operations at a + * time. + * + * @name mapValuesLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ + function mapValuesLimit(obj, limit, iteratee, callback) { + callback = once(callback); + var newObj = {}; + var _iteratee = wrapAsync(iteratee); + return eachOfLimit$2(limit)(obj, (val, key, next) => { + _iteratee(val, key, (err, result) => { + if (err) return next(err); + newObj[key] = result; + next(err); + }); + }, err => callback(err, newObj)); + } + + var mapValuesLimit$1 = awaitify(mapValuesLimit, 4); + + /** + * A relative of [`map`]{@link module:Collections.map}, designed for use with objects. + * + * Produces a new Object by mapping each value of `obj` through the `iteratee` + * function. The `iteratee` is called each `value` and `key` from `obj` and a + * callback for when it has finished processing. Each of these callbacks takes + * two arguments: an `error`, and the transformed item from `obj`. If `iteratee` + * passes an error to its callback, the main `callback` (for the `mapValues` + * function) is immediately called with the error. + * + * Note, the order of the keys in the result is not guaranteed. The keys will + * be roughly in the order they complete, (but this is very engine-specific) + * + * @name mapValues + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file3.txt' + * }; + * + * const withMissingFileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file4.txt' + * }; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, key, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.mapValues(fileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * }); + * + * // Error handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.mapValues(fileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * }).catch (err => { + * console.log(err); + * }); + * + * // Error Handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch (err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.mapValues(fileMap, getFileSizeInBytes); + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.mapValues(withMissingFileMap, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ + function mapValues(obj, iteratee, callback) { + return mapValuesLimit$1(obj, Infinity, iteratee, callback) + } + + /** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time. + * + * @name mapValuesSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ + function mapValuesSeries(obj, iteratee, callback) { + return mapValuesLimit$1(obj, 1, iteratee, callback) + } + + /** + * Caches the results of an async function. When creating a hash to store + * function results against, the callback is omitted from the hash and an + * optional hash function can be used. + * + * **Note: if the async function errs, the result will not be cached and + * subsequent calls will call the wrapped function.** + * + * If no hash function is specified, the first argument is used as a hash key, + * which may work reasonably if it is a string or a data type that converts to a + * distinct string. Note that objects and arrays will not behave reasonably. + * Neither will cases where the other arguments are significant. In such cases, + * specify your own hash function. + * + * The cache of results is exposed as the `memo` property of the function + * returned by `memoize`. + * + * @name memoize + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function to proxy and cache results from. + * @param {Function} hasher - An optional function for generating a custom hash + * for storing results. It has all the arguments applied to it apart from the + * callback, and must be synchronous. + * @returns {AsyncFunction} a memoized version of `fn` + * @example + * + * var slow_fn = function(name, callback) { + * // do something + * callback(null, result); + * }; + * var fn = async.memoize(slow_fn); + * + * // fn can now be used as if it were slow_fn + * fn('some name', function() { + * // callback + * }); + */ + function memoize(fn, hasher = v => v) { + var memo = Object.create(null); + var queues = Object.create(null); + var _fn = wrapAsync(fn); + var memoized = initialParams((args, callback) => { + var key = hasher(...args); + if (key in memo) { + setImmediate$1(() => callback(null, ...memo[key])); + } else if (key in queues) { + queues[key].push(callback); + } else { + queues[key] = [callback]; + _fn(...args, (err, ...resultArgs) => { + // #1465 don't memoize if an error occurred + if (!err) { + memo[key] = resultArgs; + } + var q = queues[key]; + delete queues[key]; + for (var i = 0, l = q.length; i < l; i++) { + q[i](err, ...resultArgs); + } + }); + } + }); + memoized.memo = memo; + memoized.unmemoized = fn; + return memoized; + } + + /* istanbul ignore file */ + + /** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `process.nextTick`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name nextTick + * @static + * @memberOf module:Utils + * @method + * @see [async.setImmediate]{@link module:Utils.setImmediate} + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ + var _defer; + + if (hasNextTick) { + _defer = process.nextTick; + } else if (hasSetImmediate) { + _defer = setImmediate; + } else { + _defer = fallback; + } + + var nextTick = wrap(_defer); + + var _parallel = awaitify((eachfn, tasks, callback) => { + var results = isArrayLike(tasks) ? [] : {}; + + eachfn(tasks, (task, key, taskCb) => { + wrapAsync(task)((err, ...result) => { + if (result.length < 2) { + [result] = result; + } + results[key] = result; + taskCb(err); + }); + }, err => callback(err, results)); + }, 3); + + /** + * Run the `tasks` collection of functions in parallel, without waiting until + * the previous function has completed. If any of the functions pass an error to + * its callback, the main `callback` is immediately called with the value of the + * error. Once the `tasks` have completed, the results are passed to the final + * `callback` as an array. + * + * **Note:** `parallel` is about kicking-off I/O tasks in parallel, not about + * parallel execution of code. If your tasks do not use any timers or perform + * any I/O, they will actually be executed in series. Any synchronous setup + * sections for each task will happen one after the other. JavaScript remains + * single-threaded. + * + * **Hint:** Use [`reflect`]{@link module:Utils.reflect} to continue the + * execution of other tasks when a task fails. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.parallel}. + * + * @name parallel + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * + * //Using Callbacks + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function parallel(tasks, callback) { + return _parallel(eachOf$1, tasks, callback); + } + + /** + * The same as [`parallel`]{@link module:ControlFlow.parallel} but runs a maximum of `limit` async operations at a + * time. + * + * @name parallelLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.parallel]{@link module:ControlFlow.parallel} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + */ + function parallelLimit(tasks, limit, callback) { + return _parallel(eachOfLimit$2(limit), tasks, callback); + } + + /** + * A queue of tasks for the worker function to complete. + * @typedef {Iterable} QueueObject + * @memberOf module:ControlFlow + * @property {Function} length - a function returning the number of items + * waiting to be processed. Invoke with `queue.length()`. + * @property {boolean} started - a boolean indicating whether or not any + * items have been pushed and processed by the queue. + * @property {Function} running - a function returning the number of items + * currently being processed. Invoke with `queue.running()`. + * @property {Function} workersList - a function returning the array of items + * currently being processed. Invoke with `queue.workersList()`. + * @property {Function} idle - a function returning false if there are items + * waiting or being processed, or true if not. Invoke with `queue.idle()`. + * @property {number} concurrency - an integer for determining how many `worker` + * functions should be run in parallel. This property can be changed after a + * `queue` is created to alter the concurrency on-the-fly. + * @property {number} payload - an integer that specifies how many items are + * passed to the worker function at a time. only applies if this is a + * [cargo]{@link module:ControlFlow.cargo} object + * @property {AsyncFunction} push - add a new task to the `queue`. Calls `callback` + * once the `worker` has finished processing the task. Instead of a single task, + * a `tasks` array can be submitted. The respective callback is used for every + * task in the list. Invoke with `queue.push(task, [callback])`, + * @property {AsyncFunction} unshift - add a new task to the front of the `queue`. + * Invoke with `queue.unshift(task, [callback])`. + * @property {AsyncFunction} pushAsync - the same as `q.push`, except this returns + * a promise that rejects if an error occurs. + * @property {AsyncFunction} unshiftAsync - the same as `q.unshift`, except this returns + * a promise that rejects if an error occurs. + * @property {Function} remove - remove items from the queue that match a test + * function. The test function will be passed an object with a `data` property, + * and a `priority` property, if this is a + * [priorityQueue]{@link module:ControlFlow.priorityQueue} object. + * Invoked with `queue.remove(testFn)`, where `testFn` is of the form + * `function ({data, priority}) {}` and returns a Boolean. + * @property {Function} saturated - a function that sets a callback that is + * called when the number of running workers hits the `concurrency` limit, and + * further tasks will be queued. If the callback is omitted, `q.saturated()` + * returns a promise for the next occurrence. + * @property {Function} unsaturated - a function that sets a callback that is + * called when the number of running workers is less than the `concurrency` & + * `buffer` limits, and further tasks will not be queued. If the callback is + * omitted, `q.unsaturated()` returns a promise for the next occurrence. + * @property {number} buffer - A minimum threshold buffer in order to say that + * the `queue` is `unsaturated`. + * @property {Function} empty - a function that sets a callback that is called + * when the last item from the `queue` is given to a `worker`. If the callback + * is omitted, `q.empty()` returns a promise for the next occurrence. + * @property {Function} drain - a function that sets a callback that is called + * when the last item from the `queue` has returned from the `worker`. If the + * callback is omitted, `q.drain()` returns a promise for the next occurrence. + * @property {Function} error - a function that sets a callback that is called + * when a task errors. Has the signature `function(error, task)`. If the + * callback is omitted, `error()` returns a promise that rejects on the next + * error. + * @property {boolean} paused - a boolean for determining whether the queue is + * in a paused state. + * @property {Function} pause - a function that pauses the processing of tasks + * until `resume()` is called. Invoke with `queue.pause()`. + * @property {Function} resume - a function that resumes the processing of + * queued tasks when the queue is paused. Invoke with `queue.resume()`. + * @property {Function} kill - a function that removes the `drain` callback and + * empties remaining tasks from the queue forcing it to go idle. No more tasks + * should be pushed to the queue after calling this function. Invoke with `queue.kill()`. + * + * @example + * const q = async.queue(worker, 2) + * q.push(item1) + * q.push(item2) + * q.push(item3) + * // queues are iterable, spread into an array to inspect + * const items = [...q] // [item1, item2, item3] + * // or use for of + * for (let item of q) { + * console.log(item) + * } + * + * q.drain(() => { + * console.log('all done') + * }) + * // or + * await q.drain() + */ + + /** + * Creates a `queue` object with the specified `concurrency`. Tasks added to the + * `queue` are processed in parallel (up to the `concurrency` limit). If all + * `worker`s are in progress, the task is queued until one becomes available. + * Once a `worker` completes a `task`, that `task`'s callback is called. + * + * @name queue + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} worker - An async function for processing a queued task. + * If you want to handle errors from an individual task, pass a callback to + * `q.push()`. Invoked with (task, callback). + * @param {number} [concurrency=1] - An `integer` for determining how many + * `worker` functions should be run in parallel. If omitted, the concurrency + * defaults to `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A queue object to manage the tasks. Callbacks can be + * attached as certain properties to listen for specific events during the + * lifecycle of the queue. + * @example + * + * // create a queue object with concurrency 2 + * var q = async.queue(function(task, callback) { + * console.log('hello ' + task.name); + * callback(); + * }, 2); + * + * // assign a callback + * q.drain(function() { + * console.log('all items have been processed'); + * }); + * // or await the end + * await q.drain() + * + * // assign an error callback + * q.error(function(err, task) { + * console.error('task experienced an error'); + * }); + * + * // add some items to the queue + * q.push({name: 'foo'}, function(err) { + * console.log('finished processing foo'); + * }); + * // callback is optional + * q.push({name: 'bar'}); + * + * // add some items to the queue (batch-wise) + * q.push([{name: 'baz'},{name: 'bay'},{name: 'bax'}], function(err) { + * console.log('finished processing item'); + * }); + * + * // add some items to the front of the queue + * q.unshift({name: 'bar'}, function (err) { + * console.log('finished processing bar'); + * }); + */ + function queue (worker, concurrency) { + var _worker = wrapAsync(worker); + return queue$1((items, cb) => { + _worker(items[0], cb); + }, concurrency, 1); + } + + // Binary min-heap implementation used for priority queue. + // Implementation is stable, i.e. push time is considered for equal priorities + class Heap { + constructor() { + this.heap = []; + this.pushCount = Number.MIN_SAFE_INTEGER; + } + + get length() { + return this.heap.length; + } + + empty () { + this.heap = []; + return this; + } + + percUp(index) { + let p; + + while (index > 0 && smaller(this.heap[index], this.heap[p=parent(index)])) { + let t = this.heap[index]; + this.heap[index] = this.heap[p]; + this.heap[p] = t; + + index = p; + } + } + + percDown(index) { + let l; + + while ((l=leftChi(index)) < this.heap.length) { + if (l+1 < this.heap.length && smaller(this.heap[l+1], this.heap[l])) { + l = l+1; + } + + if (smaller(this.heap[index], this.heap[l])) { + break; + } + + let t = this.heap[index]; + this.heap[index] = this.heap[l]; + this.heap[l] = t; + + index = l; + } + } + + push(node) { + node.pushCount = ++this.pushCount; + this.heap.push(node); + this.percUp(this.heap.length-1); + } + + unshift(node) { + return this.heap.push(node); + } + + shift() { + let [top] = this.heap; + + this.heap[0] = this.heap[this.heap.length-1]; + this.heap.pop(); + this.percDown(0); + + return top; + } + + toArray() { + return [...this]; + } + + *[Symbol.iterator] () { + for (let i = 0; i < this.heap.length; i++) { + yield this.heap[i].data; + } + } + + remove (testFn) { + let j = 0; + for (let i = 0; i < this.heap.length; i++) { + if (!testFn(this.heap[i])) { + this.heap[j] = this.heap[i]; + j++; + } + } + + this.heap.splice(j); + + for (let i = parent(this.heap.length-1); i >= 0; i--) { + this.percDown(i); + } + + return this; + } + } + + function leftChi(i) { + return (i<<1)+1; + } + + function parent(i) { + return ((i+1)>>1)-1; + } + + function smaller(x, y) { + if (x.priority !== y.priority) { + return x.priority < y.priority; + } + else { + return x.pushCount < y.pushCount; + } + } + + /** + * The same as [async.queue]{@link module:ControlFlow.queue} only tasks are assigned a priority and + * completed in ascending priority order. + * + * @name priorityQueue + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {AsyncFunction} worker - An async function for processing a queued task. + * If you want to handle errors from an individual task, pass a callback to + * `q.push()`. + * Invoked with (task, callback). + * @param {number} concurrency - An `integer` for determining how many `worker` + * functions should be run in parallel. If omitted, the concurrency defaults to + * `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A priorityQueue object to manage the tasks. There are three + * differences between `queue` and `priorityQueue` objects: + * * `push(task, priority, [callback])` - `priority` should be a number. If an + * array of `tasks` is given, all tasks will be assigned the same priority. + * * `pushAsync(task, priority, [callback])` - the same as `priorityQueue.push`, + * except this returns a promise that rejects if an error occurs. + * * The `unshift` and `unshiftAsync` methods were removed. + */ + function priorityQueue(worker, concurrency) { + // Start with a normal queue + var q = queue(worker, concurrency); + + var { + push, + pushAsync + } = q; + + q._tasks = new Heap(); + q._createTaskItem = ({data, priority}, callback) => { + return { + data, + priority, + callback + }; + }; + + function createDataItems(tasks, priority) { + if (!Array.isArray(tasks)) { + return {data: tasks, priority}; + } + return tasks.map(data => { return {data, priority}; }); + } + + // Override push to accept second parameter representing priority + q.push = function(data, priority = 0, callback) { + return push(createDataItems(data, priority), callback); + }; + + q.pushAsync = function(data, priority = 0, callback) { + return pushAsync(createDataItems(data, priority), callback); + }; + + // Remove unshift functions + delete q.unshift; + delete q.unshiftAsync; + + return q; + } + + /** + * Runs the `tasks` array of functions in parallel, without waiting until the + * previous function has completed. Once any of the `tasks` complete or pass an + * error to its callback, the main `callback` is immediately called. It's + * equivalent to `Promise.race()`. + * + * @name race + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array containing [async functions]{@link AsyncFunction} + * to run. Each function can complete with an optional `result` value. + * @param {Function} callback - A callback to run once any of the functions have + * completed. This function gets an error or result from the first function that + * completed. Invoked with (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.race([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], + * // main callback + * function(err, result) { + * // the result will be equal to 'two' as it finishes earlier + * }); + */ + function race(tasks, callback) { + callback = once(callback); + if (!Array.isArray(tasks)) return callback(new TypeError('First argument to race must be an array of functions')); + if (!tasks.length) return callback(); + for (var i = 0, l = tasks.length; i < l; i++) { + wrapAsync(tasks[i])(callback); + } + } + + var race$1 = awaitify(race, 2); + + /** + * Same as [`reduce`]{@link module:Collections.reduce}, only operates on `array` in reverse order. + * + * @name reduceRight + * @static + * @memberOf module:Collections + * @method + * @see [async.reduce]{@link module:Collections.reduce} + * @alias foldr + * @category Collection + * @param {Array} array - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + */ + function reduceRight (array, memo, iteratee, callback) { + var reversed = [...array].reverse(); + return reduce$1(reversed, memo, iteratee, callback); + } + + /** + * Wraps the async function in another function that always completes with a + * result object, even when it errors. + * + * The result object has either the property `error` or `value`. + * + * @name reflect + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function you want to wrap + * @returns {Function} - A function that always passes null to it's callback as + * the error. The second argument to the callback will be an `object` with + * either an `error` or a `value` property. + * @example + * + * async.parallel([ + * async.reflect(function(callback) { + * // do some stuff ... + * callback(null, 'one'); + * }), + * async.reflect(function(callback) { + * // do some more stuff but error ... + * callback('bad stuff happened'); + * }), + * async.reflect(function(callback) { + * // do some more stuff ... + * callback(null, 'two'); + * }) + * ], + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = 'bad stuff happened' + * // results[2].value = 'two' + * }); + */ + function reflect(fn) { + var _fn = wrapAsync(fn); + return initialParams(function reflectOn(args, reflectCallback) { + args.push((error, ...cbArgs) => { + let retVal = {}; + if (error) { + retVal.error = error; + } + if (cbArgs.length > 0){ + var value = cbArgs; + if (cbArgs.length <= 1) { + [value] = cbArgs; + } + retVal.value = value; + } + reflectCallback(null, retVal); + }); + + return _fn.apply(this, args); + }); + } + + /** + * A helper function that wraps an array or an object of functions with `reflect`. + * + * @name reflectAll + * @static + * @memberOf module:Utils + * @method + * @see [async.reflect]{@link module:Utils.reflect} + * @category Util + * @param {Array|Object|Iterable} tasks - The collection of + * [async functions]{@link AsyncFunction} to wrap in `async.reflect`. + * @returns {Array} Returns an array of async functions, each wrapped in + * `async.reflect` + * @example + * + * let tasks = [ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * // do some more stuff but error ... + * callback(new Error('bad stuff happened')); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = Error('bad stuff happened') + * // results[2].value = 'two' + * }); + * + * // an example using an object instead of an array + * let tasks = { + * one: function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * two: function(callback) { + * callback('two'); + * }, + * three: function(callback) { + * setTimeout(function() { + * callback(null, 'three'); + * }, 100); + * } + * }; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results.one.value = 'one' + * // results.two.error = 'two' + * // results.three.value = 'three' + * }); + */ + function reflectAll(tasks) { + var results; + if (Array.isArray(tasks)) { + results = tasks.map(reflect); + } else { + results = {}; + Object.keys(tasks).forEach(key => { + results[key] = reflect.call(this, tasks[key]); + }); + } + return results; + } + + function reject$2(eachfn, arr, _iteratee, callback) { + const iteratee = wrapAsync(_iteratee); + return _filter(eachfn, arr, (value, cb) => { + iteratee(value, (err, v) => { + cb(err, !v); + }); + }, callback); + } + + /** + * The opposite of [`filter`]{@link module:Collections.filter}. Removes values that pass an `async` truth test. + * + * @name reject + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.reject(fileList, fileExists, function(err, results) { + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }); + * + * // Using Promises + * async.reject(fileList, fileExists) + * .then( results => { + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.reject(fileList, fileExists); + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function reject (coll, iteratee, callback) { + return reject$2(eachOf$1, coll, iteratee, callback) + } + var reject$1 = awaitify(reject, 3); + + /** + * The same as [`reject`]{@link module:Collections.reject} but runs a maximum of `limit` async operations at a + * time. + * + * @name rejectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ + function rejectLimit (coll, limit, iteratee, callback) { + return reject$2(eachOfLimit$2(limit), coll, iteratee, callback) + } + var rejectLimit$1 = awaitify(rejectLimit, 4); + + /** + * The same as [`reject`]{@link module:Collections.reject} but runs only a single async operation at a time. + * + * @name rejectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ + function rejectSeries (coll, iteratee, callback) { + return reject$2(eachOfSeries$1, coll, iteratee, callback) + } + var rejectSeries$1 = awaitify(rejectSeries, 3); + + function constant(value) { + return function () { + return value; + } + } + + /** + * Attempts to get a successful response from `task` no more than `times` times + * before returning an error. If the task is successful, the `callback` will be + * passed the result of the successful task. If all attempts fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name retry + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @see [async.retryable]{@link module:ControlFlow.retryable} + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - Can be either an + * object with `times` and `interval` or a number. + * * `times` - The number of attempts to make before giving up. The default + * is `5`. + * * `interval` - The time to wait between retries, in milliseconds. The + * default is `0`. The interval may also be specified as a function of the + * retry count (see example). + * * `errorFilter` - An optional synchronous function that is invoked on + * erroneous result. If it returns `true` the retry attempts will continue; + * if the function returns `false` the retry flow is aborted with the current + * attempt's error and result being returned to the final callback. + * Invoked with (err). + * * If `opts` is a number, the number specifies the number of times to retry, + * with the default interval of `0`. + * @param {AsyncFunction} task - An async function to retry. + * Invoked with (callback). + * @param {Function} [callback] - An optional callback which is called when the + * task has succeeded, or after the final failed attempt. It receives the `err` + * and `result` arguments of the last attempt at completing the `task`. Invoked + * with (err, results). + * @returns {Promise} a promise if no callback provided + * + * @example + * + * // The `retry` function can be used as a stand-alone control flow by passing + * // a callback, as shown below: + * + * // try calling apiMethod 3 times + * async.retry(3, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 3 times, waiting 200 ms between each retry + * async.retry({times: 3, interval: 200}, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 10 times with exponential backoff + * // (i.e. intervals of 100, 200, 400, 800, 1600, ... milliseconds) + * async.retry({ + * times: 10, + * interval: function(retryCount) { + * return 50 * Math.pow(2, retryCount); + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod the default 5 times no delay between each retry + * async.retry(apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod only when error condition satisfies, all other + * // errors will abort the retry control flow and return to final callback + * async.retry({ + * errorFilter: function(err) { + * return err.message === 'Temporary error'; // only retry on a specific error + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // to retry individual methods that are not as reliable within other + * // control flow functions, use the `retryable` wrapper: + * async.auto({ + * users: api.getUsers.bind(api), + * payments: async.retryable(3, api.getPayments.bind(api)) + * }, function(err, results) { + * // do something with the results + * }); + * + */ + const DEFAULT_TIMES = 5; + const DEFAULT_INTERVAL = 0; + + function retry(opts, task, callback) { + var options = { + times: DEFAULT_TIMES, + intervalFunc: constant(DEFAULT_INTERVAL) + }; + + if (arguments.length < 3 && typeof opts === 'function') { + callback = task || promiseCallback(); + task = opts; + } else { + parseTimes(options, opts); + callback = callback || promiseCallback(); + } + + if (typeof task !== 'function') { + throw new Error("Invalid arguments for async.retry"); + } + + var _task = wrapAsync(task); + + var attempt = 1; + function retryAttempt() { + _task((err, ...args) => { + if (err === false) return + if (err && attempt++ < options.times && + (typeof options.errorFilter != 'function' || + options.errorFilter(err))) { + setTimeout(retryAttempt, options.intervalFunc(attempt - 1)); + } else { + callback(err, ...args); + } + }); + } + + retryAttempt(); + return callback[PROMISE_SYMBOL] + } + + function parseTimes(acc, t) { + if (typeof t === 'object') { + acc.times = +t.times || DEFAULT_TIMES; + + acc.intervalFunc = typeof t.interval === 'function' ? + t.interval : + constant(+t.interval || DEFAULT_INTERVAL); + + acc.errorFilter = t.errorFilter; + } else if (typeof t === 'number' || typeof t === 'string') { + acc.times = +t || DEFAULT_TIMES; + } else { + throw new Error("Invalid arguments for async.retry"); + } + } + + /** + * A close relative of [`retry`]{@link module:ControlFlow.retry}. This method + * wraps a task and makes it retryable, rather than immediately calling it + * with retries. + * + * @name retryable + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.retry]{@link module:ControlFlow.retry} + * @category Control Flow + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - optional + * options, exactly the same as from `retry`, except for a `opts.arity` that + * is the arity of the `task` function, defaulting to `task.length` + * @param {AsyncFunction} task - the asynchronous function to wrap. + * This function will be passed any arguments passed to the returned wrapper. + * Invoked with (...args, callback). + * @returns {AsyncFunction} The wrapped function, which when invoked, will + * retry on an error, based on the parameters specified in `opts`. + * This function will accept the same parameters as `task`. + * @example + * + * async.auto({ + * dep1: async.retryable(3, getFromFlakyService), + * process: ["dep1", async.retryable(3, function (results, cb) { + * maybeProcessData(results.dep1, cb); + * })] + * }, callback); + */ + function retryable (opts, task) { + if (!task) { + task = opts; + opts = null; + } + let arity = (opts && opts.arity) || task.length; + if (isAsync(task)) { + arity += 1; + } + var _task = wrapAsync(task); + return initialParams((args, callback) => { + if (args.length < arity - 1 || callback == null) { + args.push(callback); + callback = promiseCallback(); + } + function taskFn(cb) { + _task(...args, cb); + } + + if (opts) retry(opts, taskFn, callback); + else retry(taskFn, callback); + + return callback[PROMISE_SYMBOL] + }); + } + + /** + * Run the functions in the `tasks` collection in series, each one running once + * the previous function has completed. If any functions in the series pass an + * error to its callback, no more functions are run, and `callback` is + * immediately called with the value of the error. Otherwise, `callback` + * receives an array of results when `tasks` have completed. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function, and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.series}. + * + * **Note** that while many implementations preserve the order of object + * properties, the [ECMAScript Language Specification](http://www.ecma-international.org/ecma-262/5.1/#sec-8.6) + * explicitly states that + * + * > The mechanics and order of enumerating the properties is not specified. + * + * So if you rely on the order in which your series of functions are executed, + * and want this to work on all platforms, consider using an array. + * + * @name series + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing + * [async functions]{@link AsyncFunction} to run in series. + * Each function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This function gets a results array (or object) + * containing all the result arguments passed to the `task` callbacks. Invoked + * with (err, result). + * @return {Promise} a promise, if no callback is passed + * @example + * + * //Using Callbacks + * async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] + * }); + * + * // an example using objects instead of arrays + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.series([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function series(tasks, callback) { + return _parallel(eachOfSeries$1, tasks, callback); + } + + /** + * Returns `true` if at least one element in the `coll` satisfies an async test. + * If any iteratee call returns `true`, the main `callback` is immediately + * called. + * + * @name some + * @static + * @memberOf module:Collections + * @method + * @alias any + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + *); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // false + * // result is false since none of the files exists + * } + *); + * + * // Using Promises + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since some file in the list exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since none of the files exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists); + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists); + * console.log(result); + * // false + * // result is false since none of the files exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function some(coll, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOf$1, coll, iteratee, callback) + } + var some$1 = awaitify(some, 3); + + /** + * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time. + * + * @name someLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anyLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ + function someLimit(coll, limit, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOfLimit$2(limit), coll, iteratee, callback) + } + var someLimit$1 = awaitify(someLimit, 4); + + /** + * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time. + * + * @name someSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anySeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in series. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ + function someSeries(coll, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOfSeries$1, coll, iteratee, callback) + } + var someSeries$1 = awaitify(someSeries, 3); + + /** + * Sorts a list by the results of running each `coll` value through an async + * `iteratee`. + * + * @name sortBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a value to use as the sort criteria as + * its `result`. + * Invoked with (item, callback). + * @param {Function} callback - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is the items + * from the original `coll` sorted by the values returned by the `iteratee` + * calls. Invoked with (err, results). + * @returns {Promise} a promise, if no callback passed + * @example + * + * // bigfile.txt is a file that is 251100 bytes in size + * // mediumfile.txt is a file that is 11000 bytes in size + * // smallfile.txt is a file that is 121 bytes in size + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // By modifying the callback parameter the + * // sorting order can be influenced: + * + * // ascending order + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) return callback(getFileSizeErr); + * callback(null, fileSize); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // descending order + * async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) { + * return callback(getFileSizeErr); + * } + * callback(null, fileSize * -1); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'bigfile.txt', 'mediumfile.txt', 'smallfile.txt'] + * } + * } + * ); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * } + * ); + * + * // Using Promises + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * (async () => { + * try { + * let results = await async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * // Error handling + * async () => { + * try { + * let results = await async.sortBy(['missingfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ + function sortBy (coll, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return map$1(coll, (x, iterCb) => { + _iteratee(x, (err, criteria) => { + if (err) return iterCb(err); + iterCb(err, {value: x, criteria}); + }); + }, (err, results) => { + if (err) return callback(err); + callback(null, results.sort(comparator).map(v => v.value)); + }); + + function comparator(left, right) { + var a = left.criteria, b = right.criteria; + return a < b ? -1 : a > b ? 1 : 0; + } + } + var sortBy$1 = awaitify(sortBy, 3); + + /** + * Sets a time limit on an asynchronous function. If the function does not call + * its callback within the specified milliseconds, it will be called with a + * timeout error. The code property for the error object will be `'ETIMEDOUT'`. + * + * @name timeout + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} asyncFn - The async function to limit in time. + * @param {number} milliseconds - The specified time limit. + * @param {*} [info] - Any variable you want attached (`string`, `object`, etc) + * to timeout Error for more information.. + * @returns {AsyncFunction} Returns a wrapped function that can be used with any + * of the control flow functions. + * Invoke this function with the same parameters as you would `asyncFunc`. + * @example + * + * function myFunction(foo, callback) { + * doAsyncTask(foo, function(err, data) { + * // handle errors + * if (err) return callback(err); + * + * // do some stuff ... + * + * // return processed data + * return callback(null, data); + * }); + * } + * + * var wrapped = async.timeout(myFunction, 1000); + * + * // call `wrapped` as you would `myFunction` + * wrapped({ bar: 'bar' }, function(err, data) { + * // if `myFunction` takes < 1000 ms to execute, `err` + * // and `data` will have their expected values + * + * // else `err` will be an Error with the code 'ETIMEDOUT' + * }); + */ + function timeout(asyncFn, milliseconds, info) { + var fn = wrapAsync(asyncFn); + + return initialParams((args, callback) => { + var timedOut = false; + var timer; + + function timeoutCallback() { + var name = asyncFn.name || 'anonymous'; + var error = new Error('Callback function "' + name + '" timed out.'); + error.code = 'ETIMEDOUT'; + if (info) { + error.info = info; + } + timedOut = true; + callback(error); + } + + args.push((...cbArgs) => { + if (!timedOut) { + callback(...cbArgs); + clearTimeout(timer); + } + }); + + // setup timer and call original function + timer = setTimeout(timeoutCallback, milliseconds); + fn(...args); + }); + } + + function range(size) { + var result = Array(size); + while (size--) { + result[size] = size; + } + return result; + } + + /** + * The same as [times]{@link module:ControlFlow.times} but runs a maximum of `limit` async operations at a + * time. + * + * @name timesLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} count - The number of times to run the function. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see [async.map]{@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ + function timesLimit(count, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(range(count), limit, _iteratee, callback); + } + + /** + * Calls the `iteratee` function `n` times, and accumulates results in the same + * manner you would use with [map]{@link module:Collections.map}. + * + * @name times + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.map]{@link module:Collections.map} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + * @example + * + * // Pretend this is some complicated async factory + * var createUser = function(id, callback) { + * callback(null, { + * id: 'user' + id + * }); + * }; + * + * // generate 5 users + * async.times(5, function(n, next) { + * createUser(n, function(err, user) { + * next(err, user); + * }); + * }, function(err, users) { + * // we should now have 5 users + * }); + */ + function times (n, iteratee, callback) { + return timesLimit(n, Infinity, iteratee, callback) + } + + /** + * The same as [times]{@link module:ControlFlow.times} but runs only a single async operation at a time. + * + * @name timesSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ + function timesSeries (n, iteratee, callback) { + return timesLimit(n, 1, iteratee, callback) + } + + /** + * A relative of `reduce`. Takes an Object or Array, and iterates over each + * element in parallel, each step potentially mutating an `accumulator` value. + * The type of the accumulator defaults to the type of collection passed in. + * + * @name transform + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} [accumulator] - The initial state of the transform. If omitted, + * it will default to an empty Object or Array, depending on the type of `coll` + * @param {AsyncFunction} iteratee - A function applied to each item in the + * collection that potentially modifies the accumulator. + * Invoked with (accumulator, item, key, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the transformed accumulator. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileList, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * }); + * + * // Using Promises + * async.transform(fileList, transformFileSize) + * .then(result => { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * (async () => { + * try { + * let result = await async.transform(fileList, transformFileSize); + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileMap = { f1: 'file1.txt', f2: 'file2.txt', f3: 'file3.txt' }; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileMap, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * }); + * + * // Using Promises + * async.transform(fileMap, transformFileSize) + * .then(result => { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.transform(fileMap, transformFileSize); + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ + function transform (coll, accumulator, iteratee, callback) { + if (arguments.length <= 3 && typeof accumulator === 'function') { + callback = iteratee; + iteratee = accumulator; + accumulator = Array.isArray(coll) ? [] : {}; + } + callback = once(callback || promiseCallback()); + var _iteratee = wrapAsync(iteratee); + + eachOf$1(coll, (v, k, cb) => { + _iteratee(accumulator, v, k, cb); + }, err => callback(err, accumulator)); + return callback[PROMISE_SYMBOL] + } + + /** + * It runs each task in series but stops whenever any of the functions were + * successful. If one of the tasks were successful, the `callback` will be + * passed the result of the successful task. If all tasks fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name tryEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing functions to + * run, each function is passed a `callback(err, result)` it must call on + * completion with an error `err` (which can be `null`) and an optional `result` + * value. + * @param {Function} [callback] - An optional callback which is called when one + * of the tasks has succeeded, or all have failed. It receives the `err` and + * `result` arguments of the last attempt at completing the `task`. Invoked with + * (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * async.tryEach([ + * function getDataFromFirstWebsite(callback) { + * // Try getting the data from the first website + * callback(err, data); + * }, + * function getDataFromSecondWebsite(callback) { + * // First website failed, + * // Try getting the data from the backup website + * callback(err, data); + * } + * ], + * // optional callback + * function(err, results) { + * Now do something with the data. + * }); + * + */ + function tryEach(tasks, callback) { + var error = null; + var result; + return eachSeries$1(tasks, (task, taskCb) => { + wrapAsync(task)((err, ...args) => { + if (err === false) return taskCb(err); + + if (args.length < 2) { + [result] = args; + } else { + result = args; + } + error = err; + taskCb(err ? null : {}); + }); + }, () => callback(error, result)); + } + + var tryEach$1 = awaitify(tryEach); + + /** + * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original, + * unmemoized form. Handy for testing. + * + * @name unmemoize + * @static + * @memberOf module:Utils + * @method + * @see [async.memoize]{@link module:Utils.memoize} + * @category Util + * @param {AsyncFunction} fn - the memoized function + * @returns {AsyncFunction} a function that calls the original unmemoized function + */ + function unmemoize(fn) { + return (...args) => { + return (fn.unmemoized || fn)(...args); + }; + } + + /** + * Repeatedly call `iteratee`, while `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. + * + * @name whilst + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` passes. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + * @example + * + * var count = 0; + * async.whilst( + * function test(cb) { cb(null, count < 5); }, + * function iter(callback) { + * count++; + * setTimeout(function() { + * callback(null, count); + * }, 1000); + * }, + * function (err, n) { + * // 5 seconds have passed, n = 5 + * } + * ); + */ + function whilst(test, iteratee, callback) { + callback = onlyOnce(callback); + var _fn = wrapAsync(iteratee); + var _test = wrapAsync(test); + var results = []; + + function next(err, ...rest) { + if (err) return callback(err); + results = rest; + if (err === false) return; + _test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return _test(check); + } + var whilst$1 = awaitify(whilst, 3); + + /** + * Repeatedly call `iteratee` until `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. `callback` will be passed an error and any + * arguments passed to the final `iteratee`'s callback. + * + * The inverse of [whilst]{@link module:ControlFlow.whilst}. + * + * @name until + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * const results = [] + * let finished = false + * async.until(function test(cb) { + * cb(null, finished) + * }, function iter(next) { + * fetchPage(url, (err, body) => { + * if (err) return next(err) + * results = results.concat(body.objects) + * finished = !!body.next + * next(err) + * }) + * }, function done (err) { + * // all pages have been fetched + * }) + */ + function until(test, iteratee, callback) { + const _test = wrapAsync(test); + return whilst$1((cb) => _test((err, truth) => cb (err, !truth)), iteratee, callback); + } + + /** + * Runs the `tasks` array of functions in series, each passing their results to + * the next in the array. However, if any of the `tasks` pass an error to their + * own callback, the next function is not executed, and the main `callback` is + * immediately called with the error. + * + * @name waterfall + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array of [async functions]{@link AsyncFunction} + * to run. + * Each function should complete with any number of `result` values. + * The `result` values will be passed as arguments, in order, to the next task. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This will be passed the results of the last task's + * callback. Invoked with (err, [results]). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.waterfall([ + * function(callback) { + * callback(null, 'one', 'two'); + * }, + * function(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * }, + * function(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + * ], function (err, result) { + * // result now equals 'done' + * }); + * + * // Or, with named functions: + * async.waterfall([ + * myFirstFunction, + * mySecondFunction, + * myLastFunction, + * ], function (err, result) { + * // result now equals 'done' + * }); + * function myFirstFunction(callback) { + * callback(null, 'one', 'two'); + * } + * function mySecondFunction(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * } + * function myLastFunction(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + */ + function waterfall (tasks, callback) { + callback = once(callback); + if (!Array.isArray(tasks)) return callback(new Error('First argument to waterfall must be an array of functions')); + if (!tasks.length) return callback(); + var taskIndex = 0; + + function nextTask(args) { + var task = wrapAsync(tasks[taskIndex++]); + task(...args, onlyOnce(next)); + } + + function next(err, ...args) { + if (err === false) return + if (err || taskIndex === tasks.length) { + return callback(err, ...args); + } + nextTask(args); + } + + nextTask([]); + } + + var waterfall$1 = awaitify(waterfall); + + /** + * An "async function" in the context of Async is an asynchronous function with + * a variable number of parameters, with the final parameter being a callback. + * (`function (arg1, arg2, ..., callback) {}`) + * The final callback is of the form `callback(err, results...)`, which must be + * called once the function is completed. The callback should be called with a + * Error as its first argument to signal that an error occurred. + * Otherwise, if no error occurred, it should be called with `null` as the first + * argument, and any additional `result` arguments that may apply, to signal + * successful completion. + * The callback must be called exactly once, ideally on a later tick of the + * JavaScript event loop. + * + * This type of function is also referred to as a "Node-style async function", + * or a "continuation passing-style function" (CPS). Most of the methods of this + * library are themselves CPS/Node-style async functions, or functions that + * return CPS/Node-style async functions. + * + * Wherever we accept a Node-style async function, we also directly accept an + * [ES2017 `async` function]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function}. + * In this case, the `async` function will not be passed a final callback + * argument, and any thrown error will be used as the `err` argument of the + * implicit callback, and the return value will be used as the `result` value. + * (i.e. a `rejected` of the returned Promise becomes the `err` callback + * argument, and a `resolved` value becomes the `result`.) + * + * Note, due to JavaScript limitations, we can only detect native `async` + * functions and not transpilied implementations. + * Your environment must have `async`/`await` support for this to work. + * (e.g. Node > v7.6, or a recent version of a modern browser). + * If you are using `async` functions through a transpiler (e.g. Babel), you + * must still wrap the function with [asyncify]{@link module:Utils.asyncify}, + * because the `async function` will be compiled to an ordinary function that + * returns a promise. + * + * @typedef {Function} AsyncFunction + * @static + */ + + + var index = { + apply, + applyEach, + applyEachSeries, + asyncify, + auto, + autoInject, + cargo: cargo$1, + cargoQueue: cargo, + compose, + concat: concat$1, + concatLimit: concatLimit$1, + concatSeries: concatSeries$1, + constant: constant$1, + detect: detect$1, + detectLimit: detectLimit$1, + detectSeries: detectSeries$1, + dir, + doUntil, + doWhilst: doWhilst$1, + each, + eachLimit: eachLimit$1, + eachOf: eachOf$1, + eachOfLimit: eachOfLimit$1, + eachOfSeries: eachOfSeries$1, + eachSeries: eachSeries$1, + ensureAsync, + every: every$1, + everyLimit: everyLimit$1, + everySeries: everySeries$1, + filter: filter$1, + filterLimit: filterLimit$1, + filterSeries: filterSeries$1, + forever: forever$1, + groupBy, + groupByLimit: groupByLimit$1, + groupBySeries, + log, + map: map$1, + mapLimit: mapLimit$1, + mapSeries: mapSeries$1, + mapValues, + mapValuesLimit: mapValuesLimit$1, + mapValuesSeries, + memoize, + nextTick, + parallel, + parallelLimit, + priorityQueue, + queue, + race: race$1, + reduce: reduce$1, + reduceRight, + reflect, + reflectAll, + reject: reject$1, + rejectLimit: rejectLimit$1, + rejectSeries: rejectSeries$1, + retry, + retryable, + seq, + series, + setImmediate: setImmediate$1, + some: some$1, + someLimit: someLimit$1, + someSeries: someSeries$1, + sortBy: sortBy$1, + timeout, + times, + timesLimit, + timesSeries, + transform, + tryEach: tryEach$1, + unmemoize, + until, + waterfall: waterfall$1, + whilst: whilst$1, + + // aliases + all: every$1, + allLimit: everyLimit$1, + allSeries: everySeries$1, + any: some$1, + anyLimit: someLimit$1, + anySeries: someSeries$1, + find: detect$1, + findLimit: detectLimit$1, + findSeries: detectSeries$1, + flatMap: concat$1, + flatMapLimit: concatLimit$1, + flatMapSeries: concatSeries$1, + forEach: each, + forEachSeries: eachSeries$1, + forEachLimit: eachLimit$1, + forEachOf: eachOf$1, + forEachOfSeries: eachOfSeries$1, + forEachOfLimit: eachOfLimit$1, + inject: reduce$1, + foldl: reduce$1, + foldr: reduceRight, + select: filter$1, + selectLimit: filterLimit$1, + selectSeries: filterSeries$1, + wrapSync: asyncify, + during: whilst$1, + doDuring: doWhilst$1 + }; + + exports.all = every$1; + exports.allLimit = everyLimit$1; + exports.allSeries = everySeries$1; + exports.any = some$1; + exports.anyLimit = someLimit$1; + exports.anySeries = someSeries$1; + exports.apply = apply; + exports.applyEach = applyEach; + exports.applyEachSeries = applyEachSeries; + exports.asyncify = asyncify; + exports.auto = auto; + exports.autoInject = autoInject; + exports.cargo = cargo$1; + exports.cargoQueue = cargo; + exports.compose = compose; + exports.concat = concat$1; + exports.concatLimit = concatLimit$1; + exports.concatSeries = concatSeries$1; + exports.constant = constant$1; + exports.default = index; + exports.detect = detect$1; + exports.detectLimit = detectLimit$1; + exports.detectSeries = detectSeries$1; + exports.dir = dir; + exports.doDuring = doWhilst$1; + exports.doUntil = doUntil; + exports.doWhilst = doWhilst$1; + exports.during = whilst$1; + exports.each = each; + exports.eachLimit = eachLimit$1; + exports.eachOf = eachOf$1; + exports.eachOfLimit = eachOfLimit$1; + exports.eachOfSeries = eachOfSeries$1; + exports.eachSeries = eachSeries$1; + exports.ensureAsync = ensureAsync; + exports.every = every$1; + exports.everyLimit = everyLimit$1; + exports.everySeries = everySeries$1; + exports.filter = filter$1; + exports.filterLimit = filterLimit$1; + exports.filterSeries = filterSeries$1; + exports.find = detect$1; + exports.findLimit = detectLimit$1; + exports.findSeries = detectSeries$1; + exports.flatMap = concat$1; + exports.flatMapLimit = concatLimit$1; + exports.flatMapSeries = concatSeries$1; + exports.foldl = reduce$1; + exports.foldr = reduceRight; + exports.forEach = each; + exports.forEachLimit = eachLimit$1; + exports.forEachOf = eachOf$1; + exports.forEachOfLimit = eachOfLimit$1; + exports.forEachOfSeries = eachOfSeries$1; + exports.forEachSeries = eachSeries$1; + exports.forever = forever$1; + exports.groupBy = groupBy; + exports.groupByLimit = groupByLimit$1; + exports.groupBySeries = groupBySeries; + exports.inject = reduce$1; + exports.log = log; + exports.map = map$1; + exports.mapLimit = mapLimit$1; + exports.mapSeries = mapSeries$1; + exports.mapValues = mapValues; + exports.mapValuesLimit = mapValuesLimit$1; + exports.mapValuesSeries = mapValuesSeries; + exports.memoize = memoize; + exports.nextTick = nextTick; + exports.parallel = parallel; + exports.parallelLimit = parallelLimit; + exports.priorityQueue = priorityQueue; + exports.queue = queue; + exports.race = race$1; + exports.reduce = reduce$1; + exports.reduceRight = reduceRight; + exports.reflect = reflect; + exports.reflectAll = reflectAll; + exports.reject = reject$1; + exports.rejectLimit = rejectLimit$1; + exports.rejectSeries = rejectSeries$1; + exports.retry = retry; + exports.retryable = retryable; + exports.select = filter$1; + exports.selectLimit = filterLimit$1; + exports.selectSeries = filterSeries$1; + exports.seq = seq; + exports.series = series; + exports.setImmediate = setImmediate$1; + exports.some = some$1; + exports.someLimit = someLimit$1; + exports.someSeries = someSeries$1; + exports.sortBy = sortBy$1; + exports.timeout = timeout; + exports.times = times; + exports.timesLimit = timesLimit; + exports.timesSeries = timesSeries; + exports.transform = transform; + exports.tryEach = tryEach$1; + exports.unmemoize = unmemoize; + exports.until = until; + exports.waterfall = waterfall$1; + exports.whilst = whilst$1; + exports.wrapSync = asyncify; + + Object.defineProperty(exports, '__esModule', { value: true }); + +})); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.min.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.min.js new file mode 100644 index 0000000..f0b7fdf --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.min.js @@ -0,0 +1 @@ +(function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):(e="undefined"==typeof globalThis?e||self:globalThis,t(e.async={}))})(this,function(e){"use strict";function t(e,...t){return(...n)=>e(...t,...n)}function n(e){return function(...t){var n=t.pop();return e.call(this,t,n)}}function a(e){setTimeout(e,0)}function i(e){return(t,...n)=>e(()=>t(...n))}function r(e){return d(e)?function(...t){const n=t.pop(),a=e.apply(this,t);return s(a,n)}:n(function(t,n){var a;try{a=e.apply(this,t)}catch(t){return n(t)}return a&&"function"==typeof a.then?s(a,n):void n(null,a)})}function s(e,t){return e.then(e=>{l(t,null,e)},e=>{l(t,e&&(e instanceof Error||e.message)?e:new Error(e))})}function l(e,t,n){try{e(t,n)}catch(e){_e(t=>{throw t},e)}}function d(e){return"AsyncFunction"===e[Symbol.toStringTag]}function u(e){return"AsyncGenerator"===e[Symbol.toStringTag]}function p(e){return"function"==typeof e[Symbol.asyncIterator]}function c(e){if("function"!=typeof e)throw new Error("expected a function");return d(e)?r(e):e}function o(e,t){function n(...n){return"function"==typeof n[t-1]?e.apply(this,n):new Promise((a,i)=>{n[t-1]=(e,...t)=>e?i(e):void a(1{c(e).apply(i,n.concat(t))},a)});return i}}function f(e,t,n,a){t=t||[];var i=[],r=0,s=c(n);return e(t,(e,t,n)=>{var a=r++;s(e,(e,t)=>{i[a]=t,n(e)})},e=>{a(e,i)})}function y(e){return e&&"number"==typeof e.length&&0<=e.length&&0==e.length%1}function m(e){function t(...t){if(null!==e){var n=e;e=null,n.apply(this,t)}}return Object.assign(t,e),t}function g(e){return e[Symbol.iterator]&&e[Symbol.iterator]()}function k(e){var t=-1,n=e.length;return function a(){return++t=t||u||l||(u=!0,e.next().then(({value:e,done:t})=>{if(!(d||l))return u=!1,t?(l=!0,void(0>=p&&a(null))):void(p++,n(e,c,r),c++,i())}).catch(s))}function r(e,t){return p-=1,d?void 0:e?s(e):!1===e?(l=!0,void(d=!0)):t===be||l&&0>=p?(l=!0,a(null)):void i()}function s(e){d||(u=!1,l=!0,a(e))}let l=!1,d=!1,u=!1,p=0,c=0;i()}function O(e,t,n){function a(e,t){!1===e&&(l=!0);!0===l||(e?n(e):(++r===s||t===be)&&n(null))}n=m(n);var i=0,r=0,{length:s}=e,l=!1;for(0===s&&n(null);i{t=e,n=a}),e}function A(e,t,n){function a(e,t){k.push(()=>l(e,t))}function i(){if(!f){if(0===k.length&&0===h)return n(null,o);for(;k.length&&he()),i()}function l(e,t){if(!y){var a=L((t,...a)=>{if(h--,!1===t)return void(f=!0);if(2>a.length&&([a]=a),t){var i={};if(Object.keys(o).forEach(e=>{i[e]=o[e]}),i[e]=a,y=!0,g=Object.create(null),f)return;n(t,i)}else o[e]=a,s(e)});h++;var i=c(t[t.length-1]);1{0==--S[e]&&v.push(e)});if(t!==p)throw new Error("async.auto cannot execute tasks due to a recursive dependency")}function u(t){var n=[];return Object.keys(e).forEach(a=>{const i=e[a];Array.isArray(i)&&0<=i.indexOf(t)&&n.push(a)}),n}"number"!=typeof t&&(n=t,t=null),n=m(n||b());var p=Object.keys(e).length;if(!p)return n(null);t||(t=p);var o={},h=0,f=!1,y=!1,g=Object.create(null),k=[],v=[],S={};return Object.keys(e).forEach(t=>{var n=e[t];if(!Array.isArray(n))return a(t,[n]),void v.push(t);var i=n.slice(0,n.length-1),s=i.length;return 0===s?(a(t,n),void v.push(t)):void(S[t]=s,i.forEach(l=>{if(!e[l])throw new Error("async.auto task `"+t+"` has a non-existent dependency `"+l+"` in "+i.join(", "));r(l,()=>{s--,0===s&&a(t,n)})}))}),d(),i(),n[Ce]}function I(e){let t="",n=0,a=e.indexOf("*/");for(;ne.replace(Ne,"").trim())}function j(e,t){var n={};return Object.keys(e).forEach(t=>{function a(e,t){var n=i.map(t=>e[t]);n.push(t),c(r)(...n)}var i,r=e[t],s=d(r),l=!s&&1===r.length||s&&0===r.length;if(Array.isArray(r))i=[...r],r=i.pop(),n[t]=i.concat(0{r(e,n),t(...a)};f[e].push(n)}function r(e,t){return e?t?void(f[e]=f[e].filter(e=>e!==t)):f[e]=[]:Object.keys(f).forEach(e=>f[e]=[])}function s(e,...t){f[e].forEach(e=>e(...t))}function l(e,t,n,a){function i(e,...t){return e?n?s(e):r():1>=t.length?r(t[0]):void r(t)}if(null!=a&&"function"!=typeof a)throw new Error("task callback must be a function");k.started=!0;var r,s,l=k._createTaskItem(e,n?i:a||i);if(t?k._tasks.unshift(l):k._tasks.push(l),y||(y=!0,_e(()=>{y=!1,k.process()})),n||!a)return new Promise((e,t)=>{r=e,s=t})}function d(e){return function(t,...n){o-=1;for(var a=0,r=e.length;as("drain")),!0)}if(null==t)t=1;else if(0===t)throw new RangeError("Concurrency must not be zero");var p=c(e),o=0,h=[];const f={error:[],drain:[],saturated:[],unsaturated:[],empty:[]};var y=!1;const m=e=>t=>t?void(r(e),a(e,t)):new Promise((t,n)=>{i(e,(e,a)=>e?n(e):void t(a))});var g=!1,k={_tasks:new Ve,_createTaskItem(e,t){return{data:e,callback:t}},*[Symbol.iterator](){yield*k._tasks[Symbol.iterator]()},concurrency:t,payload:n,buffer:t/4,started:!1,paused:!1,push(e,t){return Array.isArray(e)?u(e)?void 0:e.map(e=>l(e,!1,!1,t)):l(e,!1,!1,t)},pushAsync(e,t){return Array.isArray(e)?u(e)?void 0:e.map(e=>l(e,!1,!0,t)):l(e,!1,!0,t)},kill(){r(),k._tasks.empty()},unshift(e,t){return Array.isArray(e)?u(e)?void 0:e.map(e=>l(e,!0,!1,t)):l(e,!0,!1,t)},unshiftAsync(e,t){return Array.isArray(e)?u(e)?void 0:e.map(e=>l(e,!0,!0,t)):l(e,!0,!0,t)},remove(e){k._tasks.remove(e)},process(){var e=Math.min;if(!g){for(g=!0;!k.paused&&o{t.apply(n,e.concat((e,...t)=>{a(e,t)}))},(e,t)=>a(e,...t)),a[Ce]}}function P(...e){return C(...e.reverse())}function R(...e){return function(...t){var n=t.pop();return n(null,...e)}}function z(e,t){return(n,a,i,r)=>{var s,l=!1;const d=c(i);n(a,(n,a,i)=>{d(n,(a,r)=>a||!1===a?i(a):e(r)&&!s?(l=!0,s=t(!0,n),i(null,be)):void i())},e=>e?r(e):void r(null,l?s:t(!1)))}}function N(e){return(t,...n)=>c(t)(...n,(t,...n)=>{"object"==typeof console&&(t?console.error&&console.error(t):console[e]&&n.forEach(t=>console[e](t)))})}function V(e,t,n){const a=c(t);return Xe(e,(...e)=>{const t=e.pop();a(...e,(e,n)=>t(e,!n))},n)}function Y(e){return(t,n,a)=>e(t,a)}function q(e){return d(e)?e:function(...t){var n=t.pop(),a=!0;t.push((...e)=>{a?_e(()=>n(...e)):n(...e)}),e.apply(this,t),a=!1}}function D(e,t,n,a){var r=Array(t.length);e(t,(e,t,a)=>{n(e,(e,n)=>{r[t]=!!n,a(e)})},e=>{if(e)return a(e);for(var n=[],s=0;s{n(e,(n,r)=>n?a(n):void(r&&i.push({index:t,value:e}),a(n)))},e=>e?a(e):void a(null,i.sort((e,t)=>e.index-t.index).map(e=>e.value)))}function U(e,t,n,a){var i=y(t)?D:Q;return i(e,t,c(n),a)}function G(e,t,n){return dt(e,1/0,t,n)}function W(e,t,n){return dt(e,1,t,n)}function H(e,t,n){return pt(e,1/0,t,n)}function J(e,t,n){return pt(e,1,t,n)}function K(e,t=e=>e){var a=Object.create(null),r=Object.create(null),s=c(e),l=n((e,n)=>{var d=t(...e);d in a?_e(()=>n(null,...a[d])):d in r?r[d].push(n):(r[d]=[n],s(...e,(e,...t)=>{e||(a[d]=t);var n=r[d];delete r[d];for(var s=0,u=n.length;s{n(e[0],t)},t,1)}function ee(e){return(e<<1)+1}function te(e){return(e+1>>1)-1}function ne(e,t){return e.priority===t.priority?e.pushCount({data:e,priority:t})):{data:e,priority:t}}var a=$(e,t),{push:i,pushAsync:r}=a;return a._tasks=new ht,a._createTaskItem=({data:e,priority:t},n)=>({data:e,priority:t,callback:n}),a.push=function(e,t=0,a){return i(n(e,t),a)},a.pushAsync=function(e,t=0,a){return r(n(e,t),a)},delete a.unshift,delete a.unshiftAsync,a}function ie(e,t,n,a){var i=[...e].reverse();return qe(i,t,n,a)}function re(e){var t=c(e);return n(function a(e,n){return e.push((e,...t)=>{let a={};if(e&&(a.error=e),0=t.length&&([i]=t),a.value=i}n(null,a)}),t.apply(this,e)})}function se(e){var t;return Array.isArray(e)?t=e.map(re):(t={},Object.keys(e).forEach(n=>{t[n]=re.call(this,e[n])})),t}function le(e,t,n,a){const i=c(n);return U(e,t,(e,t)=>{i(e,(e,n)=>{t(e,!n)})},a)}function de(e){return function(){return e}}function ue(e,t,n){function a(){r((e,...t)=>{!1===e||(e&&s++arguments.length&&"function"==typeof e?(n=t||b(),t=e):(pe(i,e),n=n||b()),"function"!=typeof t)throw new Error("Invalid arguments for async.retry");var r=c(t),s=1;return a(),n[Ce]}function pe(e,n){if("object"==typeof n)e.times=+n.times||kt,e.intervalFunc="function"==typeof n.interval?n.interval:de(+n.interval||vt),e.errorFilter=n.errorFilter;else if("number"==typeof n||"string"==typeof n)e.times=+n||kt;else throw new Error("Invalid arguments for async.retry")}function ce(e,t){t||(t=e,e=null);let a=e&&e.arity||t.length;d(t)&&(a+=1);var i=c(t);return n((t,n)=>{function r(e){i(...t,e)}return(t.length{function s(){var t=e.name||"anonymous",n=new Error("Callback function \""+t+"\" timed out.");n.code="ETIMEDOUT",a&&(n.info=a),d=!0,r(n)}var l,d=!1;n.push((...e)=>{d||(r(...e),clearTimeout(l))}),l=setTimeout(s,t),i(...n)})}function fe(e){for(var t=Array(e);e--;)t[e]=e;return t}function ye(e,t,n,a){var i=c(n);return De(fe(e),t,i,a)}function me(e,t,n){return ye(e,1/0,t,n)}function ge(e,t,n){return ye(e,1,t,n)}function ke(e,t,n,a){3>=arguments.length&&"function"==typeof t&&(a=n,n=t,t=Array.isArray(e)?[]:{}),a=m(a||b());var i=c(n);return Me(e,(e,n,a)=>{i(t,e,n,a)},e=>a(e,t)),a[Ce]}function ve(e){return(...t)=>(e.unmemoized||e)(...t)}function Se(e,t,n){const a=c(e);return _t(e=>a((t,n)=>e(t,!n)),t,n)}var xe,Le="function"==typeof queueMicrotask&&queueMicrotask,Ee="function"==typeof setImmediate&&setImmediate,Oe="object"==typeof process&&"function"==typeof process.nextTick;xe=Le?queueMicrotask:Ee?setImmediate:Oe?process.nextTick:a;var _e=i(xe);const be={};var Ae=e=>(t,n,a)=>{function i(e,t){if(!d)if(c-=1,e)l=!0,a(e);else if(!1===e)l=!0,d=!0;else{if(t===be||l&&0>=c)return l=!0,a(null);o||r()}}function r(){for(o=!0;c=c&&a(null));c+=1,n(t.value,t.key,L(i))}o=!1}if(a=m(a),0>=e)throw new RangeError("concurrency limit cannot be less than 1");if(!t)return a(null);if(u(t))return E(t,e,n,a);if(p(t))return E(t[Symbol.asyncIterator](),e,n,a);var s=x(t),l=!1,d=!1,c=0,o=!1;r()},Ie=o(function i(e,t,n,a){return Ae(t)(e,c(n),a)},4),Me=o(function a(e,t,n){var i=y(e)?O:_;return i(e,c(t),n)},3),je=o(function a(e,t,n){return f(Me,e,t,n)},3),we=h(je),Be=o(function a(e,t,n){return Ie(e,1,t,n)},3),Te=o(function a(e,t,n){return f(Be,e,t,n)},3),Fe=h(Te);const Ce=Symbol("promiseCallback");var Pe=/^(?:async\s)?(?:function)?\s*(?:\w+\s*)?\(([^)]+)\)(?:\s*{)/,Re=/^(?:async\s)?\s*(?:\(\s*)?((?:[^)=\s]\s*)*)(?:\)\s*)?=>/,ze=/,/,Ne=/(=.+)?(\s*)$/;class Ve{constructor(){this.head=this.tail=null,this.length=0}removeLink(e){return e.prev?e.prev.next=e.next:this.head=e.next,e.next?e.next.prev=e.prev:this.tail=e.prev,e.prev=e.next=null,this.length-=1,e}empty(){for(;this.head;)this.shift();return this}insertAfter(e,t){t.prev=e,t.next=e.next,e.next?e.next.prev=t:this.tail=t,e.next=t,this.length+=1}insertBefore(e,t){t.prev=e.prev,t.next=e,e.prev?e.prev.next=t:this.head=t,e.prev=t,this.length+=1}unshift(e){this.head?this.insertBefore(this.head,e):w(this,e)}push(e){this.tail?this.insertAfter(this.tail,e):w(this,e)}shift(){return this.head&&this.removeLink(this.head)}pop(){return this.tail&&this.removeLink(this.tail)}toArray(){return[...this]}*[Symbol.iterator](){for(var e=this.head;e;)yield e.data,e=e.next}remove(e){for(var t=this.head;t;){var{next:n}=t;e(t)&&this.removeLink(t),t=n}return this}}var Ye,qe=o(function i(e,t,n,a){a=m(a);var r=c(n);return Be(e,(e,n,a)=>{r(t,e,(e,n)=>{t=n,a(e)})},e=>a(e,t))},4),De=o(function i(e,t,n,a){return f(Ae(t),e,n,a)},4),Qe=o(function i(e,t,n,a){var r=c(n);return De(e,t,(e,t)=>{r(e,(e,...n)=>e?t(e):t(e,n))},(e,t)=>{for(var n=[],r=0;re,(e,t)=>t)(Me,e,t,n)},3),He=o(function i(e,t,n,a){return z(e=>e,(e,t)=>t)(Ae(t),e,n,a)},4),Je=o(function a(e,t,n){return z(e=>e,(e,t)=>t)(Ae(1),e,t,n)},3),Ke=N("dir"),Xe=o(function a(e,t,n){function i(e,...t){return e?n(e):void(!1===e||(s=t,d(...t,r)))}function r(e,t){return e?n(e):!1===e?void 0:t?void l(i):n(null,...s)}n=L(n);var s,l=c(e),d=c(t);return r(null,!0)},3),Ze=o(function a(e,t,n){return Me(e,Y(c(t)),n)},3),$e=o(function i(e,t,n,a){return Ae(t)(e,Y(c(n)),a)},4),et=o(function a(e,t,n){return $e(e,1,t,n)},3),tt=o(function a(e,t,n){return z(e=>!e,e=>!e)(Me,e,t,n)},3),nt=o(function i(e,t,n,a){return z(e=>!e,e=>!e)(Ae(t),e,n,a)},4),at=o(function a(e,t,n){return z(e=>!e,e=>!e)(Be,e,t,n)},3),it=o(function a(e,t,n){return U(Me,e,t,n)},3),rt=o(function i(e,t,n,a){return U(Ae(t),e,n,a)},4),st=o(function a(e,t,n){return U(Be,e,t,n)},3),lt=o(function n(e,t){function a(e){return e?i(e):void(!1===e||r(a))}var i=L(t),r=c(q(e));return a()},2),dt=o(function i(e,t,n,a){var r=c(n);return De(e,t,(e,t)=>{r(e,(n,a)=>n?t(n):t(n,{key:a,val:e}))},(e,t)=>{for(var n={},{hasOwnProperty:r}=Object.prototype,s=0;s{s(e,t,(e,a)=>e?n(e):void(r[t]=a,n(e)))},e=>a(e,r))},4);Ye=Oe?process.nextTick:Ee?setImmediate:a;var ct=i(Ye),ot=o((e,t,n)=>{var a=y(t)?[]:{};e(t,(e,t,n)=>{c(e)((e,...i)=>{2>i.length&&([i]=i),a[t]=i,n(e)})},e=>n(e,a))},3);class ht{constructor(){this.heap=[],this.pushCount=Number.MIN_SAFE_INTEGER}get length(){return this.heap.length}empty(){return this.heap=[],this}percUp(e){for(let n;0e)(Me,e,t,n)},3),xt=o(function i(e,t,n,a){return z(Boolean,e=>e)(Ae(t),e,n,a)},4),Lt=o(function a(e,t,n){return z(Boolean,e=>e)(Be,e,t,n)},3),Et=o(function a(e,t,n){function i(e,t){var n=e.criteria,a=t.criteria;return na?1:0}var r=c(t);return je(e,(e,t)=>{r(e,(n,a)=>n?t(n):void t(n,{value:e,criteria:a}))},(e,t)=>e?n(e):void n(null,t.sort(i).map(e=>e.value)))},3),Ot=o(function n(e,t){var a,i=null;return et(e,(e,t)=>{c(e)((e,...n)=>!1===e?t(e):void(2>n.length?[a]=n:a=n,i=e,t(e?null:{})))},()=>t(i,a))}),_t=o(function a(e,t,n){function i(e,...t){if(e)return n(e);d=t;!1===e||l(r)}function r(e,t){return e?n(e):!1===e?void 0:t?void s(i):n(null,...d)}n=L(n);var s=c(t),l=c(e),d=[];return l(r)},3),bt=o(function n(e,t){function a(t){var n=c(e[r++]);n(...t,L(i))}function i(n,...i){return!1===n?void 0:n||r===e.length?t(n,...i):void a(i)}if(t=m(t),!Array.isArray(e))return t(new Error("First argument to waterfall must be an array of functions"));if(!e.length)return t();var r=0;a([])});e.all=tt,e.allLimit=nt,e.allSeries=at,e.any=St,e.anyLimit=xt,e.anySeries=Lt,e.apply=t,e.applyEach=we,e.applyEachSeries=Fe,e.asyncify=r,e.auto=A,e.autoInject=j,e.cargo=T,e.cargoQueue=F,e.compose=P,e.concat=Ue,e.concatLimit=Qe,e.concatSeries=Ge,e.constant=R,e.default={apply:t,applyEach:we,applyEachSeries:Fe,asyncify:r,auto:A,autoInject:j,cargo:T,cargoQueue:F,compose:P,concat:Ue,concatLimit:Qe,concatSeries:Ge,constant:R,detect:We,detectLimit:He,detectSeries:Je,dir:Ke,doUntil:V,doWhilst:Xe,each:Ze,eachLimit:$e,eachOf:Me,eachOfLimit:Ie,eachOfSeries:Be,eachSeries:et,ensureAsync:q,every:tt,everyLimit:nt,everySeries:at,filter:it,filterLimit:rt,filterSeries:st,forever:lt,groupBy:G,groupByLimit:dt,groupBySeries:W,log:ut,map:je,mapLimit:De,mapSeries:Te,mapValues:H,mapValuesLimit:pt,mapValuesSeries:J,memoize:K,nextTick:ct,parallel:X,parallelLimit:Z,priorityQueue:ae,queue:$,race:ft,reduce:qe,reduceRight:ie,reflect:re,reflectAll:se,reject:yt,rejectLimit:mt,rejectSeries:gt,retry:ue,retryable:ce,seq:C,series:oe,setImmediate:_e,some:St,someLimit:xt,someSeries:Lt,sortBy:Et,timeout:he,times:me,timesLimit:ye,timesSeries:ge,transform:ke,tryEach:Ot,unmemoize:ve,until:Se,waterfall:bt,whilst:_t,all:tt,allLimit:nt,allSeries:at,any:St,anyLimit:xt,anySeries:Lt,find:We,findLimit:He,findSeries:Je,flatMap:Ue,flatMapLimit:Qe,flatMapSeries:Ge,forEach:Ze,forEachSeries:et,forEachLimit:$e,forEachOf:Me,forEachOfSeries:Be,forEachOfLimit:Ie,inject:qe,foldl:qe,foldr:ie,select:it,selectLimit:rt,selectSeries:st,wrapSync:r,during:_t,doDuring:Xe},e.detect=We,e.detectLimit=He,e.detectSeries=Je,e.dir=Ke,e.doDuring=Xe,e.doUntil=V,e.doWhilst=Xe,e.during=_t,e.each=Ze,e.eachLimit=$e,e.eachOf=Me,e.eachOfLimit=Ie,e.eachOfSeries=Be,e.eachSeries=et,e.ensureAsync=q,e.every=tt,e.everyLimit=nt,e.everySeries=at,e.filter=it,e.filterLimit=rt,e.filterSeries=st,e.find=We,e.findLimit=He,e.findSeries=Je,e.flatMap=Ue,e.flatMapLimit=Qe,e.flatMapSeries=Ge,e.foldl=qe,e.foldr=ie,e.forEach=Ze,e.forEachLimit=$e,e.forEachOf=Me,e.forEachOfLimit=Ie,e.forEachOfSeries=Be,e.forEachSeries=et,e.forever=lt,e.groupBy=G,e.groupByLimit=dt,e.groupBySeries=W,e.inject=qe,e.log=ut,e.map=je,e.mapLimit=De,e.mapSeries=Te,e.mapValues=H,e.mapValuesLimit=pt,e.mapValuesSeries=J,e.memoize=K,e.nextTick=ct,e.parallel=X,e.parallelLimit=Z,e.priorityQueue=ae,e.queue=$,e.race=ft,e.reduce=qe,e.reduceRight=ie,e.reflect=re,e.reflectAll=se,e.reject=yt,e.rejectLimit=mt,e.rejectSeries=gt,e.retry=ue,e.retryable=ce,e.select=it,e.selectLimit=rt,e.selectSeries=st,e.seq=C,e.series=oe,e.setImmediate=_e,e.some=St,e.someLimit=xt,e.someSeries=Lt,e.sortBy=Et,e.timeout=he,e.times=me,e.timesLimit=ye,e.timesSeries=ge,e.transform=ke,e.tryEach=Ot,e.unmemoize=ve,e.until=Se,e.waterfall=bt,e.whilst=_t,e.wrapSync=r,Object.defineProperty(e,"__esModule",{value:!0})}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.mjs b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.mjs new file mode 100644 index 0000000..2c59965 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/dist/async.mjs @@ -0,0 +1,5948 @@ +/** + * Creates a continuation function with some arguments already applied. + * + * Useful as a shorthand when combined with other control flow functions. Any + * arguments passed to the returned function are added to the arguments + * originally passed to apply. + * + * @name apply + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {Function} fn - The function you want to eventually apply all + * arguments to. Invokes with (arguments...). + * @param {...*} arguments... - Any number of arguments to automatically apply + * when the continuation is called. + * @returns {Function} the partially-applied function + * @example + * + * // using apply + * async.parallel([ + * async.apply(fs.writeFile, 'testfile1', 'test1'), + * async.apply(fs.writeFile, 'testfile2', 'test2') + * ]); + * + * + * // the same process without using apply + * async.parallel([ + * function(callback) { + * fs.writeFile('testfile1', 'test1', callback); + * }, + * function(callback) { + * fs.writeFile('testfile2', 'test2', callback); + * } + * ]); + * + * // It's possible to pass any number of additional arguments when calling the + * // continuation: + * + * node> var fn = async.apply(sys.puts, 'one'); + * node> fn('two', 'three'); + * one + * two + * three + */ +function apply(fn, ...args) { + return (...callArgs) => fn(...args,...callArgs); +} + +function initialParams (fn) { + return function (...args/*, callback*/) { + var callback = args.pop(); + return fn.call(this, args, callback); + }; +} + +/* istanbul ignore file */ + +var hasQueueMicrotask = typeof queueMicrotask === 'function' && queueMicrotask; +var hasSetImmediate = typeof setImmediate === 'function' && setImmediate; +var hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function'; + +function fallback(fn) { + setTimeout(fn, 0); +} + +function wrap(defer) { + return (fn, ...args) => defer(() => fn(...args)); +} + +var _defer$1; + +if (hasQueueMicrotask) { + _defer$1 = queueMicrotask; +} else if (hasSetImmediate) { + _defer$1 = setImmediate; +} else if (hasNextTick) { + _defer$1 = process.nextTick; +} else { + _defer$1 = fallback; +} + +var setImmediate$1 = wrap(_defer$1); + +/** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2017 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function, or Promise-returning + * function to convert to an {@link AsyncFunction}. + * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be + * invoked with `(args..., callback)`. + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es2017 example, though `asyncify` is not needed if your JS environment + * // supports async functions out of the box + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ +function asyncify(func) { + if (isAsync(func)) { + return function (...args/*, callback*/) { + const callback = args.pop(); + const promise = func.apply(this, args); + return handlePromise(promise, callback) + } + } + + return initialParams(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if (result && typeof result.then === 'function') { + return handlePromise(result, callback) + } else { + callback(null, result); + } + }); +} + +function handlePromise(promise, callback) { + return promise.then(value => { + invokeCallback(callback, null, value); + }, err => { + invokeCallback(callback, err && (err instanceof Error || err.message) ? err : new Error(err)); + }); +} + +function invokeCallback(callback, error, value) { + try { + callback(error, value); + } catch (err) { + setImmediate$1(e => { throw e }, err); + } +} + +function isAsync(fn) { + return fn[Symbol.toStringTag] === 'AsyncFunction'; +} + +function isAsyncGenerator(fn) { + return fn[Symbol.toStringTag] === 'AsyncGenerator'; +} + +function isAsyncIterable(obj) { + return typeof obj[Symbol.asyncIterator] === 'function'; +} + +function wrapAsync(asyncFn) { + if (typeof asyncFn !== 'function') throw new Error('expected a function') + return isAsync(asyncFn) ? asyncify(asyncFn) : asyncFn; +} + +// conditionally promisify a function. +// only return a promise if a callback is omitted +function awaitify (asyncFn, arity) { + if (!arity) arity = asyncFn.length; + if (!arity) throw new Error('arity is undefined') + function awaitable (...args) { + if (typeof args[arity - 1] === 'function') { + return asyncFn.apply(this, args) + } + + return new Promise((resolve, reject) => { + args[arity - 1] = (err, ...cbArgs) => { + if (err) return reject(err) + resolve(cbArgs.length > 1 ? cbArgs : cbArgs[0]); + }; + asyncFn.apply(this, args); + }) + } + + return awaitable +} + +function applyEach$1 (eachfn) { + return function applyEach(fns, ...callArgs) { + const go = awaitify(function (callback) { + var that = this; + return eachfn(fns, (fn, cb) => { + wrapAsync(fn).apply(that, callArgs.concat(cb)); + }, callback); + }); + return go; + }; +} + +function _asyncMap(eachfn, arr, iteratee, callback) { + arr = arr || []; + var results = []; + var counter = 0; + var _iteratee = wrapAsync(iteratee); + + return eachfn(arr, (value, _, iterCb) => { + var index = counter++; + _iteratee(value, (err, v) => { + results[index] = v; + iterCb(err); + }); + }, err => { + callback(err, results); + }); +} + +function isArrayLike(value) { + return value && + typeof value.length === 'number' && + value.length >= 0 && + value.length % 1 === 0; +} + +// A temporary value used to identify if the loop should be broken. +// See #1064, #1293 +const breakLoop = {}; + +function once(fn) { + function wrapper (...args) { + if (fn === null) return; + var callFn = fn; + fn = null; + callFn.apply(this, args); + } + Object.assign(wrapper, fn); + return wrapper +} + +function getIterator (coll) { + return coll[Symbol.iterator] && coll[Symbol.iterator](); +} + +function createArrayIterator(coll) { + var i = -1; + var len = coll.length; + return function next() { + return ++i < len ? {value: coll[i], key: i} : null; + } +} + +function createES2015Iterator(iterator) { + var i = -1; + return function next() { + var item = iterator.next(); + if (item.done) + return null; + i++; + return {value: item.value, key: i}; + } +} + +function createObjectIterator(obj) { + var okeys = obj ? Object.keys(obj) : []; + var i = -1; + var len = okeys.length; + return function next() { + var key = okeys[++i]; + if (key === '__proto__') { + return next(); + } + return i < len ? {value: obj[key], key} : null; + }; +} + +function createIterator(coll) { + if (isArrayLike(coll)) { + return createArrayIterator(coll); + } + + var iterator = getIterator(coll); + return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll); +} + +function onlyOnce(fn) { + return function (...args) { + if (fn === null) throw new Error("Callback was already called."); + var callFn = fn; + fn = null; + callFn.apply(this, args); + }; +} + +// for async generators +function asyncEachOfLimit(generator, limit, iteratee, callback) { + let done = false; + let canceled = false; + let awaiting = false; + let running = 0; + let idx = 0; + + function replenish() { + //console.log('replenish') + if (running >= limit || awaiting || done) return + //console.log('replenish awaiting') + awaiting = true; + generator.next().then(({value, done: iterDone}) => { + //console.log('got value', value) + if (canceled || done) return + awaiting = false; + if (iterDone) { + done = true; + if (running <= 0) { + //console.log('done nextCb') + callback(null); + } + return; + } + running++; + iteratee(value, idx, iterateeCallback); + idx++; + replenish(); + }).catch(handleError); + } + + function iterateeCallback(err, result) { + //console.log('iterateeCallback') + running -= 1; + if (canceled) return + if (err) return handleError(err) + + if (err === false) { + done = true; + canceled = true; + return + } + + if (result === breakLoop || (done && running <= 0)) { + done = true; + //console.log('done iterCb') + return callback(null); + } + replenish(); + } + + function handleError(err) { + if (canceled) return + awaiting = false; + done = true; + callback(err); + } + + replenish(); +} + +var eachOfLimit$2 = (limit) => { + return (obj, iteratee, callback) => { + callback = once(callback); + if (limit <= 0) { + throw new RangeError('concurrency limit cannot be less than 1') + } + if (!obj) { + return callback(null); + } + if (isAsyncGenerator(obj)) { + return asyncEachOfLimit(obj, limit, iteratee, callback) + } + if (isAsyncIterable(obj)) { + return asyncEachOfLimit(obj[Symbol.asyncIterator](), limit, iteratee, callback) + } + var nextElem = createIterator(obj); + var done = false; + var canceled = false; + var running = 0; + var looping = false; + + function iterateeCallback(err, value) { + if (canceled) return + running -= 1; + if (err) { + done = true; + callback(err); + } + else if (err === false) { + done = true; + canceled = true; + } + else if (value === breakLoop || (done && running <= 0)) { + done = true; + return callback(null); + } + else if (!looping) { + replenish(); + } + } + + function replenish () { + looping = true; + while (running < limit && !done) { + var elem = nextElem(); + if (elem === null) { + done = true; + if (running <= 0) { + callback(null); + } + return; + } + running += 1; + iteratee(elem.value, elem.key, onlyOnce(iterateeCallback)); + } + looping = false; + } + + replenish(); + }; +}; + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfLimit(coll, limit, iteratee, callback) { + return eachOfLimit$2(limit)(coll, wrapAsync(iteratee), callback); +} + +var eachOfLimit$1 = awaitify(eachOfLimit, 4); + +// eachOf implementation optimized for array-likes +function eachOfArrayLike(coll, iteratee, callback) { + callback = once(callback); + var index = 0, + completed = 0, + {length} = coll, + canceled = false; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err, value) { + if (err === false) { + canceled = true; + } + if (canceled === true) return + if (err) { + callback(err); + } else if ((++completed === length) || value === breakLoop) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, onlyOnce(iteratorCallback)); + } +} + +// a generic version of eachOf which can handle array, object, and iterator cases. +function eachOfGeneric (coll, iteratee, callback) { + return eachOfLimit$1(coll, Infinity, iteratee, callback); +} + +/** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each + * item in `coll`. + * The `key` is the item's key, or index in the case of an array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dev.json is a file containing a valid json object config for dev environment + * // dev.json is a file containing a valid json object config for test environment + * // prod.json is a file containing a valid json object config for prod environment + * // invalid.json is a file with a malformed json object + * + * let configs = {}; //global variable + * let validConfigFileMap = {dev: 'dev.json', test: 'test.json', prod: 'prod.json'}; + * let invalidConfigFileMap = {dev: 'dev.json', test: 'test.json', invalid: 'invalid.json'}; + * + * // asynchronous function that reads a json file and parses the contents as json object + * function parseFile(file, key, callback) { + * fs.readFile(file, "utf8", function(err, data) { + * if (err) return calback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * } + * + * // Using callbacks + * async.forEachOf(validConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * } else { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * // JSON parse error exception + * } else { + * console.log(configs); + * } + * }); + * + * // Using Promises + * async.forEachOf(validConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * }).catch( err => { + * console.error(err); + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * }).catch( err => { + * console.error(err); + * // JSON parse error exception + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.forEachOf(validConfigFileMap, parseFile); + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * catch (err) { + * console.log(err); + * } + * } + * + * //Error handing + * async () => { + * try { + * let result = await async.forEachOf(invalidConfigFileMap, parseFile); + * console.log(configs); + * } + * catch (err) { + * console.log(err); + * // JSON parse error exception + * } + * } + * + */ +function eachOf(coll, iteratee, callback) { + var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric; + return eachOfImplementation(coll, wrapAsync(iteratee), callback); +} + +var eachOf$1 = awaitify(eachOf, 3); + +/** + * Produces a new collection of values by mapping each value in `coll` through + * the `iteratee` function. The `iteratee` is called with an item from `coll` + * and a callback for when it has finished processing. Each of these callbacks + * takes 2 arguments: an `error`, and the transformed item from `coll`. If + * `iteratee` passes an error to its callback, the main `callback` (for the + * `map` function) is immediately called with the error. + * + * Note, that since this function applies the `iteratee` to each item in + * parallel, there is no guarantee that the `iteratee` functions will complete + * in order. However, the results array will be in the same order as the + * original `coll`. + * + * If `map` is passed an Object, the results will be an Array. The results + * will roughly be in the order of the original Objects' keys (but this can + * vary across JavaScript engines). + * + * @name map + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an Array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.map(fileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.map(fileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.map(fileList, getFileSizeInBytes); + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.map(withMissingFileList, getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function map (coll, iteratee, callback) { + return _asyncMap(eachOf$1, coll, iteratee, callback) +} +var map$1 = awaitify(map, 3); + +/** + * Applies the provided arguments to each function in the array, calling + * `callback` after all functions have completed. If you only provide the first + * argument, `fns`, then it will return a function which lets you pass in the + * arguments as if it were a single function call. If more arguments are + * provided, `callback` is required while `args` is still optional. The results + * for each of the applied async functions are passed to the final callback + * as an array. + * + * @name applyEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s + * to all call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - Returns a function that takes no args other than + * an optional callback, that is the result of applying the `args` to each + * of the functions. + * @example + * + * const appliedFn = async.applyEach([enableSearch, updateSchema], 'bucket') + * + * appliedFn((err, results) => { + * // results[0] is the results for `enableSearch` + * // results[1] is the results for `updateSchema` + * }); + * + * // partial application example: + * async.each( + * buckets, + * async (bucket) => async.applyEach([enableSearch, updateSchema], bucket)(), + * callback + * ); + */ +var applyEach = applyEach$1(map$1); + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time. + * + * @name eachOfSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfSeries(coll, iteratee, callback) { + return eachOfLimit$1(coll, 1, iteratee, callback) +} +var eachOfSeries$1 = awaitify(eachOfSeries, 3); + +/** + * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time. + * + * @name mapSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function mapSeries (coll, iteratee, callback) { + return _asyncMap(eachOfSeries$1, coll, iteratee, callback) +} +var mapSeries$1 = awaitify(mapSeries, 3); + +/** + * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time. + * + * @name applyEachSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.applyEach]{@link module:ControlFlow.applyEach} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} fns - A collection of {@link AsyncFunction}s to all + * call with the same arguments + * @param {...*} [args] - any number of separate arguments to pass to the + * function. + * @param {Function} [callback] - the final argument should be the callback, + * called when all functions have completed processing. + * @returns {AsyncFunction} - A function, that when called, is the result of + * appling the `args` to the list of functions. It takes no args, other than + * a callback. + */ +var applyEachSeries = applyEach$1(mapSeries$1); + +const PROMISE_SYMBOL = Symbol('promiseCallback'); + +function promiseCallback () { + let resolve, reject; + function callback (err, ...args) { + if (err) return reject(err) + resolve(args.length > 1 ? args : args[0]); + } + + callback[PROMISE_SYMBOL] = new Promise((res, rej) => { + resolve = res, + reject = rej; + }); + + return callback +} + +/** + * Determines the best order for running the {@link AsyncFunction}s in `tasks`, based on + * their requirements. Each function can optionally depend on other functions + * being completed first, and each function is run as soon as its requirements + * are satisfied. + * + * If any of the {@link AsyncFunction}s pass an error to their callback, the `auto` sequence + * will stop. Further tasks will not execute (so any other functions depending + * on it will not run), and the main `callback` is immediately called with the + * error. + * + * {@link AsyncFunction}s also receive an object containing the results of functions which + * have completed so far as the first argument, if they have dependencies. If a + * task function has no dependencies, it will only be passed a callback. + * + * @name auto + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Object} tasks - An object. Each of its properties is either a + * function or an array of requirements, with the {@link AsyncFunction} itself the last item + * in the array. The object's key of a property serves as the name of the task + * defined by that property, i.e. can be used when specifying requirements for + * other tasks. The function receives one or two arguments: + * * a `results` object, containing the results of the previously executed + * functions, only passed if the task has any dependencies, + * * a `callback(err, result)` function, which must be called when finished, + * passing an `error` (which can be `null`) and the result of the function's + * execution. + * @param {number} [concurrency=Infinity] - An optional `integer` for + * determining the maximum number of tasks that can be run in parallel. By + * default, as many as possible. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback. Results are always returned; however, if an + * error occurs, no further `tasks` will be performed, and the results object + * will only contain partial results. Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * @example + * + * //Using Callbacks + * async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }, function(err, results) { + * if (err) { + * console.log('err = ', err); + * } + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }); + * + * //Using Promises + * async.auto({ + * get_data: function(callback) { + * console.log('in get_data'); + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * console.log('in make_folder'); + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }).then(results => { + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * }).catch(err => { + * console.log('err = ', err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.auto({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: ['get_data', 'make_folder', function(results, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(results, callback) { + * // once the file is written let's email a link to it... + * callback(null, {'file':results.write_file, 'email':'user@example.com'}); + * }] + * }); + * console.log('results = ', results); + * // results = { + * // get_data: ['data', 'converted to array'] + * // make_folder; 'folder', + * // write_file: 'filename' + * // email_link: { file: 'filename', email: 'user@example.com' } + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function auto(tasks, concurrency, callback) { + if (typeof concurrency !== 'number') { + // concurrency is optional, shift the args. + callback = concurrency; + concurrency = null; + } + callback = once(callback || promiseCallback()); + var numTasks = Object.keys(tasks).length; + if (!numTasks) { + return callback(null); + } + if (!concurrency) { + concurrency = numTasks; + } + + var results = {}; + var runningTasks = 0; + var canceled = false; + var hasError = false; + + var listeners = Object.create(null); + + var readyTasks = []; + + // for cycle detection: + var readyToCheck = []; // tasks that have been identified as reachable + // without the possibility of returning to an ancestor task + var uncheckedDependencies = {}; + + Object.keys(tasks).forEach(key => { + var task = tasks[key]; + if (!Array.isArray(task)) { + // no dependencies + enqueueTask(key, [task]); + readyToCheck.push(key); + return; + } + + var dependencies = task.slice(0, task.length - 1); + var remainingDependencies = dependencies.length; + if (remainingDependencies === 0) { + enqueueTask(key, task); + readyToCheck.push(key); + return; + } + uncheckedDependencies[key] = remainingDependencies; + + dependencies.forEach(dependencyName => { + if (!tasks[dependencyName]) { + throw new Error('async.auto task `' + key + + '` has a non-existent dependency `' + + dependencyName + '` in ' + + dependencies.join(', ')); + } + addListener(dependencyName, () => { + remainingDependencies--; + if (remainingDependencies === 0) { + enqueueTask(key, task); + } + }); + }); + }); + + checkForDeadlocks(); + processQueue(); + + function enqueueTask(key, task) { + readyTasks.push(() => runTask(key, task)); + } + + function processQueue() { + if (canceled) return + if (readyTasks.length === 0 && runningTasks === 0) { + return callback(null, results); + } + while(readyTasks.length && runningTasks < concurrency) { + var run = readyTasks.shift(); + run(); + } + + } + + function addListener(taskName, fn) { + var taskListeners = listeners[taskName]; + if (!taskListeners) { + taskListeners = listeners[taskName] = []; + } + + taskListeners.push(fn); + } + + function taskComplete(taskName) { + var taskListeners = listeners[taskName] || []; + taskListeners.forEach(fn => fn()); + processQueue(); + } + + + function runTask(key, task) { + if (hasError) return; + + var taskCallback = onlyOnce((err, ...result) => { + runningTasks--; + if (err === false) { + canceled = true; + return + } + if (result.length < 2) { + [result] = result; + } + if (err) { + var safeResults = {}; + Object.keys(results).forEach(rkey => { + safeResults[rkey] = results[rkey]; + }); + safeResults[key] = result; + hasError = true; + listeners = Object.create(null); + if (canceled) return + callback(err, safeResults); + } else { + results[key] = result; + taskComplete(key); + } + }); + + runningTasks++; + var taskFn = wrapAsync(task[task.length - 1]); + if (task.length > 1) { + taskFn(results, taskCallback); + } else { + taskFn(taskCallback); + } + } + + function checkForDeadlocks() { + // Kahn's algorithm + // https://en.wikipedia.org/wiki/Topological_sorting#Kahn.27s_algorithm + // http://connalle.blogspot.com/2013/10/topological-sortingkahn-algorithm.html + var currentTask; + var counter = 0; + while (readyToCheck.length) { + currentTask = readyToCheck.pop(); + counter++; + getDependents(currentTask).forEach(dependent => { + if (--uncheckedDependencies[dependent] === 0) { + readyToCheck.push(dependent); + } + }); + } + + if (counter !== numTasks) { + throw new Error( + 'async.auto cannot execute tasks due to a recursive dependency' + ); + } + } + + function getDependents(taskName) { + var result = []; + Object.keys(tasks).forEach(key => { + const task = tasks[key]; + if (Array.isArray(task) && task.indexOf(taskName) >= 0) { + result.push(key); + } + }); + return result; + } + + return callback[PROMISE_SYMBOL] +} + +var FN_ARGS = /^(?:async\s)?(?:function)?\s*(?:\w+\s*)?\(([^)]+)\)(?:\s*{)/; +var ARROW_FN_ARGS = /^(?:async\s)?\s*(?:\(\s*)?((?:[^)=\s]\s*)*)(?:\)\s*)?=>/; +var FN_ARG_SPLIT = /,/; +var FN_ARG = /(=.+)?(\s*)$/; + +function stripComments(string) { + let stripped = ''; + let index = 0; + let endBlockComment = string.indexOf('*/'); + while (index < string.length) { + if (string[index] === '/' && string[index+1] === '/') { + // inline comment + let endIndex = string.indexOf('\n', index); + index = (endIndex === -1) ? string.length : endIndex; + } else if ((endBlockComment !== -1) && (string[index] === '/') && (string[index+1] === '*')) { + // block comment + let endIndex = string.indexOf('*/', index); + if (endIndex !== -1) { + index = endIndex + 2; + endBlockComment = string.indexOf('*/', index); + } else { + stripped += string[index]; + index++; + } + } else { + stripped += string[index]; + index++; + } + } + return stripped; +} + +function parseParams(func) { + const src = stripComments(func.toString()); + let match = src.match(FN_ARGS); + if (!match) { + match = src.match(ARROW_FN_ARGS); + } + if (!match) throw new Error('could not parse args in autoInject\nSource:\n' + src) + let [, args] = match; + return args + .replace(/\s/g, '') + .split(FN_ARG_SPLIT) + .map((arg) => arg.replace(FN_ARG, '').trim()); +} + +/** + * A dependency-injected version of the [async.auto]{@link module:ControlFlow.auto} function. Dependent + * tasks are specified as parameters to the function, after the usual callback + * parameter, with the parameter names matching the names of the tasks it + * depends on. This can provide even more readable task graphs which can be + * easier to maintain. + * + * If a final callback is specified, the task results are similarly injected, + * specified as named parameters after the initial error parameter. + * + * The autoInject function is purely syntactic sugar and its semantics are + * otherwise equivalent to [async.auto]{@link module:ControlFlow.auto}. + * + * @name autoInject + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.auto]{@link module:ControlFlow.auto} + * @category Control Flow + * @param {Object} tasks - An object, each of whose properties is an {@link AsyncFunction} of + * the form 'func([dependencies...], callback). The object's key of a property + * serves as the name of the task defined by that property, i.e. can be used + * when specifying requirements for other tasks. + * * The `callback` parameter is a `callback(err, result)` which must be called + * when finished, passing an `error` (which can be `null`) and the result of + * the function's execution. The remaining parameters name other tasks on + * which the task is dependent, and the results from those tasks are the + * arguments of those parameters. + * @param {Function} [callback] - An optional callback which is called when all + * the tasks have been completed. It receives the `err` argument if any `tasks` + * pass an error to their callback, and a `results` object with any completed + * task results, similar to `auto`. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // The example from `auto` can be rewritten as follows: + * async.autoInject({ + * get_data: function(callback) { + * // async code to get some data + * callback(null, 'data', 'converted to array'); + * }, + * make_folder: function(callback) { + * // async code to create a directory to store a file in + * // this is run at the same time as getting the data + * callback(null, 'folder'); + * }, + * write_file: function(get_data, make_folder, callback) { + * // once there is some data and the directory exists, + * // write the data to a file in the directory + * callback(null, 'filename'); + * }, + * email_link: function(write_file, callback) { + * // once the file is written let's email a link to it... + * // write_file contains the filename returned by write_file. + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * } + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + * + * // If you are using a JS minifier that mangles parameter names, `autoInject` + * // will not work with plain functions, since the parameter names will be + * // collapsed to a single letter identifier. To work around this, you can + * // explicitly specify the names of the parameters your task function needs + * // in an array, similar to Angular.js dependency injection. + * + * // This still has an advantage over plain `auto`, since the results a task + * // depends on are still spread into arguments. + * async.autoInject({ + * //... + * write_file: ['get_data', 'make_folder', function(get_data, make_folder, callback) { + * callback(null, 'filename'); + * }], + * email_link: ['write_file', function(write_file, callback) { + * callback(null, {'file':write_file, 'email':'user@example.com'}); + * }] + * //... + * }, function(err, results) { + * console.log('err = ', err); + * console.log('email_link = ', results.email_link); + * }); + */ +function autoInject(tasks, callback) { + var newTasks = {}; + + Object.keys(tasks).forEach(key => { + var taskFn = tasks[key]; + var params; + var fnIsAsync = isAsync(taskFn); + var hasNoDeps = + (!fnIsAsync && taskFn.length === 1) || + (fnIsAsync && taskFn.length === 0); + + if (Array.isArray(taskFn)) { + params = [...taskFn]; + taskFn = params.pop(); + + newTasks[key] = params.concat(params.length > 0 ? newTask : taskFn); + } else if (hasNoDeps) { + // no dependencies, use the function as-is + newTasks[key] = taskFn; + } else { + params = parseParams(taskFn); + if ((taskFn.length === 0 && !fnIsAsync) && params.length === 0) { + throw new Error("autoInject task functions require explicit parameters."); + } + + // remove callback param + if (!fnIsAsync) params.pop(); + + newTasks[key] = params.concat(newTask); + } + + function newTask(results, taskCb) { + var newArgs = params.map(name => results[name]); + newArgs.push(taskCb); + wrapAsync(taskFn)(...newArgs); + } + }); + + return auto(newTasks, callback); +} + +// Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation +// used for queues. This implementation assumes that the node provided by the user can be modified +// to adjust the next and last properties. We implement only the minimal functionality +// for queue support. +class DLL { + constructor() { + this.head = this.tail = null; + this.length = 0; + } + + removeLink(node) { + if (node.prev) node.prev.next = node.next; + else this.head = node.next; + if (node.next) node.next.prev = node.prev; + else this.tail = node.prev; + + node.prev = node.next = null; + this.length -= 1; + return node; + } + + empty () { + while(this.head) this.shift(); + return this; + } + + insertAfter(node, newNode) { + newNode.prev = node; + newNode.next = node.next; + if (node.next) node.next.prev = newNode; + else this.tail = newNode; + node.next = newNode; + this.length += 1; + } + + insertBefore(node, newNode) { + newNode.prev = node.prev; + newNode.next = node; + if (node.prev) node.prev.next = newNode; + else this.head = newNode; + node.prev = newNode; + this.length += 1; + } + + unshift(node) { + if (this.head) this.insertBefore(this.head, node); + else setInitial(this, node); + } + + push(node) { + if (this.tail) this.insertAfter(this.tail, node); + else setInitial(this, node); + } + + shift() { + return this.head && this.removeLink(this.head); + } + + pop() { + return this.tail && this.removeLink(this.tail); + } + + toArray() { + return [...this] + } + + *[Symbol.iterator] () { + var cur = this.head; + while (cur) { + yield cur.data; + cur = cur.next; + } + } + + remove (testFn) { + var curr = this.head; + while(curr) { + var {next} = curr; + if (testFn(curr)) { + this.removeLink(curr); + } + curr = next; + } + return this; + } +} + +function setInitial(dll, node) { + dll.length = 1; + dll.head = dll.tail = node; +} + +function queue$1(worker, concurrency, payload) { + if (concurrency == null) { + concurrency = 1; + } + else if(concurrency === 0) { + throw new RangeError('Concurrency must not be zero'); + } + + var _worker = wrapAsync(worker); + var numRunning = 0; + var workersList = []; + const events = { + error: [], + drain: [], + saturated: [], + unsaturated: [], + empty: [] + }; + + function on (event, handler) { + events[event].push(handler); + } + + function once (event, handler) { + const handleAndRemove = (...args) => { + off(event, handleAndRemove); + handler(...args); + }; + events[event].push(handleAndRemove); + } + + function off (event, handler) { + if (!event) return Object.keys(events).forEach(ev => events[ev] = []) + if (!handler) return events[event] = [] + events[event] = events[event].filter(ev => ev !== handler); + } + + function trigger (event, ...args) { + events[event].forEach(handler => handler(...args)); + } + + var processingScheduled = false; + function _insert(data, insertAtFront, rejectOnError, callback) { + if (callback != null && typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + + var res, rej; + function promiseCallback (err, ...args) { + // we don't care about the error, let the global error handler + // deal with it + if (err) return rejectOnError ? rej(err) : res() + if (args.length <= 1) return res(args[0]) + res(args); + } + + var item = q._createTaskItem( + data, + rejectOnError ? promiseCallback : + (callback || promiseCallback) + ); + + if (insertAtFront) { + q._tasks.unshift(item); + } else { + q._tasks.push(item); + } + + if (!processingScheduled) { + processingScheduled = true; + setImmediate$1(() => { + processingScheduled = false; + q.process(); + }); + } + + if (rejectOnError || !callback) { + return new Promise((resolve, reject) => { + res = resolve; + rej = reject; + }) + } + } + + function _createCB(tasks) { + return function (err, ...args) { + numRunning -= 1; + + for (var i = 0, l = tasks.length; i < l; i++) { + var task = tasks[i]; + + var index = workersList.indexOf(task); + if (index === 0) { + workersList.shift(); + } else if (index > 0) { + workersList.splice(index, 1); + } + + task.callback(err, ...args); + + if (err != null) { + trigger('error', err, task.data); + } + } + + if (numRunning <= (q.concurrency - q.buffer) ) { + trigger('unsaturated'); + } + + if (q.idle()) { + trigger('drain'); + } + q.process(); + }; + } + + function _maybeDrain(data) { + if (data.length === 0 && q.idle()) { + // call drain immediately if there are no tasks + setImmediate$1(() => trigger('drain')); + return true + } + return false + } + + const eventMethod = (name) => (handler) => { + if (!handler) { + return new Promise((resolve, reject) => { + once(name, (err, data) => { + if (err) return reject(err) + resolve(data); + }); + }) + } + off(name); + on(name, handler); + + }; + + var isProcessing = false; + var q = { + _tasks: new DLL(), + _createTaskItem (data, callback) { + return { + data, + callback + }; + }, + *[Symbol.iterator] () { + yield* q._tasks[Symbol.iterator](); + }, + concurrency, + payload, + buffer: concurrency / 4, + started: false, + paused: false, + push (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, false, false, callback)) + } + return _insert(data, false, false, callback); + }, + pushAsync (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, false, true, callback)) + } + return _insert(data, false, true, callback); + }, + kill () { + off(); + q._tasks.empty(); + }, + unshift (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, true, false, callback)) + } + return _insert(data, true, false, callback); + }, + unshiftAsync (data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return + return data.map(datum => _insert(datum, true, true, callback)) + } + return _insert(data, true, true, callback); + }, + remove (testFn) { + q._tasks.remove(testFn); + }, + process () { + // Avoid trying to start too many processing operations. This can occur + // when callbacks resolve synchronously (#1267). + if (isProcessing) { + return; + } + isProcessing = true; + while(!q.paused && numRunning < q.concurrency && q._tasks.length){ + var tasks = [], data = []; + var l = q._tasks.length; + if (q.payload) l = Math.min(l, q.payload); + for (var i = 0; i < l; i++) { + var node = q._tasks.shift(); + tasks.push(node); + workersList.push(node); + data.push(node.data); + } + + numRunning += 1; + + if (q._tasks.length === 0) { + trigger('empty'); + } + + if (numRunning === q.concurrency) { + trigger('saturated'); + } + + var cb = onlyOnce(_createCB(tasks)); + _worker(data, cb); + } + isProcessing = false; + }, + length () { + return q._tasks.length; + }, + running () { + return numRunning; + }, + workersList () { + return workersList; + }, + idle() { + return q._tasks.length + numRunning === 0; + }, + pause () { + q.paused = true; + }, + resume () { + if (q.paused === false) { return; } + q.paused = false; + setImmediate$1(q.process); + } + }; + // define these as fixed properties, so people get useful errors when updating + Object.defineProperties(q, { + saturated: { + writable: false, + value: eventMethod('saturated') + }, + unsaturated: { + writable: false, + value: eventMethod('unsaturated') + }, + empty: { + writable: false, + value: eventMethod('empty') + }, + drain: { + writable: false, + value: eventMethod('drain') + }, + error: { + writable: false, + value: eventMethod('error') + }, + }); + return q; +} + +/** + * Creates a `cargo` object with the specified payload. Tasks added to the + * cargo will be processed altogether (up to the `payload` limit). If the + * `worker` is in progress, the task is queued until it becomes available. Once + * the `worker` has completed some tasks, each callback of those tasks is + * called. Check out [these](https://camo.githubusercontent.com/6bbd36f4cf5b35a0f11a96dcd2e97711ffc2fb37/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130382f62626330636662302d356632392d313165322d393734662d3333393763363464633835382e676966) [animations](https://camo.githubusercontent.com/f4810e00e1c5f5f8addbe3e9f49064fd5d102699/68747470733a2f2f662e636c6f75642e6769746875622e636f6d2f6173736574732f313637363837312f36383130312f38346339323036362d356632392d313165322d383134662d3964336430323431336266642e676966) + * for how `cargo` and `queue` work. + * + * While [`queue`]{@link module:ControlFlow.queue} passes only one task to one of a group of workers + * at a time, cargo passes an array of tasks to a single worker, repeating + * when the worker is finished. + * + * @name cargo + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {AsyncFunction} worker - An asynchronous function for processing an array + * of queued tasks. Invoked with `(tasks, callback)`. + * @param {number} [payload=Infinity] - An optional `integer` for determining + * how many tasks should be processed per round; if omitted, the default is + * unlimited. + * @returns {module:ControlFlow.QueueObject} A cargo object to manage the tasks. Callbacks can + * attached as certain properties to listen for specific events during the + * lifecycle of the cargo and inner queue. + * @example + * + * // create a cargo object with payload 2 + * var cargo = async.cargo(function(tasks, callback) { + * for (var i=0; i { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.reduce(fileList, 0, getFileSizeInBytes); + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.reduce(withMissingFileList, 0, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function reduce(coll, memo, iteratee, callback) { + callback = once(callback); + var _iteratee = wrapAsync(iteratee); + return eachOfSeries$1(coll, (x, i, iterCb) => { + _iteratee(memo, x, (err, v) => { + memo = v; + iterCb(err); + }); + }, err => callback(err, memo)); +} +var reduce$1 = awaitify(reduce, 4); + +/** + * Version of the compose function that is more natural to read. Each function + * consumes the return value of the previous function. It is the equivalent of + * [compose]{@link module:ControlFlow.compose} with the arguments reversed. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name seq + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.compose]{@link module:ControlFlow.compose} + * @category Control Flow + * @param {...AsyncFunction} functions - the asynchronous functions to compose + * @returns {Function} a function that composes the `functions` in order + * @example + * + * // Requires lodash (or underscore), express3 and dresende's orm2. + * // Part of an app, that fetches cats of the logged user. + * // This example uses `seq` function to avoid overnesting and error + * // handling clutter. + * app.get('/cats', function(request, response) { + * var User = request.models.User; + * async.seq( + * User.get.bind(User), // 'User.get' has signature (id, callback(err, data)) + * function(user, fn) { + * user.getCats(fn); // 'getCats' has signature (callback(err, data)) + * } + * )(req.session.user_id, function (err, cats) { + * if (err) { + * console.error(err); + * response.json({ status: 'error', message: err.message }); + * } else { + * response.json({ status: 'ok', message: 'Cats found', data: cats }); + * } + * }); + * }); + */ +function seq(...functions) { + var _functions = functions.map(wrapAsync); + return function (...args) { + var that = this; + + var cb = args[args.length - 1]; + if (typeof cb == 'function') { + args.pop(); + } else { + cb = promiseCallback(); + } + + reduce$1(_functions, args, (newargs, fn, iterCb) => { + fn.apply(that, newargs.concat((err, ...nextargs) => { + iterCb(err, nextargs); + })); + }, + (err, results) => cb(err, ...results)); + + return cb[PROMISE_SYMBOL] + }; +} + +/** + * Creates a function which is a composition of the passed asynchronous + * functions. Each function consumes the return value of the function that + * follows. Composing functions `f()`, `g()`, and `h()` would produce the result + * of `f(g(h()))`, only this version uses callbacks to obtain the return values. + * + * If the last argument to the composed function is not a function, a promise + * is returned when you call it. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name compose + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {...AsyncFunction} functions - the asynchronous functions to compose + * @returns {Function} an asynchronous function that is the composed + * asynchronous `functions` + * @example + * + * function add1(n, callback) { + * setTimeout(function () { + * callback(null, n + 1); + * }, 10); + * } + * + * function mul3(n, callback) { + * setTimeout(function () { + * callback(null, n * 3); + * }, 10); + * } + * + * var add1mul3 = async.compose(mul3, add1); + * add1mul3(4, function (err, result) { + * // result now equals 15 + * }); + */ +function compose(...args) { + return seq(...args.reverse()); +} + +/** + * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time. + * + * @name mapLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function mapLimit (coll, limit, iteratee, callback) { + return _asyncMap(eachOfLimit$2(limit), coll, iteratee, callback) +} +var mapLimit$1 = awaitify(mapLimit, 4); + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs a maximum of `limit` async operations at a time. + * + * @name concatLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapLimit + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatLimit(coll, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(coll, limit, (val, iterCb) => { + _iteratee(val, (err, ...args) => { + if (err) return iterCb(err); + return iterCb(err, args); + }); + }, (err, mapResults) => { + var result = []; + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + result = result.concat(...mapResults[i]); + } + } + + return callback(err, result); + }); +} +var concatLimit$1 = awaitify(concatLimit, 4); + +/** + * Applies `iteratee` to each item in `coll`, concatenating the results. Returns + * the concatenated list. The `iteratee`s are called in parallel, and the + * results are concatenated as they return. The results array will be returned in + * the original order of `coll` passed to the `iteratee` function. + * + * @name concat + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @alias flatMap + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * let directoryList = ['dir1','dir2','dir3']; + * let withMissingDirectoryList = ['dir1','dir2','dir3', 'dir4']; + * + * // Using callbacks + * async.concat(directoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.concat(directoryList, fs.readdir) + * .then(results => { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir) + * .then(results => { + * console.log(results); + * }).catch(err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.concat(directoryList, fs.readdir); + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.concat(withMissingDirectoryList, fs.readdir); + * console.log(results); + * } catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } + * } + * + */ +function concat(coll, iteratee, callback) { + return concatLimit$1(coll, Infinity, iteratee, callback) +} +var concat$1 = awaitify(concat, 3); + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs only a single async operation at a time. + * + * @name concatSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapSeries + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`. + * The iteratee should complete with an array an array of results. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatSeries(coll, iteratee, callback) { + return concatLimit$1(coll, 1, iteratee, callback) +} +var concatSeries$1 = awaitify(concatSeries, 3); + +/** + * Returns a function that when called, calls-back with the values provided. + * Useful as the first function in a [`waterfall`]{@link module:ControlFlow.waterfall}, or for plugging values in to + * [`auto`]{@link module:ControlFlow.auto}. + * + * @name constant + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {...*} arguments... - Any number of arguments to automatically invoke + * callback with. + * @returns {AsyncFunction} Returns a function that when invoked, automatically + * invokes the callback with the previous given arguments. + * @example + * + * async.waterfall([ + * async.constant(42), + * function (value, next) { + * // value === 42 + * }, + * //... + * ], callback); + * + * async.waterfall([ + * async.constant(filename, "utf8"), + * fs.readFile, + * function (fileData, next) { + * //... + * } + * //... + * ], callback); + * + * async.auto({ + * hostname: async.constant("https://server.net/"), + * port: findFreePort, + * launchServer: ["hostname", "port", function (options, cb) { + * startServer(options, cb); + * }], + * //... + * }, callback); + */ +function constant$1(...args) { + return function (...ignoredArgs/*, callback*/) { + var callback = ignoredArgs.pop(); + return callback(null, ...args); + }; +} + +function _createTester(check, getResult) { + return (eachfn, arr, _iteratee, cb) => { + var testPassed = false; + var testResult; + const iteratee = wrapAsync(_iteratee); + eachfn(arr, (value, _, callback) => { + iteratee(value, (err, result) => { + if (err || err === false) return callback(err); + + if (check(result) && !testResult) { + testPassed = true; + testResult = getResult(true, value); + return callback(null, breakLoop); + } + callback(); + }); + }, err => { + if (err) return cb(err); + cb(null, testPassed ? testResult : getResult(false)); + }); + }; +} + +/** + * Returns the first value in `coll` that passes an async truth test. The + * `iteratee` is applied in parallel, meaning the first iteratee to return + * `true` will fire the detect `callback` with that result. That means the + * result might not be the first item in the original `coll` (in terms of order) + * that passes the test. + + * If order within the original `coll` is important, then look at + * [`detectSeries`]{@link module:Collections.detectSeries}. + * + * @name detect + * @static + * @memberOf module:Collections + * @method + * @alias find + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * } + *); + * + * // Using Promises + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists) + * .then(result => { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists); + * console.log(result); + * // dir1/file1.txt + * // result now equals the file in the list that exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function detect(coll, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOf$1, coll, iteratee, callback) +} +var detect$1 = awaitify(detect, 3); + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a + * time. + * + * @name detectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findLimit + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectLimit(coll, limit, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOfLimit$2(limit), coll, iteratee, callback) +} +var detectLimit$1 = awaitify(detectLimit, 4); + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time. + * + * @name detectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findSeries + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectSeries(coll, iteratee, callback) { + return _createTester(bool => bool, (res, item) => item)(eachOfLimit$2(1), coll, iteratee, callback) +} + +var detectSeries$1 = awaitify(detectSeries, 3); + +function consoleFunc(name) { + return (fn, ...args) => wrapAsync(fn)(...args, (err, ...resultArgs) => { + /* istanbul ignore else */ + if (typeof console === 'object') { + /* istanbul ignore else */ + if (err) { + /* istanbul ignore else */ + if (console.error) { + console.error(err); + } + } else if (console[name]) { /* istanbul ignore else */ + resultArgs.forEach(x => console[name](x)); + } + } + }) +} + +/** + * Logs the result of an [`async` function]{@link AsyncFunction} to the + * `console` using `console.dir` to display the properties of the resulting object. + * Only works in Node.js or in browsers that support `console.dir` and + * `console.error` (such as FF and Chrome). + * If multiple arguments are returned from the async function, + * `console.dir` is called on each argument in order. + * + * @name dir + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, {hello: name}); + * }, 1000); + * }; + * + * // in the node repl + * node> async.dir(hello, 'world'); + * {hello: 'world'} + */ +var dir = consoleFunc('dir'); + +/** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - A function which is called each time `test` + * passes. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ +function doWhilst(iteratee, test, callback) { + callback = onlyOnce(callback); + var _fn = wrapAsync(iteratee); + var _test = wrapAsync(test); + var results; + + function next(err, ...args) { + if (err) return callback(err); + if (err === false) return; + results = args; + _test(...args, check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return check(null, true); +} + +var doWhilst$1 = awaitify(doWhilst, 3); + +/** + * Like ['doWhilst']{@link module:ControlFlow.doWhilst}, except the `test` is inverted. Note the + * argument ordering differs from `until`. + * + * @name doUntil + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.doWhilst]{@link module:ControlFlow.doWhilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee` + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ +function doUntil(iteratee, test, callback) { + const _test = wrapAsync(test); + return doWhilst$1(iteratee, (...args) => { + const cb = args.pop(); + _test(...args, (err, truth) => cb (err, !truth)); + }, callback); +} + +function _withoutIndex(iteratee) { + return (value, index, callback) => iteratee(value, callback); +} + +/** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to + * each item in `coll`. Invoked with (item, callback). + * The array index is not passed to the iteratee. + * If you need the index, use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = [ 'dir1/file2.txt', 'dir2/file3.txt', 'dir/file5.txt']; + * const withMissingFileList = ['dir1/file1.txt', 'dir4/file2.txt']; + * + * // asynchronous function that deletes a file + * const deleteFile = function(file, callback) { + * fs.unlink(file, callback); + * }; + * + * // Using callbacks + * async.each(fileList, deleteFile, function(err) { + * if( err ) { + * console.log(err); + * } else { + * console.log('All files have been deleted successfully'); + * } + * }); + * + * // Error Handling + * async.each(withMissingFileList, deleteFile, function(err){ + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using Promises + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using async/await + * async () => { + * try { + * await async.each(files, deleteFile); + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * await async.each(withMissingFileList, deleteFile); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * } + * } + * + */ +function eachLimit$2(coll, iteratee, callback) { + return eachOf$1(coll, _withoutIndex(wrapAsync(iteratee)), callback); +} + +var each = awaitify(eachLimit$2, 3); + +/** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfLimit`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachLimit(coll, limit, iteratee, callback) { + return eachOfLimit$2(limit)(coll, _withoutIndex(wrapAsync(iteratee)), callback); +} +var eachLimit$1 = awaitify(eachLimit, 4); + +/** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * Note, that unlike [`each`]{@link module:Collections.each}, this function applies iteratee to each item + * in series and therefore the iteratee functions will complete in order. + + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfSeries`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachSeries(coll, iteratee, callback) { + return eachLimit$1(coll, 1, iteratee, callback) +} +var eachSeries$1 = awaitify(eachSeries, 3); + +/** + * Wrap an async function and ensure it calls its callback on a later tick of + * the event loop. If the function already calls its callback on a next tick, + * no extra deferral is added. This is useful for preventing stack overflows + * (`RangeError: Maximum call stack size exceeded`) and generally keeping + * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) + * contained. ES2017 `async` functions are returned as-is -- they are immune + * to Zalgo's corrupting influences, as they always resolve on a later tick. + * + * @name ensureAsync + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - an async function, one that expects a node-style + * callback as its last argument. + * @returns {AsyncFunction} Returns a wrapped function with the exact same call + * signature as the function passed in. + * @example + * + * function sometimesAsync(arg, callback) { + * if (cache[arg]) { + * return callback(null, cache[arg]); // this would be synchronous!! + * } else { + * doSomeIO(arg, callback); // this IO would be asynchronous + * } + * } + * + * // this has a risk of stack overflows if many results are cached in a row + * async.mapSeries(args, sometimesAsync, done); + * + * // this will defer sometimesAsync's callback if necessary, + * // preventing stack overflows + * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); + */ +function ensureAsync(fn) { + if (isAsync(fn)) return fn; + return function (...args/*, callback*/) { + var callback = args.pop(); + var sync = true; + args.push((...innerArgs) => { + if (sync) { + setImmediate$1(() => callback(...innerArgs)); + } else { + callback(...innerArgs); + } + }); + fn.apply(this, args); + sync = false; + }; +} + +/** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file5.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.every(fileList, fileExists, function(err, result) { + * console.log(result); + * // true + * // result is true since every file exists + * }); + * + * async.every(withMissingFileList, fileExists, function(err, result) { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }); + * + * // Using Promises + * async.every(fileList, fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.every(withMissingFileList, fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.every(fileList, fileExists); + * console.log(result); + * // true + * // result is true since every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.every(withMissingFileList, fileExists); + * console.log(result); + * // false + * // result is false since NOT every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function every(coll, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOf$1, coll, iteratee, callback) +} +var every$1 = awaitify(every, 3); + +/** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everyLimit(coll, limit, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOfLimit$2(limit), coll, iteratee, callback) +} +var everyLimit$1 = awaitify(everyLimit, 4); + +/** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in series. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everySeries(coll, iteratee, callback) { + return _createTester(bool => !bool, res => !res)(eachOfSeries$1, coll, iteratee, callback) +} +var everySeries$1 = awaitify(everySeries, 3); + +function filterArray(eachfn, arr, iteratee, callback) { + var truthValues = new Array(arr.length); + eachfn(arr, (x, index, iterCb) => { + iteratee(x, (err, v) => { + truthValues[index] = !!v; + iterCb(err); + }); + }, err => { + if (err) return callback(err); + var results = []; + for (var i = 0; i < arr.length; i++) { + if (truthValues[i]) results.push(arr[i]); + } + callback(null, results); + }); +} + +function filterGeneric(eachfn, coll, iteratee, callback) { + var results = []; + eachfn(coll, (x, index, iterCb) => { + iteratee(x, (err, v) => { + if (err) return iterCb(err); + if (v) { + results.push({index, value: x}); + } + iterCb(err); + }); + }, err => { + if (err) return callback(err); + callback(null, results + .sort((a, b) => a.index - b.index) + .map(v => v.value)); + }); +} + +function _filter(eachfn, coll, iteratee, callback) { + var filter = isArrayLike(coll) ? filterArray : filterGeneric; + return filter(eachfn, coll, wrapAsync(iteratee), callback); +} + +/** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const files = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.filter(files, fileExists, function(err, results) { + * if(err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * }); + * + * // Using Promises + * async.filter(files, fileExists) + * .then(results => { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.filter(files, fileExists); + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function filter (coll, iteratee, callback) { + return _filter(eachOf$1, coll, iteratee, callback) +} +var filter$1 = awaitify(filter, 3); + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + */ +function filterLimit (coll, limit, iteratee, callback) { + return _filter(eachOfLimit$2(limit), coll, iteratee, callback) +} +var filterLimit$1 = awaitify(filterLimit, 4); + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + * @returns {Promise} a promise, if no callback provided + */ +function filterSeries (coll, iteratee, callback) { + return _filter(eachOfSeries$1, coll, iteratee, callback) +} +var filterSeries$1 = awaitify(filterSeries, 3); + +/** + * Calls the asynchronous function `fn` with a callback parameter that allows it + * to call itself again, in series, indefinitely. + + * If an error is passed to the callback then `errback` is called with the + * error, and execution stops, otherwise it will never be called. + * + * @name forever + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} fn - an async function to call repeatedly. + * Invoked with (next). + * @param {Function} [errback] - when `fn` passes an error to it's callback, + * this function will be called, and execution stops. Invoked with (err). + * @returns {Promise} a promise that rejects if an error occurs and an errback + * is not passed + * @example + * + * async.forever( + * function(next) { + * // next is suitable for passing to things that need a callback(err [, whatever]); + * // it will result in this function being called again. + * }, + * function(err) { + * // if next is called with a value in its first parameter, it will appear + * // in here as 'err', and execution will stop. + * } + * ); + */ +function forever(fn, errback) { + var done = onlyOnce(errback); + var task = wrapAsync(ensureAsync(fn)); + + function next(err) { + if (err) return done(err); + if (err === false) return; + task(next); + } + return next(); +} +var forever$1 = awaitify(forever, 2); + +/** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs a maximum of `limit` async operations at a time. + * + * @name groupByLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ +function groupByLimit(coll, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(coll, limit, (val, iterCb) => { + _iteratee(val, (err, key) => { + if (err) return iterCb(err); + return iterCb(err, {key, val}); + }); + }, (err, mapResults) => { + var result = {}; + // from MDN, handle object having an `hasOwnProperty` prop + var {hasOwnProperty} = Object.prototype; + + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + var {key} = mapResults[i]; + var {val} = mapResults[i]; + + if (hasOwnProperty.call(result, key)) { + result[key].push(val); + } else { + result[key] = [val]; + } + } + } + + return callback(err, result); + }); +} + +var groupByLimit$1 = awaitify(groupByLimit, 4); + +/** + * Returns a new object, where each value corresponds to an array of items, from + * `coll`, that returned the corresponding key. That is, the keys of the object + * correspond to the values passed to the `iteratee` callback. + * + * Note: Since this function applies the `iteratee` to each item in parallel, + * there is no guarantee that the `iteratee` functions will complete in order. + * However, the values for each key in the `result` will be in the same order as + * the original `coll`. For Objects, the values will roughly be in the order of + * the original Objects' keys (but this can vary across JavaScript engines). + * + * @name groupBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const files = ['dir1/file1.txt','dir2','dir4'] + * + * // asynchronous function that detects file type as none, file, or directory + * function detectFile(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(null, 'none'); + * } + * callback(null, stat.isDirectory() ? 'directory' : 'file'); + * }); + * } + * + * //Using callbacks + * async.groupBy(files, detectFile, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * }); + * + * // Using Promises + * async.groupBy(files, detectFile) + * .then( result => { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.groupBy(files, detectFile); + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function groupBy (coll, iteratee, callback) { + return groupByLimit$1(coll, Infinity, iteratee, callback) +} + +/** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs only a single async operation at a time. + * + * @name groupBySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whose + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ +function groupBySeries (coll, iteratee, callback) { + return groupByLimit$1(coll, 1, iteratee, callback) +} + +/** + * Logs the result of an `async` function to the `console`. Only works in + * Node.js or in browsers that support `console.log` and `console.error` (such + * as FF and Chrome). If multiple arguments are returned from the async + * function, `console.log` is called on each argument in order. + * + * @name log + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, 'hello ' + name); + * }, 1000); + * }; + * + * // in the node repl + * node> async.log(hello, 'world'); + * 'hello world' + */ +var log = consoleFunc('log'); + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs a maximum of `limit` async operations at a + * time. + * + * @name mapValuesLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function mapValuesLimit(obj, limit, iteratee, callback) { + callback = once(callback); + var newObj = {}; + var _iteratee = wrapAsync(iteratee); + return eachOfLimit$2(limit)(obj, (val, key, next) => { + _iteratee(val, key, (err, result) => { + if (err) return next(err); + newObj[key] = result; + next(err); + }); + }, err => callback(err, newObj)); +} + +var mapValuesLimit$1 = awaitify(mapValuesLimit, 4); + +/** + * A relative of [`map`]{@link module:Collections.map}, designed for use with objects. + * + * Produces a new Object by mapping each value of `obj` through the `iteratee` + * function. The `iteratee` is called each `value` and `key` from `obj` and a + * callback for when it has finished processing. Each of these callbacks takes + * two arguments: an `error`, and the transformed item from `obj`. If `iteratee` + * passes an error to its callback, the main `callback` (for the `mapValues` + * function) is immediately called with the error. + * + * Note, the order of the keys in the result is not guaranteed. The keys will + * be roughly in the order they complete, (but this is very engine-specific) + * + * @name mapValues + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file3.txt' + * }; + * + * const withMissingFileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file4.txt' + * }; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, key, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.mapValues(fileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * }); + * + * // Error handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.mapValues(fileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * }).catch (err => { + * console.log(err); + * }); + * + * // Error Handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch (err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.mapValues(fileMap, getFileSizeInBytes); + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.mapValues(withMissingFileMap, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function mapValues(obj, iteratee, callback) { + return mapValuesLimit$1(obj, Infinity, iteratee, callback) +} + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time. + * + * @name mapValuesSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function mapValuesSeries(obj, iteratee, callback) { + return mapValuesLimit$1(obj, 1, iteratee, callback) +} + +/** + * Caches the results of an async function. When creating a hash to store + * function results against, the callback is omitted from the hash and an + * optional hash function can be used. + * + * **Note: if the async function errs, the result will not be cached and + * subsequent calls will call the wrapped function.** + * + * If no hash function is specified, the first argument is used as a hash key, + * which may work reasonably if it is a string or a data type that converts to a + * distinct string. Note that objects and arrays will not behave reasonably. + * Neither will cases where the other arguments are significant. In such cases, + * specify your own hash function. + * + * The cache of results is exposed as the `memo` property of the function + * returned by `memoize`. + * + * @name memoize + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function to proxy and cache results from. + * @param {Function} hasher - An optional function for generating a custom hash + * for storing results. It has all the arguments applied to it apart from the + * callback, and must be synchronous. + * @returns {AsyncFunction} a memoized version of `fn` + * @example + * + * var slow_fn = function(name, callback) { + * // do something + * callback(null, result); + * }; + * var fn = async.memoize(slow_fn); + * + * // fn can now be used as if it were slow_fn + * fn('some name', function() { + * // callback + * }); + */ +function memoize(fn, hasher = v => v) { + var memo = Object.create(null); + var queues = Object.create(null); + var _fn = wrapAsync(fn); + var memoized = initialParams((args, callback) => { + var key = hasher(...args); + if (key in memo) { + setImmediate$1(() => callback(null, ...memo[key])); + } else if (key in queues) { + queues[key].push(callback); + } else { + queues[key] = [callback]; + _fn(...args, (err, ...resultArgs) => { + // #1465 don't memoize if an error occurred + if (!err) { + memo[key] = resultArgs; + } + var q = queues[key]; + delete queues[key]; + for (var i = 0, l = q.length; i < l; i++) { + q[i](err, ...resultArgs); + } + }); + } + }); + memoized.memo = memo; + memoized.unmemoized = fn; + return memoized; +} + +/* istanbul ignore file */ + +/** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `process.nextTick`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name nextTick + * @static + * @memberOf module:Utils + * @method + * @see [async.setImmediate]{@link module:Utils.setImmediate} + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ +var _defer; + +if (hasNextTick) { + _defer = process.nextTick; +} else if (hasSetImmediate) { + _defer = setImmediate; +} else { + _defer = fallback; +} + +var nextTick = wrap(_defer); + +var _parallel = awaitify((eachfn, tasks, callback) => { + var results = isArrayLike(tasks) ? [] : {}; + + eachfn(tasks, (task, key, taskCb) => { + wrapAsync(task)((err, ...result) => { + if (result.length < 2) { + [result] = result; + } + results[key] = result; + taskCb(err); + }); + }, err => callback(err, results)); +}, 3); + +/** + * Run the `tasks` collection of functions in parallel, without waiting until + * the previous function has completed. If any of the functions pass an error to + * its callback, the main `callback` is immediately called with the value of the + * error. Once the `tasks` have completed, the results are passed to the final + * `callback` as an array. + * + * **Note:** `parallel` is about kicking-off I/O tasks in parallel, not about + * parallel execution of code. If your tasks do not use any timers or perform + * any I/O, they will actually be executed in series. Any synchronous setup + * sections for each task will happen one after the other. JavaScript remains + * single-threaded. + * + * **Hint:** Use [`reflect`]{@link module:Utils.reflect} to continue the + * execution of other tasks when a task fails. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.parallel}. + * + * @name parallel + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * + * //Using Callbacks + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function parallel(tasks, callback) { + return _parallel(eachOf$1, tasks, callback); +} + +/** + * The same as [`parallel`]{@link module:ControlFlow.parallel} but runs a maximum of `limit` async operations at a + * time. + * + * @name parallelLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.parallel]{@link module:ControlFlow.parallel} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + */ +function parallelLimit(tasks, limit, callback) { + return _parallel(eachOfLimit$2(limit), tasks, callback); +} + +/** + * A queue of tasks for the worker function to complete. + * @typedef {Iterable} QueueObject + * @memberOf module:ControlFlow + * @property {Function} length - a function returning the number of items + * waiting to be processed. Invoke with `queue.length()`. + * @property {boolean} started - a boolean indicating whether or not any + * items have been pushed and processed by the queue. + * @property {Function} running - a function returning the number of items + * currently being processed. Invoke with `queue.running()`. + * @property {Function} workersList - a function returning the array of items + * currently being processed. Invoke with `queue.workersList()`. + * @property {Function} idle - a function returning false if there are items + * waiting or being processed, or true if not. Invoke with `queue.idle()`. + * @property {number} concurrency - an integer for determining how many `worker` + * functions should be run in parallel. This property can be changed after a + * `queue` is created to alter the concurrency on-the-fly. + * @property {number} payload - an integer that specifies how many items are + * passed to the worker function at a time. only applies if this is a + * [cargo]{@link module:ControlFlow.cargo} object + * @property {AsyncFunction} push - add a new task to the `queue`. Calls `callback` + * once the `worker` has finished processing the task. Instead of a single task, + * a `tasks` array can be submitted. The respective callback is used for every + * task in the list. Invoke with `queue.push(task, [callback])`, + * @property {AsyncFunction} unshift - add a new task to the front of the `queue`. + * Invoke with `queue.unshift(task, [callback])`. + * @property {AsyncFunction} pushAsync - the same as `q.push`, except this returns + * a promise that rejects if an error occurs. + * @property {AsyncFunction} unshiftAsync - the same as `q.unshift`, except this returns + * a promise that rejects if an error occurs. + * @property {Function} remove - remove items from the queue that match a test + * function. The test function will be passed an object with a `data` property, + * and a `priority` property, if this is a + * [priorityQueue]{@link module:ControlFlow.priorityQueue} object. + * Invoked with `queue.remove(testFn)`, where `testFn` is of the form + * `function ({data, priority}) {}` and returns a Boolean. + * @property {Function} saturated - a function that sets a callback that is + * called when the number of running workers hits the `concurrency` limit, and + * further tasks will be queued. If the callback is omitted, `q.saturated()` + * returns a promise for the next occurrence. + * @property {Function} unsaturated - a function that sets a callback that is + * called when the number of running workers is less than the `concurrency` & + * `buffer` limits, and further tasks will not be queued. If the callback is + * omitted, `q.unsaturated()` returns a promise for the next occurrence. + * @property {number} buffer - A minimum threshold buffer in order to say that + * the `queue` is `unsaturated`. + * @property {Function} empty - a function that sets a callback that is called + * when the last item from the `queue` is given to a `worker`. If the callback + * is omitted, `q.empty()` returns a promise for the next occurrence. + * @property {Function} drain - a function that sets a callback that is called + * when the last item from the `queue` has returned from the `worker`. If the + * callback is omitted, `q.drain()` returns a promise for the next occurrence. + * @property {Function} error - a function that sets a callback that is called + * when a task errors. Has the signature `function(error, task)`. If the + * callback is omitted, `error()` returns a promise that rejects on the next + * error. + * @property {boolean} paused - a boolean for determining whether the queue is + * in a paused state. + * @property {Function} pause - a function that pauses the processing of tasks + * until `resume()` is called. Invoke with `queue.pause()`. + * @property {Function} resume - a function that resumes the processing of + * queued tasks when the queue is paused. Invoke with `queue.resume()`. + * @property {Function} kill - a function that removes the `drain` callback and + * empties remaining tasks from the queue forcing it to go idle. No more tasks + * should be pushed to the queue after calling this function. Invoke with `queue.kill()`. + * + * @example + * const q = async.queue(worker, 2) + * q.push(item1) + * q.push(item2) + * q.push(item3) + * // queues are iterable, spread into an array to inspect + * const items = [...q] // [item1, item2, item3] + * // or use for of + * for (let item of q) { + * console.log(item) + * } + * + * q.drain(() => { + * console.log('all done') + * }) + * // or + * await q.drain() + */ + +/** + * Creates a `queue` object with the specified `concurrency`. Tasks added to the + * `queue` are processed in parallel (up to the `concurrency` limit). If all + * `worker`s are in progress, the task is queued until one becomes available. + * Once a `worker` completes a `task`, that `task`'s callback is called. + * + * @name queue + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} worker - An async function for processing a queued task. + * If you want to handle errors from an individual task, pass a callback to + * `q.push()`. Invoked with (task, callback). + * @param {number} [concurrency=1] - An `integer` for determining how many + * `worker` functions should be run in parallel. If omitted, the concurrency + * defaults to `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A queue object to manage the tasks. Callbacks can be + * attached as certain properties to listen for specific events during the + * lifecycle of the queue. + * @example + * + * // create a queue object with concurrency 2 + * var q = async.queue(function(task, callback) { + * console.log('hello ' + task.name); + * callback(); + * }, 2); + * + * // assign a callback + * q.drain(function() { + * console.log('all items have been processed'); + * }); + * // or await the end + * await q.drain() + * + * // assign an error callback + * q.error(function(err, task) { + * console.error('task experienced an error'); + * }); + * + * // add some items to the queue + * q.push({name: 'foo'}, function(err) { + * console.log('finished processing foo'); + * }); + * // callback is optional + * q.push({name: 'bar'}); + * + * // add some items to the queue (batch-wise) + * q.push([{name: 'baz'},{name: 'bay'},{name: 'bax'}], function(err) { + * console.log('finished processing item'); + * }); + * + * // add some items to the front of the queue + * q.unshift({name: 'bar'}, function (err) { + * console.log('finished processing bar'); + * }); + */ +function queue (worker, concurrency) { + var _worker = wrapAsync(worker); + return queue$1((items, cb) => { + _worker(items[0], cb); + }, concurrency, 1); +} + +// Binary min-heap implementation used for priority queue. +// Implementation is stable, i.e. push time is considered for equal priorities +class Heap { + constructor() { + this.heap = []; + this.pushCount = Number.MIN_SAFE_INTEGER; + } + + get length() { + return this.heap.length; + } + + empty () { + this.heap = []; + return this; + } + + percUp(index) { + let p; + + while (index > 0 && smaller(this.heap[index], this.heap[p=parent(index)])) { + let t = this.heap[index]; + this.heap[index] = this.heap[p]; + this.heap[p] = t; + + index = p; + } + } + + percDown(index) { + let l; + + while ((l=leftChi(index)) < this.heap.length) { + if (l+1 < this.heap.length && smaller(this.heap[l+1], this.heap[l])) { + l = l+1; + } + + if (smaller(this.heap[index], this.heap[l])) { + break; + } + + let t = this.heap[index]; + this.heap[index] = this.heap[l]; + this.heap[l] = t; + + index = l; + } + } + + push(node) { + node.pushCount = ++this.pushCount; + this.heap.push(node); + this.percUp(this.heap.length-1); + } + + unshift(node) { + return this.heap.push(node); + } + + shift() { + let [top] = this.heap; + + this.heap[0] = this.heap[this.heap.length-1]; + this.heap.pop(); + this.percDown(0); + + return top; + } + + toArray() { + return [...this]; + } + + *[Symbol.iterator] () { + for (let i = 0; i < this.heap.length; i++) { + yield this.heap[i].data; + } + } + + remove (testFn) { + let j = 0; + for (let i = 0; i < this.heap.length; i++) { + if (!testFn(this.heap[i])) { + this.heap[j] = this.heap[i]; + j++; + } + } + + this.heap.splice(j); + + for (let i = parent(this.heap.length-1); i >= 0; i--) { + this.percDown(i); + } + + return this; + } +} + +function leftChi(i) { + return (i<<1)+1; +} + +function parent(i) { + return ((i+1)>>1)-1; +} + +function smaller(x, y) { + if (x.priority !== y.priority) { + return x.priority < y.priority; + } + else { + return x.pushCount < y.pushCount; + } +} + +/** + * The same as [async.queue]{@link module:ControlFlow.queue} only tasks are assigned a priority and + * completed in ascending priority order. + * + * @name priorityQueue + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.queue]{@link module:ControlFlow.queue} + * @category Control Flow + * @param {AsyncFunction} worker - An async function for processing a queued task. + * If you want to handle errors from an individual task, pass a callback to + * `q.push()`. + * Invoked with (task, callback). + * @param {number} concurrency - An `integer` for determining how many `worker` + * functions should be run in parallel. If omitted, the concurrency defaults to + * `1`. If the concurrency is `0`, an error is thrown. + * @returns {module:ControlFlow.QueueObject} A priorityQueue object to manage the tasks. There are three + * differences between `queue` and `priorityQueue` objects: + * * `push(task, priority, [callback])` - `priority` should be a number. If an + * array of `tasks` is given, all tasks will be assigned the same priority. + * * `pushAsync(task, priority, [callback])` - the same as `priorityQueue.push`, + * except this returns a promise that rejects if an error occurs. + * * The `unshift` and `unshiftAsync` methods were removed. + */ +function priorityQueue(worker, concurrency) { + // Start with a normal queue + var q = queue(worker, concurrency); + + var { + push, + pushAsync + } = q; + + q._tasks = new Heap(); + q._createTaskItem = ({data, priority}, callback) => { + return { + data, + priority, + callback + }; + }; + + function createDataItems(tasks, priority) { + if (!Array.isArray(tasks)) { + return {data: tasks, priority}; + } + return tasks.map(data => { return {data, priority}; }); + } + + // Override push to accept second parameter representing priority + q.push = function(data, priority = 0, callback) { + return push(createDataItems(data, priority), callback); + }; + + q.pushAsync = function(data, priority = 0, callback) { + return pushAsync(createDataItems(data, priority), callback); + }; + + // Remove unshift functions + delete q.unshift; + delete q.unshiftAsync; + + return q; +} + +/** + * Runs the `tasks` array of functions in parallel, without waiting until the + * previous function has completed. Once any of the `tasks` complete or pass an + * error to its callback, the main `callback` is immediately called. It's + * equivalent to `Promise.race()`. + * + * @name race + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array containing [async functions]{@link AsyncFunction} + * to run. Each function can complete with an optional `result` value. + * @param {Function} callback - A callback to run once any of the functions have + * completed. This function gets an error or result from the first function that + * completed. Invoked with (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.race([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], + * // main callback + * function(err, result) { + * // the result will be equal to 'two' as it finishes earlier + * }); + */ +function race(tasks, callback) { + callback = once(callback); + if (!Array.isArray(tasks)) return callback(new TypeError('First argument to race must be an array of functions')); + if (!tasks.length) return callback(); + for (var i = 0, l = tasks.length; i < l; i++) { + wrapAsync(tasks[i])(callback); + } +} + +var race$1 = awaitify(race, 2); + +/** + * Same as [`reduce`]{@link module:Collections.reduce}, only operates on `array` in reverse order. + * + * @name reduceRight + * @static + * @memberOf module:Collections + * @method + * @see [async.reduce]{@link module:Collections.reduce} + * @alias foldr + * @category Collection + * @param {Array} array - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function reduceRight (array, memo, iteratee, callback) { + var reversed = [...array].reverse(); + return reduce$1(reversed, memo, iteratee, callback); +} + +/** + * Wraps the async function in another function that always completes with a + * result object, even when it errors. + * + * The result object has either the property `error` or `value`. + * + * @name reflect + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function you want to wrap + * @returns {Function} - A function that always passes null to it's callback as + * the error. The second argument to the callback will be an `object` with + * either an `error` or a `value` property. + * @example + * + * async.parallel([ + * async.reflect(function(callback) { + * // do some stuff ... + * callback(null, 'one'); + * }), + * async.reflect(function(callback) { + * // do some more stuff but error ... + * callback('bad stuff happened'); + * }), + * async.reflect(function(callback) { + * // do some more stuff ... + * callback(null, 'two'); + * }) + * ], + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = 'bad stuff happened' + * // results[2].value = 'two' + * }); + */ +function reflect(fn) { + var _fn = wrapAsync(fn); + return initialParams(function reflectOn(args, reflectCallback) { + args.push((error, ...cbArgs) => { + let retVal = {}; + if (error) { + retVal.error = error; + } + if (cbArgs.length > 0){ + var value = cbArgs; + if (cbArgs.length <= 1) { + [value] = cbArgs; + } + retVal.value = value; + } + reflectCallback(null, retVal); + }); + + return _fn.apply(this, args); + }); +} + +/** + * A helper function that wraps an array or an object of functions with `reflect`. + * + * @name reflectAll + * @static + * @memberOf module:Utils + * @method + * @see [async.reflect]{@link module:Utils.reflect} + * @category Util + * @param {Array|Object|Iterable} tasks - The collection of + * [async functions]{@link AsyncFunction} to wrap in `async.reflect`. + * @returns {Array} Returns an array of async functions, each wrapped in + * `async.reflect` + * @example + * + * let tasks = [ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * // do some more stuff but error ... + * callback(new Error('bad stuff happened')); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = Error('bad stuff happened') + * // results[2].value = 'two' + * }); + * + * // an example using an object instead of an array + * let tasks = { + * one: function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * two: function(callback) { + * callback('two'); + * }, + * three: function(callback) { + * setTimeout(function() { + * callback(null, 'three'); + * }, 100); + * } + * }; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results.one.value = 'one' + * // results.two.error = 'two' + * // results.three.value = 'three' + * }); + */ +function reflectAll(tasks) { + var results; + if (Array.isArray(tasks)) { + results = tasks.map(reflect); + } else { + results = {}; + Object.keys(tasks).forEach(key => { + results[key] = reflect.call(this, tasks[key]); + }); + } + return results; +} + +function reject$2(eachfn, arr, _iteratee, callback) { + const iteratee = wrapAsync(_iteratee); + return _filter(eachfn, arr, (value, cb) => { + iteratee(value, (err, v) => { + cb(err, !v); + }); + }, callback); +} + +/** + * The opposite of [`filter`]{@link module:Collections.filter}. Removes values that pass an `async` truth test. + * + * @name reject + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.reject(fileList, fileExists, function(err, results) { + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }); + * + * // Using Promises + * async.reject(fileList, fileExists) + * .then( results => { + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.reject(fileList, fileExists); + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function reject (coll, iteratee, callback) { + return reject$2(eachOf$1, coll, iteratee, callback) +} +var reject$1 = awaitify(reject, 3); + +/** + * The same as [`reject`]{@link module:Collections.reject} but runs a maximum of `limit` async operations at a + * time. + * + * @name rejectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function rejectLimit (coll, limit, iteratee, callback) { + return reject$2(eachOfLimit$2(limit), coll, iteratee, callback) +} +var rejectLimit$1 = awaitify(rejectLimit, 4); + +/** + * The same as [`reject`]{@link module:Collections.reject} but runs only a single async operation at a time. + * + * @name rejectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function rejectSeries (coll, iteratee, callback) { + return reject$2(eachOfSeries$1, coll, iteratee, callback) +} +var rejectSeries$1 = awaitify(rejectSeries, 3); + +function constant(value) { + return function () { + return value; + } +} + +/** + * Attempts to get a successful response from `task` no more than `times` times + * before returning an error. If the task is successful, the `callback` will be + * passed the result of the successful task. If all attempts fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name retry + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @see [async.retryable]{@link module:ControlFlow.retryable} + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - Can be either an + * object with `times` and `interval` or a number. + * * `times` - The number of attempts to make before giving up. The default + * is `5`. + * * `interval` - The time to wait between retries, in milliseconds. The + * default is `0`. The interval may also be specified as a function of the + * retry count (see example). + * * `errorFilter` - An optional synchronous function that is invoked on + * erroneous result. If it returns `true` the retry attempts will continue; + * if the function returns `false` the retry flow is aborted with the current + * attempt's error and result being returned to the final callback. + * Invoked with (err). + * * If `opts` is a number, the number specifies the number of times to retry, + * with the default interval of `0`. + * @param {AsyncFunction} task - An async function to retry. + * Invoked with (callback). + * @param {Function} [callback] - An optional callback which is called when the + * task has succeeded, or after the final failed attempt. It receives the `err` + * and `result` arguments of the last attempt at completing the `task`. Invoked + * with (err, results). + * @returns {Promise} a promise if no callback provided + * + * @example + * + * // The `retry` function can be used as a stand-alone control flow by passing + * // a callback, as shown below: + * + * // try calling apiMethod 3 times + * async.retry(3, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 3 times, waiting 200 ms between each retry + * async.retry({times: 3, interval: 200}, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 10 times with exponential backoff + * // (i.e. intervals of 100, 200, 400, 800, 1600, ... milliseconds) + * async.retry({ + * times: 10, + * interval: function(retryCount) { + * return 50 * Math.pow(2, retryCount); + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod the default 5 times no delay between each retry + * async.retry(apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod only when error condition satisfies, all other + * // errors will abort the retry control flow and return to final callback + * async.retry({ + * errorFilter: function(err) { + * return err.message === 'Temporary error'; // only retry on a specific error + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // to retry individual methods that are not as reliable within other + * // control flow functions, use the `retryable` wrapper: + * async.auto({ + * users: api.getUsers.bind(api), + * payments: async.retryable(3, api.getPayments.bind(api)) + * }, function(err, results) { + * // do something with the results + * }); + * + */ +const DEFAULT_TIMES = 5; +const DEFAULT_INTERVAL = 0; + +function retry(opts, task, callback) { + var options = { + times: DEFAULT_TIMES, + intervalFunc: constant(DEFAULT_INTERVAL) + }; + + if (arguments.length < 3 && typeof opts === 'function') { + callback = task || promiseCallback(); + task = opts; + } else { + parseTimes(options, opts); + callback = callback || promiseCallback(); + } + + if (typeof task !== 'function') { + throw new Error("Invalid arguments for async.retry"); + } + + var _task = wrapAsync(task); + + var attempt = 1; + function retryAttempt() { + _task((err, ...args) => { + if (err === false) return + if (err && attempt++ < options.times && + (typeof options.errorFilter != 'function' || + options.errorFilter(err))) { + setTimeout(retryAttempt, options.intervalFunc(attempt - 1)); + } else { + callback(err, ...args); + } + }); + } + + retryAttempt(); + return callback[PROMISE_SYMBOL] +} + +function parseTimes(acc, t) { + if (typeof t === 'object') { + acc.times = +t.times || DEFAULT_TIMES; + + acc.intervalFunc = typeof t.interval === 'function' ? + t.interval : + constant(+t.interval || DEFAULT_INTERVAL); + + acc.errorFilter = t.errorFilter; + } else if (typeof t === 'number' || typeof t === 'string') { + acc.times = +t || DEFAULT_TIMES; + } else { + throw new Error("Invalid arguments for async.retry"); + } +} + +/** + * A close relative of [`retry`]{@link module:ControlFlow.retry}. This method + * wraps a task and makes it retryable, rather than immediately calling it + * with retries. + * + * @name retryable + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.retry]{@link module:ControlFlow.retry} + * @category Control Flow + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - optional + * options, exactly the same as from `retry`, except for a `opts.arity` that + * is the arity of the `task` function, defaulting to `task.length` + * @param {AsyncFunction} task - the asynchronous function to wrap. + * This function will be passed any arguments passed to the returned wrapper. + * Invoked with (...args, callback). + * @returns {AsyncFunction} The wrapped function, which when invoked, will + * retry on an error, based on the parameters specified in `opts`. + * This function will accept the same parameters as `task`. + * @example + * + * async.auto({ + * dep1: async.retryable(3, getFromFlakyService), + * process: ["dep1", async.retryable(3, function (results, cb) { + * maybeProcessData(results.dep1, cb); + * })] + * }, callback); + */ +function retryable (opts, task) { + if (!task) { + task = opts; + opts = null; + } + let arity = (opts && opts.arity) || task.length; + if (isAsync(task)) { + arity += 1; + } + var _task = wrapAsync(task); + return initialParams((args, callback) => { + if (args.length < arity - 1 || callback == null) { + args.push(callback); + callback = promiseCallback(); + } + function taskFn(cb) { + _task(...args, cb); + } + + if (opts) retry(opts, taskFn, callback); + else retry(taskFn, callback); + + return callback[PROMISE_SYMBOL] + }); +} + +/** + * Run the functions in the `tasks` collection in series, each one running once + * the previous function has completed. If any functions in the series pass an + * error to its callback, no more functions are run, and `callback` is + * immediately called with the value of the error. Otherwise, `callback` + * receives an array of results when `tasks` have completed. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function, and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.series}. + * + * **Note** that while many implementations preserve the order of object + * properties, the [ECMAScript Language Specification](http://www.ecma-international.org/ecma-262/5.1/#sec-8.6) + * explicitly states that + * + * > The mechanics and order of enumerating the properties is not specified. + * + * So if you rely on the order in which your series of functions are executed, + * and want this to work on all platforms, consider using an array. + * + * @name series + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing + * [async functions]{@link AsyncFunction} to run in series. + * Each function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This function gets a results array (or object) + * containing all the result arguments passed to the `task` callbacks. Invoked + * with (err, result). + * @return {Promise} a promise, if no callback is passed + * @example + * + * //Using Callbacks + * async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] + * }); + * + * // an example using objects instead of arrays + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.series([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function series(tasks, callback) { + return _parallel(eachOfSeries$1, tasks, callback); +} + +/** + * Returns `true` if at least one element in the `coll` satisfies an async test. + * If any iteratee call returns `true`, the main `callback` is immediately + * called. + * + * @name some + * @static + * @memberOf module:Collections + * @method + * @alias any + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + *); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // false + * // result is false since none of the files exists + * } + *); + * + * // Using Promises + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since some file in the list exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since none of the files exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists); + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists); + * console.log(result); + * // false + * // result is false since none of the files exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function some(coll, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOf$1, coll, iteratee, callback) +} +var some$1 = awaitify(some, 3); + +/** + * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time. + * + * @name someLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anyLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someLimit(coll, limit, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOfLimit$2(limit), coll, iteratee, callback) +} +var someLimit$1 = awaitify(someLimit, 4); + +/** + * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time. + * + * @name someSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anySeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in series. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someSeries(coll, iteratee, callback) { + return _createTester(Boolean, res => res)(eachOfSeries$1, coll, iteratee, callback) +} +var someSeries$1 = awaitify(someSeries, 3); + +/** + * Sorts a list by the results of running each `coll` value through an async + * `iteratee`. + * + * @name sortBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a value to use as the sort criteria as + * its `result`. + * Invoked with (item, callback). + * @param {Function} callback - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is the items + * from the original `coll` sorted by the values returned by the `iteratee` + * calls. Invoked with (err, results). + * @returns {Promise} a promise, if no callback passed + * @example + * + * // bigfile.txt is a file that is 251100 bytes in size + * // mediumfile.txt is a file that is 11000 bytes in size + * // smallfile.txt is a file that is 121 bytes in size + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // By modifying the callback parameter the + * // sorting order can be influenced: + * + * // ascending order + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) return callback(getFileSizeErr); + * callback(null, fileSize); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // descending order + * async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) { + * return callback(getFileSizeErr); + * } + * callback(null, fileSize * -1); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'bigfile.txt', 'mediumfile.txt', 'smallfile.txt'] + * } + * } + * ); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * } + * ); + * + * // Using Promises + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * (async () => { + * try { + * let results = await async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * // Error handling + * async () => { + * try { + * let results = await async.sortBy(['missingfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function sortBy (coll, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return map$1(coll, (x, iterCb) => { + _iteratee(x, (err, criteria) => { + if (err) return iterCb(err); + iterCb(err, {value: x, criteria}); + }); + }, (err, results) => { + if (err) return callback(err); + callback(null, results.sort(comparator).map(v => v.value)); + }); + + function comparator(left, right) { + var a = left.criteria, b = right.criteria; + return a < b ? -1 : a > b ? 1 : 0; + } +} +var sortBy$1 = awaitify(sortBy, 3); + +/** + * Sets a time limit on an asynchronous function. If the function does not call + * its callback within the specified milliseconds, it will be called with a + * timeout error. The code property for the error object will be `'ETIMEDOUT'`. + * + * @name timeout + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} asyncFn - The async function to limit in time. + * @param {number} milliseconds - The specified time limit. + * @param {*} [info] - Any variable you want attached (`string`, `object`, etc) + * to timeout Error for more information.. + * @returns {AsyncFunction} Returns a wrapped function that can be used with any + * of the control flow functions. + * Invoke this function with the same parameters as you would `asyncFunc`. + * @example + * + * function myFunction(foo, callback) { + * doAsyncTask(foo, function(err, data) { + * // handle errors + * if (err) return callback(err); + * + * // do some stuff ... + * + * // return processed data + * return callback(null, data); + * }); + * } + * + * var wrapped = async.timeout(myFunction, 1000); + * + * // call `wrapped` as you would `myFunction` + * wrapped({ bar: 'bar' }, function(err, data) { + * // if `myFunction` takes < 1000 ms to execute, `err` + * // and `data` will have their expected values + * + * // else `err` will be an Error with the code 'ETIMEDOUT' + * }); + */ +function timeout(asyncFn, milliseconds, info) { + var fn = wrapAsync(asyncFn); + + return initialParams((args, callback) => { + var timedOut = false; + var timer; + + function timeoutCallback() { + var name = asyncFn.name || 'anonymous'; + var error = new Error('Callback function "' + name + '" timed out.'); + error.code = 'ETIMEDOUT'; + if (info) { + error.info = info; + } + timedOut = true; + callback(error); + } + + args.push((...cbArgs) => { + if (!timedOut) { + callback(...cbArgs); + clearTimeout(timer); + } + }); + + // setup timer and call original function + timer = setTimeout(timeoutCallback, milliseconds); + fn(...args); + }); +} + +function range(size) { + var result = Array(size); + while (size--) { + result[size] = size; + } + return result; +} + +/** + * The same as [times]{@link module:ControlFlow.times} but runs a maximum of `limit` async operations at a + * time. + * + * @name timesLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} count - The number of times to run the function. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see [async.map]{@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ +function timesLimit(count, limit, iteratee, callback) { + var _iteratee = wrapAsync(iteratee); + return mapLimit$1(range(count), limit, _iteratee, callback); +} + +/** + * Calls the `iteratee` function `n` times, and accumulates results in the same + * manner you would use with [map]{@link module:Collections.map}. + * + * @name times + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.map]{@link module:Collections.map} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + * @example + * + * // Pretend this is some complicated async factory + * var createUser = function(id, callback) { + * callback(null, { + * id: 'user' + id + * }); + * }; + * + * // generate 5 users + * async.times(5, function(n, next) { + * createUser(n, function(err, user) { + * next(err, user); + * }); + * }, function(err, users) { + * // we should now have 5 users + * }); + */ +function times (n, iteratee, callback) { + return timesLimit(n, Infinity, iteratee, callback) +} + +/** + * The same as [times]{@link module:ControlFlow.times} but runs only a single async operation at a time. + * + * @name timesSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ +function timesSeries (n, iteratee, callback) { + return timesLimit(n, 1, iteratee, callback) +} + +/** + * A relative of `reduce`. Takes an Object or Array, and iterates over each + * element in parallel, each step potentially mutating an `accumulator` value. + * The type of the accumulator defaults to the type of collection passed in. + * + * @name transform + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} [accumulator] - The initial state of the transform. If omitted, + * it will default to an empty Object or Array, depending on the type of `coll` + * @param {AsyncFunction} iteratee - A function applied to each item in the + * collection that potentially modifies the accumulator. + * Invoked with (accumulator, item, key, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the transformed accumulator. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileList, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * }); + * + * // Using Promises + * async.transform(fileList, transformFileSize) + * .then(result => { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * (async () => { + * try { + * let result = await async.transform(fileList, transformFileSize); + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileMap = { f1: 'file1.txt', f2: 'file2.txt', f3: 'file3.txt' }; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileMap, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * }); + * + * // Using Promises + * async.transform(fileMap, transformFileSize) + * .then(result => { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.transform(fileMap, transformFileSize); + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function transform (coll, accumulator, iteratee, callback) { + if (arguments.length <= 3 && typeof accumulator === 'function') { + callback = iteratee; + iteratee = accumulator; + accumulator = Array.isArray(coll) ? [] : {}; + } + callback = once(callback || promiseCallback()); + var _iteratee = wrapAsync(iteratee); + + eachOf$1(coll, (v, k, cb) => { + _iteratee(accumulator, v, k, cb); + }, err => callback(err, accumulator)); + return callback[PROMISE_SYMBOL] +} + +/** + * It runs each task in series but stops whenever any of the functions were + * successful. If one of the tasks were successful, the `callback` will be + * passed the result of the successful task. If all tasks fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name tryEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing functions to + * run, each function is passed a `callback(err, result)` it must call on + * completion with an error `err` (which can be `null`) and an optional `result` + * value. + * @param {Function} [callback] - An optional callback which is called when one + * of the tasks has succeeded, or all have failed. It receives the `err` and + * `result` arguments of the last attempt at completing the `task`. Invoked with + * (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * async.tryEach([ + * function getDataFromFirstWebsite(callback) { + * // Try getting the data from the first website + * callback(err, data); + * }, + * function getDataFromSecondWebsite(callback) { + * // First website failed, + * // Try getting the data from the backup website + * callback(err, data); + * } + * ], + * // optional callback + * function(err, results) { + * Now do something with the data. + * }); + * + */ +function tryEach(tasks, callback) { + var error = null; + var result; + return eachSeries$1(tasks, (task, taskCb) => { + wrapAsync(task)((err, ...args) => { + if (err === false) return taskCb(err); + + if (args.length < 2) { + [result] = args; + } else { + result = args; + } + error = err; + taskCb(err ? null : {}); + }); + }, () => callback(error, result)); +} + +var tryEach$1 = awaitify(tryEach); + +/** + * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original, + * unmemoized form. Handy for testing. + * + * @name unmemoize + * @static + * @memberOf module:Utils + * @method + * @see [async.memoize]{@link module:Utils.memoize} + * @category Util + * @param {AsyncFunction} fn - the memoized function + * @returns {AsyncFunction} a function that calls the original unmemoized function + */ +function unmemoize(fn) { + return (...args) => { + return (fn.unmemoized || fn)(...args); + }; +} + +/** + * Repeatedly call `iteratee`, while `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. + * + * @name whilst + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` passes. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + * @example + * + * var count = 0; + * async.whilst( + * function test(cb) { cb(null, count < 5); }, + * function iter(callback) { + * count++; + * setTimeout(function() { + * callback(null, count); + * }, 1000); + * }, + * function (err, n) { + * // 5 seconds have passed, n = 5 + * } + * ); + */ +function whilst(test, iteratee, callback) { + callback = onlyOnce(callback); + var _fn = wrapAsync(iteratee); + var _test = wrapAsync(test); + var results = []; + + function next(err, ...rest) { + if (err) return callback(err); + results = rest; + if (err === false) return; + _test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return _test(check); +} +var whilst$1 = awaitify(whilst, 3); + +/** + * Repeatedly call `iteratee` until `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. `callback` will be passed an error and any + * arguments passed to the final `iteratee`'s callback. + * + * The inverse of [whilst]{@link module:ControlFlow.whilst}. + * + * @name until + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * const results = [] + * let finished = false + * async.until(function test(cb) { + * cb(null, finished) + * }, function iter(next) { + * fetchPage(url, (err, body) => { + * if (err) return next(err) + * results = results.concat(body.objects) + * finished = !!body.next + * next(err) + * }) + * }, function done (err) { + * // all pages have been fetched + * }) + */ +function until(test, iteratee, callback) { + const _test = wrapAsync(test); + return whilst$1((cb) => _test((err, truth) => cb (err, !truth)), iteratee, callback); +} + +/** + * Runs the `tasks` array of functions in series, each passing their results to + * the next in the array. However, if any of the `tasks` pass an error to their + * own callback, the next function is not executed, and the main `callback` is + * immediately called with the error. + * + * @name waterfall + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array of [async functions]{@link AsyncFunction} + * to run. + * Each function should complete with any number of `result` values. + * The `result` values will be passed as arguments, in order, to the next task. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This will be passed the results of the last task's + * callback. Invoked with (err, [results]). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.waterfall([ + * function(callback) { + * callback(null, 'one', 'two'); + * }, + * function(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * }, + * function(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + * ], function (err, result) { + * // result now equals 'done' + * }); + * + * // Or, with named functions: + * async.waterfall([ + * myFirstFunction, + * mySecondFunction, + * myLastFunction, + * ], function (err, result) { + * // result now equals 'done' + * }); + * function myFirstFunction(callback) { + * callback(null, 'one', 'two'); + * } + * function mySecondFunction(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * } + * function myLastFunction(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + */ +function waterfall (tasks, callback) { + callback = once(callback); + if (!Array.isArray(tasks)) return callback(new Error('First argument to waterfall must be an array of functions')); + if (!tasks.length) return callback(); + var taskIndex = 0; + + function nextTask(args) { + var task = wrapAsync(tasks[taskIndex++]); + task(...args, onlyOnce(next)); + } + + function next(err, ...args) { + if (err === false) return + if (err || taskIndex === tasks.length) { + return callback(err, ...args); + } + nextTask(args); + } + + nextTask([]); +} + +var waterfall$1 = awaitify(waterfall); + +/** + * An "async function" in the context of Async is an asynchronous function with + * a variable number of parameters, with the final parameter being a callback. + * (`function (arg1, arg2, ..., callback) {}`) + * The final callback is of the form `callback(err, results...)`, which must be + * called once the function is completed. The callback should be called with a + * Error as its first argument to signal that an error occurred. + * Otherwise, if no error occurred, it should be called with `null` as the first + * argument, and any additional `result` arguments that may apply, to signal + * successful completion. + * The callback must be called exactly once, ideally on a later tick of the + * JavaScript event loop. + * + * This type of function is also referred to as a "Node-style async function", + * or a "continuation passing-style function" (CPS). Most of the methods of this + * library are themselves CPS/Node-style async functions, or functions that + * return CPS/Node-style async functions. + * + * Wherever we accept a Node-style async function, we also directly accept an + * [ES2017 `async` function]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function}. + * In this case, the `async` function will not be passed a final callback + * argument, and any thrown error will be used as the `err` argument of the + * implicit callback, and the return value will be used as the `result` value. + * (i.e. a `rejected` of the returned Promise becomes the `err` callback + * argument, and a `resolved` value becomes the `result`.) + * + * Note, due to JavaScript limitations, we can only detect native `async` + * functions and not transpilied implementations. + * Your environment must have `async`/`await` support for this to work. + * (e.g. Node > v7.6, or a recent version of a modern browser). + * If you are using `async` functions through a transpiler (e.g. Babel), you + * must still wrap the function with [asyncify]{@link module:Utils.asyncify}, + * because the `async function` will be compiled to an ordinary function that + * returns a promise. + * + * @typedef {Function} AsyncFunction + * @static + */ + + +var index = { + apply, + applyEach, + applyEachSeries, + asyncify, + auto, + autoInject, + cargo: cargo$1, + cargoQueue: cargo, + compose, + concat: concat$1, + concatLimit: concatLimit$1, + concatSeries: concatSeries$1, + constant: constant$1, + detect: detect$1, + detectLimit: detectLimit$1, + detectSeries: detectSeries$1, + dir, + doUntil, + doWhilst: doWhilst$1, + each, + eachLimit: eachLimit$1, + eachOf: eachOf$1, + eachOfLimit: eachOfLimit$1, + eachOfSeries: eachOfSeries$1, + eachSeries: eachSeries$1, + ensureAsync, + every: every$1, + everyLimit: everyLimit$1, + everySeries: everySeries$1, + filter: filter$1, + filterLimit: filterLimit$1, + filterSeries: filterSeries$1, + forever: forever$1, + groupBy, + groupByLimit: groupByLimit$1, + groupBySeries, + log, + map: map$1, + mapLimit: mapLimit$1, + mapSeries: mapSeries$1, + mapValues, + mapValuesLimit: mapValuesLimit$1, + mapValuesSeries, + memoize, + nextTick, + parallel, + parallelLimit, + priorityQueue, + queue, + race: race$1, + reduce: reduce$1, + reduceRight, + reflect, + reflectAll, + reject: reject$1, + rejectLimit: rejectLimit$1, + rejectSeries: rejectSeries$1, + retry, + retryable, + seq, + series, + setImmediate: setImmediate$1, + some: some$1, + someLimit: someLimit$1, + someSeries: someSeries$1, + sortBy: sortBy$1, + timeout, + times, + timesLimit, + timesSeries, + transform, + tryEach: tryEach$1, + unmemoize, + until, + waterfall: waterfall$1, + whilst: whilst$1, + + // aliases + all: every$1, + allLimit: everyLimit$1, + allSeries: everySeries$1, + any: some$1, + anyLimit: someLimit$1, + anySeries: someSeries$1, + find: detect$1, + findLimit: detectLimit$1, + findSeries: detectSeries$1, + flatMap: concat$1, + flatMapLimit: concatLimit$1, + flatMapSeries: concatSeries$1, + forEach: each, + forEachSeries: eachSeries$1, + forEachLimit: eachLimit$1, + forEachOf: eachOf$1, + forEachOfSeries: eachOfSeries$1, + forEachOfLimit: eachOfLimit$1, + inject: reduce$1, + foldl: reduce$1, + foldr: reduceRight, + select: filter$1, + selectLimit: filterLimit$1, + selectSeries: filterSeries$1, + wrapSync: asyncify, + during: whilst$1, + doDuring: doWhilst$1 +}; + +export { every$1 as all, everyLimit$1 as allLimit, everySeries$1 as allSeries, some$1 as any, someLimit$1 as anyLimit, someSeries$1 as anySeries, apply, applyEach, applyEachSeries, asyncify, auto, autoInject, cargo$1 as cargo, cargo as cargoQueue, compose, concat$1 as concat, concatLimit$1 as concatLimit, concatSeries$1 as concatSeries, constant$1 as constant, index as default, detect$1 as detect, detectLimit$1 as detectLimit, detectSeries$1 as detectSeries, dir, doWhilst$1 as doDuring, doUntil, doWhilst$1 as doWhilst, whilst$1 as during, each, eachLimit$1 as eachLimit, eachOf$1 as eachOf, eachOfLimit$1 as eachOfLimit, eachOfSeries$1 as eachOfSeries, eachSeries$1 as eachSeries, ensureAsync, every$1 as every, everyLimit$1 as everyLimit, everySeries$1 as everySeries, filter$1 as filter, filterLimit$1 as filterLimit, filterSeries$1 as filterSeries, detect$1 as find, detectLimit$1 as findLimit, detectSeries$1 as findSeries, concat$1 as flatMap, concatLimit$1 as flatMapLimit, concatSeries$1 as flatMapSeries, reduce$1 as foldl, reduceRight as foldr, each as forEach, eachLimit$1 as forEachLimit, eachOf$1 as forEachOf, eachOfLimit$1 as forEachOfLimit, eachOfSeries$1 as forEachOfSeries, eachSeries$1 as forEachSeries, forever$1 as forever, groupBy, groupByLimit$1 as groupByLimit, groupBySeries, reduce$1 as inject, log, map$1 as map, mapLimit$1 as mapLimit, mapSeries$1 as mapSeries, mapValues, mapValuesLimit$1 as mapValuesLimit, mapValuesSeries, memoize, nextTick, parallel, parallelLimit, priorityQueue, queue, race$1 as race, reduce$1 as reduce, reduceRight, reflect, reflectAll, reject$1 as reject, rejectLimit$1 as rejectLimit, rejectSeries$1 as rejectSeries, retry, retryable, filter$1 as select, filterLimit$1 as selectLimit, filterSeries$1 as selectSeries, seq, series, setImmediate$1 as setImmediate, some$1 as some, someLimit$1 as someLimit, someSeries$1 as someSeries, sortBy$1 as sortBy, timeout, times, timesLimit, timesSeries, transform, tryEach$1 as tryEach, unmemoize, until, waterfall$1 as waterfall, whilst$1 as whilst, asyncify as wrapSync }; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doDuring.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doDuring.js new file mode 100644 index 0000000..c72766d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doDuring.js @@ -0,0 +1,68 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - A function which is called each time `test` + * passes. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ +function doWhilst(iteratee, test, callback) { + callback = (0, _onlyOnce2.default)(callback); + var _fn = (0, _wrapAsync2.default)(iteratee); + var _test = (0, _wrapAsync2.default)(test); + var results; + + function next(err, ...args) { + if (err) return callback(err); + if (err === false) return; + results = args; + _test(...args, check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return check(null, true); +} + +exports.default = (0, _awaitify2.default)(doWhilst, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doUntil.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doUntil.js new file mode 100644 index 0000000..519900e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doUntil.js @@ -0,0 +1,46 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = doUntil; + +var _doWhilst = require('./doWhilst.js'); + +var _doWhilst2 = _interopRequireDefault(_doWhilst); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Like ['doWhilst']{@link module:ControlFlow.doWhilst}, except the `test` is inverted. Note the + * argument ordering differs from `until`. + * + * @name doUntil + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.doWhilst]{@link module:ControlFlow.doWhilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee` + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ +function doUntil(iteratee, test, callback) { + const _test = (0, _wrapAsync2.default)(test); + return (0, _doWhilst2.default)(iteratee, (...args) => { + const cb = args.pop(); + _test(...args, (err, truth) => cb(err, !truth)); + }, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doWhilst.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doWhilst.js new file mode 100644 index 0000000..c72766d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/doWhilst.js @@ -0,0 +1,68 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The post-check version of [`whilst`]{@link module:ControlFlow.whilst}. To reflect the difference in + * the order of operations, the arguments `test` and `iteratee` are switched. + * + * `doWhilst` is to `whilst` as `do while` is to `while` in plain JavaScript. + * + * @name doWhilst + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} iteratee - A function which is called each time `test` + * passes. Invoked with (callback). + * @param {AsyncFunction} test - asynchronous truth test to perform after each + * execution of `iteratee`. Invoked with (...args, callback), where `...args` are the + * non-error args from the previous callback of `iteratee`. + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. + * `callback` will be passed an error and any arguments passed to the final + * `iteratee`'s callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + */ +function doWhilst(iteratee, test, callback) { + callback = (0, _onlyOnce2.default)(callback); + var _fn = (0, _wrapAsync2.default)(iteratee); + var _test = (0, _wrapAsync2.default)(test); + var results; + + function next(err, ...args) { + if (err) return callback(err); + if (err === false) return; + results = args; + _test(...args, check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return check(null, true); +} + +exports.default = (0, _awaitify2.default)(doWhilst, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/during.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/during.js new file mode 100644 index 0000000..4165543 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/during.js @@ -0,0 +1,78 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Repeatedly call `iteratee`, while `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. + * + * @name whilst + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` passes. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + * @example + * + * var count = 0; + * async.whilst( + * function test(cb) { cb(null, count < 5); }, + * function iter(callback) { + * count++; + * setTimeout(function() { + * callback(null, count); + * }, 1000); + * }, + * function (err, n) { + * // 5 seconds have passed, n = 5 + * } + * ); + */ +function whilst(test, iteratee, callback) { + callback = (0, _onlyOnce2.default)(callback); + var _fn = (0, _wrapAsync2.default)(iteratee); + var _test = (0, _wrapAsync2.default)(test); + var results = []; + + function next(err, ...rest) { + if (err) return callback(err); + results = rest; + if (err === false) return; + _test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return _test(check); +} +exports.default = (0, _awaitify2.default)(whilst, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/each.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/each.js new file mode 100644 index 0000000..fdfcbd8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/each.js @@ -0,0 +1,129 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _withoutIndex = require('./internal/withoutIndex.js'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to + * each item in `coll`. Invoked with (item, callback). + * The array index is not passed to the iteratee. + * If you need the index, use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = [ 'dir1/file2.txt', 'dir2/file3.txt', 'dir/file5.txt']; + * const withMissingFileList = ['dir1/file1.txt', 'dir4/file2.txt']; + * + * // asynchronous function that deletes a file + * const deleteFile = function(file, callback) { + * fs.unlink(file, callback); + * }; + * + * // Using callbacks + * async.each(fileList, deleteFile, function(err) { + * if( err ) { + * console.log(err); + * } else { + * console.log('All files have been deleted successfully'); + * } + * }); + * + * // Error Handling + * async.each(withMissingFileList, deleteFile, function(err){ + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using Promises + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using async/await + * async () => { + * try { + * await async.each(files, deleteFile); + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * await async.each(withMissingFileList, deleteFile); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * } + * } + * + */ +function eachLimit(coll, iteratee, callback) { + return (0, _eachOf2.default)(coll, (0, _withoutIndex2.default)((0, _wrapAsync2.default)(iteratee)), callback); +} + +exports.default = (0, _awaitify2.default)(eachLimit, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachLimit.js new file mode 100644 index 0000000..7f5928c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachLimit.js @@ -0,0 +1,50 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _withoutIndex = require('./internal/withoutIndex.js'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfLimit`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachLimit(coll, limit, iteratee, callback) { + return (0, _eachOfLimit2.default)(limit)(coll, (0, _withoutIndex2.default)((0, _wrapAsync2.default)(iteratee)), callback); +} +exports.default = (0, _awaitify2.default)(eachLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOf.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOf.js new file mode 100644 index 0000000..9ed20f6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOf.js @@ -0,0 +1,185 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _isArrayLike = require('./internal/isArrayLike.js'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _breakLoop = require('./internal/breakLoop.js'); + +var _breakLoop2 = _interopRequireDefault(_breakLoop); + +var _eachOfLimit = require('./eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// eachOf implementation optimized for array-likes +function eachOfArrayLike(coll, iteratee, callback) { + callback = (0, _once2.default)(callback); + var index = 0, + completed = 0, + { length } = coll, + canceled = false; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err, value) { + if (err === false) { + canceled = true; + } + if (canceled === true) return; + if (err) { + callback(err); + } else if (++completed === length || value === _breakLoop2.default) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, (0, _onlyOnce2.default)(iteratorCallback)); + } +} + +// a generic version of eachOf which can handle array, object, and iterator cases. +function eachOfGeneric(coll, iteratee, callback) { + return (0, _eachOfLimit2.default)(coll, Infinity, iteratee, callback); +} + +/** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each + * item in `coll`. + * The `key` is the item's key, or index in the case of an array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dev.json is a file containing a valid json object config for dev environment + * // dev.json is a file containing a valid json object config for test environment + * // prod.json is a file containing a valid json object config for prod environment + * // invalid.json is a file with a malformed json object + * + * let configs = {}; //global variable + * let validConfigFileMap = {dev: 'dev.json', test: 'test.json', prod: 'prod.json'}; + * let invalidConfigFileMap = {dev: 'dev.json', test: 'test.json', invalid: 'invalid.json'}; + * + * // asynchronous function that reads a json file and parses the contents as json object + * function parseFile(file, key, callback) { + * fs.readFile(file, "utf8", function(err, data) { + * if (err) return calback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * } + * + * // Using callbacks + * async.forEachOf(validConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * } else { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * // JSON parse error exception + * } else { + * console.log(configs); + * } + * }); + * + * // Using Promises + * async.forEachOf(validConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * }).catch( err => { + * console.error(err); + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * }).catch( err => { + * console.error(err); + * // JSON parse error exception + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.forEachOf(validConfigFileMap, parseFile); + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * catch (err) { + * console.log(err); + * } + * } + * + * //Error handing + * async () => { + * try { + * let result = await async.forEachOf(invalidConfigFileMap, parseFile); + * console.log(configs); + * } + * catch (err) { + * console.log(err); + * // JSON parse error exception + * } + * } + * + */ +function eachOf(coll, iteratee, callback) { + var eachOfImplementation = (0, _isArrayLike2.default)(coll) ? eachOfArrayLike : eachOfGeneric; + return eachOfImplementation(coll, (0, _wrapAsync2.default)(iteratee), callback); +} + +exports.default = (0, _awaitify2.default)(eachOf, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfLimit.js new file mode 100644 index 0000000..a596e5a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfLimit.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit2 = require('./internal/eachOfLimit.js'); + +var _eachOfLimit3 = _interopRequireDefault(_eachOfLimit2); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfLimit(coll, limit, iteratee, callback) { + return (0, _eachOfLimit3.default)(limit)(coll, (0, _wrapAsync2.default)(iteratee), callback); +} + +exports.default = (0, _awaitify2.default)(eachOfLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfSeries.js new file mode 100644 index 0000000..04243ad --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachOfSeries.js @@ -0,0 +1,39 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time. + * + * @name eachOfSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfSeries(coll, iteratee, callback) { + return (0, _eachOfLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(eachOfSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachSeries.js new file mode 100644 index 0000000..b04896e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/eachSeries.js @@ -0,0 +1,44 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachLimit = require('./eachLimit.js'); + +var _eachLimit2 = _interopRequireDefault(_eachLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * Note, that unlike [`each`]{@link module:Collections.each}, this function applies iteratee to each item + * in series and therefore the iteratee functions will complete in order. + + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfSeries`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachSeries(coll, iteratee, callback) { + return (0, _eachLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(eachSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/ensureAsync.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/ensureAsync.js new file mode 100644 index 0000000..749c5da --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/ensureAsync.js @@ -0,0 +1,67 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = ensureAsync; + +var _setImmediate = require('./internal/setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Wrap an async function and ensure it calls its callback on a later tick of + * the event loop. If the function already calls its callback on a next tick, + * no extra deferral is added. This is useful for preventing stack overflows + * (`RangeError: Maximum call stack size exceeded`) and generally keeping + * [Zalgo](http://blog.izs.me/post/59142742143/designing-apis-for-asynchrony) + * contained. ES2017 `async` functions are returned as-is -- they are immune + * to Zalgo's corrupting influences, as they always resolve on a later tick. + * + * @name ensureAsync + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - an async function, one that expects a node-style + * callback as its last argument. + * @returns {AsyncFunction} Returns a wrapped function with the exact same call + * signature as the function passed in. + * @example + * + * function sometimesAsync(arg, callback) { + * if (cache[arg]) { + * return callback(null, cache[arg]); // this would be synchronous!! + * } else { + * doSomeIO(arg, callback); // this IO would be asynchronous + * } + * } + * + * // this has a risk of stack overflows if many results are cached in a row + * async.mapSeries(args, sometimesAsync, done); + * + * // this will defer sometimesAsync's callback if necessary, + * // preventing stack overflows + * async.mapSeries(args, async.ensureAsync(sometimesAsync), done); + */ +function ensureAsync(fn) { + if ((0, _wrapAsync.isAsync)(fn)) return fn; + return function (...args /*, callback*/) { + var callback = args.pop(); + var sync = true; + args.push((...innerArgs) => { + if (sync) { + (0, _setImmediate2.default)(() => callback(...innerArgs)); + } else { + callback(...innerArgs); + } + }); + fn.apply(this, args); + sync = false; + }; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/every.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/every.js new file mode 100644 index 0000000..622b301 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/every.js @@ -0,0 +1,119 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns `true` if every element in `coll` satisfies an async test. If any + * iteratee call returns `false`, the main `callback` is immediately called. + * + * @name every + * @static + * @memberOf module:Collections + * @method + * @alias all + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file5.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.every(fileList, fileExists, function(err, result) { + * console.log(result); + * // true + * // result is true since every file exists + * }); + * + * async.every(withMissingFileList, fileExists, function(err, result) { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }); + * + * // Using Promises + * async.every(fileList, fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.every(withMissingFileList, fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since NOT every file exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.every(fileList, fileExists); + * console.log(result); + * // true + * // result is true since every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.every(withMissingFileList, fileExists); + * console.log(result); + * // false + * // result is false since NOT every file exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function every(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(every, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everyLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everyLimit.js new file mode 100644 index 0000000..375e126 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everyLimit.js @@ -0,0 +1,46 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time. + * + * @name everyLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in parallel. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everyLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(everyLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everySeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everySeries.js new file mode 100644 index 0000000..9a6bf7d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/everySeries.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time. + * + * @name everySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.every]{@link module:Collections.every} + * @alias allSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collection in series. + * The iteratee must complete with a boolean result value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result will be either `true` or `false` + * depending on the values of the async tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function everySeries(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => !bool, res => !res)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(everySeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filter.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filter.js new file mode 100644 index 0000000..2c9a63d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filter.js @@ -0,0 +1,93 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const files = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.filter(files, fileExists, function(err, results) { + * if(err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * }); + * + * // Using Promises + * async.filter(files, fileExists) + * .then(results => { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.filter(files, fileExists); + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function filter(coll, iteratee, callback) { + return (0, _filter3.default)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filter, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterLimit.js new file mode 100644 index 0000000..d3b3f50 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterLimit.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + */ +function filterLimit(coll, limit, iteratee, callback) { + return (0, _filter3.default)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filterLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterSeries.js new file mode 100644 index 0000000..019a2d0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/filterSeries.js @@ -0,0 +1,43 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + * @returns {Promise} a promise, if no callback provided + */ +function filterSeries(coll, iteratee, callback) { + return (0, _filter3.default)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filterSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/find.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/find.js new file mode 100644 index 0000000..d5896ef --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/find.js @@ -0,0 +1,96 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns the first value in `coll` that passes an async truth test. The + * `iteratee` is applied in parallel, meaning the first iteratee to return + * `true` will fire the detect `callback` with that result. That means the + * result might not be the first item in the original `coll` (in terms of order) + * that passes the test. + + * If order within the original `coll` is important, then look at + * [`detectSeries`]{@link module:Collections.detectSeries}. + * + * @name detect + * @static + * @memberOf module:Collections + * @method + * @alias find + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * } + *); + * + * // Using Promises + * async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists) + * .then(result => { + * console.log(result); + * // dir1/file1.txt + * // result now equals the first file in the list that exists + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.detect(['file3.txt','file2.txt','dir1/file1.txt'], fileExists); + * console.log(result); + * // dir1/file1.txt + * // result now equals the file in the list that exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function detect(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(detect, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findLimit.js new file mode 100644 index 0000000..c59843b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findLimit.js @@ -0,0 +1,48 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a + * time. + * + * @name detectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findLimit + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(detectLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findSeries.js new file mode 100644 index 0000000..b486899 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/findSeries.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time. + * + * @name detectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.detect]{@link module:Collections.detect} + * @alias findSeries + * @category Collections + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A truth test to apply to each item in `coll`. + * The iteratee must complete with a boolean value as its result. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the `iteratee` functions have finished. + * Result will be the first item in the array that passes the truth test + * (iteratee) or the value `undefined` if none passed. Invoked with + * (err, result). + * @returns {Promise} a promise, if a callback is omitted + */ +function detectSeries(coll, iteratee, callback) { + return (0, _createTester2.default)(bool => bool, (res, item) => item)((0, _eachOfLimit2.default)(1), coll, iteratee, callback); +} + +exports.default = (0, _awaitify2.default)(detectSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMap.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMap.js new file mode 100644 index 0000000..4540a79 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMap.js @@ -0,0 +1,115 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _concatLimit = require('./concatLimit.js'); + +var _concatLimit2 = _interopRequireDefault(_concatLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies `iteratee` to each item in `coll`, concatenating the results. Returns + * the concatenated list. The `iteratee`s are called in parallel, and the + * results are concatenated as they return. The results array will be returned in + * the original order of `coll` passed to the `iteratee` function. + * + * @name concat + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @alias flatMap + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * let directoryList = ['dir1','dir2','dir3']; + * let withMissingDirectoryList = ['dir1','dir2','dir3', 'dir4']; + * + * // Using callbacks + * async.concat(directoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.concat(directoryList, fs.readdir) + * .then(results => { + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Error Handling + * async.concat(withMissingDirectoryList, fs.readdir) + * .then(results => { + * console.log(results); + * }).catch(err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.concat(directoryList, fs.readdir); + * console.log(results); + * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] + * } catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.concat(withMissingDirectoryList, fs.readdir); + * console.log(results); + * } catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4 does not exist + * } + * } + * + */ +function concat(coll, iteratee, callback) { + return (0, _concatLimit2.default)(coll, Infinity, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(concat, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapLimit.js new file mode 100644 index 0000000..a27cc7d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapLimit.js @@ -0,0 +1,60 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _mapLimit = require('./mapLimit.js'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs a maximum of `limit` async operations at a time. + * + * @name concatLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapLimit + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, + * which should use an array as its result. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatLimit(coll, limit, iteratee, callback) { + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _mapLimit2.default)(coll, limit, (val, iterCb) => { + _iteratee(val, (err, ...args) => { + if (err) return iterCb(err); + return iterCb(err, args); + }); + }, (err, mapResults) => { + var result = []; + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + result = result.concat(...mapResults[i]); + } + } + + return callback(err, result); + }); +} +exports.default = (0, _awaitify2.default)(concatLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapSeries.js new file mode 100644 index 0000000..332de3f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/flatMapSeries.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _concatLimit = require('./concatLimit.js'); + +var _concatLimit2 = _interopRequireDefault(_concatLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`concat`]{@link module:Collections.concat} but runs only a single async operation at a time. + * + * @name concatSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.concat]{@link module:Collections.concat} + * @category Collection + * @alias flatMapSeries + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`. + * The iteratee should complete with an array an array of results. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is an array + * containing the concatenated results of the `iteratee` function. Invoked with + * (err, results). + * @returns A Promise, if no callback is passed + */ +function concatSeries(coll, iteratee, callback) { + return (0, _concatLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(concatSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldl.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldl.js new file mode 100644 index 0000000..8a69548 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldl.js @@ -0,0 +1,153 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Reduces `coll` into a single value using an async `iteratee` to return each + * successive step. `memo` is the initial state of the reduction. This function + * only operates in series. + * + * For performance reasons, it may make sense to split a call to this function + * into a parallel map, and then use the normal `Array.prototype.reduce` on the + * results. This function is for situations where each step in the reduction + * needs to be async; if you can get the data before reducing it, then it's + * probably a good idea to do so. + * + * @name reduce + * @static + * @memberOf module:Collections + * @method + * @alias inject + * @alias foldl + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file3.txt', 'file4.txt']; + * + * // asynchronous function that computes the file size in bytes + * // file size is added to the memoized value, then returned + * function getFileSizeInBytes(memo, file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, memo + stat.size); + * }); + * } + * + * // Using callbacks + * async.reduce(fileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.reduce(fileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.reduce(fileList, 0, getFileSizeInBytes); + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.reduce(withMissingFileList, 0, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function reduce(coll, memo, iteratee, callback) { + callback = (0, _once2.default)(callback); + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _eachOfSeries2.default)(coll, (x, i, iterCb) => { + _iteratee(memo, x, (err, v) => { + memo = v; + iterCb(err); + }); + }, err => callback(err, memo)); +} +exports.default = (0, _awaitify2.default)(reduce, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldr.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldr.js new file mode 100644 index 0000000..5be1b68 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/foldr.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reduceRight; + +var _reduce = require('./reduce.js'); + +var _reduce2 = _interopRequireDefault(_reduce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Same as [`reduce`]{@link module:Collections.reduce}, only operates on `array` in reverse order. + * + * @name reduceRight + * @static + * @memberOf module:Collections + * @method + * @see [async.reduce]{@link module:Collections.reduce} + * @alias foldr + * @category Collection + * @param {Array} array - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function reduceRight(array, memo, iteratee, callback) { + var reversed = [...array].reverse(); + return (0, _reduce2.default)(reversed, memo, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEach.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEach.js new file mode 100644 index 0000000..fdfcbd8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEach.js @@ -0,0 +1,129 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _withoutIndex = require('./internal/withoutIndex.js'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Applies the function `iteratee` to each item in `coll`, in parallel. + * The `iteratee` is called with an item from the list, and a callback for when + * it has finished. If the `iteratee` passes an error to its `callback`, the + * main `callback` (for the `each` function) is immediately called with the + * error. + * + * Note, that since this function applies `iteratee` to each item in parallel, + * there is no guarantee that the iteratee functions will complete in order. + * + * @name each + * @static + * @memberOf module:Collections + * @method + * @alias forEach + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to + * each item in `coll`. Invoked with (item, callback). + * The array index is not passed to the iteratee. + * If you need the index, use `eachOf`. + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const fileList = [ 'dir1/file2.txt', 'dir2/file3.txt', 'dir/file5.txt']; + * const withMissingFileList = ['dir1/file1.txt', 'dir4/file2.txt']; + * + * // asynchronous function that deletes a file + * const deleteFile = function(file, callback) { + * fs.unlink(file, callback); + * }; + * + * // Using callbacks + * async.each(fileList, deleteFile, function(err) { + * if( err ) { + * console.log(err); + * } else { + * console.log('All files have been deleted successfully'); + * } + * }); + * + * // Error Handling + * async.each(withMissingFileList, deleteFile, function(err){ + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using Promises + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.each(fileList, deleteFile) + * .then( () => { + * console.log('All files have been deleted successfully'); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * }); + * + * // Using async/await + * async () => { + * try { + * await async.each(files, deleteFile); + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * await async.each(withMissingFileList, deleteFile); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * // since dir4/file2.txt does not exist + * // dir1/file1.txt could have been deleted + * } + * } + * + */ +function eachLimit(coll, iteratee, callback) { + return (0, _eachOf2.default)(coll, (0, _withoutIndex2.default)((0, _wrapAsync2.default)(iteratee)), callback); +} + +exports.default = (0, _awaitify2.default)(eachLimit, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachLimit.js new file mode 100644 index 0000000..7f5928c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachLimit.js @@ -0,0 +1,50 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _withoutIndex = require('./internal/withoutIndex.js'); + +var _withoutIndex2 = _interopRequireDefault(_withoutIndex); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs a maximum of `limit` async operations at a time. + * + * @name eachLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfLimit`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachLimit(coll, limit, iteratee, callback) { + return (0, _eachOfLimit2.default)(limit)(coll, (0, _withoutIndex2.default)((0, _wrapAsync2.default)(iteratee)), callback); +} +exports.default = (0, _awaitify2.default)(eachLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOf.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOf.js new file mode 100644 index 0000000..9ed20f6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOf.js @@ -0,0 +1,185 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _isArrayLike = require('./internal/isArrayLike.js'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _breakLoop = require('./internal/breakLoop.js'); + +var _breakLoop2 = _interopRequireDefault(_breakLoop); + +var _eachOfLimit = require('./eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// eachOf implementation optimized for array-likes +function eachOfArrayLike(coll, iteratee, callback) { + callback = (0, _once2.default)(callback); + var index = 0, + completed = 0, + { length } = coll, + canceled = false; + if (length === 0) { + callback(null); + } + + function iteratorCallback(err, value) { + if (err === false) { + canceled = true; + } + if (canceled === true) return; + if (err) { + callback(err); + } else if (++completed === length || value === _breakLoop2.default) { + callback(null); + } + } + + for (; index < length; index++) { + iteratee(coll[index], index, (0, _onlyOnce2.default)(iteratorCallback)); + } +} + +// a generic version of eachOf which can handle array, object, and iterator cases. +function eachOfGeneric(coll, iteratee, callback) { + return (0, _eachOfLimit2.default)(coll, Infinity, iteratee, callback); +} + +/** + * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument + * to the iteratee. + * + * @name eachOf + * @static + * @memberOf module:Collections + * @method + * @alias forEachOf + * @category Collection + * @see [async.each]{@link module:Collections.each} + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each + * item in `coll`. + * The `key` is the item's key, or index in the case of an array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * // dev.json is a file containing a valid json object config for dev environment + * // dev.json is a file containing a valid json object config for test environment + * // prod.json is a file containing a valid json object config for prod environment + * // invalid.json is a file with a malformed json object + * + * let configs = {}; //global variable + * let validConfigFileMap = {dev: 'dev.json', test: 'test.json', prod: 'prod.json'}; + * let invalidConfigFileMap = {dev: 'dev.json', test: 'test.json', invalid: 'invalid.json'}; + * + * // asynchronous function that reads a json file and parses the contents as json object + * function parseFile(file, key, callback) { + * fs.readFile(file, "utf8", function(err, data) { + * if (err) return calback(err); + * try { + * configs[key] = JSON.parse(data); + * } catch (e) { + * return callback(e); + * } + * callback(); + * }); + * } + * + * // Using callbacks + * async.forEachOf(validConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * } else { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile, function (err) { + * if (err) { + * console.error(err); + * // JSON parse error exception + * } else { + * console.log(configs); + * } + * }); + * + * // Using Promises + * async.forEachOf(validConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * }).catch( err => { + * console.error(err); + * }); + * + * //Error handing + * async.forEachOf(invalidConfigFileMap, parseFile) + * .then( () => { + * console.log(configs); + * }).catch( err => { + * console.error(err); + * // JSON parse error exception + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.forEachOf(validConfigFileMap, parseFile); + * console.log(configs); + * // configs is now a map of JSON data, e.g. + * // { dev: //parsed dev.json, test: //parsed test.json, prod: //parsed prod.json} + * } + * catch (err) { + * console.log(err); + * } + * } + * + * //Error handing + * async () => { + * try { + * let result = await async.forEachOf(invalidConfigFileMap, parseFile); + * console.log(configs); + * } + * catch (err) { + * console.log(err); + * // JSON parse error exception + * } + * } + * + */ +function eachOf(coll, iteratee, callback) { + var eachOfImplementation = (0, _isArrayLike2.default)(coll) ? eachOfArrayLike : eachOfGeneric; + return eachOfImplementation(coll, (0, _wrapAsync2.default)(iteratee), callback); +} + +exports.default = (0, _awaitify2.default)(eachOf, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfLimit.js new file mode 100644 index 0000000..a596e5a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfLimit.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit2 = require('./internal/eachOfLimit.js'); + +var _eachOfLimit3 = _interopRequireDefault(_eachOfLimit2); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a + * time. + * + * @name eachOfLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. The `key` is the item's key, or index in the case of an + * array. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfLimit(coll, limit, iteratee, callback) { + return (0, _eachOfLimit3.default)(limit)(coll, (0, _wrapAsync2.default)(iteratee), callback); +} + +exports.default = (0, _awaitify2.default)(eachOfLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfSeries.js new file mode 100644 index 0000000..04243ad --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachOfSeries.js @@ -0,0 +1,39 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time. + * + * @name eachOfSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.eachOf]{@link module:Collections.eachOf} + * @alias forEachOfSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * Invoked with (item, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachOfSeries(coll, iteratee, callback) { + return (0, _eachOfLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(eachOfSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachSeries.js new file mode 100644 index 0000000..b04896e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forEachSeries.js @@ -0,0 +1,44 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachLimit = require('./eachLimit.js'); + +var _eachLimit2 = _interopRequireDefault(_eachLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time. + * + * Note, that unlike [`each`]{@link module:Collections.each}, this function applies iteratee to each item + * in series and therefore the iteratee functions will complete in order. + + * @name eachSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.each]{@link module:Collections.each} + * @alias forEachSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each + * item in `coll`. + * The array index is not passed to the iteratee. + * If you need the index, use `eachOfSeries`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all + * `iteratee` functions have finished, or an error occurs. Invoked with (err). + * @returns {Promise} a promise, if a callback is omitted + */ +function eachSeries(coll, iteratee, callback) { + return (0, _eachLimit2.default)(coll, 1, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(eachSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forever.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forever.js new file mode 100644 index 0000000..2292518 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/forever.js @@ -0,0 +1,68 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _ensureAsync = require('./ensureAsync.js'); + +var _ensureAsync2 = _interopRequireDefault(_ensureAsync); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Calls the asynchronous function `fn` with a callback parameter that allows it + * to call itself again, in series, indefinitely. + + * If an error is passed to the callback then `errback` is called with the + * error, and execution stops, otherwise it will never be called. + * + * @name forever + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} fn - an async function to call repeatedly. + * Invoked with (next). + * @param {Function} [errback] - when `fn` passes an error to it's callback, + * this function will be called, and execution stops. Invoked with (err). + * @returns {Promise} a promise that rejects if an error occurs and an errback + * is not passed + * @example + * + * async.forever( + * function(next) { + * // next is suitable for passing to things that need a callback(err [, whatever]); + * // it will result in this function being called again. + * }, + * function(err) { + * // if next is called with a value in its first parameter, it will appear + * // in here as 'err', and execution will stop. + * } + * ); + */ +function forever(fn, errback) { + var done = (0, _onlyOnce2.default)(errback); + var task = (0, _wrapAsync2.default)((0, _ensureAsync2.default)(fn)); + + function next(err) { + if (err) return done(err); + if (err === false) return; + task(next); + } + return next(); +} +exports.default = (0, _awaitify2.default)(forever, 2); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBy.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBy.js new file mode 100644 index 0000000..f295763 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBy.js @@ -0,0 +1,108 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = groupBy; + +var _groupByLimit = require('./groupByLimit.js'); + +var _groupByLimit2 = _interopRequireDefault(_groupByLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns a new object, where each value corresponds to an array of items, from + * `coll`, that returned the corresponding key. That is, the keys of the object + * correspond to the values passed to the `iteratee` callback. + * + * Note: Since this function applies the `iteratee` to each item in parallel, + * there is no guarantee that the `iteratee` functions will complete in order. + * However, the values for each key in the `result` will be in the same order as + * the original `coll`. For Objects, the values will roughly be in the order of + * the original Objects' keys (but this can vary across JavaScript engines). + * + * @name groupBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * const files = ['dir1/file1.txt','dir2','dir4'] + * + * // asynchronous function that detects file type as none, file, or directory + * function detectFile(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(null, 'none'); + * } + * callback(null, stat.isDirectory() ? 'directory' : 'file'); + * }); + * } + * + * //Using callbacks + * async.groupBy(files, detectFile, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * }); + * + * // Using Promises + * async.groupBy(files, detectFile) + * .then( result => { + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.groupBy(files, detectFile); + * console.log(result); + * // { + * // file: [ 'dir1/file1.txt' ], + * // none: [ 'dir4' ], + * // directory: [ 'dir2'] + * // } + * // result is object containing the files grouped by type + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function groupBy(coll, iteratee, callback) { + return (0, _groupByLimit2.default)(coll, Infinity, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupByLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupByLimit.js new file mode 100644 index 0000000..30fd290 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupByLimit.js @@ -0,0 +1,71 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _mapLimit = require('./mapLimit.js'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs a maximum of `limit` async operations at a time. + * + * @name groupByLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whoses + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ +function groupByLimit(coll, limit, iteratee, callback) { + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _mapLimit2.default)(coll, limit, (val, iterCb) => { + _iteratee(val, (err, key) => { + if (err) return iterCb(err); + return iterCb(err, { key, val }); + }); + }, (err, mapResults) => { + var result = {}; + // from MDN, handle object having an `hasOwnProperty` prop + var { hasOwnProperty } = Object.prototype; + + for (var i = 0; i < mapResults.length; i++) { + if (mapResults[i]) { + var { key } = mapResults[i]; + var { val } = mapResults[i]; + + if (hasOwnProperty.call(result, key)) { + result[key].push(val); + } else { + result[key] = [val]; + } + } + } + + return callback(err, result); + }); +} + +exports.default = (0, _awaitify2.default)(groupByLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBySeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBySeries.js new file mode 100644 index 0000000..e2a5287 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/groupBySeries.js @@ -0,0 +1,36 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = groupBySeries; + +var _groupByLimit = require('./groupByLimit.js'); + +var _groupByLimit2 = _interopRequireDefault(_groupByLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`groupBy`]{@link module:Collections.groupBy} but runs only a single async operation at a time. + * + * @name groupBySeries + * @static + * @memberOf module:Collections + * @method + * @see [async.groupBy]{@link module:Collections.groupBy} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a `key` to group the value under. + * Invoked with (value, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Result is an `Object` whose + * properties are arrays of values which returned the corresponding key. + * @returns {Promise} a promise, if no callback is passed + */ +function groupBySeries(coll, iteratee, callback) { + return (0, _groupByLimit2.default)(coll, 1, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/index.js new file mode 100644 index 0000000..6154647 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/index.js @@ -0,0 +1,588 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.doDuring = exports.during = exports.wrapSync = undefined; +exports.selectSeries = exports.selectLimit = exports.select = exports.foldr = exports.foldl = exports.inject = exports.forEachOfLimit = exports.forEachOfSeries = exports.forEachOf = exports.forEachLimit = exports.forEachSeries = exports.forEach = exports.flatMapSeries = exports.flatMapLimit = exports.flatMap = exports.findSeries = exports.findLimit = exports.find = exports.anySeries = exports.anyLimit = exports.any = exports.allSeries = exports.allLimit = exports.all = exports.whilst = exports.waterfall = exports.until = exports.unmemoize = exports.tryEach = exports.transform = exports.timesSeries = exports.timesLimit = exports.times = exports.timeout = exports.sortBy = exports.someSeries = exports.someLimit = exports.some = exports.setImmediate = exports.series = exports.seq = exports.retryable = exports.retry = exports.rejectSeries = exports.rejectLimit = exports.reject = exports.reflectAll = exports.reflect = exports.reduceRight = exports.reduce = exports.race = exports.queue = exports.priorityQueue = exports.parallelLimit = exports.parallel = exports.nextTick = exports.memoize = exports.mapValuesSeries = exports.mapValuesLimit = exports.mapValues = exports.mapSeries = exports.mapLimit = exports.map = exports.log = exports.groupBySeries = exports.groupByLimit = exports.groupBy = exports.forever = exports.filterSeries = exports.filterLimit = exports.filter = exports.everySeries = exports.everyLimit = exports.every = exports.ensureAsync = exports.eachSeries = exports.eachOfSeries = exports.eachOfLimit = exports.eachOf = exports.eachLimit = exports.each = exports.doWhilst = exports.doUntil = exports.dir = exports.detectSeries = exports.detectLimit = exports.detect = exports.constant = exports.concatSeries = exports.concatLimit = exports.concat = exports.compose = exports.cargoQueue = exports.cargo = exports.autoInject = exports.auto = exports.asyncify = exports.applyEachSeries = exports.applyEach = exports.apply = undefined; + +var _apply = require('./apply'); + +var _apply2 = _interopRequireDefault(_apply); + +var _applyEach = require('./applyEach'); + +var _applyEach2 = _interopRequireDefault(_applyEach); + +var _applyEachSeries = require('./applyEachSeries'); + +var _applyEachSeries2 = _interopRequireDefault(_applyEachSeries); + +var _asyncify = require('./asyncify'); + +var _asyncify2 = _interopRequireDefault(_asyncify); + +var _auto = require('./auto'); + +var _auto2 = _interopRequireDefault(_auto); + +var _autoInject = require('./autoInject'); + +var _autoInject2 = _interopRequireDefault(_autoInject); + +var _cargo = require('./cargo'); + +var _cargo2 = _interopRequireDefault(_cargo); + +var _cargoQueue = require('./cargoQueue'); + +var _cargoQueue2 = _interopRequireDefault(_cargoQueue); + +var _compose = require('./compose'); + +var _compose2 = _interopRequireDefault(_compose); + +var _concat = require('./concat'); + +var _concat2 = _interopRequireDefault(_concat); + +var _concatLimit = require('./concatLimit'); + +var _concatLimit2 = _interopRequireDefault(_concatLimit); + +var _concatSeries = require('./concatSeries'); + +var _concatSeries2 = _interopRequireDefault(_concatSeries); + +var _constant = require('./constant'); + +var _constant2 = _interopRequireDefault(_constant); + +var _detect = require('./detect'); + +var _detect2 = _interopRequireDefault(_detect); + +var _detectLimit = require('./detectLimit'); + +var _detectLimit2 = _interopRequireDefault(_detectLimit); + +var _detectSeries = require('./detectSeries'); + +var _detectSeries2 = _interopRequireDefault(_detectSeries); + +var _dir = require('./dir'); + +var _dir2 = _interopRequireDefault(_dir); + +var _doUntil = require('./doUntil'); + +var _doUntil2 = _interopRequireDefault(_doUntil); + +var _doWhilst = require('./doWhilst'); + +var _doWhilst2 = _interopRequireDefault(_doWhilst); + +var _each = require('./each'); + +var _each2 = _interopRequireDefault(_each); + +var _eachLimit = require('./eachLimit'); + +var _eachLimit2 = _interopRequireDefault(_eachLimit); + +var _eachOf = require('./eachOf'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _eachOfLimit = require('./eachOfLimit'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _eachOfSeries = require('./eachOfSeries'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _eachSeries = require('./eachSeries'); + +var _eachSeries2 = _interopRequireDefault(_eachSeries); + +var _ensureAsync = require('./ensureAsync'); + +var _ensureAsync2 = _interopRequireDefault(_ensureAsync); + +var _every = require('./every'); + +var _every2 = _interopRequireDefault(_every); + +var _everyLimit = require('./everyLimit'); + +var _everyLimit2 = _interopRequireDefault(_everyLimit); + +var _everySeries = require('./everySeries'); + +var _everySeries2 = _interopRequireDefault(_everySeries); + +var _filter = require('./filter'); + +var _filter2 = _interopRequireDefault(_filter); + +var _filterLimit = require('./filterLimit'); + +var _filterLimit2 = _interopRequireDefault(_filterLimit); + +var _filterSeries = require('./filterSeries'); + +var _filterSeries2 = _interopRequireDefault(_filterSeries); + +var _forever = require('./forever'); + +var _forever2 = _interopRequireDefault(_forever); + +var _groupBy = require('./groupBy'); + +var _groupBy2 = _interopRequireDefault(_groupBy); + +var _groupByLimit = require('./groupByLimit'); + +var _groupByLimit2 = _interopRequireDefault(_groupByLimit); + +var _groupBySeries = require('./groupBySeries'); + +var _groupBySeries2 = _interopRequireDefault(_groupBySeries); + +var _log = require('./log'); + +var _log2 = _interopRequireDefault(_log); + +var _map = require('./map'); + +var _map2 = _interopRequireDefault(_map); + +var _mapLimit = require('./mapLimit'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _mapSeries = require('./mapSeries'); + +var _mapSeries2 = _interopRequireDefault(_mapSeries); + +var _mapValues = require('./mapValues'); + +var _mapValues2 = _interopRequireDefault(_mapValues); + +var _mapValuesLimit = require('./mapValuesLimit'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +var _mapValuesSeries = require('./mapValuesSeries'); + +var _mapValuesSeries2 = _interopRequireDefault(_mapValuesSeries); + +var _memoize = require('./memoize'); + +var _memoize2 = _interopRequireDefault(_memoize); + +var _nextTick = require('./nextTick'); + +var _nextTick2 = _interopRequireDefault(_nextTick); + +var _parallel = require('./parallel'); + +var _parallel2 = _interopRequireDefault(_parallel); + +var _parallelLimit = require('./parallelLimit'); + +var _parallelLimit2 = _interopRequireDefault(_parallelLimit); + +var _priorityQueue = require('./priorityQueue'); + +var _priorityQueue2 = _interopRequireDefault(_priorityQueue); + +var _queue = require('./queue'); + +var _queue2 = _interopRequireDefault(_queue); + +var _race = require('./race'); + +var _race2 = _interopRequireDefault(_race); + +var _reduce = require('./reduce'); + +var _reduce2 = _interopRequireDefault(_reduce); + +var _reduceRight = require('./reduceRight'); + +var _reduceRight2 = _interopRequireDefault(_reduceRight); + +var _reflect = require('./reflect'); + +var _reflect2 = _interopRequireDefault(_reflect); + +var _reflectAll = require('./reflectAll'); + +var _reflectAll2 = _interopRequireDefault(_reflectAll); + +var _reject = require('./reject'); + +var _reject2 = _interopRequireDefault(_reject); + +var _rejectLimit = require('./rejectLimit'); + +var _rejectLimit2 = _interopRequireDefault(_rejectLimit); + +var _rejectSeries = require('./rejectSeries'); + +var _rejectSeries2 = _interopRequireDefault(_rejectSeries); + +var _retry = require('./retry'); + +var _retry2 = _interopRequireDefault(_retry); + +var _retryable = require('./retryable'); + +var _retryable2 = _interopRequireDefault(_retryable); + +var _seq = require('./seq'); + +var _seq2 = _interopRequireDefault(_seq); + +var _series = require('./series'); + +var _series2 = _interopRequireDefault(_series); + +var _setImmediate = require('./setImmediate'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _some = require('./some'); + +var _some2 = _interopRequireDefault(_some); + +var _someLimit = require('./someLimit'); + +var _someLimit2 = _interopRequireDefault(_someLimit); + +var _someSeries = require('./someSeries'); + +var _someSeries2 = _interopRequireDefault(_someSeries); + +var _sortBy = require('./sortBy'); + +var _sortBy2 = _interopRequireDefault(_sortBy); + +var _timeout = require('./timeout'); + +var _timeout2 = _interopRequireDefault(_timeout); + +var _times = require('./times'); + +var _times2 = _interopRequireDefault(_times); + +var _timesLimit = require('./timesLimit'); + +var _timesLimit2 = _interopRequireDefault(_timesLimit); + +var _timesSeries = require('./timesSeries'); + +var _timesSeries2 = _interopRequireDefault(_timesSeries); + +var _transform = require('./transform'); + +var _transform2 = _interopRequireDefault(_transform); + +var _tryEach = require('./tryEach'); + +var _tryEach2 = _interopRequireDefault(_tryEach); + +var _unmemoize = require('./unmemoize'); + +var _unmemoize2 = _interopRequireDefault(_unmemoize); + +var _until = require('./until'); + +var _until2 = _interopRequireDefault(_until); + +var _waterfall = require('./waterfall'); + +var _waterfall2 = _interopRequireDefault(_waterfall); + +var _whilst = require('./whilst'); + +var _whilst2 = _interopRequireDefault(_whilst); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * An "async function" in the context of Async is an asynchronous function with + * a variable number of parameters, with the final parameter being a callback. + * (`function (arg1, arg2, ..., callback) {}`) + * The final callback is of the form `callback(err, results...)`, which must be + * called once the function is completed. The callback should be called with a + * Error as its first argument to signal that an error occurred. + * Otherwise, if no error occurred, it should be called with `null` as the first + * argument, and any additional `result` arguments that may apply, to signal + * successful completion. + * The callback must be called exactly once, ideally on a later tick of the + * JavaScript event loop. + * + * This type of function is also referred to as a "Node-style async function", + * or a "continuation passing-style function" (CPS). Most of the methods of this + * library are themselves CPS/Node-style async functions, or functions that + * return CPS/Node-style async functions. + * + * Wherever we accept a Node-style async function, we also directly accept an + * [ES2017 `async` function]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function}. + * In this case, the `async` function will not be passed a final callback + * argument, and any thrown error will be used as the `err` argument of the + * implicit callback, and the return value will be used as the `result` value. + * (i.e. a `rejected` of the returned Promise becomes the `err` callback + * argument, and a `resolved` value becomes the `result`.) + * + * Note, due to JavaScript limitations, we can only detect native `async` + * functions and not transpilied implementations. + * Your environment must have `async`/`await` support for this to work. + * (e.g. Node > v7.6, or a recent version of a modern browser). + * If you are using `async` functions through a transpiler (e.g. Babel), you + * must still wrap the function with [asyncify]{@link module:Utils.asyncify}, + * because the `async function` will be compiled to an ordinary function that + * returns a promise. + * + * @typedef {Function} AsyncFunction + * @static + */ + +/** + * Async is a utility module which provides straight-forward, powerful functions + * for working with asynchronous JavaScript. Although originally designed for + * use with [Node.js](http://nodejs.org) and installable via + * `npm install --save async`, it can also be used directly in the browser. + * @module async + * @see AsyncFunction + */ + +/** + * A collection of `async` functions for manipulating collections, such as + * arrays and objects. + * @module Collections + */ + +/** + * A collection of `async` functions for controlling the flow through a script. + * @module ControlFlow + */ + +/** + * A collection of `async` utility functions. + * @module Utils + */ + +exports.default = { + apply: _apply2.default, + applyEach: _applyEach2.default, + applyEachSeries: _applyEachSeries2.default, + asyncify: _asyncify2.default, + auto: _auto2.default, + autoInject: _autoInject2.default, + cargo: _cargo2.default, + cargoQueue: _cargoQueue2.default, + compose: _compose2.default, + concat: _concat2.default, + concatLimit: _concatLimit2.default, + concatSeries: _concatSeries2.default, + constant: _constant2.default, + detect: _detect2.default, + detectLimit: _detectLimit2.default, + detectSeries: _detectSeries2.default, + dir: _dir2.default, + doUntil: _doUntil2.default, + doWhilst: _doWhilst2.default, + each: _each2.default, + eachLimit: _eachLimit2.default, + eachOf: _eachOf2.default, + eachOfLimit: _eachOfLimit2.default, + eachOfSeries: _eachOfSeries2.default, + eachSeries: _eachSeries2.default, + ensureAsync: _ensureAsync2.default, + every: _every2.default, + everyLimit: _everyLimit2.default, + everySeries: _everySeries2.default, + filter: _filter2.default, + filterLimit: _filterLimit2.default, + filterSeries: _filterSeries2.default, + forever: _forever2.default, + groupBy: _groupBy2.default, + groupByLimit: _groupByLimit2.default, + groupBySeries: _groupBySeries2.default, + log: _log2.default, + map: _map2.default, + mapLimit: _mapLimit2.default, + mapSeries: _mapSeries2.default, + mapValues: _mapValues2.default, + mapValuesLimit: _mapValuesLimit2.default, + mapValuesSeries: _mapValuesSeries2.default, + memoize: _memoize2.default, + nextTick: _nextTick2.default, + parallel: _parallel2.default, + parallelLimit: _parallelLimit2.default, + priorityQueue: _priorityQueue2.default, + queue: _queue2.default, + race: _race2.default, + reduce: _reduce2.default, + reduceRight: _reduceRight2.default, + reflect: _reflect2.default, + reflectAll: _reflectAll2.default, + reject: _reject2.default, + rejectLimit: _rejectLimit2.default, + rejectSeries: _rejectSeries2.default, + retry: _retry2.default, + retryable: _retryable2.default, + seq: _seq2.default, + series: _series2.default, + setImmediate: _setImmediate2.default, + some: _some2.default, + someLimit: _someLimit2.default, + someSeries: _someSeries2.default, + sortBy: _sortBy2.default, + timeout: _timeout2.default, + times: _times2.default, + timesLimit: _timesLimit2.default, + timesSeries: _timesSeries2.default, + transform: _transform2.default, + tryEach: _tryEach2.default, + unmemoize: _unmemoize2.default, + until: _until2.default, + waterfall: _waterfall2.default, + whilst: _whilst2.default, + + // aliases + all: _every2.default, + allLimit: _everyLimit2.default, + allSeries: _everySeries2.default, + any: _some2.default, + anyLimit: _someLimit2.default, + anySeries: _someSeries2.default, + find: _detect2.default, + findLimit: _detectLimit2.default, + findSeries: _detectSeries2.default, + flatMap: _concat2.default, + flatMapLimit: _concatLimit2.default, + flatMapSeries: _concatSeries2.default, + forEach: _each2.default, + forEachSeries: _eachSeries2.default, + forEachLimit: _eachLimit2.default, + forEachOf: _eachOf2.default, + forEachOfSeries: _eachOfSeries2.default, + forEachOfLimit: _eachOfLimit2.default, + inject: _reduce2.default, + foldl: _reduce2.default, + foldr: _reduceRight2.default, + select: _filter2.default, + selectLimit: _filterLimit2.default, + selectSeries: _filterSeries2.default, + wrapSync: _asyncify2.default, + during: _whilst2.default, + doDuring: _doWhilst2.default +}; +exports.apply = _apply2.default; +exports.applyEach = _applyEach2.default; +exports.applyEachSeries = _applyEachSeries2.default; +exports.asyncify = _asyncify2.default; +exports.auto = _auto2.default; +exports.autoInject = _autoInject2.default; +exports.cargo = _cargo2.default; +exports.cargoQueue = _cargoQueue2.default; +exports.compose = _compose2.default; +exports.concat = _concat2.default; +exports.concatLimit = _concatLimit2.default; +exports.concatSeries = _concatSeries2.default; +exports.constant = _constant2.default; +exports.detect = _detect2.default; +exports.detectLimit = _detectLimit2.default; +exports.detectSeries = _detectSeries2.default; +exports.dir = _dir2.default; +exports.doUntil = _doUntil2.default; +exports.doWhilst = _doWhilst2.default; +exports.each = _each2.default; +exports.eachLimit = _eachLimit2.default; +exports.eachOf = _eachOf2.default; +exports.eachOfLimit = _eachOfLimit2.default; +exports.eachOfSeries = _eachOfSeries2.default; +exports.eachSeries = _eachSeries2.default; +exports.ensureAsync = _ensureAsync2.default; +exports.every = _every2.default; +exports.everyLimit = _everyLimit2.default; +exports.everySeries = _everySeries2.default; +exports.filter = _filter2.default; +exports.filterLimit = _filterLimit2.default; +exports.filterSeries = _filterSeries2.default; +exports.forever = _forever2.default; +exports.groupBy = _groupBy2.default; +exports.groupByLimit = _groupByLimit2.default; +exports.groupBySeries = _groupBySeries2.default; +exports.log = _log2.default; +exports.map = _map2.default; +exports.mapLimit = _mapLimit2.default; +exports.mapSeries = _mapSeries2.default; +exports.mapValues = _mapValues2.default; +exports.mapValuesLimit = _mapValuesLimit2.default; +exports.mapValuesSeries = _mapValuesSeries2.default; +exports.memoize = _memoize2.default; +exports.nextTick = _nextTick2.default; +exports.parallel = _parallel2.default; +exports.parallelLimit = _parallelLimit2.default; +exports.priorityQueue = _priorityQueue2.default; +exports.queue = _queue2.default; +exports.race = _race2.default; +exports.reduce = _reduce2.default; +exports.reduceRight = _reduceRight2.default; +exports.reflect = _reflect2.default; +exports.reflectAll = _reflectAll2.default; +exports.reject = _reject2.default; +exports.rejectLimit = _rejectLimit2.default; +exports.rejectSeries = _rejectSeries2.default; +exports.retry = _retry2.default; +exports.retryable = _retryable2.default; +exports.seq = _seq2.default; +exports.series = _series2.default; +exports.setImmediate = _setImmediate2.default; +exports.some = _some2.default; +exports.someLimit = _someLimit2.default; +exports.someSeries = _someSeries2.default; +exports.sortBy = _sortBy2.default; +exports.timeout = _timeout2.default; +exports.times = _times2.default; +exports.timesLimit = _timesLimit2.default; +exports.timesSeries = _timesSeries2.default; +exports.transform = _transform2.default; +exports.tryEach = _tryEach2.default; +exports.unmemoize = _unmemoize2.default; +exports.until = _until2.default; +exports.waterfall = _waterfall2.default; +exports.whilst = _whilst2.default; +exports.all = _every2.default; +exports.allLimit = _everyLimit2.default; +exports.allSeries = _everySeries2.default; +exports.any = _some2.default; +exports.anyLimit = _someLimit2.default; +exports.anySeries = _someSeries2.default; +exports.find = _detect2.default; +exports.findLimit = _detectLimit2.default; +exports.findSeries = _detectSeries2.default; +exports.flatMap = _concat2.default; +exports.flatMapLimit = _concatLimit2.default; +exports.flatMapSeries = _concatSeries2.default; +exports.forEach = _each2.default; +exports.forEachSeries = _eachSeries2.default; +exports.forEachLimit = _eachLimit2.default; +exports.forEachOf = _eachOf2.default; +exports.forEachOfSeries = _eachOfSeries2.default; +exports.forEachOfLimit = _eachOfLimit2.default; +exports.inject = _reduce2.default; +exports.foldl = _reduce2.default; +exports.foldr = _reduceRight2.default; +exports.select = _filter2.default; +exports.selectLimit = _filterLimit2.default; +exports.selectSeries = _filterSeries2.default; +exports.wrapSync = _asyncify2.default; +exports.during = _whilst2.default; +exports.doDuring = _doWhilst2.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/inject.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/inject.js new file mode 100644 index 0000000..8a69548 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/inject.js @@ -0,0 +1,153 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Reduces `coll` into a single value using an async `iteratee` to return each + * successive step. `memo` is the initial state of the reduction. This function + * only operates in series. + * + * For performance reasons, it may make sense to split a call to this function + * into a parallel map, and then use the normal `Array.prototype.reduce` on the + * results. This function is for situations where each step in the reduction + * needs to be async; if you can get the data before reducing it, then it's + * probably a good idea to do so. + * + * @name reduce + * @static + * @memberOf module:Collections + * @method + * @alias inject + * @alias foldl + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file3.txt', 'file4.txt']; + * + * // asynchronous function that computes the file size in bytes + * // file size is added to the memoized value, then returned + * function getFileSizeInBytes(memo, file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, memo + stat.size); + * }); + * } + * + * // Using callbacks + * async.reduce(fileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.reduce(fileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.reduce(fileList, 0, getFileSizeInBytes); + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.reduce(withMissingFileList, 0, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function reduce(coll, memo, iteratee, callback) { + callback = (0, _once2.default)(callback); + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _eachOfSeries2.default)(coll, (x, i, iterCb) => { + _iteratee(memo, x, (err, v) => { + memo = v; + iterCb(err); + }); + }, err => callback(err, memo)); +} +exports.default = (0, _awaitify2.default)(reduce, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/DoublyLinkedList.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/DoublyLinkedList.js new file mode 100644 index 0000000..419ce44 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/DoublyLinkedList.js @@ -0,0 +1,92 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +// Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation +// used for queues. This implementation assumes that the node provided by the user can be modified +// to adjust the next and last properties. We implement only the minimal functionality +// for queue support. +class DLL { + constructor() { + this.head = this.tail = null; + this.length = 0; + } + + removeLink(node) { + if (node.prev) node.prev.next = node.next;else this.head = node.next; + if (node.next) node.next.prev = node.prev;else this.tail = node.prev; + + node.prev = node.next = null; + this.length -= 1; + return node; + } + + empty() { + while (this.head) this.shift(); + return this; + } + + insertAfter(node, newNode) { + newNode.prev = node; + newNode.next = node.next; + if (node.next) node.next.prev = newNode;else this.tail = newNode; + node.next = newNode; + this.length += 1; + } + + insertBefore(node, newNode) { + newNode.prev = node.prev; + newNode.next = node; + if (node.prev) node.prev.next = newNode;else this.head = newNode; + node.prev = newNode; + this.length += 1; + } + + unshift(node) { + if (this.head) this.insertBefore(this.head, node);else setInitial(this, node); + } + + push(node) { + if (this.tail) this.insertAfter(this.tail, node);else setInitial(this, node); + } + + shift() { + return this.head && this.removeLink(this.head); + } + + pop() { + return this.tail && this.removeLink(this.tail); + } + + toArray() { + return [...this]; + } + + *[Symbol.iterator]() { + var cur = this.head; + while (cur) { + yield cur.data; + cur = cur.next; + } + } + + remove(testFn) { + var curr = this.head; + while (curr) { + var { next } = curr; + if (testFn(curr)) { + this.removeLink(curr); + } + curr = next; + } + return this; + } +} + +exports.default = DLL; +function setInitial(dll, node) { + dll.length = 1; + dll.head = dll.tail = node; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/Heap.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/Heap.js new file mode 100644 index 0000000..7867c92 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/Heap.js @@ -0,0 +1,120 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +// Binary min-heap implementation used for priority queue. +// Implementation is stable, i.e. push time is considered for equal priorities +class Heap { + constructor() { + this.heap = []; + this.pushCount = Number.MIN_SAFE_INTEGER; + } + + get length() { + return this.heap.length; + } + + empty() { + this.heap = []; + return this; + } + + percUp(index) { + let p; + + while (index > 0 && smaller(this.heap[index], this.heap[p = parent(index)])) { + let t = this.heap[index]; + this.heap[index] = this.heap[p]; + this.heap[p] = t; + + index = p; + } + } + + percDown(index) { + let l; + + while ((l = leftChi(index)) < this.heap.length) { + if (l + 1 < this.heap.length && smaller(this.heap[l + 1], this.heap[l])) { + l = l + 1; + } + + if (smaller(this.heap[index], this.heap[l])) { + break; + } + + let t = this.heap[index]; + this.heap[index] = this.heap[l]; + this.heap[l] = t; + + index = l; + } + } + + push(node) { + node.pushCount = ++this.pushCount; + this.heap.push(node); + this.percUp(this.heap.length - 1); + } + + unshift(node) { + return this.heap.push(node); + } + + shift() { + let [top] = this.heap; + + this.heap[0] = this.heap[this.heap.length - 1]; + this.heap.pop(); + this.percDown(0); + + return top; + } + + toArray() { + return [...this]; + } + + *[Symbol.iterator]() { + for (let i = 0; i < this.heap.length; i++) { + yield this.heap[i].data; + } + } + + remove(testFn) { + let j = 0; + for (let i = 0; i < this.heap.length; i++) { + if (!testFn(this.heap[i])) { + this.heap[j] = this.heap[i]; + j++; + } + } + + this.heap.splice(j); + + for (let i = parent(this.heap.length - 1); i >= 0; i--) { + this.percDown(i); + } + + return this; + } +} + +exports.default = Heap; +function leftChi(i) { + return (i << 1) + 1; +} + +function parent(i) { + return (i + 1 >> 1) - 1; +} + +function smaller(x, y) { + if (x.priority !== y.priority) { + return x.priority < y.priority; + } else { + return x.pushCount < y.pushCount; + } +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/applyEach.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/applyEach.js new file mode 100644 index 0000000..5444912 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/applyEach.js @@ -0,0 +1,29 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (eachfn) { + return function applyEach(fns, ...callArgs) { + const go = (0, _awaitify2.default)(function (callback) { + var that = this; + return eachfn(fns, (fn, cb) => { + (0, _wrapAsync2.default)(fn).apply(that, callArgs.concat(cb)); + }, callback); + }); + return go; + }; +}; + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/asyncEachOfLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/asyncEachOfLimit.js new file mode 100644 index 0000000..34dd82b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/asyncEachOfLimit.js @@ -0,0 +1,75 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = asyncEachOfLimit; + +var _breakLoop = require('./breakLoop.js'); + +var _breakLoop2 = _interopRequireDefault(_breakLoop); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +// for async generators +function asyncEachOfLimit(generator, limit, iteratee, callback) { + let done = false; + let canceled = false; + let awaiting = false; + let running = 0; + let idx = 0; + + function replenish() { + //console.log('replenish') + if (running >= limit || awaiting || done) return; + //console.log('replenish awaiting') + awaiting = true; + generator.next().then(({ value, done: iterDone }) => { + //console.log('got value', value) + if (canceled || done) return; + awaiting = false; + if (iterDone) { + done = true; + if (running <= 0) { + //console.log('done nextCb') + callback(null); + } + return; + } + running++; + iteratee(value, idx, iterateeCallback); + idx++; + replenish(); + }).catch(handleError); + } + + function iterateeCallback(err, result) { + //console.log('iterateeCallback') + running -= 1; + if (canceled) return; + if (err) return handleError(err); + + if (err === false) { + done = true; + canceled = true; + return; + } + + if (result === _breakLoop2.default || done && running <= 0) { + done = true; + //console.log('done iterCb') + return callback(null); + } + replenish(); + } + + function handleError(err) { + if (canceled) return; + awaiting = false; + done = true; + callback(err); + } + + replenish(); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/awaitify.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/awaitify.js new file mode 100644 index 0000000..bb7a609 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/awaitify.js @@ -0,0 +1,28 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = awaitify; +// conditionally promisify a function. +// only return a promise if a callback is omitted +function awaitify(asyncFn, arity) { + if (!arity) arity = asyncFn.length; + if (!arity) throw new Error('arity is undefined'); + function awaitable(...args) { + if (typeof args[arity - 1] === 'function') { + return asyncFn.apply(this, args); + } + + return new Promise((resolve, reject) => { + args[arity - 1] = (err, ...cbArgs) => { + if (err) return reject(err); + resolve(cbArgs.length > 1 ? cbArgs : cbArgs[0]); + }; + asyncFn.apply(this, args); + }); + } + + return awaitable; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/breakLoop.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/breakLoop.js new file mode 100644 index 0000000..87413dd --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/breakLoop.js @@ -0,0 +1,10 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +// A temporary value used to identify if the loop should be broken. +// See #1064, #1293 +const breakLoop = {}; +exports.default = breakLoop; +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/consoleFunc.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/consoleFunc.js new file mode 100644 index 0000000..748d54b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/consoleFunc.js @@ -0,0 +1,31 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = consoleFunc; + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function consoleFunc(name) { + return (fn, ...args) => (0, _wrapAsync2.default)(fn)(...args, (err, ...resultArgs) => { + /* istanbul ignore else */ + if (typeof console === 'object') { + /* istanbul ignore else */ + if (err) { + /* istanbul ignore else */ + if (console.error) { + console.error(err); + } + } else if (console[name]) { + /* istanbul ignore else */ + resultArgs.forEach(x => console[name](x)); + } + } + }); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/createTester.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/createTester.js new file mode 100644 index 0000000..cafdf62 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/createTester.js @@ -0,0 +1,40 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _createTester; + +var _breakLoop = require('./breakLoop.js'); + +var _breakLoop2 = _interopRequireDefault(_breakLoop); + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _createTester(check, getResult) { + return (eachfn, arr, _iteratee, cb) => { + var testPassed = false; + var testResult; + const iteratee = (0, _wrapAsync2.default)(_iteratee); + eachfn(arr, (value, _, callback) => { + iteratee(value, (err, result) => { + if (err || err === false) return callback(err); + + if (check(result) && !testResult) { + testPassed = true; + testResult = getResult(true, value); + return callback(null, _breakLoop2.default); + } + callback(); + }); + }, err => { + if (err) return cb(err); + cb(null, testPassed ? testResult : getResult(false)); + }); + }; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/eachOfLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/eachOfLimit.js new file mode 100644 index 0000000..ceed60f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/eachOfLimit.js @@ -0,0 +1,90 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _once = require('./once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _iterator = require('./iterator.js'); + +var _iterator2 = _interopRequireDefault(_iterator); + +var _onlyOnce = require('./onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./wrapAsync.js'); + +var _asyncEachOfLimit = require('./asyncEachOfLimit.js'); + +var _asyncEachOfLimit2 = _interopRequireDefault(_asyncEachOfLimit); + +var _breakLoop = require('./breakLoop.js'); + +var _breakLoop2 = _interopRequireDefault(_breakLoop); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.default = limit => { + return (obj, iteratee, callback) => { + callback = (0, _once2.default)(callback); + if (limit <= 0) { + throw new RangeError('concurrency limit cannot be less than 1'); + } + if (!obj) { + return callback(null); + } + if ((0, _wrapAsync.isAsyncGenerator)(obj)) { + return (0, _asyncEachOfLimit2.default)(obj, limit, iteratee, callback); + } + if ((0, _wrapAsync.isAsyncIterable)(obj)) { + return (0, _asyncEachOfLimit2.default)(obj[Symbol.asyncIterator](), limit, iteratee, callback); + } + var nextElem = (0, _iterator2.default)(obj); + var done = false; + var canceled = false; + var running = 0; + var looping = false; + + function iterateeCallback(err, value) { + if (canceled) return; + running -= 1; + if (err) { + done = true; + callback(err); + } else if (err === false) { + done = true; + canceled = true; + } else if (value === _breakLoop2.default || done && running <= 0) { + done = true; + return callback(null); + } else if (!looping) { + replenish(); + } + } + + function replenish() { + looping = true; + while (running < limit && !done) { + var elem = nextElem(); + if (elem === null) { + done = true; + if (running <= 0) { + callback(null); + } + return; + } + running += 1; + iteratee(elem.value, elem.key, (0, _onlyOnce2.default)(iterateeCallback)); + } + looping = false; + } + + replenish(); + }; +}; + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/filter.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/filter.js new file mode 100644 index 0000000..065c211 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/filter.js @@ -0,0 +1,55 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _filter; + +var _isArrayLike = require('./isArrayLike.js'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function filterArray(eachfn, arr, iteratee, callback) { + var truthValues = new Array(arr.length); + eachfn(arr, (x, index, iterCb) => { + iteratee(x, (err, v) => { + truthValues[index] = !!v; + iterCb(err); + }); + }, err => { + if (err) return callback(err); + var results = []; + for (var i = 0; i < arr.length; i++) { + if (truthValues[i]) results.push(arr[i]); + } + callback(null, results); + }); +} + +function filterGeneric(eachfn, coll, iteratee, callback) { + var results = []; + eachfn(coll, (x, index, iterCb) => { + iteratee(x, (err, v) => { + if (err) return iterCb(err); + if (v) { + results.push({ index, value: x }); + } + iterCb(err); + }); + }, err => { + if (err) return callback(err); + callback(null, results.sort((a, b) => a.index - b.index).map(v => v.value)); + }); +} + +function _filter(eachfn, coll, iteratee, callback) { + var filter = (0, _isArrayLike2.default)(coll) ? filterArray : filterGeneric; + return filter(eachfn, coll, (0, _wrapAsync2.default)(iteratee), callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/getIterator.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/getIterator.js new file mode 100644 index 0000000..f518fce --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/getIterator.js @@ -0,0 +1,11 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (coll) { + return coll[Symbol.iterator] && coll[Symbol.iterator](); +}; + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/initialParams.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/initialParams.js new file mode 100644 index 0000000..04c0eff --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/initialParams.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (fn) { + return function (...args /*, callback*/) { + var callback = args.pop(); + return fn.call(this, args, callback); + }; +}; + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/isArrayLike.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/isArrayLike.js new file mode 100644 index 0000000..a4c4c8a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/isArrayLike.js @@ -0,0 +1,10 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = isArrayLike; +function isArrayLike(value) { + return value && typeof value.length === 'number' && value.length >= 0 && value.length % 1 === 0; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/iterator.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/iterator.js new file mode 100644 index 0000000..5778b1e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/iterator.js @@ -0,0 +1,57 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = createIterator; + +var _isArrayLike = require('./isArrayLike.js'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _getIterator = require('./getIterator.js'); + +var _getIterator2 = _interopRequireDefault(_getIterator); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function createArrayIterator(coll) { + var i = -1; + var len = coll.length; + return function next() { + return ++i < len ? { value: coll[i], key: i } : null; + }; +} + +function createES2015Iterator(iterator) { + var i = -1; + return function next() { + var item = iterator.next(); + if (item.done) return null; + i++; + return { value: item.value, key: i }; + }; +} + +function createObjectIterator(obj) { + var okeys = obj ? Object.keys(obj) : []; + var i = -1; + var len = okeys.length; + return function next() { + var key = okeys[++i]; + if (key === '__proto__') { + return next(); + } + return i < len ? { value: obj[key], key } : null; + }; +} + +function createIterator(coll) { + if ((0, _isArrayLike2.default)(coll)) { + return createArrayIterator(coll); + } + + var iterator = (0, _getIterator2.default)(coll); + return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/map.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/map.js new file mode 100644 index 0000000..acab1e7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/map.js @@ -0,0 +1,30 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _asyncMap; + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _asyncMap(eachfn, arr, iteratee, callback) { + arr = arr || []; + var results = []; + var counter = 0; + var _iteratee = (0, _wrapAsync2.default)(iteratee); + + return eachfn(arr, (value, _, iterCb) => { + var index = counter++; + _iteratee(value, (err, v) => { + results[index] = v; + iterCb(err); + }); + }, err => { + callback(err, results); + }); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/once.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/once.js new file mode 100644 index 0000000..a8b5792 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/once.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = once; +function once(fn) { + function wrapper(...args) { + if (fn === null) return; + var callFn = fn; + fn = null; + callFn.apply(this, args); + } + Object.assign(wrapper, fn); + return wrapper; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/onlyOnce.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/onlyOnce.js new file mode 100644 index 0000000..c95a92d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/onlyOnce.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = onlyOnce; +function onlyOnce(fn) { + return function (...args) { + if (fn === null) throw new Error("Callback was already called."); + var callFn = fn; + fn = null; + callFn.apply(this, args); + }; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/parallel.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/parallel.js new file mode 100644 index 0000000..57fbd0d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/parallel.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _isArrayLike = require('./isArrayLike.js'); + +var _isArrayLike2 = _interopRequireDefault(_isArrayLike); + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +exports.default = (0, _awaitify2.default)((eachfn, tasks, callback) => { + var results = (0, _isArrayLike2.default)(tasks) ? [] : {}; + + eachfn(tasks, (task, key, taskCb) => { + (0, _wrapAsync2.default)(task)((err, ...result) => { + if (result.length < 2) { + [result] = result; + } + results[key] = result; + taskCb(err); + }); + }, err => callback(err, results)); +}, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/promiseCallback.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/promiseCallback.js new file mode 100644 index 0000000..17a8301 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/promiseCallback.js @@ -0,0 +1,23 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +const PROMISE_SYMBOL = Symbol('promiseCallback'); + +function promiseCallback() { + let resolve, reject; + function callback(err, ...args) { + if (err) return reject(err); + resolve(args.length > 1 ? args : args[0]); + } + + callback[PROMISE_SYMBOL] = new Promise((res, rej) => { + resolve = res, reject = rej; + }); + + return callback; +} + +exports.promiseCallback = promiseCallback; +exports.PROMISE_SYMBOL = PROMISE_SYMBOL; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/queue.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/queue.js new file mode 100644 index 0000000..7414e03 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/queue.js @@ -0,0 +1,294 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = queue; + +var _onlyOnce = require('./onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _setImmediate = require('./setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _DoublyLinkedList = require('./DoublyLinkedList.js'); + +var _DoublyLinkedList2 = _interopRequireDefault(_DoublyLinkedList); + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function queue(worker, concurrency, payload) { + if (concurrency == null) { + concurrency = 1; + } else if (concurrency === 0) { + throw new RangeError('Concurrency must not be zero'); + } + + var _worker = (0, _wrapAsync2.default)(worker); + var numRunning = 0; + var workersList = []; + const events = { + error: [], + drain: [], + saturated: [], + unsaturated: [], + empty: [] + }; + + function on(event, handler) { + events[event].push(handler); + } + + function once(event, handler) { + const handleAndRemove = (...args) => { + off(event, handleAndRemove); + handler(...args); + }; + events[event].push(handleAndRemove); + } + + function off(event, handler) { + if (!event) return Object.keys(events).forEach(ev => events[ev] = []); + if (!handler) return events[event] = []; + events[event] = events[event].filter(ev => ev !== handler); + } + + function trigger(event, ...args) { + events[event].forEach(handler => handler(...args)); + } + + var processingScheduled = false; + function _insert(data, insertAtFront, rejectOnError, callback) { + if (callback != null && typeof callback !== 'function') { + throw new Error('task callback must be a function'); + } + q.started = true; + + var res, rej; + function promiseCallback(err, ...args) { + // we don't care about the error, let the global error handler + // deal with it + if (err) return rejectOnError ? rej(err) : res(); + if (args.length <= 1) return res(args[0]); + res(args); + } + + var item = q._createTaskItem(data, rejectOnError ? promiseCallback : callback || promiseCallback); + + if (insertAtFront) { + q._tasks.unshift(item); + } else { + q._tasks.push(item); + } + + if (!processingScheduled) { + processingScheduled = true; + (0, _setImmediate2.default)(() => { + processingScheduled = false; + q.process(); + }); + } + + if (rejectOnError || !callback) { + return new Promise((resolve, reject) => { + res = resolve; + rej = reject; + }); + } + } + + function _createCB(tasks) { + return function (err, ...args) { + numRunning -= 1; + + for (var i = 0, l = tasks.length; i < l; i++) { + var task = tasks[i]; + + var index = workersList.indexOf(task); + if (index === 0) { + workersList.shift(); + } else if (index > 0) { + workersList.splice(index, 1); + } + + task.callback(err, ...args); + + if (err != null) { + trigger('error', err, task.data); + } + } + + if (numRunning <= q.concurrency - q.buffer) { + trigger('unsaturated'); + } + + if (q.idle()) { + trigger('drain'); + } + q.process(); + }; + } + + function _maybeDrain(data) { + if (data.length === 0 && q.idle()) { + // call drain immediately if there are no tasks + (0, _setImmediate2.default)(() => trigger('drain')); + return true; + } + return false; + } + + const eventMethod = name => handler => { + if (!handler) { + return new Promise((resolve, reject) => { + once(name, (err, data) => { + if (err) return reject(err); + resolve(data); + }); + }); + } + off(name); + on(name, handler); + }; + + var isProcessing = false; + var q = { + _tasks: new _DoublyLinkedList2.default(), + _createTaskItem(data, callback) { + return { + data, + callback + }; + }, + *[Symbol.iterator]() { + yield* q._tasks[Symbol.iterator](); + }, + concurrency, + payload, + buffer: concurrency / 4, + started: false, + paused: false, + push(data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return; + return data.map(datum => _insert(datum, false, false, callback)); + } + return _insert(data, false, false, callback); + }, + pushAsync(data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return; + return data.map(datum => _insert(datum, false, true, callback)); + } + return _insert(data, false, true, callback); + }, + kill() { + off(); + q._tasks.empty(); + }, + unshift(data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return; + return data.map(datum => _insert(datum, true, false, callback)); + } + return _insert(data, true, false, callback); + }, + unshiftAsync(data, callback) { + if (Array.isArray(data)) { + if (_maybeDrain(data)) return; + return data.map(datum => _insert(datum, true, true, callback)); + } + return _insert(data, true, true, callback); + }, + remove(testFn) { + q._tasks.remove(testFn); + }, + process() { + // Avoid trying to start too many processing operations. This can occur + // when callbacks resolve synchronously (#1267). + if (isProcessing) { + return; + } + isProcessing = true; + while (!q.paused && numRunning < q.concurrency && q._tasks.length) { + var tasks = [], + data = []; + var l = q._tasks.length; + if (q.payload) l = Math.min(l, q.payload); + for (var i = 0; i < l; i++) { + var node = q._tasks.shift(); + tasks.push(node); + workersList.push(node); + data.push(node.data); + } + + numRunning += 1; + + if (q._tasks.length === 0) { + trigger('empty'); + } + + if (numRunning === q.concurrency) { + trigger('saturated'); + } + + var cb = (0, _onlyOnce2.default)(_createCB(tasks)); + _worker(data, cb); + } + isProcessing = false; + }, + length() { + return q._tasks.length; + }, + running() { + return numRunning; + }, + workersList() { + return workersList; + }, + idle() { + return q._tasks.length + numRunning === 0; + }, + pause() { + q.paused = true; + }, + resume() { + if (q.paused === false) { + return; + } + q.paused = false; + (0, _setImmediate2.default)(q.process); + } + }; + // define these as fixed properties, so people get useful errors when updating + Object.defineProperties(q, { + saturated: { + writable: false, + value: eventMethod('saturated') + }, + unsaturated: { + writable: false, + value: eventMethod('unsaturated') + }, + empty: { + writable: false, + value: eventMethod('empty') + }, + drain: { + writable: false, + value: eventMethod('drain') + }, + error: { + writable: false, + value: eventMethod('error') + } + }); + return q; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/range.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/range.js new file mode 100644 index 0000000..cc7b3a9 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/range.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = range; +function range(size) { + var result = Array(size); + while (size--) { + result[size] = size; + } + return result; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/reject.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/reject.js new file mode 100644 index 0000000..9d9bc80 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/reject.js @@ -0,0 +1,26 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reject; + +var _filter = require('./filter.js'); + +var _filter2 = _interopRequireDefault(_filter); + +var _wrapAsync = require('./wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function reject(eachfn, arr, _iteratee, callback) { + const iteratee = (0, _wrapAsync2.default)(_iteratee); + return (0, _filter2.default)(eachfn, arr, (value, cb) => { + iteratee(value, (err, v) => { + cb(err, !v); + }); + }, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/setImmediate.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/setImmediate.js new file mode 100644 index 0000000..513efd1 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/setImmediate.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fallback = fallback; +exports.wrap = wrap; +/* istanbul ignore file */ + +var hasQueueMicrotask = exports.hasQueueMicrotask = typeof queueMicrotask === 'function' && queueMicrotask; +var hasSetImmediate = exports.hasSetImmediate = typeof setImmediate === 'function' && setImmediate; +var hasNextTick = exports.hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function'; + +function fallback(fn) { + setTimeout(fn, 0); +} + +function wrap(defer) { + return (fn, ...args) => defer(() => fn(...args)); +} + +var _defer; + +if (hasQueueMicrotask) { + _defer = queueMicrotask; +} else if (hasSetImmediate) { + _defer = setImmediate; +} else if (hasNextTick) { + _defer = process.nextTick; +} else { + _defer = fallback; +} + +exports.default = wrap(_defer); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/withoutIndex.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/withoutIndex.js new file mode 100644 index 0000000..fa91c2d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/withoutIndex.js @@ -0,0 +1,10 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _withoutIndex; +function _withoutIndex(iteratee) { + return (value, index, callback) => iteratee(value, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/wrapAsync.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/wrapAsync.js new file mode 100644 index 0000000..ad4d619 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/internal/wrapAsync.js @@ -0,0 +1,34 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isAsyncIterable = exports.isAsyncGenerator = exports.isAsync = undefined; + +var _asyncify = require('../asyncify.js'); + +var _asyncify2 = _interopRequireDefault(_asyncify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function isAsync(fn) { + return fn[Symbol.toStringTag] === 'AsyncFunction'; +} + +function isAsyncGenerator(fn) { + return fn[Symbol.toStringTag] === 'AsyncGenerator'; +} + +function isAsyncIterable(obj) { + return typeof obj[Symbol.asyncIterator] === 'function'; +} + +function wrapAsync(asyncFn) { + if (typeof asyncFn !== 'function') throw new Error('expected a function'); + return isAsync(asyncFn) ? (0, _asyncify2.default)(asyncFn) : asyncFn; +} + +exports.default = wrapAsync; +exports.isAsync = isAsync; +exports.isAsyncGenerator = isAsyncGenerator; +exports.isAsyncIterable = isAsyncIterable; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/log.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/log.js new file mode 100644 index 0000000..332b9da --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/log.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _consoleFunc = require('./internal/consoleFunc.js'); + +var _consoleFunc2 = _interopRequireDefault(_consoleFunc); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Logs the result of an `async` function to the `console`. Only works in + * Node.js or in browsers that support `console.log` and `console.error` (such + * as FF and Chrome). If multiple arguments are returned from the async + * function, `console.log` is called on each argument in order. + * + * @name log + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} function - The function you want to eventually apply + * all arguments to. + * @param {...*} arguments... - Any number of arguments to apply to the function. + * @example + * + * // in a module + * var hello = function(name, callback) { + * setTimeout(function() { + * callback(null, 'hello ' + name); + * }, 1000); + * }; + * + * // in the node repl + * node> async.log(hello, 'world'); + * 'hello world' + */ +exports.default = (0, _consoleFunc2.default)('log'); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/map.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/map.js new file mode 100644 index 0000000..c4b7a5a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/map.js @@ -0,0 +1,142 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _map2 = require('./internal/map.js'); + +var _map3 = _interopRequireDefault(_map2); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Produces a new collection of values by mapping each value in `coll` through + * the `iteratee` function. The `iteratee` is called with an item from `coll` + * and a callback for when it has finished processing. Each of these callbacks + * takes 2 arguments: an `error`, and the transformed item from `coll`. If + * `iteratee` passes an error to its callback, the main `callback` (for the + * `map` function) is immediately called with the error. + * + * Note, that since this function applies the `iteratee` to each item in + * parallel, there is no guarantee that the `iteratee` functions will complete + * in order. However, the results array will be in the same order as the + * original `coll`. + * + * If `map` is passed an Object, the results will be an Array. The results + * will roughly be in the order of the original Objects' keys (but this can + * vary across JavaScript engines). + * + * @name map + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an Array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file4.txt']; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.map(fileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes, function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * }); + * + * // Using Promises + * async.map(fileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.map(withMissingFileList, getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.map(fileList, getFileSizeInBytes); + * console.log(results); + * // results is now an array of the file size in bytes for each file, e.g. + * // [ 1000, 2000, 3000] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let results = await async.map(withMissingFileList, getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function map(coll, iteratee, callback) { + return (0, _map3.default)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(map, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapLimit.js new file mode 100644 index 0000000..6ad3572 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapLimit.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _map2 = require('./internal/map.js'); + +var _map3 = _interopRequireDefault(_map2); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time. + * + * @name mapLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function mapLimit(coll, limit, iteratee, callback) { + return (0, _map3.default)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(mapLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapSeries.js new file mode 100644 index 0000000..8dfdd8a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapSeries.js @@ -0,0 +1,44 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _map2 = require('./internal/map.js'); + +var _map3 = _interopRequireDefault(_map2); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time. + * + * @name mapSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.map]{@link module:Collections.map} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with the transformed item. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. Results is an array of the + * transformed items from the `coll`. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function mapSeries(coll, iteratee, callback) { + return (0, _map3.default)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(mapSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValues.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValues.js new file mode 100644 index 0000000..3d0470e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValues.js @@ -0,0 +1,152 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = mapValues; + +var _mapValuesLimit = require('./mapValuesLimit.js'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A relative of [`map`]{@link module:Collections.map}, designed for use with objects. + * + * Produces a new Object by mapping each value of `obj` through the `iteratee` + * function. The `iteratee` is called each `value` and `key` from `obj` and a + * callback for when it has finished processing. Each of these callbacks takes + * two arguments: an `error`, and the transformed item from `obj`. If `iteratee` + * passes an error to its callback, the main `callback` (for the `mapValues` + * function) is immediately called with the error. + * + * Note, the order of the keys in the result is not guaranteed. The keys will + * be roughly in the order they complete, (but this is very engine-specific) + * + * @name mapValues + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file3.txt' + * }; + * + * const withMissingFileMap = { + * f1: 'file1.txt', + * f2: 'file2.txt', + * f3: 'file4.txt' + * }; + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, key, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.mapValues(fileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * }); + * + * // Error handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.mapValues(fileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * }).catch (err => { + * console.log(err); + * }); + * + * // Error Handling + * async.mapValues(withMissingFileMap, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch (err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.mapValues(fileMap, getFileSizeInBytes); + * console.log(result); + * // result is now a map of file size in bytes for each file, e.g. + * // { + * // f1: 1000, + * // f2: 2000, + * // f3: 3000 + * // } + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.mapValues(withMissingFileMap, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function mapValues(obj, iteratee, callback) { + return (0, _mapValuesLimit2.default)(obj, Infinity, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesLimit.js new file mode 100644 index 0000000..f59e36f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesLimit.js @@ -0,0 +1,61 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs a maximum of `limit` async operations at a + * time. + * + * @name mapValuesLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function mapValuesLimit(obj, limit, iteratee, callback) { + callback = (0, _once2.default)(callback); + var newObj = {}; + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _eachOfLimit2.default)(limit)(obj, (val, key, next) => { + _iteratee(val, key, (err, result) => { + if (err) return next(err); + newObj[key] = result; + next(err); + }); + }, err => callback(err, newObj)); +} + +exports.default = (0, _awaitify2.default)(mapValuesLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesSeries.js new file mode 100644 index 0000000..5f05bf2 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/mapValuesSeries.js @@ -0,0 +1,37 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = mapValuesSeries; + +var _mapValuesLimit = require('./mapValuesLimit.js'); + +var _mapValuesLimit2 = _interopRequireDefault(_mapValuesLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time. + * + * @name mapValuesSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.mapValues]{@link module:Collections.mapValues} + * @category Collection + * @param {Object} obj - A collection to iterate over. + * @param {AsyncFunction} iteratee - A function to apply to each value and key + * in `coll`. + * The iteratee should complete with the transformed value as its result. + * Invoked with (value, key, callback). + * @param {Function} [callback] - A callback which is called when all `iteratee` + * functions have finished, or an error occurs. `result` is a new object consisting + * of each key from `obj`, with each transformed value on the right-hand side. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function mapValuesSeries(obj, iteratee, callback) { + return (0, _mapValuesLimit2.default)(obj, 1, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/memoize.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/memoize.js new file mode 100644 index 0000000..6535d4e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/memoize.js @@ -0,0 +1,91 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = memoize; + +var _setImmediate = require('./internal/setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Caches the results of an async function. When creating a hash to store + * function results against, the callback is omitted from the hash and an + * optional hash function can be used. + * + * **Note: if the async function errs, the result will not be cached and + * subsequent calls will call the wrapped function.** + * + * If no hash function is specified, the first argument is used as a hash key, + * which may work reasonably if it is a string or a data type that converts to a + * distinct string. Note that objects and arrays will not behave reasonably. + * Neither will cases where the other arguments are significant. In such cases, + * specify your own hash function. + * + * The cache of results is exposed as the `memo` property of the function + * returned by `memoize`. + * + * @name memoize + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function to proxy and cache results from. + * @param {Function} hasher - An optional function for generating a custom hash + * for storing results. It has all the arguments applied to it apart from the + * callback, and must be synchronous. + * @returns {AsyncFunction} a memoized version of `fn` + * @example + * + * var slow_fn = function(name, callback) { + * // do something + * callback(null, result); + * }; + * var fn = async.memoize(slow_fn); + * + * // fn can now be used as if it were slow_fn + * fn('some name', function() { + * // callback + * }); + */ +function memoize(fn, hasher = v => v) { + var memo = Object.create(null); + var queues = Object.create(null); + var _fn = (0, _wrapAsync2.default)(fn); + var memoized = (0, _initialParams2.default)((args, callback) => { + var key = hasher(...args); + if (key in memo) { + (0, _setImmediate2.default)(() => callback(null, ...memo[key])); + } else if (key in queues) { + queues[key].push(callback); + } else { + queues[key] = [callback]; + _fn(...args, (err, ...resultArgs) => { + // #1465 don't memoize if an error occurred + if (!err) { + memo[key] = resultArgs; + } + var q = queues[key]; + delete queues[key]; + for (var i = 0, l = q.length; i < l; i++) { + q[i](err, ...resultArgs); + } + }); + } + }); + memoized.memo = memo; + memoized.unmemoized = fn; + return memoized; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/nextTick.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/nextTick.js new file mode 100644 index 0000000..8ebfda9 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/nextTick.js @@ -0,0 +1,52 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _setImmediate = require('./internal/setImmediate.js'); + +/** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `process.nextTick`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name nextTick + * @static + * @memberOf module:Utils + * @method + * @see [async.setImmediate]{@link module:Utils.setImmediate} + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ +var _defer; /* istanbul ignore file */ + + +if (_setImmediate.hasNextTick) { + _defer = process.nextTick; +} else if (_setImmediate.hasSetImmediate) { + _defer = setImmediate; +} else { + _defer = _setImmediate.fallback; +} + +exports.default = (0, _setImmediate.wrap)(_defer); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/package.json new file mode 100644 index 0000000..bcf4c41 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/package.json @@ -0,0 +1,75 @@ +{ + "name": "async", + "description": "Higher-order functions and common patterns for asynchronous code", + "version": "3.2.6", + "main": "dist/async.js", + "author": "Caolan McMahon", + "homepage": "https://caolan.github.io/async/", + "repository": { + "type": "git", + "url": "https://github.com/caolan/async.git" + }, + "bugs": { + "url": "https://github.com/caolan/async/issues" + }, + "keywords": [ + "async", + "callback", + "module", + "utility" + ], + "devDependencies": { + "@babel/eslint-parser": "^7.16.5", + "@babel/core": "7.25.2", + "babel-minify": "^0.5.0", + "babel-plugin-add-module-exports": "^1.0.4", + "babel-plugin-istanbul": "^7.0.0", + "babel-plugin-syntax-async-generators": "^6.13.0", + "babel-plugin-transform-es2015-modules-commonjs": "^6.26.2", + "babel-preset-es2015": "^6.3.13", + "babel-preset-es2017": "^6.22.0", + "babel-register": "^6.26.0", + "babelify": "^10.0.0", + "benchmark": "^2.1.1", + "bluebird": "^3.4.6", + "browserify": "^17.0.0", + "chai": "^4.2.0", + "cheerio": "^0.22.0", + "es6-promise": "^4.2.8", + "eslint": "^8.6.0", + "eslint-plugin-prefer-arrow": "^1.2.3", + "fs-extra": "^11.1.1", + "jsdoc": "^4.0.3", + "karma": "^6.3.12", + "karma-browserify": "^8.1.0", + "karma-firefox-launcher": "^2.1.2", + "karma-mocha": "^2.0.1", + "karma-mocha-reporter": "^2.2.0", + "karma-safari-launcher": "^1.0.0", + "mocha": "^6.1.4", + "native-promise-only": "^0.8.0-a", + "nyc": "^17.0.0", + "rollup": "^4.2.0", + "rollup-plugin-node-resolve": "^5.2.0", + "rollup-plugin-npm": "^2.0.0", + "rsvp": "^4.8.5", + "semver": "^7.3.5", + "yargs": "^17.3.1" + }, + "scripts": { + "coverage": "nyc npm run mocha-node-test -- --grep @nycinvalid --invert", + "jsdoc": "jsdoc -c ./support/jsdoc/jsdoc.json && node support/jsdoc/jsdoc-fix-html.js", + "lint": "eslint --fix .", + "mocha-browser-test": "karma start", + "mocha-node-test": "mocha", + "mocha-test": "npm run mocha-node-test && npm run mocha-browser-test", + "test": "npm run lint && npm run mocha-node-test" + }, + "license": "MIT", + "nyc": { + "exclude": [ + "test" + ] + }, + "module": "dist/async.mjs" +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallel.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallel.js new file mode 100644 index 0000000..2c7976f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallel.js @@ -0,0 +1,180 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = parallel; + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _parallel2 = require('./internal/parallel.js'); + +var _parallel3 = _interopRequireDefault(_parallel2); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Run the `tasks` collection of functions in parallel, without waiting until + * the previous function has completed. If any of the functions pass an error to + * its callback, the main `callback` is immediately called with the value of the + * error. Once the `tasks` have completed, the results are passed to the final + * `callback` as an array. + * + * **Note:** `parallel` is about kicking-off I/O tasks in parallel, not about + * parallel execution of code. If your tasks do not use any timers or perform + * any I/O, they will actually be executed in series. Any synchronous setup + * sections for each task will happen one after the other. JavaScript remains + * single-threaded. + * + * **Hint:** Use [`reflect`]{@link module:Utils.reflect} to continue the + * execution of other tasks when a task fails. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.parallel}. + * + * @name parallel + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * + * //Using Callbacks + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.parallel([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] even though + * // the second function had a shorter timeout. + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function parallel(tasks, callback) { + return (0, _parallel3.default)(_eachOf2.default, tasks, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallelLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallelLimit.js new file mode 100644 index 0000000..4337957 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/parallelLimit.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = parallelLimit; + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _parallel = require('./internal/parallel.js'); + +var _parallel2 = _interopRequireDefault(_parallel); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`parallel`]{@link module:ControlFlow.parallel} but runs a maximum of `limit` async operations at a + * time. + * + * @name parallelLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.parallel]{@link module:ControlFlow.parallel} + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection of + * [async functions]{@link AsyncFunction} to run. + * Each async function can complete with any number of optional `result` values. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed successfully. This function gets a results array + * (or object) containing all the result arguments passed to the task callbacks. + * Invoked with (err, results). + * @returns {Promise} a promise, if a callback is not passed + */ +function parallelLimit(tasks, limit, callback) { + return (0, _parallel2.default)((0, _eachOfLimit2.default)(limit), tasks, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/priorityQueue.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/priorityQueue.js new file mode 100644 index 0000000..16c4daa --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/priorityQueue.js @@ -0,0 +1,60 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (worker, concurrency) { + // Start with a normal queue + var q = (0, _queue2.default)(worker, concurrency); + + var { + push, + pushAsync + } = q; + + q._tasks = new _Heap2.default(); + q._createTaskItem = ({ data, priority }, callback) => { + return { + data, + priority, + callback + }; + }; + + function createDataItems(tasks, priority) { + if (!Array.isArray(tasks)) { + return { data: tasks, priority }; + } + return tasks.map(data => { + return { data, priority }; + }); + } + + // Override push to accept second parameter representing priority + q.push = function (data, priority = 0, callback) { + return push(createDataItems(data, priority), callback); + }; + + q.pushAsync = function (data, priority = 0, callback) { + return pushAsync(createDataItems(data, priority), callback); + }; + + // Remove unshift functions + delete q.unshift; + delete q.unshiftAsync; + + return q; +}; + +var _queue = require('./queue.js'); + +var _queue2 = _interopRequireDefault(_queue); + +var _Heap = require('./internal/Heap.js'); + +var _Heap2 = _interopRequireDefault(_Heap); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/queue.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/queue.js new file mode 100644 index 0000000..c01340d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/queue.js @@ -0,0 +1,24 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function (worker, concurrency) { + var _worker = (0, _wrapAsync2.default)(worker); + return (0, _queue2.default)((items, cb) => { + _worker(items[0], cb); + }, concurrency, 1); +}; + +var _queue = require('./internal/queue.js'); + +var _queue2 = _interopRequireDefault(_queue); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/race.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/race.js new file mode 100644 index 0000000..aa167be --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/race.js @@ -0,0 +1,67 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Runs the `tasks` array of functions in parallel, without waiting until the + * previous function has completed. Once any of the `tasks` complete or pass an + * error to its callback, the main `callback` is immediately called. It's + * equivalent to `Promise.race()`. + * + * @name race + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array containing [async functions]{@link AsyncFunction} + * to run. Each function can complete with an optional `result` value. + * @param {Function} callback - A callback to run once any of the functions have + * completed. This function gets an error or result from the first function that + * completed. Invoked with (err, result). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.race([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ], + * // main callback + * function(err, result) { + * // the result will be equal to 'two' as it finishes earlier + * }); + */ +function race(tasks, callback) { + callback = (0, _once2.default)(callback); + if (!Array.isArray(tasks)) return callback(new TypeError('First argument to race must be an array of functions')); + if (!tasks.length) return callback(); + for (var i = 0, l = tasks.length; i < l; i++) { + (0, _wrapAsync2.default)(tasks[i])(callback); + } +} + +exports.default = (0, _awaitify2.default)(race, 2); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduce.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduce.js new file mode 100644 index 0000000..8a69548 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduce.js @@ -0,0 +1,153 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Reduces `coll` into a single value using an async `iteratee` to return each + * successive step. `memo` is the initial state of the reduction. This function + * only operates in series. + * + * For performance reasons, it may make sense to split a call to this function + * into a parallel map, and then use the normal `Array.prototype.reduce` on the + * results. This function is for situations where each step in the reduction + * needs to be async; if you can get the data before reducing it, then it's + * probably a good idea to do so. + * + * @name reduce + * @static + * @memberOf module:Collections + * @method + * @alias inject + * @alias foldl + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * // file4.txt does not exist + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * const withMissingFileList = ['file1.txt','file2.txt','file3.txt', 'file4.txt']; + * + * // asynchronous function that computes the file size in bytes + * // file size is added to the memoized value, then returned + * function getFileSizeInBytes(memo, file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, memo + stat.size); + * }); + * } + * + * // Using callbacks + * async.reduce(fileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * } else { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes, function(err, result) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(result); + * } + * }); + * + * // Using Promises + * async.reduce(fileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * }).catch( err => { + * console.log(err); + * }); + * + * // Error Handling + * async.reduce(withMissingFileList, 0, getFileSizeInBytes) + * .then( result => { + * console.log(result); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.reduce(fileList, 0, getFileSizeInBytes); + * console.log(result); + * // 6000 + * // which is the sum of the file sizes of the three files + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // Error Handling + * async () => { + * try { + * let result = await async.reduce(withMissingFileList, 0, getFileSizeInBytes); + * console.log(result); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function reduce(coll, memo, iteratee, callback) { + callback = (0, _once2.default)(callback); + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _eachOfSeries2.default)(coll, (x, i, iterCb) => { + _iteratee(memo, x, (err, v) => { + memo = v; + iterCb(err); + }); + }, err => callback(err, memo)); +} +exports.default = (0, _awaitify2.default)(reduce, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduceRight.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduceRight.js new file mode 100644 index 0000000..5be1b68 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reduceRight.js @@ -0,0 +1,41 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reduceRight; + +var _reduce = require('./reduce.js'); + +var _reduce2 = _interopRequireDefault(_reduce); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Same as [`reduce`]{@link module:Collections.reduce}, only operates on `array` in reverse order. + * + * @name reduceRight + * @static + * @memberOf module:Collections + * @method + * @see [async.reduce]{@link module:Collections.reduce} + * @alias foldr + * @category Collection + * @param {Array} array - A collection to iterate over. + * @param {*} memo - The initial state of the reduction. + * @param {AsyncFunction} iteratee - A function applied to each item in the + * array to produce the next step in the reduction. + * The `iteratee` should complete with the next state of the reduction. + * If the iteratee completes with an error, the reduction is stopped and the + * main `callback` is immediately called with the error. + * Invoked with (memo, item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the reduced value. Invoked with + * (err, result). + * @returns {Promise} a promise, if no callback is passed + */ +function reduceRight(array, memo, iteratee, callback) { + var reversed = [...array].reverse(); + return (0, _reduce2.default)(reversed, memo, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflect.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflect.js new file mode 100644 index 0000000..3954495 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflect.js @@ -0,0 +1,78 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reflect; + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Wraps the async function in another function that always completes with a + * result object, even when it errors. + * + * The result object has either the property `error` or `value`. + * + * @name reflect + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} fn - The async function you want to wrap + * @returns {Function} - A function that always passes null to it's callback as + * the error. The second argument to the callback will be an `object` with + * either an `error` or a `value` property. + * @example + * + * async.parallel([ + * async.reflect(function(callback) { + * // do some stuff ... + * callback(null, 'one'); + * }), + * async.reflect(function(callback) { + * // do some more stuff but error ... + * callback('bad stuff happened'); + * }), + * async.reflect(function(callback) { + * // do some more stuff ... + * callback(null, 'two'); + * }) + * ], + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = 'bad stuff happened' + * // results[2].value = 'two' + * }); + */ +function reflect(fn) { + var _fn = (0, _wrapAsync2.default)(fn); + return (0, _initialParams2.default)(function reflectOn(args, reflectCallback) { + args.push((error, ...cbArgs) => { + let retVal = {}; + if (error) { + retVal.error = error; + } + if (cbArgs.length > 0) { + var value = cbArgs; + if (cbArgs.length <= 1) { + [value] = cbArgs; + } + retVal.value = value; + } + reflectCallback(null, retVal); + }); + + return _fn.apply(this, args); + }); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflectAll.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflectAll.js new file mode 100644 index 0000000..b78d598 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reflectAll.js @@ -0,0 +1,93 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = reflectAll; + +var _reflect = require('./reflect.js'); + +var _reflect2 = _interopRequireDefault(_reflect); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A helper function that wraps an array or an object of functions with `reflect`. + * + * @name reflectAll + * @static + * @memberOf module:Utils + * @method + * @see [async.reflect]{@link module:Utils.reflect} + * @category Util + * @param {Array|Object|Iterable} tasks - The collection of + * [async functions]{@link AsyncFunction} to wrap in `async.reflect`. + * @returns {Array} Returns an array of async functions, each wrapped in + * `async.reflect` + * @example + * + * let tasks = [ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * // do some more stuff but error ... + * callback(new Error('bad stuff happened')); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results[0].value = 'one' + * // results[1].error = Error('bad stuff happened') + * // results[2].value = 'two' + * }); + * + * // an example using an object instead of an array + * let tasks = { + * one: function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * two: function(callback) { + * callback('two'); + * }, + * three: function(callback) { + * setTimeout(function() { + * callback(null, 'three'); + * }, 100); + * } + * }; + * + * async.parallel(async.reflectAll(tasks), + * // optional callback + * function(err, results) { + * // values + * // results.one.value = 'one' + * // results.two.error = 'two' + * // results.three.value = 'three' + * }); + */ +function reflectAll(tasks) { + var results; + if (Array.isArray(tasks)) { + results = tasks.map(_reflect2.default); + } else { + results = {}; + Object.keys(tasks).forEach(key => { + results[key] = _reflect2.default.call(this, tasks[key]); + }); + } + return results; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reject.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reject.js new file mode 100644 index 0000000..895949b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/reject.js @@ -0,0 +1,87 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _reject2 = require('./internal/reject.js'); + +var _reject3 = _interopRequireDefault(_reject2); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The opposite of [`filter`]{@link module:Collections.filter}. Removes values that pass an `async` truth test. + * + * @name reject + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const fileList = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.reject(fileList, fileExists, function(err, results) { + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }); + * + * // Using Promises + * async.reject(fileList, fileExists) + * .then( results => { + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.reject(fileList, fileExists); + * console.log(results); + * // [ 'dir3/file6.txt' ] + * // results now equals an array of the non-existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function reject(coll, iteratee, callback) { + return (0, _reject3.default)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(reject, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectLimit.js new file mode 100644 index 0000000..ce10edf --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectLimit.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _reject2 = require('./internal/reject.js'); + +var _reject3 = _interopRequireDefault(_reject2); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`reject`]{@link module:Collections.reject} but runs a maximum of `limit` async operations at a + * time. + * + * @name rejectLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function rejectLimit(coll, limit, iteratee, callback) { + return (0, _reject3.default)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(rejectLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectSeries.js new file mode 100644 index 0000000..c08e413 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/rejectSeries.js @@ -0,0 +1,43 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _reject2 = require('./internal/reject.js'); + +var _reject3 = _interopRequireDefault(_reject2); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`reject`]{@link module:Collections.reject} but runs only a single async operation at a time. + * + * @name rejectSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.reject]{@link module:Collections.reject} + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - An async truth test to apply to each item in + * `coll`. + * The should complete with a boolean value as its `result`. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback is passed + */ +function rejectSeries(coll, iteratee, callback) { + return (0, _reject3.default)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(rejectSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retry.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retry.js new file mode 100644 index 0000000..a4b0235 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retry.js @@ -0,0 +1,159 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = retry; + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _promiseCallback = require('./internal/promiseCallback.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function constant(value) { + return function () { + return value; + }; +} + +/** + * Attempts to get a successful response from `task` no more than `times` times + * before returning an error. If the task is successful, the `callback` will be + * passed the result of the successful task. If all attempts fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name retry + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @see [async.retryable]{@link module:ControlFlow.retryable} + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - Can be either an + * object with `times` and `interval` or a number. + * * `times` - The number of attempts to make before giving up. The default + * is `5`. + * * `interval` - The time to wait between retries, in milliseconds. The + * default is `0`. The interval may also be specified as a function of the + * retry count (see example). + * * `errorFilter` - An optional synchronous function that is invoked on + * erroneous result. If it returns `true` the retry attempts will continue; + * if the function returns `false` the retry flow is aborted with the current + * attempt's error and result being returned to the final callback. + * Invoked with (err). + * * If `opts` is a number, the number specifies the number of times to retry, + * with the default interval of `0`. + * @param {AsyncFunction} task - An async function to retry. + * Invoked with (callback). + * @param {Function} [callback] - An optional callback which is called when the + * task has succeeded, or after the final failed attempt. It receives the `err` + * and `result` arguments of the last attempt at completing the `task`. Invoked + * with (err, results). + * @returns {Promise} a promise if no callback provided + * + * @example + * + * // The `retry` function can be used as a stand-alone control flow by passing + * // a callback, as shown below: + * + * // try calling apiMethod 3 times + * async.retry(3, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 3 times, waiting 200 ms between each retry + * async.retry({times: 3, interval: 200}, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod 10 times with exponential backoff + * // (i.e. intervals of 100, 200, 400, 800, 1600, ... milliseconds) + * async.retry({ + * times: 10, + * interval: function(retryCount) { + * return 50 * Math.pow(2, retryCount); + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod the default 5 times no delay between each retry + * async.retry(apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // try calling apiMethod only when error condition satisfies, all other + * // errors will abort the retry control flow and return to final callback + * async.retry({ + * errorFilter: function(err) { + * return err.message === 'Temporary error'; // only retry on a specific error + * } + * }, apiMethod, function(err, result) { + * // do something with the result + * }); + * + * // to retry individual methods that are not as reliable within other + * // control flow functions, use the `retryable` wrapper: + * async.auto({ + * users: api.getUsers.bind(api), + * payments: async.retryable(3, api.getPayments.bind(api)) + * }, function(err, results) { + * // do something with the results + * }); + * + */ +const DEFAULT_TIMES = 5; +const DEFAULT_INTERVAL = 0; + +function retry(opts, task, callback) { + var options = { + times: DEFAULT_TIMES, + intervalFunc: constant(DEFAULT_INTERVAL) + }; + + if (arguments.length < 3 && typeof opts === 'function') { + callback = task || (0, _promiseCallback.promiseCallback)(); + task = opts; + } else { + parseTimes(options, opts); + callback = callback || (0, _promiseCallback.promiseCallback)(); + } + + if (typeof task !== 'function') { + throw new Error("Invalid arguments for async.retry"); + } + + var _task = (0, _wrapAsync2.default)(task); + + var attempt = 1; + function retryAttempt() { + _task((err, ...args) => { + if (err === false) return; + if (err && attempt++ < options.times && (typeof options.errorFilter != 'function' || options.errorFilter(err))) { + setTimeout(retryAttempt, options.intervalFunc(attempt - 1)); + } else { + callback(err, ...args); + } + }); + } + + retryAttempt(); + return callback[_promiseCallback.PROMISE_SYMBOL]; +} + +function parseTimes(acc, t) { + if (typeof t === 'object') { + acc.times = +t.times || DEFAULT_TIMES; + + acc.intervalFunc = typeof t.interval === 'function' ? t.interval : constant(+t.interval || DEFAULT_INTERVAL); + + acc.errorFilter = t.errorFilter; + } else if (typeof t === 'number' || typeof t === 'string') { + acc.times = +t || DEFAULT_TIMES; + } else { + throw new Error("Invalid arguments for async.retry"); + } +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retryable.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retryable.js new file mode 100644 index 0000000..68256c3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/retryable.js @@ -0,0 +1,77 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = retryable; + +var _retry = require('./retry.js'); + +var _retry2 = _interopRequireDefault(_retry); + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _promiseCallback = require('./internal/promiseCallback.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A close relative of [`retry`]{@link module:ControlFlow.retry}. This method + * wraps a task and makes it retryable, rather than immediately calling it + * with retries. + * + * @name retryable + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.retry]{@link module:ControlFlow.retry} + * @category Control Flow + * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - optional + * options, exactly the same as from `retry`, except for a `opts.arity` that + * is the arity of the `task` function, defaulting to `task.length` + * @param {AsyncFunction} task - the asynchronous function to wrap. + * This function will be passed any arguments passed to the returned wrapper. + * Invoked with (...args, callback). + * @returns {AsyncFunction} The wrapped function, which when invoked, will + * retry on an error, based on the parameters specified in `opts`. + * This function will accept the same parameters as `task`. + * @example + * + * async.auto({ + * dep1: async.retryable(3, getFromFlakyService), + * process: ["dep1", async.retryable(3, function (results, cb) { + * maybeProcessData(results.dep1, cb); + * })] + * }, callback); + */ +function retryable(opts, task) { + if (!task) { + task = opts; + opts = null; + } + let arity = opts && opts.arity || task.length; + if ((0, _wrapAsync.isAsync)(task)) { + arity += 1; + } + var _task = (0, _wrapAsync2.default)(task); + return (0, _initialParams2.default)((args, callback) => { + if (args.length < arity - 1 || callback == null) { + args.push(callback); + callback = (0, _promiseCallback.promiseCallback)(); + } + function taskFn(cb) { + _task(...args, cb); + } + + if (opts) (0, _retry2.default)(opts, taskFn, callback);else (0, _retry2.default)(taskFn, callback); + + return callback[_promiseCallback.PROMISE_SYMBOL]; + }); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/select.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/select.js new file mode 100644 index 0000000..2c9a63d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/select.js @@ -0,0 +1,93 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns a new array of all the values in `coll` which pass an async truth + * test. This operation is performed in parallel, but the results array will be + * in the same order as the original. + * + * @name filter + * @static + * @memberOf module:Collections + * @method + * @alias select + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * + * const files = ['dir1/file1.txt','dir2/file3.txt','dir3/file6.txt']; + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.filter(files, fileExists, function(err, results) { + * if(err) { + * console.log(err); + * } else { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * }); + * + * // Using Promises + * async.filter(files, fileExists) + * .then(results => { + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let results = await async.filter(files, fileExists); + * console.log(results); + * // [ 'dir1/file1.txt', 'dir2/file3.txt' ] + * // results is now an array of the existing files + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function filter(coll, iteratee, callback) { + return (0, _filter3.default)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filter, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectLimit.js new file mode 100644 index 0000000..d3b3f50 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectLimit.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a + * time. + * + * @name filterLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results). + * @returns {Promise} a promise, if no callback provided + */ +function filterLimit(coll, limit, iteratee, callback) { + return (0, _filter3.default)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filterLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectSeries.js new file mode 100644 index 0000000..019a2d0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/selectSeries.js @@ -0,0 +1,43 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _filter2 = require('./internal/filter.js'); + +var _filter3 = _interopRequireDefault(_filter2); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time. + * + * @name filterSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.filter]{@link module:Collections.filter} + * @alias selectSeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {Function} iteratee - A truth test to apply to each item in `coll`. + * The `iteratee` is passed a `callback(err, truthValue)`, which must be called + * with a boolean argument once it has completed. Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Invoked with (err, results) + * @returns {Promise} a promise, if no callback provided + */ +function filterSeries(coll, iteratee, callback) { + return (0, _filter3.default)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(filterSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/seq.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/seq.js new file mode 100644 index 0000000..e7881cd --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/seq.js @@ -0,0 +1,79 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = seq; + +var _reduce = require('./reduce.js'); + +var _reduce2 = _interopRequireDefault(_reduce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _promiseCallback = require('./internal/promiseCallback.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Version of the compose function that is more natural to read. Each function + * consumes the return value of the previous function. It is the equivalent of + * [compose]{@link module:ControlFlow.compose} with the arguments reversed. + * + * Each function is executed with the `this` binding of the composed function. + * + * @name seq + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.compose]{@link module:ControlFlow.compose} + * @category Control Flow + * @param {...AsyncFunction} functions - the asynchronous functions to compose + * @returns {Function} a function that composes the `functions` in order + * @example + * + * // Requires lodash (or underscore), express3 and dresende's orm2. + * // Part of an app, that fetches cats of the logged user. + * // This example uses `seq` function to avoid overnesting and error + * // handling clutter. + * app.get('/cats', function(request, response) { + * var User = request.models.User; + * async.seq( + * User.get.bind(User), // 'User.get' has signature (id, callback(err, data)) + * function(user, fn) { + * user.getCats(fn); // 'getCats' has signature (callback(err, data)) + * } + * )(req.session.user_id, function (err, cats) { + * if (err) { + * console.error(err); + * response.json({ status: 'error', message: err.message }); + * } else { + * response.json({ status: 'ok', message: 'Cats found', data: cats }); + * } + * }); + * }); + */ +function seq(...functions) { + var _functions = functions.map(_wrapAsync2.default); + return function (...args) { + var that = this; + + var cb = args[args.length - 1]; + if (typeof cb == 'function') { + args.pop(); + } else { + cb = (0, _promiseCallback.promiseCallback)(); + } + + (0, _reduce2.default)(_functions, args, (newargs, fn, iterCb) => { + fn.apply(that, newargs.concat((err, ...nextargs) => { + iterCb(err, nextargs); + })); + }, (err, results) => cb(err, ...results)); + + return cb[_promiseCallback.PROMISE_SYMBOL]; + }; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/series.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/series.js new file mode 100644 index 0000000..60c17ed --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/series.js @@ -0,0 +1,186 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = series; + +var _parallel2 = require('./internal/parallel.js'); + +var _parallel3 = _interopRequireDefault(_parallel2); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Run the functions in the `tasks` collection in series, each one running once + * the previous function has completed. If any functions in the series pass an + * error to its callback, no more functions are run, and `callback` is + * immediately called with the value of the error. Otherwise, `callback` + * receives an array of results when `tasks` have completed. + * + * It is also possible to use an object instead of an array. Each property will + * be run as a function, and the results will be passed to the final `callback` + * as an object instead of an array. This can be a more readable way of handling + * results from {@link async.series}. + * + * **Note** that while many implementations preserve the order of object + * properties, the [ECMAScript Language Specification](http://www.ecma-international.org/ecma-262/5.1/#sec-8.6) + * explicitly states that + * + * > The mechanics and order of enumerating the properties is not specified. + * + * So if you rely on the order in which your series of functions are executed, + * and want this to work on all platforms, consider using an array. + * + * @name series + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing + * [async functions]{@link AsyncFunction} to run in series. + * Each function can complete with any number of optional `result` values. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This function gets a results array (or object) + * containing all the result arguments passed to the `task` callbacks. Invoked + * with (err, result). + * @return {Promise} a promise, if no callback is passed + * @example + * + * //Using Callbacks + * async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ], function(err, results) { + * console.log(results); + * // results is equal to ['one','two'] + * }); + * + * // an example using objects instead of arrays + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }, function(err, results) { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }); + * + * //Using Promises + * async.series([ + * function(callback) { + * setTimeout(function() { + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * callback(null, 'two'); + * }, 100); + * } + * ]).then(results => { + * console.log(results); + * // results is equal to ['one','two'] + * }).catch(err => { + * console.log(err); + * }); + * + * // an example using an object instead of an array + * async.series({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }).then(results => { + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * }).catch(err => { + * console.log(err); + * }); + * + * //Using async/await + * async () => { + * try { + * let results = await async.series([ + * function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 'one'); + * }, 200); + * }, + * function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 'two'); + * }, 100); + * } + * ]); + * console.log(results); + * // results is equal to ['one','two'] + * } + * catch (err) { + * console.log(err); + * } + * } + * + * // an example using an object instead of an array + * async () => { + * try { + * let results = await async.parallel({ + * one: function(callback) { + * setTimeout(function() { + * // do some async task + * callback(null, 1); + * }, 200); + * }, + * two: function(callback) { + * setTimeout(function() { + * // then do another async task + * callback(null, 2); + * }, 100); + * } + * }); + * console.log(results); + * // results is equal to: { one: 1, two: 2 } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function series(tasks, callback) { + return (0, _parallel3.default)(_eachOfSeries2.default, tasks, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/setImmediate.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/setImmediate.js new file mode 100644 index 0000000..eea8677 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/setImmediate.js @@ -0,0 +1,45 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _setImmediate = require('./internal/setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Calls `callback` on a later loop around the event loop. In Node.js this just + * calls `setImmediate`. In the browser it will use `setImmediate` if + * available, otherwise `setTimeout(callback, 0)`, which means other higher + * priority events may precede the execution of `callback`. + * + * This is used internally for browser-compatibility purposes. + * + * @name setImmediate + * @static + * @memberOf module:Utils + * @method + * @see [async.nextTick]{@link module:Utils.nextTick} + * @category Util + * @param {Function} callback - The function to call on a later loop around + * the event loop. Invoked with (args...). + * @param {...*} args... - any number of additional arguments to pass to the + * callback on the next tick. + * @example + * + * var call_order = []; + * async.nextTick(function() { + * call_order.push('two'); + * // call_order now equals ['one','two'] + * }); + * call_order.push('one'); + * + * async.setImmediate(function (a, b, c) { + * // a, b, and c equal 1, 2, and 3 + * }, 1, 2, 3); + */ +exports.default = _setImmediate2.default; +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/some.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/some.js new file mode 100644 index 0000000..a5bd328 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/some.js @@ -0,0 +1,122 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Returns `true` if at least one element in the `coll` satisfies an async test. + * If any iteratee call returns `true`, the main `callback` is immediately + * called. + * + * @name some + * @static + * @memberOf module:Collections + * @method + * @alias any + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // dir1 is a directory that contains file1.txt, file2.txt + * // dir2 is a directory that contains file3.txt, file4.txt + * // dir3 is a directory that contains file5.txt + * // dir4 does not exist + * + * // asynchronous function that checks if a file exists + * function fileExists(file, callback) { + * fs.access(file, fs.constants.F_OK, (err) => { + * callback(null, !err); + * }); + * } + * + * // Using callbacks + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + *); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists, + * function(err, result) { + * console.log(result); + * // false + * // result is false since none of the files exists + * } + *); + * + * // Using Promises + * async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists) + * .then( result => { + * console.log(result); + * // true + * // result is true since some file in the list exists + * }).catch( err => { + * console.log(err); + * }); + * + * async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists) + * .then( result => { + * console.log(result); + * // false + * // result is false since none of the files exists + * }).catch( err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir3/file5.txt'], fileExists); + * console.log(result); + * // true + * // result is true since some file in the list exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + * async () => { + * try { + * let result = await async.some(['dir1/missing.txt','dir2/missing.txt','dir4/missing.txt'], fileExists); + * console.log(result); + * // false + * // result is false since none of the files exists + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function some(coll, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)(_eachOf2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(some, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someLimit.js new file mode 100644 index 0000000..3a8096f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someLimit.js @@ -0,0 +1,47 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfLimit = require('./internal/eachOfLimit.js'); + +var _eachOfLimit2 = _interopRequireDefault(_eachOfLimit); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time. + * + * @name someLimit + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anyLimit + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in parallel. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someLimit(coll, limit, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)((0, _eachOfLimit2.default)(limit), coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(someLimit, 4); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someSeries.js new file mode 100644 index 0000000..51aad19 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/someSeries.js @@ -0,0 +1,46 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createTester = require('./internal/createTester.js'); + +var _createTester2 = _interopRequireDefault(_createTester); + +var _eachOfSeries = require('./eachOfSeries.js'); + +var _eachOfSeries2 = _interopRequireDefault(_eachOfSeries); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time. + * + * @name someSeries + * @static + * @memberOf module:Collections + * @method + * @see [async.some]{@link module:Collections.some} + * @alias anySeries + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async truth test to apply to each item + * in the collections in series. + * The iteratee should complete with a boolean `result` value. + * Invoked with (item, callback). + * @param {Function} [callback] - A callback which is called as soon as any + * iteratee returns `true`, or after all the iteratee functions have finished. + * Result will be either `true` or `false` depending on the values of the async + * tests. Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + */ +function someSeries(coll, iteratee, callback) { + return (0, _createTester2.default)(Boolean, res => res)(_eachOfSeries2.default, coll, iteratee, callback); +} +exports.default = (0, _awaitify2.default)(someSeries, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/sortBy.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/sortBy.js new file mode 100644 index 0000000..0988b61 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/sortBy.js @@ -0,0 +1,190 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _map = require('./map.js'); + +var _map2 = _interopRequireDefault(_map); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Sorts a list by the results of running each `coll` value through an async + * `iteratee`. + * + * @name sortBy + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {AsyncFunction} iteratee - An async function to apply to each item in + * `coll`. + * The iteratee should complete with a value to use as the sort criteria as + * its `result`. + * Invoked with (item, callback). + * @param {Function} callback - A callback which is called after all the + * `iteratee` functions have finished, or an error occurs. Results is the items + * from the original `coll` sorted by the values returned by the `iteratee` + * calls. Invoked with (err, results). + * @returns {Promise} a promise, if no callback passed + * @example + * + * // bigfile.txt is a file that is 251100 bytes in size + * // mediumfile.txt is a file that is 11000 bytes in size + * // smallfile.txt is a file that is 121 bytes in size + * + * // asynchronous function that returns the file size in bytes + * function getFileSizeInBytes(file, callback) { + * fs.stat(file, function(err, stat) { + * if (err) { + * return callback(err); + * } + * callback(null, stat.size); + * }); + * } + * + * // Using callbacks + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // By modifying the callback parameter the + * // sorting order can be influenced: + * + * // ascending order + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) return callback(getFileSizeErr); + * callback(null, fileSize); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * } + * ); + * + * // descending order + * async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], function(file, callback) { + * getFileSizeInBytes(file, function(getFileSizeErr, fileSize) { + * if (getFileSizeErr) { + * return callback(getFileSizeErr); + * } + * callback(null, fileSize * -1); + * }); + * }, function(err, results) { + * if (err) { + * console.log(err); + * } else { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'bigfile.txt', 'mediumfile.txt', 'smallfile.txt'] + * } + * } + * ); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes, + * function(err, results) { + * if (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } else { + * console.log(results); + * } + * } + * ); + * + * // Using Promises + * async.sortBy(['mediumfile.txt','smallfile.txt','bigfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * }).catch( err => { + * console.log(err); + * }); + * + * // Error handling + * async.sortBy(['mediumfile.txt','smallfile.txt','missingfile.txt'], getFileSizeInBytes) + * .then( results => { + * console.log(results); + * }).catch( err => { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * }); + * + * // Using async/await + * (async () => { + * try { + * let results = await async.sortBy(['bigfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * // results is now the original array of files sorted by + * // file size (ascending by default), e.g. + * // [ 'smallfile.txt', 'mediumfile.txt', 'bigfile.txt'] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * // Error handling + * async () => { + * try { + * let results = await async.sortBy(['missingfile.txt','mediumfile.txt','smallfile.txt'], getFileSizeInBytes); + * console.log(results); + * } + * catch (err) { + * console.log(err); + * // [ Error: ENOENT: no such file or directory ] + * } + * } + * + */ +function sortBy(coll, iteratee, callback) { + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _map2.default)(coll, (x, iterCb) => { + _iteratee(x, (err, criteria) => { + if (err) return iterCb(err); + iterCb(err, { value: x, criteria }); + }); + }, (err, results) => { + if (err) return callback(err); + callback(null, results.sort(comparator).map(v => v.value)); + }); + + function comparator(left, right) { + var a = left.criteria, + b = right.criteria; + return a < b ? -1 : a > b ? 1 : 0; + } +} +exports.default = (0, _awaitify2.default)(sortBy, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timeout.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timeout.js new file mode 100644 index 0000000..46bb233 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timeout.js @@ -0,0 +1,89 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = timeout; + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Sets a time limit on an asynchronous function. If the function does not call + * its callback within the specified milliseconds, it will be called with a + * timeout error. The code property for the error object will be `'ETIMEDOUT'`. + * + * @name timeout + * @static + * @memberOf module:Utils + * @method + * @category Util + * @param {AsyncFunction} asyncFn - The async function to limit in time. + * @param {number} milliseconds - The specified time limit. + * @param {*} [info] - Any variable you want attached (`string`, `object`, etc) + * to timeout Error for more information.. + * @returns {AsyncFunction} Returns a wrapped function that can be used with any + * of the control flow functions. + * Invoke this function with the same parameters as you would `asyncFunc`. + * @example + * + * function myFunction(foo, callback) { + * doAsyncTask(foo, function(err, data) { + * // handle errors + * if (err) return callback(err); + * + * // do some stuff ... + * + * // return processed data + * return callback(null, data); + * }); + * } + * + * var wrapped = async.timeout(myFunction, 1000); + * + * // call `wrapped` as you would `myFunction` + * wrapped({ bar: 'bar' }, function(err, data) { + * // if `myFunction` takes < 1000 ms to execute, `err` + * // and `data` will have their expected values + * + * // else `err` will be an Error with the code 'ETIMEDOUT' + * }); + */ +function timeout(asyncFn, milliseconds, info) { + var fn = (0, _wrapAsync2.default)(asyncFn); + + return (0, _initialParams2.default)((args, callback) => { + var timedOut = false; + var timer; + + function timeoutCallback() { + var name = asyncFn.name || 'anonymous'; + var error = new Error('Callback function "' + name + '" timed out.'); + error.code = 'ETIMEDOUT'; + if (info) { + error.info = info; + } + timedOut = true; + callback(error); + } + + args.push((...cbArgs) => { + if (!timedOut) { + callback(...cbArgs); + clearTimeout(timer); + } + }); + + // setup timer and call original function + timer = setTimeout(timeoutCallback, milliseconds); + fn(...args); + }); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/times.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/times.js new file mode 100644 index 0000000..ca7df51 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/times.js @@ -0,0 +1,50 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = times; + +var _timesLimit = require('./timesLimit.js'); + +var _timesLimit2 = _interopRequireDefault(_timesLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Calls the `iteratee` function `n` times, and accumulates results in the same + * manner you would use with [map]{@link module:Collections.map}. + * + * @name times + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.map]{@link module:Collections.map} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + * @example + * + * // Pretend this is some complicated async factory + * var createUser = function(id, callback) { + * callback(null, { + * id: 'user' + id + * }); + * }; + * + * // generate 5 users + * async.times(5, function(n, next) { + * createUser(n, function(err, user) { + * next(err, user); + * }); + * }, function(err, users) { + * // we should now have 5 users + * }); + */ +function times(n, iteratee, callback) { + return (0, _timesLimit2.default)(n, Infinity, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesLimit.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesLimit.js new file mode 100644 index 0000000..f76de25 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesLimit.js @@ -0,0 +1,43 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = timesLimit; + +var _mapLimit = require('./mapLimit.js'); + +var _mapLimit2 = _interopRequireDefault(_mapLimit); + +var _range = require('./internal/range.js'); + +var _range2 = _interopRequireDefault(_range); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [times]{@link module:ControlFlow.times} but runs a maximum of `limit` async operations at a + * time. + * + * @name timesLimit + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} count - The number of times to run the function. + * @param {number} limit - The maximum number of async operations at a time. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see [async.map]{@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ +function timesLimit(count, limit, iteratee, callback) { + var _iteratee = (0, _wrapAsync2.default)(iteratee); + return (0, _mapLimit2.default)((0, _range2.default)(count), limit, _iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesSeries.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesSeries.js new file mode 100644 index 0000000..776b4f3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/timesSeries.js @@ -0,0 +1,32 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = timesSeries; + +var _timesLimit = require('./timesLimit.js'); + +var _timesLimit2 = _interopRequireDefault(_timesLimit); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * The same as [times]{@link module:ControlFlow.times} but runs only a single async operation at a time. + * + * @name timesSeries + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.times]{@link module:ControlFlow.times} + * @category Control Flow + * @param {number} n - The number of times to run the function. + * @param {AsyncFunction} iteratee - The async function to call `n` times. + * Invoked with the iteration index and a callback: (n, next). + * @param {Function} callback - see {@link module:Collections.map}. + * @returns {Promise} a promise, if no callback is provided + */ +function timesSeries(n, iteratee, callback) { + return (0, _timesLimit2.default)(n, 1, iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/transform.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/transform.js new file mode 100644 index 0000000..75dadea --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/transform.js @@ -0,0 +1,173 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = transform; + +var _eachOf = require('./eachOf.js'); + +var _eachOf2 = _interopRequireDefault(_eachOf); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _promiseCallback = require('./internal/promiseCallback.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * A relative of `reduce`. Takes an Object or Array, and iterates over each + * element in parallel, each step potentially mutating an `accumulator` value. + * The type of the accumulator defaults to the type of collection passed in. + * + * @name transform + * @static + * @memberOf module:Collections + * @method + * @category Collection + * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. + * @param {*} [accumulator] - The initial state of the transform. If omitted, + * it will default to an empty Object or Array, depending on the type of `coll` + * @param {AsyncFunction} iteratee - A function applied to each item in the + * collection that potentially modifies the accumulator. + * Invoked with (accumulator, item, key, callback). + * @param {Function} [callback] - A callback which is called after all the + * `iteratee` functions have finished. Result is the transformed accumulator. + * Invoked with (err, result). + * @returns {Promise} a promise, if no callback provided + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileList = ['file1.txt','file2.txt','file3.txt']; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileList, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * }); + * + * // Using Promises + * async.transform(fileList, transformFileSize) + * .then(result => { + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * (async () => { + * try { + * let result = await async.transform(fileList, transformFileSize); + * console.log(result); + * // [ '1000 Bytes', '1.95 KB', '2.93 KB' ] + * } + * catch (err) { + * console.log(err); + * } + * })(); + * + * @example + * + * // file1.txt is a file that is 1000 bytes in size + * // file2.txt is a file that is 2000 bytes in size + * // file3.txt is a file that is 3000 bytes in size + * + * // helper function that returns human-readable size format from bytes + * function formatBytes(bytes, decimals = 2) { + * // implementation not included for brevity + * return humanReadbleFilesize; + * } + * + * const fileMap = { f1: 'file1.txt', f2: 'file2.txt', f3: 'file3.txt' }; + * + * // asynchronous function that returns the file size, transformed to human-readable format + * // e.g. 1024 bytes = 1KB, 1234 bytes = 1.21 KB, 1048576 bytes = 1MB, etc. + * function transformFileSize(acc, value, key, callback) { + * fs.stat(value, function(err, stat) { + * if (err) { + * return callback(err); + * } + * acc[key] = formatBytes(stat.size); + * callback(null); + * }); + * } + * + * // Using callbacks + * async.transform(fileMap, transformFileSize, function(err, result) { + * if(err) { + * console.log(err); + * } else { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * }); + * + * // Using Promises + * async.transform(fileMap, transformFileSize) + * .then(result => { + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * }).catch(err => { + * console.log(err); + * }); + * + * // Using async/await + * async () => { + * try { + * let result = await async.transform(fileMap, transformFileSize); + * console.log(result); + * // { f1: '1000 Bytes', f2: '1.95 KB', f3: '2.93 KB' } + * } + * catch (err) { + * console.log(err); + * } + * } + * + */ +function transform(coll, accumulator, iteratee, callback) { + if (arguments.length <= 3 && typeof accumulator === 'function') { + callback = iteratee; + iteratee = accumulator; + accumulator = Array.isArray(coll) ? [] : {}; + } + callback = (0, _once2.default)(callback || (0, _promiseCallback.promiseCallback)()); + var _iteratee = (0, _wrapAsync2.default)(iteratee); + + (0, _eachOf2.default)(coll, (v, k, cb) => { + _iteratee(accumulator, v, k, cb); + }, err => callback(err, accumulator)); + return callback[_promiseCallback.PROMISE_SYMBOL]; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/tryEach.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/tryEach.js new file mode 100644 index 0000000..7e63f9d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/tryEach.js @@ -0,0 +1,78 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _eachSeries = require('./eachSeries.js'); + +var _eachSeries2 = _interopRequireDefault(_eachSeries); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * It runs each task in series but stops whenever any of the functions were + * successful. If one of the tasks were successful, the `callback` will be + * passed the result of the successful task. If all tasks fail, the callback + * will be passed the error and result (if any) of the final attempt. + * + * @name tryEach + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array|Iterable|AsyncIterable|Object} tasks - A collection containing functions to + * run, each function is passed a `callback(err, result)` it must call on + * completion with an error `err` (which can be `null`) and an optional `result` + * value. + * @param {Function} [callback] - An optional callback which is called when one + * of the tasks has succeeded, or all have failed. It receives the `err` and + * `result` arguments of the last attempt at completing the `task`. Invoked with + * (err, results). + * @returns {Promise} a promise, if no callback is passed + * @example + * async.tryEach([ + * function getDataFromFirstWebsite(callback) { + * // Try getting the data from the first website + * callback(err, data); + * }, + * function getDataFromSecondWebsite(callback) { + * // First website failed, + * // Try getting the data from the backup website + * callback(err, data); + * } + * ], + * // optional callback + * function(err, results) { + * Now do something with the data. + * }); + * + */ +function tryEach(tasks, callback) { + var error = null; + var result; + return (0, _eachSeries2.default)(tasks, (task, taskCb) => { + (0, _wrapAsync2.default)(task)((err, ...args) => { + if (err === false) return taskCb(err); + + if (args.length < 2) { + [result] = args; + } else { + result = args; + } + error = err; + taskCb(err ? null : {}); + }); + }, () => callback(error, result)); +} + +exports.default = (0, _awaitify2.default)(tryEach); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/unmemoize.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/unmemoize.js new file mode 100644 index 0000000..badd7ae --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/unmemoize.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = unmemoize; +/** + * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original, + * unmemoized form. Handy for testing. + * + * @name unmemoize + * @static + * @memberOf module:Utils + * @method + * @see [async.memoize]{@link module:Utils.memoize} + * @category Util + * @param {AsyncFunction} fn - the memoized function + * @returns {AsyncFunction} a function that calls the original unmemoized function + */ +function unmemoize(fn) { + return (...args) => { + return (fn.unmemoized || fn)(...args); + }; +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/until.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/until.js new file mode 100644 index 0000000..4b69b97 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/until.js @@ -0,0 +1,61 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = until; + +var _whilst = require('./whilst.js'); + +var _whilst2 = _interopRequireDefault(_whilst); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Repeatedly call `iteratee` until `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. `callback` will be passed an error and any + * arguments passed to the final `iteratee`'s callback. + * + * The inverse of [whilst]{@link module:ControlFlow.whilst}. + * + * @name until + * @static + * @memberOf module:ControlFlow + * @method + * @see [async.whilst]{@link module:ControlFlow.whilst} + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` fails. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has passed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if a callback is not passed + * + * @example + * const results = [] + * let finished = false + * async.until(function test(cb) { + * cb(null, finished) + * }, function iter(next) { + * fetchPage(url, (err, body) => { + * if (err) return next(err) + * results = results.concat(body.objects) + * finished = !!body.next + * next(err) + * }) + * }, function done (err) { + * // all pages have been fetched + * }) + */ +function until(test, iteratee, callback) { + const _test = (0, _wrapAsync2.default)(test); + return (0, _whilst2.default)(cb => _test((err, truth) => cb(err, !truth)), iteratee, callback); +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/waterfall.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/waterfall.js new file mode 100644 index 0000000..c3242f7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/waterfall.js @@ -0,0 +1,105 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _once = require('./internal/once.js'); + +var _once2 = _interopRequireDefault(_once); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Runs the `tasks` array of functions in series, each passing their results to + * the next in the array. However, if any of the `tasks` pass an error to their + * own callback, the next function is not executed, and the main `callback` is + * immediately called with the error. + * + * @name waterfall + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {Array} tasks - An array of [async functions]{@link AsyncFunction} + * to run. + * Each function should complete with any number of `result` values. + * The `result` values will be passed as arguments, in order, to the next task. + * @param {Function} [callback] - An optional callback to run once all the + * functions have completed. This will be passed the results of the last task's + * callback. Invoked with (err, [results]). + * @returns {Promise} a promise, if a callback is omitted + * @example + * + * async.waterfall([ + * function(callback) { + * callback(null, 'one', 'two'); + * }, + * function(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * }, + * function(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + * ], function (err, result) { + * // result now equals 'done' + * }); + * + * // Or, with named functions: + * async.waterfall([ + * myFirstFunction, + * mySecondFunction, + * myLastFunction, + * ], function (err, result) { + * // result now equals 'done' + * }); + * function myFirstFunction(callback) { + * callback(null, 'one', 'two'); + * } + * function mySecondFunction(arg1, arg2, callback) { + * // arg1 now equals 'one' and arg2 now equals 'two' + * callback(null, 'three'); + * } + * function myLastFunction(arg1, callback) { + * // arg1 now equals 'three' + * callback(null, 'done'); + * } + */ +function waterfall(tasks, callback) { + callback = (0, _once2.default)(callback); + if (!Array.isArray(tasks)) return callback(new Error('First argument to waterfall must be an array of functions')); + if (!tasks.length) return callback(); + var taskIndex = 0; + + function nextTask(args) { + var task = (0, _wrapAsync2.default)(tasks[taskIndex++]); + task(...args, (0, _onlyOnce2.default)(next)); + } + + function next(err, ...args) { + if (err === false) return; + if (err || taskIndex === tasks.length) { + return callback(err, ...args); + } + nextTask(args); + } + + nextTask([]); +} + +exports.default = (0, _awaitify2.default)(waterfall); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/whilst.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/whilst.js new file mode 100644 index 0000000..4165543 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/whilst.js @@ -0,0 +1,78 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _onlyOnce = require('./internal/onlyOnce.js'); + +var _onlyOnce2 = _interopRequireDefault(_onlyOnce); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +var _wrapAsync2 = _interopRequireDefault(_wrapAsync); + +var _awaitify = require('./internal/awaitify.js'); + +var _awaitify2 = _interopRequireDefault(_awaitify); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Repeatedly call `iteratee`, while `test` returns `true`. Calls `callback` when + * stopped, or an error occurs. + * + * @name whilst + * @static + * @memberOf module:ControlFlow + * @method + * @category Control Flow + * @param {AsyncFunction} test - asynchronous truth test to perform before each + * execution of `iteratee`. Invoked with (callback). + * @param {AsyncFunction} iteratee - An async function which is called each time + * `test` passes. Invoked with (callback). + * @param {Function} [callback] - A callback which is called after the test + * function has failed and repeated execution of `iteratee` has stopped. `callback` + * will be passed an error and any arguments passed to the final `iteratee`'s + * callback. Invoked with (err, [results]); + * @returns {Promise} a promise, if no callback is passed + * @example + * + * var count = 0; + * async.whilst( + * function test(cb) { cb(null, count < 5); }, + * function iter(callback) { + * count++; + * setTimeout(function() { + * callback(null, count); + * }, 1000); + * }, + * function (err, n) { + * // 5 seconds have passed, n = 5 + * } + * ); + */ +function whilst(test, iteratee, callback) { + callback = (0, _onlyOnce2.default)(callback); + var _fn = (0, _wrapAsync2.default)(iteratee); + var _test = (0, _wrapAsync2.default)(test); + var results = []; + + function next(err, ...rest) { + if (err) return callback(err); + results = rest; + if (err === false) return; + _test(check); + } + + function check(err, truth) { + if (err) return callback(err); + if (err === false) return; + if (!truth) return callback(null, ...results); + _fn(next); + } + + return _test(check); +} +exports.default = (0, _awaitify2.default)(whilst, 3); +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/wrapSync.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/wrapSync.js new file mode 100644 index 0000000..ddc3f02 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/async/wrapSync.js @@ -0,0 +1,118 @@ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = asyncify; + +var _initialParams = require('./internal/initialParams.js'); + +var _initialParams2 = _interopRequireDefault(_initialParams); + +var _setImmediate = require('./internal/setImmediate.js'); + +var _setImmediate2 = _interopRequireDefault(_setImmediate); + +var _wrapAsync = require('./internal/wrapAsync.js'); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +/** + * Take a sync function and make it async, passing its return value to a + * callback. This is useful for plugging sync functions into a waterfall, + * series, or other async functions. Any arguments passed to the generated + * function will be passed to the wrapped function (except for the final + * callback argument). Errors thrown will be passed to the callback. + * + * If the function passed to `asyncify` returns a Promise, that promises's + * resolved/rejected state will be used to call the callback, rather than simply + * the synchronous return value. + * + * This also means you can asyncify ES2017 `async` functions. + * + * @name asyncify + * @static + * @memberOf module:Utils + * @method + * @alias wrapSync + * @category Util + * @param {Function} func - The synchronous function, or Promise-returning + * function to convert to an {@link AsyncFunction}. + * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be + * invoked with `(args..., callback)`. + * @example + * + * // passing a regular synchronous function + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(JSON.parse), + * function (data, next) { + * // data is the result of parsing the text. + * // If there was a parsing error, it would have been caught. + * } + * ], callback); + * + * // passing a function returning a promise + * async.waterfall([ + * async.apply(fs.readFile, filename, "utf8"), + * async.asyncify(function (contents) { + * return db.model.create(contents); + * }), + * function (model, next) { + * // `model` is the instantiated model object. + * // If there was an error, this function would be skipped. + * } + * ], callback); + * + * // es2017 example, though `asyncify` is not needed if your JS environment + * // supports async functions out of the box + * var q = async.queue(async.asyncify(async function(file) { + * var intermediateStep = await processFile(file); + * return await somePromise(intermediateStep) + * })); + * + * q.push(files); + */ +function asyncify(func) { + if ((0, _wrapAsync.isAsync)(func)) { + return function (...args /*, callback*/) { + const callback = args.pop(); + const promise = func.apply(this, args); + return handlePromise(promise, callback); + }; + } + + return (0, _initialParams2.default)(function (args, callback) { + var result; + try { + result = func.apply(this, args); + } catch (e) { + return callback(e); + } + // if result is Promise object + if (result && typeof result.then === 'function') { + return handlePromise(result, callback); + } else { + callback(null, result); + } + }); +} + +function handlePromise(promise, callback) { + return promise.then(value => { + invokeCallback(callback, null, value); + }, err => { + invokeCallback(callback, err && (err instanceof Error || err.message) ? err : new Error(err)); + }); +} + +function invokeCallback(callback, error, value) { + try { + callback(error, value); + } catch (err) { + (0, _setImmediate2.default)(e => { + throw e; + }, err); + } +} +module.exports = exports.default; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/.github/FUNDING.yml b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/.github/FUNDING.yml new file mode 100644 index 0000000..cea8b16 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/.github/FUNDING.yml @@ -0,0 +1,2 @@ +tidelift: "npm/balanced-match" +patreon: juliangruber diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/LICENSE.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/LICENSE.md new file mode 100644 index 0000000..2cdc8e4 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/LICENSE.md @@ -0,0 +1,21 @@ +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/README.md new file mode 100644 index 0000000..d2a48b6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/README.md @@ -0,0 +1,97 @@ +# balanced-match + +Match balanced string pairs, like `{` and `}` or `` and ``. Supports regular expressions as well! + +[![build status](https://secure.travis-ci.org/juliangruber/balanced-match.svg)](http://travis-ci.org/juliangruber/balanced-match) +[![downloads](https://img.shields.io/npm/dm/balanced-match.svg)](https://www.npmjs.org/package/balanced-match) + +[![testling badge](https://ci.testling.com/juliangruber/balanced-match.png)](https://ci.testling.com/juliangruber/balanced-match) + +## Example + +Get the first matching pair of braces: + +```js +var balanced = require('balanced-match'); + +console.log(balanced('{', '}', 'pre{in{nested}}post')); +console.log(balanced('{', '}', 'pre{first}between{second}post')); +console.log(balanced(/\s+\{\s+/, /\s+\}\s+/, 'pre { in{nest} } post')); +``` + +The matches are: + +```bash +$ node example.js +{ start: 3, end: 14, pre: 'pre', body: 'in{nested}', post: 'post' } +{ start: 3, + end: 9, + pre: 'pre', + body: 'first', + post: 'between{second}post' } +{ start: 3, end: 17, pre: 'pre', body: 'in{nest}', post: 'post' } +``` + +## API + +### var m = balanced(a, b, str) + +For the first non-nested matching pair of `a` and `b` in `str`, return an +object with those keys: + +* **start** the index of the first match of `a` +* **end** the index of the matching `b` +* **pre** the preamble, `a` and `b` not included +* **body** the match, `a` and `b` not included +* **post** the postscript, `a` and `b` not included + +If there's no match, `undefined` will be returned. + +If the `str` contains more `a` than `b` / there are unmatched pairs, the first match that was closed will be used. For example, `{{a}` will match `['{', 'a', '']` and `{a}}` will match `['', 'a', '}']`. + +### var r = balanced.range(a, b, str) + +For the first non-nested matching pair of `a` and `b` in `str`, return an +array with indexes: `[ , ]`. + +If there's no match, `undefined` will be returned. + +If the `str` contains more `a` than `b` / there are unmatched pairs, the first match that was closed will be used. For example, `{{a}` will match `[ 1, 3 ]` and `{a}}` will match `[0, 2]`. + +## Installation + +With [npm](https://npmjs.org) do: + +```bash +npm install balanced-match +``` + +## Security contact information + +To report a security vulnerability, please use the +[Tidelift security contact](https://tidelift.com/security). +Tidelift will coordinate the fix and disclosure. + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/index.js new file mode 100644 index 0000000..c67a646 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/index.js @@ -0,0 +1,62 @@ +'use strict'; +module.exports = balanced; +function balanced(a, b, str) { + if (a instanceof RegExp) a = maybeMatch(a, str); + if (b instanceof RegExp) b = maybeMatch(b, str); + + var r = range(a, b, str); + + return r && { + start: r[0], + end: r[1], + pre: str.slice(0, r[0]), + body: str.slice(r[0] + a.length, r[1]), + post: str.slice(r[1] + b.length) + }; +} + +function maybeMatch(reg, str) { + var m = str.match(reg); + return m ? m[0] : null; +} + +balanced.range = range; +function range(a, b, str) { + var begs, beg, left, right, result; + var ai = str.indexOf(a); + var bi = str.indexOf(b, ai + 1); + var i = ai; + + if (ai >= 0 && bi > 0) { + if(a===b) { + return [ai, bi]; + } + begs = []; + left = str.length; + + while (i >= 0 && !result) { + if (i == ai) { + begs.push(i); + ai = str.indexOf(a, i + 1); + } else if (begs.length == 1) { + result = [ begs.pop(), bi ]; + } else { + beg = begs.pop(); + if (beg < left) { + left = beg; + right = bi; + } + + bi = str.indexOf(b, i + 1); + } + + i = ai < bi && ai >= 0 ? ai : bi; + } + + if (begs.length) { + result = [ left, right ]; + } + } + + return result; +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/package.json new file mode 100644 index 0000000..ce6073e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/balanced-match/package.json @@ -0,0 +1,48 @@ +{ + "name": "balanced-match", + "description": "Match balanced character pairs, like \"{\" and \"}\"", + "version": "1.0.2", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/balanced-match.git" + }, + "homepage": "https://github.com/juliangruber/balanced-match", + "main": "index.js", + "scripts": { + "test": "tape test/test.js", + "bench": "matcha test/bench.js" + }, + "devDependencies": { + "matcha": "^0.7.0", + "tape": "^4.6.0" + }, + "keywords": [ + "match", + "regexp", + "test", + "balanced", + "parse" + ], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "testling": { + "files": "test/*.js", + "browsers": [ + "ie/8..latest", + "firefox/20..latest", + "firefox/nightly", + "chrome/25..latest", + "chrome/canary", + "opera/12..latest", + "opera/next", + "safari/5.1..latest", + "ipad/6.0..latest", + "iphone/6.0..latest", + "android-browser/4.2..latest" + ] + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json new file mode 100644 index 0000000..ac08048 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json @@ -0,0 +1,263 @@ +[ + "3dm", + "3ds", + "3g2", + "3gp", + "7z", + "a", + "aac", + "adp", + "afdesign", + "afphoto", + "afpub", + "ai", + "aif", + "aiff", + "alz", + "ape", + "apk", + "appimage", + "ar", + "arj", + "asf", + "au", + "avi", + "bak", + "baml", + "bh", + "bin", + "bk", + "bmp", + "btif", + "bz2", + "bzip2", + "cab", + "caf", + "cgm", + "class", + "cmx", + "cpio", + "cr2", + "cur", + "dat", + "dcm", + "deb", + "dex", + "djvu", + "dll", + "dmg", + "dng", + "doc", + "docm", + "docx", + "dot", + "dotm", + "dra", + "DS_Store", + "dsk", + "dts", + "dtshd", + "dvb", + "dwg", + "dxf", + "ecelp4800", + "ecelp7470", + "ecelp9600", + "egg", + "eol", + "eot", + "epub", + "exe", + "f4v", + "fbs", + "fh", + "fla", + "flac", + "flatpak", + "fli", + "flv", + "fpx", + "fst", + "fvt", + "g3", + "gh", + "gif", + "graffle", + "gz", + "gzip", + "h261", + "h263", + "h264", + "icns", + "ico", + "ief", + "img", + "ipa", + "iso", + "jar", + "jpeg", + "jpg", + "jpgv", + "jpm", + "jxr", + "key", + "ktx", + "lha", + "lib", + "lvp", + "lz", + "lzh", + "lzma", + "lzo", + "m3u", + "m4a", + "m4v", + "mar", + "mdi", + "mht", + "mid", + "midi", + "mj2", + "mka", + "mkv", + "mmr", + "mng", + "mobi", + "mov", + "movie", + "mp3", + "mp4", + "mp4a", + "mpeg", + "mpg", + "mpga", + "mxu", + "nef", + "npx", + "numbers", + "nupkg", + "o", + "odp", + "ods", + "odt", + "oga", + "ogg", + "ogv", + "otf", + "ott", + "pages", + "pbm", + "pcx", + "pdb", + "pdf", + "pea", + "pgm", + "pic", + "png", + "pnm", + "pot", + "potm", + "potx", + "ppa", + "ppam", + "ppm", + "pps", + "ppsm", + "ppsx", + "ppt", + "pptm", + "pptx", + "psd", + "pya", + "pyc", + "pyo", + "pyv", + "qt", + "rar", + "ras", + "raw", + "resources", + "rgb", + "rip", + "rlc", + "rmf", + "rmvb", + "rpm", + "rtf", + "rz", + "s3m", + "s7z", + "scpt", + "sgi", + "shar", + "snap", + "sil", + "sketch", + "slk", + "smv", + "snk", + "so", + "stl", + "suo", + "sub", + "swf", + "tar", + "tbz", + "tbz2", + "tga", + "tgz", + "thmx", + "tif", + "tiff", + "tlz", + "ttc", + "ttf", + "txz", + "udf", + "uvh", + "uvi", + "uvm", + "uvp", + "uvs", + "uvu", + "viv", + "vob", + "war", + "wav", + "wax", + "wbmp", + "wdp", + "weba", + "webm", + "webp", + "whl", + "wim", + "wm", + "wma", + "wmv", + "wmx", + "woff", + "woff2", + "wrm", + "wvx", + "xbm", + "xif", + "xla", + "xlam", + "xls", + "xlsb", + "xlsm", + "xlsx", + "xlt", + "xltm", + "xltx", + "xm", + "xmind", + "xpi", + "xpm", + "xwd", + "xz", + "z", + "zip", + "zipx" +] diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json.d.ts new file mode 100644 index 0000000..94a248c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/binary-extensions.json.d.ts @@ -0,0 +1,3 @@ +declare const binaryExtensionsJson: readonly string[]; + +export = binaryExtensionsJson; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.d.ts new file mode 100644 index 0000000..f469ac5 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.d.ts @@ -0,0 +1,14 @@ +/** +List of binary file extensions. + +@example +``` +import binaryExtensions = require('binary-extensions'); + +console.log(binaryExtensions); +//=> ['3ds', '3g2', …] +``` +*/ +declare const binaryExtensions: readonly string[]; + +export = binaryExtensions; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.js new file mode 100644 index 0000000..d46e468 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/index.js @@ -0,0 +1 @@ +module.exports = require('./binary-extensions.json'); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/license b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/license new file mode 100644 index 0000000..5493a1a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/license @@ -0,0 +1,10 @@ +MIT License + +Copyright (c) Sindre Sorhus (https://sindresorhus.com) +Copyright (c) Paul Miller (https://paulmillr.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/package.json new file mode 100644 index 0000000..4710c33 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/package.json @@ -0,0 +1,40 @@ +{ + "name": "binary-extensions", + "version": "2.3.0", + "description": "List of binary file extensions", + "license": "MIT", + "repository": "sindresorhus/binary-extensions", + "funding": "https://github.com/sponsors/sindresorhus", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "https://sindresorhus.com" + }, + "sideEffects": false, + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "xo && ava && tsd" + }, + "files": [ + "index.js", + "index.d.ts", + "binary-extensions.json", + "binary-extensions.json.d.ts" + ], + "keywords": [ + "binary", + "extensions", + "extension", + "file", + "json", + "list", + "array" + ], + "devDependencies": { + "ava": "^1.4.1", + "tsd": "^0.7.2", + "xo": "^0.24.0" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/readme.md new file mode 100644 index 0000000..88519b3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/binary-extensions/readme.md @@ -0,0 +1,25 @@ +# binary-extensions + +> List of binary file extensions + +The list is just a [JSON file](binary-extensions.json) and can be used anywhere. + +## Install + +```sh +npm install binary-extensions +``` + +## Usage + +```js +const binaryExtensions = require('binary-extensions'); + +console.log(binaryExtensions); +//=> ['3ds', '3g2', …] +``` + +## Related + +- [is-binary-path](https://github.com/sindresorhus/is-binary-path) - Check if a filepath is a binary file +- [text-extensions](https://github.com/sindresorhus/text-extensions) - List of text file extensions diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/HISTORY.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/HISTORY.md new file mode 100644 index 0000000..81d23e0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/HISTORY.md @@ -0,0 +1,672 @@ +1.20.3 / 2024-09-10 +=================== + + * deps: qs@6.13.0 + * add `depth` option to customize the depth level in the parser + * IMPORTANT: The default `depth` level for parsing URL-encoded data is now `32` (previously was `Infinity`) + +1.20.2 / 2023-02-21 +=================== + + * Fix strict json error message on Node.js 19+ + * deps: content-type@~1.0.5 + - perf: skip value escaping when unnecessary + * deps: raw-body@2.5.2 + +1.20.1 / 2022-10-06 +=================== + + * deps: qs@6.11.0 + * perf: remove unnecessary object clone + +1.20.0 / 2022-04-02 +=================== + + * Fix error message for json parse whitespace in `strict` + * Fix internal error when inflated body exceeds limit + * Prevent loss of async hooks context + * Prevent hanging when request already read + * deps: depd@2.0.0 + - Replace internal `eval` usage with `Function` constructor + - Use instance methods on `process` to check for listeners + * deps: http-errors@2.0.0 + - deps: depd@2.0.0 + - deps: statuses@2.0.1 + * deps: on-finished@2.4.1 + * deps: qs@6.10.3 + * deps: raw-body@2.5.1 + - deps: http-errors@2.0.0 + +1.19.2 / 2022-02-15 +=================== + + * deps: bytes@3.1.2 + * deps: qs@6.9.7 + * Fix handling of `__proto__` keys + * deps: raw-body@2.4.3 + - deps: bytes@3.1.2 + +1.19.1 / 2021-12-10 +=================== + + * deps: bytes@3.1.1 + * deps: http-errors@1.8.1 + - deps: inherits@2.0.4 + - deps: toidentifier@1.0.1 + - deps: setprototypeof@1.2.0 + * deps: qs@6.9.6 + * deps: raw-body@2.4.2 + - deps: bytes@3.1.1 + - deps: http-errors@1.8.1 + * deps: safe-buffer@5.2.1 + * deps: type-is@~1.6.18 + +1.19.0 / 2019-04-25 +=================== + + * deps: bytes@3.1.0 + - Add petabyte (`pb`) support + * deps: http-errors@1.7.2 + - Set constructor name when possible + - deps: setprototypeof@1.1.1 + - deps: statuses@'>= 1.5.0 < 2' + * deps: iconv-lite@0.4.24 + - Added encoding MIK + * deps: qs@6.7.0 + - Fix parsing array brackets after index + * deps: raw-body@2.4.0 + - deps: bytes@3.1.0 + - deps: http-errors@1.7.2 + - deps: iconv-lite@0.4.24 + * deps: type-is@~1.6.17 + - deps: mime-types@~2.1.24 + - perf: prevent internal `throw` on invalid type + +1.18.3 / 2018-05-14 +=================== + + * Fix stack trace for strict json parse error + * deps: depd@~1.1.2 + - perf: remove argument reassignment + * deps: http-errors@~1.6.3 + - deps: depd@~1.1.2 + - deps: setprototypeof@1.1.0 + - deps: statuses@'>= 1.3.1 < 2' + * deps: iconv-lite@0.4.23 + - Fix loading encoding with year appended + - Fix deprecation warnings on Node.js 10+ + * deps: qs@6.5.2 + * deps: raw-body@2.3.3 + - deps: http-errors@1.6.3 + - deps: iconv-lite@0.4.23 + * deps: type-is@~1.6.16 + - deps: mime-types@~2.1.18 + +1.18.2 / 2017-09-22 +=================== + + * deps: debug@2.6.9 + * perf: remove argument reassignment + +1.18.1 / 2017-09-12 +=================== + + * deps: content-type@~1.0.4 + - perf: remove argument reassignment + - perf: skip parameter parsing when no parameters + * deps: iconv-lite@0.4.19 + - Fix ISO-8859-1 regression + - Update Windows-1255 + * deps: qs@6.5.1 + - Fix parsing & compacting very deep objects + * deps: raw-body@2.3.2 + - deps: iconv-lite@0.4.19 + +1.18.0 / 2017-09-08 +=================== + + * Fix JSON strict violation error to match native parse error + * Include the `body` property on verify errors + * Include the `type` property on all generated errors + * Use `http-errors` to set status code on errors + * deps: bytes@3.0.0 + * deps: debug@2.6.8 + * deps: depd@~1.1.1 + - Remove unnecessary `Buffer` loading + * deps: http-errors@~1.6.2 + - deps: depd@1.1.1 + * deps: iconv-lite@0.4.18 + - Add support for React Native + - Add a warning if not loaded as utf-8 + - Fix CESU-8 decoding in Node.js 8 + - Improve speed of ISO-8859-1 encoding + * deps: qs@6.5.0 + * deps: raw-body@2.3.1 + - Use `http-errors` for standard emitted errors + - deps: bytes@3.0.0 + - deps: iconv-lite@0.4.18 + - perf: skip buffer decoding on overage chunk + * perf: prevent internal `throw` when missing charset + +1.17.2 / 2017-05-17 +=================== + + * deps: debug@2.6.7 + - Fix `DEBUG_MAX_ARRAY_LENGTH` + - deps: ms@2.0.0 + * deps: type-is@~1.6.15 + - deps: mime-types@~2.1.15 + +1.17.1 / 2017-03-06 +=================== + + * deps: qs@6.4.0 + - Fix regression parsing keys starting with `[` + +1.17.0 / 2017-03-01 +=================== + + * deps: http-errors@~1.6.1 + - Make `message` property enumerable for `HttpError`s + - deps: setprototypeof@1.0.3 + * deps: qs@6.3.1 + - Fix compacting nested arrays + +1.16.1 / 2017-02-10 +=================== + + * deps: debug@2.6.1 + - Fix deprecation messages in WebStorm and other editors + - Undeprecate `DEBUG_FD` set to `1` or `2` + +1.16.0 / 2017-01-17 +=================== + + * deps: debug@2.6.0 + - Allow colors in workers + - Deprecated `DEBUG_FD` environment variable + - Fix error when running under React Native + - Use same color for same namespace + - deps: ms@0.7.2 + * deps: http-errors@~1.5.1 + - deps: inherits@2.0.3 + - deps: setprototypeof@1.0.2 + - deps: statuses@'>= 1.3.1 < 2' + * deps: iconv-lite@0.4.15 + - Added encoding MS-31J + - Added encoding MS-932 + - Added encoding MS-936 + - Added encoding MS-949 + - Added encoding MS-950 + - Fix GBK/GB18030 handling of Euro character + * deps: qs@6.2.1 + - Fix array parsing from skipping empty values + * deps: raw-body@~2.2.0 + - deps: iconv-lite@0.4.15 + * deps: type-is@~1.6.14 + - deps: mime-types@~2.1.13 + +1.15.2 / 2016-06-19 +=================== + + * deps: bytes@2.4.0 + * deps: content-type@~1.0.2 + - perf: enable strict mode + * deps: http-errors@~1.5.0 + - Use `setprototypeof` module to replace `__proto__` setting + - deps: statuses@'>= 1.3.0 < 2' + - perf: enable strict mode + * deps: qs@6.2.0 + * deps: raw-body@~2.1.7 + - deps: bytes@2.4.0 + - perf: remove double-cleanup on happy path + * deps: type-is@~1.6.13 + - deps: mime-types@~2.1.11 + +1.15.1 / 2016-05-05 +=================== + + * deps: bytes@2.3.0 + - Drop partial bytes on all parsed units + - Fix parsing byte string that looks like hex + * deps: raw-body@~2.1.6 + - deps: bytes@2.3.0 + * deps: type-is@~1.6.12 + - deps: mime-types@~2.1.10 + +1.15.0 / 2016-02-10 +=================== + + * deps: http-errors@~1.4.0 + - Add `HttpError` export, for `err instanceof createError.HttpError` + - deps: inherits@2.0.1 + - deps: statuses@'>= 1.2.1 < 2' + * deps: qs@6.1.0 + * deps: type-is@~1.6.11 + - deps: mime-types@~2.1.9 + +1.14.2 / 2015-12-16 +=================== + + * deps: bytes@2.2.0 + * deps: iconv-lite@0.4.13 + * deps: qs@5.2.0 + * deps: raw-body@~2.1.5 + - deps: bytes@2.2.0 + - deps: iconv-lite@0.4.13 + * deps: type-is@~1.6.10 + - deps: mime-types@~2.1.8 + +1.14.1 / 2015-09-27 +=================== + + * Fix issue where invalid charset results in 400 when `verify` used + * deps: iconv-lite@0.4.12 + - Fix CESU-8 decoding in Node.js 4.x + * deps: raw-body@~2.1.4 + - Fix masking critical errors from `iconv-lite` + - deps: iconv-lite@0.4.12 + * deps: type-is@~1.6.9 + - deps: mime-types@~2.1.7 + +1.14.0 / 2015-09-16 +=================== + + * Fix JSON strict parse error to match syntax errors + * Provide static `require` analysis in `urlencoded` parser + * deps: depd@~1.1.0 + - Support web browser loading + * deps: qs@5.1.0 + * deps: raw-body@~2.1.3 + - Fix sync callback when attaching data listener causes sync read + * deps: type-is@~1.6.8 + - Fix type error when given invalid type to match against + - deps: mime-types@~2.1.6 + +1.13.3 / 2015-07-31 +=================== + + * deps: type-is@~1.6.6 + - deps: mime-types@~2.1.4 + +1.13.2 / 2015-07-05 +=================== + + * deps: iconv-lite@0.4.11 + * deps: qs@4.0.0 + - Fix dropping parameters like `hasOwnProperty` + - Fix user-visible incompatibilities from 3.1.0 + - Fix various parsing edge cases + * deps: raw-body@~2.1.2 + - Fix error stack traces to skip `makeError` + - deps: iconv-lite@0.4.11 + * deps: type-is@~1.6.4 + - deps: mime-types@~2.1.2 + - perf: enable strict mode + - perf: remove argument reassignment + +1.13.1 / 2015-06-16 +=================== + + * deps: qs@2.4.2 + - Downgraded from 3.1.0 because of user-visible incompatibilities + +1.13.0 / 2015-06-14 +=================== + + * Add `statusCode` property on `Error`s, in addition to `status` + * Change `type` default to `application/json` for JSON parser + * Change `type` default to `application/x-www-form-urlencoded` for urlencoded parser + * Provide static `require` analysis + * Use the `http-errors` module to generate errors + * deps: bytes@2.1.0 + - Slight optimizations + * deps: iconv-lite@0.4.10 + - The encoding UTF-16 without BOM now defaults to UTF-16LE when detection fails + - Leading BOM is now removed when decoding + * deps: on-finished@~2.3.0 + - Add defined behavior for HTTP `CONNECT` requests + - Add defined behavior for HTTP `Upgrade` requests + - deps: ee-first@1.1.1 + * deps: qs@3.1.0 + - Fix dropping parameters like `hasOwnProperty` + - Fix various parsing edge cases + - Parsed object now has `null` prototype + * deps: raw-body@~2.1.1 + - Use `unpipe` module for unpiping requests + - deps: iconv-lite@0.4.10 + * deps: type-is@~1.6.3 + - deps: mime-types@~2.1.1 + - perf: reduce try block size + - perf: remove bitwise operations + * perf: enable strict mode + * perf: remove argument reassignment + * perf: remove delete call + +1.12.4 / 2015-05-10 +=================== + + * deps: debug@~2.2.0 + * deps: qs@2.4.2 + - Fix allowing parameters like `constructor` + * deps: on-finished@~2.2.1 + * deps: raw-body@~2.0.1 + - Fix a false-positive when unpiping in Node.js 0.8 + - deps: bytes@2.0.1 + * deps: type-is@~1.6.2 + - deps: mime-types@~2.0.11 + +1.12.3 / 2015-04-15 +=================== + + * Slight efficiency improvement when not debugging + * deps: depd@~1.0.1 + * deps: iconv-lite@0.4.8 + - Add encoding alias UNICODE-1-1-UTF-7 + * deps: raw-body@1.3.4 + - Fix hanging callback if request aborts during read + - deps: iconv-lite@0.4.8 + +1.12.2 / 2015-03-16 +=================== + + * deps: qs@2.4.1 + - Fix error when parameter `hasOwnProperty` is present + +1.12.1 / 2015-03-15 +=================== + + * deps: debug@~2.1.3 + - Fix high intensity foreground color for bold + - deps: ms@0.7.0 + * deps: type-is@~1.6.1 + - deps: mime-types@~2.0.10 + +1.12.0 / 2015-02-13 +=================== + + * add `debug` messages + * accept a function for the `type` option + * use `content-type` to parse `Content-Type` headers + * deps: iconv-lite@0.4.7 + - Gracefully support enumerables on `Object.prototype` + * deps: raw-body@1.3.3 + - deps: iconv-lite@0.4.7 + * deps: type-is@~1.6.0 + - fix argument reassignment + - fix false-positives in `hasBody` `Transfer-Encoding` check + - support wildcard for both type and subtype (`*/*`) + - deps: mime-types@~2.0.9 + +1.11.0 / 2015-01-30 +=================== + + * make internal `extended: true` depth limit infinity + * deps: type-is@~1.5.6 + - deps: mime-types@~2.0.8 + +1.10.2 / 2015-01-20 +=================== + + * deps: iconv-lite@0.4.6 + - Fix rare aliases of single-byte encodings + * deps: raw-body@1.3.2 + - deps: iconv-lite@0.4.6 + +1.10.1 / 2015-01-01 +=================== + + * deps: on-finished@~2.2.0 + * deps: type-is@~1.5.5 + - deps: mime-types@~2.0.7 + +1.10.0 / 2014-12-02 +=================== + + * make internal `extended: true` array limit dynamic + +1.9.3 / 2014-11-21 +================== + + * deps: iconv-lite@0.4.5 + - Fix Windows-31J and X-SJIS encoding support + * deps: qs@2.3.3 + - Fix `arrayLimit` behavior + * deps: raw-body@1.3.1 + - deps: iconv-lite@0.4.5 + * deps: type-is@~1.5.3 + - deps: mime-types@~2.0.3 + +1.9.2 / 2014-10-27 +================== + + * deps: qs@2.3.2 + - Fix parsing of mixed objects and values + +1.9.1 / 2014-10-22 +================== + + * deps: on-finished@~2.1.1 + - Fix handling of pipelined requests + * deps: qs@2.3.0 + - Fix parsing of mixed implicit and explicit arrays + * deps: type-is@~1.5.2 + - deps: mime-types@~2.0.2 + +1.9.0 / 2014-09-24 +================== + + * include the charset in "unsupported charset" error message + * include the encoding in "unsupported content encoding" error message + * deps: depd@~1.0.0 + +1.8.4 / 2014-09-23 +================== + + * fix content encoding to be case-insensitive + +1.8.3 / 2014-09-19 +================== + + * deps: qs@2.2.4 + - Fix issue with object keys starting with numbers truncated + +1.8.2 / 2014-09-15 +================== + + * deps: depd@0.4.5 + +1.8.1 / 2014-09-07 +================== + + * deps: media-typer@0.3.0 + * deps: type-is@~1.5.1 + +1.8.0 / 2014-09-05 +================== + + * make empty-body-handling consistent between chunked requests + - empty `json` produces `{}` + - empty `raw` produces `new Buffer(0)` + - empty `text` produces `''` + - empty `urlencoded` produces `{}` + * deps: qs@2.2.3 + - Fix issue where first empty value in array is discarded + * deps: type-is@~1.5.0 + - fix `hasbody` to be true for `content-length: 0` + +1.7.0 / 2014-09-01 +================== + + * add `parameterLimit` option to `urlencoded` parser + * change `urlencoded` extended array limit to 100 + * respond with 413 when over `parameterLimit` in `urlencoded` + +1.6.7 / 2014-08-29 +================== + + * deps: qs@2.2.2 + - Remove unnecessary cloning + +1.6.6 / 2014-08-27 +================== + + * deps: qs@2.2.0 + - Array parsing fix + - Performance improvements + +1.6.5 / 2014-08-16 +================== + + * deps: on-finished@2.1.0 + +1.6.4 / 2014-08-14 +================== + + * deps: qs@1.2.2 + +1.6.3 / 2014-08-10 +================== + + * deps: qs@1.2.1 + +1.6.2 / 2014-08-07 +================== + + * deps: qs@1.2.0 + - Fix parsing array of objects + +1.6.1 / 2014-08-06 +================== + + * deps: qs@1.1.0 + - Accept urlencoded square brackets + - Accept empty values in implicit array notation + +1.6.0 / 2014-08-05 +================== + + * deps: qs@1.0.2 + - Complete rewrite + - Limits array length to 20 + - Limits object depth to 5 + - Limits parameters to 1,000 + +1.5.2 / 2014-07-27 +================== + + * deps: depd@0.4.4 + - Work-around v8 generating empty stack traces + +1.5.1 / 2014-07-26 +================== + + * deps: depd@0.4.3 + - Fix exception when global `Error.stackTraceLimit` is too low + +1.5.0 / 2014-07-20 +================== + + * deps: depd@0.4.2 + - Add `TRACE_DEPRECATION` environment variable + - Remove non-standard grey color from color output + - Support `--no-deprecation` argument + - Support `--trace-deprecation` argument + * deps: iconv-lite@0.4.4 + - Added encoding UTF-7 + * deps: raw-body@1.3.0 + - deps: iconv-lite@0.4.4 + - Added encoding UTF-7 + - Fix `Cannot switch to old mode now` error on Node.js 0.10+ + * deps: type-is@~1.3.2 + +1.4.3 / 2014-06-19 +================== + + * deps: type-is@1.3.1 + - fix global variable leak + +1.4.2 / 2014-06-19 +================== + + * deps: type-is@1.3.0 + - improve type parsing + +1.4.1 / 2014-06-19 +================== + + * fix urlencoded extended deprecation message + +1.4.0 / 2014-06-19 +================== + + * add `text` parser + * add `raw` parser + * check accepted charset in content-type (accepts utf-8) + * check accepted encoding in content-encoding (accepts identity) + * deprecate `bodyParser()` middleware; use `.json()` and `.urlencoded()` as needed + * deprecate `urlencoded()` without provided `extended` option + * lazy-load urlencoded parsers + * parsers split into files for reduced mem usage + * support gzip and deflate bodies + - set `inflate: false` to turn off + * deps: raw-body@1.2.2 + - Support all encodings from `iconv-lite` + +1.3.1 / 2014-06-11 +================== + + * deps: type-is@1.2.1 + - Switch dependency from mime to mime-types@1.0.0 + +1.3.0 / 2014-05-31 +================== + + * add `extended` option to urlencoded parser + +1.2.2 / 2014-05-27 +================== + + * deps: raw-body@1.1.6 + - assert stream encoding on node.js 0.8 + - assert stream encoding on node.js < 0.10.6 + - deps: bytes@1 + +1.2.1 / 2014-05-26 +================== + + * invoke `next(err)` after request fully read + - prevents hung responses and socket hang ups + +1.2.0 / 2014-05-11 +================== + + * add `verify` option + * deps: type-is@1.2.0 + - support suffix matching + +1.1.2 / 2014-05-11 +================== + + * improve json parser speed + +1.1.1 / 2014-05-11 +================== + + * fix repeated limit parsing with every request + +1.1.0 / 2014-05-10 +================== + + * add `type` option + * deps: pin for safety and consistency + +1.0.2 / 2014-04-14 +================== + + * use `type-is` module + +1.0.1 / 2014-03-20 +================== + + * lower default limits to 100kb diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/LICENSE new file mode 100644 index 0000000..386b7b6 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2014 Jonathan Ong +Copyright (c) 2014-2015 Douglas Christopher Wilson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/README.md new file mode 100644 index 0000000..f6661b7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/README.md @@ -0,0 +1,476 @@ +# body-parser + +[![NPM Version][npm-version-image]][npm-url] +[![NPM Downloads][npm-downloads-image]][npm-url] +[![Build Status][ci-image]][ci-url] +[![Test Coverage][coveralls-image]][coveralls-url] +[![OpenSSF Scorecard Badge][ossf-scorecard-badge]][ossf-scorecard-visualizer] + +Node.js body parsing middleware. + +Parse incoming request bodies in a middleware before your handlers, available +under the `req.body` property. + +**Note** As `req.body`'s shape is based on user-controlled input, all +properties and values in this object are untrusted and should be validated +before trusting. For example, `req.body.foo.toString()` may fail in multiple +ways, for example the `foo` property may not be there or may not be a string, +and `toString` may not be a function and instead a string or other user input. + +[Learn about the anatomy of an HTTP transaction in Node.js](https://nodejs.org/en/docs/guides/anatomy-of-an-http-transaction/). + +_This does not handle multipart bodies_, due to their complex and typically +large nature. For multipart bodies, you may be interested in the following +modules: + + * [busboy](https://www.npmjs.org/package/busboy#readme) and + [connect-busboy](https://www.npmjs.org/package/connect-busboy#readme) + * [multiparty](https://www.npmjs.org/package/multiparty#readme) and + [connect-multiparty](https://www.npmjs.org/package/connect-multiparty#readme) + * [formidable](https://www.npmjs.org/package/formidable#readme) + * [multer](https://www.npmjs.org/package/multer#readme) + +This module provides the following parsers: + + * [JSON body parser](#bodyparserjsonoptions) + * [Raw body parser](#bodyparserrawoptions) + * [Text body parser](#bodyparsertextoptions) + * [URL-encoded form body parser](#bodyparserurlencodedoptions) + +Other body parsers you might be interested in: + +- [body](https://www.npmjs.org/package/body#readme) +- [co-body](https://www.npmjs.org/package/co-body#readme) + +## Installation + +```sh +$ npm install body-parser +``` + +## API + +```js +var bodyParser = require('body-parser') +``` + +The `bodyParser` object exposes various factories to create middlewares. All +middlewares will populate the `req.body` property with the parsed body when +the `Content-Type` request header matches the `type` option, or an empty +object (`{}`) if there was no body to parse, the `Content-Type` was not matched, +or an error occurred. + +The various errors returned by this module are described in the +[errors section](#errors). + +### bodyParser.json([options]) + +Returns middleware that only parses `json` and only looks at requests where +the `Content-Type` header matches the `type` option. This parser accepts any +Unicode encoding of the body and supports automatic inflation of `gzip` and +`deflate` encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). + +#### Options + +The `json` function takes an optional `options` object that may contain any of +the following keys: + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### reviver + +The `reviver` option is passed directly to `JSON.parse` as the second +argument. You can find more information on this argument +[in the MDN documentation about JSON.parse](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse#Example.3A_Using_the_reviver_parameter). + +##### strict + +When set to `true`, will only accept arrays and objects; when `false` will +accept anything `JSON.parse` accepts. Defaults to `true`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a string, array of strings, or a function. If not a +function, `type` option is passed directly to the +[type-is](https://www.npmjs.org/package/type-is#readme) library and this can +be an extension name (like `json`), a mime type (like `application/json`), or +a mime type with a wildcard (like `*/*` or `*/json`). If a function, the `type` +option is called as `fn(req)` and the request is parsed if it returns a truthy +value. Defaults to `application/json`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.raw([options]) + +Returns middleware that parses all bodies as a `Buffer` and only looks at +requests where the `Content-Type` header matches the `type` option. This +parser supports automatic inflation of `gzip` and `deflate` encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This will be a `Buffer` object +of the body. + +#### Options + +The `raw` function takes an optional `options` object that may contain any of +the following keys: + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a string, array of strings, or a function. +If not a function, `type` option is passed directly to the +[type-is](https://www.npmjs.org/package/type-is#readme) library and this +can be an extension name (like `bin`), a mime type (like +`application/octet-stream`), or a mime type with a wildcard (like `*/*` or +`application/*`). If a function, the `type` option is called as `fn(req)` +and the request is parsed if it returns a truthy value. Defaults to +`application/octet-stream`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.text([options]) + +Returns middleware that parses all bodies as a string and only looks at +requests where the `Content-Type` header matches the `type` option. This +parser supports automatic inflation of `gzip` and `deflate` encodings. + +A new `body` string containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This will be a string of the +body. + +#### Options + +The `text` function takes an optional `options` object that may contain any of +the following keys: + +##### defaultCharset + +Specify the default character set for the text content if the charset is not +specified in the `Content-Type` header of the request. Defaults to `utf-8`. + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a string, array of strings, or a function. If not +a function, `type` option is passed directly to the +[type-is](https://www.npmjs.org/package/type-is#readme) library and this can +be an extension name (like `txt`), a mime type (like `text/plain`), or a mime +type with a wildcard (like `*/*` or `text/*`). If a function, the `type` +option is called as `fn(req)` and the request is parsed if it returns a +truthy value. Defaults to `text/plain`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +### bodyParser.urlencoded([options]) + +Returns middleware that only parses `urlencoded` bodies and only looks at +requests where the `Content-Type` header matches the `type` option. This +parser accepts only UTF-8 encoding of the body and supports automatic +inflation of `gzip` and `deflate` encodings. + +A new `body` object containing the parsed data is populated on the `request` +object after the middleware (i.e. `req.body`). This object will contain +key-value pairs, where the value can be a string or array (when `extended` is +`false`), or any type (when `extended` is `true`). + +#### Options + +The `urlencoded` function takes an optional `options` object that may contain +any of the following keys: + +##### extended + +The `extended` option allows to choose between parsing the URL-encoded data +with the `querystring` library (when `false`) or the `qs` library (when +`true`). The "extended" syntax allows for rich objects and arrays to be +encoded into the URL-encoded format, allowing for a JSON-like experience +with URL-encoded. For more information, please +[see the qs library](https://www.npmjs.org/package/qs#readme). + +Defaults to `true`, but using the default has been deprecated. Please +research into the difference between `qs` and `querystring` and choose the +appropriate setting. + +##### inflate + +When set to `true`, then deflated (compressed) bodies will be inflated; when +`false`, deflated bodies are rejected. Defaults to `true`. + +##### limit + +Controls the maximum request body size. If this is a number, then the value +specifies the number of bytes; if it is a string, the value is passed to the +[bytes](https://www.npmjs.com/package/bytes) library for parsing. Defaults +to `'100kb'`. + +##### parameterLimit + +The `parameterLimit` option controls the maximum number of parameters that +are allowed in the URL-encoded data. If a request contains more parameters +than this value, a 413 will be returned to the client. Defaults to `1000`. + +##### type + +The `type` option is used to determine what media type the middleware will +parse. This option can be a string, array of strings, or a function. If not +a function, `type` option is passed directly to the +[type-is](https://www.npmjs.org/package/type-is#readme) library and this can +be an extension name (like `urlencoded`), a mime type (like +`application/x-www-form-urlencoded`), or a mime type with a wildcard (like +`*/x-www-form-urlencoded`). If a function, the `type` option is called as +`fn(req)` and the request is parsed if it returns a truthy value. Defaults +to `application/x-www-form-urlencoded`. + +##### verify + +The `verify` option, if supplied, is called as `verify(req, res, buf, encoding)`, +where `buf` is a `Buffer` of the raw request body and `encoding` is the +encoding of the request. The parsing can be aborted by throwing an error. + +#### depth + +The `depth` option is used to configure the maximum depth of the `qs` library when `extended` is `true`. This allows you to limit the amount of keys that are parsed and can be useful to prevent certain types of abuse. Defaults to `32`. It is recommended to keep this value as low as possible. + +## Errors + +The middlewares provided by this module create errors using the +[`http-errors` module](https://www.npmjs.com/package/http-errors). The errors +will typically have a `status`/`statusCode` property that contains the suggested +HTTP response code, an `expose` property to determine if the `message` property +should be displayed to the client, a `type` property to determine the type of +error without matching against the `message`, and a `body` property containing +the read body, if available. + +The following are the common errors created, though any error can come through +for various reasons. + +### content encoding unsupported + +This error will occur when the request had a `Content-Encoding` header that +contained an encoding but the "inflation" option was set to `false`. The +`status` property is set to `415`, the `type` property is set to +`'encoding.unsupported'`, and the `charset` property will be set to the +encoding that is unsupported. + +### entity parse failed + +This error will occur when the request contained an entity that could not be +parsed by the middleware. The `status` property is set to `400`, the `type` +property is set to `'entity.parse.failed'`, and the `body` property is set to +the entity value that failed parsing. + +### entity verify failed + +This error will occur when the request contained an entity that could not be +failed verification by the defined `verify` option. The `status` property is +set to `403`, the `type` property is set to `'entity.verify.failed'`, and the +`body` property is set to the entity value that failed verification. + +### request aborted + +This error will occur when the request is aborted by the client before reading +the body has finished. The `received` property will be set to the number of +bytes received before the request was aborted and the `expected` property is +set to the number of expected bytes. The `status` property is set to `400` +and `type` property is set to `'request.aborted'`. + +### request entity too large + +This error will occur when the request body's size is larger than the "limit" +option. The `limit` property will be set to the byte limit and the `length` +property will be set to the request body's length. The `status` property is +set to `413` and the `type` property is set to `'entity.too.large'`. + +### request size did not match content length + +This error will occur when the request's length did not match the length from +the `Content-Length` header. This typically occurs when the request is malformed, +typically when the `Content-Length` header was calculated based on characters +instead of bytes. The `status` property is set to `400` and the `type` property +is set to `'request.size.invalid'`. + +### stream encoding should not be set + +This error will occur when something called the `req.setEncoding` method prior +to this middleware. This module operates directly on bytes only and you cannot +call `req.setEncoding` when using this module. The `status` property is set to +`500` and the `type` property is set to `'stream.encoding.set'`. + +### stream is not readable + +This error will occur when the request is no longer readable when this middleware +attempts to read it. This typically means something other than a middleware from +this module read the request body already and the middleware was also configured to +read the same request. The `status` property is set to `500` and the `type` +property is set to `'stream.not.readable'`. + +### too many parameters + +This error will occur when the content of the request exceeds the configured +`parameterLimit` for the `urlencoded` parser. The `status` property is set to +`413` and the `type` property is set to `'parameters.too.many'`. + +### unsupported charset "BOGUS" + +This error will occur when the request had a charset parameter in the +`Content-Type` header, but the `iconv-lite` module does not support it OR the +parser does not support it. The charset is contained in the message as well +as in the `charset` property. The `status` property is set to `415`, the +`type` property is set to `'charset.unsupported'`, and the `charset` property +is set to the charset that is unsupported. + +### unsupported content encoding "bogus" + +This error will occur when the request had a `Content-Encoding` header that +contained an unsupported encoding. The encoding is contained in the message +as well as in the `encoding` property. The `status` property is set to `415`, +the `type` property is set to `'encoding.unsupported'`, and the `encoding` +property is set to the encoding that is unsupported. + +### The input exceeded the depth + +This error occurs when using `bodyParser.urlencoded` with the `extended` property set to `true` and the input exceeds the configured `depth` option. The `status` property is set to `400`. It is recommended to review the `depth` option and evaluate if it requires a higher value. When the `depth` option is set to `32` (default value), the error will not be thrown. + +## Examples + +### Express/Connect top-level generic + +This example demonstrates adding a generic JSON and URL-encoded parser as a +top-level middleware, which will parse the bodies of all incoming requests. +This is the simplest setup. + +```js +var express = require('express') +var bodyParser = require('body-parser') + +var app = express() + +// parse application/x-www-form-urlencoded +app.use(bodyParser.urlencoded({ extended: false })) + +// parse application/json +app.use(bodyParser.json()) + +app.use(function (req, res) { + res.setHeader('Content-Type', 'text/plain') + res.write('you posted:\n') + res.end(JSON.stringify(req.body, null, 2)) +}) +``` + +### Express route-specific + +This example demonstrates adding body parsers specifically to the routes that +need them. In general, this is the most recommended way to use body-parser with +Express. + +```js +var express = require('express') +var bodyParser = require('body-parser') + +var app = express() + +// create application/json parser +var jsonParser = bodyParser.json() + +// create application/x-www-form-urlencoded parser +var urlencodedParser = bodyParser.urlencoded({ extended: false }) + +// POST /login gets urlencoded bodies +app.post('/login', urlencodedParser, function (req, res) { + res.send('welcome, ' + req.body.username) +}) + +// POST /api/users gets JSON bodies +app.post('/api/users', jsonParser, function (req, res) { + // create user in req.body +}) +``` + +### Change accepted type for parsers + +All the parsers accept a `type` option which allows you to change the +`Content-Type` that the middleware will parse. + +```js +var express = require('express') +var bodyParser = require('body-parser') + +var app = express() + +// parse various different custom JSON types as JSON +app.use(bodyParser.json({ type: 'application/*+json' })) + +// parse some custom thing into a Buffer +app.use(bodyParser.raw({ type: 'application/vnd.custom-type' })) + +// parse an HTML body into a string +app.use(bodyParser.text({ type: 'text/html' })) +``` + +## License + +[MIT](LICENSE) + +[ci-image]: https://badgen.net/github/checks/expressjs/body-parser/master?label=ci +[ci-url]: https://github.com/expressjs/body-parser/actions/workflows/ci.yml +[coveralls-image]: https://badgen.net/coveralls/c/github/expressjs/body-parser/master +[coveralls-url]: https://coveralls.io/r/expressjs/body-parser?branch=master +[node-version-image]: https://badgen.net/npm/node/body-parser +[node-version-url]: https://nodejs.org/en/download +[npm-downloads-image]: https://badgen.net/npm/dm/body-parser +[npm-url]: https://npmjs.org/package/body-parser +[npm-version-image]: https://badgen.net/npm/v/body-parser +[ossf-scorecard-badge]: https://api.scorecard.dev/projects/github.com/expressjs/body-parser/badge +[ossf-scorecard-visualizer]: https://ossf.github.io/scorecard-visualizer/#/projects/github.com/expressjs/body-parser \ No newline at end of file diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/SECURITY.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/SECURITY.md new file mode 100644 index 0000000..9694d42 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/SECURITY.md @@ -0,0 +1,25 @@ +# Security Policies and Procedures + +## Reporting a Bug + +The Express team and community take all security bugs seriously. Thank you +for improving the security of Express. We appreciate your efforts and +responsible disclosure and will make every effort to acknowledge your +contributions. + +Report security bugs by emailing the current owner(s) of `body-parser`. This +information can be found in the npm registry using the command +`npm owner ls body-parser`. +If unsure or unable to get the information from the above, open an issue +in the [project issue tracker](https://github.com/expressjs/body-parser/issues) +asking for the current contact information. + +To ensure the timely response to your report, please ensure that the entirety +of the report is contained within the email body and not solely behind a web +link or an attachment. + +At least one owner will acknowledge your email within 48 hours, and will send a +more detailed response within 48 hours indicating the next steps in handling +your report. After the initial reply to your report, the owners will +endeavor to keep you informed of the progress towards a fix and full +announcement, and may ask for additional information or guidance. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/index.js new file mode 100644 index 0000000..bb24d73 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/index.js @@ -0,0 +1,156 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var deprecate = require('depd')('body-parser') + +/** + * Cache of loaded parsers. + * @private + */ + +var parsers = Object.create(null) + +/** + * @typedef Parsers + * @type {function} + * @property {function} json + * @property {function} raw + * @property {function} text + * @property {function} urlencoded + */ + +/** + * Module exports. + * @type {Parsers} + */ + +exports = module.exports = deprecate.function(bodyParser, + 'bodyParser: use individual json/urlencoded middlewares') + +/** + * JSON parser. + * @public + */ + +Object.defineProperty(exports, 'json', { + configurable: true, + enumerable: true, + get: createParserGetter('json') +}) + +/** + * Raw parser. + * @public + */ + +Object.defineProperty(exports, 'raw', { + configurable: true, + enumerable: true, + get: createParserGetter('raw') +}) + +/** + * Text parser. + * @public + */ + +Object.defineProperty(exports, 'text', { + configurable: true, + enumerable: true, + get: createParserGetter('text') +}) + +/** + * URL-encoded parser. + * @public + */ + +Object.defineProperty(exports, 'urlencoded', { + configurable: true, + enumerable: true, + get: createParserGetter('urlencoded') +}) + +/** + * Create a middleware to parse json and urlencoded bodies. + * + * @param {object} [options] + * @return {function} + * @deprecated + * @public + */ + +function bodyParser (options) { + // use default type for parsers + var opts = Object.create(options || null, { + type: { + configurable: true, + enumerable: true, + value: undefined, + writable: true + } + }) + + var _urlencoded = exports.urlencoded(opts) + var _json = exports.json(opts) + + return function bodyParser (req, res, next) { + _json(req, res, function (err) { + if (err) return next(err) + _urlencoded(req, res, next) + }) + } +} + +/** + * Create a getter for loading a parser. + * @private + */ + +function createParserGetter (name) { + return function get () { + return loadParser(name) + } +} + +/** + * Load a parser module. + * @private + */ + +function loadParser (parserName) { + var parser = parsers[parserName] + + if (parser !== undefined) { + return parser + } + + // this uses a switch for static require analysis + switch (parserName) { + case 'json': + parser = require('./lib/types/json') + break + case 'raw': + parser = require('./lib/types/raw') + break + case 'text': + parser = require('./lib/types/text') + break + case 'urlencoded': + parser = require('./lib/types/urlencoded') + break + } + + // store to prevent invoking require() + return (parsers[parserName] = parser) +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/read.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/read.js new file mode 100644 index 0000000..fce6283 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/read.js @@ -0,0 +1,205 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var createError = require('http-errors') +var destroy = require('destroy') +var getBody = require('raw-body') +var iconv = require('iconv-lite') +var onFinished = require('on-finished') +var unpipe = require('unpipe') +var zlib = require('zlib') + +/** + * Module exports. + */ + +module.exports = read + +/** + * Read a request into a buffer and parse. + * + * @param {object} req + * @param {object} res + * @param {function} next + * @param {function} parse + * @param {function} debug + * @param {object} options + * @private + */ + +function read (req, res, next, parse, debug, options) { + var length + var opts = options + var stream + + // flag as parsed + req._body = true + + // read options + var encoding = opts.encoding !== null + ? opts.encoding + : null + var verify = opts.verify + + try { + // get the content stream + stream = contentstream(req, debug, opts.inflate) + length = stream.length + stream.length = undefined + } catch (err) { + return next(err) + } + + // set raw-body options + opts.length = length + opts.encoding = verify + ? null + : encoding + + // assert charset is supported + if (opts.encoding === null && encoding !== null && !iconv.encodingExists(encoding)) { + return next(createError(415, 'unsupported charset "' + encoding.toUpperCase() + '"', { + charset: encoding.toLowerCase(), + type: 'charset.unsupported' + })) + } + + // read body + debug('read body') + getBody(stream, opts, function (error, body) { + if (error) { + var _error + + if (error.type === 'encoding.unsupported') { + // echo back charset + _error = createError(415, 'unsupported charset "' + encoding.toUpperCase() + '"', { + charset: encoding.toLowerCase(), + type: 'charset.unsupported' + }) + } else { + // set status code on error + _error = createError(400, error) + } + + // unpipe from stream and destroy + if (stream !== req) { + unpipe(req) + destroy(stream, true) + } + + // read off entire request + dump(req, function onfinished () { + next(createError(400, _error)) + }) + return + } + + // verify + if (verify) { + try { + debug('verify body') + verify(req, res, body, encoding) + } catch (err) { + next(createError(403, err, { + body: body, + type: err.type || 'entity.verify.failed' + })) + return + } + } + + // parse + var str = body + try { + debug('parse body') + str = typeof body !== 'string' && encoding !== null + ? iconv.decode(body, encoding) + : body + req.body = parse(str) + } catch (err) { + next(createError(400, err, { + body: str, + type: err.type || 'entity.parse.failed' + })) + return + } + + next() + }) +} + +/** + * Get the content stream of the request. + * + * @param {object} req + * @param {function} debug + * @param {boolean} [inflate=true] + * @return {object} + * @api private + */ + +function contentstream (req, debug, inflate) { + var encoding = (req.headers['content-encoding'] || 'identity').toLowerCase() + var length = req.headers['content-length'] + var stream + + debug('content-encoding "%s"', encoding) + + if (inflate === false && encoding !== 'identity') { + throw createError(415, 'content encoding unsupported', { + encoding: encoding, + type: 'encoding.unsupported' + }) + } + + switch (encoding) { + case 'deflate': + stream = zlib.createInflate() + debug('inflate body') + req.pipe(stream) + break + case 'gzip': + stream = zlib.createGunzip() + debug('gunzip body') + req.pipe(stream) + break + case 'identity': + stream = req + stream.length = length + break + default: + throw createError(415, 'unsupported content encoding "' + encoding + '"', { + encoding: encoding, + type: 'encoding.unsupported' + }) + } + + return stream +} + +/** + * Dump the contents of a request. + * + * @param {object} req + * @param {function} callback + * @api private + */ + +function dump (req, callback) { + if (onFinished.isFinished(req)) { + callback(null) + } else { + onFinished(req, callback) + req.resume() + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/json.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/json.js new file mode 100644 index 0000000..59f3f7e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/json.js @@ -0,0 +1,247 @@ +/*! + * body-parser + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var createError = require('http-errors') +var debug = require('debug')('body-parser:json') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = json + +/** + * RegExp to match the first non-space in a string. + * + * Allowed whitespace is defined in RFC 7159: + * + * ws = *( + * %x20 / ; Space + * %x09 / ; Horizontal tab + * %x0A / ; Line feed or New line + * %x0D ) ; Carriage return + */ + +var FIRST_CHAR_REGEXP = /^[\x20\x09\x0a\x0d]*([^\x20\x09\x0a\x0d])/ // eslint-disable-line no-control-regex + +var JSON_SYNTAX_CHAR = '#' +var JSON_SYNTAX_REGEXP = /#+/g + +/** + * Create a middleware to parse JSON bodies. + * + * @param {object} [options] + * @return {function} + * @public + */ + +function json (options) { + var opts = options || {} + + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var inflate = opts.inflate !== false + var reviver = opts.reviver + var strict = opts.strict !== false + var type = opts.type || 'application/json' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (body) { + if (body.length === 0) { + // special-case empty json body, as it's a common client-side mistake + // TODO: maybe make this configurable or part of "strict" option + return {} + } + + if (strict) { + var first = firstchar(body) + + if (first !== '{' && first !== '[') { + debug('strict violation') + throw createStrictSyntaxError(body, first) + } + } + + try { + debug('parse json') + return JSON.parse(body, reviver) + } catch (e) { + throw normalizeJsonSyntaxError(e, { + message: e.message, + stack: e.stack + }) + } + } + + return function jsonParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // assert charset per RFC 7159 sec 8.1 + var charset = getCharset(req) || 'utf-8' + if (charset.slice(0, 4) !== 'utf-') { + debug('invalid charset') + next(createError(415, 'unsupported charset "' + charset.toUpperCase() + '"', { + charset: charset, + type: 'charset.unsupported' + })) + return + } + + // read + read(req, res, next, parse, debug, { + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Create strict violation syntax error matching native error. + * + * @param {string} str + * @param {string} char + * @return {Error} + * @private + */ + +function createStrictSyntaxError (str, char) { + var index = str.indexOf(char) + var partial = '' + + if (index !== -1) { + partial = str.substring(0, index) + JSON_SYNTAX_CHAR + + for (var i = index + 1; i < str.length; i++) { + partial += JSON_SYNTAX_CHAR + } + } + + try { + JSON.parse(partial); /* istanbul ignore next */ throw new SyntaxError('strict violation') + } catch (e) { + return normalizeJsonSyntaxError(e, { + message: e.message.replace(JSON_SYNTAX_REGEXP, function (placeholder) { + return str.substring(index, index + placeholder.length) + }), + stack: e.stack + }) + } +} + +/** + * Get the first non-whitespace character in a string. + * + * @param {string} str + * @return {function} + * @private + */ + +function firstchar (str) { + var match = FIRST_CHAR_REGEXP.exec(str) + + return match + ? match[1] + : undefined +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return (contentType.parse(req).parameters.charset || '').toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Normalize a SyntaxError for JSON.parse. + * + * @param {SyntaxError} error + * @param {object} obj + * @return {SyntaxError} + */ + +function normalizeJsonSyntaxError (error, obj) { + var keys = Object.getOwnPropertyNames(error) + + for (var i = 0; i < keys.length; i++) { + var key = keys[i] + if (key !== 'stack' && key !== 'message') { + delete error[key] + } + } + + // replace stack before message for Node.js 0.10 and below + error.stack = obj.stack.replace(error.message, obj.message) + error.message = obj.message + + return error +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/raw.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/raw.js new file mode 100644 index 0000000..f5d1b67 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/raw.js @@ -0,0 +1,101 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var bytes = require('bytes') +var debug = require('debug')('body-parser:raw') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = raw + +/** + * Create a middleware to parse raw bodies. + * + * @param {object} [options] + * @return {function} + * @api public + */ + +function raw (options) { + var opts = options || {} + + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'application/octet-stream' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (buf) { + return buf + } + + return function rawParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // read + read(req, res, next, parse, debug, { + encoding: null, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/text.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/text.js new file mode 100644 index 0000000..083a009 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/text.js @@ -0,0 +1,121 @@ +/*! + * body-parser + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var debug = require('debug')('body-parser:text') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = text + +/** + * Create a middleware to parse text bodies. + * + * @param {object} [options] + * @return {function} + * @api public + */ + +function text (options) { + var opts = options || {} + + var defaultCharset = opts.defaultCharset || 'utf-8' + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'text/plain' + var verify = opts.verify || false + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (buf) { + return buf + } + + return function textParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // get charset + var charset = getCharset(req) || defaultCharset + + // read + read(req, res, next, parse, debug, { + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify + }) + } +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return (contentType.parse(req).parameters.charset || '').toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/urlencoded.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/urlencoded.js new file mode 100644 index 0000000..2bd4485 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/lib/types/urlencoded.js @@ -0,0 +1,307 @@ +/*! + * body-parser + * Copyright(c) 2014 Jonathan Ong + * Copyright(c) 2014-2015 Douglas Christopher Wilson + * MIT Licensed + */ + +'use strict' + +/** + * Module dependencies. + * @private + */ + +var bytes = require('bytes') +var contentType = require('content-type') +var createError = require('http-errors') +var debug = require('debug')('body-parser:urlencoded') +var deprecate = require('depd')('body-parser') +var read = require('../read') +var typeis = require('type-is') + +/** + * Module exports. + */ + +module.exports = urlencoded + +/** + * Cache of parser modules. + */ + +var parsers = Object.create(null) + +/** + * Create a middleware to parse urlencoded bodies. + * + * @param {object} [options] + * @return {function} + * @public + */ + +function urlencoded (options) { + var opts = options || {} + + // notice because option default will flip in next major + if (opts.extended === undefined) { + deprecate('undefined extended: provide extended option') + } + + var extended = opts.extended !== false + var inflate = opts.inflate !== false + var limit = typeof opts.limit !== 'number' + ? bytes.parse(opts.limit || '100kb') + : opts.limit + var type = opts.type || 'application/x-www-form-urlencoded' + var verify = opts.verify || false + var depth = typeof opts.depth !== 'number' + ? Number(opts.depth || 32) + : opts.depth + + if (verify !== false && typeof verify !== 'function') { + throw new TypeError('option verify must be function') + } + + // create the appropriate query parser + var queryparse = extended + ? extendedparser(opts) + : simpleparser(opts) + + // create the appropriate type checking function + var shouldParse = typeof type !== 'function' + ? typeChecker(type) + : type + + function parse (body) { + return body.length + ? queryparse(body) + : {} + } + + return function urlencodedParser (req, res, next) { + if (req._body) { + debug('body already parsed') + next() + return + } + + req.body = req.body || {} + + // skip requests without bodies + if (!typeis.hasBody(req)) { + debug('skip empty body') + next() + return + } + + debug('content-type %j', req.headers['content-type']) + + // determine if request should be parsed + if (!shouldParse(req)) { + debug('skip parsing') + next() + return + } + + // assert charset + var charset = getCharset(req) || 'utf-8' + if (charset !== 'utf-8') { + debug('invalid charset') + next(createError(415, 'unsupported charset "' + charset.toUpperCase() + '"', { + charset: charset, + type: 'charset.unsupported' + })) + return + } + + // read + read(req, res, next, parse, debug, { + debug: debug, + encoding: charset, + inflate: inflate, + limit: limit, + verify: verify, + depth: depth + }) + } +} + +/** + * Get the extended query parser. + * + * @param {object} options + */ + +function extendedparser (options) { + var parameterLimit = options.parameterLimit !== undefined + ? options.parameterLimit + : 1000 + + var depth = typeof options.depth !== 'number' + ? Number(options.depth || 32) + : options.depth + var parse = parser('qs') + + if (isNaN(parameterLimit) || parameterLimit < 1) { + throw new TypeError('option parameterLimit must be a positive number') + } + + if (isNaN(depth) || depth < 0) { + throw new TypeError('option depth must be a zero or a positive number') + } + + if (isFinite(parameterLimit)) { + parameterLimit = parameterLimit | 0 + } + + return function queryparse (body) { + var paramCount = parameterCount(body, parameterLimit) + + if (paramCount === undefined) { + debug('too many parameters') + throw createError(413, 'too many parameters', { + type: 'parameters.too.many' + }) + } + + var arrayLimit = Math.max(100, paramCount) + + debug('parse extended urlencoding') + try { + return parse(body, { + allowPrototypes: true, + arrayLimit: arrayLimit, + depth: depth, + strictDepth: true, + parameterLimit: parameterLimit + }) + } catch (err) { + if (err instanceof RangeError) { + throw createError(400, 'The input exceeded the depth', { + type: 'querystring.parse.rangeError' + }) + } else { + throw err + } + } + } +} + +/** + * Get the charset of a request. + * + * @param {object} req + * @api private + */ + +function getCharset (req) { + try { + return (contentType.parse(req).parameters.charset || '').toLowerCase() + } catch (e) { + return undefined + } +} + +/** + * Count the number of parameters, stopping once limit reached + * + * @param {string} body + * @param {number} limit + * @api private + */ + +function parameterCount (body, limit) { + var count = 0 + var index = 0 + + while ((index = body.indexOf('&', index)) !== -1) { + count++ + index++ + + if (count === limit) { + return undefined + } + } + + return count +} + +/** + * Get parser for module name dynamically. + * + * @param {string} name + * @return {function} + * @api private + */ + +function parser (name) { + var mod = parsers[name] + + if (mod !== undefined) { + return mod.parse + } + + // this uses a switch for static require analysis + switch (name) { + case 'qs': + mod = require('qs') + break + case 'querystring': + mod = require('querystring') + break + } + + // store to prevent invoking require() + parsers[name] = mod + + return mod.parse +} + +/** + * Get the simple query parser. + * + * @param {object} options + */ + +function simpleparser (options) { + var parameterLimit = options.parameterLimit !== undefined + ? options.parameterLimit + : 1000 + var parse = parser('querystring') + + if (isNaN(parameterLimit) || parameterLimit < 1) { + throw new TypeError('option parameterLimit must be a positive number') + } + + if (isFinite(parameterLimit)) { + parameterLimit = parameterLimit | 0 + } + + return function queryparse (body) { + var paramCount = parameterCount(body, parameterLimit) + + if (paramCount === undefined) { + debug('too many parameters') + throw createError(413, 'too many parameters', { + type: 'parameters.too.many' + }) + } + + debug('parse urlencoding') + return parse(body, undefined, undefined, { maxKeys: parameterLimit }) + } +} + +/** + * Get the simple type checker. + * + * @param {string} type + * @return {function} + */ + +function typeChecker (type) { + return function checkType (req) { + return Boolean(typeis(req, type)) + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/package.json new file mode 100644 index 0000000..3c9926f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/body-parser/package.json @@ -0,0 +1,56 @@ +{ + "name": "body-parser", + "description": "Node.js body parsing middleware", + "version": "1.20.3", + "contributors": [ + "Douglas Christopher Wilson ", + "Jonathan Ong (http://jongleberry.com)" + ], + "license": "MIT", + "repository": "expressjs/body-parser", + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.5", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.13.0", + "raw-body": "2.5.2", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "devDependencies": { + "eslint": "8.34.0", + "eslint-config-standard": "14.1.1", + "eslint-plugin-import": "2.27.5", + "eslint-plugin-markdown": "3.0.0", + "eslint-plugin-node": "11.1.0", + "eslint-plugin-promise": "6.1.1", + "eslint-plugin-standard": "4.1.0", + "methods": "1.1.2", + "mocha": "10.2.0", + "nyc": "15.1.0", + "safe-buffer": "5.2.1", + "supertest": "6.3.3" + }, + "files": [ + "lib/", + "LICENSE", + "HISTORY.md", + "SECURITY.md", + "index.js" + ], + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + }, + "scripts": { + "lint": "eslint .", + "test": "mocha --require test/support/env --reporter spec --check-leaks --bail test/", + "test-ci": "nyc --reporter=lcov --reporter=text npm test", + "test-cov": "nyc --reporter=html --reporter=text npm test" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/LICENSE new file mode 100644 index 0000000..de32266 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2013 Julian Gruber + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/README.md new file mode 100644 index 0000000..6b4e0e1 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/README.md @@ -0,0 +1,129 @@ +# brace-expansion + +[Brace expansion](https://www.gnu.org/software/bash/manual/html_node/Brace-Expansion.html), +as known from sh/bash, in JavaScript. + +[![build status](https://secure.travis-ci.org/juliangruber/brace-expansion.svg)](http://travis-ci.org/juliangruber/brace-expansion) +[![downloads](https://img.shields.io/npm/dm/brace-expansion.svg)](https://www.npmjs.org/package/brace-expansion) +[![Greenkeeper badge](https://badges.greenkeeper.io/juliangruber/brace-expansion.svg)](https://greenkeeper.io/) + +[![testling badge](https://ci.testling.com/juliangruber/brace-expansion.png)](https://ci.testling.com/juliangruber/brace-expansion) + +## Example + +```js +var expand = require('brace-expansion'); + +expand('file-{a,b,c}.jpg') +// => ['file-a.jpg', 'file-b.jpg', 'file-c.jpg'] + +expand('-v{,,}') +// => ['-v', '-v', '-v'] + +expand('file{0..2}.jpg') +// => ['file0.jpg', 'file1.jpg', 'file2.jpg'] + +expand('file-{a..c}.jpg') +// => ['file-a.jpg', 'file-b.jpg', 'file-c.jpg'] + +expand('file{2..0}.jpg') +// => ['file2.jpg', 'file1.jpg', 'file0.jpg'] + +expand('file{0..4..2}.jpg') +// => ['file0.jpg', 'file2.jpg', 'file4.jpg'] + +expand('file-{a..e..2}.jpg') +// => ['file-a.jpg', 'file-c.jpg', 'file-e.jpg'] + +expand('file{00..10..5}.jpg') +// => ['file00.jpg', 'file05.jpg', 'file10.jpg'] + +expand('{{A..C},{a..c}}') +// => ['A', 'B', 'C', 'a', 'b', 'c'] + +expand('ppp{,config,oe{,conf}}') +// => ['ppp', 'pppconfig', 'pppoe', 'pppoeconf'] +``` + +## API + +```js +var expand = require('brace-expansion'); +``` + +### var expanded = expand(str) + +Return an array of all possible and valid expansions of `str`. If none are +found, `[str]` is returned. + +Valid expansions are: + +```js +/^(.*,)+(.+)?$/ +// {a,b,...} +``` + +A comma separated list of options, like `{a,b}` or `{a,{b,c}}` or `{,a,}`. + +```js +/^-?\d+\.\.-?\d+(\.\.-?\d+)?$/ +// {x..y[..incr]} +``` + +A numeric sequence from `x` to `y` inclusive, with optional increment. +If `x` or `y` start with a leading `0`, all the numbers will be padded +to have equal length. Negative numbers and backwards iteration work too. + +```js +/^-?\d+\.\.-?\d+(\.\.-?\d+)?$/ +// {x..y[..incr]} +``` + +An alphabetic sequence from `x` to `y` inclusive, with optional increment. +`x` and `y` must be exactly one character, and if given, `incr` must be a +number. + +For compatibility reasons, the string `${` is not eligible for brace expansion. + +## Installation + +With [npm](https://npmjs.org) do: + +```bash +npm install brace-expansion +``` + +## Contributors + +- [Julian Gruber](https://github.com/juliangruber) +- [Isaac Z. Schlueter](https://github.com/isaacs) + +## Sponsors + +This module is proudly supported by my [Sponsors](https://github.com/juliangruber/sponsors)! + +Do you want to support modules like this to improve their quality, stability and weigh in on new features? Then please consider donating to my [Patreon](https://www.patreon.com/juliangruber). Not sure how much of my modules you're using? Try [feross/thanks](https://github.com/feross/thanks)! + +## License + +(MIT) + +Copyright (c) 2013 Julian Gruber <julian@juliangruber.com> + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/index.js new file mode 100644 index 0000000..0478be8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/index.js @@ -0,0 +1,201 @@ +var concatMap = require('concat-map'); +var balanced = require('balanced-match'); + +module.exports = expandTop; + +var escSlash = '\0SLASH'+Math.random()+'\0'; +var escOpen = '\0OPEN'+Math.random()+'\0'; +var escClose = '\0CLOSE'+Math.random()+'\0'; +var escComma = '\0COMMA'+Math.random()+'\0'; +var escPeriod = '\0PERIOD'+Math.random()+'\0'; + +function numeric(str) { + return parseInt(str, 10) == str + ? parseInt(str, 10) + : str.charCodeAt(0); +} + +function escapeBraces(str) { + return str.split('\\\\').join(escSlash) + .split('\\{').join(escOpen) + .split('\\}').join(escClose) + .split('\\,').join(escComma) + .split('\\.').join(escPeriod); +} + +function unescapeBraces(str) { + return str.split(escSlash).join('\\') + .split(escOpen).join('{') + .split(escClose).join('}') + .split(escComma).join(',') + .split(escPeriod).join('.'); +} + + +// Basically just str.split(","), but handling cases +// where we have nested braced sections, which should be +// treated as individual members, like {a,{b,c},d} +function parseCommaParts(str) { + if (!str) + return ['']; + + var parts = []; + var m = balanced('{', '}', str); + + if (!m) + return str.split(','); + + var pre = m.pre; + var body = m.body; + var post = m.post; + var p = pre.split(','); + + p[p.length-1] += '{' + body + '}'; + var postParts = parseCommaParts(post); + if (post.length) { + p[p.length-1] += postParts.shift(); + p.push.apply(p, postParts); + } + + parts.push.apply(parts, p); + + return parts; +} + +function expandTop(str) { + if (!str) + return []; + + // I don't know why Bash 4.3 does this, but it does. + // Anything starting with {} will have the first two bytes preserved + // but *only* at the top level, so {},a}b will not expand to anything, + // but a{},b}c will be expanded to [a}c,abc]. + // One could argue that this is a bug in Bash, but since the goal of + // this module is to match Bash's rules, we escape a leading {} + if (str.substr(0, 2) === '{}') { + str = '\\{\\}' + str.substr(2); + } + + return expand(escapeBraces(str), true).map(unescapeBraces); +} + +function identity(e) { + return e; +} + +function embrace(str) { + return '{' + str + '}'; +} +function isPadded(el) { + return /^-?0\d/.test(el); +} + +function lte(i, y) { + return i <= y; +} +function gte(i, y) { + return i >= y; +} + +function expand(str, isTop) { + var expansions = []; + + var m = balanced('{', '}', str); + if (!m || /\$$/.test(m.pre)) return [str]; + + var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body); + var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body); + var isSequence = isNumericSequence || isAlphaSequence; + var isOptions = m.body.indexOf(',') >= 0; + if (!isSequence && !isOptions) { + // {a},b} + if (m.post.match(/,.*\}/)) { + str = m.pre + '{' + m.body + escClose + m.post; + return expand(str); + } + return [str]; + } + + var n; + if (isSequence) { + n = m.body.split(/\.\./); + } else { + n = parseCommaParts(m.body); + if (n.length === 1) { + // x{{a,b}}y ==> x{a}y x{b}y + n = expand(n[0], false).map(embrace); + if (n.length === 1) { + var post = m.post.length + ? expand(m.post, false) + : ['']; + return post.map(function(p) { + return m.pre + n[0] + p; + }); + } + } + } + + // at this point, n is the parts, and we know it's not a comma set + // with a single entry. + + // no need to expand pre, since it is guaranteed to be free of brace-sets + var pre = m.pre; + var post = m.post.length + ? expand(m.post, false) + : ['']; + + var N; + + if (isSequence) { + var x = numeric(n[0]); + var y = numeric(n[1]); + var width = Math.max(n[0].length, n[1].length) + var incr = n.length == 3 + ? Math.abs(numeric(n[2])) + : 1; + var test = lte; + var reverse = y < x; + if (reverse) { + incr *= -1; + test = gte; + } + var pad = n.some(isPadded); + + N = []; + + for (var i = x; test(i, y); i += incr) { + var c; + if (isAlphaSequence) { + c = String.fromCharCode(i); + if (c === '\\') + c = ''; + } else { + c = String(i); + if (pad) { + var need = width - c.length; + if (need > 0) { + var z = new Array(need + 1).join('0'); + if (i < 0) + c = '-' + z + c.slice(1); + else + c = z + c; + } + } + } + N.push(c); + } + } else { + N = concatMap(n, function(el) { return expand(el, false) }); + } + + for (var j = 0; j < N.length; j++) { + for (var k = 0; k < post.length; k++) { + var expansion = pre + N[j] + post[k]; + if (!isTop || isSequence || expansion) + expansions.push(expansion); + } + } + + return expansions; +} + diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/package.json new file mode 100644 index 0000000..a18faa8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/brace-expansion/package.json @@ -0,0 +1,47 @@ +{ + "name": "brace-expansion", + "description": "Brace expansion as known from sh/bash", + "version": "1.1.11", + "repository": { + "type": "git", + "url": "git://github.com/juliangruber/brace-expansion.git" + }, + "homepage": "https://github.com/juliangruber/brace-expansion", + "main": "index.js", + "scripts": { + "test": "tape test/*.js", + "gentest": "bash test/generate.sh", + "bench": "matcha test/perf/bench.js" + }, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + }, + "devDependencies": { + "matcha": "^0.7.0", + "tape": "^4.6.0" + }, + "keywords": [], + "author": { + "name": "Julian Gruber", + "email": "mail@juliangruber.com", + "url": "http://juliangruber.com" + }, + "license": "MIT", + "testling": { + "files": "test/*.js", + "browsers": [ + "ie/8..latest", + "firefox/20..latest", + "firefox/nightly", + "chrome/25..latest", + "chrome/canary", + "opera/12..latest", + "opera/next", + "safari/5.1..latest", + "ipad/6.0..latest", + "iphone/6.0..latest", + "android-browser/4.2..latest" + ] + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/LICENSE new file mode 100644 index 0000000..9af4a67 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-present, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/README.md new file mode 100644 index 0000000..f59dd60 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/README.md @@ -0,0 +1,586 @@ +# braces [![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=W8YFZ425KND68) [![NPM version](https://img.shields.io/npm/v/braces.svg?style=flat)](https://www.npmjs.com/package/braces) [![NPM monthly downloads](https://img.shields.io/npm/dm/braces.svg?style=flat)](https://npmjs.org/package/braces) [![NPM total downloads](https://img.shields.io/npm/dt/braces.svg?style=flat)](https://npmjs.org/package/braces) [![Linux Build Status](https://img.shields.io/travis/micromatch/braces.svg?style=flat&label=Travis)](https://travis-ci.org/micromatch/braces) + +> Bash-like brace expansion, implemented in JavaScript. Safer than other brace expansion libs, with complete support for the Bash 4.3 braces specification, without sacrificing speed. + +Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +$ npm install --save braces +``` + +## v3.0.0 Released!! + +See the [changelog](CHANGELOG.md) for details. + +## Why use braces? + +Brace patterns make globs more powerful by adding the ability to match specific ranges and sequences of characters. + +- **Accurate** - complete support for the [Bash 4.3 Brace Expansion](www.gnu.org/software/bash/) specification (passes all of the Bash braces tests) +- **[fast and performant](#benchmarks)** - Starts fast, runs fast and [scales well](#performance) as patterns increase in complexity. +- **Organized code base** - The parser and compiler are easy to maintain and update when edge cases crop up. +- **Well-tested** - Thousands of test assertions, and passes all of the Bash, minimatch, and [brace-expansion](https://github.com/juliangruber/brace-expansion) unit tests (as of the date this was written). +- **Safer** - You shouldn't have to worry about users defining aggressive or malicious brace patterns that can break your application. Braces takes measures to prevent malicious regex that can be used for DDoS attacks (see [catastrophic backtracking](https://www.regular-expressions.info/catastrophic.html)). +- [Supports lists](#lists) - (aka "sets") `a/{b,c}/d` => `['a/b/d', 'a/c/d']` +- [Supports sequences](#sequences) - (aka "ranges") `{01..03}` => `['01', '02', '03']` +- [Supports steps](#steps) - (aka "increments") `{2..10..2}` => `['2', '4', '6', '8', '10']` +- [Supports escaping](#escaping) - To prevent evaluation of special characters. + +## Usage + +The main export is a function that takes one or more brace `patterns` and `options`. + +```js +const braces = require('braces'); +// braces(patterns[, options]); + +console.log(braces(['{01..05}', '{a..e}'])); +//=> ['(0[1-5])', '([a-e])'] + +console.log(braces(['{01..05}', '{a..e}'], { expand: true })); +//=> ['01', '02', '03', '04', '05', 'a', 'b', 'c', 'd', 'e'] +``` + +### Brace Expansion vs. Compilation + +By default, brace patterns are compiled into strings that are optimized for creating regular expressions and matching. + +**Compiled** + +```js +console.log(braces('a/{x,y,z}/b')); +//=> ['a/(x|y|z)/b'] +console.log(braces(['a/{01..20}/b', 'a/{1..5}/b'])); +//=> [ 'a/(0[1-9]|1[0-9]|20)/b', 'a/([1-5])/b' ] +``` + +**Expanded** + +Enable brace expansion by setting the `expand` option to true, or by using [braces.expand()](#expand) (returns an array similar to what you'd expect from Bash, or `echo {1..5}`, or [minimatch](https://github.com/isaacs/minimatch)): + +```js +console.log(braces('a/{x,y,z}/b', { expand: true })); +//=> ['a/x/b', 'a/y/b', 'a/z/b'] + +console.log(braces.expand('{01..10}')); +//=> ['01','02','03','04','05','06','07','08','09','10'] +``` + +### Lists + +Expand lists (like Bash "sets"): + +```js +console.log(braces('a/{foo,bar,baz}/*.js')); +//=> ['a/(foo|bar|baz)/*.js'] + +console.log(braces.expand('a/{foo,bar,baz}/*.js')); +//=> ['a/foo/*.js', 'a/bar/*.js', 'a/baz/*.js'] +``` + +### Sequences + +Expand ranges of characters (like Bash "sequences"): + +```js +console.log(braces.expand('{1..3}')); // ['1', '2', '3'] +console.log(braces.expand('a/{1..3}/b')); // ['a/1/b', 'a/2/b', 'a/3/b'] +console.log(braces('{a..c}', { expand: true })); // ['a', 'b', 'c'] +console.log(braces('foo/{a..c}', { expand: true })); // ['foo/a', 'foo/b', 'foo/c'] + +// supports zero-padded ranges +console.log(braces('a/{01..03}/b')); //=> ['a/(0[1-3])/b'] +console.log(braces('a/{001..300}/b')); //=> ['a/(0{2}[1-9]|0[1-9][0-9]|[12][0-9]{2}|300)/b'] +``` + +See [fill-range](https://github.com/jonschlinkert/fill-range) for all available range-expansion options. + +### Steppped ranges + +Steps, or increments, may be used with ranges: + +```js +console.log(braces.expand('{2..10..2}')); +//=> ['2', '4', '6', '8', '10'] + +console.log(braces('{2..10..2}')); +//=> ['(2|4|6|8|10)'] +``` + +When the [.optimize](#optimize) method is used, or [options.optimize](#optionsoptimize) is set to true, sequences are passed to [to-regex-range](https://github.com/jonschlinkert/to-regex-range) for expansion. + +### Nesting + +Brace patterns may be nested. The results of each expanded string are not sorted, and left to right order is preserved. + +**"Expanded" braces** + +```js +console.log(braces.expand('a{b,c,/{x,y}}/e')); +//=> ['ab/e', 'ac/e', 'a/x/e', 'a/y/e'] + +console.log(braces.expand('a/{x,{1..5},y}/c')); +//=> ['a/x/c', 'a/1/c', 'a/2/c', 'a/3/c', 'a/4/c', 'a/5/c', 'a/y/c'] +``` + +**"Optimized" braces** + +```js +console.log(braces('a{b,c,/{x,y}}/e')); +//=> ['a(b|c|/(x|y))/e'] + +console.log(braces('a/{x,{1..5},y}/c')); +//=> ['a/(x|([1-5])|y)/c'] +``` + +### Escaping + +**Escaping braces** + +A brace pattern will not be expanded or evaluted if _either the opening or closing brace is escaped_: + +```js +console.log(braces.expand('a\\{d,c,b}e')); +//=> ['a{d,c,b}e'] + +console.log(braces.expand('a{d,c,b\\}e')); +//=> ['a{d,c,b}e'] +``` + +**Escaping commas** + +Commas inside braces may also be escaped: + +```js +console.log(braces.expand('a{b\\,c}d')); +//=> ['a{b,c}d'] + +console.log(braces.expand('a{d\\,c,b}e')); +//=> ['ad,ce', 'abe'] +``` + +**Single items** + +Following bash conventions, a brace pattern is also not expanded when it contains a single character: + +```js +console.log(braces.expand('a{b}c')); +//=> ['a{b}c'] +``` + +## Options + +### options.maxLength + +**Type**: `Number` + +**Default**: `10,000` + +**Description**: Limit the length of the input string. Useful when the input string is generated or your application allows users to pass a string, et cetera. + +```js +console.log(braces('a/{b,c}/d', { maxLength: 3 })); //=> throws an error +``` + +### options.expand + +**Type**: `Boolean` + +**Default**: `undefined` + +**Description**: Generate an "expanded" brace pattern (alternatively you can use the `braces.expand()` method, which does the same thing). + +```js +console.log(braces('a/{b,c}/d', { expand: true })); +//=> [ 'a/b/d', 'a/c/d' ] +``` + +### options.nodupes + +**Type**: `Boolean` + +**Default**: `undefined` + +**Description**: Remove duplicates from the returned array. + +### options.rangeLimit + +**Type**: `Number` + +**Default**: `1000` + +**Description**: To prevent malicious patterns from being passed by users, an error is thrown when `braces.expand()` is used or `options.expand` is true and the generated range will exceed the `rangeLimit`. + +You can customize `options.rangeLimit` or set it to `Inifinity` to disable this altogether. + +**Examples** + +```js +// pattern exceeds the "rangeLimit", so it's optimized automatically +console.log(braces.expand('{1..1000}')); +//=> ['([1-9]|[1-9][0-9]{1,2}|1000)'] + +// pattern does not exceed "rangeLimit", so it's NOT optimized +console.log(braces.expand('{1..100}')); +//=> ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34', '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46', '47', '48', '49', '50', '51', '52', '53', '54', '55', '56', '57', '58', '59', '60', '61', '62', '63', '64', '65', '66', '67', '68', '69', '70', '71', '72', '73', '74', '75', '76', '77', '78', '79', '80', '81', '82', '83', '84', '85', '86', '87', '88', '89', '90', '91', '92', '93', '94', '95', '96', '97', '98', '99', '100'] +``` + +### options.transform + +**Type**: `Function` + +**Default**: `undefined` + +**Description**: Customize range expansion. + +**Example: Transforming non-numeric values** + +```js +const alpha = braces.expand('x/{a..e}/y', { + transform(value, index) { + // When non-numeric values are passed, "value" is a character code. + return 'foo/' + String.fromCharCode(value) + '-' + index; + }, +}); +console.log(alpha); +//=> [ 'x/foo/a-0/y', 'x/foo/b-1/y', 'x/foo/c-2/y', 'x/foo/d-3/y', 'x/foo/e-4/y' ] +``` + +**Example: Transforming numeric values** + +```js +const numeric = braces.expand('{1..5}', { + transform(value) { + // when numeric values are passed, "value" is a number + return 'foo/' + value * 2; + }, +}); +console.log(numeric); +//=> [ 'foo/2', 'foo/4', 'foo/6', 'foo/8', 'foo/10' ] +``` + +### options.quantifiers + +**Type**: `Boolean` + +**Default**: `undefined` + +**Description**: In regular expressions, quanitifiers can be used to specify how many times a token can be repeated. For example, `a{1,3}` will match the letter `a` one to three times. + +Unfortunately, regex quantifiers happen to share the same syntax as [Bash lists](#lists) + +The `quantifiers` option tells braces to detect when [regex quantifiers](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#quantifiers) are defined in the given pattern, and not to try to expand them as lists. + +**Examples** + +```js +const braces = require('braces'); +console.log(braces('a/b{1,3}/{x,y,z}')); +//=> [ 'a/b(1|3)/(x|y|z)' ] +console.log(braces('a/b{1,3}/{x,y,z}', { quantifiers: true })); +//=> [ 'a/b{1,3}/(x|y|z)' ] +console.log(braces('a/b{1,3}/{x,y,z}', { quantifiers: true, expand: true })); +//=> [ 'a/b{1,3}/x', 'a/b{1,3}/y', 'a/b{1,3}/z' ] +``` + +### options.keepEscaping + +**Type**: `Boolean` + +**Default**: `undefined` + +**Description**: Do not strip backslashes that were used for escaping from the result. + +## What is "brace expansion"? + +Brace expansion is a type of parameter expansion that was made popular by unix shells for generating lists of strings, as well as regex-like matching when used alongside wildcards (globs). + +In addition to "expansion", braces are also used for matching. In other words: + +- [brace expansion](#brace-expansion) is for generating new lists +- [brace matching](#brace-matching) is for filtering existing lists + +
+More about brace expansion (click to expand) + +There are two main types of brace expansion: + +1. **lists**: which are defined using comma-separated values inside curly braces: `{a,b,c}` +2. **sequences**: which are defined using a starting value and an ending value, separated by two dots: `a{1..3}b`. Optionally, a third argument may be passed to define a "step" or increment to use: `a{1..100..10}b`. These are also sometimes referred to as "ranges". + +Here are some example brace patterns to illustrate how they work: + +**Sets** + +``` +{a,b,c} => a b c +{a,b,c}{1,2} => a1 a2 b1 b2 c1 c2 +``` + +**Sequences** + +``` +{1..9} => 1 2 3 4 5 6 7 8 9 +{4..-4} => 4 3 2 1 0 -1 -2 -3 -4 +{1..20..3} => 1 4 7 10 13 16 19 +{a..j} => a b c d e f g h i j +{j..a} => j i h g f e d c b a +{a..z..3} => a d g j m p s v y +``` + +**Combination** + +Sets and sequences can be mixed together or used along with any other strings. + +``` +{a,b,c}{1..3} => a1 a2 a3 b1 b2 b3 c1 c2 c3 +foo/{a,b,c}/bar => foo/a/bar foo/b/bar foo/c/bar +``` + +The fact that braces can be "expanded" from relatively simple patterns makes them ideal for quickly generating test fixtures, file paths, and similar use cases. + +## Brace matching + +In addition to _expansion_, brace patterns are also useful for performing regular-expression-like matching. + +For example, the pattern `foo/{1..3}/bar` would match any of following strings: + +``` +foo/1/bar +foo/2/bar +foo/3/bar +``` + +But not: + +``` +baz/1/qux +baz/2/qux +baz/3/qux +``` + +Braces can also be combined with [glob patterns](https://github.com/jonschlinkert/micromatch) to perform more advanced wildcard matching. For example, the pattern `*/{1..3}/*` would match any of following strings: + +``` +foo/1/bar +foo/2/bar +foo/3/bar +baz/1/qux +baz/2/qux +baz/3/qux +``` + +## Brace matching pitfalls + +Although brace patterns offer a user-friendly way of matching ranges or sets of strings, there are also some major disadvantages and potential risks you should be aware of. + +### tldr + +**"brace bombs"** + +- brace expansion can eat up a huge amount of processing resources +- as brace patterns increase _linearly in size_, the system resources required to expand the pattern increase exponentially +- users can accidentally (or intentially) exhaust your system's resources resulting in the equivalent of a DoS attack (bonus: no programming knowledge is required!) + +For a more detailed explanation with examples, see the [geometric complexity](#geometric-complexity) section. + +### The solution + +Jump to the [performance section](#performance) to see how Braces solves this problem in comparison to other libraries. + +### Geometric complexity + +At minimum, brace patterns with sets limited to two elements have quadradic or `O(n^2)` complexity. But the complexity of the algorithm increases exponentially as the number of sets, _and elements per set_, increases, which is `O(n^c)`. + +For example, the following sets demonstrate quadratic (`O(n^2)`) complexity: + +``` +{1,2}{3,4} => (2X2) => 13 14 23 24 +{1,2}{3,4}{5,6} => (2X2X2) => 135 136 145 146 235 236 245 246 +``` + +But add an element to a set, and we get a n-fold Cartesian product with `O(n^c)` complexity: + +``` +{1,2,3}{4,5,6}{7,8,9} => (3X3X3) => 147 148 149 157 158 159 167 168 169 247 248 + 249 257 258 259 267 268 269 347 348 349 357 + 358 359 367 368 369 +``` + +Now, imagine how this complexity grows given that each element is a n-tuple: + +``` +{1..100}{1..100} => (100X100) => 10,000 elements (38.4 kB) +{1..100}{1..100}{1..100} => (100X100X100) => 1,000,000 elements (5.76 MB) +``` + +Although these examples are clearly contrived, they demonstrate how brace patterns can quickly grow out of control. + +**More information** + +Interested in learning more about brace expansion? + +- [linuxjournal/bash-brace-expansion](http://www.linuxjournal.com/content/bash-brace-expansion) +- [rosettacode/Brace_expansion](https://rosettacode.org/wiki/Brace_expansion) +- [cartesian product](https://en.wikipedia.org/wiki/Cartesian_product) + +
+ +## Performance + +Braces is not only screaming fast, it's also more accurate the other brace expansion libraries. + +### Better algorithms + +Fortunately there is a solution to the ["brace bomb" problem](#brace-matching-pitfalls): _don't expand brace patterns into an array when they're used for matching_. + +Instead, convert the pattern into an optimized regular expression. This is easier said than done, and braces is the only library that does this currently. + +**The proof is in the numbers** + +Minimatch gets exponentially slower as patterns increase in complexity, braces does not. The following results were generated using `braces()` and `minimatch.braceExpand()`, respectively. + +| **Pattern** | **braces** | **[minimatch][]** | +| --------------------------- | ------------------- | ---------------------------- | +| `{1..9007199254740991}`[^1] | `298 B` (5ms 459μs) | N/A (freezes) | +| `{1..1000000000000000}` | `41 B` (1ms 15μs) | N/A (freezes) | +| `{1..100000000000000}` | `40 B` (890μs) | N/A (freezes) | +| `{1..10000000000000}` | `39 B` (2ms 49μs) | N/A (freezes) | +| `{1..1000000000000}` | `38 B` (608μs) | N/A (freezes) | +| `{1..100000000000}` | `37 B` (397μs) | N/A (freezes) | +| `{1..10000000000}` | `35 B` (983μs) | N/A (freezes) | +| `{1..1000000000}` | `34 B` (798μs) | N/A (freezes) | +| `{1..100000000}` | `33 B` (733μs) | N/A (freezes) | +| `{1..10000000}` | `32 B` (5ms 632μs) | `78.89 MB` (16s 388ms 569μs) | +| `{1..1000000}` | `31 B` (1ms 381μs) | `6.89 MB` (1s 496ms 887μs) | +| `{1..100000}` | `30 B` (950μs) | `588.89 kB` (146ms 921μs) | +| `{1..10000}` | `29 B` (1ms 114μs) | `48.89 kB` (14ms 187μs) | +| `{1..1000}` | `28 B` (760μs) | `3.89 kB` (1ms 453μs) | +| `{1..100}` | `22 B` (345μs) | `291 B` (196μs) | +| `{1..10}` | `10 B` (533μs) | `20 B` (37μs) | +| `{1..3}` | `7 B` (190μs) | `5 B` (27μs) | + +### Faster algorithms + +When you need expansion, braces is still much faster. + +_(the following results were generated using `braces.expand()` and `minimatch.braceExpand()`, respectively)_ + +| **Pattern** | **braces** | **[minimatch][]** | +| --------------- | --------------------------- | ---------------------------- | +| `{1..10000000}` | `78.89 MB` (2s 698ms 642μs) | `78.89 MB` (18s 601ms 974μs) | +| `{1..1000000}` | `6.89 MB` (458ms 576μs) | `6.89 MB` (1s 491ms 621μs) | +| `{1..100000}` | `588.89 kB` (20ms 728μs) | `588.89 kB` (156ms 919μs) | +| `{1..10000}` | `48.89 kB` (2ms 202μs) | `48.89 kB` (13ms 641μs) | +| `{1..1000}` | `3.89 kB` (1ms 796μs) | `3.89 kB` (1ms 958μs) | +| `{1..100}` | `291 B` (424μs) | `291 B` (211μs) | +| `{1..10}` | `20 B` (487μs) | `20 B` (72μs) | +| `{1..3}` | `5 B` (166μs) | `5 B` (27μs) | + +If you'd like to run these comparisons yourself, see [test/support/generate.js](test/support/generate.js). + +## Benchmarks + +### Running benchmarks + +Install dev dependencies: + +```bash +npm i -d && npm benchmark +``` + +### Latest results + +Braces is more accurate, without sacrificing performance. + +```bash +● expand - range (expanded) + braces x 53,167 ops/sec ±0.12% (102 runs sampled) + minimatch x 11,378 ops/sec ±0.10% (102 runs sampled) +● expand - range (optimized for regex) + braces x 373,442 ops/sec ±0.04% (100 runs sampled) + minimatch x 3,262 ops/sec ±0.18% (100 runs sampled) +● expand - nested ranges (expanded) + braces x 33,921 ops/sec ±0.09% (99 runs sampled) + minimatch x 10,855 ops/sec ±0.28% (100 runs sampled) +● expand - nested ranges (optimized for regex) + braces x 287,479 ops/sec ±0.52% (98 runs sampled) + minimatch x 3,219 ops/sec ±0.28% (101 runs sampled) +● expand - set (expanded) + braces x 238,243 ops/sec ±0.19% (97 runs sampled) + minimatch x 538,268 ops/sec ±0.31% (96 runs sampled) +● expand - set (optimized for regex) + braces x 321,844 ops/sec ±0.10% (97 runs sampled) + minimatch x 140,600 ops/sec ±0.15% (100 runs sampled) +● expand - nested sets (expanded) + braces x 165,371 ops/sec ±0.42% (96 runs sampled) + minimatch x 337,720 ops/sec ±0.28% (100 runs sampled) +● expand - nested sets (optimized for regex) + braces x 242,948 ops/sec ±0.12% (99 runs sampled) + minimatch x 87,403 ops/sec ±0.79% (96 runs sampled) +``` + +## About + +
+Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +
+ +
+Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +$ npm install && npm test +``` + +
+ +
+Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +$ npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
+ +### Contributors + +| **Commits** | **Contributor** | +| ----------- | ------------------------------------------------------------- | +| 197 | [jonschlinkert](https://github.com/jonschlinkert) | +| 4 | [doowb](https://github.com/doowb) | +| 1 | [es128](https://github.com/es128) | +| 1 | [eush77](https://github.com/eush77) | +| 1 | [hemanth](https://github.com/hemanth) | +| 1 | [wtgtybhertgeghgtwtg](https://github.com/wtgtybhertgeghgtwtg) | + +### Author + +**Jon Schlinkert** + +- [GitHub Profile](https://github.com/jonschlinkert) +- [Twitter Profile](https://twitter.com/jonschlinkert) +- [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) + +### License + +Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). + +--- + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on April 08, 2019._ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/index.js new file mode 100644 index 0000000..d222c13 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/index.js @@ -0,0 +1,170 @@ +'use strict'; + +const stringify = require('./lib/stringify'); +const compile = require('./lib/compile'); +const expand = require('./lib/expand'); +const parse = require('./lib/parse'); + +/** + * Expand the given pattern or create a regex-compatible string. + * + * ```js + * const braces = require('braces'); + * console.log(braces('{a,b,c}', { compile: true })); //=> ['(a|b|c)'] + * console.log(braces('{a,b,c}')); //=> ['a', 'b', 'c'] + * ``` + * @param {String} `str` + * @param {Object} `options` + * @return {String} + * @api public + */ + +const braces = (input, options = {}) => { + let output = []; + + if (Array.isArray(input)) { + for (const pattern of input) { + const result = braces.create(pattern, options); + if (Array.isArray(result)) { + output.push(...result); + } else { + output.push(result); + } + } + } else { + output = [].concat(braces.create(input, options)); + } + + if (options && options.expand === true && options.nodupes === true) { + output = [...new Set(output)]; + } + return output; +}; + +/** + * Parse the given `str` with the given `options`. + * + * ```js + * // braces.parse(pattern, [, options]); + * const ast = braces.parse('a/{b,c}/d'); + * console.log(ast); + * ``` + * @param {String} pattern Brace pattern to parse + * @param {Object} options + * @return {Object} Returns an AST + * @api public + */ + +braces.parse = (input, options = {}) => parse(input, options); + +/** + * Creates a braces string from an AST, or an AST node. + * + * ```js + * const braces = require('braces'); + * let ast = braces.parse('foo/{a,b}/bar'); + * console.log(stringify(ast.nodes[2])); //=> '{a,b}' + * ``` + * @param {String} `input` Brace pattern or AST. + * @param {Object} `options` + * @return {Array} Returns an array of expanded values. + * @api public + */ + +braces.stringify = (input, options = {}) => { + if (typeof input === 'string') { + return stringify(braces.parse(input, options), options); + } + return stringify(input, options); +}; + +/** + * Compiles a brace pattern into a regex-compatible, optimized string. + * This method is called by the main [braces](#braces) function by default. + * + * ```js + * const braces = require('braces'); + * console.log(braces.compile('a/{b,c}/d')); + * //=> ['a/(b|c)/d'] + * ``` + * @param {String} `input` Brace pattern or AST. + * @param {Object} `options` + * @return {Array} Returns an array of expanded values. + * @api public + */ + +braces.compile = (input, options = {}) => { + if (typeof input === 'string') { + input = braces.parse(input, options); + } + return compile(input, options); +}; + +/** + * Expands a brace pattern into an array. This method is called by the + * main [braces](#braces) function when `options.expand` is true. Before + * using this method it's recommended that you read the [performance notes](#performance)) + * and advantages of using [.compile](#compile) instead. + * + * ```js + * const braces = require('braces'); + * console.log(braces.expand('a/{b,c}/d')); + * //=> ['a/b/d', 'a/c/d']; + * ``` + * @param {String} `pattern` Brace pattern + * @param {Object} `options` + * @return {Array} Returns an array of expanded values. + * @api public + */ + +braces.expand = (input, options = {}) => { + if (typeof input === 'string') { + input = braces.parse(input, options); + } + + let result = expand(input, options); + + // filter out empty strings if specified + if (options.noempty === true) { + result = result.filter(Boolean); + } + + // filter out duplicates if specified + if (options.nodupes === true) { + result = [...new Set(result)]; + } + + return result; +}; + +/** + * Processes a brace pattern and returns either an expanded array + * (if `options.expand` is true), a highly optimized regex-compatible string. + * This method is called by the main [braces](#braces) function. + * + * ```js + * const braces = require('braces'); + * console.log(braces.create('user-{200..300}/project-{a,b,c}-{1..10}')) + * //=> 'user-(20[0-9]|2[1-9][0-9]|300)/project-(a|b|c)-([1-9]|10)' + * ``` + * @param {String} `pattern` Brace pattern + * @param {Object} `options` + * @return {Array} Returns an array of expanded values. + * @api public + */ + +braces.create = (input, options = {}) => { + if (input === '' || input.length < 3) { + return [input]; + } + + return options.expand !== true + ? braces.compile(input, options) + : braces.expand(input, options); +}; + +/** + * Expose "braces" + */ + +module.exports = braces; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/compile.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/compile.js new file mode 100644 index 0000000..dce69be --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/compile.js @@ -0,0 +1,60 @@ +'use strict'; + +const fill = require('fill-range'); +const utils = require('./utils'); + +const compile = (ast, options = {}) => { + const walk = (node, parent = {}) => { + const invalidBlock = utils.isInvalidBrace(parent); + const invalidNode = node.invalid === true && options.escapeInvalid === true; + const invalid = invalidBlock === true || invalidNode === true; + const prefix = options.escapeInvalid === true ? '\\' : ''; + let output = ''; + + if (node.isOpen === true) { + return prefix + node.value; + } + + if (node.isClose === true) { + console.log('node.isClose', prefix, node.value); + return prefix + node.value; + } + + if (node.type === 'open') { + return invalid ? prefix + node.value : '('; + } + + if (node.type === 'close') { + return invalid ? prefix + node.value : ')'; + } + + if (node.type === 'comma') { + return node.prev.type === 'comma' ? '' : invalid ? node.value : '|'; + } + + if (node.value) { + return node.value; + } + + if (node.nodes && node.ranges > 0) { + const args = utils.reduce(node.nodes); + const range = fill(...args, { ...options, wrap: false, toRegex: true, strictZeros: true }); + + if (range.length !== 0) { + return args.length > 1 && range.length > 1 ? `(${range})` : range; + } + } + + if (node.nodes) { + for (const child of node.nodes) { + output += walk(child, node); + } + } + + return output; + }; + + return walk(ast); +}; + +module.exports = compile; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/constants.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/constants.js new file mode 100644 index 0000000..2bb3b88 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/constants.js @@ -0,0 +1,57 @@ +'use strict'; + +module.exports = { + MAX_LENGTH: 10000, + + // Digits + CHAR_0: '0', /* 0 */ + CHAR_9: '9', /* 9 */ + + // Alphabet chars. + CHAR_UPPERCASE_A: 'A', /* A */ + CHAR_LOWERCASE_A: 'a', /* a */ + CHAR_UPPERCASE_Z: 'Z', /* Z */ + CHAR_LOWERCASE_Z: 'z', /* z */ + + CHAR_LEFT_PARENTHESES: '(', /* ( */ + CHAR_RIGHT_PARENTHESES: ')', /* ) */ + + CHAR_ASTERISK: '*', /* * */ + + // Non-alphabetic chars. + CHAR_AMPERSAND: '&', /* & */ + CHAR_AT: '@', /* @ */ + CHAR_BACKSLASH: '\\', /* \ */ + CHAR_BACKTICK: '`', /* ` */ + CHAR_CARRIAGE_RETURN: '\r', /* \r */ + CHAR_CIRCUMFLEX_ACCENT: '^', /* ^ */ + CHAR_COLON: ':', /* : */ + CHAR_COMMA: ',', /* , */ + CHAR_DOLLAR: '$', /* . */ + CHAR_DOT: '.', /* . */ + CHAR_DOUBLE_QUOTE: '"', /* " */ + CHAR_EQUAL: '=', /* = */ + CHAR_EXCLAMATION_MARK: '!', /* ! */ + CHAR_FORM_FEED: '\f', /* \f */ + CHAR_FORWARD_SLASH: '/', /* / */ + CHAR_HASH: '#', /* # */ + CHAR_HYPHEN_MINUS: '-', /* - */ + CHAR_LEFT_ANGLE_BRACKET: '<', /* < */ + CHAR_LEFT_CURLY_BRACE: '{', /* { */ + CHAR_LEFT_SQUARE_BRACKET: '[', /* [ */ + CHAR_LINE_FEED: '\n', /* \n */ + CHAR_NO_BREAK_SPACE: '\u00A0', /* \u00A0 */ + CHAR_PERCENT: '%', /* % */ + CHAR_PLUS: '+', /* + */ + CHAR_QUESTION_MARK: '?', /* ? */ + CHAR_RIGHT_ANGLE_BRACKET: '>', /* > */ + CHAR_RIGHT_CURLY_BRACE: '}', /* } */ + CHAR_RIGHT_SQUARE_BRACKET: ']', /* ] */ + CHAR_SEMICOLON: ';', /* ; */ + CHAR_SINGLE_QUOTE: '\'', /* ' */ + CHAR_SPACE: ' ', /* */ + CHAR_TAB: '\t', /* \t */ + CHAR_UNDERSCORE: '_', /* _ */ + CHAR_VERTICAL_LINE: '|', /* | */ + CHAR_ZERO_WIDTH_NOBREAK_SPACE: '\uFEFF' /* \uFEFF */ +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/expand.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/expand.js new file mode 100644 index 0000000..35b2c41 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/expand.js @@ -0,0 +1,113 @@ +'use strict'; + +const fill = require('fill-range'); +const stringify = require('./stringify'); +const utils = require('./utils'); + +const append = (queue = '', stash = '', enclose = false) => { + const result = []; + + queue = [].concat(queue); + stash = [].concat(stash); + + if (!stash.length) return queue; + if (!queue.length) { + return enclose ? utils.flatten(stash).map(ele => `{${ele}}`) : stash; + } + + for (const item of queue) { + if (Array.isArray(item)) { + for (const value of item) { + result.push(append(value, stash, enclose)); + } + } else { + for (let ele of stash) { + if (enclose === true && typeof ele === 'string') ele = `{${ele}}`; + result.push(Array.isArray(ele) ? append(item, ele, enclose) : item + ele); + } + } + } + return utils.flatten(result); +}; + +const expand = (ast, options = {}) => { + const rangeLimit = options.rangeLimit === undefined ? 1000 : options.rangeLimit; + + const walk = (node, parent = {}) => { + node.queue = []; + + let p = parent; + let q = parent.queue; + + while (p.type !== 'brace' && p.type !== 'root' && p.parent) { + p = p.parent; + q = p.queue; + } + + if (node.invalid || node.dollar) { + q.push(append(q.pop(), stringify(node, options))); + return; + } + + if (node.type === 'brace' && node.invalid !== true && node.nodes.length === 2) { + q.push(append(q.pop(), ['{}'])); + return; + } + + if (node.nodes && node.ranges > 0) { + const args = utils.reduce(node.nodes); + + if (utils.exceedsLimit(...args, options.step, rangeLimit)) { + throw new RangeError('expanded array length exceeds range limit. Use options.rangeLimit to increase or disable the limit.'); + } + + let range = fill(...args, options); + if (range.length === 0) { + range = stringify(node, options); + } + + q.push(append(q.pop(), range)); + node.nodes = []; + return; + } + + const enclose = utils.encloseBrace(node); + let queue = node.queue; + let block = node; + + while (block.type !== 'brace' && block.type !== 'root' && block.parent) { + block = block.parent; + queue = block.queue; + } + + for (let i = 0; i < node.nodes.length; i++) { + const child = node.nodes[i]; + + if (child.type === 'comma' && node.type === 'brace') { + if (i === 1) queue.push(''); + queue.push(''); + continue; + } + + if (child.type === 'close') { + q.push(append(q.pop(), queue, enclose)); + continue; + } + + if (child.value && child.type !== 'open') { + queue.push(append(queue.pop(), child.value)); + continue; + } + + if (child.nodes) { + walk(child, node); + } + } + + return queue; + }; + + return utils.flatten(walk(ast)); +}; + +module.exports = expand; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/parse.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/parse.js new file mode 100644 index 0000000..3a6988e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/parse.js @@ -0,0 +1,331 @@ +'use strict'; + +const stringify = require('./stringify'); + +/** + * Constants + */ + +const { + MAX_LENGTH, + CHAR_BACKSLASH, /* \ */ + CHAR_BACKTICK, /* ` */ + CHAR_COMMA, /* , */ + CHAR_DOT, /* . */ + CHAR_LEFT_PARENTHESES, /* ( */ + CHAR_RIGHT_PARENTHESES, /* ) */ + CHAR_LEFT_CURLY_BRACE, /* { */ + CHAR_RIGHT_CURLY_BRACE, /* } */ + CHAR_LEFT_SQUARE_BRACKET, /* [ */ + CHAR_RIGHT_SQUARE_BRACKET, /* ] */ + CHAR_DOUBLE_QUOTE, /* " */ + CHAR_SINGLE_QUOTE, /* ' */ + CHAR_NO_BREAK_SPACE, + CHAR_ZERO_WIDTH_NOBREAK_SPACE +} = require('./constants'); + +/** + * parse + */ + +const parse = (input, options = {}) => { + if (typeof input !== 'string') { + throw new TypeError('Expected a string'); + } + + const opts = options || {}; + const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; + if (input.length > max) { + throw new SyntaxError(`Input length (${input.length}), exceeds max characters (${max})`); + } + + const ast = { type: 'root', input, nodes: [] }; + const stack = [ast]; + let block = ast; + let prev = ast; + let brackets = 0; + const length = input.length; + let index = 0; + let depth = 0; + let value; + + /** + * Helpers + */ + + const advance = () => input[index++]; + const push = node => { + if (node.type === 'text' && prev.type === 'dot') { + prev.type = 'text'; + } + + if (prev && prev.type === 'text' && node.type === 'text') { + prev.value += node.value; + return; + } + + block.nodes.push(node); + node.parent = block; + node.prev = prev; + prev = node; + return node; + }; + + push({ type: 'bos' }); + + while (index < length) { + block = stack[stack.length - 1]; + value = advance(); + + /** + * Invalid chars + */ + + if (value === CHAR_ZERO_WIDTH_NOBREAK_SPACE || value === CHAR_NO_BREAK_SPACE) { + continue; + } + + /** + * Escaped chars + */ + + if (value === CHAR_BACKSLASH) { + push({ type: 'text', value: (options.keepEscaping ? value : '') + advance() }); + continue; + } + + /** + * Right square bracket (literal): ']' + */ + + if (value === CHAR_RIGHT_SQUARE_BRACKET) { + push({ type: 'text', value: '\\' + value }); + continue; + } + + /** + * Left square bracket: '[' + */ + + if (value === CHAR_LEFT_SQUARE_BRACKET) { + brackets++; + + let next; + + while (index < length && (next = advance())) { + value += next; + + if (next === CHAR_LEFT_SQUARE_BRACKET) { + brackets++; + continue; + } + + if (next === CHAR_BACKSLASH) { + value += advance(); + continue; + } + + if (next === CHAR_RIGHT_SQUARE_BRACKET) { + brackets--; + + if (brackets === 0) { + break; + } + } + } + + push({ type: 'text', value }); + continue; + } + + /** + * Parentheses + */ + + if (value === CHAR_LEFT_PARENTHESES) { + block = push({ type: 'paren', nodes: [] }); + stack.push(block); + push({ type: 'text', value }); + continue; + } + + if (value === CHAR_RIGHT_PARENTHESES) { + if (block.type !== 'paren') { + push({ type: 'text', value }); + continue; + } + block = stack.pop(); + push({ type: 'text', value }); + block = stack[stack.length - 1]; + continue; + } + + /** + * Quotes: '|"|` + */ + + if (value === CHAR_DOUBLE_QUOTE || value === CHAR_SINGLE_QUOTE || value === CHAR_BACKTICK) { + const open = value; + let next; + + if (options.keepQuotes !== true) { + value = ''; + } + + while (index < length && (next = advance())) { + if (next === CHAR_BACKSLASH) { + value += next + advance(); + continue; + } + + if (next === open) { + if (options.keepQuotes === true) value += next; + break; + } + + value += next; + } + + push({ type: 'text', value }); + continue; + } + + /** + * Left curly brace: '{' + */ + + if (value === CHAR_LEFT_CURLY_BRACE) { + depth++; + + const dollar = prev.value && prev.value.slice(-1) === '$' || block.dollar === true; + const brace = { + type: 'brace', + open: true, + close: false, + dollar, + depth, + commas: 0, + ranges: 0, + nodes: [] + }; + + block = push(brace); + stack.push(block); + push({ type: 'open', value }); + continue; + } + + /** + * Right curly brace: '}' + */ + + if (value === CHAR_RIGHT_CURLY_BRACE) { + if (block.type !== 'brace') { + push({ type: 'text', value }); + continue; + } + + const type = 'close'; + block = stack.pop(); + block.close = true; + + push({ type, value }); + depth--; + + block = stack[stack.length - 1]; + continue; + } + + /** + * Comma: ',' + */ + + if (value === CHAR_COMMA && depth > 0) { + if (block.ranges > 0) { + block.ranges = 0; + const open = block.nodes.shift(); + block.nodes = [open, { type: 'text', value: stringify(block) }]; + } + + push({ type: 'comma', value }); + block.commas++; + continue; + } + + /** + * Dot: '.' + */ + + if (value === CHAR_DOT && depth > 0 && block.commas === 0) { + const siblings = block.nodes; + + if (depth === 0 || siblings.length === 0) { + push({ type: 'text', value }); + continue; + } + + if (prev.type === 'dot') { + block.range = []; + prev.value += value; + prev.type = 'range'; + + if (block.nodes.length !== 3 && block.nodes.length !== 5) { + block.invalid = true; + block.ranges = 0; + prev.type = 'text'; + continue; + } + + block.ranges++; + block.args = []; + continue; + } + + if (prev.type === 'range') { + siblings.pop(); + + const before = siblings[siblings.length - 1]; + before.value += prev.value + value; + prev = before; + block.ranges--; + continue; + } + + push({ type: 'dot', value }); + continue; + } + + /** + * Text + */ + + push({ type: 'text', value }); + } + + // Mark imbalanced braces and brackets as invalid + do { + block = stack.pop(); + + if (block.type !== 'root') { + block.nodes.forEach(node => { + if (!node.nodes) { + if (node.type === 'open') node.isOpen = true; + if (node.type === 'close') node.isClose = true; + if (!node.nodes) node.type = 'text'; + node.invalid = true; + } + }); + + // get the location of the block on parent.nodes (block's siblings) + const parent = stack[stack.length - 1]; + const index = parent.nodes.indexOf(block); + // replace the (invalid) block with it's nodes + parent.nodes.splice(index, 1, ...block.nodes); + } + } while (stack.length > 0); + + push({ type: 'eos' }); + return ast; +}; + +module.exports = parse; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/stringify.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/stringify.js new file mode 100644 index 0000000..8bcf872 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/stringify.js @@ -0,0 +1,32 @@ +'use strict'; + +const utils = require('./utils'); + +module.exports = (ast, options = {}) => { + const stringify = (node, parent = {}) => { + const invalidBlock = options.escapeInvalid && utils.isInvalidBrace(parent); + const invalidNode = node.invalid === true && options.escapeInvalid === true; + let output = ''; + + if (node.value) { + if ((invalidBlock || invalidNode) && utils.isOpenOrClose(node)) { + return '\\' + node.value; + } + return node.value; + } + + if (node.value) { + return node.value; + } + + if (node.nodes) { + for (const child of node.nodes) { + output += stringify(child); + } + } + return output; + }; + + return stringify(ast); +}; + diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/utils.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/utils.js new file mode 100644 index 0000000..d19311f --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/lib/utils.js @@ -0,0 +1,122 @@ +'use strict'; + +exports.isInteger = num => { + if (typeof num === 'number') { + return Number.isInteger(num); + } + if (typeof num === 'string' && num.trim() !== '') { + return Number.isInteger(Number(num)); + } + return false; +}; + +/** + * Find a node of the given type + */ + +exports.find = (node, type) => node.nodes.find(node => node.type === type); + +/** + * Find a node of the given type + */ + +exports.exceedsLimit = (min, max, step = 1, limit) => { + if (limit === false) return false; + if (!exports.isInteger(min) || !exports.isInteger(max)) return false; + return ((Number(max) - Number(min)) / Number(step)) >= limit; +}; + +/** + * Escape the given node with '\\' before node.value + */ + +exports.escapeNode = (block, n = 0, type) => { + const node = block.nodes[n]; + if (!node) return; + + if ((type && node.type === type) || node.type === 'open' || node.type === 'close') { + if (node.escaped !== true) { + node.value = '\\' + node.value; + node.escaped = true; + } + } +}; + +/** + * Returns true if the given brace node should be enclosed in literal braces + */ + +exports.encloseBrace = node => { + if (node.type !== 'brace') return false; + if ((node.commas >> 0 + node.ranges >> 0) === 0) { + node.invalid = true; + return true; + } + return false; +}; + +/** + * Returns true if a brace node is invalid. + */ + +exports.isInvalidBrace = block => { + if (block.type !== 'brace') return false; + if (block.invalid === true || block.dollar) return true; + if ((block.commas >> 0 + block.ranges >> 0) === 0) { + block.invalid = true; + return true; + } + if (block.open !== true || block.close !== true) { + block.invalid = true; + return true; + } + return false; +}; + +/** + * Returns true if a node is an open or close node + */ + +exports.isOpenOrClose = node => { + if (node.type === 'open' || node.type === 'close') { + return true; + } + return node.open === true || node.close === true; +}; + +/** + * Reduce an array of text nodes. + */ + +exports.reduce = nodes => nodes.reduce((acc, node) => { + if (node.type === 'text') acc.push(node.value); + if (node.type === 'range') node.type = 'text'; + return acc; +}, []); + +/** + * Flatten an array + */ + +exports.flatten = (...args) => { + const result = []; + + const flat = arr => { + for (let i = 0; i < arr.length; i++) { + const ele = arr[i]; + + if (Array.isArray(ele)) { + flat(ele); + continue; + } + + if (ele !== undefined) { + result.push(ele); + } + } + return result; + }; + + flat(args); + return result; +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/package.json new file mode 100644 index 0000000..c3c056e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/braces/package.json @@ -0,0 +1,77 @@ +{ + "name": "braces", + "description": "Bash-like brace expansion, implemented in JavaScript. Safer than other brace expansion libs, with complete support for the Bash 4.3 braces specification, without sacrificing speed.", + "version": "3.0.3", + "homepage": "https://github.com/micromatch/braces", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "contributors": [ + "Brian Woodward (https://twitter.com/doowb)", + "Elan Shanker (https://github.com/es128)", + "Eugene Sharygin (https://github.com/eush77)", + "hemanth.hm (http://h3manth.com)", + "Jon Schlinkert (http://twitter.com/jonschlinkert)" + ], + "repository": "micromatch/braces", + "bugs": { + "url": "https://github.com/micromatch/braces/issues" + }, + "license": "MIT", + "files": [ + "index.js", + "lib" + ], + "main": "index.js", + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "mocha", + "benchmark": "node benchmark" + }, + "dependencies": { + "fill-range": "^7.1.1" + }, + "devDependencies": { + "ansi-colors": "^3.2.4", + "bash-path": "^2.0.1", + "gulp-format-md": "^2.0.0", + "mocha": "^6.1.1" + }, + "keywords": [ + "alpha", + "alphabetical", + "bash", + "brace", + "braces", + "expand", + "expansion", + "filepath", + "fill", + "fs", + "glob", + "globbing", + "letter", + "match", + "matches", + "matching", + "number", + "numerical", + "path", + "range", + "ranges", + "sh" + ], + "verb": { + "toc": false, + "layout": "default", + "tasks": [ + "readme" + ], + "lint": { + "reflinks": true + }, + "plugins": [ + "gulp-format-md" + ] + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/History.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/History.md new file mode 100644 index 0000000..d60ce0e --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/History.md @@ -0,0 +1,97 @@ +3.1.2 / 2022-01-27 +================== + + * Fix return value for un-parsable strings + +3.1.1 / 2021-11-15 +================== + + * Fix "thousandsSeparator" incorrecting formatting fractional part + +3.1.0 / 2019-01-22 +================== + + * Add petabyte (`pb`) support + +3.0.0 / 2017-08-31 +================== + + * Change "kB" to "KB" in format output + * Remove support for Node.js 0.6 + * Remove support for ComponentJS + +2.5.0 / 2017-03-24 +================== + + * Add option "unit" + +2.4.0 / 2016-06-01 +================== + + * Add option "unitSeparator" + +2.3.0 / 2016-02-15 +================== + + * Drop partial bytes on all parsed units + * Fix non-finite numbers to `.format` to return `null` + * Fix parsing byte string that looks like hex + * perf: hoist regular expressions + +2.2.0 / 2015-11-13 +================== + + * add option "decimalPlaces" + * add option "fixedDecimals" + +2.1.0 / 2015-05-21 +================== + + * add `.format` export + * add `.parse` export + +2.0.2 / 2015-05-20 +================== + + * remove map recreation + * remove unnecessary object construction + +2.0.1 / 2015-05-07 +================== + + * fix browserify require + * remove node.extend dependency + +2.0.0 / 2015-04-12 +================== + + * add option "case" + * add option "thousandsSeparator" + * return "null" on invalid parse input + * support proper round-trip: bytes(bytes(num)) === num + * units no longer case sensitive when parsing + +1.0.0 / 2014-05-05 +================== + + * add negative support. fixes #6 + +0.3.0 / 2014-03-19 +================== + + * added terabyte support + +0.2.1 / 2013-04-01 +================== + + * add .component + +0.2.0 / 2012-10-28 +================== + + * bytes(200).should.eql('200b') + +0.1.0 / 2012-07-04 +================== + + * add bytes to string conversion [yields] diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/LICENSE new file mode 100644 index 0000000..63e95a9 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/LICENSE @@ -0,0 +1,23 @@ +(The MIT License) + +Copyright (c) 2012-2014 TJ Holowaychuk +Copyright (c) 2015 Jed Watson + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +'Software'), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/Readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/Readme.md new file mode 100644 index 0000000..5790e23 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/Readme.md @@ -0,0 +1,152 @@ +# Bytes utility + +[![NPM Version][npm-image]][npm-url] +[![NPM Downloads][downloads-image]][downloads-url] +[![Build Status][ci-image]][ci-url] +[![Test Coverage][coveralls-image]][coveralls-url] + +Utility to parse a string bytes (ex: `1TB`) to bytes (`1099511627776`) and vice-versa. + +## Installation + +This is a [Node.js](https://nodejs.org/en/) module available through the +[npm registry](https://www.npmjs.com/). Installation is done using the +[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally): + +```bash +$ npm install bytes +``` + +## Usage + +```js +var bytes = require('bytes'); +``` + +#### bytes(number|string value, [options]): number|string|null + +Default export function. Delegates to either `bytes.format` or `bytes.parse` based on the type of `value`. + +**Arguments** + +| Name | Type | Description | +|---------|----------|--------------------| +| value | `number`|`string` | Number value to format or string value to parse | +| options | `Object` | Conversion options for `format` | + +**Returns** + +| Name | Type | Description | +|---------|------------------|-------------------------------------------------| +| results | `string`|`number`|`null` | Return null upon error. Numeric value in bytes, or string value otherwise. | + +**Example** + +```js +bytes(1024); +// output: '1KB' + +bytes('1KB'); +// output: 1024 +``` + +#### bytes.format(number value, [options]): string|null + +Format the given value in bytes into a string. If the value is negative, it is kept as such. If it is a float, it is + rounded. + +**Arguments** + +| Name | Type | Description | +|---------|----------|--------------------| +| value | `number` | Value in bytes | +| options | `Object` | Conversion options | + +**Options** + +| Property | Type | Description | +|-------------------|--------|-----------------------------------------------------------------------------------------| +| decimalPlaces | `number`|`null` | Maximum number of decimal places to include in output. Default value to `2`. | +| fixedDecimals | `boolean`|`null` | Whether to always display the maximum number of decimal places. Default value to `false` | +| thousandsSeparator | `string`|`null` | Example of values: `' '`, `','` and `'.'`... Default value to `''`. | +| unit | `string`|`null` | The unit in which the result will be returned (B/KB/MB/GB/TB). Default value to `''` (which means auto detect). | +| unitSeparator | `string`|`null` | Separator to use between number and unit. Default value to `''`. | + +**Returns** + +| Name | Type | Description | +|---------|------------------|-------------------------------------------------| +| results | `string`|`null` | Return null upon error. String value otherwise. | + +**Example** + +```js +bytes.format(1024); +// output: '1KB' + +bytes.format(1000); +// output: '1000B' + +bytes.format(1000, {thousandsSeparator: ' '}); +// output: '1 000B' + +bytes.format(1024 * 1.7, {decimalPlaces: 0}); +// output: '2KB' + +bytes.format(1024, {unitSeparator: ' '}); +// output: '1 KB' +``` + +#### bytes.parse(string|number value): number|null + +Parse the string value into an integer in bytes. If no unit is given, or `value` +is a number, it is assumed the value is in bytes. + +Supported units and abbreviations are as follows and are case-insensitive: + + * `b` for bytes + * `kb` for kilobytes + * `mb` for megabytes + * `gb` for gigabytes + * `tb` for terabytes + * `pb` for petabytes + +The units are in powers of two, not ten. This means 1kb = 1024b according to this parser. + +**Arguments** + +| Name | Type | Description | +|---------------|--------|--------------------| +| value | `string`|`number` | String to parse, or number in bytes. | + +**Returns** + +| Name | Type | Description | +|---------|-------------|-------------------------| +| results | `number`|`null` | Return null upon error. Value in bytes otherwise. | + +**Example** + +```js +bytes.parse('1KB'); +// output: 1024 + +bytes.parse('1024'); +// output: 1024 + +bytes.parse(1024); +// output: 1024 +``` + +## License + +[MIT](LICENSE) + +[ci-image]: https://badgen.net/github/checks/visionmedia/bytes.js/master?label=ci +[ci-url]: https://github.com/visionmedia/bytes.js/actions?query=workflow%3Aci +[coveralls-image]: https://badgen.net/coveralls/c/github/visionmedia/bytes.js/master +[coveralls-url]: https://coveralls.io/r/visionmedia/bytes.js?branch=master +[downloads-image]: https://badgen.net/npm/dm/bytes +[downloads-url]: https://npmjs.org/package/bytes +[npm-image]: https://badgen.net/npm/v/bytes +[npm-url]: https://npmjs.org/package/bytes diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/index.js new file mode 100644 index 0000000..6f2d0f8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/index.js @@ -0,0 +1,170 @@ +/*! + * bytes + * Copyright(c) 2012-2014 TJ Holowaychuk + * Copyright(c) 2015 Jed Watson + * MIT Licensed + */ + +'use strict'; + +/** + * Module exports. + * @public + */ + +module.exports = bytes; +module.exports.format = format; +module.exports.parse = parse; + +/** + * Module variables. + * @private + */ + +var formatThousandsRegExp = /\B(?=(\d{3})+(?!\d))/g; + +var formatDecimalsRegExp = /(?:\.0*|(\.[^0]+)0+)$/; + +var map = { + b: 1, + kb: 1 << 10, + mb: 1 << 20, + gb: 1 << 30, + tb: Math.pow(1024, 4), + pb: Math.pow(1024, 5), +}; + +var parseRegExp = /^((-|\+)?(\d+(?:\.\d+)?)) *(kb|mb|gb|tb|pb)$/i; + +/** + * Convert the given value in bytes into a string or parse to string to an integer in bytes. + * + * @param {string|number} value + * @param {{ + * case: [string], + * decimalPlaces: [number] + * fixedDecimals: [boolean] + * thousandsSeparator: [string] + * unitSeparator: [string] + * }} [options] bytes options. + * + * @returns {string|number|null} + */ + +function bytes(value, options) { + if (typeof value === 'string') { + return parse(value); + } + + if (typeof value === 'number') { + return format(value, options); + } + + return null; +} + +/** + * Format the given value in bytes into a string. + * + * If the value is negative, it is kept as such. If it is a float, + * it is rounded. + * + * @param {number} value + * @param {object} [options] + * @param {number} [options.decimalPlaces=2] + * @param {number} [options.fixedDecimals=false] + * @param {string} [options.thousandsSeparator=] + * @param {string} [options.unit=] + * @param {string} [options.unitSeparator=] + * + * @returns {string|null} + * @public + */ + +function format(value, options) { + if (!Number.isFinite(value)) { + return null; + } + + var mag = Math.abs(value); + var thousandsSeparator = (options && options.thousandsSeparator) || ''; + var unitSeparator = (options && options.unitSeparator) || ''; + var decimalPlaces = (options && options.decimalPlaces !== undefined) ? options.decimalPlaces : 2; + var fixedDecimals = Boolean(options && options.fixedDecimals); + var unit = (options && options.unit) || ''; + + if (!unit || !map[unit.toLowerCase()]) { + if (mag >= map.pb) { + unit = 'PB'; + } else if (mag >= map.tb) { + unit = 'TB'; + } else if (mag >= map.gb) { + unit = 'GB'; + } else if (mag >= map.mb) { + unit = 'MB'; + } else if (mag >= map.kb) { + unit = 'KB'; + } else { + unit = 'B'; + } + } + + var val = value / map[unit.toLowerCase()]; + var str = val.toFixed(decimalPlaces); + + if (!fixedDecimals) { + str = str.replace(formatDecimalsRegExp, '$1'); + } + + if (thousandsSeparator) { + str = str.split('.').map(function (s, i) { + return i === 0 + ? s.replace(formatThousandsRegExp, thousandsSeparator) + : s + }).join('.'); + } + + return str + unitSeparator + unit; +} + +/** + * Parse the string value into an integer in bytes. + * + * If no unit is given, it is assumed the value is in bytes. + * + * @param {number|string} val + * + * @returns {number|null} + * @public + */ + +function parse(val) { + if (typeof val === 'number' && !isNaN(val)) { + return val; + } + + if (typeof val !== 'string') { + return null; + } + + // Test if the string passed is valid + var results = parseRegExp.exec(val); + var floatValue; + var unit = 'b'; + + if (!results) { + // Nothing could be extracted from the given string + floatValue = parseInt(val, 10); + unit = 'b' + } else { + // Retrieve the value and the unit + floatValue = parseFloat(results[1]); + unit = results[4].toLowerCase(); + } + + if (isNaN(floatValue)) { + return null; + } + + return Math.floor(map[unit] * floatValue); +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/package.json new file mode 100644 index 0000000..f2b6a8b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/bytes/package.json @@ -0,0 +1,42 @@ +{ + "name": "bytes", + "description": "Utility to parse a string bytes to bytes and vice-versa", + "version": "3.1.2", + "author": "TJ Holowaychuk (http://tjholowaychuk.com)", + "contributors": [ + "Jed Watson ", + "Théo FIDRY " + ], + "license": "MIT", + "keywords": [ + "byte", + "bytes", + "utility", + "parse", + "parser", + "convert", + "converter" + ], + "repository": "visionmedia/bytes.js", + "devDependencies": { + "eslint": "7.32.0", + "eslint-plugin-markdown": "2.2.1", + "mocha": "9.2.0", + "nyc": "15.1.0" + }, + "files": [ + "History.md", + "LICENSE", + "Readme.md", + "index.js" + ], + "engines": { + "node": ">= 0.8" + }, + "scripts": { + "lint": "eslint .", + "test": "mocha --check-leaks --reporter spec", + "test-ci": "nyc --reporter=lcov --reporter=text npm test", + "test-cov": "nyc --reporter=html --reporter=text npm test" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintignore b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintignore new file mode 100644 index 0000000..404abb2 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintignore @@ -0,0 +1 @@ +coverage/ diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintrc b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintrc new file mode 100644 index 0000000..dfa9a6c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.eslintrc @@ -0,0 +1,16 @@ +{ + "root": true, + + "extends": "@ljharb", + + "rules": { + "func-name-matching": 0, + "id-length": 0, + "new-cap": [2, { + "capIsNewExceptions": [ + "GetIntrinsic", + ], + }], + "no-magic-numbers": 0, + }, +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.github/FUNDING.yml b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.github/FUNDING.yml new file mode 100644 index 0000000..c70c2ec --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.github/FUNDING.yml @@ -0,0 +1,12 @@ +# These are supported funding model platforms + +github: [ljharb] +patreon: # Replace with a single Patreon username +open_collective: # Replace with a single Open Collective username +ko_fi: # Replace with a single Ko-fi username +tidelift: npm/call-bind +community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry +liberapay: # Replace with a single Liberapay username +issuehunt: # Replace with a single IssueHunt username +otechie: # Replace with a single Otechie username +custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2'] diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.nycrc b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.nycrc new file mode 100644 index 0000000..bdd626c --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/.nycrc @@ -0,0 +1,9 @@ +{ + "all": true, + "check-coverage": false, + "reporter": ["text-summary", "text", "html", "json"], + "exclude": [ + "coverage", + "test" + ] +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/CHANGELOG.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/CHANGELOG.md new file mode 100644 index 0000000..c653f70 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/CHANGELOG.md @@ -0,0 +1,93 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## [v1.0.7](https://github.com/ljharb/call-bind/compare/v1.0.6...v1.0.7) - 2024-02-12 + +### Commits + +- [Refactor] use `es-define-property` [`09b76a0`](https://github.com/ljharb/call-bind/commit/09b76a01634440461d44a80c9924ec4b500f3b03) +- [Deps] update `get-intrinsic`, `set-function-length` [`ad5136d`](https://github.com/ljharb/call-bind/commit/ad5136ddda2a45c590959829ad3dce0c9f4e3590) + +## [v1.0.6](https://github.com/ljharb/call-bind/compare/v1.0.5...v1.0.6) - 2024-02-05 + +### Commits + +- [Dev Deps] update `aud`, `npmignore`, `tape` [`d564d5c`](https://github.com/ljharb/call-bind/commit/d564d5ce3e06a19df4d499c77f8d1a9da44e77aa) +- [Deps] update `get-intrinsic`, `set-function-length` [`cfc2bdc`](https://github.com/ljharb/call-bind/commit/cfc2bdca7b633df0e0e689e6b637f668f1c6792e) +- [Refactor] use `es-errors`, so things that only need those do not need `get-intrinsic` [`64cd289`](https://github.com/ljharb/call-bind/commit/64cd289ae5862c250a4ca80aa8d461047c166af5) +- [meta] add missing `engines.node` [`32a4038`](https://github.com/ljharb/call-bind/commit/32a4038857b62179f7f9b7b3df2c5260036be582) + +## [v1.0.5](https://github.com/ljharb/call-bind/compare/v1.0.4...v1.0.5) - 2023-10-19 + +### Commits + +- [Fix] throw an error on non-functions as early as possible [`f262408`](https://github.com/ljharb/call-bind/commit/f262408f822c840fbc268080f3ad7c429611066d) +- [Deps] update `set-function-length` [`3fff271`](https://github.com/ljharb/call-bind/commit/3fff27145a1e3a76a5b74f1d7c3c43d0fa3b9871) + +## [v1.0.4](https://github.com/ljharb/call-bind/compare/v1.0.3...v1.0.4) - 2023-10-19 + +## [v1.0.3](https://github.com/ljharb/call-bind/compare/v1.0.2...v1.0.3) - 2023-10-19 + +### Commits + +- [actions] reuse common workflows [`a994df6`](https://github.com/ljharb/call-bind/commit/a994df69f401f4bf735a4ccd77029b85d1549453) +- [meta] use `npmignore` to autogenerate an npmignore file [`eef3ef2`](https://github.com/ljharb/call-bind/commit/eef3ef21e1f002790837fedb8af2679c761fbdf5) +- [readme] flesh out content [`1845ccf`](https://github.com/ljharb/call-bind/commit/1845ccfd9976a607884cfc7157c93192cc16cf22) +- [actions] use `node/install` instead of `node/run`; use `codecov` action [`5b47d53`](https://github.com/ljharb/call-bind/commit/5b47d53d2fd74af5ea0a44f1d51e503cd42f7a90) +- [Refactor] use `set-function-length` [`a0e165c`](https://github.com/ljharb/call-bind/commit/a0e165c5dc61db781cbc919b586b1c2b8da0b150) +- [Dev Deps] update `@ljharb/eslint-config`, `aud`, `tape` [`9c50103`](https://github.com/ljharb/call-bind/commit/9c50103f44137279a817317cf6cc421a658f85b4) +- [meta] simplify "exports" [`019c6d0`](https://github.com/ljharb/call-bind/commit/019c6d06b0e1246ceed8e579f57e44441cbbf6d9) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `auto-changelog`, `safe-publish-latest`, `tape` [`23bd718`](https://github.com/ljharb/call-bind/commit/23bd718a288d3b03042062b4ef5153b3cea83f11) +- [actions] update codecov uploader [`62552d7`](https://github.com/ljharb/call-bind/commit/62552d79cc79e05825e99aaba134ae5b37f33da5) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `auto-changelog`, `tape` [`ec81665`](https://github.com/ljharb/call-bind/commit/ec81665b300f87eabff597afdc8b8092adfa7afd) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `safe-publish-latest`, `tape` [`35d67fc`](https://github.com/ljharb/call-bind/commit/35d67fcea883e686650f736f61da5ddca2592de8) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `tape` [`0266d8d`](https://github.com/ljharb/call-bind/commit/0266d8d2a45086a922db366d0c2932fa463662ff) +- [Dev Deps] update `@ljharb/eslint-config`, `aud`, `tape` [`43a5b28`](https://github.com/ljharb/call-bind/commit/43a5b28a444e710e1bbf92adb8afb5cf7523a223) +- [Deps] update `define-data-property`, `function-bind`, `get-intrinsic` [`780eb36`](https://github.com/ljharb/call-bind/commit/780eb36552514f8cc99c70821ce698697c2726a5) +- [Dev Deps] update `aud`, `tape` [`90d50ad`](https://github.com/ljharb/call-bind/commit/90d50ad03b061e0268b3380b0065fcaec183dc05) +- [meta] use `prepublishOnly` script for npm 7+ [`44c5433`](https://github.com/ljharb/call-bind/commit/44c5433b7980e02b4870007046407cf6fc543329) +- [Deps] update `get-intrinsic` [`86bfbfc`](https://github.com/ljharb/call-bind/commit/86bfbfcf34afdc6eabc93ce3d408548d0e27d958) +- [Deps] update `get-intrinsic` [`5c53354`](https://github.com/ljharb/call-bind/commit/5c5335489be0294c18cd7a8bb6e08226ee019ff5) +- [actions] update checkout action [`4c393a8`](https://github.com/ljharb/call-bind/commit/4c393a8173b3c8e5b30d5b3297b3b94d48bf87f3) +- [Deps] update `get-intrinsic` [`4e70bde`](https://github.com/ljharb/call-bind/commit/4e70bdec0626acb11616d66250fc14565e716e91) +- [Deps] update `get-intrinsic` [`55ae803`](https://github.com/ljharb/call-bind/commit/55ae803a920bd93c369cd798c20de31f91e9fc60) + +## [v1.0.2](https://github.com/ljharb/call-bind/compare/v1.0.1...v1.0.2) - 2021-01-11 + +### Commits + +- [Fix] properly include the receiver in the bound length [`dbae7bc`](https://github.com/ljharb/call-bind/commit/dbae7bc676c079a0d33c0a43e9ef92cb7b01345d) + +## [v1.0.1](https://github.com/ljharb/call-bind/compare/v1.0.0...v1.0.1) - 2021-01-08 + +### Commits + +- [Tests] migrate tests to Github Actions [`b6db284`](https://github.com/ljharb/call-bind/commit/b6db284c36f8ccd195b88a6764fe84b7223a0da1) +- [meta] do not publish github action workflow files [`ec7fe46`](https://github.com/ljharb/call-bind/commit/ec7fe46e60cfa4764ee943d2755f5e5a366e578e) +- [Fix] preserve original function’s length when possible [`adbceaa`](https://github.com/ljharb/call-bind/commit/adbceaa3cac4b41ea78bb19d7ccdbaaf7e0bdadb) +- [Tests] gather coverage data on every job [`d69e23c`](https://github.com/ljharb/call-bind/commit/d69e23cc65f101ba1d4c19bb07fa8eb0ec624be8) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `tape` [`2fd3586`](https://github.com/ljharb/call-bind/commit/2fd3586c5d47b335364c14293114c6b625ae1f71) +- [Deps] update `get-intrinsic` [`f23e931`](https://github.com/ljharb/call-bind/commit/f23e9318cc271c2add8bb38cfded85ee7baf8eee) +- [Deps] update `get-intrinsic` [`72d9f44`](https://github.com/ljharb/call-bind/commit/72d9f44e184465ba8dd3fb48260bbcff234985f2) +- [meta] fix FUNDING.yml [`e723573`](https://github.com/ljharb/call-bind/commit/e723573438c5a68dcec31fb5d96ea6b7e4a93be8) +- [eslint] ignore coverage output [`15e76d2`](https://github.com/ljharb/call-bind/commit/15e76d28a5f43e504696401e5b31ebb78ee1b532) +- [meta] add Automatic Rebase and Require Allow Edits workflows [`8fa4dab`](https://github.com/ljharb/call-bind/commit/8fa4dabb23ba3dd7bb92c9571c1241c08b56e4b6) + +## v1.0.0 - 2020-10-30 + +### Commits + +- Initial commit [`306cf98`](https://github.com/ljharb/call-bind/commit/306cf98c7ec9e7ef66b653ec152277ac1381eb50) +- Tests [`e10d0bb`](https://github.com/ljharb/call-bind/commit/e10d0bbdadc7a10ecedc9a1c035112d3e368b8df) +- Implementation [`43852ed`](https://github.com/ljharb/call-bind/commit/43852eda0f187327b7fad2423ca972149a52bd65) +- npm init [`408f860`](https://github.com/ljharb/call-bind/commit/408f860b773a2f610805fd3613d0d71bac1b6249) +- [meta] add Automatic Rebase and Require Allow Edits workflows [`fb349b2`](https://github.com/ljharb/call-bind/commit/fb349b2e48defbec8b5ec8a8395cc8f69f220b13) +- [meta] add `auto-changelog` [`c4001fc`](https://github.com/ljharb/call-bind/commit/c4001fc43031799ef908211c98d3b0fb2b60fde4) +- [meta] add "funding"; create `FUNDING.yml` [`d4d6d29`](https://github.com/ljharb/call-bind/commit/d4d6d2974a14bc2e98830468eda7fe6d6a776717) +- [Tests] add `npm run lint` [`dedfb98`](https://github.com/ljharb/call-bind/commit/dedfb98bd0ecefb08ddb9a94061bd10cde4332af) +- Only apps should have lockfiles [`54ac776`](https://github.com/ljharb/call-bind/commit/54ac77653db45a7361dc153d2f478e743f110650) +- [meta] add `safe-publish-latest` [`9ea8e43`](https://github.com/ljharb/call-bind/commit/9ea8e435b950ce9b705559cd651039f9bf40140f) diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/LICENSE b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/LICENSE new file mode 100644 index 0000000..48f05d0 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2020 Jordan Harband + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/README.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/README.md new file mode 100644 index 0000000..48e9047 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/README.md @@ -0,0 +1,64 @@ +# call-bind [![Version Badge][npm-version-svg]][package-url] + +[![github actions][actions-image]][actions-url] +[![coverage][codecov-image]][codecov-url] +[![dependency status][deps-svg]][deps-url] +[![dev dependency status][dev-deps-svg]][dev-deps-url] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] + +[![npm badge][npm-badge-png]][package-url] + +Robustly `.call.bind()` a function. + +## Getting started + +```sh +npm install --save call-bind +``` + +## Usage/Examples + +```js +const assert = require('assert'); +const callBind = require('call-bind'); +const callBound = require('call-bind/callBound'); + +function f(a, b) { + assert.equal(this, 1); + assert.equal(a, 2); + assert.equal(b, 3); + assert.equal(arguments.length, 2); +} + +const fBound = callBind(f); + +const slice = callBound('Array.prototype.slice'); + +delete Function.prototype.call; +delete Function.prototype.bind; + +fBound(1, 2, 3); + +assert.deepEqual(slice([1, 2, 3, 4], 1, -1), [2, 3]); +``` + +## Tests + +Clone the repo, `npm install`, and run `npm test` + +[package-url]: https://npmjs.org/package/call-bind +[npm-version-svg]: https://versionbadg.es/ljharb/call-bind.svg +[deps-svg]: https://david-dm.org/ljharb/call-bind.svg +[deps-url]: https://david-dm.org/ljharb/call-bind +[dev-deps-svg]: https://david-dm.org/ljharb/call-bind/dev-status.svg +[dev-deps-url]: https://david-dm.org/ljharb/call-bind#info=devDependencies +[npm-badge-png]: https://nodei.co/npm/call-bind.png?downloads=true&stars=true +[license-image]: https://img.shields.io/npm/l/call-bind.svg +[license-url]: LICENSE +[downloads-image]: https://img.shields.io/npm/dm/call-bind.svg +[downloads-url]: https://npm-stat.com/charts.html?package=call-bind +[codecov-image]: https://codecov.io/gh/ljharb/call-bind/branch/main/graphs/badge.svg +[codecov-url]: https://app.codecov.io/gh/ljharb/call-bind/ +[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/ljharb/call-bind +[actions-url]: https://github.com/ljharb/call-bind/actions diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/callBound.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/callBound.js new file mode 100644 index 0000000..8374adf --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/callBound.js @@ -0,0 +1,15 @@ +'use strict'; + +var GetIntrinsic = require('get-intrinsic'); + +var callBind = require('./'); + +var $indexOf = callBind(GetIntrinsic('String.prototype.indexOf')); + +module.exports = function callBoundIntrinsic(name, allowMissing) { + var intrinsic = GetIntrinsic(name, !!allowMissing); + if (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) { + return callBind(intrinsic); + } + return intrinsic; +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/index.js new file mode 100644 index 0000000..01c5b3d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/index.js @@ -0,0 +1,35 @@ +'use strict'; + +var bind = require('function-bind'); +var GetIntrinsic = require('get-intrinsic'); +var setFunctionLength = require('set-function-length'); + +var $TypeError = require('es-errors/type'); +var $apply = GetIntrinsic('%Function.prototype.apply%'); +var $call = GetIntrinsic('%Function.prototype.call%'); +var $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply); + +var $defineProperty = require('es-define-property'); +var $max = GetIntrinsic('%Math.max%'); + +module.exports = function callBind(originalFunction) { + if (typeof originalFunction !== 'function') { + throw new $TypeError('a function is required'); + } + var func = $reflectApply(bind, $call, arguments); + return setFunctionLength( + func, + 1 + $max(0, originalFunction.length - (arguments.length - 1)), + true + ); +}; + +var applyBind = function applyBind() { + return $reflectApply(bind, $apply, arguments); +}; + +if ($defineProperty) { + $defineProperty(module.exports, 'apply', { value: applyBind }); +} else { + module.exports.apply = applyBind; +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/package.json new file mode 100644 index 0000000..5ba88ff --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/package.json @@ -0,0 +1,95 @@ +{ + "name": "call-bind", + "version": "1.0.7", + "description": "Robustly `.call.bind()` a function", + "main": "index.js", + "exports": { + ".": "./index.js", + "./callBound": "./callBound.js", + "./package.json": "./package.json" + }, + "scripts": { + "prepack": "npmignore --auto --commentLines=auto", + "prepublish": "not-in-publish || npm run prepublishOnly", + "prepublishOnly": "safe-publish-latest", + "lint": "eslint --ext=.js,.mjs .", + "postlint": "evalmd README.md", + "pretest": "npm run lint", + "tests-only": "nyc tape 'test/**/*.js'", + "test": "npm run tests-only", + "posttest": "aud --production", + "version": "auto-changelog && git add CHANGELOG.md", + "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\"" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/ljharb/call-bind.git" + }, + "keywords": [ + "javascript", + "ecmascript", + "es", + "js", + "callbind", + "callbound", + "call", + "bind", + "bound", + "call-bind", + "call-bound", + "function", + "es-abstract" + ], + "author": "Jordan Harband ", + "funding": { + "url": "https://github.com/sponsors/ljharb" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/ljharb/call-bind/issues" + }, + "homepage": "https://github.com/ljharb/call-bind#readme", + "devDependencies": { + "@ljharb/eslint-config": "^21.1.0", + "aud": "^2.0.4", + "auto-changelog": "^2.4.0", + "es-value-fixtures": "^1.4.2", + "eslint": "=8.8.0", + "evalmd": "^0.0.19", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-strict-mode": "^1.0.1", + "in-publish": "^2.0.1", + "npmignore": "^0.3.1", + "nyc": "^10.3.2", + "object-inspect": "^1.13.1", + "safe-publish-latest": "^2.0.0", + "tape": "^5.7.4" + }, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "testling": { + "files": "test/index.js" + }, + "auto-changelog": { + "output": "CHANGELOG.md", + "template": "keepachangelog", + "unreleased": false, + "commitLimit": false, + "backfillLimit": false, + "hideCredit": true + }, + "publishConfig": { + "ignore": [ + ".github/workflows" + ] + }, + "engines": { + "node": ">= 0.4" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/callBound.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/callBound.js new file mode 100644 index 0000000..c32319d --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/callBound.js @@ -0,0 +1,54 @@ +'use strict'; + +var test = require('tape'); + +var callBound = require('../callBound'); + +test('callBound', function (t) { + // static primitive + t.equal(callBound('Array.length'), Array.length, 'Array.length yields itself'); + t.equal(callBound('%Array.length%'), Array.length, '%Array.length% yields itself'); + + // static non-function object + t.equal(callBound('Array.prototype'), Array.prototype, 'Array.prototype yields itself'); + t.equal(callBound('%Array.prototype%'), Array.prototype, '%Array.prototype% yields itself'); + t.equal(callBound('Array.constructor'), Array.constructor, 'Array.constructor yields itself'); + t.equal(callBound('%Array.constructor%'), Array.constructor, '%Array.constructor% yields itself'); + + // static function + t.equal(callBound('Date.parse'), Date.parse, 'Date.parse yields itself'); + t.equal(callBound('%Date.parse%'), Date.parse, '%Date.parse% yields itself'); + + // prototype primitive + t.equal(callBound('Error.prototype.message'), Error.prototype.message, 'Error.prototype.message yields itself'); + t.equal(callBound('%Error.prototype.message%'), Error.prototype.message, '%Error.prototype.message% yields itself'); + + // prototype function + t.notEqual(callBound('Object.prototype.toString'), Object.prototype.toString, 'Object.prototype.toString does not yield itself'); + t.notEqual(callBound('%Object.prototype.toString%'), Object.prototype.toString, '%Object.prototype.toString% does not yield itself'); + t.equal(callBound('Object.prototype.toString')(true), Object.prototype.toString.call(true), 'call-bound Object.prototype.toString calls into the original'); + t.equal(callBound('%Object.prototype.toString%')(true), Object.prototype.toString.call(true), 'call-bound %Object.prototype.toString% calls into the original'); + + t['throws']( + function () { callBound('does not exist'); }, + SyntaxError, + 'nonexistent intrinsic throws' + ); + t['throws']( + function () { callBound('does not exist', true); }, + SyntaxError, + 'allowMissing arg still throws for unknown intrinsic' + ); + + t.test('real but absent intrinsic', { skip: typeof WeakRef !== 'undefined' }, function (st) { + st['throws']( + function () { callBound('WeakRef'); }, + TypeError, + 'real but absent intrinsic throws' + ); + st.equal(callBound('WeakRef', true), undefined, 'allowMissing arg avoids exception'); + st.end(); + }); + + t.end(); +}); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/index.js new file mode 100644 index 0000000..1fd4668 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/call-bind/test/index.js @@ -0,0 +1,80 @@ +'use strict'; + +var callBind = require('../'); +var bind = require('function-bind'); +var gOPD = require('gopd'); +var hasStrictMode = require('has-strict-mode')(); +var forEach = require('for-each'); +var inspect = require('object-inspect'); +var v = require('es-value-fixtures'); + +var test = require('tape'); + +/* + * older engines have length nonconfigurable + * in io.js v3, it is configurable except on bound functions, hence the .bind() + */ +var functionsHaveConfigurableLengths = !!( + gOPD + && Object.getOwnPropertyDescriptor + && Object.getOwnPropertyDescriptor(bind.call(function () {}), 'length').configurable +); + +test('callBind', function (t) { + forEach(v.nonFunctions, function (nonFunction) { + t['throws']( + function () { callBind(nonFunction); }, + TypeError, + inspect(nonFunction) + ' is not a function' + ); + }); + + var sentinel = { sentinel: true }; + var func = function (a, b) { + // eslint-disable-next-line no-invalid-this + return [!hasStrictMode && this === global ? undefined : this, a, b]; + }; + t.equal(func.length, 2, 'original function length is 2'); + t.deepEqual(func(), [undefined, undefined, undefined], 'unbound func with too few args'); + t.deepEqual(func(1, 2), [undefined, 1, 2], 'unbound func with right args'); + t.deepEqual(func(1, 2, 3), [undefined, 1, 2], 'unbound func with too many args'); + + var bound = callBind(func); + t.equal(bound.length, func.length + 1, 'function length is preserved', { skip: !functionsHaveConfigurableLengths }); + t.deepEqual(bound(), [undefined, undefined, undefined], 'bound func with too few args'); + t.deepEqual(bound(1, 2), [hasStrictMode ? 1 : Object(1), 2, undefined], 'bound func with right args'); + t.deepEqual(bound(1, 2, 3), [hasStrictMode ? 1 : Object(1), 2, 3], 'bound func with too many args'); + + var boundR = callBind(func, sentinel); + t.equal(boundR.length, func.length, 'function length is preserved', { skip: !functionsHaveConfigurableLengths }); + t.deepEqual(boundR(), [sentinel, undefined, undefined], 'bound func with receiver, with too few args'); + t.deepEqual(boundR(1, 2), [sentinel, 1, 2], 'bound func with receiver, with right args'); + t.deepEqual(boundR(1, 2, 3), [sentinel, 1, 2], 'bound func with receiver, with too many args'); + + var boundArg = callBind(func, sentinel, 1); + t.equal(boundArg.length, func.length - 1, 'function length is preserved', { skip: !functionsHaveConfigurableLengths }); + t.deepEqual(boundArg(), [sentinel, 1, undefined], 'bound func with receiver and arg, with too few args'); + t.deepEqual(boundArg(2), [sentinel, 1, 2], 'bound func with receiver and arg, with right arg'); + t.deepEqual(boundArg(2, 3), [sentinel, 1, 2], 'bound func with receiver and arg, with too many args'); + + t.test('callBind.apply', function (st) { + var aBound = callBind.apply(func); + st.deepEqual(aBound(sentinel), [sentinel, undefined, undefined], 'apply-bound func with no args'); + st.deepEqual(aBound(sentinel, [1], 4), [sentinel, 1, undefined], 'apply-bound func with too few args'); + st.deepEqual(aBound(sentinel, [1, 2], 4), [sentinel, 1, 2], 'apply-bound func with right args'); + + var aBoundArg = callBind.apply(func); + st.deepEqual(aBoundArg(sentinel, [1, 2, 3], 4), [sentinel, 1, 2], 'apply-bound func with too many args'); + st.deepEqual(aBoundArg(sentinel, [1, 2], 4), [sentinel, 1, 2], 'apply-bound func with right args'); + st.deepEqual(aBoundArg(sentinel, [1], 4), [sentinel, 1, undefined], 'apply-bound func with too few args'); + + var aBoundR = callBind.apply(func, sentinel); + st.deepEqual(aBoundR([1, 2, 3], 4), [sentinel, 1, 2], 'apply-bound func with receiver and too many args'); + st.deepEqual(aBoundR([1, 2], 4), [sentinel, 1, 2], 'apply-bound func with receiver and right args'); + st.deepEqual(aBoundR([1], 4), [sentinel, 1, undefined], 'apply-bound func with receiver and too few args'); + + st.end(); + }); + + t.end(); +}); diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/index.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/index.d.ts new file mode 100644 index 0000000..9cd88f3 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/index.d.ts @@ -0,0 +1,415 @@ +/** +Basic foreground colors. + +[More colors here.](https://github.com/chalk/chalk/blob/master/readme.md#256-and-truecolor-color-support) +*/ +declare type ForegroundColor = + | 'black' + | 'red' + | 'green' + | 'yellow' + | 'blue' + | 'magenta' + | 'cyan' + | 'white' + | 'gray' + | 'grey' + | 'blackBright' + | 'redBright' + | 'greenBright' + | 'yellowBright' + | 'blueBright' + | 'magentaBright' + | 'cyanBright' + | 'whiteBright'; + +/** +Basic background colors. + +[More colors here.](https://github.com/chalk/chalk/blob/master/readme.md#256-and-truecolor-color-support) +*/ +declare type BackgroundColor = + | 'bgBlack' + | 'bgRed' + | 'bgGreen' + | 'bgYellow' + | 'bgBlue' + | 'bgMagenta' + | 'bgCyan' + | 'bgWhite' + | 'bgGray' + | 'bgGrey' + | 'bgBlackBright' + | 'bgRedBright' + | 'bgGreenBright' + | 'bgYellowBright' + | 'bgBlueBright' + | 'bgMagentaBright' + | 'bgCyanBright' + | 'bgWhiteBright'; + +/** +Basic colors. + +[More colors here.](https://github.com/chalk/chalk/blob/master/readme.md#256-and-truecolor-color-support) +*/ +declare type Color = ForegroundColor | BackgroundColor; + +declare type Modifiers = + | 'reset' + | 'bold' + | 'dim' + | 'italic' + | 'underline' + | 'inverse' + | 'hidden' + | 'strikethrough' + | 'visible'; + +declare namespace chalk { + /** + Levels: + - `0` - All colors disabled. + - `1` - Basic 16 colors support. + - `2` - ANSI 256 colors support. + - `3` - Truecolor 16 million colors support. + */ + type Level = 0 | 1 | 2 | 3; + + interface Options { + /** + Specify the color support for Chalk. + + By default, color support is automatically detected based on the environment. + + Levels: + - `0` - All colors disabled. + - `1` - Basic 16 colors support. + - `2` - ANSI 256 colors support. + - `3` - Truecolor 16 million colors support. + */ + level?: Level; + } + + /** + Return a new Chalk instance. + */ + type Instance = new (options?: Options) => Chalk; + + /** + Detect whether the terminal supports color. + */ + interface ColorSupport { + /** + The color level used by Chalk. + */ + level: Level; + + /** + Return whether Chalk supports basic 16 colors. + */ + hasBasic: boolean; + + /** + Return whether Chalk supports ANSI 256 colors. + */ + has256: boolean; + + /** + Return whether Chalk supports Truecolor 16 million colors. + */ + has16m: boolean; + } + + interface ChalkFunction { + /** + Use a template string. + + @remarks Template literals are unsupported for nested calls (see [issue #341](https://github.com/chalk/chalk/issues/341)) + + @example + ``` + import chalk = require('chalk'); + + log(chalk` + CPU: {red ${cpu.totalPercent}%} + RAM: {green ${ram.used / ram.total * 100}%} + DISK: {rgb(255,131,0) ${disk.used / disk.total * 100}%} + `); + ``` + + @example + ``` + import chalk = require('chalk'); + + log(chalk.red.bgBlack`2 + 3 = {bold ${2 + 3}}`) + ``` + */ + (text: TemplateStringsArray, ...placeholders: unknown[]): string; + + (...text: unknown[]): string; + } + + interface Chalk extends ChalkFunction { + /** + Return a new Chalk instance. + */ + Instance: Instance; + + /** + The color support for Chalk. + + By default, color support is automatically detected based on the environment. + + Levels: + - `0` - All colors disabled. + - `1` - Basic 16 colors support. + - `2` - ANSI 256 colors support. + - `3` - Truecolor 16 million colors support. + */ + level: Level; + + /** + Use HEX value to set text color. + + @param color - Hexadecimal value representing the desired color. + + @example + ``` + import chalk = require('chalk'); + + chalk.hex('#DEADED'); + ``` + */ + hex(color: string): Chalk; + + /** + Use keyword color value to set text color. + + @param color - Keyword value representing the desired color. + + @example + ``` + import chalk = require('chalk'); + + chalk.keyword('orange'); + ``` + */ + keyword(color: string): Chalk; + + /** + Use RGB values to set text color. + */ + rgb(red: number, green: number, blue: number): Chalk; + + /** + Use HSL values to set text color. + */ + hsl(hue: number, saturation: number, lightness: number): Chalk; + + /** + Use HSV values to set text color. + */ + hsv(hue: number, saturation: number, value: number): Chalk; + + /** + Use HWB values to set text color. + */ + hwb(hue: number, whiteness: number, blackness: number): Chalk; + + /** + Use a [Select/Set Graphic Rendition](https://en.wikipedia.org/wiki/ANSI_escape_code#SGR_parameters) (SGR) [color code number](https://en.wikipedia.org/wiki/ANSI_escape_code#3/4_bit) to set text color. + + 30 <= code && code < 38 || 90 <= code && code < 98 + For example, 31 for red, 91 for redBright. + */ + ansi(code: number): Chalk; + + /** + Use a [8-bit unsigned number](https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit) to set text color. + */ + ansi256(index: number): Chalk; + + /** + Use HEX value to set background color. + + @param color - Hexadecimal value representing the desired color. + + @example + ``` + import chalk = require('chalk'); + + chalk.bgHex('#DEADED'); + ``` + */ + bgHex(color: string): Chalk; + + /** + Use keyword color value to set background color. + + @param color - Keyword value representing the desired color. + + @example + ``` + import chalk = require('chalk'); + + chalk.bgKeyword('orange'); + ``` + */ + bgKeyword(color: string): Chalk; + + /** + Use RGB values to set background color. + */ + bgRgb(red: number, green: number, blue: number): Chalk; + + /** + Use HSL values to set background color. + */ + bgHsl(hue: number, saturation: number, lightness: number): Chalk; + + /** + Use HSV values to set background color. + */ + bgHsv(hue: number, saturation: number, value: number): Chalk; + + /** + Use HWB values to set background color. + */ + bgHwb(hue: number, whiteness: number, blackness: number): Chalk; + + /** + Use a [Select/Set Graphic Rendition](https://en.wikipedia.org/wiki/ANSI_escape_code#SGR_parameters) (SGR) [color code number](https://en.wikipedia.org/wiki/ANSI_escape_code#3/4_bit) to set background color. + + 30 <= code && code < 38 || 90 <= code && code < 98 + For example, 31 for red, 91 for redBright. + Use the foreground code, not the background code (for example, not 41, nor 101). + */ + bgAnsi(code: number): Chalk; + + /** + Use a [8-bit unsigned number](https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit) to set background color. + */ + bgAnsi256(index: number): Chalk; + + /** + Modifier: Resets the current color chain. + */ + readonly reset: Chalk; + + /** + Modifier: Make text bold. + */ + readonly bold: Chalk; + + /** + Modifier: Emitting only a small amount of light. + */ + readonly dim: Chalk; + + /** + Modifier: Make text italic. (Not widely supported) + */ + readonly italic: Chalk; + + /** + Modifier: Make text underline. (Not widely supported) + */ + readonly underline: Chalk; + + /** + Modifier: Inverse background and foreground colors. + */ + readonly inverse: Chalk; + + /** + Modifier: Prints the text, but makes it invisible. + */ + readonly hidden: Chalk; + + /** + Modifier: Puts a horizontal line through the center of the text. (Not widely supported) + */ + readonly strikethrough: Chalk; + + /** + Modifier: Prints the text only when Chalk has a color support level > 0. + Can be useful for things that are purely cosmetic. + */ + readonly visible: Chalk; + + readonly black: Chalk; + readonly red: Chalk; + readonly green: Chalk; + readonly yellow: Chalk; + readonly blue: Chalk; + readonly magenta: Chalk; + readonly cyan: Chalk; + readonly white: Chalk; + + /* + Alias for `blackBright`. + */ + readonly gray: Chalk; + + /* + Alias for `blackBright`. + */ + readonly grey: Chalk; + + readonly blackBright: Chalk; + readonly redBright: Chalk; + readonly greenBright: Chalk; + readonly yellowBright: Chalk; + readonly blueBright: Chalk; + readonly magentaBright: Chalk; + readonly cyanBright: Chalk; + readonly whiteBright: Chalk; + + readonly bgBlack: Chalk; + readonly bgRed: Chalk; + readonly bgGreen: Chalk; + readonly bgYellow: Chalk; + readonly bgBlue: Chalk; + readonly bgMagenta: Chalk; + readonly bgCyan: Chalk; + readonly bgWhite: Chalk; + + /* + Alias for `bgBlackBright`. + */ + readonly bgGray: Chalk; + + /* + Alias for `bgBlackBright`. + */ + readonly bgGrey: Chalk; + + readonly bgBlackBright: Chalk; + readonly bgRedBright: Chalk; + readonly bgGreenBright: Chalk; + readonly bgYellowBright: Chalk; + readonly bgBlueBright: Chalk; + readonly bgMagentaBright: Chalk; + readonly bgCyanBright: Chalk; + readonly bgWhiteBright: Chalk; + } +} + +/** +Main Chalk object that allows to chain styles together. +Call the last one as a method with a string argument. +Order doesn't matter, and later styles take precedent in case of a conflict. +This simply means that `chalk.red.yellow.green` is equivalent to `chalk.green`. +*/ +declare const chalk: chalk.Chalk & chalk.ChalkFunction & { + supportsColor: chalk.ColorSupport | false; + Level: chalk.Level; + Color: Color; + ForegroundColor: ForegroundColor; + BackgroundColor: BackgroundColor; + Modifiers: Modifiers; + stderr: chalk.Chalk & {supportsColor: chalk.ColorSupport | false}; +}; + +export = chalk; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/license b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/license new file mode 100644 index 0000000..e7af2f7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.d.ts b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.d.ts new file mode 100644 index 0000000..a0a48c8 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.d.ts @@ -0,0 +1,39 @@ +/** +Check if [`argv`](https://nodejs.org/docs/latest/api/process.html#process_process_argv) has a specific flag. + +@param flag - CLI flag to look for. The `--` prefix is optional. +@param argv - CLI arguments. Default: `process.argv`. +@returns Whether the flag exists. + +@example +``` +// $ ts-node foo.ts -f --unicorn --foo=bar -- --rainbow + +// foo.ts +import hasFlag = require('has-flag'); + +hasFlag('unicorn'); +//=> true + +hasFlag('--unicorn'); +//=> true + +hasFlag('f'); +//=> true + +hasFlag('-f'); +//=> true + +hasFlag('foo=bar'); +//=> true + +hasFlag('foo'); +//=> false + +hasFlag('rainbow'); +//=> false +``` +*/ +declare function hasFlag(flag: string, argv?: string[]): boolean; + +export = hasFlag; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.js new file mode 100644 index 0000000..b6f80b1 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/index.js @@ -0,0 +1,8 @@ +'use strict'; + +module.exports = (flag, argv = process.argv) => { + const prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--'); + const position = argv.indexOf(prefix + flag); + const terminatorPosition = argv.indexOf('--'); + return position !== -1 && (terminatorPosition === -1 || position < terminatorPosition); +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/license b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/license new file mode 100644 index 0000000..e7af2f7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/package.json new file mode 100644 index 0000000..a9cba4b --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/package.json @@ -0,0 +1,46 @@ +{ + "name": "has-flag", + "version": "4.0.0", + "description": "Check if argv has a specific flag", + "license": "MIT", + "repository": "sindresorhus/has-flag", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "sindresorhus.com" + }, + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "xo && ava && tsd" + }, + "files": [ + "index.js", + "index.d.ts" + ], + "keywords": [ + "has", + "check", + "detect", + "contains", + "find", + "flag", + "cli", + "command-line", + "argv", + "process", + "arg", + "args", + "argument", + "arguments", + "getopt", + "minimist", + "optimist" + ], + "devDependencies": { + "ava": "^1.4.1", + "tsd": "^0.7.2", + "xo": "^0.24.0" + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/readme.md new file mode 100644 index 0000000..3f72dff --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/has-flag/readme.md @@ -0,0 +1,89 @@ +# has-flag [![Build Status](https://travis-ci.org/sindresorhus/has-flag.svg?branch=master)](https://travis-ci.org/sindresorhus/has-flag) + +> Check if [`argv`](https://nodejs.org/docs/latest/api/process.html#process_process_argv) has a specific flag + +Correctly stops looking after an `--` argument terminator. + +--- + +
+ +--- + + +## Install + +``` +$ npm install has-flag +``` + + +## Usage + +```js +// foo.js +const hasFlag = require('has-flag'); + +hasFlag('unicorn'); +//=> true + +hasFlag('--unicorn'); +//=> true + +hasFlag('f'); +//=> true + +hasFlag('-f'); +//=> true + +hasFlag('foo=bar'); +//=> true + +hasFlag('foo'); +//=> false + +hasFlag('rainbow'); +//=> false +``` + +``` +$ node foo.js -f --unicorn --foo=bar -- --rainbow +``` + + +## API + +### hasFlag(flag, [argv]) + +Returns a boolean for whether the flag exists. + +#### flag + +Type: `string` + +CLI flag to look for. The `--` prefix is optional. + +#### argv + +Type: `string[]`
+Default: `process.argv` + +CLI arguments. + + +## Security + +To report a security vulnerability, please use the [Tidelift security contact](https://tidelift.com/security). Tidelift will coordinate the fix and disclosure. + + +## License + +MIT © [Sindre Sorhus](https://sindresorhus.com) diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/browser.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/browser.js new file mode 100644 index 0000000..62afa3a --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/browser.js @@ -0,0 +1,5 @@ +'use strict'; +module.exports = { + stdout: false, + stderr: false +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/index.js b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/index.js new file mode 100644 index 0000000..6fada39 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/index.js @@ -0,0 +1,135 @@ +'use strict'; +const os = require('os'); +const tty = require('tty'); +const hasFlag = require('has-flag'); + +const {env} = process; + +let forceColor; +if (hasFlag('no-color') || + hasFlag('no-colors') || + hasFlag('color=false') || + hasFlag('color=never')) { + forceColor = 0; +} else if (hasFlag('color') || + hasFlag('colors') || + hasFlag('color=true') || + hasFlag('color=always')) { + forceColor = 1; +} + +if ('FORCE_COLOR' in env) { + if (env.FORCE_COLOR === 'true') { + forceColor = 1; + } else if (env.FORCE_COLOR === 'false') { + forceColor = 0; + } else { + forceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3); + } +} + +function translateLevel(level) { + if (level === 0) { + return false; + } + + return { + level, + hasBasic: true, + has256: level >= 2, + has16m: level >= 3 + }; +} + +function supportsColor(haveStream, streamIsTTY) { + if (forceColor === 0) { + return 0; + } + + if (hasFlag('color=16m') || + hasFlag('color=full') || + hasFlag('color=truecolor')) { + return 3; + } + + if (hasFlag('color=256')) { + return 2; + } + + if (haveStream && !streamIsTTY && forceColor === undefined) { + return 0; + } + + const min = forceColor || 0; + + if (env.TERM === 'dumb') { + return min; + } + + if (process.platform === 'win32') { + // Windows 10 build 10586 is the first Windows release that supports 256 colors. + // Windows 10 build 14931 is the first release that supports 16m/TrueColor. + const osRelease = os.release().split('.'); + if ( + Number(osRelease[0]) >= 10 && + Number(osRelease[2]) >= 10586 + ) { + return Number(osRelease[2]) >= 14931 ? 3 : 2; + } + + return 1; + } + + if ('CI' in env) { + if (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') { + return 1; + } + + return min; + } + + if ('TEAMCITY_VERSION' in env) { + return /^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0; + } + + if (env.COLORTERM === 'truecolor') { + return 3; + } + + if ('TERM_PROGRAM' in env) { + const version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10); + + switch (env.TERM_PROGRAM) { + case 'iTerm.app': + return version >= 3 ? 3 : 2; + case 'Apple_Terminal': + return 2; + // No default + } + } + + if (/-256(color)?$/i.test(env.TERM)) { + return 2; + } + + if (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) { + return 1; + } + + if ('COLORTERM' in env) { + return 1; + } + + return min; +} + +function getSupportLevel(stream) { + const level = supportsColor(stream, stream && stream.isTTY); + return translateLevel(level); +} + +module.exports = { + supportsColor: getSupportLevel, + stdout: translateLevel(supportsColor(true, tty.isatty(1))), + stderr: translateLevel(supportsColor(true, tty.isatty(2))) +}; diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/license b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/license new file mode 100644 index 0000000..e7af2f7 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/package.json new file mode 100644 index 0000000..f7182ed --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/package.json @@ -0,0 +1,53 @@ +{ + "name": "supports-color", + "version": "7.2.0", + "description": "Detect whether a terminal supports color", + "license": "MIT", + "repository": "chalk/supports-color", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "sindresorhus.com" + }, + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "xo && ava" + }, + "files": [ + "index.js", + "browser.js" + ], + "keywords": [ + "color", + "colour", + "colors", + "terminal", + "console", + "cli", + "ansi", + "styles", + "tty", + "rgb", + "256", + "shell", + "xterm", + "command-line", + "support", + "supports", + "capability", + "detect", + "truecolor", + "16m" + ], + "dependencies": { + "has-flag": "^4.0.0" + }, + "devDependencies": { + "ava": "^1.4.1", + "import-fresh": "^3.0.0", + "xo": "^0.24.0" + }, + "browser": "browser.js" +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/readme.md new file mode 100644 index 0000000..3654228 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/node_modules/supports-color/readme.md @@ -0,0 +1,76 @@ +# supports-color [![Build Status](https://travis-ci.org/chalk/supports-color.svg?branch=master)](https://travis-ci.org/chalk/supports-color) + +> Detect whether a terminal supports color + + +## Install + +``` +$ npm install supports-color +``` + + +## Usage + +```js +const supportsColor = require('supports-color'); + +if (supportsColor.stdout) { + console.log('Terminal stdout supports color'); +} + +if (supportsColor.stdout.has256) { + console.log('Terminal stdout supports 256 colors'); +} + +if (supportsColor.stderr.has16m) { + console.log('Terminal stderr supports 16 million colors (truecolor)'); +} +``` + + +## API + +Returns an `Object` with a `stdout` and `stderr` property for testing either streams. Each property is an `Object`, or `false` if color is not supported. + +The `stdout`/`stderr` objects specifies a level of support for color through a `.level` property and a corresponding flag: + +- `.level = 1` and `.hasBasic = true`: Basic color support (16 colors) +- `.level = 2` and `.has256 = true`: 256 color support +- `.level = 3` and `.has16m = true`: Truecolor support (16 million colors) + + +## Info + +It obeys the `--color` and `--no-color` CLI flags. + +For situations where using `--color` is not possible, use the environment variable `FORCE_COLOR=1` (level 1), `FORCE_COLOR=2` (level 2), or `FORCE_COLOR=3` (level 3) to forcefully enable color, or `FORCE_COLOR=0` to forcefully disable. The use of `FORCE_COLOR` overrides all other color support checks. + +Explicit 256/Truecolor mode can be enabled using the `--color=256` and `--color=16m` flags, respectively. + + +## Related + +- [supports-color-cli](https://github.com/chalk/supports-color-cli) - CLI for this module +- [chalk](https://github.com/chalk/chalk) - Terminal string styling done right + + +## Maintainers + +- [Sindre Sorhus](https://github.com/sindresorhus) +- [Josh Junon](https://github.com/qix-) + + +--- + +
+ + Get professional support for this package with a Tidelift subscription + +
+ + Tidelift helps make open source sustainable for maintainers while giving companies
assurances about security, maintenance, and licensing for their dependencies. +
+
+ +--- diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/package.json b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/package.json new file mode 100644 index 0000000..47c23f2 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/package.json @@ -0,0 +1,68 @@ +{ + "name": "chalk", + "version": "4.1.2", + "description": "Terminal string styling done right", + "license": "MIT", + "repository": "chalk/chalk", + "funding": "https://github.com/chalk/chalk?sponsor=1", + "main": "source", + "engines": { + "node": ">=10" + }, + "scripts": { + "test": "xo && nyc ava && tsd", + "bench": "matcha benchmark.js" + }, + "files": [ + "source", + "index.d.ts" + ], + "keywords": [ + "color", + "colour", + "colors", + "terminal", + "console", + "cli", + "string", + "str", + "ansi", + "style", + "styles", + "tty", + "formatting", + "rgb", + "256", + "shell", + "xterm", + "log", + "logging", + "command-line", + "text" + ], + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "devDependencies": { + "ava": "^2.4.0", + "coveralls": "^3.0.7", + "execa": "^4.0.0", + "import-fresh": "^3.1.0", + "matcha": "^0.7.0", + "nyc": "^15.0.0", + "resolve-from": "^5.0.0", + "tsd": "^0.7.4", + "xo": "^0.28.2" + }, + "xo": { + "rules": { + "unicorn/prefer-string-slice": "off", + "unicorn/prefer-includes": "off", + "@typescript-eslint/member-ordering": "off", + "no-redeclare": "off", + "unicorn/string-content": "off", + "unicorn/better-regex": "off" + } + } +} diff --git a/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/readme.md b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/readme.md new file mode 100644 index 0000000..a055d21 --- /dev/null +++ b/Suli/13.b/Frontend/Javascript/2024. 11. 18/node_modules/chalk/readme.md @@ -0,0 +1,341 @@ +

+
+
+ Chalk +
+
+
+

+ +> Terminal string styling done right + +[![Build Status](https://travis-ci.org/chalk/chalk.svg?branch=master)](https://travis-ci.org/chalk/chalk) [![Coverage Status](https://coveralls.io/repos/github/chalk/chalk/badge.svg?branch=master)](https://coveralls.io/github/chalk/chalk?branch=master) [![npm dependents](https://badgen.net/npm/dependents/chalk)](https://www.npmjs.com/package/chalk?activeTab=dependents) [![Downloads](https://badgen.net/npm/dt/chalk)](https://www.npmjs.com/package/chalk) [![](https://img.shields.io/badge/unicorn-approved-ff69b4.svg)](https://www.youtube.com/watch?v=9auOCbH5Ns4) [![XO code style](https://img.shields.io/badge/code_style-XO-5ed9c7.svg)](https://github.com/xojs/xo) ![TypeScript-ready](https://img.shields.io/npm/types/chalk.svg) [![run on repl.it](https://repl.it/badge/github/chalk/chalk)](https://repl.it/github/chalk/chalk) + + + +
+ +--- + + + +--- + +
+ +## Highlights + +- Expressive API +- Highly performant +- Ability to nest styles +- [256/Truecolor color support](#256-and-truecolor-color-support) +- Auto-detects color support +- Doesn't extend `String.prototype` +- Clean and focused +- Actively maintained +- [Used by ~50,000 packages](https://www.npmjs.com/browse/depended/chalk) as of January 1, 2020 + +## Install + +```console +$ npm install chalk +``` + +## Usage + +```js +const chalk = require('chalk'); + +console.log(chalk.blue('Hello world!')); +``` + +Chalk comes with an easy to use composable API where you just chain and nest the styles you want. + +```js +const chalk = require('chalk'); +const log = console.log; + +// Combine styled and normal strings +log(chalk.blue('Hello') + ' World' + chalk.red('!')); + +// Compose multiple styles using the chainable API +log(chalk.blue.bgRed.bold('Hello world!')); + +// Pass in multiple arguments +log(chalk.blue('Hello', 'World!', 'Foo', 'bar', 'biz', 'baz')); + +// Nest styles +log(chalk.red('Hello', chalk.underline.bgBlue('world') + '!')); + +// Nest styles of the same type even (color, underline, background) +log(chalk.green( + 'I am a green line ' + + chalk.blue.underline.bold('with a blue substring') + + ' that becomes green again!' +)); + +// ES2015 template literal +log(` +CPU: ${chalk.red('90%')} +RAM: ${chalk.green('40%')} +DISK: ${chalk.yellow('70%')} +`); + +// ES2015 tagged template literal +log(chalk` +CPU: {red ${cpu.totalPercent}%} +RAM: {green ${ram.used / ram.total * 100}%} +DISK: {rgb(255,131,0) ${disk.used / disk.total * 100}%} +`); + +// Use RGB colors in terminal emulators that support it. +log(chalk.keyword('orange')('Yay for orange colored text!')); +log(chalk.rgb(123, 45, 67).underline('Underlined reddish color')); +log(chalk.hex('#DEADED').bold('Bold gray!')); +``` + +Easily define your own themes: + +```js +const chalk = require('chalk'); + +const error = chalk.bold.red; +const warning = chalk.keyword('orange'); + +console.log(error('Error!')); +console.log(warning('Warning!')); +``` + +Take advantage of console.log [string substitution](https://nodejs.org/docs/latest/api/console.html#console_console_log_data_args): + +```js +const name = 'Sindre'; +console.log(chalk.green('Hello %s'), name); +//=> 'Hello Sindre' +``` + +## API + +### chalk.` + + + + Fork me on GitHub + +
+ +
+ + + + +
+ +

javascript-natural-sort + by overset

+ +
+ A fast and lightweight function to be used in conjunction with the Array.sort() using the browser's default bubble sort. This will properly sort padded numbers, numbers preceding text, dates, floats, etc. +
+ + + + + + + + +

License

+

MIT

+ + + +

Authors

+

Jim Palmer (jimpalmer@gmail.com)

+ + + +

Contact

+

Jim Palmer (jimpalmer@gmail.com)

+ + +

Download

+

+ You can download this project in either + zip or + tar formats. +

+

You can also clone the project with Git + by running: +

$ git clone git://github.com/overset/javascript-natural-sort
+

+ + + +
+ + +" + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/naturalSort.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/naturalSort.js new file mode 100644 index 0000000..28dd64d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/naturalSort.js @@ -0,0 +1,45 @@ +/* + * Natural Sort algorithm for Javascript - Version 0.7 - Released under MIT license + * Author: Jim Palmer (based on chunking idea from Dave Koelle) + */ +/*jshint unused:false */ +module.exports = function naturalSort (a, b) { + "use strict"; + var re = /(^([+\-]?(?:0|[1-9]\d*)(?:\.\d*)?(?:[eE][+\-]?\d+)?)?$|^0x[0-9a-f]+$|\d+)/gi, + sre = /(^[ ]*|[ ]*$)/g, + dre = /(^([\w ]+,?[\w ]+)?[\w ]+,?[\w ]+\d+:\d+(:\d+)?[\w ]?|^\d{1,4}[\/\-]\d{1,4}[\/\-]\d{1,4}|^\w+, \w+ \d+, \d{4})/, + hre = /^0x[0-9a-f]+$/i, + ore = /^0/, + i = function(s) { return naturalSort.insensitive && ('' + s).toLowerCase() || '' + s; }, + // convert all to strings strip whitespace + x = i(a).replace(sre, '') || '', + y = i(b).replace(sre, '') || '', + // chunk/tokenize + xN = x.replace(re, '\0$1\0').replace(/\0$/,'').replace(/^\0/,'').split('\0'), + yN = y.replace(re, '\0$1\0').replace(/\0$/,'').replace(/^\0/,'').split('\0'), + // numeric, hex or date detection + xD = parseInt(x.match(hre), 16) || (xN.length !== 1 && x.match(dre) && Date.parse(x)), + yD = parseInt(y.match(hre), 16) || xD && y.match(dre) && Date.parse(y) || null, + oFxNcL, oFyNcL; + // first try and sort Hex codes or Dates + if (yD) { + if ( xD < yD ) { return -1; } + else if ( xD > yD ) { return 1; } + } + // natural sorting through split numeric strings and default strings + for(var cLoc=0, numS=Math.max(xN.length, yN.length); cLoc < numS; cLoc++) { + // find floats not starting with '0', string or 0 if not defined (Clint Priest) + oFxNcL = !(xN[cLoc] || '').match(ore) && parseFloat(xN[cLoc]) || xN[cLoc] || 0; + oFyNcL = !(yN[cLoc] || '').match(ore) && parseFloat(yN[cLoc]) || yN[cLoc] || 0; + // handle numeric vs string comparison - number < string - (Kyle Adams) + if (isNaN(oFxNcL) !== isNaN(oFyNcL)) { return (isNaN(oFxNcL)) ? 1 : -1; } + // rely on string comparison if different types - i.e. '02' < 2 != '02' < '2' + else if (typeof oFxNcL !== typeof oFyNcL) { + oFxNcL += ''; + oFyNcL += ''; + } + if (oFxNcL < oFyNcL) { return -1; } + if (oFxNcL > oFyNcL) { return 1; } + } + return 0; +}; diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/package.json new file mode 100644 index 0000000..4b1bf07 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/package.json @@ -0,0 +1,27 @@ +{ + "name": "javascript-natural-sort", + "version": "0.7.1", + "description": "Natural Sort algorithm for Javascript - Version 0.7 - Released under MIT license", + "main": "naturalSort.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "repository": { + "type": "git", + "url": "https://github.com/Bill4Time/javascript-natural-sort.git" + }, + "keywords": [ + "natural", + "sort", + "javascript", + "array", + "sort", + "sorting" + ], + "author": "Jim Palmer (based on chunking idea from Dave Koelle, packaged by @khous of Bill4Time)", + "license": "MIT", + "bugs": { + "url": "https://github.com/Bill4Time/javascript-natural-sort/issues" + }, + "homepage": "https://github.com/Bill4Time/javascript-natural-sort" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/speed-tests.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/speed-tests.html new file mode 100644 index 0000000..090259b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/speed-tests.html @@ -0,0 +1,105 @@ + + + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/unit-tests.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/unit-tests.html new file mode 100644 index 0000000..7b11540 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/javascript-natural-sort/unit-tests.html @@ -0,0 +1,365 @@ + + + + js-naturalsort test suite + + + + + + + +

js-naturalsort test suite

+

+

+
    + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/CONTRIBUTING.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/CONTRIBUTING.md new file mode 100644 index 0000000..474a34f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/CONTRIBUTING.md @@ -0,0 +1,24 @@ +## Contributing + +Contributions to the math.js library are very welcome! We can't do this alone. You can contribute in different ways: spread the word, report bugs, come up with ideas and suggestions, and contribute to the code. + +### What can I do? + +Search through the [issues](https://github.com/josdejong/mathjs/issues) looking for bugs that you can help fix, or look at [discussions/ideas](https://github.com/josdejong/mathjs/discussions/categories/ideas) to see if there is an idea for a new feature that that looks interesting to pick up. + +### There are a few preferences regarding code contributions: + +- The code of math.js follows the JavaScript Standard Style as described on https://standardjs.com/, powered by `eslint`. Run `npm run lint` to test, and `npm run format` to automatically adjust your code to the code style. +- Make sure you properly unit test your changes. +- Before creating a pull request, run the unit tests to make sure they all pass. +- Only commit changes done in the source files under `src`, not to the generated builds + which are located in the folders `dist` and `lib`. +- Send pull requests to the `develop` branch, not the `master` branch. + +### FAQ + +- How to implement a new function? Answer: See the section [Implementing a new function](README.md#implementing-a-new-function) in the README.md. +- Where to find more documentation? Answer: best starting point is the project's [README.md](https://github.com/josdejong/mathjs#readme) file. +- I'm not sure how/where to start, what now? Answer: feel free to ask when in doubt, just [open an issue](https://github.com/josdejong/mathjs/issues) and discuss your thoughts and questions. + +Thanks! diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/HISTORY.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/HISTORY.md new file mode 100644 index 0000000..52a11aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/HISTORY.md @@ -0,0 +1,2960 @@ +# History + +# 2204-10-02 13.2.0 + +- Feat: improve performance of functions `map`, `filter` and `forEach` (#3256). + Thanks @dvd101x. +- Feat: improve performance of the methods `map()` and `forEach()` + of `DenseMatrix` (#3251). Thanks @Galm007. +- Fix: #3253 cannot use identifiers containing special characters in function + `derivative`. +- Fix: improve the type definitions of `ConstantNode` to support all data + types (#3257). Thanks @smith120bh. +- Fix: #3259 function `symbolicEqual` missing in the TypeScript definitions. +- Fix: #3246 function `leafCount` missing in the TypeScript definitions. +- Fix: #3267 implicit multiplication with a negative number and unit `in`. +- Docs: fix broken links on the Configuration page. Thanks @vassudanagunta. +- Docs: document the syntax of `map` and `forEach` in the expression parser + (#3272). Thanks @dvd101x. + +# 2024-08-27, 13.1.1 + +- Fix security vulnerability in the CLI and web API allowing to call functions + `import`, `createUnit` and `reviver`, allowing to get access to the internal + math namespace and allowing arbitrary code execution. Thanks @StarlightPWN. +- Fix security vulnerability: when overwriting a `rawArgs` function with a + non-`rawArgs` function, it was still called with raw arguments. This was both + a functional issue and a security issue. Thanks @StarlightPWN. +- Fix security vulnerability: ensure that `ObjectWrappingMap` cannot delete + unsafe properties. Thanks @StarlightPWN. +- Fix: not being able to use methods and properties on arrays inside the + expression parser. + +# 2024-08-26, 13.1.0 + +- Feat: support multiple inputs in function `map` (#3228, #3196). + Thanks @dvd101x. +- Feat: add matrix datatypes in more cases (#3235). Thanks @dvd101x. +- Feat: export util functions `isMap`, `isPartitionedMap`, and + `isObjectWrappingMap`. +- Fix: #3241 function `map` not always working with matrices (#3242). + Thanks @dvd101x. +- Fix: #3244 fix broken link to `ResultSet` in the docs about classes. +- Docs: add a link to the documentation page about the syntax expression + from the function `evaluate` (see #3238). +- Docs: improve the documentation of `scope` and fix the example + `custom_scope_objects.js` (#3150) +- Docs: spelling fixes in the embedded docs (#3252). Thanks @dvd101x. + +# 2024-07-19, 13.0.3 + +- Fix: #3232 fix type definitions of function `format` to support notations + `hex`, `bin`, and `oct`. +- Fix: use more precise definitions for US liquid volume units (#3229). + Thanks @Vistinum. +- Fix: #2286 types static methods and members for Unit class (#3230). + Thanks @orelbn. + +# 2024-07-04, 13.0.2 + +- Fix an error in the type definitions of `quantileSeq` (#3223). + Thanks @domdomegg. + +# 2024-06-28, 13.0.1 + +- Fix: #3227 generated bundle containing `catch` blocks without parameters. +- Fix: #2348 update type definitions of the `Parser` methods (#3226). + Thanks @orelbn. + +# 2024-05-31, 13.0.0 + +Breaking changes: + +- Change `isZero`, `isPositive`, and `isNegative` to respect `config.epsilon` + (#3139, #2838). +- Change the behavior of the internal `nearlyEqual` to align with Python and + Julia (#3152, #2838) +- Upgrade to `fraction.js@4.3.7`, + see . +- Dropped support for JavaScript engines that do not fully support ES6 or + `bigint`, or are not actively maintained. ES2020 is now the minimum required + EcmaScript version. + +Non-breaking changes: + +- Implemented support for `bigint` (#3207, #3207) +- Implemented a new config option `config.numberFallback` needed for `bigint` + (#3207). +- Internal: refactored tooling to ES modules and upgraded all devDependencies. + +# 2024-05-31, 12.4.3 + +- Fix: serialization of Units without a value, see #1240. +- Fix: outdated, incorrect documentation about the order of precedence for + operator modulus `%`. See #3189. +- Fix: #3197 improve `quantileSeq` type definitions (#3198). Thanks @domdomegg. + +# 2024-04-24, 12.4.2 + +- Fix #3192: function `isNaN` returns `false` for `NaN` units in a matrix or + array (#3193). Thanks @lgerin. +- Fix: #3180 fix type definitions of functions `add` and `multiply` to allow + more than two arguments. +- Docs: correct the docs about `traverse` returning void (#3177). + Thanks @rohildshah. + +# 2024-03-13, 12.4.1 + +- Docs: implement an interactive version of the Lorenz example, and show the + chart full screen (#3151). Thanks @dvd101x. +- Fix #3172: simplify `"true and true"`. +- Fix #3163: `toTex` wrongly returning `Infinity` for large BigNumbers. +- Fix #3162: add license information about CSParse (#3164). +- Fix #3175: cannot delete units using `math.Unit.deleteUnit`. +- Fix: faster startup time of the CLI and REPL by loading the bundle. +- Fix: remove using polyfill.io inside the example + `pretty_printing_with_mathjax.html` (#3167). Thanks @SukkaW. + +# 2024-02-22, 12.4.0 + +- Feat: implement support for trailing commas in matrices (#3154, #2968). + Thanks @dvd101x. +- Feat: improve the performance of `multiply` a lot by adding matrix type + inferencing (#3149). Thanks @RandomGamingDev. +- Fix: #3100 function `round` not handling round-off errors (#3136). + Thanks @BrianFugate. +- Fix: `PartitionedMap` and `ObjectWrappingMap` missing a property + `Symbol.iterator`, causing problems when trying `new Map(scope)` (#3156). +- Fix: type definitions of function `mode` (#3153). Thanks @rich-martinez. +- Docs: describe method `getAllAsMap` in the Parser docs (#3158, #3157). + Thanks @dvd101x. + +# 2024-02-08, 12.3.2 + +- Improved the performance of custom defined functions in the expression + parser (#3150). +- Fix: #3143 cannot use `and` and `or` inside a function definition. + Regression since `v12.1.0` (#3150). + +# 2024-02-01, 12.3.1 + +- Improved the typings of the arguments of `ArrayNode`, `FunctionNode`, + `IndexNode`, `OperatorNode`, and `RelationalNode` (#3123). Thanks @sylee957. +- Added a fully featured code editor example with CodeMirror and Katex (#3027). + Thanks @dvd101x. +- Fix: #3114 build warnings related to a number of wrong `/* #__PURE__ */` + annotations. +- Fix: #3142 support BigNumber values for the options of function `format`: + `precision`, `wordSize`, `lowerExp`, `upperExp`. Support BigNumber values + for the option `wordSize` in the functions `hex`, `bin`, and `oct`. +- Fix: #3125 type definitions of function `hypot` (#3144). + Thanks @silentmissile. +- Fix: #3141 `help(config)` altering the actual `config` when evaluating the + examples. +- Docs: #3145 fix documentation about REPL, it does require a build step + nowadays. + +# 2024-01-12, 12.3.0 + +- Implement support new metric prefixes: `ronna` (`R`), `quetta` (`Q`), + `ronto` (`r`), and `quecto` (`q`) (#3113, #3112). Thanks @AlexEdgcomb. +- Fix a bug converting a unitless unit (#3117). Thanks @costerwi. +- Fix: #3097 `toSI()` wrongly converting `degC` (#3118). Thanks @costerwi. + +# 2023-12-20, 12.2.1 + +- Fix #3109: method `Node.toHTML` not accepting a custom `handler`. + +# 2023-12-08, 12.2.0 + +- Feat: lazy evaluation of operators `and`, `or`, `&`, `|` (#3090, #3101, + #2766). Thanks @smith120bh. +- Fix: passing a 4th argument with a scope to raw functions. +- Fix: #3096 embedded docs of eigs throwing an error. + +# 2023-11-17, 12.1.0 + +- Feat: Extend function `round` with support for units (#2761, #3095). +- Feat: Extend function `mod` with support for negative divisors in when + using `BigNumber` or `Fraction` (#3087). +- Fix: #3092 a typo in an error message when converting a string into a number. +- Fix: #3094 function `derivative` mutates the input expression when it fails. + +# 2023-10-26, 12.0.0 + +Breaking changes: + +- Fix #2879, #2927, #3014: change the confusing interface of `eigs` (#3037), + thanks @gwhitney. + Before, functions `eigs` returned an object: + + ``` + { values: MathCollection; vectors: MathCollection } + ``` + + where `vectors` was a 2d matrix of which the columns contained the vectors. + This is changed to `eigs` returning an object: + + ``` + { + values: MathCollection + eigenvectors: Array<{ + value: number | BigNumber + vector: MathCollection + }> + } + ``` + + Where `eigenvectors` is an array containing an object with the corresponding + eigenvalue and vector. +- Refactored the TypeScript type definitions to make them work with a `NodeNext` + module resolution (#3079, #2919). + - Type `MathJsStatic` is renamed to `MathJsInstance`. + - Type `FactoryDependencies` is deprecated, use `MathJsFactory` instead, and + import dependency maps directly from the library. +- Change the assignment operator of `.toTex()` output from `:=` to `=` (see + #2980, #2987). +- Drop official support for Node.js 14 and 16. + +Features: + +- Function `eigs` now has an option to turn off calculation of eigenvectors + (#3057, #2180). Thanks @gwhitney. + +Fixes: + +- Find eigenvectors of defective matrices (#3037). Thanks @gwhitney. + +# 2023-10-26, 11.12.0 + +- Implemented function `subtractScalar` (#3081, #2643), thanks @vrushaket. +- Fix #3073: function format not escaping control characters and double + quotes (#3082). +- Fix: function `clone` not throwing an error when passing an unsupported + type like a function. +- Fix: #2960 add type definition of function `symbolicEqual` (#3035), + thanks @juancodeaudio. + +# 2023-10-11, 11.11.2 + +- Fix #3025: improve handling of matrices and error handling + in function `corr` (#3030). Thanks @vrushaket. +- Fix #3074: improve error message when using function `max` in `derivative`. +- Fix #3073: fix parsing quotes inside a string. +- Fix #2027: cannot use named operators like `to` or `mod` as property name. + +# 2023-09-20, 11.11.1 + +- Fix #2989: use one-based indices in `print` in the parser (#3009). + Thanks @dvd101x. +- Fix #2936: `mod` sometimes giving wrong results due to internal round-off + errors (#3011). Thanks @praisennamonu1. +- Internal refactor of `quantileSeq`, and fixed the embedded help (#3003). + Thanks @dvd101x. +- Updated dependencies and devDependencies. + +# 2023-09-05, 11.11.0 + +- Implement function `corr` to calculate the correlation between two matrices + (#3015, #2624). Thanks @vrushaket. +- Lock `fraction.js` at version `4.3.4` for now, see #3024, 3022, + . + +# 2023-08-31, 11.10.1 + +- Upgrade to `fraction.js@4.3.4`, see #3022. +- Fix #3020: `lruQueue` using the global `hasOwnProperty` which may be + polluted. +- Add support for prefixes for the unit `erg`, and restrict prefixes of the + unit `joule` to only long prefixes like `kilo` and no short prefixes + like `k` (#3019). Thanks @costerwi. +- Add a new browser example `examples/browser/lorenz.html` that uses `solveODE` + and plots the result in a chart (#3018). Thanks @dvd101x. + +# 2023-08-23, 11.10.0 + +- Extend function `quantileSeq` with support for a `dimension` (#3002). + Thanks @dvd101x. +- Implement #2735: Support indexing with an array of booleans, for + example `a[[true, false, true]]` and `a[a > 2]` (#2994). Thanks @dvd101x. +- Implement function `zeta` (#2950, #2975, #2904). Thanks @Bobingstern. +- Fix #2990: `DenseMatrix` can mutate input arrays (#2991). + +# 2023-07-24, 11.9.1 + +- Fix a security vulnerability in `FunctionNode` and `SymbolNode` allowing + arbitrary code execution via `math.evaluate`. Thanks Harry Chen. +- Fix #3001: mathjs bundle containing `new Function(...)` (CSP issue). + +# 2023-07-19, 11.9.0 + +- Implement function `solveODE` (#2958). Thanks @dvd101x. +- Implement functions `zpk2tf` and `freqz` (#2988, #2969). Thanks @alykhaled. +- Implement support for units in function `range` (#2997). Thanks @dvd101x. +- Fix #2974: `simplify` puts plus and minus signs next to each other (#2981). + Thanks @MaybePixem. +- Fix #2973: fixes and improvements in the embedded docs (#2976). + Thanks @dvd101x. +- Fix #2996: two errors in the examples in the documentation about Expression + trees. +- Fix round-off errors near zero when converting temperatures (#2962). + Thanks @costerwi. +- Refactored function `range`, reducing the amount of code (#2995). + Thanks @dvd101x. + +# 2023-06-20, 11.8.2 + +- Fix #2971: improve typings of statistics functions `min`, `max`, `mean`, + `median`, `mode`, `std`, `sum`, `prod`, `variance`. Fixes a regression + introduced in v11.8.1. +- Fix #2972: type definitions of `Unit.divide(Unit)` have a wrong return type. + +# 2023-06-13, 11.8.1 + +- Fix #2964: issue in function `distance` when calculate the distance from + a point to a line (#2965). Thanks @Kiku-CN. +- Fix `math.format` not working correctly for `engineering` notation when using + BigNumbers and for `fixed` notation with `precision: 0` configured (#2956). + Thanks @mgreminger. +- Fix #2880: not possible to map cube root `cbrt`. +- Fix #2938: make the syntax description of all functions consistent in the + docs (#2941). Thanks @dvd101x. +- Fix #2954: improve the TypeScript definitions the return type of functions + `min` and `max` (#2955). Thanks @Maxim-Mazurok. +- Fix #2959: typo in an example in the docs. Thanks @kunalagrwl. +- Drop official support for Node.js 14, has reached end of life. + +# 2023-04-03, 11.8.0 + +- Extended functions `fraction`, `bignumber`, and `number` with support for + units, see #2918 (#2926). +- Implemented aliases `amp` and `amps` for unit `ampere` (#2917). + Thanks @veggiesaurus. +- Improve TypeScript definitions of function `gcd` (#2922). Thanks @brunoSnoww. +- Fix #2923: improve docs of the function `distance` (#2924). Thanks @tmtron. + +# 2023-03-15, 11.7.0 + +- Implement #2567: accept array as parameter for function `gcd` (#2878). + Thanks @jakubriegel. +- Fix #2908: improvements in the docs and examples of functions + `partitionSelect`, `diff`, `expm1`, `round`, `nthRoots`, `sign`, + `rigthArithShift`, `setIsSubset`, `setSize`, and the docs about units. + Thanks @tmtron. +- Fix #2907: determinant of empty matrix should be 1. +- Refactor index.d.ts by writing function declarations using a generic, + reducing a lot of repetition (#2913). Thanks @brunoSnoww. + +# 2023-02-24, 11.6.0 + +- Implement broadcasting for the following functions and their corresponding + operator: `add`, `dotDivide`, `dotMultiply`, `dotPow`, `gcd`, `lcm`, `mod`, + `nthRoot`, `subtract`, `bitAnd`, `bitOr`, `bitXor`, `leftShift`, + `rightArithShift`, `rightLogShift`, `and`, `or`, `xor`, `compare`, + `compareText`, `equal`, `larger`, `largerEq`, `smaller`, `smallerEq`, + `unequal`, `atan2` and `to` (#2895, #2753). Thanks @dvd101x. +- Implement support for non-power-of-2 fft (#2900, #2577). Thanks @cyavictor88. +- Fix #2888: update type definitions of function `unit` to allow creating a + unit from a fraction or complex number. +- Fix #2892: an error in the examples of the embedded help of function `sort`. +- Fix #2891: functions `column` and `row` sometimes returning a scalar number. +- Fix #2896: define the fourth argument of function `intersect` as optional + in the TypeScript definitions. Thanks @wodndb. +- Fix: quantileSeq not accepting a matrix as second argument `prob` (see #2902). +- Fix broken examples in functions `to`, `distance`, `getMatrixDataType`, + `subset`, and `max` (see #2902). + +# 2023-01-31, 11.5.1 + +- Add type definitions for function `rotationMatrix` (#2860). + Thanks @brunoSnoww. +- Add type signature for `lusolve(LUDecomposition, ...)` (#2864). + Thanks @evanmiller. +- Fix #2873: the rocket_trajectory_optimization.html example being partly + broken. Thanks @dvd101x. +- Fix #2871: coverage report broken (#2877). Thanks @bornova. +- Fix #2883: update documentation for stat functions, describe missing syntax. +- Fix #2884: fix examples in the embedded docs of function `pow` and some other + functions. +- Fix type definition of function `complex` for one numeric input (#2886), + thanks @ariymarkowitz. +- Fix type definitions of `map()` and `forEach()` (#2887), thanks @xiaohk. +- Fix #2606: improve type definitions of `dotMultiply`, `dotPow` and + `dotDivide` (#2890). Thanks @brunoSnoww. + +# 2022-12-05, 11.5.0 + +- Improve `simplify` rule matches in non-commutative contexts (#2841). + Thanks @samueltlg. +- Simplify: add rules and restructure tests for non-commutative contexts + (#2847). Thanks @samueltlg. +- Fix function `reshape` mutating the input in case of a matrix (see #2854). +- Fix TypeScript types for `multiply()` with `number[]` and `number[][]` + (#2852). Thanks @hfhchan. + +# 2022-11-18, 11.4.0 + +- Implemented more wildcards to describe rules for `simplify`, making it easier + for example to describe unary minus (#1915). Thanks @thatcomputerguy0101. +- Implemented functions `schur`, `sylvester`, and `lyap` (#2646). + Thanks @egidioln. +- Implemented function `polynomialRoot`, and use it in a benchmark (#2839). + Thanks @gwhitney. +- Fix #2825 partly: improve simplifying operations on constants in + non-commutative contexts (#2827). Thanks @samueltlg. +- Fix #2840: a bug in the docs and type definitions of `Node.traverse` and + `Node.forEach`, they do return `void`. + +# 2022-11-07, 11.3.3 + +- Fix #2830: Prevent inserting zero values when creating a `SparseMatrix` from a + `DenseMatrix` (#2836). Thanks @AlexandreAlvesDB. +- Fix #2835: a regression in the type definitions of `FunctionNode`, introduced + in `v11.3.2`. See #2733. Thanks @dsteve. + +# 2022-10-25, 11.3.2 + +- Add generics to remaining Node type definitions (#2733). Thanks @mattvague. +- Allow unit prefixes for (absolute) temperatures `kelvin`, `rankine`, + `celsius`, and `fahrenheit` (#2824). Thanks @jfeist + +# 2022-10-19, 11.3.1 + +- Fix #2809: code completion issues in some IDE's (#2812). +- Fix #2818: throw an error when a function assignment has duplicate + parameter names (#2819). +- Update `decimal.js` to version `10.4.2`. + +# 2022-10-11, 11.3.0 + +- Allow creating new subclasses of `Node` in TypeScript (#2772). + Note that this disables being able to narrow MathNodes by using the `.type` + property. Use typeguards like `isOperatorNode(...)` instead (see #2810). + Thanks @mattvague. +- Fix #2793: `flatten()` cloning entries of array/Matrix (#2799). +- Fix #2627: TypeScript definitions of `pinv` missing (#2804). + Thanks @HanchaiN. +- Update dependencies to `decimal.js@10.4.1`. + +# 2022-09-13, 11.2.1 + +- Fix doc generator being broken, not generating a function reference. + +# 2022-09-12, 11.2.0 + +- Implement function `isRelationalNode` (#2731). Thanks @isaacbyr. +- Added missing types `'largerEq'` and `'or'` in `OperatorNodeMap` in the + TypeScript definitions. Thanks @ajinkyac03. +- Fixed typos in min func type defs (#2768). Thanks @mabdullahadeel. +- Improved the TypeScript definitions for `pickRandom`. Thanks @mattvague. +- Fixed documentation of unit `min` which means `minutes`, not `minim` (#2773). + Thanks @jasonhornsby. + +# 2022-08-23, 11.1.0 + +- Add Unit constructor from value and pure (valueless) Unit (#2628). + Thanks @costerwi +- Fix #2144: `examples/advanced/custom_loading.js` was broken. +- Fix JSON `replacer` function missing in the TypeScript definitions. + Thanks @mattvague. +- Update dependencies to `typed-function@4.1.0` and `decimal.js@10.4.0`. + +# 2022-07-25, version 11.0.1 + +- Fix #2632: TypeScript issue of `simplifyConstant` and `simplifyCore` + not having a return type defined. + +# 2022-07-23, version 11.0.0 + +!!! BE CAREFUL: BREAKING CHANGES !!! + +Breaking changes: + +- Dropped official support for IE11. +- Upgraded to `typed-function@3`, see [josdejong/typed-function/HISTORY.md](https://github.com/josdejong/typed-function/blob/develop/HISTORY.md#2022-05-12-version-300). Thanks @gwhitney. Most importantly: + - Conversions now have preference over `any`. + - The `this` variable is no longer bound to the typed function itself. + - The properties `typed.types`, `typed.conversions`, and `typed.ignore` + have been removed. + - There are new static functions available like `typed.referTo`, + `typed.referToSelf`, `typed.addTypes`, `typed.addConversions`. +- Implement amended "Rule 2" for implicit multiplication (#2370, #2460): + when having a division followed by an implicit multiplication, the division + gets higher precedence over the implicit multiplication when (a) the + numerator is a constant with optionally a prefix operator (`-`, `+`, `~`), + and (b) the denominator is a constant. For example: formerly `-1 / 2 x` was + interpreted as `-1 / (2 * x)` and now it is interpreted as `(-1 / 2) * x`. + Thanks @gwhitney. +- Drop elementwise matrix support for trigonometric functions, exp, log, gamma, + square, sqrt, cube, and cbrt to prevent confusion with standard matrix + functions (#2440, #2465). Instead, use `math.map(matrix, fn)`. + Thanks @gwhitney. +- Simplify: convert equivalent function calls into operators, for example, + `add(2, x)` will now be simplified into `2 + x` (#2415, #2466). + Thanks @gwhitney. +- Removed the automatic conversion from `number` to `string` (#2482). + Thanks @gwhitney. +- Fix #2412: let function `diff` return an empty matrix when the input contains + only one element (#2422). +- Internal refactoring in the `simplifyCore` logic (#2490, #2484, #2459). + The function `simplifyCore` will no longer (partially) merge constants, that + behavior has been moved to `simplifyConstant`. The combination of + `simplifyConstant` and `simplifyCore` is still close to the old behavior + of `simplifyCore`, but there are some differences. To reproduce the same + behavior as the old `simplifyCore`, you can use + `math.simplify(expr, [math.simplifyCore, math.simplifyConstant])`. + Thanks to the refactoring, `simplify` is more thorough in reducing constants. + Thanks @gwhitney. +- Disable support for splitting rest parameters in chained calculations + (#2485, #2474). For example: `math.chain(3).max(4, 2).done()` will now throw + an error rather than return `4`, because the rest parameter of + `math.max(...number)` has been split between the contents of the chain and + the arguments to the max call. Thanks @gwhitney. +- Function `typeOf` now returns `function` (lowercase) for a function instead + of `Function` (#2560). Thanks @gwhitney. + +Non-breaking changes: + +- Fix #2600: improve the TypeScript definitions of `simplify`. + Thanks @laureen-m and @mattvague. +- Fix #2607: improve type definition of `createUnit`. Thanks @egziko. +- Fix #2608: clarify the docs on the need to configure a smaller `epsilon` + when using BigNumbers. +- Fix #2613: describe matrix methods `get` and `set` in the docs. +- Fix link to `math.rationalize` in the docs (#2616). Thanks @nukisman. +- Fix #2621: add TypeScript definitions for `count` (#2622). Thanks @Hansuku. +- Improved TypeScript definitions of `multiply` (#2623). Thanks @Windrill. + +# 2022-06-28, version 10.6.4 + +- Improve TypeScript definitions of the `factory` function, thanks @mattvague. + +# 2022-06-24, version 10.6.3 + +- Revert the TypeScript definition fixes for `factory` applied in `v10.6.2`, + they give some complications. + +# 2022-06-24, version 10.6.2 + +- Improve TypeScript definitions of `ParenthesisNode`. Thanks @mattvague. +- Change the TypeScript definition of `MathNodeCommon['type']` into a less + strict string, so it is possible to extend with new Node classes. + Thanks @mattvague. +- Improve TypeScript definitions of the `factory` function, thanks @mattvague. + +# 2022-05-31, version 10.6.1 + +- Improve the TypeScript types For `OperatorNode`: you can now define generic + types like `OperatorNode<'+', 'add'>`. Thanks @mattvague. + +# 2022-05-24, version 10.6.0 + +- Implementation of Fourier transform functions `fft` and `ifft` (#2540). + Thanks @HanchaiN. +- Fix TypeScript types not being listed in the exported fields (#2569). + Thanks @mattvague. +- Large improvements in TypeScript definitions for chained expressions (#2537). + Thanks @mattvague. +- Fix #2571: improve TypeScript definition of functions `clone` and `cloneDeep` + (#2572). Thanks @mattvague. +- Fix the first argument of `derivative` holding the expression not correctly + being converted when using `.toTex()` (#2564). Thanks @mattvague. + +# 2022-05-11, version 10.5.3 + +- Fix #2337: npm package containing examples and docs to solve security + vulnerabilities being reported on the examples and their dependencies. +- Fix core, construction, and some other functions missing in docs. +- Drop official support for Node.js 12 which has reached its end of life. + +# 2022-05-09, version 10.5.2 + +- Fix #2553: `@types/mocha` defined in `dependencies` instead of + `devDependencies`, causing problems in projects that use a different version + of this dependency. Thanks @Kolahzary. +- Fix #2550: remove `examples/node_modules` folder from the npm package. +- Fix #2528: improve contribution guidelines (#2548). +- Document `SymbolNode.onUndefinedSymbol` and + `FunctionNode.onUndefinedFunction`. + +# 2022-05-02, version 10.5.1 + +- Fix #2526, #2529: improve TypeScript definitions of function `round`, `fix`, + `floor`, `ceil`, and `nthRoot`, and improved the number only implementations + of those functions (#2531, #2539). Thanks @simlaticak and @gwhitney. +- Fix #2532: matrix index symbol `end` not working when used inside + a sub-expression. +- Fix #2524: In generating AUTHORS list, ignore a list of specific commits + (e.g., to avoid spurious duplicates in list). (#2543) +- Add type definitions of function `resolve` (#2536). Thanks @mattvague. + +# 2022-04-19, version 10.5.0 + +- Implement #1563: function `pinv`, Moore–Penrose inverse (#2521). + Thanks @HanchaiN. +- Optimize function `det` for integers by switching to the Bareiss algorithm: + no more round-off errors for integer input (#2516). Thanks @HanchaiN. +- Implement #2463: allow negative integer powers of invertible square matrices + (#2517). Thanks @HanchaiN. +- Implement the `lgamma` function (defined as log(gamma(z))) for number and + Complex types. Supersedes #320. (#2417). Thanks @yifanwww. +- Fix #2523: update to the latest complex.js to improve `sin(z)` for small + `im(z)` (#2525). Thanks @gwhitney. +- Fix #2526: update TypeScript definition of `ceil` (#2531). Thanks @simlaticak +- Change mocha reporter to 'dot' to avoid excessively long log files. (#2520) + +# 2022-04-08, version 10.4.3 + +- Fix #2508: improve the precision of stirlingS2 (#2509). Thanks @gwhitney. +- Fix #2514: implement optional argument `base` in the number implementation + of function `log` (#2515). Thanks @gwhitney. +- Improve the documentation on operator `;` (#2512). Thanks @gwhitney. + +# 2022-03-29, version 10.4.2 + +- Fix #2499: different behavior for unit conversion "degC" and "K" (#2501). + Also disables getting the sign for units with an offset, which is ambiguous. + Thanks @gwhitney. +- Fix #2503: fix an issue in `log()` for complex numbers in which the imaginary + part is much larger in absolute value than the real part, fixed in + `complex.js@2.1.0` (#2505), thanks @gwhitney, @infusion. +- Fix #2493: unclear error message when an entity that is not a function + is being called as a function (#2494). Thanks @gwhitney. +- Some fixes in the docs on units (#2498). Thanks @dvd101x. +- Add `forEach` example in embedded docs (#2507). Thanks @dvd101x. +- Correct approx.deepEqual() to accept an epsilon argument giving the + comparison tolerance. It was already being called this way, but was + silently ignoring the tolerance. Thanks @yifanwww. + +# 2022-03-23, version 10.4.1 + +- Improve TypeScript definitions for function `unit` (#2479). + Thanks @SinanAkkoyun. +- Add tests for type declarations (#2448). Thanks @samestep. +- Further improvement to TypeScript definitions of `std` and `variance` + (make dimension parameter optional, #2474). Thanks @NattapongSiri. +- Next step (as per #2431) for full publication of "is" functions like + `isMatrix` etc: Provide TypeScript definitions of "is" functions and + make them type guards. (#2432). Thanks @ChristopherChudzicki. +- Fix #2491: Multi line object expressions don't work with comments (#2492). + Thanks @gwhitney. +- Fix #2478: a bug in calculating the eigenvectors when dealing with complex + numbers (#2496). Thanks @gwhitney. +- Update project dependencies and devDependencies. + +# 2022-03-07, version 10.4.0 + +- Fix #2461: make sure `simplifyCore` recurses over all binary nodes (#2462). + Thanks @gwhitney. +- Fix #2429: fix the TypeScript definitions of functions `std` and `variance` + (#2455). Thanks @NattapongSiri. +- Fix #1633: implement a `cumsum` function generating cumulative sums of a list + of values or a matrix. (#1870). Thanks @hjonasson. +- Upgrade to the latest version of `Fraction.js`, having more strict input, + only accepting an integer numerator and denominator. See #2427. +- Fix typo in documentation example for `format`. (#2468) Thanks @abranhe. +- Write unit tests for all jsdoc examples. See #2452. Thanks @gwhitney. + +# 2021-03-02, version 10.3.0 + +- Fix #1260: implement function `symbolicEqual` (#2424). Thanks @gwhitney. +- Fix #2441, #2442: support passing a function as argument to functions created + in the expression parser (#2443). Thanks @gwhitney. +- Fix #2325: improve documentation of subset indices (#2446). Thanks @gwhitney. +- Fix #2439: fix a bug in `complexEigs` in which real-valued norms were + inadvertently being typed as complex numbers (#2445). Thanks @gwhitney. +- Fix #2436: improve documentation and error message of function `map` (#2457). + Thanks @gwhitney. + +# 2022-03-01, version 10.2.0 + +- Implemented context options to control simplifications allowed in `simplify`, + see #2399, #2391. Thanks @gwhitney. +- Implemented function `leafCount` as a first simple measure of the complexity + of an expression, see #2411, #2389. Thanks @gwhitney. +- Fix #2413: improve `combinations` to return an integer result without rounding + errors for larger values, see #2414. Thanks @gwhitney. +- Fix #2385: function `rotate` missing in TypeScript definitions. + Thanks @DIVYA-19. +- Fix #2450: Add BigNumber to parameter type in `math.unit` and add TypeScript + types for `Unit.simplify` and `Unit.units` (#2353). Thanks @joshhansen. +- Fix #2383: detect infinite loops in `simplify` (#2405). Thanks @gwhitney. +- Fix #1423: collect like factors and cancel like terms in sums (#2388). + Thanks @gwhitney. + +# 2022-02-02, version 10.1.1 + +- Improvements and fixes in function `simplify`, thanks @gwhitney: + - Fix #2393: regression bug in `simplify('2-(x+1)')`. + - Ad option `consoleDebug` to `simplify` to see what is going on. +- Fix TypeScript definition of `ConfigOptions`, which was missing option + `predictable`. + +# 2022-01-15, version 10.1.0 + +- Implemented function `invmod`, see #2368, #1744. Thanks @thetazero. +- Improvements and fixes in function `simplify`, thanks @gwhitney: + - Fix #1179, #1290: improve collection of non-constant like terms (#2384). + - Fix #2152: do not transform strings into numbers (#2372). + - Fix #1913: implement support for array and object simplification (#2382). +- Fix #2379: add embedded documentation for function `print`. +- Remove broken example from the embedded documentation of function `forEach`. + +# 2021-12-29, version 10.0.2 + +- Fix #2156: simplify expressions like `-1 / (-x)` to `1/x`. Thanks @ony3000. +- Fix #2363: remove a redundant part of the regex to split a number. +- Fix #2291: add support for fractions in function `intersect`. + Thanks @thetazero. +- Fix #2358: bug in `SparseMatrix` when replacing a subset of a matrix with + a non-consecutive index. Thanks @Al-0. + +# 2021-12-22, version 10.0.1 + +- Fix #1681: function `gamma` giving inaccurate complex results in some cases. + Thanks @kmdrGroch. +- Fixed a typo in an example, see #2366. Thanks @blackwindforce. + +# 2021-11-03, version 10.0.0 + +!!! BE CAREFUL: BREAKING CHANGES IN THE TYPESCRIPT DEFINITIONS !!! + +- Improvements to the Typescript typings (commit fc5c202e). + Thanks @joshhansen. First introduced in v9.5.1, but reverted because + it contains breaking changes. + + Breaking changes: interface `MathNode` is now renamed to `MathNodeCommon` + and the related interfaces are structured in a different way. + +- Fixed a typo in the TypeScript definition of toHTML. Thanks @TheToto. + +# 2021-11-03, version 9.5.2` + +- Revert the improvements to the Typescript typings because they contain + breaking changes. The improvements will be published in v10.0.0. See #2339. + +# 2021-10-13, version 9.5.1 + +- Various improvements to the Typescript typings. + Thanks @joshhansen and @DianaTdr. + +# 2021-09-22, version 9.5.0 + +- Implemented support for calculations with percentage, see #2303. + Thanks @rvramesh. +- Fix #2319: make the API of `Parser.evaluate` consistent with `math.evaluate`: + support a list with expressions as input. +- Improved documentation of function `setCartesian`. Thanks @fieldfoxWim. + +# 2021-09-15, version 9.4.5 + +- Improved the performance of `Node.equals` by improving the internal + function `deepStrictEqual`. Thanks @tomlarkworthy. +- Fixes in the TypeScript definitions: + - Define `hasNumericValue`. Thanks @write2kcl. + - Define `MathNode.isRelationalNode`. Thanks @m93a. + - Fix typo in `MathNode.isConditionalNode`. Thanks @m93a. + +# 2021-07-07, version 9.4.4 + +- Fixed `ArrayNode.toTex()`: remove the row delimiter on the last row, + see #2267. Thanks @davidtranhq. +- Fix #2269: `intersect` not returning `null` for matrix input. Thanks @m93a. +- Fix #2245: mathjs not working in IE11 anymore due to a missing polyfill for + `Symbol`. The browser bundle now includes the necessary polyfills (it is + larger now because of that, see also #2266). Thanks @m93a. +- Update dependencies (`complex.js@2.0.15`, `decimal.js@10.3.1`) +- Drop official support for node.js 10, which has reached end of life. + See #2258. + +# 2021-06-23, version 9.4.3 + +- Fix #2222: mathjs polluting the `Decimal` prototype. Thanks @m93a. +- Fix #2253: expression parser throwing an error when accessing nested object + properties named `e`. +- Fixes in the TypeScript definitions: + - function `floor`, #2159, #2246. Thanks @write2kcl. + - function `simplify`, see #2252. Thanks @nitroin. +- Upgraded to `decimal.js@10.3.0` + +# 2021-06-05, version 9.4.2 + +- Implemented iterative eigenvalue finder for `eigs`, making it much more + robust. See #2179, #2237. Thanks @m93a. +- Improved TypeScript definitions of function `parse`. Thanks @OpportunityLiu. + +# 2021-05-24, version 9.4.1 + +- Fix #2100: add TypeScript declaration for `eigs`. Thanks @andrebianchessi. +- Fix #2220: add TypeScript files to published npm package. Thanks @dhritzkiv. +- Update readme regarding TypeScript definition files. Thanks @dhritzkiv. +- Update to `fraction.js@4.1.1` + +# 2021-05-16, version 9.4.0 + +- Implemented support to use objects with a `Map` interface as scope, + see #2143, #2166. Thanks @jhugman. +- Extend `eigs` to support general complex matrices, see #1741. Thanks @m93a. +- DenseMatrix and SparseMatrix are now iterable, see #1184. Thanks @m93a. +- Implemented utility functions `matrixFromRows`, `matrixFromColumns`, and + `matrixFromFunction`, see #2155, #2153. Thanks @m93a. +- Added TypeScript definitions to the project, making it redundant to install + `@types/mathjs`, and making it easier to improve the definitions. See #2187, + #2192. Thanks @CatsMiaow. +- Upgraded dependencies + - `complex.js@2.0.13` (fixing #2211). Thanks @infusion + - `fraction.js@4.1.0` (`pow` now supporting rational exponents). +- Fix #2174: function `pickRandom` having no name. Thanks @HK-SHAO. +- Fix #2019: VSCode auto import keeps adding import { null } from 'mathjs'. +- Fix #2185: Fix TypeScript definition of unit division, which can also return + a number. +- Fix #2123: add type definitions for functions `row` and `column`. +- Fix some files not exposed in the package, see #2213. Thanks @javiermarinros. + +# 2021-04-12, version 9.3.2 + +- Fix #2169: mathjs requesting `@babel/runtime` dependency. + Regression introduced in `v9.3.1`. + +# 2021-04-10, version 9.3.1 + +- Fix #2133: strongly improved the performance of `isPrime`, see #2139. + Thanks @Yaffle. +- Fix #2150: give a clear error "Error: Undefined function ..." instead when + evaluating a non-existing function. +- Fix #660: expose internal functions `FunctionNode.onUndefinedFunction(name)` + and `SymbolNode.onUndefinedSymbol(name)`, allowing to override the behavior. + By default, an Error is thrown. + +# 2021-03-10, version 9.3.0 + +- Implemented support for parsing non decimal numbers with radix point, + see #2122, #2121. Thanks @clnhlzmn. +- Fix #2128: typo in docs of `luSolveAll` and `usolveAll`. + +# 2021-02-03, version 9.2.0 + +- Implemented function `count` to count the total elements in a matrix, + see #2085. Thanks @Josef37. +- Fix #2096: cleanup old reference to external dependency `crypto`. +- Some refactoring in the code to remove duplications, see #2093. + Thanks @Josef37. + +# 2021-01-27, version 9.1.0 + +- Extended function `reshape` with support for a wildcard `-1` to automatically + calculate the remaining size, like `reshape([1, 2, 3, 4, 5, 6], [-1, 2])` + which will output `[[0, 1], [2, 3], [4, 5]]`. See #2075. Thanks @Josef37. +- Fix #2087: function `simplify` ignores second argument of `log`, for example + in `simplify('log(e, 9)')` . Thanks @quentintruong. + +# 2021-01-16, version 9.0.0 + +- Improved support for bin, hex, and oct literals. See #1996. Thanks @clnhlzmn. + - **Breaking change**: parse literals with prefixes `0b`, `0c`, and `0x` are + now unsigned by default. To parse them as signed, you have to specify a + suffix specifying the word size such as `i16` or `i32`. + - Function `format` now supports more notations: `bin`, 'hex', and `oct`, + for example `format(255, {notation: "hex"})`. + - The functions `format`, `bin`, `hex`, `oct` now allow specifying a wordSize, + like `bin(10, 32)` and `format(10, {notation: "bin", wordSize: 32})`. + - BigNumber support for the bin, hex, and oct literals. +- Extended and improved the example rocket_trajectory_optimization.html. + Thanks @Josef37. + +# 2020-12-30, version 8.1.1 + +- Improved the performance of parsing and evaluating units a lot, see #2065. + Thanks @flaviut. +- Upgraded dependency `fraction.js` to `v4.0.13`. +- Moved continuous integration testing from Travis CI to Github Workflow, + see #2024, #2041. Thanks @harrysarson. + +# 2020-12-04, version 8.1.0 + +- Implemented units `kilogramforce` (`kgf`). Thanks @rnd-debug. +- Fix #2026: Implement a new option `fractionsLimit` for function `simplify`, + defaulting to `Infinity`. +- Improved the documentation of function `clone`. Thanks @redbar0n. + +# 2020-11-09, version 8.0.1 + +- Fix #1979: missing "subset" dependency when using "mathjs/number" entry point. +- Fix #2022: update pretty printing with MathJax example to the latest version + of MathJax. Thanks @pkra. + +# 2020-11-06, version 8.0.0 + +!!! BE CAREFUL: BREAKING CHANGES !!! + +- You can now use mathjs directly in node.js using ES modules without need for + a transpiler (see #1928, #1941, #1962). + Automatically loading either commonjs code or ES modules code is improved. + All generated code is moved under `/lib`: the browser bundle is moved from + `/dist` to `/lib/browser`, ES module files are moved to `/lib/esm`, + and commonjs files are moved to `/lib/cjs`. Thanks @GreenImp. +- Non-minified bundle `dist/math.js` is no longer provided. Either use the + minified bundle, or create a bundle yourself. +- Replaced random library `seed-random` with `seedrandom`, see #1955. + Thanks @poppinlp. +- Breaking changes in `pickRandom`, see #1990, #1976. + - Will no longer return the input matrix when the given number is greater + than the length of the provided possibles. Instead, the function always + returns results with the requested number of picks. + - Will now return a `Matrix` as output when input was a `Matrix`. + - Introduced a new syntax: + + ``` + math.pickRandom(array, { weights, number, elementWise }) + ``` + + - Introduced a new option `elementWise`, which is `true` by default. + When setting `elementWise` to false, an array containing arrays will return + random pick of arrays instead of the elements inside of the nested arrays. + +# 2020-11-02, version 7.6.0 + +- Implemented function `rotate(w, theta)`. See #1992, #1160. Thanks @rnd-debug. +- Implemented support for custom characters in Units via `Unit.isValidAlpha`. + See #1663, #2000. Thanks @rnd-debug. + +# 2020-10-10, version 7.5.1 + +- Fix object pollution vulnerability in `math.config`. Thanks Snyk. + +# 2020-10-07, version 7.5.0 + +- Function `pickRandom` now allows randomly picking elements from matrices + with 2 or more dimensions instead of only from a vector, see #1974. + Thanks @KonradLinkowski. + +# 2020-10-07, version 7.4.0 + +- Implemented support for passing a precision in functions `ceil`, `floor`, + and `fix`, similar to `round`, see #1967, #1901. Thanks @rnd-debug. +- Implemented function `rotationMatrix`, see #1160, #1984. Thanks @rnd-debug. +- Implement a clear error message when using `sqrtm` with a matrix having + more than two dimensions. Thanks @KonradLinkowski. +- Update dependency `decimal.js` to `10.2.1`. + +# 2020-09-26, version 7.3.0 + +- Implemented functions `usolveAll` and `lsolveAll`, see #1916. Thanks @m93a. +- Implemented support for units in functions `std` and `variance`, see #1950. + Thanks @rnd-debug. +- Implemented support for binary, octal, and hexadecimal notation in the + expression parser, and implemented functions `bin`, `oct`, and `hex` for + formatting. Thanks @clnhlzmn. +- Fix #1964: inconsistent calculation of negative dividend modulo for + `BigNumber` and `Fraction`. Thanks @ovk. + +# 2020-08-24, version 7.2.0 + +- Implemented new function `diff`, see #1634, #1920. Thanks @Veeloxfire. +- Implemented support for norm 2 for matrices in function `norm`. + Thanks @rnd-debug. + +# 2020-07-13, version 7.1.0 + +- Implement support for recursion (self-referencing) of typed-functions, + new in `typed-function@2.0.0`. This fixes #1885: functions which where + extended with a new data type did not always work. Thanks @nickewing. +- Fix #1899: documentation on expression trees still using old namespace + `math.expression.node.*` instead of `math.*`. + +# 2020-06-24, version 7.0.2 + +- Fix #1882: have `DenseMatrix.resize` and `SparseMatrix.resize` accept + `DenseMatrix` and `SparseMatrix` as inputs too, not only `Array`. +- Fix functions `sum`, `prod`, `min`, and `max` not throwing a conversion error + when passing a single string, like `sum("abc")`. + +# 2020-05-30, version 7.0.1 + +- Fix #1844: clarify the documentation of function `eigs`. Thanks @Lazersmoke. +- Fix #1855: Fix error in the documentation for `math.nthRoots(x)`. +- Fix #1856: make the library robust against Object prototype pollution. + +# 2020-05-07, version 7.0.0 + +Breaking changes: + +- Improvements in calculation of the `dot` product of complex values. + The first argument is now conjugated. See #1761. Thanks @m93a. +- Dropped official support for Node.js v8 which has reached end of life. +- Removed all deprecation warnings introduced in v6. + To upgrade smoothly from v5 to v7 or higher, upgrade to v6 first + and resolve all deprecation warnings. + +# 2020-05-04, version 6.6.5 + +- Fix #1834: value `Infinity` cannot be serialized and deserialized. + This is solved now with a new `math.replacer` function used as + `JSON.stringify(value, math.replacer)`. +- Fix #1842: value `Infinity` not turned into the latex symbol `\\infty`. + +# 2020-04-15, version 6.6.4 + +- Fix published files containing Windows line endings (CRLF instead of LF). + +# 2020-04-10, version 6.6.3 + +- Fix #1813: bug in engineering notation for numbers of function `format`, + sometimes resulting in needless trailing zeros. +- Fix #1808: methods `.toNumber()` and `.toNumeric()` not working on a + unitless unit. +- Fix #1645: not being able to use named operators `mod`, `and`, `not`, `or`, + `xor`, `to`, `in` as object keys. Thanks @Veeloxfire. +- Fix `eigs` not using `config.epsilon`. + +# 2020-03-29, version 6.6.2 + +- Fix #1789: Function `eigs` not calculating with BigNumber precision + when input contains BigNumbers. +- Run the build script during npm `prepare`, so you can use the library + directly when installing directly from git. See #1751. Thanks @cinderblock. + +# 2020-02-26, version 6.6.1 + +- Fix #1725: simplify `a/(b/c)`. Thanks @dbramwell. +- Fix examples in documentation of `row` and `column`. + +# 2020-02-01, version 6.6.0 + +- Implemented function `eigs`, see #1705, #542 #1175. Thanks @arkajitmandal. +- Fixed #1727: validate matrix size when creating a `DenseMatrix` using + `fromJSON`. +- Fixed `DenseMatrix.map` copying the size and datatype from the original + matrix instead of checking the returned dimensions and type of the callback. +- Add a caret to dependencies (like) `^1.2.3`) to allow downstream updates + without having to await a new release of mathjs. + +# 2020-01-08, version 6.5.0 + +- Implemented `baseName` option for `createUnit`, see #1707. + Thanks @ericman314. + +# 2020-01-06, version 6.4.0 + +- Extended function `dimension` with support for n-dimensional points. + Thanks @Veeloxfire. + +# 2019-12-31, version 6.3.0 + +- Improved performance of `factorial` for `BigNumber` up to a factor two, + see #1687. Thanks @kmdrGroch. + +# 2019-11-20, version 6.2.5 + +- Fixed `IndexNode` using a hardcoded, one-based implementation of `index`, + making it impossible to instantiate a zero-based version of the expression + parser. See #782. + +# 2019-11-20, version 6.2.4 + +- Fixed #1669: function 'qr' threw an error if the pivot was zero, + thanks @kevinkelleher12 and @harrysarson. +- Resolves #942: remove misleading assert in 'qr'. Thanks @harrysarson. +- Work around a bug in complex.js where `sign(0)` returns complex NaN. + Thanks @harrysarson. + +# 2019-10-06, version 6.2.3 + +- Fixed #1640: function `mean` not working for units. Thanks @clintonc. +- Fixed #1639: function `min` listed twice in the "See also" section of the + embedded docs of function `std`. +- Improved performance of `isPrime`, see #1641. Thanks @arguiot. + +# 2019-09-23, version 6.2.2 + +- Fixed methods `map` and `clone` not copying the `dotNotation` property of + `IndexNode`. Thanks @rianmcguire. +- Fixed a typo in the documentation of `toHTML`. Thanks @maytanthegeek. +- Fixed #1615: error in the docs of `isNumeric`. +- Fixed #1628: Cannot call methods on empty strings or numbers with value `0`. + +# 2019-08-31, version 6.2.1 + +- Fixed #1606: function `format` not working for expressions. + +# 2019-08-28, version 6.2.0 + +- Improved performance of `combinationsWithRep`. Thanks @waseemyusuf. +- Add unit aliases `bit` and `byte`. +- Fix docs referring to `bit` and `byte` instead of `bits` and `bytes`. +- Updated dependency `typed-function@1.1.1`. + +# 2019-08-17, version 6.1.0 + +- Implemented function `combinationsWithRep` (see #1329). Thanks @waseemyusuf. + +# 2019-08-05, version 6.0.4 + +- Fixed #1554, #1565: ES Modules where not transpiled to ES5, giving issues on + old browsers. Thanks @mockdeep for helping to find a solution. + +# 2019-07-07, version 6.0.3 + +- Add `unpkg` and `jsdelivr` fields in package.json pointing to UMD build. + Thanks @tmcw. +- Fix #1550: nested user defined function not receiving variables of an + outer user defined function. + +# 2019-06-11, version 6.0.2 + +- Fix not being able to set configuration after disabling function `import` + (regression since v6.0.0). + +# 2019-06-09, version 6.0.1 + +- Fix function reference not published in npm library. +- Fix function `evaluate` and `parse` missing in generated docs. + +# 2019-06-08, version 6.0.0 + +!!! BE CAREFUL: BREAKING CHANGES !!! + +### Most notable changes + +1. Full support for **ES modules**. Support for tree-shaking out of the box. + + Load all functions: + + ```js + import * as math from 'mathjs' + ``` + + Use a few functions: + + ```js + import { add, multiply } from 'mathjs' + ``` + + Load all functions with custom configuration: + + ```js + import { create, all } from 'mathjs' + const config = { number: 'BigNumber' } + const math = create(all, config) + ``` + + Load a few functions with custom configuration: + + ```js + import { create, addDependencies, multiplyDependencies } from 'mathjs' + const config = { number: 'BigNumber' } + const { add, multiply } = create({ + addDependencies, + multiplyDependencies + }, config) + ``` + +2. Support for **lightweight, number-only** implementations of all functions: + + ``` + import { add, multiply } from 'mathjs/number' + ``` + +3. New **dependency injection** solution used under the hood. + +### Breaking changes + +- Node 6 is no longer supported. + +- Functions `config` and `import` are not available anymore in the global + context: + + ```js + // v5 + import * as mathjs from 'mathjs' + mathjs.config(...) // error in v6.0.0 + mathjs.import(...) // error in v6.0.0 + ``` + + Instead, create your own mathjs instance and pass config and imports + there: + + ```js + // v6 + import { create, all } from 'mathjs' + const config = { number: 'BigNumber' } + const mathjs = create(all, config) + mathjs.import(...) + ``` + +- Renamed function `typeof` to `typeOf`, `var` to `variance`, + and `eval` to `evaluate`. (the old function names are reserved keywords + which can not be used as a variable name). +- Deprecated the `Matrix.storage` function. Use `math.matrix` instead to create + a matrix. +- Deprecated function `math.expression.parse`, use `math.parse` instead. + Was used before for example to customize supported characters by replacing + `math.parse.isAlpha`. +- Moved all classes like `math.type.Unit` and `math.expression.Parser` to + `math.Unit` and `math.Parser` respectively. +- Fixed #1428: transform iterating over replaced nodes. New behavior + is that it stops iterating when a node is replaced. +- Dropped support for renaming factory functions when importing them. +- Dropped fake BigNumber support of function `erf`. +- Removed all index.js files used to load specific functions instead of all, like: + + ``` + // v5 + // ... set up empty instance of mathjs, then load a set of functions: + math.import(require('mathjs/lib/function/arithmetic')) + ``` + + Individual functions are now loaded simply like: + + ```js + // v6 + import { add, multiply } from 'mathjs' + ``` + + To set a specific configuration on the functions: + + ```js + // v6 + import { create, addDependencies, multiplyDependencies } from 'mathjs' + const config = { number: 'BigNumber' } + const math = create({ addDependencies, multiplyDependencies }, config) + ``` + + See example `advanced/custom_loading.js`. + +- Updated the values of all physical units to their latest official values. + See #1529. Thanks @ericman314. + +### Non breaking changes + +- Implemented units `t`, `tonne`, `bel`, `decibel`, `dB`, and prefixes + for `candela`. Thanks @mcvladthegoat. +- Fixed `epsilon` setting being applied globally to Complex numbers. +- Fix `math.simplify('add(2, 3)')` throwing an error. +- Fix #1530: number formatting first applied `lowerExp` and `upperExp` + and after that rounded the value instead of the other way around. +- Fix #1473: remove `'use strict'` in every file, not needed anymore. + +# 2019-05-18, version 5.10.3 + +- Fixed dependency `del` being a dependency instead of devDependency. + +# 2019-05-18, version 5.10.2 + +- Fix #1515, #1516, #1517: broken package due to a naming conflict in + the build folder of a util file `typeOf.js` and `typeof.js`. + Solved by properly cleaning all build folders before building. + +# 2019-05-17, version 5.10.1 + +- Fix #1512: format using notation `engineering` can give wrong results + when the value has less significant digits than the number of digits in + the output. + +# 2019-05-08, version 5.10.0 + +- Fix `lib/header.js` not having filled in date and version. Thanks @kevjin. +- Upgraded dependency `decimal.js@10.2.0`, fixing an issue on node.js 12. + +# 2019-04-08, version 5.9.0 + +- Implemented functions `row` and `column` (see #1413). Thanks @SzechuanSage. +- Fixed #1459: `engineering` notation of function `format` not available + for `BigNumber`. +- Fixed #1465: `node.toHTML()` not correct for unary operators like + `factorial`. + +# 2019-03-20, version 5.8.0 + +- Implemented new function `apply`. Thanks @bnlcas. +- Implemented passing an optional `dimension` argument to `std` and `var`. + Thanks @bnlcas. + +# 2019-03-10, version 5.7.0 + +- Implemented support for `pow()` in `derivative`. Thanks @sam-19. +- Gracefully handle round-off errors in fix, ceil, floor, and range + (Fixes #1429, see also #1434, #1432). Thanks @ericman314. + +# 2019-03-02, version 5.6.0 + +- Upgrade decimal.js to v10.1.1 (#1421). +- Fixed #1418: missing whitespace when stringifying an expression + containing "not". + +# 2019-02-20, version 5.5.0 + +- Fixed #1401: methods `map` and `forEach` of `SparseMatrix` not working + correctly when indexes are unordered. +- Fixed #1404: inconsistent rounding of negative numbers. +- Upgrade tiny-emitter to v2.1.0 (#1397). + +# 2019-01-25, version 5.4.2 + +- Fixed `math.format` not working for BigNumbers with a precision above + 1025 digits (see #1385). Thanks @ericman314. +- Fixed incorrect LaTeX output of `RelationalNode`. Thanks @rianmcguire. +- Fixed a bug the methods `map`, `forEach`, `traverse`, and `transform` + of `FunctionNode`. + +# 2019-01-10, version 5.4.1 + +- Fix #1378: negative bignumbers not formatted correctly. +- Upgrade fraction.js to version 4.0.12 (#1369). + +# 2018-12-09, version 5.4.0 + +- Extended sum.js to accept a dimension input to calculate the sum over a + specific axis. Thanks @bnlcas. +- Fix #1328: objects can't be written multi-line. Thanks @GHolk. +- Remove side effects caused by `Unit.format` and `Unit.toString`, + making changes to the unit on execution. Thanks @ericman314. + +# 2018-12-03, version 5.3.1 + +- Fixed #1336: Unit.toSI() returning units with prefix like `mm` instead + of `m`. Thanks @ericman314. + +# 2018-11-29, version 5.3.0 + +- Implemented function `hasNumericValue`. Thanks @Sathish-kumar-Subramani. +- Fix #1326: non-ascii character in print.js. +- Fix #1337: `math.format` not working correctly with `{ precision: 0 }`. + Thanks @dkenul. + +# 2018-10-30, version 5.2.3 + +- Fixed #1293: non-unicode characters in `escape-latex` giving issues in some + specific cases. Thanks @dangmai. +- Fixed incorrect LaTeX output of function `bitNot`, see #1299. Thanks @FSMaxB. +- Fixed #1304: function `pow` not supporting inputs `pow(Unit, BigNumber)`. +- Upgraded dependencies (`escape-latex@1.2.0`) + +# 2018-10-23, version 5.2.2 + +- Fixed #1286: Fixed unit base recognition and formatting for + user-defined units. Thanks @ericman314. + +# 2018-10-18, version 5.2.1 + +- Fixed unit `rod` being defined as `5.02921` instead of `5.0292`. + Thanks @ericman314. +- Upgraded dependencies (`fraction.js@4.0.10`) +- Upgraded devDependencies (`@babel/core@7.1.2`, `nyc@13.1.0`, + `webpack@4.21.0`). + +# 2018-10-05, version 5.2.0 + +- Implemented support for chained conditionals like `10 < x <= 50`. + Thanks @ericman314. +- Add an example showing a proof of concept of using `BigInt` in mathjs. +- Fixed #1269: Bugfix for BigNumber divided by unit. Thanks @ericman314. +- Fixed #1240: allow units having just a value and no unit. + Thanks @ericman314. + +## 2018-09-09, version 5.1.2 + +- Fixed a typo in the docs of `parse`. Thanks @mathiasvr. +- Fixed #1222: a typo in the docs of `subset`. +- Fixed #1236: `quantileSeq` has inconsistent return. +- Fixed #1237: norm sometimes returning a complex number instead of + number. +- Upgraded dependencies (`fraction.js@4.0.9`) +- Upgraded devDependencies (`babel@7`, `karma-webpack@3.0.4`, + `nyc@13.0.1`, `standard@12.0.0`, `uglify-js@3.4.9`, `webpack@4.17.2`) + +## 2018-08-21, version 5.1.1 + +- Function `isNumeric` now recognizes more types. +- Fixed #1214: functions `sqrt`, `max`, `min`, `var`, `std`, `mode`, `mad`, + `median`, and `partitionSelect` not neatly handling `NaN` inputs. In some + cases (`median`, `mad`, and `partitionSelect`) this resulted in an infinite + loop. +- Upgraded dependencies (`escape-latex@1.1.1`) +- Upgraded devDependencies (`webpack@4.17.0`) + +## 2018-08-12, version 5.1.0 + +- Implemented support for strings enclosed in single quotes. + Thanks @jean-emmanuel. +- Implemented function `getMatrixDataType`. Thanks @JasonShin. +- Implemented new `options` argument in `simplify`. Thanks @paulobuchsbaum. +- Bug fixes in `rationalize`, see #1173. Thanks @paulobuchsbaum. + +## 2018-07-22, version 5.0.4 + +- Strongly improved the performance of functions `factorial` for numbers. + This improves performance of functions `gamma`, `permutation`, and + `combination` too. See #1170. Thanks @honeybar. +- Strongly improved the performance of function `reshape`, thanks to a + friend of @honeybar. + +## 2018-07-14, version 5.0.3 + +- Fixed many functions (for example `add` and `subtract`) not working + with matrices having a `datatype` defined. +- Fixed #1147: bug in `format` with `engineering` notation in outputting + the correct number of significant figures. Thanks @ericman314. +- Fixed #1162: transform functions not being cleaned up when overriding + it by importing a factory function with the same name. +- Fixed broken links in the documentation. Thanks @stropitek. +- Refactored the code of `parse` into a functional approach. + Thanks @harrysarson. +- Changed `decimal.js` import to ES6. Thanks @weinshel. + +## 2018-07-07, version 5.0.2 + +- Fixed #1136: rocket trajectory example broken (since v4.0.0). +- Fixed #1137: `simplify` unnecessarily replacing implicit multiplication with + explicit multiplication. +- Fixed #1146: `rationalize` throwing exceptions for some input with decimals. + Thanks @maruta. +- Fixed #1088: function arguments not being passed to `rawArgs` functions. +- Fixed advanced example `add_new_datatypes`. +- Fixed mathjs core constants not working without complex numbers. + Thanks @ChristopherChudzicki. +- Fixed a broken link in the documentation on units. Thanks @stropitek. +- Upgraded dependencies (`typed-function@1.0.4`, `complex.js@2.0.11`). +- Upgraded devDependencies (`babel-loader@7.1.5`, `uglify-js@3.4.3`, + `expr-eval@1.2.2`, `webpack@4.15.1`). + +## 2018-07-01, version 5.0.1 + +- Improved error messaging when converting units. Thanks @gap777. +- Upgraded devDependencies (`kerma`, `uglify-js`, `webpack`). + +## 2018-06-16, version 5.0.0 + +!!! BE CAREFUL: BREAKING CHANGES !!! + +- Implemented complex conjugate transpose `math.ctranspose`. See #1097. + Thanks @jackschmidt. +- Changed the behavior of `A'` (transpose) in the expression parser to + calculate the complex conjugate transpose. See #1097. Thanks @jackschmidt. +- Added support for `complex({abs: 1, arg: 1})`, and improved the docs on + complex numbers. Thanks @ssaket. +- Renamed `eye` to `identity`, see #1054. +- Math.js code can now contain ES6. The ES6 source code is moved from `lib` + to `src`, and `lib` now contains the compiled ES5 code. +- Upgraded dependencies: + - `decimal.js` from `9.0.1` to `10.0.1` + - Upgraded dev dependencies +- Changed code style to , run linter on `npm test`. + See #1110. +- Dropped support for bower. Use npm or an other package manages instead. +- Dropped support for (non-primitive) instances of `Number`, `Boolean`, and + `String` from functions `clone` and `typeof`. +- Dropped official support for IE9 (probably still works, but it's not tested). +- Fixed #851: More consistent behavior of sqrt, nthRoot, and pow. + Thanks @dakotablair. +- Fixed #1103: Calling `toTex` on node that contains `derivative` causing + an exception. Thanks @joelhoover. + +## 2018-06-02, version 4.4.2 + +- Drastically improved the performance of `det`. Thanks @ericman314. +- Fixed #1065, #1121: Fixed wrong documentation of function + `compareNatural` and clarified the behavior for strings. +- Fixed #1122 a regression in function `inv` (since `v4.4.1`). + Thanks @ericman314. + +## 2018-05-29, version 4.4.1 + +- Fixed #1109: a bug in `inv` when dealing with values close to zero. + Thanks @ericman314. + +## 2018-05-28, version 4.4.0 + +- Implemented functions `equalText` and `compareText`. See #1085. + +## 2018-05-21, version 4.3.0 + +- Implemented matrix exponential `math.expm`. Thanks @ericman314. +- Fixed #1101: math.js bundle not working when loading in a WebWorker. +- Upgraded dependencies + - `complex.js` from `v2.0.2` to `v2.0.10`. + - `fraction.js` from `v4.0.4` to `v4.0.8`. +- Upgraded devDependencies (`mocha`, `uglify-js`, `webpack`). + +## 2018-05-05, version 4.2.2 + +- Fixed calculating the Frobenius norm of complex matrices correctly, + see #1098. Thanks @jackschmidt. +- Fixed #1076: cannot use mathjs in React VR by updating to + `escape-latex@1.0.3`. + +## 2018-05-02, version 4.2.1 + +- Fixed `dist/math.js` being minified. + +## 2018-05-02, version 4.2.0 + +- Implemented function `math.sqrtm`. Thanks @ferrolho. +- Implemented functions `math.log2`, `math.log1p`, and `math.expm1`. + Thanks @BigFav and @harrysarson. +- Fixed some unit tests broken on nodejs v10. +- Upgraded development dependencies. +- Dropped integration testing on nodejs v4. + +## 2018-04-18, version 4.1.2 + +- Fixed #1082: implemented support for unit plurals `decades`, `centuries`, + and `millennia`. +- Fixed #1083: units `decade` and `watt` having a wrong name when stringifying. + Thanks @ericman314. + +## 2018-04-11, version 4.1.1 + +- Fixed #1063: derivative not working when resolving a variable with unary + minus like `math.derivative('-x', 'x')`. + +## 2018-04-08, version 4.1.0 + +- Extended function `math.print` with support for arrays and matrices. + Thanks @jean-emmanuel. +- Fixed #1077: Serialization/deserialization to JSON with reviver not being + supported by nodes. +- Fixed #1016: Extended `math.typeof` with support for `ResultSet` and nodes + like `SymbolNode`. +- Fixed #1072: Added support for long and short prefixes for the unit `bar` + (i.e. `millibar` and `mbar`). + +## 2018-03-17, version 4.0.1 + +- Fixed #1062: mathjs not working on ES5 browsers like IE11 and Safari 9.3. +- Fixed #1061: `math.unit` not accepting input like `1/s`. + +## 2018-02-25, version 4.0.0 + +!!! BE CAREFUL: BREAKING CHANGES !!! + +Breaking changes (see also #682): + +- **New expression compiler** + + The compiler of the expression parser is replaced with one that doesn't use + `eval` internally. See #1019. This means: + + - a slightly improved performance on most browsers. + - less risk of security exploits. + - the code of the new compiler is easier to understand, maintain, and debug. + + Breaking change here: When using custom nodes in the expression parser, + the syntax of `_compile` has changed. This is an undocumented feature though. + +- **Parsed expressions** + + - The class `ConstantNode` is changed such that it just holds a value + instead of holding a stringified value and it's type. + `ConstantNode(valueStr, valueType`) is now `ConstantNode(value)` + Stringification uses `math.format`, which may result in differently + formatted numeric output. + + - The constants `true`, `false`, `null`, `undefined`, `NaN`, `Infinity`, + and `uninitialized` are now parsed as ConstantNodes instead of + SymbolNodes in the expression parser. See #833. + +- **Implicit multiplication** + + - Changed the behavior of implicit multiplication to have higher + precedence than explicit multiplication and division, except in + a number of specific cases. This gives a more natural behavior + for implicit multiplications. For example `24h / 6h` now returns `4`, + whilst `1/2 kg` evaluates to `0.5 kg`. Thanks @ericman314. See: #792. + Detailed documentation: . + + - Immediately invoking a function returned by a function like `partialAdd(2)(3)` + is no longer supported, instead these expressions are evaluated as + an implicit multiplication `partialAdd(2) * (3)`. See #1035. + +- **String formatting** + + - In function `math.format`, the options `{exponential: {lower: number, upper: number}}` + (where `lower` and `upper` are values) are replaced with `{lowerExp: number, upperExp: number}` + (where `lowerExp` and `upperExp` are exponents). See #676. For example: + + ```js + math.format(2000, {exponential: {lower: 1e-2, upper: 1e2}}) + ``` + + is now: + + ```js + math.format(2000, {lowerExp: -2, upperExp: 2}) + ``` + + - In function `math.format`, the option `notation: 'fixed'` no longer rounds to + zero digits when no precision is specified: it leaves the digits as is. + See #676. + +- **String comparison** + + Changed the behavior of relational functions (`compare`, `equal`, + `equalScalar`, `larger`, `largerEq`, `smaller`, `smallerEq`, `unequal`) + to compare strings by their numeric value they contain instead of + alphabetically. This also impacts functions `deepEqual`, `sort`, `min`, + `max`, `median`, and `partitionSelect`. Use `compareNatural` if you + need to sort an array with text. See #680. + +- **Angle units** + + Changed `rad`, `deg`, and `grad` to have short prefixes, + and introduced `radian`, `degree`, and `gradian` and their plurals + having long prefixes. See #749. + +- **Null** + + - `null` is no longer implicitly casted to a number `0`, so input like + `math.add(2, null)` is no longer supported. See #830, #353. + + - Dropped constant `uninitialized`, which was used to initialize + leave new entries undefined when resizing a matrix is removed. + Use `undefined` instead to indicate entries that are not explicitly + set. See #833. + +- **New typed-function library** + + - The `typed-function` library used to check the input types + of functions is completely rewritten and doesn't use `eval` under + the hood anymore. This means a reduced security risk, and easier + to debug code. The API is the same, but error messages may differ + a bit. Performance is comparable but may differ in specific + use cases and browsers. + +Non breaking changes: + +- Thanks to the new expression compiler and `typed-function` implementation, + mathjs doesn't use JavaScript's `eval` anymore under the hood. + This allows using mathjs in environments with security restrictions. + See #401. +- Implemented additional methods `isUnary()` and `isBinary()` on + `OperatorNode`. See #1025. +- Improved error messages for statistical functions. +- Upgraded devDependencies. +- Fixed #1014: `derivative` silently dropping additional arguments + from operator nodes with more than two arguments. + +## 2018-02-07, version 3.20.2 + +- Upgraded to `typed-function@0.10.7` (bug-fix release). +- Fixed option `implicit` not being copied from an `OperatorNode` + when applying function `map`. Thanks @HarrySarson. +- Fixed #995: spaces and underscores not property being escaped + in `toTex()`. Thanks @FSMaxB. + +## 2018-01-17, version 3.20.1 + +- Fixed #1018: `simplifyCore` failing in some cases with parentheses. + Thanks @firepick1. + +## 2018-01-14, version 3.20.0 + +- Implement support for 3 or more arguments for operators `+` and `*` in + `derivative`. Thanks @HarrySarson. See #1002. +- Fixed `simplify` evalution of `simplify` of functions with more than two + arguments wrongly: `simplify('f(x, y, z)') evaluated to`f(f(x, y), z)` + instead of `f(x, y, z)`. Thanks @joelhoover. +- Fixed `simplify` throwing an error in some cases when simplifying unknown + functions, for example `simplify('f(4)')`. Thanks @joelhoover. +- Fixed #1013: `simplify` wrongly simplifing some expressions containing unary + minus, like `0 - -x`. Thanks @joelhoover. +- Fixed an error in an example in the documentation of `xor`. Thanks @denisx. + +## 2018-01-06, version 3.19.0 + +- Extended functions `distance` and `intersect` with support for BigNumbers. + Thanks @ovk. +- Improvements in function `simplify`: added a rule that allows combining + of like terms in embedded quantities. Thanks @joelhoover. + +## 2017-12-28, version 3.18.1 + +- Fixed #998: An issue with simplifying an expression containing a subtraction. + Thanks @firepick1. + +## 2017-12-16, version 3.18.0 + +- Implemented function `rationalize`. Thanks @paulobuchsbaum. +- Upgraded dependencies: + + ``` + decimal.js 7.2.3 → 9.0.1 (no breaking changes affecting mathjs) + fraction.js 4.0.2 → 4.0.4 + tiny-emitter 2.0.0 → 2.0.2 + ``` + +- Upgraded dev dependencies. +- Fixed #975: a wrong example in the docs of lusolve. +- Fixed #983: `pickRandom` returning an array instead of single value + when input was an array with just one value. Clarified docs. +- Fixed #969: preven issues with yarn autoclean by renaming an + interally used folder "docs" to "embeddedDocs". + +## 2017-11-18, version 3.17.0 + +- Improved `simplify` for nested exponentiations. Thanks @IvanVergiliev. +- Fixed a security issue in `typed-function` allowing arbitrary code execution + in the JavaScript engine by creating a typed function with JavaScript code + in the name. Thanks Masato Kinugawa. +- Fixed a security issue where forbidden properties like constructor could be + replaced by using unicode characters when creating an object. No known exploit, + but could possibly allow arbitrary code execution. Thanks Masato Kinugawa. + +## 2017-10-18, version 3.16.5 + +- Fixed #954: Functions `add` and `multiply` not working when + passing three or more arrays or matrices. + +## 2017-10-01, version 3.16.4 + +- Fixed #948, #949: function `simplify` returning wrong results or + running into an infinite recursive loop. Thanks @ericman314. +- Fixed many small issues in the embedded docs. Thanks @Schnark. + +## 2017-08-28, version 3.16.3 + +- Fixed #934: Wrong simplification of unary minus. Thanks @firepick1. +- Fixed #933: function `simplify` reordering operations. Thanks @firepick1. +- Fixed #930: function `isNaN` returning wrong result for complex + numbers having just one of their parts (re/im) being `NaN`. +- Fixed #929: `FibonacciHeap.isEmpty` returning wrong result. + +## 2017-08-20, version 3.16.2 + +- Fixed #924: a regression in `simplify` not accepting the signature + `simplify(expr, rules, scope)` anymore. Thanks @firepick1. +- Fixed missing parenthesis when stringifying expressions containing + implicit multiplications (see #922). Thanks @FSMaxB. + +## 2017-08-12, version 3.16.1 + +- For security reasons, type checking is now done in a more strict + way using functions like `isComplex(x)` instead of duck type checking + like `x && x.isComplex === true`. +- Fixed #915: No access to property "name". +- Fixed #901: Simplify units when calling `unit.toNumeric()`. + Thanks @AlexanderBeyn. +- Fixed `toString` of a parsed expression tree containing an + immediately invoked function assignment not being wrapped in + parenthesis (for example `(f(x) = x^2)(4)`). + +## 2017-08-06, version 3.16.0 + +- Significant performance improvements in `math.simplify`. + Thanks @firepick1. +- Improved API for `math.simplify`, optionally pass a scope with + variables which are resolved, see #907. Thanks @firepick1. +- Fixed #912: math.js didn't work on IE10 anymore (regression + since 3.15.0). + +## 2017-07-29, version 3.15.0 + +- Added support for the dollar character `$` in symbol names (see #895). +- Allow objects with prototypes as scope again in the expression parser, + this was disabled for security reasons some time ago. See #888, #899. + Thanks @ThomasBrierley. +- Fixed #846: Issues in the functions `map`, `forEach`, and `filter` + when used in the expression parser: + - Not being able to use a function assignment as inline expression + for the callback function. + - Not being able to pass an inline expression as callback for `map` + and `forEach`. + - Index and original array/matrix not passed in `map` and `filter`. + +## 2017-07-05, version 3.14.2 + +- Upgraded to `fraction.js@4.0.2` +- Fixed #891 using BigNumbers not working in browser environments. + +## 2017-06-30, version 3.14.1 + +- Reverted to `fraction.js@4.0.0`, there is an issue with `4.0.1` + in the browser. + +## 2017-06-30, version 3.14.0 + +- Implemented set methods `setCartesian`, `setDifference`, + `setDistinct`, `setIntersect`, `setIsSubset`, `setPowerset`, + `setSize`. Thanks @Nekomajin42. +- Implemented method `toHTML` on nodes. Thanks @Nekomajin42. +- Implemented `compareNatural` and `sort([...], 'natural')`. +- Upgraded dependencies to the latest versions: + - `complex.js@2.0.4` + - `decimal.js@7.2.3` + - `fraction.js@4.0.1` + - `tiny-emitter@2.0.0` + - And all devDependencies. +- Fixed #865: `splitUnit` can now deal with round-off errors. + Thanks @ericman314. +- Fixed #876: incorrect definition for unit `erg`. Thanks @pjhampton. +- More informative error message when using single quotes instead of + double quotes around a string. Thanks @HarrySarson. + +## 2017-05-27, version 3.13.3 + +- Fixed a bug in function `intersection` of line and plane. + Thanks @viclai. +- Fixed security vulnerabilities. + +## 2017-05-26, version 3.13.2 + +- Disabled function `chain` inside the expression parser for security + reasons (it's not needed there anyway). +- Fixed #856: function `subset` not returning non-primitive scalars + from Arrays correctly. (like `math.eval('arr[1]', {arr: [math.bignumber(2)]})`. +- Fixed #861: physical constants not available in the expression parser. + +## 2017-05-12, version 3.13.1 + +- Fixed creating units with an alias not working within the expression + parser. +- Fixed security vulnerabilities. Thanks Sam. + +## 2017-05-12, version 3.13.0 + +- Command line application can now evaluate inline expressions + like `mathjs 1+2`. Thanks @slavaGanzin. +- Function `derivative` now supports `abs`. Thanks @tetslee. +- Function `simplify` now supports BigNumbers. Thanks @tetslee. +- Prevent against endless loops in `simplify`. Thanks @tetslee. +- Fixed #813: function `simplify` converting small numbers to inexact + Fractions. Thanks @tetslee. +- Fixed #838: Function `simplify` now supports constants like `e`. + Thanks @tetslee. + +## 2017-05-05, version 3.12.3 + +- Fixed security vulnerabilities. Thanks Dan and Sam. + +## 2017-04-30, version 3.12.2 + +- Added a rocket trajectory optimization example. + +## 2017-04-24, version 3.12.1 + +- Fixed #804 + - Improved handling of powers of `Infinity`. Thanks @HarrySarson. + - Fixed wrong formatting of complex NaN. +- Fixed security vulnerabilities in the expression parser. + Thanks Sam and Dan. + +## 2017-04-17, version 3.12.0 + +- Implemented QR decomposition, function `math.qr`. Thanks @HarrySarson. +- Fixed #824: Calling `math.random()` freezes IE and node.js. + +## 2017-04-08, version 3.11.5 + +- More security measures in the expression parser. + WARNING: the behavior of the expression parser is now more strict, + some undocumented features may not work any longer. + - Accessing and assigning properties is now only allowed on plain + objects, not on classes, arrays, and functions anymore. + - Accessing methods is restricted to a set of known, safe methods. + +## 2017-04-03, version 3.11.4 + +- Fixed a security vulnerability in the expression parser. Thanks @xfix. + +## 2017-04-03, version 3.11.3 + +- Fixed a security vulnerability in the expression parser. Thanks @xfix. + +## 2017-04-03, version 3.11.2 + +- Fixed a security vulnerability in the expression parser. Thanks @xfix. + +## 2017-04-02, version 3.11.1 + +- Fixed security vulnerabilities in the expression parser. + Thanks Joe Vennix and @xfix. + +## 2017-04-02, version 3.11.0 + +- Implemented method Unit.toSI() to convert a unit to base SI units. + Thanks @ericman314. +- Fixed #821, #822: security vulnerabilities in the expression parser. + Thanks @comex and @xfix. + +## 2017-03-31, version 3.10.3 + +- More security fixes related to the ones fixed in `v3.10.2`. + +## 2017-03-31, version 3.10.2 + +- Fixed a security vulnerability in the expression parser allowing + execution of arbitrary JavaScript. Thanks @CapacitorSet and @denvit. + +## 2017-03-26, version 3.10.1 + +- Fixed `xgcd` for negative values. Thanks @litmit. +- Fixed #807: function transform of existing functions not being removed when + overriding such a function. + +## 2017-03-05, version 3.10.0 + +- Implemented function `reshape`. Thanks @patgrasso and @ericman314. +- Implemented configuration option `seedRandom` for deterministic random + numbers. Thanks @morsecodist. +- Small fixes in the docs. Thanks @HarrySarson. +- Dropped support for component package manager (which became deprecated about + one and a half year ago). + +## 2017-02-22, version 3.9.3 + +- Fixed #797: issue with production builds of React Native projects. +- Fixed `math.round` not accepting inputs `NaN`, `Infinity`, `-Infinity`. +- Upgraded all dependencies. + +## 2017-02-16, version 3.9.2 + +- Fixed #795: Parse error in case of a multi-line expression with just comments. + +## 2017-02-06, version 3.9.1 + +- Fixed #789: Math.js not supporting conversion of `string` to `BigNumber`, + `Fraction`, or `Complex` number. +- Fixed #790: Expression parser did not pass function arguments of enclosing + functions via `scope` to functions having `rawArgs = true`. +- Small fixes in the docs. Thanks @HarrySarson. + +## 2017-01-23, version 3.9.0 + +- Implemented support for algebra: powerful new functions `simplify` and + `derivative`. Thanks @ericman314, @tetslee, and @BigFav. +- Implemented Kronecker Product `kron`. Thanks @adamisntdead. +- Reverted `FunctionNode` not accepting a string as function name anymore. +- Fixed #765: `FunctionAssignmentNode.toString()` returning a string + incompatible with the function assignment syntax. + +## 2016-12-15, version 3.8.1 + +- Implemented function `mad` (median absolute deviation). Thanks @ruhleder. +- Fixed #762: expression parser failing to invoke a function returned + by a function. + +## 2016-11-18, version 3.8.0 + +- Functions `add` and `multiply` now accept more than two arguments. See #739. +- `OperatorNode` now supports more than two arguments. See #739. Thanks @FSMaxB. +- Implemented a method `Node.cloneDeep` for the expression nodes. See #745. +- Fixed a bug in `Node.clone()` not cloning implicit multiplication correctly. + Thanks @FSMaxB. +- Fixed #737: Improved algorithm determining the best prefix for units. + It will now retain the original unit like `1 cm` when close enough, + instead of returning `10 mm`. Thanks @ericman314. +- Fixed #732: Allow letter-like unicode characters like Ohm `\u2126`. +- Fixed #749: Units `rad`, `deg`, and `grad` can now have prefixes like `millirad`. +- Some fixes in the docs and comments of examples. Thanks @HarrySarson. + +## 2016-11-05, version 3.7.0 + +- Implemented method `Node.equals(other)` for all nodes of the expression parser. +- Implemented BigNumber support in function `arg()`. +- Command Line Interface loads faster. +- Implicit conversions between Fractions and BigNumbers throw a neat error now + (See #710). + +## 2016-10-21, version 3.6.0 + +- Implemented function `erf()`. THanks @patgrasso. +- Extended function `cross()` to support n-d vectors. Thanks @patgrasso. +- Extended function `pickRandom` with the option to pick multiple values from + an array and give the values weights: `pickRandom(possibles, number, weights)`. + Thanks @woylie. +- Parser now exposes test functions like `isAlpha` which can be replaced in + order to adjust the allowed characters in variables names (See #715). +- Fixed #727: Parser not throwing an error for invalid implicit multiplications + like `-2 2` and `2^3 4` (right after the second value of an operator). +- Fixed #688: Describe allowed variable names in the docs. + +## 2016-09-21, version 3.5.3 + +- Some more fixes regarding numbers ending with a decimal mark (like `2.`). + +## 2016-09-20, version 3.5.2 + +- Fixed numbers ending with a decimal mark (like `2.`) not being supported by + the parser, solved the underlying ambiguity in the parser. See #707, #711. + +## 2016-09-12, version 3.5.1 + +- Removed a left over console.log statement. Thanks @eknkc. + +## 2016-09-07, version 3.5.0 + +- Comments of expressions are are now stored in the parsed nodes. See #690. +- Fixed function `print` not accepting an Object with formatting options as + third parameter Thanks @ThomasBrierley. +- Fixed #707: The expression parser no longer accepts numbers ending with a dot + like `2.`. + +## 2016-08-08, version 3.4.1 + +- Fixed broken bundle files (`dist/math.js`, `dist/math.min.js`). +- Fixed some layout issues in the function reference docs. + +## 2016-08-07, version 3.4.0 + +- Implemented support for custom units using `createUnit`. Thanks @ericman314. +- Implemented function `splitUnits`. Thanks @ericman314. +- Implemented function `isPrime`. Thanks @MathBunny. + +## 2016-07-05, version 3.3.0 + +- Implemented function `isNaN`. +- Function `math.filter` now passes three arguments to the callback function: + value, index, and array. +- Removed the check on the number of arguments from functions defined in the + expression parser (see #665). +- Fixed #665: functions `map`, `forEach`, and `filter` now invoke callbacks + which are a typed-function with the correct number of arguments. + +## 2016-04-26, version 3.2.1 + +- Fixed #651: unable to perform calculations on "Unit-less" units. +- Fixed matrix.subset mutating the replacement matrix when unsqueezing it. + +## 2016-04-16, version 3.2.0 + +- Implemented #644: method `Parser.getAll()` to retrieve all defined variables. +- Upgraded dependencies (decimal.js@5.0.8, fraction.js@3.3.1, + typed-function@0.10.4). +- Fixed #601: Issue with unnamed typed-functions by upgrading to + typed-function v0.10.4. +- Fixed #636: More strict `toTex` templates, reckon with number of arguments. +- Fixed #641: Bug in expression parser parsing implicit multiplication with + wrong precedence in specific cases. +- Fixed #645: Added documentation about `engineering` notation of function + `math.format`. + +## 2016-04-03, version 3.1.4 + +- Using ES6 Math functions like `Math.sinh`, `Math.cbrt`, `Math.sign`, etc when + available. +- Fixed #631: unit aliases `weeks`, `months`, and `years` where missing. +- Fixed #632: problem with escaped backslashes at the end of strings. +- Fixed #635: `Node.toString` options where not passed to function arguments. +- Fixed #629: expression parser throws an error when passing a number with + decimal exponent instead of parsing them as implicit multiplication. +- Fixed #484, #555: inaccuracy of `math.sinh` for values between -1 and 1. +- Fixed #625: Unit `in` (`inch`) not always working due to ambiguity with + the operator `a in b` (alias of `a to b`). + +## 2016-03-24, version 3.1.3 + +- Fix broken bundle. + +## 2016-03-24, version 3.1.2 + +- Fix broken npm release. + +## 2016-03-24, version 3.1.1 + +- Fixed #621: a bug in parsing implicit multiplications like `(2)(3)+4`. +- Fixed #623: `nthRoot` of zero with a negative root returned `0` instead of + `Infinity`. +- Throw an error when functions `min`, `max`, `mean`, or `median` are invoked + with multiple matrices as arguments (see #598). + +## 2016-03-19, version 3.1.0 + +- Hide multiplication operator by default when outputting `toTex` and `toString` + for implicit multiplications. Implemented and option to output the operator. +- Implemented unit `kip` and alias `kips`. Thanks @hgupta9. +- Added support for prefixes for units `mol` and `mole`. Thanks @stu-blair. +- Restored support for implicit multiplications like `2(3+4)` and `(2+3)(4+5)`. +- Some improvements in the docs. +- Added automatic conversions from `boolean` and `null` to `Fraction`, + and conversions from `Fraction` to `Complex`. + +## 2016-03-04, version 3.0.0 + +### breaking changes + +- More restricted support for implicit multiplication in the expression + parser: `(...)(...)` is now evaluated as a function invocation, + and `[...][...]` as a matrix subset. +- Matrix multiplication no longer squeezes scalar outputs to a scalar value, + but leaves them as they are: a vector or matrix containing a single value. + See #529. +- Assignments in the expression parser now return the assigned value rather + than the created or updated object (see #533). Example: + + ``` + A = eye(3) + A[1,1] = 2 # this assignment now returns 2 instead of A + ``` + +- Expression parser now supports objects. This involves a refactoring and + extension in expression nodes: + - Implemented new node `ObjectNode`. + - Refactored `AssignmentNode`, `UpdateNode`, and `IndexNode` are refactored + into `AccessorNode`, `AssignmentNode`, and `IndexNode` having a different API. +- Upgraded the used BigNumber library `decimal.js` to v5. Replaced the + trigonometric functions of math.js with those provided in decimal.js v5. + This can give slightly different behavior qua round-off errors. +- Replaced the internal `Complex.js` class with the `complex.js` library + created by @infusion. +- Entries in a matrix (typically numbers, BigNumbers, Units, etc) are now + considered immutable, they are no longer copied when performing operations on + the entries, improving performance. +- Implemented nearly equal comparison for relational functions (`equal`, + `larger`, `smaller`, etc.) when using BigNumbers. +- Changed the casing of the configuration options `matrix` (`Array` or `Matrix`) + and `number` (`number`, `BigNumber`, `Fraction`) such that they now match + the type returned by `math.typeof`. Wrong casing gives a console warning but + will still work. +- Changed the default config value for `epsilon` from `1e-14` to `1e-12`, + see #561. + +### non-breaking changes + +- Extended function `pow` to return the real root for cubic roots of negative + numbers. See #525, #482, #567. +- Implemented support for JSON objects in the expression parser and the + function `math.format`. +- Function `math.fraction` now supports `BigNumber`, and function + `math.bignumber` now supports `Fraction`. +- Expression parser now allows function and/or variable assignments inside + accessors and conditionals, like `A[x=2]` or `a > 2 ? b="ok" : b="fail"`. +- Command line interface: + - Outputs the variable name of assignments. + - Fixed not rounding BigNumbers to 14 digits like numbers. + - Fixed non-working autocompletion of user defined variables. +- Reorganized and extended docs, added docs on classes and more. Thanks @hgupta9. +- Added new units `acre`, `hectare`, `torr`, `bar`, `mmHg`, `mmH2O`, `cmH2O`, + and added new aliases `acres`, `hectares`, `sqfeet`, `sqyard`, `sqmile`, + `sqmiles`, `mmhg`, `mmh2o`, `cmh2o`. Thanks @hgupta9. +- Fixed a bug in the toString method of an IndexNode. +- Fixed angle units `deg`, `rad`, `grad`, `cycle`, `arcsec`, and `arcmin` not + being defined as BigNumbers when configuring to use BigNumbers. + +## 2016-02-03, version 2.7.0 + +- Added more unit aliases for time: `secs`, `mins`, `hr`, `hrs`. See #551. +- Added support for doing operations with mixed `Fractions` and `BigNumbers`. +- Fixed #540: `math.intersect()` returning null in some cases. Thanks @void42. +- Fixed #546: Cannot import BigNumber, Fraction, Matrix, Array. + Thanks @brettjurgens. + +## 2016-01-08, version 2.6.0 + +- Implemented (complex) units `VA` and `VAR`. +- Implemented time units for weeks, months, years, decades, centuries, and + millennia. Thanks @owenversteeg. +- Implemented new notation `engineering` in function `math.format`. + Thanks @johnmarinelli. +- Fixed #523: In some circumstances, matrix subset returned a scalar instead + of the correct subset. +- Fixed #536: A bug in an internal method used for sparse matrices. + +## 2015-12-05, version 2.5.0 + +- Implemented support for numeric types `Fraction` and `BigNumber` in units. +- Implemented new method `toNumeric` for units. +- Implemented new units `arcsec`, `arcsecond`, `arcmin`, `arcminute`. + Thanks @devdevdata222. +- Implemented new unit `Herts` (`Hz`). Thanks @SwamWithTurtles. +- Fixed #485: Scoping issue with variables both used globally as well as in a + function definition. +- Fixed: Function `number` didn't support `Fraction` as input. + +## 2015-11-14, version 2.4.2 + +- Fixed #502: Issue with `format` in some JavaScript engines. +- Fixed #503: Removed trailing commas and the use of keyword `import` as + property, as this gives issues with old JavaScript engines. + +## 2015-10-29, version 2.4.1 + +- Fixed #480: `nthRoot` not working on Internet Explorer (up to IE11). +- Fixed #490: `nthRoot` returning an error for negative values like + `nthRoot(-2, 3)`. +- Fixed #489: an issue with initializing a sparse matrix without data. + Thanks @Retsam. +- Fixed: #493: function `combinations` did not throw an exception for + non-integer values of `k`. +- Fixed: function `import` did not override typed functions when the option + override was set true. +- Fixed: added functions `math.sparse` and `math.index` to the reference docs, + they where missing. +- Fixed: removed memoization from `gamma` and `factorial` functions, this + could blow up memory. + +## 2015-10-09, version 2.4.0 + +- Added support in the expression parser for mathematical alphanumeric symbols + in the expression parser: unicode range \u{1D400} to \u{1D7FF} excluding + invalid code points. +- Extended function `distance` with more signatures. Thanks @kv-kunalvyas. +- Fixed a bug in functions `sin` and `cos`, which gave wrong results for + BigNumber integer values around multiples of tau (i.e. `sin(bignumber(7))`). +- Fixed value of unit `stone`. Thanks @Esvandiary for finding the error. + +## 2015-09-19, version 2.3.0 + +- Implemented function `distance`. Thanks @devanp92. +- Implemented support for Fractions in function `lcm`. Thanks @infusion. +- Implemented function `cbrt` for numbers, complex numbers, BigNumbers, Units. +- Implemented function `hypot`. +- Upgraded to fraction.js v3.0.0. +- Fixed #450: issue with non sorted index in sparse matrices. +- Fixed #463, #322: inconsistent handling of implicit multiplication. +- Fixed #444: factorial of infinity not returning infinity. + +## 2015-08-30, version 2.2.0 + +- Units with powers (like `m^2` and `s^-1`) now output with the best prefix. +- Implemented support for units to `abs`, `cube`, `sign`, `sqrt`, `square`. + Thanks @ericman314. +- Implemented function `catalan` (Combinatorics). Thanks @devanp92. +- Improved the `canDefineProperty` check to return false in case of IE8, which + has a broken implementation of `defineProperty`. Thanks @golmansax. +- Fixed function `to` not working in case of a simplified unit. +- Fixed #437: an issue with row swapping in `lup`, also affecting `lusolve`. + +## 2015-08-12, version 2.1.1 + +- Fixed wrong values of the physical constants `speedOfLight`, `molarMassC12`, + and `magneticFluxQuantum`. Thanks @ericman314 for finding two of them. + +## 2015-08-11, version 2.1.0 + +- Implemented derived units (like `110 km/h in m/s`). Thanks @ericman314. +- Implemented support for electric units. Thanks @ericman314. +- Implemented about 50 physical constants like `speedOfLight`, `gravity`, etc. +- Implemented function `kldivergence` (Kullback-Leibler divergence). + Thanks @saromanov. +- Implemented function `mode`. Thanks @kv-kunalvyas. +- Added support for unicode characters in the expression parser: greek letters + and latin letters with accents. See #265. +- Internal functions `Unit.parse` and `Complex.parse` now throw an Error + instead of returning null when passing invalid input. + +## 2015-07-29, version 2.0.1 + +- Fixed operations with mixed fractions and numbers be converted to numbers + instead of fractions. + +## 2015-07-28, version 2.0.0 + +- Large internal refactoring: + - performance improvements. + - allows to create custom bundles + - functions are composed using `typed-function` and are extensible +- Implemented support for fractions, powered by the library `fraction.js`. +- Implemented matrix LU decomposition with partial pivoting and a LU based + linear equations solver (functions `lup` and `lusolve`). Thanks @rjbaucells. +- Implemented a new configuration option `predictable`, which can be set to + true in order to ensure predictable function output types. +- Implemented function `intersect`. Thanks @kv-kunalvyas. +- Implemented support for adding `toTex` properties to custom functions. + Thanks @FSMaxB. +- Implemented support for complex values to `nthRoot`. Thanks @gangachris. +- Implemented util functions `isInteger`, `isNegative`, `isNumeric`, + `isPositive`, and `isZero`. + +### breaking changes + +- String input is now converted to numbers by default for all functions. +- Adding two strings will no longer concatenate them, but will convert the + strings to numbers and add them. +- Function `index` does no longer accept an array `[start, end, step]`, but + instead accepts an array with arbitrary index values. It also accepts + a `Range` object as input. +- Function `typeof` no longer returns lower case names, but now returns lower + case names for primitives (like `number`, `boolean`, `string`), and + upper-camel-case for non-primitives (like `Array`, `Complex`, `Function`). +- Function `import` no longer supports a module name as argument. Instead, + modules can be loaded using require: `math.import(require('module-name'))`. +- Function `import` has a new option `silent` to ignore errors, and throws + errors on duplicates by default. +- Method `Node.compile()` no longer needs `math` to be passed as argument. +- Reintroduced method `Node.eval([scope])`. +- Function `sum` now returns zero when input is an empty array. Thanks @FSMAxB. +- The size of Arrays is no longer validated. Matrices will validate this on + creation. + +## 2015-07-12, version 1.7.1 + +- Fixed #397: Inaccuracies in nthRoot for very large values, and wrong results + for very small values. (backported from v2) +- Fixed #405: Parser throws error when defining a function in a multiline + expression. + +## 2015-05-31, version 1.7.0 + +- Implemented function `quantileSeq` and `partitionSelect`. Thanks @BigFav. +- Implemented functions `stirlingS2`, `bellNumbers`, `composition`, and + `multinomial`. Thanks @devanp92. +- Improved the performance of `median` (see #373). Thanks @BigFav. +- Extended the command line interface with a `mode` option to output either + the expressions result, string representation, or tex representation. + Thanks @FSMaxB. +- Fixed #309: Function median mutating the input matrix. Thanks @FSMaxB. +- Fixed `Node.transform` not recursing over replaced parts of the + node tree (see #349). +- Fixed #381: issue in docs of `randomInt`. + +## 2015-04-22, version 1.6.0 + +- Improvements in `toTex`. Thanks @FSMaxB. +- Fixed #328: `abs(0 + 0i)` evaluated to `NaN`. +- Fixed not being able to override lazy loaded constants. + +## 2015-04-09, version 1.5.2 + +- Fixed #313: parsed functions did not handle recursive calls correctly. +- Fixed #251: binary prefix and SI prefix incorrectly used for byte. Now + following SI standards (`1 KiB == 1024 B`, `1 kB == 1000 B`). +- Performance improvements in parsed functions. + +## 2015-04-08, version 1.5.1 + +- Fixed #316: a bug in rounding values when formatting. +- Fixed #317, #319: a bug in formatting negative values. + +## 2015-03-28, version 1.5.0 + +- Added unit `stone` (6.35 kg). +- Implemented support for sparse matrices. Thanks @rjbaucells. +- Implemented BigNumber support for function `atan2`. Thanks @BigFav. +- Implemented support for custom LaTeX representations. Thanks @FSMaxB. +- Improvements and bug fixes in outputting parentheses in `Node.toString` and + `Node.toTex` functions. Thanks @FSMaxB. +- Fixed #291: function `format` sometimes returning exponential notation when + it should return a fixed notation. + +## 2015-02-28, version 1.4.0 + +- Implemented trigonometric functions: + `acosh`, `acoth`, `acsch`, `asech`, `asinh`, `atanh`, `acot`, `acsc`, `asec`. + Thanks @BigFav. +- Added BigNumber support for functions: `cot`, `csc`, `sec`, `coth`, + `csch`, `sech`. Thanks @BigFav. +- Implemented support for serialization and deserialization of math.js data + types. +- Fixed the calculation of `norm()` and `abs()` for large complex numbers. + Thanks @rjbaucells. +- Fixed #281: improved formatting complex numbers. Round the real or imaginary + part to zero when the difference is larger than the configured precision. + +## 2015-02-09, version 1.3.0 + +- Implemented BigNumber implementations of most trigonometric functions: `sin`, + `cos`, `tan`, `asin`, `acos`, `atan`, `cosh`, `sinh`, `tanh`. Thanks @BigFav. +- Implemented function `trace`. Thanks @pcorey. +- Faster loading of BigNumber configuration with a high precision by lazy + loading constants like `pi` and `e`. +- Fixed constants `NaN` and `Infinity` not being BigNumber objects when + BigNumbers are configured. +- Fixed missing parentheses in the `toTex` representation of function + `permutations`. +- Some minor fixes in the docs. Thanks @KenanY. + +## 2014-12-25, version 1.2.0 + +- Support for bitwise operations `bitAnd`, `bitNot`, `bitOr`, `bitXor`, + `leftShift`, `rightArithShift`, and `rightLogShift`. Thanks @BigFav. +- Support for boolean operations `and`, `not`, `or`, `xor`. Thanks @BigFav. +- Support for `gamma` function. Thanks @BigFav. +- Converting a unit without value will now result in a unit *with* value, + i.e. `inch in cm` will return `2.54 cm` instead of `cm`. +- Improved accuracy of `sinh` and complex `cos` and `sin`. Thanks @pavpanchekha. +- Renamed function `select` to `chain`. The old function `select` will remain + functional until math.js v2.0. +- Upgraded to decimal.js v4.0.1 (BigNumber library). + +## 2014-11-22, version 1.1.1 + +- Fixed Unit divided by Number returning zero. +- Fixed BigNumber downgrading to Number for a negative base in `pow`. +- Fixed some typos in error messaging (thanks @andy0130tw) and docs. + +## 2014-11-15, version 1.1.0 + +- Implemented functions `dot` (dot product), `cross` (cross product), and + `nthRoot`. +- Officially opened up the API of expression trees: + - Documented the API. + - Implemented recursive functions `clone`, `map`, `forEach`, `traverse`, + `transform`, and `filter` for expression trees. + - Parameter `index` in the callbacks of `map` and `forEach` are now cloned + for every callback. + - Some internal refactoring inside nodes to make the API consistent: + - Renamed `params` to `args` and vice versa to make things consistent. + - Renamed `Block.nodes` to `Block.blocks`. + - `FunctionNode` now has a `name: string` instead of a `symbol: SymbolNode`. + - Changed constructor of `RangeNode` to + `new RangeNode(start: Node, end: Node [, step: Node])`. + - Nodes for a `BlockNode` must now be passed via the constructor instead + of via a function `add`. +- Fixed `2e` giving a syntax error instead of being parsed as `2 * e`. + +## 2014-09-12, version 1.0.1 + +- Disabled array notation for ranges in a matrix index in the expression parser + (it is confusing and redundant there). +- Fixed a regression in the build of function subset not being able to return + a scalar. +- Fixed some missing docs and broken links in the docs. + +## 2014-09-04, version 1.0.0 + +- Implemented a function `filter(x, test)`. +- Removed `math.distribution` for now, needs some rethinking. +- `math.number` can convert units to numbers (requires a second argument) +- Fixed some precedence issues with the range and conversion operators. +- Fixed an zero-based issue when getting a matrix subset using an index + containing a matrix. + +## 2014-08-21, version 0.27.0 + +- Implemented functions `sort(x [, compare])` and `flatten(x)`. +- Implemented support for `null` in all functions. +- Implemented support for "rawArgs" functions in the expression parser. Raw + functions are invoked with unevaluated parameters (nodes). +- Expressions in the expression parser can now be spread over multiple lines, + like '2 +\n3'. +- Changed default value of the option `wrap` of function `math.import` to false. +- Changed the default value for new entries in a resized matrix when to zero. + To leave new entries uninitialized, use the new constant `math.uninitialized` + as default value. +- Renamed transform property from `__transform__` to `transform`, and documented + the transform feature. +- Fixed a bug in `math.import` not applying options when passing a module name. +- A returned matrix subset is now only squeezed when the `index` consists of + scalar values, and no longer for ranges resolving into a single value. + +## 2014-08-03, version 0.26.0 + +- A new instance of math.js can no longer be created like `math([options])`, + to prevent side effects from math being a function instead of an object. + Instead, use the function `math.create([options])` to create a new instance. +- Implemented `BigNumber` support for all constants: `pi`, `tau`, `e`, `phi`, + `E`, `LN2`, `LN10`, `LOG2E`, `LOG10E`, `PI`, `SQRT1_2`, and `SQRT2`. +- Implemented `BigNumber` support for functions `gcd`, `xgcd`, and `lcm`. +- Fixed function `gxcd` returning an Array when math.js was configured + as `{matrix: 'matrix'}`. +- Multi-line expressions now return a `ResultSet` instead of an `Array`. +- Implemented transforms (used right now to transform one-based indices to + zero-based for expressions). +- When used inside the expression parser, functions `concat`, `min`, `max`, + and `mean` expect an one-based dimension number. +- Functions `map` and `forEach` invoke the callback with one-based indices + when used from within the expression parser. +- When adding or removing dimensions when resizing a matrix, the dimensions + are added/removed from the inner side (right) instead of outer side (left). +- Improved index out of range errors. +- Fixed function `concat` not accepting a `BigNumber` for parameter `dim`. +- Function `squeeze` now squeezes both inner and outer singleton dimensions. +- Output of getting a matrix subset is not automatically squeezed anymore + except for scalar output. +- Renamed `FunctionNode` to `FunctionAssignmentNode`, and renamed `ParamsNode` + to `FunctionNode` for more clarity. +- Fixed broken auto completion in CLI. +- Some minor fixes. + +## 2014-07-01, version 0.25.0 + +- The library now immediately returns a default instance of mathjs, there is + no need to instantiate math.js in a separate step unless one ones to set + configuration options: + + // instead of: + var mathjs = require('mathjs'), // load math.js + math = mathjs(); // create an instance + + // just do: + var math = require('mathjs'); +- Implemented support for implicit multiplication, like `math.eval('2a', {a:3})` + and `math.eval('(2+3)(1-3)')`. This changes behavior of matrix indexes as + well: an expression like `[...][...]` is not evaluated as taking a subset of + the first matrix, but as an implicit multiplication of two matrices. +- Removed utility function `ifElse`. This function is redundant now the + expression parser has a conditional operator `a ? b : c`. +- Fixed a bug with multiplying a number with a temperature, + like `math.eval('10 * celsius')`. +- Fixed a bug with symbols having value `undefined` not being evaluated. + +## 2014-06-20, version 0.24.1 + +- Something went wrong with publishing on npm. + +## 2014-06-20, version 0.24.0 + +- Added constant `null`. +- Functions `equal` and `unequal` support `null` and `undefined` now. +- Function `typeof` now recognizes regular expressions as well. +- Objects `Complex`, `Unit`, and `Help` now return their string representation + when calling `.valueOf()`. +- Changed the default number of significant digits for BigNumbers from 20 to 64. +- Changed the behavior of the conditional operator (a ? b : c) to lazy + evaluating. +- Fixed imported, wrapped functions not accepting `null` and `undefined` as + function arguments. + +## 2014-06-10, version 0.23.0 + +- Renamed some functions (everything now has a logical, camel case name): + - Renamed functions `edivide`, `emultiply`, and `epow` to `dotDivide`, + `dotMultiply`, and `dotPow` respectively. + - Renamed functions `smallereq` and `largereq` to `smallerEq` and `largerEq`. + - Renamed function `unary` to `unaryMinus` and added support for strings. +- `end` is now a reserved keyword which cannot be used as function or symbol + name in the expression parser, and is not allowed in the scope against which + an expression is evaluated. +- Implemented function `unaryPlus` and unary plus operator. +- Implemented function `deepEqual` for matrix comparisons. +- Added constant `phi`, the golden ratio (`phi = 1.618...`). +- Added constant `version`, returning the version number of math.js as string. +- Added unit `drop` (`gtt`). +- Fixed not being able to load math.js using AMD/require.js. +- Changed signature of `math.parse(expr, nodes)` to `math.parse(expr, options)` + where `options: {nodes: Object.}` +- Removed matrix support from conditional function `ifElse`. +- Removed automatic assignment of expression results to variable `ans`. + This functionality can be restored by pre- or postprocessing every evaluation, + something like: + + function evalWithAns (expr, scope) { + var ans = math.eval(expr, scope); + if (scope) { + scope.ans = ans; + } + return ans; + } + +## 2014-05-22, version 0.22.0 + +- Implemented support to export expressions to LaTeX. Thanks Niels Heisterkamp + (@nheisterkamp). +- Output of matrix multiplication is now consistently squeezed. +- Added reference documentation in the section /docs/reference. +- Fixed a bug in multiplying units without value with a number (like `5 * cm`). +- Fixed a bug in multiplying two matrices containing vectors (worked fine for + arrays). +- Fixed random functions not accepting Matrix as input, and always returning + a Matrix as output. + +## 2014-05-13, version 0.21.1 + +- Removed `crypto` library from the bundle. +- Deprecated functions `Parser.parse` and `Parser.compile`. Use + `math.parse` and `math.compile` instead. +- Fixed function `add` not adding strings and matrices element wise. +- Fixed parser not being able to evaluate an exponent followed by a unary minus + like `2^-3`, and a transpose followed by an index like `[3]'[1]`. + +## 2014-04-24, version 0.21.0 + +- Implemented trigonometric hyperbolic functions `cosh`, `coth`, `csch`, + `sech`, `sinh`, `tanh`. Thanks Rogelio J. Baucells (@rjbaucells). +- Added property `type` to all expression nodes in an expression tree. +- Fixed functions `log`, `log10`, `pow`, and `sqrt` not supporting complex + results from BigNumber input (like `sqrt(bignumber(-4))`). + +## 2014-04-16, version 0.20.0 + +- Switched to module `decimal.js` for BigNumber support, instead of + `bignumber.js`. +- Implemented support for polar coordinates to the `Complex` datatype. + Thanks Finn Pauls (@finnp). +- Implemented BigNumber support for functions `exp`, `log`, and `log10`. +- Implemented conditional operator `a ? b : c` in expression parser. +- Improved floating point comparison: the functions now check whether values + are nearly equal, against a configured maximum relative difference `epsilon`. + Thanks Rogelio J. Baucells (@rjbaucells). +- Implemented function `norm`. Thanks Rogelio J. Baucells (@rjbaucells). +- Improved function `ifElse`, is now specified for special data types too. +- Improved function `det`. Thanks Bryan Cuccioli (@bcuccioli). +- Implemented `BigNumber` support for functions `det` and `diag`. +- Added unit alias `lbs` (pound mass). +- Changed configuration option `decimals` to `precision` (applies to BigNumbers + only). +- Fixed support for element-wise comparisons between a string and a matrix. +- Fixed: expression parser now trows IndexErrors with one-based indices instead + of zero-based. +- Minor bug fixes. + +## 2014-03-30, version 0.19.0 + +- Implemented functions `compare`, `sum`, `prod`, `var`, `std`, `median`. +- Implemented function `ifElse` Thanks @mtraynham. +- Minor bug fixes. + +## 2014-02-15, version 0.18.1 + +- Added unit `feet`. +- Implemented function `compile` (shortcut for parsing and then compiling). +- Improved performance of function `pow` for matrices. Thanks @hamadu. +- Fixed broken auto completion in the command line interface. +- Fixed an error in function `combinations` for large numbers, and + improved performance of both functions `combinations` and `permutations`. + +## 2014-01-18, version 0.18.0 + +- Changed matrix index notation of expression parser from round brackets to + square brackets, for example `A[1, 1:3]` instead of `A(1, 1:3)`. +- Removed need to use the `function` keyword for function assignments in the + expression parser, you can define a function now like `f(x) = x^2`. +- Implemented a compilation step in the expression parser: expressions are + compiled into JavaScript, giving much better performance (easily 10x as fast). +- Renamed unit conversion function and operator `in` to `to`. Operator `in` is + still available in the expression parser as an alias for `to`. Added unit + `in`, an abbreviation for `inch`. Thanks Elijah Insua (@tmpvar). +- Added plurals and aliases for units. +- Implemented an argument `includeEnd` for function `range` (false by default). +- Ranges in the expression parser now support big numbers. +- Implemented functions `permutations` and `combinations`. + Thanks Daniel Levin (@daniel-levin). +- Added lower case abbreviation `l` for unit litre. + +## 2013-12-19, version 0.17.1 + +- Fixed a bug with negative temperatures. +- Fixed a bug with prefixes of units squared meter `m2` and cubic meter `m3`. + +## 2013-12-12, version 0.17.0 + +- Renamed and flattened configuration settings: + - `number.defaultType` is now `number`. + - `number.precision` is now `decimals`. + - `matrix.defaultType` is now `matrix`. +- Function `multiply` now consistently outputs a complex number on complex input. +- Fixed `mod` and `in` not working as function (only as operator). +- Fixed support for old browsers (IE8 and older), compatible when using es5-shim. +- Fixed support for Java's ScriptEngine. + +## 2013-11-28, version 0.16.0 + +- Implemented BigNumber support for arbitrary precision calculations. + Added settings `number.defaultType` and `number.precision` to configure + big numbers. +- Documentation is extended. +- Removed utility functions `isScalar`, `toScalar`, `isVector`, `toVector` + from `Matrix` and `Range`. Use `math.squeeze` and `math.size` instead. +- Implemented functions `get` and `set` on `Matrix`, for easier and faster + retrieval/replacement of elements in a matrix. +- Implemented function `resize`, handling matrices, scalars, and strings. +- Functions `ones` and `zeros` now return an empty matrix instead of a + number 1 or 0 when no arguments are provided. +- Implemented functions `min` and `max` for `Range` and `Index`. +- Resizing matrices now leaves new elements undefined by default instead of + filling them with zeros. Function `resize` now has an extra optional + parameter `defaultValue`. +- Range operator `:` in expression parser has been given a higher precedence. +- Functions don't allow arguments of unknown type anymore. +- Options be set when constructing a math.js instance or using the new function + `config(options`. Options are no longer accessible via `math.options`. +- Renamed `scientific` notation to `exponential` in function `format`. +- Function `format` outputs exponential notation with positive exponents now + always with `+` sign, so outputs `2.1e+3` instead of `2.1e3`. +- Fixed function `squeeze` not being able squeeze into a scalar. +- Some fixes and performance improvements in the `resize` and `subset` + functions. +- Function `size` now adheres to the option `matrix.defaultType` for scalar + input. +- Minor bug fixes. + +## 2013-10-26, version 0.15.0 + +- Math.js must be instantiated now, static calls are no longer supported. Usage: + - node.js: `var math = require('mathjs')();` + - browser: `var math = mathjs();` +- Implemented support for multiplying vectors with matrices. +- Improved number formatting: + - Function `format` now support various options: precision, different + notations (`fixed`, `scientific`, `auto`), and more. + - Numbers are no longer rounded to 5 digits by default when formatted. + - Implemented a function `format` for `Matrix`, `Complex`, `Unit`, `Range`, + and `Selector` to format using options. + - Function `format` does only stringify values now, and has a new parameter + `precision` to round to a specific number of digits. + - Removed option `math.options.precision`, + use `math.format(value [, precision])` instead. + - Fixed formatting numbers as scientific notation in some cases returning + a zero digit left from the decimal point. (like "0.33333e8" rather than + "3.3333e7"). Thanks @husayt. +- Implemented a function `print` to interpolate values in a template string, + this functionality was moved from the function `format`. +- Implemented statistics function `mean`. Thanks Guillermo Indalecio Fernandez + (@guillermobox). +- Extended and changed `max` and `min` for multi dimensional matrices: they now + return the maximum and minimum of the flattened array. An optional second + argument `dim` allows to calculate the `max` or `min` for specified dimension. +- Renamed option `math.options.matrix.default` to + `math.options.matrix.defaultType`. +- Removed support for comparing complex numbers in functions `smaller`, + `smallereq`, `larger`, `largereq`. Complex numbers cannot be ordered. + +## 2013-10-08, version 0.14.0 + +- Introduced an option `math.options.matrix.default` which can have values + `matrix` (default) or `array`. This option is used by the functions `eye`, + `ones`, `range`, and `zeros`, to determine the type of matrix output. +- Getting a subset of a matrix will automatically squeeze the resulting subset, + setting a subset of a matrix will automatically unsqueeze the given subset. +- Removed concatenation of nested arrays in the expression parser. + You can now input nested arrays like in JavaScript. Matrices can be + concatenated using the function `concat`. +- The matrix syntax `[...]` in the expression parser now creates 1 dimensional + matrices by default. `math.eval('[1,2,3,4]')` returns a matrix with + size `[4]`, `math.eval('[1,2;3,4]')` returns a matrix with size `[2,2]`. +- Documentation is restructured and extended. +- Fixed non working operator `mod` (modulus operator). + +## 2013-09-03, version 0.13.0 + +- Implemented support for booleans in all relevant functions. +- Implemented functions `map` and `forEach`. Thanks Sebastien Piquemal (@sebpic). +- All construction functions can be used to convert the type of variables, + also element-wise for all elements in an Array or Matrix. +- Changed matrix indexes of the expression parser to one-based with the + upper-bound included, similar to most math applications. Note that on a + JavaScript level, math.js uses zero-based indexes with excluded upper-bound. +- Removed support for scalars in the function `subset`, it now only supports + Array, Matrix, and String. +- Removed the functions `get` and `set` from a selector, they are a duplicate + of the function `subset`. +- Replaced functions `get` and `set` of `Matrix` with a single function + `subset`. +- Some moving around with code and namespaces: + - Renamed namespace `math.expr` to `math.expression` (contains Scope, Parser, + node objects). + - Renamed namespace `math.docs` to `math.expression.docs`. + - Moved `math.expr.Selector` to `math.chaining.Selector`. +- Fixed some edge cases in functions `lcm` and `xgcd`. + +## 2013-08-22, version 0.12.1 + +- Fixed outdated version of README.md. +- Fixed a broken unit test. + +## 2013-08-22, version 0.12.0 + +- Implemented functions `random([min, max])`, `randomInt([min, max])`, + `pickRandom(array)`. Thanks Sebastien Piquemal (@sebpic). +- Implemented function `distribution(name)`, generating a distribution object + with functions `random`, `randomInt`, `pickRandom` for different + distributions. Currently supporting `uniform` and `normal`. +- Changed the behavior of `range` to exclude the upper bound, so `range(1, 4)` + now returns `[1, 2, 3]` instead of `[1, 2, 3, 4]`. +- Changed the syntax of `range`, which is now `range(start, end [, step])` + instead of `range(start, [step, ] end)`. +- Changed the behavior of `ones` and `zeros` to geometric dimensions, for + example `ones(3)` returns a vector with length 3, filled with ones, and + `ones(3,3)` returns a 2D array with size [3, 3]. +- Changed the return type of `ones` and `zeros`: they now return an Array when + arguments are Numbers or an Array, and returns a Matrix when the argument + is a Matrix. +- Change matrix index notation in parser from round brackets to square brackets, + for example `A[0, 0:3]`. +- Removed the feature introduced in v0.10.0 to automatically convert a complex + value with an imaginary part equal to zero to a number. +- Fixed zeros being formatted as null. Thanks @TimKraft. + +## 2013-07-23, version 0.11.1 + +- Fixed missing development dependency + +## 2013-07-23, version 0.11.0 + +- Changed math.js from one-based to zero-based indexes. + - Getting and setting matrix subset is now zero-based. + - The dimension argument in function `concat` is now zero-based. +- Improvements in the string output of function help. +- Added constants `true` and `false`. +- Added constructor function `boolean`. +- Fixed function `select` not accepting `0` as input. + Thanks Elijah Manor (@elijahmanor). +- Parser now supports multiple unary minus operators after each other. +- Fixed not accepting empty matrices like `[[], []]`. +- Some fixes in the end user documentation. + +## 2013-07-08, version 0.10.0 + +- For complex calculations, all functions now automatically replace results + having an imaginary part of zero with a Number. (`2i * 2i` now returns a + Number `-4` instead of a Complex `-4 + 0i`). +- Implemented support for injecting custom node handlers in the parser. Can be + used for example to implement a node handler for plotting a graph. +- Implemented end user documentation and a new `help` function. +- Functions `size` and `squeeze` now return a Matrix instead of an Array as + output on Matrix input. +- Added a constant tau (2 * pi). Thanks Zak Zibrat (@palimpsests). +- Renamed function `unaryminus` to `unary`. +- Fixed a bug in determining node dependencies in function assignments. + +## 2013-06-14, version 0.9.1 + +- Implemented element-wise functions and operators: `emultiply` (`x .* y`), + `edivide` (`x ./ y`), `epow` (`x .^ y`). +- Added constants `Infinity` and `NaN`. +- Removed support for Workspace to keep the library focused on its core task. +- Fixed a bug in the Complex constructor, not accepting NaN values. +- Fixed division by zero in case of pure complex values. +- Fixed a bug in function multiply multiplying a pure complex value with + Infinity. + +## 2013-05-29, version 0.9.0 + +- Implemented function `math.parse(expr [,scope])`. Optional parameter scope can + be a plain JavaScript Object containing variables. +- Extended function `math.expr(expr [, scope])` with an additional parameter + `scope`, similar to `parse`. Example: `math.eval('x^a', {x:3, a:2});`. +- Implemented function `subset`, to get or set a subset from a matrix, string, + or other data types. +- Implemented construction functions number and string (mainly useful inside + the parser). +- Improved function `det`. Thanks Bryan Cuccioli (@bcuccioli). +- Moved the parse code from prototype math.expr.Parser to function math.parse, + simplified Parser a little bit. +- Strongly simplified the code of Scope and Workspace. +- Fixed function mod for negative numerators, and added error messages in case + of wrong input. + +## 2013-05-18, version 0.8.2 + +- Extended the import function and some other minor improvements. +- Fixed a bug in merging one dimensional vectors into a matrix. +- Fixed a bug in function subtract, when subtracting a complex number from a + real number. + +## 2013-05-10, version 0.8.1 + +- Fixed an npm warning when installing mathjs globally. + +## 2013-05-10, version 0.8.0 + +- Implemented a command line interface. When math.js is installed globally via + npm, the application is available on your system as 'mathjs'. +- Implemented `end` keyword for index operator, and added support for implicit + start and end (expressions like `a(2,:)` and `b(2:end,3:end-1)` are supported + now). +- Function math.eval is more flexible now: it supports variables and multi-line + expressions. +- Removed the read-only option from Parser and Scope. +- Fixed non-working unequal operator != in the parser. +- Fixed a bug in resizing matrices when replacing a subset. +- Fixed a bug in updating a subset of a non-existing variable. +- Minor bug fixes. + +## 2013-05-04, version 0.7.2 + +- Fixed method unequal, which was checking for equality instead of inequality. + Thanks @FJS2. + +## 2013-04-27, version 0.7.1 + +- Improvements in the parser: + - Added support for chained arguments. + - Added support for chained variable assignments. + - Added a function remove(name) to remove a variable from the parsers scope. + - Renamed nodes for more consistency and to resolve naming conflicts. + - Improved stringification of an expression tree. + - Some simplifications in the code. + - Minor bug fixes. +- Fixed a bug in the parser, returning NaN instead of throwing an error for a + number with multiple decimal separators like `2.3.4`. +- Fixed a bug in Workspace.insertAfter. +- Fixed: math.js now works on IE 6-8 too. + +## 2013-04-20, version 0.7.0 + +- Implemented method `math.eval`, which uses a readonly parser to evaluate + expressions. +- Implemented method `xgcd` (extended eucledian algorithm). Thanks Bart Kiers + (@bkiers). +- Improved math.format, which now rounds values to a maximum number of digits + instead of decimals (default is 5 digits, for example `math.format(math.pi)` + returns `3.1416`). +- Added examples. +- Changed methods square and cube to evaluate matrices element wise (consistent + with all other methods). +- Changed second parameter of method import to an object with options. +- Fixed method math.typeof on IE. +- Minor bug fixes and improvements. + +## 2013-04-13, version 0.6.0 + +- Implemented chained operations via method math.select(). For example + `math.select(3).add(4).subtract(2).done()` will return `5`. +- Implemented methods gcd and lcm. +- Implemented method `Unit.in(unit)`, which creates a clone of the unit with a + fixed representation. For example `math.unit('5.08 cm').in('inch')` will + return a unit which string representation always is in inch, thus `2 inch`. + `Unit.in(unit)` is the same as method `math.in(x, unit)`. +- Implemented `Unit.toNumber(unit)`, which returns the value of the unit when + represented with given unit. For example + `math.unit('5.08 cm').toNumber('inch')` returns the number `2`, as the + representation of the unit in inches has 2 as value. +- Improved: method `math.in(x, unit)` now supports a string as second parameter, + for example `math.in(math.unit('5.08 cm'), 'inch')`. +- Split the end user documentation of the parser functions from the source + files. +- Removed function help and the built-in documentation from the core library. +- Fixed constant i being defined as -1i instead of 1i. +- Minor bug fixes. + +## 2013-04-06, version 0.5.0 + +- Implemented data types Matrix and Range. +- Implemented matrix methods clone, concat, det, diag, eye, inv, ones, size, + squeeze, transpose, zeros. +- Implemented range operator `:`, and transpose operator `'` in parser. +- Changed: created construction methods for easy object creation for all data + types and for the parser. For example, a complex value is now created + with `math.complex(2, 3)` instead of `new math.Complex(2, 3)`, and a parser + is now created with `math.parser()` instead of `new math.parser.Parser()`. +- Changed: moved all data types under the namespace math.type, and moved the + Parser, Workspace, etc. under the namespace math.expr. +- Changed: changed operator precedence of the power operator: + - it is now right associative instead of left associative like most scripting + languages. So `2^3^4` is now calculated as `2^(3^4)`. + - it has now higher precedence than unary minus most languages, thus `-3^2` is + now calculated as `-(3^2)`. +- Changed: renamed the parsers method 'put' into 'set'. +- Fixed: method 'in' did not check for units to have the same base. + +## 2013-03-16, version 0.4.0 + +- Implemented Array support for all methods. +- Implemented Array support in the Parser. +- Implemented method format. +- Implemented parser for units, math.Unit.parse(str). +- Improved parser for complex values math.Complex.parse(str); +- Improved method help: it now evaluates the examples. +- Fixed: a scoping issue with the Parser when defining functions. +- Fixed: method 'typeof' was not working well with minified and mangled code. +- Fixed: errors in determining the best prefix for a unit. + +## 2013-03-09, version 0.3.0 + +- Implemented Workspace +- Implemented methods cot, csc, sec. +- Implemented Array support for methods with one parameter. + +## 2013-02-25, version 0.2.0 + +- Parser, Scope, and expression tree with Nodes implemented. +- Implemented method import which makes it easy to extend math.js. +- Implemented methods arg, conj, cube, equal, factorial, im, largereq, + log(x, base), log10, mod, re, sign, smallereq, square, unequal. + +## 2013-02-18, version 0.1.0 + +- Reached full compatibility with Javascripts built-in Math library. +- More functions implemented. +- Some bugfixes. + +## 2013-02-16, version 0.0.2 + +- All constants of Math implemented, plus the imaginary unit i. +- Data types Complex and Unit implemented. +- First set of functions implemented. + +## 2013-02-15, version 0.0.1 + +- First publish of the mathjs package. (package is still empty) diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/LICENSE b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/LICENSE new file mode 100644 index 0000000..9cf8c11 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/LICENSE @@ -0,0 +1,176 @@ + Apache License + Version 2.0, January 2004 + https://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/NOTICE b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/NOTICE new file mode 100644 index 0000000..8aa6f0d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/NOTICE @@ -0,0 +1,16 @@ +math.js +https://github.com/josdejong/mathjs + +Copyright (C) 2013-2024 Jos de Jong + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + https://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/README.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/README.md new file mode 100644 index 0000000..5300f6b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/README.md @@ -0,0 +1,242 @@ +![math.js](https://raw.github.com/josdejong/mathjs/master/misc/img/mathjs.png) + +[https://mathjs.org](https://mathjs.org) + +Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser with support for symbolic computation, comes with a large set of built-in functions and constants, and offers an integrated solution to work with different data types like numbers, big numbers, complex numbers, fractions, units, and matrices. Powerful and easy to use. + +[![Version](https://img.shields.io/npm/v/mathjs.svg)](https://www.npmjs.com/package/mathjs) +[![Downloads](https://img.shields.io/npm/dm/mathjs.svg)](https://www.npmjs.com/package/mathjs) +[![Build Status](https://github.com/josdejong/mathjs/workflows/Node.js%20CI/badge.svg)](https://github.com/josdejong/mathjs/actions) +[![Maintenance](https://img.shields.io/maintenance/yes/2024.svg)](https://github.com/josdejong/mathjs/graphs/commit-activity) +[![License](https://img.shields.io/github/license/josdejong/mathjs.svg)](https://github.com/josdejong/mathjs/blob/master/LICENSE) +[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fjosdejong%2Fmathjs.svg?type=shield)](https://app.fossa.io/projects/git%2Bgithub.com%2Fjosdejong%2Fmathjs?ref=badge_shield) +[![Codecov](https://codecov.io/gh/josdejong/mathjs/branch/develop/graph/badge.svg)](https://codecov.io/gh/josdejong/mathjs) +[![Github Sponsor](https://img.shields.io/github/sponsors/josdejong +)](https://github.com/sponsors/josdejong) + +## Features + +- Supports numbers, bignumbers, bigints, complex numbers, fractions, units, strings, arrays, and matrices. +- Is compatible with JavaScript's built-in Math library. +- Contains a flexible expression parser. +- Does symbolic computation. +- Comes with a large set of built-in functions and constants. +- Can be used as a command line application as well. +- Runs on any JavaScript engine. +- Is easily extensible. +- Open source. + +## Usage + +Math.js can be used in both node.js and in the browser. + +Install math.js using [npm](https://www.npmjs.com/package/mathjs): + + npm install mathjs + +Or download mathjs via one of the CDN's listed on the downloads page: + +    [https://mathjs.org/download.html](https://mathjs.org/download.html#download) + +Math.js can be used similar to JavaScript's built-in Math library. Besides that, +math.js can evaluate +[expressions](https://mathjs.org/docs/expressions/index.html) +and supports +[chained operations](https://mathjs.org/docs/core/chaining.html). + +```js +import { + atan2, chain, derivative, e, evaluate, log, pi, pow, round, sqrt +} from 'mathjs' + +// functions and constants +round(e, 3) // 2.718 +atan2(3, -3) / pi // 0.75 +log(10000, 10) // 4 +sqrt(-4) // 2i +pow([[-1, 2], [3, 1]], 2) // [[7, 0], [0, 7]] +derivative('x^2 + x', 'x') // 2 * x + 1 + +// expressions +evaluate('12 / (2.3 + 0.7)') // 4 +evaluate('12.7 cm to inch') // 5 inch +evaluate('sin(45 deg) ^ 2') // 0.5 +evaluate('9 / 3 + 2i') // 3 + 2i +evaluate('det([-1, 2; 3, 1])') // -7 + +// chaining +chain(3) + .add(4) + .multiply(2) + .done() // 14 +``` + +See the [Getting Started](https://mathjs.org/docs/getting_started.html) for a more detailed tutorial. + + +## Browser support + +Math.js works on any [ES2020](https://262.ecma-international.org/11.0/) compatible JavaScript engine, including node.js, Chrome, Firefox, Safari, and Edge. + + +## Documentation + +- [Getting Started](https://mathjs.org/docs/getting_started.html) +- [Examples](https://mathjs.org/examples/index.html) +- [Overview](https://mathjs.org/docs/index.html) +- [History](https://mathjs.org/history.html) + + +## Build + +First clone the project from github: + + git clone git@github.com:josdejong/mathjs.git + cd mathjs + +Install the project dependencies: + + npm install + +Then, the project can be build by executing the build script via npm: + + npm run build + +This will build ESM output, CommonJS output, and the bundle math.js +from the source files and put them in the folder lib. + + +## Develop + +When developing new features for mathjs, it is good to be aware of the following background information. + +### Code + +The code of `mathjs` is written in ES modules, and requires all files to have a real, relative path, meaning the files must have a `*.js` extension. Please configure adding file extensions on auto import in your IDE. + +### Architecture + +What mathjs tries to achieve is to offer an environment where you can do calculations with mixed data types, +like multiplying a regular `number` with a `Complex` number or a `BigNumber`, and work with all of those in matrices. +Mathjs also allows to add a new data type with little effort. + +The solution that mathjs uses has two main ingredients: + +- **Typed functions**. All functions are created using [`typed-function`](https://github.com/josdejong/typed-function/). This makes it easier to (dynamically) create and extend a single function with new data types, automatically do type conversions on function inputs, etc. So, if you create function multiply for two `number`s, you can extend it with support for multiplying your own data type, say `MyDecimal`. If you define a conversion from `MyDecimal` to `number`, the typed-function will automatically allow you to multiply a `MyDecimal` with a `number`. + +- **Dependency injection**. When we have a function `multiply` with support for `MyDecimal`, thanks to the dependency injection, other functions using `multiply` under the hood, like `prod`, will automatically support `MyDecimal` too. This also works the other way around: if you don't need the heavyweight `multiply` (which supports BigNumbers, matrices, etc), and you just need a plain and simple number support, you can use a lightweight implementation of `multiply` just for numbers, and inject that in `prod` and other functions. + +At the lowest level, mathjs has immutable factory functions which create immutable functions. The core function `math.create(...)` creates a new instance having functions created from all passed factory functions. A mathjs instance is a collection of created functions. It contains a function like `math.import` to allow extending the instance with new functions, which can then be used in the expression parser. + +### Implementing a new function + +A common case is to implement a new function. This involves the following steps: + +- Implement the function in the right category, for example `./src/function/arithmetic/myNewFunction.js`, where you can replace `arithmetic` with the proper category, and `myNewFunction` with the name of the new function. Add the new function to the index files `./src/factoriesAny.js` and possibly `./src/factoriesNumber.js`. +- Write documentation on the function in the source code comment of `myNewFunction.js`. This documentation is used to auto generate documentation on the website. +- Write embedded documentation for the new function in `./src/expression/embeddedDocs/function/arithmetic/myNewFunction.js`. Add the new documentation to the index file `./src/expression/embeddedDocs/embeddedDocs.js`. +- Write unit tests for the function in `./test/unit-tests/function/arithmetic/myNewFunction.test.js`. +- Write the necessary TypeScript definitions for the new function in `./types/index.d.ts`, and write tests for it in `./test/typescript-tests/testTypes.ts`. This is described in [./types/EXPLANATION.md](./types/EXPLANATION.md). +- Ensure the code style is ok by running `npm run lint` (run `npm run format` to fix the code style automatically). + + +### Build scripts + +The build script currently generates two types of output: + +- **any**, generate entry points to create full versions of all functions +- **number**: generating and entry points to create lightweight functions just supporting `number` + +For each function, an object is generated containing the factory functions of all dependencies of the function. This allows to just load a specific set of functions, and not load or bundle any other functionality. So for example, to just create function `add` you can do `math.create(addDependencies)`. + + +## Test + +To execute tests for the library, install the project dependencies once: + + npm install + +Then, the tests can be executed: + + npm test + +To test the type definitions: + + npm run test:types + +Additionally, the tests can be run on FireFox using [headless mode](https://developer.mozilla.org/en-US/Firefox/Headless_mode): + + npm run test:browser + +To run the tests remotely on BrowserStack, first set the environment variables `BROWSER_STACK_USERNAME` and `BROWSER_STACK_ACCESS_KEY` with your username and access key and then execute: + + npm run test:browserstack + +You can separately run the code linter, though it is also executed with `npm test`: + + npm run lint + +To automatically fix linting issue, run: + + npm run format + +To test code coverage of the tests: + + npm run coverage + +To see the coverage results, open the generated report in your browser: + + ./coverage/lcov-report/index.html + + +### Continuous integration testing + +Continuous integration tests are run on [Github Actions](https://github.com/josdejong/mathjs/actions) and [BrowserStack](https://www.browserstack.com) every time a commit is pushed to github. Github Actions runs the tests for different versions of node.js, and BrowserStack runs the tests on all major browsers. + +[![BrowserStack](https://raw.github.com/josdejong/mathjs/master/misc/browserstack.png)](https://www.browserstack.com) + +Thanks Github Actions and BrowserStack for the generous free hosting of this open source project! + +## License + +mathjs is published under the Apache 2.0 license: + +``` +Copyright (C) 2013-2024 Jos de Jong + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + https://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +``` + +mathjs contains a JavaScript port of the [CSparse](https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source) library, published under the LGPL-2.1+ license: + +``` +CSparse: a Concise Sparse matrix package. +Copyright (c) 2006, Timothy A. Davis. +http://www.suitesparse.com + +-------------------------------------------------------------------------------- + +CSparse is free software; you can redistribute it and/or +modify it under the terms of the GNU Lesser General Public +License as published by the Free Software Foundation; either +version 2.1 of the License, or (at your option) any later version. + +CSparse is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +Lesser General Public License for more details. + +You should have received a copy of the GNU Lesser General Public +License along with this Module; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +``` diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/cli.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/cli.js new file mode 100644 index 0000000..6d31390 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/cli.js @@ -0,0 +1,446 @@ +#!/usr/bin/env node +/** + * math.js + * https://github.com/josdejong/mathjs + * + * Math.js is an extensive math library for JavaScript and Node.js, + * It features real and complex numbers, units, matrices, a large set of + * mathematical functions, and a flexible expression parser. + * + * Usage: + * + * mathjs [scriptfile(s)] {OPTIONS} + * + * Options: + * + * --version, -v Show application version + * --help, -h Show this message + * --tex Generate LaTeX instead of evaluating + * --string Generate string instead of evaluating + * --parenthesis= Set the parenthesis option to + * either of "keep", "auto" and "all" + * + * Example usage: + * mathjs Open a command prompt + * mathjs 1+2 Evaluate expression + * mathjs script.txt Run a script file + * mathjs script1.txt script2.txt Run two script files + * mathjs script.txt > results.txt Run a script file, output to file + * cat script.txt | mathjs Run input stream + * cat script.txt | mathjs > results.txt Run input stream, output to file + * + * @license + * Copyright (C) 2013-2024 Jos de Jong + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy + * of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ + +const fs = require('fs') +const path = require('path') +const { createEmptyMap } = require('../lib/cjs/utils/map.js') +let scope = createEmptyMap() + +const PRECISION = 14 // decimals + +/** + * "Lazy" load math.js: only require when we actually start using it. + * This ensures the cli application looks like it loads instantly. + * When requesting help or version number, math.js isn't even loaded. + * @return {{ evalute: function, parse: function, math: Object }} + */ +function getMath () { + const { create, all } = require('../lib/browser/math.js') + + const math = create(all) + const parse = math.parse + const evaluate = math.evaluate + + // See https://mathjs.org/docs/expressions/security.html#less-vulnerable-expression-parser + math.import({ + 'import': function () { throw new Error('Function import is disabled') }, + 'createUnit': function () { throw new Error('Function createUnit is disabled') }, + 'reviver': function () { throw new Error('Function reviver is disabled') } + }, { override: true }) + + return { math, parse, evaluate } +} + +/** + * Helper function to format a value. Regular numbers will be rounded + * to 14 digits to prevent round-off errors from showing up. + * @param {*} value + */ +function format (value) { + const { math } = getMath() + + return math.format(value, { + fn: function (value) { + if (typeof value === 'number') { + // round numbers + return math.format(value, PRECISION) + } else { + return math.format(value) + } + } + }) +} + +/** + * auto complete a text + * @param {String} text + * @return {[Array, String]} completions + */ +function completer (text) { + const { math } = getMath() + let matches = [] + let keyword + const m = /[a-zA-Z_0-9]+$/.exec(text) + if (m) { + keyword = m[0] + + // scope variables + for (const def in scope.keys()) { + if (def.indexOf(keyword) === 0) { + matches.push(def) + } + } + + // commandline keywords + ['exit', 'quit', 'clear'].forEach(function (cmd) { + if (cmd.indexOf(keyword) === 0) { + matches.push(cmd) + } + }) + + // math functions and constants + const ignore = ['expr', 'type'] + for (const func in math.expression.mathWithTransform) { + if (hasOwnProperty(math.expression.mathWithTransform, func)) { + if (func.indexOf(keyword) === 0 && !ignore.includes(func)) { + matches.push(func) + } + } + } + + // units + const Unit = math.Unit + for (const name in Unit.UNITS) { + if (hasOwnProperty(Unit.UNITS, name)) { + if (name.indexOf(keyword) === 0) { + matches.push(name) + } + } + } + for (const name in Unit.PREFIXES) { + if (hasOwnProperty(Unit.PREFIXES, name)) { + const prefixes = Unit.PREFIXES[name] + for (const prefix in prefixes) { + if (hasOwnProperty(prefixes, prefix)) { + if (prefix.indexOf(keyword) === 0) { + matches.push(prefix) + } else if (keyword.indexOf(prefix) === 0) { + const unitKeyword = keyword.substring(prefix.length) + for (const n in Unit.UNITS) { + if (hasOwnProperty(Unit.UNITS, n)) { + if (n.indexOf(unitKeyword) === 0 && + Unit.isValuelessUnit(prefix + n)) { + matches.push(prefix + n) + } + } + } + } + } + } + } + } + + // remove duplicates + matches = matches.filter(function (elem, pos, arr) { + return arr.indexOf(elem) === pos + }) + } + + return [matches, keyword] +} + +/** + * Run stream, read and evaluate input and stream that to output. + * Text lines read from the input are evaluated, and the results are send to + * the output. + * @param input Input stream + * @param output Output stream + * @param mode Output mode + * @param parenthesis Parenthesis option + */ +function runStream (input, output, mode, parenthesis) { + const readline = require('readline') + const rl = readline.createInterface({ + input: input || process.stdin, + output: output || process.stdout, + completer: completer + }) + + if (rl.output.isTTY) { + rl.setPrompt('> ') + rl.prompt() + } + + // load math.js now, right *after* loading the prompt. + const { math, parse } = getMath() + + // TODO: automatic insertion of 'ans' before operators like +, -, *, / + + rl.on('line', function (line) { + const expr = line.trim() + + switch (expr.toLowerCase()) { + case 'quit': + case 'exit': + // exit application + rl.close() + break + case 'clear': + // clear memory + scope = createEmptyMap() + console.log('memory cleared') + + // get next input + if (rl.output.isTTY) { + rl.prompt() + } + break + default: + if (!expr) { + break + } + switch (mode) { + case 'evaluate': + // evaluate expression + try { + let node = parse(expr) + let res = node.evaluate(scope) + + if (math.isResultSet(res)) { + // we can have 0 or 1 results in the ResultSet, as the CLI + // does not allow multiple expressions separated by a return + res = res.entries[0] + node = node.blocks + .filter(function (entry) { return entry.visible }) + .map(function (entry) { return entry.node })[0] + } + + if (node) { + if (math.isAssignmentNode(node)) { + const name = findSymbolName(node) + if (name !== null) { + const value = scope.get(name) + scope.set('ans', value) + console.log(name + ' = ' + format(value)) + } else { + scope.set('ans', res) + console.log(format(res)) + } + } else if (math.isHelp(res)) { + console.log(res.toString()) + } else { + scope.set('ans', res) + console.log(format(res)) + } + } + } catch (err) { + console.log(err.toString()) + } + break + + case 'string': + try { + const string = math.parse(expr).toString({ parenthesis: parenthesis }) + console.log(string) + } catch (err) { + console.log(err.toString()) + } + break + + case 'tex': + try { + const tex = math.parse(expr).toTex({ parenthesis: parenthesis }) + console.log(tex) + } catch (err) { + console.log(err.toString()) + } + break + } + } + + // get next input + if (rl.output.isTTY) { + rl.prompt() + } + }) + + rl.on('close', function () { + console.log() + process.exit(0) + }) +} + +/** + * Find the symbol name of an AssignmentNode. Recurses into the chain of + * objects to the root object. + * @param {AssignmentNode} node + * @return {string | null} Returns the name when found, else returns null. + */ +function findSymbolName (node) { + const { math } = getMath() + let n = node + + while (n) { + if (math.isSymbolNode(n)) { + return n.name + } + n = n.object + } + + return null +} + +/** + * Output application version number. + * Version number is read version from package.json. + */ +function outputVersion () { + fs.readFile(path.join(__dirname, '/../package.json'), function (err, data) { + if (err) { + console.log(err.toString()) + } else { + const pkg = JSON.parse(data) + const version = pkg && pkg.version ? pkg.version : 'unknown' + console.log(version) + } + process.exit(0) + }) +} + +/** + * Output a help message + */ +function outputHelp () { + console.log('math.js') + console.log('https://mathjs.org') + console.log() + console.log('Math.js is an extensive math library for JavaScript and Node.js. It features ') + console.log('real and complex numbers, units, matrices, a large set of mathematical') + console.log('functions, and a flexible expression parser.') + console.log() + console.log('Usage:') + console.log(' mathjs [scriptfile(s)|expression] {OPTIONS}') + console.log() + console.log('Options:') + console.log(' --version, -v Show application version') + console.log(' --help, -h Show this message') + console.log(' --tex Generate LaTeX instead of evaluating') + console.log(' --string Generate string instead of evaluating') + console.log(' --parenthesis= Set the parenthesis option to') + console.log(' either of "keep", "auto" and "all"') + console.log() + console.log('Example usage:') + console.log(' mathjs Open a command prompt') + console.log(' mathjs 1+2 Evaluate expression') + console.log(' mathjs script.txt Run a script file') + console.log(' mathjs script.txt script2.txt Run two script files') + console.log(' mathjs script.txt > results.txt Run a script file, output to file') + console.log(' cat script.txt | mathjs Run input stream') + console.log(' cat script.txt | mathjs > results.txt Run input stream, output to file') + console.log() + process.exit(0) +} + +/** + * Process input and output, based on the command line arguments + */ +const scripts = [] // queue of scripts that need to be processed +let mode = 'evaluate' // one of 'evaluate', 'tex' or 'string' +let parenthesis = 'keep' +let version = false +let help = false + +process.argv.forEach(function (arg, index) { + if (index < 2) { + return + } + + switch (arg) { + case '-v': + case '--version': + version = true + break + + case '-h': + case '--help': + help = true + break + + case '--tex': + mode = 'tex' + break + + case '--string': + mode = 'string' + break + + case '--parenthesis=keep': + parenthesis = 'keep' + break + + case '--parenthesis=auto': + parenthesis = 'auto' + break + + case '--parenthesis=all': + parenthesis = 'all' + break + + // TODO: implement configuration via command line arguments + + default: + scripts.push(arg) + } +}) + +if (version) { + outputVersion() +} else if (help) { + outputHelp() +} else if (scripts.length === 0) { + // run a stream, can be user input or pipe input + runStream(process.stdin, process.stdout, mode, parenthesis) +} else { + fs.stat(scripts[0], function (err) { + if (err) { + const { evaluate } = getMath() + console.log(evaluate(scripts.join(' ')).toString()) + } else { + // work through the queue of scripts + scripts.forEach(function (arg) { + // run a script file + runStream(fs.createReadStream(arg), process.stdout, mode, parenthesis) + }) + } + }) +} + +// helper function to safely check whether an object as a property +// copy from the function in object.js which is ES6 +function hasOwnProperty (object, property) { + return object && Object.hasOwnProperty.call(object, property) +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/package.json new file mode 100644 index 0000000..5bbefff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/package.json @@ -0,0 +1,3 @@ +{ + "type": "commonjs" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/repl.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/repl.js new file mode 100644 index 0000000..9ad06fe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/bin/repl.js @@ -0,0 +1,10 @@ +#!/usr/bin/env node + +/* + * This simply preloads mathjs and drops you into a REPL to + * help interactive debugging. + **/ +global.math = require('../lib/browser/math.js') +const repl = require('repl') + +repl.start({ useGlobal: true }) diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js new file mode 100644 index 0000000..1e35332 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js @@ -0,0 +1,3 @@ +/*! For license information please see math.js.LICENSE.txt */ +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.math=t():e.math=t()}(this,(()=>(()=>{var e={5716:function(e,t){var r;!function(){"use strict";var n=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:.5*(Math.exp(e)+Math.exp(-e))},i=Math.sinh||function(e){return Math.abs(e)<1e-9?e:.5*(Math.exp(e)-Math.exp(-e))},o=function(){throw SyntaxError("Invalid Param")};function a(e,t){var r=Math.abs(e),n=Math.abs(t);return 0===e?Math.log(n):0===t?Math.log(r):r<3e3&&n<3e3?.5*Math.log(e*e+t*t):(e/=2,t/=2,.5*Math.log(e*e+t*t)+Math.LN2)}function s(e,t){if(!(this instanceof s))return new s(e,t);var r=function(e,t){var r={re:0,im:0};if(null==e)r.re=r.im=0;else if(void 0!==t)r.re=e,r.im=t;else switch(typeof e){case"object":if("im"in e&&"re"in e)r.re=e.re,r.im=e.im;else if("abs"in e&&"arg"in e){if(!Number.isFinite(e.abs)&&Number.isFinite(e.arg))return s.INFINITY;r.re=e.abs*Math.cos(e.arg),r.im=e.abs*Math.sin(e.arg)}else if("r"in e&&"phi"in e){if(!Number.isFinite(e.r)&&Number.isFinite(e.phi))return s.INFINITY;r.re=e.r*Math.cos(e.phi),r.im=e.r*Math.sin(e.phi)}else 2===e.length?(r.re=e[0],r.im=e[1]):o();break;case"string":r.im=r.re=0;var n=e.match(/\d+\.?\d*e[+-]?\d+|\d+\.?\d*|\.\d+|./g),i=1,a=0;null===n&&o();for(var u=0;u0&&o();break;case"number":r.im=0,r.re=e;break;default:o()}return isNaN(r.re)||isNaN(r.im),r}(e,t);this.re=r.re,this.im=r.im}s.prototype={re:0,im:0,sign:function(){var e=this.abs();return new s(this.re/e,this.im/e)},add:function(e,t){var r=new s(e,t);return this.isInfinite()&&r.isInfinite()?s.NAN:this.isInfinite()||r.isInfinite()?s.INFINITY:new s(this.re+r.re,this.im+r.im)},sub:function(e,t){var r=new s(e,t);return this.isInfinite()&&r.isInfinite()?s.NAN:this.isInfinite()||r.isInfinite()?s.INFINITY:new s(this.re-r.re,this.im-r.im)},mul:function(e,t){var r=new s(e,t);return this.isInfinite()&&r.isZero()||this.isZero()&&r.isInfinite()?s.NAN:this.isInfinite()||r.isInfinite()?s.INFINITY:0===r.im&&0===this.im?new s(this.re*r.re,0):new s(this.re*r.re-this.im*r.im,this.re*r.im+this.im*r.re)},div:function(e,t){var r=new s(e,t);if(this.isZero()&&r.isZero()||this.isInfinite()&&r.isInfinite())return s.NAN;if(this.isInfinite()||r.isZero())return s.INFINITY;if(this.isZero()||r.isInfinite())return s.ZERO;e=this.re,t=this.im;var n,i,o=r.re,a=r.im;return 0===a?new s(e/o,t/o):Math.abs(o)0)return new s(Math.pow(e,r.re),0);if(0===e)switch((r.re%4+4)%4){case 0:return new s(Math.pow(t,r.re),0);case 1:return new s(0,Math.pow(t,r.re));case 2:return new s(-Math.pow(t,r.re),0);case 3:return new s(0,-Math.pow(t,r.re))}}if(0===e&&0===t&&r.re>0&&r.im>=0)return s.ZERO;var n=Math.atan2(t,e),i=a(e,t);return e=Math.exp(r.re*i-r.im*n),t=r.im*i+r.re*n,new s(e*Math.cos(t),e*Math.sin(t))},sqrt:function(){var e,t,r=this.re,n=this.im,i=this.abs();if(r>=0){if(0===n)return new s(Math.sqrt(r),0);e=.5*Math.sqrt(2*(i+r))}else e=Math.abs(n)/Math.sqrt(2*(i-r));return t=r<=0?.5*Math.sqrt(2*(i-r)):Math.abs(n)/Math.sqrt(2*(i+r)),new s(e,n<0?-t:t)},exp:function(){var e=Math.exp(this.re);return this.im,new s(e*Math.cos(this.im),e*Math.sin(this.im))},expm1:function(){var e=this.re,t=this.im;return new s(Math.expm1(e)*Math.cos(t)+function(e){var t=Math.PI/4;if(-t>e||e>t)return Math.cos(e)-1;var r=e*e;return r*(r*(r*(r*(r*(r*(r*(r/20922789888e3-1/87178291200)+1/479001600)-1/3628800)+1/40320)-1/720)+1/24)-.5)}(t),Math.exp(e)*Math.sin(t))},log:function(){var e=this.re,t=this.im;return new s(a(e,t),Math.atan2(t,e))},abs:function(){return e=this.re,t=this.im,r=Math.abs(e),n=Math.abs(t),r<3e3&&n<3e3?Math.sqrt(r*r+n*n):(r1&&0===t,n=1-e,i=1+e,o=n*n+t*t,u=0!==o?new s((i*n-t*t)/o,(t*n+i*t)/o):new s(-1!==e?e/0:0,0!==t?t/0:0),c=u.re;return u.re=a(u.re,u.im)/2,u.im=Math.atan2(u.im,c)/2,r&&(u.im=-u.im),u},acoth:function(){var e=this.re,t=this.im;if(0===e&&0===t)return new s(0,Math.PI/2);var r=e*e+t*t;return 0!==r?new s(e/r,-t/r).atanh():new s(0!==e?e/0:0,0!==t?-t/0:0).atanh()},acsch:function(){var e=this.re,t=this.im;if(0===t)return new s(0!==e?Math.log(e+Math.sqrt(e*e+1)):1/0,0);var r=e*e+t*t;return 0!==r?new s(e/r,-t/r).asinh():new s(0!==e?e/0:0,0!==t?-t/0:0).asinh()},asech:function(){var e=this.re,t=this.im;if(this.isZero())return s.INFINITY;var r=e*e+t*t;return 0!==r?new s(e/r,-t/r).acosh():new s(0!==e?e/0:0,0!==t?-t/0:0).acosh()},inverse:function(){if(this.isZero())return s.INFINITY;if(this.isInfinite())return s.ZERO;var e=this.re,t=this.im,r=e*e+t*t;return new s(e/r,-t/r)},conjugate:function(){return new s(this.re,-this.im)},neg:function(){return new s(-this.re,-this.im)},ceil:function(e){return e=Math.pow(10,e||0),new s(Math.ceil(this.re*e)/e,Math.ceil(this.im*e)/e)},floor:function(e){return e=Math.pow(10,e||0),new s(Math.floor(this.re*e)/e,Math.floor(this.im*e)/e)},round:function(e){return e=Math.pow(10,e||0),new s(Math.round(this.re*e)/e,Math.round(this.im*e)/e)},equals:function(e,t){var r=new s(e,t);return Math.abs(r.re-this.re)<=s.EPSILON&&Math.abs(r.im-this.im)<=s.EPSILON},clone:function(){return new s(this.re,this.im)},toString:function(){var e=this.re,t=this.im,r="";return this.isNaN()?"NaN":this.isInfinite()?"Infinity":(Math.abs(e){"use strict";var t=Object.assign||function(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:{},a=o.preserveFormatting,s=void 0!==a&&a,u=o.escapeMapFn,c=void 0===u?i:u,l=String(e),f="",p=c(t({},r),s?t({},n):{}),m=Object.keys(p),d=function(){var e=!1;m.forEach((function(t,r){e||l.length>=t.length&&l.slice(0,t.length)===t&&(f+=p[m[r]],l=l.slice(t.length,l.length),e=!0)})),e||(f+=l.slice(0,1),l=l.slice(1,l.length))};l;)d();return f}},1880:e=>{e.exports=function e(t,r){"use strict";var n,i,o=/(^([+\-]?(?:0|[1-9]\d*)(?:\.\d*)?(?:[eE][+\-]?\d+)?)?$|^0x[0-9a-f]+$|\d+)/gi,a=/(^[ ]*|[ ]*$)/g,s=/(^([\w ]+,?[\w ]+)?[\w ]+,?[\w ]+\d+:\d+(:\d+)?[\w ]?|^\d{1,4}[\/\-]\d{1,4}[\/\-]\d{1,4}|^\w+, \w+ \d+, \d{4})/,u=/^0x[0-9a-f]+$/i,c=/^0/,l=function(t){return e.insensitive&&(""+t).toLowerCase()||""+t},f=l(t).replace(a,"")||"",p=l(r).replace(a,"")||"",m=f.replace(o,"\0$1\0").replace(/\0$/,"").replace(/^\0/,"").split("\0"),d=p.replace(o,"\0$1\0").replace(/\0$/,"").replace(/^\0/,"").split("\0"),h=parseInt(f.match(u),16)||1!==m.length&&f.match(s)&&Date.parse(f),g=parseInt(p.match(u),16)||h&&p.match(s)&&Date.parse(p)||null;if(g){if(hg)return 1}for(var y=0,x=Math.max(m.length,d.length);yi)return 1}return 0}},7391:(e,t,r)=>{var n=r(7180),i=r(3181),o=r(3031),a=r(9067),s=r(6833),u=r(6098),c=r(4801);c.alea=n,c.xor128=i,c.xorwow=o,c.xorshift7=a,c.xor4096=s,c.tychei=u,e.exports=c},7180:function(e,t,r){var n;!function(e,i){function o(e){var t,r=this,n=(t=4022871197,function(e){e=String(e);for(var r=0;r>>0,t=(n*=t)>>>0,t+=4294967296*(n-=t)}return 2.3283064365386963e-10*(t>>>0)});r.next=function(){var e=2091639*r.s0+2.3283064365386963e-10*r.c;return r.s0=r.s1,r.s1=r.s2,r.s2=e-(r.c=0|e)},r.c=1,r.s0=n(" "),r.s1=n(" "),r.s2=n(" "),r.s0-=n(e),r.s0<0&&(r.s0+=1),r.s1-=n(e),r.s1<0&&(r.s1+=1),r.s2-=n(e),r.s2<0&&(r.s2+=1),n=null}function a(e,t){return t.c=e.c,t.s0=e.s0,t.s1=e.s1,t.s2=e.s2,t}function s(e,t){var r=new o(e),n=t&&t.state,i=r.next;return i.int32=function(){return 4294967296*r.next()|0},i.double=function(){return i()+11102230246251565e-32*(2097152*i()|0)},i.quick=i,n&&("object"==typeof n&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.alea=s}(0,e=r.nmd(e),r.amdD)},6098:function(e,t,r){var n;!function(e,i){function o(e){var t=this,r="";t.next=function(){var e=t.b,r=t.c,n=t.d,i=t.a;return e=e<<25^e>>>7^r,r=r-n|0,n=n<<24^n>>>8^i,i=i-e|0,t.b=e=e<<20^e>>>12^r,t.c=r=r-n|0,t.d=n<<16^r>>>16^i,t.a=i-e|0},t.a=0,t.b=0,t.c=-1640531527,t.d=1367130551,e===Math.floor(e)?(t.a=e/4294967296|0,t.b=0|e):r+=e;for(var n=0;n>>0)/4294967296};return i.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},i.int32=r.next,i.quick=i,n&&("object"==typeof n&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.tychei=s}(0,e=r.nmd(e),r.amdD)},3181:function(e,t,r){var n;!function(e,i){function o(e){var t=this,r="";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:r+=e;for(var n=0;n>>0)/4294967296};return i.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},i.int32=r.next,i.quick=i,n&&("object"==typeof n&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.xor128=s}(0,e=r.nmd(e),r.amdD)},6833:function(e,t,r){var n;!function(e,i){function o(e){var t=this;t.next=function(){var e,r,n=t.w,i=t.X,o=t.i;return t.w=n=n+1640531527|0,r=i[o+34&127],e=i[o=o+1&127],r^=r<<13,e^=e<<17,r^=r>>>15,e^=e>>>12,r=i[o]=r^e,t.i=o,r+(n^n>>>16)|0},function(e,t){var r,n,i,o,a,s=[],u=128;for(t===(0|t)?(n=t,t=null):(t+="\0",n=0,u=Math.max(u,t.length)),i=0,o=-32;o>>15,n^=n<<4,n^=n>>>13,o>=0&&(a=a+1640531527|0,i=0==(r=s[127&o]^=n+a)?i+1:0);for(i>=128&&(s[127&(t&&t.length||0)]=-1),i=127,o=512;o>0;--o)n=s[i+34&127],r=s[i=i+1&127],n^=n<<13,r^=r<<17,n^=n>>>15,r^=r>>>12,s[i]=n^r;e.w=a,e.X=s,e.i=i}(t,e)}function a(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function s(e,t){null==e&&(e=+new Date);var r=new o(e),n=t&&t.state,i=function(){return(r.next()>>>0)/4294967296};return i.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},i.int32=r.next,i.quick=i,n&&(n.X&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.xor4096=s}(0,e=r.nmd(e),r.amdD)},9067:function(e,t,r){var n;!function(e,i){function o(e){var t=this;t.next=function(){var e,r,n=t.x,i=t.i;return e=n[i],r=(e^=e>>>7)^e<<24,r^=(e=n[i+1&7])^e>>>10,r^=(e=n[i+3&7])^e>>>3,r^=(e=n[i+4&7])^e<<7,e=n[i+7&7],r^=(e^=e<<13)^e<<9,n[i]=r,t.i=i+1&7,r},function(e,t){var r,n=[];if(t===(0|t))n[0]=t;else for(t=""+t,r=0;r0;--r)e.next()}(t,e)}function a(e,t){return t.x=e.x.slice(),t.i=e.i,t}function s(e,t){null==e&&(e=+new Date);var r=new o(e),n=t&&t.state,i=function(){return(r.next()>>>0)/4294967296};return i.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},i.int32=r.next,i.quick=i,n&&(n.x&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.xorshift7=s}(0,e=r.nmd(e),r.amdD)},3031:function(e,t,r){var n;!function(e,i){function o(e){var t=this,r="";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,t.v=0,e===(0|e)?t.x=e:r+=e;for(var n=0;n>>4),t.next()}function a(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function s(e,t){var r=new o(e),n=t&&t.state,i=function(){return(r.next()>>>0)/4294967296};return i.double=function(){do{var e=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},i.int32=r.next,i.quick=i,n&&("object"==typeof n&&a(n,r),i.state=function(){return a(r,{})}),i}i&&i.exports?i.exports=s:r.amdD&&r.amdO?void 0===(n=function(){return s}.call(t,r,t,i))||(i.exports=n):this.xorwow=s}(0,e=r.nmd(e),r.amdD)},4801:function(e,t,r){var n;!function(i,o,a){var s,u=256,c=a.pow(u,6),l=a.pow(2,52),f=2*l,p=u-1;function m(e,t,r){var n=[],p=y(g((t=1==t?{entropy:!0}:t||{}).entropy?[e,x(o)]:null==e?function(){try{var e;return s&&(e=s.randomBytes)?e=e(u):(e=new Uint8Array(u),(i.crypto||i.msCrypto).getRandomValues(e)),x(e)}catch(e){var t=i.navigator,r=t&&t.plugins;return[+new Date,i,r,i.screen,x(o)]}}():e,3),n),m=new d(n),b=function(){for(var e=m.g(6),t=c,r=0;e=f;)e/=2,t/=2,r>>>=1;return(e+r)/t};return b.int32=function(){return 0|m.g(4)},b.quick=function(){return m.g(4)/4294967296},b.double=b,y(x(m.S),o),(t.pass||r||function(e,t,r,n){return n&&(n.S&&h(n,m),e.state=function(){return h(m,{})}),r?(a.random=e,t):e})(b,p,"global"in t?t.global:this==a,t.state)}function d(e){var t,r=e.length,n=this,i=0,o=n.i=n.j=0,a=n.S=[];for(r||(e=[r++]);i{function t(){}t.prototype={on:function(e,t,r){var n=this.e||(this.e={});return(n[e]||(n[e]=[])).push({fn:t,ctx:r}),this},once:function(e,t,r){var n=this;function i(){n.off(e,i),t.apply(r,arguments)}return i._=t,this.on(e,i,r)},emit:function(e){for(var t=[].slice.call(arguments,1),r=((this.e||(this.e={}))[e]||[]).slice(),n=0,i=r.length;n{},9306:(e,t,r)=>{"use strict";var n=r(4901),i=r(6823),o=TypeError;e.exports=function(e){if(n(e))return e;throw new o(i(e)+" is not a function")}},5548:(e,t,r)=>{"use strict";var n=r(3517),i=r(6823),o=TypeError;e.exports=function(e){if(n(e))return e;throw new o(i(e)+" is not a constructor")}},3506:(e,t,r)=>{"use strict";var n=r(3925),i=String,o=TypeError;e.exports=function(e){if(n(e))return e;throw new o("Can't set "+i(e)+" as a prototype")}},6469:(e,t,r)=>{"use strict";var n=r(8227),i=r(2360),o=r(4913).f,a=n("unscopables"),s=Array.prototype;void 0===s[a]&&o(s,a,{configurable:!0,value:i(null)}),e.exports=function(e){s[a][e]=!0}},7829:(e,t,r)=>{"use strict";var n=r(8183).charAt;e.exports=function(e,t,r){return t+(r?n(e,t).length:1)}},679:(e,t,r)=>{"use strict";var n=r(1625),i=TypeError;e.exports=function(e,t){if(n(t,e))return e;throw new i("Incorrect invocation")}},8551:(e,t,r)=>{"use strict";var n=r(34),i=String,o=TypeError;e.exports=function(e){if(n(e))return e;throw new o(i(e)+" is not an object")}},9617:(e,t,r)=>{"use strict";var n=r(5397),i=r(5610),o=r(6198),a=function(e){return function(t,r,a){var s=n(t),u=o(s);if(0===u)return!e&&-1;var c,l=i(a,u);if(e&&r!=r){for(;u>l;)if((c=s[l++])!=c)return!0}else for(;u>l;l++)if((e||l in s)&&s[l]===r)return e||l||0;return!e&&-1}};e.exports={includes:a(!0),indexOf:a(!1)}},4598:(e,t,r)=>{"use strict";var n=r(9039);e.exports=function(e,t){var r=[][e];return!!r&&n((function(){r.call(null,t||function(){return 1},1)}))}},926:(e,t,r)=>{"use strict";var n=r(9306),i=r(8981),o=r(7055),a=r(6198),s=TypeError,u="Reduce of empty array with no initial value",c=function(e){return function(t,r,c,l){var f=i(t),p=o(f),m=a(f);if(n(r),0===m&&c<2)throw new s(u);var d=e?m-1:0,h=e?-1:1;if(c<2)for(;;){if(d in p){l=p[d],d+=h;break}if(d+=h,e?d<0:m<=d)throw new s(u)}for(;e?d>=0:m>d;d+=h)d in p&&(l=r(l,p[d],d,f));return l}};e.exports={left:c(!1),right:c(!0)}},7680:(e,t,r)=>{"use strict";var n=r(9504);e.exports=n([].slice)},4488:(e,t,r)=>{"use strict";var n=r(7680),i=Math.floor,o=function(e,t){var r=e.length;if(r<8)for(var a,s,u=1;u0;)e[s]=e[--s];s!==u++&&(e[s]=a)}else for(var c=i(r/2),l=o(n(e,0,c),t),f=o(n(e,c),t),p=l.length,m=f.length,d=0,h=0;d{"use strict";var n=r(8227)("iterator"),i=!1;try{var o=0,a={next:function(){return{done:!!o++}},return:function(){i=!0}};a[n]=function(){return this},Array.from(a,(function(){throw 2}))}catch(e){}e.exports=function(e,t){try{if(!t&&!i)return!1}catch(e){return!1}var r=!1;try{var o={};o[n]=function(){return{next:function(){return{done:r=!0}}}},e(o)}catch(e){}return r}},2195:(e,t,r)=>{"use strict";var n=r(9504),i=n({}.toString),o=n("".slice);e.exports=function(e){return o(i(e),8,-1)}},6955:(e,t,r)=>{"use strict";var n=r(2140),i=r(4901),o=r(2195),a=r(8227)("toStringTag"),s=Object,u="Arguments"===o(function(){return arguments}());e.exports=n?o:function(e){var t,r,n;return void 0===e?"Undefined":null===e?"Null":"string"==typeof(r=function(e,t){try{return e[t]}catch(e){}}(t=s(e),a))?r:u?o(t):"Object"===(n=o(t))&&i(t.callee)?"Arguments":n}},7740:(e,t,r)=>{"use strict";var n=r(9297),i=r(5031),o=r(7347),a=r(4913);e.exports=function(e,t,r){for(var s=i(t),u=a.f,c=o.f,l=0;l{"use strict";var n=r(3724),i=r(4913),o=r(6980);e.exports=n?function(e,t,r){return i.f(e,t,o(1,r))}:function(e,t,r){return e[t]=r,e}},6980:e=>{"use strict";e.exports=function(e,t){return{enumerable:!(1&e),configurable:!(2&e),writable:!(4&e),value:t}}},4659:(e,t,r)=>{"use strict";var n=r(3724),i=r(4913),o=r(6980);e.exports=function(e,t,r){n?i.f(e,t,o(0,r)):e[t]=r}},2106:(e,t,r)=>{"use strict";var n=r(283),i=r(4913);e.exports=function(e,t,r){return r.get&&n(r.get,t,{getter:!0}),r.set&&n(r.set,t,{setter:!0}),i.f(e,t,r)}},6840:(e,t,r)=>{"use strict";var n=r(4901),i=r(4913),o=r(283),a=r(9433);e.exports=function(e,t,r,s){s||(s={});var u=s.enumerable,c=void 0!==s.name?s.name:t;if(n(r)&&o(r,c,s),s.global)u?e[t]=r:a(t,r);else{try{s.unsafe?e[t]&&(u=!0):delete e[t]}catch(e){}u?e[t]=r:i.f(e,t,{value:r,enumerable:!1,configurable:!s.nonConfigurable,writable:!s.nonWritable})}return e}},9433:(e,t,r)=>{"use strict";var n=r(4576),i=Object.defineProperty;e.exports=function(e,t){try{i(n,e,{value:t,configurable:!0,writable:!0})}catch(r){n[e]=t}return t}},4606:(e,t,r)=>{"use strict";var n=r(6823),i=TypeError;e.exports=function(e,t){if(!delete e[t])throw new i("Cannot delete property "+n(t)+" of "+n(e))}},3724:(e,t,r)=>{"use strict";var n=r(9039);e.exports=!n((function(){return 7!==Object.defineProperty({},1,{get:function(){return 7}})[1]}))},4055:(e,t,r)=>{"use strict";var n=r(4576),i=r(34),o=n.document,a=i(o)&&i(o.createElement);e.exports=function(e){return a?o.createElement(e):{}}},8727:e=>{"use strict";e.exports=["constructor","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","toLocaleString","toString","valueOf"]},3709:(e,t,r)=>{"use strict";var n=r(2839).match(/firefox\/(\d+)/i);e.exports=!!n&&+n[1]},3763:(e,t,r)=>{"use strict";var n=r(2839);e.exports=/MSIE|Trident/.test(n)},4265:(e,t,r)=>{"use strict";var n=r(2839);e.exports=/ipad|iphone|ipod/i.test(n)&&"undefined"!=typeof Pebble},9544:(e,t,r)=>{"use strict";var n=r(2839);e.exports=/(?:ipad|iphone|ipod).*applewebkit/i.test(n)},6193:(e,t,r)=>{"use strict";var n=r(4215);e.exports="NODE"===n},7860:(e,t,r)=>{"use strict";var n=r(2839);e.exports=/web0s(?!.*chrome)/i.test(n)},2839:(e,t,r)=>{"use strict";var n=r(4576).navigator,i=n&&n.userAgent;e.exports=i?String(i):""},9519:(e,t,r)=>{"use strict";var n,i,o=r(4576),a=r(2839),s=o.process,u=o.Deno,c=s&&s.versions||u&&u.version,l=c&&c.v8;l&&(i=(n=l.split("."))[0]>0&&n[0]<4?1:+(n[0]+n[1])),!i&&a&&(!(n=a.match(/Edge\/(\d+)/))||n[1]>=74)&&(n=a.match(/Chrome\/(\d+)/))&&(i=+n[1]),e.exports=i},3607:(e,t,r)=>{"use strict";var n=r(2839).match(/AppleWebKit\/(\d+)\./);e.exports=!!n&&+n[1]},4215:(e,t,r)=>{"use strict";var n=r(4576),i=r(2839),o=r(2195),a=function(e){return i.slice(0,e.length)===e};e.exports=a("Bun/")?"BUN":a("Cloudflare-Workers")?"CLOUDFLARE":a("Deno/")?"DENO":a("Node.js/")?"NODE":n.Bun&&"string"==typeof Bun.version?"BUN":n.Deno&&"object"==typeof Deno.version?"DENO":"process"===o(n.process)?"NODE":n.window&&n.document?"BROWSER":"REST"},6518:(e,t,r)=>{"use strict";var n=r(4576),i=r(7347).f,o=r(6699),a=r(6840),s=r(9433),u=r(7740),c=r(2796);e.exports=function(e,t){var r,l,f,p,m,d=e.target,h=e.global,g=e.stat;if(r=h?n:g?n[d]||s(d,{}):n[d]&&n[d].prototype)for(l in t){if(p=t[l],f=e.dontCallGetSet?(m=i(r,l))&&m.value:r[l],!c(h?l:d+(g?".":"#")+l,e.forced)&&void 0!==f){if(typeof p==typeof f)continue;u(p,f)}(e.sham||f&&f.sham)&&o(p,"sham",!0),a(r,l,p,e)}}},9039:e=>{"use strict";e.exports=function(e){try{return!!e()}catch(e){return!0}}},9228:(e,t,r)=>{"use strict";r(7495);var n=r(9565),i=r(6840),o=r(7323),a=r(9039),s=r(8227),u=r(6699),c=s("species"),l=RegExp.prototype;e.exports=function(e,t,r,f){var p=s(e),m=!a((function(){var t={};return t[p]=function(){return 7},7!==""[e](t)})),d=m&&!a((function(){var t=!1,r=/a/;return"split"===e&&((r={}).constructor={},r.constructor[c]=function(){return r},r.flags="",r[p]=/./[p]),r.exec=function(){return t=!0,null},r[p](""),!t}));if(!m||!d||r){var h=/./[p],g=t(p,""[e],(function(e,t,r,i,a){var s=t.exec;return s===o||s===l.exec?m&&!a?{done:!0,value:n(h,t,r,i)}:{done:!0,value:n(e,r,t,i)}:{done:!1}}));i(String.prototype,e,g[0]),i(l,p,g[1])}f&&u(l[p],"sham",!0)}},8745:(e,t,r)=>{"use strict";var n=r(616),i=Function.prototype,o=i.apply,a=i.call;e.exports="object"==typeof Reflect&&Reflect.apply||(n?a.bind(o):function(){return a.apply(o,arguments)})},6080:(e,t,r)=>{"use strict";var n=r(7476),i=r(9306),o=r(616),a=n(n.bind);e.exports=function(e,t){return i(e),void 0===t?e:o?a(e,t):function(){return e.apply(t,arguments)}}},616:(e,t,r)=>{"use strict";var n=r(9039);e.exports=!n((function(){var e=function(){}.bind();return"function"!=typeof e||e.hasOwnProperty("prototype")}))},9565:(e,t,r)=>{"use strict";var n=r(616),i=Function.prototype.call;e.exports=n?i.bind(i):function(){return i.apply(i,arguments)}},350:(e,t,r)=>{"use strict";var n=r(3724),i=r(9297),o=Function.prototype,a=n&&Object.getOwnPropertyDescriptor,s=i(o,"name"),u=s&&"something"===function(){}.name,c=s&&(!n||n&&a(o,"name").configurable);e.exports={EXISTS:s,PROPER:u,CONFIGURABLE:c}},6706:(e,t,r)=>{"use strict";var n=r(9504),i=r(9306);e.exports=function(e,t,r){try{return n(i(Object.getOwnPropertyDescriptor(e,t)[r]))}catch(e){}}},7476:(e,t,r)=>{"use strict";var n=r(2195),i=r(9504);e.exports=function(e){if("Function"===n(e))return i(e)}},9504:(e,t,r)=>{"use strict";var n=r(616),i=Function.prototype,o=i.call,a=n&&i.bind.bind(o,o);e.exports=n?a:function(e){return function(){return o.apply(e,arguments)}}},7751:(e,t,r)=>{"use strict";var n=r(4576),i=r(4901);e.exports=function(e,t){return arguments.length<2?(r=n[e],i(r)?r:void 0):n[e]&&n[e][t];var r}},851:(e,t,r)=>{"use strict";var n=r(6955),i=r(5966),o=r(4117),a=r(6269),s=r(8227)("iterator");e.exports=function(e){if(!o(e))return i(e,s)||i(e,"@@iterator")||a[n(e)]}},81:(e,t,r)=>{"use strict";var n=r(9565),i=r(9306),o=r(8551),a=r(6823),s=r(851),u=TypeError;e.exports=function(e,t){var r=arguments.length<2?s(e):t;if(i(r))return o(n(r,e));throw new u(a(e)+" is not iterable")}},6933:(e,t,r)=>{"use strict";var n=r(9504),i=r(4376),o=r(4901),a=r(2195),s=r(655),u=n([].push);e.exports=function(e){if(o(e))return e;if(i(e)){for(var t=e.length,r=[],n=0;n{"use strict";var n=r(9306),i=r(4117);e.exports=function(e,t){var r=e[t];return i(r)?void 0:n(r)}},2478:(e,t,r)=>{"use strict";var n=r(9504),i=r(8981),o=Math.floor,a=n("".charAt),s=n("".replace),u=n("".slice),c=/\$([$&'`]|\d{1,2}|<[^>]*>)/g,l=/\$([$&'`]|\d{1,2})/g;e.exports=function(e,t,r,n,f,p){var m=r+e.length,d=n.length,h=l;return void 0!==f&&(f=i(f),h=c),s(p,h,(function(i,s){var c;switch(a(s,0)){case"$":return"$";case"&":return e;case"`":return u(t,0,r);case"'":return u(t,m);case"<":c=f[u(s,1,-1)];break;default:var l=+s;if(0===l)return i;if(l>d){var p=o(l/10);return 0===p?i:p<=d?void 0===n[p-1]?a(s,1):n[p-1]+a(s,1):i}c=n[l-1]}return void 0===c?"":c}))}},4576:function(e){"use strict";var t=function(e){return e&&e.Math===Math&&e};e.exports=t("object"==typeof globalThis&&globalThis)||t("object"==typeof window&&window)||t("object"==typeof self&&self)||t("object"==typeof global&&global)||t("object"==typeof this&&this)||function(){return this}()||Function("return this")()},9297:(e,t,r)=>{"use strict";var n=r(9504),i=r(8981),o=n({}.hasOwnProperty);e.exports=Object.hasOwn||function(e,t){return o(i(e),t)}},421:e=>{"use strict";e.exports={}},3138:e=>{"use strict";e.exports=function(e,t){try{1===arguments.length?console.error(e):console.error(e,t)}catch(e){}}},397:(e,t,r)=>{"use strict";var n=r(7751);e.exports=n("document","documentElement")},5917:(e,t,r)=>{"use strict";var n=r(3724),i=r(9039),o=r(4055);e.exports=!n&&!i((function(){return 7!==Object.defineProperty(o("div"),"a",{get:function(){return 7}}).a}))},7055:(e,t,r)=>{"use strict";var n=r(9504),i=r(9039),o=r(2195),a=Object,s=n("".split);e.exports=i((function(){return!a("z").propertyIsEnumerable(0)}))?function(e){return"String"===o(e)?s(e,""):a(e)}:a},3167:(e,t,r)=>{"use strict";var n=r(4901),i=r(34),o=r(2967);e.exports=function(e,t,r){var a,s;return o&&n(a=t.constructor)&&a!==r&&i(s=a.prototype)&&s!==r.prototype&&o(e,s),e}},3706:(e,t,r)=>{"use strict";var n=r(9504),i=r(4901),o=r(7629),a=n(Function.toString);i(o.inspectSource)||(o.inspectSource=function(e){return a(e)}),e.exports=o.inspectSource},1181:(e,t,r)=>{"use strict";var n,i,o,a=r(8622),s=r(4576),u=r(34),c=r(6699),l=r(9297),f=r(7629),p=r(6119),m=r(421),d="Object already initialized",h=s.TypeError,g=s.WeakMap;if(a||f.state){var y=f.state||(f.state=new g);y.get=y.get,y.has=y.has,y.set=y.set,n=function(e,t){if(y.has(e))throw new h(d);return t.facade=e,y.set(e,t),t},i=function(e){return y.get(e)||{}},o=function(e){return y.has(e)}}else{var x=p("state");m[x]=!0,n=function(e,t){if(l(e,x))throw new h(d);return t.facade=e,c(e,x,t),t},i=function(e){return l(e,x)?e[x]:{}},o=function(e){return l(e,x)}}e.exports={set:n,get:i,has:o,enforce:function(e){return o(e)?i(e):n(e,{})},getterFor:function(e){return function(t){var r;if(!u(t)||(r=i(t)).type!==e)throw new h("Incompatible receiver, "+e+" required");return r}}}},4209:(e,t,r)=>{"use strict";var n=r(8227),i=r(6269),o=n("iterator"),a=Array.prototype;e.exports=function(e){return void 0!==e&&(i.Array===e||a[o]===e)}},4376:(e,t,r)=>{"use strict";var n=r(2195);e.exports=Array.isArray||function(e){return"Array"===n(e)}},4901:e=>{"use strict";var t="object"==typeof document&&document.all;e.exports=void 0===t&&void 0!==t?function(e){return"function"==typeof e||e===t}:function(e){return"function"==typeof e}},3517:(e,t,r)=>{"use strict";var n=r(9504),i=r(9039),o=r(4901),a=r(6955),s=r(7751),u=r(3706),c=function(){},l=s("Reflect","construct"),f=/^\s*(?:class|function)\b/,p=n(f.exec),m=!f.test(c),d=function(e){if(!o(e))return!1;try{return l(c,[],e),!0}catch(e){return!1}},h=function(e){if(!o(e))return!1;switch(a(e)){case"AsyncFunction":case"GeneratorFunction":case"AsyncGeneratorFunction":return!1}try{return m||!!p(f,u(e))}catch(e){return!0}};h.sham=!0,e.exports=!l||i((function(){var e;return d(d.call)||!d(Object)||!d((function(){e=!0}))||e}))?h:d},2796:(e,t,r)=>{"use strict";var n=r(9039),i=r(4901),o=/#|\.prototype\./,a=function(e,t){var r=u[s(e)];return r===l||r!==c&&(i(t)?n(t):!!t)},s=a.normalize=function(e){return String(e).replace(o,".").toLowerCase()},u=a.data={},c=a.NATIVE="N",l=a.POLYFILL="P";e.exports=a},4117:e=>{"use strict";e.exports=function(e){return null==e}},34:(e,t,r)=>{"use strict";var n=r(4901);e.exports=function(e){return"object"==typeof e?null!==e:n(e)}},3925:(e,t,r)=>{"use strict";var n=r(34);e.exports=function(e){return n(e)||null===e}},6395:e=>{"use strict";e.exports=!1},788:(e,t,r)=>{"use strict";var n=r(34),i=r(2195),o=r(8227)("match");e.exports=function(e){var t;return n(e)&&(void 0!==(t=e[o])?!!t:"RegExp"===i(e))}},757:(e,t,r)=>{"use strict";var n=r(7751),i=r(4901),o=r(1625),a=r(7040),s=Object;e.exports=a?function(e){return"symbol"==typeof e}:function(e){var t=n("Symbol");return i(t)&&o(t.prototype,s(e))}},2652:(e,t,r)=>{"use strict";var n=r(6080),i=r(9565),o=r(8551),a=r(6823),s=r(4209),u=r(6198),c=r(1625),l=r(81),f=r(851),p=r(9539),m=TypeError,d=function(e,t){this.stopped=e,this.result=t},h=d.prototype;e.exports=function(e,t,r){var g,y,x,b,v,w,N,E=r&&r.that,A=!(!r||!r.AS_ENTRIES),S=!(!r||!r.IS_RECORD),M=!(!r||!r.IS_ITERATOR),C=!(!r||!r.INTERRUPTED),T=n(t,E),D=function(e){return g&&p(g,"normal",e),new d(!0,e)},F=function(e){return A?(o(e),C?T(e[0],e[1],D):T(e[0],e[1])):C?T(e,D):T(e)};if(S)g=e.iterator;else if(M)g=e;else{if(!(y=f(e)))throw new m(a(e)+" is not iterable");if(s(y)){for(x=0,b=u(e);b>x;x++)if((v=F(e[x]))&&c(h,v))return v;return new d(!1)}g=l(e,y)}for(w=S?e.next:g.next;!(N=i(w,g)).done;){try{v=F(N.value)}catch(e){p(g,"throw",e)}if("object"==typeof v&&v&&c(h,v))return v}return new d(!1)}},9539:(e,t,r)=>{"use strict";var n=r(9565),i=r(8551),o=r(5966);e.exports=function(e,t,r){var a,s;i(e);try{if(!(a=o(e,"return"))){if("throw"===t)throw r;return r}a=n(a,e)}catch(e){s=!0,a=e}if("throw"===t)throw r;if(s)throw a;return i(a),r}},6269:e=>{"use strict";e.exports={}},6198:(e,t,r)=>{"use strict";var n=r(8014);e.exports=function(e){return n(e.length)}},283:(e,t,r)=>{"use strict";var n=r(9504),i=r(9039),o=r(4901),a=r(9297),s=r(3724),u=r(350).CONFIGURABLE,c=r(3706),l=r(1181),f=l.enforce,p=l.get,m=String,d=Object.defineProperty,h=n("".slice),g=n("".replace),y=n([].join),x=s&&!i((function(){return 8!==d((function(){}),"length",{value:8}).length})),b=String(String).split("String"),v=e.exports=function(e,t,r){"Symbol("===h(m(t),0,7)&&(t="["+g(m(t),/^Symbol\(([^)]*)\).*$/,"$1")+"]"),r&&r.getter&&(t="get "+t),r&&r.setter&&(t="set "+t),(!a(e,"name")||u&&e.name!==t)&&(s?d(e,"name",{value:t,configurable:!0}):e.name=t),x&&r&&a(r,"arity")&&e.length!==r.arity&&d(e,"length",{value:r.arity});try{r&&a(r,"constructor")&&r.constructor?s&&d(e,"prototype",{writable:!1}):e.prototype&&(e.prototype=void 0)}catch(e){}var n=f(e);return a(n,"source")||(n.source=y(b,"string"==typeof t?t:"")),e};Function.prototype.toString=v((function(){return o(this)&&p(this).source||c(this)}),"toString")},741:e=>{"use strict";var t=Math.ceil,r=Math.floor;e.exports=Math.trunc||function(e){var n=+e;return(n>0?r:t)(n)}},1955:(e,t,r)=>{"use strict";var n,i,o,a,s,u=r(4576),c=r(3389),l=r(6080),f=r(9225).set,p=r(8265),m=r(9544),d=r(4265),h=r(7860),g=r(6193),y=u.MutationObserver||u.WebKitMutationObserver,x=u.document,b=u.process,v=u.Promise,w=c("queueMicrotask");if(!w){var N=new p,E=function(){var e,t;for(g&&(e=b.domain)&&e.exit();t=N.get();)try{t()}catch(e){throw N.head&&n(),e}e&&e.enter()};m||g||h||!y||!x?!d&&v&&v.resolve?((a=v.resolve(void 0)).constructor=v,s=l(a.then,a),n=function(){s(E)}):g?n=function(){b.nextTick(E)}:(f=l(f,u),n=function(){f(E)}):(i=!0,o=x.createTextNode(""),new y(E).observe(o,{characterData:!0}),n=function(){o.data=i=!i}),w=function(e){N.head||n(),N.add(e)}}e.exports=w},6043:(e,t,r)=>{"use strict";var n=r(9306),i=TypeError,o=function(e){var t,r;this.promise=new e((function(e,n){if(void 0!==t||void 0!==r)throw new i("Bad Promise constructor");t=e,r=n})),this.resolve=n(t),this.reject=n(r)};e.exports.f=function(e){return new o(e)}},2360:(e,t,r)=>{"use strict";var n,i=r(8551),o=r(6801),a=r(8727),s=r(421),u=r(397),c=r(4055),l=r(6119),f="prototype",p="script",m=l("IE_PROTO"),d=function(){},h=function(e){return"<"+p+">"+e+""},g=function(e){e.write(h("")),e.close();var t=e.parentWindow.Object;return e=null,t},y=function(){try{n=new ActiveXObject("htmlfile")}catch(e){}var e,t,r;y="undefined"!=typeof document?document.domain&&n?g(n):(t=c("iframe"),r="java"+p+":",t.style.display="none",u.appendChild(t),t.src=String(r),(e=t.contentWindow.document).open(),e.write(h("document.F=Object")),e.close(),e.F):g(n);for(var i=a.length;i--;)delete y[f][a[i]];return y()};s[m]=!0,e.exports=Object.create||function(e,t){var r;return null!==e?(d[f]=i(e),r=new d,d[f]=null,r[m]=e):r=y(),void 0===t?r:o.f(r,t)}},6801:(e,t,r)=>{"use strict";var n=r(3724),i=r(8686),o=r(4913),a=r(8551),s=r(5397),u=r(1072);t.f=n&&!i?Object.defineProperties:function(e,t){a(e);for(var r,n=s(t),i=u(t),c=i.length,l=0;c>l;)o.f(e,r=i[l++],n[r]);return e}},4913:(e,t,r)=>{"use strict";var n=r(3724),i=r(5917),o=r(8686),a=r(8551),s=r(6969),u=TypeError,c=Object.defineProperty,l=Object.getOwnPropertyDescriptor,f="enumerable",p="configurable",m="writable";t.f=n?o?function(e,t,r){if(a(e),t=s(t),a(r),"function"==typeof e&&"prototype"===t&&"value"in r&&m in r&&!r[m]){var n=l(e,t);n&&n[m]&&(e[t]=r.value,r={configurable:p in r?r[p]:n[p],enumerable:f in r?r[f]:n[f],writable:!1})}return c(e,t,r)}:c:function(e,t,r){if(a(e),t=s(t),a(r),i)try{return c(e,t,r)}catch(e){}if("get"in r||"set"in r)throw new u("Accessors not supported");return"value"in r&&(e[t]=r.value),e}},7347:(e,t,r)=>{"use strict";var n=r(3724),i=r(9565),o=r(8773),a=r(6980),s=r(5397),u=r(6969),c=r(9297),l=r(5917),f=Object.getOwnPropertyDescriptor;t.f=n?f:function(e,t){if(e=s(e),t=u(t),l)try{return f(e,t)}catch(e){}if(c(e,t))return a(!i(o.f,e,t),e[t])}},8480:(e,t,r)=>{"use strict";var n=r(1828),i=r(8727).concat("length","prototype");t.f=Object.getOwnPropertyNames||function(e){return n(e,i)}},3717:(e,t)=>{"use strict";t.f=Object.getOwnPropertySymbols},1625:(e,t,r)=>{"use strict";var n=r(9504);e.exports=n({}.isPrototypeOf)},1828:(e,t,r)=>{"use strict";var n=r(9504),i=r(9297),o=r(5397),a=r(9617).indexOf,s=r(421),u=n([].push);e.exports=function(e,t){var r,n=o(e),c=0,l=[];for(r in n)!i(s,r)&&i(n,r)&&u(l,r);for(;t.length>c;)i(n,r=t[c++])&&(~a(l,r)||u(l,r));return l}},1072:(e,t,r)=>{"use strict";var n=r(1828),i=r(8727);e.exports=Object.keys||function(e){return n(e,i)}},8773:(e,t)=>{"use strict";var r={}.propertyIsEnumerable,n=Object.getOwnPropertyDescriptor,i=n&&!r.call({1:2},1);t.f=i?function(e){var t=n(this,e);return!!t&&t.enumerable}:r},2967:(e,t,r)=>{"use strict";var n=r(6706),i=r(34),o=r(7750),a=r(3506);e.exports=Object.setPrototypeOf||("__proto__"in{}?function(){var e,t=!1,r={};try{(e=n(Object.prototype,"__proto__","set"))(r,[]),t=r instanceof Array}catch(e){}return function(r,n){return o(r),a(n),i(r)?(t?e(r,n):r.__proto__=n,r):r}}():void 0)},4270:(e,t,r)=>{"use strict";var n=r(9565),i=r(4901),o=r(34),a=TypeError;e.exports=function(e,t){var r,s;if("string"===t&&i(r=e.toString)&&!o(s=n(r,e)))return s;if(i(r=e.valueOf)&&!o(s=n(r,e)))return s;if("string"!==t&&i(r=e.toString)&&!o(s=n(r,e)))return s;throw new a("Can't convert object to primitive value")}},5031:(e,t,r)=>{"use strict";var n=r(7751),i=r(9504),o=r(8480),a=r(3717),s=r(8551),u=i([].concat);e.exports=n("Reflect","ownKeys")||function(e){var t=o.f(s(e)),r=a.f;return r?u(t,r(e)):t}},1103:e=>{"use strict";e.exports=function(e){try{return{error:!1,value:e()}}catch(e){return{error:!0,value:e}}}},916:(e,t,r)=>{"use strict";var n=r(4576),i=r(550),o=r(4901),a=r(2796),s=r(3706),u=r(8227),c=r(4215),l=r(6395),f=r(9519),p=i&&i.prototype,m=u("species"),d=!1,h=o(n.PromiseRejectionEvent),g=a("Promise",(function(){var e=s(i),t=e!==String(i);if(!t&&66===f)return!0;if(l&&(!p.catch||!p.finally))return!0;if(!f||f<51||!/native code/.test(e)){var r=new i((function(e){e(1)})),n=function(e){e((function(){}),(function(){}))};if((r.constructor={})[m]=n,!(d=r.then((function(){}))instanceof n))return!0}return!(t||"BROWSER"!==c&&"DENO"!==c||h)}));e.exports={CONSTRUCTOR:g,REJECTION_EVENT:h,SUBCLASSING:d}},550:(e,t,r)=>{"use strict";var n=r(4576);e.exports=n.Promise},3438:(e,t,r)=>{"use strict";var n=r(8551),i=r(34),o=r(6043);e.exports=function(e,t){if(n(e),i(t)&&t.constructor===e)return t;var r=o.f(e);return(0,r.resolve)(t),r.promise}},537:(e,t,r)=>{"use strict";var n=r(550),i=r(4428),o=r(916).CONSTRUCTOR;e.exports=o||!i((function(e){n.all(e).then(void 0,(function(){}))}))},1056:(e,t,r)=>{"use strict";var n=r(4913).f;e.exports=function(e,t,r){r in e||n(e,r,{configurable:!0,get:function(){return t[r]},set:function(e){t[r]=e}})}},8265:e=>{"use strict";var t=function(){this.head=null,this.tail=null};t.prototype={add:function(e){var t={item:e,next:null},r=this.tail;r?r.next=t:this.head=t,this.tail=t},get:function(){var e=this.head;if(e)return null===(this.head=e.next)&&(this.tail=null),e.item}},e.exports=t},6682:(e,t,r)=>{"use strict";var n=r(9565),i=r(8551),o=r(4901),a=r(2195),s=r(7323),u=TypeError;e.exports=function(e,t){var r=e.exec;if(o(r)){var c=n(r,e,t);return null!==c&&i(c),c}if("RegExp"===a(e))return n(s,e,t);throw new u("RegExp#exec called on incompatible receiver")}},7323:(e,t,r)=>{"use strict";var n,i,o=r(9565),a=r(9504),s=r(655),u=r(7979),c=r(8429),l=r(5745),f=r(2360),p=r(1181).get,m=r(3635),d=r(8814),h=l("native-string-replace",String.prototype.replace),g=RegExp.prototype.exec,y=g,x=a("".charAt),b=a("".indexOf),v=a("".replace),w=a("".slice),N=(i=/b*/g,o(g,n=/a/,"a"),o(g,i,"a"),0!==n.lastIndex||0!==i.lastIndex),E=c.BROKEN_CARET,A=void 0!==/()??/.exec("")[1];(N||A||E||m||d)&&(y=function(e){var t,r,n,i,a,c,l,m=this,d=p(m),S=s(e),M=d.raw;if(M)return M.lastIndex=m.lastIndex,t=o(y,M,S),m.lastIndex=M.lastIndex,t;var C=d.groups,T=E&&m.sticky,D=o(u,m),F=m.source,O=0,B=S;if(T&&(D=v(D,"y",""),-1===b(D,"g")&&(D+="g"),B=w(S,m.lastIndex),m.lastIndex>0&&(!m.multiline||m.multiline&&"\n"!==x(S,m.lastIndex-1))&&(F="(?: "+F+")",B=" "+B,O++),r=new RegExp("^(?:"+F+")",D)),A&&(r=new RegExp("^"+F+"$(?!\\s)",D)),N&&(n=m.lastIndex),i=o(g,T?r:m,B),T?i?(i.input=w(i.input,O),i[0]=w(i[0],O),i.index=m.lastIndex,m.lastIndex+=i[0].length):m.lastIndex=0:N&&i&&(m.lastIndex=m.global?i.index+i[0].length:n),A&&i&&i.length>1&&o(h,i[0],r,(function(){for(a=1;a{"use strict";var n=r(8551);e.exports=function(){var e=n(this),t="";return e.hasIndices&&(t+="d"),e.global&&(t+="g"),e.ignoreCase&&(t+="i"),e.multiline&&(t+="m"),e.dotAll&&(t+="s"),e.unicode&&(t+="u"),e.unicodeSets&&(t+="v"),e.sticky&&(t+="y"),t}},1034:(e,t,r)=>{"use strict";var n=r(9565),i=r(9297),o=r(1625),a=r(7979),s=RegExp.prototype;e.exports=function(e){var t=e.flags;return void 0!==t||"flags"in s||i(e,"flags")||!o(s,e)?t:n(a,e)}},8429:(e,t,r)=>{"use strict";var n=r(9039),i=r(4576).RegExp,o=n((function(){var e=i("a","y");return e.lastIndex=2,null!==e.exec("abcd")})),a=o||n((function(){return!i("a","y").sticky})),s=o||n((function(){var e=i("^r","gy");return e.lastIndex=2,null!==e.exec("str")}));e.exports={BROKEN_CARET:s,MISSED_STICKY:a,UNSUPPORTED_Y:o}},3635:(e,t,r)=>{"use strict";var n=r(9039),i=r(4576).RegExp;e.exports=n((function(){var e=i(".","s");return!(e.dotAll&&e.test("\n")&&"s"===e.flags)}))},8814:(e,t,r)=>{"use strict";var n=r(9039),i=r(4576).RegExp;e.exports=n((function(){var e=i("(?b)","g");return"b"!==e.exec("b").groups.a||"bc"!=="b".replace(e,"$c")}))},7750:(e,t,r)=>{"use strict";var n=r(4117),i=TypeError;e.exports=function(e){if(n(e))throw new i("Can't call method on "+e);return e}},3389:(e,t,r)=>{"use strict";var n=r(4576),i=r(3724),o=Object.getOwnPropertyDescriptor;e.exports=function(e){if(!i)return n[e];var t=o(n,e);return t&&t.value}},7633:(e,t,r)=>{"use strict";var n=r(7751),i=r(2106),o=r(8227),a=r(3724),s=o("species");e.exports=function(e){var t=n(e);a&&t&&!t[s]&&i(t,s,{configurable:!0,get:function(){return this}})}},687:(e,t,r)=>{"use strict";var n=r(4913).f,i=r(9297),o=r(8227)("toStringTag");e.exports=function(e,t,r){e&&!r&&(e=e.prototype),e&&!i(e,o)&&n(e,o,{configurable:!0,value:t})}},6119:(e,t,r)=>{"use strict";var n=r(5745),i=r(3392),o=n("keys");e.exports=function(e){return o[e]||(o[e]=i(e))}},7629:(e,t,r)=>{"use strict";var n=r(6395),i=r(4576),o=r(9433),a="__core-js_shared__",s=e.exports=i[a]||o(a,{});(s.versions||(s.versions=[])).push({version:"3.38.1",mode:n?"pure":"global",copyright:"© 2014-2024 Denis Pushkarev (zloirock.ru)",license:"https://github.com/zloirock/core-js/blob/v3.38.1/LICENSE",source:"https://github.com/zloirock/core-js"})},5745:(e,t,r)=>{"use strict";var n=r(7629);e.exports=function(e,t){return n[e]||(n[e]=t||{})}},2293:(e,t,r)=>{"use strict";var n=r(8551),i=r(5548),o=r(4117),a=r(8227)("species");e.exports=function(e,t){var r,s=n(e).constructor;return void 0===s||o(r=n(s)[a])?t:i(r)}},8183:(e,t,r)=>{"use strict";var n=r(9504),i=r(1291),o=r(655),a=r(7750),s=n("".charAt),u=n("".charCodeAt),c=n("".slice),l=function(e){return function(t,r){var n,l,f=o(a(t)),p=i(r),m=f.length;return p<0||p>=m?e?"":void 0:(n=u(f,p))<55296||n>56319||p+1===m||(l=u(f,p+1))<56320||l>57343?e?s(f,p):n:e?c(f,p,p+2):l-56320+(n-55296<<10)+65536}};e.exports={codeAt:l(!1),charAt:l(!0)}},4495:(e,t,r)=>{"use strict";var n=r(9519),i=r(9039),o=r(4576).String;e.exports=!!Object.getOwnPropertySymbols&&!i((function(){var e=Symbol("symbol detection");return!o(e)||!(Object(e)instanceof Symbol)||!Symbol.sham&&n&&n<41}))},9225:(e,t,r)=>{"use strict";var n,i,o,a,s=r(4576),u=r(8745),c=r(6080),l=r(4901),f=r(9297),p=r(9039),m=r(397),d=r(7680),h=r(4055),g=r(2812),y=r(9544),x=r(6193),b=s.setImmediate,v=s.clearImmediate,w=s.process,N=s.Dispatch,E=s.Function,A=s.MessageChannel,S=s.String,M=0,C={},T="onreadystatechange";p((function(){n=s.location}));var D=function(e){if(f(C,e)){var t=C[e];delete C[e],t()}},F=function(e){return function(){D(e)}},O=function(e){D(e.data)},B=function(e){s.postMessage(S(e),n.protocol+"//"+n.host)};b&&v||(b=function(e){g(arguments.length,1);var t=l(e)?e:E(e),r=d(arguments,1);return C[++M]=function(){u(t,void 0,r)},i(M),M},v=function(e){delete C[e]},x?i=function(e){w.nextTick(F(e))}:N&&N.now?i=function(e){N.now(F(e))}:A&&!y?(a=(o=new A).port2,o.port1.onmessage=O,i=c(a.postMessage,a)):s.addEventListener&&l(s.postMessage)&&!s.importScripts&&n&&"file:"!==n.protocol&&!p(B)?(i=B,s.addEventListener("message",O,!1)):i=T in h("script")?function(e){m.appendChild(h("script"))[T]=function(){m.removeChild(this),D(e)}}:function(e){setTimeout(F(e),0)}),e.exports={set:b,clear:v}},5610:(e,t,r)=>{"use strict";var n=r(1291),i=Math.max,o=Math.min;e.exports=function(e,t){var r=n(e);return r<0?i(r+t,0):o(r,t)}},5397:(e,t,r)=>{"use strict";var n=r(7055),i=r(7750);e.exports=function(e){return n(i(e))}},1291:(e,t,r)=>{"use strict";var n=r(741);e.exports=function(e){var t=+e;return t!=t||0===t?0:n(t)}},8014:(e,t,r)=>{"use strict";var n=r(1291),i=Math.min;e.exports=function(e){var t=n(e);return t>0?i(t,9007199254740991):0}},8981:(e,t,r)=>{"use strict";var n=r(7750),i=Object;e.exports=function(e){return i(n(e))}},2777:(e,t,r)=>{"use strict";var n=r(9565),i=r(34),o=r(757),a=r(5966),s=r(4270),u=r(8227),c=TypeError,l=u("toPrimitive");e.exports=function(e,t){if(!i(e)||o(e))return e;var r,u=a(e,l);if(u){if(void 0===t&&(t="default"),r=n(u,e,t),!i(r)||o(r))return r;throw new c("Can't convert object to primitive value")}return void 0===t&&(t="number"),s(e,t)}},6969:(e,t,r)=>{"use strict";var n=r(2777),i=r(757);e.exports=function(e){var t=n(e,"string");return i(t)?t:t+""}},2140:(e,t,r)=>{"use strict";var n={};n[r(8227)("toStringTag")]="z",e.exports="[object z]"===String(n)},655:(e,t,r)=>{"use strict";var n=r(6955),i=String;e.exports=function(e){if("Symbol"===n(e))throw new TypeError("Cannot convert a Symbol value to a string");return i(e)}},6823:e=>{"use strict";var t=String;e.exports=function(e){try{return t(e)}catch(e){return"Object"}}},3392:(e,t,r)=>{"use strict";var n=r(9504),i=0,o=Math.random(),a=n(1..toString);e.exports=function(e){return"Symbol("+(void 0===e?"":e)+")_"+a(++i+o,36)}},7040:(e,t,r)=>{"use strict";var n=r(4495);e.exports=n&&!Symbol.sham&&"symbol"==typeof Symbol.iterator},8686:(e,t,r)=>{"use strict";var n=r(3724),i=r(9039);e.exports=n&&i((function(){return 42!==Object.defineProperty((function(){}),"prototype",{value:42,writable:!1}).prototype}))},2812:e=>{"use strict";var t=TypeError;e.exports=function(e,r){if(e{"use strict";var n=r(4576),i=r(4901),o=n.WeakMap;e.exports=i(o)&&/native code/.test(String(o))},8227:(e,t,r)=>{"use strict";var n=r(4576),i=r(5745),o=r(9297),a=r(3392),s=r(4495),u=r(7040),c=n.Symbol,l=i("wks"),f=u?c.for||c:c&&c.withoutSetter||a;e.exports=function(e){return o(l,e)||(l[e]=s&&o(c,e)?c[e]:f("Symbol."+e)),l[e]}},4423:(e,t,r)=>{"use strict";var n=r(6518),i=r(9617).includes,o=r(9039),a=r(6469);n({target:"Array",proto:!0,forced:o((function(){return!Array(1).includes()}))},{includes:function(e){return i(this,e,arguments.length>1?arguments[1]:void 0)}}),a("includes")},2712:(e,t,r)=>{"use strict";var n=r(6518),i=r(926).left,o=r(4598),a=r(9519);n({target:"Array",proto:!0,forced:!r(6193)&&a>79&&a<83||!o("reduce")},{reduce:function(e){var t=arguments.length;return i(this,e,t,t>1?arguments[1]:void 0)}})},6910:(e,t,r)=>{"use strict";var n=r(6518),i=r(9504),o=r(9306),a=r(8981),s=r(6198),u=r(4606),c=r(655),l=r(9039),f=r(4488),p=r(4598),m=r(3709),d=r(3763),h=r(9519),g=r(3607),y=[],x=i(y.sort),b=i(y.push),v=l((function(){y.sort(void 0)})),w=l((function(){y.sort(null)})),N=p("sort"),E=!l((function(){if(h)return h<70;if(!(m&&m>3)){if(d)return!0;if(g)return g<603;var e,t,r,n,i="";for(e=65;e<76;e++){switch(t=String.fromCharCode(e),e){case 66:case 69:case 70:case 72:r=3;break;case 68:case 71:r=4;break;default:r=2}for(n=0;n<47;n++)y.push({k:t+n,v:r})}for(y.sort((function(e,t){return t.v-e.v})),n=0;nc(r)?1:-1}}(e)),r=s(i),n=0;n{"use strict";var n=r(6518),i=r(7751),o=r(8745),a=r(9565),s=r(9504),u=r(9039),c=r(4901),l=r(757),f=r(7680),p=r(6933),m=r(4495),d=String,h=i("JSON","stringify"),g=s(/./.exec),y=s("".charAt),x=s("".charCodeAt),b=s("".replace),v=s(1..toString),w=/[\uD800-\uDFFF]/g,N=/^[\uD800-\uDBFF]$/,E=/^[\uDC00-\uDFFF]$/,A=!m||u((function(){var e=i("Symbol")("stringify detection");return"[null]"!==h([e])||"{}"!==h({a:e})||"{}"!==h(Object(e))})),S=u((function(){return'"\\udf06\\ud834"'!==h("\udf06\ud834")||'"\\udead"'!==h("\udead")})),M=function(e,t){var r=f(arguments),n=p(t);if(c(n)||void 0!==e&&!l(e))return r[1]=function(e,t){if(c(n)&&(t=a(n,this,d(e),t)),!l(t))return t},o(h,null,r)},C=function(e,t,r){var n=y(r,t-1),i=y(r,t+1);return g(N,e)&&!g(E,i)||g(E,e)&&!g(N,n)?"\\u"+v(x(e,0),16):e};h&&n({target:"JSON",stat:!0,arity:3,forced:A||S},{stringify:function(e,t,r){var n=f(arguments),i=o(A?M:h,null,n);return S&&"string"==typeof i?b(i,w,C):i}})},3921:(e,t,r)=>{"use strict";var n=r(6518),i=r(2652),o=r(4659);n({target:"Object",stat:!0},{fromEntries:function(e){var t={};return i(e,(function(e,r){o(t,e,r)}),{AS_ENTRIES:!0}),t}})},6499:(e,t,r)=>{"use strict";var n=r(6518),i=r(9565),o=r(9306),a=r(6043),s=r(1103),u=r(2652);n({target:"Promise",stat:!0,forced:r(537)},{all:function(e){var t=this,r=a.f(t),n=r.resolve,c=r.reject,l=s((function(){var r=o(t.resolve),a=[],s=0,l=1;u(e,(function(e){var o=s++,u=!1;l++,i(r,t,e).then((function(e){u||(u=!0,a[o]=e,--l||n(a))}),c)})),--l||n(a)}));return l.error&&c(l.value),r.promise}})},2003:(e,t,r)=>{"use strict";var n=r(6518),i=r(6395),o=r(916).CONSTRUCTOR,a=r(550),s=r(7751),u=r(4901),c=r(6840),l=a&&a.prototype;if(n({target:"Promise",proto:!0,forced:o,real:!0},{catch:function(e){return this.then(void 0,e)}}),!i&&u(a)){var f=s("Promise").prototype.catch;l.catch!==f&&c(l,"catch",f,{unsafe:!0})}},436:(e,t,r)=>{"use strict";var n,i,o,a=r(6518),s=r(6395),u=r(6193),c=r(4576),l=r(9565),f=r(6840),p=r(2967),m=r(687),d=r(7633),h=r(9306),g=r(4901),y=r(34),x=r(679),b=r(2293),v=r(9225).set,w=r(1955),N=r(3138),E=r(1103),A=r(8265),S=r(1181),M=r(550),C=r(916),T=r(6043),D="Promise",F=C.CONSTRUCTOR,O=C.REJECTION_EVENT,B=C.SUBCLASSING,_=S.getterFor(D),z=S.set,I=M&&M.prototype,k=M,q=I,R=c.TypeError,P=c.document,j=c.process,U=T.f,L=U,$=!!(P&&P.createEvent&&c.dispatchEvent),H="unhandledrejection",G=function(e){var t;return!(!y(e)||!g(t=e.then))&&t},Z=function(e,t){var r,n,i,o=t.value,a=1===t.state,s=a?e.ok:e.fail,u=e.resolve,c=e.reject,f=e.domain;try{s?(a||(2===t.rejection&&X(t),t.rejection=1),!0===s?r=o:(f&&f.enter(),r=s(o),f&&(f.exit(),i=!0)),r===e.promise?c(new R("Promise-chain cycle")):(n=G(r))?l(n,r,u,c):u(r)):c(o)}catch(e){f&&!i&&f.exit(),c(e)}},V=function(e,t){e.notified||(e.notified=!0,w((function(){for(var r,n=e.reactions;r=n.get();)Z(r,e);e.notified=!1,t&&!e.rejection&&Y(e)})))},W=function(e,t,r){var n,i;$?((n=P.createEvent("Event")).promise=t,n.reason=r,n.initEvent(e,!1,!0),c.dispatchEvent(n)):n={promise:t,reason:r},!O&&(i=c["on"+e])?i(n):e===H&&N("Unhandled promise rejection",r)},Y=function(e){l(v,c,(function(){var t,r=e.facade,n=e.value;if(J(e)&&(t=E((function(){u?j.emit("unhandledRejection",n,r):W(H,r,n)})),e.rejection=u||J(e)?2:1,t.error))throw t.value}))},J=function(e){return 1!==e.rejection&&!e.parent},X=function(e){l(v,c,(function(){var t=e.facade;u?j.emit("rejectionHandled",t):W("rejectionhandled",t,e.value)}))},Q=function(e,t,r){return function(n){e(t,n,r)}},K=function(e,t,r){e.done||(e.done=!0,r&&(e=r),e.value=t,e.state=2,V(e,!0))},ee=function(e,t,r){if(!e.done){e.done=!0,r&&(e=r);try{if(e.facade===t)throw new R("Promise can't be resolved itself");var n=G(t);n?w((function(){var r={done:!1};try{l(n,t,Q(ee,r,e),Q(K,r,e))}catch(t){K(r,t,e)}})):(e.value=t,e.state=1,V(e,!1))}catch(t){K({done:!1},t,e)}}};if(F&&(q=(k=function(e){x(this,q),h(e),l(n,this);var t=_(this);try{e(Q(ee,t),Q(K,t))}catch(e){K(t,e)}}).prototype,(n=function(e){z(this,{type:D,done:!1,notified:!1,parent:!1,reactions:new A,rejection:!1,state:0,value:null})}).prototype=f(q,"then",(function(e,t){var r=_(this),n=U(b(this,k));return r.parent=!0,n.ok=!g(e)||e,n.fail=g(t)&&t,n.domain=u?j.domain:void 0,0===r.state?r.reactions.add(n):w((function(){Z(n,r)})),n.promise})),i=function(){var e=new n,t=_(e);this.promise=e,this.resolve=Q(ee,t),this.reject=Q(K,t)},T.f=U=function(e){return e===k||void 0===e?new i(e):L(e)},!s&&g(M)&&I!==Object.prototype)){o=I.then,B||f(I,"then",(function(e,t){var r=this;return new k((function(e,t){l(o,r,e,t)})).then(e,t)}),{unsafe:!0});try{delete I.constructor}catch(e){}p&&p(I,q)}a({global:!0,constructor:!0,wrap:!0,forced:F},{Promise:k}),m(k,D,!1,!0),d(D)},3362:(e,t,r)=>{"use strict";r(436),r(6499),r(2003),r(7743),r(1481),r(280)},7743:(e,t,r)=>{"use strict";var n=r(6518),i=r(9565),o=r(9306),a=r(6043),s=r(1103),u=r(2652);n({target:"Promise",stat:!0,forced:r(537)},{race:function(e){var t=this,r=a.f(t),n=r.reject,c=s((function(){var a=o(t.resolve);u(e,(function(e){i(a,t,e).then(r.resolve,n)}))}));return c.error&&n(c.value),r.promise}})},1481:(e,t,r)=>{"use strict";var n=r(6518),i=r(6043);n({target:"Promise",stat:!0,forced:r(916).CONSTRUCTOR},{reject:function(e){var t=i.f(this);return(0,t.reject)(e),t.promise}})},280:(e,t,r)=>{"use strict";var n=r(6518),i=r(7751),o=r(6395),a=r(550),s=r(916).CONSTRUCTOR,u=r(3438),c=i("Promise"),l=o&&!s;n({target:"Promise",stat:!0,forced:o||s},{resolve:function(e){return u(l&&this===c?a:this,e)}})},4864:(e,t,r)=>{"use strict";var n=r(3724),i=r(4576),o=r(9504),a=r(2796),s=r(3167),u=r(6699),c=r(2360),l=r(8480).f,f=r(1625),p=r(788),m=r(655),d=r(1034),h=r(8429),g=r(1056),y=r(6840),x=r(9039),b=r(9297),v=r(1181).enforce,w=r(7633),N=r(8227),E=r(3635),A=r(8814),S=N("match"),M=i.RegExp,C=M.prototype,T=i.SyntaxError,D=o(C.exec),F=o("".charAt),O=o("".replace),B=o("".indexOf),_=o("".slice),z=/^\?<[^\s\d!#%&*+<=>@^][^\s!#%&*+<=>@^]*>/,I=/a/g,k=/a/g,q=new M(I)!==I,R=h.MISSED_STICKY,P=h.UNSUPPORTED_Y;if(a("RegExp",n&&(!q||R||E||A||x((function(){return k[S]=!1,M(I)!==I||M(k)===k||"/a/i"!==String(M(I,"i"))}))))){for(var j=function(e,t){var r,n,i,o,a,l,h=f(C,this),g=p(e),y=void 0===t,x=[],w=e;if(!h&&g&&y&&e.constructor===j)return e;if((g||f(C,e))&&(e=e.source,y&&(t=d(w))),e=void 0===e?"":m(e),t=void 0===t?"":m(t),w=e,E&&"dotAll"in I&&(n=!!t&&B(t,"s")>-1)&&(t=O(t,/s/g,"")),r=t,R&&"sticky"in I&&(i=!!t&&B(t,"y")>-1)&&P&&(t=O(t,/y/g,"")),A&&(o=function(e){for(var t,r=e.length,n=0,i="",o=[],a=c(null),s=!1,u=!1,l=0,f="";n<=r;n++){if("\\"===(t=F(e,n)))t+=F(e,++n);else if("]"===t)s=!1;else if(!s)switch(!0){case"["===t:s=!0;break;case"("===t:if(i+=t,"?:"===_(e,n+1,n+3))continue;D(z,_(e,n+1))&&(n+=2,u=!0),l++;continue;case">"===t&&u:if(""===f||b(a,f))throw new T("Invalid capture group name");a[f]=!0,o[o.length]=[f,l],u=!1,f="";continue}u?f+=t:i+=t}return[i,o]}(e),e=o[0],x=o[1]),a=s(M(e,t),h?this:C,j),(n||i||x.length)&&(l=v(a),n&&(l.dotAll=!0,l.raw=j(function(e){for(var t,r=e.length,n=0,i="",o=!1;n<=r;n++)"\\"!==(t=F(e,n))?o||"."!==t?("["===t?o=!0:"]"===t&&(o=!1),i+=t):i+="[\\s\\S]":i+=t+F(e,++n);return i}(e),r)),i&&(l.sticky=!0),x.length&&(l.groups=x)),e!==w)try{u(a,"source",""===w?"(?:)":w)}catch(e){}return a},U=l(M),L=0;U.length>L;)g(j,M,U[L++]);C.constructor=j,j.prototype=C,y(i,"RegExp",j,{constructor:!0})}w("RegExp")},7465:(e,t,r)=>{"use strict";var n=r(3724),i=r(3635),o=r(2195),a=r(2106),s=r(1181).get,u=RegExp.prototype,c=TypeError;n&&i&&a(u,"dotAll",{configurable:!0,get:function(){if(this!==u){if("RegExp"===o(this))return!!s(this).dotAll;throw new c("Incompatible receiver, RegExp required")}}})},7495:(e,t,r)=>{"use strict";var n=r(6518),i=r(7323);n({target:"RegExp",proto:!0,forced:/./.exec!==i},{exec:i})},5440:(e,t,r)=>{"use strict";var n=r(8745),i=r(9565),o=r(9504),a=r(9228),s=r(9039),u=r(8551),c=r(4901),l=r(4117),f=r(1291),p=r(8014),m=r(655),d=r(7750),h=r(7829),g=r(5966),y=r(2478),x=r(6682),b=r(8227)("replace"),v=Math.max,w=Math.min,N=o([].concat),E=o([].push),A=o("".indexOf),S=o("".slice),M="$0"==="a".replace(/./,"$0"),C=!!/./[b]&&""===/./[b]("a","$0");a("replace",(function(e,t,r){var o=C?"$":"$0";return[function(e,r){var n=d(this),o=l(e)?void 0:g(e,b);return o?i(o,e,n,r):i(t,m(n),e,r)},function(e,i){var a=u(this),s=m(e);if("string"==typeof i&&-1===A(i,o)&&-1===A(i,"$<")){var l=r(t,a,s,i);if(l.done)return l.value}var d=c(i);d||(i=m(i));var g,b=a.global;b&&(g=a.unicode,a.lastIndex=0);for(var M,C=[];null!==(M=x(a,s))&&(E(C,M),b);)""===m(M[0])&&(a.lastIndex=h(s,p(a.lastIndex),g));for(var T,D="",F=0,O=0;O=F&&(D+=S(s,F,z)+B,F=z+_.length)}return D+S(s,F)}]}),!!s((function(){var e=/./;return e.exec=function(){var e=[];return e.groups={a:"7"},e},"7"!=="".replace(e,"$")}))||!M||C)},9463:(e,t,r)=>{"use strict";var n=r(6518),i=r(3724),o=r(4576),a=r(9504),s=r(9297),u=r(4901),c=r(1625),l=r(655),f=r(2106),p=r(7740),m=o.Symbol,d=m&&m.prototype;if(i&&u(m)&&(!("description"in d)||void 0!==m().description)){var h={},g=function(){var e=arguments.length<1||void 0===arguments[0]?void 0:l(arguments[0]),t=c(d,this)?new m(e):void 0===e?m():m(e);return""===e&&(h[t]=!0),t};p(g,m),g.prototype=d,d.constructor=g;var y="Symbol(description detection)"===String(m("description detection")),x=a(d.valueOf),b=a(d.toString),v=/^Symbol\((.*)\)[^)]+$/,w=a("".replace),N=a("".slice);f(d,"description",{configurable:!0,get:function(){var e=x(this);if(s(h,e))return"";var t=b(e),r=y?N(t,7,-1):w(t,v,"$1");return""===r?void 0:r}}),n({global:!0,constructor:!0,forced:!0},{Symbol:g})}},2369:function(e){e.exports=function(){"use strict";function e(){return!0}function t(){return!1}function r(){}const n="Argument is not a typed-function.";return function i(){function o(e){return"object"==typeof e&&null!==e&&e.constructor===Object}const a=[{name:"number",test:function(e){return"number"==typeof e}},{name:"string",test:function(e){return"string"==typeof e}},{name:"boolean",test:function(e){return"boolean"==typeof e}},{name:"Function",test:function(e){return"function"==typeof e}},{name:"Array",test:Array.isArray},{name:"Date",test:function(e){return e instanceof Date}},{name:"RegExp",test:function(e){return e instanceof RegExp}},{name:"Object",test:o},{name:"null",test:function(e){return null===e}},{name:"undefined",test:function(e){return void 0===e}}],s={name:"any",test:e,isAny:!0};let u,c,l=0,f={createCount:0};function p(e){const t=u.get(e);if(t)return t;let r='Unknown type "'+e+'"';const n=e.toLowerCase();let i;for(i of c)if(i.toLowerCase()===n){r+='. Did you mean "'+i+'" ?';break}throw new TypeError(r)}function m(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"any";const r=t?p(t).index:c.length,n=[];for(let t=0;t{const r=u.get(t);return!r.isAny&&r.test(e)}));return t.length?t:["any"]}function g(e){return e&&"function"==typeof e&&"_typedFunctionData"in e}function y(e,t,r){if(!g(e))throw new TypeError(n);const i=r&&r.exact,o=N(Array.isArray(t)?t.join(","):t),a=x(o);if(!i||a in e.signatures){const t=e._typedFunctionData.signatureMap.get(a);if(t)return t}const s=o.length;let u,c;if(i){let t;for(t in u=[],e.signatures)u.push(e._typedFunctionData.signatureMap.get(t))}else u=e._typedFunctionData.signatures;for(let e=0;e!e.has(t.name))))continue}r.push(n)}}if(u=r,0===u.length)break}for(c of u)if(c.params.length<=s)return c;throw new TypeError("Signature not found (signature: "+(e.name||"unnamed")+"("+x(o,", ")+"))")}function x(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:",";return e.map((e=>e.name)).join(t)}function b(e){const t=0===e.indexOf("..."),r=(t?e.length>3?e.slice(3):"any":e).split("|").map((e=>p(e.trim())));let n=!1,i=t?"...":"";return{types:r.map((function(e){return n=e.isAny||n,i+=e.name+"|",{name:e.name,typeIndex:e.index,test:e.test,isAny:e.isAny,conversion:null,conversionIndex:-1}})),name:i.slice(0,-1),hasAny:n,hasConversion:!1,restParam:t}}function v(e){const t=function(e){if(0===e.length)return[];const t=e.map(p);e.length>1&&t.sort(((e,t)=>e.index-t.index));let r=t[0].conversionsTo;if(1===e.length)return r;r=r.concat([]);const n=new Set(e);for(let e=1;ee.name)));let r=e.hasAny,n=e.name;const i=t.map((function(e){const t=p(e.from);return r=t.isAny||r,n+="|"+e.from,{name:e.from,typeIndex:t.index,test:t.test,isAny:t.isAny,conversion:e,conversionIndex:e.index}}));return{types:e.types.concat(i),name:n,hasAny:r,hasConversion:i.length>0,restParam:e.restParam}}function w(e){return e.typeSet||(e.typeSet=new Set,e.types.forEach((t=>e.typeSet.add(t.name)))),e.typeSet}function N(e){const t=[];if("string"!=typeof e)throw new TypeError("Signatures must be strings");const r=e.trim();if(""===r)return t;const n=r.split(",");for(let e=0;e=r+1}}return 0===e.length?function(e){return 0===e.length}:1===e.length?(r=A(e[0]),function(e){return r(e[0])&&1===e.length}):2===e.length?(r=A(e[0]),n=A(e[1]),function(e){return r(e[0])&&n(e[1])&&2===e.length}):(t=e.map(A),function(e){for(let r=0;r{const n=C(e.params,t);let i;for(i of n)r.add(i)})),r.has("any")?["any"]:Array.from(r)}function F(e,t,r){let n,i;const o=e||"unnamed";let a,s=r;for(a=0;a{const n=A(M(r.params,a));(a0){const e=h(t[a]);return n=new TypeError("Unexpected type of argument in function "+o+" (expected: "+i.join(" or ")+", actual: "+e.join(" | ")+", index: "+a+")"),n.data={category:"wrongType",fn:o,index:a,actual:e,expected:i},n}}else s=e}const u=s.map((function(e){return E(e.params)?1/0:e.params.length}));if(t.lengthc)return n=new TypeError("Too many arguments in function "+o+" (expected: "+c+", actual: "+t.length+")"),n.data={category:"tooManyArgs",fn:o,index:t.length,expectedLength:c},n;const l=[];for(let e=0;e0)return 1;const n=B(e)-B(t);return n<0?-1:n>0?1:0}function z(e,t){const r=e.params,n=t.params,i=H(r),o=H(n),a=E(r),s=E(n);if(a&&i.hasAny){if(!s||!o.hasAny)return 1}else if(s&&o.hasAny)return-1;let u,c=0,l=0;for(u of r)u.hasAny&&++c,u.hasConversion&&++l;let f=0,p=0;for(u of n)u.hasAny&&++f,u.hasConversion&&++p;if(c!==f)return c-f;if(a&&i.hasConversion){if(!s||!o.hasConversion)return 1}else if(s&&o.hasConversion)return-1;if(l!==p)return l-p;if(a){if(!s)return 1}else if(s)return-1;const m=(r.length-n.length)*(a?-1:1);if(0!==m)return m;const d=[];let h,g=0;for(let e=0;ee.hasConversion))){const n=E(e),i=e.map(k);r=function(){const e=[],r=n?arguments.length-1:arguments.length;for(let t=0;te.name)).join("|"),hasAny:e.some((e=>e.isAny)),hasConversion:!1,restParam:!0}),s.push(a)}else s=a.types.map((function(e){return{types:[e],name:e.name,hasAny:e.isAny,hasConversion:e.conversion,restParam:!1}}));return i=s,o=function(i){return e(t,r+1,n.concat([i]))},Array.prototype.concat.apply([],i.map(o))}var i,o;return[n]}(e,0,[])}function R(e,t){const r=Math.max(e.length,t.length);for(let n=0;n=n:a?n>=i:n===i}function P(e,t,r){const n=[];let i;for(i of e){let e=r[i];if("number"!=typeof e)throw new TypeError('No definition for referenced signature "'+i+'"');if(e=t[e],"function"!=typeof e)return!1;n.push(e)}return n}function j(e,t,r){const n=function(e){return e.map((e=>Y(e)?V(e.referToSelf.callback):W(e)?Z(e.referTo.references,e.referTo.callback):e))}(e),i=new Array(n.length).fill(!1);let o=!0;for(;o;){o=!1;let e=!0;for(let a=0;a{const n=e[r];if(t.test(n.toString()))throw new SyntaxError("Using `this` to self-reference a function is deprecated since typed-function@3. Use typed.referTo and typed.referToSelf instead.")}))}(n);const i=[],o=[],a={},s=[];let u;for(u in n){if(!Object.prototype.hasOwnProperty.call(n,u))continue;const e=N(u);if(!e)continue;i.forEach((function(t){if(R(t,e))throw new TypeError('Conflicting signatures "'+x(t)+'" and "'+x(e)+'".')})),i.push(e);const t=o.length;o.push(n[u]);const r=e.map(v);let c;for(c of q(r)){const e=x(c);s.push({params:c,name:e,fn:t}),c.every((e=>!e.hasConversion))&&(a[e]=t)}}s.sort(z);const c=j(o,a,se);let l;for(l in a)Object.prototype.hasOwnProperty.call(a,l)&&(a[l]=c[a[l]]);const p=[],m=new Map;for(l of s)m.has(l.name)||(l.fn=c[l.fn],p.push(l),m.set(l.name,l));const d=p[0]&&p[0].params.length<=2&&!E(p[0].params),h=p[1]&&p[1].params.length<=2&&!E(p[1].params),g=p[2]&&p[2].params.length<=2&&!E(p[2].params),y=p[3]&&p[3].params.length<=2&&!E(p[3].params),b=p[4]&&p[4].params.length<=2&&!E(p[4].params),w=p[5]&&p[5].params.length<=2&&!E(p[5].params),M=d&&h&&g&&y&&b&&w;for(let e=0;ee.test)),oe=p.map((e=>e.implementation)),ae=function(){for(let e=re;ex(N(e)))),t=H(arguments);if("function"!=typeof t)throw new TypeError("Callback function expected as last argument");return Z(e,t)},f.referToSelf=V,f.convert=function(e,t){const r=p(t);if(r.test(e))return e;const n=r.conversionsTo;if(0===n.length)throw new Error("There are no conversions to "+t+" defined.");for(let t=0;t1&&void 0!==arguments[1]?arguments[1]:{override:!1};ee(e);const r=p(e.to),n=r.conversionsTo.find((t=>t.from===e.from));if(n){if(!t||!t.override)throw new Error('There is already a conversion from "'+e.from+'" to "'+r.name+'"');f.removeConversion({from:n.from,to:e.to,convert:n.convert})}r.conversionsTo.push({from:e.from,convert:e.convert,index:l++})},f.addConversions=function(e,t){e.forEach((e=>f.addConversion(e,t)))},f.removeConversion=function(e){ee(e);const t=p(e.to),r=function(e,t){for(let r=0;rt.from===e.from));if(!r)throw new Error("Attempt to remove nonexistent conversion from "+e.from+" to "+e.to);if(r.convert!==e.convert)throw new Error("Conversion to remove does not match existing conversion");const n=t.conversionsTo.indexOf(r);t.conversionsTo.splice(n,1)},f.resolve=function(e,t){if(!g(e))throw new TypeError(n);const r=e._typedFunctionData.signatures;for(let e=0;e{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.nmd=e=>(e.paths=[],e.children||(e.children=[]),e);var n={};return(()=>{"use strict";r.d(n,{default:()=>Py});var e={};r.r(e),r.d(e,{createAbs:()=>fo,createAccessorNode:()=>dp,createAcos:()=>Cl,createAcosh:()=>Zl,createAcot:()=>Wl,createAcoth:()=>Jl,createAcsc:()=>Ql,createAcsch:()=>ef,createAdd:()=>Qf,createAddScalar:()=>yo,createAnd:()=>Ec,createAndTransform:()=>Dy,createApply:()=>mo,createApplyTransform:()=>ey,createArg:()=>Ka,createArrayNode:()=>gp,createAsec:()=>rf,createAsech:()=>of,createAsin:()=>sf,createAsinh:()=>uf,createAssignmentNode:()=>Ep,createAtan:()=>cf,createAtan2:()=>ff,createAtanh:()=>mf,createAtomicMass:()=>Og,createAvogadro:()=>Bg,createBellNumbers:()=>ah,createBigNumberClass:()=>Br,createBigint:()=>Ni,createBignumber:()=>Ci,createBin:()=>zu,createBitAnd:()=>Ga,createBitAndTransform:()=>Oy,createBitNot:()=>Va,createBitOr:()=>Ya,createBitOrTransform:()=>By,createBitXor:()=>Qa,createBlockNode:()=>Sp,createBohrMagneton:()=>fg,createBohrRadius:()=>yg,createBoltzmann:()=>_g,createBoolean:()=>Mi,createCatalan:()=>uh,createCbrt:()=>wo,createCeil:()=>To,createChain:()=>Rm,createChainClass:()=>Om,createClassicalElectronRadius:()=>xg,createClone:()=>Ln,createColumn:()=>hs,createColumnTransform:()=>ty,createCombinations:()=>Ed,createCombinationsWithRep:()=>Md,createCompare:()=>Sc,createCompareNatural:()=>Dc,createCompareText:()=>Bc,createCompile:()=>im,createComplex:()=>Ti,createComplexClass:()=>zr,createComposition:()=>lh,createConcat:()=>ms,createConcatTransform:()=>yy,createConditionalNode:()=>Cp,createConductanceQuantum:()=>pg,createConj:()=>ts,createConstantNode:()=>kp,createCorr:()=>bd,createCos:()=>hf,createCosh:()=>yf,createCot:()=>xf,createCoth:()=>vf,createCoulomb:()=>cg,createCount:()=>ys,createCreateUnit:()=>Sl,createCross:()=>bs,createCsc:()=>wf,createCsch:()=>Ef,createCtranspose:()=>pu,createCube:()=>Fo,createCumSum:()=>ad,createCumSumTransform:()=>Ay,createDeepEqual:()=>Xc,createDenseMatrixClass:()=>jn,createDerivative:()=>Ah,createDet:()=>Pm,createDeuteronMass:()=>Ag,createDiag:()=>ws,createDiff:()=>Rs,createDiffTransform:()=>by,createDistance:()=>rd,createDivide:()=>ed,createDivideScalar:()=>Zu,createDot:()=>np,createDotDivide:()=>oc,createDotMultiply:()=>Ca,createDotPow:()=>nc,createE:()=>$h,createEfimovFactor:()=>Fg,createEigs:()=>$m,createElectricConstant:()=>sg,createElectronMass:()=>bg,createElementaryCharge:()=>lg,createEqual:()=>zc,createEqualScalar:()=>bi,createEqualText:()=>qc,createErf:()=>bu,createEvaluate:()=>am,createExp:()=>Oo,createExpm:()=>Gm,createExpm1:()=>_o,createFactorial:()=>Pd,createFalse:()=>qh,createFaraday:()=>zg,createFermiCoupling:()=>vg,createFft:()=>hu,createFibonacciHeapClass:()=>ll,createFilter:()=>Ns,createFilterTransform:()=>ay,createFineStructure:()=>wg,createFirstRadiation:()=>Ig,createFix:()=>qo,createFlatten:()=>Ss,createFloor:()=>Uo,createForEach:()=>Cs,createForEachTransform:()=>sy,createFormat:()=>_u,createFraction:()=>Di,createFractionClass:()=>Gr,createFreqz:()=>Fh,createFunctionAssignmentNode:()=>Rp,createFunctionNode:()=>em,createGamma:()=>Id,createGasConstant:()=>qg,createGcd:()=>ra,createGetMatrixDataType:()=>Fs,createGravitationConstant:()=>ng,createGravity:()=>Zg,createHartreeEnergy:()=>Ng,createHasNumericValue:()=>ui,createHelp:()=>km,createHelpClass:()=>Fm,createHex:()=>ku,createHypot:()=>ep,createI:()=>Xh,createIdentity:()=>Bs,createIfft:()=>yu,createIm:()=>rs,createImmutableDenseMatrixClass:()=>sl,createIndex:()=>ap,createIndexClass:()=>ul,createIndexNode:()=>jp,createIndexTransform:()=>uy,createInfinity:()=>Ph,createIntersect:()=>nd,createInv:()=>jm,createInverseConductanceQuantum:()=>mg,createInvmod:()=>Aa,createIsInteger:()=>Xn,createIsNaN:()=>di,createIsNegative:()=>ii,createIsNumeric:()=>ai,createIsPositive:()=>li,createIsPrime:()=>$u,createIsZero:()=>pi,createKldivergence:()=>Ud,createKlitzing:()=>gg,createKron:()=>zs,createLN10:()=>Zh,createLN2:()=>Gh,createLOG10E:()=>Wh,createLOG2E:()=>Vh,createLarger:()=>Gc,createLargerEq:()=>Wc,createLcm:()=>ia,createLeafCount:()=>ph,createLeftShift:()=>xc,createLgamma:()=>qd,createLog:()=>Xu,createLog10:()=>aa,createLog1p:()=>Ku,createLog2:()=>ua,createLoschmidt:()=>kg,createLsolve:()=>uc,createLsolveAll:()=>pc,createLup:()=>lm,createLusolve:()=>Cm,createLyap:()=>Km,createMad:()=>fd,createMagneticConstant:()=>ag,createMagneticFluxQuantum:()=>dg,createMap:()=>ks,createMapTransform:()=>cy,createMatrix:()=>Oi,createMatrixClass:()=>Vr,createMatrixFromColumns:()=>qi,createMatrixFromFunction:()=>_i,createMatrixFromRows:()=>Ii,createMax:()=>ol,createMaxTransform:()=>fy,createMean:()=>ud,createMeanTransform:()=>py,createMedian:()=>ld,createMin:()=>al,createMinTransform:()=>my,createMod:()=>Wo,createMode:()=>Tu,createMolarMass:()=>Hg,createMolarMassC12:()=>Gg,createMolarPlanckConstant:()=>Rg,createMolarVolume:()=>Pg,createMultinomial:()=>$d,createMultiply:()=>fa,createMultiplyScalar:()=>ca,createNaN:()=>jh,createNeutronMass:()=>Sg,createNode:()=>up,createNorm:()=>rp,createNot:()=>cs,createNthRoot:()=>ma,createNthRoots:()=>tc,createNuclearMagneton:()=>hg,createNull:()=>Rh,createNumber:()=>wi,createNumeric:()=>Hu,createObjectNode:()=>Lp,createOct:()=>Iu,createOnes:()=>Ps,createOperatorNode:()=>Gp,createOr:()=>ls,createOrTransform:()=>Fy,createParenthesisNode:()=>Vp,createParse:()=>rm,createParser:()=>cm,createParserClass:()=>sm,createPartitionSelect:()=>rl,createPermutations:()=>Gd,createPhi:()=>Hh,createPi:()=>Uh,createPickRandom:()=>Xd,createPinv:()=>Lm,createPlanckCharge:()=>Jg,createPlanckConstant:()=>ig,createPlanckLength:()=>Vg,createPlanckMass:()=>Wg,createPlanckTemperature:()=>Xg,createPlanckTime:()=>Yg,createPolynomialRoot:()=>Dm,createPow:()=>Vu,createPrint:()=>Pu,createPrintTransform:()=>Ty,createProd:()=>Ou,createProtonMass:()=>Eg,createQr:()=>fm,createQuantileSeq:()=>gd,createQuantileSeqTransform:()=>Ny,createQuantumOfCirculation:()=>Mg,createRandom:()=>eh,createRandomInt:()=>rh,createRange:()=>Hs,createRangeClass:()=>Zr,createRangeNode:()=>Yp,createRangeTransform:()=>dy,createRationalize:()=>Mh,createRe:()=>ns,createReducedPlanckConstant:()=>og,createRelationalNode:()=>Xp,createReplacer:()=>Bh,createReshape:()=>Zs,createResize:()=>Vs,createResolve:()=>vh,createResultSet:()=>Ve,createReviver:()=>Oh,createRightArithShift:()=>vc,createRightLogShift:()=>Nc,createRotate:()=>Ys,createRotationMatrix:()=>Xs,createRound:()=>Ju,createRow:()=>Qs,createRowTransform:()=>hy,createRydberg:()=>Cg,createSQRT1_2:()=>Yh,createSQRT2:()=>Jh,createSackurTetrode:()=>jg,createSchur:()=>Xm,createSec:()=>Af,createSech:()=>Mf,createSecondRadiation:()=>Ug,createSetCartesian:()=>_f,createSetDifference:()=>If,createSetDistinct:()=>qf,createSetIntersect:()=>Pf,createSetIsSubset:()=>Uf,createSetMultiplicity:()=>$f,createSetPowerset:()=>Gf,createSetSize:()=>Vf,createSetSymDifference:()=>Yf,createSetUnion:()=>Xf,createSign:()=>ha,createSimplify:()=>gh,createSimplifyConstant:()=>yh,createSimplifyCore:()=>bh,createSin:()=>Cf,createSinh:()=>Df,createSize:()=>eu,createSlu:()=>Am,createSmaller:()=>Pc,createSmallerEq:()=>Lc,createSolveODE:()=>xu,createSort:()=>il,createSpaClass:()=>fl,createSparse:()=>El,createSparseMatrixClass:()=>vi,createSpeedOfLight:()=>rg,createSplitUnit:()=>Pi,createSqrt:()=>ga,createSqrtm:()=>Vm,createSquare:()=>xa,createSqueeze:()=>ru,createStd:()=>yd,createStdTransform:()=>vy,createStefanBoltzmann:()=>Lg,createStirlingS2:()=>ih,createString:()=>Ai,createSubset:()=>iu,createSubsetTransform:()=>gy,createSubtract:()=>va,createSubtractScalar:()=>bo,createSum:()=>id,createSumTransform:()=>wy,createSylvester:()=>Ym,createSymbolNode:()=>Qp,createSymbolicEqual:()=>Nh,createTan:()=>Ff,createTanh:()=>Of,createTau:()=>Lh,createThomsonCrossSection:()=>Tg,createTo:()=>Uu,createTrace:()=>ip,createTranspose:()=>lu,createTrue:()=>kh,createTypeOf:()=>gi,createTyped:()=>$e,createUnaryMinus:()=>uo,createUnaryPlus:()=>lo,createUnequal:()=>Kc,createUnitClass:()=>bl,createUnitFunction:()=>wl,createUppercaseE:()=>Kh,createUppercasePi:()=>Qh,createUsolve:()=>lc,createUsolveAll:()=>dc,createVacuumImpedance:()=>ug,createVariance:()=>dd,createVarianceTransform:()=>My,createVersion:()=>eg,createWeakMixingAngle:()=>Dg,createWienDisplacement:()=>$g,createXgcd:()=>Na,createXor:()=>fs,createZeros:()=>du,createZeta:()=>Mu,createZpk2tf:()=>Th}),r(4423),r(7495);var t=r(2369);function i(e,t){if(a(e,t))return e[t];if("function"==typeof e[t]&&s(e,t))throw new Error('Cannot access method "'+t+'" as a property');throw new Error('No access to property "'+t+'"')}function o(e,t,r){if(a(e,t))return e[t]=r,r;throw new Error('No access to property "'+t+'"')}function a(e,t){return!(!function(e){return"object"==typeof e&&e&&e.constructor===Object}(e)&&!Array.isArray(e)||!me(u,t)&&(t in Object.prototype||t in Function.prototype))}function s(e,t){return!(null==e||"function"!=typeof e[t]||me(e,t)&&Object.getPrototypeOf&&t in Object.getPrototypeOf(e)||!me(c,t)&&(t in Object.prototype||t in Function.prototype))}r(6910),r(4864),r(7465);const u={length:!0,name:!0},c={toString:!0,valueOf:!0,toLocaleString:!0};class l{constructor(e){this.wrappedObject=e,this[Symbol.iterator]=this.entries}keys(){return Object.keys(this.wrappedObject).filter((e=>this.has(e))).values()}get(e){return i(this.wrappedObject,e)}set(e,t){return o(this.wrappedObject,e,t),this}has(e){return a(this.wrappedObject,e)&&e in this.wrappedObject}entries(){return p(this.keys(),(e=>[e,this.get(e)]))}forEach(e){for(const t of this.keys())e(this.get(t),t,this)}delete(e){a(this.wrappedObject,e)&&delete this.wrappedObject[e]}clear(){for(const e of this.keys())this.delete(e)}get size(){return Object.keys(this.wrappedObject).length}}class f{constructor(e,t,r){this.a=e,this.b=t,this.bKeys=r,this[Symbol.iterator]=this.entries}get(e){return this.bKeys.has(e)?this.b.get(e):this.a.get(e)}set(e,t){return this.bKeys.has(e)?this.b.set(e,t):this.a.set(e,t),this}has(e){return this.b.has(e)||this.a.has(e)}keys(){return new Set([...this.a.keys(),...this.b.keys()])[Symbol.iterator]()}entries(){return p(this.keys(),(e=>[e,this.get(e)]))}forEach(e){for(const t of this.keys())e(this.get(t),t,this)}delete(e){return this.bKeys.has(e)?this.b.delete(e):this.a.delete(e)}clear(){this.a.clear(),this.b.clear()}get size(){return[...this.keys()].length}}function p(e,t){return{next:()=>{const r=e.next();return r.done?r:{value:t(r.value),done:!1}}}}function m(){return new Map}function d(e){if(!e)return m();if(k(e))return e;if(I(e))return new l(e);throw new Error("createMap can create maps from objects or Maps")}function h(e){return"number"==typeof e}function g(e){return!(!e||"object"!=typeof e||"function"!=typeof e.constructor)&&(!0===e.isBigNumber&&"object"==typeof e.constructor.prototype&&!0===e.constructor.prototype.isBigNumber||"function"==typeof e.constructor.isDecimal&&!0===e.constructor.isDecimal(e))}function y(e){return"bigint"==typeof e}function x(e){return e&&"object"==typeof e&&!0===Object.getPrototypeOf(e).isComplex||!1}function b(e){return e&&"object"==typeof e&&!0===Object.getPrototypeOf(e).isFraction||!1}function v(e){return e&&!0===e.constructor.prototype.isUnit||!1}function w(e){return"string"==typeof e}const N=Array.isArray;function E(e){return e&&!0===e.constructor.prototype.isMatrix||!1}function A(e){return Array.isArray(e)||E(e)}function S(e){return e&&e.isDenseMatrix&&!0===e.constructor.prototype.isMatrix||!1}function M(e){return e&&e.isSparseMatrix&&!0===e.constructor.prototype.isMatrix||!1}function C(e){return e&&!0===e.constructor.prototype.isRange||!1}function T(e){return e&&!0===e.constructor.prototype.isIndex||!1}function D(e){return"boolean"==typeof e}function F(e){return e&&!0===e.constructor.prototype.isResultSet||!1}function O(e){return e&&!0===e.constructor.prototype.isHelp||!1}function B(e){return"function"==typeof e}function _(e){return e instanceof Date}function z(e){return e instanceof RegExp}function I(e){return!(!e||"object"!=typeof e||e.constructor!==Object||x(e)||b(e))}function k(e){return!!e&&(e instanceof Map||e instanceof l||"function"==typeof e.set&&"function"==typeof e.get&&"function"==typeof e.keys&&"function"==typeof e.has)}function q(e){return k(e)&&k(e.a)&&k(e.b)}function R(e){return k(e)&&I(e.wrappedObject)}function P(e){return null===e}function j(e){return void 0===e}function U(e){return e&&!0===e.isAccessorNode&&!0===e.constructor.prototype.isNode||!1}function L(e){return e&&!0===e.isArrayNode&&!0===e.constructor.prototype.isNode||!1}function $(e){return e&&!0===e.isAssignmentNode&&!0===e.constructor.prototype.isNode||!1}function H(e){return e&&!0===e.isBlockNode&&!0===e.constructor.prototype.isNode||!1}function G(e){return e&&!0===e.isConditionalNode&&!0===e.constructor.prototype.isNode||!1}function Z(e){return e&&!0===e.isConstantNode&&!0===e.constructor.prototype.isNode||!1}function V(e){return Z(e)||K(e)&&1===e.args.length&&Z(e.args[0])&&"-+~".includes(e.op)}function W(e){return e&&!0===e.isFunctionAssignmentNode&&!0===e.constructor.prototype.isNode||!1}function Y(e){return e&&!0===e.isFunctionNode&&!0===e.constructor.prototype.isNode||!1}function J(e){return e&&!0===e.isIndexNode&&!0===e.constructor.prototype.isNode||!1}function X(e){return e&&!0===e.isNode&&!0===e.constructor.prototype.isNode||!1}function Q(e){return e&&!0===e.isObjectNode&&!0===e.constructor.prototype.isNode||!1}function K(e){return e&&!0===e.isOperatorNode&&!0===e.constructor.prototype.isNode||!1}function ee(e){return e&&!0===e.isParenthesisNode&&!0===e.constructor.prototype.isNode||!1}function te(e){return e&&!0===e.isRangeNode&&!0===e.constructor.prototype.isNode||!1}function re(e){return e&&!0===e.isRelationalNode&&!0===e.constructor.prototype.isNode||!1}function ne(e){return e&&!0===e.isSymbolNode&&!0===e.constructor.prototype.isNode||!1}function ie(e){return e&&!0===e.constructor.prototype.isChain||!1}function oe(e){const t=typeof e;return"object"===t?null===e?"null":g(e)?"BigNumber":e.constructor&&e.constructor.name?e.constructor.name:"Object":t}function ae(e){const t=typeof e;if("number"===t||"bigint"===t||"string"===t||"boolean"===t||null==e)return e;if("function"==typeof e.clone)return e.clone();if(Array.isArray(e))return e.map((function(e){return ae(e)}));if(e instanceof Date)return new Date(e.valueOf());if(g(e))return e;if(I(e))return function(e,t){const r={};for(const n in e)me(e,n)&&(r[n]=t(e[n]));return r}(e,ae);throw new TypeError(`Cannot clone: unknown type of value (value: ${e})`)}function se(e,t){for(const r in t)me(t,r)&&(e[r]=t[r]);return e}function ue(e,t){if(Array.isArray(t))throw new TypeError("Arrays are not supported by deepExtend");for(const r in t)if(me(t,r)&&!(r in Object.prototype)&&!(r in Function.prototype))if(t[r]&&t[r].constructor===Object)void 0===e[r]&&(e[r]={}),e[r]&&e[r].constructor===Object?ue(e[r],t[r]):e[r]=t[r];else{if(Array.isArray(t[r]))throw new TypeError("Arrays are not supported by deepExtend");e[r]=t[r]}return e}function ce(e,t){let r,n,i;if(Array.isArray(e)){if(!Array.isArray(t))return!1;if(e.length!==t.length)return!1;for(n=0,i=e.length;n!function(e){return e&&"?"===e[0]}(e))).every((e=>void 0!==r[e]))){const n=t.filter((e=>void 0===r[e]));throw new Error(`Cannot create function "${e}", some dependencies are missing: ${n.map((e=>`"${e}"`)).join(", ")}.`)}}(e,t,n),r(i)}return i.isFactory=!0,i.fn=e,i.dependencies=t.slice().sort(),n&&(i.meta=n),i}function he(e){return"function"==typeof e&&"string"==typeof e.fn&&Array.isArray(e.dependencies)}function ge(e){return e&&"?"===e[0]?e.slice(1):e}function ye(e){return"boolean"==typeof e||!!isFinite(e)&&e===Math.round(e)}function xe(e,t){return"bigint"!==t.number||/^-?\d+$/.test(e)?t.number:t.numberFallback}r(5440);const be=Math.sign||function(e){return e>0?1:e<0?-1:0},ve=Math.log2||function(e){return Math.log(e)/Math.LN2},we=Math.log10||function(e){return Math.log(e)/Math.LN10},Ne=Math.log1p||function(e){return Math.log(e+1)},Ee=Math.cbrt||function(e){if(0===e)return e;const t=e<0;let r;return t&&(e=-e),isFinite(e)?(r=Math.exp(Math.log(e)/3),r=(e/(r*r)+2*r)/3):r=e,t?-r:r},Ae=Math.expm1||function(e){return e>=2e-4||e<=-2e-4?Math.exp(e)-1:e+e*e/2+e*e*e/6};function Se(e,t,r){const n={2:"0b",8:"0o",16:"0x"}[t];let i="";if(r){if(r<1)throw new Error("size must be in greater than 0");if(!ye(r))throw new Error("size must be an integer");if(e>2**(r-1)-1||e<-(2**(r-1)))throw new Error(`Value must be in range [-2^${r-1}, 2^${r-1}-1]`);if(!ye(e))throw new Error("Value must be an integer");e<0&&(e+=2**r),i=`i${r}`}let o="";return e<0&&(e=-e,o="-"),`${o}${n}${e.toString(t)}${i}`}function Me(e,t){if("function"==typeof t)return t(e);if(e===1/0)return"Infinity";if(e===-1/0)return"-Infinity";if(isNaN(e))return"NaN";const{notation:r,precision:n,wordSize:i}=Ce(t);switch(r){case"fixed":return De(e,n);case"exponential":return Fe(e,n);case"engineering":return function(e,t){if(isNaN(e)||!isFinite(e))return String(e);const r=Oe(Te(e),t),n=r.exponent,i=r.coefficients,o=n%3==0?n:n<0?n-3-n%3:n-n%3;if(h(t))for(;t>i.length||n-o+1>i.length;)i.push(0);else{const e=Math.abs(n-o)-(i.length-1);for(let t=0;t0;)s++,a--;const u=i.slice(s).join(""),c=h(t)&&u.length||u.match(/[1-9]/)?"."+u:"",l=i.slice(0,s).join("")+c+"e"+(n>=0?"+":"")+o.toString();return r.sign+l}(e,n);case"bin":return Se(e,2,i);case"oct":return Se(e,8,i);case"hex":return Se(e,16,i);case"auto":return function(e,t,r){if(isNaN(e)||!isFinite(e))return String(e);const n=Ue(null==r?void 0:r.lowerExp,-3),i=Ue(null==r?void 0:r.upperExp,5),o=Te(e),a=t?Oe(o,t):o;if(a.exponent=i)return Fe(e,t);{let e=a.coefficients;const r=a.exponent;e.length0?r:0;return n{throw new Error('Option "precision" must be a number or BigNumber')}))),void 0!==e.wordSize&&(r=je(e.wordSize,(()=>{throw new Error('Option "wordSize" must be a number or BigNumber')}))),e.notation&&(n=e.notation)}return{notation:n,precision:t,wordSize:r}}function Te(e){const t=String(e).toLowerCase().match(/^(-?)(\d+\.?\d*)(e([+-]?\d+))?$/);if(!t)throw new SyntaxError("Invalid number "+e);const r=t[1],n=t[2];let i=parseFloat(t[4]||"0");const o=n.indexOf(".");i+=-1!==o?o-1:n.length-1;const a=n.replace(".","").replace(/^0*/,(function(e){return i-=e.length,""})).replace(/0*$/,"").split("").map((function(e){return parseInt(e)}));return 0===a.length&&(a.push(0),i++),{sign:r,coefficients:a,exponent:i}}function De(e,t){if(isNaN(e)||!isFinite(e))return String(e);const r=Te(e),n="number"==typeof t?Oe(r,r.exponent+1+t):r;let i=n.coefficients,o=n.exponent+1;const a=o+(t||0);return i.length0?"."+i.join(""):"")+"e"+(o>=0?"+":"")+o}function Oe(e,t){const r={sign:e.sign,coefficients:e.coefficients,exponent:e.exponent},n=r.coefficients;for(;t<=0;)n.unshift(0),r.exponent++,t++;if(n.length>t&&n.splice(t,n.length-t)[0]>=5){let e=t-1;for(n[e]++;10===n[e];)n.pop(),0===e&&(n.unshift(0),r.exponent++,e++),e--,n[e]++}return r}function Be(e){const t=[];for(let r=0;r2&&void 0!==arguments[2]?arguments[2]:1e-8,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0;if(r<=0)throw new Error("Relative tolerance must be greater than 0");if(n<0)throw new Error("Absolute tolerance must be at least 0");return!isNaN(e)&&!isNaN(t)&&(isFinite(e)&&isFinite(t)?e===t||Math.abs(e-t)<=Math.max(r*Math.max(Math.abs(e),Math.abs(t)),n):e===t)}Number.EPSILON;const ze=Math.acosh||function(e){return Math.log(Math.sqrt(e*e-1)+e)},Ie=Math.asinh||function(e){return Math.log(Math.sqrt(e*e+1)+e)},ke=Math.atanh||function(e){return Math.log((1+e)/(1-e))/2},qe=Math.cosh||function(e){return(Math.exp(e)+Math.exp(-e))/2},Re=Math.sinh||function(e){return(Math.exp(e)-Math.exp(-e))/2},Pe=Math.tanh||function(e){const t=Math.exp(2*e);return(t-1)/(t+1)};function je(e,t){return h(e)?e:g(e)?e.toNumber():void t()}function Ue(e,t){return h(e)?e:g(e)?e.toNumber():t}let Le=function(){return Le=t.create,t};const $e=de("typed",["?BigNumber","?Complex","?DenseMatrix","?Fraction"],(function(e){let{BigNumber:t,Complex:r,DenseMatrix:n,Fraction:i}=e;const o=Le();return o.clear(),o.addTypes([{name:"number",test:h},{name:"Complex",test:x},{name:"BigNumber",test:g},{name:"bigint",test:y},{name:"Fraction",test:b},{name:"Unit",test:v},{name:"identifier",test:e=>w&&/^[A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}][0-9A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}]*$/u.test(e)},{name:"string",test:w},{name:"Chain",test:ie},{name:"Array",test:N},{name:"Matrix",test:E},{name:"DenseMatrix",test:S},{name:"SparseMatrix",test:M},{name:"Range",test:C},{name:"Index",test:T},{name:"boolean",test:D},{name:"ResultSet",test:F},{name:"Help",test:O},{name:"function",test:B},{name:"Date",test:_},{name:"RegExp",test:z},{name:"null",test:P},{name:"undefined",test:j},{name:"AccessorNode",test:U},{name:"ArrayNode",test:L},{name:"AssignmentNode",test:$},{name:"BlockNode",test:H},{name:"ConditionalNode",test:G},{name:"ConstantNode",test:Z},{name:"FunctionNode",test:Y},{name:"FunctionAssignmentNode",test:W},{name:"IndexNode",test:J},{name:"Node",test:X},{name:"ObjectNode",test:Q},{name:"OperatorNode",test:K},{name:"ParenthesisNode",test:ee},{name:"RangeNode",test:te},{name:"RelationalNode",test:re},{name:"SymbolNode",test:ne},{name:"Map",test:k},{name:"Object",test:I}]),o.addConversions([{from:"number",to:"BigNumber",convert:function(e){if(t||He(e),e.toExponential().replace(/e.*$/,"").replace(/^0\.?0*|\./,"").length>15)throw new TypeError("Cannot implicitly convert a number with >15 significant digits to BigNumber (value: "+e+"). Use function bignumber(x) to convert to BigNumber.");return new t(e)}},{from:"number",to:"Complex",convert:function(e){return r||Ge(e),new r(e,0)}},{from:"BigNumber",to:"Complex",convert:function(e){return r||Ge(e),new r(e.toNumber(),0)}},{from:"bigint",to:"number",convert:function(e){if(e>Number.MAX_SAFE_INTEGER)throw new TypeError("Cannot implicitly convert bigint to number: value exceeds the max safe integer value (value: "+e+")");return Number(e)}},{from:"bigint",to:"BigNumber",convert:function(e){return t||He(e),new t(e.toString())}},{from:"bigint",to:"Fraction",convert:function(e){return i||Ze(e),new i(e.toString())}},{from:"Fraction",to:"BigNumber",convert:function(e){throw new TypeError("Cannot implicitly convert a Fraction to BigNumber or vice versa. Use function bignumber(x) to convert to BigNumber or fraction(x) to convert to Fraction.")}},{from:"Fraction",to:"Complex",convert:function(e){return r||Ge(e),new r(e.valueOf(),0)}},{from:"number",to:"Fraction",convert:function(e){i||Ze(e);const t=new i(e);if(t.valueOf()!==e)throw new TypeError("Cannot implicitly convert a number to a Fraction when there will be a loss of precision (value: "+e+"). Use function fraction(x) to convert to Fraction.");return t}},{from:"string",to:"number",convert:function(e){const t=Number(e);if(isNaN(t))throw new Error('Cannot convert "'+e+'" to a number');return t}},{from:"string",to:"BigNumber",convert:function(e){t||He(e);try{return new t(e)}catch(t){throw new Error('Cannot convert "'+e+'" to BigNumber')}}},{from:"string",to:"bigint",convert:function(e){try{return BigInt(e)}catch(t){throw new Error('Cannot convert "'+e+'" to BigInt')}}},{from:"string",to:"Fraction",convert:function(e){i||Ze(e);try{return new i(e)}catch(t){throw new Error('Cannot convert "'+e+'" to Fraction')}}},{from:"string",to:"Complex",convert:function(e){r||Ge(e);try{return new r(e)}catch(t){throw new Error('Cannot convert "'+e+'" to Complex')}}},{from:"boolean",to:"number",convert:function(e){return+e}},{from:"boolean",to:"BigNumber",convert:function(e){return t||He(e),new t(+e)}},{from:"boolean",to:"bigint",convert:function(e){return BigInt(+e)}},{from:"boolean",to:"Fraction",convert:function(e){return i||Ze(e),new i(+e)}},{from:"boolean",to:"string",convert:function(e){return String(e)}},{from:"Array",to:"Matrix",convert:function(e){return n||function(){throw new Error("Cannot convert array into a Matrix: no class 'DenseMatrix' provided")}(),new n(e)}},{from:"Matrix",to:"Array",convert:function(e){return e.valueOf()}}]),o.onMismatch=(e,t,r)=>{const n=o.createError(e,t,r);if(["wrongType","mismatch"].includes(n.data.category)&&1===t.length&&A(t[0])&&r.some((e=>!e.params.includes(",")))){const t=new TypeError(`Function '${e}' doesn't apply to matrices. To call it elementwise on a matrix 'M', try 'map(M, ${e})'.`);throw t.data=n.data,t}throw n},o.onMismatch=(e,t,r)=>{const n=o.createError(e,t,r);if(["wrongType","mismatch"].includes(n.data.category)&&1===t.length&&A(t[0])&&r.some((e=>!e.params.includes(",")))){const t=new TypeError(`Function '${e}' doesn't apply to matrices. To call it elementwise on a matrix 'M', try 'map(M, ${e})'.`);throw t.data=n.data,t}throw n},o}));function He(e){throw new Error(`Cannot convert value ${e} into a BigNumber: no class 'BigNumber' provided`)}function Ge(e){throw new Error(`Cannot convert value ${e} into a Complex number: no class 'Complex' provided`)}function Ze(e){throw new Error(`Cannot convert value ${e} into a Fraction, no class 'Fraction' provided.`)}const Ve=de("ResultSet",[],(()=>{function e(t){if(!(this instanceof e))throw new SyntaxError("Constructor must be called with the new operator");this.entries=t||[]}return e.prototype.type="ResultSet",e.prototype.isResultSet=!0,e.prototype.valueOf=function(){return this.entries},e.prototype.toString=function(){return"["+this.entries.join(", ")+"]"},e.prototype.toJSON=function(){return{mathjs:"ResultSet",entries:this.entries}},e.fromJSON=function(t){return new e(t.entries)},e}),{isClass:!0});var We,Ye,Je=9e15,Xe=1e9,Qe="0123456789abcdef",Ke="2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058",et="3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789",tt={precision:20,rounding:4,modulo:1,toExpNeg:-7,toExpPos:21,minE:-Je,maxE:Je,crypto:!1},rt=!0,nt="[DecimalError] ",it=nt+"Invalid argument: ",ot=nt+"Precision limit exceeded",at=nt+"crypto unavailable",st="[object Decimal]",ut=Math.floor,ct=Math.pow,lt=/^0b([01]+(\.[01]*)?|\.[01]+)(p[+-]?\d+)?$/i,ft=/^0x([0-9a-f]+(\.[0-9a-f]*)?|\.[0-9a-f]+)(p[+-]?\d+)?$/i,pt=/^0o([0-7]+(\.[0-7]*)?|\.[0-7]+)(p[+-]?\d+)?$/i,mt=/^(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,dt=1e7,ht=7,gt=Ke.length-1,yt=et.length-1,xt={toStringTag:st};function bt(e){var t,r,n,i=e.length-1,o="",a=e[0];if(i>0){for(o+=a,t=1;tr)throw Error(it+e)}function wt(e,t,r,n){var i,o,a,s;for(o=e[0];o>=10;o/=10)--t;return--t<0?(t+=ht,i=0):(i=Math.ceil((t+1)/ht),t%=ht),o=ct(10,ht-t),s=e[i]%o|0,null==n?t<3?(0==t?s=s/100|0:1==t&&(s=s/10|0),a=r<4&&99999==s||r>3&&49999==s||5e4==s||0==s):a=(r<4&&s+1==o||r>3&&s+1==o/2)&&(e[i+1]/o/100|0)==ct(10,t-2)-1||(s==o/2||0==s)&&!(e[i+1]/o/100|0):t<4?(0==t?s=s/1e3|0:1==t?s=s/100|0:2==t&&(s=s/10|0),a=(n||r<4)&&9999==s||!n&&r>3&&4999==s):a=((n||r<4)&&s+1==o||!n&&r>3&&s+1==o/2)&&(e[i+1]/o/1e3|0)==ct(10,t-3)-1,a}function Nt(e,t,r){for(var n,i,o=[0],a=0,s=e.length;ar-1&&(void 0===o[n+1]&&(o[n+1]=0),o[n+1]+=o[n]/r|0,o[n]%=r)}return o.reverse()}xt.absoluteValue=xt.abs=function(){var e=new this.constructor(this);return e.s<0&&(e.s=1),At(e)},xt.ceil=function(){return At(new this.constructor(this),this.e+1,2)},xt.clampedTo=xt.clamp=function(e,t){var r=this,n=r.constructor;if(e=new n(e),t=new n(t),!e.s||!t.s)return new n(NaN);if(e.gt(t))throw Error(it+t);return r.cmp(e)<0?e:r.cmp(t)>0?t:new n(r)},xt.comparedTo=xt.cmp=function(e){var t,r,n,i,o=this,a=o.d,s=(e=new o.constructor(e)).d,u=o.s,c=e.s;if(!a||!s)return u&&c?u!==c?u:a===s?0:!a^u<0?1:-1:NaN;if(!a[0]||!s[0])return a[0]?u:s[0]?-c:0;if(u!==c)return u;if(o.e!==e.e)return o.e>e.e^u<0?1:-1;for(t=0,r=(n=a.length)<(i=s.length)?n:i;ts[t]^u<0?1:-1;return n===i?0:n>i^u<0?1:-1},xt.cosine=xt.cos=function(){var e,t,r=this,n=r.constructor;return r.d?r.d[0]?(e=n.precision,t=n.rounding,n.precision=e+Math.max(r.e,r.sd())+ht,n.rounding=1,r=function(e,t){var r,n,i;if(t.isZero())return t;(n=t.d.length)<32?i=(1/jt(4,r=Math.ceil(n/3))).toString():(r=16,i="2.3283064365386962890625e-10"),e.precision+=r,t=Pt(e,1,t.times(i),new e(1));for(var o=r;o--;){var a=t.times(t);t=a.times(a).minus(a).times(8).plus(1)}return e.precision-=r,t}(n,Ut(n,r)),n.precision=e,n.rounding=t,At(2==Ye||3==Ye?r.neg():r,e,t,!0)):new n(1):new n(NaN)},xt.cubeRoot=xt.cbrt=function(){var e,t,r,n,i,o,a,s,u,c,l=this,f=l.constructor;if(!l.isFinite()||l.isZero())return new f(l);for(rt=!1,(o=l.s*ct(l.s*l,1/3))&&Math.abs(o)!=1/0?n=new f(o.toString()):(r=bt(l.d),(o=((e=l.e)-r.length+1)%3)&&(r+=1==o||-2==o?"0":"00"),o=ct(r,1/3),e=ut((e+1)/3)-(e%3==(e<0?-1:2)),(n=new f(r=o==1/0?"5e"+e:(r=o.toExponential()).slice(0,r.indexOf("e")+1)+e)).s=l.s),a=(e=f.precision)+3;;)if(c=(u=(s=n).times(s).times(s)).plus(l),n=Et(c.plus(l).times(s),c.plus(u),a+2,1),bt(s.d).slice(0,a)===(r=bt(n.d)).slice(0,a)){if("9999"!=(r=r.slice(a-3,a+1))&&(i||"4999"!=r)){+r&&(+r.slice(1)||"5"!=r.charAt(0))||(At(n,e+1,1),t=!n.times(n).times(n).eq(l));break}if(!i&&(At(s,e+1,0),s.times(s).times(s).eq(l))){n=s;break}a+=4,i=1}return rt=!0,At(n,e,f.rounding,t)},xt.decimalPlaces=xt.dp=function(){var e,t=this.d,r=NaN;if(t){if(r=((e=t.length-1)-ut(this.e/ht))*ht,e=t[e])for(;e%10==0;e/=10)r--;r<0&&(r=0)}return r},xt.dividedBy=xt.div=function(e){return Et(this,new this.constructor(e))},xt.dividedToIntegerBy=xt.divToInt=function(e){var t=this.constructor;return At(Et(this,new t(e),0,1,1),t.precision,t.rounding)},xt.equals=xt.eq=function(e){return 0===this.cmp(e)},xt.floor=function(){return At(new this.constructor(this),this.e+1,3)},xt.greaterThan=xt.gt=function(e){return this.cmp(e)>0},xt.greaterThanOrEqualTo=xt.gte=function(e){var t=this.cmp(e);return 1==t||0===t},xt.hyperbolicCosine=xt.cosh=function(){var e,t,r,n,i,o=this,a=o.constructor,s=new a(1);if(!o.isFinite())return new a(o.s?1/0:NaN);if(o.isZero())return s;r=a.precision,n=a.rounding,a.precision=r+Math.max(o.e,o.sd())+4,a.rounding=1,(i=o.d.length)<32?t=(1/jt(4,e=Math.ceil(i/3))).toString():(e=16,t="2.3283064365386962890625e-10"),o=Pt(a,1,o.times(t),new a(1),!0);for(var u,c=e,l=new a(8);c--;)u=o.times(o),o=s.minus(u.times(l.minus(u.times(l))));return At(o,a.precision=r,a.rounding=n,!0)},xt.hyperbolicSine=xt.sinh=function(){var e,t,r,n,i=this,o=i.constructor;if(!i.isFinite()||i.isZero())return new o(i);if(t=o.precision,r=o.rounding,o.precision=t+Math.max(i.e,i.sd())+4,o.rounding=1,(n=i.d.length)<3)i=Pt(o,2,i,i,!0);else{e=(e=1.4*Math.sqrt(n))>16?16:0|e,i=Pt(o,2,i=i.times(1/jt(5,e)),i,!0);for(var a,s=new o(5),u=new o(16),c=new o(20);e--;)a=i.times(i),i=i.times(s.plus(a.times(u.times(a).plus(c))))}return o.precision=t,o.rounding=r,At(i,t,r,!0)},xt.hyperbolicTangent=xt.tanh=function(){var e,t,r=this,n=r.constructor;return r.isFinite()?r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+7,n.rounding=1,Et(r.sinh(),r.cosh(),n.precision=e,n.rounding=t)):new n(r.s)},xt.inverseCosine=xt.acos=function(){var e,t=this,r=t.constructor,n=t.abs().cmp(1),i=r.precision,o=r.rounding;return-1!==n?0===n?t.isNeg()?Tt(r,i,o):new r(0):new r(NaN):t.isZero()?Tt(r,i+4,o).times(.5):(r.precision=i+6,r.rounding=1,t=t.asin(),e=Tt(r,i+4,o).times(.5),r.precision=i,r.rounding=o,e.minus(t))},xt.inverseHyperbolicCosine=xt.acosh=function(){var e,t,r=this,n=r.constructor;return r.lte(1)?new n(r.eq(1)?0:NaN):r.isFinite()?(e=n.precision,t=n.rounding,n.precision=e+Math.max(Math.abs(r.e),r.sd())+4,n.rounding=1,rt=!1,r=r.times(r).minus(1).sqrt().plus(r),rt=!0,n.precision=e,n.rounding=t,r.ln()):new n(r)},xt.inverseHyperbolicSine=xt.asinh=function(){var e,t,r=this,n=r.constructor;return!r.isFinite()||r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+2*Math.max(Math.abs(r.e),r.sd())+6,n.rounding=1,rt=!1,r=r.times(r).plus(1).sqrt().plus(r),rt=!0,n.precision=e,n.rounding=t,r.ln())},xt.inverseHyperbolicTangent=xt.atanh=function(){var e,t,r,n,i=this,o=i.constructor;return i.isFinite()?i.e>=0?new o(i.abs().eq(1)?i.s/0:i.isZero()?i:NaN):(e=o.precision,t=o.rounding,n=i.sd(),Math.max(n,e)<2*-i.e-1?At(new o(i),e,t,!0):(o.precision=r=n-i.e,i=Et(i.plus(1),new o(1).minus(i),r+e,1),o.precision=e+4,o.rounding=1,i=i.ln(),o.precision=e,o.rounding=t,i.times(.5))):new o(NaN)},xt.inverseSine=xt.asin=function(){var e,t,r,n,i=this,o=i.constructor;return i.isZero()?new o(i):(t=i.abs().cmp(1),r=o.precision,n=o.rounding,-1!==t?0===t?((e=Tt(o,r+4,n).times(.5)).s=i.s,e):new o(NaN):(o.precision=r+6,o.rounding=1,i=i.div(new o(1).minus(i.times(i)).sqrt().plus(1)).atan(),o.precision=r,o.rounding=n,i.times(2)))},xt.inverseTangent=xt.atan=function(){var e,t,r,n,i,o,a,s,u,c=this,l=c.constructor,f=l.precision,p=l.rounding;if(c.isFinite()){if(c.isZero())return new l(c);if(c.abs().eq(1)&&f+4<=yt)return(a=Tt(l,f+4,p).times(.25)).s=c.s,a}else{if(!c.s)return new l(NaN);if(f+4<=yt)return(a=Tt(l,f+4,p).times(.5)).s=c.s,a}for(l.precision=s=f+10,l.rounding=1,e=r=Math.min(28,s/ht+2|0);e;--e)c=c.div(c.times(c).plus(1).sqrt().plus(1));for(rt=!1,t=Math.ceil(s/ht),n=1,u=c.times(c),a=new l(c),i=c;-1!==e;)if(i=i.times(u),o=a.minus(i.div(n+=2)),i=i.times(u),void 0!==(a=o.plus(i.div(n+=2))).d[t])for(e=t;a.d[e]===o.d[e]&&e--;);return r&&(a=a.times(2<this.d.length-2},xt.isNaN=function(){return!this.s},xt.isNegative=xt.isNeg=function(){return this.s<0},xt.isPositive=xt.isPos=function(){return this.s>0},xt.isZero=function(){return!!this.d&&0===this.d[0]},xt.lessThan=xt.lt=function(e){return this.cmp(e)<0},xt.lessThanOrEqualTo=xt.lte=function(e){return this.cmp(e)<1},xt.logarithm=xt.log=function(e){var t,r,n,i,o,a,s,u,c=this,l=c.constructor,f=l.precision,p=l.rounding;if(null==e)e=new l(10),t=!0;else{if(r=(e=new l(e)).d,e.s<0||!r||!r[0]||e.eq(1))return new l(NaN);t=e.eq(10)}if(r=c.d,c.s<0||!r||!r[0]||c.eq(1))return new l(r&&!r[0]?-1/0:1!=c.s?NaN:r?0:1/0);if(t)if(r.length>1)o=!0;else{for(i=r[0];i%10==0;)i/=10;o=1!==i}if(rt=!1,a=It(c,s=f+5),n=t?Ct(l,s+10):It(e,s),wt((u=Et(a,n,s,1)).d,i=f,p))do{if(a=It(c,s+=10),n=t?Ct(l,s+10):It(e,s),u=Et(a,n,s,1),!o){+bt(u.d).slice(i+1,i+15)+1==1e14&&(u=At(u,f+1,0));break}}while(wt(u.d,i+=10,p));return rt=!0,At(u,f,p)},xt.minus=xt.sub=function(e){var t,r,n,i,o,a,s,u,c,l,f,p,m=this,d=m.constructor;if(e=new d(e),!m.d||!e.d)return m.s&&e.s?m.d?e.s=-e.s:e=new d(e.d||m.s!==e.s?m:NaN):e=new d(NaN),e;if(m.s!=e.s)return e.s=-e.s,m.plus(e);if(c=m.d,p=e.d,s=d.precision,u=d.rounding,!c[0]||!p[0]){if(p[0])e.s=-e.s;else{if(!c[0])return new d(3===u?-0:0);e=new d(m)}return rt?At(e,s,u):e}if(r=ut(e.e/ht),l=ut(m.e/ht),c=c.slice(),o=l-r){for((f=o<0)?(t=c,o=-o,a=p.length):(t=p,r=l,a=c.length),o>(n=Math.max(Math.ceil(s/ht),a)+2)&&(o=n,t.length=1),t.reverse(),n=o;n--;)t.push(0);t.reverse()}else{for((f=(n=c.length)<(a=p.length))&&(a=n),n=0;n0;--n)c[a++]=0;for(n=p.length;n>o;){if(c[--n](a=(o=Math.ceil(s/ht))>a?o+1:a+1)&&(i=a,r.length=1),r.reverse();i--;)r.push(0);r.reverse()}for((a=c.length)-(i=l.length)<0&&(i=a,r=l,l=c,c=r),t=0;i;)t=(c[--i]=c[i]+l[i]+t)/dt|0,c[i]%=dt;for(t&&(c.unshift(t),++n),a=c.length;0==c[--a];)c.pop();return e.d=c,e.e=Mt(c,n),rt?At(e,s,u):e},xt.precision=xt.sd=function(e){var t,r=this;if(void 0!==e&&e!==!!e&&1!==e&&0!==e)throw Error(it+e);return r.d?(t=Dt(r.d),e&&r.e+1>t&&(t=r.e+1)):t=NaN,t},xt.round=function(){var e=this,t=e.constructor;return At(new t(e),e.e+1,t.rounding)},xt.sine=xt.sin=function(){var e,t,r=this,n=r.constructor;return r.isFinite()?r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+Math.max(r.e,r.sd())+ht,n.rounding=1,r=function(e,t){var r,n=t.d.length;if(n<3)return t.isZero()?t:Pt(e,2,t,t);r=(r=1.4*Math.sqrt(n))>16?16:0|r,t=Pt(e,2,t=t.times(1/jt(5,r)),t);for(var i,o=new e(5),a=new e(16),s=new e(20);r--;)i=t.times(t),t=t.times(o.plus(i.times(a.times(i).minus(s))));return t}(n,Ut(n,r)),n.precision=e,n.rounding=t,At(Ye>2?r.neg():r,e,t,!0)):new n(NaN)},xt.squareRoot=xt.sqrt=function(){var e,t,r,n,i,o,a=this,s=a.d,u=a.e,c=a.s,l=a.constructor;if(1!==c||!s||!s[0])return new l(!c||c<0&&(!s||s[0])?NaN:s?a:1/0);for(rt=!1,0==(c=Math.sqrt(+a))||c==1/0?(((t=bt(s)).length+u)%2==0&&(t+="0"),c=Math.sqrt(t),u=ut((u+1)/2)-(u<0||u%2),n=new l(t=c==1/0?"5e"+u:(t=c.toExponential()).slice(0,t.indexOf("e")+1)+u)):n=new l(c.toString()),r=(u=l.precision)+3;;)if(n=(o=n).plus(Et(a,o,r+2,1)).times(.5),bt(o.d).slice(0,r)===(t=bt(n.d)).slice(0,r)){if("9999"!=(t=t.slice(r-3,r+1))&&(i||"4999"!=t)){+t&&(+t.slice(1)||"5"!=t.charAt(0))||(At(n,u+1,1),e=!n.times(n).eq(a));break}if(!i&&(At(o,u+1,0),o.times(o).eq(a))){n=o;break}r+=4,i=1}return rt=!0,At(n,u,l.rounding,e)},xt.tangent=xt.tan=function(){var e,t,r=this,n=r.constructor;return r.isFinite()?r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+10,n.rounding=1,(r=r.sin()).s=1,r=Et(r,new n(1).minus(r.times(r)).sqrt(),e+10,0),n.precision=e,n.rounding=t,At(2==Ye||4==Ye?r.neg():r,e,t,!0)):new n(NaN)},xt.times=xt.mul=function(e){var t,r,n,i,o,a,s,u,c,l=this,f=l.constructor,p=l.d,m=(e=new f(e)).d;if(e.s*=l.s,!(p&&p[0]&&m&&m[0]))return new f(!e.s||p&&!p[0]&&!m||m&&!m[0]&&!p?NaN:p&&m?0*e.s:e.s/0);for(r=ut(l.e/ht)+ut(e.e/ht),(u=p.length)<(c=m.length)&&(o=p,p=m,m=o,a=u,u=c,c=a),o=[],n=a=u+c;n--;)o.push(0);for(n=c;--n>=0;){for(t=0,i=u+n;i>n;)s=o[i]+m[n]*p[i-n-1]+t,o[i--]=s%dt|0,t=s/dt|0;o[i]=(o[i]+t)%dt|0}for(;!o[--a];)o.pop();return t?++r:o.shift(),e.d=o,e.e=Mt(o,r),rt?At(e,f.precision,f.rounding):e},xt.toBinary=function(e,t){return Lt(this,2,e,t)},xt.toDecimalPlaces=xt.toDP=function(e,t){var r=this,n=r.constructor;return r=new n(r),void 0===e?r:(vt(e,0,Xe),void 0===t?t=n.rounding:vt(t,0,8),At(r,e+r.e+1,t))},xt.toExponential=function(e,t){var r,n=this,i=n.constructor;return void 0===e?r=St(n,!0):(vt(e,0,Xe),void 0===t?t=i.rounding:vt(t,0,8),r=St(n=At(new i(n),e+1,t),!0,e+1)),n.isNeg()&&!n.isZero()?"-"+r:r},xt.toFixed=function(e,t){var r,n,i=this,o=i.constructor;return void 0===e?r=St(i):(vt(e,0,Xe),void 0===t?t=o.rounding:vt(t,0,8),r=St(n=At(new o(i),e+i.e+1,t),!1,e+n.e+1)),i.isNeg()&&!i.isZero()?"-"+r:r},xt.toFraction=function(e){var t,r,n,i,o,a,s,u,c,l,f,p,m=this,d=m.d,h=m.constructor;if(!d)return new h(m);if(c=r=new h(1),n=u=new h(0),a=(o=(t=new h(n)).e=Dt(d)-m.e-1)%ht,t.d[0]=ct(10,a<0?ht+a:a),null==e)e=o>0?t:c;else{if(!(s=new h(e)).isInt()||s.lt(c))throw Error(it+s);e=s.gt(t)?o>0?t:c:s}for(rt=!1,s=new h(bt(d)),l=h.precision,h.precision=o=d.length*ht*2;f=Et(s,t,0,1,1),1!=(i=r.plus(f.times(n))).cmp(e);)r=n,n=i,i=c,c=u.plus(f.times(i)),u=i,i=t,t=s.minus(f.times(i)),s=i;return i=Et(e.minus(r),n,0,1,1),u=u.plus(i.times(c)),r=r.plus(i.times(n)),u.s=c.s=m.s,p=Et(c,n,o,1).minus(m).abs().cmp(Et(u,r,o,1).minus(m).abs())<1?[c,n]:[u,r],h.precision=l,rt=!0,p},xt.toHexadecimal=xt.toHex=function(e,t){return Lt(this,16,e,t)},xt.toNearest=function(e,t){var r=this,n=r.constructor;if(r=new n(r),null==e){if(!r.d)return r;e=new n(1),t=n.rounding}else{if(e=new n(e),void 0===t?t=n.rounding:vt(t,0,8),!r.d)return e.s?r:e;if(!e.d)return e.s&&(e.s=r.s),e}return e.d[0]?(rt=!1,r=Et(r,e,0,t,1).times(e),rt=!0,At(r)):(e.s=r.s,r=e),r},xt.toNumber=function(){return+this},xt.toOctal=function(e,t){return Lt(this,8,e,t)},xt.toPower=xt.pow=function(e){var t,r,n,i,o,a,s=this,u=s.constructor,c=+(e=new u(e));if(!(s.d&&e.d&&s.d[0]&&e.d[0]))return new u(ct(+s,c));if((s=new u(s)).eq(1))return s;if(n=u.precision,o=u.rounding,e.eq(1))return At(s,n,o);if((t=ut(e.e/ht))>=e.d.length-1&&(r=c<0?-c:c)<=9007199254740991)return i=Ot(u,s,r,n),e.s<0?new u(1).div(i):At(i,n,o);if((a=s.s)<0){if(tu.maxE+1||t0?a/0:0):(rt=!1,u.rounding=s.s=1,r=Math.min(12,(t+"").length),(i=zt(e.times(It(s,n+r)),n)).d&&wt((i=At(i,n+5,1)).d,n,o)&&(t=n+10,+bt((i=At(zt(e.times(It(s,t+r)),t),t+5,1)).d).slice(n+1,n+15)+1==1e14&&(i=At(i,n+1,0))),i.s=a,rt=!0,u.rounding=o,At(i,n,o))},xt.toPrecision=function(e,t){var r,n=this,i=n.constructor;return void 0===e?r=St(n,n.e<=i.toExpNeg||n.e>=i.toExpPos):(vt(e,1,Xe),void 0===t?t=i.rounding:vt(t,0,8),r=St(n=At(new i(n),e,t),e<=n.e||n.e<=i.toExpNeg,e)),n.isNeg()&&!n.isZero()?"-"+r:r},xt.toSignificantDigits=xt.toSD=function(e,t){var r=this.constructor;return void 0===e?(e=r.precision,t=r.rounding):(vt(e,1,Xe),void 0===t?t=r.rounding:vt(t,0,8)),At(new r(this),e,t)},xt.toString=function(){var e=this,t=e.constructor,r=St(e,e.e<=t.toExpNeg||e.e>=t.toExpPos);return e.isNeg()&&!e.isZero()?"-"+r:r},xt.truncated=xt.trunc=function(){return At(new this.constructor(this),this.e+1,1)},xt.valueOf=xt.toJSON=function(){var e=this,t=e.constructor,r=St(e,e.e<=t.toExpNeg||e.e>=t.toExpPos);return e.isNeg()?"-"+r:r};var Et=function(){function e(e,t,r){var n,i=0,o=e.length;for(e=e.slice();o--;)n=e[o]*t+i,e[o]=n%r|0,i=n/r|0;return i&&e.unshift(i),e}function t(e,t,r,n){var i,o;if(r!=n)o=r>n?1:-1;else for(i=o=0;it[i]?1:-1;break}return o}function r(e,t,r,n){for(var i=0;r--;)e[r]-=i,i=e[r]1;)e.shift()}return function(n,i,o,a,s,u){var c,l,f,p,m,d,h,g,y,x,b,v,w,N,E,A,S,M,C,T,D=n.constructor,F=n.s==i.s?1:-1,O=n.d,B=i.d;if(!(O&&O[0]&&B&&B[0]))return new D(n.s&&i.s&&(O?!B||O[0]!=B[0]:B)?O&&0==O[0]||!B?0*F:F/0:NaN);for(u?(m=1,l=n.e-i.e):(u=dt,m=ht,l=ut(n.e/m)-ut(i.e/m)),C=B.length,S=O.length,x=(y=new D(F)).d=[],f=0;B[f]==(O[f]||0);f++);if(B[f]>(O[f]||0)&&l--,null==o?(N=o=D.precision,a=D.rounding):N=s?o+(n.e-i.e)+1:o,N<0)x.push(1),d=!0;else{if(N=N/m+2|0,f=0,1==C){for(p=0,B=B[0],N++;(f1&&(B=e(B,p,u),O=e(O,p,u),C=B.length,S=O.length),A=C,v=(b=O.slice(0,C)).length;v=u/2&&++M;do{p=0,(c=t(B,b,C,v))<0?(w=b[0],C!=v&&(w=w*u+(b[1]||0)),(p=w/M|0)>1?(p>=u&&(p=u-1),1==(c=t(h=e(B,p,u),b,g=h.length,v=b.length))&&(p--,r(h,C=10;p/=10)f++;y.e=f+l*m-1,At(y,s?o+y.e+1:o,a,d)}return y}}();function At(e,t,r,n){var i,o,a,s,u,c,l,f,p,m=e.constructor;e:if(null!=t){if(!(f=e.d))return e;for(i=1,s=f[0];s>=10;s/=10)i++;if((o=t-i)<0)o+=ht,a=t,u=(l=f[p=0])/ct(10,i-a-1)%10|0;else if((p=Math.ceil((o+1)/ht))>=(s=f.length)){if(!n)break e;for(;s++<=p;)f.push(0);l=u=0,i=1,a=(o%=ht)-ht+1}else{for(l=s=f[p],i=1;s>=10;s/=10)i++;u=(a=(o%=ht)-ht+i)<0?0:l/ct(10,i-a-1)%10|0}if(n=n||t<0||void 0!==f[p+1]||(a<0?l:l%ct(10,i-a-1)),c=r<4?(u||n)&&(0==r||r==(e.s<0?3:2)):u>5||5==u&&(4==r||n||6==r&&(o>0?a>0?l/ct(10,i-a):0:f[p-1])%10&1||r==(e.s<0?8:7)),t<1||!f[0])return f.length=0,c?(t-=e.e+1,f[0]=ct(10,(ht-t%ht)%ht),e.e=-t||0):f[0]=e.e=0,e;if(0==o?(f.length=p,s=1,p--):(f.length=p+1,s=ct(10,ht-o),f[p]=a>0?(l/ct(10,i-a)%ct(10,a)|0)*s:0),c)for(;;){if(0==p){for(o=1,a=f[0];a>=10;a/=10)o++;for(a=f[0]+=s,s=1;a>=10;a/=10)s++;o!=s&&(e.e++,f[0]==dt&&(f[0]=1));break}if(f[p]+=s,f[p]!=dt)break;f[p--]=0,s=1}for(o=f.length;0===f[--o];)f.pop()}return rt&&(e.e>m.maxE?(e.d=null,e.e=NaN):e.e0?o=o.charAt(0)+"."+o.slice(1)+Ft(n):a>1&&(o=o.charAt(0)+"."+o.slice(1)),o=o+(e.e<0?"e":"e+")+e.e):i<0?(o="0."+Ft(-i-1)+o,r&&(n=r-a)>0&&(o+=Ft(n))):i>=a?(o+=Ft(i+1-a),r&&(n=r-i-1)>0&&(o=o+"."+Ft(n))):((n=i+1)0&&(i+1===a&&(o+="."),o+=Ft(n))),o}function Mt(e,t){var r=e[0];for(t*=ht;r>=10;r/=10)t++;return t}function Ct(e,t,r){if(t>gt)throw rt=!0,r&&(e.precision=r),Error(ot);return At(new e(Ke),t,1,!0)}function Tt(e,t,r){if(t>yt)throw Error(ot);return At(new e(et),t,r,!0)}function Dt(e){var t=e.length-1,r=t*ht+1;if(t=e[t]){for(;t%10==0;t/=10)r--;for(t=e[0];t>=10;t/=10)r++}return r}function Ft(e){for(var t="";e--;)t+="0";return t}function Ot(e,t,r,n){var i,o=new e(1),a=Math.ceil(n/ht+4);for(rt=!1;;){if(r%2&&$t((o=o.times(t)).d,a)&&(i=!0),0===(r=ut(r/2))){r=o.d.length-1,i&&0===o.d[r]&&++o.d[r];break}$t((t=t.times(t)).d,a)}return rt=!0,o}function Bt(e){return 1&e.d[e.d.length-1]}function _t(e,t,r){for(var n,i=new e(t[0]),o=0;++o17)return new p(e.d?e.d[0]?e.s<0?0:1/0:1:e.s?e.s<0?0:e:NaN);for(null==t?(rt=!1,u=d):u=t,s=new p(.03125);e.e>-2;)e=e.times(s),f+=5;for(u+=n=Math.log(ct(2,f))/Math.LN10*2+5|0,r=o=a=new p(1),p.precision=u;;){if(o=At(o.times(e),u,1),r=r.times(++l),bt((s=a.plus(Et(o,r,u,1))).d).slice(0,u)===bt(a.d).slice(0,u)){for(i=f;i--;)a=At(a.times(a),u,1);if(null!=t)return p.precision=d,a;if(!(c<3&&wt(a.d,u-n,m,c)))return At(a,p.precision=d,m,rt=!0);p.precision=u+=10,r=o=s=new p(1),l=0,c++}a=s}}function It(e,t){var r,n,i,o,a,s,u,c,l,f,p,m=1,d=e,h=d.d,g=d.constructor,y=g.rounding,x=g.precision;if(d.s<0||!h||!h[0]||!d.e&&1==h[0]&&1==h.length)return new g(h&&!h[0]?-1/0:1!=d.s?NaN:h?0:d);if(null==t?(rt=!1,l=x):l=t,g.precision=l+=10,n=(r=bt(h)).charAt(0),!(Math.abs(o=d.e)<15e14))return c=Ct(g,l+2,x).times(o+""),d=It(new g(n+"."+r.slice(1)),l-10).plus(c),g.precision=x,null==t?At(d,x,y,rt=!0):d;for(;n<7&&1!=n||1==n&&r.charAt(1)>3;)n=(r=bt((d=d.times(e)).d)).charAt(0),m++;for(o=d.e,n>1?(d=new g("0."+r),o++):d=new g(n+"."+r.slice(1)),f=d,u=a=d=Et(d.minus(1),d.plus(1),l,1),p=At(d.times(d),l,1),i=3;;){if(a=At(a.times(p),l,1),bt((c=u.plus(Et(a,new g(i),l,1))).d).slice(0,l)===bt(u.d).slice(0,l)){if(u=u.times(2),0!==o&&(u=u.plus(Ct(g,l+2,x).times(o+""))),u=Et(u,new g(m),l,1),null!=t)return g.precision=x,u;if(!wt(u.d,l-10,y,s))return At(u,g.precision=x,y,rt=!0);g.precision=l+=10,c=a=d=Et(f.minus(1),f.plus(1),l,1),p=At(d.times(d),l,1),i=s=1}u=c,i+=2}}function kt(e){return String(e.s*e.s/0)}function qt(e,t){var r,n,i;for((r=t.indexOf("."))>-1&&(t=t.replace(".","")),(n=t.search(/e/i))>0?(r<0&&(r=n),r+=+t.slice(n+1),t=t.substring(0,n)):r<0&&(r=t.length),n=0;48===t.charCodeAt(n);n++);for(i=t.length;48===t.charCodeAt(i-1);--i);if(t=t.slice(n,i)){if(i-=n,e.e=r=r-n-1,e.d=[],n=(r+1)%ht,r<0&&(n+=ht),ne.constructor.maxE?(e.d=null,e.e=NaN):e.e-1){if(t=t.replace(/(\d)_(?=\d)/g,"$1"),mt.test(t))return qt(e,t)}else if("Infinity"===t||"NaN"===t)return+t||(e.s=NaN),e.e=NaN,e.d=null,e;if(ft.test(t))r=16,t=t.toLowerCase();else if(lt.test(t))r=2;else{if(!pt.test(t))throw Error(it+t);r=8}for((o=t.search(/p/i))>0?(u=+t.slice(o+1),t=t.substring(2,o)):t=t.slice(2),a=(o=t.indexOf("."))>=0,n=e.constructor,a&&(o=(s=(t=t.replace(".","")).length)-o,i=Ot(n,new n(r),o,2*o)),o=l=(c=Nt(t,r,dt)).length-1;0===c[o];--o)c.pop();return o<0?new n(0*e.s):(e.e=Mt(c,l),e.d=c,rt=!1,a&&(e=Et(e,i,4*s)),u&&(e=e.times(Math.abs(u)<54?ct(2,u):Fr.pow(2,u))),rt=!0,e)}function Pt(e,t,r,n,i){var o,a,s,u,c=e.precision,l=Math.ceil(c/ht);for(rt=!1,u=r.times(r),s=new e(n);;){if(a=Et(s.times(u),new e(t++*t++),c,1),s=i?n.plus(a):n.minus(a),n=Et(a.times(u),new e(t++*t++),c,1),void 0!==(a=s.plus(n)).d[l]){for(o=l;a.d[o]===s.d[o]&&o--;);if(-1==o)break}o=s,s=n,n=a,a=o}return rt=!0,a.d.length=l+1,a}function jt(e,t){for(var r=e;--t;)r*=e;return r}function Ut(e,t){var r,n=t.s<0,i=Tt(e,e.precision,1),o=i.times(.5);if((t=t.abs()).lte(o))return Ye=n?4:1,t;if((r=t.divToInt(i)).isZero())Ye=n?3:2;else{if((t=t.minus(r.times(i))).lte(o))return Ye=Bt(r)?n?2:3:n?4:1,t;Ye=Bt(r)?n?1:4:n?3:2}return t.minus(i).abs()}function Lt(e,t,r,n){var i,o,a,s,u,c,l,f,p,m=e.constructor,d=void 0!==r;if(d?(vt(r,1,Xe),void 0===n?n=m.rounding:vt(n,0,8)):(r=m.precision,n=m.rounding),e.isFinite()){for(d?(i=2,16==t?r=4*r-3:8==t&&(r=3*r-2)):i=t,(a=(l=St(e)).indexOf("."))>=0&&(l=l.replace(".",""),(p=new m(1)).e=l.length-a,p.d=Nt(St(p),10,i),p.e=p.d.length),o=u=(f=Nt(l,10,i)).length;0==f[--u];)f.pop();if(f[0]){if(a<0?o--:((e=new m(e)).d=f,e.e=o,f=(e=Et(e,p,r,n,0,i)).d,o=e.e,c=We),a=f[r],s=i/2,c=c||void 0!==f[r+1],c=n<4?(void 0!==a||c)&&(0===n||n===(e.s<0?3:2)):a>s||a===s&&(4===n||c||6===n&&1&f[r-1]||n===(e.s<0?8:7)),f.length=r,c)for(;++f[--r]>i-1;)f[r]=0,r||(++o,f.unshift(1));for(u=f.length;!f[u-1];--u);for(a=0,l="";a1)if(16==t||8==t){for(a=16==t?4:3,--u;u%a;u++)l+="0";for(u=(f=Nt(l,i,t)).length;!f[u-1];--u);for(a=1,l="1.";au)for(o-=u;o--;)l+="0";else ot)return e.length=t,!0}function Ht(e){return new this(e).abs()}function Gt(e){return new this(e).acos()}function Zt(e){return new this(e).acosh()}function Vt(e,t){return new this(e).plus(t)}function Wt(e){return new this(e).asin()}function Yt(e){return new this(e).asinh()}function Jt(e){return new this(e).atan()}function Xt(e){return new this(e).atanh()}function Qt(e,t){e=new this(e),t=new this(t);var r,n=this.precision,i=this.rounding,o=n+4;return e.s&&t.s?e.d||t.d?!t.d||e.isZero()?(r=t.s<0?Tt(this,n,i):new this(0)).s=e.s:!e.d||t.isZero()?(r=Tt(this,o,1).times(.5)).s=e.s:t.s<0?(this.precision=o,this.rounding=1,r=this.atan(Et(e,t,o,1)),t=Tt(this,o,1),this.precision=n,this.rounding=i,r=e.s<0?r.minus(t):r.plus(t)):r=this.atan(Et(e,t,o,1)):(r=Tt(this,o,1).times(t.s>0?.25:.75)).s=e.s:r=new this(NaN),r}function Kt(e){return new this(e).cbrt()}function er(e){return At(e=new this(e),e.e+1,2)}function tr(e,t,r){return new this(e).clamp(t,r)}function rr(e){if(!e||"object"!=typeof e)throw Error(nt+"Object expected");var t,r,n,i=!0===e.defaults,o=["precision",1,Xe,"rounding",0,8,"toExpNeg",-Je,0,"toExpPos",0,Je,"maxE",0,Je,"minE",-Je,0,"modulo",0,9];for(t=0;t=o[t+1]&&n<=o[t+2]))throw Error(it+r+": "+n);this[r]=n}if(r="crypto",i&&(this[r]=tt[r]),void 0!==(n=e[r])){if(!0!==n&&!1!==n&&0!==n&&1!==n)throw Error(it+r+": "+n);if(n){if("undefined"==typeof crypto||!crypto||!crypto.getRandomValues&&!crypto.randomBytes)throw Error(at);this[r]=!0}else this[r]=!1}return this}function nr(e){return new this(e).cos()}function ir(e){return new this(e).cosh()}function or(e,t){return new this(e).div(t)}function ar(e){return new this(e).exp()}function sr(e){return At(e=new this(e),e.e+1,3)}function ur(){var e,t,r=new this(0);for(rt=!1,e=0;e=429e7?t[o]=crypto.getRandomValues(new Uint32Array(1))[0]:s[o++]=i%1e7;else{if(!crypto.randomBytes)throw Error(at);for(t=crypto.randomBytes(n*=4);o=214e7?crypto.randomBytes(4).copy(t,o):(s.push(i%1e7),o+=4);o=n/4}else for(;o=10;i/=10)n++;no.maxE?(i.e=NaN,i.d=null):e.e=10;r/=10)t++;return void(rt?t>o.maxE?(i.e=NaN,i.d=null):t{let{on:t,config:r}=e;const n=Or.clone({precision:r.precision,modulo:Or.EUCLID});return n.prototype=Object.create(n.prototype),n.prototype.type="BigNumber",n.prototype.isBigNumber=!0,n.prototype.toJSON=function(){return{mathjs:"BigNumber",value:this.toString()}},n.fromJSON=function(e){return new n(e.value)},t&&t("config",(function(e,t){e.precision!==t.precision&&n.config({precision:e.precision})})),n}),{isClass:!0});var _r=r(5716);const zr=de("Complex",[],(()=>(Object.defineProperty(_r,"name",{value:"Complex"}),_r.prototype.constructor=_r,_r.prototype.type="Complex",_r.prototype.isComplex=!0,_r.prototype.toJSON=function(){return{mathjs:"Complex",re:this.re,im:this.im}},_r.prototype.toPolar=function(){return{r:this.abs(),phi:this.arg()}},_r.prototype.format=function(e){let t="",r=this.im,n=this.re;const i=Me(this.re,e),o=Me(this.im,e),a=h(e)?e:e?e.precision:null;if(null!==a){const e=Math.pow(10,-a);Math.abs(n/r)t.re?1:e.ret.im?1:e.im1&&(t[r]=(t[r]||0)+1):t[e]=(t[e]||0)+1,t}var Pr=function(e,t){var r,n=0,i=1,o=1,a=0,s=0,u=0,c=1,l=1,f=0,p=1,m=1,d=1,h=1e7;if(null==e);else if(void 0!==t){if(o=(n=e)*(i=t),n%1!=0||i%1!=0)throw Hr()}else switch(typeof e){case"object":if("d"in e&&"n"in e)n=e.n,i=e.d,"s"in e&&(n*=e.s);else{if(!(0 in e))throw $r();n=e[0],1 in e&&(i=e[1])}o=n*i;break;case"number":if(e<0&&(o=e,e=-e),e%1==0)n=e;else if(e>0){for(e>=1&&(e/=l=Math.pow(10,Math.floor(1+Math.log(e)/Math.LN10)));p<=h&&d<=h;){if(e===(r=(f+m)/(p+d))){p+d<=h?(n=f+m,i=p+d):d>p?(n=m,i=d):(n=f,i=p);break}e>r?(f+=m,p+=d):(m+=f,d+=p),p>h?(n=m,i=d):(n=f,i=p)}n*=l}else(isNaN(e)||isNaN(t))&&(i=n=NaN);break;case"string":if(null===(p=e.match(/\d+|./g)))throw $r();if("-"===p[f]?(o=-1,f++):"+"===p[f]&&f++,p.length===f+1?s=kr(p[f++],o):"."===p[f+1]||"."===p[f]?("."!==p[f]&&(a=kr(p[f++],o)),(1+ ++f===p.length||"("===p[f+1]&&")"===p[f+3]||"'"===p[f+1]&&"'"===p[f+3])&&(s=kr(p[f],o),c=Math.pow(10,p[f].length),f++),("("===p[f]&&")"===p[f+2]||"'"===p[f]&&"'"===p[f+2])&&(u=kr(p[f+1],o),l=Math.pow(10,p[f+1].length)-1,f+=3)):"/"===p[f+1]||":"===p[f+1]?(s=kr(p[f],o),c=kr(p[f+2],1),f+=3):"/"===p[f+3]&&" "===p[f+1]&&(a=kr(p[f],o),s=kr(p[f+2],o),c=kr(p[f+4],1),f+=5),p.length<=f){o=n=u+(i=c*l)*a+l*s;break}default:throw $r()}if(0===i)throw Lr();Ir.s=o<0?-1:1,Ir.n=Math.abs(n),Ir.d=Math.abs(i)};function jr(e,t){if(!e)return t;if(!t)return e;for(;;){if(!(e%=t))return t;if(!(t%=e))return e}}function Ur(e,t){if(Pr(e,t),!(this instanceof Ur))return qr(Ir.s*Ir.n,Ir.d);e=jr(Ir.d,Ir.n),this.s=Ir.s,this.n=Ir.n/e,this.d=Ir.d/e}var Lr=function(){return new Error("Division by Zero")},$r=function(){return new Error("Invalid argument")},Hr=function(){return new Error("Parameters must be integer")};Ur.prototype={s:1,n:0,d:1,abs:function(){return qr(this.n,this.d)},neg:function(){return qr(-this.s*this.n,this.d)},add:function(e,t){return Pr(e,t),qr(this.s*this.n*Ir.d+Ir.s*this.d*Ir.n,this.d*Ir.d)},sub:function(e,t){return Pr(e,t),qr(this.s*this.n*Ir.d-Ir.s*this.d*Ir.n,this.d*Ir.d)},mul:function(e,t){return Pr(e,t),qr(this.s*Ir.s*this.n*Ir.n,this.d*Ir.d)},div:function(e,t){return Pr(e,t),qr(this.s*Ir.s*this.n*Ir.d,this.d*Ir.n)},clone:function(){return qr(this.s*this.n,this.d)},mod:function(e,t){if(isNaN(this.n)||isNaN(this.d))return new Ur(NaN);if(void 0===e)return qr(this.s*this.n%this.d,1);if(Pr(e,t),0===Ir.n&&0===this.d)throw Lr();return qr(this.s*(Ir.d*this.n)%(Ir.n*this.d),Ir.d*this.d)},gcd:function(e,t){return Pr(e,t),qr(jr(Ir.n,this.n)*jr(Ir.d,this.d),Ir.d*this.d)},lcm:function(e,t){return Pr(e,t),0===Ir.n&&0===this.n?qr(0,1):qr(Ir.n*this.n,jr(Ir.n,this.n)*jr(Ir.d,this.d))},ceil:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Ur(NaN):qr(Math.ceil(e*this.s*this.n/this.d),e)},floor:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Ur(NaN):qr(Math.floor(e*this.s*this.n/this.d),e)},round:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Ur(NaN):qr(Math.round(e*this.s*this.n/this.d),e)},roundTo:function(e,t){return Pr(e,t),qr(this.s*Math.round(this.n*Ir.d/(this.d*Ir.n))*Ir.n,Ir.d)},inverse:function(){return qr(this.s*this.d,this.n)},pow:function(e,t){if(Pr(e,t),1===Ir.d)return Ir.s<0?qr(Math.pow(this.s*this.d,Ir.n),Math.pow(this.n,Ir.n)):qr(Math.pow(this.s*this.n,Ir.n),Math.pow(this.d,Ir.n));if(this.s<0)return null;var r=Rr(this.n),n=Rr(this.d),i=1,o=1;for(var a in r)if("1"!==a){if("0"===a){i=0;break}if(r[a]*=Ir.n,r[a]%Ir.d!=0)return null;r[a]/=Ir.d,i*=Math.pow(a,r[a])}for(var a in n)if("1"!==a){if(n[a]*=Ir.n,n[a]%Ir.d!=0)return null;n[a]/=Ir.d,o*=Math.pow(a,n[a])}return Ir.s<0?qr(o,i):qr(i,o)},equals:function(e,t){return Pr(e,t),this.s*this.n*Ir.d==Ir.s*Ir.n*this.d},compare:function(e,t){Pr(e,t);var r=this.s*this.n*Ir.d-Ir.s*Ir.n*this.d;return(0=0;o--)i=i.inverse().add(r[o]);if(Math.abs(i.sub(t).valueOf())0&&(r+=t,r+=" ",n%=i),r+=n,r+="/",r+=i),r},toLatex:function(e){var t,r="",n=this.n,i=this.d;return this.s<0&&(r+="-"),1===i?r+=n:(e&&(t=Math.floor(n/i))>0&&(r+=t,n%=i),r+="\\frac{",r+=n,r+="}{",r+=i,r+="}"),r},toContinued:function(){var e,t=this.n,r=this.d,n=[];if(isNaN(t)||isNaN(r))return n;do{n.push(Math.floor(t/r)),e=t%r,t=r,r=e}while(1!==t);return n},toString:function(e){var t=this.n,r=this.d;if(isNaN(t)||isNaN(r))return"NaN";e=e||15;var n=function(e,t){for(;t%2==0;t/=2);for(;t%5==0;t/=5);if(1===t)return 0;for(var r=10%t,n=1;1!==r;n++)if(r=10*r%t,n>2e3)return 0;return n}(0,r),i=function(e,t,r){for(var n=1,i=function(e,t,r){for(var n=1;t>0;e=e*e%r,t>>=1)1&t&&(n=n*e%r);return n}(10,r,t),o=0;o<300;o++){if(n===i)return o;n=10*n%t,i=10*i%t}return 0}(0,r,n),o=this.s<0?"-":"";if(o+=t/r|0,t%=r,(t*=10)&&(o+="."),n){for(var a=i;a--;)o+=t/r|0,t%=r,t*=10;for(o+="(",a=n;a--;)o+=t/r|0,t%=r,t*=10;o+=")"}else for(a=e;t&&a--;)o+=t/r|0,t%=r,t*=10;return o}};const Gr=de("Fraction",[],(()=>(Object.defineProperty(Ur,"name",{value:"Fraction"}),Ur.prototype.constructor=Ur,Ur.prototype.type="Fraction",Ur.prototype.isFraction=!0,Ur.prototype.toJSON=function(){return{mathjs:"Fraction",n:this.s*this.n,d:this.d}},Ur.fromJSON=function(e){return new Ur(e)},Ur)),{isClass:!0});r(3362);const Zr=de("Range",[],(()=>{function e(t,r,n){if(!(this instanceof e))throw new SyntaxError("Constructor must be called with the new operator");const i=null!=t,o=null!=r,a=null!=n;if(i)if(g(t))t=t.toNumber();else if("number"!=typeof t)throw new TypeError("Parameter start must be a number");if(o)if(g(r))r=r.toNumber();else if("number"!=typeof r)throw new TypeError("Parameter end must be a number");if(a)if(g(n))n=n.toNumber();else if("number"!=typeof n)throw new TypeError("Parameter step must be a number");this.start=i?parseFloat(t):0,this.end=o?parseFloat(r):0,this.step=a?parseFloat(n):1}return e.prototype.type="Range",e.prototype.isRange=!0,e.parse=function(t){if("string"!=typeof t)return null;const r=t.split(":").map((function(e){return parseFloat(e)}));if(r.some((function(e){return isNaN(e)})))return null;switch(r.length){case 2:return new e(r[0],r[1]);case 3:return new e(r[0],r[2],r[1]);default:return null}},e.prototype.clone=function(){return new e(this.start,this.end,this.step)},e.prototype.size=function(){let e=0;const t=this.start,r=this.step,n=this.end-t;return be(r)===be(n)?e=Math.ceil(n/r):0===n&&(e=0),isNaN(e)&&(e=0),[e]},e.prototype.min=function(){const e=this.size()[0];return e>0?this.step>0?this.start:this.start+(e-1)*this.step:void 0},e.prototype.max=function(){const e=this.size()[0];return e>0?this.step>0?this.start+(e-1)*this.step:this.start:void 0},e.prototype.forEach=function(e){let t=this.start;const r=this.step,n=this.end;let i=0;if(r>0)for(;tn;)e(t,[i],this),t+=r,i++},e.prototype.map=function(e){const t=[];return this.forEach((function(r,n,i){t[n[0]]=e(r,n,i)})),t},e.prototype.toArray=function(){const e=[];return this.forEach((function(t,r){e[r[0]]=t})),e},e.prototype.valueOf=function(){return this.toArray()},e.prototype.format=function(e){let t=Me(this.start,e);return 1!==this.step&&(t+=":"+Me(this.step,e)),t+=":"+Me(this.end,e),t},e.prototype.toString=function(){return this.format()},e.prototype.toJSON=function(){return{mathjs:"Range",start:this.start,end:this.end,step:this.step}},e.fromJSON=function(t){return new e(t.start,t.end,t.step)},e}),{isClass:!0}),Vr=de("Matrix",[],(()=>{function e(){if(!(this instanceof e))throw new SyntaxError("Constructor must be called with the new operator")}return e.prototype.type="Matrix",e.prototype.isMatrix=!0,e.prototype.storage=function(){throw new Error("Cannot invoke storage on a Matrix interface")},e.prototype.datatype=function(){throw new Error("Cannot invoke datatype on a Matrix interface")},e.prototype.create=function(e,t){throw new Error("Cannot invoke create on a Matrix interface")},e.prototype.subset=function(e,t,r){throw new Error("Cannot invoke subset on a Matrix interface")},e.prototype.get=function(e){throw new Error("Cannot invoke get on a Matrix interface")},e.prototype.set=function(e,t,r){throw new Error("Cannot invoke set on a Matrix interface")},e.prototype.resize=function(e,t){throw new Error("Cannot invoke resize on a Matrix interface")},e.prototype.reshape=function(e,t){throw new Error("Cannot invoke reshape on a Matrix interface")},e.prototype.clone=function(){throw new Error("Cannot invoke clone on a Matrix interface")},e.prototype.size=function(){throw new Error("Cannot invoke size on a Matrix interface")},e.prototype.map=function(e,t){throw new Error("Cannot invoke map on a Matrix interface")},e.prototype.forEach=function(e){throw new Error("Cannot invoke forEach on a Matrix interface")},e.prototype[Symbol.iterator]=function(){throw new Error("Cannot iterate a Matrix interface")},e.prototype.toArray=function(){throw new Error("Cannot invoke toArray on a Matrix interface")},e.prototype.valueOf=function(){throw new Error("Cannot invoke valueOf on a Matrix interface")},e.prototype.format=function(e){throw new Error("Cannot invoke format on a Matrix interface")},e.prototype.toString=function(){throw new Error("Cannot invoke toString on a Matrix interface")},e}),{isClass:!0});function Wr(){return Wr=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0?"+":"")+n.toString()}(e,n);case"bin":return Yr(e,2,i);case"oct":return Yr(e,8,i);case"hex":return Yr(e,16,i);case"auto":{const r=Xr(null==t?void 0:t.lowerExp,-3),i=Xr(null==t?void 0:t.upperExp,5);if(e.isZero())return"0";let o;const a=e.toSignificantDigits(n),s=a.e;return o=s>=r&&sen(r)+": "+Kr(e[r],t))).join(", ")+"}":String(e)}(e,t);return t&&"object"==typeof t&&"truncate"in t&&r.length>t.truncate?r.substring(0,t.truncate-3)+"...":r}function en(e){const t=String(e);let r="",n=0;for(;n/g,">"),t}function nn(e,t){if(Array.isArray(e)){let r="[";const n=e.length;for(let i=0;it?1:-1}function an(e,t,r){if(!(this instanceof an))throw new SyntaxError("Constructor must be called with the new operator");this.actual=e,this.expected=t,this.relation=r,this.message="Dimension mismatch ("+(Array.isArray(e)?"["+e.join(", ")+"]":e)+" "+(this.relation||"!=")+" "+(Array.isArray(t)?"["+t.join(", ")+"]":t)+")",this.stack=(new Error).stack}function sn(e,t,r){if(!(this instanceof sn))throw new SyntaxError("Constructor must be called with the new operator");this.index=e,arguments.length<3?(this.min=0,this.max=t):(this.min=t,this.max=r),void 0!==this.min&&this.index=this.max?this.message="Index out of range ("+this.index+" > "+(this.max-1)+")":this.message="Index out of range ("+this.index+")",this.stack=(new Error).stack}function un(e){const t=[];for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function cn(e,t,r){let n;const i=e.length;if(i!==t[r])throw new an(i,t[r]);if(r")}function ln(e,t){if(0===t.length){if(Array.isArray(e))throw new an(e.length,0)}else cn(e,t,0)}function fn(e,t){const r=e.isMatrix?e._size:un(e);t._sourceSize.forEach(((e,t)=>{if(null!==e&&e!==r[t])throw new an(e,r[t])}))}function pn(e,t){if(void 0!==e){if(!h(e)||!ye(e))throw new TypeError("Index must be an integer (value: "+e+")");if(e<0||"number"==typeof t&&e>=t)throw new sn(e,t)}}function mn(e){for(let t=0;t=0){if(t%r!=0)throw new Error("Could not replace wildcard, since "+t+" is no multiple of "+-r);n[i]=-t/r}return n}function xn(e){return e.reduce(((e,t)=>e*t),1)}function bn(e,t){const r=t||un(e);for(;Array.isArray(e)&&1===e.length;)e=e[0],r.shift();let n=r.length;for(;1===r[n-1];)n--;return nt.test(e)))}function Cn(e,t){return Array.prototype.join.call(e,t)}function Tn(e){if(!Array.isArray(e))throw new TypeError("Array input expected");if(0===e.length)return e;const t=[];let r=0;t[0]={value:e[0],identifier:0};for(let n=1;n1)return e.slice(1).reduce((function(e,r){return On(e,r,t,0)}),e[0]);throw new Error("Wrong number of arguments in function concat")}function _n(){for(var e=arguments.length,t=new Array(e),r=0;re.length)),i=Math.max(...n),o=new Array(i).fill(null);for(let e=0;eo[t]&&(o[t]=r[e])}}for(let e=0;e1||e[i]>t[o])throw new Error(`shape missmatch: missmatch is found in arg with shape (${e}) not possible to broadcast dimension ${n} with size ${e[i]} to size ${t[o]}`)}}function In(e,t){let r=un(e);if(ce(r,t))return e;zn(r,t);const n=_n(r,t),i=n.length,o=[...Array(i-r.length).fill(1),...r];let a=function(e){return Wr([],e)}(e);r.lengthe[t]),e)}function qn(e,t,r,n){return Array.isArray(e)?e.map((function(e,i){return qn(e,t.concat(i),r,n)})):n(e,t,r)}function Rn(e,r,n){if(t.isTypedFunction(e)){const i=(r.isMatrix?r.size():un(r)).map((()=>0)),o=r.isMatrix?r.get(i):kn(r,i),a=1===Object.keys(e.signatures).length,s=function(e,r,n,i){const o=[r,n,i];for(let r=3;r>0;r--){const n=o.slice(0,r);if(null!==t.resolve(e,n))return r}}(e,o,i,r),u=a?Object.values(e.signatures)[0]:e;return s>=1&&s<=3?function(){for(var t=arguments.length,r=new Array(t),i=0;i=2&&e.push(`index: ${oe(t[1])}`),t.length>=3&&e.push(`array: ${oe(t[2])}`),new TypeError(`Function ${r} cannot apply callback arguments ${n}(${e.join(", ")}) at index ${JSON.stringify(t[1])}`)}throw new TypeError(`Function ${r} cannot apply callback arguments to function ${n}: ${e.message}`)}(e,t,r,n)}}an.prototype=new RangeError,an.prototype.constructor=RangeError,an.prototype.name="DimensionError",an.prototype.isDimensionError=!0,sn.prototype=new RangeError,sn.prototype.constructor=RangeError,sn.prototype.name="IndexError",sn.prototype.isIndexError=!0,r(3110);const jn=de("DenseMatrix",["Matrix"],(e=>{let{Matrix:t}=e;function r(e,t){if(!(this instanceof r))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!w(t))throw new Error("Invalid datatype: "+t);if(E(e))"DenseMatrix"===e.type?(this._data=ae(e._data),this._size=ae(e._size),this._datatype=t||e._datatype):(this._data=e.toArray(),this._size=e.size(),this._datatype=t||e._datatype);else if(e&&N(e.data)&&N(e.size))this._data=e.data,this._size=e.size,ln(this._data,this._size),this._datatype=t||e.datatype;else if(N(e))this._data=s(e),this._size=un(this._data),ln(this._data,this._size),this._datatype=t;else{if(e)throw new TypeError("Unsupported type of data ("+oe(e)+")");this._data=[],this._size=[0],this._datatype=t}}function n(e,t,r,i){const o=i===r-1,a=t.dimension(i);return o?a.map((function(t){return pn(t,e.length),e[t]})).valueOf():a.map((function(o){return pn(o,e.length),n(e[o],t,r,i+1)})).valueOf()}function i(e,t,r,n,o){const a=o===n-1,s=t.dimension(o);a?s.forEach((function(t,n){pn(t),e[t]=r[n[0]]})):s.forEach((function(a,s){pn(a),i(e[a],t,r[s[0]],n,o+1)}))}function o(e,t,r){if(0===t.length){let t=e._data;for(;N(t);)t=t[0];return t}return e._size=t.slice(0),e._data=dn(e._data,e._size,r),e}function a(e,t,r){const n=e._size.slice(0);let i=!1;for(;n.lengthn[e]&&(n[e]=t[e],i=!0);i&&o(e,n,r)}function s(e){return E(e)?s(e.valueOf()):N(e)?e.map(s):e}return r.prototype=new t,r.prototype.createDenseMatrix=function(e,t){return new r(e,t)},Object.defineProperty(r,"name",{value:"DenseMatrix"}),r.prototype.constructor=r,r.prototype.type="DenseMatrix",r.prototype.isDenseMatrix=!0,r.prototype.getDataType=function(){return Fn(this._data,oe)},r.prototype.storage=function(){return"dense"},r.prototype.datatype=function(){return this._datatype},r.prototype.create=function(e,t){return new r(e,t)},r.prototype.subset=function(e,t,o){switch(arguments.length){case 1:return function(e,t){if(!T(t))throw new TypeError("Invalid index");if(t.isScalar())return e.get(t.min());{const i=t.size();if(i.length!==e._size.length)throw new an(i.length,e._size.length);const o=t.min(),a=t.max();for(let t=0,r=e._size.length;t");a(e,t.max().map((function(e){return e+1})),n);const s=o.length,c=0;i(e._data,t,r,s,c)}return e}(this,e,t,o);default:throw new SyntaxError("Wrong number of arguments")}},r.prototype.get=function(e){return kn(this._data,e)},r.prototype.set=function(e,t,r){if(!N(e))throw new TypeError("Array expected");if(e.lengthArray.isArray(e)&&1===e.length?e[0]:e));return o(r?this.clone():this,n,t)},r.prototype.reshape=function(e,t){const r=t?this.clone():this;r._data=gn(r._data,e);const n=r._size.reduce(((e,t)=>e*t));return r._size=yn(e,n),r},r.prototype.clone=function(){return new r({data:ae(this._data),size:ae(this._size),datatype:this._datatype})},r.prototype.size=function(){return this._size.slice(0)},r.prototype._forEach=function(e){const t=this,r=t.size();if(1===r.length){for(let n=0;n=0;a--){if(n[a]++,n[a]!==r[a]){i[a]=0===a?t._data[n[a]]:i[a-1][n[a]];for(let e=a;e[e[i]]));e.push(new r(t,this._datatype))}return e},r.prototype.toArray=function(){return ae(this._data)},r.prototype.valueOf=function(){return this._data},r.prototype.format=function(e){return Kr(this._data,e)},r.prototype.toString=function(){return Kr(this._data)},r.prototype.toJSON=function(){return{mathjs:"DenseMatrix",data:this._data,size:this._size,datatype:this._datatype}},r.prototype.diagonal=function(e){if(e){if(g(e)&&(e=e.toNumber()),!h(e)||!ye(e))throw new TypeError("The parameter k must be an integer number")}else e=0;const t=e>0?e:0,n=e<0?-e:0,i=this._size[0],o=this._size[1],a=Math.min(i-n,o-t),s=[];for(let e=0;e0?n:0,a=n<0?-n:0,s=e[0],u=e[1],c=Math.min(s-a,u-o);let l;if(N(t)){if(t.length!==c)throw new Error("Invalid value array length");l=function(e){return t[e]}}else if(E(t)){const e=t.size();if(1!==e.length||e[0]!==c)throw new Error("Invalid matrix length");l=function(e){return t.get([e])}}else l=function(){return t};i||(i=g(l(0))?l(0).mul(0):0);let f=[];if(e.length>0){f=dn(f,e,i);for(let e=0;e{let{typed:t}=e;return t(Un,{any:ae})}));function $n(e){const t=e.length,r=e[0].length;let n,i;const o=[];for(i=0;i=n.length)throw new sn(t,n.length);return E(e)?e.create(Wn(e.valueOf(),t,r),e.datatype()):Wn(e,t,r)}function Wn(e,t,r){let n,i,o,a;if(t<=0){if(Array.isArray(e[0])){for(a=$n(e),i=[],n=0;n{let{typed:t}=e;return t(Jn,{number:ye,BigNumber:function(e){return e.isInt()},bigint:function(e){return!0},Fraction:function(e){return 1===e.d&&isFinite(e.n)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Qn="number";function Kn(e){return e<0}function ei(e){return e>0}function ti(e){return Number.isNaN(e)}function ri(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1e-9,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0;if(r<=0)throw new Error("Relative tolerance must be greater than 0");if(n<0)throw new Error("Absolute tolerance must be at least 0");return!e.isNaN()&&!t.isNaN()&&(e.isFinite()&&t.isFinite()?!!e.eq(t)||e.minus(t).abs().lte(e.constructor.max(e.constructor.max(e.abs(),t.abs()).mul(r),n)):e.eq(t))}Kn.signature=Qn,ei.signature=Qn,ti.signature=Qn;const ni="isNegative",ii=de(ni,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(ni,{number:e=>!_e(e,0,r.relTol,r.absTol)&&Kn(e),BigNumber:e=>!ri(e,new e.constructor(0),r.relTol,r.absTol)&&e.isNeg()&&!e.isZero()&&!e.isNaN(),bigint:e=>e<0n,Fraction:e=>e.s<0,Unit:t.referToSelf((e=>r=>t.find(e,r.valueType())(r.value))),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),oi="isNumeric",ai=de(oi,["typed"],(e=>{let{typed:t}=e;return t(oi,{"number | BigNumber | bigint | Fraction | boolean":()=>!0,"Complex | Unit | string | null | undefined | Node":()=>!1,"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),si="hasNumericValue",ui=de(si,["typed","isNumeric"],(e=>{let{typed:t,isNumeric:r}=e;return t(si,{boolean:()=>!0,string:function(e){return e.trim().length>0&&!isNaN(Number(e))},any:function(e){return r(e)}})})),ci="isPositive",li=de(ci,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(ci,{number:e=>!_e(e,0,r.relTol,r.absTol)&&ei(e),BigNumber:e=>!(ri(e,new e.constructor(0),r.relTol,r.absTol)||e.isNeg()||e.isZero()||e.isNaN()),bigint:e=>e>0n,Fraction:e=>e.s>0&&e.n>0,Unit:t.referToSelf((e=>r=>t.find(e,r.valueType())(r.value))),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),fi="isZero",pi=de(fi,["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return t(fi,{"number | BigNumber | Complex | Fraction":e=>r(e,0),bigint:e=>0n===e,Unit:t.referToSelf((e=>r=>t.find(e,r.valueType())(r.value))),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),mi="isNaN",di=de(mi,["typed"],(e=>{let{typed:t}=e;return t(mi,{number:ti,BigNumber:function(e){return e.isNaN()},bigint:function(e){return!1},Fraction:function(e){return!1},Complex:function(e){return e.isNaN()},Unit:function(e){return Number.isNaN(e.value)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),hi="typeOf",gi=de(hi,["typed"],(e=>{let{typed:t}=e;return t(hi,{any:oe})})),yi=de("compareUnits",["typed"],(e=>{let{typed:t}=e;return{"Unit, Unit":t.referToSelf((e=>(r,n)=>{if(!r.equalBase(n))throw new Error("Cannot compare units with different base");return t.find(e,[r.valueType(),n.valueType()])(r.value,n.value)}))}})),xi="equalScalar",bi=de(xi,["typed","config"],(e=>{let{typed:t,config:r}=e;const n=yi({typed:t});return t(xi,{"boolean, boolean":function(e,t){return e===t},"number, number":function(e,t){return _e(e,t,r.relTol,r.absTol)},"BigNumber, BigNumber":function(e,t){return e.eq(t)||ri(e,t,r.relTol,r.absTol)},"bigint, bigint":function(e,t){return e===t},"Fraction, Fraction":function(e,t){return e.equals(t)},"Complex, Complex":function(e,t){return function(e,t,r,n){return _e(e.re,t.re,r,n)&&_e(e.im,t.im,r,n)}(e,t,r.relTol,r.absTol)}},n)})),vi=(de(xi,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(xi,{"number, number":function(e,t){return _e(e,t,r.relTol,r.absTol)}})})),de("SparseMatrix",["typed","equalScalar","Matrix"],(e=>{let{typed:t,equalScalar:r,Matrix:n}=e;function i(e,t){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!w(t))throw new Error("Invalid datatype: "+t);if(E(e))!function(e,t,r){"SparseMatrix"===t.type?(e._values=t._values?ae(t._values):void 0,e._index=ae(t._index),e._ptr=ae(t._ptr),e._size=ae(t._size),e._datatype=r||t._datatype):o(e,t.valueOf(),r||t._datatype)}(this,e,t);else if(e&&N(e.index)&&N(e.ptr)&&N(e.size))this._values=e.values,this._index=e.index,this._ptr=e.ptr,this._size=e.size,this._datatype=t||e.datatype;else if(N(e))o(this,e,t);else{if(e)throw new TypeError("Unsupported type of data ("+oe(e)+")");this._values=[],this._index=[],this._ptr=[0],this._size=[0,0],this._datatype=t}}function o(e,n,i){e._values=[],e._index=[],e._ptr=[],e._datatype=i;const o=n.length;let a=0,s=r,u=0;if(w(i)&&(s=t.find(r,[i,i])||r,u=t.convert(0,i)),o>0){let t=0;do{e._ptr.push(e._index.length);for(let r=0;rd){for(p=d;pl){if(c){let t=0;for(p=0;pn-1&&(e._values.splice(m,1),e._index.splice(m,1),t++)}e._ptr[p]=e._values.length}return e._size[0]=n,e._size[1]=i,e}function c(e,t,r,n,i){const o=n[0],a=n[1],s=[];let u,c;for(u=0;u");if(1===i.length)t.dimension(0).forEach((function(t,i){pn(t),e.set([t,0],r[i[0]],n)}));else{const i=t.dimension(0),o=t.dimension(1);i.forEach((function(t,i){pn(t),o.forEach((function(o,a){pn(o),e.set([t,o],r[i[0]][a[0]],n)}))}))}}return e}(this,e,t,r);default:throw new SyntaxError("Wrong number of arguments")}},i.prototype.get=function(e){if(!N(e))throw new TypeError("Array expected");if(e.length!==this._size.length)throw new an(e.length,this._size.length);if(!this._values)throw new Error("Cannot invoke get on a Pattern only matrix");const t=e[0],r=e[1];pn(t,this._size[0]),pn(r,this._size[1]);const n=a(t,this._ptr[r],this._ptr[r+1],this._index);return nl-1||c>f-1)&&(u(this,Math.max(o+1,l),Math.max(c+1,f),i),l=this._size[0],f=this._size[1]),pn(o,l),pn(c,f);const d=a(o,this._ptr[c],this._ptr[c+1],this._index);return dArray.isArray(e)&&1===e.length?e[0]:e));if(2!==n.length)throw new Error("Only two dimensions matrix are supported");return n.forEach((function(e){if(!h(e)||!ye(e)||e<0)throw new TypeError("Invalid size, must contain positive integers (size: "+Kr(n)+")")})),u(r?this.clone():this,n[0],n[1],t)},i.prototype.reshape=function(e,t){if(!N(e))throw new TypeError("Array expected");if(2!==e.length)throw new Error("Sparse matrices can only be reshaped in two dimensions");e.forEach((function(t){if(!h(t)||!ye(t)||t<=-2||0===t)throw new TypeError("Invalid size, must contain positive integers or -1 (size: "+Kr(e)+")")}));const r=this._size[0]*this._size[1];if(r!==(e=yn(e,r))[0]*e[1])throw new Error("Reshaping sparse matrix will result in the wrong number of elements");const n=t?this.clone():this;if(this._size[0]===e[0]&&this._size[1]===e[1])return n;const i=[];for(let e=0;e=0&&r<=a&&y(e._values[i],r-0,t-0)}else{const i={};for(let t=r;t "+(this._values?Kr(this._values[o],e):"X")}return i},i.prototype.toString=function(){return Kr(this.toArray())},i.prototype.toJSON=function(){return{mathjs:"SparseMatrix",values:this._values,index:this._index,ptr:this._ptr,size:this._size,datatype:this._datatype}},i.prototype.diagonal=function(e){if(e){if(g(e)&&(e=e.toNumber()),!h(e)||!ye(e))throw new TypeError("The parameter k must be an integer number")}else e=0;const t=e>0?e:0,r=e<0?-e:0,n=this._size[0],o=this._size[1],a=Math.min(n-r,o-t),s=[],u=[],c=[];c[0]=0;for(let e=t;e0?o:0,f=o<0?-o:0,p=e[0],m=e[1],d=Math.min(p-f,m-l);let y;if(N(n)){if(n.length!==d)throw new Error("Invalid value array length");y=function(e){return n[e]}}else if(E(n)){const e=n.size();if(1!==e.length||e[0]!==d)throw new Error("Invalid matrix length");y=function(e){return n.get([e])}}else y=function(){return n};const x=[],b=[],v=[];for(let e=0;e=0&&t=u||i[l]!==t)){const e=n?n[c]:void 0;i.splice(l,0,t),n&&n.splice(l,0,e),i.splice(l<=c?c+1:c,1),n&&n.splice(l<=c?c+1:c,1)}else if(l=u||i[c]!==e)){const t=n?n[l]:void 0;i.splice(c,0,e),n&&n.splice(c,0,t),i.splice(c<=l?l+1:l,1),n&&n.splice(c<=l?l+1:l,1)}}},i}),{isClass:!0})),wi=de("number",["typed"],(e=>{let{typed:t}=e;const r=t("number",{"":function(){return 0},number:function(e){return e},string:function(e){if("NaN"===e)return NaN;const t=function(e){const t=e.match(/(0[box])([0-9a-fA-F]*)\.([0-9a-fA-F]*)/);return t?{input:e,radix:{"0b":2,"0o":8,"0x":16}[t[1]],integerPart:t[2],fractionalPart:t[3]}:null}(e);if(t)return function(e){const t=parseInt(e.integerPart,e.radix);let r=0;for(let t=0;t2**r-1)throw new SyntaxError(`String "${e}" is out of range`);i>=2**(r-1)&&(i-=2**r)}return i},BigNumber:function(e){return e.toNumber()},bigint:function(e){return Number(e)},Fraction:function(e){return e.valueOf()},Unit:t.referToSelf((e=>t=>{const r=t.clone();return r.value=e(t.value),r})),null:function(e){return 0},"Unit, string | Unit":function(e,t){return e.toNumber(t)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))});return r.fromJSON=function(e){return parseFloat(e.value)},r})),Ni=de("bigint",["typed"],(e=>{let{typed:t}=e;const r=t("bigint",{"":function(){return 0n},bigint:function(e){return e},number:function(e){return BigInt(e.toFixed())},BigNumber:function(e){return BigInt(e.round().toString())},Fraction:function(e){return BigInt(e.valueOf().toFixed())},"string | boolean":function(e){return BigInt(e)},null:function(e){return 0n},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))});return r.fromJSON=function(e){return BigInt(e.value)},r})),Ei="string",Ai=de(Ei,["typed"],(e=>{let{typed:t}=e;return t(Ei,{"":function(){return""},number:Me,null:function(e){return"null"},boolean:function(e){return e+""},string:function(e){return e},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e))),any:function(e){return String(e)}})})),Si="boolean",Mi=de(Si,["typed"],(e=>{let{typed:t}=e;return t(Si,{"":function(){return!1},boolean:function(e){return e},number:function(e){return!!e},null:function(e){return!1},BigNumber:function(e){return!e.isZero()},string:function(e){const t=e.toLowerCase();if("true"===t)return!0;if("false"===t)return!1;const r=Number(e);if(""!==e&&!isNaN(r))return!!r;throw new Error('Cannot convert "'+e+'" to a boolean')},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Ci=de("bignumber",["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t("bignumber",{"":function(){return new r(0)},number:function(e){return new r(e+"")},string:function(e){const t=e.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/);if(t){const n=t[2],i=r(t[1]),o=new r(2).pow(Number(n));if(i.gt(o.sub(1)))throw new SyntaxError(`String "${e}" is out of range`);const a=new r(2).pow(Number(n)-1);return i.gte(a)?i.sub(o):i}return new r(e)},BigNumber:function(e){return e},bigint:function(e){return new r(e.toString())},Unit:t.referToSelf((e=>t=>{const r=t.clone();return r.value=e(t.value),r})),Fraction:function(e){return new r(e.n).div(e.d).times(e.s)},null:function(e){return new r(0)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Ti=de("complex",["typed","Complex"],(e=>{let{typed:t,Complex:r}=e;return t("complex",{"":function(){return r.ZERO},number:function(e){return new r(e,0)},"number, number":function(e,t){return new r(e,t)},"BigNumber, BigNumber":function(e,t){return new r(e.toNumber(),t.toNumber())},Fraction:function(e){return new r(e.valueOf(),0)},Complex:function(e){return e.clone()},string:function(e){return r(e)},null:function(e){return r(0)},Object:function(e){if("re"in e&&"im"in e)return new r(e.re,e.im);if("r"in e&&"phi"in e||"abs"in e&&"arg"in e)return new r(e);throw new Error("Expected object with properties (re and im) or (r and phi) or (abs and arg)")},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Di=de("fraction",["typed","Fraction"],(e=>{let{typed:t,Fraction:r}=e;return t("fraction",{number:function(e){if(!isFinite(e)||isNaN(e))throw new Error(e+" cannot be represented as a fraction");return new r(e)},string:function(e){return new r(e)},"number, number":function(e,t){return new r(e,t)},null:function(e){return new r(0)},BigNumber:function(e){return new r(e.toString())},bigint:function(e){return new r(e.toString())},Fraction:function(e){return e},Unit:t.referToSelf((e=>t=>{const r=t.clone();return r.value=e(t.value),r})),Object:function(e){return new r(e)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Fi="matrix",Oi=de(Fi,["typed","Matrix","DenseMatrix","SparseMatrix"],(e=>{let{typed:t,Matrix:r,DenseMatrix:n,SparseMatrix:i}=e;return t(Fi,{"":function(){return o([])},string:function(e){return o([],e)},"string, string":function(e,t){return o([],e,t)},Array:function(e){return o(e)},Matrix:function(e){return o(e,e.storage())},"Array | Matrix, string":o,"Array | Matrix, string, string":o});function o(e,t,r){if("dense"===t||"default"===t||void 0===t)return new n(e,r);if("sparse"===t)return new i(e,r);throw new TypeError("Unknown matrix type "+JSON.stringify(t)+".")}})),Bi="matrixFromFunction",_i=de(Bi,["typed","matrix","isZero"],(e=>{let{typed:t,matrix:r,isZero:n}=e;return t(Bi,{"Array | Matrix, function, string, string":function(e,t,r,n){return i(e,t,r,n)},"Array | Matrix, function, string":function(e,t,r){return i(e,t,r)},"Matrix, function":function(e,t){return i(e,t,"dense")},"Array, function":function(e,t){return i(e,t,"dense").toArray()},"Array | Matrix, string, function":function(e,t,r){return i(e,r,t)},"Array | Matrix, string, string, function":function(e,t,r,n){return i(e,n,t,r)}});function i(e,t,i,o){let a;return a=void 0!==o?r(i,o):r(i),a.resize(e),a.forEach((function(e,r){const i=t(r);n(i)||a.set(r,i)})),a}})),zi="matrixFromRows",Ii=de(zi,["typed","matrix","flatten","size"],(e=>{let{typed:t,matrix:r,flatten:n,size:i}=e;return t(zi,{"...Array":function(e){return o(e)},"...Matrix":function(e){return r(o(e.map((e=>e.toArray()))))}});function o(e){if(0===e.length)throw new TypeError("At least one row is needed to construct a matrix.");const t=a(e[0]),r=[];for(const i of e){const e=a(i);if(e!==t)throw new TypeError("The vectors had different length: "+(0|t)+" ≠ "+(0|e));r.push(n(i))}return r}function a(e){const t=i(e);if(1===t.length)return t[0];if(2===t.length){if(1===t[0])return t[1];if(1===t[1])return t[0];throw new TypeError("At least one of the arguments is not a vector.")}throw new TypeError("Only one- or two-dimensional vectors are supported.")}})),ki="matrixFromColumns",qi=de(ki,["typed","matrix","flatten","size"],(e=>{let{typed:t,matrix:r,flatten:n,size:i}=e;return t(ki,{"...Array":function(e){return o(e)},"...Matrix":function(e){return r(o(e.map((e=>e.toArray()))))}});function o(e){if(0===e.length)throw new TypeError("At least one column is needed to construct a matrix.");const t=a(e[0]),r=[];for(let e=0;e{let{typed:t}=e;return t(Ri,{"Unit, Array":function(e,t){return e.splitUnit(t)}})})),ji="number",Ui="number, number";function Li(e){return Math.abs(e)}function $i(e,t){return e+t}function Hi(e,t){return e-t}function Gi(e,t){return e*t}function Zi(e){return-e}function Vi(e){return e}function Wi(e){return Ee(e)}function Yi(e){return e*e*e}function Ji(e){return Math.exp(e)}function Xi(e){return Ae(e)}function Qi(e,t){if(!ye(e)||!ye(t))throw new Error("Parameters in function lcm must be integer numbers");if(0===e||0===t)return 0;let r;const n=e*t;for(;0!==t;)r=t,t=e%r,e=r;return Math.abs(n/e)}function Ki(e){return we(e)}function eo(e){return ve(e)}function to(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:2;const r=t<0;if(r&&(t=-t),0===t)throw new Error("Root must be non-zero");if(e<0&&Math.abs(t)%2!=1)throw new Error("Root must be odd when a is negative.");if(0===e)return r?1/0:0;if(!isFinite(e))return r?0:e;let n=Math.pow(Math.abs(e),1/t);return n=e<0?-n:n,r?1/n:n}function ro(e){return be(e)}function no(e){return e*e}function io(e,t){let r,n,i,o,a=0,s=1,u=1,c=0;if(!ye(e)||!ye(t))throw new Error("Parameters in function xgcd must be integer numbers");for(;t;)n=Math.floor(e/t),i=e-n*t,r=a,a=s-n*a,s=r,r=u,u=c-n*u,c=r,e=t,t=i;return o=e<0?[-e,-s,-c]:[e,e?s:0,c],o}function oo(e,t){return e*e<1&&t===1/0||e*e>1&&t===-1/0?0:Math.pow(e,t)}function ao(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;if(!ye(t)||t<0||t>15)throw new Error("Number of decimals in function round must be an integer from 0 to 15 inclusive");return parseFloat(De(e,t))}Li.signature=ji,$i.signature=Ui,Hi.signature=Ui,Gi.signature=Ui,Zi.signature=ji,Vi.signature=ji,Wi.signature=ji,Yi.signature=ji,Ji.signature=ji,Xi.signature=ji,Qi.signature=Ui,Ki.signature=ji,eo.signature=ji,ro.signature=ji,no.signature=ji,io.signature=Ui,oo.signature=Ui;const so="unaryMinus",uo=de(so,["typed"],(e=>{let{typed:t}=e;return t(so,{number:Zi,"Complex | BigNumber | Fraction":e=>e.neg(),bigint:e=>-e,Unit:t.referToSelf((e=>r=>{const n=r.clone();return n.value=t.find(e,n.valueType())(r.value),n})),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0)))})})),co="unaryPlus",lo=de(co,["typed","config","numeric"],(e=>{let{typed:t,config:r,numeric:n}=e;return t(co,{number:Vi,Complex:function(e){return e},BigNumber:function(e){return e},bigint:function(e){return e},Fraction:function(e){return e},Unit:function(e){return e.clone()},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),boolean:function(e){return n(e?1:0,r.number)},string:function(e){return n(e,xe(e,r))}})})),fo=de("abs",["typed"],(e=>{let{typed:t}=e;return t("abs",{number:Li,"Complex | BigNumber | Fraction | Unit":e=>e.abs(),bigint:e=>e<0n?-e:e,"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0)))})})),po="apply",mo=de(po,["typed","isInteger"],(e=>{let{typed:t,isInteger:r}=e;return t(po,{"Array | Matrix, number | BigNumber, function":function(e,t,n){if(!r(t))throw new TypeError("Integer number expected for dimension");const i=Array.isArray(e)?un(e):e.size();if(t<0||t>=i.length)throw new sn(t,i.length);return E(e)?e.create(ho(e.valueOf(),t,n),e.datatype()):ho(e,t,n)}})}));function ho(e,t,r){let n,i,o;if(t<=0){if(Array.isArray(e[0])){for(o=function(e){const t=e.length,r=e[0].length;let n,i;const o=[];for(i=0;i{let{typed:t}=e;return t(go,{"number, number":$i,"Complex, Complex":function(e,t){return e.add(t)},"BigNumber, BigNumber":function(e,t){return e.plus(t)},"bigint, bigint":function(e,t){return e+t},"Fraction, Fraction":function(e,t){return e.add(t)},"Unit, Unit":t.referToSelf((e=>(r,n)=>{if(null===r.value||void 0===r.value)throw new Error("Parameter x contains a unit with undefined value");if(null===n.value||void 0===n.value)throw new Error("Parameter y contains a unit with undefined value");if(!r.equalBase(n))throw new Error("Units do not match");const i=r.clone();return i.value=t.find(e,[i.valueType(),n.valueType()])(i.value,n.value),i.fixPrefix=!1,i}))})})),xo="subtractScalar",bo=de(xo,["typed"],(e=>{let{typed:t}=e;return t(xo,{"number, number":Hi,"Complex, Complex":function(e,t){return e.sub(t)},"BigNumber, BigNumber":function(e,t){return e.minus(t)},"bigint, bigint":function(e,t){return e-t},"Fraction, Fraction":function(e,t){return e.sub(t)},"Unit, Unit":t.referToSelf((e=>(r,n)=>{if(null===r.value||void 0===r.value)throw new Error("Parameter x contains a unit with undefined value");if(null===n.value||void 0===n.value)throw new Error("Parameter y contains a unit with undefined value");if(!r.equalBase(n))throw new Error("Units do not match");const i=r.clone();return i.value=t.find(e,[i.valueType(),n.valueType()])(i.value,n.value),i.fixPrefix=!1,i}))})})),vo="cbrt",wo=de(vo,["config","typed","isNegative","unaryMinus","matrix","Complex","BigNumber","Fraction"],(e=>{let{config:t,typed:r,isNegative:n,unaryMinus:i,matrix:o,Complex:a,BigNumber:s,Fraction:u}=e;return r(vo,{number:Wi,Complex:c,"Complex, boolean":c,BigNumber:function(e){return e.cbrt()},Unit:function(e){if(e.value&&x(e.value)){let t=e.clone();return t.value=1,t=t.pow(1/3),t.value=c(e.value),t}{const t=n(e.value);let r;t&&(e.value=i(e.value)),r=g(e.value)?new s(1).div(3):b(e.value)?new u(1,3):1/3;const o=e.pow(r);return t&&(o.value=i(o.value)),o}}});function c(e,r){const n=e.arg()/3,i=e.abs(),s=new a(Wi(i),0).mul(new a(0,n).exp());if(r){const e=[s,new a(Wi(i),0).mul(new a(0,n+2*Math.PI/3).exp()),new a(Wi(i),0).mul(new a(0,n-2*Math.PI/3).exp())];return"Array"===t.matrix?e:o(e)}return s}})),No=de("matAlgo11xS0s",["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return function(e,n,i,o){const a=e._values,s=e._index,u=e._ptr,c=e._size,l=e._datatype;if(!a)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");const f=c[0],p=c[1];let m,d=r,h=0,g=i;"string"==typeof l&&(m=l,d=t.find(r,[m,m]),h=t.convert(0,m),n=t.convert(n,m),g=t.find(i,[m,m]));const y=[],x=[],b=[];for(let e=0;e{let{typed:t,DenseMatrix:r}=e;return function(e,n,i,o){const a=e._values,s=e._index,u=e._ptr,c=e._size,l=e._datatype;if(!a)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");const f=c[0],p=c[1];let m,d=i;"string"==typeof l&&(m=l,n=t.convert(n,m),d=t.find(i,[m,m]));const h=[],g=[],y=[];for(let e=0;e{let{typed:t}=e;return function(e,n,i,o){const a=e._data,s=e._size,u=e._datatype;let c,l=i;"string"==typeof u&&(c=u,n=t.convert(n,c),l=t.find(i,[c,c]));const f=s.length>0?r(l,0,s,s[0],a,n,o):[];return e.createDenseMatrix({data:f,size:ae(s),datatype:c})};function r(e,t,n,i,o,a,s){const u=[];if(t===n.length-1)for(let t=0;t{let{typed:t,config:r,round:n}=e;return t(So,{number:function(e){return _e(e,n(e),r.relTol,r.absTol)?n(e):Math.ceil(e)},"number, number":function(e,t){if(_e(e,n(e,t),r.relTol,r.absTol))return n(e,t);{let[r,n]=`${e}e`.split("e");const i=Math.ceil(Number(`${r}e${Number(n)+t}`));return[r,n]=`${i}e`.split("e"),Number(`${r}e${Number(n)-t}`)}}})})),To=de(So,Mo,(e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:o,zeros:a,DenseMatrix:s}=e;const u=No({typed:t,equalScalar:o}),c=Eo({typed:t,DenseMatrix:s}),l=Ao({typed:t}),f=Co({typed:t,config:r,round:n});return t("ceil",{number:f.signatures.number,"number,number":f.signatures["number,number"],Complex:function(e){return e.ceil()},"Complex, number":function(e,t){return e.ceil(t)},"Complex, BigNumber":function(e,t){return e.ceil(t.toNumber())},BigNumber:function(e){return ri(e,n(e),r.relTol,r.absTol)?n(e):e.ceil()},"BigNumber, BigNumber":function(e,t){return ri(e,n(e,t),r.relTol,r.absTol)?n(e,t):e.toDecimalPlaces(t.toNumber(),Or.ROUND_CEIL)},Fraction:function(e){return e.ceil()},"Fraction, number":function(e,t){return e.ceil(t)},"Fraction, BigNumber":function(e,t){return e.ceil(t.toNumber())},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),"Array, number | BigNumber":t.referToSelf((e=>(t,r)=>Zn(t,(t=>e(t,r)),!0))),"SparseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>u(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>l(t,r,e,!1))),"number | Complex | Fraction | BigNumber, Array":t.referToSelf((e=>(t,r)=>l(i(r),t,e,!0).valueOf())),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf((e=>(t,r)=>o(t,0)?a(r.size(),r.storage()):"dense"===r.storage()?l(r,t,e,!0):c(r,t,e,!0)))})})),Do="cube",Fo=de(Do,["typed"],(e=>{let{typed:t}=e;return t(Do,{number:Yi,Complex:function(e){return e.mul(e).mul(e)},BigNumber:function(e){return e.times(e).times(e)},bigint:function(e){return e*e*e},Fraction:function(e){return e.pow(3)},Unit:function(e){return e.pow(3)}})})),Oo=de("exp",["typed"],(e=>{let{typed:t}=e;return t("exp",{number:Ji,Complex:function(e){return e.exp()},BigNumber:function(e){return e.exp()}})})),Bo="expm1",_o=de(Bo,["typed","Complex"],(e=>{let{typed:t,Complex:r}=e;return t(Bo,{number:Xi,Complex:function(e){const t=Math.exp(e.re);return new r(t*Math.cos(e.im)-1,t*Math.sin(e.im))},BigNumber:function(e){return e.exp().minus(1)}})})),zo="fix",Io=["typed","Complex","matrix","ceil","floor","equalScalar","zeros","DenseMatrix"],ko=de(zo,["typed","ceil","floor"],(e=>{let{typed:t,ceil:r,floor:n}=e;return t(zo,{number:function(e){return e>0?n(e):r(e)},"number, number":function(e,t){return e>0?n(e,t):r(e,t)}})})),qo=de(zo,Io,(e=>{let{typed:t,Complex:r,matrix:n,ceil:i,floor:o,equalScalar:a,zeros:s,DenseMatrix:u}=e;const c=Eo({typed:t,DenseMatrix:u}),l=Ao({typed:t}),f=ko({typed:t,ceil:i,floor:o});return t("fix",{number:f.signatures.number,"number, number | BigNumber":f.signatures["number,number"],Complex:function(e){return new r(e.re>0?Math.floor(e.re):Math.ceil(e.re),e.im>0?Math.floor(e.im):Math.ceil(e.im))},"Complex, number":function(e,t){return new r(e.re>0?o(e.re,t):i(e.re,t),e.im>0?o(e.im,t):i(e.im,t))},"Complex, BigNumber":function(e,t){const n=t.toNumber();return new r(e.re>0?o(e.re,n):i(e.re,n),e.im>0?o(e.im,n):i(e.im,n))},BigNumber:function(e){return e.isNegative()?i(e):o(e)},"BigNumber, number | BigNumber":function(e,t){return e.isNegative()?i(e,t):o(e,t)},Fraction:function(e){return e.s<0?e.ceil():e.floor()},"Fraction, number | BigNumber":function(e,t){return e.s<0?i(e,t):o(e,t)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),"Array | Matrix, number | BigNumber":t.referToSelf((e=>(t,r)=>Zn(t,(t=>e(t,r)),!0))),"number | Complex | Fraction | BigNumber, Array":t.referToSelf((e=>(t,r)=>l(n(r),t,e,!0).valueOf())),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf((e=>(t,r)=>a(t,0)?s(r.size(),r.storage()):"dense"===r.storage()?l(r,t,e,!0):c(r,t,e,!0)))})})),Ro="floor",Po=["typed","config","round","matrix","equalScalar","zeros","DenseMatrix"],jo=de(Ro,["typed","config","round"],(e=>{let{typed:t,config:r,round:n}=e;return t(Ro,{number:function(e){return _e(e,n(e),r.relTol,r.absTol)?n(e):Math.floor(e)},"number, number":function(e,t){if(_e(e,n(e,t),r.relTol,r.absTol))return n(e,t);{let[r,n]=`${e}e`.split("e");const i=Math.floor(Number(`${r}e${Number(n)+t}`));return[r,n]=`${i}e`.split("e"),Number(`${r}e${Number(n)-t}`)}}})})),Uo=de(Ro,Po,(e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:o,zeros:a,DenseMatrix:s}=e;const u=No({typed:t,equalScalar:o}),c=Eo({typed:t,DenseMatrix:s}),l=Ao({typed:t}),f=jo({typed:t,config:r,round:n});return t("floor",{number:f.signatures.number,"number,number":f.signatures["number,number"],Complex:function(e){return e.floor()},"Complex, number":function(e,t){return e.floor(t)},"Complex, BigNumber":function(e,t){return e.floor(t.toNumber())},BigNumber:function(e){return ri(e,n(e),r.relTol,r.absTol)?n(e):e.floor()},"BigNumber, BigNumber":function(e,t){return ri(e,n(e,t),r.relTol,r.absTol)?n(e,t):e.toDecimalPlaces(t.toNumber(),Or.ROUND_FLOOR)},Fraction:function(e){return e.floor()},"Fraction, number":function(e,t){return e.floor(t)},"Fraction, BigNumber":function(e,t){return e.floor(t.toNumber())},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),"Array, number | BigNumber":t.referToSelf((e=>(t,r)=>Zn(t,(t=>e(t,r)),!0))),"SparseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>u(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>l(t,r,e,!1))),"number | Complex | Fraction | BigNumber, Array":t.referToSelf((e=>(t,r)=>l(i(r),t,e,!0).valueOf())),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf((e=>(t,r)=>o(t,0)?a(r.size(),r.storage()):"dense"===r.storage()?l(r,t,e,!0):c(r,t,e,!0)))})})),Lo=de("matAlgo02xDS0",["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return function(e,n,i,o){const a=e._data,s=e._size,u=e._datatype||e.getDataType(),c=n._values,l=n._index,f=n._ptr,p=n._size,m=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(s.length!==p.length)throw new an(s.length,p.length);if(s[0]!==p[0]||s[1]!==p[1])throw new RangeError("Dimension mismatch. Matrix A ("+s+") must match Matrix B ("+p+")");if(!c)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");const d=s[0],h=s[1];let g,y=r,x=0,b=i;"string"==typeof u&&u===m&&"mixed"!==u&&(g=u,y=t.find(r,[g,g]),x=t.convert(0,g),b=t.find(i,[g,g]));const v=[],w=[],N=[];for(let e=0;e{let{typed:t}=e;return function(e,r,n,i){const o=e._data,a=e._size,s=e._datatype||e.getDataType(),u=r._values,c=r._index,l=r._ptr,f=r._size,p=r._datatype||void 0===r._data?r._datatype:r.getDataType();if(a.length!==f.length)throw new an(a.length,f.length);if(a[0]!==f[0]||a[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+a+") must match Matrix B ("+f+")");if(!u)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");const m=a[0],d=a[1];let h,g=0,y=n;"string"==typeof s&&s===p&&"mixed"!==s&&(h=s,g=t.convert(0,h),y=t.find(n,[h,h]));const x=[];for(let e=0;e{let{typed:t,equalScalar:r}=e;return function(e,n,i){const o=e._values,a=e._index,s=e._ptr,u=e._size,c=e._datatype||void 0===e._data?e._datatype:e.getDataType(),l=n._values,f=n._index,p=n._ptr,m=n._size,d=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(u.length!==m.length)throw new an(u.length,m.length);if(u[0]!==m[0]||u[1]!==m[1])throw new RangeError("Dimension mismatch. Matrix A ("+u+") must match Matrix B ("+m+")");const h=u[0],g=u[1];let y,x=r,b=0,v=i;"string"==typeof c&&c===d&&"mixed"!==c&&(y=c,x=t.find(r,[y,y]),b=t.convert(0,y),v=t.find(i,[y,y]));const w=o&&l?[]:void 0,N=[],E=[],A=w?[]:void 0,S=w?[]:void 0,M=[],C=[];let T,D,F,O;for(D=0;D{let{typed:t}=e;return function(e,n,i){const o=e._data,a=e._size,s=e._datatype,u=n._data,c=n._size,l=n._datatype,f=[];if(a.length!==c.length)throw new an(a.length,c.length);for(let e=0;e0?r(m,0,f,f[0],o,u):[];return e.createDenseMatrix({data:d,size:f,datatype:p})};function r(e,t,n,i,o,a){const s=[];if(t===n.length-1)for(let t=0;tfunction(e,t){return ce(e.size(),t)?e:e.create(In(e.valueOf(),t),e.datatype())}(e,r)))}const Vo=de("matrixAlgorithmSuite",["typed","matrix"],(e=>{let{typed:t,matrix:r}=e;const n=Go({typed:t}),i=Ao({typed:t});return function(e){const o=e.elop,a=e.SD||e.DS;let s;o?(s={"DenseMatrix, DenseMatrix":(e,t)=>n(...Zo(e,t),o),"Array, Array":(e,t)=>n(...Zo(r(e),r(t)),o).valueOf(),"Array, DenseMatrix":(e,t)=>n(...Zo(r(e),t),o),"DenseMatrix, Array":(e,t)=>n(...Zo(e,r(t)),o)},e.SS&&(s["SparseMatrix, SparseMatrix"]=(t,r)=>e.SS(...Zo(t,r),o,!1)),e.DS&&(s["DenseMatrix, SparseMatrix"]=(t,r)=>e.DS(...Zo(t,r),o,!1),s["Array, SparseMatrix"]=(t,n)=>e.DS(...Zo(r(t),n),o,!1)),a&&(s["SparseMatrix, DenseMatrix"]=(e,t)=>a(...Zo(t,e),o,!0),s["SparseMatrix, Array"]=(e,t)=>a(...Zo(r(t),e),o,!0))):(s={"DenseMatrix, DenseMatrix":t.referToSelf((e=>(t,r)=>n(...Zo(t,r),e))),"Array, Array":t.referToSelf((e=>(t,i)=>n(...Zo(r(t),r(i)),e).valueOf())),"Array, DenseMatrix":t.referToSelf((e=>(t,i)=>n(...Zo(r(t),i),e))),"DenseMatrix, Array":t.referToSelf((e=>(t,i)=>n(...Zo(t,r(i)),e)))},e.SS&&(s["SparseMatrix, SparseMatrix"]=t.referToSelf((t=>(r,n)=>e.SS(...Zo(r,n),t,!1)))),e.DS&&(s["DenseMatrix, SparseMatrix"]=t.referToSelf((t=>(r,n)=>e.DS(...Zo(r,n),t,!1))),s["Array, SparseMatrix"]=t.referToSelf((t=>(n,i)=>e.DS(...Zo(r(n),i),t,!1)))),a&&(s["SparseMatrix, DenseMatrix"]=t.referToSelf((e=>(t,r)=>a(...Zo(r,t),e,!0))),s["SparseMatrix, Array"]=t.referToSelf((e=>(t,n)=>a(...Zo(r(n),t),e,!0)))));const u=e.scalar||"any";(e.Ds||e.Ss)&&(o?(s["DenseMatrix,"+u]=(e,t)=>i(e,t,o,!1),s[u+", DenseMatrix"]=(e,t)=>i(t,e,o,!0),s["Array,"+u]=(e,t)=>i(r(e),t,o,!1).valueOf(),s[u+", Array"]=(e,t)=>i(r(t),e,o,!0).valueOf()):(s["DenseMatrix,"+u]=t.referToSelf((e=>(t,r)=>i(t,r,e,!1))),s[u+", DenseMatrix"]=t.referToSelf((e=>(t,r)=>i(r,t,e,!0))),s["Array,"+u]=t.referToSelf((e=>(t,n)=>i(r(t),n,e,!1).valueOf())),s[u+", Array"]=t.referToSelf((e=>(t,n)=>i(r(n),t,e,!0).valueOf()))));const c=void 0!==e.sS?e.sS:e.Ss;return o?(e.Ss&&(s["SparseMatrix,"+u]=(t,r)=>e.Ss(t,r,o,!1)),c&&(s[u+", SparseMatrix"]=(e,t)=>c(t,e,o,!0))):(e.Ss&&(s["SparseMatrix,"+u]=t.referToSelf((t=>(r,n)=>e.Ss(r,n,t,!1)))),c&&(s[u+", SparseMatrix"]=t.referToSelf((e=>(t,r)=>c(r,t,e,!0))))),o&&o.signatures&&se(s,o.signatures),s}})),Wo=de("mod",["typed","config","round","matrix","equalScalar","zeros","DenseMatrix","concat"],(e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:o,zeros:a,DenseMatrix:s,concat:u}=e;const c=Uo({typed:t,config:r,round:n,matrix:i,equalScalar:o,zeros:a,DenseMatrix:s}),l=Lo({typed:t,equalScalar:o}),f=$o({typed:t}),p=Ho({typed:t,equalScalar:o}),m=No({typed:t,equalScalar:o}),d=Eo({typed:t,DenseMatrix:s});return t("mod",{"number, number":function(e,t){return 0===t?e:e-t*c(e/t)},"BigNumber, BigNumber":function(e,t){return t.isZero()?e:e.sub(t.mul(c(e.div(t))))},"bigint, bigint":function(e,t){if(0n===t)return e;if(e<0){const r=e%t;return 0n===r?r:r+t}return e%t},"Fraction, Fraction":function(e,t){return t.equals(0)?e:e.sub(t.mul(c(e.div(t))))}},Vo({typed:t,matrix:i,concat:u})({SS:p,DS:f,SD:l,Ss:m,sS:d}))})),Yo=de("matAlgo01xDSid",["typed"],(e=>{let{typed:t}=e;return function(e,r,n,i){const o=e._data,a=e._size,s=e._datatype||e.getDataType(),u=r._values,c=r._index,l=r._ptr,f=r._size,p=r._datatype||void 0===r._data?r._datatype:r.getDataType();if(a.length!==f.length)throw new an(a.length,f.length);if(a[0]!==f[0]||a[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+a+") must match Matrix B ("+f+")");if(!u)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");const m=a[0],d=a[1],h="string"==typeof s&&"mixed"!==s&&s===p?s:void 0,g=h?t.find(n,[h,h]):n;let y,x;const b=[];for(y=0;y{let{typed:t,equalScalar:r}=e;return function(e,n,i){const o=e._values,a=e._index,s=e._ptr,u=e._size,c=e._datatype||void 0===e._data?e._datatype:e.getDataType(),l=n._values,f=n._index,p=n._ptr,m=n._size,d=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(u.length!==m.length)throw new an(u.length,m.length);if(u[0]!==m[0]||u[1]!==m[1])throw new RangeError("Dimension mismatch. Matrix A ("+u+") must match Matrix B ("+m+")");const h=u[0],g=u[1];let y,x=r,b=0,v=i;"string"==typeof c&&c===d&&"mixed"!==c&&(y=c,x=t.find(r,[y,y]),b=t.convert(0,y),v=t.find(i,[y,y]));const w=o&&l?[]:void 0,N=[],E=[],A=o&&l?[]:void 0,S=o&&l?[]:void 0,M=[],C=[];let T,D,F,O,B;for(D=0;D{let{typed:t,DenseMatrix:r}=e;return function(e,n,i,o){const a=e._values,s=e._index,u=e._ptr,c=e._size,l=e._datatype;if(!a)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");const f=c[0],p=c[1];let m,d=i;"string"==typeof l&&(m=l,n=t.convert(n,m),d=t.find(i,[m,m]));const h=[],g=[],y=[];for(let e=0;eArray.isArray(e)))}const ra=de("gcd",["typed","config","round","matrix","equalScalar","zeros","BigNumber","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,config:n,round:i,equalScalar:o,zeros:a,BigNumber:s,DenseMatrix:u,concat:c}=e;const l=Wo({typed:t,config:n,round:i,matrix:r,equalScalar:o,zeros:a,DenseMatrix:u,concat:c}),f=Yo({typed:t}),p=Jo({typed:t,equalScalar:o}),m=Xo({typed:t,DenseMatrix:u});return t("gcd",{"number, number":function(e,t){if(!ye(e)||!ye(t))throw new Error("Parameters in function gcd must be integer numbers");let r;for(;0!==t;)r=l(e,t),e=t,t=r;return e<0?-e:e},"BigNumber, BigNumber":function(e,t){if(!e.isInt()||!t.isInt())throw new Error("Parameters in function gcd must be integer numbers");const r=new s(0);for(;!t.isZero();){const r=l(e,t);e=t,t=r}return e.lt(r)?e.neg():e},"Fraction, Fraction":(e,t)=>e.gcd(t)},Vo({typed:t,matrix:r,concat:c})({SS:p,DS:f,Ss:m}),{[ea]:t.referToSelf((e=>(t,r,n)=>{let i=e(t,r);for(let t=0;tt=>{if(1===t.length&&Array.isArray(t[0])&&ta(t[0]))return e(...t[0]);if(ta(t))return e(...t);throw new Qo("gcd() supports only 1d matrices!")})),Matrix:t.referToSelf((e=>t=>e(t.toArray())))})})),na=de("matAlgo06xS0S0",["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return function(e,n,i){const o=e._values,a=e._size,s=e._datatype||void 0===e._data?e._datatype:e.getDataType(),u=n._values,c=n._size,l=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(a.length!==c.length)throw new an(a.length,c.length);if(a[0]!==c[0]||a[1]!==c[1])throw new RangeError("Dimension mismatch. Matrix A ("+a+") must match Matrix B ("+c+")");const f=a[0],p=a[1];let m,d=r,h=0,g=i;"string"==typeof s&&s===l&&"mixed"!==s&&(m=s,d=t.find(r,[m,m]),h=t.convert(0,m),g=t.find(i,[m,m]));const y=o&&u?[]:void 0,x=[],b=[],v=y?[]:void 0,w=[],N=[];for(let t=0;t{let{typed:t,matrix:r,equalScalar:n,concat:i}=e;const o=Lo({typed:t,equalScalar:n}),a=na({typed:t,equalScalar:n}),s=No({typed:t,equalScalar:n}),u=Vo({typed:t,matrix:r,concat:i}),c="number | BigNumber | Fraction | Matrix | Array",l={};return l[`${c}, ${c}, ...${c}`]=t.referToSelf((e=>(t,r,n)=>{let i=e(t,r);for(let t=0;te.lcm(t)},u({SS:a,DS:o,Ss:s}),l)})),oa="log10",aa=de(oa,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(oa,{number:function(e){return e>=0||r.predictable?Ki(e):new n(e,0).log().div(Math.LN10)},Complex:function(e){return new n(e).log().div(Math.LN10)},BigNumber:function(e){return!e.isNegative()||r.predictable?e.log():new n(e.toNumber(),0).log().div(Math.LN10)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),sa="log2",ua=de(sa,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(sa,{number:function(e){return e>=0||r.predictable?eo(e):i(new n(e,0))},Complex:i,BigNumber:function(e){return!e.isNegative()||r.predictable?e.log(2):i(new n(e.toNumber(),0))},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))});function i(e){const t=Math.sqrt(e.re*e.re+e.im*e.im);return new n(Math.log2?Math.log2(t):Math.log(t)/Math.LN2,Math.atan2(e.im,e.re)/Math.LN2)}})),ca=de("multiplyScalar",["typed"],(e=>{let{typed:t}=e;return t("multiplyScalar",{"number, number":Gi,"Complex, Complex":function(e,t){return e.mul(t)},"BigNumber, BigNumber":function(e,t){return e.times(t)},"bigint, bigint":function(e,t){return e*t},"Fraction, Fraction":function(e,t){return e.mul(t)},"number | Fraction | BigNumber | Complex, Unit":(e,t)=>t.multiply(e),"Unit, number | Fraction | BigNumber | Complex | Unit":(e,t)=>e.multiply(t)})})),la="multiply",fa=de(la,["typed","matrix","addScalar","multiplyScalar","equalScalar","dot"],(e=>{let{typed:t,matrix:r,addScalar:n,multiplyScalar:i,equalScalar:o,dot:a}=e;const s=No({typed:t,equalScalar:o}),u=Ao({typed:t});function c(e,t){switch(e.length){case 1:switch(t.length){case 1:if(e[0]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Vectors must have the same length");break;case 2:if(e[0]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Vector length ("+e[0]+") must match Matrix rows ("+t[0]+")");break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix B has "+t.length+" dimensions)")}break;case 2:switch(t.length){case 1:if(e[1]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Matrix columns ("+e[1]+") must match Vector length ("+t[0]+")");break;case 2:if(e[1]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Matrix A columns ("+e[1]+") must match Matrix B rows ("+t[0]+")");break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix B has "+t.length+" dimensions)")}break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix A has "+e.length+" dimensions)")}}const l=t("_multiplyMatrixVector",{"DenseMatrix, any":function(e,r){const o=e._data,a=e._size,s=e._datatype||e.getDataType(),u=r._data,c=r._datatype||r.getDataType(),l=a[0],f=a[1];let p,m=n,d=i;s&&c&&s===c&&"string"==typeof s&&"mixed"!==s&&(p=s,m=t.find(n,[p,p]),d=t.find(i,[p,p]));const h=[];for(let e=0;et){let e=0;for(let n=0;n(t,n)=>{c(un(t),un(n));const i=e(r(t),r(n));return E(i)?i.valueOf():i})),"Matrix, Matrix":function(e,r){const o=e.size(),s=r.size();return c(o,s),1===o.length?1===s.length?function(e,t,r){if(0===r)throw new Error("Cannot multiply two empty vectors");return a(e,t)}(e,r,o[0]):function(e,r){if("dense"!==r.storage())throw new Error("Support for SparseMatrix not implemented");return function(e,r){const o=e._data,a=e._size,s=e._datatype||e.getDataType(),u=r._data,c=r._size,l=r._datatype||r.getDataType(),f=a[0],p=c[1];let m,d=n,h=i;s&&l&&s===l&&"string"==typeof s&&"mixed"!==s&&(m=s,d=t.find(n,[m,m]),h=t.find(i,[m,m]));const g=[];for(let e=0;e(t,n)=>e(t,r(n)))),"Array, Matrix":t.referToSelf((e=>(t,n)=>e(r(t,n.storage()),n))),"SparseMatrix, any":function(e,t){return s(e,t,i,!1)},"DenseMatrix, any":function(e,t){return u(e,t,i,!1)},"any, SparseMatrix":function(e,t){return s(t,e,i,!0)},"any, DenseMatrix":function(e,t){return u(t,e,i,!0)},"Array, any":function(e,t){return u(r(e),t,i,!1).valueOf()},"any, Array":function(e,t){return u(r(t),e,i,!0).valueOf()},"any, any":i,"any, any, ...any":t.referToSelf((e=>(t,r,n)=>{let i=e(t,r);for(let t=0;t{let{typed:t,matrix:r,equalScalar:n,BigNumber:i,concat:o}=e;const a=Yo({typed:t}),s=Lo({typed:t,equalScalar:n}),u=na({typed:t,equalScalar:n}),c=No({typed:t,equalScalar:n}),l=Vo({typed:t,matrix:r,concat:o});function f(){throw new Error("Complex number not supported in function nthRoot. Use nthRoots instead.")}return t(pa,{number:to,"number, number":to,BigNumber:e=>p(e,new i(2)),"BigNumber, BigNumber":p,Complex:f,"Complex, number":f,Array:t.referTo("DenseMatrix,number",(e=>t=>e(r(t),2).valueOf())),DenseMatrix:t.referTo("DenseMatrix,number",(e=>t=>e(t,2))),SparseMatrix:t.referTo("SparseMatrix,number",(e=>t=>e(t,2))),"SparseMatrix, SparseMatrix":t.referToSelf((e=>(t,r)=>{if(1===r.density())return u(t,r,e);throw new Error("Root must be non-zero")})),"DenseMatrix, SparseMatrix":t.referToSelf((e=>(t,r)=>{if(1===r.density())return a(t,r,e,!1);throw new Error("Root must be non-zero")})),"Array, SparseMatrix":t.referTo("DenseMatrix,SparseMatrix",(e=>(t,n)=>e(r(t),n))),"number | BigNumber, SparseMatrix":t.referToSelf((e=>(t,r)=>{if(1===r.density())return c(r,t,e,!0);throw new Error("Root must be non-zero")}))},l({scalar:"number | BigNumber",SD:s,Ss:c,sS:!1}));function p(e,t){const r=i.precision,n=i.clone({precision:r+2}),o=new i(0),a=new n(1),s=t.isNegative();if(s&&(t=t.neg()),t.isZero())throw new Error("Root must be non-zero");if(e.isNegative()&&!t.abs().mod(2).equals(1))throw new Error("Root must be odd when a is negative.");if(e.isZero())return s?new n(1/0):0;if(!e.isFinite())return s?o:e;let u=e.abs().pow(a.div(t));return u=e.isNeg()?u.neg():u,new i((s?a.div(u):u).toPrecision(r))}})),da="sign",ha=de(da,["typed","BigNumber","Fraction","complex"],(e=>{let{typed:t,BigNumber:r,complex:n,Fraction:i}=e;return t(da,{number:ro,Complex:function(e){return 0===e.im?n(ro(e.re)):e.sign()},BigNumber:function(e){return new r(e.cmp(0))},bigint:function(e){return e>0n?1n:e<0n?-1n:0n},Fraction:function(e){return new i(e.s,1)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),Unit:t.referToSelf((e=>r=>{if(!r._isDerived()&&0!==r.units[0].unit.offset)throw new TypeError("sign is ambiguous for units with offset");return t.find(e,r.valueType())(r.value)}))})})),ga=de("sqrt",["config","typed","Complex"],(e=>{let{config:t,typed:r,Complex:n}=e;return r("sqrt",{number:i,Complex:function(e){return e.sqrt()},BigNumber:function(e){return!e.isNegative()||t.predictable?e.sqrt():i(e.toNumber())},Unit:function(e){return e.pow(.5)}});function i(e){return isNaN(e)?NaN:e>=0||t.predictable?Math.sqrt(e):new n(e,0).sqrt()}})),ya="square",xa=de(ya,["typed"],(e=>{let{typed:t}=e;return t(ya,{number:no,Complex:function(e){return e.mul(e)},BigNumber:function(e){return e.times(e)},bigint:function(e){return e*e},Fraction:function(e){return e.mul(e)},Unit:function(e){return e.pow(2)}})})),ba="subtract",va=de(ba,["typed","matrix","equalScalar","subtractScalar","unaryMinus","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,subtractScalar:i,unaryMinus:o,DenseMatrix:a,concat:s}=e;const u=Yo({typed:t}),c=$o({typed:t}),l=Ho({typed:t,equalScalar:n}),f=Xo({typed:t,DenseMatrix:a}),p=Eo({typed:t,DenseMatrix:a}),m=Vo({typed:t,matrix:r,concat:s});return t(ba,{"any, any":i},m({elop:i,SS:l,DS:u,SD:c,Ss:p,sS:f}))})),wa="xgcd",Na=de(wa,["typed","config","matrix","BigNumber"],(e=>{let{typed:t,config:r,matrix:n,BigNumber:i}=e;return t(wa,{"number, number":function(e,t){const i=io(e,t);return"Array"===r.matrix?i:n(i)},"BigNumber, BigNumber":function(e,t){let o,a,s;const u=new i(0),c=new i(1);let l,f=u,p=c,m=c,d=u;if(!e.isInt()||!t.isInt())throw new Error("Parameters in function xgcd must be integer numbers");for(;!t.isZero();)a=e.div(t).floor(),s=e.mod(t),o=f,f=p.minus(a.times(f)),p=o,o=m,m=d.minus(a.times(m)),d=o,e=t,t=s;return l=e.lt(u)?[e.neg(),p.neg(),d.neg()]:[e,e.isZero()?0:p,d],"Array"===r.matrix?l:n(l)}})})),Ea="invmod",Aa=de(Ea,["typed","config","BigNumber","xgcd","equal","smaller","mod","add","isInteger"],(e=>{let{typed:t,config:r,BigNumber:n,xgcd:i,equal:o,smaller:a,mod:s,add:u,isInteger:c}=e;return t(Ea,{"number, number":l,"BigNumber, BigNumber":l});function l(e,t){if(!c(e)||!c(t))throw new Error("Parameters in function invmod must be integer numbers");if(e=s(e,t),o(t,0))throw new Error("Divisor must be non zero");let r=i(e,t);r=r.valueOf();let[l,f]=r;return o(l,n(1))?(f=s(f,t),a(f,n(0))&&(f=u(f,t)),f):NaN}})),Sa=de("matAlgo09xS0Sf",["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return function(e,n,i){const o=e._values,a=e._index,s=e._ptr,u=e._size,c=e._datatype||void 0===e._data?e._datatype:e.getDataType(),l=n._values,f=n._index,p=n._ptr,m=n._size,d=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(u.length!==m.length)throw new an(u.length,m.length);if(u[0]!==m[0]||u[1]!==m[1])throw new RangeError("Dimension mismatch. Matrix A ("+u+") must match Matrix B ("+m+")");const h=u[0],g=u[1];let y,x=r,b=0,v=i;"string"==typeof c&&c===d&&"mixed"!==c&&(y=c,x=t.find(r,[y,y]),b=t.convert(0,y),v=t.find(i,[y,y]));const w=o&&l?[]:void 0,N=[],E=[],A=w?[]:void 0,S=[];let M,C,T,D,F;for(C=0;C{let{typed:t,matrix:r,equalScalar:n,multiplyScalar:i,concat:o}=e;const a=Lo({typed:t,equalScalar:n}),s=Sa({typed:t,equalScalar:n}),u=No({typed:t,equalScalar:n}),c=Vo({typed:t,matrix:r,concat:o});return t(Ma,c({elop:i,SS:s,DS:a,Ss:u}))}));function Ta(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitAnd");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);if(e.isZero()||t.eq(-1)||e.eq(t))return e;if(t.isZero()||e.eq(-1))return t;if(!e.isFinite()||!t.isFinite()){if(!e.isFinite()&&!t.isFinite())return e.isNegative()===t.isNegative()?e:new r(0);if(!e.isFinite())return t.isNegative()?e:e.isNegative()?new r(0):t;if(!t.isFinite())return e.isNegative()?t:t.isNegative()?new r(0):e}return Oa(e,t,(function(e,t){return e&t}))}function Da(e){if(e.isFinite()&&!e.isInteger())throw new Error("Integer expected in function bitNot");const t=e.constructor,r=t.precision;t.config({precision:1e9});const n=e.plus(new t(1));return n.s=-n.s||null,t.config({precision:r}),n}function Fa(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitOr");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);const n=new r(-1);return e.isZero()||t.eq(n)||e.eq(t)?t:t.isZero()||e.eq(n)?e:e.isFinite()&&t.isFinite()?Oa(e,t,(function(e,t){return e|t})):!e.isFinite()&&!e.isNegative()&&t.isNegative()||e.isNegative()&&!t.isNegative()&&!t.isFinite()?n:e.isNegative()&&t.isNegative()?e.isFinite()?e:t:e.isFinite()?t:e}function Oa(e,t,r){const n=e.constructor;let i,o;const a=+(e.s<0),s=+(t.s<0);if(a){i=Ba(Da(e));for(let e=0;e0;)r(u[--f],c[--p])===m&&(d=d.plus(h)),h=h.times(g);for(;p>0;)r(l,c[--p])===m&&(d=d.plus(h)),h=h.times(g);return n.config({precision:y}),0===m&&(d.s=-d.s),d}function Ba(e){const t=e.d;let r=t[0]+"";for(let e=1;e0)if(++i>a)for(i-=a;i--;)o+="0";else i1&&(null!==s[e+1]&&void 0!==s[e+1]||(s[e+1]=0),s[e+1]+=s[e]>>1,s[e]&=1)}return s.reverse()}function _a(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitXor");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);if(e.isZero())return t;if(t.isZero())return e;if(e.eq(t))return new r(0);const n=new r(-1);return e.eq(n)?Da(t):t.eq(n)?Da(e):e.isFinite()&&t.isFinite()?Oa(e,t,(function(e,t){return e^t})):e.isFinite()||t.isFinite()?new r(e.isNegative()===t.isNegative()?1/0:-1/0):n}function za(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function leftShift");const r=e.constructor;return e.isNaN()||t.isNaN()||t.isNegative()&&!t.isZero()?new r(NaN):e.isZero()||t.isZero()?e:e.isFinite()||t.isFinite()?t.lt(55)?e.times(Math.pow(2,t.toNumber())+""):e.times(new r(2).pow(t)):new r(NaN)}function Ia(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function rightArithShift");const r=e.constructor;return e.isNaN()||t.isNaN()||t.isNegative()&&!t.isZero()?new r(NaN):e.isZero()||t.isZero()?e:t.isFinite()?t.lt(55)?e.div(Math.pow(2,t.toNumber())+"").floor():e.div(new r(2).pow(t)).floor():e.isNegative()?new r(-1):e.isFinite()?new r(0):new r(NaN)}const ka="number, number";function qa(e,t){if(!ye(e)||!ye(t))throw new Error("Integers expected in function bitAnd");return e&t}function Ra(e){if(!ye(e))throw new Error("Integer expected in function bitNot");return~e}function Pa(e,t){if(!ye(e)||!ye(t))throw new Error("Integers expected in function bitOr");return e|t}function ja(e,t){if(!ye(e)||!ye(t))throw new Error("Integers expected in function bitXor");return e^t}function Ua(e,t){if(!ye(e)||!ye(t))throw new Error("Integers expected in function leftShift");return e<>t}function $a(e,t){if(!ye(e)||!ye(t))throw new Error("Integers expected in function rightLogShift");return e>>>t}qa.signature=ka,Ra.signature="number",Pa.signature=ka,ja.signature=ka,Ua.signature=ka,La.signature=ka,$a.signature=ka;const Ha="bitAnd",Ga=de(Ha,["typed","matrix","equalScalar","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,concat:i}=e;const o=Lo({typed:t,equalScalar:n}),a=na({typed:t,equalScalar:n}),s=No({typed:t,equalScalar:n}),u=Vo({typed:t,matrix:r,concat:i});return t(Ha,{"number, number":qa,"BigNumber, BigNumber":Ta,"bigint, bigint":(e,t)=>e&t},u({SS:a,DS:o,Ss:s}))})),Za="bitNot",Va=de(Za,["typed"],(e=>{let{typed:t}=e;return t(Za,{number:Ra,BigNumber:Da,bigint:e=>~e,"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Wa="bitOr",Ya=de(Wa,["typed","matrix","equalScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o}=e;const a=Yo({typed:t}),s=Jo({typed:t,equalScalar:n}),u=Xo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:r,concat:o});return t(Wa,{"number, number":Pa,"BigNumber, BigNumber":Fa,"bigint, bigint":(e,t)=>e|t},c({SS:s,DS:a,Ss:u}))})),Ja=de("matAlgo07xSSf",["typed","DenseMatrix"],(e=>{let{typed:t,DenseMatrix:r}=e;return function(e,i,o){const a=e._size,s=e._datatype||void 0===e._data?e._datatype:e.getDataType(),u=i._size,c=i._datatype||void 0===i._data?i._datatype:i.getDataType();if(a.length!==u.length)throw new an(a.length,u.length);if(a[0]!==u[0]||a[1]!==u[1])throw new RangeError("Dimension mismatch. Matrix A ("+a+") must match Matrix B ("+u+")");const l=a[0],f=a[1];let p,m,d,h=0,g=o;"string"==typeof s&&s===c&&"mixed"!==s&&(p=s,h=t.convert(0,p),g=t.find(o,[p,p]));const y=[];for(m=0;m{let{typed:t,matrix:r,DenseMatrix:n,concat:i}=e;const o=$o({typed:t}),a=Ja({typed:t,DenseMatrix:n}),s=Eo({typed:t,DenseMatrix:n}),u=Vo({typed:t,matrix:r,concat:i});return t(Xa,{"number, number":ja,"BigNumber, BigNumber":_a,"bigint, bigint":(e,t)=>e^t},u({SS:a,DS:o,Ss:s}))})),Ka=de("arg",["typed"],(e=>{let{typed:t}=e;return t("arg",{number:function(e){return Math.atan2(0,e)},BigNumber:function(e){return e.constructor.atan2(0,e)},Complex:function(e){return e.arg()},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),es="conj",ts=de(es,["typed"],(e=>{let{typed:t}=e;return t(es,{"number | BigNumber | Fraction":e=>e,Complex:e=>e.conjugate(),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),rs=de("im",["typed"],(e=>{let{typed:t}=e;return t("im",{number:()=>0,"BigNumber | Fraction":e=>e.mul(0),Complex:e=>e.im,"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),ns=de("re",["typed"],(e=>{let{typed:t}=e;return t("re",{"number | BigNumber | Fraction":e=>e,Complex:e=>e.re,"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),is="number, number";function os(e){return!e}function as(e,t){return!(!e&&!t)}function ss(e,t){return!!e!=!!t}function us(e,t){return!(!e||!t)}os.signature="number",as.signature=is,ss.signature=is,us.signature=is;const cs=de("not",["typed"],(e=>{let{typed:t}=e;return t("not",{"null | undefined":()=>!0,number:os,Complex:function(e){return 0===e.re&&0===e.im},BigNumber:function(e){return e.isZero()||e.isNaN()},bigint:e=>!e,Unit:t.referToSelf((e=>r=>t.find(e,r.valueType())(r.value))),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),ls=de("or",["typed","matrix","equalScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ho({typed:t,equalScalar:n}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:r,concat:o});return t("or",{"number, number":as,"Complex, Complex":function(e,t){return 0!==e.re||0!==e.im||0!==t.re||0!==t.im},"BigNumber, BigNumber":function(e,t){return!e.isZero()&&!e.isNaN()||!t.isZero()&&!t.isNaN()},"bigint, bigint":as,"Unit, Unit":t.referToSelf((e=>(t,r)=>e(t.value||0,r.value||0)))},c({SS:s,DS:a,Ss:u}))})),fs=de("xor",["typed","matrix","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,DenseMatrix:n,concat:i}=e;const o=$o({typed:t}),a=Ja({typed:t,DenseMatrix:n}),s=Eo({typed:t,DenseMatrix:n}),u=Vo({typed:t,matrix:r,concat:i});return t("xor",{"number, number":ss,"Complex, Complex":function(e,t){return(0!==e.re||0!==e.im)!=(0!==t.re||0!==t.im)},"bigint, bigint":ss,"BigNumber, BigNumber":function(e,t){return(!e.isZero()&&!e.isNaN())!=(!t.isZero()&&!t.isNaN())},"Unit, Unit":t.referToSelf((e=>(t,r)=>e(t.value||0,r.value||0)))},u({SS:a,DS:o,Ss:s}))})),ps="concat",ms=de(ps,["typed","matrix","isInteger"],(e=>{let{typed:t,matrix:r,isInteger:n}=e;return t(ps,{"...Array | Matrix | number | BigNumber":function(e){let t;const i=e.length;let o,a=-1,s=!1;const u=[];for(t=0;t0&&a>o)throw new sn(a,o+1)}else{const e=ae(r).valueOf(),n=un(e);if(u[t]=e,o=a,a=n.length-1,t>0&&a!==o)throw new an(o+1,a+1)}}if(0===u.length)throw new SyntaxError("At least one matrix expected");let c=u.shift();for(;u.length;)c=Bn(c,u.shift(),a);return s?r(c):c},"...string":function(e){return e.join("")}})})),ds="column",hs=de(ds,["typed","Index","matrix","range"],(e=>{let{typed:t,Index:r,matrix:n,range:i}=e;return t(ds,{"Matrix, number":o,"Array, number":function(e,t){return o(n(ae(e)),t).valueOf()}});function o(e,t){if(2!==e.size().length)throw new Error("Only two dimensional matrix is supported");pn(t,e.size()[1]);const o=i(0,e.size()[0]),a=new r(o,t),s=e.subset(a);return E(s)?s:n([[s]])}})),gs="count",ys=de(gs,["typed","size","prod"],(e=>{let{typed:t,size:r,prod:n}=e;return t(gs,{string:function(e){return e.length},"Matrix | Array":function(e){return n(r(e))}})})),xs="cross",bs=de(xs,["typed","matrix","subtract","multiply"],(e=>{let{typed:t,matrix:r,subtract:n,multiply:i}=e;return t(xs,{"Matrix, Matrix":function(e,t){return r(o(e.toArray(),t.toArray()))},"Matrix, Array":function(e,t){return r(o(e.toArray(),t))},"Array, Matrix":function(e,t){return r(o(e,t.toArray()))},"Array, Array":o});function o(e,t){const r=Math.max(un(e).length,un(t).length);e=bn(e),t=bn(t);const o=un(e),a=un(t);if(1!==o.length||1!==a.length||3!==o[0]||3!==a[0])throw new RangeError("Vectors with length 3 expected (Size A = ["+o.join(", ")+"], B = ["+a.join(", ")+"])");const s=[n(i(e[1],t[2]),i(e[2],t[1])),n(i(e[2],t[0]),i(e[0],t[2])),n(i(e[0],t[1]),i(e[1],t[0]))];return r>1?[s]:s}})),vs="diag",ws=de(vs,["typed","matrix","DenseMatrix","SparseMatrix"],(e=>{let{typed:t,matrix:r,DenseMatrix:n,SparseMatrix:i}=e;return t(vs,{Array:function(e){return o(e,0,un(e),null)},"Array, number":function(e,t){return o(e,t,un(e),null)},"Array, BigNumber":function(e,t){return o(e,t.toNumber(),un(e),null)},"Array, string":function(e,t){return o(e,0,un(e),t)},"Array, number, string":function(e,t,r){return o(e,t,un(e),r)},"Array, BigNumber, string":function(e,t,r){return o(e,t.toNumber(),un(e),r)},Matrix:function(e){return o(e,0,e.size(),e.storage())},"Matrix, number":function(e,t){return o(e,t,e.size(),e.storage())},"Matrix, BigNumber":function(e,t){return o(e,t.toNumber(),e.size(),e.storage())},"Matrix, string":function(e,t){return o(e,0,e.size(),t)},"Matrix, number, string":function(e,t,r){return o(e,t,e.size(),r)},"Matrix, BigNumber, string":function(e,t,r){return o(e,t.toNumber(),e.size(),r)}});function o(e,t,o,a){if(!ye(t))throw new TypeError("Second parameter in function diag must be an integer");const s=t>0?t:0,u=t<0?-t:0;switch(o.length){case 1:return function(e,t,r,o,a,s){const u=[o+a,o+s];if(r&&"sparse"!==r&&"dense"!==r)throw new TypeError(`Unknown matrix type ${r}"`);const c="sparse"===r?i.diagonal(u,e,t):n.diagonal(u,e,t);return null!==r?c:c.valueOf()}(e,t,a,o[0],u,s);case 2:return function(e,t,n,i,o,a){if(E(e)){const i=e.diagonal(t);return null!==n?n!==i.storage()?r(i,n):i:i.valueOf()}const s=Math.min(i[0]-o,i[1]-a),u=[];for(let t=0;t{let{typed:t}=e;return t("filter",{"Array, function":Es,"Matrix, function":function(e,t){return e.create(Es(e.valueOf(),t),e.datatype())},"Array, RegExp":Mn,"Matrix, RegExp":function(e,t){return e.create(Mn(e.valueOf(),t),e.datatype())}})}));function Es(e,t){const r=Rn(t,e,"filter");return function(e){if(1!==un(e).length)throw new Error("Only one dimensional matrices supported");return Array.prototype.filter.call(e,(function(e,t,n){return r(e,[t],n)}))}(e)}const As="flatten",Ss=de(As,["typed"],(e=>{let{typed:t}=e;return t(As,{Array:function(e){return En(e)},Matrix:function(e){return e.create(En(e.toArray()),e.datatype())}})})),Ms="forEach",Cs=de(Ms,["typed"],(e=>{let{typed:t}=e;return t(Ms,{"Array, function":Ts,"Matrix, function":function(e,t){e.forEach(t)}})}));function Ts(e,t){qn(e,[],e,Rn(t,e,Ms))}const Ds="getMatrixDataType",Fs=de(Ds,["typed"],(e=>{let{typed:t}=e;return t(Ds,{Array:function(e){return Fn(e,oe)},Matrix:function(e){return e.getDataType()}})})),Os="identity",Bs=de(Os,["typed","config","matrix","BigNumber","DenseMatrix","SparseMatrix"],(e=>{let{typed:t,config:r,matrix:n,BigNumber:i,DenseMatrix:o,SparseMatrix:a}=e;return t(Os,{"":function(){return"Matrix"===r.matrix?n([]):[]},string:function(e){return n(e)},"number | BigNumber":function(e){return u(e,e,"Matrix"===r.matrix?"dense":void 0)},"number | BigNumber, string":function(e,t){return u(e,e,t)},"number | BigNumber, number | BigNumber":function(e,t){return u(e,t,"Matrix"===r.matrix?"dense":void 0)},"number | BigNumber, number | BigNumber, string":function(e,t,r){return u(e,t,r)},Array:function(e){return s(e)},"Array, string":function(e,t){return s(e,t)},Matrix:function(e){return s(e.valueOf(),e.storage())},"Matrix, string":function(e,t){return s(e.valueOf(),t)}});function s(e,t){switch(e.length){case 0:return t?n(t):[];case 1:return u(e[0],e[0],t);case 2:return u(e[0],e[1],t);default:throw new Error("Vector containing two values expected")}}function u(e,t,r){const n=g(e)||g(t)?i:null;if(g(e)&&(e=e.toNumber()),g(t)&&(t=t.toNumber()),!ye(e)||e<1)throw new Error("Parameters in function identity must be positive integers");if(!ye(t)||t<1)throw new Error("Parameters in function identity must be positive integers");const s=n?new i(1):1,u=n?new n(0):0,c=[e,t];if(r){if("sparse"===r)return a.diagonal(c,s,0,u);if("dense"===r)return o.diagonal(c,s,0,u);throw new TypeError(`Unknown matrix type "${r}"`)}const l=dn([],c,u),f=e{let{typed:t,matrix:r,multiplyScalar:n}=e;return t(_s,{"Matrix, Matrix":function(e,t){return r(i(e.toArray(),t.toArray()))},"Matrix, Array":function(e,t){return r(i(e.toArray(),t))},"Array, Matrix":function(e,t){return r(i(e,t.toArray()))},"Array, Array":i});function i(e,t){if(1===un(e).length&&(e=[e]),1===un(t).length&&(t=[t]),un(e).length>2||un(t).length>2)throw new RangeError("Vectors with dimensions greater then 2 are not supported expected (Size x = "+JSON.stringify(e.length)+", y = "+JSON.stringify(t.length)+")");const r=[];let i=[];return e.map((function(e){return t.map((function(t){return i=[],r.push(i),e.map((function(e){return t.map((function(t){return i.push(n(e,t))}))}))}))}))&&r}})),Is="map",ks=de(Is,["typed"],(e=>{let{typed:t}=e;return t(Is,{"Array, function":r,"Matrix, function":function(e,t){return e.map(t)},"Array|Matrix, Array|Matrix, ...Array|Matrix|function":(e,n,i)=>function(e,n){if("function"!=typeof n)throw new Error("Last argument must be a callback function");const i=e[0].isMatrix,o=_n(...e.map((e=>e.isMatrix?e.size():un(e)))),a=i?(e,t)=>e.get(t):kn,s=i?e.map((t=>t.isMatrix?t.create(In(t.toArray(),o),t.datatype()):e[0].create(In(t.valueOf(),o)))):e.map((e=>e.isMatrix?In(e.toArray(),o):In(e,o)));let u;if(t.isTypedFunction(n)){const e=o.map((()=>0)),r=s.map((t=>a(t,e))),i=function(e,r,n,i){return null!==t.resolve(e,[...r,n,...i])?2:null!==t.resolve(e,[...r,n])?1:(t.resolve(e,r),0)}(n,r,e,s);u=l(i)}else{const t=e.length,r=function(e,t){return e.length>t+1?2:e.length===t+1?1:0}(n,t);u=l(r)}const c=(e,t)=>u([e,...s.slice(1).map((e=>a(e,t)))],t);return i?s[0].map(c):r(s[0],c);function l(e){switch(e){case 0:return e=>n(...e);case 1:return(e,t)=>n(...e,t);case 2:return(e,t)=>n(...e,t,...s)}}}([e,n,...i.slice(0,i.length-1)],i[i.length-1])});function r(e,t){return qn(e,[],e,Rn(t,e,Is))}})),qs="diff",Rs=de(qs,["typed","matrix","subtract","number"],(e=>{let{typed:t,matrix:r,subtract:n,number:i}=e;return t(qs,{"Array | Matrix":function(e){return E(e)?r(a(e.toArray())):a(e)},"Array | Matrix, number":function(e,t){if(!ye(t))throw new RangeError("Dimension must be a whole number");return E(e)?r(o(e.toArray(),t)):o(e,t)},"Array, BigNumber":t.referTo("Array,number",(e=>(t,r)=>e(t,i(r)))),"Matrix, BigNumber":t.referTo("Matrix,number",(e=>(t,r)=>e(t,i(r))))});function o(e,t){if(E(e)&&(e=e.toArray()),!Array.isArray(e))throw RangeError("Array/Matrix does not have that many dimensions");if(t>0){const r=[];return e.forEach((e=>{r.push(o(e,t-1))})),r}if(0===t)return a(e);throw RangeError("Cannot have negative dimension")}function a(e){const t=[],r=e.length;for(let n=1;n{let{typed:t,config:r,matrix:n,BigNumber:i}=e;return t("ones",{"":function(){return"Array"===r.matrix?o([]):o([],"default")},"...number | BigNumber | string":function(e){if("string"==typeof e[e.length-1]){const t=e.pop();return o(e,t)}return"Array"===r.matrix?o(e):o(e,"default")},Array:o,Matrix:function(e){const t=e.storage();return o(e.valueOf(),t)},"Array | Matrix, string":function(e,t){return o(e.valueOf(),t)}});function o(e,t){const r=function(e){let t=!1;return e.forEach((function(e,r,n){g(e)&&(t=!0,n[r]=e.toNumber())})),t}(e),o=r?new i(1):1;if(function(e){e.forEach((function(e){if("number"!=typeof e||!ye(e)||e<0)throw new Error("Parameters in function ones must be positive integers")}))}(e),t){const r=n(t);return e.length>0?r.resize(e,o):r}{const t=[];return e.length>0?dn(t,e,o):t}}}));function js(){throw new Error('No "bignumber" implementation available')}function Us(){throw new Error('No "fraction" implementation available')}function Ls(){throw new Error('No "matrix" implementation available')}const $s="range",Hs=de($s,["typed","config","?matrix","?bignumber","smaller","smallerEq","larger","largerEq","add","isPositive"],(e=>{let{typed:t,config:r,matrix:n,bignumber:i,smaller:o,smallerEq:a,larger:s,largerEq:u,add:c,isPositive:l}=e;return t($s,{string:p,"string, boolean":p,"number, number":function(e,t){return f(m(e,t,1,!1))},"number, number, number":function(e,t,r){return f(m(e,t,r,!1))},"number, number, boolean":function(e,t,r){return f(m(e,t,1,r))},"number, number, number, boolean":function(e,t,r,n){return f(m(e,t,r,n))},"BigNumber, BigNumber":function(e,t){return f(m(e,t,new(0,e.constructor)(1),!1))},"BigNumber, BigNumber, BigNumber":function(e,t,r){return f(m(e,t,r,!1))},"BigNumber, BigNumber, boolean":function(e,t,r){return f(m(e,t,new(0,e.constructor)(1),r))},"BigNumber, BigNumber, BigNumber, boolean":function(e,t,r,n){return f(m(e,t,r,n))},"Unit, Unit, Unit":function(e,t,r){return f(m(e,t,r,!1))},"Unit, Unit, Unit, boolean":function(e,t,r,n){return f(m(e,t,r,n))}});function f(e){return"Matrix"===r.matrix?n?n(e):Ls():e}function p(e,t){const n=function(e){const t=e.split(":").map((function(e){return Number(e)}));if(t.some((function(e){return isNaN(e)})))return null;switch(t.length){case 2:return{start:t[0],end:t[1],step:1};case 3:return{start:t[0],end:t[2],step:t[1]};default:return null}}(e);if(!n)throw new SyntaxError('String "'+e+'" is no valid range');return"BigNumber"===r.number?(void 0===i&&js(),f(m(i(n.start),i(n.end),i(n.step)))):f(m(n.start,n.end,n.step,t))}function m(e,t,r,n){const i=[],f=l(r)?n?a:o:n?u:s;let p=e;for(;f(p,t);)i.push(p),p=c(p,r);return i}})),Gs="reshape",Zs=de(Gs,["typed","isInteger","matrix"],(e=>{let{typed:t,isInteger:r}=e;return t(Gs,{"Matrix, Array":function(e,t){return e.reshape(t,!0)},"Array, Array":function(e,t){return t.forEach((function(e){if(!r(e))throw new TypeError("Invalid size for dimension: "+e)})),gn(e,t)}})})),Vs=de("resize",["config","matrix"],(e=>{let{config:t,matrix:r}=e;return function(e,n,i){if(2!==arguments.length&&3!==arguments.length)throw new Qo("resize",arguments.length,2,3);if(E(n)&&(n=n.valueOf()),g(n[0])&&(n=n.map((function(e){return g(e)?e.toNumber():e}))),E(e))return e.resize(n,i,!0);if("string"==typeof e)return function(e,t,r){if(void 0!==r){if("string"!=typeof r||1!==r.length)throw new TypeError("Single character expected as defaultValue")}else r=" ";if(1!==t.length)throw new an(t.length,1);const n=t[0];if("number"!=typeof n||!ye(n))throw new TypeError("Invalid size, must contain positive integers (size: "+Kr(t)+")");if(e.length>n)return e.substring(0,n);if(e.length{let{typed:t,multiply:r,rotationMatrix:n}=e;return t(Ws,{"Array , number | BigNumber | Complex | Unit":function(e,t){return i(e,2),r(n(t),e).toArray()},"Matrix , number | BigNumber | Complex | Unit":function(e,t){return i(e,2),r(n(t),e)},"Array, number | BigNumber | Complex | Unit, Array | Matrix":function(e,t,o){return i(e,3),r(n(t,o),e)},"Matrix, number | BigNumber | Complex | Unit, Array | Matrix":function(e,t,o){return i(e,3),r(n(t,o),e)}});function i(e,t){const r=Array.isArray(e)?un(e):e.size();if(r.length>2)throw new RangeError(`Vector must be of dimensions 1x${t}`);if(2===r.length&&1!==r[1])throw new RangeError(`Vector must be of dimensions 1x${t}`);if(r[0]!==t)throw new RangeError(`Vector must be of dimensions 1x${t}`)}})),Js="rotationMatrix",Xs=de(Js,["typed","config","multiplyScalar","addScalar","unaryMinus","norm","matrix","BigNumber","DenseMatrix","SparseMatrix","cos","sin"],(e=>{let{typed:t,config:r,multiplyScalar:n,addScalar:i,unaryMinus:o,norm:a,BigNumber:s,matrix:u,DenseMatrix:c,SparseMatrix:l,cos:f,sin:p}=e;return t(Js,{"":function(){return"Matrix"===r.matrix?u([]):[]},string:function(e){return u(e)},"number | BigNumber | Complex | Unit":function(e){return m(e,"Matrix"===r.matrix?"dense":void 0)},"number | BigNumber | Complex | Unit, string":function(e,t){return m(e,t)},"number | BigNumber | Complex | Unit, Array":function(e,t){const r=u(t);return d(r),x(e,r,void 0)},"number | BigNumber | Complex | Unit, Matrix":function(e,t){d(t);const n=t.storage()||("Matrix"===r.matrix?"dense":void 0);return x(e,t,n)},"number | BigNumber | Complex | Unit, Array, string":function(e,t,r){const n=u(t);return d(n),x(e,n,r)},"number | BigNumber | Complex | Unit, Matrix, string":function(e,t,r){return d(t),x(e,t,r)}});function m(e,t){const r=g(e)?new s(-1):-1,i=f(e),o=p(e);return y([[i,n(r,o)],[o,i]],t)}function d(e){const t=e.size();if(t.length<1||3!==t[0])throw new RangeError("Vector must be of dimensions 1x3")}function h(e){return e.reduce(((e,t)=>n(e,t)))}function y(e,t){if(t){if("sparse"===t)return new l(e);if("dense"===t)return new c(e);throw new TypeError(`Unknown matrix type "${t}"`)}return e}function x(e,t,r){const n=a(t);if(0===n)throw new RangeError("Rotation around zero vector");const u=g(e)?s:null,c=u?new u(1):1,l=u?new u(-1):-1,m=u?new u(t.get([0])/n):t.get([0])/n,d=u?new u(t.get([1])/n):t.get([1])/n,x=u?new u(t.get([2])/n):t.get([2])/n,b=f(e),v=i(c,o(b)),w=p(e);return y([[i(b,h([m,m,v])),i(h([m,d,v]),h([l,x,w])),i(h([m,x,v]),h([d,w]))],[i(h([m,d,v]),h([x,w])),i(b,h([d,d,v])),i(h([d,x,v]),h([l,m,w]))],[i(h([m,x,v]),h([l,d,w])),i(h([d,x,v]),h([m,w])),i(b,h([x,x,v]))]],r)}})),Qs=de("row",["typed","Index","matrix","range"],(e=>{let{typed:t,Index:r,matrix:n,range:i}=e;return t("row",{"Matrix, number":o,"Array, number":function(e,t){return o(n(ae(e)),t).valueOf()}});function o(e,t){if(2!==e.size().length)throw new Error("Only two dimensional matrix is supported");pn(t,e.size()[0]);const o=i(0,e.size()[1]),a=new r(t,o),s=e.subset(a);return E(s)?s:n([[s]])}})),Ks="size",eu=de(Ks,["typed","config","?matrix"],(e=>{let{typed:t,config:r,matrix:n}=e;return t(Ks,{Matrix:function(e){return e.create(e.size(),"number")},Array:un,string:function(e){return"Array"===r.matrix?[e.length]:n([e.length],"dense","number")},"number | Complex | BigNumber | Unit | boolean | null":function(e){return"Array"===r.matrix?[]:n?n([],"dense","number"):Ls()}})})),tu="squeeze",ru=de(tu,["typed"],(e=>{let{typed:t}=e;return t(tu,{Array:function(e){return bn(ae(e))},Matrix:function(e){const t=bn(e.toArray());return Array.isArray(t)?e.create(t,e.datatype()):t},any:function(e){return ae(e)}})})),nu="subset",iu=de(nu,["typed","matrix","zeros","add"],(e=>{let{typed:t,matrix:r,zeros:n,add:i}=e;return t(nu,{"Matrix, Index":function(e,t){return mn(t)?r():(fn(e,t),e.subset(t))},"Array, Index":t.referTo("Matrix, Index",(function(e){return function(t,n){const i=e(r(t),n);return n.isScalar()?i:i.valueOf()}})),"Object, Index":su,"string, Index":ou,"Matrix, Index, any, any":function(e,t,r,o){return mn(t)?e:(fn(e,t),e.clone().subset(t,function(e,t){if("string"==typeof e)throw new Error("can't boradcast a string");if(t._isScalar)return e;const r=t.size();if(!r.every((e=>e>0)))return e;try{return i(e,n(r))}catch(t){return e}}(r,t),o))},"Array, Index, any, any":t.referTo("Matrix, Index, any, any",(function(e){return function(t,n,i,o){const a=e(r(t),n,i,o);return a.isMatrix?a.valueOf():a}})),"Array, Index, any":t.referTo("Matrix, Index, any, any",(function(e){return function(t,n,i){return e(r(t),n,i,void 0).valueOf()}})),"Matrix, Index, any":t.referTo("Matrix, Index, any, any",(function(e){return function(t,r,n){return e(t,r,n,void 0)}})),"string, Index, string":au,"string, Index, string, string":au,"Object, Index, any":uu})}));function ou(e,t){if(!T(t))throw new TypeError("Index expected");if(mn(t))return"";if(fn(Array.from(e),t),1!==t.size().length)throw new an(t.size().length,1);const r=e.length;pn(t.min()[0],r),pn(t.max()[0],r);const n=t.dimension(0);let i="";return n.forEach((function(t){i+=e.charAt(t)})),i}function au(e,t,r,n){if(!t||!0!==t.isIndex)throw new TypeError("Index expected");if(mn(t))return e;if(fn(Array.from(e),t),1!==t.size().length)throw new an(t.size().length,1);if(void 0!==n){if("string"!=typeof n||1!==n.length)throw new TypeError("Single character expected as defaultValue")}else n=" ";const i=t.dimension(0);if(i.size()[0]!==r.length)throw new an(i.size()[0],r.length);const o=e.length;pn(t.min()[0]),pn(t.max()[0]);const a=[];for(let t=0;to)for(let e=o-1,t=a.length;e{let{typed:t,matrix:r}=e;return t(cu,{Array:e=>n(r(e)).valueOf(),Matrix:n,any:ae});function n(e){const t=e.size();let r;switch(t.length){case 1:r=e.clone();break;case 2:{const n=t[0],i=t[1];if(0===i)throw new RangeError("Cannot transpose a 2D matrix with no columns (size: "+Kr(t)+")");switch(e.storage()){case"dense":r=function(e,t,r){const n=e._data,i=[];let o;for(let e=0;e{let{typed:t,transpose:r,conj:n}=e;return t(fu,{any:function(e){return n(r(e))}})})),mu="zeros",du=de(mu,["typed","config","matrix","BigNumber"],(e=>{let{typed:t,config:r,matrix:n,BigNumber:i}=e;return t(mu,{"":function(){return"Array"===r.matrix?o([]):o([],"default")},"...number | BigNumber | string":function(e){if("string"==typeof e[e.length-1]){const t=e.pop();return o(e,t)}return"Array"===r.matrix?o(e):o(e,"default")},Array:o,Matrix:function(e){const t=e.storage();return o(e.valueOf(),t)},"Array | Matrix, string":function(e,t){return o(e.valueOf(),t)}});function o(e,t){const r=function(e){let t=!1;return e.forEach((function(e,r,n){g(e)&&(t=!0,n[r]=e.toNumber())})),t}(e),o=r?new i(0):0;if(function(e){e.forEach((function(e){if("number"!=typeof e||!ye(e)||e<0)throw new Error("Parameters in function zeros must be positive integers")}))}(e),t){const r=n(t);return e.length>0?r.resize(e,o):r}{const t=[];return e.length>0?dn(t,e,o):t}}})),hu=de("fft",["typed","matrix","addScalar","multiplyScalar","divideScalar","exp","tau","i","dotDivide","conj","pow","ceil","log2"],(e=>{let{typed:t,matrix:r,addScalar:n,multiplyScalar:i,divideScalar:o,exp:a,tau:s,i:u,dotDivide:c,conj:l,pow:f,ceil:p,log2:m}=e;return t("fft",{Array:d,Matrix:function(e){return e.create(d(e.valueOf()),e.datatype())}});function d(e){const t=un(e);return 1===t.length?g(e,t[0]):h(e.map((e=>d(e,t.slice(1)))),0)}function h(e,t){const r=un(e);if(0!==t)return new Array(r[0]).fill(0).map(((r,n)=>h(e[n],t-1)));if(1===r.length)return g(e);function n(e){const t=un(e);return new Array(t[1]).fill(0).map(((r,n)=>new Array(t[0]).fill(0).map(((t,r)=>e[r][n]))))}return n(h(n(e),1))}function g(e){const t=e.length;if(1===t)return[e[0]];if(t%2==0){const r=[...g(e.filter(((e,t)=>t%2==0))),...g(e.filter(((e,t)=>t%2==1)))];for(let e=0;ei(e[o],n[t-1+o]))),...new Array(h-t).fill(0)],x=[...new Array(t+t-1).fill(0).map(((e,t)=>o(1,n[t]))),...new Array(h-(t+t-1)).fill(0)],b=g(y),v=g(x),w=new Array(h).fill(0).map(((e,t)=>i(b[t],v[t]))),N=c(l(d(l(w))),h),E=[];for(let e=t-1;e{let{typed:t,fft:r,dotDivide:n,conj:i}=e;return t(gu,{"Array | Matrix":function(e){const t=E(e)?e.size():un(e);return n(i(r(i(e))),t.reduce(((e,t)=>e*t),1))}})})),xu=de("solveODE",["typed","add","subtract","multiply","divide","max","map","abs","isPositive","isNegative","larger","smaller","matrix","bignumber","unaryMinus"],(e=>{let{typed:t,add:r,subtract:n,multiply:i,divide:o,max:a,map:s,abs:u,isPositive:c,isNegative:l,larger:f,smaller:p,matrix:m,bignumber:d,unaryMinus:y}=e;function x(e){return function(t,m,h,x){if(2!==m.length||!m.every(E)&&!m.every(v))throw new Error('"tspan" must be an Array of two numeric values or two units [tStart, tEnd]');const b=m[0],w=m[1],N=f(w,b),A=x.firstStep;if(void 0!==A&&!c(A))throw new Error('"firstStep" must be positive');const S=x.maxStep;if(void 0!==S&&!c(S))throw new Error('"maxStep" must be positive');const M=x.minStep;if(M&&l(M))throw new Error('"minStep" must be positive or zero');const C=[b,w,A,M,S].filter((e=>void 0!==e));if(!C.every(E)&&!C.every(v))throw new Error('Inconsistent type of "t" dependant variables');const T=x.tol?x.tol:1e-4,D=x.minDelta?x.minDelta:.2,F=x.maxDelta?x.maxDelta:5,O=x.maxIter?x.maxIter:1e4,B=[b,w,...h,S,M].some(g),[_,z,I,k]=B?[d(e.a),d(e.c),d(e.b),d(e.bp)]:[e.a,e.c,e.b,e.bp];let q=A?N?A:y(A):o(n(w,b),1);const R=[b],P=[h],j=n(I,k);let U=0,L=0;const $=function(e){return e?p:f}(N),H=function(e){const t=e?f:p;return function(e,i,o){const a=r(e,o);return t(a,i)?n(i,e):o}}(N);for(;$(R[U],w);){const e=[];q=H(R[U],w,q),e.push(t(R[U],P[U]));for(let n=1;nv(e)?e.value:e))));n1/4&&(R.push(r(R[U],q)),P.push(r(P[U],i(q,I,e))),U++);let o=.84*(T/n)**.2;if(p(o,D)?o=D:f(o,F)&&(o=F),o=B?d(o):o,q=i(q,o),S&&f(u(q),S)?q=N?S:y(S):M&&p(u(q),M)&&(q=N?M:y(M)),L++,L>O)throw new Error("Maximum number of iterations reached, try changing options")}return{t:R,y:P}}}function b(e,t,r,n){return x({a:[[],[.5],[0,3/4],[2/9,1/3,4/9]],c:[null,.5,3/4,1],b:[2/9,1/3,4/9,0],bp:[7/24,1/4,1/3,1/8]})(e,t,r,n)}function w(e,t,r,n){return x({a:[[],[.2],[3/40,9/40],[44/45,-56/15,32/9],[19372/6561,-25360/2187,64448/6561,-212/729],[9017/3168,-355/33,46732/5247,49/176,-5103/18656],[35/384,0,500/1113,125/192,-2187/6784,11/84]],c:[null,.2,.3,.8,8/9,1,1],b:[35/384,0,500/1113,125/192,-2187/6784,11/84,0],bp:[5179/57600,0,7571/16695,393/640,-92097/339200,187/2100,1/40]})(e,t,r,n)}function N(e,t,r,n){const i=n.method?n.method:"RK45",o={RK23:b,RK45:w};if(i.toUpperCase()in o){const a={...n};return delete a.method,o[i.toUpperCase()](e,t,r,a)}{const e=Object.keys(o).map((e=>`"${e}"`)),t=`${e.slice(0,-1).join(", ")} and ${e.slice(-1)}`;throw new Error(`Unavailable method "${i}". Available methods are ${t}`)}}function E(e){return g(e)||h(e)}function A(e,t,r,n){const i=N(e,t.toArray(),r.toArray(),n);return{t:m(i.t),y:m(i.y)}}return t("solveODE",{"function, Array, Array, Object":N,"function, Matrix, Matrix, Object":A,"function, Array, Array":(e,t,r)=>N(e,t,r,{}),"function, Matrix, Matrix":(e,t,r)=>A(e,t,r,{}),"function, Array, number | BigNumber | Unit":(e,t,r)=>{const n=N(e,t,[r],{});return{t:n.t,y:n.y.map((e=>e[0]))}},"function, Matrix, number | BigNumber | Unit":(e,t,r)=>{const n=N(e,t.toArray(),[r],{});return{t:m(n.t),y:m(n.y.map((e=>e[0])))}},"function, Array, number | BigNumber | Unit, Object":(e,t,r,n)=>{const i=N(e,t,[r],n);return{t:i.t,y:i.y.map((e=>e[0]))}},"function, Matrix, number | BigNumber | Unit, Object":(e,t,r,n)=>{const i=N(e,t.toArray(),[r],n);return{t:m(i.t),y:m(i.y.map((e=>e[0])))}}})})),bu=de("erf",["typed"],(e=>{let{typed:t}=e;return t("name",{number:function(e){const t=Math.abs(e);return t>=Au?be(e):t<=vu?be(e)*function(e){const t=e*e;let r,n=Nu[0][4]*t,i=t;for(r=0;r<3;r+=1)n=(n+Nu[0][r])*t,i=(i+Eu[0][r])*t;return e*(n+Nu[0][3])/(i+Eu[0][3])}(t):t<=4?be(e)*(1-function(e){let t,r=Nu[1][8]*e,n=e;for(t=0;t<7;t+=1)r=(r+Nu[1][t])*e,n=(n+Eu[1][t])*e;const i=(r+Nu[1][7])/(n+Eu[1][7]),o=parseInt(16*e)/16,a=(e-o)*(e+o);return Math.exp(-o*o)*Math.exp(-a)*i}(t)):be(e)*(1-function(e){let t,r=1/(e*e),n=Nu[2][5]*r,i=r;for(t=0;t<4;t+=1)n=(n+Nu[2][t])*r,i=(i+Eu[2][t])*r;let o=r*(n+Nu[2][4])/(i+Eu[2][4]);o=(wu-o)/e,r=parseInt(16*e)/16;const a=(e-r)*(e+r);return Math.exp(-r*r)*Math.exp(-a)*o}(t))},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),vu=.46875,wu=.5641895835477563,Nu=[[3.1611237438705655,113.86415415105016,377.485237685302,3209.3775891384694,.18577770618460315],[.5641884969886701,8.883149794388377,66.11919063714163,298.6351381974001,881.952221241769,1712.0476126340707,2051.0783778260716,1230.3393547979972,2.1531153547440383e-8],[.30532663496123236,.36034489994980445,.12578172611122926,.016083785148742275,.0006587491615298378,.016315387137302097]],Eu=[[23.601290952344122,244.02463793444417,1282.6165260773723,2844.236833439171],[15.744926110709835,117.6939508913125,537.1811018620099,1621.3895745666903,3290.7992357334597,4362.619090143247,3439.3676741437216,1230.3393548037495],[2.568520192289822,1.8729528499234604,.5279051029514285,.06051834131244132,.0023352049762686918]],Au=Math.pow(2,53),Su="zeta",Mu=de(Su,["typed","config","multiply","pow","divide","factorial","equal","smallerEq","isNegative","gamma","sin","subtract","add","?Complex","?BigNumber","pi"],(e=>{let{typed:t,config:r,multiply:n,pow:i,divide:o,factorial:a,equal:s,smallerEq:u,isNegative:c,gamma:l,sin:f,subtract:p,add:m,Complex:d,BigNumber:h,pi:g}=e;return t(Su,{number:e=>y(e,(e=>e),(()=>20)),BigNumber:e=>y(e,(e=>new h(e)),(()=>Math.abs(Math.log10(r.relTol)))),Complex:function(e){return 0===e.re&&0===e.im?new d(-.5):1===e.re?new d(NaN,NaN):e.re===1/0&&0===e.im?new d(1):e.im===1/0||e.re===-1/0?new d(NaN,NaN):x(e,(e=>e),(e=>Math.round(19.5+.9*Math.abs(e.im))),(e=>e.re))}});function y(e,t,r){return s(e,0)?t(-.5):s(e,1)?t(NaN):isFinite(e)?x(e,t,r,(e=>e)):c(e)?t(NaN):t(1)}function x(e,t,r,a){const s=r(e);if(a(e)>-(s-1)/2)return function(e,t,r){const a=o(1,n(b(r(0),t),p(1,i(2,p(1,e)))));let s=r(0);for(let a=r(1);u(a,t);a=m(a,1))s=m(s,o(n((-1)**(a-1),b(a,t)),i(a,e)));return n(a,s)}(e,t(s),t);{let s=n(i(2,e),i(t(g),p(e,1)));return s=n(s,f(n(o(t(g),2),e))),s=n(s,l(p(1,e))),n(s,x(p(1,e),t,r,a))}}function b(e,t){let r=e;for(let s=e;u(s,t);s=m(s,1)){const e=o(n(a(m(t,p(s,1))),i(4,s)),n(a(p(t,s)),a(n(2,s))));r=m(r,e)}return n(t,r)}})),Cu="mode",Tu=de(Cu,["typed","isNaN","isNumeric"],(e=>{let{typed:t,isNaN:r,isNumeric:n}=e;return t(Cu,{"Array | Matrix":i,"...":function(e){return i(e)}});function i(e){if(0===(e=En(e.valueOf())).length)throw new Error("Cannot calculate mode of an empty array");const t={};let i=[],o=0;for(let a=0;ao&&(o=t[s],i=[s])}return i}}));function Du(e,t,r){let n;return String(e).includes("Unexpected type")?(n=arguments.length>2?" (type: "+oe(r)+", value: "+JSON.stringify(r)+")":" (type: "+e.data.actual+")",new TypeError("Cannot calculate "+t+", unexpected type of argument"+n)):String(e).includes("complex numbers")?(n=arguments.length>2?" (type: "+oe(r)+", value: "+JSON.stringify(r)+")":"",new TypeError("Cannot calculate "+t+", no ordering relation is defined for complex numbers"+n)):e}const Fu="prod",Ou=de(Fu,["typed","config","multiplyScalar","numeric"],(e=>{let{typed:t,config:r,multiplyScalar:n,numeric:i}=e;return t(Fu,{"Array | Matrix":o,"Array | Matrix, number | BigNumber":function(e,t){throw new Error("prod(A, dim) is not yet supported")},"...":function(e){return o(e)}});function o(e){let t;if(Gn(e,(function(e){try{t=void 0===t?e:n(t,e)}catch(t){throw Du(t,"prod",e)}})),"string"==typeof t&&(t=i(t,xe(t,r))),void 0===t)throw new Error("Cannot calculate prod of an empty array");return t}})),Bu="format",_u=de(Bu,["typed"],(e=>{let{typed:t}=e;return t(Bu,{any:Kr,"any, Object | function | number | BigNumber":Kr})})),zu=de("bin",["typed","format"],(e=>{let{typed:t,format:r}=e;return t("bin",{"number | BigNumber":function(e){return r(e,{notation:"bin"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"bin",wordSize:t})}})})),Iu=de("oct",["typed","format"],(e=>{let{typed:t,format:r}=e;return t("oct",{"number | BigNumber":function(e){return r(e,{notation:"oct"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"oct",wordSize:t})}})})),ku=de("hex",["typed","format"],(e=>{let{typed:t,format:r}=e;return t("hex",{"number | BigNumber":function(e){return r(e,{notation:"hex"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"hex",wordSize:t})}})})),qu=/\$([\w.]+)/g,Ru="print",Pu=de(Ru,["typed"],(e=>{let{typed:t}=e;return t(Ru,{"string, Object | Array":ju,"string, Object | Array, number | Object":ju})}));function ju(e,t,r){return e.replace(qu,(function(e,n){const i=n.split(".");let o=t[i.shift()];for(void 0!==o&&o.isMatrix&&(o=o.toArray());i.length&&void 0!==o;){const e=i.shift();o=e?o[e]:o+"."}return void 0!==o?w(o)?o:Kr(o,r):e}))}const Uu=de("to",["typed","matrix","concat"],(e=>{let{typed:t,matrix:r,concat:n}=e;return t("to",{"Unit, Unit | string":(e,t)=>e.to(t)},Vo({typed:t,matrix:r,concat:n})({Ds:!0}))})),Lu="isPrime",$u=de(Lu,["typed"],(e=>{let{typed:t}=e;return t(Lu,{number:function(e){if(e<=3)return e>1;if(e%2==0||e%3==0)return!1;for(let t=5;t*t<=e;t+=6)if(e%t==0||e%(t+2)==0)return!1;return!0},bigint:function(e){if(e<=3n)return e>1n;if(e%2n===0n||e%3n===0n)return!1;for(let t=5n;t*t<=e;t+=6n)if(e%t===0n||e%(t+2n)===0n)return!1;return!0},BigNumber:function(e){if(e.lte(3))return e.gt(1);if(e.mod(2).eq(0)||e.mod(3).eq(0))return!1;if(e.lt(Math.pow(2,32))){const t=e.toNumber();for(let e=5;e*e<=t;e+=6)if(t%e==0||t%(e+2)==0)return!1;return!0}function t(e,t,r){let n=1;for(;!t.eq(0);)t.mod(2).eq(0)?(t=t.div(2),e=e.mul(e).mod(r)):(t=t.sub(1),n=e.mul(n).mod(r));return n}const r=e.constructor.clone({precision:2*e.toFixed(0).length});let n=0,i=(e=new r(e)).sub(1);for(;i.mod(2).eq(0);)i=i.div(2),n+=1;let o=null;if(e.lt("3317044064679887385961981"))o=[2,3,5,7,11,13,17,19,23,29,31,37,41].filter((t=>tt=>Zn(t,e)))})})),Hu=de("numeric",["number","?bignumber","?fraction"],(e=>{let{number:t,bignumber:r,fraction:n}=e;const i={string:!0,number:!0,BigNumber:!0,Fraction:!0},o={number:e=>t(e),BigNumber:r?e=>r(e):js,bigint:e=>BigInt(e),Fraction:n?e=>n(e):Us};return function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"number";if(void 0!==(arguments.length>2?arguments[2]:void 0))throw new SyntaxError("numeric() takes one or two arguments");const r=oe(e);if(!(r in i))throw new TypeError("Cannot convert "+e+' of type "'+r+'"; valid input types are '+Object.keys(i).join(", "));if(!(t in o))throw new TypeError("Cannot convert "+e+' to type "'+t+'"; valid output types are '+Object.keys(o).join(", "));return t===r?e:o[t](e)}})),Gu="divideScalar",Zu=de(Gu,["typed","numeric"],(e=>{let{typed:t,numeric:r}=e;return t(Gu,{"number, number":function(e,t){return e/t},"Complex, Complex":function(e,t){return e.div(t)},"BigNumber, BigNumber":function(e,t){return e.div(t)},"bigint, bigint":function(e,t){return e/t},"Fraction, Fraction":function(e,t){return e.div(t)},"Unit, number | Complex | Fraction | BigNumber | Unit":(e,t)=>e.divide(t),"number | Fraction | Complex | BigNumber, Unit":(e,t)=>t.divideInto(e)})})),Vu=de("pow",["typed","config","identity","multiply","matrix","inv","fraction","number","Complex"],(e=>{let{typed:t,config:r,identity:n,multiply:i,matrix:o,inv:a,number:s,fraction:u,Complex:c}=e;return t("pow",{"number, number":l,"Complex, Complex":function(e,t){return e.pow(t)},"BigNumber, BigNumber":function(e,t){return t.isInteger()||e>=0||r.predictable?e.pow(t):new c(e.toNumber(),0).pow(t.toNumber(),0)},"bigint, bigint":(e,t)=>e**t,"Fraction, Fraction":function(e,t){const n=e.pow(t);if(null!=n)return n;if(r.predictable)throw new Error("Result of pow is non-rational and cannot be expressed as a fraction");return l(e.valueOf(),t.valueOf())},"Array, number":f,"Array, BigNumber":function(e,t){return f(e,t.toNumber())},"Matrix, number":p,"Matrix, BigNumber":function(e,t){return p(e,t.toNumber())},"Unit, number | BigNumber":function(e,t){return e.pow(t)}});function l(e,t){if(r.predictable&&!ye(t)&&e<0)try{const r=u(t),n=s(r);if((t===n||Math.abs((t-n)/t)<1e-14)&&r.d%2==1)return(r.n%2==0?1:-1)*Math.pow(-e,t)}catch(e){}return r.predictable&&(e<-1&&t===1/0||e>-1&&e<0&&t===-1/0)?NaN:ye(t)||e>=0||r.predictable?oo(e,t):e*e<1&&t===1/0||e*e>1&&t===-1/0?0:new c(e,0).pow(t,0)}function f(e,t){if(!ye(t))throw new TypeError("For A^b, b must be an integer (value is "+t+")");const r=un(e);if(2!==r.length)throw new Error("For A^b, A must be 2 dimensional (A has "+r.length+" dimensions)");if(r[0]!==r[1])throw new Error("For A^b, A must be square (size is "+r[0]+"x"+r[1]+")");if(t<0)try{return f(a(e),-t)}catch(e){if("Cannot calculate inverse, determinant is zero"===e.message)throw new TypeError("For A^b, when A is not invertible, b must be a positive integer (value is "+t+")");throw e}let o=n(r[0]).valueOf(),s=e;for(;t>=1;)1&~t||(o=i(s,o)),t>>=1,s=i(s,s);return o}function p(e,t){return o(f(e.valueOf(),t))}})),Wu="Number of decimals in function round must be an integer",Yu="round",Ju=de(Yu,["typed","config","matrix","equalScalar","zeros","BigNumber","DenseMatrix"],(e=>{let{typed:t,config:r,matrix:n,equalScalar:i,zeros:o,BigNumber:a,DenseMatrix:s}=e;const u=No({typed:t,equalScalar:i}),c=Eo({typed:t,DenseMatrix:s}),l=Ao({typed:t});function f(e){return Math.abs(Te(e).exponent)}return t(Yu,{number:function(e){const t=ao(e,f(r.relTol));return ao(_e(e,t,r.relTol,r.absTol)?t:e)},"number, number":function(e,t){const n=f(r.relTol);if(t>=n)return ao(e,t);const i=ao(e,n);return ao(_e(e,i,r.relTol,r.absTol)?i:e,t)},"number, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Wu);return new a(e).toDecimalPlaces(t.toNumber())},Complex:function(e){return e.round()},"Complex, number":function(e,t){if(t%1)throw new TypeError(Wu);return e.round(t)},"Complex, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Wu);const r=t.toNumber();return e.round(r)},BigNumber:function(e){const t=new a(e).toDecimalPlaces(f(r.relTol));return(ri(e,t,r.relTol,r.absTol)?t:e).toDecimalPlaces(0)},"BigNumber, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Wu);const n=f(r.relTol);if(t>=n)return e.toDecimalPlaces(t.toNumber());const i=e.toDecimalPlaces(n);return(ri(e,i,r.relTol,r.absTol)?i:e).toDecimalPlaces(t.toNumber())},Fraction:function(e){return e.round()},"Fraction, number":function(e,t){if(t%1)throw new TypeError(Wu);return e.round(t)},"Fraction, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Wu);return e.round(t.toNumber())},"Unit, number, Unit":t.referToSelf((e=>function(t,r,n){const i=t.toNumeric(n);return n.multiply(e(i,r))})),"Unit, BigNumber, Unit":t.referToSelf((e=>(t,r,n)=>e(t,r.toNumber(),n))),"Unit, Unit":t.referToSelf((e=>(t,r)=>e(t,0,r))),"Array | Matrix, number, Unit":t.referToSelf((e=>(t,r,n)=>Zn(t,(t=>e(t,r,n)),!0))),"Array | Matrix, BigNumber, Unit":t.referToSelf((e=>(t,r,n)=>e(t,r.toNumber(),n))),"Array | Matrix, Unit":t.referToSelf((e=>(t,r)=>e(t,0,r))),"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e,!0))),"SparseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>u(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>l(t,r,e,!1))),"Array, number | BigNumber":t.referToSelf((e=>(t,r)=>l(n(t),r,e,!1).valueOf())),"number | Complex | BigNumber | Fraction, SparseMatrix":t.referToSelf((e=>(t,r)=>i(t,0)?o(r.size(),r.storage()):c(r,t,e,!0))),"number | Complex | BigNumber | Fraction, DenseMatrix":t.referToSelf((e=>(t,r)=>i(t,0)?o(r.size(),r.storage()):l(r,t,e,!0))),"number | Complex | BigNumber | Fraction, Array":t.referToSelf((e=>(t,r)=>l(n(r),t,e,!0).valueOf()))})})),Xu=de("log",["config","typed","divideScalar","Complex"],(e=>{let{typed:t,config:r,divideScalar:n,Complex:i}=e;return t("log",{number:function(e){return e>=0||r.predictable?function(e){return Math.log(e)}(e):new i(e,0).log()},Complex:function(e){return e.log()},BigNumber:function(e){return!e.isNegative()||r.predictable?e.ln():new i(e.toNumber(),0).log()},"any, any":t.referToSelf((e=>(t,r)=>n(e(t),e(r))))})})),Qu="log1p",Ku=de(Qu,["typed","config","divideScalar","log","Complex"],(e=>{let{typed:t,config:r,divideScalar:n,log:i,Complex:o}=e;return t(Qu,{number:function(e){return e>=-1||r.predictable?Ne(e):a(new o(e,0))},Complex:a,BigNumber:function(e){const t=e.plus(1);return!t.isNegative()||r.predictable?t.ln():a(new o(e.toNumber(),0))},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e))),"any, any":t.referToSelf((e=>(t,r)=>n(e(t),i(r))))});function a(e){const t=e.re+1;return new o(Math.log(Math.sqrt(t*t+e.im*e.im)),Math.atan2(e.im,t))}})),ec="nthRoots",tc=de(ec,["config","typed","divideScalar","Complex"],(e=>{let{typed:t,config:r,divideScalar:n,Complex:i}=e;const o=[function(e){return new i(e,0)},function(e){return new i(0,e)},function(e){return new i(-e,0)},function(e){return new i(0,-e)}];function a(e,t){if(t<0)throw new Error("Root must be greater than zero");if(0===t)throw new Error("Root must be non-zero");if(t%1!=0)throw new Error("Root must be an integer");if(0===e||0===e.abs())return[new i(0,0)];const r="number"==typeof e;let n;(r||0===e.re||0===e.im)&&(n=r?2*+(e<0):0===e.im?2*+(e.re<0):2*+(e.im<0)+1);const a=e.arg(),s=e.abs(),u=[],c=Math.pow(s,1/t);for(let e=0;e{let{typed:t,equalScalar:r,matrix:n,pow:i,DenseMatrix:o,concat:a}=e;const s=$o({typed:t}),u=Ja({typed:t,DenseMatrix:o}),c=No({typed:t,equalScalar:r}),l=Eo({typed:t,DenseMatrix:o}),f=Vo({typed:t,matrix:n,concat:a}),p={};for(const e in i.signatures)Object.prototype.hasOwnProperty.call(i.signatures,e)&&(e.includes("Matrix")||e.includes("Array")||(p[e]=i.signatures[e]));const m=t(p);return t(rc,f({elop:m,SS:u,DS:s,Ss:c,sS:l}))})),ic="dotDivide",oc=de(ic,["typed","matrix","equalScalar","divideScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,divideScalar:i,DenseMatrix:o,concat:a}=e;const s=Lo({typed:t,equalScalar:n}),u=$o({typed:t}),c=Ja({typed:t,DenseMatrix:o}),l=No({typed:t,equalScalar:n}),f=Eo({typed:t,DenseMatrix:o}),p=Vo({typed:t,matrix:r,concat:a});return t(ic,p({elop:i,SS:c,DS:u,SD:s,Ss:l,sS:f}))}));function ac(e){let{DenseMatrix:t}=e;return function(e,r,n){const i=e.size();if(2!==i.length)throw new RangeError("Matrix must be two dimensional (size: "+Kr(i)+")");const o=i[0];if(o!==i[1])throw new RangeError("Matrix must be square (size: "+Kr(i)+")");let a=[];if(E(r)){const e=r.size(),i=r._data;if(1===e.length){if(e[0]!==o)throw new RangeError("Dimension mismatch. Matrix columns must match vector length.");for(let e=0;e{let{typed:t,matrix:r,divideScalar:n,multiplyScalar:i,subtractScalar:o,equalScalar:a,DenseMatrix:s}=e;const u=ac({DenseMatrix:s});return t(sc,{"SparseMatrix, Array | Matrix":function(e,t){return function(e,t){const r=(t=u(e,t,!0))._data,c=e._size[0],l=e._size[1],f=e._values,p=e._index,m=e._ptr,d=[];for(let e=0;ee&&(u.push(f[t]),c.push(r))}if(a(s,0))throw new Error("Linear system cannot be solved since matrix is singular");const g=n(t,s);for(let e=0,t=c.length;e{let{typed:t,matrix:r,divideScalar:n,multiplyScalar:i,subtractScalar:o,equalScalar:a,DenseMatrix:s}=e;const u=ac({DenseMatrix:s});return t(cc,{"SparseMatrix, Array | Matrix":function(e,t){return function(e,t){const r=(t=u(e,t,!0))._data,c=e._size[0],l=e._size[1],f=e._values,p=e._index,m=e._ptr,d=[];for(let e=l-1;e>=0;e--){const t=r[e][0]||0;if(a(t,0))d[e]=[0];else{let s=0;const u=[],c=[],l=m[e];for(let t=m[e+1]-1;t>=l;t--){const r=p[t];r===e?s=f[t]:r=0;e--){const t=r[e][0]||0;let s;if(a(t,0))s=0;else{const u=p[e][e];if(a(u,0))throw new Error("Linear system cannot be solved since matrix is singular");s=n(t,u);for(let t=e-1;t>=0;t--)r[t]=[o(r[t][0]||0,i(s,p[t][e]))]}f[e]=[s]}return new s({data:f,size:[c,1]})}})),fc="lsolveAll",pc=de(fc,["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],(e=>{let{typed:t,matrix:r,divideScalar:n,multiplyScalar:i,subtractScalar:o,equalScalar:a,DenseMatrix:s}=e;const u=ac({DenseMatrix:s});return t(fc,{"SparseMatrix, Array | Matrix":function(e,t){return function(e,t){const r=[u(e,t,!0)._data.map((e=>e[0]))],c=e._size[0],l=e._size[1],f=e._values,p=e._index,m=e._ptr;for(let e=0;ee&&(c.push(f[t]),l.push(r))}if(a(g,0))if(a(u[e],0)){if(0===s){const t=[...u];t[e]=1;for(let e=0,r=l.length;enew s({data:e.map((e=>[e])),size:[c,1]})))}(e,t)},"DenseMatrix, Array | Matrix":function(e,t){return c(e,t)},"Array, Array | Matrix":function(e,t){return c(r(e),t).map((e=>e.valueOf()))}});function c(e,t){const r=[u(e,t,!0)._data.map((e=>e[0]))],c=e._data,l=e._size[0],f=e._size[1];for(let e=0;enew s({data:e.map((e=>[e])),size:[l,1]})))}})),mc="usolveAll",dc=de(mc,["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],(e=>{let{typed:t,matrix:r,divideScalar:n,multiplyScalar:i,subtractScalar:o,equalScalar:a,DenseMatrix:s}=e;const u=ac({DenseMatrix:s});return t(mc,{"SparseMatrix, Array | Matrix":function(e,t){return function(e,t){const r=[u(e,t,!0)._data.map((e=>e[0]))],c=e._size[0],l=e._size[1],f=e._values,p=e._index,m=e._ptr;for(let e=l-1;e>=0;e--){let t=r.length;for(let s=0;s=d;t--){const r=p[t];r===e?h=f[t]:rnew s({data:e.map((e=>[e])),size:[c,1]})))}(e,t)},"DenseMatrix, Array | Matrix":function(e,t){return c(e,t)},"Array, Array | Matrix":function(e,t){return c(r(e),t).map((e=>e.valueOf()))}});function c(e,t){const r=[u(e,t,!0)._data.map((e=>e[0]))],c=e._data,l=e._size[0];for(let t=e._size[1]-1;t>=0;t--){let e=r.length;for(let s=0;s=0;r--)e[r]=o(e[r],c[r][t]);r.push(e)}}else{if(0===s)return[];r.splice(s,1),s-=1,e-=1}else{u[t]=n(u[t],c[t][t]);for(let e=t-1;e>=0;e--)u[e]=o(u[e],i(u[t],c[e][t]))}}}return r.map((e=>new s({data:e.map((e=>[e])),size:[l,1]})))}})),hc=de("matAlgo08xS0Sid",["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return function(e,n,i){const o=e._values,a=e._index,s=e._ptr,u=e._size,c=e._datatype||void 0===e._data?e._datatype:e.getDataType(),l=n._values,f=n._index,p=n._ptr,m=n._size,d=n._datatype||void 0===n._data?n._datatype:n.getDataType();if(u.length!==m.length)throw new an(u.length,m.length);if(u[0]!==m[0]||u[1]!==m[1])throw new RangeError("Dimension mismatch. Matrix A ("+u+") must match Matrix B ("+m+")");if(!o||!l)throw new Error("Cannot perform operation on Pattern Sparse Matrices");const h=u[0],g=u[1];let y,x=r,b=0,v=i;"string"==typeof c&&c===d&&"mixed"!==c&&(y=c,x=t.find(r,[y,y]),b=t.convert(0,y),v=t.find(i,[y,y]));const w=[],N=[],E=[],A=[],S=[];let M,C,T,D;for(let e=0;e{let{typed:t,matrix:r}=e;return{"Array, number":t.referTo("DenseMatrix, number",(e=>(t,n)=>e(r(t),n).valueOf())),"Array, BigNumber":t.referTo("DenseMatrix, BigNumber",(e=>(t,n)=>e(r(t),n).valueOf())),"number, Array":t.referTo("number, DenseMatrix",(e=>(t,n)=>e(t,r(n)).valueOf())),"BigNumber, Array":t.referTo("BigNumber, DenseMatrix",(e=>(t,n)=>e(t,r(n)).valueOf()))}})),yc="leftShift",xc=de(yc,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:o,concat:a}=e;const s=Yo({typed:t}),u=Lo({typed:t,equalScalar:n}),c=hc({typed:t,equalScalar:n}),l=Xo({typed:t,DenseMatrix:o}),f=No({typed:t,equalScalar:n}),p=Ao({typed:t}),m=Vo({typed:t,matrix:r,concat:a}),d=gc({typed:t,matrix:r});return t(yc,{"number, number":Ua,"BigNumber, BigNumber":za,"bigint, bigint":(e,t)=>e<(t,r)=>n(r,0)?t.clone():f(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>n(r,0)?t.clone():p(t,r,e,!1))),"number | BigNumber, SparseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):l(r,t,e,!0))),"number | BigNumber, DenseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):p(r,t,e,!0)))},d,m({SS:c,DS:s,SD:u}))})),bc="rightArithShift",vc=de(bc,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:o,concat:a}=e;const s=Yo({typed:t}),u=Lo({typed:t,equalScalar:n}),c=hc({typed:t,equalScalar:n}),l=Xo({typed:t,DenseMatrix:o}),f=No({typed:t,equalScalar:n}),p=Ao({typed:t}),m=Vo({typed:t,matrix:r,concat:a}),d=gc({typed:t,matrix:r});return t(bc,{"number, number":La,"BigNumber, BigNumber":Ia,"bigint, bigint":(e,t)=>e>>t,"SparseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>n(r,0)?t.clone():f(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>n(r,0)?t.clone():p(t,r,e,!1))),"number | BigNumber, SparseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):l(r,t,e,!0))),"number | BigNumber, DenseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):p(r,t,e,!0)))},d,m({SS:c,DS:s,SD:u}))})),wc="rightLogShift",Nc=de(wc,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:o,concat:a}=e;const s=Yo({typed:t}),u=Lo({typed:t,equalScalar:n}),c=hc({typed:t,equalScalar:n}),l=Xo({typed:t,DenseMatrix:o}),f=No({typed:t,equalScalar:n}),p=Ao({typed:t}),m=Vo({typed:t,matrix:r,concat:a}),d=gc({typed:t,matrix:r});return t(wc,{"number, number":$a,"SparseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>n(r,0)?t.clone():f(t,r,e,!1))),"DenseMatrix, number | BigNumber":t.referToSelf((e=>(t,r)=>n(r,0)?t.clone():p(t,r,e,!1))),"number | BigNumber, SparseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):l(r,t,e,!0))),"number | BigNumber, DenseMatrix":t.referToSelf((e=>(t,r)=>n(t,0)?i(r.size(),r.storage()):p(r,t,e,!0)))},d,m({SS:c,DS:s,SD:u}))})),Ec=de("and",["typed","matrix","equalScalar","zeros","not","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,not:o,concat:a}=e;const s=Lo({typed:t,equalScalar:n}),u=na({typed:t,equalScalar:n}),c=No({typed:t,equalScalar:n}),l=Ao({typed:t}),f=Vo({typed:t,matrix:r,concat:a});return t("and",{"number, number":us,"Complex, Complex":function(e,t){return!(0===e.re&&0===e.im||0===t.re&&0===t.im)},"BigNumber, BigNumber":function(e,t){return!(e.isZero()||t.isZero()||e.isNaN()||t.isNaN())},"bigint, bigint":us,"Unit, Unit":t.referToSelf((e=>(t,r)=>e(t.value||0,r.value||0))),"SparseMatrix, any":t.referToSelf((e=>(t,r)=>o(r)?i(t.size(),t.storage()):c(t,r,e,!1))),"DenseMatrix, any":t.referToSelf((e=>(t,r)=>o(r)?i(t.size(),t.storage()):l(t,r,e,!1))),"any, SparseMatrix":t.referToSelf((e=>(t,r)=>o(t)?i(t.size(),t.storage()):c(r,t,e,!0))),"any, DenseMatrix":t.referToSelf((e=>(t,r)=>o(t)?i(t.size(),t.storage()):l(r,t,e,!0))),"Array, any":t.referToSelf((e=>(t,n)=>e(r(t),n).valueOf())),"any, Array":t.referToSelf((e=>(t,n)=>e(t,r(n)).valueOf()))},f({SS:u,DS:s}))})),Ac="compare",Sc=de(Ac,["typed","config","matrix","equalScalar","BigNumber","Fraction","DenseMatrix","concat"],(e=>{let{typed:t,config:r,equalScalar:n,matrix:i,BigNumber:o,Fraction:a,DenseMatrix:s,concat:u}=e;const c=$o({typed:t}),l=Ho({typed:t,equalScalar:n}),f=Eo({typed:t,DenseMatrix:s}),p=Vo({typed:t,matrix:i,concat:u}),m=yi({typed:t});return t(Ac,Mc({typed:t,config:r}),{"boolean, boolean":function(e,t){return e===t?0:e>t?1:-1},"BigNumber, BigNumber":function(e,t){return ri(e,t,r.relTol,r.absTol)?new o(0):new o(e.cmp(t))},"bigint, bigint":function(e,t){return e===t?0n:e>t?1n:-1n},"Fraction, Fraction":function(e,t){return new a(e.compare(t))},"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},m,p({SS:l,DS:c,Ss:f}))})),Mc=de(Ac,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(Ac,{"number, number":function(e,t){return _e(e,t,r.relTol,r.absTol)?0:e>t?1:-1}})}));var Cc=r(1880);const Tc="compareNatural",Dc=de(Tc,["typed","compare"],(e=>{let{typed:t,compare:r}=e;const n=r.signatures["boolean,boolean"];return t(Tc,{"any, any":function e(t,a){const s=oe(t),u=oe(a);let c;if(!("number"!==s&&"BigNumber"!==s&&"Fraction"!==s||"number"!==u&&"BigNumber"!==u&&"Fraction"!==u))return c=r(t,a),"0"!==c.toString()?c>0?1:-1:Cc(s,u);const l=["Array","DenseMatrix","SparseMatrix"];if(l.includes(s)||l.includes(u))return c=i(e,t,a),0!==c?c:Cc(s,u);if(s!==u)return Cc(s,u);if("Complex"===s)return function(e,t){return e.re>t.re?1:e.ret.im?1:e.imr.length?1:t.length{let{typed:t,matrix:r,concat:n}=e;const i=Vo({typed:t,matrix:r,concat:n});return t(Fc,on,i({elop:on,Ds:!0}))})),_c="equal",zc=de(_c,["typed","matrix","equalScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ja({typed:t,DenseMatrix:i}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:r,concat:o});return t(_c,Ic({typed:t,equalScalar:n}),c({elop:n,SS:s,DS:a,Ss:u}))})),Ic=de(_c,["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return t(_c,{"any, any":function(e,t){return null===e?null===t:null===t?null===e:void 0===e?void 0===t:void 0===t?void 0===e:r(e,t)}})})),kc="equalText",qc=de(kc,["typed","compareText","isZero"],(e=>{let{typed:t,compareText:r,isZero:n}=e;return t(kc,{"any, any":function(e,t){return n(r(e,t))}})})),Rc="smaller",Pc=de(Rc,["typed","config","matrix","DenseMatrix","concat"],(e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ja({typed:t,DenseMatrix:i}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:n,concat:o}),l=yi({typed:t});return t(Rc,jc({typed:t,config:r}),{"boolean, boolean":(e,t)=>ee-1===e.compare(t),"Complex, Complex":function(e,t){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:a,Ss:u}))})),jc=de(Rc,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(Rc,{"number, number":function(e,t){return e{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ja({typed:t,DenseMatrix:i}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:n,concat:o}),l=yi({typed:t});return t(Uc,$c({typed:t,config:r}),{"boolean, boolean":(e,t)=>e<=t,"BigNumber, BigNumber":function(e,t){return e.lte(t)||ri(e,t,r.relTol,r.absTol)},"bigint, bigint":(e,t)=>e<=t,"Fraction, Fraction":(e,t)=>1!==e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:a,Ss:u}))})),$c=de(Uc,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(Uc,{"number, number":function(e,t){return e<=t||_e(e,t,r.relTol,r.absTol)}})})),Hc="larger",Gc=de(Hc,["typed","config","matrix","DenseMatrix","concat"],(e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ja({typed:t,DenseMatrix:i}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:n,concat:o}),l=yi({typed:t});return t(Hc,Zc({typed:t,config:r}),{"boolean, boolean":(e,t)=>e>t,"BigNumber, BigNumber":function(e,t){return e.gt(t)&&!ri(e,t,r.relTol,r.absTol)},"bigint, bigint":(e,t)=>e>t,"Fraction, Fraction":(e,t)=>1===e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:a,Ss:u}))})),Zc=de(Hc,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(Hc,{"number, number":function(e,t){return e>t&&!_e(e,t,r.relTol,r.absTol)}})})),Vc="largerEq",Wc=de(Vc,["typed","config","matrix","DenseMatrix","concat"],(e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:o}=e;const a=$o({typed:t}),s=Ja({typed:t,DenseMatrix:i}),u=Eo({typed:t,DenseMatrix:i}),c=Vo({typed:t,matrix:n,concat:o}),l=yi({typed:t});return t(Vc,Yc({typed:t,config:r}),{"boolean, boolean":(e,t)=>e>=t,"BigNumber, BigNumber":function(e,t){return e.gte(t)||ri(e,t,r.relTol,r.absTol)},"bigint, bigint":function(e,t){return e>=t},"Fraction, Fraction":(e,t)=>-1!==e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:a,Ss:u}))})),Yc=de(Vc,["typed","config"],(e=>{let{typed:t,config:r}=e;return t(Vc,{"number, number":function(e,t){return e>=t||_e(e,t,r.relTol,r.absTol)}})})),Jc="deepEqual",Xc=de(Jc,["typed","equal"],(e=>{let{typed:t,equal:r}=e;return t(Jc,{"any, any":function(e,t){return n(e.valueOf(),t.valueOf())}});function n(e,t){if(Array.isArray(e)){if(Array.isArray(t)){const r=e.length;if(r!==t.length)return!1;for(let i=0;i{let{typed:t,config:r,equalScalar:n,matrix:i,DenseMatrix:o,concat:a}=e;const s=$o({typed:t}),u=Ja({typed:t,DenseMatrix:o}),c=Eo({typed:t,DenseMatrix:o}),l=Vo({typed:t,matrix:i,concat:a});return t(Qc,el({typed:t,equalScalar:n}),l({elop:function(e,t){return!n(e,t)},SS:u,DS:s,Ss:c}))})),el=de(Qc,["typed","equalScalar"],(e=>{let{typed:t,equalScalar:r}=e;return t(Qc,{"any, any":function(e,t){return null===e?null!==t:null===t?null!==e:void 0===e?void 0!==t:void 0===t?void 0!==e:!r(e,t)}})})),tl="partitionSelect",rl=de(tl,["typed","isNumeric","isNaN","compare"],(e=>{let{typed:t,isNumeric:r,isNaN:n,compare:i}=e;const o=i,a=(e,t)=>-i(e,t);return t(tl,{"Array | Matrix, number":function(e,t){return s(e,t,o)},"Array | Matrix, number, string":function(e,t,r){if("asc"===r)return s(e,t,o);if("desc"===r)return s(e,t,a);throw new Error('Compare string must be "asc" or "desc"')},"Array | Matrix, number, function":s});function s(e,t,r){if(!ye(t)||t<0)throw new Error("k must be a non-negative integer");if(E(e)){if(e.size().length>1)throw new Error("Only one dimensional matrices supported");return u(e.valueOf(),t,r)}if(Array.isArray(e))return u(e,t,r)}function u(e,t,i){if(t>=e.length)throw new Error("k out of bounds");for(let t=0;t=0){const t=e[n];e[n]=e[r],e[r]=t,--n}else++r;i(e[r],s)>0&&--r,t<=r?a=r:o=r+1}return e[t]}})),nl="sort",il=de(nl,["typed","matrix","compare","compareNatural"],(e=>{let{typed:t,matrix:r,compare:n,compareNatural:i}=e;const o=n,a=(e,t)=>-n(e,t);return t(nl,{Array:function(e){return u(e),e.sort(o)},Matrix:function(e){return c(e),r(e.toArray().sort(o),e.storage())},"Array, function":function(e,t){return u(e),e.sort(t)},"Matrix, function":function(e,t){return c(e),r(e.toArray().sort(t),e.storage())},"Array, string":function(e,t){return u(e),e.sort(s(t))},"Matrix, string":function(e,t){return c(e),r(e.toArray().sort(s(t)),e.storage())}});function s(e){if("asc"===e)return o;if("desc"===e)return a;if("natural"===e)return i;throw new Error('String "asc", "desc", or "natural" expected')}function u(e){if(1!==un(e).length)throw new Error("One dimensional array expected")}function c(e){if(1!==e.size().length)throw new Error("One dimensional matrix expected")}})),ol=de("max",["typed","config","numeric","larger"],(e=>{let{typed:t,config:r,numeric:n,larger:i}=e;return t("max",{"Array | Matrix":a,"Array | Matrix, number | BigNumber":function(e,t){return Vn(e,t.valueOf(),o)},"...":function(e){if(Hn(e))throw new TypeError("Scalar values expected in function max");return a(e)}});function o(e,t){try{return i(e,t)?e:t}catch(e){throw Du(e,"max",t)}}function a(e){let t;if(Gn(e,(function(e){try{isNaN(e)&&"number"==typeof e?t=NaN:(void 0===t||i(e,t))&&(t=e)}catch(t){throw Du(t,"max",e)}})),void 0===t)throw new Error("Cannot calculate max of an empty array");return"string"==typeof t&&(t=n(t,xe(t,r))),t}})),al=de("min",["typed","config","numeric","smaller"],(e=>{let{typed:t,config:r,numeric:n,smaller:i}=e;return t("min",{"Array | Matrix":a,"Array | Matrix, number | BigNumber":function(e,t){return Vn(e,t.valueOf(),o)},"...":function(e){if(Hn(e))throw new TypeError("Scalar values expected in function min");return a(e)}});function o(e,t){try{return i(e,t)?e:t}catch(e){throw Du(e,"min",t)}}function a(e){let t;if(Gn(e,(function(e){try{isNaN(e)&&"number"==typeof e?t=NaN:(void 0===t||i(e,t))&&(t=e)}catch(t){throw Du(t,"min",e)}})),void 0===t)throw new Error("Cannot calculate min of an empty array");return"string"==typeof t&&(t=n(t,xe(t,r))),t}})),sl=de("ImmutableDenseMatrix",["smaller","DenseMatrix"],(e=>{let{smaller:t,DenseMatrix:r}=e;function n(e,t){if(!(this instanceof n))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!w(t))throw new Error("Invalid datatype: "+t);if(E(e)||N(e)){const n=new r(e,t);this._data=n._data,this._size=n._size,this._datatype=n._datatype,this._min=null,this._max=null}else if(e&&N(e.data)&&N(e.size))this._data=e.data,this._size=e.size,this._datatype=e.datatype,this._min=void 0!==e.min?e.min:null,this._max=void 0!==e.max?e.max:null;else{if(e)throw new TypeError("Unsupported type of data ("+oe(e)+")");this._data=[],this._size=[0],this._datatype=t,this._min=null,this._max=null}}return n.prototype=new r,n.prototype.type="ImmutableDenseMatrix",n.prototype.isImmutableDenseMatrix=!0,n.prototype.subset=function(e){switch(arguments.length){case 1:{const t=r.prototype.subset.call(this,e);return E(t)?new n({data:t._data,size:t._size,datatype:t._datatype}):t}case 2:case 3:throw new Error("Cannot invoke set subset on an Immutable Matrix instance");default:throw new SyntaxError("Wrong number of arguments")}},n.prototype.set=function(){throw new Error("Cannot invoke set on an Immutable Matrix instance")},n.prototype.resize=function(){throw new Error("Cannot invoke resize on an Immutable Matrix instance")},n.prototype.reshape=function(){throw new Error("Cannot invoke reshape on an Immutable Matrix instance")},n.prototype.clone=function(){return new n({data:ae(this._data),size:ae(this._size),datatype:this._datatype})},n.prototype.toJSON=function(){return{mathjs:"ImmutableDenseMatrix",data:this._data,size:this._size,datatype:this._datatype}},n.fromJSON=function(e){return new n(e)},n.prototype.swapRows=function(){throw new Error("Cannot invoke swapRows on an Immutable Matrix instance")},n.prototype.min=function(){if(null===this._min){let e=null;this.forEach((function(r){(null===e||t(r,e))&&(e=r)})),this._min=null!==e?e:void 0}return this._min},n.prototype.max=function(){if(null===this._max){let e=null;this.forEach((function(r){(null===e||t(e,r))&&(e=r)})),this._max=null!==e?e:void 0}return this._max},n}),{isClass:!0}),ul=de("Index",["ImmutableDenseMatrix","getMatrixDataType"],(e=>{let{ImmutableDenseMatrix:t,getMatrixDataType:r}=e;function n(e){if(!(this instanceof n))throw new SyntaxError("Constructor must be called with the new operator");this._dimensions=[],this._sourceSize=[],this._isScalar=!0;for(let e=0,t=arguments.length;e{e&&t.push(r)})),t}const ll=de("FibonacciHeap",["smaller","larger"],(e=>{let{smaller:t,larger:r}=e;const n=1/Math.log((1+Math.sqrt(5))/2);function i(){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");this._minimum=null,this._size=0}function o(e,t,r){t.left.right=t.right,t.right.left=t.left,r.degree--,r.child===t&&(r.child=t.right),0===r.degree&&(r.child=null),t.left=e,t.right=e.right,e.right=t,t.right.left=t,t.parent=null,t.mark=!1}function a(e,t){const r=t.parent;r&&(t.mark?(o(e,t,r),a(r)):t.mark=!0)}i.prototype.type="FibonacciHeap",i.prototype.isFibonacciHeap=!0,i.prototype.insert=function(e,r){const n={key:e,value:r,degree:0};if(this._minimum){const r=this._minimum;n.left=r,n.right=r.right,r.right=n,n.right.left=n,t(e,r.key)&&(this._minimum=n)}else n.left=n,n.right=n,this._minimum=n;return this._size++,n},i.prototype.size=function(){return this._size},i.prototype.clear=function(){this._minimum=null,this._size=0},i.prototype.isEmpty=function(){return 0===this._size},i.prototype.extractMinimum=function(){const e=this._minimum;if(null===e)return e;let i=this._minimum,o=e.degree,a=e.child;for(;o>0;){const e=a.right;a.left.right=a.right,a.right.left=a.left,a.left=i,a.right=i.right,i.right=a,a.right.left=a,a.parent=null,a=e,o--}return e.left.right=e.right,e.right.left=e.left,e===e.right?i=null:(i=e.right,i=function(e,i){const o=Math.floor(Math.log(i)*n)+1,a=new Array(o);let u,c=0,l=e;if(l)for(c++,l=l.right;l!==e;)c++,l=l.right;for(;c>0;){let e=l.degree;const t=l.right;for(;u=a[e],u;){if(r(l.key,u.key)){const e=u;u=l,l=e}s(u,l),a[e]=null,e++}a[e]=l,l=t,c--}e=null;for(let r=0;r{let{addScalar:t,equalScalar:r,FibonacciHeap:n}=e;function i(){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");this._values=[],this._heap=new n}return i.prototype.type="Spa",i.prototype.isSpa=!0,i.prototype.set=function(e,t){if(this._values[e])this._values[e].value=t;else{const r=this._heap.insert(e,t);this._values[e]=r}},i.prototype.get=function(e){const t=this._values[e];return t?t.value:0},i.prototype.accumulate=function(e,r){let n=this._values[e];n?n.value=t(n.value,r):(n=this._heap.insert(e,r),this._values[e]=n)},i.prototype.forEach=function(e,t,n){const i=this._heap,o=this._values,a=[];let s=i.extractMinimum();for(s&&a.push(s);s&&s.key<=t;)s.key>=e&&(r(s.value,0)||n(s.key,s.value,this)),s=i.extractMinimum(),s&&a.push(s);for(let e=0;e1&&void 0!==arguments[1]?arguments[1]:{};return r=null==r?Number.POSITIVE_INFINITY:r,t=null==t?JSON.stringify:t,function n(){"object"!=typeof n.cache&&(n.cache={values:new Map,lru:pl(r||Number.POSITIVE_INFINITY)});const i=[];for(let e=0;e{let{on:t,config:r,addScalar:n,subtractScalar:i,multiplyScalar:o,divideScalar:a,pow:s,abs:u,fix:c,round:l,equal:f,isNumeric:p,format:m,number:d,Complex:h,BigNumber:g,Fraction:y}=e;const b=d;function w(e,t){if(!(this instanceof w))throw new Error("Constructor must be called with the new operator");if(null!=e&&!p(e)&&!x(e))throw new TypeError("First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined");if(this.fixPrefix=!1,this.skipAutomaticSimplification=!0,void 0===t)this.units=[],this.dimensions=I.map((e=>0));else if("string"==typeof t){const e=w.parse(t);this.units=e.units,this.dimensions=e.dimensions}else{if(!v(t)||null!==t.value)throw new TypeError("Second parameter in Unit constructor must be a string or valueless Unit");this.fixPrefix=t.fixPrefix,this.skipAutomaticSimplification=t.skipAutomaticSimplification,this.dimensions=t.dimensions.slice(0),this.units=t.units.map((e=>Wr({},e)))}this.value=this._normalize(e)}let N,E,A;function S(){for(;" "===A||"\t"===A;)C()}function M(e){return e>="0"&&e<="9"}function C(){E++,A=N.charAt(E)}function T(e){E=e,A=N.charAt(E)}function D(){let e="";const t=E;if("+"===A?C():"-"===A&&(e+=A,C()),!function(e){return e>="0"&&e<="9"||"."===e}(A))return T(t),null;if("."===A){if(e+=A,C(),!M(A))return T(t),null}else{for(;M(A);)e+=A,C();"."===A&&(e+=A,C())}for(;M(A);)e+=A,C();if("E"===A||"e"===A){let t="";const r=E;if(t+=A,C(),"+"!==A&&"-"!==A||(t+=A,C()),!M(A))return T(r),e;for(e+=t;M(A);)e+=A,C()}return e}function F(){let e="";for(;M(A)||w.isValidAlpha(A);)e+=A,C();const t=e.charAt(0);return w.isValidAlpha(t)?e:null}function O(e){return A===e?(C(),e):null}Object.defineProperty(w,"name",{value:"Unit"}),w.prototype.constructor=w,w.prototype.type="Unit",w.prototype.isUnit=!0,w.parse=function(e,t){if(t=t||{},N=e,E=-1,A="","string"!=typeof N)throw new TypeError("Invalid argument in Unit.parse, string expected");const n=new w;n.units=[];let i=1,o=!1;C(),S();const a=D();let s=null;if(a){if("BigNumber"===r.number)s=new g(a);else if("Fraction"===r.number)try{s=new y(a)}catch(e){s=parseFloat(a)}else s=parseFloat(a);S(),O("*")?(i=1,o=!0):O("/")&&(i=-1,o=!0)}const u=[];let c=1;for(;;){for(S();"("===A;)u.push(i),c*=i,i=1,C(),S();let t;if(!A)break;{const e=A;if(t=F(),null===t)throw new SyntaxError('Unexpected "'+e+'" in "'+N+'" at index '+E.toString())}const r=B(t);if(null===r)throw new SyntaxError('Unit "'+t+'" not found.');let a=i*c;if(S(),O("^")){S();const t=D();if(null===t)throw new SyntaxError('In "'+e+'", "^" must be followed by a floating-point number');a*=t}n.units.push({unit:r.unit,prefix:r.prefix,power:a});for(let e=0;e1||Math.abs(this.units[0].power-1)>1e-15)},w.prototype._normalize=function(e){if(null==e||0===this.units.length)return e;let t=e;const r=w._getNumberConverter(oe(e));for(let e=0;e{if(me(R,e)){const t=R[e];return{unit:t,prefix:t.prefixes[""]}}for(const t in R)if(me(R,t)&&Qr(e,t)){const r=R[t],n=e.length-t.length,i=e.substring(0,n),o=me(r.prefixes,i)?r.prefixes[i]:void 0;if(void 0!==o)return{unit:r,prefix:o}}return null}),{hasher:e=>e[0],limit:100});function _(e){return e.equalBase(k.NONE)&&null!==e.value&&!r.predictable?e.value:e}w.isValuelessUnit=function(e){return null!==B(e)},w.prototype.hasBase=function(e){if("string"==typeof e&&(e=k[e]),!e)return!1;for(let t=0;t1e-12)return!1;return!0},w.prototype.equalBase=function(e){for(let t=0;t1e-12)return!1;return!0},w.prototype.equals=function(e){return this.equalBase(e)&&f(this.value,e.value)},w.prototype.multiply=function(e){const t=this.clone(),r=v(e)?e:new w(e);for(let e=0;e0?this.formatUnits():null,fixPrefix:this.fixPrefix}},w.fromJSON=function(e){var t;const r=new w(e.value,null!==(t=e.unit)&&void 0!==t?t:void 0);return r.fixPrefix=e.fixPrefix||!1,r},w.prototype.valueOf=w.prototype.toString,w.prototype.simplify=function(){const e=this.clone(),t=[];let r;for(const t in L)if(me(L,t)&&e.hasBase(k[t])){r=t;break}if("NONE"===r)e.units=[];else{let n;if(r&&me(L,r)&&(n=L[r]),n)e.units=[{unit:n.unit,prefix:n.prefix,power:1}];else{let r=!1;for(let n=0;n1e-12&&(me(L,i)?t.push({unit:L[i].unit,prefix:L[i].prefix,power:e.dimensions[n]||0}):r=!0)}t.length1e-12){if(!me(U.si,n))throw new Error("Cannot express custom unit "+n+" in SI units");t.push({unit:U.si[n].unit,prefix:U.si[n].prefix,power:e.dimensions[r]||0})}}return e.units=t,e.fixPrefix=!0,e.skipAutomaticSimplification=!0,null!==this.value?(e.value=null,this.to(e)):e},w.prototype.formatUnits=function(){let e="",t="",r=0,n=0;for(let t=0;t0?(r++,e+=" "+this.units[t].prefix.name+this.units[t].unit.name,Math.abs(this.units[t].power-1)>1e-15&&(e+="^"+this.units[t].power)):this.units[t].power<0&&n++;if(n>0)for(let e=0;e0?(t+=" "+this.units[e].prefix.name+this.units[e].unit.name,Math.abs(this.units[e].power+1)>1e-15&&(t+="^"+-this.units[e].power)):(t+=" "+this.units[e].prefix.name+this.units[e].unit.name,t+="^"+this.units[e].power));e=e.substr(1),t=t.substr(1),r>1&&n>0&&(e="("+e+")"),n>1&&r>0&&(t="("+t+")");let i=e;return r>0&&n>0&&(i+=" / "),i+=t,i},w.prototype.format=function(e){const t=this.skipAutomaticSimplification||null===this.value?this.clone():this.simplify();let r=!1;void 0!==t.value&&null!==t.value&&x(t.value)&&(r=Math.abs(t.value.re)<1e-14);for(const e in t.units)me(t.units,e)&&t.units[e].unit&&("VA"===t.units[e].unit.name&&r?t.units[e].unit=R.VAR:"VAR"!==t.units[e].unit.name||r||(t.units[e].unit=R.VA));1!==t.units.length||t.fixPrefix||Math.abs(t.units[0].power-Math.round(t.units[0].power))<1e-14&&(t.units[0].prefix=t._bestPrefix());const n=t._denormalize(t.value);let i=null!==t.value?m(n,e||{}):"";const o=t.formatUnits();return t.value&&x(t.value)&&(i="("+i+")"),o.length>0&&i.length>0&&(i+=" "),i+=o,i},w.prototype._bestPrefix=function(){if(1!==this.units.length)throw new Error("Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!");if(Math.abs(this.units[0].power-Math.round(this.units[0].power))>=1e-14)throw new Error("Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!");const e=null!==this.value?u(this.value):0,t=u(this.units[0].unit.value);let r=this.units[0].prefix;if(0===e)return r;const n=this.units[0].power;let i=Math.log(e/Math.pow(r.value*t,n))/Math.LN10-1.2;if(i>-2.200001&&i<1.800001)return r;i=Math.abs(i);const o=this.units[0].unit.prefixes;for(const a in o)if(me(o,a)){const s=o[a];if(s.scientific){const o=Math.abs(Math.log(e/Math.pow(s.value*t,n))/Math.LN10-1.2);(o0))},R={meter:{name:"meter",base:k.LENGTH,prefixes:z.LONG,value:1,offset:0},inch:{name:"inch",base:k.LENGTH,prefixes:z.NONE,value:.0254,offset:0},foot:{name:"foot",base:k.LENGTH,prefixes:z.NONE,value:.3048,offset:0},yard:{name:"yard",base:k.LENGTH,prefixes:z.NONE,value:.9144,offset:0},mile:{name:"mile",base:k.LENGTH,prefixes:z.NONE,value:1609.344,offset:0},link:{name:"link",base:k.LENGTH,prefixes:z.NONE,value:.201168,offset:0},rod:{name:"rod",base:k.LENGTH,prefixes:z.NONE,value:5.0292,offset:0},chain:{name:"chain",base:k.LENGTH,prefixes:z.NONE,value:20.1168,offset:0},angstrom:{name:"angstrom",base:k.LENGTH,prefixes:z.NONE,value:1e-10,offset:0},m:{name:"m",base:k.LENGTH,prefixes:z.SHORT,value:1,offset:0},in:{name:"in",base:k.LENGTH,prefixes:z.NONE,value:.0254,offset:0},ft:{name:"ft",base:k.LENGTH,prefixes:z.NONE,value:.3048,offset:0},yd:{name:"yd",base:k.LENGTH,prefixes:z.NONE,value:.9144,offset:0},mi:{name:"mi",base:k.LENGTH,prefixes:z.NONE,value:1609.344,offset:0},li:{name:"li",base:k.LENGTH,prefixes:z.NONE,value:.201168,offset:0},rd:{name:"rd",base:k.LENGTH,prefixes:z.NONE,value:5.02921,offset:0},ch:{name:"ch",base:k.LENGTH,prefixes:z.NONE,value:20.1168,offset:0},mil:{name:"mil",base:k.LENGTH,prefixes:z.NONE,value:254e-7,offset:0},m2:{name:"m2",base:k.SURFACE,prefixes:z.SQUARED,value:1,offset:0},sqin:{name:"sqin",base:k.SURFACE,prefixes:z.NONE,value:64516e-8,offset:0},sqft:{name:"sqft",base:k.SURFACE,prefixes:z.NONE,value:.09290304,offset:0},sqyd:{name:"sqyd",base:k.SURFACE,prefixes:z.NONE,value:.83612736,offset:0},sqmi:{name:"sqmi",base:k.SURFACE,prefixes:z.NONE,value:2589988.110336,offset:0},sqrd:{name:"sqrd",base:k.SURFACE,prefixes:z.NONE,value:25.29295,offset:0},sqch:{name:"sqch",base:k.SURFACE,prefixes:z.NONE,value:404.6873,offset:0},sqmil:{name:"sqmil",base:k.SURFACE,prefixes:z.NONE,value:6.4516e-10,offset:0},acre:{name:"acre",base:k.SURFACE,prefixes:z.NONE,value:4046.86,offset:0},hectare:{name:"hectare",base:k.SURFACE,prefixes:z.NONE,value:1e4,offset:0},m3:{name:"m3",base:k.VOLUME,prefixes:z.CUBIC,value:1,offset:0},L:{name:"L",base:k.VOLUME,prefixes:z.SHORT,value:.001,offset:0},l:{name:"l",base:k.VOLUME,prefixes:z.SHORT,value:.001,offset:0},litre:{name:"litre",base:k.VOLUME,prefixes:z.LONG,value:.001,offset:0},cuin:{name:"cuin",base:k.VOLUME,prefixes:z.NONE,value:16387064e-12,offset:0},cuft:{name:"cuft",base:k.VOLUME,prefixes:z.NONE,value:.028316846592,offset:0},cuyd:{name:"cuyd",base:k.VOLUME,prefixes:z.NONE,value:.764554857984,offset:0},teaspoon:{name:"teaspoon",base:k.VOLUME,prefixes:z.NONE,value:5e-6,offset:0},tablespoon:{name:"tablespoon",base:k.VOLUME,prefixes:z.NONE,value:15e-6,offset:0},drop:{name:"drop",base:k.VOLUME,prefixes:z.NONE,value:5e-8,offset:0},gtt:{name:"gtt",base:k.VOLUME,prefixes:z.NONE,value:5e-8,offset:0},minim:{name:"minim",base:k.VOLUME,prefixes:z.NONE,value:6.1611519921875e-8,offset:0},fluiddram:{name:"fluiddram",base:k.VOLUME,prefixes:z.NONE,value:36966911953125e-19,offset:0},fluidounce:{name:"fluidounce",base:k.VOLUME,prefixes:z.NONE,value:295735295625e-16,offset:0},gill:{name:"gill",base:k.VOLUME,prefixes:z.NONE,value:.00011829411825,offset:0},cc:{name:"cc",base:k.VOLUME,prefixes:z.NONE,value:1e-6,offset:0},cup:{name:"cup",base:k.VOLUME,prefixes:z.NONE,value:.0002365882365,offset:0},pint:{name:"pint",base:k.VOLUME,prefixes:z.NONE,value:.000473176473,offset:0},quart:{name:"quart",base:k.VOLUME,prefixes:z.NONE,value:.000946352946,offset:0},gallon:{name:"gallon",base:k.VOLUME,prefixes:z.NONE,value:.003785411784,offset:0},beerbarrel:{name:"beerbarrel",base:k.VOLUME,prefixes:z.NONE,value:.117347765304,offset:0},oilbarrel:{name:"oilbarrel",base:k.VOLUME,prefixes:z.NONE,value:.158987294928,offset:0},hogshead:{name:"hogshead",base:k.VOLUME,prefixes:z.NONE,value:.238480942392,offset:0},g:{name:"g",base:k.MASS,prefixes:z.SHORT,value:.001,offset:0},gram:{name:"gram",base:k.MASS,prefixes:z.LONG,value:.001,offset:0},ton:{name:"ton",base:k.MASS,prefixes:z.SHORT,value:907.18474,offset:0},t:{name:"t",base:k.MASS,prefixes:z.SHORT,value:1e3,offset:0},tonne:{name:"tonne",base:k.MASS,prefixes:z.LONG,value:1e3,offset:0},grain:{name:"grain",base:k.MASS,prefixes:z.NONE,value:6479891e-11,offset:0},dram:{name:"dram",base:k.MASS,prefixes:z.NONE,value:.0017718451953125,offset:0},ounce:{name:"ounce",base:k.MASS,prefixes:z.NONE,value:.028349523125,offset:0},poundmass:{name:"poundmass",base:k.MASS,prefixes:z.NONE,value:.45359237,offset:0},hundredweight:{name:"hundredweight",base:k.MASS,prefixes:z.NONE,value:45.359237,offset:0},stick:{name:"stick",base:k.MASS,prefixes:z.NONE,value:.115,offset:0},stone:{name:"stone",base:k.MASS,prefixes:z.NONE,value:6.35029318,offset:0},gr:{name:"gr",base:k.MASS,prefixes:z.NONE,value:6479891e-11,offset:0},dr:{name:"dr",base:k.MASS,prefixes:z.NONE,value:.0017718451953125,offset:0},oz:{name:"oz",base:k.MASS,prefixes:z.NONE,value:.028349523125,offset:0},lbm:{name:"lbm",base:k.MASS,prefixes:z.NONE,value:.45359237,offset:0},cwt:{name:"cwt",base:k.MASS,prefixes:z.NONE,value:45.359237,offset:0},s:{name:"s",base:k.TIME,prefixes:z.SHORT,value:1,offset:0},min:{name:"min",base:k.TIME,prefixes:z.NONE,value:60,offset:0},h:{name:"h",base:k.TIME,prefixes:z.NONE,value:3600,offset:0},second:{name:"second",base:k.TIME,prefixes:z.LONG,value:1,offset:0},sec:{name:"sec",base:k.TIME,prefixes:z.LONG,value:1,offset:0},minute:{name:"minute",base:k.TIME,prefixes:z.NONE,value:60,offset:0},hour:{name:"hour",base:k.TIME,prefixes:z.NONE,value:3600,offset:0},day:{name:"day",base:k.TIME,prefixes:z.NONE,value:86400,offset:0},week:{name:"week",base:k.TIME,prefixes:z.NONE,value:604800,offset:0},month:{name:"month",base:k.TIME,prefixes:z.NONE,value:2629800,offset:0},year:{name:"year",base:k.TIME,prefixes:z.NONE,value:31557600,offset:0},decade:{name:"decade",base:k.TIME,prefixes:z.NONE,value:315576e3,offset:0},century:{name:"century",base:k.TIME,prefixes:z.NONE,value:315576e4,offset:0},millennium:{name:"millennium",base:k.TIME,prefixes:z.NONE,value:315576e5,offset:0},hertz:{name:"Hertz",base:k.FREQUENCY,prefixes:z.LONG,value:1,offset:0,reciprocal:!0},Hz:{name:"Hz",base:k.FREQUENCY,prefixes:z.SHORT,value:1,offset:0,reciprocal:!0},rad:{name:"rad",base:k.ANGLE,prefixes:z.SHORT,value:1,offset:0},radian:{name:"radian",base:k.ANGLE,prefixes:z.LONG,value:1,offset:0},deg:{name:"deg",base:k.ANGLE,prefixes:z.SHORT,value:null,offset:0},degree:{name:"degree",base:k.ANGLE,prefixes:z.LONG,value:null,offset:0},grad:{name:"grad",base:k.ANGLE,prefixes:z.SHORT,value:null,offset:0},gradian:{name:"gradian",base:k.ANGLE,prefixes:z.LONG,value:null,offset:0},cycle:{name:"cycle",base:k.ANGLE,prefixes:z.NONE,value:null,offset:0},arcsec:{name:"arcsec",base:k.ANGLE,prefixes:z.NONE,value:null,offset:0},arcmin:{name:"arcmin",base:k.ANGLE,prefixes:z.NONE,value:null,offset:0},A:{name:"A",base:k.CURRENT,prefixes:z.SHORT,value:1,offset:0},ampere:{name:"ampere",base:k.CURRENT,prefixes:z.LONG,value:1,offset:0},K:{name:"K",base:k.TEMPERATURE,prefixes:z.SHORT,value:1,offset:0},degC:{name:"degC",base:k.TEMPERATURE,prefixes:z.SHORT,value:1,offset:273.15},degF:{name:"degF",base:k.TEMPERATURE,prefixes:z.SHORT,value:new y(5,9),offset:459.67},degR:{name:"degR",base:k.TEMPERATURE,prefixes:z.SHORT,value:new y(5,9),offset:0},kelvin:{name:"kelvin",base:k.TEMPERATURE,prefixes:z.LONG,value:1,offset:0},celsius:{name:"celsius",base:k.TEMPERATURE,prefixes:z.LONG,value:1,offset:273.15},fahrenheit:{name:"fahrenheit",base:k.TEMPERATURE,prefixes:z.LONG,value:new y(5,9),offset:459.67},rankine:{name:"rankine",base:k.TEMPERATURE,prefixes:z.LONG,value:new y(5,9),offset:0},mol:{name:"mol",base:k.AMOUNT_OF_SUBSTANCE,prefixes:z.SHORT,value:1,offset:0},mole:{name:"mole",base:k.AMOUNT_OF_SUBSTANCE,prefixes:z.LONG,value:1,offset:0},cd:{name:"cd",base:k.LUMINOUS_INTENSITY,prefixes:z.SHORT,value:1,offset:0},candela:{name:"candela",base:k.LUMINOUS_INTENSITY,prefixes:z.LONG,value:1,offset:0},N:{name:"N",base:k.FORCE,prefixes:z.SHORT,value:1,offset:0},newton:{name:"newton",base:k.FORCE,prefixes:z.LONG,value:1,offset:0},dyn:{name:"dyn",base:k.FORCE,prefixes:z.SHORT,value:1e-5,offset:0},dyne:{name:"dyne",base:k.FORCE,prefixes:z.LONG,value:1e-5,offset:0},lbf:{name:"lbf",base:k.FORCE,prefixes:z.NONE,value:4.4482216152605,offset:0},poundforce:{name:"poundforce",base:k.FORCE,prefixes:z.NONE,value:4.4482216152605,offset:0},kip:{name:"kip",base:k.FORCE,prefixes:z.LONG,value:4448.2216,offset:0},kilogramforce:{name:"kilogramforce",base:k.FORCE,prefixes:z.NONE,value:9.80665,offset:0},J:{name:"J",base:k.ENERGY,prefixes:z.SHORT,value:1,offset:0},joule:{name:"joule",base:k.ENERGY,prefixes:z.LONG,value:1,offset:0},erg:{name:"erg",base:k.ENERGY,prefixes:z.SHORTLONG,value:1e-7,offset:0},Wh:{name:"Wh",base:k.ENERGY,prefixes:z.SHORT,value:3600,offset:0},BTU:{name:"BTU",base:k.ENERGY,prefixes:z.BTU,value:1055.05585262,offset:0},eV:{name:"eV",base:k.ENERGY,prefixes:z.SHORT,value:1602176565e-28,offset:0},electronvolt:{name:"electronvolt",base:k.ENERGY,prefixes:z.LONG,value:1602176565e-28,offset:0},W:{name:"W",base:k.POWER,prefixes:z.SHORT,value:1,offset:0},watt:{name:"watt",base:k.POWER,prefixes:z.LONG,value:1,offset:0},hp:{name:"hp",base:k.POWER,prefixes:z.NONE,value:745.6998715386,offset:0},VAR:{name:"VAR",base:k.POWER,prefixes:z.SHORT,value:h.I,offset:0},VA:{name:"VA",base:k.POWER,prefixes:z.SHORT,value:1,offset:0},Pa:{name:"Pa",base:k.PRESSURE,prefixes:z.SHORT,value:1,offset:0},psi:{name:"psi",base:k.PRESSURE,prefixes:z.NONE,value:6894.75729276459,offset:0},atm:{name:"atm",base:k.PRESSURE,prefixes:z.NONE,value:101325,offset:0},bar:{name:"bar",base:k.PRESSURE,prefixes:z.SHORTLONG,value:1e5,offset:0},torr:{name:"torr",base:k.PRESSURE,prefixes:z.NONE,value:133.322,offset:0},mmHg:{name:"mmHg",base:k.PRESSURE,prefixes:z.NONE,value:133.322,offset:0},mmH2O:{name:"mmH2O",base:k.PRESSURE,prefixes:z.NONE,value:9.80665,offset:0},cmH2O:{name:"cmH2O",base:k.PRESSURE,prefixes:z.NONE,value:98.0665,offset:0},coulomb:{name:"coulomb",base:k.ELECTRIC_CHARGE,prefixes:z.LONG,value:1,offset:0},C:{name:"C",base:k.ELECTRIC_CHARGE,prefixes:z.SHORT,value:1,offset:0},farad:{name:"farad",base:k.ELECTRIC_CAPACITANCE,prefixes:z.LONG,value:1,offset:0},F:{name:"F",base:k.ELECTRIC_CAPACITANCE,prefixes:z.SHORT,value:1,offset:0},volt:{name:"volt",base:k.ELECTRIC_POTENTIAL,prefixes:z.LONG,value:1,offset:0},V:{name:"V",base:k.ELECTRIC_POTENTIAL,prefixes:z.SHORT,value:1,offset:0},ohm:{name:"ohm",base:k.ELECTRIC_RESISTANCE,prefixes:z.SHORTLONG,value:1,offset:0},henry:{name:"henry",base:k.ELECTRIC_INDUCTANCE,prefixes:z.LONG,value:1,offset:0},H:{name:"H",base:k.ELECTRIC_INDUCTANCE,prefixes:z.SHORT,value:1,offset:0},siemens:{name:"siemens",base:k.ELECTRIC_CONDUCTANCE,prefixes:z.LONG,value:1,offset:0},S:{name:"S",base:k.ELECTRIC_CONDUCTANCE,prefixes:z.SHORT,value:1,offset:0},weber:{name:"weber",base:k.MAGNETIC_FLUX,prefixes:z.LONG,value:1,offset:0},Wb:{name:"Wb",base:k.MAGNETIC_FLUX,prefixes:z.SHORT,value:1,offset:0},tesla:{name:"tesla",base:k.MAGNETIC_FLUX_DENSITY,prefixes:z.LONG,value:1,offset:0},T:{name:"T",base:k.MAGNETIC_FLUX_DENSITY,prefixes:z.SHORT,value:1,offset:0},b:{name:"b",base:k.BIT,prefixes:z.BINARY_SHORT,value:1,offset:0},bits:{name:"bits",base:k.BIT,prefixes:z.BINARY_LONG,value:1,offset:0},B:{name:"B",base:k.BIT,prefixes:z.BINARY_SHORT,value:8,offset:0},bytes:{name:"bytes",base:k.BIT,prefixes:z.BINARY_LONG,value:8,offset:0}},P={meters:"meter",inches:"inch",feet:"foot",yards:"yard",miles:"mile",links:"link",rods:"rod",chains:"chain",angstroms:"angstrom",lt:"l",litres:"litre",liter:"litre",liters:"litre",teaspoons:"teaspoon",tablespoons:"tablespoon",minims:"minim",fldr:"fluiddram",fluiddrams:"fluiddram",floz:"fluidounce",fluidounces:"fluidounce",gi:"gill",gills:"gill",cp:"cup",cups:"cup",pt:"pint",pints:"pint",qt:"quart",quarts:"quart",gal:"gallon",gallons:"gallon",bbl:"beerbarrel",beerbarrels:"beerbarrel",obl:"oilbarrel",oilbarrels:"oilbarrel",hogsheads:"hogshead",gtts:"gtt",grams:"gram",tons:"ton",tonnes:"tonne",grains:"grain",drams:"dram",ounces:"ounce",poundmasses:"poundmass",hundredweights:"hundredweight",sticks:"stick",lb:"lbm",lbs:"lbm",kips:"kip",kgf:"kilogramforce",acres:"acre",hectares:"hectare",sqfeet:"sqft",sqyard:"sqyd",sqmile:"sqmi",sqmiles:"sqmi",mmhg:"mmHg",mmh2o:"mmH2O",cmh2o:"cmH2O",seconds:"second",secs:"second",minutes:"minute",mins:"minute",hours:"hour",hr:"hour",hrs:"hour",days:"day",weeks:"week",months:"month",years:"year",decades:"decade",centuries:"century",millennia:"millennium",hertz:"hertz",radians:"radian",degrees:"degree",gradians:"gradian",cycles:"cycle",arcsecond:"arcsec",arcseconds:"arcsec",arcminute:"arcmin",arcminutes:"arcmin",BTUs:"BTU",watts:"watt",joules:"joule",amperes:"ampere",amps:"ampere",amp:"ampere",coulombs:"coulomb",volts:"volt",ohms:"ohm",farads:"farad",webers:"weber",teslas:"tesla",electronvolts:"electronvolt",moles:"mole",bit:"bits",byte:"bytes"};function j(e){if("BigNumber"===e.number){const e=gl(g);R.rad.value=new g(1),R.deg.value=e.div(180),R.grad.value=e.div(200),R.cycle.value=e.times(2),R.arcsec.value=e.div(648e3),R.arcmin.value=e.div(10800)}else R.rad.value=1,R.deg.value=Math.PI/180,R.grad.value=Math.PI/200,R.cycle.value=2*Math.PI,R.arcsec.value=Math.PI/648e3,R.arcmin.value=Math.PI/10800;R.radian.value=R.rad.value,R.degree.value=R.deg.value,R.gradian.value=R.grad.value}j(r),t&&t("config",(function(e,t){e.number!==t.number&&j(e)}));const U={si:{NONE:{unit:q,prefix:z.NONE[""]},LENGTH:{unit:R.m,prefix:z.SHORT[""]},MASS:{unit:R.g,prefix:z.SHORT.k},TIME:{unit:R.s,prefix:z.SHORT[""]},CURRENT:{unit:R.A,prefix:z.SHORT[""]},TEMPERATURE:{unit:R.K,prefix:z.SHORT[""]},LUMINOUS_INTENSITY:{unit:R.cd,prefix:z.SHORT[""]},AMOUNT_OF_SUBSTANCE:{unit:R.mol,prefix:z.SHORT[""]},ANGLE:{unit:R.rad,prefix:z.SHORT[""]},BIT:{unit:R.bits,prefix:z.SHORT[""]},FORCE:{unit:R.N,prefix:z.SHORT[""]},ENERGY:{unit:R.J,prefix:z.SHORT[""]},POWER:{unit:R.W,prefix:z.SHORT[""]},PRESSURE:{unit:R.Pa,prefix:z.SHORT[""]},ELECTRIC_CHARGE:{unit:R.C,prefix:z.SHORT[""]},ELECTRIC_CAPACITANCE:{unit:R.F,prefix:z.SHORT[""]},ELECTRIC_POTENTIAL:{unit:R.V,prefix:z.SHORT[""]},ELECTRIC_RESISTANCE:{unit:R.ohm,prefix:z.SHORT[""]},ELECTRIC_INDUCTANCE:{unit:R.H,prefix:z.SHORT[""]},ELECTRIC_CONDUCTANCE:{unit:R.S,prefix:z.SHORT[""]},MAGNETIC_FLUX:{unit:R.Wb,prefix:z.SHORT[""]},MAGNETIC_FLUX_DENSITY:{unit:R.T,prefix:z.SHORT[""]},FREQUENCY:{unit:R.Hz,prefix:z.SHORT[""]}}};U.cgs=JSON.parse(JSON.stringify(U.si)),U.cgs.LENGTH={unit:R.m,prefix:z.SHORT.c},U.cgs.MASS={unit:R.g,prefix:z.SHORT[""]},U.cgs.FORCE={unit:R.dyn,prefix:z.SHORT[""]},U.cgs.ENERGY={unit:R.erg,prefix:z.NONE[""]},U.us=JSON.parse(JSON.stringify(U.si)),U.us.LENGTH={unit:R.ft,prefix:z.NONE[""]},U.us.MASS={unit:R.lbm,prefix:z.NONE[""]},U.us.TEMPERATURE={unit:R.degF,prefix:z.NONE[""]},U.us.FORCE={unit:R.lbf,prefix:z.NONE[""]},U.us.ENERGY={unit:R.BTU,prefix:z.BTU[""]},U.us.POWER={unit:R.hp,prefix:z.NONE[""]},U.us.PRESSURE={unit:R.psi,prefix:z.NONE[""]},U.auto=JSON.parse(JSON.stringify(U.si));let L=U.auto;w.setUnitSystem=function(e){if(!me(U,e))throw new Error("Unit system "+e+" does not exist. Choices are: "+Object.keys(U).join(", "));L=U[e]},w.getUnitSystem=function(){for(const e in U)if(me(U,e)&&U[e]===L)return e},w.typeConverters={BigNumber:function(e){return null!=e&&e.isFraction?new g(e.n).div(e.d).times(e.s):new g(e+"")},Fraction:function(e){return new y(e)},Complex:function(e){return e},number:function(e){return null!=e&&e.isFraction?d(e):e}},w.prototype._numberConverter=function(){const e=w.typeConverters[this.valueType()];if(e)return e;throw new TypeError('Unsupported Unit value type "'+this.valueType()+'"')},w._getNumberConverter=function(e){if(!w.typeConverters[e])throw new TypeError('Unsupported type "'+e+'"');return w.typeConverters[e]};for(const e in R)if(me(R,e)){const t=R[e];t.dimensions=t.base.dimensions}for(const e in P)if(me(P,e)){const t=R[P[e]],r={};for(const e in t)me(t,e)&&(r[e]=t[e]);r.name=e,R[e]=r}return w.isValidAlpha=function(e){return/^[a-zA-Z]$/.test(e)},w.createUnit=function(e,t){if("object"!=typeof e)throw new TypeError("createUnit expects first parameter to be of type 'Object'");if(t&&t.override)for(const t in e)if(me(e,t)&&w.deleteUnit(t),e[t].aliases)for(let r=0;r0&&!w.isValidAlpha(A)&&!M(A))throw new Error('Invalid unit name (only alphanumeric characters are allowed): "'+e+'"')}}(e);let r,n,i,o=null,a=[],s=0;if(t&&"Unit"===t.type)o=t.clone();else if("string"==typeof t)""!==t&&(r=t);else{if("object"!=typeof t)throw new TypeError('Cannot create unit "'+e+'" from "'+t.toString()+'": expecting "string" or "Unit" or "Object"');r=t.definition,n=t.prefixes,s=t.offset,i=t.baseName,t.aliases&&(a=t.aliases.valueOf())}if(a)for(let e=0;e1e-12){r=!1;break}if(r){t=!0,u.base=k[e];break}}if(!t){i=i||e+"_STUFF";const t={dimensions:o.dimensions.slice(0)};t.key=i,k[i]=t,L[i]={unit:u,prefix:z.NONE[""]},u.base=k[i]}}else{if(i=i||e+"_STUFF",I.indexOf(i)>=0)throw new Error('Cannot create new base unit "'+e+'": a base unit with that name already exists (and cannot be overridden)');I.push(i);for(const e in k)me(k,e)&&(k[e].dimensions[I.length-1]=0);const t={dimensions:[]};for(let e=0;e{let{typed:t,Unit:r}=e;return t(vl,{Unit:function(e){return e.clone()},string:function(e){return r.isValuelessUnit(e)?new r(null,e):r.parse(e,{allowNoUnits:!0})},"number | BigNumber | Fraction | Complex, string | Unit":function(e,t){return new r(e,t)},"number | BigNumber | Fraction":function(e){return new r(e)},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),Nl="sparse",El=de(Nl,["typed","SparseMatrix"],(e=>{let{typed:t,SparseMatrix:r}=e;return t(Nl,{"":function(){return new r([])},string:function(e){return new r([],e)},"Array | Matrix":function(e){return new r(e)},"Array | Matrix, string":function(e,t){return new r(e,t)}})})),Al="createUnit",Sl=de(Al,["typed","Unit"],(e=>{let{typed:t,Unit:r}=e;return t(Al,{"Object, Object":function(e,t){return r.createUnit(e,t)},Object:function(e){return r.createUnit(e,{})},"string, Unit | string | Object, Object":function(e,t,n){const i={};return i[e]=t,r.createUnit(i,n)},"string, Unit | string | Object":function(e,t){const n={};return n[e]=t,r.createUnit(n,{})},string:function(e){const t={};return t[e]={},r.createUnit(t,{})}})})),Ml="acos",Cl=de(Ml,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(Ml,{number:function(e){return e>=-1&&e<=1||r.predictable?Math.acos(e):new n(e,0).acos()},Complex:function(e){return e.acos()},BigNumber:function(e){return e.acos()}})})),Tl="number";function Dl(e){return ze(e)}function Fl(e){return Math.atan(1/e)}function Ol(e){return isFinite(e)?(Math.log((e+1)/e)+Math.log(e/(e-1)))/2:0}function Bl(e){return Math.asin(1/e)}function _l(e){const t=1/e;return Math.log(t+Math.sqrt(t*t+1))}function zl(e){return Math.acos(1/e)}function Il(e){const t=1/e,r=Math.sqrt(t*t-1);return Math.log(r+t)}function kl(e){return Ie(e)}function ql(e){return ke(e)}function Rl(e){return 1/Math.tan(e)}function Pl(e){const t=Math.exp(2*e);return(t+1)/(t-1)}function jl(e){return 1/Math.sin(e)}function Ul(e){return 0===e?Number.POSITIVE_INFINITY:Math.abs(2/(Math.exp(e)-Math.exp(-e)))*be(e)}function Ll(e){return 1/Math.cos(e)}function $l(e){return 2/(Math.exp(e)+Math.exp(-e))}function Hl(e){return Re(e)}Dl.signature=Tl,Fl.signature=Tl,Ol.signature=Tl,Bl.signature=Tl,_l.signature=Tl,zl.signature=Tl,Il.signature=Tl,kl.signature=Tl,ql.signature=Tl,Rl.signature=Tl,Pl.signature=Tl,jl.signature=Tl,Ul.signature=Tl,Ll.signature=Tl,$l.signature=Tl,Hl.signature=Tl;const Gl="acosh",Zl=de(Gl,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(Gl,{number:function(e){return e>=1||r.predictable?Dl(e):e<=-1?new n(Math.log(Math.sqrt(e*e-1)-e),Math.PI):new n(e,0).acosh()},Complex:function(e){return e.acosh()},BigNumber:function(e){return e.acosh()}})})),Vl="acot",Wl=de(Vl,["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t(Vl,{number:Fl,Complex:function(e){return e.acot()},BigNumber:function(e){return new r(1).div(e).atan()}})})),Yl="acoth",Jl=de(Yl,["typed","config","Complex","BigNumber"],(e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t(Yl,{number:function(e){return e>=1||e<=-1||r.predictable?Ol(e):new n(e,0).acoth()},Complex:function(e){return e.acoth()},BigNumber:function(e){return new i(1).div(e).atanh()}})})),Xl="acsc",Ql=de(Xl,["typed","config","Complex","BigNumber"],(e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t(Xl,{number:function(e){return e<=-1||e>=1||r.predictable?Bl(e):new n(e,0).acsc()},Complex:function(e){return e.acsc()},BigNumber:function(e){return new i(1).div(e).asin()}})})),Kl="acsch",ef=de(Kl,["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t(Kl,{number:_l,Complex:function(e){return e.acsch()},BigNumber:function(e){return new r(1).div(e).asinh()}})})),tf="asec",rf=de(tf,["typed","config","Complex","BigNumber"],(e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t(tf,{number:function(e){return e<=-1||e>=1||r.predictable?zl(e):new n(e,0).asec()},Complex:function(e){return e.asec()},BigNumber:function(e){return new i(1).div(e).acos()}})})),nf="asech",of=de(nf,["typed","config","Complex","BigNumber"],(e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t(nf,{number:function(e){if(e<=1&&e>=-1||r.predictable){const t=1/e;if(t>0||r.predictable)return Il(e);const i=Math.sqrt(t*t-1);return new n(Math.log(i-t),Math.PI)}return new n(e,0).asech()},Complex:function(e){return e.asech()},BigNumber:function(e){return new i(1).div(e).acosh()}})})),af="asin",sf=de(af,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(af,{number:function(e){return e>=-1&&e<=1||r.predictable?Math.asin(e):new n(e,0).asin()},Complex:function(e){return e.asin()},BigNumber:function(e){return e.asin()}})})),uf=de("asinh",["typed"],(e=>{let{typed:t}=e;return t("asinh",{number:kl,Complex:function(e){return e.asinh()},BigNumber:function(e){return e.asinh()}})})),cf=de("atan",["typed"],(e=>{let{typed:t}=e;return t("atan",{number:function(e){return Math.atan(e)},Complex:function(e){return e.atan()},BigNumber:function(e){return e.atan()}})})),lf="atan2",ff=de(lf,["typed","matrix","equalScalar","BigNumber","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,BigNumber:i,DenseMatrix:o,concat:a}=e;const s=Lo({typed:t,equalScalar:n}),u=$o({typed:t}),c=Sa({typed:t,equalScalar:n}),l=No({typed:t,equalScalar:n}),f=Eo({typed:t,DenseMatrix:o}),p=Vo({typed:t,matrix:r,concat:a});return t(lf,{"number, number":Math.atan2,"BigNumber, BigNumber":(e,t)=>i.atan2(e,t)},p({scalar:"number | BigNumber",SS:c,DS:u,SD:s,Ss:l,sS:f}))})),pf="atanh",mf=de(pf,["typed","config","Complex"],(e=>{let{typed:t,config:r,Complex:n}=e;return t(pf,{number:function(e){return e<=1&&e>=-1||r.predictable?ql(e):new n(e,0).atanh()},Complex:function(e){return e.atanh()},BigNumber:function(e){return e.atanh()}})})),df=de("trigUnit",["typed"],(e=>{let{typed:t}=e;return{Unit:t.referToSelf((e=>r=>{if(!r.hasBase(r.constructor.BASE_UNITS.ANGLE))throw new TypeError("Unit in function cot is no angle");return t.find(e,r.valueType())(r.value)}))}})),hf=de("cos",["typed"],(e=>{let{typed:t}=e;const r=df({typed:t});return t("cos",{number:Math.cos,"Complex | BigNumber":e=>e.cos()},r)})),gf="cosh",yf=de(gf,["typed"],(e=>{let{typed:t}=e;return t(gf,{number:qe,"Complex | BigNumber":e=>e.cosh()})})),xf=de("cot",["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t("cot",{number:Rl,Complex:e=>e.cot(),BigNumber:e=>new r(1).div(e.tan())},df({typed:t}))})),bf="coth",vf=de(bf,["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t(bf,{number:Pl,Complex:e=>e.coth(),BigNumber:e=>new r(1).div(e.tanh())})})),wf=de("csc",["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t("csc",{number:jl,Complex:e=>e.csc(),BigNumber:e=>new r(1).div(e.sin())},df({typed:t}))})),Nf="csch",Ef=de(Nf,["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t(Nf,{number:Ul,Complex:e=>e.csch(),BigNumber:e=>new r(1).div(e.sinh())})})),Af=de("sec",["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t("sec",{number:Ll,Complex:e=>e.sec(),BigNumber:e=>new r(1).div(e.cos())},df({typed:t}))})),Sf="sech",Mf=de(Sf,["typed","BigNumber"],(e=>{let{typed:t,BigNumber:r}=e;return t(Sf,{number:$l,Complex:e=>e.sech(),BigNumber:e=>new r(1).div(e.cosh())})})),Cf=de("sin",["typed"],(e=>{let{typed:t}=e;const r=df({typed:t});return t("sin",{number:Math.sin,"Complex | BigNumber":e=>e.sin()},r)})),Tf="sinh",Df=de(Tf,["typed"],(e=>{let{typed:t}=e;return t(Tf,{number:Hl,"Complex | BigNumber":e=>e.sinh()})})),Ff=de("tan",["typed"],(e=>{let{typed:t}=e;const r=df({typed:t});return t("tan",{number:Math.tan,"Complex | BigNumber":e=>e.tan()},r)})),Of=de("tanh",["typed"],(e=>{let{typed:t}=e;return t("tanh",{number:Pe,"Complex | BigNumber":e=>e.tanh()})})),Bf="setCartesian",_f=de(Bf,["typed","size","subset","compareNatural","Index","DenseMatrix"],(e=>{let{typed:t,size:r,subset:n,compareNatural:i,Index:o,DenseMatrix:a}=e;return t(Bf,{"Array | Matrix, Array | Matrix":function(e,t){let s=[];if(0!==n(r(e),new o(0))&&0!==n(r(t),new o(0))){const r=En(Array.isArray(e)?e:e.toArray()).sort(i),n=En(Array.isArray(t)?t:t.toArray()).sort(i);s=[];for(let e=0;e{let{typed:t,size:r,subset:n,compareNatural:i,Index:o,DenseMatrix:a}=e;return t(zf,{"Array | Matrix, Array | Matrix":function(e,t){let s;if(0===n(r(e),new o(0)))s=[];else{if(0===n(r(t),new o(0)))return En(e.toArray());{const r=Tn(En(Array.isArray(e)?e:e.toArray()).sort(i)),n=Tn(En(Array.isArray(t)?t:t.toArray()).sort(i));let o;s=[];for(let e=0;e{let{typed:t,size:r,subset:n,compareNatural:i,Index:o,DenseMatrix:a}=e;return t(kf,{"Array | Matrix":function(e){let t;if(0===n(r(e),new o(0)))t=[];else{const r=En(Array.isArray(e)?e:e.toArray()).sort(i);t=[],t.push(r[0]);for(let e=1;e{let{typed:t,size:r,subset:n,compareNatural:i,Index:o,DenseMatrix:a}=e;return t(Rf,{"Array | Matrix, Array | Matrix":function(e,t){let s;if(0===n(r(e),new o(0))||0===n(r(t),new o(0)))s=[];else{const r=Tn(En(Array.isArray(e)?e:e.toArray()).sort(i)),n=Tn(En(Array.isArray(t)?t:t.toArray()).sort(i));s=[];for(let e=0;e{let{typed:t,size:r,subset:n,compareNatural:i,Index:o}=e;return t(jf,{"Array | Matrix, Array | Matrix":function(e,t){if(0===n(r(e),new o(0)))return!0;if(0===n(r(t),new o(0)))return!1;const a=Tn(En(Array.isArray(e)?e:e.toArray()).sort(i)),s=Tn(En(Array.isArray(t)?t:t.toArray()).sort(i));let u;for(let e=0;e{let{typed:t,size:r,subset:n,compareNatural:i,Index:o}=e;return t(Lf,{"number | BigNumber | Fraction | Complex, Array | Matrix":function(e,t){if(0===n(r(t),new o(0)))return 0;const a=En(Array.isArray(t)?t:t.toArray());let s=0;for(let t=0;t{let{typed:t,size:r,subset:n,compareNatural:i,Index:o}=e;return t(Hf,{"Array | Matrix":function(e){if(0===n(r(e),new o(0)))return[];const t=En(Array.isArray(e)?e:e.toArray()).sort(i),s=[];let u=0;for(;u.toString(2).length<=t.length;)s.push(a(t,u.toString(2).split("").reverse())),u++;return function(e){let t=[];for(let r=e.length-1;r>0;r--)for(let n=0;ne[n+1].length&&(t=e[n],e[n]=e[n+1],e[n+1]=t);return e}(s)}});function a(e,t){const r=[];for(let n=0;n{let{typed:t,compareNatural:r}=e;return t(Zf,{"Array | Matrix":function(e){return Array.isArray(e)?En(e).length:En(e.toArray()).length},"Array | Matrix, boolean":function(e,t){if(!1===t||0===e.length)return Array.isArray(e)?En(e).length:En(e.toArray()).length;{const t=En(Array.isArray(e)?e:e.toArray()).sort(r);let n=1;for(let e=1;e{let{typed:t,size:r,concat:n,subset:i,setDifference:o,Index:a}=e;return t(Wf,{"Array | Matrix, Array | Matrix":function(e,t){if(0===i(r(e),new a(0)))return En(t);if(0===i(r(t),new a(0)))return En(e);const s=En(e),u=En(t);return n(o(s,u),o(u,s))}})})),Jf="setUnion",Xf=de(Jf,["typed","size","concat","subset","setIntersect","setSymDifference","Index"],(e=>{let{typed:t,size:r,concat:n,subset:i,setIntersect:o,setSymDifference:a,Index:s}=e;return t(Jf,{"Array | Matrix, Array | Matrix":function(e,t){if(0===i(r(e),new s(0)))return En(t);if(0===i(r(t),new s(0)))return En(e);const u=En(e),c=En(t);return n(a(u,c),o(u,c))}})})),Qf=de("add",["typed","matrix","addScalar","equalScalar","DenseMatrix","SparseMatrix","concat"],(e=>{let{typed:t,matrix:r,addScalar:n,equalScalar:i,DenseMatrix:o,SparseMatrix:a,concat:s}=e;const u=Yo({typed:t}),c=Jo({typed:t,equalScalar:i}),l=Xo({typed:t,DenseMatrix:o}),f=Vo({typed:t,matrix:r,concat:s});return t("add",{"any, any":n,"any, any, ...any":t.referToSelf((e=>(t,r,n)=>{let i=e(t,r);for(let t=0;t{let{typed:t,abs:r,addScalar:n,divideScalar:i,multiplyScalar:o,sqrt:a,smaller:s,isPositive:u}=e;return t(Kf,{"... number | BigNumber":c,Array:c,Matrix:e=>c(En(e.toArray()))});function c(e){let t=0,c=0;for(let a=0;a{let{typed:t,abs:r,add:n,pow:i,conj:o,sqrt:a,multiply:s,equalScalar:u,larger:c,smaller:l,matrix:f,ctranspose:p,eigs:m}=e;return t(tp,{number:Math.abs,Complex:function(e){return e.abs()},BigNumber:function(e){return e.abs()},boolean:function(e){return Math.abs(e)},Array:function(e){return d(f(e),2)},Matrix:function(e){return d(e,2)},"Array, number | BigNumber | string":function(e,t){return d(f(e),t)},"Matrix, number | BigNumber | string":function(e,t){return d(e,t)}});function d(e,t){const f=e.size();if(1===f.length)return function(e,t){if(t===Number.POSITIVE_INFINITY||"inf"===t)return function(e){let t=0;return e.forEach((function(e){const n=r(e);c(n,t)&&(t=n)}),!0),t}(e);if(t===Number.NEGATIVE_INFINITY||"-inf"===t)return function(e){let t;return e.forEach((function(e){const n=r(e);t&&!l(n,t)||(t=n)}),!0),t||0}(e);if("fro"===t)return d(e,2);if("number"==typeof t&&!isNaN(t)){if(!u(t,0)){let o=0;return e.forEach((function(e){o=n(i(r(e),t),o)}),!0),i(o,1/t)}return Number.POSITIVE_INFINITY}throw new Error("Unsupported parameter value")}(e,t);if(2===f.length){if(f[0]&&f[1])return function(e,t){if(1===t)return function(e){const t=[];let i=0;return e.forEach((function(e,o){const a=o[1],s=n(t[a]||0,r(e));c(s,i)&&(i=s),t[a]=s}),!0),i}(e);if(t===Number.POSITIVE_INFINITY||"inf"===t)return function(e){const t=[];let i=0;return e.forEach((function(e,o){const a=o[0],s=n(t[a]||0,r(e));c(s,i)&&(i=s),t[a]=s}),!0),i}(e);if("fro"===t)return function(e){let t=0;return e.forEach((function(e,r){t=n(t,s(e,o(e)))})),r(a(t))}(e);if(2===t)return function(e){const t=e.size();if(t[0]!==t[1])throw new RangeError("Invalid matrix dimensions");const n=p(e),i=s(n,e),o=m(i).values.toArray(),u=o[o.length-1];return r(a(u))}(e);throw new Error("Unsupported parameter value "+t)}(e,t);throw new RangeError("Invalid matrix dimensions")}}})),np=de("dot",["typed","addScalar","multiplyScalar","conj","size"],(e=>{let{typed:t,addScalar:r,multiplyScalar:n,conj:i,size:o}=e;return t("dot",{"Array | DenseMatrix, Array | DenseMatrix":function(e,o){const u=a(e,o),c=E(e)?e._data:e,l=E(e)?e._datatype||e.getDataType():void 0,f=E(o)?o._data:o,p=E(o)?o._datatype||o.getDataType():void 0,m=2===s(e).length,d=2===s(o).length;let h=r,g=n;if(l&&p&&l===p&&"string"==typeof l&&"mixed"!==l){const e=l;h=t.find(r,[e,e]),g=t.find(n,[e,e])}if(!m&&!d){let e=g(i(c[0]),f[0]);for(let t=1;tt?m++:e===t&&(c=l(c,f(o[p],u[m])),p++,m++)}return c}});function a(e,t){const r=s(e),n=s(t);let i,o;if(1===r.length)i=r[0];else{if(2!==r.length||1!==r[1])throw new RangeError("Expected a column vector, instead got a matrix of size ("+r.join(", ")+")");i=r[0]}if(1===n.length)o=n[0];else{if(2!==n.length||1!==n[1])throw new RangeError("Expected a column vector, instead got a matrix of size ("+n.join(", ")+")");o=n[0]}if(i!==o)throw new RangeError("Vectors must have equal length ("+i+" != "+o+")");if(0===i)throw new RangeError("Cannot calculate the dot product of empty vectors");return i}function s(e){return E(e)?e.size():o(e)}})),ip=de("trace",["typed","matrix","add"],(e=>{let{typed:t,matrix:r,add:n}=e;return t("trace",{Array:function(e){return i(r(e))},SparseMatrix:function(e){const t=e._values,r=e._index,i=e._ptr,o=e._size,a=o[0],s=o[1];if(a===s){let e=0;if(t.length>0)for(let o=0;oo)break}}return e}throw new RangeError("Matrix must be square (size: "+Kr(o)+")")},DenseMatrix:i,any:ae});function i(e){const t=e._size,r=e._data;switch(t.length){case 1:if(1===t[0])return ae(r[0]);throw new RangeError("Matrix must be square (size: "+Kr(t)+")");case 2:{const e=t[0];if(e===t[1]){let t=0;for(let i=0;i{let{typed:t,Index:r}=e;return t(op,{"...number | string | BigNumber | Range | Array | Matrix":function(e){const t=e.map((function(e){return g(e)?e.toNumber():N(e)||E(e)?e.map((function(e){return g(e)?e.toNumber():e})):e})),n=new r;return r.apply(n,t),n}})})),sp=new Set(["end"]),up=de("Node",["mathWithTransform"],(e=>{let{mathWithTransform:t}=e;return class{get type(){return"Node"}get isNode(){return!0}evaluate(e){return this.compile().evaluate(e)}compile(){const e=this._compile(t,{}),r={};return{evaluate:function(t){const n=d(t);return function(e){for(const t of[...sp])if(e.has(t))throw new Error('Scope contains an illegal symbol, "'+t+'" is a reserved keyword')}(n),e(n,r,null)}}}_compile(e,t){throw new Error("Method _compile must be implemented by type "+this.type)}forEach(e){throw new Error("Cannot run forEach on a Node interface")}map(e){throw new Error("Cannot run map on a Node interface")}_ifNode(e){if(!X(e))throw new TypeError("Callback function must return a Node");return e}traverse(e){e(this,null,null),function e(t,r){t.forEach((function(t,n,i){r(t,n,i),e(t,r)}))}(this,e)}transform(e){return function t(r,n,i){const o=e(r,n,i);return o!==r?o:r.map(t)}(this,null,null)}filter(e){const t=[];return this.traverse((function(r,n,i){e(r,n,i)&&t.push(r)})),t}clone(){throw new Error("Cannot clone a Node interface")}cloneDeep(){return this.map((function(e){return e.cloneDeep()}))}equals(e){return!!e&&this.type===e.type&&ce(this,e)}toString(e){const t=this._getCustomString(e);return void 0!==t?t:this._toString(e)}_toString(){throw new Error("_toString not implemented for "+this.type)}toJSON(){throw new Error("Cannot serialize object: toJSON not implemented by "+this.type)}toHTML(e){const t=this._getCustomString(e);return void 0!==t?t:this._toHTML(e)}_toHTML(){throw new Error("_toHTML not implemented for "+this.type)}toTex(e){const t=this._getCustomString(e);return void 0!==t?t:this._toTex(e)}_toTex(e){throw new Error("_toTex not implemented for "+this.type)}_getCustomString(e){if(e&&"object"==typeof e)switch(typeof e.handler){case"object":case"undefined":return;case"function":return e.handler(this,e);default:throw new TypeError("Object or function expected as callback")}}getIdentifier(){return this.type}getContent(){return this}}}),{isClass:!0,isNode:!0});function cp(e){return cp="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},cp(e)}function lp(e,t,r){return(t=function(e){var t=function(e){if("object"!=cp(e)||!e)return e;var t=e[Symbol.toPrimitive];if(void 0!==t){var r=t.call(e,"string");if("object"!=cp(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(e)}(e);return"symbol"==cp(t)?t:t+""}(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function fp(e){return e&&e.isIndexError?new sn(e.index+1,e.min+1,void 0!==e.max?e.max+1:void 0):e}function pp(e){let{subset:t}=e;return function(e,r){try{if(Array.isArray(e))return t(e,r);if(e&&"function"==typeof e.subset)return e.subset(r);if("string"==typeof e)return t(e,r);if("object"==typeof e){if(!r.isObjectProperty())throw new TypeError("Cannot apply a numeric index as object property");return i(e,r.getObjectProperty())}throw new TypeError("Cannot apply index: unsupported type of object")}catch(e){throw fp(e)}}}const mp="AccessorNode",dp=de(mp,["subset","Node"],(e=>{let{subset:t,Node:r}=e;const n=pp({subset:t});function o(e){return!(U(e)||L(e)||Z(e)||Y(e)||Q(e)||ee(e)||ne(e))}class a extends r{constructor(e,t){if(super(),!X(e))throw new TypeError('Node expected for parameter "object"');if(!J(t))throw new TypeError('IndexNode expected for parameter "index"');this.object=e,this.index=t}get name(){return this.index?this.index.isObjectProperty()?this.index.getObjectProperty():"":this.object.name||""}get type(){return mp}get isAccessorNode(){return!0}_compile(e,t){const r=this.object._compile(e,t),o=this.index._compile(e,t);if(this.index.isObjectProperty()){const e=this.index.getObjectProperty();return function(t,n,o){return i(r(t,n,o),e)}}return function(e,t,i){const a=r(e,t,i),s=o(e,t,a);return n(a,s)}}forEach(e){e(this.object,"object",this),e(this.index,"index",this)}map(e){return new a(this._ifNode(e(this.object,"object",this)),this._ifNode(e(this.index,"index",this)))}clone(){return new a(this.object,this.index)}_toString(e){let t=this.object.toString(e);return o(this.object)&&(t="("+t+")"),t+this.index.toString(e)}_toHTML(e){let t=this.object.toHTML(e);return o(this.object)&&(t='('+t+')'),t+this.index.toHTML(e)}_toTex(e){let t=this.object.toTex(e);return o(this.object)&&(t="\\left(' + object + '\\right)"),t+this.index.toTex(e)}toJSON(){return{mathjs:mp,object:this.object,index:this.index}}static fromJSON(e){return new a(e.object,e.index)}}return lp(a,"name",mp),a}),{isClass:!0,isNode:!0}),hp="ArrayNode",gp=de(hp,["Node"],(e=>{let{Node:t}=e;class r extends t{constructor(e){if(super(),this.items=e||[],!Array.isArray(this.items)||!this.items.every(X))throw new TypeError("Array containing Nodes expected")}get type(){return hp}get isArrayNode(){return!0}_compile(e,t){const r=An(this.items,(function(r){return r._compile(e,t)}));if("Array"!==e.config.matrix){const t=e.matrix;return function(e,n,i){return t(An(r,(function(t){return t(e,n,i)})))}}return function(e,t,n){return An(r,(function(r){return r(e,t,n)}))}}forEach(e){for(let t=0;t['+this.items.map((function(t){return t.toHTML(e)})).join(',')+']'}_toTex(e){return function t(r,n){const i=r.some(L)&&!r.every(L),o=n||i,a=o?"&":"\\\\",s=r.map((function(r){return r.items?t(r.items,!n):r.toTex(e)})).join(a);return i||!o||o&&!n?"\\begin{bmatrix}"+s+"\\end{bmatrix}":s}(this.items,!1)}}return lp(r,"name",hp),r}),{isClass:!0,isNode:!0}),yp=[{AssignmentNode:{},FunctionAssignmentNode:{}},{ConditionalNode:{latexLeftParens:!1,latexRightParens:!1,latexParens:!1}},{"OperatorNode:or":{op:"or",associativity:"left",associativeWith:[]}},{"OperatorNode:xor":{op:"xor",associativity:"left",associativeWith:[]}},{"OperatorNode:and":{op:"and",associativity:"left",associativeWith:[]}},{"OperatorNode:bitOr":{op:"|",associativity:"left",associativeWith:[]}},{"OperatorNode:bitXor":{op:"^|",associativity:"left",associativeWith:[]}},{"OperatorNode:bitAnd":{op:"&",associativity:"left",associativeWith:[]}},{"OperatorNode:equal":{op:"==",associativity:"left",associativeWith:[]},"OperatorNode:unequal":{op:"!=",associativity:"left",associativeWith:[]},"OperatorNode:smaller":{op:"<",associativity:"left",associativeWith:[]},"OperatorNode:larger":{op:">",associativity:"left",associativeWith:[]},"OperatorNode:smallerEq":{op:"<=",associativity:"left",associativeWith:[]},"OperatorNode:largerEq":{op:">=",associativity:"left",associativeWith:[]},RelationalNode:{associativity:"left",associativeWith:[]}},{"OperatorNode:leftShift":{op:"<<",associativity:"left",associativeWith:[]},"OperatorNode:rightArithShift":{op:">>",associativity:"left",associativeWith:[]},"OperatorNode:rightLogShift":{op:">>>",associativity:"left",associativeWith:[]}},{"OperatorNode:to":{op:"to",associativity:"left",associativeWith:[]}},{RangeNode:{}},{"OperatorNode:add":{op:"+",associativity:"left",associativeWith:["OperatorNode:add","OperatorNode:subtract"]},"OperatorNode:subtract":{op:"-",associativity:"left",associativeWith:[]}},{"OperatorNode:multiply":{op:"*",associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","Operator:dotMultiply","Operator:dotDivide"]},"OperatorNode:divide":{op:"/",associativity:"left",associativeWith:[],latexLeftParens:!1,latexRightParens:!1,latexParens:!1},"OperatorNode:dotMultiply":{op:".*",associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","OperatorNode:dotMultiply","OperatorNode:doDivide"]},"OperatorNode:dotDivide":{op:"./",associativity:"left",associativeWith:[]},"OperatorNode:mod":{op:"mod",associativity:"left",associativeWith:[]}},{"OperatorNode:multiply":{associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","Operator:dotMultiply","Operator:dotDivide"]}},{"OperatorNode:unaryPlus":{op:"+",associativity:"right"},"OperatorNode:unaryMinus":{op:"-",associativity:"right"},"OperatorNode:bitNot":{op:"~",associativity:"right"},"OperatorNode:not":{op:"not",associativity:"right"}},{"OperatorNode:pow":{op:"^",associativity:"right",associativeWith:[],latexRightParens:!1},"OperatorNode:dotPow":{op:".^",associativity:"right",associativeWith:[]}},{"OperatorNode:factorial":{op:"!",associativity:"left"}},{"OperatorNode:ctranspose":{op:"'",associativity:"left"}}];function xp(e,t){if(!t||"auto"!==t)return e;let r=e;for(;ee(r);)r=r.content;return r}function bp(e,t,r,n){let i=e;"keep"!==t&&(i=e.getContent());const o=i.getIdentifier();let a=null;for(let e=0;e{let{subset:t,matrix:r,Node:n}=e;const a=pp({subset:t}),s=function(e){let{subset:t,matrix:r}=e;return function(e,n,i){try{if(Array.isArray(e))return r(e).subset(n,i).valueOf().forEach(((t,r)=>{e[r]=t})),e;if(e&&"function"==typeof e.subset)return e.subset(n,i);if("string"==typeof e)return t(e,n,i);if("object"==typeof e){if(!n.isObjectProperty())throw TypeError("Cannot apply a numeric index as object property");return o(e,n.getObjectProperty(),i),e}throw new TypeError("Cannot apply index: unsupported type of object")}catch(e){throw fp(e)}}}({subset:t,matrix:r});function u(e,t,r){t||(t="keep");const n=bp(e,t,r),i=bp(e.value,t,r);return"all"===t||null!==i&&i<=n}class c extends n{constructor(e,t,r){if(super(),this.object=e,this.index=r?t:null,this.value=r||t,!ne(e)&&!U(e))throw new TypeError('SymbolNode or AccessorNode expected as "object"');if(ne(e)&&"end"===e.name)throw new Error('Cannot assign to symbol "end"');if(this.index&&!J(this.index))throw new TypeError('IndexNode expected as "index"');if(!X(this.value))throw new TypeError('Node expected as "value"')}get name(){return this.index?this.index.isObjectProperty()?this.index.getObjectProperty():"":this.object.name||""}get type(){return Np}get isAssignmentNode(){return!0}_compile(e,t){const r=this.object._compile(e,t),n=this.index?this.index._compile(e,t):null,u=this.value._compile(e,t),c=this.object.name;if(this.index){if(this.index.isObjectProperty()){const e=this.index.getObjectProperty();return function(t,n,i){const a=r(t,n,i),s=u(t,n,i);return o(a,e,s),s}}if(ne(this.object))return function(e,t,i){const o=r(e,t,i),a=u(e,t,i),l=n(e,t,o);return e.set(c,s(o,l,a)),a};{const r=this.object.object._compile(e,t);if(this.object.index.isObjectProperty()){const e=this.object.index.getObjectProperty();return function(t,a,c){const l=r(t,a,c),f=i(l,e),p=n(t,a,f),m=u(t,a,c);return o(l,e,s(f,p,m)),m}}{const i=this.object.index._compile(e,t);return function(e,t,o){const c=r(e,t,o),l=i(e,t,c),f=a(c,l),p=n(e,t,f),m=u(e,t,o);return s(c,l,s(f,p,m)),m}}}}if(!ne(this.object))throw new TypeError("SymbolNode expected as object");return function(e,t,r){const n=u(e,t,r);return e.set(c,n),n}}forEach(e){e(this.object,"object",this),this.index&&e(this.index,"index",this),e(this.value,"value",this)}map(e){const t=this._ifNode(e(this.object,"object",this)),r=this.index?this._ifNode(e(this.index,"index",this)):null,n=this._ifNode(e(this.value,"value",this));return new c(t,r,n)}clone(){return new c(this.object,this.index,this.value)}_toString(e){const t=this.object.toString(e),r=this.index?this.index.toString(e):"";let n=this.value.toString(e);return u(this,e&&e.parenthesis,e&&e.implicit)&&(n="("+n+")"),t+r+" = "+n}toJSON(){return{mathjs:Np,object:this.object,index:this.index,value:this.value}}static fromJSON(e){return new c(e.object,e.index,e.value)}_toHTML(e){const t=this.object.toHTML(e),r=this.index?this.index.toHTML(e):"";let n=this.value.toHTML(e);return u(this,e&&e.parenthesis,e&&e.implicit)&&(n='('+n+')'),t+r+'='+n}_toTex(e){const t=this.object.toTex(e),r=this.index?this.index.toTex(e):"";let n=this.value.toTex(e);return u(this,e&&e.parenthesis,e&&e.implicit)&&(n=`\\left(${n}\\right)`),t+r+"="+n}}return lp(c,"name",Np),c}),{isClass:!0,isNode:!0}),Ap="BlockNode",Sp=de(Ap,["ResultSet","Node"],(e=>{let{ResultSet:t,Node:r}=e;class n extends r{constructor(e){if(super(),!Array.isArray(e))throw new Error("Array expected");this.blocks=e.map((function(e){const t=e&&e.node,r=!e||void 0===e.visible||e.visible;if(!X(t))throw new TypeError('Property "node" must be a Node');if("boolean"!=typeof r)throw new TypeError('Property "visible" must be a boolean');return{node:t,visible:r}}))}get type(){return Ap}get isBlockNode(){return!0}_compile(e,r){const n=An(this.blocks,(function(t){return{evaluate:t.node._compile(e,r),visible:t.visible}}));return function(e,r,i){const o=[];return Sn(n,(function(t){const n=t.evaluate(e,r,i);t.visible&&o.push(n)})),new t(o)}}forEach(e){for(let t=0;t;')})).join('
    ')}_toTex(e){return this.blocks.map((function(t){return t.node.toTex(e)+(t.visible?"":";")})).join("\\;\\;\n")}}return lp(n,"name",Ap),n}),{isClass:!0,isNode:!0}),Mp="ConditionalNode",Cp=de(Mp,["Node"],(e=>{let{Node:t}=e;class r extends t{constructor(e,t,r){if(super(),!X(e))throw new TypeError("Parameter condition must be a Node");if(!X(t))throw new TypeError("Parameter trueExpr must be a Node");if(!X(r))throw new TypeError("Parameter falseExpr must be a Node");this.condition=e,this.trueExpr=t,this.falseExpr=r}get type(){return Mp}get isConditionalNode(){return!0}_compile(e,t){const r=this.condition._compile(e,t),n=this.trueExpr._compile(e,t),i=this.falseExpr._compile(e,t);return function(e,t,o){return function(e){if("number"==typeof e||"boolean"==typeof e||"string"==typeof e)return!!e;if(e){if(g(e))return!e.isZero();if(x(e))return!(!e.re&&!e.im);if(v(e))return!!e.value}if(null==e)return!1;throw new TypeError('Unsupported type of condition "'+oe(e)+'"')}(r(e,t,o))?n(e,t,o):i(e,t,o)}}forEach(e){e(this.condition,"condition",this),e(this.trueExpr,"trueExpr",this),e(this.falseExpr,"falseExpr",this)}map(e){return new r(this._ifNode(e(this.condition,"condition",this)),this._ifNode(e(this.trueExpr,"trueExpr",this)),this._ifNode(e(this.falseExpr,"falseExpr",this)))}clone(){return new r(this.condition,this.trueExpr,this.falseExpr)}_toString(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=bp(this,t,e&&e.implicit);let n=this.condition.toString(e);const i=bp(this.condition,t,e&&e.implicit);("all"===t||"OperatorNode"===this.condition.type||null!==i&&i<=r)&&(n="("+n+")");let o=this.trueExpr.toString(e);const a=bp(this.trueExpr,t,e&&e.implicit);("all"===t||"OperatorNode"===this.trueExpr.type||null!==a&&a<=r)&&(o="("+o+")");let s=this.falseExpr.toString(e);const u=bp(this.falseExpr,t,e&&e.implicit);return("all"===t||"OperatorNode"===this.falseExpr.type||null!==u&&u<=r)&&(s="("+s+")"),n+" ? "+o+" : "+s}toJSON(){return{mathjs:Mp,condition:this.condition,trueExpr:this.trueExpr,falseExpr:this.falseExpr}}static fromJSON(e){return new r(e.condition,e.trueExpr,e.falseExpr)}_toHTML(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=bp(this,t,e&&e.implicit);let n=this.condition.toHTML(e);const i=bp(this.condition,t,e&&e.implicit);("all"===t||"OperatorNode"===this.condition.type||null!==i&&i<=r)&&(n='('+n+')');let o=this.trueExpr.toHTML(e);const a=bp(this.trueExpr,t,e&&e.implicit);("all"===t||"OperatorNode"===this.trueExpr.type||null!==a&&a<=r)&&(o='('+o+')');let s=this.falseExpr.toHTML(e);const u=bp(this.falseExpr,t,e&&e.implicit);return("all"===t||"OperatorNode"===this.falseExpr.type||null!==u&&u<=r)&&(s='('+s+')'),n+'?'+o+':'+s}_toTex(e){return"\\begin{cases} {"+this.trueExpr.toTex(e)+"}, &\\quad{\\text{if }\\;"+this.condition.toTex(e)+"}\\\\{"+this.falseExpr.toTex(e)+"}, &\\quad{\\text{otherwise}}\\end{cases}"}}return lp(r,"name",Mp),r}),{isClass:!0,isNode:!0});var Tp=r(3144);const Dp={Alpha:"A",alpha:"\\alpha",Beta:"B",beta:"\\beta",Gamma:"\\Gamma",gamma:"\\gamma",Delta:"\\Delta",delta:"\\delta",Epsilon:"E",epsilon:"\\epsilon",varepsilon:"\\varepsilon",Zeta:"Z",zeta:"\\zeta",Eta:"H",eta:"\\eta",Theta:"\\Theta",theta:"\\theta",vartheta:"\\vartheta",Iota:"I",iota:"\\iota",Kappa:"K",kappa:"\\kappa",varkappa:"\\varkappa",Lambda:"\\Lambda",lambda:"\\lambda",Mu:"M",mu:"\\mu",Nu:"N",nu:"\\nu",Xi:"\\Xi",xi:"\\xi",Omicron:"O",omicron:"o",Pi:"\\Pi",pi:"\\pi",varpi:"\\varpi",Rho:"P",rho:"\\rho",varrho:"\\varrho",Sigma:"\\Sigma",sigma:"\\sigma",varsigma:"\\varsigma",Tau:"T",tau:"\\tau",Upsilon:"\\Upsilon",upsilon:"\\upsilon",Phi:"\\Phi",phi:"\\phi",varphi:"\\varphi",Chi:"X",chi:"\\chi",Psi:"\\Psi",psi:"\\psi",Omega:"\\Omega",omega:"\\omega",true:"\\mathrm{True}",false:"\\mathrm{False}",i:"i",inf:"\\infty",Inf:"\\infty",infinity:"\\infty",Infinity:"\\infty",oo:"\\infty",lim:"\\lim",undefined:"\\mathbf{?}"},Fp={transpose:"^\\top",ctranspose:"^H",factorial:"!",pow:"^",dotPow:".^\\wedge",unaryPlus:"+",unaryMinus:"-",bitNot:"\\~",not:"\\neg",multiply:"\\cdot",divide:"\\frac",dotMultiply:".\\cdot",dotDivide:".:",mod:"\\mod",add:"+",subtract:"-",to:"\\rightarrow",leftShift:"<<",rightArithShift:">>",rightLogShift:">>>",equal:"=",unequal:"\\neq",smaller:"<",larger:">",smallerEq:"\\leq",largerEq:"\\geq",bitAnd:"\\&",bitXor:"\\underline{|}",bitOr:"|",and:"\\wedge",xor:"\\veebar",or:"\\vee"},Op={abs:{1:"\\left|${args[0]}\\right|"},add:{2:`\\left(\${args[0]}${Fp.add}\${args[1]}\\right)`},cbrt:{1:"\\sqrt[3]{${args[0]}}"},ceil:{1:"\\left\\lceil${args[0]}\\right\\rceil"},cube:{1:"\\left(${args[0]}\\right)^3"},divide:{2:"\\frac{${args[0]}}{${args[1]}}"},dotDivide:{2:`\\left(\${args[0]}${Fp.dotDivide}\${args[1]}\\right)`},dotMultiply:{2:`\\left(\${args[0]}${Fp.dotMultiply}\${args[1]}\\right)`},dotPow:{2:`\\left(\${args[0]}${Fp.dotPow}\${args[1]}\\right)`},exp:{1:"\\exp\\left(${args[0]}\\right)"},expm1:`\\left(e${Fp.pow}{\${args[0]}}-1\\right)`,fix:{1:"\\mathrm{${name}}\\left(${args[0]}\\right)"},floor:{1:"\\left\\lfloor${args[0]}\\right\\rfloor"},gcd:"\\gcd\\left(${args}\\right)",hypot:"\\hypot\\left(${args}\\right)",log:{1:"\\ln\\left(${args[0]}\\right)",2:"\\log_{${args[1]}}\\left(${args[0]}\\right)"},log10:{1:"\\log_{10}\\left(${args[0]}\\right)"},log1p:{1:"\\ln\\left(${args[0]}+1\\right)",2:"\\log_{${args[1]}}\\left(${args[0]}+1\\right)"},log2:"\\log_{2}\\left(${args[0]}\\right)",mod:{2:`\\left(\${args[0]}${Fp.mod}\${args[1]}\\right)`},multiply:{2:`\\left(\${args[0]}${Fp.multiply}\${args[1]}\\right)`},norm:{1:"\\left\\|${args[0]}\\right\\|",2:void 0},nthRoot:{2:"\\sqrt[${args[1]}]{${args[0]}}"},nthRoots:{2:"\\{y : $y^{args[1]} = {${args[0]}}\\}"},pow:{2:`\\left(\${args[0]}\\right)${Fp.pow}{\${args[1]}}`},round:{1:"\\left\\lfloor${args[0]}\\right\\rceil",2:void 0},sign:{1:"\\mathrm{${name}}\\left(${args[0]}\\right)"},sqrt:{1:"\\sqrt{${args[0]}}"},square:{1:"\\left(${args[0]}\\right)^2"},subtract:{2:`\\left(\${args[0]}${Fp.subtract}\${args[1]}\\right)`},unaryMinus:{1:`${Fp.unaryMinus}\\left(\${args[0]}\\right)`},unaryPlus:{1:`${Fp.unaryPlus}\\left(\${args[0]}\\right)`},bitAnd:{2:`\\left(\${args[0]}${Fp.bitAnd}\${args[1]}\\right)`},bitNot:{1:Fp.bitNot+"\\left(${args[0]}\\right)"},bitOr:{2:`\\left(\${args[0]}${Fp.bitOr}\${args[1]}\\right)`},bitXor:{2:`\\left(\${args[0]}${Fp.bitXor}\${args[1]}\\right)`},leftShift:{2:`\\left(\${args[0]}${Fp.leftShift}\${args[1]}\\right)`},rightArithShift:{2:`\\left(\${args[0]}${Fp.rightArithShift}\${args[1]}\\right)`},rightLogShift:{2:`\\left(\${args[0]}${Fp.rightLogShift}\${args[1]}\\right)`},bellNumbers:{1:"\\mathrm{B}_{${args[0]}}"},catalan:{1:"\\mathrm{C}_{${args[0]}}"},stirlingS2:{2:"\\mathrm{S}\\left(${args}\\right)"},arg:{1:"\\arg\\left(${args[0]}\\right)"},conj:{1:"\\left(${args[0]}\\right)^*"},im:{1:"\\Im\\left\\lbrace${args[0]}\\right\\rbrace"},re:{1:"\\Re\\left\\lbrace${args[0]}\\right\\rbrace"},and:{2:`\\left(\${args[0]}${Fp.and}\${args[1]}\\right)`},not:{1:Fp.not+"\\left(${args[0]}\\right)"},or:{2:`\\left(\${args[0]}${Fp.or}\${args[1]}\\right)`},xor:{2:`\\left(\${args[0]}${Fp.xor}\${args[1]}\\right)`},cross:{2:"\\left(${args[0]}\\right)\\times\\left(${args[1]}\\right)"},ctranspose:{1:`\\left(\${args[0]}\\right)${Fp.ctranspose}`},det:{1:"\\det\\left(${args[0]}\\right)"},dot:{2:"\\left(${args[0]}\\cdot${args[1]}\\right)"},expm:{1:"\\exp\\left(${args[0]}\\right)"},inv:{1:"\\left(${args[0]}\\right)^{-1}"},pinv:{1:"\\left(${args[0]}\\right)^{+}"},sqrtm:{1:`{\${args[0]}}${Fp.pow}{\\frac{1}{2}}`},trace:{1:"\\mathrm{tr}\\left(${args[0]}\\right)"},transpose:{1:`\\left(\${args[0]}\\right)${Fp.transpose}`},combinations:{2:"\\binom{${args[0]}}{${args[1]}}"},combinationsWithRep:{2:"\\left(\\!\\!{\\binom{${args[0]}}{${args[1]}}}\\!\\!\\right)"},factorial:{1:`\\left(\${args[0]}\\right)${Fp.factorial}`},gamma:{1:"\\Gamma\\left(${args[0]}\\right)"},lgamma:{1:"\\ln\\Gamma\\left(${args[0]}\\right)"},equal:{2:`\\left(\${args[0]}${Fp.equal}\${args[1]}\\right)`},larger:{2:`\\left(\${args[0]}${Fp.larger}\${args[1]}\\right)`},largerEq:{2:`\\left(\${args[0]}${Fp.largerEq}\${args[1]}\\right)`},smaller:{2:`\\left(\${args[0]}${Fp.smaller}\${args[1]}\\right)`},smallerEq:{2:`\\left(\${args[0]}${Fp.smallerEq}\${args[1]}\\right)`},unequal:{2:`\\left(\${args[0]}${Fp.unequal}\${args[1]}\\right)`},erf:{1:"erf\\left(${args[0]}\\right)"},max:"\\max\\left(${args}\\right)",min:"\\min\\left(${args}\\right)",variance:"\\mathrm{Var}\\left(${args}\\right)",acos:{1:"\\cos^{-1}\\left(${args[0]}\\right)"},acosh:{1:"\\cosh^{-1}\\left(${args[0]}\\right)"},acot:{1:"\\cot^{-1}\\left(${args[0]}\\right)"},acoth:{1:"\\coth^{-1}\\left(${args[0]}\\right)"},acsc:{1:"\\csc^{-1}\\left(${args[0]}\\right)"},acsch:{1:"\\mathrm{csch}^{-1}\\left(${args[0]}\\right)"},asec:{1:"\\sec^{-1}\\left(${args[0]}\\right)"},asech:{1:"\\mathrm{sech}^{-1}\\left(${args[0]}\\right)"},asin:{1:"\\sin^{-1}\\left(${args[0]}\\right)"},asinh:{1:"\\sinh^{-1}\\left(${args[0]}\\right)"},atan:{1:"\\tan^{-1}\\left(${args[0]}\\right)"},atan2:{2:"\\mathrm{atan2}\\left(${args}\\right)"},atanh:{1:"\\tanh^{-1}\\left(${args[0]}\\right)"},cos:{1:"\\cos\\left(${args[0]}\\right)"},cosh:{1:"\\cosh\\left(${args[0]}\\right)"},cot:{1:"\\cot\\left(${args[0]}\\right)"},coth:{1:"\\coth\\left(${args[0]}\\right)"},csc:{1:"\\csc\\left(${args[0]}\\right)"},csch:{1:"\\mathrm{csch}\\left(${args[0]}\\right)"},sec:{1:"\\sec\\left(${args[0]}\\right)"},sech:{1:"\\mathrm{sech}\\left(${args[0]}\\right)"},sin:{1:"\\sin\\left(${args[0]}\\right)"},sinh:{1:"\\sinh\\left(${args[0]}\\right)"},tan:{1:"\\tan\\left(${args[0]}\\right)"},tanh:{1:"\\tanh\\left(${args[0]}\\right)"},to:{2:`\\left(\${args[0]}${Fp.to}\${args[1]}\\right)`},numeric:function(e,t){return e.args[0].toTex()},number:{0:"0",1:"\\left(${args[0]}\\right)",2:"\\left(\\left(${args[0]}\\right)${args[1]}\\right)"},string:{0:'\\mathtt{""}',1:"\\mathrm{string}\\left(${args[0]}\\right)"},bignumber:{0:"0",1:"\\left(${args[0]}\\right)"},bigint:{0:"0",1:"\\left(${args[0]}\\right)"},complex:{0:"0",1:"\\left(${args[0]}\\right)",2:`\\left(\\left(\${args[0]}\\right)+${Dp.i}\\cdot\\left(\${args[1]}\\right)\\right)`},matrix:{0:"\\begin{bmatrix}\\end{bmatrix}",1:"\\left(${args[0]}\\right)",2:"\\left(${args[0]}\\right)"},sparse:{0:"\\begin{bsparse}\\end{bsparse}",1:"\\left(${args[0]}\\right)"},unit:{1:"\\left(${args[0]}\\right)",2:"\\left(\\left(${args[0]}\\right)${args[1]}\\right)"}},Bp={deg:"^\\circ"};function _p(e){return Tp(e,{preserveFormatting:!0})}function zp(e,t){return(t=void 0!==t&&t)?me(Bp,e)?Bp[e]:"\\mathrm{"+_p(e)+"}":me(Dp,e)?Dp[e]:_p(e)}const Ip="ConstantNode",kp=de(Ip,["Node"],(e=>{let{Node:t}=e;class r extends t{constructor(e){super(),this.value=e}get type(){return Ip}get isConstantNode(){return!0}_compile(e,t){const r=this.value;return function(){return r}}forEach(e){}map(e){return this.clone()}clone(){return new r(this.value)}_toString(e){return Kr(this.value,e)}_toHTML(e){const t=this._toString(e);switch(oe(this.value)){case"number":case"bigint":case"BigNumber":case"Fraction":return''+t+"";case"string":return''+t+"";case"boolean":return''+t+"";case"null":return''+t+"";case"undefined":return''+t+"";default:return''+t+""}}toJSON(){return{mathjs:Ip,value:this.value}}static fromJSON(e){return new r(e.value)}_toTex(e){const t=this._toString(e),r=oe(this.value);switch(r){case"string":return"\\mathtt{"+_p(t)+"}";case"number":case"BigNumber":{if(!("BigNumber"===r?this.value.isFinite():isFinite(this.value)))return this.value.valueOf()<0?"-\\infty":"\\infty";const e=t.toLowerCase().indexOf("e");return-1!==e?t.substring(0,e)+"\\cdot10^{"+t.substring(e+1)+"}":t}case"bigint":return t.toString();case"Fraction":return this.value.toLatex();default:return t}}}return lp(r,"name",Ip),r}),{isClass:!0,isNode:!0}),qp="FunctionAssignmentNode",Rp=de(qp,["typed","Node"],(e=>{let{typed:t,Node:r}=e;function n(e,t,r){const n=bp(e,t,r),i=bp(e.expr,t,r);return"all"===t||null!==i&&i<=n}class i extends r{constructor(e,t,r){if(super(),"string"!=typeof e)throw new TypeError('String expected for parameter "name"');if(!Array.isArray(t))throw new TypeError('Array containing strings or objects expected for parameter "params"');if(!X(r))throw new TypeError('Node expected for parameter "expr"');if(sp.has(e))throw new Error('Illegal function name, "'+e+'" is a reserved keyword');const n=new Set;for(const e of t){const t="string"==typeof e?e:e.name;if(n.has(t))throw new Error(`Duplicate parameter name "${t}"`);n.add(t)}this.name=e,this.params=t.map((function(e){return e&&e.name||e})),this.types=t.map((function(e){return e&&e.type||"any"})),this.expr=r}get type(){return qp}get isFunctionAssignmentNode(){return!0}_compile(e,r){const n=Object.create(r);Sn(this.params,(function(e){n[e]=!0}));const i=this.expr._compile(e,n),o=this.name,a=this.params,s=Cn(this.types,","),u=o+"("+Cn(this.params,", ")+")";return function(e,r,n){const c={};c[s]=function(){const t=Object.create(r);for(let e=0;e'+rn(this.params[e])+"");let i=this.expr.toHTML(e);return n(this,t,e&&e.implicit)&&(i='('+i+')'),''+rn(this.name)+'('+r.join(',')+')='+i}_toTex(e){const t=e&&e.parenthesis?e.parenthesis:"keep";let r=this.expr.toTex(e);return n(this,t,e&&e.implicit)&&(r=`\\left(${r}\\right)`),"\\mathrm{"+this.name+"}\\left("+this.params.map(zp).join(",")+"\\right)="+r}}return lp(i,"name",qp),i}),{isClass:!0,isNode:!0}),Pp="IndexNode",jp=de(Pp,["Node","size"],(e=>{let{Node:t,size:r}=e;class n extends t{constructor(e,t){if(super(),this.dimensions=e,this.dotNotation=t||!1,!Array.isArray(e)||!e.every(X))throw new TypeError('Array containing Nodes expected for parameter "dimensions"');if(this.dotNotation&&!this.isObjectProperty())throw new Error("dotNotation only applicable for object properties")}get type(){return Pp}get isIndexNode(){return!0}_compile(e,t){const n=An(this.dimensions,(function(n,i){if(n.filter((e=>e.isSymbolNode&&"end"===e.name)).length>0){const o=Object.create(t);o.end=!0;const a=n._compile(e,o);return function(e,t,n){if(!E(n)&&!N(n)&&!w(n))throw new TypeError('Cannot resolve "end": context must be a Matrix, Array, or string but is '+oe(n));const o=r(n).valueOf(),s=Object.create(t);return s.end=o[i],a(e,s,n)}}return n._compile(e,t)})),o=i(e,"index");return function(e,t,r){const i=An(n,(function(n){return n(e,t,r)}));return o(...i)}}forEach(e){for(let t=0;t.'+rn(this.getObjectProperty())+"":'['+t.join(',')+']'}_toTex(e){const t=this.dimensions.map((function(t){return t.toTex(e)}));return this.dotNotation?"."+this.getObjectProperty():"_{"+t.join(",")+"}"}}return lp(n,"name",Pp),n}),{isClass:!0,isNode:!0}),Up="ObjectNode",Lp=de(Up,["Node"],(e=>{let{Node:t}=e;class r extends t{constructor(e){if(super(),this.properties=e||{},e&&("object"!=typeof e||!Object.keys(e).every((function(t){return X(e[t])}))))throw new TypeError("Object containing Nodes expected")}get type(){return Up}get isObjectNode(){return!0}_compile(e,t){const r={};for(const n in this.properties)if(me(this.properties,n)){const o=en(n),a=JSON.parse(o),s=i(this.properties,n);r[a]=s._compile(e,t)}return function(e,t,n){const i={};for(const o in r)me(r,o)&&(i[o]=r[o](e,t,n));return i}}forEach(e){for(const t in this.properties)me(this.properties,t)&&e(this.properties[t],"properties["+en(t)+"]",this)}map(e){const t={};for(const r in this.properties)me(this.properties,r)&&(t[r]=this._ifNode(e(this.properties[r],"properties["+en(r)+"]",this)));return new r(t)}clone(){const e={};for(const t in this.properties)me(this.properties,t)&&(e[t]=this.properties[t]);return new r(e)}_toString(e){const t=[];for(const r in this.properties)me(this.properties,r)&&t.push(en(r)+": "+this.properties[r].toString(e));return"{"+t.join(", ")+"}"}toJSON(){return{mathjs:Up,properties:this.properties}}static fromJSON(e){return new r(e.properties)}_toHTML(e){const t=[];for(const r in this.properties)me(this.properties,r)&&t.push(''+rn(r)+':'+this.properties[r].toHTML(e));return'{'+t.join(',')+'}'}_toTex(e){const t=[];for(const r in this.properties)me(this.properties,r)&&t.push("\\mathbf{"+r+":} & "+this.properties[r].toTex(e)+"\\\\");return"\\left\\{\\begin{array}{ll}"+t.join("\n")+"\\end{array}\\right\\}"}}return lp(r,"name",Up),r}),{isClass:!0,isNode:!0});function $p(e,t){return new f(e,new l(t),new Set(Object.keys(t)))}const Hp="OperatorNode",Gp=de(Hp,["Node"],(e=>{let{Node:t}=e;function r(e,t){let n=e;if("auto"===t)for(;ee(n);)n=n.content;return!!Z(n)||!!K(n)&&r(n.args[0],t)}function n(e,t,n,i,o){const a=bp(e,t,n),s=vp(e,t);if("all"===t||i.length>2&&"OperatorNode:add"!==e.getIdentifier()&&"OperatorNode:multiply"!==e.getIdentifier())return i.map((function(e){switch(e.getContent().type){case"ArrayNode":case"ConstantNode":case"SymbolNode":case"ParenthesisNode":return!1;default:return!0}}));let u;switch(i.length){case 0:u=[];break;case 1:{const r=bp(i[0],t,n,e);if(o&&null!==r){let n,o;if("keep"===t?(n=i[0].getIdentifier(),o=e.getIdentifier()):(n=i[0].getContent().getIdentifier(),o=e.getContent().getIdentifier()),!1===yp[a][o].latexLeftParens){u=[!1];break}if(!1===yp[r][n].latexParens){u=[!1];break}}if(null===r){u=[!1];break}if(r<=a){u=[!0];break}u=[!1]}break;case 2:{let r;const c=bp(i[0],t,n,e),l=wp(e,i[0],t);let f;r=null!==c&&(c===a&&"right"===s&&!l||c=2&&"OperatorNode:multiply"===e.getIdentifier()&&e.implicit&&"all"!==t&&"hide"===n)for(let e=1;e2&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())){const t=i.map((function(t,r){return t=t.toString(e),o[r]&&(t="("+t+")"),t}));return this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===r?t.join(" "):t.join(" "+this.op+" ")}return this.fn+"("+this.args.join(", ")+")"}toJSON(){return{mathjs:Hp,op:this.op,fn:this.fn,args:this.args,implicit:this.implicit,isPercentage:this.isPercentage}}static fromJSON(e){return new o(e.op,e.fn,e.args,e.implicit,e.isPercentage)}_toHTML(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=e&&e.implicit?e.implicit:"hide",i=this.args,o=n(this,t,r,i,!1);if(1===i.length){const r=vp(this,t);let n=i[0].toHTML(e);return o[0]&&(n='('+n+')'),"right"===r?''+rn(this.op)+""+n:n+''+rn(this.op)+""}if(2===i.length){let t=i[0].toHTML(e),n=i[1].toHTML(e);return o[0]&&(t='('+t+')'),o[1]&&(n='('+n+')'),this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===r?t+''+n:t+''+rn(this.op)+""+n}{const t=i.map((function(t,r){return t=t.toHTML(e),o[r]&&(t='('+t+')'),t}));return i.length>2&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())?this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===r?t.join(''):t.join(''+rn(this.op)+""):''+rn(this.fn)+'('+t.join(',')+')'}}_toTex(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=e&&e.implicit?e.implicit:"hide",i=this.args,o=n(this,t,r,i,!0);let a=Fp[this.fn];if(a=void 0===a?this.op:a,1===i.length){const r=vp(this,t);let n=i[0].toTex(e);return o[0]&&(n=`\\left(${n}\\right)`),"right"===r?a+n:n+a}if(2===i.length){const n=i[0];let s=n.toTex(e);o[0]&&(s=`\\left(${s}\\right)`);let u,c=i[1].toTex(e);switch(o[1]&&(c=`\\left(${c}\\right)`),u="keep"===t?n.getIdentifier():n.getContent().getIdentifier(),this.getIdentifier()){case"OperatorNode:divide":return a+"{"+s+"}{"+c+"}";case"OperatorNode:pow":switch(s="{"+s+"}",c="{"+c+"}",u){case"ConditionalNode":case"OperatorNode:divide":s=`\\left(${s}\\right)`}break;case"OperatorNode:multiply":if(this.implicit&&"hide"===r)return s+"~"+c}return s+a+c}if(i.length>2&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())){const t=i.map((function(t,r){return t=t.toTex(e),o[r]&&(t=`\\left(${t}\\right)`),t}));return"OperatorNode:multiply"===this.getIdentifier()&&this.implicit&&"hide"===r?t.join("~"):t.join(a)}return"\\mathrm{"+this.fn+"}\\left("+i.map((function(t){return t.toTex(e)})).join(",")+"\\right)"}getIdentifier(){return this.type+":"+this.fn}}return lp(o,"name",Hp),o}),{isClass:!0,isNode:!0}),Zp="ParenthesisNode",Vp=de(Zp,["Node"],(e=>{let{Node:t}=e;class r extends t{constructor(e){if(super(),!X(e))throw new TypeError('Node expected for parameter "content"');this.content=e}get type(){return Zp}get isParenthesisNode(){return!0}_compile(e,t){return this.content._compile(e,t)}getContent(){return this.content.getContent()}forEach(e){e(this.content,"content",this)}map(e){const t=e(this.content,"content",this);return new r(t)}clone(){return new r(this.content)}_toString(e){return!e||e&&!e.parenthesis||e&&"keep"===e.parenthesis?"("+this.content.toString(e)+")":this.content.toString(e)}toJSON(){return{mathjs:Zp,content:this.content}}static fromJSON(e){return new r(e.content)}_toHTML(e){return!e||e&&!e.parenthesis||e&&"keep"===e.parenthesis?'('+this.content.toHTML(e)+')':this.content.toHTML(e)}_toTex(e){return!e||e&&!e.parenthesis||e&&"keep"===e.parenthesis?`\\left(${this.content.toTex(e)}\\right)`:this.content.toTex(e)}}return lp(r,"name",Zp),r}),{isClass:!0,isNode:!0}),Wp="RangeNode",Yp=de(Wp,["Node"],(e=>{let{Node:t}=e;function r(e,t,r){const n=bp(e,t,r),i={},o=bp(e.start,t,r);if(i.start=null!==o&&o<=n||"all"===t,e.step){const o=bp(e.step,t,r);i.step=null!==o&&o<=n||"all"===t}const a=bp(e.end,t,r);return i.end=null!==a&&a<=n||"all"===t,i}class n extends t{constructor(e,t,r){if(super(),!X(e))throw new TypeError("Node expected");if(!X(t))throw new TypeError("Node expected");if(r&&!X(r))throw new TypeError("Node expected");if(arguments.length>3)throw new Error("Too many arguments");this.start=e,this.end=t,this.step=r||null}get type(){return Wp}get isRangeNode(){return!0}needsEnd(){return this.filter((function(e){return ne(e)&&"end"===e.name})).length>0}_compile(e,t){const r=e.range,n=this.start._compile(e,t),i=this.end._compile(e,t);if(this.step){const o=this.step._compile(e,t);return function(e,t,a){return r(n(e,t,a),i(e,t,a),o(e,t,a))}}return function(e,t,o){return r(n(e,t,o),i(e,t,o))}}forEach(e){e(this.start,"start",this),e(this.end,"end",this),this.step&&e(this.step,"step",this)}map(e){return new n(this._ifNode(e(this.start,"start",this)),this._ifNode(e(this.end,"end",this)),this.step&&this._ifNode(e(this.step,"step",this)))}clone(){return new n(this.start,this.end,this.step&&this.step)}_toString(e){const t=r(this,e&&e.parenthesis?e.parenthesis:"keep",e&&e.implicit);let n,i=this.start.toString(e);if(t.start&&(i="("+i+")"),n=i,this.step){let r=this.step.toString(e);t.step&&(r="("+r+")"),n+=":"+r}let o=this.end.toString(e);return t.end&&(o="("+o+")"),n+=":"+o,n}toJSON(){return{mathjs:Wp,start:this.start,end:this.end,step:this.step}}static fromJSON(e){return new n(e.start,e.end,e.step)}_toHTML(e){const t=r(this,e&&e.parenthesis?e.parenthesis:"keep",e&&e.implicit);let n,i=this.start.toHTML(e);if(t.start&&(i='('+i+')'),n=i,this.step){let r=this.step.toHTML(e);t.step&&(r='('+r+')'),n+=':'+r}let o=this.end.toHTML(e);return t.end&&(o='('+o+')'),n+=':'+o,n}_toTex(e){const t=r(this,e&&e.parenthesis?e.parenthesis:"keep",e&&e.implicit);let n=this.start.toTex(e);if(t.start&&(n=`\\left(${n}\\right)`),this.step){let r=this.step.toTex(e);t.step&&(r=`\\left(${r}\\right)`),n+=":"+r}let i=this.end.toTex(e);return t.end&&(i=`\\left(${i}\\right)`),n+=":"+i,n}}return lp(n,"name",Wp),n}),{isClass:!0,isNode:!0}),Jp="RelationalNode",Xp=de(Jp,["Node"],(e=>{let{Node:t}=e;const r={equal:"==",unequal:"!=",smaller:"<",larger:">",smallerEq:"<=",largerEq:">="};class n extends t{constructor(e,t){if(super(),!Array.isArray(e))throw new TypeError("Parameter conditionals must be an array");if(!Array.isArray(t))throw new TypeError("Parameter params must be an array");if(e.length!==t.length-1)throw new TypeError("Parameter params must contain exactly one more element than parameter conditionals");this.conditionals=e,this.params=t}get type(){return Jp}get isRelationalNode(){return!0}_compile(e,t){const r=this,n=this.params.map((r=>r._compile(e,t)));return function(t,o,a){let s,u=n[0](t,o,a);for(let c=0;ce(t,"params["+r+"]",this)),this)}map(e){return new n(this.conditionals.slice(),this.params.map(((t,r)=>this._ifNode(e(t,"params["+r+"]",this))),this))}clone(){return new n(this.conditionals,this.params)}_toString(e){const t=e&&e.parenthesis?e.parenthesis:"keep",n=bp(this,t,e&&e.implicit),i=this.params.map((function(r,i){const o=bp(r,t,e&&e.implicit);return"all"===t||null!==o&&o<=n?"("+r.toString(e)+")":r.toString(e)}));let o=i[0];for(let e=0;e('+r.toHTML(e)+')':r.toHTML(e)}));let o=i[0];for(let e=0;e'+rn(r[this.conditionals[e]])+""+i[e+1];return o}_toTex(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=bp(this,t,e&&e.implicit),n=this.params.map((function(n,i){const o=bp(n,t,e&&e.implicit);return"all"===t||null!==o&&o<=r?"\\left("+n.toTex(e)+"\right)":n.toTex(e)}));let i=n[0];for(let e=0;e{let{math:t,Unit:r,Node:n}=e;function o(e){return!!r&&r.isValuelessUnit(e)}class a extends n{constructor(e){if(super(),"string"!=typeof e)throw new TypeError('String expected for parameter "name"');this.name=e}get type(){return"SymbolNode"}get isSymbolNode(){return!0}_compile(e,t){const n=this.name;if(!0===t[n])return function(e,t,r){return i(t,n)};if(n in e)return function(t,r,o){return t.has(n)?t.get(n):i(e,n)};{const e=o(n);return function(t,i,o){return t.has(n)?t.get(n):e?new r(null,n):a.onUndefinedSymbol(n)}}}forEach(e){}map(e){return this.clone()}static onUndefinedSymbol(e){throw new Error("Undefined symbol "+e)}clone(){return new a(this.name)}_toString(e){return this.name}_toHTML(e){const t=rn(this.name);return"true"===t||"false"===t?''+t+"":"i"===t?''+t+"":"Infinity"===t?''+t+"":"NaN"===t?''+t+"":"null"===t?''+t+"":"undefined"===t?''+t+"":''+t+""}toJSON(){return{mathjs:"SymbolNode",name:this.name}}static fromJSON(e){return new a(e.name)}_toTex(e){let r=!1;void 0===t[this.name]&&o(this.name)&&(r=!0);const n=zp(this.name,r);return"\\"===n[0]?n:" "+n}}return a}),{isClass:!0,isNode:!0}),Kp="FunctionNode",em=de(Kp,["math","Node","SymbolNode"],(e=>{var t;let{math:r,Node:n,SymbolNode:o}=e;const a=e=>Kr(e,{truncate:78});function u(e,t,r){let n="";const i=/\$(?:\{([a-z_][a-z_0-9]*)(?:\[([0-9]+)\])?\}|\$)/gi;let o,a=0;for(;null!==(o=i.exec(e));)if(n+=e.substring(a,o.index),a=o.index,"$$"===o[0])n+="$",a++;else{a+=o[0].length;const e=t[o[1]];if(!e)throw new ReferenceError("Template: Property "+o[1]+" does not exist.");if(void 0===o[2])switch(typeof e){case"string":n+=e;break;case"object":if(X(e))n+=e.toTex(r);else{if(!Array.isArray(e))throw new TypeError("Template: "+o[1]+" has to be a Node, String or array of Nodes");n+=e.map((function(e,t){if(X(e))return e.toTex(r);throw new TypeError("Template: "+o[1]+"["+t+"] is not a Node.")})).join(",")}break;default:throw new TypeError("Template: "+o[1]+" has to be a Node, String or array of Nodes")}else{if(!X(e[o[2]]&&e[o[2]]))throw new TypeError("Template: "+o[1]+"["+o[2]+"] is not a Node.");n+=e[o[2]].toTex(r)}}return n+=e.slice(a),n}class c extends n{constructor(e,t){if(super(),"string"==typeof e&&(e=new o(e)),!X(e))throw new TypeError('Node expected as parameter "fn"');if(!Array.isArray(t)||!t.every(X))throw new TypeError('Array containing Nodes expected for parameter "args"');this.fn=e,this.args=t||[]}get name(){return this.fn.name||""}get type(){return Kp}get isFunctionNode(){return!0}_compile(e,t){const r=this.args.map((r=>r._compile(e,t)));if(!ne(this.fn)){if(U(this.fn)&&J(this.fn.index)&&this.fn.index.isObjectProperty()){const n=this.fn.object._compile(e,t),i=this.fn.index.getObjectProperty(),o=this.args;return function(t,a,u){const c=n(t,a,u),l=function(e,t){if(!s(e,t))throw new Error('No access to method "'+t+'"');return e[t]}(c,i);if(null!=l&&l.rawArgs)return l(o,e,$p(t,a));{const e=r.map((e=>e(t,a,u)));return l.apply(c,e)}}}{const n=this.fn.toString(),i=this.fn._compile(e,t),o=this.args;return function(t,s,u){const c=i(t,s,u);if("function"!=typeof c)throw new TypeError(`Expression '${n}' did not evaluate to a function; value is:\n ${a(c)}`);if(c.rawArgs)return c(o,e,$p(t,s));{const e=r.map((e=>e(t,s,u)));return c.apply(c,e)}}}}{const n=this.fn.name;if(t[n]){const t=this.args;return function(o,s,u){const c=i(s,n);if("function"!=typeof c)throw new TypeError(`Argument '${n}' was not a function; received: ${a(c)}`);if(c.rawArgs)return c(t,e,$p(o,s));{const e=r.map((e=>e(o,s,u)));return c.apply(c,e)}}}{const t=n in e?i(e,n):void 0,o="function"==typeof t&&!0===t.rawArgs,s=t=>{let r;if(t.has(n))r=t.get(n);else{if(!(n in e))return c.onUndefinedFunction(n);r=i(e,n)}if("function"==typeof r)return r;throw new TypeError(`'${n}' is not a function; its value is:\n ${a(r)}`)};if(o){const t=this.args;return function(n,i,o){const a=s(n);return!0===a.rawArgs?a(t,e,$p(n,i)):a(...r.map((e=>e(n,i,o))))}}switch(r.length){case 0:return function(e,t,r){return s(e)()};case 1:return function(e,t,n){return s(e)((0,r[0])(e,t,n))};case 2:return function(e,t,n){const i=s(e),o=r[0],a=r[1];return i(o(e,t,n),a(e,t,n))};default:return function(e,t,n){return s(e)(...r.map((r=>r(e,t,n))))}}}}}forEach(e){e(this.fn,"fn",this);for(let t=0;t'+rn(this.fn)+'('+t.join(',')+')'}toTex(e){let t;return e&&"object"==typeof e.handler&&me(e.handler,this.name)&&(t=e.handler[this.name](this,e)),void 0!==t?t:super.toTex(e)}_toTex(e){const t=this.args.map((function(t){return t.toTex(e)}));let n,i;switch(Op[this.name]&&(n=Op[this.name]),!r[this.name]||"function"!=typeof r[this.name].toTex&&"object"!=typeof r[this.name].toTex&&"string"!=typeof r[this.name].toTex||(n=r[this.name].toTex),typeof n){case"function":i=n(this,e);break;case"string":i=u(n,this,e);break;case"object":switch(typeof n[t.length]){case"function":i=n[t.length](this,e);break;case"string":i=u(n[t.length],this,e)}}return void 0!==i?i:u("\\mathrm{${name}}\\left(${args}\\right)",this,e)}getIdentifier(){return this.type+":"+this.name}}return t=c,lp(c,"name",Kp),lp(c,"onUndefinedFunction",(function(e){throw new Error("Undefined function "+e)})),lp(c,"fromJSON",(function(e){return new t(e.fn,e.args)})),c}),{isClass:!0,isNode:!0}),tm="parse",rm=de(tm,["typed","numeric","config","AccessorNode","ArrayNode","AssignmentNode","BlockNode","ConditionalNode","ConstantNode","FunctionAssignmentNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","RangeNode","RelationalNode","SymbolNode"],(e=>{let{typed:t,numeric:r,config:n,AccessorNode:i,ArrayNode:o,AssignmentNode:a,BlockNode:s,ConditionalNode:u,ConstantNode:c,FunctionAssignmentNode:l,FunctionNode:f,IndexNode:p,ObjectNode:m,OperatorNode:d,ParenthesisNode:h,RangeNode:g,RelationalNode:y,SymbolNode:x}=e;const b=t(tm,{string:function(e){return k(e,{})},"Array | Matrix":function(e){return v(e,{})},"string, Object":function(e,t){return k(e,void 0!==t.nodes?t.nodes:{})},"Array | Matrix, Object":v});function v(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const r=void 0!==t.nodes?t.nodes:{};return Zn(e,(function(e){if("string"!=typeof e)throw new TypeError("String expected");return k(e,r)}))}const w={NULL:0,DELIMITER:1,NUMBER:2,SYMBOL:3,UNKNOWN:4},N={",":!0,"(":!0,")":!0,"[":!0,"]":!0,"{":!0,"}":!0,'"':!0,"'":!0,";":!0,"+":!0,"-":!0,"*":!0,".*":!0,"/":!0,"./":!0,"%":!0,"^":!0,".^":!0,"~":!0,"!":!0,"&":!0,"|":!0,"^|":!0,"=":!0,":":!0,"?":!0,"==":!0,"!=":!0,"<":!0,">":!0,"<=":!0,">=":!0,"<<":!0,">>":!0,">>>":!0},E={mod:!0,to:!0,in:!0,and:!0,xor:!0,or:!0,not:!0},A={true:!0,false:!1,null:null,undefined:void 0},S=["NaN","Infinity"],M={'"':'"',"'":"'","\\":"\\","/":"/",b:"\b",f:"\f",n:"\n",r:"\r",t:"\t"};function C(e,t){return e.expression.substr(e.index,t)}function T(e){return C(e,1)}function D(e){e.index++}function F(e){return e.expression.charAt(e.index-1)}function O(e){return e.expression.charAt(e.index+1)}function B(e){for(e.tokenType=w.NULL,e.token="",e.comment="";;){if("#"===T(e))for(;"\n"!==T(e)&&""!==T(e);)e.comment+=T(e),D(e);if(!b.isWhitespace(T(e),e.nestingLevel))break;D(e)}if(""===T(e))return void(e.tokenType=w.DELIMITER);if("\n"===T(e)&&!e.nestingLevel)return e.tokenType=w.DELIMITER,e.token=T(e),void D(e);const t=T(e),r=C(e,2),n=C(e,3);if(3===n.length&&N[n])return e.tokenType=w.DELIMITER,e.token=n,D(e),D(e),void D(e);if(2===r.length&&N[r])return e.tokenType=w.DELIMITER,e.token=r,D(e),void D(e);if(N[t])return e.tokenType=w.DELIMITER,e.token=t,void D(e);if(b.isDigitDot(t)){e.tokenType=w.NUMBER;const t=C(e,2);if("0b"===t||"0o"===t||"0x"===t){for(e.token+=T(e),D(e),e.token+=T(e),D(e);b.isHexDigit(T(e));)e.token+=T(e),D(e);if("."===T(e))for(e.token+=".",D(e);b.isHexDigit(T(e));)e.token+=T(e),D(e);else if("i"===T(e))for(e.token+="i",D(e);b.isDigit(T(e));)e.token+=T(e),D(e);return}if("."===T(e)){if(e.token+=T(e),D(e),!b.isDigit(T(e)))return void(e.tokenType=w.DELIMITER)}else{for(;b.isDigit(T(e));)e.token+=T(e),D(e);b.isDecimalMark(T(e),O(e))&&(e.token+=T(e),D(e))}for(;b.isDigit(T(e));)e.token+=T(e),D(e);if("E"===T(e)||"e"===T(e))if(b.isDigit(O(e))||"-"===O(e)||"+"===O(e)){if(e.token+=T(e),D(e),"+"!==T(e)&&"-"!==T(e)||(e.token+=T(e),D(e)),!b.isDigit(T(e)))throw ce(e,'Digit expected, got "'+T(e)+'"');for(;b.isDigit(T(e));)e.token+=T(e),D(e);if(b.isDecimalMark(T(e),O(e)))throw ce(e,'Digit expected, got "'+T(e)+'"')}else if("."===O(e))throw D(e),ce(e,'Digit expected, got "'+T(e)+'"')}else{if(!b.isAlpha(T(e),F(e),O(e))){for(e.tokenType=w.UNKNOWN;""!==T(e);)e.token+=T(e),D(e);throw ce(e,'Syntax error in part "'+e.token+'"')}for(;b.isAlpha(T(e),F(e),O(e))||b.isDigit(T(e));)e.token+=T(e),D(e);me(E,e.token)?e.tokenType=w.DELIMITER:e.tokenType=w.SYMBOL}}function _(e){do{B(e)}while("\n"===e.token)}function z(e){e.nestingLevel++}function I(e){e.nestingLevel--}function k(e,t){const r={extraNodes:{},expression:"",comment:"",index:0,token:"",tokenType:w.NULL,nestingLevel:0,conditionalLevel:null};Wr(r,{expression:e,extraNodes:t}),B(r);const n=function(e){let t;const r=[];let n;for(""!==e.token&&"\n"!==e.token&&";"!==e.token&&(t=q(e),e.comment&&(t.comment=e.comment));"\n"===e.token||";"===e.token;)0===r.length&&t&&(n=";"!==e.token,r.push({node:t,visible:n})),B(e),"\n"!==e.token&&";"!==e.token&&""!==e.token&&(t=q(e),e.comment&&(t.comment=e.comment),n=";"!==e.token,r.push({node:t,visible:n}));return r.length>0?new s(r):(t||(t=new c(void 0),e.comment&&(t.comment=e.comment)),t)}(r);if(""!==r.token)throw r.tokenType===w.DELIMITER?le(r,"Unexpected operator "+r.token):ce(r,'Unexpected part "'+r.token+'"');return n}function q(e){let t,r,n,i;const o=function(e){let t=function(e){let t=R(e);for(;"or"===e.token;)_(e),t=new d("or","or",[t,R(e)]);return t}(e);for(;"?"===e.token;){const r=e.conditionalLevel;e.conditionalLevel=e.nestingLevel,_(e);const n=t,i=q(e);if(":"!==e.token)throw ce(e,"False part of conditional expression expected");e.conditionalLevel=null,_(e);const o=q(e);t=new u(n,i,o),e.conditionalLevel=r}return t}(e);if("="===e.token){if(ne(o))return t=o.name,_(e),n=q(e),new a(new x(t),n);if(U(o))return _(e),n=q(e),new a(o.object,o.index,n);if(Y(o)&&ne(o.fn)&&(i=!0,r=[],t=o.name,o.args.forEach((function(e,t){ne(e)?r[t]=e.name:i=!1})),i))return _(e),n=q(e),new l(t,r,n);throw ce(e,"Invalid left hand side of assignment operator =")}return o}function R(e){let t=P(e);for(;"xor"===e.token;)_(e),t=new d("xor","xor",[t,P(e)]);return t}function P(e){let t=j(e);for(;"and"===e.token;)_(e),t=new d("and","and",[t,j(e)]);return t}function j(e){let t=L(e);for(;"|"===e.token;)_(e),t=new d("|","bitOr",[t,L(e)]);return t}function L(e){let t=$(e);for(;"^|"===e.token;)_(e),t=new d("^|","bitXor",[t,$(e)]);return t}function $(e){let t=H(e);for(;"&"===e.token;)_(e),t=new d("&","bitAnd",[t,H(e)]);return t}function H(e){const t=[G(e)],r=[],n={"==":"equal","!=":"unequal","<":"smaller",">":"larger","<=":"smallerEq",">=":"largerEq"};for(;me(n,e.token);){const i={name:e.token,fn:n[e.token]};r.push(i),_(e),t.push(G(e))}return 1===t.length?t[0]:2===t.length?new d(r[0].name,r[0].fn,t):new y(r.map((e=>e.fn)),t)}function G(e){let t,r,n,i;t=W(e);const o={"<<":"leftShift",">>":"rightArithShift",">>>":"rightLogShift"};for(;me(o,e.token);)r=e.token,n=o[r],_(e),i=[t,W(e)],t=new d(r,n,i);return t}function W(e){let t,r,n,i;t=J(e);const o={to:"to",in:"to"};for(;me(o,e.token);)r=e.token,n=o[r],_(e),"in"===r&&""===e.token?t=new d("*","multiply",[t,new x("in")],!0):(i=[t,J(e)],t=new d(r,n,i));return t}function J(e){let t;const r=[];if(t=":"===e.token?new c(1):X(e),":"===e.token&&e.conditionalLevel!==e.nestingLevel){for(r.push(t);":"===e.token&&r.length<3;)_(e),")"===e.token||"]"===e.token||","===e.token||""===e.token?r.push(new x("end")):r.push(X(e));t=3===r.length?new g(r[0],r[2],r[1]):new g(r[0],r[1])}return t}function X(e){let t,r,n,i;t=Q(e);const o={"+":"add","-":"subtract"};for(;me(o,e.token);){r=e.token,n=o[r],_(e);const a=Q(e);i=a.isPercentage?[t,new d("*","multiply",[t,a])]:[t,a],t=new d(r,n,i)}return t}function Q(e){let t,r,n,i;t=ee(e),r=t;const o={"*":"multiply",".*":"dotMultiply","/":"divide","./":"dotDivide"};for(;me(o,e.token);)n=e.token,i=o[n],_(e),r=ee(e),t=new d(n,i,[t,r]);return t}function ee(e){let t,r;for(t=te(e),r=t;e.tokenType===w.SYMBOL||"in"===e.token&&Z(t)||"in"===e.token&&K(t)&&"unaryMinus"===t.fn&&Z(t.args[0])||!(e.tokenType!==w.NUMBER||Z(r)||K(r)&&"!"!==r.op)||"("===e.token;)r=te(e),t=new d("*","multiply",[t,r],!0);return t}function te(e){let t=re(e),r=t;const n=[];for(;"/"===e.token&&V(r);){if(n.push(Wr({},e)),_(e),e.tokenType!==w.NUMBER){Wr(e,n.pop());break}if(n.push(Wr({},e)),_(e),e.tokenType!==w.SYMBOL&&"("!==e.token){n.pop(),Wr(e,n.pop());break}Wr(e,n.pop()),n.pop(),r=re(e),t=new d("/","divide",[t,r])}return t}function re(e){let t,r,n,i;t=ie(e);const o={"%":"mod",mod:"mod"};for(;me(o,e.token);)r=e.token,n=o[r],_(e),"%"===r&&e.tokenType===w.DELIMITER&&"("!==e.token?t=new d("/","divide",[t,new c(100)],!1,!0):(i=[t,ie(e)],t=new d(r,n,i));return t}function ie(e){let t,i,a;const s={"-":"unaryMinus","+":"unaryPlus","~":"bitNot",not:"not"};return me(s,e.token)?(a=s[e.token],t=e.token,_(e),i=[ie(e)],new d(t,a,i)):function(e){let t,i,a,s;return t=function(e){let t,i,a,s;t=function(e){let t=[];if(e.tokenType===w.SYMBOL&&me(e.extraNodes,e.token)){const r=e.extraNodes[e.token];if(B(e),"("===e.token){if(t=[],z(e),B(e),")"!==e.token)for(t.push(q(e));","===e.token;)B(e),t.push(q(e));if(")"!==e.token)throw ce(e,"Parenthesis ) expected");I(e),B(e)}return new r(t)}return function(e){let t,i;return e.tokenType===w.SYMBOL||e.tokenType===w.DELIMITER&&e.token in E?(i=e.token,B(e),t=me(A,i)?new c(A[i]):S.includes(i)?new c(r(i,"number")):new x(i),t=oe(e,t),t):function(e){let t,i;return'"'===e.token||"'"===e.token?(i=ae(e,e.token),t=new c(i),t=oe(e,t),t):function(e){let t,i,a,s;if("["===e.token){if(z(e),B(e),"]"!==e.token){const r=se(e);if(";"===e.token){for(a=1,i=[r];";"===e.token;)B(e),"]"!==e.token&&(i[a]=se(e),a++);if("]"!==e.token)throw ce(e,"End of matrix ] expected");I(e),B(e),s=i[0].items.length;for(let t=1;t0},b.isDecimalMark=function(e,t){return"."===e&&"/"!==t&&"*"!==t&&"^"!==t},b.isDigitDot=function(e){return e>="0"&&e<="9"||"."===e},b.isDigit=function(e){return e>="0"&&e<="9"},b.isHexDigit=function(e){return e>="0"&&e<="9"||e>="a"&&e<="f"||e>="A"&&e<="F"},t.addConversion({from:"string",to:"Node",convert:b}),b})),nm="compile",im=de(nm,["typed","parse"],(e=>{let{typed:t,parse:r}=e;return t(nm,{string:function(e){return r(e).compile()},"Array | Matrix":function(e){return Zn(e,(function(e){return r(e).compile()}))}})})),om="evaluate",am=de(om,["typed","parse"],(e=>{let{typed:t,parse:r}=e;return t(om,{string:function(e){const t=m();return r(e).compile().evaluate(t)},"string, Map | Object":function(e,t){return r(e).compile().evaluate(t)},"Array | Matrix":function(e){const t=m();return Zn(e,(function(e){return r(e).compile().evaluate(t)}))},"Array | Matrix, Map | Object":function(e,t){return Zn(e,(function(e){return r(e).compile().evaluate(t)}))}})})),sm=de("Parser",["evaluate"],(e=>{let{evaluate:t}=e;function r(){if(!(this instanceof r))throw new SyntaxError("Constructor must be called with the new operator");Object.defineProperty(this,"scope",{value:m(),writable:!1})}return r.prototype.type="Parser",r.prototype.isParser=!0,r.prototype.evaluate=function(e){return t(e,this.scope)},r.prototype.get=function(e){if(this.scope.has(e))return this.scope.get(e)},r.prototype.getAll=function(){return function(e){if(e instanceof l)return e.wrappedObject;const t={};for(const r of e.keys())o(t,r,e.get(r));return t}(this.scope)},r.prototype.getAllAsMap=function(){return this.scope},r.prototype.set=function(e,t){return this.scope.set(e,t),t},r.prototype.remove=function(e){this.scope.delete(e)},r.prototype.clear=function(){this.scope.clear()},r}),{isClass:!0}),um="parser",cm=de(um,["typed","Parser"],(e=>{let{typed:t,Parser:r}=e;return t(um,{"":function(){return new r}})})),lm=de("lup",["typed","matrix","abs","addScalar","divideScalar","multiplyScalar","subtractScalar","larger","equalScalar","unaryMinus","DenseMatrix","SparseMatrix","Spa"],(e=>{let{typed:t,matrix:r,abs:n,addScalar:i,divideScalar:o,multiplyScalar:a,subtractScalar:s,larger:u,equalScalar:c,unaryMinus:l,DenseMatrix:f,SparseMatrix:p,Spa:m}=e;return t("lup",{DenseMatrix:function(e){return d(e)},SparseMatrix:function(e){return function(e){const t=e._size[0],r=e._size[1],i=Math.min(t,r),s=e._values,f=e._index,d=e._ptr,h=[],g=[],y=[],x=[t,i],b=[],v=[],w=[],N=[i,r];let E,A,S;const M=[],C=[];for(E=0;E0&&e.forEach(0,A-1,(function(t,r){p._forEachRow(t,h,g,y,(function(n,i){n>t&&e.accumulate(n,l(a(i,r)))}))}));let C=A,D=e.get(A),F=n(D);e.forEach(A+1,t-1,(function(e,t){const r=n(t);u(r,F)&&(C=e,F=r,D=t)})),A!==C&&(p._swapRows(A,C,x[1],h,g,y),p._swapRows(A,C,N[1],b,v,w),e.swap(A,C),T(A,C)),e.forEach(0,t-1,(function(e,t){e<=A?(b.push(t),v.push(e)):(t=o(t,D),c(t,0)||(h.push(t),g.push(e)))}))}return w.push(b.length),y.push(h.length),{L:new p({values:h,index:g,ptr:y,size:x}),U:new p({values:b,index:v,ptr:w,size:N}),p:M,toString:function(){return"L: "+this.L.toString()+"\nU: "+this.U.toString()+"\nP: "+this.p}}}(e)},Array:function(e){const t=d(r(e));return{L:t.L.valueOf(),U:t.U.valueOf(),p:t.p}}});function d(e){const t=e._size[0],r=e._size[1];let l=Math.min(t,r);const p=ae(e._data),m=[],d=[t,l],h=[],g=[l,r];let y,x,b;const v=[];for(y=0;y0)for(y=0;y{let{typed:t,matrix:r,zeros:n,identity:i,isZero:o,equal:a,sign:s,sqrt:u,conj:c,unaryMinus:l,addScalar:f,divideScalar:p,multiplyScalar:m,subtractScalar:d,complex:h}=e;return Wr(t("qr",{DenseMatrix:function(e){return y(e)},SparseMatrix:function(e){return function(){throw new Error("qr not implemented for sparse matrices yet")}()},Array:function(e){const t=y(r(e));return{Q:t.Q.valueOf(),R:t.R.valueOf()}}}),{_denseQRimpl:g});function g(e){const t=e._size[0],r=e._size[1],h=i([t],"dense"),g=h._data,y=e.clone(),x=y._data;let b,v,w;const N=n([t],"");for(w=0;w0){const e="Complex"===r[0][0].type?h(0):0;for(let t=0;t=0;){const e=r[a+s],u=r[n+e];-1===u?(s--,o[t++]=e):(r[n+e]=r[i+u],++s,r[a+s]=u)}return t}function mm(e){return-e-2}const dm=de("csAmd",["add","multiply","transpose"],(e=>{let{add:t,multiply:r,transpose:n}=e;return function(e,a){if(!a||e<=0||e>3)return null;const s=a._size,u=s[0],c=s[1];let l=0,f=Math.max(16,10*Math.sqrt(c));f=Math.min(c-2,f);const p=function(e,i,o,a,s){const u=n(i);if(1===e&&a===o)return t(i,u);if(2===e){const e=u._index,t=u._ptr;let a=0;for(let r=0;rs))for(const i=t[r+1];na)r[s+p]=0,r[i+p]=-1,f++,t[p]=mm(e),r[s+e]++;else{const e=r[u+m];-1!==e&&(c[e]=p),r[l+p]=r[u+m],r[u+m]=p}}return f}(c,d,y,N,w,E,f,x,v,S,b),H=0;for(;$e?(O=T,B=n,_=y[0+T]-e):(O=m[n++],B=d[O],_=y[0+O]),F=1;F<=_;F++)M=m[B++],(z=y[x+M])<=0||(r+=z,y[x+M]=-z,m[a++]=M,-1!==y[b+M]&&(S[y[b+M]]=S[M]),-1!==S[M]?y[b+S[M]]=y[b+M]:y[v+y[N+M]]=y[b+M]);O!==T&&(d[O]=mm(T),y[E+O]=0)}for(0!==e&&(h=a),y[N+T]=r,d[T]=o,y[0+T]=a-o,y[w+T]=-2,L=i(L,l,y,E,c),I=o;I=L?y[E+O]-=z:0!==y[E+O]&&(y[E+O]=y[N+O]+e)}for(I=o;I0?(U+=e,m[P++]=O,j+=O):(d[O]=mm(T),y[E+O]=0)}y[w+M]=P-q+1;const e=P,i=q+y[0+M];for(n=R+1;n=0))for(j=S[M],M=y[A+j],y[A+j]=-1;-1!==M&&-1!==y[b+M];M=y[b+M],L++){for(_=y[0+M],k=y[w+M],n=d[M]+1;n<=d[M]+_-1;n++)y[E+m[n]]=L;let e=M;for(C=y[b+M];-1!==C;){let t=y[0+C]===_&&y[w+C]===k;for(n=d[C]+1;t&&n<=d[C]+_-1;n++)y[E+m[n]]!==L&&(t=0);t?(d[C]=mm(M),y[x+M]+=y[x+C],y[x+C]=0,y[w+C]=-1,C=y[b+C],y[b+e]=C):(e=C,C=y[b+C])}}for(n=o,I=o;I=0;C--)y[x+C]>0||(y[b+C]=y[v+d[C]],y[v+d[C]]=C);for(O=c;O>=0;O--)y[x+O]<=0||-1!==d[O]&&(y[b+O]=y[v+d[O]],y[v+d[O]]=O);for(T=0,M=0;M<=c;M++)-1===d[M]&&(T=pm(M,T,y,v,b,g,E));return g.splice(g.length-1,1),g};function i(e,t,r,n,i){if(e<2||e+t<0){for(let e=0;e{let{transpose:t}=e;return function(e,r,n,i){if(!e||!r||!n)return null;const o=e._size,a=o[0],s=o[1];let u,c,l,f,p,m,d;const h=4*s+(i?s+a+1:0),g=[],y=s,x=2*s,b=3*s,v=4*s,w=5*s+1;for(l=0;l=1&&N[c]++,2===e.jleaf&&N[e.q]--}-1!==r[c]&&(g[0+c]=r[c])}for(c=0;c{let{add:t,multiply:r,transpose:n}=e;const i=dm({add:t,multiply:r,transpose:n}),o=gm({transpose:n});return function(e,t,r){const n=t._ptr,a=t._size[1];let s;const u={};if(u.q=i(e,t),e&&!u.q)return null;if(r){const r=e?function(e,t,r){const n=e._values,i=e._index,o=e._ptr,a=e._size,s=e._datatype,u=a[0],c=a[1],l=null,f=[],p=[];let m=0;for(let e=0;e=0;r--)-1!==e[r]&&(o[a+r]=o[0+e[r]],o[0+e[r]]=r);for(r=0;r=0;h--)for(y=r[h],x=r[h+1],g=y;g=0;d--)u[d]=-1,h=c[d],-1!==h&&(0==l[m+h]++&&(l[p+h]=d),l[0+d]=l[f+h],l[f+h]=d);for(t.lnz=0,t.m2=o,h=0;h=0;){e=n[f];const t=i?i[e]:e;xm(a,e)||(bm(a,e),n[s+f]=t<0?0:vm(a[t]));let p=1;for(c=n[s+f],l=t<0?0:vm(a[t+1]);c{let{divideScalar:t,multiply:r,subtract:n}=e;return function(e,i,o,a,s,u,c){const l=e._values,f=e._index,p=e._ptr,m=e._size[1],d=i._values,h=i._index,g=i._ptr;let y,x,b,v;const w=function(e,t,r,n,i){const o=e._ptr,a=e._size,s=t._index,u=t._ptr,c=a[1];let l,f,p,m=c;for(f=u[r],p=u[r+1],l=f;l{let{abs:t,divideScalar:r,multiply:n,subtract:i,larger:o,largerEq:a,SparseMatrix:s}=e;const u=Nm({divideScalar:r,multiply:n,subtract:i});return function(e,i,c){if(!e)return null;const l=e._size[1];let f,p=100,m=100;i&&(f=i.q,p=i.lnz||p,m=i.unz||m);const d=[],h=[],g=[],y=new s({values:d,index:h,ptr:g,size:[l,l]}),x=[],b=[],v=[],w=new s({values:x,index:b,ptr:v,size:[l,l]}),N=[];let E,A;const S=[],M=[];for(E=0;E{let{typed:t,abs:r,add:n,multiply:i,transpose:o,divideScalar:a,subtract:s,larger:u,largerEq:c,SparseMatrix:l}=e;const f=ym({add:n,multiply:i,transpose:o}),p=Em({abs:r,divideScalar:a,multiply:i,subtract:s,larger:u,largerEq:c,SparseMatrix:l});return t("slu",{"SparseMatrix, number, number":function(e,t,r){if(!ye(t)||t<0||t>3)throw new Error("Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]");if(r<0||r>1)throw new Error("Partial pivoting threshold must be a number from 0 to 1");const n=f(t,e,!1),i=p(e,n,r);return{L:i.L,U:i.U,p:i.pinv,q:n.q,toString:function(){return"L: "+this.L.toString()+"\nU: "+this.U.toString()+"\np: "+this.p.toString()+(this.q?"\nq: "+this.q.toString():"")+"\n"}}}})}));function Sm(e,t){let r;const n=t.length,i=[];if(e)for(r=0;r{let{typed:t,matrix:r,lup:n,slu:i,usolve:o,lsolve:a,DenseMatrix:s}=e;const u=ac({DenseMatrix:s});return t(Mm,{"Array, Array | Matrix":function(e,t){e=r(e);const i=n(e);return l(i.L,i.U,i.p,null,t).valueOf()},"DenseMatrix, Array | Matrix":function(e,t){const r=n(e);return l(r.L,r.U,r.p,null,t)},"SparseMatrix, Array | Matrix":function(e,t){const r=n(e);return l(r.L,r.U,r.p,null,t)},"SparseMatrix, Array | Matrix, number, number":function(e,t,r,n){const o=i(e,r,n);return l(o.L,o.U,o.p,o.q,t)},"Object, Array | Matrix":function(e,t){return l(e.L,e.U,e.p,e.q,t)}});function c(e){if(E(e))return e;if(N(e))return r(e);throw new TypeError("Invalid Matrix LU decomposition")}function l(e,t,r,n,i){e=c(e),t=c(t),r&&((i=u(e,i,!0))._data=Sm(r,i._data));const s=a(e,i),l=o(t,s);return n&&(l._data=Sm(n,l._data)),l}})),Tm="polynomialRoot",Dm=de(Tm,["typed","isZero","equalScalar","add","subtract","multiply","divide","sqrt","unaryMinus","cbrt","typeOf","im","re"],(e=>{let{typed:t,isZero:r,equalScalar:n,add:i,subtract:o,multiply:a,divide:s,sqrt:u,unaryMinus:c,cbrt:l,typeOf:f,im:p,re:m}=e;return t(Tm,{"number|Complex, ...number|Complex":(e,t)=>{const d=[e,...t];for(;d.length>0&&r(d[d.length-1]);)d.pop();if(d.length<2)throw new RangeError(`Polynomial [${e}, ${t}] must have a non-zero non-constant coefficient`);switch(d.length){case 2:return[c(s(d[0],d[1]))];case 3:{const[e,t,r]=d,i=a(2,r),l=a(t,t),f=a(4,r,e);if(n(l,f))return[s(c(t),i)];const p=u(o(l,f));return[s(o(p,t),i),s(o(c(p),t),i)]}case 4:{const[e,t,r,h]=d,g=c(a(3,h)),y=a(r,r),x=a(3,h,t),b=i(a(2,r,r,r),a(27,h,h,e)),v=a(9,h,r,t);if(n(y,x)&&n(b,v))return[s(r,g)];const w=o(y,x),N=o(b,v),E=i(a(18,h,r,t,e),a(r,r,t,t)),A=i(a(4,r,r,r,e),a(4,h,t,t,t),a(27,h,h,e,e));if(n(E,A))return[s(o(a(4,h,r,t),i(a(9,h,h,e),a(r,r,r))),a(h,w)),s(o(a(9,h,e),a(r,t)),a(2,w))];let S;return S=n(y,x)?N:s(i(N,u(o(a(N,N),a(4,w,w,w)))),2),l(S,!0).toArray().map((e=>s(i(r,e,s(w,e)),g))).map((e=>"Complex"===f(e)&&n(m(e),m(e)+p(e))?m(e):e))}default:throw new RangeError(`only implemented for cubic or lower-order polynomials, not ${d}`)}}})}));r(9463);const Fm=de("Help",["evaluate"],(e=>{let{evaluate:t}=e;function r(e){if(!(this instanceof r))throw new SyntaxError("Constructor must be called with the new operator");if(!e)throw new Error('Argument "doc" missing');this.doc=e}return r.prototype.type="Help",r.prototype.isHelp=!0,r.prototype.toString=function(){const e=this.doc||{};let r="\n";if(e.name&&(r+="Name: "+e.name+"\n\n"),e.category&&(r+="Category: "+e.category+"\n\n"),e.description&&(r+="Description:\n "+e.description+"\n\n"),e.syntax&&(r+="Syntax:\n "+e.syntax.join("\n ")+"\n\n"),e.examples){r+="Examples:\n";let n=!1;const i=t("config()"),o={config:e=>(n=!0,t("config(newConfig)",{newConfig:e}))};for(let n=0;n"mathjs"!==e)).forEach((r=>{t[r]=e[r]})),new r(t)},r.prototype.valueOf=r.prototype.toString,r}),{isClass:!0}),Om=de("Chain",["?on","math","typed"],(e=>{let{on:t,math:r,typed:n}=e;function i(e){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");ie(e)?this.value=e.value:this.value=e}function o(e,t){pe(i.prototype,e,(function(){const e=t();if("function"==typeof e)return a(e)}))}function a(e){return function(){if(0===arguments.length)return new i(e(this.value));const t=[this.value];for(let e=0;ee[t]));var r,n};const s={expression:!0,docs:!0,type:!0,classes:!0,json:!0,error:!0,isChain:!0};return i.createProxy(r),t&&t("import",(function(e,t,r){r||o(e,t)})),i}),{isClass:!0}),Bm={name:"e",category:"Constants",syntax:["e"],description:"Euler's number, the base of the natural logarithm. Approximately equal to 2.71828",examples:["e","e ^ 2","exp(2)","log(e)"],seealso:["exp"]},_m={name:"pi",category:"Constants",syntax:["pi"],description:"The number pi is a mathematical constant that is the ratio of a circle's circumference to its diameter, and is approximately equal to 3.14159",examples:["pi","sin(pi/2)"],seealso:["tau"]},zm={bignumber:{name:"bignumber",category:"Construction",syntax:["bignumber(x)"],description:"Create a big number from a number or string.",examples:["0.1 + 0.2","bignumber(0.1) + bignumber(0.2)",'bignumber("7.2")','bignumber("7.2e500")',"bignumber([0.1, 0.2, 0.3])"],seealso:["boolean","bigint","complex","fraction","index","matrix","string","unit"]},bigint:{name:"bigint",category:"Construction",syntax:["bigint(x)"],description:"Create a bigint, an integer with an arbitrary number of digits, from a number or string.",examples:["123123123123123123 # a large number will lose digits",'bigint("123123123123123123")','bignumber(["1", "3", "5"])'],seealso:["boolean","bignumber","number","complex","fraction","index","matrix","string","unit"]},boolean:{name:"boolean",category:"Construction",syntax:["x","boolean(x)"],description:"Convert a string or number into a boolean.",examples:["boolean(0)","boolean(1)","boolean(3)",'boolean("true")','boolean("false")',"boolean([1, 0, 1, 1])"],seealso:["bignumber","complex","index","matrix","number","string","unit"]},complex:{name:"complex",category:"Construction",syntax:["complex()","complex(re, im)","complex(string)"],description:"Create a complex number.",examples:["complex()","complex(2, 3)",'complex("7 - 2i")'],seealso:["bignumber","boolean","index","matrix","number","string","unit"]},createUnit:{name:"createUnit",category:"Construction",syntax:["createUnit(definitions)","createUnit(name, definition)"],description:"Create a user-defined unit and register it with the Unit type.",examples:['createUnit("foo")','createUnit("knot", {definition: "0.514444444 m/s", aliases: ["knots", "kt", "kts"]})','createUnit("mph", "1 mile/hour")'],seealso:["unit","splitUnit"]},fraction:{name:"fraction",category:"Construction",syntax:["fraction(num)","fraction(matrix)","fraction(num,den)","fraction({n: num, d: den})"],description:"Create a fraction from a number or from integer numerator and denominator.",examples:["fraction(0.125)","fraction(1, 3) + fraction(2, 5)","fraction({n: 333, d: 53})","fraction([sqrt(9), sqrt(10), sqrt(11)])"],seealso:["bignumber","boolean","complex","index","matrix","string","unit"]},index:{name:"index",category:"Construction",syntax:["[start]","[start:end]","[start:step:end]","[start1, start 2, ...]","[start1:end1, start2:end2, ...]","[start1:step1:end1, start2:step2:end2, ...]"],description:"Create an index to get or replace a subset of a matrix",examples:["A = [1, 2, 3; 4, 5, 6]","A[1, :]","A[1, 2] = 50","A[1:2, 1:2] = 1","B = [1, 2, 3]","B[B>1 and B<3]"],seealso:["bignumber","boolean","complex","matrix,","number","range","string","unit"]},matrix:{name:"matrix",category:"Construction",syntax:["[]","[a1, b1, ...; a2, b2, ...]","matrix()",'matrix("dense")',"matrix([...])"],description:"Create a matrix.",examples:["[]","[1, 2, 3]","[1, 2, 3; 4, 5, 6]","matrix()","matrix([3, 4])",'matrix([3, 4; 5, 6], "sparse")','matrix([3, 4; 5, 6], "sparse", "number")'],seealso:["bignumber","boolean","complex","index","number","string","unit","sparse"]},number:{name:"number",category:"Construction",syntax:["x","number(x)","number(unit, valuelessUnit)"],description:"Create a number or convert a string or boolean into a number.",examples:["2","2e3","4.05","number(2)",'number("7.2")',"number(true)","number([true, false, true, true])",'number(unit("52cm"), "m")'],seealso:["bignumber","bigint","boolean","complex","fraction","index","matrix","string","unit"]},sparse:{name:"sparse",category:"Construction",syntax:["sparse()","sparse([a1, b1, ...; a1, b2, ...])",'sparse([a1, b1, ...; a1, b2, ...], "number")'],description:"Create a sparse matrix.",examples:["sparse()","sparse([3, 4; 5, 6])",'sparse([3, 0; 5, 0], "number")'],seealso:["bignumber","boolean","complex","index","number","string","unit","matrix"]},splitUnit:{name:"splitUnit",category:"Construction",syntax:["splitUnit(unit: Unit, parts: Unit[])"],description:"Split a unit in an array of units whose sum is equal to the original unit.",examples:['splitUnit(1 m, ["feet", "inch"])'],seealso:["unit","createUnit"]},string:{name:"string",category:"Construction",syntax:['"text"',"string(x)"],description:"Create a string or convert a value to a string",examples:['"Hello World!"',"string(4.2)","string(3 + 2i)"],seealso:["bignumber","boolean","complex","index","matrix","number","unit"]},unit:{name:"unit",category:"Construction",syntax:["value unit","unit(value, unit)","unit(string)"],description:"Create a unit.",examples:["5.5 mm","3 inch",'unit(7.1, "kilogram")','unit("23 deg")'],seealso:["bignumber","boolean","complex","index","matrix","number","string"]},e:Bm,E:Bm,false:{name:"false",category:"Constants",syntax:["false"],description:"Boolean value false",examples:["false"],seealso:["true"]},i:{name:"i",category:"Constants",syntax:["i"],description:"Imaginary unit, defined as i*i=-1. A complex number is described as a + b*i, where a is the real part, and b is the imaginary part.",examples:["i","i * i","sqrt(-1)"],seealso:[]},Infinity:{name:"Infinity",category:"Constants",syntax:["Infinity"],description:"Infinity, a number which is larger than the maximum number that can be handled by a floating point number.",examples:["Infinity","1 / 0"],seealso:[]},LN2:{name:"LN2",category:"Constants",syntax:["LN2"],description:"Returns the natural logarithm of 2, approximately equal to 0.693",examples:["LN2","log(2)"],seealso:[]},LN10:{name:"LN10",category:"Constants",syntax:["LN10"],description:"Returns the natural logarithm of 10, approximately equal to 2.302",examples:["LN10","log(10)"],seealso:[]},LOG2E:{name:"LOG2E",category:"Constants",syntax:["LOG2E"],description:"Returns the base-2 logarithm of E, approximately equal to 1.442",examples:["LOG2E","log(e, 2)"],seealso:[]},LOG10E:{name:"LOG10E",category:"Constants",syntax:["LOG10E"],description:"Returns the base-10 logarithm of E, approximately equal to 0.434",examples:["LOG10E","log(e, 10)"],seealso:[]},NaN:{name:"NaN",category:"Constants",syntax:["NaN"],description:"Not a number",examples:["NaN","0 / 0"],seealso:[]},null:{name:"null",category:"Constants",syntax:["null"],description:"Value null",examples:["null"],seealso:["true","false"]},pi:_m,PI:_m,phi:{name:"phi",category:"Constants",syntax:["phi"],description:"Phi is the golden ratio. Two quantities are in the golden ratio if their ratio is the same as the ratio of their sum to the larger of the two quantities. Phi is defined as `(1 + sqrt(5)) / 2` and is approximately 1.618034...",examples:["phi"],seealso:[]},SQRT1_2:{name:"SQRT1_2",category:"Constants",syntax:["SQRT1_2"],description:"Returns the square root of 1/2, approximately equal to 0.707",examples:["SQRT1_2","sqrt(1/2)"],seealso:[]},SQRT2:{name:"SQRT2",category:"Constants",syntax:["SQRT2"],description:"Returns the square root of 2, approximately equal to 1.414",examples:["SQRT2","sqrt(2)"],seealso:[]},tau:{name:"tau",category:"Constants",syntax:["tau"],description:"Tau is the ratio constant of a circle's circumference to radius, equal to 2 * pi, approximately 6.2832.",examples:["tau","2 * pi"],seealso:["pi"]},true:{name:"true",category:"Constants",syntax:["true"],description:"Boolean value true",examples:["true"],seealso:["false"]},version:{name:"version",category:"Constants",syntax:["version"],description:"A string with the version number of math.js",examples:["version"],seealso:[]},speedOfLight:{description:"Speed of light in vacuum",examples:["speedOfLight"]},gravitationConstant:{description:"Newtonian constant of gravitation",examples:["gravitationConstant"]},planckConstant:{description:"Planck constant",examples:["planckConstant"]},reducedPlanckConstant:{description:"Reduced Planck constant",examples:["reducedPlanckConstant"]},magneticConstant:{description:"Magnetic constant (vacuum permeability)",examples:["magneticConstant"]},electricConstant:{description:"Electric constant (vacuum permeability)",examples:["electricConstant"]},vacuumImpedance:{description:"Characteristic impedance of vacuum",examples:["vacuumImpedance"]},coulomb:{description:"Coulomb's constant",examples:["coulomb"]},elementaryCharge:{description:"Elementary charge",examples:["elementaryCharge"]},bohrMagneton:{description:"Bohr magneton",examples:["bohrMagneton"]},conductanceQuantum:{description:"Conductance quantum",examples:["conductanceQuantum"]},inverseConductanceQuantum:{description:"Inverse conductance quantum",examples:["inverseConductanceQuantum"]},magneticFluxQuantum:{description:"Magnetic flux quantum",examples:["magneticFluxQuantum"]},nuclearMagneton:{description:"Nuclear magneton",examples:["nuclearMagneton"]},klitzing:{description:"Von Klitzing constant",examples:["klitzing"]},bohrRadius:{description:"Bohr radius",examples:["bohrRadius"]},classicalElectronRadius:{description:"Classical electron radius",examples:["classicalElectronRadius"]},electronMass:{description:"Electron mass",examples:["electronMass"]},fermiCoupling:{description:"Fermi coupling constant",examples:["fermiCoupling"]},fineStructure:{description:"Fine-structure constant",examples:["fineStructure"]},hartreeEnergy:{description:"Hartree energy",examples:["hartreeEnergy"]},protonMass:{description:"Proton mass",examples:["protonMass"]},deuteronMass:{description:"Deuteron Mass",examples:["deuteronMass"]},neutronMass:{description:"Neutron mass",examples:["neutronMass"]},quantumOfCirculation:{description:"Quantum of circulation",examples:["quantumOfCirculation"]},rydberg:{description:"Rydberg constant",examples:["rydberg"]},thomsonCrossSection:{description:"Thomson cross section",examples:["thomsonCrossSection"]},weakMixingAngle:{description:"Weak mixing angle",examples:["weakMixingAngle"]},efimovFactor:{description:"Efimov factor",examples:["efimovFactor"]},atomicMass:{description:"Atomic mass constant",examples:["atomicMass"]},avogadro:{description:"Avogadro's number",examples:["avogadro"]},boltzmann:{description:"Boltzmann constant",examples:["boltzmann"]},faraday:{description:"Faraday constant",examples:["faraday"]},firstRadiation:{description:"First radiation constant",examples:["firstRadiation"]},loschmidt:{description:"Loschmidt constant at T=273.15 K and p=101.325 kPa",examples:["loschmidt"]},gasConstant:{description:"Gas constant",examples:["gasConstant"]},molarPlanckConstant:{description:"Molar Planck constant",examples:["molarPlanckConstant"]},molarVolume:{description:"Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa",examples:["molarVolume"]},sackurTetrode:{description:"Sackur-Tetrode constant at T=1 K and p=101.325 kPa",examples:["sackurTetrode"]},secondRadiation:{description:"Second radiation constant",examples:["secondRadiation"]},stefanBoltzmann:{description:"Stefan-Boltzmann constant",examples:["stefanBoltzmann"]},wienDisplacement:{description:"Wien displacement law constant",examples:["wienDisplacement"]},molarMass:{description:"Molar mass constant",examples:["molarMass"]},molarMassC12:{description:"Molar mass constant of carbon-12",examples:["molarMassC12"]},gravity:{description:"Standard acceleration of gravity (standard acceleration of free-fall on Earth)",examples:["gravity"]},planckLength:{description:"Planck length",examples:["planckLength"]},planckMass:{description:"Planck mass",examples:["planckMass"]},planckTime:{description:"Planck time",examples:["planckTime"]},planckCharge:{description:"Planck charge",examples:["planckCharge"]},planckTemperature:{description:"Planck temperature",examples:["planckTemperature"]},derivative:{name:"derivative",category:"Algebra",syntax:["derivative(expr, variable)","derivative(expr, variable, {simplify: boolean})"],description:"Takes the derivative of an expression expressed in parser Nodes. The derivative will be taken over the supplied variable in the second parameter. If there are multiple variables in the expression, it will return a partial derivative.",examples:['derivative("2x^3", "x")','derivative("2x^3", "x", {simplify: false})','derivative("2x^2 + 3x + 4", "x")','derivative("sin(2x)", "x")','f = parse("x^2 + x")','x = parse("x")',"df = derivative(f, x)","df.evaluate({x: 3})"],seealso:["simplify","parse","evaluate"]},lsolve:{name:"lsolve",category:"Algebra",syntax:["x=lsolve(L, b)"],description:"Finds one solution of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lsolve(a, b)"],seealso:["lsolveAll","lup","lusolve","usolve","matrix","sparse"]},lsolveAll:{name:"lsolveAll",category:"Algebra",syntax:["x=lsolveAll(L, b)"],description:"Finds all solutions of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lsolve(a, b)"],seealso:["lsolve","lup","lusolve","usolve","matrix","sparse"]},lup:{name:"lup",category:"Algebra",syntax:["lup(m)"],description:"Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U",examples:["lup([[2, 1], [1, 4]])","lup(matrix([[2, 1], [1, 4]]))","lup(sparse([[2, 1], [1, 4]]))"],seealso:["lusolve","lsolve","usolve","matrix","sparse","slu","qr"]},lusolve:{name:"lusolve",category:"Algebra",syntax:["x=lusolve(A, b)","x=lusolve(lu, b)"],description:"Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lusolve(a, b)"],seealso:["lup","slu","lsolve","usolve","matrix","sparse"]},leafCount:{name:"leafCount",category:"Algebra",syntax:["leafCount(expr)"],description:"Computes the number of leaves in the parse tree of the given expression",examples:['leafCount("e^(i*pi)-1")','leafCount(parse("{a: 22/7, b: 10^(1/2)}"))'],seealso:["simplify"]},polynomialRoot:{name:"polynomialRoot",category:"Algebra",syntax:["x=polynomialRoot(-6, 3)","x=polynomialRoot(4, -4, 1)","x=polynomialRoot(-8, 12, -6, 1)"],description:"Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.",examples:["a = polynomialRoot(-6, 11, -6, 1)"],seealso:["cbrt","sqrt"]},resolve:{name:"resolve",category:"Algebra",syntax:["resolve(node, scope)"],description:"Recursively substitute variables in an expression tree.",examples:['resolve(parse("1 + x"), { x: 7 })','resolve(parse("size(text)"), { text: "Hello World" })','resolve(parse("x + y"), { x: parse("3z") })','resolve(parse("3x"), { x: parse("y+z"), z: parse("w^y") })'],seealso:["simplify","evaluate"],mayThrow:["ReferenceError"]},simplify:{name:"simplify",category:"Algebra",syntax:["simplify(expr)","simplify(expr, rules)"],description:"Simplify an expression tree.",examples:['simplify("3 + 2 / 4")','simplify("2x + x")','f = parse("x * (x + 2 + x)")',"simplified = simplify(f)","simplified.evaluate({x: 2})"],seealso:["simplifyCore","derivative","evaluate","parse","rationalize","resolve"]},simplifyConstant:{name:"simplifyConstant",category:"Algebra",syntax:["simplifyConstant(expr)","simplifyConstant(expr, options)"],description:"Replace constant subexpressions of node with their values.",examples:['simplifyConstant("(3-3)*x")','simplifyConstant(parse("z-cos(tau/8)"))'],seealso:["simplify","simplifyCore","evaluate"]},simplifyCore:{name:"simplifyCore",category:"Algebra",syntax:["simplifyCore(node)"],description:"Perform simple one-pass simplifications on an expression tree.",examples:['simplifyCore(parse("0*x"))','simplifyCore(parse("(x+0)*2"))'],seealso:["simplify","simplifyConstant","evaluate"]},symbolicEqual:{name:"symbolicEqual",category:"Algebra",syntax:["symbolicEqual(expr1, expr2)","symbolicEqual(expr1, expr2, options)"],description:"Returns true if the difference of the expressions simplifies to 0",examples:['symbolicEqual("x*y","y*x")','symbolicEqual("abs(x^2)", "x^2")','symbolicEqual("abs(x)", "x", {context: {abs: {trivial: true}}})'],seealso:["simplify","evaluate"]},rationalize:{name:"rationalize",category:"Algebra",syntax:["rationalize(expr)","rationalize(expr, scope)","rationalize(expr, scope, detailed)"],description:"Transform a rationalizable expression in a rational fraction. If rational fraction is one variable polynomial then converts the numerator and denominator in canonical form, with decreasing exponents, returning the coefficients of numerator.",examples:['rationalize("2x/y - y/(x+1)")','rationalize("2x/y - y/(x+1)", true)'],seealso:["simplify"]},slu:{name:"slu",category:"Algebra",syntax:["slu(A, order, threshold)"],description:"Calculate the Matrix LU decomposition with full pivoting. Matrix A is decomposed in two matrices (L, U) and two permutation vectors (pinv, q) where P * A * Q = L * U",examples:["slu(sparse([4.5, 0, 3.2, 0; 3.1, 2.9, 0, 0.9; 0, 1.7, 3, 0; 3.5, 0.4, 0, 1]), 1, 0.001)"],seealso:["lusolve","lsolve","usolve","matrix","sparse","lup","qr"]},usolve:{name:"usolve",category:"Algebra",syntax:["x=usolve(U, b)"],description:"Finds one solution of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.",examples:["x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])"],seealso:["usolveAll","lup","lusolve","lsolve","matrix","sparse"]},usolveAll:{name:"usolveAll",category:"Algebra",syntax:["x=usolve(U, b)"],description:"Finds all solutions of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.",examples:["x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])"],seealso:["usolve","lup","lusolve","lsolve","matrix","sparse"]},qr:{name:"qr",category:"Algebra",syntax:["qr(A)"],description:"Calculates the Matrix QR decomposition. Matrix `A` is decomposed in two matrices (`Q`, `R`) where `Q` is an orthogonal matrix and `R` is an upper triangular matrix.",examples:["qr([[1, -1, 4], [1, 4, -2], [1, 4, 2], [1, -1, 0]])"],seealso:["lup","slu","matrix"]},abs:{name:"abs",category:"Arithmetic",syntax:["abs(x)"],description:"Compute the absolute value.",examples:["abs(3.5)","abs(-4.2)"],seealso:["sign"]},add:{name:"add",category:"Operators",syntax:["x + y","add(x, y)"],description:"Add two values.",examples:["a = 2.1 + 3.6","a - 3.6","3 + 2i","3 cm + 2 inch",'"2.3" + "4"'],seealso:["subtract"]},cbrt:{name:"cbrt",category:"Arithmetic",syntax:["cbrt(x)","cbrt(x, allRoots)"],description:"Compute the cubic root value. If x = y * y * y, then y is the cubic root of x. When `x` is a number or complex number, an optional second argument `allRoots` can be provided to return all three cubic roots. If not provided, the principal root is returned",examples:["cbrt(64)","cube(4)","cbrt(-8)","cbrt(2 + 3i)","cbrt(8i)","cbrt(8i, true)","cbrt(27 m^3)"],seealso:["square","sqrt","cube","multiply"]},ceil:{name:"ceil",category:"Arithmetic",syntax:["ceil(x)"],description:"Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.",examples:["ceil(3.2)","ceil(3.8)","ceil(-4.2)"],seealso:["floor","fix","round"]},cube:{name:"cube",category:"Arithmetic",syntax:["cube(x)"],description:"Compute the cube of a value. The cube of x is x * x * x.",examples:["cube(2)","2^3","2 * 2 * 2"],seealso:["multiply","square","pow"]},divide:{name:"divide",category:"Operators",syntax:["x / y","divide(x, y)"],description:"Divide two values.",examples:["a = 2 / 3","a * 3","4.5 / 2","3 + 4 / 2","(3 + 4) / 2","18 km / 4.5"],seealso:["multiply"]},dotDivide:{name:"dotDivide",category:"Operators",syntax:["x ./ y","dotDivide(x, y)"],description:"Divide two values element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","b = [2, 1, 1; 3, 2, 5]","a ./ b"],seealso:["multiply","dotMultiply","divide"]},dotMultiply:{name:"dotMultiply",category:"Operators",syntax:["x .* y","dotMultiply(x, y)"],description:"Multiply two values element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","b = [2, 1, 1; 3, 2, 5]","a .* b"],seealso:["multiply","divide","dotDivide"]},dotPow:{name:"dotPow",category:"Operators",syntax:["x .^ y","dotPow(x, y)"],description:"Calculates the power of x to y element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","a .^ 2"],seealso:["pow"]},exp:{name:"exp",category:"Arithmetic",syntax:["exp(x)"],description:"Calculate the exponent of a value.",examples:["exp(1.3)","e ^ 1.3","log(exp(1.3))","x = 2.4","(exp(i*x) == cos(x) + i*sin(x)) # Euler's formula"],seealso:["expm","expm1","pow","log"]},expm:{name:"expm",category:"Arithmetic",syntax:["exp(x)"],description:"Compute the matrix exponential, expm(A) = e^A. The matrix must be square. Not to be confused with exp(a), which performs element-wise exponentiation.",examples:["expm([[0,2],[0,0]])"],seealso:["exp"]},expm1:{name:"expm1",category:"Arithmetic",syntax:["expm1(x)"],description:"Calculate the value of subtracting 1 from the exponential value.",examples:["expm1(2)","pow(e, 2) - 1","log(expm1(2) + 1)"],seealso:["exp","pow","log"]},fix:{name:"fix",category:"Arithmetic",syntax:["fix(x)"],description:"Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.",examples:["fix(3.2)","fix(3.8)","fix(-4.2)","fix(-4.8)"],seealso:["ceil","floor","round"]},floor:{name:"floor",category:"Arithmetic",syntax:["floor(x)"],description:"Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.",examples:["floor(3.2)","floor(3.8)","floor(-4.2)"],seealso:["ceil","fix","round"]},gcd:{name:"gcd",category:"Arithmetic",syntax:["gcd(a, b)","gcd(a, b, c, ...)"],description:"Compute the greatest common divisor.",examples:["gcd(8, 12)","gcd(-4, 6)","gcd(25, 15, -10)"],seealso:["lcm","xgcd"]},hypot:{name:"hypot",category:"Arithmetic",syntax:["hypot(a, b, c, ...)","hypot([a, b, c, ...])"],description:"Calculate the hypotenuse of a list with values.",examples:["hypot(3, 4)","sqrt(3^2 + 4^2)","hypot(-2)","hypot([3, 4, 5])"],seealso:["abs","norm"]},lcm:{name:"lcm",category:"Arithmetic",syntax:["lcm(x, y)"],description:"Compute the least common multiple.",examples:["lcm(4, 6)","lcm(6, 21)","lcm(6, 21, 5)"],seealso:["gcd"]},log:{name:"log",category:"Arithmetic",syntax:["log(x)","log(x, base)"],description:"Compute the logarithm of a value. If no base is provided, the natural logarithm of x is calculated. If base if provided, the logarithm is calculated for the specified base. log(x, base) is defined as log(x) / log(base).",examples:["log(3.5)","a = log(2.4)","exp(a)","10 ^ 4","log(10000, 10)","log(10000) / log(10)","b = log(1024, 2)","2 ^ b"],seealso:["exp","log1p","log2","log10"]},log2:{name:"log2",category:"Arithmetic",syntax:["log2(x)"],description:"Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.",examples:["log2(0.03125)","log2(16)","log2(16) / log2(2)","pow(2, 4)"],seealso:["exp","log1p","log","log10"]},log1p:{name:"log1p",category:"Arithmetic",syntax:["log1p(x)","log1p(x, base)"],description:"Calculate the logarithm of a `value+1`",examples:["log1p(2.5)","exp(log1p(1.4))","pow(10, 4)","log1p(9999, 10)","log1p(9999) / log(10)"],seealso:["exp","log","log2","log10"]},log10:{name:"log10",category:"Arithmetic",syntax:["log10(x)"],description:"Compute the 10-base logarithm of a value.",examples:["log10(0.00001)","log10(10000)","10 ^ 4","log(10000) / log(10)","log(10000, 10)"],seealso:["exp","log"]},mod:{name:"mod",category:"Operators",syntax:["x % y","x mod y","mod(x, y)"],description:"Calculates the modulus, the remainder of an integer division.",examples:["7 % 3","11 % 2","10 mod 4","isOdd(x) = x % 2","isOdd(2)","isOdd(3)"],seealso:["divide"]},multiply:{name:"multiply",category:"Operators",syntax:["x * y","multiply(x, y)"],description:"multiply two values.",examples:["a = 2.1 * 3.4","a / 3.4","2 * 3 + 4","2 * (3 + 4)","3 * 2.1 km"],seealso:["divide"]},norm:{name:"norm",category:"Arithmetic",syntax:["norm(x)","norm(x, p)"],description:"Calculate the norm of a number, vector or matrix.",examples:["abs(-3.5)","norm(-3.5)","norm(3 - 4i)","norm([1, 2, -3], Infinity)","norm([1, 2, -3], -Infinity)","norm([3, 4], 2)","norm([[1, 2], [3, 4]], 1)",'norm([[1, 2], [3, 4]], "inf")','norm([[1, 2], [3, 4]], "fro")']},nthRoot:{name:"nthRoot",category:"Arithmetic",syntax:["nthRoot(a)","nthRoot(a, root)"],description:'Calculate the nth root of a value. The principal nth root of a positive real number A, is the positive real solution of the equation "x^root = A".',examples:["4 ^ 3","nthRoot(64, 3)","nthRoot(9, 2)","sqrt(9)"],seealso:["nthRoots","pow","sqrt"]},nthRoots:{name:"nthRoots",category:"Arithmetic",syntax:["nthRoots(A)","nthRoots(A, root)"],description:'Calculate the nth roots of a value. An nth root of a positive real number A, is a positive real solution of the equation "x^root = A". This function returns an array of complex values.',examples:["nthRoots(1)","nthRoots(1, 3)"],seealso:["sqrt","pow","nthRoot"]},pow:{name:"pow",category:"Operators",syntax:["x ^ y","pow(x, y)"],description:"Calculates the power of x to y, x^y.",examples:["2^3","2*2*2","1 + e ^ (pi * i)","pow([[1, 2], [4, 3]], 2)","pow([[1, 2], [4, 3]], -1)"],seealso:["multiply","nthRoot","nthRoots","sqrt"]},round:{name:"round",category:"Arithmetic",syntax:["round(x)","round(x, n)","round(unit, valuelessUnit)","round(unit, n, valuelessUnit)"],description:"round a value towards the nearest integer.If x is complex, both real and imaginary part are rounded towards the nearest integer. When n is specified, the value is rounded to n decimals.",examples:["round(3.2)","round(3.8)","round(-4.2)","round(-4.8)","round(pi, 3)","round(123.45678, 2)","round(3.241cm, 2, cm)","round([3.2, 3.8, -4.7])"],seealso:["ceil","floor","fix"]},sign:{name:"sign",category:"Arithmetic",syntax:["sign(x)"],description:"Compute the sign of a value. The sign of a value x is 1 when x>1, -1 when x<0, and 0 when x=0.",examples:["sign(3.5)","sign(-4.2)","sign(0)"],seealso:["abs"]},sqrt:{name:"sqrt",category:"Arithmetic",syntax:["sqrt(x)"],description:"Compute the square root value. If x = y * y, then y is the square root of x.",examples:["sqrt(25)","5 * 5","sqrt(-1)"],seealso:["square","sqrtm","multiply","nthRoot","nthRoots","pow"]},sqrtm:{name:"sqrtm",category:"Arithmetic",syntax:["sqrtm(x)"],description:"Calculate the principal square root of a square matrix. The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.",examples:["sqrtm([[33, 24], [48, 57]])"],seealso:["sqrt","abs","square","multiply"]},square:{name:"square",category:"Arithmetic",syntax:["square(x)"],description:"Compute the square of a value. The square of x is x * x.",examples:["square(3)","sqrt(9)","3^2","3 * 3"],seealso:["multiply","pow","sqrt","cube"]},subtract:{name:"subtract",category:"Operators",syntax:["x - y","subtract(x, y)"],description:"subtract two values.",examples:["a = 5.3 - 2","a + 2","2/3 - 1/6","2 * 3 - 3","2.1 km - 500m"],seealso:["add"]},unaryMinus:{name:"unaryMinus",category:"Operators",syntax:["-x","unaryMinus(x)"],description:"Inverse the sign of a value. Converts booleans and strings to numbers.",examples:["-4.5","-(-5.6)",'-"22"'],seealso:["add","subtract","unaryPlus"]},unaryPlus:{name:"unaryPlus",category:"Operators",syntax:["+x","unaryPlus(x)"],description:"Converts booleans and strings to numbers.",examples:["+true",'+"2"'],seealso:["add","subtract","unaryMinus"]},xgcd:{name:"xgcd",category:"Arithmetic",syntax:["xgcd(a, b)"],description:"Calculate the extended greatest common divisor for two values. The result is an array [d, x, y] with 3 entries, where d is the greatest common divisor, and d = x * a + y * b.",examples:["xgcd(8, 12)","gcd(8, 12)","xgcd(36163, 21199)"],seealso:["gcd","lcm"]},invmod:{name:"invmod",category:"Arithmetic",syntax:["invmod(a, b)"],description:"Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)",examples:["invmod(8, 12)","invmod(7, 13)","invmod(15151, 15122)"],seealso:["gcd","xgcd"]},bitAnd:{name:"bitAnd",category:"Bitwise",syntax:["x & y","bitAnd(x, y)"],description:"Bitwise AND operation. Performs the logical AND operation on each pair of the corresponding bits of the two given values by multiplying them. If both bits in the compared position are 1, the bit in the resulting binary representation is 1, otherwise, the result is 0",examples:["5 & 3","bitAnd(53, 131)","[1, 12, 31] & 42"],seealso:["bitNot","bitOr","bitXor","leftShift","rightArithShift","rightLogShift"]},bitNot:{name:"bitNot",category:"Bitwise",syntax:["~x","bitNot(x)"],description:"Bitwise NOT operation. Performs a logical negation on each bit of the given value. Bits that are 0 become 1, and those that are 1 become 0.",examples:["~1","~2","bitNot([2, -3, 4])"],seealso:["bitAnd","bitOr","bitXor","leftShift","rightArithShift","rightLogShift"]},bitOr:{name:"bitOr",category:"Bitwise",syntax:["x | y","bitOr(x, y)"],description:"Bitwise OR operation. Performs the logical inclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if the first bit is 1 or the second bit is 1 or both bits are 1, otherwise, the result is 0.",examples:["5 | 3","bitOr([1, 2, 3], 4)"],seealso:["bitAnd","bitNot","bitXor","leftShift","rightArithShift","rightLogShift"]},bitXor:{name:"bitXor",category:"Bitwise",syntax:["bitXor(x, y)"],description:"Bitwise XOR operation, exclusive OR. Performs the logical exclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if only the first bit is 1 or only the second bit is 1, but will be 0 if both are 0 or both are 1.",examples:["bitOr(1, 2)","bitXor([2, 3, 4], 4)"],seealso:["bitAnd","bitNot","bitOr","leftShift","rightArithShift","rightLogShift"]},leftShift:{name:"leftShift",category:"Bitwise",syntax:["x << y","leftShift(x, y)"],description:"Bitwise left logical shift of a value x by y number of bits.",examples:["4 << 1","8 >> 1"],seealso:["bitAnd","bitNot","bitOr","bitXor","rightArithShift","rightLogShift"]},rightArithShift:{name:"rightArithShift",category:"Bitwise",syntax:["x >> y","rightArithShift(x, y)"],description:"Bitwise right arithmetic shift of a value x by y number of bits.",examples:["8 >> 1","4 << 1","-12 >> 2"],seealso:["bitAnd","bitNot","bitOr","bitXor","leftShift","rightLogShift"]},rightLogShift:{name:"rightLogShift",category:"Bitwise",syntax:["x >>> y","rightLogShift(x, y)"],description:"Bitwise right logical shift of a value x by y number of bits.",examples:["8 >>> 1","4 << 1","-12 >>> 2"],seealso:["bitAnd","bitNot","bitOr","bitXor","leftShift","rightArithShift"]},bellNumbers:{name:"bellNumbers",category:"Combinatorics",syntax:["bellNumbers(n)"],description:"The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. `bellNumbers` only takes integer arguments. The following condition must be enforced: n >= 0.",examples:["bellNumbers(3)","bellNumbers(8)"],seealso:["stirlingS2"]},catalan:{name:"catalan",category:"Combinatorics",syntax:["catalan(n)"],description:"The Catalan Numbers enumerate combinatorial structures of many different types. catalan only takes integer arguments. The following condition must be enforced: n >= 0.",examples:["catalan(3)","catalan(8)"],seealso:["bellNumbers"]},composition:{name:"composition",category:"Combinatorics",syntax:["composition(n, k)"],description:"The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.",examples:["composition(5, 3)"],seealso:["combinations"]},stirlingS2:{name:"stirlingS2",category:"Combinatorics",syntax:["stirlingS2(n, k)"],description:"he Stirling numbers of the second kind, counts the number of ways to partition a set of n labelled objects into k nonempty unlabelled subsets. `stirlingS2` only takes integer arguments. The following condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = 1.",examples:["stirlingS2(5, 3)"],seealso:["bellNumbers"]},config:{name:"config",category:"Core",syntax:["config()","config(options)"],description:"Get configuration or change configuration.",examples:["config()","1/3 + 1/4",'config({number: "Fraction"})',"1/3 + 1/4"],seealso:[]},import:{name:"import",category:"Core",syntax:["import(functions)","import(functions, options)"],description:"Import functions or constants from an object.",examples:["import({myFn: f(x)=x^2, myConstant: 32 })","myFn(2)","myConstant"],seealso:[]},typed:{name:"typed",category:"Core",syntax:["typed(signatures)","typed(name, signatures)"],description:"Create a typed function.",examples:['double = typed({ "number": f(x)=x+x, "string": f(x)=concat(x,x) })',"double(2)",'double("hello")'],seealso:[]},arg:{name:"arg",category:"Complex",syntax:["arg(x)"],description:"Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).",examples:["arg(2 + 2i)","atan2(3, 2)","arg(2 + 3i)"],seealso:["re","im","conj","abs"]},conj:{name:"conj",category:"Complex",syntax:["conj(x)"],description:"Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.",examples:["conj(2 + 3i)","conj(2 - 3i)","conj(-5.2i)"],seealso:["re","im","abs","arg"]},re:{name:"re",category:"Complex",syntax:["re(x)"],description:"Get the real part of a complex number.",examples:["re(2 + 3i)","im(2 + 3i)","re(-5.2i)","re(2.4)"],seealso:["im","conj","abs","arg"]},im:{name:"im",category:"Complex",syntax:["im(x)"],description:"Get the imaginary part of a complex number.",examples:["im(2 + 3i)","re(2 + 3i)","im(-5.2i)","im(2.4)"],seealso:["re","conj","abs","arg"]},evaluate:{name:"evaluate",category:"Expression",syntax:["evaluate(expression)","evaluate(expression, scope)","evaluate([expr1, expr2, expr3, ...])","evaluate([expr1, expr2, expr3, ...], scope)"],description:"Evaluate an expression or an array with expressions.",examples:['evaluate("2 + 3")','evaluate("sqrt(16)")','evaluate("2 inch to cm")','evaluate("sin(x * pi)", { "x": 1/2 })','evaluate(["width=2", "height=4","width*height"])'],seealso:[]},help:{name:"help",category:"Expression",syntax:["help(object)","help(string)"],description:"Display documentation on a function or data type.",examples:["help(sqrt)",'help("complex")'],seealso:[]},distance:{name:"distance",category:"Geometry",syntax:["distance([x1, y1], [x2, y2])","distance([[x1, y1], [x2, y2]])"],description:"Calculates the Euclidean distance between two points.",examples:["distance([0,0], [4,4])","distance([[0,0], [4,4]])"],seealso:[]},intersect:{name:"intersect",category:"Geometry",syntax:["intersect(expr1, expr2, expr3, expr4)","intersect(expr1, expr2, expr3)"],description:"Computes the intersection point of lines and/or planes.",examples:["intersect([0, 0], [10, 10], [10, 0], [0, 10])","intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6])"],seealso:[]},and:{name:"and",category:"Logical",syntax:["x and y","and(x, y)"],description:"Logical and. Test whether two values are both defined with a nonzero/nonempty value.",examples:["true and false","true and true","2 and 4"],seealso:["not","or","xor"]},not:{name:"not",category:"Logical",syntax:["not x","not(x)"],description:"Logical not. Flips the boolean value of given argument.",examples:["not true","not false","not 2","not 0"],seealso:["and","or","xor"]},or:{name:"or",category:"Logical",syntax:["x or y","or(x, y)"],description:"Logical or. Test if at least one value is defined with a nonzero/nonempty value.",examples:["true or false","false or false","0 or 4"],seealso:["not","and","xor"]},xor:{name:"xor",category:"Logical",syntax:["x xor y","xor(x, y)"],description:"Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.",examples:["true xor false","false xor false","true xor true","0 xor 4"],seealso:["not","and","or"]},concat:{name:"concat",category:"Matrix",syntax:["concat(A, B, C, ...)","concat(A, B, C, ..., dim)"],description:"Concatenate matrices. By default, the matrices are concatenated by the last dimension. The dimension on which to concatenate can be provided as last argument.",examples:["A = [1, 2; 5, 6]","B = [3, 4; 7, 8]","concat(A, B)","concat(A, B, 1)","concat(A, B, 2)"],seealso:["det","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},count:{name:"count",category:"Matrix",syntax:["count(x)"],description:"Count the number of elements of a matrix, array or string.",examples:["a = [1, 2; 3, 4; 5, 6]","count(a)","size(a)",'count("hello world")'],seealso:["size"]},cross:{name:"cross",category:"Matrix",syntax:["cross(A, B)"],description:"Calculate the cross product for two vectors in three dimensional space.",examples:["cross([1, 1, 0], [0, 1, 1])","cross([3, -3, 1], [4, 9, 2])","cross([2, 3, 4], [5, 6, 7])"],seealso:["multiply","dot"]},column:{name:"column",category:"Matrix",syntax:["column(x, index)"],description:"Return a column from a matrix or array.",examples:["A = [[1, 2], [3, 4]]","column(A, 1)","column(A, 2)"],seealso:["row","matrixFromColumns"]},ctranspose:{name:"ctranspose",category:"Matrix",syntax:["x'","ctranspose(x)"],description:"Complex Conjugate and Transpose a matrix",examples:["a = [1, 2, 3; 4, 5, 6]","a'","ctranspose(a)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","zeros"]},det:{name:"det",category:"Matrix",syntax:["det(x)"],description:"Calculate the determinant of a matrix",examples:["det([1, 2; 3, 4])","det([-2, 2, 3; -1, 1, 3; 2, 0, -1])"],seealso:["concat","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},diag:{name:"diag",category:"Matrix",syntax:["diag(x)","diag(x, k)"],description:"Create a diagonal matrix or retrieve the diagonal of a matrix. When x is a vector, a matrix with the vector values on the diagonal will be returned. When x is a matrix, a vector with the diagonal values of the matrix is returned. When k is provided, the k-th diagonal will be filled in or retrieved, if k is positive, the values are placed on the super diagonal. When k is negative, the values are placed on the sub diagonal.",examples:["diag(1:3)","diag(1:3, 1)","a = [1, 2, 3; 4, 5, 6; 7, 8, 9]","diag(a)"],seealso:["concat","det","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},diff:{name:"diff",category:"Matrix",syntax:["diff(arr)","diff(arr, dim)"],description:["Create a new matrix or array with the difference of the passed matrix or array.","Dim parameter is optional and used to indicate the dimension of the array/matrix to apply the difference","If no dimension parameter is passed it is assumed as dimension 0","Dimension is zero-based in javascript and one-based in the parser","Arrays must be 'rectangular' meaning arrays like [1, 2]","If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays"],examples:["A = [1, 2, 4, 7, 0]","diff(A)","diff(A, 1)","B = [[1, 2], [3, 4]]","diff(B)","diff(B, 1)","diff(B, 2)","diff(B, bignumber(2))","diff([[1, 2], matrix([3, 4])], 2)"],seealso:["subtract","partitionSelect"]},dot:{name:"dot",category:"Matrix",syntax:["dot(A, B)","A * B"],description:"Calculate the dot product of two vectors. The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn",examples:["dot([2, 4, 1], [2, 2, 3])","[2, 4, 1] * [2, 2, 3]"],seealso:["multiply","cross"]},getMatrixDataType:{name:"getMatrixDataType",category:"Matrix",syntax:["getMatrixDataType(x)"],description:'Find the data type of all elements in a matrix or array, for example "number" if all items are a number and "Complex" if all values are complex numbers. If a matrix contains more than one data type, it will return "mixed".',examples:["getMatrixDataType([1, 2, 3])","getMatrixDataType([[5 cm], [2 inch]])",'getMatrixDataType([1, "text"])',"getMatrixDataType([1, bignumber(4)])"],seealso:["matrix","sparse","typeOf"]},identity:{name:"identity",category:"Matrix",syntax:["identity(n)","identity(m, n)","identity([m, n])"],description:"Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.",examples:["identity(3)","identity(3, 5)","a = [1, 2, 3; 4, 5, 6]","identity(size(a))"],seealso:["concat","det","diag","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},filter:{name:"filter",category:"Matrix",syntax:["filter(x, test)"],description:"Filter items in a matrix.",examples:["isPositive(x) = x > 0","filter([6, -2, -1, 4, 3], isPositive)","filter([6, -2, 0, 1, 0], x != 0)"],seealso:["sort","map","forEach"]},flatten:{name:"flatten",category:"Matrix",syntax:["flatten(x)"],description:"Flatten a multi dimensional matrix into a single dimensional matrix.",examples:["a = [1, 2, 3; 4, 5, 6]","size(a)","b = flatten(a)","size(b)"],seealso:["concat","resize","size","squeeze"]},forEach:{name:"forEach",category:"Matrix",syntax:["forEach(x, callback)"],description:"Iterates over all elements of a matrix/array, and executes the given callback function.",examples:["numberOfPets = {}","addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;",'forEach(["Dog","Cat","Cat"], addPet)',"numberOfPets"],seealso:["map","sort","filter"]},inv:{name:"inv",category:"Matrix",syntax:["inv(x)"],description:"Calculate the inverse of a matrix",examples:["inv([1, 2; 3, 4])","inv(4)","1 / 4"],seealso:["concat","det","diag","identity","ones","range","size","squeeze","subset","trace","transpose","zeros"]},pinv:{name:"pinv",category:"Matrix",syntax:["pinv(x)"],description:"Calculate the Moore–Penrose inverse of a matrix",examples:["pinv([1, 2; 3, 4])","pinv([[1, 0], [0, 1], [0, 1]])","pinv(4)"],seealso:["inv"]},eigs:{name:"eigs",category:"Matrix",syntax:["eigs(x)"],description:"Calculate the eigenvalues and optionally eigenvectors of a square matrix",examples:["eigs([[5, 2.3], [2.3, 1]])","eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })"],seealso:["inv"]},kron:{name:"kron",category:"Matrix",syntax:["kron(x, y)"],description:"Calculates the Kronecker product of 2 matrices or vectors.",examples:["kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])","kron([1,1], [2,3,4])"],seealso:["multiply","dot","cross"]},matrixFromFunction:{name:"matrixFromFunction",category:"Matrix",syntax:["matrixFromFunction(size, fn)","matrixFromFunction(size, fn, format)","matrixFromFunction(size, fn, format, datatype)","matrixFromFunction(size, format, fn)","matrixFromFunction(size, format, datatype, fn)"],description:"Create a matrix by evaluating a generating function at each index.",examples:["f(I) = I[1] - I[2]","matrixFromFunction([3,3], f)","g(I) = I[1] - I[2] == 1 ? 4 : 0",'matrixFromFunction([100, 100], "sparse", g)',"matrixFromFunction([5], random)"],seealso:["matrix","matrixFromRows","matrixFromColumns","zeros"]},matrixFromRows:{name:"matrixFromRows",category:"Matrix",syntax:["matrixFromRows(...arr)","matrixFromRows(row1, row2)","matrixFromRows(row1, row2, row3)"],description:"Create a dense matrix from vectors as individual rows.",examples:["matrixFromRows([1, 2, 3], [[4],[5],[6]])"],seealso:["matrix","matrixFromColumns","matrixFromFunction","zeros"]},matrixFromColumns:{name:"matrixFromColumns",category:"Matrix",syntax:["matrixFromColumns(...arr)","matrixFromColumns(row1, row2)","matrixFromColumns(row1, row2, row3)"],description:"Create a dense matrix from vectors as individual columns.",examples:["matrixFromColumns([1, 2, 3], [[4],[5],[6]])"],seealso:["matrix","matrixFromRows","matrixFromFunction","zeros"]},map:{name:"map",category:"Matrix",syntax:["map(x, callback)","map(x, y, ..., callback)"],description:"Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array or the matrices/arrays.",examples:["map([1, 2, 3], square)","map([1, 2], [3, 4], f(a,b) = a + b)"],seealso:["filter","forEach"]},ones:{name:"ones",category:"Matrix",syntax:["ones(m)","ones(m, n)","ones(m, n, p, ...)","ones([m])","ones([m, n])","ones([m, n, p, ...])"],description:"Create a matrix containing ones.",examples:["ones(3)","ones(3, 5)","ones([2,3]) * 4.5","a = [1, 2, 3; 4, 5, 6]","ones(size(a))"],seealso:["concat","det","diag","identity","inv","range","size","squeeze","subset","trace","transpose","zeros"]},partitionSelect:{name:"partitionSelect",category:"Matrix",syntax:["partitionSelect(x, k)","partitionSelect(x, k, compare)"],description:"Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.",examples:["partitionSelect([5, 10, 1], 2)",'partitionSelect(["C", "B", "A", "D"], 1, compareText)',"arr = [5, 2, 1]","partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]","arr","partitionSelect(arr, 1, 'desc') # returns 2, arr is now: [5, 2, 1]","arr"],seealso:["sort"]},range:{name:"range",category:"Type",syntax:["start:end","start:step:end","range(start, end)","range(start, end, step)","range(string)"],description:"Create a range. Lower bound of the range is included, upper bound is excluded.",examples:["1:5","3:-1:-3","range(3, 7)","range(0, 12, 2)",'range("4:10")',"range(1m, 1m, 3m)","a = [1, 2, 3, 4; 5, 6, 7, 8]","a[1:2, 1:2]"],seealso:["concat","det","diag","identity","inv","ones","size","squeeze","subset","trace","transpose","zeros"]},resize:{name:"resize",category:"Matrix",syntax:["resize(x, size)","resize(x, size, defaultValue)"],description:"Resize a matrix.",examples:["resize([1,2,3,4,5], [3])","resize([1,2,3], [5])","resize([1,2,3], [5], -1)","resize(2, [2, 3])",'resize("hello", [8], "!")'],seealso:["size","subset","squeeze","reshape"]},reshape:{name:"reshape",category:"Matrix",syntax:["reshape(x, sizes)"],description:"Reshape a multi dimensional array to fit the specified dimensions.",examples:["reshape([1, 2, 3, 4, 5, 6], [2, 3])","reshape([[1, 2], [3, 4]], [1, 4])","reshape([[1, 2], [3, 4]], [4])","reshape([1, 2, 3, 4], [-1, 2])"],seealso:["size","squeeze","resize"]},rotate:{name:"rotate",category:"Matrix",syntax:["rotate(w, theta)","rotate(w, theta, v)"],description:"Returns a 2-D rotation matrix (2x2) for a given angle (in radians). Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.",examples:["rotate([1, 0], pi / 2)",'rotate(matrix([1, 0]), unit("35deg"))','rotate([1, 0, 0], unit("90deg"), [0, 0, 1])','rotate(matrix([1, 0, 0]), unit("90deg"), matrix([0, 0, 1]))'],seealso:["matrix","rotationMatrix"]},rotationMatrix:{name:"rotationMatrix",category:"Matrix",syntax:["rotationMatrix(theta)","rotationMatrix(theta, v)","rotationMatrix(theta, v, format)"],description:"Returns a 2-D rotation matrix (2x2) for a given angle (in radians). Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.",examples:["rotationMatrix(pi / 2)",'rotationMatrix(unit("45deg"), [0, 0, 1])','rotationMatrix(1, matrix([0, 0, 1]), "sparse")'],seealso:["cos","sin"]},row:{name:"row",category:"Matrix",syntax:["row(x, index)"],description:"Return a row from a matrix or array.",examples:["A = [[1, 2], [3, 4]]","row(A, 1)","row(A, 2)"],seealso:["column","matrixFromRows"]},size:{name:"size",category:"Matrix",syntax:["size(x)"],description:"Calculate the size of a matrix.",examples:["size(2.3)",'size("hello world")',"a = [1, 2; 3, 4; 5, 6]","size(a)","size(1:6)"],seealso:["concat","count","det","diag","identity","inv","ones","range","squeeze","subset","trace","transpose","zeros"]},sort:{name:"sort",category:"Matrix",syntax:["sort(x)","sort(x, compare)"],description:'Sort the items in a matrix. Compare can be a string "asc", "desc", "natural", or a custom sort function.',examples:["sort([5, 10, 1])",'sort(["C", "B", "A", "D"], "natural")',"sortByLength(a, b) = size(a)[1] - size(b)[1]",'sort(["Langdon", "Tom", "Sara"], sortByLength)','sort(["10", "1", "2"], "natural")'],seealso:["map","filter","forEach"]},squeeze:{name:"squeeze",category:"Matrix",syntax:["squeeze(x)"],description:"Remove inner and outer singleton dimensions from a matrix.",examples:["a = zeros(3,2,1)","size(squeeze(a))","b = zeros(1,1,3)","size(squeeze(b))"],seealso:["concat","det","diag","identity","inv","ones","range","size","subset","trace","transpose","zeros"]},subset:{name:"subset",category:"Matrix",syntax:["value(index)","value(index) = replacement","subset(value, [index])","subset(value, [index], replacement)"],description:"Get or set a subset of the entries of a matrix or characters of a string. Indexes are one-based. There should be one index specification for each dimension of the target. Each specification can be a single index, a list of indices, or a range in colon notation `l:u`. In a range, both the lower bound l and upper bound u are included; and if a bound is omitted it defaults to the most extreme valid value. The cartesian product of the indices specified in each dimension determines the target of the operation.",examples:["d = [1, 2; 3, 4]","e = []","e[1, 1:2] = [5, 6]","e[2, :] = [7, 8]","f = d * e","f[2, 1]","f[:, 1]","f[[1,2], [1,3]] = [9, 10; 11, 12]","f"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","trace","transpose","zeros"]},trace:{name:"trace",category:"Matrix",syntax:["trace(A)"],description:"Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.",examples:["A = [1, 2, 3; -1, 2, 3; 2, 0, 3]","trace(A)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","transpose","zeros"]},transpose:{name:"transpose",category:"Matrix",syntax:["x'","transpose(x)"],description:"Transpose a matrix",examples:["a = [1, 2, 3; 4, 5, 6]","a'","transpose(a)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","zeros"]},zeros:{name:"zeros",category:"Matrix",syntax:["zeros(m)","zeros(m, n)","zeros(m, n, p, ...)","zeros([m])","zeros([m, n])","zeros([m, n, p, ...])"],description:"Create a matrix containing zeros.",examples:["zeros(3)","zeros(3, 5)","a = [1, 2, 3; 4, 5, 6]","zeros(size(a))"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose"]},fft:{name:"fft",category:"Matrix",syntax:["fft(x)"],description:"Calculate N-dimensional Fourier transform",examples:["fft([[1, 0], [1, 0]])"],seealso:["ifft"]},ifft:{name:"ifft",category:"Matrix",syntax:["ifft(x)"],description:"Calculate N-dimensional inverse Fourier transform",examples:["ifft([[2, 2], [0, 0]])"],seealso:["fft"]},sylvester:{name:"sylvester",category:"Algebra",syntax:["sylvester(A,B,C)"],description:"Solves the real-valued Sylvester equation AX+XB=C for X",examples:["sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])","A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]","sylvester(A, B, C)"],seealso:["schur","lyap"]},schur:{name:"schur",category:"Algebra",syntax:["schur(A)"],description:"Performs a real Schur decomposition of the real matrix A = UTU'",examples:["schur([[1, 0], [-4, 3]])","A = [[1, 0], [-4, 3]]","schur(A)"],seealso:["lyap","sylvester"]},lyap:{name:"lyap",category:"Algebra",syntax:["lyap(A,Q)"],description:"Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P",examples:["lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])","A = [[-2, 0], [1, -4]]","Q = [[3, 1], [1, 3]]","lyap(A,Q)"],seealso:["schur","sylvester"]},solveODE:{name:"solveODE",category:"Numeric",syntax:["solveODE(func, tspan, y0)","solveODE(func, tspan, y0, options)"],description:"Numerical Integration of Ordinary Differential Equations.",examples:["f(t,y) = y","tspan = [0, 4]","solveODE(f, tspan, 1)","solveODE(f, tspan, [1, 2])",'solveODE(f, tspan, 1, { method:"RK23", maxStep:0.1 })'],seealso:["derivative","simplifyCore"]},combinations:{name:"combinations",category:"Probability",syntax:["combinations(n, k)"],description:"Compute the number of combinations of n items taken k at a time",examples:["combinations(7, 5)"],seealso:["combinationsWithRep","permutations","factorial"]},combinationsWithRep:{name:"combinationsWithRep",category:"Probability",syntax:["combinationsWithRep(n, k)"],description:"Compute the number of combinations of n items taken k at a time with replacements.",examples:["combinationsWithRep(7, 5)"],seealso:["combinations","permutations","factorial"]},factorial:{name:"factorial",category:"Probability",syntax:["n!","factorial(n)"],description:"Compute the factorial of a value",examples:["5!","5 * 4 * 3 * 2 * 1","3!"],seealso:["combinations","combinationsWithRep","permutations","gamma"]},gamma:{name:"gamma",category:"Probability",syntax:["gamma(n)"],description:"Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.",examples:["gamma(4)","3!","gamma(1/2)","sqrt(pi)"],seealso:["factorial"]},kldivergence:{name:"kldivergence",category:"Probability",syntax:["kldivergence(x, y)"],description:"Calculate the Kullback-Leibler (KL) divergence between two distributions.",examples:["kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])"],seealso:[]},lgamma:{name:"lgamma",category:"Probability",syntax:["lgamma(n)"],description:"Logarithm of the gamma function for real, positive numbers and complex numbers, using Lanczos approximation for numbers and Stirling series for complex numbers.",examples:["lgamma(4)","lgamma(1/2)","lgamma(i)","lgamma(complex(1.1, 2))"],seealso:["gamma"]},multinomial:{name:"multinomial",category:"Probability",syntax:["multinomial(A)"],description:"Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. multinomial takes one array of integers as an argument. The following condition must be enforced: every ai > 0.",examples:["multinomial([1, 2, 1])"],seealso:["combinations","factorial"]},permutations:{name:"permutations",category:"Probability",syntax:["permutations(n)","permutations(n, k)"],description:"Compute the number of permutations of n items taken k at a time",examples:["permutations(5)","permutations(5, 3)"],seealso:["combinations","combinationsWithRep","factorial"]},pickRandom:{name:"pickRandom",category:"Probability",syntax:["pickRandom(array)","pickRandom(array, number)","pickRandom(array, weights)","pickRandom(array, number, weights)","pickRandom(array, weights, number)"],description:"Pick a random entry from a given array.",examples:["pickRandom(0:10)","pickRandom([1, 3, 1, 6])","pickRandom([1, 3, 1, 6], 2)","pickRandom([1, 3, 1, 6], [2, 3, 2, 1])","pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])","pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)"],seealso:["random","randomInt"]},random:{name:"random",category:"Probability",syntax:["random()","random(max)","random(min, max)","random(size)","random(size, max)","random(size, min, max)"],description:"Return a random number.",examples:["random()","random(10, 20)","random([2, 3])"],seealso:["pickRandom","randomInt"]},randomInt:{name:"randomInt",category:"Probability",syntax:["randomInt(max)","randomInt(min, max)","randomInt(size)","randomInt(size, max)","randomInt(size, min, max)"],description:"Return a random integer number",examples:["randomInt(10, 20)","randomInt([2, 3], 10)"],seealso:["pickRandom","random"]},compare:{name:"compare",category:"Relational",syntax:["compare(x, y)"],description:"Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y.",examples:["compare(2, 3)","compare(3, 2)","compare(2, 2)","compare(5cm, 40mm)","compare(2, [1, 2, 3])"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compareNatural","compareText"]},compareNatural:{name:"compareNatural",category:"Relational",syntax:["compareNatural(x, y)"],description:"Compare two values of any type in a deterministic, natural way. Returns 1 when x > y, -1 when x < y, and 0 when x == y.",examples:["compareNatural(2, 3)","compareNatural(3, 2)","compareNatural(2, 2)","compareNatural(5cm, 40mm)",'compareNatural("2", "10")',"compareNatural(2 + 3i, 2 + 4i)","compareNatural([1, 2, 4], [1, 2, 3])","compareNatural([1, 5], [1, 2, 3])","compareNatural([1, 2], [1, 2])","compareNatural({a: 2}, {a: 4})"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compare","compareText"]},compareText:{name:"compareText",category:"Relational",syntax:["compareText(x, y)"],description:"Compare two strings lexically. Comparison is case sensitive. Returns 1 when x > y, -1 when x < y, and 0 when x == y.",examples:['compareText("B", "A")','compareText("A", "B")','compareText("A", "A")','compareText("2", "10")','compare("2", "10")',"compare(2, 10)",'compareNatural("2", "10")','compareText("B", ["A", "B", "C"])'],seealso:["compare","compareNatural"]},deepEqual:{name:"deepEqual",category:"Relational",syntax:["deepEqual(x, y)"],description:"Check equality of two matrices element wise. Returns true if the size of both matrices is equal and when and each of the elements are equal.",examples:["deepEqual([1,3,4], [1,3,4])","deepEqual([1,3,4], [1,3])"],seealso:["equal","unequal","smaller","larger","smallerEq","largerEq","compare"]},equal:{name:"equal",category:"Relational",syntax:["x == y","equal(x, y)"],description:"Check equality of two values. Returns true if the values are equal, and false if not.",examples:["2+2 == 3","2+2 == 4","a = 3.2","b = 6-2.8","a == b","50cm == 0.5m"],seealso:["unequal","smaller","larger","smallerEq","largerEq","compare","deepEqual","equalText"]},equalText:{name:"equalText",category:"Relational",syntax:["equalText(x, y)"],description:"Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.",examples:['equalText("Hello", "Hello")','equalText("a", "A")','equal("2e3", "2000")','equalText("2e3", "2000")','equalText("B", ["A", "B", "C"])'],seealso:["compare","compareNatural","compareText","equal"]},larger:{name:"larger",category:"Relational",syntax:["x > y","larger(x, y)"],description:"Check if value x is larger than y. Returns true if x is larger than y, and false if not.",examples:["2 > 3","5 > 2*2","a = 3.3","b = 6-2.8","(a > b)","(b < a)","5 cm > 2 inch"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compare"]},largerEq:{name:"largerEq",category:"Relational",syntax:["x >= y","largerEq(x, y)"],description:"Check if value x is larger or equal to y. Returns true if x is larger or equal to y, and false if not.",examples:["2 >= 1+1","2 > 1+1","a = 3.2","b = 6-2.8","(a >= b)"],seealso:["equal","unequal","smallerEq","smaller","compare"]},smaller:{name:"smaller",category:"Relational",syntax:["x < y","smaller(x, y)"],description:"Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.",examples:["2 < 3","5 < 2*2","a = 3.3","b = 6-2.8","(a < b)","5 cm < 2 inch"],seealso:["equal","unequal","larger","smallerEq","largerEq","compare"]},smallerEq:{name:"smallerEq",category:"Relational",syntax:["x <= y","smallerEq(x, y)"],description:"Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.",examples:["2 <= 1+1","2 < 1+1","a = 3.2","b = 6-2.8","(a <= b)"],seealso:["equal","unequal","larger","smaller","largerEq","compare"]},unequal:{name:"unequal",category:"Relational",syntax:["x != y","unequal(x, y)"],description:"Check unequality of two values. Returns true if the values are unequal, and false if they are equal.",examples:["2+2 != 3","2+2 != 4","a = 3.2","b = 6-2.8","a != b","50cm != 0.5m","5 cm != 2 inch"],seealso:["equal","smaller","larger","smallerEq","largerEq","compare","deepEqual"]},setCartesian:{name:"setCartesian",category:"Set",syntax:["setCartesian(set1, set2)"],description:"Create the cartesian product of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays and the values will be sorted in ascending order before the operation.",examples:["setCartesian([1, 2], [3, 4])"],seealso:["setUnion","setIntersect","setDifference","setPowerset"]},setDifference:{name:"setDifference",category:"Set",syntax:["setDifference(set1, set2)"],description:"Create the difference of two (multi)sets: every element of set1, that is not the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setDifference([1, 2, 3, 4], [3, 4, 5, 6])","setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setIntersect","setSymDifference"]},setDistinct:{name:"setDistinct",category:"Set",syntax:["setDistinct(set)"],description:"Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.",examples:["setDistinct([1, 1, 1, 2, 2, 3])"],seealso:["setMultiplicity"]},setIntersect:{name:"setIntersect",category:"Set",syntax:["setIntersect(set1, set2)"],description:"Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setIntersect([1, 2, 3, 4], [3, 4, 5, 6])","setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setDifference"]},setIsSubset:{name:"setIsSubset",category:"Set",syntax:["setIsSubset(set1, set2)"],description:"Check whether a (multi)set is a subset of another (multi)set: every element of set1 is the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setIsSubset([1, 2], [3, 4, 5, 6])","setIsSubset([3, 4], [3, 4, 5, 6])"],seealso:["setUnion","setIntersect","setDifference"]},setMultiplicity:{name:"setMultiplicity",category:"Set",syntax:["setMultiplicity(element, set)"],description:"Count the multiplicity of an element in a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.",examples:["setMultiplicity(1, [1, 2, 2, 4])","setMultiplicity(2, [1, 2, 2, 4])"],seealso:["setDistinct","setSize"]},setPowerset:{name:"setPowerset",category:"Set",syntax:["setPowerset(set)"],description:"Create the powerset of a (multi)set: the powerset contains very possible subsets of a (multi)set. A multi-dimension array will be converted to a single-dimension array before the operation.",examples:["setPowerset([1, 2, 3])"],seealso:["setCartesian"]},setSize:{name:"setSize",category:"Set",syntax:["setSize(set)","setSize(set, unique)"],description:'Count the number of elements of a (multi)set. When the second parameter "unique" is true, count only the unique values. A multi-dimension array will be converted to a single-dimension array before the operation.',examples:["setSize([1, 2, 2, 4])","setSize([1, 2, 2, 4], true)"],seealso:["setUnion","setIntersect","setDifference"]},setSymDifference:{name:"setSymDifference",category:"Set",syntax:["setSymDifference(set1, set2)"],description:"Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])","setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setIntersect","setDifference"]},setUnion:{name:"setUnion",category:"Set",syntax:["setUnion(set1, set2)"],description:"Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setUnion([1, 2, 3, 4], [3, 4, 5, 6])","setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setIntersect","setDifference"]},zpk2tf:{name:"zpk2tf",category:"Signal",syntax:["zpk2tf(z, p, k)"],description:"Compute the transfer function of a zero-pole-gain model.",examples:["zpk2tf([1, 2], [-1, -2], 1)","zpk2tf([1, 2], [-1, -2])","zpk2tf([1 - 3i, 2 + 2i], [-1, -2])"],seealso:[]},freqz:{name:"freqz",category:"Signal",syntax:["freqz(b, a)","freqz(b, a, w)"],description:"Calculates the frequency response of a filter given its numerator and denominator coefficients.",examples:["freqz([1, 2], [1, 2, 3])","freqz([1, 2], [1, 2, 3], [0, 1])","freqz([1, 2], [1, 2, 3], 512)"],seealso:[]},erf:{name:"erf",category:"Special",syntax:["erf(x)"],description:"Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x",examples:["erf(0.2)","erf(-0.5)","erf(4)"],seealso:[]},zeta:{name:"zeta",category:"Special",syntax:["zeta(s)"],description:"Compute the Riemann Zeta Function using an infinite series and Riemann's Functional Equation for the entire complex plane",examples:["zeta(0.2)","zeta(-0.5)","zeta(4)"],seealso:[]},cumsum:{name:"cumsum",category:"Statistics",syntax:["cumsum(a, b, c, ...)","cumsum(A)"],description:"Compute the cumulative sum of all values.",examples:["cumsum(2, 3, 4, 1)","cumsum([2, 3, 4, 1])","cumsum([1, 2; 3, 4])","cumsum([1, 2; 3, 4], 1)","cumsum([1, 2; 3, 4], 2)"],seealso:["max","mean","median","min","prod","std","sum","variance"]},mad:{name:"mad",category:"Statistics",syntax:["mad(a, b, c, ...)","mad(A)"],description:"Compute the median absolute deviation of a matrix or a list with values. The median absolute deviation is defined as the median of the absolute deviations from the median.",examples:["mad(10, 20, 30)","mad([1, 2, 3])"],seealso:["mean","median","std","abs"]},max:{name:"max",category:"Statistics",syntax:["max(a, b, c, ...)","max(A)","max(A, dimension)"],description:"Compute the maximum value of a list of values.",examples:["max(2, 3, 4, 1)","max([2, 3, 4, 1])","max([2, 5; 4, 3])","max([2, 5; 4, 3], 1)","max([2, 5; 4, 3], 2)","max(2.7, 7.1, -4.5, 2.0, 4.1)","min(2.7, 7.1, -4.5, 2.0, 4.1)"],seealso:["mean","median","min","prod","std","sum","variance"]},mean:{name:"mean",category:"Statistics",syntax:["mean(a, b, c, ...)","mean(A)","mean(A, dimension)"],description:"Compute the arithmetic mean of a list of values.",examples:["mean(2, 3, 4, 1)","mean([2, 3, 4, 1])","mean([2, 5; 4, 3])","mean([2, 5; 4, 3], 1)","mean([2, 5; 4, 3], 2)","mean([1.0, 2.7, 3.2, 4.0])"],seealso:["max","median","min","prod","std","sum","variance"]},median:{name:"median",category:"Statistics",syntax:["median(a, b, c, ...)","median(A)"],description:"Compute the median of all values. The values are sorted and the middle value is returned. In case of an even number of values, the average of the two middle values is returned.",examples:["median(5, 2, 7)","median([3, -1, 5, 7])"],seealso:["max","mean","min","prod","std","sum","variance","quantileSeq"]},min:{name:"min",category:"Statistics",syntax:["min(a, b, c, ...)","min(A)","min(A, dimension)"],description:"Compute the minimum value of a list of values.",examples:["min(2, 3, 4, 1)","min([2, 3, 4, 1])","min([2, 5; 4, 3])","min([2, 5; 4, 3], 1)","min([2, 5; 4, 3], 2)","min(2.7, 7.1, -4.5, 2.0, 4.1)","max(2.7, 7.1, -4.5, 2.0, 4.1)"],seealso:["max","mean","median","prod","std","sum","variance"]},mode:{name:"mode",category:"Statistics",syntax:["mode(a, b, c, ...)","mode(A)","mode(A, a, b, B, c, ...)"],description:"Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.",examples:["mode(2, 1, 4, 3, 1)","mode([1, 2.7, 3.2, 4, 2.7])","mode(1, 4, 6, 1, 6)"],seealso:["max","mean","min","median","prod","std","sum","variance"]},prod:{name:"prod",category:"Statistics",syntax:["prod(a, b, c, ...)","prod(A)"],description:"Compute the product of all values.",examples:["prod(2, 3, 4)","prod([2, 3, 4])","prod([2, 5; 4, 3])"],seealso:["max","mean","min","median","min","std","sum","variance"]},quantileSeq:{name:"quantileSeq",category:"Statistics",syntax:["quantileSeq(A, prob[, sorted])","quantileSeq(A, [prob1, prob2, ...][, sorted])","quantileSeq(A, N[, sorted])"],description:"Compute the prob order quantile of a matrix or a list with values. The sequence is sorted and the middle value is returned. Supported types of sequence values are: Number, BigNumber, Unit Supported types of probability are: Number, BigNumber. \n\nIn case of a (multi dimensional) array or matrix, the prob order quantile of all elements will be calculated.",examples:["quantileSeq([3, -1, 5, 7], 0.5)","quantileSeq([3, -1, 5, 7], [1/3, 2/3])","quantileSeq([3, -1, 5, 7], 2)","quantileSeq([-1, 3, 5, 7], 0.5, true)"],seealso:["mean","median","min","max","prod","std","sum","variance"]},std:{name:"std",category:"Statistics",syntax:["std(a, b, c, ...)","std(A)","std(A, dimension)","std(A, normalization)","std(A, dimension, normalization)"],description:'Compute the standard deviation of all values, defined as std(A) = sqrt(variance(A)). Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".',examples:["std(2, 4, 6)","std([2, 4, 6, 8])",'std([2, 4, 6, 8], "uncorrected")','std([2, 4, 6, 8], "biased")',"std([1, 2, 3; 4, 5, 6])"],seealso:["max","mean","min","median","prod","sum","variance"]},sum:{name:"sum",category:"Statistics",syntax:["sum(a, b, c, ...)","sum(A)","sum(A, dimension)"],description:"Compute the sum of all values.",examples:["sum(2, 3, 4, 1)","sum([2, 3, 4, 1])","sum([2, 5; 4, 3])"],seealso:["max","mean","median","min","prod","std","sum","variance"]},variance:{name:"variance",category:"Statistics",syntax:["variance(a, b, c, ...)","variance(A)","variance(A, dimension)","variance(A, normalization)","variance(A, dimension, normalization)"],description:'Compute the variance of all values. Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".',examples:["variance(2, 4, 6)","variance([2, 4, 6, 8])",'variance([2, 4, 6, 8], "uncorrected")','variance([2, 4, 6, 8], "biased")',"variance([1, 2, 3; 4, 5, 6])"],seealso:["max","mean","min","median","min","prod","std","sum"]},corr:{name:"corr",category:"Statistics",syntax:["corr(A,B)"],description:"Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.",examples:["corr([2, 4, 6, 8],[1, 2, 3, 6])","corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))"],seealso:["max","mean","min","median","min","prod","std","sum"]},acos:{name:"acos",category:"Trigonometry",syntax:["acos(x)"],description:"Compute the inverse cosine of a value in radians.",examples:["acos(0.5)","acos(cos(2.3))"],seealso:["cos","atan","asin"]},acosh:{name:"acosh",category:"Trigonometry",syntax:["acosh(x)"],description:"Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.",examples:["acosh(1.5)"],seealso:["cosh","asinh","atanh"]},acot:{name:"acot",category:"Trigonometry",syntax:["acot(x)"],description:"Calculate the inverse cotangent of a value.",examples:["acot(0.5)","acot(cot(0.5))","acot(2)"],seealso:["cot","atan"]},acoth:{name:"acoth",category:"Trigonometry",syntax:["acoth(x)"],description:"Calculate the inverse hyperbolic tangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.",examples:["acoth(2)","acoth(0.5)"],seealso:["acsch","asech"]},acsc:{name:"acsc",category:"Trigonometry",syntax:["acsc(x)"],description:"Calculate the inverse cotangent of a value.",examples:["acsc(2)","acsc(csc(0.5))","acsc(0.5)"],seealso:["csc","asin","asec"]},acsch:{name:"acsch",category:"Trigonometry",syntax:["acsch(x)"],description:"Calculate the inverse hyperbolic cosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.",examples:["acsch(0.5)"],seealso:["asech","acoth"]},asec:{name:"asec",category:"Trigonometry",syntax:["asec(x)"],description:"Calculate the inverse secant of a value.",examples:["asec(0.5)","asec(sec(0.5))","asec(2)"],seealso:["acos","acot","acsc"]},asech:{name:"asech",category:"Trigonometry",syntax:["asech(x)"],description:"Calculate the inverse secant of a value.",examples:["asech(0.5)"],seealso:["acsch","acoth"]},asin:{name:"asin",category:"Trigonometry",syntax:["asin(x)"],description:"Compute the inverse sine of a value in radians.",examples:["asin(0.5)","asin(sin(0.5))"],seealso:["sin","acos","atan"]},asinh:{name:"asinh",category:"Trigonometry",syntax:["asinh(x)"],description:"Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.",examples:["asinh(0.5)"],seealso:["acosh","atanh"]},atan:{name:"atan",category:"Trigonometry",syntax:["atan(x)"],description:"Compute the inverse tangent of a value in radians.",examples:["atan(0.5)","atan(tan(0.5))"],seealso:["tan","acos","asin"]},atanh:{name:"atanh",category:"Trigonometry",syntax:["atanh(x)"],description:"Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.",examples:["atanh(0.5)"],seealso:["acosh","asinh"]},atan2:{name:"atan2",category:"Trigonometry",syntax:["atan2(y, x)"],description:"Computes the principal value of the arc tangent of y/x in radians.",examples:["atan2(2, 2) / pi","angle = 60 deg in rad","x = cos(angle)","y = sin(angle)","atan2(y, x)"],seealso:["sin","cos","tan"]},cos:{name:"cos",category:"Trigonometry",syntax:["cos(x)"],description:"Compute the cosine of x in radians.",examples:["cos(2)","cos(pi / 4) ^ 2","cos(180 deg)","cos(60 deg)","sin(0.2)^2 + cos(0.2)^2"],seealso:["acos","sin","tan"]},cosh:{name:"cosh",category:"Trigonometry",syntax:["cosh(x)"],description:"Compute the hyperbolic cosine of x in radians.",examples:["cosh(0.5)"],seealso:["sinh","tanh","coth"]},cot:{name:"cot",category:"Trigonometry",syntax:["cot(x)"],description:"Compute the cotangent of x in radians. Defined as 1/tan(x)",examples:["cot(2)","1 / tan(2)"],seealso:["sec","csc","tan"]},coth:{name:"coth",category:"Trigonometry",syntax:["coth(x)"],description:"Compute the hyperbolic cotangent of x in radians.",examples:["coth(2)","1 / tanh(2)"],seealso:["sech","csch","tanh"]},csc:{name:"csc",category:"Trigonometry",syntax:["csc(x)"],description:"Compute the cosecant of x in radians. Defined as 1/sin(x)",examples:["csc(2)","1 / sin(2)"],seealso:["sec","cot","sin"]},csch:{name:"csch",category:"Trigonometry",syntax:["csch(x)"],description:"Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)",examples:["csch(2)","1 / sinh(2)"],seealso:["sech","coth","sinh"]},sec:{name:"sec",category:"Trigonometry",syntax:["sec(x)"],description:"Compute the secant of x in radians. Defined as 1/cos(x)",examples:["sec(2)","1 / cos(2)"],seealso:["cot","csc","cos"]},sech:{name:"sech",category:"Trigonometry",syntax:["sech(x)"],description:"Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)",examples:["sech(2)","1 / cosh(2)"],seealso:["coth","csch","cosh"]},sin:{name:"sin",category:"Trigonometry",syntax:["sin(x)"],description:"Compute the sine of x in radians.",examples:["sin(2)","sin(pi / 4) ^ 2","sin(90 deg)","sin(30 deg)","sin(0.2)^2 + cos(0.2)^2"],seealso:["asin","cos","tan"]},sinh:{name:"sinh",category:"Trigonometry",syntax:["sinh(x)"],description:"Compute the hyperbolic sine of x in radians.",examples:["sinh(0.5)"],seealso:["cosh","tanh"]},tan:{name:"tan",category:"Trigonometry",syntax:["tan(x)"],description:"Compute the tangent of x in radians.",examples:["tan(0.5)","sin(0.5) / cos(0.5)","tan(pi / 4)","tan(45 deg)"],seealso:["atan","sin","cos"]},tanh:{name:"tanh",category:"Trigonometry",syntax:["tanh(x)"],description:"Compute the hyperbolic tangent of x in radians.",examples:["tanh(0.5)","sinh(0.5) / cosh(0.5)"],seealso:["sinh","cosh"]},to:{name:"to",category:"Units",syntax:["x to unit","to(x, unit)"],description:"Change the unit of a value.",examples:["5 inch to cm","3.2kg to g","16 bytes in bits"],seealso:[]},clone:{name:"clone",category:"Utils",syntax:["clone(x)"],description:"Clone a variable. Creates a copy of primitive variables, and a deep copy of matrices",examples:["clone(3.5)","clone(2 - 4i)","clone(45 deg)","clone([1, 2; 3, 4])",'clone("hello world")'],seealso:[]},format:{name:"format",category:"Utils",syntax:["format(value)","format(value, precision)"],description:"Format a value of any type as string.",examples:["format(2.3)","format(3 - 4i)","format([])","format(pi, 3)"],seealso:["print"]},bin:{name:"bin",category:"Utils",syntax:["bin(value)"],description:"Format a number as binary",examples:["bin(2)"],seealso:["oct","hex"]},oct:{name:"oct",category:"Utils",syntax:["oct(value)"],description:"Format a number as octal",examples:["oct(56)"],seealso:["bin","hex"]},hex:{name:"hex",category:"Utils",syntax:["hex(value)"],description:"Format a number as hexadecimal",examples:["hex(240)"],seealso:["bin","oct"]},isNaN:{name:"isNaN",category:"Utils",syntax:["isNaN(x)"],description:"Test whether a value is NaN (not a number)",examples:["isNaN(2)","isNaN(0 / 0)","isNaN(NaN)","isNaN(Infinity)"],seealso:["isNegative","isNumeric","isPositive","isZero"]},isInteger:{name:"isInteger",category:"Utils",syntax:["isInteger(x)"],description:"Test whether a value is an integer number.",examples:["isInteger(2)","isInteger(3.5)","isInteger([3, 0.5, -2])"],seealso:["isNegative","isNumeric","isPositive","isZero"]},isNegative:{name:"isNegative",category:"Utils",syntax:["isNegative(x)"],description:"Test whether a value is negative: smaller than zero.",examples:["isNegative(2)","isNegative(0)","isNegative(-4)","isNegative([3, 0.5, -2])"],seealso:["isInteger","isNumeric","isPositive","isZero"]},isNumeric:{name:"isNumeric",category:"Utils",syntax:["isNumeric(x)"],description:"Test whether a value is a numeric value. Returns true when the input is a number, BigNumber, Fraction, or boolean.",examples:["isNumeric(2)",'isNumeric("2")','hasNumericValue("2")',"isNumeric(0)","isNumeric(bignumber(500))","isNumeric(fraction(0.125))","isNumeric(2 + 3i)",'isNumeric([2.3, "foo", false])'],seealso:["isInteger","isZero","isNegative","isPositive","isNaN","hasNumericValue"]},hasNumericValue:{name:"hasNumericValue",category:"Utils",syntax:["hasNumericValue(x)"],description:"Test whether a value is an numeric value. In case of a string, true is returned if the string contains a numeric value.",examples:["hasNumericValue(2)",'hasNumericValue("2")','isNumeric("2")',"hasNumericValue(0)","hasNumericValue(bignumber(500))","hasNumericValue(fraction(0.125))","hasNumericValue(2 + 3i)",'hasNumericValue([2.3, "foo", false])'],seealso:["isInteger","isZero","isNegative","isPositive","isNaN","isNumeric"]},isPositive:{name:"isPositive",category:"Utils",syntax:["isPositive(x)"],description:"Test whether a value is positive: larger than zero.",examples:["isPositive(2)","isPositive(0)","isPositive(-4)","isPositive([3, 0.5, -2])"],seealso:["isInteger","isNumeric","isNegative","isZero"]},isPrime:{name:"isPrime",category:"Utils",syntax:["isPrime(x)"],description:"Test whether a value is prime: has no divisors other than itself and one.",examples:["isPrime(3)","isPrime(-2)","isPrime([2, 17, 100])"],seealso:["isInteger","isNumeric","isNegative","isZero"]},isZero:{name:"isZero",category:"Utils",syntax:["isZero(x)"],description:"Test whether a value is zero.",examples:["isZero(2)","isZero(0)","isZero(-4)","isZero([3, 0, -2, 0])"],seealso:["isInteger","isNumeric","isNegative","isPositive"]},print:{name:"print",category:"Utils",syntax:["print(template, values)","print(template, values, precision)"],description:"Interpolate values into a string template.",examples:['print("Lucy is $age years old", {age: 5})','print("The value of pi is $pi", {pi: pi}, 3)','print("Hello, $user.name!", {user: {name: "John"}})','print("Values: $1, $2, $3", [6, 9, 4])'],seealso:["format"]},typeOf:{name:"typeOf",category:"Utils",syntax:["typeOf(x)"],description:"Get the type of a variable.",examples:["typeOf(3.5)","typeOf(2 - 4i)","typeOf(45 deg)",'typeOf("hello world")'],seealso:["getMatrixDataType"]},numeric:{name:"numeric",category:"Utils",syntax:["numeric(x)"],description:"Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.",examples:['numeric("4")','numeric("4", "number")','numeric("4", "bigint")','numeric("4", "BigNumber")','numeric("4", "Fraction")','numeric(4, "Fraction")','numeric(fraction(2, 5), "number")'],seealso:["number","bigint","fraction","bignumber","string","format"]}},Im="help",km=de(Im,["typed","mathWithTransform","Help"],(e=>{let{typed:t,mathWithTransform:r,Help:n}=e;return t(Im,{any:function(e){let t,o=e;if("string"!=typeof e)for(t in r)if(me(r,t)&&e===r[t]){o=t;break}const a=i(zm,o);if(!a){const e="function"==typeof o?o.name:o;throw new Error('No documentation found on "'+e+'"')}return new n(a)}})})),qm="chain",Rm=de(qm,["typed","Chain"],(e=>{let{typed:t,Chain:r}=e;return t(qm,{"":function(){return new r},any:function(e){return new r(e)}})})),Pm=de("det",["typed","matrix","subtractScalar","multiply","divideScalar","isZero","unaryMinus"],(e=>{let{typed:t,matrix:r,subtractScalar:n,multiply:i,divideScalar:o,isZero:a,unaryMinus:s}=e;return t("det",{any:function(e){return ae(e)},"Array | Matrix":function(e){let t;switch(t=E(e)?e.size():Array.isArray(e)?(e=r(e)).size():[],t.length){case 0:return ae(e);case 1:if(1===t[0])return ae(e.valueOf()[0]);if(0===t[0])return 1;throw new RangeError("Matrix must be square (size: "+Kr(t)+")");case 2:{const r=t[0],u=t[1];if(r===u)return function(e,t){if(1===t)return ae(e[0][0]);if(2===t)return n(i(e[0][0],e[1][1]),i(e[1][0],e[0][1]));{let r=!1;const u=new Array(t).fill(0).map(((e,t)=>t));for(let s=0;s{let{typed:t,matrix:r,divideScalar:n,addScalar:i,multiply:o,unaryMinus:a,det:s,identity:u,abs:c}=e;return t("inv",{"Array | Matrix":function(e){const t=E(e)?e.size():un(e);switch(t.length){case 1:if(1===t[0])return E(e)?r([n(1,e.valueOf()[0])]):[n(1,e[0])];throw new RangeError("Matrix must be square (size: "+Kr(t)+")");case 2:{const n=t[0],i=t[1];if(n===i)return E(e)?r(l(e.valueOf(),n,i),e.storage()):l(e,n,i);throw new RangeError("Matrix must be square (size: "+Kr(t)+")")}default:throw new RangeError("Matrix must be two dimensional (size: "+Kr(t)+")")}},any:function(e){return n(1,e)}});function l(e,t,r){let l,f,p,m,d;if(1===t){if(m=e[0][0],0===m)throw Error("Cannot calculate inverse, determinant is zero");return[[n(1,m)]]}if(2===t){const t=s(e);if(0===t)throw Error("Cannot calculate inverse, determinant is zero");return[[n(e[1][1],t),n(a(e[0][1]),t)],[n(a(e[1][0]),t),n(e[0][0],t)]]}{const s=e.concat();for(l=0;lu&&(u=c(s[l][e]),h=l),l++;if(0===u)throw Error("Cannot calculate inverse, determinant is zero");l=h,l!==e&&(d=s[e],s[e]=s[l],s[l]=d,d=m[e],m[e]=m[l],m[l]=d);const g=s[e],y=m[e];for(l=0;l{let{typed:t,matrix:r,inv:n,deepEqual:i,equal:o,dotDivide:a,dot:s,ctranspose:u,divideScalar:c,multiply:l,add:f,Complex:p}=e;return t(Um,{"Array | Matrix":function(e){const t=E(e)?e.size():un(e);switch(t.length){case 1:return h(e)?u(e):1===t[0]?n(e):a(u(e),s(e,e));case 2:{if(h(e))return u(e);const i=t[0],o=t[1];if(i===o)try{return n(e)}catch(e){if(!(e instanceof Error&&e.message.match(/Cannot calculate inverse, determinant is zero/)))throw e}return E(e)?r(m(e.valueOf(),i,o),e.storage()):m(e,i,o)}default:throw new RangeError("Matrix must be two dimensional (size: "+Kr(t)+")")}},any:function(e){return o(e,0)?ae(e):c(1,e)}});function m(e,t,r){const{C:i,F:o}=function(e,t,r){const n=function(e,t,r){const n=ae(e);let i=0;for(let e=0;ee.filter(((e,r)=>r!d(s(n[t],n[t]))))}}(e,t,r),c=l(n(l(u(i),i)),u(i)),p=l(u(o),n(l(o,u(o))));return l(p,c)}function d(e){return o(f(e,p(1,1)),f(0,p(1,1)))}function h(e){return i(f(e,p(1,1)),f(l(e,0),p(1,1)))}}));const $m=de("eigs",["config","typed","matrix","addScalar","equal","subtract","abs","atan","cos","sin","multiplyScalar","divideScalar","inv","bignumber","multiply","add","larger","column","flatten","number","complex","sqrt","diag","size","reshape","qr","usolve","usolveAll","im","re","smaller","matrixFromColumns","dot"],(e=>{let{config:t,typed:r,matrix:n,addScalar:i,subtract:o,equal:a,abs:s,atan:u,cos:c,sin:l,multiplyScalar:f,divideScalar:p,inv:m,bignumber:d,multiply:y,add:v,larger:w,column:N,flatten:E,number:A,complex:S,sqrt:M,diag:C,size:T,reshape:D,qr:F,usolve:O,usolveAll:B,im:_,re:z,smaller:I,matrixFromColumns:k,dot:q}=e;const R=function(e){let{config:t,addScalar:r,subtract:n,abs:i,atan:o,cos:a,sin:s,multiplyScalar:u,inv:c,bignumber:l,multiply:f,add:p}=e;function m(e,r,n){const i=r-e;return Math.abs(i)<=t.relTol?Math.PI/4:.5*Math.atan(2*n/(r-e))}function d(e,r,a){const s=n(r,e);return i(s)<=t.relTol?l(-1).acos().div(4):u(.5,o(f(2,a,c(s))))}function h(e,t,r,n){const i=e.length,o=Math.cos(t),a=Math.sin(t),s=Array(i).fill(0),u=Array(i).fill(0);for(let t=0;t({value:o[t],vector:e})));return{values:o,eigenvectors:s}}return function(e,r){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:t.relTol,o=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0;if("number"===o)return function(e,t,r){const n=e.length,i=Math.abs(t/n);let o,a;if(r){a=new Array(n);for(let e=0;e=Math.abs(i);){const t=s[0][0],n=s[0][1];o=m(e[t][t],e[n][n],e[t][n]),e=x(e,o,t,n),r&&(a=h(a,o,t,n)),s=b(e)}const u=Array(n).fill(0);for(let t=0;t=i(o);){const t=u[0][0],n=u[0][1];a=d(e[t][t],e[n][n],e[t][n]),e=y(e,a,t,n),r&&(s=g(s,a,t,n)),u=v(e)}const c=Array(n).fill(0);for(let t=0;t=5)return null;for(s=0;;){const t=h(e,a);if(v(F(D(a,[t])),n))break;if(++s>=10)return null;a=O(t)}return a}function T(e,t,r){const n="BigNumber"===r,i="Complex"===r;let o=Array(e).fill(0).map((e=>2*Math.random()-1));return n&&(o=o.map((e=>c(e)))),i&&(o=o.map((e=>x(e)))),o=D(o,t),O(o,r)}function D(e,t){const n=f(e);for(let o of t)o=p(o,n),e=r(e,i(a(N(o,e),N(o,o)),o));return e}function F(e){return u(s(N(e,e)))}function O(e,t){const r="Complex"===t,n="BigNumber"===t?c(1):r?x(1):1;return i(a(n,F(e)),e)}return function(e,s,f,p){let h=!(arguments.length>4&&void 0!==arguments[4])||arguments[4];const w=function(e,r,n,i,s){const f="BigNumber"===i,p="Complex"===i,m=f?c(0):0,d=f?c(1):p?x(1):1,h=f?c(1):1,g=f?c(10):2,w=o(g,g);let N;s&&(N=Array(r).fill(d));let E=!1;for(;!E;){E=!0;for(let n=0;n1&&(N=l(Array(y-1).fill(m)))),y-=1,h.pop();for(let e=0;e2&&(N=l(Array(y-2).fill(m)))),y-=2,h.pop(),h.pop();for(let e=0;e+r(u(e),u(t)))),M>100){const e=Error("The eigenvalues failed to converge. Only found these eigenvalues: "+g.join(", "));throw e.values=g,e.vectors=[],e}const C=s?i(w,function(e,t){const r=[];for(let e=0;ei(p,e))),A.push(...l.map((e=>({value:s,vector:n(e)}))))}return A}(e,s,T,w,N,f,p);return{values:N,eigenvectors:t}}return{values:N}}}({config:t,addScalar:i,subtract:o,multiply:y,multiplyScalar:f,flatten:E,divideScalar:p,sqrt:M,abs:s,bignumber:d,diag:C,size:T,reshape:D,qr:F,inv:m,usolve:O,usolveAll:B,equal:a,complex:S,larger:w,smaller:I,matrixFromColumns:k,dot:q});return r("eigs",{Array:function(e){return j(n(e))},"Array, number|BigNumber":function(e,t){return j(n(e),{precision:t})},"Array, Object":(e,t)=>j(n(e),t),Matrix:function(e){return j(e,{matricize:!0})},"Matrix, number|BigNumber":function(e,t){return j(e,{precision:t,matricize:!0})},"Matrix, Object":function(e,t){const r={matricize:!0};return Wr(r,t),j(e,r)}});function j(e){var r;let i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const a=!("eigenvectors"in i)||i.eigenvectors,u=function(e,t,r){const n=e.toArray(),i=e.size();if(2!==i.length||i[0]!==i[1])throw new RangeError(`Matrix must be square (size: ${Kr(i)})`);const a=i[0];if(function(e,t,r){for(let n=0;n{let{value:t,vector:r}=e;return{value:t,vector:n(r)}})))),a&&Object.defineProperty(u,"vectors",{enumerable:!1,get:()=>{throw new Error("eigs(M).vectors replaced with eigs(M).eigenvectors")}}),u}function U(e,t,r){const n=e.datatype();if("number"===n||"BigNumber"===n||"Complex"===n)return n;let i=!1,o=!1,a=!1;for(let e=0;e{let{typed:t,abs:r,add:n,identity:i,inv:o,multiply:a}=e;return t(Hm,{Matrix:function(e){const t=e.size();if(2!==t.length||t[0]!==t[1])throw new RangeError("Matrix must be square (size: "+Kr(t)+")");const u=t[0],c=function(e){const t=e.size()[0];let n=0;for(let i=0;i1&&(y=a(y,m),x=-x),g=g*(f-e+1)/((2*f-e+1)*e),d=n(d,a(g,y)),h=n(h,a(g*x,y));let b=a(o(h),d);for(let e=0;e{let{typed:t,abs:r,add:n,multiply:i,map:o,sqrt:a,subtract:s,inv:u,size:c,max:l,identity:f}=e;const p=1e-6;function m(e){let t,o=0,a=e,m=f(c(e));do{const e=a;if(a=i(.5,n(e,u(m))),m=i(.5,n(m,u(e))),t=l(r(s(a,e))),t>p&&++o>1e3)throw new Error("computing square root of matrix: iterative method could not converge")}while(t>p);return a}return t(Zm,{"Array | Matrix":function(e){const t=E(e)?e.size():un(e);switch(t.length){case 1:if(1===t[0])return o(e,a);throw new RangeError("Matrix must be square (size: "+Kr(t)+")");case 2:if(t[0]===t[1])return m(e);throw new RangeError("Matrix must be square (size: "+Kr(t)+")");default:throw new RangeError("Matrix must be at most two dimensional (size: "+Kr(t)+")")}}})})),Wm="sylvester",Ym=de(Wm,["typed","schur","matrixFromColumns","matrix","multiply","range","concat","transpose","index","subset","add","subtract","identity","lusolve","abs"],(e=>{let{typed:t,schur:r,matrixFromColumns:n,matrix:i,multiply:o,range:a,concat:s,transpose:u,index:c,subset:l,add:f,subtract:p,identity:m,lusolve:d,abs:h}=e;return t(Wm,{"Matrix, Matrix, Matrix":g,"Array, Matrix, Matrix":function(e,t,r){return g(i(e),t,r)},"Array, Array, Matrix":function(e,t,r){return g(i(e),i(t),r)},"Array, Matrix, Array":function(e,t,r){return g(i(e),t,i(r))},"Matrix, Array, Matrix":function(e,t,r){return g(e,i(t),r)},"Matrix, Array, Array":function(e,t,r){return g(e,i(t),i(r))},"Matrix, Matrix, Array":function(e,t,r){return g(e,t,i(r))},"Array, Array, Array":function(e,t,r){return g(i(e),i(t),i(r)).toArray()}});function g(e,t,g){const y=t.size()[0],x=e.size()[0],b=r(e),v=b.T,w=b.U,N=r(o(-1,t)),E=N.T,A=N.U,S=o(o(u(w),g),A),M=a(0,x),C=[],T=(e,t)=>s(e,t,1),D=(e,t)=>s(e,t,0);for(let e=0;e1e-5){let t=D(l(S,c(M,e)),l(S,c(M,e+1)));for(let r=0;r{let{typed:t,matrix:r,identity:n,multiply:i,qr:o,norm:a,subtract:s}=e;return t(Jm,{Array:function(e){const t=u(r(e));return{U:t.U.valueOf(),T:t.T.valueOf()}},Matrix:function(e){return u(e)}});function u(e){const t=e.size()[0];let r,u=e,c=n(t),l=0;do{r=u;const e=o(u),t=e.Q,n=e.R;if(u=i(n,t),c=i(c,t),l++>100)break}while(a(s(u,r))>1e-4);return{U:c,T:u}}})),Qm="lyap",Km=de(Qm,["typed","matrix","sylvester","multiply","transpose"],(e=>{let{typed:t,matrix:r,sylvester:n,multiply:i,transpose:o}=e;return t(Qm,{"Matrix, Matrix":function(e,t){return n(e,o(e),i(-1,t))},"Array, Matrix":function(e,t){return n(r(e),o(r(e)),i(-1,t))},"Matrix, Array":function(e,t){return n(e,o(r(e)),r(i(-1,t)))},"Array, Array":function(e,t){return n(r(e),o(r(e)),r(i(-1,t))).toArray()}})})),ed=de("divide",["typed","matrix","multiply","equalScalar","divideScalar","inv"],(e=>{let{typed:t,matrix:r,multiply:n,equalScalar:i,divideScalar:o,inv:a}=e;const s=No({typed:t,equalScalar:i}),u=Ao({typed:t});return t("divide",se({"Array | Matrix, Array | Matrix":function(e,t){return n(e,a(t))},"DenseMatrix, any":function(e,t){return u(e,t,o,!1)},"SparseMatrix, any":function(e,t){return s(e,t,o,!1)},"Array, any":function(e,t){return u(r(e),t,o,!1).valueOf()},"any, Array | Matrix":function(e,t){return n(e,a(t))}},o.signatures))})),td="distance",rd=de(td,["typed","addScalar","subtractScalar","divideScalar","multiplyScalar","deepEqual","sqrt","abs"],(e=>{let{typed:t,addScalar:r,subtractScalar:n,multiplyScalar:i,divideScalar:o,deepEqual:a,sqrt:s,abs:u}=e;return t(td,{"Array, Array, Array":function(e,t,r){if(2===e.length&&2===t.length&&2===r.length){if(!l(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(!l(t))throw new TypeError("Array with 2 numbers or BigNumbers expected for second argument");if(!l(r))throw new TypeError("Array with 2 numbers or BigNumbers expected for third argument");if(a(t,r))throw new TypeError("LinePoint1 should not be same with LinePoint2");const o=n(r[1],t[1]),s=n(t[0],r[0]),u=n(i(r[0],t[1]),i(t[0],r[1]));return h(e[0],e[1],o,s,u)}throw new TypeError("Invalid Arguments: Try again")},"Object, Object, Object":function(e,t,r){if(2===Object.keys(e).length&&2===Object.keys(t).length&&2===Object.keys(r).length){if(!l(e))throw new TypeError("Values of pointX and pointY should be numbers or BigNumbers");if(!l(t))throw new TypeError("Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers");if(!l(r))throw new TypeError("Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers");if(a(d(t),d(r)))throw new TypeError("LinePoint1 should not be same with LinePoint2");if("pointX"in e&&"pointY"in e&&"lineOnePtX"in t&&"lineOnePtY"in t&&"lineTwoPtX"in r&&"lineTwoPtY"in r){const o=n(r.lineTwoPtY,t.lineOnePtY),a=n(t.lineOnePtX,r.lineTwoPtX),s=n(i(r.lineTwoPtX,t.lineOnePtY),i(t.lineOnePtX,r.lineTwoPtY));return h(e.pointX,e.pointY,o,a,s)}throw new TypeError("Key names do not match")}throw new TypeError("Invalid Arguments: Try again")},"Array, Array":function(e,t){if(2===e.length&&3===t.length){if(!l(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(!f(t))throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument");return h(e[0],e[1],t[0],t[1],t[2])}if(3===e.length&&6===t.length){if(!f(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(!m(t))throw new TypeError("Array with 6 numbers or BigNumbers expected for second argument");return y(e[0],e[1],e[2],t[0],t[1],t[2],t[3],t[4],t[5])}if(e.length===t.length&&e.length>0){if(!p(e))throw new TypeError("All values of an array should be numbers or BigNumbers");if(!p(t))throw new TypeError("All values of an array should be numbers or BigNumbers");return x(e,t)}throw new TypeError("Invalid Arguments: Try again")},"Object, Object":function(e,t){if(2===Object.keys(e).length&&3===Object.keys(t).length){if(!l(e))throw new TypeError("Values of pointX and pointY should be numbers or BigNumbers");if(!f(t))throw new TypeError("Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers");if("pointX"in e&&"pointY"in e&&"xCoeffLine"in t&&"yCoeffLine"in t&&"constant"in t)return h(e.pointX,e.pointY,t.xCoeffLine,t.yCoeffLine,t.constant);throw new TypeError("Key names do not match")}if(3===Object.keys(e).length&&6===Object.keys(t).length){if(!f(e))throw new TypeError("Values of pointX, pointY and pointZ should be numbers or BigNumbers");if(!m(t))throw new TypeError("Values of x0, y0, z0, a, b and c should be numbers or BigNumbers");if("pointX"in e&&"pointY"in e&&"x0"in t&&"y0"in t&&"z0"in t&&"a"in t&&"b"in t&&"c"in t)return y(e.pointX,e.pointY,e.pointZ,t.x0,t.y0,t.z0,t.a,t.b,t.c);throw new TypeError("Key names do not match")}if(2===Object.keys(e).length&&2===Object.keys(t).length){if(!l(e))throw new TypeError("Values of pointOneX and pointOneY should be numbers or BigNumbers");if(!l(t))throw new TypeError("Values of pointTwoX and pointTwoY should be numbers or BigNumbers");if("pointOneX"in e&&"pointOneY"in e&&"pointTwoX"in t&&"pointTwoY"in t)return x([e.pointOneX,e.pointOneY],[t.pointTwoX,t.pointTwoY]);throw new TypeError("Key names do not match")}if(3===Object.keys(e).length&&3===Object.keys(t).length){if(!f(e))throw new TypeError("Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers");if(!f(t))throw new TypeError("Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers");if("pointOneX"in e&&"pointOneY"in e&&"pointOneZ"in e&&"pointTwoX"in t&&"pointTwoY"in t&&"pointTwoZ"in t)return x([e.pointOneX,e.pointOneY,e.pointOneZ],[t.pointTwoX,t.pointTwoY,t.pointTwoZ]);throw new TypeError("Key names do not match")}throw new TypeError("Invalid Arguments: Try again")},Array:function(e){if(!function(e){if(2===e[0].length&&c(e[0][0])&&c(e[0][1])){if(e.some((e=>2!==e.length||!c(e[0])||!c(e[1]))))return!1}else{if(!(3===e[0].length&&c(e[0][0])&&c(e[0][1])&&c(e[0][2])))return!1;if(e.some((e=>3!==e.length||!c(e[0])||!c(e[1])||!c(e[2]))))return!1}return!0}(e))throw new TypeError("Incorrect array format entered for pairwise distance calculation");return function(e){const t=[];let r=[],n=[];for(let i=0;i{let{typed:t,config:r,abs:n,add:i,addScalar:o,matrix:a,multiply:s,multiplyScalar:u,divideScalar:c,subtract:l,smaller:f,equalScalar:p,flatten:m,isZero:d,isNumeric:h}=e;return t("intersect",{"Array, Array, Array":g,"Array, Array, Array, Array":y,"Matrix, Matrix, Matrix":function(e,t,r){const n=g(e.valueOf(),t.valueOf(),r.valueOf());return null===n?null:a(n)},"Matrix, Matrix, Matrix, Matrix":function(e,t,r,n){const i=y(e.valueOf(),t.valueOf(),r.valueOf(),n.valueOf());return null===i?null:a(i)}});function g(e,t,r){if(e=x(e),t=x(t),r=x(r),!v(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(!v(t))throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument");if(!function(e){return 4===e.length&&h(e[0])&&h(e[1])&&h(e[2])&&h(e[3])}(r))throw new TypeError("Array with 4 numbers expected as third argument");return function(e,t,r,n,i,a,s,f,p,m){const d=u(e,s),h=u(n,s),g=u(t,f),y=u(i,f),x=u(r,p),b=u(a,p),v=l(l(l(m,d),g),x),w=l(l(l(o(o(h,y),b),d),g),x),N=c(v,w);return[o(e,u(N,l(n,e))),o(t,u(N,l(i,t))),o(r,u(N,l(a,r)))]}(e[0],e[1],e[2],t[0],t[1],t[2],r[0],r[1],r[2],r[3])}function y(e,t,a,m){if(e=x(e),t=x(t),a=x(a),m=x(m),2===e.length){if(!b(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(!b(t))throw new TypeError("Array with 2 numbers or BigNumbers expected for second argument");if(!b(a))throw new TypeError("Array with 2 numbers or BigNumbers expected for third argument");if(!b(m))throw new TypeError("Array with 2 numbers or BigNumbers expected for fourth argument");return function(e,t,a,p){const m=e,h=a,g=l(m,t),y=l(h,p),x=l(u(g[0],y[1]),u(y[0],g[1]));if(d(x))return null;if(f(n(x),r.relTol))return null;const b=u(y[0],m[1]),v=u(y[1],m[0]),w=u(y[0],h[1]),N=u(y[1],h[0]),E=c(o(l(l(b,v),w),N),x);return i(s(g,E),m)}(e,t,a,m)}if(3===e.length){if(!v(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(!v(t))throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument");if(!v(a))throw new TypeError("Array with 3 numbers or BigNumbers expected for third argument");if(!v(m))throw new TypeError("Array with 3 numbers or BigNumbers expected for fourth argument");return function(e,t,r,n,i,a,s,f,m,h,g,y){const x=w(e,s,h,s,t,f,g,f,r,m,y,m),b=w(h,s,n,e,g,f,i,t,y,m,a,r),v=w(e,s,n,e,t,f,i,t,r,m,a,r),N=w(h,s,h,s,g,f,g,f,y,m,y,m),E=w(n,e,n,e,i,t,i,t,a,r,a,r),A=l(u(x,b),u(v,N)),S=l(u(E,N),u(b,b));if(d(S))return null;const M=c(A,S),C=c(o(x,u(M,b)),N),T=o(e,u(M,l(n,e))),D=o(t,u(M,l(i,t))),F=o(r,u(M,l(a,r))),O=o(s,u(C,l(h,s))),B=o(f,u(C,l(g,f))),_=o(m,u(C,l(y,m)));return p(T,O)&&p(D,B)&&p(F,_)?[T,D,F]:null}(e[0],e[1],e[2],t[0],t[1],t[2],a[0],a[1],a[2],m[0],m[1],m[2])}throw new TypeError("Arrays with two or thee dimensional points expected")}function x(e){return 1===e.length?e[0]:e.length>1&&Array.isArray(e[0])&&e.every((e=>Array.isArray(e)&&1===e.length))?m(e):e}function b(e){return 2===e.length&&h(e[0])&&h(e[1])}function v(e){return 3===e.length&&h(e[0])&&h(e[1])&&h(e[2])}function w(e,t,r,n,i,a,s,c,f,p,m,d){const h=u(l(e,t),l(r,n)),g=u(l(i,a),l(s,c)),y=u(l(f,p),l(m,d));return o(o(h,g),y)}})),id=de("sum",["typed","config","add","numeric"],(e=>{let{typed:t,config:r,add:n,numeric:i}=e;return t("sum",{"Array | Matrix":o,"Array | Matrix, number | BigNumber":function(e,t){try{return Vn(e,t,n)}catch(e){throw Du(e,"sum")}},"...":function(e){if(Hn(e))throw new TypeError("Scalar values expected in function sum");return o(e)}});function o(e){let t;return Gn(e,(function(e){try{t=void 0===t?e:n(t,e)}catch(t){throw Du(t,"sum",e)}})),void 0===t&&(t=i(0,r.number)),"string"==typeof t&&(t=i(t,xe(t,r))),t}})),od="cumsum",ad=de(od,["typed","add","unaryPlus"],(e=>{let{typed:t,add:r,unaryPlus:n}=e;return t(od,{Array:i,Matrix:function(e){return e.create(i(e.valueOf(),e.datatype()))},"Array, number | BigNumber":a,"Matrix, number | BigNumber":function(e,t){return e.create(a(e.valueOf(),t),e.datatype())},"...":function(e){if(Hn(e))throw new TypeError("All values expected to be scalar in function cumsum");return i(e)}});function i(e){try{return o(e)}catch(e){throw Du(e,od)}}function o(e){if(0===e.length)return[];const t=[n(e[0])];for(let n=1;n=r.length)throw new sn(t,r.length);try{return s(e,t)}catch(e){throw Du(e,od)}}function s(e,t){let r,n,i;if(t<=0){const a=e[0][0];if(Array.isArray(a)){for(i=$n(e),n=[],r=0;r{let{typed:t,add:r,divide:n}=e;return t(sd,{"Array | Matrix":i,"Array | Matrix, number | BigNumber":function(e,t){try{const i=Vn(e,t,r),o=Array.isArray(e)?un(e):e.size();return n(i,o[t])}catch(e){throw Du(e,"mean")}},"...":function(e){if(Hn(e))throw new TypeError("Scalar values expected in function mean");return i(e)}});function i(e){let t,i=0;if(Gn(e,(function(e){try{t=void 0===t?e:r(t,e),i++}catch(t){throw Du(t,"mean",e)}})),0===i)throw new Error("Cannot calculate the mean of an empty array");return n(t,i)}})),cd="median",ld=de(cd,["typed","add","divide","compare","partitionSelect"],(e=>{let{typed:t,add:r,divide:n,compare:i,partitionSelect:o}=e;function a(e){try{const t=(e=En(e.valueOf())).length;if(0===t)throw new Error("Cannot calculate median of an empty array");if(t%2==0){const r=t/2-1,n=o(e,r+1);let a=e[r];for(let t=0;t0&&(a=e[t]);return u(a,n)}{const r=o(e,(t-1)/2);return s(r)}}catch(e){throw Du(e,"median")}}const s=t({"number | BigNumber | Complex | Unit":function(e){return e}}),u=t({"number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit":function(e,t){return n(r(e,t),2)}});return t(cd,{"Array | Matrix":a,"Array | Matrix, number | BigNumber":function(e,t){throw new Error("median(A, dim) is not yet supported")},"...":function(e){if(Hn(e))throw new TypeError("Scalar values expected in function median");return a(e)}})})),fd=de("mad",["typed","abs","map","median","subtract"],(e=>{let{typed:t,abs:r,map:n,median:i,subtract:o}=e;return t("mad",{"Array | Matrix":a,"...":function(e){return a(e)}});function a(e){if(0===(e=En(e.valueOf())).length)throw new Error("Cannot calculate median absolute deviation (mad) of an empty array");try{const t=i(e);return i(n(e,(function(e){return r(o(e,t))})))}catch(e){throw e instanceof TypeError&&e.message.includes("median")?new TypeError(e.message.replace("median","mad")):Du(e,"mad")}}})),pd="unbiased",md="variance",dd=de(md,["typed","add","subtract","multiply","divide","apply","isNaN"],(e=>{let{typed:t,add:r,subtract:n,multiply:i,divide:o,apply:a,isNaN:s}=e;return t(md,{"Array | Matrix":function(e){return u(e,pd)},"Array | Matrix, string":u,"Array | Matrix, number | BigNumber":function(e,t){return c(e,t,pd)},"Array | Matrix, number | BigNumber, string":c,"...":function(e){return u(e,pd)}});function u(e,t){let a,u=0;if(0===e.length)throw new SyntaxError("Function variance requires one or more parameters (0 provided)");if(Gn(e,(function(e){try{a=void 0===a?e:r(a,e),u++}catch(t){throw Du(t,"variance",e)}})),0===u)throw new Error("Cannot calculate variance of an empty array");const c=o(a,u);if(a=void 0,Gn(e,(function(e){const t=n(e,c);a=void 0===a?i(t,t):r(a,i(t,t))})),s(a))return a;switch(t){case"uncorrected":return o(a,u);case"biased":return o(a,u+1);case"unbiased":{const e=g(a)?a.mul(0):0;return 1===u?e:o(a,u-1)}default:throw new Error('Unknown normalization "'+t+'". Choose "unbiased" (default), "uncorrected", or "biased".')}}function c(e,t,r){try{if(0===e.length)throw new SyntaxError("Function variance requires one or more parameters (0 provided)");return a(e,t,(e=>u(e,r)))}catch(e){throw Du(e,"variance")}}})),hd="quantileSeq",gd=de(hd,["typed","?bignumber","add","subtract","divide","multiply","partitionSelect","compare","isInteger","smaller","smallerEq","larger"],(e=>{let{typed:t,bignumber:r,add:n,subtract:i,divide:o,multiply:a,partitionSelect:s,compare:u,isInteger:c,smaller:l,smallerEq:f,larger:p}=e;const m=mo({typed:t,isInteger:c});return t(hd,{"Array | Matrix, number | BigNumber":(e,t)=>g(e,t,!1),"Array | Matrix, number | BigNumber, number":(e,t,r)=>d(e,t,!1,r,g),"Array | Matrix, number | BigNumber, boolean":g,"Array | Matrix, number | BigNumber, boolean, number":(e,t,r,n)=>d(e,t,r,n,g),"Array | Matrix, Array | Matrix":(e,t)=>y(e,t,!1),"Array | Matrix, Array | Matrix, number":(e,t,r)=>d(e,t,!1,r,y),"Array | Matrix, Array | Matrix, boolean":y,"Array | Matrix, Array | Matrix, boolean, number":(e,t,r,n)=>d(e,t,r,n,y)});function d(e,t,r,n,i){return m(e,n,(e=>i(e,t,r)))}function g(e,t,i){let a;const s=e.valueOf();if(l(t,0))throw new Error("N/prob must be non-negative");if(f(t,1))return h(t)?x(s,t,i):r(x(s,t,i));if(p(t,1)){if(!c(t))throw new Error("N must be a positive integer");if(p(t,4294967295))throw new Error("N must be less than or equal to 2^32-1, as that is the maximum length of an Array");const e=n(t,1);a=[];for(let r=0;l(r,t);r++){const t=o(r+1,e);a.push(x(s,t,i))}return h(t)?a:r(a)}}function y(e,t,r){const n=e.valueOf(),i=t.valueOf(),o=[];for(let e=0;e0&&(d=o[e])}return n(a(d,i(1,m)),a(g,m))}})),yd=de("std",["typed","map","sqrt","variance"],(e=>{let{typed:t,map:r,sqrt:n,variance:i}=e;return t("std",{"Array | Matrix":o,"Array | Matrix, string":o,"Array | Matrix, number | BigNumber":o,"Array | Matrix, number | BigNumber, string":o,"...":function(e){return o(e)}});function o(e,t){if(0===e.length)throw new SyntaxError("Function std requires one or more parameters (0 provided)");try{const e=i.apply(null,arguments);return A(e)?r(e,n):n(e)}catch(e){throw e instanceof TypeError&&e.message.includes(" variance")?new TypeError(e.message.replace(" variance"," std")):e}}})),xd="corr",bd=de(xd,["typed","matrix","mean","sqrt","sum","add","subtract","multiply","pow","divide"],(e=>{let{typed:t,matrix:r,sqrt:n,sum:i,add:o,subtract:a,multiply:s,pow:u,divide:c}=e;return t(xd,{"Array, Array":function(e,t){return l(e,t)},"Matrix, Matrix":function(e,t){const n=l(e.toArray(),t.toArray());return Array.isArray(n)?r(n):n}});function l(e,t){const r=[];if(Array.isArray(e[0])&&Array.isArray(t[0])){if(e.length!==t.length)throw new SyntaxError("Dimension mismatch. Array A and B must have the same length.");for(let n=0;no(e,s(r,t[n]))),0),m=i(e.map((e=>u(e,2)))),d=i(t.map((e=>u(e,2)))),h=a(s(r,p),s(l,f)),g=n(s(a(s(r,m),u(l,2)),a(s(r,d),u(f,2))));return c(h,g)}}));function vd(e,t){if(t>1;return vd(e,r)*vd(r+1,t)}function wd(e,t){if(!ye(e)||e<0)throw new TypeError("Positive integer value expected in function combinations");if(!ye(t)||t<0)throw new TypeError("Positive integer value expected in function combinations");if(t>e)throw new TypeError("k must be less than or equal to n");const r=e-t;let n=1,i=2;const o=t{let{typed:t}=e;return t(Nd,{"number, number":wd,"BigNumber, BigNumber":function(e,t){const r=e.constructor;let n,i;const o=e.minus(t),a=new r(1);if(!Ad(e)||!Ad(t))throw new TypeError("Positive integer value expected in function combinations");if(t.gt(e))throw new TypeError("k must be less than n in function combinations");if(n=a,t.lt(o))for(i=a;i.lte(o);i=i.plus(a))n=n.times(t.plus(i)).dividedBy(i);else for(i=a;i.lte(t);i=i.plus(a))n=n.times(o.plus(i)).dividedBy(i);return n}})}));function Ad(e){return e.isInteger()&&e.gte(0)}const Sd="combinationsWithRep",Md=de(Sd,["typed"],(e=>{let{typed:t}=e;return t(Sd,{"number, number":function(e,t){if(!ye(e)||e<0)throw new TypeError("Positive integer value expected in function combinationsWithRep");if(!ye(t)||t<0)throw new TypeError("Positive integer value expected in function combinationsWithRep");if(e<1)throw new TypeError("k must be less than or equal to n + k - 1");return t171?1/0:vd(1,e-1);if(e<.5)return Math.PI/(Math.sin(Math.PI*e)*Td(1-e));if(e>=171.35)return 1/0;if(e>85){const t=e*e,r=t*e,n=r*e,i=n*e;return Math.sqrt(2*Math.PI/e)*Math.pow(e/Math.E,e)*(1+1/(12*e)+1/(288*t)-139/(51840*r)-571/(2488320*n)+163879/(209018880*i)+5246819/(75246796800*i*e))}--e,t=Fd[0];for(let r=1;r=1;t--)r+=Bd[t]/(e+t);return Od+(e+.5)*Math.log(t)-t+Math.log(r)}_d.signature="number";const zd="gamma",Id=de(zd,["typed","config","multiplyScalar","pow","BigNumber","Complex"],(e=>{let{typed:t,config:r,multiplyScalar:n,pow:i,BigNumber:o,Complex:a}=e;return t(zd,{number:Td,Complex:function e(t){if(0===t.im)return Td(t.re);if(t.re<.5){const r=new a(1-t.re,-t.im),n=new a(Math.PI*t.re,Math.PI*t.im);return new a(Math.PI).div(n.sin()).div(e(r))}t=new a(t.re-1,t.im);let r=new a(Fd[0],0);for(let e=1;e2;)i-=2,u+=i,a=a.times(u);return new o(a.toPrecision(o.precision))}})),kd="lgamma",qd=de(kd,["Complex","typed"],(e=>{let{Complex:t,typed:r}=e;const n=[-.029550653594771242,.00641025641025641,-.0019175269175269176,.0008417508417508417,-.0005952380952380953,.0007936507936507937,-.002777777777777778,.08333333333333333];return r(kd,{number:_d,Complex:function e(r){if(r.isNaN())return new t(NaN,NaN);if(0===r.im)return new t(_d(r.re),0);if(r.re>=7||Math.abs(r.im)>=7)return i(r);if(r.re<=.1){const i=(n=6.283185307179586,(!0^((a=r.im)>0||!(a<0)&&1/a==1/0)?-n:n)*Math.floor(.5*r.re+.25)),o=r.mul(Math.PI).sin().log(),s=e(new t(1-r.re,-r.im));return new t(1.1447298858494002,i).sub(o).sub(s)}return r.im>=0?o(r):o(r.conjugate()).conjugate();var n,a},BigNumber:function(){throw new Error("mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber")}});function i(e){const r=e.sub(.5).mul(e.log()).sub(e).add(Od),i=new t(1,0).div(e),o=i.div(e);let a=n[0],s=n[1];const u=2*o.re,c=o.re*o.re+o.im*o.im;for(let e=2;e<8;e++){const t=s;s=-c*a+n[e],a=u*a+t}const l=i.mul(o.mul(a).add(s));return r.add(l)}function o(e){let r=0,n=0,o=e;for(e=e.add(1);e.re<=7;){o=o.mul(e);const t=o.im<0?1:0;0!==t&&0===n&&r++,n=t,e=e.add(1)}return i(e).sub(o.log()).sub(new t(0,2*r*Math.PI*1))}})),Rd="factorial",Pd=de(Rd,["typed","gamma"],(e=>{let{typed:t,gamma:r}=e;return t(Rd,{number:function(e){if(e<0)throw new Error("Value must be non-negative");return r(e+1)},BigNumber:function(e){if(e.isNegative())throw new Error("Value must be non-negative");return r(e.plus(1))},"Array | Matrix":t.referToSelf((e=>t=>Zn(t,e)))})})),jd="kldivergence",Ud=de(jd,["typed","matrix","divide","sum","multiply","map","dotDivide","log","isNumeric"],(e=>{let{typed:t,matrix:r,divide:n,sum:i,multiply:o,map:a,dotDivide:s,log:u,isNumeric:c}=e;return t(jd,{"Array, Array":function(e,t){return l(r(e),r(t))},"Matrix, Array":function(e,t){return l(e,r(t))},"Array, Matrix":function(e,t){return l(r(e),t)},"Matrix, Matrix":function(e,t){return l(e,t)}});function l(e,t){const r=t.size().length,l=e.size().length;if(r>1)throw new Error("first object must be one dimensional");if(l>1)throw new Error("second object must be one dimensional");if(r!==l)throw new Error("Length of two vectors must be equal");if(0===i(e))throw new Error("Sum of elements in first object must be non zero");if(0===i(t))throw new Error("Sum of elements in second object must be non zero");const f=n(e,i(e)),p=n(t,i(t)),m=i(o(f,a(s(f,p),(e=>u(e)))));return c(m)?m:Number.NaN}})),Ld="multinomial",$d=de(Ld,["typed","add","divide","multiply","factorial","isInteger","isPositive"],(e=>{let{typed:t,add:r,divide:n,multiply:i,factorial:o,isInteger:a,isPositive:s}=e;return t(Ld,{"Array | Matrix":function(e){let t=0,u=1;return Gn(e,(function(e){if(!a(e)||!s(e))throw new TypeError("Positive integer value expected in function multinomial");t=r(t,e),u=i(u,o(e))})),n(o(t),u)}})})),Hd="permutations",Gd=de(Hd,["typed","factorial"],(e=>{let{typed:t,factorial:r}=e;return t(Hd,{"number | BigNumber":r,"number, number":function(e,t){if(!ye(e)||e<0)throw new TypeError("Positive integer value expected in function permutations");if(!ye(t)||t<0)throw new TypeError("Positive integer value expected in function permutations");if(t>e)throw new TypeError("second argument k must be less than or equal to first argument n");return vd(e-t+1,e)},"BigNumber, BigNumber":function(e,t){let r,n;if(!Zd(e)||!Zd(t))throw new TypeError("Positive integer value expected in function permutations");if(t.gt(e))throw new TypeError("second argument k must be less than or equal to first argument n");for(r=e.mul(0).add(1),n=e.minus(t).plus(1);n.lte(e);n=n.plus(1))r=r.times(n);return r}})}));function Zd(e){return e.isInteger()&&e.gte(0)}var Vd=r(7391);const Wd=Vd(Date.now());function Yd(e){let t;var r;return t=null===(r=e)?Wd:Vd(String(r)),function(){return t()}}const Jd="pickRandom",Xd=de(Jd,["typed","config","?on"],(e=>{let{typed:t,config:r,on:n}=e,i=Yd(r.randomSeed);return n&&n("config",(function(e,t){e.randomSeed!==t.randomSeed&&(i=Yd(e.randomSeed))})),t(Jd,{"Array | Matrix":function(e){return o(e,{})},"Array | Matrix, Object":function(e,t){return o(e,t)},"Array | Matrix, number":function(e,t){return o(e,{number:t})},"Array | Matrix, Array | Matrix":function(e,t){return o(e,{weights:t})},"Array | Matrix, Array | Matrix, number":function(e,t,r){return o(e,{number:r,weights:t})},"Array | Matrix, number, Array | Matrix":function(e,t,r){return o(e,{number:t,weights:r})}});function o(e,t){let{number:r,weights:n,elementWise:o=!0}=t;const a=void 0===r;a&&(r=1);const s=E(e)?e.create:E(n)?n.create:null;e=e.valueOf(),n&&(n=n.valueOf()),!0===o&&(e=En(e),n=En(n));let u=0;if(void 0!==n){if(n.length!==e.length)throw new Error("Weights must have the same length as possibles");for(let e=0,t=n.length;e1)for(let n=0,i=e.shift();n{let{typed:t,config:r,on:n}=e,i=Yd(r.randomSeed);return n&&n("config",(function(e,t){e.randomSeed!==t.randomSeed&&(i=Yd(e.randomSeed))})),t(Kd,{"":()=>a(0,1),number:e=>a(0,e),"number, number":(e,t)=>a(e,t),"Array | Matrix":e=>o(e,0,1),"Array | Matrix, number":(e,t)=>o(e,0,t),"Array | Matrix, number, number":(e,t,r)=>o(e,t,r)});function o(e,t,r){const n=Qd(e.valueOf(),(()=>a(t,r)));return E(e)?e.create(n,"number"):n}function a(e,t){return e+i()*(t-e)}})),th="randomInt",rh=de(th,["typed","config","?on"],(e=>{let{typed:t,config:r,on:n}=e,i=Yd(r.randomSeed);return n&&n("config",(function(e,t){e.randomSeed!==t.randomSeed&&(i=Yd(e.randomSeed))})),t(th,{"":()=>a(0,1),number:e=>a(0,e),"number, number":(e,t)=>a(e,t),"Array | Matrix":e=>o(e,0,1),"Array | Matrix, number":(e,t)=>o(e,0,t),"Array | Matrix, number, number":(e,t,r)=>o(e,t,r)});function o(e,t,r){const n=Qd(e.valueOf(),(()=>a(t,r)));return E(e)?e.create(n,"number"):n}function a(e,t){return Math.floor(e+i()*(t-e))}})),nh="stirlingS2",ih=de(nh,["typed","addScalar","subtractScalar","multiplyScalar","divideScalar","pow","factorial","combinations","isNegative","isInteger","number","?bignumber","larger"],(e=>{let{typed:t,addScalar:r,subtractScalar:n,multiplyScalar:i,divideScalar:o,pow:a,factorial:s,combinations:u,isNegative:c,isInteger:l,number:f,bignumber:p,larger:m}=e;const d=[],g=[];return t(nh,{"number | BigNumber, number | BigNumber":function(e,t){if(!l(e)||c(e)||!l(t)||c(t))throw new TypeError("Non-negative integer value expected in function stirlingS2");if(m(t,e))throw new TypeError("k must be less than or equal to n in function stirlingS2");const n=!(h(e)&&h(t)),o=n?g:d,a=n?p:f,s=f(e),u=f(t);if(o[s]&&o[s].length>u)return o[s][u];for(let e=0;e<=s;++e){if(o[e]||(o[e]=[a(0===e?1:0)]),0===e)continue;const t=o[e],n=o[e-1];for(let o=t.length;o<=e&&o<=u;++o)t[o]=o===e?1:r(i(a(o),n[o]),n[o-1])}return o[s][u]}})})),oh="bellNumbers",ah=de(oh,["typed","addScalar","isNegative","isInteger","stirlingS2"],(e=>{let{typed:t,addScalar:r,isNegative:n,isInteger:i,stirlingS2:o}=e;return t(oh,{"number | BigNumber":function(e){if(!i(e)||n(e))throw new TypeError("Non-negative integer value expected in function bellNumbers");let t=0;for(let n=0;n<=e;n++)t=r(t,o(e,n));return t}})})),sh="catalan",uh=de(sh,["typed","addScalar","divideScalar","multiplyScalar","combinations","isNegative","isInteger"],(e=>{let{typed:t,addScalar:r,divideScalar:n,multiplyScalar:i,combinations:o,isNegative:a,isInteger:s}=e;return t(sh,{"number | BigNumber":function(e){if(!s(e)||a(e))throw new TypeError("Non-negative integer value expected in function catalan");return n(o(i(e,2),e),r(e,1))}})})),ch="composition",lh=de(ch,["typed","addScalar","combinations","isNegative","isPositive","isInteger","larger"],(e=>{let{typed:t,addScalar:r,combinations:n,isPositive:i,isNegative:o,isInteger:a,larger:s}=e;return t(ch,{"number | BigNumber, number | BigNumber":function(e,t){if(!(a(e)&&i(e)&&a(t)&&i(t)))throw new TypeError("Positive integer value expected in function composition");if(s(t,e))throw new TypeError("k must be less than or equal to n in function composition");return n(r(e,-1),r(t,-1))}})})),fh="leafCount",ph=de(fh,["parse","typed"],(e=>{let{parse:t,typed:r}=e;function n(e){let t=0;return e.forEach((e=>{t+=n(e)})),t||1}return r(fh,{Node:function(e){return n(e)}})}));function mh(e){return Z(e)||K(e)&&e.isUnary()&&Z(e.args[0])}function dh(e){return!!Z(e)||!(!Y(e)&&!K(e)||!e.args.every(dh))||!(!ee(e)||!dh(e.content))}const hh=de("simplifyUtil",["FunctionNode","OperatorNode","SymbolNode"],(e=>{let{FunctionNode:t,OperatorNode:r,SymbolNode:n}=e;const i=!0,o=!1,a="defaultF",s={add:{trivial:i,total:i,commutative:i,associative:i},unaryPlus:{trivial:i,total:i,commutative:i,associative:i},subtract:{trivial:o,total:i,commutative:o,associative:o},multiply:{trivial:i,total:i,commutative:i,associative:i},divide:{trivial:o,total:i,commutative:o,associative:o},paren:{trivial:i,total:i,commutative:i,associative:o},defaultF:{trivial:o,total:i,commutative:o,associative:o}};function u(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:s,n=a;if("string"==typeof e?n=e:K(e)?n=e.fn.toString():Y(e)?n=e.name:ee(e)&&(n="paren"),me(r,n)){const e=r[n];if(me(e,t))return e[t];if(me(s,n))return s[n][t]}if(me(r,a)){const e=r[a];return me(e,t)?e[t]:s[a][t]}if(me(s,n)){const e=s[n];if(me(e,t))return e[t]}return s[a][t]}function c(e){return u(e,"associative",arguments.length>1&&void 0!==arguments[1]?arguments[1]:s)}function l(e,t){let r;const n=[],i=function(e){for(let t=0;t1&&void 0!==arguments[1]?arguments[1]:s)},isAssociative:c,mergeContext:function(e,t){const r={...e};for(const n in t)me(e,n)?r[n]={...t[n],...e[n]}:r[n]=t[n];return r},flatten:function e(t,r){if(!t.args||0===t.args.length)return t;t.args=l(t,r);for(let n=0;n2&&c(t,r)){let e=t.args.pop();for(;t.args.length>0;)e=n([t.args.pop(),e]);t.args=e.args}},unflattenl:function e(t,r){if(!t.args||0===t.args.length)return;const n=f(t),i=t.args.length;for(let n=0;n2&&c(t,r)){let e=t.args.shift();for(;t.args.length>0;)e=n([e,t.args.shift()]);t.args=e.args}},defaultContext:s,realContext:{divide:{total:o},log:{total:o}},positiveContext:{subtract:{total:o},abs:{trivial:i},log:{total:i}}}})),gh=de("simplify",["config","typed","parse","add","subtract","multiply","divide","pow","isZero","equal","resolve","simplifyConstant","simplifyCore","?fraction","?bignumber","mathWithTransform","matrix","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","SymbolNode"],(e=>{let{config:t,typed:r,parse:n,add:i,subtract:o,multiply:a,divide:s,pow:u,isZero:c,equal:l,resolve:f,simplifyConstant:p,simplifyCore:h,fraction:g,bignumber:y,mathWithTransform:x,matrix:b,AccessorNode:v,ArrayNode:w,ConstantNode:N,FunctionNode:E,IndexNode:A,ObjectNode:S,OperatorNode:M,ParenthesisNode:C,SymbolNode:T}=e;const{hasProperty:D,isCommutative:F,isAssociative:O,mergeContext:B,flatten:_,unflattenr:z,unflattenl:I,createMakeNodeFunction:k,defaultContext:q,realContext:R,positiveContext:P}=hh({FunctionNode:E,OperatorNode:M,SymbolNode:T});r.addConversion({from:"Object",to:"Map",convert:d});const j=r("simplify",{Node:V,"Node, Map":(e,t)=>V(e,!1,t),"Node, Map, Object":(e,t,r)=>V(e,!1,t,r),"Node, Array":V,"Node, Array, Map":V,"Node, Array, Map, Object":V});function U(e){return e.transform((function(e,t,r){return ee(e)?U(e.content):e}))}r.removeConversion({from:"Object",to:"Map",convert:d}),j.defaultContext=q,j.realContext=R,j.positiveContext=P;const L={true:!0,false:!0,e:!0,i:!0,Infinity:!0,LN2:!0,LN10:!0,LOG2E:!0,LOG10E:!0,NaN:!0,phi:!0,pi:!0,SQRT1_2:!0,SQRT2:!0,tau:!0};function $(e,t){const r={};if(e.s){const t=e.s.split("->");if(2!==t.length)throw SyntaxError("Could not parse rule: "+e.s);r.l=t[0],r.r=t[1]}else r.l=e.l,r.r=e.r;r.l=U(n(r.l)),r.r=U(n(r.r));for(const t of["imposeContext","repeat","assuming"])t in e&&(r[t]=e[t]);if(e.evaluate&&(r.evaluate=n(e.evaluate)),O(r.l,t)){const e=!F(r.l,t);let n;e&&(n=G());const i=k(r.l),o=G();r.expanded={},r.expanded.l=i([r.l,o]),_(r.expanded.l,t),z(r.expanded.l,t),r.expanded.r=i([r.r,o]),e&&(r.expandedNC1={},r.expandedNC1.l=i([n,r.l]),r.expandedNC1.r=i([n,r.r]),r.expandedNC2={},r.expandedNC2.l=i([n,r.expanded.l]),r.expandedNC2.r=i([n,r.expanded.r]))}return r}j.rules=[h,{l:"log(e)",r:"1"},{s:"n-n1 -> n+-n1",assuming:{subtract:{total:!0}}},{s:"n-n -> 0",assuming:{subtract:{total:!1}}},{s:"-(cl*v) -> v * (-cl)",assuming:{multiply:{commutative:!0},subtract:{total:!0}}},{s:"-(cl*v) -> (-cl) * v",assuming:{multiply:{commutative:!1},subtract:{total:!0}}},{s:"-(v*cl) -> v * (-cl)",assuming:{multiply:{commutative:!1},subtract:{total:!0}}},{l:"-(n1/n2)",r:"-n1/n2"},{l:"-v",r:"v * (-1)"},{l:"(n1 + n2)*(-1)",r:"n1*(-1) + n2*(-1)",repeat:!0},{l:"n/n1^n2",r:"n*n1^-n2"},{l:"n/n1",r:"n*n1^-1"},{s:"(n1*n2)^n3 -> n1^n3 * n2^n3",assuming:{multiply:{commutative:!0}}},{s:"(n1*n2)^(-1) -> n2^(-1) * n1^(-1)",assuming:{multiply:{commutative:!1}}},{s:"(n ^ n1) ^ n2 -> n ^ (n1 * n2)",assuming:{divide:{total:!0}}},{l:" vd * ( vd * n1 + n2)",r:"vd^2 * n1 + vd * n2"},{s:" vd * (vd^n4 * n1 + n2) -> vd^(1+n4) * n1 + vd * n2",assuming:{divide:{total:!0}}},{s:"vd^n3 * ( vd * n1 + n2) -> vd^(n3+1) * n1 + vd^n3 * n2",assuming:{divide:{total:!0}}},{s:"vd^n3 * (vd^n4 * n1 + n2) -> vd^(n3+n4) * n1 + vd^n3 * n2",assuming:{divide:{total:!0}}},{l:"n*n",r:"n^2"},{s:"n * n^n1 -> n^(n1+1)",assuming:{divide:{total:!0}}},{s:"n^n1 * n^n2 -> n^(n1+n2)",assuming:{divide:{total:!0}}},p,{s:"n+n -> 2*n",assuming:{add:{total:!0}}},{l:"n+-n",r:"0"},{l:"vd*n + vd",r:"vd*(n+1)"},{l:"n3*n1 + n3*n2",r:"n3*(n1+n2)"},{l:"n3^(-n4)*n1 + n3 * n2",r:"n3^(-n4)*(n1 + n3^(n4+1) *n2)"},{l:"n3^(-n4)*n1 + n3^n5 * n2",r:"n3^(-n4)*(n1 + n3^(n4+n5)*n2)"},{s:"n*vd + vd -> (n+1)*vd",assuming:{multiply:{commutative:!1}}},{s:"vd + n*vd -> (1+n)*vd",assuming:{multiply:{commutative:!1}}},{s:"n1*n3 + n2*n3 -> (n1+n2)*n3",assuming:{multiply:{commutative:!1}}},{s:"n^n1 * n -> n^(n1+1)",assuming:{divide:{total:!0},multiply:{commutative:!1}}},{s:"n1*n3^(-n4) + n2 * n3 -> (n1 + n2*n3^(n4 + 1))*n3^(-n4)",assuming:{multiply:{commutative:!1}}},{s:"n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)",assuming:{multiply:{commutative:!1}}},{l:"n*cd + cd",r:"(n+1)*cd"},{s:"cd*n + cd -> cd*(n+1)",assuming:{multiply:{commutative:!1}}},{s:"cd + cd*n -> cd*(1+n)",assuming:{multiply:{commutative:!1}}},p,{s:"(-n)*n1 -> -(n*n1)",assuming:{subtract:{total:!0}}},{s:"n1*(-n) -> -(n1*n)",assuming:{subtract:{total:!0},multiply:{commutative:!1}}},{s:"ce+ve -> ve+ce",assuming:{add:{commutative:!0}},imposeContext:{add:{commutative:!1}}},{s:"vd*cd -> cd*vd",assuming:{multiply:{commutative:!0}},imposeContext:{multiply:{commutative:!1}}},{l:"n+-n1",r:"n-n1"},{l:"n+-(n1)",r:"n-(n1)"},{s:"n*(n1^-1) -> n/n1",assuming:{multiply:{commutative:!0}}},{s:"n*n1^-n2 -> n/n1^n2",assuming:{multiply:{commutative:!0}}},{s:"n^-1 -> 1/n",assuming:{multiply:{commutative:!0}}},{l:"n^1",r:"n"},{s:"n*(n1/n2) -> (n*n1)/n2",assuming:{multiply:{associative:!0}}},{s:"n-(n1+n2) -> n-n1-n2",assuming:{addition:{associative:!0,commutative:!0}}},{l:"1*n",r:"n",imposeContext:{multiply:{commutative:!0}}},{s:"n1/(n2/n3) -> (n1*n3)/n2",assuming:{multiply:{associative:!0}}},{l:"n1/(-n2)",r:"-n1/n2"}];let H=0;function G(){return new T("_p"+H++)}function V(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:m(),n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};const i=n.consoleDebug;t=function(e,t){const r=[];for(let n=0;n ${t[r].r.toString()}`)),i){const t=o.toString({parenthesis:"all"});t!==e&&(console.log("Applying",a,"produced",t),e=t)}I(o,n.context)}s=o.toString({parenthesis:"all"})}return o}function W(e,t,r){let n=e;if(e)for(let i=0;i=2&&2===e.args.length){const n=function(e,t){const r=[];let n,i;const o=k(e);if(F(e,t))for(let t=0;t1&&(a=o(e.args.slice(0,t))),i=e.args.slice(t),n=1===i.length?i[0]:o(i),r.push(o([a,n]))}return r}(t,r);let i=[];for(let t=0;t2)throw Error("Unexpected non-binary associative function: "+e.toString());return[]}{let n=[];for(let i=0;i2)throw new Error("permuting >2 commutative non-associative rule arguments not yet implemented");const i=Q(e.args[0],t.args[1],r);if(0===i.length)return[];const o=Q(e.args[1],t.args[0],r);if(0===o.length)return[];n=[i,o]}i=function(e){if(0===e.length)return e;const t=e.reduce(X),r=[],n={};for(let e=0;e="a"&&e.name[1]<="z"?e.name.substring(0,2):e.name[0]){case"n":case"_p":i[0].placeholders[e.name]=t;break;case"c":case"cl":if(!Z(t))return[];i[0].placeholders[e.name]=t;break;case"v":if(Z(t))return[];i[0].placeholders[e.name]=t;break;case"vl":if(!ne(t))return[];i[0].placeholders[e.name]=t;break;case"cd":if(!mh(t))return[];i[0].placeholders[e.name]=t;break;case"vd":if(mh(t))return[];i[0].placeholders[e.name]=t;break;case"ce":if(!dh(t))return[];i[0].placeholders[e.name]=t;break;case"ve":if(dh(t))return[];i[0].placeholders[e.name]=t;break;default:throw new Error("Invalid symbol in rule: "+e.name)}}else{if(!(e instanceof N))return[];if(!l(e.value,t.value))return[]}return i}function K(e,t){if(e instanceof N&&t instanceof N){if(!l(e.value,t.value))return!1}else if(e instanceof T&&t instanceof T){if(e.name!==t.name)return!1}else{if(!(e instanceof M&&t instanceof M||e instanceof E&&t instanceof E))return!1;if(e instanceof M){if(e.op!==t.op||e.fn!==t.fn)return!1}else if(e instanceof E&&e.name!==t.name)return!1;if(e.args.length!==t.args.length)return!1;for(let r=0;r{let{typed:t,config:r,mathWithTransform:n,matrix:i,fraction:o,bignumber:a,AccessorNode:s,ArrayNode:u,ConstantNode:c,FunctionNode:l,IndexNode:f,ObjectNode:p,OperatorNode:m,SymbolNode:d}=e;const{isCommutative:h,isAssociative:g,allChildren:y,createMakeNodeFunction:x}=hh({FunctionNode:l,OperatorNode:m,SymbolNode:d}),v=t("simplifyConstant",{Node:e=>S(F(e,{})),"Node, Object":function(e,t){return S(F(e,t))}});function w(e){return b(e)?e.valueOf():e instanceof Array?e.map(w):E(e)?i(w(e.valueOf())):e}function N(e,t,r){try{return n[e].apply(null,t)}catch(i){return t=t.map(w),C(n[e].apply(null,t),r)}}const A=t({Fraction:function(e){let t;const r=e.s*e.n;return t=r<0?new m("-","unaryMinus",[new c(-r)]):new c(r),1===e.d?t:new m("/","divide",[t,new c(e.d)])},number:function(e){return e<0?T(new c(-e)):new c(e)},BigNumber:function(e){return e<0?T(new c(-e)):new c(e)},bigint:function(e){return e<0n?T(new c(-e)):new c(e)},Complex:function(e){throw new Error("Cannot convert Complex number to Node")},string:function(e){return new c(e)},Matrix:function(e){return new u(e.valueOf().map((e=>A(e))))}});function S(e){return X(e)?e:A(e)}function M(e,t){if(t&&!1!==t.exactFractions&&isFinite(e)&&o){const r=o(e),n=t&&"number"==typeof t.fractionsLimit?t.fractionsLimit:1/0;if(r.valueOf()===e&&r.n{if(!X(i)){const r=t.pop();if(X(r))return[r,i];try{return t.push(N(e,[r,i],n)),t}catch(e){t.push(r)}}t.push(S(t.pop()));const o=1===t.length?t[0]:r(t);return[r([o,S(i)])]}),[i]);return 1===o.length?o[0]:r([o[0],A(o[1])])}function F(e,t){switch(e.type){case"SymbolNode":return e;case"ConstantNode":switch(typeof e.value){case"number":case"bigint":return C(e.value,t);case"string":return e.value;default:if(!isNaN(e.value))return C(e.value,t)}return e;case"FunctionNode":if(n[e.name]&&n[e.name].rawArgs)return e;if(!["add","multiply"].includes(e.name)){const r=e.args.map((e=>F(e,t)));if(!r.some(X))try{return N(e.name,r,t)}catch(e){}if("size"===e.name&&1===r.length&&L(r[0])){const e=[];let t=r[0];for(;L(t);)e.push(t.items.length),t=t.items[0];return i(e)}return new l(e.name,r.map(S))}case"OperatorNode":{const r=e.fn.toString();let n,i;const o=x(e);if(K(e)&&e.isUnary())n=[F(e.args[0],t)],i=X(n[0])?o(n):N(r,n,t);else if(g(e,t.context))if(n=y(e,t.context),n=n.map((e=>F(e,t))),h(r,t.context)){const e=[],a=[];for(let t=0;t1?(i=D(r,e,o,t),a.unshift(i),i=D(r,a,o,t)):i=D(r,n,o,t)}else i=D(r,n,o,t);else n=e.args.map((e=>F(e,t))),i=D(r,n,o,t);return i}case"ParenthesisNode":return F(e.content,t);case"AccessorNode":return function(e,t,r){if(!J(t))return new s(S(e),S(t));if(L(e)||E(e)){const n=Array.from(t.dimensions);for(;n.length>0;)if(Z(n[0])&&"string"!=typeof n[0].value){const t=C(n.shift().value,r);L(e)?e=e.items[t-1]:(e=e.valueOf()[t-1])instanceof Array&&(e=i(e))}else{if(!(n.length>1&&Z(n[1])&&"string"!=typeof n[1].value))break;{const t=C(n[1].value,r),o=[],a=L(e)?e.items:e.valueOf();for(const r of a)if(L(r))o.push(r.items[t-1]);else{if(!E(e))break;o.push(r[t-1])}if(o.length!==a.length)break;e=L(e)?new u(o):i(o),n.splice(1,1)}}return n.length===t.dimensions.length?new s(S(e),t):n.length>0?(t=new f(n),new s(S(e),t)):e}if(Q(e)&&1===t.dimensions.length&&Z(t.dimensions[0])){const r=t.dimensions[0].value;return r in e.properties?e.properties[r]:new c}return new s(S(e),t)}(F(e.object,t),F(e.index,t),t);case"ArrayNode":{const r=e.items.map((e=>F(e,t)));return r.some(X)?new u(r.map(S)):i(r)}case"IndexNode":return new f(e.dimensions.map((e=>v(e,t))));case"ObjectNode":{const r={};for(const n in e.properties)r[n]=v(e.properties[n],t);return new p(r)}default:throw new Error(`Unimplemented node type in simplifyConstant: ${e.type}`)}}return v})),xh="simplifyCore",bh=de(xh,["typed","parse","equal","isZero","add","subtract","multiply","divide","pow","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","SymbolNode"],(e=>{let{typed:t,parse:r,equal:n,isZero:i,add:o,subtract:a,multiply:s,divide:u,pow:c,AccessorNode:l,ArrayNode:f,ConstantNode:p,FunctionNode:m,IndexNode:d,ObjectNode:h,OperatorNode:g,ParenthesisNode:y,SymbolNode:x}=e;const b=new p(0),v=new p(1),w=new p(!0),N=new p(!1);function E(e){return K(e)&&["and","not","or"].includes(e.op)}const{hasProperty:A,isCommutative:S}=hh({FunctionNode:m,OperatorNode:g,SymbolNode:x});function M(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const r=t?t.context:void 0;if(A(e,"trivial",r)){if(Y(e)&&1===e.args.length)return M(e.args[0],t);let r=!1,n=0;if(e.forEach((e=>{++n,1===n&&(r=M(e,t))})),1===n)return r}let o=e;if(Y(o)){const e=function(e){const t="OperatorNode:"+e;for(const e of yp)if(t in e)return e[t].op;return null}(o.name);if(!e)return new m(M(o.fn),o.args.map((e=>M(e,t))));if(o.args.length>2&&A(o,"associative",r))for(;o.args.length>2;){const t=o.args.pop(),r=o.args.pop();o.args.push(new g(e,o.name,[t,r]))}o=new g(e,o.name,o.args)}if(K(o)&&o.isUnary()){const e=M(o.args[0],t);if("~"===o.op&&K(e)&&e.isUnary()&&"~"===e.op)return e.args[0];if("not"===o.op&&K(e)&&e.isUnary()&&"not"===e.op&&E(e.args[0]))return e.args[0];let r=!0;if("-"===o.op&&K(e)&&(e.isBinary()&&"subtract"===e.fn&&(o=new g("-","subtract",[e.args[1],e.args[0]]),r=!1),e.isUnary()&&"-"===e.op))return e.args[0];if(r)return new g(o.op,o.fn,[e])}if(K(o)&&o.isBinary()){const e=M(o.args[0],t);let a=M(o.args[1],t);if("+"===o.op){if(Z(e)&&i(e.value))return a;if(Z(a)&&i(a.value))return e;K(a)&&a.isUnary()&&"-"===a.op&&(a=a.args[0],o=new g("-","subtract",[e,a]))}if("-"===o.op)return K(a)&&a.isUnary()&&"-"===a.op?M(new g("+","add",[e,a.args[0]]),t):Z(e)&&i(e.value)?M(new g("-","unaryMinus",[a])):Z(a)&&i(a.value)?e:new g(o.op,o.fn,[e,a]);if("*"===o.op){if(Z(e)){if(i(e.value))return b;if(n(e.value,1))return a}if(Z(a)){if(i(a.value))return b;if(n(a.value,1))return e;if(S(o,r))return new g(o.op,o.fn,[a,e],o.implicit)}return new g(o.op,o.fn,[e,a],o.implicit)}if("/"===o.op)return Z(e)&&i(e.value)?b:Z(a)&&n(a.value,1)?e:new g(o.op,o.fn,[e,a]);if("^"===o.op&&Z(a)){if(i(a.value))return v;if(n(a.value,1))return e}if("and"===o.op){if(Z(e)){if(!e.value)return N;if(E(a))return a;if(Z(a))return a.value?w:N}if(Z(a)){if(!a.value)return N;if(E(e))return e}}if("or"===o.op){if(Z(e)){if(e.value)return w;if(E(a))return a}if(Z(a)){if(a.value)return w;if(E(e))return e}}return new g(o.op,o.fn,[e,a])}if(K(o))return new g(o.op,o.fn,o.args.map((e=>M(e,t))));if(L(o))return new f(o.items.map((e=>M(e,t))));if(U(o))return new l(M(o.object,t),M(o.index,t));if(J(o))return new d(o.dimensions.map((e=>M(e,t))));if(Q(o)){const e={};for(const r in o.properties)e[r]=M(o.properties[r],t);return new h(e)}return o}return t(xh,{Node:M,"Node,Object":M})})),vh=de("resolve",["typed","parse","ConstantNode","FunctionNode","OperatorNode","ParenthesisNode"],(e=>{let{typed:t,parse:r,ConstantNode:n,FunctionNode:i,OperatorNode:o,ParenthesisNode:a}=e;function s(e,t){let u=arguments.length>2&&void 0!==arguments[2]?arguments[2]:new Set;if(!t)return e;if(ne(e)){if(u.has(e.name)){const e=Array.from(u).join(", ");throw new ReferenceError(`recursive loop of variable definitions among {${e}}`)}const i=t.get(e.name);if(X(i)){const r=new Set(u);return r.add(e.name),s(i,t,r)}return"number"==typeof i?r(String(i)):void 0!==i?new n(i):e}if(K(e)){const r=e.args.map((function(e){return s(e,t,u)}));return new o(e.op,e.fn,r,e.implicit)}if(ee(e))return new a(s(e.content,t,u));if(Y(e)){const r=e.args.map((function(e){return s(e,t,u)}));return new i(e.name,r)}return e.map((e=>s(e,t,u)))}return t("resolve",{Node:s,"Node, Map | null | undefined":s,"Node, Object":(e,t)=>s(e,d(t)),"Array | Matrix":t.referToSelf((e=>t=>t.map((t=>e(t))))),"Array | Matrix, null | undefined":t.referToSelf((e=>t=>t.map((t=>e(t))))),"Array, Object":t.referTo("Array,Map",(e=>(t,r)=>e(t,d(r)))),"Matrix, Object":t.referTo("Matrix,Map",(e=>(t,r)=>e(t,d(r)))),"Array | Matrix, Map":t.referToSelf((e=>(t,r)=>t.map((t=>e(t,r)))))})})),wh="symbolicEqual",Nh=de(wh,["parse","simplify","typed","OperatorNode"],(e=>{let{parse:t,simplify:r,typed:n,OperatorNode:i}=e;function o(e,t){let n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const o=new i("-","subtract",[e,t]),a=r(o,{},n);return Z(a)&&!a.value}return n(wh,{"Node, Node":o,"Node, Node, Object":o})})),Eh="derivative",Ah=de(Eh,["typed","config","parse","simplify","equal","isZero","numeric","ConstantNode","FunctionNode","OperatorNode","ParenthesisNode","SymbolNode"],(e=>{let{typed:t,config:r,parse:n,simplify:i,equal:o,isZero:a,numeric:s,ConstantNode:u,FunctionNode:c,OperatorNode:l,ParenthesisNode:f,SymbolNode:p}=e;function m(e,t){let r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{simplify:!0};const n={};y(n,e,t.name);const o=x(e,n);return r.simplify?i(o):o}function d(e){const t=n(e);if(!t.isSymbolNode)throw new TypeError(`Invalid variable. Cannot parse ${JSON.stringify(e)} into a variable in function derivative`);return t}const h=t(Eh,{"Node, SymbolNode":m,"Node, SymbolNode, Object":m,"Node, string":(e,t)=>m(e,d(t)),"Node, string, Object":(e,t,r)=>m(e,d(t),r)});h._simplify=!0,h.toTex=function(e){return g.apply(null,e.args)};const g=t("_derivTex",{"Node, SymbolNode":function(e,t){return Z(e)&&"string"===oe(e.value)?g(n(e.value).toString(),t.toString(),1):g(e.toTex(),t.toString(),1)},"Node, ConstantNode":function(e,t){if("string"===oe(t.value))return g(e,n(t.value));throw new Error("The second parameter to 'derivative' is a non-string constant")},"Node, SymbolNode, ConstantNode":function(e,t,r){return g(e.toString(),t.name,r.value)},"string, string, number":function(e,t,r){let n;return n=1===r?"{d\\over d"+t+"}":"{d^{"+r+"}\\over d"+t+"^{"+r+"}}",n+`\\left[${e}\\right]`}}),y=t("constTag",{"Object, ConstantNode, string":function(e,t){return e[t]=!0,!0},"Object, SymbolNode, string":function(e,t,r){return t.name!==r&&(e[t]=!0,!0)},"Object, ParenthesisNode, string":function(e,t,r){return y(e,t.content,r)},"Object, FunctionAssignmentNode, string":function(e,t,r){return t.params.includes(r)?y(e,t.expr,r):(e[t]=!0,!0)},"Object, FunctionNode | OperatorNode, string":function(e,t,r){if(t.args.length>0){let n=y(e,t.args[0],r);for(let i=1;i0){const n=e.args.filter((function(e){return void 0===t[e]})),i=1===n.length?n[0]:new l("*","multiply",n),o=r.concat(x(i,t));return new l("*","multiply",o)}return new l("+","add",e.args.map((function(r){return new l("*","multiply",e.args.map((function(e){return e===r?x(e,t):e.clone()})))})))}if("/"===e.op&&e.isBinary()){const r=e.args[0],n=e.args[1];return void 0!==t[n]?new l("/","divide",[x(r,t),n]):void 0!==t[r]?new l("*","multiply",[new l("-","unaryMinus",[r]),new l("/","divide",[x(n,t),new l("^","pow",[n.clone(),b(2)])])]):new l("/","divide",[new l("-","subtract",[new l("*","multiply",[x(r,t),n.clone()]),new l("*","multiply",[r.clone(),x(n,t)])]),new l("^","pow",[n.clone(),b(2)])])}if("^"===e.op&&e.isBinary()){const r=e.args[0],n=e.args[1];if(void 0!==t[r])return Z(r)&&(a(r.value)||o(r.value,1))?b(0):new l("*","multiply",[e,new l("*","multiply",[new c("log",[r.clone()]),x(n.clone(),t)])]);if(void 0!==t[n]){if(Z(n)){if(a(n.value))return b(0);if(o(n.value,1))return x(r,t)}const e=new l("^","pow",[r.clone(),new l("-","subtract",[n,b(1)])]);return new l("*","multiply",[n.clone(),new l("*","multiply",[x(r,t),e])])}return new l("*","multiply",[new l("^","pow",[r.clone(),n.clone()]),new l("+","add",[new l("*","multiply",[x(r,t),new l("/","divide",[n.clone(),r.clone()])]),new l("*","multiply",[x(n,t),new c("log",[r.clone()])])])])}throw new Error('Cannot process operator "'+e.op+'" in derivative: the operator is not supported, undefined, or the number of arguments passed to it are not supported')}});function b(e,t){return new u(s(e,t||xe(String(e),r)))}return h})),Sh="rationalize",Mh=de(Sh,["config","typed","equal","isZero","add","subtract","multiply","divide","pow","parse","simplifyConstant","simplifyCore","simplify","?bignumber","?fraction","mathWithTransform","matrix","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","SymbolNode","ParenthesisNode"],(e=>{let{config:t,typed:r,equal:n,isZero:i,add:o,subtract:a,multiply:s,divide:u,pow:c,parse:l,simplifyConstant:f,simplifyCore:p,simplify:m,fraction:d,bignumber:h,mathWithTransform:g,matrix:y,AccessorNode:x,ArrayNode:b,ConstantNode:v,FunctionNode:w,IndexNode:N,ObjectNode:E,OperatorNode:A,SymbolNode:S,ParenthesisNode:M}=e;function C(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];const n=function(){const e=[p,{l:"n+n",r:"2*n"},{l:"n+-n",r:"0"},f,{l:"n*(n1^-1)",r:"n/n1"},{l:"n*n1^-n2",r:"n/n1^n2"},{l:"n1^-1",r:"1/n1"},{l:"n*(n1/n2)",r:"(n*n1)/n2"},{l:"1*n",r:"n"}],t=[{l:"(-n1)/(-n2)",r:"n1/n2"},{l:"(-n1)*(-n2)",r:"n1*n2"},{l:"n1--n2",r:"n1+n2"},{l:"n1-n2",r:"n1+(-n2)"},{l:"(n1+n2)*n3",r:"(n1*n3 + n2*n3)"},{l:"n1*(n2+n3)",r:"(n1*n2+n1*n3)"},{l:"c1*n + c2*n",r:"(c1+c2)*n"},{l:"c1*n + n",r:"(c1+1)*n"},{l:"c1*n - c2*n",r:"(c1-c2)*n"},{l:"c1*n - n",r:"(c1-1)*n"},{l:"v/c",r:"(1/c)*v"},{l:"v/-c",r:"-(1/c)*v"},{l:"-v*-c",r:"c*v"},{l:"-v*c",r:"-c*v"},{l:"v*-c",r:"-c*v"},{l:"v*c",r:"c*v"},{l:"-(-n1*n2)",r:"(n1*n2)"},{l:"-(n1*n2)",r:"(-n1*n2)"},{l:"-(-n1+n2)",r:"(n1-n2)"},{l:"-(n1+n2)",r:"(-n1-n2)"},{l:"(n1^n2)^n3",r:"(n1^(n2*n3))"},{l:"-(-n1/n2)",r:"(n1/n2)"},{l:"-(n1/n2)",r:"(-n1/n2)"}],r=[{l:"(n1/(n2/n3))",r:"((n1*n3)/n2)"},{l:"(n1/n2/n3)",r:"(n1/(n2*n3))"}],n={};return n.firstRules=e.concat(t,r),n.distrDivRules=[{l:"(n1/n2 + n3/n4)",r:"((n1*n4 + n3*n2)/(n2*n4))"},{l:"(n1/n2 + n3)",r:"((n1 + n3*n2)/n2)"},{l:"(n1 + n2/n3)",r:"((n1*n3 + n2)/n3)"}],n.sucDivRules=r,n.firstRulesAgain=e.concat(t),n.finalRules=[p,{l:"n*-n",r:"-n^2"},{l:"n*n",r:"n^2"},f,{l:"n*-n^n1",r:"-n^(n1+1)"},{l:"n*n^n1",r:"n^(n1+1)"},{l:"n^n1*-n^n2",r:"-n^(n1+n2)"},{l:"n^n1*n^n2",r:"n^(n1+n2)"},{l:"n^n1*-n",r:"-n^(n1+1)"},{l:"n^n1*n",r:"n^(n1+1)"},{l:"n^n1/-n",r:"-n^(n1-1)"},{l:"n^n1/n",r:"n^(n1-1)"},{l:"n/-n^n1",r:"-n^(1-n1)"},{l:"n/n^n1",r:"n^(1-n1)"},{l:"n^n1/-n^n2",r:"n^(n1-n2)"},{l:"n^n1/n^n2",r:"n^(n1-n2)"},{l:"n1+(-n2*n3)",r:"n1-n2*n3"},{l:"v*(-c)",r:"-c*v"},{l:"n1+-n2",r:"n1-n2"},{l:"v*c",r:"c*v"},{l:"(n1^n2)^n3",r:"(n1^(n2*n3))"}],n}(),i=function(e,t,r,n){const i=[],o=m(e,n,t,{exactFractions:!1}),a="+-*"+((r=!!r)?"/":"");!function e(t){const r=t.type;if("FunctionNode"===r)throw new Error("There is an unsolved function call");if("OperatorNode"===r)if("^"===t.op){if("ConstantNode"!==t.args[1].type||!ye(parseFloat(t.args[1].value)))throw new Error("There is a non-integer exponent");e(t.args[0])}else{if(!a.includes(t.op))throw new Error("Operator "+t.op+" invalid in polynomial expression");for(let r=0;r=1){let t,r;e=T(e);let i,o=!0,u=!1;for(e=m(e,n.firstRules,{},a);r=o?n.distrDivRules:n.sucDivRules,o=!o,i=(e=m(e,r,{},s)).toString(),i!==t;)u=!0,t=i;u&&(e=m(e,n.firstRulesAgain,{},a)),e=m(e,n.finalRules,{},a)}const u=[],c={};return"OperatorNode"===e.type&&e.isBinary()&&"/"===e.op?(1===o&&(e.args[0]=D(e.args[0],u),e.args[1]=D(e.args[1])),r&&(c.numerator=e.args[0],c.denominator=e.args[1])):(1===o&&(e=D(e,u)),r&&(c.numerator=e,c.denominator=null)),r?(c.coefficients=u,c.variables=i.variables,c.expression=e,c):e}return r(Sh,{Node:C,"Node, boolean":(e,t)=>C(e,{},t),"Node, Object":C,"Node, Object, boolean":C});function T(e,t,r){const n=e.type,i=arguments.length>1;if("OperatorNode"===n&&e.isBinary()){let n,o=!1;if("^"===e.op&&("ParenthesisNode"!==e.args[0].type&&"OperatorNode"!==e.args[0].type||"ConstantNode"!==e.args[1].type||(n=parseFloat(e.args[1].value),o=n>=2&&ye(n))),o){if(n>2){const t=e.args[0],r=new A("^","pow",[e.args[0].cloneDeep(),new v(n-1)]);e=new A("*","multiply",[t,r])}else e=new A("*","multiply",[e.args[0],e.args[0].cloneDeep()]);i&&("content"===r?t.content=e:t.args[r]=e)}}if("ParenthesisNode"===n)T(e.content,e,"content");else if("ConstantNode"!==n&&"SymbolNode"!==n)for(let t=0;tr&&(t[e]=0),t[e]+=a.cte*("+"===a.oper?1:-1),void(r=Math.max(e,r))}a.cte=e,""===a.fire&&(t[0]+=a.cte*("+"===a.oper?1:-1))}}}(e,null,{cte:1,oper:"+",fire:""}),r=t.length-1;let i,o=!0;for(let e=r;e>=0;e--){if(0===t[e])continue;let r=new v(o?t[e]:Math.abs(t[e]));const a=t[e]<0?"-":"+";if(e>0){let i=new S(n);if(e>1){const t=new v(e);i=new A("^","pow",[i,t])}r=-1===t[e]&&o?new A("-","unaryMinus",[i]):1===Math.abs(t[e])?i:new A("*","multiply",[r,i])}i=o?r:"+"===a?new A("+","add",[i,r]):new A("-","subtract",[i,r]),o=!1}return o?new v(0):i}})),Ch="zpk2tf",Th=de(Ch,["typed","add","multiply","Complex","number"],(e=>{let{typed:t,add:r,multiply:n,Complex:i,number:o}=e;return t(Ch,{"Array,Array,number":function(e,t,r){return a(e,t,r)},"Array,Array":function(e,t){return a(e,t,1)},"Matrix,Matrix,number":function(e,t,r){return a(e.valueOf(),t.valueOf(),r)},"Matrix,Matrix":function(e,t){return a(e.valueOf(),t.valueOf(),1)}});function a(e,t,r){e.some((e=>"BigNumber"===e.type))&&(e=e.map((e=>o(e)))),t.some((e=>"BigNumber"===e.type))&&(t=t.map((e=>o(e))));let a=[i(1,0)],u=[i(1,0)];for(let t=0;t=0&&a-i{let{typed:t,add:r,multiply:n,Complex:i,divide:o,matrix:a}=e;return t(Dh,{"Array, Array":function(e,t){return s(e,t,u(512))},"Array, Array, Array":function(e,t,r){return s(e,t,r)},"Array, Array, number":function(e,t,r){if(r<0)throw new Error("w must be a positive number");return s(e,t,u(r))},"Matrix, Matrix":function(e,t){const r=u(512),{w:n,h:i}=s(e.valueOf(),t.valueOf(),r);return{w:a(n),h:a(i)}},"Matrix, Matrix, Matrix":function(e,t,r){const{h:n}=s(e.valueOf(),t.valueOf(),r.valueOf());return{h:a(n),w:a(r)}},"Matrix, Matrix, number":function(e,t,r){if(r<0)throw new Error("w must be a positive number");const n=u(r),{h:i}=s(e.valueOf(),t.valueOf(),n);return{h:a(i),w:a(n)}}});function s(e,t,a){const s=[],u=[];for(let o=0;o{let{classes:t}=e;return function(e,r){const n=t[r&&r.mathjs];return n&&"function"==typeof n.fromJSON?n.fromJSON(r):r}})),Bh=de("replacer",[],(()=>function(e,t){return"number"!=typeof t||isFinite(t)&&!isNaN(t)?"bigint"==typeof t?{mathjs:"bigint",value:String(t)}:t:{mathjs:"number",value:String(t)}})),_h=Math.PI,zh=2*Math.PI,Ih=Math.E,kh=de("true",[],(()=>!0)),qh=de("false",[],(()=>!1)),Rh=de("null",[],(()=>null)),Ph=tg("Infinity",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1/0):1/0})),jh=tg("NaN",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(NaN):NaN})),Uh=tg("pi",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?gl(r):_h})),Lh=tg("tau",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?yl(r):zh})),$h=tg("e",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?dl(r):Ih})),Hh=tg("phi",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?hl(r):1.618033988749895})),Gh=tg("LN2",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(2).ln():Math.LN2})),Zh=tg("LN10",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(10).ln():Math.LN10})),Vh=tg("LOG2E",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1).div(new r(2).ln()):Math.LOG2E})),Wh=tg("LOG10E",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1).div(new r(10).ln()):Math.LOG10E})),Yh=tg("SQRT1_2",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r("0.5").sqrt():Math.SQRT1_2})),Jh=tg("SQRT2",["config","?BigNumber"],(e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(2).sqrt():Math.SQRT2})),Xh=tg("i",["Complex"],(e=>{let{Complex:t}=e;return t.I})),Qh=de("PI",["pi"],(e=>{let{pi:t}=e;return t})),Kh=de("E",["e"],(e=>{let{e:t}=e;return t})),eg=de("version",[],(()=>"13.2.0"));function tg(e,t,r){return de(e,t,r,{recreateOnConfigChange:!0})}const rg=Qg("speedOfLight","299792458","m s^-1"),ng=Qg("gravitationConstant","6.67430e-11","m^3 kg^-1 s^-2"),ig=Qg("planckConstant","6.62607015e-34","J s"),og=Qg("reducedPlanckConstant","1.0545718176461565e-34","J s"),ag=Qg("magneticConstant","1.25663706212e-6","N A^-2"),sg=Qg("electricConstant","8.8541878128e-12","F m^-1"),ug=Qg("vacuumImpedance","376.730313667","ohm"),cg=Qg("coulomb","8.987551792261171e9","N m^2 C^-2"),lg=Qg("elementaryCharge","1.602176634e-19","C"),fg=Qg("bohrMagneton","9.2740100783e-24","J T^-1"),pg=Qg("conductanceQuantum","7.748091729863649e-5","S"),mg=Qg("inverseConductanceQuantum","12906.403729652257","ohm"),dg=Qg("magneticFluxQuantum","2.0678338484619295e-15","Wb"),hg=Qg("nuclearMagneton","5.0507837461e-27","J T^-1"),gg=Qg("klitzing","25812.807459304513","ohm"),yg=Qg("bohrRadius","5.29177210903e-11","m"),xg=Qg("classicalElectronRadius","2.8179403262e-15","m"),bg=Qg("electronMass","9.1093837015e-31","kg"),vg=Qg("fermiCoupling","1.1663787e-5","GeV^-2"),wg=Kg("fineStructure",.0072973525693),Ng=Qg("hartreeEnergy","4.3597447222071e-18","J"),Eg=Qg("protonMass","1.67262192369e-27","kg"),Ag=Qg("deuteronMass","3.3435830926e-27","kg"),Sg=Qg("neutronMass","1.6749271613e-27","kg"),Mg=Qg("quantumOfCirculation","3.6369475516e-4","m^2 s^-1"),Cg=Qg("rydberg","10973731.568160","m^-1"),Tg=Qg("thomsonCrossSection","6.6524587321e-29","m^2"),Dg=Kg("weakMixingAngle",.2229),Fg=Kg("efimovFactor",22.7),Og=Qg("atomicMass","1.66053906660e-27","kg"),Bg=Qg("avogadro","6.02214076e23","mol^-1"),_g=Qg("boltzmann","1.380649e-23","J K^-1"),zg=Qg("faraday","96485.33212331001","C mol^-1"),Ig=Qg("firstRadiation","3.7417718521927573e-16","W m^2"),kg=Qg("loschmidt","2.686780111798444e25","m^-3"),qg=Qg("gasConstant","8.31446261815324","J K^-1 mol^-1"),Rg=Qg("molarPlanckConstant","3.990312712893431e-10","J s mol^-1"),Pg=Qg("molarVolume","0.022413969545014137","m^3 mol^-1"),jg=Kg("sackurTetrode",-1.16487052358),Ug=Qg("secondRadiation","0.014387768775039337","m K"),Lg=Qg("stefanBoltzmann","5.67037441918443e-8","W m^-2 K^-4"),$g=Qg("wienDisplacement","2.897771955e-3","m K"),Hg=Qg("molarMass","0.99999999965e-3","kg mol^-1"),Gg=Qg("molarMassC12","11.9999999958e-3","kg mol^-1"),Zg=Qg("gravity","9.80665","m s^-2"),Vg=Qg("planckLength","1.616255e-35","m"),Wg=Qg("planckMass","2.176435e-8","kg"),Yg=Qg("planckTime","5.391245e-44","s"),Jg=Qg("planckCharge","1.87554603778e-18","C"),Xg=Qg("planckTemperature","1.416785e+32","K");function Qg(e,t,r){return de(e,["config","Unit","BigNumber"],(e=>{let{config:n,Unit:i,BigNumber:o}=e;const a=new i("BigNumber"===n.number?new o(t):parseFloat(t),r);return a.fixPrefix=!0,a}))}function Kg(e,t){return de(e,["config","BigNumber"],(e=>{let{config:r,BigNumber:n}=e;return"BigNumber"===r.number?new n(t):t}))}const ey=de("apply",["typed","isInteger"],(e=>{let{typed:t,isInteger:r}=e;const n=mo({typed:t,isInteger:r});return t("apply",{"...any":function(e){const t=e[1];h(t)?e[1]=t-1:g(t)&&(e[1]=t.minus(1));try{return n.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),ty=de("column",["typed","Index","matrix","range"],(e=>{let{typed:t,Index:r,matrix:n,range:i}=e;const o=hs({typed:t,Index:r,matrix:n,range:i});return t("column",{"...any":function(e){const t=e.length-1,r=e[t];h(r)&&(e[t]=r-1);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0});function ry(e,t,r){const n=e.filter((function(e){return ne(e)&&!(e.name in t)&&!r.has(e.name)}))[0];if(!n)throw new Error('No undefined variable found in inline expression "'+e+'"');const i=n.name,o=new Map,a=new f(r,o,new Set([i])),s=e.compile();return function(e){return o.set(i,e),s.evaluate(a)}}r(3921);const ny=de("transformCallback",["typed"],(e=>{let{typed:t}=e;return function(e,n){return t.isTypedFunction(e)?r(e,n):iy(e,e.length,n)};function r(e,n){const i=Object.fromEntries(Object.entries(e.signatures).map((e=>{let[i,o]=e;const a=i.split(",").length;return t.isTypedFunction(o)?[i,r(o,n)]:[i,iy(o,a,n)]})));return"string"==typeof e.name?t(e.name,i):t(i)}}));function iy(e,t,r){return t===r?e:t===r+1?function(){for(var t=arguments.length,n=new Array(t),i=0;ir+1?function(){for(var t=arguments.length,n=new Array(t),i=0;ie+1))}const ay=de("filter",["typed"],(e=>{let{typed:t}=e;function r(e,r,i){const o=Ns({typed:t}),a=ny({typed:t});if(0===e.length)return o();let s=e[0];if(1===e.length)return o(s);const u=e.length-1;let c=e[u];return s&&(s=n(s,i)),c&&(c=ne(c)||W(c)?n(c,i):ry(c,r,i)),o(s,a(c,u))}function n(e,t){return e.compile().evaluate(t)}return r.rawArgs=!0,r}),{isTransformFunction:!0}),sy=de("forEach",["typed"],(e=>{let{typed:t}=e;const r=Cs({typed:t}),n=ny({typed:t});function i(e,t,i){if(0===e.length)return r();let a=e[0];if(1===e.length)return r(a);const s=e.length-1;let u=e[s];return a&&(a=o(a,i)),u&&(u=ne(u)||W(u)?o(u,i):ry(u,t,i)),r(a,n(u,s))}function o(e,t){return e.compile().evaluate(t)}return i.rawArgs=!0,i}),{isTransformFunction:!0}),uy=de("index",["Index","getMatrixDataType"],(e=>{let{Index:t,getMatrixDataType:r}=e;return function(){const e=[];for(let t=0,n=arguments.length;t0?0:2;else if(n&&!0===n.isSet)n=n.map((function(e){return e-1}));else if(N(n)||E(n))"boolean"!==r(n)&&(n=n.map((function(e){return e-1})));else if(h(n))n--;else if(g(n))n=n.toNumber()-1;else if("string"!=typeof n)throw new TypeError("Dimension must be an Array, Matrix, number, string, or Range");e[t]=n}const n=new t;return t.apply(n,e),n}}),{isTransformFunction:!0}),cy=de("map",["typed"],(e=>{let{typed:t}=e;const r=ks({typed:t}),n=ny({typed:t});function i(e,t,i){if(0===e.length)return r();if(1===e.length)return r(e[0]);const o=e.length-1;let a=e.slice(0,o),s=e[o];return a=a.map((e=>u(e,i))),s&&(s=ne(s)||W(s)?u(s,i):ry(s,t,i)),r(...a,n(s,o));function u(e,t){return e.compile().evaluate(t)}}return i.rawArgs=!0,i}),{isTransformFunction:!0});function ly(e){if(2===e.length&&A(e[0])){const r=(e=e.slice())[1];(h(t=r)||g(t))&&(e[1]=function(e){return h(e)?e-1:g(e)?e.minus(1):e}(r))}var t;return e}const fy=de("max",["typed","config","numeric","larger"],(e=>{let{typed:t,config:r,numeric:n,larger:i}=e;const o=ol({typed:t,config:r,numeric:n,larger:i});return t("max",{"...any":function(e){e=ly(e);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),py=de("mean",["typed","add","divide"],(e=>{let{typed:t,add:r,divide:n}=e;const i=ud({typed:t,add:r,divide:n});return t("mean",{"...any":function(e){e=ly(e);try{return i.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),my=de("min",["typed","config","numeric","smaller"],(e=>{let{typed:t,config:r,numeric:n,smaller:i}=e;const o=al({typed:t,config:r,numeric:n,smaller:i});return t("min",{"...any":function(e){e=ly(e);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),dy=de("range",["typed","config","?matrix","?bignumber","smaller","smallerEq","larger","largerEq","add","isPositive"],(e=>{let{typed:t,config:r,matrix:n,bignumber:i,smaller:o,smallerEq:a,larger:s,largerEq:u,add:c,isPositive:l}=e;const f=Hs({typed:t,config:r,matrix:n,bignumber:i,smaller:o,smallerEq:a,larger:s,largerEq:u,add:c,isPositive:l});return t("range",{"...any":function(e){return"boolean"!=typeof e[e.length-1]&&e.push(!0),f.apply(null,e)}})}),{isTransformFunction:!0}),hy=de("row",["typed","Index","matrix","range"],(e=>{let{typed:t,Index:r,matrix:n,range:i}=e;const o=Qs({typed:t,Index:r,matrix:n,range:i});return t("row",{"...any":function(e){const t=e.length-1,r=e[t];h(r)&&(e[t]=r-1);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),gy=de("subset",["typed","matrix","zeros","add"],(e=>{let{typed:t,matrix:r,zeros:n,add:i}=e;const o=iu({typed:t,matrix:r,zeros:n,add:i});return t("subset",{"...any":function(e){try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),yy=de("concat",["typed","matrix","isInteger"],(e=>{let{typed:t,matrix:r,isInteger:n}=e;const i=ms({typed:t,matrix:r,isInteger:n});return t("concat",{"...any":function(e){const t=e.length-1,r=e[t];h(r)?e[t]=r-1:g(r)&&(e[t]=r.minus(1));try{return i.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),xy="diff",by=de(xy,["typed","matrix","subtract","number","bignumber"],(e=>{let{typed:t,matrix:r,subtract:n,number:i,bignumber:o}=e;const a=Rs({typed:t,matrix:r,subtract:n,number:i,bignumber:o});return t(xy,{"...any":function(e){e=ly(e);try{return a.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),vy=de("std",["typed","map","sqrt","variance"],(e=>{let{typed:t,map:r,sqrt:n,variance:i}=e;const o=yd({typed:t,map:r,sqrt:n,variance:i});return t("std",{"...any":function(e){e=ly(e);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),wy=de("sum",["typed","config","add","numeric"],(e=>{let{typed:t,config:r,add:n,numeric:i}=e;const o=id({typed:t,config:r,add:n,numeric:i});return t("sum",{"...any":function(e){e=ly(e);try{return o.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),Ny=de("quantileSeq",["typed","bignumber","add","subtract","divide","multiply","partitionSelect","compare","isInteger","smaller","smallerEq","larger"],(e=>{let{typed:t,bignumber:r,add:n,subtract:i,divide:o,multiply:a,partitionSelect:s,compare:u,isInteger:c,smaller:l,smallerEq:f,larger:p}=e;const m=gd({typed:t,bignumber:r,add:n,subtract:i,divide:o,multiply:a,partitionSelect:s,compare:u,isInteger:c,smaller:l,smallerEq:f,larger:p});return t("quantileSeq",{"Array | Matrix, number | BigNumber":m,"Array | Matrix, number | BigNumber, number":(e,t,r)=>m(e,t,d(r)),"Array | Matrix, number | BigNumber, boolean":m,"Array | Matrix, number | BigNumber, boolean, number":(e,t,r,n)=>m(e,t,r,d(n)),"Array | Matrix, Array | Matrix":m,"Array | Matrix, Array | Matrix, number":(e,t,r)=>m(e,t,d(r)),"Array | Matrix, Array | Matrix, boolean":m,"Array | Matrix, Array | Matrix, boolean, number":(e,t,r,n)=>m(e,t,r,d(n))});function d(e){return ly([[],e])[1]}}),{isTransformFunction:!0}),Ey="cumsum",Ay=de(Ey,["typed","add","unaryPlus"],(e=>{let{typed:t,add:r,unaryPlus:n}=e;const i=ad({typed:t,add:r,unaryPlus:n});return t(Ey,{"...any":function(e){if(2===e.length&&A(e[0])){const t=e[1];h(t)?e[1]=t-1:g(t)&&(e[1]=t.minus(1))}try{return i.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),Sy="variance",My=de(Sy,["typed","add","subtract","multiply","divide","apply","isNaN"],(e=>{let{typed:t,add:r,subtract:n,multiply:i,divide:o,apply:a,isNaN:s}=e;const u=dd({typed:t,add:r,subtract:n,multiply:i,divide:o,apply:a,isNaN:s});return t(Sy,{"...any":function(e){e=ly(e);try{return u.apply(null,e)}catch(e){throw fp(e)}}})}),{isTransformFunction:!0}),Cy="print",Ty=de(Cy,["typed","matrix","zeros","add"],(e=>{let{typed:t,matrix:r,zeros:n,add:i}=e;const o=Pu({typed:t,matrix:r,zeros:n,add:i});return t(Cy,{"string, Object | Array":function(e,t){return o(a(e),t)},"string, Object | Array, number | Object":function(e,t,r){return o(a(e),t,r)}});function a(e){return e.replace(qu,(e=>"$"+e.slice(1).split(".").map((function(e){return!isNaN(e)&&e.length>0?parseInt(e)-1:e})).join(".")))}}),{isTransformFunction:!0}),Dy=de("and",["typed","matrix","zeros","add","equalScalar","not","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,not:o,concat:a}=e;const s=Ec({typed:t,matrix:r,equalScalar:n,zeros:i,not:o,concat:a});function u(e,t,r){const n=e[0].compile().evaluate(r);if(!A(n)&&!s(n,!0))return!1;const i=e[1].compile().evaluate(r);return s(n,i)}return u.rawArgs=!0,u}),{isTransformFunction:!0}),Fy=de("or",["typed","matrix","equalScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o}=e;const a=ls({typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o});function s(e,t,r){const n=e[0].compile().evaluate(r);if(!A(n)&&a(n,!1))return!0;const i=e[1].compile().evaluate(r);return a(n,i)}return s.rawArgs=!0,s}),{isTransformFunction:!0}),Oy=de("bitAnd",["typed","matrix","zeros","add","equalScalar","not","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,not:o,concat:a}=e;const s=Ga({typed:t,matrix:r,equalScalar:n,zeros:i,not:o,concat:a});function u(e,t,r){const n=e[0].compile().evaluate(r);if(!A(n)){if(isNaN(n))return NaN;if(0===n||!1===n)return 0}const i=e[1].compile().evaluate(r);return s(n,i)}return u.rawArgs=!0,u}),{isTransformFunction:!0}),By=de("bitOr",["typed","matrix","equalScalar","DenseMatrix","concat"],(e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o}=e;const a=Ya({typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:o});function s(e,t,r){const n=e[0].compile().evaluate(r);if(!A(n)){if(isNaN(n))return NaN;if(-1===n)return-1;if(!0===n)return 1}const i=e[1].compile().evaluate(r);return a(n,i)}return s.rawArgs=!0,s}),{isTransformFunction:!0});var _y=r(1504);const zy={relTol:1e-12,absTol:1e-15,matrix:"Matrix",number:"number",numberFallback:"number",precision:64,predictable:!1,randomSeed:null},Iy=["Matrix","Array"],ky=["number","BigNumber","Fraction"];function qy(e,t){function r(n){if(n){if(void 0!==n.epsilon){console.warn('Warning: The configuration option "epsilon" is deprecated. Use "relTol" and "absTol" instead.');const e=ae(n);return e.relTol=n.epsilon,e.absTol=.001*n.epsilon,delete e.epsilon,r(e)}const i=ae(e);Ry(n,"matrix",Iy),Ry(n,"number",ky),ue(e,n);const o=ae(e),a=ae(n);return t("config",o,i,a),o}return ae(e)}return r.MATRIX_OPTIONS=Iy,r.NUMBER_OPTIONS=ky,Object.keys(zy).forEach((t=>{Object.defineProperty(r,t,{get:()=>e[t],enumerable:!0,configurable:!0})})),r}function Ry(e,t,r){void 0===e[t]||r.includes(e[t])||console.warn('Warning: Unknown value "'+e[t]+'" for configuration option "'+t+'". Available options: '+r.map((e=>JSON.stringify(e))).join(", ")+".")}const Py=function e(r,n){const i=Wr({},zy,n);if("function"!=typeof Object.create)throw new Error("ES5 not supported by this JavaScript engine. Please load the es5-shim and es5-sham library for compatibility.");const o=function(e){const t=new _y;return e.on=t.on.bind(t),e.off=t.off.bind(t),e.once=t.once.bind(t),e.emit=t.emit.bind(t),e}({isNumber:h,isComplex:x,isBigNumber:g,isBigInt:y,isFraction:b,isUnit:v,isString:w,isArray:N,isMatrix:E,isCollection:A,isDenseMatrix:S,isSparseMatrix:M,isRange:C,isIndex:T,isBoolean:D,isResultSet:F,isHelp:O,isFunction:B,isDate:_,isRegExp:z,isObject:I,isMap:k,isPartitionedMap:q,isObjectWrappingMap:R,isNull:P,isUndefined:j,isAccessorNode:U,isArrayNode:L,isAssignmentNode:$,isBlockNode:H,isConditionalNode:G,isConstantNode:Z,isFunctionAssignmentNode:W,isFunctionNode:Y,isIndexNode:J,isNode:X,isObjectNode:Q,isOperatorNode:K,isParenthesisNode:ee,isRangeNode:te,isRelationalNode:re,isSymbolNode:ne,isChain:ie});o.config=qy(i,o.emit),o.expression={transform:{},mathWithTransform:{config:o.config}};const a={};function s(){for(var e=arguments.length,t=new Array(e),r=0;r2&&void 0!==arguments[2]?arguments[2]:t.fn;if(o.includes("."))throw new Error("Factory name should not contain a nested path. Name: "+JSON.stringify(o));const s=l(t)?r.expression.transform:r,u=o in r.expression.transform,f=me(s,o)?s[o]:void 0,p=function(){const n={};t.dependencies.map(ge).forEach((e=>{if(e.includes("."))throw new Error("Factory dependency should not contain a nested path. Name: "+JSON.stringify(e));"math"===e?n.math=r:"mathWithTransform"===e?n.mathWithTransform=r.expression.mathWithTransform:"classes"===e?n.classes=r:n[e]=r[e]}));const a=t(n);if(a&&"function"==typeof a.transform)throw new Error('Transforms cannot be attached to factory functions. Please create a separate function for it with export const path = "expression.transform"');if(void 0===f||i.override)return a;if(e.isTypedFunction(f)&&e.isTypedFunction(a))return e(f,a);if(i.silent)return f;throw new Error('Cannot import "'+o+'": already exists')};t.meta&&!1===t.meta.lazy?(s[o]=p(),f&&u?a(o):(l(t)||c(t))&&pe(r.expression.mathWithTransform,o,(()=>s[o]))):(pe(s,o,p),f&&u?a(o):(l(t)||c(t))&&pe(r.expression.mathWithTransform,o,(()=>s[o]))),n[o]=t,r.emit("import",o,p)}function u(e){return!me(f,e)}function c(e){return!(e.fn.includes(".")||me(f,e.fn)||e.meta&&e.meta.isClass)}function l(e){return void 0!==e&&void 0!==e.meta&&!0===e.meta.isTransformFunction||!1}const f={expression:!0,type:!0,docs:!0,error:!0,json:!0,chain:!0};return function(e,t){const r=arguments.length;if(1!==r&&2!==r)throw new Qo("import",r,1,2);t||(t={});const n={};!function e(r,n,i){if(Array.isArray(n))n.forEach((t=>e(r,t)));else if("object"==typeof n)for(const t in n)me(n,t)&&e(r,n[t],t);else if(he(n)||void 0!==i){const e=he(n)?l(n)?n.fn+".transform":n.fn:i;if(me(r,e)&&r[e]!==n&&!t.silent)throw new Error('Cannot import "'+e+'" twice');r[e]=n}else if(!t.silent)throw new TypeError("Factory, Object, or Array expected")}(n,e);for(const e in n)if(me(n,e)){const r=n[e];if(he(r))s(r,t);else if("function"==typeof(o=r)||"number"==typeof o||"string"==typeof o||"boolean"==typeof o||null===o||v(o)||x(o)||g(o)||b(o)||E(o)||Array.isArray(o))i(e,r,t);else if(!t.silent)throw new TypeError("Factory, Object, or Array expected")}var o}}(s,0,o,a);return o.import=u,o.on("config",(()=>{Object.values(a).forEach((e=>{e&&e.meta&&e.meta.recreateOnConfigChange&&u(e,{override:!0})}))})),o.create=e.bind(null,r),o.factory=de,o.import(Object.values(le(r))),o.ArgumentsError=Qo,o.DimensionError=an,o.IndexError=sn,o}(e)})(),n.default})())); +//# sourceMappingURL=math.js.map \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.LICENSE.txt b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.LICENSE.txt new file mode 100644 index 0000000..0730d65 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.LICENSE.txt @@ -0,0 +1,49 @@ +/*! + * decimal.js v10.4.3 + * An arbitrary-precision Decimal type for JavaScript. + * https://github.com/MikeMcl/decimal.js + * Copyright (c) 2022 Michael Mclaughlin + * MIT Licence + */ + +/** + * @license Complex.js v2.1.1 12/05/2020 + * + * Copyright (c) 2020, Robert Eisele (robert@xarg.org) + * Dual licensed under the MIT or GPL Version 2 licenses. + **/ + +/** + * @license Fraction.js v4.3.7 31/08/2023 + * https://www.xarg.org/2014/03/rational-numbers-in-javascript/ + * + * Copyright (c) 2023, Robert Eisele (robert@raw.org) + * Dual licensed under the MIT or GPL Version 2 licenses. + **/ + +/** + * math.js + * https://github.com/josdejong/mathjs + * + * Math.js is an extensive math library for JavaScript and Node.js, + * It features real and complex numbers, units, matrices, a large set of + * mathematical functions, and a flexible expression parser. + * + * @version 13.2.0 + * @date 2024-10-02 + * + * @license + * Copyright (C) 2013-2024 Jos de Jong + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy + * of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.map b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.map new file mode 100644 index 0000000..52766a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/math.js.map @@ -0,0 +1 @@ +{"version":3,"file":"math.js","mappings":"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uB,YAAa,yCACbqrF,SAAU,CACR,aACA,kBACA,aACA,kBACA,yBAEFK,QAAS,CACP,MACA,MACA,OACA,UjE4WF1zE,MkE/XuB,CACvBv/B,KAAM,QACNiuB,SAAU,aACVwnB,OAAQ,CACN,YAEFluB,YAAa,4CACbqrF,SAAU,CACR,iBACA,eACA,SACA,uBACA,kBAEFK,QAAS,CACP,MACA,QlEgXFvnE,ImEhYqB,CACrB1rC,KAAM,MACNiuB,SAAU,YACVwnB,OAAQ,CACN,QACA,UACA,aAEFluB,YACI,gEACJqrF,SAAU,CACR,QACA,SACA,WACA,mBACA,WACA,YAEFK,QAAS,CAAC,WnE+WVvkD,SoEjY0B,CAC1B1uD,KAAM,WACNiuB,SAAU,YACVwnB,OAAQ,CACN,QACA,kBAEFluB,YAAa,uBACbqrF,SAAU,CACR,gBACA,UACA,YACA,cACA,cAEFK,QAAS,CACP,WpEkXFt3C,KqElYsB,CACtB37D,KAAM,OACNiuB,SAAU,aACVwnB,OAAQ,CACN,UACA,cAEFluB,YAAa,oDACbqrF,SAAU,CACR,YACA,aACA,eACA,6BACA,8BACA,kBACA,4BACA,gCACA,kCrEkXF/V,QsEnYyB,CACzB78F,KAAM,UACNiuB,SAAU,aACVwnB,OAAQ,CACN,aACA,oBAEFluB,YAAa,qJAGbqrF,SAAU,CACR,QACA,iBACA,gBACA,WAEFK,QAAS,CACP,WACA,MACA,StEiXFnW,SuEpY0B,CAC1B98F,KAAM,WACNiuB,SAAU,aACVwnB,OAAQ,CACN,cACA,qBAEFluB,YAAc,2LAMdqrF,SAAU,CACR,cACA,kBAEFK,QAAS,CACP,OACA,MACA,YvEiXFh+G,IwErYqB,CACrB+K,KAAM,MACNiuB,SAAU,YACVwnB,OAAQ,CACN,QACA,aAEFluB,YACI,uCACJqrF,SAAU,CACR,MACA,QACA,mBACA,2BACA,6BAEFK,QAAS,CACP,WACA,UACA,WACA,SxEkXFj8G,MyEtYuB,CACvBgJ,KAAM,QACNiuB,SAAU,aACVwnB,OAAQ,CACN,WACA,cACA,6BACA,iCAEFluB,YACI,4LACJqrF,SAAU,CACR,aACA,aACA,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S,CACP,MACA,OACA,SACA,MACA,OACA,MACA,MACA,a5LkgBFgH,I6LzhBqB,CACrBj6G,KAAM,MACNiuB,SAAU,aACVwnB,OAAQ,CACN,oBACA,UAEFluB,YAAa,8KACbqrF,SAAU,CACR,kBACA,kBAEFK,QAAS,CACP,OACA,SACA,MACA,Q7L0gBF14G,I8L1hBqB,CACrByF,KAAM,MACNiuB,SAAU,aACVwnB,OAAQ,CACN,oBACA,SACA,qBAEFluB,YAAa,iDACbqrF,SAAU,CACR,kBACA,oBACA,oBACA,uBACA,uBACA,gCACA,iCAEFK,QAAS,CACP,OACA,SACA,MACA,OACA,MACA,MACA,a9LkgBFiH,K+L3hBsB,CACtBl6G,KAAM,OACNiuB,SAAU,aACVwnB,OAAQ,CACN,qBACA,UACA,sBAEFluB,YAAa,mDACbqrF,SAAU,CACR,mBACA,qBACA,qBACA,wBACA,wBACA,8BAEFK,QAAS,CACP,MACA,SACA,MACA,OACA,MACA,MACA,a/LogBFkH,OgM5hBwB,CACxBn6G,KAAM,SACNiuB,SAAU,aACVwnB,OAAQ,CACN,uBACA,aAEFluB,YAAa,mLACbqrF,SAAU,CACR,kBACA,yBAEFK,QAAS,CACP,MACA,OACA,MACA,OACA,MACA,MACA,WACA,gBhMygBFt1F,IiM7hBqB,CACrB3d,KAAM,MACNiuB,SAAU,aACVwnB,OAAQ,CACN,oBACA,SACA,qBAEFluB,YAAa,iDACbqrF,SAAU,CACR,kBACA,oBACA,oBACA,uBACA,uBACA,gCACA,iCAEFK,QAAS,CACP,MACA,OACA,SACA,OACA,MACA,MACA,ajMqgBFp4F,KkM9hBsB,CACtB7a,KAAM,OACNiuB,SAAU,aACVwnB,OAAQ,CACN,qBACA,UACA,4BAEFluB,YAAa,2HACbqrF,SAAU,CACR,sBACA,8BACA,uBAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,OACA,MACA,MACA,alMygBF7kE,KmM/hBsB,CACtBpuC,KAAM,OACNiuB,SAAU,aACVwnB,OAAQ,CACN,qBACA,WAEFluB,YAAa,qCACbqrF,SAAU,CACR,gBACA,kBACA,sBAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,MACA,MACA,anM2gBFmH,YoMhiB6B,CAC7Bp6G,KAAM,cACNiuB,SAAU,aACVwnB,OAAQ,CACN,iCACA,gDACA,+BAEFluB,YAAa,uWACbqrF,SAAU,CACR,kCACA,yCACA,gCACA,yCAEFK,QAAS,CACP,OACA,SACA,MACA,MACA,OACA,MACA,MACA,apM0gBFoH,IqMjiBqB,CACrBr6G,KAAM,MACNiuB,SAAU,aACVwnB,OAAQ,CACN,oBACA,SACA,oBACA,wBACA,oCAEFluB,YAAa,iLACbqrF,SAAU,CACR,eACA,oBACA,mCACA,8BACA,2BAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,OACA,MACA,arMygBFvjE,IsMliBqB,CACrB1vC,KAAM,MACNiuB,SAAU,aACVwnB,OAAQ,CACN,oBACA,SACA,qBAEFluB,YAAa,iCACbqrF,SAAU,CACR,kBACA,oBACA,qBAEFK,QAAS,CACP,MACA,OACA,SACA,MACA,OACA,MACA,MACA,atM6gBFpV,SuMniB0B,CAC1B79F,KAAM,WACNiuB,SAAU,aACVwnB,OAAQ,CACN,yBACA,cACA,yBACA,6BACA,yCAEFluB,YAAa,gIACbqrF,SAAU,CACR,oBACA,yBACA,wCACA,mCACA,gCAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,OACA,MACA,QvM0gBFqH,KwMpiBsB,CACtBt6G,KAAM,OACNiuB,SAAU,aACVwnB,OAAQ,CACN,aAEFluB,YAAa,iIACbqrF,SAAU,CACR,kCACA,wGAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,OACA,MACA,QxMohBF98G,KyMviBsB,CACtB6J,KAAM,OACNiuB,SAAU,eACVwnB,OAAQ,CACN,WAEFluB,YAAa,oDACbqrF,SAAU,CACR,YACA,kBAEFK,QAAS,CACP,MACA,OACA,SzM0hBFr8G,M0MxiBuB,CACvBoJ,KAAM,QACNiuB,SAAU,eACVwnB,OAAQ,CACN,YAEFluB,YAAa,6FACbqrF,SAAU,CACR,cAEFK,QAAS,CACP,OACA,QACA,U1M4hBF5m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","sources":["webpack://math/webpack/universalModuleDefinition","webpack://math/./node_modules/complex.js/complex.js","webpack://math/./node_modules/escape-latex/dist/index.js","webpack://math/./node_modules/javascript-natural-sort/naturalSort.js","webpack://math/./node_modules/seedrandom/index.js","webpack://math/./node_modules/seedrandom/lib/alea.js","webpack://math/./node_modules/seedrandom/lib/tychei.js","webpack://math/./node_modules/seedrandom/lib/xor128.js","webpack://math/./node_modules/seedrandom/lib/xor4096.js","webpack://math/./node_modules/seedrandom/lib/xorshift7.js","webpack://math/./node_modules/seedrandom/lib/xorwow.js","webpack://math/./node_modules/seedrandom/seedrandom.js","webpack://math/./node_modules/tiny-emitter/index.js","webpack://math/./node_modules/core-js/internals/a-callable.js","webpack://math/./node_modules/core-js/internals/a-constructor.js","webpack://math/./node_modules/core-js/internals/a-possible-prototype.js","webpack://math/./node_modules/core-js/internals/add-to-unscopables.js","webpack://math/./node_modules/core-js/internals/advance-string-index.js","webpack://math/./node_modules/core-js/internals/an-instance.js","webpack://math/./node_modules/core-js/internals/an-object.js","webpack://math/./node_modules/core-js/internals/array-includes.js","webpack://math/./node_modules/core-js/internals/array-method-is-strict.js","webpack://math/./node_modules/core-js/internals/array-reduce.js","webpack://math/./node_modules/core-js/internals/array-slice.js","webpack://math/./node_modules/core-js/internals/array-sort.js","webpack://math/./node_modules/core-js/internals/check-correctness-of-iteration.js","webpack://math/./node_modules/core-js/internals/classof-raw.js","webpack://math/./node_modules/core-js/internals/classof.js","webpack://math/./node_modules/core-js/internals/copy-constructor-properties.js","webpack://math/./node_modules/core-js/internals/create-non-enumerable-property.js","webpack://math/./node_modules/core-js/internals/create-property-descriptor.js","webpack://math/./node_modules/core-js/internals/create-property.js","webpack://math/./node_modules/core-js/internals/define-built-in-accessor.js","webpack://math/./node_modules/core-js/internals/define-built-in.js","webpack://math/./node_modules/core-js/internals/define-global-property.js","webpack://math/./node_modules/core-js/internals/delete-property-or-throw.js","webpack://math/./node_modules/core-js/internals/descriptors.js","webpack://math/./node_modules/core-js/internals/document-create-element.js","webpack://math/./node_modules/core-js/internals/enum-bug-keys.js","webpack://math/./node_modules/core-js/internals/environment-ff-version.js","webpack://math/./node_modules/core-js/internals/environment-is-ie-or-edge.js","webpack://math/./node_modules/core-js/internals/environment-is-ios-pebble.js","webpack://math/./node_modules/core-js/internals/environment-is-ios.js","webpack://math/./node_modules/core-js/internals/environment-is-node.js","webpack://math/./node_modules/core-js/internals/environment-is-webos-webkit.js","webpack://math/./node_modules/core-js/internals/environment-user-agent.js","webpack://math/./node_modules/core-js/internals/environment-v8-version.js","webpack://math/./node_modules/core-js/internals/environment-webkit-version.js","webpack://math/./node_modules/core-js/internals/environment.js","webpack://math/./node_modules/core-js/internals/export.js","webpack://math/./node_modules/core-js/internals/fails.js","webpack://math/./node_modules/core-js/internals/fix-regexp-well-known-symbol-logic.js","webpack://math/./node_modules/core-js/internals/function-apply.js","webpack://math/./node_modules/core-js/internals/function-bind-context.js","webpack://math/./node_modules/core-js/internals/function-bind-native.js","webpack://math/./node_modules/core-js/internals/function-call.js","webpack://math/./node_modules/core-js/internals/function-name.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this-accessor.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this-clause.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this.js","webpack://math/./node_modules/core-js/internals/get-built-in.js","webpack://math/./node_modules/core-js/internals/get-iterator-method.js","webpack://math/./node_modules/core-js/internals/get-iterator.js","webpack://math/./node_modules/core-js/internals/get-json-replacer-function.js","webpack://math/./node_modules/core-js/internals/get-method.js","webpack://math/./node_modules/core-js/internals/get-substitution.js","webpack://math/./node_modules/core-js/internals/global-this.js","webpack://math/./node_modules/core-js/internals/has-own-property.js","webpack://math/./node_modules/core-js/internals/hidden-keys.js","webpack://math/./node_modules/core-js/internals/host-report-errors.js","webpack://math/./node_modules/core-js/internals/html.js","webpack://math/./node_modules/core-js/internals/ie8-dom-define.js","webpack://math/./node_modules/core-js/internals/indexed-object.js","webpack://math/./node_modules/core-js/internals/inherit-if-required.js","webpack://math/./node_modules/core-js/internals/inspect-source.js","webpack://math/./node_modules/core-js/internals/internal-state.js","webpack://math/./node_modules/core-js/internals/is-array-iterator-method.js","webpack://math/./node_modules/core-js/internals/is-array.js","webpack://math/./node_modules/core-js/internals/is-callable.js","webpack://math/./node_modules/core-js/internals/is-constructor.js","webpack://math/./node_modules/core-js/internals/is-forced.js","webpack://math/./node_modules/core-js/internals/is-null-or-undefined.js","webpack://math/./node_modules/core-js/internals/is-object.js","webpack://math/./node_modules/core-js/internals/is-possible-prototype.js","webpack://math/./node_modules/core-js/internals/is-pure.js","webpack://math/./node_modules/core-js/internals/is-regexp.js","webpack://math/./node_modules/core-js/internals/is-symbol.js","webpack://math/./node_modules/core-js/internals/iterate.js","webpack://math/./node_modules/core-js/internals/iterator-close.js","webpack://math/./node_modules/core-js/internals/iterators.js","webpack://math/./node_modules/core-js/internals/length-of-array-like.js","webpack://math/./node_modules/core-js/internals/make-built-in.js","webpack://math/./node_modules/core-js/internals/math-trunc.js","webpack://math/./node_modules/core-js/internals/microtask.js","webpack://math/./node_modules/core-js/internals/new-promise-capability.js","webpack://math/./node_modules/core-js/internals/object-create.js","webpack://math/./node_modules/core-js/internals/object-define-properties.js","webpack://math/./node_modules/core-js/internals/object-define-property.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-descriptor.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-names.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-symbols.js","webpack://math/./node_modules/core-js/internals/object-is-prototype-of.js","webpack://math/./node_modules/core-js/internals/object-keys-internal.js","webpack://math/./node_modules/core-js/internals/object-keys.js","webpack://math/./node_modules/core-js/internals/object-property-is-enumerable.js","webpack://math/./node_modules/core-js/internals/object-set-prototype-of.js","webpack://math/./node_modules/core-js/internals/ordinary-to-primitive.js","webpack://math/./node_modules/core-js/internals/own-keys.js","webpack://math/./node_modules/core-js/internals/perform.js","webpack://math/./node_modules/core-js/internals/promise-constructor-detection.js","webpack://math/./node_modules/core-js/internals/promise-native-constructor.js","webpack://math/./node_modules/core-js/internals/promise-resolve.js","webpack://math/./node_modules/core-js/internals/promise-statics-incorrect-iteration.js","webpack://math/./node_modules/core-js/internals/proxy-accessor.js","webpack://math/./node_modules/core-js/internals/queue.js","webpack://math/./node_modules/core-js/internals/regexp-exec-abstract.js","webpack://math/./node_modules/core-js/internals/regexp-exec.js","webpack://math/./node_modules/core-js/internals/regexp-flags.js","webpack://math/./node_modules/core-js/internals/regexp-get-flags.js","webpack://math/./node_modules/core-js/internals/regexp-sticky-helpers.js","webpack://math/./node_modules/core-js/internals/regexp-unsupported-dot-all.js","webpack://math/./node_modules/core-js/internals/regexp-unsupported-ncg.js","webpack://math/./node_modules/core-js/internals/require-object-coercible.js","webpack://math/./node_modules/core-js/internals/safe-get-built-in.js","webpack://math/./node_modules/core-js/internals/set-species.js","webpack://math/./node_modules/core-js/internals/set-to-string-tag.js","webpack://math/./node_modules/core-js/internals/shared-key.js","webpack://math/./node_modules/core-js/internals/shared-store.js","webpack://math/./node_modules/core-js/internals/shared.js","webpack://math/./node_modules/core-js/internals/species-constructor.js","webpack://math/./node_modules/core-js/internals/string-multibyte.js","webpack://math/./node_modules/core-js/internals/symbol-constructor-detection.js","webpack://math/./node_modules/core-js/internals/task.js","webpack://math/./node_modules/core-js/internals/to-absolute-index.js","webpack://math/./node_modules/core-js/internals/to-indexed-object.js","webpack://math/./node_modules/core-js/internals/to-integer-or-infinity.js","webpack://math/./node_modules/core-js/internals/to-length.js","webpack://math/./node_modules/core-js/internals/to-object.js","webpack://math/./node_modules/core-js/internals/to-primitive.js","webpack://math/./node_modules/core-js/internals/to-property-key.js","webpack://math/./node_modules/core-js/internals/to-string-tag-support.js","webpack://math/./node_modules/core-js/internals/to-string.js","webpack://math/./node_modules/core-js/internals/try-to-string.js","webpack://math/./node_modules/core-js/internals/uid.js","webpack://math/./node_modules/core-js/internals/use-symbol-as-uid.js","webpack://math/./node_modules/core-js/internals/v8-prototype-define-bug.js","webpack://math/./node_modules/core-js/internals/validate-arguments-length.js","webpack://math/./node_modules/core-js/internals/weak-map-basic-detection.js","webpack://math/./node_modules/core-js/internals/well-known-symbol.js","webpack://math/./node_modules/core-js/modules/es.array.includes.js","webpack://math/./node_modules/core-js/modules/es.array.reduce.js","webpack://math/./node_modules/core-js/modules/es.array.sort.js","webpack://math/./node_modules/core-js/modules/es.json.stringify.js","webpack://math/./node_modules/core-js/modules/es.object.from-entries.js","webpack://math/./node_modules/core-js/modules/es.promise.all.js","webpack://math/./node_modules/core-js/modules/es.promise.catch.js","webpack://math/./node_modules/core-js/modules/es.promise.constructor.js","webpack://math/./node_modules/core-js/modules/es.promise.js","webpack://math/./node_modules/core-js/modules/es.promise.race.js","webpack://math/./node_modules/core-js/modules/es.promise.reject.js","webpack://math/./node_modules/core-js/modules/es.promise.resolve.js","webpack://math/./node_modules/core-js/modules/es.regexp.constructor.js","webpack://math/./node_modules/core-js/modules/es.regexp.dot-all.js","webpack://math/./node_modules/core-js/modules/es.regexp.exec.js","webpack://math/./node_modules/core-js/modules/es.string.replace.js","webpack://math/./node_modules/core-js/modules/es.symbol.description.js","webpack://math/./node_modules/typed-function/lib/umd/typed-function.js","webpack://math/webpack/bootstrap","webpack://math/webpack/runtime/amd define","webpack://math/webpack/runtime/amd options","webpack://math/webpack/runtime/define property getters","webpack://math/webpack/runtime/hasOwnProperty shorthand","webpack://math/webpack/runtime/make namespace object","webpack://math/webpack/runtime/node module decorator","webpack://math/./src/utils/customs.js","webpack://math/./src/utils/map.js","webpack://math/./src/utils/is.js","webpack://math/./src/utils/object.js","webpack://math/./src/utils/factory.js","webpack://math/./src/utils/number.js","webpack://math/./src/core/function/typed.js","webpack://math/./src/type/resultset/ResultSet.js","webpack://math/./node_modules/decimal.js/decimal.mjs","webpack://math/./src/type/bignumber/BigNumber.js","webpack://math/./src/type/complex/Complex.js","webpack://math/./node_modules/fraction.js/fraction.js","webpack://math/./src/type/fraction/Fraction.js","webpack://math/./src/type/matrix/Range.js","webpack://math/./src/type/matrix/Matrix.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/extends.js","webpack://math/./src/utils/bignumber/formatter.js","webpack://math/./src/utils/string.js","webpack://math/./src/error/DimensionError.js","webpack://math/./src/error/IndexError.js","webpack://math/./src/utils/array.js","webpack://math/./src/utils/optimizeCallback.js","webpack://math/./src/type/matrix/DenseMatrix.js","webpack://math/./src/function/utils/clone.js","webpack://math/./src/utils/switch.js","webpack://math/./src/utils/collection.js","webpack://math/./src/function/utils/isInteger.js","webpack://math/./src/plain/number/utils.js","webpack://math/./src/utils/bignumber/nearlyEqual.js","webpack://math/./src/function/utils/isNegative.js","webpack://math/./src/function/utils/isNumeric.js","webpack://math/./src/function/utils/hasNumericValue.js","webpack://math/./src/function/utils/isPositive.js","webpack://math/./src/function/utils/isZero.js","webpack://math/./src/function/utils/isNaN.js","webpack://math/./src/function/utils/typeOf.js","webpack://math/./src/function/relational/compareUnits.js","webpack://math/./src/function/relational/equalScalar.js","webpack://math/./src/utils/complex.js","webpack://math/./src/type/matrix/SparseMatrix.js","webpack://math/./src/type/number.js","webpack://math/./src/type/bigint.js","webpack://math/./src/type/string.js","webpack://math/./src/type/boolean.js","webpack://math/./src/type/bignumber/function/bignumber.js","webpack://math/./src/type/complex/function/complex.js","webpack://math/./src/type/fraction/function/fraction.js","webpack://math/./src/type/matrix/function/matrix.js","webpack://math/./src/function/matrix/matrixFromFunction.js","webpack://math/./src/function/matrix/matrixFromRows.js","webpack://math/./src/function/matrix/matrixFromColumns.js","webpack://math/./src/type/unit/function/splitUnit.js","webpack://math/./src/plain/number/arithmetic.js","webpack://math/./src/function/arithmetic/unaryMinus.js","webpack://math/./src/function/arithmetic/unaryPlus.js","webpack://math/./src/function/arithmetic/abs.js","webpack://math/./src/function/matrix/apply.js","webpack://math/./src/function/arithmetic/addScalar.js","webpack://math/./src/function/arithmetic/subtractScalar.js","webpack://math/./src/function/arithmetic/cbrt.js","webpack://math/./src/type/matrix/utils/matAlgo11xS0s.js","webpack://math/./src/type/matrix/utils/matAlgo12xSfs.js","webpack://math/./src/type/matrix/utils/matAlgo14xDs.js","webpack://math/./src/function/arithmetic/ceil.js","webpack://math/./src/function/arithmetic/cube.js","webpack://math/./src/function/arithmetic/exp.js","webpack://math/./src/function/arithmetic/expm1.js","webpack://math/./src/function/arithmetic/fix.js","webpack://math/./src/function/arithmetic/floor.js","webpack://math/./src/type/matrix/utils/matAlgo02xDS0.js","webpack://math/./src/type/matrix/utils/matAlgo03xDSf.js","webpack://math/./src/type/matrix/utils/matAlgo05xSfSf.js","webpack://math/./src/type/matrix/utils/matAlgo13xDD.js","webpack://math/./src/type/matrix/utils/broadcast.js","webpack://math/./src/type/matrix/utils/matrixAlgorithmSuite.js","webpack://math/./src/function/arithmetic/mod.js","webpack://math/./src/type/matrix/utils/matAlgo01xDSid.js","webpack://math/./src/type/matrix/utils/matAlgo04xSidSid.js","webpack://math/./src/type/matrix/utils/matAlgo10xSids.js","webpack://math/./src/error/ArgumentsError.js","webpack://math/./src/function/arithmetic/gcd.js","webpack://math/./src/type/matrix/utils/matAlgo06xS0S0.js","webpack://math/./src/function/arithmetic/lcm.js","webpack://math/./src/function/arithmetic/log10.js","webpack://math/./src/function/arithmetic/log2.js","webpack://math/./src/function/arithmetic/multiplyScalar.js","webpack://math/./src/function/arithmetic/multiply.js","webpack://math/./src/function/arithmetic/nthRoot.js","webpack://math/./src/function/arithmetic/sign.js","webpack://math/./src/function/arithmetic/sqrt.js","webpack://math/./src/function/arithmetic/square.js","webpack://math/./src/function/arithmetic/subtract.js","webpack://math/./src/function/arithmetic/xgcd.js","webpack://math/./src/function/arithmetic/invmod.js","webpack://math/./src/type/matrix/utils/matAlgo09xS0Sf.js","webpack://math/./src/function/arithmetic/dotMultiply.js","webpack://math/./src/utils/bignumber/bitwise.js","webpack://math/./src/plain/number/bitwise.js","webpack://math/./src/function/bitwise/bitAnd.js","webpack://math/./src/function/bitwise/bitNot.js","webpack://math/./src/function/bitwise/bitOr.js","webpack://math/./src/type/matrix/utils/matAlgo07xSSf.js","webpack://math/./src/function/bitwise/bitXor.js","webpack://math/./src/function/complex/arg.js","webpack://math/./src/function/complex/conj.js","webpack://math/./src/function/complex/im.js","webpack://math/./src/function/complex/re.js","webpack://math/./src/plain/number/logical.js","webpack://math/./src/function/logical/not.js","webpack://math/./src/function/logical/or.js","webpack://math/./src/function/logical/xor.js","webpack://math/./src/function/matrix/concat.js","webpack://math/./src/function/matrix/column.js","webpack://math/./src/function/matrix/count.js","webpack://math/./src/function/matrix/cross.js","webpack://math/./src/function/matrix/diag.js","webpack://math/./src/function/matrix/filter.js","webpack://math/./src/function/matrix/flatten.js","webpack://math/./src/function/matrix/forEach.js","webpack://math/./src/function/matrix/getMatrixDataType.js","webpack://math/./src/function/matrix/identity.js","webpack://math/./src/function/matrix/kron.js","webpack://math/./src/function/matrix/map.js","webpack://math/./src/function/matrix/diff.js","webpack://math/./src/function/matrix/ones.js","webpack://math/./src/utils/noop.js","webpack://math/./src/function/matrix/range.js","webpack://math/./src/function/matrix/reshape.js","webpack://math/./src/function/matrix/resize.js","webpack://math/./src/function/matrix/rotate.js","webpack://math/./src/function/matrix/rotationMatrix.js","webpack://math/./src/function/matrix/row.js","webpack://math/./src/function/matrix/size.js","webpack://math/./src/function/matrix/squeeze.js","webpack://math/./src/function/matrix/subset.js","webpack://math/./src/function/matrix/transpose.js","webpack://math/./src/function/matrix/ctranspose.js","webpack://math/./src/function/matrix/zeros.js","webpack://math/./src/function/matrix/fft.js","webpack://math/./src/function/matrix/ifft.js","webpack://math/./src/function/numeric/solveODE.js","webpack://math/./src/function/special/erf.js","webpack://math/./src/function/special/zeta.js","webpack://math/./src/function/statistics/mode.js","webpack://math/./src/function/statistics/utils/improveErrorMessage.js","webpack://math/./src/function/statistics/prod.js","webpack://math/./src/function/string/format.js","webpack://math/./src/function/string/bin.js","webpack://math/./src/function/string/oct.js","webpack://math/./src/function/string/hex.js","webpack://math/./src/utils/print.js","webpack://math/./src/function/string/print.js","webpack://math/./src/function/unit/to.js","webpack://math/./src/function/utils/isPrime.js","webpack://math/./src/function/utils/numeric.js","webpack://math/./src/function/arithmetic/divideScalar.js","webpack://math/./src/function/arithmetic/pow.js","webpack://math/./src/function/arithmetic/round.js","webpack://math/./src/function/arithmetic/log.js","webpack://math/./src/function/arithmetic/log1p.js","webpack://math/./src/function/arithmetic/nthRoots.js","webpack://math/./src/function/arithmetic/dotPow.js","webpack://math/./src/function/arithmetic/dotDivide.js","webpack://math/./src/function/algebra/solver/utils/solveValidation.js","webpack://math/./src/function/algebra/solver/lsolve.js","webpack://math/./src/function/algebra/solver/usolve.js","webpack://math/./src/function/algebra/solver/lsolveAll.js","webpack://math/./src/function/algebra/solver/usolveAll.js","webpack://math/./src/type/matrix/utils/matAlgo08xS0Sid.js","webpack://math/./src/function/bitwise/useMatrixForArrayScalar.js","webpack://math/./src/function/bitwise/leftShift.js","webpack://math/./src/function/bitwise/rightArithShift.js","webpack://math/./src/function/bitwise/rightLogShift.js","webpack://math/./src/function/logical/and.js","webpack://math/./src/function/relational/compare.js","webpack://math/./src/function/relational/compareNatural.js","webpack://math/./src/function/relational/compareText.js","webpack://math/./src/function/relational/equal.js","webpack://math/./src/function/relational/equalText.js","webpack://math/./src/function/relational/smaller.js","webpack://math/./src/function/relational/smallerEq.js","webpack://math/./src/function/relational/larger.js","webpack://math/./src/function/relational/largerEq.js","webpack://math/./src/function/relational/deepEqual.js","webpack://math/./src/function/relational/unequal.js","webpack://math/./src/function/matrix/partitionSelect.js","webpack://math/./src/function/matrix/sort.js","webpack://math/./src/function/statistics/max.js","webpack://math/./src/function/statistics/min.js","webpack://math/./src/type/matrix/ImmutableDenseMatrix.js","webpack://math/./src/type/matrix/MatrixIndex.js","webpack://math/./src/type/matrix/FibonacciHeap.js","webpack://math/./src/type/matrix/Spa.js","webpack://math/./src/utils/lruQueue.js","webpack://math/./src/utils/function.js","webpack://math/./src/utils/bignumber/constants.js","webpack://math/./src/type/unit/Unit.js","webpack://math/./src/type/unit/function/unit.js","webpack://math/./src/type/matrix/function/sparse.js","webpack://math/./src/type/unit/function/createUnit.js","webpack://math/./src/function/trigonometry/acos.js","webpack://math/./src/plain/number/trigonometry.js","webpack://math/./src/function/trigonometry/acosh.js","webpack://math/./src/function/trigonometry/acot.js","webpack://math/./src/function/trigonometry/acoth.js","webpack://math/./src/function/trigonometry/acsc.js","webpack://math/./src/function/trigonometry/acsch.js","webpack://math/./src/function/trigonometry/asec.js","webpack://math/./src/function/trigonometry/asech.js","webpack://math/./src/function/trigonometry/asin.js","webpack://math/./src/function/trigonometry/asinh.js","webpack://math/./src/function/trigonometry/atan.js","webpack://math/./src/function/trigonometry/atan2.js","webpack://math/./src/function/trigonometry/atanh.js","webpack://math/./src/function/trigonometry/trigUnit.js","webpack://math/./src/function/trigonometry/cos.js","webpack://math/./src/function/trigonometry/cosh.js","webpack://math/./src/function/trigonometry/cot.js","webpack://math/./src/function/trigonometry/coth.js","webpack://math/./src/function/trigonometry/csc.js","webpack://math/./src/function/trigonometry/csch.js","webpack://math/./src/function/trigonometry/sec.js","webpack://math/./src/function/trigonometry/sech.js","webpack://math/./src/function/trigonometry/sin.js","webpack://math/./src/function/trigonometry/sinh.js","webpack://math/./src/function/trigonometry/tan.js","webpack://math/./src/function/trigonometry/tanh.js","webpack://math/./src/function/set/setCartesian.js","webpack://math/./src/function/set/setDifference.js","webpack://math/./src/function/set/setDistinct.js","webpack://math/./src/function/set/setIntersect.js","webpack://math/./src/function/set/setIsSubset.js","webpack://math/./src/function/set/setMultiplicity.js","webpack://math/./src/function/set/setPowerset.js","webpack://math/./src/function/set/setSize.js","webpack://math/./src/function/set/setSymDifference.js","webpack://math/./src/function/set/setUnion.js","webpack://math/./src/function/arithmetic/add.js","webpack://math/./src/function/arithmetic/hypot.js","webpack://math/./src/function/arithmetic/norm.js","webpack://math/./src/function/matrix/dot.js","webpack://math/./src/function/matrix/trace.js","webpack://math/./src/type/matrix/function/index.js","webpack://math/./src/expression/keywords.js","webpack://math/./src/expression/node/Node.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack://math/./src/expression/transform/utils/errorTransform.js","webpack://math/./src/expression/node/utils/access.js","webpack://math/./src/expression/node/AccessorNode.js","webpack://math/./src/expression/node/ArrayNode.js","webpack://math/./src/expression/operators.js","webpack://math/./src/expression/node/AssignmentNode.js","webpack://math/./src/expression/node/utils/assign.js","webpack://math/./src/expression/node/BlockNode.js","webpack://math/./src/expression/node/ConditionalNode.js","webpack://math/./src/utils/latex.js","webpack://math/./src/expression/node/ConstantNode.js","webpack://math/./src/expression/node/FunctionAssignmentNode.js","webpack://math/./src/expression/node/IndexNode.js","webpack://math/./src/expression/node/ObjectNode.js","webpack://math/./src/utils/scope.js","webpack://math/./src/expression/node/OperatorNode.js","webpack://math/./src/expression/node/ParenthesisNode.js","webpack://math/./src/expression/node/RangeNode.js","webpack://math/./src/expression/node/RelationalNode.js","webpack://math/./src/expression/node/SymbolNode.js","webpack://math/./src/expression/node/FunctionNode.js","webpack://math/./src/expression/parse.js","webpack://math/./src/expression/function/compile.js","webpack://math/./src/expression/function/evaluate.js","webpack://math/./src/expression/Parser.js","webpack://math/./src/expression/function/parser.js","webpack://math/./src/function/algebra/decomposition/lup.js","webpack://math/./src/function/algebra/decomposition/qr.js","webpack://math/./src/function/algebra/sparse/csTdfs.js","webpack://math/./src/function/algebra/sparse/csFlip.js","webpack://math/./src/function/algebra/sparse/csAmd.js","webpack://math/./src/function/algebra/sparse/csFkeep.js","webpack://math/./src/function/algebra/sparse/csLeaf.js","webpack://math/./src/function/algebra/sparse/csCounts.js","webpack://math/./src/function/algebra/sparse/csSqr.js","webpack://math/./src/function/algebra/sparse/csPermute.js","webpack://math/./src/function/algebra/sparse/csEtree.js","webpack://math/./src/function/algebra/sparse/csPost.js","webpack://math/./src/function/algebra/sparse/csMarked.js","webpack://math/./src/function/algebra/sparse/csMark.js","webpack://math/./src/function/algebra/sparse/csUnflip.js","webpack://math/./src/function/algebra/sparse/csDfs.js","webpack://math/./src/function/algebra/sparse/csSpsolve.js","webpack://math/./src/function/algebra/sparse/csReach.js","webpack://math/./src/function/algebra/sparse/csLu.js","webpack://math/./src/function/algebra/decomposition/slu.js","webpack://math/./src/function/algebra/sparse/csIpvec.js","webpack://math/./src/function/algebra/solver/lusolve.js","webpack://math/./src/function/algebra/polynomialRoot.js","webpack://math/./src/expression/Help.js","webpack://math/./src/type/chain/Chain.js","webpack://math/./src/expression/embeddedDocs/constants/e.js","webpack://math/./src/expression/embeddedDocs/constants/pi.js","webpack://math/./src/expression/embeddedDocs/embeddedDocs.js","webpack://math/./src/expression/embeddedDocs/construction/bignumber.js","webpack://math/./src/expression/embeddedDocs/construction/bigint.js","webpack://math/./src/expression/embeddedDocs/construction/boolean.js","webpack://math/./src/expression/embeddedDocs/construction/complex.js","webpack://math/./src/expression/embeddedDocs/construction/createUnit.js","webpack://math/./src/expression/embeddedDocs/construction/fraction.js","webpack://math/./src/expression/embeddedDocs/construction/index.js","webpack://math/./src/expression/embeddedDocs/construction/matrix.js","webpack://math/./src/expression/embeddedDocs/construction/number.js","webpack://math/./src/expression/embeddedDocs/construction/sparse.js","webpack://math/./src/expression/embeddedDocs/construction/splitUnit.js","webpack://math/./src/expression/embeddedDocs/construction/string.js","webpack://math/./src/expression/embeddedDocs/construction/unit.js","webpack://math/./src/expression/embeddedDocs/constants/false.js","webpack://math/./src/expression/embeddedDocs/constants/i.js","webpack://math/./src/expression/embeddedDocs/constants/Infinity.js","webpack://math/./src/expression/embeddedDocs/constants/LN2.js","webpack://math/./src/expression/embeddedDocs/constants/LN10.js","webpack://math/./src/expression/embeddedDocs/constants/LOG2E.js","webpack://math/./src/expression/embeddedDocs/constants/LOG10E.js","webpack://math/./src/expression/embeddedDocs/constants/NaN.js","webpack://math/./src/expression/embeddedDocs/constants/null.js","webpack://math/./src/expression/embeddedDocs/constants/phi.js","webpack://math/./src/expression/embeddedDocs/constants/SQRT1_2.js","webpack://math/./src/expression/embeddedDocs/constants/SQRT2.js","webpack://math/./src/expression/embeddedDocs/constants/tau.js","webpack://math/./src/expression/embeddedDocs/constants/true.js","webpack://math/./src/expression/embeddedDocs/constants/version.js","webpack://math/./src/expression/embeddedDocs/function/algebra/derivative.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lsolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lsolveAll.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lup.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lusolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/leafCount.js","webpack://math/./src/expression/embeddedDocs/function/algebra/polynomialRoot.js","webpack://math/./src/expression/embeddedDocs/function/algebra/resolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplify.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplifyConstant.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplifyCore.js","webpack://math/./src/expression/embeddedDocs/function/algebra/symbolicEqual.js","webpack://math/./src/expression/embeddedDocs/function/algebra/rationalize.js","webpack://math/./src/expression/embeddedDocs/function/algebra/slu.js","webpack://math/./src/expression/embeddedDocs/function/algebra/usolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/usolveAll.js","webpack://math/./src/expression/embeddedDocs/function/algebra/qr.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/abs.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/add.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/cbrt.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/ceil.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/cube.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/divide.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotDivide.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotMultiply.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotPow.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/exp.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/expm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/expm1.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/fix.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/floor.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/gcd.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/hypot.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/lcm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log2.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log1p.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log10.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/mod.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/multiply.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/norm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/nthRoot.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/nthRoots.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/pow.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/round.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sign.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sqrt.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sqrtm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/square.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/subtract.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/unaryMinus.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/unaryPlus.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/xgcd.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/invmod.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitAnd.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitNot.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitOr.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitXor.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/leftShift.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/rightArithShift.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/rightLogShift.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/bellNumbers.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/catalan.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/composition.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/stirlingS2.js","webpack://math/./src/expression/embeddedDocs/core/config.js","webpack://math/./src/expression/embeddedDocs/core/import.js","webpack://math/./src/expression/embeddedDocs/core/typed.js","webpack://math/./src/expression/embeddedDocs/function/complex/arg.js","webpack://math/./src/expression/embeddedDocs/function/complex/conj.js","webpack://math/./src/expression/embeddedDocs/function/complex/re.js","webpack://math/./src/expression/embeddedDocs/function/complex/im.js","webpack://math/./src/expression/embeddedDocs/function/expression/evaluate.js","webpack://math/./src/expression/embeddedDocs/function/expression/help.js","webpack://math/./src/expression/embeddedDocs/function/geometry/distance.js","webpack://math/./src/expression/embeddedDocs/function/geometry/intersect.js","webpack://math/./src/expression/embeddedDocs/function/logical/and.js","webpack://math/./src/expression/embeddedDocs/function/logical/not.js","webpack://math/./src/expression/embeddedDocs/function/logical/or.js","webpack://math/./src/expression/embeddedDocs/function/logical/xor.js","webpack://math/./src/expression/embeddedDocs/function/matrix/concat.js","webpack://math/./src/expression/embeddedDocs/function/matrix/count.js","webpack://math/./src/expression/embeddedDocs/function/matrix/cross.js","webpack://math/./src/expression/embeddedDocs/function/matrix/column.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ctranspose.js","webpack://math/./src/expression/embeddedDocs/function/matrix/det.js","webpack://math/./src/expression/embeddedDocs/function/matrix/diag.js","webpack://math/./src/expression/embeddedDocs/function/matrix/diff.js","webpack://math/./src/expression/embeddedDocs/function/matrix/dot.js","webpack://math/./src/expression/embeddedDocs/function/matrix/getMatrixDataType.js","webpack://math/./src/expression/embeddedDocs/function/matrix/identity.js","webpack://math/./src/expression/embeddedDocs/function/matrix/filter.js","webpack://math/./src/expression/embeddedDocs/function/matrix/flatten.js","webpack://math/./src/expression/embeddedDocs/function/matrix/forEach.js","webpack://math/./src/expression/embeddedDocs/function/matrix/inv.js","webpack://math/./src/expression/embeddedDocs/function/matrix/pinv.js","webpack://math/./src/expression/embeddedDocs/function/matrix/eigs.js","webpack://math/./src/expression/embeddedDocs/function/matrix/kron.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromFunction.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromRows.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromColumns.js","webpack://math/./src/expression/embeddedDocs/function/matrix/map.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ones.js","webpack://math/./src/expression/embeddedDocs/function/matrix/partitionSelect.js","webpack://math/./src/expression/embeddedDocs/function/matrix/range.js","webpack://math/./src/expression/embeddedDocs/function/matrix/resize.js","webpack://math/./src/expression/embeddedDocs/function/matrix/reshape.js","webpack://math/./src/expression/embeddedDocs/function/matrix/rotate.js","webpack://math/./src/expression/embeddedDocs/function/matrix/rotationMatrix.js","webpack://math/./src/expression/embeddedDocs/function/matrix/row.js","webpack://math/./src/expression/embeddedDocs/function/matrix/size.js","webpack://math/./src/expression/embeddedDocs/function/matrix/sort.js","webpack://math/./src/expression/embeddedDocs/function/matrix/squeeze.js","webpack://math/./src/expression/embeddedDocs/function/matrix/subset.js","webpack://math/./src/expression/embeddedDocs/function/matrix/trace.js","webpack://math/./src/expression/embeddedDocs/function/matrix/transpose.js","webpack://math/./src/expression/embeddedDocs/function/matrix/zeros.js","webpack://math/./src/expression/embeddedDocs/function/matrix/fft.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ifft.js","webpack://math/./src/expression/embeddedDocs/function/algebra/sylvester.js","webpack://math/./src/expression/embeddedDocs/function/algebra/schur.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lyap.js","webpack://math/./src/expression/embeddedDocs/function/numeric/solveODE.js","webpack://math/./src/expression/embeddedDocs/function/probability/combinations.js","webpack://math/./src/expression/embeddedDocs/function/probability/combinationsWithRep.js","webpack://math/./src/expression/embeddedDocs/function/probability/factorial.js","webpack://math/./src/expression/embeddedDocs/function/probability/gamma.js","webpack://math/./src/expression/embeddedDocs/function/probability/kldivergence.js","webpack://math/./src/expression/embeddedDocs/function/probability/lgamma.js","webpack://math/./src/expression/embeddedDocs/function/probability/multinomial.js","webpack://math/./src/expression/embeddedDocs/function/probability/permutations.js","webpack://math/./src/expression/embeddedDocs/function/probability/pickRandom.js","webpack://math/./src/expression/embeddedDocs/function/probability/random.js","webpack://math/./src/expression/embeddedDocs/function/probability/randomInt.js","webpack://math/./src/expression/embeddedDocs/function/relational/compare.js","webpack://math/./src/expression/embeddedDocs/function/relational/compareNatural.js","webpack://math/./src/expression/embeddedDocs/function/relational/compareText.js","webpack://math/./src/expression/embeddedDocs/function/relational/deepEqual.js","webpack://math/./src/expression/embeddedDocs/function/relational/equal.js","webpack://math/./src/expression/embeddedDocs/function/relational/equalText.js","webpack://math/./src/expression/embeddedDocs/function/relational/larger.js","webpack://math/./src/expression/embeddedDocs/function/relational/largerEq.js","webpack://math/./src/expression/embeddedDocs/function/relational/smaller.js","webpack://math/./src/expression/embeddedDocs/function/relational/smallerEq.js","webpack://math/./src/expression/embeddedDocs/function/relational/unequal.js","webpack://math/./src/expression/embeddedDocs/function/set/setCartesian.js","webpack://math/./src/expression/embeddedDocs/function/set/setDifference.js","webpack://math/./src/expression/embeddedDocs/function/set/setDistinct.js","webpack://math/./src/expression/embeddedDocs/function/set/setIntersect.js","webpack://math/./src/expression/embeddedDocs/function/set/setIsSubset.js","webpack://math/./src/expression/embeddedDocs/function/set/setMultiplicity.js","webpack://math/./src/expression/embeddedDocs/function/set/setPowerset.js","webpack://math/./src/expression/embeddedDocs/function/set/setSize.js","webpack://math/./src/expression/embeddedDocs/function/set/setSymDifference.js","webpack://math/./src/expression/embeddedDocs/function/set/setUnion.js","webpack://math/./src/expression/embeddedDocs/function/signal/zpk2tf.js","webpack://math/./src/expression/embeddedDocs/function/signal/freqz.js","webpack://math/./src/expression/embeddedDocs/function/special/erf.js","webpack://math/./src/expression/embeddedDocs/function/special/zeta.js","webpack://math/./src/expression/embeddedDocs/function/statistics/cumsum.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mad.js","webpack://math/./src/expression/embeddedDocs/function/statistics/max.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mean.js","webpack://math/./src/expression/embeddedDocs/function/statistics/median.js","webpack://math/./src/expression/embeddedDocs/function/statistics/min.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mode.js","webpack://math/./src/expression/embeddedDocs/function/statistics/prod.js","webpack://math/./src/expression/embeddedDocs/function/statistics/quantileSeq.js","webpack://math/./src/expression/embeddedDocs/function/statistics/std.js","webpack://math/./src/expression/embeddedDocs/function/statistics/sum.js","webpack://math/./src/expression/embeddedDocs/function/statistics/variance.js","webpack://math/./src/expression/embeddedDocs/function/statistics/corr.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acos.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acosh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acot.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acoth.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acsc.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acsch.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asec.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asech.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asin.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asinh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atan.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atanh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atan2.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cos.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cosh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cot.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/coth.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/csc.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/csch.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sec.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sech.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sin.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sinh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/tan.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/tanh.js","webpack://math/./src/expression/embeddedDocs/function/units/to.js","webpack://math/./src/expression/embeddedDocs/function/utils/clone.js","webpack://math/./src/expression/embeddedDocs/function/utils/format.js","webpack://math/./src/expression/embeddedDocs/function/utils/bin.js","webpack://math/./src/expression/embeddedDocs/function/utils/oct.js","webpack://math/./src/expression/embeddedDocs/function/utils/hex.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNaN.js","webpack://math/./src/expression/embeddedDocs/function/utils/isInteger.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNegative.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNumeric.js","webpack://math/./src/expression/embeddedDocs/function/utils/hasNumericValue.js","webpack://math/./src/expression/embeddedDocs/function/utils/isPositive.js","webpack://math/./src/expression/embeddedDocs/function/utils/isPrime.js","webpack://math/./src/expression/embeddedDocs/function/utils/isZero.js","webpack://math/./src/expression/embeddedDocs/function/utils/print.js","webpack://math/./src/expression/embeddedDocs/function/utils/typeOf.js","webpack://math/./src/expression/embeddedDocs/function/utils/numeric.js","webpack://math/./src/expression/function/help.js","webpack://math/./src/type/chain/function/chain.js","webpack://math/./src/function/matrix/det.js","webpack://math/./src/function/matrix/inv.js","webpack://math/./src/function/matrix/pinv.js","webpack://math/./src/function/matrix/eigs.js","webpack://math/./src/function/matrix/eigs/realSymmetric.js","webpack://math/./src/function/matrix/eigs/complexEigs.js","webpack://math/./src/function/matrix/expm.js","webpack://math/./src/function/matrix/sqrtm.js","webpack://math/./src/function/algebra/sylvester.js","webpack://math/./src/function/algebra/decomposition/schur.js","webpack://math/./src/function/algebra/lyap.js","webpack://math/./src/function/arithmetic/divide.js","webpack://math/./src/function/geometry/distance.js","webpack://math/./src/function/geometry/intersect.js","webpack://math/./src/function/statistics/sum.js","webpack://math/./src/function/statistics/cumsum.js","webpack://math/./src/function/statistics/mean.js","webpack://math/./src/function/statistics/median.js","webpack://math/./src/function/statistics/mad.js","webpack://math/./src/function/statistics/variance.js","webpack://math/./src/function/statistics/quantileSeq.js","webpack://math/./src/function/statistics/std.js","webpack://math/./src/function/statistics/corr.js","webpack://math/./src/utils/product.js","webpack://math/./src/plain/number/combinations.js","webpack://math/./src/function/probability/combinations.js","webpack://math/./src/function/probability/combinationsWithRep.js","webpack://math/./src/plain/number/probability.js","webpack://math/./src/function/probability/gamma.js","webpack://math/./src/function/probability/lgamma.js","webpack://math/./src/function/probability/factorial.js","webpack://math/./src/function/probability/kldivergence.js","webpack://math/./src/function/probability/multinomial.js","webpack://math/./src/function/probability/permutations.js","webpack://math/./src/function/probability/util/seededRNG.js","webpack://math/./src/function/probability/pickRandom.js","webpack://math/./src/function/probability/util/randomMatrix.js","webpack://math/./src/function/probability/random.js","webpack://math/./src/function/probability/randomInt.js","webpack://math/./src/function/combinatorics/stirlingS2.js","webpack://math/./src/function/combinatorics/bellNumbers.js","webpack://math/./src/function/combinatorics/catalan.js","webpack://math/./src/function/combinatorics/composition.js","webpack://math/./src/function/algebra/leafCount.js","webpack://math/./src/function/algebra/simplify/wildcards.js","webpack://math/./src/function/algebra/simplify/util.js","webpack://math/./src/function/algebra/simplify.js","webpack://math/./src/function/algebra/simplifyConstant.js","webpack://math/./src/function/algebra/simplifyCore.js","webpack://math/./src/function/algebra/resolve.js","webpack://math/./src/function/algebra/symbolicEqual.js","webpack://math/./src/function/algebra/derivative.js","webpack://math/./src/function/algebra/rationalize.js","webpack://math/./src/function/signal/zpk2tf.js","webpack://math/./src/function/signal/freqz.js","webpack://math/./src/json/reviver.js","webpack://math/./src/json/replacer.js","webpack://math/./src/plain/number/constants.js","webpack://math/./src/constants.js","webpack://math/./src/version.js","webpack://math/./src/type/unit/physicalConstants.js","webpack://math/./src/expression/transform/apply.transform.js","webpack://math/./src/expression/transform/column.transform.js","webpack://math/./src/expression/transform/utils/compileInlineExpression.js","webpack://math/./src/expression/transform/utils/transformCallback.js","webpack://math/./src/expression/transform/filter.transform.js","webpack://math/./src/expression/transform/forEach.transform.js","webpack://math/./src/expression/transform/index.transform.js","webpack://math/./src/expression/transform/map.transform.js","webpack://math/./src/expression/transform/utils/lastDimToZeroBase.js","webpack://math/./src/expression/transform/utils/dimToZeroBase.js","webpack://math/./src/expression/transform/max.transform.js","webpack://math/./src/expression/transform/mean.transform.js","webpack://math/./src/expression/transform/min.transform.js","webpack://math/./src/expression/transform/range.transform.js","webpack://math/./src/expression/transform/row.transform.js","webpack://math/./src/expression/transform/subset.transform.js","webpack://math/./src/expression/transform/concat.transform.js","webpack://math/./src/expression/transform/diff.transform.js","webpack://math/./src/expression/transform/std.transform.js","webpack://math/./src/expression/transform/sum.transform.js","webpack://math/./src/expression/transform/quantileSeq.transform.js","webpack://math/./src/expression/transform/cumsum.transform.js","webpack://math/./src/expression/transform/variance.transform.js","webpack://math/./src/expression/transform/print.transform.js","webpack://math/./src/expression/transform/and.transform.js","webpack://math/./src/expression/transform/or.transform.js","webpack://math/./src/expression/transform/bitAnd.transform.js","webpack://math/./src/expression/transform/bitOr.transform.js","webpack://math/./src/core/config.js","webpack://math/./src/core/function/config.js","webpack://math/./src/defaultInstance.js","webpack://math/./src/core/create.js","webpack://math/./src/utils/emitter.js","webpack://math/./src/core/function/import.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"math\"] = factory();\n\telse\n\t\troot[\"math\"] = factory();\n})(this, () => {\nreturn ","/**\n * @license Complex.js v2.1.1 12/05/2020\n *\n * Copyright (c) 2020, Robert Eisele (robert@xarg.org)\n * Dual licensed under the MIT or GPL Version 2 licenses.\n **/\n\n/**\n *\n * This class allows the manipulation of complex numbers.\n * You can pass a complex number in different formats. Either as object, double, string or two integer parameters.\n *\n * Object form\n * { re: , im: }\n * { arg: , abs: }\n * { phi: , r: }\n *\n * Array / Vector form\n * [ real, imaginary ]\n *\n * Double form\n * 99.3 - Single double value\n *\n * String form\n * '23.1337' - Simple real number\n * '15+3i' - a simple complex number\n * '3-i' - a simple complex number\n *\n * Example:\n *\n * var c = new Complex('99.3+8i');\n * c.mul({r: 3, i: 9}).div(4.9).sub(3, 2);\n *\n */\n\n(function(root) {\n\n 'use strict';\n\n var cosh = Math.cosh || function(x) {\n return Math.abs(x) < 1e-9 ? 1 - x : (Math.exp(x) + Math.exp(-x)) * 0.5;\n };\n\n var sinh = Math.sinh || function(x) {\n return Math.abs(x) < 1e-9 ? x : (Math.exp(x) - Math.exp(-x)) * 0.5;\n };\n\n /**\n * Calculates cos(x) - 1 using Taylor series if x is small (-¼π ≤ x ≤ ¼π).\n *\n * @param {number} x\n * @returns {number} cos(x) - 1\n */\n var cosm1 = function(x) {\n\n var b = Math.PI / 4;\n if (-b > x || x > b) {\n return Math.cos(x) - 1.0;\n }\n\n /* Calculate horner form of polynomial of taylor series in Q\n var fac = 1, alt = 1, pol = {};\n for (var i = 0; i <= 16; i++) {\n fac*= i || 1;\n if (i % 2 == 0) {\n pol[i] = new Fraction(1, alt * fac);\n alt = -alt;\n }\n }\n console.log(new Polynomial(pol).toHorner()); // (((((((1/20922789888000x^2-1/87178291200)x^2+1/479001600)x^2-1/3628800)x^2+1/40320)x^2-1/720)x^2+1/24)x^2-1/2)x^2+1\n */\n\n var xx = x * x;\n return xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx / 20922789888000\n - 1 / 87178291200)\n + 1 / 479001600)\n - 1 / 3628800)\n + 1 / 40320)\n - 1 / 720)\n + 1 / 24)\n - 1 / 2);\n };\n\n var hypot = function(x, y) {\n\n var a = Math.abs(x);\n var b = Math.abs(y);\n\n if (a < 3000 && b < 3000) {\n return Math.sqrt(a * a + b * b);\n }\n\n if (a < b) {\n a = b;\n b = x / y;\n } else {\n b = y / x;\n }\n return a * Math.sqrt(1 + b * b);\n };\n\n var parser_exit = function() {\n throw SyntaxError('Invalid Param');\n };\n\n /**\n * Calculates log(sqrt(a^2+b^2)) in a way to avoid overflows\n *\n * @param {number} a\n * @param {number} b\n * @returns {number}\n */\n function logHypot(a, b) {\n\n var _a = Math.abs(a);\n var _b = Math.abs(b);\n\n if (a === 0) {\n return Math.log(_b);\n }\n\n if (b === 0) {\n return Math.log(_a);\n }\n\n if (_a < 3000 && _b < 3000) {\n return Math.log(a * a + b * b) * 0.5;\n }\n\n /* I got 4 ideas to compute this property without overflow:\n *\n * Testing 1000000 times with random samples for a,b ∈ [1, 1000000000] against a big decimal library to get an error estimate\n *\n * 1. Only eliminate the square root: (OVERALL ERROR: 3.9122483030951116e-11)\n\n Math.log(a * a + b * b) / 2\n\n *\n *\n * 2. Try to use the non-overflowing pythagoras: (OVERALL ERROR: 8.889760039210159e-10)\n\n var fn = function(a, b) {\n a = Math.abs(a);\n b = Math.abs(b);\n var t = Math.min(a, b);\n a = Math.max(a, b);\n t = t / a;\n\n return Math.log(a) + Math.log(1 + t * t) / 2;\n };\n\n * 3. Abuse the identity cos(atan(y/x) = x / sqrt(x^2+y^2): (OVERALL ERROR: 3.4780178737037204e-10)\n\n Math.log(a / Math.cos(Math.atan2(b, a)))\n\n * 4. Use 3. and apply log rules: (OVERALL ERROR: 1.2014087502620896e-9)\n\n Math.log(a) - Math.log(Math.cos(Math.atan2(b, a)))\n\n */\n\n a = a / 2;\n b = b / 2;\n\n return 0.5 * Math.log(a * a + b * b) + Math.LN2;\n }\n\n var parse = function(a, b) {\n\n var z = { 're': 0, 'im': 0 };\n\n if (a === undefined || a === null) {\n z['re'] =\n z['im'] = 0;\n } else if (b !== undefined) {\n z['re'] = a;\n z['im'] = b;\n } else\n switch (typeof a) {\n\n case 'object':\n\n if ('im' in a && 're' in a) {\n z['re'] = a['re'];\n z['im'] = a['im'];\n } else if ('abs' in a && 'arg' in a) {\n if (!Number.isFinite(a['abs']) && Number.isFinite(a['arg'])) {\n return Complex['INFINITY'];\n }\n z['re'] = a['abs'] * Math.cos(a['arg']);\n z['im'] = a['abs'] * Math.sin(a['arg']);\n } else if ('r' in a && 'phi' in a) {\n if (!Number.isFinite(a['r']) && Number.isFinite(a['phi'])) {\n return Complex['INFINITY'];\n }\n z['re'] = a['r'] * Math.cos(a['phi']);\n z['im'] = a['r'] * Math.sin(a['phi']);\n } else if (a.length === 2) { // Quick array check\n z['re'] = a[0];\n z['im'] = a[1];\n } else {\n parser_exit();\n }\n break;\n\n case 'string':\n\n z['im'] = /* void */\n z['re'] = 0;\n\n var tokens = a.match(/\\d+\\.?\\d*e[+-]?\\d+|\\d+\\.?\\d*|\\.\\d+|./g);\n var plus = 1;\n var minus = 0;\n\n if (tokens === null) {\n parser_exit();\n }\n\n for (var i = 0; i < tokens.length; i++) {\n\n var c = tokens[i];\n\n if (c === ' ' || c === '\\t' || c === '\\n') {\n /* void */\n } else if (c === '+') {\n plus++;\n } else if (c === '-') {\n minus++;\n } else if (c === 'i' || c === 'I') {\n\n if (plus + minus === 0) {\n parser_exit();\n }\n\n if (tokens[i + 1] !== ' ' && !isNaN(tokens[i + 1])) {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + tokens[i + 1]);\n i++;\n } else {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + '1');\n }\n plus = minus = 0;\n\n } else {\n\n if (plus + minus === 0 || isNaN(c)) {\n parser_exit();\n }\n\n if (tokens[i + 1] === 'i' || tokens[i + 1] === 'I') {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + c);\n i++;\n } else {\n z['re'] += parseFloat((minus % 2 ? '-' : '') + c);\n }\n plus = minus = 0;\n }\n }\n\n // Still something on the stack\n if (plus + minus > 0) {\n parser_exit();\n }\n break;\n\n case 'number':\n z['im'] = 0;\n z['re'] = a;\n break;\n\n default:\n parser_exit();\n }\n\n if (isNaN(z['re']) || isNaN(z['im'])) {\n // If a calculation is NaN, we treat it as NaN and don't throw\n //parser_exit();\n }\n\n return z;\n };\n\n /**\n * @constructor\n * @returns {Complex}\n */\n function Complex(a, b) {\n\n if (!(this instanceof Complex)) {\n return new Complex(a, b);\n }\n\n var z = parse(a, b);\n\n this['re'] = z['re'];\n this['im'] = z['im'];\n }\n\n Complex.prototype = {\n\n 're': 0,\n 'im': 0,\n\n /**\n * Calculates the sign of a complex number, which is a normalized complex\n *\n * @returns {Complex}\n */\n 'sign': function() {\n\n var abs = this['abs']();\n\n return new Complex(\n this['re'] / abs,\n this['im'] / abs);\n },\n\n /**\n * Adds two complex numbers\n *\n * @returns {Complex}\n */\n 'add': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity + Infinity = NaN\n if (this['isInfinite']() && z['isInfinite']()) {\n return Complex['NAN'];\n }\n\n // Infinity + z = Infinity { where z != Infinity }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n return new Complex(\n this['re'] + z['re'],\n this['im'] + z['im']);\n },\n\n /**\n * Subtracts two complex numbers\n *\n * @returns {Complex}\n */\n 'sub': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity - Infinity = NaN\n if (this['isInfinite']() && z['isInfinite']()) {\n return Complex['NAN'];\n }\n\n // Infinity - z = Infinity { where z != Infinity }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n return new Complex(\n this['re'] - z['re'],\n this['im'] - z['im']);\n },\n\n /**\n * Multiplies two complex numbers\n *\n * @returns {Complex}\n */\n 'mul': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity * 0 = NaN\n if ((this['isInfinite']() && z['isZero']()) || (this['isZero']() && z['isInfinite']())) {\n return Complex['NAN'];\n }\n\n // Infinity * z = Infinity { where z != 0 }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n // Short circuit for real values\n if (z['im'] === 0 && this['im'] === 0) {\n return new Complex(this['re'] * z['re'], 0);\n }\n\n return new Complex(\n this['re'] * z['re'] - this['im'] * z['im'],\n this['re'] * z['im'] + this['im'] * z['re']);\n },\n\n /**\n * Divides two complex numbers\n *\n * @returns {Complex}\n */\n 'div': function(a, b) {\n\n var z = new Complex(a, b);\n\n // 0 / 0 = NaN and Infinity / Infinity = NaN\n if ((this['isZero']() && z['isZero']()) || (this['isInfinite']() && z['isInfinite']())) {\n return Complex['NAN'];\n }\n\n // Infinity / 0 = Infinity\n if (this['isInfinite']() || z['isZero']()) {\n return Complex['INFINITY'];\n }\n\n // 0 / Infinity = 0\n if (this['isZero']() || z['isInfinite']()) {\n return Complex['ZERO'];\n }\n\n a = this['re'];\n b = this['im'];\n\n var c = z['re'];\n var d = z['im'];\n var t, x;\n\n if (0 === d) {\n // Divisor is real\n return new Complex(a / c, b / c);\n }\n\n if (Math.abs(c) < Math.abs(d)) {\n\n x = c / d;\n t = c * x + d;\n\n return new Complex(\n (a * x + b) / t,\n (b * x - a) / t);\n\n } else {\n\n x = d / c;\n t = d * x + c;\n\n return new Complex(\n (a + b * x) / t,\n (b - a * x) / t);\n }\n },\n\n /**\n * Calculate the power of two complex numbers\n *\n * @returns {Complex}\n */\n 'pow': function(a, b) {\n\n var z = new Complex(a, b);\n\n a = this['re'];\n b = this['im'];\n\n if (z['isZero']()) {\n return Complex['ONE'];\n }\n\n // If the exponent is real\n if (z['im'] === 0) {\n\n if (b === 0 && a > 0) {\n\n return new Complex(Math.pow(a, z['re']), 0);\n\n } else if (a === 0) { // If base is fully imaginary\n\n switch ((z['re'] % 4 + 4) % 4) {\n case 0:\n return new Complex(Math.pow(b, z['re']), 0);\n case 1:\n return new Complex(0, Math.pow(b, z['re']));\n case 2:\n return new Complex(-Math.pow(b, z['re']), 0);\n case 3:\n return new Complex(0, -Math.pow(b, z['re']));\n }\n }\n }\n\n /* I couldn't find a good formula, so here is a derivation and optimization\n *\n * z_1^z_2 = (a + bi)^(c + di)\n * = exp((c + di) * log(a + bi)\n * = pow(a^2 + b^2, (c + di) / 2) * exp(i(c + di)atan2(b, a))\n * =>...\n * Re = (pow(a^2 + b^2, c / 2) * exp(-d * atan2(b, a))) * cos(d * log(a^2 + b^2) / 2 + c * atan2(b, a))\n * Im = (pow(a^2 + b^2, c / 2) * exp(-d * atan2(b, a))) * sin(d * log(a^2 + b^2) / 2 + c * atan2(b, a))\n *\n * =>...\n * Re = exp(c * log(sqrt(a^2 + b^2)) - d * atan2(b, a)) * cos(d * log(sqrt(a^2 + b^2)) + c * atan2(b, a))\n * Im = exp(c * log(sqrt(a^2 + b^2)) - d * atan2(b, a)) * sin(d * log(sqrt(a^2 + b^2)) + c * atan2(b, a))\n *\n * =>\n * Re = exp(c * logsq2 - d * arg(z_1)) * cos(d * logsq2 + c * arg(z_1))\n * Im = exp(c * logsq2 - d * arg(z_1)) * sin(d * logsq2 + c * arg(z_1))\n *\n */\n\n if (a === 0 && b === 0 && z['re'] > 0 && z['im'] >= 0) {\n return Complex['ZERO'];\n }\n\n var arg = Math.atan2(b, a);\n var loh = logHypot(a, b);\n\n a = Math.exp(z['re'] * loh - z['im'] * arg);\n b = z['im'] * loh + z['re'] * arg;\n return new Complex(\n a * Math.cos(b),\n a * Math.sin(b));\n },\n\n /**\n * Calculate the complex square root\n *\n * @returns {Complex}\n */\n 'sqrt': function() {\n\n var a = this['re'];\n var b = this['im'];\n var r = this['abs']();\n\n var re, im;\n\n if (a >= 0) {\n\n if (b === 0) {\n return new Complex(Math.sqrt(a), 0);\n }\n\n re = 0.5 * Math.sqrt(2.0 * (r + a));\n } else {\n re = Math.abs(b) / Math.sqrt(2 * (r - a));\n }\n\n if (a <= 0) {\n im = 0.5 * Math.sqrt(2.0 * (r - a));\n } else {\n im = Math.abs(b) / Math.sqrt(2 * (r + a));\n }\n\n return new Complex(re, b < 0 ? -im : im);\n },\n\n /**\n * Calculate the complex exponent\n *\n * @returns {Complex}\n */\n 'exp': function() {\n\n var tmp = Math.exp(this['re']);\n\n if (this['im'] === 0) {\n //return new Complex(tmp, 0);\n }\n return new Complex(\n tmp * Math.cos(this['im']),\n tmp * Math.sin(this['im']));\n },\n\n /**\n * Calculate the complex exponent and subtracts one.\n *\n * This may be more accurate than `Complex(x).exp().sub(1)` if\n * `x` is small.\n *\n * @returns {Complex}\n */\n 'expm1': function() {\n\n /**\n * exp(a + i*b) - 1\n = exp(a) * (cos(b) + j*sin(b)) - 1\n = expm1(a)*cos(b) + cosm1(b) + j*exp(a)*sin(b)\n */\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.expm1(a) * Math.cos(b) + cosm1(b),\n Math.exp(a) * Math.sin(b));\n },\n\n /**\n * Calculate the natural log\n *\n * @returns {Complex}\n */\n 'log': function() {\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0 && a > 0) {\n //return new Complex(Math.log(a), 0);\n }\n\n return new Complex(\n logHypot(a, b),\n Math.atan2(b, a));\n },\n\n /**\n * Calculate the magnitude of the complex number\n *\n * @returns {number}\n */\n 'abs': function() {\n\n return hypot(this['re'], this['im']);\n },\n\n /**\n * Calculate the angle of the complex number\n *\n * @returns {number}\n */\n 'arg': function() {\n\n return Math.atan2(this['im'], this['re']);\n },\n\n /**\n * Calculate the sine of the complex number\n *\n * @returns {Complex}\n */\n 'sin': function() {\n\n // sin(z) = ( e^iz - e^-iz ) / 2i \n // = sin(a)cosh(b) + i cos(a)sinh(b)\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.sin(a) * cosh(b),\n Math.cos(a) * sinh(b));\n },\n\n /**\n * Calculate the cosine\n *\n * @returns {Complex}\n */\n 'cos': function() {\n\n // cos(z) = ( e^iz + e^-iz ) / 2 \n // = cos(a)cosh(b) - i sin(a)sinh(b)\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.cos(a) * cosh(b),\n -Math.sin(a) * sinh(b));\n },\n\n /**\n * Calculate the tangent\n *\n * @returns {Complex}\n */\n 'tan': function() {\n\n // tan(z) = sin(z) / cos(z) \n // = ( e^iz - e^-iz ) / ( i( e^iz + e^-iz ) )\n // = ( e^2iz - 1 ) / i( e^2iz + 1 )\n // = ( sin(2a) + i sinh(2b) ) / ( cos(2a) + cosh(2b) )\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = Math.cos(a) + cosh(b);\n\n return new Complex(\n Math.sin(a) / d,\n sinh(b) / d);\n },\n\n /**\n * Calculate the cotangent\n *\n * @returns {Complex}\n */\n 'cot': function() {\n\n // cot(c) = i(e^(ci) + e^(-ci)) / (e^(ci) - e^(-ci))\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = Math.cos(a) - cosh(b);\n\n return new Complex(\n -Math.sin(a) / d,\n sinh(b) / d);\n },\n\n /**\n * Calculate the secant\n *\n * @returns {Complex}\n */\n 'sec': function() {\n\n // sec(c) = 2 / (e^(ci) + e^(-ci))\n\n var a = this['re'];\n var b = this['im'];\n var d = 0.5 * cosh(2 * b) + 0.5 * Math.cos(2 * a);\n\n return new Complex(\n Math.cos(a) * cosh(b) / d,\n Math.sin(a) * sinh(b) / d);\n },\n\n /**\n * Calculate the cosecans\n *\n * @returns {Complex}\n */\n 'csc': function() {\n\n // csc(c) = 2i / (e^(ci) - e^(-ci))\n\n var a = this['re'];\n var b = this['im'];\n var d = 0.5 * cosh(2 * b) - 0.5 * Math.cos(2 * a);\n\n return new Complex(\n Math.sin(a) * cosh(b) / d,\n -Math.cos(a) * sinh(b) / d);\n },\n\n /**\n * Calculate the complex arcus sinus\n *\n * @returns {Complex}\n */\n 'asin': function() {\n\n // asin(c) = -i * log(ci + sqrt(1 - c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n var t1 = new Complex(\n b * b - a * a + 1,\n -2 * a * b)['sqrt']();\n\n var t2 = new Complex(\n t1['re'] - b,\n t1['im'] + a)['log']();\n\n return new Complex(t2['im'], -t2['re']);\n },\n\n /**\n * Calculate the complex arcus cosinus\n *\n * @returns {Complex}\n */\n 'acos': function() {\n\n // acos(c) = i * log(c - i * sqrt(1 - c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n var t1 = new Complex(\n b * b - a * a + 1,\n -2 * a * b)['sqrt']();\n\n var t2 = new Complex(\n t1['re'] - b,\n t1['im'] + a)['log']();\n\n return new Complex(Math.PI / 2 - t2['im'], t2['re']);\n },\n\n /**\n * Calculate the complex arcus tangent\n *\n * @returns {Complex}\n */\n 'atan': function() {\n\n // atan(c) = i / 2 log((i + x) / (i - x))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0) {\n\n if (b === 1) {\n return new Complex(0, Infinity);\n }\n\n if (b === -1) {\n return new Complex(0, -Infinity);\n }\n }\n\n var d = a * a + (1.0 - b) * (1.0 - b);\n\n var t1 = new Complex(\n (1 - b * b - a * a) / d,\n -2 * a / d).log();\n\n return new Complex(-0.5 * t1['im'], 0.5 * t1['re']);\n },\n\n /**\n * Calculate the complex arcus cotangent\n *\n * @returns {Complex}\n */\n 'acot': function() {\n\n // acot(c) = i / 2 log((c - i) / (c + i))\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0) {\n return new Complex(Math.atan2(1, a), 0);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).atan()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).atan();\n },\n\n /**\n * Calculate the complex arcus secant\n *\n * @returns {Complex}\n */\n 'asec': function() {\n\n // asec(c) = -i * log(1 / c + sqrt(1 - i / c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(0, Infinity);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).acos()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).acos();\n },\n\n /**\n * Calculate the complex arcus cosecans\n *\n * @returns {Complex}\n */\n 'acsc': function() {\n\n // acsc(c) = -i * log(i / c + sqrt(1 - 1 / c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(Math.PI / 2, Infinity);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).asin()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).asin();\n },\n\n /**\n * Calculate the complex sinh\n *\n * @returns {Complex}\n */\n 'sinh': function() {\n\n // sinh(c) = (e^c - e^-c) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n sinh(a) * Math.cos(b),\n cosh(a) * Math.sin(b));\n },\n\n /**\n * Calculate the complex cosh\n *\n * @returns {Complex}\n */\n 'cosh': function() {\n\n // cosh(c) = (e^c + e^-c) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n cosh(a) * Math.cos(b),\n sinh(a) * Math.sin(b));\n },\n\n /**\n * Calculate the complex tanh\n *\n * @returns {Complex}\n */\n 'tanh': function() {\n\n // tanh(c) = (e^c - e^-c) / (e^c + e^-c)\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = cosh(a) + Math.cos(b);\n\n return new Complex(\n sinh(a) / d,\n Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex coth\n *\n * @returns {Complex}\n */\n 'coth': function() {\n\n // coth(c) = (e^c + e^-c) / (e^c - e^-c)\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = cosh(a) - Math.cos(b);\n\n return new Complex(\n sinh(a) / d,\n -Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex coth\n *\n * @returns {Complex}\n */\n 'csch': function() {\n\n // csch(c) = 2 / (e^c - e^-c)\n\n var a = this['re'];\n var b = this['im'];\n var d = Math.cos(2 * b) - cosh(2 * a);\n\n return new Complex(\n -2 * sinh(a) * Math.cos(b) / d,\n 2 * cosh(a) * Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex sech\n *\n * @returns {Complex}\n */\n 'sech': function() {\n\n // sech(c) = 2 / (e^c + e^-c)\n\n var a = this['re'];\n var b = this['im'];\n var d = Math.cos(2 * b) + cosh(2 * a);\n\n return new Complex(\n 2 * cosh(a) * Math.cos(b) / d,\n -2 * sinh(a) * Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex asinh\n *\n * @returns {Complex}\n */\n 'asinh': function() {\n\n // asinh(c) = log(c + sqrt(c^2 + 1))\n\n var tmp = this['im'];\n this['im'] = -this['re'];\n this['re'] = tmp;\n var res = this['asin']();\n\n this['re'] = -this['im'];\n this['im'] = tmp;\n tmp = res['re'];\n\n res['re'] = -res['im'];\n res['im'] = tmp;\n return res;\n },\n\n /**\n * Calculate the complex acosh\n *\n * @returns {Complex}\n */\n 'acosh': function() {\n\n // acosh(c) = log(c + sqrt(c^2 - 1))\n\n var res = this['acos']();\n if (res['im'] <= 0) {\n var tmp = res['re'];\n res['re'] = -res['im'];\n res['im'] = tmp;\n } else {\n var tmp = res['im'];\n res['im'] = -res['re'];\n res['re'] = tmp;\n }\n return res;\n },\n\n /**\n * Calculate the complex atanh\n *\n * @returns {Complex}\n */\n 'atanh': function() {\n\n // atanh(c) = log((1+c) / (1-c)) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n var noIM = a > 1 && b === 0;\n var oneMinus = 1 - a;\n var onePlus = 1 + a;\n var d = oneMinus * oneMinus + b * b;\n\n var x = (d !== 0)\n ? new Complex(\n (onePlus * oneMinus - b * b) / d,\n (b * oneMinus + onePlus * b) / d)\n : new Complex(\n (a !== -1) ? (a / 0) : 0,\n (b !== 0) ? (b / 0) : 0);\n\n var temp = x['re'];\n x['re'] = logHypot(x['re'], x['im']) / 2;\n x['im'] = Math.atan2(x['im'], temp) / 2;\n if (noIM) {\n x['im'] = -x['im'];\n }\n return x;\n },\n\n /**\n * Calculate the complex acoth\n *\n * @returns {Complex}\n */\n 'acoth': function() {\n\n // acoth(c) = log((c+1) / (c-1)) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(0, Math.PI / 2);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).atanh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).atanh();\n },\n\n /**\n * Calculate the complex acsch\n *\n * @returns {Complex}\n */\n 'acsch': function() {\n\n // acsch(c) = log((1+sqrt(1+c^2))/c)\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0) {\n\n return new Complex(\n (a !== 0)\n ? Math.log(a + Math.sqrt(a * a + 1))\n : Infinity, 0);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).asinh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).asinh();\n },\n\n /**\n * Calculate the complex asech\n *\n * @returns {Complex}\n */\n 'asech': function() {\n\n // asech(c) = log((1+sqrt(1-c^2))/c)\n\n var a = this['re'];\n var b = this['im'];\n\n if (this['isZero']()) {\n return Complex['INFINITY'];\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).acosh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).acosh();\n },\n\n /**\n * Calculate the complex inverse 1/z\n *\n * @returns {Complex}\n */\n 'inverse': function() {\n\n // 1 / 0 = Infinity and 1 / Infinity = 0\n if (this['isZero']()) {\n return Complex['INFINITY'];\n }\n\n if (this['isInfinite']()) {\n return Complex['ZERO'];\n }\n\n var a = this['re'];\n var b = this['im'];\n\n var d = a * a + b * b;\n\n return new Complex(a / d, -b / d);\n },\n\n /**\n * Returns the complex conjugate\n *\n * @returns {Complex}\n */\n 'conjugate': function() {\n\n return new Complex(this['re'], -this['im']);\n },\n\n /**\n * Gets the negated complex number\n *\n * @returns {Complex}\n */\n 'neg': function() {\n\n return new Complex(-this['re'], -this['im']);\n },\n\n /**\n * Ceils the actual complex number\n *\n * @returns {Complex}\n */\n 'ceil': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.ceil(this['re'] * places) / places,\n Math.ceil(this['im'] * places) / places);\n },\n\n /**\n * Floors the actual complex number\n *\n * @returns {Complex}\n */\n 'floor': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.floor(this['re'] * places) / places,\n Math.floor(this['im'] * places) / places);\n },\n\n /**\n * Ceils the actual complex number\n *\n * @returns {Complex}\n */\n 'round': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.round(this['re'] * places) / places,\n Math.round(this['im'] * places) / places);\n },\n\n /**\n * Compares two complex numbers\n *\n * **Note:** new Complex(Infinity).equals(Infinity) === false\n *\n * @returns {boolean}\n */\n 'equals': function(a, b) {\n\n var z = new Complex(a, b);\n\n return Math.abs(z['re'] - this['re']) <= Complex['EPSILON'] &&\n Math.abs(z['im'] - this['im']) <= Complex['EPSILON'];\n },\n\n /**\n * Clones the actual object\n *\n * @returns {Complex}\n */\n 'clone': function() {\n\n return new Complex(this['re'], this['im']);\n },\n\n /**\n * Gets a string of the actual complex number\n *\n * @returns {string}\n */\n 'toString': function() {\n\n var a = this['re'];\n var b = this['im'];\n var ret = \"\";\n\n if (this['isNaN']()) {\n return 'NaN';\n }\n\n if (this['isInfinite']()) {\n return 'Infinity';\n }\n\n if (Math.abs(a) < Complex['EPSILON']) {\n a = 0;\n }\n\n if (Math.abs(b) < Complex['EPSILON']) {\n b = 0;\n }\n\n // If is real number\n if (b === 0) {\n return ret + a;\n }\n\n if (a !== 0) {\n ret += a;\n ret += \" \";\n if (b < 0) {\n b = -b;\n ret += \"-\";\n } else {\n ret += \"+\";\n }\n ret += \" \";\n } else if (b < 0) {\n b = -b;\n ret += \"-\";\n }\n\n if (1 !== b) { // b is the absolute imaginary part\n ret += b;\n }\n return ret + \"i\";\n },\n\n /**\n * Returns the actual number as a vector\n *\n * @returns {Array}\n */\n 'toVector': function() {\n\n return [this['re'], this['im']];\n },\n\n /**\n * Returns the actual real value of the current object\n *\n * @returns {number|null}\n */\n 'valueOf': function() {\n\n if (this['im'] === 0) {\n return this['re'];\n }\n return null;\n },\n\n /**\n * Determines whether a complex number is not on the Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isNaN': function() {\n return isNaN(this['re']) || isNaN(this['im']);\n },\n\n /**\n * Determines whether or not a complex number is at the zero pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isZero': function() {\n return this['im'] === 0 && this['re'] === 0;\n },\n\n /**\n * Determines whether a complex number is not at the infinity pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isFinite': function() {\n return isFinite(this['re']) && isFinite(this['im']);\n },\n\n /**\n * Determines whether or not a complex number is at the infinity pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isInfinite': function() {\n return !(this['isNaN']() || this['isFinite']());\n }\n };\n\n Complex['ZERO'] = new Complex(0, 0);\n Complex['ONE'] = new Complex(1, 0);\n Complex['I'] = new Complex(0, 1);\n Complex['PI'] = new Complex(Math.PI, 0);\n Complex['E'] = new Complex(Math.E, 0);\n Complex['INFINITY'] = new Complex(Infinity, Infinity);\n Complex['NAN'] = new Complex(NaN, NaN);\n Complex['EPSILON'] = 1e-15;\n\n if (typeof define === 'function' && define['amd']) {\n define([], function() {\n return Complex;\n });\n } else if (typeof exports === 'object') {\n Object.defineProperty(Complex, \"__esModule\", { 'value': true });\n Complex['default'] = Complex;\n Complex['Complex'] = Complex;\n module['exports'] = Complex;\n } else {\n root['Complex'] = Complex;\n }\n\n})(this);\n","\"use strict\";\n\n// Map the characters to escape to their escaped values. The list is derived\n// from http://www.cespedes.org/blog/85/how-to-escape-latex-special-characters\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar defaultEscapes = {\n \"{\": \"\\\\{\",\n \"}\": \"\\\\}\",\n \"\\\\\": \"\\\\textbackslash{}\",\n \"#\": \"\\\\#\",\n $: \"\\\\$\",\n \"%\": \"\\\\%\",\n \"&\": \"\\\\&\",\n \"^\": \"\\\\textasciicircum{}\",\n _: \"\\\\_\",\n \"~\": \"\\\\textasciitilde{}\"\n};\nvar formatEscapes = {\n \"\\u2013\": \"\\\\--\",\n \"\\u2014\": \"\\\\---\",\n \" \": \"~\",\n \"\\t\": \"\\\\qquad{}\",\n \"\\r\\n\": \"\\\\newline{}\",\n \"\\n\": \"\\\\newline{}\"\n};\n\nvar defaultEscapeMapFn = function defaultEscapeMapFn(defaultEscapes, formatEscapes) {\n return _extends({}, defaultEscapes, formatEscapes);\n};\n\n/**\n * Escape a string to be used in LaTeX documents.\n * @param {string} str the string to be escaped.\n * @param {boolean} params.preserveFormatting whether formatting escapes should\n * be performed (default: false).\n * @param {function} params.escapeMapFn the function to modify the escape maps.\n * @return {string} the escaped string, ready to be used in LaTeX.\n */\nmodule.exports = function (str) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$preserveFormatti = _ref.preserveFormatting,\n preserveFormatting = _ref$preserveFormatti === undefined ? false : _ref$preserveFormatti,\n _ref$escapeMapFn = _ref.escapeMapFn,\n escapeMapFn = _ref$escapeMapFn === undefined ? defaultEscapeMapFn : _ref$escapeMapFn;\n\n var runningStr = String(str);\n var result = \"\";\n\n var escapes = escapeMapFn(_extends({}, defaultEscapes), preserveFormatting ? _extends({}, formatEscapes) : {});\n var escapeKeys = Object.keys(escapes); // as it is reused later on\n\n // Algorithm: Go through the string character by character, if it matches\n // with one of the special characters then we'll replace it with the escaped\n // version.\n\n var _loop = function _loop() {\n var specialCharFound = false;\n escapeKeys.forEach(function (key, index) {\n if (specialCharFound) {\n return;\n }\n if (runningStr.length >= key.length && runningStr.slice(0, key.length) === key) {\n result += escapes[escapeKeys[index]];\n runningStr = runningStr.slice(key.length, runningStr.length);\n specialCharFound = true;\n }\n });\n if (!specialCharFound) {\n result += runningStr.slice(0, 1);\n runningStr = runningStr.slice(1, runningStr.length);\n }\n };\n\n while (runningStr) {\n _loop();\n }\n return result;\n};","/*\r\n * Natural Sort algorithm for Javascript - Version 0.7 - Released under MIT license\r\n * Author: Jim Palmer (based on chunking idea from Dave Koelle)\r\n */\r\n/*jshint unused:false */\r\nmodule.exports = function naturalSort (a, b) {\r\n\t\"use strict\";\r\n\tvar re = /(^([+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)?$|^0x[0-9a-f]+$|\\d+)/gi,\r\n\t\tsre = /(^[ ]*|[ ]*$)/g,\r\n\t\tdre = /(^([\\w ]+,?[\\w ]+)?[\\w ]+,?[\\w ]+\\d+:\\d+(:\\d+)?[\\w ]?|^\\d{1,4}[\\/\\-]\\d{1,4}[\\/\\-]\\d{1,4}|^\\w+, \\w+ \\d+, \\d{4})/,\r\n\t\thre = /^0x[0-9a-f]+$/i,\r\n\t\tore = /^0/,\r\n\t\ti = function(s) { return naturalSort.insensitive && ('' + s).toLowerCase() || '' + s; },\r\n\t\t// convert all to strings strip whitespace\r\n\t\tx = i(a).replace(sre, '') || '',\r\n\t\ty = i(b).replace(sre, '') || '',\r\n\t\t// chunk/tokenize\r\n\t\txN = x.replace(re, '\\0$1\\0').replace(/\\0$/,'').replace(/^\\0/,'').split('\\0'),\r\n\t\tyN = y.replace(re, '\\0$1\\0').replace(/\\0$/,'').replace(/^\\0/,'').split('\\0'),\r\n\t\t// numeric, hex or date detection\r\n\t\txD = parseInt(x.match(hre), 16) || (xN.length !== 1 && x.match(dre) && Date.parse(x)),\r\n\t\tyD = parseInt(y.match(hre), 16) || xD && y.match(dre) && Date.parse(y) || null,\r\n\t\toFxNcL, oFyNcL;\r\n\t// first try and sort Hex codes or Dates\r\n\tif (yD) {\r\n\t\tif ( xD < yD ) { return -1; }\r\n\t\telse if ( xD > yD ) { return 1; }\r\n\t}\r\n\t// natural sorting through split numeric strings and default strings\r\n\tfor(var cLoc=0, numS=Math.max(xN.length, yN.length); cLoc < numS; cLoc++) {\r\n\t\t// find floats not starting with '0', string or 0 if not defined (Clint Priest)\r\n\t\toFxNcL = !(xN[cLoc] || '').match(ore) && parseFloat(xN[cLoc]) || xN[cLoc] || 0;\r\n\t\toFyNcL = !(yN[cLoc] || '').match(ore) && parseFloat(yN[cLoc]) || yN[cLoc] || 0;\r\n\t\t// handle numeric vs string comparison - number < string - (Kyle Adams)\r\n\t\tif (isNaN(oFxNcL) !== isNaN(oFyNcL)) { return (isNaN(oFxNcL)) ? 1 : -1; }\r\n\t\t// rely on string comparison if different types - i.e. '02' < 2 != '02' < '2'\r\n\t\telse if (typeof oFxNcL !== typeof oFyNcL) {\r\n\t\t\toFxNcL += '';\r\n\t\t\toFyNcL += '';\r\n\t\t}\r\n\t\tif (oFxNcL < oFyNcL) { return -1; }\r\n\t\tif (oFxNcL > oFyNcL) { return 1; }\r\n\t}\r\n\treturn 0;\r\n};\r\n","// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by François Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n","// A port of an algorithm by Johannes Baagøe , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baagøe \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = String(data);\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n","// A Javascript implementaion of the \"xorshift7\" algorithm by\n// François Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n","// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","/*\nCopyright 2019 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (global, pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\n\nvar width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n} else {\n // When included as a plain script, set up Math.seedrandom global.\n math['seed' + rngname] = seedrandom;\n}\n\n\n// End anonymous scope, and pass initial values.\n})(\n // global: `self` in browsers (including strict mode and web workers),\n // otherwise `this` in Node and other environments\n (typeof self !== 'undefined') ? self : this,\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n","function E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsCallable(argument) is true`\nmodule.exports = function (argument) {\n if (isCallable(argument)) return argument;\n throw new $TypeError(tryToString(argument) + ' is not a function');\n};\n","'use strict';\nvar isConstructor = require('../internals/is-constructor');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsConstructor(argument) is true`\nmodule.exports = function (argument) {\n if (isConstructor(argument)) return argument;\n throw new $TypeError(tryToString(argument) + ' is not a constructor');\n};\n","'use strict';\nvar isPossiblePrototype = require('../internals/is-possible-prototype');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (isPossiblePrototype(argument)) return argument;\n throw new $TypeError(\"Can't set \" + $String(argument) + ' as a prototype');\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar create = require('../internals/object-create');\nvar defineProperty = require('../internals/object-define-property').f;\n\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] === undefined) {\n defineProperty(ArrayPrototype, UNSCOPABLES, {\n configurable: true,\n value: create(null)\n });\n}\n\n// add a key to Array.prototype[@@unscopables]\nmodule.exports = function (key) {\n ArrayPrototype[UNSCOPABLES][key] = true;\n};\n","'use strict';\nvar charAt = require('../internals/string-multibyte').charAt;\n\n// `AdvanceStringIndex` abstract operation\n// https://tc39.es/ecma262/#sec-advancestringindex\nmodule.exports = function (S, index, unicode) {\n return index + (unicode ? charAt(S, index).length : 1);\n};\n","'use strict';\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (it, Prototype) {\n if (isPrototypeOf(Prototype, it)) return it;\n throw new $TypeError('Incorrect invocation');\n};\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\n// `Assert: Type(argument) is Object`\nmodule.exports = function (argument) {\n if (isObject(argument)) return argument;\n throw new $TypeError($String(argument) + ' is not an object');\n};\n","'use strict';\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\n// `Array.prototype.{ indexOf, includes }` methods implementation\nvar createMethod = function (IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIndexedObject($this);\n var length = lengthOfArrayLike(O);\n if (length === 0) return !IS_INCLUDES && -1;\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare -- NaN check\n if (IS_INCLUDES && el !== el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare -- NaN check\n if (value !== value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (;length > index; index++) {\n if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;\n } return !IS_INCLUDES && -1;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.includes` method\n // https://tc39.es/ecma262/#sec-array.prototype.includes\n includes: createMethod(true),\n // `Array.prototype.indexOf` method\n // https://tc39.es/ecma262/#sec-array.prototype.indexof\n indexOf: createMethod(false)\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = function (METHOD_NAME, argument) {\n var method = [][METHOD_NAME];\n return !!method && fails(function () {\n // eslint-disable-next-line no-useless-call -- required for testing\n method.call(null, argument || function () { return 1; }, 1);\n });\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar toObject = require('../internals/to-object');\nvar IndexedObject = require('../internals/indexed-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\nvar $TypeError = TypeError;\n\nvar REDUCE_EMPTY = 'Reduce of empty array with no initial value';\n\n// `Array.prototype.{ reduce, reduceRight }` methods implementation\nvar createMethod = function (IS_RIGHT) {\n return function (that, callbackfn, argumentsLength, memo) {\n var O = toObject(that);\n var self = IndexedObject(O);\n var length = lengthOfArrayLike(O);\n aCallable(callbackfn);\n if (length === 0 && argumentsLength < 2) throw new $TypeError(REDUCE_EMPTY);\n var index = IS_RIGHT ? length - 1 : 0;\n var i = IS_RIGHT ? -1 : 1;\n if (argumentsLength < 2) while (true) {\n if (index in self) {\n memo = self[index];\n index += i;\n break;\n }\n index += i;\n if (IS_RIGHT ? index < 0 : length <= index) {\n throw new $TypeError(REDUCE_EMPTY);\n }\n }\n for (;IS_RIGHT ? index >= 0 : length > index; index += i) if (index in self) {\n memo = callbackfn(memo, self[index], index, O);\n }\n return memo;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.reduce` method\n // https://tc39.es/ecma262/#sec-array.prototype.reduce\n left: createMethod(false),\n // `Array.prototype.reduceRight` method\n // https://tc39.es/ecma262/#sec-array.prototype.reduceright\n right: createMethod(true)\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis([].slice);\n","'use strict';\nvar arraySlice = require('../internals/array-slice');\n\nvar floor = Math.floor;\n\nvar sort = function (array, comparefn) {\n var length = array.length;\n\n if (length < 8) {\n // insertion sort\n var i = 1;\n var element, j;\n\n while (i < length) {\n j = i;\n element = array[i];\n while (j && comparefn(array[j - 1], element) > 0) {\n array[j] = array[--j];\n }\n if (j !== i++) array[j] = element;\n }\n } else {\n // merge sort\n var middle = floor(length / 2);\n var left = sort(arraySlice(array, 0, middle), comparefn);\n var right = sort(arraySlice(array, middle), comparefn);\n var llength = left.length;\n var rlength = right.length;\n var lindex = 0;\n var rindex = 0;\n\n while (lindex < llength || rindex < rlength) {\n array[lindex + rindex] = (lindex < llength && rindex < rlength)\n ? comparefn(left[lindex], right[rindex]) <= 0 ? left[lindex++] : right[rindex++]\n : lindex < llength ? left[lindex++] : right[rindex++];\n }\n }\n\n return array;\n};\n\nmodule.exports = sort;\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n var called = 0;\n var iteratorWithReturn = {\n next: function () {\n return { done: !!called++ };\n },\n 'return': function () {\n SAFE_CLOSING = true;\n }\n };\n iteratorWithReturn[ITERATOR] = function () {\n return this;\n };\n // eslint-disable-next-line es/no-array-from, no-throw-literal -- required for testing\n Array.from(iteratorWithReturn, function () { throw 2; });\n} catch (error) { /* empty */ }\n\nmodule.exports = function (exec, SKIP_CLOSING) {\n try {\n if (!SKIP_CLOSING && !SAFE_CLOSING) return false;\n } catch (error) { return false; } // workaround of old WebKit + `eval` bug\n var ITERATION_SUPPORT = false;\n try {\n var object = {};\n object[ITERATOR] = function () {\n return {\n next: function () {\n return { done: ITERATION_SUPPORT = true };\n }\n };\n };\n exec(object);\n } catch (error) { /* empty */ }\n return ITERATION_SUPPORT;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar toString = uncurryThis({}.toString);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (it) {\n return stringSlice(toString(it), 8, -1);\n};\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar isCallable = require('../internals/is-callable');\nvar classofRaw = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar $Object = Object;\n\n// ES3 wrong here\nvar CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) === 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n try {\n return it[key];\n } catch (error) { /* empty */ }\n};\n\n// getting tag from ES6+ `Object.prototype.toString`\nmodule.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {\n var O, tag, result;\n return it === undefined ? 'Undefined' : it === null ? 'Null'\n // @@toStringTag case\n : typeof (tag = tryGet(O = $Object(it), TO_STRING_TAG)) == 'string' ? tag\n // builtinTag case\n : CORRECT_ARGUMENTS ? classofRaw(O)\n // ES3 arguments fallback\n : (result = classofRaw(O)) === 'Object' && isCallable(O.callee) ? 'Arguments' : result;\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar ownKeys = require('../internals/own-keys');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\n\nmodule.exports = function (target, source, exceptions) {\n var keys = ownKeys(source);\n var defineProperty = definePropertyModule.f;\n var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n if (!hasOwn(target, key) && !(exceptions && hasOwn(exceptions, key))) {\n defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n }\n }\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = DESCRIPTORS ? function (object, key, value) {\n return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","'use strict';\nmodule.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = function (object, key, value) {\n if (DESCRIPTORS) definePropertyModule.f(object, key, createPropertyDescriptor(0, value));\n else object[key] = value;\n};\n","'use strict';\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineProperty = require('../internals/object-define-property');\n\nmodule.exports = function (target, name, descriptor) {\n if (descriptor.get) makeBuiltIn(descriptor.get, name, { getter: true });\n if (descriptor.set) makeBuiltIn(descriptor.set, name, { setter: true });\n return defineProperty.f(target, name, descriptor);\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar definePropertyModule = require('../internals/object-define-property');\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nmodule.exports = function (O, key, value, options) {\n if (!options) options = {};\n var simple = options.enumerable;\n var name = options.name !== undefined ? options.name : key;\n if (isCallable(value)) makeBuiltIn(value, name, options);\n if (options.global) {\n if (simple) O[key] = value;\n else defineGlobalProperty(key, value);\n } else {\n try {\n if (!options.unsafe) delete O[key];\n else if (O[key]) simple = true;\n } catch (error) { /* empty */ }\n if (simple) O[key] = value;\n else definePropertyModule.f(O, key, {\n value: value,\n enumerable: false,\n configurable: !options.nonConfigurable,\n writable: !options.nonWritable\n });\n } return O;\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\n\nmodule.exports = function (key, value) {\n try {\n defineProperty(globalThis, key, { value: value, configurable: true, writable: true });\n } catch (error) {\n globalThis[key] = value;\n } return value;\n};\n","'use strict';\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (O, P) {\n if (!delete O[P]) throw new $TypeError('Cannot delete property ' + tryToString(P) + ' of ' + tryToString(O));\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\n// Detect IE8's incomplete defineProperty implementation\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] !== 7;\n});\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\n\nvar document = globalThis.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS = isObject(document) && isObject(document.createElement);\n\nmodule.exports = function (it) {\n return EXISTS ? document.createElement(it) : {};\n};\n","'use strict';\n// IE8- don't enum bug keys\nmodule.exports = [\n 'constructor',\n 'hasOwnProperty',\n 'isPrototypeOf',\n 'propertyIsEnumerable',\n 'toLocaleString',\n 'toString',\n 'valueOf'\n];\n","'use strict';\nvar userAgent = require('../internals/environment-user-agent');\n\nvar firefox = userAgent.match(/firefox\\/(\\d+)/i);\n\nmodule.exports = !!firefox && +firefox[1];\n","'use strict';\nvar UA = require('../internals/environment-user-agent');\n\nmodule.exports = /MSIE|Trident/.test(UA);\n","'use strict';\nvar userAgent = require('../internals/environment-user-agent');\n\nmodule.exports = /ipad|iphone|ipod/i.test(userAgent) && typeof Pebble != 'undefined';\n","'use strict';\nvar userAgent = require('../internals/environment-user-agent');\n\n// eslint-disable-next-line redos/no-vulnerable -- safe\nmodule.exports = /(?:ipad|iphone|ipod).*applewebkit/i.test(userAgent);\n","'use strict';\nvar ENVIRONMENT = require('../internals/environment');\n\nmodule.exports = ENVIRONMENT === 'NODE';\n","'use strict';\nvar userAgent = require('../internals/environment-user-agent');\n\nmodule.exports = /web0s(?!.*chrome)/i.test(userAgent);\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\nvar navigator = globalThis.navigator;\nvar userAgent = navigator && navigator.userAgent;\n\nmodule.exports = userAgent ? String(userAgent) : '';\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar userAgent = require('../internals/environment-user-agent');\n\nvar process = globalThis.process;\nvar Deno = globalThis.Deno;\nvar versions = process && process.versions || Deno && Deno.version;\nvar v8 = versions && versions.v8;\nvar match, version;\n\nif (v8) {\n match = v8.split('.');\n // in old Chrome, versions of V8 isn't V8 = Chrome / 10\n // but their correct versions are not interesting for us\n version = match[0] > 0 && match[0] < 4 ? 1 : +(match[0] + match[1]);\n}\n\n// BrowserFS NodeJS `process` polyfill incorrectly set `.v8` to `0.0`\n// so check `userAgent` even if `.v8` exists, but 0\nif (!version && userAgent) {\n match = userAgent.match(/Edge\\/(\\d+)/);\n if (!match || match[1] >= 74) {\n match = userAgent.match(/Chrome\\/(\\d+)/);\n if (match) version = +match[1];\n }\n}\n\nmodule.exports = version;\n","'use strict';\nvar userAgent = require('../internals/environment-user-agent');\n\nvar webkit = userAgent.match(/AppleWebKit\\/(\\d+)\\./);\n\nmodule.exports = !!webkit && +webkit[1];\n","'use strict';\n/* global Bun, Deno -- detection */\nvar globalThis = require('../internals/global-this');\nvar userAgent = require('../internals/environment-user-agent');\nvar classof = require('../internals/classof-raw');\n\nvar userAgentStartsWith = function (string) {\n return userAgent.slice(0, string.length) === string;\n};\n\nmodule.exports = (function () {\n if (userAgentStartsWith('Bun/')) return 'BUN';\n if (userAgentStartsWith('Cloudflare-Workers')) return 'CLOUDFLARE';\n if (userAgentStartsWith('Deno/')) return 'DENO';\n if (userAgentStartsWith('Node.js/')) return 'NODE';\n if (globalThis.Bun && typeof Bun.version == 'string') return 'BUN';\n if (globalThis.Deno && typeof Deno.version == 'object') return 'DENO';\n if (classof(globalThis.process) === 'process') return 'NODE';\n if (globalThis.window && globalThis.document) return 'BROWSER';\n return 'REST';\n})();\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\nvar isForced = require('../internals/is-forced');\n\n/*\n options.target - name of the target object\n options.global - target is the global object\n options.stat - export as static methods of target\n options.proto - export as prototype methods of target\n options.real - real prototype method for the `pure` version\n options.forced - export even if the native feature is available\n options.bind - bind methods to the target, required for the `pure` version\n options.wrap - wrap constructors to preventing global pollution, required for the `pure` version\n options.unsafe - use the simple assignment of property instead of delete + defineProperty\n options.sham - add a flag to not completely full polyfills\n options.enumerable - export as enumerable property\n options.dontCallGetSet - prevent calling a getter on target\n options.name - the .name of the function if it does not match the key\n*/\nmodule.exports = function (options, source) {\n var TARGET = options.target;\n var GLOBAL = options.global;\n var STATIC = options.stat;\n var FORCED, target, key, targetProperty, sourceProperty, descriptor;\n if (GLOBAL) {\n target = globalThis;\n } else if (STATIC) {\n target = globalThis[TARGET] || defineGlobalProperty(TARGET, {});\n } else {\n target = globalThis[TARGET] && globalThis[TARGET].prototype;\n }\n if (target) for (key in source) {\n sourceProperty = source[key];\n if (options.dontCallGetSet) {\n descriptor = getOwnPropertyDescriptor(target, key);\n targetProperty = descriptor && descriptor.value;\n } else targetProperty = target[key];\n FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);\n // contained in target\n if (!FORCED && targetProperty !== undefined) {\n if (typeof sourceProperty == typeof targetProperty) continue;\n copyConstructorProperties(sourceProperty, targetProperty);\n }\n // add a flag to not completely full polyfills\n if (options.sham || (targetProperty && targetProperty.sham)) {\n createNonEnumerableProperty(sourceProperty, 'sham', true);\n }\n defineBuiltIn(target, key, sourceProperty, options);\n }\n};\n","'use strict';\nmodule.exports = function (exec) {\n try {\n return !!exec();\n } catch (error) {\n return true;\n }\n};\n","'use strict';\n// TODO: Remove from `core-js@4` since it's moved to entry points\nrequire('../modules/es.regexp.exec');\nvar call = require('../internals/function-call');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar regexpExec = require('../internals/regexp-exec');\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\n\nvar SPECIES = wellKnownSymbol('species');\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (KEY, exec, FORCED, SHAM) {\n var SYMBOL = wellKnownSymbol(KEY);\n\n var DELEGATES_TO_SYMBOL = !fails(function () {\n // String methods call symbol-named RegExp methods\n var O = {};\n O[SYMBOL] = function () { return 7; };\n return ''[KEY](O) !== 7;\n });\n\n var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL && !fails(function () {\n // Symbol-named RegExp methods call .exec\n var execCalled = false;\n var re = /a/;\n\n if (KEY === 'split') {\n // We can't use real regex here since it causes deoptimization\n // and serious performance degradation in V8\n // https://github.com/zloirock/core-js/issues/306\n re = {};\n // RegExp[@@split] doesn't call the regex's exec method, but first creates\n // a new one. We need to return the patched regex when creating the new one.\n re.constructor = {};\n re.constructor[SPECIES] = function () { return re; };\n re.flags = '';\n re[SYMBOL] = /./[SYMBOL];\n }\n\n re.exec = function () {\n execCalled = true;\n return null;\n };\n\n re[SYMBOL]('');\n return !execCalled;\n });\n\n if (\n !DELEGATES_TO_SYMBOL ||\n !DELEGATES_TO_EXEC ||\n FORCED\n ) {\n var nativeRegExpMethod = /./[SYMBOL];\n var methods = exec(SYMBOL, ''[KEY], function (nativeMethod, regexp, str, arg2, forceStringMethod) {\n var $exec = regexp.exec;\n if ($exec === regexpExec || $exec === RegExpPrototype.exec) {\n if (DELEGATES_TO_SYMBOL && !forceStringMethod) {\n // The native String method already delegates to @@method (this\n // polyfilled function), leasing to infinite recursion.\n // We avoid it by directly calling the native @@method method.\n return { done: true, value: call(nativeRegExpMethod, regexp, str, arg2) };\n }\n return { done: true, value: call(nativeMethod, str, regexp, arg2) };\n }\n return { done: false };\n });\n\n defineBuiltIn(String.prototype, KEY, methods[0]);\n defineBuiltIn(RegExpPrototype, SYMBOL, methods[1]);\n }\n\n if (SHAM) createNonEnumerableProperty(RegExpPrototype[SYMBOL], 'sham', true);\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar apply = FunctionPrototype.apply;\nvar call = FunctionPrototype.call;\n\n// eslint-disable-next-line es/no-reflect -- safe\nmodule.exports = typeof Reflect == 'object' && Reflect.apply || (NATIVE_BIND ? call.bind(apply) : function () {\n return call.apply(apply, arguments);\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this-clause');\nvar aCallable = require('../internals/a-callable');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar bind = uncurryThis(uncurryThis.bind);\n\n// optional / simple context binding\nmodule.exports = function (fn, that) {\n aCallable(fn);\n return that === undefined ? fn : NATIVE_BIND ? bind(fn, that) : function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-function-prototype-bind -- safe\n var test = (function () { /* empty */ }).bind();\n // eslint-disable-next-line no-prototype-builtins -- safe\n return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar call = Function.prototype.call;\n\nmodule.exports = NATIVE_BIND ? call.bind(call) : function () {\n return call.apply(call, arguments);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar hasOwn = require('../internals/has-own-property');\n\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS && Object.getOwnPropertyDescriptor;\n\nvar EXISTS = hasOwn(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && (function something() { /* empty */ }).name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS || (DESCRIPTORS && getDescriptor(FunctionPrototype, 'name').configurable));\n\nmodule.exports = {\n EXISTS: EXISTS,\n PROPER: PROPER,\n CONFIGURABLE: CONFIGURABLE\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\n\nmodule.exports = function (object, key, method) {\n try {\n // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\n return uncurryThis(aCallable(Object.getOwnPropertyDescriptor(object, key)[method]));\n } catch (error) { /* empty */ }\n};\n","'use strict';\nvar classofRaw = require('../internals/classof-raw');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = function (fn) {\n // Nashorn bug:\n // https://github.com/zloirock/core-js/issues/1128\n // https://github.com/zloirock/core-js/issues/1130\n if (classofRaw(fn) === 'Function') return uncurryThis(fn);\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar call = FunctionPrototype.call;\nvar uncurryThisWithBind = NATIVE_BIND && FunctionPrototype.bind.bind(call, call);\n\nmodule.exports = NATIVE_BIND ? uncurryThisWithBind : function (fn) {\n return function () {\n return call.apply(fn, arguments);\n };\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isCallable = require('../internals/is-callable');\n\nvar aFunction = function (argument) {\n return isCallable(argument) ? argument : undefined;\n};\n\nmodule.exports = function (namespace, method) {\n return arguments.length < 2 ? aFunction(globalThis[namespace]) : globalThis[namespace] && globalThis[namespace][method];\n};\n","'use strict';\nvar classof = require('../internals/classof');\nvar getMethod = require('../internals/get-method');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar Iterators = require('../internals/iterators');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = function (it) {\n if (!isNullOrUndefined(it)) return getMethod(it, ITERATOR)\n || getMethod(it, '@@iterator')\n || Iterators[classof(it)];\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument, usingIterator) {\n var iteratorMethod = arguments.length < 2 ? getIteratorMethod(argument) : usingIterator;\n if (aCallable(iteratorMethod)) return anObject(call(iteratorMethod, argument));\n throw new $TypeError(tryToString(argument) + ' is not iterable');\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isArray = require('../internals/is-array');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar toString = require('../internals/to-string');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (replacer) {\n if (isCallable(replacer)) return replacer;\n if (!isArray(replacer)) return;\n var rawLength = replacer.length;\n var keys = [];\n for (var i = 0; i < rawLength; i++) {\n var element = replacer[i];\n if (typeof element == 'string') push(keys, element);\n else if (typeof element == 'number' || classof(element) === 'Number' || classof(element) === 'String') push(keys, toString(element));\n }\n var keysLength = keys.length;\n var root = true;\n return function (key, value) {\n if (root) {\n root = false;\n return value;\n }\n if (isArray(this)) return value;\n for (var j = 0; j < keysLength; j++) if (keys[j] === key) return value;\n };\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\n// `GetMethod` abstract operation\n// https://tc39.es/ecma262/#sec-getmethod\nmodule.exports = function (V, P) {\n var func = V[P];\n return isNullOrUndefined(func) ? undefined : aCallable(func);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar floor = Math.floor;\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n// eslint-disable-next-line redos/no-vulnerable -- safe\nvar SUBSTITUTION_SYMBOLS = /\\$([$&'`]|\\d{1,2}|<[^>]*>)/g;\nvar SUBSTITUTION_SYMBOLS_NO_NAMED = /\\$([$&'`]|\\d{1,2})/g;\n\n// `GetSubstitution` abstract operation\n// https://tc39.es/ecma262/#sec-getsubstitution\nmodule.exports = function (matched, str, position, captures, namedCaptures, replacement) {\n var tailPos = position + matched.length;\n var m = captures.length;\n var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;\n if (namedCaptures !== undefined) {\n namedCaptures = toObject(namedCaptures);\n symbols = SUBSTITUTION_SYMBOLS;\n }\n return replace(replacement, symbols, function (match, ch) {\n var capture;\n switch (charAt(ch, 0)) {\n case '$': return '$';\n case '&': return matched;\n case '`': return stringSlice(str, 0, position);\n case \"'\": return stringSlice(str, tailPos);\n case '<':\n capture = namedCaptures[stringSlice(ch, 1, -1)];\n break;\n default: // \\d\\d?\n var n = +ch;\n if (n === 0) return match;\n if (n > m) {\n var f = floor(n / 10);\n if (f === 0) return match;\n if (f <= m) return captures[f - 1] === undefined ? charAt(ch, 1) : captures[f - 1] + charAt(ch, 1);\n return match;\n }\n capture = captures[n - 1];\n }\n return capture === undefined ? '' : capture;\n });\n};\n","'use strict';\nvar check = function (it) {\n return it && it.Math === Math && it;\n};\n\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nmodule.exports =\n // eslint-disable-next-line es/no-global-this -- safe\n check(typeof globalThis == 'object' && globalThis) ||\n check(typeof window == 'object' && window) ||\n // eslint-disable-next-line no-restricted-globals -- safe\n check(typeof self == 'object' && self) ||\n check(typeof global == 'object' && global) ||\n check(typeof this == 'object' && this) ||\n // eslint-disable-next-line no-new-func -- fallback\n (function () { return this; })() || Function('return this')();\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar hasOwnProperty = uncurryThis({}.hasOwnProperty);\n\n// `HasOwnProperty` abstract operation\n// https://tc39.es/ecma262/#sec-hasownproperty\n// eslint-disable-next-line es/no-object-hasown -- safe\nmodule.exports = Object.hasOwn || function hasOwn(it, key) {\n return hasOwnProperty(toObject(it), key);\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nmodule.exports = function (a, b) {\n try {\n // eslint-disable-next-line no-console -- safe\n arguments.length === 1 ? console.error(a) : console.error(a, b);\n } catch (error) { /* empty */ }\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\nvar createElement = require('../internals/document-create-element');\n\n// Thanks to IE8 for its funny defineProperty\nmodule.exports = !DESCRIPTORS && !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(createElement('div'), 'a', {\n get: function () { return 7; }\n }).a !== 7;\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar classof = require('../internals/classof-raw');\n\nvar $Object = Object;\nvar split = uncurryThis(''.split);\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\nmodule.exports = fails(function () {\n // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346\n // eslint-disable-next-line no-prototype-builtins -- safe\n return !$Object('z').propertyIsEnumerable(0);\n}) ? function (it) {\n return classof(it) === 'String' ? split(it, '') : $Object(it);\n} : $Object;\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\n\n// makes subclassing work correct for wrapped built-ins\nmodule.exports = function ($this, dummy, Wrapper) {\n var NewTarget, NewTargetPrototype;\n if (\n // it can work only with native `setPrototypeOf`\n setPrototypeOf &&\n // we haven't completely correct pre-ES6 way for getting `new.target`, so use this\n isCallable(NewTarget = dummy.constructor) &&\n NewTarget !== Wrapper &&\n isObject(NewTargetPrototype = NewTarget.prototype) &&\n NewTargetPrototype !== Wrapper.prototype\n ) setPrototypeOf($this, NewTargetPrototype);\n return $this;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isCallable = require('../internals/is-callable');\nvar store = require('../internals/shared-store');\n\nvar functionToString = uncurryThis(Function.toString);\n\n// this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper\nif (!isCallable(store.inspectSource)) {\n store.inspectSource = function (it) {\n return functionToString(it);\n };\n}\n\nmodule.exports = store.inspectSource;\n","'use strict';\nvar NATIVE_WEAK_MAP = require('../internals/weak-map-basic-detection');\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar hasOwn = require('../internals/has-own-property');\nvar shared = require('../internals/shared-store');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError = globalThis.TypeError;\nvar WeakMap = globalThis.WeakMap;\nvar set, get, has;\n\nvar enforce = function (it) {\n return has(it) ? get(it) : set(it, {});\n};\n\nvar getterFor = function (TYPE) {\n return function (it) {\n var state;\n if (!isObject(it) || (state = get(it)).type !== TYPE) {\n throw new TypeError('Incompatible receiver, ' + TYPE + ' required');\n } return state;\n };\n};\n\nif (NATIVE_WEAK_MAP || shared.state) {\n var store = shared.state || (shared.state = new WeakMap());\n /* eslint-disable no-self-assign -- prototype methods protection */\n store.get = store.get;\n store.has = store.has;\n store.set = store.set;\n /* eslint-enable no-self-assign -- prototype methods protection */\n set = function (it, metadata) {\n if (store.has(it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n store.set(it, metadata);\n return metadata;\n };\n get = function (it) {\n return store.get(it) || {};\n };\n has = function (it) {\n return store.has(it);\n };\n} else {\n var STATE = sharedKey('state');\n hiddenKeys[STATE] = true;\n set = function (it, metadata) {\n if (hasOwn(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n createNonEnumerableProperty(it, STATE, metadata);\n return metadata;\n };\n get = function (it) {\n return hasOwn(it, STATE) ? it[STATE] : {};\n };\n has = function (it) {\n return hasOwn(it, STATE);\n };\n}\n\nmodule.exports = {\n set: set,\n get: get,\n has: has,\n enforce: enforce,\n getterFor: getterFor\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar ArrayPrototype = Array.prototype;\n\n// check on default Array iterator\nmodule.exports = function (it) {\n return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);\n};\n","'use strict';\nvar classof = require('../internals/classof-raw');\n\n// `IsArray` abstract operation\n// https://tc39.es/ecma262/#sec-isarray\n// eslint-disable-next-line es/no-array-isarray -- safe\nmodule.exports = Array.isArray || function isArray(argument) {\n return classof(argument) === 'Array';\n};\n","'use strict';\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot\nvar documentAll = typeof document == 'object' && document.all;\n\n// `IsCallable` abstract operation\n// https://tc39.es/ecma262/#sec-iscallable\n// eslint-disable-next-line unicorn/no-typeof-undefined -- required for testing\nmodule.exports = typeof documentAll == 'undefined' && documentAll !== undefined ? function (argument) {\n return typeof argument == 'function' || argument === documentAll;\n} : function (argument) {\n return typeof argument == 'function';\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof');\nvar getBuiltIn = require('../internals/get-built-in');\nvar inspectSource = require('../internals/inspect-source');\n\nvar noop = function () { /* empty */ };\nvar construct = getBuiltIn('Reflect', 'construct');\nvar constructorRegExp = /^\\s*(?:class|function)\\b/;\nvar exec = uncurryThis(constructorRegExp.exec);\nvar INCORRECT_TO_STRING = !constructorRegExp.test(noop);\n\nvar isConstructorModern = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n try {\n construct(noop, [], argument);\n return true;\n } catch (error) {\n return false;\n }\n};\n\nvar isConstructorLegacy = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n switch (classof(argument)) {\n case 'AsyncFunction':\n case 'GeneratorFunction':\n case 'AsyncGeneratorFunction': return false;\n }\n try {\n // we can't check .prototype since constructors produced by .bind haven't it\n // `Function#toString` throws on some built-it function in some legacy engines\n // (for example, `DOMQuad` and similar in FF41-)\n return INCORRECT_TO_STRING || !!exec(constructorRegExp, inspectSource(argument));\n } catch (error) {\n return true;\n }\n};\n\nisConstructorLegacy.sham = true;\n\n// `IsConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-isconstructor\nmodule.exports = !construct || fails(function () {\n var called;\n return isConstructorModern(isConstructorModern.call)\n || !isConstructorModern(Object)\n || !isConstructorModern(function () { called = true; })\n || called;\n}) ? isConstructorLegacy : isConstructorModern;\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\n\nvar replacement = /#|\\.prototype\\./;\n\nvar isForced = function (feature, detection) {\n var value = data[normalize(feature)];\n return value === POLYFILL ? true\n : value === NATIVE ? false\n : isCallable(detection) ? fails(detection)\n : !!detection;\n};\n\nvar normalize = isForced.normalize = function (string) {\n return String(string).replace(replacement, '.').toLowerCase();\n};\n\nvar data = isForced.data = {};\nvar NATIVE = isForced.NATIVE = 'N';\nvar POLYFILL = isForced.POLYFILL = 'P';\n\nmodule.exports = isForced;\n","'use strict';\n// we can't use just `it == null` since of `document.all` special case\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot-aec\nmodule.exports = function (it) {\n return it === null || it === undefined;\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\n\nmodule.exports = function (it) {\n return typeof it == 'object' ? it !== null : isCallable(it);\n};\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nmodule.exports = function (argument) {\n return isObject(argument) || argument === null;\n};\n","'use strict';\nmodule.exports = false;\n","'use strict';\nvar isObject = require('../internals/is-object');\nvar classof = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar MATCH = wellKnownSymbol('match');\n\n// `IsRegExp` abstract operation\n// https://tc39.es/ecma262/#sec-isregexp\nmodule.exports = function (it) {\n var isRegExp;\n return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classof(it) === 'RegExp');\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar $Object = Object;\n\nmodule.exports = USE_SYMBOL_AS_UID ? function (it) {\n return typeof it == 'symbol';\n} : function (it) {\n var $Symbol = getBuiltIn('Symbol');\n return isCallable($Symbol) && isPrototypeOf($Symbol.prototype, $Object(it));\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar $TypeError = TypeError;\n\nvar Result = function (stopped, result) {\n this.stopped = stopped;\n this.result = result;\n};\n\nvar ResultPrototype = Result.prototype;\n\nmodule.exports = function (iterable, unboundFunction, options) {\n var that = options && options.that;\n var AS_ENTRIES = !!(options && options.AS_ENTRIES);\n var IS_RECORD = !!(options && options.IS_RECORD);\n var IS_ITERATOR = !!(options && options.IS_ITERATOR);\n var INTERRUPTED = !!(options && options.INTERRUPTED);\n var fn = bind(unboundFunction, that);\n var iterator, iterFn, index, length, result, next, step;\n\n var stop = function (condition) {\n if (iterator) iteratorClose(iterator, 'normal', condition);\n return new Result(true, condition);\n };\n\n var callFn = function (value) {\n if (AS_ENTRIES) {\n anObject(value);\n return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);\n } return INTERRUPTED ? fn(value, stop) : fn(value);\n };\n\n if (IS_RECORD) {\n iterator = iterable.iterator;\n } else if (IS_ITERATOR) {\n iterator = iterable;\n } else {\n iterFn = getIteratorMethod(iterable);\n if (!iterFn) throw new $TypeError(tryToString(iterable) + ' is not iterable');\n // optimisation for array iterators\n if (isArrayIteratorMethod(iterFn)) {\n for (index = 0, length = lengthOfArrayLike(iterable); length > index; index++) {\n result = callFn(iterable[index]);\n if (result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n }\n iterator = getIterator(iterable, iterFn);\n }\n\n next = IS_RECORD ? iterable.next : iterator.next;\n while (!(step = call(next, iterator)).done) {\n try {\n result = callFn(step.value);\n } catch (error) {\n iteratorClose(iterator, 'throw', error);\n }\n if (typeof result == 'object' && result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar getMethod = require('../internals/get-method');\n\nmodule.exports = function (iterator, kind, value) {\n var innerResult, innerError;\n anObject(iterator);\n try {\n innerResult = getMethod(iterator, 'return');\n if (!innerResult) {\n if (kind === 'throw') throw value;\n return value;\n }\n innerResult = call(innerResult, iterator);\n } catch (error) {\n innerError = true;\n innerResult = error;\n }\n if (kind === 'throw') throw value;\n if (innerError) throw innerResult;\n anObject(innerResult);\n return value;\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar toLength = require('../internals/to-length');\n\n// `LengthOfArrayLike` abstract operation\n// https://tc39.es/ecma262/#sec-lengthofarraylike\nmodule.exports = function (obj) {\n return toLength(obj.length);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar CONFIGURABLE_FUNCTION_NAME = require('../internals/function-name').CONFIGURABLE;\nvar inspectSource = require('../internals/inspect-source');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar $String = String;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\nvar stringSlice = uncurryThis(''.slice);\nvar replace = uncurryThis(''.replace);\nvar join = uncurryThis([].join);\n\nvar CONFIGURABLE_LENGTH = DESCRIPTORS && !fails(function () {\n return defineProperty(function () { /* empty */ }, 'length', { value: 8 }).length !== 8;\n});\n\nvar TEMPLATE = String(String).split('String');\n\nvar makeBuiltIn = module.exports = function (value, name, options) {\n if (stringSlice($String(name), 0, 7) === 'Symbol(') {\n name = '[' + replace($String(name), /^Symbol\\(([^)]*)\\).*$/, '$1') + ']';\n }\n if (options && options.getter) name = 'get ' + name;\n if (options && options.setter) name = 'set ' + name;\n if (!hasOwn(value, 'name') || (CONFIGURABLE_FUNCTION_NAME && value.name !== name)) {\n if (DESCRIPTORS) defineProperty(value, 'name', { value: name, configurable: true });\n else value.name = name;\n }\n if (CONFIGURABLE_LENGTH && options && hasOwn(options, 'arity') && value.length !== options.arity) {\n defineProperty(value, 'length', { value: options.arity });\n }\n try {\n if (options && hasOwn(options, 'constructor') && options.constructor) {\n if (DESCRIPTORS) defineProperty(value, 'prototype', { writable: false });\n // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n } else if (value.prototype) value.prototype = undefined;\n } catch (error) { /* empty */ }\n var state = enforceInternalState(value);\n if (!hasOwn(state, 'source')) {\n state.source = join(TEMPLATE, typeof name == 'string' ? name : '');\n } return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn(function toString() {\n return isCallable(this) && getInternalState(this).source || inspectSource(this);\n}, 'toString');\n","'use strict';\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nmodule.exports = Math.trunc || function trunc(x) {\n var n = +x;\n return (n > 0 ? floor : ceil)(n);\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar safeGetBuiltIn = require('../internals/safe-get-built-in');\nvar bind = require('../internals/function-bind-context');\nvar macrotask = require('../internals/task').set;\nvar Queue = require('../internals/queue');\nvar IS_IOS = require('../internals/environment-is-ios');\nvar IS_IOS_PEBBLE = require('../internals/environment-is-ios-pebble');\nvar IS_WEBOS_WEBKIT = require('../internals/environment-is-webos-webkit');\nvar IS_NODE = require('../internals/environment-is-node');\n\nvar MutationObserver = globalThis.MutationObserver || globalThis.WebKitMutationObserver;\nvar document = globalThis.document;\nvar process = globalThis.process;\nvar Promise = globalThis.Promise;\nvar microtask = safeGetBuiltIn('queueMicrotask');\nvar notify, toggle, node, promise, then;\n\n// modern engines have queueMicrotask method\nif (!microtask) {\n var queue = new Queue();\n\n var flush = function () {\n var parent, fn;\n if (IS_NODE && (parent = process.domain)) parent.exit();\n while (fn = queue.get()) try {\n fn();\n } catch (error) {\n if (queue.head) notify();\n throw error;\n }\n if (parent) parent.enter();\n };\n\n // browsers with MutationObserver, except iOS - https://github.com/zloirock/core-js/issues/339\n // also except WebOS Webkit https://github.com/zloirock/core-js/issues/898\n if (!IS_IOS && !IS_NODE && !IS_WEBOS_WEBKIT && MutationObserver && document) {\n toggle = true;\n node = document.createTextNode('');\n new MutationObserver(flush).observe(node, { characterData: true });\n notify = function () {\n node.data = toggle = !toggle;\n };\n // environments with maybe non-completely correct, but existent Promise\n } else if (!IS_IOS_PEBBLE && Promise && Promise.resolve) {\n // Promise.resolve without an argument throws an error in LG WebOS 2\n promise = Promise.resolve(undefined);\n // workaround of WebKit ~ iOS Safari 10.1 bug\n promise.constructor = Promise;\n then = bind(promise.then, promise);\n notify = function () {\n then(flush);\n };\n // Node.js without promises\n } else if (IS_NODE) {\n notify = function () {\n process.nextTick(flush);\n };\n // for other environments - macrotask based on:\n // - setImmediate\n // - MessageChannel\n // - window.postMessage\n // - onreadystatechange\n // - setTimeout\n } else {\n // `webpack` dev server bug on IE global methods - use bind(fn, global)\n macrotask = bind(macrotask, globalThis);\n notify = function () {\n macrotask(flush);\n };\n }\n\n microtask = function (fn) {\n if (!queue.head) notify();\n queue.add(fn);\n };\n}\n\nmodule.exports = microtask;\n","'use strict';\nvar aCallable = require('../internals/a-callable');\n\nvar $TypeError = TypeError;\n\nvar PromiseCapability = function (C) {\n var resolve, reject;\n this.promise = new C(function ($$resolve, $$reject) {\n if (resolve !== undefined || reject !== undefined) throw new $TypeError('Bad Promise constructor');\n resolve = $$resolve;\n reject = $$reject;\n });\n this.resolve = aCallable(resolve);\n this.reject = aCallable(reject);\n};\n\n// `NewPromiseCapability` abstract operation\n// https://tc39.es/ecma262/#sec-newpromisecapability\nmodule.exports.f = function (C) {\n return new PromiseCapability(C);\n};\n","'use strict';\n/* global ActiveXObject -- old IE, WSH */\nvar anObject = require('../internals/an-object');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n // eslint-disable-next-line no-useless-assignment -- avoid memory leak\n activeXDocument = null;\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n try {\n activeXDocument = new ActiveXObject('htmlfile');\n } catch (error) { /* ignore */ }\n NullProtoObject = typeof document != 'undefined'\n ? document.domain && activeXDocument\n ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n : NullProtoObjectViaIFrame()\n : NullProtoObjectViaActiveX(activeXDocument); // WSH\n var length = enumBugKeys.length;\n while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = NullProtoObject();\n return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar definePropertyModule = require('../internals/object-define-property');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar objectKeys = require('../internals/object-keys');\n\n// `Object.defineProperties` method\n// https://tc39.es/ecma262/#sec-object.defineproperties\n// eslint-disable-next-line es/no-object-defineproperties -- safe\nexports.f = DESCRIPTORS && !V8_PROTOTYPE_DEFINE_BUG ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject(O);\n var props = toIndexedObject(Properties);\n var keys = objectKeys(Properties);\n var length = keys.length;\n var index = 0;\n var key;\n while (length > index) definePropertyModule.f(O, key = keys[index++], props[key]);\n return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar anObject = require('../internals/an-object');\nvar toPropertyKey = require('../internals/to-property-key');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar $defineProperty = Object.defineProperty;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar ENUMERABLE = 'enumerable';\nvar CONFIGURABLE = 'configurable';\nvar WRITABLE = 'writable';\n\n// `Object.defineProperty` method\n// https://tc39.es/ecma262/#sec-object.defineproperty\nexports.f = DESCRIPTORS ? V8_PROTOTYPE_DEFINE_BUG ? function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {\n var current = $getOwnPropertyDescriptor(O, P);\n if (current && current[WRITABLE]) {\n O[P] = Attributes.value;\n Attributes = {\n configurable: CONFIGURABLE in Attributes ? Attributes[CONFIGURABLE] : current[CONFIGURABLE],\n enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],\n writable: false\n };\n }\n } return $defineProperty(O, P, Attributes);\n} : $defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return $defineProperty(O, P, Attributes);\n } catch (error) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw new $TypeError('Accessors not supported');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar call = require('../internals/function-call');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar hasOwn = require('../internals/has-own-property');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\nexports.f = DESCRIPTORS ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {\n O = toIndexedObject(O);\n P = toPropertyKey(P);\n if (IE8_DOM_DEFINE) try {\n return $getOwnPropertyDescriptor(O, P);\n } catch (error) { /* empty */ }\n if (hasOwn(O, P)) return createPropertyDescriptor(!call(propertyIsEnumerableModule.f, O, P), O[P]);\n};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\nvar hiddenKeys = enumBugKeys.concat('length', 'prototype');\n\n// `Object.getOwnPropertyNames` method\n// https://tc39.es/ecma262/#sec-object.getownpropertynames\n// eslint-disable-next-line es/no-object-getownpropertynames -- safe\nexports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n return internalObjectKeys(O, hiddenKeys);\n};\n","'use strict';\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nexports.f = Object.getOwnPropertySymbols;\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis({}.isPrototypeOf);\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar indexOf = require('../internals/array-includes').indexOf;\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (object, names) {\n var O = toIndexedObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) !hasOwn(hiddenKeys, key) && hasOwn(O, key) && push(result, key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (hasOwn(O, key = names[i++])) {\n ~indexOf(result, key) || push(result, key);\n }\n return result;\n};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nmodule.exports = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys);\n};\n","'use strict';\nvar $propertyIsEnumerable = {}.propertyIsEnumerable;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Nashorn ~ JDK8 bug\nvar NASHORN_BUG = getOwnPropertyDescriptor && !$propertyIsEnumerable.call({ 1: 2 }, 1);\n\n// `Object.prototype.propertyIsEnumerable` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable\nexports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {\n var descriptor = getOwnPropertyDescriptor(this, V);\n return !!descriptor && descriptor.enumerable;\n} : $propertyIsEnumerable;\n","'use strict';\n/* eslint-disable no-proto -- safe */\nvar uncurryThisAccessor = require('../internals/function-uncurry-this-accessor');\nvar isObject = require('../internals/is-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar aPossiblePrototype = require('../internals/a-possible-prototype');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n// eslint-disable-next-line es/no-object-setprototypeof -- safe\nmodule.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {\n var CORRECT_SETTER = false;\n var test = {};\n var setter;\n try {\n setter = uncurryThisAccessor(Object.prototype, '__proto__', 'set');\n setter(test, []);\n CORRECT_SETTER = test instanceof Array;\n } catch (error) { /* empty */ }\n return function setPrototypeOf(O, proto) {\n requireObjectCoercible(O);\n aPossiblePrototype(proto);\n if (!isObject(O)) return O;\n if (CORRECT_SETTER) setter(O, proto);\n else O.__proto__ = proto;\n return O;\n };\n}() : undefined);\n","'use strict';\nvar call = require('../internals/function-call');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\n\nvar $TypeError = TypeError;\n\n// `OrdinaryToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-ordinarytoprimitive\nmodule.exports = function (input, pref) {\n var fn, val;\n if (pref === 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n if (isCallable(fn = input.valueOf) && !isObject(val = call(fn, input))) return val;\n if (pref !== 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n throw new $TypeError(\"Can't convert object to primitive value\");\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar anObject = require('../internals/an-object');\n\nvar concat = uncurryThis([].concat);\n\n// all object keys, includes non-enumerable and symbols\nmodule.exports = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {\n var keys = getOwnPropertyNamesModule.f(anObject(it));\n var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return getOwnPropertySymbols ? concat(keys, getOwnPropertySymbols(it)) : keys;\n};\n","'use strict';\nmodule.exports = function (exec) {\n try {\n return { error: false, value: exec() };\n } catch (error) {\n return { error: true, value: error };\n }\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar isCallable = require('../internals/is-callable');\nvar isForced = require('../internals/is-forced');\nvar inspectSource = require('../internals/inspect-source');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar ENVIRONMENT = require('../internals/environment');\nvar IS_PURE = require('../internals/is-pure');\nvar V8_VERSION = require('../internals/environment-v8-version');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar SPECIES = wellKnownSymbol('species');\nvar SUBCLASSING = false;\nvar NATIVE_PROMISE_REJECTION_EVENT = isCallable(globalThis.PromiseRejectionEvent);\n\nvar FORCED_PROMISE_CONSTRUCTOR = isForced('Promise', function () {\n var PROMISE_CONSTRUCTOR_SOURCE = inspectSource(NativePromiseConstructor);\n var GLOBAL_CORE_JS_PROMISE = PROMISE_CONSTRUCTOR_SOURCE !== String(NativePromiseConstructor);\n // V8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables\n // https://bugs.chromium.org/p/chromium/issues/detail?id=830565\n // We can't detect it synchronously, so just check versions\n if (!GLOBAL_CORE_JS_PROMISE && V8_VERSION === 66) return true;\n // We need Promise#{ catch, finally } in the pure version for preventing prototype pollution\n if (IS_PURE && !(NativePromisePrototype['catch'] && NativePromisePrototype['finally'])) return true;\n // We can't use @@species feature detection in V8 since it causes\n // deoptimization and performance degradation\n // https://github.com/zloirock/core-js/issues/679\n if (!V8_VERSION || V8_VERSION < 51 || !/native code/.test(PROMISE_CONSTRUCTOR_SOURCE)) {\n // Detect correctness of subclassing with @@species support\n var promise = new NativePromiseConstructor(function (resolve) { resolve(1); });\n var FakePromise = function (exec) {\n exec(function () { /* empty */ }, function () { /* empty */ });\n };\n var constructor = promise.constructor = {};\n constructor[SPECIES] = FakePromise;\n SUBCLASSING = promise.then(function () { /* empty */ }) instanceof FakePromise;\n if (!SUBCLASSING) return true;\n // Unhandled rejections tracking support, NodeJS Promise without it fails @@species test\n } return !GLOBAL_CORE_JS_PROMISE && (ENVIRONMENT === 'BROWSER' || ENVIRONMENT === 'DENO') && !NATIVE_PROMISE_REJECTION_EVENT;\n});\n\nmodule.exports = {\n CONSTRUCTOR: FORCED_PROMISE_CONSTRUCTOR,\n REJECTION_EVENT: NATIVE_PROMISE_REJECTION_EVENT,\n SUBCLASSING: SUBCLASSING\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\nmodule.exports = globalThis.Promise;\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar newPromiseCapability = require('../internals/new-promise-capability');\n\nmodule.exports = function (C, x) {\n anObject(C);\n if (isObject(x) && x.constructor === C) return x;\n var promiseCapability = newPromiseCapability.f(C);\n var resolve = promiseCapability.resolve;\n resolve(x);\n return promiseCapability.promise;\n};\n","'use strict';\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar checkCorrectnessOfIteration = require('../internals/check-correctness-of-iteration');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\nmodule.exports = FORCED_PROMISE_CONSTRUCTOR || !checkCorrectnessOfIteration(function (iterable) {\n NativePromiseConstructor.all(iterable).then(undefined, function () { /* empty */ });\n});\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\n\nmodule.exports = function (Target, Source, key) {\n key in Target || defineProperty(Target, key, {\n configurable: true,\n get: function () { return Source[key]; },\n set: function (it) { Source[key] = it; }\n });\n};\n","'use strict';\nvar Queue = function () {\n this.head = null;\n this.tail = null;\n};\n\nQueue.prototype = {\n add: function (item) {\n var entry = { item: item, next: null };\n var tail = this.tail;\n if (tail) tail.next = entry;\n else this.head = entry;\n this.tail = entry;\n },\n get: function () {\n var entry = this.head;\n if (entry) {\n var next = this.head = entry.next;\n if (next === null) this.tail = null;\n return entry.item;\n }\n }\n};\n\nmodule.exports = Queue;\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar regexpExec = require('../internals/regexp-exec');\n\nvar $TypeError = TypeError;\n\n// `RegExpExec` abstract operation\n// https://tc39.es/ecma262/#sec-regexpexec\nmodule.exports = function (R, S) {\n var exec = R.exec;\n if (isCallable(exec)) {\n var result = call(exec, R, S);\n if (result !== null) anObject(result);\n return result;\n }\n if (classof(R) === 'RegExp') return call(regexpExec, R, S);\n throw new $TypeError('RegExp#exec called on incompatible receiver');\n};\n","'use strict';\n/* eslint-disable regexp/no-empty-capturing-group, regexp/no-empty-group, regexp/no-lazy-ends -- testing */\n/* eslint-disable regexp/no-useless-quantifier -- testing */\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toString = require('../internals/to-string');\nvar regexpFlags = require('../internals/regexp-flags');\nvar stickyHelpers = require('../internals/regexp-sticky-helpers');\nvar shared = require('../internals/shared');\nvar create = require('../internals/object-create');\nvar getInternalState = require('../internals/internal-state').get;\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar UNSUPPORTED_NCG = require('../internals/regexp-unsupported-ncg');\n\nvar nativeReplace = shared('native-string-replace', String.prototype.replace);\nvar nativeExec = RegExp.prototype.exec;\nvar patchedExec = nativeExec;\nvar charAt = uncurryThis(''.charAt);\nvar indexOf = uncurryThis(''.indexOf);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n\nvar UPDATES_LAST_INDEX_WRONG = (function () {\n var re1 = /a/;\n var re2 = /b*/g;\n call(nativeExec, re1, 'a');\n call(nativeExec, re2, 'a');\n return re1.lastIndex !== 0 || re2.lastIndex !== 0;\n})();\n\nvar UNSUPPORTED_Y = stickyHelpers.BROKEN_CARET;\n\n// nonparticipating capturing group, copied from es5-shim's String#split patch.\nvar NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;\n\nvar PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED || UNSUPPORTED_Y || UNSUPPORTED_DOT_ALL || UNSUPPORTED_NCG;\n\nif (PATCH) {\n patchedExec = function exec(string) {\n var re = this;\n var state = getInternalState(re);\n var str = toString(string);\n var raw = state.raw;\n var result, reCopy, lastIndex, match, i, object, group;\n\n if (raw) {\n raw.lastIndex = re.lastIndex;\n result = call(patchedExec, raw, str);\n re.lastIndex = raw.lastIndex;\n return result;\n }\n\n var groups = state.groups;\n var sticky = UNSUPPORTED_Y && re.sticky;\n var flags = call(regexpFlags, re);\n var source = re.source;\n var charsAdded = 0;\n var strCopy = str;\n\n if (sticky) {\n flags = replace(flags, 'y', '');\n if (indexOf(flags, 'g') === -1) {\n flags += 'g';\n }\n\n strCopy = stringSlice(str, re.lastIndex);\n // Support anchored sticky behavior.\n if (re.lastIndex > 0 && (!re.multiline || re.multiline && charAt(str, re.lastIndex - 1) !== '\\n')) {\n source = '(?: ' + source + ')';\n strCopy = ' ' + strCopy;\n charsAdded++;\n }\n // ^(? + rx + ) is needed, in combination with some str slicing, to\n // simulate the 'y' flag.\n reCopy = new RegExp('^(?:' + source + ')', flags);\n }\n\n if (NPCG_INCLUDED) {\n reCopy = new RegExp('^' + source + '$(?!\\\\s)', flags);\n }\n if (UPDATES_LAST_INDEX_WRONG) lastIndex = re.lastIndex;\n\n match = call(nativeExec, sticky ? reCopy : re, strCopy);\n\n if (sticky) {\n if (match) {\n match.input = stringSlice(match.input, charsAdded);\n match[0] = stringSlice(match[0], charsAdded);\n match.index = re.lastIndex;\n re.lastIndex += match[0].length;\n } else re.lastIndex = 0;\n } else if (UPDATES_LAST_INDEX_WRONG && match) {\n re.lastIndex = re.global ? match.index + match[0].length : lastIndex;\n }\n if (NPCG_INCLUDED && match && match.length > 1) {\n // Fix browsers whose `exec` methods don't consistently return `undefined`\n // for NPCG, like IE8. NOTE: This doesn't work for /(.?)?/\n call(nativeReplace, match[0], reCopy, function () {\n for (i = 1; i < arguments.length - 2; i++) {\n if (arguments[i] === undefined) match[i] = undefined;\n }\n });\n }\n\n if (match && groups) {\n match.groups = object = create(null);\n for (i = 0; i < groups.length; i++) {\n group = groups[i];\n object[group[0]] = match[group[1]];\n }\n }\n\n return match;\n };\n}\n\nmodule.exports = patchedExec;\n","'use strict';\nvar anObject = require('../internals/an-object');\n\n// `RegExp.prototype.flags` getter implementation\n// https://tc39.es/ecma262/#sec-get-regexp.prototype.flags\nmodule.exports = function () {\n var that = anObject(this);\n var result = '';\n if (that.hasIndices) result += 'd';\n if (that.global) result += 'g';\n if (that.ignoreCase) result += 'i';\n if (that.multiline) result += 'm';\n if (that.dotAll) result += 's';\n if (that.unicode) result += 'u';\n if (that.unicodeSets) result += 'v';\n if (that.sticky) result += 'y';\n return result;\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar hasOwn = require('../internals/has-own-property');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar regExpFlags = require('../internals/regexp-flags');\n\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (R) {\n var flags = R.flags;\n return flags === undefined && !('flags' in RegExpPrototype) && !hasOwn(R, 'flags') && isPrototypeOf(RegExpPrototype, R)\n ? call(regExpFlags, R) : flags;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar globalThis = require('../internals/global-this');\n\n// babel-minify and Closure Compiler transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError\nvar $RegExp = globalThis.RegExp;\n\nvar UNSUPPORTED_Y = fails(function () {\n var re = $RegExp('a', 'y');\n re.lastIndex = 2;\n return re.exec('abcd') !== null;\n});\n\n// UC Browser bug\n// https://github.com/zloirock/core-js/issues/1008\nvar MISSED_STICKY = UNSUPPORTED_Y || fails(function () {\n return !$RegExp('a', 'y').sticky;\n});\n\nvar BROKEN_CARET = UNSUPPORTED_Y || fails(function () {\n // https://bugzilla.mozilla.org/show_bug.cgi?id=773687\n var re = $RegExp('^r', 'gy');\n re.lastIndex = 2;\n return re.exec('str') !== null;\n});\n\nmodule.exports = {\n BROKEN_CARET: BROKEN_CARET,\n MISSED_STICKY: MISSED_STICKY,\n UNSUPPORTED_Y: UNSUPPORTED_Y\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar globalThis = require('../internals/global-this');\n\n// babel-minify and Closure Compiler transpiles RegExp('.', 's') -> /./s and it causes SyntaxError\nvar $RegExp = globalThis.RegExp;\n\nmodule.exports = fails(function () {\n var re = $RegExp('.', 's');\n return !(re.dotAll && re.test('\\n') && re.flags === 's');\n});\n","'use strict';\nvar fails = require('../internals/fails');\nvar globalThis = require('../internals/global-this');\n\n// babel-minify and Closure Compiler transpiles RegExp('(?
    b)', 'g') -> /(?b)/g and it causes SyntaxError\nvar $RegExp = globalThis.RegExp;\n\nmodule.exports = fails(function () {\n var re = $RegExp('(?b)', 'g');\n return re.exec('b').groups.a !== 'b' ||\n 'b'.replace(re, '$c') !== 'bc';\n});\n","'use strict';\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\nvar $TypeError = TypeError;\n\n// `RequireObjectCoercible` abstract operation\n// https://tc39.es/ecma262/#sec-requireobjectcoercible\nmodule.exports = function (it) {\n if (isNullOrUndefined(it)) throw new $TypeError(\"Can't call method on \" + it);\n return it;\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar DESCRIPTORS = require('../internals/descriptors');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Avoid NodeJS experimental warning\nmodule.exports = function (name) {\n if (!DESCRIPTORS) return globalThis[name];\n var descriptor = getOwnPropertyDescriptor(globalThis, name);\n return descriptor && descriptor.value;\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar DESCRIPTORS = require('../internals/descriptors');\n\nvar SPECIES = wellKnownSymbol('species');\n\nmodule.exports = function (CONSTRUCTOR_NAME) {\n var Constructor = getBuiltIn(CONSTRUCTOR_NAME);\n\n if (DESCRIPTORS && Constructor && !Constructor[SPECIES]) {\n defineBuiltInAccessor(Constructor, SPECIES, {\n configurable: true,\n get: function () { return this; }\n });\n }\n};\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\nvar hasOwn = require('../internals/has-own-property');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\n\nmodule.exports = function (target, TAG, STATIC) {\n if (target && !STATIC) target = target.prototype;\n if (target && !hasOwn(target, TO_STRING_TAG)) {\n defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });\n }\n};\n","'use strict';\nvar shared = require('../internals/shared');\nvar uid = require('../internals/uid');\n\nvar keys = shared('keys');\n\nmodule.exports = function (key) {\n return keys[key] || (keys[key] = uid(key));\n};\n","'use strict';\nvar IS_PURE = require('../internals/is-pure');\nvar globalThis = require('../internals/global-this');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nvar SHARED = '__core-js_shared__';\nvar store = module.exports = globalThis[SHARED] || defineGlobalProperty(SHARED, {});\n\n(store.versions || (store.versions = [])).push({\n version: '3.38.1',\n mode: IS_PURE ? 'pure' : 'global',\n copyright: '© 2014-2024 Denis Pushkarev (zloirock.ru)',\n license: 'https://github.com/zloirock/core-js/blob/v3.38.1/LICENSE',\n source: 'https://github.com/zloirock/core-js'\n});\n","'use strict';\nvar store = require('../internals/shared-store');\n\nmodule.exports = function (key, value) {\n return store[key] || (store[key] = value || {});\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar aConstructor = require('../internals/a-constructor');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\n\n// `SpeciesConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-speciesconstructor\nmodule.exports = function (O, defaultConstructor) {\n var C = anObject(O).constructor;\n var S;\n return C === undefined || isNullOrUndefined(S = anObject(C)[SPECIES]) ? defaultConstructor : aConstructor(S);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar stringSlice = uncurryThis(''.slice);\n\nvar createMethod = function (CONVERT_TO_STRING) {\n return function ($this, pos) {\n var S = toString(requireObjectCoercible($this));\n var position = toIntegerOrInfinity(pos);\n var size = S.length;\n var first, second;\n if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;\n first = charCodeAt(S, position);\n return first < 0xD800 || first > 0xDBFF || position + 1 === size\n || (second = charCodeAt(S, position + 1)) < 0xDC00 || second > 0xDFFF\n ? CONVERT_TO_STRING\n ? charAt(S, position)\n : first\n : CONVERT_TO_STRING\n ? stringSlice(S, position, position + 2)\n : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;\n };\n};\n\nmodule.exports = {\n // `String.prototype.codePointAt` method\n // https://tc39.es/ecma262/#sec-string.prototype.codepointat\n codeAt: createMethod(false),\n // `String.prototype.at` method\n // https://github.com/mathiasbynens/String.prototype.at\n charAt: createMethod(true)\n};\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar V8_VERSION = require('../internals/environment-v8-version');\nvar fails = require('../internals/fails');\nvar globalThis = require('../internals/global-this');\n\nvar $String = globalThis.String;\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nmodule.exports = !!Object.getOwnPropertySymbols && !fails(function () {\n var symbol = Symbol('symbol detection');\n // Chrome 38 Symbol has incorrect toString conversion\n // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n // nb: Do not call `String` directly to avoid this being optimized out to `symbol+''` which will,\n // of course, fail.\n return !$String(symbol) || !(Object(symbol) instanceof Symbol) ||\n // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind-context');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar fails = require('../internals/fails');\nvar html = require('../internals/html');\nvar arraySlice = require('../internals/array-slice');\nvar createElement = require('../internals/document-create-element');\nvar validateArgumentsLength = require('../internals/validate-arguments-length');\nvar IS_IOS = require('../internals/environment-is-ios');\nvar IS_NODE = require('../internals/environment-is-node');\n\nvar set = globalThis.setImmediate;\nvar clear = globalThis.clearImmediate;\nvar process = globalThis.process;\nvar Dispatch = globalThis.Dispatch;\nvar Function = globalThis.Function;\nvar MessageChannel = globalThis.MessageChannel;\nvar String = globalThis.String;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar $location, defer, channel, port;\n\nfails(function () {\n // Deno throws a ReferenceError on `location` access without `--location` flag\n $location = globalThis.location;\n});\n\nvar run = function (id) {\n if (hasOwn(queue, id)) {\n var fn = queue[id];\n delete queue[id];\n fn();\n }\n};\n\nvar runner = function (id) {\n return function () {\n run(id);\n };\n};\n\nvar eventListener = function (event) {\n run(event.data);\n};\n\nvar globalPostMessageDefer = function (id) {\n // old engines have not location.origin\n globalThis.postMessage(String(id), $location.protocol + '//' + $location.host);\n};\n\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!set || !clear) {\n set = function setImmediate(handler) {\n validateArgumentsLength(arguments.length, 1);\n var fn = isCallable(handler) ? handler : Function(handler);\n var args = arraySlice(arguments, 1);\n queue[++counter] = function () {\n apply(fn, undefined, args);\n };\n defer(counter);\n return counter;\n };\n clear = function clearImmediate(id) {\n delete queue[id];\n };\n // Node.js 0.8-\n if (IS_NODE) {\n defer = function (id) {\n process.nextTick(runner(id));\n };\n // Sphere (JS game engine) Dispatch API\n } else if (Dispatch && Dispatch.now) {\n defer = function (id) {\n Dispatch.now(runner(id));\n };\n // Browsers with MessageChannel, includes WebWorkers\n // except iOS - https://github.com/zloirock/core-js/issues/624\n } else if (MessageChannel && !IS_IOS) {\n channel = new MessageChannel();\n port = channel.port2;\n channel.port1.onmessage = eventListener;\n defer = bind(port.postMessage, port);\n // Browsers with postMessage, skip WebWorkers\n // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n } else if (\n globalThis.addEventListener &&\n isCallable(globalThis.postMessage) &&\n !globalThis.importScripts &&\n $location && $location.protocol !== 'file:' &&\n !fails(globalPostMessageDefer)\n ) {\n defer = globalPostMessageDefer;\n globalThis.addEventListener('message', eventListener, false);\n // IE8-\n } else if (ONREADYSTATECHANGE in createElement('script')) {\n defer = function (id) {\n html.appendChild(createElement('script'))[ONREADYSTATECHANGE] = function () {\n html.removeChild(this);\n run(id);\n };\n };\n // Rest old browsers\n } else {\n defer = function (id) {\n setTimeout(runner(id), 0);\n };\n }\n}\n\nmodule.exports = {\n set: set,\n clear: clear\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar max = Math.max;\nvar min = Math.min;\n\n// Helper for a popular repeating case of the spec:\n// Let integer be ? ToInteger(index).\n// If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).\nmodule.exports = function (index, length) {\n var integer = toIntegerOrInfinity(index);\n return integer < 0 ? max(integer + length, 0) : min(integer, length);\n};\n","'use strict';\n// toObject with fallback for non-array-like ES3 strings\nvar IndexedObject = require('../internals/indexed-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nmodule.exports = function (it) {\n return IndexedObject(requireObjectCoercible(it));\n};\n","'use strict';\nvar trunc = require('../internals/math-trunc');\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nmodule.exports = function (argument) {\n var number = +argument;\n // eslint-disable-next-line no-self-compare -- NaN check\n return number !== number || number === 0 ? 0 : trunc(number);\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar min = Math.min;\n\n// `ToLength` abstract operation\n// https://tc39.es/ecma262/#sec-tolength\nmodule.exports = function (argument) {\n var len = toIntegerOrInfinity(argument);\n return len > 0 ? min(len, 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991\n};\n","'use strict';\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar $Object = Object;\n\n// `ToObject` abstract operation\n// https://tc39.es/ecma262/#sec-toobject\nmodule.exports = function (argument) {\n return $Object(requireObjectCoercible(argument));\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar getMethod = require('../internals/get-method');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar $TypeError = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nmodule.exports = function (input, pref) {\n if (!isObject(input) || isSymbol(input)) return input;\n var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n var result;\n if (exoticToPrim) {\n if (pref === undefined) pref = 'default';\n result = call(exoticToPrim, input, pref);\n if (!isObject(result) || isSymbol(result)) return result;\n throw new $TypeError(\"Can't convert object to primitive value\");\n }\n if (pref === undefined) pref = 'number';\n return ordinaryToPrimitive(input, pref);\n};\n","'use strict';\nvar toPrimitive = require('../internals/to-primitive');\nvar isSymbol = require('../internals/is-symbol');\n\n// `ToPropertyKey` abstract operation\n// https://tc39.es/ecma262/#sec-topropertykey\nmodule.exports = function (argument) {\n var key = toPrimitive(argument, 'string');\n return isSymbol(key) ? key : key + '';\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar test = {};\n\ntest[TO_STRING_TAG] = 'z';\n\nmodule.exports = String(test) === '[object z]';\n","'use strict';\nvar classof = require('../internals/classof');\n\nvar $String = String;\n\nmodule.exports = function (argument) {\n if (classof(argument) === 'Symbol') throw new TypeError('Cannot convert a Symbol value to a string');\n return $String(argument);\n};\n","'use strict';\nvar $String = String;\n\nmodule.exports = function (argument) {\n try {\n return $String(argument);\n } catch (error) {\n return 'Object';\n }\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis(1.0.toString);\n\nmodule.exports = function (key) {\n return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nmodule.exports = NATIVE_SYMBOL\n && !Symbol.sham\n && typeof Symbol.iterator == 'symbol';\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\n\n// V8 ~ Chrome 36-\n// https://bugs.chromium.org/p/v8/issues/detail?id=3334\nmodule.exports = DESCRIPTORS && fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(function () { /* empty */ }, 'prototype', {\n value: 42,\n writable: false\n }).prototype !== 42;\n});\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (passed, required) {\n if (passed < required) throw new $TypeError('Not enough arguments');\n return passed;\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isCallable = require('../internals/is-callable');\n\nvar WeakMap = globalThis.WeakMap;\n\nmodule.exports = isCallable(WeakMap) && /native code/.test(String(WeakMap));\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar shared = require('../internals/shared');\nvar hasOwn = require('../internals/has-own-property');\nvar uid = require('../internals/uid');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar Symbol = globalThis.Symbol;\nvar WellKnownSymbolsStore = shared('wks');\nvar createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol['for'] || Symbol : Symbol && Symbol.withoutSetter || uid;\n\nmodule.exports = function (name) {\n if (!hasOwn(WellKnownSymbolsStore, name)) {\n WellKnownSymbolsStore[name] = NATIVE_SYMBOL && hasOwn(Symbol, name)\n ? Symbol[name]\n : createWellKnownSymbol('Symbol.' + name);\n } return WellKnownSymbolsStore[name];\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar $includes = require('../internals/array-includes').includes;\nvar fails = require('../internals/fails');\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\n// FF99+ bug\nvar BROKEN_ON_SPARSE = fails(function () {\n // eslint-disable-next-line es/no-array-prototype-includes -- detection\n return !Array(1).includes();\n});\n\n// `Array.prototype.includes` method\n// https://tc39.es/ecma262/#sec-array.prototype.includes\n$({ target: 'Array', proto: true, forced: BROKEN_ON_SPARSE }, {\n includes: function includes(el /* , fromIndex = 0 */) {\n return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables('includes');\n","'use strict';\nvar $ = require('../internals/export');\nvar $reduce = require('../internals/array-reduce').left;\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\nvar CHROME_VERSION = require('../internals/environment-v8-version');\nvar IS_NODE = require('../internals/environment-is-node');\n\n// Chrome 80-82 has a critical bug\n// https://bugs.chromium.org/p/chromium/issues/detail?id=1049982\nvar CHROME_BUG = !IS_NODE && CHROME_VERSION > 79 && CHROME_VERSION < 83;\nvar FORCED = CHROME_BUG || !arrayMethodIsStrict('reduce');\n\n// `Array.prototype.reduce` method\n// https://tc39.es/ecma262/#sec-array.prototype.reduce\n$({ target: 'Array', proto: true, forced: FORCED }, {\n reduce: function reduce(callbackfn /* , initialValue */) {\n var length = arguments.length;\n return $reduce(this, callbackfn, length, length > 1 ? arguments[1] : undefined);\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar deletePropertyOrThrow = require('../internals/delete-property-or-throw');\nvar toString = require('../internals/to-string');\nvar fails = require('../internals/fails');\nvar internalSort = require('../internals/array-sort');\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\nvar FF = require('../internals/environment-ff-version');\nvar IE_OR_EDGE = require('../internals/environment-is-ie-or-edge');\nvar V8 = require('../internals/environment-v8-version');\nvar WEBKIT = require('../internals/environment-webkit-version');\n\nvar test = [];\nvar nativeSort = uncurryThis(test.sort);\nvar push = uncurryThis(test.push);\n\n// IE8-\nvar FAILS_ON_UNDEFINED = fails(function () {\n test.sort(undefined);\n});\n// V8 bug\nvar FAILS_ON_NULL = fails(function () {\n test.sort(null);\n});\n// Old WebKit\nvar STRICT_METHOD = arrayMethodIsStrict('sort');\n\nvar STABLE_SORT = !fails(function () {\n // feature detection can be too slow, so check engines versions\n if (V8) return V8 < 70;\n if (FF && FF > 3) return;\n if (IE_OR_EDGE) return true;\n if (WEBKIT) return WEBKIT < 603;\n\n var result = '';\n var code, chr, value, index;\n\n // generate an array with more 512 elements (Chakra and old V8 fails only in this case)\n for (code = 65; code < 76; code++) {\n chr = String.fromCharCode(code);\n\n switch (code) {\n case 66: case 69: case 70: case 72: value = 3; break;\n case 68: case 71: value = 4; break;\n default: value = 2;\n }\n\n for (index = 0; index < 47; index++) {\n test.push({ k: chr + index, v: value });\n }\n }\n\n test.sort(function (a, b) { return b.v - a.v; });\n\n for (index = 0; index < test.length; index++) {\n chr = test[index].k.charAt(0);\n if (result.charAt(result.length - 1) !== chr) result += chr;\n }\n\n return result !== 'DGBEFHACIJK';\n});\n\nvar FORCED = FAILS_ON_UNDEFINED || !FAILS_ON_NULL || !STRICT_METHOD || !STABLE_SORT;\n\nvar getSortCompare = function (comparefn) {\n return function (x, y) {\n if (y === undefined) return -1;\n if (x === undefined) return 1;\n if (comparefn !== undefined) return +comparefn(x, y) || 0;\n return toString(x) > toString(y) ? 1 : -1;\n };\n};\n\n// `Array.prototype.sort` method\n// https://tc39.es/ecma262/#sec-array.prototype.sort\n$({ target: 'Array', proto: true, forced: FORCED }, {\n sort: function sort(comparefn) {\n if (comparefn !== undefined) aCallable(comparefn);\n\n var array = toObject(this);\n\n if (STABLE_SORT) return comparefn === undefined ? nativeSort(array) : nativeSort(array, comparefn);\n\n var items = [];\n var arrayLength = lengthOfArrayLike(array);\n var itemsLength, index;\n\n for (index = 0; index < arrayLength; index++) {\n if (index in array) push(items, array[index]);\n }\n\n internalSort(items, getSortCompare(comparefn));\n\n itemsLength = lengthOfArrayLike(items);\n index = 0;\n\n while (index < itemsLength) array[index] = items[index++];\n while (index < arrayLength) deletePropertyOrThrow(array, index++);\n\n return array;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isSymbol = require('../internals/is-symbol');\nvar arraySlice = require('../internals/array-slice');\nvar getReplacerFunction = require('../internals/get-json-replacer-function');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nvar $String = String;\nvar $stringify = getBuiltIn('JSON', 'stringify');\nvar exec = uncurryThis(/./.exec);\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar replace = uncurryThis(''.replace);\nvar numberToString = uncurryThis(1.0.toString);\n\nvar tester = /[\\uD800-\\uDFFF]/g;\nvar low = /^[\\uD800-\\uDBFF]$/;\nvar hi = /^[\\uDC00-\\uDFFF]$/;\n\nvar WRONG_SYMBOLS_CONVERSION = !NATIVE_SYMBOL || fails(function () {\n var symbol = getBuiltIn('Symbol')('stringify detection');\n // MS Edge converts symbol values to JSON as {}\n return $stringify([symbol]) !== '[null]'\n // WebKit converts symbol values to JSON as null\n || $stringify({ a: symbol }) !== '{}'\n // V8 throws on boxed symbols\n || $stringify(Object(symbol)) !== '{}';\n});\n\n// https://github.com/tc39/proposal-well-formed-stringify\nvar ILL_FORMED_UNICODE = fails(function () {\n return $stringify('\\uDF06\\uD834') !== '\"\\\\udf06\\\\ud834\"'\n || $stringify('\\uDEAD') !== '\"\\\\udead\"';\n});\n\nvar stringifyWithSymbolsFix = function (it, replacer) {\n var args = arraySlice(arguments);\n var $replacer = getReplacerFunction(replacer);\n if (!isCallable($replacer) && (it === undefined || isSymbol(it))) return; // IE8 returns string on undefined\n args[1] = function (key, value) {\n // some old implementations (like WebKit) could pass numbers as keys\n if (isCallable($replacer)) value = call($replacer, this, $String(key), value);\n if (!isSymbol(value)) return value;\n };\n return apply($stringify, null, args);\n};\n\nvar fixIllFormed = function (match, offset, string) {\n var prev = charAt(string, offset - 1);\n var next = charAt(string, offset + 1);\n if ((exec(low, match) && !exec(hi, next)) || (exec(hi, match) && !exec(low, prev))) {\n return '\\\\u' + numberToString(charCodeAt(match, 0), 16);\n } return match;\n};\n\nif ($stringify) {\n // `JSON.stringify` method\n // https://tc39.es/ecma262/#sec-json.stringify\n $({ target: 'JSON', stat: true, arity: 3, forced: WRONG_SYMBOLS_CONVERSION || ILL_FORMED_UNICODE }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n stringify: function stringify(it, replacer, space) {\n var args = arraySlice(arguments);\n var result = apply(WRONG_SYMBOLS_CONVERSION ? stringifyWithSymbolsFix : $stringify, null, args);\n return ILL_FORMED_UNICODE && typeof result == 'string' ? replace(result, tester, fixIllFormed) : result;\n }\n });\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar iterate = require('../internals/iterate');\nvar createProperty = require('../internals/create-property');\n\n// `Object.fromEntries` method\n// https://github.com/tc39/proposal-object-from-entries\n$({ target: 'Object', stat: true }, {\n fromEntries: function fromEntries(iterable) {\n var obj = {};\n iterate(iterable, function (k, v) {\n createProperty(obj, k, v);\n }, { AS_ENTRIES: true });\n return obj;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.all` method\n// https://tc39.es/ecma262/#sec-promise.all\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n all: function all(iterable) {\n var C = this;\n var capability = newPromiseCapabilityModule.f(C);\n var resolve = capability.resolve;\n var reject = capability.reject;\n var result = perform(function () {\n var $promiseResolve = aCallable(C.resolve);\n var values = [];\n var counter = 0;\n var remaining = 1;\n iterate(iterable, function (promise) {\n var index = counter++;\n var alreadyCalled = false;\n remaining++;\n call($promiseResolve, C, promise).then(function (value) {\n if (alreadyCalled) return;\n alreadyCalled = true;\n values[index] = value;\n --remaining || resolve(values);\n }, reject);\n });\n --remaining || resolve(values);\n });\n if (result.error) reject(result.value);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar defineBuiltIn = require('../internals/define-built-in');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\n\n// `Promise.prototype.catch` method\n// https://tc39.es/ecma262/#sec-promise.prototype.catch\n$({ target: 'Promise', proto: true, forced: FORCED_PROMISE_CONSTRUCTOR, real: true }, {\n 'catch': function (onRejected) {\n return this.then(undefined, onRejected);\n }\n});\n\n// makes sure that native promise-based APIs `Promise#catch` properly works with patched `Promise#then`\nif (!IS_PURE && isCallable(NativePromiseConstructor)) {\n var method = getBuiltIn('Promise').prototype['catch'];\n if (NativePromisePrototype['catch'] !== method) {\n defineBuiltIn(NativePromisePrototype, 'catch', method, { unsafe: true });\n }\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar IS_NODE = require('../internals/environment-is-node');\nvar globalThis = require('../internals/global-this');\nvar call = require('../internals/function-call');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar setSpecies = require('../internals/set-species');\nvar aCallable = require('../internals/a-callable');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar anInstance = require('../internals/an-instance');\nvar speciesConstructor = require('../internals/species-constructor');\nvar task = require('../internals/task').set;\nvar microtask = require('../internals/microtask');\nvar hostReportErrors = require('../internals/host-report-errors');\nvar perform = require('../internals/perform');\nvar Queue = require('../internals/queue');\nvar InternalStateModule = require('../internals/internal-state');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar PromiseConstructorDetection = require('../internals/promise-constructor-detection');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\n\nvar PROMISE = 'Promise';\nvar FORCED_PROMISE_CONSTRUCTOR = PromiseConstructorDetection.CONSTRUCTOR;\nvar NATIVE_PROMISE_REJECTION_EVENT = PromiseConstructorDetection.REJECTION_EVENT;\nvar NATIVE_PROMISE_SUBCLASSING = PromiseConstructorDetection.SUBCLASSING;\nvar getInternalPromiseState = InternalStateModule.getterFor(PROMISE);\nvar setInternalState = InternalStateModule.set;\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar PromiseConstructor = NativePromiseConstructor;\nvar PromisePrototype = NativePromisePrototype;\nvar TypeError = globalThis.TypeError;\nvar document = globalThis.document;\nvar process = globalThis.process;\nvar newPromiseCapability = newPromiseCapabilityModule.f;\nvar newGenericPromiseCapability = newPromiseCapability;\n\nvar DISPATCH_EVENT = !!(document && document.createEvent && globalThis.dispatchEvent);\nvar UNHANDLED_REJECTION = 'unhandledrejection';\nvar REJECTION_HANDLED = 'rejectionhandled';\nvar PENDING = 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\nvar HANDLED = 1;\nvar UNHANDLED = 2;\n\nvar Internal, OwnPromiseCapability, PromiseWrapper, nativeThen;\n\n// helpers\nvar isThenable = function (it) {\n var then;\n return isObject(it) && isCallable(then = it.then) ? then : false;\n};\n\nvar callReaction = function (reaction, state) {\n var value = state.value;\n var ok = state.state === FULFILLED;\n var handler = ok ? reaction.ok : reaction.fail;\n var resolve = reaction.resolve;\n var reject = reaction.reject;\n var domain = reaction.domain;\n var result, then, exited;\n try {\n if (handler) {\n if (!ok) {\n if (state.rejection === UNHANDLED) onHandleUnhandled(state);\n state.rejection = HANDLED;\n }\n if (handler === true) result = value;\n else {\n if (domain) domain.enter();\n result = handler(value); // can throw\n if (domain) {\n domain.exit();\n exited = true;\n }\n }\n if (result === reaction.promise) {\n reject(new TypeError('Promise-chain cycle'));\n } else if (then = isThenable(result)) {\n call(then, result, resolve, reject);\n } else resolve(result);\n } else reject(value);\n } catch (error) {\n if (domain && !exited) domain.exit();\n reject(error);\n }\n};\n\nvar notify = function (state, isReject) {\n if (state.notified) return;\n state.notified = true;\n microtask(function () {\n var reactions = state.reactions;\n var reaction;\n while (reaction = reactions.get()) {\n callReaction(reaction, state);\n }\n state.notified = false;\n if (isReject && !state.rejection) onUnhandled(state);\n });\n};\n\nvar dispatchEvent = function (name, promise, reason) {\n var event, handler;\n if (DISPATCH_EVENT) {\n event = document.createEvent('Event');\n event.promise = promise;\n event.reason = reason;\n event.initEvent(name, false, true);\n globalThis.dispatchEvent(event);\n } else event = { promise: promise, reason: reason };\n if (!NATIVE_PROMISE_REJECTION_EVENT && (handler = globalThis['on' + name])) handler(event);\n else if (name === UNHANDLED_REJECTION) hostReportErrors('Unhandled promise rejection', reason);\n};\n\nvar onUnhandled = function (state) {\n call(task, globalThis, function () {\n var promise = state.facade;\n var value = state.value;\n var IS_UNHANDLED = isUnhandled(state);\n var result;\n if (IS_UNHANDLED) {\n result = perform(function () {\n if (IS_NODE) {\n process.emit('unhandledRejection', value, promise);\n } else dispatchEvent(UNHANDLED_REJECTION, promise, value);\n });\n // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should\n state.rejection = IS_NODE || isUnhandled(state) ? UNHANDLED : HANDLED;\n if (result.error) throw result.value;\n }\n });\n};\n\nvar isUnhandled = function (state) {\n return state.rejection !== HANDLED && !state.parent;\n};\n\nvar onHandleUnhandled = function (state) {\n call(task, globalThis, function () {\n var promise = state.facade;\n if (IS_NODE) {\n process.emit('rejectionHandled', promise);\n } else dispatchEvent(REJECTION_HANDLED, promise, state.value);\n });\n};\n\nvar bind = function (fn, state, unwrap) {\n return function (value) {\n fn(state, value, unwrap);\n };\n};\n\nvar internalReject = function (state, value, unwrap) {\n if (state.done) return;\n state.done = true;\n if (unwrap) state = unwrap;\n state.value = value;\n state.state = REJECTED;\n notify(state, true);\n};\n\nvar internalResolve = function (state, value, unwrap) {\n if (state.done) return;\n state.done = true;\n if (unwrap) state = unwrap;\n try {\n if (state.facade === value) throw new TypeError(\"Promise can't be resolved itself\");\n var then = isThenable(value);\n if (then) {\n microtask(function () {\n var wrapper = { done: false };\n try {\n call(then, value,\n bind(internalResolve, wrapper, state),\n bind(internalReject, wrapper, state)\n );\n } catch (error) {\n internalReject(wrapper, error, state);\n }\n });\n } else {\n state.value = value;\n state.state = FULFILLED;\n notify(state, false);\n }\n } catch (error) {\n internalReject({ done: false }, error, state);\n }\n};\n\n// constructor polyfill\nif (FORCED_PROMISE_CONSTRUCTOR) {\n // 25.4.3.1 Promise(executor)\n PromiseConstructor = function Promise(executor) {\n anInstance(this, PromisePrototype);\n aCallable(executor);\n call(Internal, this);\n var state = getInternalPromiseState(this);\n try {\n executor(bind(internalResolve, state), bind(internalReject, state));\n } catch (error) {\n internalReject(state, error);\n }\n };\n\n PromisePrototype = PromiseConstructor.prototype;\n\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n Internal = function Promise(executor) {\n setInternalState(this, {\n type: PROMISE,\n done: false,\n notified: false,\n parent: false,\n reactions: new Queue(),\n rejection: false,\n state: PENDING,\n value: null\n });\n };\n\n // `Promise.prototype.then` method\n // https://tc39.es/ecma262/#sec-promise.prototype.then\n Internal.prototype = defineBuiltIn(PromisePrototype, 'then', function then(onFulfilled, onRejected) {\n var state = getInternalPromiseState(this);\n var reaction = newPromiseCapability(speciesConstructor(this, PromiseConstructor));\n state.parent = true;\n reaction.ok = isCallable(onFulfilled) ? onFulfilled : true;\n reaction.fail = isCallable(onRejected) && onRejected;\n reaction.domain = IS_NODE ? process.domain : undefined;\n if (state.state === PENDING) state.reactions.add(reaction);\n else microtask(function () {\n callReaction(reaction, state);\n });\n return reaction.promise;\n });\n\n OwnPromiseCapability = function () {\n var promise = new Internal();\n var state = getInternalPromiseState(promise);\n this.promise = promise;\n this.resolve = bind(internalResolve, state);\n this.reject = bind(internalReject, state);\n };\n\n newPromiseCapabilityModule.f = newPromiseCapability = function (C) {\n return C === PromiseConstructor || C === PromiseWrapper\n ? new OwnPromiseCapability(C)\n : newGenericPromiseCapability(C);\n };\n\n if (!IS_PURE && isCallable(NativePromiseConstructor) && NativePromisePrototype !== Object.prototype) {\n nativeThen = NativePromisePrototype.then;\n\n if (!NATIVE_PROMISE_SUBCLASSING) {\n // make `Promise#then` return a polyfilled `Promise` for native promise-based APIs\n defineBuiltIn(NativePromisePrototype, 'then', function then(onFulfilled, onRejected) {\n var that = this;\n return new PromiseConstructor(function (resolve, reject) {\n call(nativeThen, that, resolve, reject);\n }).then(onFulfilled, onRejected);\n // https://github.com/zloirock/core-js/issues/640\n }, { unsafe: true });\n }\n\n // make `.constructor === Promise` work for native promise-based APIs\n try {\n delete NativePromisePrototype.constructor;\n } catch (error) { /* empty */ }\n\n // make `instanceof Promise` work for native promise-based APIs\n if (setPrototypeOf) {\n setPrototypeOf(NativePromisePrototype, PromisePrototype);\n }\n }\n}\n\n$({ global: true, constructor: true, wrap: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n Promise: PromiseConstructor\n});\n\nsetToStringTag(PromiseConstructor, PROMISE, false, true);\nsetSpecies(PROMISE);\n","'use strict';\n// TODO: Remove this module from `core-js@4` since it's split to modules listed below\nrequire('../modules/es.promise.constructor');\nrequire('../modules/es.promise.all');\nrequire('../modules/es.promise.catch');\nrequire('../modules/es.promise.race');\nrequire('../modules/es.promise.reject');\nrequire('../modules/es.promise.resolve');\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.race` method\n// https://tc39.es/ecma262/#sec-promise.race\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n race: function race(iterable) {\n var C = this;\n var capability = newPromiseCapabilityModule.f(C);\n var reject = capability.reject;\n var result = perform(function () {\n var $promiseResolve = aCallable(C.resolve);\n iterate(iterable, function (promise) {\n call($promiseResolve, C, promise).then(capability.resolve, reject);\n });\n });\n if (result.error) reject(result.value);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\n// `Promise.reject` method\n// https://tc39.es/ecma262/#sec-promise.reject\n$({ target: 'Promise', stat: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n reject: function reject(r) {\n var capability = newPromiseCapabilityModule.f(this);\n var capabilityReject = capability.reject;\n capabilityReject(r);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar IS_PURE = require('../internals/is-pure');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar promiseResolve = require('../internals/promise-resolve');\n\nvar PromiseConstructorWrapper = getBuiltIn('Promise');\nvar CHECK_WRAPPER = IS_PURE && !FORCED_PROMISE_CONSTRUCTOR;\n\n// `Promise.resolve` method\n// https://tc39.es/ecma262/#sec-promise.resolve\n$({ target: 'Promise', stat: true, forced: IS_PURE || FORCED_PROMISE_CONSTRUCTOR }, {\n resolve: function resolve(x) {\n return promiseResolve(CHECK_WRAPPER && this === PromiseConstructorWrapper ? NativePromiseConstructor : this, x);\n }\n});\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar globalThis = require('../internals/global-this');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isForced = require('../internals/is-forced');\nvar inheritIfRequired = require('../internals/inherit-if-required');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar create = require('../internals/object-create');\nvar getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar isRegExp = require('../internals/is-regexp');\nvar toString = require('../internals/to-string');\nvar getRegExpFlags = require('../internals/regexp-get-flags');\nvar stickyHelpers = require('../internals/regexp-sticky-helpers');\nvar proxyAccessor = require('../internals/proxy-accessor');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar fails = require('../internals/fails');\nvar hasOwn = require('../internals/has-own-property');\nvar enforceInternalState = require('../internals/internal-state').enforce;\nvar setSpecies = require('../internals/set-species');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar UNSUPPORTED_NCG = require('../internals/regexp-unsupported-ncg');\n\nvar MATCH = wellKnownSymbol('match');\nvar NativeRegExp = globalThis.RegExp;\nvar RegExpPrototype = NativeRegExp.prototype;\nvar SyntaxError = globalThis.SyntaxError;\nvar exec = uncurryThis(RegExpPrototype.exec);\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringIndexOf = uncurryThis(''.indexOf);\nvar stringSlice = uncurryThis(''.slice);\n// TODO: Use only proper RegExpIdentifierName\nvar IS_NCG = /^\\?<[^\\s\\d!#%&*+<=>@^][^\\s!#%&*+<=>@^]*>/;\nvar re1 = /a/g;\nvar re2 = /a/g;\n\n// \"new\" should create a new object, old webkit bug\nvar CORRECT_NEW = new NativeRegExp(re1) !== re1;\n\nvar MISSED_STICKY = stickyHelpers.MISSED_STICKY;\nvar UNSUPPORTED_Y = stickyHelpers.UNSUPPORTED_Y;\n\nvar BASE_FORCED = DESCRIPTORS &&\n (!CORRECT_NEW || MISSED_STICKY || UNSUPPORTED_DOT_ALL || UNSUPPORTED_NCG || fails(function () {\n re2[MATCH] = false;\n // RegExp constructor can alter flags and IsRegExp works correct with @@match\n // eslint-disable-next-line sonar/inconsistent-function-call -- required for testing\n return NativeRegExp(re1) !== re1 || NativeRegExp(re2) === re2 || String(NativeRegExp(re1, 'i')) !== '/a/i';\n }));\n\nvar handleDotAll = function (string) {\n var length = string.length;\n var index = 0;\n var result = '';\n var brackets = false;\n var chr;\n for (; index <= length; index++) {\n chr = charAt(string, index);\n if (chr === '\\\\') {\n result += chr + charAt(string, ++index);\n continue;\n }\n if (!brackets && chr === '.') {\n result += '[\\\\s\\\\S]';\n } else {\n if (chr === '[') {\n brackets = true;\n } else if (chr === ']') {\n brackets = false;\n } result += chr;\n }\n } return result;\n};\n\nvar handleNCG = function (string) {\n var length = string.length;\n var index = 0;\n var result = '';\n var named = [];\n var names = create(null);\n var brackets = false;\n var ncg = false;\n var groupid = 0;\n var groupname = '';\n var chr;\n for (; index <= length; index++) {\n chr = charAt(string, index);\n if (chr === '\\\\') {\n chr += charAt(string, ++index);\n } else if (chr === ']') {\n brackets = false;\n } else if (!brackets) switch (true) {\n case chr === '[':\n brackets = true;\n break;\n case chr === '(':\n result += chr;\n // ignore non-capturing groups\n if (stringSlice(string, index + 1, index + 3) === '?:') {\n continue;\n }\n if (exec(IS_NCG, stringSlice(string, index + 1))) {\n index += 2;\n ncg = true;\n }\n groupid++;\n continue;\n case chr === '>' && ncg:\n if (groupname === '' || hasOwn(names, groupname)) {\n throw new SyntaxError('Invalid capture group name');\n }\n names[groupname] = true;\n named[named.length] = [groupname, groupid];\n ncg = false;\n groupname = '';\n continue;\n }\n if (ncg) groupname += chr;\n else result += chr;\n } return [result, named];\n};\n\n// `RegExp` constructor\n// https://tc39.es/ecma262/#sec-regexp-constructor\nif (isForced('RegExp', BASE_FORCED)) {\n var RegExpWrapper = function RegExp(pattern, flags) {\n var thisIsRegExp = isPrototypeOf(RegExpPrototype, this);\n var patternIsRegExp = isRegExp(pattern);\n var flagsAreUndefined = flags === undefined;\n var groups = [];\n var rawPattern = pattern;\n var rawFlags, dotAll, sticky, handled, result, state;\n\n if (!thisIsRegExp && patternIsRegExp && flagsAreUndefined && pattern.constructor === RegExpWrapper) {\n return pattern;\n }\n\n if (patternIsRegExp || isPrototypeOf(RegExpPrototype, pattern)) {\n pattern = pattern.source;\n if (flagsAreUndefined) flags = getRegExpFlags(rawPattern);\n }\n\n pattern = pattern === undefined ? '' : toString(pattern);\n flags = flags === undefined ? '' : toString(flags);\n rawPattern = pattern;\n\n if (UNSUPPORTED_DOT_ALL && 'dotAll' in re1) {\n dotAll = !!flags && stringIndexOf(flags, 's') > -1;\n if (dotAll) flags = replace(flags, /s/g, '');\n }\n\n rawFlags = flags;\n\n if (MISSED_STICKY && 'sticky' in re1) {\n sticky = !!flags && stringIndexOf(flags, 'y') > -1;\n if (sticky && UNSUPPORTED_Y) flags = replace(flags, /y/g, '');\n }\n\n if (UNSUPPORTED_NCG) {\n handled = handleNCG(pattern);\n pattern = handled[0];\n groups = handled[1];\n }\n\n result = inheritIfRequired(NativeRegExp(pattern, flags), thisIsRegExp ? this : RegExpPrototype, RegExpWrapper);\n\n if (dotAll || sticky || groups.length) {\n state = enforceInternalState(result);\n if (dotAll) {\n state.dotAll = true;\n state.raw = RegExpWrapper(handleDotAll(pattern), rawFlags);\n }\n if (sticky) state.sticky = true;\n if (groups.length) state.groups = groups;\n }\n\n if (pattern !== rawPattern) try {\n // fails in old engines, but we have no alternatives for unsupported regex syntax\n createNonEnumerableProperty(result, 'source', rawPattern === '' ? '(?:)' : rawPattern);\n } catch (error) { /* empty */ }\n\n return result;\n };\n\n for (var keys = getOwnPropertyNames(NativeRegExp), index = 0; keys.length > index;) {\n proxyAccessor(RegExpWrapper, NativeRegExp, keys[index++]);\n }\n\n RegExpPrototype.constructor = RegExpWrapper;\n RegExpWrapper.prototype = RegExpPrototype;\n defineBuiltIn(globalThis, 'RegExp', RegExpWrapper, { constructor: true });\n}\n\n// https://tc39.es/ecma262/#sec-get-regexp-@@species\nsetSpecies('RegExp');\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar classof = require('../internals/classof-raw');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar getInternalState = require('../internals/internal-state').get;\n\nvar RegExpPrototype = RegExp.prototype;\nvar $TypeError = TypeError;\n\n// `RegExp.prototype.dotAll` getter\n// https://tc39.es/ecma262/#sec-get-regexp.prototype.dotall\nif (DESCRIPTORS && UNSUPPORTED_DOT_ALL) {\n defineBuiltInAccessor(RegExpPrototype, 'dotAll', {\n configurable: true,\n get: function dotAll() {\n if (this === RegExpPrototype) return;\n // We can't use InternalStateModule.getterFor because\n // we don't add metadata for regexps created by a literal.\n if (classof(this) === 'RegExp') {\n return !!getInternalState(this).dotAll;\n }\n throw new $TypeError('Incompatible receiver, RegExp required');\n }\n });\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar exec = require('../internals/regexp-exec');\n\n// `RegExp.prototype.exec` method\n// https://tc39.es/ecma262/#sec-regexp.prototype.exec\n$({ target: 'RegExp', proto: true, forced: /./.exec !== exec }, {\n exec: exec\n});\n","'use strict';\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fixRegExpWellKnownSymbolLogic = require('../internals/fix-regexp-well-known-symbol-logic');\nvar fails = require('../internals/fails');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toLength = require('../internals/to-length');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar advanceStringIndex = require('../internals/advance-string-index');\nvar getMethod = require('../internals/get-method');\nvar getSubstitution = require('../internals/get-substitution');\nvar regExpExec = require('../internals/regexp-exec-abstract');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar REPLACE = wellKnownSymbol('replace');\nvar max = Math.max;\nvar min = Math.min;\nvar concat = uncurryThis([].concat);\nvar push = uncurryThis([].push);\nvar stringIndexOf = uncurryThis(''.indexOf);\nvar stringSlice = uncurryThis(''.slice);\n\nvar maybeToString = function (it) {\n return it === undefined ? it : String(it);\n};\n\n// IE <= 11 replaces $0 with the whole match, as if it was $&\n// https://stackoverflow.com/questions/6024666/getting-ie-to-replace-a-regex-with-the-literal-string-0\nvar REPLACE_KEEPS_$0 = (function () {\n // eslint-disable-next-line regexp/prefer-escape-replacement-dollar-char -- required for testing\n return 'a'.replace(/./, '$0') === '$0';\n})();\n\n// Safari <= 13.0.3(?) substitutes nth capture where n>m with an empty string\nvar REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE = (function () {\n if (/./[REPLACE]) {\n return /./[REPLACE]('a', '$0') === '';\n }\n return false;\n})();\n\nvar REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {\n var re = /./;\n re.exec = function () {\n var result = [];\n result.groups = { a: '7' };\n return result;\n };\n // eslint-disable-next-line regexp/no-useless-dollar-replacements -- false positive\n return ''.replace(re, '$') !== '7';\n});\n\n// @@replace logic\nfixRegExpWellKnownSymbolLogic('replace', function (_, nativeReplace, maybeCallNative) {\n var UNSAFE_SUBSTITUTE = REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE ? '$' : '$0';\n\n return [\n // `String.prototype.replace` method\n // https://tc39.es/ecma262/#sec-string.prototype.replace\n function replace(searchValue, replaceValue) {\n var O = requireObjectCoercible(this);\n var replacer = isNullOrUndefined(searchValue) ? undefined : getMethod(searchValue, REPLACE);\n return replacer\n ? call(replacer, searchValue, O, replaceValue)\n : call(nativeReplace, toString(O), searchValue, replaceValue);\n },\n // `RegExp.prototype[@@replace]` method\n // https://tc39.es/ecma262/#sec-regexp.prototype-@@replace\n function (string, replaceValue) {\n var rx = anObject(this);\n var S = toString(string);\n\n if (\n typeof replaceValue == 'string' &&\n stringIndexOf(replaceValue, UNSAFE_SUBSTITUTE) === -1 &&\n stringIndexOf(replaceValue, '$<') === -1\n ) {\n var res = maybeCallNative(nativeReplace, rx, S, replaceValue);\n if (res.done) return res.value;\n }\n\n var functionalReplace = isCallable(replaceValue);\n if (!functionalReplace) replaceValue = toString(replaceValue);\n\n var global = rx.global;\n var fullUnicode;\n if (global) {\n fullUnicode = rx.unicode;\n rx.lastIndex = 0;\n }\n\n var results = [];\n var result;\n while (true) {\n result = regExpExec(rx, S);\n if (result === null) break;\n\n push(results, result);\n if (!global) break;\n\n var matchStr = toString(result[0]);\n if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n }\n\n var accumulatedResult = '';\n var nextSourcePosition = 0;\n for (var i = 0; i < results.length; i++) {\n result = results[i];\n\n var matched = toString(result[0]);\n var position = max(min(toIntegerOrInfinity(result.index), S.length), 0);\n var captures = [];\n var replacement;\n // NOTE: This is equivalent to\n // captures = result.slice(1).map(maybeToString)\n // but for some reason `nativeSlice.call(result, 1, result.length)` (called in\n // the slice polyfill when slicing native arrays) \"doesn't work\" in safari 9 and\n // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.\n for (var j = 1; j < result.length; j++) push(captures, maybeToString(result[j]));\n var namedCaptures = result.groups;\n if (functionalReplace) {\n var replacerArgs = concat([matched], captures, position, S);\n if (namedCaptures !== undefined) push(replacerArgs, namedCaptures);\n replacement = toString(apply(replaceValue, undefined, replacerArgs));\n } else {\n replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);\n }\n if (position >= nextSourcePosition) {\n accumulatedResult += stringSlice(S, nextSourcePosition, position) + replacement;\n nextSourcePosition = position + matched.length;\n }\n }\n\n return accumulatedResult + stringSlice(S, nextSourcePosition);\n }\n ];\n}, !REPLACE_SUPPORTS_NAMED_GROUPS || !REPLACE_KEEPS_$0 || REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE);\n","// `Symbol.prototype.description` getter\n// https://tc39.es/ecma262/#sec-symbol.prototype.description\n'use strict';\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar globalThis = require('../internals/global-this');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar toString = require('../internals/to-string');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\n\nvar NativeSymbol = globalThis.Symbol;\nvar SymbolPrototype = NativeSymbol && NativeSymbol.prototype;\n\nif (DESCRIPTORS && isCallable(NativeSymbol) && (!('description' in SymbolPrototype) ||\n // Safari 12 bug\n NativeSymbol().description !== undefined\n)) {\n var EmptyStringDescriptionStore = {};\n // wrap Symbol constructor for correct work with undefined description\n var SymbolWrapper = function Symbol() {\n var description = arguments.length < 1 || arguments[0] === undefined ? undefined : toString(arguments[0]);\n var result = isPrototypeOf(SymbolPrototype, this)\n // eslint-disable-next-line sonar/inconsistent-function-call -- ok\n ? new NativeSymbol(description)\n // in Edge 13, String(Symbol(undefined)) === 'Symbol(undefined)'\n : description === undefined ? NativeSymbol() : NativeSymbol(description);\n if (description === '') EmptyStringDescriptionStore[result] = true;\n return result;\n };\n\n copyConstructorProperties(SymbolWrapper, NativeSymbol);\n SymbolWrapper.prototype = SymbolPrototype;\n SymbolPrototype.constructor = SymbolWrapper;\n\n var NATIVE_SYMBOL = String(NativeSymbol('description detection')) === 'Symbol(description detection)';\n var thisSymbolValue = uncurryThis(SymbolPrototype.valueOf);\n var symbolDescriptiveString = uncurryThis(SymbolPrototype.toString);\n var regexp = /^Symbol\\((.*)\\)[^)]+$/;\n var replace = uncurryThis(''.replace);\n var stringSlice = uncurryThis(''.slice);\n\n defineBuiltInAccessor(SymbolPrototype, 'description', {\n configurable: true,\n get: function description() {\n var symbol = thisSymbolValue(this);\n if (hasOwn(EmptyStringDescriptionStore, symbol)) return '';\n var string = symbolDescriptiveString(symbol);\n var desc = NATIVE_SYMBOL ? stringSlice(string, 7, -1) : replace(string, regexp, '$1');\n return desc === '' ? undefined : desc;\n }\n });\n\n $({ global: true, constructor: true, forced: true }, {\n Symbol: SymbolWrapper\n });\n}\n","(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global[\"'typed'\"] = factory());\n})(this, (function () { 'use strict';\n\n function ok() {\n return true;\n }\n function notOk() {\n return false;\n }\n function undef() {\n return undefined;\n }\n const NOT_TYPED_FUNCTION = 'Argument is not a typed-function.';\n\n /**\n * @typedef {{\n * params: Param[],\n * fn: function,\n * test: function,\n * implementation: function\n * }} Signature\n *\n * @typedef {{\n * types: Type[],\n * hasAny: boolean,\n * hasConversion: boolean,\n * restParam: boolean\n * }} Param\n *\n * @typedef {{\n * name: string,\n * typeIndex: number,\n * test: function,\n * isAny: boolean,\n * conversion?: ConversionDef,\n * conversionIndex: number,\n * }} Type\n *\n * @typedef {{\n * from: string,\n * to: string,\n * convert: function (*) : *\n * }} ConversionDef\n *\n * @typedef {{\n * name: string,\n * test: function(*) : boolean,\n * isAny?: boolean\n * }} TypeDef\n */\n\n /**\n * @returns {() => function}\n */\n function create() {\n // data type tests\n\n /**\n * Returns true if the argument is a non-null \"plain\" object\n */\n function isPlainObject(x) {\n return typeof x === 'object' && x !== null && x.constructor === Object;\n }\n const _types = [{\n name: 'number',\n test: function (x) {\n return typeof x === 'number';\n }\n }, {\n name: 'string',\n test: function (x) {\n return typeof x === 'string';\n }\n }, {\n name: 'boolean',\n test: function (x) {\n return typeof x === 'boolean';\n }\n }, {\n name: 'Function',\n test: function (x) {\n return typeof x === 'function';\n }\n }, {\n name: 'Array',\n test: Array.isArray\n }, {\n name: 'Date',\n test: function (x) {\n return x instanceof Date;\n }\n }, {\n name: 'RegExp',\n test: function (x) {\n return x instanceof RegExp;\n }\n }, {\n name: 'Object',\n test: isPlainObject\n }, {\n name: 'null',\n test: function (x) {\n return x === null;\n }\n }, {\n name: 'undefined',\n test: function (x) {\n return x === undefined;\n }\n }];\n const anyType = {\n name: 'any',\n test: ok,\n isAny: true\n };\n\n // Data structures to track the types. As these are local variables in\n // create(), each typed universe will get its own copy, but the variables\n // will only be accessible through the (closures of the) functions supplied\n // as properties of the typed object, not directly.\n // These will be initialized in clear() below\n let typeMap; // primary store of all types\n let typeList; // Array of just type names, for the sake of ordering\n\n // And similar data structures for the type conversions:\n let nConversions = 0;\n // the actual conversions are stored on a property of the destination types\n\n // This is a temporary object, will be replaced with a function at the end\n let typed = {\n createCount: 0\n };\n\n /**\n * Takes a type name and returns the corresponding official type object\n * for that type.\n *\n * @param {string} typeName\n * @returns {TypeDef} type\n */\n function findType(typeName) {\n const type = typeMap.get(typeName);\n if (type) {\n return type;\n }\n // Remainder is error handling\n let message = 'Unknown type \"' + typeName + '\"';\n const name = typeName.toLowerCase();\n let otherName;\n for (otherName of typeList) {\n if (otherName.toLowerCase() === name) {\n message += '. Did you mean \"' + otherName + '\" ?';\n break;\n }\n }\n throw new TypeError(message);\n }\n\n /**\n * Adds an array `types` of type definitions to this typed instance.\n * Each type definition should be an object with properties:\n * 'name' - a string giving the name of the type; 'test' - function\n * returning a boolean that tests membership in the type; and optionally\n * 'isAny' - true only for the 'any' type.\n *\n * The second optional argument, `before`, gives the name of a type that\n * these types should be added before. The new types are added in the\n * order specified.\n * @param {TypeDef[]} types\n * @param {string | boolean} [beforeSpec='any'] before\n */\n function addTypes(types) {\n let beforeSpec = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any';\n const beforeIndex = beforeSpec ? findType(beforeSpec).index : typeList.length;\n const newTypes = [];\n for (let i = 0; i < types.length; ++i) {\n if (!types[i] || typeof types[i].name !== 'string' || typeof types[i].test !== 'function') {\n throw new TypeError('Object with properties {name: string, test: function} expected');\n }\n const typeName = types[i].name;\n if (typeMap.has(typeName)) {\n throw new TypeError('Duplicate type name \"' + typeName + '\"');\n }\n newTypes.push(typeName);\n typeMap.set(typeName, {\n name: typeName,\n test: types[i].test,\n isAny: types[i].isAny,\n index: beforeIndex + i,\n conversionsTo: [] // Newly added type can't have any conversions to it\n });\n }\n // update the typeList\n const affectedTypes = typeList.slice(beforeIndex);\n typeList = typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes);\n // Fix the indices\n for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) {\n typeMap.get(typeList[i]).index = i;\n }\n }\n\n /**\n * Removes all types and conversions from this typed instance.\n * May cause previously constructed typed-functions to throw\n * strange errors when they are called with types that do not\n * match any of their signatures.\n */\n function clear() {\n typeMap = new Map();\n typeList = [];\n nConversions = 0;\n addTypes([anyType], false);\n }\n\n // initialize the types to the default list\n clear();\n addTypes(_types);\n\n /**\n * Removes all conversions, leaving the types alone.\n */\n function clearConversions() {\n let typeName;\n for (typeName of typeList) {\n typeMap.get(typeName).conversionsTo = [];\n }\n nConversions = 0;\n }\n\n /**\n * Find the type names that match a value.\n * @param {*} value\n * @return {string[]} Array of names of types for which\n * the type test matches the value.\n */\n function findTypeNames(value) {\n const matches = typeList.filter(name => {\n const type = typeMap.get(name);\n return !type.isAny && type.test(value);\n });\n if (matches.length) {\n return matches;\n }\n return ['any'];\n }\n\n /**\n * Check if an entity is a typed function created by any instance\n * @param {any} entity\n * @returns {boolean}\n */\n function isTypedFunction(entity) {\n return entity && typeof entity === 'function' && '_typedFunctionData' in entity;\n }\n\n /**\n * Find a specific signature from a (composed) typed function, for example:\n *\n * typed.findSignature(fn, ['number', 'string'])\n * typed.findSignature(fn, 'number, string')\n * typed.findSignature(fn, 'number,string', {exact: true})\n *\n * This function findSignature will by default return the best match to\n * the given signature, possibly employing type conversions.\n *\n * The (optional) third argument is a plain object giving options\n * controlling the signature search. Currently the only implemented\n * option is `exact`: if specified as true (default is false), only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Note that a (possibly different) type matching\n * `any`, or one or more instances of TYPE matching `...TYPE` are\n * considered exact matches in this regard, as no conversions are used.\n *\n * This function returns a \"signature\" object, as does `typed.resolve()`,\n * which is a plain object with four keys: `params` (the array of parameters\n * for this signature), `fn` (the originally supplied function for this\n * signature), `test` (a generated function that determines if an argument\n * list matches this signature, and `implementation` (the function to call\n * on a matching argument list, that performs conversions if necessary and\n * then calls the originally supplied function).\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature search as documented\n * @return {{ params: Param[], fn: function, test: function, implementation: function }}\n * Returns the matching signature, or throws an error when no signature\n * is found.\n */\n function findSignature(fn, signature, options) {\n if (!isTypedFunction(fn)) {\n throw new TypeError(NOT_TYPED_FUNCTION);\n }\n\n // Canonicalize input\n const exact = options && options.exact;\n const stringSignature = Array.isArray(signature) ? signature.join(',') : signature;\n const params = parseSignature(stringSignature);\n const canonicalSignature = stringifyParams(params);\n\n // First hope we get lucky and exactly match a signature\n if (!exact || canonicalSignature in fn.signatures) {\n // OK, we can check the internal signatures\n const match = fn._typedFunctionData.signatureMap.get(canonicalSignature);\n if (match) {\n return match;\n }\n }\n\n // Oh well, we did not; so we have to go back and check the parameters\n // one by one, in order to catch things like `any` and rest params.\n // Note here we can assume there is at least one parameter, because\n // the empty signature would have matched successfully above.\n const nParams = params.length;\n let remainingSignatures;\n if (exact) {\n remainingSignatures = [];\n let name;\n for (name in fn.signatures) {\n remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name));\n }\n } else {\n remainingSignatures = fn._typedFunctionData.signatures;\n }\n for (let i = 0; i < nParams; ++i) {\n const want = params[i];\n const filteredSignatures = [];\n let possibility;\n for (possibility of remainingSignatures) {\n const have = getParamAtIndex(possibility.params, i);\n if (!have || want.restParam && !have.restParam) {\n continue;\n }\n if (!have.hasAny) {\n // have to check all of the wanted types are available\n const haveTypes = paramTypeSet(have);\n if (want.types.some(wtype => !haveTypes.has(wtype.name))) {\n continue;\n }\n }\n // OK, this looks good\n filteredSignatures.push(possibility);\n }\n remainingSignatures = filteredSignatures;\n if (remainingSignatures.length === 0) break;\n }\n // Return the first remaining signature that was totally matched:\n let candidate;\n for (candidate of remainingSignatures) {\n if (candidate.params.length <= nParams) {\n return candidate;\n }\n }\n throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))');\n }\n\n /**\n * Find the proper function to call for a specific signature from\n * a (composed) typed function, for example:\n *\n * typed.find(fn, ['number', 'string'])\n * typed.find(fn, 'number, string')\n * typed.find(fn, 'number,string', {exact: true})\n *\n * This function find will by default return the best match to\n * the given signature, possibly employing type conversions (and returning\n * a function that will perform those conversions as needed). The\n * (optional) third argument is a plain object giving options contolling\n * the signature search. Currently only the option `exact` is implemented,\n * which defaults to \"false\". If `exact` is specified as true, then only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Uses of `any` and `...TYPE` are considered exact if\n * no conversions are necessary to apply the corresponding function.\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature match as documented\n * @return {function}\n * Returns the function to call for the given signature, or throws an\n * error if no match is found.\n */\n function find(fn, signature, options) {\n return findSignature(fn, signature, options).implementation;\n }\n\n /**\n * Convert a given value to another data type, specified by type name.\n *\n * @param {*} value\n * @param {string} typeName\n */\n function convert(value, typeName) {\n // check conversion is needed\n const type = findType(typeName);\n if (type.test(value)) {\n return value;\n }\n const conversions = type.conversionsTo;\n if (conversions.length === 0) {\n throw new Error('There are no conversions to ' + typeName + ' defined.');\n }\n for (let i = 0; i < conversions.length; i++) {\n const fromType = findType(conversions[i].from);\n if (fromType.test(value)) {\n return conversions[i].convert(value);\n }\n }\n throw new Error('Cannot convert ' + value + ' to ' + typeName);\n }\n\n /**\n * Stringify parameters in a normalized way\n * @param {Param[]} params\n * @param {string} [','] separator\n * @return {string}\n */\n function stringifyParams(params) {\n let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ',';\n return params.map(p => p.name).join(separator);\n }\n\n /**\n * Parse a parameter, like \"...number | boolean\"\n * @param {string} param\n * @return {Param} param\n */\n function parseParam(param) {\n const restParam = param.indexOf('...') === 0;\n const types = !restParam ? param : param.length > 3 ? param.slice(3) : 'any';\n const typeDefs = types.split('|').map(s => findType(s.trim()));\n let hasAny = false;\n let paramName = restParam ? '...' : '';\n const exactTypes = typeDefs.map(function (type) {\n hasAny = type.isAny || hasAny;\n paramName += type.name + '|';\n return {\n name: type.name,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion: null,\n conversionIndex: -1\n };\n });\n return {\n types: exactTypes,\n name: paramName.slice(0, -1),\n // remove trailing '|' from above\n hasAny,\n hasConversion: false,\n restParam\n };\n }\n\n /**\n * Expands a parsed parameter with the types available from currently\n * defined conversions.\n * @param {Param} param\n * @return {Param} param\n */\n function expandParam(param) {\n const typeNames = param.types.map(t => t.name);\n const matchingConversions = availableConversions(typeNames);\n let hasAny = param.hasAny;\n let newName = param.name;\n const convertibleTypes = matchingConversions.map(function (conversion) {\n const type = findType(conversion.from);\n hasAny = type.isAny || hasAny;\n newName += '|' + conversion.from;\n return {\n name: conversion.from,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion,\n conversionIndex: conversion.index\n };\n });\n return {\n types: param.types.concat(convertibleTypes),\n name: newName,\n hasAny,\n hasConversion: convertibleTypes.length > 0,\n restParam: param.restParam\n };\n }\n\n /**\n * Return the set of type names in a parameter.\n * Caches the result for efficiency\n *\n * @param {Param} param\n * @return {Set} typenames\n */\n function paramTypeSet(param) {\n if (!param.typeSet) {\n param.typeSet = new Set();\n param.types.forEach(type => param.typeSet.add(type.name));\n }\n return param.typeSet;\n }\n\n /**\n * Parse a signature with comma separated parameters,\n * like \"number | boolean, ...string\"\n *\n * @param {string} signature\n * @return {Param[]} params\n */\n function parseSignature(rawSignature) {\n const params = [];\n if (typeof rawSignature !== 'string') {\n throw new TypeError('Signatures must be strings');\n }\n const signature = rawSignature.trim();\n if (signature === '') {\n return params;\n }\n const rawParams = signature.split(',');\n for (let i = 0; i < rawParams.length; ++i) {\n const parsedParam = parseParam(rawParams[i].trim());\n if (parsedParam.restParam && i !== rawParams.length - 1) {\n throw new SyntaxError('Unexpected rest parameter \"' + rawParams[i] + '\": ' + 'only allowed for the last parameter');\n }\n // if invalid, short-circuit (all the types may have been filtered)\n if (parsedParam.types.length === 0) {\n return null;\n }\n params.push(parsedParam);\n }\n return params;\n }\n\n /**\n * Test whether a set of params contains a restParam\n * @param {Param[]} params\n * @return {boolean} Returns true when the last parameter is a restParam\n */\n function hasRestParam(params) {\n const param = last(params);\n return param ? param.restParam : false;\n }\n\n /**\n * Create a type test for a single parameter, which can have one or multiple\n * types.\n * @param {Param} param\n * @return {function(x: *) : boolean} Returns a test function\n */\n function compileTest(param) {\n if (!param || param.types.length === 0) {\n // nothing to do\n return ok;\n } else if (param.types.length === 1) {\n return findType(param.types[0].name).test;\n } else if (param.types.length === 2) {\n const test0 = findType(param.types[0].name).test;\n const test1 = findType(param.types[1].name).test;\n return function or(x) {\n return test0(x) || test1(x);\n };\n } else {\n // param.types.length > 2\n const tests = param.types.map(function (type) {\n return findType(type.name).test;\n });\n return function or(x) {\n for (let i = 0; i < tests.length; i++) {\n if (tests[i](x)) {\n return true;\n }\n }\n return false;\n };\n }\n }\n\n /**\n * Create a test for all parameters of a signature\n * @param {Param[]} params\n * @return {function(args: Array<*>) : boolean}\n */\n function compileTests(params) {\n let tests, test0, test1;\n if (hasRestParam(params)) {\n // variable arguments like '...number'\n tests = initial(params).map(compileTest);\n const varIndex = tests.length;\n const lastTest = compileTest(last(params));\n const testRestParam = function (args) {\n for (let i = varIndex; i < args.length; i++) {\n if (!lastTest(args[i])) {\n return false;\n }\n }\n return true;\n };\n return function testArgs(args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return testRestParam(args) && args.length >= varIndex + 1;\n };\n } else {\n // no variable arguments\n if (params.length === 0) {\n return function testArgs(args) {\n return args.length === 0;\n };\n } else if (params.length === 1) {\n test0 = compileTest(params[0]);\n return function testArgs(args) {\n return test0(args[0]) && args.length === 1;\n };\n } else if (params.length === 2) {\n test0 = compileTest(params[0]);\n test1 = compileTest(params[1]);\n return function testArgs(args) {\n return test0(args[0]) && test1(args[1]) && args.length === 2;\n };\n } else {\n // arguments.length > 2\n tests = params.map(compileTest);\n return function testArgs(args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return args.length === tests.length;\n };\n }\n }\n }\n\n /**\n * Find the parameter at a specific index of a Params list.\n * Handles rest parameters.\n * @param {Param[]} params\n * @param {number} index\n * @return {Param | null} Returns the matching parameter when found,\n * null otherwise.\n */\n function getParamAtIndex(params, index) {\n return index < params.length ? params[index] : hasRestParam(params) ? last(params) : null;\n }\n\n /**\n * Get all type names of a parameter\n * @param {Params[]} params\n * @param {number} index\n * @return {string[]} Returns an array with type names\n */\n function getTypeSetAtIndex(params, index) {\n const param = getParamAtIndex(params, index);\n if (!param) {\n return new Set();\n }\n return paramTypeSet(param);\n }\n\n /**\n * Test whether a type is an exact type or conversion\n * @param {Type} type\n * @return {boolean} Returns true when\n */\n function isExactType(type) {\n return type.conversion === null || type.conversion === undefined;\n }\n\n /**\n * Helper function for creating error messages: create an array with\n * all available types on a specific argument index.\n * @param {Signature[]} signatures\n * @param {number} index\n * @return {string[]} Returns an array with available types\n */\n function mergeExpectedParams(signatures, index) {\n const typeSet = new Set();\n signatures.forEach(signature => {\n const paramSet = getTypeSetAtIndex(signature.params, index);\n let name;\n for (name of paramSet) {\n typeSet.add(name);\n }\n });\n return typeSet.has('any') ? ['any'] : Array.from(typeSet);\n }\n\n /**\n * Create\n * @param {string} name The name of the function\n * @param {array.<*>} args The actual arguments passed to the function\n * @param {Signature[]} signatures A list with available signatures\n * @return {TypeError} Returns a type error with additional data\n * attached to it in the property `data`\n */\n function createError(name, args, signatures) {\n let err, expected;\n const _name = name || 'unnamed';\n\n // test for wrong type at some index\n let matchingSignatures = signatures;\n let index;\n for (index = 0; index < args.length; index++) {\n const nextMatchingDefs = [];\n matchingSignatures.forEach(signature => {\n const param = getParamAtIndex(signature.params, index);\n const test = compileTest(param);\n if ((index < signature.params.length || hasRestParam(signature.params)) && test(args[index])) {\n nextMatchingDefs.push(signature);\n }\n });\n if (nextMatchingDefs.length === 0) {\n // no matching signatures anymore, throw error \"wrong type\"\n expected = mergeExpectedParams(matchingSignatures, index);\n if (expected.length > 0) {\n const actualTypes = findTypeNames(args[index]);\n err = new TypeError('Unexpected type of argument in function ' + _name + ' (expected: ' + expected.join(' or ') + ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')');\n err.data = {\n category: 'wrongType',\n fn: _name,\n index,\n actual: actualTypes,\n expected\n };\n return err;\n }\n } else {\n matchingSignatures = nextMatchingDefs;\n }\n }\n\n // test for too few arguments\n const lengths = matchingSignatures.map(function (signature) {\n return hasRestParam(signature.params) ? Infinity : signature.params.length;\n });\n if (args.length < Math.min.apply(null, lengths)) {\n expected = mergeExpectedParams(matchingSignatures, index);\n err = new TypeError('Too few arguments in function ' + _name + ' (expected: ' + expected.join(' or ') + ', index: ' + args.length + ')');\n err.data = {\n category: 'tooFewArgs',\n fn: _name,\n index: args.length,\n expected\n };\n return err;\n }\n\n // test for too many arguments\n const maxLength = Math.max.apply(null, lengths);\n if (args.length > maxLength) {\n err = new TypeError('Too many arguments in function ' + _name + ' (expected: ' + maxLength + ', actual: ' + args.length + ')');\n err.data = {\n category: 'tooManyArgs',\n fn: _name,\n index: args.length,\n expectedLength: maxLength\n };\n return err;\n }\n\n // Generic error\n const argTypes = [];\n for (let i = 0; i < args.length; ++i) {\n argTypes.push(findTypeNames(args[i]).join('|'));\n }\n err = new TypeError('Arguments of type \"' + argTypes.join(', ') + '\" do not match any of the defined signatures of function ' + _name + '.');\n err.data = {\n category: 'mismatch',\n actual: argTypes\n };\n return err;\n }\n\n /**\n * Find the lowest index of all exact types of a parameter (no conversions)\n * @param {Param} param\n * @return {number} Returns the index of the lowest type in typed.types\n */\n function getLowestTypeIndex(param) {\n let min = typeList.length + 1;\n for (let i = 0; i < param.types.length; i++) {\n if (isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].typeIndex);\n }\n }\n return min;\n }\n\n /**\n * Find the lowest index of the conversion of all types of the parameter\n * having a conversion\n * @param {Param} param\n * @return {number} Returns the lowest index of the conversions of this type\n */\n function getLowestConversionIndex(param) {\n let min = nConversions + 1;\n for (let i = 0; i < param.types.length; i++) {\n if (!isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].conversionIndex);\n }\n }\n return min;\n }\n\n /**\n * Compare two params\n * @param {Param} param1\n * @param {Param} param2\n * @return {number} returns -1 when param1 must get a lower\n * index than param2, 1 when the opposite,\n * or zero when both are equal\n */\n function compareParams(param1, param2) {\n // We compare a number of metrics on a param in turn:\n // 1) 'any' parameters are the least preferred\n if (param1.hasAny) {\n if (!param2.hasAny) {\n return 1;\n }\n } else if (param2.hasAny) {\n return -1;\n }\n\n // 2) Prefer non-rest to rest parameters\n if (param1.restParam) {\n if (!param2.restParam) {\n return 1;\n }\n } else if (param2.restParam) {\n return -1;\n }\n\n // 3) Prefer exact type match to conversions\n if (param1.hasConversion) {\n if (!param2.hasConversion) {\n return 1;\n }\n } else if (param2.hasConversion) {\n return -1;\n }\n\n // 4) Prefer lower type index:\n const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2);\n if (typeDiff < 0) {\n return -1;\n }\n if (typeDiff > 0) {\n return 1;\n }\n\n // 5) Prefer lower conversion index\n const convDiff = getLowestConversionIndex(param1) - getLowestConversionIndex(param2);\n if (convDiff < 0) {\n return -1;\n }\n if (convDiff > 0) {\n return 1;\n }\n\n // Don't have a basis for preference\n return 0;\n }\n\n /**\n * Compare two signatures\n * @param {Signature} signature1\n * @param {Signature} signature2\n * @return {number} returns a negative number when param1 must get a lower\n * index than param2, a positive number when the opposite,\n * or zero when both are equal\n */\n function compareSignatures(signature1, signature2) {\n const pars1 = signature1.params;\n const pars2 = signature2.params;\n const last1 = last(pars1);\n const last2 = last(pars2);\n const hasRest1 = hasRestParam(pars1);\n const hasRest2 = hasRestParam(pars2);\n // We compare a number of metrics on signatures in turn:\n // 1) An \"any rest param\" is least preferred\n if (hasRest1 && last1.hasAny) {\n if (!hasRest2 || !last2.hasAny) {\n return 1;\n }\n } else if (hasRest2 && last2.hasAny) {\n return -1;\n }\n\n // 2) Minimize the number of 'any' parameters\n let any1 = 0;\n let conv1 = 0;\n let par;\n for (par of pars1) {\n if (par.hasAny) ++any1;\n if (par.hasConversion) ++conv1;\n }\n let any2 = 0;\n let conv2 = 0;\n for (par of pars2) {\n if (par.hasAny) ++any2;\n if (par.hasConversion) ++conv2;\n }\n if (any1 !== any2) {\n return any1 - any2;\n }\n\n // 3) A conversion rest param is less preferred\n if (hasRest1 && last1.hasConversion) {\n if (!hasRest2 || !last2.hasConversion) {\n return 1;\n }\n } else if (hasRest2 && last2.hasConversion) {\n return -1;\n }\n\n // 4) Minimize the number of conversions\n if (conv1 !== conv2) {\n return conv1 - conv2;\n }\n\n // 5) Prefer no rest param\n if (hasRest1) {\n if (!hasRest2) {\n return 1;\n }\n } else if (hasRest2) {\n return -1;\n }\n\n // 6) Prefer shorter with rest param, longer without\n const lengthCriterion = (pars1.length - pars2.length) * (hasRest1 ? -1 : 1);\n if (lengthCriterion !== 0) {\n return lengthCriterion;\n }\n\n // Signatures are identical in each of the above metrics.\n // In particular, they are the same length.\n // We can therefore compare the parameters one by one.\n // First we count which signature has more preferred parameters.\n const comparisons = [];\n let tc = 0;\n for (let i = 0; i < pars1.length; ++i) {\n const thisComparison = compareParams(pars1[i], pars2[i]);\n comparisons.push(thisComparison);\n tc += thisComparison;\n }\n if (tc !== 0) {\n return tc;\n }\n\n // They have the same number of preferred parameters, so go by the\n // earliest parameter in which we have a preference.\n // In other words, dispatch is driven somewhat more by earlier\n // parameters than later ones.\n let c;\n for (c of comparisons) {\n if (c !== 0) {\n return c;\n }\n }\n\n // It's a tossup:\n return 0;\n }\n\n /**\n * Produce a list of all conversions from distinct types to one of\n * the given types.\n *\n * @param {string[]} typeNames\n * @return {ConversionDef[]} Returns the conversions that are available\n * resulting in any given type (if any)\n */\n function availableConversions(typeNames) {\n if (typeNames.length === 0) {\n return [];\n }\n const types = typeNames.map(findType);\n if (typeNames.length > 1) {\n types.sort((t1, t2) => t1.index - t2.index);\n }\n let matches = types[0].conversionsTo;\n if (typeNames.length === 1) {\n return matches;\n }\n matches = matches.concat([]); // shallow copy the matches\n // Since the types are now in index order, we just want the first\n // occurrence of any from type:\n const knownTypes = new Set(typeNames);\n for (let i = 1; i < types.length; ++i) {\n let newMatch;\n for (newMatch of types[i].conversionsTo) {\n if (!knownTypes.has(newMatch.from)) {\n matches.push(newMatch);\n knownTypes.add(newMatch.from);\n }\n }\n }\n return matches;\n }\n\n /**\n * Preprocess arguments before calling the original function:\n * - if needed convert the parameters\n * - in case of rest parameters, move the rest parameters into an Array\n * @param {Param[]} params\n * @param {function} fn\n * @return {function} Returns a wrapped function\n */\n function compileArgsPreprocessing(params, fn) {\n let fnConvert = fn;\n\n // TODO: can we make this wrapper function smarter/simpler?\n\n if (params.some(p => p.hasConversion)) {\n const restParam = hasRestParam(params);\n const compiledConversions = params.map(compileArgConversion);\n fnConvert = function convertArgs() {\n const args = [];\n const last = restParam ? arguments.length - 1 : arguments.length;\n for (let i = 0; i < last; i++) {\n args[i] = compiledConversions[i](arguments[i]);\n }\n if (restParam) {\n args[last] = arguments[last].map(compiledConversions[last]);\n }\n return fn.apply(this, args);\n };\n }\n let fnPreprocess = fnConvert;\n if (hasRestParam(params)) {\n const offset = params.length - 1;\n fnPreprocess = function preprocessRestParams() {\n return fnConvert.apply(this, slice(arguments, 0, offset).concat([slice(arguments, offset)]));\n };\n }\n return fnPreprocess;\n }\n\n /**\n * Compile conversion for a parameter to the right type\n * @param {Param} param\n * @return {function} Returns the wrapped function that will convert arguments\n *\n */\n function compileArgConversion(param) {\n let test0, test1, conversion0, conversion1;\n const tests = [];\n const conversions = [];\n param.types.forEach(function (type) {\n if (type.conversion) {\n tests.push(findType(type.conversion.from).test);\n conversions.push(type.conversion.convert);\n }\n });\n\n // create optimized conversion functions depending on the number of conversions\n switch (conversions.length) {\n case 0:\n return function convertArg(arg) {\n return arg;\n };\n case 1:\n test0 = tests[0];\n conversion0 = conversions[0];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg);\n }\n return arg;\n };\n case 2:\n test0 = tests[0];\n test1 = tests[1];\n conversion0 = conversions[0];\n conversion1 = conversions[1];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg);\n }\n if (test1(arg)) {\n return conversion1(arg);\n }\n return arg;\n };\n default:\n return function convertArg(arg) {\n for (let i = 0; i < conversions.length; i++) {\n if (tests[i](arg)) {\n return conversions[i](arg);\n }\n }\n return arg;\n };\n }\n }\n\n /**\n * Split params with union types in to separate params.\n *\n * For example:\n *\n * splitParams([['Array', 'Object'], ['string', 'RegExp'])\n * // returns:\n * // [\n * // ['Array', 'string'],\n * // ['Array', 'RegExp'],\n * // ['Object', 'string'],\n * // ['Object', 'RegExp']\n * // ]\n *\n * @param {Param[]} params\n * @return {Param[]}\n */\n function splitParams(params) {\n function _splitParams(params, index, paramsSoFar) {\n if (index < params.length) {\n const param = params[index];\n let resultingParams = [];\n if (param.restParam) {\n // split the types of a rest parameter in two:\n // one with only exact types, and one with exact types and conversions\n const exactTypes = param.types.filter(isExactType);\n if (exactTypes.length < param.types.length) {\n resultingParams.push({\n types: exactTypes,\n name: '...' + exactTypes.map(t => t.name).join('|'),\n hasAny: exactTypes.some(t => t.isAny),\n hasConversion: false,\n restParam: true\n });\n }\n resultingParams.push(param);\n } else {\n // split all the types of a regular parameter into one type per param\n resultingParams = param.types.map(function (type) {\n return {\n types: [type],\n name: type.name,\n hasAny: type.isAny,\n hasConversion: type.conversion,\n restParam: false\n };\n });\n }\n\n // recurse over the groups with types\n return flatMap(resultingParams, function (nextParam) {\n return _splitParams(params, index + 1, paramsSoFar.concat([nextParam]));\n });\n } else {\n // we've reached the end of the parameters.\n return [paramsSoFar];\n }\n }\n return _splitParams(params, 0, []);\n }\n\n /**\n * Test whether two param lists represent conflicting signatures\n * @param {Param[]} params1\n * @param {Param[]} params2\n * @return {boolean} Returns true when the signatures conflict, false otherwise.\n */\n function conflicting(params1, params2) {\n const ii = Math.max(params1.length, params2.length);\n for (let i = 0; i < ii; i++) {\n const typeSet1 = getTypeSetAtIndex(params1, i);\n const typeSet2 = getTypeSetAtIndex(params2, i);\n let overlap = false;\n let name;\n for (name of typeSet2) {\n if (typeSet1.has(name)) {\n overlap = true;\n break;\n }\n }\n if (!overlap) {\n return false;\n }\n }\n const len1 = params1.length;\n const len2 = params2.length;\n const restParam1 = hasRestParam(params1);\n const restParam2 = hasRestParam(params2);\n return restParam1 ? restParam2 ? len1 === len2 : len2 >= len1 : restParam2 ? len1 >= len2 : len1 === len2;\n }\n\n /**\n * Helper function for `resolveReferences` that returns a copy of\n * functionList wihe any prior resolutions cleared out, in case we are\n * recycling signatures from a prior typed function construction.\n *\n * @param {Array.} functionList\n * @return {Array.}\n */\n function clearResolutions(functionList) {\n return functionList.map(fn => {\n if (isReferToSelf(fn)) {\n return referToSelf(fn.referToSelf.callback);\n }\n if (isReferTo(fn)) {\n return makeReferTo(fn.referTo.references, fn.referTo.callback);\n }\n return fn;\n });\n }\n\n /**\n * Take a list of references, a list of functions functionList, and a\n * signatureMap indexing signatures into functionList, and return\n * the list of resolutions, or a false-y value if they don't all\n * resolve in a valid way (yet).\n *\n * @param {string[]} references\n * @param {Array} signatureMap\n * @return {function[] | false} resolutions\n */\n function collectResolutions(references, functionList, signatureMap) {\n const resolvedReferences = [];\n let reference;\n for (reference of references) {\n let resolution = signatureMap[reference];\n if (typeof resolution !== 'number') {\n throw new TypeError('No definition for referenced signature \"' + reference + '\"');\n }\n resolution = functionList[resolution];\n if (typeof resolution !== 'function') {\n return false;\n }\n resolvedReferences.push(resolution);\n }\n return resolvedReferences;\n }\n\n /**\n * Resolve any references in the functionList for the typed function\n * itself. The signatureMap tells which index in the functionList a\n * given signature should be mapped to (for use in resolving typed.referTo)\n * and self provides the destions of a typed.referToSelf.\n *\n * @param {Array} functionList\n * @param {Object.} signatureMap\n * @param {function} self The typed-function itself\n * @return {Array} The list of resolved functions\n */\n function resolveReferences(functionList, signatureMap, self) {\n const resolvedFunctions = clearResolutions(functionList);\n const isResolved = new Array(resolvedFunctions.length).fill(false);\n let leftUnresolved = true;\n while (leftUnresolved) {\n leftUnresolved = false;\n let nothingResolved = true;\n for (let i = 0; i < resolvedFunctions.length; ++i) {\n if (isResolved[i]) continue;\n const fn = resolvedFunctions[i];\n if (isReferToSelf(fn)) {\n resolvedFunctions[i] = fn.referToSelf.callback(self);\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referToSelf = fn.referToSelf;\n isResolved[i] = true;\n nothingResolved = false;\n } else if (isReferTo(fn)) {\n const resolvedReferences = collectResolutions(fn.referTo.references, resolvedFunctions, signatureMap);\n if (resolvedReferences) {\n resolvedFunctions[i] = fn.referTo.callback.apply(this, resolvedReferences);\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referTo = fn.referTo;\n isResolved[i] = true;\n nothingResolved = false;\n } else {\n leftUnresolved = true;\n }\n }\n }\n if (nothingResolved && leftUnresolved) {\n throw new SyntaxError('Circular reference detected in resolving typed.referTo');\n }\n }\n return resolvedFunctions;\n }\n\n /**\n * Validate whether any of the function bodies contains a self-reference\n * usage like `this(...)` or `this.signatures`. This self-referencing is\n * deprecated since typed-function v3. It has been replaced with\n * the functions typed.referTo and typed.referToSelf.\n * @param {Object.} signaturesMap\n */\n function validateDeprecatedThis(signaturesMap) {\n // TODO: remove this deprecation warning logic some day (it's introduced in v3)\n\n // match occurrences like 'this(' and 'this.signatures'\n const deprecatedThisRegex = /\\bthis(\\(|\\.signatures\\b)/;\n Object.keys(signaturesMap).forEach(signature => {\n const fn = signaturesMap[signature];\n if (deprecatedThisRegex.test(fn.toString())) {\n throw new SyntaxError('Using `this` to self-reference a function ' + 'is deprecated since typed-function@3. ' + 'Use typed.referTo and typed.referToSelf instead.');\n }\n });\n }\n\n /**\n * Create a typed function\n * @param {String} name The name for the typed function\n * @param {Object.} rawSignaturesMap\n * An object with one or\n * multiple signatures as key, and the\n * function corresponding to the\n * signature as value.\n * @return {function} Returns the created typed function.\n */\n function createTypedFunction(name, rawSignaturesMap) {\n typed.createCount++;\n if (Object.keys(rawSignaturesMap).length === 0) {\n throw new SyntaxError('No signatures provided');\n }\n if (typed.warnAgainstDeprecatedThis) {\n validateDeprecatedThis(rawSignaturesMap);\n }\n\n // Main processing loop for signatures\n const parsedParams = [];\n const originalFunctions = [];\n const signaturesMap = {};\n const preliminarySignatures = []; // may have duplicates from conversions\n let signature;\n for (signature in rawSignaturesMap) {\n // A) Protect against polluted Object prototype:\n if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) {\n continue;\n }\n // B) Parse the signature\n const params = parseSignature(signature);\n if (!params) continue;\n // C) Check for conflicts\n parsedParams.forEach(function (pp) {\n if (conflicting(pp, params)) {\n throw new TypeError('Conflicting signatures \"' + stringifyParams(pp) + '\" and \"' + stringifyParams(params) + '\".');\n }\n });\n parsedParams.push(params);\n // D) Store the provided function and add conversions\n const functionIndex = originalFunctions.length;\n originalFunctions.push(rawSignaturesMap[signature]);\n const conversionParams = params.map(expandParam);\n // E) Split the signatures and collect them up\n let sp;\n for (sp of splitParams(conversionParams)) {\n const spName = stringifyParams(sp);\n preliminarySignatures.push({\n params: sp,\n name: spName,\n fn: functionIndex\n });\n if (sp.every(p => !p.hasConversion)) {\n signaturesMap[spName] = functionIndex;\n }\n }\n }\n preliminarySignatures.sort(compareSignatures);\n\n // Note the forward reference to theTypedFn\n const resolvedFunctions = resolveReferences(originalFunctions, signaturesMap, theTypedFn);\n\n // Fill in the proper function for each signature\n let s;\n for (s in signaturesMap) {\n if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) {\n signaturesMap[s] = resolvedFunctions[signaturesMap[s]];\n }\n }\n const signatures = [];\n const internalSignatureMap = new Map(); // benchmarks faster than object\n for (s of preliminarySignatures) {\n // Note it's only safe to eliminate duplicates like this\n // _after_ the signature sorting step above; otherwise we might\n // remove the wrong one.\n if (!internalSignatureMap.has(s.name)) {\n s.fn = resolvedFunctions[s.fn];\n signatures.push(s);\n internalSignatureMap.set(s.name, s);\n }\n }\n\n // we create a highly optimized checks for the first couple of signatures with max 2 arguments\n const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params);\n const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params);\n const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params);\n const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params);\n const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params);\n const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params);\n const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5;\n\n // compile the tests\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].test = compileTests(signatures[i].params);\n }\n const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk;\n const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk;\n const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk;\n const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk;\n const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk;\n const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk;\n const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk;\n const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk;\n const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk;\n const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk;\n const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk;\n const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk;\n\n // compile the functions\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].implementation = compileArgsPreprocessing(signatures[i].params, signatures[i].fn);\n }\n const fn0 = ok0 ? signatures[0].implementation : undef;\n const fn1 = ok1 ? signatures[1].implementation : undef;\n const fn2 = ok2 ? signatures[2].implementation : undef;\n const fn3 = ok3 ? signatures[3].implementation : undef;\n const fn4 = ok4 ? signatures[4].implementation : undef;\n const fn5 = ok5 ? signatures[5].implementation : undef;\n const len0 = ok0 ? signatures[0].params.length : -1;\n const len1 = ok1 ? signatures[1].params.length : -1;\n const len2 = ok2 ? signatures[2].params.length : -1;\n const len3 = ok3 ? signatures[3].params.length : -1;\n const len4 = ok4 ? signatures[4].params.length : -1;\n const len5 = ok5 ? signatures[5].params.length : -1;\n\n // simple and generic, but also slow\n const iStart = allOk ? 6 : 0;\n const iEnd = signatures.length;\n // de-reference ahead for execution speed:\n const tests = signatures.map(s => s.test);\n const fns = signatures.map(s => s.implementation);\n const generic = function generic() {\n\n for (let i = iStart; i < iEnd; i++) {\n if (tests[i](arguments)) {\n return fns[i].apply(this, arguments);\n }\n }\n return typed.onMismatch(name, arguments, signatures);\n };\n\n // create the typed function\n // fast, specialized version. Falls back to the slower, generic one if needed\n function theTypedFn(arg0, arg1) {\n\n if (arguments.length === len0 && test00(arg0) && test01(arg1)) {\n return fn0.apply(this, arguments);\n }\n if (arguments.length === len1 && test10(arg0) && test11(arg1)) {\n return fn1.apply(this, arguments);\n }\n if (arguments.length === len2 && test20(arg0) && test21(arg1)) {\n return fn2.apply(this, arguments);\n }\n if (arguments.length === len3 && test30(arg0) && test31(arg1)) {\n return fn3.apply(this, arguments);\n }\n if (arguments.length === len4 && test40(arg0) && test41(arg1)) {\n return fn4.apply(this, arguments);\n }\n if (arguments.length === len5 && test50(arg0) && test51(arg1)) {\n return fn5.apply(this, arguments);\n }\n return generic.apply(this, arguments);\n }\n\n // attach name the typed function\n try {\n Object.defineProperty(theTypedFn, 'name', {\n value: name\n });\n } catch (err) {\n // old browsers do not support Object.defineProperty and some don't support setting the name property\n // the function name is not essential for the functioning, it's mostly useful for debugging,\n // so it's fine to have unnamed functions.\n }\n\n // attach signatures to the function.\n // This property is close to the original collection of signatures\n // used to create the typed-function, just with unions split:\n theTypedFn.signatures = signaturesMap;\n\n // Store internal data for functions like resolve, find, etc.\n // Also serves as the flag that this is a typed-function\n theTypedFn._typedFunctionData = {\n signatures,\n signatureMap: internalSignatureMap\n };\n return theTypedFn;\n }\n\n /**\n * Action to take on mismatch\n * @param {string} name Name of function that was attempted to be called\n * @param {Array} args Actual arguments to the call\n * @param {Array} signatures Known signatures of the named typed-function\n */\n function _onMismatch(name, args, signatures) {\n throw createError(name, args, signatures);\n }\n\n /**\n * Return all but the last items of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {Array}\n */\n function initial(arr) {\n return slice(arr, 0, arr.length - 1);\n }\n\n /**\n * return the last item of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {*}\n */\n function last(arr) {\n return arr[arr.length - 1];\n }\n\n /**\n * Slice an array or function Arguments\n * @param {Array | Arguments | IArguments} arr\n * @param {number} start\n * @param {number} [end]\n * @return {Array}\n */\n function slice(arr, start, end) {\n return Array.prototype.slice.call(arr, start, end);\n }\n\n /**\n * Return the first item from an array for which test(arr[i]) returns true\n * @param {Array} arr\n * @param {function} test\n * @return {* | undefined} Returns the first matching item\n * or undefined when there is no match\n */\n function findInArray(arr, test) {\n for (let i = 0; i < arr.length; i++) {\n if (test(arr[i])) {\n return arr[i];\n }\n }\n return undefined;\n }\n\n /**\n * Flat map the result invoking a callback for every item in an array.\n * https://gist.github.com/samgiles/762ee337dff48623e729\n * @param {Array} arr\n * @param {function} callback\n * @return {Array}\n */\n function flatMap(arr, callback) {\n return Array.prototype.concat.apply([], arr.map(callback));\n }\n\n /**\n * Create a reference callback to one or multiple signatures\n *\n * Syntax:\n *\n * typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) {\n * // ...\n * })\n *\n * @returns {{referTo: {references: string[], callback}}}\n */\n function referTo() {\n const references = initial(arguments).map(s => stringifyParams(parseSignature(s)));\n const callback = last(arguments);\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as last argument');\n }\n return makeReferTo(references, callback);\n }\n function makeReferTo(references, callback) {\n return {\n referTo: {\n references,\n callback\n }\n };\n }\n\n /**\n * Create a reference callback to the typed-function itself\n *\n * @param {(self: function) => function} callback\n * @returns {{referToSelf: { callback: function }}}\n */\n function referToSelf(callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as first argument');\n }\n return {\n referToSelf: {\n callback\n }\n };\n }\n\n /**\n * Test whether something is a referTo object, holding a list with reference\n * signatures and a callback.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferTo(objectOrFn) {\n return objectOrFn && typeof objectOrFn.referTo === 'object' && Array.isArray(objectOrFn.referTo.references) && typeof objectOrFn.referTo.callback === 'function';\n }\n\n /**\n * Test whether something is a referToSelf object, holding a callback where\n * to pass `self`.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferToSelf(objectOrFn) {\n return objectOrFn && typeof objectOrFn.referToSelf === 'object' && typeof objectOrFn.referToSelf.callback === 'function';\n }\n\n /**\n * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw\n * an error in case (C).\n *\n * @param { string | undefined } nameSoFar\n * @param { string | undefined } newName\n * @returns { string } updated name\n */\n function checkName(nameSoFar, newName) {\n if (!nameSoFar) {\n return newName;\n }\n if (newName && newName !== nameSoFar) {\n const err = new Error('Function names do not match (expected: ' + nameSoFar + ', actual: ' + newName + ')');\n err.data = {\n actual: newName,\n expected: nameSoFar\n };\n throw err;\n }\n return nameSoFar;\n }\n\n /**\n * Retrieve the implied name from an object with signature keys\n * and function values, checking whether all value names match\n *\n * @param { {string: function} } obj\n */\n function getObjectName(obj) {\n let name;\n for (const key in obj) {\n // Only pay attention to own properties, and only if their values\n // are typed functions or functions with a signature property\n if (Object.prototype.hasOwnProperty.call(obj, key) && (isTypedFunction(obj[key]) || typeof obj[key].signature === 'string')) {\n name = checkName(name, obj[key].name);\n }\n }\n return name;\n }\n\n /**\n * Copy all of the signatures from the second argument into the first,\n * which is modified by side effect, checking for conflicts\n *\n * @param {Object.} dest\n * @param {Object.} source\n */\n function mergeSignatures(dest, source) {\n let key;\n for (key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n if (key in dest) {\n if (source[key] !== dest[key]) {\n const err = new Error('Signature \"' + key + '\" is defined twice');\n err.data = {\n signature: key,\n sourceFunction: source[key],\n destFunction: dest[key]\n };\n throw err;\n }\n // else: both signatures point to the same function, that's fine\n }\n dest[key] = source[key];\n }\n }\n }\n const saveTyped = typed;\n\n /**\n * Originally the main function was a typed function itself, but then\n * it might not be able to generate error messages if the client\n * replaced the type system with different names.\n *\n * Main entry: typed([name], functions/objects with signatures...)\n *\n * Assembles and returns a new typed-function from the given items\n * that provide signatures and implementations, each of which may be\n * * a plain object mapping (string) signatures to implementing functions,\n * * a previously constructed typed function, or\n * * any other single function with a string-valued property `signature`.\n * The name of the resulting typed-function will be given by the\n * string-valued name argument if present, or if not, by the name\n * of any of the arguments that have one, as long as any that do are\n * consistent with each other. If no name is specified, the name will be\n * an empty string.\n *\n * @param {string} maybeName [optional]\n * @param {(function|object)[]} signature providers\n * @returns {typed-function}\n */\n typed = function (maybeName) {\n const named = typeof maybeName === 'string';\n const start = named ? 1 : 0;\n let name = named ? maybeName : '';\n const allSignatures = {};\n for (let i = start; i < arguments.length; ++i) {\n const item = arguments[i];\n let theseSignatures = {};\n let thisName;\n if (typeof item === 'function') {\n thisName = item.name;\n if (typeof item.signature === 'string') {\n // Case 1: Ordinary function with a string 'signature' property\n theseSignatures[item.signature] = item;\n } else if (isTypedFunction(item)) {\n // Case 2: Existing typed function\n theseSignatures = item.signatures;\n }\n } else if (isPlainObject(item)) {\n // Case 3: Plain object, assume keys = signatures, values = functions\n theseSignatures = item;\n if (!named) {\n thisName = getObjectName(item);\n }\n }\n if (Object.keys(theseSignatures).length === 0) {\n const err = new TypeError('Argument to \\'typed\\' at index ' + i + ' is not a (typed) function, ' + 'nor an object with signatures as keys and functions as values.');\n err.data = {\n index: i,\n argument: item\n };\n throw err;\n }\n if (!named) {\n name = checkName(name, thisName);\n }\n mergeSignatures(allSignatures, theseSignatures);\n }\n return createTypedFunction(name || '', allSignatures);\n };\n typed.create = create;\n typed.createCount = saveTyped.createCount;\n typed.onMismatch = _onMismatch;\n typed.throwMismatchError = _onMismatch;\n typed.createError = createError;\n typed.clear = clear;\n typed.clearConversions = clearConversions;\n typed.addTypes = addTypes;\n typed._findType = findType; // For unit testing only\n typed.referTo = referTo;\n typed.referToSelf = referToSelf;\n typed.convert = convert;\n typed.findSignature = findSignature;\n typed.find = find;\n typed.isTypedFunction = isTypedFunction;\n typed.warnAgainstDeprecatedThis = true;\n\n /**\n * add a type (convenience wrapper for typed.addTypes)\n * @param {{name: string, test: function}} type\n * @param {boolean} [beforeObjectTest=true]\n * If true, the new test will be inserted before\n * the test with name 'Object' (if any), since\n * tests for Object match Array and classes too.\n */\n typed.addType = function (type, beforeObjectTest) {\n let before = 'any';\n if (beforeObjectTest !== false && typeMap.has('Object')) {\n before = 'Object';\n }\n typed.addTypes([type], before);\n };\n\n /**\n * Verify that the ConversionDef conversion has a valid format.\n *\n * @param {conversionDef} conversion\n * @return {void}\n * @throws {TypeError|SyntaxError}\n */\n function _validateConversion(conversion) {\n if (!conversion || typeof conversion.from !== 'string' || typeof conversion.to !== 'string' || typeof conversion.convert !== 'function') {\n throw new TypeError('Object with properties {from: string, to: string, convert: function} expected');\n }\n if (conversion.to === conversion.from) {\n throw new SyntaxError('Illegal to define conversion from \"' + conversion.from + '\" to itself.');\n }\n }\n\n /**\n * Add a conversion\n *\n * @param {ConversionDef} conversion\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversion = function (conversion) {\n let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n override: false\n };\n _validateConversion(conversion);\n const to = findType(conversion.to);\n const existing = to.conversionsTo.find(other => other.from === conversion.from);\n if (existing) {\n if (options && options.override) {\n typed.removeConversion({\n from: existing.from,\n to: conversion.to,\n convert: existing.convert\n });\n } else {\n throw new Error('There is already a conversion from \"' + conversion.from + '\" to \"' + to.name + '\"');\n }\n }\n to.conversionsTo.push({\n from: conversion.from,\n convert: conversion.convert,\n index: nConversions++\n });\n };\n\n /**\n * Convenience wrapper to call addConversion on each conversion in a list.\n *\n * @param {ConversionDef[]} conversions\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversions = function (conversions, options) {\n conversions.forEach(conversion => typed.addConversion(conversion, options));\n };\n\n /**\n * Remove the specified conversion. The format is the same as for\n * addConversion, and the convert function must match or an error\n * is thrown.\n *\n * @param {{from: string, to: string, convert: function}} conversion\n * @returns {void}\n * @throws {TypeError|SyntaxError|Error}\n */\n typed.removeConversion = function (conversion) {\n _validateConversion(conversion);\n const to = findType(conversion.to);\n const existingConversion = findInArray(to.conversionsTo, c => c.from === conversion.from);\n if (!existingConversion) {\n throw new Error('Attempt to remove nonexistent conversion from ' + conversion.from + ' to ' + conversion.to);\n }\n if (existingConversion.convert !== conversion.convert) {\n throw new Error('Conversion to remove does not match existing conversion');\n }\n const index = to.conversionsTo.indexOf(existingConversion);\n to.conversionsTo.splice(index, 1);\n };\n\n /**\n * Produce the specific signature that a typed function\n * will execute on the given arguments. Here, a \"signature\" is an\n * object with properties 'params', 'test', 'fn', and 'implementation'.\n * This last property is a function that converts params as necessary\n * and then calls 'fn'. Returns null if there is no matching signature.\n * @param {typed-function} tf\n * @param {any[]} argList\n * @returns {{params: string, test: function, fn: function, implementation: function}}\n */\n typed.resolve = function (tf, argList) {\n if (!isTypedFunction(tf)) {\n throw new TypeError(NOT_TYPED_FUNCTION);\n }\n const sigs = tf._typedFunctionData.signatures;\n for (let i = 0; i < sigs.length; ++i) {\n if (sigs[i].test(argList)) {\n return sigs[i];\n }\n }\n return null;\n };\n return typed;\n }\n var typedFunction = create();\n\n return typedFunction;\n\n}));\n//# sourceMappingURL=typed-function.js.map\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.amdD = function () {\n\tthrow new Error('define cannot be used indirect');\n};","__webpack_require__.amdO = {};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","import { hasOwnProperty } from './object.js'\n\n/**\n * Get a property of a plain object\n * Throws an error in case the object is not a plain object or the\n * property is not defined on the object itself\n * @param {Object} object\n * @param {string} prop\n * @return {*} Returns the property value when safe\n */\nfunction getSafeProperty (object, prop) {\n // only allow getting safe properties of a plain object\n if (isSafeProperty(object, prop)) {\n return object[prop]\n }\n\n if (typeof object[prop] === 'function' && isSafeMethod(object, prop)) {\n throw new Error('Cannot access method \"' + prop + '\" as a property')\n }\n\n throw new Error('No access to property \"' + prop + '\"')\n}\n\n/**\n * Set a property on a plain object.\n * Throws an error in case the object is not a plain object or the\n * property would override an inherited property like .constructor or .toString\n * @param {Object} object\n * @param {string} prop\n * @param {*} value\n * @return {*} Returns the value\n */\n// TODO: merge this function into access.js?\nfunction setSafeProperty (object, prop, value) {\n // only allow setting safe properties of a plain object\n if (isSafeProperty(object, prop)) {\n object[prop] = value\n return value\n }\n\n throw new Error('No access to property \"' + prop + '\"')\n}\n\n/**\n * Test whether a property is safe to use on an object or Array.\n * For example .toString and .constructor are not safe\n * @param {Object | Array} object\n * @param {string} prop\n * @return {boolean} Returns true when safe\n */\nfunction isSafeProperty (object, prop) {\n if (!isPlainObject(object) && !Array.isArray(object)) {\n return false\n }\n // SAFE: whitelisted\n // e.g length\n if (hasOwnProperty(safeNativeProperties, prop)) {\n return true\n }\n // UNSAFE: inherited from Object prototype\n // e.g constructor\n if (prop in Object.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Object.prototype is a root object\n return false\n }\n // UNSAFE: inherited from Function prototype\n // e.g call, apply\n if (prop in Function.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Function.prototype is a root object\n return false\n }\n return true\n}\n\n/**\n * Validate whether a method is safe.\n * Throws an error when that's not the case.\n * @param {Object} object\n * @param {string} method\n * @return {function} Returns the method when valid\n */\nfunction getSafeMethod (object, method) {\n if (!isSafeMethod(object, method)) {\n throw new Error('No access to method \"' + method + '\"')\n }\n\n return object[method]\n}\n\n/**\n * Check whether a method is safe.\n * Throws an error when that's not the case (for example for `constructor`).\n * @param {Object} object\n * @param {string} method\n * @return {boolean} Returns true when safe, false otherwise\n */\nfunction isSafeMethod (object, method) {\n if (object === null || object === undefined || typeof object[method] !== 'function') {\n return false\n }\n // UNSAFE: ghosted\n // e.g overridden toString\n // Note that IE10 doesn't support __proto__ and we can't do this check there.\n if (hasOwnProperty(object, method) &&\n (Object.getPrototypeOf && (method in Object.getPrototypeOf(object)))) {\n return false\n }\n // SAFE: whitelisted\n // e.g toString\n if (hasOwnProperty(safeNativeMethods, method)) {\n return true\n }\n // UNSAFE: inherited from Object prototype\n // e.g constructor\n if (method in Object.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Object.prototype is a root object\n return false\n }\n // UNSAFE: inherited from Function prototype\n // e.g call, apply\n if (method in Function.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Function.prototype is a root object\n return false\n }\n return true\n}\n\nfunction isPlainObject (object) {\n return typeof object === 'object' && object && object.constructor === Object\n}\n\nconst safeNativeProperties = {\n length: true,\n name: true\n}\n\nconst safeNativeMethods = {\n toString: true,\n valueOf: true,\n toLocaleString: true\n}\n\nexport { getSafeProperty }\nexport { setSafeProperty }\nexport { isSafeProperty }\nexport { getSafeMethod }\nexport { isSafeMethod }\nexport { isPlainObject }\n","import { getSafeProperty, isSafeProperty, setSafeProperty } from './customs.js'\nimport { isMap, isObject } from './is.js'\n\n/**\n * A map facade on a bare object.\n *\n * The small number of methods needed to implement a scope,\n * forwarding on to the SafeProperty functions. Over time, the codebase\n * will stop using this method, as all objects will be Maps, rather than\n * more security prone objects.\n */\nexport class ObjectWrappingMap {\n constructor (object) {\n this.wrappedObject = object\n\n this[Symbol.iterator] = this.entries\n }\n\n keys () {\n return Object.keys(this.wrappedObject)\n .filter(key => this.has(key))\n .values()\n }\n\n get (key) {\n return getSafeProperty(this.wrappedObject, key)\n }\n\n set (key, value) {\n setSafeProperty(this.wrappedObject, key, value)\n return this\n }\n\n has (key) {\n return isSafeProperty(this.wrappedObject, key) && key in this.wrappedObject\n }\n\n entries () {\n return mapIterator(this.keys(), key => [key, this.get(key)])\n }\n\n forEach (callback) {\n for (const key of this.keys()) {\n callback(this.get(key), key, this)\n }\n }\n\n delete (key) {\n if (isSafeProperty(this.wrappedObject, key)) {\n delete this.wrappedObject[key]\n }\n }\n\n clear () {\n for (const key of this.keys()) {\n this.delete(key)\n }\n }\n\n get size () {\n return Object.keys(this.wrappedObject).length\n }\n}\n\n/**\n * Create a map with two partitions: a and b.\n * The set with bKeys determines which keys/values are read/written to map b,\n * all other values are read/written to map a\n *\n * For example:\n *\n * const a = new Map()\n * const b = new Map()\n * const p = new PartitionedMap(a, b, new Set(['x', 'y']))\n *\n * In this case, values `x` and `y` are read/written to map `b`,\n * all other values are read/written to map `a`.\n */\nexport class PartitionedMap {\n /**\n * @param {Map} a\n * @param {Map} b\n * @param {Set} bKeys\n */\n constructor (a, b, bKeys) {\n this.a = a\n this.b = b\n this.bKeys = bKeys\n\n this[Symbol.iterator] = this.entries\n }\n\n get (key) {\n return this.bKeys.has(key)\n ? this.b.get(key)\n : this.a.get(key)\n }\n\n set (key, value) {\n if (this.bKeys.has(key)) {\n this.b.set(key, value)\n } else {\n this.a.set(key, value)\n }\n return this\n }\n\n has (key) {\n return this.b.has(key) || this.a.has(key)\n }\n\n keys () {\n return new Set([\n ...this.a.keys(),\n ...this.b.keys()\n ])[Symbol.iterator]()\n }\n\n entries () {\n return mapIterator(this.keys(), key => [key, this.get(key)])\n }\n\n forEach (callback) {\n for (const key of this.keys()) {\n callback(this.get(key), key, this)\n }\n }\n\n delete (key) {\n return this.bKeys.has(key)\n ? this.b.delete(key)\n : this.a.delete(key)\n }\n\n clear () {\n this.a.clear()\n this.b.clear()\n }\n\n get size () {\n return [...this.keys()].length\n }\n}\n\n/**\n * Create a new iterator that maps over the provided iterator, applying a mapping function to each item\n */\nfunction mapIterator (it, callback) {\n return {\n next: () => {\n const n = it.next()\n return (n.done)\n ? n\n : {\n value: callback(n.value),\n done: false\n }\n }\n }\n}\n\n/**\n * Creates an empty map, or whatever your platform's polyfill is.\n *\n * @returns an empty Map or Map like object.\n */\nexport function createEmptyMap () {\n return new Map()\n}\n\n/**\n * Creates a Map from the given object.\n *\n * @param { Map | { [key: string]: unknown } | undefined } mapOrObject\n * @returns\n */\nexport function createMap (mapOrObject) {\n if (!mapOrObject) {\n return createEmptyMap()\n }\n if (isMap(mapOrObject)) {\n return mapOrObject\n }\n if (isObject(mapOrObject)) {\n return new ObjectWrappingMap(mapOrObject)\n }\n\n throw new Error('createMap can create maps from objects or Maps')\n}\n\n/**\n * Unwraps a map into an object.\n *\n * @param {Map} map\n * @returns { [key: string]: unknown }\n */\nexport function toObject (map) {\n if (map instanceof ObjectWrappingMap) {\n return map.wrappedObject\n }\n const object = {}\n for (const key of map.keys()) {\n const value = map.get(key)\n setSafeProperty(object, key, value)\n }\n return object\n}\n\n/**\n * Copies the contents of key-value pairs from each `objects` in to `map`.\n *\n * Object is `objects` can be a `Map` or object.\n *\n * This is the `Map` analog to `Object.assign`.\n */\nexport function assign (map, ...objects) {\n for (const args of objects) {\n if (!args) {\n continue\n }\n if (isMap(args)) {\n for (const key of args.keys()) {\n map.set(key, args.get(key))\n }\n } else if (isObject(args)) {\n for (const key of Object.keys(args)) {\n map.set(key, args[key])\n }\n }\n }\n return map\n}\n","// type checks for all known types\n//\n// note that:\n//\n// - check by duck-typing on a property like `isUnit`, instead of checking instanceof.\n// instanceof cannot be used because that would not allow to pass data from\n// one instance of math.js to another since each has it's own instance of Unit.\n// - check the `isUnit` property via the constructor, so there will be no\n// matches for \"fake\" instances like plain objects with a property `isUnit`.\n// That is important for security reasons.\n// - It must not be possible to override the type checks used internally,\n// for security reasons, so these functions are not exposed in the expression\n// parser.\n\nimport { ObjectWrappingMap } from './map.js'\n\nexport function isNumber (x) {\n return typeof x === 'number'\n}\n\nexport function isBigNumber (x) {\n if (\n !x || typeof x !== 'object' ||\n typeof x.constructor !== 'function'\n ) {\n return false\n }\n\n if (\n x.isBigNumber === true &&\n typeof x.constructor.prototype === 'object' &&\n x.constructor.prototype.isBigNumber === true\n ) {\n return true\n }\n\n if (\n typeof x.constructor.isDecimal === 'function' &&\n x.constructor.isDecimal(x) === true\n ) {\n return true\n }\n\n return false\n}\n\nexport function isBigInt (x) {\n return typeof x === 'bigint'\n}\n\nexport function isComplex (x) {\n return (x && typeof x === 'object' && Object.getPrototypeOf(x).isComplex === true) || false\n}\n\nexport function isFraction (x) {\n return (x && typeof x === 'object' && Object.getPrototypeOf(x).isFraction === true) || false\n}\n\nexport function isUnit (x) {\n return (x && x.constructor.prototype.isUnit === true) || false\n}\n\nexport function isString (x) {\n return typeof x === 'string'\n}\n\nexport const isArray = Array.isArray\n\nexport function isMatrix (x) {\n return (x && x.constructor.prototype.isMatrix === true) || false\n}\n\n/**\n * Test whether a value is a collection: an Array or Matrix\n * @param {*} x\n * @returns {boolean} isCollection\n */\nexport function isCollection (x) {\n return Array.isArray(x) || isMatrix(x)\n}\n\nexport function isDenseMatrix (x) {\n return (x && x.isDenseMatrix && x.constructor.prototype.isMatrix === true) || false\n}\n\nexport function isSparseMatrix (x) {\n return (x && x.isSparseMatrix && x.constructor.prototype.isMatrix === true) || false\n}\n\nexport function isRange (x) {\n return (x && x.constructor.prototype.isRange === true) || false\n}\n\nexport function isIndex (x) {\n return (x && x.constructor.prototype.isIndex === true) || false\n}\n\nexport function isBoolean (x) {\n return typeof x === 'boolean'\n}\n\nexport function isResultSet (x) {\n return (x && x.constructor.prototype.isResultSet === true) || false\n}\n\nexport function isHelp (x) {\n return (x && x.constructor.prototype.isHelp === true) || false\n}\n\nexport function isFunction (x) {\n return typeof x === 'function'\n}\n\nexport function isDate (x) {\n return x instanceof Date\n}\n\nexport function isRegExp (x) {\n return x instanceof RegExp\n}\n\nexport function isObject (x) {\n return !!(x &&\n typeof x === 'object' &&\n x.constructor === Object &&\n !isComplex(x) &&\n !isFraction(x))\n}\n\n/**\n * Returns `true` if the passed object appears to be a Map (i.e. duck typing).\n *\n * Methods looked for are `get`, `set`, `keys` and `has`.\n *\n * @param {Map | object} object\n * @returns\n */\nexport function isMap (object) {\n // We can use the fast instanceof, or a slower duck typing check.\n // The duck typing method needs to cover enough methods to not be confused with DenseMatrix.\n if (!object) {\n return false\n }\n return object instanceof Map ||\n object instanceof ObjectWrappingMap ||\n (\n typeof object.set === 'function' &&\n typeof object.get === 'function' &&\n typeof object.keys === 'function' &&\n typeof object.has === 'function'\n )\n}\n\nexport function isPartitionedMap (object) {\n return isMap(object) && isMap(object.a) && isMap(object.b)\n}\n\nexport function isObjectWrappingMap (object) {\n return isMap(object) && isObject(object.wrappedObject)\n}\n\nexport function isNull (x) {\n return x === null\n}\n\nexport function isUndefined (x) {\n return x === undefined\n}\n\nexport function isAccessorNode (x) {\n return (x && x.isAccessorNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isArrayNode (x) {\n return (x && x.isArrayNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isAssignmentNode (x) {\n return (x && x.isAssignmentNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isBlockNode (x) {\n return (x && x.isBlockNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isConditionalNode (x) {\n return (x && x.isConditionalNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isConstantNode (x) {\n return (x && x.isConstantNode === true && x.constructor.prototype.isNode === true) || false\n}\n\n/* Very specialized: returns true for those nodes which in the numerator of\n a fraction means that the division in that fraction has precedence over implicit\n multiplication, e.g. -2/3 x parses as (-2/3) x and 3/4 x parses as (3/4) x but\n 6!/8 x parses as 6! / (8x). It is located here because it is shared between\n parse.js and OperatorNode.js (for parsing and printing, respectively).\n\n This should *not* be exported from mathjs, unlike most of the tests here.\n Its name does not start with 'is' to prevent utils/snapshot.js from thinking\n it should be exported.\n*/\nexport function rule2Node (node) {\n return isConstantNode(node) ||\n (isOperatorNode(node) &&\n node.args.length === 1 &&\n isConstantNode(node.args[0]) &&\n '-+~'.includes(node.op))\n}\n\nexport function isFunctionAssignmentNode (x) {\n return (x && x.isFunctionAssignmentNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isFunctionNode (x) {\n return (x && x.isFunctionNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isIndexNode (x) {\n return (x && x.isIndexNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isNode (x) {\n return (x && x.isNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isObjectNode (x) {\n return (x && x.isObjectNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isOperatorNode (x) {\n return (x && x.isOperatorNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isParenthesisNode (x) {\n return (x && x.isParenthesisNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isRangeNode (x) {\n return (x && x.isRangeNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isRelationalNode (x) {\n return (x && x.isRelationalNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isSymbolNode (x) {\n return (x && x.isSymbolNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isChain (x) {\n return (x && x.constructor.prototype.isChain === true) || false\n}\n\nexport function typeOf (x) {\n const t = typeof x\n\n if (t === 'object') {\n if (x === null) return 'null'\n if (isBigNumber(x)) return 'BigNumber' // Special: weird mashup with Decimal\n if (x.constructor && x.constructor.name) return x.constructor.name\n\n return 'Object' // just in case\n }\n\n return t // can be 'string', 'number', 'boolean', 'function', 'bigint', ...\n}\n","import { isBigNumber, isObject } from './is.js'\n\n/**\n * Clone an object\n *\n * clone(x)\n *\n * Can clone any primitive type, array, and object.\n * If x has a function clone, this function will be invoked to clone the object.\n *\n * @param {*} x\n * @return {*} clone\n */\nexport function clone (x) {\n const type = typeof x\n\n // immutable primitive types\n if (type === 'number' || type === 'bigint' || type === 'string' || type === 'boolean' ||\n x === null || x === undefined) {\n return x\n }\n\n // use clone function of the object when available\n if (typeof x.clone === 'function') {\n return x.clone()\n }\n\n // array\n if (Array.isArray(x)) {\n return x.map(function (value) {\n return clone(value)\n })\n }\n\n if (x instanceof Date) return new Date(x.valueOf())\n if (isBigNumber(x)) return x // bignumbers are immutable\n\n // object\n if (isObject(x)) {\n return mapObject(x, clone)\n }\n\n throw new TypeError(`Cannot clone: unknown type of value (value: ${x})`)\n}\n\n/**\n * Apply map to all properties of an object\n * @param {Object} object\n * @param {function} callback\n * @return {Object} Returns a copy of the object with mapped properties\n */\nexport function mapObject (object, callback) {\n const clone = {}\n\n for (const key in object) {\n if (hasOwnProperty(object, key)) {\n clone[key] = callback(object[key])\n }\n }\n\n return clone\n}\n\n/**\n * Extend object a with the properties of object b\n * @param {Object} a\n * @param {Object} b\n * @return {Object} a\n */\nexport function extend (a, b) {\n for (const prop in b) {\n if (hasOwnProperty(b, prop)) {\n a[prop] = b[prop]\n }\n }\n return a\n}\n\n/**\n * Deep extend an object a with the properties of object b\n * @param {Object} a\n * @param {Object} b\n * @returns {Object}\n */\nexport function deepExtend (a, b) {\n // TODO: add support for Arrays to deepExtend\n if (Array.isArray(b)) {\n throw new TypeError('Arrays are not supported by deepExtend')\n }\n\n for (const prop in b) {\n // We check against prop not being in Object.prototype or Function.prototype\n // to prevent polluting for example Object.__proto__.\n if (hasOwnProperty(b, prop) && !(prop in Object.prototype) && !(prop in Function.prototype)) {\n if (b[prop] && b[prop].constructor === Object) {\n if (a[prop] === undefined) {\n a[prop] = {}\n }\n if (a[prop] && a[prop].constructor === Object) {\n deepExtend(a[prop], b[prop])\n } else {\n a[prop] = b[prop]\n }\n } else if (Array.isArray(b[prop])) {\n throw new TypeError('Arrays are not supported by deepExtend')\n } else {\n a[prop] = b[prop]\n }\n }\n }\n return a\n}\n\n/**\n * Deep test equality of all fields in two pairs of arrays or objects.\n * Compares values and functions strictly (ie. 2 is not the same as '2').\n * @param {Array | Object} a\n * @param {Array | Object} b\n * @returns {boolean}\n */\nexport function deepStrictEqual (a, b) {\n let prop, i, len\n if (Array.isArray(a)) {\n if (!Array.isArray(b)) {\n return false\n }\n\n if (a.length !== b.length) {\n return false\n }\n\n for (i = 0, len = a.length; i < len; i++) {\n if (!deepStrictEqual(a[i], b[i])) {\n return false\n }\n }\n return true\n } else if (typeof a === 'function') {\n return (a === b)\n } else if (a instanceof Object) {\n if (Array.isArray(b) || !(b instanceof Object)) {\n return false\n }\n\n for (prop in a) {\n // noinspection JSUnfilteredForInLoop\n if (!(prop in b) || !deepStrictEqual(a[prop], b[prop])) {\n return false\n }\n }\n for (prop in b) {\n // noinspection JSUnfilteredForInLoop\n if (!(prop in a)) {\n return false\n }\n }\n return true\n } else {\n return (a === b)\n }\n}\n\n/**\n * Recursively flatten a nested object.\n * @param {Object} nestedObject\n * @return {Object} Returns the flattened object\n */\nexport function deepFlatten (nestedObject) {\n const flattenedObject = {}\n\n _deepFlatten(nestedObject, flattenedObject)\n\n return flattenedObject\n}\n\n// helper function used by deepFlatten\nfunction _deepFlatten (nestedObject, flattenedObject) {\n for (const prop in nestedObject) {\n if (hasOwnProperty(nestedObject, prop)) {\n const value = nestedObject[prop]\n if (typeof value === 'object' && value !== null) {\n _deepFlatten(value, flattenedObject)\n } else {\n flattenedObject[prop] = value\n }\n }\n }\n}\n\n/**\n * Test whether the current JavaScript engine supports Object.defineProperty\n * @returns {boolean} returns true if supported\n */\nexport function canDefineProperty () {\n // test needed for broken IE8 implementation\n try {\n if (Object.defineProperty) {\n Object.defineProperty({}, 'x', { get: function () { return null } })\n return true\n }\n } catch (e) {}\n\n return false\n}\n\n/**\n * Attach a lazy loading property to a constant.\n * The given function `fn` is called once when the property is first requested.\n *\n * @param {Object} object Object where to add the property\n * @param {string} prop Property name\n * @param {Function} valueResolver Function returning the property value. Called\n * without arguments.\n */\nexport function lazy (object, prop, valueResolver) {\n let _uninitialized = true\n let _value\n\n Object.defineProperty(object, prop, {\n get: function () {\n if (_uninitialized) {\n _value = valueResolver()\n _uninitialized = false\n }\n return _value\n },\n\n set: function (value) {\n _value = value\n _uninitialized = false\n },\n\n configurable: true,\n enumerable: true\n })\n}\n\n/**\n * Traverse a path into an object.\n * When a namespace is missing, it will be created\n * @param {Object} object\n * @param {string | string[]} path A dot separated string like 'name.space'\n * @return {Object} Returns the object at the end of the path\n */\nexport function traverse (object, path) {\n if (path && typeof path === 'string') {\n return traverse(object, path.split('.'))\n }\n\n let obj = object\n\n if (path) {\n for (let i = 0; i < path.length; i++) {\n const key = path[i]\n if (!(key in obj)) {\n obj[key] = {}\n }\n obj = obj[key]\n }\n }\n\n return obj\n}\n\n/**\n * A safe hasOwnProperty\n * @param {Object} object\n * @param {string} property\n */\nexport function hasOwnProperty (object, property) {\n return object && Object.hasOwnProperty.call(object, property)\n}\n\n/**\n * Test whether an object is a factory. a factory has fields:\n *\n * - factory: function (type: Object, config: Object, load: function, typed: function [, math: Object]) (required)\n * - name: string (optional)\n * - path: string A dot separated path (optional)\n * - math: boolean If true (false by default), the math namespace is passed\n * as fifth argument of the factory function\n *\n * @param {*} object\n * @returns {boolean}\n */\nexport function isLegacyFactory (object) {\n return object && typeof object.factory === 'function'\n}\n\n/**\n * Get a nested property from an object\n * @param {Object} object\n * @param {string | string[]} path\n * @returns {Object}\n */\nexport function get (object, path) {\n if (typeof path === 'string') {\n if (isPath(path)) {\n return get(object, path.split('.'))\n } else {\n return object[path]\n }\n }\n\n let child = object\n\n for (let i = 0; i < path.length; i++) {\n const key = path[i]\n child = child ? child[key] : undefined\n }\n\n return child\n}\n\n/**\n * Set a nested property in an object\n * Mutates the object itself\n * If the path doesn't exist, it will be created\n * @param {Object} object\n * @param {string | string[]} path\n * @param {*} value\n * @returns {Object}\n */\nexport function set (object, path, value) {\n if (typeof path === 'string') {\n if (isPath(path)) {\n return set(object, path.split('.'), value)\n } else {\n object[path] = value\n return object\n }\n }\n\n let child = object\n for (let i = 0; i < path.length - 1; i++) {\n const key = path[i]\n if (child[key] === undefined) {\n child[key] = {}\n }\n child = child[key]\n }\n\n if (path.length > 0) {\n const lastKey = path[path.length - 1]\n child[lastKey] = value\n }\n\n return object\n}\n\n/**\n * Create an object composed of the picked object properties\n * @param {Object} object\n * @param {string[]} properties\n * @param {function} [transform] Optional value to transform a value when picking it\n * @return {Object}\n */\nexport function pick (object, properties, transform) {\n const copy = {}\n\n for (let i = 0; i < properties.length; i++) {\n const key = properties[i]\n const value = get(object, key)\n if (value !== undefined) {\n set(copy, key, transform ? transform(value, key) : value)\n }\n }\n\n return copy\n}\n\n/**\n * Shallow version of pick, creating an object composed of the picked object properties\n * but not for nested properties\n * @param {Object} object\n * @param {string[]} properties\n * @return {Object}\n */\nexport function pickShallow (object, properties) {\n const copy = {}\n\n for (let i = 0; i < properties.length; i++) {\n const key = properties[i]\n const value = object[key]\n if (value !== undefined) {\n copy[key] = value\n }\n }\n\n return copy\n}\n\n// helper function to test whether a string contains a path like 'user.name'\nfunction isPath (str) {\n return str.includes('.')\n}\n","import { pickShallow } from './object.js'\n\n/**\n * Create a factory function, which can be used to inject dependencies.\n *\n * The created functions are memoized, a consecutive call of the factory\n * with the exact same inputs will return the same function instance.\n * The memoized cache is exposed on `factory.cache` and can be cleared\n * if needed.\n *\n * Example:\n *\n * const name = 'log'\n * const dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n *\n * export const createLog = factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\n * // ... create the function log here and return it\n * }\n *\n * @param {string} name Name of the function to be created\n * @param {string[]} dependencies The names of all required dependencies\n * @param {function} create Callback function called with an object with all dependencies\n * @param {Object} [meta] Optional object with meta information that will be attached\n * to the created factory function as property `meta`.\n * @returns {function}\n */\nexport function factory (name, dependencies, create, meta) {\n function assertAndCreate (scope) {\n // we only pass the requested dependencies to the factory function\n // to prevent functions to rely on dependencies that are not explicitly\n // requested.\n const deps = pickShallow(scope, dependencies.map(stripOptionalNotation))\n\n assertDependencies(name, dependencies, scope)\n\n return create(deps)\n }\n\n assertAndCreate.isFactory = true\n assertAndCreate.fn = name\n assertAndCreate.dependencies = dependencies.slice().sort()\n if (meta) {\n assertAndCreate.meta = meta\n }\n\n return assertAndCreate\n}\n\n/**\n * Sort all factories such that when loading in order, the dependencies are resolved.\n *\n * @param {Array} factories\n * @returns {Array} Returns a new array with the sorted factories.\n */\nexport function sortFactories (factories) {\n const factoriesByName = {}\n\n factories.forEach(factory => {\n factoriesByName[factory.fn] = factory\n })\n\n function containsDependency (factory, dependency) {\n // TODO: detect circular references\n if (isFactory(factory)) {\n if (factory.dependencies.includes(dependency.fn || dependency.name)) {\n return true\n }\n\n if (factory.dependencies.some(d => containsDependency(factoriesByName[d], dependency))) {\n return true\n }\n }\n\n return false\n }\n\n const sorted = []\n\n function addFactory (factory) {\n let index = 0\n while (index < sorted.length && !containsDependency(sorted[index], factory)) {\n index++\n }\n\n sorted.splice(index, 0, factory)\n }\n\n // sort regular factory functions\n factories\n .filter(isFactory)\n .forEach(addFactory)\n\n // sort legacy factory functions AFTER the regular factory functions\n factories\n .filter(factory => !isFactory(factory))\n .forEach(addFactory)\n\n return sorted\n}\n\n// TODO: comment or cleanup if unused in the end\nexport function create (factories, scope = {}) {\n sortFactories(factories)\n .forEach(factory => factory(scope))\n\n return scope\n}\n\n/**\n * Test whether an object is a factory. This is the case when it has\n * properties name, dependencies, and a function create.\n * @param {*} obj\n * @returns {boolean}\n */\nexport function isFactory (obj) {\n return typeof obj === 'function' &&\n typeof obj.fn === 'string' &&\n Array.isArray(obj.dependencies)\n}\n\n/**\n * Assert that all dependencies of a list with dependencies are available in the provided scope.\n *\n * Will throw an exception when there are dependencies missing.\n *\n * @param {string} name Name for the function to be created. Used to generate a useful error message\n * @param {string[]} dependencies\n * @param {Object} scope\n */\nexport function assertDependencies (name, dependencies, scope) {\n const allDefined = dependencies\n .filter(dependency => !isOptionalDependency(dependency)) // filter optionals\n .every(dependency => scope[dependency] !== undefined)\n\n if (!allDefined) {\n const missingDependencies = dependencies.filter(dependency => scope[dependency] === undefined)\n\n // TODO: create a custom error class for this, a MathjsError or something like that\n throw new Error(`Cannot create function \"${name}\", ` +\n `some dependencies are missing: ${missingDependencies.map(d => `\"${d}\"`).join(', ')}.`)\n }\n}\n\nexport function isOptionalDependency (dependency) {\n return dependency && dependency[0] === '?'\n}\n\nexport function stripOptionalNotation (dependency) {\n return dependency && dependency[0] === '?'\n ? dependency.slice(1)\n : dependency\n}\n","import { isBigNumber, isNumber, isObject } from './is.js'\n\n/**\n * @typedef {{sign: '+' | '-' | '', coefficients: number[], exponent: number}} SplitValue\n */\n\n/**\n * Check if a number is integer\n * @param {number | boolean} value\n * @return {boolean} isInteger\n */\nexport function isInteger (value) {\n if (typeof value === 'boolean') {\n return true\n }\n\n return isFinite(value)\n ? (value === Math.round(value))\n : false\n}\n\n/**\n * Check if a string contains an integer\n * @param {string} str\n * @return {boolean} isInteger\n */\nexport function isIntegerStr (str) {\n // regex matching strings like \"123\" and \"-123\"\n return /^-?\\d+$/.test(str)\n}\n\n/**\n * Ensure the number type is compatible with the provided value.\n * If not, return 'number' instead.\n *\n * For example:\n *\n * safeNumberType('2.3', { number: 'bigint', numberFallback: 'number' })\n *\n * will return 'number' and not 'bigint' because trying to create a bigint with\n * value 2.3 would throw an exception.\n *\n * @param {string} numberStr\n * @param {{\n * number: 'number' | 'BigNumber' | 'bigint' | 'Fraction'\n * numberFallback: 'number' | 'BigNumber'\n * }} config\n * @returns {'number' | 'BigNumber' | 'bigint' | 'Fraction'}\n */\nexport function safeNumberType (numberStr, config) {\n if (config.number === 'bigint' && !isIntegerStr(numberStr)) {\n return config.numberFallback\n }\n\n return config.number\n}\n\n/**\n * Calculate the sign of a number\n * @param {number} x\n * @returns {number}\n */\nexport const sign = Math.sign || function (x) {\n if (x > 0) {\n return 1\n } else if (x < 0) {\n return -1\n } else {\n return 0\n }\n}\n\n/**\n * Calculate the base-2 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\nexport const log2 = Math.log2 || function log2 (x) {\n return Math.log(x) / Math.LN2\n}\n\n/**\n * Calculate the base-10 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\nexport const log10 = Math.log10 || function log10 (x) {\n return Math.log(x) / Math.LN10\n}\n\n/**\n * Calculate the natural logarithm of a number + 1\n * @param {number} x\n * @returns {number}\n */\nexport const log1p = Math.log1p || function (x) {\n return Math.log(x + 1)\n}\n\n/**\n * Calculate cubic root for a number\n *\n * Code from es6-shim.js:\n * https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1564-L1577\n *\n * @param {number} x\n * @returns {number} Returns the cubic root of x\n */\nexport const cbrt = Math.cbrt || function cbrt (x) {\n if (x === 0) {\n return x\n }\n\n const negate = x < 0\n let result\n if (negate) {\n x = -x\n }\n\n if (isFinite(x)) {\n result = Math.exp(Math.log(x) / 3)\n // from https://en.wikipedia.org/wiki/Cube_root#Numerical_methods\n result = (x / (result * result) + (2 * result)) / 3\n } else {\n result = x\n }\n\n return negate ? -result : result\n}\n\n/**\n * Calculates exponentiation minus 1\n * @param {number} x\n * @return {number} res\n */\nexport const expm1 = Math.expm1 || function expm1 (x) {\n return (x >= 2e-4 || x <= -2e-4)\n ? Math.exp(x) - 1\n : x + x * x / 2 + x * x * x / 6\n}\n\n/**\n * Formats a number in a given base\n * @param {number} n\n * @param {number} base\n * @param {number} size\n * @returns {string}\n */\nfunction formatNumberToBase (n, base, size) {\n const prefixes = { 2: '0b', 8: '0o', 16: '0x' }\n const prefix = prefixes[base]\n let suffix = ''\n if (size) {\n if (size < 1) {\n throw new Error('size must be in greater than 0')\n }\n if (!isInteger(size)) {\n throw new Error('size must be an integer')\n }\n if (n > 2 ** (size - 1) - 1 || n < -(2 ** (size - 1))) {\n throw new Error(`Value must be in range [-2^${size - 1}, 2^${size - 1}-1]`)\n }\n if (!isInteger(n)) {\n throw new Error('Value must be an integer')\n }\n if (n < 0) {\n n = n + 2 ** size\n }\n suffix = `i${size}`\n }\n let sign = ''\n if (n < 0) {\n n = -n\n sign = '-'\n }\n return `${sign}${prefix}${n.toString(base)}${suffix}`\n}\n\n/**\n * Convert a number to a formatted string representation.\n *\n * Syntax:\n *\n * format(value)\n * format(value, options)\n * format(value, precision)\n * format(value, fn)\n *\n * Where:\n *\n * {number} value The value to be formatted\n * {Object} options An object with formatting options. Available options:\n * {string} notation\n * Number notation. Choose from:\n * 'fixed' Always use regular number notation.\n * For example '123.40' and '14000000'\n * 'exponential' Always use exponential notation.\n * For example '1.234e+2' and '1.4e+7'\n * 'engineering' Always use engineering notation.\n * For example '123.4e+0' and '14.0e+6'\n * 'auto' (default) Regular number notation for numbers\n * having an absolute value between\n * `lowerExp` and `upperExp` bounds, and\n * uses exponential notation elsewhere.\n * Lower bound is included, upper bound\n * is excluded.\n * For example '123.4' and '1.4e7'.\n * 'bin', 'oct, or\n * 'hex' Format the number using binary, octal,\n * or hexadecimal notation.\n * For example '0b1101' and '0x10fe'.\n * {number} wordSize The word size in bits to use for formatting\n * in binary, octal, or hexadecimal notation.\n * To be used only with 'bin', 'oct', or 'hex'\n * values for 'notation' option. When this option\n * is defined the value is formatted as a signed\n * twos complement integer of the given word size\n * and the size suffix is appended to the output.\n * For example\n * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'.\n * Default value is undefined.\n * {number} precision A number between 0 and 16 to round\n * the digits of the number.\n * In case of notations 'exponential',\n * 'engineering', and 'auto',\n * `precision` defines the total\n * number of significant digits returned.\n * In case of notation 'fixed',\n * `precision` defines the number of\n * significant digits after the decimal\n * point.\n * `precision` is undefined by default,\n * not rounding any digits.\n * {number} lowerExp Exponent determining the lower boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `-3`.\n * {number} upperExp Exponent determining the upper boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `5`.\n * {Function} fn A custom formatting function. Can be used to override the\n * built-in notations. Function `fn` is called with `value` as\n * parameter and must return a string. Is useful for example to\n * format all values inside a matrix in a particular way.\n *\n * Examples:\n *\n * format(6.4) // '6.4'\n * format(1240000) // '1.24e6'\n * format(1/3) // '0.3333333333333333'\n * format(1/3, 3) // '0.333'\n * format(21385, 2) // '21000'\n * format(12.071, {notation: 'fixed'}) // '12'\n * format(2.3, {notation: 'fixed', precision: 2}) // '2.30'\n * format(52.8, {notation: 'exponential'}) // '5.28e+1'\n * format(12345678, {notation: 'engineering'}) // '12.345678e+6'\n *\n * @param {number} value\n * @param {Object | Function | number} [options]\n * @return {string} str The formatted value\n */\nexport function format (value, options) {\n if (typeof options === 'function') {\n // handle format(value, fn)\n return options(value)\n }\n\n // handle special cases\n if (value === Infinity) {\n return 'Infinity'\n } else if (value === -Infinity) {\n return '-Infinity'\n } else if (isNaN(value)) {\n return 'NaN'\n }\n\n const { notation, precision, wordSize } = normalizeFormatOptions(options)\n\n // handle the various notations\n switch (notation) {\n case 'fixed':\n return toFixed(value, precision)\n\n case 'exponential':\n return toExponential(value, precision)\n\n case 'engineering':\n return toEngineering(value, precision)\n\n case 'bin':\n return formatNumberToBase(value, 2, wordSize)\n\n case 'oct':\n return formatNumberToBase(value, 8, wordSize)\n\n case 'hex':\n return formatNumberToBase(value, 16, wordSize)\n\n case 'auto':\n // remove trailing zeros after the decimal point\n return toPrecision(value, precision, options)\n .replace(/((\\.\\d*?)(0+))($|e)/, function () {\n const digits = arguments[2]\n const e = arguments[4]\n return (digits !== '.') ? digits + e : e\n })\n\n default:\n throw new Error('Unknown notation \"' + notation + '\". ' +\n 'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.')\n }\n}\n\n/**\n * Normalize format options into an object:\n * {\n * notation: string,\n * precision: number | undefined,\n * wordSize: number | undefined\n * }\n */\nexport function normalizeFormatOptions (options) {\n // default values for options\n let notation = 'auto'\n let precision\n let wordSize\n\n if (options !== undefined) {\n if (isNumber(options)) {\n precision = options\n } else if (isBigNumber(options)) {\n precision = options.toNumber()\n } else if (isObject(options)) {\n if (options.precision !== undefined) {\n precision = _toNumberOrThrow(options.precision, () => {\n throw new Error('Option \"precision\" must be a number or BigNumber')\n })\n }\n\n if (options.wordSize !== undefined) {\n wordSize = _toNumberOrThrow(options.wordSize, () => {\n throw new Error('Option \"wordSize\" must be a number or BigNumber')\n })\n }\n\n if (options.notation) {\n notation = options.notation\n }\n } else {\n throw new Error('Unsupported type of options, number, BigNumber, or object expected')\n }\n }\n\n return { notation, precision, wordSize }\n}\n\n/**\n * Split a number into sign, coefficients, and exponent\n * @param {number | string} value\n * @return {SplitValue}\n * Returns an object containing sign, coefficients, and exponent\n */\nexport function splitNumber (value) {\n // parse the input value\n const match = String(value).toLowerCase().match(/^(-?)(\\d+\\.?\\d*)(e([+-]?\\d+))?$/)\n if (!match) {\n throw new SyntaxError('Invalid number ' + value)\n }\n\n const sign = match[1]\n const digits = match[2]\n let exponent = parseFloat(match[4] || '0')\n\n const dot = digits.indexOf('.')\n exponent += (dot !== -1) ? (dot - 1) : (digits.length - 1)\n\n const coefficients = digits\n .replace('.', '') // remove the dot (must be removed before removing leading zeros)\n .replace(/^0*/, function (zeros) {\n // remove leading zeros, add their count to the exponent\n exponent -= zeros.length\n return ''\n })\n .replace(/0*$/, '') // remove trailing zeros\n .split('')\n .map(function (d) {\n return parseInt(d)\n })\n\n if (coefficients.length === 0) {\n coefficients.push(0)\n exponent++\n }\n\n return { sign, coefficients, exponent }\n}\n\n/**\n * Format a number in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3'\n * @param {number | string} value\n * @param {number} [precision] Optional number of significant figures to return.\n */\nexport function toEngineering (value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value)\n }\n\n const split = splitNumber(value)\n const rounded = roundDigits(split, precision)\n\n const e = rounded.exponent\n const c = rounded.coefficients\n\n // find nearest lower multiple of 3 for exponent\n const newExp = e % 3 === 0 ? e : (e < 0 ? (e - 3) - (e % 3) : e - (e % 3))\n\n if (isNumber(precision)) {\n // add zeroes to give correct sig figs\n while (precision > c.length || (e - newExp) + 1 > c.length) {\n c.push(0)\n }\n } else {\n // concatenate coefficients with necessary zeros\n // add zeros if necessary (for example: 1e+8 -> 100e+6)\n const missingZeros = Math.abs(e - newExp) - (c.length - 1)\n for (let i = 0; i < missingZeros; i++) {\n c.push(0)\n }\n }\n\n // find difference in exponents\n let expDiff = Math.abs(e - newExp)\n let decimalIdx = 1\n\n // push decimal index over by expDiff times\n while (expDiff > 0) {\n decimalIdx++\n expDiff--\n }\n\n // if all coefficient values are zero after the decimal point and precision is unset, don't add a decimal value.\n // otherwise concat with the rest of the coefficients\n const decimals = c.slice(decimalIdx).join('')\n const decimalVal = ((isNumber(precision) && decimals.length) || decimals.match(/[1-9]/)) ? ('.' + decimals) : ''\n\n const str = c.slice(0, decimalIdx).join('') +\n decimalVal +\n 'e' + (e >= 0 ? '+' : '') + newExp.toString()\n return rounded.sign + str\n}\n\n/**\n * Format a number with fixed notation.\n * @param {number | string} value\n * @param {number} [precision=undefined] Optional number of decimals after the\n * decimal point. null by default.\n */\nexport function toFixed (value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value)\n }\n\n const splitValue = splitNumber(value)\n const rounded = (typeof precision === 'number')\n ? roundDigits(splitValue, splitValue.exponent + 1 + precision)\n : splitValue\n let c = rounded.coefficients\n let p = rounded.exponent + 1 // exponent may have changed\n\n // append zeros if needed\n const pp = p + (precision || 0)\n if (c.length < pp) {\n c = c.concat(zeros(pp - c.length))\n }\n\n // prepend zeros if needed\n if (p < 0) {\n c = zeros(-p + 1).concat(c)\n p = 1\n }\n\n // insert a dot if needed\n if (p < c.length) {\n c.splice(p, 0, (p === 0) ? '0.' : '.')\n }\n\n return rounded.sign + c.join('')\n}\n\n/**\n * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3'\n * @param {number | string} value\n * @param {number} [precision] Number of digits in formatted output.\n * If not provided, the maximum available digits\n * is used.\n */\nexport function toExponential (value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value)\n }\n\n // round if needed, else create a clone\n const split = splitNumber(value)\n const rounded = precision ? roundDigits(split, precision) : split\n let c = rounded.coefficients\n const e = rounded.exponent\n\n // append zeros if needed\n if (c.length < precision) {\n c = c.concat(zeros(precision - c.length))\n }\n\n // format as `C.CCCe+EEE` or `C.CCCe-EEE`\n const first = c.shift()\n return rounded.sign + first + (c.length > 0 ? ('.' + c.join('')) : '') +\n 'e' + (e >= 0 ? '+' : '') + e\n}\n\n/**\n * Format a number with a certain precision\n * @param {number | string} value\n * @param {number} [precision=undefined] Optional number of digits.\n * @param {{lowerExp: number | undefined, upperExp: number | undefined}} [options]\n * By default:\n * lowerExp = -3 (incl)\n * upper = +5 (excl)\n * @return {string}\n */\nexport function toPrecision (value, precision, options) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value)\n }\n\n // determine lower and upper bound for exponential notation.\n const lowerExp = _toNumberOrDefault(options?.lowerExp, -3)\n const upperExp = _toNumberOrDefault(options?.upperExp, 5)\n\n const split = splitNumber(value)\n const rounded = precision ? roundDigits(split, precision) : split\n if (rounded.exponent < lowerExp || rounded.exponent >= upperExp) {\n // exponential notation\n return toExponential(value, precision)\n } else {\n let c = rounded.coefficients\n const e = rounded.exponent\n\n // append trailing zeros\n if (c.length < precision) {\n c = c.concat(zeros(precision - c.length))\n }\n\n // append trailing zeros\n // TODO: simplify the next statement\n c = c.concat(zeros(e - c.length + 1 +\n (c.length < precision ? precision - c.length : 0)))\n\n // prepend zeros\n c = zeros(-e).concat(c)\n\n const dot = e > 0 ? e : 0\n if (dot < c.length - 1) {\n c.splice(dot + 1, 0, '.')\n }\n\n return rounded.sign + c.join('')\n }\n}\n\n/**\n * Round the number of digits of a number *\n * @param {SplitValue} split A value split with .splitNumber(value)\n * @param {number} precision A positive integer\n * @return {SplitValue}\n * Returns an object containing sign, coefficients, and exponent\n * with rounded digits\n */\nexport function roundDigits (split, precision) {\n // create a clone\n const rounded = {\n sign: split.sign,\n coefficients: split.coefficients,\n exponent: split.exponent\n }\n const c = rounded.coefficients\n\n // prepend zeros if needed\n while (precision <= 0) {\n c.unshift(0)\n rounded.exponent++\n precision++\n }\n\n if (c.length > precision) {\n const removed = c.splice(precision, c.length - precision)\n\n if (removed[0] >= 5) {\n let i = precision - 1\n c[i]++\n while (c[i] === 10) {\n c.pop()\n if (i === 0) {\n c.unshift(0)\n rounded.exponent++\n i++\n }\n i--\n c[i]++\n }\n }\n }\n\n return rounded\n}\n\n/**\n * Create an array filled with zeros.\n * @param {number} length\n * @return {Array}\n */\nfunction zeros (length) {\n const arr = []\n for (let i = 0; i < length; i++) {\n arr.push(0)\n }\n return arr\n}\n\n/**\n * Count the number of significant digits of a number.\n *\n * For example:\n * 2.34 returns 3\n * 0.0034 returns 2\n * 120.5e+30 returns 4\n *\n * @param {number} value\n * @return {number} digits Number of significant digits\n */\nexport function digits (value) {\n return value\n .toExponential()\n .replace(/e.*$/, '') // remove exponential notation\n .replace(/^0\\.?0*|\\./, '') // remove decimal point and leading zeros\n .length\n}\n\n/**\n * Minimum number added to one that makes the result different than one\n */\nexport const DBL_EPSILON = Number.EPSILON || 2.2204460492503130808472633361816E-16\n\n/**\n * Compares two floating point numbers.\n * @param {number} a - First value to compare\n * @param {number} b - Second value to compare\n * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0.\n * @param {number} [absTol=1e-12] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0.\n * @return {boolean} whether the two numbers are nearly equal\n *\n * @throws {Error} If `relTol` is less than or equal to 0.\n * @throws {Error} If `absTol` is less than 0.\n *\n * @example\n * nearlyEqual(1.000000001, 1.0, 1e-8); // true\n * nearlyEqual(1.000000002, 1.0, 0); // false\n * nearlyEqual(1.0, 1.009, undefined, 0.01); // true\n * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true\n */\nexport function nearlyEqual (a, b, relTol = 1e-8, absTol = 0) {\n if (relTol <= 0) {\n throw new Error('Relative tolerance must be greater than 0')\n }\n\n if (absTol < 0) {\n throw new Error('Absolute tolerance must be at least 0')\n }\n\n // NaN\n if (isNaN(a) || isNaN(b)) {\n return false\n }\n\n if (!isFinite(a) || !isFinite(b)) {\n return a === b\n }\n\n if (a === b) {\n return true\n }\n\n // abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)\n return Math.abs(a - b) <= Math.max(relTol * Math.max(Math.abs(a), Math.abs(b)), absTol)\n}\n\n/**\n * Calculate the hyperbolic arccos of a number\n * @param {number} x\n * @return {number}\n */\nexport const acosh = Math.acosh || function (x) {\n return Math.log(Math.sqrt(x * x - 1) + x)\n}\n\nexport const asinh = Math.asinh || function (x) {\n return Math.log(Math.sqrt(x * x + 1) + x)\n}\n\n/**\n * Calculate the hyperbolic arctangent of a number\n * @param {number} x\n * @return {number}\n */\nexport const atanh = Math.atanh || function (x) {\n return Math.log((1 + x) / (1 - x)) / 2\n}\n\n/**\n * Calculate the hyperbolic cosine of a number\n * @param {number} x\n * @returns {number}\n */\nexport const cosh = Math.cosh || function (x) {\n return (Math.exp(x) + Math.exp(-x)) / 2\n}\n\n/**\n * Calculate the hyperbolic sine of a number\n * @param {number} x\n * @returns {number}\n */\nexport const sinh = Math.sinh || function (x) {\n return (Math.exp(x) - Math.exp(-x)) / 2\n}\n\n/**\n * Calculate the hyperbolic tangent of a number\n * @param {number} x\n * @returns {number}\n */\nexport const tanh = Math.tanh || function (x) {\n const e = Math.exp(2 * x)\n return (e - 1) / (e + 1)\n}\n\n/**\n * Returns a value with the magnitude of x and the sign of y.\n * @param {number} x\n * @param {number} y\n * @returns {number}\n */\nexport function copysign (x, y) {\n const signx = x > 0 ? true : x < 0 ? false : 1 / x === Infinity\n const signy = y > 0 ? true : y < 0 ? false : 1 / y === Infinity\n return signx ^ signy ? -x : x\n}\n\nfunction _toNumberOrThrow (value, onError) {\n if (isNumber(value)) {\n return value\n } else if (isBigNumber(value)) {\n return value.toNumber()\n } else {\n onError()\n }\n}\n\nfunction _toNumberOrDefault (value, defaultValue) {\n if (isNumber(value)) {\n return value\n } else if (isBigNumber(value)) {\n return value.toNumber()\n } else {\n return defaultValue\n }\n}\n","/**\n * Create a typed-function which checks the types of the arguments and\n * can match them against multiple provided signatures. The typed-function\n * automatically converts inputs in order to find a matching signature.\n * Typed functions throw informative errors in case of wrong input arguments.\n *\n * See the library [typed-function](https://github.com/josdejong/typed-function)\n * for detailed documentation.\n *\n * Syntax:\n *\n * math.typed(name, signatures) : function\n * math.typed(signatures) : function\n *\n * Examples:\n *\n * // create a typed function with multiple types per argument (type union)\n * const fn2 = typed({\n * 'number | boolean': function (b) {\n * return 'b is a number or boolean'\n * },\n * 'string, number | boolean': function (a, b) {\n * return 'a is a string, b is a number or boolean'\n * }\n * })\n *\n * // create a typed function with an any type argument\n * const log = typed({\n * 'string, any': function (event, data) {\n * console.log('event: ' + event + ', data: ' + JSON.stringify(data))\n * }\n * })\n *\n * @param {string} [name] Optional name for the typed-function\n * @param {Object} signatures Object with one or multiple function signatures\n * @returns {function} The created typed-function.\n */\n\nimport typedFunction from 'typed-function'\nimport { factory } from '../../utils/factory.js'\nimport {\n isAccessorNode,\n isArray,\n isArrayNode,\n isAssignmentNode,\n isBigInt,\n isBigNumber,\n isBlockNode,\n isBoolean,\n isChain,\n isCollection,\n isComplex,\n isConditionalNode,\n isConstantNode,\n isDate,\n isDenseMatrix,\n isFraction,\n isFunction,\n isFunctionAssignmentNode,\n isFunctionNode,\n isHelp,\n isIndex,\n isIndexNode,\n isMap,\n isMatrix,\n isNode,\n isNull,\n isNumber,\n isObject,\n isObjectNode,\n isOperatorNode,\n isParenthesisNode,\n isRange,\n isRangeNode,\n isRegExp,\n isRelationalNode,\n isResultSet,\n isSparseMatrix,\n isString,\n isSymbolNode,\n isUndefined,\n isUnit\n} from '../../utils/is.js'\nimport { digits } from '../../utils/number.js'\n\n// returns a new instance of typed-function\nlet _createTyped = function () {\n // initially, return the original instance of typed-function\n // consecutively, return a new instance from typed.create.\n _createTyped = typedFunction.create\n return typedFunction\n}\n\nconst dependencies = [\n '?BigNumber',\n '?Complex',\n '?DenseMatrix',\n '?Fraction'\n]\n\n/**\n * Factory function for creating a new typed instance\n * @param {Object} dependencies Object with data types like Complex and BigNumber\n * @returns {Function}\n */\nexport const createTyped = /* #__PURE__ */ factory('typed', dependencies, function createTyped ({ BigNumber, Complex, DenseMatrix, Fraction }) {\n // TODO: typed-function must be able to silently ignore signatures with unknown data types\n\n // get a new instance of typed-function\n const typed = _createTyped()\n\n // define all types. The order of the types determines in which order function\n // arguments are type-checked (so for performance it's important to put the\n // most used types first).\n typed.clear()\n typed.addTypes([\n { name: 'number', test: isNumber },\n { name: 'Complex', test: isComplex },\n { name: 'BigNumber', test: isBigNumber },\n { name: 'bigint', test: isBigInt },\n { name: 'Fraction', test: isFraction },\n { name: 'Unit', test: isUnit },\n // The following type matches a valid variable name, i.e., an alphanumeric\n // string starting with an alphabetic character. It is used (at least)\n // in the definition of the derivative() function, as the argument telling\n // what to differentiate over must (currently) be a variable.\n // TODO: deprecate the identifier type (it's not used anymore, see https://github.com/josdejong/mathjs/issues/3253)\n {\n name: 'identifier',\n test: s => isString && /^\\p{L}[\\p{L}\\d]*$/u.test(s)\n },\n { name: 'string', test: isString },\n { name: 'Chain', test: isChain },\n { name: 'Array', test: isArray },\n { name: 'Matrix', test: isMatrix },\n { name: 'DenseMatrix', test: isDenseMatrix },\n { name: 'SparseMatrix', test: isSparseMatrix },\n { name: 'Range', test: isRange },\n { name: 'Index', test: isIndex },\n { name: 'boolean', test: isBoolean },\n { name: 'ResultSet', test: isResultSet },\n { name: 'Help', test: isHelp },\n { name: 'function', test: isFunction },\n { name: 'Date', test: isDate },\n { name: 'RegExp', test: isRegExp },\n { name: 'null', test: isNull },\n { name: 'undefined', test: isUndefined },\n\n { name: 'AccessorNode', test: isAccessorNode },\n { name: 'ArrayNode', test: isArrayNode },\n { name: 'AssignmentNode', test: isAssignmentNode },\n { name: 'BlockNode', test: isBlockNode },\n { name: 'ConditionalNode', test: isConditionalNode },\n { name: 'ConstantNode', test: isConstantNode },\n { name: 'FunctionNode', test: isFunctionNode },\n { name: 'FunctionAssignmentNode', test: isFunctionAssignmentNode },\n { name: 'IndexNode', test: isIndexNode },\n { name: 'Node', test: isNode },\n { name: 'ObjectNode', test: isObjectNode },\n { name: 'OperatorNode', test: isOperatorNode },\n { name: 'ParenthesisNode', test: isParenthesisNode },\n { name: 'RangeNode', test: isRangeNode },\n { name: 'RelationalNode', test: isRelationalNode },\n { name: 'SymbolNode', test: isSymbolNode },\n\n { name: 'Map', test: isMap },\n { name: 'Object', test: isObject } // order 'Object' last, it matches on other classes too\n ])\n\n typed.addConversions([\n {\n from: 'number',\n to: 'BigNumber',\n convert: function (x) {\n if (!BigNumber) {\n throwNoBignumber(x)\n }\n\n // note: conversion from number to BigNumber can fail if x has >15 digits\n if (digits(x) > 15) {\n throw new TypeError('Cannot implicitly convert a number with >15 significant digits to BigNumber ' +\n '(value: ' + x + '). ' +\n 'Use function bignumber(x) to convert to BigNumber.')\n }\n return new BigNumber(x)\n }\n }, {\n from: 'number',\n to: 'Complex',\n convert: function (x) {\n if (!Complex) {\n throwNoComplex(x)\n }\n\n return new Complex(x, 0)\n }\n }, {\n from: 'BigNumber',\n to: 'Complex',\n convert: function (x) {\n if (!Complex) {\n throwNoComplex(x)\n }\n\n return new Complex(x.toNumber(), 0)\n }\n }, {\n from: 'bigint',\n to: 'number',\n convert: function (x) {\n if (x > Number.MAX_SAFE_INTEGER) {\n throw new TypeError('Cannot implicitly convert bigint to number: ' +\n 'value exceeds the max safe integer value (value: ' + x + ')')\n }\n\n return Number(x)\n }\n }, {\n from: 'bigint',\n to: 'BigNumber',\n convert: function (x) {\n if (!BigNumber) {\n throwNoBignumber(x)\n }\n\n return new BigNumber(x.toString())\n }\n }, {\n from: 'bigint',\n to: 'Fraction',\n convert: function (x) {\n if (!Fraction) {\n throwNoFraction(x)\n }\n\n return new Fraction(x.toString())\n }\n }, {\n from: 'Fraction',\n to: 'BigNumber',\n convert: function (x) {\n throw new TypeError('Cannot implicitly convert a Fraction to BigNumber or vice versa. ' +\n 'Use function bignumber(x) to convert to BigNumber or fraction(x) to convert to Fraction.')\n }\n }, {\n from: 'Fraction',\n to: 'Complex',\n convert: function (x) {\n if (!Complex) {\n throwNoComplex(x)\n }\n\n return new Complex(x.valueOf(), 0)\n }\n }, {\n from: 'number',\n to: 'Fraction',\n convert: function (x) {\n if (!Fraction) {\n throwNoFraction(x)\n }\n\n const f = new Fraction(x)\n if (f.valueOf() !== x) {\n throw new TypeError('Cannot implicitly convert a number to a Fraction when there will be a loss of precision ' +\n '(value: ' + x + '). ' +\n 'Use function fraction(x) to convert to Fraction.')\n }\n return f\n }\n }, {\n // FIXME: add conversion from Fraction to number, for example for `sqrt(fraction(1,3))`\n // from: 'Fraction',\n // to: 'number',\n // convert: function (x) {\n // return x.valueOf()\n // }\n // }, {\n from: 'string',\n to: 'number',\n convert: function (x) {\n const n = Number(x)\n if (isNaN(n)) {\n throw new Error('Cannot convert \"' + x + '\" to a number')\n }\n return n\n }\n }, {\n from: 'string',\n to: 'BigNumber',\n convert: function (x) {\n if (!BigNumber) {\n throwNoBignumber(x)\n }\n\n try {\n return new BigNumber(x)\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to BigNumber')\n }\n }\n }, {\n from: 'string',\n to: 'bigint',\n convert: function (x) {\n try {\n return BigInt(x)\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to BigInt')\n }\n }\n }, {\n from: 'string',\n to: 'Fraction',\n convert: function (x) {\n if (!Fraction) {\n throwNoFraction(x)\n }\n\n try {\n return new Fraction(x)\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to Fraction')\n }\n }\n }, {\n from: 'string',\n to: 'Complex',\n convert: function (x) {\n if (!Complex) {\n throwNoComplex(x)\n }\n\n try {\n return new Complex(x)\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to Complex')\n }\n }\n }, {\n from: 'boolean',\n to: 'number',\n convert: function (x) {\n return +x\n }\n }, {\n from: 'boolean',\n to: 'BigNumber',\n convert: function (x) {\n if (!BigNumber) {\n throwNoBignumber(x)\n }\n\n return new BigNumber(+x)\n }\n }, {\n from: 'boolean',\n to: 'bigint',\n convert: function (x) {\n return BigInt(+x)\n }\n }, {\n from: 'boolean',\n to: 'Fraction',\n convert: function (x) {\n if (!Fraction) {\n throwNoFraction(x)\n }\n\n return new Fraction(+x)\n }\n }, {\n from: 'boolean',\n to: 'string',\n convert: function (x) {\n return String(x)\n }\n }, {\n from: 'Array',\n to: 'Matrix',\n convert: function (array) {\n if (!DenseMatrix) {\n throwNoMatrix()\n }\n\n return new DenseMatrix(array)\n }\n }, {\n from: 'Matrix',\n to: 'Array',\n convert: function (matrix) {\n return matrix.valueOf()\n }\n }\n ])\n\n // Provide a suggestion on how to call a function elementwise\n // This was added primarily as guidance for the v10 -> v11 transition,\n // and could potentially be removed in the future if it no longer seems\n // to be helpful.\n typed.onMismatch = (name, args, signatures) => {\n const usualError = typed.createError(name, args, signatures)\n if (['wrongType', 'mismatch'].includes(usualError.data.category) &&\n args.length === 1 && isCollection(args[0]) &&\n // check if the function can be unary:\n signatures.some(sig => !sig.params.includes(','))) {\n const err = new TypeError(\n `Function '${name}' doesn't apply to matrices. To call it ` +\n `elementwise on a matrix 'M', try 'map(M, ${name})'.`)\n err.data = usualError.data\n throw err\n }\n throw usualError\n }\n\n // Provide a suggestion on how to call a function elementwise\n // This was added primarily as guidance for the v10 -> v11 transition,\n // and could potentially be removed in the future if it no longer seems\n // to be helpful.\n typed.onMismatch = (name, args, signatures) => {\n const usualError = typed.createError(name, args, signatures)\n if (['wrongType', 'mismatch'].includes(usualError.data.category) &&\n args.length === 1 && isCollection(args[0]) &&\n // check if the function can be unary:\n signatures.some(sig => !sig.params.includes(','))) {\n const err = new TypeError(\n `Function '${name}' doesn't apply to matrices. To call it ` +\n `elementwise on a matrix 'M', try 'map(M, ${name})'.`)\n err.data = usualError.data\n throw err\n }\n throw usualError\n }\n\n return typed\n})\n\nfunction throwNoBignumber (x) {\n throw new Error(`Cannot convert value ${x} into a BigNumber: no class 'BigNumber' provided`)\n}\n\nfunction throwNoComplex (x) {\n throw new Error(`Cannot convert value ${x} into a Complex number: no class 'Complex' provided`)\n}\n\nfunction throwNoMatrix () {\n throw new Error('Cannot convert array into a Matrix: no class \\'DenseMatrix\\' provided')\n}\n\nfunction throwNoFraction (x) {\n throw new Error(`Cannot convert value ${x} into a Fraction, no class 'Fraction' provided.`)\n}\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'ResultSet'\nconst dependencies = []\n\nexport const createResultSet = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * A ResultSet contains a list or results\n * @class ResultSet\n * @param {Array} entries\n * @constructor ResultSet\n */\n function ResultSet (entries) {\n if (!(this instanceof ResultSet)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n this.entries = entries || []\n }\n\n /**\n * Attach type information\n */\n ResultSet.prototype.type = 'ResultSet'\n ResultSet.prototype.isResultSet = true\n\n /**\n * Returns the array with results hold by this ResultSet\n * @memberof ResultSet\n * @returns {Array} entries\n */\n ResultSet.prototype.valueOf = function () {\n return this.entries\n }\n\n /**\n * Returns the stringified results of the ResultSet\n * @memberof ResultSet\n * @returns {string} string\n */\n ResultSet.prototype.toString = function () {\n return '[' + this.entries.join(', ') + ']'\n }\n\n /**\n * Get a JSON representation of the ResultSet\n * @memberof ResultSet\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"ResultSet\", \"entries\": [...]}`\n */\n ResultSet.prototype.toJSON = function () {\n return {\n mathjs: 'ResultSet',\n entries: this.entries\n }\n }\n\n /**\n * Instantiate a ResultSet from a JSON object\n * @memberof ResultSet\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"ResultSet\", \"entries\": [...]}`\n * @return {ResultSet}\n */\n ResultSet.fromJSON = function (json) {\n return new ResultSet(json.entries)\n }\n\n return ResultSet\n}, { isClass: true })\n","/*!\r\n * decimal.js v10.4.3\r\n * An arbitrary-precision Decimal type for JavaScript.\r\n * https://github.com/MikeMcl/decimal.js\r\n * Copyright (c) 2022 Michael Mclaughlin \r\n * MIT Licence\r\n */\r\n\r\n\r\n// ----------------------------------- EDITABLE DEFAULTS ------------------------------------ //\r\n\r\n\r\n // The maximum exponent magnitude.\r\n // The limit on the value of `toExpNeg`, `toExpPos`, `minE` and `maxE`.\r\nvar EXP_LIMIT = 9e15, // 0 to 9e15\r\n\r\n // The limit on the value of `precision`, and on the value of the first argument to\r\n // `toDecimalPlaces`, `toExponential`, `toFixed`, `toPrecision` and `toSignificantDigits`.\r\n MAX_DIGITS = 1e9, // 0 to 1e9\r\n\r\n // Base conversion alphabet.\r\n NUMERALS = '0123456789abcdef',\r\n\r\n // The natural logarithm of 10 (1025 digits).\r\n LN10 = '2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058',\r\n\r\n // Pi (1025 digits).\r\n PI = '3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789',\r\n\r\n\r\n // The initial configuration properties of the Decimal constructor.\r\n DEFAULTS = {\r\n\r\n // These values must be integers within the stated ranges (inclusive).\r\n // Most of these values can be changed at run-time using the `Decimal.config` method.\r\n\r\n // The maximum number of significant digits of the result of a calculation or base conversion.\r\n // E.g. `Decimal.config({ precision: 20 });`\r\n precision: 20, // 1 to MAX_DIGITS\r\n\r\n // The rounding mode used when rounding to `precision`.\r\n //\r\n // ROUND_UP 0 Away from zero.\r\n // ROUND_DOWN 1 Towards zero.\r\n // ROUND_CEIL 2 Towards +Infinity.\r\n // ROUND_FLOOR 3 Towards -Infinity.\r\n // ROUND_HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // ROUND_HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // ROUND_HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // ROUND_HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // ROUND_HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n //\r\n // E.g.\r\n // `Decimal.rounding = 4;`\r\n // `Decimal.rounding = Decimal.ROUND_HALF_UP;`\r\n rounding: 4, // 0 to 8\r\n\r\n // The modulo mode used when calculating the modulus: a mod n.\r\n // The quotient (q = a / n) is calculated according to the corresponding rounding mode.\r\n // The remainder (r) is calculated as: r = a - n * q.\r\n //\r\n // UP 0 The remainder is positive if the dividend is negative, else is negative.\r\n // DOWN 1 The remainder has the same sign as the dividend (JavaScript %).\r\n // FLOOR 3 The remainder has the same sign as the divisor (Python %).\r\n // HALF_EVEN 6 The IEEE 754 remainder function.\r\n // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)). Always positive.\r\n //\r\n // Truncated division (1), floored division (3), the IEEE 754 remainder (6), and Euclidian\r\n // division (9) are commonly used for the modulus operation. The other rounding modes can also\r\n // be used, but they may not give useful results.\r\n modulo: 1, // 0 to 9\r\n\r\n // The exponent value at and beneath which `toString` returns exponential notation.\r\n // JavaScript numbers: -7\r\n toExpNeg: -7, // 0 to -EXP_LIMIT\r\n\r\n // The exponent value at and above which `toString` returns exponential notation.\r\n // JavaScript numbers: 21\r\n toExpPos: 21, // 0 to EXP_LIMIT\r\n\r\n // The minimum exponent value, beneath which underflow to zero occurs.\r\n // JavaScript numbers: -324 (5e-324)\r\n minE: -EXP_LIMIT, // -1 to -EXP_LIMIT\r\n\r\n // The maximum exponent value, above which overflow to Infinity occurs.\r\n // JavaScript numbers: 308 (1.7976931348623157e+308)\r\n maxE: EXP_LIMIT, // 1 to EXP_LIMIT\r\n\r\n // Whether to use cryptographically-secure random number generation, if available.\r\n crypto: false // true/false\r\n },\r\n\r\n\r\n// ----------------------------------- END OF EDITABLE DEFAULTS ------------------------------- //\r\n\r\n\r\n inexact, quadrant,\r\n external = true,\r\n\r\n decimalError = '[DecimalError] ',\r\n invalidArgument = decimalError + 'Invalid argument: ',\r\n precisionLimitExceeded = decimalError + 'Precision limit exceeded',\r\n cryptoUnavailable = decimalError + 'crypto unavailable',\r\n tag = '[object Decimal]',\r\n\r\n mathfloor = Math.floor,\r\n mathpow = Math.pow,\r\n\r\n isBinary = /^0b([01]+(\\.[01]*)?|\\.[01]+)(p[+-]?\\d+)?$/i,\r\n isHex = /^0x([0-9a-f]+(\\.[0-9a-f]*)?|\\.[0-9a-f]+)(p[+-]?\\d+)?$/i,\r\n isOctal = /^0o([0-7]+(\\.[0-7]*)?|\\.[0-7]+)(p[+-]?\\d+)?$/i,\r\n isDecimal = /^(\\d+(\\.\\d*)?|\\.\\d+)(e[+-]?\\d+)?$/i,\r\n\r\n BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_SAFE_INTEGER = 9007199254740991,\r\n\r\n LN10_PRECISION = LN10.length - 1,\r\n PI_PRECISION = PI.length - 1,\r\n\r\n // Decimal.prototype object\r\n P = { toStringTag: tag };\r\n\r\n\r\n// Decimal prototype methods\r\n\r\n\r\n/*\r\n * absoluteValue abs\r\n * ceil\r\n * clampedTo clamp\r\n * comparedTo cmp\r\n * cosine cos\r\n * cubeRoot cbrt\r\n * decimalPlaces dp\r\n * dividedBy div\r\n * dividedToIntegerBy divToInt\r\n * equals eq\r\n * floor\r\n * greaterThan gt\r\n * greaterThanOrEqualTo gte\r\n * hyperbolicCosine cosh\r\n * hyperbolicSine sinh\r\n * hyperbolicTangent tanh\r\n * inverseCosine acos\r\n * inverseHyperbolicCosine acosh\r\n * inverseHyperbolicSine asinh\r\n * inverseHyperbolicTangent atanh\r\n * inverseSine asin\r\n * inverseTangent atan\r\n * isFinite\r\n * isInteger isInt\r\n * isNaN\r\n * isNegative isNeg\r\n * isPositive isPos\r\n * isZero\r\n * lessThan lt\r\n * lessThanOrEqualTo lte\r\n * logarithm log\r\n * [maximum] [max]\r\n * [minimum] [min]\r\n * minus sub\r\n * modulo mod\r\n * naturalExponential exp\r\n * naturalLogarithm ln\r\n * negated neg\r\n * plus add\r\n * precision sd\r\n * round\r\n * sine sin\r\n * squareRoot sqrt\r\n * tangent tan\r\n * times mul\r\n * toBinary\r\n * toDecimalPlaces toDP\r\n * toExponential\r\n * toFixed\r\n * toFraction\r\n * toHexadecimal toHex\r\n * toNearest\r\n * toNumber\r\n * toOctal\r\n * toPower pow\r\n * toPrecision\r\n * toSignificantDigits toSD\r\n * toString\r\n * truncated trunc\r\n * valueOf toJSON\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the absolute value of this Decimal.\r\n *\r\n */\r\nP.absoluteValue = P.abs = function () {\r\n var x = new this.constructor(this);\r\n if (x.s < 0) x.s = 1;\r\n return finalise(x);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of positive Infinity.\r\n *\r\n */\r\nP.ceil = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 2);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal clamped to the range\r\n * delineated by `min` and `max`.\r\n *\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\nP.clampedTo = P.clamp = function (min, max) {\r\n var k,\r\n x = this,\r\n Ctor = x.constructor;\r\n min = new Ctor(min);\r\n max = new Ctor(max);\r\n if (!min.s || !max.s) return new Ctor(NaN);\r\n if (min.gt(max)) throw Error(invalidArgument + max);\r\n k = x.cmp(min);\r\n return k < 0 ? min : x.cmp(max) > 0 ? max : new Ctor(x);\r\n};\r\n\r\n\r\n/*\r\n * Return\r\n * 1 if the value of this Decimal is greater than the value of `y`,\r\n * -1 if the value of this Decimal is less than the value of `y`,\r\n * 0 if they have the same value,\r\n * NaN if the value of either Decimal is NaN.\r\n *\r\n */\r\nP.comparedTo = P.cmp = function (y) {\r\n var i, j, xdL, ydL,\r\n x = this,\r\n xd = x.d,\r\n yd = (y = new x.constructor(y)).d,\r\n xs = x.s,\r\n ys = y.s;\r\n\r\n // Either NaN or ±Infinity?\r\n if (!xd || !yd) {\r\n return !xs || !ys ? NaN : xs !== ys ? xs : xd === yd ? 0 : !xd ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Either zero?\r\n if (!xd[0] || !yd[0]) return xd[0] ? xs : yd[0] ? -ys : 0;\r\n\r\n // Signs differ?\r\n if (xs !== ys) return xs;\r\n\r\n // Compare exponents.\r\n if (x.e !== y.e) return x.e > y.e ^ xs < 0 ? 1 : -1;\r\n\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Compare digit by digit.\r\n for (i = 0, j = xdL < ydL ? xdL : ydL; i < j; ++i) {\r\n if (xd[i] !== yd[i]) return xd[i] > yd[i] ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Compare lengths.\r\n return xdL === ydL ? 0 : xdL > ydL ^ xs < 0 ? 1 : -1;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cosine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * cos(0) = 1\r\n * cos(-0) = 1\r\n * cos(Infinity) = NaN\r\n * cos(-Infinity) = NaN\r\n * cos(NaN) = NaN\r\n *\r\n */\r\nP.cosine = P.cos = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.d) return new Ctor(NaN);\r\n\r\n // cos(0) = cos(-0) = 1\r\n if (!x.d[0]) return new Ctor(1);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = cosine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 3 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n *\r\n * Return a new Decimal whose value is the cube root of the value of this Decimal, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * cbrt(0) = 0\r\n * cbrt(-0) = -0\r\n * cbrt(1) = 1\r\n * cbrt(-1) = -1\r\n * cbrt(N) = N\r\n * cbrt(-I) = -I\r\n * cbrt(I) = I\r\n *\r\n * Math.cbrt(x) = (x < 0 ? -Math.pow(-x, 1/3) : Math.pow(x, 1/3))\r\n *\r\n */\r\nP.cubeRoot = P.cbrt = function () {\r\n var e, m, n, r, rep, s, sd, t, t3, t3plusx,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = x.s * mathpow(x.s * x, 1 / 3);\r\n\r\n // Math.cbrt underflow/overflow?\r\n // Pass x to Math.pow as integer, then adjust the exponent of the result.\r\n if (!s || Math.abs(s) == 1 / 0) {\r\n n = digitsToString(x.d);\r\n e = x.e;\r\n\r\n // Adjust n exponent so it is a multiple of 3 away from x exponent.\r\n if (s = (e - n.length + 1) % 3) n += (s == 1 || s == -2 ? '0' : '00');\r\n s = mathpow(n, 1 / 3);\r\n\r\n // Rarely, e may be one less than the result exponent value.\r\n e = mathfloor((e + 1) / 3) - (e % 3 == (e < 0 ? -1 : 2));\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n r.s = x.s;\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Halley's method.\r\n // TODO? Compare Newton's method.\r\n for (;;) {\r\n t = r;\r\n t3 = t.times(t).times(t);\r\n t3plusx = t3.plus(x);\r\n r = divide(t3plusx.plus(x).times(t), t3plusx.plus(t3), sd + 2, 1);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or 4999\r\n // , i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n};\r\n\r\n\r\n/*\r\n * Return the number of decimal places of the value of this Decimal.\r\n *\r\n */\r\nP.decimalPlaces = P.dp = function () {\r\n var w,\r\n d = this.d,\r\n n = NaN;\r\n\r\n if (d) {\r\n w = d.length - 1;\r\n n = (w - mathfloor(this.e / LOG_BASE)) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n w = d[w];\r\n if (w) for (; w % 10 == 0; w /= 10) n--;\r\n if (n < 0) n = 0;\r\n }\r\n\r\n return n;\r\n};\r\n\r\n\r\n/*\r\n * n / 0 = I\r\n * n / N = N\r\n * n / I = 0\r\n * 0 / n = 0\r\n * 0 / 0 = N\r\n * 0 / N = N\r\n * 0 / I = 0\r\n * N / n = N\r\n * N / 0 = N\r\n * N / N = N\r\n * N / I = N\r\n * I / n = I\r\n * I / 0 = I\r\n * I / N = N\r\n * I / I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal divided by `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.dividedBy = P.div = function (y) {\r\n return divide(this, new this.constructor(y));\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the integer part of dividing the value of this Decimal\r\n * by the value of `y`, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.dividedToIntegerBy = P.divToInt = function (y) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n return finalise(divide(x, new Ctor(y), 0, 1, 1), Ctor.precision, Ctor.rounding);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is equal to the value of `y`, otherwise return false.\r\n *\r\n */\r\nP.equals = P.eq = function (y) {\r\n return this.cmp(y) === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of negative Infinity.\r\n *\r\n */\r\nP.floor = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 3);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than the value of `y`, otherwise return\r\n * false.\r\n *\r\n */\r\nP.greaterThan = P.gt = function (y) {\r\n return this.cmp(y) > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than or equal to the value of `y`,\r\n * otherwise return false.\r\n *\r\n */\r\nP.greaterThanOrEqualTo = P.gte = function (y) {\r\n var k = this.cmp(y);\r\n return k == 1 || k === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic cosine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [1, Infinity]\r\n *\r\n * cosh(x) = 1 + x^2/2! + x^4/4! + x^6/6! + ...\r\n *\r\n * cosh(0) = 1\r\n * cosh(-0) = 1\r\n * cosh(Infinity) = Infinity\r\n * cosh(-Infinity) = Infinity\r\n * cosh(NaN) = NaN\r\n *\r\n * x time taken (ms) result\r\n * 1000 9 9.8503555700852349694e+433\r\n * 10000 25 4.4034091128314607936e+4342\r\n * 100000 171 1.4033316802130615897e+43429\r\n * 1000000 3817 1.5166076984010437725e+434294\r\n * 10000000 abandoned after 2 minute wait\r\n *\r\n * TODO? Compare performance of cosh(x) = 0.5 * (exp(x) + exp(-x))\r\n *\r\n */\r\nP.hyperbolicCosine = P.cosh = function () {\r\n var k, n, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor,\r\n one = new Ctor(1);\r\n\r\n if (!x.isFinite()) return new Ctor(x.s ? 1 / 0 : NaN);\r\n if (x.isZero()) return one;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n // Argument reduction: cos(4x) = 1 - 8cos^2(x) + 8cos^4(x) + 1\r\n // i.e. cos(x) = 1 - cos^2(x/4)(8 - 8cos^2(x/4))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n // TODO? Estimation reused from cosine() and may not be optimal here.\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n n = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n n = '2.3283064365386962890625e-10';\r\n }\r\n\r\n x = taylorSeries(Ctor, 1, x.times(n), new Ctor(1), true);\r\n\r\n // Reverse argument reduction\r\n var cosh2_x,\r\n i = k,\r\n d8 = new Ctor(8);\r\n for (; i--;) {\r\n cosh2_x = x.times(x);\r\n x = one.minus(cosh2_x.times(d8.minus(cosh2_x.times(d8))));\r\n }\r\n\r\n return finalise(x, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic sine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * sinh(x) = x + x^3/3! + x^5/5! + x^7/7! + ...\r\n *\r\n * sinh(0) = 0\r\n * sinh(-0) = -0\r\n * sinh(Infinity) = Infinity\r\n * sinh(-Infinity) = -Infinity\r\n * sinh(NaN) = NaN\r\n *\r\n * x time taken (ms)\r\n * 10 2 ms\r\n * 100 5 ms\r\n * 1000 14 ms\r\n * 10000 82 ms\r\n * 100000 886 ms 1.4033316802130615897e+43429\r\n * 200000 2613 ms\r\n * 300000 5407 ms\r\n * 400000 8824 ms\r\n * 500000 13026 ms 8.7080643612718084129e+217146\r\n * 1000000 48543 ms\r\n *\r\n * TODO? Compare performance of sinh(x) = 0.5 * (exp(x) - exp(-x))\r\n *\r\n */\r\nP.hyperbolicSine = P.sinh = function () {\r\n var k, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n } else {\r\n\r\n // Alternative argument reduction: sinh(3x) = sinh(x)(3 + 4sinh^2(x))\r\n // i.e. sinh(x) = sinh(x/3)(3 + 4sinh^2(x/3))\r\n // 3 multiplications and 1 addition\r\n\r\n // Argument reduction: sinh(5x) = sinh(x)(5 + sinh^2(x)(20 + 16sinh^2(x)))\r\n // i.e. sinh(x) = sinh(x/5)(5 + sinh^2(x/5)(20 + 16sinh^2(x/5)))\r\n // 4 multiplications and 2 additions\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n\r\n // Reverse argument reduction\r\n var sinh2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sinh2_x = x.times(x);\r\n x = x.times(d5.plus(sinh2_x.times(d16.times(sinh2_x).plus(d20))));\r\n }\r\n }\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic tangent of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * tanh(x) = sinh(x) / cosh(x)\r\n *\r\n * tanh(0) = 0\r\n * tanh(-0) = -0\r\n * tanh(Infinity) = 1\r\n * tanh(-Infinity) = -1\r\n * tanh(NaN) = NaN\r\n *\r\n */\r\nP.hyperbolicTangent = P.tanh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(x.s);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 7;\r\n Ctor.rounding = 1;\r\n\r\n return divide(x.sinh(), x.cosh(), Ctor.precision = pr, Ctor.rounding = rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arccosine (inverse cosine) in radians of the value of\r\n * this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [0, pi]\r\n *\r\n * acos(x) = pi/2 - asin(x)\r\n *\r\n * acos(0) = pi/2\r\n * acos(-0) = pi/2\r\n * acos(1) = 0\r\n * acos(-1) = pi\r\n * acos(1/2) = pi/3\r\n * acos(-1/2) = 2*pi/3\r\n * acos(|x| > 1) = NaN\r\n * acos(NaN) = NaN\r\n *\r\n */\r\nP.inverseCosine = P.acos = function () {\r\n var halfPi,\r\n x = this,\r\n Ctor = x.constructor,\r\n k = x.abs().cmp(1),\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n return k === 0\r\n // |x| is 1\r\n ? x.isNeg() ? getPi(Ctor, pr, rm) : new Ctor(0)\r\n // |x| > 1 or x is NaN\r\n : new Ctor(NaN);\r\n }\r\n\r\n if (x.isZero()) return getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n // TODO? Special case acos(0.5) = pi/3 and acos(-0.5) = 2*pi/3\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.asin();\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return halfPi.minus(x);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [1, Infinity]\r\n * Range: [0, Infinity]\r\n *\r\n * acosh(x) = ln(x + sqrt(x^2 - 1))\r\n *\r\n * acosh(x < 1) = NaN\r\n * acosh(NaN) = NaN\r\n * acosh(Infinity) = Infinity\r\n * acosh(-Infinity) = NaN\r\n * acosh(0) = NaN\r\n * acosh(-0) = NaN\r\n * acosh(1) = 0\r\n * acosh(-1) = NaN\r\n *\r\n */\r\nP.inverseHyperbolicCosine = P.acosh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.lte(1)) return new Ctor(x.eq(1) ? 0 : NaN);\r\n if (!x.isFinite()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(Math.abs(x.e), x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).minus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * asinh(x) = ln(x + sqrt(x^2 + 1))\r\n *\r\n * asinh(NaN) = NaN\r\n * asinh(Infinity) = Infinity\r\n * asinh(-Infinity) = -Infinity\r\n * asinh(0) = 0\r\n * asinh(-0) = -0\r\n *\r\n */\r\nP.inverseHyperbolicSine = P.asinh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 2 * Math.max(Math.abs(x.e), x.sd()) + 6;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).plus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * atanh(x) = 0.5 * ln((1 + x) / (1 - x))\r\n *\r\n * atanh(|x| > 1) = NaN\r\n * atanh(NaN) = NaN\r\n * atanh(Infinity) = NaN\r\n * atanh(-Infinity) = NaN\r\n * atanh(0) = 0\r\n * atanh(-0) = -0\r\n * atanh(1) = Infinity\r\n * atanh(-1) = -Infinity\r\n *\r\n */\r\nP.inverseHyperbolicTangent = P.atanh = function () {\r\n var pr, rm, wpr, xsd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.e >= 0) return new Ctor(x.abs().eq(1) ? x.s / 0 : x.isZero() ? x : NaN);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n xsd = x.sd();\r\n\r\n if (Math.max(xsd, pr) < 2 * -x.e - 1) return finalise(new Ctor(x), pr, rm, true);\r\n\r\n Ctor.precision = wpr = xsd - x.e;\r\n\r\n x = divide(x.plus(1), new Ctor(1).minus(x), wpr + pr, 1);\r\n\r\n Ctor.precision = pr + 4;\r\n Ctor.rounding = 1;\r\n\r\n x = x.ln();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(0.5);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arcsine (inverse sine) in radians of the value of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * asin(x) = 2*atan(x/(1 + sqrt(1 - x^2)))\r\n *\r\n * asin(0) = 0\r\n * asin(-0) = -0\r\n * asin(1/2) = pi/6\r\n * asin(-1/2) = -pi/6\r\n * asin(1) = pi/2\r\n * asin(-1) = -pi/2\r\n * asin(|x| > 1) = NaN\r\n * asin(NaN) = NaN\r\n *\r\n * TODO? Compare performance of Taylor series.\r\n *\r\n */\r\nP.inverseSine = P.asin = function () {\r\n var halfPi, k,\r\n pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n k = x.abs().cmp(1);\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n\r\n // |x| is 1\r\n if (k === 0) {\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n halfPi.s = x.s;\r\n return halfPi;\r\n }\r\n\r\n // |x| > 1 or x is NaN\r\n return new Ctor(NaN);\r\n }\r\n\r\n // TODO? Special case asin(1/2) = pi/6 and asin(-1/2) = -pi/6\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.div(new Ctor(1).minus(x.times(x)).sqrt().plus(1)).atan();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(2);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent (inverse tangent) in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n *\r\n * atan(0) = 0\r\n * atan(-0) = -0\r\n * atan(1) = pi/4\r\n * atan(-1) = -pi/4\r\n * atan(Infinity) = pi/2\r\n * atan(-Infinity) = -pi/2\r\n * atan(NaN) = NaN\r\n *\r\n */\r\nP.inverseTangent = P.atan = function () {\r\n var i, j, k, n, px, t, r, wpr, x2,\r\n x = this,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (!x.isFinite()) {\r\n if (!x.s) return new Ctor(NaN);\r\n if (pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.5);\r\n r.s = x.s;\r\n return r;\r\n }\r\n } else if (x.isZero()) {\r\n return new Ctor(x);\r\n } else if (x.abs().eq(1) && pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.25);\r\n r.s = x.s;\r\n return r;\r\n }\r\n\r\n Ctor.precision = wpr = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n // TODO? if (x >= 1 && pr <= PI_PRECISION) atan(x) = halfPi * x.s - atan(1 / x);\r\n\r\n // Argument reduction\r\n // Ensure |x| < 0.42\r\n // atan(x) = 2 * atan(x / (1 + sqrt(1 + x^2)))\r\n\r\n k = Math.min(28, wpr / LOG_BASE + 2 | 0);\r\n\r\n for (i = k; i; --i) x = x.div(x.times(x).plus(1).sqrt().plus(1));\r\n\r\n external = false;\r\n\r\n j = Math.ceil(wpr / LOG_BASE);\r\n n = 1;\r\n x2 = x.times(x);\r\n r = new Ctor(x);\r\n px = x;\r\n\r\n // atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n for (; i !== -1;) {\r\n px = px.times(x2);\r\n t = r.minus(px.div(n += 2));\r\n\r\n px = px.times(x2);\r\n r = t.plus(px.div(n += 2));\r\n\r\n if (r.d[j] !== void 0) for (i = j; r.d[i] === t.d[i] && i--;);\r\n }\r\n\r\n if (k) r = r.times(2 << (k - 1));\r\n\r\n external = true;\r\n\r\n return finalise(r, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is a finite number, otherwise return false.\r\n *\r\n */\r\nP.isFinite = function () {\r\n return !!this.d;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is an integer, otherwise return false.\r\n *\r\n */\r\nP.isInteger = P.isInt = function () {\r\n return !!this.d && mathfloor(this.e / LOG_BASE) > this.d.length - 2;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is NaN, otherwise return false.\r\n *\r\n */\r\nP.isNaN = function () {\r\n return !this.s;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is negative, otherwise return false.\r\n *\r\n */\r\nP.isNegative = P.isNeg = function () {\r\n return this.s < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is positive, otherwise return false.\r\n *\r\n */\r\nP.isPositive = P.isPos = function () {\r\n return this.s > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is 0 or -0, otherwise return false.\r\n *\r\n */\r\nP.isZero = function () {\r\n return !!this.d && this.d[0] === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThan = P.lt = function (y) {\r\n return this.cmp(y) < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than or equal to `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThanOrEqualTo = P.lte = function (y) {\r\n return this.cmp(y) < 1;\r\n};\r\n\r\n\r\n/*\r\n * Return the logarithm of the value of this Decimal to the specified base, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * If no base is specified, return log[10](arg).\r\n *\r\n * log[base](arg) = ln(arg) / ln(base)\r\n *\r\n * The result will always be correctly rounded if the base of the log is 10, and 'almost always'\r\n * otherwise:\r\n *\r\n * Depending on the rounding mode, the result may be incorrectly rounded if the first fifteen\r\n * rounding digits are [49]99999999999999 or [50]00000000000000. In that case, the maximum error\r\n * between the result and the correctly rounded result will be one ulp (unit in the last place).\r\n *\r\n * log[-b](a) = NaN\r\n * log[0](a) = NaN\r\n * log[1](a) = NaN\r\n * log[NaN](a) = NaN\r\n * log[Infinity](a) = NaN\r\n * log[b](0) = -Infinity\r\n * log[b](-0) = -Infinity\r\n * log[b](-a) = NaN\r\n * log[b](1) = 0\r\n * log[b](Infinity) = Infinity\r\n * log[b](NaN) = NaN\r\n *\r\n * [base] {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\nP.logarithm = P.log = function (base) {\r\n var isBase10, d, denominator, k, inf, num, sd, r,\r\n arg = this,\r\n Ctor = arg.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding,\r\n guard = 5;\r\n\r\n // Default base is 10.\r\n if (base == null) {\r\n base = new Ctor(10);\r\n isBase10 = true;\r\n } else {\r\n base = new Ctor(base);\r\n d = base.d;\r\n\r\n // Return NaN if base is negative, or non-finite, or is 0 or 1.\r\n if (base.s < 0 || !d || !d[0] || base.eq(1)) return new Ctor(NaN);\r\n\r\n isBase10 = base.eq(10);\r\n }\r\n\r\n d = arg.d;\r\n\r\n // Is arg negative, non-finite, 0 or 1?\r\n if (arg.s < 0 || !d || !d[0] || arg.eq(1)) {\r\n return new Ctor(d && !d[0] ? -1 / 0 : arg.s != 1 ? NaN : d ? 0 : 1 / 0);\r\n }\r\n\r\n // The result will have a non-terminating decimal expansion if base is 10 and arg is not an\r\n // integer power of 10.\r\n if (isBase10) {\r\n if (d.length > 1) {\r\n inf = true;\r\n } else {\r\n for (k = d[0]; k % 10 === 0;) k /= 10;\r\n inf = k !== 1;\r\n }\r\n }\r\n\r\n external = false;\r\n sd = pr + guard;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n\r\n // The result will have 5 rounding digits.\r\n r = divide(num, denominator, sd, 1);\r\n\r\n // If at a rounding boundary, i.e. the result's rounding digits are [49]9999 or [50]0000,\r\n // calculate 10 further digits.\r\n //\r\n // If the result is known to have an infinite decimal expansion, repeat this until it is clear\r\n // that the result is above or below the boundary. Otherwise, if after calculating the 10\r\n // further digits, the last 14 are nines, round up and assume the result is exact.\r\n // Also assume the result is exact if the last 14 are zero.\r\n //\r\n // Example of a result that will be incorrectly rounded:\r\n // log[1048576](4503599627370502) = 2.60000000000000009610279511444746...\r\n // The above result correctly rounded using ROUND_CEIL to 1 decimal place should be 2.7, but it\r\n // will be given as 2.6 as there are 15 zeros immediately after the requested decimal place, so\r\n // the exact result would be assumed to be 2.6, which rounded using ROUND_CEIL to 1 decimal\r\n // place is still 2.6.\r\n if (checkRoundingDigits(r.d, k = pr, rm)) {\r\n\r\n do {\r\n sd += 10;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n r = divide(num, denominator, sd, 1);\r\n\r\n if (!inf) {\r\n\r\n // Check for 14 nines from the 2nd rounding digit, as the first may be 4.\r\n if (+digitsToString(r.d).slice(k + 1, k + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n\r\n break;\r\n }\r\n } while (checkRoundingDigits(r.d, k += 10, rm));\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, pr, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the maximum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\nP.max = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'lt');\r\n};\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the minimum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\nP.min = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'gt');\r\n};\r\n */\r\n\r\n\r\n/*\r\n * n - 0 = n\r\n * n - N = N\r\n * n - I = -I\r\n * 0 - n = -n\r\n * 0 - 0 = 0\r\n * 0 - N = N\r\n * 0 - I = -I\r\n * N - n = N\r\n * N - 0 = N\r\n * N - N = N\r\n * N - I = N\r\n * I - n = I\r\n * I - 0 = I\r\n * I - N = N\r\n * I - I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal minus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.minus = P.sub = function (y) {\r\n var d, e, i, j, k, len, pr, rm, xd, xe, xLTy, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return y negated if x is finite and y is ±Infinity.\r\n else if (x.d) y.s = -y.s;\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with different signs.\r\n // Return NaN if both are ±Infinity with the same sign.\r\n else y = new Ctor(y.d || x.s !== y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.plus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return y negated if x is zero and y is non-zero.\r\n if (yd[0]) y.s = -y.s;\r\n\r\n // Return x if y is zero and x is non-zero.\r\n else if (xd[0]) y = new Ctor(x);\r\n\r\n // Return zero if both are zero.\r\n // From IEEE 754 (2008) 6.3: 0 - 0 = -0 - -0 = -0 when rounding to -Infinity.\r\n else return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n e = mathfloor(y.e / LOG_BASE);\r\n xe = mathfloor(x.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n k = xe - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (k) {\r\n xLTy = k < 0;\r\n\r\n if (xLTy) {\r\n d = xd;\r\n k = -k;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = xe;\r\n len = xd.length;\r\n }\r\n\r\n // Numbers with massively different exponents would result in a very high number of\r\n // zeros needing to be prepended, but this can be avoided while still ensuring correct\r\n // rounding by limiting the number of zeros to `Math.ceil(pr / LOG_BASE) + 2`.\r\n i = Math.max(Math.ceil(pr / LOG_BASE), len) + 2;\r\n\r\n if (k > i) {\r\n k = i;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents.\r\n d.reverse();\r\n for (i = k; i--;) d.push(0);\r\n d.reverse();\r\n\r\n // Base 1e7 exponents equal.\r\n } else {\r\n\r\n // Check digits to determine which is the bigger number.\r\n\r\n i = xd.length;\r\n len = yd.length;\r\n xLTy = i < len;\r\n if (xLTy) len = i;\r\n\r\n for (i = 0; i < len; i++) {\r\n if (xd[i] != yd[i]) {\r\n xLTy = xd[i] < yd[i];\r\n break;\r\n }\r\n }\r\n\r\n k = 0;\r\n }\r\n\r\n if (xLTy) {\r\n d = xd;\r\n xd = yd;\r\n yd = d;\r\n y.s = -y.s;\r\n }\r\n\r\n len = xd.length;\r\n\r\n // Append zeros to `xd` if shorter.\r\n // Don't add zeros to `yd` if shorter as subtraction only needs to start at `yd` length.\r\n for (i = yd.length - len; i > 0; --i) xd[len++] = 0;\r\n\r\n // Subtract yd from xd.\r\n for (i = yd.length; i > k;) {\r\n\r\n if (xd[--i] < yd[i]) {\r\n for (j = i; j && xd[--j] === 0;) xd[j] = BASE - 1;\r\n --xd[j];\r\n xd[i] += BASE;\r\n }\r\n\r\n xd[i] -= yd[i];\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] === 0;) xd.pop();\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xd[0] === 0; xd.shift()) --e;\r\n\r\n // Zero?\r\n if (!xd[0]) return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n};\r\n\r\n\r\n/*\r\n * n % 0 = N\r\n * n % N = N\r\n * n % I = n\r\n * 0 % n = 0\r\n * -0 % n = -0\r\n * 0 % 0 = N\r\n * 0 % N = N\r\n * 0 % I = 0\r\n * N % n = N\r\n * N % 0 = N\r\n * N % N = N\r\n * N % I = N\r\n * I % n = N\r\n * I % 0 = N\r\n * I % N = N\r\n * I % I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal modulo `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * The result depends on the modulo mode.\r\n *\r\n */\r\nP.modulo = P.mod = function (y) {\r\n var q,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // Return NaN if x is ±Infinity or NaN, or y is NaN or ±0.\r\n if (!x.d || !y.s || y.d && !y.d[0]) return new Ctor(NaN);\r\n\r\n // Return x if y is ±Infinity or x is ±0.\r\n if (!y.d || x.d && !x.d[0]) {\r\n return finalise(new Ctor(x), Ctor.precision, Ctor.rounding);\r\n }\r\n\r\n // Prevent rounding of intermediate calculations.\r\n external = false;\r\n\r\n if (Ctor.modulo == 9) {\r\n\r\n // Euclidian division: q = sign(y) * floor(x / abs(y))\r\n // result = x - q * y where 0 <= result < abs(y)\r\n q = divide(x, y.abs(), 0, 3, 1);\r\n q.s *= y.s;\r\n } else {\r\n q = divide(x, y, 0, Ctor.modulo, 1);\r\n }\r\n\r\n q = q.times(y);\r\n\r\n external = true;\r\n\r\n return x.minus(q);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of the value of this Decimal,\r\n * i.e. the base e raised to the power the value of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.naturalExponential = P.exp = function () {\r\n return naturalExponential(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of the value of this Decimal,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.naturalLogarithm = P.ln = function () {\r\n return naturalLogarithm(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal negated, i.e. as if multiplied by\r\n * -1.\r\n *\r\n */\r\nP.negated = P.neg = function () {\r\n var x = new this.constructor(this);\r\n x.s = -x.s;\r\n return finalise(x);\r\n};\r\n\r\n\r\n/*\r\n * n + 0 = n\r\n * n + N = N\r\n * n + I = I\r\n * 0 + n = n\r\n * 0 + 0 = 0\r\n * 0 + N = N\r\n * 0 + I = I\r\n * N + n = N\r\n * N + 0 = N\r\n * N + N = N\r\n * N + I = N\r\n * I + n = I\r\n * I + 0 = I\r\n * I + N = N\r\n * I + I = I\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal plus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.plus = P.add = function (y) {\r\n var carry, d, e, i, k, len, pr, rm, xd, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with the same sign.\r\n // Return NaN if both are ±Infinity with different signs.\r\n // Return y if x is finite and y is ±Infinity.\r\n else if (!x.d) y = new Ctor(y.d || x.s === y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.minus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return x if y is zero.\r\n // Return y if y is non-zero.\r\n if (!yd[0]) y = new Ctor(x);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n k = mathfloor(x.e / LOG_BASE);\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n i = k - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (i) {\r\n\r\n if (i < 0) {\r\n d = xd;\r\n i = -i;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = k;\r\n len = xd.length;\r\n }\r\n\r\n // Limit number of zeros prepended to max(ceil(pr / LOG_BASE), len) + 1.\r\n k = Math.ceil(pr / LOG_BASE);\r\n len = k > len ? k + 1 : len + 1;\r\n\r\n if (i > len) {\r\n i = len;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents. Note: Faster to use reverse then do unshifts.\r\n d.reverse();\r\n for (; i--;) d.push(0);\r\n d.reverse();\r\n }\r\n\r\n len = xd.length;\r\n i = yd.length;\r\n\r\n // If yd is longer than xd, swap xd and yd so xd points to the longer array.\r\n if (len - i < 0) {\r\n i = len;\r\n d = yd;\r\n yd = xd;\r\n xd = d;\r\n }\r\n\r\n // Only start adding at yd.length - 1 as the further digits of xd can be left as they are.\r\n for (carry = 0; i;) {\r\n carry = (xd[--i] = xd[i] + yd[i] + carry) / BASE | 0;\r\n xd[i] %= BASE;\r\n }\r\n\r\n if (carry) {\r\n xd.unshift(carry);\r\n ++e;\r\n }\r\n\r\n // Remove trailing zeros.\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n for (len = xd.length; xd[--len] == 0;) xd.pop();\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n};\r\n\r\n\r\n/*\r\n * Return the number of significant digits of the value of this Decimal.\r\n *\r\n * [z] {boolean|number} Whether to count integer-part trailing zeros: true, false, 1 or 0.\r\n *\r\n */\r\nP.precision = P.sd = function (z) {\r\n var k,\r\n x = this;\r\n\r\n if (z !== void 0 && z !== !!z && z !== 1 && z !== 0) throw Error(invalidArgument + z);\r\n\r\n if (x.d) {\r\n k = getPrecision(x.d);\r\n if (z && x.e + 1 > k) k = x.e + 1;\r\n } else {\r\n k = NaN;\r\n }\r\n\r\n return k;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number using\r\n * rounding mode `rounding`.\r\n *\r\n */\r\nP.round = function () {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n return finalise(new Ctor(x), x.e + 1, Ctor.rounding);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n *\r\n * sin(0) = 0\r\n * sin(-0) = -0\r\n * sin(Infinity) = NaN\r\n * sin(-Infinity) = NaN\r\n * sin(NaN) = NaN\r\n *\r\n */\r\nP.sine = P.sin = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = sine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant > 2 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * sqrt(-n) = N\r\n * sqrt(N) = N\r\n * sqrt(-I) = N\r\n * sqrt(I) = I\r\n * sqrt(0) = 0\r\n * sqrt(-0) = -0\r\n *\r\n */\r\nP.squareRoot = P.sqrt = function () {\r\n var m, n, sd, r, rep, t,\r\n x = this,\r\n d = x.d,\r\n e = x.e,\r\n s = x.s,\r\n Ctor = x.constructor;\r\n\r\n // Negative/NaN/Infinity/zero?\r\n if (s !== 1 || !d || !d[0]) {\r\n return new Ctor(!s || s < 0 && (!d || d[0]) ? NaN : d ? x : 1 / 0);\r\n }\r\n\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+x);\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = digitsToString(d);\r\n\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(n);\r\n e = mathfloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Newton-Raphson iteration.\r\n for (;;) {\r\n t = r;\r\n r = t.plus(divide(x, t, sd + 2, 1)).times(0.5);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or\r\n // 4999, i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the tangent of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * tan(0) = 0\r\n * tan(-0) = -0\r\n * tan(Infinity) = NaN\r\n * tan(-Infinity) = NaN\r\n * tan(NaN) = NaN\r\n *\r\n */\r\nP.tangent = P.tan = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n x = x.sin();\r\n x.s = 1;\r\n x = divide(x, new Ctor(1).minus(x.times(x)).sqrt(), pr + 10, 0);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 4 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * n * 0 = 0\r\n * n * N = N\r\n * n * I = I\r\n * 0 * n = 0\r\n * 0 * 0 = 0\r\n * 0 * N = N\r\n * 0 * I = N\r\n * N * n = N\r\n * N * 0 = N\r\n * N * N = N\r\n * N * I = N\r\n * I * n = I\r\n * I * 0 = N\r\n * I * N = N\r\n * I * I = I\r\n *\r\n * Return a new Decimal whose value is this Decimal times `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.times = P.mul = function (y) {\r\n var carry, e, i, k, r, rL, t, xdL, ydL,\r\n x = this,\r\n Ctor = x.constructor,\r\n xd = x.d,\r\n yd = (y = new Ctor(y)).d;\r\n\r\n y.s *= x.s;\r\n\r\n // If either is NaN, ±Infinity or ±0...\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(!y.s || xd && !xd[0] && !yd || yd && !yd[0] && !xd\r\n\r\n // Return NaN if either is NaN.\r\n // Return NaN if x is ±0 and y is ±Infinity, or y is ±0 and x is ±Infinity.\r\n ? NaN\r\n\r\n // Return ±Infinity if either is ±Infinity.\r\n // Return ±0 if either is ±0.\r\n : !xd || !yd ? y.s / 0 : y.s * 0);\r\n }\r\n\r\n e = mathfloor(x.e / LOG_BASE) + mathfloor(y.e / LOG_BASE);\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Ensure xd points to the longer array.\r\n if (xdL < ydL) {\r\n r = xd;\r\n xd = yd;\r\n yd = r;\r\n rL = xdL;\r\n xdL = ydL;\r\n ydL = rL;\r\n }\r\n\r\n // Initialise the result array with zeros.\r\n r = [];\r\n rL = xdL + ydL;\r\n for (i = rL; i--;) r.push(0);\r\n\r\n // Multiply!\r\n for (i = ydL; --i >= 0;) {\r\n carry = 0;\r\n for (k = xdL + i; k > i;) {\r\n t = r[k] + yd[i] * xd[k - i - 1] + carry;\r\n r[k--] = t % BASE | 0;\r\n carry = t / BASE | 0;\r\n }\r\n\r\n r[k] = (r[k] + carry) % BASE | 0;\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; !r[--rL];) r.pop();\r\n\r\n if (carry) ++e;\r\n else r.shift();\r\n\r\n y.d = r;\r\n y.e = getBase10Exponent(r, e);\r\n\r\n return external ? finalise(y, Ctor.precision, Ctor.rounding) : y;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 2, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toBinary = function (sd, rm) {\r\n return toStringBinary(this, 2, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `dp`\r\n * decimal places using rounding mode `rm` or `rounding` if `rm` is omitted.\r\n *\r\n * If `dp` is omitted, return a new Decimal whose value is the value of this Decimal.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toDecimalPlaces = P.toDP = function (dp, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n if (dp === void 0) return x;\r\n\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n return finalise(x, dp + x.e + 1, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in exponential notation rounded to\r\n * `dp` fixed decimal places using rounding mode `rounding`.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toExponential = function (dp, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x, true);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), dp + 1, rm);\r\n str = finiteToString(x, true, dp + 1);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in normal (fixed-point) notation to\r\n * `dp` fixed decimal places and rounded using rounding mode `rm` or `rounding` if `rm` is\r\n * omitted.\r\n *\r\n * As with JavaScript numbers, (-0).toFixed(0) is '0', but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * (-0).toFixed(0) is '0', but (-0.1).toFixed(0) is '-0'.\r\n * (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'.\r\n * (-0).toFixed(3) is '0.000'.\r\n * (-0.5).toFixed(0) is '-0'.\r\n *\r\n */\r\nP.toFixed = function (dp, rm) {\r\n var str, y,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n y = finalise(new Ctor(x), dp + x.e + 1, rm);\r\n str = finiteToString(y, false, dp + y.e + 1);\r\n }\r\n\r\n // To determine whether to add the minus sign look at the value before it was rounded,\r\n // i.e. look at `x` rather than `y`.\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return an array representing the value of this Decimal as a simple fraction with an integer\r\n * numerator and an integer denominator.\r\n *\r\n * The denominator will be a positive non-zero value less than or equal to the specified maximum\r\n * denominator. If a maximum denominator is not specified, the denominator will be the lowest\r\n * value necessary to represent the number exactly.\r\n *\r\n * [maxD] {number|string|Decimal} Maximum denominator. Integer >= 1 and < Infinity.\r\n *\r\n */\r\nP.toFraction = function (maxD) {\r\n var d, d0, d1, d2, e, k, n, n0, n1, pr, q, r,\r\n x = this,\r\n xd = x.d,\r\n Ctor = x.constructor;\r\n\r\n if (!xd) return new Ctor(x);\r\n\r\n n1 = d0 = new Ctor(1);\r\n d1 = n0 = new Ctor(0);\r\n\r\n d = new Ctor(d1);\r\n e = d.e = getPrecision(xd) - x.e - 1;\r\n k = e % LOG_BASE;\r\n d.d[0] = mathpow(10, k < 0 ? LOG_BASE + k : k);\r\n\r\n if (maxD == null) {\r\n\r\n // d is 10**e, the minimum max-denominator needed.\r\n maxD = e > 0 ? d : n1;\r\n } else {\r\n n = new Ctor(maxD);\r\n if (!n.isInt() || n.lt(n1)) throw Error(invalidArgument + n);\r\n maxD = n.gt(d) ? (e > 0 ? d : n1) : n;\r\n }\r\n\r\n external = false;\r\n n = new Ctor(digitsToString(xd));\r\n pr = Ctor.precision;\r\n Ctor.precision = e = xd.length * LOG_BASE * 2;\r\n\r\n for (;;) {\r\n q = divide(n, d, 0, 1, 1);\r\n d2 = d0.plus(q.times(d1));\r\n if (d2.cmp(maxD) == 1) break;\r\n d0 = d1;\r\n d1 = d2;\r\n d2 = n1;\r\n n1 = n0.plus(q.times(d2));\r\n n0 = d2;\r\n d2 = d;\r\n d = n.minus(q.times(d2));\r\n n = d2;\r\n }\r\n\r\n d2 = divide(maxD.minus(d0), d1, 0, 1, 1);\r\n n0 = n0.plus(d2.times(n1));\r\n d0 = d0.plus(d2.times(d1));\r\n n0.s = n1.s = x.s;\r\n\r\n // Determine which fraction is closer to x, n0/d0 or n1/d1?\r\n r = divide(n1, d1, e, 1).minus(x).abs().cmp(divide(n0, d0, e, 1).minus(x).abs()) < 1\r\n ? [n1, d1] : [n0, d0];\r\n\r\n Ctor.precision = pr;\r\n external = true;\r\n\r\n return r;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 16, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toHexadecimal = P.toHex = function (sd, rm) {\r\n return toStringBinary(this, 16, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Returns a new Decimal whose value is the nearest multiple of `y` in the direction of rounding\r\n * mode `rm`, or `Decimal.rounding` if `rm` is omitted, to the value of this Decimal.\r\n *\r\n * The return value will always have the same sign as this Decimal, unless either this Decimal\r\n * or `y` is NaN, in which case the return value will be also be NaN.\r\n *\r\n * The return value is not affected by the value of `precision`.\r\n *\r\n * y {number|string|Decimal} The magnitude to round to a multiple of.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toNearest() rounding mode not an integer: {rm}'\r\n * 'toNearest() rounding mode out of range: {rm}'\r\n *\r\n */\r\nP.toNearest = function (y, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n\r\n if (y == null) {\r\n\r\n // If x is not finite, return x.\r\n if (!x.d) return x;\r\n\r\n y = new Ctor(1);\r\n rm = Ctor.rounding;\r\n } else {\r\n y = new Ctor(y);\r\n if (rm === void 0) {\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(rm, 0, 8);\r\n }\r\n\r\n // If x is not finite, return x if y is not NaN, else NaN.\r\n if (!x.d) return y.s ? x : y;\r\n\r\n // If y is not finite, return Infinity with the sign of x if y is Infinity, else NaN.\r\n if (!y.d) {\r\n if (y.s) y.s = x.s;\r\n return y;\r\n }\r\n }\r\n\r\n // If y is not zero, calculate the nearest multiple of y to x.\r\n if (y.d[0]) {\r\n external = false;\r\n x = divide(x, y, 0, rm, 1).times(y);\r\n external = true;\r\n finalise(x);\r\n\r\n // If y is zero, return zero with the sign of x.\r\n } else {\r\n y.s = x.s;\r\n x = y;\r\n }\r\n\r\n return x;\r\n};\r\n\r\n\r\n/*\r\n * Return the value of this Decimal converted to a number primitive.\r\n * Zero keeps its sign.\r\n *\r\n */\r\nP.toNumber = function () {\r\n return +this;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 8, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toOctal = function (sd, rm) {\r\n return toStringBinary(this, 8, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal raised to the power `y`, rounded\r\n * to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * ECMAScript compliant.\r\n *\r\n * pow(x, NaN) = NaN\r\n * pow(x, ±0) = 1\r\n\r\n * pow(NaN, non-zero) = NaN\r\n * pow(abs(x) > 1, +Infinity) = +Infinity\r\n * pow(abs(x) > 1, -Infinity) = +0\r\n * pow(abs(x) == 1, ±Infinity) = NaN\r\n * pow(abs(x) < 1, +Infinity) = +0\r\n * pow(abs(x) < 1, -Infinity) = +Infinity\r\n * pow(+Infinity, y > 0) = +Infinity\r\n * pow(+Infinity, y < 0) = +0\r\n * pow(-Infinity, odd integer > 0) = -Infinity\r\n * pow(-Infinity, even integer > 0) = +Infinity\r\n * pow(-Infinity, odd integer < 0) = -0\r\n * pow(-Infinity, even integer < 0) = +0\r\n * pow(+0, y > 0) = +0\r\n * pow(+0, y < 0) = +Infinity\r\n * pow(-0, odd integer > 0) = -0\r\n * pow(-0, even integer > 0) = +0\r\n * pow(-0, odd integer < 0) = -Infinity\r\n * pow(-0, even integer < 0) = +Infinity\r\n * pow(finite x < 0, finite non-integer) = NaN\r\n *\r\n * For non-integer or very large exponents pow(x, y) is calculated using\r\n *\r\n * x^y = exp(y*ln(x))\r\n *\r\n * Assuming the first 15 rounding digits are each equally likely to be any digit 0-9, the\r\n * probability of an incorrectly rounded result\r\n * P([49]9{14} | [50]0{14}) = 2 * 0.2 * 10^-14 = 4e-15 = 1/2.5e+14\r\n * i.e. 1 in 250,000,000,000,000\r\n *\r\n * If a result is incorrectly rounded the maximum error will be 1 ulp (unit in last place).\r\n *\r\n * y {number|string|Decimal} The power to which to raise this Decimal.\r\n *\r\n */\r\nP.toPower = P.pow = function (y) {\r\n var e, k, pr, r, rm, s,\r\n x = this,\r\n Ctor = x.constructor,\r\n yn = +(y = new Ctor(y));\r\n\r\n // Either ±Infinity, NaN or ±0?\r\n if (!x.d || !y.d || !x.d[0] || !y.d[0]) return new Ctor(mathpow(+x, yn));\r\n\r\n x = new Ctor(x);\r\n\r\n if (x.eq(1)) return x;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (y.eq(1)) return finalise(x, pr, rm);\r\n\r\n // y exponent\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n // If y is a small integer use the 'exponentiation by squaring' algorithm.\r\n if (e >= y.d.length - 1 && (k = yn < 0 ? -yn : yn) <= MAX_SAFE_INTEGER) {\r\n r = intPow(Ctor, x, k, pr);\r\n return y.s < 0 ? new Ctor(1).div(r) : finalise(r, pr, rm);\r\n }\r\n\r\n s = x.s;\r\n\r\n // if x is negative\r\n if (s < 0) {\r\n\r\n // if y is not an integer\r\n if (e < y.d.length - 1) return new Ctor(NaN);\r\n\r\n // Result is positive if x is negative and the last digit of integer y is even.\r\n if ((y.d[e] & 1) == 0) s = 1;\r\n\r\n // if x.eq(-1)\r\n if (x.e == 0 && x.d[0] == 1 && x.d.length == 1) {\r\n x.s = s;\r\n return x;\r\n }\r\n }\r\n\r\n // Estimate result exponent.\r\n // x^y = 10^e, where e = y * log10(x)\r\n // log10(x) = log10(x_significand) + x_exponent\r\n // log10(x_significand) = ln(x_significand) / ln(10)\r\n k = mathpow(+x, yn);\r\n e = k == 0 || !isFinite(k)\r\n ? mathfloor(yn * (Math.log('0.' + digitsToString(x.d)) / Math.LN10 + x.e + 1))\r\n : new Ctor(k + '').e;\r\n\r\n // Exponent estimate may be incorrect e.g. x: 0.999999999999999999, y: 2.29, e: 0, r.e: -1.\r\n\r\n // Overflow/underflow?\r\n if (e > Ctor.maxE + 1 || e < Ctor.minE - 1) return new Ctor(e > 0 ? s / 0 : 0);\r\n\r\n external = false;\r\n Ctor.rounding = x.s = 1;\r\n\r\n // Estimate the extra guard digits needed to ensure five correct rounding digits from\r\n // naturalLogarithm(x). Example of failure without these extra digits (precision: 10):\r\n // new Decimal(2.32456).pow('2087987436534566.46411')\r\n // should be 1.162377823e+764914905173815, but is 1.162355823e+764914905173815\r\n k = Math.min(12, (e + '').length);\r\n\r\n // r = x^y = exp(y*ln(x))\r\n r = naturalExponential(y.times(naturalLogarithm(x, pr + k)), pr);\r\n\r\n // r may be Infinity, e.g. (0.9999999999999999).pow(-1e+40)\r\n if (r.d) {\r\n\r\n // Truncate to the required precision plus five rounding digits.\r\n r = finalise(r, pr + 5, 1);\r\n\r\n // If the rounding digits are [49]9999 or [50]0000 increase the precision by 10 and recalculate\r\n // the result.\r\n if (checkRoundingDigits(r.d, pr, rm)) {\r\n e = pr + 10;\r\n\r\n // Truncate to the increased precision plus five rounding digits.\r\n r = finalise(naturalExponential(y.times(naturalLogarithm(x, e + k)), e), e + 5, 1);\r\n\r\n // Check for 14 nines from the 2nd rounding digit (the first rounding digit may be 4 or 9).\r\n if (+digitsToString(r.d).slice(pr + 1, pr + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n }\r\n }\r\n\r\n r.s = s;\r\n external = true;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(r, pr, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal rounded to `sd` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * Return exponential notation if `sd` is less than the number of digits necessary to represent\r\n * the integer part of the value in normal notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toPrecision = function (sd, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), sd, rm);\r\n str = finiteToString(x, sd <= x.e || x.e <= Ctor.toExpNeg, sd);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `sd`\r\n * significant digits using rounding mode `rm`, or to `precision` and `rounding` respectively if\r\n * omitted.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toSD() digits out of range: {sd}'\r\n * 'toSD() digits not an integer: {sd}'\r\n * 'toSD() rounding mode not an integer: {rm}'\r\n * 'toSD() rounding mode out of range: {rm}'\r\n *\r\n */\r\nP.toSignificantDigits = P.toSD = function (sd, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n }\r\n\r\n return finalise(new Ctor(x), sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal.\r\n *\r\n * Return exponential notation if this Decimal has a positive exponent equal to or greater than\r\n * `toExpPos`, or a negative exponent equal to or less than `toExpNeg`.\r\n *\r\n */\r\nP.toString = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal truncated to a whole number.\r\n *\r\n */\r\nP.truncated = P.trunc = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 1);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal.\r\n * Unlike `toString`, negative zero will include the minus sign.\r\n *\r\n */\r\nP.valueOf = P.toJSON = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() ? '-' + str : str;\r\n};\r\n\r\n\r\n// Helper functions for Decimal.prototype (P) and/or Decimal methods, and their callers.\r\n\r\n\r\n/*\r\n * digitsToString P.cubeRoot, P.logarithm, P.squareRoot, P.toFraction, P.toPower,\r\n * finiteToString, naturalExponential, naturalLogarithm\r\n * checkInt32 P.toDecimalPlaces, P.toExponential, P.toFixed, P.toNearest,\r\n * P.toPrecision, P.toSignificantDigits, toStringBinary, random\r\n * checkRoundingDigits P.logarithm, P.toPower, naturalExponential, naturalLogarithm\r\n * convertBase toStringBinary, parseOther\r\n * cos P.cos\r\n * divide P.atanh, P.cubeRoot, P.dividedBy, P.dividedToIntegerBy,\r\n * P.logarithm, P.modulo, P.squareRoot, P.tan, P.tanh, P.toFraction,\r\n * P.toNearest, toStringBinary, naturalExponential, naturalLogarithm,\r\n * taylorSeries, atan2, parseOther\r\n * finalise P.absoluteValue, P.atan, P.atanh, P.ceil, P.cos, P.cosh,\r\n * P.cubeRoot, P.dividedToIntegerBy, P.floor, P.logarithm, P.minus,\r\n * P.modulo, P.negated, P.plus, P.round, P.sin, P.sinh, P.squareRoot,\r\n * P.tan, P.times, P.toDecimalPlaces, P.toExponential, P.toFixed,\r\n * P.toNearest, P.toPower, P.toPrecision, P.toSignificantDigits,\r\n * P.truncated, divide, getLn10, getPi, naturalExponential,\r\n * naturalLogarithm, ceil, floor, round, trunc\r\n * finiteToString P.toExponential, P.toFixed, P.toPrecision, P.toString, P.valueOf,\r\n * toStringBinary\r\n * getBase10Exponent P.minus, P.plus, P.times, parseOther\r\n * getLn10 P.logarithm, naturalLogarithm\r\n * getPi P.acos, P.asin, P.atan, toLessThanHalfPi, atan2\r\n * getPrecision P.precision, P.toFraction\r\n * getZeroString digitsToString, finiteToString\r\n * intPow P.toPower, parseOther\r\n * isOdd toLessThanHalfPi\r\n * maxOrMin max, min\r\n * naturalExponential P.naturalExponential, P.toPower\r\n * naturalLogarithm P.acosh, P.asinh, P.atanh, P.logarithm, P.naturalLogarithm,\r\n * P.toPower, naturalExponential\r\n * nonFiniteToString finiteToString, toStringBinary\r\n * parseDecimal Decimal\r\n * parseOther Decimal\r\n * sin P.sin\r\n * taylorSeries P.cosh, P.sinh, cos, sin\r\n * toLessThanHalfPi P.cos, P.sin\r\n * toStringBinary P.toBinary, P.toHexadecimal, P.toOctal\r\n * truncate intPow\r\n *\r\n * Throws: P.logarithm, P.precision, P.toFraction, checkInt32, getLn10, getPi,\r\n * naturalLogarithm, config, parseOther, random, Decimal\r\n */\r\n\r\n\r\nfunction digitsToString(d) {\r\n var i, k, ws,\r\n indexOfLastWord = d.length - 1,\r\n str = '',\r\n w = d[0];\r\n\r\n if (indexOfLastWord > 0) {\r\n str += w;\r\n for (i = 1; i < indexOfLastWord; i++) {\r\n ws = d[i] + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n str += ws;\r\n }\r\n\r\n w = d[i];\r\n ws = w + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n } else if (w === 0) {\r\n return '0';\r\n }\r\n\r\n // Remove trailing zeros of last w.\r\n for (; w % 10 === 0;) w /= 10;\r\n\r\n return str + w;\r\n}\r\n\r\n\r\nfunction checkInt32(i, min, max) {\r\n if (i !== ~~i || i < min || i > max) {\r\n throw Error(invalidArgument + i);\r\n }\r\n}\r\n\r\n\r\n/*\r\n * Check 5 rounding digits if `repeating` is null, 4 otherwise.\r\n * `repeating == null` if caller is `log` or `pow`,\r\n * `repeating != null` if caller is `naturalLogarithm` or `naturalExponential`.\r\n */\r\nfunction checkRoundingDigits(d, i, rm, repeating) {\r\n var di, k, r, rd;\r\n\r\n // Get the length of the first word of the array d.\r\n for (k = d[0]; k >= 10; k /= 10) --i;\r\n\r\n // Is the rounding digit in the first word of d?\r\n if (--i < 0) {\r\n i += LOG_BASE;\r\n di = 0;\r\n } else {\r\n di = Math.ceil((i + 1) / LOG_BASE);\r\n i %= LOG_BASE;\r\n }\r\n\r\n // i is the index (0 - 6) of the rounding digit.\r\n // E.g. if within the word 3487563 the first rounding digit is 5,\r\n // then i = 4, k = 1000, rd = 3487563 % 1000 = 563\r\n k = mathpow(10, LOG_BASE - i);\r\n rd = d[di] % k | 0;\r\n\r\n if (repeating == null) {\r\n if (i < 3) {\r\n if (i == 0) rd = rd / 100 | 0;\r\n else if (i == 1) rd = rd / 10 | 0;\r\n r = rm < 4 && rd == 99999 || rm > 3 && rd == 49999 || rd == 50000 || rd == 0;\r\n } else {\r\n r = (rm < 4 && rd + 1 == k || rm > 3 && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 100 | 0) == mathpow(10, i - 2) - 1 ||\r\n (rd == k / 2 || rd == 0) && (d[di + 1] / k / 100 | 0) == 0;\r\n }\r\n } else {\r\n if (i < 4) {\r\n if (i == 0) rd = rd / 1000 | 0;\r\n else if (i == 1) rd = rd / 100 | 0;\r\n else if (i == 2) rd = rd / 10 | 0;\r\n r = (repeating || rm < 4) && rd == 9999 || !repeating && rm > 3 && rd == 4999;\r\n } else {\r\n r = ((repeating || rm < 4) && rd + 1 == k ||\r\n (!repeating && rm > 3) && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 1000 | 0) == mathpow(10, i - 3) - 1;\r\n }\r\n }\r\n\r\n return r;\r\n}\r\n\r\n\r\n// Convert string of `baseIn` to an array of numbers of `baseOut`.\r\n// Eg. convertBase('255', 10, 16) returns [15, 15].\r\n// Eg. convertBase('ff', 16, 10) returns [2, 5, 5].\r\nfunction convertBase(str, baseIn, baseOut) {\r\n var j,\r\n arr = [0],\r\n arrL,\r\n i = 0,\r\n strL = str.length;\r\n\r\n for (; i < strL;) {\r\n for (arrL = arr.length; arrL--;) arr[arrL] *= baseIn;\r\n arr[0] += NUMERALS.indexOf(str.charAt(i++));\r\n for (j = 0; j < arr.length; j++) {\r\n if (arr[j] > baseOut - 1) {\r\n if (arr[j + 1] === void 0) arr[j + 1] = 0;\r\n arr[j + 1] += arr[j] / baseOut | 0;\r\n arr[j] %= baseOut;\r\n }\r\n }\r\n }\r\n\r\n return arr.reverse();\r\n}\r\n\r\n\r\n/*\r\n * cos(x) = 1 - x^2/2! + x^4/4! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\nfunction cosine(Ctor, x) {\r\n var k, len, y;\r\n\r\n if (x.isZero()) return x;\r\n\r\n // Argument reduction: cos(4x) = 8*(cos^4(x) - cos^2(x)) + 1\r\n // i.e. cos(x) = 8*(cos^4(x/4) - cos^2(x/4)) + 1\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n len = x.d.length;\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n y = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n y = '2.3283064365386962890625e-10';\r\n }\r\n\r\n Ctor.precision += k;\r\n\r\n x = taylorSeries(Ctor, 1, x.times(y), new Ctor(1));\r\n\r\n // Reverse argument reduction\r\n for (var i = k; i--;) {\r\n var cos2x = x.times(x);\r\n x = cos2x.times(cos2x).minus(cos2x).times(8).plus(1);\r\n }\r\n\r\n Ctor.precision -= k;\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Perform division in the specified base.\r\n */\r\nvar divide = (function () {\r\n\r\n // Assumes non-zero x and k, and hence non-zero result.\r\n function multiplyInteger(x, k, base) {\r\n var temp,\r\n carry = 0,\r\n i = x.length;\r\n\r\n for (x = x.slice(); i--;) {\r\n temp = x[i] * k + carry;\r\n x[i] = temp % base | 0;\r\n carry = temp / base | 0;\r\n }\r\n\r\n if (carry) x.unshift(carry);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, r;\r\n\r\n if (aL != bL) {\r\n r = aL > bL ? 1 : -1;\r\n } else {\r\n for (i = r = 0; i < aL; i++) {\r\n if (a[i] != b[i]) {\r\n r = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return r;\r\n }\r\n\r\n function subtract(a, b, aL, base) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * base + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1;) a.shift();\r\n }\r\n\r\n return function (x, y, pr, rm, dp, base) {\r\n var cmp, e, i, k, logBase, more, prod, prodL, q, qd, rem, remL, rem0, sd, t, xi, xL, yd0,\r\n yL, yz,\r\n Ctor = x.constructor,\r\n sign = x.s == y.s ? 1 : -1,\r\n xd = x.d,\r\n yd = y.d;\r\n\r\n // Either NaN, Infinity or 0?\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(// Return NaN if either NaN, or both Infinity or 0.\r\n !x.s || !y.s || (xd ? yd && xd[0] == yd[0] : !yd) ? NaN :\r\n\r\n // Return ±0 if x is 0 or y is ±Infinity, or return ±Infinity as y is 0.\r\n xd && xd[0] == 0 || !yd ? sign * 0 : sign / 0);\r\n }\r\n\r\n if (base) {\r\n logBase = 1;\r\n e = x.e - y.e;\r\n } else {\r\n base = BASE;\r\n logBase = LOG_BASE;\r\n e = mathfloor(x.e / logBase) - mathfloor(y.e / logBase);\r\n }\r\n\r\n yL = yd.length;\r\n xL = xd.length;\r\n q = new Ctor(sign);\r\n qd = q.d = [];\r\n\r\n // Result exponent may be one less than e.\r\n // The digit array of a Decimal from toStringBinary may have trailing zeros.\r\n for (i = 0; yd[i] == (xd[i] || 0); i++);\r\n\r\n if (yd[i] > (xd[i] || 0)) e--;\r\n\r\n if (pr == null) {\r\n sd = pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else if (dp) {\r\n sd = pr + (x.e - y.e) + 1;\r\n } else {\r\n sd = pr;\r\n }\r\n\r\n if (sd < 0) {\r\n qd.push(1);\r\n more = true;\r\n } else {\r\n\r\n // Convert precision in number of base 10 digits to base 1e7 digits.\r\n sd = sd / logBase + 2 | 0;\r\n i = 0;\r\n\r\n // divisor < 1e7\r\n if (yL == 1) {\r\n k = 0;\r\n yd = yd[0];\r\n sd++;\r\n\r\n // k is the carry.\r\n for (; (i < xL || k) && sd--; i++) {\r\n t = k * base + (xd[i] || 0);\r\n qd[i] = t / yd | 0;\r\n k = t % yd | 0;\r\n }\r\n\r\n more = k || i < xL;\r\n\r\n // divisor >= 1e7\r\n } else {\r\n\r\n // Normalise xd and yd so highest order digit of yd is >= base/2\r\n k = base / (yd[0] + 1) | 0;\r\n\r\n if (k > 1) {\r\n yd = multiplyInteger(yd, k, base);\r\n xd = multiplyInteger(xd, k, base);\r\n yL = yd.length;\r\n xL = xd.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xd.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL;) rem[remL++] = 0;\r\n\r\n yz = yd.slice();\r\n yz.unshift(0);\r\n yd0 = yd[0];\r\n\r\n if (yd[1] >= base / 2) ++yd0;\r\n\r\n do {\r\n k = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, k.\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * base + (rem[1] || 0);\r\n\r\n // k will be how many times the divisor goes into the current remainder.\r\n k = rem0 / yd0 | 0;\r\n\r\n // Algorithm:\r\n // 1. product = divisor * trial digit (k)\r\n // 2. if product > remainder: product -= divisor, k--\r\n // 3. remainder -= product\r\n // 4. if product was < remainder at 2:\r\n // 5. compare new remainder and divisor\r\n // 6. If remainder > divisor: remainder -= divisor, k++\r\n\r\n if (k > 1) {\r\n if (k >= base) k = base - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiplyInteger(yd, k, base);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n cmp = compare(prod, rem, prodL, remL);\r\n\r\n // product > remainder.\r\n if (cmp == 1) {\r\n k--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yd, prodL, base);\r\n }\r\n } else {\r\n\r\n // cmp is -1.\r\n // If k is 0, there is no need to compare yd and rem again below, so change cmp to 1\r\n // to avoid it. If k is 1 there is a need to compare yd and rem again below.\r\n if (k == 0) cmp = k = 1;\r\n prod = yd.slice();\r\n }\r\n\r\n prodL = prod.length;\r\n if (prodL < remL) prod.unshift(0);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL, base);\r\n\r\n // If product was < previous remainder.\r\n if (cmp == -1) {\r\n remL = rem.length;\r\n\r\n // Compare divisor and new remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n if (cmp < 1) {\r\n k++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yd, remL, base);\r\n }\r\n }\r\n\r\n remL = rem.length;\r\n } else if (cmp === 0) {\r\n k++;\r\n rem = [0];\r\n } // if cmp === 1, k will be 0\r\n\r\n // Add the next digit, k, to the result array.\r\n qd[i++] = k;\r\n\r\n // Update the remainder.\r\n if (cmp && rem[0]) {\r\n rem[remL++] = xd[xi] || 0;\r\n } else {\r\n rem = [xd[xi]];\r\n remL = 1;\r\n }\r\n\r\n } while ((xi++ < xL || rem[0] !== void 0) && sd--);\r\n\r\n more = rem[0] !== void 0;\r\n }\r\n\r\n // Leading zero?\r\n if (!qd[0]) qd.shift();\r\n }\r\n\r\n // logBase is 1 when divide is being used for base conversion.\r\n if (logBase == 1) {\r\n q.e = e;\r\n inexact = more;\r\n } else {\r\n\r\n // To calculate q.e, first get the number of digits of qd[0].\r\n for (i = 1, k = qd[0]; k >= 10; k /= 10) i++;\r\n q.e = i + e * logBase - 1;\r\n\r\n finalise(q, dp ? pr + q.e + 1 : pr, rm, more);\r\n }\r\n\r\n return q;\r\n };\r\n})();\r\n\r\n\r\n/*\r\n * Round `x` to `sd` significant digits using rounding mode `rm`.\r\n * Check for over/under-flow.\r\n */\r\n function finalise(x, sd, rm, isTruncated) {\r\n var digits, i, j, k, rd, roundUp, w, xd, xdi,\r\n Ctor = x.constructor;\r\n\r\n // Don't round if sd is null or undefined.\r\n out: if (sd != null) {\r\n xd = x.d;\r\n\r\n // Infinity/NaN.\r\n if (!xd) return x;\r\n\r\n // rd: the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // w: the word of xd containing rd, a base 1e7 number.\r\n // xdi: the index of w within xd.\r\n // digits: the number of digits of w.\r\n // i: what would be the index of rd within w if all the numbers were 7 digits long (i.e. if\r\n // they had leading zeros)\r\n // j: if > 0, the actual index of rd within w (if < 0, rd is a leading zero).\r\n\r\n // Get the length of the first word of the digits array xd.\r\n for (digits = 1, k = xd[0]; k >= 10; k /= 10) digits++;\r\n i = sd - digits;\r\n\r\n // Is the rounding digit in the first word of xd?\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n w = xd[xdi = 0];\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = w / mathpow(10, digits - j - 1) % 10 | 0;\r\n } else {\r\n xdi = Math.ceil((i + 1) / LOG_BASE);\r\n k = xd.length;\r\n if (xdi >= k) {\r\n if (isTruncated) {\r\n\r\n // Needed by `naturalExponential`, `naturalLogarithm` and `squareRoot`.\r\n for (; k++ <= xdi;) xd.push(0);\r\n w = rd = 0;\r\n digits = 1;\r\n i %= LOG_BASE;\r\n j = i - LOG_BASE + 1;\r\n } else {\r\n break out;\r\n }\r\n } else {\r\n w = k = xd[xdi];\r\n\r\n // Get the number of digits of w.\r\n for (digits = 1; k >= 10; k /= 10) digits++;\r\n\r\n // Get the index of rd within w.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within w, adjusted for leading zeros.\r\n // The number of leading zeros of w is given by LOG_BASE - digits.\r\n j = i - LOG_BASE + digits;\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = j < 0 ? 0 : w / mathpow(10, digits - j - 1) % 10 | 0;\r\n }\r\n }\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n isTruncated = isTruncated || sd < 0 ||\r\n xd[xdi + 1] !== void 0 || (j < 0 ? w : w % mathpow(10, digits - j - 1));\r\n\r\n // The expression `w % mathpow(10, digits - j - 1)` returns all the digits of w to the right\r\n // of the digit at (left-to-right) index j, e.g. if w is 908714 and j is 2, the expression\r\n // will give 714.\r\n\r\n roundUp = rm < 4\r\n ? (rd || isTruncated) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || isTruncated || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? w / mathpow(10, digits - j) : 0 : xd[xdi - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n if (sd < 1 || !xd[0]) {\r\n xd.length = 0;\r\n if (roundUp) {\r\n\r\n // Convert sd to decimal places.\r\n sd -= x.e + 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xd[0] = mathpow(10, (LOG_BASE - sd % LOG_BASE) % LOG_BASE);\r\n x.e = -sd || 0;\r\n } else {\r\n\r\n // Zero.\r\n xd[0] = x.e = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xd.length = xdi;\r\n k = 1;\r\n xdi--;\r\n } else {\r\n xd.length = xdi + 1;\r\n k = mathpow(10, LOG_BASE - i);\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of w.\r\n xd[xdi] = j > 0 ? (w / mathpow(10, digits - j) % mathpow(10, j) | 0) * k : 0;\r\n }\r\n\r\n if (roundUp) {\r\n for (;;) {\r\n\r\n // Is the digit to be rounded up in the first word of xd?\r\n if (xdi == 0) {\r\n\r\n // i will be the length of xd[0] before k is added.\r\n for (i = 1, j = xd[0]; j >= 10; j /= 10) i++;\r\n j = xd[0] += k;\r\n for (k = 1; j >= 10; j /= 10) k++;\r\n\r\n // if i != k the length has increased.\r\n if (i != k) {\r\n x.e++;\r\n if (xd[0] == BASE) xd[0] = 1;\r\n }\r\n\r\n break;\r\n } else {\r\n xd[xdi] += k;\r\n if (xd[xdi] != BASE) break;\r\n xd[xdi--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xd.length; xd[--i] === 0;) xd.pop();\r\n }\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > Ctor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < Ctor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // Ctor.underflow = true;\r\n } // else Ctor.underflow = false;\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\nfunction finiteToString(x, isExp, sd) {\r\n if (!x.isFinite()) return nonFiniteToString(x);\r\n var k,\r\n e = x.e,\r\n str = digitsToString(x.d),\r\n len = str.length;\r\n\r\n if (isExp) {\r\n if (sd && (k = sd - len) > 0) {\r\n str = str.charAt(0) + '.' + str.slice(1) + getZeroString(k);\r\n } else if (len > 1) {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n\r\n str = str + (x.e < 0 ? 'e' : 'e+') + x.e;\r\n } else if (e < 0) {\r\n str = '0.' + getZeroString(-e - 1) + str;\r\n if (sd && (k = sd - len) > 0) str += getZeroString(k);\r\n } else if (e >= len) {\r\n str += getZeroString(e + 1 - len);\r\n if (sd && (k = sd - e - 1) > 0) str = str + '.' + getZeroString(k);\r\n } else {\r\n if ((k = e + 1) < len) str = str.slice(0, k) + '.' + str.slice(k);\r\n if (sd && (k = sd - len) > 0) {\r\n if (e + 1 === len) str += '.';\r\n str += getZeroString(k);\r\n }\r\n }\r\n\r\n return str;\r\n}\r\n\r\n\r\n// Calculate the base 10 exponent from the base 1e7 exponent.\r\nfunction getBase10Exponent(digits, e) {\r\n var w = digits[0];\r\n\r\n // Add the number of digits of the first word of the digits array.\r\n for ( e *= LOG_BASE; w >= 10; w /= 10) e++;\r\n return e;\r\n}\r\n\r\n\r\nfunction getLn10(Ctor, sd, pr) {\r\n if (sd > LN10_PRECISION) {\r\n\r\n // Reset global state in case the exception is caught.\r\n external = true;\r\n if (pr) Ctor.precision = pr;\r\n throw Error(precisionLimitExceeded);\r\n }\r\n return finalise(new Ctor(LN10), sd, 1, true);\r\n}\r\n\r\n\r\nfunction getPi(Ctor, sd, rm) {\r\n if (sd > PI_PRECISION) throw Error(precisionLimitExceeded);\r\n return finalise(new Ctor(PI), sd, rm, true);\r\n}\r\n\r\n\r\nfunction getPrecision(digits) {\r\n var w = digits.length - 1,\r\n len = w * LOG_BASE + 1;\r\n\r\n w = digits[w];\r\n\r\n // If non-zero...\r\n if (w) {\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n for (; w % 10 == 0; w /= 10) len--;\r\n\r\n // Add the number of digits of the first word.\r\n for (w = digits[0]; w >= 10; w /= 10) len++;\r\n }\r\n\r\n return len;\r\n}\r\n\r\n\r\nfunction getZeroString(k) {\r\n var zs = '';\r\n for (; k--;) zs += '0';\r\n return zs;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of Decimal `x` to the power `n`, where `n` is an\r\n * integer of type number.\r\n *\r\n * Implements 'exponentiation by squaring'. Called by `pow` and `parseOther`.\r\n *\r\n */\r\nfunction intPow(Ctor, x, n, pr) {\r\n var isTruncated,\r\n r = new Ctor(1),\r\n\r\n // Max n of 9007199254740991 takes 53 loop iterations.\r\n // Maximum digits array length; leaves [28, 34] guard digits.\r\n k = Math.ceil(pr / LOG_BASE + 4);\r\n\r\n external = false;\r\n\r\n for (;;) {\r\n if (n % 2) {\r\n r = r.times(x);\r\n if (truncate(r.d, k)) isTruncated = true;\r\n }\r\n\r\n n = mathfloor(n / 2);\r\n if (n === 0) {\r\n\r\n // To ensure correct rounding when r.d is truncated, increment the last word if it is zero.\r\n n = r.d.length - 1;\r\n if (isTruncated && r.d[n] === 0) ++r.d[n];\r\n break;\r\n }\r\n\r\n x = x.times(x);\r\n truncate(x.d, k);\r\n }\r\n\r\n external = true;\r\n\r\n return r;\r\n}\r\n\r\n\r\nfunction isOdd(n) {\r\n return n.d[n.d.length - 1] & 1;\r\n}\r\n\r\n\r\n/*\r\n * Handle `max` and `min`. `ltgt` is 'lt' or 'gt'.\r\n */\r\nfunction maxOrMin(Ctor, args, ltgt) {\r\n var y,\r\n x = new Ctor(args[0]),\r\n i = 0;\r\n\r\n for (; ++i < args.length;) {\r\n y = new Ctor(args[i]);\r\n if (!y.s) {\r\n x = y;\r\n break;\r\n } else if (x[ltgt](y)) {\r\n x = y;\r\n }\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * Taylor/Maclaurin series.\r\n *\r\n * exp(x) = x^0/0! + x^1/1! + x^2/2! + x^3/3! + ...\r\n *\r\n * Argument reduction:\r\n * Repeat x = x / 32, k += 5, until |x| < 0.1\r\n * exp(x) = exp(x / 2^k)^(2^k)\r\n *\r\n * Previously, the argument was initially reduced by\r\n * exp(x) = exp(r) * 10^k where r = x - k * ln10, k = floor(x / ln10)\r\n * to first put r in the range [0, ln10], before dividing by 32 until |x| < 0.1, but this was\r\n * found to be slower than just dividing repeatedly by 32 as above.\r\n *\r\n * Max integer argument: exp('20723265836946413') = 6.3e+9000000000000000\r\n * Min integer argument: exp('-20723265836946411') = 1.2e-9000000000000000\r\n * (Math object integer min/max: Math.exp(709) = 8.2e+307, Math.exp(-745) = 5e-324)\r\n *\r\n * exp(Infinity) = Infinity\r\n * exp(-Infinity) = 0\r\n * exp(NaN) = NaN\r\n * exp(±0) = 1\r\n *\r\n * exp(x) is non-terminating for any finite, non-zero x.\r\n *\r\n * The result will always be correctly rounded.\r\n *\r\n */\r\nfunction naturalExponential(x, sd) {\r\n var denominator, guard, j, pow, sum, t, wpr,\r\n rep = 0,\r\n i = 0,\r\n k = 0,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // 0/NaN/Infinity?\r\n if (!x.d || !x.d[0] || x.e > 17) {\r\n\r\n return new Ctor(x.d\r\n ? !x.d[0] ? 1 : x.s < 0 ? 0 : 1 / 0\r\n : x.s ? x.s < 0 ? 0 : x : 0 / 0);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n t = new Ctor(0.03125);\r\n\r\n // while abs(x) >= 0.1\r\n while (x.e > -2) {\r\n\r\n // x = x / 2^5\r\n x = x.times(t);\r\n k += 5;\r\n }\r\n\r\n // Use 2 * log10(2^k) + 5 (empirically derived) to estimate the increase in precision\r\n // necessary to ensure the first 4 rounding digits are correct.\r\n guard = Math.log(mathpow(2, k)) / Math.LN10 * 2 + 5 | 0;\r\n wpr += guard;\r\n denominator = pow = sum = new Ctor(1);\r\n Ctor.precision = wpr;\r\n\r\n for (;;) {\r\n pow = finalise(pow.times(x), wpr, 1);\r\n denominator = denominator.times(++i);\r\n t = sum.plus(divide(pow, denominator, wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n j = k;\r\n while (j--) sum = finalise(sum.times(sum), wpr, 1);\r\n\r\n // Check to see if the first 4 rounding digits are [49]999.\r\n // If so, repeat the summation with a higher precision, otherwise\r\n // e.g. with precision: 18, rounding: 1\r\n // exp(18.404272462595034083567793919843761) = 98372560.1229999999 (should be 98372560.123)\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n\r\n if (rep < 3 && checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += 10;\r\n denominator = pow = t = new Ctor(1);\r\n i = 0;\r\n rep++;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n }\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * ln(-n) = NaN\r\n * ln(0) = -Infinity\r\n * ln(-0) = -Infinity\r\n * ln(1) = 0\r\n * ln(Infinity) = Infinity\r\n * ln(-Infinity) = NaN\r\n * ln(NaN) = NaN\r\n *\r\n * ln(n) (n != 1) is non-terminating.\r\n *\r\n */\r\nfunction naturalLogarithm(y, sd) {\r\n var c, c0, denominator, e, numerator, rep, sum, t, wpr, x1, x2,\r\n n = 1,\r\n guard = 10,\r\n x = y,\r\n xd = x.d,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // Is x negative or Infinity, NaN, 0 or 1?\r\n if (x.s < 0 || !xd || !xd[0] || !x.e && xd[0] == 1 && xd.length == 1) {\r\n return new Ctor(xd && !xd[0] ? -1 / 0 : x.s != 1 ? NaN : xd ? 0 : x);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n Ctor.precision = wpr += guard;\r\n c = digitsToString(xd);\r\n c0 = c.charAt(0);\r\n\r\n if (Math.abs(e = x.e) < 1.5e15) {\r\n\r\n // Argument reduction.\r\n // The series converges faster the closer the argument is to 1, so using\r\n // ln(a^b) = b * ln(a), ln(a) = ln(a^b) / b\r\n // multiply the argument by itself until the leading digits of the significand are 7, 8, 9,\r\n // 10, 11, 12 or 13, recording the number of multiplications so the sum of the series can\r\n // later be divided by this number, then separate out the power of 10 using\r\n // ln(a*10^b) = ln(a) + b*ln(10).\r\n\r\n // max n is 21 (gives 0.9, 1.0 or 1.1) (9e15 / 21 = 4.2e14).\r\n //while (c0 < 9 && c0 != 1 || c0 == 1 && c.charAt(1) > 1) {\r\n // max n is 6 (gives 0.7 - 1.3)\r\n while (c0 < 7 && c0 != 1 || c0 == 1 && c.charAt(1) > 3) {\r\n x = x.times(y);\r\n c = digitsToString(x.d);\r\n c0 = c.charAt(0);\r\n n++;\r\n }\r\n\r\n e = x.e;\r\n\r\n if (c0 > 1) {\r\n x = new Ctor('0.' + c);\r\n e++;\r\n } else {\r\n x = new Ctor(c0 + '.' + c.slice(1));\r\n }\r\n } else {\r\n\r\n // The argument reduction method above may result in overflow if the argument y is a massive\r\n // number with exponent >= 1500000000000000 (9e15 / 6 = 1.5e15), so instead recall this\r\n // function using ln(x*10^e) = ln(x) + e*ln(10).\r\n t = getLn10(Ctor, wpr + 2, pr).times(e + '');\r\n x = naturalLogarithm(new Ctor(c0 + '.' + c.slice(1)), wpr - guard).plus(t);\r\n Ctor.precision = pr;\r\n\r\n return sd == null ? finalise(x, pr, rm, external = true) : x;\r\n }\r\n\r\n // x1 is x reduced to a value near 1.\r\n x1 = x;\r\n\r\n // Taylor series.\r\n // ln(y) = ln((1 + x)/(1 - x)) = 2(x + x^3/3 + x^5/5 + x^7/7 + ...)\r\n // where x = (y - 1)/(y + 1) (|x| < 1)\r\n sum = numerator = x = divide(x.minus(1), x.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = 3;\r\n\r\n for (;;) {\r\n numerator = finalise(numerator.times(x2), wpr, 1);\r\n t = sum.plus(divide(numerator, new Ctor(denominator), wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n sum = sum.times(2);\r\n\r\n // Reverse the argument reduction. Check that e is not 0 because, besides preventing an\r\n // unnecessary calculation, -0 + 0 = +0 and to ensure correct rounding -0 needs to stay -0.\r\n if (e !== 0) sum = sum.plus(getLn10(Ctor, wpr + 2, pr).times(e + ''));\r\n sum = divide(sum, new Ctor(n), wpr, 1);\r\n\r\n // Is rm > 3 and the first 4 rounding digits 4999, or rm < 4 (or the summation has\r\n // been repeated previously) and the first 4 rounding digits 9999?\r\n // If so, restart the summation with a higher precision, otherwise\r\n // e.g. with precision: 12, rounding: 1\r\n // ln(135520028.6126091714265381533) = 18.7246299999 when it should be 18.72463.\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n if (checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += guard;\r\n t = numerator = x = divide(x1.minus(1), x1.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = rep = 1;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n denominator += 2;\r\n }\r\n}\r\n\r\n\r\n// ±Infinity, NaN.\r\nfunction nonFiniteToString(x) {\r\n // Unsigned.\r\n return String(x.s * x.s / 0);\r\n}\r\n\r\n\r\n/*\r\n * Parse the value of a new Decimal `x` from string `str`.\r\n */\r\nfunction parseDecimal(x, str) {\r\n var e, i, len;\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48; i++);\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(len - 1) === 48; --len);\r\n str = str.slice(i, len);\r\n\r\n if (str) {\r\n len -= i;\r\n x.e = e = e - i - 1;\r\n x.d = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first word of the digits array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE;\r\n\r\n if (i < len) {\r\n if (i) x.d.push(+str.slice(0, i));\r\n for (len -= LOG_BASE; i < len;) x.d.push(+str.slice(i, i += LOG_BASE));\r\n str = str.slice(i);\r\n i = LOG_BASE - str.length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--;) str += '0';\r\n x.d.push(+str);\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > x.constructor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < x.constructor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // x.constructor.underflow = true;\r\n } // else x.constructor.underflow = false;\r\n }\r\n } else {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Parse the value of a new Decimal `x` from a string `str`, which is not a decimal value.\r\n */\r\nfunction parseOther(x, str) {\r\n var base, Ctor, divisor, i, isFloat, len, p, xd, xe;\r\n\r\n if (str.indexOf('_') > -1) {\r\n str = str.replace(/(\\d)_(?=\\d)/g, '$1');\r\n if (isDecimal.test(str)) return parseDecimal(x, str);\r\n } else if (str === 'Infinity' || str === 'NaN') {\r\n if (!+str) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return x;\r\n }\r\n\r\n if (isHex.test(str)) {\r\n base = 16;\r\n str = str.toLowerCase();\r\n } else if (isBinary.test(str)) {\r\n base = 2;\r\n } else if (isOctal.test(str)) {\r\n base = 8;\r\n } else {\r\n throw Error(invalidArgument + str);\r\n }\r\n\r\n // Is there a binary exponent part?\r\n i = str.search(/p/i);\r\n\r\n if (i > 0) {\r\n p = +str.slice(i + 1);\r\n str = str.substring(2, i);\r\n } else {\r\n str = str.slice(2);\r\n }\r\n\r\n // Convert `str` as an integer then divide the result by `base` raised to a power such that the\r\n // fraction part will be restored.\r\n i = str.indexOf('.');\r\n isFloat = i >= 0;\r\n Ctor = x.constructor;\r\n\r\n if (isFloat) {\r\n str = str.replace('.', '');\r\n len = str.length;\r\n i = len - i;\r\n\r\n // log[10](16) = 1.2041... , log[10](88) = 1.9444....\r\n divisor = intPow(Ctor, new Ctor(base), i, i * 2);\r\n }\r\n\r\n xd = convertBase(str, base, BASE);\r\n xe = xd.length - 1;\r\n\r\n // Remove trailing zeros.\r\n for (i = xe; xd[i] === 0; --i) xd.pop();\r\n if (i < 0) return new Ctor(x.s * 0);\r\n x.e = getBase10Exponent(xd, xe);\r\n x.d = xd;\r\n external = false;\r\n\r\n // At what precision to perform the division to ensure exact conversion?\r\n // maxDecimalIntegerPartDigitCount = ceil(log[10](b) * otherBaseIntegerPartDigitCount)\r\n // log[10](2) = 0.30103, log[10](8) = 0.90309, log[10](16) = 1.20412\r\n // E.g. ceil(1.2 * 3) = 4, so up to 4 decimal digits are needed to represent 3 hex int digits.\r\n // maxDecimalFractionPartDigitCount = {Hex:4|Oct:3|Bin:1} * otherBaseFractionPartDigitCount\r\n // Therefore using 4 * the number of digits of str will always be enough.\r\n if (isFloat) x = divide(x, divisor, len * 4);\r\n\r\n // Multiply by the binary exponent part if present.\r\n if (p) x = x.times(Math.abs(p) < 54 ? mathpow(2, p) : Decimal.pow(2, p));\r\n external = true;\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\nfunction sine(Ctor, x) {\r\n var k,\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n return x.isZero() ? x : taylorSeries(Ctor, 2, x, x);\r\n }\r\n\r\n // Argument reduction: sin(5x) = 16*sin^5(x) - 20*sin^3(x) + 5*sin(x)\r\n // i.e. sin(x) = 16*sin^5(x/5) - 20*sin^3(x/5) + 5*sin(x/5)\r\n // and sin(x) = sin(x/5)(5 + sin^2(x/5)(16sin^2(x/5) - 20))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x);\r\n\r\n // Reverse argument reduction\r\n var sin2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sin2_x = x.times(x);\r\n x = x.times(d5.plus(sin2_x.times(d16.times(sin2_x).minus(d20))));\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n// Calculate Taylor series for `cos`, `cosh`, `sin` and `sinh`.\r\nfunction taylorSeries(Ctor, n, x, y, isHyperbolic) {\r\n var j, t, u, x2,\r\n i = 1,\r\n pr = Ctor.precision,\r\n k = Math.ceil(pr / LOG_BASE);\r\n\r\n external = false;\r\n x2 = x.times(x);\r\n u = new Ctor(y);\r\n\r\n for (;;) {\r\n t = divide(u.times(x2), new Ctor(n++ * n++), pr, 1);\r\n u = isHyperbolic ? y.plus(t) : y.minus(t);\r\n y = divide(t.times(x2), new Ctor(n++ * n++), pr, 1);\r\n t = u.plus(y);\r\n\r\n if (t.d[k] !== void 0) {\r\n for (j = k; t.d[j] === u.d[j] && j--;);\r\n if (j == -1) break;\r\n }\r\n\r\n j = u;\r\n u = y;\r\n y = t;\r\n t = j;\r\n i++;\r\n }\r\n\r\n external = true;\r\n t.d.length = k + 1;\r\n\r\n return t;\r\n}\r\n\r\n\r\n// Exponent e must be positive and non-zero.\r\nfunction tinyPow(b, e) {\r\n var n = b;\r\n while (--e) n *= b;\r\n return n;\r\n}\r\n\r\n\r\n// Return the absolute value of `x` reduced to less than or equal to half pi.\r\nfunction toLessThanHalfPi(Ctor, x) {\r\n var t,\r\n isNeg = x.s < 0,\r\n pi = getPi(Ctor, Ctor.precision, 1),\r\n halfPi = pi.times(0.5);\r\n\r\n x = x.abs();\r\n\r\n if (x.lte(halfPi)) {\r\n quadrant = isNeg ? 4 : 1;\r\n return x;\r\n }\r\n\r\n t = x.divToInt(pi);\r\n\r\n if (t.isZero()) {\r\n quadrant = isNeg ? 3 : 2;\r\n } else {\r\n x = x.minus(t.times(pi));\r\n\r\n // 0 <= x < pi\r\n if (x.lte(halfPi)) {\r\n quadrant = isOdd(t) ? (isNeg ? 2 : 3) : (isNeg ? 4 : 1);\r\n return x;\r\n }\r\n\r\n quadrant = isOdd(t) ? (isNeg ? 1 : 4) : (isNeg ? 3 : 2);\r\n }\r\n\r\n return x.minus(pi).abs();\r\n}\r\n\r\n\r\n/*\r\n * Return the value of Decimal `x` as a string in base `baseOut`.\r\n *\r\n * If the optional `sd` argument is present include a binary exponent suffix.\r\n */\r\nfunction toStringBinary(x, baseOut, sd, rm) {\r\n var base, e, i, k, len, roundUp, str, xd, y,\r\n Ctor = x.constructor,\r\n isExp = sd !== void 0;\r\n\r\n if (isExp) {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n } else {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n }\r\n\r\n if (!x.isFinite()) {\r\n str = nonFiniteToString(x);\r\n } else {\r\n str = finiteToString(x);\r\n i = str.indexOf('.');\r\n\r\n // Use exponential notation according to `toExpPos` and `toExpNeg`? No, but if required:\r\n // maxBinaryExponent = floor((decimalExponent + 1) * log[2](10))\r\n // minBinaryExponent = floor(decimalExponent * log[2](10))\r\n // log[2](10) = 3.321928094887362347870319429489390175864\r\n\r\n if (isExp) {\r\n base = 2;\r\n if (baseOut == 16) {\r\n sd = sd * 4 - 3;\r\n } else if (baseOut == 8) {\r\n sd = sd * 3 - 2;\r\n }\r\n } else {\r\n base = baseOut;\r\n }\r\n\r\n // Convert the number as an integer then divide the result by its base raised to a power such\r\n // that the fraction part will be restored.\r\n\r\n // Non-integer.\r\n if (i >= 0) {\r\n str = str.replace('.', '');\r\n y = new Ctor(1);\r\n y.e = str.length - i;\r\n y.d = convertBase(finiteToString(y), 10, base);\r\n y.e = y.d.length;\r\n }\r\n\r\n xd = convertBase(str, 10, base);\r\n e = len = xd.length;\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] == 0;) xd.pop();\r\n\r\n if (!xd[0]) {\r\n str = isExp ? '0p+0' : '0';\r\n } else {\r\n if (i < 0) {\r\n e--;\r\n } else {\r\n x = new Ctor(x);\r\n x.d = xd;\r\n x.e = e;\r\n x = divide(x, y, sd, rm, 0, base);\r\n xd = x.d;\r\n e = x.e;\r\n roundUp = inexact;\r\n }\r\n\r\n // The rounding digit, i.e. the digit after the digit that may be rounded up.\r\n i = xd[sd];\r\n k = base / 2;\r\n roundUp = roundUp || xd[sd + 1] !== void 0;\r\n\r\n roundUp = rm < 4\r\n ? (i !== void 0 || roundUp) && (rm === 0 || rm === (x.s < 0 ? 3 : 2))\r\n : i > k || i === k && (rm === 4 || roundUp || rm === 6 && xd[sd - 1] & 1 ||\r\n rm === (x.s < 0 ? 8 : 7));\r\n\r\n xd.length = sd;\r\n\r\n if (roundUp) {\r\n\r\n // Rounding up may mean the previous digit has to be rounded up and so on.\r\n for (; ++xd[--sd] > base - 1;) {\r\n xd[sd] = 0;\r\n if (!sd) {\r\n ++e;\r\n xd.unshift(1);\r\n }\r\n }\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // E.g. [4, 11, 15] becomes 4bf.\r\n for (i = 0, str = ''; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n\r\n // Add binary exponent suffix?\r\n if (isExp) {\r\n if (len > 1) {\r\n if (baseOut == 16 || baseOut == 8) {\r\n i = baseOut == 16 ? 4 : 3;\r\n for (--len; len % i; len++) str += '0';\r\n xd = convertBase(str, base, baseOut);\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // xd[0] will always be be 1\r\n for (i = 1, str = '1.'; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n } else {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n }\r\n\r\n str = str + (e < 0 ? 'p' : 'p+') + e;\r\n } else if (e < 0) {\r\n for (; ++e;) str = '0' + str;\r\n str = '0.' + str;\r\n } else {\r\n if (++e > len) for (e -= len; e-- ;) str += '0';\r\n else if (e < len) str = str.slice(0, e) + '.' + str.slice(e);\r\n }\r\n }\r\n\r\n str = (baseOut == 16 ? '0x' : baseOut == 2 ? '0b' : baseOut == 8 ? '0o' : '') + str;\r\n }\r\n\r\n return x.s < 0 ? '-' + str : str;\r\n}\r\n\r\n\r\n// Does not strip trailing zeros.\r\nfunction truncate(arr, len) {\r\n if (arr.length > len) {\r\n arr.length = len;\r\n return true;\r\n }\r\n}\r\n\r\n\r\n// Decimal methods\r\n\r\n\r\n/*\r\n * abs\r\n * acos\r\n * acosh\r\n * add\r\n * asin\r\n * asinh\r\n * atan\r\n * atanh\r\n * atan2\r\n * cbrt\r\n * ceil\r\n * clamp\r\n * clone\r\n * config\r\n * cos\r\n * cosh\r\n * div\r\n * exp\r\n * floor\r\n * hypot\r\n * ln\r\n * log\r\n * log2\r\n * log10\r\n * max\r\n * min\r\n * mod\r\n * mul\r\n * pow\r\n * random\r\n * round\r\n * set\r\n * sign\r\n * sin\r\n * sinh\r\n * sqrt\r\n * sub\r\n * sum\r\n * tan\r\n * tanh\r\n * trunc\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the absolute value of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction abs(x) {\r\n return new this(x).abs();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arccosine in radians of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction acos(x) {\r\n return new this(x).acos();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction acosh(x) {\r\n return new this(x).acosh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sum of `x` and `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction add(x, y) {\r\n return new this(x).plus(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arcsine in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction asin(x) {\r\n return new this(x).asin();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction asinh(x) {\r\n return new this(x).asinh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction atan(x) {\r\n return new this(x).atan();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction atanh(x) {\r\n return new this(x).atanh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent in radians of `y/x` in the range -pi to pi\r\n * (inclusive), rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi, pi]\r\n *\r\n * y {number|string|Decimal} The y-coordinate.\r\n * x {number|string|Decimal} The x-coordinate.\r\n *\r\n * atan2(±0, -0) = ±pi\r\n * atan2(±0, +0) = ±0\r\n * atan2(±0, -x) = ±pi for x > 0\r\n * atan2(±0, x) = ±0 for x > 0\r\n * atan2(-y, ±0) = -pi/2 for y > 0\r\n * atan2(y, ±0) = pi/2 for y > 0\r\n * atan2(±y, -Infinity) = ±pi for finite y > 0\r\n * atan2(±y, +Infinity) = ±0 for finite y > 0\r\n * atan2(±Infinity, x) = ±pi/2 for finite x\r\n * atan2(±Infinity, -Infinity) = ±3*pi/4\r\n * atan2(±Infinity, +Infinity) = ±pi/4\r\n * atan2(NaN, x) = NaN\r\n * atan2(y, NaN) = NaN\r\n *\r\n */\r\nfunction atan2(y, x) {\r\n y = new this(y);\r\n x = new this(x);\r\n var r,\r\n pr = this.precision,\r\n rm = this.rounding,\r\n wpr = pr + 4;\r\n\r\n // Either NaN\r\n if (!y.s || !x.s) {\r\n r = new this(NaN);\r\n\r\n // Both ±Infinity\r\n } else if (!y.d && !x.d) {\r\n r = getPi(this, wpr, 1).times(x.s > 0 ? 0.25 : 0.75);\r\n r.s = y.s;\r\n\r\n // x is ±Infinity or y is ±0\r\n } else if (!x.d || y.isZero()) {\r\n r = x.s < 0 ? getPi(this, pr, rm) : new this(0);\r\n r.s = y.s;\r\n\r\n // y is ±Infinity or x is ±0\r\n } else if (!y.d || x.isZero()) {\r\n r = getPi(this, wpr, 1).times(0.5);\r\n r.s = y.s;\r\n\r\n // Both non-zero and finite\r\n } else if (x.s < 0) {\r\n this.precision = wpr;\r\n this.rounding = 1;\r\n r = this.atan(divide(y, x, wpr, 1));\r\n x = getPi(this, wpr, 1);\r\n this.precision = pr;\r\n this.rounding = rm;\r\n r = y.s < 0 ? r.minus(x) : r.plus(x);\r\n } else {\r\n r = this.atan(divide(y, x, wpr, 1));\r\n }\r\n\r\n return r;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cube root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction cbrt(x) {\r\n return new this(x).cbrt();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` rounded to an integer using `ROUND_CEIL`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction ceil(x) {\r\n return finalise(x = new this(x), x.e + 1, 2);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` clamped to the range delineated by `min` and `max`.\r\n *\r\n * x {number|string|Decimal}\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\nfunction clamp(x, min, max) {\r\n return new this(x).clamp(min, max);\r\n}\r\n\r\n\r\n/*\r\n * Configure global settings for a Decimal constructor.\r\n *\r\n * `obj` is an object with one or more of the following properties,\r\n *\r\n * precision {number}\r\n * rounding {number}\r\n * toExpNeg {number}\r\n * toExpPos {number}\r\n * maxE {number}\r\n * minE {number}\r\n * modulo {number}\r\n * crypto {boolean|number}\r\n * defaults {true}\r\n *\r\n * E.g. Decimal.config({ precision: 20, rounding: 4 })\r\n *\r\n */\r\nfunction config(obj) {\r\n if (!obj || typeof obj !== 'object') throw Error(decimalError + 'Object expected');\r\n var i, p, v,\r\n useDefaults = obj.defaults === true,\r\n ps = [\r\n 'precision', 1, MAX_DIGITS,\r\n 'rounding', 0, 8,\r\n 'toExpNeg', -EXP_LIMIT, 0,\r\n 'toExpPos', 0, EXP_LIMIT,\r\n 'maxE', 0, EXP_LIMIT,\r\n 'minE', -EXP_LIMIT, 0,\r\n 'modulo', 0, 9\r\n ];\r\n\r\n for (i = 0; i < ps.length; i += 3) {\r\n if (p = ps[i], useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (mathfloor(v) === v && v >= ps[i + 1] && v <= ps[i + 2]) this[p] = v;\r\n else throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n if (p = 'crypto', useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (v === true || v === false || v === 0 || v === 1) {\r\n if (v) {\r\n if (typeof crypto != 'undefined' && crypto &&\r\n (crypto.getRandomValues || crypto.randomBytes)) {\r\n this[p] = true;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n } else {\r\n this[p] = false;\r\n }\r\n } else {\r\n throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n return this;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cosine of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction cos(x) {\r\n return new this(x).cos();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic cosine of `x`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction cosh(x) {\r\n return new this(x).cosh();\r\n}\r\n\r\n\r\n/*\r\n * Create and return a Decimal constructor with the same configuration properties as this Decimal\r\n * constructor.\r\n *\r\n */\r\nfunction clone(obj) {\r\n var i, p, ps;\r\n\r\n /*\r\n * The Decimal constructor and exported function.\r\n * Return a new Decimal instance.\r\n *\r\n * v {number|string|Decimal} A numeric value.\r\n *\r\n */\r\n function Decimal(v) {\r\n var e, i, t,\r\n x = this;\r\n\r\n // Decimal called without new.\r\n if (!(x instanceof Decimal)) return new Decimal(v);\r\n\r\n // Retain a reference to this Decimal constructor, and shadow Decimal.prototype.constructor\r\n // which points to Object.\r\n x.constructor = Decimal;\r\n\r\n // Duplicate.\r\n if (isDecimalInstance(v)) {\r\n x.s = v.s;\r\n\r\n if (external) {\r\n if (!v.d || v.e > Decimal.maxE) {\r\n\r\n // Infinity.\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (v.e < Decimal.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d.slice();\r\n }\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d ? v.d.slice() : v.d;\r\n }\r\n\r\n return;\r\n }\r\n\r\n t = typeof v;\r\n\r\n if (t === 'number') {\r\n if (v === 0) {\r\n x.s = 1 / v < 0 ? -1 : 1;\r\n x.e = 0;\r\n x.d = [0];\r\n return;\r\n }\r\n\r\n if (v < 0) {\r\n v = -v;\r\n x.s = -1;\r\n } else {\r\n x.s = 1;\r\n }\r\n\r\n // Fast path for small integers.\r\n if (v === ~~v && v < 1e7) {\r\n for (e = 0, i = v; i >= 10; i /= 10) e++;\r\n\r\n if (external) {\r\n if (e > Decimal.maxE) {\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (e < Decimal.minE) {\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n\r\n return;\r\n\r\n // Infinity, NaN.\r\n } else if (v * 0 !== 0) {\r\n if (!v) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return;\r\n }\r\n\r\n return parseDecimal(x, v.toString());\r\n\r\n } else if (t !== 'string') {\r\n throw Error(invalidArgument + v);\r\n }\r\n\r\n // Minus sign?\r\n if ((i = v.charCodeAt(0)) === 45) {\r\n v = v.slice(1);\r\n x.s = -1;\r\n } else {\r\n // Plus sign?\r\n if (i === 43) v = v.slice(1);\r\n x.s = 1;\r\n }\r\n\r\n return isDecimal.test(v) ? parseDecimal(x, v) : parseOther(x, v);\r\n }\r\n\r\n Decimal.prototype = P;\r\n\r\n Decimal.ROUND_UP = 0;\r\n Decimal.ROUND_DOWN = 1;\r\n Decimal.ROUND_CEIL = 2;\r\n Decimal.ROUND_FLOOR = 3;\r\n Decimal.ROUND_HALF_UP = 4;\r\n Decimal.ROUND_HALF_DOWN = 5;\r\n Decimal.ROUND_HALF_EVEN = 6;\r\n Decimal.ROUND_HALF_CEIL = 7;\r\n Decimal.ROUND_HALF_FLOOR = 8;\r\n Decimal.EUCLID = 9;\r\n\r\n Decimal.config = Decimal.set = config;\r\n Decimal.clone = clone;\r\n Decimal.isDecimal = isDecimalInstance;\r\n\r\n Decimal.abs = abs;\r\n Decimal.acos = acos;\r\n Decimal.acosh = acosh; // ES6\r\n Decimal.add = add;\r\n Decimal.asin = asin;\r\n Decimal.asinh = asinh; // ES6\r\n Decimal.atan = atan;\r\n Decimal.atanh = atanh; // ES6\r\n Decimal.atan2 = atan2;\r\n Decimal.cbrt = cbrt; // ES6\r\n Decimal.ceil = ceil;\r\n Decimal.clamp = clamp;\r\n Decimal.cos = cos;\r\n Decimal.cosh = cosh; // ES6\r\n Decimal.div = div;\r\n Decimal.exp = exp;\r\n Decimal.floor = floor;\r\n Decimal.hypot = hypot; // ES6\r\n Decimal.ln = ln;\r\n Decimal.log = log;\r\n Decimal.log10 = log10; // ES6\r\n Decimal.log2 = log2; // ES6\r\n Decimal.max = max;\r\n Decimal.min = min;\r\n Decimal.mod = mod;\r\n Decimal.mul = mul;\r\n Decimal.pow = pow;\r\n Decimal.random = random;\r\n Decimal.round = round;\r\n Decimal.sign = sign; // ES6\r\n Decimal.sin = sin;\r\n Decimal.sinh = sinh; // ES6\r\n Decimal.sqrt = sqrt;\r\n Decimal.sub = sub;\r\n Decimal.sum = sum;\r\n Decimal.tan = tan;\r\n Decimal.tanh = tanh; // ES6\r\n Decimal.trunc = trunc; // ES6\r\n\r\n if (obj === void 0) obj = {};\r\n if (obj) {\r\n if (obj.defaults !== true) {\r\n ps = ['precision', 'rounding', 'toExpNeg', 'toExpPos', 'maxE', 'minE', 'modulo', 'crypto'];\r\n for (i = 0; i < ps.length;) if (!obj.hasOwnProperty(p = ps[i++])) obj[p] = this[p];\r\n }\r\n }\r\n\r\n Decimal.config(obj);\r\n\r\n return Decimal;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` divided by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction div(x, y) {\r\n return new this(x).div(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The power to which to raise the base of the natural log.\r\n *\r\n */\r\nfunction exp(x) {\r\n return new this(x).exp();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` round to an integer using `ROUND_FLOOR`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction floor(x) {\r\n return finalise(x = new this(x), x.e + 1, 3);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of the sum of the squares of the arguments,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * hypot(a, b, ...) = sqrt(a^2 + b^2 + ...)\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction hypot() {\r\n var i, n,\r\n t = new this(0);\r\n\r\n external = false;\r\n\r\n for (i = 0; i < arguments.length;) {\r\n n = new this(arguments[i++]);\r\n if (!n.d) {\r\n if (n.s) {\r\n external = true;\r\n return new this(1 / 0);\r\n }\r\n t = n;\r\n } else if (t.d) {\r\n t = t.plus(n.times(n));\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return t.sqrt();\r\n}\r\n\r\n\r\n/*\r\n * Return true if object is a Decimal instance (where Decimal is any Decimal constructor),\r\n * otherwise return false.\r\n *\r\n */\r\nfunction isDecimalInstance(obj) {\r\n return obj instanceof Decimal || obj && obj.toStringTag === tag || false;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction ln(x) {\r\n return new this(x).ln();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the log of `x` to the base `y`, or to base 10 if no base\r\n * is specified, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * log[y](x)\r\n *\r\n * x {number|string|Decimal} The argument of the logarithm.\r\n * y {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\nfunction log(x, y) {\r\n return new this(x).log(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the base 2 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction log2(x) {\r\n return new this(x).log(2);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the base 10 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction log10(x) {\r\n return new this(x).log(10);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the maximum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction max() {\r\n return maxOrMin(this, arguments, 'lt');\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the minimum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction min() {\r\n return maxOrMin(this, arguments, 'gt');\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` modulo `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction mod(x, y) {\r\n return new this(x).mod(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` multiplied by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction mul(x, y) {\r\n return new this(x).mul(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` raised to the power `y`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The base.\r\n * y {number|string|Decimal} The exponent.\r\n *\r\n */\r\nfunction pow(x, y) {\r\n return new this(x).pow(y);\r\n}\r\n\r\n\r\n/*\r\n * Returns a new Decimal with a random value equal to or greater than 0 and less than 1, and with\r\n * `sd`, or `Decimal.precision` if `sd` is omitted, significant digits (or less if trailing zeros\r\n * are produced).\r\n *\r\n * [sd] {number} Significant digits. Integer, 0 to MAX_DIGITS inclusive.\r\n *\r\n */\r\nfunction random(sd) {\r\n var d, e, k, n,\r\n i = 0,\r\n r = new this(1),\r\n rd = [];\r\n\r\n if (sd === void 0) sd = this.precision;\r\n else checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n k = Math.ceil(sd / LOG_BASE);\r\n\r\n if (!this.crypto) {\r\n for (; i < k;) rd[i++] = Math.random() * 1e7 | 0;\r\n\r\n // Browsers supporting crypto.getRandomValues.\r\n } else if (crypto.getRandomValues) {\r\n d = crypto.getRandomValues(new Uint32Array(k));\r\n\r\n for (; i < k;) {\r\n n = d[i];\r\n\r\n // 0 <= n < 4294967296\r\n // Probability n >= 4.29e9, is 4967296 / 4294967296 = 0.00116 (1 in 865).\r\n if (n >= 4.29e9) {\r\n d[i] = crypto.getRandomValues(new Uint32Array(1))[0];\r\n } else {\r\n\r\n // 0 <= n <= 4289999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd[i++] = n % 1e7;\r\n }\r\n }\r\n\r\n // Node.js supporting crypto.randomBytes.\r\n } else if (crypto.randomBytes) {\r\n\r\n // buffer\r\n d = crypto.randomBytes(k *= 4);\r\n\r\n for (; i < k;) {\r\n\r\n // 0 <= n < 2147483648\r\n n = d[i] + (d[i + 1] << 8) + (d[i + 2] << 16) + ((d[i + 3] & 0x7f) << 24);\r\n\r\n // Probability n >= 2.14e9, is 7483648 / 2147483648 = 0.0035 (1 in 286).\r\n if (n >= 2.14e9) {\r\n crypto.randomBytes(4).copy(d, i);\r\n } else {\r\n\r\n // 0 <= n <= 2139999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd.push(n % 1e7);\r\n i += 4;\r\n }\r\n }\r\n\r\n i = k / 4;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n\r\n k = rd[--i];\r\n sd %= LOG_BASE;\r\n\r\n // Convert trailing digits to zeros according to sd.\r\n if (k && sd) {\r\n n = mathpow(10, LOG_BASE - sd);\r\n rd[i] = (k / n | 0) * n;\r\n }\r\n\r\n // Remove trailing words which are zero.\r\n for (; rd[i] === 0; i--) rd.pop();\r\n\r\n // Zero?\r\n if (i < 0) {\r\n e = 0;\r\n rd = [0];\r\n } else {\r\n e = -1;\r\n\r\n // Remove leading words which are zero and adjust exponent accordingly.\r\n for (; rd[0] === 0; e -= LOG_BASE) rd.shift();\r\n\r\n // Count the digits of the first word of rd to determine leading zeros.\r\n for (k = 1, n = rd[0]; n >= 10; n /= 10) k++;\r\n\r\n // Adjust the exponent for leading zeros of the first word of rd.\r\n if (k < LOG_BASE) e -= LOG_BASE - k;\r\n }\r\n\r\n r.e = e;\r\n r.d = rd;\r\n\r\n return r;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` rounded to an integer using rounding mode `rounding`.\r\n *\r\n * To emulate `Math.round`, set rounding to 7 (ROUND_HALF_CEIL).\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction round(x) {\r\n return finalise(x = new this(x), x.e + 1, this.rounding);\r\n}\r\n\r\n\r\n/*\r\n * Return\r\n * 1 if x > 0,\r\n * -1 if x < 0,\r\n * 0 if x is 0,\r\n * -0 if x is -0,\r\n * NaN otherwise\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction sign(x) {\r\n x = new this(x);\r\n return x.d ? (x.d[0] ? x.s : 0 * x.s) : x.s || NaN;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sine of `x`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction sin(x) {\r\n return new this(x).sin();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic sine of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction sinh(x) {\r\n return new this(x).sinh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction sqrt(x) {\r\n return new this(x).sqrt();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` minus `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction sub(x, y) {\r\n return new this(x).sub(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sum of the arguments, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * Only the result is rounded, not the intermediate calculations.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction sum() {\r\n var i = 0,\r\n args = arguments,\r\n x = new this(args[i]);\r\n\r\n external = false;\r\n for (; x.s && ++i < args.length;) x = x.plus(args[i]);\r\n external = true;\r\n\r\n return finalise(x, this.precision, this.rounding);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the tangent of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction tan(x) {\r\n return new this(x).tan();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic tangent of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction tanh(x) {\r\n return new this(x).tanh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` truncated to an integer.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction trunc(x) {\r\n return finalise(x = new this(x), x.e + 1, 1);\r\n}\r\n\r\n\r\nP[Symbol.for('nodejs.util.inspect.custom')] = P.toString;\r\nP[Symbol.toStringTag] = 'Decimal';\r\n\r\n// Create and configure initial Decimal constructor.\r\nexport var Decimal = P.constructor = clone(DEFAULTS);\r\n\r\n// Create the internal constants from their string values.\r\nLN10 = new Decimal(LN10);\r\nPI = new Decimal(PI);\r\n\r\nexport default Decimal;\r\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'BigNumber'\nconst dependencies = ['?on', 'config']\n\nexport const createBigNumberClass = /* #__PURE__ */ factory(name, dependencies, ({ on, config }) => {\n const BigNumber = Decimal.clone({ precision: config.precision, modulo: Decimal.EUCLID })\n BigNumber.prototype = Object.create(BigNumber.prototype)\n\n /**\n * Attach type information\n */\n BigNumber.prototype.type = 'BigNumber'\n BigNumber.prototype.isBigNumber = true\n\n /**\n * Get a JSON representation of a BigNumber containing\n * type information\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"BigNumber\", \"value\": \"0.2\"}`\n */\n BigNumber.prototype.toJSON = function () {\n return {\n mathjs: 'BigNumber',\n value: this.toString()\n }\n }\n\n /**\n * Instantiate a BigNumber from a JSON object\n * @param {Object} json a JSON object structured as:\n * `{\"mathjs\": \"BigNumber\", \"value\": \"0.2\"}`\n * @return {BigNumber}\n */\n BigNumber.fromJSON = function (json) {\n return new BigNumber(json.value)\n }\n\n if (on) {\n // listen for changed in the configuration, automatically apply changed precision\n on('config', function (curr, prev) {\n if (curr.precision !== prev.precision) {\n BigNumber.config({ precision: curr.precision })\n }\n })\n }\n\n return BigNumber\n}, { isClass: true })\n","import Complex from 'complex.js'\nimport { format } from '../../utils/number.js'\nimport { isNumber, isUnit } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Complex'\nconst dependencies = []\n\nexport const createComplexClass = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * Attach type information\n */\n Object.defineProperty(Complex, 'name', { value: 'Complex' })\n Complex.prototype.constructor = Complex\n Complex.prototype.type = 'Complex'\n Complex.prototype.isComplex = true\n\n /**\n * Get a JSON representation of the complex number\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Complex\", \"re\": 2, \"im\": 3}`\n */\n Complex.prototype.toJSON = function () {\n return {\n mathjs: 'Complex',\n re: this.re,\n im: this.im\n }\n }\n\n /*\n * Return the value of the complex number in polar notation\n * The angle phi will be set in the interval of [-pi, pi].\n * @return {{r: number, phi: number}} Returns and object with properties r and phi.\n */\n Complex.prototype.toPolar = function () {\n return {\n r: this.abs(),\n phi: this.arg()\n }\n }\n\n /**\n * Get a string representation of the complex number,\n * with optional formatting options.\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @return {string} str\n */\n Complex.prototype.format = function (options) {\n let str = ''\n let im = this.im\n let re = this.re\n const strRe = format(this.re, options)\n const strIm = format(this.im, options)\n\n // round either re or im when smaller than the configured precision\n const precision = isNumber(options) ? options : options ? options.precision : null\n if (precision !== null) {\n const epsilon = Math.pow(10, -precision)\n if (Math.abs(re / im) < epsilon) {\n re = 0\n }\n if (Math.abs(im / re) < epsilon) {\n im = 0\n }\n }\n\n if (im === 0) {\n // real value\n str = strRe\n } else if (re === 0) {\n // purely complex value\n if (im === 1) {\n str = 'i'\n } else if (im === -1) {\n str = '-i'\n } else {\n str = strIm + 'i'\n }\n } else {\n // complex value\n if (im < 0) {\n if (im === -1) {\n str = strRe + ' - i'\n } else {\n str = strRe + ' - ' + strIm.substring(1) + 'i'\n }\n } else {\n if (im === 1) {\n str = strRe + ' + i'\n } else {\n str = strRe + ' + ' + strIm + 'i'\n }\n }\n }\n return str\n }\n\n /**\n * Create a complex number from polar coordinates\n *\n * Usage:\n *\n * Complex.fromPolar(r: number, phi: number) : Complex\n * Complex.fromPolar({r: number, phi: number}) : Complex\n *\n * @param {*} args...\n * @return {Complex}\n */\n Complex.fromPolar = function (args) {\n switch (arguments.length) {\n case 1:\n {\n const arg = arguments[0]\n if (typeof arg === 'object') {\n return Complex(arg)\n } else {\n throw new TypeError('Input has to be an object with r and phi keys.')\n }\n }\n case 2:\n {\n const r = arguments[0]\n let phi = arguments[1]\n if (isNumber(r)) {\n if (isUnit(phi) && phi.hasBase('ANGLE')) {\n // convert unit to a number in radians\n phi = phi.toNumber('rad')\n }\n\n if (isNumber(phi)) {\n return new Complex({ r, phi })\n }\n\n throw new TypeError('Phi is not a number nor an angle unit.')\n } else {\n throw new TypeError('Radius r is not a number.')\n }\n }\n\n default:\n throw new SyntaxError('Wrong number of arguments in function fromPolar')\n }\n }\n\n Complex.prototype.valueOf = Complex.prototype.toString\n\n /**\n * Create a Complex number from a JSON object\n * @param {Object} json A JSON Object structured as\n * {\"mathjs\": \"Complex\", \"re\": 2, \"im\": 3}\n * All properties are optional, default values\n * for `re` and `im` are 0.\n * @return {Complex} Returns a new Complex number\n */\n Complex.fromJSON = function (json) {\n return new Complex(json)\n }\n\n /**\n * Compare two complex numbers, `a` and `b`:\n *\n * - Returns 1 when the real part of `a` is larger than the real part of `b`\n * - Returns -1 when the real part of `a` is smaller than the real part of `b`\n * - Returns 1 when the real parts are equal\n * and the imaginary part of `a` is larger than the imaginary part of `b`\n * - Returns -1 when the real parts are equal\n * and the imaginary part of `a` is smaller than the imaginary part of `b`\n * - Returns 0 when both real and imaginary parts are equal.\n *\n * @params {Complex} a\n * @params {Complex} b\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n Complex.compare = function (a, b) {\n if (a.re > b.re) { return 1 }\n if (a.re < b.re) { return -1 }\n\n if (a.im > b.im) { return 1 }\n if (a.im < b.im) { return -1 }\n\n return 0\n }\n\n return Complex\n}, { isClass: true })\n","/**\n * @license Fraction.js v4.3.7 31/08/2023\n * https://www.xarg.org/2014/03/rational-numbers-in-javascript/\n *\n * Copyright (c) 2023, Robert Eisele (robert@raw.org)\n * Dual licensed under the MIT or GPL Version 2 licenses.\n **/\n\n\n/**\n *\n * This class offers the possibility to calculate fractions.\n * You can pass a fraction in different formats. Either as array, as double, as string or as an integer.\n *\n * Array/Object form\n * [ 0 => , 1 => ]\n * [ n => , d => ]\n *\n * Integer form\n * - Single integer value\n *\n * Double form\n * - Single double value\n *\n * String form\n * 123.456 - a simple double\n * 123/456 - a string fraction\n * 123.'456' - a double with repeating decimal places\n * 123.(456) - synonym\n * 123.45'6' - a double with repeating last place\n * 123.45(6) - synonym\n *\n * Example:\n *\n * var f = new Fraction(\"9.4'31'\");\n * f.mul([-4, 3]).div(4.9);\n *\n */\n\n\n// Maximum search depth for cyclic rational numbers. 2000 should be more than enough.\n// Example: 1/7 = 0.(142857) has 6 repeating decimal places.\n// If MAX_CYCLE_LEN gets reduced, long cycles will not be detected and toString() only gets the first 10 digits\nvar MAX_CYCLE_LEN = 2000;\n\n// Parsed data to avoid calling \"new\" all the time\nvar P = {\n \"s\": 1,\n \"n\": 0,\n \"d\": 1\n};\n\nfunction assign(n, s) {\n\n if (isNaN(n = parseInt(n, 10))) {\n throw InvalidParameter();\n }\n return n * s;\n}\n\n// Creates a new Fraction internally without the need of the bulky constructor\nfunction newFraction(n, d) {\n\n if (d === 0) {\n throw DivisionByZero();\n }\n\n var f = Object.create(Fraction.prototype);\n f[\"s\"] = n < 0 ? -1 : 1;\n\n n = n < 0 ? -n : n;\n\n var a = gcd(n, d);\n\n f[\"n\"] = n / a;\n f[\"d\"] = d / a;\n return f;\n}\n\nfunction factorize(num) {\n\n var factors = {};\n\n var n = num;\n var i = 2;\n var s = 4;\n\n while (s <= n) {\n\n while (n % i === 0) {\n n/= i;\n factors[i] = (factors[i] || 0) + 1;\n }\n s+= 1 + 2 * i++;\n }\n\n if (n !== num) {\n if (n > 1)\n factors[n] = (factors[n] || 0) + 1;\n } else {\n factors[num] = (factors[num] || 0) + 1;\n }\n return factors;\n}\n\nvar parse = function(p1, p2) {\n\n var n = 0, d = 1, s = 1;\n var v = 0, w = 0, x = 0, y = 1, z = 1;\n\n var A = 0, B = 1;\n var C = 1, D = 1;\n\n var N = 10000000;\n var M;\n\n if (p1 === undefined || p1 === null) {\n /* void */\n } else if (p2 !== undefined) {\n n = p1;\n d = p2;\n s = n * d;\n\n if (n % 1 !== 0 || d % 1 !== 0) {\n throw NonIntegerParameter();\n }\n\n } else\n switch (typeof p1) {\n\n case \"object\":\n {\n if (\"d\" in p1 && \"n\" in p1) {\n n = p1[\"n\"];\n d = p1[\"d\"];\n if (\"s\" in p1)\n n*= p1[\"s\"];\n } else if (0 in p1) {\n n = p1[0];\n if (1 in p1)\n d = p1[1];\n } else {\n throw InvalidParameter();\n }\n s = n * d;\n break;\n }\n case \"number\":\n {\n if (p1 < 0) {\n s = p1;\n p1 = -p1;\n }\n\n if (p1 % 1 === 0) {\n n = p1;\n } else if (p1 > 0) { // check for != 0, scale would become NaN (log(0)), which converges really slow\n\n if (p1 >= 1) {\n z = Math.pow(10, Math.floor(1 + Math.log(p1) / Math.LN10));\n p1/= z;\n }\n\n // Using Farey Sequences\n // http://www.johndcook.com/blog/2010/10/20/best-rational-approximation/\n\n while (B <= N && D <= N) {\n M = (A + C) / (B + D);\n\n if (p1 === M) {\n if (B + D <= N) {\n n = A + C;\n d = B + D;\n } else if (D > B) {\n n = C;\n d = D;\n } else {\n n = A;\n d = B;\n }\n break;\n\n } else {\n\n if (p1 > M) {\n A+= C;\n B+= D;\n } else {\n C+= A;\n D+= B;\n }\n\n if (B > N) {\n n = C;\n d = D;\n } else {\n n = A;\n d = B;\n }\n }\n }\n n*= z;\n } else if (isNaN(p1) || isNaN(p2)) {\n d = n = NaN;\n }\n break;\n }\n case \"string\":\n {\n B = p1.match(/\\d+|./g);\n\n if (B === null)\n throw InvalidParameter();\n\n if (B[A] === '-') {// Check for minus sign at the beginning\n s = -1;\n A++;\n } else if (B[A] === '+') {// Check for plus sign at the beginning\n A++;\n }\n\n if (B.length === A + 1) { // Check if it's just a simple number \"1234\"\n w = assign(B[A++], s);\n } else if (B[A + 1] === '.' || B[A] === '.') { // Check if it's a decimal number\n\n if (B[A] !== '.') { // Handle 0.5 and .5\n v = assign(B[A++], s);\n }\n A++;\n\n // Check for decimal places\n if (A + 1 === B.length || B[A + 1] === '(' && B[A + 3] === ')' || B[A + 1] === \"'\" && B[A + 3] === \"'\") {\n w = assign(B[A], s);\n y = Math.pow(10, B[A].length);\n A++;\n }\n\n // Check for repeating places\n if (B[A] === '(' && B[A + 2] === ')' || B[A] === \"'\" && B[A + 2] === \"'\") {\n x = assign(B[A + 1], s);\n z = Math.pow(10, B[A + 1].length) - 1;\n A+= 3;\n }\n\n } else if (B[A + 1] === '/' || B[A + 1] === ':') { // Check for a simple fraction \"123/456\" or \"123:456\"\n w = assign(B[A], s);\n y = assign(B[A + 2], 1);\n A+= 3;\n } else if (B[A + 3] === '/' && B[A + 1] === ' ') { // Check for a complex fraction \"123 1/2\"\n v = assign(B[A], s);\n w = assign(B[A + 2], s);\n y = assign(B[A + 4], 1);\n A+= 5;\n }\n\n if (B.length <= A) { // Check for more tokens on the stack\n d = y * z;\n s = /* void */\n n = x + d * v + z * w;\n break;\n }\n\n /* Fall through on error */\n }\n default:\n throw InvalidParameter();\n }\n\n if (d === 0) {\n throw DivisionByZero();\n }\n\n P[\"s\"] = s < 0 ? -1 : 1;\n P[\"n\"] = Math.abs(n);\n P[\"d\"] = Math.abs(d);\n};\n\nfunction modpow(b, e, m) {\n\n var r = 1;\n for (; e > 0; b = (b * b) % m, e >>= 1) {\n\n if (e & 1) {\n r = (r * b) % m;\n }\n }\n return r;\n}\n\n\nfunction cycleLen(n, d) {\n\n for (; d % 2 === 0;\n d/= 2) {\n }\n\n for (; d % 5 === 0;\n d/= 5) {\n }\n\n if (d === 1) // Catch non-cyclic numbers\n return 0;\n\n // If we would like to compute really large numbers quicker, we could make use of Fermat's little theorem:\n // 10^(d-1) % d == 1\n // However, we don't need such large numbers and MAX_CYCLE_LEN should be the capstone,\n // as we want to translate the numbers to strings.\n\n var rem = 10 % d;\n var t = 1;\n\n for (; rem !== 1; t++) {\n rem = rem * 10 % d;\n\n if (t > MAX_CYCLE_LEN)\n return 0; // Returning 0 here means that we don't print it as a cyclic number. It's likely that the answer is `d-1`\n }\n return t;\n}\n\n\nfunction cycleStart(n, d, len) {\n\n var rem1 = 1;\n var rem2 = modpow(10, len, d);\n\n for (var t = 0; t < 300; t++) { // s < ~log10(Number.MAX_VALUE)\n // Solve 10^s == 10^(s+t) (mod d)\n\n if (rem1 === rem2)\n return t;\n\n rem1 = rem1 * 10 % d;\n rem2 = rem2 * 10 % d;\n }\n return 0;\n}\n\nfunction gcd(a, b) {\n\n if (!a)\n return b;\n if (!b)\n return a;\n\n while (1) {\n a%= b;\n if (!a)\n return b;\n b%= a;\n if (!b)\n return a;\n }\n};\n\n/**\n * Module constructor\n *\n * @constructor\n * @param {number|Fraction=} a\n * @param {number=} b\n */\nexport default function Fraction(a, b) {\n\n parse(a, b);\n\n if (this instanceof Fraction) {\n a = gcd(P[\"d\"], P[\"n\"]); // Abuse variable a\n this[\"s\"] = P[\"s\"];\n this[\"n\"] = P[\"n\"] / a;\n this[\"d\"] = P[\"d\"] / a;\n } else {\n return newFraction(P['s'] * P['n'], P['d']);\n }\n}\n\nvar DivisionByZero = function() { return new Error(\"Division by Zero\"); };\nvar InvalidParameter = function() { return new Error(\"Invalid argument\"); };\nvar NonIntegerParameter = function() { return new Error(\"Parameters must be integer\"); };\n\nFraction.prototype = {\n\n \"s\": 1,\n \"n\": 0,\n \"d\": 1,\n\n /**\n * Calculates the absolute value\n *\n * Ex: new Fraction(-4).abs() => 4\n **/\n \"abs\": function() {\n\n return newFraction(this[\"n\"], this[\"d\"]);\n },\n\n /**\n * Inverts the sign of the current fraction\n *\n * Ex: new Fraction(-4).neg() => 4\n **/\n \"neg\": function() {\n\n return newFraction(-this[\"s\"] * this[\"n\"], this[\"d\"]);\n },\n\n /**\n * Adds two rational numbers\n *\n * Ex: new Fraction({n: 2, d: 3}).add(\"14.9\") => 467 / 30\n **/\n \"add\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * this[\"n\"] * P[\"d\"] + P[\"s\"] * this[\"d\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Subtracts two rational numbers\n *\n * Ex: new Fraction({n: 2, d: 3}).add(\"14.9\") => -427 / 30\n **/\n \"sub\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * this[\"n\"] * P[\"d\"] - P[\"s\"] * this[\"d\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Multiplies two rational numbers\n *\n * Ex: new Fraction(\"-17.(345)\").mul(3) => 5776 / 111\n **/\n \"mul\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * P[\"s\"] * this[\"n\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Divides two rational numbers\n *\n * Ex: new Fraction(\"-17.(345)\").inverse().div(3)\n **/\n \"div\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * P[\"s\"] * this[\"n\"] * P[\"d\"],\n this[\"d\"] * P[\"n\"]\n );\n },\n\n /**\n * Clones the actual object\n *\n * Ex: new Fraction(\"-17.(345)\").clone()\n **/\n \"clone\": function() {\n return newFraction(this['s'] * this['n'], this['d']);\n },\n\n /**\n * Calculates the modulo of two rational numbers - a more precise fmod\n *\n * Ex: new Fraction('4.(3)').mod([7, 8]) => (13/3) % (7/8) = (5/6)\n **/\n \"mod\": function(a, b) {\n\n if (isNaN(this['n']) || isNaN(this['d'])) {\n return new Fraction(NaN);\n }\n\n if (a === undefined) {\n return newFraction(this[\"s\"] * this[\"n\"] % this[\"d\"], 1);\n }\n\n parse(a, b);\n if (0 === P[\"n\"] && 0 === this[\"d\"]) {\n throw DivisionByZero();\n }\n\n /*\n * First silly attempt, kinda slow\n *\n return that[\"sub\"]({\n \"n\": num[\"n\"] * Math.floor((this.n / this.d) / (num.n / num.d)),\n \"d\": num[\"d\"],\n \"s\": this[\"s\"]\n });*/\n\n /*\n * New attempt: a1 / b1 = a2 / b2 * q + r\n * => b2 * a1 = a2 * b1 * q + b1 * b2 * r\n * => (b2 * a1 % a2 * b1) / (b1 * b2)\n */\n return newFraction(\n this[\"s\"] * (P[\"d\"] * this[\"n\"]) % (P[\"n\"] * this[\"d\"]),\n P[\"d\"] * this[\"d\"]\n );\n },\n\n /**\n * Calculates the fractional gcd of two rational numbers\n *\n * Ex: new Fraction(5,8).gcd(3,7) => 1/56\n */\n \"gcd\": function(a, b) {\n\n parse(a, b);\n\n // gcd(a / b, c / d) = gcd(a, c) / lcm(b, d)\n\n return newFraction(gcd(P[\"n\"], this[\"n\"]) * gcd(P[\"d\"], this[\"d\"]), P[\"d\"] * this[\"d\"]);\n },\n\n /**\n * Calculates the fractional lcm of two rational numbers\n *\n * Ex: new Fraction(5,8).lcm(3,7) => 15\n */\n \"lcm\": function(a, b) {\n\n parse(a, b);\n\n // lcm(a / b, c / d) = lcm(a, c) / gcd(b, d)\n\n if (P[\"n\"] === 0 && this[\"n\"] === 0) {\n return newFraction(0, 1);\n }\n return newFraction(P[\"n\"] * this[\"n\"], gcd(P[\"n\"], this[\"n\"]) * gcd(P[\"d\"], this[\"d\"]));\n },\n\n /**\n * Calculates the ceil of a rational number\n *\n * Ex: new Fraction('4.(3)').ceil() => (5 / 1)\n **/\n \"ceil\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.ceil(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Calculates the floor of a rational number\n *\n * Ex: new Fraction('4.(3)').floor() => (4 / 1)\n **/\n \"floor\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.floor(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Rounds a rational number\n *\n * Ex: new Fraction('4.(3)').round() => (4 / 1)\n **/\n \"round\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.round(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Rounds a rational number to a multiple of another rational number\n *\n * Ex: new Fraction('0.9').roundTo(\"1/8\") => 7 / 8\n **/\n \"roundTo\": function(a, b) {\n\n /*\n k * x/y ≤ a/b < (k+1) * x/y\n ⇔ k ≤ a/b / (x/y) < (k+1)\n ⇔ k = floor(a/b * y/x)\n */\n\n parse(a, b);\n\n return newFraction(this['s'] * Math.round(this['n'] * P['d'] / (this['d'] * P['n'])) * P['n'], P['d']);\n },\n\n /**\n * Gets the inverse of the fraction, means numerator and denominator are exchanged\n *\n * Ex: new Fraction([-3, 4]).inverse() => -4 / 3\n **/\n \"inverse\": function() {\n\n return newFraction(this[\"s\"] * this[\"d\"], this[\"n\"]);\n },\n\n /**\n * Calculates the fraction to some rational exponent, if possible\n *\n * Ex: new Fraction(-1,2).pow(-3) => -8\n */\n \"pow\": function(a, b) {\n\n parse(a, b);\n\n // Trivial case when exp is an integer\n\n if (P['d'] === 1) {\n\n if (P['s'] < 0) {\n return newFraction(Math.pow(this['s'] * this[\"d\"], P['n']), Math.pow(this[\"n\"], P['n']));\n } else {\n return newFraction(Math.pow(this['s'] * this[\"n\"], P['n']), Math.pow(this[\"d\"], P['n']));\n }\n }\n\n // Negative roots become complex\n // (-a/b)^(c/d) = x\n // <=> (-1)^(c/d) * (a/b)^(c/d) = x\n // <=> (cos(pi) + i*sin(pi))^(c/d) * (a/b)^(c/d) = x # rotate 1 by 180°\n // <=> (cos(c*pi/d) + i*sin(c*pi/d)) * (a/b)^(c/d) = x # DeMoivre's formula in Q ( https://proofwiki.org/wiki/De_Moivre%27s_Formula/Rational_Index )\n // From which follows that only for c=0 the root is non-complex. c/d is a reduced fraction, so that sin(c/dpi)=0 occurs for d=1, which is handled by our trivial case.\n if (this['s'] < 0) return null;\n\n // Now prime factor n and d\n var N = factorize(this['n']);\n var D = factorize(this['d']);\n\n // Exponentiate and take root for n and d individually\n var n = 1;\n var d = 1;\n for (var k in N) {\n if (k === '1') continue;\n if (k === '0') {\n n = 0;\n break;\n }\n N[k]*= P['n'];\n\n if (N[k] % P['d'] === 0) {\n N[k]/= P['d'];\n } else return null;\n n*= Math.pow(k, N[k]);\n }\n\n for (var k in D) {\n if (k === '1') continue;\n D[k]*= P['n'];\n\n if (D[k] % P['d'] === 0) {\n D[k]/= P['d'];\n } else return null;\n d*= Math.pow(k, D[k]);\n }\n\n if (P['s'] < 0) {\n return newFraction(d, n);\n }\n return newFraction(n, d);\n },\n\n /**\n * Check if two rational numbers are the same\n *\n * Ex: new Fraction(19.6).equals([98, 5]);\n **/\n \"equals\": function(a, b) {\n\n parse(a, b);\n return this[\"s\"] * this[\"n\"] * P[\"d\"] === P[\"s\"] * P[\"n\"] * this[\"d\"]; // Same as compare() === 0\n },\n\n /**\n * Check if two rational numbers are the same\n *\n * Ex: new Fraction(19.6).equals([98, 5]);\n **/\n \"compare\": function(a, b) {\n\n parse(a, b);\n var t = (this[\"s\"] * this[\"n\"] * P[\"d\"] - P[\"s\"] * P[\"n\"] * this[\"d\"]);\n return (0 < t) - (t < 0);\n },\n\n \"simplify\": function(eps) {\n\n if (isNaN(this['n']) || isNaN(this['d'])) {\n return this;\n }\n\n eps = eps || 0.001;\n\n var thisABS = this['abs']();\n var cont = thisABS['toContinued']();\n\n for (var i = 1; i < cont.length; i++) {\n\n var s = newFraction(cont[i - 1], 1);\n for (var k = i - 2; k >= 0; k--) {\n s = s['inverse']()['add'](cont[k]);\n }\n\n if (Math.abs(s['sub'](thisABS).valueOf()) < eps) {\n return s['mul'](this['s']);\n }\n }\n return this;\n },\n\n /**\n * Check if two rational numbers are divisible\n *\n * Ex: new Fraction(19.6).divisible(1.5);\n */\n \"divisible\": function(a, b) {\n\n parse(a, b);\n return !(!(P[\"n\"] * this[\"d\"]) || ((this[\"n\"] * P[\"d\"]) % (P[\"n\"] * this[\"d\"])));\n },\n\n /**\n * Returns a decimal representation of the fraction\n *\n * Ex: new Fraction(\"100.'91823'\").valueOf() => 100.91823918239183\n **/\n 'valueOf': function() {\n\n return this[\"s\"] * this[\"n\"] / this[\"d\"];\n },\n\n /**\n * Returns a string-fraction representation of a Fraction object\n *\n * Ex: new Fraction(\"1.'3'\").toFraction(true) => \"4 1/3\"\n **/\n 'toFraction': function(excludeWhole) {\n\n var whole, str = \"\";\n var n = this[\"n\"];\n var d = this[\"d\"];\n if (this[\"s\"] < 0) {\n str+= '-';\n }\n\n if (d === 1) {\n str+= n;\n } else {\n\n if (excludeWhole && (whole = Math.floor(n / d)) > 0) {\n str+= whole;\n str+= \" \";\n n%= d;\n }\n\n str+= n;\n str+= '/';\n str+= d;\n }\n return str;\n },\n\n /**\n * Returns a latex representation of a Fraction object\n *\n * Ex: new Fraction(\"1.'3'\").toLatex() => \"\\frac{4}{3}\"\n **/\n 'toLatex': function(excludeWhole) {\n\n var whole, str = \"\";\n var n = this[\"n\"];\n var d = this[\"d\"];\n if (this[\"s\"] < 0) {\n str+= '-';\n }\n\n if (d === 1) {\n str+= n;\n } else {\n\n if (excludeWhole && (whole = Math.floor(n / d)) > 0) {\n str+= whole;\n n%= d;\n }\n\n str+= \"\\\\frac{\";\n str+= n;\n str+= '}{';\n str+= d;\n str+= '}';\n }\n return str;\n },\n\n /**\n * Returns an array of continued fraction elements\n *\n * Ex: new Fraction(\"7/8\").toContinued() => [0,1,7]\n */\n 'toContinued': function() {\n\n var t;\n var a = this['n'];\n var b = this['d'];\n var res = [];\n\n if (isNaN(a) || isNaN(b)) {\n return res;\n }\n\n do {\n res.push(Math.floor(a / b));\n t = a % b;\n a = b;\n b = t;\n } while (a !== 1);\n\n return res;\n },\n\n /**\n * Creates a string representation of a fraction with all digits\n *\n * Ex: new Fraction(\"100.'91823'\").toString() => \"100.(91823)\"\n **/\n 'toString': function(dec) {\n\n var N = this[\"n\"];\n var D = this[\"d\"];\n\n if (isNaN(N) || isNaN(D)) {\n return \"NaN\";\n }\n\n dec = dec || 15; // 15 = decimal places when no repetation\n\n var cycLen = cycleLen(N, D); // Cycle length\n var cycOff = cycleStart(N, D, cycLen); // Cycle start\n\n var str = this['s'] < 0 ? \"-\" : \"\";\n\n str+= N / D | 0;\n\n N%= D;\n N*= 10;\n\n if (N)\n str+= \".\";\n\n if (cycLen) {\n\n for (var i = cycOff; i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n str+= \"(\";\n for (var i = cycLen; i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n str+= \")\";\n } else {\n for (var i = dec; N && i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n }\n return str;\n }\n};\n","import Fraction from 'fraction.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Fraction'\nconst dependencies = []\n\nexport const createFractionClass = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * Attach type information\n */\n Object.defineProperty(Fraction, 'name', { value: 'Fraction' })\n Fraction.prototype.constructor = Fraction\n Fraction.prototype.type = 'Fraction'\n Fraction.prototype.isFraction = true\n\n /**\n * Get a JSON representation of a Fraction containing type information\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Fraction\", \"n\": 3, \"d\": 8}`\n */\n Fraction.prototype.toJSON = function () {\n return {\n mathjs: 'Fraction',\n n: this.s * this.n,\n d: this.d\n }\n }\n\n /**\n * Instantiate a Fraction from a JSON object\n * @param {Object} json a JSON object structured as:\n * `{\"mathjs\": \"Fraction\", \"n\": 3, \"d\": 8}`\n * @return {BigNumber}\n */\n Fraction.fromJSON = function (json) {\n return new Fraction(json)\n }\n\n return Fraction\n}, { isClass: true })\n","import { isBigNumber } from '../../utils/is.js'\nimport { format, sign } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Range'\nconst dependencies = []\n\nexport const createRangeClass = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * Create a range. A range has a start, step, and end, and contains functions\n * to iterate over the range.\n *\n * A range can be constructed as:\n *\n * const range = new Range(start, end)\n * const range = new Range(start, end, step)\n *\n * To get the result of the range:\n * range.forEach(function (x) {\n * console.log(x)\n * })\n * range.map(function (x) {\n * return math.sin(x)\n * })\n * range.toArray()\n *\n * Example usage:\n *\n * const c = new Range(2, 6) // 2:1:5\n * c.toArray() // [2, 3, 4, 5]\n * const d = new Range(2, -3, -1) // 2:-1:-2\n * d.toArray() // [2, 1, 0, -1, -2]\n *\n * @class Range\n * @constructor Range\n * @param {number} start included lower bound\n * @param {number} end excluded upper bound\n * @param {number} [step] step size, default value is 1\n */\n function Range (start, end, step) {\n if (!(this instanceof Range)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n const hasStart = start !== null && start !== undefined\n const hasEnd = end !== null && end !== undefined\n const hasStep = step !== null && step !== undefined\n\n if (hasStart) {\n if (isBigNumber(start)) {\n start = start.toNumber()\n } else if (typeof start !== 'number') {\n throw new TypeError('Parameter start must be a number')\n }\n }\n if (hasEnd) {\n if (isBigNumber(end)) {\n end = end.toNumber()\n } else if (typeof end !== 'number') {\n throw new TypeError('Parameter end must be a number')\n }\n }\n if (hasStep) {\n if (isBigNumber(step)) {\n step = step.toNumber()\n } else if (typeof step !== 'number') {\n throw new TypeError('Parameter step must be a number')\n }\n }\n\n this.start = hasStart ? parseFloat(start) : 0\n this.end = hasEnd ? parseFloat(end) : 0\n this.step = hasStep ? parseFloat(step) : 1\n }\n\n /**\n * Attach type information\n */\n Range.prototype.type = 'Range'\n Range.prototype.isRange = true\n\n /**\n * Parse a string into a range,\n * The string contains the start, optional step, and end, separated by a colon.\n * If the string does not contain a valid range, null is returned.\n * For example str='0:2:11'.\n * @memberof Range\n * @param {string} str\n * @return {Range | null} range\n */\n Range.parse = function (str) {\n if (typeof str !== 'string') {\n return null\n }\n\n const args = str.split(':')\n const nums = args.map(function (arg) {\n return parseFloat(arg)\n })\n\n const invalid = nums.some(function (num) {\n return isNaN(num)\n })\n if (invalid) {\n return null\n }\n\n switch (nums.length) {\n case 2:\n return new Range(nums[0], nums[1])\n case 3:\n return new Range(nums[0], nums[2], nums[1])\n default:\n return null\n }\n }\n\n /**\n * Create a clone of the range\n * @return {Range} clone\n */\n Range.prototype.clone = function () {\n return new Range(this.start, this.end, this.step)\n }\n\n /**\n * Retrieve the size of the range.\n * Returns an array containing one number, the number of elements in the range.\n * @memberof Range\n * @returns {number[]} size\n */\n Range.prototype.size = function () {\n let len = 0\n const start = this.start\n const step = this.step\n const end = this.end\n const diff = end - start\n\n if (sign(step) === sign(diff)) {\n len = Math.ceil((diff) / step)\n } else if (diff === 0) {\n len = 0\n }\n\n if (isNaN(len)) {\n len = 0\n }\n return [len]\n }\n\n /**\n * Calculate the minimum value in the range\n * @memberof Range\n * @return {number | undefined} min\n */\n Range.prototype.min = function () {\n const size = this.size()[0]\n\n if (size > 0) {\n if (this.step > 0) {\n // positive step\n return this.start\n } else {\n // negative step\n return this.start + (size - 1) * this.step\n }\n } else {\n return undefined\n }\n }\n\n /**\n * Calculate the maximum value in the range\n * @memberof Range\n * @return {number | undefined} max\n */\n Range.prototype.max = function () {\n const size = this.size()[0]\n\n if (size > 0) {\n if (this.step > 0) {\n // positive step\n return this.start + (size - 1) * this.step\n } else {\n // negative step\n return this.start\n }\n } else {\n return undefined\n }\n }\n\n /**\n * Execute a callback function for each value in the range.\n * @memberof Range\n * @param {function} callback The callback method is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Range being traversed.\n */\n Range.prototype.forEach = function (callback) {\n let x = this.start\n const step = this.step\n const end = this.end\n let i = 0\n\n if (step > 0) {\n while (x < end) {\n callback(x, [i], this)\n x += step\n i++\n }\n } else if (step < 0) {\n while (x > end) {\n callback(x, [i], this)\n x += step\n i++\n }\n }\n }\n\n /**\n * Execute a callback function for each value in the Range, and return the\n * results as an array\n * @memberof Range\n * @param {function} callback The callback method is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @returns {Array} array\n */\n Range.prototype.map = function (callback) {\n const array = []\n this.forEach(function (value, index, obj) {\n array[index[0]] = callback(value, index, obj)\n })\n return array\n }\n\n /**\n * Create an Array with a copy of the Ranges data\n * @memberof Range\n * @returns {Array} array\n */\n Range.prototype.toArray = function () {\n const array = []\n this.forEach(function (value, index) {\n array[index[0]] = value\n })\n return array\n }\n\n /**\n * Get the primitive value of the Range, a one dimensional array\n * @memberof Range\n * @returns {Array} array\n */\n Range.prototype.valueOf = function () {\n // TODO: implement a caching mechanism for range.valueOf()\n return this.toArray()\n }\n\n /**\n * Get a string representation of the range, with optional formatting options.\n * Output is formatted as 'start:step:end', for example '2:6' or '0:0.2:11'\n * @memberof Range\n * @param {Object | number | function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n Range.prototype.format = function (options) {\n let str = format(this.start, options)\n\n if (this.step !== 1) {\n str += ':' + format(this.step, options)\n }\n str += ':' + format(this.end, options)\n return str\n }\n\n /**\n * Get a string representation of the range.\n * @memberof Range\n * @returns {string}\n */\n Range.prototype.toString = function () {\n return this.format()\n }\n\n /**\n * Get a JSON representation of the range\n * @memberof Range\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Range\", \"start\": 2, \"end\": 4, \"step\": 1}`\n */\n Range.prototype.toJSON = function () {\n return {\n mathjs: 'Range',\n start: this.start,\n end: this.end,\n step: this.step\n }\n }\n\n /**\n * Instantiate a Range from a JSON object\n * @memberof Range\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Range\", \"start\": 2, \"end\": 4, \"step\": 1}`\n * @return {Range}\n */\n Range.fromJSON = function (json) {\n return new Range(json.start, json.end, json.step)\n }\n\n return Range\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'Matrix'\nconst dependencies = []\n\nexport const createMatrixClass = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * @constructor Matrix\n *\n * A Matrix is a wrapper around an Array. A matrix can hold a multi dimensional\n * array. A matrix can be constructed as:\n *\n * let matrix = math.matrix(data)\n *\n * Matrix contains the functions to resize, get and set values, get the size,\n * clone the matrix and to convert the matrix to a vector, array, or scalar.\n * Furthermore, one can iterate over the matrix using map and forEach.\n * The internal Array of the Matrix can be accessed using the function valueOf.\n *\n * Example usage:\n *\n * let matrix = math.matrix([[1, 2], [3, 4]])\n * matix.size() // [2, 2]\n * matrix.resize([3, 2], 5)\n * matrix.valueOf() // [[1, 2], [3, 4], [5, 5]]\n * matrix.subset([1,2]) // 3 (indexes are zero-based)\n *\n */\n function Matrix () {\n if (!(this instanceof Matrix)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n }\n\n /**\n * Attach type information\n */\n Matrix.prototype.type = 'Matrix'\n Matrix.prototype.isMatrix = true\n\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @return {string} The storage format.\n */\n Matrix.prototype.storage = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke storage on a Matrix interface')\n }\n\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @return {string} The datatype.\n */\n Matrix.prototype.datatype = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke datatype on a Matrix interface')\n }\n\n /**\n * Create a new Matrix With the type of the current matrix instance\n * @param {Array | Object} data\n * @param {string} [datatype]\n */\n Matrix.prototype.create = function (data, datatype) {\n throw new Error('Cannot invoke create on a Matrix interface')\n }\n\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n Matrix.prototype.subset = function (index, replacement, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke subset on a Matrix interface')\n }\n\n /**\n * Get a single element from the matrix.\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n Matrix.prototype.get = function (index) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke get on a Matrix interface')\n }\n\n /**\n * Replace a single element in the matrix.\n * @param {number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {Matrix} self\n */\n Matrix.prototype.set = function (index, value, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke set on a Matrix interface')\n }\n\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @param {number[]} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n Matrix.prototype.resize = function (size, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke resize on a Matrix interface')\n }\n\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * @param {number[]} size The new size the matrix should have.\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n Matrix.prototype.reshape = function (size, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke reshape on a Matrix interface')\n }\n\n /**\n * Create a clone of the matrix\n * @return {Matrix} clone\n */\n Matrix.prototype.clone = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke clone on a Matrix interface')\n }\n\n /**\n * Retrieve the size of the matrix.\n * @returns {number[]} size\n */\n Matrix.prototype.size = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke size on a Matrix interface')\n }\n\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {Matrix} matrix\n */\n Matrix.prototype.map = function (callback, skipZeros) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke map on a Matrix interface')\n }\n\n /**\n * Execute a callback function on each entry of the matrix.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n */\n Matrix.prototype.forEach = function (callback) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke forEach on a Matrix interface')\n }\n\n /**\n * Iterate over the matrix elements\n * @return {Iterable<{ value, index: number[] }>}\n */\n Matrix.prototype[Symbol.iterator] = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot iterate a Matrix interface')\n }\n\n /**\n * Create an Array with a copy of the data of the Matrix\n * @returns {Array} array\n */\n Matrix.prototype.toArray = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke toArray on a Matrix interface')\n }\n\n /**\n * Get the primitive value of the Matrix: a multidimensional array\n * @returns {Array} array\n */\n Matrix.prototype.valueOf = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke valueOf on a Matrix interface')\n }\n\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n Matrix.prototype.format = function (options) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke format on a Matrix interface')\n }\n\n /**\n * Get a string representation of the matrix\n * @returns {string} str\n */\n Matrix.prototype.toString = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke toString on a Matrix interface')\n }\n\n return Matrix\n}, { isClass: true })\n","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","import { isBigNumber, isNumber } from '../is.js'\nimport { isInteger, normalizeFormatOptions } from '../number.js'\n\n/**\n * Formats a BigNumber in a given base\n * @param {BigNumber} n\n * @param {number} base\n * @param {number} size\n * @returns {string}\n */\nfunction formatBigNumberToBase (n, base, size) {\n const BigNumberCtor = n.constructor\n const big2 = new BigNumberCtor(2)\n let suffix = ''\n if (size) {\n if (size < 1) {\n throw new Error('size must be in greater than 0')\n }\n if (!isInteger(size)) {\n throw new Error('size must be an integer')\n }\n if (n.greaterThan(big2.pow(size - 1).sub(1)) || n.lessThan(big2.pow(size - 1).mul(-1))) {\n throw new Error(`Value must be in range [-2^${size - 1}, 2^${size - 1}-1]`)\n }\n if (!n.isInteger()) {\n throw new Error('Value must be an integer')\n }\n if (n.lessThan(0)) {\n n = n.add(big2.pow(size))\n }\n suffix = `i${size}`\n }\n switch (base) {\n case 2: return `${n.toBinary()}${suffix}`\n case 8: return `${n.toOctal()}${suffix}`\n case 16: return `${n.toHexadecimal()}${suffix}`\n default: throw new Error(`Base ${base} not supported `)\n }\n}\n\n/**\n * Convert a BigNumber to a formatted string representation.\n *\n * Syntax:\n *\n * format(value)\n * format(value, options)\n * format(value, precision)\n * format(value, fn)\n *\n * Where:\n *\n * {number} value The value to be formatted\n * {Object} options An object with formatting options. Available options:\n * {string} notation\n * Number notation. Choose from:\n * 'fixed' Always use regular number notation.\n * For example '123.40' and '14000000'\n * 'exponential' Always use exponential notation.\n * For example '1.234e+2' and '1.4e+7'\n * 'auto' (default) Regular number notation for numbers\n * having an absolute value between\n * `lower` and `upper` bounds, and uses\n * exponential notation elsewhere.\n * Lower bound is included, upper bound\n * is excluded.\n * For example '123.4' and '1.4e7'.\n * 'bin', 'oct, or\n * 'hex' Format the number using binary, octal,\n * or hexadecimal notation.\n * For example '0b1101' and '0x10fe'.\n * {number} wordSize The word size in bits to use for formatting\n * in binary, octal, or hexadecimal notation.\n * To be used only with 'bin', 'oct', or 'hex'\n * values for 'notation' option. When this option\n * is defined the value is formatted as a signed\n * twos complement integer of the given word size\n * and the size suffix is appended to the output.\n * For example\n * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'.\n * Default value is undefined.\n * {number} precision A number between 0 and 16 to round\n * the digits of the number.\n * In case of notations 'exponential',\n * 'engineering', and 'auto',\n * `precision` defines the total\n * number of significant digits returned.\n * In case of notation 'fixed',\n * `precision` defines the number of\n * significant digits after the decimal\n * point.\n * `precision` is undefined by default.\n * {number} lowerExp Exponent determining the lower boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `-3`.\n * {number} upperExp Exponent determining the upper boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `5`.\n * {Function} fn A custom formatting function. Can be used to override the\n * built-in notations. Function `fn` is called with `value` as\n * parameter and must return a string. Is useful for example to\n * format all values inside a matrix in a particular way.\n *\n * Examples:\n *\n * format(6.4) // '6.4'\n * format(1240000) // '1.24e6'\n * format(1/3) // '0.3333333333333333'\n * format(1/3, 3) // '0.333'\n * format(21385, 2) // '21000'\n * format(12e8, {notation: 'fixed'}) // returns '1200000000'\n * format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000'\n * format(52.8, {notation: 'exponential'}) // returns '5.28e+1'\n * format(12400, {notation: 'engineering'}) // returns '12.400e+3'\n *\n * @param {BigNumber} value\n * @param {Object | Function | number | BigNumber} [options]\n * @return {string} str The formatted value\n */\nexport function format (value, options) {\n if (typeof options === 'function') {\n // handle format(value, fn)\n return options(value)\n }\n\n // handle special cases\n if (!value.isFinite()) {\n return value.isNaN() ? 'NaN' : (value.gt(0) ? 'Infinity' : '-Infinity')\n }\n\n const { notation, precision, wordSize } = normalizeFormatOptions(options)\n\n // handle the various notations\n switch (notation) {\n case 'fixed':\n return toFixed(value, precision)\n\n case 'exponential':\n return toExponential(value, precision)\n\n case 'engineering':\n return toEngineering(value, precision)\n\n case 'bin':\n return formatBigNumberToBase(value, 2, wordSize)\n\n case 'oct':\n return formatBigNumberToBase(value, 8, wordSize)\n\n case 'hex':\n return formatBigNumberToBase(value, 16, wordSize)\n\n case 'auto':\n {\n // determine lower and upper bound for exponential notation.\n // TODO: implement support for upper and lower to be BigNumbers themselves\n const lowerExp = _toNumberOrDefault(options?.lowerExp, -3)\n const upperExp = _toNumberOrDefault(options?.upperExp, 5)\n\n // handle special case zero\n if (value.isZero()) return '0'\n\n // determine whether or not to output exponential notation\n let str\n const rounded = value.toSignificantDigits(precision)\n const exp = rounded.e\n if (exp >= lowerExp && exp < upperExp) {\n // normal number notation\n str = rounded.toFixed()\n } else {\n // exponential notation\n str = toExponential(value, precision)\n }\n\n // remove trailing zeros after the decimal point\n return str.replace(/((\\.\\d*?)(0+))($|e)/, function () {\n const digits = arguments[2]\n const e = arguments[4]\n return (digits !== '.') ? digits + e : e\n })\n }\n default:\n throw new Error('Unknown notation \"' + notation + '\". ' +\n 'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.')\n }\n}\n\n/**\n * Format a BigNumber in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3'\n * @param {BigNumber} value\n * @param {number} [precision] Optional number of significant figures to return.\n */\nexport function toEngineering (value, precision) {\n // find nearest lower multiple of 3 for exponent\n const e = value.e\n const newExp = e % 3 === 0 ? e : (e < 0 ? (e - 3) - (e % 3) : e - (e % 3))\n\n // find difference in exponents, and calculate the value without exponent\n const valueWithoutExp = value.mul(Math.pow(10, -newExp))\n\n let valueStr = valueWithoutExp.toPrecision(precision)\n if (valueStr.includes('e')) {\n const BigNumber = value.constructor\n valueStr = new BigNumber(valueStr).toFixed()\n }\n\n return valueStr + 'e' + (e >= 0 ? '+' : '') + newExp.toString()\n}\n\n/**\n * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3'\n * @param {BigNumber} value\n * @param {number} [precision] Number of digits in formatted output.\n * If not provided, the maximum available digits\n * is used.\n * @returns {string} str\n */\nexport function toExponential (value, precision) {\n if (precision !== undefined) {\n return value.toExponential(precision - 1) // Note the offset of one\n } else {\n return value.toExponential()\n }\n}\n\n/**\n * Format a number with fixed notation.\n * @param {BigNumber} value\n * @param {number} [precision=undefined] Optional number of decimals after the\n * decimal point. Undefined by default.\n */\nexport function toFixed (value, precision) {\n return value.toFixed(precision)\n}\n\nfunction _toNumberOrDefault (value, defaultValue) {\n if (isNumber(value)) {\n return value\n } else if (isBigNumber(value)) {\n return value.toNumber()\n } else {\n return defaultValue\n }\n}\n","import { isBigNumber, isString, typeOf } from './is.js'\nimport { format as formatNumber } from './number.js'\nimport { format as formatBigNumber } from './bignumber/formatter.js'\n\n/**\n * Check if a text ends with a certain string.\n * @param {string} text\n * @param {string} search\n */\nexport function endsWith (text, search) {\n const start = text.length - search.length\n const end = text.length\n return (text.substring(start, end) === search)\n}\n\n/**\n * Format a value of any type into a string.\n *\n * Usage:\n * math.format(value)\n * math.format(value, precision)\n * math.format(value, options)\n *\n * When value is a function:\n *\n * - When the function has a property `syntax`, it returns this\n * syntax description.\n * - In other cases, a string `'function'` is returned.\n *\n * When `value` is an Object:\n *\n * - When the object contains a property `format` being a function, this\n * function is invoked as `value.format(options)` and the result is returned.\n * - When the object has its own `toString` method, this method is invoked\n * and the result is returned.\n * - In other cases the function will loop over all object properties and\n * return JSON object notation like '{\"a\": 2, \"b\": 3}'.\n *\n * Example usage:\n * math.format(2/7) // '0.2857142857142857'\n * math.format(math.pi, 3) // '3.14'\n * math.format(new Complex(2, 3)) // '2 + 3i'\n * math.format('hello') // '\"hello\"'\n *\n * @param {*} value Value to be stringified\n * @param {Object | number | Function} [options]\n * Formatting options. See src/utils/number.js:format for a\n * description of the available options controlling number output.\n * This generic \"format\" also supports the option property `truncate: NN`\n * giving the maximum number NN of characters to return (if there would\n * have been more, they are deleted and replaced by an ellipsis).\n * @return {string} str\n */\nexport function format (value, options) {\n const result = _format(value, options)\n if (options && typeof options === 'object' && 'truncate' in options &&\n result.length > options.truncate) {\n return result.substring(0, options.truncate - 3) + '...'\n }\n return result\n}\n\nfunction _format (value, options) {\n if (typeof value === 'number') {\n return formatNumber(value, options)\n }\n\n if (isBigNumber(value)) {\n return formatBigNumber(value, options)\n }\n\n // note: we use unsafe duck-typing here to check for Fractions, this is\n // ok here since we're only invoking toString or concatenating its values\n if (looksLikeFraction(value)) {\n if (!options || options.fraction !== 'decimal') {\n // output as ratio, like '1/3'\n return (value.s * value.n) + '/' + value.d\n } else {\n // output as decimal, like '0.(3)'\n return value.toString()\n }\n }\n\n if (Array.isArray(value)) {\n return formatArray(value, options)\n }\n\n if (isString(value)) {\n return stringify(value)\n }\n\n if (typeof value === 'function') {\n return value.syntax ? String(value.syntax) : 'function'\n }\n\n if (value && typeof value === 'object') {\n if (typeof value.format === 'function') {\n return value.format(options)\n } else if (value && value.toString(options) !== {}.toString()) {\n // this object has a non-native toString method, use that one\n return value.toString(options)\n } else {\n const entries = Object.keys(value).map(key => {\n return stringify(key) + ': ' + format(value[key], options)\n })\n\n return '{' + entries.join(', ') + '}'\n }\n }\n\n return String(value)\n}\n\n/**\n * Stringify a value into a string enclosed in double quotes.\n * Unescaped double quotes and backslashes inside the value are escaped.\n * @param {*} value\n * @return {string}\n */\nexport function stringify (value) {\n const text = String(value)\n let escaped = ''\n let i = 0\n while (i < text.length) {\n const c = text.charAt(i)\n escaped += (c in controlCharacters) ? controlCharacters[c] : c\n i++\n }\n\n return '\"' + escaped + '\"'\n}\n\nconst controlCharacters = {\n '\"': '\\\\\"',\n '\\\\': '\\\\\\\\',\n '\\b': '\\\\b',\n '\\f': '\\\\f',\n '\\n': '\\\\n',\n '\\r': '\\\\r',\n '\\t': '\\\\t'\n}\n\n/**\n * Escape special HTML characters\n * @param {*} value\n * @return {string}\n */\nexport function escape (value) {\n let text = String(value)\n text = text.replace(/&/g, '&')\n .replace(/\"/g, '"')\n .replace(/'/g, ''')\n .replace(//g, '>')\n\n return text\n}\n\n/**\n * Recursively format an n-dimensional matrix\n * Example output: \"[[1, 2], [3, 4]]\"\n * @param {Array} array\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\nfunction formatArray (array, options) {\n if (Array.isArray(array)) {\n let str = '['\n const len = array.length\n for (let i = 0; i < len; i++) {\n if (i !== 0) {\n str += ', '\n }\n str += formatArray(array[i], options)\n }\n str += ']'\n return str\n } else {\n return format(array, options)\n }\n}\n\n/**\n * Check whether a value looks like a Fraction (unsafe duck-type check)\n * @param {*} value\n * @return {boolean}\n */\nfunction looksLikeFraction (value) {\n return (value &&\n typeof value === 'object' &&\n typeof value.s === 'number' &&\n typeof value.n === 'number' &&\n typeof value.d === 'number') || false\n}\n\n/**\n * Compare two strings\n * @param {string} x\n * @param {string} y\n * @returns {number}\n */\nexport function compareText (x, y) {\n // we don't want to convert numbers to string, only accept string input\n if (!isString(x)) {\n throw new TypeError('Unexpected type of argument in function compareText ' +\n '(expected: string or Array or Matrix, actual: ' + typeOf(x) + ', index: 0)')\n }\n if (!isString(y)) {\n throw new TypeError('Unexpected type of argument in function compareText ' +\n '(expected: string or Array or Matrix, actual: ' + typeOf(y) + ', index: 1)')\n }\n\n return (x === y)\n ? 0\n : (x > y ? 1 : -1)\n}\n","/**\n * Create a range error with the message:\n * 'Dimension mismatch ( != )'\n * @param {number | number[]} actual The actual size\n * @param {number | number[]} expected The expected size\n * @param {string} [relation='!='] Optional relation between actual\n * and expected size: '!=', '<', etc.\n * @extends RangeError\n */\nexport function DimensionError (actual, expected, relation) {\n if (!(this instanceof DimensionError)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n this.actual = actual\n this.expected = expected\n this.relation = relation\n\n this.message = 'Dimension mismatch (' +\n (Array.isArray(actual) ? ('[' + actual.join(', ') + ']') : actual) +\n ' ' + (this.relation || '!=') + ' ' +\n (Array.isArray(expected) ? ('[' + expected.join(', ') + ']') : expected) +\n ')'\n\n this.stack = (new Error()).stack\n}\n\nDimensionError.prototype = new RangeError()\nDimensionError.prototype.constructor = RangeError\nDimensionError.prototype.name = 'DimensionError'\nDimensionError.prototype.isDimensionError = true\n","/**\n * Create a range error with the message:\n * 'Index out of range (index < min)'\n * 'Index out of range (index < max)'\n *\n * @param {number} index The actual index\n * @param {number} [min=0] Minimum index (included)\n * @param {number} [max] Maximum index (excluded)\n * @extends RangeError\n */\nexport function IndexError (index, min, max) {\n if (!(this instanceof IndexError)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n this.index = index\n if (arguments.length < 3) {\n this.min = 0\n this.max = min\n } else {\n this.min = min\n this.max = max\n }\n\n if (this.min !== undefined && this.index < this.min) {\n this.message = 'Index out of range (' + this.index + ' < ' + this.min + ')'\n } else if (this.max !== undefined && this.index >= this.max) {\n this.message = 'Index out of range (' + this.index + ' > ' + (this.max - 1) + ')'\n } else {\n this.message = 'Index out of range (' + this.index + ')'\n }\n\n this.stack = (new Error()).stack\n}\n\nIndexError.prototype = new RangeError()\nIndexError.prototype.constructor = RangeError\nIndexError.prototype.name = 'IndexError'\nIndexError.prototype.isIndexError = true\n","import { isInteger } from './number.js'\nimport { isNumber, isBigNumber, isArray, isString } from './is.js'\nimport { format } from './string.js'\nimport { DimensionError } from '../error/DimensionError.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { deepStrictEqual } from './object.js'\n\n/**\n * Calculate the size of a multi dimensional array.\n * This function checks the size of the first entry, it does not validate\n * whether all dimensions match. (use function `validate` for that)\n * @param {Array} x\n * @Return {Number[]} size\n */\nexport function arraySize (x) {\n const s = []\n\n while (Array.isArray(x)) {\n s.push(x.length)\n x = x[0]\n }\n\n return s\n}\n\n/**\n * Recursively validate whether each element in a multi dimensional array\n * has a size corresponding to the provided size array.\n * @param {Array} array Array to be validated\n * @param {number[]} size Array with the size of each dimension\n * @param {number} dim Current dimension\n * @throws DimensionError\n * @private\n */\nfunction _validate (array, size, dim) {\n let i\n const len = array.length\n\n if (len !== size[dim]) {\n throw new DimensionError(len, size[dim])\n }\n\n if (dim < size.length - 1) {\n // recursively validate each child array\n const dimNext = dim + 1\n for (i = 0; i < len; i++) {\n const child = array[i]\n if (!Array.isArray(child)) {\n throw new DimensionError(size.length - 1, size.length, '<')\n }\n _validate(array[i], size, dimNext)\n }\n } else {\n // last dimension. none of the childs may be an array\n for (i = 0; i < len; i++) {\n if (Array.isArray(array[i])) {\n throw new DimensionError(size.length + 1, size.length, '>')\n }\n }\n }\n}\n\n/**\n * Validate whether each element in a multi dimensional array has\n * a size corresponding to the provided size array.\n * @param {Array} array Array to be validated\n * @param {number[]} size Array with the size of each dimension\n * @throws DimensionError\n */\nexport function validate (array, size) {\n const isScalar = (size.length === 0)\n if (isScalar) {\n // scalar\n if (Array.isArray(array)) {\n throw new DimensionError(array.length, 0)\n }\n } else {\n // array\n _validate(array, size, 0)\n }\n}\n\n/**\n * Validate whether the source of the index matches the size of the Array\n * @param {Array | Matrix} array Array to be validated\n * @param {Index} index Index with the source information to validate\n * @throws DimensionError\n */\nexport function validateIndexSourceSize (value, index) {\n const valueSize = value.isMatrix ? value._size : arraySize(value)\n const sourceSize = index._sourceSize\n // checks if the source size is not null and matches the valueSize\n sourceSize.forEach((sourceDim, i) => {\n if (sourceDim !== null && sourceDim !== valueSize[i]) { throw new DimensionError(sourceDim, valueSize[i]) }\n })\n}\n\n/**\n * Test whether index is an integer number with index >= 0 and index < length\n * when length is provided\n * @param {number} index Zero-based index\n * @param {number} [length] Length of the array\n */\nexport function validateIndex (index, length) {\n if (index !== undefined) {\n if (!isNumber(index) || !isInteger(index)) {\n throw new TypeError('Index must be an integer (value: ' + index + ')')\n }\n if (index < 0 || (typeof length === 'number' && index >= length)) {\n throw new IndexError(index, length)\n }\n }\n}\n\n/**\n * Test if and index has empty values\n * @param {number} index Zero-based index\n */\nexport function isEmptyIndex (index) {\n for (let i = 0; i < index._dimensions.length; ++i) {\n const dimension = index._dimensions[i]\n if (dimension._data && isArray(dimension._data)) {\n if (dimension._size[0] === 0) {\n return true\n }\n } else if (dimension.isRange) {\n if (dimension.start === dimension.end) {\n return true\n }\n } else if (isString(dimension)) {\n if (dimension.length === 0) {\n return true\n }\n }\n }\n return false\n}\n\n/**\n * Resize a multi dimensional array. The resized array is returned.\n * @param {Array | number} array Array to be resized\n * @param {number[]} size Array with the size of each dimension\n * @param {*} [defaultValue=0] Value to be filled in in new entries,\n * zero by default. Specify for example `null`,\n * to clearly see entries that are not explicitly\n * set.\n * @return {Array} array The resized array\n */\nexport function resize (array, size, defaultValue) {\n // check the type of the arguments\n if (!Array.isArray(size)) {\n throw new TypeError('Array expected')\n }\n if (size.length === 0) {\n throw new Error('Resizing to scalar is not supported')\n }\n\n // check whether size contains positive integers\n size.forEach(function (value) {\n if (!isNumber(value) || !isInteger(value) || value < 0) {\n throw new TypeError('Invalid size, must contain positive integers ' +\n '(size: ' + format(size) + ')')\n }\n })\n\n // convert number to an array\n if (isNumber(array) || isBigNumber(array)) {\n array = [array]\n }\n\n // recursively resize the array\n const _defaultValue = (defaultValue !== undefined) ? defaultValue : 0\n _resize(array, size, 0, _defaultValue)\n\n return array\n}\n\n/**\n * Recursively resize a multi dimensional array\n * @param {Array} array Array to be resized\n * @param {number[]} size Array with the size of each dimension\n * @param {number} dim Current dimension\n * @param {*} [defaultValue] Value to be filled in in new entries,\n * undefined by default.\n * @private\n */\nfunction _resize (array, size, dim, defaultValue) {\n let i\n let elem\n const oldLen = array.length\n const newLen = size[dim]\n const minLen = Math.min(oldLen, newLen)\n\n // apply new length\n array.length = newLen\n\n if (dim < size.length - 1) {\n // non-last dimension\n const dimNext = dim + 1\n\n // resize existing child arrays\n for (i = 0; i < minLen; i++) {\n // resize child array\n elem = array[i]\n if (!Array.isArray(elem)) {\n elem = [elem] // add a dimension\n array[i] = elem\n }\n _resize(elem, size, dimNext, defaultValue)\n }\n\n // create new child arrays\n for (i = minLen; i < newLen; i++) {\n // get child array\n elem = []\n array[i] = elem\n\n // resize new child array\n _resize(elem, size, dimNext, defaultValue)\n }\n } else {\n // last dimension\n\n // remove dimensions of existing values\n for (i = 0; i < minLen; i++) {\n while (Array.isArray(array[i])) {\n array[i] = array[i][0]\n }\n }\n\n // fill new elements with the default value\n for (i = minLen; i < newLen; i++) {\n array[i] = defaultValue\n }\n }\n}\n\n/**\n * Re-shape a multi dimensional array to fit the specified dimensions\n * @param {Array} array Array to be reshaped\n * @param {number[]} sizes List of sizes for each dimension\n * @returns {Array} Array whose data has been formatted to fit the\n * specified dimensions\n *\n * @throws {DimensionError} If the product of the new dimension sizes does\n * not equal that of the old ones\n */\nexport function reshape (array, sizes) {\n const flatArray = flatten(array)\n const currentLength = flatArray.length\n\n if (!Array.isArray(array) || !Array.isArray(sizes)) {\n throw new TypeError('Array expected')\n }\n\n if (sizes.length === 0) {\n throw new DimensionError(0, currentLength, '!=')\n }\n\n sizes = processSizesWildcard(sizes, currentLength)\n const newLength = product(sizes)\n if (currentLength !== newLength) {\n throw new DimensionError(\n newLength,\n currentLength,\n '!='\n )\n }\n\n try {\n return _reshape(flatArray, sizes)\n } catch (e) {\n if (e instanceof DimensionError) {\n throw new DimensionError(\n newLength,\n currentLength,\n '!='\n )\n }\n throw e\n }\n}\n\n/**\n * Replaces the wildcard -1 in the sizes array.\n * @param {number[]} sizes List of sizes for each dimension. At most on wildcard.\n * @param {number} currentLength Number of elements in the array.\n * @throws {Error} If more than one wildcard or unable to replace it.\n * @returns {number[]} The sizes array with wildcard replaced.\n */\nexport function processSizesWildcard (sizes, currentLength) {\n const newLength = product(sizes)\n const processedSizes = sizes.slice()\n const WILDCARD = -1\n const wildCardIndex = sizes.indexOf(WILDCARD)\n\n const isMoreThanOneWildcard = sizes.indexOf(WILDCARD, wildCardIndex + 1) >= 0\n if (isMoreThanOneWildcard) {\n throw new Error('More than one wildcard in sizes')\n }\n\n const hasWildcard = wildCardIndex >= 0\n const canReplaceWildcard = currentLength % newLength === 0\n\n if (hasWildcard) {\n if (canReplaceWildcard) {\n processedSizes[wildCardIndex] = -currentLength / newLength\n } else {\n throw new Error('Could not replace wildcard, since ' + currentLength + ' is no multiple of ' + (-newLength))\n }\n }\n return processedSizes\n}\n\n/**\n * Computes the product of all array elements.\n * @param {number[]} array Array of factors\n * @returns {number} Product of all elements\n */\nfunction product (array) {\n return array.reduce((prev, curr) => prev * curr, 1)\n}\n\n/**\n * Iteratively re-shape a multi dimensional array to fit the specified dimensions\n * @param {Array} array Array to be reshaped\n * @param {number[]} sizes List of sizes for each dimension\n * @returns {Array} Array whose data has been formatted to fit the\n * specified dimensions\n */\n\nfunction _reshape (array, sizes) {\n // testing if there are enough elements for the requested shape\n let tmpArray = array\n let tmpArray2\n // for each dimensions starting by the last one and ignoring the first one\n for (let sizeIndex = sizes.length - 1; sizeIndex > 0; sizeIndex--) {\n const size = sizes[sizeIndex]\n tmpArray2 = []\n\n // aggregate the elements of the current tmpArray in elements of the requested size\n const length = tmpArray.length / size\n for (let i = 0; i < length; i++) {\n tmpArray2.push(tmpArray.slice(i * size, (i + 1) * size))\n }\n // set it as the new tmpArray for the next loop turn or for return\n tmpArray = tmpArray2\n }\n\n return tmpArray\n}\n\n/**\n * Squeeze a multi dimensional array\n * @param {Array} array\n * @param {Array} [size]\n * @returns {Array} returns the array itself\n */\nexport function squeeze (array, size) {\n const s = size || arraySize(array)\n\n // squeeze outer dimensions\n while (Array.isArray(array) && array.length === 1) {\n array = array[0]\n s.shift()\n }\n\n // find the first dimension to be squeezed\n let dims = s.length\n while (s[dims - 1] === 1) {\n dims--\n }\n\n // squeeze inner dimensions\n if (dims < s.length) {\n array = _squeeze(array, dims, 0)\n s.length = dims\n }\n\n return array\n}\n\n/**\n * Recursively squeeze a multi dimensional array\n * @param {Array} array\n * @param {number} dims Required number of dimensions\n * @param {number} dim Current dimension\n * @returns {Array | *} Returns the squeezed array\n * @private\n */\nfunction _squeeze (array, dims, dim) {\n let i, ii\n\n if (dim < dims) {\n const next = dim + 1\n for (i = 0, ii = array.length; i < ii; i++) {\n array[i] = _squeeze(array[i], dims, next)\n }\n } else {\n while (Array.isArray(array)) {\n array = array[0]\n }\n }\n\n return array\n}\n\n/**\n * Unsqueeze a multi dimensional array: add dimensions when missing\n *\n * Paramter `size` will be mutated to match the new, unqueezed matrix size.\n *\n * @param {Array} array\n * @param {number} dims Desired number of dimensions of the array\n * @param {number} [outer] Number of outer dimensions to be added\n * @param {Array} [size] Current size of array.\n * @returns {Array} returns the array itself\n * @private\n */\nexport function unsqueeze (array, dims, outer, size) {\n const s = size || arraySize(array)\n\n // unsqueeze outer dimensions\n if (outer) {\n for (let i = 0; i < outer; i++) {\n array = [array]\n s.unshift(1)\n }\n }\n\n // unsqueeze inner dimensions\n array = _unsqueeze(array, dims, 0)\n while (s.length < dims) {\n s.push(1)\n }\n\n return array\n}\n\n/**\n * Recursively unsqueeze a multi dimensional array\n * @param {Array} array\n * @param {number} dims Required number of dimensions\n * @param {number} dim Current dimension\n * @returns {Array | *} Returns the squeezed array\n * @private\n */\nfunction _unsqueeze (array, dims, dim) {\n let i, ii\n\n if (Array.isArray(array)) {\n const next = dim + 1\n for (i = 0, ii = array.length; i < ii; i++) {\n array[i] = _unsqueeze(array[i], dims, next)\n }\n } else {\n for (let d = dim; d < dims; d++) {\n array = [array]\n }\n }\n\n return array\n}\n/**\n * Flatten a multi dimensional array, put all elements in a one dimensional\n * array\n * @param {Array} array A multi dimensional array\n * @return {Array} The flattened array (1 dimensional)\n */\nexport function flatten (array) {\n if (!Array.isArray(array)) {\n // if not an array, return as is\n return array\n }\n const flat = []\n\n array.forEach(function callback (value) {\n if (Array.isArray(value)) {\n value.forEach(callback) // traverse through sub-arrays recursively\n } else {\n flat.push(value)\n }\n })\n\n return flat\n}\n\n/**\n * A safe map\n * @param {Array} array\n * @param {function} callback\n */\nexport function map (array, callback) {\n return Array.prototype.map.call(array, callback)\n}\n\n/**\n * A safe forEach\n * @param {Array} array\n * @param {function} callback\n */\nexport function forEach (array, callback) {\n Array.prototype.forEach.call(array, callback)\n}\n\n/**\n * A safe filter\n * @param {Array} array\n * @param {function} callback\n */\nexport function filter (array, callback) {\n if (arraySize(array).length !== 1) {\n throw new Error('Only one dimensional matrices supported')\n }\n\n return Array.prototype.filter.call(array, callback)\n}\n\n/**\n * Filter values in a callback given a regular expression\n * @param {Array} array\n * @param {RegExp} regexp\n * @return {Array} Returns the filtered array\n * @private\n */\nexport function filterRegExp (array, regexp) {\n if (arraySize(array).length !== 1) {\n throw new Error('Only one dimensional matrices supported')\n }\n\n return Array.prototype.filter.call(array, (entry) => regexp.test(entry))\n}\n\n/**\n * A safe join\n * @param {Array} array\n * @param {string} separator\n */\nexport function join (array, separator) {\n return Array.prototype.join.call(array, separator)\n}\n\n/**\n * Assign a numeric identifier to every element of a sorted array\n * @param {Array} a An array\n * @return {Array} An array of objects containing the original value and its identifier\n */\nexport function identify (a) {\n if (!Array.isArray(a)) {\n throw new TypeError('Array input expected')\n }\n\n if (a.length === 0) {\n return a\n }\n\n const b = []\n let count = 0\n b[0] = { value: a[0], identifier: 0 }\n for (let i = 1; i < a.length; i++) {\n if (a[i] === a[i - 1]) {\n count++\n } else {\n count = 0\n }\n b.push({ value: a[i], identifier: count })\n }\n return b\n}\n\n/**\n * Remove the numeric identifier from the elements\n * @param {array} a An array\n * @return {array} An array of values without identifiers\n */\nexport function generalize (a) {\n if (!Array.isArray(a)) {\n throw new TypeError('Array input expected')\n }\n\n if (a.length === 0) {\n return a\n }\n\n const b = []\n for (let i = 0; i < a.length; i++) {\n b.push(a[i].value)\n }\n return b\n}\n\n/**\n * Check the datatype of a given object\n * This is a low level implementation that should only be used by\n * parent Matrix classes such as SparseMatrix or DenseMatrix\n * This method does not validate Array Matrix shape\n * @param {Array} array\n * @param {function} typeOf Callback function to use to determine the type of a value\n * @return {string}\n */\nexport function getArrayDataType (array, typeOf) {\n let type // to hold type info\n let length = 0 // to hold length value to ensure it has consistent sizes\n\n for (let i = 0; i < array.length; i++) {\n const item = array[i]\n const isArray = Array.isArray(item)\n\n // Saving the target matrix row size\n if (i === 0 && isArray) {\n length = item.length\n }\n\n // If the current item is an array but the length does not equal the targetVectorSize\n if (isArray && item.length !== length) {\n return undefined\n }\n\n const itemType = isArray\n ? getArrayDataType(item, typeOf) // recurse into a nested array\n : typeOf(item)\n\n if (type === undefined) {\n type = itemType // first item\n } else if (type !== itemType) {\n return 'mixed'\n } else {\n // we're good, everything has the same type so far\n }\n }\n\n return type\n}\n\n/**\n * Return the last item from an array\n * @param {array}\n * @returns {*}\n */\nexport function last (array) {\n return array[array.length - 1]\n}\n\n/**\n * Get all but the last element of array.\n * @param {array}\n * @returns {*}\n */\nexport function initial (array) {\n return array.slice(0, array.length - 1)\n}\n\n/**\n * Recursively concatenate two matrices.\n * The contents of the matrices is not cloned.\n * @param {Array} a Multi dimensional array\n * @param {Array} b Multi dimensional array\n * @param {number} concatDim The dimension on which to concatenate (zero-based)\n * @param {number} dim The current dim (zero-based)\n * @return {Array} c The concatenated matrix\n * @private\n */\nfunction concatRecursive (a, b, concatDim, dim) {\n if (dim < concatDim) {\n // recurse into next dimension\n if (a.length !== b.length) {\n throw new DimensionError(a.length, b.length)\n }\n\n const c = []\n for (let i = 0; i < a.length; i++) {\n c[i] = concatRecursive(a[i], b[i], concatDim, dim + 1)\n }\n return c\n } else {\n // concatenate this dimension\n return a.concat(b)\n }\n}\n\n/**\n * Concatenates many arrays in the specified direction\n * @param {...Array} arrays All the arrays to concatenate\n * @param {number} concatDim The dimension on which to concatenate (zero-based)\n * @returns\n*/\nexport function concat () {\n const arrays = Array.prototype.slice.call(arguments, 0, -1)\n const concatDim = Array.prototype.slice.call(arguments, -1)\n\n if (arrays.length === 1) {\n return arrays[0]\n }\n if (arrays.length > 1) {\n return arrays.slice(1).reduce(function (A, B) { return concatRecursive(A, B, concatDim, 0) }, arrays[0])\n } else {\n throw new Error('Wrong number of arguments in function concat')\n }\n}\n\n/**\n * Receives two or more sizes and get's the broadcasted size for both.\n * @param {...number[]} sizes Sizes to broadcast together\n * @returns\n */\nexport function broadcastSizes (...sizes) {\n const dimensions = sizes.map((s) => s.length)\n const N = Math.max(...dimensions)\n const sizeMax = new Array(N).fill(null)\n // check for every size\n for (let i = 0; i < sizes.length; i++) {\n const size = sizes[i]\n const dim = dimensions[i]\n for (let j = 0; j < dim; j++) {\n const n = N - dim + j\n if (size[j] > sizeMax[n]) {\n sizeMax[n] = size[j]\n }\n }\n }\n for (let i = 0; i < sizes.length; i++) {\n checkBroadcastingRules(sizes[i], sizeMax)\n }\n return sizeMax\n}\n\n/**\n * Checks if it's possible to broadcast a size to another size\n * @param {number[]} size The size of the array to check\n * @param {number[]} toSize The size of the array to validate if it can be broadcasted to\n */\nexport function checkBroadcastingRules (size, toSize) {\n const N = toSize.length\n const dim = size.length\n for (let j = 0; j < dim; j++) {\n const n = N - dim + j\n if ((size[j] < toSize[n] && size[j] > 1) || (size[j] > toSize[n])) {\n throw new Error(\n `shape missmatch: missmatch is found in arg with shape (${size}) not possible to broadcast dimension ${dim} with size ${size[j]} to size ${toSize[n]}`\n )\n }\n }\n}\n\n/**\n * Broadcasts a single array to a certain size\n * @param {array} array Array to be broadcasted\n * @param {number[]} toSize Size to broadcast the array\n * @returns The broadcasted array\n */\nexport function broadcastTo (array, toSize) {\n let Asize = arraySize(array)\n if (deepStrictEqual(Asize, toSize)) {\n return array\n }\n checkBroadcastingRules(Asize, toSize)\n const broadcastedSize = broadcastSizes(Asize, toSize)\n const N = broadcastedSize.length\n const paddedSize = [...Array(N - Asize.length).fill(1), ...Asize]\n\n let A = clone(array)\n // reshape A if needed to make it ready for concat\n if (Asize.length < N) {\n A = reshape(A, paddedSize)\n Asize = arraySize(A)\n }\n\n // stretches the array on each dimension to make it the same size as index\n for (let dim = 0; dim < N; dim++) {\n if (Asize[dim] < broadcastedSize[dim]) {\n A = stretch(A, broadcastedSize[dim], dim)\n Asize = arraySize(A)\n }\n }\n return A\n}\n\n/**\n * Broadcasts arrays and returns the broadcasted arrays in an array\n * @param {...Array | any} arrays\n * @returns\n */\nexport function broadcastArrays (...arrays) {\n if (arrays.length === 0) {\n throw new Error('Insuficient number of argumnets in function broadcastArrays')\n }\n if (arrays.length === 1) {\n return arrays[0]\n }\n const sizes = arrays.map(function (array) { return arraySize(array) })\n const broadcastedSize = broadcastSizes(...sizes)\n const broadcastedArrays = []\n arrays.forEach(function (array) { broadcastedArrays.push(broadcastTo(array, broadcastedSize)) })\n return broadcastedArrays\n}\n\n/**\n * stretches a matrix up to a certain size in a certain dimension\n * @param {Array} arrayToStretch\n * @param {number[]} sizeToStretch\n * @param {number} dimToStretch\n * @returns\n */\nexport function stretch (arrayToStretch, sizeToStretch, dimToStretch) {\n return concat(...Array(sizeToStretch).fill(arrayToStretch), dimToStretch)\n}\n\n/**\n* Retrieves a single element from an array given an index.\n*\n* @param {Array} array - The array from which to retrieve the value.\n* @param {Array} idx - An array of indices specifying the position of the desired element in each dimension.\n* @returns {*} - The value at the specified position in the array.\n*\n* @example\n* const arr = [[[1, 2], [3, 4]], [[5, 6], [7, 8]]];\n* const index = [1, 0, 1];\n* console.log(getValue(arr, index)); // 6\n*/\nexport function get (array, index) {\n if (!Array.isArray(array)) { throw new Error('Array expected') }\n const size = arraySize(array)\n if (index.length !== size.length) { throw new DimensionError(index.length, size.length) }\n for (let x = 0; x < index.length; x++) { validateIndex(index[x], size[x]) }\n return index.reduce((acc, curr) => acc[curr], array)\n}\n\n/**\n * Recursive function to map a multi-dimensional array.\n *\n * @param {*} value - The current value being processed in the array.\n * @param {Array} index - The index of the current value being processed in the array.\n * @param {Array} array - The array being processed.\n * @param {Function} callback - Function that produces the element of the new Array, taking three arguments: the value of the element, the index of the element, and the Array being processed.\n * @returns {*} The new array with each element being the result of the callback function.\n */\nexport function recurse (value, index, array, callback) {\n if (Array.isArray(value)) {\n return value.map(function (child, i) {\n // we create a copy of the index array and append the new index value\n return recurse(child, index.concat(i), array, callback)\n })\n } else {\n // invoke the callback function with the right number of arguments\n return callback(value, index, array)\n }\n}\n\n/**\n * Deep clones a multidimensional array\n * @param {Array} array\n * @returns cloned array\n */\nexport function clone (array) {\n return Object.assign([], array)\n}\n","import typed from 'typed-function'\nimport { get, arraySize } from './array.js'\nimport { typeOf as _typeOf } from './is.js'\n\n/**\n * Simplifies a callback function by reducing its complexity and potentially improving its performance.\n *\n * @param {Function} callback The original callback function to simplify.\n * @param {Array|Matrix} array The array that will be used with the callback function.\n * @param {string} name The name of the function that is using the callback.\n * @returns {Function} Returns a simplified version of the callback function.\n */\nexport function optimizeCallback (callback, array, name) {\n if (typed.isTypedFunction(callback)) {\n const firstIndex = (array.isMatrix ? array.size() : arraySize(array)).map(() => 0)\n const firstValue = array.isMatrix ? array.get(firstIndex) : get(array, firstIndex)\n const hasSingleSignature = Object.keys(callback.signatures).length === 1\n const numberOfArguments = _findNumberOfArguments(callback, firstValue, firstIndex, array)\n const fastCallback = hasSingleSignature ? Object.values(callback.signatures)[0] : callback\n if (numberOfArguments >= 1 && numberOfArguments <= 3) {\n return (...args) => _tryFunctionWithArgs(fastCallback, args.slice(0, numberOfArguments), name, callback.name)\n }\n return (...args) => _tryFunctionWithArgs(fastCallback, args, name, callback.name)\n }\n return callback\n}\n\nfunction _findNumberOfArguments (callback, value, index, array) {\n const testArgs = [value, index, array]\n for (let i = 3; i > 0; i--) {\n const args = testArgs.slice(0, i)\n if (typed.resolve(callback, args) !== null) {\n return i\n }\n }\n}\n\n/**\n * @param {function} func The selected function taken from one of the signatures of the callback function\n * @param {Array} args List with arguments to apply to the selected signature\n * @param {string} mappingFnName the name of the function that is using the callback\n * @param {string} callbackName the name of the callback function\n * @returns {*} Returns the return value of the invoked signature\n * @throws {TypeError} Throws an error when no matching signature was found\n */\nfunction _tryFunctionWithArgs (func, args, mappingFnName, callbackName) {\n try {\n return func(...args)\n } catch (err) {\n _createCallbackError(err, args, mappingFnName, callbackName)\n }\n}\n\n/**\n * Creates and throws a detailed TypeError when a callback function fails.\n *\n * @param {Error} err The original error thrown by the callback function.\n * @param {Array} args The arguments that were passed to the callback function.\n * @param {string} mappingFnName The name of the function that is using the callback.\n * @param {string} callbackName The name of the callback function.\n * @throws {TypeError} Throws a detailed TypeError with enriched error message.\n */\nfunction _createCallbackError (err, args, mappingFnName, callbackName) {\n // Enrich the error message so the user understands that it took place inside the callback function\n if (err instanceof TypeError && err.data?.category === 'wrongType') {\n const argsDesc = []\n argsDesc.push(`value: ${_typeOf(args[0])}`)\n if (args.length >= 2) { argsDesc.push(`index: ${_typeOf(args[1])}`) }\n if (args.length >= 3) { argsDesc.push(`array: ${_typeOf(args[2])}`) }\n\n throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` +\n `${callbackName}(${argsDesc.join(', ')}) at index ${JSON.stringify(args[1])}`)\n } else {\n throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` +\n `to function ${callbackName}: ${err.message}`)\n }\n}\n","// deno-lint-ignore-file no-this-alias\nimport { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'\nimport { arraySize, getArrayDataType, processSizesWildcard, reshape, resize, unsqueeze, validate, validateIndex, broadcastTo, get } from '../../utils/array.js'\nimport { format } from '../../utils/string.js'\nimport { isInteger } from '../../utils/number.js'\nimport { clone, deepStrictEqual } from '../../utils/object.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\nimport { optimizeCallback } from '../../utils/optimizeCallback.js'\n\nconst name = 'DenseMatrix'\nconst dependencies = [\n 'Matrix'\n]\n\nexport const createDenseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ Matrix }) => {\n /**\n * Dense Matrix implementation. A regular, dense matrix, supporting multi-dimensional matrices. This is the default matrix type.\n * @class DenseMatrix\n * @enum {{ value, index: number[] }}\n */\n function DenseMatrix (data, datatype) {\n if (!(this instanceof DenseMatrix)) { throw new SyntaxError('Constructor must be called with the new operator') }\n if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n if (isMatrix(data)) {\n // check data is a DenseMatrix\n if (data.type === 'DenseMatrix') {\n // clone data & size\n this._data = clone(data._data)\n this._size = clone(data._size)\n this._datatype = datatype || data._datatype\n } else {\n // build data from existing matrix\n this._data = data.toArray()\n this._size = data.size()\n this._datatype = datatype || data._datatype\n }\n } else if (data && isArray(data.data) && isArray(data.size)) {\n // initialize fields from JSON representation\n this._data = data.data\n this._size = data.size\n // verify the dimensions of the array\n validate(this._data, this._size)\n this._datatype = datatype || data.datatype\n } else if (isArray(data)) {\n // replace nested Matrices with Arrays\n this._data = preprocess(data)\n // get the dimensions of the array\n this._size = arraySize(this._data)\n // verify the dimensions of the array, TODO: compute size while processing array\n validate(this._data, this._size)\n // data type unknown\n this._datatype = datatype\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + typeOf(data) + ')')\n } else {\n // nothing provided\n this._data = []\n this._size = [0]\n this._datatype = datatype\n }\n }\n\n DenseMatrix.prototype = new Matrix()\n\n /**\n * Create a new DenseMatrix\n */\n DenseMatrix.prototype.createDenseMatrix = function (data, datatype) {\n return new DenseMatrix(data, datatype)\n }\n\n /**\n * Attach type information\n */\n Object.defineProperty(DenseMatrix, 'name', { value: 'DenseMatrix' })\n DenseMatrix.prototype.constructor = DenseMatrix\n DenseMatrix.prototype.type = 'DenseMatrix'\n DenseMatrix.prototype.isDenseMatrix = true\n\n /**\n * Get the matrix type\n *\n * Usage:\n * const matrixType = matrix.getDataType() // retrieves the matrix type\n *\n * @memberOf DenseMatrix\n * @return {string} type information; if multiple types are found from the Matrix, it will return \"mixed\"\n */\n DenseMatrix.prototype.getDataType = function () {\n return getArrayDataType(this._data, typeOf)\n }\n\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @memberof DenseMatrix\n * @return {string} The storage format.\n */\n DenseMatrix.prototype.storage = function () {\n return 'dense'\n }\n\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @memberof DenseMatrix\n * @return {string} The datatype.\n */\n DenseMatrix.prototype.datatype = function () {\n return this._datatype\n }\n\n /**\n * Create a new DenseMatrix\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {string} [datatype]\n */\n DenseMatrix.prototype.create = function (data, datatype) {\n return new DenseMatrix(data, datatype)\n }\n\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @memberof DenseMatrix\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n DenseMatrix.prototype.subset = function (index, replacement, defaultValue) {\n switch (arguments.length) {\n case 1:\n return _get(this, index)\n\n // intentional fall through\n case 2:\n case 3:\n return _set(this, index, replacement, defaultValue)\n\n default:\n throw new SyntaxError('Wrong number of arguments')\n }\n }\n\n /**\n * Get a single element from the matrix.\n * @memberof DenseMatrix\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n DenseMatrix.prototype.get = function (index) {\n return get(this._data, index)\n }\n\n /**\n * Replace a single element in the matrix.\n * @memberof DenseMatrix\n * @param {number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {DenseMatrix} self\n */\n DenseMatrix.prototype.set = function (index, value, defaultValue) {\n if (!isArray(index)) { throw new TypeError('Array expected') }\n if (index.length < this._size.length) { throw new DimensionError(index.length, this._size.length, '<') }\n\n let i, ii, indexI\n\n // enlarge matrix when needed\n const size = index.map(function (i) {\n return i + 1\n })\n _fit(this, size, defaultValue)\n\n // traverse over the dimensions\n let data = this._data\n for (i = 0, ii = index.length - 1; i < ii; i++) {\n indexI = index[i]\n validateIndex(indexI, data.length)\n data = data[indexI]\n }\n\n // set new value\n indexI = index[index.length - 1]\n validateIndex(indexI, data.length)\n data[indexI] = value\n\n return this\n }\n\n /**\n * Get a submatrix of this matrix\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix\n * @param {Index} index Zero-based index\n * @private\n */\n function _get (matrix, index) {\n if (!isIndex(index)) {\n throw new TypeError('Invalid index')\n }\n\n const isScalar = index.isScalar()\n if (isScalar) {\n // return a scalar\n return matrix.get(index.min())\n } else {\n // validate dimensions\n const size = index.size()\n if (size.length !== matrix._size.length) {\n throw new DimensionError(size.length, matrix._size.length)\n }\n\n // validate if any of the ranges in the index is out of range\n const min = index.min()\n const max = index.max()\n for (let i = 0, ii = matrix._size.length; i < ii; i++) {\n validateIndex(min[i], matrix._size[i])\n validateIndex(max[i], matrix._size[i])\n }\n\n // retrieve submatrix\n // TODO: more efficient when creating an empty matrix and setting _data and _size manually\n return new DenseMatrix(_getSubmatrix(matrix._data, index, size.length, 0), matrix._datatype)\n }\n }\n\n /**\n * Recursively get a submatrix of a multi dimensional matrix.\n * Index is not checked for correct number or length of dimensions.\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {Index} index\n * @param {number} dims Total number of dimensions\n * @param {number} dim Current dimension\n * @return {Array} submatrix\n * @private\n */\n function _getSubmatrix (data, index, dims, dim) {\n const last = (dim === dims - 1)\n const range = index.dimension(dim)\n\n if (last) {\n return range.map(function (i) {\n validateIndex(i, data.length)\n return data[i]\n }).valueOf()\n } else {\n return range.map(function (i) {\n validateIndex(i, data.length)\n const child = data[i]\n return _getSubmatrix(child, index, dims, dim + 1)\n }).valueOf()\n }\n }\n\n /**\n * Replace a submatrix in this matrix\n * Indexes are zero-based.\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix\n * @param {Index} index\n * @param {DenseMatrix | Array | *} submatrix\n * @param {*} defaultValue Default value, filled in on new entries when\n * the matrix is resized.\n * @return {DenseMatrix} matrix\n * @private\n */\n function _set (matrix, index, submatrix, defaultValue) {\n if (!index || index.isIndex !== true) {\n throw new TypeError('Invalid index')\n }\n\n // get index size and check whether the index contains a single value\n const iSize = index.size()\n const isScalar = index.isScalar()\n\n // calculate the size of the submatrix, and convert it into an Array if needed\n let sSize\n if (isMatrix(submatrix)) {\n sSize = submatrix.size()\n submatrix = submatrix.valueOf()\n } else {\n sSize = arraySize(submatrix)\n }\n\n if (isScalar) {\n // set a scalar\n\n // check whether submatrix is a scalar\n if (sSize.length !== 0) {\n throw new TypeError('Scalar expected')\n }\n matrix.set(index.min(), submatrix, defaultValue)\n } else {\n // set a submatrix\n\n // broadcast submatrix\n if (!deepStrictEqual(sSize, iSize)) {\n try {\n if (sSize.length === 0) {\n submatrix = broadcastTo([submatrix], iSize)\n } else {\n submatrix = broadcastTo(submatrix, iSize)\n }\n sSize = arraySize(submatrix)\n } catch {\n }\n }\n\n // validate dimensions\n if (iSize.length < matrix._size.length) {\n throw new DimensionError(iSize.length, matrix._size.length, '<')\n }\n\n if (sSize.length < iSize.length) {\n // calculate number of missing outer dimensions\n let i = 0\n let outer = 0\n while (iSize[i] === 1 && sSize[i] === 1) {\n i++\n }\n while (iSize[i] === 1) {\n outer++\n i++\n }\n\n // unsqueeze both outer and inner dimensions\n submatrix = unsqueeze(submatrix, iSize.length, outer, sSize)\n }\n\n // check whether the size of the submatrix matches the index size\n if (!deepStrictEqual(iSize, sSize)) {\n throw new DimensionError(iSize, sSize, '>')\n }\n\n // enlarge matrix when needed\n const size = index.max().map(function (i) {\n return i + 1\n })\n _fit(matrix, size, defaultValue)\n\n // insert the sub matrix\n const dims = iSize.length\n const dim = 0\n _setSubmatrix(matrix._data, index, submatrix, dims, dim)\n }\n\n return matrix\n }\n\n /**\n * Replace a submatrix of a multi dimensional matrix.\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {Index} index\n * @param {Array} submatrix\n * @param {number} dims Total number of dimensions\n * @param {number} dim\n * @private\n */\n function _setSubmatrix (data, index, submatrix, dims, dim) {\n const last = (dim === dims - 1)\n const range = index.dimension(dim)\n\n if (last) {\n range.forEach(function (dataIndex, subIndex) {\n validateIndex(dataIndex)\n data[dataIndex] = submatrix[subIndex[0]]\n })\n } else {\n range.forEach(function (dataIndex, subIndex) {\n validateIndex(dataIndex)\n _setSubmatrix(data[dataIndex], index, submatrix[subIndex[0]], dims, dim + 1)\n })\n }\n }\n\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @memberof DenseMatrix\n * @param {number[] || Matrix} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n DenseMatrix.prototype.resize = function (size, defaultValue, copy) {\n // validate arguments\n if (!isCollection(size)) {\n throw new TypeError('Array or Matrix expected')\n }\n\n // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n const sizeArray = size.valueOf().map(value => {\n return Array.isArray(value) && value.length === 1\n ? value[0]\n : value\n })\n\n // matrix to resize\n const m = copy ? this.clone() : this\n // resize matrix\n return _resize(m, sizeArray, defaultValue)\n }\n\n function _resize (matrix, size, defaultValue) {\n // check size\n if (size.length === 0) {\n // first value in matrix\n let v = matrix._data\n // go deep\n while (isArray(v)) {\n v = v[0]\n }\n return v\n }\n // resize matrix\n matrix._size = size.slice(0) // copy the array\n matrix._data = resize(matrix._data, matrix._size, defaultValue)\n // return matrix\n return matrix\n }\n\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * NOTE: This might be better suited to copy by default, instead of modifying\n * in place. For now, it operates in place to remain consistent with\n * resize().\n *\n * @memberof DenseMatrix\n * @param {number[]} size The new size the matrix should have.\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n DenseMatrix.prototype.reshape = function (size, copy) {\n const m = copy ? this.clone() : this\n\n m._data = reshape(m._data, size)\n const currentLength = m._size.reduce((length, size) => length * size)\n m._size = processSizesWildcard(size, currentLength)\n return m\n }\n\n /**\n * Enlarge the matrix when it is smaller than given size.\n * If the matrix is larger or equal sized, nothing is done.\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix The matrix to be resized\n * @param {number[]} size\n * @param {*} defaultValue Default value, filled in on new entries.\n * @private\n */\n function _fit (matrix, size, defaultValue) {\n const // copy the array\n newSize = matrix._size.slice(0)\n\n let changed = false\n\n // add dimensions when needed\n while (newSize.length < size.length) {\n newSize.push(0)\n changed = true\n }\n\n // enlarge size when needed\n for (let i = 0, ii = size.length; i < ii; i++) {\n if (size[i] > newSize[i]) {\n newSize[i] = size[i]\n changed = true\n }\n }\n\n if (changed) {\n // resize only when size is changed\n _resize(matrix, newSize, defaultValue)\n }\n }\n\n /**\n * Create a clone of the matrix\n * @memberof DenseMatrix\n * @return {DenseMatrix} clone\n */\n DenseMatrix.prototype.clone = function () {\n const m = new DenseMatrix({\n data: clone(this._data),\n size: clone(this._size),\n datatype: this._datatype\n })\n return m\n }\n\n /**\n * Retrieve the size of the matrix.\n * @memberof DenseMatrix\n * @returns {number[]} size\n */\n DenseMatrix.prototype.size = function () {\n return this._size.slice(0) // return a clone of _size\n }\n\n /**\n * Applies a callback function to a reference to each element of the matrix\n * @memberof DenseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: an array, an integer index to that\n * array, and the Matrix being traversed.\n */\n DenseMatrix.prototype._forEach = function (callback) {\n // matrix instance\n const me = this\n const s = me.size()\n\n // if there is only one dimension, just loop through it\n if (s.length === 1) {\n for (let i = 0; i < s[0]; i++) {\n callback(me._data, i, [i])\n }\n return\n }\n\n // keep track of the current index permutation\n const index = Array(s.length).fill(0)\n\n // store a reference of each dimension of the matrix for faster access\n const data = Array(s.length - 1)\n const last = data.length - 1\n\n data[0] = me._data[0]\n for (let i = 0; i < last; i++) {\n data[i + 1] = data[i][0]\n }\n\n index[last] = -1\n while (true) {\n let i\n for (i = last; i >= 0; i--) {\n // march index to the next permutation\n index[i]++\n if (index[i] === s[i]) {\n index[i] = 0\n continue\n }\n\n // update references to matrix dimensions\n data[i] = i === 0 ? me._data[index[i]] : data[i - 1][index[i]]\n for (let j = i; j < last; j++) {\n data[j + 1] = data[j][0]\n }\n\n // loop through the last dimension and map each value\n for (let j = 0; j < s[data.length]; j++) {\n index[data.length] = j\n callback(data[last], j, index.slice(0))\n }\n break\n }\n\n if (i === -1) {\n break\n }\n }\n }\n\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @memberof DenseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n *\n * @return {DenseMatrix} matrix\n */\n DenseMatrix.prototype.map = function (callback) {\n const me = this\n const result = new DenseMatrix(me)\n const fastCallback = optimizeCallback(callback, me._data, 'map')\n\n result._forEach(function (arr, i, index) {\n arr[i] = fastCallback(arr[i], index, me)\n })\n\n return result\n }\n\n /**\n * Execute a callback function on each entry of the matrix.\n * @memberof DenseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n */\n DenseMatrix.prototype.forEach = function (callback) {\n const me = this\n const fastCallback = optimizeCallback(callback, me._data, 'map')\n me._forEach(function (arr, i, index) {\n fastCallback(arr[i], index, me)\n })\n }\n\n /**\n * Iterate over the matrix elements\n * @return {Iterable<{ value, index: number[] }>}\n */\n DenseMatrix.prototype[Symbol.iterator] = function * () {\n const recurse = function * (value, index) {\n if (isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n yield * recurse(value[i], index.concat(i))\n }\n } else {\n yield ({ value, index })\n }\n }\n yield * recurse(this._data, [])\n }\n\n /**\n * Returns an array containing the rows of a 2D matrix\n * @returns {Array}\n */\n DenseMatrix.prototype.rows = function () {\n const result = []\n\n const s = this.size()\n if (s.length !== 2) {\n throw new TypeError('Rows can only be returned for a 2D matrix.')\n }\n\n const data = this._data\n for (const row of data) {\n result.push(new DenseMatrix([row], this._datatype))\n }\n\n return result\n }\n\n /**\n * Returns an array containing the columns of a 2D matrix\n * @returns {Array}\n */\n DenseMatrix.prototype.columns = function () {\n const result = []\n\n const s = this.size()\n if (s.length !== 2) {\n throw new TypeError('Rows can only be returned for a 2D matrix.')\n }\n\n const data = this._data\n for (let i = 0; i < s[1]; i++) {\n const col = data.map(row => [row[i]])\n result.push(new DenseMatrix(col, this._datatype))\n }\n\n return result\n }\n\n /**\n * Create an Array with a copy of the data of the DenseMatrix\n * @memberof DenseMatrix\n * @returns {Array} array\n */\n DenseMatrix.prototype.toArray = function () {\n return clone(this._data)\n }\n\n /**\n * Get the primitive value of the DenseMatrix: a multidimensional array\n * @memberof DenseMatrix\n * @returns {Array} array\n */\n DenseMatrix.prototype.valueOf = function () {\n return this._data\n }\n\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @memberof DenseMatrix\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n DenseMatrix.prototype.format = function (options) {\n return format(this._data, options)\n }\n\n /**\n * Get a string representation of the matrix\n * @memberof DenseMatrix\n * @returns {string} str\n */\n DenseMatrix.prototype.toString = function () {\n return format(this._data)\n }\n\n /**\n * Get a JSON representation of the matrix\n * @memberof DenseMatrix\n * @returns {Object}\n */\n DenseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'DenseMatrix',\n data: this._data,\n size: this._size,\n datatype: this._datatype\n }\n }\n\n /**\n * Get the kth Matrix diagonal.\n *\n * @memberof DenseMatrix\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved.\n *\n * @returns {Matrix} The matrix with the diagonal values.\n */\n DenseMatrix.prototype.diagonal = function (k) {\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if (isBigNumber(k)) { k = k.toNumber() }\n // is must be an integer\n if (!isNumber(k) || !isInteger(k)) {\n throw new TypeError('The parameter k must be an integer number')\n }\n } else {\n // default value\n k = 0\n }\n\n const kSuper = k > 0 ? k : 0\n const kSub = k < 0 ? -k : 0\n\n // rows & columns\n const rows = this._size[0]\n const columns = this._size[1]\n\n // number diagonal values\n const n = Math.min(rows - kSub, columns - kSuper)\n\n // x is a matrix get diagonal from matrix\n const data = []\n\n // loop rows\n for (let i = 0; i < n; i++) {\n data[i] = this._data[i + kSub][i + kSuper]\n }\n\n // create DenseMatrix\n return new DenseMatrix({\n data,\n size: [n],\n datatype: this._datatype\n })\n }\n\n /**\n * Create a diagonal matrix.\n *\n * @memberof DenseMatrix\n * @param {Array} size The matrix size.\n * @param {number | Matrix | Array } value The values for the diagonal.\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in.\n * @param {number} [defaultValue] The default value for non-diagonal\n * @param {string} [datatype] The datatype for the diagonal\n *\n * @returns {DenseMatrix}\n */\n DenseMatrix.diagonal = function (size, value, k, defaultValue) {\n if (!isArray(size)) { throw new TypeError('Array expected, size parameter') }\n if (size.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n // map size & validate\n size = size.map(function (s) {\n // check it is a big number\n if (isBigNumber(s)) {\n // convert it\n s = s.toNumber()\n }\n // validate arguments\n if (!isNumber(s) || !isInteger(s) || s < 1) {\n throw new Error('Size values must be positive integers')\n }\n return s\n })\n\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if (isBigNumber(k)) { k = k.toNumber() }\n // is must be an integer\n if (!isNumber(k) || !isInteger(k)) {\n throw new TypeError('The parameter k must be an integer number')\n }\n } else {\n // default value\n k = 0\n }\n\n const kSuper = k > 0 ? k : 0\n const kSub = k < 0 ? -k : 0\n\n // rows and columns\n const rows = size[0]\n const columns = size[1]\n\n // number of non-zero items\n const n = Math.min(rows - kSub, columns - kSuper)\n\n // value extraction function\n let _value\n\n // check value\n if (isArray(value)) {\n // validate array\n if (value.length !== n) {\n // number of values in array must be n\n throw new Error('Invalid value array length')\n }\n // define function\n _value = function (i) {\n // return value @ i\n return value[i]\n }\n } else if (isMatrix(value)) {\n // matrix size\n const ms = value.size()\n // validate matrix\n if (ms.length !== 1 || ms[0] !== n) {\n // number of values in array must be n\n throw new Error('Invalid matrix length')\n }\n // define function\n _value = function (i) {\n // return value @ i\n return value.get([i])\n }\n } else {\n // define function\n _value = function () {\n // return value\n return value\n }\n }\n\n // discover default value if needed\n if (!defaultValue) {\n // check first value in array\n defaultValue = isBigNumber(_value(0))\n ? _value(0).mul(0) // trick to create a BigNumber with value zero\n : 0\n }\n\n // empty array\n let data = []\n\n // check we need to resize array\n if (size.length > 0) {\n // resize array\n data = resize(data, size, defaultValue)\n // fill diagonal\n for (let d = 0; d < n; d++) {\n data[d + kSub][d + kSuper] = _value(d)\n }\n }\n\n // create DenseMatrix\n return new DenseMatrix({\n data,\n size: [rows, columns]\n })\n }\n\n /**\n * Generate a matrix from a JSON object\n * @memberof DenseMatrix\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"DenseMatrix\", data: [], size: []}`,\n * where mathjs is optional\n * @returns {DenseMatrix}\n */\n DenseMatrix.fromJSON = function (json) {\n return new DenseMatrix(json)\n }\n\n /**\n * Swap rows i and j in Matrix.\n *\n * @memberof DenseMatrix\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n DenseMatrix.prototype.swapRows = function (i, j) {\n // check index\n if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) {\n throw new Error('Row index must be positive integers')\n }\n // check dimensions\n if (this._size.length !== 2) {\n throw new Error('Only two dimensional matrix is supported')\n }\n // validate index\n validateIndex(i, this._size[0])\n validateIndex(j, this._size[0])\n\n // swap rows\n DenseMatrix._swapRows(i, j, this._data)\n // return current instance\n return this\n }\n\n /**\n * Swap rows i and j in Dense Matrix data structure.\n *\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n * @param {Array} data Matrix data\n */\n DenseMatrix._swapRows = function (i, j, data) {\n // swap values i <-> j\n const vi = data[i]\n data[i] = data[j]\n data[j] = vi\n }\n\n /**\n * Preprocess data, which can be an Array or DenseMatrix with nested Arrays and\n * Matrices. Clones all (nested) Arrays, and replaces all nested Matrices with Arrays\n * @memberof DenseMatrix\n * @param {Array | Matrix} data\n * @return {Array} data\n */\n function preprocess (data) {\n if (isMatrix(data)) {\n return preprocess(data.valueOf())\n }\n\n if (isArray(data)) {\n return data.map(preprocess)\n }\n\n return data\n }\n\n return DenseMatrix\n}, { isClass: true })\n","import { clone as objectClone } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'clone'\nconst dependencies = ['typed']\n\nexport const createClone = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Clone an object. Will make a deep copy of the data.\n *\n * Syntax:\n *\n * math.clone(x)\n *\n * Examples:\n *\n * math.clone(3.5) // returns number 3.5\n * math.clone(math.complex('2-4i')) // returns Complex 2 - 4i\n * math.clone(math.unit(45, 'deg')) // returns Unit 45 deg\n * math.clone([[1, 2], [3, 4]]) // returns Array [[1, 2], [3, 4]]\n * math.clone(\"hello world\") // returns string \"hello world\"\n *\n * @param {*} x Object to be cloned\n * @return {*} A clone of object x\n */\n return typed(name, {\n any: objectClone\n })\n})\n","/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\nexport function _switch (mat) {\n const I = mat.length\n const J = mat[0].length\n let i, j\n const ret = []\n for (j = 0; j < J; j++) {\n const tmp = []\n for (i = 0; i < I; i++) {\n tmp.push(mat[i][j])\n }\n ret.push(tmp)\n }\n return ret\n}\n","import { isCollection, isMatrix } from './is.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { arraySize } from './array.js'\nimport { _switch } from './switch.js'\n\n/**\n * Test whether an array contains collections\n * @param {Array} array\n * @returns {boolean} Returns true when the array contains one or multiple\n * collections (Arrays or Matrices). Returns false otherwise.\n */\nexport function containsCollections (array) {\n for (let i = 0; i < array.length; i++) {\n if (isCollection(array[i])) {\n return true\n }\n }\n return false\n}\n\n/**\n * Recursively loop over all elements in a given multi dimensional array\n * and invoke the callback on each of the elements.\n * @param {Array | Matrix} array\n * @param {Function} callback The callback method is invoked with one\n * parameter: the current element in the array\n */\nexport function deepForEach (array, callback) {\n if (isMatrix(array)) {\n array = array.valueOf()\n }\n\n for (let i = 0, ii = array.length; i < ii; i++) {\n const value = array[i]\n\n if (Array.isArray(value)) {\n deepForEach(value, callback)\n } else {\n callback(value)\n }\n }\n}\n\n/**\n * Execute the callback function element wise for each element in array and any\n * nested array\n * Returns an array with the results\n * @param {Array | Matrix} array\n * @param {Function} callback The callback is called with two parameters:\n * value1 and value2, which contain the current\n * element of both arrays.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {Array | Matrix} res\n */\nexport function deepMap (array, callback, skipZeros) {\n if (array && (typeof array.map === 'function')) {\n // TODO: replace array.map with a for loop to improve performance\n return array.map(function (x) {\n return deepMap(x, callback, skipZeros)\n })\n } else {\n return callback(array)\n }\n}\n\n/**\n * Reduce a given matrix or array to a new matrix or\n * array with one less dimension, applying the given\n * callback in the selected dimension.\n * @param {Array | Matrix} mat\n * @param {number} dim\n * @param {Function} callback\n * @return {Array | Matrix} res\n */\nexport function reduce (mat, dim, callback) {\n const size = Array.isArray(mat) ? arraySize(mat) : mat.size()\n if (dim < 0 || (dim >= size.length)) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new IndexError(dim, size.length)\n }\n\n if (isMatrix(mat)) {\n return mat.create(_reduce(mat.valueOf(), dim, callback), mat.datatype())\n } else {\n return _reduce(mat, dim, callback)\n }\n}\n\n/**\n * Recursively reduce a matrix\n * @param {Array} mat\n * @param {number} dim\n * @param {Function} callback\n * @returns {Array} ret\n * @private\n */\nfunction _reduce (mat, dim, callback) {\n let i, ret, val, tran\n\n if (dim <= 0) {\n if (!Array.isArray(mat[0])) {\n val = mat[0]\n for (i = 1; i < mat.length; i++) {\n val = callback(val, mat[i])\n }\n return val\n } else {\n tran = _switch(mat)\n ret = []\n for (i = 0; i < tran.length; i++) {\n ret[i] = _reduce(tran[i], dim - 1, callback)\n }\n return ret\n }\n } else {\n ret = []\n for (i = 0; i < mat.length; i++) {\n ret[i] = _reduce(mat[i], dim - 1, callback)\n }\n return ret\n }\n}\n\n// TODO: document function scatter\nexport function scatter (a, j, w, x, u, mark, cindex, f, inverse, update, value) {\n // a arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n\n // vars\n let k, k0, k1, i\n\n // check we need to process values (pattern matrix)\n if (x) {\n // values in j\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]\n // check value exists in current j\n if (w[i] !== mark) {\n // i is new entry in j\n w[i] = mark\n // add i to pattern of C\n cindex.push(i)\n // x(i) = A, check we need to call function this time\n if (update) {\n // copy value to workspace calling callback function\n x[i] = inverse ? f(avalues[k], value) : f(value, avalues[k])\n // function was called on current row\n u[i] = mark\n } else {\n // copy value to workspace\n x[i] = avalues[k]\n }\n } else {\n // i exists in C already\n x[i] = inverse ? f(avalues[k], x[i]) : f(x[i], avalues[k])\n // function was called on current row\n u[i] = mark\n }\n }\n } else {\n // values in j\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]\n // check value exists in current j\n if (w[i] !== mark) {\n // i is new entry in j\n w[i] = mark\n // add i to pattern of C\n cindex.push(i)\n } else {\n // indicate function was called on current row\n u[i] = mark\n }\n }\n }\n}\n","import { deepMap } from '../../utils/collection.js'\nimport { isInteger as isIntegerNumber } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isInteger'\nconst dependencies = ['typed']\n\nexport const createIsInteger = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Test whether a value is an integer number.\n * The function supports `number`, `BigNumber`, and `Fraction`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isInteger(x)\n *\n * Examples:\n *\n * math.isInteger(2) // returns true\n * math.isInteger(0) // returns true\n * math.isInteger(0.5) // returns false\n * math.isInteger(math.bignumber(500)) // returns true\n * math.isInteger(math.fraction(4)) // returns true\n * math.isInteger('3') // returns true\n * math.isInteger([3, 0.5, -2]) // returns [true, false, true]\n * math.isInteger(math.complex('2-4i')) // throws an error\n *\n * See also:\n *\n * isNumeric, isPositive, isNegative, isZero\n *\n * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` contains a numeric, integer value.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: isIntegerNumber, // TODO: what to do with isInteger(add(0.1, 0.2)) ?\n\n BigNumber: function (x) {\n return x.isInt()\n },\n\n bigint: function (x) {\n return true\n },\n\n Fraction: function (x) {\n return x.d === 1 && isFinite(x.n)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { isInteger } from '../../utils/number.js'\n\nconst n1 = 'number'\n\nexport function isIntegerNumber (x) {\n return isInteger(x)\n}\nisIntegerNumber.signature = n1\n\nexport function isNegativeNumber (x) {\n return x < 0\n}\nisNegativeNumber.signature = n1\n\nexport function isPositiveNumber (x) {\n return x > 0\n}\nisPositiveNumber.signature = n1\n\nexport function isZeroNumber (x) {\n return x === 0\n}\nisZeroNumber.signature = n1\n\nexport function isNaNNumber (x) {\n return Number.isNaN(x)\n}\nisNaNNumber.signature = n1\n","/**\n * Compares two BigNumbers.\n * @param {BigNumber} a - First value to compare\n * @param {BigNumber} b - Second value to compare\n * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0.\n * @param {number} [absTol=0] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0.\n * @returns {boolean} whether the two numbers are nearly equal\n * @throws {Error} If `relTol` is less than or equal to 0.\n * @throws {Error} If `absTol` is less than 0.\n *\n * @example\n * nearlyEqual(1.000000001, 1.0, 1e-9); // true\n * nearlyEqual(1.000000002, 1.0, 0); // false\n * nearlyEqual(1.0, 1.009, undefined, 0.02); // true\n * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true\n */\nexport function nearlyEqual (a, b, relTol = 1e-9, absTol = 0) {\n if (relTol <= 0) {\n throw new Error('Relative tolerance must be greater than 0')\n }\n\n if (absTol < 0) {\n throw new Error('Absolute tolerance must be at least 0')\n }\n // NaN\n if (a.isNaN() || b.isNaN()) {\n return false\n }\n\n if (!a.isFinite() || !b.isFinite()) {\n return a.eq(b)\n }\n // use \"==\" operator, handles infinities\n if (a.eq(b)) {\n return true\n }\n // abs(a-b) <= max(relTol * max(abs(a), abs(b)), absTol)\n return a.minus(b).abs().lte(a.constructor.max(a.constructor.max(a.abs(), b.abs()).mul(relTol), absTol))\n}\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNegativeNumber } from '../../plain/number/index.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\n\nconst name = 'isNegative'\nconst dependencies = ['typed', 'config']\n\nexport const createIsNegative = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\n /**\n * Test whether a value is negative: smaller than zero.\n * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNegative(x)\n *\n * Examples:\n *\n * math.isNegative(3) // returns false\n * math.isNegative(-2) // returns true\n * math.isNegative(0) // returns false\n * math.isNegative(-0) // returns false\n * math.isNegative(math.bignumber(2)) // returns false\n * math.isNegative(math.fraction(-2, 5)) // returns true\n * math.isNegative('-2') // returns true\n * math.isNegative([2, 0, -3]) // returns [false, false, true]\n *\n * See also:\n *\n * isNumeric, isPositive, isZero, isInteger\n *\n * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isNegativeNumber(x),\n\n BigNumber: x => bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol)\n ? false\n : x.isNeg() && !x.isZero() && !x.isNaN(),\n\n bigint: x => x < 0n,\n\n Fraction: x => x.s < 0, // It's enough to decide on the sign\n\n Unit: typed.referToSelf(self =>\n x => typed.find(self, x.valueType())(x.value)),\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isNumeric'\nconst dependencies = ['typed']\n\nexport const createIsNumeric = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Test whether a value is an numeric value.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNumeric(x)\n *\n * Examples:\n *\n * math.isNumeric(2) // returns true\n * math.isNumeric('2') // returns false\n * math.hasNumericValue('2') // returns true\n * math.isNumeric(0) // returns true\n * math.isNumeric(math.bignumber('42')) // returns true\n * math.isNumeric(math.bigint('42')) // returns true\n * math.isNumeric(math.fraction(4)) // returns true\n * math.isNumeric(math.complex('2-4i')) // returns false\n * math.isNumeric([2.3, 'foo', false]) // returns [true, false, true]\n *\n * See also:\n *\n * isZero, isPositive, isNegative, isInteger, hasNumericValue\n *\n * @param {*} x Value to be tested\n * @return {boolean} Returns true when `x` is a `number`, `BigNumber`,\n * `Fraction`, or `boolean`. Returns false for other types.\n * Throws an error in case of unknown types.\n */\n return typed(name, {\n 'number | BigNumber | bigint | Fraction | boolean': () => true,\n 'Complex | Unit | string | null | undefined | Node': () => false,\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'hasNumericValue'\nconst dependencies = ['typed', 'isNumeric']\n\nexport const createHasNumericValue = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNumeric }) => {\n /**\n * Test whether a value is an numeric value.\n *\n * In case of a string, true is returned if the string contains a numeric value.\n *\n * Syntax:\n *\n * math.hasNumericValue(x)\n *\n * Examples:\n *\n * math.hasNumericValue(2) // returns true\n * math.hasNumericValue('2') // returns true\n * math.isNumeric('2') // returns false\n * math.hasNumericValue(0) // returns true\n * math.hasNumericValue(math.bignumber('500')) // returns true\n * math.hasNumericValue(math.bigint('42')) // returns true\n * math.hasNumericValue(42n) // returns true\n * math.hasNumericValue(math.fraction(4)) // returns true\n * math.hasNumericValue(math.complex('2-4i')) // returns false\n * math.hasNumericValue(false) // returns true\n * math.hasNumericValue([2.3, 'foo', false]) // returns [true, false, true]\n *\n * See also:\n *\n * isZero, isPositive, isNegative, isInteger, isNumeric\n *\n * @param {*} x Value to be tested\n * @return {boolean} Returns true when `x` is a `number`, `BigNumber`,\n * `Fraction`, `Boolean`, or a `String` containing number. Returns false for other types.\n * Throws an error in case of unknown types.\n */\n return typed(name, {\n boolean: () => true,\n string: function (x) {\n return x.trim().length > 0 && !isNaN(Number(x))\n },\n any: function (x) {\n return isNumeric(x)\n }\n })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isPositiveNumber } from '../../plain/number/index.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\n\nconst name = 'isPositive'\nconst dependencies = ['typed', 'config']\n\nexport const createIsPositive = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\n /**\n * Test whether a value is positive: larger than zero.\n * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isPositive(x)\n *\n * Examples:\n *\n * math.isPositive(3) // returns true\n * math.isPositive(-2) // returns false\n * math.isPositive(0) // returns false\n * math.isPositive(-0) // returns false\n * math.isPositive(0.5) // returns true\n * math.isPositive(math.bignumber(2)) // returns true\n * math.isPositive(math.fraction(-2, 5)) // returns false\n * math.isPositive(math.fraction(1, 3)) // returns true\n * math.isPositive('2') // returns true\n * math.isPositive([2, 0, -3]) // returns [true, false, false]\n *\n * See also:\n *\n * isNumeric, isZero, isNegative, isInteger\n *\n * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isPositiveNumber(x),\n\n BigNumber: x =>\n bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol)\n ? false\n : !x.isNeg() && !x.isZero() && !x.isNaN(),\n\n bigint: x => x > 0n,\n\n Fraction: x => x.s > 0 && x.n > 0,\n\n Unit: typed.referToSelf(self =>\n x => typed.find(self, x.valueType())(x.value)),\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isZero'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createIsZero = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Test whether a value is zero.\n * The function can check for zero for types `number`, `BigNumber`, `Fraction`,\n * `Complex`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isZero(x)\n *\n * Examples:\n *\n * math.isZero(0) // returns true\n * math.isZero(2) // returns false\n * math.isZero(0.5) // returns false\n * math.isZero(math.bignumber(0)) // returns true\n * math.isZero(math.fraction(0)) // returns true\n * math.isZero(math.fraction(1,3)) // returns false\n * math.isZero(math.complex('2 - 4i')) // returns false\n * math.isZero(math.complex('0i')) // returns true\n * math.isZero('0') // returns true\n * math.isZero('2') // returns false\n * math.isZero([2, 0, -3]) // returns [false, true, false]\n *\n * See also:\n *\n * isNumeric, isPositive, isNegative, isInteger\n *\n * @param {number | BigNumber | bigint | Complex | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n 'number | BigNumber | Complex | Fraction': x => equalScalar(x, 0),\n\n bigint: x => x === 0n,\n\n Unit: typed.referToSelf(self =>\n x => typed.find(self, x.valueType())(x.value)),\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNaNNumber } from '../../plain/number/index.js'\n\nconst name = 'isNaN'\nconst dependencies = ['typed']\n\nexport const createIsNaN = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Test whether a value is NaN (not a number).\n * The function supports types `number`, `BigNumber`, `Fraction`, `Unit` and `Complex`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNaN(x)\n *\n * Examples:\n *\n * math.isNaN(3) // returns false\n * math.isNaN(NaN) // returns true\n * math.isNaN(0) // returns false\n * math.isNaN(math.bignumber(NaN)) // returns true\n * math.isNaN(math.bignumber(0)) // returns false\n * math.isNaN(math.fraction(-2, 5)) // returns false\n * math.isNaN('-2') // returns false\n * math.isNaN([2, 0, -3, NaN]) // returns [false, false, false, true]\n *\n * See also:\n *\n * isNumeric, isNegative, isPositive, isZero, isInteger\n *\n * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is NaN.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: isNaNNumber,\n\n BigNumber: function (x) {\n return x.isNaN()\n },\n\n bigint: function (x) {\n return false\n },\n\n Fraction: function (x) {\n return false\n },\n\n Complex: function (x) {\n return x.isNaN()\n },\n\n Unit: function (x) {\n return Number.isNaN(x.value)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { typeOf as _typeOf } from '../../utils/is.js'\n\nconst name = 'typeOf'\nconst dependencies = ['typed']\n\nexport const createTypeOf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Determine the type of an entity.\n *\n * Syntax:\n *\n * math.typeOf(x)\n *\n * Examples:\n *\n * // This list is intended to include all relevant types, for testing\n * // purposes:\n * math.typeOf(3.5) // returns 'number'\n * math.typeOf(42n) // returns 'bigint'\n * math.typeOf(math.complex('2-4i')) // returns 'Complex'\n * math.typeOf(math.unit('45 deg')) // returns 'Unit'\n * math.typeOf('hello world') // returns 'string'\n * math.typeOf(null) // returns 'null'\n * math.typeOf(true) // returns 'boolean'\n * math.typeOf([1, 2, 3]) // returns 'Array'\n * math.typeOf(new Date()) // returns 'Date'\n * math.typeOf(function () {}) // returns 'function'\n * math.typeOf({a: 2, b: 3}) // returns 'Object'\n * math.typeOf(/a regexp/) // returns 'RegExp'\n * math.typeOf(undefined) // returns 'undefined'\n * math.typeOf(math.bignumber('23e99')) // returns 'BigNumber'\n * math.typeOf(math.chain(2)) // returns 'Chain'\n * math.typeOf(math.fraction(1, 3)) // returns 'Fraction'\n * math.typeOf(math.help('sqrt')) // returns 'Help'\n * math.typeOf(math.index(1, 3)) // returns 'Index'\n * math.typeOf(math.matrix([[1],[3]])) // returns 'DenseMatrix'\n * math.typeOf(math.matrix([],'sparse')) // returns 'SparseMatrix'\n * math.typeOf(new math.Range(0, 10)) // returns 'Range'\n * math.typeOf(math.evaluate('a=2\\na')) // returns 'ResultSet'\n * math.typeOf(math.parse('A[2]')) // returns 'AccessorNode'\n * math.typeOf(math.parse('[1,2,3]')) // returns 'ArrayNode'\n * math.typeOf(math.parse('x=2')) // returns 'AssignmentNode'\n * math.typeOf(math.parse('a=2; b=3')) // returns 'BlockNode'\n * math.typeOf(math.parse('x<0?-1:1')) // returns 'ConditionalNode'\n * math.typeOf(math.parse('2.3')) // returns 'ConstantNode'\n * math.typeOf(math.parse('f(x)=x^2')) // returns 'FunctionAssignmentNode'\n * math.typeOf(math.parse('sqrt(4)')) // returns 'FunctionNode'\n * math.typeOf(math.parse('A[2]').index) // returns 'IndexNode'\n * math.typeOf(math.parse('{a:2}')) // returns 'ObjectNode'\n * math.typeOf(math.parse('(2+3)')) // returns 'ParenthesisNode'\n * math.typeOf(math.parse('1:10')) // returns 'RangeNode'\n * math.typeOf(math.parse('a ({\n 'Unit, Unit': typed.referToSelf(self => (x, y) => {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base')\n }\n return typed.find(self, [x.valueType(), y.valueType()])(x.value, y.value)\n })\n })\n)\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { complexEquals } from '../../utils/complex.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'equalScalar'\nconst dependencies = ['typed', 'config']\n\nexport const createEqualScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Test whether two scalar values are nearly equal.\n *\n * @param {number | BigNumber | bigint | Fraction | boolean | Complex | Unit} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | boolean | Complex} y Second value to compare\n * @return {boolean} Returns true when the compared values are equal, else returns false\n * @private\n */\n return typed(name, {\n\n 'boolean, boolean': function (x, y) {\n return x === y\n },\n\n 'number, number': function (x, y) {\n return nearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.eq(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'bigint, bigint': function (x, y) {\n return x === y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return x.equals(y)\n },\n\n 'Complex, Complex': function (x, y) {\n return complexEquals(x, y, config.relTol, config.absTol)\n }\n }, compareUnits)\n})\n\nexport const createEqualScalarNumber = factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return nearlyEqual(x, y, config.relTol, config.absTol)\n }\n })\n})\n","import { nearlyEqual } from './number.js'\n\n/**\n * Test whether two complex values are equal provided a given relTol and absTol.\n * Does not use or change the global Complex.EPSILON setting\n * @param {Complex} x - The first complex number for comparison.\n * @param {Complex} y - The second complex number for comparison.\n * @param {number} relTol - The relative tolerance for comparison.\n * @param {number} absTol - The absolute tolerance for comparison.\n * @returns {boolean} - Returns true if the two complex numbers are equal within the given tolerances, otherwise returns false.\n */\nexport function complexEquals (x, y, relTol, absTol) {\n return nearlyEqual(x.re, y.re, relTol, absTol) && nearlyEqual(x.im, y.im, relTol, absTol)\n}\n","import { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { format } from '../../utils/string.js'\nimport { clone, deepStrictEqual } from '../../utils/object.js'\nimport { arraySize, getArrayDataType, processSizesWildcard, unsqueeze, validateIndex } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { optimizeCallback } from '../../utils/optimizeCallback.js'\n\nconst name = 'SparseMatrix'\nconst dependencies = [\n 'typed',\n 'equalScalar',\n 'Matrix'\n]\n\nexport const createSparseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar, Matrix }) => {\n /**\n * Sparse Matrix implementation. This type implements\n * a [Compressed Column Storage](https://en.wikipedia.org/wiki/Sparse_matrix#Compressed_sparse_column_(CSC_or_CCS))\n * format for two-dimensional sparse matrices.\n * @class SparseMatrix\n */\n function SparseMatrix (data, datatype) {\n if (!(this instanceof SparseMatrix)) { throw new SyntaxError('Constructor must be called with the new operator') }\n if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n if (isMatrix(data)) {\n // create from matrix\n _createFromMatrix(this, data, datatype)\n } else if (data && isArray(data.index) && isArray(data.ptr) && isArray(data.size)) {\n // initialize fields\n this._values = data.values\n this._index = data.index\n this._ptr = data.ptr\n this._size = data.size\n this._datatype = datatype || data.datatype\n } else if (isArray(data)) {\n // create from array\n _createFromArray(this, data, datatype)\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + typeOf(data) + ')')\n } else {\n // nothing provided\n this._values = []\n this._index = []\n this._ptr = [0]\n this._size = [0, 0]\n this._datatype = datatype\n }\n }\n\n function _createFromMatrix (matrix, source, datatype) {\n // check matrix type\n if (source.type === 'SparseMatrix') {\n // clone arrays\n matrix._values = source._values ? clone(source._values) : undefined\n matrix._index = clone(source._index)\n matrix._ptr = clone(source._ptr)\n matrix._size = clone(source._size)\n matrix._datatype = datatype || source._datatype\n } else {\n // build from matrix data\n _createFromArray(matrix, source.valueOf(), datatype || source._datatype)\n }\n }\n\n function _createFromArray (matrix, data, datatype) {\n // initialize fields\n matrix._values = []\n matrix._index = []\n matrix._ptr = []\n matrix._datatype = datatype\n // discover rows & columns, do not use math.size() to avoid looping array twice\n const rows = data.length\n let columns = 0\n\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n if (isString(datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar\n // convert 0 to the same datatype\n zero = typed.convert(0, datatype)\n }\n\n // check we have rows (empty array)\n if (rows > 0) {\n // column index\n let j = 0\n do {\n // store pointer to values index\n matrix._ptr.push(matrix._index.length)\n // loop rows\n for (let i = 0; i < rows; i++) {\n // current row\n const row = data[i]\n // check row is an array\n if (isArray(row)) {\n // update columns if needed (only on first column)\n if (j === 0 && columns < row.length) { columns = row.length }\n // check row has column\n if (j < row.length) {\n // value\n const v = row[j]\n // check value != 0\n if (!eq(v, zero)) {\n // store value\n matrix._values.push(v)\n // index\n matrix._index.push(i)\n }\n }\n } else {\n // update columns if needed (only on first column)\n if (j === 0 && columns < 1) { columns = 1 }\n // check value != 0 (row is a scalar)\n if (!eq(row, zero)) {\n // store value\n matrix._values.push(row)\n // index\n matrix._index.push(i)\n }\n }\n }\n // increment index\n j++\n }\n while (j < columns)\n }\n // store number of values in ptr\n matrix._ptr.push(matrix._index.length)\n // size\n matrix._size = [rows, columns]\n }\n\n SparseMatrix.prototype = new Matrix()\n\n /**\n * Create a new SparseMatrix\n */\n SparseMatrix.prototype.createSparseMatrix = function (data, datatype) {\n return new SparseMatrix(data, datatype)\n }\n\n /**\n * Attach type information\n */\n Object.defineProperty(SparseMatrix, 'name', { value: 'SparseMatrix' })\n SparseMatrix.prototype.constructor = SparseMatrix\n SparseMatrix.prototype.type = 'SparseMatrix'\n SparseMatrix.prototype.isSparseMatrix = true\n\n /**\n * Get the matrix type\n *\n * Usage:\n * const matrixType = matrix.getDataType() // retrieves the matrix type\n *\n * @memberOf SparseMatrix\n * @return {string} type information; if multiple types are found from the Matrix, it will return \"mixed\"\n */\n SparseMatrix.prototype.getDataType = function () {\n return getArrayDataType(this._values, typeOf)\n }\n\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @memberof SparseMatrix\n * @return {string} The storage format.\n */\n SparseMatrix.prototype.storage = function () {\n return 'sparse'\n }\n\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @memberof SparseMatrix\n * @return {string} The datatype.\n */\n SparseMatrix.prototype.datatype = function () {\n return this._datatype\n }\n\n /**\n * Create a new SparseMatrix\n * @memberof SparseMatrix\n * @param {Array} data\n * @param {string} [datatype]\n */\n SparseMatrix.prototype.create = function (data, datatype) {\n return new SparseMatrix(data, datatype)\n }\n\n /**\n * Get the matrix density.\n *\n * Usage:\n * const density = matrix.density() // retrieve matrix density\n *\n * @memberof SparseMatrix\n * @return {number} The matrix density.\n */\n SparseMatrix.prototype.density = function () {\n // rows & columns\n const rows = this._size[0]\n const columns = this._size[1]\n // calculate density\n return rows !== 0 && columns !== 0 ? (this._index.length / (rows * columns)) : 0\n }\n\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @memberof SparseMatrix\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n SparseMatrix.prototype.subset = function (index, replacement, defaultValue) { // check it is a pattern matrix\n if (!this._values) { throw new Error('Cannot invoke subset on a Pattern only matrix') }\n\n // check arguments\n switch (arguments.length) {\n case 1:\n return _getsubset(this, index)\n\n // intentional fall through\n case 2:\n case 3:\n return _setsubset(this, index, replacement, defaultValue)\n\n default:\n throw new SyntaxError('Wrong number of arguments')\n }\n }\n\n function _getsubset (matrix, idx) {\n // check idx\n if (!isIndex(idx)) {\n throw new TypeError('Invalid index')\n }\n\n const isScalar = idx.isScalar()\n if (isScalar) {\n // return a scalar\n return matrix.get(idx.min())\n }\n // validate dimensions\n const size = idx.size()\n if (size.length !== matrix._size.length) {\n throw new DimensionError(size.length, matrix._size.length)\n }\n\n // vars\n let i, ii, k, kk\n\n // validate if any of the ranges in the index is out of range\n const min = idx.min()\n const max = idx.max()\n for (i = 0, ii = matrix._size.length; i < ii; i++) {\n validateIndex(min[i], matrix._size[i])\n validateIndex(max[i], matrix._size[i])\n }\n\n // matrix arrays\n const mvalues = matrix._values\n const mindex = matrix._index\n const mptr = matrix._ptr\n\n // rows & columns dimensions for result matrix\n const rows = idx.dimension(0)\n const columns = idx.dimension(1)\n\n // workspace & permutation vector\n const w = []\n const pv = []\n\n // loop rows in resulting matrix\n rows.forEach(function (i, r) {\n // update permutation vector\n pv[i] = r[0]\n // mark i in workspace\n w[i] = true\n })\n\n // result matrix arrays\n const values = mvalues ? [] : undefined\n const index = []\n const ptr = []\n\n // loop columns in result matrix\n columns.forEach(function (j) {\n // update ptr\n ptr.push(index.length)\n // loop values in column j\n for (k = mptr[j], kk = mptr[j + 1]; k < kk; k++) {\n // row\n i = mindex[k]\n // check row is in result matrix\n if (w[i] === true) {\n // push index\n index.push(pv[i])\n // check we need to process values\n if (values) { values.push(mvalues[k]) }\n }\n }\n })\n // update ptr\n ptr.push(index.length)\n\n // return matrix\n return new SparseMatrix({\n values,\n index,\n ptr,\n size,\n datatype: matrix._datatype\n })\n }\n\n function _setsubset (matrix, index, submatrix, defaultValue) {\n // check index\n if (!index || index.isIndex !== true) {\n throw new TypeError('Invalid index')\n }\n\n // get index size and check whether the index contains a single value\n const iSize = index.size()\n const isScalar = index.isScalar()\n\n // calculate the size of the submatrix, and convert it into an Array if needed\n let sSize\n if (isMatrix(submatrix)) {\n // submatrix size\n sSize = submatrix.size()\n // use array representation\n submatrix = submatrix.toArray()\n } else {\n // get submatrix size (array, scalar)\n sSize = arraySize(submatrix)\n }\n\n // check index is a scalar\n if (isScalar) {\n // verify submatrix is a scalar\n if (sSize.length !== 0) {\n throw new TypeError('Scalar expected')\n }\n // set value\n matrix.set(index.min(), submatrix, defaultValue)\n } else {\n // validate dimensions, index size must be one or two dimensions\n if (iSize.length !== 1 && iSize.length !== 2) {\n throw new DimensionError(iSize.length, matrix._size.length, '<')\n }\n\n // check submatrix and index have the same dimensions\n if (sSize.length < iSize.length) {\n // calculate number of missing outer dimensions\n let i = 0\n let outer = 0\n while (iSize[i] === 1 && sSize[i] === 1) {\n i++\n }\n while (iSize[i] === 1) {\n outer++\n i++\n }\n // unsqueeze both outer and inner dimensions\n submatrix = unsqueeze(submatrix, iSize.length, outer, sSize)\n }\n\n // check whether the size of the submatrix matches the index size\n if (!deepStrictEqual(iSize, sSize)) {\n throw new DimensionError(iSize, sSize, '>')\n }\n\n // insert the sub matrix\n if (iSize.length === 1) {\n // if the replacement index only has 1 dimension, go trough each one and set its value\n const range = index.dimension(0)\n range.forEach(function (dataIndex, subIndex) {\n validateIndex(dataIndex)\n matrix.set([dataIndex, 0], submatrix[subIndex[0]], defaultValue)\n })\n } else {\n // if the replacement index has 2 dimensions, go through each one and set the value in the correct index\n const firstDimensionRange = index.dimension(0)\n const secondDimensionRange = index.dimension(1)\n firstDimensionRange.forEach(function (firstDataIndex, firstSubIndex) {\n validateIndex(firstDataIndex)\n secondDimensionRange.forEach(function (secondDataIndex, secondSubIndex) {\n validateIndex(secondDataIndex)\n matrix.set([firstDataIndex, secondDataIndex], submatrix[firstSubIndex[0]][secondSubIndex[0]], defaultValue)\n })\n })\n }\n }\n return matrix\n }\n\n /**\n * Get a single element from the matrix.\n * @memberof SparseMatrix\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n SparseMatrix.prototype.get = function (index) {\n if (!isArray(index)) { throw new TypeError('Array expected') }\n if (index.length !== this._size.length) { throw new DimensionError(index.length, this._size.length) }\n\n // check it is a pattern matrix\n if (!this._values) { throw new Error('Cannot invoke get on a Pattern only matrix') }\n\n // row and column\n const i = index[0]\n const j = index[1]\n\n // check i, j are valid\n validateIndex(i, this._size[0])\n validateIndex(j, this._size[1])\n\n // find value index\n const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index)\n // check k is prior to next column k and it is in the correct row\n if (k < this._ptr[j + 1] && this._index[k] === i) { return this._values[k] }\n\n return 0\n }\n\n /**\n * Replace a single element in the matrix.\n * @memberof SparseMatrix\n * @param {number[]} index Zero-based index\n * @param {*} v\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be set to zero.\n * @return {SparseMatrix} self\n */\n SparseMatrix.prototype.set = function (index, v, defaultValue) {\n if (!isArray(index)) { throw new TypeError('Array expected') }\n if (index.length !== this._size.length) { throw new DimensionError(index.length, this._size.length) }\n\n // check it is a pattern matrix\n if (!this._values) { throw new Error('Cannot invoke set on a Pattern only matrix') }\n\n // row and column\n const i = index[0]\n const j = index[1]\n\n // rows & columns\n let rows = this._size[0]\n let columns = this._size[1]\n\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n if (isString(this._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [this._datatype, this._datatype]) || equalScalar\n // convert 0 to the same datatype\n zero = typed.convert(0, this._datatype)\n }\n\n // check we need to resize matrix\n if (i > rows - 1 || j > columns - 1) {\n // resize matrix\n _resize(this, Math.max(i + 1, rows), Math.max(j + 1, columns), defaultValue)\n // update rows & columns\n rows = this._size[0]\n columns = this._size[1]\n }\n\n // check i, j are valid\n validateIndex(i, rows)\n validateIndex(j, columns)\n\n // find value index\n const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index)\n // check k is prior to next column k and it is in the correct row\n if (k < this._ptr[j + 1] && this._index[k] === i) {\n // check value != 0\n if (!eq(v, zero)) {\n // update value\n this._values[k] = v\n } else {\n // remove value from matrix\n _remove(k, j, this._values, this._index, this._ptr)\n }\n } else {\n if (!eq(v, zero)) {\n // insert value @ (i, j)\n _insert(k, i, j, v, this._values, this._index, this._ptr)\n }\n }\n\n return this\n }\n\n function _getValueIndex (i, top, bottom, index) {\n // check row is on the bottom side\n if (bottom - top === 0) { return bottom }\n // loop rows [top, bottom[\n for (let r = top; r < bottom; r++) {\n // check we found value index\n if (index[r] === i) { return r }\n }\n // we did not find row\n return top\n }\n\n function _remove (k, j, values, index, ptr) {\n // remove value @ k\n values.splice(k, 1)\n index.splice(k, 1)\n // update pointers\n for (let x = j + 1; x < ptr.length; x++) { ptr[x]-- }\n }\n\n function _insert (k, i, j, v, values, index, ptr) {\n // insert value\n values.splice(k, 0, v)\n // update row for k\n index.splice(k, 0, i)\n // update column pointers\n for (let x = j + 1; x < ptr.length; x++) { ptr[x]++ }\n }\n\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @memberof SparseMatrix\n * @param {number[] | Matrix} size The new size the matrix should have.\n * Since sparse matrices are always two-dimensional,\n * size must be two numbers in either an array or a matrix\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n SparseMatrix.prototype.resize = function (size, defaultValue, copy) {\n // validate arguments\n if (!isCollection(size)) {\n throw new TypeError('Array or Matrix expected')\n }\n\n // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n const sizeArray = size.valueOf().map(value => {\n return Array.isArray(value) && value.length === 1\n ? value[0]\n : value\n })\n\n if (sizeArray.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n // check sizes\n sizeArray.forEach(function (value) {\n if (!isNumber(value) || !isInteger(value) || value < 0) {\n throw new TypeError('Invalid size, must contain positive integers ' +\n '(size: ' + format(sizeArray) + ')')\n }\n })\n\n // matrix to resize\n const m = copy ? this.clone() : this\n // resize matrix\n return _resize(m, sizeArray[0], sizeArray[1], defaultValue)\n }\n\n function _resize (matrix, rows, columns, defaultValue) {\n // value to insert at the time of growing matrix\n let value = defaultValue || 0\n\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n if (isString(matrix._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar\n // convert 0 to the same datatype\n zero = typed.convert(0, matrix._datatype)\n // convert value to the same datatype\n value = typed.convert(value, matrix._datatype)\n }\n\n // should we insert the value?\n const ins = !eq(value, zero)\n\n // old columns and rows\n const r = matrix._size[0]\n let c = matrix._size[1]\n\n let i, j, k\n\n // check we need to increase columns\n if (columns > c) {\n // loop new columns\n for (j = c; j < columns; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._values.length\n // check we need to insert matrix._values\n if (ins) {\n // loop rows\n for (i = 0; i < r; i++) {\n // add new matrix._values\n matrix._values.push(value)\n // update matrix._index\n matrix._index.push(i)\n }\n }\n }\n // store number of matrix._values in matrix._ptr\n matrix._ptr[columns] = matrix._values.length\n } else if (columns < c) {\n // truncate matrix._ptr\n matrix._ptr.splice(columns + 1, c - columns)\n // truncate matrix._values and matrix._index\n matrix._values.splice(matrix._ptr[columns], matrix._values.length)\n matrix._index.splice(matrix._ptr[columns], matrix._index.length)\n }\n // update columns\n c = columns\n\n // check we need to increase rows\n if (rows > r) {\n // check we have to insert values\n if (ins) {\n // inserts\n let n = 0\n // loop columns\n for (j = 0; j < c; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._ptr[j] + n\n // where to insert matrix._values\n k = matrix._ptr[j + 1] + n\n // pointer\n let p = 0\n // loop new rows, initialize pointer\n for (i = r; i < rows; i++, p++) {\n // add value\n matrix._values.splice(k + p, 0, value)\n // update matrix._index\n matrix._index.splice(k + p, 0, i)\n // increment inserts\n n++\n }\n }\n // store number of matrix._values in matrix._ptr\n matrix._ptr[c] = matrix._values.length\n }\n } else if (rows < r) {\n // deletes\n let d = 0\n // loop columns\n for (j = 0; j < c; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._ptr[j] - d\n // where matrix._values start for next column\n const k0 = matrix._ptr[j]\n const k1 = matrix._ptr[j + 1] - d\n // loop matrix._index\n for (k = k0; k < k1; k++) {\n // row\n i = matrix._index[k]\n // check we need to delete value and matrix._index\n if (i > rows - 1) {\n // remove value\n matrix._values.splice(k, 1)\n // remove item from matrix._index\n matrix._index.splice(k, 1)\n // increase deletes\n d++\n }\n }\n }\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._values.length\n }\n // update matrix._size\n matrix._size[0] = rows\n matrix._size[1] = columns\n // return matrix\n return matrix\n }\n\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * NOTE: This might be better suited to copy by default, instead of modifying\n * in place. For now, it operates in place to remain consistent with\n * resize().\n *\n * @memberof SparseMatrix\n * @param {number[]} sizes The new size the matrix should have.\n * Since sparse matrices are always two-dimensional,\n * size must be two numbers in either an array or a matrix\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n SparseMatrix.prototype.reshape = function (sizes, copy) {\n // validate arguments\n if (!isArray(sizes)) { throw new TypeError('Array expected') }\n if (sizes.length !== 2) { throw new Error('Sparse matrices can only be reshaped in two dimensions') }\n\n // check sizes\n sizes.forEach(function (value) {\n if (!isNumber(value) || !isInteger(value) || value <= -2 || value === 0) {\n throw new TypeError('Invalid size, must contain positive integers or -1 ' +\n '(size: ' + format(sizes) + ')')\n }\n })\n\n const currentLength = this._size[0] * this._size[1]\n sizes = processSizesWildcard(sizes, currentLength)\n const newLength = sizes[0] * sizes[1]\n\n // m * n must not change\n if (currentLength !== newLength) {\n throw new Error('Reshaping sparse matrix will result in the wrong number of elements')\n }\n\n // matrix to reshape\n const m = copy ? this.clone() : this\n\n // return unchanged if the same shape\n if (this._size[0] === sizes[0] && this._size[1] === sizes[1]) {\n return m\n }\n\n // Convert to COO format (generate a column index)\n const colIndex = []\n for (let i = 0; i < m._ptr.length; i++) {\n for (let j = 0; j < m._ptr[i + 1] - m._ptr[i]; j++) {\n colIndex.push(i)\n }\n }\n\n // Clone the values array\n const values = m._values.slice()\n\n // Clone the row index array\n const rowIndex = m._index.slice()\n\n // Transform the (row, column) indices\n for (let i = 0; i < m._index.length; i++) {\n const r1 = rowIndex[i]\n const c1 = colIndex[i]\n const flat = r1 * m._size[1] + c1\n colIndex[i] = flat % sizes[1]\n rowIndex[i] = Math.floor(flat / sizes[1])\n }\n\n // Now reshaping is supposed to preserve the row-major order, BUT these sparse matrices are stored\n // in column-major order, so we have to reorder the value array now. One option is to use a multisort,\n // sorting several arrays based on some other array.\n\n // OR, we could easily just:\n\n // 1. Remove all values from the matrix\n m._values.length = 0\n m._index.length = 0\n m._ptr.length = sizes[1] + 1\n m._size = sizes.slice()\n for (let i = 0; i < m._ptr.length; i++) {\n m._ptr[i] = 0\n }\n\n // 2. Re-insert all elements in the proper order (simplified code from SparseMatrix.prototype.set)\n // This step is probably the most time-consuming\n for (let h = 0; h < values.length; h++) {\n const i = rowIndex[h]\n const j = colIndex[h]\n const v = values[h]\n const k = _getValueIndex(i, m._ptr[j], m._ptr[j + 1], m._index)\n _insert(k, i, j, v, m._values, m._index, m._ptr)\n }\n\n // The value indices are inserted out of order, but apparently that's... still OK?\n\n return m\n }\n\n /**\n * Create a clone of the matrix\n * @memberof SparseMatrix\n * @return {SparseMatrix} clone\n */\n SparseMatrix.prototype.clone = function () {\n const m = new SparseMatrix({\n values: this._values ? clone(this._values) : undefined,\n index: clone(this._index),\n ptr: clone(this._ptr),\n size: clone(this._size),\n datatype: this._datatype\n })\n return m\n }\n\n /**\n * Retrieve the size of the matrix.\n * @memberof SparseMatrix\n * @returns {number[]} size\n */\n SparseMatrix.prototype.size = function () {\n return this._size.slice(0) // copy the Array\n }\n\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @memberof SparseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {SparseMatrix} matrix\n */\n SparseMatrix.prototype.map = function (callback, skipZeros) {\n // check it is a pattern matrix\n if (!this._values) { throw new Error('Cannot invoke map on a Pattern only matrix') }\n // matrix instance\n const me = this\n // rows and columns\n const rows = this._size[0]\n const columns = this._size[1]\n const fastCallback = optimizeCallback(callback, me, 'map')\n // invoke callback\n const invoke = function (v, i, j) {\n // invoke callback\n return fastCallback(v, [i, j], me)\n }\n // invoke _map\n return _map(this, 0, rows - 1, 0, columns - 1, invoke, skipZeros)\n }\n\n /**\n * Create a new matrix with the results of the callback function executed on the interval\n * [minRow..maxRow, minColumn..maxColumn].\n */\n function _map (matrix, minRow, maxRow, minColumn, maxColumn, callback, skipZeros) {\n // result arrays\n const values = []\n const index = []\n const ptr = []\n\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n if (isString(matrix._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar\n // convert 0 to the same datatype\n zero = typed.convert(0, matrix._datatype)\n }\n\n // invoke callback\n const invoke = function (v, x, y) {\n // invoke callback\n const value = callback(v, x, y)\n // check value != 0\n if (!eq(value, zero)) {\n // store value\n values.push(value)\n // index\n index.push(x)\n }\n }\n // loop columns\n for (let j = minColumn; j <= maxColumn; j++) {\n // store pointer to values index\n ptr.push(values.length)\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = matrix._ptr[j]\n const k1 = matrix._ptr[j + 1]\n\n if (skipZeros) {\n // loop k within [k0, k1[\n for (let k = k0; k < k1; k++) {\n // row index\n const i = matrix._index[k]\n // check i is in range\n if (i >= minRow && i <= maxRow) {\n // value @ k\n invoke(matrix._values[k], i - minRow, j - minColumn)\n }\n }\n } else {\n // create a cache holding all defined values\n const values = {}\n for (let k = k0; k < k1; k++) {\n const i = matrix._index[k]\n values[i] = matrix._values[k]\n }\n\n // loop over all rows (indexes can be unordered so we can't use that),\n // and either read the value or zero\n for (let i = minRow; i <= maxRow; i++) {\n const value = (i in values) ? values[i] : 0\n invoke(value, i - minRow, j - minColumn)\n }\n }\n }\n\n // store number of values in ptr\n ptr.push(values.length)\n // return sparse matrix\n return new SparseMatrix({\n values,\n index,\n ptr,\n size: [maxRow - minRow + 1, maxColumn - minColumn + 1]\n })\n }\n\n /**\n * Execute a callback function on each entry of the matrix.\n * @memberof SparseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n * If false, the indices are guaranteed to be in order,\n * if true, the indices can be unordered.\n */\n SparseMatrix.prototype.forEach = function (callback, skipZeros) {\n // check it is a pattern matrix\n if (!this._values) { throw new Error('Cannot invoke forEach on a Pattern only matrix') }\n // matrix instance\n const me = this\n // rows and columns\n const rows = this._size[0]\n const columns = this._size[1]\n const fastCallback = optimizeCallback(callback, me, 'forEach')\n // loop columns\n for (let j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = this._ptr[j]\n const k1 = this._ptr[j + 1]\n\n if (skipZeros) {\n // loop k within [k0, k1[\n for (let k = k0; k < k1; k++) {\n // row index\n const i = this._index[k]\n\n // value @ k\n fastCallback(this._values[k], [i, j], me)\n }\n } else {\n // create a cache holding all defined values\n const values = {}\n for (let k = k0; k < k1; k++) {\n const i = this._index[k]\n values[i] = this._values[k]\n }\n\n // loop over all rows (indexes can be unordered so we can't use that),\n // and either read the value or zero\n for (let i = 0; i < rows; i++) {\n const value = (i in values) ? values[i] : 0\n fastCallback(value, [i, j], me)\n }\n }\n }\n }\n\n /**\n * Iterate over the matrix elements, skipping zeros\n * @return {Iterable<{ value, index: number[] }>}\n */\n SparseMatrix.prototype[Symbol.iterator] = function * () {\n if (!this._values) { throw new Error('Cannot iterate a Pattern only matrix') }\n\n const columns = this._size[1]\n\n for (let j = 0; j < columns; j++) {\n const k0 = this._ptr[j]\n const k1 = this._ptr[j + 1]\n\n for (let k = k0; k < k1; k++) {\n // row index\n const i = this._index[k]\n\n yield ({ value: this._values[k], index: [i, j] })\n }\n }\n }\n\n /**\n * Create an Array with a copy of the data of the SparseMatrix\n * @memberof SparseMatrix\n * @returns {Array} array\n */\n SparseMatrix.prototype.toArray = function () {\n return _toArray(this._values, this._index, this._ptr, this._size, true)\n }\n\n /**\n * Get the primitive value of the SparseMatrix: a two dimensions array\n * @memberof SparseMatrix\n * @returns {Array} array\n */\n SparseMatrix.prototype.valueOf = function () {\n return _toArray(this._values, this._index, this._ptr, this._size, false)\n }\n\n function _toArray (values, index, ptr, size, copy) {\n // rows and columns\n const rows = size[0]\n const columns = size[1]\n // result\n const a = []\n // vars\n let i, j\n // initialize array\n for (i = 0; i < rows; i++) {\n a[i] = []\n for (j = 0; j < columns; j++) { a[i][j] = 0 }\n }\n\n // loop columns\n for (j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = ptr[j]\n const k1 = ptr[j + 1]\n // loop k within [k0, k1[\n for (let k = k0; k < k1; k++) {\n // row index\n i = index[k]\n // set value (use one for pattern matrix)\n a[i][j] = values ? (copy ? clone(values[k]) : values[k]) : 1\n }\n }\n return a\n }\n\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @memberof SparseMatrix\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n SparseMatrix.prototype.format = function (options) {\n // rows and columns\n const rows = this._size[0]\n const columns = this._size[1]\n // density\n const density = this.density()\n // rows & columns\n let str = 'Sparse Matrix [' + format(rows, options) + ' x ' + format(columns, options) + '] density: ' + format(density, options) + '\\n'\n // loop columns\n for (let j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = this._ptr[j]\n const k1 = this._ptr[j + 1]\n // loop k within [k0, k1[\n for (let k = k0; k < k1; k++) {\n // row index\n const i = this._index[k]\n // append value\n str += '\\n (' + format(i, options) + ', ' + format(j, options) + ') ==> ' + (this._values ? format(this._values[k], options) : 'X')\n }\n }\n return str\n }\n\n /**\n * Get a string representation of the matrix\n * @memberof SparseMatrix\n * @returns {string} str\n */\n SparseMatrix.prototype.toString = function () {\n return format(this.toArray())\n }\n\n /**\n * Get a JSON representation of the matrix\n * @memberof SparseMatrix\n * @returns {Object}\n */\n SparseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'SparseMatrix',\n values: this._values,\n index: this._index,\n ptr: this._ptr,\n size: this._size,\n datatype: this._datatype\n }\n }\n\n /**\n * Get the kth Matrix diagonal.\n *\n * @memberof SparseMatrix\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved.\n *\n * @returns {Matrix} The matrix vector with the diagonal values.\n */\n SparseMatrix.prototype.diagonal = function (k) {\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if (isBigNumber(k)) { k = k.toNumber() }\n // is must be an integer\n if (!isNumber(k) || !isInteger(k)) {\n throw new TypeError('The parameter k must be an integer number')\n }\n } else {\n // default value\n k = 0\n }\n\n const kSuper = k > 0 ? k : 0\n const kSub = k < 0 ? -k : 0\n\n // rows & columns\n const rows = this._size[0]\n const columns = this._size[1]\n\n // number diagonal values\n const n = Math.min(rows - kSub, columns - kSuper)\n\n // diagonal arrays\n const values = []\n const index = []\n const ptr = []\n // initial ptr value\n ptr[0] = 0\n // loop columns\n for (let j = kSuper; j < columns && values.length < n; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = this._ptr[j]\n const k1 = this._ptr[j + 1]\n // loop x within [k0, k1[\n for (let x = k0; x < k1; x++) {\n // row index\n const i = this._index[x]\n // check row\n if (i === j - kSuper + kSub) {\n // value on this column\n values.push(this._values[x])\n // store row\n index[values.length - 1] = i - kSub\n // exit loop\n break\n }\n }\n }\n // close ptr\n ptr.push(values.length)\n // return matrix\n return new SparseMatrix({\n values,\n index,\n ptr,\n size: [n, 1]\n })\n }\n\n /**\n * Generate a matrix from a JSON object\n * @memberof SparseMatrix\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SparseMatrix\", \"values\": [], \"index\": [], \"ptr\": [], \"size\": []}`,\n * where mathjs is optional\n * @returns {SparseMatrix}\n */\n SparseMatrix.fromJSON = function (json) {\n return new SparseMatrix(json)\n }\n\n /**\n * Create a diagonal matrix.\n *\n * @memberof SparseMatrix\n * @param {Array} size The matrix size.\n * @param {number | Array | Matrix } value The values for the diagonal.\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in.\n * @param {number} [defaultValue] The default value for non-diagonal\n * @param {string} [datatype] The Matrix datatype, values must be of this datatype.\n *\n * @returns {SparseMatrix}\n */\n SparseMatrix.diagonal = function (size, value, k, defaultValue, datatype) {\n if (!isArray(size)) { throw new TypeError('Array expected, size parameter') }\n if (size.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n // map size & validate\n size = size.map(function (s) {\n // check it is a big number\n if (isBigNumber(s)) {\n // convert it\n s = s.toNumber()\n }\n // validate arguments\n if (!isNumber(s) || !isInteger(s) || s < 1) {\n throw new Error('Size values must be positive integers')\n }\n return s\n })\n\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if (isBigNumber(k)) { k = k.toNumber() }\n // is must be an integer\n if (!isNumber(k) || !isInteger(k)) {\n throw new TypeError('The parameter k must be an integer number')\n }\n } else {\n // default value\n k = 0\n }\n\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n if (isString(datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar\n // convert 0 to the same datatype\n zero = typed.convert(0, datatype)\n }\n\n const kSuper = k > 0 ? k : 0\n const kSub = k < 0 ? -k : 0\n\n // rows and columns\n const rows = size[0]\n const columns = size[1]\n\n // number of non-zero items\n const n = Math.min(rows - kSub, columns - kSuper)\n\n // value extraction function\n let _value\n\n // check value\n if (isArray(value)) {\n // validate array\n if (value.length !== n) {\n // number of values in array must be n\n throw new Error('Invalid value array length')\n }\n // define function\n _value = function (i) {\n // return value @ i\n return value[i]\n }\n } else if (isMatrix(value)) {\n // matrix size\n const ms = value.size()\n // validate matrix\n if (ms.length !== 1 || ms[0] !== n) {\n // number of values in array must be n\n throw new Error('Invalid matrix length')\n }\n // define function\n _value = function (i) {\n // return value @ i\n return value.get([i])\n }\n } else {\n // define function\n _value = function () {\n // return value\n return value\n }\n }\n\n // create arrays\n const values = []\n const index = []\n const ptr = []\n\n // loop items\n for (let j = 0; j < columns; j++) {\n // number of rows with value\n ptr.push(values.length)\n // diagonal index\n const i = j - kSuper\n // check we need to set diagonal value\n if (i >= 0 && i < n) {\n // get value @ i\n const v = _value(i)\n // check for zero\n if (!eq(v, zero)) {\n // column\n index.push(i + kSub)\n // add value\n values.push(v)\n }\n }\n }\n // last value should be number of values\n ptr.push(values.length)\n // create SparseMatrix\n return new SparseMatrix({\n values,\n index,\n ptr,\n size: [rows, columns]\n })\n }\n\n /**\n * Swap rows i and j in Matrix.\n *\n * @memberof SparseMatrix\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n SparseMatrix.prototype.swapRows = function (i, j) {\n // check index\n if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) {\n throw new Error('Row index must be positive integers')\n }\n // check dimensions\n if (this._size.length !== 2) {\n throw new Error('Only two dimensional matrix is supported')\n }\n // validate index\n validateIndex(i, this._size[0])\n validateIndex(j, this._size[0])\n\n // swap rows\n SparseMatrix._swapRows(i, j, this._size[1], this._values, this._index, this._ptr)\n // return current instance\n return this\n }\n\n /**\n * Loop rows with data in column j.\n *\n * @param {number} j Column\n * @param {Array} values Matrix values\n * @param {Array} index Matrix row indeces\n * @param {Array} ptr Matrix column pointers\n * @param {Function} callback Callback function invoked for every row in column j\n */\n SparseMatrix._forEachRow = function (j, values, index, ptr, callback) {\n // indeces for column j\n const k0 = ptr[j]\n const k1 = ptr[j + 1]\n\n // loop\n for (let k = k0; k < k1; k++) {\n // invoke callback\n callback(index[k], values[k])\n }\n }\n\n /**\n * Swap rows x and y in Sparse Matrix data structures.\n *\n * @param {number} x Matrix row index 1\n * @param {number} y Matrix row index 2\n * @param {number} columns Number of columns in matrix\n * @param {Array} values Matrix values\n * @param {Array} index Matrix row indeces\n * @param {Array} ptr Matrix column pointers\n */\n SparseMatrix._swapRows = function (x, y, columns, values, index, ptr) {\n // loop columns\n for (let j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = ptr[j]\n const k1 = ptr[j + 1]\n // find value index @ x\n const kx = _getValueIndex(x, k0, k1, index)\n // find value index @ x\n const ky = _getValueIndex(y, k0, k1, index)\n // check both rows exist in matrix\n if (kx < k1 && ky < k1 && index[kx] === x && index[ky] === y) {\n // swap values (check for pattern matrix)\n if (values) {\n const v = values[kx]\n values[kx] = values[ky]\n values[ky] = v\n }\n // next column\n continue\n }\n // check x row exist & no y row\n if (kx < k1 && index[kx] === x && (ky >= k1 || index[ky] !== y)) {\n // value @ x (check for pattern matrix)\n const vx = values ? values[kx] : undefined\n // insert value @ y\n index.splice(ky, 0, y)\n if (values) { values.splice(ky, 0, vx) }\n // remove value @ x (adjust array index if needed)\n index.splice(ky <= kx ? kx + 1 : kx, 1)\n if (values) { values.splice(ky <= kx ? kx + 1 : kx, 1) }\n // next column\n continue\n }\n // check y row exist & no x row\n if (ky < k1 && index[ky] === y && (kx >= k1 || index[kx] !== x)) {\n // value @ y (check for pattern matrix)\n const vy = values ? values[ky] : undefined\n // insert value @ x\n index.splice(kx, 0, x)\n if (values) { values.splice(kx, 0, vy) }\n // remove value @ y (adjust array index if needed)\n index.splice(kx <= ky ? ky + 1 : ky, 1)\n if (values) { values.splice(kx <= ky ? ky + 1 : ky, 1) }\n }\n }\n }\n\n return SparseMatrix\n}, { isClass: true })\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'number'\nconst dependencies = ['typed']\n\n/**\n * Separates the radix, integer part, and fractional part of a non decimal number string\n * @param {string} input string to parse\n * @returns {object} the parts of the string or null if not a valid input\n */\nfunction getNonDecimalNumberParts (input) {\n const nonDecimalWithRadixMatch = input.match(/(0[box])([0-9a-fA-F]*)\\.([0-9a-fA-F]*)/)\n if (nonDecimalWithRadixMatch) {\n const radix = ({ '0b': 2, '0o': 8, '0x': 16 })[nonDecimalWithRadixMatch[1]]\n const integerPart = nonDecimalWithRadixMatch[2]\n const fractionalPart = nonDecimalWithRadixMatch[3]\n return { input, radix, integerPart, fractionalPart }\n } else {\n return null\n }\n}\n\n/**\n * Makes a number from a radix, and integer part, and a fractional part\n * @param {parts} [x] parts of the number string (from getNonDecimalNumberParts)\n * @returns {number} the number\n */\nfunction makeNumberFromNonDecimalParts (parts) {\n const n = parseInt(parts.integerPart, parts.radix)\n let f = 0\n for (let i = 0; i < parts.fractionalPart.length; i++) {\n const digitValue = parseInt(parts.fractionalPart[i], parts.radix)\n f += digitValue / Math.pow(parts.radix, i + 1)\n }\n const result = n + f\n if (isNaN(result)) {\n throw new SyntaxError('String \"' + parts.input + '\" is not a valid number')\n }\n return result\n}\n\nexport const createNumber = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Create a number or convert a string, boolean, or unit to a number.\n * When value is a matrix, all elements will be converted to number.\n *\n * Syntax:\n *\n * math.number(value)\n * math.number(unit, valuelessUnit)\n *\n * Examples:\n *\n * math.number(2) // returns number 2\n * math.number('7.2') // returns number 7.2\n * math.number(true) // returns number 1\n * math.number([true, false, true, true]) // returns [1, 0, 1, 1]\n * math.number(math.unit('52cm'), 'm') // returns 0.52\n *\n * See also:\n *\n * bignumber, bigint, boolean, numeric, complex, index, matrix, string, unit\n *\n * @param {string | number | BigNumber | Fraction | boolean | Array | Matrix | Unit | null} [value] Value to be converted\n * @param {Unit | string} [valuelessUnit] A valueless unit, used to convert a unit to a number\n * @return {number | Array | Matrix} The created number\n */\n const number = typed('number', {\n '': function () {\n return 0\n },\n\n number: function (x) {\n return x\n },\n\n string: function (x) {\n if (x === 'NaN') return NaN\n const nonDecimalNumberParts = getNonDecimalNumberParts(x)\n if (nonDecimalNumberParts) {\n return makeNumberFromNonDecimalParts(nonDecimalNumberParts)\n }\n let size = 0\n const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/)\n if (wordSizeSuffixMatch) {\n // x includes a size suffix like 0xffffi32, so we extract\n // the suffix and remove it from x\n size = Number(wordSizeSuffixMatch[2])\n x = wordSizeSuffixMatch[1]\n }\n let num = Number(x)\n if (isNaN(num)) {\n throw new SyntaxError('String \"' + x + '\" is not a valid number')\n }\n if (wordSizeSuffixMatch) {\n // x is a signed bin, oct, or hex literal\n // num is the value of string x if x is interpreted as unsigned\n if (num > 2 ** size - 1) {\n // literal is too large for size suffix\n throw new SyntaxError(`String \"${x}\" is out of range`)\n }\n // check if the bit at index size - 1 is set and if so do the twos complement\n if (num >= 2 ** (size - 1)) {\n num = num - 2 ** size\n }\n }\n return num\n },\n\n BigNumber: function (x) {\n return x.toNumber()\n },\n\n bigint: function (x) {\n return Number(x)\n },\n\n Fraction: function (x) {\n return x.valueOf()\n },\n\n Unit: typed.referToSelf(self => (x) => {\n const clone = x.clone()\n clone.value = self(x.value)\n return clone\n }),\n\n null: function (x) {\n return 0\n },\n\n 'Unit, string | Unit': function (unit, valuelessUnit) {\n return unit.toNumber(valuelessUnit)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n\n // reviver function to parse a JSON object like:\n //\n // {\"mathjs\":\"number\",\"value\":\"2.3\"}\n //\n // into a number 2.3\n number.fromJSON = function (json) {\n return parseFloat(json.value)\n }\n\n return number\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'bigint'\nconst dependencies = ['typed']\n\nexport const createBigint = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Create a bigint or convert a string, boolean, or unit to a bigint.\n * When value is a matrix, all elements will be converted to bigint.\n *\n * Syntax:\n *\n * math.bigint(value)\n *\n * Examples:\n *\n * math.bigint(2) // returns 2n\n * math.bigint('123') // returns 123n\n * math.bigint(true) // returns 1n\n * math.bigint([true, false, true, true]) // returns [1n, 0n, 1n, 1n]\n *\n * See also:\n *\n * number, bignumber, boolean, complex, index, matrix, string, unit\n *\n * @param {string | number | BigNumber | bigint | Fraction | boolean | Array | Matrix | null} [value] Value to be converted\n * @return {bigint | Array | Matrix} The created bigint\n */\n const bigint = typed('bigint', {\n '': function () {\n return 0n\n },\n\n bigint: function (x) {\n return x\n },\n\n number: function (x) {\n return BigInt(x.toFixed())\n },\n\n BigNumber: function (x) {\n return BigInt(x.round().toString())\n },\n\n Fraction: function (x) {\n return BigInt(x.valueOf().toFixed())\n },\n\n 'string | boolean': function (x) {\n return BigInt(x)\n },\n\n null: function (x) {\n return 0n\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n\n // reviver function to parse a JSON object like:\n //\n // {\"mathjs\":\"bigint\",\"value\":\"123\"}\n //\n // into a bigint 123n\n bigint.fromJSON = function (json) {\n return BigInt(json.value)\n }\n\n return bigint\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\nimport { format } from '../utils/number.js'\n\nconst name = 'string'\nconst dependencies = ['typed']\n\nexport const createString = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Create a string or convert any object into a string.\n * Elements of Arrays and Matrices are processed element wise.\n *\n * Syntax:\n *\n * math.string(value)\n *\n * Examples:\n *\n * math.string(4.2) // returns string '4.2'\n * math.string(math.complex(3, 2) // returns string '3 + 2i'\n *\n * const u = math.unit(5, 'km')\n * math.string(u.to('m')) // returns string '5000 m'\n *\n * math.string([true, false]) // returns ['true', 'false']\n *\n * See also:\n *\n * bignumber, boolean, complex, index, matrix, number, unit\n *\n * @param {* | Array | Matrix | null} [value] A value to convert to a string\n * @return {string | Array | Matrix} The created string\n */\n return typed(name, {\n '': function () {\n return ''\n },\n\n number: format,\n\n null: function (x) {\n return 'null'\n },\n\n boolean: function (x) {\n return x + ''\n },\n\n string: function (x) {\n return x\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)),\n\n any: function (x) {\n return String(x)\n }\n })\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'boolean'\nconst dependencies = ['typed']\n\nexport const createBoolean = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Create a boolean or convert a string or number to a boolean.\n * In case of a number, `true` is returned for non-zero numbers, and `false` in\n * case of zero.\n * Strings can be `'true'` or `'false'`, or can contain a number.\n * When value is a matrix, all elements will be converted to boolean.\n *\n * Syntax:\n *\n * math.boolean(x)\n *\n * Examples:\n *\n * math.boolean(0) // returns false\n * math.boolean(1) // returns true\n * math.boolean(-3) // returns true\n * math.boolean('true') // returns true\n * math.boolean('false') // returns false\n * math.boolean([1, 0, 1, 1]) // returns [true, false, true, true]\n *\n * See also:\n *\n * bignumber, complex, index, matrix, string, unit\n *\n * @param {string | number | boolean | Array | Matrix | null} value A value of any type\n * @return {boolean | Array | Matrix} The boolean value\n */\n return typed(name, {\n '': function () {\n return false\n },\n\n boolean: function (x) {\n return x\n },\n\n number: function (x) {\n return !!x\n },\n\n null: function (x) {\n return false\n },\n\n BigNumber: function (x) {\n return !x.isZero()\n },\n\n string: function (x) {\n // try case insensitive\n const lcase = x.toLowerCase()\n if (lcase === 'true') {\n return true\n } else if (lcase === 'false') {\n return false\n }\n\n // test whether value is a valid number\n const num = Number(x)\n if (x !== '' && !isNaN(num)) {\n return !!num\n }\n\n throw new Error('Cannot convert \"' + x + '\" to a boolean')\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'bignumber'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createBignumber = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Create a BigNumber, which can store numbers with arbitrary precision.\n * When a matrix is provided, all elements will be converted to BigNumber.\n *\n * Syntax:\n *\n * math.bignumber(x)\n *\n * Examples:\n *\n * 0.1 + 0.2 // returns number 0.30000000000000004\n * math.bignumber(0.1) + math.bignumber(0.2) // returns BigNumber 0.3\n *\n *\n * 7.2e500 // returns number Infinity\n * math.bignumber('7.2e500') // returns BigNumber 7.2e500\n *\n * See also:\n *\n * number, bigint, boolean, complex, index, matrix, string, unit\n *\n * @param {number | string | Fraction | BigNumber | bigint | Array | Matrix | boolean | null} [value] Value for the big number,\n * 0 by default.\n * @returns {BigNumber} The created bignumber\n */\n return typed('bignumber', {\n '': function () {\n return new BigNumber(0)\n },\n\n number: function (x) {\n // convert to string to prevent errors in case of >15 digits\n return new BigNumber(x + '')\n },\n\n string: function (x) {\n const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/)\n if (wordSizeSuffixMatch) {\n // x has a word size suffix\n const size = wordSizeSuffixMatch[2]\n const n = BigNumber(wordSizeSuffixMatch[1])\n const twoPowSize = new BigNumber(2).pow(Number(size))\n if (n.gt(twoPowSize.sub(1))) {\n throw new SyntaxError(`String \"${x}\" is out of range`)\n }\n const twoPowSizeSubOne = new BigNumber(2).pow(Number(size) - 1)\n if (n.gte(twoPowSizeSubOne)) {\n return n.sub(twoPowSize)\n } else {\n return n\n }\n }\n return new BigNumber(x)\n },\n\n BigNumber: function (x) {\n // we assume a BigNumber is immutable\n return x\n },\n\n bigint: function (x) {\n return new BigNumber(x.toString())\n },\n\n Unit: typed.referToSelf(self => (x) => {\n const clone = x.clone()\n clone.value = self(x.value)\n return clone\n }),\n\n Fraction: function (x) {\n return new BigNumber(x.n).div(x.d).times(x.s)\n },\n\n null: function (x) {\n return new BigNumber(0)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'complex'\nconst dependencies = ['typed', 'Complex']\n\nexport const createComplex = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex }) => {\n /**\n * Create a complex value or convert a value to a complex value.\n *\n * Syntax:\n *\n * math.complex() // creates a complex value with zero\n * // as real and imaginary part.\n * math.complex(re : number, im : string) // creates a complex value with provided\n * // values for real and imaginary part.\n * math.complex(re : number) // creates a complex value with provided\n * // real value and zero imaginary part.\n * math.complex(complex : Complex) // clones the provided complex value.\n * math.complex(arg : string) // parses a string into a complex value.\n * math.complex(array : Array) // converts the elements of the array\n * // or matrix element wise into a\n * // complex value.\n * math.complex({re: number, im: number}) // creates a complex value with provided\n * // values for real an imaginary part.\n * math.complex({r: number, phi: number}) // creates a complex value with provided\n * // polar coordinates\n *\n * Examples:\n *\n * const a = math.complex(3, -4) // a = Complex 3 - 4i\n * a.re = 5 // a = Complex 5 - 4i\n * const i = a.im // Number -4\n * const b = math.complex('2 + 6i') // Complex 2 + 6i\n * const c = math.complex() // Complex 0 + 0i\n * const d = math.add(a, b) // Complex 5 + 2i\n *\n * See also:\n *\n * bignumber, boolean, index, matrix, number, string, unit\n *\n * @param {* | Array | Matrix} [args]\n * Arguments specifying the real and imaginary part of the complex number\n * @return {Complex | Array | Matrix} Returns a complex value\n */\n return typed('complex', {\n '': function () {\n return Complex.ZERO\n },\n\n number: function (x) {\n return new Complex(x, 0)\n },\n\n 'number, number': function (re, im) {\n return new Complex(re, im)\n },\n\n // TODO: this signature should be redundant\n 'BigNumber, BigNumber': function (re, im) {\n return new Complex(re.toNumber(), im.toNumber())\n },\n\n Fraction: function (x) {\n return new Complex(x.valueOf(), 0)\n },\n\n Complex: function (x) {\n return x.clone()\n },\n\n string: function (x) {\n return Complex(x) // for example '2 + 3i'\n },\n\n null: function (x) {\n return Complex(0)\n },\n\n Object: function (x) {\n if ('re' in x && 'im' in x) {\n return new Complex(x.re, x.im)\n }\n\n if (('r' in x && 'phi' in x) || ('abs' in x && 'arg' in x)) {\n return new Complex(x)\n }\n\n throw new Error('Expected object with properties (re and im) or (r and phi) or (abs and arg)')\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'fraction'\nconst dependencies = ['typed', 'Fraction']\n\nexport const createFraction = /* #__PURE__ */ factory(name, dependencies, ({ typed, Fraction }) => {\n /**\n * Create a fraction or convert a value to a fraction.\n *\n * With one numeric argument, produces the closest rational approximation to the\n * input.\n * With two arguments, the first is the numerator and the second is the denominator,\n * and creates the corresponding fraction. Both numerator and denominator must be\n * integers.\n * With one object argument, looks for the integer numerator as the value of property\n * 'n' and the integer denominator as the value of property 'd'.\n * With a matrix argument, creates a matrix of the same shape with entries\n * converted into fractions.\n *\n * Syntax:\n * math.fraction(value)\n * math.fraction(numerator, denominator)\n * math.fraction({n: numerator, d: denominator})\n * math.fraction(matrix: Array | Matrix)\n *\n * Examples:\n *\n * math.fraction(6.283) // returns Fraction 6283/1000\n * math.fraction(1, 3) // returns Fraction 1/3\n * math.fraction('2/3') // returns Fraction 2/3\n * math.fraction({n: 2, d: 3}) // returns Fraction 2/3\n * math.fraction([0.2, 0.25, 1.25]) // returns Array [1/5, 1/4, 5/4]\n * math.fraction(4, 5.1) // throws Error: Parameters must be integer\n *\n * See also:\n *\n * bignumber, number, string, unit\n *\n * @param {number | string | Fraction | BigNumber | bigint | Unit | Array | Matrix} [args]\n * Arguments specifying the value, or numerator and denominator of\n * the fraction\n * @return {Fraction | Array | Matrix} Returns a fraction\n */\n return typed('fraction', {\n number: function (x) {\n if (!isFinite(x) || isNaN(x)) {\n throw new Error(x + ' cannot be represented as a fraction')\n }\n\n return new Fraction(x)\n },\n\n string: function (x) {\n return new Fraction(x)\n },\n\n 'number, number': function (numerator, denominator) {\n return new Fraction(numerator, denominator)\n },\n\n null: function (x) {\n return new Fraction(0)\n },\n\n BigNumber: function (x) {\n return new Fraction(x.toString())\n },\n\n bigint: function (x) {\n return new Fraction(x.toString())\n },\n\n Fraction: function (x) {\n return x // fractions are immutable\n },\n\n Unit: typed.referToSelf(self => (x) => {\n const clone = x.clone()\n clone.value = self(x.value)\n return clone\n }),\n\n Object: function (x) {\n return new Fraction(x)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matrix'\nconst dependencies = ['typed', 'Matrix', 'DenseMatrix', 'SparseMatrix']\n\nexport const createMatrix = /* #__PURE__ */ factory(name, dependencies, ({ typed, Matrix, DenseMatrix, SparseMatrix }) => {\n /**\n * Create a Matrix. The function creates a new `math.Matrix` object from\n * an `Array`. A Matrix has utility functions to manipulate the data in the\n * matrix, like getting the size and getting or setting values in the matrix.\n * Supported storage formats are 'dense' and 'sparse'.\n *\n * Syntax:\n *\n * math.matrix() // creates an empty matrix using default storage format (dense).\n * math.matrix(data) // creates a matrix with initial data using default storage format (dense).\n * math.matrix('dense') // creates an empty matrix using the given storage format.\n * math.matrix(data, 'dense') // creates a matrix with initial data using the given storage format.\n * math.matrix(data, 'sparse') // creates a sparse matrix with initial data.\n * math.matrix(data, 'sparse', 'number') // creates a sparse matrix with initial data, number data type.\n *\n * Examples:\n *\n * let m = math.matrix([[1, 2], [3, 4]])\n * m.size() // Array [2, 2]\n * m.resize([3, 2], 5)\n * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]]\n * m.get([1, 0]) // number 3\n *\n * See also:\n *\n * bignumber, boolean, complex, index, number, string, unit, sparse\n *\n * @param {Array | Matrix} [data] A multi dimensional array\n * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'`\n * @param {string} [datatype] Type of the values\n *\n * @return {Matrix} The created matrix\n */\n return typed(name, {\n '': function () {\n return _create([])\n },\n\n string: function (format) {\n return _create([], format)\n },\n\n 'string, string': function (format, datatype) {\n return _create([], format, datatype)\n },\n\n Array: function (data) {\n return _create(data)\n },\n\n Matrix: function (data) {\n return _create(data, data.storage())\n },\n\n 'Array | Matrix, string': _create,\n\n 'Array | Matrix, string, string': _create\n })\n\n /**\n * Create a new Matrix with given storage format\n * @param {Array} data\n * @param {string} [format]\n * @param {string} [datatype]\n * @returns {Matrix} Returns a new Matrix\n * @private\n */\n function _create (data, format, datatype) {\n // get storage format constructor\n if (format === 'dense' || format === 'default' || format === undefined) {\n return new DenseMatrix(data, datatype)\n }\n\n if (format === 'sparse') {\n return new SparseMatrix(data, datatype)\n }\n\n throw new TypeError('Unknown matrix type ' + JSON.stringify(format) + '.')\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromFunction'\nconst dependencies = ['typed', 'matrix', 'isZero']\n\nexport const createMatrixFromFunction = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isZero }) => {\n /**\n * Create a matrix by evaluating a generating function at each index.\n * The simplest overload returns a multi-dimensional array as long as `size` is an array.\n * Passing `size` as a Matrix or specifying a `format` will result in returning a Matrix.\n *\n * Syntax:\n *\n * math.matrixFromFunction(size, fn)\n * math.matrixFromFunction(size, fn, format)\n * math.matrixFromFunction(size, fn, format, datatype)\n * math.matrixFromFunction(size, format, fn)\n * math.matrixFromFunction(size, format, datatype, fn)\n *\n * Examples:\n *\n * math.matrixFromFunction([3,3], i => i[0] - i[1]) // an antisymmetric matrix\n * math.matrixFromFunction([100, 100], 'sparse', i => i[0] - i[1] === 1 ? 4 : 0) // a sparse subdiagonal matrix\n * math.matrixFromFunction([5], i => math.random()) // a random vector\n *\n * See also:\n *\n * matrix, zeros\n *\n * @param {Array | Matrix} size The size of the matrix to be created\n * @param {function} fn Callback function invoked for every entry in the matrix\n * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'`\n * @param {string} [datatype] Type of the values\n * @return {Array | Matrix} Returns the created matrix\n */\n return typed(name, {\n 'Array | Matrix, function, string, string': function (size, fn, format, datatype) {\n return _create(size, fn, format, datatype)\n },\n 'Array | Matrix, function, string': function (size, fn, format) {\n return _create(size, fn, format)\n },\n 'Matrix, function': function (size, fn) {\n return _create(size, fn, 'dense')\n },\n 'Array, function': function (size, fn) {\n return _create(size, fn, 'dense').toArray()\n },\n 'Array | Matrix, string, function': function (size, format, fn) {\n return _create(size, fn, format)\n },\n 'Array | Matrix, string, string, function': function (size, format, datatype, fn) {\n return _create(size, fn, format, datatype)\n }\n })\n\n function _create (size, fn, format, datatype) {\n let m\n if (datatype !== undefined) {\n m = matrix(format, datatype)\n } else {\n m = matrix(format)\n }\n\n m.resize(size)\n m.forEach(function (_, index) {\n const val = fn(index)\n if (isZero(val)) return\n m.set(index, val)\n })\n\n return m\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromRows'\nconst dependencies = ['typed', 'matrix', 'flatten', 'size']\n\nexport const createMatrixFromRows = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, flatten, size }) => {\n /**\n * Create a dense matrix from vectors as individual rows.\n * If you pass column vectors, they will be transposed (but not conjugated!)\n *\n * Syntax:\n *\n * math.matrixFromRows(...arr)\n * math.matrixFromRows(row1, row2)\n * math.matrixFromRows(row1, row2, row3)\n *\n * Examples:\n *\n * math.matrixFromRows([1, 2, 3], [[4],[5],[6]])\n * math.matrixFromRows(...vectors)\n *\n * See also:\n *\n * matrix, matrixFromColumns, matrixFromFunction, zeros\n *\n * @param {... Array | Matrix} rows Multiple rows\n * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned\n */\n return typed(name, {\n '...Array': function (arr) {\n return _createArray(arr)\n },\n '...Matrix': function (arr) {\n return matrix(_createArray(arr.map(m => m.toArray())))\n }\n\n // TODO implement this properly for SparseMatrix\n })\n\n function _createArray (arr) {\n if (arr.length === 0) throw new TypeError('At least one row is needed to construct a matrix.')\n const N = checkVectorTypeAndReturnLength(arr[0])\n\n const result = []\n for (const row of arr) {\n const rowLength = checkVectorTypeAndReturnLength(row)\n\n if (rowLength !== N) {\n throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (rowLength | 0))\n }\n\n result.push(flatten(row))\n }\n\n return result\n }\n\n function checkVectorTypeAndReturnLength (vec) {\n const s = size(vec)\n\n if (s.length === 1) { // 1D vector\n return s[0]\n } else if (s.length === 2) { // 2D vector\n if (s[0] === 1) { // row vector\n return s[1]\n } else if (s[1] === 1) { // col vector\n return s[0]\n } else {\n throw new TypeError('At least one of the arguments is not a vector.')\n }\n } else {\n throw new TypeError('Only one- or two-dimensional vectors are supported.')\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromColumns'\nconst dependencies = ['typed', 'matrix', 'flatten', 'size']\n\nexport const createMatrixFromColumns = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, flatten, size }) => {\n /**\n * Create a dense matrix from vectors as individual columns.\n * If you pass row vectors, they will be transposed (but not conjugated!)\n *\n * Syntax:\n *\n * math.matrixFromColumns(...arr)\n * math.matrixFromColumns(col1, col2)\n * math.matrixFromColumns(col1, col2, col3)\n *\n * Examples:\n *\n * math.matrixFromColumns([1, 2, 3], [[4],[5],[6]])\n * math.matrixFromColumns(...vectors)\n *\n * See also:\n *\n * matrix, matrixFromRows, matrixFromFunction, zeros\n *\n * @param {... Array | Matrix} cols Multiple columns\n * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned\n */\n return typed(name, {\n '...Array': function (arr) {\n return _createArray(arr)\n },\n '...Matrix': function (arr) {\n return matrix(_createArray(arr.map(m => m.toArray())))\n }\n\n // TODO implement this properly for SparseMatrix\n })\n\n function _createArray (arr) {\n if (arr.length === 0) throw new TypeError('At least one column is needed to construct a matrix.')\n const N = checkVectorTypeAndReturnLength(arr[0])\n\n // create an array with empty rows\n const result = []\n for (let i = 0; i < N; i++) {\n result[i] = []\n }\n\n // loop columns\n for (const col of arr) {\n const colLength = checkVectorTypeAndReturnLength(col)\n\n if (colLength !== N) {\n throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (colLength | 0))\n }\n\n const f = flatten(col)\n\n // push a value to each row\n for (let i = 0; i < N; i++) {\n result[i].push(f[i])\n }\n }\n\n return result\n }\n\n function checkVectorTypeAndReturnLength (vec) {\n const s = size(vec)\n\n if (s.length === 1) { // 1D vector\n return s[0]\n } else if (s.length === 2) { // 2D vector\n if (s[0] === 1) { // row vector\n return s[1]\n } else if (s[1] === 1) { // col vector\n return s[0]\n } else {\n throw new TypeError('At least one of the arguments is not a vector.')\n }\n } else {\n throw new TypeError('Only one- or two-dimensional vectors are supported.')\n }\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'splitUnit'\nconst dependencies = ['typed']\n\nexport const createSplitUnit = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Split a unit in an array of units whose sum is equal to the original unit.\n *\n * Syntax:\n *\n * math.splitUnit(unit: Unit, parts: Array.)\n *\n * Example:\n *\n * math.splitUnit(new Unit(1, 'm'), ['feet', 'inch'])\n * // [ 3 feet, 3.3700787401575 inch ]\n *\n * See also:\n *\n * unit\n *\n * @param {Array} [parts] An array of strings or valueless units.\n * @return {Array} An array of units.\n */\n return typed(name, {\n 'Unit, Array': function (unit, parts) {\n return unit.splitUnit(parts)\n }\n })\n})\n","import { cbrt, expm1, isInteger, log10, log1p, log2, sign, toFixed } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function absNumber (a) {\n return Math.abs(a)\n}\nabsNumber.signature = n1\n\nexport function addNumber (a, b) {\n return a + b\n}\naddNumber.signature = n2\n\nexport function subtractNumber (a, b) {\n return a - b\n}\nsubtractNumber.signature = n2\n\nexport function multiplyNumber (a, b) {\n return a * b\n}\nmultiplyNumber.signature = n2\n\nexport function divideNumber (a, b) {\n return a / b\n}\ndivideNumber.signature = n2\n\nexport function unaryMinusNumber (x) {\n return -x\n}\nunaryMinusNumber.signature = n1\n\nexport function unaryPlusNumber (x) {\n return x\n}\nunaryPlusNumber.signature = n1\n\nexport function cbrtNumber (x) {\n return cbrt(x)\n}\ncbrtNumber.signature = n1\n\nexport function cubeNumber (x) {\n return x * x * x\n}\ncubeNumber.signature = n1\n\nexport function expNumber (x) {\n return Math.exp(x)\n}\nexpNumber.signature = n1\n\nexport function expm1Number (x) {\n return expm1(x)\n}\nexpm1Number.signature = n1\n\n/**\n * Calculate gcd for numbers\n * @param {number} a\n * @param {number} b\n * @returns {number} Returns the greatest common denominator of a and b\n */\nexport function gcdNumber (a, b) {\n if (!isInteger(a) || !isInteger(b)) {\n throw new Error('Parameters in function gcd must be integer numbers')\n }\n\n // https://en.wikipedia.org/wiki/Euclidean_algorithm\n let r\n while (b !== 0) {\n r = a % b\n a = b\n b = r\n }\n return (a < 0) ? -a : a\n}\ngcdNumber.signature = n2\n\n/**\n * Calculate lcm for two numbers\n * @param {number} a\n * @param {number} b\n * @returns {number} Returns the least common multiple of a and b\n */\nexport function lcmNumber (a, b) {\n if (!isInteger(a) || !isInteger(b)) {\n throw new Error('Parameters in function lcm must be integer numbers')\n }\n\n if (a === 0 || b === 0) {\n return 0\n }\n\n // https://en.wikipedia.org/wiki/Euclidean_algorithm\n // evaluate lcm here inline to reduce overhead\n let t\n const prod = a * b\n while (b !== 0) {\n t = b\n b = a % t\n a = t\n }\n return Math.abs(prod / a)\n}\nlcmNumber.signature = n2\n\n/**\n * Calculate the logarithm of a value, optionally to a given base.\n * @param {number} x\n * @param {number | null | undefined} base\n * @return {number}\n */\nexport function logNumber (x, y) {\n if (y) { return Math.log(x) / Math.log(y) }\n return Math.log(x)\n}\n\n/**\n * Calculate the 10-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\nexport function log10Number (x) {\n return log10(x)\n}\nlog10Number.signature = n1\n\n/**\n * Calculate the 2-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\nexport function log2Number (x) {\n return log2(x)\n}\nlog2Number.signature = n1\n\n/**\n * Calculate the natural logarithm of a `number+1`\n * @param {number} x\n * @returns {number}\n */\nexport function log1pNumber (x) {\n return log1p(x)\n}\nlog1pNumber.signature = n1\n\n/**\n * Calculate the modulus of two numbers\n * @param {number} x\n * @param {number} y\n * @returns {number} res\n * @private\n */\nexport function modNumber (x, y) {\n // We don't use JavaScript's % operator here as this doesn't work\n // correctly for x < 0 and x === 0\n // see https://en.wikipedia.org/wiki/Modulo_operation\n return (y === 0) ? x : x - y * Math.floor(x / y)\n}\nmodNumber.signature = n2\n\n/**\n * Calculate the nth root of a, solve x^root == a\n * http://rosettacode.org/wiki/Nth_root#JavaScript\n * @param {number} a\n * @param {number} [2] root\n * @private\n */\nexport function nthRootNumber (a, root = 2) {\n const inv = root < 0\n if (inv) {\n root = -root\n }\n\n if (root === 0) {\n throw new Error('Root must be non-zero')\n }\n if (a < 0 && (Math.abs(root) % 2 !== 1)) {\n throw new Error('Root must be odd when a is negative.')\n }\n\n // edge cases zero and infinity\n if (a === 0) {\n return inv ? Infinity : 0\n }\n if (!isFinite(a)) {\n return inv ? 0 : a\n }\n\n let x = Math.pow(Math.abs(a), 1 / root)\n // If a < 0, we require that root is an odd integer,\n // so (-1) ^ (1/root) = -1\n x = a < 0 ? -x : x\n return inv ? 1 / x : x\n\n // Very nice algorithm, but fails with nthRoot(-2, 3).\n // Newton's method has some well-known problems at times:\n // https://en.wikipedia.org/wiki/Newton%27s_method#Failure_analysis\n /*\n let x = 1 // Initial guess\n let xPrev = 1\n let i = 0\n const iMax = 10000\n do {\n const delta = (a / Math.pow(x, root - 1) - x) / root\n xPrev = x\n x = x + delta\n i++\n }\n while (xPrev !== x && i < iMax)\n\n if (xPrev !== x) {\n throw new Error('Function nthRoot failed to converge')\n }\n\n return inv ? 1 / x : x\n */\n}\n\nexport function signNumber (x) {\n return sign(x)\n}\nsignNumber.signature = n1\n\nexport function sqrtNumber (x) {\n return Math.sqrt(x)\n}\nsqrtNumber.signature = n1\n\nexport function squareNumber (x) {\n return x * x\n}\nsquareNumber.signature = n1\n\n/**\n * Calculate xgcd for two numbers\n * @param {number} a\n * @param {number} b\n * @return {number} result\n * @private\n */\nexport function xgcdNumber (a, b) {\n // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n let t // used to swap two variables\n let q // quotient\n let r // remainder\n let x = 0\n let lastx = 1\n let y = 1\n let lasty = 0\n\n if (!isInteger(a) || !isInteger(b)) {\n throw new Error('Parameters in function xgcd must be integer numbers')\n }\n\n while (b) {\n q = Math.floor(a / b)\n r = a - q * b\n\n t = x\n x = lastx - q * x\n lastx = t\n\n t = y\n y = lasty - q * y\n lasty = t\n\n a = b\n b = r\n }\n\n let res\n if (a < 0) {\n res = [-a, -lastx, -lasty]\n } else {\n res = [a, a ? lastx : 0, lasty]\n }\n return res\n}\nxgcdNumber.signature = n2\n\n/**\n * Calculates the power of x to y, x^y, for two numbers.\n * @param {number} x\n * @param {number} y\n * @return {number} res\n */\nexport function powNumber (x, y) {\n // x^Infinity === 0 if -1 < x < 1\n // A real number 0 is returned instead of complex(0)\n if ((x * x < 1 && y === Infinity) ||\n (x * x > 1 && y === -Infinity)) {\n return 0\n }\n\n return Math.pow(x, y)\n}\npowNumber.signature = n2\n\n/**\n * round a number to the given number of decimals, or to zero if decimals is\n * not provided\n * @param {number} value\n * @param {number} decimals number of decimals, between 0 and 15 (0 by default)\n * @return {number} roundedValue\n */\nexport function roundNumber (value, decimals = 0) {\n if (!isInteger(decimals) || decimals < 0 || decimals > 15) {\n throw new Error('Number of decimals in function round must be an integer from 0 to 15 inclusive')\n }\n return parseFloat(toFixed(value, decimals))\n}\n\n/**\n * Calculate the norm of a number, the absolute value.\n * @param {number} x\n * @return {number}\n */\nexport function normNumber (x) {\n return Math.abs(x)\n}\nnormNumber.signature = n1\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { unaryMinusNumber } from '../../plain/number/index.js'\n\nconst name = 'unaryMinus'\nconst dependencies = ['typed']\n\nexport const createUnaryMinus = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Inverse the sign of a value, apply a unary minus operation.\n *\n * For matrices, the function is evaluated element wise. Boolean values and\n * strings will be converted to a number. For complex numbers, both real and\n * complex value are inverted.\n *\n * Syntax:\n *\n * math.unaryMinus(x)\n *\n * Examples:\n *\n * math.unaryMinus(3.5) // returns -3.5\n * math.unaryMinus(-4.2) // returns 4.2\n *\n * See also:\n *\n * add, subtract, unaryPlus\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Number to be inverted.\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Returns the value with inverted sign.\n */\n return typed(name, {\n number: unaryMinusNumber,\n\n 'Complex | BigNumber | Fraction': x => x.neg(),\n\n bigint: x => -x,\n\n Unit: typed.referToSelf(self => x => {\n const res = x.clone()\n res.value = typed.find(self, res.valueType())(x.value)\n return res\n }),\n\n // deep map collection, skip zeros since unaryMinus(0) = 0\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true))\n\n // TODO: add support for string\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { unaryPlusNumber } from '../../plain/number/index.js'\nimport { safeNumberType } from '../../utils/number.js'\n\nconst name = 'unaryPlus'\nconst dependencies = ['typed', 'config', 'numeric']\n\nexport const createUnaryPlus = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric }) => {\n /**\n * Unary plus operation.\n * Boolean values and strings will be converted to a number, numeric values will be returned as is.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.unaryPlus(x)\n *\n * Examples:\n *\n * math.unaryPlus(3.5) // returns 3.5\n * math.unaryPlus(1) // returns 1\n *\n * See also:\n *\n * unaryMinus, add, subtract\n *\n * @param {number | BigNumber | bigint | Fraction | string | Complex | Unit | Array | Matrix} x\n * Input value\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix}\n * Returns the input value when numeric, converts to a number when input is non-numeric.\n */\n return typed(name, {\n number: unaryPlusNumber,\n\n Complex: function (x) {\n return x // complex numbers are immutable\n },\n\n BigNumber: function (x) {\n return x // bignumbers are immutable\n },\n\n bigint: function (x) {\n return x\n },\n\n Fraction: function (x) {\n return x // fractions are immutable\n },\n\n Unit: function (x) {\n return x.clone()\n },\n\n // deep map collection, skip zeros since unaryPlus(0) = 0\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)),\n\n boolean: function (x) {\n return numeric(x ? 1 : 0, config.number)\n },\n\n string: function (x) {\n return numeric(x, safeNumberType(x, config))\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { absNumber } from '../../plain/number/index.js'\n\nconst name = 'abs'\nconst dependencies = ['typed']\n\nexport const createAbs = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the absolute value of a number. For matrices, the function is\n * evaluated element wise.\n *\n * Syntax:\n *\n * math.abs(x)\n *\n * Examples:\n *\n * math.abs(3.5) // returns number 3.5\n * math.abs(-4.2) // returns number 4.2\n *\n * math.abs([3, -5, -1, 0, 2]) // returns Array [3, 5, 1, 0, 2]\n *\n * See also:\n *\n * sign\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x\n * A number or matrix for which to get the absolute value\n * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit}\n * Absolute value of `x`\n */\n return typed(name, {\n number: absNumber,\n\n 'Complex | BigNumber | Fraction | Unit': x => x.abs(),\n\n bigint: x => x < 0n ? -x : x,\n\n // deep map collection, skip zeros since abs(0) = 0\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { arraySize } from '../../utils/array.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { IndexError } from '../../error/IndexError.js'\n\nconst name = 'apply'\nconst dependencies = ['typed', 'isInteger']\n\nexport const createApply = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\n /**\n * Apply a function that maps an array to a scalar\n * along a given axis of a matrix or array.\n * Returns a new matrix or array with one less dimension than the input.\n *\n * Syntax:\n *\n * math.apply(A, dim, callback)\n *\n * Where:\n *\n * - `dim: number` is a zero-based dimension over which to concatenate the matrices.\n *\n * Examples:\n *\n * const A = [[1, 2], [3, 4]]\n * const sum = math.sum\n *\n * math.apply(A, 0, sum) // returns [4, 6]\n * math.apply(A, 1, sum) // returns [3, 7]\n *\n * See also:\n *\n * map, filter, forEach\n *\n * @param {Array | Matrix} array The input Matrix\n * @param {number} dim The dimension along which the callback is applied\n * @param {Function} callback The callback function that is applied. This Function\n * should take an array or 1-d matrix as an input and\n * return a number.\n * @return {Array | Matrix} res The residual matrix with the function applied over some dimension.\n */\n return typed(name, {\n 'Array | Matrix, number | BigNumber, function': function (mat, dim, callback) {\n if (!isInteger(dim)) {\n throw new TypeError('Integer number expected for dimension')\n }\n\n const size = Array.isArray(mat) ? arraySize(mat) : mat.size()\n if (dim < 0 || (dim >= size.length)) {\n throw new IndexError(dim, size.length)\n }\n\n if (isMatrix(mat)) {\n return mat.create(_apply(mat.valueOf(), dim, callback), mat.datatype())\n } else {\n return _apply(mat, dim, callback)\n }\n }\n })\n})\n\n/**\n * Recursively reduce a matrix\n * @param {Array} mat\n * @param {number} dim\n * @param {Function} callback\n * @returns {Array} ret\n * @private\n */\nfunction _apply (mat, dim, callback) {\n let i, ret, tran\n\n if (dim <= 0) {\n if (!Array.isArray(mat[0])) {\n return callback(mat)\n } else {\n tran = _switch(mat)\n ret = []\n for (i = 0; i < tran.length; i++) {\n ret[i] = _apply(tran[i], dim - 1, callback)\n }\n return ret\n }\n } else {\n ret = []\n for (i = 0; i < mat.length; i++) {\n ret[i] = _apply(mat[i], dim - 1, callback)\n }\n return ret\n }\n}\n\n/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\nfunction _switch (mat) {\n const I = mat.length\n const J = mat[0].length\n let i, j\n const ret = []\n for (j = 0; j < J; j++) {\n const tmp = []\n for (i = 0; i < I; i++) {\n tmp.push(mat[i][j])\n }\n ret.push(tmp)\n }\n return ret\n}\n","import { factory } from '../../utils/factory.js'\nimport { addNumber } from '../../plain/number/index.js'\n\nconst name = 'addScalar'\nconst dependencies = ['typed']\n\nexport const createAddScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Add two scalar values, `x + y`.\n * This function is meant for internal use: it is used by the public function\n * `add`\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to add\n * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to add\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Sum of `x` and `y`\n * @private\n */\n return typed(name, {\n\n 'number, number': addNumber,\n\n 'Complex, Complex': function (x, y) {\n return x.add(y)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.plus(y)\n },\n\n 'bigint, bigint': function (x, y) {\n return x + y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return x.add(y)\n },\n\n 'Unit, Unit': typed.referToSelf(self => (x, y) => {\n if (x.value === null || x.value === undefined) {\n throw new Error('Parameter x contains a unit with undefined value')\n }\n if (y.value === null || y.value === undefined) {\n throw new Error('Parameter y contains a unit with undefined value')\n }\n if (!x.equalBase(y)) throw new Error('Units do not match')\n\n const res = x.clone()\n res.value =\n typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value)\n res.fixPrefix = false\n return res\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { subtractNumber } from '../../plain/number/index.js'\n\nconst name = 'subtractScalar'\nconst dependencies = ['typed']\n\nexport const createSubtractScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Subtract two scalar values, `x - y`.\n * This function is meant for internal use: it is used by the public function\n * `subtract`\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value\n * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to be subtracted from `x`\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Difference of `x` and `y`\n * @private\n */\n return typed(name, {\n\n 'number, number': subtractNumber,\n\n 'Complex, Complex': function (x, y) {\n return x.sub(y)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.minus(y)\n },\n\n 'bigint, bigint': function (x, y) {\n return x - y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return x.sub(y)\n },\n\n 'Unit, Unit': typed.referToSelf(self => (x, y) => {\n if (x.value === null || x.value === undefined) {\n throw new Error('Parameter x contains a unit with undefined value')\n }\n if (y.value === null || y.value === undefined) {\n throw new Error('Parameter y contains a unit with undefined value')\n }\n if (!x.equalBase(y)) throw new Error('Units do not match')\n\n const res = x.clone()\n res.value =\n typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value)\n res.fixPrefix = false\n return res\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isBigNumber, isComplex, isFraction } from '../../utils/is.js'\nimport { cbrtNumber } from '../../plain/number/index.js'\n\nconst name = 'cbrt'\nconst dependencies = [\n 'config',\n 'typed',\n 'isNegative',\n 'unaryMinus',\n 'matrix',\n 'Complex',\n 'BigNumber',\n 'Fraction'\n]\n\nexport const createCbrt = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, isNegative, unaryMinus, matrix, Complex, BigNumber, Fraction }) => {\n /**\n * Calculate the cubic root of a value.\n *\n * To avoid confusion with the matrix cube root, this function does not\n * apply to matrices. For a matrix, to take the cube root elementwise,\n * see the examples.\n *\n * Syntax:\n *\n * math.cbrt(x)\n * math.cbrt(x, allRoots)\n *\n * Examples:\n *\n * math.cbrt(27) // returns 3\n * math.cube(3) // returns 27\n * math.cbrt(-64) // returns -4\n * math.cbrt(math.unit('27 m^3')) // returns Unit 3 m\n * math.map([27, 64, 125], x => math.cbrt(x)) // returns [3, 4, 5]\n *\n * const x = math.complex('8i')\n * math.cbrt(x) // returns Complex 1.7320508075689 + i\n * math.cbrt(x, true) // returns Matrix [\n * // 1.7320508075689 + i\n * // -1.7320508075689 + i\n * // -2i\n * // ]\n *\n * See also:\n *\n * square, sqrt, cube\n *\n * @param {number | BigNumber | Complex | Unit} x\n * Value for which to calculate the cubic root.\n * @param {boolean} [allRoots] Optional, false by default. Only applicable\n * when `x` is a number or complex number. If true, all complex\n * roots are returned, if false (default) the principal root is\n * returned.\n * @return {number | BigNumber | Complex | Unit}\n * Returns the cubic root of `x`\n */\n return typed(name, {\n number: cbrtNumber,\n // note: signature 'number, boolean' is also supported,\n // created by typed as it knows how to convert number to Complex\n\n Complex: _cbrtComplex,\n\n 'Complex, boolean': _cbrtComplex,\n\n BigNumber: function (x) {\n return x.cbrt()\n },\n\n Unit: _cbrtUnit\n })\n\n /**\n * Calculate the cubic root for a complex number\n * @param {Complex} x\n * @param {boolean} [allRoots] If true, the function will return an array\n * with all three roots. If false or undefined,\n * the principal root is returned.\n * @returns {Complex | Array. | Matrix.} Returns the cubic root(s) of x\n * @private\n */\n function _cbrtComplex (x, allRoots) {\n // https://www.wikiwand.com/en/Cube_root#/Complex_numbers\n\n const arg3 = x.arg() / 3\n const abs = x.abs()\n\n // principal root:\n const principal = new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3).exp())\n\n if (allRoots) {\n const all = [\n principal,\n new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 + Math.PI * 2 / 3).exp()),\n new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 - Math.PI * 2 / 3).exp())\n ]\n\n return (config.matrix === 'Array') ? all : matrix(all)\n } else {\n return principal\n }\n }\n\n /**\n * Calculate the cubic root for a Unit\n * @param {Unit} x\n * @return {Unit} Returns the cubic root of x\n * @private\n */\n function _cbrtUnit (x) {\n if (x.value && isComplex(x.value)) {\n let result = x.clone()\n result.value = 1.0\n result = result.pow(1.0 / 3) // Compute the units\n result.value = _cbrtComplex(x.value) // Compute the value\n return result\n } else {\n const negate = isNegative(x.value)\n if (negate) {\n x.value = unaryMinus(x.value)\n }\n\n // TODO: create a helper function for this\n let third\n if (isBigNumber(x.value)) {\n third = new BigNumber(1).div(3)\n } else if (isFraction(x.value)) {\n third = new Fraction(1, 3)\n } else {\n third = 1 / 3\n }\n\n const result = x.pow(third)\n\n if (negate) {\n result.value = unaryMinus(result.value)\n }\n\n return result\n }\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo11xS0s'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo11xS0s = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked NZ times (number of nonzero items in S).\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function matAlgo11xS0s (s, b, callback, inverse) {\n // sparse matrix arrays\n const avalues = s._values\n const aindex = s._index\n const aptr = s._ptr\n const asize = s._size\n const adt = s._datatype\n\n // sparse matrix cannot be a Pattern matrix\n if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // convert b to the same datatype\n b = typed.convert(b, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = []\n const cindex = []\n const cptr = []\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n // initialize ptr\n cptr[j] = cindex.length\n // values in j\n for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n const i = aindex[k]\n // invoke callback\n const v = inverse ? cf(b, avalues[k]) : cf(avalues[k], b)\n // check value is zero\n if (!eq(v, zero)) {\n // push index & value\n cindex.push(i)\n cvalues.push(v)\n }\n }\n }\n // update ptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return s.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo12xSfs'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo12xSfs = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked MxN times.\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ f(0, b) ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function matAlgo12xSfs (s, b, callback, inverse) {\n // sparse matrix arrays\n const avalues = s._values\n const aindex = s._index\n const aptr = s._ptr\n const asize = s._size\n const adt = s._datatype\n\n // sparse matrix cannot be a Pattern matrix\n if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string') {\n // datatype\n dt = adt\n // convert b to the same datatype\n b = typed.convert(b, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cdata = []\n\n // workspaces\n const x = []\n // marks indicating we have a value in x for a given column\n const w = []\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n // columns mark\n const mark = j + 1\n // values in j\n for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n const r = aindex[k]\n // update workspace\n x[r] = avalues[k]\n w[r] = mark\n }\n // loop rows\n for (let i = 0; i < rows; i++) {\n // initialize C on first column\n if (j === 0) {\n // create row array\n cdata[i] = []\n }\n // check sparse matrix has a value @ i,j\n if (w[i] === mark) {\n // invoke callback, update C\n cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b)\n } else {\n // dense matrix value @ i, j\n cdata[i][j] = inverse ? cf(b, 0) : cf(0, b)\n }\n }\n }\n\n // return dense matrix\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { clone } from '../../../utils/object.js'\n\nconst name = 'matAlgo14xDs'\nconst dependencies = ['typed']\n\nexport const createMatAlgo14xDs = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, b).\n * Callback function invoked MxN times.\n *\n * C(i,j,...z) = f(Aij..z, b)\n *\n * @param {Matrix} a The DenseMatrix instance (A)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij..z,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Aij..z)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97659042\n */\n return function matAlgo14xDs (a, b, callback, inverse) {\n // a arrays\n const adata = a._data\n const asize = a._size\n const adt = a._datatype\n\n // datatype\n let dt\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string') {\n // datatype\n dt = adt\n // convert b to the same datatype\n b = typed.convert(b, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // populate cdata, iterate through dimensions\n const cdata = asize.length > 0 ? _iterate(cf, 0, asize, asize[0], adata, b, inverse) : []\n\n // c matrix\n return a.createDenseMatrix({\n data: cdata,\n size: clone(asize),\n datatype: dt\n })\n }\n\n // recursive function\n function _iterate (f, level, s, n, av, bv, inverse) {\n // initialize array for this level\n const cv = []\n // check we reach the last level\n if (level === s.length - 1) {\n // loop arrays in last level\n for (let i = 0; i < n; i++) {\n // invoke callback and store value\n cv[i] = inverse ? f(bv, av[i]) : f(av[i], bv)\n }\n } else {\n // iterate current level\n for (let j = 0; j < n; j++) {\n // iterate next level\n cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv, inverse)\n }\n }\n return cv\n }\n})\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'ceil'\nconst dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createCeilNumber = /* #__PURE__ */ factory(\n name, ['typed', 'config', 'round'], ({ typed, config, round }) => {\n return typed(name, {\n number: function (x) {\n if (nearlyEqual(x, round(x), config.relTol, config.absTol)) {\n return round(x)\n } else {\n return Math.ceil(x)\n }\n },\n\n 'number, number': function (x, n) {\n if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n return round(x, n)\n } else {\n let [number, exponent] = `${x}e`.split('e')\n const result = Math.ceil(Number(`${number}e${Number(exponent) + n}`));\n [number, exponent] = `${result}e`.split('e')\n return Number(`${number}e${Number(exponent) - n}`)\n }\n }\n })\n }\n)\n\nexport const createCeil = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix }) => {\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n const ceilNumber = createCeilNumber({ typed, config, round })\n /**\n * Round a value towards plus infinity\n * If `x` is complex, both real and imaginary part are rounded towards plus infinity.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.ceil(x)\n * math.ceil(x, n)\n *\n * Examples:\n *\n * math.ceil(3.2) // returns number 4\n * math.ceil(3.8) // returns number 4\n * math.ceil(-4.2) // returns number -4\n * math.ceil(-4.7) // returns number -4\n *\n * math.ceil(3.212, 2) // returns number 3.22\n * math.ceil(3.288, 2) // returns number 3.29\n * math.ceil(-4.212, 2) // returns number -4.21\n * math.ceil(-4.782, 2) // returns number -4.78\n *\n * const c = math.complex(3.24, -2.71)\n * math.ceil(c) // returns Complex 4 - 2i\n * math.ceil(c, 1) // returns Complex 3.3 - 2.7i\n *\n * math.ceil([3.2, 3.8, -4.7]) // returns Array [4, 4, -4]\n * math.ceil([3.21, 3.82, -4.71], 1) // returns Array [3.3, 3.9, -4.7]\n *\n * See also:\n *\n * floor, fix, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n return typed('ceil', {\n number: ceilNumber.signatures.number,\n 'number,number': ceilNumber.signatures['number,number'],\n\n Complex: function (x) {\n return x.ceil()\n },\n\n 'Complex, number': function (x, n) {\n return x.ceil(n)\n },\n\n 'Complex, BigNumber': function (x, n) {\n return x.ceil(n.toNumber())\n },\n\n BigNumber: function (x) {\n if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) {\n return round(x)\n } else {\n return x.ceil()\n }\n },\n\n 'BigNumber, BigNumber': function (x, n) {\n if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n return round(x, n)\n } else {\n return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_CEIL)\n }\n },\n\n Fraction: function (x) {\n return x.ceil()\n },\n\n 'Fraction, number': function (x, n) {\n return x.ceil(n)\n },\n\n 'Fraction, BigNumber': function (x, n) {\n return x.ceil(n.toNumber())\n },\n\n 'Array | Matrix': typed.referToSelf(self => (x) => {\n // deep map collection, skip zeros since ceil(0) = 0\n return deepMap(x, self, true)\n }),\n\n 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n // deep map collection, skip zeros since ceil(0) = 0\n return deepMap(x, i => self(i, n), true)\n }),\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'number | Complex | Fraction | BigNumber, Array':\n typed.referToSelf(self => (x, y) => {\n // use matrix implementation\n return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n }),\n\n 'number | Complex | Fraction | BigNumber, Matrix':\n typed.referToSelf(self => (x, y) => {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n if (y.storage() === 'dense') {\n return matAlgo14xDs(y, x, self, true)\n }\n return matAlgo12xSfs(y, x, self, true)\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cubeNumber } from '../../plain/number/index.js'\n\nconst name = 'cube'\nconst dependencies = ['typed']\n\nexport const createCube = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the cube of a value, `x * x * x`.\n * To avoid confusion with `pow(M,3)`, this function does not apply to matrices.\n * If you wish to cube every entry of a matrix, see the examples.\n *\n * Syntax:\n *\n * math.cube(x)\n *\n * Examples:\n *\n * math.cube(2) // returns number 8\n * math.pow(2, 3) // returns number 8\n * math.cube(4) // returns number 64\n * 4 * 4 * 4 // returns number 64\n *\n * math.map([1, 2, 3, 4], math.cube) // returns Array [1, 8, 27, 64]\n *\n * See also:\n *\n * multiply, square, pow, cbrt\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Number for which to calculate the cube\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Cube of x\n */\n return typed(name, {\n number: cubeNumber,\n\n Complex: function (x) {\n return x.mul(x).mul(x) // Is faster than pow(x, 3)\n },\n\n BigNumber: function (x) {\n return x.times(x).times(x)\n },\n\n bigint: function (x) {\n return x * x * x\n },\n\n Fraction: function (x) {\n return x.pow(3) // Is faster than mul()mul()mul()\n },\n\n Unit: function (x) {\n return x.pow(3)\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { expNumber } from '../../plain/number/index.js'\n\nconst name = 'exp'\nconst dependencies = ['typed']\n\nexport const createExp = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the exponential of a value.\n * For matrices, if you want the matrix exponential of square matrix, use\n * the `expm` function; if you want to take the exponential of each element,\n * see the examples.\n *\n * Syntax:\n *\n * math.exp(x)\n *\n * Examples:\n *\n * math.exp(2) // returns number 7.3890560989306495\n * math.pow(math.e, 2) // returns number 7.3890560989306495\n * math.log(math.exp(2)) // returns number 2\n *\n * math.map([1, 2, 3], math.exp)\n * // returns Array [\n * // 2.718281828459045,\n * // 7.3890560989306495,\n * // 20.085536923187668\n * // ]\n *\n * See also:\n *\n * expm1, expm, log, pow\n *\n * @param {number | BigNumber | Complex} x A number to exponentiate\n * @return {number | BigNumber | Complex} Exponential of `x`\n */\n return typed(name, {\n number: expNumber,\n\n Complex: function (x) {\n return x.exp()\n },\n\n BigNumber: function (x) {\n return x.exp()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { expm1Number } from '../../plain/number/index.js'\n\nconst name = 'expm1'\nconst dependencies = ['typed', 'Complex']\n\nexport const createExpm1 = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex }) => {\n /**\n * Calculate the value of subtracting 1 from the exponential value.\n * This function is more accurate than `math.exp(x)-1` when `x` is near 0\n * To avoid ambiguity with the matrix exponential `expm`, this function\n * does not operate on matrices; if you wish to apply it elementwise, see\n * the examples.\n *\n * Syntax:\n *\n * math.expm1(x)\n *\n * Examples:\n *\n * math.expm1(2) // returns number 6.38905609893065\n * math.pow(math.e, 2) - 1 // returns number 6.3890560989306495\n * math.expm1(1e-8) // returns number 1.0000000050000001e-8\n * math.exp(1e-8) - 1 // returns number 9.9999999392253e-9\n * math.log(math.expm1(2) + 1) // returns number 2\n *\n * math.map([1, 2, 3], math.expm1)\n * // returns Array [\n * // 1.718281828459045,\n * // 6.3890560989306495,\n * // 19.085536923187668\n * // ]\n *\n * See also:\n *\n * exp, expm, log, pow\n *\n * @param {number | BigNumber | Complex} x The number to exponentiate\n * @return {number | BigNumber | Complex} Exponential of `x`, minus one\n */\n return typed(name, {\n number: expm1Number,\n\n Complex: function (x) {\n const r = Math.exp(x.re)\n return new Complex(\n r * Math.cos(x.im) - 1,\n r * Math.sin(x.im)\n )\n },\n\n BigNumber: function (x) {\n return x.exp().minus(1)\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'fix'\nconst dependencies = ['typed', 'Complex', 'matrix', 'ceil', 'floor', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createFixNumber = /* #__PURE__ */ factory(\n name, ['typed', 'ceil', 'floor'], ({ typed, ceil, floor }) => {\n return typed(name, {\n number: function (x) {\n return (x > 0) ? floor(x) : ceil(x)\n },\n\n 'number, number': function (x, n) {\n return (x > 0) ? floor(x, n) : ceil(x, n)\n }\n })\n }\n)\n\nexport const createFix = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex, matrix, ceil, floor, equalScalar, zeros, DenseMatrix }) => {\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n const fixNumber = createFixNumber({ typed, ceil, floor })\n /**\n * Round a value towards zero.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.fix(x)\n * math.fix(x,n)\n *\n * Examples:\n *\n * math.fix(3.2) // returns number 3\n * math.fix(3.8) // returns number 3\n * math.fix(-4.2) // returns number -4\n * math.fix(-4.7) // returns number -4\n *\n * math.fix(3.12, 1) // returns number 3.1\n * math.fix(3.18, 1) // returns number 3.1\n * math.fix(-4.12, 1) // returns number -4.1\n * math.fix(-4.17, 1) // returns number -4.1\n *\n * const c = math.complex(3.22, -2.78)\n * math.fix(c) // returns Complex 3 - 2i\n * math.fix(c, 1) // returns Complex 3.2 -2.7i\n *\n * math.fix([3.2, 3.8, -4.7]) // returns Array [3, 3, -4]\n * math.fix([3.2, 3.8, -4.7], 1) // returns Array [3.2, 3.8, -4.7]\n *\n * See also:\n *\n * ceil, floor, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n return typed('fix', {\n number: fixNumber.signatures.number,\n 'number, number | BigNumber': fixNumber.signatures['number,number'],\n\n Complex: function (x) {\n return new Complex(\n (x.re > 0) ? Math.floor(x.re) : Math.ceil(x.re),\n (x.im > 0) ? Math.floor(x.im) : Math.ceil(x.im)\n )\n },\n\n 'Complex, number': function (x, n) {\n return new Complex(\n (x.re > 0) ? floor(x.re, n) : ceil(x.re, n),\n (x.im > 0) ? floor(x.im, n) : ceil(x.im, n)\n )\n },\n\n 'Complex, BigNumber': function (x, bn) {\n const n = bn.toNumber()\n return new Complex(\n (x.re > 0) ? floor(x.re, n) : ceil(x.re, n),\n (x.im > 0) ? floor(x.im, n) : ceil(x.im, n)\n )\n },\n\n BigNumber: function (x) {\n return x.isNegative() ? ceil(x) : floor(x)\n },\n\n 'BigNumber, number | BigNumber': function (x, n) {\n return x.isNegative() ? ceil(x, n) : floor(x, n)\n },\n\n Fraction: function (x) {\n return x.s < 0 ? x.ceil() : x.floor()\n },\n\n 'Fraction, number | BigNumber': function (x, n) {\n return x.s < 0 ? ceil(x, n) : floor(x, n)\n },\n\n 'Array | Matrix': typed.referToSelf(self => (x) => {\n // deep map collection, skip zeros since fix(0) = 0\n return deepMap(x, self, true)\n }),\n\n 'Array | Matrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n // deep map collection, skip zeros since fix(0) = 0\n return deepMap(x, i => self(i, n), true)\n }),\n\n 'number | Complex | Fraction | BigNumber, Array':\n typed.referToSelf(self => (x, y) => {\n // use matrix implementation\n return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n }),\n\n 'number | Complex | Fraction | BigNumber, Matrix':\n typed.referToSelf(self => (x, y) => {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n if (y.storage() === 'dense') {\n return matAlgo14xDs(y, x, self, true)\n }\n return matAlgo12xSfs(y, x, self, true)\n })\n })\n})\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'floor'\nconst dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createFloorNumber = /* #__PURE__ */ factory(\n name, ['typed', 'config', 'round'], ({ typed, config, round }) => {\n return typed(name, {\n number: function (x) {\n if (nearlyEqual(x, round(x), config.relTol, config.absTol)) {\n return round(x)\n } else {\n return Math.floor(x)\n }\n },\n\n 'number, number': function (x, n) {\n if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n return round(x, n)\n } else {\n let [number, exponent] = `${x}e`.split('e')\n const result = Math.floor(Number(`${number}e${Number(exponent) + n}`));\n [number, exponent] = `${result}e`.split('e')\n return Number(`${number}e${Number(exponent) - n}`)\n }\n }\n })\n }\n)\n\nexport const createFloor = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix }) => {\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n const floorNumber = createFloorNumber({ typed, config, round })\n /**\n * Round a value towards minus infinity.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.floor(x)\n * math.floor(x, n)\n *\n * Examples:\n *\n * math.floor(3.2) // returns number 3\n * math.floor(3.8) // returns number 3\n * math.floor(-4.2) // returns number -5\n * math.floor(-4.7) // returns number -5\n *\n * math.floor(3.212, 2) // returns number 3.21\n * math.floor(3.288, 2) // returns number 3.28\n * math.floor(-4.212, 2) // returns number -4.22\n * math.floor(-4.782, 2) // returns number -4.79\n *\n * const c = math.complex(3.24, -2.71)\n * math.floor(c) // returns Complex 3 - 3i\n * math.floor(c, 1) // returns Complex 3.2 -2.8i\n *\n * math.floor([3.2, 3.8, -4.7]) // returns Array [3, 3, -5]\n * math.floor([3.21, 3.82, -4.71], 1) // returns Array [3.2, 3.8, -4.8]\n *\n * math.floor(math.tau, [2, 3]) // returns Array [6.28, 6.283]\n *\n * // Note that floor(array, array) currently not implemented.\n *\n * See also:\n *\n * ceil, fix, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n return typed('floor', {\n number: floorNumber.signatures.number,\n 'number,number': floorNumber.signatures['number,number'],\n\n Complex: function (x) {\n return x.floor()\n },\n\n 'Complex, number': function (x, n) {\n return x.floor(n)\n },\n\n 'Complex, BigNumber': function (x, n) {\n return x.floor(n.toNumber())\n },\n\n BigNumber: function (x) {\n if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) {\n return round(x)\n } else {\n return x.floor()\n }\n },\n\n 'BigNumber, BigNumber': function (x, n) {\n if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n return round(x, n)\n } else {\n return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_FLOOR)\n }\n },\n\n Fraction: function (x) {\n return x.floor()\n },\n\n 'Fraction, number': function (x, n) {\n return x.floor(n)\n },\n\n 'Fraction, BigNumber': function (x, n) {\n return x.floor(n.toNumber())\n },\n\n 'Array | Matrix': typed.referToSelf(self => (x) => {\n // deep map collection, skip zeros since floor(0) = 0\n return deepMap(x, self, true)\n }),\n\n 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n // deep map collection, skip zeros since ceil(0) = 0\n return deepMap(x, i => self(i, n), true)\n }),\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'number | Complex | Fraction | BigNumber, Array':\n typed.referToSelf(self => (x, y) => {\n // use matrix implementation\n return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n }),\n\n 'number | Complex | Fraction | BigNumber, Matrix':\n typed.referToSelf(self => (x, y) => {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n if (y.storage() === 'dense') {\n return matAlgo14xDs(y, x, self, true)\n }\n return matAlgo12xSfs(y, x, self, true)\n })\n })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo02xDS0'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo02xDS0 = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij).\n * Callback function invoked NNZ times (number of nonzero items in SparseMatrix).\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (S)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function matAlgo02xDS0 (denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n const adata = denseMatrix._data\n const asize = denseMatrix._size\n const adt = denseMatrix._datatype || denseMatrix.getDataType()\n // sparse matrix arrays\n const bvalues = sparseMatrix._values\n const bindex = sparseMatrix._index\n const bptr = sparseMatrix._ptr\n const bsize = sparseMatrix._size\n const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // sparse matrix cannot be a Pattern matrix\n if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result (SparseMatrix)\n const cvalues = []\n const cindex = []\n const cptr = []\n\n // loop columns in b\n for (let j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // values in column j\n for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n const i = bindex[k]\n // update C(i,j)\n const cij = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n // check for nonzero\n if (!eq(cij, zero)) {\n // push i & v\n cindex.push(i)\n cvalues.push(cij)\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return sparseMatrix.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo03xDSf'\nconst dependencies = ['typed']\n\nexport const createMatAlgo03xDSf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Iterates over SparseMatrix items and invokes the callback function f(Dij, Sij).\n * Callback function invoked M*N times.\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ f(Dij, 0) ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (C)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function matAlgo03xDSf (denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n const adata = denseMatrix._data\n const asize = denseMatrix._size\n const adt = denseMatrix._datatype || denseMatrix.getDataType()\n // sparse matrix arrays\n const bvalues = sparseMatrix._values\n const bindex = sparseMatrix._index\n const bptr = sparseMatrix._ptr\n const bsize = sparseMatrix._size\n const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // sparse matrix cannot be a Pattern matrix\n if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result (DenseMatrix)\n const cdata = []\n\n // initialize dense matrix\n for (let z = 0; z < rows; z++) {\n // initialize row\n cdata[z] = []\n }\n\n // workspace\n const x = []\n // marks indicating we have a value in x for a given column\n const w = []\n\n // loop columns in b\n for (let j = 0; j < columns; j++) {\n // column mark\n const mark = j + 1\n // values in column j\n for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n const i = bindex[k]\n // update workspace\n x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n w[i] = mark\n }\n // process workspace\n for (let y = 0; y < rows; y++) {\n // check we have a calculated value for current row\n if (w[y] === mark) {\n // use calculated value\n cdata[y][j] = x[y]\n } else {\n // calculate value\n cdata[y][j] = inverse ? cf(zero, adata[y][j]) : cf(adata[y][j], zero)\n }\n }\n }\n\n // return dense matrix\n return denseMatrix.createDenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo05xSfSf'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo05xSfSf = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 || B(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo05xSfSf (a, b, callback) {\n // sparse matrix arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = avalues && bvalues ? [] : undefined\n const cindex = []\n const cptr = []\n\n // workspaces\n const xa = cvalues ? [] : undefined\n const xb = cvalues ? [] : undefined\n // marks indicating we have a value in x for a given column\n const wa = []\n const wb = []\n\n // vars\n let i, j, k, k1\n\n // loop columns\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // columns mark\n const mark = j + 1\n // loop values A(:,j)\n for (k = aptr[j], k1 = aptr[j + 1]; k < k1; k++) {\n // row\n i = aindex[k]\n // push index\n cindex.push(i)\n // update workspace\n wa[i] = mark\n // check we need to process values\n if (xa) { xa[i] = avalues[k] }\n }\n // loop values B(:,j)\n for (k = bptr[j], k1 = bptr[j + 1]; k < k1; k++) {\n // row\n i = bindex[k]\n // check row existed in A\n if (wa[i] !== mark) {\n // push index\n cindex.push(i)\n }\n // update workspace\n wb[i] = mark\n // check we need to process values\n if (xb) { xb[i] = bvalues[k] }\n }\n // check we need to process values (non pattern matrix)\n if (cvalues) {\n // initialize first index in j\n k = cptr[j]\n // loop index in j\n while (k < cindex.length) {\n // row\n i = cindex[k]\n // marks\n const wai = wa[i]\n const wbi = wb[i]\n // check Aij or Bij are nonzero\n if (wai === mark || wbi === mark) {\n // matrix values @ i,j\n const va = wai === mark ? xa[i] : zero\n const vb = wbi === mark ? xb[i] : zero\n // Cij\n const vc = cf(va, vb)\n // check for zero\n if (!eq(vc, zero)) {\n // push value\n cvalues.push(vc)\n // increment pointer\n k++\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1)\n }\n }\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo13xDD'\nconst dependencies = ['typed']\n\nexport const createMatAlgo13xDD = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, Bij..z).\n * Callback function invoked MxN times.\n *\n * C(i,j,...z) = f(Aij..z, Bij..z)\n *\n * @param {Matrix} a The DenseMatrix instance (A)\n * @param {Matrix} b The DenseMatrix instance (B)\n * @param {Function} callback The f(Aij..z,Bij..z) operation to invoke\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97658658\n */\n return function matAlgo13xDD (a, b, callback) {\n // a arrays\n const adata = a._data\n const asize = a._size\n const adt = a._datatype\n // b arrays\n const bdata = b._data\n const bsize = b._size\n const bdt = b._datatype\n // c arrays\n const csize = []\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // validate each one of the dimension sizes\n for (let s = 0; s < asize.length; s++) {\n // must match\n if (asize[s] !== bsize[s]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n // update dimension in c\n csize[s] = asize[s]\n }\n\n // datatype\n let dt\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // populate cdata, iterate through dimensions\n const cdata = csize.length > 0 ? _iterate(cf, 0, csize, csize[0], adata, bdata) : []\n\n // c matrix\n return a.createDenseMatrix({\n data: cdata,\n size: csize,\n datatype: dt\n })\n }\n\n // recursive function\n function _iterate (f, level, s, n, av, bv) {\n // initialize array for this level\n const cv = []\n // check we reach the last level\n if (level === s.length - 1) {\n // loop arrays in last level\n for (let i = 0; i < n; i++) {\n // invoke callback and store value\n cv[i] = f(av[i], bv[i])\n }\n } else {\n // iterate current level\n for (let j = 0; j < n; j++) {\n // iterate next level\n cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv[j])\n }\n }\n return cv\n }\n})\n","import { broadcastSizes, broadcastTo } from '../../../utils/array.js'\nimport { deepStrictEqual } from '../../../utils/object.js'\n\n/**\n* Broadcasts two matrices, and return both in an array\n* It checks if it's possible with broadcasting rules\n*\n* @param {Matrix} A First Matrix\n* @param {Matrix} B Second Matrix\n*\n* @return {Matrix[]} [ broadcastedA, broadcastedB ]\n*/\n\nexport function broadcast (A, B) {\n if (deepStrictEqual(A.size(), B.size())) {\n // If matrices have the same size return them\n return [A, B]\n }\n\n // calculate the broadcasted sizes\n const newSize = broadcastSizes(A.size(), B.size())\n\n // return the array with the two broadcasted matrices\n return [A, B].map(M => _broadcastTo(M, newSize))\n}\n\n/**\n * Broadcasts a matrix to the given size.\n *\n * @param {Matrix} M - The matrix to be broadcasted.\n * @param {number[]} size - The desired size of the broadcasted matrix.\n * @returns {Matrix} The broadcasted matrix.\n * @throws {Error} If the size parameter is not an array of numbers.\n */\nfunction _broadcastTo (M, size) {\n if (deepStrictEqual(M.size(), size)) {\n return M\n }\n return M.create(broadcastTo(M.valueOf(), size), M.datatype())\n}\n","import { factory } from '../../../utils/factory.js'\nimport { extend } from '../../../utils/object.js'\nimport { createMatAlgo13xDD } from './matAlgo13xDD.js'\nimport { createMatAlgo14xDs } from './matAlgo14xDs.js'\nimport { broadcast } from './broadcast.js'\n\nconst name = 'matrixAlgorithmSuite'\nconst dependencies = ['typed', 'matrix']\n\nexport const createMatrixAlgorithmSuite = /* #__PURE__ */ factory(\n name, dependencies, ({ typed, matrix }) => {\n const matAlgo13xDD = createMatAlgo13xDD({ typed })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n /**\n * Return a signatures object with the usual boilerplate of\n * matrix algorithms, based on a plain options object with the\n * following properties:\n * elop: function -- the elementwise operation to use, defaults to self\n * SS: function -- the algorithm to apply for two sparse matrices\n * DS: function -- the algorithm to apply for a dense and a sparse matrix\n * SD: function -- algo for a sparse and a dense; defaults to SD flipped\n * Ss: function -- the algorithm to apply for a sparse matrix and scalar\n * sS: function -- algo for scalar and sparse; defaults to Ss flipped\n * scalar: string -- typed-function type for scalars, defaults to 'any'\n *\n * If Ss is not specified, no matrix-scalar signatures are generated.\n *\n * @param {object} options\n * @return {Object} signatures\n */\n return function matrixAlgorithmSuite (options) {\n const elop = options.elop\n const SD = options.SD || options.DS\n let matrixSignatures\n if (elop) {\n // First the dense ones\n matrixSignatures = {\n 'DenseMatrix, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(x, y), elop),\n 'Array, Array': (x, y) =>\n matAlgo13xDD(...broadcast(matrix(x), matrix(y)), elop).valueOf(),\n 'Array, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(matrix(x), y), elop),\n 'DenseMatrix, Array': (x, y) => matAlgo13xDD(...broadcast(x, matrix(y)), elop)\n }\n // Now incorporate sparse matrices\n if (options.SS) {\n matrixSignatures['SparseMatrix, SparseMatrix'] =\n (x, y) => options.SS(...broadcast(x, y), elop, false)\n }\n if (options.DS) {\n matrixSignatures['DenseMatrix, SparseMatrix'] =\n (x, y) => options.DS(...broadcast(x, y), elop, false)\n matrixSignatures['Array, SparseMatrix'] =\n (x, y) => options.DS(...broadcast(matrix(x), y), elop, false)\n }\n if (SD) {\n matrixSignatures['SparseMatrix, DenseMatrix'] =\n (x, y) => SD(...broadcast(y, x), elop, true)\n matrixSignatures['SparseMatrix, Array'] =\n (x, y) => SD(...broadcast(matrix(y), x), elop, true)\n }\n } else {\n // No elop, use this\n // First the dense ones\n matrixSignatures = {\n 'DenseMatrix, DenseMatrix': typed.referToSelf(self => (x, y) => {\n return matAlgo13xDD(...broadcast(x, y), self)\n }),\n 'Array, Array': typed.referToSelf(self => (x, y) => {\n return matAlgo13xDD(...broadcast(matrix(x), matrix(y)), self).valueOf()\n }),\n 'Array, DenseMatrix': typed.referToSelf(self => (x, y) => {\n return matAlgo13xDD(...broadcast(matrix(x), y), self)\n }),\n 'DenseMatrix, Array': typed.referToSelf(self => (x, y) => {\n return matAlgo13xDD(...broadcast(x, matrix(y)), self)\n })\n }\n // Now incorporate sparse matrices\n if (options.SS) {\n matrixSignatures['SparseMatrix, SparseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return options.SS(...broadcast(x, y), self, false)\n })\n }\n if (options.DS) {\n matrixSignatures['DenseMatrix, SparseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return options.DS(...broadcast(x, y), self, false)\n })\n matrixSignatures['Array, SparseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return options.DS(...broadcast(matrix(x), y), self, false)\n })\n }\n if (SD) {\n matrixSignatures['SparseMatrix, DenseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return SD(...broadcast(y, x), self, true)\n })\n matrixSignatures['SparseMatrix, Array'] =\n typed.referToSelf(self => (x, y) => {\n return SD(...broadcast(matrix(y), x), self, true)\n })\n }\n }\n\n // Now add the scalars\n const scalar = options.scalar || 'any'\n const Ds = options.Ds || options.Ss\n if (Ds) {\n if (elop) {\n matrixSignatures['DenseMatrix,' + scalar] =\n (x, y) => matAlgo14xDs(x, y, elop, false)\n matrixSignatures[scalar + ', DenseMatrix'] =\n (x, y) => matAlgo14xDs(y, x, elop, true)\n matrixSignatures['Array,' + scalar] =\n (x, y) => matAlgo14xDs(matrix(x), y, elop, false).valueOf()\n matrixSignatures[scalar + ', Array'] =\n (x, y) => matAlgo14xDs(matrix(y), x, elop, true).valueOf()\n } else {\n matrixSignatures['DenseMatrix,' + scalar] =\n typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(x, y, self, false)\n })\n matrixSignatures[scalar + ', DenseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(y, x, self, true)\n })\n matrixSignatures['Array,' + scalar] =\n typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(matrix(x), y, self, false).valueOf()\n })\n matrixSignatures[scalar + ', Array'] =\n typed.referToSelf(self => (x, y) => {\n return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n })\n }\n }\n const sS = (options.sS !== undefined) ? options.sS : options.Ss\n if (elop) {\n if (options.Ss) {\n matrixSignatures['SparseMatrix,' + scalar] =\n (x, y) => options.Ss(x, y, elop, false)\n }\n if (sS) {\n matrixSignatures[scalar + ', SparseMatrix'] =\n (x, y) => sS(y, x, elop, true)\n }\n } else {\n if (options.Ss) {\n matrixSignatures['SparseMatrix,' + scalar] =\n typed.referToSelf(self => (x, y) => {\n return options.Ss(x, y, self, false)\n })\n }\n if (sS) {\n matrixSignatures[scalar + ', SparseMatrix'] =\n typed.referToSelf(self => (x, y) => {\n return sS(y, x, self, true)\n })\n }\n }\n // Also pull in the scalar signatures if the operator is a typed function\n if (elop && elop.signatures) {\n extend(matrixSignatures, elop.signatures)\n }\n return matrixSignatures\n }\n })\n","import { factory } from '../../utils/factory.js'\nimport { createFloor } from './floor.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'mod'\nconst dependencies = [\n 'typed',\n 'config',\n 'round',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createMod = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n const floor = createFloor({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix })\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Calculates the modulus, the remainder of an integer division.\n *\n * For matrices, the function is evaluated element wise.\n *\n * The modulus is defined as:\n *\n * x - y * floor(x / y)\n *\n * See https://en.wikipedia.org/wiki/Modulo_operation.\n *\n * Syntax:\n *\n * math.mod(x, y)\n *\n * Examples:\n *\n * math.mod(8, 3) // returns 2\n * math.mod(11, 2) // returns 1\n *\n * function isOdd(x) {\n * return math.mod(x, 2) != 0\n * }\n *\n * isOdd(2) // returns false\n * isOdd(3) // returns true\n *\n * See also:\n *\n * divide\n *\n * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Dividend\n * @param {number | BigNumber | bigint | Fraction | Array | Matrix} y Divisor\n * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the remainder of `x` divided by `y`.\n */\n return typed(\n name,\n {\n 'number, number': _modNumber,\n\n 'BigNumber, BigNumber': function (x, y) {\n return y.isZero() ? x : x.sub(y.mul(floor(x.div(y))))\n },\n\n 'bigint, bigint': function (x, y) {\n if (y === 0n) {\n return x\n }\n\n if (x < 0) {\n const m = x % y\n return m === 0n ? m : m + y\n }\n\n return x % y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return y.equals(0) ? x : x.sub(y.mul(floor(x.div(y))))\n }\n },\n matrixAlgorithmSuite({\n SS: matAlgo05xSfSf,\n DS: matAlgo03xDSf,\n SD: matAlgo02xDS0,\n Ss: matAlgo11xS0s,\n sS: matAlgo12xSfs\n })\n )\n\n /**\n * Calculate the modulus of two numbers\n * @param {number} x\n * @param {number} y\n * @returns {number} res\n * @private\n */\n function _modNumber (x, y) {\n // We don't use JavaScript's % operator here as this doesn't work\n // correctly for x < 0 and x === 0\n // see https://en.wikipedia.org/wiki/Modulo_operation\n\n // We use mathjs floor to handle errors associated with\n // precision float approximation\n return (y === 0) ? x : x - y * floor(x / y)\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo01xDSid'\nconst dependencies = ['typed']\n\nexport const createMatAlgo01xDSid = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij).\n * Callback function invoked NNZ times (number of nonzero items in SparseMatrix).\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ Dij ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (S)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function algorithm1 (denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n const adata = denseMatrix._data\n const asize = denseMatrix._size\n const adt = denseMatrix._datatype || denseMatrix.getDataType()\n // sparse matrix arrays\n const bvalues = sparseMatrix._values\n const bindex = sparseMatrix._index\n const bptr = sparseMatrix._ptr\n const bsize = sparseMatrix._size\n const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // sparse matrix cannot be a Pattern matrix\n if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // process data types\n const dt = typeof adt === 'string' && adt !== 'mixed' && adt === bdt ? adt : undefined\n // callback function\n const cf = dt ? typed.find(callback, [dt, dt]) : callback\n\n // vars\n let i, j\n\n // result (DenseMatrix)\n const cdata = []\n // initialize c\n for (i = 0; i < rows; i++) { cdata[i] = [] }\n\n // workspace\n const x = []\n // marks indicating we have a value in x for a given column\n const w = []\n\n // loop columns in b\n for (j = 0; j < columns; j++) {\n // column mark\n const mark = j + 1\n // values in column j\n for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]\n // update workspace\n x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n // mark i as updated\n w[i] = mark\n }\n // loop rows\n for (i = 0; i < rows; i++) {\n // check row is in workspace\n if (w[i] === mark) {\n // c[i][j] was already calculated\n cdata[i][j] = x[i]\n } else {\n // item does not exist in S\n cdata[i][j] = adata[i][j]\n }\n }\n }\n\n // return dense matrix\n return denseMatrix.createDenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo04xSidSid'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo04xSidSid = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0\n * └ B(i,j) ; A(i,j) === 0\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo04xSidSid (a, b, callback) {\n // sparse matrix arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = avalues && bvalues ? [] : undefined\n const cindex = []\n const cptr = []\n\n // workspace\n const xa = avalues && bvalues ? [] : undefined\n const xb = avalues && bvalues ? [] : undefined\n // marks indicating we have a value in x for a given column\n const wa = []\n const wb = []\n\n // vars\n let i, j, k, k0, k1\n\n // loop columns\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // columns mark\n const mark = j + 1\n // loop A(:,j)\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]\n // update c\n cindex.push(i)\n // update workspace\n wa[i] = mark\n // check we need to process values\n if (xa) { xa[i] = avalues[k] }\n }\n // loop B(:,j)\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]\n // check row exists in A\n if (wa[i] === mark) {\n // update record in xa @ i\n if (xa) {\n // invoke callback\n const v = cf(xa[i], bvalues[k])\n // check for zero\n if (!eq(v, zero)) {\n // update workspace\n xa[i] = v\n } else {\n // remove mark (index will be removed later)\n wa[i] = null\n }\n }\n } else {\n // update c\n cindex.push(i)\n // update workspace\n wb[i] = mark\n // check we need to process values\n if (xb) { xb[i] = bvalues[k] }\n }\n }\n // check we need to process values (non pattern matrix)\n if (xa && xb) {\n // initialize first index in j\n k = cptr[j]\n // loop index in j\n while (k < cindex.length) {\n // row\n i = cindex[k]\n // check workspace has value @ i\n if (wa[i] === mark) {\n // push value (Aij != 0 || (Aij != 0 && Bij != 0))\n cvalues[k] = xa[i]\n // increment pointer\n k++\n } else if (wb[i] === mark) {\n // push value (bij != 0)\n cvalues[k] = xb[i]\n // increment pointer\n k++\n } else {\n // remove index @ k\n cindex.splice(k, 1)\n }\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo10xSids'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo10xSids = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked NZ times (number of nonzero items in S).\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ b ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function matAlgo10xSids (s, b, callback, inverse) {\n // sparse matrix arrays\n const avalues = s._values\n const aindex = s._index\n const aptr = s._ptr\n const asize = s._size\n const adt = s._datatype\n\n // sparse matrix cannot be a Pattern matrix\n if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string') {\n // datatype\n dt = adt\n // convert b to the same datatype\n b = typed.convert(b, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cdata = []\n\n // workspaces\n const x = []\n // marks indicating we have a value in x for a given column\n const w = []\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n // columns mark\n const mark = j + 1\n // values in j\n for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n const r = aindex[k]\n // update workspace\n x[r] = avalues[k]\n w[r] = mark\n }\n // loop rows\n for (let i = 0; i < rows; i++) {\n // initialize C on first column\n if (j === 0) {\n // create row array\n cdata[i] = []\n }\n // check sparse matrix has a value @ i,j\n if (w[i] === mark) {\n // invoke callback, update C\n cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b)\n } else {\n // dense matrix value @ i, j\n cdata[i][j] = b\n }\n }\n }\n\n // return dense matrix\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n })\n }\n})\n","/**\n * Create a syntax error with the message:\n * 'Wrong number of arguments in function ( provided, - expected)'\n * @param {string} fn Function name\n * @param {number} count Actual argument count\n * @param {number} min Minimum required argument count\n * @param {number} [max] Maximum required argument count\n * @extends Error\n */\nexport function ArgumentsError (fn, count, min, max) {\n if (!(this instanceof ArgumentsError)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n this.fn = fn\n this.count = count\n this.min = min\n this.max = max\n\n this.message = 'Wrong number of arguments in function ' + fn +\n ' (' + count + ' provided, ' +\n min + ((max !== undefined && max !== null) ? ('-' + max) : '') + ' expected)'\n\n this.stack = (new Error()).stack\n}\n\nArgumentsError.prototype = new Error()\nArgumentsError.prototype.constructor = Error\nArgumentsError.prototype.name = 'ArgumentsError'\nArgumentsError.prototype.isArgumentsError = true\n","import { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMod } from './mod.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\n\nconst name = 'gcd'\nconst dependencies = [\n 'typed',\n 'config',\n 'round',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'BigNumber',\n 'DenseMatrix',\n 'concat'\n]\n\nconst gcdTypes = 'number | BigNumber | Fraction | Matrix | Array'\nconst gcdManyTypesSignature = `${gcdTypes}, ${gcdTypes}, ...${gcdTypes}`\n\nfunction is1d (array) {\n return !array.some(element => Array.isArray(element))\n}\n\nexport const createGcd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, config, round, equalScalar, zeros, BigNumber, DenseMatrix, concat }) => {\n const mod = createMod({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix, concat })\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Calculate the greatest common divisor for two or more values or arrays.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.gcd(a, b)\n * math.gcd(a, b, c, ...)\n *\n * Examples:\n *\n * math.gcd(8, 12) // returns 4\n * math.gcd(-4, 6) // returns 2\n * math.gcd(25, 15, -10) // returns 5\n *\n * math.gcd([8, -4], [12, 6]) // returns [4, 2]\n *\n * See also:\n *\n * lcm, xgcd\n *\n * @param {... number | BigNumber | Fraction | Array | Matrix} args Two or more integer numbers\n * @return {number | BigNumber | Fraction | Array | Matrix} The greatest common divisor\n */\n return typed(\n name,\n {\n 'number, number': _gcdNumber,\n 'BigNumber, BigNumber': _gcdBigNumber,\n 'Fraction, Fraction': (x, y) => x.gcd(y)\n },\n matrixAlgorithmSuite({\n SS: matAlgo04xSidSid,\n DS: matAlgo01xDSid,\n Ss: matAlgo10xSids\n }),\n {\n [gcdManyTypesSignature]: typed.referToSelf(self => (a, b, args) => {\n let res = self(a, b)\n for (let i = 0; i < args.length; i++) {\n res = self(res, args[i])\n }\n return res\n }),\n Array: typed.referToSelf(self => (array) => {\n if (array.length === 1 && Array.isArray(array[0]) && is1d(array[0])) {\n return self(...array[0])\n }\n if (is1d(array)) {\n return self(...array)\n }\n throw new ArgumentsError('gcd() supports only 1d matrices!')\n }),\n Matrix: typed.referToSelf(self => (matrix) => {\n return self(matrix.toArray())\n })\n }\n )\n\n /**\n * Calculate gcd for numbers\n * @param {number} a\n * @param {number} b\n * @returns {number} Returns the greatest common denominator of a and b\n * @private\n */\n function _gcdNumber (a, b) {\n if (!isInteger(a) || !isInteger(b)) {\n throw new Error('Parameters in function gcd must be integer numbers')\n }\n\n // https://en.wikipedia.org/wiki/Euclidean_algorithm\n let r\n while (b !== 0) {\n r = mod(a, b)\n a = b\n b = r\n }\n return (a < 0) ? -a : a\n }\n\n /**\n * Calculate gcd for BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @returns {BigNumber} Returns greatest common denominator of a and b\n * @private\n */\n function _gcdBigNumber (a, b) {\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function gcd must be integer numbers')\n }\n\n // https://en.wikipedia.org/wiki/Euclidean_algorithm\n const zero = new BigNumber(0)\n while (!b.isZero()) {\n const r = mod(a, b)\n a = b\n b = r\n }\n return a.lt(zero) ? a.neg() : a\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\nimport { scatter } from '../../../utils/collection.js'\n\nconst name = 'matAlgo06xS0S0'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo06xS0S0 = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked (Anz U Bnz) times, where Anz and Bnz are the nonzero elements in both matrices.\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo06xS0S0 (a, b, callback) {\n // sparse matrix arrays\n const avalues = a._values\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bvalues = b._values\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = avalues && bvalues ? [] : undefined\n const cindex = []\n const cptr = []\n\n // workspaces\n const x = cvalues ? [] : undefined\n // marks indicating we have a value in x for a given column\n const w = []\n // marks indicating value in a given row has been updated\n const u = []\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // columns mark\n const mark = j + 1\n // scatter the values of A(:,j) into workspace\n scatter(a, j, w, x, u, mark, cindex, cf)\n // scatter the values of B(:,j) into workspace\n scatter(b, j, w, x, u, mark, cindex, cf)\n // check we need to process values (non pattern matrix)\n if (x) {\n // initialize first index in j\n let k = cptr[j]\n // loop index in j\n while (k < cindex.length) {\n // row\n const i = cindex[k]\n // check function was invoked on current row (Aij !=0 && Bij != 0)\n if (u[i] === mark) {\n // value @ i\n const v = x[i]\n // check for zero value\n if (!eq(v, zero)) {\n // push value\n cvalues.push(v)\n // increment pointer\n k++\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1)\n }\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1)\n }\n }\n } else {\n // initialize first index in j\n let p = cptr[j]\n // loop index in j\n while (p < cindex.length) {\n // row\n const r = cindex[p]\n // check function was invoked on current row (Aij !=0 && Bij != 0)\n if (u[r] !== mark) {\n // remove value @ i, do not increment pointer\n cindex.splice(p, 1)\n } else {\n // increment pointer\n p++\n }\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { lcmNumber } from '../../plain/number/index.js'\n\nconst name = 'lcm'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'concat'\n]\n\nexport const createLcm = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n const lcmTypes = 'number | BigNumber | Fraction | Matrix | Array'\n const lcmManySignature = {}\n lcmManySignature[`${lcmTypes}, ${lcmTypes}, ...${lcmTypes}`] =\n typed.referToSelf(self => (a, b, args) => {\n let res = self(a, b)\n for (let i = 0; i < args.length; i++) {\n res = self(res, args[i])\n }\n return res\n })\n\n /**\n * Calculate the least common multiple for two or more values or arrays.\n *\n * lcm is defined as:\n *\n * lcm(a, b) = abs(a * b) / gcd(a, b)\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.lcm(a, b)\n * math.lcm(a, b, c, ...)\n *\n * Examples:\n *\n * math.lcm(4, 6) // returns 12\n * math.lcm(6, 21) // returns 42\n * math.lcm(6, 21, 5) // returns 210\n *\n * math.lcm([4, 6], [6, 21]) // returns [12, 42]\n *\n * See also:\n *\n * gcd, xgcd\n *\n * @param {... number | BigNumber | Array | Matrix} args Two or more integer numbers\n * @return {number | BigNumber | Array | Matrix} The least common multiple\n */\n return typed(\n name, {\n 'number, number': lcmNumber,\n 'BigNumber, BigNumber': _lcmBigNumber,\n 'Fraction, Fraction': (x, y) => x.lcm(y)\n },\n matrixAlgorithmSuite({\n SS: matAlgo06xS0S0,\n DS: matAlgo02xDS0,\n Ss: matAlgo11xS0s\n }),\n lcmManySignature\n )\n\n /**\n * Calculate lcm for two BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @returns {BigNumber} Returns the least common multiple of a and b\n * @private\n */\n function _lcmBigNumber (a, b) {\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function lcm must be integer numbers')\n }\n\n if (a.isZero()) {\n return a\n }\n if (b.isZero()) {\n return b\n }\n\n // https://en.wikipedia.org/wiki/Euclidean_algorithm\n // evaluate lcm here inline to reduce overhead\n const prod = a.times(b)\n while (!b.isZero()) {\n const t = b\n b = a.mod(t)\n a = t\n }\n return prod.div(a).abs()\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log10Number } from '../../plain/number/index.js'\n\nconst name = 'log10'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createLog10 = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the 10-base logarithm of a value. This is the same as calculating `log(x, 10)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log10(x)\n *\n * Examples:\n *\n * math.log10(0.00001) // returns -5\n * math.log10(10000) // returns 4\n * math.log(10000) / math.log(10) // returns 4\n * math.pow(10, 4) // returns 10000\n *\n * See also:\n *\n * exp, log, log1p, log2\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the 10-base logarithm of `x`\n */\n return typed(name, {\n number: function (x) {\n if (x >= 0 || config.predictable) {\n return log10Number(x)\n } else {\n // negative value -> complex value computation\n return new Complex(x, 0).log().div(Math.LN10)\n }\n },\n\n Complex: function (x) {\n return new Complex(x).log().div(Math.LN10)\n },\n\n BigNumber: function (x) {\n if (!x.isNegative() || config.predictable) {\n return x.log()\n } else {\n // downgrade to number, return Complex valued result\n return new Complex(x.toNumber(), 0).log().div(Math.LN10)\n }\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log2Number } from '../../plain/number/index.js'\n\nconst name = 'log2'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createLog2 = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log2(x)\n *\n * Examples:\n *\n * math.log2(0.03125) // returns -5\n * math.log2(16) // returns 4\n * math.log2(16) / math.log2(2) // returns 4\n * math.pow(2, 4) // returns 16\n *\n * See also:\n *\n * exp, log, log1p, log10\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the 2-base logarithm of `x`\n */\n return typed(name, {\n number: function (x) {\n if (x >= 0 || config.predictable) {\n return log2Number(x)\n } else {\n // negative value -> complex value computation\n return _log2Complex(new Complex(x, 0))\n }\n },\n\n Complex: _log2Complex,\n\n BigNumber: function (x) {\n if (!x.isNegative() || config.predictable) {\n return x.log(2)\n } else {\n // downgrade to number, return Complex valued result\n return _log2Complex(new Complex(x.toNumber(), 0))\n }\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n\n /**\n * Calculate log2 for a complex value\n * @param {Complex} x\n * @returns {Complex}\n * @private\n */\n function _log2Complex (x) {\n const newX = Math.sqrt(x.re * x.re + x.im * x.im)\n return new Complex(\n (Math.log2) ? Math.log2(newX) : Math.log(newX) / Math.LN2,\n Math.atan2(x.im, x.re) / Math.LN2\n )\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { multiplyNumber } from '../../plain/number/index.js'\n\nconst name = 'multiplyScalar'\nconst dependencies = ['typed']\n\nexport const createMultiplyScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Multiply two scalar values, `x * y`.\n * This function is meant for internal use: it is used by the public function\n * `multiply`\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to multiply\n * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to multiply\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Multiplication of `x` and `y`\n * @private\n */\n return typed('multiplyScalar', {\n\n 'number, number': multiplyNumber,\n\n 'Complex, Complex': function (x, y) {\n return x.mul(y)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.times(y)\n },\n\n 'bigint, bigint': function (x, y) {\n return x * y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return x.mul(y)\n },\n\n 'number | Fraction | BigNumber | Complex, Unit': (x, y) => y.multiply(x),\n\n 'Unit, number | Fraction | BigNumber | Complex | Unit': (x, y) => x.multiply(y)\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'multiply'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'addScalar',\n 'multiplyScalar',\n 'equalScalar',\n 'dot'\n]\n\nexport const createMultiply = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, addScalar, multiplyScalar, equalScalar, dot }) => {\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n function _validateMatrixDimensions (size1, size2) {\n // check left operand dimensions\n switch (size1.length) {\n case 1:\n // check size2\n switch (size2.length) {\n case 1:\n // Vector x Vector\n if (size1[0] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Vectors must have the same length')\n }\n break\n case 2:\n // Vector x Matrix\n if (size1[0] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Vector length (' + size1[0] + ') must match Matrix rows (' + size2[0] + ')')\n }\n break\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)')\n }\n break\n case 2:\n // check size2\n switch (size2.length) {\n case 1:\n // Matrix x Vector\n if (size1[1] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Matrix columns (' + size1[1] + ') must match Vector length (' + size2[0] + ')')\n }\n break\n case 2:\n // Matrix x Matrix\n if (size1[1] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Matrix A columns (' + size1[1] + ') must match Matrix B rows (' + size2[0] + ')')\n }\n break\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)')\n }\n break\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix A has ' + size1.length + ' dimensions)')\n }\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (N)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {number} Scalar value\n */\n function _multiplyVectorVector (a, b, n) {\n // check empty vector\n if (n === 0) { throw new Error('Cannot multiply two empty vectors') }\n return dot(a, b)\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (M)\n * @param {Matrix} b Matrix (MxN)\n *\n * @return {Matrix} Dense Vector (N)\n */\n function _multiplyVectorMatrix (a, b) {\n // process storage\n if (b.storage() !== 'dense') {\n throw new Error('Support for SparseMatrix not implemented')\n }\n return _multiplyVectorDenseMatrix(a, b)\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (M)\n * @param {Matrix} b Dense Matrix (MxN)\n *\n * @return {Matrix} Dense Vector (N)\n */\n function _multiplyVectorDenseMatrix (a, b) {\n // a dense\n const adata = a._data\n const asize = a._size\n const adt = a._datatype || a.getDataType()\n // b dense\n const bdata = b._data\n const bsize = b._size\n const bdt = b._datatype || b.getDataType()\n // rows & columns\n const alength = asize[0]\n const bcolumns = bsize[1]\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n }\n\n // result\n const c = []\n\n // loop matrix columns\n for (let j = 0; j < bcolumns; j++) {\n // sum (do not initialize it with zero)\n let sum = mf(adata[0], bdata[0][j])\n // loop vector\n for (let i = 1; i < alength; i++) {\n // multiply & accumulate\n sum = af(sum, mf(adata[i], bdata[i][j]))\n }\n c[j] = sum\n }\n\n // return matrix\n return a.createDenseMatrix({\n data: c,\n size: [bcolumns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a Matrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} Dense Vector (M)\n */\n const _multiplyMatrixVector = typed('_multiplyMatrixVector', {\n 'DenseMatrix, any': _multiplyDenseMatrixVector,\n 'SparseMatrix, any': _multiplySparseMatrixVector\n })\n\n /**\n * C = A * B\n *\n * @param {Matrix} a Matrix (MxN)\n * @param {Matrix} b Matrix (NxC)\n *\n * @return {Matrix} Matrix (MxC)\n */\n const _multiplyMatrixMatrix = typed('_multiplyMatrixMatrix', {\n 'DenseMatrix, DenseMatrix': _multiplyDenseMatrixDenseMatrix,\n 'DenseMatrix, SparseMatrix': _multiplyDenseMatrixSparseMatrix,\n 'SparseMatrix, DenseMatrix': _multiplySparseMatrixDenseMatrix,\n 'SparseMatrix, SparseMatrix': _multiplySparseMatrixSparseMatrix\n })\n\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} Dense Vector (M)\n */\n function _multiplyDenseMatrixVector (a, b) {\n // a dense\n const adata = a._data\n const asize = a._size\n const adt = a._datatype || a.getDataType()\n // b dense\n const bdata = b._data\n const bdt = b._datatype || b.getDataType()\n // rows & columns\n const arows = asize[0]\n const acolumns = asize[1]\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n }\n\n // result\n const c = []\n\n // loop matrix a rows\n for (let i = 0; i < arows; i++) {\n // current row\n const row = adata[i]\n // sum (do not initialize it with zero)\n let sum = mf(row[0], bdata[0])\n // loop matrix a columns\n for (let j = 1; j < acolumns; j++) {\n // multiply & accumulate\n sum = af(sum, mf(row[j], bdata[j]))\n }\n c[i] = sum\n }\n\n // return matrix\n return a.createDenseMatrix({\n data: c,\n size: [arows],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b DenseMatrix (NxC)\n *\n * @return {Matrix} DenseMatrix (MxC)\n */\n function _multiplyDenseMatrixDenseMatrix (a, b) { // getDataType()\n // a dense\n const adata = a._data\n const asize = a._size\n const adt = a._datatype || a.getDataType()\n // b dense\n const bdata = b._data\n const bsize = b._size\n const bdt = b._datatype || b.getDataType()\n // rows & columns\n const arows = asize[0]\n const acolumns = asize[1]\n const bcolumns = bsize[1]\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n }\n\n // result\n const c = []\n\n // loop matrix a rows\n for (let i = 0; i < arows; i++) {\n // current row\n const row = adata[i]\n // initialize row array\n c[i] = []\n // loop matrix b columns\n for (let j = 0; j < bcolumns; j++) {\n // sum (avoid initializing sum to zero)\n let sum = mf(row[0], bdata[0][j])\n // loop matrix a columns\n for (let x = 1; x < acolumns; x++) {\n // multiply & accumulate\n sum = af(sum, mf(row[x], bdata[x][j]))\n }\n c[i][j] = sum\n }\n }\n\n // return matrix\n return a.createDenseMatrix({\n data: c,\n size: [arows, bcolumns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b SparseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n function _multiplyDenseMatrixSparseMatrix (a, b) {\n // a dense\n const adata = a._data\n const asize = a._size\n const adt = a._datatype || a.getDataType()\n // b sparse\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n // validate b matrix\n if (!bvalues) { throw new Error('Cannot multiply Dense Matrix times Pattern only Matrix') }\n // rows & columns\n const arows = asize[0]\n const bcolumns = bsize[1]\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n // equalScalar signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n }\n\n // result\n const cvalues = []\n const cindex = []\n const cptr = []\n // c matrix\n const c = b.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n\n // loop b columns\n for (let jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length\n // indeces in column jb\n const kb0 = bptr[jb]\n const kb1 = bptr[jb + 1]\n // do not process column jb if no data exists\n if (kb1 > kb0) {\n // last row mark processed\n let last = 0\n // loop a rows\n for (let i = 0; i < arows; i++) {\n // column mark\n const mark = i + 1\n // C[i, jb]\n let cij\n // values in b column j\n for (let kb = kb0; kb < kb1; kb++) {\n // row\n const ib = bindex[kb]\n // check value has been initialized\n if (last !== mark) {\n // first value in column jb\n cij = mf(adata[i][ib], bvalues[kb])\n // update mark\n last = mark\n } else {\n // accumulate value\n cij = af(cij, mf(adata[i][ib], bvalues[kb]))\n }\n }\n // check column has been processed and value != 0\n if (last === mark && !eq(cij, zero)) {\n // push row & value\n cindex.push(i)\n cvalues.push(cij)\n }\n }\n }\n }\n // update ptr\n cptr[bcolumns] = cindex.length\n\n // return sparse matrix\n return c\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} SparseMatrix (M, 1)\n */\n function _multiplySparseMatrixVector (a, b) {\n // a sparse\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // validate a matrix\n if (!avalues) { throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix') }\n // b dense\n const bdata = b._data\n const bdt = b._datatype || b.getDataType()\n // rows & columns\n const arows = a._size[0]\n const brows = b._size[0]\n // result\n const cvalues = []\n const cindex = []\n const cptr = []\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n // equalScalar signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n }\n\n // workspace\n const x = []\n // vector with marks indicating a value x[i] exists in a given column\n const w = []\n\n // update ptr\n cptr[0] = 0\n // rows in b\n for (let ib = 0; ib < brows; ib++) {\n // b[ib]\n const vbi = bdata[ib]\n // check b[ib] != 0, avoid loops\n if (!eq(vbi, zero)) {\n // A values & index in ib column\n for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // a row\n const ia = aindex[ka]\n // check value exists in current j\n if (!w[ia]) {\n // ia is new entry in j\n w[ia] = true\n // add i to pattern of C\n cindex.push(ia)\n // x(ia) = A\n x[ia] = mf(vbi, avalues[ka])\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(vbi, avalues[ka]))\n }\n }\n }\n }\n // copy values from x to column jb of c\n for (let p1 = cindex.length, p = 0; p < p1; p++) {\n // row\n const ic = cindex[p]\n // copy value\n cvalues[p] = x[ic]\n }\n // update ptr\n cptr[1] = cindex.length\n\n // matrix to return\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, 1],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b DenseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n function _multiplySparseMatrixDenseMatrix (a, b) {\n // a sparse\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // validate a matrix\n if (!avalues) { throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix') }\n // b dense\n const bdata = b._data\n const bdt = b._datatype || b.getDataType()\n // rows & columns\n const arows = a._size[0]\n const brows = b._size[0]\n const bcolumns = b._size[1]\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n // equalScalar signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n }\n\n // result\n const cvalues = []\n const cindex = []\n const cptr = []\n // c matrix\n const c = a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n\n // workspace\n const x = []\n // vector with marks indicating a value x[i] exists in a given column\n const w = []\n\n // loop b columns\n for (let jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length\n // mark in workspace for current column\n const mark = jb + 1\n // rows in jb\n for (let ib = 0; ib < brows; ib++) {\n // b[ib, jb]\n const vbij = bdata[ib][jb]\n // check b[ib, jb] != 0, avoid loops\n if (!eq(vbij, zero)) {\n // A values & index in ib column\n for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // a row\n const ia = aindex[ka]\n // check value exists in current j\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark\n // add i to pattern of C\n cindex.push(ia)\n // x(ia) = A\n x[ia] = mf(vbij, avalues[ka])\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(vbij, avalues[ka]))\n }\n }\n }\n }\n // copy values from x to column jb of c\n for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n // row\n const ic = cindex[p]\n // copy value\n cvalues[p] = x[ic]\n }\n }\n // update ptr\n cptr[bcolumns] = cindex.length\n\n // return sparse matrix\n return c\n }\n\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b SparseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n function _multiplySparseMatrixSparseMatrix (a, b) {\n // a sparse\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // b sparse\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // rows & columns\n const arows = a._size[0]\n const bcolumns = b._size[1]\n // flag indicating both matrices (a & b) contain data\n const values = avalues && bvalues\n\n // datatype\n let dt\n // addScalar signature to use\n let af = addScalar\n // multiplyScalar signature to use\n let mf = multiplyScalar\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signatures that matches (dt, dt)\n af = typed.find(addScalar, [dt, dt])\n mf = typed.find(multiplyScalar, [dt, dt])\n }\n\n // result\n const cvalues = values ? [] : undefined\n const cindex = []\n const cptr = []\n // c matrix\n const c = a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n\n // workspace\n const x = values ? [] : undefined\n // vector with marks indicating a value x[i] exists in a given column\n const w = []\n // variables\n let ka, ka0, ka1, kb, kb0, kb1, ia, ib\n // loop b columns\n for (let jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length\n // mark in workspace for current column\n const mark = jb + 1\n // B values & index in j\n for (kb0 = bptr[jb], kb1 = bptr[jb + 1], kb = kb0; kb < kb1; kb++) {\n // b row\n ib = bindex[kb]\n // check we need to process values\n if (values) {\n // loop values in a[:,ib]\n for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // row\n ia = aindex[ka]\n // check value exists in current j\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark\n // add i to pattern of C\n cindex.push(ia)\n // x(ia) = A\n x[ia] = mf(bvalues[kb], avalues[ka])\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(bvalues[kb], avalues[ka]))\n }\n }\n } else {\n // loop values in a[:,ib]\n for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // row\n ia = aindex[ka]\n // check value exists in current j\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark\n // add i to pattern of C\n cindex.push(ia)\n }\n }\n }\n }\n // check we need to process matrix values (pattern matrix)\n if (values) {\n // copy values from x to column jb of c\n for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n // row\n const ic = cindex[p]\n // copy value\n cvalues[p] = x[ic]\n }\n }\n }\n // update ptr\n cptr[bcolumns] = cindex.length\n\n // return sparse matrix\n return c\n }\n\n /**\n * Multiply two or more values, `x * y`.\n * For matrices, the matrix product is calculated.\n *\n * Syntax:\n *\n * math.multiply(x, y)\n * math.multiply(x, y, z, ...)\n *\n * Examples:\n *\n * math.multiply(4, 5.2) // returns number 20.8\n * math.multiply(2, 3, 4) // returns number 24\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(4, 1)\n * math.multiply(a, b) // returns Complex 5 + 14i\n *\n * const c = [[1, 2], [4, 3]]\n * const d = [[1, 2, 3], [3, -4, 7]]\n * math.multiply(c, d) // returns Array [[7, -6, 17], [13, -4, 33]]\n *\n * const e = math.unit('2.1 km')\n * math.multiply(3, e) // returns Unit 6.3 km\n *\n * See also:\n *\n * divide, prod, cross, dot\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to multiply\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to multiply\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y`\n */\n return typed(name, multiplyScalar, {\n // we extend the signatures of multiplyScalar with signatures dealing with matrices\n\n 'Array, Array': typed.referTo('Matrix, Matrix', selfMM => (x, y) => {\n // check dimensions\n _validateMatrixDimensions(arraySize(x), arraySize(y))\n\n // use dense matrix implementation\n const m = selfMM(matrix(x), matrix(y))\n // return array or scalar\n return isMatrix(m) ? m.valueOf() : m\n }),\n\n 'Matrix, Matrix': function (x, y) {\n // dimensions\n const xsize = x.size()\n const ysize = y.size()\n\n // check dimensions\n _validateMatrixDimensions(xsize, ysize)\n\n // process dimensions\n if (xsize.length === 1) {\n // process y dimensions\n if (ysize.length === 1) {\n // Vector * Vector\n return _multiplyVectorVector(x, y, xsize[0])\n }\n // Vector * Matrix\n return _multiplyVectorMatrix(x, y)\n }\n // process y dimensions\n if (ysize.length === 1) {\n // Matrix * Vector\n return _multiplyMatrixVector(x, y)\n }\n // Matrix * Matrix\n return _multiplyMatrixMatrix(x, y)\n },\n\n 'Matrix, Array': typed.referTo('Matrix,Matrix', selfMM =>\n (x, y) => selfMM(x, matrix(y))),\n\n 'Array, Matrix': typed.referToSelf(self => (x, y) => {\n // use Matrix * Matrix implementation\n return self(matrix(x, y.storage()), y)\n }),\n\n 'SparseMatrix, any': function (x, y) {\n return matAlgo11xS0s(x, y, multiplyScalar, false)\n },\n\n 'DenseMatrix, any': function (x, y) {\n return matAlgo14xDs(x, y, multiplyScalar, false)\n },\n\n 'any, SparseMatrix': function (x, y) {\n return matAlgo11xS0s(y, x, multiplyScalar, true)\n },\n\n 'any, DenseMatrix': function (x, y) {\n return matAlgo14xDs(y, x, multiplyScalar, true)\n },\n\n 'Array, any': function (x, y) {\n // use matrix implementation\n return matAlgo14xDs(matrix(x), y, multiplyScalar, false).valueOf()\n },\n\n 'any, Array': function (x, y) {\n // use matrix implementation\n return matAlgo14xDs(matrix(y), x, multiplyScalar, true).valueOf()\n },\n\n 'any, any': multiplyScalar,\n\n 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => {\n let result = self(x, y)\n\n for (let i = 0; i < rest.length; i++) {\n result = self(result, rest[i])\n }\n\n return result\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { nthRootNumber } from '../../plain/number/index.js'\n\nconst name = 'nthRoot'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'BigNumber',\n 'concat'\n]\n\nexport const createNthRoot = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, BigNumber, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Calculate the nth root of a value.\n * The principal nth root of a positive real number A, is the positive real\n * solution of the equation\n *\n * x^root = A\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.nthRoot(a)\n * math.nthRoot(a, root)\n *\n * Examples:\n *\n * math.nthRoot(9, 2) // returns 3 (since 3^2 == 9)\n * math.sqrt(9) // returns 3 (since 3^2 == 9)\n * math.nthRoot(64, 3) // returns 4 (since 4^3 == 64)\n *\n * See also:\n *\n * sqrt, pow\n *\n * @param {number | BigNumber | Array | Matrix | Complex} a\n * Value for which to calculate the nth root\n * @param {number | BigNumber} [root=2] The root.\n * @return {number | Complex | Array | Matrix} Returns the nth root of `a`\n */\n function complexErr () {\n throw new Error(\n 'Complex number not supported in function nthRoot. Use nthRoots instead.')\n }\n\n return typed(\n name,\n {\n number: nthRootNumber,\n 'number, number': nthRootNumber,\n\n BigNumber: x => _bigNthRoot(x, new BigNumber(2)),\n 'BigNumber, BigNumber': _bigNthRoot,\n\n Complex: complexErr,\n 'Complex, number': complexErr,\n\n Array: typed.referTo('DenseMatrix,number', selfDn =>\n x => selfDn(matrix(x), 2).valueOf()),\n DenseMatrix: typed.referTo('DenseMatrix,number', selfDn =>\n x => selfDn(x, 2)),\n SparseMatrix: typed.referTo('SparseMatrix,number', selfSn =>\n x => selfSn(x, 2)),\n\n 'SparseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // sparse + sparse\n return matAlgo06xS0S0(x, y, self)\n } else {\n // throw exception\n throw new Error('Root must be non-zero')\n }\n }),\n\n 'DenseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // dense + sparse\n return matAlgo01xDSid(x, y, self, false)\n } else {\n // throw exception\n throw new Error('Root must be non-zero')\n }\n }),\n\n 'Array, SparseMatrix': typed.referTo('DenseMatrix,SparseMatrix', selfDS =>\n (x, y) => selfDS(matrix(x), y)),\n\n 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // sparse - scalar\n return matAlgo11xS0s(y, x, self, true)\n } else {\n // throw exception\n throw new Error('Root must be non-zero')\n }\n })\n },\n matrixAlgorithmSuite({\n scalar: 'number | BigNumber',\n SD: matAlgo02xDS0,\n Ss: matAlgo11xS0s,\n sS: false\n })\n )\n\n /**\n * Calculate the nth root of a for BigNumbers, solve x^root == a\n * https://rosettacode.org/wiki/Nth_root#JavaScript\n * @param {BigNumber} a\n * @param {BigNumber} root\n * @private\n */\n function _bigNthRoot (a, root) {\n const precision = BigNumber.precision\n const Big = BigNumber.clone({ precision: precision + 2 })\n const zero = new BigNumber(0)\n\n const one = new Big(1)\n const inv = root.isNegative()\n if (inv) {\n root = root.neg()\n }\n\n if (root.isZero()) {\n throw new Error('Root must be non-zero')\n }\n if (a.isNegative() && !root.abs().mod(2).equals(1)) {\n throw new Error('Root must be odd when a is negative.')\n }\n\n // edge cases zero and infinity\n if (a.isZero()) {\n return inv ? new Big(Infinity) : 0\n }\n if (!a.isFinite()) {\n return inv ? zero : a\n }\n\n let x = a.abs().pow(one.div(root))\n // If a < 0, we require that root is an odd integer,\n // so (-1) ^ (1/root) = -1\n x = a.isNeg() ? x.neg() : x\n return new BigNumber((inv ? one.div(x) : x).toPrecision(precision))\n }\n})\n\nexport const createNthRootNumber = /* #__PURE__ */ factory(name, ['typed'], ({ typed }) => {\n return typed(name, {\n number: nthRootNumber,\n 'number, number': nthRootNumber\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { signNumber } from '../../plain/number/index.js'\n\nconst name = 'sign'\nconst dependencies = ['typed', 'BigNumber', 'Fraction', 'complex']\n\nexport const createSign = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber, complex, Fraction }) => {\n /**\n * Compute the sign of a value. The sign of a value x is:\n *\n * - 1 when x > 0\n * - -1 when x < 0\n * - 0 when x == 0\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sign(x)\n *\n * Examples:\n *\n * math.sign(3.5) // returns 1\n * math.sign(-4.2) // returns -1\n * math.sign(0) // returns 0\n *\n * math.sign([3, 5, -2, 0, 2]) // returns [1, 1, -1, 0, 1]\n *\n * See also:\n *\n * abs\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x\n * The number for which to determine the sign\n * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit}\n * The sign of `x`\n */\n return typed(name, {\n number: signNumber,\n\n Complex: function (x) {\n return x.im === 0 ? complex(signNumber(x.re)) : x.sign()\n },\n\n BigNumber: function (x) {\n return new BigNumber(x.cmp(0))\n },\n\n bigint: function (x) {\n return x > 0n ? 1n : x < 0n ? -1n : 0n\n },\n\n Fraction: function (x) {\n return new Fraction(x.s, 1)\n },\n\n // deep map collection, skip zeros since sign(0) = 0\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)),\n\n Unit: typed.referToSelf(self => x => {\n if (!x._isDerived() && x.units[0].unit.offset !== 0) {\n throw new TypeError('sign is ambiguous for units with offset')\n }\n return typed.find(self, x.valueType())(x.value)\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'sqrt'\nconst dependencies = ['config', 'typed', 'Complex']\n\nexport const createSqrt = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, Complex }) => {\n /**\n * Calculate the square root of a value.\n *\n * For matrices, if you want the matrix square root of a square matrix,\n * use the `sqrtm` function. If you wish to apply `sqrt` elementwise to\n * a matrix M, use `math.map(M, math.sqrt)`.\n *\n * Syntax:\n *\n * math.sqrt(x)\n *\n * Examples:\n *\n * math.sqrt(25) // returns 5\n * math.square(5) // returns 25\n * math.sqrt(-4) // returns Complex 2i\n *\n * See also:\n *\n * square, multiply, cube, cbrt, sqrtm\n *\n * @param {number | BigNumber | Complex | Unit} x\n * Value for which to calculate the square root.\n * @return {number | BigNumber | Complex | Unit}\n * Returns the square root of `x`\n */\n return typed('sqrt', {\n number: _sqrtNumber,\n\n Complex: function (x) {\n return x.sqrt()\n },\n\n BigNumber: function (x) {\n if (!x.isNegative() || config.predictable) {\n return x.sqrt()\n } else {\n // negative value -> downgrade to number to do complex value computation\n return _sqrtNumber(x.toNumber())\n }\n },\n\n Unit: function (x) {\n // Someday will work for complex units when they are implemented\n return x.pow(0.5)\n }\n\n })\n\n /**\n * Calculate sqrt for a number\n * @param {number} x\n * @returns {number | Complex} Returns the square root of x\n * @private\n */\n function _sqrtNumber (x) {\n if (isNaN(x)) {\n return NaN\n } else if (x >= 0 || config.predictable) {\n return Math.sqrt(x)\n } else {\n return new Complex(x, 0).sqrt()\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { squareNumber } from '../../plain/number/index.js'\n\nconst name = 'square'\nconst dependencies = ['typed']\n\nexport const createSquare = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the square of a value, `x * x`.\n * To avoid confusion with multiplying a square matrix by itself,\n * this function does not apply to matrices. If you wish to square\n * every element of a matrix, see the examples.\n *\n * Syntax:\n *\n * math.square(x)\n *\n * Examples:\n *\n * math.square(2) // returns number 4\n * math.square(3) // returns number 9\n * math.pow(3, 2) // returns number 9\n * math.multiply(3, 3) // returns number 9\n *\n * math.map([1, 2, 3, 4], math.square) // returns Array [1, 4, 9, 16]\n *\n * See also:\n *\n * multiply, cube, sqrt, pow\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x\n * Number for which to calculate the square\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit}\n * Squared value\n */\n return typed(name, {\n number: squareNumber,\n\n Complex: function (x) {\n return x.mul(x)\n },\n\n BigNumber: function (x) {\n return x.times(x)\n },\n\n bigint: function (x) {\n return x * x\n },\n\n Fraction: function (x) {\n return x.mul(x)\n },\n\n Unit: function (x) {\n return x.pow(2)\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'subtract'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'subtractScalar',\n 'unaryMinus',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createSubtract = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, subtractScalar, unaryMinus, DenseMatrix, concat }) => {\n // TODO: split function subtract in two: subtract and subtractScalar\n\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Subtract two values, `x - y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.subtract(x, y)\n *\n * Examples:\n *\n * math.subtract(5.3, 2) // returns number 3.3\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(4, 1)\n * math.subtract(a, b) // returns Complex -2 + 2i\n *\n * math.subtract([5, 7, 4], 4) // returns Array [1, 3, 0]\n *\n * const c = math.unit('2.1 km')\n * const d = math.unit('500m')\n * math.subtract(c, d) // returns Unit 1.6 km\n *\n * See also:\n *\n * add\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Initial value\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Value to subtract from `x`\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Subtraction of `x` and `y`\n */\n return typed(\n name,\n {\n 'any, any': subtractScalar\n },\n matrixAlgorithmSuite({\n elop: subtractScalar,\n SS: matAlgo05xSfSf,\n DS: matAlgo01xDSid,\n SD: matAlgo03xDSf,\n Ss: matAlgo12xSfs,\n sS: matAlgo10xSids\n })\n )\n})\n","import { factory } from '../../utils/factory.js'\nimport { xgcdNumber } from '../../plain/number/index.js'\n\nconst name = 'xgcd'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createXgcd = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\n /**\n * Calculate the extended greatest common divisor for two values.\n * See https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm.\n *\n * Syntax:\n *\n * math.xgcd(a, b)\n *\n * Examples:\n *\n * math.xgcd(8, 12) // returns [4, -1, 1]\n * math.gcd(8, 12) // returns 4\n * math.xgcd(36163, 21199) // returns [1247, -7, 12]\n *\n * See also:\n *\n * gcd, lcm\n *\n * @param {number | BigNumber} a An integer number\n * @param {number | BigNumber} b An integer number\n * @return {Array} Returns an array containing 3 integers `[div, m, n]`\n * where `div = gcd(a, b)` and `a*m + b*n = div`\n */\n return typed(name, {\n 'number, number': function (a, b) {\n const res = xgcdNumber(a, b)\n\n return (config.matrix === 'Array')\n ? res\n : matrix(res)\n },\n 'BigNumber, BigNumber': _xgcdBigNumber\n // TODO: implement support for Fraction\n })\n\n /**\n * Calculate xgcd for two BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @return {BigNumber[]} result\n * @private\n */\n function _xgcdBigNumber (a, b) {\n // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n let // used to swap two variables\n t\n\n let // quotient\n q\n\n let // remainder\n r\n\n const zero = new BigNumber(0)\n const one = new BigNumber(1)\n let x = zero\n let lastx = one\n let y = one\n let lasty = zero\n\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function xgcd must be integer numbers')\n }\n\n while (!b.isZero()) {\n q = a.div(b).floor()\n r = a.mod(b)\n\n t = x\n x = lastx.minus(q.times(x))\n lastx = t\n\n t = y\n y = lasty.minus(q.times(y))\n lasty = t\n\n a = b\n b = r\n }\n\n let res\n if (a.lt(zero)) {\n res = [a.neg(), lastx.neg(), lasty.neg()]\n } else {\n res = [a, !a.isZero() ? lastx : 0, lasty]\n }\n return (config.matrix === 'Array') ? res : matrix(res)\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'invmod'\nconst dependencies = ['typed', 'config', 'BigNumber', 'xgcd', 'equal', 'smaller', 'mod', 'add', 'isInteger']\n\nexport const createInvmod = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, BigNumber, xgcd, equal, smaller, mod, add, isInteger }) => {\n /**\n * Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation `ax ≣ 1 (mod b)`\n * See https://en.wikipedia.org/wiki/Modular_multiplicative_inverse.\n *\n * Syntax:\n *\n * math.invmod(a, b)\n *\n * Examples:\n *\n * math.invmod(8, 12) // returns NaN\n * math.invmod(7, 13) // returns 2\n * math.invmod(15151, 15122) // returns 10429\n *\n * See also:\n *\n * gcd, xgcd\n *\n * @param {number | BigNumber} a An integer number\n * @param {number | BigNumber} b An integer number\n * @return {number | BigNumber } Returns an integer number\n * where `invmod(a,b)*a ≣ 1 (mod b)`\n */\n return typed(name, {\n 'number, number': invmod,\n 'BigNumber, BigNumber': invmod\n })\n\n function invmod (a, b) {\n if (!isInteger(a) || !isInteger(b)) throw new Error('Parameters in function invmod must be integer numbers')\n a = mod(a, b)\n if (equal(b, 0)) throw new Error('Divisor must be non zero')\n let res = xgcd(a, b)\n res = res.valueOf()\n let [gcd, inv] = res\n if (!equal(gcd, BigNumber(1))) return NaN\n inv = mod(inv, b)\n if (smaller(inv, BigNumber(0))) inv = add(inv, b)\n return inv\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo09xS0Sf'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo09xS0Sf = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix A and invokes the callback function f(Aij, Bij).\n * Callback function invoked NZA times, number of nonzero elements in A.\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo09xS0Sf (a, b, callback) {\n // sparse matrix arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = avalues && bvalues ? [] : undefined\n const cindex = []\n const cptr = []\n\n // workspaces\n const x = cvalues ? [] : undefined\n // marks indicating we have a value in x for a given column\n const w = []\n\n // vars\n let i, j, k, k0, k1\n\n // loop columns\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // column mark\n const mark = j + 1\n // check we need to process values\n if (x) {\n // loop B(:,j)\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]\n // update workspace\n w[i] = mark\n x[i] = bvalues[k]\n }\n }\n // loop A(:,j)\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]\n // check we need to process values\n if (x) {\n // b value @ i,j\n const vb = w[i] === mark ? x[i] : zero\n // invoke f\n const vc = cf(avalues[k], vb)\n // check zero value\n if (!eq(vc, zero)) {\n // push index\n cindex.push(i)\n // push value\n cvalues.push(vc)\n }\n } else {\n // push index\n cindex.push(i)\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotMultiply'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'multiplyScalar',\n 'concat'\n]\n\nexport const createDotMultiply = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, multiplyScalar, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo09xS0Sf = createMatAlgo09xS0Sf({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Multiply two matrices element wise. The function accepts both matrices and\n * scalar values.\n *\n * Syntax:\n *\n * math.dotMultiply(x, y)\n *\n * Examples:\n *\n * math.dotMultiply(2, 4) // returns 8\n *\n * a = [[9, 5], [6, 1]]\n * b = [[3, 2], [5, 2]]\n *\n * math.dotMultiply(a, b) // returns [[27, 10], [30, 2]]\n * math.multiply(a, b) // returns [[52, 28], [23, 14]]\n *\n * See also:\n *\n * multiply, divide, dotDivide\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Left hand value\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Right hand value\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y`\n */\n return typed(name, matrixAlgorithmSuite({\n elop: multiplyScalar,\n SS: matAlgo09xS0Sf,\n DS: matAlgo02xDS0,\n Ss: matAlgo11xS0s\n }))\n})\n","/**\n * Bitwise and for Bignumbers\n *\n * Special Cases:\n * N & n = N\n * n & 0 = 0\n * n & -1 = n\n * n & n = n\n * I & I = I\n * -I & -I = -I\n * I & -I = 0\n * I & n = n\n * I & -n = I\n * -I & n = 0\n * -I & -n = -I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` & `y`, is fully precise\n * @private\n */\nexport function bitAndBigNumber (x, y) {\n if ((x.isFinite() && !x.isInteger()) || (y.isFinite() && !y.isInteger())) {\n throw new Error('Integers expected in function bitAnd')\n }\n\n const BigNumber = x.constructor\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN)\n }\n\n if (x.isZero() || y.eq(-1) || x.eq(y)) {\n return x\n }\n if (y.isZero() || x.eq(-1)) {\n return y\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if (!x.isFinite() && !y.isFinite()) {\n if (x.isNegative() === y.isNegative()) {\n return x\n }\n return new BigNumber(0)\n }\n if (!x.isFinite()) {\n if (y.isNegative()) {\n return x\n }\n if (x.isNegative()) {\n return new BigNumber(0)\n }\n return y\n }\n if (!y.isFinite()) {\n if (x.isNegative()) {\n return y\n }\n if (y.isNegative()) {\n return new BigNumber(0)\n }\n return x\n }\n }\n return bitwise(x, y, function (a, b) { return a & b })\n}\n\n/**\n * Bitwise not\n * @param {BigNumber} x\n * @return {BigNumber} Result of ~`x`, fully precise\n *\n */\nexport function bitNotBigNumber (x) {\n if (x.isFinite() && !x.isInteger()) {\n throw new Error('Integer expected in function bitNot')\n }\n\n const BigNumber = x.constructor\n const prevPrec = BigNumber.precision\n BigNumber.config({ precision: 1E9 })\n\n const result = x.plus(new BigNumber(1))\n result.s = -result.s || null\n\n BigNumber.config({ precision: prevPrec })\n return result\n}\n\n/**\n * Bitwise OR for BigNumbers\n *\n * Special Cases:\n * N | n = N\n * n | 0 = n\n * n | -1 = -1\n * n | n = n\n * I | I = I\n * -I | -I = -I\n * I | -n = -1\n * I | -I = -1\n * I | n = I\n * -I | n = -I\n * -I | -n = -n\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` | `y`, fully precise\n */\nexport function bitOrBigNumber (x, y) {\n if ((x.isFinite() && !x.isInteger()) || (y.isFinite() && !y.isInteger())) {\n throw new Error('Integers expected in function bitOr')\n }\n\n const BigNumber = x.constructor\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN)\n }\n\n const negOne = new BigNumber(-1)\n if (x.isZero() || y.eq(negOne) || x.eq(y)) {\n return y\n }\n if (y.isZero() || x.eq(negOne)) {\n return x\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if ((!x.isFinite() && !x.isNegative() && y.isNegative()) ||\n (x.isNegative() && !y.isNegative() && !y.isFinite())) {\n return negOne\n }\n if (x.isNegative() && y.isNegative()) {\n return x.isFinite() ? x : y\n }\n return x.isFinite() ? y : x\n }\n\n return bitwise(x, y, function (a, b) { return a | b })\n}\n\n/**\n * Applies bitwise function to numbers\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @param {function (a, b)} func\n * @return {BigNumber}\n */\nexport function bitwise (x, y, func) {\n const BigNumber = x.constructor\n\n let xBits, yBits\n const xSign = +(x.s < 0)\n const ySign = +(y.s < 0)\n if (xSign) {\n xBits = decCoefficientToBinaryString(bitNotBigNumber(x))\n for (let i = 0; i < xBits.length; ++i) {\n xBits[i] ^= 1\n }\n } else {\n xBits = decCoefficientToBinaryString(x)\n }\n if (ySign) {\n yBits = decCoefficientToBinaryString(bitNotBigNumber(y))\n for (let i = 0; i < yBits.length; ++i) {\n yBits[i] ^= 1\n }\n } else {\n yBits = decCoefficientToBinaryString(y)\n }\n\n let minBits, maxBits, minSign\n if (xBits.length <= yBits.length) {\n minBits = xBits\n maxBits = yBits\n minSign = xSign\n } else {\n minBits = yBits\n maxBits = xBits\n minSign = ySign\n }\n\n let shortLen = minBits.length\n let longLen = maxBits.length\n const expFuncVal = func(xSign, ySign) ^ 1\n let outVal = new BigNumber(expFuncVal ^ 1)\n let twoPower = new BigNumber(1)\n const two = new BigNumber(2)\n\n const prevPrec = BigNumber.precision\n BigNumber.config({ precision: 1E9 })\n\n while (shortLen > 0) {\n if (func(minBits[--shortLen], maxBits[--longLen]) === expFuncVal) {\n outVal = outVal.plus(twoPower)\n }\n twoPower = twoPower.times(two)\n }\n while (longLen > 0) {\n if (func(minSign, maxBits[--longLen]) === expFuncVal) {\n outVal = outVal.plus(twoPower)\n }\n twoPower = twoPower.times(two)\n }\n\n BigNumber.config({ precision: prevPrec })\n\n if (expFuncVal === 0) {\n outVal.s = -outVal.s\n }\n return outVal\n}\n\n/* Extracted from decimal.js, and edited to specialize. */\nfunction decCoefficientToBinaryString (x) {\n // Convert to string\n const a = x.d // array with digits\n let r = a[0] + ''\n\n for (let i = 1; i < a.length; ++i) {\n let s = a[i] + ''\n for (let z = 7 - s.length; z--;) {\n s = '0' + s\n }\n\n r += s\n }\n\n let j = r.length\n while (r.charAt(j) === '0') {\n j--\n }\n\n let xe = x.e\n let str = r.slice(0, j + 1 || 1)\n const strL = str.length\n if (xe > 0) {\n if (++xe > strL) {\n // Append zeros.\n xe -= strL\n while (xe--) {\n str += '0'\n }\n } else if (xe < strL) {\n str = str.slice(0, xe) + '.' + str.slice(xe)\n }\n }\n\n // Convert from base 10 (decimal) to base 2\n const arr = [0]\n for (let i = 0; i < str.length;) {\n let arrL = arr.length\n while (arrL--) {\n arr[arrL] *= 10\n }\n\n arr[0] += parseInt(str.charAt(i++)) // convert to int\n for (let j = 0; j < arr.length; ++j) {\n if (arr[j] > 1) {\n if (arr[j + 1] === null || arr[j + 1] === undefined) {\n arr[j + 1] = 0\n }\n\n arr[j + 1] += arr[j] >> 1\n arr[j] &= 1\n }\n }\n }\n\n return arr.reverse()\n}\n\n/**\n * Bitwise XOR for BigNumbers\n *\n * Special Cases:\n * N ^ n = N\n * n ^ 0 = n\n * n ^ n = 0\n * n ^ -1 = ~n\n * I ^ n = I\n * I ^ -n = -I\n * I ^ -I = -1\n * -I ^ n = -I\n * -I ^ -n = I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` ^ `y`, fully precise\n *\n */\nexport function bitXor (x, y) {\n if ((x.isFinite() && !x.isInteger()) || (y.isFinite() && !y.isInteger())) {\n throw new Error('Integers expected in function bitXor')\n }\n\n const BigNumber = x.constructor\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN)\n }\n if (x.isZero()) {\n return y\n }\n if (y.isZero()) {\n return x\n }\n\n if (x.eq(y)) {\n return new BigNumber(0)\n }\n\n const negOne = new BigNumber(-1)\n if (x.eq(negOne)) {\n return bitNotBigNumber(y)\n }\n if (y.eq(negOne)) {\n return bitNotBigNumber(x)\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if (!x.isFinite() && !y.isFinite()) {\n return negOne\n }\n return new BigNumber(x.isNegative() === y.isNegative()\n ? Infinity\n : -Infinity)\n }\n return bitwise(x, y, function (a, b) { return a ^ b })\n}\n\n/**\n * Bitwise left shift\n *\n * Special Cases:\n * n << -n = N\n * n << N = N\n * N << n = N\n * n << 0 = n\n * 0 << n = 0\n * I << I = N\n * I << n = I\n * n << I = I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` << `y`\n *\n */\nexport function leftShiftBigNumber (x, y) {\n if ((x.isFinite() && !x.isInteger()) || (y.isFinite() && !y.isInteger())) {\n throw new Error('Integers expected in function leftShift')\n }\n\n const BigNumber = x.constructor\n if (x.isNaN() || y.isNaN() || (y.isNegative() && !y.isZero())) {\n return new BigNumber(NaN)\n }\n if (x.isZero() || y.isZero()) {\n return x\n }\n if (!x.isFinite() && !y.isFinite()) {\n return new BigNumber(NaN)\n }\n\n // Math.pow(2, y) is fully precise for y < 55, and fast\n if (y.lt(55)) {\n return x.times(Math.pow(2, y.toNumber()) + '')\n }\n return x.times(new BigNumber(2).pow(y))\n}\n\n/*\n * Special Cases:\n * n >> -n = N\n * n >> N = N\n * N >> n = N\n * I >> I = N\n * n >> 0 = n\n * I >> n = I\n * -I >> n = -I\n * -I >> I = -I\n * n >> I = I\n * -n >> I = -1\n * 0 >> n = 0\n *\n * @param {BigNumber} value\n * @param {BigNumber} value\n * @return {BigNumber} Result of `x` >> `y`\n *\n */\nexport function rightArithShiftBigNumber (x, y) {\n if ((x.isFinite() && !x.isInteger()) || (y.isFinite() && !y.isInteger())) {\n throw new Error('Integers expected in function rightArithShift')\n }\n\n const BigNumber = x.constructor\n if (x.isNaN() || y.isNaN() || (y.isNegative() && !y.isZero())) {\n return new BigNumber(NaN)\n }\n if (x.isZero() || y.isZero()) {\n return x\n }\n if (!y.isFinite()) {\n if (x.isNegative()) {\n return new BigNumber(-1)\n }\n if (!x.isFinite()) {\n return new BigNumber(NaN)\n }\n return new BigNumber(0)\n }\n\n // Math.pow(2, y) is fully precise for y < 55, and fast\n if (y.lt(55)) {\n return x.div(Math.pow(2, y.toNumber()) + '').floor()\n }\n return x.div(new BigNumber(2).pow(y)).floor()\n}\n","import { isInteger } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function bitAndNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function bitAnd')\n }\n\n return x & y\n}\nbitAndNumber.signature = n2\n\nexport function bitNotNumber (x) {\n if (!isInteger(x)) {\n throw new Error('Integer expected in function bitNot')\n }\n\n return ~x\n}\nbitNotNumber.signature = n1\n\nexport function bitOrNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function bitOr')\n }\n\n return x | y\n}\nbitOrNumber.signature = n2\n\nexport function bitXorNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function bitXor')\n }\n\n return x ^ y\n}\nbitXorNumber.signature = n2\n\nexport function leftShiftNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function leftShift')\n }\n\n return x << y\n}\nleftShiftNumber.signature = n2\n\nexport function rightArithShiftNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function rightArithShift')\n }\n\n return x >> y\n}\nrightArithShiftNumber.signature = n2\n\nexport function rightLogShiftNumber (x, y) {\n if (!isInteger(x) || !isInteger(y)) {\n throw new Error('Integers expected in function rightLogShift')\n }\n\n return x >>> y\n}\nrightLogShiftNumber.signature = n2\n","import { bitAndBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitAndNumber } from '../../plain/number/index.js'\n\nconst name = 'bitAnd'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'concat'\n]\n\nexport const createBitAnd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Bitwise AND two values, `x & y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.bitAnd(x, y)\n *\n * Examples:\n *\n * math.bitAnd(53, 131) // returns number 1\n *\n * math.bitAnd([1, 12, 31], 42) // returns Array [0, 8, 10]\n *\n * See also:\n *\n * bitNot, bitOr, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x First value to and\n * @param {number | BigNumber | bigint | Array | Matrix} y Second value to and\n * @return {number | BigNumber | bigint | Array | Matrix} AND of `x` and `y`\n */\n return typed(\n name,\n {\n 'number, number': bitAndNumber,\n 'BigNumber, BigNumber': bitAndBigNumber,\n 'bigint, bigint': (x, y) => x & y\n },\n matrixAlgorithmSuite({\n SS: matAlgo06xS0S0,\n DS: matAlgo02xDS0,\n Ss: matAlgo11xS0s\n })\n )\n})\n","import { bitNotBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { bitNotNumber } from '../../plain/number/index.js'\n\nconst name = 'bitNot'\nconst dependencies = ['typed']\n\nexport const createBitNot = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Bitwise NOT value, `~x`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.bitNot(x)\n *\n * Examples:\n *\n * math.bitNot(1) // returns number -2\n *\n * math.bitNot([2, -3, 4]) // returns Array [-3, 2, -5]\n *\n * See also:\n *\n * bitAnd, bitOr, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x Value to not\n * @return {number | BigNumber | bigint | Array | Matrix} NOT of `x`\n */\n return typed(name, {\n number: bitNotNumber,\n BigNumber: bitNotBigNumber,\n bigint: x => ~x,\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { bitOrBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitOrNumber } from '../../plain/number/index.js'\n\nconst name = 'bitOr'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createBitOr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Bitwise OR two values, `x | y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the lowest print base.\n *\n * Syntax:\n *\n * math.bitOr(x, y)\n *\n * Examples:\n *\n * math.bitOr(1, 2) // returns number 3\n *\n * math.bitOr([1, 2, 3], 4) // returns Array [5, 6, 7]\n *\n * See also:\n *\n * bitAnd, bitNot, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x First value to or\n * @param {number | BigNumber | bigint | Array | Matrix} y Second value to or\n * @return {number | BigNumber | bigint | Array | Matrix} OR of `x` and `y`\n */\n return typed(\n name,\n {\n 'number, number': bitOrNumber,\n 'BigNumber, BigNumber': bitOrBigNumber,\n 'bigint, bigint': (x, y) => x | y\n },\n matrixAlgorithmSuite({\n SS: matAlgo04xSidSid,\n DS: matAlgo01xDSid,\n Ss: matAlgo10xSids\n })\n )\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo07xSSf'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo07xSSf = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\n /**\n * Iterates over SparseMatrix A and SparseMatrix B items (zero and nonzero) and invokes the callback function f(Aij, Bij).\n * Callback function invoked MxN times.\n *\n * C(i,j) = f(Aij, Bij)\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo07xSSf (a, b, callback) {\n // sparse matrix arrays\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // vars\n let i, j\n\n // result arrays\n const cdata = []\n // initialize c\n for (i = 0; i < rows; i++) { cdata[i] = [] }\n\n // workspaces\n const xa = []\n const xb = []\n // marks indicating we have a value in x for a given column\n const wa = []\n const wb = []\n\n // loop columns\n for (j = 0; j < columns; j++) {\n // columns mark\n const mark = j + 1\n // scatter the values of A(:,j) into workspace\n _scatter(a, j, wa, xa, mark)\n // scatter the values of B(:,j) into workspace\n _scatter(b, j, wb, xb, mark)\n // loop rows\n for (i = 0; i < rows; i++) {\n // matrix values @ i,j\n const va = wa[i] === mark ? xa[i] : zero\n const vb = wb[i] === mark ? xb[i] : zero\n // invoke callback\n cdata[i][j] = cf(va, vb)\n }\n }\n\n // return dense matrix\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n\n function _scatter (m, j, w, x, mark) {\n // a arrays\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n // loop values in column j\n for (let k = ptr[j], k1 = ptr[j + 1]; k < k1; k++) {\n // row\n const i = index[k]\n // update workspace\n w[i] = mark\n x[i] = values[k]\n }\n }\n})\n","import { bitXor as bigBitXor } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitXorNumber } from '../../plain/number/index.js'\n\nconst name = 'bitXor'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createBitXor = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Bitwise XOR two values, `x ^ y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.bitXor(x, y)\n *\n * Examples:\n *\n * math.bitXor(1, 2) // returns number 3\n *\n * math.bitXor([2, 3, 4], 4) // returns Array [6, 7, 0]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x First value to xor\n * @param {number | BigNumber | bigint | Array | Matrix} y Second value to xor\n * @return {number | BigNumber | bigint | Array | Matrix} XOR of `x` and `y`\n */\n return typed(\n name,\n {\n 'number, number': bitXorNumber,\n 'BigNumber, BigNumber': bigBitXor,\n 'bigint, bigint': (x, y) => x ^ y\n },\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'arg'\nconst dependencies = ['typed']\n\nexport const createArg = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the argument of a complex value.\n * For a complex number `a + bi`, the argument is computed as `atan2(b, a)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.arg(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 2)\n * math.arg(a) / math.pi // returns number 0.25\n *\n * const b = math.complex('2 + 3i')\n * math.arg(b) // returns number 0.982793723247329\n * math.atan2(3, 2) // returns number 0.982793723247329\n *\n * See also:\n *\n * re, im, conj, abs\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The argument of x\n */\n return typed(name, {\n number: function (x) {\n return Math.atan2(0, x)\n },\n\n BigNumber: function (x) {\n return x.constructor.atan2(0, x)\n },\n\n Complex: function (x) {\n return x.arg()\n },\n\n // TODO: implement BigNumber support for function arg\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'conj'\nconst dependencies = ['typed']\n\nexport const createConj = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the complex conjugate of a complex value.\n * If `x = a+bi`, the complex conjugate of `x` is `a - bi`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.conj(x)\n *\n * Examples:\n *\n * math.conj(math.complex('2 + 3i')) // returns Complex 2 - 3i\n * math.conj(math.complex('2 - 3i')) // returns Complex 2 + 3i\n * math.conj(math.complex('-5.2i')) // returns Complex 5.2i\n *\n * See also:\n *\n * re, im, arg, abs\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Complex | Array | Matrix}\n * The complex conjugate of x\n */\n return typed(name, {\n 'number | BigNumber | Fraction': x => x,\n Complex: x => x.conjugate(),\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'im'\nconst dependencies = ['typed']\n\nexport const createIm = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Get the imaginary part of a complex number.\n * For a complex number `a + bi`, the function returns `b`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.im(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 3)\n * math.re(a) // returns number 2\n * math.im(a) // returns number 3\n *\n * math.re(math.complex('-5.2i')) // returns number -5.2\n * math.re(math.complex(2.4)) // returns number 0\n *\n * See also:\n *\n * re, conj, abs, arg\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The imaginary part of x\n */\n return typed(name, {\n number: () => 0,\n 'BigNumber | Fraction': x => x.mul(0),\n Complex: x => x.im,\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 're'\nconst dependencies = ['typed']\n\nexport const createRe = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Get the real part of a complex number.\n * For a complex number `a + bi`, the function returns `a`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.re(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 3)\n * math.re(a) // returns number 2\n * math.im(a) // returns number 3\n *\n * math.re(math.complex('-5.2i')) // returns number 0\n * math.re(math.complex(2.4)) // returns number 2.4\n *\n * See also:\n *\n * im, conj, abs, arg\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The real part of x\n */\n return typed(name, {\n 'number | BigNumber | Fraction': x => x,\n Complex: x => x.re,\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","const n1 = 'number'\nconst n2 = 'number, number'\n\nexport function notNumber (x) {\n return !x\n}\nnotNumber.signature = n1\n\nexport function orNumber (x, y) {\n return !!(x || y)\n}\norNumber.signature = n2\n\nexport function xorNumber (x, y) {\n return !!x !== !!y\n}\nxorNumber.signature = n2\n\nexport function andNumber (x, y) {\n return !!(x && y)\n}\nandNumber.signature = n2\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { notNumber } from '../../plain/number/index.js'\n\nconst name = 'not'\nconst dependencies = ['typed']\n\nexport const createNot = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Logical `not`. Flips boolean value of a given parameter.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.not(x)\n *\n * Examples:\n *\n * math.not(2) // returns false\n * math.not(0) // returns true\n * math.not(true) // returns false\n *\n * a = [2, -7, 0]\n * math.not(a) // returns [false, false, true]\n *\n * See also:\n *\n * and, or, xor\n *\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check\n * @return {boolean | Array | Matrix}\n * Returns true when input is a zero or empty value.\n */\n return typed(name, {\n 'null | undefined': () => true,\n\n number: notNumber,\n\n Complex: function (x) {\n return x.re === 0 && x.im === 0\n },\n\n BigNumber: function (x) {\n return x.isZero() || x.isNaN()\n },\n\n bigint: x => !x,\n\n Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)),\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { orNumber } from '../../plain/number/index.js'\n\nconst name = 'or'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createOr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Logical `or`. Test if at least one value is defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.or(x, y)\n *\n * Examples:\n *\n * math.or(2, 4) // returns true\n *\n * a = [2, 5, 0]\n * b = [0, 22, 0]\n * c = 0\n *\n * math.or(a, b) // returns [true, true, false]\n * math.or(b, c) // returns [false, true, false]\n *\n * See also:\n *\n * and, not, xor\n *\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when one of the inputs is defined with a nonzero/nonempty value.\n */\n return typed(\n name,\n {\n 'number, number': orNumber,\n\n 'Complex, Complex': function (x, y) {\n return (x.re !== 0 || x.im !== 0) || (y.re !== 0 || y.im !== 0)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return (!x.isZero() && !x.isNaN()) || (!y.isZero() && !y.isNaN())\n },\n\n 'bigint, bigint': orNumber,\n\n 'Unit, Unit': typed.referToSelf(self =>\n (x, y) => self(x.value || 0, y.value || 0))\n },\n matrixAlgorithmSuite({\n SS: matAlgo05xSfSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n","import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { xorNumber } from '../../plain/number/index.js'\n\nconst name = 'xor'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createXor = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Logical `xor`. Test whether one and only one value is defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.xor(x, y)\n *\n * Examples:\n *\n * math.xor(2, 4) // returns false\n *\n * a = [2, 0, 0]\n * b = [2, 7, 0]\n * c = 0\n *\n * math.xor(a, b) // returns [false, true, false]\n * math.xor(a, c) // returns [true, false, false]\n *\n * See also:\n *\n * and, not, or\n *\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when one and only one input is defined with a nonzero/nonempty value.\n */\n return typed(\n name,\n {\n 'number, number': xorNumber,\n\n 'Complex, Complex': function (x, y) {\n return ((x.re !== 0 || x.im !== 0) !== (y.re !== 0 || y.im !== 0))\n },\n\n 'bigint, bigint': xorNumber,\n\n 'BigNumber, BigNumber': function (x, y) {\n return ((!x.isZero() && !x.isNaN()) !== (!y.isZero() && !y.isNaN()))\n },\n\n 'Unit, Unit': typed.referToSelf(self =>\n (x, y) => self(x.value || 0, y.value || 0))\n },\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n","import { isBigNumber, isMatrix, isNumber } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { arraySize, concat as _concat } from '../../utils/array.js'\nimport { IndexError } from '../../error/IndexError.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'concat'\nconst dependencies = ['typed', 'matrix', 'isInteger']\n\nexport const createConcat = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isInteger }) => {\n /**\n * Concatenate two or more matrices.\n *\n * Syntax:\n *\n * math.concat(A, B, C, ...)\n * math.concat(A, B, C, ..., dim)\n *\n * Where:\n *\n * - `dim: number` is a zero-based dimension over which to concatenate the matrices.\n * By default the last dimension of the matrices.\n *\n * Examples:\n *\n * const A = [[1, 2], [5, 6]]\n * const B = [[3, 4], [7, 8]]\n *\n * math.concat(A, B) // returns [[1, 2, 3, 4], [5, 6, 7, 8]]\n * math.concat(A, B, 0) // returns [[1, 2], [5, 6], [3, 4], [7, 8]]\n * math.concat('hello', ' ', 'world') // returns 'hello world'\n *\n * See also:\n *\n * size, squeeze, subset, transpose\n *\n * @param {... Array | Matrix} args Two or more matrices\n * @return {Array | Matrix} Concatenated matrix\n */\n return typed(name, {\n // TODO: change signature to '...Array | Matrix, dim?' when supported\n '...Array | Matrix | number | BigNumber': function (args) {\n let i\n const len = args.length\n let dim = -1 // zero-based dimension\n let prevDim\n let asMatrix = false\n const matrices = [] // contains multi dimensional arrays\n\n for (i = 0; i < len; i++) {\n const arg = args[i]\n\n // test whether we need to return a Matrix (if not we return an Array)\n if (isMatrix(arg)) {\n asMatrix = true\n }\n\n if (isNumber(arg) || isBigNumber(arg)) {\n if (i !== len - 1) {\n throw new Error('Dimension must be specified as last argument')\n }\n\n // last argument contains the dimension on which to concatenate\n prevDim = dim\n dim = arg.valueOf() // change BigNumber to number\n\n if (!isInteger(dim)) {\n throw new TypeError('Integer number expected for dimension')\n }\n\n if (dim < 0 || (i > 0 && dim > prevDim)) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new IndexError(dim, prevDim + 1)\n }\n } else {\n // this is a matrix or array\n const m = clone(arg).valueOf()\n const size = arraySize(m)\n matrices[i] = m\n prevDim = dim\n dim = size.length - 1\n\n // verify whether each of the matrices has the same number of dimensions\n if (i > 0 && dim !== prevDim) {\n throw new DimensionError(prevDim + 1, dim + 1)\n }\n }\n }\n\n if (matrices.length === 0) {\n throw new SyntaxError('At least one matrix expected')\n }\n\n let res = matrices.shift()\n while (matrices.length) {\n res = _concat(res, matrices.shift(), dim)\n }\n\n return asMatrix ? matrix(res) : res\n },\n\n '...string': function (args) {\n return args.join('')\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { validateIndex } from '../../utils/array.js'\n\nconst name = 'column'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\nexport const createColumn = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n /**\n * Return a column from a Matrix.\n *\n * Syntax:\n *\n * math.column(value, index)\n *\n * Example:\n *\n * // get a column\n * const d = [[1, 2], [3, 4]]\n * math.column(d, 1) // returns [[2], [4]]\n *\n * See also:\n *\n * row\n *\n * @param {Array | Matrix } value An array or matrix\n * @param {number} column The index of the column\n * @return {Array | Matrix} The retrieved column\n */\n return typed(name, {\n 'Matrix, number': _column,\n\n 'Array, number': function (value, column) {\n return _column(matrix(clone(value)), column).valueOf()\n }\n })\n\n /**\n * Retrieve a column of a matrix\n * @param {Matrix } value A matrix\n * @param {number} column The index of the column\n * @return {Matrix} The retrieved column\n */\n function _column (value, column) {\n // check dimensions\n if (value.size().length !== 2) {\n throw new Error('Only two dimensional matrix is supported')\n }\n\n validateIndex(column, value.size()[1])\n\n const rowRange = range(0, value.size()[0])\n const index = new Index(rowRange, column)\n const result = value.subset(index)\n return isMatrix(result)\n ? result\n : matrix([[result]])\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'count'\nconst dependencies = ['typed', 'size', 'prod']\n\nexport const createCount = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, prod }) => {\n /**\n * Count the number of elements of a matrix, array or string.\n *\n * Syntax:\n *\n * math.count(x)\n *\n * Examples:\n *\n * math.count('hello world') // returns 11\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.count(A) // returns 6\n * math.count(math.range(1,6)) // returns 5\n *\n * See also:\n *\n * size\n *\n * @param {string | Array | Matrix} x A matrix or string\n * @return {number} An integer with the elements in `x`.\n */\n return typed(name, {\n string: function (x) {\n return x.length\n },\n\n 'Matrix | Array': function (x) {\n return prod(size(x))\n }\n })\n})\n","import { arraySize, squeeze } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'cross'\nconst dependencies = ['typed', 'matrix', 'subtract', 'multiply']\n\nexport const createCross = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, multiply }) => {\n /**\n * Calculate the cross product for two vectors in three dimensional space.\n * The cross product of `A = [a1, a2, a3]` and `B = [b1, b2, b3]` is defined\n * as:\n *\n * cross(A, B) = [\n * a2 * b3 - a3 * b2,\n * a3 * b1 - a1 * b3,\n * a1 * b2 - a2 * b1\n * ]\n *\n * If one of the input vectors has a dimension greater than 1, the output\n * vector will be a 1x3 (2-dimensional) matrix.\n *\n * Syntax:\n *\n * math.cross(x, y)\n *\n * Examples:\n *\n * math.cross([1, 1, 0], [0, 1, 1]) // Returns [1, -1, 1]\n * math.cross([3, -3, 1], [4, 9, 2]) // Returns [-15, -2, 39]\n * math.cross([2, 3, 4], [5, 6, 7]) // Returns [-3, 6, -3]\n * math.cross([[1, 2, 3]], [[4], [5], [6]]) // Returns [[-3, 6, -3]]\n *\n * See also:\n *\n * dot, multiply\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {Array | Matrix} Returns the cross product of `x` and `y`\n */\n return typed(name, {\n 'Matrix, Matrix': function (x, y) {\n return matrix(_cross(x.toArray(), y.toArray()))\n },\n\n 'Matrix, Array': function (x, y) {\n return matrix(_cross(x.toArray(), y))\n },\n\n 'Array, Matrix': function (x, y) {\n return matrix(_cross(x, y.toArray()))\n },\n\n 'Array, Array': _cross\n })\n\n /**\n * Calculate the cross product for two arrays\n * @param {Array} x First vector\n * @param {Array} y Second vector\n * @returns {Array} Returns the cross product of x and y\n * @private\n */\n function _cross (x, y) {\n const highestDimension = Math.max(arraySize(x).length, arraySize(y).length)\n\n x = squeeze(x)\n y = squeeze(y)\n\n const xSize = arraySize(x)\n const ySize = arraySize(y)\n\n if (xSize.length !== 1 || ySize.length !== 1 || xSize[0] !== 3 || ySize[0] !== 3) {\n throw new RangeError('Vectors with length 3 expected ' +\n '(Size A = [' + xSize.join(', ') + '], B = [' + ySize.join(', ') + '])')\n }\n\n const product = [\n subtract(multiply(x[1], y[2]), multiply(x[2], y[1])),\n subtract(multiply(x[2], y[0]), multiply(x[0], y[2])),\n subtract(multiply(x[0], y[1]), multiply(x[1], y[0]))\n ]\n\n if (highestDimension > 1) {\n return [product]\n } else {\n return product\n }\n }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'diag'\nconst dependencies = ['typed', 'matrix', 'DenseMatrix', 'SparseMatrix']\n\nexport const createDiag = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, SparseMatrix }) => {\n /**\n * Create a diagonal matrix or retrieve the diagonal of a matrix\n *\n * When `x` is a vector, a matrix with vector `x` on the diagonal will be returned.\n * When `x` is a two dimensional matrix, the matrixes `k`th diagonal will be returned as vector.\n * When k is positive, the values are placed on the super diagonal.\n * When k is negative, the values are placed on the sub diagonal.\n *\n * Syntax:\n *\n * math.diag(X)\n * math.diag(X, format)\n * math.diag(X, k)\n * math.diag(X, k, format)\n *\n * Examples:\n *\n * // create a diagonal matrix\n * math.diag([1, 2, 3]) // returns [[1, 0, 0], [0, 2, 0], [0, 0, 3]]\n * math.diag([1, 2, 3], 1) // returns [[0, 1, 0, 0], [0, 0, 2, 0], [0, 0, 0, 3]]\n * math.diag([1, 2, 3], -1) // returns [[0, 0, 0], [1, 0, 0], [0, 2, 0], [0, 0, 3]]\n *\n * // retrieve the diagonal from a matrix\n * const a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]\n * math.diag(a) // returns [1, 5, 9]\n *\n * See also:\n *\n * ones, zeros, identity\n *\n * @param {Matrix | Array} x A two dimensional matrix or a vector\n * @param {number | BigNumber} [k=0] The diagonal where the vector will be filled\n * in or retrieved.\n * @param {string} [format='dense'] The matrix storage format.\n *\n * @returns {Matrix | Array} Diagonal matrix from input vector, or diagonal from input matrix.\n */\n return typed(name, {\n // FIXME: simplify this huge amount of signatures as soon as typed-function supports optional arguments\n\n Array: function (x) {\n return _diag(x, 0, arraySize(x), null)\n },\n\n 'Array, number': function (x, k) {\n return _diag(x, k, arraySize(x), null)\n },\n\n 'Array, BigNumber': function (x, k) {\n return _diag(x, k.toNumber(), arraySize(x), null)\n },\n\n 'Array, string': function (x, format) {\n return _diag(x, 0, arraySize(x), format)\n },\n\n 'Array, number, string': function (x, k, format) {\n return _diag(x, k, arraySize(x), format)\n },\n\n 'Array, BigNumber, string': function (x, k, format) {\n return _diag(x, k.toNumber(), arraySize(x), format)\n },\n\n Matrix: function (x) {\n return _diag(x, 0, x.size(), x.storage())\n },\n\n 'Matrix, number': function (x, k) {\n return _diag(x, k, x.size(), x.storage())\n },\n\n 'Matrix, BigNumber': function (x, k) {\n return _diag(x, k.toNumber(), x.size(), x.storage())\n },\n\n 'Matrix, string': function (x, format) {\n return _diag(x, 0, x.size(), format)\n },\n\n 'Matrix, number, string': function (x, k, format) {\n return _diag(x, k, x.size(), format)\n },\n\n 'Matrix, BigNumber, string': function (x, k, format) {\n return _diag(x, k.toNumber(), x.size(), format)\n }\n })\n\n /**\n * Creeate diagonal matrix from a vector or vice versa\n * @param {Array | Matrix} x\n * @param {number} k\n * @param {string} format Storage format for matrix. If null,\n * an Array is returned\n * @returns {Array | Matrix}\n * @private\n */\n function _diag (x, k, size, format) {\n if (!isInteger(k)) {\n throw new TypeError('Second parameter in function diag must be an integer')\n }\n\n const kSuper = k > 0 ? k : 0\n const kSub = k < 0 ? -k : 0\n\n // check dimensions\n switch (size.length) {\n case 1:\n return _createDiagonalMatrix(x, k, format, size[0], kSub, kSuper)\n case 2:\n return _getDiagonal(x, k, format, size, kSub, kSuper)\n }\n throw new RangeError('Matrix for function diag must be 2 dimensional')\n }\n\n function _createDiagonalMatrix (x, k, format, l, kSub, kSuper) {\n // matrix size\n const ms = [l + kSub, l + kSuper]\n\n if (format && format !== 'sparse' && format !== 'dense') {\n throw new TypeError(`Unknown matrix type ${format}\"`)\n }\n\n // create diagonal matrix\n const m = format === 'sparse'\n ? SparseMatrix.diagonal(ms, x, k)\n : DenseMatrix.diagonal(ms, x, k)\n // check we need to return a matrix\n return format !== null ? m : m.valueOf()\n }\n\n function _getDiagonal (x, k, format, s, kSub, kSuper) {\n // check x is a Matrix\n if (isMatrix(x)) {\n // get diagonal matrix\n const dm = x.diagonal(k)\n // check we need to return a matrix\n if (format !== null) {\n // check we need to change matrix format\n if (format !== dm.storage()) { return matrix(dm, format) }\n return dm\n }\n return dm.valueOf()\n }\n // vector size\n const n = Math.min(s[0] - kSub, s[1] - kSuper)\n // diagonal values\n const vector = []\n // loop diagonal\n for (let i = 0; i < n; i++) {\n vector[i] = x[i + kSub][i + kSuper]\n }\n // check we need to return a matrix\n return format !== null ? matrix(vector) : vector\n }\n})\n","import { optimizeCallback } from '../../utils/optimizeCallback.js'\nimport { filter, filterRegExp } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'filter'\nconst dependencies = ['typed']\n\nexport const createFilter = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Filter the items in an array or one dimensional matrix.\n *\n * Syntax:\n *\n * math.filter(x, test)\n *\n * Examples:\n *\n * function isPositive (x) {\n * return x > 0\n * }\n * math.filter([6, -2, -1, 4, 3], isPositive) // returns [6, 4, 3]\n *\n * math.filter([\"23\", \"foo\", \"100\", \"55\", \"bar\"], /[0-9]+/) // returns [\"23\", \"100\", \"55\"]\n *\n * See also:\n *\n * forEach, map, sort\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to filter\n * @param {Function | RegExp} test\n * A function or regular expression to test items.\n * All entries for which `test` returns true are returned.\n * When `test` is a function, it is invoked with three parameters:\n * the value of the element, the index of the element, and the\n * matrix/array being traversed. The function must return a boolean.\n * @return {Matrix | Array} Returns the filtered matrix.\n */\n return typed('filter', {\n 'Array, function': _filterCallback,\n\n 'Matrix, function': function (x, test) {\n return x.create(_filterCallback(x.valueOf(), test), x.datatype())\n },\n\n 'Array, RegExp': filterRegExp,\n\n 'Matrix, RegExp': function (x, test) {\n return x.create(filterRegExp(x.valueOf(), test), x.datatype())\n }\n })\n})\n\n/**\n * Filter values in a callback given a callback function\n * @param {Array} x\n * @param {Function} callback\n * @return {Array} Returns the filtered array\n * @private\n */\nfunction _filterCallback (x, callback) {\n const fastCallback = optimizeCallback(callback, x, 'filter')\n return filter(x, function (value, index, array) {\n // invoke the callback function with the right number of arguments\n return fastCallback(value, [index], array)\n })\n}\n","import { flatten as flattenArray } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'flatten'\nconst dependencies = ['typed']\n\nexport const createFlatten = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Flatten a multidimensional matrix into a single dimensional matrix.\n * A new matrix is returned, the original matrix is left untouched.\n *\n * Syntax:\n *\n * math.flatten(x)\n *\n * Examples:\n *\n * math.flatten([[1,2], [3,4]]) // returns [1, 2, 3, 4]\n *\n * See also:\n *\n * concat, resize, size, squeeze\n *\n * @param {Matrix | Array} x Matrix to be flattened\n * @return {Matrix | Array} Returns the flattened matrix\n */\n return typed(name, {\n Array: function (x) {\n return flattenArray(x)\n },\n\n Matrix: function (x) {\n // Return the same matrix type as x (Dense or Sparse Matrix)\n // Return the same data type as x\n return x.create(flattenArray(x.toArray()), x.datatype())\n }\n })\n})\n","import { optimizeCallback } from '../../utils/optimizeCallback.js'\nimport { factory } from '../../utils/factory.js'\nimport { recurse } from '../../utils/array.js'\n\nconst name = 'forEach'\nconst dependencies = ['typed']\n\nexport const createForEach = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Iterate over all elements of a matrix/array, and executes the given callback function.\n *\n * Syntax:\n *\n * math.forEach(x, callback)\n *\n * Examples:\n *\n * math.forEach([1, 2, 3], function(value) {\n * console.log(value)\n * })\n * // outputs 1, 2, 3\n *\n * See also:\n *\n * filter, map, sort\n *\n * @param {Matrix | Array} x The matrix to iterate on.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix/array being traversed.\n */\n return typed(name, {\n 'Array, function': _forEach,\n\n 'Matrix, function': function (x, callback) {\n x.forEach(callback)\n }\n })\n})\n\n/**\n * forEach for a multidimensional array\n * @param {Array} array\n * @param {Function} callback\n * @private\n */\nfunction _forEach (array, callback) {\n recurse(array, [], array, optimizeCallback(callback, array, name))\n}\n","import { factory } from '../../utils/factory.js'\nimport { getArrayDataType } from '../../utils/array.js'\nimport { typeOf } from '../../utils/is.js'\n\nconst name = 'getMatrixDataType'\nconst dependencies = ['typed']\n\nexport const createGetMatrixDataType = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Find the data type of all elements in a matrix or array,\n * for example 'number' if all items are a number and 'Complex' if all values\n * are complex numbers.\n * If a matrix contains more than one data type, it will return 'mixed'.\n *\n * Syntax:\n *\n * math.getMatrixDataType(x)\n *\n * Examples:\n *\n * const x = [ [1, 2, 3], [4, 5, 6] ]\n * const mixedX = [ [1, true], [2, 3] ]\n * const fractionX = [ [math.fraction(1, 3)], [math.fraction(1, 3)] ]\n * const unitX = [ [math.unit('5cm')], [math.unit('5cm')] ]\n * const bigNumberX = [ [math.bignumber(1)], [math.bignumber(0)] ]\n * const sparse = math.sparse(x)\n * const dense = math.matrix(x)\n * math.getMatrixDataType(x) // returns 'number'\n * math.getMatrixDataType(sparse) // returns 'number'\n * math.getMatrixDataType(dense) // returns 'number'\n * math.getMatrixDataType(mixedX) // returns 'mixed'\n * math.getMatrixDataType(fractionX) // returns 'Fraction'\n * math.getMatrixDataType(unitX) // returns 'Unit'\n * math.getMatrixDataType(bigNumberX) // return 'BigNumber'\n *\n * See also:\n * SparseMatrix, DenseMatrix\n *\n * @param {...Matrix | Array} x The Matrix with values.\n *\n * @return {string} A string representation of the matrix type\n */\n return typed(name, {\n Array: function (x) {\n return getArrayDataType(x, typeOf)\n },\n Matrix: function (x) {\n return x.getDataType()\n }\n })\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { resize } from '../../utils/array.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'identity'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'BigNumber',\n 'DenseMatrix',\n 'SparseMatrix'\n]\n\nexport const createIdentity = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber, DenseMatrix, SparseMatrix }) => {\n /**\n * Create a 2-dimensional identity matrix with size m x n or n x n.\n * The matrix has ones on the diagonal and zeros elsewhere.\n *\n * Syntax:\n *\n * math.identity(n)\n * math.identity(n, format)\n * math.identity(m, n)\n * math.identity(m, n, format)\n * math.identity([m, n])\n * math.identity([m, n], format)\n *\n * Examples:\n *\n * math.identity(3) // returns [[1, 0, 0], [0, 1, 0], [0, 0, 1]]\n * math.identity(3, 2) // returns [[1, 0], [0, 1], [0, 0]]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.identity(math.size(A)) // returns [[1, 0, 0], [0, 1, 0]]\n *\n * See also:\n *\n * diag, ones, zeros, size, range\n *\n * @param {...number | Matrix | Array} size The size for the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Matrix | Array | number} A matrix with ones on the diagonal.\n */\n return typed(name, {\n '': function () {\n return (config.matrix === 'Matrix') ? matrix([]) : []\n },\n\n string: function (format) {\n return matrix(format)\n },\n\n 'number | BigNumber': function (rows) {\n return _identity(rows, rows, config.matrix === 'Matrix' ? 'dense' : undefined)\n },\n\n 'number | BigNumber, string': function (rows, format) {\n return _identity(rows, rows, format)\n },\n\n 'number | BigNumber, number | BigNumber': function (rows, cols) {\n return _identity(rows, cols, config.matrix === 'Matrix' ? 'dense' : undefined)\n },\n\n 'number | BigNumber, number | BigNumber, string': function (rows, cols, format) {\n return _identity(rows, cols, format)\n },\n\n Array: function (size) {\n return _identityVector(size)\n },\n\n 'Array, string': function (size, format) {\n return _identityVector(size, format)\n },\n\n Matrix: function (size) {\n return _identityVector(size.valueOf(), size.storage())\n },\n\n 'Matrix, string': function (size, format) {\n return _identityVector(size.valueOf(), format)\n }\n })\n\n function _identityVector (size, format) {\n switch (size.length) {\n case 0: return format ? matrix(format) : []\n case 1: return _identity(size[0], size[0], format)\n case 2: return _identity(size[0], size[1], format)\n default: throw new Error('Vector containing two values expected')\n }\n }\n\n /**\n * Create an identity matrix\n * @param {number | BigNumber} rows\n * @param {number | BigNumber} cols\n * @param {string} [format]\n * @returns {Matrix}\n * @private\n */\n function _identity (rows, cols, format) {\n // BigNumber constructor with the right precision\n const Big = (isBigNumber(rows) || isBigNumber(cols))\n ? BigNumber\n : null\n\n if (isBigNumber(rows)) rows = rows.toNumber()\n if (isBigNumber(cols)) cols = cols.toNumber()\n\n if (!isInteger(rows) || rows < 1) {\n throw new Error('Parameters in function identity must be positive integers')\n }\n if (!isInteger(cols) || cols < 1) {\n throw new Error('Parameters in function identity must be positive integers')\n }\n\n const one = Big ? new BigNumber(1) : 1\n const defaultValue = Big ? new Big(0) : 0\n const size = [rows, cols]\n\n // check we need to return a matrix\n if (format) {\n // create diagonal matrix (use optimized implementation for storage format)\n if (format === 'sparse') {\n return SparseMatrix.diagonal(size, one, 0, defaultValue)\n }\n if (format === 'dense') {\n return DenseMatrix.diagonal(size, one, 0, defaultValue)\n }\n throw new TypeError(`Unknown matrix type \"${format}\"`)\n }\n\n // create and resize array\n const res = resize([], size, defaultValue)\n // fill in ones on the diagonal\n const minimum = rows < cols ? rows : cols\n // fill diagonal\n for (let d = 0; d < minimum; d++) {\n res[d][d] = one\n }\n return res\n }\n})\n","import { arraySize as size } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'kron'\nconst dependencies = ['typed', 'matrix', 'multiplyScalar']\n\nexport const createKron = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, multiplyScalar }) => {\n /**\n * Calculates the Kronecker product of 2 matrices or vectors.\n *\n * NOTE: If a one dimensional vector / matrix is given, it will be\n * wrapped so its two dimensions.\n * See the examples.\n *\n * Syntax:\n *\n * math.kron(x, y)\n *\n * Examples:\n *\n * math.kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])\n * // returns [ [ 1, 2, 0, 0 ], [ 3, 4, 0, 0 ], [ 0, 0, 1, 2 ], [ 0, 0, 3, 4 ] ]\n *\n * math.kron([1,1], [2,3,4])\n * // returns [ [ 2, 3, 4, 2, 3, 4 ] ]\n *\n * See also:\n *\n * multiply, dot, cross\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {Array | Matrix} Returns the Kronecker product of `x` and `y`\n */\n return typed(name, {\n 'Matrix, Matrix': function (x, y) {\n return matrix(_kron(x.toArray(), y.toArray()))\n },\n\n 'Matrix, Array': function (x, y) {\n return matrix(_kron(x.toArray(), y))\n },\n\n 'Array, Matrix': function (x, y) {\n return matrix(_kron(x, y.toArray()))\n },\n\n 'Array, Array': _kron\n })\n\n /**\n * Calculate the Kronecker product of two matrices / vectors\n * @param {Array} a First vector\n * @param {Array} b Second vector\n * @returns {Array} Returns the Kronecker product of x and y\n * @private\n */\n function _kron (a, b) {\n // Deal with the dimensions of the matricies.\n if (size(a).length === 1) {\n // Wrap it in a 2D Matrix\n a = [a]\n }\n if (size(b).length === 1) {\n // Wrap it in a 2D Matrix\n b = [b]\n }\n if (size(a).length > 2 || size(b).length > 2) {\n throw new RangeError('Vectors with dimensions greater then 2 are not supported expected ' +\n '(Size x = ' + JSON.stringify(a.length) + ', y = ' + JSON.stringify(b.length) + ')')\n }\n const t = []\n let r = []\n\n return a.map(function (a) {\n return b.map(function (b) {\n r = []\n t.push(r)\n return a.map(function (y) {\n return b.map(function (x) {\n return r.push(multiplyScalar(y, x))\n })\n })\n })\n }) && t\n }\n})\n","import { optimizeCallback } from '../../utils/optimizeCallback.js'\nimport { arraySize, broadcastSizes, broadcastTo, get, recurse } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'map'\nconst dependencies = ['typed']\n\nexport const createMap = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Create a new matrix or array with the results of a callback function executed on\n * each entry of a given matrix/array.\n *\n * For each entry of the input,\n *\n * the callback is invoked with 2N + 1 arguments:\n * the N values of the entry, the index at which that entry occurs, and the N full\n * broadcasted matrix/array being traversed where N is the number of matrices being traversed.\n * Note that because the matrix/array might be\n * multidimensional, the \"index\" argument is always an array of numbers giving\n * the index in each dimension. This is true even for vectors: the \"index\"\n * argument is an array of length 1, rather than simply a number.\n *\n * Syntax:\n *\n * math.map(x, callback)\n * math.map(x, y, ..., callback)\n *\n * Examples:\n *\n * math.map([1, 2, 3], function(value) {\n * return value * value\n * }) // returns [1, 4, 9]\n * math.map([1, 2], [3, 4], function(a, b) {\n * return a + b\n * }) // returns [4, 6]\n *\n * // The callback is normally called with three arguments:\n * // callback(value, index, Array)\n * // If you want to call with only one argument, use:\n * math.map([1, 2, 3], x => math.format(x)) // returns ['1', '2', '3']\n * // It can also be called with 2N + 1 arguments: for N arrays\n * // callback(value1, value2, index, BroadcastedArray1, BroadcastedArray2)\n *\n * See also:\n *\n * filter, forEach, sort\n *\n * @param {Matrix | Array} x The input to iterate on.\n * @param {Function} callback\n * The function to call (as described above) on each entry of the input\n * @return {Matrix | array}\n * Transformed map of x; always has the same type and shape as x\n */\n return typed(name, {\n 'Array, function': _mapArray,\n\n 'Matrix, function': function (x, callback) {\n return x.map(callback)\n },\n\n 'Array|Matrix, Array|Matrix, ...Array|Matrix|function': (A, B, rest) =>\n _mapMultiple([A, B, ...rest.slice(0, rest.length - 1)], rest[rest.length - 1])\n })\n\n /**\n * Maps over multiple arrays or matrices.\n *\n * @param {Array} Arrays - An array of arrays or matrices to map over.\n * @param {function} multiCallback - The callback function to apply to each element.\n * @throws {Error} If the last argument is not a callback function.\n * @returns {Array|Matrix} A new array or matrix with each element being the result of the callback function.\n *\n * @example\n * _mapMultiple([[1, 2, 3], [4, 5, 6]], (a, b) => a + b); // Returns [5, 7, 9]\n */\n function _mapMultiple (Arrays, multiCallback) {\n if (typeof multiCallback !== 'function') {\n throw new Error('Last argument must be a callback function')\n }\n\n const firstArrayIsMatrix = Arrays[0].isMatrix\n\n const newSize = broadcastSizes(...Arrays.map(M => M.isMatrix ? M.size() : arraySize(M)))\n\n const _get = firstArrayIsMatrix\n ? (matrix, idx) => matrix.get(idx)\n : get\n\n const broadcastedArrays = firstArrayIsMatrix\n ? Arrays.map(M => M.isMatrix\n ? M.create(broadcastTo(M.toArray(), newSize), M.datatype())\n : Arrays[0].create(broadcastTo(M.valueOf(), newSize)))\n : Arrays.map(M => M.isMatrix\n ? broadcastTo(M.toArray(), newSize)\n : broadcastTo(M, newSize))\n\n let callback\n\n if (typed.isTypedFunction(multiCallback)) {\n const firstIndex = newSize.map(() => 0)\n const firstValues = broadcastedArrays.map(array => _get(array, firstIndex))\n const callbackCase = _getTypedCallbackCase(multiCallback, firstValues, firstIndex, broadcastedArrays)\n callback = _getLimitedCallback(callbackCase)\n } else {\n const numberOfArrays = Arrays.length\n const callbackCase = _getCallbackCase(multiCallback, numberOfArrays)\n callback = _getLimitedCallback(callbackCase)\n }\n\n const broadcastedArraysCallback = (x, idx) =>\n callback(\n [x, ...broadcastedArrays.slice(1).map(Array => _get(Array, idx))],\n idx)\n\n if (firstArrayIsMatrix) {\n return broadcastedArrays[0].map(broadcastedArraysCallback)\n } else {\n return _mapArray(broadcastedArrays[0], broadcastedArraysCallback)\n }\n\n function _getLimitedCallback (callbackCase) {\n switch (callbackCase) {\n case 0:\n return x => multiCallback(...x)\n case 1:\n return (x, idx) => multiCallback(...x, idx)\n case 2:\n return (x, idx) => multiCallback(...x, idx, ...broadcastedArrays)\n }\n }\n\n function _getCallbackCase (callback, numberOfArrays) {\n if (callback.length > numberOfArrays + 1) { return 2 }\n if (callback.length === numberOfArrays + 1) { return 1 }\n return 0\n }\n\n function _getTypedCallbackCase (callback, values, idx, arrays) {\n if (typed.resolve(callback, [...values, idx, ...arrays]) !== null) { return 2 }\n if (typed.resolve(callback, [...values, idx]) !== null) { return 1 }\n if (typed.resolve(callback, values) !== null) { return 0 }\n // this should never happen\n return 0\n }\n }\n /**\n * Map for a multi dimensional array\n * @param {Array} array\n * @param {Function} callback\n * @return {Array}\n * @private\n */\n function _mapArray (array, callback) {\n return recurse(array, [], array, optimizeCallback(callback, array, name))\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'diff'\nconst dependencies = ['typed', 'matrix', 'subtract', 'number']\n\nexport const createDiff = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, number }) => {\n /**\n * Create a new matrix or array of the difference between elements of the given array\n * The optional dim parameter lets you specify the dimension to evaluate the difference of\n * If no dimension parameter is passed it is assumed as dimension 0\n *\n * Dimension is zero-based in javascript and one-based in the parser and can be a number or bignumber\n * Arrays must be 'rectangular' meaning arrays like [1, 2]\n * If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays\n *\n * Syntax:\n *\n * math.diff(arr)\n * math.diff(arr, dim)\n *\n * Examples:\n *\n * const arr = [1, 2, 4, 7, 0]\n * math.diff(arr) // returns [1, 2, 3, -7] (no dimension passed so 0 is assumed)\n * math.diff(math.matrix(arr)) // returns Matrix [1, 2, 3, -7]\n *\n * const arr = [[1, 2, 3, 4, 5], [1, 2, 3, 4, 5], [9, 8, 7, 6, 4]]\n * math.diff(arr) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]]\n * math.diff(arr, 0) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]]\n * math.diff(arr, 1) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]]\n * math.diff(arr, math.bignumber(1)) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]]\n *\n * math.diff(arr, 2) // throws RangeError as arr is 2 dimensional not 3\n * math.diff(arr, -1) // throws RangeError as negative dimensions are not allowed\n *\n * // These will all produce the same result\n * math.diff([[1, 2], [3, 4]])\n * math.diff([math.matrix([1, 2]), math.matrix([3, 4])])\n * math.diff([[1, 2], math.matrix([3, 4])])\n * math.diff([math.matrix([1, 2]), [3, 4]])\n * // They do not produce the same result as math.diff(math.matrix([[1, 2], [3, 4]])) as this returns a matrix\n *\n * See Also:\n *\n * sum\n * subtract\n * partitionSelect\n *\n * @param {Array | Matrix} arr An array or matrix\n * @param {number | BigNumber} dim Dimension\n * @return {Array | Matrix} Difference between array elements in given dimension\n */\n return typed(name, {\n 'Array | Matrix': function (arr) { // No dimension specified => assume dimension 0\n if (isMatrix(arr)) {\n return matrix(_diff(arr.toArray()))\n } else {\n return _diff(arr)\n }\n },\n 'Array | Matrix, number': function (arr, dim) {\n if (!isInteger(dim)) throw new RangeError('Dimension must be a whole number')\n if (isMatrix(arr)) {\n return matrix(_recursive(arr.toArray(), dim))\n } else {\n return _recursive(arr, dim)\n }\n },\n 'Array, BigNumber': typed.referTo('Array,number', selfAn =>\n (arr, dim) => selfAn(arr, number(dim))),\n 'Matrix, BigNumber': typed.referTo('Matrix,number', selfMn =>\n (arr, dim) => selfMn(arr, number(dim)))\n })\n\n /**\n * Recursively find the correct dimension in the array/matrix\n * Then Apply _diff to that dimension\n *\n * @param {Array} arr The array\n * @param {number} dim Dimension\n * @return {Array} resulting array\n */\n function _recursive (arr, dim) {\n if (isMatrix(arr)) {\n arr = arr.toArray() // Makes sure arrays like [ matrix([0, 1]), matrix([1, 0]) ] are processed properly\n }\n if (!Array.isArray(arr)) {\n throw RangeError('Array/Matrix does not have that many dimensions')\n }\n if (dim > 0) {\n const result = []\n arr.forEach(element => {\n result.push(_recursive(element, dim - 1))\n })\n return result\n } else if (dim === 0) {\n return _diff(arr)\n } else {\n throw RangeError('Cannot have negative dimension')\n }\n }\n\n /**\n * Difference between elements in the array\n *\n * @param {Array} arr An array\n * @return {Array} resulting array\n */\n function _diff (arr) {\n const result = []\n const size = arr.length\n for (let i = 1; i < size; i++) {\n result.push(_ElementDiff(arr[i - 1], arr[i]))\n }\n return result\n }\n\n /**\n * Difference between 2 objects\n *\n * @param {Object} obj1 First object\n * @param {Object} obj2 Second object\n * @return {Array} resulting array\n */\n function _ElementDiff (obj1, obj2) {\n // Convert matrices to arrays\n if (isMatrix(obj1)) obj1 = obj1.toArray()\n if (isMatrix(obj2)) obj2 = obj2.toArray()\n\n const obj1IsArray = Array.isArray(obj1)\n const obj2IsArray = Array.isArray(obj2)\n if (obj1IsArray && obj2IsArray) {\n return _ArrayDiff(obj1, obj2)\n }\n if (!obj1IsArray && !obj2IsArray) {\n return subtract(obj2, obj1) // Difference is (second - first) NOT (first - second)\n }\n throw TypeError('Cannot calculate difference between 1 array and 1 non-array')\n }\n\n /**\n * Difference of elements in 2 arrays\n *\n * @param {Array} arr1 Array 1\n * @param {Array} arr2 Array 2\n * @return {Array} resulting array\n */\n function _ArrayDiff (arr1, arr2) {\n if (arr1.length !== arr2.length) {\n throw RangeError('Not all sub-arrays have the same length')\n }\n const result = []\n const size = arr1.length\n for (let i = 0; i < size; i++) {\n result.push(_ElementDiff(arr1[i], arr2[i]))\n }\n return result\n }\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { resize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ones'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createOnes = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\n /**\n * Create a matrix filled with ones. The created matrix can have one or\n * multiple dimensions.\n *\n * Syntax:\n *\n * math.ones(m)\n * math.ones(m, format)\n * math.ones(m, n)\n * math.ones(m, n, format)\n * math.ones([m, n])\n * math.ones([m, n], format)\n * math.ones([m, n, p, ...])\n * math.ones([m, n, p, ...], format)\n *\n * Examples:\n *\n * math.ones() // returns []\n * math.ones(3) // returns [1, 1, 1]\n * math.ones(3, 2) // returns [[1, 1], [1, 1], [1, 1]]\n * math.ones(3, 2, 'dense') // returns Dense Matrix [[1, 1], [1, 1], [1, 1]]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.ones(math.size(A)) // returns [[1, 1, 1], [1, 1, 1]]\n *\n * See also:\n *\n * zeros, identity, size, range\n *\n * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Array | Matrix | number} A matrix filled with ones\n */\n return typed('ones', {\n '': function () {\n return (config.matrix === 'Array')\n ? _ones([])\n : _ones([], 'default')\n },\n\n // math.ones(m, n, p, ..., format)\n // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this\n '...number | BigNumber | string': function (size) {\n const last = size[size.length - 1]\n if (typeof last === 'string') {\n const format = size.pop()\n return _ones(size, format)\n } else if (config.matrix === 'Array') {\n return _ones(size)\n } else {\n return _ones(size, 'default')\n }\n },\n\n Array: _ones,\n\n Matrix: function (size) {\n const format = size.storage()\n return _ones(size.valueOf(), format)\n },\n\n 'Array | Matrix, string': function (size, format) {\n return _ones(size.valueOf(), format)\n }\n })\n\n /**\n * Create an Array or Matrix with ones\n * @param {Array} size\n * @param {string} [format='default']\n * @return {Array | Matrix}\n * @private\n */\n function _ones (size, format) {\n const hasBigNumbers = _normalize(size)\n const defaultValue = hasBigNumbers ? new BigNumber(1) : 1\n _validate(size)\n\n if (format) {\n // return a matrix\n const m = matrix(format)\n if (size.length > 0) {\n return m.resize(size, defaultValue)\n }\n return m\n } else {\n // return an Array\n const arr = []\n if (size.length > 0) {\n return resize(arr, size, defaultValue)\n }\n return arr\n }\n }\n\n // replace BigNumbers with numbers, returns true if size contained BigNumbers\n function _normalize (size) {\n let hasBigNumbers = false\n size.forEach(function (value, index, arr) {\n if (isBigNumber(value)) {\n hasBigNumbers = true\n arr[index] = value.toNumber()\n }\n })\n return hasBigNumbers\n }\n\n // validate arguments\n function _validate (size) {\n size.forEach(function (value) {\n if (typeof value !== 'number' || !isInteger(value) || value < 0) {\n throw new Error('Parameters in function ones must be positive integers')\n }\n })\n }\n})\n","export function noBignumber () {\n throw new Error('No \"bignumber\" implementation available')\n}\n\nexport function noFraction () {\n throw new Error('No \"fraction\" implementation available')\n}\n\nexport function noMatrix () {\n throw new Error('No \"matrix\" implementation available')\n}\n\nexport function noIndex () {\n throw new Error('No \"index\" implementation available')\n}\n\nexport function noSubset () {\n throw new Error('No \"matrix\" implementation available')\n}\n","import { factory } from '../../utils/factory.js'\nimport { noBignumber, noMatrix } from '../../utils/noop.js'\n\nconst name = 'range'\nconst dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']\n\nexport const createRange = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive }) => {\n /**\n * Create an array from a range.\n * By default, the range end is excluded. This can be customized by providing\n * an extra parameter `includeEnd`.\n *\n * Syntax:\n *\n * math.range(str [, includeEnd]) // Create a range from a string,\n * // where the string contains the\n * // start, optional step, and end,\n * // separated by a colon.\n * math.range(start, end [, includeEnd]) // Create a range with start and\n * // end and a step size of 1.\n * math.range(start, end, step [, includeEnd]) // Create a range with start, step,\n * // and end.\n *\n * Where:\n *\n * - `str: string`\n * A string 'start:end' or 'start:step:end'\n * - `start: {number | BigNumber | Unit}`\n * Start of the range\n * - `end: number | BigNumber | Unit`\n * End of the range, excluded by default, included when parameter includeEnd=true\n * - `step: number | BigNumber | Unit`\n * Step size. Default value is 1.\n * - `includeEnd: boolean`\n * Option to specify whether to include the end or not. False by default.\n *\n * Examples:\n *\n * math.range(2, 6) // [2, 3, 4, 5]\n * math.range(2, -3, -1) // [2, 1, 0, -1, -2]\n * math.range('2:1:6') // [2, 3, 4, 5]\n * math.range(2, 6, true) // [2, 3, 4, 5, 6]\n * math.range(math.unit(2, 'm'), math.unit(-3, 'm'), math.unit(-1, 'm')) // [2 m, 1 m, 0 m , -1 m, -2 m]\n *\n * See also:\n *\n * ones, zeros, size, subset\n *\n * @param {*} args Parameters describing the ranges `start`, `end`, and optional `step`.\n * @return {Array | Matrix} range\n */\n return typed(name, {\n // TODO: simplify signatures when typed-function supports default values and optional arguments\n\n // TODO: a number or boolean should not be converted to string here\n string: _strRange,\n 'string, boolean': _strRange,\n\n 'number, number': function (start, end) {\n return _out(_range(start, end, 1, false))\n },\n 'number, number, number': function (start, end, step) {\n return _out(_range(start, end, step, false))\n },\n 'number, number, boolean': function (start, end, includeEnd) {\n return _out(_range(start, end, 1, includeEnd))\n },\n 'number, number, number, boolean': function (start, end, step, includeEnd) {\n return _out(_range(start, end, step, includeEnd))\n },\n\n 'BigNumber, BigNumber': function (start, end) {\n const BigNumber = start.constructor\n\n return _out(_range(start, end, new BigNumber(1), false))\n },\n 'BigNumber, BigNumber, BigNumber': function (start, end, step) {\n return _out(_range(start, end, step, false))\n },\n 'BigNumber, BigNumber, boolean': function (start, end, includeEnd) {\n const BigNumber = start.constructor\n\n return _out(_range(start, end, new BigNumber(1), includeEnd))\n },\n 'BigNumber, BigNumber, BigNumber, boolean': function (start, end, step, includeEnd) {\n return _out(_range(start, end, step, includeEnd))\n },\n 'Unit, Unit, Unit': function (start, end, step) {\n return _out(_range(start, end, step, false))\n },\n 'Unit, Unit, Unit, boolean': function (start, end, step, includeEnd) {\n return _out(_range(start, end, step, includeEnd))\n }\n\n })\n\n function _out (arr) {\n if (config.matrix === 'Matrix') {\n return matrix ? matrix(arr) : noMatrix()\n }\n\n return arr\n }\n\n function _strRange (str, includeEnd) {\n const r = _parse(str)\n if (!r) {\n throw new SyntaxError('String \"' + str + '\" is no valid range')\n }\n\n if (config.number === 'BigNumber') {\n if (bignumber === undefined) {\n noBignumber()\n }\n\n return _out(_range(\n bignumber(r.start),\n bignumber(r.end),\n bignumber(r.step)),\n includeEnd)\n } else {\n return _out(_range(r.start, r.end, r.step, includeEnd))\n }\n }\n\n /**\n * Create a range with numbers or BigNumbers\n * @param {number | BigNumber | Unit} start\n * @param {number | BigNumber | Unit} end\n * @param {number | BigNumber | Unit} step\n * @param {boolean} includeEnd\n * @returns {Array} range\n * @private\n */\n function _range (start, end, step, includeEnd) {\n const array = []\n const ongoing = isPositive(step)\n ? includeEnd ? smallerEq : smaller\n : includeEnd ? largerEq : larger\n let x = start\n while (ongoing(x, end)) {\n array.push(x)\n x = add(x, step)\n }\n return array\n }\n\n /**\n * Parse a string into a range,\n * The string contains the start, optional step, and end, separated by a colon.\n * If the string does not contain a valid range, null is returned.\n * For example str='0:2:11'.\n * @param {string} str\n * @return {{start: number, end: number, step: number} | null} range Object containing properties start, end, step\n * @private\n */\n function _parse (str) {\n const args = str.split(':')\n\n // number\n const nums = args.map(function (arg) {\n // use Number and not parseFloat as Number returns NaN on invalid garbage in the string\n return Number(arg)\n })\n\n const invalid = nums.some(function (num) {\n return isNaN(num)\n })\n if (invalid) {\n return null\n }\n\n switch (nums.length) {\n case 2:\n return {\n start: nums[0],\n end: nums[1],\n step: 1\n }\n\n case 3:\n return {\n start: nums[0],\n end: nums[2],\n step: nums[1]\n }\n\n default:\n return null\n }\n }\n})\n","import { reshape as arrayReshape } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'reshape'\nconst dependencies = ['typed', 'isInteger', 'matrix']\n\nexport const createReshape = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\n /**\n * Reshape a multi dimensional array to fit the specified dimensions\n *\n * Syntax:\n *\n * math.reshape(x, sizes)\n *\n * Examples:\n *\n * math.reshape([1, 2, 3, 4, 5, 6], [2, 3])\n * // returns Array [[1, 2, 3], [4, 5, 6]]\n *\n * math.reshape([[1, 2], [3, 4]], [1, 4])\n * // returns Array [[1, 2, 3, 4]]\n *\n * math.reshape([[1, 2], [3, 4]], [4])\n * // returns Array [1, 2, 3, 4]\n *\n * const x = math.matrix([1, 2, 3, 4, 5, 6, 7, 8])\n * math.reshape(x, [2, 2, 2])\n * // returns Matrix [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]\n *\n * math.reshape([1, 2, 3, 4], [-1, 2])\n * // returns Matrix [[1, 2], [3, 4]]\n *\n * See also:\n *\n * size, squeeze, resize\n *\n * @param {Array | Matrix | *} x Matrix to be reshaped\n * @param {number[]} sizes One dimensional array with integral sizes for\n * each dimension. One -1 is allowed as wildcard,\n * which calculates this dimension automatically.\n *\n * @return {* | Array | Matrix} A reshaped clone of matrix `x`\n *\n * @throws {TypeError} If `sizes` does not contain solely integers\n * @throws {DimensionError} If the product of the new dimension sizes does\n * not equal that of the old ones\n */\n return typed(name, {\n\n 'Matrix, Array': function (x, sizes) {\n return x.reshape(sizes, true)\n },\n\n 'Array, Array': function (x, sizes) {\n sizes.forEach(function (size) {\n if (!isInteger(size)) {\n throw new TypeError('Invalid size for dimension: ' + size)\n }\n })\n return arrayReshape(x, sizes)\n }\n\n })\n})\n","import { isBigNumber, isMatrix } from '../../utils/is.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\nimport { isInteger } from '../../utils/number.js'\nimport { format } from '../../utils/string.js'\nimport { clone } from '../../utils/object.js'\nimport { resize as arrayResize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'resize'\nconst dependencies = ['config', 'matrix']\n\nexport const createResize = /* #__PURE__ */ factory(name, dependencies, ({ config, matrix }) => {\n /**\n * Resize a matrix\n *\n * Syntax:\n *\n * math.resize(x, size)\n * math.resize(x, size, defaultValue)\n *\n * Examples:\n *\n * math.resize([1, 2, 3, 4, 5], [3]) // returns Array [1, 2, 3]\n * math.resize([1, 2, 3], [5], 0) // returns Array [1, 2, 3, 0, 0]\n * math.resize(2, [2, 3], 0) // returns Matrix [[2, 0, 0], [0, 0, 0]]\n * math.resize(\"hello\", [8], \"!\") // returns string 'hello!!!'\n *\n * See also:\n *\n * size, squeeze, subset, reshape\n *\n * @param {Array | Matrix | *} x Matrix to be resized\n * @param {Array | Matrix} size One dimensional array with numbers\n * @param {number | string} [defaultValue=0] Zero by default, except in\n * case of a string, in that case\n * defaultValue = ' '\n * @return {* | Array | Matrix} A resized clone of matrix `x`\n */\n // TODO: rework resize to a typed-function\n return function resize (x, size, defaultValue) {\n if (arguments.length !== 2 && arguments.length !== 3) {\n throw new ArgumentsError('resize', arguments.length, 2, 3)\n }\n\n if (isMatrix(size)) {\n size = size.valueOf() // get Array\n }\n\n if (isBigNumber(size[0])) {\n // convert bignumbers to numbers\n size = size.map(function (value) {\n return !isBigNumber(value) ? value : value.toNumber()\n })\n }\n\n // check x is a Matrix\n if (isMatrix(x)) {\n // use optimized matrix implementation, return copy\n return x.resize(size, defaultValue, true)\n }\n\n if (typeof x === 'string') {\n // resize string\n return _resizeString(x, size, defaultValue)\n }\n\n // check result should be a matrix\n const asMatrix = Array.isArray(x) ? false : (config.matrix !== 'Array')\n\n if (size.length === 0) {\n // output a scalar\n while (Array.isArray(x)) {\n x = x[0]\n }\n\n return clone(x)\n } else {\n // output an array/matrix\n if (!Array.isArray(x)) {\n x = [x]\n }\n x = clone(x)\n\n const res = arrayResize(x, size, defaultValue)\n return asMatrix ? matrix(res) : res\n }\n }\n\n /**\n * Resize a string\n * @param {string} str\n * @param {number[]} size\n * @param {string} [defaultChar=' ']\n * @private\n */\n function _resizeString (str, size, defaultChar) {\n if (defaultChar !== undefined) {\n if (typeof defaultChar !== 'string' || defaultChar.length !== 1) {\n throw new TypeError('Single character expected as defaultValue')\n }\n } else {\n defaultChar = ' '\n }\n\n if (size.length !== 1) {\n throw new DimensionError(size.length, 1)\n }\n const len = size[0]\n if (typeof len !== 'number' || !isInteger(len)) {\n throw new TypeError('Invalid size, must contain positive integers ' +\n '(size: ' + format(size) + ')')\n }\n\n if (str.length > len) {\n return str.substring(0, len)\n } else if (str.length < len) {\n let res = str\n for (let i = 0, ii = len - str.length; i < ii; i++) {\n res += defaultChar\n }\n return res\n } else {\n return str\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { arraySize } from '../../utils/array.js'\n\nconst name = 'rotate'\nconst dependencies = [\n 'typed',\n 'multiply',\n 'rotationMatrix'\n]\n\nexport const createRotate = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed, multiply, rotationMatrix\n }) => {\n /**\n * Rotate a vector of size 1x2 counter-clockwise by a given angle\n * Rotate a vector of size 1x3 counter-clockwise by a given angle around the given axis\n *\n * Syntax:\n *\n * math.rotate(w, theta)\n * math.rotate(w, theta, v)\n *\n * Examples:\n *\n * math.rotate([11, 12], math.pi / 2) // returns [-12, 11]\n * math.rotate(matrix([11, 12]), math.pi / 2) // returns [-12, 11]\n *\n * math.rotate([1, 0, 0], unit('90deg'), [0, 0, 1]) // returns [0, 1, 0]\n * math.rotate(matrix([1, 0, 0]), unit('90deg'), [0, 0, 1]) // returns Matrix [0, 1, 0]\n *\n * math.rotate([1, 0], math.complex(1 + i)) // returns [cos(1 + i) - sin(1 + i), sin(1 + i) + cos(1 + i)]\n *\n * See also:\n *\n * matrix, rotationMatrix\n *\n * @param {Array | Matrix} w Vector to rotate\n * @param {number | BigNumber | Complex | Unit} theta Rotation angle\n * @param {Array | Matrix} [v] Rotation axis\n * @return {Array | Matrix} Multiplication of the rotation matrix and w\n */\n return typed(name, {\n 'Array , number | BigNumber | Complex | Unit': function (w, theta) {\n _validateSize(w, 2)\n const matrixRes = multiply(rotationMatrix(theta), w)\n return matrixRes.toArray()\n },\n\n 'Matrix , number | BigNumber | Complex | Unit': function (w, theta) {\n _validateSize(w, 2)\n return multiply(rotationMatrix(theta), w)\n },\n\n 'Array, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) {\n _validateSize(w, 3)\n const matrixRes = multiply(rotationMatrix(theta, v), w)\n return matrixRes\n },\n\n 'Matrix, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) {\n _validateSize(w, 3)\n return multiply(rotationMatrix(theta, v), w)\n }\n })\n\n function _validateSize (v, expectedSize) {\n const actualSize = Array.isArray(v) ? arraySize(v) : v.size()\n if (actualSize.length > 2) {\n throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n }\n if (actualSize.length === 2 && actualSize[1] !== 1) {\n throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n }\n if (actualSize[0] !== expectedSize) {\n throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n }\n }\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'rotationMatrix'\nconst dependencies = [\n 'typed',\n 'config',\n 'multiplyScalar',\n 'addScalar',\n 'unaryMinus',\n 'norm',\n 'matrix',\n 'BigNumber',\n 'DenseMatrix',\n 'SparseMatrix',\n 'cos',\n 'sin'\n]\n\nexport const createRotationMatrix = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed, config, multiplyScalar,\n addScalar, unaryMinus, norm, BigNumber,\n matrix, DenseMatrix, SparseMatrix, cos, sin\n }) => {\n /**\n * Create a 2-dimensional counter-clockwise rotation matrix (2x2) for a given angle (expressed in radians).\n * Create a 2-dimensional counter-clockwise rotation matrix (3x3) by a given angle (expressed in radians) around a given axis (1x3).\n *\n * Syntax:\n *\n * math.rotationMatrix(theta)\n * math.rotationMatrix(theta, format)\n * math.rotationMatrix(theta, [v])\n * math.rotationMatrix(theta, [v], format)\n *\n * Examples:\n *\n * math.rotationMatrix(math.pi / 2) // returns [[0, -1], [1, 0]]\n * math.rotationMatrix(math.bignumber(1)) // returns [[bignumber(cos(1)), bignumber(-sin(1))], [bignumber(sin(1)), bignumber(cos(1))]]\n * math.rotationMatrix(math.complex(1 + i)) // returns [[cos(1 + i), -sin(1 + i)], [sin(1 + i), cos(1 + i)]]\n * math.rotationMatrix(math.unit('1rad')) // returns [[cos(1), -sin(1)], [sin(1), cos(1)]]\n *\n * math.rotationMatrix(math.pi / 2, [0, 1, 0]) // returns [[0, 0, 1], [0, 1, 0], [-1, 0, 0]]\n * math.rotationMatrix(math.pi / 2, matrix([0, 1, 0])) // returns matrix([[0, 0, 1], [0, 1, 0], [-1, 0, 0]])\n *\n *\n * See also:\n *\n * matrix, cos, sin\n *\n *\n * @param {number | BigNumber | Complex | Unit} theta Rotation angle\n * @param {Array | Matrix} [v] Rotation axis\n * @param {string} [format] Result Matrix storage format\n * @return {Array | Matrix} Rotation matrix\n */\n\n return typed(name, {\n '': function () {\n return (config.matrix === 'Matrix') ? matrix([]) : []\n },\n\n string: function (format) {\n return matrix(format)\n },\n\n 'number | BigNumber | Complex | Unit': function (theta) {\n return _rotationMatrix2x2(theta, config.matrix === 'Matrix' ? 'dense' : undefined)\n },\n\n 'number | BigNumber | Complex | Unit, string': function (theta, format) {\n return _rotationMatrix2x2(theta, format)\n },\n\n 'number | BigNumber | Complex | Unit, Array': function (theta, v) {\n const matrixV = matrix(v)\n _validateVector(matrixV)\n return _rotationMatrix3x3(theta, matrixV, undefined)\n },\n\n 'number | BigNumber | Complex | Unit, Matrix': function (theta, v) {\n _validateVector(v)\n const storageType = v.storage() || (config.matrix === 'Matrix' ? 'dense' : undefined)\n return _rotationMatrix3x3(theta, v, storageType)\n },\n\n 'number | BigNumber | Complex | Unit, Array, string': function (theta, v, format) {\n const matrixV = matrix(v)\n _validateVector(matrixV)\n return _rotationMatrix3x3(theta, matrixV, format)\n },\n\n 'number | BigNumber | Complex | Unit, Matrix, string': function (theta, v, format) {\n _validateVector(v)\n return _rotationMatrix3x3(theta, v, format)\n }\n\n })\n\n /**\n * Returns 2x2 matrix of 2D rotation of angle theta\n *\n * @param {number | BigNumber | Complex | Unit} theta The rotation angle\n * @param {string} format The result Matrix storage format\n * @returns {Matrix}\n * @private\n */\n function _rotationMatrix2x2 (theta, format) {\n const Big = isBigNumber(theta)\n\n const minusOne = Big ? new BigNumber(-1) : -1\n const cosTheta = cos(theta)\n const sinTheta = sin(theta)\n const data = [[cosTheta, multiplyScalar(minusOne, sinTheta)], [sinTheta, cosTheta]]\n\n return _convertToFormat(data, format)\n }\n\n function _validateVector (v) {\n const size = v.size()\n if (size.length < 1 || size[0] !== 3) {\n throw new RangeError('Vector must be of dimensions 1x3')\n }\n }\n\n function _mul (array) {\n return array.reduce((p, curr) => multiplyScalar(p, curr))\n }\n\n function _convertToFormat (data, format) {\n if (format) {\n if (format === 'sparse') {\n return new SparseMatrix(data)\n }\n if (format === 'dense') {\n return new DenseMatrix(data)\n }\n throw new TypeError(`Unknown matrix type \"${format}\"`)\n }\n return data\n }\n\n /**\n * Returns a 3x3 matrix of rotation of angle theta around vector v\n *\n * @param {number | BigNumber | Complex | Unit} theta The rotation angle\n * @param {Matrix} v The rotation axis vector\n * @param {string} format The storage format of the resulting matrix\n * @returns {Matrix}\n * @private\n */\n function _rotationMatrix3x3 (theta, v, format) {\n const normV = norm(v)\n if (normV === 0) {\n throw new RangeError('Rotation around zero vector')\n }\n\n const Big = isBigNumber(theta) ? BigNumber : null\n\n const one = Big ? new Big(1) : 1\n const minusOne = Big ? new Big(-1) : -1\n const vx = Big ? new Big(v.get([0]) / normV) : v.get([0]) / normV\n const vy = Big ? new Big(v.get([1]) / normV) : v.get([1]) / normV\n const vz = Big ? new Big(v.get([2]) / normV) : v.get([2]) / normV\n const c = cos(theta)\n const oneMinusC = addScalar(one, unaryMinus(c))\n const s = sin(theta)\n\n const r11 = addScalar(c, _mul([vx, vx, oneMinusC]))\n const r12 = addScalar(_mul([vx, vy, oneMinusC]), _mul([minusOne, vz, s]))\n const r13 = addScalar(_mul([vx, vz, oneMinusC]), _mul([vy, s]))\n\n const r21 = addScalar(_mul([vx, vy, oneMinusC]), _mul([vz, s]))\n const r22 = addScalar(c, _mul([vy, vy, oneMinusC]))\n const r23 = addScalar(_mul([vy, vz, oneMinusC]), _mul([minusOne, vx, s]))\n\n const r31 = addScalar(_mul([vx, vz, oneMinusC]), _mul([minusOne, vy, s]))\n const r32 = addScalar(_mul([vy, vz, oneMinusC]), _mul([vx, s]))\n const r33 = addScalar(c, _mul([vz, vz, oneMinusC]))\n\n const data = [[r11, r12, r13], [r21, r22, r23], [r31, r32, r33]]\n\n return _convertToFormat(data, format)\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { validateIndex } from '../../utils/array.js'\n\nconst name = 'row'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\nexport const createRow = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n /**\n * Return a row from a Matrix.\n *\n * Syntax:\n *\n * math.row(value, index)\n *\n * Example:\n *\n * // get a row\n * const d = [[1, 2], [3, 4]]\n * math.row(d, 1) // returns [[3, 4]]\n *\n * See also:\n *\n * column\n *\n * @param {Array | Matrix } value An array or matrix\n * @param {number} row The index of the row\n * @return {Array | Matrix} The retrieved row\n */\n return typed(name, {\n 'Matrix, number': _row,\n\n 'Array, number': function (value, row) {\n return _row(matrix(clone(value)), row).valueOf()\n }\n })\n\n /**\n * Retrieve a row of a matrix\n * @param {Matrix } value A matrix\n * @param {number} row The index of the row\n * @return {Matrix} The retrieved row\n */\n function _row (value, row) {\n // check dimensions\n if (value.size().length !== 2) {\n throw new Error('Only two dimensional matrix is supported')\n }\n\n validateIndex(row, value.size()[0])\n\n const columnRange = range(0, value.size()[1])\n const index = new Index(row, columnRange)\n const result = value.subset(index)\n return isMatrix(result)\n ? result\n : matrix([[result]])\n }\n})\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { noMatrix } from '../../utils/noop.js'\n\nconst name = 'size'\nconst dependencies = ['typed', 'config', '?matrix']\n\nexport const createSize = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix }) => {\n /**\n * Calculate the size of a matrix or scalar.\n *\n * Syntax:\n *\n * math.size(x)\n *\n * Examples:\n *\n * math.size(2.3) // returns []\n * math.size('hello world') // returns [11]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.size(A) // returns [2, 3]\n * math.size(math.range(1,6).toArray()) // returns [5]\n *\n * See also:\n *\n * count, resize, squeeze, subset\n *\n * @param {boolean | number | Complex | Unit | string | Array | Matrix} x A matrix\n * @return {Array | Matrix} A vector with size of `x`.\n */\n return typed(name, {\n Matrix: function (x) {\n return x.create(x.size(), 'number')\n },\n\n Array: arraySize,\n\n string: function (x) {\n return (config.matrix === 'Array') ? [x.length] : matrix([x.length], 'dense', 'number')\n },\n\n 'number | Complex | BigNumber | Unit | boolean | null': function (x) {\n // scalar\n return (config.matrix === 'Array')\n ? []\n : matrix ? matrix([], 'dense', 'number') : noMatrix()\n }\n })\n})\n","import { clone } from '../../utils/object.js'\nimport { squeeze as arraySqueeze } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'squeeze'\nconst dependencies = ['typed']\n\nexport const createSqueeze = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Squeeze a matrix, remove inner and outer singleton dimensions from a matrix.\n *\n * Syntax:\n *\n * math.squeeze(x)\n *\n * Examples:\n *\n * math.squeeze([3]) // returns 3\n * math.squeeze([[3]]) // returns 3\n *\n * const A = math.zeros(3, 1) // returns [[0], [0], [0]] (size 3x1)\n * math.squeeze(A) // returns [0, 0, 0] (size 3)\n *\n * const B = math.zeros(1, 3) // returns [[0, 0, 0]] (size 1x3)\n * math.squeeze(B) // returns [0, 0, 0] (size 3)\n *\n * // only inner and outer dimensions are removed\n * const C = math.zeros(2, 1, 3) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3)\n * math.squeeze(C) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3)\n *\n * See also:\n *\n * subset\n *\n * @param {Matrix | Array} x Matrix to be squeezed\n * @return {Matrix | Array} Squeezed matrix\n */\n return typed(name, {\n Array: function (x) {\n return arraySqueeze(clone(x))\n },\n\n Matrix: function (x) {\n const res = arraySqueeze(x.toArray())\n // FIXME: return the same type of matrix as the input\n return Array.isArray(res) ? x.create(res, x.datatype()) : res\n },\n\n any: function (x) {\n // scalar\n return clone(x)\n }\n })\n})\n","import { isIndex } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { isEmptyIndex, validateIndex, validateIndexSourceSize } from '../../utils/array.js'\nimport { getSafeProperty, setSafeProperty } from '../../utils/customs.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'subset'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createSubset = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\n /**\n * Get or set a subset of a matrix or string.\n *\n * Syntax:\n * math.subset(value, index) // retrieve a subset\n * math.subset(value, index, replacement [, defaultValue]) // replace a subset\n *\n * Examples:\n *\n * // get a subset\n * const d = [[1, 2], [3, 4]]\n * math.subset(d, math.index(1, 0)) // returns 3\n * math.subset(d, math.index([0, 1], 1)) // returns [[2], [4]]\n * math.subset(d, math.index([false, true], 0)) // returns [[3]]\n *\n * // replace a subset\n * const e = []\n * const f = math.subset(e, math.index(0, [0, 2]), [5, 6]) // f = [[5, 0, 6]]\n * const g = math.subset(f, math.index(1, 1), 7, 0) // g = [[5, 0, 6], [0, 7, 0]]\n * math.subset(g, math.index([false, true], 1), 8) // returns [[5, 0, 6], [0, 8, 0]]\n *\n * // get submatrix using ranges\n * const M = [\n * [1,2,3],\n * [4,5,6],\n * [7,8,9]\n * ]\n * math.subset(M, math.index(math.range(0,2), math.range(0,3))) // [[1, 2, 3], [4, 5, 6]]\n *\n * See also:\n *\n * size, resize, squeeze, index\n *\n * @param {Array | Matrix | string} matrix An array, matrix, or string\n * @param {Index} index\n * For each dimension of the target, specifies an index or a list of\n * indices to fetch or set. `subset` uses the cartesian product of\n * the indices specified in each dimension.\n * @param {*} [replacement] An array, matrix, or scalar.\n * If provided, the subset is replaced with replacement.\n * If not provided, the subset is returned\n * @param {*} [defaultValue=undefined] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * math.matrix elements will be left undefined.\n * @return {Array | Matrix | string} Either the retrieved subset or the updated matrix.\n */\n\n return typed(name, {\n // get subset\n 'Matrix, Index': function (value, index) {\n if (isEmptyIndex(index)) { return matrix() }\n validateIndexSourceSize(value, index)\n return value.subset(index)\n },\n\n 'Array, Index': typed.referTo('Matrix, Index', function (subsetRef) {\n return function (value, index) {\n const subsetResult = subsetRef(matrix(value), index)\n return index.isScalar() ? subsetResult : subsetResult.valueOf()\n }\n }),\n\n 'Object, Index': _getObjectProperty,\n\n 'string, Index': _getSubstring,\n\n // set subset\n 'Matrix, Index, any, any': function (value, index, replacement, defaultValue) {\n if (isEmptyIndex(index)) { return value }\n validateIndexSourceSize(value, index)\n return value.clone().subset(index, _broadcastReplacement(replacement, index), defaultValue)\n },\n\n 'Array, Index, any, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n return function (value, index, replacement, defaultValue) {\n const subsetResult = subsetRef(matrix(value), index, replacement, defaultValue)\n return subsetResult.isMatrix ? subsetResult.valueOf() : subsetResult\n }\n }),\n\n 'Array, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n return function (value, index, replacement) {\n return subsetRef(matrix(value), index, replacement, undefined).valueOf()\n }\n }),\n\n 'Matrix, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n return function (value, index, replacement) { return subsetRef(value, index, replacement, undefined) }\n }),\n\n 'string, Index, string': _setSubstring,\n 'string, Index, string, string': _setSubstring,\n 'Object, Index, any': _setObjectProperty\n })\n\n /**\n * Broadcasts a replacment value to be the same size as index\n * @param {number | BigNumber | Array | Matrix} replacement Replacement value to try to broadcast\n * @param {*} index Index value\n * @returns broadcasted replacement that matches the size of index\n */\n\n function _broadcastReplacement (replacement, index) {\n if (typeof replacement === 'string') {\n throw new Error('can\\'t boradcast a string')\n }\n if (index._isScalar) {\n return replacement\n }\n\n const indexSize = index.size()\n if (indexSize.every(d => d > 0)) {\n try {\n return add(replacement, zeros(indexSize))\n } catch (error) {\n return replacement\n }\n } else {\n return replacement\n }\n }\n})\n\n/**\n * Retrieve a subset of a string\n * @param {string} str string from which to get a substring\n * @param {Index} index An index or list of indices (character positions)\n * @returns {string} substring\n * @private\n */\nfunction _getSubstring (str, index) {\n if (!isIndex(index)) {\n // TODO: better error message\n throw new TypeError('Index expected')\n }\n\n if (isEmptyIndex(index)) { return '' }\n validateIndexSourceSize(Array.from(str), index)\n\n if (index.size().length !== 1) {\n throw new DimensionError(index.size().length, 1)\n }\n\n // validate whether the range is out of range\n const strLen = str.length\n validateIndex(index.min()[0], strLen)\n validateIndex(index.max()[0], strLen)\n\n const range = index.dimension(0)\n\n let substr = ''\n range.forEach(function (v) {\n substr += str.charAt(v)\n })\n\n return substr\n}\n\n/**\n * Replace a substring in a string\n * @param {string} str string to be replaced\n * @param {Index} index An index or list of indices (character positions)\n * @param {string} replacement Replacement string\n * @param {string} [defaultValue] Default value to be used when resizing\n * the string. is ' ' by default\n * @returns {string} result\n * @private\n */\nfunction _setSubstring (str, index, replacement, defaultValue) {\n if (!index || index.isIndex !== true) {\n // TODO: better error message\n throw new TypeError('Index expected')\n }\n if (isEmptyIndex(index)) { return str }\n validateIndexSourceSize(Array.from(str), index)\n if (index.size().length !== 1) {\n throw new DimensionError(index.size().length, 1)\n }\n if (defaultValue !== undefined) {\n if (typeof defaultValue !== 'string' || defaultValue.length !== 1) {\n throw new TypeError('Single character expected as defaultValue')\n }\n } else {\n defaultValue = ' '\n }\n\n const range = index.dimension(0)\n const len = range.size()[0]\n\n if (len !== replacement.length) {\n throw new DimensionError(range.size()[0], replacement.length)\n }\n\n // validate whether the range is out of range\n const strLen = str.length\n validateIndex(index.min()[0])\n validateIndex(index.max()[0])\n\n // copy the string into an array with characters\n const chars = []\n for (let i = 0; i < strLen; i++) {\n chars[i] = str.charAt(i)\n }\n\n range.forEach(function (v, i) {\n chars[v] = replacement.charAt(i[0])\n })\n\n // initialize undefined characters with a space\n if (chars.length > strLen) {\n for (let i = strLen - 1, len = chars.length; i < len; i++) {\n if (!chars[i]) {\n chars[i] = defaultValue\n }\n }\n }\n\n return chars.join('')\n}\n\n/**\n * Retrieve a property from an object\n * @param {Object} object\n * @param {Index} index\n * @return {*} Returns the value of the property\n * @private\n */\nfunction _getObjectProperty (object, index) {\n if (isEmptyIndex(index)) { return undefined }\n\n if (index.size().length !== 1) {\n throw new DimensionError(index.size(), 1)\n }\n\n const key = index.dimension(0)\n if (typeof key !== 'string') {\n throw new TypeError('String expected as index to retrieve an object property')\n }\n\n return getSafeProperty(object, key)\n}\n\n/**\n * Set a property on an object\n * @param {Object} object\n * @param {Index} index\n * @param {*} replacement\n * @return {*} Returns the updated object\n * @private\n */\nfunction _setObjectProperty (object, index, replacement) {\n if (isEmptyIndex(index)) { return object }\n if (index.size().length !== 1) {\n throw new DimensionError(index.size(), 1)\n }\n\n const key = index.dimension(0)\n if (typeof key !== 'string') {\n throw new TypeError('String expected as index to retrieve an object property')\n }\n\n // clone the object, and apply the property to the clone\n const updated = clone(object)\n setSafeProperty(updated, key, replacement)\n\n return updated\n}\n","import { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'transpose'\nconst dependencies = ['typed', 'matrix']\n\nexport const createTranspose = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix }) => {\n /**\n * Transpose a matrix. All values of the matrix are reflected over its\n * main diagonal. Only applicable to two dimensional matrices containing\n * a vector (i.e. having size `[1,n]` or `[n,1]`). One dimensional\n * vectors and scalars return the input unchanged.\n *\n * Syntax:\n *\n * math.transpose(x)\n *\n * Examples:\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.transpose(A) // returns [[1, 4], [2, 5], [3, 6]]\n *\n * See also:\n *\n * diag, inv, subset, squeeze\n *\n * @param {Array | Matrix} x Matrix to be transposed\n * @return {Array | Matrix} The transposed matrix\n */\n return typed(name, {\n Array: x => transposeMatrix(matrix(x)).valueOf(),\n Matrix: transposeMatrix,\n any: clone // scalars\n })\n\n function transposeMatrix (x) {\n // matrix size\n const size = x.size()\n\n // result\n let c\n\n // process dimensions\n switch (size.length) {\n case 1:\n // vector\n c = x.clone()\n break\n\n case 2:\n {\n // rows and columns\n const rows = size[0]\n const columns = size[1]\n\n // check columns\n if (columns === 0) {\n // throw exception\n throw new RangeError('Cannot transpose a 2D matrix with no columns (size: ' + format(size) + ')')\n }\n\n // process storage format\n switch (x.storage()) {\n case 'dense':\n c = _denseTranspose(x, rows, columns)\n break\n case 'sparse':\n c = _sparseTranspose(x, rows, columns)\n break\n }\n }\n break\n\n default:\n // multi dimensional\n throw new RangeError('Matrix must be a vector or two dimensional (size: ' + format(size) + ')')\n }\n return c\n }\n\n function _denseTranspose (m, rows, columns) {\n // matrix array\n const data = m._data\n // transposed matrix data\n const transposed = []\n let transposedRow\n // loop columns\n for (let j = 0; j < columns; j++) {\n // initialize row\n transposedRow = transposed[j] = []\n // loop rows\n for (let i = 0; i < rows; i++) {\n // set data\n transposedRow[i] = clone(data[i][j])\n }\n }\n // return matrix\n return m.createDenseMatrix({\n data: transposed,\n size: [columns, rows],\n datatype: m._datatype\n })\n }\n\n function _sparseTranspose (m, rows, columns) {\n // matrix arrays\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n // result matrices\n const cvalues = values ? [] : undefined\n const cindex = []\n const cptr = []\n // row counts\n const w = []\n for (let x = 0; x < rows; x++) { w[x] = 0 }\n // vars\n let p, l, j\n // loop values in matrix\n for (p = 0, l = index.length; p < l; p++) {\n // number of values in row\n w[index[p]]++\n }\n // cumulative sum\n let sum = 0\n // initialize cptr with the cummulative sum of row counts\n for (let i = 0; i < rows; i++) {\n // update cptr\n cptr.push(sum)\n // update sum\n sum += w[i]\n // update w\n w[i] = cptr[i]\n }\n // update cptr\n cptr.push(sum)\n // loop columns\n for (j = 0; j < columns; j++) {\n // values & index in column\n for (let k0 = ptr[j], k1 = ptr[j + 1], k = k0; k < k1; k++) {\n // C values & index\n const q = w[index[k]]++\n // C[j, i] = A[i, j]\n cindex[q] = j\n // check we need to process values (pattern matrix)\n if (values) { cvalues[q] = clone(values[k]) }\n }\n }\n // return matrix\n return m.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [columns, rows],\n datatype: m._datatype\n })\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'ctranspose'\nconst dependencies = ['typed', 'transpose', 'conj']\n\nexport const createCtranspose = /* #__PURE__ */ factory(name, dependencies, ({ typed, transpose, conj }) => {\n /**\n * Transpose and complex conjugate a matrix. All values of the matrix are\n * reflected over its main diagonal and then the complex conjugate is\n * taken. This is equivalent to complex conjugation for scalars and\n * vectors.\n *\n * Syntax:\n *\n * math.ctranspose(x)\n *\n * Examples:\n *\n * const A = [[1, 2, 3], [4, 5, math.complex(6,7)]]\n * math.ctranspose(A) // returns [[1, 4], [2, 5], [3, {re:6,im:7}]]\n *\n * See also:\n *\n * transpose, diag, inv, subset, squeeze\n *\n * @param {Array | Matrix} x Matrix to be ctransposed\n * @return {Array | Matrix} The ctransposed matrix\n */\n return typed(name, {\n any: function (x) {\n return conj(transpose(x))\n }\n })\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { resize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'zeros'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createZeros = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\n /**\n * Create a matrix filled with zeros. The created matrix can have one or\n * multiple dimensions.\n *\n * Syntax:\n *\n * math.zeros(m)\n * math.zeros(m, format)\n * math.zeros(m, n)\n * math.zeros(m, n, format)\n * math.zeros([m, n])\n * math.zeros([m, n], format)\n *\n * Examples:\n *\n * math.zeros() // returns []\n * math.zeros(3) // returns [0, 0, 0]\n * math.zeros(3, 2) // returns [[0, 0], [0, 0], [0, 0]]\n * math.zeros(3, 'dense') // returns [0, 0, 0]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.zeros(math.size(A)) // returns [[0, 0, 0], [0, 0, 0]]\n *\n * See also:\n *\n * ones, identity, size, range\n *\n * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Array | Matrix} A matrix filled with zeros\n */\n return typed(name, {\n '': function () {\n return (config.matrix === 'Array')\n ? _zeros([])\n : _zeros([], 'default')\n },\n\n // math.zeros(m, n, p, ..., format)\n // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this\n '...number | BigNumber | string': function (size) {\n const last = size[size.length - 1]\n if (typeof last === 'string') {\n const format = size.pop()\n return _zeros(size, format)\n } else if (config.matrix === 'Array') {\n return _zeros(size)\n } else {\n return _zeros(size, 'default')\n }\n },\n\n Array: _zeros,\n\n Matrix: function (size) {\n const format = size.storage()\n return _zeros(size.valueOf(), format)\n },\n\n 'Array | Matrix, string': function (size, format) {\n return _zeros(size.valueOf(), format)\n }\n })\n\n /**\n * Create an Array or Matrix with zeros\n * @param {Array} size\n * @param {string} [format='default']\n * @return {Array | Matrix}\n * @private\n */\n function _zeros (size, format) {\n const hasBigNumbers = _normalize(size)\n const defaultValue = hasBigNumbers ? new BigNumber(0) : 0\n _validate(size)\n\n if (format) {\n // return a matrix\n const m = matrix(format)\n if (size.length > 0) {\n return m.resize(size, defaultValue)\n }\n return m\n } else {\n // return an Array\n const arr = []\n if (size.length > 0) {\n return resize(arr, size, defaultValue)\n }\n return arr\n }\n }\n\n // replace BigNumbers with numbers, returns true if size contained BigNumbers\n function _normalize (size) {\n let hasBigNumbers = false\n size.forEach(function (value, index, arr) {\n if (isBigNumber(value)) {\n hasBigNumbers = true\n arr[index] = value.toNumber()\n }\n })\n return hasBigNumbers\n }\n\n // validate arguments\n function _validate (size) {\n size.forEach(function (value) {\n if (typeof value !== 'number' || !isInteger(value) || value < 0) {\n throw new Error('Parameters in function zeros must be positive integers')\n }\n })\n }\n})\n\n// TODO: zeros contains almost the same code as ones. Reuse this?\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'fft'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'addScalar',\n 'multiplyScalar',\n 'divideScalar',\n 'exp',\n 'tau',\n 'i',\n 'dotDivide',\n 'conj',\n 'pow',\n 'ceil',\n 'log2'\n]\n\nexport const createFft = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n matrix,\n addScalar,\n multiplyScalar,\n divideScalar,\n exp,\n tau,\n i: I,\n dotDivide,\n conj,\n pow,\n ceil,\n log2\n}) => {\n /**\n * Calculate N-dimensional Fourier transform\n *\n * Syntax:\n *\n * math.fft(arr)\n *\n * Examples:\n *\n * math.fft([[1, 0], [1, 0]]) // returns [[{re:2, im:0}, {re:2, im:0}], [{re:0, im:0}, {re:0, im:0}]]\n *\n *\n * See Also:\n *\n * ifft\n *\n * @param {Array | Matrix} arr An array or matrix\n * @return {Array | Matrix} N-dimensional Fourier transformation of the array\n */\n return typed(name, {\n Array: _ndFft,\n Matrix: function (matrix) {\n return matrix.create(_ndFft(matrix.valueOf()), matrix.datatype())\n }\n })\n\n /**\n * Perform an N-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @return {Array} resulting array\n */\n function _ndFft (arr) {\n const size = arraySize(arr)\n if (size.length === 1) return _fft(arr, size[0])\n // ndFft along dimension 1,...,N-1 then 1dFft along dimension 0\n return _1dFft(arr.map(slice => _ndFft(slice, size.slice(1))), 0)\n }\n\n /**\n * Perform an 1-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @param {number} dim dimension of the array to perform on\n * @return {Array} resulting array\n */\n function _1dFft (arr, dim) {\n const size = arraySize(arr)\n if (dim !== 0) return new Array(size[0]).fill(0).map((_, i) => _1dFft(arr[i], dim - 1))\n if (size.length === 1) return _fft(arr)\n function _transpose (arr) { // Swap first 2 dimensions\n const size = arraySize(arr)\n return new Array(size[1]).fill(0).map((_, j) => new Array(size[0]).fill(0).map((_, i) => arr[i][j]))\n }\n return _transpose(_1dFft(_transpose(arr), 1))\n }\n /**\n * Perform an 1-dimensional non-power-of-2 Fourier transform using Chirp-Z Transform\n *\n * @param {Array} arr The array\n * @return {Array} resulting array\n */\n function _czt (arr) {\n const n = arr.length\n const w = exp(divideScalar(multiplyScalar(-1, multiplyScalar(I, tau)), n))\n const chirp = []\n for (let i = 1 - n; i < n; i++) {\n chirp.push(pow(w, divideScalar(pow(i, 2), 2)))\n }\n const N2 = pow(2, ceil(log2(n + n - 1)))\n const xp = [\n ...new Array(n).fill(0).map((_, i) => multiplyScalar(arr[i], chirp[n - 1 + i])),\n ...new Array(N2 - n).fill(0)\n ]\n const ichirp = [\n ...new Array(n + n - 1).fill(0).map((_, i) => divideScalar(1, chirp[i])),\n ...new Array(N2 - (n + n - 1)).fill(0)\n ]\n const fftXp = _fft(xp)\n const fftIchirp = _fft(ichirp)\n const fftProduct = new Array(N2).fill(0).map((_, i) => multiplyScalar(fftXp[i], fftIchirp[i]))\n const ifftProduct = dotDivide(conj(_ndFft(conj(fftProduct))), N2)\n const ret = []\n for (let i = n - 1; i < n + n - 1; i++) {\n ret.push(multiplyScalar(ifftProduct[i], chirp[i]))\n }\n return ret\n }\n /**\n * Perform an 1-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @return {Array} resulting array\n */\n function _fft (arr) {\n const len = arr.length\n if (len === 1) return [arr[0]]\n if (len % 2 === 0) {\n const ret = [\n ..._fft(arr.filter((_, i) => i % 2 === 0), len / 2),\n ..._fft(arr.filter((_, i) => i % 2 === 1), len / 2)\n ]\n for (let k = 0; k < len / 2; k++) {\n const p = ret[k]\n const q = multiplyScalar(\n ret[k + len / 2],\n exp(\n multiplyScalar(multiplyScalar(tau, I), divideScalar(-k, len))\n )\n )\n ret[k] = addScalar(p, q)\n ret[k + len / 2] = addScalar(p, multiplyScalar(-1, q))\n }\n return ret\n } else {\n // use chirp-z transform for non-power-of-2 FFT\n return _czt(arr)\n }\n // throw new Error('Can only calculate FFT of power-of-two size')\n }\n})\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'ifft'\nconst dependencies = [\n 'typed',\n 'fft',\n 'dotDivide',\n 'conj'\n]\n\nexport const createIfft = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n fft,\n dotDivide,\n conj\n}) => {\n /**\n * Calculate N-dimensional inverse Fourier transform\n *\n * Syntax:\n *\n * math.ifft(arr)\n *\n * Examples:\n *\n * math.ifft([[2, 2], [0, 0]]) // returns [[{re:1, im:0}, {re:0, im:0}], [{re:1, im:0}, {re:0, im:0}]]\n *\n * See Also:\n *\n * fft\n *\n * @param {Array | Matrix} arr An array or matrix\n * @return {Array | Matrix} N-dimensional Fourier transformation of the array\n */\n return typed(name, {\n 'Array | Matrix': function (arr) {\n const size = isMatrix(arr) ? arr.size() : arraySize(arr)\n return dotDivide(conj(fft(conj(arr))), size.reduce((acc, curr) => acc * curr, 1))\n }\n })\n})\n","import { isUnit, isNumber, isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'solveODE'\nconst dependencies = [\n 'typed',\n 'add',\n 'subtract',\n 'multiply',\n 'divide',\n 'max',\n 'map',\n 'abs',\n 'isPositive',\n 'isNegative',\n 'larger',\n 'smaller',\n 'matrix',\n 'bignumber',\n 'unaryMinus'\n]\n\nexport const createSolveODE = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n add,\n subtract,\n multiply,\n divide,\n max,\n map,\n abs,\n isPositive,\n isNegative,\n larger,\n smaller,\n matrix,\n bignumber,\n unaryMinus\n }\n) => {\n /**\n * Numerical Integration of Ordinary Differential Equations\n *\n * Two variable step methods are provided:\n * - \"RK23\": Bogacki–Shampine method\n * - \"RK45\": Dormand-Prince method RK5(4)7M (default)\n *\n * The arguments are expected as follows.\n *\n * - `func` should be the forcing function `f(t, y)`\n * - `tspan` should be a vector of two numbers or units `[tStart, tEnd]`\n * - `y0` the initial state values, should be a scalar or a flat array\n * - `options` should be an object with the following information:\n * - `method` ('RK45'): ['RK23', 'RK45']\n * - `tol` (1e-3): Numeric tolerance of the method, the solver keeps the error estimates less than this value\n * - `firstStep`: Initial step size\n * - `minStep`: minimum step size of the method\n * - `maxStep`: maximum step size of the method\n * - `minDelta` (0.2): minimum ratio of change for the step\n * - `maxDelta` (5): maximum ratio of change for the step\n * - `maxIter` (1e4): maximum number of iterations\n *\n * The returned value is an object with `{t, y}` please note that even though `t` means time, it can represent any other independant variable like `x`:\n * - `t` an array of size `[n]`\n * - `y` the states array can be in two ways\n * - **if `y0` is a scalar:** returns an array-like of size `[n]`\n * - **if `y0` is a flat array-like of size [m]:** returns an array like of size `[n, m]`\n *\n * Syntax:\n *\n * math.solveODE(func, tspan, y0)\n * math.solveODE(func, tspan, y0, options)\n *\n * Examples:\n *\n * function func(t, y) {return y}\n * const tspan = [0, 4]\n * const y0 = 1\n * math.solveODE(func, tspan, y0)\n * math.solveODE(func, tspan, [1, 2])\n * math.solveODE(func, tspan, y0, { method:\"RK23\", maxStep:0.1 })\n *\n * See also:\n *\n * derivative, simplifyCore\n *\n * @param {function} func The forcing function f(t,y)\n * @param {Array | Matrix} tspan The time span\n * @param {number | BigNumber | Unit | Array | Matrix} y0 The initial value\n * @param {Object} [options] Optional configuration options\n * @return {Object} Return an object with t and y values as arrays\n */\n\n function _rk (butcherTableau) {\n // generates an adaptive runge kutta method from it's butcher tableau\n\n return function (f, tspan, y0, options) {\n // adaptive runge kutta methods\n const wrongTSpan = !((tspan.length === 2) && (tspan.every(isNumOrBig) || tspan.every(isUnit)))\n if (wrongTSpan) {\n throw new Error('\"tspan\" must be an Array of two numeric values or two units [tStart, tEnd]')\n }\n const t0 = tspan[0] // initial time\n const tf = tspan[1] // final time\n const isForwards = larger(tf, t0)\n const firstStep = options.firstStep\n if (firstStep !== undefined && !isPositive(firstStep)) {\n throw new Error('\"firstStep\" must be positive')\n }\n const maxStep = options.maxStep\n if (maxStep !== undefined && !isPositive(maxStep)) {\n throw new Error('\"maxStep\" must be positive')\n }\n const minStep = options.minStep\n if (minStep && isNegative(minStep)) {\n throw new Error('\"minStep\" must be positive or zero')\n }\n const timeVars = [t0, tf, firstStep, minStep, maxStep].filter(x => x !== undefined)\n if (!(timeVars.every(isNumOrBig) || timeVars.every(isUnit))) {\n throw new Error('Inconsistent type of \"t\" dependant variables')\n }\n const steps = 1 // divide time in this number of steps\n const tol = options.tol ? options.tol : 1e-4 // define a tolerance (must be an option)\n const minDelta = options.minDelta ? options.minDelta : 0.2\n const maxDelta = options.maxDelta ? options.maxDelta : 5\n const maxIter = options.maxIter ? options.maxIter : 10_000 // stop inifite evaluation if something goes wrong\n const hasBigNumbers = [t0, tf, ...y0, maxStep, minStep].some(isBigNumber)\n const [a, c, b, bp] = hasBigNumbers\n ? [\n bignumber(butcherTableau.a),\n bignumber(butcherTableau.c),\n bignumber(butcherTableau.b),\n bignumber(butcherTableau.bp)\n ]\n : [butcherTableau.a, butcherTableau.c, butcherTableau.b, butcherTableau.bp]\n\n let h = firstStep\n ? isForwards ? firstStep : unaryMinus(firstStep)\n : divide(subtract(tf, t0), steps) // define the first step size\n const t = [t0] // start the time array\n const y = [y0] // start the solution array\n\n const deltaB = subtract(b, bp) // b - bp\n\n let n = 0\n let iter = 0\n const ongoing = _createOngoing(isForwards)\n const trimStep = _createTrimStep(isForwards)\n // iterate unitil it reaches either the final time or maximum iterations\n while (ongoing(t[n], tf)) {\n const k = []\n\n // trim the time step so that it doesn't overshoot\n h = trimStep(t[n], tf, h)\n\n // calculate the first value of k\n k.push(f(t[n], y[n]))\n\n // calculate the rest of the values of k\n for (let i = 1; i < c.length; ++i) {\n k.push(\n f(\n add(t[n], multiply(c[i], h)),\n add(y[n], multiply(h, a[i], k))\n )\n )\n }\n\n // estimate the error by comparing solutions of different orders\n const TE = max(\n abs(\n map(multiply(deltaB, k), (X) =>\n isUnit(X) ? X.value : X\n )\n )\n )\n\n if (TE < tol && tol / TE > 1 / 4) {\n // push solution if within tol\n t.push(add(t[n], h))\n y.push(add(y[n], multiply(h, b, k)))\n n++\n }\n\n // estimate the delta value that will affect the step size\n let delta = 0.84 * (tol / TE) ** (1 / 5)\n\n if (smaller(delta, minDelta)) {\n delta = minDelta\n } else if (larger(delta, maxDelta)) {\n delta = maxDelta\n }\n\n delta = hasBigNumbers ? bignumber(delta) : delta\n h = multiply(h, delta)\n\n if (maxStep && larger(abs(h), maxStep)) {\n h = isForwards ? maxStep : unaryMinus(maxStep)\n } else if (minStep && smaller(abs(h), minStep)) {\n h = isForwards ? minStep : unaryMinus(minStep)\n }\n iter++\n if (iter > maxIter) {\n throw new Error('Maximum number of iterations reached, try changing options')\n }\n }\n return { t, y }\n }\n }\n\n function _rk23 (f, tspan, y0, options) {\n // Bogacki–Shampine method\n\n // Define the butcher table\n const a = [\n [],\n [1 / 2],\n [0, 3 / 4],\n [2 / 9, 1 / 3, 4 / 9]\n ]\n\n const c = [null, 1 / 2, 3 / 4, 1]\n const b = [2 / 9, 1 / 3, 4 / 9, 0]\n const bp = [7 / 24, 1 / 4, 1 / 3, 1 / 8]\n\n const butcherTableau = { a, c, b, bp }\n\n // Solve an adaptive step size rk method\n return _rk(butcherTableau)(f, tspan, y0, options)\n }\n\n function _rk45 (f, tspan, y0, options) {\n // Dormand Prince method\n\n // Define the butcher tableau\n const a = [\n [],\n [1 / 5],\n [3 / 40, 9 / 40],\n [44 / 45, -56 / 15, 32 / 9],\n [19372 / 6561, -25360 / 2187, 64448 / 6561, -212 / 729],\n [9017 / 3168, -355 / 33, 46732 / 5247, 49 / 176, -5103 / 18656],\n [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84]\n ]\n\n const c = [null, 1 / 5, 3 / 10, 4 / 5, 8 / 9, 1, 1]\n const b = [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84, 0]\n const bp = [5179 / 57600, 0, 7571 / 16695, 393 / 640, -92097 / 339200, 187 / 2100, 1 / 40]\n\n const butcherTableau = { a, c, b, bp }\n\n // Solve an adaptive step size rk method\n return _rk(butcherTableau)(f, tspan, y0, options)\n }\n\n function _solveODE (f, tspan, y0, opt) {\n const method = opt.method ? opt.method : 'RK45'\n const methods = {\n RK23: _rk23,\n RK45: _rk45\n }\n if (method.toUpperCase() in methods) {\n const methodOptions = { ...opt } // clone the options object\n delete methodOptions.method // delete the method as it won't be needed\n return methods[method.toUpperCase()](f, tspan, y0, methodOptions)\n } else {\n // throw an error indicating there is no such method\n const methodsWithQuotes = Object.keys(methods).map(x => `\"${x}\"`)\n // generates a string of methods like: \"BDF\", \"RK23\" and \"RK45\"\n const availableMethodsString = `${methodsWithQuotes.slice(0, -1).join(', ')} and ${methodsWithQuotes.slice(-1)}`\n throw new Error(`Unavailable method \"${method}\". Available methods are ${availableMethodsString}`)\n }\n }\n\n function _createOngoing (isForwards) {\n // returns the correct function to test if it's still iterating\n return isForwards ? smaller : larger\n }\n\n function _createTrimStep (isForwards) {\n const outOfBounds = isForwards ? larger : smaller\n return function (t, tf, h) {\n const next = add(t, h)\n return outOfBounds(next, tf) ? subtract(tf, t) : h\n }\n }\n\n function isNumOrBig (x) {\n // checks if it's a number or bignumber\n return isBigNumber(x) || isNumber(x)\n }\n\n function _matrixSolveODE (f, T, y0, options) {\n // receives matrices and returns matrices\n const sol = _solveODE(f, T.toArray(), y0.toArray(), options)\n return { t: matrix(sol.t), y: matrix(sol.y) }\n }\n\n return typed('solveODE', {\n 'function, Array, Array, Object': _solveODE,\n 'function, Matrix, Matrix, Object': _matrixSolveODE,\n 'function, Array, Array': (f, T, y0) => _solveODE(f, T, y0, {}),\n 'function, Matrix, Matrix': (f, T, y0) => _matrixSolveODE(f, T, y0, {}),\n 'function, Array, number | BigNumber | Unit': (f, T, y0) => {\n const sol = _solveODE(f, T, [y0], {})\n return { t: sol.t, y: sol.y.map((Y) => Y[0]) }\n },\n 'function, Matrix, number | BigNumber | Unit': (f, T, y0) => {\n const sol = _solveODE(f, T.toArray(), [y0], {})\n return { t: matrix(sol.t), y: matrix(sol.y.map((Y) => Y[0])) }\n },\n 'function, Array, number | BigNumber | Unit, Object': (f, T, y0, options) => {\n const sol = _solveODE(f, T, [y0], options)\n return { t: sol.t, y: sol.y.map((Y) => Y[0]) }\n },\n 'function, Matrix, number | BigNumber | Unit, Object': (f, T, y0, options) => {\n const sol = _solveODE(f, T.toArray(), [y0], options)\n return { t: matrix(sol.t), y: matrix(sol.y.map((Y) => Y[0])) }\n }\n })\n})\n","/* eslint-disable no-loss-of-precision */\n\nimport { deepMap } from '../../utils/collection.js'\nimport { sign } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'erf'\nconst dependencies = [\n 'typed'\n]\n\nexport const createErf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the erf function of a value using a rational Chebyshev\n * approximations for different intervals of x.\n *\n * This is a translation of W. J. Cody's Fortran implementation from 1987\n * ( https://www.netlib.org/specfun/erf ). See the AMS publication\n * \"Rational Chebyshev Approximations for the Error Function\" by W. J. Cody\n * for an explanation of this process.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.erf(x)\n *\n * Examples:\n *\n * math.erf(0.2) // returns 0.22270258921047847\n * math.erf(-0.5) // returns -0.5204998778130465\n * math.erf(4) // returns 0.9999999845827421\n *\n * See also:\n * zeta\n *\n * @param {number | Array | Matrix} x A real number\n * @return {number | Array | Matrix} The erf of `x`\n */\n return typed('name', {\n number: function (x) {\n const y = Math.abs(x)\n\n if (y >= MAX_NUM) {\n return sign(x)\n }\n if (y <= THRESH) {\n return sign(x) * erf1(y)\n }\n if (y <= 4.0) {\n return sign(x) * (1 - erfc2(y))\n }\n return sign(x) * (1 - erfc3(y))\n },\n\n 'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self))\n\n // TODO: For complex numbers, use the approximation for the Faddeeva function\n // from \"More Efficient Computation of the Complex Error Function\" (AMS)\n\n })\n\n /**\n * Approximates the error function erf() for x <= 0.46875 using this function:\n * n\n * erf(x) = x * sum (p_j * x^(2j)) / (q_j * x^(2j))\n * j=0\n */\n function erf1 (y) {\n const ysq = y * y\n let xnum = P[0][4] * ysq\n let xden = ysq\n let i\n\n for (i = 0; i < 3; i += 1) {\n xnum = (xnum + P[0][i]) * ysq\n xden = (xden + Q[0][i]) * ysq\n }\n return y * (xnum + P[0][3]) / (xden + Q[0][3])\n }\n\n /**\n * Approximates the complement of the error function erfc() for\n * 0.46875 <= x <= 4.0 using this function:\n * n\n * erfc(x) = e^(-x^2) * sum (p_j * x^j) / (q_j * x^j)\n * j=0\n */\n function erfc2 (y) {\n let xnum = P[1][8] * y\n let xden = y\n let i\n\n for (i = 0; i < 7; i += 1) {\n xnum = (xnum + P[1][i]) * y\n xden = (xden + Q[1][i]) * y\n }\n const result = (xnum + P[1][7]) / (xden + Q[1][7])\n const ysq = parseInt(y * 16) / 16\n const del = (y - ysq) * (y + ysq)\n return Math.exp(-ysq * ysq) * Math.exp(-del) * result\n }\n\n /**\n * Approximates the complement of the error function erfc() for x > 4.0 using\n * this function:\n *\n * erfc(x) = (e^(-x^2) / x) * [ 1/sqrt(pi) +\n * n\n * 1/(x^2) * sum (p_j * x^(-2j)) / (q_j * x^(-2j)) ]\n * j=0\n */\n function erfc3 (y) {\n let ysq = 1 / (y * y)\n let xnum = P[2][5] * ysq\n let xden = ysq\n let i\n\n for (i = 0; i < 4; i += 1) {\n xnum = (xnum + P[2][i]) * ysq\n xden = (xden + Q[2][i]) * ysq\n }\n let result = ysq * (xnum + P[2][4]) / (xden + Q[2][4])\n result = (SQRPI - result) / y\n ysq = parseInt(y * 16) / 16\n const del = (y - ysq) * (y + ysq)\n return Math.exp(-ysq * ysq) * Math.exp(-del) * result\n }\n})\n\n/**\n * Upper bound for the first approximation interval, 0 <= x <= THRESH\n * @constant\n */\nconst THRESH = 0.46875\n\n/**\n * Constant used by W. J. Cody's Fortran77 implementation to denote sqrt(pi)\n * @constant\n */\nconst SQRPI = 5.6418958354775628695e-1\n\n/**\n * Coefficients for each term of the numerator sum (p_j) for each approximation\n * interval (see W. J. Cody's paper for more details)\n * @constant\n */\nconst P = [[\n 3.16112374387056560e00, 1.13864154151050156e02,\n 3.77485237685302021e02, 3.20937758913846947e03,\n 1.85777706184603153e-1\n], [\n 5.64188496988670089e-1, 8.88314979438837594e00,\n 6.61191906371416295e01, 2.98635138197400131e02,\n 8.81952221241769090e02, 1.71204761263407058e03,\n 2.05107837782607147e03, 1.23033935479799725e03,\n 2.15311535474403846e-8\n], [\n 3.05326634961232344e-1, 3.60344899949804439e-1,\n 1.25781726111229246e-1, 1.60837851487422766e-2,\n 6.58749161529837803e-4, 1.63153871373020978e-2\n]]\n\n/**\n * Coefficients for each term of the denominator sum (q_j) for each approximation\n * interval (see W. J. Cody's paper for more details)\n * @constant\n */\nconst Q = [[\n 2.36012909523441209e01, 2.44024637934444173e02,\n 1.28261652607737228e03, 2.84423683343917062e03\n], [\n 1.57449261107098347e01, 1.17693950891312499e02,\n 5.37181101862009858e02, 1.62138957456669019e03,\n 3.29079923573345963e03, 4.36261909014324716e03,\n 3.43936767414372164e03, 1.23033935480374942e03\n], [\n 2.56852019228982242e00, 1.87295284992346047e00,\n 5.27905102951428412e-1, 6.05183413124413191e-2,\n 2.33520497626869185e-3\n]]\n\n/**\n * Maximum/minimum safe numbers to input to erf() (in ES6+, this number is\n * Number.[MAX|MIN]_SAFE_INTEGER). erf() for all numbers beyond this limit will\n * return 1\n */\nconst MAX_NUM = Math.pow(2, 53)\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'zeta'\nconst dependencies = ['typed', 'config', 'multiply', 'pow', 'divide', 'factorial', 'equal', 'smallerEq', 'isNegative', 'gamma', 'sin', 'subtract', 'add', '?Complex', '?BigNumber', 'pi']\n\nexport const createZeta = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiply, pow, divide, factorial, equal, smallerEq, isNegative, gamma, sin, subtract, add, Complex, BigNumber, pi }) => {\n /**\n * Compute the Riemann Zeta function of a value using an infinite series for\n * all of the complex plane using Riemann's Functional equation.\n *\n * Based off the paper by Xavier Gourdon and Pascal Sebah\n * ( http://numbers.computation.free.fr/Constants/Miscellaneous/zetaevaluations.pdf )\n *\n * Implementation and slight modification by Anik Patel\n *\n * Note: the implementation is accurate up to about 6 digits.\n *\n * Syntax:\n *\n * math.zeta(n)\n *\n * Examples:\n *\n * math.zeta(5) // returns 1.0369277551433895\n * math.zeta(-0.5) // returns -0.2078862249773449\n * math.zeta(math.i) // returns 0.0033002236853253153 - 0.4181554491413212i\n *\n * See also:\n * erf\n *\n * @param {number | Complex | BigNumber} s A Real, Complex or BigNumber parameter to the Riemann Zeta Function\n * @return {number | Complex | BigNumber} The Riemann Zeta of `s`\n */\n return typed(name, {\n number: (s) => zetaNumeric(s, value => value, () => 20),\n BigNumber: (s) => zetaNumeric(\n s,\n value => new BigNumber(value),\n () => {\n // relTol is for example 1e-12. Extract the positive exponent 12 from that\n return Math.abs(Math.log10(config.relTol))\n }\n ),\n Complex: zetaComplex\n })\n\n /**\n * @param {number | BigNumber} s\n * @param {(value: number) => number | BigNumber} createValue\n * @param {(value: number | BigNumber | Complex) => number} determineDigits\n * @returns {number | BigNumber}\n */\n function zetaNumeric (s, createValue, determineDigits) {\n if (equal(s, 0)) {\n return createValue(-0.5)\n }\n if (equal(s, 1)) {\n return createValue(NaN)\n }\n if (!isFinite(s)) {\n return isNegative(s) ? createValue(NaN) : createValue(1)\n }\n\n return zeta(s, createValue, determineDigits, s => s)\n }\n\n /**\n * @param {Complex} s\n * @returns {Complex}\n */\n function zetaComplex (s) {\n if (s.re === 0 && s.im === 0) {\n return new Complex(-0.5)\n }\n if (s.re === 1) {\n return new Complex(NaN, NaN)\n }\n if (s.re === Infinity && s.im === 0) {\n return new Complex(1)\n }\n if (s.im === Infinity || s.re === -Infinity) {\n return new Complex(NaN, NaN)\n }\n\n return zeta(s, value => value, s => Math.round(1.3 * 15 + 0.9 * Math.abs(s.im)), s => s.re)\n }\n\n /**\n * @param {number | BigNumber | Complex} s\n * @param {(value: number) => number | BigNumber | Complex} createValue\n * @param {(value: number | BigNumber | Complex) => number} determineDigits\n * @param {(value: number | BigNumber | Complex) => number} getRe\n * @returns {*|number}\n */\n function zeta (s, createValue, determineDigits, getRe) {\n const n = determineDigits(s)\n if (getRe(s) > -(n - 1) / 2) {\n return f(s, createValue(n), createValue)\n } else {\n // Function Equation for reflection to x < 1\n let c = multiply(pow(2, s), pow(createValue(pi), subtract(s, 1)))\n c = multiply(c, (sin(multiply(divide(createValue(pi), 2), s))))\n c = multiply(c, gamma(subtract(1, s)))\n return multiply(c, zeta(subtract(1, s), createValue, determineDigits, getRe))\n }\n }\n\n /**\n * Calculate a portion of the sum\n * @param {number | BigNumber} k a positive integer\n * @param {number | BigNumber} n a positive integer\n * @return {number} the portion of the sum\n **/\n function d (k, n) {\n let S = k\n for (let j = k; smallerEq(j, n); j = add(j, 1)) {\n const factor = divide(\n multiply(factorial(add(n, subtract(j, 1))), pow(4, j)),\n multiply(factorial(subtract(n, j)), factorial(multiply(2, j)))\n )\n S = add(S, factor)\n }\n\n return multiply(n, S)\n }\n\n /**\n * Calculate the positive Riemann Zeta function\n * @param {number} s a real or complex number with s.re > 1\n * @param {number} n a positive integer\n * @param {(number) => number | BigNumber | Complex} createValue\n * @return {number} Riemann Zeta of s\n **/\n function f (s, n, createValue) {\n const c = divide(1, multiply(d(createValue(0), n), subtract(1, pow(2, subtract(1, s)))))\n let S = createValue(0)\n for (let k = createValue(1); smallerEq(k, n); k = add(k, 1)) {\n S = add(S, divide(multiply((-1) ** (k - 1), d(k, n)), pow(k, s)))\n }\n return multiply(c, S)\n }\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'mode'\nconst dependencies = ['typed', 'isNaN', 'isNumeric']\n\nexport const createMode = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNaN, isNumeric }) => {\n /**\n * Computes the mode of a set of numbers or a list with values(numbers or characters).\n * If there are multiple modes, it returns a list of those values.\n *\n * Syntax:\n *\n * math.mode(a, b, c, ...)\n * math.mode(A)\n *\n * Examples:\n *\n * math.mode(2, 1, 4, 3, 1) // returns [1]\n * math.mode([1, 2.7, 3.2, 4, 2.7]) // returns [2.7]\n * math.mode(1, 4, 6, 1, 6) // returns [1, 6]\n * math.mode('a','a','b','c') // returns [\"a\"]\n * math.mode(1, 1.5, 'abc') // returns [1, 1.5, \"abc\"]\n *\n * See also:\n *\n * median,\n * mean\n *\n * @param {... *} args A single matrix\n * @return {*} The mode of all values\n */\n return typed(name, {\n 'Array | Matrix': _mode,\n\n '...': function (args) {\n return _mode(args)\n }\n })\n\n /**\n * Calculates the mode in an 1-dimensional array\n * @param {Array} values\n * @return {Array} mode\n * @private\n */\n function _mode (values) {\n values = flatten(values.valueOf())\n const num = values.length\n if (num === 0) {\n throw new Error('Cannot calculate mode of an empty array')\n }\n\n const count = {}\n let mode = []\n let max = 0\n for (let i = 0; i < values.length; i++) {\n const value = values[i]\n\n if (isNumeric(value) && isNaN(value)) {\n throw new Error('Cannot calculate mode of an array containing NaN values')\n }\n\n if (!(value in count)) {\n count[value] = 0\n }\n\n count[value]++\n\n if (count[value] === max) {\n mode.push(value)\n } else if (count[value] > max) {\n max = count[value]\n mode = [value]\n }\n }\n return mode\n }\n})\n","import { typeOf } from '../../../utils/is.js'\n\n/**\n * Improve error messages for statistics functions. Errors are typically\n * thrown in an internally used function like larger, causing the error\n * not to mention the function (like max) which is actually used by the user.\n *\n * @param {Error} err\n * @param {String} fnName\n * @param {*} [value]\n * @return {Error}\n */\nexport function improveErrorMessage (err, fnName, value) {\n // TODO: add information with the index (also needs transform in expression parser)\n let details\n\n if (String(err).includes('Unexpected type')) {\n details = arguments.length > 2\n ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')'\n : ' (type: ' + err.data.actual + ')'\n\n return new TypeError('Cannot calculate ' + fnName + ', unexpected type of argument' + details)\n }\n\n if (String(err).includes('complex numbers')) {\n details = arguments.length > 2\n ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')'\n : ''\n\n return new TypeError('Cannot calculate ' + fnName + ', no ordering relation is defined for complex numbers' + details)\n }\n\n return err\n}\n","import { deepForEach } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'prod'\nconst dependencies = ['typed', 'config', 'multiplyScalar', 'numeric']\n\nexport const createProd = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiplyScalar, numeric }) => {\n /**\n * Compute the product of a matrix or a list with values.\n * In case of a multidimensional array or matrix, the sum of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.prod(a, b, c, ...)\n * math.prod(A)\n *\n * Examples:\n *\n * math.multiply(2, 3) // returns 6\n * math.prod(2, 3) // returns 6\n * math.prod(2, 3, 4) // returns 24\n * math.prod([2, 3, 4]) // returns 24\n * math.prod([[2, 5], [4, 3]]) // returns 120\n *\n * See also:\n *\n * mean, median, min, max, sum, std, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The product of all values\n */\n return typed(name, {\n // prod([a, b, c, d, ...])\n 'Array | Matrix': _prod,\n\n // prod([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function (array, dim) {\n // TODO: implement prod(A, dim)\n throw new Error('prod(A, dim) is not yet supported')\n // return reduce(arguments[0], arguments[1], math.prod)\n },\n\n // prod(a, b, c, d, ...)\n '...': function (args) {\n return _prod(args)\n }\n })\n\n /**\n * Recursively calculate the product of an n-dimensional array\n * @param {Array} array\n * @return {number} prod\n * @private\n */\n function _prod (array) {\n let prod\n\n deepForEach(array, function (value) {\n try {\n prod = (prod === undefined) ? value : multiplyScalar(prod, value)\n } catch (err) {\n throw improveErrorMessage(err, 'prod', value)\n }\n })\n\n // make sure returning numeric value: parse a string into a numeric value\n if (typeof prod === 'string') {\n prod = numeric(prod, safeNumberType(prod, config))\n }\n\n if (prod === undefined) {\n throw new Error('Cannot calculate prod of an empty array')\n }\n\n return prod\n }\n})\n","import { format as formatString } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'format'\nconst dependencies = ['typed']\n\nexport const createFormat = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Format a value of any type into a string.\n *\n * Syntax:\n *\n * math.format(value)\n * math.format(value, options)\n * math.format(value, precision)\n * math.format(value, callback)\n *\n * Where:\n *\n * - `value: *`\n * The value to be formatted\n * - `options: Object`\n * An object with formatting options. Available options:\n * - `notation: string`\n * Number notation. Choose from:\n * - `'fixed'`\n * Always use regular number notation.\n * For example `'123.40'` and `'14000000'`\n * - `'exponential'`\n * Always use exponential notation.\n * For example `'1.234e+2'` and `'1.4e+7'`\n * - `'engineering'`\n * Always use engineering notation: always have exponential notation,\n * and select the exponent to be a multiple of `3`.\n * For example `'123.4e+0'` and `'14.0e+6'`\n * - `'auto'` (default)\n * Regular number notation for numbers having an absolute value between\n * `lower` and `upper` bounds, and uses exponential notation elsewhere.\n * Lower bound is included, upper bound is excluded.\n * For example `'123.4'` and `'1.4e7'`.\n * - `'bin'`, `'oct'`, or `'hex'`\n * Format the number using binary, octal, or hexadecimal notation.\n * For example `'0b1101'` and `'0x10fe'`.\n * - `wordSize: number | BigNumber`\n * The word size in bits to use for formatting in binary, octal, or\n * hexadecimal notation. To be used only with `'bin'`, `'oct'`, or `'hex'`\n * values for `notation` option. When this option is defined the value\n * is formatted as a signed twos complement integer of the given word\n * size and the size suffix is appended to the output.\n * For example `format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'`.\n * Default value is undefined.\n * - `precision: number | BigNumber`\n * Limit the number of digits of the formatted value.\n * For regular numbers, must be a number between `0` and `16`.\n * For bignumbers, the maximum depends on the configured precision,\n * see function `config()`.\n * In case of notations `'exponential'`, `'engineering'`, and `'auto'`,\n * `precision` defines the total number of significant digits returned.\n * In case of notation `'fixed'`, `precision` defines the number of\n * significant digits after the decimal point.\n * `precision` is undefined by default.\n * - `lowerExp: number`\n * Exponent determining the lower boundary for formatting a value with\n * an exponent when `notation='auto'`. Default value is `-3`.\n * - `upperExp: number`\n * Exponent determining the upper boundary for formatting a value with\n * an exponent when `notation='auto'`. Default value is `5`.\n * - `fraction: string`. Available values: `'ratio'` (default) or `'decimal'`.\n * For example `format(fraction(1, 3))` will output `'1/3'` when `'ratio'`\n * is configured, and will output `'0.(3)'` when `'decimal'` is configured.\n * - `truncate: number`. Specifies the maximum allowed length of the\n * returned string. If it had been longer, the excess characters\n * are deleted and replaced with `'...'`.\n * - `callback: function`\n * A custom formatting function, invoked for all numeric elements in `value`,\n * for example all elements of a matrix, or the real and imaginary\n * parts of a complex number. This callback can be used to override the\n * built-in numeric notation with any type of formatting. Function `callback`\n * is called with `value` as parameter and must return a string.\n *\n * When `value` is an Object:\n *\n * - When the object contains a property `format` being a function, this function\n * is invoked as `value.format(options)` and the result is returned.\n * - When the object has its own `toString` method, this method is invoked\n * and the result is returned.\n * - In other cases the function will loop over all object properties and\n * return JSON object notation like '{\"a\": 2, \"b\": 3}'.\n *\n * When value is a function:\n *\n * - When the function has a property `syntax`, it returns this\n * syntax description.\n * - In other cases, a string `'function'` is returned.\n *\n * Examples:\n *\n * math.format(6.4) // returns '6.4'\n * math.format(1240000) // returns '1.24e+6'\n * math.format(1/3) // returns '0.3333333333333333'\n * math.format(1/3, 3) // returns '0.333'\n * math.format(21385, 2) // returns '21000'\n * math.format(12e8, {notation: 'fixed'}) // returns '1200000000'\n * math.format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000'\n * math.format(52.8, {notation: 'exponential'}) // returns '5.28e+1'\n * math.format(12400, {notation: 'engineering'}) // returns '12.4e+3'\n * math.format(2000, {lowerExp: -2, upperExp: 2}) // returns '2e+3'\n *\n * function formatCurrency(value) {\n * // return currency notation with two digits:\n * return '$' + value.toFixed(2)\n *\n * // you could also use math.format inside the callback:\n * // return '$' + math.format(value, {notation: 'fixed', precision: 2})\n * }\n * math.format([2.1, 3, 0.016], formatCurrency) // returns '[$2.10, $3.00, $0.02]'\n *\n * See also:\n *\n * print\n *\n * @param {*} value Value to be stringified\n * @param {Object | Function | number} [options] Formatting options\n * @return {string} The formatted value\n */\n return typed(name, {\n any: formatString,\n 'any, Object | function | number | BigNumber': formatString\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'bin'\nconst dependencies = ['typed', 'format']\n\n/**\n * Format a number as binary.\n *\n * Syntax:\n *\n * math.bin(value)\n *\n * Examples:\n *\n * //the following outputs \"0b10\"\n * math.bin(2)\n *\n * See also:\n *\n * oct\n * hex\n *\n * @param {number | BigNumber} value Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\nexport const createBin = factory(name, dependencies, ({ typed, format }) => {\n return typed(name, {\n 'number | BigNumber': function (n) {\n return format(n, { notation: 'bin' })\n },\n 'number | BigNumber, number | BigNumber': function (n, wordSize) {\n return format(n, { notation: 'bin', wordSize })\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'oct'\nconst dependencies = ['typed', 'format']\n\n/**\n * Format a number as octal.\n *\n * Syntax:\n *\n * math.oct(value)\n *\n * Examples:\n *\n * //the following outputs \"0o70\"\n * math.oct(56)\n *\n * See also:\n *\n * bin\n * hex\n *\n * @param {number | BigNumber} value Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\n\nexport const createOct = factory(name, dependencies, ({ typed, format }) => {\n return typed(name, {\n 'number | BigNumber': function (n) {\n return format(n, { notation: 'oct' })\n },\n 'number | BigNumber, number | BigNumber': function (n, wordSize) {\n return format(n, { notation: 'oct', wordSize })\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'hex'\nconst dependencies = ['typed', 'format']\n\n/**\n * Format a number as hexadecimal.\n *\n * Syntax:\n *\n * math.hex(value)\n *\n * Examples:\n *\n * math.hex(240) // returns \"0xF0\"\n *\n * See also:\n *\n * oct\n * bin\n *\n * @param {number | BigNumber} value Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\nexport const createHex = factory(name, dependencies, ({ typed, format }) => {\n return typed(name, {\n 'number | BigNumber': function (n) {\n return format(n, { notation: 'hex' })\n },\n 'number | BigNumber, number | BigNumber': function (n, wordSize) {\n return format(n, { notation: 'hex', wordSize })\n }\n })\n})\n","export const printTemplate = /\\$([\\w.]+)/g\n","import { format } from '../../utils/string.js'\nimport { isString } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { printTemplate } from '../../utils/print.js'\n\nconst name = 'print'\nconst dependencies = ['typed']\n\nexport const createPrint = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Interpolate values into a string template.\n *\n * Syntax:\n *\n * math.print(template, values)\n * math.print(template, values, precision)\n * math.print(template, values, options)\n *\n * Example usage:\n *\n * // the following outputs: 'Lucy is 5 years old'\n * math.print('Lucy is $age years old', {age: 5})\n *\n * // the following outputs: 'The value of pi is 3.141592654'\n * math.print('The value of pi is $pi', {pi: math.pi}, 10)\n *\n * // the following outputs: 'hello Mary! The date is 2013-03-23'\n * math.print('Hello $user.name! The date is $date', {\n * user: {\n * name: 'Mary',\n * },\n * date: new Date(2013, 2, 23).toISOString().substring(0, 10)\n * })\n *\n * // the following outputs: 'My favorite fruits are apples and bananas !'\n * math.print('My favorite fruits are $0 and $1 !', [\n * 'apples',\n * 'bananas'\n * ])\n *\n * See also:\n *\n * format\n *\n * @param {string} template A string containing variable placeholders.\n * @param {Object | Array | Matrix} values An object or array containing variables\n * which will be filled in in the template.\n * @param {number | Object} [options] Formatting options,\n * or the number of digits to format numbers.\n * See function math.format for a description\n * of all options.\n * @return {string} Interpolated string\n */\n return typed(name, {\n // note: Matrix will be converted automatically to an Array\n 'string, Object | Array': _print,\n 'string, Object | Array, number | Object': _print\n })\n})\n\n/**\n * Interpolate values into a string template.\n * @param {string} template\n * @param {Object} values\n * @param {number | Object} [options]\n * @returns {string} Interpolated string\n * @private\n */\nfunction _print (template, values, options) {\n return template.replace(printTemplate, function (original, key) {\n const keys = key.split('.')\n let value = values[keys.shift()]\n if (value !== undefined && value.isMatrix) {\n value = value.toArray()\n }\n while (keys.length && value !== undefined) {\n const k = keys.shift()\n value = k ? value[k] : value + '.'\n }\n\n if (value !== undefined) {\n if (!isString(value)) {\n return format(value, options)\n } else {\n return value\n }\n }\n\n return original\n }\n )\n}\n","import { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'to'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'concat'\n]\n\nexport const createTo = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, concat }) => {\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Change the unit of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.to(x, unit)\n *\n * Examples:\n *\n * math.to(math.unit('2 inch'), 'cm') // returns Unit 5.08 cm\n * math.to(math.unit('2 inch'), math.unit('cm')) // returns Unit 5.08 cm\n * math.to(math.unit(16, 'bytes'), 'bits') // returns Unit 128 bits\n *\n * See also:\n *\n * unit\n *\n * @param {Unit | Array | Matrix} x The unit to be converted.\n * @param {Unit | Array | Matrix} unit New unit. Can be a string like \"cm\"\n * or a unit without value.\n * @return {Unit | Array | Matrix} value with changed, fixed unit.\n */\n return typed(\n name,\n { 'Unit, Unit | string': (x, unit) => x.to(unit) },\n matrixAlgorithmSuite({ Ds: true })\n )\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isPrime'\nconst dependencies = ['typed']\n\nexport const createIsPrime = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Test whether a value is prime: has no divisors other than itself and one.\n * The function supports type `number`, `bignumber`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isPrime(x)\n *\n * Examples:\n *\n * math.isPrime(3) // returns true\n * math.isPrime(-2) // returns false\n * math.isPrime(0) // returns false\n * math.isPrime(-0) // returns false\n * math.isPrime(0.5) // returns false\n * math.isPrime('2') // returns true\n * math.isPrime([2, 17, 100]) // returns [true, true, false]\n *\n * See also:\n *\n * isNumeric, isZero, isNegative, isInteger\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: function (x) {\n if (x <= 3) {\n return x > 1\n }\n if (x % 2 === 0 || x % 3 === 0) {\n return false\n }\n for (let i = 5; i * i <= x; i += 6) {\n if (x % i === 0 || x % (i + 2) === 0) {\n return false\n }\n }\n return true\n },\n\n bigint: function (x) {\n if (x <= 3n) {\n return x > 1n\n }\n if (x % 2n === 0n || x % 3n === 0n) {\n return false\n }\n for (let i = 5n; i * i <= x; i += 6n) {\n if (x % i === 0n || x % (i + 2n) === 0n) {\n return false\n }\n }\n return true\n },\n\n BigNumber: function (n) {\n if (n.lte(3)) return n.gt(1)\n if (n.mod(2).eq(0) || n.mod(3).eq(0)) return false\n if (n.lt(Math.pow(2, 32))) {\n const x = n.toNumber()\n for (let i = 5; i * i <= x; i += 6) {\n if (x % i === 0 || x % (i + 2) === 0) {\n return false\n }\n }\n return true\n }\n\n function modPow (base, exponent, modulus) {\n // exponent can be huge, use non-recursive variant\n let accumulator = 1\n while (!exponent.eq(0)) {\n if (exponent.mod(2).eq(0)) {\n exponent = exponent.div(2)\n base = base.mul(base).mod(modulus)\n } else {\n exponent = exponent.sub(1)\n accumulator = base.mul(accumulator).mod(modulus)\n }\n }\n return accumulator\n }\n\n // https://en.wikipedia.org/wiki/Miller%E2%80%93Rabin_primality_test#Deterministic_variants\n const Decimal = n.constructor.clone({ precision: n.toFixed(0).length * 2 })\n n = new Decimal(n)\n let r = 0\n let d = n.sub(1)\n while (d.mod(2).eq(0)) {\n d = d.div(2)\n r += 1\n }\n let bases = null\n // https://en.wikipedia.org/wiki/Miller–Rabin_primality_test#Testing_against_small_sets_of_bases\n if (n.lt('3317044064679887385961981')) {\n bases = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41].filter(x => x < n)\n } else {\n const max = Math.min(n.toNumber() - 2, Math.floor(2 * Math.pow(n.toFixed(0).length * Math.log(10), 2)))\n bases = []\n for (let i = 2; i <= max; i += 1) {\n bases.push(max)\n }\n }\n for (let i = 0; i < bases.length; i += 1) {\n const a = bases[i]\n const adn = modPow(n.sub(n).add(a), d, n)\n if (!adn.eq(1)) {\n for (let i = 0, x = adn; !x.eq(n.sub(1)); i += 1, x = x.mul(x).mod(n)) {\n if (i === r - 1) {\n return false\n }\n }\n }\n }\n return true\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { noBignumber, noFraction } from '../../utils/noop.js'\n\nconst name = 'numeric'\nconst dependencies = ['number', '?bignumber', '?fraction']\n\nexport const createNumeric = /* #__PURE__ */ factory(name, dependencies, ({ number, bignumber, fraction }) => {\n const validInputTypes = {\n string: true,\n number: true,\n BigNumber: true,\n Fraction: true\n }\n\n // Load the conversion functions for each output type\n const validOutputTypes = {\n number: (x) => number(x),\n BigNumber: bignumber\n ? (x) => bignumber(x)\n : noBignumber,\n bigint: (x) => BigInt(x),\n Fraction: fraction\n ? (x) => fraction(x)\n : noFraction\n }\n\n /**\n * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.\n *\n * Syntax:\n *\n * math.numeric(x)\n *\n * Examples:\n *\n * math.numeric('4') // returns 4\n * math.numeric('4', 'number') // returns 4\n * math.numeric('4', 'bigint') // returns 4n\n * math.numeric('4', 'BigNumber') // returns BigNumber 4\n * math.numeric('4', 'Fraction') // returns Fraction 4\n * math.numeric(4, 'Fraction') // returns Fraction 4\n * math.numeric(math.fraction(2, 5), 'number') // returns 0.4\n *\n * See also:\n *\n * number, fraction, bignumber, bigint, string, format\n *\n * @param {string | number | BigNumber | bigint | Fraction } value\n * A numeric value or a string containing a numeric value\n * @param {string} outputType\n * Desired numeric output type.\n * Available values: 'number', 'BigNumber', or 'Fraction'\n * @return {number | BigNumber | bigint | Fraction}\n * Returns an instance of the numeric in the requested type\n */\n return function numeric (value, outputType = 'number', check) {\n if (check !== undefined) {\n throw new SyntaxError('numeric() takes one or two arguments')\n }\n const inputType = typeOf(value)\n\n if (!(inputType in validInputTypes)) {\n throw new TypeError('Cannot convert ' + value + ' of type \"' + inputType + '\"; valid input types are ' + Object.keys(validInputTypes).join(', '))\n }\n if (!(outputType in validOutputTypes)) {\n throw new TypeError('Cannot convert ' + value + ' to type \"' + outputType + '\"; valid output types are ' + Object.keys(validOutputTypes).join(', '))\n }\n\n if (outputType === inputType) {\n return value\n } else {\n return validOutputTypes[outputType](value)\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'divideScalar'\nconst dependencies = ['typed', 'numeric']\n\nexport const createDivideScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed, numeric }) => {\n /**\n * Divide two scalar values, `x / y`.\n * This function is meant for internal use: it is used by the public functions\n * `divide` and `inv`.\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Numerator\n * @param {number | BigNumber | bigint | Fraction | Complex} y Denominator\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Quotient, `x / y`\n * @private\n */\n return typed(name, {\n 'number, number': function (x, y) {\n return x / y\n },\n\n 'Complex, Complex': function (x, y) {\n return x.div(y)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.div(y)\n },\n\n 'bigint, bigint': function (x, y) {\n return x / y\n },\n\n 'Fraction, Fraction': function (x, y) {\n return x.div(y)\n },\n\n 'Unit, number | Complex | Fraction | BigNumber | Unit':\n (x, y) => x.divide(y),\n\n 'number | Fraction | Complex | BigNumber, Unit':\n (x, y) => y.divideInto(x)\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { arraySize as size } from '../../utils/array.js'\nimport { powNumber } from '../../plain/number/index.js'\n\nconst name = 'pow'\nconst dependencies = [\n 'typed',\n 'config',\n 'identity',\n 'multiply',\n 'matrix',\n 'inv',\n 'fraction',\n 'number',\n 'Complex'\n]\n\nexport const createPow = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, identity, multiply, matrix, inv, number, fraction, Complex }) => {\n /**\n * Calculates the power of x to y, `x ^ y`.\n *\n * Matrix exponentiation is supported for square matrices `x` and integers `y`:\n * when `y` is nonnegative, `x` may be any square matrix; and when `y` is\n * negative, `x` must be invertible, and then this function returns\n * inv(x)^(-y).\n *\n * For cubic roots of negative numbers, the function returns the principal\n * root by default. In order to let the function return the real root,\n * math.js can be configured with `math.config({predictable: true})`.\n * To retrieve all cubic roots of a value, use `math.cbrt(x, true)`.\n *\n * Syntax:\n *\n * math.pow(x, y)\n *\n * Examples:\n *\n * math.pow(2, 3) // returns number 8\n *\n * const a = math.complex(2, 3)\n * math.pow(a, 2) // returns Complex -5 + 12i\n *\n * const b = [[1, 2], [4, 3]]\n * math.pow(b, 2) // returns Array [[9, 8], [16, 17]]\n *\n * const c = [[1, 2], [4, 3]]\n * math.pow(c, -1) // returns Array [[-0.6, 0.4], [0.8, -0.2]]\n *\n * See also:\n *\n * multiply, sqrt, cbrt, nthRoot\n *\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x The base\n * @param {number | BigNumber | bigint | Complex} y The exponent\n * @return {number | BigNumber | bigint | Complex | Array | Matrix} The value of `x` to the power `y`\n */\n return typed(name, {\n 'number, number': _pow,\n\n 'Complex, Complex': function (x, y) {\n return x.pow(y)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n if (y.isInteger() || x >= 0 || config.predictable) {\n return x.pow(y)\n } else {\n return new Complex(x.toNumber(), 0).pow(y.toNumber(), 0)\n }\n },\n\n 'bigint, bigint': (x, y) => x ** y,\n\n 'Fraction, Fraction': function (x, y) {\n const result = x.pow(y)\n\n if (result != null) {\n return result\n }\n\n if (config.predictable) {\n throw new Error('Result of pow is non-rational and cannot be expressed as a fraction')\n } else {\n return _pow(x.valueOf(), y.valueOf())\n }\n },\n\n 'Array, number': _powArray,\n\n 'Array, BigNumber': function (x, y) {\n return _powArray(x, y.toNumber())\n },\n\n 'Matrix, number': _powMatrix,\n\n 'Matrix, BigNumber': function (x, y) {\n return _powMatrix(x, y.toNumber())\n },\n\n 'Unit, number | BigNumber': function (x, y) {\n return x.pow(y)\n }\n\n })\n\n /**\n * Calculates the power of x to y, x^y, for two numbers.\n * @param {number} x\n * @param {number} y\n * @return {number | Complex} res\n * @private\n */\n function _pow (x, y) {\n // Alternatively could define a 'realmode' config option or something, but\n // 'predictable' will work for now\n if (config.predictable && !isInteger(y) && x < 0) {\n // Check to see if y can be represented as a fraction\n try {\n const yFrac = fraction(y)\n const yNum = number(yFrac)\n if (y === yNum || Math.abs((y - yNum) / y) < 1e-14) {\n if (yFrac.d % 2 === 1) {\n return (yFrac.n % 2 === 0 ? 1 : -1) * Math.pow(-x, y)\n }\n }\n } catch (ex) {\n // fraction() throws an error if y is Infinity, etc.\n }\n\n // Unable to express y as a fraction, so continue on\n }\n\n // **for predictable mode** x^Infinity === NaN if x < -1\n // N.B. this behavour is different from `Math.pow` which gives\n // (-2)^Infinity === Infinity\n if (config.predictable &&\n ((x < -1 && y === Infinity) ||\n (x > -1 && x < 0 && y === -Infinity))) {\n return NaN\n }\n\n if (isInteger(y) || x >= 0 || config.predictable) {\n return powNumber(x, y)\n } else {\n // TODO: the following infinity checks are duplicated from powNumber. Deduplicate this somehow\n\n // x^Infinity === 0 if -1 < x < 1\n // A real number 0 is returned instead of complex(0)\n if ((x * x < 1 && y === Infinity) ||\n (x * x > 1 && y === -Infinity)) {\n return 0\n }\n\n return new Complex(x, 0).pow(y, 0)\n }\n }\n\n /**\n * Calculate the power of a 2d array\n * @param {Array} x must be a 2 dimensional, square matrix\n * @param {number} y a integer value (positive if `x` is not invertible)\n * @returns {Array}\n * @private\n */\n function _powArray (x, y) {\n if (!isInteger(y)) {\n throw new TypeError('For A^b, b must be an integer (value is ' + y + ')')\n }\n // verify that A is a 2 dimensional square matrix\n const s = size(x)\n if (s.length !== 2) {\n throw new Error('For A^b, A must be 2 dimensional (A has ' + s.length + ' dimensions)')\n }\n if (s[0] !== s[1]) {\n throw new Error('For A^b, A must be square (size is ' + s[0] + 'x' + s[1] + ')')\n }\n if (y < 0) {\n try {\n return _powArray(inv(x), -y)\n } catch (error) {\n if (error.message === 'Cannot calculate inverse, determinant is zero') {\n throw new TypeError('For A^b, when A is not invertible, b must be a positive integer (value is ' + y + ')')\n }\n throw error\n }\n }\n\n let res = identity(s[0]).valueOf()\n let px = x\n while (y >= 1) {\n if ((y & 1) === 1) {\n res = multiply(px, res)\n }\n y >>= 1\n px = multiply(px, px)\n }\n return res\n }\n\n /**\n * Calculate the power of a 2d matrix\n * @param {Matrix} x must be a 2 dimensional, square matrix\n * @param {number} y a positive, integer value\n * @returns {Matrix}\n * @private\n */\n function _powMatrix (x, y) {\n return matrix(_powArray(x.valueOf(), y))\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual, splitNumber } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { roundNumber } from '../../plain/number/index.js'\n\nconst NO_INT = 'Number of decimals in function round must be an integer'\n\nconst name = 'round'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'BigNumber',\n 'DenseMatrix'\n]\n\nexport const createRound = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, equalScalar, zeros, BigNumber, DenseMatrix }) => {\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n function toExponent (epsilon) {\n return Math.abs(splitNumber(epsilon).exponent)\n }\n\n /**\n * Round a value towards the nearest rounded value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.round(x)\n * math.round(x, n)\n * math.round(unit, valuelessUnit)\n * math.round(unit, n, valuelessUnit)\n *\n * Examples:\n *\n * math.round(3.22) // returns number 3\n * math.round(3.82) // returns number 4\n * math.round(-4.2) // returns number -4\n * math.round(-4.7) // returns number -5\n * math.round(3.22, 1) // returns number 3.2\n * math.round(3.88, 1) // returns number 3.9\n * math.round(-4.21, 1) // returns number -4.2\n * math.round(-4.71, 1) // returns number -4.7\n * math.round(math.pi, 3) // returns number 3.142\n * math.round(123.45678, 2) // returns number 123.46\n *\n * const c = math.complex(3.2, -2.7)\n * math.round(c) // returns Complex 3 - 3i\n *\n * const unit = math.unit('3.241 cm')\n * const cm = math.unit('cm')\n * const mm = math.unit('mm')\n * math.round(unit, 1, cm) // returns Unit 3.2 cm\n * math.round(unit, 1, mm) // returns Unit 32.4 mm\n *\n * math.round([3.2, 3.8, -4.7]) // returns Array [3, 4, -5]\n *\n * See also:\n *\n * ceil, fix, floor\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Value to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @param {Unit} [valuelessUnit] A valueless unit\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n return typed(name, {\n number: function (x) {\n // Handle round off errors by first rounding to relTol precision\n const xEpsilon = roundNumber(x, toExponent(config.relTol))\n const xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n return roundNumber(xSelected)\n },\n\n 'number, number': function (x, n) {\n // Same as number: unless user specifies more decimals than relTol\n const epsilonExponent = toExponent(config.relTol)\n if (n >= epsilonExponent) { return roundNumber(x, n) }\n\n const xEpsilon = roundNumber(x, epsilonExponent)\n const xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n return roundNumber(xSelected, n)\n },\n\n 'number, BigNumber': function (x, n) {\n if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n return new BigNumber(x).toDecimalPlaces(n.toNumber())\n },\n\n Complex: function (x) {\n return x.round()\n },\n\n 'Complex, number': function (x, n) {\n if (n % 1) { throw new TypeError(NO_INT) }\n\n return x.round(n)\n },\n\n 'Complex, BigNumber': function (x, n) {\n if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n const _n = n.toNumber()\n return x.round(_n)\n },\n\n BigNumber: function (x) {\n // Handle round off errors by first rounding to relTol precision\n const xEpsilon = new BigNumber(x).toDecimalPlaces(toExponent(config.relTol))\n const xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n return xSelected.toDecimalPlaces(0)\n },\n\n 'BigNumber, BigNumber': function (x, n) {\n if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n // Same as BigNumber: unless user specifies more decimals than relTol\n const epsilonExponent = toExponent(config.relTol)\n if (n >= epsilonExponent) { return x.toDecimalPlaces(n.toNumber()) }\n\n const xEpsilon = x.toDecimalPlaces(epsilonExponent)\n const xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n return xSelected.toDecimalPlaces(n.toNumber())\n },\n\n Fraction: function (x) {\n return x.round()\n },\n\n 'Fraction, number': function (x, n) {\n if (n % 1) { throw new TypeError(NO_INT) }\n return x.round(n)\n },\n\n 'Fraction, BigNumber': function (x, n) {\n if (!n.isInteger()) { throw new TypeError(NO_INT) }\n return x.round(n.toNumber())\n },\n\n 'Unit, number, Unit': typed.referToSelf(self => function (x, n, unit) {\n const valueless = x.toNumeric(unit)\n return unit.multiply(self(valueless, n))\n }),\n\n 'Unit, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)),\n\n 'Unit, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)),\n\n 'Array | Matrix, number, Unit': typed.referToSelf(self => (x, n, unit) => {\n // deep map collection, skip zeros since round(0) = 0\n return deepMap(x, (value) => self(value, n, unit), true)\n }),\n\n 'Array | Matrix, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)),\n\n 'Array | Matrix, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)),\n\n 'Array | Matrix': typed.referToSelf(self => x => {\n // deep map collection, skip zeros since round(0) = 0\n return deepMap(x, self, true)\n }),\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n return matAlgo11xS0s(x, n, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n return matAlgo14xDs(x, n, self, false)\n }),\n\n 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n // use matrix implementation\n return matAlgo14xDs(matrix(x), n, self, false).valueOf()\n }),\n\n 'number | Complex | BigNumber | Fraction, SparseMatrix': typed.referToSelf(self => (x, n) => {\n // check scalar is zero\n if (equalScalar(x, 0)) {\n // do not execute algorithm, result will be a zero matrix\n return zeros(n.size(), n.storage())\n }\n return matAlgo12xSfs(n, x, self, true)\n }),\n\n 'number | Complex | BigNumber | Fraction, DenseMatrix': typed.referToSelf(self => (x, n) => {\n // check scalar is zero\n if (equalScalar(x, 0)) {\n // do not execute algorithm, result will be a zero matrix\n return zeros(n.size(), n.storage())\n }\n return matAlgo14xDs(n, x, self, true)\n }),\n\n 'number | Complex | BigNumber | Fraction, Array': typed.referToSelf(self => (x, n) => {\n // use matrix implementation\n return matAlgo14xDs(matrix(n), x, self, true).valueOf()\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { logNumber } from '../../plain/number/index.js'\n\nconst name = 'log'\nconst dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n\nexport const createLog = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\n /**\n * Calculate the logarithm of a value.\n *\n * To avoid confusion with the matrix logarithm, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.log(x)\n * math.log(x, base)\n *\n * Examples:\n *\n * math.log(3.5) // returns 1.252762968495368\n * math.exp(math.log(2.4)) // returns 2.4\n *\n * math.pow(10, 4) // returns 10000\n * math.log(10000, 10) // returns 4\n * math.log(10000) / math.log(10) // returns 4\n *\n * math.log(1024, 2) // returns 10\n * math.pow(2, 10) // returns 1024\n *\n * See also:\n *\n * exp, log2, log10, log1p\n *\n * @param {number | BigNumber | Complex} x\n * Value for which to calculate the logarithm.\n * @param {number | BigNumber | Complex} [base=e]\n * Optional base for the logarithm. If not provided, the natural\n * logarithm of `x` is calculated.\n * @return {number | BigNumber | Complex}\n * Returns the logarithm of `x`\n */\n return typed(name, {\n number: function (x) {\n if (x >= 0 || config.predictable) {\n return logNumber(x)\n } else {\n // negative value -> complex value computation\n return new Complex(x, 0).log()\n }\n },\n\n Complex: function (x) {\n return x.log()\n },\n\n BigNumber: function (x) {\n if (!x.isNegative() || config.predictable) {\n return x.ln()\n } else {\n // downgrade to number, return Complex valued result\n return new Complex(x.toNumber(), 0).log()\n }\n },\n\n 'any, any': typed.referToSelf(self => (x, base) => {\n // calculate logarithm for a specified base, log(x, base)\n return divideScalar(self(x), self(base))\n })\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log1p as _log1p } from '../../utils/number.js'\n\nconst name = 'log1p'\nconst dependencies = ['typed', 'config', 'divideScalar', 'log', 'Complex']\n\nexport const createLog1p = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, log, Complex }) => {\n /**\n * Calculate the logarithm of a `value+1`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log1p(x)\n * math.log1p(x, base)\n *\n * Examples:\n *\n * math.log1p(2.5) // returns 1.252762968495368\n * math.exp(math.log1p(1.4)) // returns 2.4\n *\n * math.pow(10, 4) // returns 10000\n * math.log1p(9999, 10) // returns 4\n * math.log1p(9999) / math.log(10) // returns 4\n *\n * See also:\n *\n * exp, log, log2, log10\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm of `x+1`.\n * @param {number | BigNumber | Complex} [base=e]\n * Optional base for the logarithm. If not provided, the natural\n * logarithm of `x+1` is calculated.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the logarithm of `x+1`\n */\n return typed(name, {\n number: function (x) {\n if (x >= -1 || config.predictable) {\n return _log1p(x)\n } else {\n // negative value -> complex value computation\n return _log1pComplex(new Complex(x, 0))\n }\n },\n\n Complex: _log1pComplex,\n\n BigNumber: function (x) {\n const y = x.plus(1)\n if (!y.isNegative() || config.predictable) {\n return y.ln()\n } else {\n // downgrade to number, return Complex valued result\n return _log1pComplex(new Complex(x.toNumber(), 0))\n }\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)),\n\n 'any, any': typed.referToSelf(self => (x, base) => {\n // calculate logarithm for a specified base, log1p(x, base)\n return divideScalar(self(x), log(base))\n })\n })\n\n /**\n * Calculate the natural logarithm of a complex number + 1\n * @param {Complex} x\n * @returns {Complex}\n * @private\n */\n function _log1pComplex (x) {\n const xRe1p = x.re + 1\n return new Complex(\n Math.log(Math.sqrt(xRe1p * xRe1p + x.im * x.im)),\n Math.atan2(x.im, xRe1p)\n )\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'nthRoots'\nconst dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n\nexport const createNthRoots = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\n /**\n * Each function here returns a real multiple of i as a Complex value.\n * @param {number} val\n * @return {Complex} val, i*val, -val or -i*val for index 0, 1, 2, 3\n */\n // This is used to fix float artifacts for zero-valued components.\n const _calculateExactResult = [\n function realPos (val) { return new Complex(val, 0) },\n function imagPos (val) { return new Complex(0, val) },\n function realNeg (val) { return new Complex(-val, 0) },\n function imagNeg (val) { return new Complex(0, -val) }\n ]\n\n /**\n * Calculate the nth root of a Complex Number a using De Movire's Theorem.\n * @param {Complex} a\n * @param {number} root\n * @return {Array} array of n Complex Roots\n */\n function _nthComplexRoots (a, root) {\n if (root < 0) throw new Error('Root must be greater than zero')\n if (root === 0) throw new Error('Root must be non-zero')\n if (root % 1 !== 0) throw new Error('Root must be an integer')\n if (a === 0 || a.abs() === 0) return [new Complex(0, 0)]\n const aIsNumeric = typeof (a) === 'number'\n let offset\n // determine the offset (argument of a)/(pi/2)\n if (aIsNumeric || a.re === 0 || a.im === 0) {\n if (aIsNumeric) {\n offset = 2 * (+(a < 0)) // numeric value on the real axis\n } else if (a.im === 0) {\n offset = 2 * (+(a.re < 0)) // complex value on the real axis\n } else {\n offset = 2 * (+(a.im < 0)) + 1 // complex value on the imaginary axis\n }\n }\n const arg = a.arg()\n const abs = a.abs()\n const roots = []\n const r = Math.pow(abs, 1 / root)\n for (let k = 0; k < root; k++) {\n const halfPiFactor = (offset + 4 * k) / root\n /**\n * If (offset + 4*k)/root is an integral multiple of pi/2\n * then we can produce a more exact result.\n */\n if (halfPiFactor === Math.round(halfPiFactor)) {\n roots.push(_calculateExactResult[halfPiFactor % 4](r))\n continue\n }\n roots.push(new Complex({ r, phi: (arg + 2 * Math.PI * k) / root }))\n }\n return roots\n }\n\n /**\n * Calculate the nth roots of a value.\n * An nth root of a positive real number A,\n * is a positive real solution of the equation \"x^root = A\".\n * This function returns an array of complex values.\n *\n * Syntax:\n *\n * math.nthRoots(x)\n * math.nthRoots(x, root)\n *\n * Examples:\n *\n * math.nthRoots(1)\n * // returns [\n * // {re: 1, im: 0},\n * // {re: -1, im: 0}\n * // ]\n * math.nthRoots(1, 3)\n * // returns [\n * // { re: 1, im: 0 },\n * // { re: -0.4999999999999998, im: 0.8660254037844387 },\n * // { re: -0.5000000000000004, im: -0.8660254037844385 }\n * // ]\n *\n * See also:\n *\n * nthRoot, pow, sqrt\n *\n * @param {number | BigNumber | Fraction | Complex} x Number to be rounded\n * @param {number} [root=2] Optional root, default value is 2\n * @return {number | BigNumber | Fraction | Complex} Returns the nth roots\n */\n return typed(name, {\n Complex: function (x) {\n return _nthComplexRoots(x, 2)\n },\n 'Complex, number': _nthComplexRoots\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotPow'\nconst dependencies = [\n 'typed',\n 'equalScalar',\n 'matrix',\n 'pow',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createDotPow = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar, matrix, pow, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n const powScalarSignatures = {}\n for (const signature in pow.signatures) {\n if (Object.prototype.hasOwnProperty.call(pow.signatures, signature)) {\n if (!signature.includes('Matrix') && !signature.includes('Array')) {\n powScalarSignatures[signature] = pow.signatures[signature]\n }\n }\n }\n const powScalar = typed(powScalarSignatures)\n\n /**\n * Calculates the power of x to y element wise.\n *\n * Syntax:\n *\n * math.dotPow(x, y)\n *\n * Examples:\n *\n * math.dotPow(2, 3) // returns number 8\n *\n * const a = [[1, 2], [4, 3]]\n * math.dotPow(a, 2) // returns Array [[1, 4], [16, 9]]\n * math.pow(a, 2) // returns Array [[9, 8], [16, 17]]\n *\n * See also:\n *\n * pow, sqrt, multiply\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x The base\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} y The exponent\n * @return {number | BigNumber | Complex | Unit | Array | Matrix} The value of `x` to the power `y`\n */\n return typed(name, matrixAlgorithmSuite({\n elop: powScalar,\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo11xS0s,\n sS: matAlgo12xSfs\n }))\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotDivide'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'divideScalar',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createDotDivide = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, divideScalar, DenseMatrix, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Divide two matrices element wise. The function accepts both matrices and\n * scalar values.\n *\n * Syntax:\n *\n * math.dotDivide(x, y)\n *\n * Examples:\n *\n * math.dotDivide(2, 4) // returns 0.5\n *\n * a = [[9, 5], [6, 1]]\n * b = [[3, 2], [5, 2]]\n *\n * math.dotDivide(a, b) // returns [[3, 2.5], [1.2, 0.5]]\n * math.divide(a, b) // returns [[1.75, 0.75], [-1.75, 2.25]]\n *\n * See also:\n *\n * divide, multiply, dotMultiply\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Numerator\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Denominator\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Quotient, `x ./ y`\n */\n return typed(name, matrixAlgorithmSuite({\n elop: divideScalar,\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n SD: matAlgo02xDS0,\n Ss: matAlgo11xS0s,\n sS: matAlgo12xSfs\n }))\n})\n","import { isArray, isMatrix, isDenseMatrix, isSparseMatrix } from '../../../../utils/is.js'\nimport { arraySize } from '../../../../utils/array.js'\nimport { format } from '../../../../utils/string.js'\n\nexport function createSolveValidation ({ DenseMatrix }) {\n /**\n * Validates matrix and column vector b for backward/forward substitution algorithms.\n *\n * @param {Matrix} m An N x N matrix\n * @param {Array | Matrix} b A column vector\n * @param {Boolean} copy Return a copy of vector b\n *\n * @return {DenseMatrix} Dense column vector b\n */\n return function solveValidation (m, b, copy) {\n const mSize = m.size()\n\n if (mSize.length !== 2) {\n throw new RangeError('Matrix must be two dimensional (size: ' + format(mSize) + ')')\n }\n\n const rows = mSize[0]\n const columns = mSize[1]\n\n if (rows !== columns) {\n throw new RangeError('Matrix must be square (size: ' + format(mSize) + ')')\n }\n\n let data = []\n\n if (isMatrix(b)) {\n const bSize = b.size()\n const bdata = b._data\n\n // 1-dim vector\n if (bSize.length === 1) {\n if (bSize[0] !== rows) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.')\n }\n\n for (let i = 0; i < rows; i++) {\n data[i] = [bdata[i]]\n }\n\n return new DenseMatrix({\n data,\n size: [rows, 1],\n datatype: b._datatype\n })\n }\n\n // 2-dim column\n if (bSize.length === 2) {\n if (bSize[0] !== rows || bSize[1] !== 1) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.')\n }\n\n if (isDenseMatrix(b)) {\n if (copy) {\n data = []\n\n for (let i = 0; i < rows; i++) {\n data[i] = [bdata[i][0]]\n }\n\n return new DenseMatrix({\n data,\n size: [rows, 1],\n datatype: b._datatype\n })\n }\n\n return b\n }\n\n if (isSparseMatrix(b)) {\n for (let i = 0; i < rows; i++) { data[i] = [0] }\n\n const values = b._values\n const index = b._index\n const ptr = b._ptr\n\n for (let k1 = ptr[1], k = ptr[0]; k < k1; k++) {\n const i = index[k]\n data[i][0] = values[k]\n }\n\n return new DenseMatrix({\n data,\n size: [rows, 1],\n datatype: b._datatype\n })\n }\n }\n\n throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.')\n }\n\n if (isArray(b)) {\n const bsize = arraySize(b)\n\n if (bsize.length === 1) {\n if (bsize[0] !== rows) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.')\n }\n\n for (let i = 0; i < rows; i++) {\n data[i] = [b[i]]\n }\n\n return new DenseMatrix({\n data,\n size: [rows, 1]\n })\n }\n\n if (bsize.length === 2) {\n if (bsize[0] !== rows || bsize[1] !== 1) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.')\n }\n\n for (let i = 0; i < rows; i++) {\n data[i] = [b[i][0]]\n }\n\n return new DenseMatrix({\n data,\n size: [rows, 1]\n })\n }\n\n throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.')\n }\n }\n}\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'lsolve'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'equalScalar',\n 'DenseMatrix'\n]\n\nexport const createLsolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n const solveValidation = createSolveValidation({ DenseMatrix })\n\n /**\n * Finds one solution of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. Throws an error if there's no solution.\n *\n * `L * x = b`\n *\n * Syntax:\n *\n * math.lsolve(L, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = lsolve(a, b) // [[-5.5], [20]]\n *\n * See also:\n *\n * lsolveAll, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} L A N x N matrix or array (L)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix | Array} A column vector with the linear system solution (x)\n */\n return typed(name, {\n\n 'SparseMatrix, Array | Matrix': function (m, b) {\n return _sparseForwardSubstitution(m, b)\n },\n\n 'DenseMatrix, Array | Matrix': function (m, b) {\n return _denseForwardSubstitution(m, b)\n },\n\n 'Array, Array | Matrix': function (a, b) {\n const m = matrix(a)\n const r = _denseForwardSubstitution(m, b)\n return r.valueOf()\n }\n })\n\n function _denseForwardSubstitution (m, b) {\n // validate matrix and vector, return copy of column vector b\n b = solveValidation(m, b, true)\n const bdata = b._data\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n // result\n const x = []\n\n const mdata = m._data\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n const bj = bdata[j][0] || 0\n let xj\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n\n const vjj = mdata[j][j]\n\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular')\n }\n\n xj = divideScalar(bj, vjj)\n\n // loop rows\n for (let i = j + 1; i < rows; i++) {\n bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]\n }\n } else {\n // degenerate row, we can choose any value\n xj = 0\n }\n\n x[j] = [xj]\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n })\n }\n\n function _sparseForwardSubstitution (m, b) {\n // validate matrix and vector, return copy of column vector b\n b = solveValidation(m, b, true)\n\n const bdata = b._data\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n\n // result\n const x = []\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n const bj = bdata[j][0] || 0\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n\n let vjj = 0\n // matrix values & indices (column j)\n const jValues = []\n const jIndices = []\n\n // first and last index in the column\n const firstIndex = ptr[j]\n const lastIndex = ptr[j + 1]\n\n // values in column, find value at [j, j]\n for (let k = firstIndex; k < lastIndex; k++) {\n const i = index[k]\n\n // check row (rows are not sorted!)\n if (i === j) {\n vjj = values[k]\n } else if (i > j) {\n // store lower triangular\n jValues.push(values[k])\n jIndices.push(i)\n }\n }\n\n // at this point we must have a value in vjj\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular')\n }\n\n const xj = divideScalar(bj, vjj)\n\n for (let k = 0, l = jIndices.length; k < l; k++) {\n const i = jIndices[k]\n bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, jValues[k]))]\n }\n\n x[j] = [xj]\n } else {\n // degenerate row, we can choose any value\n x[j] = [0]\n }\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'usolve'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'equalScalar',\n 'DenseMatrix'\n]\n\nexport const createUsolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n const solveValidation = createSolveValidation({ DenseMatrix })\n\n /**\n * Finds one solution of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. Throws an error if there's no solution.\n *\n * `U * x = b`\n *\n * Syntax:\n *\n * math.usolve(U, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = usolve(a, b) // [[8], [9]]\n *\n * See also:\n *\n * usolveAll, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} U A N x N matrix or array (U)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix | Array} A column vector with the linear system solution (x)\n */\n return typed(name, {\n\n 'SparseMatrix, Array | Matrix': function (m, b) {\n return _sparseBackwardSubstitution(m, b)\n },\n\n 'DenseMatrix, Array | Matrix': function (m, b) {\n return _denseBackwardSubstitution(m, b)\n },\n\n 'Array, Array | Matrix': function (a, b) {\n const m = matrix(a)\n const r = _denseBackwardSubstitution(m, b)\n return r.valueOf()\n }\n })\n\n function _denseBackwardSubstitution (m, b) {\n // make b into a column vector\n b = solveValidation(m, b, true)\n\n const bdata = b._data\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n // result\n const x = []\n\n const mdata = m._data\n // loop columns backwards\n for (let j = columns - 1; j >= 0; j--) {\n // b[j]\n const bj = bdata[j][0] || 0\n // x[j]\n let xj\n\n if (!equalScalar(bj, 0)) {\n // value at [j, j]\n const vjj = mdata[j][j]\n\n if (equalScalar(vjj, 0)) {\n // system cannot be solved\n throw new Error('Linear system cannot be solved since matrix is singular')\n }\n\n xj = divideScalar(bj, vjj)\n\n // loop rows\n for (let i = j - 1; i >= 0; i--) {\n // update copy of b\n bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]\n }\n } else {\n // zero value at j\n xj = 0\n }\n // update x\n x[j] = [xj]\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n })\n }\n\n function _sparseBackwardSubstitution (m, b) {\n // make b into a column vector\n b = solveValidation(m, b, true)\n\n const bdata = b._data\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n\n // result\n const x = []\n\n // loop columns backwards\n for (let j = columns - 1; j >= 0; j--) {\n const bj = bdata[j][0] || 0\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n\n let vjj = 0\n\n // upper triangular matrix values & index (column j)\n const jValues = []\n const jIndices = []\n\n // first & last indeces in column\n const firstIndex = ptr[j]\n const lastIndex = ptr[j + 1]\n\n // values in column, find value at [j, j], loop backwards\n for (let k = lastIndex - 1; k >= firstIndex; k--) {\n const i = index[k]\n\n // check row (rows are not sorted!)\n if (i === j) {\n vjj = values[k]\n } else if (i < j) {\n // store upper triangular\n jValues.push(values[k])\n jIndices.push(i)\n }\n }\n\n // at this point we must have a value in vjj\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular')\n }\n\n const xj = divideScalar(bj, vjj)\n\n for (let k = 0, lastIndex = jIndices.length; k < lastIndex; k++) {\n const i = jIndices[k]\n bdata[i] = [subtractScalar(bdata[i][0], multiplyScalar(xj, jValues[k]))]\n }\n\n x[j] = [xj]\n } else {\n // degenerate row, we can choose any value\n x[j] = [0]\n }\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n })\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'lsolveAll'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'equalScalar',\n 'DenseMatrix'\n]\n\nexport const createLsolveAll = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n const solveValidation = createSolveValidation({ DenseMatrix })\n\n /**\n * Finds all solutions of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix.\n *\n * `L * x = b`\n *\n * Syntax:\n *\n * math.lsolveAll(L, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = lsolveAll(a, b) // [ [[-5.5], [20]] ]\n *\n * See also:\n *\n * lsolve, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} L A N x N matrix or array (L)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system\n */\n return typed(name, {\n\n 'SparseMatrix, Array | Matrix': function (m, b) {\n return _sparseForwardSubstitution(m, b)\n },\n\n 'DenseMatrix, Array | Matrix': function (m, b) {\n return _denseForwardSubstitution(m, b)\n },\n\n 'Array, Array | Matrix': function (a, b) {\n const m = matrix(a)\n const R = _denseForwardSubstitution(m, b)\n return R.map(r => r.valueOf())\n }\n })\n\n function _denseForwardSubstitution (m, b_) {\n // the algorithm is derived from\n // https://www.overleaf.com/read/csvgqdxggyjv\n\n // array of right-hand sides\n const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n const M = m._data\n const rows = m._size[0]\n const columns = m._size[1]\n\n // loop columns\n for (let i = 0; i < columns; i++) {\n let L = B.length\n\n // loop right-hand sides\n for (let k = 0; k < L; k++) {\n const b = B[k]\n\n if (!equalScalar(M[i][i], 0)) {\n // non-singular row\n\n b[i] = divideScalar(b[i], M[i][i])\n\n for (let j = i + 1; j < columns; j++) {\n // b[j] -= b[i] * M[j,i]\n b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i]))\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n\n if (k === 0) {\n // There is no valid solution\n return []\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1)\n k -= 1\n L -= 1\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n\n const bNew = [...b]\n bNew[i] = 1\n\n for (let j = i + 1; j < columns; j++) {\n bNew[j] = subtractScalar(bNew[j], M[j][i])\n }\n\n B.push(bNew)\n }\n }\n }\n\n return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n }\n\n function _sparseForwardSubstitution (m, b_) {\n // array of right-hand sides\n const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n\n // loop columns\n for (let i = 0; i < columns; i++) {\n let L = B.length\n\n // loop right-hand sides\n for (let k = 0; k < L; k++) {\n const b = B[k]\n\n // values & indices (column i)\n const iValues = []\n const iIndices = []\n\n // first & last indeces in column\n const firstIndex = ptr[i]\n const lastIndex = ptr[i + 1]\n\n // find the value at [i, i]\n let Mii = 0\n for (let j = firstIndex; j < lastIndex; j++) {\n const J = index[j]\n // check row\n if (J === i) {\n Mii = values[j]\n } else if (J > i) {\n // store lower triangular\n iValues.push(values[j])\n iIndices.push(J)\n }\n }\n\n if (!equalScalar(Mii, 0)) {\n // non-singular row\n\n b[i] = divideScalar(b[i], Mii)\n\n for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n const J = iIndices[j]\n b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j]))\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n\n if (k === 0) {\n // There is no valid solution\n return []\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1)\n k -= 1\n L -= 1\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n\n const bNew = [...b]\n bNew[i] = 1\n\n for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n const J = iIndices[j]\n bNew[J] = subtractScalar(bNew[J], iValues[j])\n }\n\n B.push(bNew)\n }\n }\n }\n\n return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'usolveAll'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'equalScalar',\n 'DenseMatrix'\n]\n\nexport const createUsolveAll = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n const solveValidation = createSolveValidation({ DenseMatrix })\n\n /**\n * Finds all solutions of a linear equation system by backward substitution. Matrix must be an upper triangular matrix.\n *\n * `U * x = b`\n *\n * Syntax:\n *\n * math.usolveAll(U, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = usolveAll(a, b) // [ [[8], [9]] ]\n *\n * See also:\n *\n * usolve, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} U A N x N matrix or array (U)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system\n */\n return typed(name, {\n\n 'SparseMatrix, Array | Matrix': function (m, b) {\n return _sparseBackwardSubstitution(m, b)\n },\n\n 'DenseMatrix, Array | Matrix': function (m, b) {\n return _denseBackwardSubstitution(m, b)\n },\n\n 'Array, Array | Matrix': function (a, b) {\n const m = matrix(a)\n const R = _denseBackwardSubstitution(m, b)\n return R.map(r => r.valueOf())\n }\n })\n\n function _denseBackwardSubstitution (m, b_) {\n // the algorithm is derived from\n // https://www.overleaf.com/read/csvgqdxggyjv\n\n // array of right-hand sides\n const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n const M = m._data\n const rows = m._size[0]\n const columns = m._size[1]\n\n // loop columns backwards\n for (let i = columns - 1; i >= 0; i--) {\n let L = B.length\n\n // loop right-hand sides\n for (let k = 0; k < L; k++) {\n const b = B[k]\n\n if (!equalScalar(M[i][i], 0)) {\n // non-singular row\n\n b[i] = divideScalar(b[i], M[i][i])\n\n for (let j = i - 1; j >= 0; j--) {\n // b[j] -= b[i] * M[j,i]\n b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i]))\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n\n if (k === 0) {\n // There is no valid solution\n return []\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1)\n k -= 1\n L -= 1\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n\n const bNew = [...b]\n bNew[i] = 1\n\n for (let j = i - 1; j >= 0; j--) {\n bNew[j] = subtractScalar(bNew[j], M[j][i])\n }\n\n B.push(bNew)\n }\n }\n }\n\n return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n }\n\n function _sparseBackwardSubstitution (m, b_) {\n // array of right-hand sides\n const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n const rows = m._size[0]\n const columns = m._size[1]\n\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n\n // loop columns backwards\n for (let i = columns - 1; i >= 0; i--) {\n let L = B.length\n\n // loop right-hand sides\n for (let k = 0; k < L; k++) {\n const b = B[k]\n\n // values & indices (column i)\n const iValues = []\n const iIndices = []\n\n // first & last indeces in column\n const firstIndex = ptr[i]\n const lastIndex = ptr[i + 1]\n\n // find the value at [i, i]\n let Mii = 0\n for (let j = lastIndex - 1; j >= firstIndex; j--) {\n const J = index[j]\n // check row\n if (J === i) {\n Mii = values[j]\n } else if (J < i) {\n // store upper triangular\n iValues.push(values[j])\n iIndices.push(J)\n }\n }\n\n if (!equalScalar(Mii, 0)) {\n // non-singular row\n\n b[i] = divideScalar(b[i], Mii)\n\n // loop upper triangular\n for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n const J = iIndices[j]\n b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j]))\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n\n if (k === 0) {\n // There is no valid solution\n return []\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1)\n k -= 1\n L -= 1\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n\n const bNew = [...b]\n bNew[i] = 1\n\n // loop upper triangular\n for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n const J = iIndices[j]\n bNew[J] = subtractScalar(bNew[J], iValues[j])\n }\n\n B.push(bNew)\n }\n }\n }\n\n return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo08xS0Sid'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo08xS0Sid = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function matAlgo08xS0Sid (a, b, callback) {\n // sparse matrix arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n // sparse matrix arrays\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n const bsize = b._size\n const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n // validate dimensions\n if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n // check rows & columns\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n // sparse matrix cannot be a Pattern matrix\n if (!avalues || !bvalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrices') }\n\n // rows & columns\n const rows = asize[0]\n const columns = asize[1]\n\n // datatype\n let dt\n // equal signature to use\n let eq = equalScalar\n // zero value\n let zero = 0\n // callback signature to use\n let cf = callback\n\n // process data types\n if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n // datatype\n dt = adt\n // find signature that matches (dt, dt)\n eq = typed.find(equalScalar, [dt, dt])\n // convert 0 to the same datatype\n zero = typed.convert(0, dt)\n // callback\n cf = typed.find(callback, [dt, dt])\n }\n\n // result arrays\n const cvalues = []\n const cindex = []\n const cptr = []\n\n // workspace\n const x = []\n // marks indicating we have a value in x for a given column\n const w = []\n\n // vars\n let k, k0, k1, i\n\n // loop columns\n for (let j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length\n // columns mark\n const mark = j + 1\n // loop values in a\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]\n // mark workspace\n w[i] = mark\n // set value\n x[i] = avalues[k]\n // add index\n cindex.push(i)\n }\n // loop values in b\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]\n // check value exists in workspace\n if (w[i] === mark) {\n // evaluate callback\n x[i] = cf(x[i], bvalues[k])\n }\n }\n // initialize first index in j\n k = cptr[j]\n // loop index in j\n while (k < cindex.length) {\n // row\n i = cindex[k]\n // value @ i\n const v = x[i]\n // check for zero value\n if (!eq(v, zero)) {\n // push value\n cvalues.push(v)\n // increment pointer\n k++\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1)\n }\n }\n }\n // update cptr\n cptr[columns] = cindex.length\n\n // return sparse matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n })\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nexport const createUseMatrixForArrayScalar = /* #__PURE__ */ factory('useMatrixForArrayScalar', ['typed', 'matrix'], ({ typed, matrix }) => ({\n 'Array, number': typed.referTo('DenseMatrix, number',\n selfDn => (x, y) => selfDn(matrix(x), y).valueOf()),\n\n 'Array, BigNumber': typed.referTo('DenseMatrix, BigNumber',\n selfDB => (x, y) => selfDB(matrix(x), y).valueOf()),\n\n 'number, Array': typed.referTo('number, DenseMatrix',\n selfnD => (x, y) => selfnD(x, matrix(y)).valueOf()),\n\n 'BigNumber, Array': typed.referTo('BigNumber, DenseMatrix',\n selfBD => (x, y) => selfBD(x, matrix(y)).valueOf())\n}))\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\nimport { leftShiftNumber } from '../../plain/number/index.js'\nimport { leftShiftBigNumber } from '../../utils/bignumber/bitwise.js'\n\nconst name = 'leftShift'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createLeftShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\n\n /**\n * Bitwise left logical shift of a value x by y number of bits, `x << y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.leftShift(x, y)\n *\n * Examples:\n *\n * math.leftShift(1, 2) // returns number 4\n *\n * math.leftShift([1, 2, 4], 4) // returns Array [16, 32, 64]\n *\n * See also:\n *\n * leftShift, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted\n * @param {number | BigNumber | bigint} y Amount of shifts\n * @return {number | BigNumber | bigint | Array | Matrix} `x` shifted left `y` times\n */\n return typed(\n name,\n {\n 'number, number': leftShiftNumber,\n\n 'BigNumber, BigNumber': leftShiftBigNumber,\n\n 'bigint, bigint': (x, y) => x << y,\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo10xSids(y, x, self, true)\n }),\n\n 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo14xDs(y, x, self, true)\n })\n },\n useMatrixForArrayScalar,\n matrixAlgorithmSuite({\n SS: matAlgo08xS0Sid,\n DS: matAlgo01xDSid,\n SD: matAlgo02xDS0\n })\n )\n})\n","import { rightArithShiftBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\nimport { rightArithShiftNumber } from '../../plain/number/index.js'\n\nconst name = 'rightArithShift'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createRightArithShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\n\n /**\n * Bitwise right arithmetic shift of a value x by y number of bits, `x >> y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.rightArithShift(x, y)\n *\n * Examples:\n *\n * math.rightArithShift(4, 2) // returns number 1\n *\n * math.rightArithShift([16, -32, 64], 4) // returns Array [1, -2, 4]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted\n * @param {number | BigNumber | bigint} y Amount of shifts\n * @return {number | BigNumber | bigint | Array | Matrix} `x` zero-filled shifted right `y` times\n */\n return typed(\n name,\n {\n 'number, number': rightArithShiftNumber,\n\n 'BigNumber, BigNumber': rightArithShiftBigNumber,\n\n 'bigint, bigint': (x, y) => x >> y,\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo10xSids(y, x, self, true)\n }),\n\n 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo14xDs(y, x, self, true)\n })\n },\n useMatrixForArrayScalar,\n matrixAlgorithmSuite({\n SS: matAlgo08xS0Sid,\n DS: matAlgo01xDSid,\n SD: matAlgo02xDS0\n })\n )\n})\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { rightLogShiftNumber } from '../../plain/number/index.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\n\nconst name = 'rightLogShift'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createRightLogShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\n\n /**\n * Bitwise right logical shift of value x by y number of bits, `x >>> y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.rightLogShift(x, y)\n *\n * Examples:\n *\n * math.rightLogShift(4, 2) // returns number 1\n *\n * math.rightLogShift([16, 32, 64], 4) // returns Array [1, 2, 4]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, bitXor, leftShift, rightLogShift\n *\n * @param {number | Array | Matrix} x Value to be shifted\n * @param {number} y Amount of shifts\n * @return {number | Array | Matrix} `x` zero-filled shifted right `y` times\n */\n\n return typed(\n name,\n {\n 'number, number': rightLogShiftNumber,\n\n // 'BigNumber, BigNumber': ..., // TODO: implement BigNumber support for rightLogShift\n\n 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone()\n }\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo10xSids(y, x, self, true)\n }),\n\n 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage())\n }\n return matAlgo14xDs(y, x, self, true)\n })\n },\n useMatrixForArrayScalar,\n matrixAlgorithmSuite({\n SS: matAlgo08xS0Sid,\n DS: matAlgo01xDSid,\n SD: matAlgo02xDS0\n })\n )\n})\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { andNumber } from '../../plain/number/index.js'\n\nconst name = 'and'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'zeros',\n 'not',\n 'concat'\n]\n\nexport const createAnd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Logical `and`. Test whether two values are both defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.and(x, y)\n *\n * Examples:\n *\n * math.and(2, 4) // returns true\n *\n * a = [2, 0, 0]\n * b = [3, 7, 0]\n * c = 0\n *\n * math.and(a, b) // returns [true, false, false]\n * math.and(a, c) // returns [false, false, false]\n *\n * See also:\n *\n * not, or, xor\n *\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when both inputs are defined with a nonzero/nonempty value.\n */\n return typed(\n name,\n {\n 'number, number': andNumber,\n\n 'Complex, Complex': function (x, y) {\n return (x.re !== 0 || x.im !== 0) && (y.re !== 0 || y.im !== 0)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return !x.isZero() && !y.isZero() && !x.isNaN() && !y.isNaN()\n },\n\n 'bigint, bigint': andNumber,\n\n 'Unit, Unit': typed.referToSelf(self =>\n (x, y) => self(x.value || 0, y.value || 0)),\n\n 'SparseMatrix, any': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (not(y)) {\n // return zero matrix\n return zeros(x.size(), x.storage())\n }\n return matAlgo11xS0s(x, y, self, false)\n }),\n\n 'DenseMatrix, any': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (not(y)) {\n // return zero matrix\n return zeros(x.size(), x.storage())\n }\n return matAlgo14xDs(x, y, self, false)\n }),\n\n 'any, SparseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (not(x)) {\n // return zero matrix\n return zeros(x.size(), x.storage())\n }\n return matAlgo11xS0s(y, x, self, true)\n }),\n\n 'any, DenseMatrix': typed.referToSelf(self => (x, y) => {\n // check scalar\n if (not(x)) {\n // return zero matrix\n return zeros(x.size(), x.storage())\n }\n return matAlgo14xDs(y, x, self, true)\n }),\n\n 'Array, any': typed.referToSelf(self => (x, y) => {\n // use matrix implementation\n return self(matrix(x), y).valueOf()\n }),\n\n 'any, Array': typed.referToSelf(self => (x, y) => {\n // use matrix implementation\n return self(x, matrix(y)).valueOf()\n })\n },\n matrixAlgorithmSuite({\n SS: matAlgo06xS0S0,\n DS: matAlgo02xDS0\n })\n )\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'compare'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'equalScalar',\n 'BigNumber',\n 'Fraction',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createCompare = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, equalScalar, matrix, BigNumber, Fraction, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y.\n *\n * x and y are considered equal when the relative difference between x and y\n * is smaller than the configured absTol and relTol. The function cannot be used to\n * compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.compare(x, y)\n *\n * Examples:\n *\n * math.compare(6, 1) // returns 1\n * math.compare(2, 3) // returns -1\n * math.compare(7, 7) // returns 0\n * math.compare('10', '2') // returns 1\n * math.compare('1000', '1e3') // returns 0\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('40 mm')\n * math.compare(a, b) // returns 1\n *\n * math.compare(2, [1, 2, 3]) // returns [1, 0, -1]\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, larger, largerEq, compareNatural, compareText\n *\n * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} y Second value to compare\n * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n return typed(\n name,\n createCompareNumber({ typed, config }),\n {\n 'boolean, boolean': function (x, y) {\n return x === y ? 0 : (x > y ? 1 : -1)\n },\n\n 'BigNumber, BigNumber': function (x, y) {\n return bigNearlyEqual(x, y, config.relTol, config.absTol)\n ? new BigNumber(0)\n : new BigNumber(x.cmp(y))\n },\n\n 'bigint, bigint': function (x, y) {\n return x === y ? 0n : (x > y ? 1n : -1n)\n },\n\n 'Fraction, Fraction': function (x, y) {\n return new Fraction(x.compare(y))\n },\n\n 'Complex, Complex': function () {\n throw new TypeError('No ordering relation is defined for complex numbers')\n }\n },\n compareUnits,\n matrixAlgorithmSuite({\n SS: matAlgo05xSfSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createCompareNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return nearlyEqual(x, y, config.relTol, config.absTol)\n ? 0\n : (x > y ? 1 : -1)\n }\n })\n})\n","import naturalSort from 'javascript-natural-sort'\nimport { isDenseMatrix, isSparseMatrix, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'compareNatural'\nconst dependencies = [\n 'typed',\n 'compare'\n]\n\nexport const createCompareNatural = /* #__PURE__ */ factory(name, dependencies, ({ typed, compare }) => {\n const compareBooleans = compare.signatures['boolean,boolean']\n\n /**\n * Compare two values of any type in a deterministic, natural way.\n *\n * For numeric values, the function works the same as `math.compare`.\n * For types of values that can't be compared mathematically,\n * the function compares in a natural way.\n *\n * For numeric values, x and y are considered equal when the relative\n * difference between x and y is smaller than the configured relTol and absTol.\n * The function cannot be used to compare values smaller than\n * approximately 2.22e-16.\n *\n * For Complex numbers, first the real parts are compared. If equal,\n * the imaginary parts are compared.\n *\n * Strings are compared with a natural sorting algorithm, which\n * orders strings in a \"logic\" way following some heuristics.\n * This differs from the function `compare`, which converts the string\n * into a numeric value and compares that. The function `compareText`\n * on the other hand compares text lexically.\n *\n * Arrays and Matrices are compared value by value until there is an\n * unequal pair of values encountered. Objects are compared by sorted\n * keys until the keys or their values are unequal.\n *\n * Syntax:\n *\n * math.compareNatural(x, y)\n *\n * Examples:\n *\n * math.compareNatural(6, 1) // returns 1\n * math.compareNatural(2, 3) // returns -1\n * math.compareNatural(7, 7) // returns 0\n *\n * math.compareNatural('10', '2') // returns 1\n * math.compareText('10', '2') // returns -1\n * math.compare('10', '2') // returns 1\n *\n * math.compareNatural('Answer: 10', 'Answer: 2') // returns 1\n * math.compareText('Answer: 10', 'Answer: 2') // returns -1\n * math.compare('Answer: 10', 'Answer: 2')\n * // Error: Cannot convert \"Answer: 10\" to a number\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('40 mm')\n * math.compareNatural(a, b) // returns 1\n *\n * const c = math.complex('2 + 3i')\n * const d = math.complex('2 + 4i')\n * math.compareNatural(c, d) // returns -1\n *\n * math.compareNatural([1, 2, 4], [1, 2, 3]) // returns 1\n * math.compareNatural([1, 2, 3], [1, 2]) // returns 1\n * math.compareNatural([1, 5], [1, 2, 3]) // returns 1\n * math.compareNatural([1, 2], [1, 2]) // returns 0\n *\n * math.compareNatural({a: 2}, {a: 4}) // returns -1\n *\n * See also:\n *\n * compare, compareText\n *\n * @param {*} x First value to compare\n * @param {*} y Second value to compare\n * @return {number} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n return typed(name, { 'any, any': _compareNatural }) // just to check # args\n\n function _compareNatural (x, y) {\n const typeX = typeOf(x)\n const typeY = typeOf(y)\n let c\n\n // numeric types\n if ((typeX === 'number' || typeX === 'BigNumber' || typeX === 'Fraction') &&\n (typeY === 'number' || typeY === 'BigNumber' || typeY === 'Fraction')) {\n c = compare(x, y)\n if (c.toString() !== '0') {\n // c can be number, BigNumber, or Fraction\n return c > 0 ? 1 : -1 // return a number\n } else {\n return naturalSort(typeX, typeY)\n }\n }\n\n // matrix types\n const matTypes = ['Array', 'DenseMatrix', 'SparseMatrix']\n if (matTypes.includes(typeX) || matTypes.includes(typeY)) {\n c = compareMatricesAndArrays(_compareNatural, x, y)\n if (c !== 0) {\n return c\n } else {\n return naturalSort(typeX, typeY)\n }\n }\n\n // in case of different types, order by name of type, i.e. 'BigNumber' < 'Complex'\n if (typeX !== typeY) {\n return naturalSort(typeX, typeY)\n }\n\n if (typeX === 'Complex') {\n return compareComplexNumbers(x, y)\n }\n\n if (typeX === 'Unit') {\n if (x.equalBase(y)) {\n return _compareNatural(x.value, y.value)\n }\n\n // compare by units\n return compareArrays(_compareNatural, x.formatUnits(), y.formatUnits())\n }\n\n if (typeX === 'boolean') {\n return compareBooleans(x, y)\n }\n\n if (typeX === 'string') {\n return naturalSort(x, y)\n }\n\n if (typeX === 'Object') {\n return compareObjects(_compareNatural, x, y)\n }\n\n if (typeX === 'null') {\n return 0\n }\n\n if (typeX === 'undefined') {\n return 0\n }\n\n // this should not occur...\n throw new TypeError('Unsupported type of value \"' + typeX + '\"')\n }\n\n /**\n * Compare mixed matrix/array types, by converting to same-shaped array.\n * This comparator is non-deterministic regarding input types.\n * @param {Array | SparseMatrix | DenseMatrix | *} x\n * @param {Array | SparseMatrix | DenseMatrix | *} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n function compareMatricesAndArrays (compareNatural, x, y) {\n if (isSparseMatrix(x) && isSparseMatrix(y)) {\n return compareArrays(compareNatural, x.toJSON().values, y.toJSON().values)\n }\n if (isSparseMatrix(x)) {\n // note: convert to array is expensive\n return compareMatricesAndArrays(compareNatural, x.toArray(), y)\n }\n if (isSparseMatrix(y)) {\n // note: convert to array is expensive\n return compareMatricesAndArrays(compareNatural, x, y.toArray())\n }\n\n // convert DenseArray into Array\n if (isDenseMatrix(x)) {\n return compareMatricesAndArrays(compareNatural, x.toJSON().data, y)\n }\n if (isDenseMatrix(y)) {\n return compareMatricesAndArrays(compareNatural, x, y.toJSON().data)\n }\n\n // convert scalars to array\n if (!Array.isArray(x)) {\n return compareMatricesAndArrays(compareNatural, [x], y)\n }\n if (!Array.isArray(y)) {\n return compareMatricesAndArrays(compareNatural, x, [y])\n }\n\n return compareArrays(compareNatural, x, y)\n }\n\n /**\n * Compare two Arrays\n *\n * - First, compares value by value\n * - Next, if all corresponding values are equal,\n * look at the length: longest array will be considered largest\n *\n * @param {Array} x\n * @param {Array} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n function compareArrays (compareNatural, x, y) {\n // compare each value\n for (let i = 0, ii = Math.min(x.length, y.length); i < ii; i++) {\n const v = compareNatural(x[i], y[i])\n if (v !== 0) {\n return v\n }\n }\n\n // compare the size of the arrays\n if (x.length > y.length) { return 1 }\n if (x.length < y.length) { return -1 }\n\n // both Arrays have equal size and content\n return 0\n }\n\n /**\n * Compare two objects\n *\n * - First, compare sorted property names\n * - Next, compare the property values\n *\n * @param {Object} x\n * @param {Object} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n function compareObjects (compareNatural, x, y) {\n const keysX = Object.keys(x)\n const keysY = Object.keys(y)\n\n // compare keys\n keysX.sort(naturalSort)\n keysY.sort(naturalSort)\n const c = compareArrays(compareNatural, keysX, keysY)\n if (c !== 0) {\n return c\n }\n\n // compare values\n for (let i = 0; i < keysX.length; i++) {\n const v = compareNatural(x[keysX[i]], y[keysY[i]])\n if (v !== 0) {\n return v\n }\n }\n\n return 0\n }\n})\n\n/**\n * Compare two complex numbers, `x` and `y`:\n *\n * - First, compare the real values of `x` and `y`\n * - If equal, compare the imaginary values of `x` and `y`\n *\n * @params {Complex} x\n * @params {Complex} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\nfunction compareComplexNumbers (x, y) {\n if (x.re > y.re) { return 1 }\n if (x.re < y.re) { return -1 }\n\n if (x.im > y.im) { return 1 }\n if (x.im < y.im) { return -1 }\n\n return 0\n}\n","import { compareText as _compareText } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'compareText'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'concat'\n]\n\n_compareText.signature = 'any, any'\n\nexport const createCompareText = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, concat }) => {\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Compare two strings lexically. Comparison is case sensitive.\n * Returns 1 when x > y, -1 when x < y, and 0 when x == y.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.compareText(x, y)\n *\n * Examples:\n *\n * math.compareText('B', 'A') // returns 1\n * math.compareText('2', '10') // returns 1\n * math.compare('2', '10') // returns -1\n * math.compareNatural('2', '10') // returns -1\n *\n * math.compareText('B', ['A', 'B', 'C']) // returns [1, 0, -1]\n *\n * See also:\n *\n * equal, equalText, compare, compareNatural\n *\n * @param {string | Array | DenseMatrix} x First string to compare\n * @param {string | Array | DenseMatrix} y Second string to compare\n * @return {number | Array | DenseMatrix} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n return typed(name, _compareText, matrixAlgorithmSuite({\n elop: _compareText,\n Ds: true\n }))\n})\n\nexport const createCompareTextNumber = /* #__PURE__ */ factory(\n name, ['typed'], ({ typed }) => typed(name, _compareText)\n)\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'equal'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createEqual = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Test whether two values are equal.\n *\n * The function tests whether the relative difference between x and y is\n * smaller than the configured relTol and absTol. The function cannot be used to\n * compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * In case of complex numbers, x.re must equal y.re, and x.im must equal y.im.\n *\n * Values `null` and `undefined` are compared strictly, thus `null` is only\n * equal to `null` and nothing else, and `undefined` is only equal to\n * `undefined` and nothing else. Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.equal(x, y)\n *\n * Examples:\n *\n * math.equal(2 + 2, 3) // returns false\n * math.equal(2 + 2, 4) // returns true\n *\n * const a = math.unit('50 cm')\n * const b = math.unit('5 m')\n * math.equal(a, b) // returns true\n *\n * const c = [2, 5, 1]\n * const d = [2, 7, 1]\n *\n * math.equal(c, d) // returns [true, false, true]\n * math.deepEqual(c, d) // returns false\n *\n * math.equal(\"1000\", \"1e3\") // returns true\n * math.equal(0, null) // returns false\n *\n * See also:\n *\n * unequal, smaller, smallerEq, larger, largerEq, compare, deepEqual, equalText\n *\n * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the compared values are equal, else returns false\n */\n return typed(\n name,\n createEqualNumber({ typed, equalScalar }),\n matrixAlgorithmSuite({\n elop: equalScalar,\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createEqualNumber = factory(name, ['typed', 'equalScalar'], ({ typed, equalScalar }) => {\n return typed(name, {\n 'any, any': function (x, y) {\n // strict equality for null and undefined?\n if (x === null) { return y === null }\n if (y === null) { return x === null }\n if (x === undefined) { return y === undefined }\n if (y === undefined) { return x === undefined }\n\n return equalScalar(x, y)\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'equalText'\nconst dependencies = [\n 'typed',\n 'compareText',\n 'isZero'\n]\n\nexport const createEqualText = /* #__PURE__ */ factory(name, dependencies, ({ typed, compareText, isZero }) => {\n /**\n * Check equality of two strings. Comparison is case sensitive.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.equalText(x, y)\n *\n * Examples:\n *\n * math.equalText('Hello', 'Hello') // returns true\n * math.equalText('a', 'A') // returns false\n * math.equal('2e3', '2000') // returns true\n * math.equalText('2e3', '2000') // returns false\n *\n * math.equalText('B', ['A', 'B', 'C']) // returns [false, true, false]\n *\n * See also:\n *\n * equal, compareText, compare, compareNatural\n *\n * @param {string | Array | DenseMatrix} x First string to compare\n * @param {string | Array | DenseMatrix} y Second string to compare\n * @return {number | Array | DenseMatrix} Returns true if the values are equal, and false if not.\n */\n return typed(name, {\n 'any, any': function (x, y) {\n return isZero(compareText(x, y))\n }\n })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'smaller'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createSmaller = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Test whether value x is smaller than y.\n *\n * The function returns true when x is smaller than y and the relative\n * difference between x and y is smaller than the configured relTol and absTol. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.smaller(x, y)\n *\n * Examples:\n *\n * math.smaller(2, 3) // returns true\n * math.smaller(5, 2 * 2) // returns false\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('2 inch')\n * math.smaller(a, b) // returns true\n *\n * See also:\n *\n * equal, unequal, smallerEq, smaller, smallerEq, compare\n *\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false\n */\n return typed(\n name,\n createSmallerNumber({ typed, config }),\n {\n 'boolean, boolean': (x, y) => x < y,\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.lt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'bigint, bigint': (x, y) => x < y,\n\n 'Fraction, Fraction': (x, y) => (x.compare(y) === -1),\n\n 'Complex, Complex': function (x, y) {\n throw new TypeError('No ordering relation is defined for complex numbers')\n }\n },\n compareUnits,\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createSmallerNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return x < y && !nearlyEqual(x, y, config.relTol, config.absTol)\n }\n })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'smallerEq'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createSmallerEq = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Test whether value x is smaller or equal to y.\n *\n * The function returns true when x is smaller than y or the relative\n * difference between x and y is smaller than the configured relTol and absTol. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.smallerEq(x, y)\n *\n * Examples:\n *\n * math.smaller(1 + 2, 3) // returns false\n * math.smallerEq(1 + 2, 3) // returns true\n *\n * See also:\n *\n * equal, unequal, smaller, larger, largerEq, compare\n *\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false\n */\n return typed(\n name,\n createSmallerEqNumber({ typed, config }),\n {\n 'boolean, boolean': (x, y) => (x <= y),\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.lte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'bigint, bigint': (x, y) => (x <= y),\n\n 'Fraction, Fraction': (x, y) => (x.compare(y) !== 1),\n\n 'Complex, Complex': function () {\n throw new TypeError('No ordering relation is defined for complex numbers')\n }\n },\n compareUnits,\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createSmallerEqNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return x <= y || nearlyEqual(x, y, config.relTol, config.absTol)\n }\n })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'larger'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createLarger = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Test whether value x is larger than y.\n *\n * The function returns true when x is larger than y and the relative\n * difference between x and y is larger than the configured relTol and absTol. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.larger(x, y)\n *\n * Examples:\n *\n * math.larger(2, 3) // returns false\n * math.larger(5, 2 + 2) // returns true\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('2 inch')\n * math.larger(a, b) // returns false\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, largerEq, compare\n *\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is larger than y, else returns false\n */\n return typed(\n name,\n createLargerNumber({ typed, config }),\n {\n 'boolean, boolean': (x, y) => x > y,\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.gt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'bigint, bigint': (x, y) => x > y,\n\n 'Fraction, Fraction': (x, y) => (x.compare(y) === 1),\n\n 'Complex, Complex': function () {\n throw new TypeError('No ordering relation is defined for complex numbers')\n }\n },\n compareUnits,\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createLargerNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return x > y && !nearlyEqual(x, y, config.relTol, config.absTol)\n }\n })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'largerEq'\nconst dependencies = [\n 'typed',\n 'config',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createLargerEq = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n const compareUnits = createCompareUnits({ typed })\n\n /**\n * Test whether value x is larger or equal to y.\n *\n * The function returns true when x is larger than y or the relative\n * difference between x and y is smaller than the configured relTol and absTol. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.largerEq(x, y)\n *\n * Examples:\n *\n * math.larger(2, 1 + 1) // returns false\n * math.largerEq(2, 1 + 1) // returns true\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, larger, compare\n *\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is larger or equal to y, else returns false\n */\n return typed(\n name,\n createLargerEqNumber({ typed, config }),\n {\n 'boolean, boolean': (x, y) => x >= y,\n\n 'BigNumber, BigNumber': function (x, y) {\n return x.gte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n },\n\n 'bigint, bigint': function (x, y) {\n return x >= y\n },\n\n 'Fraction, Fraction': (x, y) => (x.compare(y) !== -1),\n\n 'Complex, Complex': function () {\n throw new TypeError('No ordering relation is defined for complex numbers')\n }\n },\n compareUnits,\n matrixAlgorithmSuite({\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n})\n\nexport const createLargerEqNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n return typed(name, {\n 'number, number': function (x, y) {\n return x >= y || nearlyEqual(x, y, config.relTol, config.absTol)\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'deepEqual'\nconst dependencies = [\n 'typed',\n 'equal'\n]\n\nexport const createDeepEqual = /* #__PURE__ */ factory(name, dependencies, ({ typed, equal }) => {\n /**\n * Test element wise whether two matrices are equal.\n * The function accepts both matrices and scalar values.\n *\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.deepEqual(x, y)\n *\n * Examples:\n *\n * math.deepEqual(2, 4) // returns false\n *\n * a = [2, 5, 1]\n * b = [2, 7, 1]\n *\n * math.deepEqual(a, b) // returns false\n * math.equal(a, b) // returns [true, false, true]\n *\n * See also:\n *\n * equal, unequal\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First matrix to compare\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second matrix to compare\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix}\n * Returns true when the input matrices have the same size and each of their elements is equal.\n */\n return typed(name, {\n 'any, any': function (x, y) {\n return _deepEqual(x.valueOf(), y.valueOf())\n }\n })\n\n /**\n * Test whether two arrays have the same size and all elements are equal\n * @param {Array | *} x\n * @param {Array | *} y\n * @return {boolean} Returns true if both arrays are deep equal\n */\n function _deepEqual (x, y) {\n if (Array.isArray(x)) {\n if (Array.isArray(y)) {\n const len = x.length\n if (len !== y.length) {\n return false\n }\n\n for (let i = 0; i < len; i++) {\n if (!_deepEqual(x[i], y[i])) {\n return false\n }\n }\n\n return true\n } else {\n return false\n }\n } else {\n if (Array.isArray(y)) {\n return false\n } else {\n return equal(x, y)\n }\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'unequal'\nconst dependencies = [\n 'typed',\n 'config',\n 'equalScalar',\n 'matrix',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createUnequal = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, equalScalar, matrix, DenseMatrix, concat }) => {\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Test whether two values are unequal.\n *\n * The function tests whether the relative difference between x and y is\n * larger than the configured relTol and absTol. The function cannot be used to compare\n * values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * In case of complex numbers, x.re must unequal y.re, or x.im must unequal y.im.\n * Strings are compared by their numerical value.\n *\n * Values `null` and `undefined` are compared strictly, thus `null` is unequal\n * with everything except `null`, and `undefined` is unequal with everything\n * except `undefined`.\n *\n * Syntax:\n *\n * math.unequal(x, y)\n *\n * Examples:\n *\n * math.unequal(2 + 2, 3) // returns true\n * math.unequal(2 + 2, 4) // returns false\n *\n * const a = math.unit('50 cm')\n * const b = math.unit('5 m')\n * math.unequal(a, b) // returns false\n *\n * const c = [2, 5, 1]\n * const d = [2, 7, 1]\n *\n * math.unequal(c, d) // returns [false, true, false]\n * math.deepEqual(c, d) // returns false\n *\n * math.unequal(0, null) // returns true\n * See also:\n *\n * equal, deepEqual, smaller, smallerEq, larger, largerEq, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the compared values are unequal, else returns false\n */\n return typed(\n name,\n createUnequalNumber({ typed, equalScalar }),\n matrixAlgorithmSuite({\n elop: _unequal,\n SS: matAlgo07xSSf,\n DS: matAlgo03xDSf,\n Ss: matAlgo12xSfs\n })\n )\n\n function _unequal (x, y) {\n return !equalScalar(x, y)\n }\n})\n\nexport const createUnequalNumber = factory(name, ['typed', 'equalScalar'], ({ typed, equalScalar }) => {\n return typed(name, {\n 'any, any': function (x, y) {\n // strict equality for null and undefined?\n if (x === null) { return y !== null }\n if (y === null) { return x !== null }\n if (x === undefined) { return y !== undefined }\n if (y === undefined) { return x !== undefined }\n\n return !equalScalar(x, y)\n }\n })\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'partitionSelect'\nconst dependencies = ['typed', 'isNumeric', 'isNaN', 'compare']\n\nexport const createPartitionSelect = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNumeric, isNaN, compare }) => {\n const asc = compare\n const desc = (a, b) => -compare(a, b)\n\n /**\n * Partition-based selection of an array or 1D matrix.\n * Will find the kth smallest value, and mutates the input array.\n * Uses Quickselect.\n *\n * Syntax:\n *\n * math.partitionSelect(x, k)\n * math.partitionSelect(x, k, compare)\n *\n * Examples:\n *\n * math.partitionSelect([5, 10, 1], 2) // returns 10\n * math.partitionSelect(['C', 'B', 'A', 'D'], 1, math.compareText) // returns 'B'\n *\n * function sortByLength (a, b) {\n * return a.length - b.length\n * }\n * math.partitionSelect(['Langdon', 'Tom', 'Sara'], 2, sortByLength) // returns 'Langdon'\n *\n * // the input array is mutated\n * arr = [5, 2, 1]\n * math.partitionSelect(arr, 0) // returns 1, arr is now: [1, 2, 5]\n * math.partitionSelect(arr, 1, 'desc') // returns 2, arr is now: [5, 2, 1]\n *\n * See also:\n *\n * sort\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to sort\n * @param {Number} k The kth smallest value to be retrieved zero-based index\n * @param {Function | 'asc' | 'desc'} [compare='asc']\n * An optional comparator function. The function is called as\n * `compare(a, b)`, and must return 1 when a > b, -1 when a < b,\n * and 0 when a == b.\n * @return {*} Returns the kth lowest value.\n */\n return typed(name, {\n 'Array | Matrix, number': function (x, k) {\n return _partitionSelect(x, k, asc)\n },\n\n 'Array | Matrix, number, string': function (x, k, compare) {\n if (compare === 'asc') {\n return _partitionSelect(x, k, asc)\n } else if (compare === 'desc') {\n return _partitionSelect(x, k, desc)\n } else {\n throw new Error('Compare string must be \"asc\" or \"desc\"')\n }\n },\n\n 'Array | Matrix, number, function': _partitionSelect\n })\n\n function _partitionSelect (x, k, compare) {\n if (!isInteger(k) || k < 0) {\n throw new Error('k must be a non-negative integer')\n }\n\n if (isMatrix(x)) {\n const size = x.size()\n if (size.length > 1) {\n throw new Error('Only one dimensional matrices supported')\n }\n return quickSelect(x.valueOf(), k, compare)\n }\n\n if (Array.isArray(x)) {\n return quickSelect(x, k, compare)\n }\n }\n\n /**\n * Quickselect algorithm.\n * Code adapted from:\n * https://blog.teamleadnet.com/2012/07/quick-select-algorithm-find-kth-element.html\n *\n * @param {Array} arr\n * @param {Number} k\n * @param {Function} compare\n * @private\n */\n function quickSelect (arr, k, compare) {\n if (k >= arr.length) {\n throw new Error('k out of bounds')\n }\n\n // check for NaN values since these can cause an infinite while loop\n for (let i = 0; i < arr.length; i++) {\n if (isNumeric(arr[i]) && isNaN(arr[i])) {\n return arr[i] // return NaN\n }\n }\n\n let from = 0\n let to = arr.length - 1\n\n // if from == to we reached the kth element\n while (from < to) {\n let r = from\n let w = to\n const pivot = arr[Math.floor(Math.random() * (to - from + 1)) + from]\n\n // stop if the reader and writer meets\n while (r < w) {\n // arr[r] >= pivot\n if (compare(arr[r], pivot) >= 0) { // put the large values at the end\n const tmp = arr[w]\n arr[w] = arr[r]\n arr[r] = tmp\n --w\n } else { // the value is smaller than the pivot, skip\n ++r\n }\n }\n\n // if we stepped up (r++) we need to step one down (arr[r] > pivot)\n if (compare(arr[r], pivot) > 0) {\n --r\n }\n\n // the r pointer is on the end of the first k elements\n if (k <= r) {\n to = r\n } else {\n from = r + 1\n }\n }\n\n return arr[k]\n }\n})\n","import { arraySize as size } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'sort'\nconst dependencies = ['typed', 'matrix', 'compare', 'compareNatural']\n\nexport const createSort = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, compare, compareNatural }) => {\n const compareAsc = compare\n const compareDesc = (a, b) => -compare(a, b)\n\n /**\n * Sort the items in a matrix.\n *\n * Syntax:\n *\n * math.sort(x)\n * math.sort(x, compare)\n *\n * Examples:\n *\n * math.sort([5, 10, 1]) // returns [1, 5, 10]\n * math.sort(['C', 'B', 'A', 'D'], math.compareNatural)\n * // returns ['A', 'B', 'C', 'D']\n *\n * function sortByLength (a, b) {\n * return a.length - b.length\n * }\n * math.sort(['Langdon', 'Tom', 'Sara'], sortByLength)\n * // returns ['Tom', 'Sara', 'Langdon']\n *\n * See also:\n *\n * filter, forEach, map, compare, compareNatural\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to sort\n * @param {Function | 'asc' | 'desc' | 'natural'} [compare='asc']\n * An optional _comparator function or name. The function is called as\n * `compare(a, b)`, and must return 1 when a > b, -1 when a < b,\n * and 0 when a == b.\n * @return {Matrix | Array} Returns the sorted matrix.\n */\n return typed(name, {\n Array: function (x) {\n _arrayIsVector(x)\n return x.sort(compareAsc)\n },\n\n Matrix: function (x) {\n _matrixIsVector(x)\n return matrix(x.toArray().sort(compareAsc), x.storage())\n },\n\n 'Array, function': function (x, _comparator) {\n _arrayIsVector(x)\n return x.sort(_comparator)\n },\n\n 'Matrix, function': function (x, _comparator) {\n _matrixIsVector(x)\n return matrix(x.toArray().sort(_comparator), x.storage())\n },\n\n 'Array, string': function (x, order) {\n _arrayIsVector(x)\n return x.sort(_comparator(order))\n },\n\n 'Matrix, string': function (x, order) {\n _matrixIsVector(x)\n return matrix(x.toArray().sort(_comparator(order)), x.storage())\n }\n })\n\n /**\n * Get the comparator for given order ('asc', 'desc', 'natural')\n * @param {'asc' | 'desc' | 'natural'} order\n * @return {Function} Returns a _comparator function\n */\n function _comparator (order) {\n if (order === 'asc') {\n return compareAsc\n } else if (order === 'desc') {\n return compareDesc\n } else if (order === 'natural') {\n return compareNatural\n } else {\n throw new Error('String \"asc\", \"desc\", or \"natural\" expected')\n }\n }\n\n /**\n * Validate whether an array is one dimensional\n * Throws an error when this is not the case\n * @param {Array} array\n * @private\n */\n function _arrayIsVector (array) {\n if (size(array).length !== 1) {\n throw new Error('One dimensional array expected')\n }\n }\n\n /**\n * Validate whether a matrix is one dimensional\n * Throws an error when this is not the case\n * @param {Matrix} matrix\n * @private\n */\n function _matrixIsVector (matrix) {\n if (matrix.size().length !== 1) {\n throw new Error('One dimensional matrix expected')\n }\n }\n})\n","import { deepForEach, reduce, containsCollections } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'max'\nconst dependencies = ['typed', 'config', 'numeric', 'larger']\n\nexport const createMax = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, larger }) => {\n /**\n * Compute the maximum value of a matrix or a list with values.\n * In case of a multidimensional array, the maximum of the flattened array\n * will be calculated. When `dim` is provided, the maximum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.max(a, b, c, ...)\n * math.max(A)\n * math.max(A, dimension)\n *\n * Examples:\n *\n * math.max(2, 1, 4, 3) // returns 4\n * math.max([2, 1, 4, 3]) // returns 4\n *\n * // maximum over a specified dimension (zero-based)\n * math.max([[2, 5], [4, 3], [1, 7]], 0) // returns [4, 7]\n * math.max([[2, 5], [4, 3], [1, 7]], 1) // returns [5, 4, 7]\n *\n * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1\n * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5\n *\n * See also:\n *\n * mean, median, min, prod, std, sum, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The maximum value\n */\n return typed(name, {\n // max([a, b, c, d, ...])\n 'Array | Matrix': _max,\n\n // max([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function (array, dim) {\n return reduce(array, dim.valueOf(), _largest)\n },\n\n // max(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('Scalar values expected in function max')\n }\n\n return _max(args)\n }\n })\n\n /**\n * Return the largest of two values\n * @param {*} x\n * @param {*} y\n * @returns {*} Returns x when x is largest, or y when y is largest\n * @private\n */\n function _largest (x, y) {\n try {\n return larger(x, y) ? x : y\n } catch (err) {\n throw improveErrorMessage(err, 'max', y)\n }\n }\n\n /**\n * Recursively calculate the maximum value in an n-dimensional array\n * @param {Array} array\n * @return {number} max\n * @private\n */\n function _max (array) {\n let res\n\n deepForEach(array, function (value) {\n try {\n if (isNaN(value) && typeof value === 'number') {\n res = NaN\n } else if (res === undefined || larger(value, res)) {\n res = value\n }\n } catch (err) {\n throw improveErrorMessage(err, 'max', value)\n }\n })\n\n if (res === undefined) {\n throw new Error('Cannot calculate max of an empty array')\n }\n\n // make sure returning numeric value: parse a string into a numeric value\n if (typeof res === 'string') {\n res = numeric(res, safeNumberType(res, config))\n }\n\n return res\n }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'min'\nconst dependencies = ['typed', 'config', 'numeric', 'smaller']\n\nexport const createMin = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, smaller }) => {\n /**\n * Compute the minimum value of a matrix or a list of values.\n * In case of a multidimensional array, the minimum of the flattened array\n * will be calculated. When `dim` is provided, the minimum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.min(a, b, c, ...)\n * math.min(A)\n * math.min(A, dimension)\n *\n * Examples:\n *\n * math.min(2, 1, 4, 3) // returns 1\n * math.min([2, 1, 4, 3]) // returns 1\n *\n * // minimum over a specified dimension (zero-based)\n * math.min([[2, 5], [4, 3], [1, 7]], 0) // returns [1, 3]\n * math.min([[2, 5], [4, 3], [1, 7]], 1) // returns [2, 3, 1]\n *\n * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1\n * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5\n *\n * See also:\n *\n * mean, median, max, prod, std, sum, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The minimum value\n */\n return typed(name, {\n // min([a, b, c, d, ...])\n 'Array | Matrix': _min,\n\n // min([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function (array, dim) {\n return reduce(array, dim.valueOf(), _smallest)\n },\n\n // min(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('Scalar values expected in function min')\n }\n\n return _min(args)\n }\n })\n\n /**\n * Return the smallest of two values\n * @param {*} x\n * @param {*} y\n * @returns {*} Returns x when x is smallest, or y when y is smallest\n * @private\n */\n function _smallest (x, y) {\n try {\n return smaller(x, y) ? x : y\n } catch (err) {\n throw improveErrorMessage(err, 'min', y)\n }\n }\n\n /**\n * Recursively calculate the minimum value in an n-dimensional array\n * @param {Array} array\n * @return {number} min\n * @private\n */\n function _min (array) {\n let min\n\n deepForEach(array, function (value) {\n try {\n if (isNaN(value) && typeof value === 'number') {\n min = NaN\n } else if (min === undefined || smaller(value, min)) {\n min = value\n }\n } catch (err) {\n throw improveErrorMessage(err, 'min', value)\n }\n })\n\n if (min === undefined) {\n throw new Error('Cannot calculate min of an empty array')\n }\n\n // make sure returning numeric value: parse a string into a numeric value\n if (typeof min === 'string') {\n min = numeric(min, safeNumberType(min, config))\n }\n\n return min\n }\n})\n","import { isArray, isMatrix, isString, typeOf } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ImmutableDenseMatrix'\nconst dependencies = [\n 'smaller',\n 'DenseMatrix'\n]\n\nexport const createImmutableDenseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ smaller, DenseMatrix }) => {\n function ImmutableDenseMatrix (data, datatype) {\n if (!(this instanceof ImmutableDenseMatrix)) { throw new SyntaxError('Constructor must be called with the new operator') }\n if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n if (isMatrix(data) || isArray(data)) {\n // use DenseMatrix implementation\n const matrix = new DenseMatrix(data, datatype)\n // internal structures\n this._data = matrix._data\n this._size = matrix._size\n this._datatype = matrix._datatype\n this._min = null\n this._max = null\n } else if (data && isArray(data.data) && isArray(data.size)) {\n // initialize fields from JSON representation\n this._data = data.data\n this._size = data.size\n this._datatype = data.datatype\n this._min = typeof data.min !== 'undefined' ? data.min : null\n this._max = typeof data.max !== 'undefined' ? data.max : null\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + typeOf(data) + ')')\n } else {\n // nothing provided\n this._data = []\n this._size = [0]\n this._datatype = datatype\n this._min = null\n this._max = null\n }\n }\n\n ImmutableDenseMatrix.prototype = new DenseMatrix()\n\n /**\n * Attach type information\n */\n ImmutableDenseMatrix.prototype.type = 'ImmutableDenseMatrix'\n ImmutableDenseMatrix.prototype.isImmutableDenseMatrix = true\n\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @param {Index} index\n * @param {Array | ImmutableDenseMatrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n ImmutableDenseMatrix.prototype.subset = function (index) {\n switch (arguments.length) {\n case 1:\n {\n // use base implementation\n const m = DenseMatrix.prototype.subset.call(this, index)\n // check result is a matrix\n if (isMatrix(m)) {\n // return immutable matrix\n return new ImmutableDenseMatrix({\n data: m._data,\n size: m._size,\n datatype: m._datatype\n })\n }\n return m\n }\n // intentional fall through\n case 2:\n case 3:\n throw new Error('Cannot invoke set subset on an Immutable Matrix instance')\n\n default:\n throw new SyntaxError('Wrong number of arguments')\n }\n }\n\n /**\n * Replace a single element in the matrix.\n * @param {Number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {ImmutableDenseMatrix} self\n */\n ImmutableDenseMatrix.prototype.set = function () {\n throw new Error('Cannot invoke set on an Immutable Matrix instance')\n }\n\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @param {Number[]} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n ImmutableDenseMatrix.prototype.resize = function () {\n throw new Error('Cannot invoke resize on an Immutable Matrix instance')\n }\n\n /**\n * Disallows reshaping in favor of immutability.\n *\n * @throws {Error} Operation not allowed\n */\n ImmutableDenseMatrix.prototype.reshape = function () {\n throw new Error('Cannot invoke reshape on an Immutable Matrix instance')\n }\n\n /**\n * Create a clone of the matrix\n * @return {ImmutableDenseMatrix} clone\n */\n ImmutableDenseMatrix.prototype.clone = function () {\n return new ImmutableDenseMatrix({\n data: clone(this._data),\n size: clone(this._size),\n datatype: this._datatype\n })\n }\n\n /**\n * Get a JSON representation of the matrix\n * @returns {Object}\n */\n ImmutableDenseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'ImmutableDenseMatrix',\n data: this._data,\n size: this._size,\n datatype: this._datatype\n }\n }\n\n /**\n * Generate a matrix from a JSON object\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ImmutableDenseMatrix\", data: [], size: []}`,\n * where mathjs is optional\n * @returns {ImmutableDenseMatrix}\n */\n ImmutableDenseMatrix.fromJSON = function (json) {\n return new ImmutableDenseMatrix(json)\n }\n\n /**\n * Swap rows i and j in Matrix.\n *\n * @param {Number} i Matrix row index 1\n * @param {Number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n ImmutableDenseMatrix.prototype.swapRows = function () {\n throw new Error('Cannot invoke swapRows on an Immutable Matrix instance')\n }\n\n /**\n * Calculate the minimum value in the set\n * @return {Number | undefined} min\n */\n ImmutableDenseMatrix.prototype.min = function () {\n // check min has been calculated before\n if (this._min === null) {\n // minimum\n let m = null\n // compute min\n this.forEach(function (v) {\n if (m === null || smaller(v, m)) { m = v }\n })\n this._min = m !== null ? m : undefined\n }\n return this._min\n }\n\n /**\n * Calculate the maximum value in the set\n * @return {Number | undefined} max\n */\n ImmutableDenseMatrix.prototype.max = function () {\n // check max has been calculated before\n if (this._max === null) {\n // maximum\n let m = null\n // compute max\n this.forEach(function (v) {\n if (m === null || smaller(m, v)) { m = v }\n })\n this._max = m !== null ? m : undefined\n }\n return this._max\n }\n\n return ImmutableDenseMatrix\n}, { isClass: true })\n","import { isArray, isMatrix, isRange } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Index'\nconst dependencies = ['ImmutableDenseMatrix', 'getMatrixDataType']\n\nexport const createIndexClass = /* #__PURE__ */ factory(name, dependencies, ({ ImmutableDenseMatrix, getMatrixDataType }) => {\n /**\n * Create an index. An Index can store ranges and sets for multiple dimensions.\n * Matrix.get, Matrix.set, and math.subset accept an Index as input.\n *\n * Usage:\n * const index = new Index(range1, range2, matrix1, array1, ...)\n *\n * Where each parameter can be any of:\n * A number\n * A string (containing a name of an object property)\n * An instance of Range\n * An Array with the Set values\n * An Array with Booleans\n * A Matrix with the Set values\n * A Matrix with Booleans\n *\n * The parameters start, end, and step must be integer numbers.\n *\n * @class Index\n * @Constructor Index\n * @param {...*} ranges\n */\n function Index (ranges) {\n if (!(this instanceof Index)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n this._dimensions = []\n this._sourceSize = []\n this._isScalar = true\n\n for (let i = 0, ii = arguments.length; i < ii; i++) {\n const arg = arguments[i]\n const argIsArray = isArray(arg)\n const argIsMatrix = isMatrix(arg)\n let sourceSize = null\n if (isRange(arg)) {\n this._dimensions.push(arg)\n this._isScalar = false\n } else if (argIsArray || argIsMatrix) {\n // create matrix\n let m\n\n if (getMatrixDataType(arg) === 'boolean') {\n if (argIsArray) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg).valueOf())\n if (argIsMatrix) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg._data).valueOf())\n sourceSize = arg.valueOf().length\n } else {\n m = _createImmutableMatrix(arg.valueOf())\n }\n\n this._dimensions.push(m)\n // size\n const size = m.size()\n // scalar\n if (size.length !== 1 || size[0] !== 1 || sourceSize !== null) {\n this._isScalar = false\n }\n } else if (typeof arg === 'number') {\n this._dimensions.push(_createImmutableMatrix([arg]))\n } else if (typeof arg === 'string') {\n // object property (arguments.count should be 1)\n this._dimensions.push(arg)\n } else {\n throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range')\n }\n this._sourceSize.push(sourceSize)\n // TODO: implement support for wildcard '*'\n }\n }\n\n /**\n * Attach type information\n */\n Index.prototype.type = 'Index'\n Index.prototype.isIndex = true\n\n function _createImmutableMatrix (arg) {\n // loop array elements\n for (let i = 0, l = arg.length; i < l; i++) {\n if (typeof arg[i] !== 'number' || !isInteger(arg[i])) {\n throw new TypeError('Index parameters must be positive integer numbers')\n }\n }\n // create matrix\n return new ImmutableDenseMatrix(arg)\n }\n\n /**\n * Create a clone of the index\n * @memberof Index\n * @return {Index} clone\n */\n Index.prototype.clone = function () {\n const index = new Index()\n index._dimensions = clone(this._dimensions)\n index._isScalar = this._isScalar\n index._sourceSize = this._sourceSize\n return index\n }\n\n /**\n * Create an index from an array with ranges/numbers\n * @memberof Index\n * @param {Array.} ranges\n * @return {Index} index\n * @private\n */\n Index.create = function (ranges) {\n const index = new Index()\n Index.apply(index, ranges)\n return index\n }\n\n /**\n * Retrieve the size of the index, the number of elements for each dimension.\n * @memberof Index\n * @returns {number[]} size\n */\n Index.prototype.size = function () {\n const size = []\n\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n const d = this._dimensions[i]\n size[i] = (typeof d === 'string') ? 1 : d.size()[0]\n }\n\n return size\n }\n\n /**\n * Get the maximum value for each of the indexes ranges.\n * @memberof Index\n * @returns {number[]} max\n */\n Index.prototype.max = function () {\n const values = []\n\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n const range = this._dimensions[i]\n values[i] = (typeof range === 'string') ? range : range.max()\n }\n\n return values\n }\n\n /**\n * Get the minimum value for each of the indexes ranges.\n * @memberof Index\n * @returns {number[]} min\n */\n Index.prototype.min = function () {\n const values = []\n\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n const range = this._dimensions[i]\n values[i] = (typeof range === 'string') ? range : range.min()\n }\n\n return values\n }\n\n /**\n * Loop over each of the ranges of the index\n * @memberof Index\n * @param {Function} callback Called for each range with a Range as first\n * argument, the dimension as second, and the\n * index object as third.\n */\n Index.prototype.forEach = function (callback) {\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n callback(this._dimensions[i], i, this)\n }\n }\n\n /**\n * Retrieve the dimension for the given index\n * @memberof Index\n * @param {Number} dim Number of the dimension\n * @returns {Range | null} range\n */\n Index.prototype.dimension = function (dim) {\n return this._dimensions[dim] || null\n }\n\n /**\n * Test whether this index contains an object property\n * @returns {boolean} Returns true if the index is an object property\n */\n Index.prototype.isObjectProperty = function () {\n return this._dimensions.length === 1 && typeof this._dimensions[0] === 'string'\n }\n\n /**\n * Returns the object property name when the Index holds a single object property,\n * else returns null\n * @returns {string | null}\n */\n Index.prototype.getObjectProperty = function () {\n return this.isObjectProperty() ? this._dimensions[0] : null\n }\n\n /**\n * Test whether this index contains only a single value.\n *\n * This is the case when the index is created with only scalar values as ranges,\n * not for ranges resolving into a single value.\n * @memberof Index\n * @return {boolean} isScalar\n */\n Index.prototype.isScalar = function () {\n return this._isScalar\n }\n\n /**\n * Expand the Index into an array.\n * For example new Index([0,3], [2,7]) returns [[0,1,2], [2,3,4,5,6]]\n * @memberof Index\n * @returns {Array} array\n */\n Index.prototype.toArray = function () {\n const array = []\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n const dimension = this._dimensions[i]\n array.push((typeof dimension === 'string') ? dimension : dimension.toArray())\n }\n return array\n }\n\n /**\n * Get the primitive value of the Index, a two dimensional array.\n * Equivalent to Index.toArray().\n * @memberof Index\n * @returns {Array} array\n */\n Index.prototype.valueOf = Index.prototype.toArray\n\n /**\n * Get the string representation of the index, for example '[2:6]' or '[0:2:10, 4:7, [1,2,3]]'\n * @memberof Index\n * @returns {String} str\n */\n Index.prototype.toString = function () {\n const strings = []\n\n for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n const dimension = this._dimensions[i]\n if (typeof dimension === 'string') {\n strings.push(JSON.stringify(dimension))\n } else {\n strings.push(dimension.toString())\n }\n }\n\n return '[' + strings.join(', ') + ']'\n }\n\n /**\n * Get a JSON representation of the Index\n * @memberof Index\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Index\", \"ranges\": [{\"mathjs\": \"Range\", start: 0, end: 10, step:1}, ...]}`\n */\n Index.prototype.toJSON = function () {\n return {\n mathjs: 'Index',\n dimensions: this._dimensions\n }\n }\n\n /**\n * Instantiate an Index from a JSON object\n * @memberof Index\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Index\", \"dimensions\": [{\"mathjs\": \"Range\", start: 0, end: 10, step:1}, ...]}`\n * @return {Index}\n */\n Index.fromJSON = function (json) {\n return Index.create(json.dimensions)\n }\n\n return Index\n}, { isClass: true })\n\n/**\n * Receives an array of booleans and returns an array of Numbers for Index\n * @param {Array} booleanArrayIndex An array of booleans\n * @return {Array} A set of numbers ready for index\n */\nfunction _booleansArrayToNumbersForIndex (booleanArrayIndex) {\n // gets an array of booleans and returns an array of numbers\n const indexOfNumbers = []\n booleanArrayIndex.forEach((bool, idx) => {\n if (bool) {\n indexOfNumbers.push(idx)\n }\n })\n return indexOfNumbers\n}\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'FibonacciHeap'\nconst dependencies = ['smaller', 'larger']\n\nexport const createFibonacciHeapClass = /* #__PURE__ */ factory(name, dependencies, ({ smaller, larger }) => {\n const oneOverLogPhi = 1.0 / Math.log((1.0 + Math.sqrt(5.0)) / 2.0)\n\n /**\n * Fibonacci Heap implementation, used interally for Matrix math.\n * @class FibonacciHeap\n * @constructor FibonacciHeap\n */\n function FibonacciHeap () {\n if (!(this instanceof FibonacciHeap)) { throw new SyntaxError('Constructor must be called with the new operator') }\n\n // initialize fields\n this._minimum = null\n this._size = 0\n }\n\n /**\n * Attach type information\n */\n FibonacciHeap.prototype.type = 'FibonacciHeap'\n FibonacciHeap.prototype.isFibonacciHeap = true\n\n /**\n * Inserts a new data element into the heap. No heap consolidation is\n * performed at this time, the new node is simply inserted into the root\n * list of this heap. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.insert = function (key, value) {\n // create node\n const node = {\n key,\n value,\n degree: 0\n }\n // check we have a node in the minimum\n if (this._minimum) {\n // minimum node\n const minimum = this._minimum\n // update left & right of node\n node.left = minimum\n node.right = minimum.right\n minimum.right = node\n node.right.left = node\n // update minimum node in heap if needed\n if (smaller(key, minimum.key)) {\n // node has a smaller key, use it as minimum\n this._minimum = node\n }\n } else {\n // set left & right\n node.left = node\n node.right = node\n // this is the first node\n this._minimum = node\n }\n // increment number of nodes in heap\n this._size++\n // return node\n return node\n }\n\n /**\n * Returns the number of nodes in heap. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.size = function () {\n return this._size\n }\n\n /**\n * Removes all elements from this heap.\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.clear = function () {\n this._minimum = null\n this._size = 0\n }\n\n /**\n * Returns true if the heap is empty, otherwise false.\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.isEmpty = function () {\n return this._size === 0\n }\n\n /**\n * Extracts the node with minimum key from heap. Amortized running\n * time: O(log n).\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.extractMinimum = function () {\n // node to remove\n const node = this._minimum\n // check we have a minimum\n if (node === null) { return node }\n // current minimum\n let minimum = this._minimum\n // get number of children\n let numberOfChildren = node.degree\n // pointer to the first child\n let x = node.child\n // for each child of node do...\n while (numberOfChildren > 0) {\n // store node in right side\n const tempRight = x.right\n // remove x from child list\n x.left.right = x.right\n x.right.left = x.left\n // add x to root list of heap\n x.left = minimum\n x.right = minimum.right\n minimum.right = x\n x.right.left = x\n // set Parent[x] to null\n x.parent = null\n x = tempRight\n numberOfChildren--\n }\n // remove node from root list of heap\n node.left.right = node.right\n node.right.left = node.left\n // update minimum\n if (node === node.right) {\n // empty\n minimum = null\n } else {\n // update minimum\n minimum = node.right\n // we need to update the pointer to the root with minimum key\n minimum = _findMinimumNode(minimum, this._size)\n }\n // decrement size of heap\n this._size--\n // update minimum\n this._minimum = minimum\n // return node\n return node\n }\n\n /**\n * Removes a node from the heap given the reference to the node. The trees\n * in the heap will be consolidated, if necessary. This operation may fail\n * to remove the correct element if there are nodes with key value -Infinity.\n * Running time: O(log n) amortized.\n * @memberof FibonacciHeap\n */\n FibonacciHeap.prototype.remove = function (node) {\n // decrease key value\n this._minimum = _decreaseKey(this._minimum, node, -1)\n // remove the smallest\n this.extractMinimum()\n }\n\n /**\n * Decreases the key value for a heap node, given the new value to take on.\n * The structure of the heap may be changed and will not be consolidated.\n * Running time: O(1) amortized.\n * @memberof FibonacciHeap\n */\n function _decreaseKey (minimum, node, key) {\n // set node key\n node.key = key\n // get parent node\n const parent = node.parent\n if (parent && smaller(node.key, parent.key)) {\n // remove node from parent\n _cut(minimum, node, parent)\n // remove all nodes from parent to the root parent\n _cascadingCut(minimum, parent)\n }\n // update minimum node if needed\n if (smaller(node.key, minimum.key)) { minimum = node }\n // return minimum\n return minimum\n }\n\n /**\n * The reverse of the link operation: removes node from the child list of parent.\n * This method assumes that min is non-null. Running time: O(1).\n * @memberof FibonacciHeap\n */\n function _cut (minimum, node, parent) {\n // remove node from parent children and decrement Degree[parent]\n node.left.right = node.right\n node.right.left = node.left\n parent.degree--\n // reset y.child if necessary\n if (parent.child === node) { parent.child = node.right }\n // remove child if degree is 0\n if (parent.degree === 0) { parent.child = null }\n // add node to root list of heap\n node.left = minimum\n node.right = minimum.right\n minimum.right = node\n node.right.left = node\n // set parent[node] to null\n node.parent = null\n // set mark[node] to false\n node.mark = false\n }\n\n /**\n * Performs a cascading cut operation. This cuts node from its parent and then\n * does the same for its parent, and so on up the tree.\n * Running time: O(log n); O(1) excluding the recursion.\n * @memberof FibonacciHeap\n */\n function _cascadingCut (minimum, node) {\n // store parent node\n const parent = node.parent\n // if there's a parent...\n if (!parent) { return }\n // if node is unmarked, set it marked\n if (!node.mark) {\n node.mark = true\n } else {\n // it's marked, cut it from parent\n _cut(minimum, node, parent)\n // cut its parent as well\n _cascadingCut(parent)\n }\n }\n\n /**\n * Make the first node a child of the second one. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n const _linkNodes = function (node, parent) {\n // remove node from root list of heap\n node.left.right = node.right\n node.right.left = node.left\n // make node a Child of parent\n node.parent = parent\n if (!parent.child) {\n parent.child = node\n node.right = node\n node.left = node\n } else {\n node.left = parent.child\n node.right = parent.child.right\n parent.child.right = node\n node.right.left = node\n }\n // increase degree[parent]\n parent.degree++\n // set mark[node] false\n node.mark = false\n }\n\n function _findMinimumNode (minimum, size) {\n // to find trees of the same degree efficiently we use an array of length O(log n) in which we keep a pointer to one root of each degree\n const arraySize = Math.floor(Math.log(size) * oneOverLogPhi) + 1\n // create list with initial capacity\n const array = new Array(arraySize)\n // find the number of root nodes.\n let numRoots = 0\n let x = minimum\n if (x) {\n numRoots++\n x = x.right\n while (x !== minimum) {\n numRoots++\n x = x.right\n }\n }\n // vars\n let y\n // For each node in root list do...\n while (numRoots > 0) {\n // access this node's degree..\n let d = x.degree\n // get next node\n const next = x.right\n // check if there is a node already in array with the same degree\n while (true) {\n // get node with the same degree is any\n y = array[d]\n if (!y) { break }\n // make one node with the same degree a child of the other, do this based on the key value.\n if (larger(x.key, y.key)) {\n const temp = y\n y = x\n x = temp\n }\n // make y a child of x\n _linkNodes(y, x)\n // we have handled this degree, go to next one.\n array[d] = null\n d++\n }\n // save this node for later when we might encounter another of the same degree.\n array[d] = x\n // move forward through list.\n x = next\n numRoots--\n }\n // Set min to null (effectively losing the root list) and reconstruct the root list from the array entries in array[].\n minimum = null\n // loop nodes in array\n for (let i = 0; i < arraySize; i++) {\n // get current node\n y = array[i]\n if (!y) { continue }\n // check if we have a linked list\n if (minimum) {\n // First remove node from root list.\n y.left.right = y.right\n y.right.left = y.left\n // now add to root list, again.\n y.left = minimum\n y.right = minimum.right\n minimum.right = y\n y.right.left = y\n // check if this is a new min.\n if (smaller(y.key, minimum.key)) { minimum = y }\n } else { minimum = y }\n }\n return minimum\n }\n\n return FibonacciHeap\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'Spa'\nconst dependencies = ['addScalar', 'equalScalar', 'FibonacciHeap']\n\nexport const createSpaClass = /* #__PURE__ */ factory(name, dependencies, ({ addScalar, equalScalar, FibonacciHeap }) => {\n /**\n * An ordered Sparse Accumulator is a representation for a sparse vector that includes a dense array\n * of the vector elements and an ordered list of non-zero elements.\n */\n function Spa () {\n if (!(this instanceof Spa)) { throw new SyntaxError('Constructor must be called with the new operator') }\n\n // allocate vector, TODO use typed arrays\n this._values = []\n this._heap = new FibonacciHeap()\n }\n\n /**\n * Attach type information\n */\n Spa.prototype.type = 'Spa'\n Spa.prototype.isSpa = true\n\n /**\n * Set the value for index i.\n *\n * @param {number} i The index\n * @param {number | BigNumber | Complex} The value at index i\n */\n Spa.prototype.set = function (i, v) {\n // check we have a value @ i\n if (!this._values[i]) {\n // insert in heap\n const node = this._heap.insert(i, v)\n // set the value @ i\n this._values[i] = node\n } else {\n // update the value @ i\n this._values[i].value = v\n }\n }\n\n Spa.prototype.get = function (i) {\n const node = this._values[i]\n if (node) { return node.value }\n return 0\n }\n\n Spa.prototype.accumulate = function (i, v) {\n // node @ i\n let node = this._values[i]\n if (!node) {\n // insert in heap\n node = this._heap.insert(i, v)\n // initialize value\n this._values[i] = node\n } else {\n // accumulate value\n node.value = addScalar(node.value, v)\n }\n }\n\n Spa.prototype.forEach = function (from, to, callback) {\n // references\n const heap = this._heap\n const values = this._values\n // nodes\n const nodes = []\n // node with minimum key, save it\n let node = heap.extractMinimum()\n if (node) { nodes.push(node) }\n // extract nodes from heap (ordered)\n while (node && node.key <= to) {\n // check it is in range\n if (node.key >= from) {\n // check value is not zero\n if (!equalScalar(node.value, 0)) {\n // invoke callback\n callback(node.key, node.value, this)\n }\n }\n // extract next node, save it\n node = heap.extractMinimum()\n if (node) { nodes.push(node) }\n }\n // reinsert all nodes in heap\n for (let i = 0; i < nodes.length; i++) {\n // current node\n const n = nodes[i]\n // insert node in heap\n node = heap.insert(n.key, n.value)\n // update values\n values[node.key] = node\n }\n }\n\n Spa.prototype.swap = function (i, j) {\n // node @ i and j\n let nodei = this._values[i]\n let nodej = this._values[j]\n // check we need to insert indeces\n if (!nodei && nodej) {\n // insert in heap\n nodei = this._heap.insert(i, nodej.value)\n // remove from heap\n this._heap.remove(nodej)\n // set values\n this._values[i] = nodei\n this._values[j] = undefined\n } else if (nodei && !nodej) {\n // insert in heap\n nodej = this._heap.insert(j, nodei.value)\n // remove from heap\n this._heap.remove(nodei)\n // set values\n this._values[j] = nodej\n this._values[i] = undefined\n } else if (nodei && nodej) {\n // swap values\n const v = nodei.value\n nodei.value = nodej.value\n nodej.value = v\n }\n }\n\n return Spa\n}, { isClass: true })\n","// (c) 2018, Mariusz Nowak\n// SPDX-License-Identifier: ISC\n// Derived from https://github.com/medikoo/lru-queue\nexport function lruQueue (limit) {\n let size = 0\n let base = 1\n let queue = Object.create(null)\n let map = Object.create(null)\n let index = 0\n const del = function (id) {\n const oldIndex = map[id]\n if (!oldIndex) return\n delete queue[oldIndex]\n delete map[id]\n --size\n if (base !== oldIndex) return\n if (!size) {\n index = 0\n base = 1\n return\n }\n while (!Object.prototype.hasOwnProperty.call(queue, ++base)) { /* empty */ }\n }\n limit = Math.abs(limit)\n return {\n hit: function (id) {\n const oldIndex = map[id]; const nuIndex = ++index\n queue[nuIndex] = id\n map[id] = nuIndex\n if (!oldIndex) {\n ++size\n if (size <= limit) return undefined\n id = queue[base]\n del(id)\n return id\n }\n delete queue[oldIndex]\n if (base !== oldIndex) return undefined\n while (!Object.prototype.hasOwnProperty.call(queue, ++base)) { /* empty */ }\n return undefined\n },\n delete: del,\n clear: function () {\n size = index = 0\n base = 1\n queue = Object.create(null)\n map = Object.create(null)\n }\n }\n}\n","// function utils\n\nimport { lruQueue } from './lruQueue.js'\n\n/**\n * Memoize a given function by caching the computed result.\n * The cache of a memoized function can be cleared by deleting the `cache`\n * property of the function.\n *\n * @param {function} fn The function to be memoized.\n * Must be a pure function.\n * @param {Object} [options]\n * @param {function(args: Array): string} [options.hasher]\n * A custom hash builder. Is JSON.stringify by default.\n * @param {number | undefined} [options.limit]\n * Maximum number of values that may be cached. Undefined indicates\n * unlimited (default)\n * @return {function} Returns the memoized function\n */\nexport function memoize (fn, { hasher, limit } = {}) {\n limit = limit == null ? Number.POSITIVE_INFINITY : limit\n hasher = hasher == null ? JSON.stringify : hasher\n\n return function memoize () {\n if (typeof memoize.cache !== 'object') {\n memoize.cache = {\n values: new Map(),\n lru: lruQueue(limit || Number.POSITIVE_INFINITY)\n }\n }\n const args = []\n for (let i = 0; i < arguments.length; i++) {\n args[i] = arguments[i]\n }\n const hash = hasher(args)\n\n if (memoize.cache.values.has(hash)) {\n memoize.cache.lru.hit(hash)\n return memoize.cache.values.get(hash)\n }\n\n const newVal = fn.apply(fn, args)\n memoize.cache.values.set(hash, newVal)\n memoize.cache.values.delete(memoize.cache.lru.hit(hash))\n\n return newVal\n }\n}\n\n/**\n * Memoize a given function by caching all results and the arguments,\n * and comparing against the arguments of previous results before\n * executing again.\n * This is less performant than `memoize` which calculates a hash,\n * which is very fast to compare. Use `memoizeCompare` only when it is\n * not possible to create a unique serializable hash from the function\n * arguments.\n * The isEqual function must compare two sets of arguments\n * and return true when equal (can be a deep equality check for example).\n * @param {function} fn\n * @param {function(a: *, b: *) : boolean} isEqual\n * @returns {function}\n */\nexport function memoizeCompare (fn, isEqual) {\n const memoize = function memoize () {\n const args = []\n for (let i = 0; i < arguments.length; i++) {\n args[i] = arguments[i]\n }\n\n for (let c = 0; c < memoize.cache.length; c++) {\n const cached = memoize.cache[c]\n\n if (isEqual(args, cached.args)) {\n // TODO: move this cache entry to the top so recently used entries move up?\n return cached.res\n }\n }\n\n const res = fn.apply(fn, args)\n memoize.cache.unshift({ args, res })\n\n return res\n }\n\n memoize.cache = []\n\n return memoize\n}\n","import { memoize } from '../function.js'\n\n/**\n * Calculate BigNumber e\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns e\n */\nexport const createBigNumberE = memoize(function (BigNumber) {\n return new BigNumber(1).exp()\n}, { hasher })\n\n/**\n * Calculate BigNumber golden ratio, phi = (1+sqrt(5))/2\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns phi\n */\nexport const createBigNumberPhi = memoize(function (BigNumber) {\n return new BigNumber(1).plus(new BigNumber(5).sqrt()).div(2)\n}, { hasher })\n\n/**\n * Calculate BigNumber pi.\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns pi\n */\nexport const createBigNumberPi = memoize(function (BigNumber) {\n return BigNumber.acos(-1)\n}, { hasher })\n\n/**\n * Calculate BigNumber tau, tau = 2 * pi\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns tau\n */\nexport const createBigNumberTau = memoize(function (BigNumber) {\n return createBigNumberPi(BigNumber).times(2)\n}, { hasher })\n\n/**\n * Create a hash for a BigNumber constructor function. The created has is\n * the configured precision\n * @param {Array} args Supposed to contain a single entry with\n * a BigNumber constructor\n * @return {number} precision\n * @private\n */\nfunction hasher (args) {\n return args[0].precision\n}\n","import { isComplex, isUnit, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { memoize } from '../../utils/function.js'\nimport { endsWith } from '../../utils/string.js'\nimport { clone, hasOwnProperty } from '../../utils/object.js'\nimport { createBigNumberPi as createPi } from '../../utils/bignumber/constants.js'\n\nconst name = 'Unit'\nconst dependencies = [\n '?on',\n 'config',\n 'addScalar',\n 'subtractScalar',\n 'multiplyScalar',\n 'divideScalar',\n 'pow',\n 'abs',\n 'fix',\n 'round',\n 'equal',\n 'isNumeric',\n 'format',\n 'number',\n 'Complex',\n 'BigNumber',\n 'Fraction'\n]\n\nexport const createUnitClass = /* #__PURE__ */ factory(name, dependencies, ({\n on,\n config,\n addScalar,\n subtractScalar,\n multiplyScalar,\n divideScalar,\n pow,\n abs,\n fix,\n round,\n equal,\n isNumeric,\n format,\n number,\n Complex,\n BigNumber,\n Fraction\n}) => {\n const toNumber = number\n /**\n * A unit can be constructed in the following ways:\n *\n * const a = new Unit(value, valuelessUnit)\n * const b = new Unit(null, valuelessUnit)\n * const c = Unit.parse(str)\n *\n * Example usage:\n *\n * const a = new Unit(5, 'cm') // 50 mm\n * const b = Unit.parse('23 kg') // 23 kg\n * const c = math.in(a, new Unit(null, 'm') // 0.05 m\n * const d = new Unit(9.81, \"m/s^2\") // 9.81 m/s^2\n *\n * @class Unit\n * @constructor Unit\n * @param {number | BigNumber | Fraction | Complex | boolean} [value] A value like 5.2\n * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like \"cm\"\n */\n function Unit (value, valuelessUnit) {\n if (!(this instanceof Unit)) {\n throw new Error('Constructor must be called with the new operator')\n }\n\n if (!(value === null || value === undefined || isNumeric(value) || isComplex(value))) {\n throw new TypeError('First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined')\n }\n\n this.fixPrefix = false // if true, function format will not search for the\n // best prefix but leave it as initially provided.\n // fixPrefix is set true by the method Unit.to\n\n // The justification behind this is that if the constructor is explicitly called,\n // the caller wishes the units to be returned exactly as supplied.\n this.skipAutomaticSimplification = true\n\n if (valuelessUnit === undefined) {\n this.units = []\n this.dimensions = BASE_DIMENSIONS.map(x => 0)\n } else if (typeof valuelessUnit === 'string') {\n const u = Unit.parse(valuelessUnit)\n this.units = u.units\n this.dimensions = u.dimensions\n } else if (isUnit(valuelessUnit) && valuelessUnit.value === null) {\n // clone from valuelessUnit\n this.fixPrefix = valuelessUnit.fixPrefix\n this.skipAutomaticSimplification = valuelessUnit.skipAutomaticSimplification\n this.dimensions = valuelessUnit.dimensions.slice(0)\n this.units = valuelessUnit.units.map(u => Object.assign({}, u))\n } else {\n throw new TypeError('Second parameter in Unit constructor must be a string or valueless Unit')\n }\n\n this.value = this._normalize(value)\n }\n\n /**\n * Attach type information\n */\n Object.defineProperty(Unit, 'name', { value: 'Unit' })\n Unit.prototype.constructor = Unit\n Unit.prototype.type = 'Unit'\n Unit.prototype.isUnit = true\n\n // private variables and functions for the Unit parser\n let text, index, c\n\n function skipWhitespace () {\n while (c === ' ' || c === '\\t') {\n next()\n }\n }\n\n function isDigitDot (c) {\n return ((c >= '0' && c <= '9') || c === '.')\n }\n\n function isDigit (c) {\n return ((c >= '0' && c <= '9'))\n }\n\n function next () {\n index++\n c = text.charAt(index)\n }\n\n function revert (oldIndex) {\n index = oldIndex\n c = text.charAt(index)\n }\n\n function parseNumber () {\n let number = ''\n const oldIndex = index\n\n if (c === '+') {\n next()\n } else if (c === '-') {\n number += c\n next()\n }\n\n if (!isDigitDot(c)) {\n // a + or - must be followed by a digit\n revert(oldIndex)\n return null\n }\n\n // get number, can have a single dot\n if (c === '.') {\n number += c\n next()\n if (!isDigit(c)) {\n // this is no legal number, it is just a dot\n revert(oldIndex)\n return null\n }\n } else {\n while (isDigit(c)) {\n number += c\n next()\n }\n if (c === '.') {\n number += c\n next()\n }\n }\n while (isDigit(c)) {\n number += c\n next()\n }\n\n // check for exponential notation like \"2.3e-4\" or \"1.23e50\"\n if (c === 'E' || c === 'e') {\n // The grammar branches here. This could either be part of an exponent or the start of a unit that begins with the letter e, such as \"4exabytes\"\n\n let tentativeNumber = ''\n const tentativeIndex = index\n\n tentativeNumber += c\n next()\n\n if (c === '+' || c === '-') {\n tentativeNumber += c\n next()\n }\n\n // Scientific notation MUST be followed by an exponent (otherwise we assume it is not scientific notation)\n if (!isDigit(c)) {\n // The e or E must belong to something else, so return the number without the e or E.\n revert(tentativeIndex)\n return number\n }\n\n // We can now safely say that this is scientific notation.\n number = number + tentativeNumber\n while (isDigit(c)) {\n number += c\n next()\n }\n }\n\n return number\n }\n\n function parseUnit () {\n let unitName = ''\n\n // Alphanumeric characters only; matches [a-zA-Z0-9]\n while (isDigit(c) || Unit.isValidAlpha(c)) {\n unitName += c\n next()\n }\n\n // Must begin with [a-zA-Z]\n const firstC = unitName.charAt(0)\n if (Unit.isValidAlpha(firstC)) {\n return unitName\n } else {\n return null\n }\n }\n\n function parseCharacter (toFind) {\n if (c === toFind) {\n next()\n return toFind\n } else {\n return null\n }\n }\n\n /**\n * Parse a string into a unit. The value of the unit is parsed as number,\n * BigNumber, or Fraction depending on the math.js config setting `number`.\n *\n * Throws an exception if the provided string does not contain a valid unit or\n * cannot be parsed.\n * @memberof Unit\n * @param {string} str A string like \"5.2 inch\", \"4e2 cm/s^2\"\n * @return {Unit} unit\n */\n Unit.parse = function (str, options) {\n options = options || {}\n text = str\n index = -1\n c = ''\n\n if (typeof text !== 'string') {\n throw new TypeError('Invalid argument in Unit.parse, string expected')\n }\n\n const unit = new Unit()\n unit.units = []\n\n let powerMultiplierCurrent = 1\n let expectingUnit = false\n\n // A unit should follow this pattern:\n // [number] ...[ [*/] unit[^number] ]\n // unit[^number] ... [ [*/] unit[^number] ]\n\n // Rules:\n // number is any floating point number.\n // unit is any alphanumeric string beginning with an alpha. Units with names like e3 should be avoided because they look like the exponent of a floating point number!\n // The string may optionally begin with a number.\n // Each unit may optionally be followed by ^number.\n // Whitespace or a forward slash is recommended between consecutive units, although the following technically is parseable:\n // 2m^2kg/s^2\n // it is not good form. If a unit starts with e, then it could be confused as a floating point number:\n // 4erg\n\n next()\n skipWhitespace()\n\n // Optional number at the start of the string\n const valueStr = parseNumber()\n let value = null\n if (valueStr) {\n if (config.number === 'BigNumber') {\n value = new BigNumber(valueStr)\n } else if (config.number === 'Fraction') {\n try {\n // not all numbers can be turned in Fractions, for example very small numbers not\n value = new Fraction(valueStr)\n } catch (err) {\n value = parseFloat(valueStr)\n }\n } else { // number\n value = parseFloat(valueStr)\n }\n\n skipWhitespace() // Whitespace is not required here\n\n // handle multiplication or division right after the value, like '1/s'\n if (parseCharacter('*')) {\n powerMultiplierCurrent = 1\n expectingUnit = true\n } else if (parseCharacter('/')) {\n powerMultiplierCurrent = -1\n expectingUnit = true\n }\n }\n\n // Stack to keep track of powerMultipliers applied to each parentheses group\n const powerMultiplierStack = []\n\n // Running product of all elements in powerMultiplierStack\n let powerMultiplierStackProduct = 1\n\n while (true) {\n skipWhitespace()\n\n // Check for and consume opening parentheses, pushing powerMultiplierCurrent to the stack\n // A '(' will always appear directly before a unit.\n while (c === '(') {\n powerMultiplierStack.push(powerMultiplierCurrent)\n powerMultiplierStackProduct *= powerMultiplierCurrent\n powerMultiplierCurrent = 1\n next()\n skipWhitespace()\n }\n\n // Is there something here?\n let uStr\n if (c) {\n const oldC = c\n uStr = parseUnit()\n if (uStr === null) {\n throw new SyntaxError('Unexpected \"' + oldC + '\" in \"' + text + '\" at index ' + index.toString())\n }\n } else {\n // End of input.\n break\n }\n\n // Verify the unit exists and get the prefix (if any)\n const res = _findUnit(uStr)\n if (res === null) {\n // Unit not found.\n throw new SyntaxError('Unit \"' + uStr + '\" not found.')\n }\n\n let power = powerMultiplierCurrent * powerMultiplierStackProduct\n // Is there a \"^ number\"?\n skipWhitespace()\n if (parseCharacter('^')) {\n skipWhitespace()\n const p = parseNumber()\n if (p === null) {\n // No valid number found for the power!\n throw new SyntaxError('In \"' + str + '\", \"^\" must be followed by a floating-point number')\n }\n power *= p\n }\n\n // Add the unit to the list\n unit.units.push({\n unit: res.unit,\n prefix: res.prefix,\n power\n })\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n unit.dimensions[i] += (res.unit.dimensions[i] || 0) * power\n }\n\n // Check for and consume closing parentheses, popping from the stack.\n // A ')' will always follow a unit.\n skipWhitespace()\n while (c === ')') {\n if (powerMultiplierStack.length === 0) {\n throw new SyntaxError('Unmatched \")\" in \"' + text + '\" at index ' + index.toString())\n }\n powerMultiplierStackProduct /= powerMultiplierStack.pop()\n next()\n skipWhitespace()\n }\n\n // \"*\" and \"/\" should mean we are expecting something to come next.\n // Is there a forward slash? If so, negate powerMultiplierCurrent. The next unit or paren group is in the denominator.\n expectingUnit = false\n\n if (parseCharacter('*')) {\n // explicit multiplication\n powerMultiplierCurrent = 1\n expectingUnit = true\n } else if (parseCharacter('/')) {\n // division\n powerMultiplierCurrent = -1\n expectingUnit = true\n } else {\n // implicit multiplication\n powerMultiplierCurrent = 1\n }\n\n // Replace the unit into the auto unit system\n if (res.unit.base) {\n const baseDim = res.unit.base.key\n UNIT_SYSTEMS.auto[baseDim] = {\n unit: res.unit,\n prefix: res.prefix\n }\n }\n }\n\n // Has the string been entirely consumed?\n skipWhitespace()\n if (c) {\n throw new SyntaxError('Could not parse: \"' + str + '\"')\n }\n\n // Is there a trailing slash?\n if (expectingUnit) {\n throw new SyntaxError('Trailing characters: \"' + str + '\"')\n }\n\n // Is the parentheses stack empty?\n if (powerMultiplierStack.length !== 0) {\n throw new SyntaxError('Unmatched \"(\" in \"' + text + '\"')\n }\n\n // Are there any units at all?\n if (unit.units.length === 0 && !options.allowNoUnits) {\n throw new SyntaxError('\"' + str + '\" contains no units')\n }\n\n unit.value = (value !== undefined) ? unit._normalize(value) : null\n return unit\n }\n\n /**\n * create a copy of this unit\n * @memberof Unit\n * @return {Unit} Returns a cloned version of the unit\n */\n Unit.prototype.clone = function () {\n const unit = new Unit()\n\n unit.fixPrefix = this.fixPrefix\n unit.skipAutomaticSimplification = this.skipAutomaticSimplification\n\n unit.value = clone(this.value)\n unit.dimensions = this.dimensions.slice(0)\n unit.units = []\n for (let i = 0; i < this.units.length; i++) {\n unit.units[i] = { }\n for (const p in this.units[i]) {\n if (hasOwnProperty(this.units[i], p)) {\n unit.units[i][p] = this.units[i][p]\n }\n }\n }\n\n return unit\n }\n\n /**\n * Return the type of the value of this unit\n *\n * @memberof Unit\n * @return {string} type of the value of the unit\n */\n Unit.prototype.valueType = function () {\n return typeOf(this.value)\n }\n\n /**\n * Return whether the unit is derived (such as m/s, or cm^2, but not N)\n * @memberof Unit\n * @return {boolean} True if the unit is derived\n * @private\n */\n Unit.prototype._isDerived = function () {\n if (this.units.length === 0) {\n return false\n }\n return this.units.length > 1 || Math.abs(this.units[0].power - 1.0) > 1e-15\n }\n\n /**\n * Normalize a value, based on its currently set unit(s)\n * @memberof Unit\n * @param {number | BigNumber | Fraction | boolean} value\n * @return {number | BigNumber | Fraction | boolean} normalized value\n * @private\n */\n Unit.prototype._normalize = function (value) {\n if (value === null || value === undefined || this.units.length === 0) {\n return value\n }\n let res = value\n const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n for (let i = 0; i < this.units.length; i++) {\n const unitValue = convert(this.units[i].unit.value)\n const unitPrefixValue = convert(this.units[i].prefix.value)\n const unitPower = convert(this.units[i].power)\n res = multiplyScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower))\n }\n\n return res\n }\n\n /**\n * Denormalize a value, based on its currently set unit(s)\n * @memberof Unit\n * @param {number} value\n * @param {number} [prefixValue] Optional prefix value to be used (ignored if this is a derived unit)\n * @return {number} denormalized value\n * @private\n */\n Unit.prototype._denormalize = function (value, prefixValue) {\n if (value === null || value === undefined || this.units.length === 0) {\n return value\n }\n let res = value\n const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n for (let i = 0; i < this.units.length; i++) {\n const unitValue = convert(this.units[i].unit.value)\n const unitPrefixValue = convert(this.units[i].prefix.value)\n const unitPower = convert(this.units[i].power)\n res = divideScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower))\n }\n\n return res\n }\n\n /**\n * Find a unit from a string\n * @memberof Unit\n * @param {string} str A string like 'cm' or 'inch'\n * @returns {Object | null} result When found, an object with fields unit and\n * prefix is returned. Else, null is returned.\n * @private\n */\n const _findUnit = memoize((str) => {\n // First, match units names exactly. For example, a user could define 'mm' as 10^-4 m, which is silly, but then we would want 'mm' to match the user-defined unit.\n if (hasOwnProperty(UNITS, str)) {\n const unit = UNITS[str]\n const prefix = unit.prefixes['']\n return { unit, prefix }\n }\n\n for (const name in UNITS) {\n if (hasOwnProperty(UNITS, name)) {\n if (endsWith(str, name)) {\n const unit = UNITS[name]\n const prefixLen = (str.length - name.length)\n const prefixName = str.substring(0, prefixLen)\n const prefix = hasOwnProperty(unit.prefixes, prefixName)\n ? unit.prefixes[prefixName]\n : undefined\n if (prefix !== undefined) {\n // store unit, prefix, and value\n return { unit, prefix }\n }\n }\n }\n }\n\n return null\n }, { hasher: (args) => args[0], limit: 100 })\n\n /**\n * Test if the given expression is a unit.\n * The unit can have a prefix but cannot have a value.\n * @memberof Unit\n * @param {string} name A string to be tested whether it is a value less unit.\n * The unit can have prefix, like \"cm\"\n * @return {boolean} true if the given string is a unit\n */\n Unit.isValuelessUnit = function (name) {\n return (_findUnit(name) !== null)\n }\n\n /**\n * check if this unit has given base unit\n * If this unit is a derived unit, this will ALWAYS return false, since by definition base units are not derived.\n * @memberof Unit\n * @param {BASE_UNIT | string | undefined} base\n */\n Unit.prototype.hasBase = function (base) {\n if (typeof (base) === 'string') {\n base = BASE_UNITS[base]\n }\n\n if (!base) { return false }\n\n // All dimensions must be the same\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n if (Math.abs((this.dimensions[i] || 0) - (base.dimensions[i] || 0)) > 1e-12) {\n return false\n }\n }\n return true\n }\n\n /**\n * Check if this unit has a base or bases equal to another base or bases\n * For derived units, the exponent on each base also must match\n * @memberof Unit\n * @param {Unit} other\n * @return {boolean} true if equal base\n */\n Unit.prototype.equalBase = function (other) {\n // All dimensions must be the same\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n if (Math.abs((this.dimensions[i] || 0) - (other.dimensions[i] || 0)) > 1e-12) {\n return false\n }\n }\n return true\n }\n\n /**\n * Check if this unit equals another unit\n * @memberof Unit\n * @param {Unit} other\n * @return {boolean} true if both units are equal\n */\n Unit.prototype.equals = function (other) {\n return (this.equalBase(other) && equal(this.value, other.value))\n }\n\n /**\n * Multiply this unit with another one or with a scalar\n * @memberof Unit\n * @param {Unit} other\n * @return {Unit} product of this unit and the other unit\n */\n Unit.prototype.multiply = function (_other) {\n const res = this.clone()\n const other = isUnit(_other) ? _other : new Unit(_other)\n\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) + (other.dimensions[i] || 0)\n }\n\n // Append other's units list onto res\n for (let i = 0; i < other.units.length; i++) {\n // Make a shallow copy of every unit\n const inverted = {\n ...other.units[i]\n }\n res.units.push(inverted)\n }\n\n // If at least one operand has a value, then the result should also have a value\n if (this.value !== null || other.value !== null) {\n const valThis = this.value === null ? this._normalize(1) : this.value\n const valOther = other.value === null ? other._normalize(1) : other.value\n res.value = multiplyScalar(valThis, valOther)\n } else {\n res.value = null\n }\n\n if (isUnit(_other)) {\n res.skipAutomaticSimplification = false\n }\n\n return getNumericIfUnitless(res)\n }\n\n /**\n * Divide a number by this unit\n *\n * @memberof Unit\n * @param {numeric} numerator\n * @param {unit} result of dividing numerator by this unit\n */\n Unit.prototype.divideInto = function (numerator) {\n return new Unit(numerator).divide(this)\n }\n\n /**\n * Divide this unit by another one\n * @memberof Unit\n * @param {Unit | numeric} other\n * @return {Unit} result of dividing this unit by the other unit\n */\n Unit.prototype.divide = function (_other) {\n const res = this.clone()\n const other = isUnit(_other) ? _other : new Unit(_other)\n\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) - (other.dimensions[i] || 0)\n }\n\n // Invert and append other's units list onto res\n for (let i = 0; i < other.units.length; i++) {\n // Make a shallow copy of every unit\n const inverted = {\n ...other.units[i],\n power: -other.units[i].power\n }\n res.units.push(inverted)\n }\n\n // If at least one operand has a value, the result should have a value\n if (this.value !== null || other.value !== null) {\n const valThis = this.value === null ? this._normalize(1) : this.value\n const valOther = other.value === null ? other._normalize(1) : other.value\n res.value = divideScalar(valThis, valOther)\n } else {\n res.value = null\n }\n\n if (isUnit(_other)) {\n res.skipAutomaticSimplification = false\n }\n\n return getNumericIfUnitless(res)\n }\n\n /**\n * Calculate the power of a unit\n * @memberof Unit\n * @param {number | Fraction | BigNumber} p\n * @returns {Unit} The result: this^p\n */\n Unit.prototype.pow = function (p) {\n const res = this.clone()\n\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) * p\n }\n\n // Adjust the power of each unit in the list\n for (let i = 0; i < res.units.length; i++) {\n res.units[i].power *= p\n }\n\n if (res.value !== null) {\n res.value = pow(res.value, p)\n\n // only allow numeric output, we don't want to return a Complex number\n // if (!isNumeric(res.value)) {\n // res.value = NaN\n // }\n // Update: Complex supported now\n } else {\n res.value = null\n }\n\n res.skipAutomaticSimplification = false\n\n return getNumericIfUnitless(res)\n }\n\n /**\n * Return the numeric value of this unit if it is dimensionless, has a value, and config.predictable == false; or the original unit otherwise\n * @param {Unit} unit\n * @returns {number | Fraction | BigNumber | Unit} The numeric value of the unit if conditions are met, or the original unit otherwise\n */\n function getNumericIfUnitless (unit) {\n if (unit.equalBase(BASE_UNITS.NONE) && unit.value !== null && !config.predictable) {\n return unit.value\n } else {\n return unit\n }\n }\n\n /**\n * Calculate the absolute value of a unit\n * @memberof Unit\n * @param {number | Fraction | BigNumber} x\n * @returns {Unit} The result: |x|, absolute value of x\n */\n Unit.prototype.abs = function () {\n const ret = this.clone()\n if (ret.value !== null) {\n if (ret._isDerived() || ret.units.length === 0 || ret.units[0].unit.offset === 0) {\n ret.value = abs(ret.value)\n } else {\n // To give the correct, but unexpected, results for units with an offset.\n // For example, abs(-283.15 degC) = -263.15 degC !!!\n // We must take the offset into consideration here\n const convert = ret._numberConverter() // convert to Fraction or BigNumber if needed\n const unitValue = convert(ret.units[0].unit.value)\n const nominalOffset = convert(ret.units[0].unit.offset)\n const unitOffset = multiplyScalar(unitValue, nominalOffset)\n ret.value = subtractScalar(abs(addScalar(ret.value, unitOffset)), unitOffset)\n }\n }\n\n for (const i in ret.units) {\n if (ret.units[i].unit.name === 'VA' || ret.units[i].unit.name === 'VAR') {\n ret.units[i].unit = UNITS.W\n }\n }\n\n return ret\n }\n\n /**\n * Convert the unit to a specific unit name.\n * @memberof Unit\n * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like \"cm\"\n * @returns {Unit} Returns a clone of the unit with a fixed prefix and unit.\n */\n Unit.prototype.to = function (valuelessUnit) {\n const value = this.value === null ? this._normalize(1) : this.value\n let other\n if (typeof valuelessUnit === 'string') {\n other = Unit.parse(valuelessUnit)\n } else if (isUnit(valuelessUnit)) {\n other = valuelessUnit.clone()\n } else {\n throw new Error('String or Unit expected as parameter')\n }\n\n if (!this.equalBase(other)) {\n throw new Error(`Units do not match ('${other.toString()}' != '${this.toString()}')`)\n }\n if (other.value !== null) {\n throw new Error('Cannot convert to a unit with a value')\n }\n\n if (this.value === null || this._isDerived() ||\n this.units.length === 0 || other.units.length === 0 ||\n this.units[0].unit.offset === other.units[0].unit.offset) {\n other.value = clone(value)\n } else {\n /* Need to adjust value by difference in offset to convert */\n const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n const thisUnitValue = this.units[0].unit.value\n const thisNominalOffset = this.units[0].unit.offset\n const thisUnitOffset = multiplyScalar(thisUnitValue, thisNominalOffset)\n\n const otherUnitValue = other.units[0].unit.value\n const otherNominalOffset = other.units[0].unit.offset\n const otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset)\n\n other.value = addScalar(value, convert(subtractScalar(thisUnitOffset, otherUnitOffset)))\n }\n other.fixPrefix = true\n other.skipAutomaticSimplification = true\n return other\n }\n\n /**\n * Return the value of the unit when represented with given valueless unit\n * @memberof Unit\n * @param {string | Unit} valuelessUnit For example 'cm' or 'inch'\n * @return {number} Returns the unit value as number.\n */\n // TODO: deprecate Unit.toNumber? It's always better to use toNumeric\n Unit.prototype.toNumber = function (valuelessUnit) {\n return toNumber(this.toNumeric(valuelessUnit))\n }\n\n /**\n * Return the value of the unit in the original numeric type\n * @memberof Unit\n * @param {string | Unit} valuelessUnit For example 'cm' or 'inch'\n * @return {number | BigNumber | Fraction} Returns the unit value\n */\n Unit.prototype.toNumeric = function (valuelessUnit) {\n let other\n if (valuelessUnit) {\n // Allow getting the numeric value without converting to a different unit\n other = this.to(valuelessUnit)\n } else {\n other = this.clone()\n }\n\n if (other._isDerived() || other.units.length === 0) {\n return other._denormalize(other.value)\n } else {\n return other._denormalize(other.value, other.units[0].prefix.value)\n }\n }\n\n /**\n * Get a string representation of the unit.\n * @memberof Unit\n * @return {string}\n */\n Unit.prototype.toString = function () {\n return this.format()\n }\n\n /**\n * Get a JSON representation of the unit\n * @memberof Unit\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Unit\", \"value\": 2, \"unit\": \"cm\", \"fixPrefix\": false}`\n */\n Unit.prototype.toJSON = function () {\n return {\n mathjs: 'Unit',\n value: this._denormalize(this.value),\n unit: this.units.length > 0 ? this.formatUnits() : null,\n fixPrefix: this.fixPrefix\n }\n }\n\n /**\n * Instantiate a Unit from a JSON object\n * @memberof Unit\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Unit\", \"value\": 2, \"unit\": \"cm\", \"fixPrefix\": false}`\n * @return {Unit}\n */\n Unit.fromJSON = function (json) {\n const unit = new Unit(json.value, json.unit ?? undefined)\n unit.fixPrefix = json.fixPrefix || false\n return unit\n }\n\n /**\n * Returns the string representation of the unit.\n * @memberof Unit\n * @return {string}\n */\n Unit.prototype.valueOf = Unit.prototype.toString\n\n /**\n * Simplify this Unit's unit list and return a new Unit with the simplified list.\n * The returned Unit will contain a list of the \"best\" units for formatting.\n */\n Unit.prototype.simplify = function () {\n const ret = this.clone()\n\n const proposedUnitList = []\n\n // Search for a matching base\n let matchingBase\n for (const key in currentUnitSystem) {\n if (hasOwnProperty(currentUnitSystem, key)) {\n if (ret.hasBase(BASE_UNITS[key])) {\n matchingBase = key\n break\n }\n }\n }\n\n if (matchingBase === 'NONE') {\n ret.units = []\n } else {\n let matchingUnit\n if (matchingBase) {\n // Does the unit system have a matching unit?\n if (hasOwnProperty(currentUnitSystem, matchingBase)) {\n matchingUnit = currentUnitSystem[matchingBase]\n }\n }\n if (matchingUnit) {\n ret.units = [{\n unit: matchingUnit.unit,\n prefix: matchingUnit.prefix,\n power: 1.0\n }]\n } else {\n // Multiple units or units with powers are formatted like this:\n // 5 (kg m^2) / (s^3 mol)\n // Build an representation from the base units of the current unit system\n let missingBaseDim = false\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n const baseDim = BASE_DIMENSIONS[i]\n if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n if (hasOwnProperty(currentUnitSystem, baseDim)) {\n proposedUnitList.push({\n unit: currentUnitSystem[baseDim].unit,\n prefix: currentUnitSystem[baseDim].prefix,\n power: ret.dimensions[i] || 0\n })\n } else {\n missingBaseDim = true\n }\n }\n }\n\n // Is the proposed unit list \"simpler\" than the existing one?\n if (proposedUnitList.length < ret.units.length && !missingBaseDim) {\n // Replace this unit list with the proposed list\n ret.units = proposedUnitList\n }\n }\n }\n\n return ret\n }\n\n /**\n * Returns a new Unit in the SI system with the same value as this one\n */\n Unit.prototype.toSI = function () {\n const ret = this.clone()\n\n const proposedUnitList = []\n\n // Multiple units or units with powers are formatted like this:\n // 5 (kg m^2) / (s^3 mol)\n // Build an representation from the base units of the SI unit system\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n const baseDim = BASE_DIMENSIONS[i]\n if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n if (hasOwnProperty(UNIT_SYSTEMS.si, baseDim)) {\n proposedUnitList.push({\n unit: UNIT_SYSTEMS.si[baseDim].unit,\n prefix: UNIT_SYSTEMS.si[baseDim].prefix,\n power: ret.dimensions[i] || 0\n })\n } else {\n throw new Error('Cannot express custom unit ' + baseDim + ' in SI units')\n }\n }\n }\n\n // Replace this unit list with the proposed list\n ret.units = proposedUnitList\n\n ret.fixPrefix = true\n ret.skipAutomaticSimplification = true\n\n if (this.value !== null) {\n ret.value = null\n return this.to(ret)\n }\n return ret\n }\n\n /**\n * Get a string representation of the units of this Unit, without the value. The unit list is formatted as-is without first being simplified.\n * @memberof Unit\n * @return {string}\n */\n Unit.prototype.formatUnits = function () {\n let strNum = ''\n let strDen = ''\n let nNum = 0\n let nDen = 0\n\n for (let i = 0; i < this.units.length; i++) {\n if (this.units[i].power > 0) {\n nNum++\n strNum += ' ' + this.units[i].prefix.name + this.units[i].unit.name\n if (Math.abs(this.units[i].power - 1.0) > 1e-15) {\n strNum += '^' + this.units[i].power\n }\n } else if (this.units[i].power < 0) {\n nDen++\n }\n }\n\n if (nDen > 0) {\n for (let i = 0; i < this.units.length; i++) {\n if (this.units[i].power < 0) {\n if (nNum > 0) {\n strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name\n if (Math.abs(this.units[i].power + 1.0) > 1e-15) {\n strDen += '^' + (-this.units[i].power)\n }\n } else {\n strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name\n strDen += '^' + (this.units[i].power)\n }\n }\n }\n }\n // Remove leading \" \"\n strNum = strNum.substr(1)\n strDen = strDen.substr(1)\n\n // Add parans for better copy/paste back into evaluate, for example, or for better pretty print formatting\n if (nNum > 1 && nDen > 0) {\n strNum = '(' + strNum + ')'\n }\n if (nDen > 1 && nNum > 0) {\n strDen = '(' + strDen + ')'\n }\n\n let str = strNum\n if (nNum > 0 && nDen > 0) {\n str += ' / '\n }\n str += strDen\n\n return str\n }\n\n /**\n * Get a string representation of the Unit, with optional formatting options.\n * @memberof Unit\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @return {string}\n */\n Unit.prototype.format = function (options) {\n // Simplfy the unit list, unless it is valueless or was created directly in the\n // constructor or as the result of to or toSI\n const simp = this.skipAutomaticSimplification || this.value === null\n ? this.clone()\n : this.simplify()\n\n // Apply some custom logic for handling VA and VAR. The goal is to express the value of the unit as a real value, if possible. Otherwise, use a real-valued unit instead of a complex-valued one.\n let isImaginary = false\n if (typeof (simp.value) !== 'undefined' && simp.value !== null && isComplex(simp.value)) {\n // TODO: Make this better, for example, use relative magnitude of re and im rather than absolute\n isImaginary = Math.abs(simp.value.re) < 1e-14\n }\n\n for (const i in simp.units) {\n if (hasOwnProperty(simp.units, i)) {\n if (simp.units[i].unit) {\n if (simp.units[i].unit.name === 'VA' && isImaginary) {\n simp.units[i].unit = UNITS.VAR\n } else if (simp.units[i].unit.name === 'VAR' && !isImaginary) {\n simp.units[i].unit = UNITS.VA\n }\n }\n }\n }\n\n // Now apply the best prefix\n // Units must have only one unit and not have the fixPrefix flag set\n if (simp.units.length === 1 && !simp.fixPrefix) {\n // Units must have integer powers, otherwise the prefix will change the\n // outputted value by not-an-integer-power-of-ten\n if (Math.abs(simp.units[0].power - Math.round(simp.units[0].power)) < 1e-14) {\n // Apply the best prefix\n simp.units[0].prefix = simp._bestPrefix()\n }\n }\n\n const value = simp._denormalize(simp.value)\n let str = (simp.value !== null) ? format(value, options || {}) : ''\n const unitStr = simp.formatUnits()\n if (simp.value && isComplex(simp.value)) {\n str = '(' + str + ')' // Surround complex values with ( ) to enable better parsing\n }\n if (unitStr.length > 0 && str.length > 0) {\n str += ' '\n }\n str += unitStr\n\n return str\n }\n\n /**\n * Calculate the best prefix using current value.\n * @memberof Unit\n * @returns {Object} prefix\n * @private\n */\n Unit.prototype._bestPrefix = function () {\n if (this.units.length !== 1) {\n throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!')\n }\n if (Math.abs(this.units[0].power - Math.round(this.units[0].power)) >= 1e-14) {\n throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!')\n }\n\n // find the best prefix value (resulting in the value of which\n // the absolute value of the log10 is closest to zero,\n // though with a little offset of 1.2 for nicer values: you get a\n // sequence 1mm 100mm 500mm 0.6m 1m 10m 100m 500m 0.6km 1km ...\n\n // Note: the units value can be any numeric type, but to find the best\n // prefix it's enough to work with limited precision of a regular number\n // Update: using mathjs abs since we also allow complex numbers\n const absValue = this.value !== null ? abs(this.value) : 0\n const absUnitValue = abs(this.units[0].unit.value)\n let bestPrefix = this.units[0].prefix\n if (absValue === 0) {\n return bestPrefix\n }\n const power = this.units[0].power\n let bestDiff = Math.log(absValue / Math.pow(bestPrefix.value * absUnitValue, power)) / Math.LN10 - 1.2\n if (bestDiff > -2.200001 && bestDiff < 1.800001) return bestPrefix // Allow the original prefix\n bestDiff = Math.abs(bestDiff)\n const prefixes = this.units[0].unit.prefixes\n for (const p in prefixes) {\n if (hasOwnProperty(prefixes, p)) {\n const prefix = prefixes[p]\n if (prefix.scientific) {\n const diff = Math.abs(\n Math.log(absValue / Math.pow(prefix.value * absUnitValue, power)) / Math.LN10 - 1.2)\n\n if (diff < bestDiff ||\n (diff === bestDiff && prefix.name.length < bestPrefix.name.length)) {\n // choose the prefix with the smallest diff, or if equal, choose the one\n // with the shortest name (can happen with SHORTLONG for example)\n bestPrefix = prefix\n bestDiff = diff\n }\n }\n }\n }\n\n return bestPrefix\n }\n\n /**\n * Returns an array of units whose sum is equal to this unit\n * @memberof Unit\n * @param {Array} [parts] An array of strings or valueless units.\n *\n * Example:\n *\n * const u = new Unit(1, 'm')\n * u.splitUnit(['feet', 'inch'])\n * [ 3 feet, 3.3700787401575 inch ]\n *\n * @return {Array} An array of units.\n */\n Unit.prototype.splitUnit = function (parts) {\n let x = this.clone()\n const ret = []\n for (let i = 0; i < parts.length; i++) {\n // Convert x to the requested unit\n x = x.to(parts[i])\n if (i === parts.length - 1) break\n\n // Get the numeric value of this unit\n const xNumeric = x.toNumeric()\n\n // Check to see if xNumeric is nearly equal to an integer,\n // since fix can incorrectly round down if there is round-off error\n const xRounded = round(xNumeric)\n let xFixed\n const isNearlyEqual = equal(xRounded, xNumeric)\n if (isNearlyEqual) {\n xFixed = xRounded\n } else {\n xFixed = fix(x.toNumeric())\n }\n\n const y = new Unit(xFixed, parts[i].toString())\n ret.push(y)\n x = subtractScalar(x, y)\n }\n\n // This little bit fixes a bug where the remainder should be 0 but is a little bit off.\n // But instead of comparing x, the remainder, with zero--we will compare the sum of\n // all the parts so far with the original value. If they are nearly equal,\n // we set the remainder to 0.\n let testSum = 0\n for (let i = 0; i < ret.length; i++) {\n testSum = addScalar(testSum, ret[i].value)\n }\n if (equal(testSum, this.value)) {\n x.value = 0\n }\n\n ret.push(x)\n\n return ret\n }\n\n const PREFIXES = {\n NONE: {\n '': { name: '', value: 1, scientific: true }\n },\n SHORT: {\n '': { name: '', value: 1, scientific: true },\n\n da: { name: 'da', value: 1e1, scientific: false },\n h: { name: 'h', value: 1e2, scientific: false },\n k: { name: 'k', value: 1e3, scientific: true },\n M: { name: 'M', value: 1e6, scientific: true },\n G: { name: 'G', value: 1e9, scientific: true },\n T: { name: 'T', value: 1e12, scientific: true },\n P: { name: 'P', value: 1e15, scientific: true },\n E: { name: 'E', value: 1e18, scientific: true },\n Z: { name: 'Z', value: 1e21, scientific: true },\n Y: { name: 'Y', value: 1e24, scientific: true },\n R: { name: 'R', value: 1e27, scientific: true },\n Q: { name: 'Q', value: 1e30, scientific: true },\n\n d: { name: 'd', value: 1e-1, scientific: false },\n c: { name: 'c', value: 1e-2, scientific: false },\n m: { name: 'm', value: 1e-3, scientific: true },\n u: { name: 'u', value: 1e-6, scientific: true },\n n: { name: 'n', value: 1e-9, scientific: true },\n p: { name: 'p', value: 1e-12, scientific: true },\n f: { name: 'f', value: 1e-15, scientific: true },\n a: { name: 'a', value: 1e-18, scientific: true },\n z: { name: 'z', value: 1e-21, scientific: true },\n y: { name: 'y', value: 1e-24, scientific: true },\n r: { name: 'r', value: 1e-27, scientific: true },\n q: { name: 'q', value: 1e-30, scientific: true }\n },\n LONG: {\n '': { name: '', value: 1, scientific: true },\n\n deca: { name: 'deca', value: 1e1, scientific: false },\n hecto: { name: 'hecto', value: 1e2, scientific: false },\n kilo: { name: 'kilo', value: 1e3, scientific: true },\n mega: { name: 'mega', value: 1e6, scientific: true },\n giga: { name: 'giga', value: 1e9, scientific: true },\n tera: { name: 'tera', value: 1e12, scientific: true },\n peta: { name: 'peta', value: 1e15, scientific: true },\n exa: { name: 'exa', value: 1e18, scientific: true },\n zetta: { name: 'zetta', value: 1e21, scientific: true },\n yotta: { name: 'yotta', value: 1e24, scientific: true },\n ronna: { name: 'ronna', value: 1e27, scientific: true },\n quetta: { name: 'quetta', value: 1e30, scientific: true },\n\n deci: { name: 'deci', value: 1e-1, scientific: false },\n centi: { name: 'centi', value: 1e-2, scientific: false },\n milli: { name: 'milli', value: 1e-3, scientific: true },\n micro: { name: 'micro', value: 1e-6, scientific: true },\n nano: { name: 'nano', value: 1e-9, scientific: true },\n pico: { name: 'pico', value: 1e-12, scientific: true },\n femto: { name: 'femto', value: 1e-15, scientific: true },\n atto: { name: 'atto', value: 1e-18, scientific: true },\n zepto: { name: 'zepto', value: 1e-21, scientific: true },\n yocto: { name: 'yocto', value: 1e-24, scientific: true },\n ronto: { name: 'ronto', value: 1e-27, scientific: true },\n quecto: { name: 'quecto', value: 1e-30, scientific: true }\n },\n SQUARED: {\n '': { name: '', value: 1, scientific: true },\n\n da: { name: 'da', value: 1e2, scientific: false },\n h: { name: 'h', value: 1e4, scientific: false },\n k: { name: 'k', value: 1e6, scientific: true },\n M: { name: 'M', value: 1e12, scientific: true },\n G: { name: 'G', value: 1e18, scientific: true },\n T: { name: 'T', value: 1e24, scientific: true },\n P: { name: 'P', value: 1e30, scientific: true },\n E: { name: 'E', value: 1e36, scientific: true },\n Z: { name: 'Z', value: 1e42, scientific: true },\n Y: { name: 'Y', value: 1e48, scientific: true },\n R: { name: 'R', value: 1e54, scientific: true },\n Q: { name: 'Q', value: 1e60, scientific: true },\n\n d: { name: 'd', value: 1e-2, scientific: false },\n c: { name: 'c', value: 1e-4, scientific: false },\n m: { name: 'm', value: 1e-6, scientific: true },\n u: { name: 'u', value: 1e-12, scientific: true },\n n: { name: 'n', value: 1e-18, scientific: true },\n p: { name: 'p', value: 1e-24, scientific: true },\n f: { name: 'f', value: 1e-30, scientific: true },\n a: { name: 'a', value: 1e-36, scientific: true },\n z: { name: 'z', value: 1e-42, scientific: true },\n y: { name: 'y', value: 1e-48, scientific: true },\n r: { name: 'r', value: 1e-54, scientific: true },\n q: { name: 'q', value: 1e-60, scientific: true }\n },\n CUBIC: {\n '': { name: '', value: 1, scientific: true },\n\n da: { name: 'da', value: 1e3, scientific: false },\n h: { name: 'h', value: 1e6, scientific: false },\n k: { name: 'k', value: 1e9, scientific: true },\n M: { name: 'M', value: 1e18, scientific: true },\n G: { name: 'G', value: 1e27, scientific: true },\n T: { name: 'T', value: 1e36, scientific: true },\n P: { name: 'P', value: 1e45, scientific: true },\n E: { name: 'E', value: 1e54, scientific: true },\n Z: { name: 'Z', value: 1e63, scientific: true },\n Y: { name: 'Y', value: 1e72, scientific: true },\n R: { name: 'R', value: 1e81, scientific: true },\n Q: { name: 'Q', value: 1e90, scientific: true },\n\n d: { name: 'd', value: 1e-3, scientific: false },\n c: { name: 'c', value: 1e-6, scientific: false },\n m: { name: 'm', value: 1e-9, scientific: true },\n u: { name: 'u', value: 1e-18, scientific: true },\n n: { name: 'n', value: 1e-27, scientific: true },\n p: { name: 'p', value: 1e-36, scientific: true },\n f: { name: 'f', value: 1e-45, scientific: true },\n a: { name: 'a', value: 1e-54, scientific: true },\n z: { name: 'z', value: 1e-63, scientific: true },\n y: { name: 'y', value: 1e-72, scientific: true },\n r: { name: 'r', value: 1e-81, scientific: true },\n q: { name: 'q', value: 1e-90, scientific: true }\n },\n BINARY_SHORT_SI: {\n '': { name: '', value: 1, scientific: true },\n k: { name: 'k', value: 1e3, scientific: true },\n M: { name: 'M', value: 1e6, scientific: true },\n G: { name: 'G', value: 1e9, scientific: true },\n T: { name: 'T', value: 1e12, scientific: true },\n P: { name: 'P', value: 1e15, scientific: true },\n E: { name: 'E', value: 1e18, scientific: true },\n Z: { name: 'Z', value: 1e21, scientific: true },\n Y: { name: 'Y', value: 1e24, scientific: true }\n },\n BINARY_SHORT_IEC: {\n '': { name: '', value: 1, scientific: true },\n Ki: { name: 'Ki', value: 1024, scientific: true },\n Mi: { name: 'Mi', value: Math.pow(1024, 2), scientific: true },\n Gi: { name: 'Gi', value: Math.pow(1024, 3), scientific: true },\n Ti: { name: 'Ti', value: Math.pow(1024, 4), scientific: true },\n Pi: { name: 'Pi', value: Math.pow(1024, 5), scientific: true },\n Ei: { name: 'Ei', value: Math.pow(1024, 6), scientific: true },\n Zi: { name: 'Zi', value: Math.pow(1024, 7), scientific: true },\n Yi: { name: 'Yi', value: Math.pow(1024, 8), scientific: true }\n },\n BINARY_LONG_SI: {\n '': { name: '', value: 1, scientific: true },\n kilo: { name: 'kilo', value: 1e3, scientific: true },\n mega: { name: 'mega', value: 1e6, scientific: true },\n giga: { name: 'giga', value: 1e9, scientific: true },\n tera: { name: 'tera', value: 1e12, scientific: true },\n peta: { name: 'peta', value: 1e15, scientific: true },\n exa: { name: 'exa', value: 1e18, scientific: true },\n zetta: { name: 'zetta', value: 1e21, scientific: true },\n yotta: { name: 'yotta', value: 1e24, scientific: true }\n },\n BINARY_LONG_IEC: {\n '': { name: '', value: 1, scientific: true },\n kibi: { name: 'kibi', value: 1024, scientific: true },\n mebi: { name: 'mebi', value: Math.pow(1024, 2), scientific: true },\n gibi: { name: 'gibi', value: Math.pow(1024, 3), scientific: true },\n tebi: { name: 'tebi', value: Math.pow(1024, 4), scientific: true },\n pebi: { name: 'pebi', value: Math.pow(1024, 5), scientific: true },\n exi: { name: 'exi', value: Math.pow(1024, 6), scientific: true },\n zebi: { name: 'zebi', value: Math.pow(1024, 7), scientific: true },\n yobi: { name: 'yobi', value: Math.pow(1024, 8), scientific: true }\n },\n BTU: {\n '': { name: '', value: 1, scientific: true },\n MM: { name: 'MM', value: 1e6, scientific: true }\n }\n }\n\n PREFIXES.SHORTLONG = Object.assign({}, PREFIXES.SHORT, PREFIXES.LONG)\n PREFIXES.BINARY_SHORT = Object.assign({}, PREFIXES.BINARY_SHORT_SI, PREFIXES.BINARY_SHORT_IEC)\n PREFIXES.BINARY_LONG = Object.assign({}, PREFIXES.BINARY_LONG_SI, PREFIXES.BINARY_LONG_IEC)\n\n /* Internally, each unit is represented by a value and a dimension array. The elements of the dimensions array have the following meaning:\n * Index Dimension\n * ----- ---------\n * 0 Length\n * 1 Mass\n * 2 Time\n * 3 Current\n * 4 Temperature\n * 5 Luminous intensity\n * 6 Amount of substance\n * 7 Angle\n * 8 Bit (digital)\n * For example, the unit \"298.15 K\" is a pure temperature and would have a value of 298.15 and a dimension array of [0, 0, 0, 0, 1, 0, 0, 0, 0]. The unit \"1 cal / (gm °C)\" can be written in terms of the 9 fundamental dimensions as [length^2] / ([time^2] * [temperature]), and would a value of (after conversion to SI) 4184.0 and a dimensions array of [2, 0, -2, 0, -1, 0, 0, 0, 0].\n *\n */\n\n const BASE_DIMENSIONS = ['MASS', 'LENGTH', 'TIME', 'CURRENT', 'TEMPERATURE', 'LUMINOUS_INTENSITY', 'AMOUNT_OF_SUBSTANCE', 'ANGLE', 'BIT']\n\n const BASE_UNITS = {\n NONE: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 0]\n },\n MASS: {\n dimensions: [1, 0, 0, 0, 0, 0, 0, 0, 0]\n },\n LENGTH: {\n dimensions: [0, 1, 0, 0, 0, 0, 0, 0, 0]\n },\n TIME: {\n dimensions: [0, 0, 1, 0, 0, 0, 0, 0, 0]\n },\n CURRENT: {\n dimensions: [0, 0, 0, 1, 0, 0, 0, 0, 0]\n },\n TEMPERATURE: {\n dimensions: [0, 0, 0, 0, 1, 0, 0, 0, 0]\n },\n LUMINOUS_INTENSITY: {\n dimensions: [0, 0, 0, 0, 0, 1, 0, 0, 0]\n },\n AMOUNT_OF_SUBSTANCE: {\n dimensions: [0, 0, 0, 0, 0, 0, 1, 0, 0]\n },\n\n FORCE: {\n dimensions: [1, 1, -2, 0, 0, 0, 0, 0, 0]\n },\n SURFACE: {\n dimensions: [0, 2, 0, 0, 0, 0, 0, 0, 0]\n },\n VOLUME: {\n dimensions: [0, 3, 0, 0, 0, 0, 0, 0, 0]\n },\n ENERGY: {\n dimensions: [1, 2, -2, 0, 0, 0, 0, 0, 0]\n },\n POWER: {\n dimensions: [1, 2, -3, 0, 0, 0, 0, 0, 0]\n },\n PRESSURE: {\n dimensions: [1, -1, -2, 0, 0, 0, 0, 0, 0]\n },\n\n ELECTRIC_CHARGE: {\n dimensions: [0, 0, 1, 1, 0, 0, 0, 0, 0]\n },\n ELECTRIC_CAPACITANCE: {\n dimensions: [-1, -2, 4, 2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_POTENTIAL: {\n dimensions: [1, 2, -3, -1, 0, 0, 0, 0, 0]\n },\n ELECTRIC_RESISTANCE: {\n dimensions: [1, 2, -3, -2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_INDUCTANCE: {\n dimensions: [1, 2, -2, -2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_CONDUCTANCE: {\n dimensions: [-1, -2, 3, 2, 0, 0, 0, 0, 0]\n },\n MAGNETIC_FLUX: {\n dimensions: [1, 2, -2, -1, 0, 0, 0, 0, 0]\n },\n MAGNETIC_FLUX_DENSITY: {\n dimensions: [1, 0, -2, -1, 0, 0, 0, 0, 0]\n },\n\n FREQUENCY: {\n dimensions: [0, 0, -1, 0, 0, 0, 0, 0, 0]\n },\n ANGLE: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 1, 0]\n },\n BIT: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 1]\n }\n }\n\n for (const key in BASE_UNITS) {\n if (hasOwnProperty(BASE_UNITS, key)) {\n BASE_UNITS[key].key = key\n }\n }\n\n const BASE_UNIT_NONE = {}\n\n const UNIT_NONE = { name: '', base: BASE_UNIT_NONE, value: 1, offset: 0, dimensions: BASE_DIMENSIONS.map(x => 0) }\n\n const UNITS = {\n // length\n meter: {\n name: 'meter',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n inch: {\n name: 'inch',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0254,\n offset: 0\n },\n foot: {\n name: 'foot',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.3048,\n offset: 0\n },\n yard: {\n name: 'yard',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.9144,\n offset: 0\n },\n mile: {\n name: 'mile',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1609.344,\n offset: 0\n },\n link: {\n name: 'link',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.201168,\n offset: 0\n },\n rod: {\n name: 'rod',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 5.0292,\n offset: 0\n },\n chain: {\n name: 'chain',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 20.1168,\n offset: 0\n },\n angstrom: {\n name: 'angstrom',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1e-10,\n offset: 0\n },\n\n m: {\n name: 'm',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n in: {\n name: 'in',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0254,\n offset: 0\n },\n ft: {\n name: 'ft',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.3048,\n offset: 0\n },\n yd: {\n name: 'yd',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.9144,\n offset: 0\n },\n mi: {\n name: 'mi',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1609.344,\n offset: 0\n },\n li: {\n name: 'li',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.201168,\n offset: 0\n },\n rd: {\n name: 'rd',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 5.029210,\n offset: 0\n },\n ch: {\n name: 'ch',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 20.1168,\n offset: 0\n },\n mil: {\n name: 'mil',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0000254,\n offset: 0\n }, // 1/1000 inch\n\n // Surface\n m2: {\n name: 'm2',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.SQUARED,\n value: 1,\n offset: 0\n },\n sqin: {\n name: 'sqin',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.00064516,\n offset: 0\n }, // 645.16 mm2\n sqft: {\n name: 'sqft',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.09290304,\n offset: 0\n }, // 0.09290304 m2\n sqyd: {\n name: 'sqyd',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.83612736,\n offset: 0\n }, // 0.83612736 m2\n sqmi: {\n name: 'sqmi',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 2589988.110336,\n offset: 0\n }, // 2.589988110336 km2\n sqrd: {\n name: 'sqrd',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 25.29295,\n offset: 0\n }, // 25.29295 m2\n sqch: {\n name: 'sqch',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 404.6873,\n offset: 0\n }, // 404.6873 m2\n sqmil: {\n name: 'sqmil',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 6.4516e-10,\n offset: 0\n }, // 6.4516 * 10^-10 m2\n acre: {\n name: 'acre',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 4046.86,\n offset: 0\n }, // 4046.86 m2\n hectare: {\n name: 'hectare',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 10000,\n offset: 0\n }, // 10000 m2\n\n // Volume\n m3: {\n name: 'm3',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.CUBIC,\n value: 1,\n offset: 0\n },\n L: {\n name: 'L',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n }, // litre\n l: {\n name: 'l',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n }, // litre\n litre: {\n name: 'litre',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.LONG,\n value: 0.001,\n offset: 0\n },\n cuin: {\n name: 'cuin',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 1.6387064e-5,\n offset: 0\n }, // 1.6387064e-5 m3\n cuft: {\n name: 'cuft',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.028316846592,\n offset: 0\n }, // 28.316 846 592 L\n cuyd: {\n name: 'cuyd',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.764554857984,\n offset: 0\n }, // 764.554 857 984 L\n teaspoon: {\n name: 'teaspoon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000005,\n offset: 0\n }, // 5 mL\n tablespoon: {\n name: 'tablespoon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000015,\n offset: 0\n }, // 15 mL\n // {name: 'cup', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.000240, offset: 0}, // 240 mL // not possible, we have already another cup\n drop: {\n name: 'drop',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 5e-8,\n offset: 0\n }, // 0.05 mL = 5e-8 m3\n gtt: {\n name: 'gtt',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 5e-8,\n offset: 0\n }, // 0.05 mL = 5e-8 m3\n\n // Liquid volume\n minim: {\n name: 'minim',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000000061611519921875,\n offset: 0\n }, // 1/61440 gallons\n fluiddram: {\n name: 'fluiddram',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0000036966911953125,\n offset: 0\n }, // 1/1024 gallons\n fluidounce: {\n name: 'fluidounce',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0000295735295625,\n offset: 0\n }, // 1/128 gallons\n gill: {\n name: 'gill',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.00011829411825,\n offset: 0\n }, // 1/32 gallons\n cc: {\n name: 'cc',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 1e-6,\n offset: 0\n }, // 1e-6 L\n cup: {\n name: 'cup',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0002365882365,\n offset: 0\n }, // 1/16 gallons\n pint: {\n name: 'pint',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000473176473,\n offset: 0\n }, // 1/8 gallons\n quart: {\n name: 'quart',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000946352946,\n offset: 0\n }, // 1/4 gallons\n gallon: {\n name: 'gallon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.003785411784,\n offset: 0\n }, // 3.785411784 L\n beerbarrel: {\n name: 'beerbarrel',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.117347765304,\n offset: 0\n }, // 31 gallons\n oilbarrel: {\n name: 'oilbarrel',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.158987294928,\n offset: 0\n }, // 42 gallons\n hogshead: {\n name: 'hogshead',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.238480942392,\n offset: 0\n }, // 63 gallons\n\n // Mass\n g: {\n name: 'g',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n },\n gram: {\n name: 'gram',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.LONG,\n value: 0.001,\n offset: 0\n },\n\n ton: {\n name: 'ton',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 907.18474,\n offset: 0\n },\n t: {\n name: 't',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 1000,\n offset: 0\n },\n tonne: {\n name: 'tonne',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.LONG,\n value: 1000,\n offset: 0\n },\n\n grain: {\n name: 'grain',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 64.79891e-6,\n offset: 0\n },\n dram: {\n name: 'dram',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 1.7718451953125e-3,\n offset: 0\n },\n ounce: {\n name: 'ounce',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 28.349523125e-3,\n offset: 0\n },\n poundmass: {\n name: 'poundmass',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 453.59237e-3,\n offset: 0\n },\n hundredweight: {\n name: 'hundredweight',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 45.359237,\n offset: 0\n },\n stick: {\n name: 'stick',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 115e-3,\n offset: 0\n },\n stone: {\n name: 'stone',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 6.35029318,\n offset: 0\n },\n\n gr: {\n name: 'gr',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 64.79891e-6,\n offset: 0\n },\n dr: {\n name: 'dr',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 1.7718451953125e-3,\n offset: 0\n },\n oz: {\n name: 'oz',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 28.349523125e-3,\n offset: 0\n },\n lbm: {\n name: 'lbm',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 453.59237e-3,\n offset: 0\n },\n cwt: {\n name: 'cwt',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 45.359237,\n offset: 0\n },\n\n // Time\n s: {\n name: 's',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n min: {\n name: 'min',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 60,\n offset: 0\n },\n h: {\n name: 'h',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3600,\n offset: 0\n },\n second: {\n name: 'second',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n sec: {\n name: 'sec',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n minute: {\n name: 'minute',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 60,\n offset: 0\n },\n hour: {\n name: 'hour',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3600,\n offset: 0\n },\n day: {\n name: 'day',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 86400,\n offset: 0\n },\n week: {\n name: 'week',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 7 * 86400,\n offset: 0\n },\n month: {\n name: 'month',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 2629800, // 1/12th of Julian year\n offset: 0\n },\n year: {\n name: 'year',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 31557600, // Julian year\n offset: 0\n },\n decade: {\n name: 'decade',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 315576000, // Julian decade\n offset: 0\n },\n century: {\n name: 'century',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3155760000, // Julian century\n offset: 0\n },\n millennium: {\n name: 'millennium',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 31557600000, // Julian millennium\n offset: 0\n },\n\n // Frequency\n hertz: {\n name: 'Hertz',\n base: BASE_UNITS.FREQUENCY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0,\n reciprocal: true\n },\n Hz: {\n name: 'Hz',\n base: BASE_UNITS.FREQUENCY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0,\n reciprocal: true\n },\n\n // Angle\n rad: {\n name: 'rad',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n radian: {\n name: 'radian',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // deg = rad / (2*pi) * 360 = rad / 0.017453292519943295769236907684888\n deg: {\n name: 'deg',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n degree: {\n name: 'degree',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n // grad = rad / (2*pi) * 400 = rad / 0.015707963267948966192313216916399\n grad: {\n name: 'grad',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n gradian: {\n name: 'gradian',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n // cycle = rad / (2*pi) = rad / 6.2831853071795864769252867665793\n cycle: {\n name: 'cycle',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n // arcsec = rad / (3600 * (360 / 2 * pi)) = rad / 0.0000048481368110953599358991410235795\n arcsec: {\n name: 'arcsec',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n // arcmin = rad / (60 * (360 / 2 * pi)) = rad / 0.00029088820866572159615394846141477\n arcmin: {\n name: 'arcmin',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null, // will be filled in by calculateAngleValues()\n offset: 0\n },\n\n // Electric current\n A: {\n name: 'A',\n base: BASE_UNITS.CURRENT,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n ampere: {\n name: 'ampere',\n base: BASE_UNITS.CURRENT,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n\n // Temperature\n // K(C) = °C + 273.15\n // K(F) = (°F + 459.67) * (5 / 9)\n // K(R) = °R * (5 / 9)\n K: {\n name: 'K',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n degC: {\n name: 'degC',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 273.15\n },\n degF: {\n name: 'degF',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.SHORT,\n value: new Fraction(5, 9),\n offset: 459.67\n },\n degR: {\n name: 'degR',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.SHORT,\n value: new Fraction(5, 9),\n offset: 0\n },\n kelvin: {\n name: 'kelvin',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n celsius: {\n name: 'celsius',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 273.15\n },\n fahrenheit: {\n name: 'fahrenheit',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.LONG,\n value: new Fraction(5, 9),\n offset: 459.67\n },\n rankine: {\n name: 'rankine',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.LONG,\n value: new Fraction(5, 9),\n offset: 0\n },\n\n // amount of substance\n mol: {\n name: 'mol',\n base: BASE_UNITS.AMOUNT_OF_SUBSTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n mole: {\n name: 'mole',\n base: BASE_UNITS.AMOUNT_OF_SUBSTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n\n // luminous intensity\n cd: {\n name: 'cd',\n base: BASE_UNITS.LUMINOUS_INTENSITY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n candela: {\n name: 'candela',\n base: BASE_UNITS.LUMINOUS_INTENSITY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // TODO: units STERADIAN\n // {name: 'sr', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0},\n // {name: 'steradian', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0},\n\n // Force\n N: {\n name: 'N',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n newton: {\n name: 'newton',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n dyn: {\n name: 'dyn',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.SHORT,\n value: 0.00001,\n offset: 0\n },\n dyne: {\n name: 'dyne',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 0.00001,\n offset: 0\n },\n lbf: {\n name: 'lbf',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 4.4482216152605,\n offset: 0\n },\n poundforce: {\n name: 'poundforce',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 4.4482216152605,\n offset: 0\n },\n kip: {\n name: 'kip',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 4448.2216,\n offset: 0\n },\n kilogramforce: {\n name: 'kilogramforce',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 9.80665,\n offset: 0\n },\n\n // Energy\n J: {\n name: 'J',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n joule: {\n name: 'joule',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n erg: {\n name: 'erg',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORTLONG, // Both kiloerg and kerg are acceptable\n value: 1e-7,\n offset: 0\n },\n Wh: {\n name: 'Wh',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 3600,\n offset: 0\n },\n BTU: {\n name: 'BTU',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.BTU,\n value: 1055.05585262,\n offset: 0\n },\n eV: {\n name: 'eV',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 1.602176565e-19,\n offset: 0\n },\n electronvolt: {\n name: 'electronvolt',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.LONG,\n value: 1.602176565e-19,\n offset: 0\n },\n\n // Power\n W: {\n name: 'W',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n watt: {\n name: 'watt',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n hp: {\n name: 'hp',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.NONE,\n value: 745.6998715386,\n offset: 0\n },\n\n // Electrical power units\n VAR: {\n name: 'VAR',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: Complex.I,\n offset: 0\n },\n\n VA: {\n name: 'VA',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n\n // Pressure\n Pa: {\n name: 'Pa',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n psi: {\n name: 'psi',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 6894.75729276459,\n offset: 0\n },\n atm: {\n name: 'atm',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 101325,\n offset: 0\n },\n bar: {\n name: 'bar',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.SHORTLONG,\n value: 100000,\n offset: 0\n },\n torr: {\n name: 'torr',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 133.322,\n offset: 0\n },\n mmHg: {\n name: 'mmHg',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 133.322,\n offset: 0\n },\n mmH2O: {\n name: 'mmH2O',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 9.80665,\n offset: 0\n },\n cmH2O: {\n name: 'cmH2O',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 98.0665,\n offset: 0\n },\n\n // Electric charge\n coulomb: {\n name: 'coulomb',\n base: BASE_UNITS.ELECTRIC_CHARGE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n C: {\n name: 'C',\n base: BASE_UNITS.ELECTRIC_CHARGE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric capacitance\n farad: {\n name: 'farad',\n base: BASE_UNITS.ELECTRIC_CAPACITANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n F: {\n name: 'F',\n base: BASE_UNITS.ELECTRIC_CAPACITANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric potential\n volt: {\n name: 'volt',\n base: BASE_UNITS.ELECTRIC_POTENTIAL,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n V: {\n name: 'V',\n base: BASE_UNITS.ELECTRIC_POTENTIAL,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric resistance\n ohm: {\n name: 'ohm',\n base: BASE_UNITS.ELECTRIC_RESISTANCE,\n prefixes: PREFIXES.SHORTLONG, // Both Mohm and megaohm are acceptable\n value: 1,\n offset: 0\n },\n /*\n * Unicode breaks in browsers if charset is not specified\n Ω: {\n name: 'Ω',\n base: BASE_UNITS.ELECTRIC_RESISTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n */\n // Electric inductance\n henry: {\n name: 'henry',\n base: BASE_UNITS.ELECTRIC_INDUCTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n H: {\n name: 'H',\n base: BASE_UNITS.ELECTRIC_INDUCTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric conductance\n siemens: {\n name: 'siemens',\n base: BASE_UNITS.ELECTRIC_CONDUCTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n S: {\n name: 'S',\n base: BASE_UNITS.ELECTRIC_CONDUCTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Magnetic flux\n weber: {\n name: 'weber',\n base: BASE_UNITS.MAGNETIC_FLUX,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n Wb: {\n name: 'Wb',\n base: BASE_UNITS.MAGNETIC_FLUX,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Magnetic flux density\n tesla: {\n name: 'tesla',\n base: BASE_UNITS.MAGNETIC_FLUX_DENSITY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n T: {\n name: 'T',\n base: BASE_UNITS.MAGNETIC_FLUX_DENSITY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n\n // Binary\n b: {\n name: 'b',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_SHORT,\n value: 1,\n offset: 0\n },\n bits: {\n name: 'bits',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_LONG,\n value: 1,\n offset: 0\n },\n B: {\n name: 'B',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_SHORT,\n value: 8,\n offset: 0\n },\n bytes: {\n name: 'bytes',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_LONG,\n value: 8,\n offset: 0\n }\n }\n\n // aliases (formerly plurals)\n // note that ALIASES is only used at creation to create more entries in UNITS by copying the aliased units\n const ALIASES = {\n meters: 'meter',\n inches: 'inch',\n feet: 'foot',\n yards: 'yard',\n miles: 'mile',\n links: 'link',\n rods: 'rod',\n chains: 'chain',\n angstroms: 'angstrom',\n\n lt: 'l',\n litres: 'litre',\n liter: 'litre',\n liters: 'litre',\n teaspoons: 'teaspoon',\n tablespoons: 'tablespoon',\n minims: 'minim',\n fldr: 'fluiddram',\n fluiddrams: 'fluiddram',\n floz: 'fluidounce',\n fluidounces: 'fluidounce',\n gi: 'gill',\n gills: 'gill',\n cp: 'cup',\n cups: 'cup',\n pt: 'pint',\n pints: 'pint',\n qt: 'quart',\n quarts: 'quart',\n gal: 'gallon',\n gallons: 'gallon',\n bbl: 'beerbarrel',\n beerbarrels: 'beerbarrel',\n obl: 'oilbarrel',\n oilbarrels: 'oilbarrel',\n hogsheads: 'hogshead',\n gtts: 'gtt',\n\n grams: 'gram',\n tons: 'ton',\n tonnes: 'tonne',\n grains: 'grain',\n drams: 'dram',\n ounces: 'ounce',\n poundmasses: 'poundmass',\n hundredweights: 'hundredweight',\n sticks: 'stick',\n lb: 'lbm',\n lbs: 'lbm',\n\n kips: 'kip',\n kgf: 'kilogramforce',\n\n acres: 'acre',\n hectares: 'hectare',\n sqfeet: 'sqft',\n sqyard: 'sqyd',\n sqmile: 'sqmi',\n sqmiles: 'sqmi',\n\n mmhg: 'mmHg',\n mmh2o: 'mmH2O',\n cmh2o: 'cmH2O',\n\n seconds: 'second',\n secs: 'second',\n minutes: 'minute',\n mins: 'minute',\n hours: 'hour',\n hr: 'hour',\n hrs: 'hour',\n days: 'day',\n weeks: 'week',\n months: 'month',\n years: 'year',\n decades: 'decade',\n centuries: 'century',\n millennia: 'millennium',\n\n hertz: 'hertz',\n\n radians: 'radian',\n degrees: 'degree',\n gradians: 'gradian',\n cycles: 'cycle',\n arcsecond: 'arcsec',\n arcseconds: 'arcsec',\n arcminute: 'arcmin',\n arcminutes: 'arcmin',\n\n BTUs: 'BTU',\n watts: 'watt',\n joules: 'joule',\n\n amperes: 'ampere',\n amps: 'ampere',\n amp: 'ampere',\n coulombs: 'coulomb',\n volts: 'volt',\n ohms: 'ohm',\n farads: 'farad',\n webers: 'weber',\n teslas: 'tesla',\n electronvolts: 'electronvolt',\n moles: 'mole',\n\n bit: 'bits',\n byte: 'bytes'\n }\n\n /**\n * Calculate the values for the angle units.\n * Value is calculated as number or BigNumber depending on the configuration\n * @param {{number: 'number' | 'BigNumber'}} config\n */\n function calculateAngleValues (config) {\n if (config.number === 'BigNumber') {\n const pi = createPi(BigNumber)\n UNITS.rad.value = new BigNumber(1)\n UNITS.deg.value = pi.div(180) // 2 * pi / 360\n UNITS.grad.value = pi.div(200) // 2 * pi / 400\n UNITS.cycle.value = pi.times(2) // 2 * pi\n UNITS.arcsec.value = pi.div(648000) // 2 * pi / 360 / 3600\n UNITS.arcmin.value = pi.div(10800) // 2 * pi / 360 / 60\n } else { // number\n UNITS.rad.value = 1\n UNITS.deg.value = Math.PI / 180 // 2 * pi / 360\n UNITS.grad.value = Math.PI / 200 // 2 * pi / 400\n UNITS.cycle.value = Math.PI * 2 // 2 * pi\n UNITS.arcsec.value = Math.PI / 648000 // 2 * pi / 360 / 3600\n UNITS.arcmin.value = Math.PI / 10800 // 2 * pi / 360 / 60\n }\n\n // copy to the full names of the angles\n UNITS.radian.value = UNITS.rad.value\n UNITS.degree.value = UNITS.deg.value\n UNITS.gradian.value = UNITS.grad.value\n }\n\n // apply the angle values now\n calculateAngleValues(config)\n\n if (on) {\n // recalculate the values on change of configuration\n on('config', function (curr, prev) {\n if (curr.number !== prev.number) {\n calculateAngleValues(curr)\n }\n })\n }\n\n /**\n * A unit system is a set of dimensionally independent base units plus a set of derived units, formed by multiplication and division of the base units, that are by convention used with the unit system.\n * A user perhaps could issue a command to select a preferred unit system, or use the default (see below).\n * Auto unit system: The default unit system is updated on the fly anytime a unit is parsed. The corresponding unit in the default unit system is updated, so that answers are given in the same units the user supplies.\n */\n const UNIT_SYSTEMS = {\n si: {\n // Base units\n NONE: { unit: UNIT_NONE, prefix: PREFIXES.NONE[''] },\n LENGTH: { unit: UNITS.m, prefix: PREFIXES.SHORT[''] },\n MASS: { unit: UNITS.g, prefix: PREFIXES.SHORT.k },\n TIME: { unit: UNITS.s, prefix: PREFIXES.SHORT[''] },\n CURRENT: { unit: UNITS.A, prefix: PREFIXES.SHORT[''] },\n TEMPERATURE: { unit: UNITS.K, prefix: PREFIXES.SHORT[''] },\n LUMINOUS_INTENSITY: { unit: UNITS.cd, prefix: PREFIXES.SHORT[''] },\n AMOUNT_OF_SUBSTANCE: { unit: UNITS.mol, prefix: PREFIXES.SHORT[''] },\n ANGLE: { unit: UNITS.rad, prefix: PREFIXES.SHORT[''] },\n BIT: { unit: UNITS.bits, prefix: PREFIXES.SHORT[''] },\n\n // Derived units\n FORCE: { unit: UNITS.N, prefix: PREFIXES.SHORT[''] },\n ENERGY: { unit: UNITS.J, prefix: PREFIXES.SHORT[''] },\n POWER: { unit: UNITS.W, prefix: PREFIXES.SHORT[''] },\n PRESSURE: { unit: UNITS.Pa, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_CHARGE: { unit: UNITS.C, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_CAPACITANCE: { unit: UNITS.F, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_POTENTIAL: { unit: UNITS.V, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_RESISTANCE: { unit: UNITS.ohm, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_INDUCTANCE: { unit: UNITS.H, prefix: PREFIXES.SHORT[''] },\n ELECTRIC_CONDUCTANCE: { unit: UNITS.S, prefix: PREFIXES.SHORT[''] },\n MAGNETIC_FLUX: { unit: UNITS.Wb, prefix: PREFIXES.SHORT[''] },\n MAGNETIC_FLUX_DENSITY: { unit: UNITS.T, prefix: PREFIXES.SHORT[''] },\n FREQUENCY: { unit: UNITS.Hz, prefix: PREFIXES.SHORT[''] }\n }\n }\n\n // Clone to create the other unit systems\n UNIT_SYSTEMS.cgs = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si))\n UNIT_SYSTEMS.cgs.LENGTH = { unit: UNITS.m, prefix: PREFIXES.SHORT.c }\n UNIT_SYSTEMS.cgs.MASS = { unit: UNITS.g, prefix: PREFIXES.SHORT[''] }\n UNIT_SYSTEMS.cgs.FORCE = { unit: UNITS.dyn, prefix: PREFIXES.SHORT[''] }\n UNIT_SYSTEMS.cgs.ENERGY = { unit: UNITS.erg, prefix: PREFIXES.NONE[''] }\n // there are wholly 4 unique cgs systems for electricity and magnetism,\n // so let's not worry about it unless somebody complains\n\n UNIT_SYSTEMS.us = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si))\n UNIT_SYSTEMS.us.LENGTH = { unit: UNITS.ft, prefix: PREFIXES.NONE[''] }\n UNIT_SYSTEMS.us.MASS = { unit: UNITS.lbm, prefix: PREFIXES.NONE[''] }\n UNIT_SYSTEMS.us.TEMPERATURE = { unit: UNITS.degF, prefix: PREFIXES.NONE[''] }\n UNIT_SYSTEMS.us.FORCE = { unit: UNITS.lbf, prefix: PREFIXES.NONE[''] }\n UNIT_SYSTEMS.us.ENERGY = { unit: UNITS.BTU, prefix: PREFIXES.BTU[''] }\n UNIT_SYSTEMS.us.POWER = { unit: UNITS.hp, prefix: PREFIXES.NONE[''] }\n UNIT_SYSTEMS.us.PRESSURE = { unit: UNITS.psi, prefix: PREFIXES.NONE[''] }\n\n // Add additional unit systems here.\n\n // Choose a unit system to seed the auto unit system.\n UNIT_SYSTEMS.auto = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si))\n\n // Set the current unit system\n let currentUnitSystem = UNIT_SYSTEMS.auto\n\n /**\n * Set a unit system for formatting derived units.\n * @memberof Unit\n * @param {string} [name] The name of the unit system.\n */\n Unit.setUnitSystem = function (name) {\n if (hasOwnProperty(UNIT_SYSTEMS, name)) {\n currentUnitSystem = UNIT_SYSTEMS[name]\n } else {\n throw new Error('Unit system ' + name + ' does not exist. Choices are: ' + Object.keys(UNIT_SYSTEMS).join(', '))\n }\n }\n\n /**\n * Return the current unit system.\n * @memberof Unit\n * @return {string} The current unit system.\n */\n Unit.getUnitSystem = function () {\n for (const key in UNIT_SYSTEMS) {\n if (hasOwnProperty(UNIT_SYSTEMS, key)) {\n if (UNIT_SYSTEMS[key] === currentUnitSystem) {\n return key\n }\n }\n }\n }\n\n /**\n * Converters to convert from number to an other numeric type like BigNumber\n * or Fraction\n */\n Unit.typeConverters = {\n BigNumber: function (x) {\n if (x?.isFraction) return new BigNumber(x.n).div(x.d).times(x.s)\n return new BigNumber(x + '') // stringify to prevent constructor error\n },\n\n Fraction: function (x) {\n return new Fraction(x)\n },\n\n Complex: function (x) {\n return x\n },\n\n number: function (x) {\n if (x?.isFraction) return number(x)\n return x\n }\n }\n\n /**\n * Retrieve the right converter function corresponding with this unit's\n * value\n *\n * @memberof Unit\n * @return {Function}\n */\n Unit.prototype._numberConverter = function () {\n const convert = Unit.typeConverters[this.valueType()]\n if (convert) {\n return convert\n }\n throw new TypeError('Unsupported Unit value type \"' + this.valueType() + '\"')\n }\n\n /**\n * Retrieve the right convertor function corresponding with the type\n * of provided exampleValue.\n *\n * @param {string} type A string 'number', 'BigNumber', or 'Fraction'\n * In case of an unknown type,\n * @return {Function}\n */\n Unit._getNumberConverter = function (type) {\n if (!Unit.typeConverters[type]) {\n throw new TypeError('Unsupported type \"' + type + '\"')\n }\n\n return Unit.typeConverters[type]\n }\n\n // Add dimensions to each built-in unit\n for (const key in UNITS) {\n if (hasOwnProperty(UNITS, key)) {\n const unit = UNITS[key]\n unit.dimensions = unit.base.dimensions\n }\n }\n\n // Create aliases\n for (const name in ALIASES) {\n if (hasOwnProperty(ALIASES, name)) {\n const unit = UNITS[ALIASES[name]]\n const alias = {}\n for (const key in unit) {\n if (hasOwnProperty(unit, key)) {\n alias[key] = unit[key]\n }\n }\n alias.name = name\n UNITS[name] = alias\n }\n }\n\n /**\n * Checks if a character is a valid latin letter (upper or lower case).\n * Note that this function can be overridden, for example to allow support of other alphabets.\n * @memberof Unit\n * @param {string} c Tested character\n * @return {boolean} true if the character is a latin letter\n */\n Unit.isValidAlpha = function isValidAlpha (c) {\n return /^[a-zA-Z]$/.test(c)\n }\n\n function assertUnitNameIsValid (name) {\n for (let i = 0; i < name.length; i++) {\n c = name.charAt(i)\n\n if (i === 0 && !Unit.isValidAlpha(c)) { throw new Error('Invalid unit name (must begin with alpha character): \"' + name + '\"') }\n\n if (i > 0 && !(Unit.isValidAlpha(c) ||\n isDigit(c))) { throw new Error('Invalid unit name (only alphanumeric characters are allowed): \"' + name + '\"') }\n }\n }\n\n /**\n * Wrapper around createUnitSingle.\n * Example:\n * createUnit( {\n * foo: {\n * prefixes: 'long',\n * baseName: 'essence-of-foo'\n * },\n * bar: '40 foo',\n * baz: {\n * definition: '1 bar/hour',\n * prefixes: 'long'\n * }\n * },\n * {\n * override: true\n * })\n * @memberof Unit\n * @param {object} obj Object map. Each key becomes a unit which is defined by its value.\n * @param {object} options\n * @return {Unit} the last created unit\n */\n Unit.createUnit = function (obj, options) {\n if (typeof (obj) !== 'object') {\n throw new TypeError(\"createUnit expects first parameter to be of type 'Object'\")\n }\n\n // Remove all units and aliases we are overriding\n if (options && options.override) {\n for (const key in obj) {\n if (hasOwnProperty(obj, key)) {\n Unit.deleteUnit(key)\n }\n if (obj[key].aliases) {\n for (let i = 0; i < obj[key].aliases.length; i++) {\n Unit.deleteUnit(obj[key].aliases[i])\n }\n }\n }\n }\n\n // TODO: traverse multiple times until all units have been added\n let lastUnit\n for (const key in obj) {\n if (hasOwnProperty(obj, key)) {\n lastUnit = Unit.createUnitSingle(key, obj[key])\n }\n }\n return lastUnit\n }\n\n /**\n * Create a user-defined unit and register it with the Unit type.\n * Example:\n * createUnitSingle('knot', '0.514444444 m/s')\n *\n * @memberof Unit\n * @param {string} name The name of the new unit. Must be unique. Example: 'knot'\n * @param {string | Unit | object} definition Definition of the unit in terms\n * of existing units. For example, '0.514444444 m / s'. Can be a Unit, a string,\n * or an Object. If an Object, may have the following properties:\n * - definition {string | Unit} The definition of this unit.\n * - prefixes {string} \"none\", \"short\", \"long\", \"binary_short\", or \"binary_long\".\n * The default is \"none\".\n * - aliases {Array} Array of strings. Example: ['knots', 'kt', 'kts']\n * - offset {Numeric} An offset to apply when converting from the unit. For\n * example, the offset for celsius is 273.15 and the offset for farhenheit\n * is 459.67. Default is 0.\n * - baseName {string} If the unit's dimension does not match that of any other\n * base unit, the name of the newly create base unit. Otherwise, this property\n * has no effect.\n *\n * @return {Unit}\n */\n Unit.createUnitSingle = function (name, obj) {\n if (typeof (obj) === 'undefined' || obj === null) {\n obj = {}\n }\n\n if (typeof (name) !== 'string') {\n throw new TypeError(\"createUnitSingle expects first parameter to be of type 'string'\")\n }\n\n // Check collisions with existing units\n if (hasOwnProperty(UNITS, name)) {\n throw new Error('Cannot create unit \"' + name + '\": a unit with that name already exists')\n }\n\n // TODO: Validate name for collisions with other built-in functions (like abs or cos, for example), and for acceptable variable names. For example, '42' is probably not a valid unit. Nor is '%', since it is also an operator.\n\n assertUnitNameIsValid(name)\n\n let defUnit = null // The Unit from which the new unit will be created.\n let aliases = []\n let offset = 0\n let definition\n let prefixes\n let baseName\n if (obj && obj.type === 'Unit') {\n defUnit = obj.clone()\n } else if (typeof (obj) === 'string') {\n if (obj !== '') {\n definition = obj\n }\n } else if (typeof (obj) === 'object') {\n definition = obj.definition\n prefixes = obj.prefixes\n offset = obj.offset\n baseName = obj.baseName\n if (obj.aliases) {\n aliases = obj.aliases.valueOf() // aliases could be a Matrix, so convert to Array\n }\n } else {\n throw new TypeError('Cannot create unit \"' + name + '\" from \"' + obj.toString() + '\": expecting \"string\" or \"Unit\" or \"Object\"')\n }\n\n if (aliases) {\n for (let i = 0; i < aliases.length; i++) {\n if (hasOwnProperty(UNITS, aliases[i])) {\n throw new Error('Cannot create alias \"' + aliases[i] + '\": a unit with that name already exists')\n }\n }\n }\n\n if (definition && typeof (definition) === 'string' && !defUnit) {\n try {\n defUnit = Unit.parse(definition, { allowNoUnits: true })\n } catch (ex) {\n ex.message = 'Could not create unit \"' + name + '\" from \"' + definition + '\": ' + ex.message\n throw (ex)\n }\n } else if (definition && definition.type === 'Unit') {\n defUnit = definition.clone()\n }\n\n aliases = aliases || []\n offset = offset || 0\n if (prefixes && prefixes.toUpperCase) { prefixes = PREFIXES[prefixes.toUpperCase()] || PREFIXES.NONE } else { prefixes = PREFIXES.NONE }\n\n // If defUnit is null, it is because the user did not\n // specify a defintion. So create a new base dimension.\n let newUnit = {}\n if (!defUnit) {\n // Add a new base dimension\n baseName = baseName || name + '_STUFF' // foo --> foo_STUFF, or the essence of foo\n if (BASE_DIMENSIONS.indexOf(baseName) >= 0) {\n throw new Error('Cannot create new base unit \"' + name + '\": a base unit with that name already exists (and cannot be overridden)')\n }\n BASE_DIMENSIONS.push(baseName)\n\n // Push 0 onto existing base units\n for (const b in BASE_UNITS) {\n if (hasOwnProperty(BASE_UNITS, b)) {\n BASE_UNITS[b].dimensions[BASE_DIMENSIONS.length - 1] = 0\n }\n }\n\n // Add the new base unit\n const newBaseUnit = { dimensions: [] }\n for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n newBaseUnit.dimensions[i] = 0\n }\n newBaseUnit.dimensions[BASE_DIMENSIONS.length - 1] = 1\n newBaseUnit.key = baseName\n BASE_UNITS[baseName] = newBaseUnit\n\n newUnit = {\n name,\n value: 1,\n dimensions: BASE_UNITS[baseName].dimensions.slice(0),\n prefixes,\n offset,\n base: BASE_UNITS[baseName]\n }\n\n currentUnitSystem[baseName] = {\n unit: newUnit,\n prefix: PREFIXES.NONE['']\n }\n } else {\n newUnit = {\n name,\n value: defUnit.value,\n dimensions: defUnit.dimensions.slice(0),\n prefixes,\n offset\n }\n\n // Create a new base if no matching base exists\n let anyMatch = false\n for (const i in BASE_UNITS) {\n if (hasOwnProperty(BASE_UNITS, i)) {\n let match = true\n for (let j = 0; j < BASE_DIMENSIONS.length; j++) {\n if (Math.abs((newUnit.dimensions[j] || 0) - (BASE_UNITS[i].dimensions[j] || 0)) > 1e-12) {\n match = false\n break\n }\n }\n if (match) {\n anyMatch = true\n newUnit.base = BASE_UNITS[i]\n break\n }\n }\n }\n if (!anyMatch) {\n baseName = baseName || name + '_STUFF' // foo --> foo_STUFF, or the essence of foo\n // Add the new base unit\n const newBaseUnit = { dimensions: defUnit.dimensions.slice(0) }\n newBaseUnit.key = baseName\n BASE_UNITS[baseName] = newBaseUnit\n\n currentUnitSystem[baseName] = {\n unit: newUnit,\n prefix: PREFIXES.NONE['']\n }\n\n newUnit.base = BASE_UNITS[baseName]\n }\n }\n\n Unit.UNITS[name] = newUnit\n\n for (let i = 0; i < aliases.length; i++) {\n const aliasName = aliases[i]\n const alias = {}\n for (const key in newUnit) {\n if (hasOwnProperty(newUnit, key)) {\n alias[key] = newUnit[key]\n }\n }\n alias.name = aliasName\n Unit.UNITS[aliasName] = alias\n }\n\n // delete the memoization cache because we created a new unit\n delete _findUnit.cache\n\n return new Unit(null, name)\n }\n\n Unit.deleteUnit = function (name) {\n delete Unit.UNITS[name]\n\n // delete the memoization cache because we deleted a unit\n delete _findUnit.cache\n }\n\n // expose arrays with prefixes, dimensions, units, systems\n Unit.PREFIXES = PREFIXES\n Unit.BASE_DIMENSIONS = BASE_DIMENSIONS\n Unit.BASE_UNITS = BASE_UNITS\n Unit.UNIT_SYSTEMS = UNIT_SYSTEMS\n Unit.UNITS = UNITS\n\n return Unit\n}, { isClass: true })\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'unit'\nconst dependencies = ['typed', 'Unit']\n\n// This function is named createUnitFunction to prevent a naming conflict with createUnit\nexport const createUnitFunction = /* #__PURE__ */ factory(name, dependencies, ({ typed, Unit }) => {\n /**\n * Create a unit. Depending on the passed arguments, the function\n * will create and return a new math.Unit object.\n * When a matrix is provided, all elements will be converted to units.\n *\n * Syntax:\n *\n * math.unit(unit : string)\n * math.unit(value : number, valuelessUnit : Unit)\n * math.unit(value : number, valuelessUnit : string)\n *\n * Examples:\n *\n * const kph = math.unit('km/h') // returns Unit km/h (valueless)\n * const v = math.unit(25, kph) // returns Unit 25 km/h\n * const a = math.unit(5, 'cm') // returns Unit 50 mm\n * const b = math.unit('23 kg') // returns Unit 23 kg\n * a.to('m') // returns Unit 0.05 m\n *\n * See also:\n *\n * bignumber, boolean, complex, index, matrix, number, string, createUnit\n *\n * @param {* | Array | Matrix} args A number and unit.\n * @return {Unit | Array | Matrix} The created unit\n */\n\n return typed(name, {\n Unit: function (x) {\n return x.clone()\n },\n\n string: function (x) {\n if (Unit.isValuelessUnit(x)) {\n return new Unit(null, x) // a pure unit\n }\n\n return Unit.parse(x, { allowNoUnits: true }) // a unit with value, like '5cm'\n },\n\n 'number | BigNumber | Fraction | Complex, string | Unit': function (value, unit) {\n return new Unit(value, unit)\n },\n\n 'number | BigNumber | Fraction': function (value) {\n // dimensionless\n return new Unit(value)\n },\n\n 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'sparse'\nconst dependencies = ['typed', 'SparseMatrix']\n\nexport const createSparse = /* #__PURE__ */ factory(name, dependencies, ({ typed, SparseMatrix }) => {\n /**\n * Create a Sparse Matrix. The function creates a new `math.Matrix` object from\n * an `Array`. A Matrix has utility functions to manipulate the data in the\n * matrix, like getting the size and getting or setting values in the matrix.\n * Note that a Sparse Matrix is always 2-dimensional, so for example if\n * you create one from a plain array of _n_ numbers, you get an _n_ by 1\n * Sparse \"column vector\".\n *\n * Syntax:\n *\n * math.sparse() // creates an empty sparse matrix.\n * math.sparse(data) // creates a sparse matrix with initial data.\n * math.sparse(data, 'number') // creates a sparse matrix with initial data, number datatype.\n *\n * Examples:\n *\n * let m = math.sparse([[1, 2], [3, 4]])\n * m.size() // Array [2, 2]\n * m.resize([3, 2], 5)\n * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]]\n * m.get([1, 0]) // number 3\n * let v = math.sparse([0, 0, 1])\n * v.size() // Array [3, 1]\n * v.get([2, 0]) // number 1\n *\n * See also:\n *\n * bignumber, boolean, complex, index, number, string, unit, matrix\n *\n * @param {Array | Matrix} [data] A two dimensional array\n *\n * @return {Matrix} The created matrix\n */\n return typed(name, {\n '': function () {\n return new SparseMatrix([])\n },\n\n string: function (datatype) {\n return new SparseMatrix([], datatype)\n },\n\n 'Array | Matrix': function (data) {\n return new SparseMatrix(data)\n },\n\n 'Array | Matrix, string': function (data, datatype) {\n return new SparseMatrix(data, datatype)\n }\n })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'createUnit'\nconst dependencies = ['typed', 'Unit']\n\nexport const createCreateUnit = /* #__PURE__ */ factory(name, dependencies, ({ typed, Unit }) => {\n /**\n * Create a user-defined unit and register it with the Unit type.\n *\n * Syntax:\n *\n * math.createUnit({\n * baseUnit1: {\n * aliases: [string, ...]\n * prefixes: object\n * },\n * unit2: {\n * definition: string,\n * aliases: [string, ...]\n * prefixes: object,\n * offset: number\n * },\n * unit3: string // Shortcut\n * })\n *\n * // Another shortcut:\n * math.createUnit(string, unit : string, [object])\n *\n * Examples:\n *\n * math.createUnit('foo')\n * math.createUnit('knot', {definition: '0.514444444 m/s', aliases: ['knots', 'kt', 'kts']})\n * math.createUnit('mph', '1 mile/hour')\n * math.createUnit('km', math.unit(1000, 'm'))\n *\n * @param {string} name The name of the new unit. Must be unique. Example: 'knot'\n * @param {string, UnitDefinition, Unit} definition Definition of the unit in terms of existing units. For example, '0.514444444 m / s'.\n * @param {Object} options (optional) An object containing any of the following properties:\n * - `prefixes {string}` \"none\", \"short\", \"long\", \"binary_short\", or \"binary_long\". The default is \"none\".\n * - `aliases {Array}` Array of strings. Example: ['knots', 'kt', 'kts']\n * - `offset {Numeric}` An offset to apply when converting from the unit. For example, the offset for celsius is 273.15. Default is 0.\n *\n * See also:\n *\n * unit\n *\n * @return {Unit} The new unit\n */\n return typed(name, {\n\n // General function signature. First parameter is an object where each property is the definition of a new unit. The object keys are the unit names and the values are the definitions. The values can be objects, strings, or Units. If a property is an empty object or an empty string, a new base unit is created. The second parameter is the options.\n 'Object, Object': function (obj, options) {\n return Unit.createUnit(obj, options)\n },\n\n // Same as above but without the options.\n Object: function (obj) {\n return Unit.createUnit(obj, {})\n },\n\n // Shortcut method for creating one unit.\n 'string, Unit | string | Object, Object': function (name, def, options) {\n const obj = {}\n obj[name] = def\n return Unit.createUnit(obj, options)\n },\n\n // Same as above but without the options.\n 'string, Unit | string | Object': function (name, def) {\n const obj = {}\n obj[name] = def\n return Unit.createUnit(obj, {})\n },\n\n // Without a definition, creates a base unit.\n string: function (name) {\n const obj = {}\n obj[name] = {}\n return Unit.createUnit(obj, {})\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'acos'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAcos = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the inverse cosine of a value.\n *\n * To avoid confusion with the matrix arccosine, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.acos(x)\n *\n * Examples:\n *\n * math.acos(0.5) // returns number 1.0471975511965979\n * math.acos(math.cos(1.5)) // returns number 1.5\n *\n * math.acos(2) // returns Complex 0 + 1.3169578969248166 i\n *\n * See also:\n *\n * cos, atan, asin\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} The arc cosine of x\n */\n return typed(name, {\n number: function (x) {\n if ((x >= -1 && x <= 1) || config.predictable) {\n return Math.acos(x)\n } else {\n return new Complex(x, 0).acos()\n }\n },\n\n Complex: function (x) {\n return x.acos()\n },\n\n BigNumber: function (x) {\n return x.acos()\n }\n })\n})\n","import { acosh, asinh, atanh, cosh, sign, sinh, tanh } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function acosNumber (x) {\n return Math.acos(x)\n}\nacosNumber.signature = n1\n\nexport function acoshNumber (x) {\n return acosh(x)\n}\nacoshNumber.signature = n1\n\nexport function acotNumber (x) {\n return Math.atan(1 / x)\n}\nacotNumber.signature = n1\n\nexport function acothNumber (x) {\n return isFinite(x)\n ? (Math.log((x + 1) / x) + Math.log(x / (x - 1))) / 2\n : 0\n}\nacothNumber.signature = n1\n\nexport function acscNumber (x) {\n return Math.asin(1 / x)\n}\nacscNumber.signature = n1\n\nexport function acschNumber (x) {\n const xInv = 1 / x\n return Math.log(xInv + Math.sqrt(xInv * xInv + 1))\n}\nacschNumber.signature = n1\n\nexport function asecNumber (x) {\n return Math.acos(1 / x)\n}\nasecNumber.signature = n1\n\nexport function asechNumber (x) {\n const xInv = 1 / x\n const ret = Math.sqrt(xInv * xInv - 1)\n return Math.log(ret + xInv)\n}\nasechNumber.signature = n1\n\nexport function asinNumber (x) {\n return Math.asin(x)\n}\nasinNumber.signature = n1\n\nexport function asinhNumber (x) {\n return asinh(x)\n}\nasinhNumber.signature = n1\n\nexport function atanNumber (x) {\n return Math.atan(x)\n}\natanNumber.signature = n1\n\nexport function atan2Number (y, x) {\n return Math.atan2(y, x)\n}\natan2Number.signature = n2\n\nexport function atanhNumber (x) {\n return atanh(x)\n}\natanhNumber.signature = n1\n\nexport function cosNumber (x) {\n return Math.cos(x)\n}\ncosNumber.signature = n1\n\nexport function coshNumber (x) {\n return cosh(x)\n}\ncoshNumber.signature = n1\n\nexport function cotNumber (x) {\n return 1 / Math.tan(x)\n}\ncotNumber.signature = n1\n\nexport function cothNumber (x) {\n const e = Math.exp(2 * x)\n return (e + 1) / (e - 1)\n}\ncothNumber.signature = n1\n\nexport function cscNumber (x) {\n return 1 / Math.sin(x)\n}\ncscNumber.signature = n1\n\nexport function cschNumber (x) {\n // consider values close to zero (+/-)\n if (x === 0) {\n return Number.POSITIVE_INFINITY\n } else {\n return Math.abs(2 / (Math.exp(x) - Math.exp(-x))) * sign(x)\n }\n}\ncschNumber.signature = n1\n\nexport function secNumber (x) {\n return 1 / Math.cos(x)\n}\nsecNumber.signature = n1\n\nexport function sechNumber (x) {\n return 2 / (Math.exp(x) + Math.exp(-x))\n}\nsechNumber.signature = n1\n\nexport function sinNumber (x) {\n return Math.sin(x)\n}\nsinNumber.signature = n1\n\nexport function sinhNumber (x) {\n return sinh(x)\n}\nsinhNumber.signature = n1\n\nexport function tanNumber (x) {\n return Math.tan(x)\n}\ntanNumber.signature = n1\n\nexport function tanhNumber (x) {\n return tanh(x)\n}\ntanhNumber.signature = n1\n","import { factory } from '../../utils/factory.js'\nimport { acoshNumber } from '../../plain/number/index.js'\n\nconst name = 'acosh'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAcosh = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the hyperbolic arccos of a value,\n * defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acosh(x)\n *\n * Examples:\n *\n * math.acosh(1.5) // returns 0.9624236501192069\n *\n * See also:\n *\n * cosh, asinh, atanh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arccosine of x\n */\n return typed(name, {\n number: function (x) {\n if (x >= 1 || config.predictable) {\n return acoshNumber(x)\n }\n if (x <= -1) {\n return new Complex(Math.log(Math.sqrt(x * x - 1) - x), Math.PI)\n }\n return new Complex(x, 0).acosh()\n },\n\n Complex: function (x) {\n return x.acosh()\n },\n\n BigNumber: function (x) {\n return x.acosh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acotNumber } from '../../plain/number/index.js'\n\nconst name = 'acot'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createAcot = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Calculate the inverse cotangent of a value, defined as `acot(x) = atan(1/x)`.\n *\n * To avoid confusion with the matrix arccotanget, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.acot(x)\n *\n * Examples:\n *\n * math.acot(0.5) // returns number 1.1071487177940904\n * math.acot(2) // returns number 0.4636476090008061\n * math.acot(math.cot(1.5)) // returns number 1.5\n *\n * See also:\n *\n * cot, atan\n *\n * @param {number | BigNumber| Complex} x Function input\n * @return {number | BigNumber| Complex} The arc cotangent of x\n */\n return typed(name, {\n number: acotNumber,\n\n Complex: function (x) {\n return x.acot()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).atan()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acothNumber } from '../../plain/number/index.js'\n\nconst name = 'acoth'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAcoth = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n /**\n * Calculate the inverse hyperbolic tangent of a value,\n * defined as `acoth(x) = atanh(1/x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.\n *\n * To avoid confusion with the matrix inverse hyperbolic tangent, this\n * function does not apply to matrices.\n *\n * Syntax:\n *\n * math.acoth(x)\n *\n * Examples:\n *\n * math.acoth(0.5) // returns 0.8047189562170503\n *\n * See also:\n *\n * acsch, asech\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arccotangent of x\n */\n return typed(name, {\n number: function (x) {\n if (x >= 1 || x <= -1 || config.predictable) {\n return acothNumber(x)\n }\n return new Complex(x, 0).acoth()\n },\n\n Complex: function (x) {\n return x.acoth()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).atanh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acscNumber } from '../../plain/number/index.js'\n\nconst name = 'acsc'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAcsc = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n /**\n * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`.\n *\n * To avoid confusion with the matrix arccosecant, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.acsc(x)\n *\n * Examples:\n *\n * math.acsc(2) // returns 0.5235987755982989\n * math.acsc(0.5) // returns Complex 1.5707963267948966 -1.3169578969248166i\n * math.acsc(math.csc(1.5)) // returns number ~1.5\n *\n * See also:\n *\n * csc, asin, asec\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} The arc cosecant of x\n */\n return typed(name, {\n number: function (x) {\n if (x <= -1 || x >= 1 || config.predictable) {\n return acscNumber(x)\n }\n return new Complex(x, 0).acsc()\n },\n\n Complex: function (x) {\n return x.acsc()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).asin()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acschNumber } from '../../plain/number/index.js'\n\nconst name = 'acsch'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createAcsch = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Calculate the inverse hyperbolic cosecant of a value,\n * defined as `acsch(x) = asinh(1/x) = ln(1/x + sqrt(1/x^2 + 1))`.\n *\n * To avoid confusion with the matrix inverse hyperbolic cosecant, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.acsch(x)\n *\n * Examples:\n *\n * math.acsch(0.5) // returns 1.4436354751788103\n *\n * See also:\n *\n * asech, acoth\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arccosecant of x\n */\n return typed(name, {\n number: acschNumber,\n\n Complex: function (x) {\n return x.acsch()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).asinh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asecNumber } from '../../plain/number/index.js'\n\nconst name = 'asec'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAsec = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n /**\n * Calculate the inverse secant of a value. Defined as `asec(x) = acos(1/x)`.\n *\n * To avoid confusion with the matrix arcsecant, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.asec(x)\n *\n * Examples:\n *\n * math.asec(2) // returns 1.0471975511965979\n * math.asec(math.sec(1.5)) // returns 1.5\n *\n * math.asec(0.5) // returns Complex 0 + 1.3169578969248166i\n *\n * See also:\n *\n * acos, acot, acsc\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} The arc secant of x\n */\n return typed(name, {\n number: function (x) {\n if (x <= -1 || x >= 1 || config.predictable) {\n return asecNumber(x)\n }\n return new Complex(x, 0).asec()\n },\n\n Complex: function (x) {\n return x.asec()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).acos()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asechNumber } from '../../plain/number/index.js'\n\nconst name = 'asech'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAsech = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n /**\n * Calculate the hyperbolic arcsecant of a value,\n * defined as `asech(x) = acosh(1/x) = ln(sqrt(1/x^2 - 1) + 1/x)`.\n *\n * To avoid confusion with the matrix hyperbolic arcsecant, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.asech(x)\n *\n * Examples:\n *\n * math.asech(0.5) // returns 1.3169578969248166\n *\n * See also:\n *\n * acsch, acoth\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arcsecant of x\n */\n return typed(name, {\n number: function (x) {\n if ((x <= 1 && x >= -1) || config.predictable) {\n const xInv = 1 / x\n if (xInv > 0 || config.predictable) {\n return asechNumber(x)\n }\n\n const ret = Math.sqrt(xInv * xInv - 1)\n return new Complex(Math.log(ret - xInv), Math.PI)\n }\n\n return new Complex(x, 0).asech()\n },\n\n Complex: function (x) {\n return x.asech()\n },\n\n BigNumber: function (x) {\n return new BigNumber(1).div(x).acosh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'asin'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAsin = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the inverse sine of a value.\n *\n * To avoid confusion with the matric arcsine, this function does not apply\n * to matrices.\n *\n * Syntax:\n *\n * math.asin(x)\n *\n * Examples:\n *\n * math.asin(0.5) // returns number 0.5235987755982989\n * math.asin(math.sin(1.5)) // returns number ~1.5\n *\n * math.asin(2) // returns Complex 1.5707963267948966 -1.3169578969248166i\n *\n * See also:\n *\n * sin, atan, acos\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} The arc sine of x\n */\n return typed(name, {\n number: function (x) {\n if ((x >= -1 && x <= 1) || config.predictable) {\n return Math.asin(x)\n } else {\n return new Complex(x, 0).asin()\n }\n },\n\n Complex: function (x) {\n return x.asin()\n },\n\n BigNumber: function (x) {\n return x.asin()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asinhNumber } from '../../plain/number/index.js'\n\nconst name = 'asinh'\nconst dependencies = ['typed']\n\nexport const createAsinh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the hyperbolic arcsine of a value,\n * defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.\n *\n * To avoid confusion with the matrix hyperbolic arcsine, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.asinh(x)\n *\n * Examples:\n *\n * math.asinh(0.5) // returns 0.48121182505960347\n *\n * See also:\n *\n * acosh, atanh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arcsine of x\n */\n return typed('asinh', {\n number: asinhNumber,\n\n Complex: function (x) {\n return x.asinh()\n },\n\n BigNumber: function (x) {\n return x.asinh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'atan'\nconst dependencies = ['typed']\n\nexport const createAtan = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the inverse tangent of a value.\n *\n * To avoid confusion with matrix arctangent, this function does not apply\n * to matrices.\n *\n * Syntax:\n *\n * math.atan(x)\n *\n * Examples:\n *\n * math.atan(0.5) // returns number 0.4636476090008061\n * math.atan(2) // returns number 1.1071487177940904\n * math.atan(math.tan(1.5)) // returns number 1.5\n *\n * See also:\n *\n * tan, asin, acos\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} The arc tangent of x\n */\n return typed('atan', {\n number: function (x) {\n return Math.atan(x)\n },\n\n Complex: function (x) {\n return x.atan()\n },\n\n BigNumber: function (x) {\n return x.atan()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'atan2'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'equalScalar',\n 'BigNumber',\n 'DenseMatrix',\n 'concat'\n]\n\nexport const createAtan2 = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, BigNumber, DenseMatrix, concat }) => {\n const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n const matAlgo09xS0Sf = createMatAlgo09xS0Sf({ typed, equalScalar })\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n /**\n * Calculate the inverse tangent function with two arguments, y/x.\n * By providing two arguments, the right quadrant of the computed angle can be\n * determined.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.atan2(y, x)\n *\n * Examples:\n *\n * math.atan2(2, 2) / math.pi // returns number 0.25\n *\n * const angle = math.unit(60, 'deg') // returns Unit 60 deg\n * const x = math.cos(angle)\n * const y = math.sin(angle)\n *\n * math.atan(2) // returns number 1.1071487177940904\n *\n * See also:\n *\n * tan, atan, sin, cos\n *\n * @param {number | Array | Matrix} y Second dimension\n * @param {number | Array | Matrix} x First dimension\n * @return {number | Array | Matrix} Four-quadrant inverse tangent\n */\n return typed(\n name,\n {\n 'number, number': Math.atan2,\n\n // Complex numbers doesn't seem to have a reasonable implementation of\n // atan2(). Even Matlab removed the support, after they only calculated\n // the atan only on base of the real part of the numbers and ignored\n // the imaginary.\n\n 'BigNumber, BigNumber': (y, x) => BigNumber.atan2(y, x)\n },\n matrixAlgorithmSuite({\n scalar: 'number | BigNumber',\n SS: matAlgo09xS0Sf,\n DS: matAlgo03xDSf,\n SD: matAlgo02xDS0,\n Ss: matAlgo11xS0s,\n sS: matAlgo12xSfs\n })\n )\n})\n","import { factory } from '../../utils/factory.js'\nimport { atanhNumber } from '../../plain/number/index.js'\n\nconst name = 'atanh'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAtanh = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n /**\n * Calculate the hyperbolic arctangent of a value,\n * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.\n *\n * To avoid confusion with the matrix hyperbolic arctangent, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.atanh(x)\n *\n * Examples:\n *\n * math.atanh(0.5) // returns 0.5493061443340549\n *\n * See also:\n *\n * acosh, asinh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic arctangent of x\n */\n return typed(name, {\n number: function (x) {\n if ((x <= 1 && x >= -1) || config.predictable) {\n return atanhNumber(x)\n }\n return new Complex(x, 0).atanh()\n },\n\n Complex: function (x) {\n return x.atanh()\n },\n\n BigNumber: function (x) {\n return x.atanh()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nexport const createTrigUnit = /* #__PURE__ */ factory(\n 'trigUnit', ['typed'], ({ typed }) => ({\n Unit: typed.referToSelf(self => x => {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function cot is no angle')\n }\n return typed.find(self, x.valueType())(x.value)\n })\n })\n)\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'cos'\nconst dependencies = ['typed']\n\nexport const createCos = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the cosine of a value.\n *\n * To avoid confusion with the matrix cosine, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.cos(x)\n *\n * Examples:\n *\n * math.cos(2) // returns number -0.4161468365471422\n * math.cos(math.pi / 4) // returns number 0.7071067811865475\n * math.cos(math.unit(180, 'deg')) // returns number -1\n * math.cos(math.unit(60, 'deg')) // returns number 0.5\n *\n * const angle = 0.2\n * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1\n *\n * See also:\n *\n * cos, tan\n *\n * @param {number | BigNumber | Complex | Unit} x Function input\n * @return {number | BigNumber | Complex} Cosine of x\n */\n return typed(name, {\n number: Math.cos,\n 'Complex | BigNumber': x => x.cos()\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cosh as coshNumber } from '../../utils/number.js'\n\nconst name = 'cosh'\nconst dependencies = ['typed']\n\nexport const createCosh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the hyperbolic cosine of a value,\n * defined as `cosh(x) = 1/2 * (exp(x) + exp(-x))`.\n *\n * To avoid confusion with the matrix hyperbolic cosine, this function does\n * not apply to matrices.\n *\n * Syntax:\n *\n * math.cosh(x)\n *\n * Examples:\n *\n * math.cosh(0.5) // returns number 1.1276259652063807\n *\n * See also:\n *\n * sinh, tanh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic cosine of x\n */\n return typed(name, {\n number: coshNumber,\n 'Complex | BigNumber': x => x.cosh()\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cotNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'cot'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCot = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the cotangent of a value. Defined as `cot(x) = 1 / tan(x)`.\n *\n * To avoid confusion with the matrix cotangent, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.cot(x)\n *\n * Examples:\n *\n * math.cot(2) // returns number -0.45765755436028577\n * 1 / math.tan(2) // returns number -0.45765755436028577\n *\n * See also:\n *\n * tan, sec, csc\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Cotangent of x\n */\n return typed(name, {\n number: cotNumber,\n Complex: x => x.cot(),\n BigNumber: x => new BigNumber(1).div(x.tan())\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cothNumber } from '../../plain/number/index.js'\n\nconst name = 'coth'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCoth = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Calculate the hyperbolic cotangent of a value,\n * defined as `coth(x) = 1 / tanh(x)`.\n *\n * To avoid confusion with the matrix hyperbolic cotangent, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.coth(x)\n *\n * Examples:\n *\n * // coth(x) = 1 / tanh(x)\n * math.coth(2) // returns 1.0373147207275482\n * 1 / math.tanh(2) // returns 1.0373147207275482\n *\n * See also:\n *\n * sinh, tanh, cosh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic cotangent of x\n */\n return typed(name, {\n number: cothNumber,\n Complex: x => x.coth(),\n BigNumber: x => new BigNumber(1).div(x.tanh())\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cscNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'csc'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCsc = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the cosecant of a value, defined as `csc(x) = 1/sin(x)`.\n *\n * To avoid confusion with the matrix cosecant, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.csc(x)\n *\n * Examples:\n *\n * math.csc(2) // returns number 1.099750170294617\n * 1 / math.sin(2) // returns number 1.099750170294617\n *\n * See also:\n *\n * sin, sec, cot\n *\n * @param {number | BigNumber | Complex | Unit} x Function input\n * @return {number | BigNumber | Complex} Cosecant of x\n */\n return typed(name, {\n number: cscNumber,\n Complex: x => x.csc(),\n BigNumber: x => new BigNumber(1).div(x.sin())\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cschNumber } from '../../plain/number/index.js'\n\nconst name = 'csch'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCsch = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Calculate the hyperbolic cosecant of a value,\n * defined as `csch(x) = 1 / sinh(x)`.\n *\n * To avoid confusion with the matrix hyperbolic cosecant, this function\n * does not apply to matrices.\n *\n * Syntax:\n *\n * math.csch(x)\n *\n * Examples:\n *\n * // csch(x) = 1/ sinh(x)\n * math.csch(0.5) // returns 1.9190347513349437\n * 1 / math.sinh(0.5) // returns 1.9190347513349437\n *\n * See also:\n *\n * sinh, sech, coth\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic cosecant of x\n */\n return typed(name, {\n number: cschNumber,\n Complex: x => x.csch(),\n BigNumber: x => new BigNumber(1).div(x.sinh())\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { secNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'sec'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createSec = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the secant of a value, defined as `sec(x) = 1/cos(x)`.\n *\n * To avoid confusion with the matrix secant, this function does not\n * apply to matrices.\n *\n * Syntax:\n *\n * math.sec(x)\n *\n * Examples:\n *\n * math.sec(2) // returns number -2.4029979617223822\n * 1 / math.cos(2) // returns number -2.4029979617223822\n *\n * See also:\n *\n * cos, csc, cot\n *\n * @param {number | BigNumber | Complex | Unit} x Function input\n * @return {number | BigNumber | Complex} Secant of x\n */\n return typed(name, {\n number: secNumber,\n Complex: x => x.sec(),\n BigNumber: x => new BigNumber(1).div(x.cos())\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { sechNumber } from '../../plain/number/index.js'\n\nconst name = 'sech'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createSech = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n /**\n * Calculate the hyperbolic secant of a value,\n * defined as `sech(x) = 1 / cosh(x)`.\n *\n * To avoid confusion with the matrix hyperbolic secant, this function does\n * not apply to matrices.\n *\n * Syntax:\n *\n * math.sech(x)\n *\n * Examples:\n *\n * // sech(x) = 1/ cosh(x)\n * math.sech(0.5) // returns 0.886818883970074\n * 1 / math.cosh(0.5) // returns 0.886818883970074\n *\n * See also:\n *\n * cosh, csch, coth\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic secant of x\n */\n return typed(name, {\n number: sechNumber,\n Complex: x => x.sech(),\n BigNumber: x => new BigNumber(1).div(x.cosh())\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'sin'\nconst dependencies = ['typed']\n\nexport const createSin = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the sine of a value.\n *\n * To avoid confusion with the matrix sine, this function does not apply\n * to matrices.\n *\n * Syntax:\n *\n * math.sin(x)\n *\n * Examples:\n *\n * math.sin(2) // returns number 0.9092974268256813\n * math.sin(math.pi / 4) // returns number 0.7071067811865475\n * math.sin(math.unit(90, 'deg')) // returns number 1\n * math.sin(math.unit(30, 'deg')) // returns number 0.5\n *\n * const angle = 0.2\n * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1\n *\n * See also:\n *\n * cos, tan\n *\n * @param {number | BigNumber | Complex | Unit} x Function input\n * @return {number | BigNumber | Complex} Sine of x\n */\n return typed(name, {\n number: Math.sin,\n 'Complex | BigNumber': x => x.sin()\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { sinhNumber } from '../../plain/number/index.js'\n\nconst name = 'sinh'\nconst dependencies = ['typed']\n\nexport const createSinh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the hyperbolic sine of a value,\n * defined as `sinh(x) = 1/2 * (exp(x) - exp(-x))`.\n *\n * To avoid confusion with the matrix hyperbolic sine, this function does\n * not apply to matrices.\n *\n * Syntax:\n *\n * math.sinh(x)\n *\n * Examples:\n *\n * math.sinh(0.5) // returns number 0.5210953054937474\n *\n * See also:\n *\n * cosh, tanh\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic sine of x\n */\n return typed(name, {\n number: sinhNumber,\n 'Complex | BigNumber': x => x.sinh()\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'tan'\nconst dependencies = ['typed']\n\nexport const createTan = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n const trigUnit = createTrigUnit({ typed })\n\n /**\n * Calculate the tangent of a value. `tan(x)` is equal to `sin(x) / cos(x)`.\n *\n * To avoid confusion with the matrix tangent, this function does not apply\n * to matrices.\n *\n * Syntax:\n *\n * math.tan(x)\n *\n * Examples:\n *\n * math.tan(0.5) // returns number 0.5463024898437905\n * math.sin(0.5) / math.cos(0.5) // returns number 0.5463024898437905\n * math.tan(math.pi / 4) // returns number 1\n * math.tan(math.unit(45, 'deg')) // returns number 1\n *\n * See also:\n *\n * atan, sin, cos\n *\n * @param {number | BigNumber | Complex | Unit} x Function input\n * @return {number | BigNumber | Complex} Tangent of x\n */\n return typed(name, {\n number: Math.tan,\n 'Complex | BigNumber': x => x.tan()\n }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { tanh as _tanh } from '../../utils/number.js'\n\nconst name = 'tanh'\nconst dependencies = ['typed']\n\nexport const createTanh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Calculate the hyperbolic tangent of a value,\n * defined as `tanh(x) = (exp(2 * x) - 1) / (exp(2 * x) + 1)`.\n *\n * To avoid confusion with matrix hyperbolic tangent, this function does\n * not apply to matrices.\n *\n * Syntax:\n *\n * math.tanh(x)\n *\n * Examples:\n *\n * // tanh(x) = sinh(x) / cosh(x) = 1 / coth(x)\n * math.tanh(0.5) // returns 0.46211715726000974\n * math.sinh(0.5) / math.cosh(0.5) // returns 0.46211715726000974\n * 1 / math.coth(0.5) // returns 0.46211715726000974\n *\n * See also:\n *\n * sinh, cosh, coth\n *\n * @param {number | BigNumber | Complex} x Function input\n * @return {number | BigNumber | Complex} Hyperbolic tangent of x\n */\n return typed('tanh', {\n number: _tanh,\n 'Complex | BigNumber': x => x.tanh()\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setCartesian'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetCartesian = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\n /**\n * Create the cartesian product of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays\n * and the values will be sorted in ascending order before the operation.\n *\n * Syntax:\n *\n * math.setCartesian(set1, set2)\n *\n * Examples:\n *\n * math.setCartesian([1, 2], [3, 4]) // returns [[1, 3], [1, 4], [2, 3], [2, 4]]\n * math.setCartesian([4, 3], [2, 1]) // returns [[3, 1], [3, 2], [4, 1], [4, 2]]\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference, setPowerset\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The cartesian product of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n let result = []\n\n if (subset(size(a1), new Index(0)) !== 0 && subset(size(a2), new Index(0)) !== 0) { // if any of them is empty, return empty\n const b1 = flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)\n const b2 = flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)\n result = []\n for (let i = 0; i < b1.length; i++) {\n for (let j = 0; j < b2.length; j++) {\n result.push([b1[i], b2[j]])\n }\n }\n }\n // return an array, if both inputs were arrays\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return result\n }\n // return a matrix otherwise\n return new DenseMatrix(result)\n }\n })\n})\n","import { flatten, generalize, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setDifference'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetDifference = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\n /**\n * Create the difference of two (multi)sets: every element of set1, that is not the element of set2.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setDifference(set1, set2)\n *\n * Examples:\n *\n * math.setDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2]\n * math.setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2]\n *\n * See also:\n *\n * setUnion, setIntersect, setSymDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The difference of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n let result\n if (subset(size(a1), new Index(0)) === 0) { // empty-anything=empty\n result = []\n } else if (subset(size(a2), new Index(0)) === 0) { // anything-empty=anything\n return flatten(a1.toArray())\n } else {\n const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n result = []\n let inb2\n for (let i = 0; i < b1.length; i++) {\n inb2 = false\n for (let j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n inb2 = true\n break\n }\n }\n if (!inb2) {\n result.push(b1[i])\n }\n }\n }\n // return an array, if both inputs were arrays\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return generalize(result)\n }\n // return a matrix otherwise\n return new DenseMatrix(generalize(result))\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setDistinct'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetDistinct = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\n /**\n * Collect the distinct elements of a multiset.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setDistinct(set)\n *\n * Examples:\n *\n * math.setDistinct([1, 1, 1, 2, 2, 3]) // returns [1, 2, 3]\n *\n * See also:\n *\n * setMultiplicity\n *\n * @param {Array | Matrix} a A multiset\n * @return {Array | Matrix} A set containing the distinc elements of the multiset\n */\n return typed(name, {\n 'Array | Matrix': function (a) {\n let result\n if (subset(size(a), new Index(0)) === 0) { // if empty, return empty\n result = []\n } else {\n const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n result = []\n result.push(b[0])\n for (let i = 1; i < b.length; i++) {\n if (compareNatural(b[i], b[i - 1]) !== 0) {\n result.push(b[i])\n }\n }\n }\n // return an array, if the input was an array\n if (Array.isArray(a)) {\n return result\n }\n // return a matrix otherwise\n return new DenseMatrix(result)\n }\n })\n})\n","import { flatten, generalize, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setIntersect'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetIntersect = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\n /**\n * Create the intersection of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setIntersect(set1, set2)\n *\n * Examples:\n *\n * math.setIntersect([1, 2, 3, 4], [3, 4, 5, 6]) // returns [3, 4]\n * math.setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [3, 4]\n *\n * See also:\n *\n * setUnion, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The intersection of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n let result\n if (subset(size(a1), new Index(0)) === 0 || subset(size(a2), new Index(0)) === 0) { // of any of them is empty, return empty\n result = []\n } else {\n const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n result = []\n for (let i = 0; i < b1.length; i++) {\n for (let j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n result.push(b1[i])\n break\n }\n }\n }\n }\n // return an array, if both inputs were arrays\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return generalize(result)\n }\n // return a matrix otherwise\n return new DenseMatrix(generalize(result))\n }\n })\n})\n","import { flatten, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setIsSubset'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetIsSubset = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\n /**\n * Check whether a (multi)set is a subset of another (multi)set. (Every element of set1 is the element of set2.)\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setIsSubset(set1, set2)\n *\n * Examples:\n *\n * math.setIsSubset([1, 2], [3, 4, 5, 6]) // returns false\n * math.setIsSubset([3, 4], [3, 4, 5, 6]) // returns true\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {boolean} Returns true when a1 is a subset of a2, returns false otherwise\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) { // empty is a subset of anything\n return true\n } else if (subset(size(a2), new Index(0)) === 0) { // anything is not a subset of empty\n return false\n }\n const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n let inb2\n for (let i = 0; i < b1.length; i++) {\n inb2 = false\n for (let j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n inb2 = true\n break\n }\n }\n if (inb2 === false) {\n return false\n }\n }\n return true\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setMultiplicity'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetMultiplicity = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\n /**\n * Count the multiplicity of an element in a multiset.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setMultiplicity(element, set)\n *\n * Examples:\n *\n * math.setMultiplicity(1, [1, 2, 2, 4]) // returns 1\n * math.setMultiplicity(2, [1, 2, 2, 4]) // returns 2\n *\n * See also:\n *\n * setDistinct, setSize\n *\n * @param {number | BigNumber | Fraction | Complex} e An element in the multiset\n * @param {Array | Matrix} a A multiset\n * @return {number} The number of how many times the multiset contains the element\n */\n return typed(name, {\n 'number | BigNumber | Fraction | Complex, Array | Matrix': function (e, a) {\n if (subset(size(a), new Index(0)) === 0) { // if empty, return 0\n return 0\n }\n const b = flatten(Array.isArray(a) ? a : a.toArray())\n let count = 0\n for (let i = 0; i < b.length; i++) {\n if (compareNatural(b[i], e) === 0) {\n count++\n }\n }\n return count\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setPowerset'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetPowerset = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\n /**\n * Create the powerset of a (multi)set. (The powerset contains very possible subsets of a (multi)set.)\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setPowerset(set)\n *\n * Examples:\n *\n * math.setPowerset([1, 2, 3]) // returns [[], [1], [2], [3], [1, 2], [1, 3], [2, 3], [1, 2, 3]]\n *\n * See also:\n *\n * setCartesian\n *\n * @param {Array | Matrix} a A (multi)set\n * @return {Array} The powerset of the (multi)set\n */\n return typed(name, {\n 'Array | Matrix': function (a) {\n if (subset(size(a), new Index(0)) === 0) { // if empty, return empty\n return []\n }\n const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n const result = []\n let number = 0\n while (number.toString(2).length <= b.length) {\n result.push(_subset(b, number.toString(2).split('').reverse()))\n number++\n }\n // can not return a matrix, because of the different size of the subarrays\n return _sort(result)\n }\n })\n\n // create subset\n function _subset (array, bitarray) {\n const result = []\n for (let i = 0; i < bitarray.length; i++) {\n if (bitarray[i] === '1') {\n result.push(array[i])\n }\n }\n return result\n }\n\n // sort subsests by length\n function _sort (array) {\n let temp = []\n for (let i = array.length - 1; i > 0; i--) {\n for (let j = 0; j < i; j++) {\n if (array[j].length > array[j + 1].length) {\n temp = array[j]\n array[j] = array[j + 1]\n array[j + 1] = temp\n }\n }\n }\n return array\n }\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setSize'\nconst dependencies = ['typed', 'compareNatural']\n\nexport const createSetSize = /* #__PURE__ */ factory(name, dependencies, ({ typed, compareNatural }) => {\n /**\n * Count the number of elements of a (multi)set. When a second parameter is 'true', count only the unique values.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setSize(set)\n * math.setSize(set, unique)\n *\n * Examples:\n *\n * math.setSize([1, 2, 2, 4]) // returns 4\n * math.setSize([1, 2, 2, 4], true) // returns 3\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a A multiset\n * @param {boolean} [unique] If true, only the unique values are counted. False by default\n * @return {number} The number of elements of the (multi)set\n */\n return typed(name, {\n 'Array | Matrix': function (a) {\n return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length\n },\n 'Array | Matrix, boolean': function (a, unique) {\n if (unique === false || a.length === 0) {\n return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length\n } else {\n const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n let count = 1\n for (let i = 1; i < b.length; i++) {\n if (compareNatural(b[i], b[i - 1]) !== 0) {\n count++\n }\n }\n return count\n }\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setSymDifference'\nconst dependencies = ['typed', 'size', 'concat', 'subset', 'setDifference', 'Index']\n\nexport const createSetSymDifference = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, concat, subset, setDifference, Index }) => {\n /**\n * Create the symmetric difference of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setSymDifference(set1, set2)\n *\n * Examples:\n *\n * math.setSymDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 5, 6]\n * math.setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 5, 6]\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The symmetric difference of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) { // if any of them is empty, return the other one\n return flatten(a2)\n } else if (subset(size(a2), new Index(0)) === 0) {\n return flatten(a1)\n }\n const b1 = flatten(a1)\n const b2 = flatten(a2)\n return concat(setDifference(b1, b2), setDifference(b2, b1))\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setUnion'\nconst dependencies = ['typed', 'size', 'concat', 'subset', 'setIntersect', 'setSymDifference', 'Index']\n\nexport const createSetUnion = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, concat, subset, setIntersect, setSymDifference, Index }) => {\n /**\n * Create the union of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setUnion(set1, set2)\n *\n * Examples:\n *\n * math.setUnion([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 3, 4, 5, 6]\n * math.setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 3, 4, 5, 6]\n *\n * See also:\n *\n * setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The union of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function (a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) { // if any of them is empty, return the other one\n return flatten(a2)\n } else if (subset(size(a2), new Index(0)) === 0) {\n return flatten(a1)\n }\n const b1 = flatten(a1)\n const b2 = flatten(a2)\n return concat(setSymDifference(b1, b2), setIntersect(b1, b2))\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'add'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'addScalar',\n 'equalScalar',\n 'DenseMatrix',\n 'SparseMatrix',\n 'concat'\n]\n\nexport const createAdd = /* #__PURE__ */ factory(\n name,\n dependencies,\n ({ typed, matrix, addScalar, equalScalar, DenseMatrix, SparseMatrix, concat }) => {\n const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n /**\n * Add two or more values, `x + y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.add(x, y)\n * math.add(x, y, z, ...)\n *\n * Examples:\n *\n * math.add(2, 3) // returns number 5\n * math.add(2, 3, 4) // returns number 9\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(-4, 1)\n * math.add(a, b) // returns Complex -2 + 4i\n *\n * math.add([1, 2, 3], 4) // returns Array [5, 6, 7]\n *\n * const c = math.unit('5 cm')\n * const d = math.unit('2.1 mm')\n * math.add(c, d) // returns Unit 52.1 mm\n *\n * math.add(\"2.3\", \"4\") // returns number 6.3\n *\n * See also:\n *\n * subtract, sum\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to add\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to add\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Sum of `x` and `y`\n */\n return typed(\n name,\n {\n 'any, any': addScalar,\n\n 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => {\n let result = self(x, y)\n\n for (let i = 0; i < rest.length; i++) {\n result = self(result, rest[i])\n }\n\n return result\n })\n },\n matrixAlgorithmSuite({\n elop: addScalar,\n DS: matAlgo01xDSid,\n SS: matAlgo04xSidSid,\n Ss: matAlgo10xSids\n })\n )\n })\n","import { factory } from '../../utils/factory.js'\nimport { flatten } from '../../utils/array.js'\nimport { isComplex } from '../../utils/is.js'\n\nconst name = 'hypot'\nconst dependencies = [\n 'typed',\n 'abs',\n 'addScalar',\n 'divideScalar',\n 'multiplyScalar',\n 'sqrt',\n 'smaller',\n 'isPositive'\n]\n\nexport const createHypot = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, addScalar, divideScalar, multiplyScalar, sqrt, smaller, isPositive }) => {\n /**\n * Calculate the hypotenuse of a list with values. The hypotenuse is defined as:\n *\n * hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...)\n *\n * For matrix input, the hypotenuse is calculated for all values in the matrix.\n *\n * Syntax:\n *\n * math.hypot(a, b, ...)\n * math.hypot([a, b, c, ...])\n *\n * Examples:\n *\n * math.hypot(3, 4) // 5\n * math.hypot(3, 4, 5) // 7.0710678118654755\n * math.hypot([3, 4, 5]) // 7.0710678118654755\n * math.hypot(-2) // 2\n *\n * See also:\n *\n * abs, norm\n *\n * @param {... number | BigNumber | Array | Matrix} args A list with numeric values or an Array or Matrix.\n * Matrix and Array input is flattened and returns a\n * single number for the whole matrix.\n * @return {number | BigNumber} Returns the hypothenusa of the input values.\n */\n return typed(name, {\n '... number | BigNumber': _hypot,\n\n Array: _hypot,\n\n Matrix: M => _hypot(flatten(M.toArray()))\n })\n\n /**\n * Calculate the hypotenuse for an Array with values\n * @param {Array.} args\n * @return {number | BigNumber} Returns the result\n * @private\n */\n function _hypot (args) {\n // code based on `hypot` from es6-shim:\n // https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1619-L1633\n let result = 0\n let largest = 0\n\n for (let i = 0; i < args.length; i++) {\n if (isComplex(args[i])) {\n throw new TypeError('Unexpected type of argument to hypot')\n }\n const value = abs(args[i])\n if (smaller(largest, value)) {\n result = multiplyScalar(result,\n multiplyScalar(divideScalar(largest, value), divideScalar(largest, value)))\n result = addScalar(result, 1)\n largest = value\n } else {\n result = addScalar(result, isPositive(value)\n ? multiplyScalar(divideScalar(value, largest), divideScalar(value, largest))\n : value)\n }\n }\n\n return multiplyScalar(largest, sqrt(result))\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'norm'\nconst dependencies = [\n 'typed',\n 'abs',\n 'add',\n 'pow',\n 'conj',\n 'sqrt',\n 'multiply',\n 'equalScalar',\n 'larger',\n 'smaller',\n 'matrix',\n 'ctranspose',\n 'eigs'\n]\n\nexport const createNorm = /* #__PURE__ */ factory(\n name,\n dependencies,\n ({\n typed,\n abs,\n add,\n pow,\n conj,\n sqrt,\n multiply,\n equalScalar,\n larger,\n smaller,\n matrix,\n ctranspose,\n eigs\n }) => {\n /**\n * Calculate the norm of a number, vector or matrix.\n *\n * The second parameter p is optional. If not provided, it defaults to 2.\n *\n * Syntax:\n *\n * math.norm(x)\n * math.norm(x, p)\n *\n * Examples:\n *\n * math.abs(-3.5) // returns 3.5\n * math.norm(-3.5) // returns 3.5\n *\n * math.norm(math.complex(3, -4)) // returns 5\n *\n * math.norm([1, 2, -3], Infinity) // returns 3\n * math.norm([1, 2, -3], -Infinity) // returns 1\n *\n * math.norm([3, 4], 2) // returns 5\n *\n * math.norm([[1, 2], [3, 4]], 1) // returns 6\n * math.norm([[1, 2], [3, 4]], 'inf') // returns 7\n * math.norm([[1, 2], [3, 4]], 'fro') // returns 5.477225575051661\n *\n * See also:\n *\n * abs, hypot\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the norm\n * @param {number | BigNumber | string} [p=2]\n * Vector space.\n * Supported numbers include Infinity and -Infinity.\n * Supported strings are: 'inf', '-inf', and 'fro' (The Frobenius norm)\n * @return {number | BigNumber} the p-norm\n */\n return typed(name, {\n number: Math.abs,\n\n Complex: function (x) {\n return x.abs()\n },\n\n BigNumber: function (x) {\n // norm(x) = abs(x)\n return x.abs()\n },\n\n boolean: function (x) {\n // norm(x) = abs(x)\n return Math.abs(x)\n },\n\n Array: function (x) {\n return _norm(matrix(x), 2)\n },\n\n Matrix: function (x) {\n return _norm(x, 2)\n },\n\n 'Array, number | BigNumber | string': function (x, p) {\n return _norm(matrix(x), p)\n },\n\n 'Matrix, number | BigNumber | string': function (x, p) {\n return _norm(x, p)\n }\n })\n\n /**\n * Calculate the plus infinity norm for a vector\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _vectorNormPlusInfinity (x) {\n // norm(x, Infinity) = max(abs(x))\n let pinf = 0\n // skip zeros since abs(0) === 0\n x.forEach(function (value) {\n const v = abs(value)\n if (larger(v, pinf)) {\n pinf = v\n }\n }, true)\n return pinf\n }\n\n /**\n * Calculate the minus infinity norm for a vector\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _vectorNormMinusInfinity (x) {\n // norm(x, -Infinity) = min(abs(x))\n let ninf\n // skip zeros since abs(0) === 0\n x.forEach(function (value) {\n const v = abs(value)\n if (!ninf || smaller(v, ninf)) {\n ninf = v\n }\n }, true)\n return ninf || 0\n }\n\n /**\n * Calculate the norm for a vector\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n function _vectorNorm (x, p) {\n // check p\n if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n return _vectorNormPlusInfinity(x)\n }\n if (p === Number.NEGATIVE_INFINITY || p === '-inf') {\n return _vectorNormMinusInfinity(x)\n }\n if (p === 'fro') {\n return _norm(x, 2)\n }\n if (typeof p === 'number' && !isNaN(p)) {\n // check p != 0\n if (!equalScalar(p, 0)) {\n // norm(x, p) = sum(abs(xi) ^ p) ^ 1/p\n let n = 0\n // skip zeros since abs(0) === 0\n x.forEach(function (value) {\n n = add(pow(abs(value), p), n)\n }, true)\n return pow(n, 1 / p)\n }\n return Number.POSITIVE_INFINITY\n }\n // invalid parameter value\n throw new Error('Unsupported parameter value')\n }\n\n /**\n * Calculate the Frobenius norm for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _matrixNormFrobenius (x) {\n // norm(x) = sqrt(sum(diag(x'x)))\n let fro = 0\n x.forEach(function (value, index) {\n fro = add(fro, multiply(value, conj(value)))\n })\n return abs(sqrt(fro))\n }\n\n /**\n * Calculate the norm L1 for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _matrixNormOne (x) {\n // norm(x) = the largest column sum\n const c = []\n // result\n let maxc = 0\n // skip zeros since abs(0) == 0\n x.forEach(function (value, index) {\n const j = index[1]\n const cj = add(c[j] || 0, abs(value))\n if (larger(cj, maxc)) {\n maxc = cj\n }\n c[j] = cj\n }, true)\n return maxc\n }\n\n /**\n * Calculate the norm L2 for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _matrixNormTwo (x) {\n // norm(x) = sqrt( max eigenvalue of A*.A)\n const sizeX = x.size()\n if (sizeX[0] !== sizeX[1]) {\n throw new RangeError('Invalid matrix dimensions')\n }\n const tx = ctranspose(x)\n const squaredX = multiply(tx, x)\n const eigenVals = eigs(squaredX).values.toArray()\n const rho = eigenVals[eigenVals.length - 1]\n return abs(sqrt(rho))\n }\n\n /**\n * Calculate the infinity norm for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n function _matrixNormInfinity (x) {\n // norm(x) = the largest row sum\n const r = []\n // result\n let maxr = 0\n // skip zeros since abs(0) == 0\n x.forEach(function (value, index) {\n const i = index[0]\n const ri = add(r[i] || 0, abs(value))\n if (larger(ri, maxr)) {\n maxr = ri\n }\n r[i] = ri\n }, true)\n return maxr\n }\n\n /**\n * Calculate the norm for a 2D Matrix (M*N)\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n function _matrixNorm (x, p) {\n // check p\n if (p === 1) {\n return _matrixNormOne(x)\n }\n if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n return _matrixNormInfinity(x)\n }\n if (p === 'fro') {\n return _matrixNormFrobenius(x)\n }\n if (p === 2) {\n return _matrixNormTwo(x)\n } // invalid parameter value\n\n throw new Error('Unsupported parameter value ' + p)\n }\n\n /**\n * Calculate the norm for an array\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n function _norm (x, p) {\n // size\n const sizeX = x.size()\n\n // check if it is a vector\n if (sizeX.length === 1) {\n return _vectorNorm(x, p)\n }\n // MxN matrix\n if (sizeX.length === 2) {\n if (sizeX[0] && sizeX[1]) {\n return _matrixNorm(x, p)\n } else {\n throw new RangeError('Invalid matrix dimensions')\n }\n }\n }\n }\n)\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'dot'\nconst dependencies = ['typed', 'addScalar', 'multiplyScalar', 'conj', 'size']\n\nexport const createDot = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, multiplyScalar, conj, size }) => {\n /**\n * Calculate the dot product of two vectors. The dot product of\n * `A = [a1, a2, ..., an]` and `B = [b1, b2, ..., bn]` is defined as:\n *\n * dot(A, B) = conj(a1) * b1 + conj(a2) * b2 + ... + conj(an) * bn\n *\n * Syntax:\n *\n * math.dot(x, y)\n *\n * Examples:\n *\n * math.dot([2, 4, 1], [2, 2, 3]) // returns number 15\n * math.multiply([2, 4, 1], [2, 2, 3]) // returns number 15\n *\n * See also:\n *\n * multiply, cross\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {number} Returns the dot product of `x` and `y`\n */\n return typed(name, {\n 'Array | DenseMatrix, Array | DenseMatrix': _denseDot,\n 'SparseMatrix, SparseMatrix': _sparseDot\n })\n\n function _validateDim (x, y) {\n const xSize = _size(x)\n const ySize = _size(y)\n let xLen, yLen\n\n if (xSize.length === 1) {\n xLen = xSize[0]\n } else if (xSize.length === 2 && xSize[1] === 1) {\n xLen = xSize[0]\n } else {\n throw new RangeError('Expected a column vector, instead got a matrix of size (' + xSize.join(', ') + ')')\n }\n\n if (ySize.length === 1) {\n yLen = ySize[0]\n } else if (ySize.length === 2 && ySize[1] === 1) {\n yLen = ySize[0]\n } else {\n throw new RangeError('Expected a column vector, instead got a matrix of size (' + ySize.join(', ') + ')')\n }\n\n if (xLen !== yLen) throw new RangeError('Vectors must have equal length (' + xLen + ' != ' + yLen + ')')\n if (xLen === 0) throw new RangeError('Cannot calculate the dot product of empty vectors')\n\n return xLen\n }\n\n function _denseDot (a, b) {\n const N = _validateDim(a, b)\n\n const adata = isMatrix(a) ? a._data : a\n const adt = isMatrix(a) ? a._datatype || a.getDataType() : undefined\n\n const bdata = isMatrix(b) ? b._data : b\n const bdt = isMatrix(b) ? b._datatype || b.getDataType() : undefined\n\n // are these 2-dimensional column vectors? (as opposed to 1-dimensional vectors)\n const aIsColumn = _size(a).length === 2\n const bIsColumn = _size(b).length === 2\n\n let add = addScalar\n let mul = multiplyScalar\n\n // process data types\n if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n const dt = adt\n // find signatures that matches (dt, dt)\n add = typed.find(addScalar, [dt, dt])\n mul = typed.find(multiplyScalar, [dt, dt])\n }\n\n // both vectors 1-dimensional\n if (!aIsColumn && !bIsColumn) {\n let c = mul(conj(adata[0]), bdata[0])\n for (let i = 1; i < N; i++) {\n c = add(c, mul(conj(adata[i]), bdata[i]))\n }\n return c\n }\n\n // a is 1-dim, b is column\n if (!aIsColumn && bIsColumn) {\n let c = mul(conj(adata[0]), bdata[0][0])\n for (let i = 1; i < N; i++) {\n c = add(c, mul(conj(adata[i]), bdata[i][0]))\n }\n return c\n }\n\n // a is column, b is 1-dim\n if (aIsColumn && !bIsColumn) {\n let c = mul(conj(adata[0][0]), bdata[0])\n for (let i = 1; i < N; i++) {\n c = add(c, mul(conj(adata[i][0]), bdata[i]))\n }\n return c\n }\n\n // both vectors are column\n if (aIsColumn && bIsColumn) {\n let c = mul(conj(adata[0][0]), bdata[0][0])\n for (let i = 1; i < N; i++) {\n c = add(c, mul(conj(adata[i][0]), bdata[i][0]))\n }\n return c\n }\n }\n\n function _sparseDot (x, y) {\n _validateDim(x, y)\n\n const xindex = x._index\n const xvalues = x._values\n\n const yindex = y._index\n const yvalues = y._values\n\n // TODO optimize add & mul using datatype\n let c = 0\n const add = addScalar\n const mul = multiplyScalar\n\n let i = 0\n let j = 0\n while (i < xindex.length && j < yindex.length) {\n const I = xindex[i]\n const J = yindex[j]\n\n if (I < J) {\n i++\n continue\n }\n if (I > J) {\n j++\n continue\n }\n if (I === J) {\n c = add(c, mul(xvalues[i], yvalues[j]))\n i++\n j++\n }\n }\n\n return c\n }\n\n // TODO remove this once #1771 is fixed\n function _size (x) {\n return isMatrix(x) ? x.size() : size(x)\n }\n})\n","import { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'trace'\nconst dependencies = ['typed', 'matrix', 'add']\n\nexport const createTrace = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, add }) => {\n /**\n * Calculate the trace of a matrix: the sum of the elements on the main\n * diagonal of a square matrix.\n *\n * Syntax:\n *\n * math.trace(x)\n *\n * Examples:\n *\n * math.trace([[1, 2], [3, 4]]) // returns 5\n *\n * const A = [\n * [1, 2, 3],\n * [-1, 2, 3],\n * [2, 0, 3]\n * ]\n * math.trace(A) // returns 6\n *\n * See also:\n *\n * diag\n *\n * @param {Array | Matrix} x A matrix\n *\n * @return {number} The trace of `x`\n */\n return typed('trace', {\n Array: function _arrayTrace (x) {\n // use dense matrix implementation\n return _denseTrace(matrix(x))\n },\n\n SparseMatrix: _sparseTrace,\n\n DenseMatrix: _denseTrace,\n\n any: clone\n })\n\n function _denseTrace (m) {\n // matrix size & data\n const size = m._size\n const data = m._data\n\n // process dimensions\n switch (size.length) {\n case 1:\n // vector\n if (size[0] === 1) {\n // return data[0]\n return clone(data[0])\n }\n throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n case 2:\n {\n // two dimensional\n const rows = size[0]\n const cols = size[1]\n if (rows === cols) {\n // calulate sum\n let sum = 0\n // loop diagonal\n for (let i = 0; i < rows; i++) { sum = add(sum, data[i][i]) }\n // return trace\n return sum\n } else {\n throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n }\n }\n default:\n // multi dimensional\n throw new RangeError('Matrix must be two dimensional (size: ' + format(size) + ')')\n }\n }\n\n function _sparseTrace (m) {\n // matrix arrays\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n const size = m._size\n // check dimensions\n const rows = size[0]\n const columns = size[1]\n // matrix must be square\n if (rows === columns) {\n // calulate sum\n let sum = 0\n // check we have data (avoid looping columns)\n if (values.length > 0) {\n // loop columns\n for (let j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = ptr[j]\n const k1 = ptr[j + 1]\n // loop k within [k0, k1[\n for (let k = k0; k < k1; k++) {\n // row index\n const i = index[k]\n // check row\n if (i === j) {\n // accumulate value\n sum = add(sum, values[k])\n // exit loop\n break\n }\n if (i > j) {\n // exit loop, no value on the diagonal for column j\n break\n }\n }\n }\n }\n // return trace\n return sum\n }\n throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n }\n})\n","import { isBigNumber, isMatrix, isArray } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'index'\nconst dependencies = ['typed', 'Index']\n\nexport const createIndex = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index }) => {\n /**\n * Create an index. An Index can store ranges having start, step, and end\n * for multiple dimensions.\n * Matrix.get, Matrix.set, and math.subset accept an Index as input.\n *\n * Syntax:\n *\n * math.index(range1, range2, ...)\n *\n * Where each range can be any of:\n *\n * - A number\n * - A string for getting/setting an object property\n * - An instance of `Range`\n * - A one-dimensional Array or a Matrix with numbers or booleans\n *\n * Indexes must be zero-based, integer numbers.\n *\n * Examples:\n *\n * const b = [1, 2, 3, 4, 5]\n * math.subset(b, math.index([1, 2, 3])) // returns [2, 3, 4]\n * math.subset(b, math.index([false, true, true, true, false])) // returns [2, 3, 4]\n *\n * const a = math.matrix([[1, 2], [3, 4]])\n * a.subset(math.index(0, 1)) // returns 2\n * a.subset(math.index(0, [false, true])) // returns 2\n *\n * See also:\n *\n * bignumber, boolean, complex, matrix, number, string, unit\n *\n * @param {...*} ranges Zero or more ranges or numbers.\n * @return {Index} Returns the created index\n */\n return typed(name, {\n '...number | string | BigNumber | Range | Array | Matrix': function (args) {\n const ranges = args.map(function (arg) {\n if (isBigNumber(arg)) {\n return arg.toNumber() // convert BigNumber to Number\n } else if (isArray(arg) || isMatrix(arg)) {\n return arg.map(function (elem) {\n // convert BigNumber to Number\n return isBigNumber(elem) ? elem.toNumber() : elem\n })\n } else {\n return arg\n }\n })\n\n const res = new Index()\n Index.apply(res, ranges)\n return res\n }\n })\n})\n","// Reserved keywords not allowed to use in the parser\nexport const keywords = new Set([\n 'end'\n])\n","import { isNode } from '../../utils/is.js'\n\nimport { keywords } from '../keywords.js'\nimport { deepStrictEqual } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMap } from '../../utils/map.js'\n\nconst name = 'Node'\nconst dependencies = ['mathWithTransform']\n\nexport const createNode = /* #__PURE__ */ factory(name, dependencies, ({ mathWithTransform }) => {\n /**\n * Validate the symbol names of a scope.\n * Throws an error when the scope contains an illegal symbol.\n * @param {Object} scope\n */\n function _validateScope (scope) {\n for (const symbol of [...keywords]) {\n if (scope.has(symbol)) {\n throw new Error('Scope contains an illegal symbol, \"' + symbol + '\" is a reserved keyword')\n }\n }\n }\n\n class Node {\n get type () { return 'Node' }\n get isNode () { return true }\n\n /**\n * Evaluate the node\n * @param {Object} [scope] Scope to read/write variables\n * @return {*} Returns the result\n */\n evaluate (scope) {\n return this.compile().evaluate(scope)\n }\n\n /**\n * Compile the node into an optimized, evauatable JavaScript function\n * @return {{evaluate: function([Object])}} object\n * Returns an object with a function 'evaluate',\n * which can be invoked as expr.evaluate([scope: Object]),\n * where scope is an optional object with\n * variables.\n */\n compile () {\n const expr = this._compile(mathWithTransform, {})\n const args = {}\n const context = null\n\n function evaluate (scope) {\n const s = createMap(scope)\n _validateScope(s)\n return expr(s, args, context)\n }\n\n return {\n evaluate\n }\n }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n throw new Error('Method _compile must be implemented by type ' + this.type)\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot run forEach on a Node interface')\n }\n\n /**\n * Create a new Node whose children are the results of calling the\n * provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {OperatorNode} Returns a transformed copy of the node\n */\n map (callback) {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot run map on a Node interface')\n }\n\n /**\n * Validate whether an object is a Node, for use with map\n * @param {Node} node\n * @returns {Node} Returns the input if it's a node, else throws an Error\n * @protected\n */\n _ifNode (node) {\n if (!isNode(node)) {\n throw new TypeError('Callback function must return a Node')\n }\n return node\n }\n\n /**\n * Recursively traverse all nodes in a node tree. Executes given callback for\n * this node and each of its child nodes.\n * @param {function(node: Node, path: string, parent: Node)} callback\n * A callback called for every node in the node tree.\n */\n traverse (callback) {\n // execute callback for itself\n // eslint-disable-next-line\n callback(this, null, null)\n\n // recursively traverse over all children of a node\n function _traverse (node, callback) {\n node.forEach(function (child, path, parent) {\n callback(child, path, parent)\n _traverse(child, callback)\n })\n }\n\n _traverse(this, callback)\n }\n\n /**\n * Recursively transform a node tree via a transform function.\n *\n * For example, to replace all nodes of type SymbolNode having name 'x' with\n * a ConstantNode with value 2:\n *\n * const res = Node.transform(function (node, path, parent) {\n * if (node && node.isSymbolNode) && (node.name === 'x')) {\n * return new ConstantNode(2)\n * }\n * else {\n * return node\n * }\n * })\n *\n * @param {function(node: Node, path: string, parent: Node) : Node} callback\n * A mapping function accepting a node, and returning\n * a replacement for the node or the original node. The \"signature\"\n * of the callback must be:\n * callback(node: Node, index: string, parent: Node) : Node\n * @return {Node} Returns the original node or its replacement\n */\n transform (callback) {\n function _transform (child, path, parent) {\n const replacement = callback(child, path, parent)\n\n if (replacement !== child) {\n // stop iterating when the node is replaced\n return replacement\n }\n\n return child.map(_transform)\n }\n\n return _transform(this, null, null)\n }\n\n /**\n * Find any node in the node tree matching given filter function. For\n * example, to find all nodes of type SymbolNode having name 'x':\n *\n * const results = Node.filter(function (node) {\n * return (node && node.isSymbolNode) && (node.name === 'x')\n * })\n *\n * @param {function(node: Node, path: string, parent: Node) : Node} callback\n * A test function returning true when a node matches, and false\n * otherwise. Function signature:\n * callback(node: Node, index: string, parent: Node) : boolean\n * @return {Node[]} nodes\n * An array with nodes matching given filter criteria\n */\n filter (callback) {\n const nodes = []\n\n this.traverse(function (node, path, parent) {\n if (callback(node, path, parent)) {\n nodes.push(node)\n }\n })\n\n return nodes\n }\n\n /**\n * Create a shallow clone of this node\n * @return {Node}\n */\n clone () {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot clone a Node interface')\n }\n\n /**\n * Create a deep clone of this node\n * @return {Node}\n */\n cloneDeep () {\n return this.map(function (node) {\n return node.cloneDeep()\n })\n }\n\n /**\n * Deep compare this node with another node.\n * @param {Node} other\n * @return {boolean} Returns true when both nodes are of the same type and\n * contain the same values (as do their childs)\n */\n equals (other) {\n return other\n ? this.type === other.type && deepStrictEqual(this, other)\n : false\n }\n\n /**\n * Get string representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\"or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n toString (options) {\n const customString = this._getCustomString(options)\n\n if (typeof customString !== 'undefined') {\n return customString\n }\n\n return this._toString(options)\n }\n\n /**\n * Internal function to generate the string output.\n * This has to be implemented by every Node\n *\n * @throws {Error}\n */\n _toString () {\n // must be implemented by each of the Node implementations\n throw new Error('_toString not implemented for ' + this.type)\n }\n\n /**\n * Get a JSON representation of the node\n * Both .toJSON() and the static .fromJSON(json) should be implemented by all\n * implementations of Node\n * @returns {Object}\n */\n toJSON () {\n throw new Error(\n 'Cannot serialize object: toJSON not implemented by ' + this.type)\n }\n\n /**\n * Get HTML representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\" or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n toHTML (options) {\n const customString = this._getCustomString(options)\n\n if (typeof customString !== 'undefined') {\n return customString\n }\n\n return this._toHTML(options)\n }\n\n /**\n * Internal function to generate the HTML output.\n * This has to be implemented by every Node\n *\n * @throws {Error}\n */\n _toHTML () {\n // must be implemented by each of the Node implementations\n throw new Error('_toHTML not implemented for ' + this.type)\n }\n\n /**\n * Get LaTeX representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\"or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n toTex (options) {\n const customString = this._getCustomString(options)\n\n if (typeof customString !== 'undefined') {\n return customString\n }\n\n return this._toTex(options)\n }\n\n /**\n * Internal function to generate the LaTeX output.\n * This has to be implemented by every Node\n *\n * @param {Object} [options]\n * @throws {Error}\n */\n _toTex (options) {\n // must be implemented by each of the Node implementations\n throw new Error('_toTex not implemented for ' + this.type)\n }\n\n /**\n * Helper used by `to...` functions.\n */\n _getCustomString (options) {\n if (options && typeof options === 'object') {\n switch (typeof options.handler) {\n case 'object':\n case 'undefined':\n return\n case 'function':\n return options.handler(this, options)\n default:\n throw new TypeError('Object or function expected as callback')\n }\n }\n }\n\n /**\n * Get identifier.\n * @return {string}\n */\n getIdentifier () {\n return this.type\n }\n\n /**\n * Get the content of the current Node.\n * @return {Node} node\n **/\n getContent () {\n return this\n }\n }\n\n return Node\n}, { isClass: true, isNode: true })\n","function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nexport { _typeof as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import { IndexError } from '../../../error/IndexError.js'\n\n/**\n * Transform zero-based indices to one-based indices in errors\n * @param {Error} err\n * @returns {Error | IndexError} Returns the transformed error\n */\nexport function errorTransform (err) {\n if (err && err.isIndexError) {\n return new IndexError(\n err.index + 1,\n err.min + 1,\n err.max !== undefined ? err.max + 1 : undefined)\n }\n\n return err\n}\n","import { errorTransform } from '../../transform/utils/errorTransform.js'\nimport { getSafeProperty } from '../../../utils/customs.js'\n\nexport function accessFactory ({ subset }) {\n /**\n * Retrieve part of an object:\n *\n * - Retrieve a property from an object\n * - Retrieve a part of a string\n * - Retrieve a matrix subset\n *\n * @param {Object | Array | Matrix | string} object\n * @param {Index} index\n * @return {Object | Array | Matrix | string} Returns the subset\n */\n return function access (object, index) {\n try {\n if (Array.isArray(object)) {\n return subset(object, index)\n } else if (object && typeof object.subset === 'function') { // Matrix\n return object.subset(index)\n } else if (typeof object === 'string') {\n // TODO: move getStringSubset into a separate util file, use that\n return subset(object, index)\n } else if (typeof object === 'object') {\n if (!index.isObjectProperty()) {\n throw new TypeError('Cannot apply a numeric index as object property')\n }\n\n return getSafeProperty(object, index.getObjectProperty())\n } else {\n throw new TypeError('Cannot apply index: unsupported type of object')\n }\n } catch (err) {\n throw errorTransform(err)\n }\n }\n}\n","import {\n isAccessorNode,\n isArrayNode,\n isConstantNode,\n isFunctionNode,\n isIndexNode,\n isNode,\n isObjectNode,\n isParenthesisNode,\n isSymbolNode\n} from '../../utils/is.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { accessFactory } from './utils/access.js'\n\nconst name = 'AccessorNode'\nconst dependencies = [\n 'subset',\n 'Node'\n]\n\nexport const createAccessorNode = /* #__PURE__ */ factory(name, dependencies, ({ subset, Node }) => {\n const access = accessFactory({ subset })\n\n /**\n * Are parenthesis needed?\n * @private\n */\n function needParenthesis (node) {\n // TODO: maybe make a method on the nodes which tells whether they need parenthesis?\n return !(\n isAccessorNode(node) ||\n isArrayNode(node) ||\n isConstantNode(node) ||\n isFunctionNode(node) ||\n isObjectNode(node) ||\n isParenthesisNode(node) ||\n isSymbolNode(node))\n }\n\n class AccessorNode extends Node {\n /**\n * @constructor AccessorNode\n * @extends {Node}\n * Access an object property or get a matrix subset\n *\n * @param {Node} object The object from which to retrieve\n * a property or subset.\n * @param {IndexNode} index IndexNode containing ranges\n */\n constructor (object, index) {\n super()\n if (!isNode(object)) {\n throw new TypeError('Node expected for parameter \"object\"')\n }\n if (!isIndexNode(index)) {\n throw new TypeError('IndexNode expected for parameter \"index\"')\n }\n\n this.object = object\n this.index = index\n }\n\n // readonly property name\n get name () {\n if (this.index) {\n return (this.index.isObjectProperty())\n ? this.index.getObjectProperty()\n : ''\n } else {\n return this.object.name || ''\n }\n }\n\n static name = name\n get type () { return name }\n get isAccessorNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalObject = this.object._compile(math, argNames)\n const evalIndex = this.index._compile(math, argNames)\n\n if (this.index.isObjectProperty()) {\n const prop = this.index.getObjectProperty()\n return function evalAccessorNode (scope, args, context) {\n // get a property from an object evaluated using the scope.\n return getSafeProperty(evalObject(scope, args, context), prop)\n }\n } else {\n return function evalAccessorNode (scope, args, context) {\n const object = evalObject(scope, args, context)\n // we pass just object here instead of context:\n const index = evalIndex(scope, args, object)\n return access(object, index)\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.object, 'object', this)\n callback(this.index, 'index', this)\n }\n\n /**\n * Create a new AccessorNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {AccessorNode} Returns a transformed copy of the node\n */\n map (callback) {\n return new AccessorNode(\n this._ifNode(callback(this.object, 'object', this)),\n this._ifNode(callback(this.index, 'index', this))\n )\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {AccessorNode}\n */\n clone () {\n return new AccessorNode(this.object, this.index)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string}\n */\n _toString (options) {\n let object = this.object.toString(options)\n if (needParenthesis(this.object)) {\n object = '(' + object + ')'\n }\n\n return object + this.index.toString(options)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string}\n */\n _toHTML (options) {\n let object = this.object.toHTML(options)\n if (needParenthesis(this.object)) {\n object =\n '(' +\n object +\n ')'\n }\n\n return object + this.index.toHTML(options)\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string}\n */\n _toTex (options) {\n let object = this.object.toTex(options)\n if (needParenthesis(this.object)) {\n object = '\\\\left(\\' + object + \\'\\\\right)'\n }\n\n return object + this.index.toTex(options)\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n object: this.object,\n index: this.index\n }\n }\n\n /**\n * Instantiate an AccessorNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"AccessorNode\", object: ..., index: ...}`,\n * where mathjs is optional\n * @returns {AccessorNode}\n */\n static fromJSON (json) {\n return new AccessorNode(json.object, json.index)\n }\n }\n\n return AccessorNode\n}, { isClass: true, isNode: true })\n","import { isArrayNode, isNode } from '../../utils/is.js'\nimport { map } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ArrayNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createArrayNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n class ArrayNode extends Node {\n /**\n * @constructor ArrayNode\n * @extends {Node}\n * Holds an 1-dimensional array with items\n * @param {Node[]} [items] 1 dimensional array with items\n */\n constructor (items) {\n super()\n this.items = items || []\n\n // validate input\n if (!Array.isArray(this.items) || !this.items.every(isNode)) {\n throw new TypeError('Array containing Nodes expected')\n }\n }\n\n static name = name\n get type () { return name }\n get isArrayNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalItems = map(this.items, function (item) {\n return item._compile(math, argNames)\n })\n\n const asMatrix = (math.config.matrix !== 'Array')\n if (asMatrix) {\n const matrix = math.matrix\n return function evalArrayNode (scope, args, context) {\n return matrix(map(evalItems, function (evalItem) {\n return evalItem(scope, args, context)\n }))\n }\n } else {\n return function evalArrayNode (scope, args, context) {\n return map(evalItems, function (evalItem) {\n return evalItem(scope, args, context)\n })\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n for (let i = 0; i < this.items.length; i++) {\n const node = this.items[i]\n callback(node, 'items[' + i + ']', this)\n }\n }\n\n /**\n * Create a new ArrayNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ArrayNode} Returns a transformed copy of the node\n */\n map (callback) {\n const items = []\n for (let i = 0; i < this.items.length; i++) {\n items[i] = this._ifNode(callback(this.items[i], 'items[' + i + ']', this))\n }\n return new ArrayNode(items)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {ArrayNode}\n */\n clone () {\n return new ArrayNode(this.items.slice(0))\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toString (options) {\n const items = this.items.map(function (node) {\n return node.toString(options)\n })\n return '[' + items.join(', ') + ']'\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n items: this.items\n }\n }\n\n /**\n * Instantiate an ArrayNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ArrayNode\", items: [...]}`,\n * where mathjs is optional\n * @returns {ArrayNode}\n */\n static fromJSON (json) {\n return new ArrayNode(json.items)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toHTML (options) {\n const items = this.items.map(function (node) {\n return node.toHTML(options)\n })\n return '[' +\n items.join(',') +\n ']'\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n function itemsToTex (items, nested) {\n const mixedItems = items.some(isArrayNode) && !items.every(isArrayNode)\n const itemsFormRow = nested || mixedItems\n const itemSep = itemsFormRow ? '&' : '\\\\\\\\'\n const itemsTex = items\n .map(function (node) {\n if (node.items) {\n return itemsToTex(node.items, !nested)\n } else {\n return node.toTex(options)\n }\n })\n .join(itemSep)\n return mixedItems || !itemsFormRow || (itemsFormRow && !nested)\n ? '\\\\begin{bmatrix}' + itemsTex + '\\\\end{bmatrix}'\n : itemsTex\n }\n return itemsToTex(this.items, false)\n }\n }\n\n return ArrayNode\n}, { isClass: true, isNode: true })\n","// list of identifiers of nodes in order of their precedence\n// also contains information about left/right associativity\n// and which other operator the operator is associative with\n// Example:\n// addition is associative with addition and subtraction, because:\n// (a+b)+c=a+(b+c)\n// (a+b)-c=a+(b-c)\n//\n// postfix operators are left associative, prefix operators\n// are right associative\n//\n// It's also possible to set the following properties:\n// latexParens: if set to false, this node doesn't need to be enclosed\n// in parentheses when using LaTeX\n// latexLeftParens: if set to false, this !OperatorNode's!\n// left argument doesn't need to be enclosed\n// in parentheses\n// latexRightParens: the same for the right argument\nimport { hasOwnProperty } from '../utils/object.js'\nimport { isConstantNode, isParenthesisNode, rule2Node } from '../utils/is.js'\n\nexport const properties = [\n { // assignment\n AssignmentNode: {},\n FunctionAssignmentNode: {}\n },\n { // conditional expression\n ConditionalNode: {\n latexLeftParens: false,\n latexRightParens: false,\n latexParens: false\n // conditionals don't need parentheses in LaTeX because\n // they are 2 dimensional\n }\n },\n { // logical or\n 'OperatorNode:or': {\n op: 'or',\n associativity: 'left',\n associativeWith: []\n }\n\n },\n { // logical xor\n 'OperatorNode:xor': {\n op: 'xor',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // logical and\n 'OperatorNode:and': {\n op: 'and',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // bitwise or\n 'OperatorNode:bitOr': {\n op: '|',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // bitwise xor\n 'OperatorNode:bitXor': {\n op: '^|',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // bitwise and\n 'OperatorNode:bitAnd': {\n op: '&',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // relational operators\n 'OperatorNode:equal': {\n op: '==',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:unequal': {\n op: '!=',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:smaller': {\n op: '<',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:larger': {\n op: '>',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:smallerEq': {\n op: '<=',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:largerEq': {\n op: '>=',\n associativity: 'left',\n associativeWith: []\n },\n RelationalNode: {\n associativity: 'left',\n associativeWith: []\n }\n },\n { // bitshift operators\n 'OperatorNode:leftShift': {\n op: '<<',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:rightArithShift': {\n op: '>>',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:rightLogShift': {\n op: '>>>',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // unit conversion\n 'OperatorNode:to': {\n op: 'to',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // range\n RangeNode: {}\n },\n { // addition, subtraction\n 'OperatorNode:add': {\n op: '+',\n associativity: 'left',\n associativeWith: ['OperatorNode:add', 'OperatorNode:subtract']\n },\n 'OperatorNode:subtract': {\n op: '-',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // multiply, divide, modulus\n 'OperatorNode:multiply': {\n op: '*',\n associativity: 'left',\n associativeWith: [\n 'OperatorNode:multiply',\n 'OperatorNode:divide',\n 'Operator:dotMultiply',\n 'Operator:dotDivide'\n ]\n },\n 'OperatorNode:divide': {\n op: '/',\n associativity: 'left',\n associativeWith: [],\n latexLeftParens: false,\n latexRightParens: false,\n latexParens: false\n // fractions don't require parentheses because\n // they're 2 dimensional, so parens aren't needed\n // in LaTeX\n },\n 'OperatorNode:dotMultiply': {\n op: '.*',\n associativity: 'left',\n associativeWith: [\n 'OperatorNode:multiply',\n 'OperatorNode:divide',\n 'OperatorNode:dotMultiply',\n 'OperatorNode:doDivide'\n ]\n },\n 'OperatorNode:dotDivide': {\n op: './',\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:mod': {\n op: 'mod',\n associativity: 'left',\n associativeWith: []\n }\n },\n { // Repeat multiplication for implicit multiplication\n 'OperatorNode:multiply': {\n associativity: 'left',\n associativeWith: [\n 'OperatorNode:multiply',\n 'OperatorNode:divide',\n 'Operator:dotMultiply',\n 'Operator:dotDivide'\n ]\n }\n },\n { // unary prefix operators\n 'OperatorNode:unaryPlus': {\n op: '+',\n associativity: 'right'\n },\n 'OperatorNode:unaryMinus': {\n op: '-',\n associativity: 'right'\n },\n 'OperatorNode:bitNot': {\n op: '~',\n associativity: 'right'\n },\n 'OperatorNode:not': {\n op: 'not',\n associativity: 'right'\n }\n },\n { // exponentiation\n 'OperatorNode:pow': {\n op: '^',\n associativity: 'right',\n associativeWith: [],\n latexRightParens: false\n // the exponent doesn't need parentheses in\n // LaTeX because it's 2 dimensional\n // (it's on top)\n },\n 'OperatorNode:dotPow': {\n op: '.^',\n associativity: 'right',\n associativeWith: []\n }\n },\n { // factorial\n 'OperatorNode:factorial': {\n op: '!',\n associativity: 'left'\n }\n },\n { // matrix transpose\n 'OperatorNode:ctranspose': {\n op: \"'\",\n associativity: 'left'\n }\n }\n]\n\n/**\n * Returns the first non-parenthesis internal node, but only\n * when the 'parenthesis' option is unset or auto.\n * @param {Node} _node\n * @param {string} parenthesis\n * @return {Node}\n */\nfunction unwrapParen (_node, parenthesis) {\n if (!parenthesis || parenthesis !== 'auto') return _node\n let node = _node\n while (isParenthesisNode(node)) node = node.content\n return node\n}\n\n/**\n * Get the precedence of a Node.\n * Higher number for higher precedence, starting with 0.\n * Returns null if the precedence is undefined.\n *\n * @param {Node} _node\n * @param {string} parenthesis\n * @param {string} implicit\n * @param {Node} parent (for determining context for implicit multiplication)\n * @return {number | null}\n */\nexport function getPrecedence (_node, parenthesis, implicit, parent) {\n let node = _node\n if (parenthesis !== 'keep') {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n node = _node.getContent()\n }\n const identifier = node.getIdentifier()\n let precedence = null\n for (let i = 0; i < properties.length; i++) {\n if (identifier in properties[i]) {\n precedence = i\n break\n }\n }\n // Bump up precedence of implicit multiplication, except when preceded\n // by a \"Rule 2\" fraction ( [unaryOp]constant / constant )\n if (identifier === 'OperatorNode:multiply' && node.implicit &&\n implicit !== 'show') {\n const leftArg = unwrapParen(node.args[0], parenthesis)\n if (!(isConstantNode(leftArg) && parent &&\n parent.getIdentifier() === 'OperatorNode:divide' &&\n rule2Node(unwrapParen(parent.args[0], parenthesis))) &&\n !(leftArg.getIdentifier() === 'OperatorNode:divide' &&\n rule2Node(unwrapParen(leftArg.args[0], parenthesis)) &&\n isConstantNode(unwrapParen(leftArg.args[1])))\n ) {\n precedence += 1\n }\n }\n return precedence\n}\n\n/**\n * Get the associativity of an operator (left or right).\n * Returns a string containing 'left' or 'right' or null if\n * the associativity is not defined.\n *\n * @param {Node} _node\n * @param {string} parenthesis\n * @return {string|null}\n * @throws {Error}\n */\nexport function getAssociativity (_node, parenthesis) {\n let node = _node\n if (parenthesis !== 'keep') {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n node = _node.getContent()\n }\n const identifier = node.getIdentifier()\n const index = getPrecedence(node, parenthesis)\n if (index === null) {\n // node isn't in the list\n return null\n }\n const property = properties[index][identifier]\n\n if (hasOwnProperty(property, 'associativity')) {\n if (property.associativity === 'left') {\n return 'left'\n }\n if (property.associativity === 'right') {\n return 'right'\n }\n // associativity is invalid\n throw Error('\\'' + identifier + '\\' has the invalid associativity \\'' +\n property.associativity + '\\'.')\n }\n\n // associativity is undefined\n return null\n}\n\n/**\n * Check if an operator is associative with another operator.\n * Returns either true or false or null if not defined.\n *\n * @param {Node} nodeA\n * @param {Node} nodeB\n * @param {string} parenthesis\n * @return {boolean | null}\n */\nexport function isAssociativeWith (nodeA, nodeB, parenthesis) {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n const a = (parenthesis !== 'keep') ? nodeA.getContent() : nodeA\n const b = (parenthesis !== 'keep') ? nodeA.getContent() : nodeB\n const identifierA = a.getIdentifier()\n const identifierB = b.getIdentifier()\n const index = getPrecedence(a, parenthesis)\n if (index === null) {\n // node isn't in the list\n return null\n }\n const property = properties[index][identifierA]\n\n if (hasOwnProperty(property, 'associativeWith') &&\n (property.associativeWith instanceof Array)) {\n for (let i = 0; i < property.associativeWith.length; i++) {\n if (property.associativeWith[i] === identifierB) {\n return true\n }\n }\n return false\n }\n\n // associativeWith is not defined\n return null\n}\n\n/**\n * Get the operator associated with a function name.\n * Returns a string with the operator symbol, or null if the\n * input is not the name of a function associated with an\n * operator.\n *\n * @param {string} Function name\n * @return {string | null} Associated operator symbol, if any\n */\nexport function getOperator (fn) {\n const identifier = 'OperatorNode:' + fn\n for (const group of properties) {\n if (identifier in group) {\n return group[identifier].op\n }\n }\n return null\n}\n","import { isAccessorNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'\nimport { getSafeProperty, setSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { accessFactory } from './utils/access.js'\nimport { assignFactory } from './utils/assign.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'AssignmentNode'\nconst dependencies = [\n 'subset',\n '?matrix', // FIXME: should not be needed at all, should be handled by subset\n 'Node'\n]\n\nexport const createAssignmentNode = /* #__PURE__ */ factory(name, dependencies, ({ subset, matrix, Node }) => {\n const access = accessFactory({ subset })\n const assign = assignFactory({ subset, matrix })\n\n /*\n * Is parenthesis needed?\n * @param {node} node\n * @param {string} [parenthesis='keep']\n * @param {string} implicit\n * @private\n */\n function needParenthesis (node, parenthesis, implicit) {\n if (!parenthesis) {\n parenthesis = 'keep'\n }\n\n const precedence = getPrecedence(node, parenthesis, implicit)\n const exprPrecedence = getPrecedence(node.value, parenthesis, implicit)\n return (parenthesis === 'all') ||\n ((exprPrecedence !== null) && (exprPrecedence <= precedence))\n }\n\n class AssignmentNode extends Node {\n /**\n * @constructor AssignmentNode\n * @extends {Node}\n *\n * Define a symbol, like `a=3.2`, update a property like `a.b=3.2`, or\n * replace a subset of a matrix like `A[2,2]=42`.\n *\n * Syntax:\n *\n * new AssignmentNode(symbol, value)\n * new AssignmentNode(object, index, value)\n *\n * Usage:\n *\n * new AssignmentNode(new SymbolNode('a'), new ConstantNode(2)) // a=2\n * new AssignmentNode(new SymbolNode('a'),\n * new IndexNode('b'),\n * new ConstantNode(2)) // a.b=2\n * new AssignmentNode(new SymbolNode('a'),\n * new IndexNode(1, 2),\n * new ConstantNode(3)) // a[1,2]=3\n *\n * @param {SymbolNode | AccessorNode} object\n * Object on which to assign a value\n * @param {IndexNode} [index=null]\n * Index, property name or matrix index. Optional. If not provided\n * and `object` is a SymbolNode, the property is assigned to the\n * global scope.\n * @param {Node} value\n * The value to be assigned\n */\n constructor (object, index, value) {\n super()\n this.object = object\n this.index = value ? index : null\n this.value = value || index\n\n // validate input\n if (!isSymbolNode(object) && !isAccessorNode(object)) {\n throw new TypeError('SymbolNode or AccessorNode expected as \"object\"')\n }\n if (isSymbolNode(object) && object.name === 'end') {\n throw new Error('Cannot assign to symbol \"end\"')\n }\n if (this.index && !isIndexNode(this.index)) { // index is optional\n throw new TypeError('IndexNode expected as \"index\"')\n }\n if (!isNode(this.value)) {\n throw new TypeError('Node expected as \"value\"')\n }\n }\n\n // class name for typing purposes:\n static name = name\n\n // readonly property name\n get name () {\n if (this.index) {\n return (this.index.isObjectProperty())\n ? this.index.getObjectProperty()\n : ''\n } else {\n return this.object.name || ''\n }\n }\n\n get type () { return name }\n get isAssignmentNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalObject = this.object._compile(math, argNames)\n const evalIndex = this.index ? this.index._compile(math, argNames) : null\n const evalValue = this.value._compile(math, argNames)\n const name = this.object.name\n\n if (!this.index) {\n // apply a variable to the scope, for example `a=2`\n if (!isSymbolNode(this.object)) {\n throw new TypeError('SymbolNode expected as object')\n }\n\n return function evalAssignmentNode (scope, args, context) {\n const value = evalValue(scope, args, context)\n scope.set(name, value)\n return value\n }\n } else if (this.index.isObjectProperty()) {\n // apply an object property for example `a.b=2`\n const prop = this.index.getObjectProperty()\n\n return function evalAssignmentNode (scope, args, context) {\n const object = evalObject(scope, args, context)\n const value = evalValue(scope, args, context)\n setSafeProperty(object, prop, value)\n return value\n }\n } else if (isSymbolNode(this.object)) {\n // update a matrix subset, for example `a[2]=3`\n return function evalAssignmentNode (scope, args, context) {\n const childObject = evalObject(scope, args, context)\n const value = evalValue(scope, args, context)\n // Important: we pass childObject instead of context:\n const index = evalIndex(scope, args, childObject)\n scope.set(name, assign(childObject, index, value))\n return value\n }\n } else { // isAccessorNode(node.object) === true\n // update a matrix subset, for example `a.b[2]=3`\n\n // we will not use the compile function of the AccessorNode, but\n // compile it ourselves here as we need the parent object of the\n // AccessorNode:\n // wee need to apply the updated object to parent object\n const evalParentObject = this.object.object._compile(math, argNames)\n\n if (this.object.index.isObjectProperty()) {\n const parentProp = this.object.index.getObjectProperty()\n\n return function evalAssignmentNode (scope, args, context) {\n const parent = evalParentObject(scope, args, context)\n const childObject = getSafeProperty(parent, parentProp)\n // Important: we pass childObject instead of context:\n const index = evalIndex(scope, args, childObject)\n const value = evalValue(scope, args, context)\n setSafeProperty(\n parent, parentProp, assign(childObject, index, value))\n return value\n }\n } else {\n // if some parameters use the 'end' parameter, we need to calculate\n // the size\n const evalParentIndex = this.object.index._compile(math, argNames)\n\n return function evalAssignmentNode (scope, args, context) {\n const parent = evalParentObject(scope, args, context)\n // Important: we pass parent instead of context:\n const parentIndex = evalParentIndex(scope, args, parent)\n const childObject = access(parent, parentIndex)\n // Important: we pass childObject instead of context\n const index = evalIndex(scope, args, childObject)\n const value = evalValue(scope, args, context)\n\n assign(parent, parentIndex, assign(childObject, index, value))\n\n return value\n }\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.object, 'object', this)\n if (this.index) {\n callback(this.index, 'index', this)\n }\n callback(this.value, 'value', this)\n }\n\n /**\n * Create a new AssignmentNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {AssignmentNode} Returns a transformed copy of the node\n */\n map (callback) {\n const object = this._ifNode(callback(this.object, 'object', this))\n const index = this.index\n ? this._ifNode(callback(this.index, 'index', this))\n : null\n const value = this._ifNode(callback(this.value, 'value', this))\n\n return new AssignmentNode(object, index, value)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {AssignmentNode}\n */\n clone () {\n return new AssignmentNode(this.object, this.index, this.value)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string}\n */\n _toString (options) {\n const object = this.object.toString(options)\n const index = this.index ? this.index.toString(options) : ''\n let value = this.value.toString(options)\n if (needParenthesis(\n this, options && options.parenthesis, options && options.implicit)) {\n value = '(' + value + ')'\n }\n\n return object + index + ' = ' + value\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n object: this.object,\n index: this.index,\n value: this.value\n }\n }\n\n /**\n * Instantiate an AssignmentNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"AssignmentNode\", object: ..., index: ..., value: ...}`,\n * where mathjs is optional\n * @returns {AssignmentNode}\n */\n static fromJSON (json) {\n return new AssignmentNode(json.object, json.index, json.value)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string}\n */\n _toHTML (options) {\n const object = this.object.toHTML(options)\n const index = this.index ? this.index.toHTML(options) : ''\n let value = this.value.toHTML(options)\n if (needParenthesis(\n this, options && options.parenthesis, options && options.implicit)) {\n value = '(' +\n value +\n ')'\n }\n\n return object + index +\n '=' +\n value\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string}\n */\n _toTex (options) {\n const object = this.object.toTex(options)\n const index = this.index ? this.index.toTex(options) : ''\n let value = this.value.toTex(options)\n if (needParenthesis(\n this, options && options.parenthesis, options && options.implicit)) {\n value = `\\\\left(${value}\\\\right)`\n }\n\n return object + index + '=' + value\n }\n }\n\n return AssignmentNode\n}, { isClass: true, isNode: true })\n","import { errorTransform } from '../../transform/utils/errorTransform.js'\nimport { setSafeProperty } from '../../../utils/customs.js'\n\nexport function assignFactory ({ subset, matrix }) {\n /**\n * Replace part of an object:\n *\n * - Assign a property to an object\n * - Replace a part of a string\n * - Replace a matrix subset\n *\n * @param {Object | Array | Matrix | string} object\n * @param {Index} index\n * @param {*} value\n * @return {Object | Array | Matrix | string} Returns the original object\n * except in case of a string\n */\n // TODO: change assign to return the value instead of the object\n return function assign (object, index, value) {\n try {\n if (Array.isArray(object)) {\n const result = matrix(object).subset(index, value).valueOf()\n\n // shallow copy all (updated) items into the original array\n result.forEach((item, index) => {\n object[index] = item\n })\n\n return object\n } else if (object && typeof object.subset === 'function') { // Matrix\n return object.subset(index, value)\n } else if (typeof object === 'string') {\n // TODO: move setStringSubset into a separate util file, use that\n return subset(object, index, value)\n } else if (typeof object === 'object') {\n if (!index.isObjectProperty()) {\n throw TypeError('Cannot apply a numeric index as object property')\n }\n setSafeProperty(object, index.getObjectProperty(), value)\n return object\n } else {\n throw new TypeError('Cannot apply index: unsupported type of object')\n }\n } catch (err) {\n throw errorTransform(err)\n }\n }\n}\n","import { isNode } from '../../utils/is.js'\nimport { forEach, map } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'BlockNode'\nconst dependencies = [\n 'ResultSet',\n 'Node'\n]\n\nexport const createBlockNode = /* #__PURE__ */ factory(name, dependencies, ({ ResultSet, Node }) => {\n class BlockNode extends Node {\n /**\n * @constructor BlockNode\n * @extends {Node}\n * Holds a set with blocks\n * @param {Array.<{node: Node} | {node: Node, visible: boolean}>} blocks\n * An array with blocks, where a block is constructed as an\n * Object with properties block, which is a Node, and visible,\n * which is a boolean. The property visible is optional and\n * is true by default\n */\n constructor (blocks) {\n super()\n // validate input, copy blocks\n if (!Array.isArray(blocks)) throw new Error('Array expected')\n this.blocks = blocks.map(function (block) {\n const node = block && block.node\n const visible = block &&\n block.visible !== undefined\n ? block.visible\n : true\n\n if (!isNode(node)) throw new TypeError('Property \"node\" must be a Node')\n if (typeof visible !== 'boolean') { throw new TypeError('Property \"visible\" must be a boolean') }\n\n return { node, visible }\n })\n }\n\n static name = name\n get type () { return name }\n get isBlockNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalBlocks = map(this.blocks, function (block) {\n return {\n evaluate: block.node._compile(math, argNames),\n visible: block.visible\n }\n })\n\n return function evalBlockNodes (scope, args, context) {\n const results = []\n\n forEach(evalBlocks, function evalBlockNode (block) {\n const result = block.evaluate(scope, args, context)\n if (block.visible) {\n results.push(result)\n }\n })\n\n return new ResultSet(results)\n }\n }\n\n /**\n * Execute a callback for each of the child blocks of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n for (let i = 0; i < this.blocks.length; i++) {\n callback(this.blocks[i].node, 'blocks[' + i + '].node', this)\n }\n }\n\n /**\n * Create a new BlockNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {BlockNode} Returns a transformed copy of the node\n */\n map (callback) {\n const blocks = []\n for (let i = 0; i < this.blocks.length; i++) {\n const block = this.blocks[i]\n const node = this._ifNode(\n callback(block.node, 'blocks[' + i + '].node', this))\n blocks[i] = {\n node,\n visible: block.visible\n }\n }\n return new BlockNode(blocks)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {BlockNode}\n */\n clone () {\n const blocks = this.blocks.map(function (block) {\n return {\n node: block.node,\n visible: block.visible\n }\n })\n\n return new BlockNode(blocks)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toString (options) {\n return this.blocks.map(function (param) {\n return param.node.toString(options) + (param.visible ? '' : ';')\n }).join('\\n')\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n blocks: this.blocks\n }\n }\n\n /**\n * Instantiate an BlockNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"BlockNode\", blocks: [{node: ..., visible: false}, ...]}`,\n * where mathjs is optional\n * @returns {BlockNode}\n */\n static fromJSON (json) {\n return new BlockNode(json.blocks)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toHTML (options) {\n return this.blocks.map(function (param) {\n return param.node.toHTML(options) +\n (param.visible ? '' : ';')\n }).join('
    ')\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n return this.blocks.map(function (param) {\n return param.node.toTex(options) + (param.visible ? '' : ';')\n }).join('\\\\;\\\\;\\n')\n }\n }\n\n return BlockNode\n}, { isClass: true, isNode: true })\n","import { isBigNumber, isComplex, isNode, isUnit, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'ConditionalNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createConditionalNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n /**\n * Test whether a condition is met\n * @param {*} condition\n * @returns {boolean} true if condition is true or non-zero, else false\n */\n function testCondition (condition) {\n if (typeof condition === 'number' ||\n typeof condition === 'boolean' ||\n typeof condition === 'string') {\n return !!condition\n }\n\n if (condition) {\n if (isBigNumber(condition)) {\n return !condition.isZero()\n }\n\n if (isComplex(condition)) {\n return !!((condition.re || condition.im))\n }\n\n if (isUnit(condition)) {\n return !!condition.value\n }\n }\n\n if (condition === null || condition === undefined) {\n return false\n }\n\n throw new TypeError('Unsupported type of condition \"' + typeOf(condition) + '\"')\n }\n\n class ConditionalNode extends Node {\n /**\n * A lazy evaluating conditional operator: 'condition ? trueExpr : falseExpr'\n *\n * @param {Node} condition Condition, must result in a boolean\n * @param {Node} trueExpr Expression evaluated when condition is true\n * @param {Node} falseExpr Expression evaluated when condition is true\n *\n * @constructor ConditionalNode\n * @extends {Node}\n */\n constructor (condition, trueExpr, falseExpr) {\n super()\n if (!isNode(condition)) { throw new TypeError('Parameter condition must be a Node') }\n if (!isNode(trueExpr)) { throw new TypeError('Parameter trueExpr must be a Node') }\n if (!isNode(falseExpr)) { throw new TypeError('Parameter falseExpr must be a Node') }\n\n this.condition = condition\n this.trueExpr = trueExpr\n this.falseExpr = falseExpr\n }\n\n static name = name\n get type () { return name }\n get isConditionalNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalCondition = this.condition._compile(math, argNames)\n const evalTrueExpr = this.trueExpr._compile(math, argNames)\n const evalFalseExpr = this.falseExpr._compile(math, argNames)\n\n return function evalConditionalNode (scope, args, context) {\n return testCondition(evalCondition(scope, args, context))\n ? evalTrueExpr(scope, args, context)\n : evalFalseExpr(scope, args, context)\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.condition, 'condition', this)\n callback(this.trueExpr, 'trueExpr', this)\n callback(this.falseExpr, 'falseExpr', this)\n }\n\n /**\n * Create a new ConditionalNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ConditionalNode} Returns a transformed copy of the node\n */\n map (callback) {\n return new ConditionalNode(\n this._ifNode(callback(this.condition, 'condition', this)),\n this._ifNode(callback(this.trueExpr, 'trueExpr', this)),\n this._ifNode(callback(this.falseExpr, 'falseExpr', this))\n )\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {ConditionalNode}\n */\n clone () {\n return new ConditionalNode(this.condition, this.trueExpr, this.falseExpr)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const precedence =\n getPrecedence(this, parenthesis, options && options.implicit)\n\n // Enclose Arguments in parentheses if they are an OperatorNode\n // or have lower or equal precedence\n // NOTE: enclosing all OperatorNodes in parentheses is a decision\n // purely based on aesthetics and readability\n let condition = this.condition.toString(options)\n const conditionPrecedence =\n getPrecedence(this.condition, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.condition.type === 'OperatorNode') ||\n ((conditionPrecedence !== null) &&\n (conditionPrecedence <= precedence))) {\n condition = '(' + condition + ')'\n }\n\n let trueExpr = this.trueExpr.toString(options)\n const truePrecedence =\n getPrecedence(this.trueExpr, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.trueExpr.type === 'OperatorNode') ||\n ((truePrecedence !== null) && (truePrecedence <= precedence))) {\n trueExpr = '(' + trueExpr + ')'\n }\n\n let falseExpr = this.falseExpr.toString(options)\n const falsePrecedence =\n getPrecedence(this.falseExpr, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.falseExpr.type === 'OperatorNode') ||\n ((falsePrecedence !== null) && (falsePrecedence <= precedence))) {\n falseExpr = '(' + falseExpr + ')'\n }\n return condition + ' ? ' + trueExpr + ' : ' + falseExpr\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n condition: this.condition,\n trueExpr: this.trueExpr,\n falseExpr: this.falseExpr\n }\n }\n\n /**\n * Instantiate an ConditionalNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * ```\n * {\"mathjs\": \"ConditionalNode\",\n * \"condition\": ...,\n * \"trueExpr\": ...,\n * \"falseExpr\": ...}\n * ```\n * where mathjs is optional\n * @returns {ConditionalNode}\n */\n static fromJSON (json) {\n return new ConditionalNode(json.condition, json.trueExpr, json.falseExpr)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const precedence =\n getPrecedence(this, parenthesis, options && options.implicit)\n\n // Enclose Arguments in parentheses if they are an OperatorNode\n // or have lower or equal precedence\n // NOTE: enclosing all OperatorNodes in parentheses is a decision\n // purely based on aesthetics and readability\n let condition = this.condition.toHTML(options)\n const conditionPrecedence =\n getPrecedence(this.condition, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.condition.type === 'OperatorNode') ||\n ((conditionPrecedence !== null) &&\n (conditionPrecedence <= precedence))) {\n condition =\n '(' +\n condition +\n ')'\n }\n\n let trueExpr = this.trueExpr.toHTML(options)\n const truePrecedence =\n getPrecedence(this.trueExpr, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.trueExpr.type === 'OperatorNode') ||\n ((truePrecedence !== null) && (truePrecedence <= precedence))) {\n trueExpr =\n '(' +\n trueExpr +\n ')'\n }\n\n let falseExpr = this.falseExpr.toHTML(options)\n const falsePrecedence =\n getPrecedence(this.falseExpr, parenthesis, options && options.implicit)\n if ((parenthesis === 'all') ||\n (this.falseExpr.type === 'OperatorNode') ||\n ((falsePrecedence !== null) && (falsePrecedence <= precedence))) {\n falseExpr =\n '(' +\n falseExpr +\n ')'\n }\n return condition +\n '?' +\n trueExpr +\n ':' +\n falseExpr\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n return '\\\\begin{cases} {' +\n this.trueExpr.toTex(options) + '}, &\\\\quad{\\\\text{if }\\\\;' +\n this.condition.toTex(options) +\n '}\\\\\\\\{' + this.falseExpr.toTex(options) +\n '}, &\\\\quad{\\\\text{otherwise}}\\\\end{cases}'\n }\n }\n\n return ConditionalNode\n}, { isClass: true, isNode: true })\n","/* eslint no-template-curly-in-string: \"off\" */\n\nimport escapeLatexLib from 'escape-latex'\nimport { hasOwnProperty } from './object.js'\n\nexport const latexSymbols = {\n // GREEK LETTERS\n Alpha: 'A',\n alpha: '\\\\alpha',\n Beta: 'B',\n beta: '\\\\beta',\n Gamma: '\\\\Gamma',\n gamma: '\\\\gamma',\n Delta: '\\\\Delta',\n delta: '\\\\delta',\n Epsilon: 'E',\n epsilon: '\\\\epsilon',\n varepsilon: '\\\\varepsilon',\n Zeta: 'Z',\n zeta: '\\\\zeta',\n Eta: 'H',\n eta: '\\\\eta',\n Theta: '\\\\Theta',\n theta: '\\\\theta',\n vartheta: '\\\\vartheta',\n Iota: 'I',\n iota: '\\\\iota',\n Kappa: 'K',\n kappa: '\\\\kappa',\n varkappa: '\\\\varkappa',\n Lambda: '\\\\Lambda',\n lambda: '\\\\lambda',\n Mu: 'M',\n mu: '\\\\mu',\n Nu: 'N',\n nu: '\\\\nu',\n Xi: '\\\\Xi',\n xi: '\\\\xi',\n Omicron: 'O',\n omicron: 'o',\n Pi: '\\\\Pi',\n pi: '\\\\pi',\n varpi: '\\\\varpi',\n Rho: 'P',\n rho: '\\\\rho',\n varrho: '\\\\varrho',\n Sigma: '\\\\Sigma',\n sigma: '\\\\sigma',\n varsigma: '\\\\varsigma',\n Tau: 'T',\n tau: '\\\\tau',\n Upsilon: '\\\\Upsilon',\n upsilon: '\\\\upsilon',\n Phi: '\\\\Phi',\n phi: '\\\\phi',\n varphi: '\\\\varphi',\n Chi: 'X',\n chi: '\\\\chi',\n Psi: '\\\\Psi',\n psi: '\\\\psi',\n Omega: '\\\\Omega',\n omega: '\\\\omega',\n // logic\n true: '\\\\mathrm{True}',\n false: '\\\\mathrm{False}',\n // other\n i: 'i', // TODO use \\i ??\n inf: '\\\\infty',\n Inf: '\\\\infty',\n infinity: '\\\\infty',\n Infinity: '\\\\infty',\n oo: '\\\\infty',\n lim: '\\\\lim',\n undefined: '\\\\mathbf{?}'\n}\n\nexport const latexOperators = {\n transpose: '^\\\\top',\n ctranspose: '^H',\n factorial: '!',\n pow: '^',\n dotPow: '.^\\\\wedge', // TODO find ideal solution\n unaryPlus: '+',\n unaryMinus: '-',\n bitNot: '\\\\~', // TODO find ideal solution\n not: '\\\\neg',\n multiply: '\\\\cdot',\n divide: '\\\\frac', // TODO how to handle that properly?\n dotMultiply: '.\\\\cdot', // TODO find ideal solution\n dotDivide: '.:', // TODO find ideal solution\n mod: '\\\\mod',\n add: '+',\n subtract: '-',\n to: '\\\\rightarrow',\n leftShift: '<<',\n rightArithShift: '>>',\n rightLogShift: '>>>',\n equal: '=',\n unequal: '\\\\neq',\n smaller: '<',\n larger: '>',\n smallerEq: '\\\\leq',\n largerEq: '\\\\geq',\n bitAnd: '\\\\&',\n bitXor: '\\\\underline{|}',\n bitOr: '|',\n and: '\\\\wedge',\n xor: '\\\\veebar',\n or: '\\\\vee'\n}\n\nexport const latexFunctions = {\n // arithmetic\n abs: { 1: '\\\\left|${args[0]}\\\\right|' },\n add: { 2: `\\\\left(\\${args[0]}${latexOperators.add}\\${args[1]}\\\\right)` },\n cbrt: { 1: '\\\\sqrt[3]{${args[0]}}' },\n ceil: { 1: '\\\\left\\\\lceil${args[0]}\\\\right\\\\rceil' },\n cube: { 1: '\\\\left(${args[0]}\\\\right)^3' },\n divide: { 2: '\\\\frac{${args[0]}}{${args[1]}}' },\n dotDivide: { 2: `\\\\left(\\${args[0]}${latexOperators.dotDivide}\\${args[1]}\\\\right)` },\n dotMultiply: { 2: `\\\\left(\\${args[0]}${latexOperators.dotMultiply}\\${args[1]}\\\\right)` },\n dotPow: { 2: `\\\\left(\\${args[0]}${latexOperators.dotPow}\\${args[1]}\\\\right)` },\n exp: { 1: '\\\\exp\\\\left(${args[0]}\\\\right)' },\n expm1: `\\\\left(e${latexOperators.pow}{\\${args[0]}}-1\\\\right)`,\n fix: { 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)' },\n floor: { 1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rfloor' },\n gcd: '\\\\gcd\\\\left(${args}\\\\right)',\n hypot: '\\\\hypot\\\\left(${args}\\\\right)',\n log: {\n 1: '\\\\ln\\\\left(${args[0]}\\\\right)',\n 2: '\\\\log_{${args[1]}}\\\\left(${args[0]}\\\\right)'\n },\n log10: { 1: '\\\\log_{10}\\\\left(${args[0]}\\\\right)' },\n log1p: {\n 1: '\\\\ln\\\\left(${args[0]}+1\\\\right)',\n 2: '\\\\log_{${args[1]}}\\\\left(${args[0]}+1\\\\right)'\n },\n log2: '\\\\log_{2}\\\\left(${args[0]}\\\\right)',\n mod: { 2: `\\\\left(\\${args[0]}${latexOperators.mod}\\${args[1]}\\\\right)` },\n multiply: { 2: `\\\\left(\\${args[0]}${latexOperators.multiply}\\${args[1]}\\\\right)` },\n norm: {\n 1: '\\\\left\\\\|${args[0]}\\\\right\\\\|',\n 2: undefined // use default template\n },\n nthRoot: { 2: '\\\\sqrt[${args[1]}]{${args[0]}}' },\n nthRoots: { 2: '\\\\{y : $y^{args[1]} = {${args[0]}}\\\\}' },\n pow: { 2: `\\\\left(\\${args[0]}\\\\right)${latexOperators.pow}{\\${args[1]}}` },\n round: {\n 1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rceil',\n 2: undefined // use default template\n },\n sign: { 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)' },\n sqrt: { 1: '\\\\sqrt{${args[0]}}' },\n square: { 1: '\\\\left(${args[0]}\\\\right)^2' },\n subtract: { 2: `\\\\left(\\${args[0]}${latexOperators.subtract}\\${args[1]}\\\\right)` },\n unaryMinus: { 1: `${latexOperators.unaryMinus}\\\\left(\\${args[0]}\\\\right)` },\n unaryPlus: { 1: `${latexOperators.unaryPlus}\\\\left(\\${args[0]}\\\\right)` },\n\n // bitwise\n bitAnd: { 2: `\\\\left(\\${args[0]}${latexOperators.bitAnd}\\${args[1]}\\\\right)` },\n bitNot: { 1: latexOperators.bitNot + '\\\\left(${args[0]}\\\\right)' },\n bitOr: { 2: `\\\\left(\\${args[0]}${latexOperators.bitOr}\\${args[1]}\\\\right)` },\n bitXor: { 2: `\\\\left(\\${args[0]}${latexOperators.bitXor}\\${args[1]}\\\\right)` },\n leftShift: { 2: `\\\\left(\\${args[0]}${latexOperators.leftShift}\\${args[1]}\\\\right)` },\n rightArithShift: { 2: `\\\\left(\\${args[0]}${latexOperators.rightArithShift}\\${args[1]}\\\\right)` },\n rightLogShift: { 2: `\\\\left(\\${args[0]}${latexOperators.rightLogShift}\\${args[1]}\\\\right)` },\n\n // combinatorics\n bellNumbers: { 1: '\\\\mathrm{B}_{${args[0]}}' },\n catalan: { 1: '\\\\mathrm{C}_{${args[0]}}' },\n stirlingS2: { 2: '\\\\mathrm{S}\\\\left(${args}\\\\right)' },\n\n // complex\n arg: { 1: '\\\\arg\\\\left(${args[0]}\\\\right)' },\n conj: { 1: '\\\\left(${args[0]}\\\\right)^*' },\n im: { 1: '\\\\Im\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace' },\n re: { 1: '\\\\Re\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace' },\n\n // logical\n and: { 2: `\\\\left(\\${args[0]}${latexOperators.and}\\${args[1]}\\\\right)` },\n not: { 1: latexOperators.not + '\\\\left(${args[0]}\\\\right)' },\n or: { 2: `\\\\left(\\${args[0]}${latexOperators.or}\\${args[1]}\\\\right)` },\n xor: { 2: `\\\\left(\\${args[0]}${latexOperators.xor}\\${args[1]}\\\\right)` },\n\n // matrix\n cross: { 2: '\\\\left(${args[0]}\\\\right)\\\\times\\\\left(${args[1]}\\\\right)' },\n ctranspose: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.ctranspose}` },\n det: { 1: '\\\\det\\\\left(${args[0]}\\\\right)' },\n dot: { 2: '\\\\left(${args[0]}\\\\cdot${args[1]}\\\\right)' },\n expm: { 1: '\\\\exp\\\\left(${args[0]}\\\\right)' },\n inv: { 1: '\\\\left(${args[0]}\\\\right)^{-1}' },\n pinv: { 1: '\\\\left(${args[0]}\\\\right)^{+}' },\n sqrtm: { 1: `{\\${args[0]}}${latexOperators.pow}{\\\\frac{1}{2}}` },\n trace: { 1: '\\\\mathrm{tr}\\\\left(${args[0]}\\\\right)' },\n transpose: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.transpose}` },\n\n // probability\n combinations: { 2: '\\\\binom{${args[0]}}{${args[1]}}' },\n combinationsWithRep: { 2: '\\\\left(\\\\!\\\\!{\\\\binom{${args[0]}}{${args[1]}}}\\\\!\\\\!\\\\right)' },\n factorial: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.factorial}` },\n gamma: { 1: '\\\\Gamma\\\\left(${args[0]}\\\\right)' },\n lgamma: { 1: '\\\\ln\\\\Gamma\\\\left(${args[0]}\\\\right)' },\n\n // relational\n equal: { 2: `\\\\left(\\${args[0]}${latexOperators.equal}\\${args[1]}\\\\right)` },\n larger: { 2: `\\\\left(\\${args[0]}${latexOperators.larger}\\${args[1]}\\\\right)` },\n largerEq: { 2: `\\\\left(\\${args[0]}${latexOperators.largerEq}\\${args[1]}\\\\right)` },\n smaller: { 2: `\\\\left(\\${args[0]}${latexOperators.smaller}\\${args[1]}\\\\right)` },\n smallerEq: { 2: `\\\\left(\\${args[0]}${latexOperators.smallerEq}\\${args[1]}\\\\right)` },\n unequal: { 2: `\\\\left(\\${args[0]}${latexOperators.unequal}\\${args[1]}\\\\right)` },\n\n // special\n erf: { 1: 'erf\\\\left(${args[0]}\\\\right)' },\n\n // statistics\n max: '\\\\max\\\\left(${args}\\\\right)',\n min: '\\\\min\\\\left(${args}\\\\right)',\n variance: '\\\\mathrm{Var}\\\\left(${args}\\\\right)',\n\n // trigonometry\n acos: { 1: '\\\\cos^{-1}\\\\left(${args[0]}\\\\right)' },\n acosh: { 1: '\\\\cosh^{-1}\\\\left(${args[0]}\\\\right)' },\n acot: { 1: '\\\\cot^{-1}\\\\left(${args[0]}\\\\right)' },\n acoth: { 1: '\\\\coth^{-1}\\\\left(${args[0]}\\\\right)' },\n acsc: { 1: '\\\\csc^{-1}\\\\left(${args[0]}\\\\right)' },\n acsch: { 1: '\\\\mathrm{csch}^{-1}\\\\left(${args[0]}\\\\right)' },\n asec: { 1: '\\\\sec^{-1}\\\\left(${args[0]}\\\\right)' },\n asech: { 1: '\\\\mathrm{sech}^{-1}\\\\left(${args[0]}\\\\right)' },\n asin: { 1: '\\\\sin^{-1}\\\\left(${args[0]}\\\\right)' },\n asinh: { 1: '\\\\sinh^{-1}\\\\left(${args[0]}\\\\right)' },\n atan: { 1: '\\\\tan^{-1}\\\\left(${args[0]}\\\\right)' },\n atan2: { 2: '\\\\mathrm{atan2}\\\\left(${args}\\\\right)' },\n atanh: { 1: '\\\\tanh^{-1}\\\\left(${args[0]}\\\\right)' },\n cos: { 1: '\\\\cos\\\\left(${args[0]}\\\\right)' },\n cosh: { 1: '\\\\cosh\\\\left(${args[0]}\\\\right)' },\n cot: { 1: '\\\\cot\\\\left(${args[0]}\\\\right)' },\n coth: { 1: '\\\\coth\\\\left(${args[0]}\\\\right)' },\n csc: { 1: '\\\\csc\\\\left(${args[0]}\\\\right)' },\n csch: { 1: '\\\\mathrm{csch}\\\\left(${args[0]}\\\\right)' },\n sec: { 1: '\\\\sec\\\\left(${args[0]}\\\\right)' },\n sech: { 1: '\\\\mathrm{sech}\\\\left(${args[0]}\\\\right)' },\n sin: { 1: '\\\\sin\\\\left(${args[0]}\\\\right)' },\n sinh: { 1: '\\\\sinh\\\\left(${args[0]}\\\\right)' },\n tan: { 1: '\\\\tan\\\\left(${args[0]}\\\\right)' },\n tanh: { 1: '\\\\tanh\\\\left(${args[0]}\\\\right)' },\n\n // unit\n to: { 2: `\\\\left(\\${args[0]}${latexOperators.to}\\${args[1]}\\\\right)` },\n\n // utils\n numeric: function (node, options) {\n // Not sure if this is strictly right but should work correctly for the vast majority of use cases.\n return node.args[0].toTex()\n },\n\n // type\n number: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(\\\\left(${args[0]}\\\\right)${args[1]}\\\\right)'\n },\n string: {\n 0: '\\\\mathtt{\"\"}',\n 1: '\\\\mathrm{string}\\\\left(${args[0]}\\\\right)'\n },\n bignumber: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)'\n },\n bigint: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)'\n },\n complex: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: `\\\\left(\\\\left(\\${args[0]}\\\\right)+${latexSymbols.i}\\\\cdot\\\\left(\\${args[1]}\\\\right)\\\\right)`\n },\n matrix: {\n 0: '\\\\begin{bmatrix}\\\\end{bmatrix}',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(${args[0]}\\\\right)'\n },\n sparse: {\n 0: '\\\\begin{bsparse}\\\\end{bsparse}',\n 1: '\\\\left(${args[0]}\\\\right)'\n },\n unit: {\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(\\\\left(${args[0]}\\\\right)${args[1]}\\\\right)'\n }\n\n}\n\nexport const defaultTemplate = '\\\\mathrm{${name}}\\\\left(${args}\\\\right)'\n\nconst latexUnits = {\n deg: '^\\\\circ'\n}\n\nexport function escapeLatex (string) {\n return escapeLatexLib(string, { preserveFormatting: true })\n}\n\n// @param {string} name\n// @param {boolean} isUnit\nexport function toSymbol (name, isUnit) {\n isUnit = typeof isUnit === 'undefined' ? false : isUnit\n if (isUnit) {\n if (hasOwnProperty(latexUnits, name)) {\n return latexUnits[name]\n }\n\n return '\\\\mathrm{' + escapeLatex(name) + '}'\n }\n\n if (hasOwnProperty(latexSymbols, name)) {\n return latexSymbols[name]\n }\n\n return escapeLatex(name)\n}\n","import { format } from '../../utils/string.js'\nimport { typeOf } from '../../utils/is.js'\nimport { escapeLatex } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ConstantNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createConstantNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n class ConstantNode extends Node {\n /**\n * A ConstantNode holds a constant value like a number or string.\n *\n * Usage:\n *\n * new ConstantNode(2.3)\n * new ConstantNode('hello')\n *\n * @param {*} value Value can be any type (number, BigNumber, bigint, string, ...)\n * @constructor ConstantNode\n * @extends {Node}\n */\n constructor (value) {\n super()\n this.value = value\n }\n\n static name = name\n get type () { return name }\n get isConstantNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const value = this.value\n\n return function evalConstantNode () {\n return value\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n // nothing to do, we don't have any children\n }\n\n /**\n * Create a new ConstantNode with children produced by the given callback.\n * Trivial because there are no children.\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {ConstantNode} Returns a clone of the node\n */\n map (callback) {\n return this.clone()\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {ConstantNode}\n */\n clone () {\n return new ConstantNode(this.value)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n return format(this.value, options)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const value = this._toString(options)\n\n switch (typeOf(this.value)) {\n case 'number':\n case 'bigint':\n case 'BigNumber':\n case 'Fraction':\n return '' + value + ''\n case 'string':\n return '' + value + ''\n case 'boolean':\n return '' + value + ''\n case 'null':\n return '' + value + ''\n case 'undefined':\n return '' + value + ''\n\n default:\n return '' + value + ''\n }\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return { mathjs: name, value: this.value }\n }\n\n /**\n * Instantiate a ConstantNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SymbolNode\", value: 2.3}`,\n * where mathjs is optional\n * @returns {ConstantNode}\n */\n static fromJSON (json) {\n return new ConstantNode(json.value)\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const value = this._toString(options)\n const type = typeOf(this.value)\n\n switch (type) {\n case 'string':\n return '\\\\mathtt{' + escapeLatex(value) + '}'\n\n case 'number':\n case 'BigNumber': {\n const finite = type === 'BigNumber' ? this.value.isFinite() : isFinite(this.value)\n if (!finite) {\n return (this.value.valueOf() < 0)\n ? '-\\\\infty'\n : '\\\\infty'\n }\n\n const index = value.toLowerCase().indexOf('e')\n if (index !== -1) {\n return value.substring(0, index) + '\\\\cdot10^{' +\n value.substring(index + 1) + '}'\n }\n\n return value\n }\n\n case 'bigint': {\n return value.toString()\n }\n\n case 'Fraction':\n return this.value.toLatex()\n\n default:\n return value\n }\n }\n }\n\n return ConstantNode\n}, { isClass: true, isNode: true })\n","import { isNode } from '../../utils/is.js'\n\nimport { keywords } from '../keywords.js'\nimport { escape } from '../../utils/string.js'\nimport { forEach, join } from '../../utils/array.js'\nimport { toSymbol } from '../../utils/latex.js'\nimport { getPrecedence } from '../operators.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'FunctionAssignmentNode'\nconst dependencies = [\n 'typed',\n 'Node'\n]\n\nexport const createFunctionAssignmentNode = /* #__PURE__ */ factory(name, dependencies, ({ typed, Node }) => {\n /**\n * Is parenthesis needed?\n * @param {Node} node\n * @param {Object} parenthesis\n * @param {string} implicit\n * @private\n */\n function needParenthesis (node, parenthesis, implicit) {\n const precedence = getPrecedence(node, parenthesis, implicit)\n const exprPrecedence = getPrecedence(node.expr, parenthesis, implicit)\n\n return (parenthesis === 'all') ||\n ((exprPrecedence !== null) && (exprPrecedence <= precedence))\n }\n\n class FunctionAssignmentNode extends Node {\n /**\n * @constructor FunctionAssignmentNode\n * @extends {Node}\n * Function assignment\n *\n * @param {string} name Function name\n * @param {string[] | Array.<{name: string, type: string}>} params\n * Array with function parameter names, or an\n * array with objects containing the name\n * and type of the parameter\n * @param {Node} expr The function expression\n */\n constructor (name, params, expr) {\n super()\n // validate input\n if (typeof name !== 'string') { throw new TypeError('String expected for parameter \"name\"') }\n if (!Array.isArray(params)) {\n throw new TypeError(\n 'Array containing strings or objects expected for parameter \"params\"')\n }\n if (!isNode(expr)) { throw new TypeError('Node expected for parameter \"expr\"') }\n if (keywords.has(name)) { throw new Error('Illegal function name, \"' + name + '\" is a reserved keyword') }\n\n const paramNames = new Set()\n for (const param of params) {\n const name = typeof param === 'string' ? param : param.name\n if (paramNames.has(name)) {\n throw new Error(`Duplicate parameter name \"${name}\"`)\n } else {\n paramNames.add(name)\n }\n }\n\n this.name = name\n this.params = params.map(function (param) {\n return (param && param.name) || param\n })\n this.types = params.map(function (param) {\n return (param && param.type) || 'any'\n })\n this.expr = expr\n }\n\n static name = name\n get type () { return name }\n get isFunctionAssignmentNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const childArgNames = Object.create(argNames)\n forEach(this.params, function (param) {\n childArgNames[param] = true\n })\n\n // compile the function expression with the child args\n const evalExpr = this.expr._compile(math, childArgNames)\n const name = this.name\n const params = this.params\n const signature = join(this.types, ',')\n const syntax = name + '(' + join(this.params, ', ') + ')'\n\n return function evalFunctionAssignmentNode (scope, args, context) {\n const signatures = {}\n signatures[signature] = function () {\n const childArgs = Object.create(args)\n\n for (let i = 0; i < params.length; i++) {\n childArgs[params[i]] = arguments[i]\n }\n\n return evalExpr(scope, childArgs, context)\n }\n const fn = typed(name, signatures)\n fn.syntax = syntax\n\n scope.set(name, fn)\n\n return fn\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.expr, 'expr', this)\n }\n\n /**\n * Create a new FunctionAssignmentNode whose children are the results of\n * calling the provided callback function for each child of the original\n * node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {FunctionAssignmentNode} Returns a transformed copy of the node\n */\n map (callback) {\n const expr = this._ifNode(callback(this.expr, 'expr', this))\n\n return new FunctionAssignmentNode(this.name, this.params.slice(0), expr)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {FunctionAssignmentNode}\n */\n clone () {\n return new FunctionAssignmentNode(\n this.name, this.params.slice(0), this.expr)\n }\n\n /**\n * get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n let expr = this.expr.toString(options)\n if (needParenthesis(this, parenthesis, options && options.implicit)) {\n expr = '(' + expr + ')'\n }\n return this.name + '(' + this.params.join(', ') + ') = ' + expr\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n const types = this.types\n\n return {\n mathjs: name,\n name: this.name,\n params: this.params.map(function (param, index) {\n return {\n name: param,\n type: types[index]\n }\n }),\n expr: this.expr\n }\n }\n\n /**\n * Instantiate an FunctionAssignmentNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * ```\n * {\"mathjs\": \"FunctionAssignmentNode\",\n * name: ..., params: ..., expr: ...}\n * ```\n * where mathjs is optional\n * @returns {FunctionAssignmentNode}\n */\n static fromJSON (json) {\n return new FunctionAssignmentNode(json.name, json.params, json.expr)\n }\n\n /**\n * get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const parenthesis = (options && options.parenthesis) ? options.parenthesis : 'keep'\n const params = []\n for (let i = 0; i < this.params.length; i++) {\n params.push('' +\n escape(this.params[i]) + '')\n }\n let expr = this.expr.toHTML(options)\n if (needParenthesis(this, parenthesis, options && options.implicit)) {\n expr = '(' +\n expr +\n ')'\n }\n return '' +\n escape(this.name) + '' +\n '(' +\n params.join(',') +\n ')' +\n '=' +\n expr\n }\n\n /**\n * get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n let expr = this.expr.toTex(options)\n if (needParenthesis(this, parenthesis, options && options.implicit)) {\n expr = `\\\\left(${expr}\\\\right)`\n }\n\n return '\\\\mathrm{' + this.name +\n '}\\\\left(' + this.params.map(toSymbol).join(',') + '\\\\right)=' + expr\n }\n }\n\n return FunctionAssignmentNode\n}, { isClass: true, isNode: true })\n","import { map } from '../../utils/array.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { isArray, isConstantNode, isMatrix, isNode, isString, typeOf } from '../../utils/is.js'\nimport { escape } from '../../utils/string.js'\n\nconst name = 'IndexNode'\nconst dependencies = [\n 'Node',\n 'size'\n]\n\nexport const createIndexNode = /* #__PURE__ */ factory(name, dependencies, ({ Node, size }) => {\n class IndexNode extends Node {\n /**\n * @constructor IndexNode\n * @extends Node\n *\n * Describes a subset of a matrix or an object property.\n * Cannot be used on its own, needs to be used within an AccessorNode or\n * AssignmentNode.\n *\n * @param {Node[]} dimensions\n * @param {boolean} [dotNotation=false]\n * Optional property describing whether this index was written using dot\n * notation like `a.b`, or using bracket notation like `a[\"b\"]`\n * (which is the default). This property is used for string conversion.\n */\n constructor (dimensions, dotNotation) {\n super()\n this.dimensions = dimensions\n this.dotNotation = dotNotation || false\n\n // validate input\n if (!Array.isArray(dimensions) || !dimensions.every(isNode)) {\n throw new TypeError(\n 'Array containing Nodes expected for parameter \"dimensions\"')\n }\n if (this.dotNotation && !this.isObjectProperty()) {\n throw new Error('dotNotation only applicable for object properties')\n }\n }\n\n static name = name\n get type () { return name }\n get isIndexNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n // TODO: implement support for bignumber (currently bignumbers are silently\n // reduced to numbers when changing the value to zero-based)\n\n // TODO: Optimization: when the range values are ConstantNodes,\n // we can beforehand resolve the zero-based value\n\n // optimization for a simple object property\n const evalDimensions = map(this.dimensions, function (dimension, i) {\n const needsEnd = dimension\n .filter(node => node.isSymbolNode && node.name === 'end')\n .length > 0\n\n if (needsEnd) {\n // SymbolNode 'end' is used inside the index,\n // like in `A[end]` or `A[end - 2]`\n const childArgNames = Object.create(argNames)\n childArgNames.end = true\n\n const _evalDimension = dimension._compile(math, childArgNames)\n\n return function evalDimension (scope, args, context) {\n if (!isMatrix(context) && !isArray(context) && !isString(context)) {\n throw new TypeError(\n 'Cannot resolve \"end\": ' +\n 'context must be a Matrix, Array, or string but is ' +\n typeOf(context))\n }\n\n const s = size(context).valueOf()\n const childArgs = Object.create(args)\n childArgs.end = s[i]\n\n return _evalDimension(scope, childArgs, context)\n }\n } else {\n // SymbolNode `end` not used\n return dimension._compile(math, argNames)\n }\n })\n\n const index = getSafeProperty(math, 'index')\n\n return function evalIndexNode (scope, args, context) {\n const dimensions = map(evalDimensions, function (evalDimension) {\n return evalDimension(scope, args, context)\n })\n\n return index(...dimensions)\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n for (let i = 0; i < this.dimensions.length; i++) {\n callback(this.dimensions[i], 'dimensions[' + i + ']', this)\n }\n }\n\n /**\n * Create a new IndexNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {IndexNode} Returns a transformed copy of the node\n */\n map (callback) {\n const dimensions = []\n for (let i = 0; i < this.dimensions.length; i++) {\n dimensions[i] = this._ifNode(\n callback(this.dimensions[i], 'dimensions[' + i + ']', this))\n }\n\n return new IndexNode(dimensions, this.dotNotation)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {IndexNode}\n */\n clone () {\n return new IndexNode(this.dimensions.slice(0), this.dotNotation)\n }\n\n /**\n * Test whether this IndexNode contains a single property name\n * @return {boolean}\n */\n isObjectProperty () {\n return this.dimensions.length === 1 &&\n isConstantNode(this.dimensions[0]) &&\n typeof this.dimensions[0].value === 'string'\n }\n\n /**\n * Returns the property name if IndexNode contains a property.\n * If not, returns null.\n * @return {string | null}\n */\n getObjectProperty () {\n return this.isObjectProperty() ? this.dimensions[0].value : null\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n // format the parameters like \"[1, 0:5]\"\n return this.dotNotation\n ? ('.' + this.getObjectProperty())\n : ('[' + this.dimensions.join(', ') + ']')\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n dimensions: this.dimensions,\n dotNotation: this.dotNotation\n }\n }\n\n /**\n * Instantiate an IndexNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"IndexNode\", dimensions: [...], dotNotation: false}`,\n * where mathjs is optional\n * @returns {IndexNode}\n */\n static fromJSON (json) {\n return new IndexNode(json.dimensions, json.dotNotation)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n // format the parameters like \"[1, 0:5]\"\n const dimensions = []\n for (let i = 0; i < this.dimensions.length; i++) {\n dimensions[i] = this.dimensions[i].toHTML()\n }\n if (this.dotNotation) {\n return '.' +\n '' +\n escape(this.getObjectProperty()) + ''\n } else {\n return '[' +\n dimensions.join(',') +\n ']'\n }\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const dimensions = this.dimensions.map(function (range) {\n return range.toTex(options)\n })\n\n return this.dotNotation\n ? ('.' + this.getObjectProperty() + '')\n : ('_{' + dimensions.join(',') + '}')\n }\n }\n\n return IndexNode\n}, { isClass: true, isNode: true })\n","import { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNode } from '../../utils/is.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { escape, stringify } from '../../utils/string.js'\n\nconst name = 'ObjectNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createObjectNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n class ObjectNode extends Node {\n /**\n * @constructor ObjectNode\n * @extends {Node}\n * Holds an object with keys/values\n * @param {Object.} [properties] object with key/value pairs\n */\n constructor (properties) {\n super()\n this.properties = properties || {}\n\n // validate input\n if (properties) {\n if (!(typeof properties === 'object') ||\n !Object.keys(properties).every(function (key) {\n return isNode(properties[key])\n })) {\n throw new TypeError('Object containing Nodes expected')\n }\n }\n }\n\n static name = name\n get type () { return name }\n get isObjectNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const evalEntries = {}\n\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n // we stringify/parse the key here to resolve unicode characters,\n // so you cannot create a key like {\"co\\\\u006Estructor\": null}\n const stringifiedKey = stringify(key)\n const parsedKey = JSON.parse(stringifiedKey)\n const prop = getSafeProperty(this.properties, key)\n\n evalEntries[parsedKey] = prop._compile(math, argNames)\n }\n }\n\n return function evalObjectNode (scope, args, context) {\n const obj = {}\n\n for (const key in evalEntries) {\n if (hasOwnProperty(evalEntries, key)) {\n obj[key] = evalEntries[key](scope, args, context)\n }\n }\n\n return obj\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n callback(\n this.properties[key], 'properties[' + stringify(key) + ']', this)\n }\n }\n }\n\n /**\n * Create a new ObjectNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ObjectNode} Returns a transformed copy of the node\n */\n map (callback) {\n const properties = {}\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n properties[key] = this._ifNode(\n callback(\n this.properties[key], 'properties[' + stringify(key) + ']', this))\n }\n }\n return new ObjectNode(properties)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {ObjectNode}\n */\n clone () {\n const properties = {}\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n properties[key] = this.properties[key]\n }\n }\n return new ObjectNode(properties)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toString (options) {\n const entries = []\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n entries.push(\n stringify(key) + ': ' + this.properties[key].toString(options))\n }\n }\n return '{' + entries.join(', ') + '}'\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n properties: this.properties\n }\n }\n\n /**\n * Instantiate an OperatorNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ObjectNode\", \"properties\": {...}}`,\n * where mathjs is optional\n * @returns {ObjectNode}\n */\n static fromJSON (json) {\n return new ObjectNode(json.properties)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toHTML (options) {\n const entries = []\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n entries.push(\n '' + escape(key) + '' +\n '' +\n ':' + this.properties[key].toHTML(options))\n }\n }\n return '{' +\n entries.join(',') +\n '}'\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const entries = []\n for (const key in this.properties) {\n if (hasOwnProperty(this.properties, key)) {\n entries.push(\n '\\\\mathbf{' + key + ':} & ' +\n this.properties[key].toTex(options) + '\\\\\\\\')\n }\n }\n const tex = '\\\\left\\\\{\\\\begin{array}{ll}' + entries.join('\\n') +\n '\\\\end{array}\\\\right\\\\}'\n return tex\n }\n }\n\n return ObjectNode\n}, { isClass: true, isNode: true })\n","import { ObjectWrappingMap, PartitionedMap } from './map.js'\n\n/**\n * Create a new scope which can access the parent scope,\n * but does not affect it when written. This is suitable for variable definitions\n * within a block node, or function definition.\n *\n * If parent scope has a createSubScope method, it delegates to that. Otherwise,\n * creates an empty map, and copies the parent scope to it, adding in\n * the remaining `args`.\n *\n * @param {Map} parentScope\n * @param {Object} args\n * @returns {PartitionedMap}\n */\nexport function createSubScope (parentScope, args) {\n return new PartitionedMap(\n parentScope,\n new ObjectWrappingMap(args),\n new Set(Object.keys(args))\n )\n}\n","import { isNode, isConstantNode, isOperatorNode, isParenthesisNode } from '../../utils/is.js'\nimport { map } from '../../utils/array.js'\nimport { createSubScope } from '../../utils/scope.js'\nimport { escape } from '../../utils/string.js'\nimport { getSafeProperty, isSafeMethod } from '../../utils/customs.js'\nimport { getAssociativity, getPrecedence, isAssociativeWith, properties } from '../operators.js'\nimport { latexOperators } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'OperatorNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createOperatorNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n /**\n * Returns true if the expression starts with a constant, under\n * the current parenthesization:\n * @param {Node} expression\n * @param {string} parenthesis\n * @return {boolean}\n */\n function startsWithConstant (expr, parenthesis) {\n let curNode = expr\n if (parenthesis === 'auto') {\n while (isParenthesisNode(curNode)) curNode = curNode.content\n }\n if (isConstantNode(curNode)) return true\n if (isOperatorNode(curNode)) {\n return startsWithConstant(curNode.args[0], parenthesis)\n }\n return false\n }\n\n /**\n * Calculate which parentheses are necessary. Gets an OperatorNode\n * (which is the root of the tree) and an Array of Nodes\n * (this.args) and returns an array where 'true' means that an argument\n * has to be enclosed in parentheses whereas 'false' means the opposite.\n *\n * @param {OperatorNode} root\n * @param {string} parenthesis\n * @param {Node[]} args\n * @param {boolean} latex\n * @return {boolean[]}\n * @private\n */\n function calculateNecessaryParentheses (root, parenthesis, implicit, args, latex) {\n // precedence of the root OperatorNode\n const precedence = getPrecedence(root, parenthesis, implicit)\n const associativity = getAssociativity(root, parenthesis)\n\n if ((parenthesis === 'all') || ((args.length > 2) && (root.getIdentifier() !== 'OperatorNode:add') && (root.getIdentifier() !== 'OperatorNode:multiply'))) {\n return args.map(function (arg) {\n switch (arg.getContent().type) { // Nodes that don't need extra parentheses\n case 'ArrayNode':\n case 'ConstantNode':\n case 'SymbolNode':\n case 'ParenthesisNode':\n return false\n default:\n return true\n }\n })\n }\n\n let result\n switch (args.length) {\n case 0:\n result = []\n break\n\n case 1: // unary operators\n {\n // precedence of the operand\n const operandPrecedence = getPrecedence(args[0], parenthesis, implicit, root)\n\n // handle special cases for LaTeX, where some of the parentheses aren't needed\n if (latex && (operandPrecedence !== null)) {\n let operandIdentifier\n let rootIdentifier\n if (parenthesis === 'keep') {\n operandIdentifier = args[0].getIdentifier()\n rootIdentifier = root.getIdentifier()\n } else {\n // Ignore Parenthesis Nodes when not in 'keep' mode\n operandIdentifier = args[0].getContent().getIdentifier()\n rootIdentifier = root.getContent().getIdentifier()\n }\n if (properties[precedence][rootIdentifier].latexLeftParens === false) {\n result = [false]\n break\n }\n\n if (properties[operandPrecedence][operandIdentifier].latexParens === false) {\n result = [false]\n break\n }\n }\n\n if (operandPrecedence === null) {\n // if the operand has no defined precedence, no parens are needed\n result = [false]\n break\n }\n\n if (operandPrecedence <= precedence) {\n // if the operands precedence is lower, parens are needed\n result = [true]\n break\n }\n\n // otherwise, no parens needed\n result = [false]\n }\n break\n case 2: // binary operators\n {\n let lhsParens // left hand side needs parenthesis?\n // precedence of the left hand side\n const lhsPrecedence = getPrecedence(args[0], parenthesis, implicit, root)\n // is the root node associative with the left hand side\n const assocWithLhs = isAssociativeWith(root, args[0], parenthesis)\n\n if (lhsPrecedence === null) {\n // if the left hand side has no defined precedence, no parens are needed\n // FunctionNode for example\n lhsParens = false\n } else if ((lhsPrecedence === precedence) && (associativity === 'right') && !assocWithLhs) {\n // In case of equal precedence, if the root node is left associative\n // parens are **never** necessary for the left hand side.\n // If it is right associative however, parens are necessary\n // if the root node isn't associative with the left hand side\n lhsParens = true\n } else if (lhsPrecedence < precedence) {\n lhsParens = true\n } else {\n lhsParens = false\n }\n\n let rhsParens // right hand side needs parenthesis?\n // precedence of the right hand side\n const rhsPrecedence = getPrecedence(args[1], parenthesis, implicit, root)\n // is the root node associative with the right hand side?\n const assocWithRhs = isAssociativeWith(root, args[1], parenthesis)\n\n if (rhsPrecedence === null) {\n // if the right hand side has no defined precedence, no parens are needed\n // FunctionNode for example\n rhsParens = false\n } else if ((rhsPrecedence === precedence) && (associativity === 'left') && !assocWithRhs) {\n // In case of equal precedence, if the root node is right associative\n // parens are **never** necessary for the right hand side.\n // If it is left associative however, parens are necessary\n // if the root node isn't associative with the right hand side\n rhsParens = true\n } else if (rhsPrecedence < precedence) {\n rhsParens = true\n } else {\n rhsParens = false\n }\n\n // handle special cases for LaTeX, where some of the parentheses aren't needed\n if (latex) {\n let rootIdentifier\n let lhsIdentifier\n let rhsIdentifier\n if (parenthesis === 'keep') {\n rootIdentifier = root.getIdentifier()\n lhsIdentifier = root.args[0].getIdentifier()\n rhsIdentifier = root.args[1].getIdentifier()\n } else {\n // Ignore ParenthesisNodes when not in 'keep' mode\n rootIdentifier = root.getContent().getIdentifier()\n lhsIdentifier = root.args[0].getContent().getIdentifier()\n rhsIdentifier = root.args[1].getContent().getIdentifier()\n }\n\n if (lhsPrecedence !== null) {\n if (properties[precedence][rootIdentifier].latexLeftParens === false) {\n lhsParens = false\n }\n\n if (properties[lhsPrecedence][lhsIdentifier].latexParens === false) {\n lhsParens = false\n }\n }\n\n if (rhsPrecedence !== null) {\n if (properties[precedence][rootIdentifier].latexRightParens === false) {\n rhsParens = false\n }\n\n if (properties[rhsPrecedence][rhsIdentifier].latexParens === false) {\n rhsParens = false\n }\n }\n }\n\n result = [lhsParens, rhsParens]\n }\n break\n\n default:\n if ((root.getIdentifier() === 'OperatorNode:add') || (root.getIdentifier() === 'OperatorNode:multiply')) {\n result = args.map(function (arg) {\n const argPrecedence = getPrecedence(arg, parenthesis, implicit, root)\n const assocWithArg = isAssociativeWith(root, arg, parenthesis)\n const argAssociativity = getAssociativity(arg, parenthesis)\n if (argPrecedence === null) {\n // if the argument has no defined precedence, no parens are needed\n return false\n } else if ((precedence === argPrecedence) && (associativity === argAssociativity) && !assocWithArg) {\n return true\n } else if (argPrecedence < precedence) {\n return true\n }\n\n return false\n })\n }\n break\n }\n\n // Handles an edge case of parentheses with implicit multiplication\n // of ConstantNode.\n // In that case, parenthesize ConstantNodes that follow an unparenthesized\n // expression, even though they normally wouldn't be printed.\n if (args.length >= 2 && root.getIdentifier() === 'OperatorNode:multiply' &&\n root.implicit && parenthesis !== 'all' && implicit === 'hide') {\n for (let i = 1; i < result.length; ++i) {\n if (startsWithConstant(args[i], parenthesis) && !result[i - 1] &&\n (parenthesis !== 'keep' || !isParenthesisNode(args[i - 1]))) {\n result[i] = true\n }\n }\n }\n\n return result\n }\n\n class OperatorNode extends Node {\n /**\n * @constructor OperatorNode\n * @extends {Node}\n * An operator with two arguments, like 2+3\n *\n * @param {string} op Operator name, for example '+'\n * @param {string} fn Function name, for example 'add'\n * @param {Node[]} args Operator arguments\n * @param {boolean} [implicit] Is this an implicit multiplication?\n * @param {boolean} [isPercentage] Is this an percentage Operation?\n */\n constructor (op, fn, args, implicit, isPercentage) {\n super()\n // validate input\n if (typeof op !== 'string') {\n throw new TypeError('string expected for parameter \"op\"')\n }\n if (typeof fn !== 'string') {\n throw new TypeError('string expected for parameter \"fn\"')\n }\n if (!Array.isArray(args) || !args.every(isNode)) {\n throw new TypeError(\n 'Array containing Nodes expected for parameter \"args\"')\n }\n\n this.implicit = (implicit === true)\n this.isPercentage = (isPercentage === true)\n this.op = op\n this.fn = fn\n this.args = args || []\n }\n\n static name = name\n get type () { return name }\n get isOperatorNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n // validate fn\n if (typeof this.fn !== 'string' || !isSafeMethod(math, this.fn)) {\n if (!math[this.fn]) {\n throw new Error(\n 'Function ' + this.fn + ' missing in provided namespace \"math\"')\n } else {\n throw new Error('No access to function \"' + this.fn + '\"')\n }\n }\n\n const fn = getSafeProperty(math, this.fn)\n const evalArgs = map(this.args, function (arg) {\n return arg._compile(math, argNames)\n })\n\n if (typeof fn === 'function' && fn.rawArgs === true) {\n // pass unevaluated parameters (nodes) to the function\n // \"raw\" evaluation\n const rawArgs = this.args\n return function evalOperatorNode (scope, args, context) {\n return fn(rawArgs, math, createSubScope(scope, args))\n }\n } else if (evalArgs.length === 1) {\n const evalArg0 = evalArgs[0]\n return function evalOperatorNode (scope, args, context) {\n return fn(evalArg0(scope, args, context))\n }\n } else if (evalArgs.length === 2) {\n const evalArg0 = evalArgs[0]\n const evalArg1 = evalArgs[1]\n return function evalOperatorNode (scope, args, context) {\n return fn(\n evalArg0(scope, args, context),\n evalArg1(scope, args, context))\n }\n } else {\n return function evalOperatorNode (scope, args, context) {\n return fn.apply(null, map(evalArgs, function (evalArg) {\n return evalArg(scope, args, context)\n }))\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n for (let i = 0; i < this.args.length; i++) {\n callback(this.args[i], 'args[' + i + ']', this)\n }\n }\n\n /**\n * Create a new OperatorNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {OperatorNode} Returns a transformed copy of the node\n */\n map (callback) {\n const args = []\n for (let i = 0; i < this.args.length; i++) {\n args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this))\n }\n return new OperatorNode(\n this.op, this.fn, args, this.implicit, this.isPercentage)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {OperatorNode}\n */\n clone () {\n return new OperatorNode(\n this.op, this.fn, this.args.slice(0), this.implicit, this.isPercentage)\n }\n\n /**\n * Check whether this is an unary OperatorNode:\n * has exactly one argument, like `-a`.\n * @return {boolean}\n * Returns true when an unary operator node, false otherwise.\n */\n isUnary () {\n return this.args.length === 1\n }\n\n /**\n * Check whether this is a binary OperatorNode:\n * has exactly two arguments, like `a + b`.\n * @return {boolean}\n * Returns true when a binary operator node, false otherwise.\n */\n isBinary () {\n return this.args.length === 2\n }\n\n /**\n * Get string representation.\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const implicit = (options && options.implicit) ? options.implicit : 'hide'\n const args = this.args\n const parens =\n calculateNecessaryParentheses(this, parenthesis, implicit, args, false)\n\n if (args.length === 1) { // unary operators\n const assoc = getAssociativity(this, parenthesis)\n\n let operand = args[0].toString(options)\n if (parens[0]) {\n operand = '(' + operand + ')'\n }\n\n // for example for \"not\", we want a space between operand and argument\n const opIsNamed = /[a-zA-Z]+/.test(this.op)\n\n if (assoc === 'right') { // prefix operator\n return this.op + (opIsNamed ? ' ' : '') + operand\n } else if (assoc === 'left') { // postfix\n return operand + (opIsNamed ? ' ' : '') + this.op\n }\n\n // fall back to postfix\n return operand + this.op\n } else if (args.length === 2) {\n let lhs = args[0].toString(options) // left hand side\n let rhs = args[1].toString(options) // right hand side\n if (parens[0]) { // left hand side in parenthesis?\n lhs = '(' + lhs + ')'\n }\n if (parens[1]) { // right hand side in parenthesis?\n rhs = '(' + rhs + ')'\n }\n\n if (this.implicit &&\n (this.getIdentifier() === 'OperatorNode:multiply') &&\n (implicit === 'hide')) {\n return lhs + ' ' + rhs\n }\n\n return lhs + ' ' + this.op + ' ' + rhs\n } else if ((args.length > 2) &&\n ((this.getIdentifier() === 'OperatorNode:add') ||\n (this.getIdentifier() === 'OperatorNode:multiply'))) {\n const stringifiedArgs = args.map(function (arg, index) {\n arg = arg.toString(options)\n if (parens[index]) { // put in parenthesis?\n arg = '(' + arg + ')'\n }\n\n return arg\n })\n\n if (this.implicit &&\n (this.getIdentifier() === 'OperatorNode:multiply') &&\n (implicit === 'hide')) {\n return stringifiedArgs.join(' ')\n }\n\n return stringifiedArgs.join(' ' + this.op + ' ')\n } else {\n // fallback to formatting as a function call\n return this.fn + '(' + this.args.join(', ') + ')'\n }\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n op: this.op,\n fn: this.fn,\n args: this.args,\n implicit: this.implicit,\n isPercentage: this.isPercentage\n }\n }\n\n /**\n * Instantiate an OperatorNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * ```\n * {\"mathjs\": \"OperatorNode\",\n * \"op\": \"+\", \"fn\": \"add\", \"args\": [...],\n * \"implicit\": false,\n * \"isPercentage\":false}\n * ```\n * where mathjs is optional\n * @returns {OperatorNode}\n */\n static fromJSON (json) {\n return new OperatorNode(\n json.op, json.fn, json.args, json.implicit, json.isPercentage)\n }\n\n /**\n * Get HTML representation.\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const implicit = (options && options.implicit) ? options.implicit : 'hide'\n const args = this.args\n const parens =\n calculateNecessaryParentheses(this, parenthesis, implicit, args, false)\n\n if (args.length === 1) { // unary operators\n const assoc = getAssociativity(this, parenthesis)\n\n let operand = args[0].toHTML(options)\n if (parens[0]) {\n operand =\n '(' +\n operand +\n ')'\n }\n\n if (assoc === 'right') { // prefix operator\n return '' + escape(this.op) + '' +\n operand\n } else { // postfix when assoc === 'left' or undefined\n return operand +\n '' + escape(this.op) + ''\n }\n } else if (args.length === 2) { // binary operatoes\n let lhs = args[0].toHTML(options) // left hand side\n let rhs = args[1].toHTML(options) // right hand side\n if (parens[0]) { // left hand side in parenthesis?\n lhs = '(' +\n lhs +\n ')'\n }\n if (parens[1]) { // right hand side in parenthesis?\n rhs = '(' +\n rhs +\n ')'\n }\n\n if (this.implicit &&\n (this.getIdentifier() === 'OperatorNode:multiply') &&\n (implicit === 'hide')) {\n return lhs +\n '' + rhs\n }\n\n return lhs +\n '' + escape(this.op) + '' +\n rhs\n } else {\n const stringifiedArgs = args.map(function (arg, index) {\n arg = arg.toHTML(options)\n if (parens[index]) { // put in parenthesis?\n arg =\n '(' +\n arg +\n ')'\n }\n\n return arg\n })\n\n if ((args.length > 2) &&\n ((this.getIdentifier() === 'OperatorNode:add') ||\n (this.getIdentifier() === 'OperatorNode:multiply'))) {\n if (this.implicit &&\n (this.getIdentifier() === 'OperatorNode:multiply') &&\n (implicit === 'hide')) {\n return stringifiedArgs.join(\n '')\n }\n\n return stringifiedArgs.join(\n '' + escape(this.op) + '')\n } else {\n // fallback to formatting as a function call\n return '' + escape(this.fn) +\n '' +\n '(' +\n stringifiedArgs.join(',') +\n ')'\n }\n }\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const implicit = (options && options.implicit) ? options.implicit : 'hide'\n const args = this.args\n const parens =\n calculateNecessaryParentheses(this, parenthesis, implicit, args, true)\n\n let op = latexOperators[this.fn]\n op = typeof op === 'undefined' ? this.op : op // fall back to using this.op\n\n if (args.length === 1) { // unary operators\n const assoc = getAssociativity(this, parenthesis)\n\n let operand = args[0].toTex(options)\n if (parens[0]) {\n operand = `\\\\left(${operand}\\\\right)`\n }\n\n if (assoc === 'right') { // prefix operator\n return op + operand\n } else if (assoc === 'left') { // postfix operator\n return operand + op\n }\n\n // fall back to postfix\n return operand + op\n } else if (args.length === 2) { // binary operators\n const lhs = args[0] // left hand side\n let lhsTex = lhs.toTex(options)\n if (parens[0]) {\n lhsTex = `\\\\left(${lhsTex}\\\\right)`\n }\n\n const rhs = args[1] // right hand side\n let rhsTex = rhs.toTex(options)\n if (parens[1]) {\n rhsTex = `\\\\left(${rhsTex}\\\\right)`\n }\n\n // handle some exceptions (due to the way LaTeX works)\n let lhsIdentifier\n if (parenthesis === 'keep') {\n lhsIdentifier = lhs.getIdentifier()\n } else {\n // Ignore ParenthesisNodes if in 'keep' mode\n lhsIdentifier = lhs.getContent().getIdentifier()\n }\n switch (this.getIdentifier()) {\n case 'OperatorNode:divide':\n // op contains '\\\\frac' at this point\n return op + '{' + lhsTex + '}' + '{' + rhsTex + '}'\n case 'OperatorNode:pow':\n lhsTex = '{' + lhsTex + '}'\n rhsTex = '{' + rhsTex + '}'\n switch (lhsIdentifier) {\n case 'ConditionalNode': //\n case 'OperatorNode:divide':\n lhsTex = `\\\\left(${lhsTex}\\\\right)`\n }\n break\n case 'OperatorNode:multiply':\n if (this.implicit && (implicit === 'hide')) {\n return lhsTex + '~' + rhsTex\n }\n }\n return lhsTex + op + rhsTex\n } else if ((args.length > 2) &&\n ((this.getIdentifier() === 'OperatorNode:add') ||\n (this.getIdentifier() === 'OperatorNode:multiply'))) {\n const texifiedArgs = args.map(function (arg, index) {\n arg = arg.toTex(options)\n if (parens[index]) {\n arg = `\\\\left(${arg}\\\\right)`\n }\n return arg\n })\n\n if ((this.getIdentifier() === 'OperatorNode:multiply') &&\n this.implicit && implicit === 'hide') {\n return texifiedArgs.join('~')\n }\n\n return texifiedArgs.join(op)\n } else {\n // fall back to formatting as a function call\n // as this is a fallback, it doesn't use\n // fancy function names\n return '\\\\mathrm{' + this.fn + '}\\\\left(' +\n args.map(function (arg) {\n return arg.toTex(options)\n }).join(',') + '\\\\right)'\n }\n }\n\n /**\n * Get identifier.\n * @return {string}\n */\n getIdentifier () {\n return this.type + ':' + this.fn\n }\n }\n\n return OperatorNode\n}, { isClass: true, isNode: true })\n","import { isNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ParenthesisNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createParenthesisNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n class ParenthesisNode extends Node {\n /**\n * @constructor ParenthesisNode\n * @extends {Node}\n * A parenthesis node describes manual parenthesis from the user input\n * @param {Node} content\n * @extends {Node}\n */\n constructor (content) {\n super()\n // validate input\n if (!isNode(content)) {\n throw new TypeError('Node expected for parameter \"content\"')\n }\n\n this.content = content\n }\n\n static name = name\n get type () { return name }\n get isParenthesisNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n return this.content._compile(math, argNames)\n }\n\n /**\n * Get the content of the current Node.\n * @return {Node} content\n * @override\n **/\n getContent () {\n return this.content.getContent()\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.content, 'content', this)\n }\n\n /**\n * Create a new ParenthesisNode whose child is the result of calling\n * the provided callback function on the child of this node.\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {ParenthesisNode} Returns a clone of the node\n */\n map (callback) {\n const content = callback(this.content, 'content', this)\n return new ParenthesisNode(content)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {ParenthesisNode}\n */\n clone () {\n return new ParenthesisNode(this.content)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toString (options) {\n if ((!options) ||\n (options && !options.parenthesis) ||\n (options && options.parenthesis === 'keep')) {\n return '(' + this.content.toString(options) + ')'\n }\n return this.content.toString(options)\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return { mathjs: name, content: this.content }\n }\n\n /**\n * Instantiate an ParenthesisNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ParenthesisNode\", \"content\": ...}`,\n * where mathjs is optional\n * @returns {ParenthesisNode}\n */\n static fromJSON (json) {\n return new ParenthesisNode(json.content)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toHTML (options) {\n if ((!options) ||\n (options && !options.parenthesis) ||\n (options && options.parenthesis === 'keep')) {\n return '(' +\n this.content.toHTML(options) +\n ')'\n }\n return this.content.toHTML(options)\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toTex (options) {\n if ((!options) ||\n (options && !options.parenthesis) ||\n (options && options.parenthesis === 'keep')) {\n return `\\\\left(${this.content.toTex(options)}\\\\right)`\n }\n return this.content.toTex(options)\n }\n }\n\n return ParenthesisNode\n}, { isClass: true, isNode: true })\n","import { isNode, isSymbolNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'RangeNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createRangeNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n /**\n * Calculate the necessary parentheses\n * @param {Node} node\n * @param {string} parenthesis\n * @param {string} implicit\n * @return {Object} parentheses\n * @private\n */\n function calculateNecessaryParentheses (node, parenthesis, implicit) {\n const precedence = getPrecedence(node, parenthesis, implicit)\n const parens = {}\n\n const startPrecedence = getPrecedence(node.start, parenthesis, implicit)\n parens.start = ((startPrecedence !== null) && (startPrecedence <= precedence)) ||\n (parenthesis === 'all')\n\n if (node.step) {\n const stepPrecedence = getPrecedence(node.step, parenthesis, implicit)\n parens.step = ((stepPrecedence !== null) && (stepPrecedence <= precedence)) ||\n (parenthesis === 'all')\n }\n\n const endPrecedence = getPrecedence(node.end, parenthesis, implicit)\n parens.end = ((endPrecedence !== null) && (endPrecedence <= precedence)) ||\n (parenthesis === 'all')\n\n return parens\n }\n\n class RangeNode extends Node {\n /**\n * @constructor RangeNode\n * @extends {Node}\n * create a range\n * @param {Node} start included lower-bound\n * @param {Node} end included upper-bound\n * @param {Node} [step] optional step\n */\n constructor (start, end, step) {\n super()\n // validate inputs\n if (!isNode(start)) throw new TypeError('Node expected')\n if (!isNode(end)) throw new TypeError('Node expected')\n if (step && !isNode(step)) throw new TypeError('Node expected')\n if (arguments.length > 3) throw new Error('Too many arguments')\n\n this.start = start // included lower-bound\n this.end = end // included upper-bound\n this.step = step || null // optional step\n }\n\n static name = name\n get type () { return name }\n get isRangeNode () { return true }\n\n /**\n * Check whether the RangeNode needs the `end` symbol to be defined.\n * This end is the size of the Matrix in current dimension.\n * @return {boolean}\n */\n needsEnd () {\n // find all `end` symbols in this RangeNode\n const endSymbols = this.filter(function (node) {\n return isSymbolNode(node) && (node.name === 'end')\n })\n\n return endSymbols.length > 0\n }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const range = math.range\n const evalStart = this.start._compile(math, argNames)\n const evalEnd = this.end._compile(math, argNames)\n\n if (this.step) {\n const evalStep = this.step._compile(math, argNames)\n\n return function evalRangeNode (scope, args, context) {\n return range(\n evalStart(scope, args, context),\n evalEnd(scope, args, context),\n evalStep(scope, args, context)\n )\n }\n } else {\n return function evalRangeNode (scope, args, context) {\n return range(\n evalStart(scope, args, context),\n evalEnd(scope, args, context)\n )\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.start, 'start', this)\n callback(this.end, 'end', this)\n if (this.step) {\n callback(this.step, 'step', this)\n }\n }\n\n /**\n * Create a new RangeNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {RangeNode} Returns a transformed copy of the node\n */\n map (callback) {\n return new RangeNode(\n this._ifNode(callback(this.start, 'start', this)),\n this._ifNode(callback(this.end, 'end', this)),\n this.step && this._ifNode(callback(this.step, 'step', this))\n )\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {RangeNode}\n */\n clone () {\n return new RangeNode(this.start, this.end, this.step && this.step)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const parens =\n calculateNecessaryParentheses(\n this, parenthesis, options && options.implicit)\n\n // format string as start:step:stop\n let str\n\n let start = this.start.toString(options)\n if (parens.start) {\n start = '(' + start + ')'\n }\n str = start\n\n if (this.step) {\n let step = this.step.toString(options)\n if (parens.step) {\n step = '(' + step + ')'\n }\n str += ':' + step\n }\n\n let end = this.end.toString(options)\n if (parens.end) {\n end = '(' + end + ')'\n }\n str += ':' + end\n\n return str\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n start: this.start,\n end: this.end,\n step: this.step\n }\n }\n\n /**\n * Instantiate an RangeNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"RangeNode\", \"start\": ..., \"end\": ..., \"step\": ...}`,\n * where mathjs is optional\n * @returns {RangeNode}\n */\n static fromJSON (json) {\n return new RangeNode(json.start, json.end, json.step)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const parens =\n calculateNecessaryParentheses(\n this, parenthesis, options && options.implicit)\n\n // format string as start:step:stop\n let str\n\n let start = this.start.toHTML(options)\n if (parens.start) {\n start = '(' +\n start +\n ')'\n }\n str = start\n\n if (this.step) {\n let step = this.step.toHTML(options)\n if (parens.step) {\n step = '(' +\n step +\n ')'\n }\n str += ':' + step\n }\n\n let end = this.end.toHTML(options)\n if (parens.end) {\n end = '(' +\n end +\n ')'\n }\n str += ':' + end\n\n return str\n }\n\n /**\n * Get LaTeX representation\n * @params {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const parens =\n calculateNecessaryParentheses(\n this, parenthesis, options && options.implicit)\n\n let str = this.start.toTex(options)\n if (parens.start) {\n str = `\\\\left(${str}\\\\right)`\n }\n\n if (this.step) {\n let step = this.step.toTex(options)\n if (parens.step) {\n step = `\\\\left(${step}\\\\right)`\n }\n str += ':' + step\n }\n\n let end = this.end.toTex(options)\n if (parens.end) {\n end = `\\\\left(${end}\\\\right)`\n }\n str += ':' + end\n\n return str\n }\n }\n\n return RangeNode\n}, { isClass: true, isNode: true })\n","import { getPrecedence } from '../operators.js'\nimport { escape } from '../../utils/string.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { latexOperators } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'RelationalNode'\nconst dependencies = [\n 'Node'\n]\n\nexport const createRelationalNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n const operatorMap = {\n equal: '==',\n unequal: '!=',\n smaller: '<',\n larger: '>',\n smallerEq: '<=',\n largerEq: '>='\n }\n\n class RelationalNode extends Node {\n /**\n * A node representing a chained conditional expression, such as 'x > y > z'\n *\n * @param {String[]} conditionals\n * An array of conditional operators used to compare the parameters\n * @param {Node[]} params\n * The parameters that will be compared\n *\n * @constructor RelationalNode\n * @extends {Node}\n */\n constructor (conditionals, params) {\n super()\n if (!Array.isArray(conditionals)) { throw new TypeError('Parameter conditionals must be an array') }\n if (!Array.isArray(params)) { throw new TypeError('Parameter params must be an array') }\n if (conditionals.length !== params.length - 1) {\n throw new TypeError(\n 'Parameter params must contain exactly one more element ' +\n 'than parameter conditionals')\n }\n\n this.conditionals = conditionals\n this.params = params\n }\n\n static name = name\n get type () { return name }\n get isRelationalNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const self = this\n\n const compiled = this.params.map(p => p._compile(math, argNames))\n\n return function evalRelationalNode (scope, args, context) {\n let evalLhs\n let evalRhs = compiled[0](scope, args, context)\n\n for (let i = 0; i < self.conditionals.length; i++) {\n evalLhs = evalRhs\n evalRhs = compiled[i + 1](scope, args, context)\n const condFn = getSafeProperty(math, self.conditionals[i])\n if (!condFn(evalLhs, evalRhs)) {\n return false\n }\n }\n return true\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n this.params.forEach((n, i) => callback(n, 'params[' + i + ']', this), this)\n }\n\n /**\n * Create a new RelationalNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {RelationalNode} Returns a transformed copy of the node\n */\n map (callback) {\n return new RelationalNode(\n this.conditionals.slice(),\n this.params.map(\n (n, i) => this._ifNode(callback(n, 'params[' + i + ']', this)), this))\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {RelationalNode}\n */\n clone () {\n return new RelationalNode(this.conditionals, this.params)\n }\n\n /**\n * Get string representation.\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const precedence =\n getPrecedence(this, parenthesis, options && options.implicit)\n\n const paramStrings = this.params.map(function (p, index) {\n const paramPrecedence =\n getPrecedence(p, parenthesis, options && options.implicit)\n return (parenthesis === 'all' ||\n (paramPrecedence !== null && paramPrecedence <= precedence))\n ? '(' + p.toString(options) + ')'\n : p.toString(options)\n })\n\n let ret = paramStrings[0]\n for (let i = 0; i < this.conditionals.length; i++) {\n ret += ' ' + operatorMap[this.conditionals[i]]\n ret += ' ' + paramStrings[i + 1]\n }\n\n return ret\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n conditionals: this.conditionals,\n params: this.params\n }\n }\n\n /**\n * Instantiate a RelationalNode from its JSON representation\n * @param {Object} json\n * An object structured like\n * `{\"mathjs\": \"RelationalNode\", \"conditionals\": ..., \"params\": ...}`,\n * where mathjs is optional\n * @returns {RelationalNode}\n */\n static fromJSON (json) {\n return new RelationalNode(json.conditionals, json.params)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const precedence =\n getPrecedence(this, parenthesis, options && options.implicit)\n\n const paramStrings = this.params.map(function (p, index) {\n const paramPrecedence =\n getPrecedence(p, parenthesis, options && options.implicit)\n return (parenthesis === 'all' ||\n (paramPrecedence !== null && paramPrecedence <= precedence))\n ? ('(' +\n p.toHTML(options) +\n ')')\n : p.toHTML(options)\n })\n\n let ret = paramStrings[0]\n for (let i = 0; i < this.conditionals.length; i++) {\n ret += '' +\n escape(operatorMap[this.conditionals[i]]) + '' +\n paramStrings[i + 1]\n }\n\n return ret\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const parenthesis =\n (options && options.parenthesis) ? options.parenthesis : 'keep'\n const precedence =\n getPrecedence(this, parenthesis, options && options.implicit)\n\n const paramStrings = this.params.map(function (p, index) {\n const paramPrecedence =\n getPrecedence(p, parenthesis, options && options.implicit)\n return (parenthesis === 'all' ||\n (paramPrecedence !== null && paramPrecedence <= precedence))\n ? '\\\\left(' + p.toTex(options) + '\\right)'\n : p.toTex(options)\n })\n\n let ret = paramStrings[0]\n for (let i = 0; i < this.conditionals.length; i++) {\n ret += latexOperators[this.conditionals[i]] + paramStrings[i + 1]\n }\n\n return ret\n }\n }\n\n return RelationalNode\n}, { isClass: true, isNode: true })\n","import { escape } from '../../utils/string.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { toSymbol } from '../../utils/latex.js'\n\nconst name = 'SymbolNode'\nconst dependencies = [\n 'math',\n '?Unit',\n 'Node'\n]\n\nexport const createSymbolNode = /* #__PURE__ */ factory(name, dependencies, ({ math, Unit, Node }) => {\n /**\n * Check whether some name is a valueless unit like \"inch\".\n * @param {string} name\n * @return {boolean}\n */\n function isValuelessUnit (name) {\n return Unit ? Unit.isValuelessUnit(name) : false\n }\n\n class SymbolNode extends Node {\n /**\n * @constructor SymbolNode\n * @extends {Node}\n * A symbol node can hold and resolve a symbol\n * @param {string} name\n * @extends {Node}\n */\n constructor (name) {\n super()\n // validate input\n if (typeof name !== 'string') {\n throw new TypeError('String expected for parameter \"name\"')\n }\n\n this.name = name\n }\n\n get type () { return 'SymbolNode' }\n get isSymbolNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n const name = this.name\n\n if (argNames[name] === true) {\n // this is a FunctionAssignment argument\n // (like an x when inside the expression of a function\n // assignment `f(x) = ...`)\n return function (scope, args, context) {\n return getSafeProperty(args, name)\n }\n } else if (name in math) {\n return function (scope, args, context) {\n return scope.has(name)\n ? scope.get(name)\n : getSafeProperty(math, name)\n }\n } else {\n const isUnit = isValuelessUnit(name)\n\n return function (scope, args, context) {\n return scope.has(name)\n ? scope.get(name)\n : isUnit\n ? new Unit(null, name)\n : SymbolNode.onUndefinedSymbol(name)\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n // nothing to do, we don't have any children\n }\n\n /**\n * Create a new SymbolNode with children produced by the given callback.\n * Trivial since a SymbolNode has no children\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {SymbolNode} Returns a clone of the node\n */\n map (callback) {\n return this.clone()\n }\n\n /**\n * Throws an error 'Undefined symbol {name}'\n * @param {string} name\n */\n static onUndefinedSymbol (name) {\n throw new Error('Undefined symbol ' + name)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {SymbolNode}\n */\n clone () {\n return new SymbolNode(this.name)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toString (options) {\n return this.name\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toHTML (options) {\n const name = escape(this.name)\n\n if (name === 'true' || name === 'false') {\n return '' + name + ''\n } else if (name === 'i') {\n return '' +\n name + ''\n } else if (name === 'Infinity') {\n return '' +\n name + ''\n } else if (name === 'NaN') {\n return '' + name + ''\n } else if (name === 'null') {\n return '' + name + ''\n } else if (name === 'undefined') {\n return '' +\n name + ''\n }\n\n return '' + name + ''\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: 'SymbolNode',\n name: this.name\n }\n }\n\n /**\n * Instantiate a SymbolNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SymbolNode\", name: \"x\"}`,\n * where mathjs is optional\n * @returns {SymbolNode}\n */\n static fromJSON (json) {\n return new SymbolNode(json.name)\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n _toTex (options) {\n let isUnit = false\n if ((typeof math[this.name] === 'undefined') &&\n isValuelessUnit(this.name)) {\n isUnit = true\n }\n const symbol = toSymbol(this.name, isUnit)\n if (symbol[0] === '\\\\') {\n // no space needed if the symbol starts with '\\'\n return symbol\n }\n // the space prevents symbols from breaking stuff like '\\cdot'\n // if it's written right before the symbol\n return ' ' + symbol\n }\n }\n\n return SymbolNode\n}, { isClass: true, isNode: true })\n","import { isAccessorNode, isFunctionAssignmentNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'\nimport { escape, format } from '../../utils/string.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { getSafeProperty, getSafeMethod } from '../../utils/customs.js'\nimport { createSubScope } from '../../utils/scope.js'\nimport { factory } from '../../utils/factory.js'\nimport { defaultTemplate, latexFunctions } from '../../utils/latex.js'\n\nconst name = 'FunctionNode'\nconst dependencies = [\n 'math',\n 'Node',\n 'SymbolNode'\n]\n\nexport const createFunctionNode = /* #__PURE__ */ factory(name, dependencies, ({ math, Node, SymbolNode }) => {\n /* format to fixed length */\n const strin = entity => format(entity, { truncate: 78 })\n\n /*\n * Expand a LaTeX template\n *\n * @param {string} template\n * @param {Node} node\n * @param {Object} options\n * @private\n **/\n function expandTemplate (template, node, options) {\n let latex = ''\n\n // Match everything of the form ${identifier} or ${identifier[2]} or $$\n // while submatching identifier and 2 (in the second case)\n const regex = /\\$(?:\\{([a-z_][a-z_0-9]*)(?:\\[([0-9]+)\\])?\\}|\\$)/gi\n\n let inputPos = 0 // position in the input string\n let match\n while ((match = regex.exec(template)) !== null) { // go through all matches\n // add everything in front of the match to the LaTeX string\n latex += template.substring(inputPos, match.index)\n inputPos = match.index\n\n if (match[0] === '$$') { // escaped dollar sign\n latex += '$'\n inputPos++\n } else { // template parameter\n inputPos += match[0].length\n const property = node[match[1]]\n if (!property) {\n throw new ReferenceError('Template: Property ' + match[1] + ' does not exist.')\n }\n if (match[2] === undefined) { // no square brackets\n switch (typeof property) {\n case 'string':\n latex += property\n break\n case 'object':\n if (isNode(property)) {\n latex += property.toTex(options)\n } else if (Array.isArray(property)) {\n // make array of Nodes into comma separated list\n latex += property.map(function (arg, index) {\n if (isNode(arg)) {\n return arg.toTex(options)\n }\n throw new TypeError('Template: ' + match[1] + '[' + index + '] is not a Node.')\n }).join(',')\n } else {\n throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes')\n }\n break\n default:\n throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes')\n }\n } else { // with square brackets\n if (isNode(property[match[2]] && property[match[2]])) {\n latex += property[match[2]].toTex(options)\n } else {\n throw new TypeError('Template: ' + match[1] + '[' + match[2] + '] is not a Node.')\n }\n }\n }\n }\n latex += template.slice(inputPos) // append rest of the template\n\n return latex\n }\n\n class FunctionNode extends Node {\n /**\n * @constructor FunctionNode\n * @extends {./Node}\n * invoke a list with arguments on a node\n * @param {./Node | string} fn\n * Item resolving to a function on which to invoke\n * the arguments, typically a SymbolNode or AccessorNode\n * @param {./Node[]} args\n */\n constructor (fn, args) {\n super()\n if (typeof fn === 'string') {\n fn = new SymbolNode(fn)\n }\n\n // validate input\n if (!isNode(fn)) throw new TypeError('Node expected as parameter \"fn\"')\n if (!Array.isArray(args) || !args.every(isNode)) {\n throw new TypeError(\n 'Array containing Nodes expected for parameter \"args\"')\n }\n\n this.fn = fn\n this.args = args || []\n }\n\n // readonly property name\n get name () {\n return this.fn.name || ''\n }\n\n static name = name\n get type () { return name }\n get isFunctionNode () { return true }\n\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n _compile (math, argNames) {\n // compile arguments\n const evalArgs = this.args.map((arg) => arg._compile(math, argNames))\n\n if (isSymbolNode(this.fn)) {\n const name = this.fn.name\n if (!argNames[name]) {\n // we can statically determine whether the function\n // has the rawArgs property\n const fn = name in math ? getSafeProperty(math, name) : undefined\n const isRaw = typeof fn === 'function' && fn.rawArgs === true\n\n const resolveFn = (scope) => {\n let value\n if (scope.has(name)) {\n value = scope.get(name)\n } else if (name in math) {\n value = getSafeProperty(math, name)\n } else {\n return FunctionNode.onUndefinedFunction(name)\n }\n if (typeof value === 'function') {\n return value\n }\n throw new TypeError(\n `'${name}' is not a function; its value is:\\n ${strin(value)}`\n )\n }\n\n if (isRaw) {\n // pass unevaluated parameters (nodes) to the function\n // \"raw\" evaluation\n const rawArgs = this.args\n return function evalFunctionNode (scope, args, context) {\n const fn = resolveFn(scope)\n\n // the original function can be overwritten in the scope with a non-rawArgs function\n if (fn.rawArgs === true) {\n return fn(rawArgs, math, createSubScope(scope, args))\n } else {\n // \"regular\" evaluation\n const values = evalArgs.map((evalArg) => evalArg(scope, args, context))\n return fn(...values)\n }\n }\n } else {\n // \"regular\" evaluation\n switch (evalArgs.length) {\n case 0: return function evalFunctionNode (scope, args, context) {\n const fn = resolveFn(scope)\n return fn()\n }\n case 1: return function evalFunctionNode (scope, args, context) {\n const fn = resolveFn(scope)\n const evalArg0 = evalArgs[0]\n return fn(\n evalArg0(scope, args, context)\n )\n }\n case 2: return function evalFunctionNode (scope, args, context) {\n const fn = resolveFn(scope)\n const evalArg0 = evalArgs[0]\n const evalArg1 = evalArgs[1]\n return fn(\n evalArg0(scope, args, context),\n evalArg1(scope, args, context)\n )\n }\n default: return function evalFunctionNode (scope, args, context) {\n const fn = resolveFn(scope)\n const values = evalArgs.map((evalArg) => evalArg(scope, args, context))\n return fn(...values)\n }\n }\n }\n } else { // the function symbol is an argName\n const rawArgs = this.args\n return function evalFunctionNode (scope, args, context) {\n const fn = getSafeProperty(args, name)\n if (typeof fn !== 'function') {\n throw new TypeError(\n `Argument '${name}' was not a function; received: ${strin(fn)}`\n )\n }\n if (fn.rawArgs) {\n // \"Raw\" evaluation\n return fn(rawArgs, math, createSubScope(scope, args))\n } else {\n const values = evalArgs.map(\n (evalArg) => evalArg(scope, args, context))\n return fn.apply(fn, values)\n }\n }\n }\n } else if (\n isAccessorNode(this.fn) &&\n isIndexNode(this.fn.index) &&\n this.fn.index.isObjectProperty()\n ) {\n // execute the function with the right context:\n // the object of the AccessorNode\n\n const evalObject = this.fn.object._compile(math, argNames)\n const prop = this.fn.index.getObjectProperty()\n const rawArgs = this.args\n\n return function evalFunctionNode (scope, args, context) {\n const object = evalObject(scope, args, context)\n const fn = getSafeMethod(object, prop)\n\n if (fn?.rawArgs) {\n // \"Raw\" evaluation\n return fn(rawArgs, math, createSubScope(scope, args))\n } else {\n // \"regular\" evaluation\n const values = evalArgs.map((evalArg) => evalArg(scope, args, context))\n return fn.apply(object, values)\n }\n }\n } else {\n // node.fn.isAccessorNode && !node.fn.index.isObjectProperty()\n // we have to dynamically determine whether the function has the\n // rawArgs property\n const fnExpr = this.fn.toString()\n const evalFn = this.fn._compile(math, argNames)\n const rawArgs = this.args\n\n return function evalFunctionNode (scope, args, context) {\n const fn = evalFn(scope, args, context)\n if (typeof fn !== 'function') {\n throw new TypeError(\n `Expression '${fnExpr}' did not evaluate to a function; value is:` +\n `\\n ${strin(fn)}`\n )\n }\n if (fn.rawArgs) {\n // \"Raw\" evaluation\n return fn(rawArgs, math, createSubScope(scope, args))\n } else {\n // \"regular\" evaluation\n const values = evalArgs.map(\n (evalArg) => evalArg(scope, args, context))\n return fn.apply(fn, values)\n }\n }\n }\n }\n\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n forEach (callback) {\n callback(this.fn, 'fn', this)\n\n for (let i = 0; i < this.args.length; i++) {\n callback(this.args[i], 'args[' + i + ']', this)\n }\n }\n\n /**\n * Create a new FunctionNode whose children are the results of calling\n * the provided callback function for each child of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {FunctionNode} Returns a transformed copy of the node\n */\n map (callback) {\n const fn = this._ifNode(callback(this.fn, 'fn', this))\n const args = []\n for (let i = 0; i < this.args.length; i++) {\n args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this))\n }\n return new FunctionNode(fn, args)\n }\n\n /**\n * Create a clone of this node, a shallow copy\n * @return {FunctionNode}\n */\n clone () {\n return new FunctionNode(this.fn, this.args.slice(0))\n }\n\n /**\n * Throws an error 'Undefined function {name}'\n * @param {string} name\n */\n static onUndefinedFunction = function (name) {\n throw new Error('Undefined function ' + name)\n }\n\n /**\n * Get string representation. (wrapper function)\n * This overrides parts of Node's toString function.\n * If callback is an object containing callbacks, it\n * calls the correct callback for the current node,\n * otherwise it falls back to calling Node's toString\n * function.\n *\n * @param {Object} options\n * @return {string} str\n * @override\n */\n toString (options) {\n let customString\n const name = this.fn.toString(options)\n if (options &&\n (typeof options.handler === 'object') &&\n hasOwnProperty(options.handler, name)) {\n // callback is a map of callback functions\n customString = options.handler[name](this, options)\n }\n\n if (typeof customString !== 'undefined') {\n return customString\n }\n\n // fall back to Node's toString\n return super.toString(options)\n }\n\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n _toString (options) {\n const args = this.args.map(function (arg) {\n return arg.toString(options)\n })\n\n const fn = isFunctionAssignmentNode(this.fn)\n ? ('(' + this.fn.toString(options) + ')')\n : this.fn.toString(options)\n\n // format the arguments like \"add(2, 4.2)\"\n return fn + '(' + args.join(', ') + ')'\n }\n\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n toJSON () {\n return {\n mathjs: name,\n fn: this.fn,\n args: this.args\n }\n }\n\n /**\n * Instantiate an AssignmentNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"FunctionNode\", fn: ..., args: ...}`,\n * where mathjs is optional\n * @returns {FunctionNode}\n */\n static fromJSON = function (json) {\n return new FunctionNode(json.fn, json.args)\n }\n\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n _toHTML (options) {\n const args = this.args.map(function (arg) {\n return arg.toHTML(options)\n })\n\n // format the arguments like \"add(2, 4.2)\"\n return '' + escape(this.fn) +\n '(' +\n args.join(',') +\n ')'\n }\n\n /**\n * Get LaTeX representation. (wrapper function)\n * This overrides parts of Node's toTex function.\n * If callback is an object containing callbacks, it\n * calls the correct callback for the current node,\n * otherwise it falls back to calling Node's toTex\n * function.\n *\n * @param {Object} options\n * @return {string}\n */\n toTex (options) {\n let customTex\n if (options &&\n (typeof options.handler === 'object') &&\n hasOwnProperty(options.handler, this.name)) {\n // callback is a map of callback functions\n customTex = options.handler[this.name](this, options)\n }\n\n if (typeof customTex !== 'undefined') {\n return customTex\n }\n\n // fall back to Node's toTex\n return super.toTex(options)\n }\n\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n _toTex (options) {\n const args = this.args.map(function (arg) { // get LaTeX of the arguments\n return arg.toTex(options)\n })\n\n let latexConverter\n\n if (latexFunctions[this.name]) {\n latexConverter = latexFunctions[this.name]\n }\n\n // toTex property on the function itself\n if (math[this.name] &&\n ((typeof math[this.name].toTex === 'function') ||\n (typeof math[this.name].toTex === 'object') ||\n (typeof math[this.name].toTex === 'string'))\n ) {\n // .toTex is a callback function\n latexConverter = math[this.name].toTex\n }\n\n let customToTex\n switch (typeof latexConverter) {\n case 'function': // a callback function\n customToTex = latexConverter(this, options)\n break\n case 'string': // a template string\n customToTex = expandTemplate(latexConverter, this, options)\n break\n case 'object':\n // an object with different \"converters\" for different\n // numbers of arguments\n switch (typeof latexConverter[args.length]) {\n case 'function':\n customToTex = latexConverter[args.length](this, options)\n break\n case 'string':\n customToTex =\n expandTemplate(latexConverter[args.length], this, options)\n break\n }\n }\n\n if (typeof customToTex !== 'undefined') {\n return customToTex\n }\n\n return expandTemplate(defaultTemplate, this, options)\n }\n\n /**\n * Get identifier.\n * @return {string}\n */\n getIdentifier () {\n return this.type + ':' + this.name\n }\n }\n\n return FunctionNode\n}, { isClass: true, isNode: true })\n","import { factory } from '../utils/factory.js'\nimport { isAccessorNode, isConstantNode, isFunctionNode, isOperatorNode, isSymbolNode, rule2Node } from '../utils/is.js'\nimport { deepMap } from '../utils/collection.js'\nimport { safeNumberType } from '../utils/number.js'\nimport { hasOwnProperty } from '../utils/object.js'\n\nconst name = 'parse'\nconst dependencies = [\n 'typed',\n 'numeric',\n 'config',\n 'AccessorNode',\n 'ArrayNode',\n 'AssignmentNode',\n 'BlockNode',\n 'ConditionalNode',\n 'ConstantNode',\n 'FunctionAssignmentNode',\n 'FunctionNode',\n 'IndexNode',\n 'ObjectNode',\n 'OperatorNode',\n 'ParenthesisNode',\n 'RangeNode',\n 'RelationalNode',\n 'SymbolNode'\n]\n\nexport const createParse = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n numeric,\n config,\n AccessorNode,\n ArrayNode,\n AssignmentNode,\n BlockNode,\n ConditionalNode,\n ConstantNode,\n FunctionAssignmentNode,\n FunctionNode,\n IndexNode,\n ObjectNode,\n OperatorNode,\n ParenthesisNode,\n RangeNode,\n RelationalNode,\n SymbolNode\n}) => {\n /**\n * Parse an expression. Returns a node tree, which can be evaluated by\n * invoking node.evaluate().\n *\n * Note the evaluating arbitrary expressions may involve security risks,\n * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information.\n *\n * Syntax:\n *\n * math.parse(expr)\n * math.parse(expr, options)\n * math.parse([expr1, expr2, expr3, ...])\n * math.parse([expr1, expr2, expr3, ...], options)\n *\n * Example:\n *\n * const node1 = math.parse('sqrt(3^2 + 4^2)')\n * node1.compile().evaluate() // 5\n *\n * let scope = {a:3, b:4}\n * const node2 = math.parse('a * b') // 12\n * const code2 = node2.compile()\n * code2.evaluate(scope) // 12\n * scope.a = 5\n * code2.evaluate(scope) // 20\n *\n * const nodes = math.parse(['a = 3', 'b = 4', 'a * b'])\n * nodes[2].compile().evaluate() // 12\n *\n * See also:\n *\n * evaluate, compile\n *\n * @param {string | string[] | Matrix} expr Expression to be parsed\n * @param {{nodes: Object}} [options] Available options:\n * - `nodes` a set of custom nodes\n * @return {Node | Node[]} node\n * @throws {Error}\n */\n const parse = typed(name, {\n string: function (expression) {\n return parseStart(expression, {})\n },\n 'Array | Matrix': function (expressions) {\n return parseMultiple(expressions, {})\n },\n 'string, Object': function (expression, options) {\n const extraNodes = options.nodes !== undefined ? options.nodes : {}\n\n return parseStart(expression, extraNodes)\n },\n 'Array | Matrix, Object': parseMultiple\n })\n\n function parseMultiple (expressions, options = {}) {\n const extraNodes = options.nodes !== undefined ? options.nodes : {}\n\n // parse an array or matrix with expressions\n return deepMap(expressions, function (elem) {\n if (typeof elem !== 'string') throw new TypeError('String expected')\n\n return parseStart(elem, extraNodes)\n })\n }\n\n // token types enumeration\n const TOKENTYPE = {\n NULL: 0,\n DELIMITER: 1,\n NUMBER: 2,\n SYMBOL: 3,\n UNKNOWN: 4\n }\n\n // map with all delimiters\n const DELIMITERS = {\n ',': true,\n '(': true,\n ')': true,\n '[': true,\n ']': true,\n '{': true,\n '}': true,\n '\"': true,\n '\\'': true,\n ';': true,\n\n '+': true,\n '-': true,\n '*': true,\n '.*': true,\n '/': true,\n './': true,\n '%': true,\n '^': true,\n '.^': true,\n '~': true,\n '!': true,\n '&': true,\n '|': true,\n '^|': true,\n '=': true,\n ':': true,\n '?': true,\n\n '==': true,\n '!=': true,\n '<': true,\n '>': true,\n '<=': true,\n '>=': true,\n\n '<<': true,\n '>>': true,\n '>>>': true\n }\n\n // map with all named delimiters\n const NAMED_DELIMITERS = {\n mod: true,\n to: true,\n in: true,\n and: true,\n xor: true,\n or: true,\n not: true\n }\n\n const CONSTANTS = {\n true: true,\n false: false,\n null: null,\n undefined\n }\n\n const NUMERIC_CONSTANTS = [\n 'NaN',\n 'Infinity'\n ]\n\n const ESCAPE_CHARACTERS = {\n '\"': '\"',\n \"'\": \"'\",\n '\\\\': '\\\\',\n '/': '/',\n b: '\\b',\n f: '\\f',\n n: '\\n',\n r: '\\r',\n t: '\\t'\n // note that \\u is handled separately in parseStringToken()\n }\n\n function initialState () {\n return {\n extraNodes: {}, // current extra nodes, must be careful not to mutate\n expression: '', // current expression\n comment: '', // last parsed comment\n index: 0, // current index in expr\n token: '', // current token\n tokenType: TOKENTYPE.NULL, // type of the token\n nestingLevel: 0, // level of nesting inside parameters, used to ignore newline characters\n conditionalLevel: null // when a conditional is being parsed, the level of the conditional is stored here\n }\n }\n\n /**\n * View upto `length` characters of the expression starting at the current character.\n *\n * @param {Object} state\n * @param {number} [length=1] Number of characters to view\n * @returns {string}\n * @private\n */\n function currentString (state, length) {\n return state.expression.substr(state.index, length)\n }\n\n /**\n * View the current character. Returns '' if end of expression is reached.\n *\n * @param {Object} state\n * @returns {string}\n * @private\n */\n function currentCharacter (state) {\n return currentString(state, 1)\n }\n\n /**\n * Get the next character from the expression.\n * The character is stored into the char c. If the end of the expression is\n * reached, the function puts an empty string in c.\n * @private\n */\n function next (state) {\n state.index++\n }\n\n /**\n * Preview the previous character from the expression.\n * @return {string} cNext\n * @private\n */\n function prevCharacter (state) {\n return state.expression.charAt(state.index - 1)\n }\n\n /**\n * Preview the next character from the expression.\n * @return {string} cNext\n * @private\n */\n function nextCharacter (state) {\n return state.expression.charAt(state.index + 1)\n }\n\n /**\n * Get next token in the current string expr.\n * The token and token type are available as token and tokenType\n * @private\n */\n function getToken (state) {\n state.tokenType = TOKENTYPE.NULL\n state.token = ''\n state.comment = ''\n\n // skip over ignored characters:\n while (true) {\n // comments:\n if (currentCharacter(state) === '#') {\n while (currentCharacter(state) !== '\\n' &&\n currentCharacter(state) !== '') {\n state.comment += currentCharacter(state)\n next(state)\n }\n }\n // whitespace: space, tab, and newline when inside parameters\n if (parse.isWhitespace(currentCharacter(state), state.nestingLevel)) {\n next(state)\n } else {\n break\n }\n }\n\n // check for end of expression\n if (currentCharacter(state) === '') {\n // token is still empty\n state.tokenType = TOKENTYPE.DELIMITER\n return\n }\n\n // check for new line character\n if (currentCharacter(state) === '\\n' && !state.nestingLevel) {\n state.tokenType = TOKENTYPE.DELIMITER\n state.token = currentCharacter(state)\n next(state)\n return\n }\n\n const c1 = currentCharacter(state)\n const c2 = currentString(state, 2)\n const c3 = currentString(state, 3)\n if (c3.length === 3 && DELIMITERS[c3]) {\n state.tokenType = TOKENTYPE.DELIMITER\n state.token = c3\n next(state)\n next(state)\n next(state)\n return\n }\n\n // check for delimiters consisting of 2 characters\n if (c2.length === 2 && DELIMITERS[c2]) {\n state.tokenType = TOKENTYPE.DELIMITER\n state.token = c2\n next(state)\n next(state)\n return\n }\n\n // check for delimiters consisting of 1 character\n if (DELIMITERS[c1]) {\n state.tokenType = TOKENTYPE.DELIMITER\n state.token = c1\n next(state)\n return\n }\n\n // check for a number\n if (parse.isDigitDot(c1)) {\n state.tokenType = TOKENTYPE.NUMBER\n\n // check for binary, octal, or hex\n const c2 = currentString(state, 2)\n if (c2 === '0b' || c2 === '0o' || c2 === '0x') {\n state.token += currentCharacter(state)\n next(state)\n state.token += currentCharacter(state)\n next(state)\n while (parse.isHexDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n if (currentCharacter(state) === '.') {\n // this number has a radix point\n state.token += '.'\n next(state)\n // get the digits after the radix\n while (parse.isHexDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n } else if (currentCharacter(state) === 'i') {\n // this number has a word size suffix\n state.token += 'i'\n next(state)\n // get the word size\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n }\n return\n }\n\n // get number, can have a single dot\n if (currentCharacter(state) === '.') {\n state.token += currentCharacter(state)\n next(state)\n\n if (!parse.isDigit(currentCharacter(state))) {\n // this is no number, it is just a dot (can be dot notation)\n state.tokenType = TOKENTYPE.DELIMITER\n return\n }\n } else {\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n }\n\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n // check for exponential notation like \"2.3e-4\", \"1.23e50\" or \"2e+4\"\n if (currentCharacter(state) === 'E' || currentCharacter(state) === 'e') {\n if (parse.isDigit(nextCharacter(state)) || nextCharacter(state) === '-' || nextCharacter(state) === '+') {\n state.token += currentCharacter(state)\n next(state)\n\n if (currentCharacter(state) === '+' || currentCharacter(state) === '-') {\n state.token += currentCharacter(state)\n next(state)\n }\n // Scientific notation MUST be followed by an exponent\n if (!parse.isDigit(currentCharacter(state))) {\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"')\n }\n\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n\n if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) {\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"')\n }\n } else if (nextCharacter(state) === '.') {\n next(state)\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"')\n }\n }\n\n return\n }\n\n // check for variables, functions, named operators\n if (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state))) {\n while (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state)) || parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state)\n next(state)\n }\n\n if (hasOwnProperty(NAMED_DELIMITERS, state.token)) {\n state.tokenType = TOKENTYPE.DELIMITER\n } else {\n state.tokenType = TOKENTYPE.SYMBOL\n }\n\n return\n }\n\n // something unknown is found, wrong characters -> a syntax error\n state.tokenType = TOKENTYPE.UNKNOWN\n while (currentCharacter(state) !== '') {\n state.token += currentCharacter(state)\n next(state)\n }\n throw createSyntaxError(state, 'Syntax error in part \"' + state.token + '\"')\n }\n\n /**\n * Get next token and skip newline tokens\n */\n function getTokenSkipNewline (state) {\n do {\n getToken(state)\n }\n while (state.token === '\\n') // eslint-disable-line no-unmodified-loop-condition\n }\n\n /**\n * Open parameters.\n * New line characters will be ignored until closeParams(state) is called\n */\n function openParams (state) {\n state.nestingLevel++\n }\n\n /**\n * Close parameters.\n * New line characters will no longer be ignored\n */\n function closeParams (state) {\n state.nestingLevel--\n }\n\n /**\n * Checks whether the current character `c` is a valid alpha character:\n *\n * - A latin letter (upper or lower case) Ascii: a-z, A-Z\n * - An underscore Ascii: _\n * - A dollar sign Ascii: $\n * - A latin letter with accents Unicode: \\u00C0 - \\u02AF\n * - A greek letter Unicode: \\u0370 - \\u03FF\n * - A mathematical alphanumeric symbol Unicode: \\u{1D400} - \\u{1D7FF} excluding invalid code points\n *\n * The previous and next characters are needed to determine whether\n * this character is part of a unicode surrogate pair.\n *\n * @param {string} c Current character in the expression\n * @param {string} cPrev Previous character\n * @param {string} cNext Next character\n * @return {boolean}\n */\n parse.isAlpha = function isAlpha (c, cPrev, cNext) {\n return parse.isValidLatinOrGreek(c) ||\n parse.isValidMathSymbol(c, cNext) ||\n parse.isValidMathSymbol(cPrev, c)\n }\n\n /**\n * Test whether a character is a valid latin, greek, or letter-like character\n * @param {string} c\n * @return {boolean}\n */\n parse.isValidLatinOrGreek = function isValidLatinOrGreek (c) {\n return /^[a-zA-Z_$\\u00C0-\\u02AF\\u0370-\\u03FF\\u2100-\\u214F]$/.test(c)\n }\n\n /**\n * Test whether two given 16 bit characters form a surrogate pair of a\n * unicode math symbol.\n *\n * https://unicode-table.com/en/\n * https://www.wikiwand.com/en/Mathematical_operators_and_symbols_in_Unicode\n *\n * Note: In ES6 will be unicode aware:\n * https://stackoverflow.com/questions/280712/javascript-unicode-regexes\n * https://mathiasbynens.be/notes/es6-unicode-regex\n *\n * @param {string} high\n * @param {string} low\n * @return {boolean}\n */\n parse.isValidMathSymbol = function isValidMathSymbol (high, low) {\n return /^[\\uD835]$/.test(high) &&\n /^[\\uDC00-\\uDFFF]$/.test(low) &&\n /^[^\\uDC55\\uDC9D\\uDCA0\\uDCA1\\uDCA3\\uDCA4\\uDCA7\\uDCA8\\uDCAD\\uDCBA\\uDCBC\\uDCC4\\uDD06\\uDD0B\\uDD0C\\uDD15\\uDD1D\\uDD3A\\uDD3F\\uDD45\\uDD47-\\uDD49\\uDD51\\uDEA6\\uDEA7\\uDFCC\\uDFCD]$/.test(low)\n }\n\n /**\n * Check whether given character c is a white space character: space, tab, or enter\n * @param {string} c\n * @param {number} nestingLevel\n * @return {boolean}\n */\n parse.isWhitespace = function isWhitespace (c, nestingLevel) {\n // TODO: also take '\\r' carriage return as newline? Or does that give problems on mac?\n return c === ' ' || c === '\\t' || (c === '\\n' && nestingLevel > 0)\n }\n\n /**\n * Test whether the character c is a decimal mark (dot).\n * This is the case when it's not the start of a delimiter '.*', './', or '.^'\n * @param {string} c\n * @param {string} cNext\n * @return {boolean}\n */\n parse.isDecimalMark = function isDecimalMark (c, cNext) {\n return c === '.' && cNext !== '/' && cNext !== '*' && cNext !== '^'\n }\n\n /**\n * checks if the given char c is a digit or dot\n * @param {string} c a string with one character\n * @return {boolean}\n */\n parse.isDigitDot = function isDigitDot (c) {\n return ((c >= '0' && c <= '9') || c === '.')\n }\n\n /**\n * checks if the given char c is a digit\n * @param {string} c a string with one character\n * @return {boolean}\n */\n parse.isDigit = function isDigit (c) {\n return (c >= '0' && c <= '9')\n }\n\n /**\n * checks if the given char c is a hex digit\n * @param {string} c a string with one character\n * @return {boolean}\n */\n parse.isHexDigit = function isHexDigit (c) {\n return ((c >= '0' && c <= '9') ||\n (c >= 'a' && c <= 'f') ||\n (c >= 'A' && c <= 'F'))\n }\n\n /**\n * Start of the parse levels below, in order of precedence\n * @return {Node} node\n * @private\n */\n function parseStart (expression, extraNodes) {\n const state = initialState()\n Object.assign(state, { expression, extraNodes })\n getToken(state)\n\n const node = parseBlock(state)\n\n // check for garbage at the end of the expression\n // an expression ends with a empty character '' and tokenType DELIMITER\n if (state.token !== '') {\n if (state.tokenType === TOKENTYPE.DELIMITER) {\n // user entered a not existing operator like \"//\"\n\n // TODO: give hints for aliases, for example with \"<>\" give as hint \" did you mean !== ?\"\n throw createError(state, 'Unexpected operator ' + state.token)\n } else {\n throw createSyntaxError(state, 'Unexpected part \"' + state.token + '\"')\n }\n }\n\n return node\n }\n\n /**\n * Parse a block with expressions. Expressions can be separated by a newline\n * character '\\n', or by a semicolon ';'. In case of a semicolon, no output\n * of the preceding line is returned.\n * @return {Node} node\n * @private\n */\n function parseBlock (state) {\n let node\n const blocks = []\n let visible\n\n if (state.token !== '' && state.token !== '\\n' && state.token !== ';') {\n node = parseAssignment(state)\n if (state.comment) {\n node.comment = state.comment\n }\n }\n\n // TODO: simplify this loop\n while (state.token === '\\n' || state.token === ';') { // eslint-disable-line no-unmodified-loop-condition\n if (blocks.length === 0 && node) {\n visible = (state.token !== ';')\n blocks.push({ node, visible })\n }\n\n getToken(state)\n if (state.token !== '\\n' && state.token !== ';' && state.token !== '') {\n node = parseAssignment(state)\n if (state.comment) {\n node.comment = state.comment\n }\n\n visible = (state.token !== ';')\n blocks.push({ node, visible })\n }\n }\n\n if (blocks.length > 0) {\n return new BlockNode(blocks)\n } else {\n if (!node) {\n node = new ConstantNode(undefined)\n if (state.comment) {\n node.comment = state.comment\n }\n }\n\n return node\n }\n }\n\n /**\n * Assignment of a function or variable,\n * - can be a variable like 'a=2.3'\n * - or a updating an existing variable like 'matrix(2,3:5)=[6,7,8]'\n * - defining a function like 'f(x) = x^2'\n * @return {Node} node\n * @private\n */\n function parseAssignment (state) {\n let name, args, value, valid\n\n const node = parseConditional(state)\n\n if (state.token === '=') {\n if (isSymbolNode(node)) {\n // parse a variable assignment like 'a = 2/3'\n name = node.name\n getTokenSkipNewline(state)\n value = parseAssignment(state)\n return new AssignmentNode(new SymbolNode(name), value)\n } else if (isAccessorNode(node)) {\n // parse a matrix subset assignment like 'A[1,2] = 4'\n getTokenSkipNewline(state)\n value = parseAssignment(state)\n return new AssignmentNode(node.object, node.index, value)\n } else if (isFunctionNode(node) && isSymbolNode(node.fn)) {\n // parse function assignment like 'f(x) = x^2'\n valid = true\n args = []\n\n name = node.name\n node.args.forEach(function (arg, index) {\n if (isSymbolNode(arg)) {\n args[index] = arg.name\n } else {\n valid = false\n }\n })\n\n if (valid) {\n getTokenSkipNewline(state)\n value = parseAssignment(state)\n return new FunctionAssignmentNode(name, args, value)\n }\n }\n\n throw createSyntaxError(state, 'Invalid left hand side of assignment operator =')\n }\n\n return node\n }\n\n /**\n * conditional operation\n *\n * condition ? truePart : falsePart\n *\n * Note: conditional operator is right-associative\n *\n * @return {Node} node\n * @private\n */\n function parseConditional (state) {\n let node = parseLogicalOr(state)\n\n while (state.token === '?') { // eslint-disable-line no-unmodified-loop-condition\n // set a conditional level, the range operator will be ignored as long\n // as conditionalLevel === state.nestingLevel.\n const prev = state.conditionalLevel\n state.conditionalLevel = state.nestingLevel\n getTokenSkipNewline(state)\n\n const condition = node\n const trueExpr = parseAssignment(state)\n\n if (state.token !== ':') throw createSyntaxError(state, 'False part of conditional expression expected')\n\n state.conditionalLevel = null\n getTokenSkipNewline(state)\n\n const falseExpr = parseAssignment(state) // Note: check for conditional operator again, right associativity\n\n node = new ConditionalNode(condition, trueExpr, falseExpr)\n\n // restore the previous conditional level\n state.conditionalLevel = prev\n }\n\n return node\n }\n\n /**\n * logical or, 'x or y'\n * @return {Node} node\n * @private\n */\n function parseLogicalOr (state) {\n let node = parseLogicalXor(state)\n\n while (state.token === 'or') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('or', 'or', [node, parseLogicalXor(state)])\n }\n\n return node\n }\n\n /**\n * logical exclusive or, 'x xor y'\n * @return {Node} node\n * @private\n */\n function parseLogicalXor (state) {\n let node = parseLogicalAnd(state)\n\n while (state.token === 'xor') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('xor', 'xor', [node, parseLogicalAnd(state)])\n }\n\n return node\n }\n\n /**\n * logical and, 'x and y'\n * @return {Node} node\n * @private\n */\n function parseLogicalAnd (state) {\n let node = parseBitwiseOr(state)\n\n while (state.token === 'and') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('and', 'and', [node, parseBitwiseOr(state)])\n }\n\n return node\n }\n\n /**\n * bitwise or, 'x | y'\n * @return {Node} node\n * @private\n */\n function parseBitwiseOr (state) {\n let node = parseBitwiseXor(state)\n\n while (state.token === '|') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('|', 'bitOr', [node, parseBitwiseXor(state)])\n }\n\n return node\n }\n\n /**\n * bitwise exclusive or (xor), 'x ^| y'\n * @return {Node} node\n * @private\n */\n function parseBitwiseXor (state) {\n let node = parseBitwiseAnd(state)\n\n while (state.token === '^|') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('^|', 'bitXor', [node, parseBitwiseAnd(state)])\n }\n\n return node\n }\n\n /**\n * bitwise and, 'x & y'\n * @return {Node} node\n * @private\n */\n function parseBitwiseAnd (state) {\n let node = parseRelational(state)\n\n while (state.token === '&') { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n node = new OperatorNode('&', 'bitAnd', [node, parseRelational(state)])\n }\n\n return node\n }\n\n /**\n * Parse a chained conditional, like 'a > b >= c'\n * @return {Node} node\n */\n function parseRelational (state) {\n const params = [parseShift(state)]\n const conditionals = []\n\n const operators = {\n '==': 'equal',\n '!=': 'unequal',\n '<': 'smaller',\n '>': 'larger',\n '<=': 'smallerEq',\n '>=': 'largerEq'\n }\n\n while (hasOwnProperty(operators, state.token)) { // eslint-disable-line no-unmodified-loop-condition\n const cond = { name: state.token, fn: operators[state.token] }\n conditionals.push(cond)\n getTokenSkipNewline(state)\n params.push(parseShift(state))\n }\n\n if (params.length === 1) {\n return params[0]\n } else if (params.length === 2) {\n return new OperatorNode(conditionals[0].name, conditionals[0].fn, params)\n } else {\n return new RelationalNode(conditionals.map(c => c.fn), params)\n }\n }\n\n /**\n * Bitwise left shift, bitwise right arithmetic shift, bitwise right logical shift\n * @return {Node} node\n * @private\n */\n function parseShift (state) {\n let node, name, fn, params\n\n node = parseConversion(state)\n\n const operators = {\n '<<': 'leftShift',\n '>>': 'rightArithShift',\n '>>>': 'rightLogShift'\n }\n\n while (hasOwnProperty(operators, state.token)) {\n name = state.token\n fn = operators[name]\n\n getTokenSkipNewline(state)\n params = [node, parseConversion(state)]\n node = new OperatorNode(name, fn, params)\n }\n\n return node\n }\n\n /**\n * conversion operators 'to' and 'in'\n * @return {Node} node\n * @private\n */\n function parseConversion (state) {\n let node, name, fn, params\n\n node = parseRange(state)\n\n const operators = {\n to: 'to',\n in: 'to' // alias of 'to'\n }\n\n while (hasOwnProperty(operators, state.token)) {\n name = state.token\n fn = operators[name]\n\n getTokenSkipNewline(state)\n\n if (name === 'in' && state.token === '') {\n // end of expression -> this is the unit 'in' ('inch')\n node = new OperatorNode('*', 'multiply', [node, new SymbolNode('in')], true)\n } else {\n // operator 'a to b' or 'a in b'\n params = [node, parseRange(state)]\n node = new OperatorNode(name, fn, params)\n }\n }\n\n return node\n }\n\n /**\n * parse range, \"start:end\", \"start:step:end\", \":\", \"start:\", \":end\", etc\n * @return {Node} node\n * @private\n */\n function parseRange (state) {\n let node\n const params = []\n\n if (state.token === ':') {\n // implicit start=1 (one-based)\n node = new ConstantNode(1)\n } else {\n // explicit start\n node = parseAddSubtract(state)\n }\n\n if (state.token === ':' && (state.conditionalLevel !== state.nestingLevel)) {\n // we ignore the range operator when a conditional operator is being processed on the same level\n params.push(node)\n\n // parse step and end\n while (state.token === ':' && params.length < 3) { // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state)\n\n if (state.token === ')' || state.token === ']' || state.token === ',' || state.token === '') {\n // implicit end\n params.push(new SymbolNode('end'))\n } else {\n // explicit end\n params.push(parseAddSubtract(state))\n }\n }\n\n if (params.length === 3) {\n // params = [start, step, end]\n node = new RangeNode(params[0], params[2], params[1]) // start, end, step\n } else { // length === 2\n // params = [start, end]\n node = new RangeNode(params[0], params[1]) // start, end\n }\n }\n\n return node\n }\n\n /**\n * add or subtract\n * @return {Node} node\n * @private\n */\n function parseAddSubtract (state) {\n let node, name, fn, params\n\n node = parseMultiplyDivide(state)\n\n const operators = {\n '+': 'add',\n '-': 'subtract'\n }\n while (hasOwnProperty(operators, state.token)) {\n name = state.token\n fn = operators[name]\n\n getTokenSkipNewline(state)\n const rightNode = parseMultiplyDivide(state)\n if (rightNode.isPercentage) {\n params = [node, new OperatorNode('*', 'multiply', [node, rightNode])]\n } else {\n params = [node, rightNode]\n }\n node = new OperatorNode(name, fn, params)\n }\n\n return node\n }\n\n /**\n * multiply, divide\n * @return {Node} node\n * @private\n */\n function parseMultiplyDivide (state) {\n let node, last, name, fn\n\n node = parseImplicitMultiplication(state)\n last = node\n\n const operators = {\n '*': 'multiply',\n '.*': 'dotMultiply',\n '/': 'divide',\n './': 'dotDivide'\n }\n\n while (true) {\n if (hasOwnProperty(operators, state.token)) {\n // explicit operators\n name = state.token\n fn = operators[name]\n\n getTokenSkipNewline(state)\n\n last = parseImplicitMultiplication(state)\n node = new OperatorNode(name, fn, [node, last])\n } else {\n break\n }\n }\n\n return node\n }\n\n /**\n * implicit multiplication\n * @return {Node} node\n * @private\n */\n function parseImplicitMultiplication (state) {\n let node, last\n\n node = parseRule2(state)\n last = node\n\n while (true) {\n if ((state.tokenType === TOKENTYPE.SYMBOL) ||\n (state.token === 'in' && isConstantNode(node)) ||\n (state.token === 'in' && isOperatorNode(node) && node.fn === 'unaryMinus' && isConstantNode(node.args[0])) ||\n (state.tokenType === TOKENTYPE.NUMBER &&\n !isConstantNode(last) &&\n (!isOperatorNode(last) || last.op === '!')) ||\n (state.token === '(')) {\n // parse implicit multiplication\n //\n // symbol: implicit multiplication like '2a', '(2+3)a', 'a b'\n // number: implicit multiplication like '(2+3)2'\n // parenthesis: implicit multiplication like '2(3+4)', '(3+4)(1+2)'\n last = parseRule2(state)\n node = new OperatorNode('*', 'multiply', [node, last], true /* implicit */)\n } else {\n break\n }\n }\n\n return node\n }\n\n /**\n * Infamous \"rule 2\" as described in https://github.com/josdejong/mathjs/issues/792#issuecomment-361065370\n * And as amended in https://github.com/josdejong/mathjs/issues/2370#issuecomment-1054052164\n * Explicit division gets higher precedence than implicit multiplication\n * when the division matches this pattern:\n * [unaryPrefixOp]?[number] / [number] [symbol]\n * @return {Node} node\n * @private\n */\n function parseRule2 (state) {\n let node = parseModulusPercentage(state)\n let last = node\n const tokenStates = []\n\n while (true) {\n // Match the \"number /\" part of the pattern \"number / number symbol\"\n if (state.token === '/' && rule2Node(last)) {\n // Look ahead to see if the next token is a number\n tokenStates.push(Object.assign({}, state))\n getTokenSkipNewline(state)\n\n // Match the \"number / number\" part of the pattern\n if (state.tokenType === TOKENTYPE.NUMBER) {\n // Look ahead again\n tokenStates.push(Object.assign({}, state))\n getTokenSkipNewline(state)\n\n // Match the \"symbol\" part of the pattern, or a left parenthesis\n if (state.tokenType === TOKENTYPE.SYMBOL || state.token === '(') {\n // We've matched the pattern \"number / number symbol\".\n // Rewind once and build the \"number / number\" node; the symbol will be consumed later\n Object.assign(state, tokenStates.pop())\n tokenStates.pop()\n last = parseModulusPercentage(state)\n node = new OperatorNode('/', 'divide', [node, last])\n } else {\n // Not a match, so rewind\n tokenStates.pop()\n Object.assign(state, tokenStates.pop())\n break\n }\n } else {\n // Not a match, so rewind\n Object.assign(state, tokenStates.pop())\n break\n }\n } else {\n break\n }\n }\n\n return node\n }\n\n /**\n * modulus and percentage\n * @return {Node} node\n * @private\n */\n function parseModulusPercentage (state) {\n let node, name, fn, params\n\n node = parseUnary(state)\n\n const operators = {\n '%': 'mod',\n mod: 'mod'\n }\n\n while (hasOwnProperty(operators, state.token)) {\n name = state.token\n fn = operators[name]\n\n getTokenSkipNewline(state)\n\n if (name === '%' && state.tokenType === TOKENTYPE.DELIMITER && state.token !== '(') {\n // If the expression contains only %, then treat that as /100\n node = new OperatorNode('/', 'divide', [node, new ConstantNode(100)], false, true)\n } else {\n params = [node, parseUnary(state)]\n node = new OperatorNode(name, fn, params)\n }\n }\n\n return node\n }\n\n /**\n * Unary plus and minus, and logical and bitwise not\n * @return {Node} node\n * @private\n */\n function parseUnary (state) {\n let name, params, fn\n const operators = {\n '-': 'unaryMinus',\n '+': 'unaryPlus',\n '~': 'bitNot',\n not: 'not'\n }\n\n if (hasOwnProperty(operators, state.token)) {\n fn = operators[state.token]\n name = state.token\n\n getTokenSkipNewline(state)\n params = [parseUnary(state)]\n\n return new OperatorNode(name, fn, params)\n }\n\n return parsePow(state)\n }\n\n /**\n * power\n * Note: power operator is right associative\n * @return {Node} node\n * @private\n */\n function parsePow (state) {\n let node, name, fn, params\n\n node = parseLeftHandOperators(state)\n\n if (state.token === '^' || state.token === '.^') {\n name = state.token\n fn = (name === '^') ? 'pow' : 'dotPow'\n\n getTokenSkipNewline(state)\n params = [node, parseUnary(state)] // Go back to unary, we can have '2^-3'\n node = new OperatorNode(name, fn, params)\n }\n\n return node\n }\n\n /**\n * Left hand operators: factorial x!, ctranspose x'\n * @return {Node} node\n * @private\n */\n function parseLeftHandOperators (state) {\n let node, name, fn, params\n\n node = parseCustomNodes(state)\n\n const operators = {\n '!': 'factorial',\n '\\'': 'ctranspose'\n }\n\n while (hasOwnProperty(operators, state.token)) {\n name = state.token\n fn = operators[name]\n\n getToken(state)\n params = [node]\n\n node = new OperatorNode(name, fn, params)\n node = parseAccessors(state, node)\n }\n\n return node\n }\n\n /**\n * Parse a custom node handler. A node handler can be used to process\n * nodes in a custom way, for example for handling a plot.\n *\n * A handler must be passed as second argument of the parse function.\n * - must extend math.Node\n * - must contain a function _compile(defs: Object) : string\n * - must contain a function find(filter: Object) : Node[]\n * - must contain a function toString() : string\n * - the constructor is called with a single argument containing all parameters\n *\n * For example:\n *\n * nodes = {\n * 'plot': PlotHandler\n * }\n *\n * The constructor of the handler is called as:\n *\n * node = new PlotHandler(params)\n *\n * The handler will be invoked when evaluating an expression like:\n *\n * node = math.parse('plot(sin(x), x)', nodes)\n *\n * @return {Node} node\n * @private\n */\n function parseCustomNodes (state) {\n let params = []\n\n if (state.tokenType === TOKENTYPE.SYMBOL && hasOwnProperty(state.extraNodes, state.token)) {\n const CustomNode = state.extraNodes[state.token]\n\n getToken(state)\n\n // parse parameters\n if (state.token === '(') {\n params = []\n\n openParams(state)\n getToken(state)\n\n if (state.token !== ')') {\n params.push(parseAssignment(state))\n\n // parse a list with parameters\n while (state.token === ',') { // eslint-disable-line no-unmodified-loop-condition\n getToken(state)\n params.push(parseAssignment(state))\n }\n }\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected')\n }\n closeParams(state)\n getToken(state)\n }\n\n // create a new custom node\n // noinspection JSValidateTypes\n return new CustomNode(params)\n }\n\n return parseSymbol(state)\n }\n\n /**\n * parse symbols: functions, variables, constants, units\n * @return {Node} node\n * @private\n */\n function parseSymbol (state) {\n let node, name\n\n if (state.tokenType === TOKENTYPE.SYMBOL ||\n (state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS)) {\n name = state.token\n\n getToken(state)\n\n if (hasOwnProperty(CONSTANTS, name)) { // true, false, null, ...\n node = new ConstantNode(CONSTANTS[name])\n } else if (NUMERIC_CONSTANTS.includes(name)) { // NaN, Infinity\n node = new ConstantNode(numeric(name, 'number'))\n } else {\n node = new SymbolNode(name)\n }\n\n // parse function parameters and matrix index\n node = parseAccessors(state, node)\n return node\n }\n\n return parseString(state)\n }\n\n /**\n * parse accessors:\n * - function invocation in round brackets (...), for example sqrt(2)\n * - index enclosed in square brackets [...], for example A[2,3]\n * - dot notation for properties, like foo.bar\n * @param {Object} state\n * @param {Node} node Node on which to apply the parameters. If there\n * are no parameters in the expression, the node\n * itself is returned\n * @param {string[]} [types] Filter the types of notations\n * can be ['(', '[', '.']\n * @return {Node} node\n * @private\n */\n function parseAccessors (state, node, types) {\n let params\n\n while ((state.token === '(' || state.token === '[' || state.token === '.') &&\n (!types || types.includes(state.token))) { // eslint-disable-line no-unmodified-loop-condition\n params = []\n\n if (state.token === '(') {\n if (isSymbolNode(node) || isAccessorNode(node)) {\n // function invocation like fn(2, 3) or obj.fn(2, 3)\n openParams(state)\n getToken(state)\n\n if (state.token !== ')') {\n params.push(parseAssignment(state))\n\n // parse a list with parameters\n while (state.token === ',') { // eslint-disable-line no-unmodified-loop-condition\n getToken(state)\n params.push(parseAssignment(state))\n }\n }\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected')\n }\n closeParams(state)\n getToken(state)\n\n node = new FunctionNode(node, params)\n } else {\n // implicit multiplication like (2+3)(4+5) or sqrt(2)(1+2)\n // don't parse it here but let it be handled by parseImplicitMultiplication\n // with correct precedence\n return node\n }\n } else if (state.token === '[') {\n // index notation like variable[2, 3]\n openParams(state)\n getToken(state)\n\n if (state.token !== ']') {\n params.push(parseAssignment(state))\n\n // parse a list with parameters\n while (state.token === ',') { // eslint-disable-line no-unmodified-loop-condition\n getToken(state)\n params.push(parseAssignment(state))\n }\n }\n\n if (state.token !== ']') {\n throw createSyntaxError(state, 'Parenthesis ] expected')\n }\n closeParams(state)\n getToken(state)\n\n node = new AccessorNode(node, new IndexNode(params))\n } else {\n // dot notation like variable.prop\n getToken(state)\n\n const isPropertyName = state.tokenType === TOKENTYPE.SYMBOL ||\n (state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS)\n if (!isPropertyName) {\n throw createSyntaxError(state, 'Property name expected after dot')\n }\n\n params.push(new ConstantNode(state.token))\n getToken(state)\n\n const dotNotation = true\n node = new AccessorNode(node, new IndexNode(params, dotNotation))\n }\n }\n\n return node\n }\n\n /**\n * Parse a single or double quoted string.\n * @return {Node} node\n * @private\n */\n function parseString (state) {\n let node, str\n\n if (state.token === '\"' || state.token === \"'\") {\n str = parseStringToken(state, state.token)\n\n // create constant\n node = new ConstantNode(str)\n\n // parse index parameters\n node = parseAccessors(state, node)\n\n return node\n }\n\n return parseMatrix(state)\n }\n\n /**\n * Parse a string surrounded by single or double quotes\n * @param {Object} state\n * @param {\"'\" | \"\\\"\"} quote\n * @return {string}\n */\n function parseStringToken (state, quote) {\n let str = ''\n\n while (currentCharacter(state) !== '' && currentCharacter(state) !== quote) {\n if (currentCharacter(state) === '\\\\') {\n next(state)\n\n const char = currentCharacter(state)\n const escapeChar = ESCAPE_CHARACTERS[char]\n if (escapeChar !== undefined) {\n // an escaped control character like \\\" or \\n\n str += escapeChar\n state.index += 1\n } else if (char === 'u') {\n // escaped unicode character\n const unicode = state.expression.slice(state.index + 1, state.index + 5)\n if (/^[0-9A-Fa-f]{4}$/.test(unicode)) { // test whether the string holds four hexadecimal values\n str += String.fromCharCode(parseInt(unicode, 16))\n state.index += 5\n } else {\n throw createSyntaxError(state, `Invalid unicode character \\\\u${unicode}`)\n }\n } else {\n throw createSyntaxError(state, `Bad escape character \\\\${char}`)\n }\n } else {\n // any regular character\n str += currentCharacter(state)\n next(state)\n }\n }\n\n getToken(state)\n if (state.token !== quote) {\n throw createSyntaxError(state, `End of string ${quote} expected`)\n }\n getToken(state)\n\n return str\n }\n\n /**\n * parse the matrix\n * @return {Node} node\n * @private\n */\n function parseMatrix (state) {\n let array, params, rows, cols\n\n if (state.token === '[') {\n // matrix [...]\n openParams(state)\n getToken(state)\n\n if (state.token !== ']') {\n // this is a non-empty matrix\n const row = parseRow(state)\n\n if (state.token === ';') {\n // 2 dimensional array\n rows = 1\n params = [row]\n\n // the rows of the matrix are separated by dot-comma's\n while (state.token === ';') { // eslint-disable-line no-unmodified-loop-condition\n getToken(state)\n\n if (state.token !== ']') {\n params[rows] = parseRow(state)\n rows++\n }\n }\n\n if (state.token !== ']') {\n throw createSyntaxError(state, 'End of matrix ] expected')\n }\n closeParams(state)\n getToken(state)\n\n // check if the number of columns matches in all rows\n cols = params[0].items.length\n for (let r = 1; r < rows; r++) {\n if (params[r].items.length !== cols) {\n throw createError(state, 'Column dimensions mismatch ' +\n '(' + params[r].items.length + ' !== ' + cols + ')')\n }\n }\n\n array = new ArrayNode(params)\n } else {\n // 1 dimensional vector\n if (state.token !== ']') {\n throw createSyntaxError(state, 'End of matrix ] expected')\n }\n closeParams(state)\n getToken(state)\n\n array = row\n }\n } else {\n // this is an empty matrix \"[ ]\"\n closeParams(state)\n getToken(state)\n array = new ArrayNode([])\n }\n\n return parseAccessors(state, array)\n }\n\n return parseObject(state)\n }\n\n /**\n * Parse a single comma-separated row from a matrix, like 'a, b, c'\n * @return {ArrayNode} node\n */\n function parseRow (state) {\n const params = [parseAssignment(state)]\n let len = 1\n\n while (state.token === ',') { // eslint-disable-line no-unmodified-loop-condition\n getToken(state)\n\n // parse expression\n if (state.token !== ']' && state.token !== ';') {\n params[len] = parseAssignment(state)\n len++\n }\n }\n\n return new ArrayNode(params)\n }\n\n /**\n * parse an object, enclosed in angle brackets{...}, for example {value: 2}\n * @return {Node} node\n * @private\n */\n function parseObject (state) {\n if (state.token === '{') {\n openParams(state)\n let key\n\n const properties = {}\n do {\n getToken(state)\n\n if (state.token !== '}') {\n // parse key\n if (state.token === '\"' || state.token === \"'\") {\n key = parseStringToken(state, state.token)\n } else if (state.tokenType === TOKENTYPE.SYMBOL || (state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS)) {\n key = state.token\n getToken(state)\n } else {\n throw createSyntaxError(state, 'Symbol or string expected as object key')\n }\n\n // parse key/value separator\n if (state.token !== ':') {\n throw createSyntaxError(state, 'Colon : expected after object key')\n }\n getToken(state)\n\n // parse key\n properties[key] = parseAssignment(state)\n }\n }\n while (state.token === ',') // eslint-disable-line no-unmodified-loop-condition\n\n if (state.token !== '}') {\n throw createSyntaxError(state, 'Comma , or bracket } expected after object value')\n }\n closeParams(state)\n getToken(state)\n\n let node = new ObjectNode(properties)\n\n // parse index parameters\n node = parseAccessors(state, node)\n\n return node\n }\n\n return parseNumber(state)\n }\n\n /**\n * parse a number\n * @return {Node} node\n * @private\n */\n function parseNumber (state) {\n let numberStr\n\n if (state.tokenType === TOKENTYPE.NUMBER) {\n // this is a number\n numberStr = state.token\n getToken(state)\n\n const numericType = safeNumberType(numberStr, config)\n const value = numeric(numberStr, numericType)\n\n return new ConstantNode(value)\n }\n\n return parseParentheses(state)\n }\n\n /**\n * parentheses\n * @return {Node} node\n * @private\n */\n function parseParentheses (state) {\n let node\n\n // check if it is a parenthesized expression\n if (state.token === '(') {\n // parentheses (...)\n openParams(state)\n getToken(state)\n\n node = parseAssignment(state) // start again\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected')\n }\n closeParams(state)\n getToken(state)\n\n node = new ParenthesisNode(node)\n node = parseAccessors(state, node)\n return node\n }\n\n return parseEnd(state)\n }\n\n /**\n * Evaluated when the expression is not yet ended but expected to end\n * @return {Node} res\n * @private\n */\n function parseEnd (state) {\n if (state.token === '') {\n // syntax error or unexpected end of expression\n throw createSyntaxError(state, 'Unexpected end of expression')\n } else {\n throw createSyntaxError(state, 'Value expected')\n }\n }\n\n /**\n * Shortcut for getting the current row value (one based)\n * Returns the line of the currently handled expression\n * @private\n */\n /* TODO: implement keeping track on the row number\n function row () {\n return null\n }\n */\n\n /**\n * Shortcut for getting the current col value (one based)\n * Returns the column (position) where the last state.token starts\n * @private\n */\n function col (state) {\n return state.index - state.token.length + 1\n }\n\n /**\n * Create an error\n * @param {Object} state\n * @param {string} message\n * @return {SyntaxError} instantiated error\n * @private\n */\n function createSyntaxError (state, message) {\n const c = col(state)\n const error = new SyntaxError(message + ' (char ' + c + ')')\n error.char = c\n\n return error\n }\n\n /**\n * Create an error\n * @param {Object} state\n * @param {string} message\n * @return {Error} instantiated error\n * @private\n */\n function createError (state, message) {\n const c = col(state)\n const error = new SyntaxError(message + ' (char ' + c + ')')\n error.char = c\n\n return error\n }\n\n // Now that we can parse, automatically convert strings to Nodes by parsing\n typed.addConversion({ from: 'string', to: 'Node', convert: parse })\n\n return parse\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'compile'\nconst dependencies = ['typed', 'parse']\n\nexport const createCompile = /* #__PURE__ */ factory(name, dependencies, ({ typed, parse }) => {\n /**\n * Parse and compile an expression.\n * Returns a an object with a function `evaluate([scope])` to evaluate the\n * compiled expression.\n *\n * Syntax:\n *\n * math.compile(expr) // returns one node\n * math.compile([expr1, expr2, expr3, ...]) // returns an array with nodes\n *\n * Examples:\n *\n * const code1 = math.compile('sqrt(3^2 + 4^2)')\n * code1.evaluate() // 5\n *\n * let scope = {a: 3, b: 4}\n * const code2 = math.compile('a * b') // 12\n * code2.evaluate(scope) // 12\n * scope.a = 5\n * code2.evaluate(scope) // 20\n *\n * const nodes = math.compile(['a = 3', 'b = 4', 'a * b'])\n * nodes[2].evaluate() // 12\n *\n * See also:\n *\n * parse, evaluate\n *\n * @param {string | string[] | Array | Matrix} expr\n * The expression to be compiled\n * @return {{evaluate: Function} | Array.<{evaluate: Function}>} code\n * An object with the compiled expression\n * @throws {Error}\n */\n return typed(name, {\n string: function (expr) {\n return parse(expr).compile()\n },\n\n 'Array | Matrix': function (expr) {\n return deepMap(expr, function (entry) {\n return parse(entry).compile()\n })\n }\n })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { createEmptyMap } from '../../utils/map.js'\n\nconst name = 'evaluate'\nconst dependencies = ['typed', 'parse']\n\nexport const createEvaluate = /* #__PURE__ */ factory(name, dependencies, ({ typed, parse }) => {\n /**\n * Evaluate an expression.\n *\n * The expression parser does not use JavaScript. Its syntax is close\n * to JavaScript but more suited for mathematical expressions.\n * See [https://mathjs.org/docs/expressions/syntax.html](https://mathjs.org/docs/expressions/syntax.html) to learn\n * the syntax and get an overview of the exact differences from JavaScript.\n *\n * Note the evaluating arbitrary expressions may involve security risks,\n * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information.\n *\n * Syntax:\n *\n * math.evaluate(expr)\n * math.evaluate(expr, scope)\n * math.evaluate([expr1, expr2, expr3, ...])\n * math.evaluate([expr1, expr2, expr3, ...], scope)\n *\n * Example:\n *\n * math.evaluate('(2+3)/4') // 1.25\n * math.evaluate('sqrt(3^2 + 4^2)') // 5\n * math.evaluate('sqrt(-4)') // 2i\n * math.evaluate(['a=3', 'b=4', 'a*b']) // [3, 4, 12]\n *\n * let scope = {a:3, b:4}\n * math.evaluate('a * b', scope) // 12\n *\n * See also:\n *\n * parse, compile\n *\n * @param {string | string[] | Matrix} expr The expression to be evaluated\n * @param {Object} [scope] Scope to read/write variables\n * @return {*} The result of the expression\n * @throws {Error}\n */\n return typed(name, {\n string: function (expr) {\n const scope = createEmptyMap()\n return parse(expr).compile().evaluate(scope)\n },\n\n 'string, Map | Object': function (expr, scope) {\n return parse(expr).compile().evaluate(scope)\n },\n\n 'Array | Matrix': function (expr) {\n const scope = createEmptyMap()\n return deepMap(expr, function (entry) {\n return parse(entry).compile().evaluate(scope)\n })\n },\n\n 'Array | Matrix, Map | Object': function (expr, scope) {\n return deepMap(expr, function (entry) {\n return parse(entry).compile().evaluate(scope)\n })\n }\n })\n})\n","import { factory } from '../utils/factory.js'\nimport { createEmptyMap, toObject } from '../utils/map.js'\n\nconst name = 'Parser'\nconst dependencies = ['evaluate']\n\nexport const createParserClass = /* #__PURE__ */ factory(name, dependencies, ({ evaluate }) => {\n /**\n * @constructor Parser\n * Parser contains methods to evaluate or parse expressions, and has a number\n * of convenience methods to get, set, and remove variables from memory. Parser\n * keeps a scope containing variables in memory, which is used for all\n * evaluations.\n *\n * Methods:\n * const result = parser.evaluate(expr) // evaluate an expression\n * const value = parser.get(name) // retrieve a variable from the parser\n * const values = parser.getAll() // retrieve all defined variables\n * parser.set(name, value) // set a variable in the parser\n * parser.remove(name) // clear a variable from the\n * // parsers scope\n * parser.clear() // clear the parsers scope\n *\n * Example usage:\n * const parser = new Parser()\n * // Note: there is a convenience method which can be used instead:\n * // const parser = new math.parser()\n *\n * // evaluate expressions\n * parser.evaluate('sqrt(3^2 + 4^2)') // 5\n * parser.evaluate('sqrt(-4)') // 2i\n * parser.evaluate('2 inch in cm') // 5.08 cm\n * parser.evaluate('cos(45 deg)') // 0.7071067811865476\n *\n * // define variables and functions\n * parser.evaluate('x = 7 / 2') // 3.5\n * parser.evaluate('x + 3') // 6.5\n * parser.evaluate('f(x, y) = x^y') // f(x, y)\n * parser.evaluate('f(2, 3)') // 8\n *\n * // get and set variables and functions\n * const x = parser.get('x') // 3.5\n * const f = parser.get('f') // function\n * const g = f(3, 2) // 9\n * parser.set('h', 500)\n * const i = parser.evaluate('h / 2') // 250\n * parser.set('hello', function (name) {\n * return 'hello, ' + name + '!'\n * })\n * parser.evaluate('hello(\"user\")') // \"hello, user!\"\n *\n * // clear defined functions and variables\n * parser.clear()\n *\n */\n function Parser () {\n if (!(this instanceof Parser)) {\n throw new SyntaxError(\n 'Constructor must be called with the new operator')\n }\n\n Object.defineProperty(this, 'scope', {\n value: createEmptyMap(),\n writable: false\n })\n }\n\n /**\n * Attach type information\n */\n Parser.prototype.type = 'Parser'\n Parser.prototype.isParser = true\n\n /**\n * Parse and evaluate the given expression\n * @param {string | string[]} expr A string containing an expression,\n * for example \"2+3\", or a list with expressions\n * @return {*} result The result, or undefined when the expression was empty\n * @throws {Error}\n */\n Parser.prototype.evaluate = function (expr) {\n // TODO: validate arguments\n return evaluate(expr, this.scope)\n }\n\n /**\n * Get a variable (a function or variable) by name from the parsers scope.\n * Returns undefined when not found\n * @param {string} name\n * @return {* | undefined} value\n */\n Parser.prototype.get = function (name) {\n // TODO: validate arguments\n if (this.scope.has(name)) {\n return this.scope.get(name)\n }\n }\n\n /**\n * Get a map with all defined variables\n * @return {Object} values\n */\n Parser.prototype.getAll = function () {\n return toObject(this.scope)\n }\n\n /**\n * Get a map with all defined variables\n * @return {Map} values\n */\n Parser.prototype.getAllAsMap = function () {\n return this.scope\n }\n\n /**\n * Set a symbol (a function or variable) by name from the parsers scope.\n * @param {string} name\n * @param {* | undefined} value\n */\n Parser.prototype.set = function (name, value) {\n this.scope.set(name, value)\n return value\n }\n\n /**\n * Remove a variable from the parsers scope\n * @param {string} name\n */\n Parser.prototype.remove = function (name) {\n this.scope.delete(name)\n }\n\n /**\n * Clear the scope with variables and functions\n */\n Parser.prototype.clear = function () {\n this.scope.clear()\n }\n\n return Parser\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'parser'\nconst dependencies = ['typed', 'Parser']\n\nexport const createParser = /* #__PURE__ */ factory(name, dependencies, ({ typed, Parser }) => {\n /**\n * Create a parser. The function creates a new `math.Parser` object.\n *\n * Syntax:\n *\n * math.parser()\n *\n * Examples:\n *\n * const parser = new math.parser()\n *\n * // evaluate expressions\n * const a = parser.evaluate('sqrt(3^2 + 4^2)') // 5\n * const b = parser.evaluate('sqrt(-4)') // 2i\n * const c = parser.evaluate('2 inch in cm') // 5.08 cm\n * const d = parser.evaluate('cos(45 deg)') // 0.7071067811865476\n *\n * // define variables and functions\n * parser.evaluate('x = 7 / 2') // 3.5\n * parser.evaluate('x + 3') // 6.5\n * parser.evaluate('f(x, y) = x^y') // f(x, y)\n * parser.evaluate('f(2, 3)') // 8\n *\n * // get and set variables and functions\n * const x = parser.get('x') // 3.5\n * const f = parser.get('f') // function\n * const g = f(3, 2) // 9\n * parser.set('h', 500)\n * const i = parser.evaluate('h / 2') // 250\n * parser.set('hello', function (name) {\n * return 'hello, ' + name + '!'\n * })\n * parser.evaluate('hello(\"user\")') // \"hello, user!\"\n *\n * // clear defined functions and variables\n * parser.clear()\n *\n * See also:\n *\n * evaluate, compile, parse\n *\n * @return {Parser} Parser\n */\n return typed(name, {\n '': function () {\n return new Parser()\n }\n })\n})\n","import { clone } from '../../../utils/object.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'lup'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'abs',\n 'addScalar',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'larger',\n 'equalScalar',\n 'unaryMinus',\n 'DenseMatrix',\n 'SparseMatrix',\n 'Spa'\n]\n\nexport const createLup = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n matrix,\n abs,\n addScalar,\n divideScalar,\n multiplyScalar,\n subtractScalar,\n larger,\n equalScalar,\n unaryMinus,\n DenseMatrix,\n SparseMatrix,\n Spa\n }\n) => {\n /**\n * Calculate the Matrix LU decomposition with partial pivoting. Matrix `A` is decomposed in two matrices (`L`, `U`) and a\n * row permutation vector `p` where `A[p,:] = L * U`\n *\n * Syntax:\n *\n * math.lup(A)\n *\n * Example:\n *\n * const m = [[2, 1], [1, 4]]\n * const r = math.lup(m)\n * // r = {\n * // L: [[1, 0], [0.5, 1]],\n * // U: [[2, 1], [0, 3.5]],\n * // P: [0, 1]\n * // }\n *\n * See also:\n *\n * slu, lsolve, lusolve, usolve\n *\n * @param {Matrix | Array} A A two dimensional matrix or array for which to get the LUP decomposition.\n *\n * @return {{L: Array | Matrix, U: Array | Matrix, P: Array.}} The lower triangular matrix, the upper triangular matrix and the permutation matrix.\n */\n return typed(name, {\n\n DenseMatrix: function (m) {\n return _denseLUP(m)\n },\n\n SparseMatrix: function (m) {\n return _sparseLUP(m)\n },\n\n Array: function (a) {\n // create dense matrix from array\n const m = matrix(a)\n // lup, use matrix implementation\n const r = _denseLUP(m)\n // result\n return {\n L: r.L.valueOf(),\n U: r.U.valueOf(),\n p: r.p\n }\n }\n })\n\n function _denseLUP (m) {\n // rows & columns\n const rows = m._size[0]\n const columns = m._size[1]\n // minimum rows and columns\n let n = Math.min(rows, columns)\n // matrix array, clone original data\n const data = clone(m._data)\n // l matrix arrays\n const ldata = []\n const lsize = [rows, n]\n // u matrix arrays\n const udata = []\n const usize = [n, columns]\n // vars\n let i, j, k\n // permutation vector\n const p = []\n for (i = 0; i < rows; i++) { p[i] = i }\n // loop columns\n for (j = 0; j < columns; j++) {\n // skip first column in upper triangular matrix\n if (j > 0) {\n // loop rows\n for (i = 0; i < rows; i++) {\n // min i,j\n const min = Math.min(i, j)\n // v[i, j]\n let s = 0\n // loop up to min\n for (k = 0; k < min; k++) {\n // s = l[i, k] - data[k, j]\n s = addScalar(s, multiplyScalar(data[i][k], data[k][j]))\n }\n data[i][j] = subtractScalar(data[i][j], s)\n }\n }\n // row with larger value in cvector, row >= j\n let pi = j\n let pabsv = 0\n let vjj = 0\n // loop rows\n for (i = j; i < rows; i++) {\n // data @ i, j\n const v = data[i][j]\n // absolute value\n const absv = abs(v)\n // value is greater than pivote value\n if (larger(absv, pabsv)) {\n // store row\n pi = i\n // update max value\n pabsv = absv\n // value @ [j, j]\n vjj = v\n }\n }\n // swap rows (j <-> pi)\n if (j !== pi) {\n // swap values j <-> pi in p\n p[j] = [p[pi], p[pi] = p[j]][0]\n // swap j <-> pi in data\n DenseMatrix._swapRows(j, pi, data)\n }\n // check column is in lower triangular matrix\n if (j < rows) {\n // loop rows (lower triangular matrix)\n for (i = j + 1; i < rows; i++) {\n // value @ i, j\n const vij = data[i][j]\n if (!equalScalar(vij, 0)) {\n // update data\n data[i][j] = divideScalar(data[i][j], vjj)\n }\n }\n }\n }\n // loop columns\n for (j = 0; j < columns; j++) {\n // loop rows\n for (i = 0; i < rows; i++) {\n // initialize row in arrays\n if (j === 0) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i] = []\n }\n // L\n ldata[i] = []\n }\n // check we are in the upper triangular matrix\n if (i < j) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i][j] = data[i][j]\n }\n // check column exists in lower triangular matrix\n if (j < rows) {\n // L\n ldata[i][j] = 0\n }\n continue\n }\n // diagonal value\n if (i === j) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i][j] = data[i][j]\n }\n // check column exists in lower triangular matrix\n if (j < rows) {\n // L\n ldata[i][j] = 1\n }\n continue\n }\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i][j] = 0\n }\n // check column exists in lower triangular matrix\n if (j < rows) {\n // L\n ldata[i][j] = data[i][j]\n }\n }\n }\n // l matrix\n const l = new DenseMatrix({\n data: ldata,\n size: lsize\n })\n // u matrix\n const u = new DenseMatrix({\n data: udata,\n size: usize\n })\n // p vector\n const pv = []\n for (i = 0, n = p.length; i < n; i++) { pv[p[i]] = i }\n // return matrices\n return {\n L: l,\n U: u,\n p: pv,\n toString: function () {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\nP: ' + this.p\n }\n }\n }\n\n function _sparseLUP (m) {\n // rows & columns\n const rows = m._size[0]\n const columns = m._size[1]\n // minimum rows and columns\n const n = Math.min(rows, columns)\n // matrix arrays (will not be modified, thanks to permutation vector)\n const values = m._values\n const index = m._index\n const ptr = m._ptr\n // l matrix arrays\n const lvalues = []\n const lindex = []\n const lptr = []\n const lsize = [rows, n]\n // u matrix arrays\n const uvalues = []\n const uindex = []\n const uptr = []\n const usize = [n, columns]\n // vars\n let i, j, k\n // permutation vectors, (current index -> original index) and (original index -> current index)\n const pvCo = []\n const pvOc = []\n for (i = 0; i < rows; i++) {\n pvCo[i] = i\n pvOc[i] = i\n }\n // swap indices in permutation vectors (condition x < y)!\n const swapIndeces = function (x, y) {\n // find pv indeces getting data from x and y\n const kx = pvOc[x]\n const ky = pvOc[y]\n // update permutation vector current -> original\n pvCo[kx] = y\n pvCo[ky] = x\n // update permutation vector original -> current\n pvOc[x] = ky\n pvOc[y] = kx\n }\n // loop columns\n for (j = 0; j < columns; j++) {\n // sparse accumulator\n const spa = new Spa()\n // check lower triangular matrix has a value @ column j\n if (j < rows) {\n // update ptr\n lptr.push(lvalues.length)\n // first value in j column for lower triangular matrix\n lvalues.push(1)\n lindex.push(j)\n }\n // update ptr\n uptr.push(uvalues.length)\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n const k0 = ptr[j]\n const k1 = ptr[j + 1]\n // copy column j into sparse accumulator\n for (k = k0; k < k1; k++) {\n // row\n i = index[k]\n // copy column values into sparse accumulator (use permutation vector)\n spa.set(pvCo[i], values[k])\n }\n // skip first column in upper triangular matrix\n if (j > 0) {\n // loop rows in column j (above diagonal)\n spa.forEach(0, j - 1, function (k, vkj) {\n // loop rows in column k (L)\n SparseMatrix._forEachRow(k, lvalues, lindex, lptr, function (i, vik) {\n // check row is below k\n if (i > k) {\n // update spa value\n spa.accumulate(i, unaryMinus(multiplyScalar(vik, vkj)))\n }\n })\n })\n }\n // row with larger value in spa, row >= j\n let pi = j\n let vjj = spa.get(j)\n let pabsv = abs(vjj)\n // loop values in spa (order by row, below diagonal)\n spa.forEach(j + 1, rows - 1, function (x, v) {\n // absolute value\n const absv = abs(v)\n // value is greater than pivote value\n if (larger(absv, pabsv)) {\n // store row\n pi = x\n // update max value\n pabsv = absv\n // value @ [j, j]\n vjj = v\n }\n })\n // swap rows (j <-> pi)\n if (j !== pi) {\n // swap values j <-> pi in L\n SparseMatrix._swapRows(j, pi, lsize[1], lvalues, lindex, lptr)\n // swap values j <-> pi in U\n SparseMatrix._swapRows(j, pi, usize[1], uvalues, uindex, uptr)\n // swap values in spa\n spa.swap(j, pi)\n // update permutation vector (swap values @ j, pi)\n swapIndeces(j, pi)\n }\n // loop values in spa (order by row)\n spa.forEach(0, rows - 1, function (x, v) {\n // check we are above diagonal\n if (x <= j) {\n // update upper triangular matrix\n uvalues.push(v)\n uindex.push(x)\n } else {\n // update value\n v = divideScalar(v, vjj)\n // check value is non zero\n if (!equalScalar(v, 0)) {\n // update lower triangular matrix\n lvalues.push(v)\n lindex.push(x)\n }\n }\n })\n }\n // update ptrs\n uptr.push(uvalues.length)\n lptr.push(lvalues.length)\n\n // return matrices\n return {\n L: new SparseMatrix({\n values: lvalues,\n index: lindex,\n ptr: lptr,\n size: lsize\n }),\n U: new SparseMatrix({\n values: uvalues,\n index: uindex,\n ptr: uptr,\n size: usize\n }),\n p: pvCo,\n toString: function () {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\nP: ' + this.p\n }\n }\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'qr'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'zeros',\n 'identity',\n 'isZero',\n 'equal',\n 'sign',\n 'sqrt',\n 'conj',\n 'unaryMinus',\n 'addScalar',\n 'divideScalar',\n 'multiplyScalar',\n 'subtractScalar',\n 'complex'\n]\n\nexport const createQr = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n matrix,\n zeros,\n identity,\n isZero,\n equal,\n sign,\n sqrt,\n conj,\n unaryMinus,\n addScalar,\n divideScalar,\n multiplyScalar,\n subtractScalar,\n complex\n }\n) => {\n /**\n * Calculate the Matrix QR decomposition. Matrix `A` is decomposed in\n * two matrices (`Q`, `R`) where `Q` is an\n * orthogonal matrix and `R` is an upper triangular matrix.\n *\n * Syntax:\n *\n * math.qr(A)\n *\n * Example:\n *\n * const m = [\n * [1, -1, 4],\n * [1, 4, -2],\n * [1, 4, 2],\n * [1, -1, 0]\n * ]\n * const result = math.qr(m)\n * // r = {\n * // Q: [\n * // [0.5, -0.5, 0.5],\n * // [0.5, 0.5, -0.5],\n * // [0.5, 0.5, 0.5],\n * // [0.5, -0.5, -0.5],\n * // ],\n * // R: [\n * // [2, 3, 2],\n * // [0, 5, -2],\n * // [0, 0, 4],\n * // [0, 0, 0]\n * // ]\n * // }\n *\n * See also:\n *\n * lup, lusolve\n *\n * @param {Matrix | Array} A A two dimensional matrix or array\n * for which to get the QR decomposition.\n *\n * @return {{Q: Array | Matrix, R: Array | Matrix}} Q: the orthogonal\n * matrix and R: the upper triangular matrix\n */\n return Object.assign(typed(name, {\n\n DenseMatrix: function (m) {\n return _denseQR(m)\n },\n\n SparseMatrix: function (m) {\n return _sparseQR(m)\n },\n\n Array: function (a) {\n // create dense matrix from array\n const m = matrix(a)\n // lup, use matrix implementation\n const r = _denseQR(m)\n // result\n return {\n Q: r.Q.valueOf(),\n R: r.R.valueOf()\n }\n }\n }), { _denseQRimpl })\n\n function _denseQRimpl (m) {\n // rows & columns (m x n)\n const rows = m._size[0] // m\n const cols = m._size[1] // n\n\n const Q = identity([rows], 'dense')\n const Qdata = Q._data\n\n const R = m.clone()\n const Rdata = R._data\n\n // vars\n let i, j, k\n\n const w = zeros([rows], '')\n\n for (k = 0; k < Math.min(cols, rows); ++k) {\n /*\n * **k-th Household matrix**\n *\n * The matrix I - 2*v*transpose(v)\n * x = first column of A\n * x1 = first element of x\n * alpha = x1 / |x1| * |x|\n * e1 = tranpose([1, 0, 0, ...])\n * u = x - alpha * e1\n * v = u / |u|\n *\n * Household matrix = I - 2 * v * tranpose(v)\n *\n * * Initially Q = I and R = A.\n * * Household matrix is a reflection in a plane normal to v which\n * will zero out all but the top right element in R.\n * * Appplying reflection to both Q and R will not change product.\n * * Repeat this process on the (1,1) minor to get R as an upper\n * triangular matrix.\n * * Reflections leave the magnitude of the columns of Q unchanged\n * so Q remains othoganal.\n *\n */\n\n const pivot = Rdata[k][k]\n const sgn = unaryMinus(equal(pivot, 0) ? 1 : sign(pivot))\n const conjSgn = conj(sgn)\n\n let alphaSquared = 0\n\n for (i = k; i < rows; i++) {\n alphaSquared = addScalar(alphaSquared, multiplyScalar(Rdata[i][k], conj(Rdata[i][k])))\n }\n\n const alpha = multiplyScalar(sgn, sqrt(alphaSquared))\n\n if (!isZero(alpha)) {\n // first element in vector u\n const u1 = subtractScalar(pivot, alpha)\n\n // w = v * u1 / |u| (only elements k to (rows-1) are used)\n w[k] = 1\n\n for (i = k + 1; i < rows; i++) {\n w[i] = divideScalar(Rdata[i][k], u1)\n }\n\n // tau = - conj(u1 / alpha)\n const tau = unaryMinus(conj(divideScalar(u1, alpha)))\n\n let s\n\n /*\n * tau and w have been choosen so that\n *\n * 2 * v * tranpose(v) = tau * w * tranpose(w)\n */\n\n /*\n * -- calculate R = R - tau * w * tranpose(w) * R --\n * Only do calculation with rows k to (rows-1)\n * Additionally columns 0 to (k-1) will not be changed by this\n * multiplication so do not bother recalculating them\n */\n for (j = k; j < cols; j++) {\n s = 0.0\n\n // calculate jth element of [tranpose(w) * R]\n for (i = k; i < rows; i++) {\n s = addScalar(s, multiplyScalar(conj(w[i]), Rdata[i][j]))\n }\n\n // calculate the jth element of [tau * transpose(w) * R]\n s = multiplyScalar(s, tau)\n\n for (i = k; i < rows; i++) {\n Rdata[i][j] = multiplyScalar(\n subtractScalar(Rdata[i][j], multiplyScalar(w[i], s)),\n conjSgn\n )\n }\n }\n /*\n * -- calculate Q = Q - tau * Q * w * transpose(w) --\n * Q is a square matrix (rows x rows)\n * Only do calculation with columns k to (rows-1)\n * Additionally rows 0 to (k-1) will not be changed by this\n * multiplication so do not bother recalculating them\n */\n for (i = 0; i < rows; i++) {\n s = 0.0\n\n // calculate ith element of [Q * w]\n for (j = k; j < rows; j++) {\n s = addScalar(s, multiplyScalar(Qdata[i][j], w[j]))\n }\n\n // calculate the ith element of [tau * Q * w]\n s = multiplyScalar(s, tau)\n\n for (j = k; j < rows; ++j) {\n Qdata[i][j] = divideScalar(\n subtractScalar(Qdata[i][j], multiplyScalar(s, conj(w[j]))),\n conjSgn\n )\n }\n }\n }\n }\n\n // return matrices\n return {\n Q,\n R,\n toString: function () {\n return 'Q: ' + this.Q.toString() + '\\nR: ' + this.R.toString()\n }\n }\n }\n\n function _denseQR (m) {\n const ret = _denseQRimpl(m)\n const Rdata = ret.R._data\n if (m._data.length > 0) {\n const zero = Rdata[0][0].type === 'Complex' ? complex(0) : 0\n\n for (let i = 0; i < Rdata.length; ++i) {\n for (let j = 0; j < i && j < (Rdata[0] || []).length; ++j) {\n Rdata[i][j] = zero\n }\n }\n }\n\n return ret\n }\n\n function _sparseQR (m) {\n throw new Error('qr not implemented for sparse matrices yet')\n }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Depth-first search and postorder of a tree rooted at node j\n *\n * @param {Number} j The tree node\n * @param {Number} k\n * @param {Array} w The workspace array\n * @param {Number} head The index offset within the workspace for the head array\n * @param {Number} next The index offset within the workspace for the next array\n * @param {Array} post The post ordering array\n * @param {Number} stack The index offset within the workspace for the stack array\n */\nexport function csTdfs (j, k, w, head, next, post, stack) {\n // variables\n let top = 0\n // place j on the stack\n w[stack] = j\n // while (stack is not empty)\n while (top >= 0) {\n // p = top of stack\n const p = w[stack + top]\n // i = youngest child of p\n const i = w[head + p]\n if (i === -1) {\n // p has no unordered children left\n top--\n // node p is the kth postordered node\n post[k++] = p\n } else {\n // remove i from children of p\n w[head + p] = w[next + i]\n // increment top\n ++top\n // start dfs on child node i\n w[stack + top] = i\n }\n }\n return k\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * This function \"flips\" its input about the integer -1.\n *\n * @param {Number} i The value to flip\n */\nexport function csFlip (i) {\n // flip the value\n return -i - 2\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { factory } from '../../../utils/factory.js'\nimport { csFkeep } from './csFkeep.js'\nimport { csFlip } from './csFlip.js'\nimport { csTdfs } from './csTdfs.js'\n\nconst name = 'csAmd'\nconst dependencies = [\n 'add',\n 'multiply',\n 'transpose'\n]\n\nexport const createCsAmd = /* #__PURE__ */ factory(name, dependencies, ({ add, multiply, transpose }) => {\n /**\n * Approximate minimum degree ordering. The minimum degree algorithm is a widely used\n * heuristic for finding a permutation P so that P*A*P' has fewer nonzeros in its factorization\n * than A. It is a gready method that selects the sparsest pivot row and column during the course\n * of a right looking sparse Cholesky factorization.\n *\n * @param {Number} order 0: Natural, 1: Cholesky, 2: LU, 3: QR\n * @param {Matrix} m Sparse Matrix\n */\n return function csAmd (order, a) {\n // check input parameters\n if (!a || order <= 0 || order > 3) { return null }\n // a matrix arrays\n const asize = a._size\n // rows and columns\n const m = asize[0]\n const n = asize[1]\n // initialize vars\n let lemax = 0\n // dense threshold\n let dense = Math.max(16, 10 * Math.sqrt(n))\n dense = Math.min(n - 2, dense)\n // create target matrix C\n const cm = _createTargetMatrix(order, a, m, n, dense)\n // drop diagonal entries\n csFkeep(cm, _diag, null)\n // C matrix arrays\n const cindex = cm._index\n const cptr = cm._ptr\n\n // number of nonzero elements in C\n let cnz = cptr[n]\n\n // allocate result (n+1)\n const P = []\n\n // create workspace (8 * (n + 1))\n const W = []\n const len = 0 // first n + 1 entries\n const nv = n + 1 // next n + 1 entries\n const next = 2 * (n + 1) // next n + 1 entries\n const head = 3 * (n + 1) // next n + 1 entries\n const elen = 4 * (n + 1) // next n + 1 entries\n const degree = 5 * (n + 1) // next n + 1 entries\n const w = 6 * (n + 1) // next n + 1 entries\n const hhead = 7 * (n + 1) // last n + 1 entries\n\n // use P as workspace for last\n const last = P\n\n // initialize quotient graph\n let mark = _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree)\n\n // initialize degree lists\n let nel = _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next)\n\n // minimum degree node\n let mindeg = 0\n\n // vars\n let i, j, k, k1, k2, e, pj, ln, nvi, pk, eln, p1, p2, pn, h, d\n\n // while (selecting pivots) do\n while (nel < n) {\n // select node of minimum approximate degree. amd() is now ready to start eliminating the graph. It first\n // finds a node k of minimum degree and removes it from its degree list. The variable nel keeps track of thow\n // many nodes have been eliminated.\n for (k = -1; mindeg < n && (k = W[head + mindeg]) === -1; mindeg++);\n if (W[next + k] !== -1) { last[W[next + k]] = -1 }\n // remove k from degree list\n W[head + mindeg] = W[next + k]\n // elenk = |Ek|\n const elenk = W[elen + k]\n // # of nodes k represents\n let nvk = W[nv + k]\n // W[nv + k] nodes of A eliminated\n nel += nvk\n\n // Construct a new element. The new element Lk is constructed in place if |Ek| = 0. nv[i] is\n // negated for all nodes i in Lk to flag them as members of this set. Each node i is removed from the\n // degree lists. All elements e in Ek are absorved into element k.\n let dk = 0\n // flag k as in Lk\n W[nv + k] = -nvk\n let p = cptr[k]\n // do in place if W[elen + k] === 0\n const pk1 = (elenk === 0) ? p : cnz\n let pk2 = pk1\n for (k1 = 1; k1 <= elenk + 1; k1++) {\n if (k1 > elenk) {\n // search the nodes in k\n e = k\n // list of nodes starts at cindex[pj]\n pj = p\n // length of list of nodes in k\n ln = W[len + k] - elenk\n } else {\n // search the nodes in e\n e = cindex[p++]\n pj = cptr[e]\n // length of list of nodes in e\n ln = W[len + e]\n }\n for (k2 = 1; k2 <= ln; k2++) {\n i = cindex[pj++]\n // check node i dead, or seen\n if ((nvi = W[nv + i]) <= 0) { continue }\n // W[degree + Lk] += size of node i\n dk += nvi\n // negate W[nv + i] to denote i in Lk\n W[nv + i] = -nvi\n // place i in Lk\n cindex[pk2++] = i\n if (W[next + i] !== -1) { last[W[next + i]] = last[i] }\n // check we need to remove i from degree list\n if (last[i] !== -1) { W[next + last[i]] = W[next + i] } else { W[head + W[degree + i]] = W[next + i] }\n }\n if (e !== k) {\n // absorb e into k\n cptr[e] = csFlip(k)\n // e is now a dead element\n W[w + e] = 0\n }\n }\n // cindex[cnz...nzmax] is free\n if (elenk !== 0) { cnz = pk2 }\n // external degree of k - |Lk\\i|\n W[degree + k] = dk\n // element k is in cindex[pk1..pk2-1]\n cptr[k] = pk1\n W[len + k] = pk2 - pk1\n // k is now an element\n W[elen + k] = -2\n\n // Find set differences. The scan1 function now computes the set differences |Le \\ Lk| for all elements e. At the start of the\n // scan, no entry in the w array is greater than or equal to mark.\n\n // clear w if necessary\n mark = _wclear(mark, lemax, W, w, n)\n // scan 1: find |Le\\Lk|\n for (pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]\n // check if W[elen + i] empty, skip it\n if ((eln = W[elen + i]) <= 0) { continue }\n // W[nv + i] was negated\n nvi = -W[nv + i]\n const wnvi = mark - nvi\n // scan Ei\n for (p = cptr[i], p1 = cptr[i] + eln - 1; p <= p1; p++) {\n e = cindex[p]\n if (W[w + e] >= mark) {\n // decrement |Le\\Lk|\n W[w + e] -= nvi\n } else if (W[w + e] !== 0) {\n // ensure e is a live element, 1st time e seen in scan 1\n W[w + e] = W[degree + e] + wnvi\n }\n }\n }\n\n // degree update\n // The second pass computes the approximate degree di, prunes the sets Ei and Ai, and computes a hash\n // function h(i) for all nodes in Lk.\n\n // scan2: degree update\n for (pk = pk1; pk < pk2; pk++) {\n // consider node i in Lk\n i = cindex[pk]\n p1 = cptr[i]\n p2 = p1 + W[elen + i] - 1\n pn = p1\n // scan Ei\n for (h = 0, d = 0, p = p1; p <= p2; p++) {\n e = cindex[p]\n // check e is an unabsorbed element\n if (W[w + e] !== 0) {\n // dext = |Le\\Lk|\n const dext = W[w + e] - mark\n if (dext > 0) {\n // sum up the set differences\n d += dext\n // keep e in Ei\n cindex[pn++] = e\n // compute the hash of node i\n h += e\n } else {\n // aggressive absorb. e->k\n cptr[e] = csFlip(k)\n // e is a dead element\n W[w + e] = 0\n }\n }\n }\n // W[elen + i] = |Ei|\n W[elen + i] = pn - p1 + 1\n const p3 = pn\n const p4 = p1 + W[len + i]\n // prune edges in Ai\n for (p = p2 + 1; p < p4; p++) {\n j = cindex[p]\n // check node j dead or in Lk\n const nvj = W[nv + j]\n if (nvj <= 0) { continue }\n // degree(i) += |j|\n d += nvj\n // place j in node list of i\n cindex[pn++] = j\n // compute hash for node i\n h += j\n }\n // check for mass elimination\n if (d === 0) {\n // absorb i into k\n cptr[i] = csFlip(k)\n nvi = -W[nv + i]\n // |Lk| -= |i|\n dk -= nvi\n // |k| += W[nv + i]\n nvk += nvi\n nel += nvi\n W[nv + i] = 0\n // node i is dead\n W[elen + i] = -1\n } else {\n // update degree(i)\n W[degree + i] = Math.min(W[degree + i], d)\n // move first node to end\n cindex[pn] = cindex[p3]\n // move 1st el. to end of Ei\n cindex[p3] = cindex[p1]\n // add k as 1st element in of Ei\n cindex[p1] = k\n // new len of adj. list of node i\n W[len + i] = pn - p1 + 1\n // finalize hash of i\n h = (h < 0 ? -h : h) % n\n // place i in hash bucket\n W[next + i] = W[hhead + h]\n W[hhead + h] = i\n // save hash of i in last[i]\n last[i] = h\n }\n }\n // finalize |Lk|\n W[degree + k] = dk\n lemax = Math.max(lemax, dk)\n // clear w\n mark = _wclear(mark + lemax, lemax, W, w, n)\n\n // Supernode detection. Supernode detection relies on the hash function h(i) computed for each node i.\n // If two nodes have identical adjacency lists, their hash functions wil be identical.\n for (pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]\n // check i is dead, skip it\n if (W[nv + i] >= 0) { continue }\n // scan hash bucket of node i\n h = last[i]\n i = W[hhead + h]\n // hash bucket will be empty\n W[hhead + h] = -1\n for (; i !== -1 && W[next + i] !== -1; i = W[next + i], mark++) {\n ln = W[len + i]\n eln = W[elen + i]\n for (p = cptr[i] + 1; p <= cptr[i] + ln - 1; p++) { W[w + cindex[p]] = mark }\n let jlast = i\n // compare i with all j\n for (j = W[next + i]; j !== -1;) {\n let ok = W[len + j] === ln && W[elen + j] === eln\n for (p = cptr[j] + 1; ok && p <= cptr[j] + ln - 1; p++) {\n // compare i and j\n if (W[w + cindex[p]] !== mark) { ok = 0 }\n }\n // check i and j are identical\n if (ok) {\n // absorb j into i\n cptr[j] = csFlip(i)\n W[nv + i] += W[nv + j]\n W[nv + j] = 0\n // node j is dead\n W[elen + j] = -1\n // delete j from hash bucket\n j = W[next + j]\n W[next + jlast] = j\n } else {\n // j and i are different\n jlast = j\n j = W[next + j]\n }\n }\n }\n }\n\n // Finalize new element. The elimination of node k is nearly complete. All nodes i in Lk are scanned one last time.\n // Node i is removed from Lk if it is dead. The flagged status of nv[i] is cleared.\n for (p = pk1, pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]\n // check i is dead, skip it\n if ((nvi = -W[nv + i]) <= 0) { continue }\n // restore W[nv + i]\n W[nv + i] = nvi\n // compute external degree(i)\n d = W[degree + i] + dk - nvi\n d = Math.min(d, n - nel - nvi)\n if (W[head + d] !== -1) { last[W[head + d]] = i }\n // put i back in degree list\n W[next + i] = W[head + d]\n last[i] = -1\n W[head + d] = i\n // find new minimum degree\n mindeg = Math.min(mindeg, d)\n W[degree + i] = d\n // place i in Lk\n cindex[p++] = i\n }\n // # nodes absorbed into k\n W[nv + k] = nvk\n // length of adj list of element k\n if ((W[len + k] = p - pk1) === 0) {\n // k is a root of the tree\n cptr[k] = -1\n // k is now a dead element\n W[w + k] = 0\n }\n if (elenk !== 0) {\n // free unused space in Lk\n cnz = p\n }\n }\n\n // Postordering. The elimination is complete, but no permutation has been computed. All that is left\n // of the graph is the assembly tree (ptr) and a set of dead nodes and elements (i is a dead node if\n // nv[i] is zero and a dead element if nv[i] > 0). It is from this information only that the final permutation\n // is computed. The tree is restored by unflipping all of ptr.\n\n // fix assembly tree\n for (i = 0; i < n; i++) { cptr[i] = csFlip(cptr[i]) }\n for (j = 0; j <= n; j++) { W[head + j] = -1 }\n // place unordered nodes in lists\n for (j = n; j >= 0; j--) {\n // skip if j is an element\n if (W[nv + j] > 0) { continue }\n // place j in list of its parent\n W[next + j] = W[head + cptr[j]]\n W[head + cptr[j]] = j\n }\n // place elements in lists\n for (e = n; e >= 0; e--) {\n // skip unless e is an element\n if (W[nv + e] <= 0) { continue }\n if (cptr[e] !== -1) {\n // place e in list of its parent\n W[next + e] = W[head + cptr[e]]\n W[head + cptr[e]] = e\n }\n }\n // postorder the assembly tree\n for (k = 0, i = 0; i <= n; i++) {\n if (cptr[i] === -1) { k = csTdfs(i, k, W, head, next, P, w) }\n }\n // remove last item in array\n P.splice(P.length - 1, 1)\n // return P\n return P\n }\n\n /**\n * Creates the matrix that will be used by the approximate minimum degree ordering algorithm. The function accepts the matrix M as input and returns a permutation\n * vector P. The amd algorithm operates on a symmetrix matrix, so one of three symmetric matrices is formed.\n *\n * Order: 0\n * A natural ordering P=null matrix is returned.\n *\n * Order: 1\n * Matrix must be square. This is appropriate for a Cholesky or LU factorization.\n * P = M + M'\n *\n * Order: 2\n * Dense columns from M' are dropped, M recreated from M'. This is appropriatefor LU factorization of unsymmetric matrices.\n * P = M' * M\n *\n * Order: 3\n * This is best used for QR factorization or LU factorization is matrix M has no dense rows. A dense row is a row with more than 10*sqr(columns) entries.\n * P = M' * M\n */\n function _createTargetMatrix (order, a, m, n, dense) {\n // compute A'\n const at = transpose(a)\n\n // check order = 1, matrix must be square\n if (order === 1 && n === m) {\n // C = A + A'\n return add(a, at)\n }\n\n // check order = 2, drop dense columns from M'\n if (order === 2) {\n // transpose arrays\n const tindex = at._index\n const tptr = at._ptr\n // new column index\n let p2 = 0\n // loop A' columns (rows)\n for (let j = 0; j < m; j++) {\n // column j of AT starts here\n let p = tptr[j]\n // new column j starts here\n tptr[j] = p2\n // skip dense col j\n if (tptr[j + 1] - p > dense) { continue }\n // map rows in column j of A\n for (const p1 = tptr[j + 1]; p < p1; p++) { tindex[p2++] = tindex[p] }\n }\n // finalize AT\n tptr[m] = p2\n // recreate A from new transpose matrix\n a = transpose(at)\n // use A' * A\n return multiply(at, a)\n }\n\n // use A' * A, square or rectangular matrix\n return multiply(at, a)\n }\n\n /**\n * Initialize quotient graph. There are four kind of nodes and elements that must be represented:\n *\n * - A live node is a node i (or a supernode) that has not been selected as a pivot nad has not been merged into another supernode.\n * - A dead node i is one that has been removed from the graph, having been absorved into r = flip(ptr[i]).\n * - A live element e is one that is in the graph, having been formed when node e was selected as the pivot.\n * - A dead element e is one that has benn absorved into a subsequent element s = flip(ptr[e]).\n */\n function _initializeQuotientGraph (n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree) {\n // Initialize quotient graph\n for (let k = 0; k < n; k++) { W[len + k] = cptr[k + 1] - cptr[k] }\n W[len + n] = 0\n // initialize workspace\n for (let i = 0; i <= n; i++) {\n // degree list i is empty\n W[head + i] = -1\n last[i] = -1\n W[next + i] = -1\n // hash list i is empty\n W[hhead + i] = -1\n // node i is just one node\n W[nv + i] = 1\n // node i is alive\n W[w + i] = 1\n // Ek of node i is empty\n W[elen + i] = 0\n // degree of node i\n W[degree + i] = W[len + i]\n }\n // clear w\n const mark = _wclear(0, 0, W, w, n)\n // n is a dead element\n W[elen + n] = -2\n // n is a root of assembly tree\n cptr[n] = -1\n // n is a dead element\n W[w + n] = 0\n // return mark\n return mark\n }\n\n /**\n * Initialize degree lists. Each node is placed in its degree lists. Nodes of zero degree are eliminated immediately. Nodes with\n * degree >= dense are alsol eliminated and merged into a placeholder node n, a dead element. Thes nodes will appera last in the\n * output permutation p.\n */\n function _initializeDegreeLists (n, cptr, W, degree, elen, w, dense, nv, head, last, next) {\n // result\n let nel = 0\n // loop columns\n for (let i = 0; i < n; i++) {\n // degree @ i\n const d = W[degree + i]\n // check node i is empty\n if (d === 0) {\n // element i is dead\n W[elen + i] = -2\n nel++\n // i is a root of assembly tree\n cptr[i] = -1\n W[w + i] = 0\n } else if (d > dense) {\n // absorb i into element n\n W[nv + i] = 0\n // node i is dead\n W[elen + i] = -1\n nel++\n cptr[i] = csFlip(n)\n W[nv + n]++\n } else {\n const h = W[head + d]\n if (h !== -1) { last[h] = i }\n // put node i in degree list d\n W[next + i] = W[head + d]\n W[head + d] = i\n }\n }\n return nel\n }\n\n function _wclear (mark, lemax, W, w, n) {\n if (mark < 2 || (mark + lemax < 0)) {\n for (let k = 0; k < n; k++) {\n if (W[w + k] !== 0) { W[w + k] = 1 }\n }\n mark = 2\n }\n // at this point, W [0..n-1] < mark holds\n return mark\n }\n\n function _diag (i, j) {\n return i !== j\n }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Keeps entries in the matrix when the callback function returns true, removes the entry otherwise\n *\n * @param {Matrix} a The sparse matrix\n * @param {function} callback The callback function, function will be invoked with the following args:\n * - The entry row\n * - The entry column\n * - The entry value\n * - The state parameter\n * @param {any} other The state\n *\n * @return The number of nonzero elements in the matrix\n */\nexport function csFkeep (a, callback, other) {\n // a arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n // columns\n const n = asize[1]\n // nonzero items\n let nz = 0\n // loop columns\n for (let j = 0; j < n; j++) {\n // get current location of col j\n let p = aptr[j]\n // record new location of col j\n aptr[j] = nz\n for (; p < aptr[j + 1]; p++) {\n // check we need to keep this item\n if (callback(aindex[p], j, avalues ? avalues[p] : 1, other)) {\n // keep A(i,j)\n aindex[nz] = aindex[p]\n // check we need to process values (pattern only)\n if (avalues) { avalues[nz] = avalues[p] }\n // increment nonzero items\n nz++\n }\n }\n }\n // finalize A\n aptr[n] = nz\n // trim arrays\n aindex.splice(nz, aindex.length - nz)\n // check we need to process values (pattern only)\n if (avalues) { avalues.splice(nz, avalues.length - nz) }\n // return number of nonzero items\n return nz\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * This function determines if j is a leaf of the ith row subtree.\n * Consider A(i,j), node j in ith row subtree and return lca(jprev,j)\n *\n * @param {Number} i The ith row subtree\n * @param {Number} j The node to test\n * @param {Array} w The workspace array\n * @param {Number} first The index offset within the workspace for the first array\n * @param {Number} maxfirst The index offset within the workspace for the maxfirst array\n * @param {Number} prevleaf The index offset within the workspace for the prevleaf array\n * @param {Number} ancestor The index offset within the workspace for the ancestor array\n *\n * @return {Object}\n */\nexport function csLeaf (i, j, w, first, maxfirst, prevleaf, ancestor) {\n let s, sparent\n\n // our result\n let jleaf = 0\n let q\n\n // check j is a leaf\n if (i <= j || w[first + j] <= w[maxfirst + i]) { return (-1) }\n // update max first[j] seen so far\n w[maxfirst + i] = w[first + j]\n // jprev = previous leaf of ith subtree\n const jprev = w[prevleaf + i]\n w[prevleaf + i] = j\n\n // check j is first or subsequent leaf\n if (jprev === -1) {\n // 1st leaf, q = root of ith subtree\n jleaf = 1\n q = i\n } else {\n // update jleaf\n jleaf = 2\n // q = least common ancester (jprev,j)\n for (q = jprev; q !== w[ancestor + q]; q = w[ancestor + q]);\n for (s = jprev; s !== q; s = sparent) {\n // path compression\n sparent = w[ancestor + s]\n w[ancestor + s] = q\n }\n }\n return { jleaf, q }\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { factory } from '../../../utils/factory.js'\nimport { csLeaf } from './csLeaf.js'\n\nconst name = 'csCounts'\nconst dependencies = [\n 'transpose'\n]\n\nexport const createCsCounts = /* #__PURE__ */ factory(name, dependencies, ({ transpose }) => {\n /**\n * Computes the column counts using the upper triangular part of A.\n * It transposes A internally, none of the input parameters are modified.\n *\n * @param {Matrix} a The sparse matrix A\n *\n * @param {Matrix} ata Count the columns of A'A instead\n *\n * @return An array of size n of the column counts or null on error\n */\n return function (a, parent, post, ata) {\n // check inputs\n if (!a || !parent || !post) { return null }\n // a matrix arrays\n const asize = a._size\n // rows and columns\n const m = asize[0]\n const n = asize[1]\n // variables\n let i, j, k, J, p, p0, p1\n\n // workspace size\n const s = 4 * n + (ata ? (n + m + 1) : 0)\n // allocate workspace\n const w = [] // (s)\n const ancestor = 0 // first n entries\n const maxfirst = n // next n entries\n const prevleaf = 2 * n // next n entries\n const first = 3 * n // next n entries\n const head = 4 * n // next n + 1 entries (used when ata is true)\n const next = 5 * n + 1 // last entries in workspace\n // clear workspace w[0..s-1]\n for (k = 0; k < s; k++) { w[k] = -1 }\n\n // allocate result\n const colcount = [] // (n)\n\n // AT = A'\n const at = transpose(a)\n // at arrays\n const tindex = at._index\n const tptr = at._ptr\n\n // find w[first + j]\n for (k = 0; k < n; k++) {\n j = post[k]\n // colcount[j]=1 if j is a leaf\n colcount[j] = (w[first + j] === -1) ? 1 : 0\n for (; j !== -1 && w[first + j] === -1; j = parent[j]) { w[first + j] = k }\n }\n\n // initialize ata if needed\n if (ata) {\n // invert post\n for (k = 0; k < n; k++) { w[post[k]] = k }\n // loop rows (columns in AT)\n for (i = 0; i < m; i++) {\n // values in column i of AT\n for (k = n, p0 = tptr[i], p1 = tptr[i + 1], p = p0; p < p1; p++) { k = Math.min(k, w[tindex[p]]) }\n // place row i in linked list k\n w[next + i] = w[head + k]\n w[head + k] = i\n }\n }\n\n // each node in its own set\n for (i = 0; i < n; i++) { w[ancestor + i] = i }\n\n for (k = 0; k < n; k++) {\n // j is the kth node in postordered etree\n j = post[k]\n // check j is not a root\n if (parent[j] !== -1) { colcount[parent[j]]-- }\n\n // J=j for LL'=A case\n for (J = (ata ? w[head + k] : j); J !== -1; J = (ata ? w[next + J] : -1)) {\n for (p = tptr[J]; p < tptr[J + 1]; p++) {\n i = tindex[p]\n const r = csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor)\n // check A(i,j) is in skeleton\n if (r.jleaf >= 1) { colcount[j]++ }\n // check account for overlap in q\n if (r.jleaf === 2) { colcount[r.q]-- }\n }\n }\n if (parent[j] !== -1) { w[ancestor + j] = parent[j] }\n }\n // sum up colcount's of each child\n for (j = 0; j < n; j++) {\n if (parent[j] !== -1) { colcount[parent[j]] += colcount[j] }\n }\n return colcount\n }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csPermute } from './csPermute.js'\nimport { csPost } from './csPost.js'\nimport { csEtree } from './csEtree.js'\nimport { createCsAmd } from './csAmd.js'\nimport { createCsCounts } from './csCounts.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'csSqr'\nconst dependencies = [\n 'add',\n 'multiply',\n 'transpose'\n]\n\nexport const createCsSqr = /* #__PURE__ */ factory(name, dependencies, ({ add, multiply, transpose }) => {\n const csAmd = createCsAmd({ add, multiply, transpose })\n const csCounts = createCsCounts({ transpose })\n\n /**\n * Symbolic ordering and analysis for QR and LU decompositions.\n *\n * @param {Number} order The ordering strategy (see csAmd for more details)\n * @param {Matrix} a The A matrix\n * @param {boolean} qr Symbolic ordering and analysis for QR decomposition (true) or\n * symbolic ordering and analysis for LU decomposition (false)\n *\n * @return {Object} The Symbolic ordering and analysis for matrix A\n */\n return function csSqr (order, a, qr) {\n // a arrays\n const aptr = a._ptr\n const asize = a._size\n // columns\n const n = asize[1]\n // vars\n let k\n // symbolic analysis result\n const s = {}\n // fill-reducing ordering\n s.q = csAmd(order, a)\n // validate results\n if (order && !s.q) { return null }\n // QR symbolic analysis\n if (qr) {\n // apply permutations if needed\n const c = order ? csPermute(a, null, s.q, 0) : a\n // etree of C'*C, where C=A(:,q)\n s.parent = csEtree(c, 1)\n // post order elimination tree\n const post = csPost(s.parent, n)\n // col counts chol(C'*C)\n s.cp = csCounts(c, s.parent, post, 1)\n // check we have everything needed to calculate number of nonzero elements\n if (c && s.parent && s.cp && _vcount(c, s)) {\n // calculate number of nonzero elements\n for (s.unz = 0, k = 0; k < n; k++) { s.unz += s.cp[k] }\n }\n } else {\n // for LU factorization only, guess nnz(L) and nnz(U)\n s.unz = 4 * (aptr[n]) + n\n s.lnz = s.unz\n }\n // return result S\n return s\n }\n\n /**\n * Compute nnz(V) = s.lnz, s.pinv, s.leftmost, s.m2 from A and s.parent\n */\n function _vcount (a, s) {\n // a arrays\n const aptr = a._ptr\n const aindex = a._index\n const asize = a._size\n // rows & columns\n const m = asize[0]\n const n = asize[1]\n // initialize s arrays\n s.pinv = [] // (m + n)\n s.leftmost = [] // (m)\n // vars\n const parent = s.parent\n const pinv = s.pinv\n const leftmost = s.leftmost\n // workspace, next: first m entries, head: next n entries, tail: next n entries, nque: next n entries\n const w = [] // (m + 3 * n)\n const next = 0\n const head = m\n const tail = m + n\n const nque = m + 2 * n\n // vars\n let i, k, p, p0, p1\n // initialize w\n for (k = 0; k < n; k++) {\n // queue k is empty\n w[head + k] = -1\n w[tail + k] = -1\n w[nque + k] = 0\n }\n // initialize row arrays\n for (i = 0; i < m; i++) { leftmost[i] = -1 }\n // loop columns backwards\n for (k = n - 1; k >= 0; k--) {\n // values & index for column k\n for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) {\n // leftmost[i] = min(find(A(i,:)))\n leftmost[aindex[p]] = k\n }\n }\n // scan rows in reverse order\n for (i = m - 1; i >= 0; i--) {\n // row i is not yet ordered\n pinv[i] = -1\n k = leftmost[i]\n // check row i is empty\n if (k === -1) { continue }\n // first row in queue k\n if (w[nque + k]++ === 0) { w[tail + k] = i }\n // put i at head of queue k\n w[next + i] = w[head + k]\n w[head + k] = i\n }\n s.lnz = 0\n s.m2 = m\n // find row permutation and nnz(V)\n for (k = 0; k < n; k++) {\n // remove row i from queue k\n i = w[head + k]\n // count V(k,k) as nonzero\n s.lnz++\n // add a fictitious row\n if (i < 0) { i = s.m2++ }\n // associate row i with V(:,k)\n pinv[i] = k\n // skip if V(k+1:m,k) is empty\n if (--nque[k] <= 0) { continue }\n // nque[k] is nnz (V(k+1:m,k))\n s.lnz += w[nque + k]\n // move all rows to parent of k\n const pa = parent[k]\n if (pa !== -1) {\n if (w[nque + pa] === 0) { w[tail + pa] = w[tail + k] }\n w[next + w[tail + k]] = w[head + pa]\n w[head + pa] = w[next + i]\n w[nque + pa] += w[nque + k]\n }\n }\n for (i = 0; i < m; i++) {\n if (pinv[i] < 0) { pinv[i] = k++ }\n }\n return true\n }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Permutes a sparse matrix C = P * A * Q\n *\n * @param {SparseMatrix} a The Matrix A\n * @param {Array} pinv The row permutation vector\n * @param {Array} q The column permutation vector\n * @param {boolean} values Create a pattern matrix (false), values and pattern otherwise\n *\n * @return {Matrix} C = P * A * Q, null on error\n */\nexport function csPermute (a, pinv, q, values) {\n // a arrays\n const avalues = a._values\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n const adt = a._datatype\n // rows & columns\n const m = asize[0]\n const n = asize[1]\n // c arrays\n const cvalues = values && a._values ? [] : null\n const cindex = [] // (aptr[n])\n const cptr = [] // (n + 1)\n // initialize vars\n let nz = 0\n // loop columns\n for (let k = 0; k < n; k++) {\n // column k of C is column q[k] of A\n cptr[k] = nz\n // apply column permutation\n const j = q ? (q[k]) : k\n // loop values in column j of A\n for (let t0 = aptr[j], t1 = aptr[j + 1], t = t0; t < t1; t++) {\n // row i of A is row pinv[i] of C\n const r = pinv ? pinv[aindex[t]] : aindex[t]\n // index\n cindex[nz] = r\n // check we need to populate values\n if (cvalues) { cvalues[nz] = avalues[t] }\n // increment number of nonzero elements\n nz++\n }\n }\n // finalize the last column of C\n cptr[n] = nz\n // return C matrix\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [m, n],\n datatype: adt\n })\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Computes the elimination tree of Matrix A (using triu(A)) or the\n * elimination tree of A'A without forming A'A.\n *\n * @param {Matrix} a The A Matrix\n * @param {boolean} ata A value of true the function computes the etree of A'A\n */\nexport function csEtree (a, ata) {\n // check inputs\n if (!a) { return null }\n // a arrays\n const aindex = a._index\n const aptr = a._ptr\n const asize = a._size\n // rows & columns\n const m = asize[0]\n const n = asize[1]\n\n // allocate result\n const parent = [] // (n)\n\n // allocate workspace\n const w = [] // (n + (ata ? m : 0))\n const ancestor = 0 // first n entries in w\n const prev = n // last m entries (ata = true)\n\n let i, inext\n\n // check we are calculating A'A\n if (ata) {\n // initialize workspace\n for (i = 0; i < m; i++) { w[prev + i] = -1 }\n }\n // loop columns\n for (let k = 0; k < n; k++) {\n // node k has no parent yet\n parent[k] = -1\n // nor does k have an ancestor\n w[ancestor + k] = -1\n // values in column k\n for (let p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) {\n // row\n const r = aindex[p]\n // node\n i = ata ? (w[prev + r]) : r\n // traverse from i to k\n for (; i !== -1 && i < k; i = inext) {\n // inext = ancestor of i\n inext = w[ancestor + i]\n // path compression\n w[ancestor + i] = k\n // check no anc., parent is k\n if (inext === -1) { parent[i] = k }\n }\n if (ata) { w[prev + r] = k }\n }\n }\n return parent\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csTdfs } from './csTdfs.js'\n\n/**\n * Post order a tree of forest\n *\n * @param {Array} parent The tree or forest\n * @param {Number} n Number of columns\n */\nexport function csPost (parent, n) {\n // check inputs\n if (!parent) { return null }\n // vars\n let k = 0\n let j\n // allocate result\n const post = [] // (n)\n // workspace, head: first n entries, next: next n entries, stack: last n entries\n const w = [] // (3 * n)\n const head = 0\n const next = n\n const stack = 2 * n\n // initialize workspace\n for (j = 0; j < n; j++) {\n // empty linked lists\n w[head + j] = -1\n }\n // traverse nodes in reverse order\n for (j = n - 1; j >= 0; j--) {\n // check j is a root\n if (parent[j] === -1) { continue }\n // add j to list of its parent\n w[next + j] = w[head + parent[j]]\n w[head + parent[j]] = j\n }\n // loop nodes\n for (j = 0; j < n; j++) {\n // skip j if it is not a root\n if (parent[j] !== -1) { continue }\n // depth-first search\n k = csTdfs(j, k, w, head, next, post, stack)\n }\n return post\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Checks if the node at w[j] is marked\n *\n * @param {Array} w The array\n * @param {Number} j The array index\n */\nexport function csMarked (w, j) {\n // check node is marked\n return w[j] < 0\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { csFlip } from './csFlip.js'\n\n/**\n * Marks the node at w[j]\n *\n * @param {Array} w The array\n * @param {Number} j The array index\n */\nexport function csMark (w, j) {\n // mark w[j]\n w[j] = csFlip(w[j])\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csFlip } from './csFlip.js'\n\n/**\n * Flips the value if it is negative of returns the same value otherwise.\n *\n * @param {Number} i The value to flip\n */\nexport function csUnflip (i) {\n // flip the value if it is negative\n return i < 0 ? csFlip(i) : i\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csMarked } from './csMarked.js'\nimport { csMark } from './csMark.js'\nimport { csUnflip } from './csUnflip.js'\n\n/**\n * Depth-first search computes the nonzero pattern xi of the directed graph G (Matrix) starting\n * at nodes in B (see csReach()).\n *\n * @param {Number} j The starting node for the DFS algorithm\n * @param {Matrix} g The G matrix to search, ptr array modified, then restored\n * @param {Number} top Start index in stack xi[top..n-1]\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b\n *\n * @return {Number} New value of top\n */\nexport function csDfs (j, g, top, xi, pinv) {\n // g arrays\n const index = g._index\n const ptr = g._ptr\n const size = g._size\n // columns\n const n = size[1]\n // vars\n let i, p, p2\n // initialize head\n let head = 0\n // initialize the recursion stack\n xi[0] = j\n // loop\n while (head >= 0) {\n // get j from the top of the recursion stack\n j = xi[head]\n // apply permutation vector\n const jnew = pinv ? pinv[j] : j\n // check node j is marked\n if (!csMarked(ptr, j)) {\n // mark node j as visited\n csMark(ptr, j)\n // update stack (last n entries in xi)\n xi[n + head] = jnew < 0 ? 0 : csUnflip(ptr[jnew])\n }\n // node j done if no unvisited neighbors\n let done = 1\n // examine all neighbors of j, stack (last n entries in xi)\n for (p = xi[n + head], p2 = jnew < 0 ? 0 : csUnflip(ptr[jnew + 1]); p < p2; p++) {\n // consider neighbor node i\n i = index[p]\n // check we have visited node i, skip it\n if (csMarked(ptr, i)) { continue }\n // pause depth-first search of node j, update stack (last n entries in xi)\n xi[n + head] = p\n // start dfs at node i\n xi[++head] = i\n // node j is not done\n done = 0\n // break, to start dfs(i)\n break\n }\n // check depth-first search at node j is done\n if (done) {\n // remove j from the recursion stack\n head--\n // and place in the output stack\n xi[--top] = j\n }\n }\n return top\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csReach } from './csReach.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'csSpsolve'\nconst dependencies = [\n 'divideScalar',\n 'multiply',\n 'subtract'\n]\n\nexport const createCsSpsolve = /* #__PURE__ */ factory(name, dependencies, ({ divideScalar, multiply, subtract }) => {\n /**\n * The function csSpsolve() computes the solution to G * x = bk, where bk is the\n * kth column of B. When lo is true, the function assumes G = L is lower triangular with the\n * diagonal entry as the first entry in each column. When lo is true, the function assumes G = U\n * is upper triangular with the diagonal entry as the last entry in each column.\n *\n * @param {Matrix} g The G matrix\n * @param {Matrix} b The B matrix\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} x The soluton to the linear system G * x = b\n * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b\n * @param {boolean} lo The lower (true) upper triangular (false) flag\n *\n * @return {Number} The index for the nonzero pattern\n */\n return function csSpsolve (g, b, k, xi, x, pinv, lo) {\n // g arrays\n const gvalues = g._values\n const gindex = g._index\n const gptr = g._ptr\n const gsize = g._size\n // columns\n const n = gsize[1]\n // b arrays\n const bvalues = b._values\n const bindex = b._index\n const bptr = b._ptr\n // vars\n let p, p0, p1, q\n // xi[top..n-1] = csReach(B(:,k))\n const top = csReach(g, b, k, xi, pinv)\n // clear x\n for (p = top; p < n; p++) { x[xi[p]] = 0 }\n // scatter b\n for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { x[bindex[p]] = bvalues[p] }\n // loop columns\n for (let px = top; px < n; px++) {\n // x array index for px\n const j = xi[px]\n // apply permutation vector (U x = b), j maps to column J of G\n const J = pinv ? pinv[j] : j\n // check column J is empty\n if (J < 0) { continue }\n // column value indeces in G, p0 <= p < p1\n p0 = gptr[J]\n p1 = gptr[J + 1]\n // x(j) /= G(j,j)\n x[j] = divideScalar(x[j], gvalues[lo ? p0 : (p1 - 1)])\n // first entry L(j,j)\n p = lo ? (p0 + 1) : p0\n q = lo ? (p1) : (p1 - 1)\n // loop\n for (; p < q; p++) {\n // row\n const i = gindex[p]\n // x(i) -= G(i,j) * x(j)\n x[i] = subtract(x[i], multiply(gvalues[p], x[j]))\n }\n }\n // return top of stack\n return top\n }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { csMarked } from './csMarked.js'\nimport { csMark } from './csMark.js'\nimport { csDfs } from './csDfs.js'\n\n/**\n * The csReach function computes X = Reach(B), where B is the nonzero pattern of the n-by-1\n * sparse column of vector b. The function returns the set of nodes reachable from any node in B. The\n * nonzero pattern xi of the solution x to the sparse linear system Lx=b is given by X=Reach(B).\n *\n * @param {Matrix} g The G matrix\n * @param {Matrix} b The B matrix\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} pinv The inverse row permutation vector\n *\n * @return {Number} The index for the nonzero pattern\n */\nexport function csReach (g, b, k, xi, pinv) {\n // g arrays\n const gptr = g._ptr\n const gsize = g._size\n // b arrays\n const bindex = b._index\n const bptr = b._ptr\n // columns\n const n = gsize[1]\n // vars\n let p, p0, p1\n // initialize top\n let top = n\n // loop column indeces in B\n for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) {\n // node i\n const i = bindex[p]\n // check node i is marked\n if (!csMarked(gptr, i)) {\n // start a dfs at unmarked node i\n top = csDfs(i, g, top, xi, pinv)\n }\n }\n // loop columns from top -> n - 1\n for (p = top; p < n; p++) {\n // restore G\n csMark(gptr, xi[p])\n }\n return top\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { factory } from '../../../utils/factory.js'\nimport { createCsSpsolve } from './csSpsolve.js'\n\nconst name = 'csLu'\nconst dependencies = [\n 'abs',\n 'divideScalar',\n 'multiply',\n 'subtract',\n 'larger',\n 'largerEq',\n 'SparseMatrix'\n]\n\nexport const createCsLu = /* #__PURE__ */ factory(name, dependencies, ({ abs, divideScalar, multiply, subtract, larger, largerEq, SparseMatrix }) => {\n const csSpsolve = createCsSpsolve({ divideScalar, multiply, subtract })\n\n /**\n * Computes the numeric LU factorization of the sparse matrix A. Implements a Left-looking LU factorization\n * algorithm that computes L and U one column at a tume. At the kth step, it access columns 1 to k-1 of L\n * and column k of A. Given the fill-reducing column ordering q (see parameter s) computes L, U and pinv so\n * L * U = A(p, q), where p is the inverse of pinv.\n *\n * @param {Matrix} m The A Matrix to factorize\n * @param {Object} s The symbolic analysis from csSqr(). Provides the fill-reducing\n * column ordering q\n * @param {Number} tol Partial pivoting threshold (1 for partial pivoting)\n *\n * @return {Number} The numeric LU factorization of A or null\n */\n return function csLu (m, s, tol) {\n // validate input\n if (!m) { return null }\n // m arrays\n const size = m._size\n // columns\n const n = size[1]\n // symbolic analysis result\n let q\n let lnz = 100\n let unz = 100\n // update symbolic analysis parameters\n if (s) {\n q = s.q\n lnz = s.lnz || lnz\n unz = s.unz || unz\n }\n // L arrays\n const lvalues = [] // (lnz)\n const lindex = [] // (lnz)\n const lptr = [] // (n + 1)\n // L\n const L = new SparseMatrix({\n values: lvalues,\n index: lindex,\n ptr: lptr,\n size: [n, n]\n })\n // U arrays\n const uvalues = [] // (unz)\n const uindex = [] // (unz)\n const uptr = [] // (n + 1)\n // U\n const U = new SparseMatrix({\n values: uvalues,\n index: uindex,\n ptr: uptr,\n size: [n, n]\n })\n // inverse of permutation vector\n const pinv = [] // (n)\n // vars\n let i, p\n // allocate arrays\n const x = [] // (n)\n const xi = [] // (2 * n)\n // initialize variables\n for (i = 0; i < n; i++) {\n // clear workspace\n x[i] = 0\n // no rows pivotal yet\n pinv[i] = -1\n // no cols of L yet\n lptr[i + 1] = 0\n }\n // reset number of nonzero elements in L and U\n lnz = 0\n unz = 0\n // compute L(:,k) and U(:,k)\n for (let k = 0; k < n; k++) {\n // update ptr\n lptr[k] = lnz\n uptr[k] = unz\n // apply column permutations if needed\n const col = q ? q[k] : k\n // solve triangular system, x = L\\A(:,col)\n const top = csSpsolve(L, m, col, xi, x, pinv, 1)\n // find pivot\n let ipiv = -1\n let a = -1\n // loop xi[] from top -> n\n for (p = top; p < n; p++) {\n // x[i] is nonzero\n i = xi[p]\n // check row i is not yet pivotal\n if (pinv[i] < 0) {\n // absolute value of x[i]\n const xabs = abs(x[i])\n // check absoulte value is greater than pivot value\n if (larger(xabs, a)) {\n // largest pivot candidate so far\n a = xabs\n ipiv = i\n }\n } else {\n // x(i) is the entry U(pinv[i],k)\n uindex[unz] = pinv[i]\n uvalues[unz++] = x[i]\n }\n }\n // validate we found a valid pivot\n if (ipiv === -1 || a <= 0) { return null }\n // update actual pivot column, give preference to diagonal value\n if (pinv[col] < 0 && largerEq(abs(x[col]), multiply(a, tol))) { ipiv = col }\n // the chosen pivot\n const pivot = x[ipiv]\n // last entry in U(:,k) is U(k,k)\n uindex[unz] = k\n uvalues[unz++] = pivot\n // ipiv is the kth pivot row\n pinv[ipiv] = k\n // first entry in L(:,k) is L(k,k) = 1\n lindex[lnz] = ipiv\n lvalues[lnz++] = 1\n // L(k+1:n,k) = x / pivot\n for (p = top; p < n; p++) {\n // row\n i = xi[p]\n // check x(i) is an entry in L(:,k)\n if (pinv[i] < 0) {\n // save unpermuted row in L\n lindex[lnz] = i\n // scale pivot column\n lvalues[lnz++] = divideScalar(x[i], pivot)\n }\n // x[0..n-1] = 0 for next k\n x[i] = 0\n }\n }\n // update ptr\n lptr[n] = lnz\n uptr[n] = unz\n // fix row indices of L for final pinv\n for (p = 0; p < lnz; p++) { lindex[p] = pinv[lindex[p]] }\n // trim arrays\n lvalues.splice(lnz, lvalues.length - lnz)\n lindex.splice(lnz, lindex.length - lnz)\n uvalues.splice(unz, uvalues.length - unz)\n uindex.splice(unz, uindex.length - unz)\n // return LU factor\n return { L, U, pinv }\n }\n})\n","import { isInteger } from '../../../utils/number.js'\nimport { factory } from '../../../utils/factory.js'\nimport { createCsSqr } from '../sparse/csSqr.js'\nimport { createCsLu } from '../sparse/csLu.js'\n\nconst name = 'slu'\nconst dependencies = [\n 'typed',\n 'abs',\n 'add',\n 'multiply',\n 'transpose',\n 'divideScalar',\n 'subtract',\n 'larger',\n 'largerEq',\n 'SparseMatrix'\n]\n\nexport const createSlu = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, multiply, transpose, divideScalar, subtract, larger, largerEq, SparseMatrix }) => {\n const csSqr = createCsSqr({ add, multiply, transpose })\n const csLu = createCsLu({ abs, divideScalar, multiply, subtract, larger, largerEq, SparseMatrix })\n\n /**\n * Calculate the Sparse Matrix LU decomposition with full pivoting. Sparse Matrix `A` is decomposed in two matrices (`L`, `U`) and two permutation vectors (`pinv`, `q`) where\n *\n * `P * A * Q = L * U`\n *\n * Syntax:\n *\n * math.slu(A, order, threshold)\n *\n * Examples:\n *\n * const A = math.sparse([[4,3], [6, 3]])\n * math.slu(A, 1, 0.001)\n * // returns:\n * // {\n * // L: [[1, 0], [1.5, 1]]\n * // U: [[4, 3], [0, -1.5]]\n * // p: [0, 1]\n * // q: [0, 1]\n * // }\n *\n * See also:\n *\n * lup, lsolve, usolve, lusolve\n *\n * @param {SparseMatrix} A A two dimensional sparse matrix for which to get the LU decomposition.\n * @param {Number} order The Symbolic Ordering and Analysis order:\n * 0 - Natural ordering, no permutation vector q is returned\n * 1 - Matrix must be square, symbolic ordering and analisis is performed on M = A + A'\n * 2 - Symbolic ordering and analisis is performed on M = A' * A. Dense columns from A' are dropped, A recreated from A'.\n * This is appropriatefor LU factorization of unsymmetric matrices.\n * 3 - Symbolic ordering and analisis is performed on M = A' * A. This is best used for LU factorization is matrix M has no dense rows.\n * A dense row is a row with more than 10*sqr(columns) entries.\n * @param {Number} threshold Partial pivoting threshold (1 for partial pivoting)\n *\n * @return {Object} The lower triangular matrix, the upper triangular matrix and the permutation vectors.\n */\n return typed(name, {\n\n 'SparseMatrix, number, number': function (a, order, threshold) {\n // verify order\n if (!isInteger(order) || order < 0 || order > 3) { throw new Error('Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]') }\n // verify threshold\n if (threshold < 0 || threshold > 1) { throw new Error('Partial pivoting threshold must be a number from 0 to 1') }\n\n // perform symbolic ordering and analysis\n const s = csSqr(order, a, false)\n\n // perform lu decomposition\n const f = csLu(a, s, threshold)\n\n // return decomposition\n return {\n L: f.L,\n U: f.U,\n p: f.pinv,\n q: s.q,\n toString: function () {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\np: ' + this.p.toString() + (this.q ? '\\nq: ' + this.q.toString() : '') + '\\n'\n }\n }\n }\n })\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * Permutes a vector; x = P'b. In MATLAB notation, x(p)=b.\n *\n * @param {Array} p The permutation vector of length n. null value denotes identity\n * @param {Array} b The input vector\n *\n * @return {Array} The output vector x = P'b\n */\nexport function csIpvec (p, b) {\n // vars\n let k\n const n = b.length\n const x = []\n // check permutation vector was provided, p = null denotes identity\n if (p) {\n // loop vector\n for (k = 0; k < n; k++) {\n // apply permutation\n x[p[k]] = b[k]\n }\n } else {\n // loop vector\n for (k = 0; k < n; k++) {\n // x[i] = b[i]\n x[k] = b[k]\n }\n }\n return x\n}\n","import { isArray, isMatrix } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\nimport { csIpvec } from '../sparse/csIpvec.js'\n\nconst name = 'lusolve'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'lup',\n 'slu',\n 'usolve',\n 'lsolve',\n 'DenseMatrix'\n]\n\nexport const createLusolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, lup, slu, usolve, lsolve, DenseMatrix }) => {\n const solveValidation = createSolveValidation({ DenseMatrix })\n\n /**\n * Solves the linear system `A * x = b` where `A` is an [n x n] matrix and `b` is a [n] column vector.\n *\n * Syntax:\n *\n * math.lusolve(A, b) // returns column vector with the solution to the linear system A * x = b\n * math.lusolve(lup, b) // returns column vector with the solution to the linear system A * x = b, lup = math.lup(A)\n *\n * Examples:\n *\n * const m = [[1, 0, 0, 0], [0, 2, 0, 0], [0, 0, 3, 0], [0, 0, 0, 4]]\n *\n * const x = math.lusolve(m, [-1, -1, -1, -1]) // x = [[-1], [-0.5], [-1/3], [-0.25]]\n *\n * const f = math.lup(m)\n * const x1 = math.lusolve(f, [-1, -1, -1, -1]) // x1 = [[-1], [-0.5], [-1/3], [-0.25]]\n * const x2 = math.lusolve(f, [1, 2, 1, -1]) // x2 = [[1], [1], [1/3], [-0.25]]\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = math.lusolve(a, b) // [[2], [5]]\n *\n * See also:\n *\n * lup, slu, lsolve, usolve\n *\n * @param {Matrix | Array | Object} A Invertible Matrix or the Matrix LU decomposition\n * @param {Matrix | Array} b Column Vector\n * @param {number} [order] The Symbolic Ordering and Analysis order, see slu for details. Matrix must be a SparseMatrix\n * @param {Number} [threshold] Partial pivoting threshold (1 for partial pivoting), see slu for details. Matrix must be a SparseMatrix.\n *\n * @return {DenseMatrix | Array} Column vector with the solution to the linear system A * x = b\n */\n return typed(name, {\n\n 'Array, Array | Matrix': function (a, b) {\n a = matrix(a)\n const d = lup(a)\n const x = _lusolve(d.L, d.U, d.p, null, b)\n return x.valueOf()\n },\n\n 'DenseMatrix, Array | Matrix': function (a, b) {\n const d = lup(a)\n return _lusolve(d.L, d.U, d.p, null, b)\n },\n\n 'SparseMatrix, Array | Matrix': function (a, b) {\n const d = lup(a)\n return _lusolve(d.L, d.U, d.p, null, b)\n },\n\n 'SparseMatrix, Array | Matrix, number, number': function (a, b, order, threshold) {\n const d = slu(a, order, threshold)\n return _lusolve(d.L, d.U, d.p, d.q, b)\n },\n\n 'Object, Array | Matrix': function (d, b) {\n return _lusolve(d.L, d.U, d.p, d.q, b)\n }\n })\n\n function _toMatrix (a) {\n if (isMatrix(a)) { return a }\n if (isArray(a)) { return matrix(a) }\n throw new TypeError('Invalid Matrix LU decomposition')\n }\n\n function _lusolve (l, u, p, q, b) {\n // verify decomposition\n l = _toMatrix(l)\n u = _toMatrix(u)\n\n // apply row permutations if needed (b is a DenseMatrix)\n if (p) {\n b = solveValidation(l, b, true)\n b._data = csIpvec(p, b._data)\n }\n\n // use forward substitution to resolve L * y = b\n const y = lsolve(l, b)\n // use backward substitution to resolve U * x = y\n const x = usolve(u, y)\n\n // apply column permutations if needed (x is a DenseMatrix)\n if (q) { x._data = csIpvec(q, x._data) }\n\n return x\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'polynomialRoot'\nconst dependencies = [\n 'typed',\n 'isZero',\n 'equalScalar',\n 'add',\n 'subtract',\n 'multiply',\n 'divide',\n 'sqrt',\n 'unaryMinus',\n 'cbrt',\n 'typeOf',\n 'im',\n 're'\n]\n\nexport const createPolynomialRoot = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n isZero,\n equalScalar,\n add,\n subtract,\n multiply,\n divide,\n sqrt,\n unaryMinus,\n cbrt,\n typeOf,\n im,\n re\n}) => {\n /**\n * Finds the numerical values of the distinct roots of a polynomial with real or complex coefficients.\n * Currently operates only on linear, quadratic, and cubic polynomials using the standard\n * formulas for the roots.\n *\n * Syntax:\n *\n * math.polynomialRoot(constant, linearCoeff, quadraticCoeff, cubicCoeff)\n *\n * Examples:\n * // linear\n * math.polynomialRoot(6, 3) // [-2]\n * math.polynomialRoot(math.complex(6,3), 3) // [-2 - i]\n * math.polynomialRoot(math.complex(6,3), math.complex(2,1)) // [-3 + 0i]\n * // quadratic\n * math.polynomialRoot(2, -3, 1) // [2, 1]\n * math.polynomialRoot(8, 8, 2) // [-2]\n * math.polynomialRoot(-2, 0, 1) // [1.4142135623730951, -1.4142135623730951]\n * math.polynomialRoot(2, -2, 1) // [1 + i, 1 - i]\n * math.polynomialRoot(math.complex(1,3), math.complex(-3, -2), 1) // [2 + i, 1 + i]\n * // cubic\n * math.polynomialRoot(-6, 11, -6, 1) // [1, 3, 2]\n * math.polynomialRoot(-8, 0, 0, 1) // [-1 - 1.7320508075688774i, 2, -1 + 1.7320508075688774i]\n * math.polynomialRoot(0, 8, 8, 2) // [0, -2]\n * math.polynomialRoot(1, 1, 1, 1) // [-1 + 0i, 0 - i, 0 + i]\n *\n * See also:\n * cbrt, sqrt\n *\n * @param {... number | Complex} coeffs\n * The coefficients of the polynomial, starting with with the constant coefficent, followed\n * by the linear coefficient and subsequent coefficients of increasing powers.\n * @return {Array} The distinct roots of the polynomial\n */\n\n return typed(name, {\n 'number|Complex, ...number|Complex': (constant, restCoeffs) => {\n const coeffs = [constant, ...restCoeffs]\n while (coeffs.length > 0 && isZero(coeffs[coeffs.length - 1])) {\n coeffs.pop()\n }\n if (coeffs.length < 2) {\n throw new RangeError(\n `Polynomial [${constant}, ${restCoeffs}] must have a non-zero non-constant coefficient`)\n }\n switch (coeffs.length) {\n case 2: // linear\n return [unaryMinus(divide(coeffs[0], coeffs[1]))]\n case 3: { // quadratic\n const [c, b, a] = coeffs\n const denom = multiply(2, a)\n const d1 = multiply(b, b)\n const d2 = multiply(4, a, c)\n if (equalScalar(d1, d2)) return [divide(unaryMinus(b), denom)]\n const discriminant = sqrt(subtract(d1, d2))\n return [\n divide(subtract(discriminant, b), denom),\n divide(subtract(unaryMinus(discriminant), b), denom)\n ]\n }\n case 4: { // cubic, cf. https://en.wikipedia.org/wiki/Cubic_equation\n const [d, c, b, a] = coeffs\n const denom = unaryMinus(multiply(3, a))\n const D0_1 = multiply(b, b)\n const D0_2 = multiply(3, a, c)\n const D1_1 = add(multiply(2, b, b, b), multiply(27, a, a, d))\n const D1_2 = multiply(9, a, b, c)\n if (equalScalar(D0_1, D0_2) && equalScalar(D1_1, D1_2)) {\n return [divide(b, denom)]\n }\n const Delta0 = subtract(D0_1, D0_2)\n const Delta1 = subtract(D1_1, D1_2)\n const discriminant1 = add(\n multiply(18, a, b, c, d), multiply(b, b, c, c))\n const discriminant2 = add(\n multiply(4, b, b, b, d),\n multiply(4, a, c, c, c),\n multiply(27, a, a, d, d))\n if (equalScalar(discriminant1, discriminant2)) {\n return [\n divide(\n subtract(\n multiply(4, a, b, c),\n add(multiply(9, a, a, d), multiply(b, b, b))),\n multiply(a, Delta0)), // simple root\n divide(\n subtract(multiply(9, a, d), multiply(b, c)),\n multiply(2, Delta0)) // double root\n ]\n }\n // OK, we have three distinct roots\n let Ccubed\n if (equalScalar(D0_1, D0_2)) {\n Ccubed = Delta1\n } else {\n Ccubed = divide(\n add(\n Delta1,\n sqrt(subtract(\n multiply(Delta1, Delta1), multiply(4, Delta0, Delta0, Delta0)))\n ),\n 2)\n }\n const allRoots = true\n const rawRoots = cbrt(Ccubed, allRoots).toArray().map(\n C => divide(add(b, C, divide(Delta0, C)), denom))\n return rawRoots.map(r => {\n if (typeOf(r) === 'Complex' && equalScalar(re(r), re(r) + im(r))) {\n return re(r)\n }\n return r\n })\n }\n default:\n throw new RangeError(`only implemented for cubic or lower-order polynomials, not ${coeffs}`)\n }\n }\n })\n})\n","import { isHelp } from '../utils/is.js'\nimport { clone } from '../utils/object.js'\nimport { format } from '../utils/string.js'\nimport { factory } from '../utils/factory.js'\n\nconst name = 'Help'\nconst dependencies = ['evaluate']\n\nexport const createHelpClass = /* #__PURE__ */ factory(name, dependencies, ({ evaluate }) => {\n /**\n * Documentation object\n * @param {Object} doc Object containing properties:\n * {string} name\n * {string} category\n * {string} description\n * {string[]} syntax\n * {string[]} examples\n * {string[]} seealso\n * @constructor\n */\n function Help (doc) {\n if (!(this instanceof Help)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n if (!doc) throw new Error('Argument \"doc\" missing')\n\n this.doc = doc\n }\n\n /**\n * Attach type information\n */\n Help.prototype.type = 'Help'\n Help.prototype.isHelp = true\n\n /**\n * Generate a string representation of the Help object\n * @return {string} Returns a string\n * @private\n */\n Help.prototype.toString = function () {\n const doc = this.doc || {}\n let desc = '\\n'\n\n if (doc.name) {\n desc += 'Name: ' + doc.name + '\\n\\n'\n }\n if (doc.category) {\n desc += 'Category: ' + doc.category + '\\n\\n'\n }\n if (doc.description) {\n desc += 'Description:\\n ' + doc.description + '\\n\\n'\n }\n if (doc.syntax) {\n desc += 'Syntax:\\n ' + doc.syntax.join('\\n ') + '\\n\\n'\n }\n if (doc.examples) {\n desc += 'Examples:\\n'\n\n // after evaluating the examples, we restore config in case the examples\n // did change the config.\n let configChanged = false\n const originalConfig = evaluate('config()')\n\n const scope = {\n config: (newConfig) => {\n configChanged = true\n return evaluate('config(newConfig)', { newConfig })\n }\n }\n\n for (let i = 0; i < doc.examples.length; i++) {\n const expr = doc.examples[i]\n desc += ' ' + expr + '\\n'\n\n let res\n try {\n // note: res can be undefined when `expr` is an empty string\n res = evaluate(expr, scope)\n } catch (e) {\n res = e\n }\n if (res !== undefined && !isHelp(res)) {\n desc += ' ' + format(res, { precision: 14 }) + '\\n'\n }\n }\n desc += '\\n'\n\n if (configChanged) {\n evaluate('config(originalConfig)', { originalConfig })\n }\n }\n if (doc.mayThrow && doc.mayThrow.length) {\n desc += 'Throws: ' + doc.mayThrow.join(', ') + '\\n\\n'\n }\n if (doc.seealso && doc.seealso.length) {\n desc += 'See also: ' + doc.seealso.join(', ') + '\\n'\n }\n\n return desc\n }\n\n /**\n * Export the help object to JSON\n */\n Help.prototype.toJSON = function () {\n const obj = clone(this.doc)\n obj.mathjs = 'Help'\n return obj\n }\n\n /**\n * Instantiate a Help object from a JSON object\n * @param {Object} json\n * @returns {Help} Returns a new Help object\n */\n Help.fromJSON = function (json) {\n const doc = {}\n\n Object.keys(json)\n .filter(prop => prop !== 'mathjs')\n .forEach(prop => {\n doc[prop] = json[prop]\n })\n\n return new Help(doc)\n }\n\n /**\n * Returns a string representation of the Help object\n */\n Help.prototype.valueOf = Help.prototype.toString\n\n return Help\n}, { isClass: true })\n","import { isChain } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { hasOwnProperty, lazy } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Chain'\nconst dependencies = ['?on', 'math', 'typed']\n\nexport const createChainClass = /* #__PURE__ */ factory(name, dependencies, ({ on, math, typed }) => {\n /**\n * @constructor Chain\n * Wrap any value in a chain, allowing to perform chained operations on\n * the value.\n *\n * All methods available in the math.js library can be called upon the chain,\n * and then will be evaluated with the value itself as first argument.\n * The chain can be closed by executing chain.done(), which will return\n * the final value.\n *\n * The Chain has a number of special functions:\n * - done() Finalize the chained operation and return the\n * chain's value.\n * - valueOf() The same as done()\n * - toString() Returns a string representation of the chain's value.\n *\n * @param {*} [value]\n */\n function Chain (value) {\n if (!(this instanceof Chain)) {\n throw new SyntaxError('Constructor must be called with the new operator')\n }\n\n if (isChain(value)) {\n this.value = value.value\n } else {\n this.value = value\n }\n }\n\n /**\n * Attach type information\n */\n Chain.prototype.type = 'Chain'\n Chain.prototype.isChain = true\n\n /**\n * Close the chain. Returns the final value.\n * Does the same as method valueOf()\n * @returns {*} value\n */\n Chain.prototype.done = function () {\n return this.value\n }\n\n /**\n * Close the chain. Returns the final value.\n * Does the same as method done()\n * @returns {*} value\n */\n Chain.prototype.valueOf = function () {\n return this.value\n }\n\n /**\n * Get a string representation of the value in the chain\n * @returns {string}\n */\n Chain.prototype.toString = function () {\n return format(this.value)\n }\n\n /**\n * Get a JSON representation of the chain\n * @returns {Object}\n */\n Chain.prototype.toJSON = function () {\n return {\n mathjs: 'Chain',\n value: this.value\n }\n }\n\n /**\n * Instantiate a Chain from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"Chain\", value: ...}`,\n * where mathjs is optional\n * @returns {Chain}\n */\n Chain.fromJSON = function (json) {\n return new Chain(json.value)\n }\n\n /**\n * Create a proxy method for the chain\n * @param {string} name\n * @param {Function} fn The function to be proxied\n * If fn is no function, it is silently ignored.\n * @private\n */\n function createProxy (name, fn) {\n if (typeof fn === 'function') {\n Chain.prototype[name] = chainify(fn)\n }\n }\n\n /**\n * Create a proxy method for the chain\n * @param {string} name\n * @param {function} resolver The function resolving with the\n * function to be proxied\n * @private\n */\n function createLazyProxy (name, resolver) {\n lazy(Chain.prototype, name, function outerResolver () {\n const fn = resolver()\n if (typeof fn === 'function') {\n return chainify(fn)\n }\n\n return undefined // if not a function, ignore\n })\n }\n\n /**\n * Make a function chainable\n * @param {function} fn\n * @return {Function} chain function\n * @private\n */\n function chainify (fn) {\n return function () {\n // Here, `this` will be the context of a Chain instance\n if (arguments.length === 0) {\n return new Chain(fn(this.value))\n }\n const args = [this.value]\n for (let i = 0; i < arguments.length; i++) {\n args[i + 1] = arguments[i]\n }\n if (typed.isTypedFunction(fn)) {\n const sigObject = typed.resolve(fn, args)\n // We want to detect if a rest parameter has matched across the\n // value in the chain and the current arguments of this call.\n // That is the case if and only if the matching signature has\n // exactly one parameter (which then must be a rest parameter\n // as it is matching at least two actual arguments).\n if (sigObject.params.length === 1) {\n throw new Error('chain function ' + fn.name + ' cannot match rest parameter between chain value and additional arguments.')\n }\n return new Chain(sigObject.implementation.apply(fn, args))\n }\n return new Chain(fn.apply(fn, args))\n }\n }\n\n /**\n * Create a proxy for a single method, or an object with multiple methods.\n * Example usage:\n *\n * Chain.createProxy('add', function add (x, y) {...})\n * Chain.createProxy({\n * add: function add (x, y) {...},\n * subtract: function subtract (x, y) {...}\n * }\n *\n * @param {string | Object} arg0 A name (string), or an object with\n * functions\n * @param {*} [arg1] A function, when arg0 is a name\n */\n Chain.createProxy = function (arg0, arg1) {\n if (typeof arg0 === 'string') {\n // createProxy(name, value)\n createProxy(arg0, arg1)\n } else {\n // createProxy(values)\n for (const name in arg0) {\n if (hasOwnProperty(arg0, name) && excludedNames[name] === undefined) {\n createLazyProxy(name, () => arg0[name])\n }\n }\n }\n }\n\n const excludedNames = {\n expression: true,\n docs: true,\n type: true,\n classes: true,\n json: true,\n error: true,\n isChain: true // conflicts with the property isChain of a Chain instance\n }\n\n // create proxy for everything that is in math.js\n Chain.createProxy(math)\n\n // register on the import event, automatically add a proxy for every imported function.\n if (on) {\n on('import', function (name, resolver, path) {\n if (!path) {\n // an imported function (not a data type or something special)\n createLazyProxy(name, resolver)\n }\n })\n }\n\n return Chain\n}, { isClass: true })\n","export const eDocs = {\n name: 'e',\n category: 'Constants',\n syntax: [\n 'e'\n ],\n description: 'Euler\\'s number, the base of the natural logarithm. Approximately equal to 2.71828',\n examples: [\n 'e',\n 'e ^ 2',\n 'exp(2)',\n 'log(e)'\n ],\n seealso: ['exp']\n}\n","export const piDocs = {\n name: 'pi',\n category: 'Constants',\n syntax: [\n 'pi'\n ],\n description: 'The number pi is a mathematical constant that is the ratio of a circle\\'s circumference to its diameter, and is approximately equal to 3.14159',\n examples: [\n 'pi',\n 'sin(pi/2)'\n ],\n seealso: ['tau']\n}\n","import { eDocs } from './constants/e.js'\nimport { falseDocs } from './constants/false.js'\nimport { iDocs } from './constants/i.js'\nimport { InfinityDocs } from './constants/Infinity.js'\nimport { LN10Docs } from './constants/LN10.js'\nimport { LN2Docs } from './constants/LN2.js'\nimport { LOG10EDocs } from './constants/LOG10E.js'\nimport { LOG2EDocs } from './constants/LOG2E.js'\nimport { NaNDocs } from './constants/NaN.js'\nimport { nullDocs } from './constants/null.js'\nimport { phiDocs } from './constants/phi.js'\nimport { piDocs } from './constants/pi.js'\nimport { SQRT12Docs } from './constants/SQRT1_2.js'\nimport { SQRT2Docs } from './constants/SQRT2.js'\nimport { tauDocs } from './constants/tau.js'\nimport { trueDocs } from './constants/true.js'\nimport { versionDocs } from './constants/version.js'\nimport { bignumberDocs } from './construction/bignumber.js'\nimport { bigintDocs } from './construction/bigint.js'\nimport { booleanDocs } from './construction/boolean.js'\nimport { complexDocs } from './construction/complex.js'\nimport { createUnitDocs } from './construction/createUnit.js'\nimport { fractionDocs } from './construction/fraction.js'\nimport { indexDocs } from './construction/index.js'\nimport { matrixDocs } from './construction/matrix.js'\nimport { numberDocs } from './construction/number.js'\nimport { sparseDocs } from './construction/sparse.js'\nimport { splitUnitDocs } from './construction/splitUnit.js'\nimport { stringDocs } from './construction/string.js'\nimport { unitDocs } from './construction/unit.js'\nimport { configDocs } from './core/config.js'\nimport { importDocs } from './core/import.js'\nimport { typedDocs } from './core/typed.js'\nimport { derivativeDocs } from './function/algebra/derivative.js'\nimport { leafCountDocs } from './function/algebra/leafCount.js'\nimport { lsolveDocs } from './function/algebra/lsolve.js'\nimport { lsolveAllDocs } from './function/algebra/lsolveAll.js'\nimport { lupDocs } from './function/algebra/lup.js'\nimport { lusolveDocs } from './function/algebra/lusolve.js'\nimport { polynomialRootDocs } from './function/algebra/polynomialRoot.js'\nimport { qrDocs } from './function/algebra/qr.js'\nimport { rationalizeDocs } from './function/algebra/rationalize.js'\nimport { resolveDocs } from './function/algebra/resolve.js'\nimport { simplifyDocs } from './function/algebra/simplify.js'\nimport { simplifyConstantDocs } from './function/algebra/simplifyConstant.js'\nimport { simplifyCoreDocs } from './function/algebra/simplifyCore.js'\nimport { sluDocs } from './function/algebra/slu.js'\nimport { symbolicEqualDocs } from './function/algebra/symbolicEqual.js'\nimport { usolveDocs } from './function/algebra/usolve.js'\nimport { usolveAllDocs } from './function/algebra/usolveAll.js'\nimport { absDocs } from './function/arithmetic/abs.js'\nimport { addDocs } from './function/arithmetic/add.js'\nimport { cbrtDocs } from './function/arithmetic/cbrt.js'\nimport { ceilDocs } from './function/arithmetic/ceil.js'\nimport { cubeDocs } from './function/arithmetic/cube.js'\nimport { divideDocs } from './function/arithmetic/divide.js'\nimport { dotDivideDocs } from './function/arithmetic/dotDivide.js'\nimport { dotMultiplyDocs } from './function/arithmetic/dotMultiply.js'\nimport { dotPowDocs } from './function/arithmetic/dotPow.js'\nimport { expDocs } from './function/arithmetic/exp.js'\nimport { expmDocs } from './function/arithmetic/expm.js'\nimport { expm1Docs } from './function/arithmetic/expm1.js'\nimport { fixDocs } from './function/arithmetic/fix.js'\nimport { floorDocs } from './function/arithmetic/floor.js'\nimport { gcdDocs } from './function/arithmetic/gcd.js'\nimport { hypotDocs } from './function/arithmetic/hypot.js'\nimport { invmodDocs } from './function/arithmetic/invmod.js'\nimport { lcmDocs } from './function/arithmetic/lcm.js'\nimport { logDocs } from './function/arithmetic/log.js'\nimport { log10Docs } from './function/arithmetic/log10.js'\nimport { log1pDocs } from './function/arithmetic/log1p.js'\nimport { log2Docs } from './function/arithmetic/log2.js'\nimport { modDocs } from './function/arithmetic/mod.js'\nimport { multiplyDocs } from './function/arithmetic/multiply.js'\nimport { normDocs } from './function/arithmetic/norm.js'\nimport { nthRootDocs } from './function/arithmetic/nthRoot.js'\nimport { nthRootsDocs } from './function/arithmetic/nthRoots.js'\nimport { powDocs } from './function/arithmetic/pow.js'\nimport { roundDocs } from './function/arithmetic/round.js'\nimport { signDocs } from './function/arithmetic/sign.js'\nimport { sqrtDocs } from './function/arithmetic/sqrt.js'\nimport { sqrtmDocs } from './function/arithmetic/sqrtm.js'\nimport { sylvesterDocs } from './function/algebra/sylvester.js'\nimport { schurDocs } from './function/algebra/schur.js'\nimport { lyapDocs } from './function/algebra/lyap.js'\nimport { squareDocs } from './function/arithmetic/square.js'\nimport { subtractDocs } from './function/arithmetic/subtract.js'\nimport { unaryMinusDocs } from './function/arithmetic/unaryMinus.js'\nimport { unaryPlusDocs } from './function/arithmetic/unaryPlus.js'\nimport { xgcdDocs } from './function/arithmetic/xgcd.js'\nimport { bitAndDocs } from './function/bitwise/bitAnd.js'\nimport { bitNotDocs } from './function/bitwise/bitNot.js'\nimport { bitOrDocs } from './function/bitwise/bitOr.js'\nimport { bitXorDocs } from './function/bitwise/bitXor.js'\nimport { leftShiftDocs } from './function/bitwise/leftShift.js'\nimport { rightArithShiftDocs } from './function/bitwise/rightArithShift.js'\nimport { rightLogShiftDocs } from './function/bitwise/rightLogShift.js'\nimport { bellNumbersDocs } from './function/combinatorics/bellNumbers.js'\nimport { catalanDocs } from './function/combinatorics/catalan.js'\nimport { compositionDocs } from './function/combinatorics/composition.js'\nimport { stirlingS2Docs } from './function/combinatorics/stirlingS2.js'\nimport { argDocs } from './function/complex/arg.js'\nimport { conjDocs } from './function/complex/conj.js'\nimport { imDocs } from './function/complex/im.js'\nimport { reDocs } from './function/complex/re.js'\nimport { evaluateDocs } from './function/expression/evaluate.js'\nimport { helpDocs } from './function/expression/help.js'\nimport { distanceDocs } from './function/geometry/distance.js'\nimport { intersectDocs } from './function/geometry/intersect.js'\nimport { andDocs } from './function/logical/and.js'\nimport { notDocs } from './function/logical/not.js'\nimport { orDocs } from './function/logical/or.js'\nimport { xorDocs } from './function/logical/xor.js'\nimport { columnDocs } from './function/matrix/column.js'\nimport { concatDocs } from './function/matrix/concat.js'\nimport { countDocs } from './function/matrix/count.js'\nimport { crossDocs } from './function/matrix/cross.js'\nimport { ctransposeDocs } from './function/matrix/ctranspose.js'\nimport { detDocs } from './function/matrix/det.js'\nimport { diagDocs } from './function/matrix/diag.js'\nimport { diffDocs } from './function/matrix/diff.js'\nimport { dotDocs } from './function/matrix/dot.js'\nimport { eigsDocs } from './function/matrix/eigs.js'\nimport { filterDocs } from './function/matrix/filter.js'\nimport { flattenDocs } from './function/matrix/flatten.js'\nimport { forEachDocs } from './function/matrix/forEach.js'\nimport { getMatrixDataTypeDocs } from './function/matrix/getMatrixDataType.js'\nimport { identityDocs } from './function/matrix/identity.js'\nimport { invDocs } from './function/matrix/inv.js'\nimport { pinvDocs } from './function/matrix/pinv.js'\nimport { kronDocs } from './function/matrix/kron.js'\nimport { mapDocs } from './function/matrix/map.js'\nimport { matrixFromColumnsDocs } from './function/matrix/matrixFromColumns.js'\nimport { matrixFromFunctionDocs } from './function/matrix/matrixFromFunction.js'\nimport { matrixFromRowsDocs } from './function/matrix/matrixFromRows.js'\nimport { onesDocs } from './function/matrix/ones.js'\nimport { partitionSelectDocs } from './function/matrix/partitionSelect.js'\nimport { rangeDocs } from './function/matrix/range.js'\nimport { reshapeDocs } from './function/matrix/reshape.js'\nimport { resizeDocs } from './function/matrix/resize.js'\nimport { rotateDocs } from './function/matrix/rotate.js'\nimport { rotationMatrixDocs } from './function/matrix/rotationMatrix.js'\nimport { rowDocs } from './function/matrix/row.js'\nimport { sizeDocs } from './function/matrix/size.js'\nimport { sortDocs } from './function/matrix/sort.js'\nimport { squeezeDocs } from './function/matrix/squeeze.js'\nimport { subsetDocs } from './function/matrix/subset.js'\nimport { traceDocs } from './function/matrix/trace.js'\nimport { transposeDocs } from './function/matrix/transpose.js'\nimport { zerosDocs } from './function/matrix/zeros.js'\nimport { fftDocs } from './function/matrix/fft.js'\nimport { ifftDocs } from './function/matrix/ifft.js'\nimport { combinationsDocs } from './function/probability/combinations.js'\nimport { combinationsWithRepDocs } from './function/probability/combinationsWithRep.js'\nimport { factorialDocs } from './function/probability/factorial.js'\nimport { gammaDocs } from './function/probability/gamma.js'\nimport { lgammaDocs } from './function/probability/lgamma.js'\nimport { kldivergenceDocs } from './function/probability/kldivergence.js'\nimport { multinomialDocs } from './function/probability/multinomial.js'\nimport { permutationsDocs } from './function/probability/permutations.js'\nimport { pickRandomDocs } from './function/probability/pickRandom.js'\nimport { randomDocs } from './function/probability/random.js'\nimport { randomIntDocs } from './function/probability/randomInt.js'\nimport { compareDocs } from './function/relational/compare.js'\nimport { compareNaturalDocs } from './function/relational/compareNatural.js'\nimport { compareTextDocs } from './function/relational/compareText.js'\nimport { deepEqualDocs } from './function/relational/deepEqual.js'\nimport { equalDocs } from './function/relational/equal.js'\nimport { equalTextDocs } from './function/relational/equalText.js'\nimport { largerDocs } from './function/relational/larger.js'\nimport { largerEqDocs } from './function/relational/largerEq.js'\nimport { smallerDocs } from './function/relational/smaller.js'\nimport { smallerEqDocs } from './function/relational/smallerEq.js'\nimport { unequalDocs } from './function/relational/unequal.js'\nimport { setCartesianDocs } from './function/set/setCartesian.js'\nimport { setDifferenceDocs } from './function/set/setDifference.js'\nimport { setDistinctDocs } from './function/set/setDistinct.js'\nimport { setIntersectDocs } from './function/set/setIntersect.js'\nimport { setIsSubsetDocs } from './function/set/setIsSubset.js'\nimport { setMultiplicityDocs } from './function/set/setMultiplicity.js'\nimport { setPowersetDocs } from './function/set/setPowerset.js'\nimport { setSizeDocs } from './function/set/setSize.js'\nimport { setSymDifferenceDocs } from './function/set/setSymDifference.js'\nimport { setUnionDocs } from './function/set/setUnion.js'\nimport { zpk2tfDocs } from './function/signal/zpk2tf.js'\nimport { freqzDocs } from './function/signal/freqz.js'\nimport { erfDocs } from './function/special/erf.js'\nimport { zetaDocs } from './function/special/zeta.js'\nimport { madDocs } from './function/statistics/mad.js'\nimport { maxDocs } from './function/statistics/max.js'\nimport { meanDocs } from './function/statistics/mean.js'\nimport { medianDocs } from './function/statistics/median.js'\nimport { minDocs } from './function/statistics/min.js'\nimport { modeDocs } from './function/statistics/mode.js'\nimport { prodDocs } from './function/statistics/prod.js'\nimport { quantileSeqDocs } from './function/statistics/quantileSeq.js'\nimport { stdDocs } from './function/statistics/std.js'\nimport { cumSumDocs } from './function/statistics/cumsum.js'\nimport { sumDocs } from './function/statistics/sum.js'\nimport { varianceDocs } from './function/statistics/variance.js'\nimport { corrDocs } from './function/statistics/corr.js'\nimport { acosDocs } from './function/trigonometry/acos.js'\nimport { acoshDocs } from './function/trigonometry/acosh.js'\nimport { acotDocs } from './function/trigonometry/acot.js'\nimport { acothDocs } from './function/trigonometry/acoth.js'\nimport { acscDocs } from './function/trigonometry/acsc.js'\nimport { acschDocs } from './function/trigonometry/acsch.js'\nimport { asecDocs } from './function/trigonometry/asec.js'\nimport { asechDocs } from './function/trigonometry/asech.js'\nimport { asinDocs } from './function/trigonometry/asin.js'\nimport { asinhDocs } from './function/trigonometry/asinh.js'\nimport { atanDocs } from './function/trigonometry/atan.js'\nimport { atan2Docs } from './function/trigonometry/atan2.js'\nimport { atanhDocs } from './function/trigonometry/atanh.js'\nimport { cosDocs } from './function/trigonometry/cos.js'\nimport { coshDocs } from './function/trigonometry/cosh.js'\nimport { cotDocs } from './function/trigonometry/cot.js'\nimport { cothDocs } from './function/trigonometry/coth.js'\nimport { cscDocs } from './function/trigonometry/csc.js'\nimport { cschDocs } from './function/trigonometry/csch.js'\nimport { secDocs } from './function/trigonometry/sec.js'\nimport { sechDocs } from './function/trigonometry/sech.js'\nimport { sinDocs } from './function/trigonometry/sin.js'\nimport { sinhDocs } from './function/trigonometry/sinh.js'\nimport { tanDocs } from './function/trigonometry/tan.js'\nimport { tanhDocs } from './function/trigonometry/tanh.js'\nimport { toDocs } from './function/units/to.js'\nimport { binDocs } from './function/utils/bin.js'\nimport { cloneDocs } from './function/utils/clone.js'\nimport { formatDocs } from './function/utils/format.js'\nimport { hasNumericValueDocs } from './function/utils/hasNumericValue.js'\nimport { hexDocs } from './function/utils/hex.js'\nimport { isIntegerDocs } from './function/utils/isInteger.js'\nimport { isNaNDocs } from './function/utils/isNaN.js'\nimport { isNegativeDocs } from './function/utils/isNegative.js'\nimport { isNumericDocs } from './function/utils/isNumeric.js'\nimport { isPositiveDocs } from './function/utils/isPositive.js'\nimport { isPrimeDocs } from './function/utils/isPrime.js'\nimport { isZeroDocs } from './function/utils/isZero.js'\nimport { numericDocs } from './function/utils/numeric.js'\nimport { octDocs } from './function/utils/oct.js'\nimport { printDocs } from './function/utils/print.js'\nimport { typeOfDocs } from './function/utils/typeOf.js'\nimport { solveODEDocs } from './function/numeric/solveODE.js'\n\nexport const embeddedDocs = {\n\n // construction functions\n bignumber: bignumberDocs,\n bigint: bigintDocs,\n boolean: booleanDocs,\n complex: complexDocs,\n createUnit: createUnitDocs,\n fraction: fractionDocs,\n index: indexDocs,\n matrix: matrixDocs,\n number: numberDocs,\n sparse: sparseDocs,\n splitUnit: splitUnitDocs,\n string: stringDocs,\n unit: unitDocs,\n\n // constants\n e: eDocs,\n E: eDocs,\n false: falseDocs,\n i: iDocs,\n Infinity: InfinityDocs,\n LN2: LN2Docs,\n LN10: LN10Docs,\n LOG2E: LOG2EDocs,\n LOG10E: LOG10EDocs,\n NaN: NaNDocs,\n null: nullDocs,\n pi: piDocs,\n PI: piDocs,\n phi: phiDocs,\n SQRT1_2: SQRT12Docs,\n SQRT2: SQRT2Docs,\n tau: tauDocs,\n true: trueDocs,\n version: versionDocs,\n\n // physical constants\n // TODO: more detailed docs for physical constants\n speedOfLight: { description: 'Speed of light in vacuum', examples: ['speedOfLight'] },\n gravitationConstant: { description: 'Newtonian constant of gravitation', examples: ['gravitationConstant'] },\n planckConstant: { description: 'Planck constant', examples: ['planckConstant'] },\n reducedPlanckConstant: { description: 'Reduced Planck constant', examples: ['reducedPlanckConstant'] },\n\n magneticConstant: { description: 'Magnetic constant (vacuum permeability)', examples: ['magneticConstant'] },\n electricConstant: { description: 'Electric constant (vacuum permeability)', examples: ['electricConstant'] },\n vacuumImpedance: { description: 'Characteristic impedance of vacuum', examples: ['vacuumImpedance'] },\n coulomb: { description: 'Coulomb\\'s constant', examples: ['coulomb'] },\n elementaryCharge: { description: 'Elementary charge', examples: ['elementaryCharge'] },\n bohrMagneton: { description: 'Bohr magneton', examples: ['bohrMagneton'] },\n conductanceQuantum: { description: 'Conductance quantum', examples: ['conductanceQuantum'] },\n inverseConductanceQuantum: { description: 'Inverse conductance quantum', examples: ['inverseConductanceQuantum'] },\n // josephson: {description: 'Josephson constant', examples: ['josephson']},\n magneticFluxQuantum: { description: 'Magnetic flux quantum', examples: ['magneticFluxQuantum'] },\n nuclearMagneton: { description: 'Nuclear magneton', examples: ['nuclearMagneton'] },\n klitzing: { description: 'Von Klitzing constant', examples: ['klitzing'] },\n\n bohrRadius: { description: 'Bohr radius', examples: ['bohrRadius'] },\n classicalElectronRadius: { description: 'Classical electron radius', examples: ['classicalElectronRadius'] },\n electronMass: { description: 'Electron mass', examples: ['electronMass'] },\n fermiCoupling: { description: 'Fermi coupling constant', examples: ['fermiCoupling'] },\n fineStructure: { description: 'Fine-structure constant', examples: ['fineStructure'] },\n hartreeEnergy: { description: 'Hartree energy', examples: ['hartreeEnergy'] },\n protonMass: { description: 'Proton mass', examples: ['protonMass'] },\n deuteronMass: { description: 'Deuteron Mass', examples: ['deuteronMass'] },\n neutronMass: { description: 'Neutron mass', examples: ['neutronMass'] },\n quantumOfCirculation: { description: 'Quantum of circulation', examples: ['quantumOfCirculation'] },\n rydberg: { description: 'Rydberg constant', examples: ['rydberg'] },\n thomsonCrossSection: { description: 'Thomson cross section', examples: ['thomsonCrossSection'] },\n weakMixingAngle: { description: 'Weak mixing angle', examples: ['weakMixingAngle'] },\n efimovFactor: { description: 'Efimov factor', examples: ['efimovFactor'] },\n\n atomicMass: { description: 'Atomic mass constant', examples: ['atomicMass'] },\n avogadro: { description: 'Avogadro\\'s number', examples: ['avogadro'] },\n boltzmann: { description: 'Boltzmann constant', examples: ['boltzmann'] },\n faraday: { description: 'Faraday constant', examples: ['faraday'] },\n firstRadiation: { description: 'First radiation constant', examples: ['firstRadiation'] },\n loschmidt: { description: 'Loschmidt constant at T=273.15 K and p=101.325 kPa', examples: ['loschmidt'] },\n gasConstant: { description: 'Gas constant', examples: ['gasConstant'] },\n molarPlanckConstant: { description: 'Molar Planck constant', examples: ['molarPlanckConstant'] },\n molarVolume: { description: 'Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa', examples: ['molarVolume'] },\n sackurTetrode: { description: 'Sackur-Tetrode constant at T=1 K and p=101.325 kPa', examples: ['sackurTetrode'] },\n secondRadiation: { description: 'Second radiation constant', examples: ['secondRadiation'] },\n stefanBoltzmann: { description: 'Stefan-Boltzmann constant', examples: ['stefanBoltzmann'] },\n wienDisplacement: { description: 'Wien displacement law constant', examples: ['wienDisplacement'] },\n // spectralRadiance: {description: 'First radiation constant for spectral radiance', examples: ['spectralRadiance']},\n\n molarMass: { description: 'Molar mass constant', examples: ['molarMass'] },\n molarMassC12: { description: 'Molar mass constant of carbon-12', examples: ['molarMassC12'] },\n gravity: { description: 'Standard acceleration of gravity (standard acceleration of free-fall on Earth)', examples: ['gravity'] },\n\n planckLength: { description: 'Planck length', examples: ['planckLength'] },\n planckMass: { description: 'Planck mass', examples: ['planckMass'] },\n planckTime: { description: 'Planck time', examples: ['planckTime'] },\n planckCharge: { description: 'Planck charge', examples: ['planckCharge'] },\n planckTemperature: { description: 'Planck temperature', examples: ['planckTemperature'] },\n\n // functions - algebra\n derivative: derivativeDocs,\n lsolve: lsolveDocs,\n lsolveAll: lsolveAllDocs,\n lup: lupDocs,\n lusolve: lusolveDocs,\n leafCount: leafCountDocs,\n polynomialRoot: polynomialRootDocs,\n resolve: resolveDocs,\n simplify: simplifyDocs,\n simplifyConstant: simplifyConstantDocs,\n simplifyCore: simplifyCoreDocs,\n symbolicEqual: symbolicEqualDocs,\n rationalize: rationalizeDocs,\n slu: sluDocs,\n usolve: usolveDocs,\n usolveAll: usolveAllDocs,\n qr: qrDocs,\n\n // functions - arithmetic\n abs: absDocs,\n add: addDocs,\n cbrt: cbrtDocs,\n ceil: ceilDocs,\n cube: cubeDocs,\n divide: divideDocs,\n dotDivide: dotDivideDocs,\n dotMultiply: dotMultiplyDocs,\n dotPow: dotPowDocs,\n exp: expDocs,\n expm: expmDocs,\n expm1: expm1Docs,\n fix: fixDocs,\n floor: floorDocs,\n gcd: gcdDocs,\n hypot: hypotDocs,\n lcm: lcmDocs,\n log: logDocs,\n log2: log2Docs,\n log1p: log1pDocs,\n log10: log10Docs,\n mod: modDocs,\n multiply: multiplyDocs,\n norm: normDocs,\n nthRoot: nthRootDocs,\n nthRoots: nthRootsDocs,\n pow: powDocs,\n round: roundDocs,\n sign: signDocs,\n sqrt: sqrtDocs,\n sqrtm: sqrtmDocs,\n square: squareDocs,\n subtract: subtractDocs,\n unaryMinus: unaryMinusDocs,\n unaryPlus: unaryPlusDocs,\n xgcd: xgcdDocs,\n invmod: invmodDocs,\n\n // functions - bitwise\n bitAnd: bitAndDocs,\n bitNot: bitNotDocs,\n bitOr: bitOrDocs,\n bitXor: bitXorDocs,\n leftShift: leftShiftDocs,\n rightArithShift: rightArithShiftDocs,\n rightLogShift: rightLogShiftDocs,\n\n // functions - combinatorics\n bellNumbers: bellNumbersDocs,\n catalan: catalanDocs,\n composition: compositionDocs,\n stirlingS2: stirlingS2Docs,\n\n // functions - core\n config: configDocs,\n import: importDocs,\n typed: typedDocs,\n\n // functions - complex\n arg: argDocs,\n conj: conjDocs,\n re: reDocs,\n im: imDocs,\n\n // functions - expression\n evaluate: evaluateDocs,\n help: helpDocs,\n\n // functions - geometry\n distance: distanceDocs,\n intersect: intersectDocs,\n\n // functions - logical\n and: andDocs,\n not: notDocs,\n or: orDocs,\n xor: xorDocs,\n\n // functions - matrix\n concat: concatDocs,\n count: countDocs,\n cross: crossDocs,\n column: columnDocs,\n ctranspose: ctransposeDocs,\n det: detDocs,\n diag: diagDocs,\n diff: diffDocs,\n dot: dotDocs,\n getMatrixDataType: getMatrixDataTypeDocs,\n identity: identityDocs,\n filter: filterDocs,\n flatten: flattenDocs,\n forEach: forEachDocs,\n inv: invDocs,\n pinv: pinvDocs,\n eigs: eigsDocs,\n kron: kronDocs,\n matrixFromFunction: matrixFromFunctionDocs,\n matrixFromRows: matrixFromRowsDocs,\n matrixFromColumns: matrixFromColumnsDocs,\n map: mapDocs,\n ones: onesDocs,\n partitionSelect: partitionSelectDocs,\n range: rangeDocs,\n resize: resizeDocs,\n reshape: reshapeDocs,\n rotate: rotateDocs,\n rotationMatrix: rotationMatrixDocs,\n row: rowDocs,\n size: sizeDocs,\n sort: sortDocs,\n squeeze: squeezeDocs,\n subset: subsetDocs,\n trace: traceDocs,\n transpose: transposeDocs,\n zeros: zerosDocs,\n fft: fftDocs,\n ifft: ifftDocs,\n sylvester: sylvesterDocs,\n schur: schurDocs,\n lyap: lyapDocs,\n\n // functions - numeric\n solveODE: solveODEDocs,\n\n // functions - probability\n combinations: combinationsDocs,\n combinationsWithRep: combinationsWithRepDocs,\n // distribution: distributionDocs,\n factorial: factorialDocs,\n gamma: gammaDocs,\n kldivergence: kldivergenceDocs,\n lgamma: lgammaDocs,\n multinomial: multinomialDocs,\n permutations: permutationsDocs,\n pickRandom: pickRandomDocs,\n random: randomDocs,\n randomInt: randomIntDocs,\n\n // functions - relational\n compare: compareDocs,\n compareNatural: compareNaturalDocs,\n compareText: compareTextDocs,\n deepEqual: deepEqualDocs,\n equal: equalDocs,\n equalText: equalTextDocs,\n larger: largerDocs,\n largerEq: largerEqDocs,\n smaller: smallerDocs,\n smallerEq: smallerEqDocs,\n unequal: unequalDocs,\n\n // functions - set\n setCartesian: setCartesianDocs,\n setDifference: setDifferenceDocs,\n setDistinct: setDistinctDocs,\n setIntersect: setIntersectDocs,\n setIsSubset: setIsSubsetDocs,\n setMultiplicity: setMultiplicityDocs,\n setPowerset: setPowersetDocs,\n setSize: setSizeDocs,\n setSymDifference: setSymDifferenceDocs,\n setUnion: setUnionDocs,\n\n // functions - signal\n zpk2tf: zpk2tfDocs,\n freqz: freqzDocs,\n\n // functions - special\n erf: erfDocs,\n zeta: zetaDocs,\n\n // functions - statistics\n cumsum: cumSumDocs,\n mad: madDocs,\n max: maxDocs,\n mean: meanDocs,\n median: medianDocs,\n min: minDocs,\n mode: modeDocs,\n prod: prodDocs,\n quantileSeq: quantileSeqDocs,\n std: stdDocs,\n sum: sumDocs,\n variance: varianceDocs,\n corr: corrDocs,\n\n // functions - trigonometry\n acos: acosDocs,\n acosh: acoshDocs,\n acot: acotDocs,\n acoth: acothDocs,\n acsc: acscDocs,\n acsch: acschDocs,\n asec: asecDocs,\n asech: asechDocs,\n asin: asinDocs,\n asinh: asinhDocs,\n atan: atanDocs,\n atanh: atanhDocs,\n atan2: atan2Docs,\n cos: cosDocs,\n cosh: coshDocs,\n cot: cotDocs,\n coth: cothDocs,\n csc: cscDocs,\n csch: cschDocs,\n sec: secDocs,\n sech: sechDocs,\n sin: sinDocs,\n sinh: sinhDocs,\n tan: tanDocs,\n tanh: tanhDocs,\n\n // functions - units\n to: toDocs,\n\n // functions - utils\n clone: cloneDocs,\n format: formatDocs,\n bin: binDocs,\n oct: octDocs,\n hex: hexDocs,\n isNaN: isNaNDocs,\n isInteger: isIntegerDocs,\n isNegative: isNegativeDocs,\n isNumeric: isNumericDocs,\n hasNumericValue: hasNumericValueDocs,\n isPositive: isPositiveDocs,\n isPrime: isPrimeDocs,\n isZero: isZeroDocs,\n print: printDocs,\n typeOf: typeOfDocs,\n numeric: numericDocs\n}\n","export const bignumberDocs = {\n name: 'bignumber',\n category: 'Construction',\n syntax: [\n 'bignumber(x)'\n ],\n description:\n 'Create a big number from a number or string.',\n examples: [\n '0.1 + 0.2',\n 'bignumber(0.1) + bignumber(0.2)',\n 'bignumber(\"7.2\")',\n 'bignumber(\"7.2e500\")',\n 'bignumber([0.1, 0.2, 0.3])'\n ],\n seealso: [\n 'boolean', 'bigint', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n ]\n}\n","export const bigintDocs = {\n name: 'bigint',\n category: 'Construction',\n syntax: [\n 'bigint(x)'\n ],\n description:\n 'Create a bigint, an integer with an arbitrary number of digits, from a number or string.',\n examples: [\n '123123123123123123 # a large number will lose digits',\n 'bigint(\"123123123123123123\")',\n 'bignumber([\"1\", \"3\", \"5\"])'\n ],\n seealso: [\n 'boolean', 'bignumber', 'number', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n ]\n}\n","export const booleanDocs = {\n name: 'boolean',\n category: 'Construction',\n syntax: [\n 'x',\n 'boolean(x)'\n ],\n description:\n 'Convert a string or number into a boolean.',\n examples: [\n 'boolean(0)',\n 'boolean(1)',\n 'boolean(3)',\n 'boolean(\"true\")',\n 'boolean(\"false\")',\n 'boolean([1, 0, 1, 1])'\n ],\n seealso: [\n 'bignumber', 'complex', 'index', 'matrix', 'number', 'string', 'unit'\n ]\n}\n","export const complexDocs = {\n name: 'complex',\n category: 'Construction',\n syntax: [\n 'complex()',\n 'complex(re, im)',\n 'complex(string)'\n ],\n description:\n 'Create a complex number.',\n examples: [\n 'complex()',\n 'complex(2, 3)',\n 'complex(\"7 - 2i\")'\n ],\n seealso: [\n 'bignumber', 'boolean', 'index', 'matrix', 'number', 'string', 'unit'\n ]\n}\n","export const createUnitDocs = {\n name: 'createUnit',\n category: 'Construction',\n syntax: [\n 'createUnit(definitions)',\n 'createUnit(name, definition)'\n ],\n description:\n 'Create a user-defined unit and register it with the Unit type.',\n examples: [\n 'createUnit(\"foo\")',\n 'createUnit(\"knot\", {definition: \"0.514444444 m/s\", aliases: [\"knots\", \"kt\", \"kts\"]})',\n 'createUnit(\"mph\", \"1 mile/hour\")'\n ],\n seealso: [\n 'unit', 'splitUnit'\n ]\n}\n","export const fractionDocs = {\n name: 'fraction',\n category: 'Construction',\n syntax: [\n 'fraction(num)',\n 'fraction(matrix)',\n 'fraction(num,den)',\n 'fraction({n: num, d: den})'\n ],\n description:\n 'Create a fraction from a number or from integer numerator and denominator.',\n examples: [\n 'fraction(0.125)',\n 'fraction(1, 3) + fraction(2, 5)',\n 'fraction({n: 333, d: 53})',\n 'fraction([sqrt(9), sqrt(10), sqrt(11)])'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'index', 'matrix', 'string', 'unit'\n ]\n}\n","export const indexDocs = {\n name: 'index',\n category: 'Construction',\n syntax: [\n '[start]',\n '[start:end]',\n '[start:step:end]',\n '[start1, start 2, ...]',\n '[start1:end1, start2:end2, ...]',\n '[start1:step1:end1, start2:step2:end2, ...]'\n ],\n description:\n 'Create an index to get or replace a subset of a matrix',\n examples: [\n 'A = [1, 2, 3; 4, 5, 6]',\n 'A[1, :]',\n 'A[1, 2] = 50',\n 'A[1:2, 1:2] = 1',\n 'B = [1, 2, 3]',\n 'B[B>1 and B<3]'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'matrix,', 'number', 'range', 'string', 'unit'\n ]\n}\n","export const matrixDocs = {\n name: 'matrix',\n category: 'Construction',\n syntax: [\n '[]',\n '[a1, b1, ...; a2, b2, ...]',\n 'matrix()',\n 'matrix(\"dense\")',\n 'matrix([...])'\n ],\n description:\n 'Create a matrix.',\n examples: [\n '[]',\n '[1, 2, 3]',\n '[1, 2, 3; 4, 5, 6]',\n 'matrix()',\n 'matrix([3, 4])',\n 'matrix([3, 4; 5, 6], \"sparse\")',\n 'matrix([3, 4; 5, 6], \"sparse\", \"number\")'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'sparse'\n ]\n}\n","export const numberDocs = {\n name: 'number',\n category: 'Construction',\n syntax: [\n 'x',\n 'number(x)',\n 'number(unit, valuelessUnit)'\n ],\n description:\n 'Create a number or convert a string or boolean into a number.',\n examples: [\n '2',\n '2e3',\n '4.05',\n 'number(2)',\n 'number(\"7.2\")',\n 'number(true)',\n 'number([true, false, true, true])',\n 'number(unit(\"52cm\"), \"m\")'\n ],\n seealso: [\n 'bignumber', 'bigint', 'boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n ]\n}\n","export const sparseDocs = {\n name: 'sparse',\n category: 'Construction',\n syntax: [\n 'sparse()',\n 'sparse([a1, b1, ...; a1, b2, ...])',\n 'sparse([a1, b1, ...; a1, b2, ...], \"number\")'\n ],\n description:\n 'Create a sparse matrix.',\n examples: [\n 'sparse()',\n 'sparse([3, 4; 5, 6])',\n 'sparse([3, 0; 5, 0], \"number\")'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'matrix'\n ]\n}\n","export const splitUnitDocs = {\n name: 'splitUnit',\n category: 'Construction',\n syntax: [\n 'splitUnit(unit: Unit, parts: Unit[])'\n ],\n description:\n 'Split a unit in an array of units whose sum is equal to the original unit.',\n examples: [\n 'splitUnit(1 m, [\"feet\", \"inch\"])'\n ],\n seealso: [\n 'unit', 'createUnit'\n ]\n}\n","export const stringDocs = {\n name: 'string',\n category: 'Construction',\n syntax: [\n '\"text\"',\n 'string(x)'\n ],\n description:\n 'Create a string or convert a value to a string',\n examples: [\n '\"Hello World!\"',\n 'string(4.2)',\n 'string(3 + 2i)'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'unit'\n ]\n}\n","export const unitDocs = {\n name: 'unit',\n category: 'Construction',\n syntax: [\n 'value unit',\n 'unit(value, unit)',\n 'unit(string)'\n ],\n description:\n 'Create a unit.',\n examples: [\n '5.5 mm',\n '3 inch',\n 'unit(7.1, \"kilogram\")',\n 'unit(\"23 deg\")'\n ],\n seealso: [\n 'bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'string'\n ]\n}\n","export const falseDocs = {\n name: 'false',\n category: 'Constants',\n syntax: [\n 'false'\n ],\n description: 'Boolean value false',\n examples: [\n 'false'\n ],\n seealso: ['true']\n}\n","export const iDocs = {\n name: 'i',\n category: 'Constants',\n syntax: [\n 'i'\n ],\n description: 'Imaginary unit, defined as i*i=-1. A complex number is described as a + b*i, where a is the real part, and b is the imaginary part.',\n examples: [\n 'i',\n 'i * i',\n 'sqrt(-1)'\n ],\n seealso: []\n}\n","export const InfinityDocs = {\n name: 'Infinity',\n category: 'Constants',\n syntax: [\n 'Infinity'\n ],\n description: 'Infinity, a number which is larger than the maximum number that can be handled by a floating point number.',\n examples: [\n 'Infinity',\n '1 / 0'\n ],\n seealso: []\n}\n","export const LN2Docs = {\n name: 'LN2',\n category: 'Constants',\n syntax: [\n 'LN2'\n ],\n description: 'Returns the natural logarithm of 2, approximately equal to 0.693',\n examples: [\n 'LN2',\n 'log(2)'\n ],\n seealso: []\n}\n","export const LN10Docs = {\n name: 'LN10',\n category: 'Constants',\n syntax: [\n 'LN10'\n ],\n description: 'Returns the natural logarithm of 10, approximately equal to 2.302',\n examples: [\n 'LN10',\n 'log(10)'\n ],\n seealso: []\n}\n","export const LOG2EDocs = {\n name: 'LOG2E',\n category: 'Constants',\n syntax: [\n 'LOG2E'\n ],\n description: 'Returns the base-2 logarithm of E, approximately equal to 1.442',\n examples: [\n 'LOG2E',\n 'log(e, 2)'\n ],\n seealso: []\n}\n","export const LOG10EDocs = {\n name: 'LOG10E',\n category: 'Constants',\n syntax: [\n 'LOG10E'\n ],\n description: 'Returns the base-10 logarithm of E, approximately equal to 0.434',\n examples: [\n 'LOG10E',\n 'log(e, 10)'\n ],\n seealso: []\n}\n","export const NaNDocs = {\n name: 'NaN',\n category: 'Constants',\n syntax: [\n 'NaN'\n ],\n description: 'Not a number',\n examples: [\n 'NaN',\n '0 / 0'\n ],\n seealso: []\n}\n","export const nullDocs = {\n name: 'null',\n category: 'Constants',\n syntax: [\n 'null'\n ],\n description: 'Value null',\n examples: [\n 'null'\n ],\n seealso: ['true', 'false']\n}\n","export const phiDocs = {\n name: 'phi',\n category: 'Constants',\n syntax: [\n 'phi'\n ],\n description: 'Phi is the golden ratio. Two quantities are in the golden ratio if their ratio is the same as the ratio of their sum to the larger of the two quantities. Phi is defined as `(1 + sqrt(5)) / 2` and is approximately 1.618034...',\n examples: [\n 'phi'\n ],\n seealso: []\n}\n","export const SQRT12Docs = {\n name: 'SQRT1_2',\n category: 'Constants',\n syntax: [\n 'SQRT1_2'\n ],\n description: 'Returns the square root of 1/2, approximately equal to 0.707',\n examples: [\n 'SQRT1_2',\n 'sqrt(1/2)'\n ],\n seealso: []\n}\n","export const SQRT2Docs = {\n name: 'SQRT2',\n category: 'Constants',\n syntax: [\n 'SQRT2'\n ],\n description: 'Returns the square root of 2, approximately equal to 1.414',\n examples: [\n 'SQRT2',\n 'sqrt(2)'\n ],\n seealso: []\n}\n","export const tauDocs = {\n name: 'tau',\n category: 'Constants',\n syntax: [\n 'tau'\n ],\n description: 'Tau is the ratio constant of a circle\\'s circumference to radius, equal to 2 * pi, approximately 6.2832.',\n examples: [\n 'tau',\n '2 * pi'\n ],\n seealso: ['pi']\n}\n","export const trueDocs = {\n name: 'true',\n category: 'Constants',\n syntax: [\n 'true'\n ],\n description: 'Boolean value true',\n examples: [\n 'true'\n ],\n seealso: ['false']\n}\n","export const versionDocs = {\n name: 'version',\n category: 'Constants',\n syntax: [\n 'version'\n ],\n description: 'A string with the version number of math.js',\n examples: [\n 'version'\n ],\n seealso: []\n}\n","export const derivativeDocs = {\n name: 'derivative',\n category: 'Algebra',\n syntax: [\n 'derivative(expr, variable)',\n 'derivative(expr, variable, {simplify: boolean})'\n ],\n description: 'Takes the derivative of an expression expressed in parser Nodes. The derivative will be taken over the supplied variable in the second parameter. If there are multiple variables in the expression, it will return a partial derivative.',\n examples: [\n 'derivative(\"2x^3\", \"x\")',\n 'derivative(\"2x^3\", \"x\", {simplify: false})',\n 'derivative(\"2x^2 + 3x + 4\", \"x\")',\n 'derivative(\"sin(2x)\", \"x\")',\n 'f = parse(\"x^2 + x\")',\n 'x = parse(\"x\")',\n 'df = derivative(f, x)',\n 'df.evaluate({x: 3})'\n ],\n seealso: [\n 'simplify', 'parse', 'evaluate'\n ]\n}\n","export const lsolveDocs = {\n name: 'lsolve',\n category: 'Algebra',\n syntax: [\n 'x=lsolve(L, b)'\n ],\n description:\n 'Finds one solution of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.',\n examples: [\n 'a = [-2, 3; 2, 1]',\n 'b = [11, 9]',\n 'x = lsolve(a, b)'\n ],\n seealso: [\n 'lsolveAll', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'\n ]\n}\n","export const lsolveAllDocs = {\n name: 'lsolveAll',\n category: 'Algebra',\n syntax: [\n 'x=lsolveAll(L, b)'\n ],\n description:\n 'Finds all solutions of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.',\n examples: [\n 'a = [-2, 3; 2, 1]',\n 'b = [11, 9]',\n 'x = lsolve(a, b)'\n ],\n seealso: [\n 'lsolve', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'\n ]\n}\n","export const lupDocs = {\n name: 'lup',\n category: 'Algebra',\n syntax: [\n 'lup(m)'\n ],\n description:\n 'Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U',\n examples: [\n 'lup([[2, 1], [1, 4]])',\n 'lup(matrix([[2, 1], [1, 4]]))',\n 'lup(sparse([[2, 1], [1, 4]]))'\n ],\n seealso: [\n 'lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'slu', 'qr'\n ]\n}\n","export const lusolveDocs = {\n name: 'lusolve',\n category: 'Algebra',\n syntax: [\n 'x=lusolve(A, b)',\n 'x=lusolve(lu, b)'\n ],\n description: 'Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.',\n examples: [\n 'a = [-2, 3; 2, 1]',\n 'b = [11, 9]',\n 'x = lusolve(a, b)'\n ],\n seealso: [\n 'lup', 'slu', 'lsolve', 'usolve', 'matrix', 'sparse'\n ]\n}\n","export const leafCountDocs = {\n name: 'leafCount',\n category: 'Algebra',\n syntax: ['leafCount(expr)'],\n description: 'Computes the number of leaves in the parse tree of the given expression',\n examples: [\n 'leafCount(\"e^(i*pi)-1\")',\n 'leafCount(parse(\"{a: 22/7, b: 10^(1/2)}\"))'\n ],\n seealso: ['simplify']\n}\n","export const polynomialRootDocs = {\n name: 'polynomialRoot',\n category: 'Algebra',\n syntax: [\n 'x=polynomialRoot(-6, 3)',\n 'x=polynomialRoot(4, -4, 1)',\n 'x=polynomialRoot(-8, 12, -6, 1)'\n ],\n description: 'Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.',\n examples: [\n 'a = polynomialRoot(-6, 11, -6, 1)'\n ],\n seealso: [\n 'cbrt', 'sqrt'\n ]\n}\n","export const resolveDocs = {\n name: 'resolve',\n category: 'Algebra',\n syntax: [\n 'resolve(node, scope)'\n ],\n description: 'Recursively substitute variables in an expression tree.',\n examples: [\n 'resolve(parse(\"1 + x\"), { x: 7 })',\n 'resolve(parse(\"size(text)\"), { text: \"Hello World\" })',\n 'resolve(parse(\"x + y\"), { x: parse(\"3z\") })',\n 'resolve(parse(\"3x\"), { x: parse(\"y+z\"), z: parse(\"w^y\") })'\n ],\n seealso: [\n 'simplify', 'evaluate'\n ],\n mayThrow: [\n 'ReferenceError'\n ]\n}\n","export const simplifyDocs = {\n name: 'simplify',\n category: 'Algebra',\n syntax: [\n 'simplify(expr)',\n 'simplify(expr, rules)'\n ],\n description: 'Simplify an expression tree.',\n examples: [\n 'simplify(\"3 + 2 / 4\")',\n 'simplify(\"2x + x\")',\n 'f = parse(\"x * (x + 2 + x)\")',\n 'simplified = simplify(f)',\n 'simplified.evaluate({x: 2})'\n ],\n seealso: [\n 'simplifyCore', 'derivative', 'evaluate', 'parse', 'rationalize', 'resolve'\n ]\n}\n","export const simplifyConstantDocs = {\n name: 'simplifyConstant',\n category: 'Algebra',\n syntax: [\n 'simplifyConstant(expr)',\n 'simplifyConstant(expr, options)'\n ],\n description: 'Replace constant subexpressions of node with their values.',\n examples: [\n 'simplifyConstant(\"(3-3)*x\")',\n 'simplifyConstant(parse(\"z-cos(tau/8)\"))'\n ],\n seealso: [\n 'simplify', 'simplifyCore', 'evaluate'\n ]\n}\n","export const simplifyCoreDocs = {\n name: 'simplifyCore',\n category: 'Algebra',\n syntax: [\n 'simplifyCore(node)'\n ],\n description: 'Perform simple one-pass simplifications on an expression tree.',\n examples: [\n 'simplifyCore(parse(\"0*x\"))',\n 'simplifyCore(parse(\"(x+0)*2\"))'\n ],\n seealso: [\n 'simplify', 'simplifyConstant', 'evaluate'\n ]\n}\n","export const symbolicEqualDocs = {\n name: 'symbolicEqual',\n category: 'Algebra',\n syntax: [\n 'symbolicEqual(expr1, expr2)',\n 'symbolicEqual(expr1, expr2, options)'\n ],\n description: 'Returns true if the difference of the expressions simplifies to 0',\n examples: [\n 'symbolicEqual(\"x*y\",\"y*x\")',\n 'symbolicEqual(\"abs(x^2)\", \"x^2\")',\n 'symbolicEqual(\"abs(x)\", \"x\", {context: {abs: {trivial: true}}})'\n ],\n seealso: ['simplify', 'evaluate']\n}\n","export const rationalizeDocs = {\n name: 'rationalize',\n category: 'Algebra',\n syntax: [\n 'rationalize(expr)',\n 'rationalize(expr, scope)',\n 'rationalize(expr, scope, detailed)'\n ],\n description: 'Transform a rationalizable expression in a rational fraction. If rational fraction is one variable polynomial then converts the numerator and denominator in canonical form, with decreasing exponents, returning the coefficients of numerator.',\n examples: [\n 'rationalize(\"2x/y - y/(x+1)\")',\n 'rationalize(\"2x/y - y/(x+1)\", true)'\n ],\n seealso: [\n 'simplify'\n ]\n}\n","export const sluDocs = {\n name: 'slu',\n category: 'Algebra',\n syntax: [\n 'slu(A, order, threshold)'\n ],\n description: 'Calculate the Matrix LU decomposition with full pivoting. Matrix A is decomposed in two matrices (L, U) and two permutation vectors (pinv, q) where P * A * Q = L * U',\n examples: [\n 'slu(sparse([4.5, 0, 3.2, 0; 3.1, 2.9, 0, 0.9; 0, 1.7, 3, 0; 3.5, 0.4, 0, 1]), 1, 0.001)'\n ],\n seealso: [\n 'lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'lup', 'qr'\n ]\n}\n","export const usolveDocs = {\n name: 'usolve',\n category: 'Algebra',\n syntax: [\n 'x=usolve(U, b)'\n ],\n description:\n 'Finds one solution of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.',\n examples: [\n 'x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'\n ],\n seealso: [\n 'usolveAll', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'\n ]\n}\n","export const usolveAllDocs = {\n name: 'usolveAll',\n category: 'Algebra',\n syntax: [\n 'x=usolve(U, b)'\n ],\n description:\n 'Finds all solutions of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.',\n examples: [\n 'x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'\n ],\n seealso: [\n 'usolve', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'\n ]\n}\n","export const qrDocs = {\n name: 'qr',\n category: 'Algebra',\n syntax: [\n 'qr(A)'\n ],\n description:\n 'Calculates the Matrix QR decomposition. Matrix `A` is decomposed in two matrices (`Q`, `R`) where `Q` is an orthogonal matrix and `R` is an upper triangular matrix.',\n examples: [\n 'qr([[1, -1, 4], [1, 4, -2], [1, 4, 2], [1, -1, 0]])'\n ],\n seealso: [\n 'lup', 'slu', 'matrix'\n ]\n}\n","export const absDocs = {\n name: 'abs',\n category: 'Arithmetic',\n syntax: [\n 'abs(x)'\n ],\n description: 'Compute the absolute value.',\n examples: [\n 'abs(3.5)',\n 'abs(-4.2)'\n ],\n seealso: ['sign']\n}\n","export const addDocs = {\n name: 'add',\n category: 'Operators',\n syntax: [\n 'x + y',\n 'add(x, y)'\n ],\n description: 'Add two values.',\n examples: [\n 'a = 2.1 + 3.6',\n 'a - 3.6',\n '3 + 2i',\n '3 cm + 2 inch',\n '\"2.3\" + \"4\"'\n ],\n seealso: [\n 'subtract'\n ]\n}\n","export const cbrtDocs = {\n name: 'cbrt',\n category: 'Arithmetic',\n syntax: [\n 'cbrt(x)',\n 'cbrt(x, allRoots)'\n ],\n description:\n 'Compute the cubic root value. If x = y * y * y, then y is the cubic root of x. When `x` is a number or complex number, an optional second argument `allRoots` can be provided to return all three cubic roots. If not provided, the principal root is returned',\n examples: [\n 'cbrt(64)',\n 'cube(4)',\n 'cbrt(-8)',\n 'cbrt(2 + 3i)',\n 'cbrt(8i)',\n 'cbrt(8i, true)',\n 'cbrt(27 m^3)'\n ],\n seealso: [\n 'square',\n 'sqrt',\n 'cube',\n 'multiply'\n ]\n}\n","export const ceilDocs = {\n name: 'ceil',\n category: 'Arithmetic',\n syntax: [\n 'ceil(x)'\n ],\n description:\n 'Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.',\n examples: [\n 'ceil(3.2)',\n 'ceil(3.8)',\n 'ceil(-4.2)'\n ],\n seealso: ['floor', 'fix', 'round']\n}\n","export const cubeDocs = {\n name: 'cube',\n category: 'Arithmetic',\n syntax: [\n 'cube(x)'\n ],\n description: 'Compute the cube of a value. The cube of x is x * x * x.',\n examples: [\n 'cube(2)',\n '2^3',\n '2 * 2 * 2'\n ],\n seealso: [\n 'multiply',\n 'square',\n 'pow'\n ]\n}\n","export const divideDocs = {\n name: 'divide',\n category: 'Operators',\n syntax: [\n 'x / y',\n 'divide(x, y)'\n ],\n description: 'Divide two values.',\n examples: [\n 'a = 2 / 3',\n 'a * 3',\n '4.5 / 2',\n '3 + 4 / 2',\n '(3 + 4) / 2',\n '18 km / 4.5'\n ],\n seealso: [\n 'multiply'\n ]\n}\n","export const dotDivideDocs = {\n name: 'dotDivide',\n category: 'Operators',\n syntax: [\n 'x ./ y',\n 'dotDivide(x, y)'\n ],\n description: 'Divide two values element wise.',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'b = [2, 1, 1; 3, 2, 5]',\n 'a ./ b'\n ],\n seealso: [\n 'multiply',\n 'dotMultiply',\n 'divide'\n ]\n}\n","export const dotMultiplyDocs = {\n name: 'dotMultiply',\n category: 'Operators',\n syntax: [\n 'x .* y',\n 'dotMultiply(x, y)'\n ],\n description: 'Multiply two values element wise.',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'b = [2, 1, 1; 3, 2, 5]',\n 'a .* b'\n ],\n seealso: [\n 'multiply',\n 'divide',\n 'dotDivide'\n ]\n}\n","export const dotPowDocs = {\n name: 'dotPow',\n category: 'Operators',\n syntax: [\n 'x .^ y',\n 'dotPow(x, y)'\n ],\n description:\n 'Calculates the power of x to y element wise.',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'a .^ 2'\n ],\n seealso: [\n 'pow'\n ]\n}\n","export const expDocs = {\n name: 'exp',\n category: 'Arithmetic',\n syntax: [\n 'exp(x)'\n ],\n description: 'Calculate the exponent of a value.',\n examples: [\n 'exp(1.3)',\n 'e ^ 1.3',\n 'log(exp(1.3))',\n 'x = 2.4',\n '(exp(i*x) == cos(x) + i*sin(x)) # Euler\\'s formula'\n ],\n seealso: [\n 'expm',\n 'expm1',\n 'pow',\n 'log'\n ]\n}\n","export const expmDocs = {\n name: 'expm',\n category: 'Arithmetic',\n syntax: [\n 'exp(x)'\n ],\n description: 'Compute the matrix exponential, expm(A) = e^A. ' +\n 'The matrix must be square. ' +\n 'Not to be confused with exp(a), which performs element-wise exponentiation.',\n examples: [\n 'expm([[0,2],[0,0]])'\n ],\n seealso: [\n 'exp'\n ]\n}\n","export const expm1Docs = {\n name: 'expm1',\n category: 'Arithmetic',\n syntax: [\n 'expm1(x)'\n ],\n description: 'Calculate the value of subtracting 1 from the exponential value.',\n examples: [\n 'expm1(2)',\n 'pow(e, 2) - 1',\n 'log(expm1(2) + 1)'\n ],\n seealso: [\n 'exp',\n 'pow',\n 'log'\n ]\n}\n","export const fixDocs = {\n name: 'fix',\n category: 'Arithmetic',\n syntax: [\n 'fix(x)'\n ],\n description:\n 'Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.',\n examples: [\n 'fix(3.2)',\n 'fix(3.8)',\n 'fix(-4.2)',\n 'fix(-4.8)'\n ],\n seealso: ['ceil', 'floor', 'round']\n}\n","export const floorDocs = {\n name: 'floor',\n category: 'Arithmetic',\n syntax: [\n 'floor(x)'\n ],\n description:\n 'Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.',\n examples: [\n 'floor(3.2)',\n 'floor(3.8)',\n 'floor(-4.2)'\n ],\n seealso: ['ceil', 'fix', 'round']\n}\n","export const gcdDocs = {\n name: 'gcd',\n category: 'Arithmetic',\n syntax: [\n 'gcd(a, b)',\n 'gcd(a, b, c, ...)'\n ],\n description: 'Compute the greatest common divisor.',\n examples: [\n 'gcd(8, 12)',\n 'gcd(-4, 6)',\n 'gcd(25, 15, -10)'\n ],\n seealso: ['lcm', 'xgcd']\n}\n","export const hypotDocs = {\n name: 'hypot',\n category: 'Arithmetic',\n syntax: [\n 'hypot(a, b, c, ...)',\n 'hypot([a, b, c, ...])'\n ],\n description: 'Calculate the hypotenuse of a list with values.',\n examples: [\n 'hypot(3, 4)',\n 'sqrt(3^2 + 4^2)',\n 'hypot(-2)',\n 'hypot([3, 4, 5])'\n ],\n seealso: ['abs', 'norm']\n}\n","export const lcmDocs = {\n name: 'lcm',\n category: 'Arithmetic',\n syntax: [\n 'lcm(x, y)'\n ],\n description: 'Compute the least common multiple.',\n examples: [\n 'lcm(4, 6)',\n 'lcm(6, 21)',\n 'lcm(6, 21, 5)'\n ],\n seealso: ['gcd']\n}\n","export const logDocs = {\n name: 'log',\n category: 'Arithmetic',\n syntax: [\n 'log(x)',\n 'log(x, base)'\n ],\n description: 'Compute the logarithm of a value. If no base is provided, the natural logarithm of x is calculated. If base if provided, the logarithm is calculated for the specified base. log(x, base) is defined as log(x) / log(base).',\n examples: [\n 'log(3.5)',\n 'a = log(2.4)',\n 'exp(a)',\n '10 ^ 4',\n 'log(10000, 10)',\n 'log(10000) / log(10)',\n 'b = log(1024, 2)',\n '2 ^ b'\n ],\n seealso: [\n 'exp',\n 'log1p',\n 'log2',\n 'log10'\n ]\n}\n","export const log2Docs = {\n name: 'log2',\n category: 'Arithmetic',\n syntax: [\n 'log2(x)'\n ],\n description: 'Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.',\n examples: [\n 'log2(0.03125)',\n 'log2(16)',\n 'log2(16) / log2(2)',\n 'pow(2, 4)'\n ],\n seealso: [\n 'exp',\n 'log1p',\n 'log',\n 'log10'\n ]\n}\n","export const log1pDocs = {\n name: 'log1p',\n category: 'Arithmetic',\n syntax: [\n 'log1p(x)',\n 'log1p(x, base)'\n ],\n description: 'Calculate the logarithm of a `value+1`',\n examples: [\n 'log1p(2.5)',\n 'exp(log1p(1.4))',\n 'pow(10, 4)',\n 'log1p(9999, 10)',\n 'log1p(9999) / log(10)'\n ],\n seealso: [\n 'exp',\n 'log',\n 'log2',\n 'log10'\n ]\n}\n","export const log10Docs = {\n name: 'log10',\n category: 'Arithmetic',\n syntax: [\n 'log10(x)'\n ],\n description: 'Compute the 10-base logarithm of a value.',\n examples: [\n 'log10(0.00001)',\n 'log10(10000)',\n '10 ^ 4',\n 'log(10000) / log(10)',\n 'log(10000, 10)'\n ],\n seealso: [\n 'exp',\n 'log'\n ]\n}\n","export const modDocs = {\n name: 'mod',\n category: 'Operators',\n syntax: [\n 'x % y',\n 'x mod y',\n 'mod(x, y)'\n ],\n description:\n 'Calculates the modulus, the remainder of an integer division.',\n examples: [\n '7 % 3',\n '11 % 2',\n '10 mod 4',\n 'isOdd(x) = x % 2',\n 'isOdd(2)',\n 'isOdd(3)'\n ],\n seealso: ['divide']\n}\n","export const multiplyDocs = {\n name: 'multiply',\n category: 'Operators',\n syntax: [\n 'x * y',\n 'multiply(x, y)'\n ],\n description: 'multiply two values.',\n examples: [\n 'a = 2.1 * 3.4',\n 'a / 3.4',\n '2 * 3 + 4',\n '2 * (3 + 4)',\n '3 * 2.1 km'\n ],\n seealso: [\n 'divide'\n ]\n}\n","export const normDocs = {\n name: 'norm',\n category: 'Arithmetic',\n syntax: [\n 'norm(x)',\n 'norm(x, p)'\n ],\n description: 'Calculate the norm of a number, vector or matrix.',\n examples: [\n 'abs(-3.5)',\n 'norm(-3.5)',\n 'norm(3 - 4i)',\n 'norm([1, 2, -3], Infinity)',\n 'norm([1, 2, -3], -Infinity)',\n 'norm([3, 4], 2)',\n 'norm([[1, 2], [3, 4]], 1)',\n 'norm([[1, 2], [3, 4]], \"inf\")',\n 'norm([[1, 2], [3, 4]], \"fro\")'\n ]\n}\n","export const nthRootDocs = {\n name: 'nthRoot',\n category: 'Arithmetic',\n syntax: [\n 'nthRoot(a)',\n 'nthRoot(a, root)'\n ],\n description: 'Calculate the nth root of a value. ' +\n 'The principal nth root of a positive real number A, ' +\n 'is the positive real solution of the equation \"x^root = A\".',\n examples: [\n '4 ^ 3',\n 'nthRoot(64, 3)',\n 'nthRoot(9, 2)',\n 'sqrt(9)'\n ],\n seealso: [\n 'nthRoots',\n 'pow',\n 'sqrt'\n ]\n}\n","export const nthRootsDocs = {\n name: 'nthRoots',\n category: 'Arithmetic',\n syntax: [\n 'nthRoots(A)',\n 'nthRoots(A, root)'\n ],\n description: ('' +\n 'Calculate the nth roots of a value. ' +\n 'An nth root of a positive real number A, ' +\n 'is a positive real solution of the equation \"x^root = A\". ' +\n 'This function returns an array of complex values.'\n ),\n examples: [\n 'nthRoots(1)',\n 'nthRoots(1, 3)'\n ],\n seealso: [\n 'sqrt',\n 'pow',\n 'nthRoot'\n ]\n}\n","export const powDocs = {\n name: 'pow',\n category: 'Operators',\n syntax: [\n 'x ^ y',\n 'pow(x, y)'\n ],\n description:\n 'Calculates the power of x to y, x^y.',\n examples: [\n '2^3',\n '2*2*2',\n '1 + e ^ (pi * i)',\n 'pow([[1, 2], [4, 3]], 2)',\n 'pow([[1, 2], [4, 3]], -1)'\n ],\n seealso: [\n 'multiply',\n 'nthRoot',\n 'nthRoots',\n 'sqrt'\n ]\n}\n","export const roundDocs = {\n name: 'round',\n category: 'Arithmetic',\n syntax: [\n 'round(x)',\n 'round(x, n)',\n 'round(unit, valuelessUnit)',\n 'round(unit, n, valuelessUnit)'\n ],\n description:\n 'round a value towards the nearest integer.If x is complex, both real and imaginary part are rounded towards the nearest integer. When n is specified, the value is rounded to n decimals.',\n examples: [\n 'round(3.2)',\n 'round(3.8)',\n 'round(-4.2)',\n 'round(-4.8)',\n 'round(pi, 3)',\n 'round(123.45678, 2)',\n 'round(3.241cm, 2, cm)',\n 'round([3.2, 3.8, -4.7])'\n ],\n seealso: ['ceil', 'floor', 'fix']\n}\n","export const signDocs = {\n name: 'sign',\n category: 'Arithmetic',\n syntax: [\n 'sign(x)'\n ],\n description:\n 'Compute the sign of a value. The sign of a value x is 1 when x>1, -1 when x<0, and 0 when x=0.',\n examples: [\n 'sign(3.5)',\n 'sign(-4.2)',\n 'sign(0)'\n ],\n seealso: [\n 'abs'\n ]\n}\n","export const sqrtDocs = {\n name: 'sqrt',\n category: 'Arithmetic',\n syntax: [\n 'sqrt(x)'\n ],\n description:\n 'Compute the square root value. If x = y * y, then y is the square root of x.',\n examples: [\n 'sqrt(25)',\n '5 * 5',\n 'sqrt(-1)'\n ],\n seealso: [\n 'square',\n 'sqrtm',\n 'multiply',\n 'nthRoot',\n 'nthRoots',\n 'pow'\n ]\n}\n","export const sqrtmDocs = {\n name: 'sqrtm',\n category: 'Arithmetic',\n syntax: [\n 'sqrtm(x)'\n ],\n description:\n 'Calculate the principal square root of a square matrix. The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.',\n examples: [\n 'sqrtm([[33, 24], [48, 57]])'\n ],\n seealso: [\n 'sqrt',\n 'abs',\n 'square',\n 'multiply'\n ]\n}\n","export const squareDocs = {\n name: 'square',\n category: 'Arithmetic',\n syntax: [\n 'square(x)'\n ],\n description:\n 'Compute the square of a value. The square of x is x * x.',\n examples: [\n 'square(3)',\n 'sqrt(9)',\n '3^2',\n '3 * 3'\n ],\n seealso: [\n 'multiply',\n 'pow',\n 'sqrt',\n 'cube'\n ]\n}\n","export const subtractDocs = {\n name: 'subtract',\n category: 'Operators',\n syntax: [\n 'x - y',\n 'subtract(x, y)'\n ],\n description: 'subtract two values.',\n examples: [\n 'a = 5.3 - 2',\n 'a + 2',\n '2/3 - 1/6',\n '2 * 3 - 3',\n '2.1 km - 500m'\n ],\n seealso: [\n 'add'\n ]\n}\n","export const unaryMinusDocs = {\n name: 'unaryMinus',\n category: 'Operators',\n syntax: [\n '-x',\n 'unaryMinus(x)'\n ],\n description:\n 'Inverse the sign of a value. Converts booleans and strings to numbers.',\n examples: [\n '-4.5',\n '-(-5.6)',\n '-\"22\"'\n ],\n seealso: [\n 'add', 'subtract', 'unaryPlus'\n ]\n}\n","export const unaryPlusDocs = {\n name: 'unaryPlus',\n category: 'Operators',\n syntax: [\n '+x',\n 'unaryPlus(x)'\n ],\n description:\n 'Converts booleans and strings to numbers.',\n examples: [\n '+true',\n '+\"2\"'\n ],\n seealso: [\n 'add', 'subtract', 'unaryMinus'\n ]\n}\n","export const xgcdDocs = {\n name: 'xgcd',\n category: 'Arithmetic',\n syntax: [\n 'xgcd(a, b)'\n ],\n description: 'Calculate the extended greatest common divisor for two values. The result is an array [d, x, y] with 3 entries, where d is the greatest common divisor, and d = x * a + y * b.',\n examples: [\n 'xgcd(8, 12)',\n 'gcd(8, 12)',\n 'xgcd(36163, 21199)'\n ],\n seealso: ['gcd', 'lcm']\n}\n","export const invmodDocs = {\n name: 'invmod',\n category: 'Arithmetic',\n syntax: [\n 'invmod(a, b)'\n ],\n description: 'Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)',\n examples: [\n 'invmod(8, 12)',\n 'invmod(7, 13)',\n 'invmod(15151, 15122)'\n ],\n seealso: ['gcd', 'xgcd']\n}\n","export const bitAndDocs = {\n name: 'bitAnd',\n category: 'Bitwise',\n syntax: [\n 'x & y',\n 'bitAnd(x, y)'\n ],\n description: 'Bitwise AND operation. Performs the logical AND operation on each pair of the corresponding bits of the two given values by multiplying them. If both bits in the compared position are 1, the bit in the resulting binary representation is 1, otherwise, the result is 0',\n examples: [\n '5 & 3',\n 'bitAnd(53, 131)',\n '[1, 12, 31] & 42'\n ],\n seealso: [\n 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n ]\n}\n","export const bitNotDocs = {\n name: 'bitNot',\n category: 'Bitwise',\n syntax: [\n '~x',\n 'bitNot(x)'\n ],\n description: 'Bitwise NOT operation. Performs a logical negation on each bit of the given value. Bits that are 0 become 1, and those that are 1 become 0.',\n examples: [\n '~1',\n '~2',\n 'bitNot([2, -3, 4])'\n ],\n seealso: [\n 'bitAnd', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n ]\n}\n","export const bitOrDocs = {\n name: 'bitOr',\n category: 'Bitwise',\n syntax: [\n 'x | y',\n 'bitOr(x, y)'\n ],\n description: 'Bitwise OR operation. Performs the logical inclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if the first bit is 1 or the second bit is 1 or both bits are 1, otherwise, the result is 0.',\n examples: [\n '5 | 3',\n 'bitOr([1, 2, 3], 4)'\n ],\n seealso: [\n 'bitAnd', 'bitNot', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n ]\n}\n","export const bitXorDocs = {\n name: 'bitXor',\n category: 'Bitwise',\n syntax: [\n 'bitXor(x, y)'\n ],\n description: 'Bitwise XOR operation, exclusive OR. Performs the logical exclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if only the first bit is 1 or only the second bit is 1, but will be 0 if both are 0 or both are 1.',\n examples: [\n 'bitOr(1, 2)',\n 'bitXor([2, 3, 4], 4)'\n ],\n seealso: [\n 'bitAnd', 'bitNot', 'bitOr', 'leftShift', 'rightArithShift', 'rightLogShift'\n ]\n}\n","export const leftShiftDocs = {\n name: 'leftShift',\n category: 'Bitwise',\n syntax: [\n 'x << y',\n 'leftShift(x, y)'\n ],\n description: 'Bitwise left logical shift of a value x by y number of bits.',\n examples: [\n '4 << 1',\n '8 >> 1'\n ],\n seealso: [\n 'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'rightArithShift', 'rightLogShift'\n ]\n}\n","export const rightArithShiftDocs = {\n name: 'rightArithShift',\n category: 'Bitwise',\n syntax: [\n 'x >> y',\n 'rightArithShift(x, y)'\n ],\n description: 'Bitwise right arithmetic shift of a value x by y number of bits.',\n examples: [\n '8 >> 1',\n '4 << 1',\n '-12 >> 2'\n ],\n seealso: [\n 'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightLogShift'\n ]\n}\n","export const rightLogShiftDocs = {\n name: 'rightLogShift',\n category: 'Bitwise',\n syntax: [\n 'x >>> y',\n 'rightLogShift(x, y)'\n ],\n description: 'Bitwise right logical shift of a value x by y number of bits.',\n examples: [\n '8 >>> 1',\n '4 << 1',\n '-12 >>> 2'\n ],\n seealso: [\n 'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift'\n ]\n}\n","export const bellNumbersDocs = {\n name: 'bellNumbers',\n category: 'Combinatorics',\n syntax: [\n 'bellNumbers(n)'\n ],\n description: 'The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. `bellNumbers` only takes integer arguments. The following condition must be enforced: n >= 0.',\n examples: [\n 'bellNumbers(3)',\n 'bellNumbers(8)'\n ],\n seealso: ['stirlingS2']\n}\n","export const catalanDocs = {\n name: 'catalan',\n category: 'Combinatorics',\n syntax: [\n 'catalan(n)'\n ],\n description: 'The Catalan Numbers enumerate combinatorial structures of many different types. catalan only takes integer arguments. The following condition must be enforced: n >= 0.',\n examples: [\n 'catalan(3)',\n 'catalan(8)'\n ],\n seealso: ['bellNumbers']\n}\n","export const compositionDocs = {\n name: 'composition',\n category: 'Combinatorics',\n syntax: [\n 'composition(n, k)'\n ],\n description: 'The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.',\n examples: [\n 'composition(5, 3)'\n ],\n seealso: ['combinations']\n}\n","export const stirlingS2Docs = {\n name: 'stirlingS2',\n category: 'Combinatorics',\n syntax: [\n 'stirlingS2(n, k)'\n ],\n description: 'he Stirling numbers of the second kind, counts the number of ways to partition a set of n labelled objects into k nonempty unlabelled subsets. `stirlingS2` only takes integer arguments. The following condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = 1.',\n examples: [\n 'stirlingS2(5, 3)'\n ],\n seealso: ['bellNumbers']\n}\n","export const configDocs = {\n name: 'config',\n category: 'Core',\n syntax: [\n 'config()',\n 'config(options)'\n ],\n description: 'Get configuration or change configuration.',\n examples: [\n 'config()',\n '1/3 + 1/4',\n 'config({number: \"Fraction\"})',\n '1/3 + 1/4'\n ],\n seealso: []\n}\n","export const importDocs = {\n name: 'import',\n category: 'Core',\n syntax: [\n 'import(functions)',\n 'import(functions, options)'\n ],\n description: 'Import functions or constants from an object.',\n examples: [\n 'import({myFn: f(x)=x^2, myConstant: 32 })',\n 'myFn(2)',\n 'myConstant'\n ],\n seealso: []\n}\n","export const typedDocs = {\n name: 'typed',\n category: 'Core',\n syntax: [\n 'typed(signatures)',\n 'typed(name, signatures)'\n ],\n description: 'Create a typed function.',\n examples: [\n 'double = typed({ \"number\": f(x)=x+x, \"string\": f(x)=concat(x,x) })',\n 'double(2)',\n 'double(\"hello\")'\n ],\n seealso: []\n}\n","export const argDocs = {\n name: 'arg',\n category: 'Complex',\n syntax: [\n 'arg(x)'\n ],\n description:\n 'Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).',\n examples: [\n 'arg(2 + 2i)',\n 'atan2(3, 2)',\n 'arg(2 + 3i)'\n ],\n seealso: [\n 're',\n 'im',\n 'conj',\n 'abs'\n ]\n}\n","export const conjDocs = {\n name: 'conj',\n category: 'Complex',\n syntax: [\n 'conj(x)'\n ],\n description:\n 'Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.',\n examples: [\n 'conj(2 + 3i)',\n 'conj(2 - 3i)',\n 'conj(-5.2i)'\n ],\n seealso: [\n 're',\n 'im',\n 'abs',\n 'arg'\n ]\n}\n","export const reDocs = {\n name: 're',\n category: 'Complex',\n syntax: [\n 're(x)'\n ],\n description: 'Get the real part of a complex number.',\n examples: [\n 're(2 + 3i)',\n 'im(2 + 3i)',\n 're(-5.2i)',\n 're(2.4)'\n ],\n seealso: [\n 'im',\n 'conj',\n 'abs',\n 'arg'\n ]\n}\n","export const imDocs = {\n name: 'im',\n category: 'Complex',\n syntax: [\n 'im(x)'\n ],\n description: 'Get the imaginary part of a complex number.',\n examples: [\n 'im(2 + 3i)',\n 're(2 + 3i)',\n 'im(-5.2i)',\n 'im(2.4)'\n ],\n seealso: [\n 're',\n 'conj',\n 'abs',\n 'arg'\n ]\n}\n","export const evaluateDocs = {\n name: 'evaluate',\n category: 'Expression',\n syntax: [\n 'evaluate(expression)',\n 'evaluate(expression, scope)',\n 'evaluate([expr1, expr2, expr3, ...])',\n 'evaluate([expr1, expr2, expr3, ...], scope)'\n ],\n description: 'Evaluate an expression or an array with expressions.',\n examples: [\n 'evaluate(\"2 + 3\")',\n 'evaluate(\"sqrt(16)\")',\n 'evaluate(\"2 inch to cm\")',\n 'evaluate(\"sin(x * pi)\", { \"x\": 1/2 })',\n 'evaluate([\"width=2\", \"height=4\",\"width*height\"])'\n ],\n seealso: []\n}\n","export const helpDocs = {\n name: 'help',\n category: 'Expression',\n syntax: [\n 'help(object)',\n 'help(string)'\n ],\n description: 'Display documentation on a function or data type.',\n examples: [\n 'help(sqrt)',\n 'help(\"complex\")'\n ],\n seealso: []\n}\n","export const distanceDocs = {\n name: 'distance',\n category: 'Geometry',\n syntax: [\n 'distance([x1, y1], [x2, y2])',\n 'distance([[x1, y1], [x2, y2]])'\n ],\n description: 'Calculates the Euclidean distance between two points.',\n examples: [\n 'distance([0,0], [4,4])',\n 'distance([[0,0], [4,4]])'\n ],\n seealso: []\n}\n","export const intersectDocs = {\n name: 'intersect',\n category: 'Geometry',\n syntax: [\n 'intersect(expr1, expr2, expr3, expr4)',\n 'intersect(expr1, expr2, expr3)'\n ],\n description: 'Computes the intersection point of lines and/or planes.',\n examples: [\n 'intersect([0, 0], [10, 10], [10, 0], [0, 10])',\n 'intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6])'\n ],\n seealso: []\n}\n","export const andDocs = {\n name: 'and',\n category: 'Logical',\n syntax: [\n 'x and y',\n 'and(x, y)'\n ],\n description: 'Logical and. Test whether two values are both defined with a nonzero/nonempty value.',\n examples: [\n 'true and false',\n 'true and true',\n '2 and 4'\n ],\n seealso: [\n 'not', 'or', 'xor'\n ]\n}\n","export const notDocs = {\n name: 'not',\n category: 'Logical',\n syntax: [\n 'not x',\n 'not(x)'\n ],\n description: 'Logical not. Flips the boolean value of given argument.',\n examples: [\n 'not true',\n 'not false',\n 'not 2',\n 'not 0'\n ],\n seealso: [\n 'and', 'or', 'xor'\n ]\n}\n","export const orDocs = {\n name: 'or',\n category: 'Logical',\n syntax: [\n 'x or y',\n 'or(x, y)'\n ],\n description: 'Logical or. Test if at least one value is defined with a nonzero/nonempty value.',\n examples: [\n 'true or false',\n 'false or false',\n '0 or 4'\n ],\n seealso: [\n 'not', 'and', 'xor'\n ]\n}\n","export const xorDocs = {\n name: 'xor',\n category: 'Logical',\n syntax: [\n 'x xor y',\n 'xor(x, y)'\n ],\n description: 'Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.',\n examples: [\n 'true xor false',\n 'false xor false',\n 'true xor true',\n '0 xor 4'\n ],\n seealso: [\n 'not', 'and', 'or'\n ]\n}\n","export const concatDocs = {\n name: 'concat',\n category: 'Matrix',\n syntax: [\n 'concat(A, B, C, ...)',\n 'concat(A, B, C, ..., dim)'\n ],\n description: 'Concatenate matrices. By default, the matrices are concatenated by the last dimension. The dimension on which to concatenate can be provided as last argument.',\n examples: [\n 'A = [1, 2; 5, 6]',\n 'B = [3, 4; 7, 8]',\n 'concat(A, B)',\n 'concat(A, B, 1)',\n 'concat(A, B, 2)'\n ],\n seealso: [\n 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const countDocs = {\n name: 'count',\n category: 'Matrix',\n syntax: [\n 'count(x)'\n ],\n description: 'Count the number of elements of a matrix, array or string.',\n examples: [\n 'a = [1, 2; 3, 4; 5, 6]',\n 'count(a)',\n 'size(a)',\n 'count(\"hello world\")'\n ],\n seealso: [\n 'size'\n ]\n}\n","export const crossDocs = {\n name: 'cross',\n category: 'Matrix',\n syntax: [\n 'cross(A, B)'\n ],\n description: 'Calculate the cross product for two vectors in three dimensional space.',\n examples: [\n 'cross([1, 1, 0], [0, 1, 1])',\n 'cross([3, -3, 1], [4, 9, 2])',\n 'cross([2, 3, 4], [5, 6, 7])'\n ],\n seealso: [\n 'multiply',\n 'dot'\n ]\n}\n","export const columnDocs = {\n name: 'column',\n category: 'Matrix',\n syntax: [\n 'column(x, index)'\n ],\n description: 'Return a column from a matrix or array.',\n examples: [\n 'A = [[1, 2], [3, 4]]',\n 'column(A, 1)',\n 'column(A, 2)'\n ],\n seealso: ['row', 'matrixFromColumns']\n}\n","export const ctransposeDocs = {\n name: 'ctranspose',\n category: 'Matrix',\n syntax: [\n 'x\\'',\n 'ctranspose(x)'\n ],\n description: 'Complex Conjugate and Transpose a matrix',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'a\\'',\n 'ctranspose(a)'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'\n ]\n}\n","export const detDocs = {\n name: 'det',\n category: 'Matrix',\n syntax: [\n 'det(x)'\n ],\n description: 'Calculate the determinant of a matrix',\n examples: [\n 'det([1, 2; 3, 4])',\n 'det([-2, 2, 3; -1, 1, 3; 2, 0, -1])'\n ],\n seealso: [\n 'concat', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const diagDocs = {\n name: 'diag',\n category: 'Matrix',\n syntax: [\n 'diag(x)',\n 'diag(x, k)'\n ],\n description: 'Create a diagonal matrix or retrieve the diagonal of a matrix. When x is a vector, a matrix with the vector values on the diagonal will be returned. When x is a matrix, a vector with the diagonal values of the matrix is returned. When k is provided, the k-th diagonal will be filled in or retrieved, if k is positive, the values are placed on the super diagonal. When k is negative, the values are placed on the sub diagonal.',\n examples: [\n 'diag(1:3)',\n 'diag(1:3, 1)',\n 'a = [1, 2, 3; 4, 5, 6; 7, 8, 9]',\n 'diag(a)'\n ],\n seealso: [\n 'concat', 'det', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const diffDocs = {\n name: 'diff',\n category: 'Matrix',\n syntax: [\n 'diff(arr)',\n 'diff(arr, dim)'\n ],\n description: [\n 'Create a new matrix or array with the difference of the passed matrix or array.',\n 'Dim parameter is optional and used to indicate the dimension of the array/matrix to apply the difference',\n 'If no dimension parameter is passed it is assumed as dimension 0',\n 'Dimension is zero-based in javascript and one-based in the parser',\n 'Arrays must be \\'rectangular\\' meaning arrays like [1, 2]',\n 'If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays'\n ],\n examples: [\n 'A = [1, 2, 4, 7, 0]',\n 'diff(A)',\n 'diff(A, 1)',\n 'B = [[1, 2], [3, 4]]',\n 'diff(B)',\n 'diff(B, 1)',\n 'diff(B, 2)',\n 'diff(B, bignumber(2))',\n 'diff([[1, 2], matrix([3, 4])], 2)'\n ],\n seealso: ['subtract', 'partitionSelect']\n}\n","export const dotDocs = {\n name: 'dot',\n category: 'Matrix',\n syntax: [\n 'dot(A, B)',\n 'A * B'\n ],\n description: 'Calculate the dot product of two vectors. ' +\n 'The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] ' +\n 'is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn',\n examples: [\n 'dot([2, 4, 1], [2, 2, 3])',\n '[2, 4, 1] * [2, 2, 3]'\n ],\n seealso: [\n 'multiply',\n 'cross'\n ]\n}\n","export const getMatrixDataTypeDocs = {\n name: 'getMatrixDataType',\n category: 'Matrix',\n syntax: [\n 'getMatrixDataType(x)'\n ],\n description: 'Find the data type of all elements in a matrix or array, ' +\n 'for example \"number\" if all items are a number ' +\n 'and \"Complex\" if all values are complex numbers. ' +\n 'If a matrix contains more than one data type, it will return \"mixed\".',\n examples: [\n 'getMatrixDataType([1, 2, 3])',\n 'getMatrixDataType([[5 cm], [2 inch]])',\n 'getMatrixDataType([1, \"text\"])',\n 'getMatrixDataType([1, bignumber(4)])'\n ],\n seealso: ['matrix', 'sparse', 'typeOf']\n}\n","export const identityDocs = {\n name: 'identity',\n category: 'Matrix',\n syntax: [\n 'identity(n)',\n 'identity(m, n)',\n 'identity([m, n])'\n ],\n description: 'Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.',\n examples: [\n 'identity(3)',\n 'identity(3, 5)',\n 'a = [1, 2, 3; 4, 5, 6]',\n 'identity(size(a))'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const filterDocs = {\n name: 'filter',\n category: 'Matrix',\n syntax: [\n 'filter(x, test)'\n ],\n description: 'Filter items in a matrix.',\n examples: [\n 'isPositive(x) = x > 0',\n 'filter([6, -2, -1, 4, 3], isPositive)',\n 'filter([6, -2, 0, 1, 0], x != 0)'\n ],\n seealso: ['sort', 'map', 'forEach']\n}\n","export const flattenDocs = {\n name: 'flatten',\n category: 'Matrix',\n syntax: [\n 'flatten(x)'\n ],\n description: 'Flatten a multi dimensional matrix into a single dimensional matrix.',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'size(a)',\n 'b = flatten(a)',\n 'size(b)'\n ],\n seealso: [\n 'concat', 'resize', 'size', 'squeeze'\n ]\n}\n","export const forEachDocs = {\n name: 'forEach',\n category: 'Matrix',\n syntax: [\n 'forEach(x, callback)'\n ],\n description: 'Iterates over all elements of a matrix/array, and executes the given callback function.',\n examples: [\n 'numberOfPets = {}',\n 'addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;',\n 'forEach([\"Dog\",\"Cat\",\"Cat\"], addPet)',\n 'numberOfPets'\n ],\n seealso: ['map', 'sort', 'filter']\n}\n","export const invDocs = {\n name: 'inv',\n category: 'Matrix',\n syntax: [\n 'inv(x)'\n ],\n description: 'Calculate the inverse of a matrix',\n examples: [\n 'inv([1, 2; 3, 4])',\n 'inv(4)',\n '1 / 4'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const pinvDocs = {\n name: 'pinv',\n category: 'Matrix',\n syntax: [\n 'pinv(x)'\n ],\n description: 'Calculate the Moore–Penrose inverse of a matrix',\n examples: [\n 'pinv([1, 2; 3, 4])',\n 'pinv([[1, 0], [0, 1], [0, 1]])',\n 'pinv(4)'\n ],\n seealso: [\n 'inv'\n ]\n}\n","export const eigsDocs = {\n name: 'eigs',\n category: 'Matrix',\n syntax: [\n 'eigs(x)'\n ],\n description: 'Calculate the eigenvalues and optionally eigenvectors of a square matrix',\n examples: [\n 'eigs([[5, 2.3], [2.3, 1]])',\n 'eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })'\n ],\n seealso: [\n 'inv'\n ]\n}\n","export const kronDocs = {\n name: 'kron',\n category: 'Matrix',\n syntax: [\n 'kron(x, y)'\n ],\n description: 'Calculates the Kronecker product of 2 matrices or vectors.',\n examples: [\n 'kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])',\n 'kron([1,1], [2,3,4])'\n ],\n seealso: [\n 'multiply', 'dot', 'cross'\n ]\n}\n","export const matrixFromFunctionDocs = {\n name: 'matrixFromFunction',\n category: 'Matrix',\n syntax: [\n 'matrixFromFunction(size, fn)',\n 'matrixFromFunction(size, fn, format)',\n 'matrixFromFunction(size, fn, format, datatype)',\n 'matrixFromFunction(size, format, fn)',\n 'matrixFromFunction(size, format, datatype, fn)'\n ],\n description: 'Create a matrix by evaluating a generating function at each index.',\n examples: [\n 'f(I) = I[1] - I[2]',\n 'matrixFromFunction([3,3], f)',\n 'g(I) = I[1] - I[2] == 1 ? 4 : 0',\n 'matrixFromFunction([100, 100], \"sparse\", g)',\n 'matrixFromFunction([5], random)'\n ],\n seealso: [\n 'matrix', 'matrixFromRows', 'matrixFromColumns', 'zeros'\n ]\n}\n","export const matrixFromRowsDocs = {\n name: 'matrixFromRows',\n category: 'Matrix',\n syntax: [\n 'matrixFromRows(...arr)',\n 'matrixFromRows(row1, row2)',\n 'matrixFromRows(row1, row2, row3)'\n ],\n description: 'Create a dense matrix from vectors as individual rows.',\n examples: [\n 'matrixFromRows([1, 2, 3], [[4],[5],[6]])'\n ],\n seealso: [\n 'matrix', 'matrixFromColumns', 'matrixFromFunction', 'zeros'\n ]\n}\n","export const matrixFromColumnsDocs = {\n name: 'matrixFromColumns',\n category: 'Matrix',\n syntax: [\n 'matrixFromColumns(...arr)',\n 'matrixFromColumns(row1, row2)',\n 'matrixFromColumns(row1, row2, row3)'\n ],\n description: 'Create a dense matrix from vectors as individual columns.',\n examples: [\n 'matrixFromColumns([1, 2, 3], [[4],[5],[6]])'\n ],\n seealso: [\n 'matrix', 'matrixFromRows', 'matrixFromFunction', 'zeros'\n ]\n}\n","export const mapDocs = {\n name: 'map',\n category: 'Matrix',\n syntax: [\n 'map(x, callback)',\n 'map(x, y, ..., callback)'\n ],\n description: 'Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array or the matrices/arrays.',\n examples: [\n 'map([1, 2, 3], square)',\n 'map([1, 2], [3, 4], f(a,b) = a + b)'\n ],\n seealso: ['filter', 'forEach']\n}\n","export const onesDocs = {\n name: 'ones',\n category: 'Matrix',\n syntax: [\n 'ones(m)',\n 'ones(m, n)',\n 'ones(m, n, p, ...)',\n 'ones([m])',\n 'ones([m, n])',\n 'ones([m, n, p, ...])'\n ],\n description: 'Create a matrix containing ones.',\n examples: [\n 'ones(3)',\n 'ones(3, 5)',\n 'ones([2,3]) * 4.5',\n 'a = [1, 2, 3; 4, 5, 6]',\n 'ones(size(a))'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const partitionSelectDocs = {\n name: 'partitionSelect',\n category: 'Matrix',\n syntax: [\n 'partitionSelect(x, k)',\n 'partitionSelect(x, k, compare)'\n ],\n description: 'Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.',\n examples: [\n 'partitionSelect([5, 10, 1], 2)',\n 'partitionSelect([\"C\", \"B\", \"A\", \"D\"], 1, compareText)',\n 'arr = [5, 2, 1]',\n 'partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]',\n 'arr',\n 'partitionSelect(arr, 1, \\'desc\\') # returns 2, arr is now: [5, 2, 1]',\n 'arr'\n ],\n seealso: ['sort']\n}\n","export const rangeDocs = {\n name: 'range',\n category: 'Type',\n syntax: [\n 'start:end',\n 'start:step:end',\n 'range(start, end)',\n 'range(start, end, step)',\n 'range(string)'\n ],\n description:\n 'Create a range. Lower bound of the range is included, upper bound is excluded.',\n examples: [\n '1:5',\n '3:-1:-3',\n 'range(3, 7)',\n 'range(0, 12, 2)',\n 'range(\"4:10\")',\n 'range(1m, 1m, 3m)',\n 'a = [1, 2, 3, 4; 5, 6, 7, 8]',\n 'a[1:2, 1:2]'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const resizeDocs = {\n name: 'resize',\n category: 'Matrix',\n syntax: [\n 'resize(x, size)',\n 'resize(x, size, defaultValue)'\n ],\n description: 'Resize a matrix.',\n examples: [\n 'resize([1,2,3,4,5], [3])',\n 'resize([1,2,3], [5])',\n 'resize([1,2,3], [5], -1)',\n 'resize(2, [2, 3])',\n 'resize(\"hello\", [8], \"!\")'\n ],\n seealso: [\n 'size', 'subset', 'squeeze', 'reshape'\n ]\n}\n","export const reshapeDocs = {\n name: 'reshape',\n category: 'Matrix',\n syntax: [\n 'reshape(x, sizes)'\n ],\n description: 'Reshape a multi dimensional array to fit the specified dimensions.',\n examples: [\n 'reshape([1, 2, 3, 4, 5, 6], [2, 3])',\n 'reshape([[1, 2], [3, 4]], [1, 4])',\n 'reshape([[1, 2], [3, 4]], [4])',\n 'reshape([1, 2, 3, 4], [-1, 2])'\n ],\n seealso: [\n 'size', 'squeeze', 'resize'\n ]\n}\n","export const rotateDocs = {\n name: 'rotate',\n category: 'Matrix',\n syntax: [\n 'rotate(w, theta)',\n 'rotate(w, theta, v)'\n ],\n description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' +\n 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n examples: [\n 'rotate([1, 0], pi / 2)',\n 'rotate(matrix([1, 0]), unit(\"35deg\"))',\n 'rotate([1, 0, 0], unit(\"90deg\"), [0, 0, 1])',\n 'rotate(matrix([1, 0, 0]), unit(\"90deg\"), matrix([0, 0, 1]))'\n ],\n seealso: [\n 'matrix', 'rotationMatrix'\n ]\n}\n","export const rotationMatrixDocs = {\n name: 'rotationMatrix',\n category: 'Matrix',\n syntax: [\n 'rotationMatrix(theta)',\n 'rotationMatrix(theta, v)',\n 'rotationMatrix(theta, v, format)'\n ],\n description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' +\n 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n examples: [\n 'rotationMatrix(pi / 2)',\n 'rotationMatrix(unit(\"45deg\"), [0, 0, 1])',\n 'rotationMatrix(1, matrix([0, 0, 1]), \"sparse\")'\n ],\n seealso: [\n 'cos', 'sin'\n ]\n}\n","export const rowDocs = {\n name: 'row',\n category: 'Matrix',\n syntax: [\n 'row(x, index)'\n ],\n description: 'Return a row from a matrix or array.',\n examples: [\n 'A = [[1, 2], [3, 4]]',\n 'row(A, 1)',\n 'row(A, 2)'\n ],\n seealso: ['column', 'matrixFromRows']\n}\n","export const sizeDocs = {\n name: 'size',\n category: 'Matrix',\n syntax: [\n 'size(x)'\n ],\n description: 'Calculate the size of a matrix.',\n examples: [\n 'size(2.3)',\n 'size(\"hello world\")',\n 'a = [1, 2; 3, 4; 5, 6]',\n 'size(a)',\n 'size(1:6)'\n ],\n seealso: [\n 'concat', 'count', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const sortDocs = {\n name: 'sort',\n category: 'Matrix',\n syntax: [\n 'sort(x)',\n 'sort(x, compare)'\n ],\n description: 'Sort the items in a matrix. Compare can be a string \"asc\", \"desc\", \"natural\", or a custom sort function.',\n examples: [\n 'sort([5, 10, 1])',\n 'sort([\"C\", \"B\", \"A\", \"D\"], \"natural\")',\n 'sortByLength(a, b) = size(a)[1] - size(b)[1]',\n 'sort([\"Langdon\", \"Tom\", \"Sara\"], sortByLength)',\n 'sort([\"10\", \"1\", \"2\"], \"natural\")'\n ],\n seealso: ['map', 'filter', 'forEach']\n}\n","export const squeezeDocs = {\n name: 'squeeze',\n category: 'Matrix',\n syntax: [\n 'squeeze(x)'\n ],\n description: 'Remove inner and outer singleton dimensions from a matrix.',\n examples: [\n 'a = zeros(3,2,1)',\n 'size(squeeze(a))',\n 'b = zeros(1,1,3)',\n 'size(squeeze(b))'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'subset', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const subsetDocs = {\n name: 'subset',\n category: 'Matrix',\n syntax: [\n 'value(index)',\n 'value(index) = replacement',\n 'subset(value, [index])',\n 'subset(value, [index], replacement)'\n ],\n description: 'Get or set a subset of the entries of a matrix or ' +\n 'characters of a string. ' +\n 'Indexes are one-based. There should be one index specification for ' +\n 'each dimension of the target. Each specification can be a single ' +\n 'index, a list of indices, or a range in colon notation `l:u`. ' +\n 'In a range, both the lower bound l and upper bound u are included; ' +\n 'and if a bound is omitted it defaults to the most extreme valid value. ' +\n 'The cartesian product of the indices specified in each dimension ' +\n 'determines the target of the operation.',\n examples: [\n 'd = [1, 2; 3, 4]',\n 'e = []',\n 'e[1, 1:2] = [5, 6]',\n 'e[2, :] = [7, 8]',\n 'f = d * e',\n 'f[2, 1]',\n 'f[:, 1]',\n 'f[[1,2], [1,3]] = [9, 10; 11, 12]',\n 'f'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'trace', 'transpose', 'zeros'\n ]\n}\n","export const traceDocs = {\n name: 'trace',\n category: 'Matrix',\n syntax: [\n 'trace(A)'\n ],\n description: 'Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.',\n examples: [\n 'A = [1, 2, 3; -1, 2, 3; 2, 0, 3]',\n 'trace(A)'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'transpose', 'zeros'\n ]\n}\n","export const transposeDocs = {\n name: 'transpose',\n category: 'Matrix',\n syntax: [\n 'x\\'',\n 'transpose(x)'\n ],\n description: 'Transpose a matrix',\n examples: [\n 'a = [1, 2, 3; 4, 5, 6]',\n 'a\\'',\n 'transpose(a)'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'\n ]\n}\n","export const zerosDocs = {\n name: 'zeros',\n category: 'Matrix',\n syntax: [\n 'zeros(m)',\n 'zeros(m, n)',\n 'zeros(m, n, p, ...)',\n 'zeros([m])',\n 'zeros([m, n])',\n 'zeros([m, n, p, ...])'\n ],\n description: 'Create a matrix containing zeros.',\n examples: [\n 'zeros(3)',\n 'zeros(3, 5)',\n 'a = [1, 2, 3; 4, 5, 6]',\n 'zeros(size(a))'\n ],\n seealso: [\n 'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose'\n ]\n}\n","export const fftDocs = {\n name: 'fft',\n category: 'Matrix',\n syntax: [\n 'fft(x)'\n ],\n description: 'Calculate N-dimensional Fourier transform',\n examples: [\n 'fft([[1, 0], [1, 0]])'\n ],\n seealso: [\n 'ifft'\n ]\n}\n","export const ifftDocs = {\n name: 'ifft',\n category: 'Matrix',\n syntax: [\n 'ifft(x)'\n ],\n description: 'Calculate N-dimensional inverse Fourier transform',\n examples: [\n 'ifft([[2, 2], [0, 0]])'\n ],\n seealso: [\n 'fft'\n ]\n}\n","export const sylvesterDocs = {\n name: 'sylvester',\n category: 'Algebra',\n syntax: [\n 'sylvester(A,B,C)'\n ],\n description: 'Solves the real-valued Sylvester equation AX+XB=C for X',\n examples: [\n 'sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])',\n 'A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]',\n 'sylvester(A, B, C)'\n ],\n seealso: [\n 'schur', 'lyap'\n ]\n}\n","export const schurDocs = {\n name: 'schur',\n category: 'Algebra',\n syntax: [\n 'schur(A)'\n ],\n description: 'Performs a real Schur decomposition of the real matrix A = UTU\\'',\n examples: [\n 'schur([[1, 0], [-4, 3]])',\n 'A = [[1, 0], [-4, 3]]',\n 'schur(A)'\n ],\n seealso: [\n 'lyap', 'sylvester'\n ]\n}\n","export const lyapDocs = {\n name: 'lyap',\n category: 'Algebra',\n syntax: [\n 'lyap(A,Q)'\n ],\n description: 'Solves the Continuous-time Lyapunov equation AP+PA\\'+Q=0 for P',\n examples: [\n 'lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])',\n 'A = [[-2, 0], [1, -4]]',\n 'Q = [[3, 1], [1, 3]]',\n 'lyap(A,Q)'\n ],\n seealso: [\n 'schur', 'sylvester'\n ]\n}\n","export const solveODEDocs = {\n name: 'solveODE',\n category: 'Numeric',\n syntax: [\n 'solveODE(func, tspan, y0)',\n 'solveODE(func, tspan, y0, options)'\n ],\n description: 'Numerical Integration of Ordinary Differential Equations.',\n examples: [\n 'f(t,y) = y',\n 'tspan = [0, 4]',\n 'solveODE(f, tspan, 1)',\n 'solveODE(f, tspan, [1, 2])',\n 'solveODE(f, tspan, 1, { method:\"RK23\", maxStep:0.1 })'\n ],\n seealso: ['derivative', 'simplifyCore']\n}\n","export const combinationsDocs = {\n name: 'combinations',\n category: 'Probability',\n syntax: [\n 'combinations(n, k)'\n ],\n description: 'Compute the number of combinations of n items taken k at a time',\n examples: [\n 'combinations(7, 5)'\n ],\n seealso: ['combinationsWithRep', 'permutations', 'factorial']\n}\n","export const combinationsWithRepDocs = {\n name: 'combinationsWithRep',\n category: 'Probability',\n syntax: [\n 'combinationsWithRep(n, k)'\n ],\n description: 'Compute the number of combinations of n items taken k at a time with replacements.',\n examples: [\n 'combinationsWithRep(7, 5)'\n ],\n seealso: ['combinations', 'permutations', 'factorial']\n}\n","export const factorialDocs = {\n name: 'factorial',\n category: 'Probability',\n syntax: [\n 'n!',\n 'factorial(n)'\n ],\n description: 'Compute the factorial of a value',\n examples: [\n '5!',\n '5 * 4 * 3 * 2 * 1',\n '3!'\n ],\n seealso: ['combinations', 'combinationsWithRep', 'permutations', 'gamma']\n}\n","export const gammaDocs = {\n name: 'gamma',\n category: 'Probability',\n syntax: [\n 'gamma(n)'\n ],\n description: 'Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.',\n examples: [\n 'gamma(4)',\n '3!',\n 'gamma(1/2)',\n 'sqrt(pi)'\n ],\n seealso: ['factorial']\n}\n","export const kldivergenceDocs = {\n name: 'kldivergence',\n category: 'Probability',\n syntax: [\n 'kldivergence(x, y)'\n ],\n description: 'Calculate the Kullback-Leibler (KL) divergence between two distributions.',\n examples: [\n 'kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])'\n ],\n seealso: []\n}\n","export const lgammaDocs = {\n name: 'lgamma',\n category: 'Probability',\n syntax: ['lgamma(n)'],\n description:\n 'Logarithm of the gamma function for real, positive numbers and complex numbers, ' +\n 'using Lanczos approximation for numbers and Stirling series for complex numbers.',\n examples: [\n 'lgamma(4)',\n 'lgamma(1/2)',\n 'lgamma(i)',\n 'lgamma(complex(1.1, 2))'\n ],\n seealso: ['gamma']\n}\n","export const multinomialDocs = {\n name: 'multinomial',\n category: 'Probability',\n syntax: [\n 'multinomial(A)'\n ],\n description: 'Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. multinomial takes one array of integers as an argument. The following condition must be enforced: every ai > 0.',\n examples: [\n 'multinomial([1, 2, 1])'\n ],\n seealso: ['combinations', 'factorial']\n}\n","export const permutationsDocs = {\n name: 'permutations',\n category: 'Probability',\n syntax: [\n 'permutations(n)',\n 'permutations(n, k)'\n ],\n description: 'Compute the number of permutations of n items taken k at a time',\n examples: [\n 'permutations(5)',\n 'permutations(5, 3)'\n ],\n seealso: ['combinations', 'combinationsWithRep', 'factorial']\n}\n","export const pickRandomDocs = {\n name: 'pickRandom',\n category: 'Probability',\n syntax: [\n 'pickRandom(array)',\n 'pickRandom(array, number)',\n 'pickRandom(array, weights)',\n 'pickRandom(array, number, weights)',\n 'pickRandom(array, weights, number)'\n ],\n description:\n 'Pick a random entry from a given array.',\n examples: [\n 'pickRandom(0:10)',\n 'pickRandom([1, 3, 1, 6])',\n 'pickRandom([1, 3, 1, 6], 2)',\n 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1])',\n 'pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])',\n 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)'\n ],\n seealso: ['random', 'randomInt']\n}\n","export const randomDocs = {\n name: 'random',\n category: 'Probability',\n syntax: [\n 'random()',\n 'random(max)',\n 'random(min, max)',\n 'random(size)',\n 'random(size, max)',\n 'random(size, min, max)'\n ],\n description:\n 'Return a random number.',\n examples: [\n 'random()',\n 'random(10, 20)',\n 'random([2, 3])'\n ],\n seealso: ['pickRandom', 'randomInt']\n}\n","export const randomIntDocs = {\n name: 'randomInt',\n category: 'Probability',\n syntax: [\n 'randomInt(max)',\n 'randomInt(min, max)',\n 'randomInt(size)',\n 'randomInt(size, max)',\n 'randomInt(size, min, max)'\n ],\n description:\n 'Return a random integer number',\n examples: [\n 'randomInt(10, 20)',\n 'randomInt([2, 3], 10)'\n ],\n seealso: ['pickRandom', 'random']\n}\n","export const compareDocs = {\n name: 'compare',\n category: 'Relational',\n syntax: [\n 'compare(x, y)'\n ],\n description:\n 'Compare two values. ' +\n 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: [\n 'compare(2, 3)',\n 'compare(3, 2)',\n 'compare(2, 2)',\n 'compare(5cm, 40mm)',\n 'compare(2, [1, 2, 3])'\n ],\n seealso: [\n 'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compareNatural', 'compareText'\n ]\n}\n","export const compareNaturalDocs = {\n name: 'compareNatural',\n category: 'Relational',\n syntax: [\n 'compareNatural(x, y)'\n ],\n description:\n 'Compare two values of any type in a deterministic, natural way. ' +\n 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: [\n 'compareNatural(2, 3)',\n 'compareNatural(3, 2)',\n 'compareNatural(2, 2)',\n 'compareNatural(5cm, 40mm)',\n 'compareNatural(\"2\", \"10\")',\n 'compareNatural(2 + 3i, 2 + 4i)',\n 'compareNatural([1, 2, 4], [1, 2, 3])',\n 'compareNatural([1, 5], [1, 2, 3])',\n 'compareNatural([1, 2], [1, 2])',\n 'compareNatural({a: 2}, {a: 4})'\n ],\n seealso: [\n 'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare', 'compareText'\n ]\n}\n","export const compareTextDocs = {\n name: 'compareText',\n category: 'Relational',\n syntax: [\n 'compareText(x, y)'\n ],\n description:\n 'Compare two strings lexically. Comparison is case sensitive. ' +\n 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: [\n 'compareText(\"B\", \"A\")',\n 'compareText(\"A\", \"B\")',\n 'compareText(\"A\", \"A\")',\n 'compareText(\"2\", \"10\")',\n 'compare(\"2\", \"10\")',\n 'compare(2, 10)',\n 'compareNatural(\"2\", \"10\")',\n 'compareText(\"B\", [\"A\", \"B\", \"C\"])'\n ],\n seealso: [\n 'compare', 'compareNatural'\n ]\n}\n","export const deepEqualDocs = {\n name: 'deepEqual',\n category: 'Relational',\n syntax: [\n 'deepEqual(x, y)'\n ],\n description:\n 'Check equality of two matrices element wise. Returns true if the size of both matrices is equal and when and each of the elements are equal.',\n examples: [\n 'deepEqual([1,3,4], [1,3,4])',\n 'deepEqual([1,3,4], [1,3])'\n ],\n seealso: [\n 'equal', 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare'\n ]\n}\n","export const equalDocs = {\n name: 'equal',\n category: 'Relational',\n syntax: [\n 'x == y',\n 'equal(x, y)'\n ],\n description:\n 'Check equality of two values. Returns true if the values are equal, and false if not.',\n examples: [\n '2+2 == 3',\n '2+2 == 4',\n 'a = 3.2',\n 'b = 6-2.8',\n 'a == b',\n '50cm == 0.5m'\n ],\n seealso: [\n 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual', 'equalText'\n ]\n}\n","export const equalTextDocs = {\n name: 'equalText',\n category: 'Relational',\n syntax: [\n 'equalText(x, y)'\n ],\n description:\n 'Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.',\n examples: [\n 'equalText(\"Hello\", \"Hello\")',\n 'equalText(\"a\", \"A\")',\n 'equal(\"2e3\", \"2000\")',\n 'equalText(\"2e3\", \"2000\")',\n 'equalText(\"B\", [\"A\", \"B\", \"C\"])'\n ],\n seealso: [\n 'compare', 'compareNatural', 'compareText', 'equal'\n ]\n}\n","export const largerDocs = {\n name: 'larger',\n category: 'Relational',\n syntax: [\n 'x > y',\n 'larger(x, y)'\n ],\n description:\n 'Check if value x is larger than y. Returns true if x is larger than y, and false if not.',\n examples: [\n '2 > 3',\n '5 > 2*2',\n 'a = 3.3',\n 'b = 6-2.8',\n '(a > b)',\n '(b < a)',\n '5 cm > 2 inch'\n ],\n seealso: [\n 'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare'\n ]\n}\n","export const largerEqDocs = {\n name: 'largerEq',\n category: 'Relational',\n syntax: [\n 'x >= y',\n 'largerEq(x, y)'\n ],\n description:\n 'Check if value x is larger or equal to y. Returns true if x is larger or equal to y, and false if not.',\n examples: [\n '2 >= 1+1',\n '2 > 1+1',\n 'a = 3.2',\n 'b = 6-2.8',\n '(a >= b)'\n ],\n seealso: [\n 'equal', 'unequal', 'smallerEq', 'smaller', 'compare'\n ]\n}\n","export const smallerDocs = {\n name: 'smaller',\n category: 'Relational',\n syntax: [\n 'x < y',\n 'smaller(x, y)'\n ],\n description:\n 'Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.',\n examples: [\n '2 < 3',\n '5 < 2*2',\n 'a = 3.3',\n 'b = 6-2.8',\n '(a < b)',\n '5 cm < 2 inch'\n ],\n seealso: [\n 'equal', 'unequal', 'larger', 'smallerEq', 'largerEq', 'compare'\n ]\n}\n","export const smallerEqDocs = {\n name: 'smallerEq',\n category: 'Relational',\n syntax: [\n 'x <= y',\n 'smallerEq(x, y)'\n ],\n description:\n 'Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.',\n examples: [\n '2 <= 1+1',\n '2 < 1+1',\n 'a = 3.2',\n 'b = 6-2.8',\n '(a <= b)'\n ],\n seealso: [\n 'equal', 'unequal', 'larger', 'smaller', 'largerEq', 'compare'\n ]\n}\n","export const unequalDocs = {\n name: 'unequal',\n category: 'Relational',\n syntax: [\n 'x != y',\n 'unequal(x, y)'\n ],\n description:\n 'Check unequality of two values. Returns true if the values are unequal, and false if they are equal.',\n examples: [\n '2+2 != 3',\n '2+2 != 4',\n 'a = 3.2',\n 'b = 6-2.8',\n 'a != b',\n '50cm != 0.5m',\n '5 cm != 2 inch'\n ],\n seealso: [\n 'equal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual'\n ]\n}\n","export const setCartesianDocs = {\n name: 'setCartesian',\n category: 'Set',\n syntax: [\n 'setCartesian(set1, set2)'\n ],\n description:\n 'Create the cartesian product of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays and the values will be sorted in ascending order before the operation.',\n examples: [\n 'setCartesian([1, 2], [3, 4])'\n ],\n seealso: [\n 'setUnion', 'setIntersect', 'setDifference', 'setPowerset'\n ]\n}\n","export const setDifferenceDocs = {\n name: 'setDifference',\n category: 'Set',\n syntax: [\n 'setDifference(set1, set2)'\n ],\n description:\n 'Create the difference of two (multi)sets: every element of set1, that is not the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: [\n 'setDifference([1, 2, 3, 4], [3, 4, 5, 6])',\n 'setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n ],\n seealso: [\n 'setUnion', 'setIntersect', 'setSymDifference'\n ]\n}\n","export const setDistinctDocs = {\n name: 'setDistinct',\n category: 'Set',\n syntax: [\n 'setDistinct(set)'\n ],\n description:\n 'Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: [\n 'setDistinct([1, 1, 1, 2, 2, 3])'\n ],\n seealso: [\n 'setMultiplicity'\n ]\n}\n","export const setIntersectDocs = {\n name: 'setIntersect',\n category: 'Set',\n syntax: [\n 'setIntersect(set1, set2)'\n ],\n description:\n 'Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: [\n 'setIntersect([1, 2, 3, 4], [3, 4, 5, 6])',\n 'setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n ],\n seealso: [\n 'setUnion', 'setDifference'\n ]\n}\n","export const setIsSubsetDocs = {\n name: 'setIsSubset',\n category: 'Set',\n syntax: [\n 'setIsSubset(set1, set2)'\n ],\n description:\n 'Check whether a (multi)set is a subset of another (multi)set: every element of set1 is the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: [\n 'setIsSubset([1, 2], [3, 4, 5, 6])',\n 'setIsSubset([3, 4], [3, 4, 5, 6])'\n ],\n seealso: [\n 'setUnion', 'setIntersect', 'setDifference'\n ]\n}\n","export const setMultiplicityDocs = {\n name: 'setMultiplicity',\n category: 'Set',\n syntax: [\n 'setMultiplicity(element, set)'\n ],\n description:\n 'Count the multiplicity of an element in a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: [\n 'setMultiplicity(1, [1, 2, 2, 4])',\n 'setMultiplicity(2, [1, 2, 2, 4])'\n ],\n seealso: [\n 'setDistinct', 'setSize'\n ]\n}\n","export const setPowersetDocs = {\n name: 'setPowerset',\n category: 'Set',\n syntax: [\n 'setPowerset(set)'\n ],\n description:\n 'Create the powerset of a (multi)set: the powerset contains very possible subsets of a (multi)set. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: [\n 'setPowerset([1, 2, 3])'\n ],\n seealso: [\n 'setCartesian'\n ]\n}\n","export const setSizeDocs = {\n name: 'setSize',\n category: 'Set',\n syntax: [\n 'setSize(set)',\n 'setSize(set, unique)'\n ],\n description:\n 'Count the number of elements of a (multi)set. When the second parameter \"unique\" is true, count only the unique values. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: [\n 'setSize([1, 2, 2, 4])',\n 'setSize([1, 2, 2, 4], true)'\n ],\n seealso: [\n 'setUnion', 'setIntersect', 'setDifference'\n ]\n}\n","export const setSymDifferenceDocs = {\n name: 'setSymDifference',\n category: 'Set',\n syntax: [\n 'setSymDifference(set1, set2)'\n ],\n description:\n 'Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: [\n 'setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])',\n 'setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n ],\n seealso: [\n 'setUnion', 'setIntersect', 'setDifference'\n ]\n}\n","export const setUnionDocs = {\n name: 'setUnion',\n category: 'Set',\n syntax: [\n 'setUnion(set1, set2)'\n ],\n description:\n 'Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: [\n 'setUnion([1, 2, 3, 4], [3, 4, 5, 6])',\n 'setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n ],\n seealso: [\n 'setIntersect', 'setDifference'\n ]\n}\n","export const zpk2tfDocs = {\n name: 'zpk2tf',\n category: 'Signal',\n syntax: [\n 'zpk2tf(z, p, k)'\n ],\n description: 'Compute the transfer function of a zero-pole-gain model.',\n examples: [\n 'zpk2tf([1, 2], [-1, -2], 1)',\n 'zpk2tf([1, 2], [-1, -2])',\n 'zpk2tf([1 - 3i, 2 + 2i], [-1, -2])'\n ],\n seealso: []\n}\n","export const freqzDocs = {\n name: 'freqz',\n category: 'Signal',\n syntax: [\n 'freqz(b, a)',\n 'freqz(b, a, w)'\n ],\n description: 'Calculates the frequency response of a filter given its numerator and denominator coefficients.',\n examples: [\n 'freqz([1, 2], [1, 2, 3])',\n 'freqz([1, 2], [1, 2, 3], [0, 1])',\n 'freqz([1, 2], [1, 2, 3], 512)'\n ],\n seealso: []\n}\n","export const erfDocs = {\n name: 'erf',\n category: 'Special',\n syntax: [\n 'erf(x)'\n ],\n description: 'Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x',\n examples: [\n 'erf(0.2)',\n 'erf(-0.5)',\n 'erf(4)'\n ],\n seealso: []\n}\n","export const zetaDocs = {\n name: 'zeta',\n category: 'Special',\n syntax: [\n 'zeta(s)'\n ],\n description: 'Compute the Riemann Zeta Function using an infinite series and Riemann\\'s Functional Equation for the entire complex plane',\n examples: [\n 'zeta(0.2)',\n 'zeta(-0.5)',\n 'zeta(4)'\n ],\n seealso: []\n}\n","export const cumSumDocs = {\n name: 'cumsum',\n category: 'Statistics',\n syntax: [\n 'cumsum(a, b, c, ...)',\n 'cumsum(A)'\n ],\n description: 'Compute the cumulative sum of all values.',\n examples: [\n 'cumsum(2, 3, 4, 1)',\n 'cumsum([2, 3, 4, 1])',\n 'cumsum([1, 2; 3, 4])',\n 'cumsum([1, 2; 3, 4], 1)',\n 'cumsum([1, 2; 3, 4], 2)'\n ],\n seealso: [\n 'max',\n 'mean',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const madDocs = {\n name: 'mad',\n category: 'Statistics',\n syntax: [\n 'mad(a, b, c, ...)',\n 'mad(A)'\n ],\n description: 'Compute the median absolute deviation of a matrix or a list with values. The median absolute deviation is defined as the median of the absolute deviations from the median.',\n examples: [\n 'mad(10, 20, 30)',\n 'mad([1, 2, 3])'\n ],\n seealso: [\n 'mean',\n 'median',\n 'std',\n 'abs'\n ]\n}\n","export const maxDocs = {\n name: 'max',\n category: 'Statistics',\n syntax: [\n 'max(a, b, c, ...)',\n 'max(A)',\n 'max(A, dimension)'\n ],\n description: 'Compute the maximum value of a list of values.',\n examples: [\n 'max(2, 3, 4, 1)',\n 'max([2, 3, 4, 1])',\n 'max([2, 5; 4, 3])',\n 'max([2, 5; 4, 3], 1)',\n 'max([2, 5; 4, 3], 2)',\n 'max(2.7, 7.1, -4.5, 2.0, 4.1)',\n 'min(2.7, 7.1, -4.5, 2.0, 4.1)'\n ],\n seealso: [\n 'mean',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const meanDocs = {\n name: 'mean',\n category: 'Statistics',\n syntax: [\n 'mean(a, b, c, ...)',\n 'mean(A)',\n 'mean(A, dimension)'\n ],\n description: 'Compute the arithmetic mean of a list of values.',\n examples: [\n 'mean(2, 3, 4, 1)',\n 'mean([2, 3, 4, 1])',\n 'mean([2, 5; 4, 3])',\n 'mean([2, 5; 4, 3], 1)',\n 'mean([2, 5; 4, 3], 2)',\n 'mean([1.0, 2.7, 3.2, 4.0])'\n ],\n seealso: [\n 'max',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const medianDocs = {\n name: 'median',\n category: 'Statistics',\n syntax: [\n 'median(a, b, c, ...)',\n 'median(A)'\n ],\n description: 'Compute the median of all values. The values are sorted and the middle value is returned. In case of an even number of values, the average of the two middle values is returned.',\n examples: [\n 'median(5, 2, 7)',\n 'median([3, -1, 5, 7])'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'prod',\n 'std',\n 'sum',\n 'variance',\n 'quantileSeq'\n ]\n}\n","export const minDocs = {\n name: 'min',\n category: 'Statistics',\n syntax: [\n 'min(a, b, c, ...)',\n 'min(A)',\n 'min(A, dimension)'\n ],\n description: 'Compute the minimum value of a list of values.',\n examples: [\n 'min(2, 3, 4, 1)',\n 'min([2, 3, 4, 1])',\n 'min([2, 5; 4, 3])',\n 'min([2, 5; 4, 3], 1)',\n 'min([2, 5; 4, 3], 2)',\n 'min(2.7, 7.1, -4.5, 2.0, 4.1)',\n 'max(2.7, 7.1, -4.5, 2.0, 4.1)'\n ],\n seealso: [\n 'max',\n 'mean',\n 'median',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const modeDocs = {\n name: 'mode',\n category: 'Statistics',\n syntax: [\n 'mode(a, b, c, ...)',\n 'mode(A)',\n 'mode(A, a, b, B, c, ...)'\n ],\n description: 'Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.',\n examples: [\n 'mode(2, 1, 4, 3, 1)',\n 'mode([1, 2.7, 3.2, 4, 2.7])',\n 'mode(1, 4, 6, 1, 6)'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'median',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const prodDocs = {\n name: 'prod',\n category: 'Statistics',\n syntax: [\n 'prod(a, b, c, ...)',\n 'prod(A)'\n ],\n description: 'Compute the product of all values.',\n examples: [\n 'prod(2, 3, 4)',\n 'prod([2, 3, 4])',\n 'prod([2, 5; 4, 3])'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'median',\n 'min',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const quantileSeqDocs = {\n name: 'quantileSeq',\n category: 'Statistics',\n syntax: [\n 'quantileSeq(A, prob[, sorted])',\n 'quantileSeq(A, [prob1, prob2, ...][, sorted])',\n 'quantileSeq(A, N[, sorted])'\n ],\n description: 'Compute the prob order quantile of a matrix or a list with values. The sequence is sorted and the middle value is returned. Supported types of sequence values are: Number, BigNumber, Unit Supported types of probability are: Number, BigNumber. \\n\\nIn case of a (multi dimensional) array or matrix, the prob order quantile of all elements will be calculated.',\n examples: [\n 'quantileSeq([3, -1, 5, 7], 0.5)',\n 'quantileSeq([3, -1, 5, 7], [1/3, 2/3])',\n 'quantileSeq([3, -1, 5, 7], 2)',\n 'quantileSeq([-1, 3, 5, 7], 0.5, true)'\n ],\n seealso: [\n 'mean',\n 'median',\n 'min',\n 'max',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const stdDocs = {\n name: 'std',\n category: 'Statistics',\n syntax: [\n 'std(a, b, c, ...)',\n 'std(A)',\n 'std(A, dimension)',\n 'std(A, normalization)',\n 'std(A, dimension, normalization)'\n ],\n description: 'Compute the standard deviation of all values, defined as std(A) = sqrt(variance(A)). Optional parameter normalization can be \"unbiased\" (default), \"uncorrected\", or \"biased\".',\n examples: [\n 'std(2, 4, 6)',\n 'std([2, 4, 6, 8])',\n 'std([2, 4, 6, 8], \"uncorrected\")',\n 'std([2, 4, 6, 8], \"biased\")',\n 'std([1, 2, 3; 4, 5, 6])'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'median',\n 'prod',\n 'sum',\n 'variance'\n ]\n}\n","export const sumDocs = {\n name: 'sum',\n category: 'Statistics',\n syntax: [\n 'sum(a, b, c, ...)',\n 'sum(A)',\n 'sum(A, dimension)'\n ],\n description: 'Compute the sum of all values.',\n examples: [\n 'sum(2, 3, 4, 1)',\n 'sum([2, 3, 4, 1])',\n 'sum([2, 5; 4, 3])'\n ],\n seealso: [\n 'max',\n 'mean',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum',\n 'variance'\n ]\n}\n","export const varianceDocs = {\n name: 'variance',\n category: 'Statistics',\n syntax: [\n 'variance(a, b, c, ...)',\n 'variance(A)',\n 'variance(A, dimension)',\n 'variance(A, normalization)',\n 'variance(A, dimension, normalization)'\n ],\n description: 'Compute the variance of all values. Optional parameter normalization can be \"unbiased\" (default), \"uncorrected\", or \"biased\".',\n examples: [\n 'variance(2, 4, 6)',\n 'variance([2, 4, 6, 8])',\n 'variance([2, 4, 6, 8], \"uncorrected\")',\n 'variance([2, 4, 6, 8], \"biased\")',\n 'variance([1, 2, 3; 4, 5, 6])'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum'\n ]\n}\n","export const corrDocs = {\n name: 'corr',\n category: 'Statistics',\n syntax: [\n 'corr(A,B)'\n ],\n description: 'Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.',\n examples: [\n 'corr([2, 4, 6, 8],[1, 2, 3, 6])',\n 'corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))'\n ],\n seealso: [\n 'max',\n 'mean',\n 'min',\n 'median',\n 'min',\n 'prod',\n 'std',\n 'sum'\n ]\n}\n","export const acosDocs = {\n name: 'acos',\n category: 'Trigonometry',\n syntax: [\n 'acos(x)'\n ],\n description: 'Compute the inverse cosine of a value in radians.',\n examples: [\n 'acos(0.5)',\n 'acos(cos(2.3))'\n ],\n seealso: [\n 'cos',\n 'atan',\n 'asin'\n ]\n}\n","export const acoshDocs = {\n name: 'acosh',\n category: 'Trigonometry',\n syntax: [\n 'acosh(x)'\n ],\n description: 'Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.',\n examples: [\n 'acosh(1.5)'\n ],\n seealso: [\n 'cosh',\n 'asinh',\n 'atanh'\n ]\n}\n","export const acotDocs = {\n name: 'acot',\n category: 'Trigonometry',\n syntax: [\n 'acot(x)'\n ],\n description: 'Calculate the inverse cotangent of a value.',\n examples: [\n 'acot(0.5)',\n 'acot(cot(0.5))',\n 'acot(2)'\n ],\n seealso: [\n 'cot',\n 'atan'\n ]\n}\n","export const acothDocs = {\n name: 'acoth',\n category: 'Trigonometry',\n syntax: [\n 'acoth(x)'\n ],\n description: 'Calculate the inverse hyperbolic tangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.',\n examples: [\n 'acoth(2)',\n 'acoth(0.5)'\n ],\n seealso: [\n 'acsch',\n 'asech'\n ]\n}\n","export const acscDocs = {\n name: 'acsc',\n category: 'Trigonometry',\n syntax: [\n 'acsc(x)'\n ],\n description: 'Calculate the inverse cotangent of a value.',\n examples: [\n 'acsc(2)',\n 'acsc(csc(0.5))',\n 'acsc(0.5)'\n ],\n seealso: [\n 'csc',\n 'asin',\n 'asec'\n ]\n}\n","export const acschDocs = {\n name: 'acsch',\n category: 'Trigonometry',\n syntax: [\n 'acsch(x)'\n ],\n description: 'Calculate the inverse hyperbolic cosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.',\n examples: [\n 'acsch(0.5)'\n ],\n seealso: [\n 'asech',\n 'acoth'\n ]\n}\n","export const asecDocs = {\n name: 'asec',\n category: 'Trigonometry',\n syntax: [\n 'asec(x)'\n ],\n description: 'Calculate the inverse secant of a value.',\n examples: [\n 'asec(0.5)',\n 'asec(sec(0.5))',\n 'asec(2)'\n ],\n seealso: [\n 'acos',\n 'acot',\n 'acsc'\n ]\n}\n","export const asechDocs = {\n name: 'asech',\n category: 'Trigonometry',\n syntax: [\n 'asech(x)'\n ],\n description: 'Calculate the inverse secant of a value.',\n examples: [\n 'asech(0.5)'\n ],\n seealso: [\n 'acsch',\n 'acoth'\n ]\n}\n","export const asinDocs = {\n name: 'asin',\n category: 'Trigonometry',\n syntax: [\n 'asin(x)'\n ],\n description: 'Compute the inverse sine of a value in radians.',\n examples: [\n 'asin(0.5)',\n 'asin(sin(0.5))'\n ],\n seealso: [\n 'sin',\n 'acos',\n 'atan'\n ]\n}\n","export const asinhDocs = {\n name: 'asinh',\n category: 'Trigonometry',\n syntax: [\n 'asinh(x)'\n ],\n description: 'Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.',\n examples: [\n 'asinh(0.5)'\n ],\n seealso: [\n 'acosh',\n 'atanh'\n ]\n}\n","export const atanDocs = {\n name: 'atan',\n category: 'Trigonometry',\n syntax: [\n 'atan(x)'\n ],\n description: 'Compute the inverse tangent of a value in radians.',\n examples: [\n 'atan(0.5)',\n 'atan(tan(0.5))'\n ],\n seealso: [\n 'tan',\n 'acos',\n 'asin'\n ]\n}\n","export const atanhDocs = {\n name: 'atanh',\n category: 'Trigonometry',\n syntax: [\n 'atanh(x)'\n ],\n description: 'Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.',\n examples: [\n 'atanh(0.5)'\n ],\n seealso: [\n 'acosh',\n 'asinh'\n ]\n}\n","export const atan2Docs = {\n name: 'atan2',\n category: 'Trigonometry',\n syntax: [\n 'atan2(y, x)'\n ],\n description:\n 'Computes the principal value of the arc tangent of y/x in radians.',\n examples: [\n 'atan2(2, 2) / pi',\n 'angle = 60 deg in rad',\n 'x = cos(angle)',\n 'y = sin(angle)',\n 'atan2(y, x)'\n ],\n seealso: [\n 'sin',\n 'cos',\n 'tan'\n ]\n}\n","export const cosDocs = {\n name: 'cos',\n category: 'Trigonometry',\n syntax: [\n 'cos(x)'\n ],\n description: 'Compute the cosine of x in radians.',\n examples: [\n 'cos(2)',\n 'cos(pi / 4) ^ 2',\n 'cos(180 deg)',\n 'cos(60 deg)',\n 'sin(0.2)^2 + cos(0.2)^2'\n ],\n seealso: [\n 'acos',\n 'sin',\n 'tan'\n ]\n}\n","export const coshDocs = {\n name: 'cosh',\n category: 'Trigonometry',\n syntax: [\n 'cosh(x)'\n ],\n description: 'Compute the hyperbolic cosine of x in radians.',\n examples: [\n 'cosh(0.5)'\n ],\n seealso: [\n 'sinh',\n 'tanh',\n 'coth'\n ]\n}\n","export const cotDocs = {\n name: 'cot',\n category: 'Trigonometry',\n syntax: [\n 'cot(x)'\n ],\n description: 'Compute the cotangent of x in radians. Defined as 1/tan(x)',\n examples: [\n 'cot(2)',\n '1 / tan(2)'\n ],\n seealso: [\n 'sec',\n 'csc',\n 'tan'\n ]\n}\n","export const cothDocs = {\n name: 'coth',\n category: 'Trigonometry',\n syntax: [\n 'coth(x)'\n ],\n description: 'Compute the hyperbolic cotangent of x in radians.',\n examples: [\n 'coth(2)',\n '1 / tanh(2)'\n ],\n seealso: [\n 'sech',\n 'csch',\n 'tanh'\n ]\n}\n","export const cscDocs = {\n name: 'csc',\n category: 'Trigonometry',\n syntax: [\n 'csc(x)'\n ],\n description: 'Compute the cosecant of x in radians. Defined as 1/sin(x)',\n examples: [\n 'csc(2)',\n '1 / sin(2)'\n ],\n seealso: [\n 'sec',\n 'cot',\n 'sin'\n ]\n}\n","export const cschDocs = {\n name: 'csch',\n category: 'Trigonometry',\n syntax: [\n 'csch(x)'\n ],\n description: 'Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)',\n examples: [\n 'csch(2)',\n '1 / sinh(2)'\n ],\n seealso: [\n 'sech',\n 'coth',\n 'sinh'\n ]\n}\n","export const secDocs = {\n name: 'sec',\n category: 'Trigonometry',\n syntax: [\n 'sec(x)'\n ],\n description: 'Compute the secant of x in radians. Defined as 1/cos(x)',\n examples: [\n 'sec(2)',\n '1 / cos(2)'\n ],\n seealso: [\n 'cot',\n 'csc',\n 'cos'\n ]\n}\n","export const sechDocs = {\n name: 'sech',\n category: 'Trigonometry',\n syntax: [\n 'sech(x)'\n ],\n description: 'Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)',\n examples: [\n 'sech(2)',\n '1 / cosh(2)'\n ],\n seealso: [\n 'coth',\n 'csch',\n 'cosh'\n ]\n}\n","export const sinDocs = {\n name: 'sin',\n category: 'Trigonometry',\n syntax: [\n 'sin(x)'\n ],\n description: 'Compute the sine of x in radians.',\n examples: [\n 'sin(2)',\n 'sin(pi / 4) ^ 2',\n 'sin(90 deg)',\n 'sin(30 deg)',\n 'sin(0.2)^2 + cos(0.2)^2'\n ],\n seealso: [\n 'asin',\n 'cos',\n 'tan'\n ]\n}\n","export const sinhDocs = {\n name: 'sinh',\n category: 'Trigonometry',\n syntax: [\n 'sinh(x)'\n ],\n description: 'Compute the hyperbolic sine of x in radians.',\n examples: [\n 'sinh(0.5)'\n ],\n seealso: [\n 'cosh',\n 'tanh'\n ]\n}\n","export const tanDocs = {\n name: 'tan',\n category: 'Trigonometry',\n syntax: [\n 'tan(x)'\n ],\n description: 'Compute the tangent of x in radians.',\n examples: [\n 'tan(0.5)',\n 'sin(0.5) / cos(0.5)',\n 'tan(pi / 4)',\n 'tan(45 deg)'\n ],\n seealso: [\n 'atan',\n 'sin',\n 'cos'\n ]\n}\n","export const tanhDocs = {\n name: 'tanh',\n category: 'Trigonometry',\n syntax: [\n 'tanh(x)'\n ],\n description: 'Compute the hyperbolic tangent of x in radians.',\n examples: [\n 'tanh(0.5)',\n 'sinh(0.5) / cosh(0.5)'\n ],\n seealso: [\n 'sinh',\n 'cosh'\n ]\n}\n","export const toDocs = {\n name: 'to',\n category: 'Units',\n syntax: [\n 'x to unit',\n 'to(x, unit)'\n ],\n description: 'Change the unit of a value.',\n examples: [\n '5 inch to cm',\n '3.2kg to g',\n '16 bytes in bits'\n ],\n seealso: []\n}\n","export const cloneDocs = {\n name: 'clone',\n category: 'Utils',\n syntax: [\n 'clone(x)'\n ],\n description: 'Clone a variable. Creates a copy of primitive variables, and a deep copy of matrices',\n examples: [\n 'clone(3.5)',\n 'clone(2 - 4i)',\n 'clone(45 deg)',\n 'clone([1, 2; 3, 4])',\n 'clone(\"hello world\")'\n ],\n seealso: []\n}\n","export const formatDocs = {\n name: 'format',\n category: 'Utils',\n syntax: [\n 'format(value)',\n 'format(value, precision)'\n ],\n description: 'Format a value of any type as string.',\n examples: [\n 'format(2.3)',\n 'format(3 - 4i)',\n 'format([])',\n 'format(pi, 3)'\n ],\n seealso: ['print']\n}\n","export const binDocs = {\n name: 'bin',\n category: 'Utils',\n syntax: [\n 'bin(value)'\n ],\n description: 'Format a number as binary',\n examples: [\n 'bin(2)'\n ],\n seealso: ['oct', 'hex']\n}\n","export const octDocs = {\n name: 'oct',\n category: 'Utils',\n syntax: [\n 'oct(value)'\n ],\n description: 'Format a number as octal',\n examples: [\n 'oct(56)'\n ],\n seealso: ['bin', 'hex']\n}\n","export const hexDocs = {\n name: 'hex',\n category: 'Utils',\n syntax: [\n 'hex(value)'\n ],\n description: 'Format a number as hexadecimal',\n examples: [\n 'hex(240)'\n ],\n seealso: ['bin', 'oct']\n}\n","export const isNaNDocs = {\n name: 'isNaN',\n category: 'Utils',\n syntax: [\n 'isNaN(x)'\n ],\n description: 'Test whether a value is NaN (not a number)',\n examples: [\n 'isNaN(2)',\n 'isNaN(0 / 0)',\n 'isNaN(NaN)',\n 'isNaN(Infinity)'\n ],\n seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isIntegerDocs = {\n name: 'isInteger',\n category: 'Utils',\n syntax: [\n 'isInteger(x)'\n ],\n description: 'Test whether a value is an integer number.',\n examples: [\n 'isInteger(2)',\n 'isInteger(3.5)',\n 'isInteger([3, 0.5, -2])'\n ],\n seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isNegativeDocs = {\n name: 'isNegative',\n category: 'Utils',\n syntax: [\n 'isNegative(x)'\n ],\n description: 'Test whether a value is negative: smaller than zero.',\n examples: [\n 'isNegative(2)',\n 'isNegative(0)',\n 'isNegative(-4)',\n 'isNegative([3, 0.5, -2])'\n ],\n seealso: ['isInteger', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isNumericDocs = {\n name: 'isNumeric',\n category: 'Utils',\n syntax: [\n 'isNumeric(x)'\n ],\n description: 'Test whether a value is a numeric value. ' +\n 'Returns true when the input is a number, BigNumber, Fraction, or boolean.',\n examples: [\n 'isNumeric(2)',\n 'isNumeric(\"2\")',\n 'hasNumericValue(\"2\")',\n 'isNumeric(0)',\n 'isNumeric(bignumber(500))',\n 'isNumeric(fraction(0.125))',\n 'isNumeric(2 + 3i)',\n 'isNumeric([2.3, \"foo\", false])'\n ],\n seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'hasNumericValue']\n}\n","export const hasNumericValueDocs = {\n name: 'hasNumericValue',\n category: 'Utils',\n syntax: [\n 'hasNumericValue(x)'\n ],\n description: 'Test whether a value is an numeric value. ' +\n 'In case of a string, true is returned if the string contains a numeric value.',\n examples: [\n 'hasNumericValue(2)',\n 'hasNumericValue(\"2\")',\n 'isNumeric(\"2\")',\n 'hasNumericValue(0)',\n 'hasNumericValue(bignumber(500))',\n 'hasNumericValue(fraction(0.125))',\n 'hasNumericValue(2 + 3i)',\n 'hasNumericValue([2.3, \"foo\", false])'\n ],\n seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'isNumeric']\n}\n","export const isPositiveDocs = {\n name: 'isPositive',\n category: 'Utils',\n syntax: [\n 'isPositive(x)'\n ],\n description: 'Test whether a value is positive: larger than zero.',\n examples: [\n 'isPositive(2)',\n 'isPositive(0)',\n 'isPositive(-4)',\n 'isPositive([3, 0.5, -2])'\n ],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n}\n","export const isPrimeDocs = {\n name: 'isPrime',\n category: 'Utils',\n syntax: [\n 'isPrime(x)'\n ],\n description: 'Test whether a value is prime: has no divisors other than itself and one.',\n examples: [\n 'isPrime(3)',\n 'isPrime(-2)',\n 'isPrime([2, 17, 100])'\n ],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n}\n","export const isZeroDocs = {\n name: 'isZero',\n category: 'Utils',\n syntax: [\n 'isZero(x)'\n ],\n description: 'Test whether a value is zero.',\n examples: [\n 'isZero(2)',\n 'isZero(0)',\n 'isZero(-4)',\n 'isZero([3, 0, -2, 0])'\n ],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isPositive']\n}\n","export const printDocs = {\n name: 'print',\n category: 'Utils',\n syntax: [\n 'print(template, values)',\n 'print(template, values, precision)'\n ],\n description: 'Interpolate values into a string template.',\n examples: [\n 'print(\"Lucy is $age years old\", {age: 5})',\n 'print(\"The value of pi is $pi\", {pi: pi}, 3)',\n 'print(\"Hello, $user.name!\", {user: {name: \"John\"}})',\n 'print(\"Values: $1, $2, $3\", [6, 9, 4])'\n ],\n seealso: ['format']\n}\n","export const typeOfDocs = {\n name: 'typeOf',\n category: 'Utils',\n syntax: [\n 'typeOf(x)'\n ],\n description: 'Get the type of a variable.',\n examples: [\n 'typeOf(3.5)',\n 'typeOf(2 - 4i)',\n 'typeOf(45 deg)',\n 'typeOf(\"hello world\")'\n ],\n seealso: ['getMatrixDataType']\n}\n","export const numericDocs = {\n name: 'numeric',\n category: 'Utils',\n syntax: [\n 'numeric(x)'\n ],\n description: 'Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.',\n examples: [\n 'numeric(\"4\")',\n 'numeric(\"4\", \"number\")',\n 'numeric(\"4\", \"bigint\")',\n 'numeric(\"4\", \"BigNumber\")',\n 'numeric(\"4\", \"Fraction\")',\n 'numeric(4, \"Fraction\")',\n 'numeric(fraction(2, 5), \"number\")'\n ],\n seealso: ['number', 'bigint', 'fraction', 'bignumber', 'string', 'format']\n}\n","import { factory } from '../../utils/factory.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { embeddedDocs } from '../embeddedDocs/embeddedDocs.js'\nimport { hasOwnProperty } from '../../utils/object.js'\n\nconst name = 'help'\nconst dependencies = ['typed', 'mathWithTransform', 'Help']\n\nexport const createHelp = /* #__PURE__ */ factory(name, dependencies, ({ typed, mathWithTransform, Help }) => {\n /**\n * Retrieve help on a function or data type.\n * Help files are retrieved from the embedded documentation in math.docs.\n *\n * Syntax:\n *\n * math.help(search)\n *\n * Examples:\n *\n * console.log(math.help('sin').toString())\n * console.log(math.help(math.add).toString())\n * console.log(math.help(math.add).toJSON())\n *\n * @param {Function | string | Object} search A function or function name\n * for which to get help\n * @return {Help} A help object\n */\n return typed(name, {\n any: function (search) {\n let prop\n let searchName = search\n\n if (typeof search !== 'string') {\n for (prop in mathWithTransform) {\n // search in functions and constants\n if (hasOwnProperty(mathWithTransform, prop) && (search === mathWithTransform[prop])) {\n searchName = prop\n break\n }\n }\n\n /* TODO: implement help for data types\n if (!text) {\n // search data type\n for (prop in math.type) {\n if (hasOwnProperty(math, prop)) {\n if (search === math.type[prop]) {\n text = prop\n break\n }\n }\n }\n }\n */\n }\n\n const doc = getSafeProperty(embeddedDocs, searchName)\n if (!doc) {\n const searchText = typeof searchName === 'function' ? searchName.name : searchName\n throw new Error('No documentation found on \"' + searchText + '\"')\n }\n return new Help(doc)\n }\n })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'chain'\nconst dependencies = ['typed', 'Chain']\n\nexport const createChain = /* #__PURE__ */ factory(name, dependencies, ({ typed, Chain }) => {\n /**\n * Wrap any value in a chain, allowing to perform chained operations on\n * the value.\n *\n * All methods available in the math.js library can be called upon the chain,\n * and then will be evaluated with the value itself as first argument.\n * The chain can be closed by executing `chain.done()`, which returns\n * the final value.\n *\n * The chain has a number of special functions:\n *\n * - `done()` Finalize the chain and return the chain's value.\n * - `valueOf()` The same as `done()`\n * - `toString()` Executes `math.format()` onto the chain's value, returning\n * a string representation of the value.\n *\n * Syntax:\n *\n * math.chain(value)\n *\n * Examples:\n *\n * math.chain(3)\n * .add(4)\n * .subtract(2)\n * .done() // 5\n *\n * math.chain( [[1, 2], [3, 4]] )\n * .subset(math.index(0, 0), 8)\n * .multiply(3)\n * .done() // [[24, 6], [9, 12]]\n *\n * @param {*} [value] A value of any type on which to start a chained operation.\n * @return {math.Chain} The created chain\n */\n return typed(name, {\n '': function () {\n return new Chain()\n },\n\n any: function (value) {\n return new Chain(value)\n }\n })\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'det'\nconst dependencies = ['typed', 'matrix', 'subtractScalar', 'multiply', 'divideScalar', 'isZero', 'unaryMinus']\n\nexport const createDet = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtractScalar, multiply, divideScalar, isZero, unaryMinus }) => {\n /**\n * Calculate the determinant of a matrix.\n *\n * Syntax:\n *\n * math.det(x)\n *\n * Examples:\n *\n * math.det([[1, 2], [3, 4]]) // returns -2\n *\n * const A = [\n * [-2, 2, 3],\n * [-1, 1, 3],\n * [2, 0, -1]\n * ]\n * math.det(A) // returns 6\n *\n * See also:\n *\n * inv\n *\n * @param {Array | Matrix} x A matrix\n * @return {number} The determinant of `x`\n */\n return typed(name, {\n any: function (x) {\n return clone(x)\n },\n\n 'Array | Matrix': function det (x) {\n let size\n if (isMatrix(x)) {\n size = x.size()\n } else if (Array.isArray(x)) {\n x = matrix(x)\n size = x.size()\n } else {\n // a scalar\n size = []\n }\n\n switch (size.length) {\n case 0:\n // scalar\n return clone(x)\n\n case 1:\n // vector\n if (size[0] === 1) {\n return clone(x.valueOf()[0])\n } if (size[0] === 0) {\n return 1 // det of an empty matrix is per definition 1\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n\n case 2:\n {\n // two-dimensional array\n const rows = size[0]\n const cols = size[1]\n if (rows === cols) {\n return _det(x.clone().valueOf(), rows, cols)\n } if (cols === 0) {\n return 1 // det of an empty matrix is per definition 1\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' +\n '(size: ' + format(size) + ')')\n }\n }\n })\n\n /**\n * Calculate the determinant of a matrix\n * @param {Array[]} matrix A square, two dimensional matrix\n * @param {number} rows Number of rows of the matrix (zero-based)\n * @param {number} cols Number of columns of the matrix (zero-based)\n * @returns {number} det\n * @private\n */\n function _det (matrix, rows, cols) {\n if (rows === 1) {\n // this is a 1 x 1 matrix\n return clone(matrix[0][0])\n } else if (rows === 2) {\n // this is a 2 x 2 matrix\n // the determinant of [a11,a12;a21,a22] is det = a11*a22-a21*a12\n return subtractScalar(\n multiply(matrix[0][0], matrix[1][1]),\n multiply(matrix[1][0], matrix[0][1])\n )\n } else {\n // Bareiss algorithm\n // this algorithm have same complexity as LUP decomposition (O(n^3))\n // but it preserve precision of floating point more relative to the LUP decomposition\n let negated = false\n const rowIndices = new Array(rows).fill(0).map((_, i) => i) // matrix index of row i\n for (let k = 0; k < rows; k++) {\n let k_ = rowIndices[k]\n if (isZero(matrix[k_][k])) {\n let _k\n for (_k = k + 1; _k < rows; _k++) {\n if (!isZero(matrix[rowIndices[_k]][k])) {\n k_ = rowIndices[_k]\n rowIndices[_k] = rowIndices[k]\n rowIndices[k] = k_\n negated = !negated\n break\n }\n }\n if (_k === rows) return matrix[k_][k] // some zero of the type\n }\n const piv = matrix[k_][k]\n const piv_ = k === 0 ? 1 : matrix[rowIndices[k - 1]][k - 1]\n for (let i = k + 1; i < rows; i++) {\n const i_ = rowIndices[i]\n for (let j = k + 1; j < rows; j++) {\n matrix[i_][j] = divideScalar(subtractScalar(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_)\n }\n }\n }\n const det = matrix[rowIndices[rows - 1]][rows - 1]\n return negated ? unaryMinus(det) : det\n }\n }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\n\nconst name = 'inv'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'divideScalar',\n 'addScalar',\n 'multiply',\n 'unaryMinus',\n 'det',\n 'identity',\n 'abs'\n]\n\nexport const createInv = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, addScalar, multiply, unaryMinus, det, identity, abs }) => {\n /**\n * Calculate the inverse of a square matrix.\n *\n * Syntax:\n *\n * math.inv(x)\n *\n * Examples:\n *\n * math.inv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]]\n * math.inv(4) // returns 0.25\n * 1 / 4 // returns 0.25\n *\n * See also:\n *\n * det, transpose\n *\n * @param {number | Complex | Array | Matrix} x Matrix to be inversed\n * @return {number | Complex | Array | Matrix} The inverse of `x`.\n */\n return typed(name, {\n 'Array | Matrix': function (x) {\n const size = isMatrix(x) ? x.size() : arraySize(x)\n switch (size.length) {\n case 1:\n // vector\n if (size[0] === 1) {\n if (isMatrix(x)) {\n return matrix([\n divideScalar(1, x.valueOf()[0])\n ])\n } else {\n return [\n divideScalar(1, x[0])\n ]\n }\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n\n case 2:\n // two dimensional array\n {\n const rows = size[0]\n const cols = size[1]\n if (rows === cols) {\n if (isMatrix(x)) {\n return matrix(\n _inv(x.valueOf(), rows, cols),\n x.storage()\n )\n } else {\n // return an Array\n return _inv(x, rows, cols)\n }\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' +\n '(size: ' + format(size) + ')')\n }\n },\n\n any: function (x) {\n // scalar\n return divideScalar(1, x) // FIXME: create a BigNumber one when configured for bignumbers\n }\n })\n\n /**\n * Calculate the inverse of a square matrix\n * @param {Array[]} mat A square matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns, must equal rows\n * @return {Array[]} inv Inverse matrix\n * @private\n */\n function _inv (mat, rows, cols) {\n let r, s, f, value, temp\n\n if (rows === 1) {\n // this is a 1 x 1 matrix\n value = mat[0][0]\n if (value === 0) {\n throw Error('Cannot calculate inverse, determinant is zero')\n }\n return [[\n divideScalar(1, value)\n ]]\n } else if (rows === 2) {\n // this is a 2 x 2 matrix\n const d = det(mat)\n if (d === 0) {\n throw Error('Cannot calculate inverse, determinant is zero')\n }\n return [\n [\n divideScalar(mat[1][1], d),\n divideScalar(unaryMinus(mat[0][1]), d)\n ],\n [\n divideScalar(unaryMinus(mat[1][0]), d),\n divideScalar(mat[0][0], d)\n ]\n ]\n } else {\n // this is a matrix of 3 x 3 or larger\n // calculate inverse using gauss-jordan elimination\n // https://en.wikipedia.org/wiki/Gaussian_elimination\n // http://mathworld.wolfram.com/MatrixInverse.html\n // http://math.uww.edu/~mcfarlat/inverse.htm\n\n // make a copy of the matrix (only the arrays, not of the elements)\n const A = mat.concat()\n for (r = 0; r < rows; r++) {\n A[r] = A[r].concat()\n }\n\n // create an identity matrix which in the end will contain the\n // matrix inverse\n const B = identity(rows).valueOf()\n\n // loop over all columns, and perform row reductions\n for (let c = 0; c < cols; c++) {\n // Pivoting: Swap row c with row r, where row r contains the largest element A[r][c]\n let ABig = abs(A[c][c])\n let rBig = c\n r = c + 1\n while (r < rows) {\n if (abs(A[r][c]) > ABig) {\n ABig = abs(A[r][c])\n rBig = r\n }\n r++\n }\n if (ABig === 0) {\n throw Error('Cannot calculate inverse, determinant is zero')\n }\n r = rBig\n if (r !== c) {\n temp = A[c]; A[c] = A[r]; A[r] = temp\n temp = B[c]; B[c] = B[r]; B[r] = temp\n }\n\n // eliminate non-zero values on the other rows at column c\n const Ac = A[c]\n const Bc = B[c]\n for (r = 0; r < rows; r++) {\n const Ar = A[r]\n const Br = B[r]\n if (r !== c) {\n // eliminate value at column c and row r\n if (Ar[c] !== 0) {\n f = divideScalar(unaryMinus(Ar[c]), Ac[c])\n\n // add (f * row c) to row r to eliminate the value\n // at column c\n for (s = c; s < cols; s++) {\n Ar[s] = addScalar(Ar[s], multiply(f, Ac[s]))\n }\n for (s = 0; s < cols; s++) {\n Br[s] = addScalar(Br[s], multiply(f, Bc[s]))\n }\n }\n } else {\n // normalize value at Acc to 1,\n // divide each value on row r with the value at Acc\n f = Ac[c]\n for (s = c; s < cols; s++) {\n Ar[s] = divideScalar(Ar[s], f)\n }\n for (s = 0; s < cols; s++) {\n Br[s] = divideScalar(Br[s], f)\n }\n }\n }\n }\n return B\n }\n }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\nimport { clone } from '../../utils/object.js'\n\nconst name = 'pinv'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'inv',\n 'deepEqual',\n 'equal',\n 'dotDivide',\n 'dot',\n 'ctranspose',\n 'divideScalar',\n 'multiply',\n 'add',\n 'Complex'\n]\n\nexport const createPinv = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n matrix,\n inv,\n deepEqual,\n equal,\n dotDivide,\n dot,\n ctranspose,\n divideScalar,\n multiply,\n add,\n Complex\n}) => {\n /**\n * Calculate the Moore–Penrose inverse of a matrix.\n *\n * Syntax:\n *\n * math.pinv(x)\n *\n * Examples:\n *\n * math.pinv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]]\n * math.pinv([[1, 0], [0, 1], [0, 1]]) // returns [[1, 0, 0], [0, 0.5, 0.5]]\n * math.pinv(4) // returns 0.25\n *\n * See also:\n *\n * inv\n *\n * @param {number | Complex | Array | Matrix} x Matrix to be inversed\n * @return {number | Complex | Array | Matrix} The inverse of `x`.\n */\n return typed(name, {\n 'Array | Matrix': function (x) {\n const size = isMatrix(x) ? x.size() : arraySize(x)\n switch (size.length) {\n case 1:\n // vector\n if (_isZeros(x)) return ctranspose(x) // null vector\n if (size[0] === 1) {\n return inv(x) // invertible matrix\n } else {\n return dotDivide(ctranspose(x), dot(x, x))\n }\n\n case 2:\n // two dimensional array\n {\n if (_isZeros(x)) return ctranspose(x) // zero matrixx\n const rows = size[0]\n const cols = size[1]\n if (rows === cols) {\n try {\n return inv(x) // invertible matrix\n } catch (err) {\n if (err instanceof Error && err.message.match(/Cannot calculate inverse, determinant is zero/)) {\n // Expected\n } else {\n throw err\n }\n }\n }\n if (isMatrix(x)) {\n return matrix(\n _pinv(x.valueOf(), rows, cols),\n x.storage()\n )\n } else {\n // return an Array\n return _pinv(x, rows, cols)\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' +\n '(size: ' + format(size) + ')')\n }\n },\n\n any: function (x) {\n // scalar\n if (equal(x, 0)) return clone(x) // zero\n return divideScalar(1, x)\n }\n })\n\n /**\n * Calculate the Moore–Penrose inverse of a matrix\n * @param {Array[]} mat A matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {Array[]} pinv Pseudoinverse matrix\n * @private\n */\n function _pinv (mat, rows, cols) {\n const { C, F } = _rankFact(mat, rows, cols) // TODO: Use SVD instead (may improve precision)\n const Cpinv = multiply(inv(multiply(ctranspose(C), C)), ctranspose(C))\n const Fpinv = multiply(ctranspose(F), inv(multiply(F, ctranspose(F))))\n return multiply(Fpinv, Cpinv)\n }\n\n /**\n * Calculate the reduced row echelon form of a matrix\n *\n * Modified from https://rosettacode.org/wiki/Reduced_row_echelon_form\n *\n * @param {Array[]} mat A matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {Array[]} Reduced row echelon form\n * @private\n */\n function _rref (mat, rows, cols) {\n const M = clone(mat)\n let lead = 0\n for (let r = 0; r < rows; r++) {\n if (cols <= lead) {\n return M\n }\n let i = r\n while (_isZero(M[i][lead])) {\n i++\n if (rows === i) {\n i = r\n lead++\n if (cols === lead) {\n return M\n }\n }\n }\n\n [M[i], M[r]] = [M[r], M[i]]\n\n let val = M[r][lead]\n for (let j = 0; j < cols; j++) {\n M[r][j] = dotDivide(M[r][j], val)\n }\n\n for (let i = 0; i < rows; i++) {\n if (i === r) continue\n val = M[i][lead]\n for (let j = 0; j < cols; j++) {\n M[i][j] = add(M[i][j], multiply(-1, multiply(val, M[r][j])))\n }\n }\n lead++\n }\n return M\n }\n\n /**\n * Calculate the rank factorization of a matrix\n *\n * @param {Array[]} mat A matrix (M)\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {{C: Array, F: Array}} rank factorization where M = C F\n * @private\n */\n function _rankFact (mat, rows, cols) {\n const rref = _rref(mat, rows, cols)\n const C = mat.map((_, i) => _.filter((_, j) => j < rows && !_isZero(dot(rref[j], rref[j]))))\n const F = rref.filter((_, i) => !_isZero(dot(rref[i], rref[i])))\n return { C, F }\n }\n\n function _isZero (x) {\n return equal(add(x, Complex(1, 1)), add(0, Complex(1, 1)))\n }\n\n function _isZeros (arr) {\n return deepEqual(add(arr, Complex(1, 1)), add(multiply(arr, 0), Complex(1, 1)))\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\nimport { createComplexEigs } from './eigs/complexEigs.js'\nimport { createRealSymmetric } from './eigs/realSymmetric.js'\nimport { typeOf, isNumber, isBigNumber, isComplex, isFraction } from '../../utils/is.js'\n\nconst name = 'eigs'\n\n// The absolute state of math.js's dependency system:\nconst dependencies = ['config', 'typed', 'matrix', 'addScalar', 'equal', 'subtract', 'abs', 'atan', 'cos', 'sin', 'multiplyScalar', 'divideScalar', 'inv', 'bignumber', 'multiply', 'add', 'larger', 'column', 'flatten', 'number', 'complex', 'sqrt', 'diag', 'size', 'reshape', 'qr', 'usolve', 'usolveAll', 'im', 're', 'smaller', 'matrixFromColumns', 'dot']\nexport const createEigs = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, matrix, addScalar, subtract, equal, abs, atan, cos, sin, multiplyScalar, divideScalar, inv, bignumber, multiply, add, larger, column, flatten, number, complex, sqrt, diag, size, reshape, qr, usolve, usolveAll, im, re, smaller, matrixFromColumns, dot }) => {\n const doRealSymmetric = createRealSymmetric({ config, addScalar, subtract, column, flatten, equal, abs, atan, cos, sin, multiplyScalar, inv, bignumber, complex, multiply, add })\n const doComplexEigs = createComplexEigs({ config, addScalar, subtract, multiply, multiplyScalar, flatten, divideScalar, sqrt, abs, bignumber, diag, size, reshape, qr, inv, usolve, usolveAll, equal, complex, larger, smaller, matrixFromColumns, dot })\n\n /**\n * Compute eigenvalues and optionally eigenvectors of a square matrix.\n * The eigenvalues are sorted by their absolute value, ascending, and\n * returned as a vector in the `values` property of the returned project.\n * An eigenvalue with algebraic multiplicity k will be listed k times, so\n * that the returned `values` vector always has length equal to the size\n * of the input matrix.\n *\n * The `eigenvectors` property of the return value provides the eigenvectors.\n * It is an array of plain objects: the `value` property of each gives the\n * associated eigenvalue, and the `vector` property gives the eigenvector\n * itself. Note that the same `value` property will occur as many times in\n * the list provided by `eigenvectors` as the geometric multiplicity of\n * that value.\n *\n * If the algorithm fails to converge, it will throw an error –\n * in that case, however, you may still find useful information\n * in `err.values` and `err.vectors`.\n *\n * Note that the 'precision' option does not directly specify the _accuracy_\n * of the returned eigenvalues. Rather, it determines how small an entry\n * of the iterative approximations to an upper triangular matrix must be\n * in order to be considered zero. The actual accuracy of the returned\n * eigenvalues may be greater or less than the precision, depending on the\n * conditioning of the matrix and how far apart or close the actual\n * eigenvalues are. Note that currently, relatively simple, \"traditional\"\n * methods of eigenvalue computation are being used; this is not a modern,\n * high-precision eigenvalue computation. That said, it should typically\n * produce fairly reasonable results.\n *\n * Syntax:\n *\n * math.eigs(x, [prec])\n * math.eigs(x, {options})\n *\n * Examples:\n *\n * const { eigs, multiply, column, transpose, matrixFromColumns } = math\n * const H = [[5, 2.3], [2.3, 1]]\n * const ans = eigs(H) // returns {values: [E1,E2...sorted], eigenvectors: [{value: E1, vector: v2}, {value: e, vector: v2}, ...]\n * const E = ans.values\n * const V = ans.eigenvectors\n * multiply(H, V[0].vector)) // returns multiply(E[0], V[0].vector))\n * const U = matrixFromColumns(...V.map(obj => obj.vector))\n * const UTxHxU = multiply(transpose(U), H, U) // diagonalizes H if possible\n * E[0] == UTxHxU[0][0] // returns true always\n *\n * // Compute only approximate eigenvalues:\n * const {values} = eigs(H, {eigenvectors: false, precision: 1e-6})\n *\n * See also:\n *\n * inv\n *\n * @param {Array | Matrix} x Matrix to be diagonalized\n *\n * @param {number | BigNumber | OptsObject} [opts] Object with keys `precision`, defaulting to config.relTol, and `eigenvectors`, defaulting to true and specifying whether to compute eigenvectors. If just a number, specifies precision.\n * @return {{values: Array|Matrix, eigenvectors?: Array}} Object containing an array of eigenvalues and an array of {value: number|BigNumber, vector: Array|Matrix} objects. The eigenvectors property is undefined if eigenvectors were not requested.\n *\n */\n return typed('eigs', {\n\n // The conversion to matrix in the first two implementations,\n // just to convert back to an array right away in\n // computeValuesAndVectors, is unfortunate, and should perhaps be\n // streamlined. It is done because the Matrix object carries some\n // type information about its entries, and so constructing the matrix\n // is a roundabout way of doing type detection.\n Array: function (x) { return doEigs(matrix(x)) },\n 'Array, number|BigNumber': function (x, prec) {\n return doEigs(matrix(x), { precision: prec })\n },\n 'Array, Object' (x, opts) { return doEigs(matrix(x), opts) },\n Matrix: function (mat) {\n return doEigs(mat, { matricize: true })\n },\n 'Matrix, number|BigNumber': function (mat, prec) {\n return doEigs(mat, { precision: prec, matricize: true })\n },\n 'Matrix, Object': function (mat, opts) {\n const useOpts = { matricize: true }\n Object.assign(useOpts, opts)\n return doEigs(mat, useOpts)\n }\n })\n\n function doEigs (mat, opts = {}) {\n const computeVectors = 'eigenvectors' in opts ? opts.eigenvectors : true\n const prec = opts.precision ?? config.relTol\n const result = computeValuesAndVectors(mat, prec, computeVectors)\n if (opts.matricize) {\n result.values = matrix(result.values)\n if (computeVectors) {\n result.eigenvectors = result.eigenvectors.map(({ value, vector }) =>\n ({ value, vector: matrix(vector) }))\n }\n }\n if (computeVectors) {\n Object.defineProperty(result, 'vectors', {\n enumerable: false, // to make sure that the eigenvectors can still be\n // converted to string.\n get: () => {\n throw new Error('eigs(M).vectors replaced with eigs(M).eigenvectors')\n }\n })\n }\n return result\n }\n\n function computeValuesAndVectors (mat, prec, computeVectors) {\n const arr = mat.toArray() // NOTE: arr is guaranteed to be unaliased\n // and so safe to modify in place\n const asize = mat.size()\n\n if (asize.length !== 2 || asize[0] !== asize[1]) {\n throw new RangeError(`Matrix must be square (size: ${format(asize)})`)\n }\n\n const N = asize[0]\n\n if (isReal(arr, N, prec)) {\n coerceReal(arr, N) // modifies arr by side effect\n\n if (isSymmetric(arr, N, prec)) {\n const type = coerceTypes(mat, arr, N) // modifies arr by side effect\n return doRealSymmetric(arr, N, prec, type, computeVectors)\n }\n }\n\n const type = coerceTypes(mat, arr, N) // modifies arr by side effect\n return doComplexEigs(arr, N, prec, type, computeVectors)\n }\n\n /** @return {boolean} */\n function isSymmetric (arr, N, prec) {\n for (let i = 0; i < N; i++) {\n for (let j = i; j < N; j++) {\n // TODO proper comparison of bignum and frac\n if (larger(bignumber(abs(subtract(arr[i][j], arr[j][i]))), prec)) {\n return false\n }\n }\n }\n\n return true\n }\n\n /** @return {boolean} */\n function isReal (arr, N, prec) {\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n // TODO proper comparison of bignum and frac\n if (larger(bignumber(abs(im(arr[i][j]))), prec)) {\n return false\n }\n }\n }\n\n return true\n }\n\n function coerceReal (arr, N) {\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n arr[i][j] = re(arr[i][j])\n }\n }\n }\n\n /** @return {'number' | 'BigNumber' | 'Complex'} */\n function coerceTypes (mat, arr, N) {\n /** @type {string} */\n const type = mat.datatype()\n\n if (type === 'number' || type === 'BigNumber' || type === 'Complex') {\n return type\n }\n\n let hasNumber = false\n let hasBig = false\n let hasComplex = false\n\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n const el = arr[i][j]\n\n if (isNumber(el) || isFraction(el)) {\n hasNumber = true\n } else if (isBigNumber(el)) {\n hasBig = true\n } else if (isComplex(el)) {\n hasComplex = true\n } else {\n throw TypeError('Unsupported type in Matrix: ' + typeOf(el))\n }\n }\n }\n\n if (hasBig && hasComplex) {\n console.warn('Complex BigNumbers not supported, this operation will lose precission.')\n }\n\n if (hasComplex) {\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n arr[i][j] = complex(arr[i][j])\n }\n }\n\n return 'Complex'\n }\n\n if (hasBig) {\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n arr[i][j] = bignumber(arr[i][j])\n }\n }\n\n return 'BigNumber'\n }\n\n if (hasNumber) {\n for (let i = 0; i < N; i++) {\n for (let j = 0; j < N; j++) {\n arr[i][j] = number(arr[i][j])\n }\n }\n\n return 'number'\n } else {\n throw TypeError('Matrix contains unsupported types only.')\n }\n }\n})\n","import { clone } from '../../../utils/object.js'\n\nexport function createRealSymmetric ({ config, addScalar, subtract, abs, atan, cos, sin, multiplyScalar, inv, bignumber, multiply, add }) {\n /**\n * @param {number[] | BigNumber[]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number' | 'BigNumber'} type\n */\n function main (arr, N, prec = config.relTol, type, computeVectors) {\n if (type === 'number') {\n return diag(arr, prec, computeVectors)\n }\n\n if (type === 'BigNumber') {\n return diagBig(arr, prec, computeVectors)\n }\n\n throw TypeError('Unsupported data type: ' + type)\n }\n\n // diagonalization implementation for number (efficient)\n function diag (x, precision, computeVectors) {\n const N = x.length\n const e0 = Math.abs(precision / N)\n let psi\n let Sij\n if (computeVectors) {\n Sij = new Array(N)\n // Sij is Identity Matrix\n for (let i = 0; i < N; i++) {\n Sij[i] = Array(N).fill(0)\n Sij[i][i] = 1.0\n }\n }\n // initial error\n let Vab = getAij(x)\n while (Math.abs(Vab[1]) >= Math.abs(e0)) {\n const i = Vab[0][0]\n const j = Vab[0][1]\n psi = getTheta(x[i][i], x[j][j], x[i][j])\n x = x1(x, psi, i, j)\n if (computeVectors) Sij = Sij1(Sij, psi, i, j)\n Vab = getAij(x)\n }\n const Ei = Array(N).fill(0) // eigenvalues\n for (let i = 0; i < N; i++) {\n Ei[i] = x[i][i]\n }\n return sorting(clone(Ei), Sij, computeVectors)\n }\n\n // diagonalization implementation for bigNumber\n function diagBig (x, precision, computeVectors) {\n const N = x.length\n const e0 = abs(precision / N)\n let psi\n let Sij\n if (computeVectors) {\n Sij = new Array(N)\n // Sij is Identity Matrix\n for (let i = 0; i < N; i++) {\n Sij[i] = Array(N).fill(0)\n Sij[i][i] = 1.0\n }\n }\n // initial error\n let Vab = getAijBig(x)\n while (abs(Vab[1]) >= abs(e0)) {\n const i = Vab[0][0]\n const j = Vab[0][1]\n psi = getThetaBig(x[i][i], x[j][j], x[i][j])\n x = x1Big(x, psi, i, j)\n if (computeVectors) Sij = Sij1Big(Sij, psi, i, j)\n Vab = getAijBig(x)\n }\n const Ei = Array(N).fill(0) // eigenvalues\n for (let i = 0; i < N; i++) {\n Ei[i] = x[i][i]\n }\n // return [clone(Ei), clone(Sij)]\n return sorting(clone(Ei), Sij, computeVectors)\n }\n\n // get angle\n function getTheta (aii, ajj, aij) {\n const denom = (ajj - aii)\n if (Math.abs(denom) <= config.relTol) {\n return Math.PI / 4.0\n } else {\n return 0.5 * Math.atan(2.0 * aij / (ajj - aii))\n }\n }\n\n // get angle\n function getThetaBig (aii, ajj, aij) {\n const denom = subtract(ajj, aii)\n if (abs(denom) <= config.relTol) {\n return bignumber(-1).acos().div(4)\n } else {\n return multiplyScalar(0.5, atan(multiply(2.0, aij, inv(denom))))\n }\n }\n\n // update eigvec\n function Sij1 (Sij, theta, i, j) {\n const N = Sij.length\n const c = Math.cos(theta)\n const s = Math.sin(theta)\n const Ski = Array(N).fill(0)\n const Skj = Array(N).fill(0)\n for (let k = 0; k < N; k++) {\n Ski[k] = c * Sij[k][i] - s * Sij[k][j]\n Skj[k] = s * Sij[k][i] + c * Sij[k][j]\n }\n for (let k = 0; k < N; k++) {\n Sij[k][i] = Ski[k]\n Sij[k][j] = Skj[k]\n }\n return Sij\n }\n // update eigvec for overlap\n function Sij1Big (Sij, theta, i, j) {\n const N = Sij.length\n const c = cos(theta)\n const s = sin(theta)\n const Ski = Array(N).fill(bignumber(0))\n const Skj = Array(N).fill(bignumber(0))\n for (let k = 0; k < N; k++) {\n Ski[k] = subtract(multiplyScalar(c, Sij[k][i]), multiplyScalar(s, Sij[k][j]))\n Skj[k] = addScalar(multiplyScalar(s, Sij[k][i]), multiplyScalar(c, Sij[k][j]))\n }\n for (let k = 0; k < N; k++) {\n Sij[k][i] = Ski[k]\n Sij[k][j] = Skj[k]\n }\n return Sij\n }\n\n // update matrix\n function x1Big (Hij, theta, i, j) {\n const N = Hij.length\n const c = bignumber(cos(theta))\n const s = bignumber(sin(theta))\n const c2 = multiplyScalar(c, c)\n const s2 = multiplyScalar(s, s)\n const Aki = Array(N).fill(bignumber(0))\n const Akj = Array(N).fill(bignumber(0))\n // 2cs Hij\n const csHij = multiply(bignumber(2), c, s, Hij[i][j])\n // Aii\n const Aii = addScalar(subtract(multiplyScalar(c2, Hij[i][i]), csHij), multiplyScalar(s2, Hij[j][j]))\n const Ajj = add(multiplyScalar(s2, Hij[i][i]), csHij, multiplyScalar(c2, Hij[j][j]))\n // 0 to i\n for (let k = 0; k < N; k++) {\n Aki[k] = subtract(multiplyScalar(c, Hij[i][k]), multiplyScalar(s, Hij[j][k]))\n Akj[k] = addScalar(multiplyScalar(s, Hij[i][k]), multiplyScalar(c, Hij[j][k]))\n }\n // Modify Hij\n Hij[i][i] = Aii\n Hij[j][j] = Ajj\n Hij[i][j] = bignumber(0)\n Hij[j][i] = bignumber(0)\n // 0 to i\n for (let k = 0; k < N; k++) {\n if (k !== i && k !== j) {\n Hij[i][k] = Aki[k]\n Hij[k][i] = Aki[k]\n Hij[j][k] = Akj[k]\n Hij[k][j] = Akj[k]\n }\n }\n return Hij\n }\n\n // update matrix\n function x1 (Hij, theta, i, j) {\n const N = Hij.length\n const c = Math.cos(theta)\n const s = Math.sin(theta)\n const c2 = c * c\n const s2 = s * s\n const Aki = Array(N).fill(0)\n const Akj = Array(N).fill(0)\n // Aii\n const Aii = c2 * Hij[i][i] - 2 * c * s * Hij[i][j] + s2 * Hij[j][j]\n const Ajj = s2 * Hij[i][i] + 2 * c * s * Hij[i][j] + c2 * Hij[j][j]\n // 0 to i\n for (let k = 0; k < N; k++) {\n Aki[k] = c * Hij[i][k] - s * Hij[j][k]\n Akj[k] = s * Hij[i][k] + c * Hij[j][k]\n }\n // Modify Hij\n Hij[i][i] = Aii\n Hij[j][j] = Ajj\n Hij[i][j] = 0\n Hij[j][i] = 0\n // 0 to i\n for (let k = 0; k < N; k++) {\n if (k !== i && k !== j) {\n Hij[i][k] = Aki[k]\n Hij[k][i] = Aki[k]\n Hij[j][k] = Akj[k]\n Hij[k][j] = Akj[k]\n }\n }\n return Hij\n }\n\n // get max off-diagonal value from Upper Diagonal\n function getAij (Mij) {\n const N = Mij.length\n let maxMij = 0\n let maxIJ = [0, 1]\n for (let i = 0; i < N; i++) {\n for (let j = i + 1; j < N; j++) {\n if (Math.abs(maxMij) < Math.abs(Mij[i][j])) {\n maxMij = Math.abs(Mij[i][j])\n maxIJ = [i, j]\n }\n }\n }\n return [maxIJ, maxMij]\n }\n\n // get max off-diagonal value from Upper Diagonal\n function getAijBig (Mij) {\n const N = Mij.length\n let maxMij = 0\n let maxIJ = [0, 1]\n for (let i = 0; i < N; i++) {\n for (let j = i + 1; j < N; j++) {\n if (abs(maxMij) < abs(Mij[i][j])) {\n maxMij = abs(Mij[i][j])\n maxIJ = [i, j]\n }\n }\n }\n return [maxIJ, maxMij]\n }\n\n // sort results\n function sorting (E, S, computeVectors) {\n const N = E.length\n const values = Array(N)\n let vecs\n if (computeVectors) {\n vecs = Array(N)\n for (let k = 0; k < N; k++) {\n vecs[k] = Array(N)\n }\n }\n for (let i = 0; i < N; i++) {\n let minID = 0\n let minE = E[0]\n for (let j = 0; j < E.length; j++) {\n if (abs(E[j]) < abs(minE)) {\n minID = j\n minE = E[minID]\n }\n }\n values[i] = E.splice(minID, 1)[0]\n if (computeVectors) {\n for (let k = 0; k < N; k++) {\n vecs[i][k] = S[k][minID]\n S[k].splice(minID, 1)\n }\n }\n }\n if (!computeVectors) return { values }\n const eigenvectors = vecs.map((vector, i) => ({ value: values[i], vector }))\n return { values, eigenvectors }\n }\n\n return main\n}\n","import { clone } from '../../../utils/object.js'\n\nexport function createComplexEigs ({ addScalar, subtract, flatten, multiply, multiplyScalar, divideScalar, sqrt, abs, bignumber, diag, size, reshape, inv, qr, usolve, usolveAll, equal, complex, larger, smaller, matrixFromColumns, dot }) {\n /**\n * @param {number[][]} arr the matrix to find eigenvalues of\n * @param {number} N size of the matrix\n * @param {number|BigNumber} prec precision, anything lower will be considered zero\n * @param {'number'|'BigNumber'|'Complex'} type\n * @param {boolean} findVectors should we find eigenvectors?\n *\n * @returns {{ values: number[], vectors: number[][] }}\n */\n function complexEigs (arr, N, prec, type, findVectors = true) {\n // TODO check if any row/col are zero except the diagonal\n\n // make sure corresponding rows and columns have similar magnitude\n // important because of numerical stability\n // MODIFIES arr by side effect!\n const R = balance(arr, N, prec, type, findVectors)\n\n // R is the row transformation matrix\n // arr = A' = R A R^-1, A is the original matrix\n // (if findVectors is false, R is undefined)\n // (And so to return to original matrix: A = R^-1 arr R)\n\n // TODO if magnitudes of elements vary over many orders,\n // move greatest elements to the top left corner\n\n // using similarity transformations, reduce the matrix\n // to Hessenberg form (upper triangular plus one subdiagonal row)\n // updates the transformation matrix R with new row operationsq\n // MODIFIES arr by side effect!\n reduceToHessenberg(arr, N, prec, type, findVectors, R)\n // still true that original A = R^-1 arr R)\n\n // find eigenvalues\n const { values, C } = iterateUntilTriangular(arr, N, prec, type, findVectors)\n\n // values is the list of eigenvalues, C is the column\n // transformation matrix that transforms arr, the hessenberg\n // matrix, to upper triangular\n // (So U = C^-1 arr C and the relationship between current arr\n // and original A is unchanged.)\n\n if (findVectors) {\n const eigenvectors = findEigenvectors(arr, N, C, R, values, prec, type)\n return { values, eigenvectors }\n }\n\n return { values }\n }\n\n /**\n * @param {number[][]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {number[][]}\n */\n function balance (arr, N, prec, type, findVectors) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n const realzero = big ? bignumber(0) : 0\n const one = big ? bignumber(1) : cplx ? complex(1) : 1\n const realone = big ? bignumber(1) : 1\n\n // base of the floating-point arithmetic\n const radix = big ? bignumber(10) : 2\n const radixSq = multiplyScalar(radix, radix)\n\n // the diagonal transformation matrix R\n let Rdiag\n if (findVectors) {\n Rdiag = Array(N).fill(one)\n }\n\n // this isn't the only time we loop thru the matrix...\n let last = false\n\n while (!last) {\n // ...haha I'm joking! unless...\n last = true\n\n for (let i = 0; i < N; i++) {\n // compute the taxicab norm of i-th column and row\n // TODO optimize for complex numbers\n let colNorm = realzero\n let rowNorm = realzero\n\n for (let j = 0; j < N; j++) {\n if (i === j) continue\n colNorm = addScalar(colNorm, abs(arr[j][i]))\n rowNorm = addScalar(rowNorm, abs(arr[i][j]))\n }\n\n if (!equal(colNorm, 0) && !equal(rowNorm, 0)) {\n // find integer power closest to balancing the matrix\n // (we want to scale only by integer powers of radix,\n // so that we don't lose any precision due to round-off)\n\n let f = realone\n let c = colNorm\n\n const rowDivRadix = divideScalar(rowNorm, radix)\n const rowMulRadix = multiplyScalar(rowNorm, radix)\n\n while (smaller(c, rowDivRadix)) {\n c = multiplyScalar(c, radixSq)\n f = multiplyScalar(f, radix)\n }\n while (larger(c, rowMulRadix)) {\n c = divideScalar(c, radixSq)\n f = divideScalar(f, radix)\n }\n\n // check whether balancing is needed\n // condition = (c + rowNorm) / f < 0.95 * (colNorm + rowNorm)\n const condition = smaller(divideScalar(addScalar(c, rowNorm), f), multiplyScalar(addScalar(colNorm, rowNorm), 0.95))\n\n // apply balancing similarity transformation\n if (condition) {\n // we should loop once again to check whether\n // another rebalancing is needed\n last = false\n\n const g = divideScalar(1, f)\n\n for (let j = 0; j < N; j++) {\n if (i === j) {\n continue\n }\n arr[i][j] = multiplyScalar(arr[i][j], g)\n arr[j][i] = multiplyScalar(arr[j][i], f)\n }\n\n // keep track of transformations\n if (findVectors) {\n Rdiag[i] = multiplyScalar(Rdiag[i], g)\n }\n }\n }\n }\n }\n\n // return the diagonal row transformation matrix\n return findVectors ? diag(Rdiag) : null\n }\n\n /**\n * @param {number[][]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number'|'BigNumber'|'Complex'} type\n * @param {boolean} findVectors\n * @param {number[][]} R the row transformation matrix that will be modified\n */\n function reduceToHessenberg (arr, N, prec, type, findVectors, R) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n\n if (big) { prec = bignumber(prec) }\n\n for (let i = 0; i < N - 2; i++) {\n // Find the largest subdiag element in the i-th col\n\n let maxIndex = 0\n let max = zero\n\n for (let j = i + 1; j < N; j++) {\n const el = arr[j][i]\n if (smaller(abs(max), abs(el))) {\n max = el\n maxIndex = j\n }\n }\n\n // This col is pivoted, no need to do anything\n if (smaller(abs(max), prec)) {\n continue\n }\n\n if (maxIndex !== i + 1) {\n // Interchange maxIndex-th and (i+1)-th row\n const tmp1 = arr[maxIndex]\n arr[maxIndex] = arr[i + 1]\n arr[i + 1] = tmp1\n\n // Interchange maxIndex-th and (i+1)-th column\n for (let j = 0; j < N; j++) {\n const tmp2 = arr[j][maxIndex]\n arr[j][maxIndex] = arr[j][i + 1]\n arr[j][i + 1] = tmp2\n }\n\n // keep track of transformations\n if (findVectors) {\n const tmp3 = R[maxIndex]\n R[maxIndex] = R[i + 1]\n R[i + 1] = tmp3\n }\n }\n\n // Reduce following rows and columns\n for (let j = i + 2; j < N; j++) {\n const n = divideScalar(arr[j][i], max)\n\n if (n === 0) {\n continue\n }\n\n // from j-th row subtract n-times (i+1)th row\n for (let k = 0; k < N; k++) {\n arr[j][k] = subtract(arr[j][k], multiplyScalar(n, arr[i + 1][k]))\n }\n\n // to (i+1)th column add n-times j-th column\n for (let k = 0; k < N; k++) {\n arr[k][i + 1] = addScalar(arr[k][i + 1], multiplyScalar(n, arr[k][j]))\n }\n\n // keep track of transformations\n if (findVectors) {\n for (let k = 0; k < N; k++) {\n R[j][k] = subtract(R[j][k], multiplyScalar(n, R[i + 1][k]))\n }\n }\n }\n }\n\n return R\n }\n\n /**\n * @returns {{values: values, C: Matrix}}\n * @see Press, Wiliams: Numerical recipes in Fortran 77\n * @see https://en.wikipedia.org/wiki/QR_algorithm\n */\n function iterateUntilTriangular (A, N, prec, type, findVectors) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n if (big) { prec = bignumber(prec) }\n\n // The Francis Algorithm\n // The core idea of this algorithm is that doing successive\n // A' = QtAQ transformations will eventually converge to block-\n // upper-triangular with diagonal blocks either 1x1 or 2x2.\n // The Q here is the one from the QR decomposition, A = QR.\n // Since the eigenvalues of a block-upper-triangular matrix are\n // the eigenvalues of its diagonal blocks and we know how to find\n // eigenvalues of a 2x2 matrix, we know the eigenvalues of A.\n\n let arr = clone(A)\n\n // the list of converged eigenvalues\n const lambdas = []\n\n // size of arr, which will get smaller as eigenvalues converge\n let n = N\n\n // the diagonal of the block-diagonal matrix that turns\n // converged 2x2 matrices into upper triangular matrices\n const Sdiag = []\n\n // N×N matrix describing the overall transformation done during the QR algorithm\n let Qtotal = findVectors ? diag(Array(N).fill(one)) : undefined\n\n // nxn matrix describing the QR transformations done since last convergence\n let Qpartial = findVectors ? diag(Array(n).fill(one)) : undefined\n\n // last eigenvalue converged before this many steps\n let lastConvergenceBefore = 0\n\n while (lastConvergenceBefore <= 100) {\n lastConvergenceBefore += 1\n\n // TODO if the convergence is slow, do something clever\n\n // Perform the factorization\n\n const k = arr[n - 1][n - 1] // TODO this is apparently a somewhat\n // old-fashioned choice; ideally set close to an eigenvalue, or\n // perhaps better yet switch to the implicit QR version that is sometimes\n // specifically called the \"Francis algorithm\" that is alluded to\n // in the following TODO. (Or perhaps we switch to an independently\n // optimized third-party package for the linear algebra operations...)\n\n for (let i = 0; i < n; i++) {\n arr[i][i] = subtract(arr[i][i], k)\n }\n\n // TODO do an implicit QR transformation\n const { Q, R } = qr(arr)\n arr = multiply(R, Q)\n\n for (let i = 0; i < n; i++) {\n arr[i][i] = addScalar(arr[i][i], k)\n }\n\n // keep track of transformations\n if (findVectors) {\n Qpartial = multiply(Qpartial, Q)\n }\n\n // The rightmost diagonal element converged to an eigenvalue\n if (n === 1 || smaller(abs(arr[n - 1][n - 2]), prec)) {\n lastConvergenceBefore = 0\n lambdas.push(arr[n - 1][n - 1])\n\n // keep track of transformations\n if (findVectors) {\n Sdiag.unshift([[1]])\n inflateMatrix(Qpartial, N)\n Qtotal = multiply(Qtotal, Qpartial)\n\n if (n > 1) {\n Qpartial = diag(Array(n - 1).fill(one))\n }\n }\n\n // reduce the matrix size\n n -= 1\n arr.pop()\n for (let i = 0; i < n; i++) {\n arr[i].pop()\n }\n\n // The rightmost diagonal 2x2 block converged\n } else if (n === 2 || smaller(abs(arr[n - 2][n - 3]), prec)) {\n lastConvergenceBefore = 0\n const ll = eigenvalues2x2(\n arr[n - 2][n - 2], arr[n - 2][n - 1],\n arr[n - 1][n - 2], arr[n - 1][n - 1]\n )\n lambdas.push(...ll)\n\n // keep track of transformations\n if (findVectors) {\n Sdiag.unshift(jordanBase2x2(\n arr[n - 2][n - 2], arr[n - 2][n - 1],\n arr[n - 1][n - 2], arr[n - 1][n - 1],\n ll[0], ll[1], prec, type\n ))\n inflateMatrix(Qpartial, N)\n Qtotal = multiply(Qtotal, Qpartial)\n if (n > 2) {\n Qpartial = diag(Array(n - 2).fill(one))\n }\n }\n\n // reduce the matrix size\n n -= 2\n arr.pop()\n arr.pop()\n for (let i = 0; i < n; i++) {\n arr[i].pop()\n arr[i].pop()\n }\n }\n\n if (n === 0) {\n break\n }\n }\n\n // standard sorting\n lambdas.sort((a, b) => +subtract(abs(a), abs(b)))\n\n // the algorithm didn't converge\n if (lastConvergenceBefore > 100) {\n const err = Error('The eigenvalues failed to converge. Only found these eigenvalues: ' + lambdas.join(', '))\n err.values = lambdas\n err.vectors = []\n throw err\n }\n\n // combine the overall QR transformation Qtotal with the subsequent\n // transformation S that turns the diagonal 2x2 blocks to upper triangular\n const C = findVectors ? multiply(Qtotal, blockDiag(Sdiag, N)) : undefined\n\n return { values: lambdas, C }\n }\n\n /**\n * @param {Matrix} A hessenberg-form matrix\n * @param {number} N size of A\n * @param {Matrix} C column transformation matrix that turns A into upper triangular\n * @param {Matrix} R similarity that turns original matrix into A\n * @param {number[]} values array of eigenvalues of A\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {number[][]} eigenvalues\n */\n function findEigenvectors (A, N, C, R, values, prec, type) {\n const Cinv = inv(C)\n const U = multiply(Cinv, A, C)\n\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n // turn values into a kind of \"multiset\"\n // this way it is easier to find eigenvectors\n const uniqueValues = []\n const multiplicities = []\n\n for (const lambda of values) {\n const i = indexOf(uniqueValues, lambda, equal)\n\n if (i === -1) {\n uniqueValues.push(lambda)\n multiplicities.push(1)\n } else {\n multiplicities[i] += 1\n }\n }\n\n // find eigenvectors by solving U − lambdaE = 0\n // TODO replace with an iterative eigenvector algorithm\n // (this one might fail for imprecise eigenvalues)\n\n const vectors = []\n const len = uniqueValues.length\n const b = Array(N).fill(zero)\n const E = diag(Array(N).fill(one))\n\n for (let i = 0; i < len; i++) {\n const lambda = uniqueValues[i]\n const S = subtract(U, multiply(lambda, E)) // the characteristic matrix\n\n let solutions = usolveAll(S, b)\n solutions.shift() // ignore the null vector\n\n // looks like we missed something, try inverse iteration\n // But if that fails, just presume that the original matrix truly\n // was defective.\n while (solutions.length < multiplicities[i]) {\n const approxVec = inverseIterate(S, N, solutions, prec, type)\n if (approxVec === null) { break } // no more vectors were found\n solutions.push(approxVec)\n }\n\n // Transform back into original array coordinates\n const correction = multiply(inv(R), C)\n solutions = solutions.map(v => multiply(correction, v))\n\n vectors.push(\n ...solutions.map(v => ({ value: lambda, vector: flatten(v) })))\n }\n\n return vectors\n }\n\n /**\n * Compute the eigenvalues of an 2x2 matrix\n * @return {[number,number]}\n */\n function eigenvalues2x2 (a, b, c, d) {\n // lambda_+- = 1/2 trA +- 1/2 sqrt( tr^2 A - 4 detA )\n const trA = addScalar(a, d)\n const detA = subtract(multiplyScalar(a, d), multiplyScalar(b, c))\n const x = multiplyScalar(trA, 0.5)\n const y = multiplyScalar(sqrt(subtract(multiplyScalar(trA, trA), multiplyScalar(4, detA))), 0.5)\n\n return [addScalar(x, y), subtract(x, y)]\n }\n\n /**\n * For an 2x2 matrix compute the transformation matrix S,\n * so that SAS^-1 is an upper triangular matrix\n * @return {[[number,number],[number,number]]}\n * @see https://math.berkeley.edu/~ogus/old/Math_54-05/webfoils/jordan.pdf\n * @see http://people.math.harvard.edu/~knill/teaching/math21b2004/exhibits/2dmatrices/index.html\n */\n function jordanBase2x2 (a, b, c, d, l1, l2, prec, type) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n // matrix is already upper triangular\n // return an identity matrix\n if (smaller(abs(c), prec)) {\n return [[one, zero], [zero, one]]\n }\n\n // matrix is diagonalizable\n // return its eigenvectors as columns\n if (larger(abs(subtract(l1, l2)), prec)) {\n return [[subtract(l1, d), subtract(l2, d)], [c, c]]\n }\n\n // matrix is not diagonalizable\n // compute diagonal elements of N = A - lambdaI\n const na = subtract(a, l1)\n const nd = subtract(d, l1)\n\n // col(N,2) = 0 implies S = ( col(N,1), e_1 )\n // col(N,2) != 0 implies S = ( col(N,2), e_2 )\n\n if (smaller(abs(b), prec) && smaller(abs(nd), prec)) {\n return [[na, one], [c, zero]]\n } else {\n return [[b, zero], [nd, one]]\n }\n }\n\n /**\n * Enlarge the matrix from nxn to NxN, setting the new\n * elements to 1 on diagonal and 0 elsewhere\n */\n function inflateMatrix (arr, N) {\n // add columns\n for (let i = 0; i < arr.length; i++) {\n arr[i].push(...Array(N - arr[i].length).fill(0))\n }\n\n // add rows\n for (let i = arr.length; i < N; i++) {\n arr.push(Array(N).fill(0))\n arr[i][i] = 1\n }\n\n return arr\n }\n\n /**\n * Create a block-diagonal matrix with the given square matrices on the diagonal\n * @param {Matrix[] | number[][][]} arr array of matrices to be placed on the diagonal\n * @param {number} N the size of the resulting matrix\n */\n function blockDiag (arr, N) {\n const M = []\n for (let i = 0; i < N; i++) {\n M[i] = Array(N).fill(0)\n }\n\n let I = 0\n for (const sub of arr) {\n const n = sub.length\n\n for (let i = 0; i < n; i++) {\n for (let j = 0; j < n; j++) {\n M[I + i][I + j] = sub[i][j]\n }\n }\n\n I += n\n }\n\n return M\n }\n\n /**\n * Finds the index of an element in an array using a custom equality function\n * @template T\n * @param {Array} arr array in which to search\n * @param {T} el the element to find\n * @param {function(T, T): boolean} fn the equality function, first argument is an element of `arr`, the second is always `el`\n * @returns {number} the index of `el`, or -1 when it's not in `arr`\n */\n function indexOf (arr, el, fn) {\n for (let i = 0; i < arr.length; i++) {\n if (fn(arr[i], el)) {\n return i\n }\n }\n return -1\n }\n\n /**\n * Provided a near-singular upper-triangular matrix A and a list of vectors,\n * finds an eigenvector of A with the smallest eigenvalue, which is orthogonal\n * to each vector in the list\n * @template T\n * @param {T[][]} A near-singular square matrix\n * @param {number} N dimension\n * @param {T[][]} orthog list of vectors\n * @param {number} prec epsilon\n * @param {'number'|'BigNumber'|'Complex'} type\n * @return {T[] | null} eigenvector\n *\n * @see Numerical Recipes for Fortran 77 – 11.7 Eigenvalues or Eigenvectors by Inverse Iteration\n */\n function inverseIterate (A, N, orthog, prec, type) {\n const largeNum = type === 'BigNumber' ? bignumber(1000) : 1000\n\n let b // the vector\n\n // you better choose a random vector before I count to five\n let i = 0\n for (; i < 5; ++i) {\n b = randomOrthogonalVector(N, orthog, type)\n try {\n b = usolve(A, b)\n } catch {\n // That direction didn't work, likely because the original matrix\n // was defective. But still make the full number of tries...\n continue\n }\n if (larger(norm(b), largeNum)) { break }\n }\n if (i >= 5) {\n return null // couldn't find any orthogonal vector in the image\n }\n\n // you better converge before I count to ten\n i = 0\n while (true) {\n const c = usolve(A, b)\n\n if (smaller(norm(orthogonalComplement(b, [c])), prec)) { break }\n if (++i >= 10) { return null }\n\n b = normalize(c)\n }\n\n return b\n }\n\n /**\n * Generates a random unit vector of dimension N, orthogonal to each vector in the list\n * @template T\n * @param {number} N dimension\n * @param {T[][]} orthog list of vectors\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {T[]} random vector\n */\n function randomOrthogonalVector (N, orthog, type) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n\n // generate random vector with the correct type\n let v = Array(N).fill(0).map(_ => 2 * Math.random() - 1)\n if (big) { v = v.map(n => bignumber(n)) }\n if (cplx) { v = v.map(n => complex(n)) }\n\n // project to orthogonal complement\n v = orthogonalComplement(v, orthog)\n\n // normalize\n return normalize(v, type)\n }\n\n /**\n * Project vector v to the orthogonal complement of an array of vectors\n */\n function orthogonalComplement (v, orthog) {\n const vectorShape = size(v)\n for (let w of orthog) {\n w = reshape(w, vectorShape) // make sure this is just a vector computation\n // v := v − (w, v)/|w|^2 w\n v = subtract(v, multiply(divideScalar(dot(w, v), dot(w, w)), w))\n }\n\n return v\n }\n\n /**\n * Calculate the norm of a vector.\n * We can't use math.norm because factory can't handle circular dependency.\n * Seriously, I'm really fed up with factory.\n */\n function norm (v) {\n return abs(sqrt(dot(v, v)))\n }\n\n /**\n * Normalize a vector\n * @template T\n * @param {T[]} v\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {T[]} normalized vec\n */\n function normalize (v, type) {\n const big = type === 'BigNumber'\n const cplx = type === 'Complex'\n const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n return multiply(divideScalar(one, norm(v)), v)\n }\n\n return complexEigs\n}\n","import { isSparseMatrix } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'expm'\nconst dependencies = ['typed', 'abs', 'add', 'identity', 'inv', 'multiply']\n\nexport const createExpm = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, identity, inv, multiply }) => {\n /**\n * Compute the matrix exponential, expm(A) = e^A. The matrix must be square.\n * Not to be confused with exp(a), which performs element-wise\n * exponentiation.\n *\n * The exponential is calculated using the Padé approximant with scaling and\n * squaring; see \"Nineteen Dubious Ways to Compute the Exponential of a\n * Matrix,\" by Moler and Van Loan.\n *\n * Syntax:\n *\n * math.expm(x)\n *\n * Examples:\n *\n * const A = [[0,2],[0,0]]\n * math.expm(A) // returns [[1,2],[0,1]]\n *\n * See also:\n *\n * exp\n *\n * @param {Matrix} x A square Matrix\n * @return {Matrix} The exponential of x\n */\n return typed(name, {\n\n Matrix: function (A) {\n // Check matrix size\n const size = A.size()\n\n if (size.length !== 2 || size[0] !== size[1]) {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n\n const n = size[0]\n\n // Desired accuracy of the approximant (The actual accuracy\n // will be affected by round-off error)\n const eps = 1e-15\n\n // The Padé approximant is not so accurate when the values of A\n // are \"large\", so scale A by powers of two. Then compute the\n // exponential, and square the result repeatedly according to\n // the identity e^A = (e^(A/m))^m\n\n // Compute infinity-norm of A, ||A||, to see how \"big\" it is\n const infNorm = infinityNorm(A)\n\n // Find the optimal scaling factor and number of terms in the\n // Padé approximant to reach the desired accuracy\n const params = findParams(infNorm, eps)\n const q = params.q\n const j = params.j\n\n // The Pade approximation to e^A is:\n // Rqq(A) = Dqq(A) ^ -1 * Nqq(A)\n // where\n // Nqq(A) = sum(i=0, q, (2q-i)!p! / [ (2q)!i!(q-i)! ] A^i\n // Dqq(A) = sum(i=0, q, (2q-i)!q! / [ (2q)!i!(q-i)! ] (-A)^i\n\n // Scale A by 1 / 2^j\n const Apos = multiply(A, Math.pow(2, -j))\n\n // The i=0 term is just the identity matrix\n let N = identity(n)\n let D = identity(n)\n\n // Initialization (i=0)\n let factor = 1\n\n // Initialization (i=1)\n let AposToI = Apos // Cloning not necessary\n let alternate = -1\n\n for (let i = 1; i <= q; i++) {\n if (i > 1) {\n AposToI = multiply(AposToI, Apos)\n alternate = -alternate\n }\n factor = factor * (q - i + 1) / ((2 * q - i + 1) * i)\n\n N = add(N, multiply(factor, AposToI))\n D = add(D, multiply(factor * alternate, AposToI))\n }\n\n let R = multiply(inv(D), N)\n\n // Square j times\n for (let i = 0; i < j; i++) {\n R = multiply(R, R)\n }\n\n return isSparseMatrix(A)\n ? A.createSparseMatrix(R)\n : R\n }\n\n })\n\n function infinityNorm (A) {\n const n = A.size()[0]\n let infNorm = 0\n for (let i = 0; i < n; i++) {\n let rowSum = 0\n for (let j = 0; j < n; j++) {\n rowSum += abs(A.get([i, j]))\n }\n infNorm = Math.max(rowSum, infNorm)\n }\n return infNorm\n }\n\n /**\n * Find the best parameters for the Pade approximant given\n * the matrix norm and desired accuracy. Returns the first acceptable\n * combination in order of increasing computational load.\n */\n function findParams (infNorm, eps) {\n const maxSearchSize = 30\n for (let k = 0; k < maxSearchSize; k++) {\n for (let q = 0; q <= k; q++) {\n const j = k - q\n if (errorEstimate(infNorm, q, j) < eps) {\n return { q, j }\n }\n }\n }\n throw new Error('Could not find acceptable parameters to compute the matrix exponential (try increasing maxSearchSize in expm.js)')\n }\n\n /**\n * Returns the estimated error of the Pade approximant for the given\n * parameters.\n */\n function errorEstimate (infNorm, q, j) {\n let qfac = 1\n for (let i = 2; i <= q; i++) {\n qfac *= i\n }\n let twoqfac = qfac\n for (let i = q + 1; i <= 2 * q; i++) {\n twoqfac *= i\n }\n const twoqp1fac = twoqfac * (2 * q + 1)\n\n return 8.0 *\n Math.pow(infNorm / Math.pow(2, j), 2 * q) *\n qfac * qfac / (twoqfac * twoqp1fac)\n }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'sqrtm'\nconst dependencies = ['typed', 'abs', 'add', 'multiply', 'map', 'sqrt', 'subtract', 'inv', 'size', 'max', 'identity']\n\nexport const createSqrtm = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, multiply, map, sqrt, subtract, inv, size, max, identity }) => {\n const _maxIterations = 1e3\n const _tolerance = 1e-6\n\n /**\n * Calculate the principal square root matrix using the Denman–Beavers iterative method\n *\n * https://en.wikipedia.org/wiki/Square_root_of_a_matrix#By_Denman–Beavers_iteration\n *\n * @param {Array | Matrix} A The square matrix `A`\n * @return {Array | Matrix} The principal square root of matrix `A`\n * @private\n */\n function _denmanBeavers (A) {\n let error\n let iterations = 0\n\n let Y = A\n let Z = identity(size(A))\n\n do {\n const Yk = Y\n Y = multiply(0.5, add(Yk, inv(Z)))\n Z = multiply(0.5, add(Z, inv(Yk)))\n\n error = max(abs(subtract(Y, Yk)))\n\n if (error > _tolerance && ++iterations > _maxIterations) {\n throw new Error('computing square root of matrix: iterative method could not converge')\n }\n } while (error > _tolerance)\n\n return Y\n }\n\n /**\n * Calculate the principal square root of a square matrix.\n * The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.\n *\n * https://en.wikipedia.org/wiki/Square_root_of_a_matrix\n *\n * Syntax:\n *\n * math.sqrtm(A)\n *\n * Examples:\n *\n * math.sqrtm([[33, 24], [48, 57]]) // returns [[5, 2], [4, 7]]\n *\n * See also:\n *\n * sqrt, pow\n *\n * @param {Array | Matrix} A The square matrix `A`\n * @return {Array | Matrix} The principal square root of matrix `A`\n */\n return typed(name, {\n 'Array | Matrix': function (A) {\n const size = isMatrix(A) ? A.size() : arraySize(A)\n switch (size.length) {\n case 1:\n // Single element Array | Matrix\n if (size[0] === 1) {\n return map(A, sqrt)\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n\n case 2:\n {\n // Two-dimensional Array | Matrix\n const rows = size[0]\n const cols = size[1]\n if (rows === cols) {\n return _denmanBeavers(A)\n } else {\n throw new RangeError('Matrix must be square ' +\n '(size: ' + format(size) + ')')\n }\n }\n default:\n // Multi dimensional array\n throw new RangeError('Matrix must be at most two dimensional ' +\n '(size: ' + format(size) + ')')\n }\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'sylvester'\nconst dependencies = [\n 'typed',\n 'schur',\n 'matrixFromColumns',\n 'matrix',\n 'multiply',\n 'range',\n 'concat',\n 'transpose',\n 'index',\n 'subset',\n 'add',\n 'subtract',\n 'identity',\n 'lusolve',\n 'abs'\n]\n\nexport const createSylvester = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n schur,\n matrixFromColumns,\n matrix,\n multiply,\n range,\n concat,\n transpose,\n index,\n subset,\n add,\n subtract,\n identity,\n lusolve,\n abs\n }\n) => {\n /**\n *\n * Solves the real-valued Sylvester equation AX+XB=C for X, where A, B and C are\n * matrices of appropriate dimensions, being A and B squared. Notice that other\n * equivalent definitions for the Sylvester equation exist and this function\n * assumes the one presented in the original publication of the the Bartels-\n * Stewart algorithm, which is implemented by this function.\n * https://en.wikipedia.org/wiki/Sylvester_equation\n *\n * Syntax:\n *\n * math.sylvester(A, B, C)\n *\n * Examples:\n *\n * const A = [[-1, -2], [1, 1]]\n * const B = [[2, -1], [1, -2]]\n * const C = [[-3, 2], [3, 0]]\n * math.sylvester(A, B, C) // returns DenseMatrix [[-0.25, 0.25], [1.5, -1.25]]\n *\n * See also:\n *\n * schur, lyap\n *\n * @param {Matrix | Array} A Matrix A\n * @param {Matrix | Array} B Matrix B\n * @param {Matrix | Array} C Matrix C\n * @return {Matrix | Array} Matrix X, solving the Sylvester equation\n */\n return typed(name, {\n 'Matrix, Matrix, Matrix': _sylvester,\n 'Array, Matrix, Matrix': function (A, B, C) {\n return _sylvester(matrix(A), B, C)\n },\n 'Array, Array, Matrix': function (A, B, C) {\n return _sylvester(matrix(A), matrix(B), C)\n },\n 'Array, Matrix, Array': function (A, B, C) {\n return _sylvester(matrix(A), B, matrix(C))\n },\n 'Matrix, Array, Matrix': function (A, B, C) {\n return _sylvester(A, matrix(B), C)\n },\n 'Matrix, Array, Array': function (A, B, C) {\n return _sylvester(A, matrix(B), matrix(C))\n },\n 'Matrix, Matrix, Array': function (A, B, C) {\n return _sylvester(A, B, matrix(C))\n },\n 'Array, Array, Array': function (A, B, C) {\n return _sylvester(matrix(A), matrix(B), matrix(C)).toArray()\n }\n })\n function _sylvester (A, B, C) {\n const n = B.size()[0]\n const m = A.size()[0]\n\n const sA = schur(A)\n const F = sA.T\n const U = sA.U\n const sB = schur(multiply(-1, B))\n const G = sB.T\n const V = sB.U\n const D = multiply(multiply(transpose(U), C), V)\n const all = range(0, m)\n const y = []\n\n const hc = (a, b) => concat(a, b, 1)\n const vc = (a, b) => concat(a, b, 0)\n\n for (let k = 0; k < n; k++) {\n if (k < (n - 1) && abs(subset(G, index(k + 1, k))) > 1e-5) {\n let RHS = vc(subset(D, index(all, k)), subset(D, index(all, k + 1)))\n for (let j = 0; j < k; j++) {\n RHS = add(RHS,\n vc(multiply(y[j], subset(G, index(j, k))), multiply(y[j], subset(G, index(j, k + 1))))\n )\n }\n const gkk = multiply(identity(m), multiply(-1, subset(G, index(k, k))))\n const gmk = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k))))\n const gkm = multiply(identity(m), multiply(-1, subset(G, index(k, k + 1))))\n const gmm = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k + 1))))\n const LHS = vc(\n hc(add(F, gkk), gmk),\n hc(gkm, add(F, gmm))\n )\n const yAux = lusolve(LHS, RHS)\n y[k] = yAux.subset(index(range(0, m), 0))\n y[k + 1] = yAux.subset(index(range(m, 2 * m), 0))\n k++\n } else {\n let RHS = subset(D, index(all, k))\n for (let j = 0; j < k; j++) { RHS = add(RHS, multiply(y[j], subset(G, index(j, k)))) }\n const gkk = subset(G, index(k, k))\n const LHS = subtract(F, multiply(gkk, identity(m)))\n\n y[k] = lusolve(LHS, RHS)\n }\n }\n const Y = matrix(matrixFromColumns(...y))\n const X = multiply(U, multiply(Y, transpose(V)))\n\n return X\n }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'schur'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'identity',\n 'multiply',\n 'qr',\n 'norm',\n 'subtract'\n]\n\nexport const createSchur = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n matrix,\n identity,\n multiply,\n qr,\n norm,\n subtract\n }\n) => {\n /**\n *\n * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal\n * and T is upper quasi-triangular.\n * https://en.wikipedia.org/wiki/Schur_decomposition\n *\n * Syntax:\n *\n * math.schur(A)\n *\n * Examples:\n *\n * const A = [[1, 0], [-4, 3]]\n * math.schur(A) // returns {T: [[3, 4], [0, 1]], R: [[0, 1], [-1, 0]]}\n *\n * See also:\n *\n * sylvester, lyap, qr\n *\n * @param {Array | Matrix} A Matrix A\n * @return {{U: Array | Matrix, T: Array | Matrix}} Object containing both matrix U and T of the Schur Decomposition A=UTU'\n */\n return typed(name, {\n Array: function (X) {\n const r = _schur(matrix(X))\n return {\n U: r.U.valueOf(),\n T: r.T.valueOf()\n }\n },\n\n Matrix: function (X) {\n return _schur(X)\n }\n })\n function _schur (X) {\n const n = X.size()[0]\n let A = X\n let U = identity(n)\n let k = 0\n let A0\n do {\n A0 = A\n const QR = qr(A)\n const Q = QR.Q\n const R = QR.R\n A = multiply(R, Q)\n U = multiply(U, Q)\n if ((k++) > 100) { break }\n } while (norm(subtract(A, A0)) > 1e-4)\n return { U, T: A }\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'lyap'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'sylvester',\n 'multiply',\n 'transpose'\n]\n\nexport const createLyap = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n matrix,\n sylvester,\n multiply,\n transpose\n }\n) => {\n /**\n *\n * Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P, where\n * Q is an input matrix. When Q is symmetric, P is also symmetric. Notice\n * that different equivalent definitions exist for the Continuous-time\n * Lyapunov equation.\n * https://en.wikipedia.org/wiki/Lyapunov_equation\n *\n * Syntax:\n *\n * math.lyap(A, Q)\n *\n * Examples:\n *\n * const A = [[-2, 0], [1, -4]]\n * const Q = [[3, 1], [1, 3]]\n * const P = math.lyap(A, Q)\n *\n * See also:\n *\n * sylvester, schur\n *\n * @param {Matrix | Array} A Matrix A\n * @param {Matrix | Array} Q Matrix Q\n * @return {Matrix | Array} Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q\n */\n return typed(name, {\n 'Matrix, Matrix': function (A, Q) {\n return sylvester(A, transpose(A), multiply(-1, Q))\n },\n 'Array, Matrix': function (A, Q) {\n return sylvester(matrix(A), transpose(matrix(A)), multiply(-1, Q))\n },\n 'Matrix, Array': function (A, Q) {\n return sylvester(A, transpose(matrix(A)), matrix(multiply(-1, Q)))\n },\n 'Array, Array': function (A, Q) {\n return sylvester(matrix(A), transpose(matrix(A)), matrix(multiply(-1, Q))).toArray()\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\nimport { extend } from '../../utils/object.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'divide'\nconst dependencies = [\n 'typed',\n 'matrix',\n 'multiply',\n 'equalScalar',\n 'divideScalar',\n 'inv'\n]\n\nexport const createDivide = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, multiply, equalScalar, divideScalar, inv }) => {\n const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n /**\n * Divide two values, `x / y`.\n * To divide matrices, `x` is multiplied with the inverse of `y`: `x * inv(y)`.\n *\n * Syntax:\n *\n * math.divide(x, y)\n *\n * Examples:\n *\n * math.divide(2, 3) // returns number 0.6666666666666666\n *\n * const a = math.complex(5, 14)\n * const b = math.complex(4, 1)\n * math.divide(a, b) // returns Complex 2 + 3i\n *\n * const c = [[7, -6], [13, -4]]\n * const d = [[1, 2], [4, 3]]\n * math.divide(c, d) // returns Array [[-9, 4], [-11, 6]]\n *\n * const e = math.unit('18 km')\n * math.divide(e, 4.5) // returns Unit 4 km\n *\n * See also:\n *\n * multiply\n *\n * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Numerator\n * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix} y Denominator\n * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Quotient, `x / y`\n */\n return typed('divide', extend({\n // we extend the signatures of divideScalar with signatures dealing with matrices\n\n 'Array | Matrix, Array | Matrix': function (x, y) {\n // TODO: implement matrix right division using pseudo inverse\n // https://www.mathworks.nl/help/matlab/ref/mrdivide.html\n // https://www.gnu.org/software/octave/doc/interpreter/Arithmetic-Ops.html\n // https://stackoverflow.com/questions/12263932/how-does-gnu-octave-matrix-division-work-getting-unexpected-behaviour\n return multiply(x, inv(y))\n },\n\n 'DenseMatrix, any': function (x, y) {\n return matAlgo14xDs(x, y, divideScalar, false)\n },\n\n 'SparseMatrix, any': function (x, y) {\n return matAlgo11xS0s(x, y, divideScalar, false)\n },\n\n 'Array, any': function (x, y) {\n // use matrix implementation\n return matAlgo14xDs(matrix(x), y, divideScalar, false).valueOf()\n },\n\n 'any, Array | Matrix': function (x, y) {\n return multiply(x, inv(y))\n }\n }, divideScalar.signatures))\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'distance'\nconst dependencies = [\n 'typed',\n 'addScalar',\n 'subtractScalar',\n 'divideScalar',\n 'multiplyScalar',\n 'deepEqual',\n 'sqrt',\n 'abs'\n]\n\nexport const createDistance = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, subtractScalar, multiplyScalar, divideScalar, deepEqual, sqrt, abs }) => {\n /**\n * Calculates:\n * The eucledian distance between two points in N-dimensional spaces.\n * Distance between point and a line in 2 and 3 dimensional spaces.\n * Pairwise distance between a set of 2D or 3D points\n * NOTE:\n * When substituting coefficients of a line(a, b and c), use ax + by + c = 0 instead of ax + by = c\n * For parametric equation of a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, c)\n *\n * Syntax:\n *\n * math.distance([x1,y1], [x2,y2])\n * math.distance({pointOneX, pointOneY}, {pointTwoX, pointTwoY})\n * math.distance([x1,y1,z1], [x2,y2,z2])\n * math.distance({pointOneX, pointOneY, pointOneZ}, {pointTwoX, pointTwoY, pointTwoZ})\n * math.distance([x1,y1,z1,a1], [x2,y2,z2,a2])\n * math.distance([[x1,y1], [x2,y2], [x3,y3]])\n * math.distance([[x1,y1,z1], [x2,y2,z2], [x3,y3,z3]])\n * math.distance([pointX,pointY], [a,b,c])\n * math.distance([pointX,pointY], [lineOnePtX,lineOnePtY], [lineTwoPtX,lineTwoPtY])\n * math.distance({pointX, pointY}, {lineOnePtX, lineOnePtY}, {lineTwoPtX, lineTwoPtY})\n * math.distance([pointX,pointY,pointZ], [x0, y0, z0, a, b, c])\n * math.distance({pointX, pointY, pointZ}, {x0, y0, z0, a, b, c})\n *\n * Examples:\n * math.distance([0,0], [4,4]) // Returns 5.656854249492381\n * math.distance(\n * {pointOneX: 0, pointOneY: 0},\n * {pointTwoX: 10, pointTwoY: 10}) // Returns 14.142135623730951\n * math.distance([1, 0, 1], [4, -2, 2]) // Returns 3.7416573867739413\n * math.distance(\n * {pointOneX: 4, pointOneY: 5, pointOneZ: 8},\n * {pointTwoX: 2, pointTwoY: 7, pointTwoZ: 9}) // Returns 3\n * math.distance([1, 0, 1, 0], [0, -1, 0, -1]) // Returns 2\n * math.distance([[1, 2], [1, 2], [1, 3]]) // Returns [0, 1, 1]\n * math.distance([[1,2,4], [1,2,6], [8,1,3]]) // Returns [2, 7.14142842854285, 7.681145747868608]\n * math.distance([10, 10], [8, 1, 3]) // Returns 11.535230316796387\n * math.distance([0, 0], [3, 0], [0, 4]) // Returns 2.4\n * math.distance(\n * {pointX: 0, pointY: 0},\n * {lineOnePtX: 3, lineOnePtY: 0},\n * {lineTwoPtX: 0, lineTwoPtY: 4}) // Returns 2.4\n * math.distance([2, 3, 1], [1, 1, 2, 5, 0, 1]) // Returns 2.3204774044612857\n * math.distance(\n * {pointX: 2, pointY: 3, pointZ: 1},\n * {x0: 1, y0: 1, z0: 2, a: 5, b: 0, c: 1}) // Returns 2.3204774044612857\n *\n * @param {Array | Matrix | Object} x Co-ordinates of first point\n * @param {Array | Matrix | Object} y Co-ordinates of second point\n * @return {Number | BigNumber} Returns the distance from two/three points\n */\n return typed(name, {\n 'Array, Array, Array': function (x, y, z) {\n // Point to Line 2D (x=Point, y=LinePoint1, z=LinePoint2)\n if (x.length === 2 && y.length === 2 && z.length === 2) {\n if (!_2d(x)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument') }\n if (!_2d(y)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument') }\n if (!_2d(z)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument') }\n if (deepEqual(y, z)) { throw new TypeError('LinePoint1 should not be same with LinePoint2') }\n const xCoeff = subtractScalar(z[1], y[1])\n const yCoeff = subtractScalar(y[0], z[0])\n const constant = subtractScalar(multiplyScalar(z[0], y[1]), multiplyScalar(y[0], z[1]))\n\n return _distancePointLine2D(x[0], x[1], xCoeff, yCoeff, constant)\n } else {\n throw new TypeError('Invalid Arguments: Try again')\n }\n },\n 'Object, Object, Object': function (x, y, z) {\n if (Object.keys(x).length === 2 && Object.keys(y).length === 2 && Object.keys(z).length === 2) {\n if (!_2d(x)) { throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers') }\n if (!_2d(y)) { throw new TypeError('Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers') }\n if (!_2d(z)) { throw new TypeError('Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers') }\n if (deepEqual(_objectToArray(y), _objectToArray(z))) { throw new TypeError('LinePoint1 should not be same with LinePoint2') }\n if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y &&\n 'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) {\n const xCoeff = subtractScalar(z.lineTwoPtY, y.lineOnePtY)\n const yCoeff = subtractScalar(y.lineOnePtX, z.lineTwoPtX)\n const constant = subtractScalar(multiplyScalar(z.lineTwoPtX, y.lineOnePtY), multiplyScalar(y.lineOnePtX, z.lineTwoPtY))\n return _distancePointLine2D(x.pointX, x.pointY, xCoeff, yCoeff, constant)\n } else {\n throw new TypeError('Key names do not match')\n }\n } else {\n throw new TypeError('Invalid Arguments: Try again')\n }\n },\n 'Array, Array': function (x, y) {\n // Point to Line 2D (x=[pointX, pointY], y=[x-coeff, y-coeff, const])\n if (x.length === 2 && y.length === 3) {\n if (!_2d(x)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument')\n }\n if (!_3d(y)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument')\n }\n\n return _distancePointLine2D(x[0], x[1], y[0], y[1], y[2])\n } else if (x.length === 3 && y.length === 6) {\n // Point to Line 3D\n if (!_3d(x)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument')\n }\n if (!_parametricLine(y)) {\n throw new TypeError('Array with 6 numbers or BigNumbers expected for second argument')\n }\n\n return _distancePointLine3D(x[0], x[1], x[2], y[0], y[1], y[2], y[3], y[4], y[5])\n } else if (x.length === y.length && x.length > 0) {\n // Point to Point N-dimensions\n if (!_containsOnlyNumbers(x)) {\n throw new TypeError('All values of an array should be numbers or BigNumbers')\n }\n if (!_containsOnlyNumbers(y)) {\n throw new TypeError('All values of an array should be numbers or BigNumbers')\n }\n\n return _euclideanDistance(x, y)\n } else {\n throw new TypeError('Invalid Arguments: Try again')\n }\n },\n 'Object, Object': function (x, y) {\n if (Object.keys(x).length === 2 && Object.keys(y).length === 3) {\n if (!_2d(x)) {\n throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers')\n }\n if (!_3d(y)) {\n throw new TypeError('Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers')\n }\n if ('pointX' in x && 'pointY' in x && 'xCoeffLine' in y && 'yCoeffLine' in y && 'constant' in y) {\n return _distancePointLine2D(x.pointX, x.pointY, y.xCoeffLine, y.yCoeffLine, y.constant)\n } else {\n throw new TypeError('Key names do not match')\n }\n } else if (Object.keys(x).length === 3 && Object.keys(y).length === 6) {\n // Point to Line 3D\n if (!_3d(x)) {\n throw new TypeError('Values of pointX, pointY and pointZ should be numbers or BigNumbers')\n }\n if (!_parametricLine(y)) {\n throw new TypeError('Values of x0, y0, z0, a, b and c should be numbers or BigNumbers')\n }\n if ('pointX' in x && 'pointY' in x && 'x0' in y && 'y0' in y && 'z0' in y && 'a' in y && 'b' in y && 'c' in y) {\n return _distancePointLine3D(x.pointX, x.pointY, x.pointZ, y.x0, y.y0, y.z0, y.a, y.b, y.c)\n } else {\n throw new TypeError('Key names do not match')\n }\n } else if (Object.keys(x).length === 2 && Object.keys(y).length === 2) {\n // Point to Point 2D\n if (!_2d(x)) {\n throw new TypeError('Values of pointOneX and pointOneY should be numbers or BigNumbers')\n }\n if (!_2d(y)) {\n throw new TypeError('Values of pointTwoX and pointTwoY should be numbers or BigNumbers')\n }\n if ('pointOneX' in x && 'pointOneY' in x && 'pointTwoX' in y && 'pointTwoY' in y) {\n return _euclideanDistance([x.pointOneX, x.pointOneY], [y.pointTwoX, y.pointTwoY])\n } else {\n throw new TypeError('Key names do not match')\n }\n } else if (Object.keys(x).length === 3 && Object.keys(y).length === 3) {\n // Point to Point 3D\n if (!_3d(x)) {\n throw new TypeError('Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers')\n }\n if (!_3d(y)) {\n throw new TypeError('Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers')\n }\n if ('pointOneX' in x && 'pointOneY' in x && 'pointOneZ' in x &&\n 'pointTwoX' in y && 'pointTwoY' in y && 'pointTwoZ' in y\n ) {\n return _euclideanDistance([x.pointOneX, x.pointOneY, x.pointOneZ], [y.pointTwoX, y.pointTwoY, y.pointTwoZ])\n } else {\n throw new TypeError('Key names do not match')\n }\n } else {\n throw new TypeError('Invalid Arguments: Try again')\n }\n },\n Array: function (arr) {\n if (!_pairwise(arr)) { throw new TypeError('Incorrect array format entered for pairwise distance calculation') }\n\n return _distancePairwise(arr)\n }\n })\n\n function _isNumber (a) {\n // distance supports numbers and bignumbers\n return (typeof a === 'number' || isBigNumber(a))\n }\n\n function _2d (a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (a.constructor !== Array) {\n a = _objectToArray(a)\n }\n return _isNumber(a[0]) && _isNumber(a[1])\n }\n\n function _3d (a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (a.constructor !== Array) {\n a = _objectToArray(a)\n }\n return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2])\n }\n\n function _containsOnlyNumbers (a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (!Array.isArray(a)) {\n a = _objectToArray(a)\n }\n return a.every(_isNumber)\n }\n\n function _parametricLine (a) {\n if (a.constructor !== Array) {\n a = _objectToArray(a)\n }\n return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]) &&\n _isNumber(a[3]) && _isNumber(a[4]) && _isNumber(a[5])\n }\n\n function _objectToArray (o) {\n const keys = Object.keys(o)\n const a = []\n for (let i = 0; i < keys.length; i++) {\n a.push(o[keys[i]])\n }\n return a\n }\n\n function _pairwise (a) {\n // checks for valid arguments passed to _distancePairwise(Array)\n if (a[0].length === 2 && _isNumber(a[0][0]) && _isNumber(a[0][1])) {\n if (a.some(aI => aI.length !== 2 || !_isNumber(aI[0]) || !_isNumber(aI[1]))) {\n return false\n }\n } else if (a[0].length === 3 && _isNumber(a[0][0]) && _isNumber(a[0][1]) && _isNumber(a[0][2])) {\n if (a.some(aI => aI.length !== 3 || !_isNumber(aI[0]) || !_isNumber(aI[1]) || !_isNumber(aI[2]))) {\n return false\n }\n } else {\n return false\n }\n return true\n }\n\n function _distancePointLine2D (x, y, a, b, c) {\n const num = abs(addScalar(addScalar(multiplyScalar(a, x), multiplyScalar(b, y)), c))\n const den = sqrt(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)))\n return divideScalar(num, den)\n }\n\n function _distancePointLine3D (x, y, z, x0, y0, z0, a, b, c) {\n let num = [subtractScalar(multiplyScalar(subtractScalar(y0, y), c), multiplyScalar(subtractScalar(z0, z), b)),\n subtractScalar(multiplyScalar(subtractScalar(z0, z), a), multiplyScalar(subtractScalar(x0, x), c)),\n subtractScalar(multiplyScalar(subtractScalar(x0, x), b), multiplyScalar(subtractScalar(y0, y), a))]\n num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2])))\n const den = sqrt(addScalar(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)), multiplyScalar(c, c)))\n return divideScalar(num, den)\n }\n\n function _euclideanDistance (x, y) {\n const vectorSize = x.length\n let result = 0\n let diff = 0\n for (let i = 0; i < vectorSize; i++) {\n diff = subtractScalar(x[i], y[i])\n result = addScalar(multiplyScalar(diff, diff), result)\n }\n return sqrt(result)\n }\n\n function _distancePairwise (a) {\n const result = []\n let pointA = []\n let pointB = []\n for (let i = 0; i < a.length - 1; i++) {\n for (let j = i + 1; j < a.length; j++) {\n if (a[0].length === 2) {\n pointA = [a[i][0], a[i][1]]\n pointB = [a[j][0], a[j][1]]\n } else if (a[0].length === 3) {\n pointA = [a[i][0], a[i][1], a[i][2]]\n pointB = [a[j][0], a[j][1], a[j][2]]\n }\n result.push(_euclideanDistance(pointA, pointB))\n }\n }\n return result\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'intersect'\nconst dependencies = [\n 'typed', 'config', 'abs', 'add', 'addScalar', 'matrix', 'multiply', 'multiplyScalar', 'divideScalar', 'subtract', 'smaller', 'equalScalar', 'flatten', 'isZero', 'isNumeric'\n]\n\nexport const createIntersect = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, abs, add, addScalar, matrix, multiply, multiplyScalar, divideScalar, subtract, smaller, equalScalar, flatten, isZero, isNumeric }) => {\n /**\n * Calculates the point of intersection of two lines in two or three dimensions\n * and of a line and a plane in three dimensions. The inputs are in the form of\n * arrays or 1 dimensional matrices. The line intersection functions return null\n * if the lines do not meet.\n *\n * Note: Fill the plane coefficients as `x + y + z = c` and not as `x + y + z + c = 0`.\n *\n * Syntax:\n *\n * math.intersect(endPoint1Line1, endPoint2Line1, endPoint1Line2, endPoint2Line2)\n * math.intersect(endPoint1, endPoint2, planeCoefficients)\n *\n * Examples:\n *\n * math.intersect([0, 0], [10, 10], [10, 0], [0, 10]) // Returns [5, 5]\n * math.intersect([0, 0, 0], [10, 10, 0], [10, 0, 0], [0, 10, 0]) // Returns [5, 5, 0]\n * math.intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6]) // Returns [7, -4, 3]\n *\n * @param {Array | Matrix} w Co-ordinates of first end-point of first line\n * @param {Array | Matrix} x Co-ordinates of second end-point of first line\n * @param {Array | Matrix} y Co-ordinates of first end-point of second line\n * OR Co-efficients of the plane's equation\n * @param {Array | Matrix} z Co-ordinates of second end-point of second line\n * OR undefined if the calculation is for line and plane\n * @return {Array} Returns the point of intersection of lines/lines-planes\n */\n return typed('intersect', {\n 'Array, Array, Array': _AAA,\n\n 'Array, Array, Array, Array': _AAAA,\n\n 'Matrix, Matrix, Matrix': function (x, y, plane) {\n const arr = _AAA(x.valueOf(), y.valueOf(), plane.valueOf())\n return arr === null ? null : matrix(arr)\n },\n\n 'Matrix, Matrix, Matrix, Matrix': function (w, x, y, z) {\n // TODO: output matrix type should match input matrix type\n const arr = _AAAA(w.valueOf(), x.valueOf(), y.valueOf(), z.valueOf())\n return arr === null ? null : matrix(arr)\n }\n })\n\n function _AAA (x, y, plane) {\n x = _coerceArr(x)\n y = _coerceArr(y)\n plane = _coerceArr(plane)\n\n if (!_3d(x)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument') }\n if (!_3d(y)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument') }\n if (!_4d(plane)) { throw new TypeError('Array with 4 numbers expected as third argument') }\n\n return _intersectLinePlane(x[0], x[1], x[2], y[0], y[1], y[2], plane[0], plane[1], plane[2], plane[3])\n }\n\n function _AAAA (w, x, y, z) {\n w = _coerceArr(w)\n x = _coerceArr(x)\n y = _coerceArr(y)\n z = _coerceArr(z)\n\n if (w.length === 2) {\n if (!_2d(w)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument') }\n if (!_2d(x)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument') }\n if (!_2d(y)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument') }\n if (!_2d(z)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for fourth argument') }\n\n return _intersect2d(w, x, y, z)\n } else if (w.length === 3) {\n if (!_3d(w)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument') }\n if (!_3d(x)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument') }\n if (!_3d(y)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for third argument') }\n if (!_3d(z)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for fourth argument') }\n\n return _intersect3d(w[0], w[1], w[2], x[0], x[1], x[2], y[0], y[1], y[2], z[0], z[1], z[2])\n } else {\n throw new TypeError('Arrays with two or thee dimensional points expected')\n }\n }\n\n /** Coerce row and column 2-dim arrays to 1-dim array */\n function _coerceArr (arr) {\n // row matrix\n if (arr.length === 1) return arr[0]\n\n // column matrix\n if (arr.length > 1 && Array.isArray(arr[0])) {\n if (arr.every(el => Array.isArray(el) && el.length === 1)) return flatten(arr)\n }\n\n return arr\n }\n\n function _2d (x) {\n return x.length === 2 && isNumeric(x[0]) && isNumeric(x[1])\n }\n\n function _3d (x) {\n return x.length === 3 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2])\n }\n\n function _4d (x) {\n return x.length === 4 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]) && isNumeric(x[3])\n }\n\n function _intersect2d (p1a, p1b, p2a, p2b) {\n const o1 = p1a\n const o2 = p2a\n const d1 = subtract(o1, p1b)\n const d2 = subtract(o2, p2b)\n const det = subtract(multiplyScalar(d1[0], d2[1]), multiplyScalar(d2[0], d1[1]))\n if (isZero(det)) return null\n if (smaller(abs(det), config.relTol)) {\n return null\n }\n const d20o11 = multiplyScalar(d2[0], o1[1])\n const d21o10 = multiplyScalar(d2[1], o1[0])\n const d20o21 = multiplyScalar(d2[0], o2[1])\n const d21o20 = multiplyScalar(d2[1], o2[0])\n const t = divideScalar(addScalar(subtract(subtract(d20o11, d21o10), d20o21), d21o20), det)\n return add(multiply(d1, t), o1)\n }\n\n function _intersect3dHelper (a, b, c, d, e, f, g, h, i, j, k, l) {\n // (a - b)*(c - d) + (e - f)*(g - h) + (i - j)*(k - l)\n const add1 = multiplyScalar(subtract(a, b), subtract(c, d))\n const add2 = multiplyScalar(subtract(e, f), subtract(g, h))\n const add3 = multiplyScalar(subtract(i, j), subtract(k, l))\n return addScalar(addScalar(add1, add2), add3)\n }\n\n function _intersect3d (x1, y1, z1, x2, y2, z2, x3, y3, z3, x4, y4, z4) {\n const d1343 = _intersect3dHelper(x1, x3, x4, x3, y1, y3, y4, y3, z1, z3, z4, z3)\n const d4321 = _intersect3dHelper(x4, x3, x2, x1, y4, y3, y2, y1, z4, z3, z2, z1)\n const d1321 = _intersect3dHelper(x1, x3, x2, x1, y1, y3, y2, y1, z1, z3, z2, z1)\n const d4343 = _intersect3dHelper(x4, x3, x4, x3, y4, y3, y4, y3, z4, z3, z4, z3)\n const d2121 = _intersect3dHelper(x2, x1, x2, x1, y2, y1, y2, y1, z2, z1, z2, z1)\n const numerator = subtract(multiplyScalar(d1343, d4321), multiplyScalar(d1321, d4343))\n const denominator = subtract(multiplyScalar(d2121, d4343), multiplyScalar(d4321, d4321))\n if (isZero(denominator)) return null\n const ta = divideScalar(numerator, denominator)\n const tb = divideScalar(addScalar(d1343, multiplyScalar(ta, d4321)), d4343)\n\n const pax = addScalar(x1, multiplyScalar(ta, subtract(x2, x1)))\n const pay = addScalar(y1, multiplyScalar(ta, subtract(y2, y1)))\n const paz = addScalar(z1, multiplyScalar(ta, subtract(z2, z1)))\n const pbx = addScalar(x3, multiplyScalar(tb, subtract(x4, x3)))\n const pby = addScalar(y3, multiplyScalar(tb, subtract(y4, y3)))\n const pbz = addScalar(z3, multiplyScalar(tb, subtract(z4, z3)))\n if (equalScalar(pax, pbx) && equalScalar(pay, pby) && equalScalar(paz, pbz)) {\n return [pax, pay, paz]\n } else {\n return null\n }\n }\n\n function _intersectLinePlane (x1, y1, z1, x2, y2, z2, x, y, z, c) {\n const x1x = multiplyScalar(x1, x)\n const x2x = multiplyScalar(x2, x)\n const y1y = multiplyScalar(y1, y)\n const y2y = multiplyScalar(y2, y)\n const z1z = multiplyScalar(z1, z)\n const z2z = multiplyScalar(z2, z)\n\n const numerator = subtract(subtract(subtract(c, x1x), y1y), z1z)\n const denominator = subtract(subtract(subtract(addScalar(addScalar(x2x, y2y), z2z), x1x), y1y), z1z)\n\n const t = divideScalar(numerator, denominator)\n\n const px = addScalar(x1, multiplyScalar(t, subtract(x2, x1)))\n const py = addScalar(y1, multiplyScalar(t, subtract(y2, y1)))\n const pz = addScalar(z1, multiplyScalar(t, subtract(z2, z1)))\n return [px, py, pz]\n // TODO: Add cases when line is parallel to the plane:\n // (a) no intersection,\n // (b) line contained in plane\n }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'sum'\nconst dependencies = ['typed', 'config', 'add', 'numeric']\n\nexport const createSum = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, add, numeric }) => {\n /**\n * Compute the sum of a matrix or a list with values.\n * In case of a multidimensional array or matrix, the sum of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.sum(a, b, c, ...)\n * math.sum(A)\n * math.sum(A, dimension)\n *\n * Examples:\n *\n * math.sum(2, 1, 4, 3) // returns 10\n * math.sum([2, 1, 4, 3]) // returns 10\n * math.sum([[2, 5], [4, 3], [1, 7]]) // returns 22\n *\n * See also:\n *\n * mean, median, min, max, prod, std, variance, cumsum\n *\n * @param {... *} args A single matrix or multiple scalar values\n * @return {*} The sum of all values\n */\n return typed(name, {\n // sum([a, b, c, d, ...])\n 'Array | Matrix': _sum,\n\n // sum([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': _nsumDim,\n\n // sum(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('Scalar values expected in function sum')\n }\n\n return _sum(args)\n }\n })\n\n /**\n * Recursively calculate the sum of an n-dimensional array\n * @param {Array | Matrix} array\n * @return {number} sum\n * @private\n */\n function _sum (array) {\n let sum\n\n deepForEach(array, function (value) {\n try {\n sum = (sum === undefined) ? value : add(sum, value)\n } catch (err) {\n throw improveErrorMessage(err, 'sum', value)\n }\n })\n\n // make sure returning numeric value: parse a string into a numeric value\n if (sum === undefined) {\n sum = numeric(0, config.number)\n }\n if (typeof sum === 'string') {\n sum = numeric(sum, safeNumberType(sum, config))\n }\n\n return sum\n }\n\n function _nsumDim (array, dim) {\n try {\n const sum = reduce(array, dim, add)\n return sum\n } catch (err) {\n throw improveErrorMessage(err, 'sum')\n }\n }\n})\n","import { containsCollections } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { _switch } from '../../utils/switch.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\nimport { arraySize } from '../../utils/array.js'\nimport { IndexError } from '../../error/IndexError.js'\n\nconst name = 'cumsum'\nconst dependencies = ['typed', 'add', 'unaryPlus']\n\nexport const createCumSum = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, unaryPlus }) => {\n /**\n * Compute the cumulative sum of a matrix or a list with values.\n * In case of a (multi dimensional) array or matrix, the cumulative sums\n * along a specified dimension (defaulting to the first) will be calculated.\n *\n * Syntax:\n *\n * math.cumsum(a, b, c, ...)\n * math.cumsum(A)\n *\n * Examples:\n *\n * math.cumsum(2, 1, 4, 3) // returns [2, 3, 7, 10]\n * math.cumsum([2, 1, 4, 3]) // returns [2, 3, 7, 10]\n * math.cumsum([[1, 2], [3, 4]]) // returns [[1, 2], [4, 6]]\n * math.cumsum([[1, 2], [3, 4]], 0) // returns [[1, 2], [4, 6]]\n * math.cumsum([[1, 2], [3, 4]], 1) // returns [[1, 3], [3, 7]]\n * math.cumsum([[2, 5], [4, 3], [1, 7]]) // returns [[2, 5], [6, 8], [7, 15]]\n *\n * See also:\n *\n * mean, median, min, max, prod, std, variance, sum\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The cumulative sum of all values\n */\n return typed(name, {\n // sum([a, b, c, d, ...])\n Array: _cumsum,\n Matrix: function (matrix) {\n return matrix.create(_cumsum(matrix.valueOf(), matrix.datatype()))\n },\n\n // sum([a, b, c, d, ...], dim)\n 'Array, number | BigNumber': _ncumSumDim,\n 'Matrix, number | BigNumber': function (matrix, dim) {\n return matrix.create(_ncumSumDim(matrix.valueOf(), dim), matrix.datatype())\n },\n\n // cumsum(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('All values expected to be scalar in function cumsum')\n }\n\n return _cumsum(args)\n }\n })\n\n /**\n * Recursively calculate the cumulative sum of an n-dimensional array\n * @param {Array} array\n * @return {number} cumsum\n * @private\n */\n function _cumsum (array) {\n try {\n return _cumsummap(array)\n } catch (err) {\n throw improveErrorMessage(err, name)\n }\n }\n\n function _cumsummap (array) {\n if (array.length === 0) {\n return []\n }\n\n const sums = [unaryPlus(array[0])] // unaryPlus converts to number if need be\n for (let i = 1; i < array.length; ++i) {\n // Must use add below and not addScalar for the case of summing a\n // 2+-dimensional array along the 0th dimension (the row vectors,\n // or higher-d analogues, are literally added to each other).\n sums.push(add(sums[i - 1], array[i]))\n }\n return sums\n }\n\n function _ncumSumDim (array, dim) {\n const size = arraySize(array)\n if (dim < 0 || (dim >= size.length)) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new IndexError(dim, size.length)\n }\n\n try {\n return _cumsumDimensional(array, dim)\n } catch (err) {\n throw improveErrorMessage(err, name)\n }\n }\n\n /* Possible TODO: Refactor _reduce in collection.js to be able to work here as well */\n function _cumsumDimensional (mat, dim) {\n let i, ret, tran\n\n if (dim <= 0) {\n const initialValue = mat[0][0]\n if (!Array.isArray(initialValue)) {\n return _cumsummap(mat)\n } else {\n tran = _switch(mat)\n ret = []\n for (i = 0; i < tran.length; i++) {\n ret[i] = _cumsumDimensional(tran[i], dim - 1)\n }\n return ret\n }\n } else {\n ret = []\n for (i = 0; i < mat.length; i++) {\n ret[i] = _cumsumDimensional(mat[i], dim - 1)\n }\n return ret\n }\n }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'mean'\nconst dependencies = ['typed', 'add', 'divide']\n\nexport const createMean = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide }) => {\n /**\n * Compute the mean value of matrix or a list with values.\n * In case of a multidimensional array, the mean of the flattened array\n * will be calculated. When `dim` is provided, the maximum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.mean(a, b, c, ...)\n * math.mean(A)\n * math.mean(A, dimension)\n *\n * Examples:\n *\n * math.mean(2, 1, 4, 3) // returns 2.5\n * math.mean([1, 2.7, 3.2, 4]) // returns 2.725\n *\n * math.mean([[2, 5], [6, 3], [1, 7]], 0) // returns [3, 5]\n * math.mean([[2, 5], [6, 3], [1, 7]], 1) // returns [3.5, 4.5, 4]\n *\n * See also:\n *\n * median, min, max, sum, prod, std, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The mean of all values\n */\n return typed(name, {\n // mean([a, b, c, d, ...])\n 'Array | Matrix': _mean,\n\n // mean([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': _nmeanDim,\n\n // mean(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('Scalar values expected in function mean')\n }\n\n return _mean(args)\n }\n })\n\n /**\n * Calculate the mean value in an n-dimensional array, returning a\n * n-1 dimensional array\n * @param {Array} array\n * @param {number} dim\n * @return {number} mean\n * @private\n */\n function _nmeanDim (array, dim) {\n try {\n const sum = reduce(array, dim, add)\n const s = Array.isArray(array) ? arraySize(array) : array.size()\n return divide(sum, s[dim])\n } catch (err) {\n throw improveErrorMessage(err, 'mean')\n }\n }\n\n /**\n * Recursively calculate the mean value in an n-dimensional array\n * @param {Array} array\n * @return {number} mean\n * @private\n */\n function _mean (array) {\n let sum\n let num = 0\n\n deepForEach(array, function (value) {\n try {\n sum = sum === undefined ? value : add(sum, value)\n num++\n } catch (err) {\n throw improveErrorMessage(err, 'mean', value)\n }\n })\n\n if (num === 0) {\n throw new Error('Cannot calculate the mean of an empty array')\n }\n return divide(sum, num)\n }\n})\n","import { containsCollections } from '../../utils/collection.js'\nimport { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'median'\nconst dependencies = ['typed', 'add', 'divide', 'compare', 'partitionSelect']\n\nexport const createMedian = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide, compare, partitionSelect }) => {\n /**\n * Recursively calculate the median of an n-dimensional array\n * @param {Array} array\n * @return {Number} median\n * @private\n */\n function _median (array) {\n try {\n array = flatten(array.valueOf())\n\n const num = array.length\n if (num === 0) {\n throw new Error('Cannot calculate median of an empty array')\n }\n\n if (num % 2 === 0) {\n // even: return the average of the two middle values\n const mid = num / 2 - 1\n const right = partitionSelect(array, mid + 1)\n\n // array now partitioned at mid + 1, take max of left part\n let left = array[mid]\n for (let i = 0; i < mid; ++i) {\n if (compare(array[i], left) > 0) {\n left = array[i]\n }\n }\n\n return middle2(left, right)\n } else {\n // odd: return the middle value\n const m = partitionSelect(array, (num - 1) / 2)\n\n return middle(m)\n }\n } catch (err) {\n throw improveErrorMessage(err, 'median')\n }\n }\n\n // helper function to type check the middle value of the array\n const middle = typed({\n 'number | BigNumber | Complex | Unit': function (value) {\n return value\n }\n })\n\n // helper function to type check the two middle value of the array\n const middle2 = typed({\n 'number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit': function (left, right) {\n return divide(add(left, right), 2)\n }\n })\n\n /**\n * Compute the median of a matrix or a list with values. The values are\n * sorted and the middle value is returned. In case of an even number of\n * values, the average of the two middle values is returned.\n * Supported types of values are: Number, BigNumber, Unit\n *\n * In case of a (multi dimensional) array or matrix, the median of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.median(a, b, c, ...)\n * math.median(A)\n *\n * Examples:\n *\n * math.median(5, 2, 7) // returns 5\n * math.median([3, -1, 5, 7]) // returns 4\n *\n * See also:\n *\n * mean, min, max, sum, prod, std, variance, quantileSeq\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The median\n */\n return typed(name, {\n // median([a, b, c, d, ...])\n 'Array | Matrix': _median,\n\n // median([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function (array, dim) {\n // TODO: implement median(A, dim)\n throw new Error('median(A, dim) is not yet supported')\n // return reduce(arguments[0], arguments[1], ...)\n },\n\n // median(a, b, c, d, ...)\n '...': function (args) {\n if (containsCollections(args)) {\n throw new TypeError('Scalar values expected in function median')\n }\n\n return _median(args)\n }\n })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'mad'\nconst dependencies = ['typed', 'abs', 'map', 'median', 'subtract']\n\nexport const createMad = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, map, median, subtract }) => {\n /**\n * Compute the median absolute deviation of a matrix or a list with values.\n * The median absolute deviation is defined as the median of the absolute\n * deviations from the median.\n *\n * Syntax:\n *\n * math.mad(a, b, c, ...)\n * math.mad(A)\n *\n * Examples:\n *\n * math.mad(10, 20, 30) // returns 10\n * math.mad([1, 2, 3]) // returns 1\n * math.mad([[1, 2, 3], [4, 5, 6]]) // returns 1.5\n *\n * See also:\n *\n * median, mean, std, abs\n *\n * @param {Array | Matrix} array\n * A single matrix or multiple scalar values.\n * @return {*} The median absolute deviation.\n */\n return typed(name, {\n // mad([a, b, c, d, ...])\n 'Array | Matrix': _mad,\n\n // mad(a, b, c, d, ...)\n '...': function (args) {\n return _mad(args)\n }\n })\n\n function _mad (array) {\n array = flatten(array.valueOf())\n\n if (array.length === 0) {\n throw new Error('Cannot calculate median absolute deviation (mad) of an empty array')\n }\n\n try {\n const med = median(array)\n return median(map(array, function (value) {\n return abs(subtract(value, med))\n }))\n } catch (err) {\n if (err instanceof TypeError && err.message.includes('median')) {\n throw new TypeError(err.message.replace('median', 'mad'))\n } else {\n throw improveErrorMessage(err, 'mad')\n }\n }\n }\n})\n","import { deepForEach } from '../../utils/collection.js'\nimport { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst DEFAULT_NORMALIZATION = 'unbiased'\n\nconst name = 'variance'\nconst dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']\n\nexport const createVariance = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, subtract, multiply, divide, apply, isNaN }) => {\n /**\n * Compute the variance of a matrix or a list with values.\n * In case of a multidimensional array or matrix, the variance over all\n * elements will be calculated.\n *\n * Additionally, it is possible to compute the variance along the rows\n * or columns of a matrix by specifying the dimension as the second argument.\n *\n * Optionally, the type of normalization can be specified as the final\n * parameter. The parameter `normalization` can be one of the following values:\n *\n * - 'unbiased' (default) The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n *\n *\n * Note that older browser may not like the variable name `var`. In that\n * case, the function can be called as `math['var'](...)` instead of\n * `math.var(...)`.\n *\n * Syntax:\n *\n * math.variance(a, b, c, ...)\n * math.variance(A)\n * math.variance(A, normalization)\n * math.variance(A, dimension)\n * math.variance(A, dimension, normalization)\n *\n * Examples:\n *\n * math.variance(2, 4, 6) // returns 4\n * math.variance([2, 4, 6, 8]) // returns 6.666666666666667\n * math.variance([2, 4, 6, 8], 'uncorrected') // returns 5\n * math.variance([2, 4, 6, 8], 'biased') // returns 4\n *\n * math.variance([[1, 2, 3], [4, 5, 6]]) // returns 3.5\n * math.variance([[1, 2, 3], [4, 6, 8]], 0) // returns [4.5, 8, 12.5]\n * math.variance([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 4]\n * math.variance([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.5, 2]\n *\n * See also:\n *\n * mean, median, max, min, prod, std, sum\n *\n * @param {Array | Matrix} array\n * A single matrix or or multiple scalar values\n * @param {string} [normalization='unbiased']\n * Determines how to normalize the variance.\n * Choose 'unbiased' (default), 'uncorrected', or 'biased'.\n * @param dimension {number | BigNumber}\n * Determines the axis to compute the variance for a matrix\n * @return {*} The variance\n */\n return typed(name, {\n // variance([a, b, c, d, ...])\n 'Array | Matrix': function (array) {\n return _var(array, DEFAULT_NORMALIZATION)\n },\n\n // variance([a, b, c, d, ...], normalization)\n 'Array | Matrix, string': _var,\n\n // variance([a, b, c, c, ...], dim)\n 'Array | Matrix, number | BigNumber': function (array, dim) {\n return _varDim(array, dim, DEFAULT_NORMALIZATION)\n },\n\n // variance([a, b, c, c, ...], dim, normalization)\n 'Array | Matrix, number | BigNumber, string': _varDim,\n\n // variance(a, b, c, d, ...)\n '...': function (args) {\n return _var(args, DEFAULT_NORMALIZATION)\n }\n })\n\n /**\n * Recursively calculate the variance of an n-dimensional array\n * @param {Array} array\n * @param {string} normalization\n * Determines how to normalize the variance:\n * - 'unbiased' The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n * @return {number | BigNumber} variance\n * @private\n */\n function _var (array, normalization) {\n let sum\n let num = 0\n\n if (array.length === 0) {\n throw new SyntaxError('Function variance requires one or more parameters (0 provided)')\n }\n\n // calculate the mean and number of elements\n deepForEach(array, function (value) {\n try {\n sum = sum === undefined ? value : add(sum, value)\n num++\n } catch (err) {\n throw improveErrorMessage(err, 'variance', value)\n }\n })\n if (num === 0) throw new Error('Cannot calculate variance of an empty array')\n\n const mean = divide(sum, num)\n\n // calculate the variance\n sum = undefined\n deepForEach(array, function (value) {\n const diff = subtract(value, mean)\n sum = sum === undefined ? multiply(diff, diff) : add(sum, multiply(diff, diff))\n })\n\n if (isNaN(sum)) {\n return sum\n }\n\n switch (normalization) {\n case 'uncorrected':\n return divide(sum, num)\n\n case 'biased':\n return divide(sum, num + 1)\n\n case 'unbiased':\n {\n const zero = isBigNumber(sum) ? sum.mul(0) : 0\n return (num === 1) ? zero : divide(sum, num - 1)\n }\n\n default:\n throw new Error('Unknown normalization \"' + normalization + '\". ' +\n 'Choose \"unbiased\" (default), \"uncorrected\", or \"biased\".')\n }\n }\n\n function _varDim (array, dim, normalization) {\n try {\n if (array.length === 0) {\n throw new SyntaxError('Function variance requires one or more parameters (0 provided)')\n }\n return apply(array, dim, (x) => _var(x, normalization))\n } catch (err) {\n throw improveErrorMessage(err, 'variance')\n }\n }\n})\n","import { isNumber } from '../../utils/is.js'\nimport { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { createApply } from '../matrix/apply.js'\n\nconst name = 'quantileSeq'\nconst dependencies = ['typed', '?bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']\n\nexport const createQuantileSeq = /* #__PURE__ */ factory(name, dependencies, ({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger }) => {\n const apply = createApply({ typed, isInteger })\n\n /**\n * Compute the prob order quantile of a matrix or a list with values.\n * The sequence is sorted and the middle value is returned.\n * Supported types of sequence values are: Number, BigNumber, Unit\n * Supported types of probability are: Number, BigNumber\n *\n * In case of a multidimensional array or matrix, the prob order quantile\n * of all elements will be calculated.\n *\n * Syntax:\n *\n * math.quantileSeq(A, prob[, sorted])\n * math.quantileSeq(A, [prob1, prob2, ...][, sorted])\n * math.quantileSeq(A, N[, sorted])\n *\n * Examples:\n *\n * math.quantileSeq([3, -1, 5, 7], 0.5) // returns 4\n * math.quantileSeq([3, -1, 5, 7], [1/3, 2/3]) // returns [3, 5]\n * math.quantileSeq([3, -1, 5, 7], 2) // returns [3, 5]\n * math.quantileSeq([-1, 3, 5, 7], 0.5, true) // returns 4\n *\n * See also:\n *\n * median, mean, min, max, sum, prod, std, variance\n *\n * @param {Array, Matrix} data A single matrix or Array\n * @param {Number, BigNumber, Array} probOrN prob is the order of the quantile, while N is\n * the amount of evenly distributed steps of\n * probabilities; only one of these options can\n * be provided\n * @param {Boolean} sorted=false is data sorted in ascending order\n * @return {Number, BigNumber, Unit, Array} Quantile(s)\n */\n return typed(name, {\n 'Array | Matrix, number | BigNumber': (data, p) => _quantileSeqProbNumber(data, p, false),\n 'Array | Matrix, number | BigNumber, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbNumber),\n 'Array | Matrix, number | BigNumber, boolean': _quantileSeqProbNumber,\n 'Array | Matrix, number | BigNumber, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbNumber),\n 'Array | Matrix, Array | Matrix': (data, p) => _quantileSeqProbCollection(data, p, false),\n 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbCollection),\n 'Array | Matrix, Array | Matrix, boolean': _quantileSeqProbCollection,\n 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbCollection)\n })\n\n function _quantileSeqDim (data, prob, sorted, dim, fn) {\n return apply(data, dim, x => fn(x, prob, sorted))\n }\n\n function _quantileSeqProbNumber (data, probOrN, sorted) {\n let probArr\n const dataArr = data.valueOf()\n if (smaller(probOrN, 0)) {\n throw new Error('N/prob must be non-negative')\n }\n if (smallerEq(probOrN, 1)) {\n // quantileSeq([a, b, c, d, ...], prob[,sorted])\n return isNumber(probOrN)\n ? _quantileSeq(dataArr, probOrN, sorted)\n : bignumber(_quantileSeq(dataArr, probOrN, sorted))\n }\n if (larger(probOrN, 1)) {\n // quantileSeq([a, b, c, d, ...], N[,sorted])\n if (!isInteger(probOrN)) {\n throw new Error('N must be a positive integer')\n }\n\n // largest possible Array length is 2^32-1\n // 2^32 < 10^15, thus safe conversion guaranteed\n if (larger(probOrN, 4294967295)) {\n throw new Error('N must be less than or equal to 2^32-1, as that is the maximum length of an Array')\n }\n\n const nPlusOne = add(probOrN, 1)\n probArr = []\n\n for (let i = 0; smaller(i, probOrN); i++) {\n const prob = divide(i + 1, nPlusOne)\n probArr.push(_quantileSeq(dataArr, prob, sorted))\n }\n\n return isNumber(probOrN) ? probArr : bignumber(probArr)\n }\n }\n\n /**\n * Calculate the prob order quantile of an n-dimensional array.\n *\n * @param {Array, Matrix} array\n * @param {Array, Matrix} prob\n * @param {Boolean} sorted\n * @return {Number, BigNumber, Unit} prob order quantile\n * @private\n */\n\n function _quantileSeqProbCollection (data, probOrN, sorted) {\n const dataArr = data.valueOf()\n // quantileSeq([a, b, c, d, ...], [prob1, prob2, ...][,sorted])\n const probOrNArr = probOrN.valueOf()\n const probArr = []\n for (let i = 0; i < probOrNArr.length; ++i) {\n probArr.push(_quantileSeq(dataArr, probOrNArr[i], sorted))\n }\n return probArr\n }\n\n /**\n * Calculate the prob order quantile of an n-dimensional array.\n *\n * @param {Array} array\n * @param {Number, BigNumber} prob\n * @param {Boolean} sorted\n * @return {Number, BigNumber, Unit} prob order quantile\n * @private\n */\n function _quantileSeq (array, prob, sorted) {\n const flat = flatten(array)\n const len = flat.length\n if (len === 0) {\n throw new Error('Cannot calculate quantile of an empty sequence')\n }\n\n const index = isNumber(prob) ? prob * (len - 1) : prob.times(len - 1)\n const integerPart = isNumber(prob) ? Math.floor(index) : index.floor().toNumber()\n const fracPart = isNumber(prob) ? index % 1 : index.minus(integerPart)\n\n if (isInteger(index)) {\n return sorted\n ? flat[index]\n : partitionSelect(\n flat,\n isNumber(prob) ? index : index.valueOf()\n )\n }\n let left\n let right\n if (sorted) {\n left = flat[integerPart]\n right = flat[integerPart + 1]\n } else {\n right = partitionSelect(flat, integerPart + 1)\n\n // max of partition is kth largest\n left = flat[integerPart]\n for (let i = 0; i < integerPart; ++i) {\n if (compare(flat[i], left) > 0) {\n left = flat[i]\n }\n }\n }\n // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1]\n return add(multiply(left, subtract(1, fracPart)), multiply(right, fracPart))\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\nconst name = 'std'\nconst dependencies = ['typed', 'map', 'sqrt', 'variance']\n\nexport const createStd = /* #__PURE__ */ factory(name, dependencies, ({ typed, map, sqrt, variance }) => {\n /**\n * Compute the standard deviation of a matrix or a list with values.\n * The standard deviations is defined as the square root of the variance:\n * `std(A) = sqrt(variance(A))`.\n * In case of a (multi dimensional) array or matrix, the standard deviation\n * over all elements will be calculated by default, unless an axis is specified\n * in which case the standard deviation will be computed along that axis.\n *\n * Additionally, it is possible to compute the standard deviation along the rows\n * or columns of a matrix by specifying the dimension as the second argument.\n *\n * Optionally, the type of normalization can be specified as the final\n * parameter. The parameter `normalization` can be one of the following values:\n *\n * - 'unbiased' (default) The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n *\n *\n * Syntax:\n *\n * math.std(a, b, c, ...)\n * math.std(A)\n * math.std(A, normalization)\n * math.std(A, dimension)\n * math.std(A, dimension, normalization)\n *\n * Examples:\n *\n * math.std(2, 4, 6) // returns 2\n * math.std([2, 4, 6, 8]) // returns 2.581988897471611\n * math.std([2, 4, 6, 8], 'uncorrected') // returns 2.23606797749979\n * math.std([2, 4, 6, 8], 'biased') // returns 2\n *\n * math.std([[1, 2, 3], [4, 5, 6]]) // returns 1.8708286933869707\n * math.std([[1, 2, 3], [4, 6, 8]], 0) // returns [2.1213203435596424, 2.8284271247461903, 3.5355339059327378]\n * math.std([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 2]\n * math.std([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.7071067811865476, 1.4142135623730951]\n *\n * See also:\n *\n * mean, median, max, min, prod, sum, variance\n *\n * @param {Array | Matrix} array\n * A single matrix or or multiple scalar values\n * @param {string} [normalization='unbiased']\n * Determines how to normalize the variance.\n * Choose 'unbiased' (default), 'uncorrected', or 'biased'.\n * @param dimension {number | BigNumber}\n * Determines the axis to compute the standard deviation for a matrix\n * @return {*} The standard deviation\n */\n return typed(name, {\n // std([a, b, c, d, ...])\n 'Array | Matrix': _std,\n\n // std([a, b, c, d, ...], normalization)\n 'Array | Matrix, string': _std,\n\n // std([a, b, c, c, ...], dim)\n 'Array | Matrix, number | BigNumber': _std,\n\n // std([a, b, c, c, ...], dim, normalization)\n 'Array | Matrix, number | BigNumber, string': _std,\n\n // std(a, b, c, d, ...)\n '...': function (args) {\n return _std(args)\n }\n })\n\n function _std (array, normalization) {\n if (array.length === 0) {\n throw new SyntaxError('Function std requires one or more parameters (0 provided)')\n }\n\n try {\n const v = variance.apply(null, arguments)\n if (isCollection(v)) {\n return map(v, sqrt)\n } else {\n return sqrt(v)\n }\n } catch (err) {\n if (err instanceof TypeError && err.message.includes(' variance')) {\n throw new TypeError(err.message.replace(' variance', ' std'))\n } else {\n throw err\n }\n }\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'corr'\nconst dependencies = ['typed', 'matrix', 'mean', 'sqrt', 'sum', 'add', 'subtract', 'multiply', 'pow', 'divide']\n\nexport const createCorr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, sqrt, sum, add, subtract, multiply, pow, divide }) => {\n /**\n * Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.\n *\n * Syntax:\n *\n * math.corr(A, B)\n *\n * Examples:\n *\n * math.corr([1, 2, 3, 4, 5], [4, 5, 6, 7, 8]) // returns 1\n * math.corr([1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]) //returns 0.9569941688503644\n * math.corr([[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]],[[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]]) // returns [1,1]\n *\n * See also:\n *\n * median, mean, min, max, sum, prod, std, variance\n *\n * @param {Array | Matrix} A The first array or matrix to compute correlation coefficient\n * @param {Array | Matrix} B The second array or matrix to compute correlation coefficient\n * @return {*} The correlation coefficient\n */\n return typed(name, {\n 'Array, Array': function (A, B) {\n return _corr(A, B)\n },\n 'Matrix, Matrix': function (A, B) {\n const res = _corr(A.toArray(), B.toArray())\n return Array.isArray(res) ? matrix(res) : res\n }\n })\n /**\n * Calculate the correlation coefficient between two arrays or matrices.\n * @param {Array | Matrix} A\n * @param {Array | Matrix} B\n * @return {*} correlation coefficient\n * @private\n */\n function _corr (A, B) {\n const correlations = []\n if (Array.isArray(A[0]) && Array.isArray(B[0])) {\n if (A.length !== B.length) {\n throw new SyntaxError('Dimension mismatch. Array A and B must have the same length.')\n }\n for (let i = 0; i < A.length; i++) {\n if (A[i].length !== B[i].length) {\n throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.')\n }\n correlations.push(correlation(A[i], B[i]))\n }\n return correlations\n } else {\n if (A.length !== B.length) {\n throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.')\n }\n return correlation(A, B)\n }\n }\n function correlation (A, B) {\n const n = A.length\n const sumX = sum(A)\n const sumY = sum(B)\n const sumXY = A.reduce((acc, x, index) => add(acc, multiply(x, B[index])), 0)\n const sumXSquare = sum(A.map(x => pow(x, 2)))\n const sumYSquare = sum(B.map(y => pow(y, 2)))\n const numerator = subtract(multiply(n, sumXY), multiply(sumX, sumY))\n const denominator = sqrt(multiply(subtract(multiply(n, sumXSquare), pow(sumX, 2)), subtract(multiply(n, sumYSquare), pow(sumY, 2))))\n return divide(numerator, denominator)\n }\n})\n","/** @param {number} i\n * @param {number} n\n * @returns {number} product of i to n\n */\nexport function product (i, n) {\n if (n < i) {\n return 1\n }\n\n if (n === i) {\n return n\n }\n\n const half = (n + i) >> 1 // divide (n + i) by 2 and truncate to integer\n return product(i, half) * product(half + 1, n)\n}\n","import { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nexport function combinationsNumber (n, k) {\n if (!isInteger(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function combinations')\n }\n if (!isInteger(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function combinations')\n }\n if (k > n) {\n throw new TypeError('k must be less than or equal to n')\n }\n\n const nMinusk = n - k\n\n let answer = 1\n const firstnumerator = (k < nMinusk) ? nMinusk + 1 : k + 1\n let nextdivisor = 2\n const lastdivisor = (k < nMinusk) ? k : nMinusk\n // balance multiplications and divisions to try to keep intermediate values\n // in exact-integer range as long as possible\n for (let nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) {\n answer *= nextnumerator\n while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) {\n answer /= nextdivisor\n ++nextdivisor\n }\n }\n // for big n, k, floating point may have caused weirdness in remainder\n if (nextdivisor <= lastdivisor) {\n answer /= product(nextdivisor, lastdivisor)\n }\n return answer\n}\ncombinationsNumber.signature = 'number, number'\n","import { factory } from '../../utils/factory.js'\nimport { combinationsNumber } from '../../plain/number/combinations.js'\n\nconst name = 'combinations'\nconst dependencies = ['typed']\n\nexport const createCombinations = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the number of ways of picking `k` unordered outcomes from `n`\n * possibilities.\n *\n * Combinations only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.combinations(n, k)\n *\n * Examples:\n *\n * math.combinations(7, 5) // returns 21\n *\n * See also:\n *\n * combinationsWithRep, permutations, factorial\n *\n * @param {number | BigNumber} n Total number of objects in the set\n * @param {number | BigNumber} k Number of objects in the subset\n * @return {number | BigNumber} Number of possible combinations.\n */\n return typed(name, {\n 'number, number': combinationsNumber,\n\n 'BigNumber, BigNumber': function (n, k) {\n const BigNumber = n.constructor\n let result, i\n const nMinusk = n.minus(k)\n const one = new BigNumber(1)\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function combinations')\n }\n if (k.gt(n)) {\n throw new TypeError('k must be less than n in function combinations')\n }\n\n result = one\n if (k.lt(nMinusk)) {\n for (i = one; i.lte(nMinusk); i = i.plus(one)) {\n result = result.times(k.plus(i)).dividedBy(i)\n }\n } else {\n for (i = one; i.lte(k); i = i.plus(one)) {\n result = result.times(nMinusk.plus(i)).dividedBy(i)\n }\n }\n\n return result\n }\n\n // TODO: implement support for collection in combinations\n })\n})\n\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\nfunction isPositiveInteger (n) {\n return n.isInteger() && n.gte(0)\n}\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nconst name = 'combinationsWithRep'\nconst dependencies = ['typed']\n\nexport const createCombinationsWithRep = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Compute the number of ways of picking `k` unordered outcomes from `n`\n * possibilities, allowing individual outcomes to be repeated more than once.\n *\n * CombinationsWithRep only takes integer arguments.\n * The following condition must be enforced: k <= n + k -1.\n *\n * Syntax:\n *\n * math.combinationsWithRep(n, k)\n *\n * Examples:\n *\n * math.combinationsWithRep(7, 5) // returns 462\n *\n * See also:\n *\n * combinations, permutations, factorial\n *\n * @param {number | BigNumber} n Total number of objects in the set\n * @param {number | BigNumber} k Number of objects in the subset\n * @return {number | BigNumber} Number of possible combinations with replacement.\n */\n return typed(name, {\n 'number, number': function (n, k) {\n if (!isInteger(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep')\n }\n if (!isInteger(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep')\n }\n if (n < 1) {\n throw new TypeError('k must be less than or equal to n + k - 1')\n }\n\n if (k < n - 1) {\n const prodrange = product(n, n + k - 1)\n return prodrange / product(1, k)\n }\n const prodrange = product(k + 1, n + k - 1)\n return prodrange / product(1, n - 1)\n },\n\n 'BigNumber, BigNumber': function (n, k) {\n const BigNumber = n.constructor\n let result, i\n const one = new BigNumber(1)\n const nMinusOne = n.minus(one)\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep')\n }\n if (n.lt(one)) {\n throw new TypeError('k must be less than or equal to n + k - 1 in function combinationsWithRep')\n }\n\n result = one\n if (k.lt(nMinusOne)) {\n for (i = one; i.lte(nMinusOne); i = i.plus(one)) {\n result = result.times(k.plus(i)).dividedBy(i)\n }\n } else {\n for (i = one; i.lte(k); i = i.plus(one)) {\n result = result.times(nMinusOne.plus(i)).dividedBy(i)\n }\n }\n\n return result\n }\n })\n})\n\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\nfunction isPositiveInteger (n) {\n return n.isInteger() && n.gte(0)\n}\n","/* eslint-disable no-loss-of-precision */\n\nimport { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nexport function gammaNumber (n) {\n let x\n\n if (isInteger(n)) {\n if (n <= 0) {\n return isFinite(n) ? Infinity : NaN\n }\n\n if (n > 171) {\n return Infinity // Will overflow\n }\n\n return product(1, n - 1)\n }\n\n if (n < 0.5) {\n return Math.PI / (Math.sin(Math.PI * n) * gammaNumber(1 - n))\n }\n\n if (n >= 171.35) {\n return Infinity // will overflow\n }\n\n if (n > 85.0) { // Extended Stirling Approx\n const twoN = n * n\n const threeN = twoN * n\n const fourN = threeN * n\n const fiveN = fourN * n\n return Math.sqrt(2 * Math.PI / n) * Math.pow((n / Math.E), n) *\n (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) -\n 571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) +\n 5246819 / (75246796800 * fiveN * n))\n }\n\n --n\n x = gammaP[0]\n for (let i = 1; i < gammaP.length; ++i) {\n x += gammaP[i] / (n + i)\n }\n\n const t = n + gammaG + 0.5\n return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x\n}\ngammaNumber.signature = 'number'\n\n// TODO: comment on the variables g and p\n\nexport const gammaG = 4.7421875\n\nexport const gammaP = [\n 0.99999999999999709182,\n 57.156235665862923517,\n -59.597960355475491248,\n 14.136097974741747174,\n -0.49191381609762019978,\n 0.33994649984811888699e-4,\n 0.46523628927048575665e-4,\n -0.98374475304879564677e-4,\n 0.15808870322491248884e-3,\n -0.21026444172410488319e-3,\n 0.21743961811521264320e-3,\n -0.16431810653676389022e-3,\n 0.84418223983852743293e-4,\n -0.26190838401581408670e-4,\n 0.36899182659531622704e-5\n]\n\n// lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code\n\n// log(2 * pi) / 2\nexport const lnSqrt2PI = 0.91893853320467274178\n\nexport const lgammaG = 5 // Lanczos parameter \"g\"\nexport const lgammaN = 7 // Range of coefficients \"n\"\n\nexport const lgammaSeries = [\n 1.000000000190015,\n 76.18009172947146,\n -86.50532032941677,\n 24.01409824083091,\n -1.231739572450155,\n 0.1208650973866179e-2,\n -0.5395239384953e-5\n]\n\nexport function lgammaNumber (n) {\n if (n < 0) return NaN\n if (n === 0) return Infinity\n if (!isFinite(n)) return n\n\n if (n < 0.5) {\n // Use Euler's reflection formula:\n // gamma(z) = PI / (sin(PI * z) * gamma(1 - z))\n return Math.log(Math.PI / Math.sin(Math.PI * n)) - lgammaNumber(1 - n)\n }\n\n // Compute the logarithm of the Gamma function using the Lanczos method\n\n n = n - 1\n const base = n + lgammaG + 0.5 // Base of the Lanczos exponential\n let sum = lgammaSeries[0]\n\n // We start with the terms that have the smallest coefficients and largest denominator\n for (let i = lgammaN - 1; i >= 1; i--) {\n sum += lgammaSeries[i] / (n + i)\n }\n\n return lnSqrt2PI + (n + 0.5) * Math.log(base) - base + Math.log(sum)\n}\nlgammaNumber.signature = 'number'\n","import { factory } from '../../utils/factory.js'\nimport { gammaG, gammaNumber, gammaP } from '../../plain/number/index.js'\n\nconst name = 'gamma'\nconst dependencies = ['typed', 'config', 'multiplyScalar', 'pow', 'BigNumber', 'Complex']\n\nexport const createGamma = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiplyScalar, pow, BigNumber, Complex }) => {\n /**\n * Compute the gamma function of a value using Lanczos approximation for\n * small values, and an extended Stirling approximation for large values.\n *\n * To avoid confusion with the matrix Gamma function, this function does\n * not apply to matrices.\n *\n * Syntax:\n *\n * math.gamma(n)\n *\n * Examples:\n *\n * math.gamma(5) // returns 24\n * math.gamma(-0.5) // returns -3.5449077018110335\n * math.gamma(math.i) // returns -0.15494982830180973 - 0.49801566811835596i\n *\n * See also:\n *\n * combinations, factorial, permutations\n *\n * @param {number | BigNumber | Complex} n A real or complex number\n * @return {number | BigNumber | Complex} The gamma of `n`\n */\n\n function gammaComplex (n) {\n if (n.im === 0) {\n return gammaNumber(n.re)\n }\n\n // Lanczos approximation doesn't work well with real part lower than 0.5\n // So reflection formula is required\n if (n.re < 0.5) { // Euler's reflection formula\n // gamma(1-z) * gamma(z) = PI / sin(PI * z)\n // real part of Z should not be integer [sin(PI) == 0 -> 1/0 - undefined]\n // thanks to imperfect sin implementation sin(PI * n) != 0\n // we can safely use it anyway\n const t = new Complex(1 - n.re, -n.im)\n const r = new Complex(Math.PI * n.re, Math.PI * n.im)\n\n return new Complex(Math.PI).div(r.sin()).div(gammaComplex(t))\n }\n\n // Lanczos approximation\n // z -= 1\n n = new Complex(n.re - 1, n.im)\n\n // x = gammaPval[0]\n let x = new Complex(gammaP[0], 0)\n // for (i, gammaPval) in enumerate(gammaP):\n for (let i = 1; i < gammaP.length; ++i) {\n // x += gammaPval / (z + i)\n const gammaPval = new Complex(gammaP[i], 0)\n x = x.add(gammaPval.div(n.add(i)))\n }\n // t = z + gammaG + 0.5\n const t = new Complex(n.re + gammaG + 0.5, n.im)\n\n // y = sqrt(2 * pi) * t ** (z + 0.5) * exp(-t) * x\n const twoPiSqrt = Math.sqrt(2 * Math.PI)\n const tpow = t.pow(n.add(0.5))\n const expt = t.neg().exp()\n\n // y = [x] * [sqrt(2 * pi)] * [t ** (z + 0.5)] * [exp(-t)]\n return x.mul(twoPiSqrt).mul(tpow).mul(expt)\n }\n\n return typed(name, {\n number: gammaNumber,\n Complex: gammaComplex,\n BigNumber: function (n) {\n if (n.isInteger()) {\n return (n.isNegative() || n.isZero())\n ? new BigNumber(Infinity)\n : bigFactorial(n.minus(1))\n }\n\n if (!n.isFinite()) {\n return new BigNumber(n.isNegative() ? NaN : Infinity)\n }\n\n throw new Error('Integer BigNumber expected')\n }\n })\n\n /**\n * Calculate factorial for a BigNumber\n * @param {BigNumber} n\n * @returns {BigNumber} Returns the factorial of n\n */\n function bigFactorial (n) {\n if (n < 8) {\n return new BigNumber([1, 1, 2, 6, 24, 120, 720, 5040][n])\n }\n\n const precision = config.precision + (Math.log(n.toNumber()) | 0)\n const Big = BigNumber.clone({ precision })\n\n if (n % 2 === 1) {\n return n.times(bigFactorial(new BigNumber(n - 1)))\n }\n\n let p = n\n let prod = new Big(n)\n let sum = n.toNumber()\n\n while (p > 2) {\n p -= 2\n sum += p\n prod = prod.times(sum)\n }\n\n return new BigNumber(prod.toPrecision(BigNumber.precision))\n }\n})\n","/* eslint-disable no-loss-of-precision */\n\n// References\n// ----------\n// [1] Hare, \"Computing the Principal Branch of log-Gamma\", Journal of Algorithms, 1997.\n// [2] https://math.stackexchange.com/questions/1338753/how-do-i-calculate-values-for-gamma-function-with-complex-arguments\n\nimport { lgammaNumber, lnSqrt2PI } from '../../plain/number/index.js'\nimport { factory } from '../../utils/factory.js'\nimport { copysign } from '../../utils/number.js'\n\nconst name = 'lgamma'\nconst dependencies = ['Complex', 'typed']\n\nexport const createLgamma = /* #__PURE__ */ factory(name, dependencies, ({ Complex, typed }) => {\n // Stirling series is non-convergent, we need to use the recurrence `lgamma(z) = lgamma(z+1) - log z` to get\n // sufficient accuracy.\n //\n // These two values are copied from Scipy implementation:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L37\n const SMALL_RE = 7\n const SMALL_IM = 7\n\n /**\n * The coefficients are B[2*n]/(2*n*(2*n - 1)) where B[2*n] is the (2*n)th Bernoulli number. See (1.1) in [1].\n *\n * If you cannot access the paper, can also get these values from the formula in [2].\n *\n * 1 / 12 = 0.00833333333333333333333333333333\n * 1 / 360 = 0.00277777777777777777777777777778\n * ...\n * 3617 / 133400 = 0.02955065359477124183006535947712\n */\n const coeffs = [\n -2.955065359477124183e-2, 6.4102564102564102564e-3, -1.9175269175269175269e-3, 8.4175084175084175084e-4,\n -5.952380952380952381e-4, 7.9365079365079365079e-4, -2.7777777777777777778e-3, 8.3333333333333333333e-2\n ]\n\n /**\n * Logarithm of the gamma function for real, positive numbers and complex numbers,\n * using Lanczos approximation for numbers and Stirling series for complex numbers.\n *\n * Syntax:\n *\n * math.lgamma(n)\n *\n * Examples:\n *\n * math.lgamma(5) // returns 3.178053830347945\n * math.lgamma(0) // returns Infinity\n * math.lgamma(-0.5) // returns NaN\n * math.lgamma(math.i) // returns -0.6509231993018536 - 1.8724366472624294i\n *\n * See also:\n *\n * gamma\n *\n * @param {number | Complex} n A real or complex number\n * @return {number | Complex} The log gamma of `n`\n */\n return typed(name, {\n number: lgammaNumber,\n Complex: lgammaComplex,\n BigNumber: function () {\n throw new Error(\"mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber\")\n }\n })\n\n function lgammaComplex (n) {\n const TWOPI = 6.2831853071795864769252842 // 2*pi\n const LOGPI = 1.1447298858494001741434262 // log(pi)\n\n const REFLECTION = 0.1\n\n if (n.isNaN()) {\n return new Complex(NaN, NaN)\n } else if (n.im === 0) {\n return new Complex(lgammaNumber(n.re), 0)\n } else if (n.re >= SMALL_RE || Math.abs(n.im) >= SMALL_IM) {\n return lgammaStirling(n)\n } else if (n.re <= REFLECTION) {\n // Reflection formula. see Proposition 3.1 in [1]\n const tmp = copysign(TWOPI, n.im) * Math.floor(0.5 * n.re + 0.25)\n const a = n.mul(Math.PI).sin().log()\n const b = lgammaComplex(new Complex(1 - n.re, -n.im))\n return new Complex(LOGPI, tmp).sub(a).sub(b)\n } else if (n.im >= 0) {\n return lgammaRecurrence(n)\n } else {\n return lgammaRecurrence(n.conjugate()).conjugate()\n }\n }\n\n function lgammaStirling (z) {\n // formula ref in [2]\n // computation ref:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L101\n\n // left part\n\n // x (log(x) - 1) + 1/2 (log(2PI) - log(x))\n // => (x - 0.5) * log(x) - x + log(2PI) / 2\n const leftPart = z.sub(0.5).mul(z.log()).sub(z).add(lnSqrt2PI)\n\n // right part\n\n const rz = new Complex(1, 0).div(z)\n const rzz = rz.div(z)\n\n let a = coeffs[0]\n let b = coeffs[1]\n const r = 2 * rzz.re\n const s = rzz.re * rzz.re + rzz.im * rzz.im\n\n for (let i = 2; i < 8; i++) {\n const tmp = b\n b = -s * a + coeffs[i]\n a = r * a + tmp\n }\n\n const rightPart = rz.mul(rzz.mul(a).add(b))\n\n // plus left and right\n\n return leftPart.add(rightPart)\n }\n\n function lgammaRecurrence (z) {\n // computation ref:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L78\n\n let signflips = 0\n let sb = 0\n let shiftprod = z\n\n z = z.add(1)\n while (z.re <= SMALL_RE) {\n shiftprod = shiftprod.mul(z)\n\n const nsb = shiftprod.im < 0 ? 1 : 0\n if (nsb !== 0 && sb === 0) signflips++\n sb = nsb\n\n z = z.add(1)\n }\n\n return lgammaStirling(z)\n .sub(shiftprod.log())\n .sub(new Complex(0, signflips * 2 * Math.PI * 1))\n }\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'factorial'\nconst dependencies = ['typed', 'gamma']\n\nexport const createFactorial = /* #__PURE__ */ factory(name, dependencies, ({ typed, gamma }) => {\n /**\n * Compute the factorial of a value\n *\n * Factorial only supports an integer value as argument.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.factorial(n)\n *\n * Examples:\n *\n * math.factorial(5) // returns 120\n * math.factorial(3) // returns 6\n *\n * See also:\n *\n * combinations, combinationsWithRep, gamma, permutations\n *\n * @param {number | BigNumber | Array | Matrix} n An integer number\n * @return {number | BigNumber | Array | Matrix} The factorial of `n`\n */\n return typed(name, {\n number: function (n) {\n if (n < 0) {\n throw new Error('Value must be non-negative')\n }\n\n return gamma(n + 1)\n },\n\n BigNumber: function (n) {\n if (n.isNegative()) {\n throw new Error('Value must be non-negative')\n }\n\n return gamma(n.plus(1))\n },\n\n 'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self))\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'kldivergence'\nconst dependencies = ['typed', 'matrix', 'divide', 'sum', 'multiply', 'map', 'dotDivide', 'log', 'isNumeric']\n\nexport const createKldivergence = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divide, sum, multiply, map, dotDivide, log, isNumeric }) => {\n /**\n * Calculate the Kullback-Leibler (KL) divergence between two distributions\n *\n * Syntax:\n *\n * math.kldivergence(x, y)\n *\n * Examples:\n *\n * math.kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5]) //returns 0.24376698773121153\n *\n *\n * @param {Array | Matrix} q First vector\n * @param {Array | Matrix} p Second vector\n * @return {number} Returns distance between q and p\n */\n return typed(name, {\n 'Array, Array': function (q, p) {\n return _kldiv(matrix(q), matrix(p))\n },\n\n 'Matrix, Array': function (q, p) {\n return _kldiv(q, matrix(p))\n },\n\n 'Array, Matrix': function (q, p) {\n return _kldiv(matrix(q), p)\n },\n\n 'Matrix, Matrix': function (q, p) {\n return _kldiv(q, p)\n }\n\n })\n\n function _kldiv (q, p) {\n const plength = p.size().length\n const qlength = q.size().length\n if (plength > 1) {\n throw new Error('first object must be one dimensional')\n }\n\n if (qlength > 1) {\n throw new Error('second object must be one dimensional')\n }\n\n if (plength !== qlength) {\n throw new Error('Length of two vectors must be equal')\n }\n\n // Before calculation, apply normalization\n const sumq = sum(q)\n if (sumq === 0) {\n throw new Error('Sum of elements in first object must be non zero')\n }\n\n const sump = sum(p)\n if (sump === 0) {\n throw new Error('Sum of elements in second object must be non zero')\n }\n const qnorm = divide(q, sum(q))\n const pnorm = divide(p, sum(p))\n\n const result = sum(multiply(qnorm, map(dotDivide(qnorm, pnorm), x => log(x))))\n if (isNumeric(result)) {\n return result\n } else {\n return Number.NaN\n }\n }\n})\n","import { deepForEach } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'multinomial'\nconst dependencies = ['typed', 'add', 'divide', 'multiply', 'factorial', 'isInteger', 'isPositive']\n\nexport const createMultinomial = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide, multiply, factorial, isInteger, isPositive }) => {\n /**\n * Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities.\n *\n * multinomial takes one array of integers as an argument.\n * The following condition must be enforced: every ai <= 0\n *\n * Syntax:\n *\n * math.multinomial(a) // a is an array type\n *\n * Examples:\n *\n * math.multinomial([1,2,1]) // returns 12\n *\n * See also:\n *\n * combinations, factorial\n *\n * @param {number[] | BigNumber[]} a Integer numbers of objects in the subset\n * @return {Number | BigNumber} Multinomial coefficient.\n */\n return typed(name, {\n 'Array | Matrix': function (a) {\n let sum = 0\n let denom = 1\n\n deepForEach(a, function (ai) {\n if (!isInteger(ai) || !isPositive(ai)) {\n throw new TypeError('Positive integer value expected in function multinomial')\n }\n sum = add(sum, ai)\n denom = multiply(denom, factorial(ai))\n })\n\n return divide(factorial(sum), denom)\n }\n })\n})\n","import { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'permutations'\nconst dependencies = ['typed', 'factorial']\n\nexport const createPermutations = /* #__PURE__ */ factory(name, dependencies, ({ typed, factorial }) => {\n /**\n * Compute the number of ways of obtaining an ordered subset of `k` elements\n * from a set of `n` elements.\n *\n * Permutations only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.permutations(n)\n * math.permutations(n, k)\n *\n * Examples:\n *\n * math.permutations(5) // 120\n * math.permutations(5, 3) // 60\n *\n * See also:\n *\n * combinations, combinationsWithRep, factorial\n *\n * @param {number | BigNumber} n The number of objects in total\n * @param {number | BigNumber} [k] The number of objects in the subset\n * @return {number | BigNumber} The number of permutations\n */\n return typed(name, {\n 'number | BigNumber': factorial,\n 'number, number': function (n, k) {\n if (!isInteger(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function permutations')\n }\n if (!isInteger(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function permutations')\n }\n if (k > n) {\n throw new TypeError('second argument k must be less than or equal to first argument n')\n }\n // Permute n objects, k at a time\n return product((n - k) + 1, n)\n },\n\n 'BigNumber, BigNumber': function (n, k) {\n let result, i\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function permutations')\n }\n if (k.gt(n)) {\n throw new TypeError('second argument k must be less than or equal to first argument n')\n }\n\n const one = n.mul(0).add(1)\n result = one\n for (i = n.minus(k).plus(1); i.lte(n); i = i.plus(1)) {\n result = result.times(i)\n }\n\n return result\n }\n\n // TODO: implement support for collection in permutations\n })\n})\n\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\nfunction isPositiveInteger (n) {\n return n.isInteger() && n.gte(0)\n}\n","import seedrandom from 'seedrandom'\n\nconst singletonRandom = /* #__PURE__ */ seedrandom(Date.now())\n\nexport function createRng (randomSeed) {\n let random\n\n // create a new random generator with given seed\n function setSeed (seed) {\n random = seed === null ? singletonRandom : seedrandom(String(seed))\n }\n\n // initialize a seeded pseudo random number generator with config's random seed\n setSeed(randomSeed)\n\n // wrapper function so the rng can be updated via generator\n function rng () {\n return random()\n }\n\n return rng\n}\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isMatrix, isNumber } from '../../utils/is.js'\nimport { createRng } from './util/seededRNG.js'\n\nconst name = 'pickRandom'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createPickRandom = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n // seeded pseudo random number generator\n let rng = createRng(config.randomSeed)\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = createRng(curr.randomSeed)\n }\n })\n }\n\n /**\n * Random pick one or more values from a one dimensional array.\n * Array elements are picked using a random function with uniform or weighted distribution.\n *\n * Syntax:\n *\n * math.pickRandom(array)\n * math.pickRandom(array, number)\n * math.pickRandom(array, weights)\n * math.pickRandom(array, number, weights)\n * math.pickRandom(array, weights, number)\n * math.pickRandom(array, { weights, number, elementWise })\n *\n * Examples:\n *\n * math.pickRandom([3, 6, 12, 2]) // returns one of the values in the array\n * math.pickRandom([3, 6, 12, 2], 2) // returns an array of two of the values in the array\n * math.pickRandom([3, 6, 12, 2], { number: 2 }) // returns an array of two of the values in the array\n * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1]) // returns one of the values in the array with weighted distribution\n * math.pickRandom([3, 6, 12, 2], 2, [1, 3, 2, 1]) // returns an array of two of the values in the array with weighted distribution\n * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1], 2) // returns an array of two of the values in the array with weighted distribution\n *\n * math.pickRandom([{x: 1.0, y: 2.0}, {x: 1.1, y: 2.0}], { elementWise: false })\n * // returns one of the items in the array\n *\n * See also:\n *\n * random, randomInt\n *\n * @param {Array | Matrix} array A one dimensional array\n * @param {Int} number An int or float\n * @param {Array | Matrix} weights An array of ints or floats\n * @return {number | Array} Returns a single random value from array when number is undefined.\n * Returns an array with the configured number of elements when number is defined.\n */\n return typed(name, {\n 'Array | Matrix': function (possibles) {\n return _pickRandom(possibles, {})\n },\n\n 'Array | Matrix, Object': function (possibles, options) {\n return _pickRandom(possibles, options)\n },\n\n 'Array | Matrix, number': function (possibles, number) {\n return _pickRandom(possibles, { number })\n },\n\n 'Array | Matrix, Array | Matrix': function (possibles, weights) {\n return _pickRandom(possibles, { weights })\n },\n\n 'Array | Matrix, Array | Matrix, number': function (possibles, weights, number) {\n return _pickRandom(possibles, { number, weights })\n },\n\n 'Array | Matrix, number, Array | Matrix': function (possibles, number, weights) {\n return _pickRandom(possibles, { number, weights })\n }\n })\n\n /**\n * @param {Array | Matrix} possibles\n * @param {{\n * number?: number,\n * weights?: Array | Matrix,\n * elementWise: boolean\n * }} options\n * @returns {number | Array}\n * @private\n */\n function _pickRandom (possibles, { number, weights, elementWise = true }) {\n const single = (typeof number === 'undefined')\n if (single) {\n number = 1\n }\n\n const createMatrix = isMatrix(possibles)\n ? possibles.create\n : isMatrix(weights)\n ? weights.create\n : null\n\n possibles = possibles.valueOf() // get Array\n if (weights) {\n weights = weights.valueOf() // get Array\n }\n\n if (elementWise === true) {\n possibles = flatten(possibles)\n weights = flatten(weights)\n }\n\n let totalWeights = 0\n\n if (typeof weights !== 'undefined') {\n if (weights.length !== possibles.length) {\n throw new Error('Weights must have the same length as possibles')\n }\n\n for (let i = 0, len = weights.length; i < len; i++) {\n if (!isNumber(weights[i]) || weights[i] < 0) {\n throw new Error('Weights must be an array of positive numbers')\n }\n\n totalWeights += weights[i]\n }\n }\n\n const length = possibles.length\n\n const result = []\n let pick\n\n while (result.length < number) {\n if (typeof weights === 'undefined') {\n pick = possibles[Math.floor(rng() * length)]\n } else {\n let randKey = rng() * totalWeights\n\n for (let i = 0, len = possibles.length; i < len; i++) {\n randKey -= weights[i]\n\n if (randKey < 0) {\n pick = possibles[i]\n break\n }\n }\n }\n\n result.push(pick)\n }\n\n return single\n ? result[0]\n : createMatrix\n ? createMatrix(result)\n : result\n }\n})\n","/**\n * This is a util function for generating a random matrix recursively.\n * @param {number[]} size\n * @param {function} random\n * @returns {Array}\n */\nexport function randomMatrix (size, random) {\n const data = []\n size = size.slice(0)\n\n if (size.length > 1) {\n for (let i = 0, length = size.shift(); i < length; i++) {\n data.push(randomMatrix(size, random))\n }\n } else {\n for (let i = 0, length = size.shift(); i < length; i++) {\n data.push(random())\n }\n }\n\n return data\n}\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { createRng } from './util/seededRNG.js'\nimport { randomMatrix } from './util/randomMatrix.js'\n\nconst name = 'random'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createRandom = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n // seeded pseudo random number generator\n let rng = createRng(config.randomSeed)\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = createRng(curr.randomSeed)\n }\n })\n }\n\n /**\n * Return a random number larger or equal to `min` and smaller than `max`\n * using a uniform distribution.\n *\n * Syntax:\n *\n * math.random() // generate a random number between 0 and 1\n * math.random(max) // generate a random number between 0 and max\n * math.random(min, max) // generate a random number between min and max\n * math.random(size) // generate a matrix with random numbers between 0 and 1\n * math.random(size, max) // generate a matrix with random numbers between 0 and max\n * math.random(size, min, max) // generate a matrix with random numbers between min and max\n *\n * Examples:\n *\n * math.random() // returns a random number between 0 and 1\n * math.random(100) // returns a random number between 0 and 100\n * math.random(30, 40) // returns a random number between 30 and 40\n * math.random([2, 3]) // returns a 2x3 matrix with random numbers between 0 and 1\n *\n * See also:\n *\n * randomInt, pickRandom\n *\n * @param {Array | Matrix} [size] If provided, an array or matrix with given\n * size and filled with random values is returned\n * @param {number} [min] Minimum boundary for the random value, included\n * @param {number} [max] Maximum boundary for the random value, excluded\n * @return {number | Array | Matrix} A random number\n */\n return typed(name, {\n '': () => _random(0, 1),\n number: (max) => _random(0, max),\n 'number, number': (min, max) => _random(min, max),\n 'Array | Matrix': (size) => _randomMatrix(size, 0, 1),\n 'Array | Matrix, number': (size, max) => _randomMatrix(size, 0, max),\n 'Array | Matrix, number, number': (size, min, max) => _randomMatrix(size, min, max)\n })\n\n function _randomMatrix (size, min, max) {\n const res = randomMatrix(size.valueOf(), () => _random(min, max))\n return isMatrix(size) ? size.create(res, 'number') : res\n }\n\n function _random (min, max) {\n return min + rng() * (max - min)\n }\n})\n\n// number only implementation of random, no matrix support\n// TODO: there is quite some duplicate code in both createRandom and createRandomNumber, can we improve that?\nexport const createRandomNumber = /* #__PURE__ */ factory(name, ['typed', 'config', '?on'], ({ typed, config, on, matrix }) => {\n // seeded pseudo random number generator1\n let rng = createRng(config.randomSeed)\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = createRng(curr.randomSeed)\n }\n })\n }\n\n return typed(name, {\n '': () => _random(0, 1),\n number: (max) => _random(0, max),\n 'number, number': (min, max) => _random(min, max)\n })\n\n function _random (min, max) {\n return min + rng() * (max - min)\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { randomMatrix } from './util/randomMatrix.js'\nimport { createRng } from './util/seededRNG.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'randomInt'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createRandomInt = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n // seeded pseudo random number generator\n let rng = createRng(config.randomSeed)\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = createRng(curr.randomSeed)\n }\n })\n }\n\n /**\n * Return a random integer number larger or equal to `min` and smaller than `max`\n * using a uniform distribution.\n *\n * Syntax:\n *\n * math.randomInt() // generate a random integer between 0 and 1\n * math.randomInt(max) // generate a random integer between 0 and max\n * math.randomInt(min, max) // generate a random integer between min and max\n * math.randomInt(size) // generate a matrix with random integer between 0 and 1\n * math.randomInt(size, max) // generate a matrix with random integer between 0 and max\n * math.randomInt(size, min, max) // generate a matrix with random integer between min and max\n *\n * Examples:\n *\n * math.randomInt(100) // returns a random integer between 0 and 100\n * math.randomInt(30, 40) // returns a random integer between 30 and 40\n * math.randomInt([2, 3]) // returns a 2x3 matrix with random integers between 0 and 1\n *\n * See also:\n *\n * random, pickRandom\n *\n * @param {Array | Matrix} [size] If provided, an array or matrix with given\n * size and filled with random values is returned\n * @param {number} [min] Minimum boundary for the random value, included\n * @param {number} [max] Maximum boundary for the random value, excluded\n * @return {number | Array | Matrix} A random integer value\n */\n return typed(name, {\n '': () => _randomInt(0, 1),\n number: (max) => _randomInt(0, max),\n 'number, number': (min, max) => _randomInt(min, max),\n 'Array | Matrix': (size) => _randomIntMatrix(size, 0, 1),\n 'Array | Matrix, number': (size, max) => _randomIntMatrix(size, 0, max),\n 'Array | Matrix, number, number': (size, min, max) => _randomIntMatrix(size, min, max)\n })\n\n function _randomIntMatrix (size, min, max) {\n const res = randomMatrix(size.valueOf(), () => _randomInt(min, max))\n return isMatrix(size) ? size.create(res, 'number') : res\n }\n\n function _randomInt (min, max) {\n return Math.floor(min + rng() * (max - min))\n }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'stirlingS2'\nconst dependencies = [\n 'typed',\n 'addScalar',\n 'subtractScalar',\n 'multiplyScalar',\n 'divideScalar',\n 'pow',\n 'factorial',\n 'combinations',\n 'isNegative',\n 'isInteger',\n 'number',\n '?bignumber',\n 'larger'\n]\n\nexport const createStirlingS2 = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n addScalar,\n subtractScalar,\n multiplyScalar,\n divideScalar,\n pow,\n factorial,\n combinations,\n isNegative,\n isInteger,\n number,\n bignumber,\n larger\n }\n) => {\n const smallCache = []\n const bigCache = []\n /**\n * The Stirling numbers of the second kind, counts the number of ways to partition\n * a set of n labelled objects into k nonempty unlabelled subsets.\n * stirlingS2 only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * If n = k or k = 1 <= n, then s(n,k) = 1\n * If k = 0 < n, then s(n,k) = 0\n *\n * Note that if either n or k is supplied as a BigNumber, the result will be\n * as well.\n *\n * Syntax:\n *\n * math.stirlingS2(n, k)\n *\n * Examples:\n *\n * math.stirlingS2(5, 3) //returns 25\n *\n * See also:\n *\n * bellNumbers\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @param {Number | BigNumber} k Number of objects in the subset\n * @return {Number | BigNumber} S(n,k)\n */\n return typed(name, {\n 'number | BigNumber, number | BigNumber': function (n, k) {\n if (!isInteger(n) || isNegative(n) || !isInteger(k) || isNegative(k)) {\n throw new TypeError('Non-negative integer value expected in function stirlingS2')\n } else if (larger(k, n)) {\n throw new TypeError('k must be less than or equal to n in function stirlingS2')\n }\n\n const big = !(isNumber(n) && isNumber(k))\n const cache = big ? bigCache : smallCache\n const make = big ? bignumber : number\n const nn = number(n)\n const nk = number(k)\n /* See if we already have the value: */\n if (cache[nn] && cache[nn].length > nk) {\n return cache[nn][nk]\n }\n /* Fill the cache */\n for (let m = 0; m <= nn; ++m) {\n if (!cache[m]) {\n cache[m] = [m === 0 ? make(1) : make(0)]\n }\n if (m === 0) continue\n const row = cache[m]\n const prev = cache[m - 1]\n for (let i = row.length; i <= m && i <= nk; ++i) {\n if (i === m) {\n row[i] = 1\n } else {\n row[i] = addScalar(multiplyScalar(make(i), prev[i]), prev[i - 1])\n }\n }\n }\n return cache[nn][nk]\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'bellNumbers'\nconst dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2']\n\nexport const createBellNumbers = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, isNegative, isInteger, stirlingS2 }) => {\n /**\n * The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S.\n * bellNumbers only takes integer arguments.\n * The following condition must be enforced: n >= 0\n *\n * Syntax:\n *\n * math.bellNumbers(n)\n *\n * Examples:\n *\n * math.bellNumbers(3) // returns 5\n * math.bellNumbers(8) // returns 4140\n *\n * See also:\n *\n * stirlingS2\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @return {Number | BigNumber} B(n)\n */\n return typed(name, {\n 'number | BigNumber': function (n) {\n if (!isInteger(n) || isNegative(n)) {\n throw new TypeError('Non-negative integer value expected in function bellNumbers')\n }\n\n // Sum (k=0, n) S(n,k).\n let result = 0\n for (let i = 0; i <= n; i++) {\n result = addScalar(result, stirlingS2(n, i))\n }\n\n return result\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'catalan'\nconst dependencies = [\n 'typed',\n 'addScalar',\n 'divideScalar',\n 'multiplyScalar',\n 'combinations',\n 'isNegative',\n 'isInteger'\n]\n\nexport const createCatalan = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n addScalar,\n divideScalar,\n multiplyScalar,\n combinations,\n isNegative,\n isInteger\n }\n) => {\n /**\n * The Catalan Numbers enumerate combinatorial structures of many different types.\n * catalan only takes integer arguments.\n * The following condition must be enforced: n >= 0\n *\n * Syntax:\n *\n * math.catalan(n)\n *\n * Examples:\n *\n * math.catalan(3) // returns 5\n * math.catalan(8) // returns 1430\n *\n * See also:\n *\n * bellNumbers\n *\n * @param {Number | BigNumber} n nth Catalan number\n * @return {Number | BigNumber} Cn(n)\n */\n return typed(name, {\n 'number | BigNumber': function (n) {\n if (!isInteger(n) || isNegative(n)) {\n throw new TypeError('Non-negative integer value expected in function catalan')\n }\n\n return divideScalar(combinations(multiplyScalar(n, 2), n), addScalar(n, 1))\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'composition'\nconst dependencies = [\n 'typed',\n 'addScalar',\n 'combinations',\n 'isNegative',\n 'isPositive',\n 'isInteger',\n 'larger'\n]\n\nexport const createComposition = /* #__PURE__ */ factory(name, dependencies, (\n {\n typed,\n addScalar,\n combinations,\n isPositive,\n isNegative,\n isInteger,\n larger\n }\n) => {\n /**\n * The composition counts of n into k parts.\n *\n * composition only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.composition(n, k)\n *\n * Examples:\n *\n * math.composition(5, 3) // returns 6\n *\n * See also:\n *\n * combinations\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @param {Number | BigNumber} k Number of objects in the subset\n * @return {Number | BigNumber} Returns the composition counts of n into k parts.\n */\n return typed(name, {\n 'number | BigNumber, number | BigNumber': function (n, k) {\n if (!isInteger(n) || !isPositive(n) || !isInteger(k) || !isPositive(k)) {\n throw new TypeError('Positive integer value expected in function composition')\n } else if (larger(k, n)) {\n throw new TypeError('k must be less than or equal to n in function composition')\n }\n\n return combinations(addScalar(n, -1), addScalar(k, -1))\n }\n })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'leafCount'\nconst dependencies = [\n 'parse',\n 'typed'\n]\n\nexport const createLeafCount = /* #__PURE__ */ factory(name, dependencies, ({\n parse,\n typed\n}) => {\n // This does the real work, but we don't have to recurse through\n // a typed call if we separate it out\n function countLeaves (node) {\n let count = 0\n node.forEach(n => { count += countLeaves(n) })\n return count || 1\n }\n\n /**\n * Gives the number of \"leaf nodes\" in the parse tree of the given expression\n * A leaf node is one that has no subexpressions, essentially either a\n * symbol or a constant. Note that `5!` has just one leaf, the '5'; the\n * unary factorial operator does not add a leaf. On the other hand,\n * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves.\n *\n * The `simplify()` function should generally not increase the `leafCount()`\n * of an expression, although currently there is no guarantee that it never\n * does so. In many cases, `simplify()` reduces the leaf count.\n *\n * Syntax:\n *\n * math.leafCount(expr)\n *\n * Examples:\n *\n * math.leafCount('x') // 1\n * math.leafCount(math.parse('a*d-b*c')) // 4\n * math.leafCount('[a,b;c,d][0,1]') // 6\n *\n * See also:\n *\n * simplify\n *\n * @param {Node|string} expr The expression to count the leaves of\n *\n * @return {number} The number of leaves of `expr`\n *\n */\n return typed(name, {\n Node: function (expr) {\n return countLeaves(expr)\n }\n })\n})\n","import { isConstantNode, isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'\nexport { isConstantNode, isSymbolNode as isVariableNode } from '../../../utils/is.js'\n\nexport function isNumericNode (x) {\n return isConstantNode(x) || (isOperatorNode(x) && x.isUnary() && isConstantNode(x.args[0]))\n}\n\nexport function isConstantExpression (x) {\n if (isConstantNode(x)) { // Basic Constant types\n return true\n }\n if ((isFunctionNode(x) || isOperatorNode(x)) && x.args.every(isConstantExpression)) { // Can be constant depending on arguments\n return true\n }\n if (isParenthesisNode(x) && isConstantExpression(x.content)) { // Parenthesis are transparent\n return true\n }\n return false // Probably missing some edge cases\n}\n","import { isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\nimport { hasOwnProperty } from '../../../utils/object.js'\n\nconst name = 'simplifyUtil'\nconst dependencies = [\n 'FunctionNode',\n 'OperatorNode',\n 'SymbolNode'\n]\n\nexport const createUtil = /* #__PURE__ */ factory(name, dependencies, ({ FunctionNode, OperatorNode, SymbolNode }) => {\n // TODO commutative/associative properties rely on the arguments\n // e.g. multiply is not commutative for matrices\n // The properties should be calculated from an argument to simplify, or possibly something in math.config\n // the other option is for typed() to specify a return type so that we can evaluate the type of arguments\n\n /* So that properties of an operator fit on one line: */\n const T = true\n const F = false\n\n const defaultName = 'defaultF'\n const defaultContext = {\n /* */ add: { trivial: T, total: T, commutative: T, associative: T },\n /**/ unaryPlus: { trivial: T, total: T, commutative: T, associative: T },\n /* */ subtract: { trivial: F, total: T, commutative: F, associative: F },\n /* */ multiply: { trivial: T, total: T, commutative: T, associative: T },\n /* */ divide: { trivial: F, total: T, commutative: F, associative: F },\n /* */ paren: { trivial: T, total: T, commutative: T, associative: F },\n /* */ defaultF: { trivial: F, total: T, commutative: F, associative: F }\n }\n const realContext = { divide: { total: F }, log: { total: F } }\n const positiveContext = {\n subtract: { total: F },\n abs: { trivial: T },\n log: { total: T }\n }\n\n function hasProperty (nodeOrName, property, context = defaultContext) {\n let name = defaultName\n if (typeof nodeOrName === 'string') {\n name = nodeOrName\n } else if (isOperatorNode(nodeOrName)) {\n name = nodeOrName.fn.toString()\n } else if (isFunctionNode(nodeOrName)) {\n name = nodeOrName.name\n } else if (isParenthesisNode(nodeOrName)) {\n name = 'paren'\n }\n if (hasOwnProperty(context, name)) {\n const properties = context[name]\n if (hasOwnProperty(properties, property)) {\n return properties[property]\n }\n if (hasOwnProperty(defaultContext, name)) {\n return defaultContext[name][property]\n }\n }\n if (hasOwnProperty(context, defaultName)) {\n const properties = context[defaultName]\n if (hasOwnProperty(properties, property)) {\n return properties[property]\n }\n return defaultContext[defaultName][property]\n }\n /* name not found in context and context has no global default */\n /* So use default context. */\n if (hasOwnProperty(defaultContext, name)) {\n const properties = defaultContext[name]\n if (hasOwnProperty(properties, property)) {\n return properties[property]\n }\n }\n return defaultContext[defaultName][property]\n }\n\n function isCommutative (node, context = defaultContext) {\n return hasProperty(node, 'commutative', context)\n }\n\n function isAssociative (node, context = defaultContext) {\n return hasProperty(node, 'associative', context)\n }\n\n /**\n * Merge the given contexts, with primary overriding secondary\n * wherever they might conflict\n */\n function mergeContext (primary, secondary) {\n const merged = { ...primary }\n for (const prop in secondary) {\n if (hasOwnProperty(primary, prop)) {\n merged[prop] = { ...secondary[prop], ...primary[prop] }\n } else {\n merged[prop] = secondary[prop]\n }\n }\n return merged\n }\n\n /**\n * Flatten all associative operators in an expression tree.\n * Assumes parentheses have already been removed.\n */\n function flatten (node, context) {\n if (!node.args || node.args.length === 0) {\n return node\n }\n node.args = allChildren(node, context)\n for (let i = 0; i < node.args.length; i++) {\n flatten(node.args[i], context)\n }\n }\n\n /**\n * Get the children of a node as if it has been flattened.\n * TODO implement for FunctionNodes\n */\n function allChildren (node, context) {\n let op\n const children = []\n const findChildren = function (node) {\n for (let i = 0; i < node.args.length; i++) {\n const child = node.args[i]\n if (isOperatorNode(child) && op === child.op) {\n findChildren(child)\n } else {\n children.push(child)\n }\n }\n }\n\n if (isAssociative(node, context)) {\n op = node.op\n findChildren(node)\n return children\n } else {\n return node.args\n }\n }\n\n /**\n * Unflatten all flattened operators to a right-heavy binary tree.\n */\n function unflattenr (node, context) {\n if (!node.args || node.args.length === 0) {\n return\n }\n const makeNode = createMakeNodeFunction(node)\n const l = node.args.length\n for (let i = 0; i < l; i++) {\n unflattenr(node.args[i], context)\n }\n if (l > 2 && isAssociative(node, context)) {\n let curnode = node.args.pop()\n while (node.args.length > 0) {\n curnode = makeNode([node.args.pop(), curnode])\n }\n node.args = curnode.args\n }\n }\n\n /**\n * Unflatten all flattened operators to a left-heavy binary tree.\n */\n function unflattenl (node, context) {\n if (!node.args || node.args.length === 0) {\n return\n }\n const makeNode = createMakeNodeFunction(node)\n const l = node.args.length\n for (let i = 0; i < l; i++) {\n unflattenl(node.args[i], context)\n }\n if (l > 2 && isAssociative(node, context)) {\n let curnode = node.args.shift()\n while (node.args.length > 0) {\n curnode = makeNode([curnode, node.args.shift()])\n }\n node.args = curnode.args\n }\n }\n\n function createMakeNodeFunction (node) {\n if (isOperatorNode(node)) {\n return function (args) {\n try {\n return new OperatorNode(node.op, node.fn, args, node.implicit)\n } catch (err) {\n console.error(err)\n return []\n }\n }\n } else {\n return function (args) {\n return new FunctionNode(new SymbolNode(node.name), args)\n }\n }\n }\n\n return {\n createMakeNodeFunction,\n hasProperty,\n isCommutative,\n isAssociative,\n mergeContext,\n flatten,\n allChildren,\n unflattenr,\n unflattenl,\n defaultContext,\n realContext,\n positiveContext\n }\n})\n","import { isParenthesisNode } from '../../utils/is.js'\nimport { isConstantNode, isVariableNode, isNumericNode, isConstantExpression } from './simplify/wildcards.js'\nimport { factory } from '../../utils/factory.js'\nimport { createUtil } from './simplify/util.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { createEmptyMap, createMap } from '../../utils/map.js'\n\nconst name = 'simplify'\nconst dependencies = [\n 'config',\n 'typed',\n 'parse',\n 'add',\n 'subtract',\n 'multiply',\n 'divide',\n 'pow',\n 'isZero',\n 'equal',\n 'resolve',\n 'simplifyConstant',\n 'simplifyCore',\n '?fraction',\n '?bignumber',\n 'mathWithTransform',\n 'matrix',\n 'AccessorNode',\n 'ArrayNode',\n 'ConstantNode',\n 'FunctionNode',\n 'IndexNode',\n 'ObjectNode',\n 'OperatorNode',\n 'ParenthesisNode',\n 'SymbolNode'\n]\n\nexport const createSimplify = /* #__PURE__ */ factory(name, dependencies, (\n {\n config,\n typed,\n parse,\n add,\n subtract,\n multiply,\n divide,\n pow,\n isZero,\n equal,\n resolve,\n simplifyConstant,\n simplifyCore,\n fraction,\n bignumber,\n mathWithTransform,\n matrix,\n AccessorNode,\n ArrayNode,\n ConstantNode,\n FunctionNode,\n IndexNode,\n ObjectNode,\n OperatorNode,\n ParenthesisNode,\n SymbolNode\n }\n) => {\n const { hasProperty, isCommutative, isAssociative, mergeContext, flatten, unflattenr, unflattenl, createMakeNodeFunction, defaultContext, realContext, positiveContext } =\n createUtil({ FunctionNode, OperatorNode, SymbolNode })\n\n /**\n * Simplify an expression tree.\n *\n * A list of rules are applied to an expression, repeating over the list until\n * no further changes are made.\n * It's possible to pass a custom set of rules to the function as second\n * argument. A rule can be specified as an object, string, or function:\n *\n * const rules = [\n * { l: 'n1*n3 + n2*n3', r: '(n1+n2)*n3' },\n * 'n1*n3 + n2*n3 -> (n1+n2)*n3',\n * function (node) {\n * // ... return a new node or return the node unchanged\n * return node\n * }\n * ]\n *\n * String and object rules consist of a left and right pattern. The left is\n * used to match against the expression and the right determines what matches\n * are replaced with. The main difference between a pattern and a normal\n * expression is that variables starting with the following characters are\n * interpreted as wildcards:\n *\n * - 'n' - Matches any node [Node]\n * - 'c' - Matches a constant literal (5 or 3.2) [ConstantNode]\n * - 'cl' - Matches a constant literal; same as c [ConstantNode]\n * - 'cd' - Matches a decimal literal (5 or -3.2) [ConstantNode or unaryMinus wrapping a ConstantNode]\n * - 'ce' - Matches a constant expression (-5 or √3) [Expressions consisting of only ConstantNodes, functions, and operators]\n * - 'v' - Matches a variable; anything not matched by c (-5 or x) [Node that is not a ConstantNode]\n * - 'vl' - Matches a variable literal (x or y) [SymbolNode]\n * - 'vd' - Matches a non-decimal expression; anything not matched by cd (x or √3) [Node that is not a ConstantNode or unaryMinus that is wrapping a ConstantNode]\n * - 've' - Matches a variable expression; anything not matched by ce (x or 2x) [Expressions that contain a SymbolNode or other non-constant term]\n *\n * The default list of rules is exposed on the function as `simplify.rules`\n * and can be used as a basis to built a set of custom rules. Note that since\n * the `simplifyCore` function is in the default list of rules, by default\n * simplify will convert any function calls in the expression that have\n * operator equivalents to their operator forms.\n *\n * To specify a rule as a string, separate the left and right pattern by '->'\n * When specifying a rule as an object, the following keys are meaningful:\n * - l - the left pattern\n * - r - the right pattern\n * - s - in lieu of l and r, the string form that is broken at -> to give them\n * - repeat - whether to repeat this rule until the expression stabilizes\n * - assuming - gives a context object, as in the 'context' option to\n * simplify. Every property in the context object must match the current\n * context in order, or else the rule will not be applied.\n * - imposeContext - gives a context object, as in the 'context' option to\n * simplify. Any settings specified will override the incoming context\n * for all matches of this rule.\n *\n * For more details on the theory, see:\n *\n * - [Strategies for simplifying math expressions (Stackoverflow)](https://stackoverflow.com/questions/7540227/strategies-for-simplifying-math-expressions)\n * - [Symbolic computation - Simplification (Wikipedia)](https://en.wikipedia.org/wiki/Symbolic_computation#Simplification)\n *\n * An optional `options` argument can be passed as last argument of `simplify`.\n * Currently available options (defaults in parentheses):\n * - `consoleDebug` (false): whether to write the expression being simplified\n * and any changes to it, along with the rule responsible, to console\n * - `context` (simplify.defaultContext): an object giving properties of\n * each operator, which determine what simplifications are allowed. The\n * currently meaningful properties are commutative, associative,\n * total (whether the operation is defined for all arguments), and\n * trivial (whether the operation applied to a single argument leaves\n * that argument unchanged). The default context is very permissive and\n * allows almost all simplifications. Only properties differing from\n * the default need to be specified; the default context is used as a\n * fallback. Additional contexts `simplify.realContext` and\n * `simplify.positiveContext` are supplied to cause simplify to perform\n * just simplifications guaranteed to preserve all values of the expression\n * assuming all variables and subexpressions are real numbers or\n * positive real numbers, respectively. (Note that these are in some cases\n * more restrictive than the default context; for example, the default\n * context will allow `x/x` to simplify to 1, whereas\n * `simplify.realContext` will not, as `0/0` is not equal to 1.)\n * - `exactFractions` (true): whether to try to convert all constants to\n * exact rational numbers.\n * - `fractionsLimit` (10000): when `exactFractions` is true, constants will\n * be expressed as fractions only when both numerator and denominator\n * are smaller than `fractionsLimit`.\n *\n * Syntax:\n *\n * math.simplify(expr)\n * math.simplify(expr, rules)\n * math.simplify(expr, rules)\n * math.simplify(expr, rules, scope)\n * math.simplify(expr, rules, scope, options)\n * math.simplify(expr, scope)\n * math.simplify(expr, scope, options)\n *\n * Examples:\n *\n * math.simplify('2 * 1 * x ^ (2 - 1)') // Node \"2 * x\"\n * math.simplify('2 * 3 * x', {x: 4}) // Node \"24\"\n * const f = math.parse('2 * 1 * x ^ (2 - 1)')\n * math.simplify(f) // Node \"2 * x\"\n * math.simplify('0.4 * x', {}, {exactFractions: true}) // Node \"x * 2 / 5\"\n * math.simplify('0.4 * x', {}, {exactFractions: false}) // Node \"0.4 * x\"\n *\n * See also:\n *\n * simplifyCore, derivative, evaluate, parse, rationalize, resolve\n *\n * @param {Node | string} expr\n * The expression to be simplified\n * @param {SimplifyRule[]} [rules]\n * Optional list with custom rules\n * @param {Object} [scope] Optional scope with variables\n * @param {SimplifyOptions} [options] Optional configuration settings\n * @return {Node} Returns the simplified form of `expr`\n */\n typed.addConversion({ from: 'Object', to: 'Map', convert: createMap })\n const simplify = typed('simplify', {\n Node: _simplify,\n 'Node, Map': (expr, scope) => _simplify(expr, false, scope),\n 'Node, Map, Object':\n (expr, scope, options) => _simplify(expr, false, scope, options),\n 'Node, Array': _simplify,\n 'Node, Array, Map': _simplify,\n 'Node, Array, Map, Object': _simplify\n })\n typed.removeConversion({ from: 'Object', to: 'Map', convert: createMap })\n\n simplify.defaultContext = defaultContext\n simplify.realContext = realContext\n simplify.positiveContext = positiveContext\n\n function removeParens (node) {\n return node.transform(function (node, path, parent) {\n return isParenthesisNode(node)\n ? removeParens(node.content)\n : node\n })\n }\n\n // All constants that are allowed in rules\n const SUPPORTED_CONSTANTS = {\n true: true,\n false: true,\n e: true,\n i: true,\n Infinity: true,\n LN2: true,\n LN10: true,\n LOG2E: true,\n LOG10E: true,\n NaN: true,\n phi: true,\n pi: true,\n SQRT1_2: true,\n SQRT2: true,\n tau: true\n // null: false,\n // undefined: false,\n // version: false,\n }\n\n // Array of strings, used to build the ruleSet.\n // Each l (left side) and r (right side) are parsed by\n // the expression parser into a node tree.\n // Left hand sides are matched to subtrees within the\n // expression to be parsed and replaced with the right\n // hand side.\n // TODO: Add support for constraints on constants (either in the form of a '=' expression or a callback [callback allows things like comparing symbols alphabetically])\n // To evaluate lhs constants for rhs constants, use: { l: 'c1+c2', r: 'c3', evaluate: 'c3 = c1 + c2' }. Multiple assignments are separated by ';' in block format.\n // It is possible to get into an infinite loop with conflicting rules\n simplify.rules = [\n simplifyCore,\n // { l: 'n+0', r: 'n' }, // simplifyCore\n // { l: 'n^0', r: '1' }, // simplifyCore\n // { l: '0*n', r: '0' }, // simplifyCore\n // { l: 'n/n', r: '1'}, // simplifyCore\n // { l: 'n^1', r: 'n' }, // simplifyCore\n // { l: '+n1', r:'n1' }, // simplifyCore\n // { l: 'n--n1', r:'n+n1' }, // simplifyCore\n { l: 'log(e)', r: '1' },\n\n // temporary rules\n // Note initially we tend constants to the right because like-term\n // collection prefers the left, and we would rather collect nonconstants\n {\n s: 'n-n1 -> n+-n1', // temporarily replace 'subtract' so we can further flatten the 'add' operator\n assuming: { subtract: { total: true } }\n },\n {\n s: 'n-n -> 0', // partial alternative when we can't always subtract\n assuming: { subtract: { total: false } }\n },\n {\n s: '-(cl*v) -> v * (-cl)', // make non-constant terms positive\n assuming: { multiply: { commutative: true }, subtract: { total: true } }\n },\n {\n s: '-(cl*v) -> (-cl) * v', // non-commutative version, part 1\n assuming: { multiply: { commutative: false }, subtract: { total: true } }\n },\n {\n s: '-(v*cl) -> v * (-cl)', // non-commutative version, part 2\n assuming: { multiply: { commutative: false }, subtract: { total: true } }\n },\n { l: '-(n1/n2)', r: '-n1/n2' },\n { l: '-v', r: 'v * (-1)' }, // finish making non-constant terms positive\n { l: '(n1 + n2)*(-1)', r: 'n1*(-1) + n2*(-1)', repeat: true }, // expand negations to achieve as much sign cancellation as possible\n { l: 'n/n1^n2', r: 'n*n1^-n2' }, // temporarily replace 'divide' so we can further flatten the 'multiply' operator\n { l: 'n/n1', r: 'n*n1^-1' },\n {\n s: '(n1*n2)^n3 -> n1^n3 * n2^n3',\n assuming: { multiply: { commutative: true } }\n },\n {\n s: '(n1*n2)^(-1) -> n2^(-1) * n1^(-1)',\n assuming: { multiply: { commutative: false } }\n },\n\n // expand nested exponentiation\n {\n s: '(n ^ n1) ^ n2 -> n ^ (n1 * n2)',\n assuming: { divide: { total: true } } // 1/(1/n) = n needs 1/n to exist\n },\n\n // collect like factors; into a sum, only do this for nonconstants\n { l: ' vd * ( vd * n1 + n2)', r: 'vd^2 * n1 + vd * n2' },\n {\n s: ' vd * (vd^n4 * n1 + n2) -> vd^(1+n4) * n1 + vd * n2',\n assuming: { divide: { total: true } } // v*1/v = v^(1+-1) needs 1/v\n },\n {\n s: 'vd^n3 * ( vd * n1 + n2) -> vd^(n3+1) * n1 + vd^n3 * n2',\n assuming: { divide: { total: true } }\n },\n {\n s: 'vd^n3 * (vd^n4 * n1 + n2) -> vd^(n3+n4) * n1 + vd^n3 * n2',\n assuming: { divide: { total: true } }\n },\n { l: 'n*n', r: 'n^2' },\n {\n s: 'n * n^n1 -> n^(n1+1)',\n assuming: { divide: { total: true } } // n*1/n = n^(-1+1) needs 1/n\n },\n {\n s: 'n^n1 * n^n2 -> n^(n1+n2)',\n assuming: { divide: { total: true } } // ditto for n^2*1/n^2\n },\n\n // Unfortunately, to deal with more complicated cancellations, it\n // becomes necessary to simplify constants twice per pass. It's not\n // terribly expensive compared to matching rules, so this should not\n // pose a performance problem.\n simplifyConstant, // First: before collecting like terms\n\n // collect like terms\n {\n s: 'n+n -> 2*n',\n assuming: { add: { total: true } } // 2 = 1 + 1 needs to exist\n },\n { l: 'n+-n', r: '0' },\n { l: 'vd*n + vd', r: 'vd*(n+1)' }, // NOTE: leftmost position is special:\n { l: 'n3*n1 + n3*n2', r: 'n3*(n1+n2)' }, // All sub-monomials tried there.\n { l: 'n3^(-n4)*n1 + n3 * n2', r: 'n3^(-n4)*(n1 + n3^(n4+1) *n2)' },\n { l: 'n3^(-n4)*n1 + n3^n5 * n2', r: 'n3^(-n4)*(n1 + n3^(n4+n5)*n2)' },\n // noncommutative additional cases (term collection & factoring)\n {\n s: 'n*vd + vd -> (n+1)*vd',\n assuming: { multiply: { commutative: false } }\n },\n {\n s: 'vd + n*vd -> (1+n)*vd',\n assuming: { multiply: { commutative: false } }\n },\n {\n s: 'n1*n3 + n2*n3 -> (n1+n2)*n3',\n assuming: { multiply: { commutative: false } }\n },\n {\n s: 'n^n1 * n -> n^(n1+1)',\n assuming: { divide: { total: true }, multiply: { commutative: false } }\n },\n {\n s: 'n1*n3^(-n4) + n2 * n3 -> (n1 + n2*n3^(n4 + 1))*n3^(-n4)',\n assuming: { multiply: { commutative: false } }\n },\n {\n s: 'n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)',\n assuming: { multiply: { commutative: false } }\n },\n { l: 'n*cd + cd', r: '(n+1)*cd' },\n {\n s: 'cd*n + cd -> cd*(n+1)',\n assuming: { multiply: { commutative: false } }\n },\n {\n s: 'cd + cd*n -> cd*(1+n)',\n assuming: { multiply: { commutative: false } }\n },\n simplifyConstant, // Second: before returning expressions to \"standard form\"\n\n // make factors positive (and undo 'make non-constant terms positive')\n {\n s: '(-n)*n1 -> -(n*n1)',\n assuming: { subtract: { total: true } }\n },\n {\n s: 'n1*(-n) -> -(n1*n)', // in case * non-commutative\n assuming: { subtract: { total: true }, multiply: { commutative: false } }\n },\n\n // final ordering of constants\n {\n s: 'ce+ve -> ve+ce',\n assuming: { add: { commutative: true } },\n imposeContext: { add: { commutative: false } }\n },\n {\n s: 'vd*cd -> cd*vd',\n assuming: { multiply: { commutative: true } },\n imposeContext: { multiply: { commutative: false } }\n },\n\n // undo temporary rules\n // { l: '(-1) * n', r: '-n' }, // #811 added test which proved this is redundant\n { l: 'n+-n1', r: 'n-n1' }, // undo replace 'subtract'\n { l: 'n+-(n1)', r: 'n-(n1)' },\n {\n s: 'n*(n1^-1) -> n/n1', // undo replace 'divide'; for * commutative\n assuming: { multiply: { commutative: true } } // o.w. / not conventional\n },\n {\n s: 'n*n1^-n2 -> n/n1^n2',\n assuming: { multiply: { commutative: true } } // o.w. / not conventional\n },\n {\n s: 'n^-1 -> 1/n',\n assuming: { multiply: { commutative: true } } // o.w. / not conventional\n },\n { l: 'n^1', r: 'n' }, // can be produced by power cancellation\n {\n s: 'n*(n1/n2) -> (n*n1)/n2', // '*' before '/'\n assuming: { multiply: { associative: true } }\n },\n {\n s: 'n-(n1+n2) -> n-n1-n2', // '-' before '+'\n assuming: { addition: { associative: true, commutative: true } }\n },\n // { l: '(n1/n2)/n3', r: 'n1/(n2*n3)' },\n // { l: '(n*n1)/(n*n2)', r: 'n1/n2' },\n\n // simplifyConstant can leave an extra factor of 1, which can always\n // be eliminated, since the identity always commutes\n { l: '1*n', r: 'n', imposeContext: { multiply: { commutative: true } } },\n\n {\n s: 'n1/(n2/n3) -> (n1*n3)/n2',\n assuming: { multiply: { associative: true } }\n },\n\n { l: 'n1/(-n2)', r: '-n1/n2' }\n\n ]\n\n /**\n * Takes any rule object as allowed by the specification in simplify\n * and puts it in a standard form used by applyRule\n */\n function _canonicalizeRule (ruleObject, context) {\n const newRule = {}\n if (ruleObject.s) {\n const lr = ruleObject.s.split('->')\n if (lr.length === 2) {\n newRule.l = lr[0]\n newRule.r = lr[1]\n } else {\n throw SyntaxError('Could not parse rule: ' + ruleObject.s)\n }\n } else {\n newRule.l = ruleObject.l\n newRule.r = ruleObject.r\n }\n newRule.l = removeParens(parse(newRule.l))\n newRule.r = removeParens(parse(newRule.r))\n for (const prop of ['imposeContext', 'repeat', 'assuming']) {\n if (prop in ruleObject) {\n newRule[prop] = ruleObject[prop]\n }\n }\n if (ruleObject.evaluate) {\n newRule.evaluate = parse(ruleObject.evaluate)\n }\n\n if (isAssociative(newRule.l, context)) {\n const nonCommutative = !isCommutative(newRule.l, context)\n let leftExpandsym\n // Gen. the LHS placeholder used in this NC-context specific expansion rules\n if (nonCommutative) leftExpandsym = _getExpandPlaceholderSymbol()\n\n const makeNode = createMakeNodeFunction(newRule.l)\n const expandsym = _getExpandPlaceholderSymbol()\n newRule.expanded = {}\n newRule.expanded.l = makeNode([newRule.l, expandsym])\n // Push the expandsym into the deepest possible branch.\n // This helps to match the newRule against nodes returned from getSplits() later on.\n flatten(newRule.expanded.l, context)\n unflattenr(newRule.expanded.l, context)\n newRule.expanded.r = makeNode([newRule.r, expandsym])\n\n // In and for a non-commutative context, attempting with yet additional expansion rules makes\n // way for more matches cases of multi-arg expressions; such that associative rules (such as\n // 'n*n -> n^2') can be applied to exprs. such as 'a * b * b' and 'a * b * b * a'.\n if (nonCommutative) {\n // 'Non-commutative' 1: LHS (placeholder) only\n newRule.expandedNC1 = {}\n newRule.expandedNC1.l = makeNode([leftExpandsym, newRule.l])\n newRule.expandedNC1.r = makeNode([leftExpandsym, newRule.r])\n // 'Non-commutative' 2: farmost LHS and RHS placeholders\n newRule.expandedNC2 = {}\n newRule.expandedNC2.l = makeNode([leftExpandsym, newRule.expanded.l])\n newRule.expandedNC2.r = makeNode([leftExpandsym, newRule.expanded.r])\n }\n }\n\n return newRule\n }\n\n /**\n * Parse the string array of rules into nodes\n *\n * Example syntax for rules:\n *\n * Position constants to the left in a product:\n * { l: 'n1 * c1', r: 'c1 * n1' }\n * n1 is any Node, and c1 is a ConstantNode.\n *\n * Apply difference of squares formula:\n * { l: '(n1 - n2) * (n1 + n2)', r: 'n1^2 - n2^2' }\n * n1, n2 mean any Node.\n *\n * Short hand notation:\n * 'n1 * c1 -> c1 * n1'\n */\n function _buildRules (rules, context) {\n // Array of rules to be used to simplify expressions\n const ruleSet = []\n for (let i = 0; i < rules.length; i++) {\n let rule = rules[i]\n let newRule\n const ruleType = typeof rule\n switch (ruleType) {\n case 'string':\n rule = { s: rule }\n /* falls through */\n case 'object':\n newRule = _canonicalizeRule(rule, context)\n break\n case 'function':\n newRule = rule\n break\n default:\n throw TypeError('Unsupported type of rule: ' + ruleType)\n }\n // console.log('Adding rule: ' + rules[i])\n // console.log(newRule)\n ruleSet.push(newRule)\n }\n return ruleSet\n }\n\n let _lastsym = 0\n function _getExpandPlaceholderSymbol () {\n return new SymbolNode('_p' + _lastsym++)\n }\n\n function _simplify (expr, rules, scope = createEmptyMap(), options = {}) {\n const debug = options.consoleDebug\n rules = _buildRules(rules || simplify.rules, options.context)\n let res = resolve(expr, scope)\n res = removeParens(res)\n const visited = {}\n let str = res.toString({ parenthesis: 'all' })\n while (!visited[str]) {\n visited[str] = true\n _lastsym = 0 // counter for placeholder symbols\n let laststr = str\n if (debug) console.log('Working on: ', str)\n for (let i = 0; i < rules.length; i++) {\n let rulestr = ''\n if (typeof rules[i] === 'function') {\n res = rules[i](res, options)\n if (debug) rulestr = rules[i].name\n } else {\n flatten(res, options.context)\n res = applyRule(res, rules[i], options.context)\n if (debug) {\n rulestr = `${rules[i].l.toString()} -> ${rules[i].r.toString()}`\n }\n }\n if (debug) {\n const newstr = res.toString({ parenthesis: 'all' })\n if (newstr !== laststr) {\n console.log('Applying', rulestr, 'produced', newstr)\n laststr = newstr\n }\n }\n /* Use left-heavy binary tree internally,\n * since custom rule functions may expect it\n */\n unflattenl(res, options.context)\n }\n str = res.toString({ parenthesis: 'all' })\n }\n return res\n }\n\n function mapRule (nodes, rule, context) {\n let resNodes = nodes\n if (nodes) {\n for (let i = 0; i < nodes.length; ++i) {\n const newNode = applyRule(nodes[i], rule, context)\n if (newNode !== nodes[i]) {\n if (resNodes === nodes) {\n resNodes = nodes.slice()\n }\n resNodes[i] = newNode\n }\n }\n }\n return resNodes\n }\n\n /**\n * Returns a simplfied form of node, or the original node if no simplification was possible.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object | Function} rule\n * @param {Object} context -- information about assumed properties of operators\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The simplified form of `expr`, or the original node if no simplification was possible.\n */\n function applyRule (node, rule, context) {\n // console.log('Entering applyRule(\"', rule.l.toString({parenthesis:'all'}), '->', rule.r.toString({parenthesis:'all'}), '\",', node.toString({parenthesis:'all'}),')')\n\n // check that the assumptions for this rule are satisfied by the current\n // context:\n if (rule.assuming) {\n for (const symbol in rule.assuming) {\n for (const property in rule.assuming[symbol]) {\n if (hasProperty(symbol, property, context) !==\n rule.assuming[symbol][property]) {\n return node\n }\n }\n }\n }\n\n const mergedContext = mergeContext(rule.imposeContext, context)\n\n // Do not clone node unless we find a match\n let res = node\n\n // First replace our child nodes with their simplified versions\n // If a child could not be simplified, applying the rule to it\n // will have no effect since the node is returned unchanged\n if (res instanceof OperatorNode || res instanceof FunctionNode) {\n const newArgs = mapRule(res.args, rule, context)\n if (newArgs !== res.args) {\n res = res.clone()\n res.args = newArgs\n }\n } else if (res instanceof ParenthesisNode) {\n if (res.content) {\n const newContent = applyRule(res.content, rule, context)\n if (newContent !== res.content) {\n res = new ParenthesisNode(newContent)\n }\n }\n } else if (res instanceof ArrayNode) {\n const newItems = mapRule(res.items, rule, context)\n if (newItems !== res.items) {\n res = new ArrayNode(newItems)\n }\n } else if (res instanceof AccessorNode) {\n let newObj = res.object\n if (res.object) {\n newObj = applyRule(res.object, rule, context)\n }\n let newIndex = res.index\n if (res.index) {\n newIndex = applyRule(res.index, rule, context)\n }\n if (newObj !== res.object || newIndex !== res.index) {\n res = new AccessorNode(newObj, newIndex)\n }\n } else if (res instanceof IndexNode) {\n const newDims = mapRule(res.dimensions, rule, context)\n if (newDims !== res.dimensions) {\n res = new IndexNode(newDims)\n }\n } else if (res instanceof ObjectNode) {\n let changed = false\n const newProps = {}\n for (const prop in res.properties) {\n newProps[prop] = applyRule(res.properties[prop], rule, context)\n if (newProps[prop] !== res.properties[prop]) {\n changed = true\n }\n }\n if (changed) {\n res = new ObjectNode(newProps)\n }\n }\n\n // Try to match a rule against this node\n let repl = rule.r\n let matches = _ruleMatch(rule.l, res, mergedContext)[0]\n\n // If the rule is associative operator, we can try matching it while allowing additional terms.\n // This allows us to match rules like 'n+n' to the expression '(1+x)+x' or even 'x+1+x' if the operator is commutative.\n if (!matches && rule.expanded) {\n repl = rule.expanded.r\n matches = _ruleMatch(rule.expanded.l, res, mergedContext)[0]\n }\n // Additional, non-commutative context expansion-rules\n if (!matches && rule.expandedNC1) {\n repl = rule.expandedNC1.r\n matches = _ruleMatch(rule.expandedNC1.l, res, mergedContext)[0]\n if (!matches) { // Existence of NC1 implies NC2\n repl = rule.expandedNC2.r\n matches = _ruleMatch(rule.expandedNC2.l, res, mergedContext)[0]\n }\n }\n\n if (matches) {\n // const before = res.toString({parenthesis: 'all'})\n\n // Create a new node by cloning the rhs of the matched rule\n // we keep any implicit multiplication state if relevant\n const implicit = res.implicit\n res = repl.clone()\n if (implicit && 'implicit' in repl) {\n res.implicit = true\n }\n\n // Replace placeholders with their respective nodes without traversing deeper into the replaced nodes\n res = res.transform(function (node) {\n if (node.isSymbolNode && hasOwnProperty(matches.placeholders, node.name)) {\n return matches.placeholders[node.name].clone()\n } else {\n return node\n }\n })\n\n // const after = res.toString({parenthesis: 'all'})\n // console.log('Simplified ' + before + ' to ' + after)\n }\n\n if (rule.repeat && res !== node) {\n res = applyRule(res, rule, context)\n }\n\n return res\n }\n\n /**\n * Get (binary) combinations of a flattened binary node\n * e.g. +(node1, node2, node3) -> [\n * +(node1, +(node2, node3)),\n * +(node2, +(node1, node3)),\n * +(node3, +(node1, node2))]\n *\n */\n function getSplits (node, context) {\n const res = []\n let right, rightArgs\n const makeNode = createMakeNodeFunction(node)\n if (isCommutative(node, context)) {\n for (let i = 0; i < node.args.length; i++) {\n rightArgs = node.args.slice(0)\n rightArgs.splice(i, 1)\n right = (rightArgs.length === 1) ? rightArgs[0] : makeNode(rightArgs)\n res.push(makeNode([node.args[i], right]))\n }\n } else {\n // Keep order, but try all parenthesizations\n for (let i = 1; i < node.args.length; i++) {\n let left = node.args[0]\n if (i > 1) {\n left = makeNode(node.args.slice(0, i))\n }\n rightArgs = node.args.slice(i)\n right = (rightArgs.length === 1) ? rightArgs[0] : makeNode(rightArgs)\n res.push(makeNode([left, right]))\n }\n }\n return res\n }\n\n /**\n * Returns the set union of two match-placeholders or null if there is a conflict.\n */\n function mergeMatch (match1, match2) {\n const res = { placeholders: {} }\n\n // Some matches may not have placeholders; this is OK\n if (!match1.placeholders && !match2.placeholders) {\n return res\n } else if (!match1.placeholders) {\n return match2\n } else if (!match2.placeholders) {\n return match1\n }\n\n // Placeholders with the same key must match exactly\n for (const key in match1.placeholders) {\n if (hasOwnProperty(match1.placeholders, key)) {\n res.placeholders[key] = match1.placeholders[key]\n\n if (hasOwnProperty(match2.placeholders, key)) {\n if (!_exactMatch(match1.placeholders[key], match2.placeholders[key])) {\n return null\n }\n }\n }\n }\n\n for (const key in match2.placeholders) {\n if (hasOwnProperty(match2.placeholders, key)) {\n res.placeholders[key] = match2.placeholders[key]\n }\n }\n\n return res\n }\n\n /**\n * Combine two lists of matches by applying mergeMatch to the cartesian product of two lists of matches.\n * Each list represents matches found in one child of a node.\n */\n function combineChildMatches (list1, list2) {\n const res = []\n\n if (list1.length === 0 || list2.length === 0) {\n return res\n }\n\n let merged\n for (let i1 = 0; i1 < list1.length; i1++) {\n for (let i2 = 0; i2 < list2.length; i2++) {\n merged = mergeMatch(list1[i1], list2[i2])\n if (merged) {\n res.push(merged)\n }\n }\n }\n return res\n }\n\n /**\n * Combine multiple lists of matches by applying mergeMatch to the cartesian product of two lists of matches.\n * Each list represents matches found in one child of a node.\n * Returns a list of unique matches.\n */\n function mergeChildMatches (childMatches) {\n if (childMatches.length === 0) {\n return childMatches\n }\n\n const sets = childMatches.reduce(combineChildMatches)\n const uniqueSets = []\n const unique = {}\n for (let i = 0; i < sets.length; i++) {\n const s = JSON.stringify(sets[i])\n if (!unique[s]) {\n unique[s] = true\n uniqueSets.push(sets[i])\n }\n }\n return uniqueSets\n }\n\n /**\n * Determines whether node matches rule.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} rule\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object} context -- provides assumed properties of operators\n * @param {Boolean} isSplit -- whether we are in process of splitting an\n * n-ary operator node into possible binary combinations.\n * Defaults to false.\n * @return {Object} Information about the match, if it exists.\n */\n function _ruleMatch (rule, node, context, isSplit) {\n // console.log('Entering _ruleMatch(' + JSON.stringify(rule) + ', ' + JSON.stringify(node) + ')')\n // console.log('rule = ' + rule)\n // console.log('node = ' + node)\n\n // console.log('Entering _ruleMatch(', rule.toString({parenthesis:'all'}), ', ', node.toString({parenthesis:'all'}), ', ', context, ')')\n let res = [{ placeholders: {} }]\n\n if ((rule instanceof OperatorNode && node instanceof OperatorNode) ||\n (rule instanceof FunctionNode && node instanceof FunctionNode)) {\n // If the rule is an OperatorNode or a FunctionNode, then node must match exactly\n if (rule instanceof OperatorNode) {\n if (rule.op !== node.op || rule.fn !== node.fn) {\n return []\n }\n } else if (rule instanceof FunctionNode) {\n if (rule.name !== node.name) {\n return []\n }\n }\n\n // rule and node match. Search the children of rule and node.\n if ((node.args.length === 1 && rule.args.length === 1) ||\n (!isAssociative(node, context) &&\n node.args.length === rule.args.length) ||\n isSplit) {\n // Expect non-associative operators to match exactly,\n // except in any order if operator is commutative\n let childMatches = []\n for (let i = 0; i < rule.args.length; i++) {\n const childMatch = _ruleMatch(rule.args[i], node.args[i], context)\n if (childMatch.length === 0) {\n // Child did not match, so stop searching immediately\n break\n }\n // The child matched, so add the information returned from the child to our result\n childMatches.push(childMatch)\n }\n if (childMatches.length !== rule.args.length) {\n if (!isCommutative(node, context) || // exact match in order needed\n rule.args.length === 1) { // nothing to commute\n return []\n }\n if (rule.args.length > 2) {\n /* Need to generate all permutations and try them.\n * It's a bit complicated, and unlikely to come up since there\n * are very few ternary or higher operators. So punt for now.\n */\n throw new Error('permuting >2 commutative non-associative rule arguments not yet implemented')\n }\n /* Exactly two arguments, try them reversed */\n const leftMatch = _ruleMatch(rule.args[0], node.args[1], context)\n if (leftMatch.length === 0) {\n return []\n }\n const rightMatch = _ruleMatch(rule.args[1], node.args[0], context)\n if (rightMatch.length === 0) {\n return []\n }\n childMatches = [leftMatch, rightMatch]\n }\n res = mergeChildMatches(childMatches)\n } else if (node.args.length >= 2 && rule.args.length === 2) { // node is flattened, rule is not\n // Associative operators/functions can be split in different ways so we check if the rule\n // matches for each of them and return their union.\n const splits = getSplits(node, context)\n let splitMatches = []\n for (let i = 0; i < splits.length; i++) {\n const matchSet = _ruleMatch(rule, splits[i], context, true) // recursing at the same tree depth here\n splitMatches = splitMatches.concat(matchSet)\n }\n return splitMatches\n } else if (rule.args.length > 2) {\n throw Error('Unexpected non-binary associative function: ' + rule.toString())\n } else {\n // Incorrect number of arguments in rule and node, so no match\n return []\n }\n } else if (rule instanceof SymbolNode) {\n // If the rule is a SymbolNode, then it carries a special meaning\n // according to the first one or two characters of the symbol node name.\n // These meanings are expalined in the documentation for simplify()\n if (rule.name.length === 0) {\n throw new Error('Symbol in rule has 0 length...!?')\n }\n if (SUPPORTED_CONSTANTS[rule.name]) {\n // built-in constant must match exactly\n if (rule.name !== node.name) {\n return []\n }\n } else {\n // wildcards are composed of up to two alphabetic or underscore characters\n switch (rule.name[1] >= 'a' && rule.name[1] <= 'z' ? rule.name.substring(0, 2) : rule.name[0]) {\n case 'n':\n case '_p':\n // rule matches _anything_, so assign this node to the rule.name placeholder\n // Assign node to the rule.name placeholder.\n // Our parent will check for matches among placeholders.\n res[0].placeholders[rule.name] = node\n break\n case 'c':\n case 'cl':\n // rule matches a ConstantNode\n if (isConstantNode(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 'v':\n // rule matches anything other than a ConstantNode\n if (!isConstantNode(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 'vl':\n // rule matches VariableNode\n if (isVariableNode(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 'cd':\n // rule matches a ConstantNode or unaryMinus-wrapped ConstantNode\n if (isNumericNode(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 'vd':\n // rule matches anything other than a ConstantNode or unaryMinus-wrapped ConstantNode\n if (!isNumericNode(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 'ce':\n // rule matches expressions that have a constant value\n if (isConstantExpression(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n case 've':\n // rule matches expressions that do not have a constant value\n if (!isConstantExpression(node)) {\n res[0].placeholders[rule.name] = node\n } else {\n // mis-match: rule does not encompass current node\n return []\n }\n break\n default:\n throw new Error('Invalid symbol in rule: ' + rule.name)\n }\n }\n } else if (rule instanceof ConstantNode) {\n // Literal constant must match exactly\n if (!equal(rule.value, node.value)) {\n return []\n }\n } else {\n // Some other node was encountered which we aren't prepared for, so no match\n return []\n }\n\n // It's a match!\n\n // console.log('_ruleMatch(' + rule.toString() + ', ' + node.toString() + ') found a match')\n return res\n }\n\n /**\n * Determines whether p and q (and all their children nodes) are identical.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} p\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} q\n * @return {Object} Information about the match, if it exists.\n */\n function _exactMatch (p, q) {\n if (p instanceof ConstantNode && q instanceof ConstantNode) {\n if (!equal(p.value, q.value)) {\n return false\n }\n } else if (p instanceof SymbolNode && q instanceof SymbolNode) {\n if (p.name !== q.name) {\n return false\n }\n } else if ((p instanceof OperatorNode && q instanceof OperatorNode) ||\n (p instanceof FunctionNode && q instanceof FunctionNode)) {\n if (p instanceof OperatorNode) {\n if (p.op !== q.op || p.fn !== q.fn) {\n return false\n }\n } else if (p instanceof FunctionNode) {\n if (p.name !== q.name) {\n return false\n }\n }\n\n if (p.args.length !== q.args.length) {\n return false\n }\n\n for (let i = 0; i < p.args.length; i++) {\n if (!_exactMatch(p.args[i], q.args[i])) {\n return false\n }\n }\n } else {\n return false\n }\n\n return true\n }\n\n return simplify\n})\n","import { isFraction, isMatrix, isNode, isArrayNode, isConstantNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { createUtil } from './simplify/util.js'\nimport { noBignumber, noFraction } from '../../utils/noop.js'\n\nconst name = 'simplifyConstant'\nconst dependencies = [\n 'typed',\n 'config',\n 'mathWithTransform',\n 'matrix',\n '?fraction',\n '?bignumber',\n 'AccessorNode',\n 'ArrayNode',\n 'ConstantNode',\n 'FunctionNode',\n 'IndexNode',\n 'ObjectNode',\n 'OperatorNode',\n 'SymbolNode'\n]\n\nexport const createSimplifyConstant = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n config,\n mathWithTransform,\n matrix,\n fraction,\n bignumber,\n AccessorNode,\n ArrayNode,\n ConstantNode,\n FunctionNode,\n IndexNode,\n ObjectNode,\n OperatorNode,\n SymbolNode\n}) => {\n const { isCommutative, isAssociative, allChildren, createMakeNodeFunction } =\n createUtil({ FunctionNode, OperatorNode, SymbolNode })\n\n /**\n * simplifyConstant() takes a mathjs expression (either a Node representing\n * a parse tree or a string which it parses to produce a node), and replaces\n * any subexpression of it consisting entirely of constants with the computed\n * value of that subexpression.\n *\n * Syntax:\n *\n * math.simplifyConstant(expr)\n * math.simplifyConstant(expr, options)\n *\n * Examples:\n *\n * math.simplifyConstant('x + 4*3/6') // Node \"x + 2\"\n * math.simplifyConstant('z cos(0)') // Node \"z 1\"\n * math.simplifyConstant('(5.2 + 1.08)t', {exactFractions: false}) // Node \"6.28 t\"\n *\n * See also:\n *\n * simplify, simplifyCore, resolve, derivative\n *\n * @param {Node | string} node\n * The expression to be simplified\n * @param {Object} options\n * Simplification options, as per simplify()\n * @return {Node} Returns expression with constant subexpressions evaluated\n */\n const simplifyConstant = typed('simplifyConstant', {\n Node: node => _ensureNode(foldFraction(node, {})),\n\n 'Node, Object': function (expr, options) {\n return _ensureNode(foldFraction(expr, options))\n }\n })\n\n function _removeFractions (thing) {\n if (isFraction(thing)) {\n return thing.valueOf()\n }\n if (thing instanceof Array) {\n return thing.map(_removeFractions)\n }\n if (isMatrix(thing)) {\n return matrix(_removeFractions(thing.valueOf()))\n }\n return thing\n }\n\n function _eval (fnname, args, options) {\n try {\n return mathWithTransform[fnname].apply(null, args)\n } catch (ignore) {\n // sometimes the implicit type conversion causes the evaluation to fail, so we'll try again after removing Fractions\n args = args.map(_removeFractions)\n return _toNumber(mathWithTransform[fnname].apply(null, args), options)\n }\n }\n\n const _toNode = typed({\n Fraction: _fractionToNode,\n number: function (n) {\n if (n < 0) {\n return unaryMinusNode(new ConstantNode(-n))\n }\n return new ConstantNode(n)\n },\n BigNumber: function (n) {\n if (n < 0) {\n return unaryMinusNode(new ConstantNode(-n))\n }\n return new ConstantNode(n) // old parameters: (n.toString(), 'number')\n },\n bigint: function (n) {\n if (n < 0n) {\n return unaryMinusNode(new ConstantNode(-n))\n }\n return new ConstantNode(n)\n },\n Complex: function (s) {\n throw new Error('Cannot convert Complex number to Node')\n },\n string: function (s) {\n return new ConstantNode(s)\n },\n Matrix: function (m) {\n return new ArrayNode(m.valueOf().map(e => _toNode(e)))\n }\n })\n\n function _ensureNode (thing) {\n if (isNode(thing)) {\n return thing\n }\n return _toNode(thing)\n }\n\n // convert a number to a fraction only if it can be expressed exactly,\n // and when both numerator and denominator are small enough\n function _exactFraction (n, options) {\n const exactFractions = (options && options.exactFractions !== false)\n if (exactFractions && isFinite(n) && fraction) {\n const f = fraction(n)\n const fractionsLimit = (options && typeof options.fractionsLimit === 'number')\n ? options.fractionsLimit\n : Infinity // no limit by default\n\n if (f.valueOf() === n && f.n < fractionsLimit && f.d < fractionsLimit) {\n return f\n }\n }\n return n\n }\n\n // Convert numbers to a preferred number type in preference order: Fraction, number, Complex\n // BigNumbers are left alone\n const _toNumber = typed({\n 'string, Object': function (s, options) {\n const numericType = safeNumberType(s, config)\n\n if (numericType === 'BigNumber') {\n if (bignumber === undefined) {\n noBignumber()\n }\n return bignumber(s)\n } else if (numericType === 'bigint') {\n return BigInt(s)\n } else if (numericType === 'Fraction') {\n if (fraction === undefined) {\n noFraction()\n }\n return fraction(s)\n } else {\n const n = parseFloat(s)\n return _exactFraction(n, options)\n }\n },\n\n 'Fraction, Object': function (s, options) { return s }, // we don't need options here\n\n 'BigNumber, Object': function (s, options) { return s }, // we don't need options here\n\n 'number, Object': function (s, options) {\n return _exactFraction(s, options)\n },\n\n 'bigint, Object': function (s, options) {\n return s\n },\n\n 'Complex, Object': function (s, options) {\n if (s.im !== 0) {\n return s\n }\n return _exactFraction(s.re, options)\n },\n\n 'Matrix, Object': function (s, options) {\n return matrix(_exactFraction(s.valueOf()))\n },\n\n 'Array, Object': function (s, options) {\n return s.map(_exactFraction)\n }\n })\n\n function unaryMinusNode (n) {\n return new OperatorNode('-', 'unaryMinus', [n])\n }\n\n function _fractionToNode (f) {\n let n\n const vn = f.s * f.n\n if (vn < 0) {\n n = new OperatorNode('-', 'unaryMinus', [new ConstantNode(-vn)])\n } else {\n n = new ConstantNode(vn)\n }\n\n if (f.d === 1) {\n return n\n }\n return new OperatorNode('/', 'divide', [n, new ConstantNode(f.d)])\n }\n\n /* Handles constant indexing of ArrayNodes, matrices, and ObjectNodes */\n function _foldAccessor (obj, index, options) {\n if (!isIndexNode(index)) { // don't know what to do with that...\n return new AccessorNode(_ensureNode(obj), _ensureNode(index))\n }\n if (isArrayNode(obj) || isMatrix(obj)) {\n const remainingDims = Array.from(index.dimensions)\n /* We will resolve constant indices one at a time, looking\n * just in the first or second dimensions because (a) arrays\n * of more than two dimensions are likely rare, and (b) pulling\n * out the third or higher dimension would be pretty intricate.\n * The price is that we miss simplifying [..3d array][x,y,1]\n */\n while (remainingDims.length > 0) {\n if (isConstantNode(remainingDims[0]) &&\n typeof remainingDims[0].value !== 'string') {\n const first = _toNumber(remainingDims.shift().value, options)\n if (isArrayNode(obj)) {\n obj = obj.items[first - 1]\n } else { // matrix\n obj = obj.valueOf()[first - 1]\n if (obj instanceof Array) {\n obj = matrix(obj)\n }\n }\n } else if (remainingDims.length > 1 &&\n isConstantNode(remainingDims[1]) &&\n typeof remainingDims[1].value !== 'string') {\n const second = _toNumber(remainingDims[1].value, options)\n const tryItems = []\n const fromItems = isArrayNode(obj) ? obj.items : obj.valueOf()\n for (const item of fromItems) {\n if (isArrayNode(item)) {\n tryItems.push(item.items[second - 1])\n } else if (isMatrix(obj)) {\n tryItems.push(item[second - 1])\n } else {\n break\n }\n }\n if (tryItems.length === fromItems.length) {\n if (isArrayNode(obj)) {\n obj = new ArrayNode(tryItems)\n } else { // matrix\n obj = matrix(tryItems)\n }\n remainingDims.splice(1, 1)\n } else { // extracting slice along 2nd dimension failed, give up\n break\n }\n } else { // neither 1st or 2nd dimension is constant, give up\n break\n }\n }\n if (remainingDims.length === index.dimensions.length) {\n /* No successful constant indexing */\n return new AccessorNode(_ensureNode(obj), index)\n }\n if (remainingDims.length > 0) {\n /* Indexed some but not all dimensions */\n index = new IndexNode(remainingDims)\n return new AccessorNode(_ensureNode(obj), index)\n }\n /* All dimensions were constant, access completely resolved */\n return obj\n }\n if (isObjectNode(obj) &&\n index.dimensions.length === 1 &&\n isConstantNode(index.dimensions[0])) {\n const key = index.dimensions[0].value\n if (key in obj.properties) {\n return obj.properties[key]\n }\n return new ConstantNode() // undefined\n }\n /* Don't know how to index this sort of obj, at least not with this index */\n return new AccessorNode(_ensureNode(obj), index)\n }\n\n /*\n * Create a binary tree from a list of Fractions and Nodes.\n * Tries to fold Fractions by evaluating them until the first Node in the list is hit, so\n * `args` should be sorted to have the Fractions at the start (if the operator is commutative).\n * @param args - list of Fractions and Nodes\n * @param fn - evaluator for the binary operation evaluator that accepts two Fractions\n * @param makeNode - creates a binary OperatorNode/FunctionNode from a list of child Nodes\n * if args.length is 1, returns args[0]\n * @return - Either a Node representing a binary expression or Fraction\n */\n function foldOp (fn, args, makeNode, options) {\n const first = args.shift()\n\n // In the following reduction, sofar always has one of the three following\n // forms: [NODE], [CONSTANT], or [NODE, CONSTANT]\n const reduction = args.reduce((sofar, next) => {\n if (!isNode(next)) {\n const last = sofar.pop()\n\n if (isNode(last)) {\n return [last, next]\n }\n // Two constants in a row, try to fold them into one\n try {\n sofar.push(_eval(fn, [last, next], options))\n return sofar\n } catch (ignoreandcontinue) {\n sofar.push(last)\n // fall through to Node case\n }\n }\n\n // Encountered a Node, or failed folding --\n // collapse everything so far into a single tree:\n sofar.push(_ensureNode(sofar.pop()))\n const newtree = (sofar.length === 1) ? sofar[0] : makeNode(sofar)\n return [makeNode([newtree, _ensureNode(next)])]\n }, [first])\n\n if (reduction.length === 1) {\n return reduction[0]\n }\n // Might end up with a tree and a constant at the end:\n return makeNode([reduction[0], _toNode(reduction[1])])\n }\n\n // destroys the original node and returns a folded one\n function foldFraction (node, options) {\n switch (node.type) {\n case 'SymbolNode':\n return node\n case 'ConstantNode':\n switch (typeof node.value) {\n case 'number': return _toNumber(node.value, options)\n case 'bigint': return _toNumber(node.value, options)\n case 'string': return node.value\n default:\n if (!isNaN(node.value)) return _toNumber(node.value, options)\n }\n return node\n case 'FunctionNode':\n if (mathWithTransform[node.name] && mathWithTransform[node.name].rawArgs) {\n return node\n }\n {\n // Process operators as OperatorNode\n const operatorFunctions = ['add', 'multiply']\n if (!operatorFunctions.includes(node.name)) {\n const args = node.args.map(arg => foldFraction(arg, options))\n\n // If all args are numbers\n if (!args.some(isNode)) {\n try {\n return _eval(node.name, args, options)\n } catch (ignoreandcontinue) { }\n }\n\n // Size of a matrix does not depend on entries\n if (node.name === 'size' &&\n args.length === 1 &&\n isArrayNode(args[0])) {\n const sz = []\n let section = args[0]\n while (isArrayNode(section)) {\n sz.push(section.items.length)\n section = section.items[0]\n }\n return matrix(sz)\n }\n\n // Convert all args to nodes and construct a symbolic function call\n return new FunctionNode(node.name, args.map(_ensureNode))\n } else {\n // treat as operator\n }\n }\n /* falls through */\n case 'OperatorNode':\n {\n const fn = node.fn.toString()\n let args\n let res\n const makeNode = createMakeNodeFunction(node)\n if (isOperatorNode(node) && node.isUnary()) {\n args = [foldFraction(node.args[0], options)]\n if (!isNode(args[0])) {\n res = _eval(fn, args, options)\n } else {\n res = makeNode(args)\n }\n } else if (isAssociative(node, options.context)) {\n args = allChildren(node, options.context)\n args = args.map(arg => foldFraction(arg, options))\n\n if (isCommutative(fn, options.context)) {\n // commutative binary operator\n const consts = []\n const vars = []\n\n for (let i = 0; i < args.length; i++) {\n if (!isNode(args[i])) {\n consts.push(args[i])\n } else {\n vars.push(args[i])\n }\n }\n\n if (consts.length > 1) {\n res = foldOp(fn, consts, makeNode, options)\n vars.unshift(res)\n res = foldOp(fn, vars, makeNode, options)\n } else {\n // we won't change the children order since it's not neccessary\n res = foldOp(fn, args, makeNode, options)\n }\n } else {\n // non-commutative binary operator\n res = foldOp(fn, args, makeNode, options)\n }\n } else {\n // non-associative binary operator\n args = node.args.map(arg => foldFraction(arg, options))\n res = foldOp(fn, args, makeNode, options)\n }\n return res\n }\n case 'ParenthesisNode':\n // remove the uneccessary parenthesis\n return foldFraction(node.content, options)\n case 'AccessorNode':\n return _foldAccessor(\n foldFraction(node.object, options),\n foldFraction(node.index, options),\n options)\n case 'ArrayNode': {\n const foldItems = node.items.map(item => foldFraction(item, options))\n if (foldItems.some(isNode)) {\n return new ArrayNode(foldItems.map(_ensureNode))\n }\n /* All literals -- return a Matrix so we can operate on it */\n return matrix(foldItems)\n }\n case 'IndexNode': {\n return new IndexNode(\n node.dimensions.map(n => simplifyConstant(n, options)))\n }\n case 'ObjectNode': {\n const foldProps = {}\n for (const prop in node.properties) {\n foldProps[prop] = simplifyConstant(node.properties[prop], options)\n }\n return new ObjectNode(foldProps)\n }\n case 'AssignmentNode':\n /* falls through */\n case 'BlockNode':\n /* falls through */\n case 'FunctionAssignmentNode':\n /* falls through */\n case 'RangeNode':\n /* falls through */\n case 'ConditionalNode':\n /* falls through */\n default:\n throw new Error(`Unimplemented node type in simplifyConstant: ${node.type}`)\n }\n }\n\n return simplifyConstant\n})\n","import { isAccessorNode, isArrayNode, isConstantNode, isFunctionNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'\nimport { getOperator } from '../../expression/operators.js'\nimport { createUtil } from './simplify/util.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'simplifyCore'\nconst dependencies = [\n 'typed',\n 'parse',\n 'equal',\n 'isZero',\n 'add',\n 'subtract',\n 'multiply',\n 'divide',\n 'pow',\n 'AccessorNode',\n 'ArrayNode',\n 'ConstantNode',\n 'FunctionNode',\n 'IndexNode',\n 'ObjectNode',\n 'OperatorNode',\n 'ParenthesisNode',\n 'SymbolNode'\n]\n\nexport const createSimplifyCore = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n parse,\n equal,\n isZero,\n add,\n subtract,\n multiply,\n divide,\n pow,\n AccessorNode,\n ArrayNode,\n ConstantNode,\n FunctionNode,\n IndexNode,\n ObjectNode,\n OperatorNode,\n ParenthesisNode,\n SymbolNode\n}) => {\n const node0 = new ConstantNode(0)\n const node1 = new ConstantNode(1)\n const nodeT = new ConstantNode(true)\n const nodeF = new ConstantNode(false)\n // test if a node will always have a boolean value (true/false)\n // not sure if this list is complete\n function isAlwaysBoolean (node) {\n return isOperatorNode(node) && ['and', 'not', 'or'].includes(node.op)\n }\n\n const { hasProperty, isCommutative } =\n createUtil({ FunctionNode, OperatorNode, SymbolNode })\n /**\n * simplifyCore() performs single pass simplification suitable for\n * applications requiring ultimate performance. To roughly summarize,\n * it handles cases along the lines of simplifyConstant() but where\n * knowledge of a single argument is sufficient to determine the value.\n * In contrast, simplify() extends simplifyCore() with additional passes\n * to provide deeper simplification (such as gathering like terms).\n *\n * Specifically, simplifyCore:\n *\n * * Converts all function calls with operator equivalents to their\n * operator forms.\n * * Removes operators or function calls that are guaranteed to have no\n * effect (such as unary '+').\n * * Removes double unary '-', '~', and 'not'\n * * Eliminates addition/subtraction of 0 and multiplication/division/powers\n * by 1 or 0.\n * * Converts addition of a negation into subtraction.\n * * Eliminates logical operations with constant true or false leading\n * arguments.\n * * Puts constants on the left of a product, if multiplication is\n * considered commutative by the options (which is the default)\n *\n * Syntax:\n *\n * math.simplifyCore(expr)\n * math.simplifyCore(expr, options)\n *\n * Examples:\n *\n * const f = math.parse('2 * 1 * x ^ (1 - 0)')\n * math.simplifyCore(f) // Node \"2 * x\"\n * math.simplify('2 * 1 * x ^ (1 - 0)', [math.simplifyCore]) // Node \"2 * x\"\n *\n * See also:\n *\n * simplify, simplifyConstant, resolve, derivative\n *\n * @param {Node | string} node\n * The expression to be simplified\n * @param {Object} options\n * Simplification options, as per simplify()\n * @return {Node} Returns expression with basic simplifications applied\n */\n function _simplifyCore (nodeToSimplify, options = {}) {\n const context = options ? options.context : undefined\n if (hasProperty(nodeToSimplify, 'trivial', context)) {\n // This node does nothing if it has only one argument, so if so,\n // return that argument simplified\n if (isFunctionNode(nodeToSimplify) && nodeToSimplify.args.length === 1) {\n return _simplifyCore(nodeToSimplify.args[0], options)\n }\n // For other node types, we try the generic methods\n let simpChild = false\n let childCount = 0\n nodeToSimplify.forEach(c => {\n ++childCount\n if (childCount === 1) {\n simpChild = _simplifyCore(c, options)\n }\n })\n if (childCount === 1) {\n return simpChild\n }\n }\n let node = nodeToSimplify\n if (isFunctionNode(node)) {\n const op = getOperator(node.name)\n if (op) {\n // Replace FunctionNode with a new OperatorNode\n if (node.args.length > 2 && hasProperty(node, 'associative', context)) {\n // unflatten into binary operations since that's what simplifyCore handles\n while (node.args.length > 2) {\n const last = node.args.pop()\n const seclast = node.args.pop()\n node.args.push(new OperatorNode(op, node.name, [last, seclast]))\n }\n }\n node = new OperatorNode(op, node.name, node.args)\n } else {\n return new FunctionNode(\n _simplifyCore(node.fn), node.args.map(n => _simplifyCore(n, options)))\n }\n }\n if (isOperatorNode(node) && node.isUnary()) {\n const a0 = _simplifyCore(node.args[0], options)\n\n if (node.op === '~') { // bitwise not\n if (isOperatorNode(a0) && a0.isUnary() && a0.op === '~') {\n return a0.args[0]\n }\n }\n if (node.op === 'not') { // logical not\n if (isOperatorNode(a0) && a0.isUnary() && a0.op === 'not') {\n // Has the effect of turning the argument into a boolean\n // So can only eliminate the double negation if\n // the inside is already boolean\n if (isAlwaysBoolean(a0.args[0])) {\n return a0.args[0]\n }\n }\n }\n let finish = true\n if (node.op === '-') { // unary minus\n if (isOperatorNode(a0)) {\n if (a0.isBinary() && a0.fn === 'subtract') {\n node = new OperatorNode('-', 'subtract', [a0.args[1], a0.args[0]])\n finish = false // continue to process the new binary node\n }\n if (a0.isUnary() && a0.op === '-') {\n return a0.args[0]\n }\n }\n }\n if (finish) return new OperatorNode(node.op, node.fn, [a0])\n }\n if (isOperatorNode(node) && node.isBinary()) {\n const a0 = _simplifyCore(node.args[0], options)\n let a1 = _simplifyCore(node.args[1], options)\n\n if (node.op === '+') {\n if (isConstantNode(a0) && isZero(a0.value)) {\n return a1\n }\n if (isConstantNode(a1) && isZero(a1.value)) {\n return a0\n }\n if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') {\n a1 = a1.args[0]\n node = new OperatorNode('-', 'subtract', [a0, a1])\n }\n }\n if (node.op === '-') {\n if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') {\n return _simplifyCore(\n new OperatorNode('+', 'add', [a0, a1.args[0]]), options)\n }\n if (isConstantNode(a0) && isZero(a0.value)) {\n return _simplifyCore(new OperatorNode('-', 'unaryMinus', [a1]))\n }\n if (isConstantNode(a1) && isZero(a1.value)) {\n return a0\n }\n return new OperatorNode(node.op, node.fn, [a0, a1])\n }\n if (node.op === '*') {\n if (isConstantNode(a0)) {\n if (isZero(a0.value)) {\n return node0\n } else if (equal(a0.value, 1)) {\n return a1\n }\n }\n if (isConstantNode(a1)) {\n if (isZero(a1.value)) {\n return node0\n } else if (equal(a1.value, 1)) {\n return a0\n }\n if (isCommutative(node, context)) {\n return new OperatorNode(node.op, node.fn, [a1, a0], node.implicit) // constants on left\n }\n }\n return new OperatorNode(node.op, node.fn, [a0, a1], node.implicit)\n }\n if (node.op === '/') {\n if (isConstantNode(a0) && isZero(a0.value)) {\n return node0\n }\n if (isConstantNode(a1) && equal(a1.value, 1)) {\n return a0\n }\n return new OperatorNode(node.op, node.fn, [a0, a1])\n }\n if (node.op === '^') {\n if (isConstantNode(a1)) {\n if (isZero(a1.value)) {\n return node1\n } else if (equal(a1.value, 1)) {\n return a0\n }\n }\n }\n if (node.op === 'and') {\n if (isConstantNode(a0)) {\n if (a0.value) {\n if (isAlwaysBoolean(a1)) return a1\n if (isConstantNode(a1)) {\n return a1.value ? nodeT : nodeF\n }\n } else {\n return nodeF\n }\n }\n if (isConstantNode(a1)) {\n if (a1.value) {\n if (isAlwaysBoolean(a0)) return a0\n } else {\n return nodeF\n }\n }\n }\n if (node.op === 'or') {\n if (isConstantNode(a0)) {\n if (a0.value) {\n return nodeT\n } else {\n if (isAlwaysBoolean(a1)) return a1\n }\n }\n if (isConstantNode(a1)) {\n if (a1.value) {\n return nodeT\n } else {\n if (isAlwaysBoolean(a0)) return a0\n }\n }\n }\n return new OperatorNode(node.op, node.fn, [a0, a1])\n }\n if (isOperatorNode(node)) {\n return new OperatorNode(\n node.op, node.fn, node.args.map(a => _simplifyCore(a, options)))\n }\n if (isArrayNode(node)) {\n return new ArrayNode(node.items.map(n => _simplifyCore(n, options)))\n }\n if (isAccessorNode(node)) {\n return new AccessorNode(\n _simplifyCore(node.object, options), _simplifyCore(node.index, options))\n }\n if (isIndexNode(node)) {\n return new IndexNode(\n node.dimensions.map(n => _simplifyCore(n, options)))\n }\n if (isObjectNode(node)) {\n const newProps = {}\n for (const prop in node.properties) {\n newProps[prop] = _simplifyCore(node.properties[prop], options)\n }\n return new ObjectNode(newProps)\n }\n // cannot simplify\n return node\n }\n\n return typed(name, { Node: _simplifyCore, 'Node,Object': _simplifyCore })\n})\n","import { createMap } from '../../utils/map.js'\nimport { isFunctionNode, isNode, isOperatorNode, isParenthesisNode, isSymbolNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'resolve'\nconst dependencies = [\n 'typed',\n 'parse',\n 'ConstantNode',\n 'FunctionNode',\n 'OperatorNode',\n 'ParenthesisNode'\n]\n\nexport const createResolve = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n parse,\n ConstantNode,\n FunctionNode,\n OperatorNode,\n ParenthesisNode\n}) => {\n /**\n * resolve(expr, scope) replaces variable nodes with their scoped values\n *\n * Syntax:\n *\n * math.resolve(expr, scope)\n *\n * Examples:\n *\n * math.resolve('x + y', {x:1, y:2}) // Node '1 + 2'\n * math.resolve(math.parse('x+y'), {x:1, y:2}) // Node '1 + 2'\n * math.simplify('x+y', {x:2, y: math.parse('x+x')}).toString() // \"6\"\n *\n * See also:\n *\n * simplify, evaluate\n *\n * @param {Node | Node[]} node\n * The expression tree (or trees) to be simplified\n * @param {Object} scope\n * Scope specifying variables to be resolved\n * @return {Node | Node[]} Returns `node` with variables recursively substituted.\n * @throws {ReferenceError}\n * If there is a cyclic dependency among the variables in `scope`,\n * resolution is impossible and a ReferenceError is thrown.\n */\n function _resolve (node, scope, within = new Set()) { // note `within`:\n // `within` is not documented, since it is for internal cycle\n // detection only\n if (!scope) {\n return node\n }\n if (isSymbolNode(node)) {\n if (within.has(node.name)) {\n const variables = Array.from(within).join(', ')\n throw new ReferenceError(\n `recursive loop of variable definitions among {${variables}}`\n )\n }\n const value = scope.get(node.name)\n if (isNode(value)) {\n const nextWithin = new Set(within)\n nextWithin.add(node.name)\n return _resolve(value, scope, nextWithin)\n } else if (typeof value === 'number') {\n return parse(String(value))\n } else if (value !== undefined) {\n return new ConstantNode(value)\n } else {\n return node\n }\n } else if (isOperatorNode(node)) {\n const args = node.args.map(function (arg) {\n return _resolve(arg, scope, within)\n })\n return new OperatorNode(node.op, node.fn, args, node.implicit)\n } else if (isParenthesisNode(node)) {\n return new ParenthesisNode(_resolve(node.content, scope, within))\n } else if (isFunctionNode(node)) {\n const args = node.args.map(function (arg) {\n return _resolve(arg, scope, within)\n })\n return new FunctionNode(node.name, args)\n }\n\n // Otherwise just recursively resolve any children (might also work\n // for some of the above special cases)\n return node.map(child => _resolve(child, scope, within))\n }\n\n return typed('resolve', {\n Node: _resolve,\n 'Node, Map | null | undefined': _resolve,\n 'Node, Object': (n, scope) => _resolve(n, createMap(scope)),\n // For arrays and matrices, we map `self` rather than `_resolve`\n // because resolve is fairly expensive anyway, and this way\n // we get nice error messages if one entry in the array has wrong type.\n 'Array | Matrix': typed.referToSelf(self => A => A.map(n => self(n))),\n 'Array | Matrix, null | undefined': typed.referToSelf(\n self => A => A.map(n => self(n))),\n 'Array, Object': typed.referTo(\n 'Array,Map', selfAM => (A, scope) => selfAM(A, createMap(scope))),\n 'Matrix, Object': typed.referTo(\n 'Matrix,Map', selfMM => (A, scope) => selfMM(A, createMap(scope))),\n 'Array | Matrix, Map': typed.referToSelf(\n self => (A, scope) => A.map(n => self(n, scope)))\n })\n})\n","import { isConstantNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'symbolicEqual'\nconst dependencies = [\n 'parse',\n 'simplify',\n 'typed',\n 'OperatorNode'\n]\n\nexport const createSymbolicEqual = /* #__PURE__ */ factory(name, dependencies, ({\n parse,\n simplify,\n typed,\n OperatorNode\n}) => {\n /**\n * Attempts to determine if two expressions are symbolically equal, i.e.\n * one is the result of valid algebraic manipulations on the other.\n * Currently, this simply checks if the difference of the two expressions\n * simplifies down to 0. So there are two important caveats:\n * 1. whether two expressions are symbolically equal depends on the\n * manipulations allowed. Therefore, this function takes an optional\n * third argument, which are the options that control the behavior\n * as documented for the `simplify()` function.\n * 2. it is in general intractable to find the minimal simplification of\n * an arbitrarily complicated expression. So while a `true` value\n * of `symbolicEqual` ensures that the two expressions can be manipulated\n * to match each other, a `false` value does not absolutely rule this out.\n *\n * Syntax:\n *\n * math.symbolicEqual(expr1, expr2)\n * math.symbolicEqual(expr1, expr2, options)\n *\n * Examples:\n *\n * math.symbolicEqual('x*y', 'y*x') // Returns true\n * math.symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}}) // Returns false\n * math.symbolicEqual('x/y', '(y*x^(-1))^(-1)') // Returns true\n * math.symbolicEqual('abs(x)','x') // Returns false\n * math.symbolicEqual('abs(x)','x', simplify.positiveContext) // Returns true\n *\n * See also:\n *\n * simplify, evaluate\n *\n * @param {Node|string} expr1 The first expression to compare\n * @param {Node|string} expr2 The second expression to compare\n * @param {Object} [options] Optional option object, passed to simplify\n * @returns {boolean}\n * Returns true if a valid manipulation making the expressions equal\n * is found.\n */\n function _symbolicEqual (e1, e2, options = {}) {\n const diff = new OperatorNode('-', 'subtract', [e1, e2])\n const simplified = simplify(diff, {}, options)\n return (isConstantNode(simplified) && !(simplified.value))\n }\n\n return typed(name, {\n 'Node, Node': _symbolicEqual,\n 'Node, Node, Object': _symbolicEqual\n })\n})\n","import { isConstantNode, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\n\nconst name = 'derivative'\nconst dependencies = [\n 'typed',\n 'config',\n 'parse',\n 'simplify',\n 'equal',\n 'isZero',\n 'numeric',\n 'ConstantNode',\n 'FunctionNode',\n 'OperatorNode',\n 'ParenthesisNode',\n 'SymbolNode'\n]\n\nexport const createDerivative = /* #__PURE__ */ factory(name, dependencies, ({\n typed,\n config,\n parse,\n simplify,\n equal,\n isZero,\n numeric,\n ConstantNode,\n FunctionNode,\n OperatorNode,\n ParenthesisNode,\n SymbolNode\n}) => {\n /**\n * Takes the derivative of an expression expressed in parser Nodes.\n * The derivative will be taken over the supplied variable in the\n * second parameter. If there are multiple variables in the expression,\n * it will return a partial derivative.\n *\n * This uses rules of differentiation which can be found here:\n *\n * - [Differentiation rules (Wikipedia)](https://en.wikipedia.org/wiki/Differentiation_rules)\n *\n * Syntax:\n *\n * math.derivative(expr, variable)\n * math.derivative(expr, variable, options)\n *\n * Examples:\n *\n * math.derivative('x^2', 'x') // Node '2 * x'\n * math.derivative('x^2', 'x', {simplify: false}) // Node '2 * 1 * x ^ (2 - 1)'\n * math.derivative('sin(2x)', 'x')) // Node '2 * cos(2 * x)'\n * math.derivative('2*x', 'x').evaluate() // number 2\n * math.derivative('x^2', 'x').evaluate({x: 4}) // number 8\n * const f = math.parse('x^2')\n * const x = math.parse('x')\n * math.derivative(f, x) // Node {2 * x}\n *\n * See also:\n *\n * simplify, parse, evaluate\n *\n * @param {Node | string} expr The expression to differentiate\n * @param {SymbolNode | string} variable The variable over which to differentiate\n * @param {{simplify: boolean}} [options]\n * There is one option available, `simplify`, which\n * is true by default. When false, output will not\n * be simplified.\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr`\n */\n function plainDerivative (expr, variable, options = { simplify: true }) {\n const constNodes = {}\n constTag(constNodes, expr, variable.name)\n const res = _derivative(expr, constNodes)\n return options.simplify ? simplify(res) : res\n }\n\n function parseIdentifier (string) {\n const symbol = parse(string)\n if (!symbol.isSymbolNode) {\n throw new TypeError('Invalid variable. ' +\n `Cannot parse ${JSON.stringify(string)} into a variable in function derivative`)\n }\n return symbol\n }\n\n const derivative = typed(name, {\n 'Node, SymbolNode': plainDerivative,\n 'Node, SymbolNode, Object': plainDerivative,\n 'Node, string': (node, symbol) => plainDerivative(node, parseIdentifier(symbol)),\n 'Node, string, Object': (node, symbol, options) => plainDerivative(node, parseIdentifier(symbol), options)\n\n /* TODO: implement and test syntax with order of derivatives -> implement as an option {order: number}\n 'Node, SymbolNode, ConstantNode': function (expr, variable, {order}) {\n let res = expr\n for (let i = 0; i < order; i++) {\n let constNodes = {}\n constTag(constNodes, expr, variable.name)\n res = _derivative(res, constNodes)\n }\n return res\n }\n */\n })\n\n derivative._simplify = true\n\n derivative.toTex = function (deriv) {\n return _derivTex.apply(null, deriv.args)\n }\n\n // FIXME: move the toTex method of derivative to latex.js. Difficulty is that it relies on parse.\n // NOTE: the optional \"order\" parameter here is currently unused\n const _derivTex = typed('_derivTex', {\n 'Node, SymbolNode': function (expr, x) {\n if (isConstantNode(expr) && typeOf(expr.value) === 'string') {\n return _derivTex(parse(expr.value).toString(), x.toString(), 1)\n } else {\n return _derivTex(expr.toTex(), x.toString(), 1)\n }\n },\n 'Node, ConstantNode': function (expr, x) {\n if (typeOf(x.value) === 'string') {\n return _derivTex(expr, parse(x.value))\n } else {\n throw new Error(\"The second parameter to 'derivative' is a non-string constant\")\n }\n },\n 'Node, SymbolNode, ConstantNode': function (expr, x, order) {\n return _derivTex(expr.toString(), x.name, order.value)\n },\n 'string, string, number': function (expr, x, order) {\n let d\n if (order === 1) {\n d = '{d\\\\over d' + x + '}'\n } else {\n d = '{d^{' + order + '}\\\\over d' + x + '^{' + order + '}}'\n }\n return d + `\\\\left[${expr}\\\\right]`\n }\n })\n\n /**\n * Does a depth-first search on the expression tree to identify what Nodes\n * are constants (e.g. 2 + 2), and stores the ones that are constants in\n * constNodes. Classification is done as follows:\n *\n * 1. ConstantNodes are constants.\n * 2. If there exists a SymbolNode, of which we are differentiating over,\n * in the subtree it is not constant.\n *\n * @param {Object} constNodes Holds the nodes that are constant\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {string} varName Variable that we are differentiating\n * @return {boolean} if node is constant\n */\n // TODO: can we rewrite constTag into a pure function?\n const constTag = typed('constTag', {\n 'Object, ConstantNode, string': function (constNodes, node) {\n constNodes[node] = true\n return true\n },\n\n 'Object, SymbolNode, string': function (constNodes, node, varName) {\n // Treat other variables like constants. For reasoning, see:\n // https://en.wikipedia.org/wiki/Partial_derivative\n if (node.name !== varName) {\n constNodes[node] = true\n return true\n }\n return false\n },\n\n 'Object, ParenthesisNode, string': function (constNodes, node, varName) {\n return constTag(constNodes, node.content, varName)\n },\n\n 'Object, FunctionAssignmentNode, string': function (constNodes, node, varName) {\n if (!node.params.includes(varName)) {\n constNodes[node] = true\n return true\n }\n return constTag(constNodes, node.expr, varName)\n },\n\n 'Object, FunctionNode | OperatorNode, string': function (constNodes, node, varName) {\n if (node.args.length > 0) {\n let isConst = constTag(constNodes, node.args[0], varName)\n for (let i = 1; i < node.args.length; ++i) {\n isConst = constTag(constNodes, node.args[i], varName) && isConst\n }\n\n if (isConst) {\n constNodes[node] = true\n return true\n }\n }\n return false\n }\n })\n\n /**\n * Applies differentiation rules.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object} constNodes Holds the nodes that are constant\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr`\n */\n const _derivative = typed('_derivative', {\n 'ConstantNode, Object': function (node) {\n return createConstantNode(0)\n },\n\n 'SymbolNode, Object': function (node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0)\n }\n return createConstantNode(1)\n },\n\n 'ParenthesisNode, Object': function (node, constNodes) {\n return new ParenthesisNode(_derivative(node.content, constNodes))\n },\n\n 'FunctionAssignmentNode, Object': function (node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0)\n }\n return _derivative(node.expr, constNodes)\n },\n\n 'FunctionNode, Object': function (node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0)\n }\n\n const arg0 = node.args[0]\n let arg1\n\n let div = false // is output a fraction?\n let negative = false // is output negative?\n\n let funcDerivative\n switch (node.name) {\n case 'cbrt':\n // d/dx(cbrt(x)) = 1 / (3x^(2/3))\n div = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n createConstantNode(3),\n new OperatorNode('^', 'pow', [\n arg0,\n new OperatorNode('/', 'divide', [\n createConstantNode(2),\n createConstantNode(3)\n ])\n ])\n ])\n break\n case 'sqrt':\n case 'nthRoot':\n // d/dx(sqrt(x)) = 1 / (2*sqrt(x))\n if (node.args.length === 1) {\n div = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n createConstantNode(2),\n new FunctionNode('sqrt', [arg0])\n ])\n } else if (node.args.length === 2) {\n // Rearrange from nthRoot(x, a) -> x^(1/a)\n arg1 = new OperatorNode('/', 'divide', [\n createConstantNode(1),\n node.args[1]\n ])\n\n // Is a variable?\n constNodes[arg1] = constNodes[node.args[1]]\n\n return _derivative(new OperatorNode('^', 'pow', [arg0, arg1]), constNodes)\n }\n break\n case 'log10':\n arg1 = createConstantNode(10)\n /* fall through! */\n case 'log':\n if (!arg1 && node.args.length === 1) {\n // d/dx(log(x)) = 1 / x\n funcDerivative = arg0.clone()\n div = true\n } else if ((node.args.length === 1 && arg1) ||\n (node.args.length === 2 && constNodes[node.args[1]] !== undefined)) {\n // d/dx(log(x, c)) = 1 / (x*ln(c))\n funcDerivative = new OperatorNode('*', 'multiply', [\n arg0.clone(),\n new FunctionNode('log', [arg1 || node.args[1]])\n ])\n div = true\n } else if (node.args.length === 2) {\n // d/dx(log(f(x), g(x))) = d/dx(log(f(x)) / log(g(x)))\n return _derivative(new OperatorNode('/', 'divide', [\n new FunctionNode('log', [arg0]),\n new FunctionNode('log', [node.args[1]])\n ]), constNodes)\n }\n break\n case 'pow':\n if (node.args.length === 2) {\n constNodes[arg1] = constNodes[node.args[1]]\n // Pass to pow operator node parser\n return _derivative(new OperatorNode('^', 'pow', [arg0, node.args[1]]), constNodes)\n }\n break\n case 'exp':\n // d/dx(e^x) = e^x\n funcDerivative = new FunctionNode('exp', [arg0.clone()])\n break\n case 'sin':\n // d/dx(sin(x)) = cos(x)\n funcDerivative = new FunctionNode('cos', [arg0.clone()])\n break\n case 'cos':\n // d/dx(cos(x)) = -sin(x)\n funcDerivative = new OperatorNode('-', 'unaryMinus', [\n new FunctionNode('sin', [arg0.clone()])\n ])\n break\n case 'tan':\n // d/dx(tan(x)) = sec(x)^2\n funcDerivative = new OperatorNode('^', 'pow', [\n new FunctionNode('sec', [arg0.clone()]),\n createConstantNode(2)\n ])\n break\n case 'sec':\n // d/dx(sec(x)) = sec(x)tan(x)\n funcDerivative = new OperatorNode('*', 'multiply', [\n node,\n new FunctionNode('tan', [arg0.clone()])\n ])\n break\n case 'csc':\n // d/dx(csc(x)) = -csc(x)cot(x)\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n node,\n new FunctionNode('cot', [arg0.clone()])\n ])\n break\n case 'cot':\n // d/dx(cot(x)) = -csc(x)^2\n negative = true\n funcDerivative = new OperatorNode('^', 'pow', [\n new FunctionNode('csc', [arg0.clone()]),\n createConstantNode(2)\n ])\n break\n case 'asin':\n // d/dx(asin(x)) = 1 / sqrt(1 - x^2)\n div = true\n funcDerivative = new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n createConstantNode(1),\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ])\n ])\n ])\n break\n case 'acos':\n // d/dx(acos(x)) = -1 / sqrt(1 - x^2)\n div = true\n negative = true\n funcDerivative = new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n createConstantNode(1),\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ])\n ])\n ])\n break\n case 'atan':\n // d/dx(atan(x)) = 1 / (x^2 + 1)\n div = true\n funcDerivative = new OperatorNode('+', 'add', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n break\n case 'asec':\n // d/dx(asec(x)) = 1 / (|x|*sqrt(x^2 - 1))\n div = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n new FunctionNode('abs', [arg0.clone()]),\n new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n ])\n ])\n break\n case 'acsc':\n // d/dx(acsc(x)) = -1 / (|x|*sqrt(x^2 - 1))\n div = true\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n new FunctionNode('abs', [arg0.clone()]),\n new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n ])\n ])\n break\n case 'acot':\n // d/dx(acot(x)) = -1 / (x^2 + 1)\n div = true\n negative = true\n funcDerivative = new OperatorNode('+', 'add', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n break\n case 'sinh':\n // d/dx(sinh(x)) = cosh(x)\n funcDerivative = new FunctionNode('cosh', [arg0.clone()])\n break\n case 'cosh':\n // d/dx(cosh(x)) = sinh(x)\n funcDerivative = new FunctionNode('sinh', [arg0.clone()])\n break\n case 'tanh':\n // d/dx(tanh(x)) = sech(x)^2\n funcDerivative = new OperatorNode('^', 'pow', [\n new FunctionNode('sech', [arg0.clone()]),\n createConstantNode(2)\n ])\n break\n case 'sech':\n // d/dx(sech(x)) = -sech(x)tanh(x)\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n node,\n new FunctionNode('tanh', [arg0.clone()])\n ])\n break\n case 'csch':\n // d/dx(csch(x)) = -csch(x)coth(x)\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n node,\n new FunctionNode('coth', [arg0.clone()])\n ])\n break\n case 'coth':\n // d/dx(coth(x)) = -csch(x)^2\n negative = true\n funcDerivative = new OperatorNode('^', 'pow', [\n new FunctionNode('csch', [arg0.clone()]),\n createConstantNode(2)\n ])\n break\n case 'asinh':\n // d/dx(asinh(x)) = 1 / sqrt(x^2 + 1)\n div = true\n funcDerivative = new FunctionNode('sqrt', [\n new OperatorNode('+', 'add', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n ])\n break\n case 'acosh':\n // d/dx(acosh(x)) = 1 / sqrt(x^2 - 1); XXX potentially only for x >= 1 (the real spectrum)\n div = true\n funcDerivative = new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n ])\n break\n case 'atanh':\n // d/dx(atanh(x)) = 1 / (1 - x^2)\n div = true\n funcDerivative = new OperatorNode('-', 'subtract', [\n createConstantNode(1),\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ])\n ])\n break\n case 'asech':\n // d/dx(asech(x)) = -1 / (x*sqrt(1 - x^2))\n div = true\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n arg0.clone(),\n new FunctionNode('sqrt', [\n new OperatorNode('-', 'subtract', [\n createConstantNode(1),\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ])\n ])\n ])\n ])\n break\n case 'acsch':\n // d/dx(acsch(x)) = -1 / (|x|*sqrt(x^2 + 1))\n div = true\n negative = true\n funcDerivative = new OperatorNode('*', 'multiply', [\n new FunctionNode('abs', [arg0.clone()]),\n new FunctionNode('sqrt', [\n new OperatorNode('+', 'add', [\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ]),\n createConstantNode(1)\n ])\n ])\n ])\n break\n case 'acoth':\n // d/dx(acoth(x)) = -1 / (1 - x^2)\n div = true\n negative = true\n funcDerivative = new OperatorNode('-', 'subtract', [\n createConstantNode(1),\n new OperatorNode('^', 'pow', [\n arg0.clone(),\n createConstantNode(2)\n ])\n ])\n break\n case 'abs':\n // d/dx(abs(x)) = abs(x)/x\n funcDerivative = new OperatorNode('/', 'divide', [\n new FunctionNode(new SymbolNode('abs'), [arg0.clone()]),\n arg0.clone()\n ])\n break\n case 'gamma': // Needs digamma function, d/dx(gamma(x)) = gamma(x)digamma(x)\n default:\n throw new Error('Cannot process function \"' + node.name + '\" in derivative: ' +\n 'the function is not supported, undefined, or the number of arguments passed to it are not supported')\n }\n\n let op, func\n if (div) {\n op = '/'\n func = 'divide'\n } else {\n op = '*'\n func = 'multiply'\n }\n\n /* Apply chain rule to all functions:\n F(x) = f(g(x))\n F'(x) = g'(x)*f'(g(x)) */\n let chainDerivative = _derivative(arg0, constNodes)\n if (negative) {\n chainDerivative = new OperatorNode('-', 'unaryMinus', [chainDerivative])\n }\n return new OperatorNode(op, func, [chainDerivative, funcDerivative])\n },\n\n 'OperatorNode, Object': function (node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0)\n }\n\n if (node.op === '+') {\n // d/dx(sum(f(x)) = sum(f'(x))\n return new OperatorNode(node.op, node.fn, node.args.map(function (arg) {\n return _derivative(arg, constNodes)\n }))\n }\n\n if (node.op === '-') {\n // d/dx(+/-f(x)) = +/-f'(x)\n if (node.isUnary()) {\n return new OperatorNode(node.op, node.fn, [\n _derivative(node.args[0], constNodes)\n ])\n }\n\n // Linearity of differentiation, d/dx(f(x) +/- g(x)) = f'(x) +/- g'(x)\n if (node.isBinary()) {\n return new OperatorNode(node.op, node.fn, [\n _derivative(node.args[0], constNodes),\n _derivative(node.args[1], constNodes)\n ])\n }\n }\n\n if (node.op === '*') {\n // d/dx(c*f(x)) = c*f'(x)\n const constantTerms = node.args.filter(function (arg) {\n return constNodes[arg] !== undefined\n })\n\n if (constantTerms.length > 0) {\n const nonConstantTerms = node.args.filter(function (arg) {\n return constNodes[arg] === undefined\n })\n\n const nonConstantNode = nonConstantTerms.length === 1\n ? nonConstantTerms[0]\n : new OperatorNode('*', 'multiply', nonConstantTerms)\n\n const newArgs = constantTerms.concat(_derivative(nonConstantNode, constNodes))\n\n return new OperatorNode('*', 'multiply', newArgs)\n }\n\n // Product Rule, d/dx(f(x)*g(x)) = f'(x)*g(x) + f(x)*g'(x)\n return new OperatorNode('+', 'add', node.args.map(function (argOuter) {\n return new OperatorNode('*', 'multiply', node.args.map(function (argInner) {\n return (argInner === argOuter)\n ? _derivative(argInner, constNodes)\n : argInner.clone()\n }))\n }))\n }\n\n if (node.op === '/' && node.isBinary()) {\n const arg0 = node.args[0]\n const arg1 = node.args[1]\n\n // d/dx(f(x) / c) = f'(x) / c\n if (constNodes[arg1] !== undefined) {\n return new OperatorNode('/', 'divide', [_derivative(arg0, constNodes), arg1])\n }\n\n // Reciprocal Rule, d/dx(c / f(x)) = -c(f'(x)/f(x)^2)\n if (constNodes[arg0] !== undefined) {\n return new OperatorNode('*', 'multiply', [\n new OperatorNode('-', 'unaryMinus', [arg0]),\n new OperatorNode('/', 'divide', [\n _derivative(arg1, constNodes),\n new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])\n ])\n ])\n }\n\n // Quotient rule, d/dx(f(x) / g(x)) = (f'(x)g(x) - f(x)g'(x)) / g(x)^2\n return new OperatorNode('/', 'divide', [\n new OperatorNode('-', 'subtract', [\n new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), arg1.clone()]),\n new OperatorNode('*', 'multiply', [arg0.clone(), _derivative(arg1, constNodes)])\n ]),\n new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])\n ])\n }\n\n if (node.op === '^' && node.isBinary()) {\n const arg0 = node.args[0]\n const arg1 = node.args[1]\n\n if (constNodes[arg0] !== undefined) {\n // If is secretly constant; 0^f(x) = 1 (in JS), 1^f(x) = 1\n if (isConstantNode(arg0) && (isZero(arg0.value) || equal(arg0.value, 1))) {\n return createConstantNode(0)\n }\n\n // d/dx(c^f(x)) = c^f(x)*ln(c)*f'(x)\n return new OperatorNode('*', 'multiply', [\n node,\n new OperatorNode('*', 'multiply', [\n new FunctionNode('log', [arg0.clone()]),\n _derivative(arg1.clone(), constNodes)\n ])\n ])\n }\n\n if (constNodes[arg1] !== undefined) {\n if (isConstantNode(arg1)) {\n // If is secretly constant; f(x)^0 = 1 -> d/dx(1) = 0\n if (isZero(arg1.value)) {\n return createConstantNode(0)\n }\n // Ignore exponent; f(x)^1 = f(x)\n if (equal(arg1.value, 1)) {\n return _derivative(arg0, constNodes)\n }\n }\n\n // Elementary Power Rule, d/dx(f(x)^c) = c*f'(x)*f(x)^(c-1)\n const powMinusOne = new OperatorNode('^', 'pow', [\n arg0.clone(),\n new OperatorNode('-', 'subtract', [\n arg1,\n createConstantNode(1)\n ])\n ])\n\n return new OperatorNode('*', 'multiply', [\n arg1.clone(),\n new OperatorNode('*', 'multiply', [\n _derivative(arg0, constNodes),\n powMinusOne\n ])\n ])\n }\n\n // Functional Power Rule, d/dx(f^g) = f^g*[f'*(g/f) + g'ln(f)]\n return new OperatorNode('*', 'multiply', [\n new OperatorNode('^', 'pow', [arg0.clone(), arg1.clone()]),\n new OperatorNode('+', 'add', [\n new OperatorNode('*', 'multiply', [\n _derivative(arg0, constNodes),\n new OperatorNode('/', 'divide', [arg1.clone(), arg0.clone()])\n ]),\n new OperatorNode('*', 'multiply', [\n _derivative(arg1, constNodes),\n new FunctionNode('log', [arg0.clone()])\n ])\n ])\n ])\n }\n\n throw new Error('Cannot process operator \"' + node.op + '\" in derivative: ' +\n 'the operator is not supported, undefined, or the number of arguments passed to it are not supported')\n }\n })\n\n /**\n * Helper function to create a constant node with a specific type\n * (number, BigNumber, Fraction)\n * @param {number} value\n * @param {string} [valueType]\n * @return {ConstantNode}\n */\n function createConstantNode (value, valueType) {\n return new ConstantNode(numeric(value, valueType || safeNumberType(String(value), config)))\n }\n\n return derivative\n})\n","import { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'rationalize'\nconst dependencies = [\n 'config',\n 'typed',\n 'equal',\n 'isZero',\n 'add',\n 'subtract',\n 'multiply',\n 'divide',\n 'pow',\n 'parse',\n 'simplifyConstant',\n 'simplifyCore',\n 'simplify',\n '?bignumber',\n '?fraction',\n 'mathWithTransform',\n 'matrix',\n 'AccessorNode',\n 'ArrayNode',\n 'ConstantNode',\n 'FunctionNode',\n 'IndexNode',\n 'ObjectNode',\n 'OperatorNode',\n 'SymbolNode',\n 'ParenthesisNode'\n]\n\nexport const createRationalize = /* #__PURE__ */ factory(name, dependencies, ({\n config,\n typed,\n equal,\n isZero,\n add,\n subtract,\n multiply,\n divide,\n pow,\n parse,\n simplifyConstant,\n simplifyCore,\n simplify,\n fraction,\n bignumber,\n mathWithTransform,\n matrix,\n AccessorNode,\n ArrayNode,\n ConstantNode,\n FunctionNode,\n IndexNode,\n ObjectNode,\n OperatorNode,\n SymbolNode,\n ParenthesisNode\n}) => {\n /**\n * Transform a rationalizable expression in a rational fraction.\n * If rational fraction is one variable polynomial then converts\n * the numerator and denominator in canonical form, with decreasing\n * exponents, returning the coefficients of numerator.\n *\n * Syntax:\n *\n * math.rationalize(expr)\n * math.rationalize(expr, detailed)\n * math.rationalize(expr, scope)\n * math.rationalize(expr, scope, detailed)\n *\n * Examples:\n *\n * math.rationalize('sin(x)+y')\n * // Error: There is an unsolved function call\n * math.rationalize('2x/y - y/(x+1)')\n * // (2*x^2-y^2+2*x)/(x*y+y)\n * math.rationalize('(2x+1)^6')\n * // 64*x^6+192*x^5+240*x^4+160*x^3+60*x^2+12*x+1\n * math.rationalize('2x/( (2x-1) / (3x+2) ) - 5x/ ( (3x+4) / (2x^2-5) ) + 3')\n * // -20*x^4+28*x^3+104*x^2+6*x-12)/(6*x^2+5*x-4)\n * math.rationalize('x/(1-x)/(x-2)/(x-3)/(x-4) + 2x/ ( (1-2x)/(2-3x) )/ ((3-4x)/(4-5x) )') =\n * // (-30*x^7+344*x^6-1506*x^5+3200*x^4-3472*x^3+1846*x^2-381*x)/\n * // (-8*x^6+90*x^5-383*x^4+780*x^3-797*x^2+390*x-72)\n *\n * math.rationalize('x+x+x+y',{y:1}) // 3*x+1\n * math.rationalize('x+x+x+y',{}) // 3*x+y\n *\n * const ret = math.rationalize('x+x+x+y',{},true)\n * // ret.expression=3*x+y, ret.variables = [\"x\",\"y\"]\n * const ret = math.rationalize('-2+5x^2',{},true)\n * // ret.expression=5*x^2-2, ret.variables = [\"x\"], ret.coefficients=[-2,0,5]\n *\n * See also:\n *\n * simplify\n *\n * @param {Node|string} expr The expression to check if is a polynomial expression\n * @param {Object|boolean} optional scope of expression or true for already evaluated rational expression at input\n * @param {Boolean} detailed optional True if return an object, false if return expression node (default)\n *\n * @return {Object | Node} The rational polynomial of `expr` or an object\n * `{expression, numerator, denominator, variables, coefficients}`, where\n * `expression` is a `Node` with the node simplified expression,\n * `numerator` is a `Node` with the simplified numerator of expression,\n * `denominator` is a `Node` or `boolean` with the simplified denominator or `false` (if there is no denominator),\n * `variables` is an array with variable names,\n * and `coefficients` is an array with coefficients of numerator sorted by increased exponent\n * {Expression Node} node simplified expression\n *\n */\n function _rationalize (expr, scope = {}, detailed = false) {\n const setRules = rulesRationalize() // Rules for change polynomial in near canonical form\n const polyRet = polynomial(expr, scope, true, setRules.firstRules) // Check if expression is a rationalizable polynomial\n const nVars = polyRet.variables.length\n const noExactFractions = { exactFractions: false }\n const withExactFractions = { exactFractions: true }\n expr = polyRet.expression\n\n if (nVars >= 1) { // If expression in not a constant\n expr = expandPower(expr) // First expand power of polynomials (cannot be made from rules!)\n let sBefore // Previous expression\n let rules\n let eDistrDiv = true\n let redoInic = false\n // Apply the initial rules, including succ div rules:\n expr = simplify(expr, setRules.firstRules, {}, noExactFractions)\n let s\n while (true) {\n // Alternate applying successive division rules and distr.div.rules\n // until there are no more changes:\n rules = eDistrDiv ? setRules.distrDivRules : setRules.sucDivRules\n expr = simplify(expr, rules, {}, withExactFractions)\n eDistrDiv = !eDistrDiv // Swap between Distr.Div and Succ. Div. Rules\n\n s = expr.toString()\n if (s === sBefore) {\n break // No changes : end of the loop\n }\n\n redoInic = true\n sBefore = s\n }\n\n if (redoInic) { // Apply first rules again without succ div rules (if there are changes)\n expr = simplify(expr, setRules.firstRulesAgain, {}, noExactFractions)\n }\n // Apply final rules:\n expr = simplify(expr, setRules.finalRules, {}, noExactFractions)\n } // NVars >= 1\n\n const coefficients = []\n const retRationalize = {}\n\n if (expr.type === 'OperatorNode' && expr.isBinary() && expr.op === '/') { // Separate numerator from denominator\n if (nVars === 1) {\n expr.args[0] = polyToCanonical(expr.args[0], coefficients)\n expr.args[1] = polyToCanonical(expr.args[1])\n }\n if (detailed) {\n retRationalize.numerator = expr.args[0]\n retRationalize.denominator = expr.args[1]\n }\n } else {\n if (nVars === 1) {\n expr = polyToCanonical(expr, coefficients)\n }\n if (detailed) {\n retRationalize.numerator = expr\n retRationalize.denominator = null\n }\n }\n // nVars\n\n if (!detailed) return expr\n retRationalize.coefficients = coefficients\n retRationalize.variables = polyRet.variables\n retRationalize.expression = expr\n return retRationalize\n }\n\n return typed(name, {\n Node: _rationalize,\n 'Node, boolean': (expr, detailed) => _rationalize(expr, {}, detailed),\n 'Node, Object': _rationalize,\n 'Node, Object, boolean': _rationalize\n }) // end of typed rationalize\n\n /**\n * Function to simplify an expression using an optional scope and\n * return it if the expression is a polynomial expression, i.e.\n * an expression with one or more variables and the operators\n * +, -, *, and ^, where the exponent can only be a positive integer.\n *\n * Syntax:\n *\n * polynomial(expr,scope,extended, rules)\n *\n * @param {Node | string} expr The expression to simplify and check if is polynomial expression\n * @param {object} scope Optional scope for expression simplification\n * @param {boolean} extended Optional. Default is false. When true allows divide operator.\n * @param {array} rules Optional. Default is no rule.\n *\n *\n * @return {Object}\n * {Object} node: node simplified expression\n * {Array} variables: variable names\n */\n function polynomial (expr, scope, extended, rules) {\n const variables = []\n const node = simplify(expr, rules, scope, { exactFractions: false }) // Resolves any variables and functions with all defined parameters\n extended = !!extended\n\n const oper = '+-*' + (extended ? '/' : '')\n recPoly(node)\n const retFunc = {}\n retFunc.expression = node\n retFunc.variables = variables\n return retFunc\n\n // -------------------------------------------------------------------------------------------------------\n\n /**\n * Function to simplify an expression using an optional scope and\n * return it if the expression is a polynomial expression, i.e.\n * an expression with one or more variables and the operators\n * +, -, *, and ^, where the exponent can only be a positive integer.\n *\n * Syntax:\n *\n * recPoly(node)\n *\n *\n * @param {Node} node The current sub tree expression in recursion\n *\n * @return nothing, throw an exception if error\n */\n function recPoly (node) {\n const tp = node.type // node type\n if (tp === 'FunctionNode') {\n // No function call in polynomial expression\n throw new Error('There is an unsolved function call')\n } else if (tp === 'OperatorNode') {\n if (node.op === '^') {\n // TODO: handle negative exponents like in '1/x^(-2)'\n if (node.args[1].type !== 'ConstantNode' || !isInteger(parseFloat(node.args[1].value))) {\n throw new Error('There is a non-integer exponent')\n } else {\n recPoly(node.args[0])\n }\n } else {\n if (!oper.includes(node.op)) {\n throw new Error('Operator ' + node.op + ' invalid in polynomial expression')\n }\n for (let i = 0; i < node.args.length; i++) {\n recPoly(node.args[i])\n }\n } // type of operator\n } else if (tp === 'SymbolNode') {\n const name = node.name // variable name\n const pos = variables.indexOf(name)\n if (pos === -1) {\n // new variable in expression\n variables.push(name)\n }\n } else if (tp === 'ParenthesisNode') {\n recPoly(node.content)\n } else if (tp !== 'ConstantNode') {\n throw new Error('type ' + tp + ' is not allowed in polynomial expression')\n }\n } // end of recPoly\n } // end of polynomial\n\n // ---------------------------------------------------------------------------------------\n /**\n * Return a rule set to rationalize an polynomial expression in rationalize\n *\n * Syntax:\n *\n * rulesRationalize()\n *\n * @return {array} rule set to rationalize an polynomial expression\n */\n function rulesRationalize () {\n const oldRules = [simplifyCore, // sCore\n { l: 'n+n', r: '2*n' },\n { l: 'n+-n', r: '0' },\n simplifyConstant, // sConstant\n { l: 'n*(n1^-1)', r: 'n/n1' },\n { l: 'n*n1^-n2', r: 'n/n1^n2' },\n { l: 'n1^-1', r: '1/n1' },\n { l: 'n*(n1/n2)', r: '(n*n1)/n2' },\n { l: '1*n', r: 'n' }]\n\n const rulesFirst = [\n { l: '(-n1)/(-n2)', r: 'n1/n2' }, // Unary division\n { l: '(-n1)*(-n2)', r: 'n1*n2' }, // Unary multiplication\n { l: 'n1--n2', r: 'n1+n2' }, // '--' elimination\n { l: 'n1-n2', r: 'n1+(-n2)' }, // Subtraction turn into add with un�ry minus\n { l: '(n1+n2)*n3', r: '(n1*n3 + n2*n3)' }, // Distributive 1\n { l: 'n1*(n2+n3)', r: '(n1*n2+n1*n3)' }, // Distributive 2\n { l: 'c1*n + c2*n', r: '(c1+c2)*n' }, // Joining constants\n { l: 'c1*n + n', r: '(c1+1)*n' }, // Joining constants\n { l: 'c1*n - c2*n', r: '(c1-c2)*n' }, // Joining constants\n { l: 'c1*n - n', r: '(c1-1)*n' }, // Joining constants\n { l: 'v/c', r: '(1/c)*v' }, // variable/constant (new!)\n { l: 'v/-c', r: '-(1/c)*v' }, // variable/constant (new!)\n { l: '-v*-c', r: 'c*v' }, // Inversion constant and variable 1\n { l: '-v*c', r: '-c*v' }, // Inversion constant and variable 2\n { l: 'v*-c', r: '-c*v' }, // Inversion constant and variable 3\n { l: 'v*c', r: 'c*v' }, // Inversion constant and variable 4\n { l: '-(-n1*n2)', r: '(n1*n2)' }, // Unary propagation\n { l: '-(n1*n2)', r: '(-n1*n2)' }, // Unary propagation\n { l: '-(-n1+n2)', r: '(n1-n2)' }, // Unary propagation\n { l: '-(n1+n2)', r: '(-n1-n2)' }, // Unary propagation\n { l: '(n1^n2)^n3', r: '(n1^(n2*n3))' }, // Power to Power\n { l: '-(-n1/n2)', r: '(n1/n2)' }, // Division and Unary\n { l: '-(n1/n2)', r: '(-n1/n2)' }] // Divisao and Unary\n\n const rulesDistrDiv = [\n { l: '(n1/n2 + n3/n4)', r: '((n1*n4 + n3*n2)/(n2*n4))' }, // Sum of fractions\n { l: '(n1/n2 + n3)', r: '((n1 + n3*n2)/n2)' }, // Sum fraction with number 1\n { l: '(n1 + n2/n3)', r: '((n1*n3 + n2)/n3)' }] // Sum fraction with number 1\n\n const rulesSucDiv = [\n { l: '(n1/(n2/n3))', r: '((n1*n3)/n2)' }, // Division simplification\n { l: '(n1/n2/n3)', r: '(n1/(n2*n3))' }]\n\n const setRules = {} // rules set in 4 steps.\n\n // All rules => infinite loop\n // setRules.allRules =oldRules.concat(rulesFirst,rulesDistrDiv,rulesSucDiv)\n\n setRules.firstRules = oldRules.concat(rulesFirst, rulesSucDiv) // First rule set\n setRules.distrDivRules = rulesDistrDiv // Just distr. div. rules\n setRules.sucDivRules = rulesSucDiv // Jus succ. div. rules\n setRules.firstRulesAgain = oldRules.concat(rulesFirst) // Last rules set without succ. div.\n\n // Division simplification\n\n // Second rule set.\n // There is no aggregate expression with parentesis, but the only variable can be scattered.\n setRules.finalRules = [simplifyCore, // simplify.rules[0]\n { l: 'n*-n', r: '-n^2' }, // Joining multiply with power 1\n { l: 'n*n', r: 'n^2' }, // Joining multiply with power 2\n simplifyConstant, // simplify.rules[14] old 3rd index in oldRules\n { l: 'n*-n^n1', r: '-n^(n1+1)' }, // Joining multiply with power 3\n { l: 'n*n^n1', r: 'n^(n1+1)' }, // Joining multiply with power 4\n { l: 'n^n1*-n^n2', r: '-n^(n1+n2)' }, // Joining multiply with power 5\n { l: 'n^n1*n^n2', r: 'n^(n1+n2)' }, // Joining multiply with power 6\n { l: 'n^n1*-n', r: '-n^(n1+1)' }, // Joining multiply with power 7\n { l: 'n^n1*n', r: 'n^(n1+1)' }, // Joining multiply with power 8\n { l: 'n^n1/-n', r: '-n^(n1-1)' }, // Joining multiply with power 8\n { l: 'n^n1/n', r: 'n^(n1-1)' }, // Joining division with power 1\n { l: 'n/-n^n1', r: '-n^(1-n1)' }, // Joining division with power 2\n { l: 'n/n^n1', r: 'n^(1-n1)' }, // Joining division with power 3\n { l: 'n^n1/-n^n2', r: 'n^(n1-n2)' }, // Joining division with power 4\n { l: 'n^n1/n^n2', r: 'n^(n1-n2)' }, // Joining division with power 5\n { l: 'n1+(-n2*n3)', r: 'n1-n2*n3' }, // Solving useless parenthesis 1\n { l: 'v*(-c)', r: '-c*v' }, // Solving useless unary 2\n { l: 'n1+-n2', r: 'n1-n2' }, // Solving +- together (new!)\n { l: 'v*c', r: 'c*v' }, // inversion constant with variable\n { l: '(n1^n2)^n3', r: '(n1^(n2*n3))' } // Power to Power\n\n ]\n return setRules\n } // End rulesRationalize\n\n // ---------------------------------------------------------------------------------------\n /**\n * Expand recursively a tree node for handling with expressions with exponents\n * (it's not for constants, symbols or functions with exponents)\n * PS: The other parameters are internal for recursion\n *\n * Syntax:\n *\n * expandPower(node)\n *\n * @param {Node} node Current expression node\n * @param {node} parent Parent current node inside the recursion\n * @param (int} Parent number of chid inside the rercursion\n *\n * @return {node} node expression with all powers expanded.\n */\n function expandPower (node, parent, indParent) {\n const tp = node.type\n const internal = (arguments.length > 1) // TRUE in internal calls\n\n if (tp === 'OperatorNode' && node.isBinary()) {\n let does = false\n let val\n if (node.op === '^') { // First operator: Parenthesis or UnaryMinus\n if ((node.args[0].type === 'ParenthesisNode' ||\n node.args[0].type === 'OperatorNode') &&\n (node.args[1].type === 'ConstantNode')) { // Second operator: Constant\n val = parseFloat(node.args[1].value)\n does = (val >= 2 && isInteger(val))\n }\n }\n\n if (does) { // Exponent >= 2\n // Before:\n // operator A --> Subtree\n // parent pow\n // constant\n //\n if (val > 2) { // Exponent > 2,\n // AFTER: (exponent > 2)\n // operator A --> Subtree\n // parent *\n // deep clone (operator A --> Subtree\n // pow\n // constant - 1\n //\n const nEsqTopo = node.args[0]\n const nDirTopo = new OperatorNode('^', 'pow', [node.args[0].cloneDeep(), new ConstantNode(val - 1)])\n node = new OperatorNode('*', 'multiply', [nEsqTopo, nDirTopo])\n } else { // Expo = 2 - no power\n // AFTER: (exponent = 2)\n // operator A --> Subtree\n // parent oper\n // deep clone (operator A --> Subtree)\n //\n node = new OperatorNode('*', 'multiply', [node.args[0], node.args[0].cloneDeep()])\n }\n\n if (internal) {\n // Change parent references in internal recursive calls\n if (indParent === 'content') { parent.content = node } else { parent.args[indParent] = node }\n }\n } // does\n } // binary OperatorNode\n\n if (tp === 'ParenthesisNode') {\n // Recursion\n expandPower(node.content, node, 'content')\n } else if (tp !== 'ConstantNode' && tp !== 'SymbolNode') {\n for (let i = 0; i < node.args.length; i++) {\n expandPower(node.args[i], node, i)\n }\n }\n\n if (!internal) {\n // return the root node\n return node\n }\n } // End expandPower\n\n // ---------------------------------------------------------------------------------------\n /**\n * Auxilary function for rationalize\n * Convert near canonical polynomial in one variable in a canonical polynomial\n * with one term for each exponent in decreasing order\n *\n * Syntax:\n *\n * polyToCanonical(node [, coefficients])\n *\n * @param {Node | string} expr The near canonical polynomial expression to convert in a a canonical polynomial expression\n *\n * The string or tree expression needs to be at below syntax, with free spaces:\n * ( (^(-)? | [+-]? )cte (*)? var (^expo)? | cte )+\n * Where 'var' is one variable with any valid name\n * 'cte' are real numeric constants with any value. It can be omitted if equal than 1\n * 'expo' are integers greater than 0. It can be omitted if equal than 1.\n *\n * @param {array} coefficients Optional returns coefficients sorted by increased exponent\n *\n *\n * @return {node} new node tree with one variable polynomial or string error.\n */\n function polyToCanonical (node, coefficients) {\n if (coefficients === undefined) { coefficients = [] } // coefficients.\n\n coefficients[0] = 0 // index is the exponent\n const o = {}\n o.cte = 1\n o.oper = '+'\n\n // fire: mark with * or ^ when finds * or ^ down tree, reset to \"\" with + and -.\n // It is used to deduce the exponent: 1 for *, 0 for \"\".\n o.fire = ''\n\n let maxExpo = 0 // maximum exponent\n let varname = '' // variable name\n\n recurPol(node, null, o)\n maxExpo = coefficients.length - 1\n let first = true\n let no\n\n for (let i = maxExpo; i >= 0; i--) {\n if (coefficients[i] === 0) continue\n let n1 = new ConstantNode(\n first ? coefficients[i] : Math.abs(coefficients[i]))\n const op = coefficients[i] < 0 ? '-' : '+'\n\n if (i > 0) { // Is not a constant without variable\n let n2 = new SymbolNode(varname)\n if (i > 1) {\n const n3 = new ConstantNode(i)\n n2 = new OperatorNode('^', 'pow', [n2, n3])\n }\n if (coefficients[i] === -1 && first) { n1 = new OperatorNode('-', 'unaryMinus', [n2]) } else if (Math.abs(coefficients[i]) === 1) { n1 = n2 } else { n1 = new OperatorNode('*', 'multiply', [n1, n2]) }\n }\n\n if (first) { no = n1 } else if (op === '+') { no = new OperatorNode('+', 'add', [no, n1]) } else { no = new OperatorNode('-', 'subtract', [no, n1]) }\n\n first = false\n } // for\n\n if (first) { return new ConstantNode(0) } else { return no }\n\n /**\n * Recursive auxilary function inside polyToCanonical for\n * converting expression in canonical form\n *\n * Syntax:\n *\n * recurPol(node, noPai, obj)\n *\n * @param {Node} node The current subpolynomial expression\n * @param {Node | Null} noPai The current parent node\n * @param {object} obj Object with many internal flags\n *\n * @return {} No return. If error, throws an exception\n */\n function recurPol (node, noPai, o) {\n const tp = node.type\n if (tp === 'FunctionNode') {\n // ***** FunctionName *****\n // No function call in polynomial expression\n throw new Error('There is an unsolved function call')\n } else if (tp === 'OperatorNode') {\n // ***** OperatorName *****\n if (!'+-*^'.includes(node.op)) throw new Error('Operator ' + node.op + ' invalid')\n\n if (noPai !== null) {\n // -(unary),^ : children of *,+,-\n if ((node.fn === 'unaryMinus' || node.fn === 'pow') && noPai.fn !== 'add' &&\n noPai.fn !== 'subtract' && noPai.fn !== 'multiply') { throw new Error('Invalid ' + node.op + ' placing') }\n\n // -,+,* : children of +,-\n if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'multiply') &&\n noPai.fn !== 'add' && noPai.fn !== 'subtract') { throw new Error('Invalid ' + node.op + ' placing') }\n\n // -,+ : first child\n if ((node.fn === 'subtract' || node.fn === 'add' ||\n node.fn === 'unaryMinus') && o.noFil !== 0) { throw new Error('Invalid ' + node.op + ' placing') }\n } // Has parent\n\n // Firers: ^,* Old: ^,&,-(unary): firers\n if (node.op === '^' || node.op === '*') {\n o.fire = node.op\n }\n\n for (let i = 0; i < node.args.length; i++) {\n // +,-: reset fire\n if (node.fn === 'unaryMinus') o.oper = '-'\n if (node.op === '+' || node.fn === 'subtract') {\n o.fire = ''\n o.cte = 1 // default if there is no constant\n o.oper = (i === 0 ? '+' : node.op)\n }\n o.noFil = i // number of son\n recurPol(node.args[i], node, o)\n } // for in children\n } else if (tp === 'SymbolNode') { // ***** SymbolName *****\n if (node.name !== varname && varname !== '') { throw new Error('There is more than one variable') }\n varname = node.name\n if (noPai === null) {\n coefficients[1] = 1\n return\n }\n\n // ^: Symbol is First child\n if (noPai.op === '^' && o.noFil !== 0) { throw new Error('In power the variable should be the first parameter') }\n\n // *: Symbol is Second child\n if (noPai.op === '*' && o.noFil !== 1) { throw new Error('In multiply the variable should be the second parameter') }\n\n // Symbol: firers '',* => it means there is no exponent above, so it's 1 (cte * var)\n if (o.fire === '' || o.fire === '*') {\n if (maxExpo < 1) coefficients[1] = 0\n coefficients[1] += o.cte * (o.oper === '+' ? 1 : -1)\n maxExpo = Math.max(1, maxExpo)\n }\n } else if (tp === 'ConstantNode') {\n const valor = parseFloat(node.value)\n if (noPai === null) {\n coefficients[0] = valor\n return\n }\n if (noPai.op === '^') {\n // cte: second child of power\n if (o.noFil !== 1) throw new Error('Constant cannot be powered')\n\n if (!isInteger(valor) || valor <= 0) { throw new Error('Non-integer exponent is not allowed') }\n\n for (let i = maxExpo + 1; i < valor; i++) coefficients[i] = 0\n if (valor > maxExpo) coefficients[valor] = 0\n coefficients[valor] += o.cte * (o.oper === '+' ? 1 : -1)\n maxExpo = Math.max(valor, maxExpo)\n return\n }\n o.cte = valor\n\n // Cte: firer '' => There is no exponent and no multiplication, so the exponent is 0.\n if (o.fire === '') { coefficients[0] += o.cte * (o.oper === '+' ? 1 : -1) }\n } else { throw new Error('Type ' + tp + ' is not allowed') }\n } // End of recurPol\n } // End of polyToCanonical\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'zpk2tf'\n\nconst dependencies = [\n 'typed',\n 'add',\n 'multiply',\n 'Complex',\n 'number'\n]\n\nexport const createZpk2tf = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, multiply, Complex, number }) => {\n /**\n * Compute the transfer function of a zero-pole-gain model.\n *\n * Syntax:\n * math.zpk2tf(z, p, k)\n *\n * Examples:\n * math.zpk2tf([1, 2], [-1, -2], 1) // returns [[1, -3, 2], [1, 3, 2]]\n *\n * See also:\n * freqz\n *\n * @param {Array} z Array of zeros values\n * @param {Array} p Array of poles values\n * @param {number} k Gain value\n * @return {Array} Two dimensional array containing the numerator (first row) and denominator (second row) polynomials\n *\n */\n return typed(name, {\n 'Array,Array,number': function (z, p, k) {\n return _zpk2tf(z, p, k)\n },\n 'Array,Array': function (z, p) {\n return _zpk2tf(z, p, 1)\n },\n 'Matrix,Matrix,number': function (z, p, k) {\n return _zpk2tf(z.valueOf(), p.valueOf(), k)\n },\n 'Matrix,Matrix': function (z, p) {\n return _zpk2tf(z.valueOf(), p.valueOf(), 1)\n }\n })\n\n function _zpk2tf (z, p, k) {\n // if z is bignumber, convert it to number\n if (z.some((el) => el.type === 'BigNumber')) {\n z = z.map((el) => number(el))\n }\n // if p is bignumber, convert it to number\n if (p.some((el) => el.type === 'BigNumber')) {\n p = p.map((el) => number(el))\n }\n let num = [Complex(1, 0)]\n let den = [Complex(1, 0)]\n for (let i = 0; i < z.length; i++) {\n let zero = z[i]\n if (typeof zero === 'number') zero = Complex(zero, 0)\n num = _multiply(num, [Complex(1, 0), Complex(-zero.re, -zero.im)])\n }\n for (let i = 0; i < p.length; i++) {\n let pole = p[i]\n if (typeof pole === 'number') pole = Complex(pole, 0)\n den = _multiply(den, [Complex(1, 0), Complex(-pole.re, -pole.im)])\n }\n for (let i = 0; i < num.length; i++) {\n num[i] = multiply(num[i], k)\n }\n return [num, den]\n }\n\n function _multiply (a, b) {\n const c = []\n for (let i = 0; i < a.length + b.length - 1; i++) {\n c[i] = Complex(0, 0)\n for (let j = 0; j < a.length; j++) {\n if (i - j >= 0 && i - j < b.length) {\n c[i] = add(c[i], multiply(a[j], b[i - j]))\n }\n }\n }\n return c\n }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'freqz'\n\nconst dependencies = [\n 'typed',\n 'add',\n 'multiply',\n 'Complex',\n 'divide',\n 'matrix'\n]\n\nexport const createFreqz = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, multiply, Complex, divide, matrix }) => {\n /**\n * Calculates the frequency response of a filter given its numerator and denominator coefficients.\n *\n * Syntax:\n * math.freqz(b, a)\n * math.freqz(b, a, w)\n *\n * Examples:\n * math.freqz([1, 2], [1, 2, 3], 4) // returns { h: [0.5 + 0i, 0.4768589245763655 + 0.2861153547458193i, 0.25000000000000006 + 0.75i, -0.770976571635189 + 0.4625859429811135i], w: [0, 0.7853981633974483, 1.5707963267948966, 2.356194490192345 ] }\n * math.freqz([1, 2], [1, 2, 3], [0, 1]) // returns { h: [0.5 + 0i, 0.45436781 + 0.38598051i], w: [0, 1] }\n *\n * See also:\n * zpk2tf\n *\n * @param {Array.} b The numerator coefficients of the filter.\n * @param {Array.} a The denominator coefficients of the filter.\n * @param {Array.} [w] A vector of frequencies (in radians/sample) at which the frequency response is to be computed or the number of points to compute (if a number is not provided, the default is 512 points)\n * @returns {Object} An object with two properties: h, a vector containing the complex frequency response, and w, a vector containing the normalized frequencies (in radians/sample) at which the response was computed.\n *\n *\n */\n return typed(name, {\n 'Array, Array': function (b, a) {\n const w = createBins(512)\n return _freqz(b, a, w)\n },\n 'Array, Array, Array': function (b, a, w) {\n return _freqz(b, a, w)\n },\n 'Array, Array, number': function (b, a, w) {\n if (w < 0) {\n throw new Error('w must be a positive number')\n }\n const w2 = createBins(w)\n return _freqz(b, a, w2)\n },\n 'Matrix, Matrix': function (b, a) {\n // console.log('here')\n const _w = createBins(512)\n const { w, h } = _freqz(b.valueOf(), a.valueOf(), _w)\n return {\n w: matrix(w),\n h: matrix(h)\n }\n },\n 'Matrix, Matrix, Matrix': function (b, a, w) {\n const { h } = _freqz(b.valueOf(), a.valueOf(), w.valueOf())\n return {\n h: matrix(h),\n w: matrix(w)\n }\n },\n 'Matrix, Matrix, number': function (b, a, w) {\n if (w < 0) {\n throw new Error('w must be a positive number')\n }\n const _w = createBins(w)\n const { h } = _freqz(b.valueOf(), a.valueOf(), _w)\n return {\n h: matrix(h),\n w: matrix(_w)\n }\n }\n })\n\n function _freqz (b, a, w) {\n const num = []\n const den = []\n for (let i = 0; i < w.length; i++) {\n let sumNum = Complex(0, 0)\n let sumDen = Complex(0, 0)\n for (let j = 0; j < b.length; j++) {\n sumNum = add(sumNum, multiply(b[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i]))))\n }\n for (let j = 0; j < a.length; j++) {\n sumDen = add(sumDen, multiply(a[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i]))))\n }\n num.push(sumNum)\n den.push(sumDen)\n }\n const h = []\n for (let i = 0; i < num.length; i++) {\n h.push(divide(num[i], den[i]))\n }\n return { h, w }\n }\n\n function createBins (n) {\n const bins = []\n for (let i = 0; i < n; i++) {\n bins.push(i / n * Math.PI)\n }\n return bins\n }\n})\n","import { factory } from '../utils/factory.js'\n\nconst name = 'reviver'\nconst dependencies = [\n 'classes'\n]\n\nexport const createReviver = /* #__PURE__ */ factory(name, dependencies, ({ classes }) => {\n /**\n * Instantiate mathjs data types from their JSON representation\n * @param {string} key\n * @param {*} value\n * @returns {*} Returns the revived object\n */\n return function reviver (key, value) {\n const constructor = classes[value && value.mathjs]\n\n if (constructor && typeof constructor.fromJSON === 'function') {\n return constructor.fromJSON(value)\n }\n\n return value\n }\n})\n","import { factory } from '../utils/factory.js'\n\nconst name = 'replacer'\nconst dependencies = []\n\nexport const createReplacer = /* #__PURE__ */ factory(name, dependencies, () => {\n /**\n * Stringify data types into their JSON representation.\n * Most data types can be serialized using their `.toJSON` method,\n * but not all, for example the number `Infinity`. For these cases you have\n * to use the replacer. Example usage:\n *\n * JSON.stringify([2, Infinity], math.replacer)\n *\n * @param {string} key\n * @param {*} value\n * @returns {*} Returns the replaced object\n */\n return function replacer (key, value) {\n // the numeric values Infinitiy, -Infinity, and NaN cannot be serialized to JSON\n if (typeof value === 'number' && (!isFinite(value) || isNaN(value))) {\n return {\n mathjs: 'number',\n value: String(value)\n }\n }\n\n if (typeof value === 'bigint') {\n return {\n mathjs: 'bigint',\n value: String(value)\n }\n }\n\n return value\n }\n})\n","export const pi = Math.PI\nexport const tau = 2 * Math.PI\nexport const e = Math.E\nexport const phi = 1.6180339887498948 // eslint-disable-line no-loss-of-precision\n","import { factory } from './utils/factory.js'\nimport { version } from './version.js'\nimport {\n createBigNumberE,\n createBigNumberPhi,\n createBigNumberPi,\n createBigNumberTau\n} from './utils/bignumber/constants.js'\nimport { pi, tau, e, phi } from './plain/number/index.js'\n\nexport const createTrue = /* #__PURE__ */ factory('true', [], () => true)\nexport const createFalse = /* #__PURE__ */ factory('false', [], () => false)\nexport const createNull = /* #__PURE__ */ factory('null', [], () => null)\n\nexport const createInfinity = /* #__PURE__ */ recreateFactory(\n 'Infinity',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(Infinity)\n : Infinity\n)\n\nexport const createNaN = /* #__PURE__ */ recreateFactory(\n 'NaN',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(NaN)\n : NaN\n)\n\nexport const createPi = /* #__PURE__ */ recreateFactory(\n 'pi',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? createBigNumberPi(BigNumber)\n : pi\n)\n\nexport const createTau = /* #__PURE__ */ recreateFactory(\n 'tau',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? createBigNumberTau(BigNumber)\n : tau\n)\n\nexport const createE = /* #__PURE__ */ recreateFactory(\n 'e',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? createBigNumberE(BigNumber)\n : e\n)\n\n// golden ratio, (1+sqrt(5))/2\nexport const createPhi = /* #__PURE__ */ recreateFactory(\n 'phi',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? createBigNumberPhi(BigNumber)\n : phi\n)\n\nexport const createLN2 = /* #__PURE__ */ recreateFactory(\n 'LN2',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(2).ln()\n : Math.LN2\n)\n\nexport const createLN10 = /* #__PURE__ */ recreateFactory(\n 'LN10',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(10).ln()\n : Math.LN10\n)\n\nexport const createLOG2E = /* #__PURE__ */ recreateFactory(\n 'LOG2E',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(1).div(new BigNumber(2).ln())\n : Math.LOG2E\n)\n\nexport const createLOG10E = /* #__PURE__ */ recreateFactory(\n 'LOG10E',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(1).div(new BigNumber(10).ln())\n : Math.LOG10E\n)\n\nexport const createSQRT1_2 = /* #__PURE__ */ recreateFactory( // eslint-disable-line camelcase\n 'SQRT1_2',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber('0.5').sqrt()\n : Math.SQRT1_2\n)\n\nexport const createSQRT2 = /* #__PURE__ */ recreateFactory(\n 'SQRT2',\n ['config', '?BigNumber'],\n ({ config, BigNumber }) => (config.number === 'BigNumber')\n ? new BigNumber(2).sqrt()\n : Math.SQRT2\n)\n\nexport const createI = /* #__PURE__ */ recreateFactory(\n 'i',\n ['Complex'],\n ({ Complex }) => Complex.I\n)\n\n// for backward compatibility with v5\nexport const createUppercasePi = /* #__PURE__ */ factory('PI', ['pi'], ({ pi }) => pi)\nexport const createUppercaseE = /* #__PURE__ */ factory('E', ['e'], ({ e }) => e)\n\nexport const createVersion = /* #__PURE__ */ factory('version', [], () => version)\n\n// helper function to create a factory with a flag recreateOnConfigChange\n// idea: allow passing optional properties to be attached to the factory function as 4th argument?\nfunction recreateFactory (name, dependencies, create) {\n return factory(name, dependencies, create, {\n recreateOnConfigChange: true\n })\n}\n","export const version = '13.2.0'\n// Note: This file is automatically generated when building math.js.\n// Changes made in this file will be overwritten.\n","import { factory } from '../../utils/factory.js'\n\n// Source: https://en.wikipedia.org/wiki/Physical_constant\n\n// Universal constants\nexport const createSpeedOfLight = /* #__PURE__ */ unitFactory('speedOfLight', '299792458', 'm s^-1')\nexport const createGravitationConstant = /* #__PURE__ */ unitFactory('gravitationConstant', '6.67430e-11', 'm^3 kg^-1 s^-2')\nexport const createPlanckConstant = /* #__PURE__ */ unitFactory('planckConstant', '6.62607015e-34', 'J s')\nexport const createReducedPlanckConstant = /* #__PURE__ */ unitFactory('reducedPlanckConstant', '1.0545718176461565e-34', 'J s')\n\n// Electromagnetic constants\nexport const createMagneticConstant = /* #__PURE__ */ unitFactory('magneticConstant', '1.25663706212e-6', 'N A^-2')\nexport const createElectricConstant = /* #__PURE__ */ unitFactory('electricConstant', '8.8541878128e-12', 'F m^-1')\nexport const createVacuumImpedance = /* #__PURE__ */ unitFactory('vacuumImpedance', '376.730313667', 'ohm')\nexport const createCoulomb = /* #__PURE__ */ unitFactory('coulomb', '8.987551792261171e9', 'N m^2 C^-2')\nexport const createElementaryCharge = /* #__PURE__ */ unitFactory('elementaryCharge', '1.602176634e-19', 'C')\nexport const createBohrMagneton = /* #__PURE__ */ unitFactory('bohrMagneton', '9.2740100783e-24', 'J T^-1')\nexport const createConductanceQuantum = /* #__PURE__ */ unitFactory('conductanceQuantum', '7.748091729863649e-5', 'S')\nexport const createInverseConductanceQuantum = /* #__PURE__ */ unitFactory('inverseConductanceQuantum', '12906.403729652257', 'ohm')\nexport const createMagneticFluxQuantum = /* #__PURE__ */ unitFactory('magneticFluxQuantum', '2.0678338484619295e-15', 'Wb')\nexport const createNuclearMagneton = /* #__PURE__ */ unitFactory('nuclearMagneton', '5.0507837461e-27', 'J T^-1')\nexport const createKlitzing = /* #__PURE__ */ unitFactory('klitzing', '25812.807459304513', 'ohm')\nexport const createJosephson = /* #__PURE__ */ unitFactory('josephson', '4.835978484169836e14 Hz V', 'Hz V^-1') // TODO: support for Hz needed\n\n// Atomic and nuclear constants\nexport const createBohrRadius = /* #__PURE__ */ unitFactory('bohrRadius', '5.29177210903e-11', 'm')\nexport const createClassicalElectronRadius = /* #__PURE__ */ unitFactory('classicalElectronRadius', '2.8179403262e-15', 'm')\nexport const createElectronMass = /* #__PURE__ */ unitFactory('electronMass', '9.1093837015e-31', 'kg')\nexport const createFermiCoupling = /* #__PURE__ */ unitFactory('fermiCoupling', '1.1663787e-5', 'GeV^-2')\nexport const createFineStructure = numberFactory('fineStructure', 7.2973525693e-3)\nexport const createHartreeEnergy = /* #__PURE__ */ unitFactory('hartreeEnergy', '4.3597447222071e-18', 'J')\nexport const createProtonMass = /* #__PURE__ */ unitFactory('protonMass', '1.67262192369e-27', 'kg')\nexport const createDeuteronMass = /* #__PURE__ */ unitFactory('deuteronMass', '3.3435830926e-27', 'kg')\nexport const createNeutronMass = /* #__PURE__ */ unitFactory('neutronMass', '1.6749271613e-27', 'kg')\nexport const createQuantumOfCirculation = /* #__PURE__ */ unitFactory('quantumOfCirculation', '3.6369475516e-4', 'm^2 s^-1')\nexport const createRydberg = /* #__PURE__ */ unitFactory('rydberg', '10973731.568160', 'm^-1')\nexport const createThomsonCrossSection = /* #__PURE__ */ unitFactory('thomsonCrossSection', '6.6524587321e-29', 'm^2')\nexport const createWeakMixingAngle = numberFactory('weakMixingAngle', 0.22290)\nexport const createEfimovFactor = numberFactory('efimovFactor', 22.7)\n\n// Physico-chemical constants\nexport const createAtomicMass = /* #__PURE__ */ unitFactory('atomicMass', '1.66053906660e-27', 'kg')\nexport const createAvogadro = /* #__PURE__ */ unitFactory('avogadro', '6.02214076e23', 'mol^-1')\nexport const createBoltzmann = /* #__PURE__ */ unitFactory('boltzmann', '1.380649e-23', 'J K^-1')\nexport const createFaraday = /* #__PURE__ */ unitFactory('faraday', '96485.33212331001', 'C mol^-1')\nexport const createFirstRadiation = /* #__PURE__ */ unitFactory('firstRadiation', '3.7417718521927573e-16', 'W m^2')\n// TODO spectralRadiance = 1.1910429723971881e-16 W m^2 sr^-1\nexport const createLoschmidt = /* #__PURE__ */ unitFactory('loschmidt', '2.686780111798444e25', 'm^-3')\nexport const createGasConstant = /* #__PURE__ */ unitFactory('gasConstant', '8.31446261815324', 'J K^-1 mol^-1')\nexport const createMolarPlanckConstant = /* #__PURE__ */ unitFactory('molarPlanckConstant', '3.990312712893431e-10', 'J s mol^-1')\nexport const createMolarVolume = /* #__PURE__ */ unitFactory('molarVolume', '0.022413969545014137', 'm^3 mol^-1')\nexport const createSackurTetrode = numberFactory('sackurTetrode', -1.16487052358)\nexport const createSecondRadiation = /* #__PURE__ */ unitFactory('secondRadiation', '0.014387768775039337', 'm K')\nexport const createStefanBoltzmann = /* #__PURE__ */ unitFactory('stefanBoltzmann', '5.67037441918443e-8', 'W m^-2 K^-4')\nexport const createWienDisplacement = /* #__PURE__ */ unitFactory('wienDisplacement', '2.897771955e-3', 'm K')\n\n// Adopted values\nexport const createMolarMass = /* #__PURE__ */ unitFactory('molarMass', '0.99999999965e-3', 'kg mol^-1')\nexport const createMolarMassC12 = /* #__PURE__ */ unitFactory('molarMassC12', '11.9999999958e-3', 'kg mol^-1')\nexport const createGravity = /* #__PURE__ */ unitFactory('gravity', '9.80665', 'm s^-2')\n// atm is defined in Unit.js\n\n// Natural units\nexport const createPlanckLength = /* #__PURE__ */ unitFactory('planckLength', '1.616255e-35', 'm')\nexport const createPlanckMass = /* #__PURE__ */ unitFactory('planckMass', '2.176435e-8', 'kg')\nexport const createPlanckTime = /* #__PURE__ */ unitFactory('planckTime', '5.391245e-44', 's')\nexport const createPlanckCharge = /* #__PURE__ */ unitFactory('planckCharge', '1.87554603778e-18', 'C')\nexport const createPlanckTemperature = /* #__PURE__ */ unitFactory('planckTemperature', '1.416785e+32', 'K')\n\n// helper function to create a factory function which creates a physical constant,\n// a Unit with either a number value or a BigNumber value depending on the configuration\nfunction unitFactory (name, valueStr, unitStr) {\n const dependencies = ['config', 'Unit', 'BigNumber']\n\n return factory(name, dependencies, ({ config, Unit, BigNumber }) => {\n // Note that we can parse into number or BigNumber.\n // We do not parse into Fractions as that doesn't make sense: we would lose precision of the values\n // Therefore we dont use Unit.parse()\n const value = config.number === 'BigNumber'\n ? new BigNumber(valueStr)\n : parseFloat(valueStr)\n\n const unit = new Unit(value, unitStr)\n unit.fixPrefix = true\n return unit\n })\n}\n\n// helper function to create a factory function which creates a numeric constant,\n// either a number or BigNumber depending on the configuration\nfunction numberFactory (name, value) {\n const dependencies = ['config', 'BigNumber']\n\n return factory(name, dependencies, ({ config, BigNumber }) => {\n return config.number === 'BigNumber'\n ? new BigNumber(value)\n : value\n })\n}\n","import { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createApply } from '../../function/matrix/apply.js'\nimport { isBigNumber, isNumber } from '../../utils/is.js'\n\nconst name = 'apply'\nconst dependencies = ['typed', 'isInteger']\n\n/**\n * Attach a transform function to math.apply\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function apply\n * from one-based to zero based\n */\nexport const createApplyTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\n const apply = createApply({ typed, isInteger })\n\n // @see: comment of concat itself\n return typed('apply', {\n '...any': function (args) {\n // change dim from one-based to zero-based\n const dim = args[1]\n\n if (isNumber(dim)) {\n args[1] = dim - 1\n } else if (isBigNumber(dim)) {\n args[1] = dim.minus(1)\n }\n\n try {\n return apply.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createColumn } from '../../function/matrix/column.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'column'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\n/**\n * Attach a transform function to matrix.column\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `index` parameter of function column\n * from zero-based to one-based\n */\nexport const createColumnTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n const column = createColumn({ typed, Index, matrix, range })\n\n // @see: comment of column itself\n return typed('column', {\n '...any': function (args) {\n // change last argument from zero-based to one-based\n const lastIndex = args.length - 1\n const last = args[lastIndex]\n if (isNumber(last)) {\n args[lastIndex] = last - 1\n }\n\n try {\n return column.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { isSymbolNode } from '../../../utils/is.js'\nimport { PartitionedMap } from '../../../utils/map.js'\n\n/**\n * Compile an inline expression like \"x > 0\"\n * @param {Node} expression\n * @param {Object} math\n * @param {Map} scope\n * @return {function} Returns a function with one argument which fills in the\n * undefined variable (like \"x\") and evaluates the expression\n */\nexport function compileInlineExpression (expression, math, scope) {\n // find an undefined symbol\n const symbol = expression.filter(function (node) {\n return isSymbolNode(node) &&\n !(node.name in math) &&\n !(scope.has(node.name))\n })[0]\n\n if (!symbol) {\n throw new Error('No undefined variable found in inline expression \"' + expression + '\"')\n }\n\n // create a test function for this equation\n const name = symbol.name // variable name\n const argsScope = new Map()\n const subScope = new PartitionedMap(scope, argsScope, new Set([name]))\n const eq = expression.compile()\n return function inlineExpression (x) {\n argsScope.set(name, x)\n return eq.evaluate(subScope)\n }\n}\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'transformCallback'\nconst dependencies = ['typed']\n\nexport const createTransformCallback = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Transforms the given callback function based on its type and number of arrays.\n *\n * @param {Function} callback - The callback function to transform.\n * @param {number} numberOfArrays - The number of arrays to pass to the callback function.\n * @returns {*} - The transformed callback function.\n */\n return function (callback, numberOfArrays) {\n if (typed.isTypedFunction(callback)) {\n return _transformTypedCallbackFunction(callback, numberOfArrays)\n } else {\n return _transformCallbackFunction(callback, callback.length, numberOfArrays)\n }\n }\n\n /**\n * Transforms the given typed callback function based on the number of arrays.\n *\n * @param {Function} typedFunction - The typed callback function to transform.\n * @param {number} numberOfArrays - The number of arrays to pass to the callback function.\n * @returns {*} - The transformed callback function.\n */\n function _transformTypedCallbackFunction (typedFunction, numberOfArrays) {\n const signatures = Object.fromEntries(\n Object.entries(typedFunction.signatures)\n .map(([signature, callbackFunction]) => {\n const numberOfCallbackInputs = signature.split(',').length\n if (typed.isTypedFunction(callbackFunction)) {\n return [signature, _transformTypedCallbackFunction(callbackFunction, numberOfArrays)]\n } else {\n return [signature, _transformCallbackFunction(callbackFunction, numberOfCallbackInputs, numberOfArrays)]\n }\n })\n )\n\n if (typeof typedFunction.name === 'string') {\n return typed(typedFunction.name, signatures)\n } else {\n return typed(signatures)\n }\n }\n})\n\n/**\n * Transforms the callback function based on the number of callback inputs and arrays.\n * There are three cases:\n * 1. The callback function has N arguments.\n * 2. The callback function has N+1 arguments.\n * 3. The callback function has 2N+1 arguments.\n *\n * @param {Function} callbackFunction - The callback function to transform.\n * @param {number} numberOfCallbackInputs - The number of callback inputs.\n * @param {number} numberOfArrays - The number of arrays.\n * @returns {Function} The transformed callback function.\n */\nfunction _transformCallbackFunction (callbackFunction, numberOfCallbackInputs, numberOfArrays) {\n if (numberOfCallbackInputs === numberOfArrays) {\n return callbackFunction\n } else if (numberOfCallbackInputs === numberOfArrays + 1) {\n return function (...args) {\n const vals = args.slice(0, numberOfArrays)\n const idx = _transformDims(args[numberOfArrays])\n return callbackFunction(...vals, idx)\n }\n } else if (numberOfCallbackInputs > numberOfArrays + 1) {\n return function (...args) {\n const vals = args.slice(0, numberOfArrays)\n const idx = _transformDims(args[numberOfArrays])\n const rest = args.slice(numberOfArrays + 1)\n return callbackFunction(...vals, idx, ...rest)\n }\n } else {\n return callbackFunction\n }\n}\n\n/**\n * Transforms the dimensions by adding 1 to each dimension.\n *\n * @param {Array} dims - The dimensions to transform.\n * @returns {Array} The transformed dimensions.\n */\nfunction _transformDims (dims) {\n return dims.map(dim => dim + 1)\n}\n","import { createFilter } from '../../function/matrix/filter.js'\nimport { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\nimport { createTransformCallback } from './utils/transformCallback.js'\n\nconst name = 'filter'\nconst dependencies = ['typed']\n\nexport const createFilterTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Attach a transform function to math.filter\n * Adds a property transform containing the transform function.\n *\n * This transform adds support for equations as test function for math.filter,\n * so you can do something like 'filter([3, -2, 5], x > 0)'.\n */\n function filterTransform (args, math, scope) {\n const filter = createFilter({ typed })\n const transformCallback = createTransformCallback({ typed })\n\n if (args.length === 0) {\n return filter()\n }\n let x = args[0]\n\n if (args.length === 1) {\n return filter(x)\n }\n\n const N = args.length - 1\n let callback = args[N]\n\n if (x) {\n x = _compileAndEvaluate(x, scope)\n }\n\n if (callback) {\n if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) {\n // a function pointer, like filter([3, -2, 5], myTestFunction)\n callback = _compileAndEvaluate(callback, scope)\n } else {\n // an expression like filter([3, -2, 5], x > 0)\n callback = compileInlineExpression(callback, math, scope)\n }\n }\n\n return filter(x, transformCallback(callback, N))\n }\n filterTransform.rawArgs = true\n\n function _compileAndEvaluate (arg, scope) {\n return arg.compile().evaluate(scope)\n }\n\n return filterTransform\n}, { isTransformFunction: true })\n","import { createForEach } from '../../function/matrix/forEach.js'\nimport { createTransformCallback } from './utils/transformCallback.js'\nimport { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\n\nconst name = 'forEach'\nconst dependencies = ['typed']\n\nexport const createForEachTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Attach a transform function to math.forEach\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n const forEach = createForEach({ typed })\n const transformCallback = createTransformCallback({ typed })\n function forEachTransform (args, math, scope) {\n if (args.length === 0) {\n return forEach()\n }\n let x = args[0]\n\n if (args.length === 1) {\n return forEach(x)\n }\n\n const N = args.length - 1\n let callback = args[N]\n\n if (x) {\n x = _compileAndEvaluate(x, scope)\n }\n\n if (callback) {\n if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) {\n // a function pointer, like filter([3, -2, 5], myTestFunction)\n callback = _compileAndEvaluate(callback, scope)\n } else {\n // an expression like filter([3, -2, 5], x > 0)\n callback = compileInlineExpression(callback, math, scope)\n }\n }\n\n return forEach(x, transformCallback(callback, N))\n }\n forEachTransform.rawArgs = true\n\n function _compileAndEvaluate (arg, scope) {\n return arg.compile().evaluate(scope)\n }\n return forEachTransform\n}, { isTransformFunction: true })\n","import { isArray, isBigNumber, isMatrix, isNumber, isRange } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'index'\nconst dependencies = ['Index', 'getMatrixDataType']\n\nexport const createIndexTransform = /* #__PURE__ */ factory(name, dependencies, ({ Index, getMatrixDataType }) => {\n /**\n * Attach a transform function to math.index\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n return function indexTransform () {\n const args = []\n for (let i = 0, ii = arguments.length; i < ii; i++) {\n let arg = arguments[i]\n\n // change from one-based to zero based, convert BigNumber to number and leave Array of Booleans as is\n if (isRange(arg)) {\n arg.start--\n arg.end -= (arg.step > 0 ? 0 : 2)\n } else if (arg && arg.isSet === true) {\n arg = arg.map(function (v) { return v - 1 })\n } else if (isArray(arg) || isMatrix(arg)) {\n if (getMatrixDataType(arg) !== 'boolean') {\n arg = arg.map(function (v) { return v - 1 })\n }\n } else if (isNumber(arg)) {\n arg--\n } else if (isBigNumber(arg)) {\n arg = arg.toNumber() - 1\n } else if (typeof arg === 'string') {\n // leave as is\n } else {\n throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range')\n }\n\n args[i] = arg\n }\n\n const res = new Index()\n Index.apply(res, args)\n return res\n }\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { createMap } from '../../function/matrix/map.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\nimport { createTransformCallback } from './utils/transformCallback.js'\n\nconst name = 'map'\nconst dependencies = ['typed']\n\nexport const createMapTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n /**\n * Attach a transform function to math.map\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n const map = createMap({ typed })\n const transformCallback = createTransformCallback({ typed })\n\n function mapTransform (args, math, scope) {\n if (args.length === 0) {\n return map()\n }\n\n if (args.length === 1) {\n return map(args[0])\n }\n const N = args.length - 1\n let X = args.slice(0, N)\n let callback = args[N]\n X = X.map(arg => _compileAndEvaluate(arg, scope))\n\n if (callback) {\n if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) {\n // a function pointer, like filter([3, -2, 5], myTestFunction)\n callback = _compileAndEvaluate(callback, scope)\n } else {\n // an expression like filter([3, -2, 5], x > 0)\n callback = compileInlineExpression(callback, math, scope)\n }\n }\n return map(...X, transformCallback(callback, N))\n\n function _compileAndEvaluate (arg, scope) {\n return arg.compile().evaluate(scope)\n }\n }\n mapTransform.rawArgs = true\n\n return mapTransform\n}, { isTransformFunction: true })\n","import { isCollection } from '../../../utils/is.js'\nimport { dimToZeroBase, isNumberOrBigNumber } from './dimToZeroBase.js'\n/**\n * Change last argument dim from one-based to zero-based.\n */\nexport function lastDimToZeroBase (args) {\n if (args.length === 2 && isCollection(args[0])) {\n args = args.slice()\n const dim = args[1]\n if (isNumberOrBigNumber(dim)) {\n args[1] = dimToZeroBase(dim)\n }\n }\n return args\n}\n","import { isNumber, isBigNumber } from '../../../utils/is.js'\n/**\n * Change last argument dim from one-based to zero-based.\n */\nexport function dimToZeroBase (dim) {\n if (isNumber(dim)) {\n return dim - 1\n } else if (isBigNumber(dim)) {\n return dim.minus(1)\n } else {\n return dim\n }\n}\n\nexport function isNumberOrBigNumber (n) {\n return isNumber(n) || isBigNumber(n)\n}\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMax } from '../../function/statistics/max.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'max'\nconst dependencies = ['typed', 'config', 'numeric', 'larger']\n\nexport const createMaxTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, larger }) => {\n const max = createMax({ typed, config, numeric, larger })\n\n /**\n * Attach a transform function to math.max\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function max\n * from one-based to zero based\n */\n return typed('max', {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return max.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMean } from '../../function/statistics/mean.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'mean'\nconst dependencies = ['typed', 'add', 'divide']\n\nexport const createMeanTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide }) => {\n const mean = createMean({ typed, add, divide })\n\n /**\n * Attach a transform function to math.mean\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function mean\n * from one-based to zero based\n */\n return typed('mean', {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return mean.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMin } from '../../function/statistics/min.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'min'\nconst dependencies = ['typed', 'config', 'numeric', 'smaller']\n\nexport const createMinTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, smaller }) => {\n const min = createMin({ typed, config, numeric, smaller })\n\n /**\n * Attach a transform function to math.min\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function min\n * from one-based to zero based\n */\n return typed('min', {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return min.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createRange } from '../../function/matrix/range.js'\n\nconst name = 'range'\nconst dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']\n\nexport const createRangeTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive }) => {\n const range = createRange({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive })\n\n /**\n * Attach a transform function to math.range\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n return typed('range', {\n '...any': function (args) {\n const lastIndex = args.length - 1\n const last = args[lastIndex]\n if (typeof last !== 'boolean') {\n // append a parameter includeEnd=true\n args.push(true)\n }\n\n return range.apply(null, args)\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createRow } from '../../function/matrix/row.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'row'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\n/**\n * Attach a transform function to matrix.column\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `index` parameter of function column\n * from zero-based to one-based\n */\nexport const createRowTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n const row = createRow({ typed, Index, matrix, range })\n\n // @see: comment of row itself\n return typed('row', {\n '...any': function (args) {\n // change last argument from zero-based to one-based\n const lastIndex = args.length - 1\n const last = args[lastIndex]\n if (isNumber(last)) {\n args[lastIndex] = last - 1\n }\n\n try {\n return row.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createSubset } from '../../function/matrix/subset.js'\n\nconst name = 'subset'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createSubsetTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\n const subset = createSubset({ typed, matrix, zeros, add })\n\n /**\n * Attach a transform function to math.subset\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n return typed('subset', {\n '...any': function (args) {\n try {\n return subset.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { isBigNumber, isNumber } from '../../utils/is.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createConcat } from '../../function/matrix/concat.js'\n\nconst name = 'concat'\nconst dependencies = ['typed', 'matrix', 'isInteger']\n\nexport const createConcatTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isInteger }) => {\n const concat = createConcat({ typed, matrix, isInteger })\n\n /**\n * Attach a transform function to math.range\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function concat\n * from one-based to zero based\n */\n return typed('concat', {\n '...any': function (args) {\n // change last argument from one-based to zero-based\n const lastIndex = args.length - 1\n const last = args[lastIndex]\n if (isNumber(last)) {\n args[lastIndex] = last - 1\n } else if (isBigNumber(last)) {\n args[lastIndex] = last.minus(1)\n }\n\n try {\n return concat.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createDiff } from '../../function/matrix/diff.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'diff'\nconst dependencies = ['typed', 'matrix', 'subtract', 'number', 'bignumber']\n\nexport const createDiffTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, number, bignumber }) => {\n const diff = createDiff({ typed, matrix, subtract, number, bignumber })\n\n /**\n * Attach a transform function to math.diff\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n return typed(name, {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return diff.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createStd } from '../../function/statistics/std.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'std'\nconst dependencies = ['typed', 'map', 'sqrt', 'variance']\n\n/**\n * Attach a transform function to math.std\n * Adds a property transform containing the transform function.\n *\n * This transform changed the `dim` parameter of function std\n * from one-based to zero based\n */\nexport const createStdTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, map, sqrt, variance }) => {\n const std = createStd({ typed, map, sqrt, variance })\n\n return typed('std', {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return std.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createSum } from '../../function/statistics/sum.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\n/**\n * Attach a transform function to math.sum\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function sum\n * from one-based to zero based\n */\nconst name = 'sum'\nconst dependencies = ['typed', 'config', 'add', 'numeric']\n\nexport const createSumTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, add, numeric }) => {\n const sum = createSum({ typed, config, add, numeric })\n\n return typed(name, {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return sum.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createQuantileSeq } from '../../function/statistics/quantileSeq.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'quantileSeq'\nconst dependencies = ['typed', 'bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']\n\n/**\n * Attach a transform function to math.quantileSeq\n * Adds a property transform containing the transform function.\n *\n * This transform changed the `dim` parameter of function std\n * from one-based to zero based\n */\nexport const createQuantileSeqTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger }) => {\n const quantileSeq = createQuantileSeq({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger })\n\n return typed('quantileSeq', {\n 'Array | Matrix, number | BigNumber': quantileSeq,\n 'Array | Matrix, number | BigNumber, number': (arr, prob, dim) => quantileSeq(arr, prob, dimToZeroBase(dim)),\n 'Array | Matrix, number | BigNumber, boolean': quantileSeq,\n 'Array | Matrix, number | BigNumber, boolean, number': (arr, prob, sorted, dim) => quantileSeq(arr, prob, sorted, dimToZeroBase(dim)),\n 'Array | Matrix, Array | Matrix': quantileSeq,\n 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => quantileSeq(data, prob, dimToZeroBase(dim)),\n 'Array | Matrix, Array | Matrix, boolean': quantileSeq,\n 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => quantileSeq(data, prob, sorted, dimToZeroBase(dim))\n })\n\n function dimToZeroBase (dim) {\n // TODO: find a better way, maybe lastDimToZeroBase could apply to more cases.\n return lastDimToZeroBase([[], dim])[1]\n }\n}, { isTransformFunction: true })\n","import { isBigNumber, isCollection, isNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createCumSum } from '../../function/statistics/cumsum.js'\n\n/**\n * Attach a transform function to math.sum\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function sum\n * from one-based to zero based\n */\nconst name = 'cumsum'\nconst dependencies = ['typed', 'add', 'unaryPlus']\n\nexport const createCumSumTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, unaryPlus }) => {\n const cumsum = createCumSum({ typed, add, unaryPlus })\n\n return typed(name, {\n '...any': function (args) {\n // change last argument dim from one-based to zero-based\n if (args.length === 2 && isCollection(args[0])) {\n const dim = args[1]\n if (isNumber(dim)) {\n args[1] = dim - 1\n } else if (isBigNumber(dim)) {\n args[1] = dim.minus(1)\n }\n }\n\n try {\n return cumsum.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createVariance } from '../../function/statistics/variance.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'variance'\nconst dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']\n\n/**\n * Attach a transform function to math.var\n * Adds a property transform containing the transform function.\n *\n * This transform changed the `dim` parameter of function var\n * from one-based to zero based\n */\nexport const createVarianceTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, subtract, multiply, divide, apply, isNaN }) => {\n const variance = createVariance({ typed, add, subtract, multiply, divide, apply, isNaN })\n\n return typed(name, {\n '...any': function (args) {\n args = lastDimToZeroBase(args)\n\n try {\n return variance.apply(null, args)\n } catch (err) {\n throw errorTransform(err)\n }\n }\n })\n}, { isTransformFunction: true })\n","import { createPrint } from '../../function/string/print.js'\nimport { factory } from '../../utils/factory.js'\nimport { printTemplate } from '../../utils/print.js'\n\nconst name = 'print'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createPrintTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\n const print = createPrint({ typed, matrix, zeros, add })\n return typed(name, {\n 'string, Object | Array': function (template, values) { return print(_convertTemplateToZeroBasedIndex(template), values) },\n 'string, Object | Array, number | Object': function (template, values, options) { return print(_convertTemplateToZeroBasedIndex(template), values, options) }\n })\n\n function _convertTemplateToZeroBasedIndex (template) {\n return template.replace(printTemplate, (x) => {\n const parts = x.slice(1).split('.')\n const result = parts.map(function (part) {\n if (!isNaN(part) && part.length > 0) {\n return parseInt(part) - 1\n } else {\n return part\n }\n })\n return '$' + result.join('.')\n })\n }\n}, { isTransformFunction: true })\n","import { createAnd } from '../../function/logical/and.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'and'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']\n\nexport const createAndTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n const and = createAnd({ typed, matrix, equalScalar, zeros, not, concat })\n\n function andTransform (args, math, scope) {\n const condition1 = args[0].compile().evaluate(scope)\n if (!isCollection(condition1) && !and(condition1, true)) {\n return false\n }\n const condition2 = args[1].compile().evaluate(scope)\n return and(condition1, condition2)\n }\n\n andTransform.rawArgs = true\n\n return andTransform\n}, { isTransformFunction: true })\n","import { createOr } from '../../function/logical/or.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'or'\nconst dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']\n\nexport const createOrTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n const or = createOr({ typed, matrix, equalScalar, DenseMatrix, concat })\n\n function orTransform (args, math, scope) {\n const condition1 = args[0].compile().evaluate(scope)\n if (!isCollection(condition1) && or(condition1, false)) {\n return true\n }\n const condition2 = args[1].compile().evaluate(scope)\n return or(condition1, condition2)\n }\n\n orTransform.rawArgs = true\n\n return orTransform\n}, { isTransformFunction: true })\n","import { createBitAnd } from '../../function/bitwise/bitAnd.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'bitAnd'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']\n\nexport const createBitAndTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n const bitAnd = createBitAnd({ typed, matrix, equalScalar, zeros, not, concat })\n\n function bitAndTransform (args, math, scope) {\n const condition1 = args[0].compile().evaluate(scope)\n if (!isCollection(condition1)) {\n if (isNaN(condition1)) {\n return NaN\n }\n if (condition1 === 0 || condition1 === false) {\n return 0\n }\n }\n const condition2 = args[1].compile().evaluate(scope)\n return bitAnd(condition1, condition2)\n }\n\n bitAndTransform.rawArgs = true\n\n return bitAndTransform\n}, { isTransformFunction: true })\n","import { createBitOr } from '../../function/bitwise/bitOr.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'bitOr'\nconst dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']\n\nexport const createBitOrTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n const bitOr = createBitOr({ typed, matrix, equalScalar, DenseMatrix, concat })\n\n function bitOrTransform (args, math, scope) {\n const condition1 = args[0].compile().evaluate(scope)\n if (!isCollection(condition1)) {\n if (isNaN(condition1)) {\n return NaN\n }\n if (condition1 === (-1)) {\n return -1\n }\n if (condition1 === true) {\n return 1\n }\n }\n const condition2 = args[1].compile().evaluate(scope)\n return bitOr(condition1, condition2)\n }\n\n bitOrTransform.rawArgs = true\n\n return bitOrTransform\n}, { isTransformFunction: true })\n","export const DEFAULT_CONFIG = {\n // minimum relative difference between two compared values,\n // used by all comparison functions\n relTol: 1e-12,\n\n // minimum absolute difference between two compared values,\n // used by all comparison functions\n absTol: 1e-15,\n\n // type of default matrix output. Choose 'matrix' (default) or 'array'\n matrix: 'Matrix',\n\n // type of default number output. Choose 'number' (default) 'BigNumber', 'bigint', or 'Fraction'\n number: 'number',\n\n // type of fallback used for config { number: 'bigint' } when a value cannot be represented\n // in the configured numeric type. Choose 'number' (default) or 'BigNumber'.\n numberFallback: 'number',\n\n // number of significant digits in BigNumbers\n precision: 64,\n\n // predictable output type of functions. When true, output type depends only\n // on the input types. When false (default), output type can vary depending\n // on input values. For example `math.sqrt(-4)` returns `complex('2i')` when\n // predictable is false, and returns `NaN` when true.\n predictable: false,\n\n // random seed for seeded pseudo random number generation\n // null = randomly seed\n randomSeed: null\n}\n","import { clone, deepExtend } from '../../utils/object.js'\nimport { DEFAULT_CONFIG } from '../config.js'\n\nexport const MATRIX_OPTIONS = ['Matrix', 'Array'] // valid values for option matrix\nexport const NUMBER_OPTIONS = ['number', 'BigNumber', 'Fraction'] // valid values for option number\n\nexport function configFactory (config, emit) {\n /**\n * Set configuration options for math.js, and get current options.\n * Will emit a 'config' event, with arguments (curr, prev, changes).\n *\n * This function is only available on a mathjs instance created using `create`.\n *\n * Syntax:\n *\n * math.config(config: Object): Object\n *\n * Examples:\n *\n *\n * import { create, all } from 'mathjs'\n *\n * // create a mathjs instance\n * const math = create(all)\n *\n * math.config().number // outputs 'number'\n * math.evaluate('0.4') // outputs number 0.4\n * math.config({number: 'Fraction'})\n * math.evaluate('0.4') // outputs Fraction 2/5\n *\n * @param {Object} [options] Available options:\n * {number} relTol\n * Minimum relative difference between two\n * compared values, used by all comparison functions.\n * {number} absTol\n * Minimum absolute difference between two\n * compared values, used by all comparison functions.\n * {string} matrix\n * A string 'Matrix' (default) or 'Array'.\n * {string} number\n * A string 'number' (default), 'BigNumber', 'bigint', or 'Fraction'\n * {number} precision\n * The number of significant digits for BigNumbers.\n * Not applicable for Numbers.\n * {string} parenthesis\n * How to display parentheses in LaTeX and string\n * output.\n * {string} randomSeed\n * Random seed for seeded pseudo random number generator.\n * Set to null to randomly seed.\n * @return {Object} Returns the current configuration\n */\n function _config (options) {\n if (options) {\n if (options.epsilon !== undefined) {\n // this if is only for backwards compatibility, it can be removed in the future.\n console.warn('Warning: The configuration option \"epsilon\" is deprecated. Use \"relTol\" and \"absTol\" instead.')\n const optionsFix = clone(options)\n optionsFix.relTol = options.epsilon\n optionsFix.absTol = options.epsilon * 1e-3\n delete optionsFix.epsilon\n return _config(optionsFix)\n }\n const prev = clone(config)\n\n // validate some of the options\n validateOption(options, 'matrix', MATRIX_OPTIONS)\n validateOption(options, 'number', NUMBER_OPTIONS)\n\n // merge options\n deepExtend(config, options)\n\n const curr = clone(config)\n\n const changes = clone(options)\n\n // emit 'config' event\n emit('config', curr, prev, changes)\n\n return curr\n } else {\n return clone(config)\n }\n }\n\n // attach the valid options to the function so they can be extended\n _config.MATRIX_OPTIONS = MATRIX_OPTIONS\n _config.NUMBER_OPTIONS = NUMBER_OPTIONS\n\n // attach the config properties as readonly properties to the config function\n Object.keys(DEFAULT_CONFIG).forEach(key => {\n Object.defineProperty(_config, key, {\n get: () => config[key],\n enumerable: true,\n configurable: true\n })\n })\n\n return _config\n}\n\n/**\n * Validate an option\n * @param {Object} options Object with options\n * @param {string} name Name of the option to validate\n * @param {Array.} values Array with valid values for this option\n */\nfunction validateOption (options, name, values) {\n if (options[name] !== undefined && !values.includes(options[name])) {\n // unknown value\n console.warn('Warning: Unknown value \"' + options[name] + '\" for configuration option \"' + name + '\". ' +\n 'Available options: ' + values.map(value => JSON.stringify(value)).join(', ') + '.')\n }\n}\n","import * as all from './factoriesAny.js'\nimport { create } from './core/create.js'\n\nexport default create(all)\n","import typedFunction from 'typed-function'\nimport { ArgumentsError } from '../error/ArgumentsError.js'\nimport { DimensionError } from '../error/DimensionError.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { factory, isFactory } from '../utils/factory.js'\nimport {\n isAccessorNode,\n isArray,\n isArrayNode,\n isAssignmentNode,\n isBigInt,\n isBigNumber,\n isBlockNode,\n isBoolean,\n isChain,\n isCollection,\n isComplex,\n isConditionalNode,\n isConstantNode,\n isDate,\n isDenseMatrix,\n isFraction,\n isFunction,\n isFunctionAssignmentNode,\n isFunctionNode,\n isHelp,\n isIndex,\n isIndexNode,\n isMap,\n isMatrix,\n isNode,\n isNull,\n isNumber,\n isObject,\n isObjectNode,\n isObjectWrappingMap,\n isOperatorNode,\n isParenthesisNode,\n isPartitionedMap,\n isRange,\n isRangeNode,\n isRegExp,\n isRelationalNode,\n isResultSet,\n isSparseMatrix,\n isString,\n isSymbolNode,\n isUndefined,\n isUnit\n} from '../utils/is.js'\nimport { deepFlatten, isLegacyFactory } from '../utils/object.js'\nimport * as emitter from './../utils/emitter.js'\nimport { DEFAULT_CONFIG } from './config.js'\nimport { configFactory } from './function/config.js'\nimport { importFactory } from './function/import.js'\n\n/**\n * Create a mathjs instance from given factory functions and optionally config\n *\n * Usage:\n *\n * const mathjs1 = create({ createAdd, createMultiply, ...})\n * const config = { number: 'BigNumber' }\n * const mathjs2 = create(all, config)\n *\n * @param {Object} [factories] An object with factory functions\n * The object can contain nested objects,\n * all nested objects will be flattened.\n * @param {Object} [config] Available options:\n * {number} relTol\n * Minimum relative difference between two\n * compared values, used by all comparison functions.\n * {number} absTol\n * Minimum absolute difference between two\n * compared values, used by all comparison functions.\n * {string} matrix\n * A string 'Matrix' (default) or 'Array'.\n * {string} number\n * A string 'number' (default), 'BigNumber', or 'Fraction'\n * {number} precision\n * The number of significant digits for BigNumbers.\n * Not applicable for Numbers.\n * {boolean} predictable\n * Predictable output type of functions. When true,\n * output type depends only on the input types. When\n * false (default), output type can vary depending\n * on input values. For example `math.sqrt(-4)`\n * returns `complex('2i')` when predictable is false, and\n * returns `NaN` when true.\n * {string} randomSeed\n * Random seed for seeded pseudo random number generator.\n * Set to null to randomly seed.\n * @returns {Object} Returns a bare-bone math.js instance containing\n * functions:\n * - `import` to add new functions\n * - `config` to change configuration\n * - `on`, `off`, `once`, `emit` for events\n */\nexport function create (factories, config) {\n const configInternal = Object.assign({}, DEFAULT_CONFIG, config)\n\n // simple test for ES5 support\n if (typeof Object.create !== 'function') {\n throw new Error('ES5 not supported by this JavaScript engine. ' +\n 'Please load the es5-shim and es5-sham library for compatibility.')\n }\n\n // create the mathjs instance\n const math = emitter.mixin({\n // only here for backward compatibility for legacy factory functions\n isNumber,\n isComplex,\n isBigNumber,\n isBigInt,\n isFraction,\n isUnit,\n isString,\n isArray,\n isMatrix,\n isCollection,\n isDenseMatrix,\n isSparseMatrix,\n isRange,\n isIndex,\n isBoolean,\n isResultSet,\n isHelp,\n isFunction,\n isDate,\n isRegExp,\n isObject,\n isMap,\n isPartitionedMap,\n isObjectWrappingMap,\n isNull,\n isUndefined,\n\n isAccessorNode,\n isArrayNode,\n isAssignmentNode,\n isBlockNode,\n isConditionalNode,\n isConstantNode,\n isFunctionAssignmentNode,\n isFunctionNode,\n isIndexNode,\n isNode,\n isObjectNode,\n isOperatorNode,\n isParenthesisNode,\n isRangeNode,\n isRelationalNode,\n isSymbolNode,\n\n isChain\n })\n\n // load config function and apply provided config\n math.config = configFactory(configInternal, math.emit)\n\n math.expression = {\n transform: {},\n mathWithTransform: {\n config: math.config\n }\n }\n\n // cached factories and instances used by function load\n const legacyFactories = []\n const legacyInstances = []\n\n /**\n * Load a function or data type from a factory.\n * If the function or data type already exists, the existing instance is\n * returned.\n * @param {Function} factory\n * @returns {*}\n */\n function load (factory) {\n if (isFactory(factory)) {\n return factory(math)\n }\n\n const firstProperty = factory[Object.keys(factory)[0]]\n if (isFactory(firstProperty)) {\n return firstProperty(math)\n }\n\n if (!isLegacyFactory(factory)) {\n console.warn('Factory object with properties `type`, `name`, and `factory` expected', factory)\n throw new Error('Factory object with properties `type`, `name`, and `factory` expected')\n }\n\n const index = legacyFactories.indexOf(factory)\n let instance\n if (index === -1) {\n // doesn't yet exist\n if (factory.math === true) {\n // pass with math namespace\n instance = factory.factory(math.type, configInternal, load, math.typed, math)\n } else {\n instance = factory.factory(math.type, configInternal, load, math.typed)\n }\n\n // append to the cache\n legacyFactories.push(factory)\n legacyInstances.push(instance)\n } else {\n // already existing function, return the cached instance\n instance = legacyInstances[index]\n }\n\n return instance\n }\n\n const importedFactories = {}\n\n // load the import function\n function lazyTyped (...args) {\n return math.typed.apply(math.typed, args)\n }\n lazyTyped.isTypedFunction = typedFunction.isTypedFunction\n\n const internalImport = importFactory(lazyTyped, load, math, importedFactories)\n math.import = internalImport\n\n // listen for changes in config, import all functions again when changed\n // TODO: move this listener into the import function?\n math.on('config', () => {\n Object.values(importedFactories).forEach(factory => {\n if (factory && factory.meta && factory.meta.recreateOnConfigChange) {\n // FIXME: only re-create when the current instance is the same as was initially created\n // FIXME: delete the functions/constants before importing them again?\n internalImport(factory, { override: true })\n }\n })\n })\n\n // the create function exposed on the mathjs instance is bound to\n // the factory functions passed before\n math.create = create.bind(null, factories)\n\n // export factory function\n math.factory = factory\n\n // import the factory functions like createAdd as an array instead of object,\n // else they will get a different naming (`createAdd` instead of `add`).\n math.import(Object.values(deepFlatten(factories)))\n\n math.ArgumentsError = ArgumentsError\n math.DimensionError = DimensionError\n math.IndexError = IndexError\n\n return math\n}\n","import Emitter from 'tiny-emitter'\n\n/**\n * Extend given object with emitter functions `on`, `off`, `once`, `emit`\n * @param {Object} obj\n * @return {Object} obj\n */\nexport function mixin (obj) {\n // create event emitter\n const emitter = new Emitter()\n\n // bind methods to obj (we don't want to expose the emitter.e Array...)\n obj.on = emitter.on.bind(emitter)\n obj.off = emitter.off.bind(emitter)\n obj.once = emitter.once.bind(emitter)\n obj.emit = emitter.emit.bind(emitter)\n\n return obj\n}\n","import { isBigNumber, isComplex, isFraction, isMatrix, isUnit } from '../../utils/is.js'\nimport { isFactory, stripOptionalNotation } from '../../utils/factory.js'\nimport { hasOwnProperty, lazy } from '../../utils/object.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\n\nexport function importFactory (typed, load, math, importedFactories) {\n /**\n * Import functions from an object or a module.\n *\n * This function is only available on a mathjs instance created using `create`.\n *\n * Syntax:\n *\n * math.import(functions)\n * math.import(functions, options)\n *\n * Where:\n *\n * - `functions: Object`\n * An object with functions or factories to be imported.\n * - `options: Object` An object with import options. Available options:\n * - `override: boolean`\n * If true, existing functions will be overwritten. False by default.\n * - `silent: boolean`\n * If true, the function will not throw errors on duplicates or invalid\n * types. False by default.\n * - `wrap: boolean`\n * If true, the functions will be wrapped in a wrapper function\n * which converts data types like Matrix to primitive data types like Array.\n * The wrapper is needed when extending math.js with libraries which do not\n * support these data type. False by default.\n *\n * Examples:\n *\n * import { create, all } from 'mathjs'\n * import * as numbers from 'numbers'\n *\n * // create a mathjs instance\n * const math = create(all)\n *\n * // define new functions and variables\n * math.import({\n * myvalue: 42,\n * hello: function (name) {\n * return 'hello, ' + name + '!'\n * }\n * })\n *\n * // use the imported function and variable\n * math.myvalue * 2 // 84\n * math.hello('user') // 'hello, user!'\n *\n * // import the npm module 'numbers'\n * // (must be installed first with `npm install numbers`)\n * math.import(numbers, {wrap: true})\n *\n * math.fibonacci(7) // returns 13\n *\n * @param {Object | Array} functions Object with functions to be imported.\n * @param {Object} [options] Import options.\n */\n function mathImport (functions, options) {\n const num = arguments.length\n if (num !== 1 && num !== 2) {\n throw new ArgumentsError('import', num, 1, 2)\n }\n\n if (!options) {\n options = {}\n }\n\n function flattenImports (flatValues, value, name) {\n if (Array.isArray(value)) {\n value.forEach(item => flattenImports(flatValues, item))\n } else if (typeof value === 'object') {\n for (const name in value) {\n if (hasOwnProperty(value, name)) {\n flattenImports(flatValues, value[name], name)\n }\n }\n } else if (isFactory(value) || name !== undefined) {\n const flatName = isFactory(value)\n ? isTransformFunctionFactory(value)\n ? (value.fn + '.transform') // TODO: this is ugly\n : value.fn\n : name\n\n // we allow importing the same function twice if it points to the same implementation\n if (hasOwnProperty(flatValues, flatName) && flatValues[flatName] !== value && !options.silent) {\n throw new Error('Cannot import \"' + flatName + '\" twice')\n }\n\n flatValues[flatName] = value\n } else {\n if (!options.silent) {\n throw new TypeError('Factory, Object, or Array expected')\n }\n }\n }\n\n const flatValues = {}\n flattenImports(flatValues, functions)\n\n for (const name in flatValues) {\n if (hasOwnProperty(flatValues, name)) {\n // console.log('import', name)\n const value = flatValues[name]\n\n if (isFactory(value)) {\n // we ignore name here and enforce the name of the factory\n // maybe at some point we do want to allow overriding it\n // in that case we can implement an option overrideFactoryNames: true\n _importFactory(value, options)\n } else if (isSupportedType(value)) {\n _import(name, value, options)\n } else {\n if (!options.silent) {\n throw new TypeError('Factory, Object, or Array expected')\n }\n }\n }\n }\n }\n\n /**\n * Add a property to the math namespace\n * @param {string} name\n * @param {*} value\n * @param {Object} options See import for a description of the options\n * @private\n */\n function _import (name, value, options) {\n // TODO: refactor this function, it's to complicated and contains duplicate code\n if (options.wrap && typeof value === 'function') {\n // create a wrapper around the function\n value = _wrap(value)\n }\n\n // turn a plain function with a typed-function signature into a typed-function\n if (hasTypedFunctionSignature(value)) {\n value = typed(name, {\n [value.signature]: value\n })\n }\n\n if (typed.isTypedFunction(math[name]) && typed.isTypedFunction(value)) {\n if (options.override) {\n // give the typed function the right name\n value = typed(name, value.signatures)\n } else {\n // merge the existing and typed function\n value = typed(math[name], value)\n }\n\n math[name] = value\n delete importedFactories[name]\n\n _importTransform(name, value)\n math.emit('import', name, function resolver () {\n return value\n })\n return\n }\n\n if (math[name] === undefined || options.override) {\n math[name] = value\n delete importedFactories[name]\n\n _importTransform(name, value)\n math.emit('import', name, function resolver () {\n return value\n })\n return\n }\n\n if (!options.silent) {\n throw new Error('Cannot import \"' + name + '\": already exists')\n }\n }\n\n function _importTransform (name, value) {\n if (value && typeof value.transform === 'function') {\n math.expression.transform[name] = value.transform\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = value.transform\n }\n } else {\n // remove existing transform\n delete math.expression.transform[name]\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = value\n }\n }\n }\n\n function _deleteTransform (name) {\n delete math.expression.transform[name]\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = math[name]\n } else {\n delete math.expression.mathWithTransform[name]\n }\n }\n\n /**\n * Create a wrapper a round an function which converts the arguments\n * to their primitive values (like convert a Matrix to Array)\n * @param {Function} fn\n * @return {Function} Returns the wrapped function\n * @private\n */\n function _wrap (fn) {\n const wrapper = function wrapper () {\n const args = []\n for (let i = 0, len = arguments.length; i < len; i++) {\n const arg = arguments[i]\n args[i] = arg && arg.valueOf()\n }\n return fn.apply(math, args)\n }\n\n if (fn.transform) {\n wrapper.transform = fn.transform\n }\n\n return wrapper\n }\n\n /**\n * Import an instance of a factory into math.js\n * @param {function(scope: object)} factory\n * @param {Object} options See import for a description of the options\n * @param {string} [name=factory.name] Optional custom name\n * @private\n */\n function _importFactory (factory, options, name = factory.fn) {\n if (name.includes('.')) {\n throw new Error('Factory name should not contain a nested path. ' +\n 'Name: ' + JSON.stringify(name))\n }\n\n const namespace = isTransformFunctionFactory(factory)\n ? math.expression.transform\n : math\n\n const existingTransform = name in math.expression.transform\n const existing = hasOwnProperty(namespace, name) ? namespace[name] : undefined\n\n const resolver = function () {\n // collect all dependencies, handle finding both functions and classes and other special cases\n const dependencies = {}\n factory.dependencies\n .map(stripOptionalNotation)\n .forEach(dependency => {\n if (dependency.includes('.')) {\n throw new Error('Factory dependency should not contain a nested path. ' +\n 'Name: ' + JSON.stringify(dependency))\n }\n\n if (dependency === 'math') {\n dependencies.math = math\n } else if (dependency === 'mathWithTransform') {\n dependencies.mathWithTransform = math.expression.mathWithTransform\n } else if (dependency === 'classes') { // special case for json reviver\n dependencies.classes = math\n } else {\n dependencies[dependency] = math[dependency]\n }\n })\n\n const instance = /* #__PURE__ */ factory(dependencies)\n\n if (instance && typeof instance.transform === 'function') {\n throw new Error('Transforms cannot be attached to factory functions. ' +\n 'Please create a separate function for it with export const path = \"expression.transform\"')\n }\n\n if (existing === undefined || options.override) {\n return instance\n }\n\n if (typed.isTypedFunction(existing) && typed.isTypedFunction(instance)) {\n // merge the existing and new typed function\n return typed(existing, instance)\n }\n\n if (options.silent) {\n // keep existing, ignore imported function\n return existing\n } else {\n throw new Error('Cannot import \"' + name + '\": already exists')\n }\n }\n\n // TODO: add unit test with non-lazy factory\n if (!factory.meta || factory.meta.lazy !== false) {\n lazy(namespace, name, resolver)\n\n // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two)\n if (existing && existingTransform) {\n _deleteTransform(name)\n } else {\n if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n lazy(math.expression.mathWithTransform, name, () => namespace[name])\n }\n }\n } else {\n namespace[name] = resolver()\n\n // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two)\n if (existing && existingTransform) {\n _deleteTransform(name)\n } else {\n if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n lazy(math.expression.mathWithTransform, name, () => namespace[name])\n }\n }\n }\n\n // TODO: improve factories, store a list with imports instead which can be re-played\n importedFactories[name] = factory\n\n math.emit('import', name, resolver)\n }\n\n /**\n * Check whether given object is a type which can be imported\n * @param {Function | number | string | boolean | null | Unit | Complex} object\n * @return {boolean}\n * @private\n */\n function isSupportedType (object) {\n return typeof object === 'function' ||\n typeof object === 'number' ||\n typeof object === 'string' ||\n typeof object === 'boolean' ||\n object === null ||\n isUnit(object) ||\n isComplex(object) ||\n isBigNumber(object) ||\n isFraction(object) ||\n isMatrix(object) ||\n Array.isArray(object)\n }\n\n function hasTypedFunctionSignature (fn) {\n return typeof fn === 'function' && typeof fn.signature === 'string'\n }\n\n function allowedInExpressions (name) {\n return !hasOwnProperty(unsafe, name)\n }\n\n function factoryAllowedInExpressions (factory) {\n return !factory.fn.includes('.') && // FIXME: make checking on path redundant, check on meta data instead\n !hasOwnProperty(unsafe, factory.fn) &&\n (!factory.meta || !factory.meta.isClass)\n }\n\n function isTransformFunctionFactory (factory) {\n return (factory !== undefined &&\n factory.meta !== undefined &&\n factory.meta.isTransformFunction === true) || false\n }\n\n // namespaces and functions not available in the parser for safety reasons\n const unsafe = {\n expression: true,\n type: true,\n docs: true,\n error: true,\n json: true,\n chain: true // chain method not supported. Note that there is a unit chain too.\n }\n\n return mathImport\n}\n"],"names":["root","factory","exports","module","define","amd","this","cosh","Math","x","abs","exp","sinh","parser_exit","SyntaxError","logHypot","a","b","_a","_b","log","LN2","Complex","z","undefined","Number","isFinite","cos","sin","length","tokens","match","plus","minus","i","c","isNaN","parseFloat","parse","prototype","t","d","pow","arg","atan2","loh","re","im","r","sqrt","tmp","expm1","PI","xx","cosm1","y","t1","t2","Infinity","atan","acos","asin","res","noIM","oneMinus","onePlus","temp","atanh","asinh","acosh","places","ceil","floor","round","ret","E","NaN","_extends","Object","assign","target","arguments","source","key","hasOwnProperty","call","defaultEscapes","$","_","formatEscapes","defaultEscapeMapFn","str","_ref","_ref$preserveFormatti","preserveFormatting","_ref$escapeMapFn","escapeMapFn","runningStr","String","result","escapes","escapeKeys","keys","_loop","specialCharFound","forEach","index","slice","naturalSort","oFxNcL","oFyNcL","sre","dre","hre","ore","s","insensitive","toLowerCase","replace","xN","split","yN","xD","parseInt","Date","yD","cLoc","numS","max","alea","xor128","xorwow","xorshift7","xor4096","tychei","sr","global","Alea","seed","n","me","mash","data","h","charCodeAt","next","s0","s1","s2","copy","f","impl","opts","xg","state","prng","int32","double","quick","XorGen","strseed","k","w","v","X","j","limit","init","push","pool","math","nodecrypto","width","startdenom","significance","overflow","mask","seedrandom","options","callback","shortseed","mixkey","flatten","entropy","tostring","out","randomBytes","Uint8Array","crypto","msCrypto","getRandomValues","e","browser","navigator","plugins","screen","autoseed","arc4","ARC4","g","S","pass","is_math_call","keylen","count","obj","depth","prop","typ","smear","stringseed","fromCharCode","apply","random","ex","self","on","name","ctx","fn","once","listener","off","emit","evtArr","len","evts","liveEvents","TinyEmitter","isCallable","tryToString","$TypeError","TypeError","argument","isConstructor","isPossiblePrototype","$String","wellKnownSymbol","create","defineProperty","UNSCOPABLES","ArrayPrototype","Array","configurable","value","charAt","unicode","isPrototypeOf","it","Prototype","isObject","toIndexedObject","toAbsoluteIndex","lengthOfArrayLike","createMethod","IS_INCLUDES","$this","el","fromIndex","O","includes","indexOf","fails","METHOD_NAME","method","aCallable","toObject","IndexedObject","REDUCE_EMPTY","IS_RIGHT","that","callbackfn","argumentsLength","memo","left","right","uncurryThis","arraySlice","sort","array","comparefn","element","middle","llength","rlength","lindex","rindex","ITERATOR","SAFE_CLOSING","called","iteratorWithReturn","done","from","error","exec","SKIP_CLOSING","ITERATION_SUPPORT","object","toString","stringSlice","TO_STRING_TAG_SUPPORT","classofRaw","TO_STRING_TAG","$Object","CORRECT_ARGUMENTS","tag","tryGet","callee","hasOwn","ownKeys","getOwnPropertyDescriptorModule","definePropertyModule","exceptions","getOwnPropertyDescriptor","DESCRIPTORS","createPropertyDescriptor","bitmap","enumerable","writable","makeBuiltIn","descriptor","get","getter","set","setter","defineGlobalProperty","simple","unsafe","nonConfigurable","nonWritable","globalThis","P","document","EXISTS","createElement","firefox","UA","test","userAgent","Pebble","ENVIRONMENT","version","process","Deno","versions","v8","webkit","classof","userAgentStartsWith","string","Bun","window","createNonEnumerableProperty","defineBuiltIn","copyConstructorProperties","isForced","targetProperty","sourceProperty","TARGET","GLOBAL","STATIC","stat","dontCallGetSet","forced","sham","regexpExec","SPECIES","RegExpPrototype","RegExp","KEY","FORCED","SHAM","SYMBOL","DELEGATES_TO_SYMBOL","DELEGATES_TO_EXEC","execCalled","constructor","flags","nativeRegExpMethod","methods","nativeMethod","regexp","arg2","forceStringMethod","$exec","NATIVE_BIND","FunctionPrototype","Function","Reflect","bind","getDescriptor","PROPER","CONFIGURABLE","uncurryThisWithBind","namespace","getMethod","isNullOrUndefined","Iterators","anObject","getIteratorMethod","usingIterator","iteratorMethod","isArray","replacer","rawLength","keysLength","V","func","SUBSTITUTION_SYMBOLS","SUBSTITUTION_SYMBOLS_NO_NAMED","matched","position","captures","namedCaptures","replacement","tailPos","m","symbols","ch","capture","check","console","getBuiltIn","propertyIsEnumerable","setPrototypeOf","dummy","Wrapper","NewTarget","NewTargetPrototype","store","functionToString","inspectSource","has","NATIVE_WEAK_MAP","shared","sharedKey","hiddenKeys","OBJECT_ALREADY_INITIALIZED","WeakMap","metadata","facade","STATE","enforce","getterFor","TYPE","type","documentAll","all","noop","construct","constructorRegExp","INCORRECT_TO_STRING","isConstructorModern","isConstructorLegacy","feature","detection","normalize","POLYFILL","NATIVE","MATCH","isRegExp","USE_SYMBOL_AS_UID","$Symbol","isArrayIteratorMethod","getIterator","iteratorClose","Result","stopped","ResultPrototype","iterable","unboundFunction","iterator","iterFn","step","AS_ENTRIES","IS_RECORD","IS_ITERATOR","INTERRUPTED","stop","condition","callFn","kind","innerResult","innerError","toLength","CONFIGURABLE_FUNCTION_NAME","InternalStateModule","enforceInternalState","getInternalState","join","CONFIGURABLE_LENGTH","TEMPLATE","arity","trunc","notify","toggle","node","promise","then","safeGetBuiltIn","macrotask","Queue","IS_IOS","IS_IOS_PEBBLE","IS_WEBOS_WEBKIT","IS_NODE","MutationObserver","WebKitMutationObserver","Promise","microtask","queue","flush","parent","domain","exit","head","enter","resolve","nextTick","createTextNode","observe","characterData","add","PromiseCapability","C","reject","$$resolve","$$reject","activeXDocument","definePropertiesModule","enumBugKeys","html","documentCreateElement","PROTOTYPE","SCRIPT","IE_PROTO","EmptyConstructor","scriptTag","content","LT","NullProtoObjectViaActiveX","write","close","parentWindow","NullProtoObject","ActiveXObject","iframeDocument","iframe","JS","style","display","appendChild","src","contentWindow","open","F","Properties","V8_PROTOTYPE_DEFINE_BUG","objectKeys","defineProperties","props","IE8_DOM_DEFINE","toPropertyKey","$defineProperty","$getOwnPropertyDescriptor","ENUMERABLE","WRITABLE","Attributes","current","propertyIsEnumerableModule","internalObjectKeys","concat","getOwnPropertyNames","getOwnPropertySymbols","names","$propertyIsEnumerable","NASHORN_BUG","uncurryThisAccessor","requireObjectCoercible","aPossiblePrototype","CORRECT_SETTER","proto","__proto__","input","pref","val","valueOf","getOwnPropertyNamesModule","getOwnPropertySymbolsModule","NativePromiseConstructor","IS_PURE","V8_VERSION","NativePromisePrototype","SUBCLASSING","NATIVE_PROMISE_REJECTION_EVENT","PromiseRejectionEvent","FORCED_PROMISE_CONSTRUCTOR","PROMISE_CONSTRUCTOR_SOURCE","GLOBAL_CORE_JS_PROMISE","FakePromise","CONSTRUCTOR","REJECTION_EVENT","newPromiseCapability","promiseCapability","checkCorrectnessOfIteration","Target","Source","tail","item","entry","R","re1","re2","regexpFlags","stickyHelpers","UNSUPPORTED_DOT_ALL","UNSUPPORTED_NCG","nativeReplace","nativeExec","patchedExec","UPDATES_LAST_INDEX_WRONG","lastIndex","UNSUPPORTED_Y","BROKEN_CARET","NPCG_INCLUDED","reCopy","group","raw","groups","sticky","charsAdded","strCopy","multiline","hasIndices","ignoreCase","dotAll","unicodeSets","regExpFlags","$RegExp","MISSED_STICKY","defineBuiltInAccessor","CONSTRUCTOR_NAME","Constructor","TAG","uid","SHARED","mode","copyright","license","aConstructor","defaultConstructor","toIntegerOrInfinity","CONVERT_TO_STRING","pos","first","second","size","codeAt","symbol","Symbol","$location","defer","channel","port","validateArgumentsLength","setImmediate","clear","clearImmediate","Dispatch","MessageChannel","counter","ONREADYSTATECHANGE","location","run","id","runner","eventListener","event","globalPostMessageDefer","postMessage","protocol","host","handler","args","now","port2","port1","onmessage","addEventListener","importScripts","removeChild","setTimeout","min","integer","number","isSymbol","ordinaryToPrimitive","TO_PRIMITIVE","exoticToPrim","toPrimitive","postfix","NATIVE_SYMBOL","passed","required","WellKnownSymbolsStore","createWellKnownSymbol","withoutSetter","$includes","addToUnscopables","$reduce","arrayMethodIsStrict","CHROME_VERSION","reduce","deletePropertyOrThrow","internalSort","FF","IE_OR_EDGE","V8","WEBKIT","nativeSort","FAILS_ON_UNDEFINED","FAILS_ON_NULL","STRICT_METHOD","STABLE_SORT","code","chr","itemsLength","items","arrayLength","getSortCompare","getReplacerFunction","$stringify","numberToString","tester","low","hi","WRONG_SYMBOLS_CONVERSION","ILL_FORMED_UNICODE","stringifyWithSymbolsFix","$replacer","fixIllFormed","offset","prev","stringify","space","iterate","createProperty","fromEntries","newPromiseCapabilityModule","perform","capability","$promiseResolve","values","remaining","alreadyCalled","real","onRejected","Internal","OwnPromiseCapability","nativeThen","setToStringTag","setSpecies","anInstance","speciesConstructor","task","hostReportErrors","PromiseConstructorDetection","PROMISE","NATIVE_PROMISE_SUBCLASSING","getInternalPromiseState","setInternalState","PromiseConstructor","PromisePrototype","newGenericPromiseCapability","DISPATCH_EVENT","createEvent","dispatchEvent","UNHANDLED_REJECTION","isThenable","callReaction","reaction","exited","ok","fail","rejection","onHandleUnhandled","isReject","notified","reactions","onUnhandled","reason","initEvent","isUnhandled","unwrap","internalReject","internalResolve","wrapper","executor","onFulfilled","PromiseWrapper","wrap","race","capabilityReject","promiseResolve","PromiseConstructorWrapper","CHECK_WRAPPER","inheritIfRequired","getRegExpFlags","proxyAccessor","NativeRegExp","stringIndexOf","IS_NCG","CORRECT_NEW","RegExpWrapper","pattern","rawFlags","handled","thisIsRegExp","patternIsRegExp","flagsAreUndefined","rawPattern","named","brackets","ncg","groupid","groupname","handleNCG","handleDotAll","fixRegExpWellKnownSymbolLogic","advanceStringIndex","getSubstitution","regExpExec","REPLACE","REPLACE_KEEPS_$0","REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE","maybeCallNative","UNSAFE_SUBSTITUTE","searchValue","replaceValue","rx","functionalReplace","fullUnicode","results","accumulatedResult","nextSourcePosition","replacerArgs","NativeSymbol","SymbolPrototype","description","EmptyStringDescriptionStore","SymbolWrapper","thisSymbolValue","symbolDescriptiveString","desc","notOk","undef","NOT_TYPED_FUNCTION","isPlainObject","_types","anyType","isAny","typeMap","typeList","nConversions","typed","createCount","findType","typeName","message","otherName","addTypes","types","beforeSpec","beforeIndex","newTypes","conversionsTo","affectedTypes","Map","findTypeNames","matches","filter","isTypedFunction","entity","findSignature","signature","exact","params","parseSignature","canonicalSignature","stringifyParams","signatures","_typedFunctionData","signatureMap","nParams","remainingSignatures","candidate","want","filteredSignatures","possibility","have","getParamAtIndex","restParam","hasAny","haveTypes","paramTypeSet","some","wtype","separator","map","p","parseParam","param","typeDefs","trim","paramName","typeIndex","conversion","conversionIndex","hasConversion","expandParam","matchingConversions","typeNames","knownTypes","Set","newMatch","availableConversions","newName","convertibleTypes","typeSet","rawSignature","rawParams","parsedParam","hasRestParam","last","compileTest","test0","test1","tests","compileTests","initial","varIndex","lastTest","testRestParam","getTypeSetAtIndex","isExactType","mergeExpectedParams","paramSet","createError","err","expected","_name","matchingSignatures","nextMatchingDefs","actualTypes","category","actual","lengths","maxLength","expectedLength","argTypes","getLowestTypeIndex","getLowestConversionIndex","compareParams","param1","param2","typeDiff","convDiff","compareSignatures","signature1","signature2","pars1","pars2","last1","last2","hasRest1","hasRest2","par","any1","conv1","any2","conv2","lengthCriterion","comparisons","tc","thisComparison","compileArgsPreprocessing","fnConvert","compiledConversions","compileArgConversion","fnPreprocess","conversion0","conversion1","conversions","convert","splitParams","_splitParams","paramsSoFar","resultingParams","exactTypes","arr","nextParam","conflicting","params1","params2","ii","typeSet1","typeSet2","overlap","len1","len2","restParam1","restParam2","collectResolutions","references","functionList","resolvedReferences","reference","resolution","resolveReferences","resolvedFunctions","isReferToSelf","referToSelf","isReferTo","makeReferTo","referTo","clearResolutions","isResolved","fill","leftUnresolved","nothingResolved","createTypedFunction","rawSignaturesMap","warnAgainstDeprecatedThis","signaturesMap","deprecatedThisRegex","validateDeprecatedThis","parsedParams","originalFunctions","preliminarySignatures","pp","functionIndex","conversionParams","sp","spName","every","theTypedFn","internalSignatureMap","ok0","ok1","ok2","ok3","ok4","ok5","allOk","test00","test10","test20","test30","test40","test50","test01","test11","test21","test31","test41","test51","implementation","fn0","fn1","fn2","fn3","fn4","fn5","len0","len3","len4","len5","iStart","iEnd","fns","generic","onMismatch","arg0","arg1","_onMismatch","start","end","objectOrFn","checkName","nameSoFar","Error","getObjectName","mergeSignatures","dest","sourceFunction","destFunction","saveTyped","_validateConversion","to","maybeName","allSignatures","thisName","theseSignatures","throwMismatchError","clearConversions","_findType","find","addType","beforeObjectTest","before","addConversion","override","existing","other","removeConversion","addConversions","existingConversion","findInArray","splice","tf","argList","sigs","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","loaded","__webpack_modules__","amdD","amdO","definition","o","toStringTag","nmd","paths","children","getSafeProperty","isSafeProperty","isSafeMethod","setSafeProperty","safeNativeProperties","getPrototypeOf","safeNativeMethods","toLocaleString","ObjectWrappingMap","wrappedObject","entries","mapIterator","delete","PartitionedMap","bKeys","createEmptyMap","createMap","mapOrObject","isMap","isNumber","isBigNumber","isDecimal","isBigInt","isComplex","isFraction","isUnit","isString","isMatrix","isCollection","isDenseMatrix","isSparseMatrix","isRange","isIndex","isBoolean","isResultSet","isHelp","isFunction","isDate","isPartitionedMap","isObjectWrappingMap","isNull","isUndefined","isAccessorNode","isNode","isArrayNode","isAssignmentNode","isBlockNode","isConditionalNode","isConstantNode","rule2Node","isOperatorNode","op","isFunctionAssignmentNode","isFunctionNode","isIndexNode","isObjectNode","isParenthesisNode","isRangeNode","isRelationalNode","isSymbolNode","isChain","typeOf","clone","mapObject","extend","deepExtend","deepStrictEqual","deepFlatten","nestedObject","flattenedObject","_deepFlatten","lazy","valueResolver","_value","_uninitialized","property","dependencies","meta","assertAndCreate","scope","deps","properties","pickShallow","stripOptionalNotation","dependency","isOptionalDependency","missingDependencies","assertDependencies","isFactory","isInteger","safeNumberType","numberStr","config","numberFallback","sign","log2","log10","LN10","log1p","cbrt","negate","formatNumberToBase","base","prefix","suffix","format","notation","precision","wordSize","normalizeFormatOptions","toFixed","toExponential","rounded","roundDigits","splitNumber","exponent","coefficients","newExp","missingZeros","expDiff","decimalIdx","decimals","decimalVal","toEngineering","lowerExp","_toNumberOrDefault","upperExp","zeros","dot","toPrecision","digits","toNumber","_toNumberOrThrow","splitValue","shift","unshift","pop","nearlyEqual","relTol","absTol","EPSILON","tanh","onError","defaultValue","_createTyped","typedFunction","createTyped","BigNumber","DenseMatrix","Fraction","throwNoBignumber","throwNoComplex","MAX_SAFE_INTEGER","throwNoFraction","BigInt","throwNoMatrix","matrix","usualError","sig","createResultSet","ResultSet","toJSON","mathjs","fromJSON","json","isClass","inexact","quadrant","EXP_LIMIT","MAX_DIGITS","NUMERALS","DEFAULTS","rounding","modulo","toExpNeg","toExpPos","minE","maxE","external","decimalError","invalidArgument","precisionLimitExceeded","cryptoUnavailable","mathfloor","mathpow","isBinary","isHex","isOctal","BASE","LOG_BASE","LN10_PRECISION","PI_PRECISION","digitsToString","ws","indexOfLastWord","getZeroString","checkInt32","checkRoundingDigits","rm","repeating","di","rd","convertBase","baseIn","baseOut","arrL","strL","reverse","absoluteValue","finalise","clampedTo","clamp","Ctor","gt","cmp","comparedTo","xdL","ydL","xd","yd","xs","ys","cosine","pr","sd","isZero","tinyPow","taylorSeries","times","cos2x","toLessThanHalfPi","neg","cubeRoot","rep","t3","t3plusx","divide","eq","decimalPlaces","dp","dividedBy","div","dividedToIntegerBy","divToInt","equals","greaterThan","greaterThanOrEqualTo","gte","hyperbolicCosine","one","cosh2_x","d8","hyperbolicSine","sinh2_x","d5","d16","d20","hyperbolicTangent","inverseCosine","halfPi","isNeg","getPi","inverseHyperbolicCosine","lte","ln","inverseHyperbolicSine","inverseHyperbolicTangent","wpr","xsd","inverseSine","inverseTangent","px","x2","isInt","isNegative","isPositive","isPos","lessThan","lt","lessThanOrEqualTo","logarithm","isBase10","denominator","inf","num","naturalLogarithm","getLn10","sub","xe","xLTy","getBase10Exponent","mod","q","naturalExponential","negated","carry","getPrecision","sine","sin2_x","squareRoot","tangent","tan","mul","rL","toBinary","toStringBinary","toDecimalPlaces","toDP","finiteToString","toFraction","maxD","d0","d1","d2","n0","n1","toHexadecimal","toHex","toNearest","toOctal","toPower","yn","intPow","toSignificantDigits","toSD","truncated","multiplyInteger","compare","aL","bL","subtract","logBase","more","prod","prodL","qd","rem","remL","rem0","xi","xL","yd0","yL","yz","isTruncated","roundUp","xdi","isExp","nonFiniteToString","zs","truncate","isOdd","maxOrMin","ltgt","guard","sum","c0","numerator","x1","parseDecimal","search","substring","parseOther","divisor","isFloat","Decimal","isHyperbolic","u","pi","useDefaults","defaults","ps","hypot","isDecimalInstance","Uint32Array","for","ROUND_UP","ROUND_DOWN","ROUND_CEIL","ROUND_FLOOR","ROUND_HALF_UP","ROUND_HALF_DOWN","ROUND_HALF_EVEN","ROUND_HALF_CEIL","ROUND_HALF_FLOOR","EUCLID","createBigNumberClass","curr","createComplexClass","toPolar","phi","strRe","strIm","epsilon","hasBase","InvalidParameter","newFraction","DivisionByZero","gcd","factorize","factors","p1","p2","M","A","B","D","N","NonIntegerParameter","eps","thisABS","cont","excludeWhole","whole","dec","cycLen","cycleLen","cycOff","rem1","rem2","modpow","cycleStart","createFractionClass","createRangeClass","Range","hasStart","hasEnd","hasStep","nums","diff","toArray","createMatrixClass","Matrix","storage","datatype","subset","resize","reshape","skipZeros","formatBigNumberToBase","big2","BigNumberCtor","endsWith","text","formatNumber","valueStr","formatBigNumber","looksLikeFraction","fraction","formatArray","syntax","_format","escaped","controlCharacters","escape","compareText","DimensionError","relation","stack","IndexError","arraySize","_validate","dim","dimNext","child","validate","validateIndexSourceSize","valueSize","_size","_sourceSize","sourceDim","validateIndex","isEmptyIndex","_dimensions","dimension","_data","_resize","elem","oldLen","newLen","minLen","sizes","flatArray","currentLength","newLength","product","processSizesWildcard","tmpArray2","tmpArray","sizeIndex","_reshape","processedSizes","wildCardIndex","squeeze","dims","_squeeze","unsqueeze","outer","_unsqueeze","flat","filterRegExp","identify","identifier","generalize","getArrayDataType","itemType","concatRecursive","concatDim","arrays","broadcastSizes","_len","_key","dimensions","sizeMax","checkBroadcastingRules","toSize","broadcastTo","Asize","broadcastedSize","paddedSize","arrayToStretch","sizeToStretch","dimToStretch","acc","recurse","optimizeCallback","firstIndex","firstValue","hasSingleSignature","numberOfArguments","testArgs","_findNumberOfArguments","fastCallback","_tryFunctionWithArgs","_len2","_key2","mappingFnName","callbackName","_err$data","argsDesc","_typeOf","JSON","_createCallbackError","RangeError","isDimensionError","isIndexError","createDenseMatrixClass","_datatype","preprocess","_getSubmatrix","range","_setSubmatrix","submatrix","dataIndex","subIndex","_fit","newSize","changed","createDenseMatrix","getDataType","isScalar","_get","iSize","sSize","_unused","_set","indexI","sizeArray","_forEach","rows","row","columns","col","diagonal","kSuper","kSub","ms","swapRows","_swapRows","vi","createClone","any","objectClone","_switch","mat","I","J","containsCollections","deepForEach","deepMap","_reduce","tran","scatter","mark","cindex","inverse","update","avalues","_values","aindex","_index","aptr","_ptr","k0","k1","createIsInteger","isIntegerNumber","bigint","isNegativeNumber","isPositiveNumber","isNaNNumber","createIsNegative","bigNearlyEqual","Unit","valueType","createIsNumeric","number | BigNumber | bigint | Fraction | boolean","Complex | Unit | string | null | undefined | Node","createHasNumericValue","isNumeric","boolean","createIsPositive","createIsZero","equalScalar","createIsNaN","createTypeOf","createCompareUnits","equalBase","createEqualScalar","compareUnits","complexEquals","createSparseMatrixClass","_ref2","SparseMatrix","_createFromArray","_createFromMatrix","ptr","zero","_getValueIndex","top","bottom","_insert","ins","_toArray","createSparseMatrix","density","idx","kk","mvalues","mindex","mptr","pv","_getsubset","firstDimensionRange","secondDimensionRange","firstDataIndex","firstSubIndex","secondDataIndex","secondSubIndex","_setsubset","_remove","colIndex","rowIndex","r1","c1","minRow","maxRow","minColumn","maxColumn","invoke","_map","_forEachRow","kx","ky","vx","vy","createNumber","nonDecimalNumberParts","nonDecimalWithRadixMatch","radix","integerPart","fractionalPart","getNonDecimalNumberParts","parts","makeNumberFromNonDecimalParts","wordSizeSuffixMatch","null","unit","valuelessUnit","createBigint","createString","createBoolean","lcase","createBignumber","twoPowSize","twoPowSizeSubOne","createComplex","ZERO","createFraction","createMatrix","_create","createMatrixFromFunction","createMatrixFromRows","_createArray","checkVectorTypeAndReturnLength","rowLength","vec","createMatrixFromColumns","colLength","createSplitUnit","splitUnit","n2","absNumber","addNumber","subtractNumber","multiplyNumber","unaryMinusNumber","unaryPlusNumber","cbrtNumber","cubeNumber","expNumber","expm1Number","lcmNumber","log10Number","log2Number","nthRootNumber","inv","signNumber","squareNumber","xgcdNumber","lastx","lasty","powNumber","roundNumber","createUnaryMinus","createUnaryPlus","numeric","createAbs","createApply","_apply","createAddScalar","fixPrefix","createSubtractScalar","createCbrt","unaryMinus","_cbrtComplex","third","allRoots","arg3","principal","createMatAlgo11xS0s","asize","adt","dt","cf","cvalues","cptr","createMatAlgo12xSfs","cdata","createMatAlgo14xDs","adata","_iterate","level","av","bv","cv","createCeilNumber","createCeil","matAlgo11xS0s","matAlgo12xSfs","matAlgo14xDs","ceilNumber","createCube","createExp","createExpm1","createFixNumber","createFix","fixNumber","bn","createFloorNumber","createFloor","floorNumber","createMatAlgo02xDS0","denseMatrix","sparseMatrix","bvalues","bindex","bptr","bsize","bdt","cij","createMatAlgo03xDSf","createMatAlgo05xSfSf","xa","xb","wa","wb","wai","wbi","vc","createMatAlgo13xDD","bdata","csize","broadcast","_broadcastTo","createMatrixAlgorithmSuite","matAlgo13xDD","elop","SD","DS","matrixSignatures","DenseMatrix, DenseMatrix","Array, Array","Array, DenseMatrix","DenseMatrix, Array","SS","scalar","Ds","Ss","sS","createMod","matAlgo02xDS0","matAlgo03xDSf","matAlgo05xSfSf","matrixAlgorithmSuite","createMatAlgo01xDSid","createMatAlgo04xSidSid","createMatAlgo10xSids","ArgumentsError","isArgumentsError","gcdTypes","gcdManyTypesSignature","is1d","createGcd","matAlgo01xDSid","matAlgo04xSidSid","matAlgo10xSids","Fraction, Fraction","createMatAlgo06xS0S0","createLcm","matAlgo06xS0S0","lcmTypes","lcmManySignature","lcm","createLog10","predictable","createLog2","_log2Complex","newX","createMultiplyScalar","number | Fraction | BigNumber | Complex, Unit","multiply","Unit, number | Fraction | BigNumber | Complex | Unit","createMultiply","addScalar","multiplyScalar","_validateMatrixDimensions","size1","size2","_multiplyMatrixVector","arows","acolumns","af","mf","brows","ib","vbi","ka0","ka1","ka","ia","ic","_multiplyMatrixMatrix","bcolumns","jb","kb0","kb1","kb","vbij","p0","selfMM","xsize","ysize","_multiplyVectorVector","alength","_multiplyVectorDenseMatrix","_multiplyVectorMatrix","rest","createNthRoot","complexErr","_bigNthRoot","selfDn","selfSn","selfDS","Big","createSign","complex","_isDerived","units","createSqrt","_sqrtNumber","createSquare","createSubtract","subtractScalar","createXgcd","createInvmod","xgcd","equal","smaller","invmod","createMatAlgo09xS0Sf","vb","createDotMultiply","matAlgo09xS0Sf","bitAndBigNumber","bitwise","bitNotBigNumber","prevPrec","bitOrBigNumber","negOne","xBits","yBits","xSign","ySign","decCoefficientToBinaryString","minBits","maxBits","minSign","shortLen","longLen","expFuncVal","outVal","twoPower","two","bitXor","leftShiftBigNumber","rightArithShiftBigNumber","bitAndNumber","bitNotNumber","bitOrNumber","bitXorNumber","leftShiftNumber","rightArithShiftNumber","rightLogShiftNumber","createBitAnd","bigint, bigint","createBitNot","createBitOr","createMatAlgo07xSSf","_scatter","va","createBitXor","matAlgo07xSSf","bigBitXor","createArg","createConj","conjugate","createIm","createRe","notNumber","orNumber","xorNumber","andNumber","createNot","null | undefined","createOr","createXor","createConcat","prevDim","asMatrix","matrices","_concat","createColumn","Index","_column","column","rowRange","createCross","_cross","highestDimension","xSize","ySize","createDiag","_diag","l","_createDiagonalMatrix","dm","vector","_getDiagonal","createFilter","_filterCallback","createFlatten","flattenArray","createForEach","createGetMatrixDataType","createIdentity","_identity","cols","_identityVector","minimum","createKron","_kron","_mapArray","Array|Matrix, Array|Matrix, ...Array|Matrix|function","Arrays","multiCallback","firstArrayIsMatrix","broadcastedArrays","firstValues","callbackCase","_getTypedCallbackCase","_getLimitedCallback","numberOfArrays","_getCallbackCase","broadcastedArraysCallback","_mapMultiple","createDiff","_diff","_recursive","selfAn","selfMn","_ElementDiff","obj1","obj2","obj1IsArray","obj2IsArray","arr1","arr2","_ArrayDiff","createOnes","_ones","hasBigNumbers","_normalize","noBignumber","noFraction","noMatrix","createRange","bignumber","smallerEq","larger","largerEq","_strRange","_out","_range","includeEnd","_parse","ongoing","createReshape","arrayReshape","createResize","defaultChar","_resizeString","arrayResize","createRotate","rotationMatrix","theta","_validateSize","expectedSize","actualSize","createRotationMatrix","norm","_rotationMatrix2x2","matrixV","_validateVector","_rotationMatrix3x3","storageType","minusOne","cosTheta","sinTheta","_convertToFormat","_mul","normV","vz","oneMinusC","createRow","_row","columnRange","createSize","createSqueeze","arraySqueeze","createSubset","subsetRef","subsetResult","_getObjectProperty","_getSubstring","_isScalar","indexSize","_broadcastReplacement","_setSubstring","_setObjectProperty","strLen","substr","chars","updated","createTranspose","transposeMatrix","transposed","transposedRow","_denseTranspose","_sparseTranspose","createCtranspose","transpose","conj","createZeros","_zeros","createFft","divideScalar","tau","dotDivide","_ndFft","_fft","_1dFft","_transpose","chirp","N2","xp","ichirp","fftXp","fftIchirp","fftProduct","ifftProduct","_czt","createIfft","fft","createSolveODE","_rk","butcherTableau","tspan","y0","isNumOrBig","t0","isForwards","firstStep","maxStep","minStep","timeVars","tol","minDelta","maxDelta","maxIter","bp","deltaB","iter","_createOngoing","trimStep","outOfBounds","_createTrimStep","TE","delta","_rk23","_rk45","_solveODE","opt","RK23","RK45","toUpperCase","methodOptions","methodsWithQuotes","availableMethodsString","_matrixSolveODE","T","sol","function, Array, Array","function, Matrix, Matrix","function, Array, number | BigNumber | Unit","Y","function, Matrix, number | BigNumber | Unit","function, Array, number | BigNumber | Unit, Object","function, Matrix, number | BigNumber | Unit, Object","createErf","MAX_NUM","THRESH","ysq","xnum","xden","Q","erf1","del","erfc2","SQRPI","erfc3","createZeta","factorial","gamma","zetaNumeric","zeta","createValue","determineDigits","getRe","factor","createMode","_mode","improveErrorMessage","fnName","details","createProd","_prod","createFormat","formatString","createBin","createOct","createHex","printTemplate","createPrint","_print","template","original","createTo","Unit, Unit | string","createIsPrime","modPow","modulus","accumulator","bases","adn","createNumeric","validInputTypes","validOutputTypes","outputType","inputType","createDivideScalar","Unit, number | Complex | Fraction | BigNumber | Unit","number | Fraction | Complex | BigNumber, Unit","divideInto","createPow","identity","_pow","_powArray","_powMatrix","yFrac","yNum","NO_INT","createRound","toExponent","xEpsilon","epsilonExponent","_n","valueless","toNumeric","createLog","logNumber","createLog1p","_log1p","_log1pComplex","xRe1p","createNthRoots","_calculateExactResult","_nthComplexRoots","aIsNumeric","roots","halfPiFactor","createDotPow","powScalarSignatures","powScalar","createDotDivide","createSolveValidation","mSize","bSize","createLsolve","solveValidation","bj","vjj","jValues","jIndices","xj","_sparseForwardSubstitution","_denseForwardSubstitution","mdata","createUsolve","_sparseBackwardSubstitution","_denseBackwardSubstitution","createLsolveAll","b_","L","iValues","iIndices","Mii","bNew","createUsolveAll","createMatAlgo08xS0Sid","createUseMatrixForArrayScalar","selfDB","selfnD","selfBD","createLeftShift","matAlgo08xS0Sid","useMatrixForArrayScalar","createRightArithShift","createRightLogShift","createAnd","not","createCompare","createCompareNumber","createCompareNatural","compareBooleans","_compareNatural","typeX","typeY","matTypes","compareMatricesAndArrays","compareComplexNumbers","compareArrays","formatUnits","compareNatural","keysX","keysY","compareObjects","_compareText","createCompareText","createEqual","createEqualNumber","createEqualText","createSmaller","createSmallerNumber","boolean, boolean","createSmallerEq","createSmallerEqNumber","createLarger","createLargerNumber","createLargerEq","createLargerEqNumber","createDeepEqual","_deepEqual","createUnequal","createUnequalNumber","createPartitionSelect","asc","_partitionSelect","quickSelect","pivot","createSort","compareAsc","compareDesc","_arrayIsVector","_matrixIsVector","_comparator","order","createMax","_max","_largest","createMin","_min","_smallest","createImmutableDenseMatrixClass","ImmutableDenseMatrix","isImmutableDenseMatrix","createIndexClass","getMatrixDataType","ranges","argIsArray","argIsMatrix","sourceSize","_createImmutableMatrix","_booleansArrayToNumbersForIndex","isObjectProperty","getObjectProperty","strings","booleanArrayIndex","indexOfNumbers","bool","createFibonacciHeapClass","oneOverLogPhi","FibonacciHeap","_minimum","_cut","degree","_cascadingCut","isFibonacciHeap","insert","isEmpty","extractMinimum","numberOfChildren","tempRight","numRoots","_linkNodes","_findMinimumNode","remove","_decreaseKey","createSpaClass","Spa","_heap","isSpa","accumulate","heap","nodes","swap","nodei","nodej","lruQueue","oldIndex","hit","nuIndex","memoize","hasher","POSITIVE_INFINITY","cache","lru","hash","newVal","createBigNumberE","createBigNumberPhi","createBigNumberPi","createBigNumberTau","createUnitClass","fix","skipAutomaticSimplification","BASE_DIMENSIONS","skipWhitespace","isDigit","revert","parseNumber","isDigitDot","tentativeNumber","tentativeIndex","parseUnit","unitName","isValidAlpha","firstC","parseCharacter","toFind","powerMultiplierCurrent","expectingUnit","powerMultiplierStack","powerMultiplierStackProduct","uStr","oldC","_findUnit","power","baseDim","UNIT_SYSTEMS","auto","allowNoUnits","_getNumberConverter","unitValue","unitPrefixValue","unitPower","_denormalize","prefixValue","UNITS","prefixes","prefixLen","prefixName","getNumericIfUnitless","BASE_UNITS","NONE","isValuelessUnit","_other","inverted","valThis","valOther","_numberConverter","nominalOffset","unitOffset","W","thisUnitValue","thisNominalOffset","thisUnitOffset","otherUnitValue","otherNominalOffset","otherUnitOffset","_json$unit","simplify","proposedUnitList","matchingBase","currentUnitSystem","matchingUnit","missingBaseDim","toSI","si","strNum","strDen","nNum","nDen","simp","isImaginary","VAR","VA","_bestPrefix","unitStr","absValue","absUnitValue","bestPrefix","bestDiff","scientific","xNumeric","xRounded","xFixed","testSum","PREFIXES","SHORT","da","G","Z","LONG","deca","hecto","kilo","mega","giga","tera","peta","exa","zetta","yotta","ronna","quetta","deci","centi","milli","micro","nano","pico","femto","atto","zepto","yocto","ronto","quecto","SQUARED","CUBIC","BINARY_SHORT_SI","BINARY_SHORT_IEC","Ki","Mi","Gi","Ti","Pi","Ei","Zi","Yi","BINARY_LONG_SI","BINARY_LONG_IEC","kibi","mebi","gibi","tebi","pebi","exi","zebi","yobi","BTU","MM","SHORTLONG","BINARY_SHORT","BINARY_LONG","MASS","LENGTH","TIME","CURRENT","TEMPERATURE","LUMINOUS_INTENSITY","AMOUNT_OF_SUBSTANCE","FORCE","SURFACE","VOLUME","ENERGY","POWER","PRESSURE","ELECTRIC_CHARGE","ELECTRIC_CAPACITANCE","ELECTRIC_POTENTIAL","ELECTRIC_RESISTANCE","ELECTRIC_INDUCTANCE","ELECTRIC_CONDUCTANCE","MAGNETIC_FLUX","MAGNETIC_FLUX_DENSITY","FREQUENCY","ANGLE","BIT","UNIT_NONE","meter","inch","foot","yard","mile","link","rod","chain","angstrom","in","ft","mi","li","mil","m2","sqin","sqft","sqyd","sqmi","sqrd","sqch","sqmil","acre","hectare","m3","litre","cuin","cuft","cuyd","teaspoon","tablespoon","drop","gtt","minim","fluiddram","fluidounce","gill","cc","cup","pint","quart","gallon","beerbarrel","oilbarrel","hogshead","gram","ton","tonne","grain","dram","ounce","poundmass","hundredweight","stick","stone","gr","dr","oz","lbm","cwt","sec","minute","hour","day","week","month","year","decade","century","millennium","hertz","reciprocal","Hz","rad","radian","deg","grad","gradian","cycle","arcsec","arcmin","ampere","K","degC","degF","degR","kelvin","celsius","fahrenheit","rankine","mol","mole","cd","candela","newton","dyn","dyne","lbf","poundforce","kip","kilogramforce","joule","erg","Wh","eV","electronvolt","watt","hp","Pa","psi","atm","bar","torr","mmHg","mmH2O","cmH2O","coulomb","farad","volt","ohm","henry","H","siemens","weber","Wb","tesla","bits","bytes","ALIASES","meters","inches","feet","yards","miles","links","rods","chains","angstroms","litres","liter","liters","teaspoons","tablespoons","minims","fldr","fluiddrams","floz","fluidounces","gi","gills","cp","cups","pt","pints","qt","quarts","gal","gallons","bbl","beerbarrels","obl","oilbarrels","hogsheads","gtts","grams","tons","tonnes","grains","drams","ounces","poundmasses","hundredweights","sticks","lb","lbs","kips","kgf","acres","hectares","sqfeet","sqyard","sqmile","sqmiles","mmhg","mmh2o","cmh2o","seconds","secs","minutes","mins","hours","hr","hrs","days","weeks","months","years","decades","centuries","millennia","radians","degrees","gradians","cycles","arcsecond","arcseconds","arcminute","arcminutes","BTUs","watts","joules","amperes","amps","amp","coulombs","volts","ohms","farads","webers","teslas","electronvolts","moles","bit","byte","calculateAngleValues","createPi","cgs","us","setUnitSystem","getUnitSystem","typeConverters","alias","createUnit","deleteUnit","aliases","lastUnit","createUnitSingle","assertUnitNameIsValid","baseName","defUnit","newUnit","anyMatch","newBaseUnit","aliasName","createUnitFunction","createSparse","createCreateUnit","def","createAcos","acoshNumber","acotNumber","acothNumber","acscNumber","acschNumber","xInv","asecNumber","asechNumber","asinhNumber","atanhNumber","cotNumber","cothNumber","cscNumber","cschNumber","secNumber","sechNumber","sinhNumber","createAcosh","createAcot","acot","createAcoth","acoth","createAcsc","acsc","createAcsch","acsch","createAsec","asec","createAsech","asech","createAsin","createAsinh","createAtan","createAtan2","BigNumber, BigNumber","createAtanh","createTrigUnit","createCos","trigUnit","createCosh","coshNumber","createCot","cot","createCoth","coth","createCsc","csc","createCsch","csch","createSec","createSech","sech","createSin","createSinh","createTan","createTanh","_tanh","createSetCartesian","a1","a2","b1","b2","createSetDifference","inb2","createSetDistinct","createSetIntersect","createSetIsSubset","createSetMultiplicity","createSetPowerset","_subset","_sort","bitarray","createSetSize","unique","createSetSymDifference","setDifference","createSetUnion","setIntersect","setSymDifference","createAdd","createHypot","_hypot","largest","createNorm","ctranspose","eigs","_norm","sizeX","pinf","_vectorNormPlusInfinity","NEGATIVE_INFINITY","ninf","_vectorNormMinusInfinity","_vectorNorm","maxc","cj","_matrixNormOne","maxr","ri","_matrixNormInfinity","fro","_matrixNormFrobenius","tx","squaredX","eigenVals","rho","_matrixNormTwo","_matrixNorm","createDot","_validateDim","aIsColumn","bIsColumn","xindex","xvalues","yindex","yvalues","xLen","yLen","createTrace","_denseTrace","createIndex","keywords","createNode","mathWithTransform","evaluate","compile","expr","_compile","_validateScope","argNames","_ifNode","traverse","_traverse","path","transform","_transform","cloneDeep","customString","_getCustomString","_toString","toHTML","_toHTML","toTex","_toTex","getIdentifier","getContent","_typeof","_defineProperty","errorTransform","accessFactory","createAccessorNode","Node","access","needParenthesis","AccessorNode","super","evalObject","evalIndex","context","createArrayNode","ArrayNode","evalItems","evalItem","itemsToTex","nested","mixedItems","itemsFormRow","itemSep","itemsTex","AssignmentNode","FunctionAssignmentNode","ConditionalNode","latexLeftParens","latexRightParens","latexParens","associativity","associativeWith","RelationalNode","RangeNode","unwrapParen","_node","parenthesis","getPrecedence","implicit","precedence","leftArg","getAssociativity","isAssociativeWith","nodeA","nodeB","identifierA","identifierB","createAssignmentNode","assignFactory","exprPrecedence","evalValue","childObject","evalParentObject","parentProp","evalParentIndex","parentIndex","createBlockNode","BlockNode","blocks","block","visible","evalBlocks","createConditionalNode","trueExpr","falseExpr","evalCondition","evalTrueExpr","evalFalseExpr","testCondition","conditionPrecedence","truePrecedence","falsePrecedence","latexSymbols","Alpha","alpha","Beta","beta","Gamma","Delta","Epsilon","varepsilon","Zeta","Eta","eta","Theta","vartheta","Iota","iota","Kappa","kappa","varkappa","Lambda","lambda","Mu","mu","Nu","nu","Xi","Omicron","omicron","varpi","Rho","varrho","Sigma","sigma","varsigma","Tau","Upsilon","upsilon","Phi","varphi","Chi","chi","Psi","Omega","omega","true","false","Inf","infinity","oo","lim","latexOperators","dotPow","unaryPlus","bitNot","dotMultiply","leftShift","rightArithShift","rightLogShift","unequal","bitAnd","bitOr","and","xor","or","latexFunctions","cube","nthRoot","nthRoots","square","bellNumbers","catalan","stirlingS2","cross","det","expm","pinv","sqrtm","trace","combinations","combinationsWithRep","lgamma","erf","variance","sparse","latexUnits","escapeLatex","escapeLatexLib","toSymbol","createConstantNode","ConstantNode","toLatex","createFunctionAssignmentNode","paramNames","childArgNames","evalExpr","childArgs","createIndexNode","IndexNode","dotNotation","evalDimensions","_evalDimension","evalDimension","createObjectNode","ObjectNode","evalEntries","stringifiedKey","parsedKey","createSubScope","parentScope","createOperatorNode","startsWithConstant","curNode","calculateNecessaryParentheses","latex","operandPrecedence","operandIdentifier","rootIdentifier","lhsParens","lhsPrecedence","assocWithLhs","rhsParens","rhsPrecedence","assocWithRhs","lhsIdentifier","rhsIdentifier","argPrecedence","assocWithArg","argAssociativity","OperatorNode","isPercentage","evalArgs","rawArgs","evalArg0","evalArg1","evalArg","isUnary","parens","assoc","operand","opIsNamed","lhs","rhs","stringifiedArgs","lhsTex","rhsTex","texifiedArgs","createParenthesisNode","ParenthesisNode","createRangeNode","startPrecedence","stepPrecedence","endPrecedence","needsEnd","evalStart","evalEnd","evalStep","createRelationalNode","operatorMap","conditionals","compiled","evalLhs","evalRhs","condFn","paramStrings","paramPrecedence","createSymbolNode","SymbolNode","onUndefinedSymbol","createFunctionNode","_FunctionNode","strin","expandTemplate","regex","inputPos","ReferenceError","FunctionNode","getSafeMethod","fnExpr","evalFn","isRaw","resolveFn","onUndefinedFunction","customTex","latexConverter","customToTex","createParse","expression","parseStart","expressions","parseMultiple","extraNodes","TOKENTYPE","NULL","DELIMITER","NUMBER","UNKNOWN","DELIMITERS","NAMED_DELIMITERS","CONSTANTS","NUMERIC_CONSTANTS","ESCAPE_CHARACTERS","currentString","currentCharacter","prevCharacter","nextCharacter","getToken","tokenType","token","comment","isWhitespace","nestingLevel","c2","c3","isHexDigit","isDecimalMark","createSyntaxError","isAlpha","getTokenSkipNewline","openParams","closeParams","conditionalLevel","parseAssignment","parseBlock","valid","parseLogicalXor","parseLogicalOr","parseConditional","parseLogicalAnd","parseBitwiseOr","parseBitwiseXor","parseBitwiseAnd","parseRelational","parseShift","operators","cond","parseConversion","parseRange","parseAddSubtract","parseMultiplyDivide","rightNode","parseImplicitMultiplication","parseRule2","parseModulusPercentage","tokenStates","parseUnary","CustomNode","parseAccessors","parseStringToken","parseRow","numericType","parseEnd","parseParentheses","parseObject","parseMatrix","parseString","parseSymbol","parseCustomNodes","parseLeftHandOperators","parsePow","quote","char","escapeChar","cPrev","cNext","isValidLatinOrGreek","isValidMathSymbol","high","createCompile","createEvaluate","createParserClass","Parser","isParser","getAll","getAllAsMap","createParser","createLup","_denseLUP","lvalues","lptr","lsize","uvalues","uindex","uptr","usize","pvCo","pvOc","swapIndeces","spa","vkj","vik","pabsv","absv","U","_sparseLUP","ldata","udata","vij","createQr","_denseQR","_sparseQR","_denseQRimpl","Qdata","Rdata","sgn","conjSgn","alphaSquared","u1","csTdfs","post","csFlip","createCsAmd","lemax","dense","cm","at","tindex","tptr","_createTargetMatrix","nz","csFkeep","cnz","nv","elen","hhead","k2","pj","nvi","pk","eln","pn","_wclear","_initializeQuotientGraph","nel","_initializeDegreeLists","mindeg","elenk","nvk","dk","pk1","pk2","wnvi","dext","p3","p4","nvj","jlast","csLeaf","maxfirst","prevleaf","ancestor","sparent","jleaf","jprev","createCsCounts","ata","colcount","createCsSqr","csAmd","csCounts","qr","csPermute","inext","csEtree","csPost","leftmost","nque","lnz","pa","_vcount","unz","csMarked","csMark","csUnflip","csDfs","jnew","createCsSpsolve","lo","gvalues","gindex","gptr","gsize","csReach","createCsLu","csSpsolve","ipiv","xabs","createSlu","csSqr","csLu","threshold","csIpvec","createLusolve","lup","slu","usolve","lsolve","_lusolve","_toMatrix","createPolynomialRoot","number|Complex, ...number|Complex","constant","restCoeffs","coeffs","denom","discriminant","D0_1","D0_2","D1_1","D1_2","Delta0","Delta1","discriminant1","discriminant2","Ccubed","createHelpClass","Help","doc","examples","configChanged","originalConfig","newConfig","mayThrow","seealso","createChainClass","Chain","createLazyProxy","resolver","chainify","sigObject","createProxy","excludedNames","docs","classes","eDocs","piDocs","embeddedDocs","LOG2E","LOG10E","SQRT1_2","SQRT2","speedOfLight","gravitationConstant","planckConstant","reducedPlanckConstant","magneticConstant","electricConstant","vacuumImpedance","elementaryCharge","bohrMagneton","conductanceQuantum","inverseConductanceQuantum","magneticFluxQuantum","nuclearMagneton","klitzing","bohrRadius","classicalElectronRadius","electronMass","fermiCoupling","fineStructure","hartreeEnergy","protonMass","deuteronMass","neutronMass","quantumOfCirculation","rydberg","thomsonCrossSection","weakMixingAngle","efimovFactor","atomicMass","avogadro","boltzmann","faraday","firstRadiation","loschmidt","gasConstant","molarPlanckConstant","molarVolume","sackurTetrode","secondRadiation","stefanBoltzmann","wienDisplacement","molarMass","molarMassC12","gravity","planckLength","planckMass","planckTime","planckCharge","planckTemperature","derivative","lsolveAll","lusolve","leafCount","polynomialRoot","simplifyConstant","simplifyCore","symbolicEqual","rationalize","usolveAll","composition","import","help","distance","intersect","diag","kron","matrixFromFunction","matrixFromRows","matrixFromColumns","ones","partitionSelect","rotate","ifft","sylvester","schur","lyap","solveODE","kldivergence","multinomial","permutations","pickRandom","randomInt","deepEqual","equalText","setCartesian","setDistinct","setIsSubset","setMultiplicity","setPowerset","setSize","setUnion","zpk2tf","freqz","cumsum","mad","mean","median","quantileSeq","std","corr","bin","oct","hex","hasNumericValue","isPrime","print","createHelp","searchName","searchText","createChain","createDet","rowIndices","k_","_k","piv","piv_","i_","_det","createInv","_inv","ABig","rBig","Ac","Bc","Ar","Br","createPinv","_isZeros","_pinv","rref","lead","_isZero","_rref","_rankFact","Cpinv","Fpinv","createEigs","doRealSymmetric","getTheta","aii","ajj","aij","getThetaBig","Sij1","Sij","Ski","Skj","Sij1Big","x1Big","Hij","Aki","Akj","csHij","Aii","Ajj","getAij","Mij","maxMij","maxIJ","getAijBig","sorting","computeVectors","vecs","minID","eigenvectors","prec","e0","Vab","diagBig","createRealSymmetric","doComplexEigs","eigenvalues2x2","trA","detA","jordanBase2x2","l1","l2","big","cplx","na","nd","inflateMatrix","inverseIterate","orthog","largeNum","randomOrthogonalVector","orthogonalComplement","vectorShape","findVectors","realzero","realone","radixSq","Rdiag","colNorm","rowNorm","rowDivRadix","rowMulRadix","balance","maxIndex","tmp1","tmp2","tmp3","reduceToHessenberg","lambdas","Sdiag","Qtotal","Qpartial","lastConvergenceBefore","ll","vectors","blockDiag","iterateUntilTriangular","Cinv","uniqueValues","multiplicities","solutions","approxVec","correction","findEigenvectors","createComplexEigs","doEigs","Array, Object","matricize","useOpts","_opts$precision","isReal","coerceReal","isSymmetric","coerceTypes","computeValuesAndVectors","hasNumber","hasBig","hasComplex","warn","createExpm","infNorm","rowSum","infinityNorm","errorEstimate","findParams","Apos","AposToI","alternate","qfac","twoqfac","twoqp1fac","createSqrtm","_tolerance","_denmanBeavers","iterations","Yk","createSylvester","_sylvester","sA","sB","hc","RHS","gkk","gmk","gkm","gmm","LHS","yAux","createSchur","_schur","A0","QR","createLyap","createDivide","createDistance","_2d","xCoeff","yCoeff","_distancePointLine2D","_objectToArray","lineTwoPtY","lineOnePtY","lineOnePtX","lineTwoPtX","pointX","pointY","_3d","_parametricLine","_distancePointLine3D","_containsOnlyNumbers","_euclideanDistance","xCoeffLine","yCoeffLine","pointZ","x0","z0","pointOneX","pointOneY","pointTwoX","pointTwoY","pointOneZ","pointTwoZ","_isNumber","aI","_pairwise","pointA","pointB","_distancePairwise","den","vectorSize","createIntersect","_AAA","_AAAA","plane","_coerceArr","_4d","y1","z1","y2","z2","x1x","x2x","y1y","y2y","z1z","z2z","_intersectLinePlane","p1a","p1b","p2a","p2b","o1","o2","d20o11","d21o10","d20o21","d21o20","_intersect2d","x3","y3","z3","x4","y4","z4","d1343","_intersect3dHelper","d4321","d1321","d4343","d2121","ta","tb","pax","pay","paz","pbx","pby","pbz","_intersect3d","add1","add2","add3","createSum","_sum","createCumSum","_cumsum","_ncumSumDim","_cumsummap","sums","_cumsumDimensional","initialValue","createMean","_mean","createMedian","_median","mid","middle2","createMad","_mad","med","DEFAULT_NORMALIZATION","createVariance","_var","_varDim","normalization","createQuantileSeq","Array | Matrix, number | BigNumber","_quantileSeqProbNumber","Array | Matrix, number | BigNumber, number","prob","_quantileSeqDim","Array | Matrix, number | BigNumber, boolean, number","sorted","Array | Matrix, Array | Matrix","_quantileSeqProbCollection","Array | Matrix, Array | Matrix, number","Array | Matrix, Array | Matrix, boolean, number","probOrN","probArr","dataArr","_quantileSeq","nPlusOne","probOrNArr","fracPart","createStd","_std","createCorr","_corr","correlations","correlation","sumX","sumY","sumXY","sumXSquare","sumYSquare","half","combinationsNumber","nMinusk","answer","nextdivisor","lastdivisor","nextnumerator","createCombinations","isPositiveInteger","createCombinationsWithRep","nMinusOne","gammaNumber","twoN","threeN","fourN","fiveN","gammaP","gammaG","lnSqrt2PI","lgammaSeries","lgammaNumber","lgammaN","createGamma","gammaComplex","gammaPval","twoPiSqrt","tpow","expt","bigFactorial","createLgamma","lgammaComplex","lgammaStirling","lgammaRecurrence","leftPart","rz","rzz","rightPart","signflips","sb","shiftprod","nsb","createFactorial","createKldivergence","_kldiv","plength","qlength","qnorm","pnorm","createMultinomial","ai","createPermutations","singletonRandom","createRng","randomSeed","createPickRandom","rng","possibles","_pickRandom","weights","elementWise","single","totalWeights","pick","randKey","randomMatrix","createRandom","_random","number, number","_randomMatrix","Array | Matrix, number","Array | Matrix, number, number","createRandomInt","_randomInt","_randomIntMatrix","createStirlingS2","smallCache","bigCache","make","nn","nk","createBellNumbers","createCatalan","createComposition","createLeafCount","countLeaves","isNumericNode","isConstantExpression","createUtil","defaultName","defaultContext","trivial","total","commutative","associative","paren","defaultF","hasProperty","nodeOrName","isAssociative","allChildren","findChildren","createMakeNodeFunction","isCommutative","mergeContext","primary","secondary","merged","unflattenr","makeNode","curnode","unflattenl","realContext","positiveContext","createSimplify","_simplify","Node, Map","Node, Map, Object","removeParens","SUPPORTED_CONSTANTS","_canonicalizeRule","ruleObject","newRule","lr","nonCommutative","leftExpandsym","_getExpandPlaceholderSymbol","expandsym","expanded","expandedNC1","expandedNC2","rules","assuming","repeat","imposeContext","addition","_lastsym","debug","consoleDebug","ruleSet","rule","ruleType","_buildRules","visited","laststr","rulestr","applyRule","newstr","mapRule","resNodes","newNode","mergedContext","newArgs","newContent","newItems","newObj","newIndex","newDims","newProps","repl","_ruleMatch","placeholders","mergeMatch","match1","match2","_exactMatch","combineChildMatches","list1","list2","i1","i2","isSplit","splits","rightArgs","getSplits","splitMatches","matchSet","childMatches","childMatch","leftMatch","rightMatch","sets","uniqueSets","mergeChildMatches","isVariableNode","createSimplifyConstant","_ensureNode","foldFraction","_removeFractions","thing","_eval","fnname","ignore","_toNumber","_toNode","vn","unaryMinusNode","_exactFraction","exactFractions","fractionsLimit","foldOp","reduction","sofar","ignoreandcontinue","newtree","sz","section","consts","vars","remainingDims","tryItems","fromItems","_foldAccessor","foldItems","foldProps","createSimplifyCore","node0","node1","nodeT","nodeF","isAlwaysBoolean","_simplifyCore","nodeToSimplify","simpChild","childCount","getOperator","seclast","a0","finish","createResolve","_resolve","within","variables","nextWithin","Node, Object","selfAM","createSymbolicEqual","_symbolicEqual","e1","e2","simplified","createDerivative","plainDerivative","variable","constNodes","constTag","_derivative","parseIdentifier","Node, string","Node, string, Object","deriv","_derivTex","varName","isConst","funcDerivative","negative","chainDerivative","constantTerms","nonConstantTerms","nonConstantNode","argOuter","argInner","powMinusOne","createRationalize","_rationalize","detailed","setRules","oldRules","rulesFirst","rulesSucDiv","firstRules","distrDivRules","sucDivRules","firstRulesAgain","finalRules","rulesRationalize","polyRet","extended","oper","recPoly","tp","retFunc","polynomial","nVars","noExactFractions","withExactFractions","sBefore","expandPower","eDistrDiv","redoInic","retRationalize","polyToCanonical","Node, boolean","indParent","internal","does","nEsqTopo","nDirTopo","maxExpo","varname","recurPol","noPai","noFil","fire","cte","valor","no","n3","createZpk2tf","_zpk2tf","_multiply","pole","createFreqz","_freqz","createBins","_w","sumNum","sumDen","bins","createReviver","createReplacer","createTrue","createFalse","createNull","createInfinity","recreateFactory","createNaN","_ref3","createTau","_ref4","createE","_ref5","createPhi","_ref6","createLN2","_ref7","createLN10","_ref8","createLOG2E","_ref9","createLOG10E","_ref10","createSQRT1_2","_ref11","createSQRT2","_ref12","createI","_ref13","createUppercasePi","_ref14","createUppercaseE","_ref15","createVersion","recreateOnConfigChange","createSpeedOfLight","unitFactory","createGravitationConstant","createPlanckConstant","createReducedPlanckConstant","createMagneticConstant","createElectricConstant","createVacuumImpedance","createCoulomb","createElementaryCharge","createBohrMagneton","createConductanceQuantum","createInverseConductanceQuantum","createMagneticFluxQuantum","createNuclearMagneton","createKlitzing","createBohrRadius","createClassicalElectronRadius","createElectronMass","createFermiCoupling","createFineStructure","numberFactory","createHartreeEnergy","createProtonMass","createDeuteronMass","createNeutronMass","createQuantumOfCirculation","createRydberg","createThomsonCrossSection","createWeakMixingAngle","createEfimovFactor","createAtomicMass","createAvogadro","createBoltzmann","createFaraday","createFirstRadiation","createLoschmidt","createGasConstant","createMolarPlanckConstant","createMolarVolume","createSackurTetrode","createSecondRadiation","createStefanBoltzmann","createWienDisplacement","createMolarMass","createMolarMassC12","createGravity","createPlanckLength","createPlanckMass","createPlanckTime","createPlanckCharge","createPlanckTemperature","createApplyTransform","isTransformFunction","createColumnTransform","compileInlineExpression","argsScope","subScope","createTransformCallback","_transformTypedCallbackFunction","_transformCallbackFunction","callbackFunction","numberOfCallbackInputs","vals","_transformDims","createFilterTransform","filterTransform","transformCallback","_compileAndEvaluate","createForEachTransform","forEachTransform","createIndexTransform","isSet","createMapTransform","mapTransform","lastDimToZeroBase","dimToZeroBase","createMaxTransform","createMeanTransform","createMinTransform","createRangeTransform","createRowTransform","createSubsetTransform","createConcatTransform","createDiffTransform","createStdTransform","createSumTransform","createQuantileSeqTransform","createCumSumTransform","createVarianceTransform","createPrintTransform","_convertTemplateToZeroBasedIndex","part","createAndTransform","andTransform","condition1","condition2","createOrTransform","orTransform","createBitAndTransform","bitAndTransform","createBitOrTransform","bitOrTransform","DEFAULT_CONFIG","MATRIX_OPTIONS","NUMBER_OPTIONS","configFactory","_config","optionsFix","validateOption","changes","factories","configInternal","emitter","Emitter","importedFactories","lazyTyped","internalImport","load","_import","_wrap","_importTransform","silent","allowedInExpressions","_deleteTransform","_importFactory","isTransformFunctionFactory","existingTransform","instance","factoryAllowedInExpressions","functions","flatValues","flattenImports","flatName","importFactory"],"sourceRoot":""} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/package.json new file mode 100644 index 0000000..5bbefff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/browser/package.json @@ -0,0 +1,3 @@ +{ + "type": "commonjs" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/constants.js new file mode 100644 index 0000000..2c97fbb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/constants.js @@ -0,0 +1,130 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createVersion = exports.createUppercasePi = exports.createUppercaseE = exports.createTrue = exports.createTau = exports.createSQRT2 = exports.createSQRT1_2 = exports.createPi = exports.createPhi = exports.createNull = exports.createNaN = exports.createLOG2E = exports.createLOG10E = exports.createLN2 = exports.createLN10 = exports.createInfinity = exports.createI = exports.createFalse = exports.createE = void 0; +var _factory = require("./utils/factory.js"); +var _version = require("./version.js"); +var _constants = require("./utils/bignumber/constants.js"); +var _index = require("./plain/number/index.js"); +const createTrue = exports.createTrue = /* #__PURE__ */(0, _factory.factory)('true', [], () => true); +const createFalse = exports.createFalse = /* #__PURE__ */(0, _factory.factory)('false', [], () => false); +const createNull = exports.createNull = /* #__PURE__ */(0, _factory.factory)('null', [], () => null); +const createInfinity = exports.createInfinity = /* #__PURE__ */recreateFactory('Infinity', ['config', '?BigNumber'], _ref => { + let { + config, + BigNumber + } = _ref; + return config.number === 'BigNumber' ? new BigNumber(Infinity) : Infinity; +}); +const createNaN = exports.createNaN = /* #__PURE__ */recreateFactory('NaN', ['config', '?BigNumber'], _ref2 => { + let { + config, + BigNumber + } = _ref2; + return config.number === 'BigNumber' ? new BigNumber(NaN) : NaN; +}); +const createPi = exports.createPi = /* #__PURE__ */recreateFactory('pi', ['config', '?BigNumber'], _ref3 => { + let { + config, + BigNumber + } = _ref3; + return config.number === 'BigNumber' ? (0, _constants.createBigNumberPi)(BigNumber) : _index.pi; +}); +const createTau = exports.createTau = /* #__PURE__ */recreateFactory('tau', ['config', '?BigNumber'], _ref4 => { + let { + config, + BigNumber + } = _ref4; + return config.number === 'BigNumber' ? (0, _constants.createBigNumberTau)(BigNumber) : _index.tau; +}); +const createE = exports.createE = /* #__PURE__ */recreateFactory('e', ['config', '?BigNumber'], _ref5 => { + let { + config, + BigNumber + } = _ref5; + return config.number === 'BigNumber' ? (0, _constants.createBigNumberE)(BigNumber) : _index.e; +}); + +// golden ratio, (1+sqrt(5))/2 +const createPhi = exports.createPhi = /* #__PURE__ */recreateFactory('phi', ['config', '?BigNumber'], _ref6 => { + let { + config, + BigNumber + } = _ref6; + return config.number === 'BigNumber' ? (0, _constants.createBigNumberPhi)(BigNumber) : _index.phi; +}); +const createLN2 = exports.createLN2 = /* #__PURE__ */recreateFactory('LN2', ['config', '?BigNumber'], _ref7 => { + let { + config, + BigNumber + } = _ref7; + return config.number === 'BigNumber' ? new BigNumber(2).ln() : Math.LN2; +}); +const createLN10 = exports.createLN10 = /* #__PURE__ */recreateFactory('LN10', ['config', '?BigNumber'], _ref8 => { + let { + config, + BigNumber + } = _ref8; + return config.number === 'BigNumber' ? new BigNumber(10).ln() : Math.LN10; +}); +const createLOG2E = exports.createLOG2E = /* #__PURE__ */recreateFactory('LOG2E', ['config', '?BigNumber'], _ref9 => { + let { + config, + BigNumber + } = _ref9; + return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(2).ln()) : Math.LOG2E; +}); +const createLOG10E = exports.createLOG10E = /* #__PURE__ */recreateFactory('LOG10E', ['config', '?BigNumber'], _ref10 => { + let { + config, + BigNumber + } = _ref10; + return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(10).ln()) : Math.LOG10E; +}); +const createSQRT1_2 = exports.createSQRT1_2 = /* #__PURE__ */recreateFactory( +// eslint-disable-line camelcase +'SQRT1_2', ['config', '?BigNumber'], _ref11 => { + let { + config, + BigNumber + } = _ref11; + return config.number === 'BigNumber' ? new BigNumber('0.5').sqrt() : Math.SQRT1_2; +}); +const createSQRT2 = exports.createSQRT2 = /* #__PURE__ */recreateFactory('SQRT2', ['config', '?BigNumber'], _ref12 => { + let { + config, + BigNumber + } = _ref12; + return config.number === 'BigNumber' ? new BigNumber(2).sqrt() : Math.SQRT2; +}); +const createI = exports.createI = /* #__PURE__ */recreateFactory('i', ['Complex'], _ref13 => { + let { + Complex + } = _ref13; + return Complex.I; +}); + +// for backward compatibility with v5 +const createUppercasePi = exports.createUppercasePi = /* #__PURE__ */(0, _factory.factory)('PI', ['pi'], _ref14 => { + let { + pi + } = _ref14; + return pi; +}); +const createUppercaseE = exports.createUppercaseE = /* #__PURE__ */(0, _factory.factory)('E', ['e'], _ref15 => { + let { + e + } = _ref15; + return e; +}); +const createVersion = exports.createVersion = /* #__PURE__ */(0, _factory.factory)('version', [], () => _version.version); + +// helper function to create a factory with a flag recreateOnConfigChange +// idea: allow passing optional properties to be attached to the factory function as 4th argument? +function recreateFactory(name, dependencies, create) { + return (0, _factory.factory)(name, dependencies, create, { + recreateOnConfigChange: true + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/config.js new file mode 100644 index 0000000..ea073bb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/config.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.DEFAULT_CONFIG = void 0; +const DEFAULT_CONFIG = exports.DEFAULT_CONFIG = { + // minimum relative difference between two compared values, + // used by all comparison functions + relTol: 1e-12, + // minimum absolute difference between two compared values, + // used by all comparison functions + absTol: 1e-15, + // type of default matrix output. Choose 'matrix' (default) or 'array' + matrix: 'Matrix', + // type of default number output. Choose 'number' (default) 'BigNumber', 'bigint', or 'Fraction' + number: 'number', + // type of fallback used for config { number: 'bigint' } when a value cannot be represented + // in the configured numeric type. Choose 'number' (default) or 'BigNumber'. + numberFallback: 'number', + // number of significant digits in BigNumbers + precision: 64, + // predictable output type of functions. When true, output type depends only + // on the input types. When false (default), output type can vary depending + // on input values. For example `math.sqrt(-4)` returns `complex('2i')` when + // predictable is false, and returns `NaN` when true. + predictable: false, + // random seed for seeded pseudo random number generation + // null = randomly seed + randomSeed: null +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/create.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/create.js new file mode 100644 index 0000000..0032abf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/create.js @@ -0,0 +1,213 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.create = create; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _typedFunction = _interopRequireDefault(require("typed-function")); +var _ArgumentsError = require("../error/ArgumentsError.js"); +var _DimensionError = require("../error/DimensionError.js"); +var _IndexError = require("../error/IndexError.js"); +var _factory = require("../utils/factory.js"); +var _is = require("../utils/is.js"); +var _object = require("../utils/object.js"); +var emitter = _interopRequireWildcard(require("./../utils/emitter.js")); +var _config = require("./config.js"); +var _config2 = require("./function/config.js"); +var _import = require("./function/import.js"); +function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } +function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } +/** + * Create a mathjs instance from given factory functions and optionally config + * + * Usage: + * + * const mathjs1 = create({ createAdd, createMultiply, ...}) + * const config = { number: 'BigNumber' } + * const mathjs2 = create(all, config) + * + * @param {Object} [factories] An object with factory functions + * The object can contain nested objects, + * all nested objects will be flattened. + * @param {Object} [config] Available options: + * {number} relTol + * Minimum relative difference between two + * compared values, used by all comparison functions. + * {number} absTol + * Minimum absolute difference between two + * compared values, used by all comparison functions. + * {string} matrix + * A string 'Matrix' (default) or 'Array'. + * {string} number + * A string 'number' (default), 'BigNumber', or 'Fraction' + * {number} precision + * The number of significant digits for BigNumbers. + * Not applicable for Numbers. + * {boolean} predictable + * Predictable output type of functions. When true, + * output type depends only on the input types. When + * false (default), output type can vary depending + * on input values. For example `math.sqrt(-4)` + * returns `complex('2i')` when predictable is false, and + * returns `NaN` when true. + * {string} randomSeed + * Random seed for seeded pseudo random number generator. + * Set to null to randomly seed. + * @returns {Object} Returns a bare-bone math.js instance containing + * functions: + * - `import` to add new functions + * - `config` to change configuration + * - `on`, `off`, `once`, `emit` for events + */ +function create(factories, config) { + const configInternal = (0, _extends2.default)({}, _config.DEFAULT_CONFIG, config); + + // simple test for ES5 support + if (typeof Object.create !== 'function') { + throw new Error('ES5 not supported by this JavaScript engine. ' + 'Please load the es5-shim and es5-sham library for compatibility.'); + } + + // create the mathjs instance + const math = emitter.mixin({ + // only here for backward compatibility for legacy factory functions + isNumber: _is.isNumber, + isComplex: _is.isComplex, + isBigNumber: _is.isBigNumber, + isBigInt: _is.isBigInt, + isFraction: _is.isFraction, + isUnit: _is.isUnit, + isString: _is.isString, + isArray: _is.isArray, + isMatrix: _is.isMatrix, + isCollection: _is.isCollection, + isDenseMatrix: _is.isDenseMatrix, + isSparseMatrix: _is.isSparseMatrix, + isRange: _is.isRange, + isIndex: _is.isIndex, + isBoolean: _is.isBoolean, + isResultSet: _is.isResultSet, + isHelp: _is.isHelp, + isFunction: _is.isFunction, + isDate: _is.isDate, + isRegExp: _is.isRegExp, + isObject: _is.isObject, + isMap: _is.isMap, + isPartitionedMap: _is.isPartitionedMap, + isObjectWrappingMap: _is.isObjectWrappingMap, + isNull: _is.isNull, + isUndefined: _is.isUndefined, + isAccessorNode: _is.isAccessorNode, + isArrayNode: _is.isArrayNode, + isAssignmentNode: _is.isAssignmentNode, + isBlockNode: _is.isBlockNode, + isConditionalNode: _is.isConditionalNode, + isConstantNode: _is.isConstantNode, + isFunctionAssignmentNode: _is.isFunctionAssignmentNode, + isFunctionNode: _is.isFunctionNode, + isIndexNode: _is.isIndexNode, + isNode: _is.isNode, + isObjectNode: _is.isObjectNode, + isOperatorNode: _is.isOperatorNode, + isParenthesisNode: _is.isParenthesisNode, + isRangeNode: _is.isRangeNode, + isRelationalNode: _is.isRelationalNode, + isSymbolNode: _is.isSymbolNode, + isChain: _is.isChain + }); + + // load config function and apply provided config + math.config = (0, _config2.configFactory)(configInternal, math.emit); + math.expression = { + transform: {}, + mathWithTransform: { + config: math.config + } + }; + + // cached factories and instances used by function load + const legacyFactories = []; + const legacyInstances = []; + + /** + * Load a function or data type from a factory. + * If the function or data type already exists, the existing instance is + * returned. + * @param {Function} factory + * @returns {*} + */ + function load(factory) { + if ((0, _factory.isFactory)(factory)) { + return factory(math); + } + const firstProperty = factory[Object.keys(factory)[0]]; + if ((0, _factory.isFactory)(firstProperty)) { + return firstProperty(math); + } + if (!(0, _object.isLegacyFactory)(factory)) { + console.warn('Factory object with properties `type`, `name`, and `factory` expected', factory); + throw new Error('Factory object with properties `type`, `name`, and `factory` expected'); + } + const index = legacyFactories.indexOf(factory); + let instance; + if (index === -1) { + // doesn't yet exist + if (factory.math === true) { + // pass with math namespace + instance = factory.factory(math.type, configInternal, load, math.typed, math); + } else { + instance = factory.factory(math.type, configInternal, load, math.typed); + } + + // append to the cache + legacyFactories.push(factory); + legacyInstances.push(instance); + } else { + // already existing function, return the cached instance + instance = legacyInstances[index]; + } + return instance; + } + const importedFactories = {}; + + // load the import function + function lazyTyped() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + return math.typed.apply(math.typed, args); + } + lazyTyped.isTypedFunction = _typedFunction.default.isTypedFunction; + const internalImport = (0, _import.importFactory)(lazyTyped, load, math, importedFactories); + math.import = internalImport; + + // listen for changes in config, import all functions again when changed + // TODO: move this listener into the import function? + math.on('config', () => { + Object.values(importedFactories).forEach(factory => { + if (factory && factory.meta && factory.meta.recreateOnConfigChange) { + // FIXME: only re-create when the current instance is the same as was initially created + // FIXME: delete the functions/constants before importing them again? + internalImport(factory, { + override: true + }); + } + }); + }); + + // the create function exposed on the mathjs instance is bound to + // the factory functions passed before + math.create = create.bind(null, factories); + + // export factory function + math.factory = _factory.factory; + + // import the factory functions like createAdd as an array instead of object, + // else they will get a different naming (`createAdd` instead of `add`). + math.import(Object.values((0, _object.deepFlatten)(factories))); + math.ArgumentsError = _ArgumentsError.ArgumentsError; + math.DimensionError = _DimensionError.DimensionError; + math.IndexError = _IndexError.IndexError; + return math; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/config.js new file mode 100644 index 0000000..b275af5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/config.js @@ -0,0 +1,115 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NUMBER_OPTIONS = exports.MATRIX_OPTIONS = void 0; +exports.configFactory = configFactory; +var _object = require("../../utils/object.js"); +var _config2 = require("../config.js"); +const MATRIX_OPTIONS = exports.MATRIX_OPTIONS = ['Matrix', 'Array']; // valid values for option matrix +const NUMBER_OPTIONS = exports.NUMBER_OPTIONS = ['number', 'BigNumber', 'Fraction']; // valid values for option number + +function configFactory(config, emit) { + /** + * Set configuration options for math.js, and get current options. + * Will emit a 'config' event, with arguments (curr, prev, changes). + * + * This function is only available on a mathjs instance created using `create`. + * + * Syntax: + * + * math.config(config: Object): Object + * + * Examples: + * + * + * import { create, all } from 'mathjs' + * + * // create a mathjs instance + * const math = create(all) + * + * math.config().number // outputs 'number' + * math.evaluate('0.4') // outputs number 0.4 + * math.config({number: 'Fraction'}) + * math.evaluate('0.4') // outputs Fraction 2/5 + * + * @param {Object} [options] Available options: + * {number} relTol + * Minimum relative difference between two + * compared values, used by all comparison functions. + * {number} absTol + * Minimum absolute difference between two + * compared values, used by all comparison functions. + * {string} matrix + * A string 'Matrix' (default) or 'Array'. + * {string} number + * A string 'number' (default), 'BigNumber', 'bigint', or 'Fraction' + * {number} precision + * The number of significant digits for BigNumbers. + * Not applicable for Numbers. + * {string} parenthesis + * How to display parentheses in LaTeX and string + * output. + * {string} randomSeed + * Random seed for seeded pseudo random number generator. + * Set to null to randomly seed. + * @return {Object} Returns the current configuration + */ + function _config(options) { + if (options) { + if (options.epsilon !== undefined) { + // this if is only for backwards compatibility, it can be removed in the future. + console.warn('Warning: The configuration option "epsilon" is deprecated. Use "relTol" and "absTol" instead.'); + const optionsFix = (0, _object.clone)(options); + optionsFix.relTol = options.epsilon; + optionsFix.absTol = options.epsilon * 1e-3; + delete optionsFix.epsilon; + return _config(optionsFix); + } + const prev = (0, _object.clone)(config); + + // validate some of the options + validateOption(options, 'matrix', MATRIX_OPTIONS); + validateOption(options, 'number', NUMBER_OPTIONS); + + // merge options + (0, _object.deepExtend)(config, options); + const curr = (0, _object.clone)(config); + const changes = (0, _object.clone)(options); + + // emit 'config' event + emit('config', curr, prev, changes); + return curr; + } else { + return (0, _object.clone)(config); + } + } + + // attach the valid options to the function so they can be extended + _config.MATRIX_OPTIONS = MATRIX_OPTIONS; + _config.NUMBER_OPTIONS = NUMBER_OPTIONS; + + // attach the config properties as readonly properties to the config function + Object.keys(_config2.DEFAULT_CONFIG).forEach(key => { + Object.defineProperty(_config, key, { + get: () => config[key], + enumerable: true, + configurable: true + }); + }); + return _config; +} + +/** + * Validate an option + * @param {Object} options Object with options + * @param {string} name Name of the option to validate + * @param {Array.} values Array with valid values for this option + */ +function validateOption(options, name, values) { + if (options[name] !== undefined && !values.includes(options[name])) { + // unknown value + console.warn('Warning: Unknown value "' + options[name] + '" for configuration option "' + name + '". ' + 'Available options: ' + values.map(value => JSON.stringify(value)).join(', ') + '.'); + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/import.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/import.js new file mode 100644 index 0000000..422b63f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/import.js @@ -0,0 +1,331 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.importFactory = importFactory; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _object = require("../../utils/object.js"); +var _ArgumentsError = require("../../error/ArgumentsError.js"); +function importFactory(typed, load, math, importedFactories) { + /** + * Import functions from an object or a module. + * + * This function is only available on a mathjs instance created using `create`. + * + * Syntax: + * + * math.import(functions) + * math.import(functions, options) + * + * Where: + * + * - `functions: Object` + * An object with functions or factories to be imported. + * - `options: Object` An object with import options. Available options: + * - `override: boolean` + * If true, existing functions will be overwritten. False by default. + * - `silent: boolean` + * If true, the function will not throw errors on duplicates or invalid + * types. False by default. + * - `wrap: boolean` + * If true, the functions will be wrapped in a wrapper function + * which converts data types like Matrix to primitive data types like Array. + * The wrapper is needed when extending math.js with libraries which do not + * support these data type. False by default. + * + * Examples: + * + * import { create, all } from 'mathjs' + * import * as numbers from 'numbers' + * + * // create a mathjs instance + * const math = create(all) + * + * // define new functions and variables + * math.import({ + * myvalue: 42, + * hello: function (name) { + * return 'hello, ' + name + '!' + * } + * }) + * + * // use the imported function and variable + * math.myvalue * 2 // 84 + * math.hello('user') // 'hello, user!' + * + * // import the npm module 'numbers' + * // (must be installed first with `npm install numbers`) + * math.import(numbers, {wrap: true}) + * + * math.fibonacci(7) // returns 13 + * + * @param {Object | Array} functions Object with functions to be imported. + * @param {Object} [options] Import options. + */ + function mathImport(functions, options) { + const num = arguments.length; + if (num !== 1 && num !== 2) { + throw new _ArgumentsError.ArgumentsError('import', num, 1, 2); + } + if (!options) { + options = {}; + } + function flattenImports(flatValues, value, name) { + if (Array.isArray(value)) { + value.forEach(item => flattenImports(flatValues, item)); + } else if (typeof value === 'object') { + for (const name in value) { + if ((0, _object.hasOwnProperty)(value, name)) { + flattenImports(flatValues, value[name], name); + } + } + } else if ((0, _factory.isFactory)(value) || name !== undefined) { + const flatName = (0, _factory.isFactory)(value) ? isTransformFunctionFactory(value) ? value.fn + '.transform' // TODO: this is ugly + : value.fn : name; + + // we allow importing the same function twice if it points to the same implementation + if ((0, _object.hasOwnProperty)(flatValues, flatName) && flatValues[flatName] !== value && !options.silent) { + throw new Error('Cannot import "' + flatName + '" twice'); + } + flatValues[flatName] = value; + } else { + if (!options.silent) { + throw new TypeError('Factory, Object, or Array expected'); + } + } + } + const flatValues = {}; + flattenImports(flatValues, functions); + for (const name in flatValues) { + if ((0, _object.hasOwnProperty)(flatValues, name)) { + // console.log('import', name) + const value = flatValues[name]; + if ((0, _factory.isFactory)(value)) { + // we ignore name here and enforce the name of the factory + // maybe at some point we do want to allow overriding it + // in that case we can implement an option overrideFactoryNames: true + _importFactory(value, options); + } else if (isSupportedType(value)) { + _import(name, value, options); + } else { + if (!options.silent) { + throw new TypeError('Factory, Object, or Array expected'); + } + } + } + } + } + + /** + * Add a property to the math namespace + * @param {string} name + * @param {*} value + * @param {Object} options See import for a description of the options + * @private + */ + function _import(name, value, options) { + // TODO: refactor this function, it's to complicated and contains duplicate code + if (options.wrap && typeof value === 'function') { + // create a wrapper around the function + value = _wrap(value); + } + + // turn a plain function with a typed-function signature into a typed-function + if (hasTypedFunctionSignature(value)) { + value = typed(name, { + [value.signature]: value + }); + } + if (typed.isTypedFunction(math[name]) && typed.isTypedFunction(value)) { + if (options.override) { + // give the typed function the right name + value = typed(name, value.signatures); + } else { + // merge the existing and typed function + value = typed(math[name], value); + } + math[name] = value; + delete importedFactories[name]; + _importTransform(name, value); + math.emit('import', name, function resolver() { + return value; + }); + return; + } + if (math[name] === undefined || options.override) { + math[name] = value; + delete importedFactories[name]; + _importTransform(name, value); + math.emit('import', name, function resolver() { + return value; + }); + return; + } + if (!options.silent) { + throw new Error('Cannot import "' + name + '": already exists'); + } + } + function _importTransform(name, value) { + if (value && typeof value.transform === 'function') { + math.expression.transform[name] = value.transform; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = value.transform; + } + } else { + // remove existing transform + delete math.expression.transform[name]; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = value; + } + } + } + function _deleteTransform(name) { + delete math.expression.transform[name]; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = math[name]; + } else { + delete math.expression.mathWithTransform[name]; + } + } + + /** + * Create a wrapper a round an function which converts the arguments + * to their primitive values (like convert a Matrix to Array) + * @param {Function} fn + * @return {Function} Returns the wrapped function + * @private + */ + function _wrap(fn) { + const wrapper = function wrapper() { + const args = []; + for (let i = 0, len = arguments.length; i < len; i++) { + const arg = arguments[i]; + args[i] = arg && arg.valueOf(); + } + return fn.apply(math, args); + }; + if (fn.transform) { + wrapper.transform = fn.transform; + } + return wrapper; + } + + /** + * Import an instance of a factory into math.js + * @param {function(scope: object)} factory + * @param {Object} options See import for a description of the options + * @param {string} [name=factory.name] Optional custom name + * @private + */ + function _importFactory(factory, options) { + let name = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : factory.fn; + if (name.includes('.')) { + throw new Error('Factory name should not contain a nested path. ' + 'Name: ' + JSON.stringify(name)); + } + const namespace = isTransformFunctionFactory(factory) ? math.expression.transform : math; + const existingTransform = name in math.expression.transform; + const existing = (0, _object.hasOwnProperty)(namespace, name) ? namespace[name] : undefined; + const resolver = function () { + // collect all dependencies, handle finding both functions and classes and other special cases + const dependencies = {}; + factory.dependencies.map(_factory.stripOptionalNotation).forEach(dependency => { + if (dependency.includes('.')) { + throw new Error('Factory dependency should not contain a nested path. ' + 'Name: ' + JSON.stringify(dependency)); + } + if (dependency === 'math') { + dependencies.math = math; + } else if (dependency === 'mathWithTransform') { + dependencies.mathWithTransform = math.expression.mathWithTransform; + } else if (dependency === 'classes') { + // special case for json reviver + dependencies.classes = math; + } else { + dependencies[dependency] = math[dependency]; + } + }); + const instance = /* #__PURE__ */factory(dependencies); + if (instance && typeof instance.transform === 'function') { + throw new Error('Transforms cannot be attached to factory functions. ' + 'Please create a separate function for it with export const path = "expression.transform"'); + } + if (existing === undefined || options.override) { + return instance; + } + if (typed.isTypedFunction(existing) && typed.isTypedFunction(instance)) { + // merge the existing and new typed function + return typed(existing, instance); + } + if (options.silent) { + // keep existing, ignore imported function + return existing; + } else { + throw new Error('Cannot import "' + name + '": already exists'); + } + }; + + // TODO: add unit test with non-lazy factory + if (!factory.meta || factory.meta.lazy !== false) { + (0, _object.lazy)(namespace, name, resolver); + + // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two) + if (existing && existingTransform) { + _deleteTransform(name); + } else { + if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) { + (0, _object.lazy)(math.expression.mathWithTransform, name, () => namespace[name]); + } + } + } else { + namespace[name] = resolver(); + + // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two) + if (existing && existingTransform) { + _deleteTransform(name); + } else { + if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) { + (0, _object.lazy)(math.expression.mathWithTransform, name, () => namespace[name]); + } + } + } + + // TODO: improve factories, store a list with imports instead which can be re-played + importedFactories[name] = factory; + math.emit('import', name, resolver); + } + + /** + * Check whether given object is a type which can be imported + * @param {Function | number | string | boolean | null | Unit | Complex} object + * @return {boolean} + * @private + */ + function isSupportedType(object) { + return typeof object === 'function' || typeof object === 'number' || typeof object === 'string' || typeof object === 'boolean' || object === null || (0, _is.isUnit)(object) || (0, _is.isComplex)(object) || (0, _is.isBigNumber)(object) || (0, _is.isFraction)(object) || (0, _is.isMatrix)(object) || Array.isArray(object); + } + function hasTypedFunctionSignature(fn) { + return typeof fn === 'function' && typeof fn.signature === 'string'; + } + function allowedInExpressions(name) { + return !(0, _object.hasOwnProperty)(unsafe, name); + } + function factoryAllowedInExpressions(factory) { + return !factory.fn.includes('.') && + // FIXME: make checking on path redundant, check on meta data instead + !(0, _object.hasOwnProperty)(unsafe, factory.fn) && (!factory.meta || !factory.meta.isClass); + } + function isTransformFunctionFactory(factory) { + return factory !== undefined && factory.meta !== undefined && factory.meta.isTransformFunction === true || false; + } + + // namespaces and functions not available in the parser for safety reasons + const unsafe = { + expression: true, + type: true, + docs: true, + error: true, + json: true, + chain: true // chain method not supported. Note that there is a unit chain too. + }; + return mathImport; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/typed.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/typed.js new file mode 100644 index 0000000..628ae9a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/core/function/typed.js @@ -0,0 +1,461 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTyped = void 0; +var _typedFunction = _interopRequireDefault(require("typed-function")); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +/** + * Create a typed-function which checks the types of the arguments and + * can match them against multiple provided signatures. The typed-function + * automatically converts inputs in order to find a matching signature. + * Typed functions throw informative errors in case of wrong input arguments. + * + * See the library [typed-function](https://github.com/josdejong/typed-function) + * for detailed documentation. + * + * Syntax: + * + * math.typed(name, signatures) : function + * math.typed(signatures) : function + * + * Examples: + * + * // create a typed function with multiple types per argument (type union) + * const fn2 = typed({ + * 'number | boolean': function (b) { + * return 'b is a number or boolean' + * }, + * 'string, number | boolean': function (a, b) { + * return 'a is a string, b is a number or boolean' + * } + * }) + * + * // create a typed function with an any type argument + * const log = typed({ + * 'string, any': function (event, data) { + * console.log('event: ' + event + ', data: ' + JSON.stringify(data)) + * } + * }) + * + * @param {string} [name] Optional name for the typed-function + * @param {Object} signatures Object with one or multiple function signatures + * @returns {function} The created typed-function. + */ + +// returns a new instance of typed-function +let _createTyped = function () { + // initially, return the original instance of typed-function + // consecutively, return a new instance from typed.create. + _createTyped = _typedFunction.default.create; + return _typedFunction.default; +}; +const dependencies = ['?BigNumber', '?Complex', '?DenseMatrix', '?Fraction']; + +/** + * Factory function for creating a new typed instance + * @param {Object} dependencies Object with data types like Complex and BigNumber + * @returns {Function} + */ +const createTyped = exports.createTyped = /* #__PURE__ */(0, _factory.factory)('typed', dependencies, function createTyped(_ref) { + let { + BigNumber, + Complex, + DenseMatrix, + Fraction + } = _ref; + // TODO: typed-function must be able to silently ignore signatures with unknown data types + + // get a new instance of typed-function + const typed = _createTyped(); + + // define all types. The order of the types determines in which order function + // arguments are type-checked (so for performance it's important to put the + // most used types first). + typed.clear(); + typed.addTypes([{ + name: 'number', + test: _is.isNumber + }, { + name: 'Complex', + test: _is.isComplex + }, { + name: 'BigNumber', + test: _is.isBigNumber + }, { + name: 'bigint', + test: _is.isBigInt + }, { + name: 'Fraction', + test: _is.isFraction + }, { + name: 'Unit', + test: _is.isUnit + }, + // The following type matches a valid variable name, i.e., an alphanumeric + // string starting with an alphabetic character. It is used (at least) + // in the definition of the derivative() function, as the argument telling + // what to differentiate over must (currently) be a variable. + // TODO: deprecate the identifier type (it's not used anymore, see https://github.com/josdejong/mathjs/issues/3253) + { + name: 'identifier', + test: s => _is.isString && /^[A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}][0-9A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}]*$/u.test(s) + }, { + name: 'string', + test: _is.isString + }, { + name: 'Chain', + test: _is.isChain + }, { + name: 'Array', + test: _is.isArray + }, { + name: 'Matrix', + test: _is.isMatrix + }, { + name: 'DenseMatrix', + test: _is.isDenseMatrix + }, { + name: 'SparseMatrix', + test: _is.isSparseMatrix + }, { + name: 'Range', + test: _is.isRange + }, { + name: 'Index', + test: _is.isIndex + }, { + name: 'boolean', + test: _is.isBoolean + }, { + name: 'ResultSet', + test: _is.isResultSet + }, { + name: 'Help', + test: _is.isHelp + }, { + name: 'function', + test: _is.isFunction + }, { + name: 'Date', + test: _is.isDate + }, { + name: 'RegExp', + test: _is.isRegExp + }, { + name: 'null', + test: _is.isNull + }, { + name: 'undefined', + test: _is.isUndefined + }, { + name: 'AccessorNode', + test: _is.isAccessorNode + }, { + name: 'ArrayNode', + test: _is.isArrayNode + }, { + name: 'AssignmentNode', + test: _is.isAssignmentNode + }, { + name: 'BlockNode', + test: _is.isBlockNode + }, { + name: 'ConditionalNode', + test: _is.isConditionalNode + }, { + name: 'ConstantNode', + test: _is.isConstantNode + }, { + name: 'FunctionNode', + test: _is.isFunctionNode + }, { + name: 'FunctionAssignmentNode', + test: _is.isFunctionAssignmentNode + }, { + name: 'IndexNode', + test: _is.isIndexNode + }, { + name: 'Node', + test: _is.isNode + }, { + name: 'ObjectNode', + test: _is.isObjectNode + }, { + name: 'OperatorNode', + test: _is.isOperatorNode + }, { + name: 'ParenthesisNode', + test: _is.isParenthesisNode + }, { + name: 'RangeNode', + test: _is.isRangeNode + }, { + name: 'RelationalNode', + test: _is.isRelationalNode + }, { + name: 'SymbolNode', + test: _is.isSymbolNode + }, { + name: 'Map', + test: _is.isMap + }, { + name: 'Object', + test: _is.isObject + } // order 'Object' last, it matches on other classes too + ]); + typed.addConversions([{ + from: 'number', + to: 'BigNumber', + convert: function (x) { + if (!BigNumber) { + throwNoBignumber(x); + } + + // note: conversion from number to BigNumber can fail if x has >15 digits + if ((0, _number.digits)(x) > 15) { + throw new TypeError('Cannot implicitly convert a number with >15 significant digits to BigNumber ' + '(value: ' + x + '). ' + 'Use function bignumber(x) to convert to BigNumber.'); + } + return new BigNumber(x); + } + }, { + from: 'number', + to: 'Complex', + convert: function (x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x, 0); + } + }, { + from: 'BigNumber', + to: 'Complex', + convert: function (x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x.toNumber(), 0); + } + }, { + from: 'bigint', + to: 'number', + convert: function (x) { + if (x > Number.MAX_SAFE_INTEGER) { + throw new TypeError('Cannot implicitly convert bigint to number: ' + 'value exceeds the max safe integer value (value: ' + x + ')'); + } + return Number(x); + } + }, { + from: 'bigint', + to: 'BigNumber', + convert: function (x) { + if (!BigNumber) { + throwNoBignumber(x); + } + return new BigNumber(x.toString()); + } + }, { + from: 'bigint', + to: 'Fraction', + convert: function (x) { + if (!Fraction) { + throwNoFraction(x); + } + return new Fraction(x.toString()); + } + }, { + from: 'Fraction', + to: 'BigNumber', + convert: function (x) { + throw new TypeError('Cannot implicitly convert a Fraction to BigNumber or vice versa. ' + 'Use function bignumber(x) to convert to BigNumber or fraction(x) to convert to Fraction.'); + } + }, { + from: 'Fraction', + to: 'Complex', + convert: function (x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x.valueOf(), 0); + } + }, { + from: 'number', + to: 'Fraction', + convert: function (x) { + if (!Fraction) { + throwNoFraction(x); + } + const f = new Fraction(x); + if (f.valueOf() !== x) { + throw new TypeError('Cannot implicitly convert a number to a Fraction when there will be a loss of precision ' + '(value: ' + x + '). ' + 'Use function fraction(x) to convert to Fraction.'); + } + return f; + } + }, { + // FIXME: add conversion from Fraction to number, for example for `sqrt(fraction(1,3))` + // from: 'Fraction', + // to: 'number', + // convert: function (x) { + // return x.valueOf() + // } + // }, { + from: 'string', + to: 'number', + convert: function (x) { + const n = Number(x); + if (isNaN(n)) { + throw new Error('Cannot convert "' + x + '" to a number'); + } + return n; + } + }, { + from: 'string', + to: 'BigNumber', + convert: function (x) { + if (!BigNumber) { + throwNoBignumber(x); + } + try { + return new BigNumber(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to BigNumber'); + } + } + }, { + from: 'string', + to: 'bigint', + convert: function (x) { + try { + return BigInt(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to BigInt'); + } + } + }, { + from: 'string', + to: 'Fraction', + convert: function (x) { + if (!Fraction) { + throwNoFraction(x); + } + try { + return new Fraction(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to Fraction'); + } + } + }, { + from: 'string', + to: 'Complex', + convert: function (x) { + if (!Complex) { + throwNoComplex(x); + } + try { + return new Complex(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to Complex'); + } + } + }, { + from: 'boolean', + to: 'number', + convert: function (x) { + return +x; + } + }, { + from: 'boolean', + to: 'BigNumber', + convert: function (x) { + if (!BigNumber) { + throwNoBignumber(x); + } + return new BigNumber(+x); + } + }, { + from: 'boolean', + to: 'bigint', + convert: function (x) { + return BigInt(+x); + } + }, { + from: 'boolean', + to: 'Fraction', + convert: function (x) { + if (!Fraction) { + throwNoFraction(x); + } + return new Fraction(+x); + } + }, { + from: 'boolean', + to: 'string', + convert: function (x) { + return String(x); + } + }, { + from: 'Array', + to: 'Matrix', + convert: function (array) { + if (!DenseMatrix) { + throwNoMatrix(); + } + return new DenseMatrix(array); + } + }, { + from: 'Matrix', + to: 'Array', + convert: function (matrix) { + return matrix.valueOf(); + } + }]); + + // Provide a suggestion on how to call a function elementwise + // This was added primarily as guidance for the v10 -> v11 transition, + // and could potentially be removed in the future if it no longer seems + // to be helpful. + typed.onMismatch = (name, args, signatures) => { + const usualError = typed.createError(name, args, signatures); + if (['wrongType', 'mismatch'].includes(usualError.data.category) && args.length === 1 && (0, _is.isCollection)(args[0]) && + // check if the function can be unary: + signatures.some(sig => !sig.params.includes(','))) { + const err = new TypeError(`Function '${name}' doesn't apply to matrices. To call it ` + `elementwise on a matrix 'M', try 'map(M, ${name})'.`); + err.data = usualError.data; + throw err; + } + throw usualError; + }; + + // Provide a suggestion on how to call a function elementwise + // This was added primarily as guidance for the v10 -> v11 transition, + // and could potentially be removed in the future if it no longer seems + // to be helpful. + typed.onMismatch = (name, args, signatures) => { + const usualError = typed.createError(name, args, signatures); + if (['wrongType', 'mismatch'].includes(usualError.data.category) && args.length === 1 && (0, _is.isCollection)(args[0]) && + // check if the function can be unary: + signatures.some(sig => !sig.params.includes(','))) { + const err = new TypeError(`Function '${name}' doesn't apply to matrices. To call it ` + `elementwise on a matrix 'M', try 'map(M, ${name})'.`); + err.data = usualError.data; + throw err; + } + throw usualError; + }; + return typed; +}); +function throwNoBignumber(x) { + throw new Error(`Cannot convert value ${x} into a BigNumber: no class 'BigNumber' provided`); +} +function throwNoComplex(x) { + throw new Error(`Cannot convert value ${x} into a Complex number: no class 'Complex' provided`); +} +function throwNoMatrix() { + throw new Error('Cannot convert array into a Matrix: no class \'DenseMatrix\' provided'); +} +function throwNoFraction(x) { + throw new Error(`Cannot convert value ${x} into a Fraction, no class 'Fraction' provided.`); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/defaultInstance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/defaultInstance.js new file mode 100644 index 0000000..527dd44 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/defaultInstance.js @@ -0,0 +1,11 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = void 0; +var all = _interopRequireWildcard(require("./factoriesAny.js")); +var _create = require("./core/create.js"); +function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } +function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } +var _default = exports.default = (0, _create.create)(all); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesAny.js new file mode 100644 index 0000000..3678043 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesAny.js @@ -0,0 +1,12 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.all = void 0; +var allFactories = _interopRequireWildcard(require("../factoriesAny.js")); +function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } +function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } +// creating all factories here in a separate file is needed to get tree-shaking working + +const all = exports.all = allFactories; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesNumber.js new file mode 100644 index 0000000..5279cdf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/allFactoriesNumber.js @@ -0,0 +1,12 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.all = void 0; +var allFactories = _interopRequireWildcard(require("../factoriesNumber.js")); +function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } +function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } +// creating all factories here in a separate file is needed to get tree-shaking working + +const all = exports.all = allFactories; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/configReadonly.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/configReadonly.js new file mode 100644 index 0000000..509c249 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/configReadonly.js @@ -0,0 +1,22 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.config = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _config = require("../core/config.js"); +var _config2 = require("../core/function/config.js"); +// create a read-only version of config +const config = function (options) { + if (options) { + throw new Error('The global config is readonly. \n' + 'Please create a mathjs instance if you want to change the default configuration. \n' + 'Example:\n' + '\n' + ' import { create, all } from \'mathjs\';\n' + ' const mathjs = create(all);\n' + ' mathjs.config({ number: \'BigNumber\' });\n'); + } + return Object.freeze(_config.DEFAULT_CONFIG); +}; +exports.config = config; +(0, _extends2.default)(config, _config.DEFAULT_CONFIG, { + MATRIX_OPTIONS: _config2.MATRIX_OPTIONS, + NUMBER_OPTIONS: _config2.NUMBER_OPTIONS +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny.generated.js new file mode 100644 index 0000000..c424404 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny.generated.js @@ -0,0 +1,2546 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +Object.defineProperty(exports, "AccessorNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesAccessorNodeGenerated.AccessorNodeDependencies; + } +}); +Object.defineProperty(exports, "ArrayNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesArrayNodeGenerated.ArrayNodeDependencies; + } +}); +Object.defineProperty(exports, "AssignmentNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies; + } +}); +Object.defineProperty(exports, "BigNumberDependencies", { + enumerable: true, + get: function () { + return _dependenciesBigNumberClassGenerated.BigNumberDependencies; + } +}); +Object.defineProperty(exports, "BlockNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesBlockNodeGenerated.BlockNodeDependencies; + } +}); +Object.defineProperty(exports, "ChainDependencies", { + enumerable: true, + get: function () { + return _dependenciesChainClassGenerated.ChainDependencies; + } +}); +Object.defineProperty(exports, "ComplexDependencies", { + enumerable: true, + get: function () { + return _dependenciesComplexClassGenerated.ComplexDependencies; + } +}); +Object.defineProperty(exports, "ConditionalNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies; + } +}); +Object.defineProperty(exports, "ConstantNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesConstantNodeGenerated.ConstantNodeDependencies; + } +}); +Object.defineProperty(exports, "DenseMatrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies; + } +}); +Object.defineProperty(exports, "EDependencies", { + enumerable: true, + get: function () { + return _dependenciesUppercaseEGenerated.EDependencies; + } +}); +Object.defineProperty(exports, "FibonacciHeapDependencies", { + enumerable: true, + get: function () { + return _dependenciesFibonacciHeapClassGenerated.FibonacciHeapDependencies; + } +}); +Object.defineProperty(exports, "FractionDependencies", { + enumerable: true, + get: function () { + return _dependenciesFractionClassGenerated.FractionDependencies; + } +}); +Object.defineProperty(exports, "FunctionAssignmentNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies; + } +}); +Object.defineProperty(exports, "FunctionNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesFunctionNodeGenerated.FunctionNodeDependencies; + } +}); +Object.defineProperty(exports, "HelpDependencies", { + enumerable: true, + get: function () { + return _dependenciesHelpClassGenerated.HelpDependencies; + } +}); +Object.defineProperty(exports, "ImmutableDenseMatrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesImmutableDenseMatrixClassGenerated.ImmutableDenseMatrixDependencies; + } +}); +Object.defineProperty(exports, "IndexDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexClassGenerated.IndexDependencies; + } +}); +Object.defineProperty(exports, "IndexNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexNodeGenerated.IndexNodeDependencies; + } +}); +Object.defineProperty(exports, "InfinityDependencies", { + enumerable: true, + get: function () { + return _dependenciesInfinityGenerated.InfinityDependencies; + } +}); +Object.defineProperty(exports, "LN10Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLN10Generated.LN10Dependencies; + } +}); +Object.defineProperty(exports, "LN2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLN2Generated.LN2Dependencies; + } +}); +Object.defineProperty(exports, "LOG10EDependencies", { + enumerable: true, + get: function () { + return _dependenciesLOG10EGenerated.LOG10EDependencies; + } +}); +Object.defineProperty(exports, "LOG2EDependencies", { + enumerable: true, + get: function () { + return _dependenciesLOG2EGenerated.LOG2EDependencies; + } +}); +Object.defineProperty(exports, "MatrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixClassGenerated.MatrixDependencies; + } +}); +Object.defineProperty(exports, "NaNDependencies", { + enumerable: true, + get: function () { + return _dependenciesNaNGenerated.NaNDependencies; + } +}); +Object.defineProperty(exports, "NodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesNodeGenerated.NodeDependencies; + } +}); +Object.defineProperty(exports, "ObjectNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesObjectNodeGenerated.ObjectNodeDependencies; + } +}); +Object.defineProperty(exports, "OperatorNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesOperatorNodeGenerated.OperatorNodeDependencies; + } +}); +Object.defineProperty(exports, "PIDependencies", { + enumerable: true, + get: function () { + return _dependenciesUppercasePiGenerated.PIDependencies; + } +}); +Object.defineProperty(exports, "ParenthesisNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies; + } +}); +Object.defineProperty(exports, "ParserDependencies", { + enumerable: true, + get: function () { + return _dependenciesParserClassGenerated.ParserDependencies; + } +}); +Object.defineProperty(exports, "RangeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeClassGenerated.RangeDependencies; + } +}); +Object.defineProperty(exports, "RangeNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeNodeGenerated.RangeNodeDependencies; + } +}); +Object.defineProperty(exports, "RelationalNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRelationalNodeGenerated.RelationalNodeDependencies; + } +}); +Object.defineProperty(exports, "ResultSetDependencies", { + enumerable: true, + get: function () { + return _dependenciesResultSetGenerated.ResultSetDependencies; + } +}); +Object.defineProperty(exports, "SQRT1_2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesSQRT1_2Generated.SQRT1_2Dependencies; + } +}); +Object.defineProperty(exports, "SQRT2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesSQRT2Generated.SQRT2Dependencies; + } +}); +Object.defineProperty(exports, "SpaDependencies", { + enumerable: true, + get: function () { + return _dependenciesSpaClassGenerated.SpaDependencies; + } +}); +Object.defineProperty(exports, "SparseMatrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies; + } +}); +Object.defineProperty(exports, "SymbolNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSymbolNodeGenerated.SymbolNodeDependencies; + } +}); +Object.defineProperty(exports, "UnitDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnitClassGenerated.UnitDependencies; + } +}); +Object.defineProperty(exports, "absDependencies", { + enumerable: true, + get: function () { + return _dependenciesAbsGenerated.absDependencies; + } +}); +Object.defineProperty(exports, "acosDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcosGenerated.acosDependencies; + } +}); +Object.defineProperty(exports, "acoshDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcoshGenerated.acoshDependencies; + } +}); +Object.defineProperty(exports, "acotDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcotGenerated.acotDependencies; + } +}); +Object.defineProperty(exports, "acothDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcothGenerated.acothDependencies; + } +}); +Object.defineProperty(exports, "acscDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcscGenerated.acscDependencies; + } +}); +Object.defineProperty(exports, "acschDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcschGenerated.acschDependencies; + } +}); +Object.defineProperty(exports, "addDependencies", { + enumerable: true, + get: function () { + return _dependenciesAddGenerated.addDependencies; + } +}); +Object.defineProperty(exports, "addScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesAddScalarGenerated.addScalarDependencies; + } +}); +Object.defineProperty(exports, "all", { + enumerable: true, + get: function () { + return _allFactoriesAny.all; + } +}); +Object.defineProperty(exports, "andDependencies", { + enumerable: true, + get: function () { + return _dependenciesAndGenerated.andDependencies; + } +}); +Object.defineProperty(exports, "andTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesAndTransformGenerated.andTransformDependencies; + } +}); +Object.defineProperty(exports, "applyDependencies", { + enumerable: true, + get: function () { + return _dependenciesApplyGenerated.applyDependencies; + } +}); +Object.defineProperty(exports, "applyTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesApplyTransformGenerated.applyTransformDependencies; + } +}); +Object.defineProperty(exports, "argDependencies", { + enumerable: true, + get: function () { + return _dependenciesArgGenerated.argDependencies; + } +}); +Object.defineProperty(exports, "asecDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsecGenerated.asecDependencies; + } +}); +Object.defineProperty(exports, "asechDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsechGenerated.asechDependencies; + } +}); +Object.defineProperty(exports, "asinDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsinGenerated.asinDependencies; + } +}); +Object.defineProperty(exports, "asinhDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsinhGenerated.asinhDependencies; + } +}); +Object.defineProperty(exports, "atan2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesAtan2Generated.atan2Dependencies; + } +}); +Object.defineProperty(exports, "atanDependencies", { + enumerable: true, + get: function () { + return _dependenciesAtanGenerated.atanDependencies; + } +}); +Object.defineProperty(exports, "atanhDependencies", { + enumerable: true, + get: function () { + return _dependenciesAtanhGenerated.atanhDependencies; + } +}); +Object.defineProperty(exports, "atomicMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesAtomicMassGenerated.atomicMassDependencies; + } +}); +Object.defineProperty(exports, "avogadroDependencies", { + enumerable: true, + get: function () { + return _dependenciesAvogadroGenerated.avogadroDependencies; + } +}); +Object.defineProperty(exports, "bellNumbersDependencies", { + enumerable: true, + get: function () { + return _dependenciesBellNumbersGenerated.bellNumbersDependencies; + } +}); +Object.defineProperty(exports, "bigintDependencies", { + enumerable: true, + get: function () { + return _dependenciesBigintGenerated.bigintDependencies; + } +}); +Object.defineProperty(exports, "bignumberDependencies", { + enumerable: true, + get: function () { + return _dependenciesBignumberGenerated.bignumberDependencies; + } +}); +Object.defineProperty(exports, "binDependencies", { + enumerable: true, + get: function () { + return _dependenciesBinGenerated.binDependencies; + } +}); +Object.defineProperty(exports, "bitAndDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitAndGenerated.bitAndDependencies; + } +}); +Object.defineProperty(exports, "bitAndTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitAndTransformGenerated.bitAndTransformDependencies; + } +}); +Object.defineProperty(exports, "bitNotDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitNotGenerated.bitNotDependencies; + } +}); +Object.defineProperty(exports, "bitOrDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitOrGenerated.bitOrDependencies; + } +}); +Object.defineProperty(exports, "bitOrTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitOrTransformGenerated.bitOrTransformDependencies; + } +}); +Object.defineProperty(exports, "bitXorDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitXorGenerated.bitXorDependencies; + } +}); +Object.defineProperty(exports, "bohrMagnetonDependencies", { + enumerable: true, + get: function () { + return _dependenciesBohrMagnetonGenerated.bohrMagnetonDependencies; + } +}); +Object.defineProperty(exports, "bohrRadiusDependencies", { + enumerable: true, + get: function () { + return _dependenciesBohrRadiusGenerated.bohrRadiusDependencies; + } +}); +Object.defineProperty(exports, "boltzmannDependencies", { + enumerable: true, + get: function () { + return _dependenciesBoltzmannGenerated.boltzmannDependencies; + } +}); +Object.defineProperty(exports, "booleanDependencies", { + enumerable: true, + get: function () { + return _dependenciesBooleanGenerated.booleanDependencies; + } +}); +Object.defineProperty(exports, "catalanDependencies", { + enumerable: true, + get: function () { + return _dependenciesCatalanGenerated.catalanDependencies; + } +}); +Object.defineProperty(exports, "cbrtDependencies", { + enumerable: true, + get: function () { + return _dependenciesCbrtGenerated.cbrtDependencies; + } +}); +Object.defineProperty(exports, "ceilDependencies", { + enumerable: true, + get: function () { + return _dependenciesCeilGenerated.ceilDependencies; + } +}); +Object.defineProperty(exports, "chainDependencies", { + enumerable: true, + get: function () { + return _dependenciesChainGenerated.chainDependencies; + } +}); +Object.defineProperty(exports, "classicalElectronRadiusDependencies", { + enumerable: true, + get: function () { + return _dependenciesClassicalElectronRadiusGenerated.classicalElectronRadiusDependencies; + } +}); +Object.defineProperty(exports, "cloneDependencies", { + enumerable: true, + get: function () { + return _dependenciesCloneGenerated.cloneDependencies; + } +}); +Object.defineProperty(exports, "columnDependencies", { + enumerable: true, + get: function () { + return _dependenciesColumnGenerated.columnDependencies; + } +}); +Object.defineProperty(exports, "columnTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesColumnTransformGenerated.columnTransformDependencies; + } +}); +Object.defineProperty(exports, "combinationsDependencies", { + enumerable: true, + get: function () { + return _dependenciesCombinationsGenerated.combinationsDependencies; + } +}); +Object.defineProperty(exports, "combinationsWithRepDependencies", { + enumerable: true, + get: function () { + return _dependenciesCombinationsWithRepGenerated.combinationsWithRepDependencies; + } +}); +Object.defineProperty(exports, "compareDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareGenerated.compareDependencies; + } +}); +Object.defineProperty(exports, "compareNaturalDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareNaturalGenerated.compareNaturalDependencies; + } +}); +Object.defineProperty(exports, "compareTextDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareTextGenerated.compareTextDependencies; + } +}); +Object.defineProperty(exports, "compileDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompileGenerated.compileDependencies; + } +}); +Object.defineProperty(exports, "complexDependencies", { + enumerable: true, + get: function () { + return _dependenciesComplexGenerated.complexDependencies; + } +}); +Object.defineProperty(exports, "compositionDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompositionGenerated.compositionDependencies; + } +}); +Object.defineProperty(exports, "concatDependencies", { + enumerable: true, + get: function () { + return _dependenciesConcatGenerated.concatDependencies; + } +}); +Object.defineProperty(exports, "concatTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesConcatTransformGenerated.concatTransformDependencies; + } +}); +Object.defineProperty(exports, "conductanceQuantumDependencies", { + enumerable: true, + get: function () { + return _dependenciesConductanceQuantumGenerated.conductanceQuantumDependencies; + } +}); +Object.defineProperty(exports, "conjDependencies", { + enumerable: true, + get: function () { + return _dependenciesConjGenerated.conjDependencies; + } +}); +Object.defineProperty(exports, "corrDependencies", { + enumerable: true, + get: function () { + return _dependenciesCorrGenerated.corrDependencies; + } +}); +Object.defineProperty(exports, "cosDependencies", { + enumerable: true, + get: function () { + return _dependenciesCosGenerated.cosDependencies; + } +}); +Object.defineProperty(exports, "coshDependencies", { + enumerable: true, + get: function () { + return _dependenciesCoshGenerated.coshDependencies; + } +}); +Object.defineProperty(exports, "cotDependencies", { + enumerable: true, + get: function () { + return _dependenciesCotGenerated.cotDependencies; + } +}); +Object.defineProperty(exports, "cothDependencies", { + enumerable: true, + get: function () { + return _dependenciesCothGenerated.cothDependencies; + } +}); +Object.defineProperty(exports, "coulombDependencies", { + enumerable: true, + get: function () { + return _dependenciesCoulombGenerated.coulombDependencies; + } +}); +Object.defineProperty(exports, "countDependencies", { + enumerable: true, + get: function () { + return _dependenciesCountGenerated.countDependencies; + } +}); +Object.defineProperty(exports, "createUnitDependencies", { + enumerable: true, + get: function () { + return _dependenciesCreateUnitGenerated.createUnitDependencies; + } +}); +Object.defineProperty(exports, "crossDependencies", { + enumerable: true, + get: function () { + return _dependenciesCrossGenerated.crossDependencies; + } +}); +Object.defineProperty(exports, "cscDependencies", { + enumerable: true, + get: function () { + return _dependenciesCscGenerated.cscDependencies; + } +}); +Object.defineProperty(exports, "cschDependencies", { + enumerable: true, + get: function () { + return _dependenciesCschGenerated.cschDependencies; + } +}); +Object.defineProperty(exports, "ctransposeDependencies", { + enumerable: true, + get: function () { + return _dependenciesCtransposeGenerated.ctransposeDependencies; + } +}); +Object.defineProperty(exports, "cubeDependencies", { + enumerable: true, + get: function () { + return _dependenciesCubeGenerated.cubeDependencies; + } +}); +Object.defineProperty(exports, "cumsumDependencies", { + enumerable: true, + get: function () { + return _dependenciesCumSumGenerated.cumsumDependencies; + } +}); +Object.defineProperty(exports, "cumsumTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesCumSumTransformGenerated.cumsumTransformDependencies; + } +}); +Object.defineProperty(exports, "deepEqualDependencies", { + enumerable: true, + get: function () { + return _dependenciesDeepEqualGenerated.deepEqualDependencies; + } +}); +Object.defineProperty(exports, "derivativeDependencies", { + enumerable: true, + get: function () { + return _dependenciesDerivativeGenerated.derivativeDependencies; + } +}); +Object.defineProperty(exports, "detDependencies", { + enumerable: true, + get: function () { + return _dependenciesDetGenerated.detDependencies; + } +}); +Object.defineProperty(exports, "deuteronMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesDeuteronMassGenerated.deuteronMassDependencies; + } +}); +Object.defineProperty(exports, "diagDependencies", { + enumerable: true, + get: function () { + return _dependenciesDiagGenerated.diagDependencies; + } +}); +Object.defineProperty(exports, "diffDependencies", { + enumerable: true, + get: function () { + return _dependenciesDiffGenerated.diffDependencies; + } +}); +Object.defineProperty(exports, "diffTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesDiffTransformGenerated.diffTransformDependencies; + } +}); +Object.defineProperty(exports, "distanceDependencies", { + enumerable: true, + get: function () { + return _dependenciesDistanceGenerated.distanceDependencies; + } +}); +Object.defineProperty(exports, "divideDependencies", { + enumerable: true, + get: function () { + return _dependenciesDivideGenerated.divideDependencies; + } +}); +Object.defineProperty(exports, "divideScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesDivideScalarGenerated.divideScalarDependencies; + } +}); +Object.defineProperty(exports, "dotDependencies", { + enumerable: true, + get: function () { + return _dependenciesDotGenerated.dotDependencies; + } +}); +Object.defineProperty(exports, "dotDivideDependencies", { + enumerable: true, + get: function () { + return _dependenciesDotDivideGenerated.dotDivideDependencies; + } +}); +Object.defineProperty(exports, "dotMultiplyDependencies", { + enumerable: true, + get: function () { + return _dependenciesDotMultiplyGenerated.dotMultiplyDependencies; + } +}); +Object.defineProperty(exports, "dotPowDependencies", { + enumerable: true, + get: function () { + return _dependenciesDotPowGenerated.dotPowDependencies; + } +}); +Object.defineProperty(exports, "eDependencies", { + enumerable: true, + get: function () { + return _dependenciesEGenerated.eDependencies; + } +}); +Object.defineProperty(exports, "efimovFactorDependencies", { + enumerable: true, + get: function () { + return _dependenciesEfimovFactorGenerated.efimovFactorDependencies; + } +}); +Object.defineProperty(exports, "eigsDependencies", { + enumerable: true, + get: function () { + return _dependenciesEigsGenerated.eigsDependencies; + } +}); +Object.defineProperty(exports, "electricConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesElectricConstantGenerated.electricConstantDependencies; + } +}); +Object.defineProperty(exports, "electronMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesElectronMassGenerated.electronMassDependencies; + } +}); +Object.defineProperty(exports, "elementaryChargeDependencies", { + enumerable: true, + get: function () { + return _dependenciesElementaryChargeGenerated.elementaryChargeDependencies; + } +}); +Object.defineProperty(exports, "equalDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualGenerated.equalDependencies; + } +}); +Object.defineProperty(exports, "equalScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualScalarGenerated.equalScalarDependencies; + } +}); +Object.defineProperty(exports, "equalTextDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualTextGenerated.equalTextDependencies; + } +}); +Object.defineProperty(exports, "erfDependencies", { + enumerable: true, + get: function () { + return _dependenciesErfGenerated.erfDependencies; + } +}); +Object.defineProperty(exports, "evaluateDependencies", { + enumerable: true, + get: function () { + return _dependenciesEvaluateGenerated.evaluateDependencies; + } +}); +Object.defineProperty(exports, "expDependencies", { + enumerable: true, + get: function () { + return _dependenciesExpGenerated.expDependencies; + } +}); +Object.defineProperty(exports, "expm1Dependencies", { + enumerable: true, + get: function () { + return _dependenciesExpm1Generated.expm1Dependencies; + } +}); +Object.defineProperty(exports, "expmDependencies", { + enumerable: true, + get: function () { + return _dependenciesExpmGenerated.expmDependencies; + } +}); +Object.defineProperty(exports, "factorialDependencies", { + enumerable: true, + get: function () { + return _dependenciesFactorialGenerated.factorialDependencies; + } +}); +Object.defineProperty(exports, "falseDependencies", { + enumerable: true, + get: function () { + return _dependenciesFalseGenerated.falseDependencies; + } +}); +Object.defineProperty(exports, "faradayDependencies", { + enumerable: true, + get: function () { + return _dependenciesFaradayGenerated.faradayDependencies; + } +}); +Object.defineProperty(exports, "fermiCouplingDependencies", { + enumerable: true, + get: function () { + return _dependenciesFermiCouplingGenerated.fermiCouplingDependencies; + } +}); +Object.defineProperty(exports, "fftDependencies", { + enumerable: true, + get: function () { + return _dependenciesFftGenerated.fftDependencies; + } +}); +Object.defineProperty(exports, "filterDependencies", { + enumerable: true, + get: function () { + return _dependenciesFilterGenerated.filterDependencies; + } +}); +Object.defineProperty(exports, "filterTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesFilterTransformGenerated.filterTransformDependencies; + } +}); +Object.defineProperty(exports, "fineStructureDependencies", { + enumerable: true, + get: function () { + return _dependenciesFineStructureGenerated.fineStructureDependencies; + } +}); +Object.defineProperty(exports, "firstRadiationDependencies", { + enumerable: true, + get: function () { + return _dependenciesFirstRadiationGenerated.firstRadiationDependencies; + } +}); +Object.defineProperty(exports, "fixDependencies", { + enumerable: true, + get: function () { + return _dependenciesFixGenerated.fixDependencies; + } +}); +Object.defineProperty(exports, "flattenDependencies", { + enumerable: true, + get: function () { + return _dependenciesFlattenGenerated.flattenDependencies; + } +}); +Object.defineProperty(exports, "floorDependencies", { + enumerable: true, + get: function () { + return _dependenciesFloorGenerated.floorDependencies; + } +}); +Object.defineProperty(exports, "forEachDependencies", { + enumerable: true, + get: function () { + return _dependenciesForEachGenerated.forEachDependencies; + } +}); +Object.defineProperty(exports, "forEachTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesForEachTransformGenerated.forEachTransformDependencies; + } +}); +Object.defineProperty(exports, "formatDependencies", { + enumerable: true, + get: function () { + return _dependenciesFormatGenerated.formatDependencies; + } +}); +Object.defineProperty(exports, "fractionDependencies", { + enumerable: true, + get: function () { + return _dependenciesFractionGenerated.fractionDependencies; + } +}); +Object.defineProperty(exports, "freqzDependencies", { + enumerable: true, + get: function () { + return _dependenciesFreqzGenerated.freqzDependencies; + } +}); +Object.defineProperty(exports, "gammaDependencies", { + enumerable: true, + get: function () { + return _dependenciesGammaGenerated.gammaDependencies; + } +}); +Object.defineProperty(exports, "gasConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesGasConstantGenerated.gasConstantDependencies; + } +}); +Object.defineProperty(exports, "gcdDependencies", { + enumerable: true, + get: function () { + return _dependenciesGcdGenerated.gcdDependencies; + } +}); +Object.defineProperty(exports, "getMatrixDataTypeDependencies", { + enumerable: true, + get: function () { + return _dependenciesGetMatrixDataTypeGenerated.getMatrixDataTypeDependencies; + } +}); +Object.defineProperty(exports, "gravitationConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesGravitationConstantGenerated.gravitationConstantDependencies; + } +}); +Object.defineProperty(exports, "gravityDependencies", { + enumerable: true, + get: function () { + return _dependenciesGravityGenerated.gravityDependencies; + } +}); +Object.defineProperty(exports, "hartreeEnergyDependencies", { + enumerable: true, + get: function () { + return _dependenciesHartreeEnergyGenerated.hartreeEnergyDependencies; + } +}); +Object.defineProperty(exports, "hasNumericValueDependencies", { + enumerable: true, + get: function () { + return _dependenciesHasNumericValueGenerated.hasNumericValueDependencies; + } +}); +Object.defineProperty(exports, "helpDependencies", { + enumerable: true, + get: function () { + return _dependenciesHelpGenerated.helpDependencies; + } +}); +Object.defineProperty(exports, "hexDependencies", { + enumerable: true, + get: function () { + return _dependenciesHexGenerated.hexDependencies; + } +}); +Object.defineProperty(exports, "hypotDependencies", { + enumerable: true, + get: function () { + return _dependenciesHypotGenerated.hypotDependencies; + } +}); +Object.defineProperty(exports, "iDependencies", { + enumerable: true, + get: function () { + return _dependenciesIGenerated.iDependencies; + } +}); +Object.defineProperty(exports, "identityDependencies", { + enumerable: true, + get: function () { + return _dependenciesIdentityGenerated.identityDependencies; + } +}); +Object.defineProperty(exports, "ifftDependencies", { + enumerable: true, + get: function () { + return _dependenciesIfftGenerated.ifftDependencies; + } +}); +Object.defineProperty(exports, "imDependencies", { + enumerable: true, + get: function () { + return _dependenciesImGenerated.imDependencies; + } +}); +Object.defineProperty(exports, "indexDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexGenerated.indexDependencies; + } +}); +Object.defineProperty(exports, "indexTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexTransformGenerated.indexTransformDependencies; + } +}); +Object.defineProperty(exports, "intersectDependencies", { + enumerable: true, + get: function () { + return _dependenciesIntersectGenerated.intersectDependencies; + } +}); +Object.defineProperty(exports, "invDependencies", { + enumerable: true, + get: function () { + return _dependenciesInvGenerated.invDependencies; + } +}); +Object.defineProperty(exports, "inverseConductanceQuantumDependencies", { + enumerable: true, + get: function () { + return _dependenciesInverseConductanceQuantumGenerated.inverseConductanceQuantumDependencies; + } +}); +Object.defineProperty(exports, "invmodDependencies", { + enumerable: true, + get: function () { + return _dependenciesInvmodGenerated.invmodDependencies; + } +}); +Object.defineProperty(exports, "isIntegerDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsIntegerGenerated.isIntegerDependencies; + } +}); +Object.defineProperty(exports, "isNaNDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNaNGenerated.isNaNDependencies; + } +}); +Object.defineProperty(exports, "isNegativeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNegativeGenerated.isNegativeDependencies; + } +}); +Object.defineProperty(exports, "isNumericDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNumericGenerated.isNumericDependencies; + } +}); +Object.defineProperty(exports, "isPositiveDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsPositiveGenerated.isPositiveDependencies; + } +}); +Object.defineProperty(exports, "isPrimeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsPrimeGenerated.isPrimeDependencies; + } +}); +Object.defineProperty(exports, "isZeroDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsZeroGenerated.isZeroDependencies; + } +}); +Object.defineProperty(exports, "kldivergenceDependencies", { + enumerable: true, + get: function () { + return _dependenciesKldivergenceGenerated.kldivergenceDependencies; + } +}); +Object.defineProperty(exports, "klitzingDependencies", { + enumerable: true, + get: function () { + return _dependenciesKlitzingGenerated.klitzingDependencies; + } +}); +Object.defineProperty(exports, "kronDependencies", { + enumerable: true, + get: function () { + return _dependenciesKronGenerated.kronDependencies; + } +}); +Object.defineProperty(exports, "largerDependencies", { + enumerable: true, + get: function () { + return _dependenciesLargerGenerated.largerDependencies; + } +}); +Object.defineProperty(exports, "largerEqDependencies", { + enumerable: true, + get: function () { + return _dependenciesLargerEqGenerated.largerEqDependencies; + } +}); +Object.defineProperty(exports, "lcmDependencies", { + enumerable: true, + get: function () { + return _dependenciesLcmGenerated.lcmDependencies; + } +}); +Object.defineProperty(exports, "leafCountDependencies", { + enumerable: true, + get: function () { + return _dependenciesLeafCountGenerated.leafCountDependencies; + } +}); +Object.defineProperty(exports, "leftShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesLeftShiftGenerated.leftShiftDependencies; + } +}); +Object.defineProperty(exports, "lgammaDependencies", { + enumerable: true, + get: function () { + return _dependenciesLgammaGenerated.lgammaDependencies; + } +}); +Object.defineProperty(exports, "log10Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLog10Generated.log10Dependencies; + } +}); +Object.defineProperty(exports, "log1pDependencies", { + enumerable: true, + get: function () { + return _dependenciesLog1pGenerated.log1pDependencies; + } +}); +Object.defineProperty(exports, "log2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLog2Generated.log2Dependencies; + } +}); +Object.defineProperty(exports, "logDependencies", { + enumerable: true, + get: function () { + return _dependenciesLogGenerated.logDependencies; + } +}); +Object.defineProperty(exports, "loschmidtDependencies", { + enumerable: true, + get: function () { + return _dependenciesLoschmidtGenerated.loschmidtDependencies; + } +}); +Object.defineProperty(exports, "lsolveAllDependencies", { + enumerable: true, + get: function () { + return _dependenciesLsolveAllGenerated.lsolveAllDependencies; + } +}); +Object.defineProperty(exports, "lsolveDependencies", { + enumerable: true, + get: function () { + return _dependenciesLsolveGenerated.lsolveDependencies; + } +}); +Object.defineProperty(exports, "lupDependencies", { + enumerable: true, + get: function () { + return _dependenciesLupGenerated.lupDependencies; + } +}); +Object.defineProperty(exports, "lusolveDependencies", { + enumerable: true, + get: function () { + return _dependenciesLusolveGenerated.lusolveDependencies; + } +}); +Object.defineProperty(exports, "lyapDependencies", { + enumerable: true, + get: function () { + return _dependenciesLyapGenerated.lyapDependencies; + } +}); +Object.defineProperty(exports, "madDependencies", { + enumerable: true, + get: function () { + return _dependenciesMadGenerated.madDependencies; + } +}); +Object.defineProperty(exports, "magneticConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesMagneticConstantGenerated.magneticConstantDependencies; + } +}); +Object.defineProperty(exports, "magneticFluxQuantumDependencies", { + enumerable: true, + get: function () { + return _dependenciesMagneticFluxQuantumGenerated.magneticFluxQuantumDependencies; + } +}); +Object.defineProperty(exports, "mapDependencies", { + enumerable: true, + get: function () { + return _dependenciesMapGenerated.mapDependencies; + } +}); +Object.defineProperty(exports, "mapTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMapTransformGenerated.mapTransformDependencies; + } +}); +Object.defineProperty(exports, "matrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixGenerated.matrixDependencies; + } +}); +Object.defineProperty(exports, "matrixFromColumnsDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixFromColumnsGenerated.matrixFromColumnsDependencies; + } +}); +Object.defineProperty(exports, "matrixFromFunctionDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixFromFunctionGenerated.matrixFromFunctionDependencies; + } +}); +Object.defineProperty(exports, "matrixFromRowsDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixFromRowsGenerated.matrixFromRowsDependencies; + } +}); +Object.defineProperty(exports, "maxDependencies", { + enumerable: true, + get: function () { + return _dependenciesMaxGenerated.maxDependencies; + } +}); +Object.defineProperty(exports, "maxTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMaxTransformGenerated.maxTransformDependencies; + } +}); +Object.defineProperty(exports, "meanDependencies", { + enumerable: true, + get: function () { + return _dependenciesMeanGenerated.meanDependencies; + } +}); +Object.defineProperty(exports, "meanTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMeanTransformGenerated.meanTransformDependencies; + } +}); +Object.defineProperty(exports, "medianDependencies", { + enumerable: true, + get: function () { + return _dependenciesMedianGenerated.medianDependencies; + } +}); +Object.defineProperty(exports, "minDependencies", { + enumerable: true, + get: function () { + return _dependenciesMinGenerated.minDependencies; + } +}); +Object.defineProperty(exports, "minTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMinTransformGenerated.minTransformDependencies; + } +}); +Object.defineProperty(exports, "modDependencies", { + enumerable: true, + get: function () { + return _dependenciesModGenerated.modDependencies; + } +}); +Object.defineProperty(exports, "modeDependencies", { + enumerable: true, + get: function () { + return _dependenciesModeGenerated.modeDependencies; + } +}); +Object.defineProperty(exports, "molarMassC12Dependencies", { + enumerable: true, + get: function () { + return _dependenciesMolarMassC12Generated.molarMassC12Dependencies; + } +}); +Object.defineProperty(exports, "molarMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesMolarMassGenerated.molarMassDependencies; + } +}); +Object.defineProperty(exports, "molarPlanckConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesMolarPlanckConstantGenerated.molarPlanckConstantDependencies; + } +}); +Object.defineProperty(exports, "molarVolumeDependencies", { + enumerable: true, + get: function () { + return _dependenciesMolarVolumeGenerated.molarVolumeDependencies; + } +}); +Object.defineProperty(exports, "multinomialDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultinomialGenerated.multinomialDependencies; + } +}); +Object.defineProperty(exports, "multiplyDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultiplyGenerated.multiplyDependencies; + } +}); +Object.defineProperty(exports, "multiplyScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies; + } +}); +Object.defineProperty(exports, "neutronMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesNeutronMassGenerated.neutronMassDependencies; + } +}); +Object.defineProperty(exports, "normDependencies", { + enumerable: true, + get: function () { + return _dependenciesNormGenerated.normDependencies; + } +}); +Object.defineProperty(exports, "notDependencies", { + enumerable: true, + get: function () { + return _dependenciesNotGenerated.notDependencies; + } +}); +Object.defineProperty(exports, "nthRootDependencies", { + enumerable: true, + get: function () { + return _dependenciesNthRootGenerated.nthRootDependencies; + } +}); +Object.defineProperty(exports, "nthRootsDependencies", { + enumerable: true, + get: function () { + return _dependenciesNthRootsGenerated.nthRootsDependencies; + } +}); +Object.defineProperty(exports, "nuclearMagnetonDependencies", { + enumerable: true, + get: function () { + return _dependenciesNuclearMagnetonGenerated.nuclearMagnetonDependencies; + } +}); +Object.defineProperty(exports, "nullDependencies", { + enumerable: true, + get: function () { + return _dependenciesNullGenerated.nullDependencies; + } +}); +Object.defineProperty(exports, "numberDependencies", { + enumerable: true, + get: function () { + return _dependenciesNumberGenerated.numberDependencies; + } +}); +Object.defineProperty(exports, "numericDependencies", { + enumerable: true, + get: function () { + return _dependenciesNumericGenerated.numericDependencies; + } +}); +Object.defineProperty(exports, "octDependencies", { + enumerable: true, + get: function () { + return _dependenciesOctGenerated.octDependencies; + } +}); +Object.defineProperty(exports, "onesDependencies", { + enumerable: true, + get: function () { + return _dependenciesOnesGenerated.onesDependencies; + } +}); +Object.defineProperty(exports, "orDependencies", { + enumerable: true, + get: function () { + return _dependenciesOrGenerated.orDependencies; + } +}); +Object.defineProperty(exports, "orTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesOrTransformGenerated.orTransformDependencies; + } +}); +Object.defineProperty(exports, "parseDependencies", { + enumerable: true, + get: function () { + return _dependenciesParseGenerated.parseDependencies; + } +}); +Object.defineProperty(exports, "parserDependencies", { + enumerable: true, + get: function () { + return _dependenciesParserGenerated.parserDependencies; + } +}); +Object.defineProperty(exports, "partitionSelectDependencies", { + enumerable: true, + get: function () { + return _dependenciesPartitionSelectGenerated.partitionSelectDependencies; + } +}); +Object.defineProperty(exports, "permutationsDependencies", { + enumerable: true, + get: function () { + return _dependenciesPermutationsGenerated.permutationsDependencies; + } +}); +Object.defineProperty(exports, "phiDependencies", { + enumerable: true, + get: function () { + return _dependenciesPhiGenerated.phiDependencies; + } +}); +Object.defineProperty(exports, "piDependencies", { + enumerable: true, + get: function () { + return _dependenciesPiGenerated.piDependencies; + } +}); +Object.defineProperty(exports, "pickRandomDependencies", { + enumerable: true, + get: function () { + return _dependenciesPickRandomGenerated.pickRandomDependencies; + } +}); +Object.defineProperty(exports, "pinvDependencies", { + enumerable: true, + get: function () { + return _dependenciesPinvGenerated.pinvDependencies; + } +}); +Object.defineProperty(exports, "planckChargeDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckChargeGenerated.planckChargeDependencies; + } +}); +Object.defineProperty(exports, "planckConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckConstantGenerated.planckConstantDependencies; + } +}); +Object.defineProperty(exports, "planckLengthDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckLengthGenerated.planckLengthDependencies; + } +}); +Object.defineProperty(exports, "planckMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckMassGenerated.planckMassDependencies; + } +}); +Object.defineProperty(exports, "planckTemperatureDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckTemperatureGenerated.planckTemperatureDependencies; + } +}); +Object.defineProperty(exports, "planckTimeDependencies", { + enumerable: true, + get: function () { + return _dependenciesPlanckTimeGenerated.planckTimeDependencies; + } +}); +Object.defineProperty(exports, "polynomialRootDependencies", { + enumerable: true, + get: function () { + return _dependenciesPolynomialRootGenerated.polynomialRootDependencies; + } +}); +Object.defineProperty(exports, "powDependencies", { + enumerable: true, + get: function () { + return _dependenciesPowGenerated.powDependencies; + } +}); +Object.defineProperty(exports, "printDependencies", { + enumerable: true, + get: function () { + return _dependenciesPrintGenerated.printDependencies; + } +}); +Object.defineProperty(exports, "printTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesPrintTransformGenerated.printTransformDependencies; + } +}); +Object.defineProperty(exports, "prodDependencies", { + enumerable: true, + get: function () { + return _dependenciesProdGenerated.prodDependencies; + } +}); +Object.defineProperty(exports, "protonMassDependencies", { + enumerable: true, + get: function () { + return _dependenciesProtonMassGenerated.protonMassDependencies; + } +}); +Object.defineProperty(exports, "qrDependencies", { + enumerable: true, + get: function () { + return _dependenciesQrGenerated.qrDependencies; + } +}); +Object.defineProperty(exports, "quantileSeqDependencies", { + enumerable: true, + get: function () { + return _dependenciesQuantileSeqGenerated.quantileSeqDependencies; + } +}); +Object.defineProperty(exports, "quantileSeqTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesQuantileSeqTransformGenerated.quantileSeqTransformDependencies; + } +}); +Object.defineProperty(exports, "quantumOfCirculationDependencies", { + enumerable: true, + get: function () { + return _dependenciesQuantumOfCirculationGenerated.quantumOfCirculationDependencies; + } +}); +Object.defineProperty(exports, "randomDependencies", { + enumerable: true, + get: function () { + return _dependenciesRandomGenerated.randomDependencies; + } +}); +Object.defineProperty(exports, "randomIntDependencies", { + enumerable: true, + get: function () { + return _dependenciesRandomIntGenerated.randomIntDependencies; + } +}); +Object.defineProperty(exports, "rangeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeGenerated.rangeDependencies; + } +}); +Object.defineProperty(exports, "rangeTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeTransformGenerated.rangeTransformDependencies; + } +}); +Object.defineProperty(exports, "rationalizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRationalizeGenerated.rationalizeDependencies; + } +}); +Object.defineProperty(exports, "reDependencies", { + enumerable: true, + get: function () { + return _dependenciesReGenerated.reDependencies; + } +}); +Object.defineProperty(exports, "reducedPlanckConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesReducedPlanckConstantGenerated.reducedPlanckConstantDependencies; + } +}); +Object.defineProperty(exports, "replacerDependencies", { + enumerable: true, + get: function () { + return _dependenciesReplacerGenerated.replacerDependencies; + } +}); +Object.defineProperty(exports, "reshapeDependencies", { + enumerable: true, + get: function () { + return _dependenciesReshapeGenerated.reshapeDependencies; + } +}); +Object.defineProperty(exports, "resizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesResizeGenerated.resizeDependencies; + } +}); +Object.defineProperty(exports, "resolveDependencies", { + enumerable: true, + get: function () { + return _dependenciesResolveGenerated.resolveDependencies; + } +}); +Object.defineProperty(exports, "reviverDependencies", { + enumerable: true, + get: function () { + return _dependenciesReviverGenerated.reviverDependencies; + } +}); +Object.defineProperty(exports, "rightArithShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesRightArithShiftGenerated.rightArithShiftDependencies; + } +}); +Object.defineProperty(exports, "rightLogShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesRightLogShiftGenerated.rightLogShiftDependencies; + } +}); +Object.defineProperty(exports, "rotateDependencies", { + enumerable: true, + get: function () { + return _dependenciesRotateGenerated.rotateDependencies; + } +}); +Object.defineProperty(exports, "rotationMatrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesRotationMatrixGenerated.rotationMatrixDependencies; + } +}); +Object.defineProperty(exports, "roundDependencies", { + enumerable: true, + get: function () { + return _dependenciesRoundGenerated.roundDependencies; + } +}); +Object.defineProperty(exports, "rowDependencies", { + enumerable: true, + get: function () { + return _dependenciesRowGenerated.rowDependencies; + } +}); +Object.defineProperty(exports, "rowTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesRowTransformGenerated.rowTransformDependencies; + } +}); +Object.defineProperty(exports, "rydbergDependencies", { + enumerable: true, + get: function () { + return _dependenciesRydbergGenerated.rydbergDependencies; + } +}); +Object.defineProperty(exports, "sackurTetrodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSackurTetrodeGenerated.sackurTetrodeDependencies; + } +}); +Object.defineProperty(exports, "schurDependencies", { + enumerable: true, + get: function () { + return _dependenciesSchurGenerated.schurDependencies; + } +}); +Object.defineProperty(exports, "secDependencies", { + enumerable: true, + get: function () { + return _dependenciesSecGenerated.secDependencies; + } +}); +Object.defineProperty(exports, "sechDependencies", { + enumerable: true, + get: function () { + return _dependenciesSechGenerated.sechDependencies; + } +}); +Object.defineProperty(exports, "secondRadiationDependencies", { + enumerable: true, + get: function () { + return _dependenciesSecondRadiationGenerated.secondRadiationDependencies; + } +}); +Object.defineProperty(exports, "setCartesianDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetCartesianGenerated.setCartesianDependencies; + } +}); +Object.defineProperty(exports, "setDifferenceDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetDifferenceGenerated.setDifferenceDependencies; + } +}); +Object.defineProperty(exports, "setDistinctDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetDistinctGenerated.setDistinctDependencies; + } +}); +Object.defineProperty(exports, "setIntersectDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetIntersectGenerated.setIntersectDependencies; + } +}); +Object.defineProperty(exports, "setIsSubsetDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetIsSubsetGenerated.setIsSubsetDependencies; + } +}); +Object.defineProperty(exports, "setMultiplicityDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetMultiplicityGenerated.setMultiplicityDependencies; + } +}); +Object.defineProperty(exports, "setPowersetDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetPowersetGenerated.setPowersetDependencies; + } +}); +Object.defineProperty(exports, "setSizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetSizeGenerated.setSizeDependencies; + } +}); +Object.defineProperty(exports, "setSymDifferenceDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetSymDifferenceGenerated.setSymDifferenceDependencies; + } +}); +Object.defineProperty(exports, "setUnionDependencies", { + enumerable: true, + get: function () { + return _dependenciesSetUnionGenerated.setUnionDependencies; + } +}); +Object.defineProperty(exports, "signDependencies", { + enumerable: true, + get: function () { + return _dependenciesSignGenerated.signDependencies; + } +}); +Object.defineProperty(exports, "simplifyConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies; + } +}); +Object.defineProperty(exports, "simplifyCoreDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies; + } +}); +Object.defineProperty(exports, "simplifyDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyGenerated.simplifyDependencies; + } +}); +Object.defineProperty(exports, "sinDependencies", { + enumerable: true, + get: function () { + return _dependenciesSinGenerated.sinDependencies; + } +}); +Object.defineProperty(exports, "sinhDependencies", { + enumerable: true, + get: function () { + return _dependenciesSinhGenerated.sinhDependencies; + } +}); +Object.defineProperty(exports, "sizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSizeGenerated.sizeDependencies; + } +}); +Object.defineProperty(exports, "sluDependencies", { + enumerable: true, + get: function () { + return _dependenciesSluGenerated.sluDependencies; + } +}); +Object.defineProperty(exports, "smallerDependencies", { + enumerable: true, + get: function () { + return _dependenciesSmallerGenerated.smallerDependencies; + } +}); +Object.defineProperty(exports, "smallerEqDependencies", { + enumerable: true, + get: function () { + return _dependenciesSmallerEqGenerated.smallerEqDependencies; + } +}); +Object.defineProperty(exports, "solveODEDependencies", { + enumerable: true, + get: function () { + return _dependenciesSolveODEGenerated.solveODEDependencies; + } +}); +Object.defineProperty(exports, "sortDependencies", { + enumerable: true, + get: function () { + return _dependenciesSortGenerated.sortDependencies; + } +}); +Object.defineProperty(exports, "sparseDependencies", { + enumerable: true, + get: function () { + return _dependenciesSparseGenerated.sparseDependencies; + } +}); +Object.defineProperty(exports, "speedOfLightDependencies", { + enumerable: true, + get: function () { + return _dependenciesSpeedOfLightGenerated.speedOfLightDependencies; + } +}); +Object.defineProperty(exports, "splitUnitDependencies", { + enumerable: true, + get: function () { + return _dependenciesSplitUnitGenerated.splitUnitDependencies; + } +}); +Object.defineProperty(exports, "sqrtDependencies", { + enumerable: true, + get: function () { + return _dependenciesSqrtGenerated.sqrtDependencies; + } +}); +Object.defineProperty(exports, "sqrtmDependencies", { + enumerable: true, + get: function () { + return _dependenciesSqrtmGenerated.sqrtmDependencies; + } +}); +Object.defineProperty(exports, "squareDependencies", { + enumerable: true, + get: function () { + return _dependenciesSquareGenerated.squareDependencies; + } +}); +Object.defineProperty(exports, "squeezeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSqueezeGenerated.squeezeDependencies; + } +}); +Object.defineProperty(exports, "stdDependencies", { + enumerable: true, + get: function () { + return _dependenciesStdGenerated.stdDependencies; + } +}); +Object.defineProperty(exports, "stdTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesStdTransformGenerated.stdTransformDependencies; + } +}); +Object.defineProperty(exports, "stefanBoltzmannDependencies", { + enumerable: true, + get: function () { + return _dependenciesStefanBoltzmannGenerated.stefanBoltzmannDependencies; + } +}); +Object.defineProperty(exports, "stirlingS2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesStirlingS2Generated.stirlingS2Dependencies; + } +}); +Object.defineProperty(exports, "stringDependencies", { + enumerable: true, + get: function () { + return _dependenciesStringGenerated.stringDependencies; + } +}); +Object.defineProperty(exports, "subsetDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubsetGenerated.subsetDependencies; + } +}); +Object.defineProperty(exports, "subsetTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubsetTransformGenerated.subsetTransformDependencies; + } +}); +Object.defineProperty(exports, "subtractDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubtractGenerated.subtractDependencies; + } +}); +Object.defineProperty(exports, "subtractScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubtractScalarGenerated.subtractScalarDependencies; + } +}); +Object.defineProperty(exports, "sumDependencies", { + enumerable: true, + get: function () { + return _dependenciesSumGenerated.sumDependencies; + } +}); +Object.defineProperty(exports, "sumTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesSumTransformGenerated.sumTransformDependencies; + } +}); +Object.defineProperty(exports, "sylvesterDependencies", { + enumerable: true, + get: function () { + return _dependenciesSylvesterGenerated.sylvesterDependencies; + } +}); +Object.defineProperty(exports, "symbolicEqualDependencies", { + enumerable: true, + get: function () { + return _dependenciesSymbolicEqualGenerated.symbolicEqualDependencies; + } +}); +Object.defineProperty(exports, "tanDependencies", { + enumerable: true, + get: function () { + return _dependenciesTanGenerated.tanDependencies; + } +}); +Object.defineProperty(exports, "tanhDependencies", { + enumerable: true, + get: function () { + return _dependenciesTanhGenerated.tanhDependencies; + } +}); +Object.defineProperty(exports, "tauDependencies", { + enumerable: true, + get: function () { + return _dependenciesTauGenerated.tauDependencies; + } +}); +Object.defineProperty(exports, "thomsonCrossSectionDependencies", { + enumerable: true, + get: function () { + return _dependenciesThomsonCrossSectionGenerated.thomsonCrossSectionDependencies; + } +}); +Object.defineProperty(exports, "toDependencies", { + enumerable: true, + get: function () { + return _dependenciesToGenerated.toDependencies; + } +}); +Object.defineProperty(exports, "traceDependencies", { + enumerable: true, + get: function () { + return _dependenciesTraceGenerated.traceDependencies; + } +}); +Object.defineProperty(exports, "transposeDependencies", { + enumerable: true, + get: function () { + return _dependenciesTransposeGenerated.transposeDependencies; + } +}); +Object.defineProperty(exports, "trueDependencies", { + enumerable: true, + get: function () { + return _dependenciesTrueGenerated.trueDependencies; + } +}); +Object.defineProperty(exports, "typeOfDependencies", { + enumerable: true, + get: function () { + return _dependenciesTypeOfGenerated.typeOfDependencies; + } +}); +Object.defineProperty(exports, "typedDependencies", { + enumerable: true, + get: function () { + return _dependenciesTypedGenerated.typedDependencies; + } +}); +Object.defineProperty(exports, "unaryMinusDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnaryMinusGenerated.unaryMinusDependencies; + } +}); +Object.defineProperty(exports, "unaryPlusDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnaryPlusGenerated.unaryPlusDependencies; + } +}); +Object.defineProperty(exports, "unequalDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnequalGenerated.unequalDependencies; + } +}); +Object.defineProperty(exports, "unitDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnitFunctionGenerated.unitDependencies; + } +}); +Object.defineProperty(exports, "usolveAllDependencies", { + enumerable: true, + get: function () { + return _dependenciesUsolveAllGenerated.usolveAllDependencies; + } +}); +Object.defineProperty(exports, "usolveDependencies", { + enumerable: true, + get: function () { + return _dependenciesUsolveGenerated.usolveDependencies; + } +}); +Object.defineProperty(exports, "vacuumImpedanceDependencies", { + enumerable: true, + get: function () { + return _dependenciesVacuumImpedanceGenerated.vacuumImpedanceDependencies; + } +}); +Object.defineProperty(exports, "varianceDependencies", { + enumerable: true, + get: function () { + return _dependenciesVarianceGenerated.varianceDependencies; + } +}); +Object.defineProperty(exports, "varianceTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesVarianceTransformGenerated.varianceTransformDependencies; + } +}); +Object.defineProperty(exports, "versionDependencies", { + enumerable: true, + get: function () { + return _dependenciesVersionGenerated.versionDependencies; + } +}); +Object.defineProperty(exports, "weakMixingAngleDependencies", { + enumerable: true, + get: function () { + return _dependenciesWeakMixingAngleGenerated.weakMixingAngleDependencies; + } +}); +Object.defineProperty(exports, "wienDisplacementDependencies", { + enumerable: true, + get: function () { + return _dependenciesWienDisplacementGenerated.wienDisplacementDependencies; + } +}); +Object.defineProperty(exports, "xgcdDependencies", { + enumerable: true, + get: function () { + return _dependenciesXgcdGenerated.xgcdDependencies; + } +}); +Object.defineProperty(exports, "xorDependencies", { + enumerable: true, + get: function () { + return _dependenciesXorGenerated.xorDependencies; + } +}); +Object.defineProperty(exports, "zerosDependencies", { + enumerable: true, + get: function () { + return _dependenciesZerosGenerated.zerosDependencies; + } +}); +Object.defineProperty(exports, "zetaDependencies", { + enumerable: true, + get: function () { + return _dependenciesZetaGenerated.zetaDependencies; + } +}); +Object.defineProperty(exports, "zpk2tfDependencies", { + enumerable: true, + get: function () { + return _dependenciesZpk2tfGenerated.zpk2tfDependencies; + } +}); +var _dependenciesAbsGenerated = require("./dependenciesAny/dependenciesAbs.generated.js"); +var _dependenciesAccessorNodeGenerated = require("./dependenciesAny/dependenciesAccessorNode.generated.js"); +var _dependenciesAcosGenerated = require("./dependenciesAny/dependenciesAcos.generated.js"); +var _dependenciesAcoshGenerated = require("./dependenciesAny/dependenciesAcosh.generated.js"); +var _dependenciesAcotGenerated = require("./dependenciesAny/dependenciesAcot.generated.js"); +var _dependenciesAcothGenerated = require("./dependenciesAny/dependenciesAcoth.generated.js"); +var _dependenciesAcscGenerated = require("./dependenciesAny/dependenciesAcsc.generated.js"); +var _dependenciesAcschGenerated = require("./dependenciesAny/dependenciesAcsch.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAny/dependenciesAdd.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAny/dependenciesAddScalar.generated.js"); +var _dependenciesAndGenerated = require("./dependenciesAny/dependenciesAnd.generated.js"); +var _dependenciesAndTransformGenerated = require("./dependenciesAny/dependenciesAndTransform.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesAny/dependenciesApply.generated.js"); +var _dependenciesApplyTransformGenerated = require("./dependenciesAny/dependenciesApplyTransform.generated.js"); +var _dependenciesArgGenerated = require("./dependenciesAny/dependenciesArg.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesAny/dependenciesArrayNode.generated.js"); +var _dependenciesAsecGenerated = require("./dependenciesAny/dependenciesAsec.generated.js"); +var _dependenciesAsechGenerated = require("./dependenciesAny/dependenciesAsech.generated.js"); +var _dependenciesAsinGenerated = require("./dependenciesAny/dependenciesAsin.generated.js"); +var _dependenciesAsinhGenerated = require("./dependenciesAny/dependenciesAsinh.generated.js"); +var _dependenciesAssignmentNodeGenerated = require("./dependenciesAny/dependenciesAssignmentNode.generated.js"); +var _dependenciesAtanGenerated = require("./dependenciesAny/dependenciesAtan.generated.js"); +var _dependenciesAtan2Generated = require("./dependenciesAny/dependenciesAtan2.generated.js"); +var _dependenciesAtanhGenerated = require("./dependenciesAny/dependenciesAtanh.generated.js"); +var _dependenciesAtomicMassGenerated = require("./dependenciesAny/dependenciesAtomicMass.generated.js"); +var _dependenciesAvogadroGenerated = require("./dependenciesAny/dependenciesAvogadro.generated.js"); +var _dependenciesBellNumbersGenerated = require("./dependenciesAny/dependenciesBellNumbers.generated.js"); +var _dependenciesBigNumberClassGenerated = require("./dependenciesAny/dependenciesBigNumberClass.generated.js"); +var _dependenciesBigintGenerated = require("./dependenciesAny/dependenciesBigint.generated.js"); +var _dependenciesBignumberGenerated = require("./dependenciesAny/dependenciesBignumber.generated.js"); +var _dependenciesBinGenerated = require("./dependenciesAny/dependenciesBin.generated.js"); +var _dependenciesBitAndGenerated = require("./dependenciesAny/dependenciesBitAnd.generated.js"); +var _dependenciesBitAndTransformGenerated = require("./dependenciesAny/dependenciesBitAndTransform.generated.js"); +var _dependenciesBitNotGenerated = require("./dependenciesAny/dependenciesBitNot.generated.js"); +var _dependenciesBitOrGenerated = require("./dependenciesAny/dependenciesBitOr.generated.js"); +var _dependenciesBitOrTransformGenerated = require("./dependenciesAny/dependenciesBitOrTransform.generated.js"); +var _dependenciesBitXorGenerated = require("./dependenciesAny/dependenciesBitXor.generated.js"); +var _dependenciesBlockNodeGenerated = require("./dependenciesAny/dependenciesBlockNode.generated.js"); +var _dependenciesBohrMagnetonGenerated = require("./dependenciesAny/dependenciesBohrMagneton.generated.js"); +var _dependenciesBohrRadiusGenerated = require("./dependenciesAny/dependenciesBohrRadius.generated.js"); +var _dependenciesBoltzmannGenerated = require("./dependenciesAny/dependenciesBoltzmann.generated.js"); +var _dependenciesBooleanGenerated = require("./dependenciesAny/dependenciesBoolean.generated.js"); +var _dependenciesCatalanGenerated = require("./dependenciesAny/dependenciesCatalan.generated.js"); +var _dependenciesCbrtGenerated = require("./dependenciesAny/dependenciesCbrt.generated.js"); +var _dependenciesCeilGenerated = require("./dependenciesAny/dependenciesCeil.generated.js"); +var _dependenciesChainGenerated = require("./dependenciesAny/dependenciesChain.generated.js"); +var _dependenciesChainClassGenerated = require("./dependenciesAny/dependenciesChainClass.generated.js"); +var _dependenciesClassicalElectronRadiusGenerated = require("./dependenciesAny/dependenciesClassicalElectronRadius.generated.js"); +var _dependenciesCloneGenerated = require("./dependenciesAny/dependenciesClone.generated.js"); +var _dependenciesColumnGenerated = require("./dependenciesAny/dependenciesColumn.generated.js"); +var _dependenciesColumnTransformGenerated = require("./dependenciesAny/dependenciesColumnTransform.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesAny/dependenciesCombinations.generated.js"); +var _dependenciesCombinationsWithRepGenerated = require("./dependenciesAny/dependenciesCombinationsWithRep.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesAny/dependenciesCompare.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesAny/dependenciesCompareNatural.generated.js"); +var _dependenciesCompareTextGenerated = require("./dependenciesAny/dependenciesCompareText.generated.js"); +var _dependenciesCompileGenerated = require("./dependenciesAny/dependenciesCompile.generated.js"); +var _dependenciesComplexGenerated = require("./dependenciesAny/dependenciesComplex.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesAny/dependenciesComplexClass.generated.js"); +var _dependenciesCompositionGenerated = require("./dependenciesAny/dependenciesComposition.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesAny/dependenciesConcat.generated.js"); +var _dependenciesConcatTransformGenerated = require("./dependenciesAny/dependenciesConcatTransform.generated.js"); +var _dependenciesConditionalNodeGenerated = require("./dependenciesAny/dependenciesConditionalNode.generated.js"); +var _dependenciesConductanceQuantumGenerated = require("./dependenciesAny/dependenciesConductanceQuantum.generated.js"); +var _dependenciesConjGenerated = require("./dependenciesAny/dependenciesConj.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesAny/dependenciesConstantNode.generated.js"); +var _dependenciesCorrGenerated = require("./dependenciesAny/dependenciesCorr.generated.js"); +var _dependenciesCosGenerated = require("./dependenciesAny/dependenciesCos.generated.js"); +var _dependenciesCoshGenerated = require("./dependenciesAny/dependenciesCosh.generated.js"); +var _dependenciesCotGenerated = require("./dependenciesAny/dependenciesCot.generated.js"); +var _dependenciesCothGenerated = require("./dependenciesAny/dependenciesCoth.generated.js"); +var _dependenciesCoulombGenerated = require("./dependenciesAny/dependenciesCoulomb.generated.js"); +var _dependenciesCountGenerated = require("./dependenciesAny/dependenciesCount.generated.js"); +var _dependenciesCreateUnitGenerated = require("./dependenciesAny/dependenciesCreateUnit.generated.js"); +var _dependenciesCrossGenerated = require("./dependenciesAny/dependenciesCross.generated.js"); +var _dependenciesCscGenerated = require("./dependenciesAny/dependenciesCsc.generated.js"); +var _dependenciesCschGenerated = require("./dependenciesAny/dependenciesCsch.generated.js"); +var _dependenciesCtransposeGenerated = require("./dependenciesAny/dependenciesCtranspose.generated.js"); +var _dependenciesCubeGenerated = require("./dependenciesAny/dependenciesCube.generated.js"); +var _dependenciesCumSumGenerated = require("./dependenciesAny/dependenciesCumSum.generated.js"); +var _dependenciesCumSumTransformGenerated = require("./dependenciesAny/dependenciesCumSumTransform.generated.js"); +var _dependenciesDeepEqualGenerated = require("./dependenciesAny/dependenciesDeepEqual.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesAny/dependenciesDenseMatrixClass.generated.js"); +var _dependenciesDerivativeGenerated = require("./dependenciesAny/dependenciesDerivative.generated.js"); +var _dependenciesDetGenerated = require("./dependenciesAny/dependenciesDet.generated.js"); +var _dependenciesDeuteronMassGenerated = require("./dependenciesAny/dependenciesDeuteronMass.generated.js"); +var _dependenciesDiagGenerated = require("./dependenciesAny/dependenciesDiag.generated.js"); +var _dependenciesDiffGenerated = require("./dependenciesAny/dependenciesDiff.generated.js"); +var _dependenciesDiffTransformGenerated = require("./dependenciesAny/dependenciesDiffTransform.generated.js"); +var _dependenciesDistanceGenerated = require("./dependenciesAny/dependenciesDistance.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesAny/dependenciesDivide.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesAny/dependenciesDivideScalar.generated.js"); +var _dependenciesDotGenerated = require("./dependenciesAny/dependenciesDot.generated.js"); +var _dependenciesDotDivideGenerated = require("./dependenciesAny/dependenciesDotDivide.generated.js"); +var _dependenciesDotMultiplyGenerated = require("./dependenciesAny/dependenciesDotMultiply.generated.js"); +var _dependenciesDotPowGenerated = require("./dependenciesAny/dependenciesDotPow.generated.js"); +var _dependenciesEGenerated = require("./dependenciesAny/dependenciesE.generated.js"); +var _dependenciesEfimovFactorGenerated = require("./dependenciesAny/dependenciesEfimovFactor.generated.js"); +var _dependenciesEigsGenerated = require("./dependenciesAny/dependenciesEigs.generated.js"); +var _dependenciesElectricConstantGenerated = require("./dependenciesAny/dependenciesElectricConstant.generated.js"); +var _dependenciesElectronMassGenerated = require("./dependenciesAny/dependenciesElectronMass.generated.js"); +var _dependenciesElementaryChargeGenerated = require("./dependenciesAny/dependenciesElementaryCharge.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesAny/dependenciesEqual.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesAny/dependenciesEqualScalar.generated.js"); +var _dependenciesEqualTextGenerated = require("./dependenciesAny/dependenciesEqualText.generated.js"); +var _dependenciesErfGenerated = require("./dependenciesAny/dependenciesErf.generated.js"); +var _dependenciesEvaluateGenerated = require("./dependenciesAny/dependenciesEvaluate.generated.js"); +var _dependenciesExpGenerated = require("./dependenciesAny/dependenciesExp.generated.js"); +var _dependenciesExpmGenerated = require("./dependenciesAny/dependenciesExpm.generated.js"); +var _dependenciesExpm1Generated = require("./dependenciesAny/dependenciesExpm1.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesAny/dependenciesFactorial.generated.js"); +var _dependenciesFalseGenerated = require("./dependenciesAny/dependenciesFalse.generated.js"); +var _dependenciesFaradayGenerated = require("./dependenciesAny/dependenciesFaraday.generated.js"); +var _dependenciesFermiCouplingGenerated = require("./dependenciesAny/dependenciesFermiCoupling.generated.js"); +var _dependenciesFftGenerated = require("./dependenciesAny/dependenciesFft.generated.js"); +var _dependenciesFibonacciHeapClassGenerated = require("./dependenciesAny/dependenciesFibonacciHeapClass.generated.js"); +var _dependenciesFilterGenerated = require("./dependenciesAny/dependenciesFilter.generated.js"); +var _dependenciesFilterTransformGenerated = require("./dependenciesAny/dependenciesFilterTransform.generated.js"); +var _dependenciesFineStructureGenerated = require("./dependenciesAny/dependenciesFineStructure.generated.js"); +var _dependenciesFirstRadiationGenerated = require("./dependenciesAny/dependenciesFirstRadiation.generated.js"); +var _dependenciesFixGenerated = require("./dependenciesAny/dependenciesFix.generated.js"); +var _dependenciesFlattenGenerated = require("./dependenciesAny/dependenciesFlatten.generated.js"); +var _dependenciesFloorGenerated = require("./dependenciesAny/dependenciesFloor.generated.js"); +var _dependenciesForEachGenerated = require("./dependenciesAny/dependenciesForEach.generated.js"); +var _dependenciesForEachTransformGenerated = require("./dependenciesAny/dependenciesForEachTransform.generated.js"); +var _dependenciesFormatGenerated = require("./dependenciesAny/dependenciesFormat.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesAny/dependenciesFraction.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesAny/dependenciesFractionClass.generated.js"); +var _dependenciesFreqzGenerated = require("./dependenciesAny/dependenciesFreqz.generated.js"); +var _dependenciesFunctionAssignmentNodeGenerated = require("./dependenciesAny/dependenciesFunctionAssignmentNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesAny/dependenciesFunctionNode.generated.js"); +var _dependenciesGammaGenerated = require("./dependenciesAny/dependenciesGamma.generated.js"); +var _dependenciesGasConstantGenerated = require("./dependenciesAny/dependenciesGasConstant.generated.js"); +var _dependenciesGcdGenerated = require("./dependenciesAny/dependenciesGcd.generated.js"); +var _dependenciesGetMatrixDataTypeGenerated = require("./dependenciesAny/dependenciesGetMatrixDataType.generated.js"); +var _dependenciesGravitationConstantGenerated = require("./dependenciesAny/dependenciesGravitationConstant.generated.js"); +var _dependenciesGravityGenerated = require("./dependenciesAny/dependenciesGravity.generated.js"); +var _dependenciesHartreeEnergyGenerated = require("./dependenciesAny/dependenciesHartreeEnergy.generated.js"); +var _dependenciesHasNumericValueGenerated = require("./dependenciesAny/dependenciesHasNumericValue.generated.js"); +var _dependenciesHelpGenerated = require("./dependenciesAny/dependenciesHelp.generated.js"); +var _dependenciesHelpClassGenerated = require("./dependenciesAny/dependenciesHelpClass.generated.js"); +var _dependenciesHexGenerated = require("./dependenciesAny/dependenciesHex.generated.js"); +var _dependenciesHypotGenerated = require("./dependenciesAny/dependenciesHypot.generated.js"); +var _dependenciesIGenerated = require("./dependenciesAny/dependenciesI.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesAny/dependenciesIdentity.generated.js"); +var _dependenciesIfftGenerated = require("./dependenciesAny/dependenciesIfft.generated.js"); +var _dependenciesImGenerated = require("./dependenciesAny/dependenciesIm.generated.js"); +var _dependenciesImmutableDenseMatrixClassGenerated = require("./dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js"); +var _dependenciesIndexGenerated = require("./dependenciesAny/dependenciesIndex.generated.js"); +var _dependenciesIndexClassGenerated = require("./dependenciesAny/dependenciesIndexClass.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesAny/dependenciesIndexNode.generated.js"); +var _dependenciesIndexTransformGenerated = require("./dependenciesAny/dependenciesIndexTransform.generated.js"); +var _dependenciesInfinityGenerated = require("./dependenciesAny/dependenciesInfinity.generated.js"); +var _dependenciesIntersectGenerated = require("./dependenciesAny/dependenciesIntersect.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesAny/dependenciesInv.generated.js"); +var _dependenciesInverseConductanceQuantumGenerated = require("./dependenciesAny/dependenciesInverseConductanceQuantum.generated.js"); +var _dependenciesInvmodGenerated = require("./dependenciesAny/dependenciesInvmod.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesAny/dependenciesIsInteger.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesAny/dependenciesIsNaN.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesAny/dependenciesIsNegative.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesAny/dependenciesIsNumeric.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesAny/dependenciesIsPositive.generated.js"); +var _dependenciesIsPrimeGenerated = require("./dependenciesAny/dependenciesIsPrime.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesAny/dependenciesIsZero.generated.js"); +var _dependenciesKldivergenceGenerated = require("./dependenciesAny/dependenciesKldivergence.generated.js"); +var _dependenciesKlitzingGenerated = require("./dependenciesAny/dependenciesKlitzing.generated.js"); +var _dependenciesKronGenerated = require("./dependenciesAny/dependenciesKron.generated.js"); +var _dependenciesLN10Generated = require("./dependenciesAny/dependenciesLN10.generated.js"); +var _dependenciesLN2Generated = require("./dependenciesAny/dependenciesLN2.generated.js"); +var _dependenciesLOG10EGenerated = require("./dependenciesAny/dependenciesLOG10E.generated.js"); +var _dependenciesLOG2EGenerated = require("./dependenciesAny/dependenciesLOG2E.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesAny/dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesAny/dependenciesLargerEq.generated.js"); +var _dependenciesLcmGenerated = require("./dependenciesAny/dependenciesLcm.generated.js"); +var _dependenciesLeafCountGenerated = require("./dependenciesAny/dependenciesLeafCount.generated.js"); +var _dependenciesLeftShiftGenerated = require("./dependenciesAny/dependenciesLeftShift.generated.js"); +var _dependenciesLgammaGenerated = require("./dependenciesAny/dependenciesLgamma.generated.js"); +var _dependenciesLogGenerated = require("./dependenciesAny/dependenciesLog.generated.js"); +var _dependenciesLog10Generated = require("./dependenciesAny/dependenciesLog10.generated.js"); +var _dependenciesLog1pGenerated = require("./dependenciesAny/dependenciesLog1p.generated.js"); +var _dependenciesLog2Generated = require("./dependenciesAny/dependenciesLog2.generated.js"); +var _dependenciesLoschmidtGenerated = require("./dependenciesAny/dependenciesLoschmidt.generated.js"); +var _dependenciesLsolveGenerated = require("./dependenciesAny/dependenciesLsolve.generated.js"); +var _dependenciesLsolveAllGenerated = require("./dependenciesAny/dependenciesLsolveAll.generated.js"); +var _dependenciesLupGenerated = require("./dependenciesAny/dependenciesLup.generated.js"); +var _dependenciesLusolveGenerated = require("./dependenciesAny/dependenciesLusolve.generated.js"); +var _dependenciesLyapGenerated = require("./dependenciesAny/dependenciesLyap.generated.js"); +var _dependenciesMadGenerated = require("./dependenciesAny/dependenciesMad.generated.js"); +var _dependenciesMagneticConstantGenerated = require("./dependenciesAny/dependenciesMagneticConstant.generated.js"); +var _dependenciesMagneticFluxQuantumGenerated = require("./dependenciesAny/dependenciesMagneticFluxQuantum.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesAny/dependenciesMap.generated.js"); +var _dependenciesMapTransformGenerated = require("./dependenciesAny/dependenciesMapTransform.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesAny/dependenciesMatrix.generated.js"); +var _dependenciesMatrixClassGenerated = require("./dependenciesAny/dependenciesMatrixClass.generated.js"); +var _dependenciesMatrixFromColumnsGenerated = require("./dependenciesAny/dependenciesMatrixFromColumns.generated.js"); +var _dependenciesMatrixFromFunctionGenerated = require("./dependenciesAny/dependenciesMatrixFromFunction.generated.js"); +var _dependenciesMatrixFromRowsGenerated = require("./dependenciesAny/dependenciesMatrixFromRows.generated.js"); +var _dependenciesMaxGenerated = require("./dependenciesAny/dependenciesMax.generated.js"); +var _dependenciesMaxTransformGenerated = require("./dependenciesAny/dependenciesMaxTransform.generated.js"); +var _dependenciesMeanGenerated = require("./dependenciesAny/dependenciesMean.generated.js"); +var _dependenciesMeanTransformGenerated = require("./dependenciesAny/dependenciesMeanTransform.generated.js"); +var _dependenciesMedianGenerated = require("./dependenciesAny/dependenciesMedian.generated.js"); +var _dependenciesMinGenerated = require("./dependenciesAny/dependenciesMin.generated.js"); +var _dependenciesMinTransformGenerated = require("./dependenciesAny/dependenciesMinTransform.generated.js"); +var _dependenciesModGenerated = require("./dependenciesAny/dependenciesMod.generated.js"); +var _dependenciesModeGenerated = require("./dependenciesAny/dependenciesMode.generated.js"); +var _dependenciesMolarMassGenerated = require("./dependenciesAny/dependenciesMolarMass.generated.js"); +var _dependenciesMolarMassC12Generated = require("./dependenciesAny/dependenciesMolarMassC12.generated.js"); +var _dependenciesMolarPlanckConstantGenerated = require("./dependenciesAny/dependenciesMolarPlanckConstant.generated.js"); +var _dependenciesMolarVolumeGenerated = require("./dependenciesAny/dependenciesMolarVolume.generated.js"); +var _dependenciesMultinomialGenerated = require("./dependenciesAny/dependenciesMultinomial.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesAny/dependenciesMultiply.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesAny/dependenciesMultiplyScalar.generated.js"); +var _dependenciesNaNGenerated = require("./dependenciesAny/dependenciesNaN.generated.js"); +var _dependenciesNeutronMassGenerated = require("./dependenciesAny/dependenciesNeutronMass.generated.js"); +var _dependenciesNodeGenerated = require("./dependenciesAny/dependenciesNode.generated.js"); +var _dependenciesNormGenerated = require("./dependenciesAny/dependenciesNorm.generated.js"); +var _dependenciesNotGenerated = require("./dependenciesAny/dependenciesNot.generated.js"); +var _dependenciesNthRootGenerated = require("./dependenciesAny/dependenciesNthRoot.generated.js"); +var _dependenciesNthRootsGenerated = require("./dependenciesAny/dependenciesNthRoots.generated.js"); +var _dependenciesNuclearMagnetonGenerated = require("./dependenciesAny/dependenciesNuclearMagneton.generated.js"); +var _dependenciesNullGenerated = require("./dependenciesAny/dependenciesNull.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesAny/dependenciesNumber.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesAny/dependenciesNumeric.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesAny/dependenciesObjectNode.generated.js"); +var _dependenciesOctGenerated = require("./dependenciesAny/dependenciesOct.generated.js"); +var _dependenciesOnesGenerated = require("./dependenciesAny/dependenciesOnes.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesAny/dependenciesOperatorNode.generated.js"); +var _dependenciesOrGenerated = require("./dependenciesAny/dependenciesOr.generated.js"); +var _dependenciesOrTransformGenerated = require("./dependenciesAny/dependenciesOrTransform.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesAny/dependenciesParenthesisNode.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesAny/dependenciesParse.generated.js"); +var _dependenciesParserGenerated = require("./dependenciesAny/dependenciesParser.generated.js"); +var _dependenciesParserClassGenerated = require("./dependenciesAny/dependenciesParserClass.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesAny/dependenciesPartitionSelect.generated.js"); +var _dependenciesPermutationsGenerated = require("./dependenciesAny/dependenciesPermutations.generated.js"); +var _dependenciesPhiGenerated = require("./dependenciesAny/dependenciesPhi.generated.js"); +var _dependenciesPiGenerated = require("./dependenciesAny/dependenciesPi.generated.js"); +var _dependenciesPickRandomGenerated = require("./dependenciesAny/dependenciesPickRandom.generated.js"); +var _dependenciesPinvGenerated = require("./dependenciesAny/dependenciesPinv.generated.js"); +var _dependenciesPlanckChargeGenerated = require("./dependenciesAny/dependenciesPlanckCharge.generated.js"); +var _dependenciesPlanckConstantGenerated = require("./dependenciesAny/dependenciesPlanckConstant.generated.js"); +var _dependenciesPlanckLengthGenerated = require("./dependenciesAny/dependenciesPlanckLength.generated.js"); +var _dependenciesPlanckMassGenerated = require("./dependenciesAny/dependenciesPlanckMass.generated.js"); +var _dependenciesPlanckTemperatureGenerated = require("./dependenciesAny/dependenciesPlanckTemperature.generated.js"); +var _dependenciesPlanckTimeGenerated = require("./dependenciesAny/dependenciesPlanckTime.generated.js"); +var _dependenciesPolynomialRootGenerated = require("./dependenciesAny/dependenciesPolynomialRoot.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesAny/dependenciesPow.generated.js"); +var _dependenciesPrintGenerated = require("./dependenciesAny/dependenciesPrint.generated.js"); +var _dependenciesPrintTransformGenerated = require("./dependenciesAny/dependenciesPrintTransform.generated.js"); +var _dependenciesProdGenerated = require("./dependenciesAny/dependenciesProd.generated.js"); +var _dependenciesProtonMassGenerated = require("./dependenciesAny/dependenciesProtonMass.generated.js"); +var _dependenciesQrGenerated = require("./dependenciesAny/dependenciesQr.generated.js"); +var _dependenciesQuantileSeqGenerated = require("./dependenciesAny/dependenciesQuantileSeq.generated.js"); +var _dependenciesQuantileSeqTransformGenerated = require("./dependenciesAny/dependenciesQuantileSeqTransform.generated.js"); +var _dependenciesQuantumOfCirculationGenerated = require("./dependenciesAny/dependenciesQuantumOfCirculation.generated.js"); +var _dependenciesRandomGenerated = require("./dependenciesAny/dependenciesRandom.generated.js"); +var _dependenciesRandomIntGenerated = require("./dependenciesAny/dependenciesRandomInt.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesAny/dependenciesRange.generated.js"); +var _dependenciesRangeClassGenerated = require("./dependenciesAny/dependenciesRangeClass.generated.js"); +var _dependenciesRangeNodeGenerated = require("./dependenciesAny/dependenciesRangeNode.generated.js"); +var _dependenciesRangeTransformGenerated = require("./dependenciesAny/dependenciesRangeTransform.generated.js"); +var _dependenciesRationalizeGenerated = require("./dependenciesAny/dependenciesRationalize.generated.js"); +var _dependenciesReGenerated = require("./dependenciesAny/dependenciesRe.generated.js"); +var _dependenciesReducedPlanckConstantGenerated = require("./dependenciesAny/dependenciesReducedPlanckConstant.generated.js"); +var _dependenciesRelationalNodeGenerated = require("./dependenciesAny/dependenciesRelationalNode.generated.js"); +var _dependenciesReplacerGenerated = require("./dependenciesAny/dependenciesReplacer.generated.js"); +var _dependenciesReshapeGenerated = require("./dependenciesAny/dependenciesReshape.generated.js"); +var _dependenciesResizeGenerated = require("./dependenciesAny/dependenciesResize.generated.js"); +var _dependenciesResolveGenerated = require("./dependenciesAny/dependenciesResolve.generated.js"); +var _dependenciesResultSetGenerated = require("./dependenciesAny/dependenciesResultSet.generated.js"); +var _dependenciesReviverGenerated = require("./dependenciesAny/dependenciesReviver.generated.js"); +var _dependenciesRightArithShiftGenerated = require("./dependenciesAny/dependenciesRightArithShift.generated.js"); +var _dependenciesRightLogShiftGenerated = require("./dependenciesAny/dependenciesRightLogShift.generated.js"); +var _dependenciesRotateGenerated = require("./dependenciesAny/dependenciesRotate.generated.js"); +var _dependenciesRotationMatrixGenerated = require("./dependenciesAny/dependenciesRotationMatrix.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesAny/dependenciesRound.generated.js"); +var _dependenciesRowGenerated = require("./dependenciesAny/dependenciesRow.generated.js"); +var _dependenciesRowTransformGenerated = require("./dependenciesAny/dependenciesRowTransform.generated.js"); +var _dependenciesRydbergGenerated = require("./dependenciesAny/dependenciesRydberg.generated.js"); +var _dependenciesSQRT1_2Generated = require("./dependenciesAny/dependenciesSQRT1_2.generated.js"); +var _dependenciesSQRT2Generated = require("./dependenciesAny/dependenciesSQRT2.generated.js"); +var _dependenciesSackurTetrodeGenerated = require("./dependenciesAny/dependenciesSackurTetrode.generated.js"); +var _dependenciesSchurGenerated = require("./dependenciesAny/dependenciesSchur.generated.js"); +var _dependenciesSecGenerated = require("./dependenciesAny/dependenciesSec.generated.js"); +var _dependenciesSechGenerated = require("./dependenciesAny/dependenciesSech.generated.js"); +var _dependenciesSecondRadiationGenerated = require("./dependenciesAny/dependenciesSecondRadiation.generated.js"); +var _dependenciesSetCartesianGenerated = require("./dependenciesAny/dependenciesSetCartesian.generated.js"); +var _dependenciesSetDifferenceGenerated = require("./dependenciesAny/dependenciesSetDifference.generated.js"); +var _dependenciesSetDistinctGenerated = require("./dependenciesAny/dependenciesSetDistinct.generated.js"); +var _dependenciesSetIntersectGenerated = require("./dependenciesAny/dependenciesSetIntersect.generated.js"); +var _dependenciesSetIsSubsetGenerated = require("./dependenciesAny/dependenciesSetIsSubset.generated.js"); +var _dependenciesSetMultiplicityGenerated = require("./dependenciesAny/dependenciesSetMultiplicity.generated.js"); +var _dependenciesSetPowersetGenerated = require("./dependenciesAny/dependenciesSetPowerset.generated.js"); +var _dependenciesSetSizeGenerated = require("./dependenciesAny/dependenciesSetSize.generated.js"); +var _dependenciesSetSymDifferenceGenerated = require("./dependenciesAny/dependenciesSetSymDifference.generated.js"); +var _dependenciesSetUnionGenerated = require("./dependenciesAny/dependenciesSetUnion.generated.js"); +var _dependenciesSignGenerated = require("./dependenciesAny/dependenciesSign.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesAny/dependenciesSimplify.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesAny/dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesAny/dependenciesSimplifyCore.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesAny/dependenciesSin.generated.js"); +var _dependenciesSinhGenerated = require("./dependenciesAny/dependenciesSinh.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesAny/dependenciesSize.generated.js"); +var _dependenciesSluGenerated = require("./dependenciesAny/dependenciesSlu.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesAny/dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesAny/dependenciesSmallerEq.generated.js"); +var _dependenciesSolveODEGenerated = require("./dependenciesAny/dependenciesSolveODE.generated.js"); +var _dependenciesSortGenerated = require("./dependenciesAny/dependenciesSort.generated.js"); +var _dependenciesSpaClassGenerated = require("./dependenciesAny/dependenciesSpaClass.generated.js"); +var _dependenciesSparseGenerated = require("./dependenciesAny/dependenciesSparse.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesAny/dependenciesSparseMatrixClass.generated.js"); +var _dependenciesSpeedOfLightGenerated = require("./dependenciesAny/dependenciesSpeedOfLight.generated.js"); +var _dependenciesSplitUnitGenerated = require("./dependenciesAny/dependenciesSplitUnit.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesAny/dependenciesSqrt.generated.js"); +var _dependenciesSqrtmGenerated = require("./dependenciesAny/dependenciesSqrtm.generated.js"); +var _dependenciesSquareGenerated = require("./dependenciesAny/dependenciesSquare.generated.js"); +var _dependenciesSqueezeGenerated = require("./dependenciesAny/dependenciesSqueeze.generated.js"); +var _dependenciesStdGenerated = require("./dependenciesAny/dependenciesStd.generated.js"); +var _dependenciesStdTransformGenerated = require("./dependenciesAny/dependenciesStdTransform.generated.js"); +var _dependenciesStefanBoltzmannGenerated = require("./dependenciesAny/dependenciesStefanBoltzmann.generated.js"); +var _dependenciesStirlingS2Generated = require("./dependenciesAny/dependenciesStirlingS2.generated.js"); +var _dependenciesStringGenerated = require("./dependenciesAny/dependenciesString.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesAny/dependenciesSubset.generated.js"); +var _dependenciesSubsetTransformGenerated = require("./dependenciesAny/dependenciesSubsetTransform.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesAny/dependenciesSubtract.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesAny/dependenciesSubtractScalar.generated.js"); +var _dependenciesSumGenerated = require("./dependenciesAny/dependenciesSum.generated.js"); +var _dependenciesSumTransformGenerated = require("./dependenciesAny/dependenciesSumTransform.generated.js"); +var _dependenciesSylvesterGenerated = require("./dependenciesAny/dependenciesSylvester.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesAny/dependenciesSymbolNode.generated.js"); +var _dependenciesSymbolicEqualGenerated = require("./dependenciesAny/dependenciesSymbolicEqual.generated.js"); +var _dependenciesTanGenerated = require("./dependenciesAny/dependenciesTan.generated.js"); +var _dependenciesTanhGenerated = require("./dependenciesAny/dependenciesTanh.generated.js"); +var _dependenciesTauGenerated = require("./dependenciesAny/dependenciesTau.generated.js"); +var _dependenciesThomsonCrossSectionGenerated = require("./dependenciesAny/dependenciesThomsonCrossSection.generated.js"); +var _dependenciesToGenerated = require("./dependenciesAny/dependenciesTo.generated.js"); +var _dependenciesTraceGenerated = require("./dependenciesAny/dependenciesTrace.generated.js"); +var _dependenciesTransposeGenerated = require("./dependenciesAny/dependenciesTranspose.generated.js"); +var _dependenciesTrueGenerated = require("./dependenciesAny/dependenciesTrue.generated.js"); +var _dependenciesTypeOfGenerated = require("./dependenciesAny/dependenciesTypeOf.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesAny/dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesAny/dependenciesUnaryMinus.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesAny/dependenciesUnaryPlus.generated.js"); +var _dependenciesUnequalGenerated = require("./dependenciesAny/dependenciesUnequal.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesAny/dependenciesUnitClass.generated.js"); +var _dependenciesUnitFunctionGenerated = require("./dependenciesAny/dependenciesUnitFunction.generated.js"); +var _dependenciesUppercaseEGenerated = require("./dependenciesAny/dependenciesUppercaseE.generated.js"); +var _dependenciesUppercasePiGenerated = require("./dependenciesAny/dependenciesUppercasePi.generated.js"); +var _dependenciesUsolveGenerated = require("./dependenciesAny/dependenciesUsolve.generated.js"); +var _dependenciesUsolveAllGenerated = require("./dependenciesAny/dependenciesUsolveAll.generated.js"); +var _dependenciesVacuumImpedanceGenerated = require("./dependenciesAny/dependenciesVacuumImpedance.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesAny/dependenciesVariance.generated.js"); +var _dependenciesVarianceTransformGenerated = require("./dependenciesAny/dependenciesVarianceTransform.generated.js"); +var _dependenciesVersionGenerated = require("./dependenciesAny/dependenciesVersion.generated.js"); +var _dependenciesWeakMixingAngleGenerated = require("./dependenciesAny/dependenciesWeakMixingAngle.generated.js"); +var _dependenciesWienDisplacementGenerated = require("./dependenciesAny/dependenciesWienDisplacement.generated.js"); +var _dependenciesXgcdGenerated = require("./dependenciesAny/dependenciesXgcd.generated.js"); +var _dependenciesXorGenerated = require("./dependenciesAny/dependenciesXor.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesAny/dependenciesZeros.generated.js"); +var _dependenciesZetaGenerated = require("./dependenciesAny/dependenciesZeta.generated.js"); +var _dependenciesZpk2tfGenerated = require("./dependenciesAny/dependenciesZpk2tf.generated.js"); +var _allFactoriesAny = require("./allFactoriesAny.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAbs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAbs.generated.js new file mode 100644 index 0000000..a209244 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAbs.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.absDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const absDependencies = exports.absDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAbs: _factoriesAny.createAbs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAccessorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAccessorNode.generated.js new file mode 100644 index 0000000..1013f15 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAccessorNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.AccessorNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const AccessorNodeDependencies = exports.AccessorNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + createAccessorNode: _factoriesAny.createAccessorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcos.generated.js new file mode 100644 index 0000000..3a33acb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcos.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acosDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acosDependencies = exports.acosDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcos: _factoriesAny.createAcos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcosh.generated.js new file mode 100644 index 0000000..c11f52c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcosh.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acoshDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acoshDependencies = exports.acoshDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcosh: _factoriesAny.createAcosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcot.generated.js new file mode 100644 index 0000000..ff6fe20 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcot.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acotDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acotDependencies = exports.acotDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcot: _factoriesAny.createAcot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcoth.generated.js new file mode 100644 index 0000000..52eb9c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcoth.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acothDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acothDependencies = exports.acothDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcoth: _factoriesAny.createAcoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsc.generated.js new file mode 100644 index 0000000..ec86871 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsc.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acscDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acscDependencies = exports.acscDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcsc: _factoriesAny.createAcsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsch.generated.js new file mode 100644 index 0000000..117284d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsch.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acschDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acschDependencies = exports.acschDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcsch: _factoriesAny.createAcsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAdd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAdd.generated.js new file mode 100644 index 0000000..fe3d875 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAdd.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const addDependencies = exports.addDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAdd: _factoriesAny.createAdd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAddScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAddScalar.generated.js new file mode 100644 index 0000000..0259adb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAddScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const addScalarDependencies = exports.addScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAddScalar: _factoriesAny.createAddScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAnd.generated.js new file mode 100644 index 0000000..62b49af --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAnd.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.andDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNotGenerated = require("./dependenciesNot.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const andDependencies = exports.andDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + notDependencies: _dependenciesNotGenerated.notDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createAnd: _factoriesAny.createAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAndTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAndTransform.generated.js new file mode 100644 index 0000000..23cfcd9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAndTransform.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.andTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNotGenerated = require("./dependenciesNot.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const andTransformDependencies = exports.andTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + notDependencies: _dependenciesNotGenerated.notDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createAndTransform: _factoriesAny.createAndTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApply.generated.js new file mode 100644 index 0000000..afe4d38 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApply.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.applyDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const applyDependencies = exports.applyDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createApply: _factoriesAny.createApply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApplyTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApplyTransform.generated.js new file mode 100644 index 0000000..b1bf1ca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApplyTransform.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.applyTransformDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const applyTransformDependencies = exports.applyTransformDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createApplyTransform: _factoriesAny.createApplyTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArg.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArg.generated.js new file mode 100644 index 0000000..9b63396 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArg.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.argDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const argDependencies = exports.argDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createArg: _factoriesAny.createArg +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArrayNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArrayNode.generated.js new file mode 100644 index 0000000..1dd6e9d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArrayNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ArrayNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ArrayNodeDependencies = exports.ArrayNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createArrayNode: _factoriesAny.createArrayNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsec.generated.js new file mode 100644 index 0000000..4ce5ddd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsec.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asecDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asecDependencies = exports.asecDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsec: _factoriesAny.createAsec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsech.generated.js new file mode 100644 index 0000000..c998c7d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsech.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asechDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asechDependencies = exports.asechDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsech: _factoriesAny.createAsech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsin.generated.js new file mode 100644 index 0000000..16407af --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsin.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asinDependencies = exports.asinDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsin: _factoriesAny.createAsin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsinh.generated.js new file mode 100644 index 0000000..9952f06 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsinh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asinhDependencies = exports.asinhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsinh: _factoriesAny.createAsinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAssignmentNode.generated.js new file mode 100644 index 0000000..3356a2c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAssignmentNode.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.AssignmentNodeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const AssignmentNodeDependencies = exports.AssignmentNodeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + createAssignmentNode: _factoriesAny.createAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan.generated.js new file mode 100644 index 0000000..8e74620 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atanDependencies = exports.atanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtan: _factoriesAny.createAtan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan2.generated.js new file mode 100644 index 0000000..d6f892b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan2.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atan2Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atan2Dependencies = exports.atan2Dependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtan2: _factoriesAny.createAtan2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtanh.generated.js new file mode 100644 index 0000000..8474b1b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtanh.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanhDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atanhDependencies = exports.atanhDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtanh: _factoriesAny.createAtanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtomicMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtomicMass.generated.js new file mode 100644 index 0000000..22c1c3c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtomicMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atomicMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atomicMassDependencies = exports.atomicMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createAtomicMass: _factoriesAny.createAtomicMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAvogadro.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAvogadro.generated.js new file mode 100644 index 0000000..5bc3c9f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAvogadro.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.avogadroDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const avogadroDependencies = exports.avogadroDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createAvogadro: _factoriesAny.createAvogadro +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBellNumbers.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBellNumbers.generated.js new file mode 100644 index 0000000..042691b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBellNumbers.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bellNumbersDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesStirlingS2Generated = require("./dependenciesStirlingS2.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bellNumbersDependencies = exports.bellNumbersDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + stirlingS2Dependencies: _dependenciesStirlingS2Generated.stirlingS2Dependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBellNumbers: _factoriesAny.createBellNumbers +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigNumberClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigNumberClass.generated.js new file mode 100644 index 0000000..3c96c2e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigNumberClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.BigNumberDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const BigNumberDependencies = exports.BigNumberDependencies = { + createBigNumberClass: _factoriesAny.createBigNumberClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigint.generated.js new file mode 100644 index 0000000..5b2e8c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigint.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bigintDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bigintDependencies = exports.bigintDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBigint: _factoriesAny.createBigint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBignumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBignumber.generated.js new file mode 100644 index 0000000..872f75f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBignumber.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bignumberDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bignumberDependencies = exports.bignumberDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBignumber: _factoriesAny.createBignumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBin.generated.js new file mode 100644 index 0000000..da90dde --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBin.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.binDependencies = void 0; +var _dependenciesFormatGenerated = require("./dependenciesFormat.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const binDependencies = exports.binDependencies = { + formatDependencies: _dependenciesFormatGenerated.formatDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBin: _factoriesAny.createBin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAnd.generated.js new file mode 100644 index 0000000..be66698 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAnd.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitAndDependencies = exports.bitAndDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitAnd: _factoriesAny.createBitAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAndTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAndTransform.generated.js new file mode 100644 index 0000000..dcf6dc0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAndTransform.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNotGenerated = require("./dependenciesNot.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitAndTransformDependencies = exports.bitAndTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + notDependencies: _dependenciesNotGenerated.notDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createBitAndTransform: _factoriesAny.createBitAndTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitNot.generated.js new file mode 100644 index 0000000..4ab8f47 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitNot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitNotDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitNotDependencies = exports.bitNotDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitNot: _factoriesAny.createBitNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOr.generated.js new file mode 100644 index 0000000..78cf43d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOr.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitOrDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitOrDependencies = exports.bitOrDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitOr: _factoriesAny.createBitOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOrTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOrTransform.generated.js new file mode 100644 index 0000000..2671bc1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOrTransform.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitOrTransformDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitOrTransformDependencies = exports.bitOrTransformDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitOrTransform: _factoriesAny.createBitOrTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitXor.generated.js new file mode 100644 index 0000000..b499dbf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitXor.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitXorDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitXorDependencies = exports.bitXorDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitXor: _factoriesAny.createBitXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBlockNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBlockNode.generated.js new file mode 100644 index 0000000..10c04cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBlockNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.BlockNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesResultSetGenerated = require("./dependenciesResultSet.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const BlockNodeDependencies = exports.BlockNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + ResultSetDependencies: _dependenciesResultSetGenerated.ResultSetDependencies, + createBlockNode: _factoriesAny.createBlockNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrMagneton.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrMagneton.generated.js new file mode 100644 index 0000000..7d72bc7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrMagneton.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bohrMagnetonDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bohrMagnetonDependencies = exports.bohrMagnetonDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createBohrMagneton: _factoriesAny.createBohrMagneton +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrRadius.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrRadius.generated.js new file mode 100644 index 0000000..476da49 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrRadius.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bohrRadiusDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bohrRadiusDependencies = exports.bohrRadiusDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createBohrRadius: _factoriesAny.createBohrRadius +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoltzmann.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoltzmann.generated.js new file mode 100644 index 0000000..4f5135b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoltzmann.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.boltzmannDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const boltzmannDependencies = exports.boltzmannDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createBoltzmann: _factoriesAny.createBoltzmann +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoolean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoolean.generated.js new file mode 100644 index 0000000..d52eae8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoolean.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.booleanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const booleanDependencies = exports.booleanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBoolean: _factoriesAny.createBoolean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCatalan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCatalan.generated.js new file mode 100644 index 0000000..1e35a08 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCatalan.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.catalanDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const catalanDependencies = exports.catalanDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCatalan: _factoriesAny.createCatalan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCbrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCbrt.generated.js new file mode 100644 index 0000000..5608678 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCbrt.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cbrtDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cbrtDependencies = exports.cbrtDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createCbrt: _factoriesAny.createCbrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCeil.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCeil.generated.js new file mode 100644 index 0000000..261c51e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCeil.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ceilDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ceilDependencies = exports.ceilDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createCeil: _factoriesAny.createCeil +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChain.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChain.generated.js new file mode 100644 index 0000000..61ba627 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChain.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.chainDependencies = void 0; +var _dependenciesChainClassGenerated = require("./dependenciesChainClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const chainDependencies = exports.chainDependencies = { + ChainDependencies: _dependenciesChainClassGenerated.ChainDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createChain: _factoriesAny.createChain +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChainClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChainClass.generated.js new file mode 100644 index 0000000..8c00a84 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChainClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ChainDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ChainDependencies = exports.ChainDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createChainClass: _factoriesAny.createChainClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js new file mode 100644 index 0000000..e08033a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.classicalElectronRadiusDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const classicalElectronRadiusDependencies = exports.classicalElectronRadiusDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createClassicalElectronRadius: _factoriesAny.createClassicalElectronRadius +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClone.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClone.generated.js new file mode 100644 index 0000000..a23e7c4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClone.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cloneDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cloneDependencies = exports.cloneDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createClone: _factoriesAny.createClone +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumn.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumn.generated.js new file mode 100644 index 0000000..0db7c9e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumn.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.columnDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesRange.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const columnDependencies = exports.columnDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + rangeDependencies: _dependenciesRangeGenerated.rangeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createColumn: _factoriesAny.createColumn +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumnTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumnTransform.generated.js new file mode 100644 index 0000000..84e9737 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumnTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.columnTransformDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesRange.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const columnTransformDependencies = exports.columnTransformDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + rangeDependencies: _dependenciesRangeGenerated.rangeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createColumnTransform: _factoriesAny.createColumnTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinations.generated.js new file mode 100644 index 0000000..41d58d6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinations.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const combinationsDependencies = exports.combinationsDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCombinations: _factoriesAny.createCombinations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js new file mode 100644 index 0000000..8727fc1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsWithRepDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const combinationsWithRepDependencies = exports.combinationsWithRepDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCombinationsWithRep: _factoriesAny.createCombinationsWithRep +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompare.generated.js new file mode 100644 index 0000000..f5f7b26 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompare.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareDependencies = exports.compareDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompare: _factoriesAny.createCompare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareNatural.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareNatural.generated.js new file mode 100644 index 0000000..34dca1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareNatural.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareNaturalDependencies = void 0; +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareNaturalDependencies = exports.compareNaturalDependencies = { + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompareNatural: _factoriesAny.createCompareNatural +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareText.generated.js new file mode 100644 index 0000000..863a8a3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareText.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareTextDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareTextDependencies = exports.compareTextDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompareText: _factoriesAny.createCompareText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompile.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompile.generated.js new file mode 100644 index 0000000..08e0e7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompile.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compileDependencies = void 0; +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compileDependencies = exports.compileDependencies = { + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompile: _factoriesAny.createCompile +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplex.generated.js new file mode 100644 index 0000000..f6fbf39 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplex.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.complexDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const complexDependencies = exports.complexDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createComplex: _factoriesAny.createComplex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplexClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplexClass.generated.js new file mode 100644 index 0000000..480c6e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplexClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ComplexDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ComplexDependencies = exports.ComplexDependencies = { + createComplexClass: _factoriesAny.createComplexClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComposition.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComposition.generated.js new file mode 100644 index 0000000..159937a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComposition.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compositionDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compositionDependencies = exports.compositionDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createComposition: _factoriesAny.createComposition +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcat.generated.js new file mode 100644 index 0000000..5406431 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcat.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.concatDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const concatDependencies = exports.concatDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createConcat: _factoriesAny.createConcat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcatTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcatTransform.generated.js new file mode 100644 index 0000000..b34b69f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcatTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.concatTransformDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const concatTransformDependencies = exports.concatTransformDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createConcatTransform: _factoriesAny.createConcatTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConditionalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConditionalNode.generated.js new file mode 100644 index 0000000..e4fe8a4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConditionalNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ConditionalNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ConditionalNodeDependencies = exports.ConditionalNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createConditionalNode: _factoriesAny.createConditionalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js new file mode 100644 index 0000000..b9c4ba4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.conductanceQuantumDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const conductanceQuantumDependencies = exports.conductanceQuantumDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createConductanceQuantum: _factoriesAny.createConductanceQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConj.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConj.generated.js new file mode 100644 index 0000000..17e72c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConj.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.conjDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const conjDependencies = exports.conjDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createConj: _factoriesAny.createConj +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConstantNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConstantNode.generated.js new file mode 100644 index 0000000..bfabdf9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConstantNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ConstantNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ConstantNodeDependencies = exports.ConstantNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createConstantNode: _factoriesAny.createConstantNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCorr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCorr.generated.js new file mode 100644 index 0000000..44679f5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCorr.generated.js @@ -0,0 +1,35 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.corrDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMeanGenerated = require("./dependenciesMean.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesSumGenerated = require("./dependenciesSum.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const corrDependencies = exports.corrDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + meanDependencies: _dependenciesMeanGenerated.meanDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + sumDependencies: _dependenciesSumGenerated.sumDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCorr: _factoriesAny.createCorr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCos.generated.js new file mode 100644 index 0000000..baa3170 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCos.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cosDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cosDependencies = exports.cosDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCos: _factoriesAny.createCos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCosh.generated.js new file mode 100644 index 0000000..14528a6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCosh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.coshDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const coshDependencies = exports.coshDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCosh: _factoriesAny.createCosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCot.generated.js new file mode 100644 index 0000000..02c4e5f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCot.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cotDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cotDependencies = exports.cotDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCot: _factoriesAny.createCot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoth.generated.js new file mode 100644 index 0000000..8dc4cb6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoth.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cothDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cothDependencies = exports.cothDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCoth: _factoriesAny.createCoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoulomb.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoulomb.generated.js new file mode 100644 index 0000000..a9b2d72 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoulomb.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.coulombDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const coulombDependencies = exports.coulombDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createCoulomb: _factoriesAny.createCoulomb +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCount.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCount.generated.js new file mode 100644 index 0000000..a9b2b3d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCount.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.countDependencies = void 0; +var _dependenciesProdGenerated = require("./dependenciesProd.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const countDependencies = exports.countDependencies = { + prodDependencies: _dependenciesProdGenerated.prodDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCount: _factoriesAny.createCount +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCreateUnit.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCreateUnit.generated.js new file mode 100644 index 0000000..991076b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCreateUnit.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnitDependencies = void 0; +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const createUnitDependencies = exports.createUnitDependencies = { + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCreateUnit: _factoriesAny.createCreateUnit +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCross.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCross.generated.js new file mode 100644 index 0000000..8be6d39 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCross.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.crossDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const crossDependencies = exports.crossDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCross: _factoriesAny.createCross +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsc.generated.js new file mode 100644 index 0000000..342c99f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsc.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cscDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cscDependencies = exports.cscDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCsc: _factoriesAny.createCsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsch.generated.js new file mode 100644 index 0000000..5e461e0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsch.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cschDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cschDependencies = exports.cschDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCsch: _factoriesAny.createCsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCtranspose.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCtranspose.generated.js new file mode 100644 index 0000000..6d17118 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCtranspose.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ctransposeDependencies = void 0; +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesTransposeGenerated = require("./dependenciesTranspose.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ctransposeDependencies = exports.ctransposeDependencies = { + conjDependencies: _dependenciesConjGenerated.conjDependencies, + transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCtranspose: _factoriesAny.createCtranspose +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCube.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCube.generated.js new file mode 100644 index 0000000..b5de087 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCube.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cubeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cubeDependencies = exports.cubeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCube: _factoriesAny.createCube +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSum.generated.js new file mode 100644 index 0000000..bd1dfd0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSum.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cumsumDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesUnaryPlus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cumsumDependencies = exports.cumsumDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies, + createCumSum: _factoriesAny.createCumSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSumTransform.generated.js new file mode 100644 index 0000000..4370a1e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSumTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cumsumTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesUnaryPlus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cumsumTransformDependencies = exports.cumsumTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies, + createCumSumTransform: _factoriesAny.createCumSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeepEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeepEqual.generated.js new file mode 100644 index 0000000..f0d2fb0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeepEqual.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.deepEqualDependencies = void 0; +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const deepEqualDependencies = exports.deepEqualDependencies = { + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDeepEqual: _factoriesAny.createDeepEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js new file mode 100644 index 0000000..921d31e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.DenseMatrixDependencies = void 0; +var _dependenciesMatrixClassGenerated = require("./dependenciesMatrixClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const DenseMatrixDependencies = exports.DenseMatrixDependencies = { + MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies, + createDenseMatrixClass: _factoriesAny.createDenseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDerivative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDerivative.generated.js new file mode 100644 index 0000000..ecac7f2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDerivative.generated.js @@ -0,0 +1,37 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.derivativeDependencies = void 0; +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesSimplify.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const derivativeDependencies = exports.derivativeDependencies = { + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDerivative: _factoriesAny.createDerivative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDet.generated.js new file mode 100644 index 0000000..1697b14 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDet.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.detDependencies = void 0; +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const detDependencies = exports.detDependencies = { + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createDet: _factoriesAny.createDet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeuteronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeuteronMass.generated.js new file mode 100644 index 0000000..096e30d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeuteronMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.deuteronMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const deuteronMassDependencies = exports.deuteronMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createDeuteronMass: _factoriesAny.createDeuteronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiag.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiag.generated.js new file mode 100644 index 0000000..a4e36ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiag.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.diagDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const diagDependencies = exports.diagDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDiag: _factoriesAny.createDiag +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiff.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiff.generated.js new file mode 100644 index 0000000..94f634a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiff.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.diffDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const diffDependencies = exports.diffDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDiff: _factoriesAny.createDiff +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiffTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiffTransform.generated.js new file mode 100644 index 0000000..37a03b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiffTransform.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.diffTransformDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const diffTransformDependencies = exports.diffTransformDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDiffTransform: _factoriesAny.createDiffTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDistance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDistance.generated.js new file mode 100644 index 0000000..3a82821 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDistance.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.distanceDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDeepEqualGenerated = require("./dependenciesDeepEqual.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const distanceDependencies = exports.distanceDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + deepEqualDependencies: _dependenciesDeepEqualGenerated.deepEqualDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDistance: _factoriesAny.createDistance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivide.generated.js new file mode 100644 index 0000000..eb7279a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivide.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.divideDependencies = void 0; +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const divideDependencies = exports.divideDependencies = { + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDivide: _factoriesAny.createDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivideScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivideScalar.generated.js new file mode 100644 index 0000000..cb63652 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivideScalar.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.divideScalarDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const divideScalarDependencies = exports.divideScalarDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDivideScalar: _factoriesAny.createDivideScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDot.generated.js new file mode 100644 index 0000000..7de92d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDot.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const dotDependencies = exports.dotDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + conjDependencies: _dependenciesConjGenerated.conjDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDot: _factoriesAny.createDot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotDivide.generated.js new file mode 100644 index 0000000..55d7c5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotDivide.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotDivideDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const dotDivideDependencies = exports.dotDivideDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDotDivide: _factoriesAny.createDotDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotMultiply.generated.js new file mode 100644 index 0000000..f69a302 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotMultiply.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotMultiplyDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const dotMultiplyDependencies = exports.dotMultiplyDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDotMultiply: _factoriesAny.createDotMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotPow.generated.js new file mode 100644 index 0000000..adf53b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotPow.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotPowDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const dotPowDependencies = exports.dotPowDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDotPow: _factoriesAny.createDotPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesE.generated.js new file mode 100644 index 0000000..dccc3aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesE.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.eDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const eDependencies = exports.eDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createE: _factoriesAny.createE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEfimovFactor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEfimovFactor.generated.js new file mode 100644 index 0000000..f5318a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEfimovFactor.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.efimovFactorDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const efimovFactorDependencies = exports.efimovFactorDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createEfimovFactor: _factoriesAny.createEfimovFactor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEigs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEigs.generated.js new file mode 100644 index 0000000..8332e40 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEigs.generated.js @@ -0,0 +1,79 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.eigsDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesAtanGenerated = require("./dependenciesAtan.generated.js"); +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesColumnGenerated = require("./dependenciesColumn.generated.js"); +var _dependenciesComplexGenerated = require("./dependenciesComplex.generated.js"); +var _dependenciesCosGenerated = require("./dependenciesCos.generated.js"); +var _dependenciesDiagGenerated = require("./dependenciesDiag.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesDotGenerated = require("./dependenciesDot.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesFlattenGenerated = require("./dependenciesFlatten.generated.js"); +var _dependenciesImGenerated = require("./dependenciesIm.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMatrixFromColumnsGenerated = require("./dependenciesMatrixFromColumns.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesQrGenerated = require("./dependenciesQr.generated.js"); +var _dependenciesReGenerated = require("./dependenciesRe.generated.js"); +var _dependenciesReshapeGenerated = require("./dependenciesReshape.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesSin.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUsolveGenerated = require("./dependenciesUsolve.generated.js"); +var _dependenciesUsolveAllGenerated = require("./dependenciesUsolveAll.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const eigsDependencies = exports.eigsDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + atanDependencies: _dependenciesAtanGenerated.atanDependencies, + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + columnDependencies: _dependenciesColumnGenerated.columnDependencies, + complexDependencies: _dependenciesComplexGenerated.complexDependencies, + cosDependencies: _dependenciesCosGenerated.cosDependencies, + diagDependencies: _dependenciesDiagGenerated.diagDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + dotDependencies: _dependenciesDotGenerated.dotDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies, + imDependencies: _dependenciesImGenerated.imDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + matrixFromColumnsDependencies: _dependenciesMatrixFromColumnsGenerated.matrixFromColumnsDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + qrDependencies: _dependenciesQrGenerated.qrDependencies, + reDependencies: _dependenciesReGenerated.reDependencies, + reshapeDependencies: _dependenciesReshapeGenerated.reshapeDependencies, + sinDependencies: _dependenciesSinGenerated.sinDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + usolveDependencies: _dependenciesUsolveGenerated.usolveDependencies, + usolveAllDependencies: _dependenciesUsolveAllGenerated.usolveAllDependencies, + createEigs: _factoriesAny.createEigs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectricConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectricConstant.generated.js new file mode 100644 index 0000000..5c6f2d8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectricConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.electricConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const electricConstantDependencies = exports.electricConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createElectricConstant: _factoriesAny.createElectricConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectronMass.generated.js new file mode 100644 index 0000000..1850f7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectronMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.electronMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const electronMassDependencies = exports.electronMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createElectronMass: _factoriesAny.createElectronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElementaryCharge.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElementaryCharge.generated.js new file mode 100644 index 0000000..cff49e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElementaryCharge.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.elementaryChargeDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const elementaryChargeDependencies = exports.elementaryChargeDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createElementaryCharge: _factoriesAny.createElementaryCharge +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqual.generated.js new file mode 100644 index 0000000..4ac085d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqual.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalDependencies = exports.equalDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqual: _factoriesAny.createEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualScalar.generated.js new file mode 100644 index 0000000..74c417d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalScalarDependencies = exports.equalScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqualScalar: _factoriesAny.createEqualScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualText.generated.js new file mode 100644 index 0000000..cb8c2d4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualText.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalTextDependencies = void 0; +var _dependenciesCompareTextGenerated = require("./dependenciesCompareText.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalTextDependencies = exports.equalTextDependencies = { + compareTextDependencies: _dependenciesCompareTextGenerated.compareTextDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqualText: _factoriesAny.createEqualText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesErf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesErf.generated.js new file mode 100644 index 0000000..c829914 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesErf.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.erfDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const erfDependencies = exports.erfDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createErf: _factoriesAny.createErf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEvaluate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEvaluate.generated.js new file mode 100644 index 0000000..91fc6c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEvaluate.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.evaluateDependencies = void 0; +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const evaluateDependencies = exports.evaluateDependencies = { + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEvaluate: _factoriesAny.createEvaluate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExp.generated.js new file mode 100644 index 0000000..40d3405 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExp.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const expDependencies = exports.expDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createExp: _factoriesAny.createExp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm.generated.js new file mode 100644 index 0000000..f0c0bad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expmDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const expmDependencies = exports.expmDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createExpm: _factoriesAny.createExpm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm1.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm1.generated.js new file mode 100644 index 0000000..2341cce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm1.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expm1Dependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const expm1Dependencies = exports.expm1Dependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createExpm1: _factoriesAny.createExpm1 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFactorial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFactorial.generated.js new file mode 100644 index 0000000..5b0cb68 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFactorial.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.factorialDependencies = void 0; +var _dependenciesGammaGenerated = require("./dependenciesGamma.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const factorialDependencies = exports.factorialDependencies = { + gammaDependencies: _dependenciesGammaGenerated.gammaDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFactorial: _factoriesAny.createFactorial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFalse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFalse.generated.js new file mode 100644 index 0000000..cf7d620 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFalse.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.falseDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const falseDependencies = exports.falseDependencies = { + createFalse: _factoriesAny.createFalse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFaraday.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFaraday.generated.js new file mode 100644 index 0000000..0b764b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFaraday.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.faradayDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const faradayDependencies = exports.faradayDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createFaraday: _factoriesAny.createFaraday +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFermiCoupling.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFermiCoupling.generated.js new file mode 100644 index 0000000..e83d858 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFermiCoupling.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fermiCouplingDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fermiCouplingDependencies = exports.fermiCouplingDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createFermiCoupling: _factoriesAny.createFermiCoupling +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFft.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFft.generated.js new file mode 100644 index 0000000..afcb954 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFft.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fftDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCeilGenerated = require("./dependenciesCeil.generated.js"); +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesDotDivideGenerated = require("./dependenciesDotDivide.generated.js"); +var _dependenciesExpGenerated = require("./dependenciesExp.generated.js"); +var _dependenciesIGenerated = require("./dependenciesI.generated.js"); +var _dependenciesLog2Generated = require("./dependenciesLog2.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesTauGenerated = require("./dependenciesTau.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fftDependencies = exports.fftDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + ceilDependencies: _dependenciesCeilGenerated.ceilDependencies, + conjDependencies: _dependenciesConjGenerated.conjDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies, + expDependencies: _dependenciesExpGenerated.expDependencies, + iDependencies: _dependenciesIGenerated.iDependencies, + log2Dependencies: _dependenciesLog2Generated.log2Dependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + tauDependencies: _dependenciesTauGenerated.tauDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFft: _factoriesAny.createFft +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js new file mode 100644 index 0000000..a652c0d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FibonacciHeapDependencies = void 0; +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FibonacciHeapDependencies = exports.FibonacciHeapDependencies = { + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + createFibonacciHeapClass: _factoriesAny.createFibonacciHeapClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilter.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilter.generated.js new file mode 100644 index 0000000..d2a95b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilter.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.filterDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const filterDependencies = exports.filterDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFilter: _factoriesAny.createFilter +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilterTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilterTransform.generated.js new file mode 100644 index 0000000..e20f07b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilterTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.filterTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const filterTransformDependencies = exports.filterTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFilterTransform: _factoriesAny.createFilterTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFineStructure.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFineStructure.generated.js new file mode 100644 index 0000000..d23fcd1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFineStructure.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fineStructureDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fineStructureDependencies = exports.fineStructureDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createFineStructure: _factoriesAny.createFineStructure +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFirstRadiation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFirstRadiation.generated.js new file mode 100644 index 0000000..71f6d89 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFirstRadiation.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.firstRadiationDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const firstRadiationDependencies = exports.firstRadiationDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createFirstRadiation: _factoriesAny.createFirstRadiation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFix.generated.js new file mode 100644 index 0000000..a3991af --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFix.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fixDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesCeilGenerated = require("./dependenciesCeil.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesFloorGenerated = require("./dependenciesFloor.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fixDependencies = exports.fixDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + ceilDependencies: _dependenciesCeilGenerated.ceilDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + floorDependencies: _dependenciesFloorGenerated.floorDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createFix: _factoriesAny.createFix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFlatten.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFlatten.generated.js new file mode 100644 index 0000000..7374fba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFlatten.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.flattenDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const flattenDependencies = exports.flattenDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFlatten: _factoriesAny.createFlatten +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFloor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFloor.generated.js new file mode 100644 index 0000000..0dab5f4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFloor.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.floorDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const floorDependencies = exports.floorDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createFloor: _factoriesAny.createFloor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEach.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEach.generated.js new file mode 100644 index 0000000..332f049 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEach.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.forEachDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const forEachDependencies = exports.forEachDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createForEach: _factoriesAny.createForEach +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEachTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEachTransform.generated.js new file mode 100644 index 0000000..97f8396 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEachTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.forEachTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const forEachTransformDependencies = exports.forEachTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createForEachTransform: _factoriesAny.createForEachTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFormat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFormat.generated.js new file mode 100644 index 0000000..17e9173 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFormat.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.formatDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const formatDependencies = exports.formatDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFormat: _factoriesAny.createFormat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFraction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFraction.generated.js new file mode 100644 index 0000000..01a451b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFraction.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fractionDependencies = void 0; +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fractionDependencies = exports.fractionDependencies = { + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFraction: _factoriesAny.createFraction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFractionClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFractionClass.generated.js new file mode 100644 index 0000000..3537798 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFractionClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FractionDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FractionDependencies = exports.FractionDependencies = { + createFractionClass: _factoriesAny.createFractionClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFreqz.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFreqz.generated.js new file mode 100644 index 0000000..e4b9c18 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFreqz.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.freqzDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const freqzDependencies = exports.freqzDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFreqz: _factoriesAny.createFreqz +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js new file mode 100644 index 0000000..533b6a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FunctionAssignmentNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FunctionAssignmentNodeDependencies = exports.FunctionAssignmentNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFunctionAssignmentNode: _factoriesAny.createFunctionAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionNode.generated.js new file mode 100644 index 0000000..d49ec5c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FunctionNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FunctionNodeDependencies = exports.FunctionNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + createFunctionNode: _factoriesAny.createFunctionNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGamma.generated.js new file mode 100644 index 0000000..af6f35a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGamma.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gammaDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gammaDependencies = exports.gammaDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createGamma: _factoriesAny.createGamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGasConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGasConstant.generated.js new file mode 100644 index 0000000..21dfe43 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGasConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gasConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gasConstantDependencies = exports.gasConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createGasConstant: _factoriesAny.createGasConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGcd.generated.js new file mode 100644 index 0000000..a43a568 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGcd.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gcdDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gcdDependencies = exports.gcdDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createGcd: _factoriesAny.createGcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js new file mode 100644 index 0000000..82e4827 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getMatrixDataTypeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const getMatrixDataTypeDependencies = exports.getMatrixDataTypeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createGetMatrixDataType: _factoriesAny.createGetMatrixDataType +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravitationConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravitationConstant.generated.js new file mode 100644 index 0000000..51b8b36 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravitationConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gravitationConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gravitationConstantDependencies = exports.gravitationConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createGravitationConstant: _factoriesAny.createGravitationConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravity.generated.js new file mode 100644 index 0000000..3b16894 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravity.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gravityDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gravityDependencies = exports.gravityDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createGravity: _factoriesAny.createGravity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js new file mode 100644 index 0000000..8a62590 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hartreeEnergyDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hartreeEnergyDependencies = exports.hartreeEnergyDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createHartreeEnergy: _factoriesAny.createHartreeEnergy +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHasNumericValue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHasNumericValue.generated.js new file mode 100644 index 0000000..6aeb4c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHasNumericValue.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasNumericValueDependencies = void 0; +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hasNumericValueDependencies = exports.hasNumericValueDependencies = { + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHasNumericValue: _factoriesAny.createHasNumericValue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelp.generated.js new file mode 100644 index 0000000..75337a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelp.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.helpDependencies = void 0; +var _dependenciesHelpClassGenerated = require("./dependenciesHelpClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const helpDependencies = exports.helpDependencies = { + HelpDependencies: _dependenciesHelpClassGenerated.HelpDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHelp: _factoriesAny.createHelp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelpClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelpClass.generated.js new file mode 100644 index 0000000..3d2dcd0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelpClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.HelpDependencies = void 0; +var _dependenciesEvaluateGenerated = require("./dependenciesEvaluate.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const HelpDependencies = exports.HelpDependencies = { + evaluateDependencies: _dependenciesEvaluateGenerated.evaluateDependencies, + createHelpClass: _factoriesAny.createHelpClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHex.generated.js new file mode 100644 index 0000000..a3cfc5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHex.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hexDependencies = void 0; +var _dependenciesFormatGenerated = require("./dependenciesFormat.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hexDependencies = exports.hexDependencies = { + formatDependencies: _dependenciesFormatGenerated.formatDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHex: _factoriesAny.createHex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHypot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHypot.generated.js new file mode 100644 index 0000000..d77515b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHypot.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hypotDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hypotDependencies = exports.hypotDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHypot: _factoriesAny.createHypot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesI.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesI.generated.js new file mode 100644 index 0000000..a172b7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesI.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.iDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const iDependencies = exports.iDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + createI: _factoriesAny.createI +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIdentity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIdentity.generated.js new file mode 100644 index 0000000..dc2635c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIdentity.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.identityDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const identityDependencies = exports.identityDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIdentity: _factoriesAny.createIdentity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIfft.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIfft.generated.js new file mode 100644 index 0000000..b39012b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIfft.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ifftDependencies = void 0; +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesDotDivideGenerated = require("./dependenciesDotDivide.generated.js"); +var _dependenciesFftGenerated = require("./dependenciesFft.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ifftDependencies = exports.ifftDependencies = { + conjDependencies: _dependenciesConjGenerated.conjDependencies, + dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies, + fftDependencies: _dependenciesFftGenerated.fftDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIfft: _factoriesAny.createIfft +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIm.generated.js new file mode 100644 index 0000000..5f8f27a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIm.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.imDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const imDependencies = exports.imDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIm: _factoriesAny.createIm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js new file mode 100644 index 0000000..6096907 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ImmutableDenseMatrixDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ImmutableDenseMatrixDependencies = exports.ImmutableDenseMatrixDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + createImmutableDenseMatrixClass: _factoriesAny.createImmutableDenseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndex.generated.js new file mode 100644 index 0000000..74abca3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndex.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.indexDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const indexDependencies = exports.indexDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIndex: _factoriesAny.createIndex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexClass.generated.js new file mode 100644 index 0000000..6731548 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexClass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.IndexDependencies = void 0; +var _dependenciesImmutableDenseMatrixClassGenerated = require("./dependenciesImmutableDenseMatrixClass.generated.js"); +var _dependenciesGetMatrixDataTypeGenerated = require("./dependenciesGetMatrixDataType.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const IndexDependencies = exports.IndexDependencies = { + ImmutableDenseMatrixDependencies: _dependenciesImmutableDenseMatrixClassGenerated.ImmutableDenseMatrixDependencies, + getMatrixDataTypeDependencies: _dependenciesGetMatrixDataTypeGenerated.getMatrixDataTypeDependencies, + createIndexClass: _factoriesAny.createIndexClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexNode.generated.js new file mode 100644 index 0000000..967371d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.IndexNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const IndexNodeDependencies = exports.IndexNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + createIndexNode: _factoriesAny.createIndexNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexTransform.generated.js new file mode 100644 index 0000000..94fc2f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexTransform.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.indexTransformDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesGetMatrixDataTypeGenerated = require("./dependenciesGetMatrixDataType.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const indexTransformDependencies = exports.indexTransformDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + getMatrixDataTypeDependencies: _dependenciesGetMatrixDataTypeGenerated.getMatrixDataTypeDependencies, + createIndexTransform: _factoriesAny.createIndexTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInfinity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInfinity.generated.js new file mode 100644 index 0000000..2534c8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInfinity.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.InfinityDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const InfinityDependencies = exports.InfinityDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createInfinity: _factoriesAny.createInfinity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIntersect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIntersect.generated.js new file mode 100644 index 0000000..5ecc970 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIntersect.generated.js @@ -0,0 +1,43 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.intersectDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesFlattenGenerated = require("./dependenciesFlatten.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const intersectDependencies = exports.intersectDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIntersect: _factoriesAny.createIntersect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInv.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInv.generated.js new file mode 100644 index 0000000..7641b37 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInv.generated.js @@ -0,0 +1,33 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.invDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDetGenerated = require("./dependenciesDet.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const invDependencies = exports.invDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + detDependencies: _dependenciesDetGenerated.detDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createInv: _factoriesAny.createInv +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js new file mode 100644 index 0000000..37f933d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.inverseConductanceQuantumDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const inverseConductanceQuantumDependencies = exports.inverseConductanceQuantumDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createInverseConductanceQuantum: _factoriesAny.createInverseConductanceQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInvmod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInvmod.generated.js new file mode 100644 index 0000000..fa6d7f2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInvmod.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.invmodDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesModGenerated = require("./dependenciesMod.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesXgcdGenerated = require("./dependenciesXgcd.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const invmodDependencies = exports.invmodDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + modDependencies: _dependenciesModGenerated.modDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + xgcdDependencies: _dependenciesXgcdGenerated.xgcdDependencies, + createInvmod: _factoriesAny.createInvmod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsInteger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsInteger.generated.js new file mode 100644 index 0000000..35afad2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsInteger.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isIntegerDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isIntegerDependencies = exports.isIntegerDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsInteger: _factoriesAny.createIsInteger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNaN.generated.js new file mode 100644 index 0000000..190d036 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNaN.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNaNDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNaNDependencies = exports.isNaNDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNaN: _factoriesAny.createIsNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNegative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNegative.generated.js new file mode 100644 index 0000000..1039abf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNegative.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNegativeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNegativeDependencies = exports.isNegativeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNegative: _factoriesAny.createIsNegative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNumeric.generated.js new file mode 100644 index 0000000..5ba31d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNumeric.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNumericDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNumericDependencies = exports.isNumericDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNumeric: _factoriesAny.createIsNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPositive.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPositive.generated.js new file mode 100644 index 0000000..0b19335 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPositive.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPositiveDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isPositiveDependencies = exports.isPositiveDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsPositive: _factoriesAny.createIsPositive +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPrime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPrime.generated.js new file mode 100644 index 0000000..82ebfd0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPrime.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPrimeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isPrimeDependencies = exports.isPrimeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsPrime: _factoriesAny.createIsPrime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsZero.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsZero.generated.js new file mode 100644 index 0000000..1d86159 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsZero.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isZeroDependencies = void 0; +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isZeroDependencies = exports.isZeroDependencies = { + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsZero: _factoriesAny.createIsZero +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKldivergence.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKldivergence.generated.js new file mode 100644 index 0000000..30cd592 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKldivergence.generated.js @@ -0,0 +1,33 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.kldivergenceDependencies = void 0; +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesDotDivideGenerated = require("./dependenciesDotDivide.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesLogGenerated = require("./dependenciesLog.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSumGenerated = require("./dependenciesSum.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const kldivergenceDependencies = exports.kldivergenceDependencies = { + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + logDependencies: _dependenciesLogGenerated.logDependencies, + mapDependencies: _dependenciesMapGenerated.mapDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + sumDependencies: _dependenciesSumGenerated.sumDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createKldivergence: _factoriesAny.createKldivergence +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKlitzing.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKlitzing.generated.js new file mode 100644 index 0000000..9c6aefc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKlitzing.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.klitzingDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const klitzingDependencies = exports.klitzingDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createKlitzing: _factoriesAny.createKlitzing +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKron.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKron.generated.js new file mode 100644 index 0000000..7e6eff6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKron.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.kronDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const kronDependencies = exports.kronDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createKron: _factoriesAny.createKron +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN10.generated.js new file mode 100644 index 0000000..42d6d6f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN10.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN10Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LN10Dependencies = exports.LN10Dependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createLN10: _factoriesAny.createLN10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN2.generated.js new file mode 100644 index 0000000..6ea7e58 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN2.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN2Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LN2Dependencies = exports.LN2Dependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createLN2: _factoriesAny.createLN2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG10E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG10E.generated.js new file mode 100644 index 0000000..d86d760 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG10E.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG10EDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LOG10EDependencies = exports.LOG10EDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createLOG10E: _factoriesAny.createLOG10E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG2E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG2E.generated.js new file mode 100644 index 0000000..c85914b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG2E.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG2EDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LOG2EDependencies = exports.LOG2EDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createLOG2E: _factoriesAny.createLOG2E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLarger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLarger.generated.js new file mode 100644 index 0000000..f620af8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLarger.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const largerDependencies = exports.largerDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLarger: _factoriesAny.createLarger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLargerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLargerEq.generated.js new file mode 100644 index 0000000..3f29148 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLargerEq.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerEqDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const largerEqDependencies = exports.largerEqDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLargerEq: _factoriesAny.createLargerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLcm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLcm.generated.js new file mode 100644 index 0000000..f279e17 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLcm.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lcmDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lcmDependencies = exports.lcmDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLcm: _factoriesAny.createLcm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeafCount.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeafCount.generated.js new file mode 100644 index 0000000..409882d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeafCount.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.leafCountDependencies = void 0; +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const leafCountDependencies = exports.leafCountDependencies = { + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLeafCount: _factoriesAny.createLeafCount +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeftShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeftShift.generated.js new file mode 100644 index 0000000..bd6c224 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeftShift.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.leftShiftDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const leftShiftDependencies = exports.leftShiftDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createLeftShift: _factoriesAny.createLeftShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLgamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLgamma.generated.js new file mode 100644 index 0000000..7c12fe1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLgamma.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lgammaDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lgammaDependencies = exports.lgammaDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLgamma: _factoriesAny.createLgamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog.generated.js new file mode 100644 index 0000000..b1be622 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.logDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const logDependencies = exports.logDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog: _factoriesAny.createLog +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog10.generated.js new file mode 100644 index 0000000..865cd7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog10.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log10Dependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log10Dependencies = exports.log10Dependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog10: _factoriesAny.createLog10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog1p.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog1p.generated.js new file mode 100644 index 0000000..7b6af55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog1p.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log1pDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesLogGenerated = require("./dependenciesLog.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log1pDependencies = exports.log1pDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + logDependencies: _dependenciesLogGenerated.logDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog1p: _factoriesAny.createLog1p +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog2.generated.js new file mode 100644 index 0000000..be63826 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog2.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log2Dependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log2Dependencies = exports.log2Dependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog2: _factoriesAny.createLog2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLoschmidt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLoschmidt.generated.js new file mode 100644 index 0000000..1188507 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLoschmidt.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.loschmidtDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const loschmidtDependencies = exports.loschmidtDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createLoschmidt: _factoriesAny.createLoschmidt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolve.generated.js new file mode 100644 index 0000000..a7baef8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolve.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lsolveDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lsolveDependencies = exports.lsolveDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLsolve: _factoriesAny.createLsolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolveAll.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolveAll.generated.js new file mode 100644 index 0000000..1c2c7ce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolveAll.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lsolveAllDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lsolveAllDependencies = exports.lsolveAllDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLsolveAll: _factoriesAny.createLsolveAll +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLup.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLup.generated.js new file mode 100644 index 0000000..84ff4ac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLup.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lupDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSpaClassGenerated = require("./dependenciesSpaClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lupDependencies = exports.lupDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + SpaDependencies: _dependenciesSpaClassGenerated.SpaDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createLup: _factoriesAny.createLup +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLusolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLusolve.generated.js new file mode 100644 index 0000000..fb3df3f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLusolve.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lusolveDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesLsolveGenerated = require("./dependenciesLsolve.generated.js"); +var _dependenciesLupGenerated = require("./dependenciesLup.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesSluGenerated = require("./dependenciesSlu.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUsolveGenerated = require("./dependenciesUsolve.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lusolveDependencies = exports.lusolveDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + lsolveDependencies: _dependenciesLsolveGenerated.lsolveDependencies, + lupDependencies: _dependenciesLupGenerated.lupDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + sluDependencies: _dependenciesSluGenerated.sluDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + usolveDependencies: _dependenciesUsolveGenerated.usolveDependencies, + createLusolve: _factoriesAny.createLusolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLyap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLyap.generated.js new file mode 100644 index 0000000..9a092ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLyap.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lyapDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSylvesterGenerated = require("./dependenciesSylvester.generated.js"); +var _dependenciesTransposeGenerated = require("./dependenciesTranspose.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lyapDependencies = exports.lyapDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + sylvesterDependencies: _dependenciesSylvesterGenerated.sylvesterDependencies, + transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLyap: _factoriesAny.createLyap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMad.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMad.generated.js new file mode 100644 index 0000000..d8f13d2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMad.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.madDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesMedianGenerated = require("./dependenciesMedian.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const madDependencies = exports.madDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + mapDependencies: _dependenciesMapGenerated.mapDependencies, + medianDependencies: _dependenciesMedianGenerated.medianDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMad: _factoriesAny.createMad +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticConstant.generated.js new file mode 100644 index 0000000..7812682 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.magneticConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const magneticConstantDependencies = exports.magneticConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMagneticConstant: _factoriesAny.createMagneticConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js new file mode 100644 index 0000000..8a2d2a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.magneticFluxQuantumDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const magneticFluxQuantumDependencies = exports.magneticFluxQuantumDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMagneticFluxQuantum: _factoriesAny.createMagneticFluxQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMap.generated.js new file mode 100644 index 0000000..23e401d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMap.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mapDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const mapDependencies = exports.mapDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMap: _factoriesAny.createMap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMapTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMapTransform.generated.js new file mode 100644 index 0000000..42567b3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMapTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mapTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const mapTransformDependencies = exports.mapTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMapTransform: _factoriesAny.createMapTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrix.generated.js new file mode 100644 index 0000000..f085dd6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrix.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesMatrixClassGenerated = require("./dependenciesMatrixClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const matrixDependencies = exports.matrixDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMatrix: _factoriesAny.createMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixClass.generated.js new file mode 100644 index 0000000..f28ed0c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.MatrixDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const MatrixDependencies = exports.MatrixDependencies = { + createMatrixClass: _factoriesAny.createMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js new file mode 100644 index 0000000..2722b83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromColumnsDependencies = void 0; +var _dependenciesFlattenGenerated = require("./dependenciesFlatten.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const matrixFromColumnsDependencies = exports.matrixFromColumnsDependencies = { + flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMatrixFromColumns: _factoriesAny.createMatrixFromColumns +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js new file mode 100644 index 0000000..affb043 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromFunctionDependencies = void 0; +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const matrixFromFunctionDependencies = exports.matrixFromFunctionDependencies = { + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMatrixFromFunction: _factoriesAny.createMatrixFromFunction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js new file mode 100644 index 0000000..bc05055 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromRowsDependencies = void 0; +var _dependenciesFlattenGenerated = require("./dependenciesFlatten.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const matrixFromRowsDependencies = exports.matrixFromRowsDependencies = { + flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMatrixFromRows: _factoriesAny.createMatrixFromRows +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMax.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMax.generated.js new file mode 100644 index 0000000..9740c37 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMax.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.maxDependencies = void 0; +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const maxDependencies = exports.maxDependencies = { + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMax: _factoriesAny.createMax +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMaxTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMaxTransform.generated.js new file mode 100644 index 0000000..b7b2275 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMaxTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.maxTransformDependencies = void 0; +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const maxTransformDependencies = exports.maxTransformDependencies = { + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMaxTransform: _factoriesAny.createMaxTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMean.generated.js new file mode 100644 index 0000000..73fb788 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMean.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.meanDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const meanDependencies = exports.meanDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMean: _factoriesAny.createMean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMeanTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMeanTransform.generated.js new file mode 100644 index 0000000..43b58de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMeanTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.meanTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const meanTransformDependencies = exports.meanTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMeanTransform: _factoriesAny.createMeanTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMedian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMedian.generated.js new file mode 100644 index 0000000..7ccea59 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMedian.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.medianDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesPartitionSelect.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const medianDependencies = exports.medianDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMedian: _factoriesAny.createMedian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMin.generated.js new file mode 100644 index 0000000..4ae9bc5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMin.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.minDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const minDependencies = exports.minDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMin: _factoriesAny.createMin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMinTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMinTransform.generated.js new file mode 100644 index 0000000..9cc2656 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMinTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.minTransformDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const minTransformDependencies = exports.minTransformDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMinTransform: _factoriesAny.createMinTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMod.generated.js new file mode 100644 index 0000000..0c66c0c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMod.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const modDependencies = exports.modDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createMod: _factoriesAny.createMod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMode.generated.js new file mode 100644 index 0000000..120cf46 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMode.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modeDependencies = void 0; +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const modeDependencies = exports.modeDependencies = { + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMode: _factoriesAny.createMode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMass.generated.js new file mode 100644 index 0000000..359508e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.molarMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const molarMassDependencies = exports.molarMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMolarMass: _factoriesAny.createMolarMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMassC12.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMassC12.generated.js new file mode 100644 index 0000000..685080c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMassC12.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.molarMassC12Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const molarMassC12Dependencies = exports.molarMassC12Dependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMolarMassC12: _factoriesAny.createMolarMassC12 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js new file mode 100644 index 0000000..465673e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.molarPlanckConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const molarPlanckConstantDependencies = exports.molarPlanckConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMolarPlanckConstant: _factoriesAny.createMolarPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarVolume.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarVolume.generated.js new file mode 100644 index 0000000..025d170 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarVolume.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.molarVolumeDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const molarVolumeDependencies = exports.molarVolumeDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createMolarVolume: _factoriesAny.createMolarVolume +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultinomial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultinomial.generated.js new file mode 100644 index 0000000..7aac091 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultinomial.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multinomialDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multinomialDependencies = exports.multinomialDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultinomial: _factoriesAny.createMultinomial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiply.generated.js new file mode 100644 index 0000000..5058b57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiply.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multiplyDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDotGenerated = require("./dependenciesDot.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multiplyDependencies = exports.multiplyDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + dotDependencies: _dependenciesDotGenerated.dotDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultiply: _factoriesAny.createMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js new file mode 100644 index 0000000..c93ed59 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multiplyScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multiplyScalarDependencies = exports.multiplyScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultiplyScalar: _factoriesAny.createMultiplyScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNaN.generated.js new file mode 100644 index 0000000..0a40ca2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNaN.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NaNDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const NaNDependencies = exports.NaNDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createNaN: _factoriesAny.createNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNeutronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNeutronMass.generated.js new file mode 100644 index 0000000..793c05d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNeutronMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.neutronMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const neutronMassDependencies = exports.neutronMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createNeutronMass: _factoriesAny.createNeutronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNode.generated.js new file mode 100644 index 0000000..4028831 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNode.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NodeDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const NodeDependencies = exports.NodeDependencies = { + createNode: _factoriesAny.createNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNorm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNorm.generated.js new file mode 100644 index 0000000..a9144a6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNorm.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.normDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesCtransposeGenerated = require("./dependenciesCtranspose.generated.js"); +var _dependenciesEigsGenerated = require("./dependenciesEigs.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const normDependencies = exports.normDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + conjDependencies: _dependenciesConjGenerated.conjDependencies, + ctransposeDependencies: _dependenciesCtransposeGenerated.ctransposeDependencies, + eigsDependencies: _dependenciesEigsGenerated.eigsDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNorm: _factoriesAny.createNorm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNot.generated.js new file mode 100644 index 0000000..0b6d52a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.notDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const notDependencies = exports.notDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNot: _factoriesAny.createNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoot.generated.js new file mode 100644 index 0000000..fb7b091 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoot.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nthRootDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nthRootDependencies = exports.nthRootDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNthRoot: _factoriesAny.createNthRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoots.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoots.generated.js new file mode 100644 index 0000000..a2fd939 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoots.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nthRootsDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nthRootsDependencies = exports.nthRootsDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNthRoots: _factoriesAny.createNthRoots +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js new file mode 100644 index 0000000..016d4f9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nuclearMagnetonDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nuclearMagnetonDependencies = exports.nuclearMagnetonDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createNuclearMagneton: _factoriesAny.createNuclearMagneton +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNull.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNull.generated.js new file mode 100644 index 0000000..06e6030 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNull.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nullDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nullDependencies = exports.nullDependencies = { + createNull: _factoriesAny.createNull +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumber.generated.js new file mode 100644 index 0000000..f2daee6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumber.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numberDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const numberDependencies = exports.numberDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNumber: _factoriesAny.createNumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumeric.generated.js new file mode 100644 index 0000000..736f9de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumeric.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numericDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesFraction.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const numericDependencies = exports.numericDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + fractionDependencies: _dependenciesFractionGenerated.fractionDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + createNumeric: _factoriesAny.createNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesObjectNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesObjectNode.generated.js new file mode 100644 index 0000000..9d6abee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesObjectNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ObjectNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ObjectNodeDependencies = exports.ObjectNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createObjectNode: _factoriesAny.createObjectNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOct.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOct.generated.js new file mode 100644 index 0000000..22a2fc9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOct.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.octDependencies = void 0; +var _dependenciesFormatGenerated = require("./dependenciesFormat.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const octDependencies = exports.octDependencies = { + formatDependencies: _dependenciesFormatGenerated.formatDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createOct: _factoriesAny.createOct +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOnes.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOnes.generated.js new file mode 100644 index 0000000..6bf6fa4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOnes.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.onesDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const onesDependencies = exports.onesDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createOnes: _factoriesAny.createOnes +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOperatorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOperatorNode.generated.js new file mode 100644 index 0000000..2787034 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOperatorNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.OperatorNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const OperatorNodeDependencies = exports.OperatorNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createOperatorNode: _factoriesAny.createOperatorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOr.generated.js new file mode 100644 index 0000000..de904e7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOr.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.orDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const orDependencies = exports.orDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createOr: _factoriesAny.createOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOrTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOrTransform.generated.js new file mode 100644 index 0000000..83f0370 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOrTransform.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.orTransformDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const orTransformDependencies = exports.orTransformDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createOrTransform: _factoriesAny.createOrTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParenthesisNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParenthesisNode.generated.js new file mode 100644 index 0000000..08de22b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParenthesisNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ParenthesisNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ParenthesisNodeDependencies = exports.ParenthesisNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createParenthesisNode: _factoriesAny.createParenthesisNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParse.generated.js new file mode 100644 index 0000000..de8dace --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParse.generated.js @@ -0,0 +1,49 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.parseDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesAssignmentNodeGenerated = require("./dependenciesAssignmentNode.generated.js"); +var _dependenciesBlockNodeGenerated = require("./dependenciesBlockNode.generated.js"); +var _dependenciesConditionalNodeGenerated = require("./dependenciesConditionalNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionAssignmentNodeGenerated = require("./dependenciesFunctionAssignmentNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesRangeNodeGenerated = require("./dependenciesRangeNode.generated.js"); +var _dependenciesRelationalNodeGenerated = require("./dependenciesRelationalNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const parseDependencies = exports.parseDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + AssignmentNodeDependencies: _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies, + BlockNodeDependencies: _dependenciesBlockNodeGenerated.BlockNodeDependencies, + ConditionalNodeDependencies: _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionAssignmentNodeDependencies: _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + RangeNodeDependencies: _dependenciesRangeNodeGenerated.RangeNodeDependencies, + RelationalNodeDependencies: _dependenciesRelationalNodeGenerated.RelationalNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createParse: _factoriesAny.createParse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParser.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParser.generated.js new file mode 100644 index 0000000..9fa99ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParser.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.parserDependencies = void 0; +var _dependenciesParserClassGenerated = require("./dependenciesParserClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const parserDependencies = exports.parserDependencies = { + ParserDependencies: _dependenciesParserClassGenerated.ParserDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createParser: _factoriesAny.createParser +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParserClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParserClass.generated.js new file mode 100644 index 0000000..2187acc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParserClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ParserDependencies = void 0; +var _dependenciesEvaluateGenerated = require("./dependenciesEvaluate.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ParserDependencies = exports.ParserDependencies = { + evaluateDependencies: _dependenciesEvaluateGenerated.evaluateDependencies, + createParserClass: _factoriesAny.createParserClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPartitionSelect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPartitionSelect.generated.js new file mode 100644 index 0000000..3ec52a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPartitionSelect.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.partitionSelectDependencies = void 0; +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const partitionSelectDependencies = exports.partitionSelectDependencies = { + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPartitionSelect: _factoriesAny.createPartitionSelect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPermutations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPermutations.generated.js new file mode 100644 index 0000000..dd90fb5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPermutations.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.permutationsDependencies = void 0; +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const permutationsDependencies = exports.permutationsDependencies = { + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPermutations: _factoriesAny.createPermutations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPhi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPhi.generated.js new file mode 100644 index 0000000..d11ac28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPhi.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.phiDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const phiDependencies = exports.phiDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createPhi: _factoriesAny.createPhi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPi.generated.js new file mode 100644 index 0000000..98f8d9e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPi.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.piDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const piDependencies = exports.piDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createPi: _factoriesAny.createPi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPickRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPickRandom.generated.js new file mode 100644 index 0000000..492616c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPickRandom.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.pickRandomDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const pickRandomDependencies = exports.pickRandomDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPickRandom: _factoriesAny.createPickRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPinv.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPinv.generated.js new file mode 100644 index 0000000..73f1f8b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPinv.generated.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.pinvDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCtransposeGenerated = require("./dependenciesCtranspose.generated.js"); +var _dependenciesDeepEqualGenerated = require("./dependenciesDeepEqual.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesDotGenerated = require("./dependenciesDot.generated.js"); +var _dependenciesDotDivideGenerated = require("./dependenciesDotDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const pinvDependencies = exports.pinvDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + ctransposeDependencies: _dependenciesCtransposeGenerated.ctransposeDependencies, + deepEqualDependencies: _dependenciesDeepEqualGenerated.deepEqualDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + dotDependencies: _dependenciesDotGenerated.dotDependencies, + dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPinv: _factoriesAny.createPinv +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckCharge.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckCharge.generated.js new file mode 100644 index 0000000..a201819 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckCharge.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckChargeDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckChargeDependencies = exports.planckChargeDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckCharge: _factoriesAny.createPlanckCharge +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckConstant.generated.js new file mode 100644 index 0000000..067e11d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckConstantDependencies = exports.planckConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckConstant: _factoriesAny.createPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckLength.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckLength.generated.js new file mode 100644 index 0000000..8e3fd7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckLength.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckLengthDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckLengthDependencies = exports.planckLengthDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckLength: _factoriesAny.createPlanckLength +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckMass.generated.js new file mode 100644 index 0000000..131852c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckMassDependencies = exports.planckMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckMass: _factoriesAny.createPlanckMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js new file mode 100644 index 0000000..742e2ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckTemperatureDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckTemperatureDependencies = exports.planckTemperatureDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckTemperature: _factoriesAny.createPlanckTemperature +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTime.generated.js new file mode 100644 index 0000000..4a24085 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTime.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.planckTimeDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const planckTimeDependencies = exports.planckTimeDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createPlanckTime: _factoriesAny.createPlanckTime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js new file mode 100644 index 0000000..08b10fb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.polynomialRootDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCbrtGenerated = require("./dependenciesCbrt.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesImGenerated = require("./dependenciesIm.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesReGenerated = require("./dependenciesRe.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypeOfGenerated = require("./dependenciesTypeOf.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const polynomialRootDependencies = exports.polynomialRootDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + cbrtDependencies: _dependenciesCbrtGenerated.cbrtDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + imDependencies: _dependenciesImGenerated.imDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + reDependencies: _dependenciesReGenerated.reDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typeOfDependencies: _dependenciesTypeOfGenerated.typeOfDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createPolynomialRoot: _factoriesAny.createPolynomialRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPow.generated.js new file mode 100644 index 0000000..9f3cf06 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPow.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.powDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesFraction.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const powDependencies = exports.powDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + fractionDependencies: _dependenciesFractionGenerated.fractionDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPow: _factoriesAny.createPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrint.generated.js new file mode 100644 index 0000000..61ec88a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrint.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.printDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const printDependencies = exports.printDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPrint: _factoriesAny.createPrint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrintTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrintTransform.generated.js new file mode 100644 index 0000000..de5b63c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrintTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.printTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const printTransformDependencies = exports.printTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createPrintTransform: _factoriesAny.createPrintTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProd.generated.js new file mode 100644 index 0000000..81232f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProd.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.prodDependencies = void 0; +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const prodDependencies = exports.prodDependencies = { + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createProd: _factoriesAny.createProd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProtonMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProtonMass.generated.js new file mode 100644 index 0000000..1676078 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProtonMass.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.protonMassDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const protonMassDependencies = exports.protonMassDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createProtonMass: _factoriesAny.createProtonMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQr.generated.js new file mode 100644 index 0000000..c84ce8e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQr.generated.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.qrDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesComplexGenerated = require("./dependenciesComplex.generated.js"); +var _dependenciesConjGenerated = require("./dependenciesConj.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSignGenerated = require("./dependenciesSign.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const qrDependencies = exports.qrDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + complexDependencies: _dependenciesComplexGenerated.complexDependencies, + conjDependencies: _dependenciesConjGenerated.conjDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + signDependencies: _dependenciesSignGenerated.signDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createQr: _factoriesAny.createQr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeq.generated.js new file mode 100644 index 0000000..9752ff1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeq.generated.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.quantileSeqDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesPartitionSelect.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const quantileSeqDependencies = exports.quantileSeqDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createQuantileSeq: _factoriesAny.createQuantileSeq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js new file mode 100644 index 0000000..37e2332 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.quantileSeqTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesPartitionSelect.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const quantileSeqTransformDependencies = exports.quantileSeqTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createQuantileSeqTransform: _factoriesAny.createQuantileSeqTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js new file mode 100644 index 0000000..10a77cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.quantumOfCirculationDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const quantumOfCirculationDependencies = exports.quantumOfCirculationDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createQuantumOfCirculation: _factoriesAny.createQuantumOfCirculation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandom.generated.js new file mode 100644 index 0000000..bd3adb8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandom.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const randomDependencies = exports.randomDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRandom: _factoriesAny.createRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandomInt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandomInt.generated.js new file mode 100644 index 0000000..d28db08 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandomInt.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomIntDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const randomIntDependencies = exports.randomIntDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRandomInt: _factoriesAny.createRandomInt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRange.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRange.generated.js new file mode 100644 index 0000000..7c3aa34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRange.generated.js @@ -0,0 +1,33 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rangeDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesLargerEq.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rangeDependencies = exports.rangeDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRange: _factoriesAny.createRange +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeClass.generated.js new file mode 100644 index 0000000..f1e48ad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RangeDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RangeDependencies = exports.RangeDependencies = { + createRangeClass: _factoriesAny.createRangeClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeNode.generated.js new file mode 100644 index 0000000..7aad9a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RangeNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RangeNodeDependencies = exports.RangeNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createRangeNode: _factoriesAny.createRangeNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeTransform.generated.js new file mode 100644 index 0000000..60a437d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeTransform.generated.js @@ -0,0 +1,33 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rangeTransformDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesLargerEq.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rangeTransformDependencies = exports.rangeTransformDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRangeTransform: _factoriesAny.createRangeTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRationalize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRationalize.generated.js new file mode 100644 index 0000000..7668049 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRationalize.generated.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rationalizeDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesFraction.generated.js"); +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesSimplify.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesSimplifyCore.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rationalizeDependencies = exports.rationalizeDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + fractionDependencies: _dependenciesFractionGenerated.fractionDependencies, + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies, + simplifyConstantDependencies: _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies, + simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRationalize: _factoriesAny.createRationalize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRe.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRe.generated.js new file mode 100644 index 0000000..35789c5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRe.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const reDependencies = exports.reDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRe: _factoriesAny.createRe +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js new file mode 100644 index 0000000..4041248 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reducedPlanckConstantDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const reducedPlanckConstantDependencies = exports.reducedPlanckConstantDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createReducedPlanckConstant: _factoriesAny.createReducedPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRelationalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRelationalNode.generated.js new file mode 100644 index 0000000..62c1626 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRelationalNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RelationalNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RelationalNodeDependencies = exports.RelationalNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createRelationalNode: _factoriesAny.createRelationalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReplacer.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReplacer.generated.js new file mode 100644 index 0000000..39e3ff1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReplacer.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.replacerDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const replacerDependencies = exports.replacerDependencies = { + createReplacer: _factoriesAny.createReplacer +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReshape.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReshape.generated.js new file mode 100644 index 0000000..7587a7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReshape.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reshapeDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const reshapeDependencies = exports.reshapeDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createReshape: _factoriesAny.createReshape +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResize.generated.js new file mode 100644 index 0000000..4c9546e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResize.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.resizeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const resizeDependencies = exports.resizeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + createResize: _factoriesAny.createResize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResolve.generated.js new file mode 100644 index 0000000..7b174e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResolve.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.resolveDependencies = void 0; +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const resolveDependencies = exports.resolveDependencies = { + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createResolve: _factoriesAny.createResolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResultSet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResultSet.generated.js new file mode 100644 index 0000000..0ee382c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResultSet.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ResultSetDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ResultSetDependencies = exports.ResultSetDependencies = { + createResultSet: _factoriesAny.createResultSet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReviver.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReviver.generated.js new file mode 100644 index 0000000..8507ead --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReviver.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reviverDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const reviverDependencies = exports.reviverDependencies = { + createReviver: _factoriesAny.createReviver +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightArithShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightArithShift.generated.js new file mode 100644 index 0000000..a2add6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightArithShift.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightArithShiftDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rightArithShiftDependencies = exports.rightArithShiftDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createRightArithShift: _factoriesAny.createRightArithShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightLogShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightLogShift.generated.js new file mode 100644 index 0000000..ae40dd7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightLogShift.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightLogShiftDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rightLogShiftDependencies = exports.rightLogShiftDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createRightLogShift: _factoriesAny.createRightLogShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotate.generated.js new file mode 100644 index 0000000..ac2bf2d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotate.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rotateDependencies = void 0; +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesRotationMatrixGenerated = require("./dependenciesRotationMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rotateDependencies = exports.rotateDependencies = { + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + rotationMatrixDependencies: _dependenciesRotationMatrixGenerated.rotationMatrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRotate: _factoriesAny.createRotate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotationMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotationMatrix.generated.js new file mode 100644 index 0000000..b64a159 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotationMatrix.generated.js @@ -0,0 +1,37 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rotationMatrixDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCosGenerated = require("./dependenciesCos.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNormGenerated = require("./dependenciesNorm.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesSin.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rotationMatrixDependencies = exports.rotationMatrixDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + cosDependencies: _dependenciesCosGenerated.cosDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + normDependencies: _dependenciesNormGenerated.normDependencies, + sinDependencies: _dependenciesSinGenerated.sinDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createRotationMatrix: _factoriesAny.createRotationMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRound.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRound.generated.js new file mode 100644 index 0000000..3b222f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRound.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.roundDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const roundDependencies = exports.roundDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createRound: _factoriesAny.createRound +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRow.generated.js new file mode 100644 index 0000000..39b94b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRow.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rowDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesRange.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rowDependencies = exports.rowDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + rangeDependencies: _dependenciesRangeGenerated.rangeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRow: _factoriesAny.createRow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRowTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRowTransform.generated.js new file mode 100644 index 0000000..70fc593 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRowTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rowTransformDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesRange.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rowTransformDependencies = exports.rowTransformDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + rangeDependencies: _dependenciesRangeGenerated.rangeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRowTransform: _factoriesAny.createRowTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRydberg.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRydberg.generated.js new file mode 100644 index 0000000..6df96b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRydberg.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rydbergDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rydbergDependencies = exports.rydbergDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createRydberg: _factoriesAny.createRydberg +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT1_2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT1_2.generated.js new file mode 100644 index 0000000..d2257d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT1_2.generated.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT1_2Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +// eslint-disable-line camelcase + +const SQRT1_2Dependencies = exports.SQRT1_2Dependencies = { + // eslint-disable-line camelcase + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createSQRT1_2: _factoriesAny.createSQRT1_2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT2.generated.js new file mode 100644 index 0000000..f6b0b76 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT2.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT2Dependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SQRT2Dependencies = exports.SQRT2Dependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createSQRT2: _factoriesAny.createSQRT2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSackurTetrode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSackurTetrode.generated.js new file mode 100644 index 0000000..48869b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSackurTetrode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sackurTetrodeDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sackurTetrodeDependencies = exports.sackurTetrodeDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createSackurTetrode: _factoriesAny.createSackurTetrode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSchur.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSchur.generated.js new file mode 100644 index 0000000..38fdf66 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSchur.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.schurDependencies = void 0; +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesNormGenerated = require("./dependenciesNorm.generated.js"); +var _dependenciesQrGenerated = require("./dependenciesQr.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const schurDependencies = exports.schurDependencies = { + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + normDependencies: _dependenciesNormGenerated.normDependencies, + qrDependencies: _dependenciesQrGenerated.qrDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSchur: _factoriesAny.createSchur +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSec.generated.js new file mode 100644 index 0000000..7c17436 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSec.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.secDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const secDependencies = exports.secDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSec: _factoriesAny.createSec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSech.generated.js new file mode 100644 index 0000000..954a48d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSech.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sechDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sechDependencies = exports.sechDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSech: _factoriesAny.createSech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSecondRadiation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSecondRadiation.generated.js new file mode 100644 index 0000000..25f2773 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSecondRadiation.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.secondRadiationDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const secondRadiationDependencies = exports.secondRadiationDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createSecondRadiation: _factoriesAny.createSecondRadiation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetCartesian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetCartesian.generated.js new file mode 100644 index 0000000..7ad7c4d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetCartesian.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setCartesianDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setCartesianDependencies = exports.setCartesianDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetCartesian: _factoriesAny.createSetCartesian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDifference.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDifference.generated.js new file mode 100644 index 0000000..048786c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDifference.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setDifferenceDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setDifferenceDependencies = exports.setDifferenceDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetDifference: _factoriesAny.createSetDifference +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDistinct.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDistinct.generated.js new file mode 100644 index 0000000..047735f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDistinct.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setDistinctDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setDistinctDependencies = exports.setDistinctDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetDistinct: _factoriesAny.createSetDistinct +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIntersect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIntersect.generated.js new file mode 100644 index 0000000..7f24e3a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIntersect.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setIntersectDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setIntersectDependencies = exports.setIntersectDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetIntersect: _factoriesAny.createSetIntersect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIsSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIsSubset.generated.js new file mode 100644 index 0000000..2171853 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIsSubset.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setIsSubsetDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setIsSubsetDependencies = exports.setIsSubsetDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetIsSubset: _factoriesAny.createSetIsSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js new file mode 100644 index 0000000..404a796 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setMultiplicityDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setMultiplicityDependencies = exports.setMultiplicityDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetMultiplicity: _factoriesAny.createSetMultiplicity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetPowerset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetPowerset.generated.js new file mode 100644 index 0000000..d35c0d4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetPowerset.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setPowersetDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setPowersetDependencies = exports.setPowersetDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetPowerset: _factoriesAny.createSetPowerset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSize.generated.js new file mode 100644 index 0000000..9b821a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSize.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setSizeDependencies = void 0; +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setSizeDependencies = exports.setSizeDependencies = { + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetSize: _factoriesAny.createSetSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSymDifference.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSymDifference.generated.js new file mode 100644 index 0000000..6c4bf9b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSymDifference.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setSymDifferenceDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesSetDifferenceGenerated = require("./dependenciesSetDifference.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setSymDifferenceDependencies = exports.setSymDifferenceDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + setDifferenceDependencies: _dependenciesSetDifferenceGenerated.setDifferenceDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetSymDifference: _factoriesAny.createSetSymDifference +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetUnion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetUnion.generated.js new file mode 100644 index 0000000..0ca3b74 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetUnion.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setUnionDependencies = void 0; +var _dependenciesIndexClassGenerated = require("./dependenciesIndexClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesSetIntersectGenerated = require("./dependenciesSetIntersect.generated.js"); +var _dependenciesSetSymDifferenceGenerated = require("./dependenciesSetSymDifference.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const setUnionDependencies = exports.setUnionDependencies = { + IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + setIntersectDependencies: _dependenciesSetIntersectGenerated.setIntersectDependencies, + setSymDifferenceDependencies: _dependenciesSetSymDifferenceGenerated.setSymDifferenceDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSetUnion: _factoriesAny.createSetUnion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSign.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSign.generated.js new file mode 100644 index 0000000..8a8d566 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSign.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.signDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _dependenciesComplexGenerated = require("./dependenciesComplex.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const signDependencies = exports.signDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + complexDependencies: _dependenciesComplexGenerated.complexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSign: _factoriesAny.createSign +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplify.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplify.generated.js new file mode 100644 index 0000000..e09a719 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplify.generated.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesFraction.generated.js"); +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesResolveGenerated = require("./dependenciesResolve.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesSimplifyCore.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyDependencies = exports.simplifyDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + fractionDependencies: _dependenciesFractionGenerated.fractionDependencies, + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + resolveDependencies: _dependenciesResolveGenerated.resolveDependencies, + simplifyConstantDependencies: _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies, + simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplify: _factoriesAny.createSimplify +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js new file mode 100644 index 0000000..a74a21d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyConstantDependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesFractionGenerated = require("./dependenciesFraction.generated.js"); +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyConstantDependencies = exports.simplifyConstantDependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + fractionDependencies: _dependenciesFractionGenerated.fractionDependencies, + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplifyConstant: _factoriesAny.createSimplifyConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyCore.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyCore.generated.js new file mode 100644 index 0000000..24ab57b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyCore.generated.js @@ -0,0 +1,51 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyCoreDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyCoreDependencies = exports.simplifyCoreDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplifyCore: _factoriesAny.createSimplifyCore +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSin.generated.js new file mode 100644 index 0000000..d598bb1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSin.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sinDependencies = exports.sinDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSin: _factoriesAny.createSin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSinh.generated.js new file mode 100644 index 0000000..3ca69c5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSinh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sinhDependencies = exports.sinhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSinh: _factoriesAny.createSinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSize.generated.js new file mode 100644 index 0000000..4d61dfe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSize.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sizeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sizeDependencies = exports.sizeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSize: _factoriesAny.createSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSlu.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSlu.generated.js new file mode 100644 index 0000000..ce824d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSlu.generated.js @@ -0,0 +1,35 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sluDependencies = void 0; +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesLargerEq.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTransposeGenerated = require("./dependenciesTranspose.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sluDependencies = exports.sluDependencies = { + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSlu: _factoriesAny.createSlu +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmaller.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmaller.generated.js new file mode 100644 index 0000000..58244e0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmaller.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const smallerDependencies = exports.smallerDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSmaller: _factoriesAny.createSmaller +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmallerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmallerEq.generated.js new file mode 100644 index 0000000..5482bb6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmallerEq.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerEqDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const smallerEqDependencies = exports.smallerEqDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSmallerEq: _factoriesAny.createSmallerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSolveODE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSolveODE.generated.js new file mode 100644 index 0000000..b23de99 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSolveODE.generated.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.solveODEDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMaxGenerated = require("./dependenciesMax.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const solveODEDependencies = exports.solveODEDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + mapDependencies: _dependenciesMapGenerated.mapDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + maxDependencies: _dependenciesMaxGenerated.maxDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createSolveODE: _factoriesAny.createSolveODE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSort.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSort.generated.js new file mode 100644 index 0000000..94036fd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSort.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sortDependencies = void 0; +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesCompareNatural.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sortDependencies = exports.sortDependencies = { + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSort: _factoriesAny.createSort +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpaClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpaClass.generated.js new file mode 100644 index 0000000..6ffda1e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpaClass.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SpaDependencies = void 0; +var _dependenciesFibonacciHeapClassGenerated = require("./dependenciesFibonacciHeapClass.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SpaDependencies = exports.SpaDependencies = { + FibonacciHeapDependencies: _dependenciesFibonacciHeapClassGenerated.FibonacciHeapDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + createSpaClass: _factoriesAny.createSpaClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparse.generated.js new file mode 100644 index 0000000..89047ce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparse.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sparseDependencies = void 0; +var _dependenciesSparseMatrixClassGenerated = require("./dependenciesSparseMatrixClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sparseDependencies = exports.sparseDependencies = { + SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSparse: _factoriesAny.createSparse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js new file mode 100644 index 0000000..af95c83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SparseMatrixDependencies = void 0; +var _dependenciesMatrixClassGenerated = require("./dependenciesMatrixClass.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SparseMatrixDependencies = exports.SparseMatrixDependencies = { + MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSparseMatrixClass: _factoriesAny.createSparseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js new file mode 100644 index 0000000..6a0daf2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.speedOfLightDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const speedOfLightDependencies = exports.speedOfLightDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createSpeedOfLight: _factoriesAny.createSpeedOfLight +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSplitUnit.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSplitUnit.generated.js new file mode 100644 index 0000000..244bb24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSplitUnit.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.splitUnitDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const splitUnitDependencies = exports.splitUnitDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSplitUnit: _factoriesAny.createSplitUnit +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrt.generated.js new file mode 100644 index 0000000..693e1b3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrt.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sqrtDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sqrtDependencies = exports.sqrtDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSqrt: _factoriesAny.createSqrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrtm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrtm.generated.js new file mode 100644 index 0000000..c02cf69 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrtm.generated.js @@ -0,0 +1,37 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sqrtmDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesInvGenerated = require("./dependenciesInv.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesMaxGenerated = require("./dependenciesMax.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sqrtmDependencies = exports.sqrtmDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + invDependencies: _dependenciesInvGenerated.invDependencies, + mapDependencies: _dependenciesMapGenerated.mapDependencies, + maxDependencies: _dependenciesMaxGenerated.maxDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSqrtm: _factoriesAny.createSqrtm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSquare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSquare.generated.js new file mode 100644 index 0000000..fe2dc1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSquare.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.squareDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const squareDependencies = exports.squareDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSquare: _factoriesAny.createSquare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqueeze.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqueeze.generated.js new file mode 100644 index 0000000..bce917c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqueeze.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.squeezeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const squeezeDependencies = exports.squeezeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSqueeze: _factoriesAny.createSqueeze +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStd.generated.js new file mode 100644 index 0000000..3a20a73 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStd.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stdDependencies = void 0; +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesVariance.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stdDependencies = exports.stdDependencies = { + mapDependencies: _dependenciesMapGenerated.mapDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies, + createStd: _factoriesAny.createStd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStdTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStdTransform.generated.js new file mode 100644 index 0000000..9869410 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStdTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stdTransformDependencies = void 0; +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesVariance.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stdTransformDependencies = exports.stdTransformDependencies = { + mapDependencies: _dependenciesMapGenerated.mapDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies, + createStdTransform: _factoriesAny.createStdTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js new file mode 100644 index 0000000..f5c4ad4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stefanBoltzmannDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stefanBoltzmannDependencies = exports.stefanBoltzmannDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createStefanBoltzmann: _factoriesAny.createStefanBoltzmann +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStirlingS2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStirlingS2.generated.js new file mode 100644 index 0000000..7f7a6d4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStirlingS2.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stirlingS2Dependencies = void 0; +var _dependenciesBignumberGenerated = require("./dependenciesBignumber.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stirlingS2Dependencies = exports.stirlingS2Dependencies = { + bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createStirlingS2: _factoriesAny.createStirlingS2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesString.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesString.generated.js new file mode 100644 index 0000000..2a14a55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesString.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stringDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stringDependencies = exports.stringDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createString: _factoriesAny.createString +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubset.generated.js new file mode 100644 index 0000000..9f658cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubset.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subsetDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subsetDependencies = exports.subsetDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createSubset: _factoriesAny.createSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubsetTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubsetTransform.generated.js new file mode 100644 index 0000000..d85fe5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubsetTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subsetTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesZerosGenerated = require("./dependenciesZeros.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subsetTransformDependencies = exports.subsetTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + zerosDependencies: _dependenciesZerosGenerated.zerosDependencies, + createSubsetTransform: _factoriesAny.createSubsetTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtract.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtract.generated.js new file mode 100644 index 0000000..784a909 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtract.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subtractDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesUnaryMinus.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subtractDependencies = exports.subtractDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies, + createSubtract: _factoriesAny.createSubtract +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtractScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtractScalar.generated.js new file mode 100644 index 0000000..33608da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtractScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subtractScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subtractScalarDependencies = exports.subtractScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSubtractScalar: _factoriesAny.createSubtractScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSum.generated.js new file mode 100644 index 0000000..78927db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSum.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sumDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sumDependencies = exports.sumDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSum: _factoriesAny.createSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSumTransform.generated.js new file mode 100644 index 0000000..1961331 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSumTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sumTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sumTransformDependencies = exports.sumTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSumTransform: _factoriesAny.createSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSylvester.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSylvester.generated.js new file mode 100644 index 0000000..b5db13f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSylvester.generated.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sylvesterDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesIdentityGenerated = require("./dependenciesIdentity.generated.js"); +var _dependenciesIndexGenerated = require("./dependenciesIndex.generated.js"); +var _dependenciesLusolveGenerated = require("./dependenciesLusolve.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMatrixFromColumnsGenerated = require("./dependenciesMatrixFromColumns.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesRange.generated.js"); +var _dependenciesSchurGenerated = require("./dependenciesSchur.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTransposeGenerated = require("./dependenciesTranspose.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sylvesterDependencies = exports.sylvesterDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + identityDependencies: _dependenciesIdentityGenerated.identityDependencies, + indexDependencies: _dependenciesIndexGenerated.indexDependencies, + lusolveDependencies: _dependenciesLusolveGenerated.lusolveDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + matrixFromColumnsDependencies: _dependenciesMatrixFromColumnsGenerated.matrixFromColumnsDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + rangeDependencies: _dependenciesRangeGenerated.rangeDependencies, + schurDependencies: _dependenciesSchurGenerated.schurDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSylvester: _factoriesAny.createSylvester +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolNode.generated.js new file mode 100644 index 0000000..a34e548 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SymbolNodeDependencies = void 0; +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SymbolNodeDependencies = exports.SymbolNodeDependencies = { + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createSymbolNode: _factoriesAny.createSymbolNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js new file mode 100644 index 0000000..562c7c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.symbolicEqualDependencies = void 0; +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesSimplify.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const symbolicEqualDependencies = exports.symbolicEqualDependencies = { + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSymbolicEqual: _factoriesAny.createSymbolicEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTan.generated.js new file mode 100644 index 0000000..df5060e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTan.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tanDependencies = exports.tanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTan: _factoriesAny.createTan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTanh.generated.js new file mode 100644 index 0000000..8b03fed --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTanh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tanhDependencies = exports.tanhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTanh: _factoriesAny.createTanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTau.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTau.generated.js new file mode 100644 index 0000000..3cbd68d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTau.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tauDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tauDependencies = exports.tauDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createTau: _factoriesAny.createTau +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js new file mode 100644 index 0000000..6aa9bae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.thomsonCrossSectionDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const thomsonCrossSectionDependencies = exports.thomsonCrossSectionDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createThomsonCrossSection: _factoriesAny.createThomsonCrossSection +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTo.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTo.generated.js new file mode 100644 index 0000000..055da52 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTo.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.toDependencies = void 0; +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const toDependencies = exports.toDependencies = { + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTo: _factoriesAny.createTo +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrace.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrace.generated.js new file mode 100644 index 0000000..0101245 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrace.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.traceDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const traceDependencies = exports.traceDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTrace: _factoriesAny.createTrace +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTranspose.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTranspose.generated.js new file mode 100644 index 0000000..a50a2e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTranspose.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.transposeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const transposeDependencies = exports.transposeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTranspose: _factoriesAny.createTranspose +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrue.generated.js new file mode 100644 index 0000000..7a7f863 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrue.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.trueDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const trueDependencies = exports.trueDependencies = { + createTrue: _factoriesAny.createTrue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTypeOf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTypeOf.generated.js new file mode 100644 index 0000000..2d69b03 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTypeOf.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typeOfDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const typeOfDependencies = exports.typeOfDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTypeOf: _factoriesAny.createTypeOf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTyped.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTyped.generated.js new file mode 100644 index 0000000..1cec5b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTyped.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typedDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const typedDependencies = exports.typedDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + createTyped: _factoriesAny.createTyped +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryMinus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryMinus.generated.js new file mode 100644 index 0000000..4235a84 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryMinus.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryMinusDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unaryMinusDependencies = exports.unaryMinusDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnaryMinus: _factoriesAny.createUnaryMinus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryPlus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryPlus.generated.js new file mode 100644 index 0000000..7f50a4f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryPlus.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryPlusDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unaryPlusDependencies = exports.unaryPlusDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnaryPlus: _factoriesAny.createUnaryPlus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnequal.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnequal.generated.js new file mode 100644 index 0000000..16a0e2f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnequal.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unequalDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unequalDependencies = exports.unequalDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnequal: _factoriesAny.createUnequal +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitClass.generated.js new file mode 100644 index 0000000..9da2ac5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitClass.generated.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.UnitDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesFractionClassGenerated = require("./dependenciesFractionClass.generated.js"); +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesFixGenerated = require("./dependenciesFix.generated.js"); +var _dependenciesFormatGenerated = require("./dependenciesFormat.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const UnitDependencies = exports.UnitDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies, + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + fixDependencies: _dependenciesFixGenerated.fixDependencies, + formatDependencies: _dependenciesFormatGenerated.formatDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + createUnitClass: _factoriesAny.createUnitClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitFunction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitFunction.generated.js new file mode 100644 index 0000000..fc4cbfb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitFunction.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unitDependencies = void 0; +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unitDependencies = exports.unitDependencies = { + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnitFunction: _factoriesAny.createUnitFunction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercaseE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercaseE.generated.js new file mode 100644 index 0000000..21959cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercaseE.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.EDependencies = void 0; +var _dependenciesEGenerated = require("./dependenciesE.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const EDependencies = exports.EDependencies = { + eDependencies: _dependenciesEGenerated.eDependencies, + createUppercaseE: _factoriesAny.createUppercaseE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercasePi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercasePi.generated.js new file mode 100644 index 0000000..3503d4c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercasePi.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.PIDependencies = void 0; +var _dependenciesPiGenerated = require("./dependenciesPi.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const PIDependencies = exports.PIDependencies = { + piDependencies: _dependenciesPiGenerated.piDependencies, + createUppercasePi: _factoriesAny.createUppercasePi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolve.generated.js new file mode 100644 index 0000000..e54ac02 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolve.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.usolveDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const usolveDependencies = exports.usolveDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUsolve: _factoriesAny.createUsolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolveAll.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolveAll.generated.js new file mode 100644 index 0000000..60f017b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolveAll.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.usolveAllDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const usolveAllDependencies = exports.usolveAllDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUsolveAll: _factoriesAny.createUsolveAll +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js new file mode 100644 index 0000000..4619717 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.vacuumImpedanceDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const vacuumImpedanceDependencies = exports.vacuumImpedanceDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createVacuumImpedance: _factoriesAny.createVacuumImpedance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVariance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVariance.generated.js new file mode 100644 index 0000000..9753188 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVariance.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.varianceDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesApply.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const varianceDependencies = exports.varianceDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + applyDependencies: _dependenciesApplyGenerated.applyDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createVariance: _factoriesAny.createVariance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVarianceTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVarianceTransform.generated.js new file mode 100644 index 0000000..b824b25 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVarianceTransform.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.varianceTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesApply.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const varianceTransformDependencies = exports.varianceTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + applyDependencies: _dependenciesApplyGenerated.applyDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createVarianceTransform: _factoriesAny.createVarianceTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVersion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVersion.generated.js new file mode 100644 index 0000000..8987e6b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVersion.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.versionDependencies = void 0; +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const versionDependencies = exports.versionDependencies = { + createVersion: _factoriesAny.createVersion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js new file mode 100644 index 0000000..666712d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.weakMixingAngleDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const weakMixingAngleDependencies = exports.weakMixingAngleDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + createWeakMixingAngle: _factoriesAny.createWeakMixingAngle +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWienDisplacement.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWienDisplacement.generated.js new file mode 100644 index 0000000..ffead9b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWienDisplacement.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.wienDisplacementDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesUnitClassGenerated = require("./dependenciesUnitClass.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const wienDisplacementDependencies = exports.wienDisplacementDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies, + createWienDisplacement: _factoriesAny.createWienDisplacement +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXgcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXgcd.generated.js new file mode 100644 index 0000000..5d9ffbc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXgcd.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xgcdDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const xgcdDependencies = exports.xgcdDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createXgcd: _factoriesAny.createXgcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXor.generated.js new file mode 100644 index 0000000..ffcc830 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXor.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xorDependencies = void 0; +var _dependenciesDenseMatrixClassGenerated = require("./dependenciesDenseMatrixClass.generated.js"); +var _dependenciesConcatGenerated = require("./dependenciesConcat.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const xorDependencies = exports.xorDependencies = { + DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies, + concatDependencies: _dependenciesConcatGenerated.concatDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createXor: _factoriesAny.createXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeros.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeros.generated.js new file mode 100644 index 0000000..3a5e95a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeros.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zerosDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const zerosDependencies = exports.zerosDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createZeros: _factoriesAny.createZeros +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeta.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeta.generated.js new file mode 100644 index 0000000..007d273 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeta.generated.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zetaDependencies = void 0; +var _dependenciesBigNumberClassGenerated = require("./dependenciesBigNumberClass.generated.js"); +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesGammaGenerated = require("./dependenciesGamma.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPiGenerated = require("./dependenciesPi.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesSin.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const zetaDependencies = exports.zetaDependencies = { + BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies, + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + gammaDependencies: _dependenciesGammaGenerated.gammaDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + piDependencies: _dependenciesPiGenerated.piDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + sinDependencies: _dependenciesSinGenerated.sinDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createZeta: _factoriesAny.createZeta +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZpk2tf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZpk2tf.generated.js new file mode 100644 index 0000000..926b4ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZpk2tf.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zpk2tfDependencies = void 0; +var _dependenciesComplexClassGenerated = require("./dependenciesComplexClass.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesAny = require("../../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const zpk2tfDependencies = exports.zpk2tfDependencies = { + ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createZpk2tf: _factoriesAny.createZpk2tf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber.generated.js new file mode 100644 index 0000000..e68dbf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber.generated.js @@ -0,0 +1,1447 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +Object.defineProperty(exports, "AccessorNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesAccessorNodeGenerated.AccessorNodeDependencies; + } +}); +Object.defineProperty(exports, "ArrayNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesArrayNodeGenerated.ArrayNodeDependencies; + } +}); +Object.defineProperty(exports, "AssignmentNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies; + } +}); +Object.defineProperty(exports, "BlockNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesBlockNodeGenerated.BlockNodeDependencies; + } +}); +Object.defineProperty(exports, "ChainDependencies", { + enumerable: true, + get: function () { + return _dependenciesChainClassGenerated.ChainDependencies; + } +}); +Object.defineProperty(exports, "ConditionalNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies; + } +}); +Object.defineProperty(exports, "ConstantNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesConstantNodeGenerated.ConstantNodeDependencies; + } +}); +Object.defineProperty(exports, "EDependencies", { + enumerable: true, + get: function () { + return _dependenciesUppercaseEGenerated.EDependencies; + } +}); +Object.defineProperty(exports, "FunctionAssignmentNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies; + } +}); +Object.defineProperty(exports, "FunctionNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesFunctionNodeGenerated.FunctionNodeDependencies; + } +}); +Object.defineProperty(exports, "HelpDependencies", { + enumerable: true, + get: function () { + return _dependenciesHelpClassGenerated.HelpDependencies; + } +}); +Object.defineProperty(exports, "IndexNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexNodeGenerated.IndexNodeDependencies; + } +}); +Object.defineProperty(exports, "InfinityDependencies", { + enumerable: true, + get: function () { + return _dependenciesInfinityGenerated.InfinityDependencies; + } +}); +Object.defineProperty(exports, "LN10Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLN10Generated.LN10Dependencies; + } +}); +Object.defineProperty(exports, "LN2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLN2Generated.LN2Dependencies; + } +}); +Object.defineProperty(exports, "LOG10EDependencies", { + enumerable: true, + get: function () { + return _dependenciesLOG10EGenerated.LOG10EDependencies; + } +}); +Object.defineProperty(exports, "LOG2EDependencies", { + enumerable: true, + get: function () { + return _dependenciesLOG2EGenerated.LOG2EDependencies; + } +}); +Object.defineProperty(exports, "NaNDependencies", { + enumerable: true, + get: function () { + return _dependenciesNaNGenerated.NaNDependencies; + } +}); +Object.defineProperty(exports, "NodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesNodeGenerated.NodeDependencies; + } +}); +Object.defineProperty(exports, "ObjectNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesObjectNodeGenerated.ObjectNodeDependencies; + } +}); +Object.defineProperty(exports, "OperatorNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesOperatorNodeGenerated.OperatorNodeDependencies; + } +}); +Object.defineProperty(exports, "PIDependencies", { + enumerable: true, + get: function () { + return _dependenciesUppercasePiGenerated.PIDependencies; + } +}); +Object.defineProperty(exports, "ParenthesisNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies; + } +}); +Object.defineProperty(exports, "ParserDependencies", { + enumerable: true, + get: function () { + return _dependenciesParserClassGenerated.ParserDependencies; + } +}); +Object.defineProperty(exports, "RangeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeClassGenerated.RangeDependencies; + } +}); +Object.defineProperty(exports, "RangeNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeNodeGenerated.RangeNodeDependencies; + } +}); +Object.defineProperty(exports, "RelationalNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRelationalNodeGenerated.RelationalNodeDependencies; + } +}); +Object.defineProperty(exports, "ResultSetDependencies", { + enumerable: true, + get: function () { + return _dependenciesResultSetGenerated.ResultSetDependencies; + } +}); +Object.defineProperty(exports, "SQRT1_2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesSQRT1_2Generated.SQRT1_2Dependencies; + } +}); +Object.defineProperty(exports, "SQRT2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesSQRT2Generated.SQRT2Dependencies; + } +}); +Object.defineProperty(exports, "SymbolNodeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSymbolNodeGenerated.SymbolNodeDependencies; + } +}); +Object.defineProperty(exports, "absDependencies", { + enumerable: true, + get: function () { + return _dependenciesAbsGenerated.absDependencies; + } +}); +Object.defineProperty(exports, "acosDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcosGenerated.acosDependencies; + } +}); +Object.defineProperty(exports, "acoshDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcoshGenerated.acoshDependencies; + } +}); +Object.defineProperty(exports, "acotDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcotGenerated.acotDependencies; + } +}); +Object.defineProperty(exports, "acothDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcothGenerated.acothDependencies; + } +}); +Object.defineProperty(exports, "acscDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcscGenerated.acscDependencies; + } +}); +Object.defineProperty(exports, "acschDependencies", { + enumerable: true, + get: function () { + return _dependenciesAcschGenerated.acschDependencies; + } +}); +Object.defineProperty(exports, "addDependencies", { + enumerable: true, + get: function () { + return _dependenciesAddGenerated.addDependencies; + } +}); +Object.defineProperty(exports, "addScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesAddScalarGenerated.addScalarDependencies; + } +}); +Object.defineProperty(exports, "all", { + enumerable: true, + get: function () { + return _allFactoriesNumber.all; + } +}); +Object.defineProperty(exports, "andDependencies", { + enumerable: true, + get: function () { + return _dependenciesAndGenerated.andDependencies; + } +}); +Object.defineProperty(exports, "applyDependencies", { + enumerable: true, + get: function () { + return _dependenciesApplyGenerated.applyDependencies; + } +}); +Object.defineProperty(exports, "applyTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesApplyTransformGenerated.applyTransformDependencies; + } +}); +Object.defineProperty(exports, "asecDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsecGenerated.asecDependencies; + } +}); +Object.defineProperty(exports, "asechDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsechGenerated.asechDependencies; + } +}); +Object.defineProperty(exports, "asinDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsinGenerated.asinDependencies; + } +}); +Object.defineProperty(exports, "asinhDependencies", { + enumerable: true, + get: function () { + return _dependenciesAsinhGenerated.asinhDependencies; + } +}); +Object.defineProperty(exports, "atan2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesAtan2Generated.atan2Dependencies; + } +}); +Object.defineProperty(exports, "atanDependencies", { + enumerable: true, + get: function () { + return _dependenciesAtanGenerated.atanDependencies; + } +}); +Object.defineProperty(exports, "atanhDependencies", { + enumerable: true, + get: function () { + return _dependenciesAtanhGenerated.atanhDependencies; + } +}); +Object.defineProperty(exports, "bellNumbersDependencies", { + enumerable: true, + get: function () { + return _dependenciesBellNumbersGenerated.bellNumbersDependencies; + } +}); +Object.defineProperty(exports, "bigintDependencies", { + enumerable: true, + get: function () { + return _dependenciesBigintGenerated.bigintDependencies; + } +}); +Object.defineProperty(exports, "bitAndDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitAndGenerated.bitAndDependencies; + } +}); +Object.defineProperty(exports, "bitNotDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitNotGenerated.bitNotDependencies; + } +}); +Object.defineProperty(exports, "bitOrDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitOrGenerated.bitOrDependencies; + } +}); +Object.defineProperty(exports, "bitXorDependencies", { + enumerable: true, + get: function () { + return _dependenciesBitXorGenerated.bitXorDependencies; + } +}); +Object.defineProperty(exports, "booleanDependencies", { + enumerable: true, + get: function () { + return _dependenciesBooleanGenerated.booleanDependencies; + } +}); +Object.defineProperty(exports, "catalanDependencies", { + enumerable: true, + get: function () { + return _dependenciesCatalanGenerated.catalanDependencies; + } +}); +Object.defineProperty(exports, "cbrtDependencies", { + enumerable: true, + get: function () { + return _dependenciesCbrtGenerated.cbrtDependencies; + } +}); +Object.defineProperty(exports, "ceilDependencies", { + enumerable: true, + get: function () { + return _dependenciesCeilGenerated.ceilDependencies; + } +}); +Object.defineProperty(exports, "chainDependencies", { + enumerable: true, + get: function () { + return _dependenciesChainGenerated.chainDependencies; + } +}); +Object.defineProperty(exports, "cloneDependencies", { + enumerable: true, + get: function () { + return _dependenciesCloneGenerated.cloneDependencies; + } +}); +Object.defineProperty(exports, "combinationsDependencies", { + enumerable: true, + get: function () { + return _dependenciesCombinationsGenerated.combinationsDependencies; + } +}); +Object.defineProperty(exports, "combinationsWithRepDependencies", { + enumerable: true, + get: function () { + return _dependenciesCombinationsWithRepGenerated.combinationsWithRepDependencies; + } +}); +Object.defineProperty(exports, "compareDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareGenerated.compareDependencies; + } +}); +Object.defineProperty(exports, "compareNaturalDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareNaturalGenerated.compareNaturalDependencies; + } +}); +Object.defineProperty(exports, "compareTextDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompareTextGenerated.compareTextDependencies; + } +}); +Object.defineProperty(exports, "compileDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompileGenerated.compileDependencies; + } +}); +Object.defineProperty(exports, "compositionDependencies", { + enumerable: true, + get: function () { + return _dependenciesCompositionGenerated.compositionDependencies; + } +}); +Object.defineProperty(exports, "corrDependencies", { + enumerable: true, + get: function () { + return _dependenciesCorrGenerated.corrDependencies; + } +}); +Object.defineProperty(exports, "cosDependencies", { + enumerable: true, + get: function () { + return _dependenciesCosGenerated.cosDependencies; + } +}); +Object.defineProperty(exports, "coshDependencies", { + enumerable: true, + get: function () { + return _dependenciesCoshGenerated.coshDependencies; + } +}); +Object.defineProperty(exports, "cotDependencies", { + enumerable: true, + get: function () { + return _dependenciesCotGenerated.cotDependencies; + } +}); +Object.defineProperty(exports, "cothDependencies", { + enumerable: true, + get: function () { + return _dependenciesCothGenerated.cothDependencies; + } +}); +Object.defineProperty(exports, "cscDependencies", { + enumerable: true, + get: function () { + return _dependenciesCscGenerated.cscDependencies; + } +}); +Object.defineProperty(exports, "cschDependencies", { + enumerable: true, + get: function () { + return _dependenciesCschGenerated.cschDependencies; + } +}); +Object.defineProperty(exports, "cubeDependencies", { + enumerable: true, + get: function () { + return _dependenciesCubeGenerated.cubeDependencies; + } +}); +Object.defineProperty(exports, "cumsumDependencies", { + enumerable: true, + get: function () { + return _dependenciesCumSumGenerated.cumsumDependencies; + } +}); +Object.defineProperty(exports, "cumsumTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesCumSumTransformGenerated.cumsumTransformDependencies; + } +}); +Object.defineProperty(exports, "deepEqualDependencies", { + enumerable: true, + get: function () { + return _dependenciesDeepEqualGenerated.deepEqualDependencies; + } +}); +Object.defineProperty(exports, "derivativeDependencies", { + enumerable: true, + get: function () { + return _dependenciesDerivativeGenerated.derivativeDependencies; + } +}); +Object.defineProperty(exports, "divideDependencies", { + enumerable: true, + get: function () { + return _dependenciesDivideGenerated.divideDependencies; + } +}); +Object.defineProperty(exports, "divideScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesDivideScalarGenerated.divideScalarDependencies; + } +}); +Object.defineProperty(exports, "eDependencies", { + enumerable: true, + get: function () { + return _dependenciesEGenerated.eDependencies; + } +}); +Object.defineProperty(exports, "equalDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualGenerated.equalDependencies; + } +}); +Object.defineProperty(exports, "equalScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualScalarGenerated.equalScalarDependencies; + } +}); +Object.defineProperty(exports, "equalTextDependencies", { + enumerable: true, + get: function () { + return _dependenciesEqualTextGenerated.equalTextDependencies; + } +}); +Object.defineProperty(exports, "erfDependencies", { + enumerable: true, + get: function () { + return _dependenciesErfGenerated.erfDependencies; + } +}); +Object.defineProperty(exports, "evaluateDependencies", { + enumerable: true, + get: function () { + return _dependenciesEvaluateGenerated.evaluateDependencies; + } +}); +Object.defineProperty(exports, "expDependencies", { + enumerable: true, + get: function () { + return _dependenciesExpGenerated.expDependencies; + } +}); +Object.defineProperty(exports, "expm1Dependencies", { + enumerable: true, + get: function () { + return _dependenciesExpm1Generated.expm1Dependencies; + } +}); +Object.defineProperty(exports, "factorialDependencies", { + enumerable: true, + get: function () { + return _dependenciesFactorialGenerated.factorialDependencies; + } +}); +Object.defineProperty(exports, "falseDependencies", { + enumerable: true, + get: function () { + return _dependenciesFalseGenerated.falseDependencies; + } +}); +Object.defineProperty(exports, "filterDependencies", { + enumerable: true, + get: function () { + return _dependenciesFilterGenerated.filterDependencies; + } +}); +Object.defineProperty(exports, "filterTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesFilterTransformGenerated.filterTransformDependencies; + } +}); +Object.defineProperty(exports, "fixDependencies", { + enumerable: true, + get: function () { + return _dependenciesFixGenerated.fixDependencies; + } +}); +Object.defineProperty(exports, "floorDependencies", { + enumerable: true, + get: function () { + return _dependenciesFloorGenerated.floorDependencies; + } +}); +Object.defineProperty(exports, "forEachDependencies", { + enumerable: true, + get: function () { + return _dependenciesForEachGenerated.forEachDependencies; + } +}); +Object.defineProperty(exports, "forEachTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesForEachTransformGenerated.forEachTransformDependencies; + } +}); +Object.defineProperty(exports, "formatDependencies", { + enumerable: true, + get: function () { + return _dependenciesFormatGenerated.formatDependencies; + } +}); +Object.defineProperty(exports, "gammaDependencies", { + enumerable: true, + get: function () { + return _dependenciesGammaGenerated.gammaDependencies; + } +}); +Object.defineProperty(exports, "gcdDependencies", { + enumerable: true, + get: function () { + return _dependenciesGcdGenerated.gcdDependencies; + } +}); +Object.defineProperty(exports, "hasNumericValueDependencies", { + enumerable: true, + get: function () { + return _dependenciesHasNumericValueGenerated.hasNumericValueDependencies; + } +}); +Object.defineProperty(exports, "helpDependencies", { + enumerable: true, + get: function () { + return _dependenciesHelpGenerated.helpDependencies; + } +}); +Object.defineProperty(exports, "hypotDependencies", { + enumerable: true, + get: function () { + return _dependenciesHypotGenerated.hypotDependencies; + } +}); +Object.defineProperty(exports, "indexDependencies", { + enumerable: true, + get: function () { + return _dependenciesIndexGenerated.indexDependencies; + } +}); +Object.defineProperty(exports, "isIntegerDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsIntegerGenerated.isIntegerDependencies; + } +}); +Object.defineProperty(exports, "isNaNDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNaNGenerated.isNaNDependencies; + } +}); +Object.defineProperty(exports, "isNegativeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNegativeGenerated.isNegativeDependencies; + } +}); +Object.defineProperty(exports, "isNumericDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsNumericGenerated.isNumericDependencies; + } +}); +Object.defineProperty(exports, "isPositiveDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsPositiveGenerated.isPositiveDependencies; + } +}); +Object.defineProperty(exports, "isPrimeDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsPrimeGenerated.isPrimeDependencies; + } +}); +Object.defineProperty(exports, "isZeroDependencies", { + enumerable: true, + get: function () { + return _dependenciesIsZeroGenerated.isZeroDependencies; + } +}); +Object.defineProperty(exports, "largerDependencies", { + enumerable: true, + get: function () { + return _dependenciesLargerGenerated.largerDependencies; + } +}); +Object.defineProperty(exports, "largerEqDependencies", { + enumerable: true, + get: function () { + return _dependenciesLargerEqGenerated.largerEqDependencies; + } +}); +Object.defineProperty(exports, "lcmDependencies", { + enumerable: true, + get: function () { + return _dependenciesLcmGenerated.lcmDependencies; + } +}); +Object.defineProperty(exports, "leftShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesLeftShiftGenerated.leftShiftDependencies; + } +}); +Object.defineProperty(exports, "lgammaDependencies", { + enumerable: true, + get: function () { + return _dependenciesLgammaGenerated.lgammaDependencies; + } +}); +Object.defineProperty(exports, "log10Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLog10Generated.log10Dependencies; + } +}); +Object.defineProperty(exports, "log1pDependencies", { + enumerable: true, + get: function () { + return _dependenciesLog1pGenerated.log1pDependencies; + } +}); +Object.defineProperty(exports, "log2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesLog2Generated.log2Dependencies; + } +}); +Object.defineProperty(exports, "logDependencies", { + enumerable: true, + get: function () { + return _dependenciesLogGenerated.logDependencies; + } +}); +Object.defineProperty(exports, "madDependencies", { + enumerable: true, + get: function () { + return _dependenciesMadGenerated.madDependencies; + } +}); +Object.defineProperty(exports, "mapDependencies", { + enumerable: true, + get: function () { + return _dependenciesMapGenerated.mapDependencies; + } +}); +Object.defineProperty(exports, "mapTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMapTransformGenerated.mapTransformDependencies; + } +}); +Object.defineProperty(exports, "matrixDependencies", { + enumerable: true, + get: function () { + return _dependenciesMatrixGenerated.matrixDependencies; + } +}); +Object.defineProperty(exports, "maxDependencies", { + enumerable: true, + get: function () { + return _dependenciesMaxGenerated.maxDependencies; + } +}); +Object.defineProperty(exports, "maxTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMaxTransformGenerated.maxTransformDependencies; + } +}); +Object.defineProperty(exports, "meanDependencies", { + enumerable: true, + get: function () { + return _dependenciesMeanGenerated.meanDependencies; + } +}); +Object.defineProperty(exports, "meanTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMeanTransformGenerated.meanTransformDependencies; + } +}); +Object.defineProperty(exports, "medianDependencies", { + enumerable: true, + get: function () { + return _dependenciesMedianGenerated.medianDependencies; + } +}); +Object.defineProperty(exports, "minDependencies", { + enumerable: true, + get: function () { + return _dependenciesMinGenerated.minDependencies; + } +}); +Object.defineProperty(exports, "minTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesMinTransformGenerated.minTransformDependencies; + } +}); +Object.defineProperty(exports, "modDependencies", { + enumerable: true, + get: function () { + return _dependenciesModGenerated.modDependencies; + } +}); +Object.defineProperty(exports, "modeDependencies", { + enumerable: true, + get: function () { + return _dependenciesModeGenerated.modeDependencies; + } +}); +Object.defineProperty(exports, "multinomialDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultinomialGenerated.multinomialDependencies; + } +}); +Object.defineProperty(exports, "multiplyDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultiplyGenerated.multiplyDependencies; + } +}); +Object.defineProperty(exports, "multiplyScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies; + } +}); +Object.defineProperty(exports, "normDependencies", { + enumerable: true, + get: function () { + return _dependenciesNormGenerated.normDependencies; + } +}); +Object.defineProperty(exports, "notDependencies", { + enumerable: true, + get: function () { + return _dependenciesNotGenerated.notDependencies; + } +}); +Object.defineProperty(exports, "nthRootDependencies", { + enumerable: true, + get: function () { + return _dependenciesNthRootGenerated.nthRootDependencies; + } +}); +Object.defineProperty(exports, "nullDependencies", { + enumerable: true, + get: function () { + return _dependenciesNullGenerated.nullDependencies; + } +}); +Object.defineProperty(exports, "numberDependencies", { + enumerable: true, + get: function () { + return _dependenciesNumberGenerated.numberDependencies; + } +}); +Object.defineProperty(exports, "numericDependencies", { + enumerable: true, + get: function () { + return _dependenciesNumericGenerated.numericDependencies; + } +}); +Object.defineProperty(exports, "orDependencies", { + enumerable: true, + get: function () { + return _dependenciesOrGenerated.orDependencies; + } +}); +Object.defineProperty(exports, "parseDependencies", { + enumerable: true, + get: function () { + return _dependenciesParseGenerated.parseDependencies; + } +}); +Object.defineProperty(exports, "parserDependencies", { + enumerable: true, + get: function () { + return _dependenciesParserGenerated.parserDependencies; + } +}); +Object.defineProperty(exports, "partitionSelectDependencies", { + enumerable: true, + get: function () { + return _dependenciesPartitionSelectGenerated.partitionSelectDependencies; + } +}); +Object.defineProperty(exports, "permutationsDependencies", { + enumerable: true, + get: function () { + return _dependenciesPermutationsGenerated.permutationsDependencies; + } +}); +Object.defineProperty(exports, "phiDependencies", { + enumerable: true, + get: function () { + return _dependenciesPhiGenerated.phiDependencies; + } +}); +Object.defineProperty(exports, "piDependencies", { + enumerable: true, + get: function () { + return _dependenciesPiGenerated.piDependencies; + } +}); +Object.defineProperty(exports, "pickRandomDependencies", { + enumerable: true, + get: function () { + return _dependenciesPickRandomGenerated.pickRandomDependencies; + } +}); +Object.defineProperty(exports, "powDependencies", { + enumerable: true, + get: function () { + return _dependenciesPowGenerated.powDependencies; + } +}); +Object.defineProperty(exports, "printDependencies", { + enumerable: true, + get: function () { + return _dependenciesPrintGenerated.printDependencies; + } +}); +Object.defineProperty(exports, "prodDependencies", { + enumerable: true, + get: function () { + return _dependenciesProdGenerated.prodDependencies; + } +}); +Object.defineProperty(exports, "quantileSeqDependencies", { + enumerable: true, + get: function () { + return _dependenciesQuantileSeqGenerated.quantileSeqDependencies; + } +}); +Object.defineProperty(exports, "randomDependencies", { + enumerable: true, + get: function () { + return _dependenciesRandomGenerated.randomDependencies; + } +}); +Object.defineProperty(exports, "randomIntDependencies", { + enumerable: true, + get: function () { + return _dependenciesRandomIntGenerated.randomIntDependencies; + } +}); +Object.defineProperty(exports, "rangeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeGenerated.rangeDependencies; + } +}); +Object.defineProperty(exports, "rangeTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesRangeTransformGenerated.rangeTransformDependencies; + } +}); +Object.defineProperty(exports, "rationalizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesRationalizeGenerated.rationalizeDependencies; + } +}); +Object.defineProperty(exports, "replacerDependencies", { + enumerable: true, + get: function () { + return _dependenciesReplacerGenerated.replacerDependencies; + } +}); +Object.defineProperty(exports, "resolveDependencies", { + enumerable: true, + get: function () { + return _dependenciesResolveGenerated.resolveDependencies; + } +}); +Object.defineProperty(exports, "reviverDependencies", { + enumerable: true, + get: function () { + return _dependenciesReviverGenerated.reviverDependencies; + } +}); +Object.defineProperty(exports, "rightArithShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesRightArithShiftGenerated.rightArithShiftDependencies; + } +}); +Object.defineProperty(exports, "rightLogShiftDependencies", { + enumerable: true, + get: function () { + return _dependenciesRightLogShiftGenerated.rightLogShiftDependencies; + } +}); +Object.defineProperty(exports, "roundDependencies", { + enumerable: true, + get: function () { + return _dependenciesRoundGenerated.roundDependencies; + } +}); +Object.defineProperty(exports, "secDependencies", { + enumerable: true, + get: function () { + return _dependenciesSecGenerated.secDependencies; + } +}); +Object.defineProperty(exports, "sechDependencies", { + enumerable: true, + get: function () { + return _dependenciesSechGenerated.sechDependencies; + } +}); +Object.defineProperty(exports, "signDependencies", { + enumerable: true, + get: function () { + return _dependenciesSignGenerated.signDependencies; + } +}); +Object.defineProperty(exports, "simplifyConstantDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies; + } +}); +Object.defineProperty(exports, "simplifyCoreDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies; + } +}); +Object.defineProperty(exports, "simplifyDependencies", { + enumerable: true, + get: function () { + return _dependenciesSimplifyGenerated.simplifyDependencies; + } +}); +Object.defineProperty(exports, "sinDependencies", { + enumerable: true, + get: function () { + return _dependenciesSinGenerated.sinDependencies; + } +}); +Object.defineProperty(exports, "sinhDependencies", { + enumerable: true, + get: function () { + return _dependenciesSinhGenerated.sinhDependencies; + } +}); +Object.defineProperty(exports, "sizeDependencies", { + enumerable: true, + get: function () { + return _dependenciesSizeGenerated.sizeDependencies; + } +}); +Object.defineProperty(exports, "smallerDependencies", { + enumerable: true, + get: function () { + return _dependenciesSmallerGenerated.smallerDependencies; + } +}); +Object.defineProperty(exports, "smallerEqDependencies", { + enumerable: true, + get: function () { + return _dependenciesSmallerEqGenerated.smallerEqDependencies; + } +}); +Object.defineProperty(exports, "sqrtDependencies", { + enumerable: true, + get: function () { + return _dependenciesSqrtGenerated.sqrtDependencies; + } +}); +Object.defineProperty(exports, "squareDependencies", { + enumerable: true, + get: function () { + return _dependenciesSquareGenerated.squareDependencies; + } +}); +Object.defineProperty(exports, "stdDependencies", { + enumerable: true, + get: function () { + return _dependenciesStdGenerated.stdDependencies; + } +}); +Object.defineProperty(exports, "stdTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesStdTransformGenerated.stdTransformDependencies; + } +}); +Object.defineProperty(exports, "stirlingS2Dependencies", { + enumerable: true, + get: function () { + return _dependenciesStirlingS2Generated.stirlingS2Dependencies; + } +}); +Object.defineProperty(exports, "stringDependencies", { + enumerable: true, + get: function () { + return _dependenciesStringGenerated.stringDependencies; + } +}); +Object.defineProperty(exports, "subsetDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubsetGenerated.subsetDependencies; + } +}); +Object.defineProperty(exports, "subsetTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubsetTransformGenerated.subsetTransformDependencies; + } +}); +Object.defineProperty(exports, "subtractDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubtractGenerated.subtractDependencies; + } +}); +Object.defineProperty(exports, "subtractScalarDependencies", { + enumerable: true, + get: function () { + return _dependenciesSubtractScalarGenerated.subtractScalarDependencies; + } +}); +Object.defineProperty(exports, "sumDependencies", { + enumerable: true, + get: function () { + return _dependenciesSumGenerated.sumDependencies; + } +}); +Object.defineProperty(exports, "sumTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesSumTransformGenerated.sumTransformDependencies; + } +}); +Object.defineProperty(exports, "tanDependencies", { + enumerable: true, + get: function () { + return _dependenciesTanGenerated.tanDependencies; + } +}); +Object.defineProperty(exports, "tanhDependencies", { + enumerable: true, + get: function () { + return _dependenciesTanhGenerated.tanhDependencies; + } +}); +Object.defineProperty(exports, "tauDependencies", { + enumerable: true, + get: function () { + return _dependenciesTauGenerated.tauDependencies; + } +}); +Object.defineProperty(exports, "trueDependencies", { + enumerable: true, + get: function () { + return _dependenciesTrueGenerated.trueDependencies; + } +}); +Object.defineProperty(exports, "typeOfDependencies", { + enumerable: true, + get: function () { + return _dependenciesTypeOfGenerated.typeOfDependencies; + } +}); +Object.defineProperty(exports, "typedDependencies", { + enumerable: true, + get: function () { + return _dependenciesTypedGenerated.typedDependencies; + } +}); +Object.defineProperty(exports, "unaryMinusDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnaryMinusGenerated.unaryMinusDependencies; + } +}); +Object.defineProperty(exports, "unaryPlusDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnaryPlusGenerated.unaryPlusDependencies; + } +}); +Object.defineProperty(exports, "unequalDependencies", { + enumerable: true, + get: function () { + return _dependenciesUnequalGenerated.unequalDependencies; + } +}); +Object.defineProperty(exports, "varianceDependencies", { + enumerable: true, + get: function () { + return _dependenciesVarianceGenerated.varianceDependencies; + } +}); +Object.defineProperty(exports, "varianceTransformDependencies", { + enumerable: true, + get: function () { + return _dependenciesVarianceTransformGenerated.varianceTransformDependencies; + } +}); +Object.defineProperty(exports, "versionDependencies", { + enumerable: true, + get: function () { + return _dependenciesVersionGenerated.versionDependencies; + } +}); +Object.defineProperty(exports, "xgcdDependencies", { + enumerable: true, + get: function () { + return _dependenciesXgcdGenerated.xgcdDependencies; + } +}); +Object.defineProperty(exports, "xorDependencies", { + enumerable: true, + get: function () { + return _dependenciesXorGenerated.xorDependencies; + } +}); +Object.defineProperty(exports, "zetaDependencies", { + enumerable: true, + get: function () { + return _dependenciesZetaGenerated.zetaDependencies; + } +}); +var _dependenciesAbsGenerated = require("./dependenciesNumber/dependenciesAbs.generated.js"); +var _dependenciesAccessorNodeGenerated = require("./dependenciesNumber/dependenciesAccessorNode.generated.js"); +var _dependenciesAcosGenerated = require("./dependenciesNumber/dependenciesAcos.generated.js"); +var _dependenciesAcoshGenerated = require("./dependenciesNumber/dependenciesAcosh.generated.js"); +var _dependenciesAcotGenerated = require("./dependenciesNumber/dependenciesAcot.generated.js"); +var _dependenciesAcothGenerated = require("./dependenciesNumber/dependenciesAcoth.generated.js"); +var _dependenciesAcscGenerated = require("./dependenciesNumber/dependenciesAcsc.generated.js"); +var _dependenciesAcschGenerated = require("./dependenciesNumber/dependenciesAcsch.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesNumber/dependenciesAdd.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesNumber/dependenciesAddScalar.generated.js"); +var _dependenciesAndGenerated = require("./dependenciesNumber/dependenciesAnd.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesNumber/dependenciesApply.generated.js"); +var _dependenciesApplyTransformGenerated = require("./dependenciesNumber/dependenciesApplyTransform.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesNumber/dependenciesArrayNode.generated.js"); +var _dependenciesAsecGenerated = require("./dependenciesNumber/dependenciesAsec.generated.js"); +var _dependenciesAsechGenerated = require("./dependenciesNumber/dependenciesAsech.generated.js"); +var _dependenciesAsinGenerated = require("./dependenciesNumber/dependenciesAsin.generated.js"); +var _dependenciesAsinhGenerated = require("./dependenciesNumber/dependenciesAsinh.generated.js"); +var _dependenciesAssignmentNodeGenerated = require("./dependenciesNumber/dependenciesAssignmentNode.generated.js"); +var _dependenciesAtanGenerated = require("./dependenciesNumber/dependenciesAtan.generated.js"); +var _dependenciesAtan2Generated = require("./dependenciesNumber/dependenciesAtan2.generated.js"); +var _dependenciesAtanhGenerated = require("./dependenciesNumber/dependenciesAtanh.generated.js"); +var _dependenciesBellNumbersGenerated = require("./dependenciesNumber/dependenciesBellNumbers.generated.js"); +var _dependenciesBigintGenerated = require("./dependenciesNumber/dependenciesBigint.generated.js"); +var _dependenciesBitAndGenerated = require("./dependenciesNumber/dependenciesBitAnd.generated.js"); +var _dependenciesBitNotGenerated = require("./dependenciesNumber/dependenciesBitNot.generated.js"); +var _dependenciesBitOrGenerated = require("./dependenciesNumber/dependenciesBitOr.generated.js"); +var _dependenciesBitXorGenerated = require("./dependenciesNumber/dependenciesBitXor.generated.js"); +var _dependenciesBlockNodeGenerated = require("./dependenciesNumber/dependenciesBlockNode.generated.js"); +var _dependenciesBooleanGenerated = require("./dependenciesNumber/dependenciesBoolean.generated.js"); +var _dependenciesCatalanGenerated = require("./dependenciesNumber/dependenciesCatalan.generated.js"); +var _dependenciesCbrtGenerated = require("./dependenciesNumber/dependenciesCbrt.generated.js"); +var _dependenciesCeilGenerated = require("./dependenciesNumber/dependenciesCeil.generated.js"); +var _dependenciesChainGenerated = require("./dependenciesNumber/dependenciesChain.generated.js"); +var _dependenciesChainClassGenerated = require("./dependenciesNumber/dependenciesChainClass.generated.js"); +var _dependenciesCloneGenerated = require("./dependenciesNumber/dependenciesClone.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesNumber/dependenciesCombinations.generated.js"); +var _dependenciesCombinationsWithRepGenerated = require("./dependenciesNumber/dependenciesCombinationsWithRep.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesNumber/dependenciesCompare.generated.js"); +var _dependenciesCompareNaturalGenerated = require("./dependenciesNumber/dependenciesCompareNatural.generated.js"); +var _dependenciesCompareTextGenerated = require("./dependenciesNumber/dependenciesCompareText.generated.js"); +var _dependenciesCompileGenerated = require("./dependenciesNumber/dependenciesCompile.generated.js"); +var _dependenciesCompositionGenerated = require("./dependenciesNumber/dependenciesComposition.generated.js"); +var _dependenciesConditionalNodeGenerated = require("./dependenciesNumber/dependenciesConditionalNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesNumber/dependenciesConstantNode.generated.js"); +var _dependenciesCorrGenerated = require("./dependenciesNumber/dependenciesCorr.generated.js"); +var _dependenciesCosGenerated = require("./dependenciesNumber/dependenciesCos.generated.js"); +var _dependenciesCoshGenerated = require("./dependenciesNumber/dependenciesCosh.generated.js"); +var _dependenciesCotGenerated = require("./dependenciesNumber/dependenciesCot.generated.js"); +var _dependenciesCothGenerated = require("./dependenciesNumber/dependenciesCoth.generated.js"); +var _dependenciesCscGenerated = require("./dependenciesNumber/dependenciesCsc.generated.js"); +var _dependenciesCschGenerated = require("./dependenciesNumber/dependenciesCsch.generated.js"); +var _dependenciesCubeGenerated = require("./dependenciesNumber/dependenciesCube.generated.js"); +var _dependenciesCumSumGenerated = require("./dependenciesNumber/dependenciesCumSum.generated.js"); +var _dependenciesCumSumTransformGenerated = require("./dependenciesNumber/dependenciesCumSumTransform.generated.js"); +var _dependenciesDeepEqualGenerated = require("./dependenciesNumber/dependenciesDeepEqual.generated.js"); +var _dependenciesDerivativeGenerated = require("./dependenciesNumber/dependenciesDerivative.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesNumber/dependenciesDivide.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesNumber/dependenciesDivideScalar.generated.js"); +var _dependenciesEGenerated = require("./dependenciesNumber/dependenciesE.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesNumber/dependenciesEqual.generated.js"); +var _dependenciesEqualScalarGenerated = require("./dependenciesNumber/dependenciesEqualScalar.generated.js"); +var _dependenciesEqualTextGenerated = require("./dependenciesNumber/dependenciesEqualText.generated.js"); +var _dependenciesErfGenerated = require("./dependenciesNumber/dependenciesErf.generated.js"); +var _dependenciesEvaluateGenerated = require("./dependenciesNumber/dependenciesEvaluate.generated.js"); +var _dependenciesExpGenerated = require("./dependenciesNumber/dependenciesExp.generated.js"); +var _dependenciesExpm1Generated = require("./dependenciesNumber/dependenciesExpm1.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesNumber/dependenciesFactorial.generated.js"); +var _dependenciesFalseGenerated = require("./dependenciesNumber/dependenciesFalse.generated.js"); +var _dependenciesFilterGenerated = require("./dependenciesNumber/dependenciesFilter.generated.js"); +var _dependenciesFilterTransformGenerated = require("./dependenciesNumber/dependenciesFilterTransform.generated.js"); +var _dependenciesFixGenerated = require("./dependenciesNumber/dependenciesFix.generated.js"); +var _dependenciesFloorGenerated = require("./dependenciesNumber/dependenciesFloor.generated.js"); +var _dependenciesForEachGenerated = require("./dependenciesNumber/dependenciesForEach.generated.js"); +var _dependenciesForEachTransformGenerated = require("./dependenciesNumber/dependenciesForEachTransform.generated.js"); +var _dependenciesFormatGenerated = require("./dependenciesNumber/dependenciesFormat.generated.js"); +var _dependenciesFunctionAssignmentNodeGenerated = require("./dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesNumber/dependenciesFunctionNode.generated.js"); +var _dependenciesGammaGenerated = require("./dependenciesNumber/dependenciesGamma.generated.js"); +var _dependenciesGcdGenerated = require("./dependenciesNumber/dependenciesGcd.generated.js"); +var _dependenciesHasNumericValueGenerated = require("./dependenciesNumber/dependenciesHasNumericValue.generated.js"); +var _dependenciesHelpGenerated = require("./dependenciesNumber/dependenciesHelp.generated.js"); +var _dependenciesHelpClassGenerated = require("./dependenciesNumber/dependenciesHelpClass.generated.js"); +var _dependenciesHypotGenerated = require("./dependenciesNumber/dependenciesHypot.generated.js"); +var _dependenciesIndexGenerated = require("./dependenciesNumber/dependenciesIndex.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesNumber/dependenciesIndexNode.generated.js"); +var _dependenciesInfinityGenerated = require("./dependenciesNumber/dependenciesInfinity.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesNumber/dependenciesIsInteger.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesNumber/dependenciesIsNaN.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesNumber/dependenciesIsNegative.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesNumber/dependenciesIsNumeric.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesNumber/dependenciesIsPositive.generated.js"); +var _dependenciesIsPrimeGenerated = require("./dependenciesNumber/dependenciesIsPrime.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesNumber/dependenciesIsZero.generated.js"); +var _dependenciesLN10Generated = require("./dependenciesNumber/dependenciesLN10.generated.js"); +var _dependenciesLN2Generated = require("./dependenciesNumber/dependenciesLN2.generated.js"); +var _dependenciesLOG10EGenerated = require("./dependenciesNumber/dependenciesLOG10E.generated.js"); +var _dependenciesLOG2EGenerated = require("./dependenciesNumber/dependenciesLOG2E.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesNumber/dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesNumber/dependenciesLargerEq.generated.js"); +var _dependenciesLcmGenerated = require("./dependenciesNumber/dependenciesLcm.generated.js"); +var _dependenciesLeftShiftGenerated = require("./dependenciesNumber/dependenciesLeftShift.generated.js"); +var _dependenciesLgammaGenerated = require("./dependenciesNumber/dependenciesLgamma.generated.js"); +var _dependenciesLogGenerated = require("./dependenciesNumber/dependenciesLog.generated.js"); +var _dependenciesLog10Generated = require("./dependenciesNumber/dependenciesLog10.generated.js"); +var _dependenciesLog1pGenerated = require("./dependenciesNumber/dependenciesLog1p.generated.js"); +var _dependenciesLog2Generated = require("./dependenciesNumber/dependenciesLog2.generated.js"); +var _dependenciesMadGenerated = require("./dependenciesNumber/dependenciesMad.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesNumber/dependenciesMap.generated.js"); +var _dependenciesMapTransformGenerated = require("./dependenciesNumber/dependenciesMapTransform.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesNumber/dependenciesMatrix.generated.js"); +var _dependenciesMaxGenerated = require("./dependenciesNumber/dependenciesMax.generated.js"); +var _dependenciesMaxTransformGenerated = require("./dependenciesNumber/dependenciesMaxTransform.generated.js"); +var _dependenciesMeanGenerated = require("./dependenciesNumber/dependenciesMean.generated.js"); +var _dependenciesMeanTransformGenerated = require("./dependenciesNumber/dependenciesMeanTransform.generated.js"); +var _dependenciesMedianGenerated = require("./dependenciesNumber/dependenciesMedian.generated.js"); +var _dependenciesMinGenerated = require("./dependenciesNumber/dependenciesMin.generated.js"); +var _dependenciesMinTransformGenerated = require("./dependenciesNumber/dependenciesMinTransform.generated.js"); +var _dependenciesModGenerated = require("./dependenciesNumber/dependenciesMod.generated.js"); +var _dependenciesModeGenerated = require("./dependenciesNumber/dependenciesMode.generated.js"); +var _dependenciesMultinomialGenerated = require("./dependenciesNumber/dependenciesMultinomial.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesNumber/dependenciesMultiply.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesNumber/dependenciesMultiplyScalar.generated.js"); +var _dependenciesNaNGenerated = require("./dependenciesNumber/dependenciesNaN.generated.js"); +var _dependenciesNodeGenerated = require("./dependenciesNumber/dependenciesNode.generated.js"); +var _dependenciesNormGenerated = require("./dependenciesNumber/dependenciesNorm.generated.js"); +var _dependenciesNotGenerated = require("./dependenciesNumber/dependenciesNot.generated.js"); +var _dependenciesNthRootGenerated = require("./dependenciesNumber/dependenciesNthRoot.generated.js"); +var _dependenciesNullGenerated = require("./dependenciesNumber/dependenciesNull.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber/dependenciesNumber.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumber/dependenciesNumeric.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesNumber/dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesNumber/dependenciesOperatorNode.generated.js"); +var _dependenciesOrGenerated = require("./dependenciesNumber/dependenciesOr.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesNumber/dependenciesParenthesisNode.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesNumber/dependenciesParse.generated.js"); +var _dependenciesParserGenerated = require("./dependenciesNumber/dependenciesParser.generated.js"); +var _dependenciesParserClassGenerated = require("./dependenciesNumber/dependenciesParserClass.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesNumber/dependenciesPartitionSelect.generated.js"); +var _dependenciesPermutationsGenerated = require("./dependenciesNumber/dependenciesPermutations.generated.js"); +var _dependenciesPhiGenerated = require("./dependenciesNumber/dependenciesPhi.generated.js"); +var _dependenciesPiGenerated = require("./dependenciesNumber/dependenciesPi.generated.js"); +var _dependenciesPickRandomGenerated = require("./dependenciesNumber/dependenciesPickRandom.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesNumber/dependenciesPow.generated.js"); +var _dependenciesPrintGenerated = require("./dependenciesNumber/dependenciesPrint.generated.js"); +var _dependenciesProdGenerated = require("./dependenciesNumber/dependenciesProd.generated.js"); +var _dependenciesQuantileSeqGenerated = require("./dependenciesNumber/dependenciesQuantileSeq.generated.js"); +var _dependenciesRandomGenerated = require("./dependenciesNumber/dependenciesRandom.generated.js"); +var _dependenciesRandomIntGenerated = require("./dependenciesNumber/dependenciesRandomInt.generated.js"); +var _dependenciesRangeGenerated = require("./dependenciesNumber/dependenciesRange.generated.js"); +var _dependenciesRangeClassGenerated = require("./dependenciesNumber/dependenciesRangeClass.generated.js"); +var _dependenciesRangeNodeGenerated = require("./dependenciesNumber/dependenciesRangeNode.generated.js"); +var _dependenciesRangeTransformGenerated = require("./dependenciesNumber/dependenciesRangeTransform.generated.js"); +var _dependenciesRationalizeGenerated = require("./dependenciesNumber/dependenciesRationalize.generated.js"); +var _dependenciesRelationalNodeGenerated = require("./dependenciesNumber/dependenciesRelationalNode.generated.js"); +var _dependenciesReplacerGenerated = require("./dependenciesNumber/dependenciesReplacer.generated.js"); +var _dependenciesResolveGenerated = require("./dependenciesNumber/dependenciesResolve.generated.js"); +var _dependenciesResultSetGenerated = require("./dependenciesNumber/dependenciesResultSet.generated.js"); +var _dependenciesReviverGenerated = require("./dependenciesNumber/dependenciesReviver.generated.js"); +var _dependenciesRightArithShiftGenerated = require("./dependenciesNumber/dependenciesRightArithShift.generated.js"); +var _dependenciesRightLogShiftGenerated = require("./dependenciesNumber/dependenciesRightLogShift.generated.js"); +var _dependenciesRoundGenerated = require("./dependenciesNumber/dependenciesRound.generated.js"); +var _dependenciesSQRT1_2Generated = require("./dependenciesNumber/dependenciesSQRT1_2.generated.js"); +var _dependenciesSQRT2Generated = require("./dependenciesNumber/dependenciesSQRT2.generated.js"); +var _dependenciesSecGenerated = require("./dependenciesNumber/dependenciesSec.generated.js"); +var _dependenciesSechGenerated = require("./dependenciesNumber/dependenciesSech.generated.js"); +var _dependenciesSignGenerated = require("./dependenciesNumber/dependenciesSign.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesNumber/dependenciesSimplify.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesNumber/dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesNumber/dependenciesSimplifyCore.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesNumber/dependenciesSin.generated.js"); +var _dependenciesSinhGenerated = require("./dependenciesNumber/dependenciesSinh.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesNumber/dependenciesSize.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesNumber/dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesNumber/dependenciesSmallerEq.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesNumber/dependenciesSqrt.generated.js"); +var _dependenciesSquareGenerated = require("./dependenciesNumber/dependenciesSquare.generated.js"); +var _dependenciesStdGenerated = require("./dependenciesNumber/dependenciesStd.generated.js"); +var _dependenciesStdTransformGenerated = require("./dependenciesNumber/dependenciesStdTransform.generated.js"); +var _dependenciesStirlingS2Generated = require("./dependenciesNumber/dependenciesStirlingS2.generated.js"); +var _dependenciesStringGenerated = require("./dependenciesNumber/dependenciesString.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesNumber/dependenciesSubset.generated.js"); +var _dependenciesSubsetTransformGenerated = require("./dependenciesNumber/dependenciesSubsetTransform.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesNumber/dependenciesSubtract.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesNumber/dependenciesSubtractScalar.generated.js"); +var _dependenciesSumGenerated = require("./dependenciesNumber/dependenciesSum.generated.js"); +var _dependenciesSumTransformGenerated = require("./dependenciesNumber/dependenciesSumTransform.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesNumber/dependenciesSymbolNode.generated.js"); +var _dependenciesTanGenerated = require("./dependenciesNumber/dependenciesTan.generated.js"); +var _dependenciesTanhGenerated = require("./dependenciesNumber/dependenciesTanh.generated.js"); +var _dependenciesTauGenerated = require("./dependenciesNumber/dependenciesTau.generated.js"); +var _dependenciesTrueGenerated = require("./dependenciesNumber/dependenciesTrue.generated.js"); +var _dependenciesTypeOfGenerated = require("./dependenciesNumber/dependenciesTypeOf.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesNumber/dependenciesTyped.generated.js"); +var _dependenciesUnaryMinusGenerated = require("./dependenciesNumber/dependenciesUnaryMinus.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesNumber/dependenciesUnaryPlus.generated.js"); +var _dependenciesUnequalGenerated = require("./dependenciesNumber/dependenciesUnequal.generated.js"); +var _dependenciesUppercaseEGenerated = require("./dependenciesNumber/dependenciesUppercaseE.generated.js"); +var _dependenciesUppercasePiGenerated = require("./dependenciesNumber/dependenciesUppercasePi.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesNumber/dependenciesVariance.generated.js"); +var _dependenciesVarianceTransformGenerated = require("./dependenciesNumber/dependenciesVarianceTransform.generated.js"); +var _dependenciesVersionGenerated = require("./dependenciesNumber/dependenciesVersion.generated.js"); +var _dependenciesXgcdGenerated = require("./dependenciesNumber/dependenciesXgcd.generated.js"); +var _dependenciesXorGenerated = require("./dependenciesNumber/dependenciesXor.generated.js"); +var _dependenciesZetaGenerated = require("./dependenciesNumber/dependenciesZeta.generated.js"); +var _allFactoriesNumber = require("./allFactoriesNumber.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAbs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAbs.generated.js new file mode 100644 index 0000000..e9485c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAbs.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.absDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const absDependencies = exports.absDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAbs: _factoriesNumber.createAbs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAccessorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAccessorNode.generated.js new file mode 100644 index 0000000..1e76b37 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAccessorNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.AccessorNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const AccessorNodeDependencies = exports.AccessorNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + createAccessorNode: _factoriesNumber.createAccessorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcos.generated.js new file mode 100644 index 0000000..ba76716 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcos.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acosDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acosDependencies = exports.acosDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcos: _factoriesNumber.createAcos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcosh.generated.js new file mode 100644 index 0000000..6d65aa0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcosh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acoshDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acoshDependencies = exports.acoshDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcosh: _factoriesNumber.createAcosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcot.generated.js new file mode 100644 index 0000000..fa77128 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acotDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acotDependencies = exports.acotDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcot: _factoriesNumber.createAcot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcoth.generated.js new file mode 100644 index 0000000..26e4d33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcoth.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acothDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acothDependencies = exports.acothDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcoth: _factoriesNumber.createAcoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsc.generated.js new file mode 100644 index 0000000..97a796a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsc.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acscDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acscDependencies = exports.acscDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcsc: _factoriesNumber.createAcsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsch.generated.js new file mode 100644 index 0000000..a732848 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAcsch.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acschDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const acschDependencies = exports.acschDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAcsch: _factoriesNumber.createAcsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAdd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAdd.generated.js new file mode 100644 index 0000000..0e292c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAdd.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const addDependencies = exports.addDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAdd: _factoriesNumber.createAdd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAddScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAddScalar.generated.js new file mode 100644 index 0000000..51789ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAddScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const addScalarDependencies = exports.addScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAddScalar: _factoriesNumber.createAddScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAnd.generated.js new file mode 100644 index 0000000..20f1fe3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAnd.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.andDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const andDependencies = exports.andDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAnd: _factoriesNumber.createAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApply.generated.js new file mode 100644 index 0000000..d742831 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApply.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.applyDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const applyDependencies = exports.applyDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createApply: _factoriesNumber.createApply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApplyTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApplyTransform.generated.js new file mode 100644 index 0000000..424126c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesApplyTransform.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.applyTransformDependencies = void 0; +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const applyTransformDependencies = exports.applyTransformDependencies = { + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createApplyTransform: _factoriesNumber.createApplyTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesArrayNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesArrayNode.generated.js new file mode 100644 index 0000000..dc59bef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesArrayNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ArrayNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ArrayNodeDependencies = exports.ArrayNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createArrayNode: _factoriesNumber.createArrayNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsec.generated.js new file mode 100644 index 0000000..57e34a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsec.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asecDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asecDependencies = exports.asecDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsec: _factoriesNumber.createAsec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsech.generated.js new file mode 100644 index 0000000..8723bb2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsech.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asechDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asechDependencies = exports.asechDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsech: _factoriesNumber.createAsech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsin.generated.js new file mode 100644 index 0000000..743cf4f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsin.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asinDependencies = exports.asinDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsin: _factoriesNumber.createAsin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsinh.generated.js new file mode 100644 index 0000000..9a7c1bf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAsinh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const asinhDependencies = exports.asinhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAsinh: _factoriesNumber.createAsinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js new file mode 100644 index 0000000..db3c7f4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.AssignmentNodeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSubsetGenerated = require("./dependenciesSubset.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const AssignmentNodeDependencies = exports.AssignmentNodeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies, + createAssignmentNode: _factoriesNumber.createAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan.generated.js new file mode 100644 index 0000000..74f6f0b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atanDependencies = exports.atanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtan: _factoriesNumber.createAtan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan2.generated.js new file mode 100644 index 0000000..fe4d438 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtan2.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atan2Dependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atan2Dependencies = exports.atan2Dependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtan2: _factoriesNumber.createAtan2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtanh.generated.js new file mode 100644 index 0000000..6f67c96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesAtanh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const atanhDependencies = exports.atanhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createAtanh: _factoriesNumber.createAtanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBellNumbers.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBellNumbers.generated.js new file mode 100644 index 0000000..84a4ab6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBellNumbers.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bellNumbersDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesStirlingS2Generated = require("./dependenciesStirlingS2.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bellNumbersDependencies = exports.bellNumbersDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + stirlingS2Dependencies: _dependenciesStirlingS2Generated.stirlingS2Dependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBellNumbers: _factoriesNumber.createBellNumbers +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBigint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBigint.generated.js new file mode 100644 index 0000000..711e272 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBigint.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bigintDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bigintDependencies = exports.bigintDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBigint: _factoriesNumber.createBigint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitAnd.generated.js new file mode 100644 index 0000000..1d8fb1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitAnd.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitAndDependencies = exports.bitAndDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitAnd: _factoriesNumber.createBitAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitNot.generated.js new file mode 100644 index 0000000..cb2d71e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitNot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitNotDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitNotDependencies = exports.bitNotDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitNot: _factoriesNumber.createBitNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitOr.generated.js new file mode 100644 index 0000000..6ce8e6e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitOr.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitOrDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitOrDependencies = exports.bitOrDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitOr: _factoriesNumber.createBitOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitXor.generated.js new file mode 100644 index 0000000..d1b6408 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBitXor.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitXorDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const bitXorDependencies = exports.bitXorDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBitXor: _factoriesNumber.createBitXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBlockNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBlockNode.generated.js new file mode 100644 index 0000000..aafced2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBlockNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.BlockNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesResultSetGenerated = require("./dependenciesResultSet.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const BlockNodeDependencies = exports.BlockNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + ResultSetDependencies: _dependenciesResultSetGenerated.ResultSetDependencies, + createBlockNode: _factoriesNumber.createBlockNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBoolean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBoolean.generated.js new file mode 100644 index 0000000..7f19df9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesBoolean.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.booleanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const booleanDependencies = exports.booleanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createBoolean: _factoriesNumber.createBoolean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCatalan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCatalan.generated.js new file mode 100644 index 0000000..cc1737d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCatalan.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.catalanDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const catalanDependencies = exports.catalanDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCatalan: _factoriesNumber.createCatalan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCbrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCbrt.generated.js new file mode 100644 index 0000000..7f34821 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCbrt.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cbrtDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cbrtDependencies = exports.cbrtDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCbrt: _factoriesNumber.createCbrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCeil.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCeil.generated.js new file mode 100644 index 0000000..5a99231 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCeil.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ceilDependencies = void 0; +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ceilDependencies = exports.ceilDependencies = { + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCeil: _factoriesNumber.createCeil +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChain.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChain.generated.js new file mode 100644 index 0000000..e4fcb16 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChain.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.chainDependencies = void 0; +var _dependenciesChainClassGenerated = require("./dependenciesChainClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const chainDependencies = exports.chainDependencies = { + ChainDependencies: _dependenciesChainClassGenerated.ChainDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createChain: _factoriesNumber.createChain +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChainClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChainClass.generated.js new file mode 100644 index 0000000..099a462 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesChainClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ChainDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ChainDependencies = exports.ChainDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createChainClass: _factoriesNumber.createChainClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesClone.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesClone.generated.js new file mode 100644 index 0000000..d635205 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesClone.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cloneDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cloneDependencies = exports.cloneDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createClone: _factoriesNumber.createClone +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinations.generated.js new file mode 100644 index 0000000..54f291b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinations.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const combinationsDependencies = exports.combinationsDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCombinations: _factoriesNumber.createCombinations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js new file mode 100644 index 0000000..3ab0e01 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsWithRepDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const combinationsWithRepDependencies = exports.combinationsWithRepDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCombinationsWithRep: _factoriesNumber.createCombinationsWithRep +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompare.generated.js new file mode 100644 index 0000000..a2ef64a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompare.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareDependencies = exports.compareDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompare: _factoriesNumber.createCompare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareNatural.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareNatural.generated.js new file mode 100644 index 0000000..79b56c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareNatural.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareNaturalDependencies = void 0; +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareNaturalDependencies = exports.compareNaturalDependencies = { + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompareNatural: _factoriesNumber.createCompareNatural +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareText.generated.js new file mode 100644 index 0000000..10831d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompareText.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareTextDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compareTextDependencies = exports.compareTextDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompareText: _factoriesNumber.createCompareText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompile.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompile.generated.js new file mode 100644 index 0000000..e05ece3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCompile.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compileDependencies = void 0; +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compileDependencies = exports.compileDependencies = { + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCompile: _factoriesNumber.createCompile +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesComposition.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesComposition.generated.js new file mode 100644 index 0000000..86fa60b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesComposition.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compositionDependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const compositionDependencies = exports.compositionDependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createComposition: _factoriesNumber.createComposition +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConditionalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConditionalNode.generated.js new file mode 100644 index 0000000..3717bf3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConditionalNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ConditionalNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ConditionalNodeDependencies = exports.ConditionalNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createConditionalNode: _factoriesNumber.createConditionalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConstantNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConstantNode.generated.js new file mode 100644 index 0000000..a6121e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesConstantNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ConstantNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ConstantNodeDependencies = exports.ConstantNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createConstantNode: _factoriesNumber.createConstantNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCorr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCorr.generated.js new file mode 100644 index 0000000..0406748 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCorr.generated.js @@ -0,0 +1,35 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.corrDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMeanGenerated = require("./dependenciesMean.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesSumGenerated = require("./dependenciesSum.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const corrDependencies = exports.corrDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + meanDependencies: _dependenciesMeanGenerated.meanDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + sumDependencies: _dependenciesSumGenerated.sumDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCorr: _factoriesNumber.createCorr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCos.generated.js new file mode 100644 index 0000000..7a1c466 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCos.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cosDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cosDependencies = exports.cosDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCos: _factoriesNumber.createCos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCosh.generated.js new file mode 100644 index 0000000..afb0b87 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCosh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.coshDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const coshDependencies = exports.coshDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCosh: _factoriesNumber.createCosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCot.generated.js new file mode 100644 index 0000000..8e2c524 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cotDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cotDependencies = exports.cotDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCot: _factoriesNumber.createCot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCoth.generated.js new file mode 100644 index 0000000..f5eb7b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCoth.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cothDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cothDependencies = exports.cothDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCoth: _factoriesNumber.createCoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsc.generated.js new file mode 100644 index 0000000..181723c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsc.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cscDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cscDependencies = exports.cscDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCsc: _factoriesNumber.createCsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsch.generated.js new file mode 100644 index 0000000..e4ea771 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCsch.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cschDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cschDependencies = exports.cschDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCsch: _factoriesNumber.createCsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCube.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCube.generated.js new file mode 100644 index 0000000..6735e1b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCube.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cubeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cubeDependencies = exports.cubeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createCube: _factoriesNumber.createCube +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSum.generated.js new file mode 100644 index 0000000..63e1596 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSum.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cumsumDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesUnaryPlus.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cumsumDependencies = exports.cumsumDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies, + createCumSum: _factoriesNumber.createCumSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js new file mode 100644 index 0000000..5ab2c2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cumsumTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesUnaryPlusGenerated = require("./dependenciesUnaryPlus.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const cumsumTransformDependencies = exports.cumsumTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies, + createCumSumTransform: _factoriesNumber.createCumSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDeepEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDeepEqual.generated.js new file mode 100644 index 0000000..dc54e9c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDeepEqual.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.deepEqualDependencies = void 0; +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const deepEqualDependencies = exports.deepEqualDependencies = { + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDeepEqual: _factoriesNumber.createDeepEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDerivative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDerivative.generated.js new file mode 100644 index 0000000..cf41d1f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDerivative.generated.js @@ -0,0 +1,37 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.derivativeDependencies = void 0; +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesSimplify.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const derivativeDependencies = exports.derivativeDependencies = { + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDerivative: _factoriesNumber.createDerivative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivide.generated.js new file mode 100644 index 0000000..346757e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivide.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.divideDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const divideDependencies = exports.divideDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDivide: _factoriesNumber.createDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivideScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivideScalar.generated.js new file mode 100644 index 0000000..64dfeb4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesDivideScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.divideScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const divideScalarDependencies = exports.divideScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createDivideScalar: _factoriesNumber.createDivideScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesE.generated.js new file mode 100644 index 0000000..cecc000 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesE.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.eDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const eDependencies = exports.eDependencies = { + createE: _factoriesNumber.createE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqual.generated.js new file mode 100644 index 0000000..a59e816 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqual.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalDependencies = void 0; +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalDependencies = exports.equalDependencies = { + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqual: _factoriesNumber.createEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualScalar.generated.js new file mode 100644 index 0000000..a691430 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalScalarDependencies = exports.equalScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqualScalar: _factoriesNumber.createEqualScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualText.generated.js new file mode 100644 index 0000000..220c175 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEqualText.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalTextDependencies = void 0; +var _dependenciesCompareTextGenerated = require("./dependenciesCompareText.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const equalTextDependencies = exports.equalTextDependencies = { + compareTextDependencies: _dependenciesCompareTextGenerated.compareTextDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEqualText: _factoriesNumber.createEqualText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesErf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesErf.generated.js new file mode 100644 index 0000000..7daf4fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesErf.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.erfDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const erfDependencies = exports.erfDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createErf: _factoriesNumber.createErf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEvaluate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEvaluate.generated.js new file mode 100644 index 0000000..7f62901 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesEvaluate.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.evaluateDependencies = void 0; +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const evaluateDependencies = exports.evaluateDependencies = { + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createEvaluate: _factoriesNumber.createEvaluate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExp.generated.js new file mode 100644 index 0000000..1f6a507 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExp.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const expDependencies = exports.expDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createExp: _factoriesNumber.createExp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExpm1.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExpm1.generated.js new file mode 100644 index 0000000..04cf1c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesExpm1.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expm1Dependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const expm1Dependencies = exports.expm1Dependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createExpm1: _factoriesNumber.createExpm1 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFactorial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFactorial.generated.js new file mode 100644 index 0000000..b610553 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFactorial.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.factorialDependencies = void 0; +var _dependenciesGammaGenerated = require("./dependenciesGamma.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const factorialDependencies = exports.factorialDependencies = { + gammaDependencies: _dependenciesGammaGenerated.gammaDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFactorial: _factoriesNumber.createFactorial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFalse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFalse.generated.js new file mode 100644 index 0000000..67e166e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFalse.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.falseDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const falseDependencies = exports.falseDependencies = { + createFalse: _factoriesNumber.createFalse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilter.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilter.generated.js new file mode 100644 index 0000000..141e4f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilter.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.filterDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const filterDependencies = exports.filterDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFilter: _factoriesNumber.createFilter +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilterTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilterTransform.generated.js new file mode 100644 index 0000000..9fe1a59 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFilterTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.filterTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const filterTransformDependencies = exports.filterTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFilterTransform: _factoriesNumber.createFilterTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFix.generated.js new file mode 100644 index 0000000..f4f5c96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFix.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fixDependencies = void 0; +var _dependenciesCeilGenerated = require("./dependenciesCeil.generated.js"); +var _dependenciesFloorGenerated = require("./dependenciesFloor.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const fixDependencies = exports.fixDependencies = { + ceilDependencies: _dependenciesCeilGenerated.ceilDependencies, + floorDependencies: _dependenciesFloorGenerated.floorDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFix: _factoriesNumber.createFix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFloor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFloor.generated.js new file mode 100644 index 0000000..582d328 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFloor.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.floorDependencies = void 0; +var _dependenciesRoundGenerated = require("./dependenciesRound.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const floorDependencies = exports.floorDependencies = { + roundDependencies: _dependenciesRoundGenerated.roundDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFloor: _factoriesNumber.createFloor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEach.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEach.generated.js new file mode 100644 index 0000000..81936d0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEach.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.forEachDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const forEachDependencies = exports.forEachDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createForEach: _factoriesNumber.createForEach +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEachTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEachTransform.generated.js new file mode 100644 index 0000000..2aa784a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesForEachTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.forEachTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const forEachTransformDependencies = exports.forEachTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createForEachTransform: _factoriesNumber.createForEachTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFormat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFormat.generated.js new file mode 100644 index 0000000..0479849 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFormat.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.formatDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const formatDependencies = exports.formatDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFormat: _factoriesNumber.createFormat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js new file mode 100644 index 0000000..218e5fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FunctionAssignmentNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FunctionAssignmentNodeDependencies = exports.FunctionAssignmentNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createFunctionAssignmentNode: _factoriesNumber.createFunctionAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionNode.generated.js new file mode 100644 index 0000000..62c3d4d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesFunctionNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.FunctionNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const FunctionNodeDependencies = exports.FunctionNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + createFunctionNode: _factoriesNumber.createFunctionNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGamma.generated.js new file mode 100644 index 0000000..b27dc79 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGamma.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gammaDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gammaDependencies = exports.gammaDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createGamma: _factoriesNumber.createGamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGcd.generated.js new file mode 100644 index 0000000..d797983 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesGcd.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gcdDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const gcdDependencies = exports.gcdDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createGcd: _factoriesNumber.createGcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js new file mode 100644 index 0000000..44acb49 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasNumericValueDependencies = void 0; +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hasNumericValueDependencies = exports.hasNumericValueDependencies = { + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHasNumericValue: _factoriesNumber.createHasNumericValue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelp.generated.js new file mode 100644 index 0000000..64af532 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelp.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.helpDependencies = void 0; +var _dependenciesHelpClassGenerated = require("./dependenciesHelpClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const helpDependencies = exports.helpDependencies = { + HelpDependencies: _dependenciesHelpClassGenerated.HelpDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHelp: _factoriesNumber.createHelp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelpClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelpClass.generated.js new file mode 100644 index 0000000..6253896 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHelpClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.HelpDependencies = void 0; +var _dependenciesEvaluateGenerated = require("./dependenciesEvaluate.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const HelpDependencies = exports.HelpDependencies = { + evaluateDependencies: _dependenciesEvaluateGenerated.evaluateDependencies, + createHelpClass: _factoriesNumber.createHelpClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHypot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHypot.generated.js new file mode 100644 index 0000000..fb7e015 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesHypot.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hypotDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const hypotDependencies = exports.hypotDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createHypot: _factoriesNumber.createHypot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndex.generated.js new file mode 100644 index 0000000..72b8bc7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndex.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.indexDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const indexDependencies = exports.indexDependencies = { + createIndex: _factoriesNumber.createIndex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndexNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndexNode.generated.js new file mode 100644 index 0000000..c2c40f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIndexNode.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.IndexNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _dependenciesSizeGenerated = require("./dependenciesSize.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const IndexNodeDependencies = exports.IndexNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + sizeDependencies: _dependenciesSizeGenerated.sizeDependencies, + createIndexNode: _factoriesNumber.createIndexNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesInfinity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesInfinity.generated.js new file mode 100644 index 0000000..1196315 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesInfinity.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.InfinityDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const InfinityDependencies = exports.InfinityDependencies = { + createInfinity: _factoriesNumber.createInfinity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsInteger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsInteger.generated.js new file mode 100644 index 0000000..2450b89 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsInteger.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isIntegerDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isIntegerDependencies = exports.isIntegerDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsInteger: _factoriesNumber.createIsInteger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNaN.generated.js new file mode 100644 index 0000000..ae67c93 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNaN.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNaNDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNaNDependencies = exports.isNaNDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNaN: _factoriesNumber.createIsNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNegative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNegative.generated.js new file mode 100644 index 0000000..e6772f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNegative.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNegativeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNegativeDependencies = exports.isNegativeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNegative: _factoriesNumber.createIsNegative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNumeric.generated.js new file mode 100644 index 0000000..6c7f4c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsNumeric.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNumericDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isNumericDependencies = exports.isNumericDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsNumeric: _factoriesNumber.createIsNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPositive.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPositive.generated.js new file mode 100644 index 0000000..1e8cedd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPositive.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPositiveDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isPositiveDependencies = exports.isPositiveDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsPositive: _factoriesNumber.createIsPositive +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPrime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPrime.generated.js new file mode 100644 index 0000000..45bdf5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsPrime.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPrimeDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isPrimeDependencies = exports.isPrimeDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsPrime: _factoriesNumber.createIsPrime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsZero.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsZero.generated.js new file mode 100644 index 0000000..a760963 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesIsZero.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isZeroDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const isZeroDependencies = exports.isZeroDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createIsZero: _factoriesNumber.createIsZero +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN10.generated.js new file mode 100644 index 0000000..9b1512c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN10.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN10Dependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LN10Dependencies = exports.LN10Dependencies = { + createLN10: _factoriesNumber.createLN10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN2.generated.js new file mode 100644 index 0000000..483a4dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLN2.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN2Dependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LN2Dependencies = exports.LN2Dependencies = { + createLN2: _factoriesNumber.createLN2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG10E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG10E.generated.js new file mode 100644 index 0000000..e86e5c4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG10E.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG10EDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LOG10EDependencies = exports.LOG10EDependencies = { + createLOG10E: _factoriesNumber.createLOG10E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG2E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG2E.generated.js new file mode 100644 index 0000000..abf38ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLOG2E.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG2EDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const LOG2EDependencies = exports.LOG2EDependencies = { + createLOG2E: _factoriesNumber.createLOG2E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLarger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLarger.generated.js new file mode 100644 index 0000000..02c305b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLarger.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const largerDependencies = exports.largerDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLarger: _factoriesNumber.createLarger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLargerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLargerEq.generated.js new file mode 100644 index 0000000..f6a60a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLargerEq.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerEqDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const largerEqDependencies = exports.largerEqDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLargerEq: _factoriesNumber.createLargerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLcm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLcm.generated.js new file mode 100644 index 0000000..3b1cd75 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLcm.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lcmDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lcmDependencies = exports.lcmDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLcm: _factoriesNumber.createLcm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLeftShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLeftShift.generated.js new file mode 100644 index 0000000..64bb0d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLeftShift.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.leftShiftDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const leftShiftDependencies = exports.leftShiftDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLeftShift: _factoriesNumber.createLeftShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLgamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLgamma.generated.js new file mode 100644 index 0000000..8afdc01 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLgamma.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lgammaDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const lgammaDependencies = exports.lgammaDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLgamma: _factoriesNumber.createLgamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog.generated.js new file mode 100644 index 0000000..57d9550 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.logDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const logDependencies = exports.logDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog: _factoriesNumber.createLog +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog10.generated.js new file mode 100644 index 0000000..edfb462 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog10.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log10Dependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log10Dependencies = exports.log10Dependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog10: _factoriesNumber.createLog10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog1p.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog1p.generated.js new file mode 100644 index 0000000..45acff9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog1p.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log1pDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log1pDependencies = exports.log1pDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog1p: _factoriesNumber.createLog1p +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog2.generated.js new file mode 100644 index 0000000..d80d6ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesLog2.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log2Dependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const log2Dependencies = exports.log2Dependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createLog2: _factoriesNumber.createLog2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMad.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMad.generated.js new file mode 100644 index 0000000..9eb37a6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMad.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.madDependencies = void 0; +var _dependenciesAbsGenerated = require("./dependenciesAbs.generated.js"); +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesMedianGenerated = require("./dependenciesMedian.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const madDependencies = exports.madDependencies = { + absDependencies: _dependenciesAbsGenerated.absDependencies, + mapDependencies: _dependenciesMapGenerated.mapDependencies, + medianDependencies: _dependenciesMedianGenerated.medianDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMad: _factoriesNumber.createMad +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMap.generated.js new file mode 100644 index 0000000..504764d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMap.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mapDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const mapDependencies = exports.mapDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMap: _factoriesNumber.createMap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMapTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMapTransform.generated.js new file mode 100644 index 0000000..cc42590 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMapTransform.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mapTransformDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const mapTransformDependencies = exports.mapTransformDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMapTransform: _factoriesNumber.createMapTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMatrix.generated.js new file mode 100644 index 0000000..21bcd3c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMatrix.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const matrixDependencies = exports.matrixDependencies = { + createMatrix: _factoriesNumber.createMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMax.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMax.generated.js new file mode 100644 index 0000000..358aae2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMax.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.maxDependencies = void 0; +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const maxDependencies = exports.maxDependencies = { + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMax: _factoriesNumber.createMax +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMaxTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMaxTransform.generated.js new file mode 100644 index 0000000..154d6b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMaxTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.maxTransformDependencies = void 0; +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const maxTransformDependencies = exports.maxTransformDependencies = { + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMaxTransform: _factoriesNumber.createMaxTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMean.generated.js new file mode 100644 index 0000000..4d8c88d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMean.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.meanDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const meanDependencies = exports.meanDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMean: _factoriesNumber.createMean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMeanTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMeanTransform.generated.js new file mode 100644 index 0000000..f2fa8f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMeanTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.meanTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const meanTransformDependencies = exports.meanTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMeanTransform: _factoriesNumber.createMeanTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMedian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMedian.generated.js new file mode 100644 index 0000000..c1cbb1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMedian.generated.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.medianDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesPartitionSelect.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const medianDependencies = exports.medianDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMedian: _factoriesNumber.createMedian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMin.generated.js new file mode 100644 index 0000000..0b28234 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMin.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.minDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const minDependencies = exports.minDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMin: _factoriesNumber.createMin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMinTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMinTransform.generated.js new file mode 100644 index 0000000..340c8ab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMinTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.minTransformDependencies = void 0; +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const minTransformDependencies = exports.minTransformDependencies = { + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMinTransform: _factoriesNumber.createMinTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMod.generated.js new file mode 100644 index 0000000..ac9ffa6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMod.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const modDependencies = exports.modDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMod: _factoriesNumber.createMod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMode.generated.js new file mode 100644 index 0000000..6c66983 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMode.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modeDependencies = void 0; +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const modeDependencies = exports.modeDependencies = { + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMode: _factoriesNumber.createMode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultinomial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultinomial.generated.js new file mode 100644 index 0000000..17b6f75 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultinomial.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multinomialDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multinomialDependencies = exports.multinomialDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultinomial: _factoriesNumber.createMultinomial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiply.generated.js new file mode 100644 index 0000000..b7c2937 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiply.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multiplyDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multiplyDependencies = exports.multiplyDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultiply: _factoriesNumber.createMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js new file mode 100644 index 0000000..0501d3d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multiplyScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const multiplyScalarDependencies = exports.multiplyScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createMultiplyScalar: _factoriesNumber.createMultiplyScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNaN.generated.js new file mode 100644 index 0000000..afdf6ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNaN.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NaNDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const NaNDependencies = exports.NaNDependencies = { + createNaN: _factoriesNumber.createNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNode.generated.js new file mode 100644 index 0000000..74cf58f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNode.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NodeDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const NodeDependencies = exports.NodeDependencies = { + createNode: _factoriesNumber.createNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNorm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNorm.generated.js new file mode 100644 index 0000000..9993c89 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNorm.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.normDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const normDependencies = exports.normDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNorm: _factoriesNumber.createNorm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNot.generated.js new file mode 100644 index 0000000..c48e858 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.notDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const notDependencies = exports.notDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNot: _factoriesNumber.createNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNthRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNthRoot.generated.js new file mode 100644 index 0000000..221da34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNthRoot.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nthRootDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nthRootDependencies = exports.nthRootDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNthRoot: _factoriesNumber.createNthRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNull.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNull.generated.js new file mode 100644 index 0000000..6a72e3c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNull.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nullDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const nullDependencies = exports.nullDependencies = { + createNull: _factoriesNumber.createNull +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumber.generated.js new file mode 100644 index 0000000..e9e7af2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumber.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numberDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const numberDependencies = exports.numberDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createNumber: _factoriesNumber.createNumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumeric.generated.js new file mode 100644 index 0000000..7b20e94 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesNumeric.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numericDependencies = void 0; +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const numericDependencies = exports.numericDependencies = { + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + createNumeric: _factoriesNumber.createNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesObjectNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesObjectNode.generated.js new file mode 100644 index 0000000..e7da029 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesObjectNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ObjectNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ObjectNodeDependencies = exports.ObjectNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createObjectNode: _factoriesNumber.createObjectNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOperatorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOperatorNode.generated.js new file mode 100644 index 0000000..274dd46 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOperatorNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.OperatorNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const OperatorNodeDependencies = exports.OperatorNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createOperatorNode: _factoriesNumber.createOperatorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOr.generated.js new file mode 100644 index 0000000..36be79c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesOr.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.orDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const orDependencies = exports.orDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createOr: _factoriesNumber.createOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js new file mode 100644 index 0000000..f4695b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ParenthesisNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ParenthesisNodeDependencies = exports.ParenthesisNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createParenthesisNode: _factoriesNumber.createParenthesisNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParse.generated.js new file mode 100644 index 0000000..15c9ff8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParse.generated.js @@ -0,0 +1,49 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.parseDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesAssignmentNodeGenerated = require("./dependenciesAssignmentNode.generated.js"); +var _dependenciesBlockNodeGenerated = require("./dependenciesBlockNode.generated.js"); +var _dependenciesConditionalNodeGenerated = require("./dependenciesConditionalNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionAssignmentNodeGenerated = require("./dependenciesFunctionAssignmentNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesRangeNodeGenerated = require("./dependenciesRangeNode.generated.js"); +var _dependenciesRelationalNodeGenerated = require("./dependenciesRelationalNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const parseDependencies = exports.parseDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + AssignmentNodeDependencies: _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies, + BlockNodeDependencies: _dependenciesBlockNodeGenerated.BlockNodeDependencies, + ConditionalNodeDependencies: _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionAssignmentNodeDependencies: _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + RangeNodeDependencies: _dependenciesRangeNodeGenerated.RangeNodeDependencies, + RelationalNodeDependencies: _dependenciesRelationalNodeGenerated.RelationalNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createParse: _factoriesNumber.createParse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParser.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParser.generated.js new file mode 100644 index 0000000..98aa7b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParser.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.parserDependencies = void 0; +var _dependenciesParserClassGenerated = require("./dependenciesParserClass.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const parserDependencies = exports.parserDependencies = { + ParserDependencies: _dependenciesParserClassGenerated.ParserDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createParser: _factoriesNumber.createParser +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParserClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParserClass.generated.js new file mode 100644 index 0000000..5266912 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesParserClass.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ParserDependencies = void 0; +var _dependenciesEvaluateGenerated = require("./dependenciesEvaluate.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ParserDependencies = exports.ParserDependencies = { + evaluateDependencies: _dependenciesEvaluateGenerated.evaluateDependencies, + createParserClass: _factoriesNumber.createParserClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js new file mode 100644 index 0000000..2d7cfd3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.partitionSelectDependencies = void 0; +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesIsNumericGenerated = require("./dependenciesIsNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const partitionSelectDependencies = exports.partitionSelectDependencies = { + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPartitionSelect: _factoriesNumber.createPartitionSelect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPermutations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPermutations.generated.js new file mode 100644 index 0000000..2c1fac4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPermutations.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.permutationsDependencies = void 0; +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const permutationsDependencies = exports.permutationsDependencies = { + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPermutations: _factoriesNumber.createPermutations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPhi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPhi.generated.js new file mode 100644 index 0000000..3c1e7d2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPhi.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.phiDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const phiDependencies = exports.phiDependencies = { + createPhi: _factoriesNumber.createPhi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPi.generated.js new file mode 100644 index 0000000..cc98a69 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPi.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.piDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const piDependencies = exports.piDependencies = { + createPi: _factoriesNumber.createPi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPickRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPickRandom.generated.js new file mode 100644 index 0000000..667e87c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPickRandom.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.pickRandomDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const pickRandomDependencies = exports.pickRandomDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPickRandom: _factoriesNumber.createPickRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPow.generated.js new file mode 100644 index 0000000..6a173d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPow.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.powDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const powDependencies = exports.powDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPow: _factoriesNumber.createPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPrint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPrint.generated.js new file mode 100644 index 0000000..b0916fd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesPrint.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.printDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const printDependencies = exports.printDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createPrint: _factoriesNumber.createPrint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesProd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesProd.generated.js new file mode 100644 index 0000000..4cab317 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesProd.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.prodDependencies = void 0; +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const prodDependencies = exports.prodDependencies = { + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createProd: _factoriesNumber.createProd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js new file mode 100644 index 0000000..a12bee6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js @@ -0,0 +1,37 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.quantileSeqDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesCompareGenerated = require("./dependenciesCompare.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPartitionSelectGenerated = require("./dependenciesPartitionSelect.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const quantileSeqDependencies = exports.quantileSeqDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + compareDependencies: _dependenciesCompareGenerated.compareDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createQuantileSeq: _factoriesNumber.createQuantileSeq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandom.generated.js new file mode 100644 index 0000000..e90d8d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandom.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const randomDependencies = exports.randomDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRandom: _factoriesNumber.createRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandomInt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandomInt.generated.js new file mode 100644 index 0000000..01cccb4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRandomInt.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomIntDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const randomIntDependencies = exports.randomIntDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRandomInt: _factoriesNumber.createRandomInt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRange.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRange.generated.js new file mode 100644 index 0000000..9ce7eb1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRange.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rangeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesLargerEq.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rangeDependencies = exports.rangeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRange: _factoriesNumber.createRange +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeClass.generated.js new file mode 100644 index 0000000..4dd2681 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeClass.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RangeDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RangeDependencies = exports.RangeDependencies = { + createRangeClass: _factoriesNumber.createRangeClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeNode.generated.js new file mode 100644 index 0000000..dcdce30 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RangeNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RangeNodeDependencies = exports.RangeNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createRangeNode: _factoriesNumber.createRangeNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeTransform.generated.js new file mode 100644 index 0000000..43743f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRangeTransform.generated.js @@ -0,0 +1,31 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rangeTransformDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesIsPositiveGenerated = require("./dependenciesIsPositive.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesLargerEqGenerated = require("./dependenciesLargerEq.generated.js"); +var _dependenciesSmallerGenerated = require("./dependenciesSmaller.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rangeTransformDependencies = exports.rangeTransformDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies, + smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRangeTransform: _factoriesNumber.createRangeTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRationalize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRationalize.generated.js new file mode 100644 index 0000000..56eb3aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRationalize.generated.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rationalizeDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSimplifyGenerated = require("./dependenciesSimplify.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesSimplifyCore.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rationalizeDependencies = exports.rationalizeDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies, + simplifyConstantDependencies: _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies, + simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRationalize: _factoriesNumber.createRationalize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRelationalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRelationalNode.generated.js new file mode 100644 index 0000000..729e180 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRelationalNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.RelationalNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const RelationalNodeDependencies = exports.RelationalNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createRelationalNode: _factoriesNumber.createRelationalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReplacer.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReplacer.generated.js new file mode 100644 index 0000000..c091ba7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReplacer.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.replacerDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const replacerDependencies = exports.replacerDependencies = { + createReplacer: _factoriesNumber.createReplacer +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResolve.generated.js new file mode 100644 index 0000000..6f4fd77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResolve.generated.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.resolveDependencies = void 0; +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const resolveDependencies = exports.resolveDependencies = { + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createResolve: _factoriesNumber.createResolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResultSet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResultSet.generated.js new file mode 100644 index 0000000..9e97ede --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesResultSet.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ResultSetDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const ResultSetDependencies = exports.ResultSetDependencies = { + createResultSet: _factoriesNumber.createResultSet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReviver.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReviver.generated.js new file mode 100644 index 0000000..c94c35b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesReviver.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reviverDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const reviverDependencies = exports.reviverDependencies = { + createReviver: _factoriesNumber.createReviver +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightArithShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightArithShift.generated.js new file mode 100644 index 0000000..9dcd16e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightArithShift.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightArithShiftDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rightArithShiftDependencies = exports.rightArithShiftDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRightArithShift: _factoriesNumber.createRightArithShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightLogShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightLogShift.generated.js new file mode 100644 index 0000000..a95962b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRightLogShift.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightLogShiftDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const rightLogShiftDependencies = exports.rightLogShiftDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRightLogShift: _factoriesNumber.createRightLogShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRound.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRound.generated.js new file mode 100644 index 0000000..497ae98 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesRound.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.roundDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const roundDependencies = exports.roundDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createRound: _factoriesNumber.createRound +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js new file mode 100644 index 0000000..129a7ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT1_2Dependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +// eslint-disable-line camelcase + +const SQRT1_2Dependencies = exports.SQRT1_2Dependencies = { + // eslint-disable-line camelcase + createSQRT1_2: _factoriesNumber.createSQRT1_2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT2.generated.js new file mode 100644 index 0000000..a252e5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSQRT2.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT2Dependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SQRT2Dependencies = exports.SQRT2Dependencies = { + createSQRT2: _factoriesNumber.createSQRT2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSec.generated.js new file mode 100644 index 0000000..b616955 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSec.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.secDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const secDependencies = exports.secDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSec: _factoriesNumber.createSec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSech.generated.js new file mode 100644 index 0000000..dcec568 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSech.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sechDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sechDependencies = exports.sechDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSech: _factoriesNumber.createSech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSign.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSign.generated.js new file mode 100644 index 0000000..e0a485d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSign.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.signDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const signDependencies = exports.signDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSign: _factoriesNumber.createSign +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplify.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplify.generated.js new file mode 100644 index 0000000..58a326b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplify.generated.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesResolveGenerated = require("./dependenciesResolve.generated.js"); +var _dependenciesSimplifyConstantGenerated = require("./dependenciesSimplifyConstant.generated.js"); +var _dependenciesSimplifyCoreGenerated = require("./dependenciesSimplifyCore.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyDependencies = exports.simplifyDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + resolveDependencies: _dependenciesResolveGenerated.resolveDependencies, + simplifyConstantDependencies: _dependenciesSimplifyConstantGenerated.simplifyConstantDependencies, + simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplify: _factoriesNumber.createSimplify +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js new file mode 100644 index 0000000..a2c8b51 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js @@ -0,0 +1,35 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyConstantDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyConstantDependencies = exports.simplifyConstantDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplifyConstant: _factoriesNumber.createSimplifyConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js new file mode 100644 index 0000000..da13883 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js @@ -0,0 +1,51 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyCoreDependencies = void 0; +var _dependenciesAccessorNodeGenerated = require("./dependenciesAccessorNode.generated.js"); +var _dependenciesArrayNodeGenerated = require("./dependenciesArrayNode.generated.js"); +var _dependenciesConstantNodeGenerated = require("./dependenciesConstantNode.generated.js"); +var _dependenciesFunctionNodeGenerated = require("./dependenciesFunctionNode.generated.js"); +var _dependenciesIndexNodeGenerated = require("./dependenciesIndexNode.generated.js"); +var _dependenciesObjectNodeGenerated = require("./dependenciesObjectNode.generated.js"); +var _dependenciesOperatorNodeGenerated = require("./dependenciesOperatorNode.generated.js"); +var _dependenciesParenthesisNodeGenerated = require("./dependenciesParenthesisNode.generated.js"); +var _dependenciesSymbolNodeGenerated = require("./dependenciesSymbolNode.generated.js"); +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesIsZeroGenerated = require("./dependenciesIsZero.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesParseGenerated = require("./dependenciesParse.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const simplifyCoreDependencies = exports.simplifyCoreDependencies = { + AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies, + ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies, + ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies, + FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies, + IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies, + ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies, + OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies, + ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies, + SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies, + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + parseDependencies: _dependenciesParseGenerated.parseDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSimplifyCore: _factoriesNumber.createSimplifyCore +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSin.generated.js new file mode 100644 index 0000000..7839170 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSin.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sinDependencies = exports.sinDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSin: _factoriesNumber.createSin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSinh.generated.js new file mode 100644 index 0000000..774f86a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSinh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sinhDependencies = exports.sinhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSinh: _factoriesNumber.createSinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSize.generated.js new file mode 100644 index 0000000..ec34481 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSize.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sizeDependencies = void 0; +var _dependenciesMatrixGenerated = require("./dependenciesMatrix.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sizeDependencies = exports.sizeDependencies = { + matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSize: _factoriesNumber.createSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmaller.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmaller.generated.js new file mode 100644 index 0000000..0638bb8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmaller.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const smallerDependencies = exports.smallerDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSmaller: _factoriesNumber.createSmaller +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmallerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmallerEq.generated.js new file mode 100644 index 0000000..877962a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSmallerEq.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerEqDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const smallerEqDependencies = exports.smallerEqDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSmallerEq: _factoriesNumber.createSmallerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSqrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSqrt.generated.js new file mode 100644 index 0000000..b1cc9d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSqrt.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sqrtDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sqrtDependencies = exports.sqrtDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSqrt: _factoriesNumber.createSqrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSquare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSquare.generated.js new file mode 100644 index 0000000..f9ad8dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSquare.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.squareDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const squareDependencies = exports.squareDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSquare: _factoriesNumber.createSquare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStd.generated.js new file mode 100644 index 0000000..73dff61 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStd.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stdDependencies = void 0; +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesVariance.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stdDependencies = exports.stdDependencies = { + mapDependencies: _dependenciesMapGenerated.mapDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies, + createStd: _factoriesNumber.createStd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStdTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStdTransform.generated.js new file mode 100644 index 0000000..369b1b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStdTransform.generated.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stdTransformDependencies = void 0; +var _dependenciesMapGenerated = require("./dependenciesMap.generated.js"); +var _dependenciesSqrtGenerated = require("./dependenciesSqrt.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _dependenciesVarianceGenerated = require("./dependenciesVariance.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stdTransformDependencies = exports.stdTransformDependencies = { + mapDependencies: _dependenciesMapGenerated.mapDependencies, + sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies, + createStdTransform: _factoriesNumber.createStdTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStirlingS2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStirlingS2.generated.js new file mode 100644 index 0000000..cf455f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesStirlingS2.generated.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stirlingS2Dependencies = void 0; +var _dependenciesAddScalarGenerated = require("./dependenciesAddScalar.generated.js"); +var _dependenciesCombinationsGenerated = require("./dependenciesCombinations.generated.js"); +var _dependenciesDivideScalarGenerated = require("./dependenciesDivideScalar.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesIsIntegerGenerated = require("./dependenciesIsInteger.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesLargerGenerated = require("./dependenciesLarger.generated.js"); +var _dependenciesMultiplyScalarGenerated = require("./dependenciesMultiplyScalar.generated.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSubtractScalarGenerated = require("./dependenciesSubtractScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stirlingS2Dependencies = exports.stirlingS2Dependencies = { + addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies, + combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies, + divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + largerDependencies: _dependenciesLargerGenerated.largerDependencies, + multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies, + numberDependencies: _dependenciesNumberGenerated.numberDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + subtractScalarDependencies: _dependenciesSubtractScalarGenerated.subtractScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createStirlingS2: _factoriesNumber.createStirlingS2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesString.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesString.generated.js new file mode 100644 index 0000000..ef8705a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesString.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stringDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const stringDependencies = exports.stringDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createString: _factoriesNumber.createString +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubset.generated.js new file mode 100644 index 0000000..7673178 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubset.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subsetDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subsetDependencies = exports.subsetDependencies = { + createSubset: _factoriesNumber.createSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js new file mode 100644 index 0000000..1cb79b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subsetTransformDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subsetTransformDependencies = exports.subsetTransformDependencies = { + createSubsetTransform: _factoriesNumber.createSubsetTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtract.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtract.generated.js new file mode 100644 index 0000000..188f60f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtract.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subtractDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subtractDependencies = exports.subtractDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSubtract: _factoriesNumber.createSubtract +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js new file mode 100644 index 0000000..9373c85 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subtractScalarDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const subtractScalarDependencies = exports.subtractScalarDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSubtractScalar: _factoriesNumber.createSubtractScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSum.generated.js new file mode 100644 index 0000000..9b2904b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSum.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sumDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sumDependencies = exports.sumDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSum: _factoriesNumber.createSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSumTransform.generated.js new file mode 100644 index 0000000..ec6215e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSumTransform.generated.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sumTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesNumericGenerated = require("./dependenciesNumeric.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const sumTransformDependencies = exports.sumTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + numericDependencies: _dependenciesNumericGenerated.numericDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createSumTransform: _factoriesNumber.createSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSymbolNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSymbolNode.generated.js new file mode 100644 index 0000000..df354a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesSymbolNode.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SymbolNodeDependencies = void 0; +var _dependenciesNodeGenerated = require("./dependenciesNode.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const SymbolNodeDependencies = exports.SymbolNodeDependencies = { + NodeDependencies: _dependenciesNodeGenerated.NodeDependencies, + createSymbolNode: _factoriesNumber.createSymbolNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTan.generated.js new file mode 100644 index 0000000..8b77910 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTan.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tanDependencies = exports.tanDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTan: _factoriesNumber.createTan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTanh.generated.js new file mode 100644 index 0000000..9e22258 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTanh.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanhDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tanhDependencies = exports.tanhDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTanh: _factoriesNumber.createTanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTau.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTau.generated.js new file mode 100644 index 0000000..aa0458c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTau.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tauDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const tauDependencies = exports.tauDependencies = { + createTau: _factoriesNumber.createTau +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTrue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTrue.generated.js new file mode 100644 index 0000000..53250b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTrue.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.trueDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const trueDependencies = exports.trueDependencies = { + createTrue: _factoriesNumber.createTrue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTypeOf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTypeOf.generated.js new file mode 100644 index 0000000..f354174 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTypeOf.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typeOfDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const typeOfDependencies = exports.typeOfDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createTypeOf: _factoriesNumber.createTypeOf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTyped.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTyped.generated.js new file mode 100644 index 0000000..bf7963e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesTyped.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typedDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const typedDependencies = exports.typedDependencies = { + createTyped: _factoriesNumber.createTyped +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js new file mode 100644 index 0000000..b9c3371 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryMinusDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unaryMinusDependencies = exports.unaryMinusDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnaryMinus: _factoriesNumber.createUnaryMinus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js new file mode 100644 index 0000000..fe5a51c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryPlusDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unaryPlusDependencies = exports.unaryPlusDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnaryPlus: _factoriesNumber.createUnaryPlus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnequal.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnequal.generated.js new file mode 100644 index 0000000..3ec27ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUnequal.generated.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unequalDependencies = void 0; +var _dependenciesEqualScalarGenerated = require("./dependenciesEqualScalar.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const unequalDependencies = exports.unequalDependencies = { + equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createUnequal: _factoriesNumber.createUnequal +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercaseE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercaseE.generated.js new file mode 100644 index 0000000..18d39e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercaseE.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.EDependencies = void 0; +var _dependenciesEGenerated = require("./dependenciesE.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const EDependencies = exports.EDependencies = { + eDependencies: _dependenciesEGenerated.eDependencies, + createUppercaseE: _factoriesNumber.createUppercaseE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercasePi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercasePi.generated.js new file mode 100644 index 0000000..720c460 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesUppercasePi.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.PIDependencies = void 0; +var _dependenciesPiGenerated = require("./dependenciesPi.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const PIDependencies = exports.PIDependencies = { + piDependencies: _dependenciesPiGenerated.piDependencies, + createUppercasePi: _factoriesNumber.createUppercasePi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVariance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVariance.generated.js new file mode 100644 index 0000000..f6642df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVariance.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.varianceDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesApply.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const varianceDependencies = exports.varianceDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + applyDependencies: _dependenciesApplyGenerated.applyDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createVariance: _factoriesNumber.createVariance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js new file mode 100644 index 0000000..3f48b55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.varianceTransformDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesApplyGenerated = require("./dependenciesApply.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesIsNaNGenerated = require("./dependenciesIsNaN.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const varianceTransformDependencies = exports.varianceTransformDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + applyDependencies: _dependenciesApplyGenerated.applyDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createVarianceTransform: _factoriesNumber.createVarianceTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVersion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVersion.generated.js new file mode 100644 index 0000000..aeb1a13 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesVersion.generated.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.versionDependencies = void 0; +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const versionDependencies = exports.versionDependencies = { + createVersion: _factoriesNumber.createVersion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXgcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXgcd.generated.js new file mode 100644 index 0000000..8f457ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXgcd.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xgcdDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const xgcdDependencies = exports.xgcdDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createXgcd: _factoriesNumber.createXgcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXor.generated.js new file mode 100644 index 0000000..2aaaf77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesXor.generated.js @@ -0,0 +1,17 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xorDependencies = void 0; +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const xorDependencies = exports.xorDependencies = { + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createXor: _factoriesNumber.createXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesZeta.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesZeta.generated.js new file mode 100644 index 0000000..e2be460 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/dependenciesNumber/dependenciesZeta.generated.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zetaDependencies = void 0; +var _dependenciesAddGenerated = require("./dependenciesAdd.generated.js"); +var _dependenciesDivideGenerated = require("./dependenciesDivide.generated.js"); +var _dependenciesEqualGenerated = require("./dependenciesEqual.generated.js"); +var _dependenciesFactorialGenerated = require("./dependenciesFactorial.generated.js"); +var _dependenciesGammaGenerated = require("./dependenciesGamma.generated.js"); +var _dependenciesIsNegativeGenerated = require("./dependenciesIsNegative.generated.js"); +var _dependenciesMultiplyGenerated = require("./dependenciesMultiply.generated.js"); +var _dependenciesPiGenerated = require("./dependenciesPi.generated.js"); +var _dependenciesPowGenerated = require("./dependenciesPow.generated.js"); +var _dependenciesSinGenerated = require("./dependenciesSin.generated.js"); +var _dependenciesSmallerEqGenerated = require("./dependenciesSmallerEq.generated.js"); +var _dependenciesSubtractGenerated = require("./dependenciesSubtract.generated.js"); +var _dependenciesTypedGenerated = require("./dependenciesTyped.generated.js"); +var _factoriesNumber = require("../../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const zetaDependencies = exports.zetaDependencies = { + addDependencies: _dependenciesAddGenerated.addDependencies, + divideDependencies: _dependenciesDivideGenerated.divideDependencies, + equalDependencies: _dependenciesEqualGenerated.equalDependencies, + factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies, + gammaDependencies: _dependenciesGammaGenerated.gammaDependencies, + isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies, + multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies, + piDependencies: _dependenciesPiGenerated.piDependencies, + powDependencies: _dependenciesPowGenerated.powDependencies, + sinDependencies: _dependenciesSinGenerated.sinDependencies, + smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies, + subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies, + typedDependencies: _dependenciesTypedGenerated.typedDependencies, + createZeta: _factoriesNumber.createZeta +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsAny.generated.js new file mode 100644 index 0000000..4df8611 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsAny.generated.js @@ -0,0 +1,764 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.derivative = exports.compile = exports.chain = exports.SymbolNode = exports.RelationalNode = exports.RangeNode = exports.Parser = exports.ParenthesisNode = exports.OperatorNode = exports.ObjectNode = exports.Node = exports.IndexNode = exports.Help = exports.FunctionNode = exports.FunctionAssignmentNode = exports.ConstantNode = exports.ConditionalNode = exports.Chain = exports.BlockNode = exports.AssignmentNode = exports.ArrayNode = exports.AccessorNode = void 0; +Object.defineProperty(exports, "docs", { + enumerable: true, + get: function () { + return _embeddedDocs.embeddedDocs; + } +}); +exports.symbolicEqual = exports.simplifyCore = exports.simplifyConstant = exports.simplify = exports.reviver = exports.resolve = exports.rationalize = exports.parser = exports.parse = exports.leafCount = exports.help = exports.evaluate = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _configReadonly = require("./configReadonly.js"); +var _factoriesAny = require("../factoriesAny.js"); +var _pureFunctionsAnyGenerated = require("./pureFunctionsAny.generated.js"); +var _embeddedDocs = require("../expression/embeddedDocs/embeddedDocs.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const math = {}; // NOT pure! +const mathWithTransform = {}; // NOT pure! +const classes = {}; // NOT pure! + +const Node = exports.Node = (0, _factoriesAny.createNode)({ + mathWithTransform +}); +const ObjectNode = exports.ObjectNode = (0, _factoriesAny.createObjectNode)({ + Node +}); +const OperatorNode = exports.OperatorNode = (0, _factoriesAny.createOperatorNode)({ + Node +}); +const ParenthesisNode = exports.ParenthesisNode = (0, _factoriesAny.createParenthesisNode)({ + Node +}); +const RelationalNode = exports.RelationalNode = (0, _factoriesAny.createRelationalNode)({ + Node +}); +const ArrayNode = exports.ArrayNode = (0, _factoriesAny.createArrayNode)({ + Node +}); +const BlockNode = exports.BlockNode = (0, _factoriesAny.createBlockNode)({ + Node, + ResultSet: _pureFunctionsAnyGenerated.ResultSet +}); +const ConditionalNode = exports.ConditionalNode = (0, _factoriesAny.createConditionalNode)({ + Node +}); +const ConstantNode = exports.ConstantNode = (0, _factoriesAny.createConstantNode)({ + Node +}); +const RangeNode = exports.RangeNode = (0, _factoriesAny.createRangeNode)({ + Node +}); +const reviver = exports.reviver = (0, _factoriesAny.createReviver)({ + classes +}); +const Chain = exports.Chain = (0, _factoriesAny.createChainClass)({ + math, + typed: _pureFunctionsAnyGenerated.typed +}); +const FunctionAssignmentNode = exports.FunctionAssignmentNode = (0, _factoriesAny.createFunctionAssignmentNode)({ + Node, + typed: _pureFunctionsAnyGenerated.typed +}); +const chain = exports.chain = (0, _factoriesAny.createChain)({ + Chain, + typed: _pureFunctionsAnyGenerated.typed +}); +const IndexNode = exports.IndexNode = (0, _factoriesAny.createIndexNode)({ + Node, + size: _pureFunctionsAnyGenerated.size +}); +const AccessorNode = exports.AccessorNode = (0, _factoriesAny.createAccessorNode)({ + Node, + subset: _pureFunctionsAnyGenerated.subset +}); +const AssignmentNode = exports.AssignmentNode = (0, _factoriesAny.createAssignmentNode)({ + matrix: _pureFunctionsAnyGenerated.matrix, + Node, + subset: _pureFunctionsAnyGenerated.subset +}); +const SymbolNode = exports.SymbolNode = (0, _factoriesAny.createSymbolNode)({ + Unit: _pureFunctionsAnyGenerated.Unit, + Node, + math +}); +const FunctionNode = exports.FunctionNode = (0, _factoriesAny.createFunctionNode)({ + Node, + SymbolNode, + math +}); +const parse = exports.parse = (0, _factoriesAny.createParse)({ + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode, + config: _configReadonly.config, + numeric: _pureFunctionsAnyGenerated.numeric, + typed: _pureFunctionsAnyGenerated.typed +}); +const resolve = exports.resolve = (0, _factoriesAny.createResolve)({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + parse, + typed: _pureFunctionsAnyGenerated.typed +}); +const simplifyConstant = exports.simplifyConstant = (0, _factoriesAny.createSimplifyConstant)({ + bignumber: _pureFunctionsAnyGenerated.bignumber, + fraction: _pureFunctionsAnyGenerated.fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + config: _configReadonly.config, + mathWithTransform, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed +}); +const compile = exports.compile = (0, _factoriesAny.createCompile)({ + parse, + typed: _pureFunctionsAnyGenerated.typed +}); +const simplifyCore = exports.simplifyCore = (0, _factoriesAny.createSimplifyCore)({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsAnyGenerated.add, + divide: _pureFunctionsAnyGenerated.divide, + equal: _pureFunctionsAnyGenerated.equal, + isZero: _pureFunctionsAnyGenerated.isZero, + multiply: _pureFunctionsAnyGenerated.multiply, + parse, + pow: _pureFunctionsAnyGenerated.pow, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed +}); +const evaluate = exports.evaluate = (0, _factoriesAny.createEvaluate)({ + parse, + typed: _pureFunctionsAnyGenerated.typed +}); +const Help = exports.Help = (0, _factoriesAny.createHelpClass)({ + evaluate +}); +const Parser = exports.Parser = (0, _factoriesAny.createParserClass)({ + evaluate +}); +const simplify = exports.simplify = (0, _factoriesAny.createSimplify)({ + bignumber: _pureFunctionsAnyGenerated.bignumber, + fraction: _pureFunctionsAnyGenerated.fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsAnyGenerated.add, + config: _configReadonly.config, + divide: _pureFunctionsAnyGenerated.divide, + equal: _pureFunctionsAnyGenerated.equal, + isZero: _pureFunctionsAnyGenerated.isZero, + mathWithTransform, + matrix: _pureFunctionsAnyGenerated.matrix, + multiply: _pureFunctionsAnyGenerated.multiply, + parse, + pow: _pureFunctionsAnyGenerated.pow, + resolve, + simplifyConstant, + simplifyCore, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed +}); +const symbolicEqual = exports.symbolicEqual = (0, _factoriesAny.createSymbolicEqual)({ + OperatorNode, + parse, + simplify, + typed: _pureFunctionsAnyGenerated.typed +}); +const leafCount = exports.leafCount = (0, _factoriesAny.createLeafCount)({ + parse, + typed: _pureFunctionsAnyGenerated.typed +}); +const parser = exports.parser = (0, _factoriesAny.createParser)({ + Parser, + typed: _pureFunctionsAnyGenerated.typed +}); +const rationalize = exports.rationalize = (0, _factoriesAny.createRationalize)({ + bignumber: _pureFunctionsAnyGenerated.bignumber, + fraction: _pureFunctionsAnyGenerated.fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsAnyGenerated.add, + config: _configReadonly.config, + divide: _pureFunctionsAnyGenerated.divide, + equal: _pureFunctionsAnyGenerated.equal, + isZero: _pureFunctionsAnyGenerated.isZero, + mathWithTransform, + matrix: _pureFunctionsAnyGenerated.matrix, + multiply: _pureFunctionsAnyGenerated.multiply, + parse, + pow: _pureFunctionsAnyGenerated.pow, + simplify, + simplifyConstant, + simplifyCore, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed +}); +const derivative = exports.derivative = (0, _factoriesAny.createDerivative)({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + config: _configReadonly.config, + equal: _pureFunctionsAnyGenerated.equal, + isZero: _pureFunctionsAnyGenerated.isZero, + numeric: _pureFunctionsAnyGenerated.numeric, + parse, + simplify, + typed: _pureFunctionsAnyGenerated.typed +}); +const help = exports.help = (0, _factoriesAny.createHelp)({ + Help, + mathWithTransform, + typed: _pureFunctionsAnyGenerated.typed +}); +(0, _extends2.default)(math, { + e: _pureFunctionsAnyGenerated.e, + false: _pureFunctionsAnyGenerated._false, + fineStructure: _pureFunctionsAnyGenerated.fineStructure, + i: _pureFunctionsAnyGenerated.i, + Infinity: _pureFunctionsAnyGenerated._Infinity, + LN10: _pureFunctionsAnyGenerated.LN10, + LOG10E: _pureFunctionsAnyGenerated.LOG10E, + NaN: _pureFunctionsAnyGenerated._NaN, + null: _pureFunctionsAnyGenerated._null, + phi: _pureFunctionsAnyGenerated.phi, + SQRT1_2: _pureFunctionsAnyGenerated.SQRT1_2, + sackurTetrode: _pureFunctionsAnyGenerated.sackurTetrode, + tau: _pureFunctionsAnyGenerated.tau, + true: _pureFunctionsAnyGenerated._true, + 'E': _pureFunctionsAnyGenerated.e, + version: _pureFunctionsAnyGenerated.version, + efimovFactor: _pureFunctionsAnyGenerated.efimovFactor, + LN2: _pureFunctionsAnyGenerated.LN2, + pi: _pureFunctionsAnyGenerated.pi, + replacer: _pureFunctionsAnyGenerated.replacer, + reviver, + SQRT2: _pureFunctionsAnyGenerated.SQRT2, + typed: _pureFunctionsAnyGenerated.typed, + 'PI': _pureFunctionsAnyGenerated.pi, + weakMixingAngle: _pureFunctionsAnyGenerated.weakMixingAngle, + abs: _pureFunctionsAnyGenerated.abs, + acos: _pureFunctionsAnyGenerated.acos, + acot: _pureFunctionsAnyGenerated.acot, + acsc: _pureFunctionsAnyGenerated.acsc, + addScalar: _pureFunctionsAnyGenerated.addScalar, + arg: _pureFunctionsAnyGenerated.arg, + asech: _pureFunctionsAnyGenerated.asech, + asinh: _pureFunctionsAnyGenerated.asinh, + atan: _pureFunctionsAnyGenerated.atan, + atanh: _pureFunctionsAnyGenerated.atanh, + bigint: _pureFunctionsAnyGenerated.bigint, + bitNot: _pureFunctionsAnyGenerated.bitNot, + boolean: _pureFunctionsAnyGenerated.boolean, + clone: _pureFunctionsAnyGenerated.clone, + combinations: _pureFunctionsAnyGenerated.combinations, + complex: _pureFunctionsAnyGenerated.complex, + conj: _pureFunctionsAnyGenerated.conj, + cos: _pureFunctionsAnyGenerated.cos, + cot: _pureFunctionsAnyGenerated.cot, + csc: _pureFunctionsAnyGenerated.csc, + cube: _pureFunctionsAnyGenerated.cube, + equalScalar: _pureFunctionsAnyGenerated.equalScalar, + erf: _pureFunctionsAnyGenerated.erf, + exp: _pureFunctionsAnyGenerated.exp, + expm1: _pureFunctionsAnyGenerated.expm1, + filter: _pureFunctionsAnyGenerated.filter, + flatten: _pureFunctionsAnyGenerated.flatten, + forEach: _pureFunctionsAnyGenerated.forEach, + format: _pureFunctionsAnyGenerated.format, + getMatrixDataType: _pureFunctionsAnyGenerated.getMatrixDataType, + hex: _pureFunctionsAnyGenerated.hex, + im: _pureFunctionsAnyGenerated.im, + isInteger: _pureFunctionsAnyGenerated.isInteger, + isNegative: _pureFunctionsAnyGenerated.isNegative, + isPositive: _pureFunctionsAnyGenerated.isPositive, + isZero: _pureFunctionsAnyGenerated.isZero, + LOG2E: _pureFunctionsAnyGenerated.LOG2E, + lgamma: _pureFunctionsAnyGenerated.lgamma, + log10: _pureFunctionsAnyGenerated.log10, + log2: _pureFunctionsAnyGenerated.log2, + map: _pureFunctionsAnyGenerated.map, + multiplyScalar: _pureFunctionsAnyGenerated.multiplyScalar, + not: _pureFunctionsAnyGenerated.not, + number: _pureFunctionsAnyGenerated.number, + oct: _pureFunctionsAnyGenerated.oct, + pickRandom: _pureFunctionsAnyGenerated.pickRandom, + print: _pureFunctionsAnyGenerated.print, + random: _pureFunctionsAnyGenerated.random, + re: _pureFunctionsAnyGenerated.re, + sec: _pureFunctionsAnyGenerated.sec, + sign: _pureFunctionsAnyGenerated.sign, + sin: _pureFunctionsAnyGenerated.sin, + splitUnit: _pureFunctionsAnyGenerated.splitUnit, + square: _pureFunctionsAnyGenerated.square, + string: _pureFunctionsAnyGenerated.string, + subtractScalar: _pureFunctionsAnyGenerated.subtractScalar, + tan: _pureFunctionsAnyGenerated.tan, + typeOf: _pureFunctionsAnyGenerated.typeOf, + acosh: _pureFunctionsAnyGenerated.acosh, + acsch: _pureFunctionsAnyGenerated.acsch, + apply: _pureFunctionsAnyGenerated.apply, + asec: _pureFunctionsAnyGenerated.asec, + bignumber: _pureFunctionsAnyGenerated.bignumber, + chain, + combinationsWithRep: _pureFunctionsAnyGenerated.combinationsWithRep, + cosh: _pureFunctionsAnyGenerated.cosh, + csch: _pureFunctionsAnyGenerated.csch, + isNaN: _pureFunctionsAnyGenerated.isNaN, + isPrime: _pureFunctionsAnyGenerated.isPrime, + randomInt: _pureFunctionsAnyGenerated.randomInt, + sech: _pureFunctionsAnyGenerated.sech, + sinh: _pureFunctionsAnyGenerated.sinh, + sparse: _pureFunctionsAnyGenerated.sparse, + sqrt: _pureFunctionsAnyGenerated.sqrt, + squeeze: _pureFunctionsAnyGenerated.squeeze, + tanh: _pureFunctionsAnyGenerated.tanh, + unaryMinus: _pureFunctionsAnyGenerated.unaryMinus, + acoth: _pureFunctionsAnyGenerated.acoth, + bin: _pureFunctionsAnyGenerated.bin, + coth: _pureFunctionsAnyGenerated.coth, + fraction: _pureFunctionsAnyGenerated.fraction, + isNumeric: _pureFunctionsAnyGenerated.isNumeric, + matrix: _pureFunctionsAnyGenerated.matrix, + matrixFromFunction: _pureFunctionsAnyGenerated.matrixFromFunction, + mode: _pureFunctionsAnyGenerated.mode, + numeric: _pureFunctionsAnyGenerated.numeric, + prod: _pureFunctionsAnyGenerated.prod, + reshape: _pureFunctionsAnyGenerated.reshape, + size: _pureFunctionsAnyGenerated.size, + transpose: _pureFunctionsAnyGenerated.transpose, + xgcd: _pureFunctionsAnyGenerated.xgcd, + zeros: _pureFunctionsAnyGenerated.zeros, + asin: _pureFunctionsAnyGenerated.asin, + cbrt: _pureFunctionsAnyGenerated.cbrt, + concat: _pureFunctionsAnyGenerated.concat, + count: _pureFunctionsAnyGenerated.count, + ctranspose: _pureFunctionsAnyGenerated.ctranspose, + diag: _pureFunctionsAnyGenerated.diag, + divideScalar: _pureFunctionsAnyGenerated.divideScalar, + dotDivide: _pureFunctionsAnyGenerated.dotDivide, + equal: _pureFunctionsAnyGenerated.equal, + hasNumericValue: _pureFunctionsAnyGenerated.hasNumericValue, + identity: _pureFunctionsAnyGenerated.identity, + kron: _pureFunctionsAnyGenerated.kron, + largerEq: _pureFunctionsAnyGenerated.largerEq, + leftShift: _pureFunctionsAnyGenerated.leftShift, + lsolve: _pureFunctionsAnyGenerated.lsolve, + matrixFromColumns: _pureFunctionsAnyGenerated.matrixFromColumns, + nthRoot: _pureFunctionsAnyGenerated.nthRoot, + ones: _pureFunctionsAnyGenerated.ones, + qr: _pureFunctionsAnyGenerated.qr, + resize: _pureFunctionsAnyGenerated.resize, + rightArithShift: _pureFunctionsAnyGenerated.rightArithShift, + round: _pureFunctionsAnyGenerated.round, + smaller: _pureFunctionsAnyGenerated.smaller, + subtract: _pureFunctionsAnyGenerated.subtract, + to: _pureFunctionsAnyGenerated.to, + unaryPlus: _pureFunctionsAnyGenerated.unaryPlus, + usolve: _pureFunctionsAnyGenerated.usolve, + xor: _pureFunctionsAnyGenerated.xor, + add: _pureFunctionsAnyGenerated.add, + atan2: _pureFunctionsAnyGenerated.atan2, + bitAnd: _pureFunctionsAnyGenerated.bitAnd, + bitOr: _pureFunctionsAnyGenerated.bitOr, + bitXor: _pureFunctionsAnyGenerated.bitXor, + catalan: _pureFunctionsAnyGenerated.catalan, + compare: _pureFunctionsAnyGenerated.compare, + compareText: _pureFunctionsAnyGenerated.compareText, + cumsum: _pureFunctionsAnyGenerated.cumsum, + deepEqual: _pureFunctionsAnyGenerated.deepEqual, + diff: _pureFunctionsAnyGenerated.diff, + distance: _pureFunctionsAnyGenerated.distance, + dot: _pureFunctionsAnyGenerated.dot, + equalText: _pureFunctionsAnyGenerated.equalText, + floor: _pureFunctionsAnyGenerated.floor, + gcd: _pureFunctionsAnyGenerated.gcd, + hypot: _pureFunctionsAnyGenerated.hypot, + larger: _pureFunctionsAnyGenerated.larger, + log: _pureFunctionsAnyGenerated.log, + lsolveAll: _pureFunctionsAnyGenerated.lsolveAll, + matrixFromRows: _pureFunctionsAnyGenerated.matrixFromRows, + min: _pureFunctionsAnyGenerated.min, + mod: _pureFunctionsAnyGenerated.mod, + multiply: _pureFunctionsAnyGenerated.multiply, + nthRoots: _pureFunctionsAnyGenerated.nthRoots, + or: _pureFunctionsAnyGenerated.or, + partitionSelect: _pureFunctionsAnyGenerated.partitionSelect, + rightLogShift: _pureFunctionsAnyGenerated.rightLogShift, + slu: _pureFunctionsAnyGenerated.slu, + subset: _pureFunctionsAnyGenerated.subset, + sum: _pureFunctionsAnyGenerated.sum, + trace: _pureFunctionsAnyGenerated.trace, + usolveAll: _pureFunctionsAnyGenerated.usolveAll, + zpk2tf: _pureFunctionsAnyGenerated.zpk2tf, + ceil: _pureFunctionsAnyGenerated.ceil, + compareNatural: _pureFunctionsAnyGenerated.compareNatural, + composition: _pureFunctionsAnyGenerated.composition, + cross: _pureFunctionsAnyGenerated.cross, + det: _pureFunctionsAnyGenerated.det, + dotMultiply: _pureFunctionsAnyGenerated.dotMultiply, + fix: _pureFunctionsAnyGenerated.fix, + index: _pureFunctionsAnyGenerated.index, + intersect: _pureFunctionsAnyGenerated.intersect, + invmod: _pureFunctionsAnyGenerated.invmod, + lcm: _pureFunctionsAnyGenerated.lcm, + log1p: _pureFunctionsAnyGenerated.log1p, + max: _pureFunctionsAnyGenerated.max, + setCartesian: _pureFunctionsAnyGenerated.setCartesian, + setDistinct: _pureFunctionsAnyGenerated.setDistinct, + setIsSubset: _pureFunctionsAnyGenerated.setIsSubset, + setPowerset: _pureFunctionsAnyGenerated.setPowerset, + smallerEq: _pureFunctionsAnyGenerated.smallerEq, + sort: _pureFunctionsAnyGenerated.sort, + unequal: _pureFunctionsAnyGenerated.unequal, + and: _pureFunctionsAnyGenerated.and, + range: _pureFunctionsAnyGenerated.range, + row: _pureFunctionsAnyGenerated.row, + setDifference: _pureFunctionsAnyGenerated.setDifference, + setMultiplicity: _pureFunctionsAnyGenerated.setMultiplicity, + setSymDifference: _pureFunctionsAnyGenerated.setSymDifference, + column: _pureFunctionsAnyGenerated.column, + inv: _pureFunctionsAnyGenerated.inv, + lup: _pureFunctionsAnyGenerated.lup, + pinv: _pureFunctionsAnyGenerated.pinv, + pow: _pureFunctionsAnyGenerated.pow, + setIntersect: _pureFunctionsAnyGenerated.setIntersect, + setUnion: _pureFunctionsAnyGenerated.setUnion, + sqrtm: _pureFunctionsAnyGenerated.sqrtm, + vacuumImpedance: _pureFunctionsAnyGenerated.vacuumImpedance, + wienDisplacement: _pureFunctionsAnyGenerated.wienDisplacement, + atomicMass: _pureFunctionsAnyGenerated.atomicMass, + bohrMagneton: _pureFunctionsAnyGenerated.bohrMagneton, + boltzmann: _pureFunctionsAnyGenerated.boltzmann, + conductanceQuantum: _pureFunctionsAnyGenerated.conductanceQuantum, + coulomb: _pureFunctionsAnyGenerated.coulomb, + deuteronMass: _pureFunctionsAnyGenerated.deuteronMass, + dotPow: _pureFunctionsAnyGenerated.dotPow, + electricConstant: _pureFunctionsAnyGenerated.electricConstant, + elementaryCharge: _pureFunctionsAnyGenerated.elementaryCharge, + expm: _pureFunctionsAnyGenerated.expm, + faraday: _pureFunctionsAnyGenerated.faraday, + fft: _pureFunctionsAnyGenerated.fft, + gamma: _pureFunctionsAnyGenerated.gamma, + gravitationConstant: _pureFunctionsAnyGenerated.gravitationConstant, + hartreeEnergy: _pureFunctionsAnyGenerated.hartreeEnergy, + ifft: _pureFunctionsAnyGenerated.ifft, + klitzing: _pureFunctionsAnyGenerated.klitzing, + loschmidt: _pureFunctionsAnyGenerated.loschmidt, + magneticConstant: _pureFunctionsAnyGenerated.magneticConstant, + molarMass: _pureFunctionsAnyGenerated.molarMass, + molarPlanckConstant: _pureFunctionsAnyGenerated.molarPlanckConstant, + neutronMass: _pureFunctionsAnyGenerated.neutronMass, + nuclearMagneton: _pureFunctionsAnyGenerated.nuclearMagneton, + planckCharge: _pureFunctionsAnyGenerated.planckCharge, + planckLength: _pureFunctionsAnyGenerated.planckLength, + planckTemperature: _pureFunctionsAnyGenerated.planckTemperature, + protonMass: _pureFunctionsAnyGenerated.protonMass, + quantumOfCirculation: _pureFunctionsAnyGenerated.quantumOfCirculation, + reducedPlanckConstant: _pureFunctionsAnyGenerated.reducedPlanckConstant, + rydberg: _pureFunctionsAnyGenerated.rydberg, + secondRadiation: _pureFunctionsAnyGenerated.secondRadiation, + speedOfLight: _pureFunctionsAnyGenerated.speedOfLight, + stefanBoltzmann: _pureFunctionsAnyGenerated.stefanBoltzmann, + thomsonCrossSection: _pureFunctionsAnyGenerated.thomsonCrossSection, + avogadro: _pureFunctionsAnyGenerated.avogadro, + bohrRadius: _pureFunctionsAnyGenerated.bohrRadius, + createUnit: _pureFunctionsAnyGenerated.createUnit, + divide: _pureFunctionsAnyGenerated.divide, + electronMass: _pureFunctionsAnyGenerated.electronMass, + factorial: _pureFunctionsAnyGenerated.factorial, + firstRadiation: _pureFunctionsAnyGenerated.firstRadiation, + gravity: _pureFunctionsAnyGenerated.gravity, + inverseConductanceQuantum: _pureFunctionsAnyGenerated.inverseConductanceQuantum, + lusolve: _pureFunctionsAnyGenerated.lusolve, + magneticFluxQuantum: _pureFunctionsAnyGenerated.magneticFluxQuantum, + molarMassC12: _pureFunctionsAnyGenerated.molarMassC12, + multinomial: _pureFunctionsAnyGenerated.multinomial, + parse, + permutations: _pureFunctionsAnyGenerated.permutations, + planckMass: _pureFunctionsAnyGenerated.planckMass, + polynomialRoot: _pureFunctionsAnyGenerated.polynomialRoot, + resolve, + setSize: _pureFunctionsAnyGenerated.setSize, + simplifyConstant, + solveODE: _pureFunctionsAnyGenerated.solveODE, + stirlingS2: _pureFunctionsAnyGenerated.stirlingS2, + unit: _pureFunctionsAnyGenerated.unit, + bellNumbers: _pureFunctionsAnyGenerated.bellNumbers, + compile, + eigs: _pureFunctionsAnyGenerated.eigs, + fermiCoupling: _pureFunctionsAnyGenerated.fermiCoupling, + gasConstant: _pureFunctionsAnyGenerated.gasConstant, + kldivergence: _pureFunctionsAnyGenerated.kldivergence, + mean: _pureFunctionsAnyGenerated.mean, + molarVolume: _pureFunctionsAnyGenerated.molarVolume, + planckConstant: _pureFunctionsAnyGenerated.planckConstant, + quantileSeq: _pureFunctionsAnyGenerated.quantileSeq, + simplifyCore, + variance: _pureFunctionsAnyGenerated.variance, + classicalElectronRadius: _pureFunctionsAnyGenerated.classicalElectronRadius, + evaluate, + median: _pureFunctionsAnyGenerated.median, + simplify, + symbolicEqual, + corr: _pureFunctionsAnyGenerated.corr, + freqz: _pureFunctionsAnyGenerated.freqz, + leafCount, + mad: _pureFunctionsAnyGenerated.mad, + parser, + rationalize, + std: _pureFunctionsAnyGenerated.std, + zeta: _pureFunctionsAnyGenerated.zeta, + derivative, + norm: _pureFunctionsAnyGenerated.norm, + rotationMatrix: _pureFunctionsAnyGenerated.rotationMatrix, + help, + planckTime: _pureFunctionsAnyGenerated.planckTime, + schur: _pureFunctionsAnyGenerated.schur, + rotate: _pureFunctionsAnyGenerated.rotate, + sylvester: _pureFunctionsAnyGenerated.sylvester, + lyap: _pureFunctionsAnyGenerated.lyap, + config: _configReadonly.config +}); +(0, _extends2.default)(mathWithTransform, math, { + filter: (0, _factoriesAny.createFilterTransform)({ + typed: _pureFunctionsAnyGenerated.typed + }), + forEach: (0, _factoriesAny.createForEachTransform)({ + typed: _pureFunctionsAnyGenerated.typed + }), + map: (0, _factoriesAny.createMapTransform)({ + typed: _pureFunctionsAnyGenerated.typed + }), + apply: (0, _factoriesAny.createApplyTransform)({ + isInteger: _pureFunctionsAnyGenerated.isInteger, + typed: _pureFunctionsAnyGenerated.typed + }), + or: (0, _factoriesAny.createOrTransform)({ + DenseMatrix: _pureFunctionsAnyGenerated.DenseMatrix, + concat: _pureFunctionsAnyGenerated.concat, + equalScalar: _pureFunctionsAnyGenerated.equalScalar, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed + }), + and: (0, _factoriesAny.createAndTransform)({ + add: _pureFunctionsAnyGenerated.add, + concat: _pureFunctionsAnyGenerated.concat, + equalScalar: _pureFunctionsAnyGenerated.equalScalar, + matrix: _pureFunctionsAnyGenerated.matrix, + not: _pureFunctionsAnyGenerated.not, + typed: _pureFunctionsAnyGenerated.typed, + zeros: _pureFunctionsAnyGenerated.zeros + }), + concat: (0, _factoriesAny.createConcatTransform)({ + isInteger: _pureFunctionsAnyGenerated.isInteger, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed + }), + max: (0, _factoriesAny.createMaxTransform)({ + config: _configReadonly.config, + larger: _pureFunctionsAnyGenerated.larger, + numeric: _pureFunctionsAnyGenerated.numeric, + typed: _pureFunctionsAnyGenerated.typed + }), + print: (0, _factoriesAny.createPrintTransform)({ + add: _pureFunctionsAnyGenerated.add, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed, + zeros: _pureFunctionsAnyGenerated.zeros + }), + bitAnd: (0, _factoriesAny.createBitAndTransform)({ + add: _pureFunctionsAnyGenerated.add, + concat: _pureFunctionsAnyGenerated.concat, + equalScalar: _pureFunctionsAnyGenerated.equalScalar, + matrix: _pureFunctionsAnyGenerated.matrix, + not: _pureFunctionsAnyGenerated.not, + typed: _pureFunctionsAnyGenerated.typed, + zeros: _pureFunctionsAnyGenerated.zeros + }), + diff: (0, _factoriesAny.createDiffTransform)({ + bignumber: _pureFunctionsAnyGenerated.bignumber, + matrix: _pureFunctionsAnyGenerated.matrix, + number: _pureFunctionsAnyGenerated.number, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed + }), + min: (0, _factoriesAny.createMinTransform)({ + config: _configReadonly.config, + numeric: _pureFunctionsAnyGenerated.numeric, + smaller: _pureFunctionsAnyGenerated.smaller, + typed: _pureFunctionsAnyGenerated.typed + }), + subset: (0, _factoriesAny.createSubsetTransform)({ + add: _pureFunctionsAnyGenerated.add, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed, + zeros: _pureFunctionsAnyGenerated.zeros + }), + bitOr: (0, _factoriesAny.createBitOrTransform)({ + DenseMatrix: _pureFunctionsAnyGenerated.DenseMatrix, + concat: _pureFunctionsAnyGenerated.concat, + equalScalar: _pureFunctionsAnyGenerated.equalScalar, + matrix: _pureFunctionsAnyGenerated.matrix, + typed: _pureFunctionsAnyGenerated.typed + }), + cumsum: (0, _factoriesAny.createCumSumTransform)({ + add: _pureFunctionsAnyGenerated.add, + typed: _pureFunctionsAnyGenerated.typed, + unaryPlus: _pureFunctionsAnyGenerated.unaryPlus + }), + index: (0, _factoriesAny.createIndexTransform)({ + Index: _pureFunctionsAnyGenerated.Index, + getMatrixDataType: _pureFunctionsAnyGenerated.getMatrixDataType + }), + sum: (0, _factoriesAny.createSumTransform)({ + add: _pureFunctionsAnyGenerated.add, + config: _configReadonly.config, + numeric: _pureFunctionsAnyGenerated.numeric, + typed: _pureFunctionsAnyGenerated.typed + }), + range: (0, _factoriesAny.createRangeTransform)({ + bignumber: _pureFunctionsAnyGenerated.bignumber, + matrix: _pureFunctionsAnyGenerated.matrix, + add: _pureFunctionsAnyGenerated.add, + config: _configReadonly.config, + isPositive: _pureFunctionsAnyGenerated.isPositive, + larger: _pureFunctionsAnyGenerated.larger, + largerEq: _pureFunctionsAnyGenerated.largerEq, + smaller: _pureFunctionsAnyGenerated.smaller, + smallerEq: _pureFunctionsAnyGenerated.smallerEq, + typed: _pureFunctionsAnyGenerated.typed + }), + row: (0, _factoriesAny.createRowTransform)({ + Index: _pureFunctionsAnyGenerated.Index, + matrix: _pureFunctionsAnyGenerated.matrix, + range: _pureFunctionsAnyGenerated.range, + typed: _pureFunctionsAnyGenerated.typed + }), + column: (0, _factoriesAny.createColumnTransform)({ + Index: _pureFunctionsAnyGenerated.Index, + matrix: _pureFunctionsAnyGenerated.matrix, + range: _pureFunctionsAnyGenerated.range, + typed: _pureFunctionsAnyGenerated.typed + }), + mean: (0, _factoriesAny.createMeanTransform)({ + add: _pureFunctionsAnyGenerated.add, + divide: _pureFunctionsAnyGenerated.divide, + typed: _pureFunctionsAnyGenerated.typed + }), + quantileSeq: (0, _factoriesAny.createQuantileSeqTransform)({ + add: _pureFunctionsAnyGenerated.add, + bignumber: _pureFunctionsAnyGenerated.bignumber, + compare: _pureFunctionsAnyGenerated.compare, + divide: _pureFunctionsAnyGenerated.divide, + isInteger: _pureFunctionsAnyGenerated.isInteger, + larger: _pureFunctionsAnyGenerated.larger, + multiply: _pureFunctionsAnyGenerated.multiply, + partitionSelect: _pureFunctionsAnyGenerated.partitionSelect, + smaller: _pureFunctionsAnyGenerated.smaller, + smallerEq: _pureFunctionsAnyGenerated.smallerEq, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed + }), + variance: (0, _factoriesAny.createVarianceTransform)({ + add: _pureFunctionsAnyGenerated.add, + apply: _pureFunctionsAnyGenerated.apply, + divide: _pureFunctionsAnyGenerated.divide, + isNaN: _pureFunctionsAnyGenerated.isNaN, + multiply: _pureFunctionsAnyGenerated.multiply, + subtract: _pureFunctionsAnyGenerated.subtract, + typed: _pureFunctionsAnyGenerated.typed + }), + std: (0, _factoriesAny.createStdTransform)({ + map: _pureFunctionsAnyGenerated.map, + sqrt: _pureFunctionsAnyGenerated.sqrt, + typed: _pureFunctionsAnyGenerated.typed, + variance: _pureFunctionsAnyGenerated.variance + }) +}); +(0, _extends2.default)(classes, { + BigNumber: _pureFunctionsAnyGenerated.BigNumber, + Complex: _pureFunctionsAnyGenerated.Complex, + Fraction: _pureFunctionsAnyGenerated.Fraction, + Matrix: _pureFunctionsAnyGenerated.Matrix, + Node, + ObjectNode, + OperatorNode, + ParenthesisNode, + Range: _pureFunctionsAnyGenerated.Range, + RelationalNode, + ResultSet: _pureFunctionsAnyGenerated.ResultSet, + ArrayNode, + BlockNode, + ConditionalNode, + ConstantNode, + DenseMatrix: _pureFunctionsAnyGenerated.DenseMatrix, + RangeNode, + Chain, + FunctionAssignmentNode, + SparseMatrix: _pureFunctionsAnyGenerated.SparseMatrix, + IndexNode, + ImmutableDenseMatrix: _pureFunctionsAnyGenerated.ImmutableDenseMatrix, + Index: _pureFunctionsAnyGenerated.Index, + AccessorNode, + AssignmentNode, + FibonacciHeap: _pureFunctionsAnyGenerated.FibonacciHeap, + Spa: _pureFunctionsAnyGenerated.Spa, + Unit: _pureFunctionsAnyGenerated.Unit, + SymbolNode, + FunctionNode, + Help, + Parser +}); +Chain.createProxy(math); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsNumber.generated.js new file mode 100644 index 0000000..6b687c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/impureFunctionsNumber.generated.js @@ -0,0 +1,515 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.derivative = exports.compile = exports.chain = exports.SymbolNode = exports.RelationalNode = exports.RangeNode = exports.Parser = exports.ParenthesisNode = exports.OperatorNode = exports.ObjectNode = exports.Node = exports.IndexNode = exports.Help = exports.FunctionNode = exports.FunctionAssignmentNode = exports.ConstantNode = exports.ConditionalNode = exports.Chain = exports.BlockNode = exports.AssignmentNode = exports.ArrayNode = exports.AccessorNode = void 0; +Object.defineProperty(exports, "docs", { + enumerable: true, + get: function () { + return _embeddedDocs.embeddedDocs; + } +}); +exports.simplifyCore = exports.simplifyConstant = exports.simplify = exports.reviver = exports.resolve = exports.rationalize = exports.parser = exports.parse = exports.help = exports.evaluate = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _configReadonly = require("./configReadonly.js"); +var _factoriesNumber = require("../factoriesNumber.js"); +var _pureFunctionsNumberGenerated = require("./pureFunctionsNumber.generated.js"); +var _embeddedDocs = require("../expression/embeddedDocs/embeddedDocs.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const math = {}; // NOT pure! +const mathWithTransform = {}; // NOT pure! +const classes = {}; // NOT pure! + +const Chain = exports.Chain = (0, _factoriesNumber.createChainClass)({ + math, + typed: _pureFunctionsNumberGenerated.typed +}); +const Node = exports.Node = (0, _factoriesNumber.createNode)({ + mathWithTransform +}); +const ObjectNode = exports.ObjectNode = (0, _factoriesNumber.createObjectNode)({ + Node +}); +const RangeNode = exports.RangeNode = (0, _factoriesNumber.createRangeNode)({ + Node +}); +const RelationalNode = exports.RelationalNode = (0, _factoriesNumber.createRelationalNode)({ + Node +}); +const reviver = exports.reviver = (0, _factoriesNumber.createReviver)({ + classes +}); +const SymbolNode = exports.SymbolNode = (0, _factoriesNumber.createSymbolNode)({ + Node, + math +}); +const AccessorNode = exports.AccessorNode = (0, _factoriesNumber.createAccessorNode)({ + Node, + subset: _pureFunctionsNumberGenerated.subset +}); +const AssignmentNode = exports.AssignmentNode = (0, _factoriesNumber.createAssignmentNode)({ + matrix: _pureFunctionsNumberGenerated.matrix, + Node, + subset: _pureFunctionsNumberGenerated.subset +}); +const BlockNode = exports.BlockNode = (0, _factoriesNumber.createBlockNode)({ + Node, + ResultSet: _pureFunctionsNumberGenerated.ResultSet +}); +const chain = exports.chain = (0, _factoriesNumber.createChain)({ + Chain, + typed: _pureFunctionsNumberGenerated.typed +}); +const ConditionalNode = exports.ConditionalNode = (0, _factoriesNumber.createConditionalNode)({ + Node +}); +const FunctionNode = exports.FunctionNode = (0, _factoriesNumber.createFunctionNode)({ + Node, + SymbolNode, + math +}); +const IndexNode = exports.IndexNode = (0, _factoriesNumber.createIndexNode)({ + Node, + size: _pureFunctionsNumberGenerated.size +}); +const OperatorNode = exports.OperatorNode = (0, _factoriesNumber.createOperatorNode)({ + Node +}); +const ConstantNode = exports.ConstantNode = (0, _factoriesNumber.createConstantNode)({ + Node +}); +const FunctionAssignmentNode = exports.FunctionAssignmentNode = (0, _factoriesNumber.createFunctionAssignmentNode)({ + Node, + typed: _pureFunctionsNumberGenerated.typed +}); +const ParenthesisNode = exports.ParenthesisNode = (0, _factoriesNumber.createParenthesisNode)({ + Node +}); +const ArrayNode = exports.ArrayNode = (0, _factoriesNumber.createArrayNode)({ + Node +}); +const simplifyConstant = exports.simplifyConstant = (0, _factoriesNumber.createSimplifyConstant)({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + config: _configReadonly.config, + mathWithTransform, + matrix: _pureFunctionsNumberGenerated.matrix, + typed: _pureFunctionsNumberGenerated.typed +}); +const parse = exports.parse = (0, _factoriesNumber.createParse)({ + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode, + config: _configReadonly.config, + numeric: _pureFunctionsNumberGenerated.numeric, + typed: _pureFunctionsNumberGenerated.typed +}); +const resolve = exports.resolve = (0, _factoriesNumber.createResolve)({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + parse, + typed: _pureFunctionsNumberGenerated.typed +}); +const simplifyCore = exports.simplifyCore = (0, _factoriesNumber.createSimplifyCore)({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsNumberGenerated.add, + divide: _pureFunctionsNumberGenerated.divide, + equal: _pureFunctionsNumberGenerated.equal, + isZero: _pureFunctionsNumberGenerated.isZero, + multiply: _pureFunctionsNumberGenerated.multiply, + parse, + pow: _pureFunctionsNumberGenerated.pow, + subtract: _pureFunctionsNumberGenerated.subtract, + typed: _pureFunctionsNumberGenerated.typed +}); +const compile = exports.compile = (0, _factoriesNumber.createCompile)({ + parse, + typed: _pureFunctionsNumberGenerated.typed +}); +const evaluate = exports.evaluate = (0, _factoriesNumber.createEvaluate)({ + parse, + typed: _pureFunctionsNumberGenerated.typed +}); +const Help = exports.Help = (0, _factoriesNumber.createHelpClass)({ + evaluate +}); +const Parser = exports.Parser = (0, _factoriesNumber.createParserClass)({ + evaluate +}); +const simplify = exports.simplify = (0, _factoriesNumber.createSimplify)({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsNumberGenerated.add, + config: _configReadonly.config, + divide: _pureFunctionsNumberGenerated.divide, + equal: _pureFunctionsNumberGenerated.equal, + isZero: _pureFunctionsNumberGenerated.isZero, + mathWithTransform, + matrix: _pureFunctionsNumberGenerated.matrix, + multiply: _pureFunctionsNumberGenerated.multiply, + parse, + pow: _pureFunctionsNumberGenerated.pow, + resolve, + simplifyConstant, + simplifyCore, + subtract: _pureFunctionsNumberGenerated.subtract, + typed: _pureFunctionsNumberGenerated.typed +}); +const derivative = exports.derivative = (0, _factoriesNumber.createDerivative)({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + config: _configReadonly.config, + equal: _pureFunctionsNumberGenerated.equal, + isZero: _pureFunctionsNumberGenerated.isZero, + numeric: _pureFunctionsNumberGenerated.numeric, + parse, + simplify, + typed: _pureFunctionsNumberGenerated.typed +}); +const rationalize = exports.rationalize = (0, _factoriesNumber.createRationalize)({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add: _pureFunctionsNumberGenerated.add, + config: _configReadonly.config, + divide: _pureFunctionsNumberGenerated.divide, + equal: _pureFunctionsNumberGenerated.equal, + isZero: _pureFunctionsNumberGenerated.isZero, + mathWithTransform, + matrix: _pureFunctionsNumberGenerated.matrix, + multiply: _pureFunctionsNumberGenerated.multiply, + parse, + pow: _pureFunctionsNumberGenerated.pow, + simplify, + simplifyConstant, + simplifyCore, + subtract: _pureFunctionsNumberGenerated.subtract, + typed: _pureFunctionsNumberGenerated.typed +}); +const help = exports.help = (0, _factoriesNumber.createHelp)({ + Help, + mathWithTransform, + typed: _pureFunctionsNumberGenerated.typed +}); +const parser = exports.parser = (0, _factoriesNumber.createParser)({ + Parser, + typed: _pureFunctionsNumberGenerated.typed +}); +(0, _extends2.default)(math, { + e: _pureFunctionsNumberGenerated.e, + false: _pureFunctionsNumberGenerated._false, + index: _pureFunctionsNumberGenerated.index, + Infinity: _pureFunctionsNumberGenerated._Infinity, + LN10: _pureFunctionsNumberGenerated.LN10, + LOG10E: _pureFunctionsNumberGenerated.LOG10E, + matrix: _pureFunctionsNumberGenerated.matrix, + NaN: _pureFunctionsNumberGenerated._NaN, + null: _pureFunctionsNumberGenerated._null, + phi: _pureFunctionsNumberGenerated.phi, + replacer: _pureFunctionsNumberGenerated.replacer, + SQRT1_2: _pureFunctionsNumberGenerated.SQRT1_2, + subset: _pureFunctionsNumberGenerated.subset, + tau: _pureFunctionsNumberGenerated.tau, + typed: _pureFunctionsNumberGenerated.typed, + unaryPlus: _pureFunctionsNumberGenerated.unaryPlus, + 'E': _pureFunctionsNumberGenerated.e, + version: _pureFunctionsNumberGenerated.version, + xor: _pureFunctionsNumberGenerated.xor, + abs: _pureFunctionsNumberGenerated.abs, + acos: _pureFunctionsNumberGenerated.acos, + acot: _pureFunctionsNumberGenerated.acot, + acsc: _pureFunctionsNumberGenerated.acsc, + add: _pureFunctionsNumberGenerated.add, + and: _pureFunctionsNumberGenerated.and, + asec: _pureFunctionsNumberGenerated.asec, + asin: _pureFunctionsNumberGenerated.asin, + atan: _pureFunctionsNumberGenerated.atan, + atanh: _pureFunctionsNumberGenerated.atanh, + bigint: _pureFunctionsNumberGenerated.bigint, + bitNot: _pureFunctionsNumberGenerated.bitNot, + bitXor: _pureFunctionsNumberGenerated.bitXor, + boolean: _pureFunctionsNumberGenerated.boolean, + cbrt: _pureFunctionsNumberGenerated.cbrt, + combinations: _pureFunctionsNumberGenerated.combinations, + compare: _pureFunctionsNumberGenerated.compare, + compareText: _pureFunctionsNumberGenerated.compareText, + cos: _pureFunctionsNumberGenerated.cos, + cot: _pureFunctionsNumberGenerated.cot, + csc: _pureFunctionsNumberGenerated.csc, + cube: _pureFunctionsNumberGenerated.cube, + divide: _pureFunctionsNumberGenerated.divide, + equalScalar: _pureFunctionsNumberGenerated.equalScalar, + erf: _pureFunctionsNumberGenerated.erf, + exp: _pureFunctionsNumberGenerated.exp, + filter: _pureFunctionsNumberGenerated.filter, + forEach: _pureFunctionsNumberGenerated.forEach, + format: _pureFunctionsNumberGenerated.format, + gamma: _pureFunctionsNumberGenerated.gamma, + isInteger: _pureFunctionsNumberGenerated.isInteger, + isNegative: _pureFunctionsNumberGenerated.isNegative, + isPositive: _pureFunctionsNumberGenerated.isPositive, + isZero: _pureFunctionsNumberGenerated.isZero, + LOG2E: _pureFunctionsNumberGenerated.LOG2E, + largerEq: _pureFunctionsNumberGenerated.largerEq, + leftShift: _pureFunctionsNumberGenerated.leftShift, + log: _pureFunctionsNumberGenerated.log, + log1p: _pureFunctionsNumberGenerated.log1p, + map: _pureFunctionsNumberGenerated.map, + mean: _pureFunctionsNumberGenerated.mean, + mod: _pureFunctionsNumberGenerated.mod, + multiply: _pureFunctionsNumberGenerated.multiply, + not: _pureFunctionsNumberGenerated.not, + number: _pureFunctionsNumberGenerated.number, + or: _pureFunctionsNumberGenerated.or, + pi: _pureFunctionsNumberGenerated.pi, + pow: _pureFunctionsNumberGenerated.pow, + random: _pureFunctionsNumberGenerated.random, + reviver, + rightLogShift: _pureFunctionsNumberGenerated.rightLogShift, + SQRT2: _pureFunctionsNumberGenerated.SQRT2, + sech: _pureFunctionsNumberGenerated.sech, + sin: _pureFunctionsNumberGenerated.sin, + size: _pureFunctionsNumberGenerated.size, + smallerEq: _pureFunctionsNumberGenerated.smallerEq, + square: _pureFunctionsNumberGenerated.square, + string: _pureFunctionsNumberGenerated.string, + subtract: _pureFunctionsNumberGenerated.subtract, + tanh: _pureFunctionsNumberGenerated.tanh, + typeOf: _pureFunctionsNumberGenerated.typeOf, + unequal: _pureFunctionsNumberGenerated.unequal, + xgcd: _pureFunctionsNumberGenerated.xgcd, + acoth: _pureFunctionsNumberGenerated.acoth, + addScalar: _pureFunctionsNumberGenerated.addScalar, + asech: _pureFunctionsNumberGenerated.asech, + bitAnd: _pureFunctionsNumberGenerated.bitAnd, + chain, + combinationsWithRep: _pureFunctionsNumberGenerated.combinationsWithRep, + cosh: _pureFunctionsNumberGenerated.cosh, + csch: _pureFunctionsNumberGenerated.csch, + divideScalar: _pureFunctionsNumberGenerated.divideScalar, + equalText: _pureFunctionsNumberGenerated.equalText, + expm1: _pureFunctionsNumberGenerated.expm1, + isNumeric: _pureFunctionsNumberGenerated.isNumeric, + LN2: _pureFunctionsNumberGenerated.LN2, + lcm: _pureFunctionsNumberGenerated.lcm, + log10: _pureFunctionsNumberGenerated.log10, + multiplyScalar: _pureFunctionsNumberGenerated.multiplyScalar, + nthRoot: _pureFunctionsNumberGenerated.nthRoot, + pickRandom: _pureFunctionsNumberGenerated.pickRandom, + randomInt: _pureFunctionsNumberGenerated.randomInt, + rightArithShift: _pureFunctionsNumberGenerated.rightArithShift, + sec: _pureFunctionsNumberGenerated.sec, + sinh: _pureFunctionsNumberGenerated.sinh, + sqrt: _pureFunctionsNumberGenerated.sqrt, + tan: _pureFunctionsNumberGenerated.tan, + unaryMinus: _pureFunctionsNumberGenerated.unaryMinus, + acosh: _pureFunctionsNumberGenerated.acosh, + apply: _pureFunctionsNumberGenerated.apply, + asinh: _pureFunctionsNumberGenerated.asinh, + bitOr: _pureFunctionsNumberGenerated.bitOr, + clone: _pureFunctionsNumberGenerated.clone, + coth: _pureFunctionsNumberGenerated.coth, + equal: _pureFunctionsNumberGenerated.equal, + factorial: _pureFunctionsNumberGenerated.factorial, + hasNumericValue: _pureFunctionsNumberGenerated.hasNumericValue, + isNaN: _pureFunctionsNumberGenerated.isNaN, + larger: _pureFunctionsNumberGenerated.larger, + log2: _pureFunctionsNumberGenerated.log2, + mode: _pureFunctionsNumberGenerated.mode, + norm: _pureFunctionsNumberGenerated.norm, + partitionSelect: _pureFunctionsNumberGenerated.partitionSelect, + print: _pureFunctionsNumberGenerated.print, + round: _pureFunctionsNumberGenerated.round, + smaller: _pureFunctionsNumberGenerated.smaller, + subtractScalar: _pureFunctionsNumberGenerated.subtractScalar, + true: _pureFunctionsNumberGenerated._true, + variance: _pureFunctionsNumberGenerated.variance, + zeta: _pureFunctionsNumberGenerated.zeta, + acsch: _pureFunctionsNumberGenerated.acsch, + atan2: _pureFunctionsNumberGenerated.atan2, + catalan: _pureFunctionsNumberGenerated.catalan, + compareNatural: _pureFunctionsNumberGenerated.compareNatural, + composition: _pureFunctionsNumberGenerated.composition, + cumsum: _pureFunctionsNumberGenerated.cumsum, + floor: _pureFunctionsNumberGenerated.floor, + hypot: _pureFunctionsNumberGenerated.hypot, + lgamma: _pureFunctionsNumberGenerated.lgamma, + median: _pureFunctionsNumberGenerated.median, + multinomial: _pureFunctionsNumberGenerated.multinomial, + permutations: _pureFunctionsNumberGenerated.permutations, + quantileSeq: _pureFunctionsNumberGenerated.quantileSeq, + sign: _pureFunctionsNumberGenerated.sign, + std: _pureFunctionsNumberGenerated.std, + stirlingS2: _pureFunctionsNumberGenerated.stirlingS2, + 'PI': _pureFunctionsNumberGenerated.pi, + ceil: _pureFunctionsNumberGenerated.ceil, + deepEqual: _pureFunctionsNumberGenerated.deepEqual, + fix: _pureFunctionsNumberGenerated.fix, + isPrime: _pureFunctionsNumberGenerated.isPrime, + numeric: _pureFunctionsNumberGenerated.numeric, + prod: _pureFunctionsNumberGenerated.prod, + simplifyConstant, + bellNumbers: _pureFunctionsNumberGenerated.bellNumbers, + gcd: _pureFunctionsNumberGenerated.gcd, + mad: _pureFunctionsNumberGenerated.mad, + range: _pureFunctionsNumberGenerated.range, + sum: _pureFunctionsNumberGenerated.sum, + corr: _pureFunctionsNumberGenerated.corr, + max: _pureFunctionsNumberGenerated.max, + parse, + resolve, + simplifyCore, + compile, + evaluate, + simplify, + derivative, + min: _pureFunctionsNumberGenerated.min, + rationalize, + help, + parser, + config: _configReadonly.config +}); +(0, _extends2.default)(mathWithTransform, math, { + cumsum: (0, _factoriesNumber.createCumSumTransform)({ + add: _pureFunctionsNumberGenerated.add, + typed: _pureFunctionsNumberGenerated.typed, + unaryPlus: _pureFunctionsNumberGenerated.unaryPlus + }), + apply: (0, _factoriesNumber.createApplyTransform)({ + isInteger: _pureFunctionsNumberGenerated.isInteger, + typed: _pureFunctionsNumberGenerated.typed + }), + filter: (0, _factoriesNumber.createFilterTransform)({ + typed: _pureFunctionsNumberGenerated.typed + }), + forEach: (0, _factoriesNumber.createForEachTransform)({ + typed: _pureFunctionsNumberGenerated.typed + }), + map: (0, _factoriesNumber.createMapTransform)({ + typed: _pureFunctionsNumberGenerated.typed + }), + mean: (0, _factoriesNumber.createMeanTransform)({ + add: _pureFunctionsNumberGenerated.add, + divide: _pureFunctionsNumberGenerated.divide, + typed: _pureFunctionsNumberGenerated.typed + }), + subset: (0, _factoriesNumber.createSubsetTransform)({}), + range: (0, _factoriesNumber.createRangeTransform)({ + matrix: _pureFunctionsNumberGenerated.matrix, + add: _pureFunctionsNumberGenerated.add, + config: _configReadonly.config, + isPositive: _pureFunctionsNumberGenerated.isPositive, + larger: _pureFunctionsNumberGenerated.larger, + largerEq: _pureFunctionsNumberGenerated.largerEq, + smaller: _pureFunctionsNumberGenerated.smaller, + smallerEq: _pureFunctionsNumberGenerated.smallerEq, + typed: _pureFunctionsNumberGenerated.typed + }), + std: (0, _factoriesNumber.createStdTransform)({ + map: _pureFunctionsNumberGenerated.map, + sqrt: _pureFunctionsNumberGenerated.sqrt, + typed: _pureFunctionsNumberGenerated.typed, + variance: _pureFunctionsNumberGenerated.variance + }), + sum: (0, _factoriesNumber.createSumTransform)({ + add: _pureFunctionsNumberGenerated.add, + config: _configReadonly.config, + numeric: _pureFunctionsNumberGenerated.numeric, + typed: _pureFunctionsNumberGenerated.typed + }), + max: (0, _factoriesNumber.createMaxTransform)({ + config: _configReadonly.config, + larger: _pureFunctionsNumberGenerated.larger, + numeric: _pureFunctionsNumberGenerated.numeric, + typed: _pureFunctionsNumberGenerated.typed + }), + min: (0, _factoriesNumber.createMinTransform)({ + config: _configReadonly.config, + numeric: _pureFunctionsNumberGenerated.numeric, + smaller: _pureFunctionsNumberGenerated.smaller, + typed: _pureFunctionsNumberGenerated.typed + }), + variance: (0, _factoriesNumber.createVarianceTransform)({ + add: _pureFunctionsNumberGenerated.add, + apply: _pureFunctionsNumberGenerated.apply, + divide: _pureFunctionsNumberGenerated.divide, + isNaN: _pureFunctionsNumberGenerated.isNaN, + multiply: _pureFunctionsNumberGenerated.multiply, + subtract: _pureFunctionsNumberGenerated.subtract, + typed: _pureFunctionsNumberGenerated.typed + }) +}); +(0, _extends2.default)(classes, { + Range: _pureFunctionsNumberGenerated.Range, + ResultSet: _pureFunctionsNumberGenerated.ResultSet, + Chain, + Node, + ObjectNode, + RangeNode, + RelationalNode, + SymbolNode, + AccessorNode, + AssignmentNode, + BlockNode, + ConditionalNode, + FunctionNode, + IndexNode, + OperatorNode, + ConstantNode, + FunctionAssignmentNode, + ParenthesisNode, + ArrayNode, + Help, + Parser +}); +Chain.createProxy(math); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainAny.js new file mode 100644 index 0000000..2b46e44 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainAny.js @@ -0,0 +1,115 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _exportNames = { + config: true, + IndexError: true, + DimensionError: true, + ArgumentsError: true, + create: true, + factory: true +}; +Object.defineProperty(exports, "ArgumentsError", { + enumerable: true, + get: function () { + return _ArgumentsError.ArgumentsError; + } +}); +Object.defineProperty(exports, "DimensionError", { + enumerable: true, + get: function () { + return _DimensionError.DimensionError; + } +}); +Object.defineProperty(exports, "IndexError", { + enumerable: true, + get: function () { + return _IndexError.IndexError; + } +}); +Object.defineProperty(exports, "config", { + enumerable: true, + get: function () { + return _configReadonly.config; + } +}); +Object.defineProperty(exports, "create", { + enumerable: true, + get: function () { + return _create.create; + } +}); +Object.defineProperty(exports, "factory", { + enumerable: true, + get: function () { + return _factory.factory; + } +}); +var _configReadonly = require("./configReadonly.js"); +var _pureFunctionsAnyGenerated = require("./pureFunctionsAny.generated.js"); +Object.keys(_pureFunctionsAnyGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _pureFunctionsAnyGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _pureFunctionsAnyGenerated[key]; + } + }); +}); +var _impureFunctionsAnyGenerated = require("./impureFunctionsAny.generated.js"); +Object.keys(_impureFunctionsAnyGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _impureFunctionsAnyGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _impureFunctionsAnyGenerated[key]; + } + }); +}); +var _typeChecks = require("./typeChecks.js"); +Object.keys(_typeChecks).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _typeChecks[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _typeChecks[key]; + } + }); +}); +var _IndexError = require("../error/IndexError.js"); +var _DimensionError = require("../error/DimensionError.js"); +var _ArgumentsError = require("../error/ArgumentsError.js"); +var _dependenciesAnyGenerated = require("./dependenciesAny.generated.js"); +Object.keys(_dependenciesAnyGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _dependenciesAnyGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _dependenciesAnyGenerated[key]; + } + }); +}); +var _factoriesAny = require("../factoriesAny.js"); +Object.keys(_factoriesAny).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _factoriesAny[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _factoriesAny[key]; + } + }); +}); +var _create = require("../core/create.js"); +var _factory = require("../utils/factory.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainNumber.js new file mode 100644 index 0000000..8e1e282 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/mainNumber.js @@ -0,0 +1,115 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _exportNames = { + config: true, + IndexError: true, + DimensionError: true, + ArgumentsError: true, + create: true, + factory: true +}; +Object.defineProperty(exports, "ArgumentsError", { + enumerable: true, + get: function () { + return _ArgumentsError.ArgumentsError; + } +}); +Object.defineProperty(exports, "DimensionError", { + enumerable: true, + get: function () { + return _DimensionError.DimensionError; + } +}); +Object.defineProperty(exports, "IndexError", { + enumerable: true, + get: function () { + return _IndexError.IndexError; + } +}); +Object.defineProperty(exports, "config", { + enumerable: true, + get: function () { + return _configReadonly.config; + } +}); +Object.defineProperty(exports, "create", { + enumerable: true, + get: function () { + return _create.create; + } +}); +Object.defineProperty(exports, "factory", { + enumerable: true, + get: function () { + return _factory.factory; + } +}); +var _configReadonly = require("./configReadonly.js"); +var _pureFunctionsNumberGenerated = require("./pureFunctionsNumber.generated.js"); +Object.keys(_pureFunctionsNumberGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _pureFunctionsNumberGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _pureFunctionsNumberGenerated[key]; + } + }); +}); +var _impureFunctionsNumberGenerated = require("./impureFunctionsNumber.generated.js"); +Object.keys(_impureFunctionsNumberGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _impureFunctionsNumberGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _impureFunctionsNumberGenerated[key]; + } + }); +}); +var _typeChecks = require("./typeChecks.js"); +Object.keys(_typeChecks).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _typeChecks[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _typeChecks[key]; + } + }); +}); +var _IndexError = require("../error/IndexError.js"); +var _DimensionError = require("../error/DimensionError.js"); +var _ArgumentsError = require("../error/ArgumentsError.js"); +var _dependenciesNumberGenerated = require("./dependenciesNumber.generated.js"); +Object.keys(_dependenciesNumberGenerated).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _dependenciesNumberGenerated[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _dependenciesNumberGenerated[key]; + } + }); +}); +var _factoriesNumber = require("../factoriesNumber.js"); +Object.keys(_factoriesNumber).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _factoriesNumber[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _factoriesNumber[key]; + } + }); +}); +var _create = require("../core/create.js"); +var _factory = require("../utils/factory.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsAny.generated.js new file mode 100644 index 0000000..c82ccbe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsAny.generated.js @@ -0,0 +1,1801 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.e = exports.dotPow = exports.dotMultiply = exports.dotDivide = exports.dot = exports.divideScalar = exports.divide = exports.distance = exports.diff = exports.diag = exports.deuteronMass = exports.det = exports.deepEqual = exports.cumsum = exports.cube = exports.ctranspose = exports.csch = exports.csc = exports.cross = exports.createUnit = exports.count = exports.coulomb = exports.coth = exports.cot = exports.cosh = exports.cos = exports.corr = exports.conj = exports.conductanceQuantum = exports.concat = exports.composition = exports.complex = exports.compareText = exports.compareNatural = exports.compare = exports.combinationsWithRep = exports.combinations = exports.column = exports.clone = exports.classicalElectronRadius = exports.ceil = exports.cbrt = exports.catalan = exports.boolean = exports.boltzmann = exports.bohrRadius = exports.bohrMagneton = exports.bitXor = exports.bitOr = exports.bitNot = exports.bitAnd = exports.bin = exports.bignumber = exports.bigint = exports.bellNumbers = exports.avogadro = exports.atomicMass = exports.atanh = exports.atan2 = exports.atan = exports.asinh = exports.asin = exports.asech = exports.asec = exports.arg = exports.apply = exports.and = exports.addScalar = exports.add = exports.acsch = exports.acsc = exports.acoth = exports.acot = exports.acosh = exports.acos = exports.abs = exports._true = exports._null = exports._false = exports._NaN = exports._Infinity = exports.Unit = exports.SparseMatrix = exports.Spa = exports.SQRT2 = exports.SQRT1_2 = exports.ResultSet = exports.Range = exports.Matrix = exports.LOG2E = exports.LOG10E = exports.LN2 = exports.LN10 = exports.Index = exports.ImmutableDenseMatrix = exports.Fraction = exports.FibonacciHeap = exports.DenseMatrix = exports.Complex = exports.BigNumber = void 0; +exports.oct = exports.numeric = exports.number = exports.nuclearMagneton = exports.nthRoots = exports.nthRoot = exports.not = exports.norm = exports.neutronMass = exports.multiplyScalar = exports.multiply = exports.multinomial = exports.molarVolume = exports.molarPlanckConstant = exports.molarMassC12 = exports.molarMass = exports.mode = exports.mod = exports.min = exports.median = exports.mean = exports.max = exports.matrixFromRows = exports.matrixFromFunction = exports.matrixFromColumns = exports.matrix = exports.map = exports.magneticFluxQuantum = exports.magneticConstant = exports.mad = exports.lyap = exports.lusolve = exports.lup = exports.lsolveAll = exports.lsolve = exports.loschmidt = exports.log2 = exports.log1p = exports.log10 = exports.log = exports.lgamma = exports.leftShift = exports.lcm = exports.largerEq = exports.larger = exports.kron = exports.klitzing = exports.kldivergence = exports.isZero = exports.isPrime = exports.isPositive = exports.isNumeric = exports.isNegative = exports.isNaN = exports.isInteger = exports.invmod = exports.inverseConductanceQuantum = exports.inv = exports.intersect = exports.index = exports.im = exports.ifft = exports.identity = exports.i = exports.hypot = exports.hex = exports.hasNumericValue = exports.hartreeEnergy = exports.gravity = exports.gravitationConstant = exports.getMatrixDataType = exports.gcd = exports.gasConstant = exports.gamma = exports.freqz = exports.fraction = exports.format = exports.forEach = exports.floor = exports.flatten = exports.fix = exports.firstRadiation = exports.fineStructure = exports.filter = exports.fft = exports.fermiCoupling = exports.faraday = exports.factorial = exports.expm1 = exports.expm = exports.exp = exports.erf = exports.equalText = exports.equalScalar = exports.equal = exports.elementaryCharge = exports.electronMass = exports.electricConstant = exports.eigs = exports.efimovFactor = void 0; +exports.zeros = exports.xor = exports.xgcd = exports.wienDisplacement = exports.weakMixingAngle = exports.version = exports.variance = exports.vacuumImpedance = exports.usolveAll = exports.usolve = exports.unit = exports.unequal = exports.unaryPlus = exports.unaryMinus = exports.typed = exports.typeOf = exports.transpose = exports.trace = exports.to = exports.thomsonCrossSection = exports.tau = exports.tanh = exports.tan = exports.sylvester = exports.sum = exports.subtractScalar = exports.subtract = exports.subset = exports.string = exports.stirlingS2 = exports.stefanBoltzmann = exports.std = exports.squeeze = exports.square = exports.sqrtm = exports.sqrt = exports.splitUnit = exports.speedOfLight = exports.sparse = exports.sort = exports.solveODE = exports.smallerEq = exports.smaller = exports.slu = exports.size = exports.sinh = exports.sin = exports.sign = exports.setUnion = exports.setSymDifference = exports.setSize = exports.setPowerset = exports.setMultiplicity = exports.setIsSubset = exports.setIntersect = exports.setDistinct = exports.setDifference = exports.setCartesian = exports.secondRadiation = exports.sech = exports.sec = exports.schur = exports.sackurTetrode = exports.rydberg = exports.row = exports.round = exports.rotationMatrix = exports.rotate = exports.rightLogShift = exports.rightArithShift = exports.resize = exports.reshape = exports.replacer = exports.reducedPlanckConstant = exports.re = exports.range = exports.randomInt = exports.random = exports.quantumOfCirculation = exports.quantileSeq = exports.qr = exports.protonMass = exports.prod = exports.print = exports.pow = exports.polynomialRoot = exports.planckTime = exports.planckTemperature = exports.planckMass = exports.planckLength = exports.planckConstant = exports.planckCharge = exports.pinv = exports.pickRandom = exports.pi = exports.phi = exports.permutations = exports.partitionSelect = exports.or = exports.ones = void 0; +exports.zpk2tf = exports.zeta = void 0; +var _configReadonly = require("./configReadonly.js"); +var _factoriesAny = require("../factoriesAny.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const BigNumber = exports.BigNumber = /* #__PURE__ */(0, _factoriesAny.createBigNumberClass)({ + config: _configReadonly.config +}); +const Complex = exports.Complex = /* #__PURE__ */(0, _factoriesAny.createComplexClass)({}); +const e = exports.e = /* #__PURE__ */(0, _factoriesAny.createE)({ + BigNumber, + config: _configReadonly.config +}); +const _false = exports._false = /* #__PURE__ */(0, _factoriesAny.createFalse)({}); +const fineStructure = exports.fineStructure = /* #__PURE__ */(0, _factoriesAny.createFineStructure)({ + BigNumber, + config: _configReadonly.config +}); +const Fraction = exports.Fraction = /* #__PURE__ */(0, _factoriesAny.createFractionClass)({}); +const i = exports.i = /* #__PURE__ */(0, _factoriesAny.createI)({ + Complex +}); +const _Infinity = exports._Infinity = /* #__PURE__ */(0, _factoriesAny.createInfinity)({ + BigNumber, + config: _configReadonly.config +}); +const LN10 = exports.LN10 = /* #__PURE__ */(0, _factoriesAny.createLN10)({ + BigNumber, + config: _configReadonly.config +}); +const LOG10E = exports.LOG10E = /* #__PURE__ */(0, _factoriesAny.createLOG10E)({ + BigNumber, + config: _configReadonly.config +}); +const Matrix = exports.Matrix = /* #__PURE__ */(0, _factoriesAny.createMatrixClass)({}); +const _NaN = exports._NaN = /* #__PURE__ */(0, _factoriesAny.createNaN)({ + BigNumber, + config: _configReadonly.config +}); +const _null = exports._null = /* #__PURE__ */(0, _factoriesAny.createNull)({}); +const phi = exports.phi = /* #__PURE__ */(0, _factoriesAny.createPhi)({ + BigNumber, + config: _configReadonly.config +}); +const Range = exports.Range = /* #__PURE__ */(0, _factoriesAny.createRangeClass)({}); +const ResultSet = exports.ResultSet = /* #__PURE__ */(0, _factoriesAny.createResultSet)({}); +const SQRT1_2 = exports.SQRT1_2 = /* #__PURE__ */(0, _factoriesAny.createSQRT1_2)({ + BigNumber, + config: _configReadonly.config +}); +const sackurTetrode = exports.sackurTetrode = /* #__PURE__ */(0, _factoriesAny.createSackurTetrode)({ + BigNumber, + config: _configReadonly.config +}); +const tau = exports.tau = /* #__PURE__ */(0, _factoriesAny.createTau)({ + BigNumber, + config: _configReadonly.config +}); +const _true = exports._true = /* #__PURE__ */(0, _factoriesAny.createTrue)({}); +const version = exports.version = /* #__PURE__ */(0, _factoriesAny.createVersion)({}); +const DenseMatrix = exports.DenseMatrix = /* #__PURE__ */(0, _factoriesAny.createDenseMatrixClass)({ + Matrix +}); +const efimovFactor = exports.efimovFactor = /* #__PURE__ */(0, _factoriesAny.createEfimovFactor)({ + BigNumber, + config: _configReadonly.config +}); +const LN2 = exports.LN2 = /* #__PURE__ */(0, _factoriesAny.createLN2)({ + BigNumber, + config: _configReadonly.config +}); +const pi = exports.pi = /* #__PURE__ */(0, _factoriesAny.createPi)({ + BigNumber, + config: _configReadonly.config +}); +const replacer = exports.replacer = /* #__PURE__ */(0, _factoriesAny.createReplacer)({}); +const SQRT2 = exports.SQRT2 = /* #__PURE__ */(0, _factoriesAny.createSQRT2)({ + BigNumber, + config: _configReadonly.config +}); +const typed = exports.typed = /* #__PURE__ */(0, _factoriesAny.createTyped)({ + BigNumber, + Complex, + DenseMatrix, + Fraction +}); +const weakMixingAngle = exports.weakMixingAngle = /* #__PURE__ */(0, _factoriesAny.createWeakMixingAngle)({ + BigNumber, + config: _configReadonly.config +}); +const abs = exports.abs = /* #__PURE__ */(0, _factoriesAny.createAbs)({ + typed +}); +const acos = exports.acos = /* #__PURE__ */(0, _factoriesAny.createAcos)({ + Complex, + config: _configReadonly.config, + typed +}); +const acot = exports.acot = /* #__PURE__ */(0, _factoriesAny.createAcot)({ + BigNumber, + typed +}); +const acsc = exports.acsc = /* #__PURE__ */(0, _factoriesAny.createAcsc)({ + BigNumber, + Complex, + config: _configReadonly.config, + typed +}); +const addScalar = exports.addScalar = /* #__PURE__ */(0, _factoriesAny.createAddScalar)({ + typed +}); +const arg = exports.arg = /* #__PURE__ */(0, _factoriesAny.createArg)({ + typed +}); +const asech = exports.asech = /* #__PURE__ */(0, _factoriesAny.createAsech)({ + BigNumber, + Complex, + config: _configReadonly.config, + typed +}); +const asinh = exports.asinh = /* #__PURE__ */(0, _factoriesAny.createAsinh)({ + typed +}); +const atan = exports.atan = /* #__PURE__ */(0, _factoriesAny.createAtan)({ + typed +}); +const atanh = exports.atanh = /* #__PURE__ */(0, _factoriesAny.createAtanh)({ + Complex, + config: _configReadonly.config, + typed +}); +const bigint = exports.bigint = /* #__PURE__ */(0, _factoriesAny.createBigint)({ + typed +}); +const bitNot = exports.bitNot = /* #__PURE__ */(0, _factoriesAny.createBitNot)({ + typed +}); +const boolean = exports.boolean = /* #__PURE__ */(0, _factoriesAny.createBoolean)({ + typed +}); +const clone = exports.clone = /* #__PURE__ */(0, _factoriesAny.createClone)({ + typed +}); +const combinations = exports.combinations = /* #__PURE__ */(0, _factoriesAny.createCombinations)({ + typed +}); +const complex = exports.complex = /* #__PURE__ */(0, _factoriesAny.createComplex)({ + Complex, + typed +}); +const conj = exports.conj = /* #__PURE__ */(0, _factoriesAny.createConj)({ + typed +}); +const cos = exports.cos = /* #__PURE__ */(0, _factoriesAny.createCos)({ + typed +}); +const cot = exports.cot = /* #__PURE__ */(0, _factoriesAny.createCot)({ + BigNumber, + typed +}); +const csc = exports.csc = /* #__PURE__ */(0, _factoriesAny.createCsc)({ + BigNumber, + typed +}); +const cube = exports.cube = /* #__PURE__ */(0, _factoriesAny.createCube)({ + typed +}); +const equalScalar = exports.equalScalar = /* #__PURE__ */(0, _factoriesAny.createEqualScalar)({ + config: _configReadonly.config, + typed +}); +const erf = exports.erf = /* #__PURE__ */(0, _factoriesAny.createErf)({ + typed +}); +const exp = exports.exp = /* #__PURE__ */(0, _factoriesAny.createExp)({ + typed +}); +const expm1 = exports.expm1 = /* #__PURE__ */(0, _factoriesAny.createExpm1)({ + Complex, + typed +}); +const filter = exports.filter = /* #__PURE__ */(0, _factoriesAny.createFilter)({ + typed +}); +const flatten = exports.flatten = /* #__PURE__ */(0, _factoriesAny.createFlatten)({ + typed +}); +const forEach = exports.forEach = /* #__PURE__ */(0, _factoriesAny.createForEach)({ + typed +}); +const format = exports.format = /* #__PURE__ */(0, _factoriesAny.createFormat)({ + typed +}); +const getMatrixDataType = exports.getMatrixDataType = /* #__PURE__ */(0, _factoriesAny.createGetMatrixDataType)({ + typed +}); +const hex = exports.hex = /* #__PURE__ */(0, _factoriesAny.createHex)({ + format, + typed +}); +const im = exports.im = /* #__PURE__ */(0, _factoriesAny.createIm)({ + typed +}); +const isInteger = exports.isInteger = /* #__PURE__ */(0, _factoriesAny.createIsInteger)({ + typed +}); +const isNegative = exports.isNegative = /* #__PURE__ */(0, _factoriesAny.createIsNegative)({ + config: _configReadonly.config, + typed +}); +const isPositive = exports.isPositive = /* #__PURE__ */(0, _factoriesAny.createIsPositive)({ + config: _configReadonly.config, + typed +}); +const isZero = exports.isZero = /* #__PURE__ */(0, _factoriesAny.createIsZero)({ + equalScalar, + typed +}); +const LOG2E = exports.LOG2E = /* #__PURE__ */(0, _factoriesAny.createLOG2E)({ + BigNumber, + config: _configReadonly.config +}); +const lgamma = exports.lgamma = /* #__PURE__ */(0, _factoriesAny.createLgamma)({ + Complex, + typed +}); +const log10 = exports.log10 = /* #__PURE__ */(0, _factoriesAny.createLog10)({ + Complex, + config: _configReadonly.config, + typed +}); +const log2 = exports.log2 = /* #__PURE__ */(0, _factoriesAny.createLog2)({ + Complex, + config: _configReadonly.config, + typed +}); +const map = exports.map = /* #__PURE__ */(0, _factoriesAny.createMap)({ + typed +}); +const multiplyScalar = exports.multiplyScalar = /* #__PURE__ */(0, _factoriesAny.createMultiplyScalar)({ + typed +}); +const not = exports.not = /* #__PURE__ */(0, _factoriesAny.createNot)({ + typed +}); +const number = exports.number = /* #__PURE__ */(0, _factoriesAny.createNumber)({ + typed +}); +const oct = exports.oct = /* #__PURE__ */(0, _factoriesAny.createOct)({ + format, + typed +}); +const pickRandom = exports.pickRandom = /* #__PURE__ */(0, _factoriesAny.createPickRandom)({ + config: _configReadonly.config, + typed +}); +const print = exports.print = /* #__PURE__ */(0, _factoriesAny.createPrint)({ + typed +}); +const random = exports.random = /* #__PURE__ */(0, _factoriesAny.createRandom)({ + config: _configReadonly.config, + typed +}); +const re = exports.re = /* #__PURE__ */(0, _factoriesAny.createRe)({ + typed +}); +const sec = exports.sec = /* #__PURE__ */(0, _factoriesAny.createSec)({ + BigNumber, + typed +}); +const sign = exports.sign = /* #__PURE__ */(0, _factoriesAny.createSign)({ + BigNumber, + Fraction, + complex, + typed +}); +const sin = exports.sin = /* #__PURE__ */(0, _factoriesAny.createSin)({ + typed +}); +const SparseMatrix = exports.SparseMatrix = /* #__PURE__ */(0, _factoriesAny.createSparseMatrixClass)({ + Matrix, + equalScalar, + typed +}); +const splitUnit = exports.splitUnit = /* #__PURE__ */(0, _factoriesAny.createSplitUnit)({ + typed +}); +const square = exports.square = /* #__PURE__ */(0, _factoriesAny.createSquare)({ + typed +}); +const string = exports.string = /* #__PURE__ */(0, _factoriesAny.createString)({ + typed +}); +const subtractScalar = exports.subtractScalar = /* #__PURE__ */(0, _factoriesAny.createSubtractScalar)({ + typed +}); +const tan = exports.tan = /* #__PURE__ */(0, _factoriesAny.createTan)({ + typed +}); +const typeOf = exports.typeOf = /* #__PURE__ */(0, _factoriesAny.createTypeOf)({ + typed +}); +const acosh = exports.acosh = /* #__PURE__ */(0, _factoriesAny.createAcosh)({ + Complex, + config: _configReadonly.config, + typed +}); +const acsch = exports.acsch = /* #__PURE__ */(0, _factoriesAny.createAcsch)({ + BigNumber, + typed +}); +const apply = exports.apply = /* #__PURE__ */(0, _factoriesAny.createApply)({ + isInteger, + typed +}); +const asec = exports.asec = /* #__PURE__ */(0, _factoriesAny.createAsec)({ + BigNumber, + Complex, + config: _configReadonly.config, + typed +}); +const bignumber = exports.bignumber = /* #__PURE__ */(0, _factoriesAny.createBignumber)({ + BigNumber, + typed +}); +const combinationsWithRep = exports.combinationsWithRep = /* #__PURE__ */(0, _factoriesAny.createCombinationsWithRep)({ + typed +}); +const cosh = exports.cosh = /* #__PURE__ */(0, _factoriesAny.createCosh)({ + typed +}); +const csch = exports.csch = /* #__PURE__ */(0, _factoriesAny.createCsch)({ + BigNumber, + typed +}); +const isNaN = exports.isNaN = /* #__PURE__ */(0, _factoriesAny.createIsNaN)({ + typed +}); +const isPrime = exports.isPrime = /* #__PURE__ */(0, _factoriesAny.createIsPrime)({ + typed +}); +const randomInt = exports.randomInt = /* #__PURE__ */(0, _factoriesAny.createRandomInt)({ + config: _configReadonly.config, + typed +}); +const sech = exports.sech = /* #__PURE__ */(0, _factoriesAny.createSech)({ + BigNumber, + typed +}); +const sinh = exports.sinh = /* #__PURE__ */(0, _factoriesAny.createSinh)({ + typed +}); +const sparse = exports.sparse = /* #__PURE__ */(0, _factoriesAny.createSparse)({ + SparseMatrix, + typed +}); +const sqrt = exports.sqrt = /* #__PURE__ */(0, _factoriesAny.createSqrt)({ + Complex, + config: _configReadonly.config, + typed +}); +const squeeze = exports.squeeze = /* #__PURE__ */(0, _factoriesAny.createSqueeze)({ + typed +}); +const tanh = exports.tanh = /* #__PURE__ */(0, _factoriesAny.createTanh)({ + typed +}); +const unaryMinus = exports.unaryMinus = /* #__PURE__ */(0, _factoriesAny.createUnaryMinus)({ + typed +}); +const acoth = exports.acoth = /* #__PURE__ */(0, _factoriesAny.createAcoth)({ + BigNumber, + Complex, + config: _configReadonly.config, + typed +}); +const bin = exports.bin = /* #__PURE__ */(0, _factoriesAny.createBin)({ + format, + typed +}); +const coth = exports.coth = /* #__PURE__ */(0, _factoriesAny.createCoth)({ + BigNumber, + typed +}); +const fraction = exports.fraction = /* #__PURE__ */(0, _factoriesAny.createFraction)({ + Fraction, + typed +}); +const isNumeric = exports.isNumeric = /* #__PURE__ */(0, _factoriesAny.createIsNumeric)({ + typed +}); +const matrix = exports.matrix = /* #__PURE__ */(0, _factoriesAny.createMatrix)({ + DenseMatrix, + Matrix, + SparseMatrix, + typed +}); +const matrixFromFunction = exports.matrixFromFunction = /* #__PURE__ */(0, _factoriesAny.createMatrixFromFunction)({ + isZero, + matrix, + typed +}); +const mode = exports.mode = /* #__PURE__ */(0, _factoriesAny.createMode)({ + isNaN, + isNumeric, + typed +}); +const numeric = exports.numeric = /* #__PURE__ */(0, _factoriesAny.createNumeric)({ + bignumber, + fraction, + number +}); +const prod = exports.prod = /* #__PURE__ */(0, _factoriesAny.createProd)({ + config: _configReadonly.config, + multiplyScalar, + numeric, + typed +}); +const reshape = exports.reshape = /* #__PURE__ */(0, _factoriesAny.createReshape)({ + isInteger, + matrix, + typed +}); +const size = exports.size = /* #__PURE__ */(0, _factoriesAny.createSize)({ + matrix, + config: _configReadonly.config, + typed +}); +const transpose = exports.transpose = /* #__PURE__ */(0, _factoriesAny.createTranspose)({ + matrix, + typed +}); +const xgcd = exports.xgcd = /* #__PURE__ */(0, _factoriesAny.createXgcd)({ + BigNumber, + config: _configReadonly.config, + matrix, + typed +}); +const zeros = exports.zeros = /* #__PURE__ */(0, _factoriesAny.createZeros)({ + BigNumber, + config: _configReadonly.config, + matrix, + typed +}); +const asin = exports.asin = /* #__PURE__ */(0, _factoriesAny.createAsin)({ + Complex, + config: _configReadonly.config, + typed +}); +const cbrt = exports.cbrt = /* #__PURE__ */(0, _factoriesAny.createCbrt)({ + BigNumber, + Complex, + Fraction, + config: _configReadonly.config, + isNegative, + matrix, + typed, + unaryMinus +}); +const concat = exports.concat = /* #__PURE__ */(0, _factoriesAny.createConcat)({ + isInteger, + matrix, + typed +}); +const count = exports.count = /* #__PURE__ */(0, _factoriesAny.createCount)({ + prod, + size, + typed +}); +const ctranspose = exports.ctranspose = /* #__PURE__ */(0, _factoriesAny.createCtranspose)({ + conj, + transpose, + typed +}); +const diag = exports.diag = /* #__PURE__ */(0, _factoriesAny.createDiag)({ + DenseMatrix, + SparseMatrix, + matrix, + typed +}); +const divideScalar = exports.divideScalar = /* #__PURE__ */(0, _factoriesAny.createDivideScalar)({ + numeric, + typed +}); +const dotDivide = exports.dotDivide = /* #__PURE__ */(0, _factoriesAny.createDotDivide)({ + DenseMatrix, + concat, + divideScalar, + equalScalar, + matrix, + typed +}); +const equal = exports.equal = /* #__PURE__ */(0, _factoriesAny.createEqual)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +const hasNumericValue = exports.hasNumericValue = /* #__PURE__ */(0, _factoriesAny.createHasNumericValue)({ + isNumeric, + typed +}); +const identity = exports.identity = /* #__PURE__ */(0, _factoriesAny.createIdentity)({ + BigNumber, + DenseMatrix, + SparseMatrix, + config: _configReadonly.config, + matrix, + typed +}); +const kron = exports.kron = /* #__PURE__ */(0, _factoriesAny.createKron)({ + matrix, + multiplyScalar, + typed +}); +const largerEq = exports.largerEq = /* #__PURE__ */(0, _factoriesAny.createLargerEq)({ + DenseMatrix, + concat, + config: _configReadonly.config, + matrix, + typed +}); +const leftShift = exports.leftShift = /* #__PURE__ */(0, _factoriesAny.createLeftShift)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +const lsolve = exports.lsolve = /* #__PURE__ */(0, _factoriesAny.createLsolve)({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +const matrixFromColumns = exports.matrixFromColumns = /* #__PURE__ */(0, _factoriesAny.createMatrixFromColumns)({ + flatten, + matrix, + size, + typed +}); +const nthRoot = exports.nthRoot = /* #__PURE__ */(0, _factoriesAny.createNthRoot)({ + BigNumber, + concat, + equalScalar, + matrix, + typed +}); +const ones = exports.ones = /* #__PURE__ */(0, _factoriesAny.createOnes)({ + BigNumber, + config: _configReadonly.config, + matrix, + typed +}); +const qr = exports.qr = /* #__PURE__ */(0, _factoriesAny.createQr)({ + addScalar, + complex, + conj, + divideScalar, + equal, + identity, + isZero, + matrix, + multiplyScalar, + sign, + sqrt, + subtractScalar, + typed, + unaryMinus, + zeros +}); +const resize = exports.resize = /* #__PURE__ */(0, _factoriesAny.createResize)({ + config: _configReadonly.config, + matrix +}); +const rightArithShift = exports.rightArithShift = /* #__PURE__ */(0, _factoriesAny.createRightArithShift)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +const round = exports.round = /* #__PURE__ */(0, _factoriesAny.createRound)({ + BigNumber, + DenseMatrix, + config: _configReadonly.config, + equalScalar, + matrix, + typed, + zeros +}); +const smaller = exports.smaller = /* #__PURE__ */(0, _factoriesAny.createSmaller)({ + DenseMatrix, + concat, + config: _configReadonly.config, + matrix, + typed +}); +const subtract = exports.subtract = /* #__PURE__ */(0, _factoriesAny.createSubtract)({ + DenseMatrix, + concat, + equalScalar, + matrix, + subtractScalar, + typed, + unaryMinus +}); +const to = exports.to = /* #__PURE__ */(0, _factoriesAny.createTo)({ + concat, + matrix, + typed +}); +const unaryPlus = exports.unaryPlus = /* #__PURE__ */(0, _factoriesAny.createUnaryPlus)({ + config: _configReadonly.config, + numeric, + typed +}); +const usolve = exports.usolve = /* #__PURE__ */(0, _factoriesAny.createUsolve)({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +const xor = exports.xor = /* #__PURE__ */(0, _factoriesAny.createXor)({ + DenseMatrix, + concat, + matrix, + typed +}); +const add = exports.add = /* #__PURE__ */(0, _factoriesAny.createAdd)({ + DenseMatrix, + SparseMatrix, + addScalar, + concat, + equalScalar, + matrix, + typed +}); +const atan2 = exports.atan2 = /* #__PURE__ */(0, _factoriesAny.createAtan2)({ + BigNumber, + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +const bitAnd = exports.bitAnd = /* #__PURE__ */(0, _factoriesAny.createBitAnd)({ + concat, + equalScalar, + matrix, + typed +}); +const bitOr = exports.bitOr = /* #__PURE__ */(0, _factoriesAny.createBitOr)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +const bitXor = exports.bitXor = /* #__PURE__ */(0, _factoriesAny.createBitXor)({ + DenseMatrix, + concat, + matrix, + typed +}); +const catalan = exports.catalan = /* #__PURE__ */(0, _factoriesAny.createCatalan)({ + addScalar, + combinations, + divideScalar, + isInteger, + isNegative, + multiplyScalar, + typed +}); +const compare = exports.compare = /* #__PURE__ */(0, _factoriesAny.createCompare)({ + BigNumber, + DenseMatrix, + Fraction, + concat, + config: _configReadonly.config, + equalScalar, + matrix, + typed +}); +const compareText = exports.compareText = /* #__PURE__ */(0, _factoriesAny.createCompareText)({ + concat, + matrix, + typed +}); +const cumsum = exports.cumsum = /* #__PURE__ */(0, _factoriesAny.createCumSum)({ + add, + typed, + unaryPlus +}); +const deepEqual = exports.deepEqual = /* #__PURE__ */(0, _factoriesAny.createDeepEqual)({ + equal, + typed +}); +const diff = exports.diff = /* #__PURE__ */(0, _factoriesAny.createDiff)({ + matrix, + number, + subtract, + typed +}); +const distance = exports.distance = /* #__PURE__ */(0, _factoriesAny.createDistance)({ + abs, + addScalar, + deepEqual, + divideScalar, + multiplyScalar, + sqrt, + subtractScalar, + typed +}); +const dot = exports.dot = /* #__PURE__ */(0, _factoriesAny.createDot)({ + addScalar, + conj, + multiplyScalar, + size, + typed +}); +const equalText = exports.equalText = /* #__PURE__ */(0, _factoriesAny.createEqualText)({ + compareText, + isZero, + typed +}); +const floor = exports.floor = /* #__PURE__ */(0, _factoriesAny.createFloor)({ + DenseMatrix, + config: _configReadonly.config, + equalScalar, + matrix, + round, + typed, + zeros +}); +const gcd = exports.gcd = /* #__PURE__ */(0, _factoriesAny.createGcd)({ + BigNumber, + DenseMatrix, + concat, + config: _configReadonly.config, + equalScalar, + matrix, + round, + typed, + zeros +}); +const hypot = exports.hypot = /* #__PURE__ */(0, _factoriesAny.createHypot)({ + abs, + addScalar, + divideScalar, + isPositive, + multiplyScalar, + smaller, + sqrt, + typed +}); +const ImmutableDenseMatrix = exports.ImmutableDenseMatrix = /* #__PURE__ */(0, _factoriesAny.createImmutableDenseMatrixClass)({ + DenseMatrix, + smaller +}); +const Index = exports.Index = /* #__PURE__ */(0, _factoriesAny.createIndexClass)({ + ImmutableDenseMatrix, + getMatrixDataType +}); +const larger = exports.larger = /* #__PURE__ */(0, _factoriesAny.createLarger)({ + DenseMatrix, + concat, + config: _configReadonly.config, + matrix, + typed +}); +const log = exports.log = /* #__PURE__ */(0, _factoriesAny.createLog)({ + Complex, + config: _configReadonly.config, + divideScalar, + typed +}); +const lsolveAll = exports.lsolveAll = /* #__PURE__ */(0, _factoriesAny.createLsolveAll)({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +const matrixFromRows = exports.matrixFromRows = /* #__PURE__ */(0, _factoriesAny.createMatrixFromRows)({ + flatten, + matrix, + size, + typed +}); +const min = exports.min = /* #__PURE__ */(0, _factoriesAny.createMin)({ + config: _configReadonly.config, + numeric, + smaller, + typed +}); +const mod = exports.mod = /* #__PURE__ */(0, _factoriesAny.createMod)({ + DenseMatrix, + concat, + config: _configReadonly.config, + equalScalar, + matrix, + round, + typed, + zeros +}); +const multiply = exports.multiply = /* #__PURE__ */(0, _factoriesAny.createMultiply)({ + addScalar, + dot, + equalScalar, + matrix, + multiplyScalar, + typed +}); +const nthRoots = exports.nthRoots = /* #__PURE__ */(0, _factoriesAny.createNthRoots)({ + Complex, + config: _configReadonly.config, + divideScalar, + typed +}); +const or = exports.or = /* #__PURE__ */(0, _factoriesAny.createOr)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +const partitionSelect = exports.partitionSelect = /* #__PURE__ */(0, _factoriesAny.createPartitionSelect)({ + compare, + isNaN, + isNumeric, + typed +}); +const rightLogShift = exports.rightLogShift = /* #__PURE__ */(0, _factoriesAny.createRightLogShift)({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +const slu = exports.slu = /* #__PURE__ */(0, _factoriesAny.createSlu)({ + SparseMatrix, + abs, + add, + divideScalar, + larger, + largerEq, + multiply, + subtract, + transpose, + typed +}); +const subset = exports.subset = /* #__PURE__ */(0, _factoriesAny.createSubset)({ + add, + matrix, + typed, + zeros +}); +const sum = exports.sum = /* #__PURE__ */(0, _factoriesAny.createSum)({ + add, + config: _configReadonly.config, + numeric, + typed +}); +const trace = exports.trace = /* #__PURE__ */(0, _factoriesAny.createTrace)({ + add, + matrix, + typed +}); +const usolveAll = exports.usolveAll = /* #__PURE__ */(0, _factoriesAny.createUsolveAll)({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +const zpk2tf = exports.zpk2tf = /* #__PURE__ */(0, _factoriesAny.createZpk2tf)({ + Complex, + add, + multiply, + number, + typed +}); +const ceil = exports.ceil = /* #__PURE__ */(0, _factoriesAny.createCeil)({ + DenseMatrix, + config: _configReadonly.config, + equalScalar, + matrix, + round, + typed, + zeros +}); +const compareNatural = exports.compareNatural = /* #__PURE__ */(0, _factoriesAny.createCompareNatural)({ + compare, + typed +}); +const composition = exports.composition = /* #__PURE__ */(0, _factoriesAny.createComposition)({ + addScalar, + combinations, + isInteger, + isNegative, + isPositive, + larger, + typed +}); +const cross = exports.cross = /* #__PURE__ */(0, _factoriesAny.createCross)({ + matrix, + multiply, + subtract, + typed +}); +const det = exports.det = /* #__PURE__ */(0, _factoriesAny.createDet)({ + divideScalar, + isZero, + matrix, + multiply, + subtractScalar, + typed, + unaryMinus +}); +const dotMultiply = exports.dotMultiply = /* #__PURE__ */(0, _factoriesAny.createDotMultiply)({ + concat, + equalScalar, + matrix, + multiplyScalar, + typed +}); +const FibonacciHeap = exports.FibonacciHeap = /* #__PURE__ */(0, _factoriesAny.createFibonacciHeapClass)({ + larger, + smaller +}); +const fix = exports.fix = /* #__PURE__ */(0, _factoriesAny.createFix)({ + Complex, + DenseMatrix, + ceil, + equalScalar, + floor, + matrix, + typed, + zeros +}); +const index = exports.index = /* #__PURE__ */(0, _factoriesAny.createIndex)({ + Index, + typed +}); +const intersect = exports.intersect = /* #__PURE__ */(0, _factoriesAny.createIntersect)({ + abs, + add, + addScalar, + config: _configReadonly.config, + divideScalar, + equalScalar, + flatten, + isNumeric, + isZero, + matrix, + multiply, + multiplyScalar, + smaller, + subtract, + typed +}); +const invmod = exports.invmod = /* #__PURE__ */(0, _factoriesAny.createInvmod)({ + BigNumber, + add, + config: _configReadonly.config, + equal, + isInteger, + mod, + smaller, + typed, + xgcd +}); +const lcm = exports.lcm = /* #__PURE__ */(0, _factoriesAny.createLcm)({ + concat, + equalScalar, + matrix, + typed +}); +const log1p = exports.log1p = /* #__PURE__ */(0, _factoriesAny.createLog1p)({ + Complex, + config: _configReadonly.config, + divideScalar, + log, + typed +}); +const max = exports.max = /* #__PURE__ */(0, _factoriesAny.createMax)({ + config: _configReadonly.config, + larger, + numeric, + typed +}); +const setCartesian = exports.setCartesian = /* #__PURE__ */(0, _factoriesAny.createSetCartesian)({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +const setDistinct = exports.setDistinct = /* #__PURE__ */(0, _factoriesAny.createSetDistinct)({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +const setIsSubset = exports.setIsSubset = /* #__PURE__ */(0, _factoriesAny.createSetIsSubset)({ + Index, + compareNatural, + size, + subset, + typed +}); +const setPowerset = exports.setPowerset = /* #__PURE__ */(0, _factoriesAny.createSetPowerset)({ + Index, + compareNatural, + size, + subset, + typed +}); +const smallerEq = exports.smallerEq = /* #__PURE__ */(0, _factoriesAny.createSmallerEq)({ + DenseMatrix, + concat, + config: _configReadonly.config, + matrix, + typed +}); +const sort = exports.sort = /* #__PURE__ */(0, _factoriesAny.createSort)({ + compare, + compareNatural, + matrix, + typed +}); +const unequal = exports.unequal = /* #__PURE__ */(0, _factoriesAny.createUnequal)({ + DenseMatrix, + concat, + config: _configReadonly.config, + equalScalar, + matrix, + typed +}); +const and = exports.and = /* #__PURE__ */(0, _factoriesAny.createAnd)({ + concat, + equalScalar, + matrix, + not, + typed, + zeros +}); +const range = exports.range = /* #__PURE__ */(0, _factoriesAny.createRange)({ + bignumber, + matrix, + add, + config: _configReadonly.config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed +}); +const row = exports.row = /* #__PURE__ */(0, _factoriesAny.createRow)({ + Index, + matrix, + range, + typed +}); +const setDifference = exports.setDifference = /* #__PURE__ */(0, _factoriesAny.createSetDifference)({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +const setMultiplicity = exports.setMultiplicity = /* #__PURE__ */(0, _factoriesAny.createSetMultiplicity)({ + Index, + compareNatural, + size, + subset, + typed +}); +const setSymDifference = exports.setSymDifference = /* #__PURE__ */(0, _factoriesAny.createSetSymDifference)({ + Index, + concat, + setDifference, + size, + subset, + typed +}); +const Spa = exports.Spa = /* #__PURE__ */(0, _factoriesAny.createSpaClass)({ + FibonacciHeap, + addScalar, + equalScalar +}); +const column = exports.column = /* #__PURE__ */(0, _factoriesAny.createColumn)({ + Index, + matrix, + range, + typed +}); +const inv = exports.inv = /* #__PURE__ */(0, _factoriesAny.createInv)({ + abs, + addScalar, + det, + divideScalar, + identity, + matrix, + multiply, + typed, + unaryMinus +}); +const lup = exports.lup = /* #__PURE__ */(0, _factoriesAny.createLup)({ + DenseMatrix, + Spa, + SparseMatrix, + abs, + addScalar, + divideScalar, + equalScalar, + larger, + matrix, + multiplyScalar, + subtractScalar, + typed, + unaryMinus +}); +const pinv = exports.pinv = /* #__PURE__ */(0, _factoriesAny.createPinv)({ + Complex, + add, + ctranspose, + deepEqual, + divideScalar, + dot, + dotDivide, + equal, + inv, + matrix, + multiply, + typed +}); +const pow = exports.pow = /* #__PURE__ */(0, _factoriesAny.createPow)({ + Complex, + config: _configReadonly.config, + fraction, + identity, + inv, + matrix, + multiply, + number, + typed +}); +const setIntersect = exports.setIntersect = /* #__PURE__ */(0, _factoriesAny.createSetIntersect)({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +const setUnion = exports.setUnion = /* #__PURE__ */(0, _factoriesAny.createSetUnion)({ + Index, + concat, + setIntersect, + setSymDifference, + size, + subset, + typed +}); +const sqrtm = exports.sqrtm = /* #__PURE__ */(0, _factoriesAny.createSqrtm)({ + abs, + add, + identity, + inv, + map, + max, + multiply, + size, + sqrt, + subtract, + typed +}); +const Unit = exports.Unit = /* #__PURE__ */(0, _factoriesAny.createUnitClass)({ + BigNumber, + Complex, + Fraction, + abs, + addScalar, + config: _configReadonly.config, + divideScalar, + equal, + fix, + format, + isNumeric, + multiplyScalar, + number, + pow, + round, + subtractScalar +}); +const vacuumImpedance = exports.vacuumImpedance = /* #__PURE__ */(0, _factoriesAny.createVacuumImpedance)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const wienDisplacement = exports.wienDisplacement = /* #__PURE__ */(0, _factoriesAny.createWienDisplacement)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const atomicMass = exports.atomicMass = /* #__PURE__ */(0, _factoriesAny.createAtomicMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const bohrMagneton = exports.bohrMagneton = /* #__PURE__ */(0, _factoriesAny.createBohrMagneton)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const boltzmann = exports.boltzmann = /* #__PURE__ */(0, _factoriesAny.createBoltzmann)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const conductanceQuantum = exports.conductanceQuantum = /* #__PURE__ */(0, _factoriesAny.createConductanceQuantum)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const coulomb = exports.coulomb = /* #__PURE__ */(0, _factoriesAny.createCoulomb)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const deuteronMass = exports.deuteronMass = /* #__PURE__ */(0, _factoriesAny.createDeuteronMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const dotPow = exports.dotPow = /* #__PURE__ */(0, _factoriesAny.createDotPow)({ + DenseMatrix, + concat, + equalScalar, + matrix, + pow, + typed +}); +const electricConstant = exports.electricConstant = /* #__PURE__ */(0, _factoriesAny.createElectricConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const elementaryCharge = exports.elementaryCharge = /* #__PURE__ */(0, _factoriesAny.createElementaryCharge)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const expm = exports.expm = /* #__PURE__ */(0, _factoriesAny.createExpm)({ + abs, + add, + identity, + inv, + multiply, + typed +}); +const faraday = exports.faraday = /* #__PURE__ */(0, _factoriesAny.createFaraday)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const fft = exports.fft = /* #__PURE__ */(0, _factoriesAny.createFft)({ + addScalar, + ceil, + conj, + divideScalar, + dotDivide, + exp, + i, + log2, + matrix, + multiplyScalar, + pow, + tau, + typed +}); +const gamma = exports.gamma = /* #__PURE__ */(0, _factoriesAny.createGamma)({ + BigNumber, + Complex, + config: _configReadonly.config, + multiplyScalar, + pow, + typed +}); +const gravitationConstant = exports.gravitationConstant = /* #__PURE__ */(0, _factoriesAny.createGravitationConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const hartreeEnergy = exports.hartreeEnergy = /* #__PURE__ */(0, _factoriesAny.createHartreeEnergy)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const ifft = exports.ifft = /* #__PURE__ */(0, _factoriesAny.createIfft)({ + conj, + dotDivide, + fft, + typed +}); +const klitzing = exports.klitzing = /* #__PURE__ */(0, _factoriesAny.createKlitzing)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const loschmidt = exports.loschmidt = /* #__PURE__ */(0, _factoriesAny.createLoschmidt)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const magneticConstant = exports.magneticConstant = /* #__PURE__ */(0, _factoriesAny.createMagneticConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const molarMass = exports.molarMass = /* #__PURE__ */(0, _factoriesAny.createMolarMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const molarPlanckConstant = exports.molarPlanckConstant = /* #__PURE__ */(0, _factoriesAny.createMolarPlanckConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const neutronMass = exports.neutronMass = /* #__PURE__ */(0, _factoriesAny.createNeutronMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const nuclearMagneton = exports.nuclearMagneton = /* #__PURE__ */(0, _factoriesAny.createNuclearMagneton)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const planckCharge = exports.planckCharge = /* #__PURE__ */(0, _factoriesAny.createPlanckCharge)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const planckLength = exports.planckLength = /* #__PURE__ */(0, _factoriesAny.createPlanckLength)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const planckTemperature = exports.planckTemperature = /* #__PURE__ */(0, _factoriesAny.createPlanckTemperature)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const protonMass = exports.protonMass = /* #__PURE__ */(0, _factoriesAny.createProtonMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const quantumOfCirculation = exports.quantumOfCirculation = /* #__PURE__ */(0, _factoriesAny.createQuantumOfCirculation)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const reducedPlanckConstant = exports.reducedPlanckConstant = /* #__PURE__ */(0, _factoriesAny.createReducedPlanckConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const rydberg = exports.rydberg = /* #__PURE__ */(0, _factoriesAny.createRydberg)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const secondRadiation = exports.secondRadiation = /* #__PURE__ */(0, _factoriesAny.createSecondRadiation)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const speedOfLight = exports.speedOfLight = /* #__PURE__ */(0, _factoriesAny.createSpeedOfLight)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const stefanBoltzmann = exports.stefanBoltzmann = /* #__PURE__ */(0, _factoriesAny.createStefanBoltzmann)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const thomsonCrossSection = exports.thomsonCrossSection = /* #__PURE__ */(0, _factoriesAny.createThomsonCrossSection)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const avogadro = exports.avogadro = /* #__PURE__ */(0, _factoriesAny.createAvogadro)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const bohrRadius = exports.bohrRadius = /* #__PURE__ */(0, _factoriesAny.createBohrRadius)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const createUnit = exports.createUnit = /* #__PURE__ */(0, _factoriesAny.createCreateUnit)({ + Unit, + typed +}); +const divide = exports.divide = /* #__PURE__ */(0, _factoriesAny.createDivide)({ + divideScalar, + equalScalar, + inv, + matrix, + multiply, + typed +}); +const electronMass = exports.electronMass = /* #__PURE__ */(0, _factoriesAny.createElectronMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const factorial = exports.factorial = /* #__PURE__ */(0, _factoriesAny.createFactorial)({ + gamma, + typed +}); +const firstRadiation = exports.firstRadiation = /* #__PURE__ */(0, _factoriesAny.createFirstRadiation)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const gravity = exports.gravity = /* #__PURE__ */(0, _factoriesAny.createGravity)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const inverseConductanceQuantum = exports.inverseConductanceQuantum = /* #__PURE__ */(0, _factoriesAny.createInverseConductanceQuantum)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const lusolve = exports.lusolve = /* #__PURE__ */(0, _factoriesAny.createLusolve)({ + DenseMatrix, + lsolve, + lup, + matrix, + slu, + typed, + usolve +}); +const magneticFluxQuantum = exports.magneticFluxQuantum = /* #__PURE__ */(0, _factoriesAny.createMagneticFluxQuantum)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const molarMassC12 = exports.molarMassC12 = /* #__PURE__ */(0, _factoriesAny.createMolarMassC12)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const multinomial = exports.multinomial = /* #__PURE__ */(0, _factoriesAny.createMultinomial)({ + add, + divide, + factorial, + isInteger, + isPositive, + multiply, + typed +}); +const permutations = exports.permutations = /* #__PURE__ */(0, _factoriesAny.createPermutations)({ + factorial, + typed +}); +const planckMass = exports.planckMass = /* #__PURE__ */(0, _factoriesAny.createPlanckMass)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const polynomialRoot = exports.polynomialRoot = /* #__PURE__ */(0, _factoriesAny.createPolynomialRoot)({ + add, + cbrt, + divide, + equalScalar, + im, + isZero, + multiply, + re, + sqrt, + subtract, + typeOf, + typed, + unaryMinus +}); +const setSize = exports.setSize = /* #__PURE__ */(0, _factoriesAny.createSetSize)({ + compareNatural, + typed +}); +const solveODE = exports.solveODE = /* #__PURE__ */(0, _factoriesAny.createSolveODE)({ + abs, + add, + bignumber, + divide, + isNegative, + isPositive, + larger, + map, + matrix, + max, + multiply, + smaller, + subtract, + typed, + unaryMinus +}); +const stirlingS2 = exports.stirlingS2 = /* #__PURE__ */(0, _factoriesAny.createStirlingS2)({ + bignumber, + addScalar, + combinations, + divideScalar, + factorial, + isInteger, + isNegative, + larger, + multiplyScalar, + number, + pow, + subtractScalar, + typed +}); +const unit = exports.unit = /* #__PURE__ */(0, _factoriesAny.createUnitFunction)({ + Unit, + typed +}); +const bellNumbers = exports.bellNumbers = /* #__PURE__ */(0, _factoriesAny.createBellNumbers)({ + addScalar, + isInteger, + isNegative, + stirlingS2, + typed +}); +const eigs = exports.eigs = /* #__PURE__ */(0, _factoriesAny.createEigs)({ + abs, + add, + addScalar, + atan, + bignumber, + column, + complex, + config: _configReadonly.config, + cos, + diag, + divideScalar, + dot, + equal, + flatten, + im, + inv, + larger, + matrix, + matrixFromColumns, + multiply, + multiplyScalar, + number, + qr, + re, + reshape, + sin, + size, + smaller, + sqrt, + subtract, + typed, + usolve, + usolveAll +}); +const fermiCoupling = exports.fermiCoupling = /* #__PURE__ */(0, _factoriesAny.createFermiCoupling)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const gasConstant = exports.gasConstant = /* #__PURE__ */(0, _factoriesAny.createGasConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const kldivergence = exports.kldivergence = /* #__PURE__ */(0, _factoriesAny.createKldivergence)({ + divide, + dotDivide, + isNumeric, + log, + map, + matrix, + multiply, + sum, + typed +}); +const mean = exports.mean = /* #__PURE__ */(0, _factoriesAny.createMean)({ + add, + divide, + typed +}); +const molarVolume = exports.molarVolume = /* #__PURE__ */(0, _factoriesAny.createMolarVolume)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const planckConstant = exports.planckConstant = /* #__PURE__ */(0, _factoriesAny.createPlanckConstant)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const quantileSeq = exports.quantileSeq = /* #__PURE__ */(0, _factoriesAny.createQuantileSeq)({ + bignumber, + add, + compare, + divide, + isInteger, + larger, + multiply, + partitionSelect, + smaller, + smallerEq, + subtract, + typed +}); +const variance = exports.variance = /* #__PURE__ */(0, _factoriesAny.createVariance)({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed +}); +const classicalElectronRadius = exports.classicalElectronRadius = /* #__PURE__ */(0, _factoriesAny.createClassicalElectronRadius)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const median = exports.median = /* #__PURE__ */(0, _factoriesAny.createMedian)({ + add, + compare, + divide, + partitionSelect, + typed +}); +const corr = exports.corr = /* #__PURE__ */(0, _factoriesAny.createCorr)({ + add, + divide, + matrix, + mean, + multiply, + pow, + sqrt, + subtract, + sum, + typed +}); +const freqz = exports.freqz = /* #__PURE__ */(0, _factoriesAny.createFreqz)({ + Complex, + add, + divide, + matrix, + multiply, + typed +}); +const mad = exports.mad = /* #__PURE__ */(0, _factoriesAny.createMad)({ + abs, + map, + median, + subtract, + typed +}); +const std = exports.std = /* #__PURE__ */(0, _factoriesAny.createStd)({ + map, + sqrt, + typed, + variance +}); +const zeta = exports.zeta = /* #__PURE__ */(0, _factoriesAny.createZeta)({ + BigNumber, + Complex, + add, + config: _configReadonly.config, + divide, + equal, + factorial, + gamma, + isNegative, + multiply, + pi, + pow, + sin, + smallerEq, + subtract, + typed +}); +const norm = exports.norm = /* #__PURE__ */(0, _factoriesAny.createNorm)({ + abs, + add, + conj, + ctranspose, + eigs, + equalScalar, + larger, + matrix, + multiply, + pow, + smaller, + sqrt, + typed +}); +const rotationMatrix = exports.rotationMatrix = /* #__PURE__ */(0, _factoriesAny.createRotationMatrix)({ + BigNumber, + DenseMatrix, + SparseMatrix, + addScalar, + config: _configReadonly.config, + cos, + matrix, + multiplyScalar, + norm, + sin, + typed, + unaryMinus +}); +const planckTime = exports.planckTime = /* #__PURE__ */(0, _factoriesAny.createPlanckTime)({ + BigNumber, + Unit, + config: _configReadonly.config +}); +const schur = exports.schur = /* #__PURE__ */(0, _factoriesAny.createSchur)({ + identity, + matrix, + multiply, + norm, + qr, + subtract, + typed +}); +const rotate = exports.rotate = /* #__PURE__ */(0, _factoriesAny.createRotate)({ + multiply, + rotationMatrix, + typed +}); +const sylvester = exports.sylvester = /* #__PURE__ */(0, _factoriesAny.createSylvester)({ + abs, + add, + concat, + identity, + index, + lusolve, + matrix, + matrixFromColumns, + multiply, + range, + schur, + subset, + subtract, + transpose, + typed +}); +const lyap = exports.lyap = /* #__PURE__ */(0, _factoriesAny.createLyap)({ + matrix, + multiply, + sylvester, + transpose, + typed +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsNumber.generated.js new file mode 100644 index 0000000..fb71fe2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/pureFunctionsNumber.generated.js @@ -0,0 +1,611 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.median = exports.mean = exports.max = exports.matrix = exports.map = exports.mad = exports.log2 = exports.log1p = exports.log10 = exports.log = exports.lgamma = exports.leftShift = exports.lcm = exports.largerEq = exports.larger = exports.isZero = exports.isPrime = exports.isPositive = exports.isNumeric = exports.isNegative = exports.isNaN = exports.isInteger = exports.index = exports.hypot = exports.hasNumericValue = exports.gcd = exports.gamma = exports.format = exports.forEach = exports.floor = exports.fix = exports.filter = exports.factorial = exports.expm1 = exports.exp = exports.erf = exports.equalText = exports.equalScalar = exports.equal = exports.e = exports.divideScalar = exports.divide = exports.deepEqual = exports.cumsum = exports.cube = exports.csch = exports.csc = exports.coth = exports.cot = exports.cosh = exports.cos = exports.corr = exports.composition = exports.compareText = exports.compareNatural = exports.compare = exports.combinationsWithRep = exports.combinations = exports.clone = exports.ceil = exports.cbrt = exports.catalan = exports.boolean = exports.bitXor = exports.bitOr = exports.bitNot = exports.bitAnd = exports.bigint = exports.bellNumbers = exports.atanh = exports.atan2 = exports.atan = exports.asinh = exports.asin = exports.asech = exports.asec = exports.apply = exports.and = exports.addScalar = exports.add = exports.acsch = exports.acsc = exports.acoth = exports.acot = exports.acosh = exports.acos = exports.abs = exports._true = exports._null = exports._false = exports._NaN = exports._Infinity = exports.SQRT2 = exports.SQRT1_2 = exports.ResultSet = exports.Range = exports.LOG2E = exports.LOG10E = exports.LN2 = exports.LN10 = void 0; +exports.zeta = exports.xor = exports.xgcd = exports.version = exports.variance = exports.unequal = exports.unaryPlus = exports.unaryMinus = exports.typed = exports.typeOf = exports.tau = exports.tanh = exports.tan = exports.sum = exports.subtractScalar = exports.subtract = exports.subset = exports.string = exports.stirlingS2 = exports.std = exports.square = exports.sqrt = exports.smallerEq = exports.smaller = exports.size = exports.sinh = exports.sin = exports.sign = exports.sech = exports.sec = exports.round = exports.rightLogShift = exports.rightArithShift = exports.replacer = exports.range = exports.randomInt = exports.random = exports.quantileSeq = exports.prod = exports.print = exports.pow = exports.pickRandom = exports.pi = exports.phi = exports.permutations = exports.partitionSelect = exports.or = exports.numeric = exports.number = exports.nthRoot = exports.not = exports.norm = exports.multiplyScalar = exports.multiply = exports.multinomial = exports.mode = exports.mod = exports.min = void 0; +var _configReadonly = require("./configReadonly.js"); +var _factoriesNumber = require("../factoriesNumber.js"); +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ + +const e = exports.e = /* #__PURE__ */(0, _factoriesNumber.createE)({ + config: _configReadonly.config +}); +const _false = exports._false = /* #__PURE__ */(0, _factoriesNumber.createFalse)({}); +const index = exports.index = /* #__PURE__ */(0, _factoriesNumber.createIndex)({}); +const _Infinity = exports._Infinity = /* #__PURE__ */(0, _factoriesNumber.createInfinity)({ + config: _configReadonly.config +}); +const LN10 = exports.LN10 = /* #__PURE__ */(0, _factoriesNumber.createLN10)({ + config: _configReadonly.config +}); +const LOG10E = exports.LOG10E = /* #__PURE__ */(0, _factoriesNumber.createLOG10E)({ + config: _configReadonly.config +}); +const matrix = exports.matrix = /* #__PURE__ */(0, _factoriesNumber.createMatrix)({}); +const _NaN = exports._NaN = /* #__PURE__ */(0, _factoriesNumber.createNaN)({ + config: _configReadonly.config +}); +const _null = exports._null = /* #__PURE__ */(0, _factoriesNumber.createNull)({}); +const phi = exports.phi = /* #__PURE__ */(0, _factoriesNumber.createPhi)({ + config: _configReadonly.config +}); +const Range = exports.Range = /* #__PURE__ */(0, _factoriesNumber.createRangeClass)({}); +const replacer = exports.replacer = /* #__PURE__ */(0, _factoriesNumber.createReplacer)({}); +const ResultSet = exports.ResultSet = /* #__PURE__ */(0, _factoriesNumber.createResultSet)({}); +const SQRT1_2 = exports.SQRT1_2 = /* #__PURE__ */(0, _factoriesNumber.createSQRT1_2)({ + config: _configReadonly.config +}); +const subset = exports.subset = /* #__PURE__ */(0, _factoriesNumber.createSubset)({}); +const tau = exports.tau = /* #__PURE__ */(0, _factoriesNumber.createTau)({ + config: _configReadonly.config +}); +const typed = exports.typed = /* #__PURE__ */(0, _factoriesNumber.createTyped)({}); +const unaryPlus = exports.unaryPlus = /* #__PURE__ */(0, _factoriesNumber.createUnaryPlus)({ + typed +}); +const version = exports.version = /* #__PURE__ */(0, _factoriesNumber.createVersion)({}); +const xor = exports.xor = /* #__PURE__ */(0, _factoriesNumber.createXor)({ + typed +}); +const abs = exports.abs = /* #__PURE__ */(0, _factoriesNumber.createAbs)({ + typed +}); +const acos = exports.acos = /* #__PURE__ */(0, _factoriesNumber.createAcos)({ + typed +}); +const acot = exports.acot = /* #__PURE__ */(0, _factoriesNumber.createAcot)({ + typed +}); +const acsc = exports.acsc = /* #__PURE__ */(0, _factoriesNumber.createAcsc)({ + typed +}); +const add = exports.add = /* #__PURE__ */(0, _factoriesNumber.createAdd)({ + typed +}); +const and = exports.and = /* #__PURE__ */(0, _factoriesNumber.createAnd)({ + typed +}); +const asec = exports.asec = /* #__PURE__ */(0, _factoriesNumber.createAsec)({ + typed +}); +const asin = exports.asin = /* #__PURE__ */(0, _factoriesNumber.createAsin)({ + typed +}); +const atan = exports.atan = /* #__PURE__ */(0, _factoriesNumber.createAtan)({ + typed +}); +const atanh = exports.atanh = /* #__PURE__ */(0, _factoriesNumber.createAtanh)({ + typed +}); +const bigint = exports.bigint = /* #__PURE__ */(0, _factoriesNumber.createBigint)({ + typed +}); +const bitNot = exports.bitNot = /* #__PURE__ */(0, _factoriesNumber.createBitNot)({ + typed +}); +const bitXor = exports.bitXor = /* #__PURE__ */(0, _factoriesNumber.createBitXor)({ + typed +}); +const boolean = exports.boolean = /* #__PURE__ */(0, _factoriesNumber.createBoolean)({ + typed +}); +const cbrt = exports.cbrt = /* #__PURE__ */(0, _factoriesNumber.createCbrt)({ + typed +}); +const combinations = exports.combinations = /* #__PURE__ */(0, _factoriesNumber.createCombinations)({ + typed +}); +const compare = exports.compare = /* #__PURE__ */(0, _factoriesNumber.createCompare)({ + config: _configReadonly.config, + typed +}); +const compareText = exports.compareText = /* #__PURE__ */(0, _factoriesNumber.createCompareText)({ + typed +}); +const cos = exports.cos = /* #__PURE__ */(0, _factoriesNumber.createCos)({ + typed +}); +const cot = exports.cot = /* #__PURE__ */(0, _factoriesNumber.createCot)({ + typed +}); +const csc = exports.csc = /* #__PURE__ */(0, _factoriesNumber.createCsc)({ + typed +}); +const cube = exports.cube = /* #__PURE__ */(0, _factoriesNumber.createCube)({ + typed +}); +const divide = exports.divide = /* #__PURE__ */(0, _factoriesNumber.createDivide)({ + typed +}); +const equalScalar = exports.equalScalar = /* #__PURE__ */(0, _factoriesNumber.createEqualScalar)({ + config: _configReadonly.config, + typed +}); +const erf = exports.erf = /* #__PURE__ */(0, _factoriesNumber.createErf)({ + typed +}); +const exp = exports.exp = /* #__PURE__ */(0, _factoriesNumber.createExp)({ + typed +}); +const filter = exports.filter = /* #__PURE__ */(0, _factoriesNumber.createFilter)({ + typed +}); +const forEach = exports.forEach = /* #__PURE__ */(0, _factoriesNumber.createForEach)({ + typed +}); +const format = exports.format = /* #__PURE__ */(0, _factoriesNumber.createFormat)({ + typed +}); +const gamma = exports.gamma = /* #__PURE__ */(0, _factoriesNumber.createGamma)({ + typed +}); +const isInteger = exports.isInteger = /* #__PURE__ */(0, _factoriesNumber.createIsInteger)({ + typed +}); +const isNegative = exports.isNegative = /* #__PURE__ */(0, _factoriesNumber.createIsNegative)({ + typed +}); +const isPositive = exports.isPositive = /* #__PURE__ */(0, _factoriesNumber.createIsPositive)({ + typed +}); +const isZero = exports.isZero = /* #__PURE__ */(0, _factoriesNumber.createIsZero)({ + typed +}); +const LOG2E = exports.LOG2E = /* #__PURE__ */(0, _factoriesNumber.createLOG2E)({ + config: _configReadonly.config +}); +const largerEq = exports.largerEq = /* #__PURE__ */(0, _factoriesNumber.createLargerEq)({ + config: _configReadonly.config, + typed +}); +const leftShift = exports.leftShift = /* #__PURE__ */(0, _factoriesNumber.createLeftShift)({ + typed +}); +const log = exports.log = /* #__PURE__ */(0, _factoriesNumber.createLog)({ + typed +}); +const log1p = exports.log1p = /* #__PURE__ */(0, _factoriesNumber.createLog1p)({ + typed +}); +const map = exports.map = /* #__PURE__ */(0, _factoriesNumber.createMap)({ + typed +}); +const mean = exports.mean = /* #__PURE__ */(0, _factoriesNumber.createMean)({ + add, + divide, + typed +}); +const mod = exports.mod = /* #__PURE__ */(0, _factoriesNumber.createMod)({ + typed +}); +const multiply = exports.multiply = /* #__PURE__ */(0, _factoriesNumber.createMultiply)({ + typed +}); +const not = exports.not = /* #__PURE__ */(0, _factoriesNumber.createNot)({ + typed +}); +const number = exports.number = /* #__PURE__ */(0, _factoriesNumber.createNumber)({ + typed +}); +const or = exports.or = /* #__PURE__ */(0, _factoriesNumber.createOr)({ + typed +}); +const pi = exports.pi = /* #__PURE__ */(0, _factoriesNumber.createPi)({ + config: _configReadonly.config +}); +const pow = exports.pow = /* #__PURE__ */(0, _factoriesNumber.createPow)({ + typed +}); +const random = exports.random = /* #__PURE__ */(0, _factoriesNumber.createRandom)({ + config: _configReadonly.config, + typed +}); +const rightLogShift = exports.rightLogShift = /* #__PURE__ */(0, _factoriesNumber.createRightLogShift)({ + typed +}); +const SQRT2 = exports.SQRT2 = /* #__PURE__ */(0, _factoriesNumber.createSQRT2)({ + config: _configReadonly.config +}); +const sech = exports.sech = /* #__PURE__ */(0, _factoriesNumber.createSech)({ + typed +}); +const sin = exports.sin = /* #__PURE__ */(0, _factoriesNumber.createSin)({ + typed +}); +const size = exports.size = /* #__PURE__ */(0, _factoriesNumber.createSize)({ + matrix, + config: _configReadonly.config, + typed +}); +const smallerEq = exports.smallerEq = /* #__PURE__ */(0, _factoriesNumber.createSmallerEq)({ + config: _configReadonly.config, + typed +}); +const square = exports.square = /* #__PURE__ */(0, _factoriesNumber.createSquare)({ + typed +}); +const string = exports.string = /* #__PURE__ */(0, _factoriesNumber.createString)({ + typed +}); +const subtract = exports.subtract = /* #__PURE__ */(0, _factoriesNumber.createSubtract)({ + typed +}); +const tanh = exports.tanh = /* #__PURE__ */(0, _factoriesNumber.createTanh)({ + typed +}); +const typeOf = exports.typeOf = /* #__PURE__ */(0, _factoriesNumber.createTypeOf)({ + typed +}); +const unequal = exports.unequal = /* #__PURE__ */(0, _factoriesNumber.createUnequal)({ + equalScalar, + typed +}); +const xgcd = exports.xgcd = /* #__PURE__ */(0, _factoriesNumber.createXgcd)({ + typed +}); +const acoth = exports.acoth = /* #__PURE__ */(0, _factoriesNumber.createAcoth)({ + typed +}); +const addScalar = exports.addScalar = /* #__PURE__ */(0, _factoriesNumber.createAddScalar)({ + typed +}); +const asech = exports.asech = /* #__PURE__ */(0, _factoriesNumber.createAsech)({ + typed +}); +const bitAnd = exports.bitAnd = /* #__PURE__ */(0, _factoriesNumber.createBitAnd)({ + typed +}); +const combinationsWithRep = exports.combinationsWithRep = /* #__PURE__ */(0, _factoriesNumber.createCombinationsWithRep)({ + typed +}); +const cosh = exports.cosh = /* #__PURE__ */(0, _factoriesNumber.createCosh)({ + typed +}); +const csch = exports.csch = /* #__PURE__ */(0, _factoriesNumber.createCsch)({ + typed +}); +const divideScalar = exports.divideScalar = /* #__PURE__ */(0, _factoriesNumber.createDivideScalar)({ + typed +}); +const equalText = exports.equalText = /* #__PURE__ */(0, _factoriesNumber.createEqualText)({ + compareText, + isZero, + typed +}); +const expm1 = exports.expm1 = /* #__PURE__ */(0, _factoriesNumber.createExpm1)({ + typed +}); +const isNumeric = exports.isNumeric = /* #__PURE__ */(0, _factoriesNumber.createIsNumeric)({ + typed +}); +const LN2 = exports.LN2 = /* #__PURE__ */(0, _factoriesNumber.createLN2)({ + config: _configReadonly.config +}); +const lcm = exports.lcm = /* #__PURE__ */(0, _factoriesNumber.createLcm)({ + typed +}); +const log10 = exports.log10 = /* #__PURE__ */(0, _factoriesNumber.createLog10)({ + typed +}); +const multiplyScalar = exports.multiplyScalar = /* #__PURE__ */(0, _factoriesNumber.createMultiplyScalar)({ + typed +}); +const nthRoot = exports.nthRoot = /* #__PURE__ */(0, _factoriesNumber.createNthRoot)({ + typed +}); +const pickRandom = exports.pickRandom = /* #__PURE__ */(0, _factoriesNumber.createPickRandom)({ + config: _configReadonly.config, + typed +}); +const randomInt = exports.randomInt = /* #__PURE__ */(0, _factoriesNumber.createRandomInt)({ + config: _configReadonly.config, + typed +}); +const rightArithShift = exports.rightArithShift = /* #__PURE__ */(0, _factoriesNumber.createRightArithShift)({ + typed +}); +const sec = exports.sec = /* #__PURE__ */(0, _factoriesNumber.createSec)({ + typed +}); +const sinh = exports.sinh = /* #__PURE__ */(0, _factoriesNumber.createSinh)({ + typed +}); +const sqrt = exports.sqrt = /* #__PURE__ */(0, _factoriesNumber.createSqrt)({ + typed +}); +const tan = exports.tan = /* #__PURE__ */(0, _factoriesNumber.createTan)({ + typed +}); +const unaryMinus = exports.unaryMinus = /* #__PURE__ */(0, _factoriesNumber.createUnaryMinus)({ + typed +}); +const acosh = exports.acosh = /* #__PURE__ */(0, _factoriesNumber.createAcosh)({ + typed +}); +const apply = exports.apply = /* #__PURE__ */(0, _factoriesNumber.createApply)({ + isInteger, + typed +}); +const asinh = exports.asinh = /* #__PURE__ */(0, _factoriesNumber.createAsinh)({ + typed +}); +const bitOr = exports.bitOr = /* #__PURE__ */(0, _factoriesNumber.createBitOr)({ + typed +}); +const clone = exports.clone = /* #__PURE__ */(0, _factoriesNumber.createClone)({ + typed +}); +const coth = exports.coth = /* #__PURE__ */(0, _factoriesNumber.createCoth)({ + typed +}); +const equal = exports.equal = /* #__PURE__ */(0, _factoriesNumber.createEqual)({ + equalScalar, + typed +}); +const factorial = exports.factorial = /* #__PURE__ */(0, _factoriesNumber.createFactorial)({ + gamma, + typed +}); +const hasNumericValue = exports.hasNumericValue = /* #__PURE__ */(0, _factoriesNumber.createHasNumericValue)({ + isNumeric, + typed +}); +const isNaN = exports.isNaN = /* #__PURE__ */(0, _factoriesNumber.createIsNaN)({ + typed +}); +const larger = exports.larger = /* #__PURE__ */(0, _factoriesNumber.createLarger)({ + config: _configReadonly.config, + typed +}); +const log2 = exports.log2 = /* #__PURE__ */(0, _factoriesNumber.createLog2)({ + typed +}); +const mode = exports.mode = /* #__PURE__ */(0, _factoriesNumber.createMode)({ + isNaN, + isNumeric, + typed +}); +const norm = exports.norm = /* #__PURE__ */(0, _factoriesNumber.createNorm)({ + typed +}); +const partitionSelect = exports.partitionSelect = /* #__PURE__ */(0, _factoriesNumber.createPartitionSelect)({ + compare, + isNaN, + isNumeric, + typed +}); +const print = exports.print = /* #__PURE__ */(0, _factoriesNumber.createPrint)({ + typed +}); +const round = exports.round = /* #__PURE__ */(0, _factoriesNumber.createRound)({ + typed +}); +const smaller = exports.smaller = /* #__PURE__ */(0, _factoriesNumber.createSmaller)({ + config: _configReadonly.config, + typed +}); +const subtractScalar = exports.subtractScalar = /* #__PURE__ */(0, _factoriesNumber.createSubtractScalar)({ + typed +}); +const _true = exports._true = /* #__PURE__ */(0, _factoriesNumber.createTrue)({}); +const variance = exports.variance = /* #__PURE__ */(0, _factoriesNumber.createVariance)({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed +}); +const zeta = exports.zeta = /* #__PURE__ */(0, _factoriesNumber.createZeta)({ + add, + config: _configReadonly.config, + divide, + equal, + factorial, + gamma, + isNegative, + multiply, + pi, + pow, + sin, + smallerEq, + subtract, + typed +}); +const acsch = exports.acsch = /* #__PURE__ */(0, _factoriesNumber.createAcsch)({ + typed +}); +const atan2 = exports.atan2 = /* #__PURE__ */(0, _factoriesNumber.createAtan2)({ + typed +}); +const catalan = exports.catalan = /* #__PURE__ */(0, _factoriesNumber.createCatalan)({ + addScalar, + combinations, + divideScalar, + isInteger, + isNegative, + multiplyScalar, + typed +}); +const compareNatural = exports.compareNatural = /* #__PURE__ */(0, _factoriesNumber.createCompareNatural)({ + compare, + typed +}); +const composition = exports.composition = /* #__PURE__ */(0, _factoriesNumber.createComposition)({ + addScalar, + combinations, + isInteger, + isNegative, + isPositive, + larger, + typed +}); +const cumsum = exports.cumsum = /* #__PURE__ */(0, _factoriesNumber.createCumSum)({ + add, + typed, + unaryPlus +}); +const floor = exports.floor = /* #__PURE__ */(0, _factoriesNumber.createFloor)({ + config: _configReadonly.config, + round, + typed +}); +const hypot = exports.hypot = /* #__PURE__ */(0, _factoriesNumber.createHypot)({ + abs, + addScalar, + divideScalar, + isPositive, + multiplyScalar, + smaller, + sqrt, + typed +}); +const lgamma = exports.lgamma = /* #__PURE__ */(0, _factoriesNumber.createLgamma)({ + typed +}); +const median = exports.median = /* #__PURE__ */(0, _factoriesNumber.createMedian)({ + add, + compare, + divide, + partitionSelect, + typed +}); +const multinomial = exports.multinomial = /* #__PURE__ */(0, _factoriesNumber.createMultinomial)({ + add, + divide, + factorial, + isInteger, + isPositive, + multiply, + typed +}); +const permutations = exports.permutations = /* #__PURE__ */(0, _factoriesNumber.createPermutations)({ + factorial, + typed +}); +const quantileSeq = exports.quantileSeq = /* #__PURE__ */(0, _factoriesNumber.createQuantileSeq)({ + add, + compare, + divide, + isInteger, + larger, + multiply, + partitionSelect, + smaller, + smallerEq, + subtract, + typed +}); +const sign = exports.sign = /* #__PURE__ */(0, _factoriesNumber.createSign)({ + typed +}); +const std = exports.std = /* #__PURE__ */(0, _factoriesNumber.createStd)({ + map, + sqrt, + typed, + variance +}); +const stirlingS2 = exports.stirlingS2 = /* #__PURE__ */(0, _factoriesNumber.createStirlingS2)({ + addScalar, + combinations, + divideScalar, + factorial, + isInteger, + isNegative, + larger, + multiplyScalar, + number, + pow, + subtractScalar, + typed +}); +const ceil = exports.ceil = /* #__PURE__ */(0, _factoriesNumber.createCeil)({ + config: _configReadonly.config, + round, + typed +}); +const deepEqual = exports.deepEqual = /* #__PURE__ */(0, _factoriesNumber.createDeepEqual)({ + equal, + typed +}); +const fix = exports.fix = /* #__PURE__ */(0, _factoriesNumber.createFix)({ + ceil, + floor, + typed +}); +const isPrime = exports.isPrime = /* #__PURE__ */(0, _factoriesNumber.createIsPrime)({ + typed +}); +const numeric = exports.numeric = /* #__PURE__ */(0, _factoriesNumber.createNumeric)({ + number +}); +const prod = exports.prod = /* #__PURE__ */(0, _factoriesNumber.createProd)({ + config: _configReadonly.config, + multiplyScalar, + numeric, + typed +}); +const bellNumbers = exports.bellNumbers = /* #__PURE__ */(0, _factoriesNumber.createBellNumbers)({ + addScalar, + isInteger, + isNegative, + stirlingS2, + typed +}); +const gcd = exports.gcd = /* #__PURE__ */(0, _factoriesNumber.createGcd)({ + typed +}); +const mad = exports.mad = /* #__PURE__ */(0, _factoriesNumber.createMad)({ + abs, + map, + median, + subtract, + typed +}); +const range = exports.range = /* #__PURE__ */(0, _factoriesNumber.createRange)({ + matrix, + add, + config: _configReadonly.config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed +}); +const sum = exports.sum = /* #__PURE__ */(0, _factoriesNumber.createSum)({ + add, + config: _configReadonly.config, + numeric, + typed +}); +const corr = exports.corr = /* #__PURE__ */(0, _factoriesNumber.createCorr)({ + add, + divide, + matrix, + mean, + multiply, + pow, + sqrt, + subtract, + sum, + typed +}); +const max = exports.max = /* #__PURE__ */(0, _factoriesNumber.createMax)({ + config: _configReadonly.config, + larger, + numeric, + typed +}); +const min = exports.min = /* #__PURE__ */(0, _factoriesNumber.createMin)({ + config: _configReadonly.config, + numeric, + smaller, + typed +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/typeChecks.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/typeChecks.js new file mode 100644 index 0000000..44c58bf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/entry/typeChecks.js @@ -0,0 +1,264 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +Object.defineProperty(exports, "isAccessorNode", { + enumerable: true, + get: function () { + return _is.isAccessorNode; + } +}); +Object.defineProperty(exports, "isArray", { + enumerable: true, + get: function () { + return _is.isArray; + } +}); +Object.defineProperty(exports, "isArrayNode", { + enumerable: true, + get: function () { + return _is.isArrayNode; + } +}); +Object.defineProperty(exports, "isAssignmentNode", { + enumerable: true, + get: function () { + return _is.isAssignmentNode; + } +}); +Object.defineProperty(exports, "isBigInt", { + enumerable: true, + get: function () { + return _is.isBigInt; + } +}); +Object.defineProperty(exports, "isBigNumber", { + enumerable: true, + get: function () { + return _is.isBigNumber; + } +}); +Object.defineProperty(exports, "isBlockNode", { + enumerable: true, + get: function () { + return _is.isBlockNode; + } +}); +Object.defineProperty(exports, "isBoolean", { + enumerable: true, + get: function () { + return _is.isBoolean; + } +}); +Object.defineProperty(exports, "isChain", { + enumerable: true, + get: function () { + return _is.isChain; + } +}); +Object.defineProperty(exports, "isCollection", { + enumerable: true, + get: function () { + return _is.isCollection; + } +}); +Object.defineProperty(exports, "isComplex", { + enumerable: true, + get: function () { + return _is.isComplex; + } +}); +Object.defineProperty(exports, "isConditionalNode", { + enumerable: true, + get: function () { + return _is.isConditionalNode; + } +}); +Object.defineProperty(exports, "isConstantNode", { + enumerable: true, + get: function () { + return _is.isConstantNode; + } +}); +Object.defineProperty(exports, "isDate", { + enumerable: true, + get: function () { + return _is.isDate; + } +}); +Object.defineProperty(exports, "isDenseMatrix", { + enumerable: true, + get: function () { + return _is.isDenseMatrix; + } +}); +Object.defineProperty(exports, "isFraction", { + enumerable: true, + get: function () { + return _is.isFraction; + } +}); +Object.defineProperty(exports, "isFunction", { + enumerable: true, + get: function () { + return _is.isFunction; + } +}); +Object.defineProperty(exports, "isFunctionAssignmentNode", { + enumerable: true, + get: function () { + return _is.isFunctionAssignmentNode; + } +}); +Object.defineProperty(exports, "isFunctionNode", { + enumerable: true, + get: function () { + return _is.isFunctionNode; + } +}); +Object.defineProperty(exports, "isHelp", { + enumerable: true, + get: function () { + return _is.isHelp; + } +}); +Object.defineProperty(exports, "isIndex", { + enumerable: true, + get: function () { + return _is.isIndex; + } +}); +Object.defineProperty(exports, "isIndexNode", { + enumerable: true, + get: function () { + return _is.isIndexNode; + } +}); +Object.defineProperty(exports, "isMap", { + enumerable: true, + get: function () { + return _is.isMap; + } +}); +Object.defineProperty(exports, "isMatrix", { + enumerable: true, + get: function () { + return _is.isMatrix; + } +}); +Object.defineProperty(exports, "isNode", { + enumerable: true, + get: function () { + return _is.isNode; + } +}); +Object.defineProperty(exports, "isNull", { + enumerable: true, + get: function () { + return _is.isNull; + } +}); +Object.defineProperty(exports, "isNumber", { + enumerable: true, + get: function () { + return _is.isNumber; + } +}); +Object.defineProperty(exports, "isObject", { + enumerable: true, + get: function () { + return _is.isObject; + } +}); +Object.defineProperty(exports, "isObjectNode", { + enumerable: true, + get: function () { + return _is.isObjectNode; + } +}); +Object.defineProperty(exports, "isObjectWrappingMap", { + enumerable: true, + get: function () { + return _is.isObjectWrappingMap; + } +}); +Object.defineProperty(exports, "isOperatorNode", { + enumerable: true, + get: function () { + return _is.isOperatorNode; + } +}); +Object.defineProperty(exports, "isParenthesisNode", { + enumerable: true, + get: function () { + return _is.isParenthesisNode; + } +}); +Object.defineProperty(exports, "isPartitionedMap", { + enumerable: true, + get: function () { + return _is.isPartitionedMap; + } +}); +Object.defineProperty(exports, "isRange", { + enumerable: true, + get: function () { + return _is.isRange; + } +}); +Object.defineProperty(exports, "isRangeNode", { + enumerable: true, + get: function () { + return _is.isRangeNode; + } +}); +Object.defineProperty(exports, "isRegExp", { + enumerable: true, + get: function () { + return _is.isRegExp; + } +}); +Object.defineProperty(exports, "isRelationalNode", { + enumerable: true, + get: function () { + return _is.isRelationalNode; + } +}); +Object.defineProperty(exports, "isResultSet", { + enumerable: true, + get: function () { + return _is.isResultSet; + } +}); +Object.defineProperty(exports, "isSparseMatrix", { + enumerable: true, + get: function () { + return _is.isSparseMatrix; + } +}); +Object.defineProperty(exports, "isString", { + enumerable: true, + get: function () { + return _is.isString; + } +}); +Object.defineProperty(exports, "isSymbolNode", { + enumerable: true, + get: function () { + return _is.isSymbolNode; + } +}); +Object.defineProperty(exports, "isUndefined", { + enumerable: true, + get: function () { + return _is.isUndefined; + } +}); +Object.defineProperty(exports, "isUnit", { + enumerable: true, + get: function () { + return _is.isUnit; + } +}); +var _is = require("../utils/is.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/ArgumentsError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/ArgumentsError.js new file mode 100644 index 0000000..78e6de7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/ArgumentsError.js @@ -0,0 +1,30 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ArgumentsError = ArgumentsError; +/** + * Create a syntax error with the message: + * 'Wrong number of arguments in function ( provided, - expected)' + * @param {string} fn Function name + * @param {number} count Actual argument count + * @param {number} min Minimum required argument count + * @param {number} [max] Maximum required argument count + * @extends Error + */ +function ArgumentsError(fn, count, min, max) { + if (!(this instanceof ArgumentsError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.fn = fn; + this.count = count; + this.min = min; + this.max = max; + this.message = 'Wrong number of arguments in function ' + fn + ' (' + count + ' provided, ' + min + (max !== undefined && max !== null ? '-' + max : '') + ' expected)'; + this.stack = new Error().stack; +} +ArgumentsError.prototype = new Error(); +ArgumentsError.prototype.constructor = Error; +ArgumentsError.prototype.name = 'ArgumentsError'; +ArgumentsError.prototype.isArgumentsError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/DimensionError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/DimensionError.js new file mode 100644 index 0000000..821d407 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/DimensionError.js @@ -0,0 +1,29 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.DimensionError = DimensionError; +/** + * Create a range error with the message: + * 'Dimension mismatch ( != )' + * @param {number | number[]} actual The actual size + * @param {number | number[]} expected The expected size + * @param {string} [relation='!='] Optional relation between actual + * and expected size: '!=', '<', etc. + * @extends RangeError + */ +function DimensionError(actual, expected, relation) { + if (!(this instanceof DimensionError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.actual = actual; + this.expected = expected; + this.relation = relation; + this.message = 'Dimension mismatch (' + (Array.isArray(actual) ? '[' + actual.join(', ') + ']' : actual) + ' ' + (this.relation || '!=') + ' ' + (Array.isArray(expected) ? '[' + expected.join(', ') + ']' : expected) + ')'; + this.stack = new Error().stack; +} +DimensionError.prototype = new RangeError(); +DimensionError.prototype.constructor = RangeError; +DimensionError.prototype.name = 'DimensionError'; +DimensionError.prototype.isDimensionError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/IndexError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/IndexError.js new file mode 100644 index 0000000..ec6c794 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/error/IndexError.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.IndexError = IndexError; +/** + * Create a range error with the message: + * 'Index out of range (index < min)' + * 'Index out of range (index < max)' + * + * @param {number} index The actual index + * @param {number} [min=0] Minimum index (included) + * @param {number} [max] Maximum index (excluded) + * @extends RangeError + */ +function IndexError(index, min, max) { + if (!(this instanceof IndexError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.index = index; + if (arguments.length < 3) { + this.min = 0; + this.max = min; + } else { + this.min = min; + this.max = max; + } + if (this.min !== undefined && this.index < this.min) { + this.message = 'Index out of range (' + this.index + ' < ' + this.min + ')'; + } else if (this.max !== undefined && this.index >= this.max) { + this.message = 'Index out of range (' + this.index + ' > ' + (this.max - 1) + ')'; + } else { + this.message = 'Index out of range (' + this.index + ')'; + } + this.stack = new Error().stack; +} +IndexError.prototype = new RangeError(); +IndexError.prototype.constructor = RangeError; +IndexError.prototype.name = 'IndexError'; +IndexError.prototype.isIndexError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Help.js new file mode 100644 index 0000000..a5269c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Help.js @@ -0,0 +1,138 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createHelpClass = void 0; +var _is = require("../utils/is.js"); +var _object = require("../utils/object.js"); +var _string = require("../utils/string.js"); +var _factory = require("../utils/factory.js"); +const name = 'Help'; +const dependencies = ['evaluate']; +const createHelpClass = exports.createHelpClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + evaluate + } = _ref; + /** + * Documentation object + * @param {Object} doc Object containing properties: + * {string} name + * {string} category + * {string} description + * {string[]} syntax + * {string[]} examples + * {string[]} seealso + * @constructor + */ + function Help(doc) { + if (!(this instanceof Help)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (!doc) throw new Error('Argument "doc" missing'); + this.doc = doc; + } + + /** + * Attach type information + */ + Help.prototype.type = 'Help'; + Help.prototype.isHelp = true; + + /** + * Generate a string representation of the Help object + * @return {string} Returns a string + * @private + */ + Help.prototype.toString = function () { + const doc = this.doc || {}; + let desc = '\n'; + if (doc.name) { + desc += 'Name: ' + doc.name + '\n\n'; + } + if (doc.category) { + desc += 'Category: ' + doc.category + '\n\n'; + } + if (doc.description) { + desc += 'Description:\n ' + doc.description + '\n\n'; + } + if (doc.syntax) { + desc += 'Syntax:\n ' + doc.syntax.join('\n ') + '\n\n'; + } + if (doc.examples) { + desc += 'Examples:\n'; + + // after evaluating the examples, we restore config in case the examples + // did change the config. + let configChanged = false; + const originalConfig = evaluate('config()'); + const scope = { + config: newConfig => { + configChanged = true; + return evaluate('config(newConfig)', { + newConfig + }); + } + }; + for (let i = 0; i < doc.examples.length; i++) { + const expr = doc.examples[i]; + desc += ' ' + expr + '\n'; + let res; + try { + // note: res can be undefined when `expr` is an empty string + res = evaluate(expr, scope); + } catch (e) { + res = e; + } + if (res !== undefined && !(0, _is.isHelp)(res)) { + desc += ' ' + (0, _string.format)(res, { + precision: 14 + }) + '\n'; + } + } + desc += '\n'; + if (configChanged) { + evaluate('config(originalConfig)', { + originalConfig + }); + } + } + if (doc.mayThrow && doc.mayThrow.length) { + desc += 'Throws: ' + doc.mayThrow.join(', ') + '\n\n'; + } + if (doc.seealso && doc.seealso.length) { + desc += 'See also: ' + doc.seealso.join(', ') + '\n'; + } + return desc; + }; + + /** + * Export the help object to JSON + */ + Help.prototype.toJSON = function () { + const obj = (0, _object.clone)(this.doc); + obj.mathjs = 'Help'; + return obj; + }; + + /** + * Instantiate a Help object from a JSON object + * @param {Object} json + * @returns {Help} Returns a new Help object + */ + Help.fromJSON = function (json) { + const doc = {}; + Object.keys(json).filter(prop => prop !== 'mathjs').forEach(prop => { + doc[prop] = json[prop]; + }); + return new Help(doc); + }; + + /** + * Returns a string representation of the Help object + */ + Help.prototype.valueOf = Help.prototype.toString; + return Help; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Parser.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Parser.js new file mode 100644 index 0000000..d6bcb8e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/Parser.js @@ -0,0 +1,147 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createParserClass = void 0; +var _factory = require("../utils/factory.js"); +var _map = require("../utils/map.js"); +const name = 'Parser'; +const dependencies = ['evaluate']; +const createParserClass = exports.createParserClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + evaluate + } = _ref; + /** + * @constructor Parser + * Parser contains methods to evaluate or parse expressions, and has a number + * of convenience methods to get, set, and remove variables from memory. Parser + * keeps a scope containing variables in memory, which is used for all + * evaluations. + * + * Methods: + * const result = parser.evaluate(expr) // evaluate an expression + * const value = parser.get(name) // retrieve a variable from the parser + * const values = parser.getAll() // retrieve all defined variables + * parser.set(name, value) // set a variable in the parser + * parser.remove(name) // clear a variable from the + * // parsers scope + * parser.clear() // clear the parsers scope + * + * Example usage: + * const parser = new Parser() + * // Note: there is a convenience method which can be used instead: + * // const parser = new math.parser() + * + * // evaluate expressions + * parser.evaluate('sqrt(3^2 + 4^2)') // 5 + * parser.evaluate('sqrt(-4)') // 2i + * parser.evaluate('2 inch in cm') // 5.08 cm + * parser.evaluate('cos(45 deg)') // 0.7071067811865476 + * + * // define variables and functions + * parser.evaluate('x = 7 / 2') // 3.5 + * parser.evaluate('x + 3') // 6.5 + * parser.evaluate('f(x, y) = x^y') // f(x, y) + * parser.evaluate('f(2, 3)') // 8 + * + * // get and set variables and functions + * const x = parser.get('x') // 3.5 + * const f = parser.get('f') // function + * const g = f(3, 2) // 9 + * parser.set('h', 500) + * const i = parser.evaluate('h / 2') // 250 + * parser.set('hello', function (name) { + * return 'hello, ' + name + '!' + * }) + * parser.evaluate('hello("user")') // "hello, user!" + * + * // clear defined functions and variables + * parser.clear() + * + */ + function Parser() { + if (!(this instanceof Parser)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + Object.defineProperty(this, 'scope', { + value: (0, _map.createEmptyMap)(), + writable: false + }); + } + + /** + * Attach type information + */ + Parser.prototype.type = 'Parser'; + Parser.prototype.isParser = true; + + /** + * Parse and evaluate the given expression + * @param {string | string[]} expr A string containing an expression, + * for example "2+3", or a list with expressions + * @return {*} result The result, or undefined when the expression was empty + * @throws {Error} + */ + Parser.prototype.evaluate = function (expr) { + // TODO: validate arguments + return evaluate(expr, this.scope); + }; + + /** + * Get a variable (a function or variable) by name from the parsers scope. + * Returns undefined when not found + * @param {string} name + * @return {* | undefined} value + */ + Parser.prototype.get = function (name) { + // TODO: validate arguments + if (this.scope.has(name)) { + return this.scope.get(name); + } + }; + + /** + * Get a map with all defined variables + * @return {Object} values + */ + Parser.prototype.getAll = function () { + return (0, _map.toObject)(this.scope); + }; + + /** + * Get a map with all defined variables + * @return {Map} values + */ + Parser.prototype.getAllAsMap = function () { + return this.scope; + }; + + /** + * Set a symbol (a function or variable) by name from the parsers scope. + * @param {string} name + * @param {* | undefined} value + */ + Parser.prototype.set = function (name, value) { + this.scope.set(name, value); + return value; + }; + + /** + * Remove a variable from the parsers scope + * @param {string} name + */ + Parser.prototype.remove = function (name) { + this.scope.delete(name); + }; + + /** + * Clear the scope with variables and functions + */ + Parser.prototype.clear = function () { + this.scope.clear(); + }; + return Parser; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/Infinity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/Infinity.js new file mode 100644 index 0000000..0d196e7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/Infinity.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.InfinityDocs = void 0; +const InfinityDocs = exports.InfinityDocs = { + name: 'Infinity', + category: 'Constants', + syntax: ['Infinity'], + description: 'Infinity, a number which is larger than the maximum number that can be handled by a floating point number.', + examples: ['Infinity', '1 / 0'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN10.js new file mode 100644 index 0000000..cb72ec4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN10.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN10Docs = void 0; +const LN10Docs = exports.LN10Docs = { + name: 'LN10', + category: 'Constants', + syntax: ['LN10'], + description: 'Returns the natural logarithm of 10, approximately equal to 2.302', + examples: ['LN10', 'log(10)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN2.js new file mode 100644 index 0000000..8e02ef2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LN2Docs = void 0; +const LN2Docs = exports.LN2Docs = { + name: 'LN2', + category: 'Constants', + syntax: ['LN2'], + description: 'Returns the natural logarithm of 2, approximately equal to 0.693', + examples: ['LN2', 'log(2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG10E.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG10E.js new file mode 100644 index 0000000..b8f4e1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG10E.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG10EDocs = void 0; +const LOG10EDocs = exports.LOG10EDocs = { + name: 'LOG10E', + category: 'Constants', + syntax: ['LOG10E'], + description: 'Returns the base-10 logarithm of E, approximately equal to 0.434', + examples: ['LOG10E', 'log(e, 10)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG2E.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG2E.js new file mode 100644 index 0000000..9ed7b87 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG2E.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.LOG2EDocs = void 0; +const LOG2EDocs = exports.LOG2EDocs = { + name: 'LOG2E', + category: 'Constants', + syntax: ['LOG2E'], + description: 'Returns the base-2 logarithm of E, approximately equal to 1.442', + examples: ['LOG2E', 'log(e, 2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/NaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/NaN.js new file mode 100644 index 0000000..adab0d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/NaN.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.NaNDocs = void 0; +const NaNDocs = exports.NaNDocs = { + name: 'NaN', + category: 'Constants', + syntax: ['NaN'], + description: 'Not a number', + examples: ['NaN', '0 / 0'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT1_2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT1_2.js new file mode 100644 index 0000000..76d2977 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT1_2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT12Docs = void 0; +const SQRT12Docs = exports.SQRT12Docs = { + name: 'SQRT1_2', + category: 'Constants', + syntax: ['SQRT1_2'], + description: 'Returns the square root of 1/2, approximately equal to 0.707', + examples: ['SQRT1_2', 'sqrt(1/2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT2.js new file mode 100644 index 0000000..c119c71 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.SQRT2Docs = void 0; +const SQRT2Docs = exports.SQRT2Docs = { + name: 'SQRT2', + category: 'Constants', + syntax: ['SQRT2'], + description: 'Returns the square root of 2, approximately equal to 1.414', + examples: ['SQRT2', 'sqrt(2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/e.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/e.js new file mode 100644 index 0000000..efd8222 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/e.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.eDocs = void 0; +const eDocs = exports.eDocs = { + name: 'e', + category: 'Constants', + syntax: ['e'], + description: 'Euler\'s number, the base of the natural logarithm. Approximately equal to 2.71828', + examples: ['e', 'e ^ 2', 'exp(2)', 'log(e)'], + seealso: ['exp'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/false.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/false.js new file mode 100644 index 0000000..37d4bbb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/false.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.falseDocs = void 0; +const falseDocs = exports.falseDocs = { + name: 'false', + category: 'Constants', + syntax: ['false'], + description: 'Boolean value false', + examples: ['false'], + seealso: ['true'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/i.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/i.js new file mode 100644 index 0000000..b0c0f4f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/i.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.iDocs = void 0; +const iDocs = exports.iDocs = { + name: 'i', + category: 'Constants', + syntax: ['i'], + description: 'Imaginary unit, defined as i*i=-1. A complex number is described as a + b*i, where a is the real part, and b is the imaginary part.', + examples: ['i', 'i * i', 'sqrt(-1)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/null.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/null.js new file mode 100644 index 0000000..250eca4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/null.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nullDocs = void 0; +const nullDocs = exports.nullDocs = { + name: 'null', + category: 'Constants', + syntax: ['null'], + description: 'Value null', + examples: ['null'], + seealso: ['true', 'false'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/phi.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/phi.js new file mode 100644 index 0000000..46175cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/phi.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.phiDocs = void 0; +const phiDocs = exports.phiDocs = { + name: 'phi', + category: 'Constants', + syntax: ['phi'], + description: 'Phi is the golden ratio. Two quantities are in the golden ratio if their ratio is the same as the ratio of their sum to the larger of the two quantities. Phi is defined as `(1 + sqrt(5)) / 2` and is approximately 1.618034...', + examples: ['phi'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/pi.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/pi.js new file mode 100644 index 0000000..d7b6bea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/pi.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.piDocs = void 0; +const piDocs = exports.piDocs = { + name: 'pi', + category: 'Constants', + syntax: ['pi'], + description: 'The number pi is a mathematical constant that is the ratio of a circle\'s circumference to its diameter, and is approximately equal to 3.14159', + examples: ['pi', 'sin(pi/2)'], + seealso: ['tau'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/tau.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/tau.js new file mode 100644 index 0000000..da38e95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/tau.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tauDocs = void 0; +const tauDocs = exports.tauDocs = { + name: 'tau', + category: 'Constants', + syntax: ['tau'], + description: 'Tau is the ratio constant of a circle\'s circumference to radius, equal to 2 * pi, approximately 6.2832.', + examples: ['tau', '2 * pi'], + seealso: ['pi'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/true.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/true.js new file mode 100644 index 0000000..5719e8c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/true.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.trueDocs = void 0; +const trueDocs = exports.trueDocs = { + name: 'true', + category: 'Constants', + syntax: ['true'], + description: 'Boolean value true', + examples: ['true'], + seealso: ['false'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/version.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/version.js new file mode 100644 index 0000000..e215e43 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/version.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.versionDocs = void 0; +const versionDocs = exports.versionDocs = { + name: 'version', + category: 'Constants', + syntax: ['version'], + description: 'A string with the version number of math.js', + examples: ['version'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bigint.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bigint.js new file mode 100644 index 0000000..35a92c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bigint.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bigintDocs = void 0; +const bigintDocs = exports.bigintDocs = { + name: 'bigint', + category: 'Construction', + syntax: ['bigint(x)'], + description: 'Create a bigint, an integer with an arbitrary number of digits, from a number or string.', + examples: ['123123123123123123 # a large number will lose digits', 'bigint("123123123123123123")', 'bignumber(["1", "3", "5"])'], + seealso: ['boolean', 'bignumber', 'number', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bignumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bignumber.js new file mode 100644 index 0000000..e852d27 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bignumber.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bignumberDocs = void 0; +const bignumberDocs = exports.bignumberDocs = { + name: 'bignumber', + category: 'Construction', + syntax: ['bignumber(x)'], + description: 'Create a big number from a number or string.', + examples: ['0.1 + 0.2', 'bignumber(0.1) + bignumber(0.2)', 'bignumber("7.2")', 'bignumber("7.2e500")', 'bignumber([0.1, 0.2, 0.3])'], + seealso: ['boolean', 'bigint', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/boolean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/boolean.js new file mode 100644 index 0000000..cac2f0a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/boolean.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.booleanDocs = void 0; +const booleanDocs = exports.booleanDocs = { + name: 'boolean', + category: 'Construction', + syntax: ['x', 'boolean(x)'], + description: 'Convert a string or number into a boolean.', + examples: ['boolean(0)', 'boolean(1)', 'boolean(3)', 'boolean("true")', 'boolean("false")', 'boolean([1, 0, 1, 1])'], + seealso: ['bignumber', 'complex', 'index', 'matrix', 'number', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/complex.js new file mode 100644 index 0000000..c73b0de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/complex.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.complexDocs = void 0; +const complexDocs = exports.complexDocs = { + name: 'complex', + category: 'Construction', + syntax: ['complex()', 'complex(re, im)', 'complex(string)'], + description: 'Create a complex number.', + examples: ['complex()', 'complex(2, 3)', 'complex("7 - 2i")'], + seealso: ['bignumber', 'boolean', 'index', 'matrix', 'number', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/createUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/createUnit.js new file mode 100644 index 0000000..13d213a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/createUnit.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnitDocs = void 0; +const createUnitDocs = exports.createUnitDocs = { + name: 'createUnit', + category: 'Construction', + syntax: ['createUnit(definitions)', 'createUnit(name, definition)'], + description: 'Create a user-defined unit and register it with the Unit type.', + examples: ['createUnit("foo")', 'createUnit("knot", {definition: "0.514444444 m/s", aliases: ["knots", "kt", "kts"]})', 'createUnit("mph", "1 mile/hour")'], + seealso: ['unit', 'splitUnit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/fraction.js new file mode 100644 index 0000000..b51923b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/fraction.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fractionDocs = void 0; +const fractionDocs = exports.fractionDocs = { + name: 'fraction', + category: 'Construction', + syntax: ['fraction(num)', 'fraction(matrix)', 'fraction(num,den)', 'fraction({n: num, d: den})'], + description: 'Create a fraction from a number or from integer numerator and denominator.', + examples: ['fraction(0.125)', 'fraction(1, 3) + fraction(2, 5)', 'fraction({n: 333, d: 53})', 'fraction([sqrt(9), sqrt(10), sqrt(11)])'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/index.js new file mode 100644 index 0000000..2aedda9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/index.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.indexDocs = void 0; +const indexDocs = exports.indexDocs = { + name: 'index', + category: 'Construction', + syntax: ['[start]', '[start:end]', '[start:step:end]', '[start1, start 2, ...]', '[start1:end1, start2:end2, ...]', '[start1:step1:end1, start2:step2:end2, ...]'], + description: 'Create an index to get or replace a subset of a matrix', + examples: ['A = [1, 2, 3; 4, 5, 6]', 'A[1, :]', 'A[1, 2] = 50', 'A[1:2, 1:2] = 1', 'B = [1, 2, 3]', 'B[B>1 and B<3]'], + seealso: ['bignumber', 'boolean', 'complex', 'matrix,', 'number', 'range', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/matrix.js new file mode 100644 index 0000000..2cd0ecf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/matrix.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixDocs = void 0; +const matrixDocs = exports.matrixDocs = { + name: 'matrix', + category: 'Construction', + syntax: ['[]', '[a1, b1, ...; a2, b2, ...]', 'matrix()', 'matrix("dense")', 'matrix([...])'], + description: 'Create a matrix.', + examples: ['[]', '[1, 2, 3]', '[1, 2, 3; 4, 5, 6]', 'matrix()', 'matrix([3, 4])', 'matrix([3, 4; 5, 6], "sparse")', 'matrix([3, 4; 5, 6], "sparse", "number")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/number.js new file mode 100644 index 0000000..4374c3f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/number.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numberDocs = void 0; +const numberDocs = exports.numberDocs = { + name: 'number', + category: 'Construction', + syntax: ['x', 'number(x)', 'number(unit, valuelessUnit)'], + description: 'Create a number or convert a string or boolean into a number.', + examples: ['2', '2e3', '4.05', 'number(2)', 'number("7.2")', 'number(true)', 'number([true, false, true, true])', 'number(unit("52cm"), "m")'], + seealso: ['bignumber', 'bigint', 'boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/sparse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/sparse.js new file mode 100644 index 0000000..062dd57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/sparse.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sparseDocs = void 0; +const sparseDocs = exports.sparseDocs = { + name: 'sparse', + category: 'Construction', + syntax: ['sparse()', 'sparse([a1, b1, ...; a1, b2, ...])', 'sparse([a1, b1, ...; a1, b2, ...], "number")'], + description: 'Create a sparse matrix.', + examples: ['sparse()', 'sparse([3, 4; 5, 6])', 'sparse([3, 0; 5, 0], "number")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'matrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/splitUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/splitUnit.js new file mode 100644 index 0000000..7c03ce9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/splitUnit.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.splitUnitDocs = void 0; +const splitUnitDocs = exports.splitUnitDocs = { + name: 'splitUnit', + category: 'Construction', + syntax: ['splitUnit(unit: Unit, parts: Unit[])'], + description: 'Split a unit in an array of units whose sum is equal to the original unit.', + examples: ['splitUnit(1 m, ["feet", "inch"])'], + seealso: ['unit', 'createUnit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/string.js new file mode 100644 index 0000000..6a07f5f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/string.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stringDocs = void 0; +const stringDocs = exports.stringDocs = { + name: 'string', + category: 'Construction', + syntax: ['"text"', 'string(x)'], + description: 'Create a string or convert a value to a string', + examples: ['"Hello World!"', 'string(4.2)', 'string(3 + 2i)'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/unit.js new file mode 100644 index 0000000..95bec70 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/unit.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unitDocs = void 0; +const unitDocs = exports.unitDocs = { + name: 'unit', + category: 'Construction', + syntax: ['value unit', 'unit(value, unit)', 'unit(string)'], + description: 'Create a unit.', + examples: ['5.5 mm', '3 inch', 'unit(7.1, "kilogram")', 'unit("23 deg")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'string'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/config.js new file mode 100644 index 0000000..97b9fce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/config.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.configDocs = void 0; +const configDocs = exports.configDocs = { + name: 'config', + category: 'Core', + syntax: ['config()', 'config(options)'], + description: 'Get configuration or change configuration.', + examples: ['config()', '1/3 + 1/4', 'config({number: "Fraction"})', '1/3 + 1/4'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/import.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/import.js new file mode 100644 index 0000000..38353f0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/import.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.importDocs = void 0; +const importDocs = exports.importDocs = { + name: 'import', + category: 'Core', + syntax: ['import(functions)', 'import(functions, options)'], + description: 'Import functions or constants from an object.', + examples: ['import({myFn: f(x)=x^2, myConstant: 32 })', 'myFn(2)', 'myConstant'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/typed.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/typed.js new file mode 100644 index 0000000..bddba19 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/typed.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typedDocs = void 0; +const typedDocs = exports.typedDocs = { + name: 'typed', + category: 'Core', + syntax: ['typed(signatures)', 'typed(name, signatures)'], + description: 'Create a typed function.', + examples: ['double = typed({ "number": f(x)=x+x, "string": f(x)=concat(x,x) })', 'double(2)', 'double("hello")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/embeddedDocs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/embeddedDocs.js new file mode 100644 index 0000000..eb9afbf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/embeddedDocs.js @@ -0,0 +1,726 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.embeddedDocs = void 0; +var _e = require("./constants/e.js"); +var _false = require("./constants/false.js"); +var _i = require("./constants/i.js"); +var _Infinity = require("./constants/Infinity.js"); +var _LN = require("./constants/LN10.js"); +var _LN2 = require("./constants/LN2.js"); +var _LOG10E = require("./constants/LOG10E.js"); +var _LOG2E = require("./constants/LOG2E.js"); +var _NaN = require("./constants/NaN.js"); +var _null = require("./constants/null.js"); +var _phi = require("./constants/phi.js"); +var _pi = require("./constants/pi.js"); +var _SQRT1_ = require("./constants/SQRT1_2.js"); +var _SQRT = require("./constants/SQRT2.js"); +var _tau = require("./constants/tau.js"); +var _true = require("./constants/true.js"); +var _version = require("./constants/version.js"); +var _bignumber = require("./construction/bignumber.js"); +var _bigint = require("./construction/bigint.js"); +var _boolean = require("./construction/boolean.js"); +var _complex = require("./construction/complex.js"); +var _createUnit = require("./construction/createUnit.js"); +var _fraction = require("./construction/fraction.js"); +var _index = require("./construction/index.js"); +var _matrix = require("./construction/matrix.js"); +var _number = require("./construction/number.js"); +var _sparse = require("./construction/sparse.js"); +var _splitUnit = require("./construction/splitUnit.js"); +var _string = require("./construction/string.js"); +var _unit = require("./construction/unit.js"); +var _config = require("./core/config.js"); +var _import = require("./core/import.js"); +var _typed = require("./core/typed.js"); +var _derivative = require("./function/algebra/derivative.js"); +var _leafCount = require("./function/algebra/leafCount.js"); +var _lsolve = require("./function/algebra/lsolve.js"); +var _lsolveAll = require("./function/algebra/lsolveAll.js"); +var _lup = require("./function/algebra/lup.js"); +var _lusolve = require("./function/algebra/lusolve.js"); +var _polynomialRoot = require("./function/algebra/polynomialRoot.js"); +var _qr = require("./function/algebra/qr.js"); +var _rationalize = require("./function/algebra/rationalize.js"); +var _resolve = require("./function/algebra/resolve.js"); +var _simplify = require("./function/algebra/simplify.js"); +var _simplifyConstant = require("./function/algebra/simplifyConstant.js"); +var _simplifyCore = require("./function/algebra/simplifyCore.js"); +var _slu = require("./function/algebra/slu.js"); +var _symbolicEqual = require("./function/algebra/symbolicEqual.js"); +var _usolve = require("./function/algebra/usolve.js"); +var _usolveAll = require("./function/algebra/usolveAll.js"); +var _abs = require("./function/arithmetic/abs.js"); +var _add = require("./function/arithmetic/add.js"); +var _cbrt = require("./function/arithmetic/cbrt.js"); +var _ceil = require("./function/arithmetic/ceil.js"); +var _cube = require("./function/arithmetic/cube.js"); +var _divide = require("./function/arithmetic/divide.js"); +var _dotDivide = require("./function/arithmetic/dotDivide.js"); +var _dotMultiply = require("./function/arithmetic/dotMultiply.js"); +var _dotPow = require("./function/arithmetic/dotPow.js"); +var _exp = require("./function/arithmetic/exp.js"); +var _expm = require("./function/arithmetic/expm.js"); +var _expm2 = require("./function/arithmetic/expm1.js"); +var _fix = require("./function/arithmetic/fix.js"); +var _floor = require("./function/arithmetic/floor.js"); +var _gcd = require("./function/arithmetic/gcd.js"); +var _hypot = require("./function/arithmetic/hypot.js"); +var _invmod = require("./function/arithmetic/invmod.js"); +var _lcm = require("./function/arithmetic/lcm.js"); +var _log = require("./function/arithmetic/log.js"); +var _log2 = require("./function/arithmetic/log10.js"); +var _log1p = require("./function/arithmetic/log1p.js"); +var _log3 = require("./function/arithmetic/log2.js"); +var _mod = require("./function/arithmetic/mod.js"); +var _multiply = require("./function/arithmetic/multiply.js"); +var _norm = require("./function/arithmetic/norm.js"); +var _nthRoot = require("./function/arithmetic/nthRoot.js"); +var _nthRoots = require("./function/arithmetic/nthRoots.js"); +var _pow = require("./function/arithmetic/pow.js"); +var _round = require("./function/arithmetic/round.js"); +var _sign = require("./function/arithmetic/sign.js"); +var _sqrt = require("./function/arithmetic/sqrt.js"); +var _sqrtm = require("./function/arithmetic/sqrtm.js"); +var _sylvester = require("./function/algebra/sylvester.js"); +var _schur = require("./function/algebra/schur.js"); +var _lyap = require("./function/algebra/lyap.js"); +var _square = require("./function/arithmetic/square.js"); +var _subtract = require("./function/arithmetic/subtract.js"); +var _unaryMinus = require("./function/arithmetic/unaryMinus.js"); +var _unaryPlus = require("./function/arithmetic/unaryPlus.js"); +var _xgcd = require("./function/arithmetic/xgcd.js"); +var _bitAnd = require("./function/bitwise/bitAnd.js"); +var _bitNot = require("./function/bitwise/bitNot.js"); +var _bitOr = require("./function/bitwise/bitOr.js"); +var _bitXor = require("./function/bitwise/bitXor.js"); +var _leftShift = require("./function/bitwise/leftShift.js"); +var _rightArithShift = require("./function/bitwise/rightArithShift.js"); +var _rightLogShift = require("./function/bitwise/rightLogShift.js"); +var _bellNumbers = require("./function/combinatorics/bellNumbers.js"); +var _catalan = require("./function/combinatorics/catalan.js"); +var _composition = require("./function/combinatorics/composition.js"); +var _stirlingS = require("./function/combinatorics/stirlingS2.js"); +var _arg = require("./function/complex/arg.js"); +var _conj = require("./function/complex/conj.js"); +var _im = require("./function/complex/im.js"); +var _re = require("./function/complex/re.js"); +var _evaluate = require("./function/expression/evaluate.js"); +var _help = require("./function/expression/help.js"); +var _distance = require("./function/geometry/distance.js"); +var _intersect = require("./function/geometry/intersect.js"); +var _and = require("./function/logical/and.js"); +var _not = require("./function/logical/not.js"); +var _or = require("./function/logical/or.js"); +var _xor = require("./function/logical/xor.js"); +var _column = require("./function/matrix/column.js"); +var _concat = require("./function/matrix/concat.js"); +var _count = require("./function/matrix/count.js"); +var _cross = require("./function/matrix/cross.js"); +var _ctranspose = require("./function/matrix/ctranspose.js"); +var _det = require("./function/matrix/det.js"); +var _diag = require("./function/matrix/diag.js"); +var _diff = require("./function/matrix/diff.js"); +var _dot = require("./function/matrix/dot.js"); +var _eigs = require("./function/matrix/eigs.js"); +var _filter = require("./function/matrix/filter.js"); +var _flatten = require("./function/matrix/flatten.js"); +var _forEach = require("./function/matrix/forEach.js"); +var _getMatrixDataType = require("./function/matrix/getMatrixDataType.js"); +var _identity = require("./function/matrix/identity.js"); +var _inv = require("./function/matrix/inv.js"); +var _pinv = require("./function/matrix/pinv.js"); +var _kron = require("./function/matrix/kron.js"); +var _map = require("./function/matrix/map.js"); +var _matrixFromColumns = require("./function/matrix/matrixFromColumns.js"); +var _matrixFromFunction = require("./function/matrix/matrixFromFunction.js"); +var _matrixFromRows = require("./function/matrix/matrixFromRows.js"); +var _ones = require("./function/matrix/ones.js"); +var _partitionSelect = require("./function/matrix/partitionSelect.js"); +var _range = require("./function/matrix/range.js"); +var _reshape = require("./function/matrix/reshape.js"); +var _resize = require("./function/matrix/resize.js"); +var _rotate = require("./function/matrix/rotate.js"); +var _rotationMatrix = require("./function/matrix/rotationMatrix.js"); +var _row = require("./function/matrix/row.js"); +var _size = require("./function/matrix/size.js"); +var _sort = require("./function/matrix/sort.js"); +var _squeeze = require("./function/matrix/squeeze.js"); +var _subset = require("./function/matrix/subset.js"); +var _trace = require("./function/matrix/trace.js"); +var _transpose = require("./function/matrix/transpose.js"); +var _zeros = require("./function/matrix/zeros.js"); +var _fft = require("./function/matrix/fft.js"); +var _ifft = require("./function/matrix/ifft.js"); +var _combinations = require("./function/probability/combinations.js"); +var _combinationsWithRep = require("./function/probability/combinationsWithRep.js"); +var _factorial = require("./function/probability/factorial.js"); +var _gamma = require("./function/probability/gamma.js"); +var _lgamma = require("./function/probability/lgamma.js"); +var _kldivergence = require("./function/probability/kldivergence.js"); +var _multinomial = require("./function/probability/multinomial.js"); +var _permutations = require("./function/probability/permutations.js"); +var _pickRandom = require("./function/probability/pickRandom.js"); +var _random = require("./function/probability/random.js"); +var _randomInt = require("./function/probability/randomInt.js"); +var _compare = require("./function/relational/compare.js"); +var _compareNatural = require("./function/relational/compareNatural.js"); +var _compareText = require("./function/relational/compareText.js"); +var _deepEqual = require("./function/relational/deepEqual.js"); +var _equal = require("./function/relational/equal.js"); +var _equalText = require("./function/relational/equalText.js"); +var _larger = require("./function/relational/larger.js"); +var _largerEq = require("./function/relational/largerEq.js"); +var _smaller = require("./function/relational/smaller.js"); +var _smallerEq = require("./function/relational/smallerEq.js"); +var _unequal = require("./function/relational/unequal.js"); +var _setCartesian = require("./function/set/setCartesian.js"); +var _setDifference = require("./function/set/setDifference.js"); +var _setDistinct = require("./function/set/setDistinct.js"); +var _setIntersect = require("./function/set/setIntersect.js"); +var _setIsSubset = require("./function/set/setIsSubset.js"); +var _setMultiplicity = require("./function/set/setMultiplicity.js"); +var _setPowerset = require("./function/set/setPowerset.js"); +var _setSize = require("./function/set/setSize.js"); +var _setSymDifference = require("./function/set/setSymDifference.js"); +var _setUnion = require("./function/set/setUnion.js"); +var _zpk2tf = require("./function/signal/zpk2tf.js"); +var _freqz = require("./function/signal/freqz.js"); +var _erf = require("./function/special/erf.js"); +var _zeta = require("./function/special/zeta.js"); +var _mad = require("./function/statistics/mad.js"); +var _max = require("./function/statistics/max.js"); +var _mean = require("./function/statistics/mean.js"); +var _median = require("./function/statistics/median.js"); +var _min = require("./function/statistics/min.js"); +var _mode = require("./function/statistics/mode.js"); +var _prod = require("./function/statistics/prod.js"); +var _quantileSeq = require("./function/statistics/quantileSeq.js"); +var _std = require("./function/statistics/std.js"); +var _cumsum = require("./function/statistics/cumsum.js"); +var _sum = require("./function/statistics/sum.js"); +var _variance = require("./function/statistics/variance.js"); +var _corr = require("./function/statistics/corr.js"); +var _acos = require("./function/trigonometry/acos.js"); +var _acosh = require("./function/trigonometry/acosh.js"); +var _acot = require("./function/trigonometry/acot.js"); +var _acoth = require("./function/trigonometry/acoth.js"); +var _acsc = require("./function/trigonometry/acsc.js"); +var _acsch = require("./function/trigonometry/acsch.js"); +var _asec = require("./function/trigonometry/asec.js"); +var _asech = require("./function/trigonometry/asech.js"); +var _asin = require("./function/trigonometry/asin.js"); +var _asinh = require("./function/trigonometry/asinh.js"); +var _atan = require("./function/trigonometry/atan.js"); +var _atan2 = require("./function/trigonometry/atan2.js"); +var _atanh = require("./function/trigonometry/atanh.js"); +var _cos = require("./function/trigonometry/cos.js"); +var _cosh = require("./function/trigonometry/cosh.js"); +var _cot = require("./function/trigonometry/cot.js"); +var _coth = require("./function/trigonometry/coth.js"); +var _csc = require("./function/trigonometry/csc.js"); +var _csch = require("./function/trigonometry/csch.js"); +var _sec = require("./function/trigonometry/sec.js"); +var _sech = require("./function/trigonometry/sech.js"); +var _sin = require("./function/trigonometry/sin.js"); +var _sinh = require("./function/trigonometry/sinh.js"); +var _tan = require("./function/trigonometry/tan.js"); +var _tanh = require("./function/trigonometry/tanh.js"); +var _to = require("./function/units/to.js"); +var _bin = require("./function/utils/bin.js"); +var _clone = require("./function/utils/clone.js"); +var _format = require("./function/utils/format.js"); +var _hasNumericValue = require("./function/utils/hasNumericValue.js"); +var _hex = require("./function/utils/hex.js"); +var _isInteger = require("./function/utils/isInteger.js"); +var _isNaN = require("./function/utils/isNaN.js"); +var _isNegative = require("./function/utils/isNegative.js"); +var _isNumeric = require("./function/utils/isNumeric.js"); +var _isPositive = require("./function/utils/isPositive.js"); +var _isPrime = require("./function/utils/isPrime.js"); +var _isZero = require("./function/utils/isZero.js"); +var _numeric = require("./function/utils/numeric.js"); +var _oct = require("./function/utils/oct.js"); +var _print = require("./function/utils/print.js"); +var _typeOf = require("./function/utils/typeOf.js"); +var _solveODE = require("./function/numeric/solveODE.js"); +const embeddedDocs = exports.embeddedDocs = { + // construction functions + bignumber: _bignumber.bignumberDocs, + bigint: _bigint.bigintDocs, + boolean: _boolean.booleanDocs, + complex: _complex.complexDocs, + createUnit: _createUnit.createUnitDocs, + fraction: _fraction.fractionDocs, + index: _index.indexDocs, + matrix: _matrix.matrixDocs, + number: _number.numberDocs, + sparse: _sparse.sparseDocs, + splitUnit: _splitUnit.splitUnitDocs, + string: _string.stringDocs, + unit: _unit.unitDocs, + // constants + e: _e.eDocs, + E: _e.eDocs, + false: _false.falseDocs, + i: _i.iDocs, + Infinity: _Infinity.InfinityDocs, + LN2: _LN2.LN2Docs, + LN10: _LN.LN10Docs, + LOG2E: _LOG2E.LOG2EDocs, + LOG10E: _LOG10E.LOG10EDocs, + NaN: _NaN.NaNDocs, + null: _null.nullDocs, + pi: _pi.piDocs, + PI: _pi.piDocs, + phi: _phi.phiDocs, + SQRT1_2: _SQRT1_.SQRT12Docs, + SQRT2: _SQRT.SQRT2Docs, + tau: _tau.tauDocs, + true: _true.trueDocs, + version: _version.versionDocs, + // physical constants + // TODO: more detailed docs for physical constants + speedOfLight: { + description: 'Speed of light in vacuum', + examples: ['speedOfLight'] + }, + gravitationConstant: { + description: 'Newtonian constant of gravitation', + examples: ['gravitationConstant'] + }, + planckConstant: { + description: 'Planck constant', + examples: ['planckConstant'] + }, + reducedPlanckConstant: { + description: 'Reduced Planck constant', + examples: ['reducedPlanckConstant'] + }, + magneticConstant: { + description: 'Magnetic constant (vacuum permeability)', + examples: ['magneticConstant'] + }, + electricConstant: { + description: 'Electric constant (vacuum permeability)', + examples: ['electricConstant'] + }, + vacuumImpedance: { + description: 'Characteristic impedance of vacuum', + examples: ['vacuumImpedance'] + }, + coulomb: { + description: 'Coulomb\'s constant', + examples: ['coulomb'] + }, + elementaryCharge: { + description: 'Elementary charge', + examples: ['elementaryCharge'] + }, + bohrMagneton: { + description: 'Bohr magneton', + examples: ['bohrMagneton'] + }, + conductanceQuantum: { + description: 'Conductance quantum', + examples: ['conductanceQuantum'] + }, + inverseConductanceQuantum: { + description: 'Inverse conductance quantum', + examples: ['inverseConductanceQuantum'] + }, + // josephson: {description: 'Josephson constant', examples: ['josephson']}, + magneticFluxQuantum: { + description: 'Magnetic flux quantum', + examples: ['magneticFluxQuantum'] + }, + nuclearMagneton: { + description: 'Nuclear magneton', + examples: ['nuclearMagneton'] + }, + klitzing: { + description: 'Von Klitzing constant', + examples: ['klitzing'] + }, + bohrRadius: { + description: 'Bohr radius', + examples: ['bohrRadius'] + }, + classicalElectronRadius: { + description: 'Classical electron radius', + examples: ['classicalElectronRadius'] + }, + electronMass: { + description: 'Electron mass', + examples: ['electronMass'] + }, + fermiCoupling: { + description: 'Fermi coupling constant', + examples: ['fermiCoupling'] + }, + fineStructure: { + description: 'Fine-structure constant', + examples: ['fineStructure'] + }, + hartreeEnergy: { + description: 'Hartree energy', + examples: ['hartreeEnergy'] + }, + protonMass: { + description: 'Proton mass', + examples: ['protonMass'] + }, + deuteronMass: { + description: 'Deuteron Mass', + examples: ['deuteronMass'] + }, + neutronMass: { + description: 'Neutron mass', + examples: ['neutronMass'] + }, + quantumOfCirculation: { + description: 'Quantum of circulation', + examples: ['quantumOfCirculation'] + }, + rydberg: { + description: 'Rydberg constant', + examples: ['rydberg'] + }, + thomsonCrossSection: { + description: 'Thomson cross section', + examples: ['thomsonCrossSection'] + }, + weakMixingAngle: { + description: 'Weak mixing angle', + examples: ['weakMixingAngle'] + }, + efimovFactor: { + description: 'Efimov factor', + examples: ['efimovFactor'] + }, + atomicMass: { + description: 'Atomic mass constant', + examples: ['atomicMass'] + }, + avogadro: { + description: 'Avogadro\'s number', + examples: ['avogadro'] + }, + boltzmann: { + description: 'Boltzmann constant', + examples: ['boltzmann'] + }, + faraday: { + description: 'Faraday constant', + examples: ['faraday'] + }, + firstRadiation: { + description: 'First radiation constant', + examples: ['firstRadiation'] + }, + loschmidt: { + description: 'Loschmidt constant at T=273.15 K and p=101.325 kPa', + examples: ['loschmidt'] + }, + gasConstant: { + description: 'Gas constant', + examples: ['gasConstant'] + }, + molarPlanckConstant: { + description: 'Molar Planck constant', + examples: ['molarPlanckConstant'] + }, + molarVolume: { + description: 'Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa', + examples: ['molarVolume'] + }, + sackurTetrode: { + description: 'Sackur-Tetrode constant at T=1 K and p=101.325 kPa', + examples: ['sackurTetrode'] + }, + secondRadiation: { + description: 'Second radiation constant', + examples: ['secondRadiation'] + }, + stefanBoltzmann: { + description: 'Stefan-Boltzmann constant', + examples: ['stefanBoltzmann'] + }, + wienDisplacement: { + description: 'Wien displacement law constant', + examples: ['wienDisplacement'] + }, + // spectralRadiance: {description: 'First radiation constant for spectral radiance', examples: ['spectralRadiance']}, + + molarMass: { + description: 'Molar mass constant', + examples: ['molarMass'] + }, + molarMassC12: { + description: 'Molar mass constant of carbon-12', + examples: ['molarMassC12'] + }, + gravity: { + description: 'Standard acceleration of gravity (standard acceleration of free-fall on Earth)', + examples: ['gravity'] + }, + planckLength: { + description: 'Planck length', + examples: ['planckLength'] + }, + planckMass: { + description: 'Planck mass', + examples: ['planckMass'] + }, + planckTime: { + description: 'Planck time', + examples: ['planckTime'] + }, + planckCharge: { + description: 'Planck charge', + examples: ['planckCharge'] + }, + planckTemperature: { + description: 'Planck temperature', + examples: ['planckTemperature'] + }, + // functions - algebra + derivative: _derivative.derivativeDocs, + lsolve: _lsolve.lsolveDocs, + lsolveAll: _lsolveAll.lsolveAllDocs, + lup: _lup.lupDocs, + lusolve: _lusolve.lusolveDocs, + leafCount: _leafCount.leafCountDocs, + polynomialRoot: _polynomialRoot.polynomialRootDocs, + resolve: _resolve.resolveDocs, + simplify: _simplify.simplifyDocs, + simplifyConstant: _simplifyConstant.simplifyConstantDocs, + simplifyCore: _simplifyCore.simplifyCoreDocs, + symbolicEqual: _symbolicEqual.symbolicEqualDocs, + rationalize: _rationalize.rationalizeDocs, + slu: _slu.sluDocs, + usolve: _usolve.usolveDocs, + usolveAll: _usolveAll.usolveAllDocs, + qr: _qr.qrDocs, + // functions - arithmetic + abs: _abs.absDocs, + add: _add.addDocs, + cbrt: _cbrt.cbrtDocs, + ceil: _ceil.ceilDocs, + cube: _cube.cubeDocs, + divide: _divide.divideDocs, + dotDivide: _dotDivide.dotDivideDocs, + dotMultiply: _dotMultiply.dotMultiplyDocs, + dotPow: _dotPow.dotPowDocs, + exp: _exp.expDocs, + expm: _expm.expmDocs, + expm1: _expm2.expm1Docs, + fix: _fix.fixDocs, + floor: _floor.floorDocs, + gcd: _gcd.gcdDocs, + hypot: _hypot.hypotDocs, + lcm: _lcm.lcmDocs, + log: _log.logDocs, + log2: _log3.log2Docs, + log1p: _log1p.log1pDocs, + log10: _log2.log10Docs, + mod: _mod.modDocs, + multiply: _multiply.multiplyDocs, + norm: _norm.normDocs, + nthRoot: _nthRoot.nthRootDocs, + nthRoots: _nthRoots.nthRootsDocs, + pow: _pow.powDocs, + round: _round.roundDocs, + sign: _sign.signDocs, + sqrt: _sqrt.sqrtDocs, + sqrtm: _sqrtm.sqrtmDocs, + square: _square.squareDocs, + subtract: _subtract.subtractDocs, + unaryMinus: _unaryMinus.unaryMinusDocs, + unaryPlus: _unaryPlus.unaryPlusDocs, + xgcd: _xgcd.xgcdDocs, + invmod: _invmod.invmodDocs, + // functions - bitwise + bitAnd: _bitAnd.bitAndDocs, + bitNot: _bitNot.bitNotDocs, + bitOr: _bitOr.bitOrDocs, + bitXor: _bitXor.bitXorDocs, + leftShift: _leftShift.leftShiftDocs, + rightArithShift: _rightArithShift.rightArithShiftDocs, + rightLogShift: _rightLogShift.rightLogShiftDocs, + // functions - combinatorics + bellNumbers: _bellNumbers.bellNumbersDocs, + catalan: _catalan.catalanDocs, + composition: _composition.compositionDocs, + stirlingS2: _stirlingS.stirlingS2Docs, + // functions - core + config: _config.configDocs, + import: _import.importDocs, + typed: _typed.typedDocs, + // functions - complex + arg: _arg.argDocs, + conj: _conj.conjDocs, + re: _re.reDocs, + im: _im.imDocs, + // functions - expression + evaluate: _evaluate.evaluateDocs, + help: _help.helpDocs, + // functions - geometry + distance: _distance.distanceDocs, + intersect: _intersect.intersectDocs, + // functions - logical + and: _and.andDocs, + not: _not.notDocs, + or: _or.orDocs, + xor: _xor.xorDocs, + // functions - matrix + concat: _concat.concatDocs, + count: _count.countDocs, + cross: _cross.crossDocs, + column: _column.columnDocs, + ctranspose: _ctranspose.ctransposeDocs, + det: _det.detDocs, + diag: _diag.diagDocs, + diff: _diff.diffDocs, + dot: _dot.dotDocs, + getMatrixDataType: _getMatrixDataType.getMatrixDataTypeDocs, + identity: _identity.identityDocs, + filter: _filter.filterDocs, + flatten: _flatten.flattenDocs, + forEach: _forEach.forEachDocs, + inv: _inv.invDocs, + pinv: _pinv.pinvDocs, + eigs: _eigs.eigsDocs, + kron: _kron.kronDocs, + matrixFromFunction: _matrixFromFunction.matrixFromFunctionDocs, + matrixFromRows: _matrixFromRows.matrixFromRowsDocs, + matrixFromColumns: _matrixFromColumns.matrixFromColumnsDocs, + map: _map.mapDocs, + ones: _ones.onesDocs, + partitionSelect: _partitionSelect.partitionSelectDocs, + range: _range.rangeDocs, + resize: _resize.resizeDocs, + reshape: _reshape.reshapeDocs, + rotate: _rotate.rotateDocs, + rotationMatrix: _rotationMatrix.rotationMatrixDocs, + row: _row.rowDocs, + size: _size.sizeDocs, + sort: _sort.sortDocs, + squeeze: _squeeze.squeezeDocs, + subset: _subset.subsetDocs, + trace: _trace.traceDocs, + transpose: _transpose.transposeDocs, + zeros: _zeros.zerosDocs, + fft: _fft.fftDocs, + ifft: _ifft.ifftDocs, + sylvester: _sylvester.sylvesterDocs, + schur: _schur.schurDocs, + lyap: _lyap.lyapDocs, + // functions - numeric + solveODE: _solveODE.solveODEDocs, + // functions - probability + combinations: _combinations.combinationsDocs, + combinationsWithRep: _combinationsWithRep.combinationsWithRepDocs, + // distribution: distributionDocs, + factorial: _factorial.factorialDocs, + gamma: _gamma.gammaDocs, + kldivergence: _kldivergence.kldivergenceDocs, + lgamma: _lgamma.lgammaDocs, + multinomial: _multinomial.multinomialDocs, + permutations: _permutations.permutationsDocs, + pickRandom: _pickRandom.pickRandomDocs, + random: _random.randomDocs, + randomInt: _randomInt.randomIntDocs, + // functions - relational + compare: _compare.compareDocs, + compareNatural: _compareNatural.compareNaturalDocs, + compareText: _compareText.compareTextDocs, + deepEqual: _deepEqual.deepEqualDocs, + equal: _equal.equalDocs, + equalText: _equalText.equalTextDocs, + larger: _larger.largerDocs, + largerEq: _largerEq.largerEqDocs, + smaller: _smaller.smallerDocs, + smallerEq: _smallerEq.smallerEqDocs, + unequal: _unequal.unequalDocs, + // functions - set + setCartesian: _setCartesian.setCartesianDocs, + setDifference: _setDifference.setDifferenceDocs, + setDistinct: _setDistinct.setDistinctDocs, + setIntersect: _setIntersect.setIntersectDocs, + setIsSubset: _setIsSubset.setIsSubsetDocs, + setMultiplicity: _setMultiplicity.setMultiplicityDocs, + setPowerset: _setPowerset.setPowersetDocs, + setSize: _setSize.setSizeDocs, + setSymDifference: _setSymDifference.setSymDifferenceDocs, + setUnion: _setUnion.setUnionDocs, + // functions - signal + zpk2tf: _zpk2tf.zpk2tfDocs, + freqz: _freqz.freqzDocs, + // functions - special + erf: _erf.erfDocs, + zeta: _zeta.zetaDocs, + // functions - statistics + cumsum: _cumsum.cumSumDocs, + mad: _mad.madDocs, + max: _max.maxDocs, + mean: _mean.meanDocs, + median: _median.medianDocs, + min: _min.minDocs, + mode: _mode.modeDocs, + prod: _prod.prodDocs, + quantileSeq: _quantileSeq.quantileSeqDocs, + std: _std.stdDocs, + sum: _sum.sumDocs, + variance: _variance.varianceDocs, + corr: _corr.corrDocs, + // functions - trigonometry + acos: _acos.acosDocs, + acosh: _acosh.acoshDocs, + acot: _acot.acotDocs, + acoth: _acoth.acothDocs, + acsc: _acsc.acscDocs, + acsch: _acsch.acschDocs, + asec: _asec.asecDocs, + asech: _asech.asechDocs, + asin: _asin.asinDocs, + asinh: _asinh.asinhDocs, + atan: _atan.atanDocs, + atanh: _atanh.atanhDocs, + atan2: _atan2.atan2Docs, + cos: _cos.cosDocs, + cosh: _cosh.coshDocs, + cot: _cot.cotDocs, + coth: _coth.cothDocs, + csc: _csc.cscDocs, + csch: _csch.cschDocs, + sec: _sec.secDocs, + sech: _sech.sechDocs, + sin: _sin.sinDocs, + sinh: _sinh.sinhDocs, + tan: _tan.tanDocs, + tanh: _tanh.tanhDocs, + // functions - units + to: _to.toDocs, + // functions - utils + clone: _clone.cloneDocs, + format: _format.formatDocs, + bin: _bin.binDocs, + oct: _oct.octDocs, + hex: _hex.hexDocs, + isNaN: _isNaN.isNaNDocs, + isInteger: _isInteger.isIntegerDocs, + isNegative: _isNegative.isNegativeDocs, + isNumeric: _isNumeric.isNumericDocs, + hasNumericValue: _hasNumericValue.hasNumericValueDocs, + isPositive: _isPositive.isPositiveDocs, + isPrime: _isPrime.isPrimeDocs, + isZero: _isZero.isZeroDocs, + print: _print.printDocs, + typeOf: _typeOf.typeOfDocs, + numeric: _numeric.numericDocs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/derivative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/derivative.js new file mode 100644 index 0000000..e986679 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/derivative.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.derivativeDocs = void 0; +const derivativeDocs = exports.derivativeDocs = { + name: 'derivative', + category: 'Algebra', + syntax: ['derivative(expr, variable)', 'derivative(expr, variable, {simplify: boolean})'], + description: 'Takes the derivative of an expression expressed in parser Nodes. The derivative will be taken over the supplied variable in the second parameter. If there are multiple variables in the expression, it will return a partial derivative.', + examples: ['derivative("2x^3", "x")', 'derivative("2x^3", "x", {simplify: false})', 'derivative("2x^2 + 3x + 4", "x")', 'derivative("sin(2x)", "x")', 'f = parse("x^2 + x")', 'x = parse("x")', 'df = derivative(f, x)', 'df.evaluate({x: 3})'], + seealso: ['simplify', 'parse', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/leafCount.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/leafCount.js new file mode 100644 index 0000000..93447eb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/leafCount.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.leafCountDocs = void 0; +const leafCountDocs = exports.leafCountDocs = { + name: 'leafCount', + category: 'Algebra', + syntax: ['leafCount(expr)'], + description: 'Computes the number of leaves in the parse tree of the given expression', + examples: ['leafCount("e^(i*pi)-1")', 'leafCount(parse("{a: 22/7, b: 10^(1/2)}"))'], + seealso: ['simplify'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolve.js new file mode 100644 index 0000000..0cf5b71 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolve.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lsolveDocs = void 0; +const lsolveDocs = exports.lsolveDocs = { + name: 'lsolve', + category: 'Algebra', + syntax: ['x=lsolve(L, b)'], + description: 'Finds one solution of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'], + seealso: ['lsolveAll', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolveAll.js new file mode 100644 index 0000000..4472408 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolveAll.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lsolveAllDocs = void 0; +const lsolveAllDocs = exports.lsolveAllDocs = { + name: 'lsolveAll', + category: 'Algebra', + syntax: ['x=lsolveAll(L, b)'], + description: 'Finds all solutions of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'], + seealso: ['lsolve', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lup.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lup.js new file mode 100644 index 0000000..4d7030d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lup.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lupDocs = void 0; +const lupDocs = exports.lupDocs = { + name: 'lup', + category: 'Algebra', + syntax: ['lup(m)'], + description: 'Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U', + examples: ['lup([[2, 1], [1, 4]])', 'lup(matrix([[2, 1], [1, 4]]))', 'lup(sparse([[2, 1], [1, 4]]))'], + seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'slu', 'qr'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lusolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lusolve.js new file mode 100644 index 0000000..7f17520 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lusolve.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lusolveDocs = void 0; +const lusolveDocs = exports.lusolveDocs = { + name: 'lusolve', + category: 'Algebra', + syntax: ['x=lusolve(A, b)', 'x=lusolve(lu, b)'], + description: 'Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lusolve(a, b)'], + seealso: ['lup', 'slu', 'lsolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lyap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lyap.js new file mode 100644 index 0000000..1c894ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lyap.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lyapDocs = void 0; +const lyapDocs = exports.lyapDocs = { + name: 'lyap', + category: 'Algebra', + syntax: ['lyap(A,Q)'], + description: 'Solves the Continuous-time Lyapunov equation AP+PA\'+Q=0 for P', + examples: ['lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])', 'A = [[-2, 0], [1, -4]]', 'Q = [[3, 1], [1, 3]]', 'lyap(A,Q)'], + seealso: ['schur', 'sylvester'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/polynomialRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/polynomialRoot.js new file mode 100644 index 0000000..c329c4b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/polynomialRoot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.polynomialRootDocs = void 0; +const polynomialRootDocs = exports.polynomialRootDocs = { + name: 'polynomialRoot', + category: 'Algebra', + syntax: ['x=polynomialRoot(-6, 3)', 'x=polynomialRoot(4, -4, 1)', 'x=polynomialRoot(-8, 12, -6, 1)'], + description: 'Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.', + examples: ['a = polynomialRoot(-6, 11, -6, 1)'], + seealso: ['cbrt', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/qr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/qr.js new file mode 100644 index 0000000..ea02732 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/qr.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.qrDocs = void 0; +const qrDocs = exports.qrDocs = { + name: 'qr', + category: 'Algebra', + syntax: ['qr(A)'], + description: 'Calculates the Matrix QR decomposition. Matrix `A` is decomposed in two matrices (`Q`, `R`) where `Q` is an orthogonal matrix and `R` is an upper triangular matrix.', + examples: ['qr([[1, -1, 4], [1, 4, -2], [1, 4, 2], [1, -1, 0]])'], + seealso: ['lup', 'slu', 'matrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/rationalize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/rationalize.js new file mode 100644 index 0000000..d449ce2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/rationalize.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rationalizeDocs = void 0; +const rationalizeDocs = exports.rationalizeDocs = { + name: 'rationalize', + category: 'Algebra', + syntax: ['rationalize(expr)', 'rationalize(expr, scope)', 'rationalize(expr, scope, detailed)'], + description: 'Transform a rationalizable expression in a rational fraction. If rational fraction is one variable polynomial then converts the numerator and denominator in canonical form, with decreasing exponents, returning the coefficients of numerator.', + examples: ['rationalize("2x/y - y/(x+1)")', 'rationalize("2x/y - y/(x+1)", true)'], + seealso: ['simplify'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/resolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/resolve.js new file mode 100644 index 0000000..58eeb4d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/resolve.js @@ -0,0 +1,15 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.resolveDocs = void 0; +const resolveDocs = exports.resolveDocs = { + name: 'resolve', + category: 'Algebra', + syntax: ['resolve(node, scope)'], + description: 'Recursively substitute variables in an expression tree.', + examples: ['resolve(parse("1 + x"), { x: 7 })', 'resolve(parse("size(text)"), { text: "Hello World" })', 'resolve(parse("x + y"), { x: parse("3z") })', 'resolve(parse("3x"), { x: parse("y+z"), z: parse("w^y") })'], + seealso: ['simplify', 'evaluate'], + mayThrow: ['ReferenceError'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/schur.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/schur.js new file mode 100644 index 0000000..1fd2f34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/schur.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.schurDocs = void 0; +const schurDocs = exports.schurDocs = { + name: 'schur', + category: 'Algebra', + syntax: ['schur(A)'], + description: 'Performs a real Schur decomposition of the real matrix A = UTU\'', + examples: ['schur([[1, 0], [-4, 3]])', 'A = [[1, 0], [-4, 3]]', 'schur(A)'], + seealso: ['lyap', 'sylvester'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplify.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplify.js new file mode 100644 index 0000000..385e7e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplify.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyDocs = void 0; +const simplifyDocs = exports.simplifyDocs = { + name: 'simplify', + category: 'Algebra', + syntax: ['simplify(expr)', 'simplify(expr, rules)'], + description: 'Simplify an expression tree.', + examples: ['simplify("3 + 2 / 4")', 'simplify("2x + x")', 'f = parse("x * (x + 2 + x)")', 'simplified = simplify(f)', 'simplified.evaluate({x: 2})'], + seealso: ['simplifyCore', 'derivative', 'evaluate', 'parse', 'rationalize', 'resolve'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyConstant.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyConstant.js new file mode 100644 index 0000000..b23cdfc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyConstant.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyConstantDocs = void 0; +const simplifyConstantDocs = exports.simplifyConstantDocs = { + name: 'simplifyConstant', + category: 'Algebra', + syntax: ['simplifyConstant(expr)', 'simplifyConstant(expr, options)'], + description: 'Replace constant subexpressions of node with their values.', + examples: ['simplifyConstant("(3-3)*x")', 'simplifyConstant(parse("z-cos(tau/8)"))'], + seealso: ['simplify', 'simplifyCore', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyCore.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyCore.js new file mode 100644 index 0000000..01ebc74 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyCore.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.simplifyCoreDocs = void 0; +const simplifyCoreDocs = exports.simplifyCoreDocs = { + name: 'simplifyCore', + category: 'Algebra', + syntax: ['simplifyCore(node)'], + description: 'Perform simple one-pass simplifications on an expression tree.', + examples: ['simplifyCore(parse("0*x"))', 'simplifyCore(parse("(x+0)*2"))'], + seealso: ['simplify', 'simplifyConstant', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/slu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/slu.js new file mode 100644 index 0000000..1403e16 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/slu.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sluDocs = void 0; +const sluDocs = exports.sluDocs = { + name: 'slu', + category: 'Algebra', + syntax: ['slu(A, order, threshold)'], + description: 'Calculate the Matrix LU decomposition with full pivoting. Matrix A is decomposed in two matrices (L, U) and two permutation vectors (pinv, q) where P * A * Q = L * U', + examples: ['slu(sparse([4.5, 0, 3.2, 0; 3.1, 2.9, 0, 0.9; 0, 1.7, 3, 0; 3.5, 0.4, 0, 1]), 1, 0.001)'], + seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'lup', 'qr'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/sylvester.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/sylvester.js new file mode 100644 index 0000000..d124f2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/sylvester.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sylvesterDocs = void 0; +const sylvesterDocs = exports.sylvesterDocs = { + name: 'sylvester', + category: 'Algebra', + syntax: ['sylvester(A,B,C)'], + description: 'Solves the real-valued Sylvester equation AX+XB=C for X', + examples: ['sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])', 'A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]', 'sylvester(A, B, C)'], + seealso: ['schur', 'lyap'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/symbolicEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/symbolicEqual.js new file mode 100644 index 0000000..cdd4c49 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/symbolicEqual.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.symbolicEqualDocs = void 0; +const symbolicEqualDocs = exports.symbolicEqualDocs = { + name: 'symbolicEqual', + category: 'Algebra', + syntax: ['symbolicEqual(expr1, expr2)', 'symbolicEqual(expr1, expr2, options)'], + description: 'Returns true if the difference of the expressions simplifies to 0', + examples: ['symbolicEqual("x*y","y*x")', 'symbolicEqual("abs(x^2)", "x^2")', 'symbolicEqual("abs(x)", "x", {context: {abs: {trivial: true}}})'], + seealso: ['simplify', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolve.js new file mode 100644 index 0000000..b0bcb2b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolve.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.usolveDocs = void 0; +const usolveDocs = exports.usolveDocs = { + name: 'usolve', + category: 'Algebra', + syntax: ['x=usolve(U, b)'], + description: 'Finds one solution of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.', + examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'], + seealso: ['usolveAll', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolveAll.js new file mode 100644 index 0000000..8c2af3c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolveAll.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.usolveAllDocs = void 0; +const usolveAllDocs = exports.usolveAllDocs = { + name: 'usolveAll', + category: 'Algebra', + syntax: ['x=usolve(U, b)'], + description: 'Finds all solutions of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.', + examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'], + seealso: ['usolve', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/abs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/abs.js new file mode 100644 index 0000000..d12f229 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/abs.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.absDocs = void 0; +const absDocs = exports.absDocs = { + name: 'abs', + category: 'Arithmetic', + syntax: ['abs(x)'], + description: 'Compute the absolute value.', + examples: ['abs(3.5)', 'abs(-4.2)'], + seealso: ['sign'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/add.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/add.js new file mode 100644 index 0000000..a35fdec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/add.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.addDocs = void 0; +const addDocs = exports.addDocs = { + name: 'add', + category: 'Operators', + syntax: ['x + y', 'add(x, y)'], + description: 'Add two values.', + examples: ['a = 2.1 + 3.6', 'a - 3.6', '3 + 2i', '3 cm + 2 inch', '"2.3" + "4"'], + seealso: ['subtract'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cbrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cbrt.js new file mode 100644 index 0000000..c16f047 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cbrt.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cbrtDocs = void 0; +const cbrtDocs = exports.cbrtDocs = { + name: 'cbrt', + category: 'Arithmetic', + syntax: ['cbrt(x)', 'cbrt(x, allRoots)'], + description: 'Compute the cubic root value. If x = y * y * y, then y is the cubic root of x. When `x` is a number or complex number, an optional second argument `allRoots` can be provided to return all three cubic roots. If not provided, the principal root is returned', + examples: ['cbrt(64)', 'cube(4)', 'cbrt(-8)', 'cbrt(2 + 3i)', 'cbrt(8i)', 'cbrt(8i, true)', 'cbrt(27 m^3)'], + seealso: ['square', 'sqrt', 'cube', 'multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/ceil.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/ceil.js new file mode 100644 index 0000000..db22bbd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/ceil.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ceilDocs = void 0; +const ceilDocs = exports.ceilDocs = { + name: 'ceil', + category: 'Arithmetic', + syntax: ['ceil(x)'], + description: 'Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.', + examples: ['ceil(3.2)', 'ceil(3.8)', 'ceil(-4.2)'], + seealso: ['floor', 'fix', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cube.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cube.js new file mode 100644 index 0000000..e81dfb8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cube.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cubeDocs = void 0; +const cubeDocs = exports.cubeDocs = { + name: 'cube', + category: 'Arithmetic', + syntax: ['cube(x)'], + description: 'Compute the cube of a value. The cube of x is x * x * x.', + examples: ['cube(2)', '2^3', '2 * 2 * 2'], + seealso: ['multiply', 'square', 'pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/divide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/divide.js new file mode 100644 index 0000000..97699d4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/divide.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.divideDocs = void 0; +const divideDocs = exports.divideDocs = { + name: 'divide', + category: 'Operators', + syntax: ['x / y', 'divide(x, y)'], + description: 'Divide two values.', + examples: ['a = 2 / 3', 'a * 3', '4.5 / 2', '3 + 4 / 2', '(3 + 4) / 2', '18 km / 4.5'], + seealso: ['multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotDivide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotDivide.js new file mode 100644 index 0000000..4dd03d0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotDivide.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotDivideDocs = void 0; +const dotDivideDocs = exports.dotDivideDocs = { + name: 'dotDivide', + category: 'Operators', + syntax: ['x ./ y', 'dotDivide(x, y)'], + description: 'Divide two values element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a ./ b'], + seealso: ['multiply', 'dotMultiply', 'divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotMultiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotMultiply.js new file mode 100644 index 0000000..efa679e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotMultiply.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotMultiplyDocs = void 0; +const dotMultiplyDocs = exports.dotMultiplyDocs = { + name: 'dotMultiply', + category: 'Operators', + syntax: ['x .* y', 'dotMultiply(x, y)'], + description: 'Multiply two values element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a .* b'], + seealso: ['multiply', 'divide', 'dotDivide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotPow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotPow.js new file mode 100644 index 0000000..cf9310d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotPow.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotPowDocs = void 0; +const dotPowDocs = exports.dotPowDocs = { + name: 'dotPow', + category: 'Operators', + syntax: ['x .^ y', 'dotPow(x, y)'], + description: 'Calculates the power of x to y element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a .^ 2'], + seealso: ['pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/exp.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/exp.js new file mode 100644 index 0000000..560d1d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/exp.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expDocs = void 0; +const expDocs = exports.expDocs = { + name: 'exp', + category: 'Arithmetic', + syntax: ['exp(x)'], + description: 'Calculate the exponent of a value.', + examples: ['exp(1.3)', 'e ^ 1.3', 'log(exp(1.3))', 'x = 2.4', '(exp(i*x) == cos(x) + i*sin(x)) # Euler\'s formula'], + seealso: ['expm', 'expm1', 'pow', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm.js new file mode 100644 index 0000000..e1d0279 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expmDocs = void 0; +const expmDocs = exports.expmDocs = { + name: 'expm', + category: 'Arithmetic', + syntax: ['exp(x)'], + description: 'Compute the matrix exponential, expm(A) = e^A. ' + 'The matrix must be square. ' + 'Not to be confused with exp(a), which performs element-wise exponentiation.', + examples: ['expm([[0,2],[0,0]])'], + seealso: ['exp'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm1.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm1.js new file mode 100644 index 0000000..dc95343 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm1.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.expm1Docs = void 0; +const expm1Docs = exports.expm1Docs = { + name: 'expm1', + category: 'Arithmetic', + syntax: ['expm1(x)'], + description: 'Calculate the value of subtracting 1 from the exponential value.', + examples: ['expm1(2)', 'pow(e, 2) - 1', 'log(expm1(2) + 1)'], + seealso: ['exp', 'pow', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/fix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/fix.js new file mode 100644 index 0000000..293d954 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/fix.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fixDocs = void 0; +const fixDocs = exports.fixDocs = { + name: 'fix', + category: 'Arithmetic', + syntax: ['fix(x)'], + description: 'Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.', + examples: ['fix(3.2)', 'fix(3.8)', 'fix(-4.2)', 'fix(-4.8)'], + seealso: ['ceil', 'floor', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/floor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/floor.js new file mode 100644 index 0000000..789f941 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/floor.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.floorDocs = void 0; +const floorDocs = exports.floorDocs = { + name: 'floor', + category: 'Arithmetic', + syntax: ['floor(x)'], + description: 'Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.', + examples: ['floor(3.2)', 'floor(3.8)', 'floor(-4.2)'], + seealso: ['ceil', 'fix', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/gcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/gcd.js new file mode 100644 index 0000000..fd6c007 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/gcd.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gcdDocs = void 0; +const gcdDocs = exports.gcdDocs = { + name: 'gcd', + category: 'Arithmetic', + syntax: ['gcd(a, b)', 'gcd(a, b, c, ...)'], + description: 'Compute the greatest common divisor.', + examples: ['gcd(8, 12)', 'gcd(-4, 6)', 'gcd(25, 15, -10)'], + seealso: ['lcm', 'xgcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/hypot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/hypot.js new file mode 100644 index 0000000..b10ec20 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/hypot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hypotDocs = void 0; +const hypotDocs = exports.hypotDocs = { + name: 'hypot', + category: 'Arithmetic', + syntax: ['hypot(a, b, c, ...)', 'hypot([a, b, c, ...])'], + description: 'Calculate the hypotenuse of a list with values.', + examples: ['hypot(3, 4)', 'sqrt(3^2 + 4^2)', 'hypot(-2)', 'hypot([3, 4, 5])'], + seealso: ['abs', 'norm'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/invmod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/invmod.js new file mode 100644 index 0000000..f389aab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/invmod.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.invmodDocs = void 0; +const invmodDocs = exports.invmodDocs = { + name: 'invmod', + category: 'Arithmetic', + syntax: ['invmod(a, b)'], + description: 'Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)', + examples: ['invmod(8, 12)', 'invmod(7, 13)', 'invmod(15151, 15122)'], + seealso: ['gcd', 'xgcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/lcm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/lcm.js new file mode 100644 index 0000000..d1621c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/lcm.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lcmDocs = void 0; +const lcmDocs = exports.lcmDocs = { + name: 'lcm', + category: 'Arithmetic', + syntax: ['lcm(x, y)'], + description: 'Compute the least common multiple.', + examples: ['lcm(4, 6)', 'lcm(6, 21)', 'lcm(6, 21, 5)'], + seealso: ['gcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log.js new file mode 100644 index 0000000..2a7739c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.logDocs = void 0; +const logDocs = exports.logDocs = { + name: 'log', + category: 'Arithmetic', + syntax: ['log(x)', 'log(x, base)'], + description: 'Compute the logarithm of a value. If no base is provided, the natural logarithm of x is calculated. If base if provided, the logarithm is calculated for the specified base. log(x, base) is defined as log(x) / log(base).', + examples: ['log(3.5)', 'a = log(2.4)', 'exp(a)', '10 ^ 4', 'log(10000, 10)', 'log(10000) / log(10)', 'b = log(1024, 2)', '2 ^ b'], + seealso: ['exp', 'log1p', 'log2', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log10.js new file mode 100644 index 0000000..513e9a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log10.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log10Docs = void 0; +const log10Docs = exports.log10Docs = { + name: 'log10', + category: 'Arithmetic', + syntax: ['log10(x)'], + description: 'Compute the 10-base logarithm of a value.', + examples: ['log10(0.00001)', 'log10(10000)', '10 ^ 4', 'log(10000) / log(10)', 'log(10000, 10)'], + seealso: ['exp', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log1p.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log1p.js new file mode 100644 index 0000000..f05ec54 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log1p.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log1pDocs = void 0; +const log1pDocs = exports.log1pDocs = { + name: 'log1p', + category: 'Arithmetic', + syntax: ['log1p(x)', 'log1p(x, base)'], + description: 'Calculate the logarithm of a `value+1`', + examples: ['log1p(2.5)', 'exp(log1p(1.4))', 'pow(10, 4)', 'log1p(9999, 10)', 'log1p(9999) / log(10)'], + seealso: ['exp', 'log', 'log2', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log2.js new file mode 100644 index 0000000..51c098e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.log2Docs = void 0; +const log2Docs = exports.log2Docs = { + name: 'log2', + category: 'Arithmetic', + syntax: ['log2(x)'], + description: 'Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.', + examples: ['log2(0.03125)', 'log2(16)', 'log2(16) / log2(2)', 'pow(2, 4)'], + seealso: ['exp', 'log1p', 'log', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/mod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/mod.js new file mode 100644 index 0000000..42c116c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/mod.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modDocs = void 0; +const modDocs = exports.modDocs = { + name: 'mod', + category: 'Operators', + syntax: ['x % y', 'x mod y', 'mod(x, y)'], + description: 'Calculates the modulus, the remainder of an integer division.', + examples: ['7 % 3', '11 % 2', '10 mod 4', 'isOdd(x) = x % 2', 'isOdd(2)', 'isOdd(3)'], + seealso: ['divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/multiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/multiply.js new file mode 100644 index 0000000..d0af98c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/multiply.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multiplyDocs = void 0; +const multiplyDocs = exports.multiplyDocs = { + name: 'multiply', + category: 'Operators', + syntax: ['x * y', 'multiply(x, y)'], + description: 'multiply two values.', + examples: ['a = 2.1 * 3.4', 'a / 3.4', '2 * 3 + 4', '2 * (3 + 4)', '3 * 2.1 km'], + seealso: ['divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/norm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/norm.js new file mode 100644 index 0000000..80c3935 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/norm.js @@ -0,0 +1,13 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.normDocs = void 0; +const normDocs = exports.normDocs = { + name: 'norm', + category: 'Arithmetic', + syntax: ['norm(x)', 'norm(x, p)'], + description: 'Calculate the norm of a number, vector or matrix.', + examples: ['abs(-3.5)', 'norm(-3.5)', 'norm(3 - 4i)', 'norm([1, 2, -3], Infinity)', 'norm([1, 2, -3], -Infinity)', 'norm([3, 4], 2)', 'norm([[1, 2], [3, 4]], 1)', 'norm([[1, 2], [3, 4]], "inf")', 'norm([[1, 2], [3, 4]], "fro")'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoot.js new file mode 100644 index 0000000..77de859 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nthRootDocs = void 0; +const nthRootDocs = exports.nthRootDocs = { + name: 'nthRoot', + category: 'Arithmetic', + syntax: ['nthRoot(a)', 'nthRoot(a, root)'], + description: 'Calculate the nth root of a value. ' + 'The principal nth root of a positive real number A, ' + 'is the positive real solution of the equation "x^root = A".', + examples: ['4 ^ 3', 'nthRoot(64, 3)', 'nthRoot(9, 2)', 'sqrt(9)'], + seealso: ['nthRoots', 'pow', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoots.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoots.js new file mode 100644 index 0000000..edef828 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoots.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nthRootsDocs = void 0; +const nthRootsDocs = exports.nthRootsDocs = { + name: 'nthRoots', + category: 'Arithmetic', + syntax: ['nthRoots(A)', 'nthRoots(A, root)'], + description: '' + 'Calculate the nth roots of a value. ' + 'An nth root of a positive real number A, ' + 'is a positive real solution of the equation "x^root = A". ' + 'This function returns an array of complex values.', + examples: ['nthRoots(1)', 'nthRoots(1, 3)'], + seealso: ['sqrt', 'pow', 'nthRoot'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/pow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/pow.js new file mode 100644 index 0000000..c62f021 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/pow.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.powDocs = void 0; +const powDocs = exports.powDocs = { + name: 'pow', + category: 'Operators', + syntax: ['x ^ y', 'pow(x, y)'], + description: 'Calculates the power of x to y, x^y.', + examples: ['2^3', '2*2*2', '1 + e ^ (pi * i)', 'pow([[1, 2], [4, 3]], 2)', 'pow([[1, 2], [4, 3]], -1)'], + seealso: ['multiply', 'nthRoot', 'nthRoots', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/round.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/round.js new file mode 100644 index 0000000..ff59b28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/round.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.roundDocs = void 0; +const roundDocs = exports.roundDocs = { + name: 'round', + category: 'Arithmetic', + syntax: ['round(x)', 'round(x, n)', 'round(unit, valuelessUnit)', 'round(unit, n, valuelessUnit)'], + description: 'round a value towards the nearest integer.If x is complex, both real and imaginary part are rounded towards the nearest integer. When n is specified, the value is rounded to n decimals.', + examples: ['round(3.2)', 'round(3.8)', 'round(-4.2)', 'round(-4.8)', 'round(pi, 3)', 'round(123.45678, 2)', 'round(3.241cm, 2, cm)', 'round([3.2, 3.8, -4.7])'], + seealso: ['ceil', 'floor', 'fix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sign.js new file mode 100644 index 0000000..e616252 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sign.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.signDocs = void 0; +const signDocs = exports.signDocs = { + name: 'sign', + category: 'Arithmetic', + syntax: ['sign(x)'], + description: 'Compute the sign of a value. The sign of a value x is 1 when x>1, -1 when x<0, and 0 when x=0.', + examples: ['sign(3.5)', 'sign(-4.2)', 'sign(0)'], + seealso: ['abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrt.js new file mode 100644 index 0000000..78cefc8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrt.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sqrtDocs = void 0; +const sqrtDocs = exports.sqrtDocs = { + name: 'sqrt', + category: 'Arithmetic', + syntax: ['sqrt(x)'], + description: 'Compute the square root value. If x = y * y, then y is the square root of x.', + examples: ['sqrt(25)', '5 * 5', 'sqrt(-1)'], + seealso: ['square', 'sqrtm', 'multiply', 'nthRoot', 'nthRoots', 'pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrtm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrtm.js new file mode 100644 index 0000000..609612d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrtm.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sqrtmDocs = void 0; +const sqrtmDocs = exports.sqrtmDocs = { + name: 'sqrtm', + category: 'Arithmetic', + syntax: ['sqrtm(x)'], + description: 'Calculate the principal square root of a square matrix. The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.', + examples: ['sqrtm([[33, 24], [48, 57]])'], + seealso: ['sqrt', 'abs', 'square', 'multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/square.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/square.js new file mode 100644 index 0000000..1a4ea51 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/square.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.squareDocs = void 0; +const squareDocs = exports.squareDocs = { + name: 'square', + category: 'Arithmetic', + syntax: ['square(x)'], + description: 'Compute the square of a value. The square of x is x * x.', + examples: ['square(3)', 'sqrt(9)', '3^2', '3 * 3'], + seealso: ['multiply', 'pow', 'sqrt', 'cube'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/subtract.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/subtract.js new file mode 100644 index 0000000..2fd1da7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/subtract.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subtractDocs = void 0; +const subtractDocs = exports.subtractDocs = { + name: 'subtract', + category: 'Operators', + syntax: ['x - y', 'subtract(x, y)'], + description: 'subtract two values.', + examples: ['a = 5.3 - 2', 'a + 2', '2/3 - 1/6', '2 * 3 - 3', '2.1 km - 500m'], + seealso: ['add'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryMinus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryMinus.js new file mode 100644 index 0000000..bc2f335 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryMinus.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryMinusDocs = void 0; +const unaryMinusDocs = exports.unaryMinusDocs = { + name: 'unaryMinus', + category: 'Operators', + syntax: ['-x', 'unaryMinus(x)'], + description: 'Inverse the sign of a value. Converts booleans and strings to numbers.', + examples: ['-4.5', '-(-5.6)', '-"22"'], + seealso: ['add', 'subtract', 'unaryPlus'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryPlus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryPlus.js new file mode 100644 index 0000000..263b8ee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryPlus.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unaryPlusDocs = void 0; +const unaryPlusDocs = exports.unaryPlusDocs = { + name: 'unaryPlus', + category: 'Operators', + syntax: ['+x', 'unaryPlus(x)'], + description: 'Converts booleans and strings to numbers.', + examples: ['+true', '+"2"'], + seealso: ['add', 'subtract', 'unaryMinus'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/xgcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/xgcd.js new file mode 100644 index 0000000..1d68e0f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/xgcd.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xgcdDocs = void 0; +const xgcdDocs = exports.xgcdDocs = { + name: 'xgcd', + category: 'Arithmetic', + syntax: ['xgcd(a, b)'], + description: 'Calculate the extended greatest common divisor for two values. The result is an array [d, x, y] with 3 entries, where d is the greatest common divisor, and d = x * a + y * b.', + examples: ['xgcd(8, 12)', 'gcd(8, 12)', 'xgcd(36163, 21199)'], + seealso: ['gcd', 'lcm'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitAnd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitAnd.js new file mode 100644 index 0000000..954403d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitAnd.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndDocs = void 0; +const bitAndDocs = exports.bitAndDocs = { + name: 'bitAnd', + category: 'Bitwise', + syntax: ['x & y', 'bitAnd(x, y)'], + description: 'Bitwise AND operation. Performs the logical AND operation on each pair of the corresponding bits of the two given values by multiplying them. If both bits in the compared position are 1, the bit in the resulting binary representation is 1, otherwise, the result is 0', + examples: ['5 & 3', 'bitAnd(53, 131)', '[1, 12, 31] & 42'], + seealso: ['bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitNot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitNot.js new file mode 100644 index 0000000..ec91700 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitNot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitNotDocs = void 0; +const bitNotDocs = exports.bitNotDocs = { + name: 'bitNot', + category: 'Bitwise', + syntax: ['~x', 'bitNot(x)'], + description: 'Bitwise NOT operation. Performs a logical negation on each bit of the given value. Bits that are 0 become 1, and those that are 1 become 0.', + examples: ['~1', '~2', 'bitNot([2, -3, 4])'], + seealso: ['bitAnd', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitOr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitOr.js new file mode 100644 index 0000000..e252ef4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitOr.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitOrDocs = void 0; +const bitOrDocs = exports.bitOrDocs = { + name: 'bitOr', + category: 'Bitwise', + syntax: ['x | y', 'bitOr(x, y)'], + description: 'Bitwise OR operation. Performs the logical inclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if the first bit is 1 or the second bit is 1 or both bits are 1, otherwise, the result is 0.', + examples: ['5 | 3', 'bitOr([1, 2, 3], 4)'], + seealso: ['bitAnd', 'bitNot', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitXor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitXor.js new file mode 100644 index 0000000..b91aa4e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitXor.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitXorDocs = void 0; +const bitXorDocs = exports.bitXorDocs = { + name: 'bitXor', + category: 'Bitwise', + syntax: ['bitXor(x, y)'], + description: 'Bitwise XOR operation, exclusive OR. Performs the logical exclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if only the first bit is 1 or only the second bit is 1, but will be 0 if both are 0 or both are 1.', + examples: ['bitOr(1, 2)', 'bitXor([2, 3, 4], 4)'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/leftShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/leftShift.js new file mode 100644 index 0000000..ff0368c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/leftShift.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.leftShiftDocs = void 0; +const leftShiftDocs = exports.leftShiftDocs = { + name: 'leftShift', + category: 'Bitwise', + syntax: ['x << y', 'leftShift(x, y)'], + description: 'Bitwise left logical shift of a value x by y number of bits.', + examples: ['4 << 1', '8 >> 1'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightArithShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightArithShift.js new file mode 100644 index 0000000..b8da2a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightArithShift.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightArithShiftDocs = void 0; +const rightArithShiftDocs = exports.rightArithShiftDocs = { + name: 'rightArithShift', + category: 'Bitwise', + syntax: ['x >> y', 'rightArithShift(x, y)'], + description: 'Bitwise right arithmetic shift of a value x by y number of bits.', + examples: ['8 >> 1', '4 << 1', '-12 >> 2'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightLogShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightLogShift.js new file mode 100644 index 0000000..5259600 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightLogShift.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rightLogShiftDocs = void 0; +const rightLogShiftDocs = exports.rightLogShiftDocs = { + name: 'rightLogShift', + category: 'Bitwise', + syntax: ['x >>> y', 'rightLogShift(x, y)'], + description: 'Bitwise right logical shift of a value x by y number of bits.', + examples: ['8 >>> 1', '4 << 1', '-12 >>> 2'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/bellNumbers.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/bellNumbers.js new file mode 100644 index 0000000..209cfad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/bellNumbers.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bellNumbersDocs = void 0; +const bellNumbersDocs = exports.bellNumbersDocs = { + name: 'bellNumbers', + category: 'Combinatorics', + syntax: ['bellNumbers(n)'], + description: 'The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. `bellNumbers` only takes integer arguments. The following condition must be enforced: n >= 0.', + examples: ['bellNumbers(3)', 'bellNumbers(8)'], + seealso: ['stirlingS2'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/catalan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/catalan.js new file mode 100644 index 0000000..b83ff95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/catalan.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.catalanDocs = void 0; +const catalanDocs = exports.catalanDocs = { + name: 'catalan', + category: 'Combinatorics', + syntax: ['catalan(n)'], + description: 'The Catalan Numbers enumerate combinatorial structures of many different types. catalan only takes integer arguments. The following condition must be enforced: n >= 0.', + examples: ['catalan(3)', 'catalan(8)'], + seealso: ['bellNumbers'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/composition.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/composition.js new file mode 100644 index 0000000..94672a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/composition.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compositionDocs = void 0; +const compositionDocs = exports.compositionDocs = { + name: 'composition', + category: 'Combinatorics', + syntax: ['composition(n, k)'], + description: 'The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.', + examples: ['composition(5, 3)'], + seealso: ['combinations'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/stirlingS2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/stirlingS2.js new file mode 100644 index 0000000..b79ec8f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/stirlingS2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stirlingS2Docs = void 0; +const stirlingS2Docs = exports.stirlingS2Docs = { + name: 'stirlingS2', + category: 'Combinatorics', + syntax: ['stirlingS2(n, k)'], + description: 'he Stirling numbers of the second kind, counts the number of ways to partition a set of n labelled objects into k nonempty unlabelled subsets. `stirlingS2` only takes integer arguments. The following condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = 1.', + examples: ['stirlingS2(5, 3)'], + seealso: ['bellNumbers'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/arg.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/arg.js new file mode 100644 index 0000000..d128a92 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/arg.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.argDocs = void 0; +const argDocs = exports.argDocs = { + name: 'arg', + category: 'Complex', + syntax: ['arg(x)'], + description: 'Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).', + examples: ['arg(2 + 2i)', 'atan2(3, 2)', 'arg(2 + 3i)'], + seealso: ['re', 'im', 'conj', 'abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/conj.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/conj.js new file mode 100644 index 0000000..af7e879 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/conj.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.conjDocs = void 0; +const conjDocs = exports.conjDocs = { + name: 'conj', + category: 'Complex', + syntax: ['conj(x)'], + description: 'Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.', + examples: ['conj(2 + 3i)', 'conj(2 - 3i)', 'conj(-5.2i)'], + seealso: ['re', 'im', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/im.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/im.js new file mode 100644 index 0000000..fa841cf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/im.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.imDocs = void 0; +const imDocs = exports.imDocs = { + name: 'im', + category: 'Complex', + syntax: ['im(x)'], + description: 'Get the imaginary part of a complex number.', + examples: ['im(2 + 3i)', 're(2 + 3i)', 'im(-5.2i)', 'im(2.4)'], + seealso: ['re', 'conj', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/re.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/re.js new file mode 100644 index 0000000..c79281f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/re.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reDocs = void 0; +const reDocs = exports.reDocs = { + name: 're', + category: 'Complex', + syntax: ['re(x)'], + description: 'Get the real part of a complex number.', + examples: ['re(2 + 3i)', 'im(2 + 3i)', 're(-5.2i)', 're(2.4)'], + seealso: ['im', 'conj', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/evaluate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/evaluate.js new file mode 100644 index 0000000..fafa197 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/evaluate.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.evaluateDocs = void 0; +const evaluateDocs = exports.evaluateDocs = { + name: 'evaluate', + category: 'Expression', + syntax: ['evaluate(expression)', 'evaluate(expression, scope)', 'evaluate([expr1, expr2, expr3, ...])', 'evaluate([expr1, expr2, expr3, ...], scope)'], + description: 'Evaluate an expression or an array with expressions.', + examples: ['evaluate("2 + 3")', 'evaluate("sqrt(16)")', 'evaluate("2 inch to cm")', 'evaluate("sin(x * pi)", { "x": 1/2 })', 'evaluate(["width=2", "height=4","width*height"])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/help.js new file mode 100644 index 0000000..bd3871a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/help.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.helpDocs = void 0; +const helpDocs = exports.helpDocs = { + name: 'help', + category: 'Expression', + syntax: ['help(object)', 'help(string)'], + description: 'Display documentation on a function or data type.', + examples: ['help(sqrt)', 'help("complex")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/distance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/distance.js new file mode 100644 index 0000000..0e6d3da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/distance.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.distanceDocs = void 0; +const distanceDocs = exports.distanceDocs = { + name: 'distance', + category: 'Geometry', + syntax: ['distance([x1, y1], [x2, y2])', 'distance([[x1, y1], [x2, y2]])'], + description: 'Calculates the Euclidean distance between two points.', + examples: ['distance([0,0], [4,4])', 'distance([[0,0], [4,4]])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/intersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/intersect.js new file mode 100644 index 0000000..935ba7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/intersect.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.intersectDocs = void 0; +const intersectDocs = exports.intersectDocs = { + name: 'intersect', + category: 'Geometry', + syntax: ['intersect(expr1, expr2, expr3, expr4)', 'intersect(expr1, expr2, expr3)'], + description: 'Computes the intersection point of lines and/or planes.', + examples: ['intersect([0, 0], [10, 10], [10, 0], [0, 10])', 'intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/and.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/and.js new file mode 100644 index 0000000..248d533 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/and.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.andDocs = void 0; +const andDocs = exports.andDocs = { + name: 'and', + category: 'Logical', + syntax: ['x and y', 'and(x, y)'], + description: 'Logical and. Test whether two values are both defined with a nonzero/nonempty value.', + examples: ['true and false', 'true and true', '2 and 4'], + seealso: ['not', 'or', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/not.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/not.js new file mode 100644 index 0000000..47492b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/not.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.notDocs = void 0; +const notDocs = exports.notDocs = { + name: 'not', + category: 'Logical', + syntax: ['not x', 'not(x)'], + description: 'Logical not. Flips the boolean value of given argument.', + examples: ['not true', 'not false', 'not 2', 'not 0'], + seealso: ['and', 'or', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/or.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/or.js new file mode 100644 index 0000000..ce5abe7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/or.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.orDocs = void 0; +const orDocs = exports.orDocs = { + name: 'or', + category: 'Logical', + syntax: ['x or y', 'or(x, y)'], + description: 'Logical or. Test if at least one value is defined with a nonzero/nonempty value.', + examples: ['true or false', 'false or false', '0 or 4'], + seealso: ['not', 'and', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/xor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/xor.js new file mode 100644 index 0000000..3d2189c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/xor.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.xorDocs = void 0; +const xorDocs = exports.xorDocs = { + name: 'xor', + category: 'Logical', + syntax: ['x xor y', 'xor(x, y)'], + description: 'Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.', + examples: ['true xor false', 'false xor false', 'true xor true', '0 xor 4'], + seealso: ['not', 'and', 'or'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/column.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/column.js new file mode 100644 index 0000000..cbda3dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/column.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.columnDocs = void 0; +const columnDocs = exports.columnDocs = { + name: 'column', + category: 'Matrix', + syntax: ['column(x, index)'], + description: 'Return a column from a matrix or array.', + examples: ['A = [[1, 2], [3, 4]]', 'column(A, 1)', 'column(A, 2)'], + seealso: ['row', 'matrixFromColumns'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/concat.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/concat.js new file mode 100644 index 0000000..66ed0a4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/concat.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.concatDocs = void 0; +const concatDocs = exports.concatDocs = { + name: 'concat', + category: 'Matrix', + syntax: ['concat(A, B, C, ...)', 'concat(A, B, C, ..., dim)'], + description: 'Concatenate matrices. By default, the matrices are concatenated by the last dimension. The dimension on which to concatenate can be provided as last argument.', + examples: ['A = [1, 2; 5, 6]', 'B = [3, 4; 7, 8]', 'concat(A, B)', 'concat(A, B, 1)', 'concat(A, B, 2)'], + seealso: ['det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/count.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/count.js new file mode 100644 index 0000000..49991b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/count.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.countDocs = void 0; +const countDocs = exports.countDocs = { + name: 'count', + category: 'Matrix', + syntax: ['count(x)'], + description: 'Count the number of elements of a matrix, array or string.', + examples: ['a = [1, 2; 3, 4; 5, 6]', 'count(a)', 'size(a)', 'count("hello world")'], + seealso: ['size'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/cross.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/cross.js new file mode 100644 index 0000000..8df9433 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/cross.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.crossDocs = void 0; +const crossDocs = exports.crossDocs = { + name: 'cross', + category: 'Matrix', + syntax: ['cross(A, B)'], + description: 'Calculate the cross product for two vectors in three dimensional space.', + examples: ['cross([1, 1, 0], [0, 1, 1])', 'cross([3, -3, 1], [4, 9, 2])', 'cross([2, 3, 4], [5, 6, 7])'], + seealso: ['multiply', 'dot'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ctranspose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ctranspose.js new file mode 100644 index 0000000..3c5567d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ctranspose.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ctransposeDocs = void 0; +const ctransposeDocs = exports.ctransposeDocs = { + name: 'ctranspose', + category: 'Matrix', + syntax: ['x\'', 'ctranspose(x)'], + description: 'Complex Conjugate and Transpose a matrix', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\'', 'ctranspose(a)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/det.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/det.js new file mode 100644 index 0000000..8902df4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/det.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.detDocs = void 0; +const detDocs = exports.detDocs = { + name: 'det', + category: 'Matrix', + syntax: ['det(x)'], + description: 'Calculate the determinant of a matrix', + examples: ['det([1, 2; 3, 4])', 'det([-2, 2, 3; -1, 1, 3; 2, 0, -1])'], + seealso: ['concat', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diag.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diag.js new file mode 100644 index 0000000..55b4dcd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diag.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.diagDocs = void 0; +const diagDocs = exports.diagDocs = { + name: 'diag', + category: 'Matrix', + syntax: ['diag(x)', 'diag(x, k)'], + description: 'Create a diagonal matrix or retrieve the diagonal of a matrix. When x is a vector, a matrix with the vector values on the diagonal will be returned. When x is a matrix, a vector with the diagonal values of the matrix is returned. When k is provided, the k-th diagonal will be filled in or retrieved, if k is positive, the values are placed on the super diagonal. When k is negative, the values are placed on the sub diagonal.', + examples: ['diag(1:3)', 'diag(1:3, 1)', 'a = [1, 2, 3; 4, 5, 6; 7, 8, 9]', 'diag(a)'], + seealso: ['concat', 'det', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diff.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diff.js new file mode 100644 index 0000000..44e5aa1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diff.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.diffDocs = void 0; +const diffDocs = exports.diffDocs = { + name: 'diff', + category: 'Matrix', + syntax: ['diff(arr)', 'diff(arr, dim)'], + description: ['Create a new matrix or array with the difference of the passed matrix or array.', 'Dim parameter is optional and used to indicate the dimension of the array/matrix to apply the difference', 'If no dimension parameter is passed it is assumed as dimension 0', 'Dimension is zero-based in javascript and one-based in the parser', 'Arrays must be \'rectangular\' meaning arrays like [1, 2]', 'If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays'], + examples: ['A = [1, 2, 4, 7, 0]', 'diff(A)', 'diff(A, 1)', 'B = [[1, 2], [3, 4]]', 'diff(B)', 'diff(B, 1)', 'diff(B, 2)', 'diff(B, bignumber(2))', 'diff([[1, 2], matrix([3, 4])], 2)'], + seealso: ['subtract', 'partitionSelect'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/dot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/dot.js new file mode 100644 index 0000000..c3eda6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/dot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dotDocs = void 0; +const dotDocs = exports.dotDocs = { + name: 'dot', + category: 'Matrix', + syntax: ['dot(A, B)', 'A * B'], + description: 'Calculate the dot product of two vectors. ' + 'The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] ' + 'is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn', + examples: ['dot([2, 4, 1], [2, 2, 3])', '[2, 4, 1] * [2, 2, 3]'], + seealso: ['multiply', 'cross'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/eigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/eigs.js new file mode 100644 index 0000000..0b960b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/eigs.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.eigsDocs = void 0; +const eigsDocs = exports.eigsDocs = { + name: 'eigs', + category: 'Matrix', + syntax: ['eigs(x)'], + description: 'Calculate the eigenvalues and optionally eigenvectors of a square matrix', + examples: ['eigs([[5, 2.3], [2.3, 1]])', 'eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })'], + seealso: ['inv'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/fft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/fft.js new file mode 100644 index 0000000..487324f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/fft.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.fftDocs = void 0; +const fftDocs = exports.fftDocs = { + name: 'fft', + category: 'Matrix', + syntax: ['fft(x)'], + description: 'Calculate N-dimensional Fourier transform', + examples: ['fft([[1, 0], [1, 0]])'], + seealso: ['ifft'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/filter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/filter.js new file mode 100644 index 0000000..0e0ba28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/filter.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.filterDocs = void 0; +const filterDocs = exports.filterDocs = { + name: 'filter', + category: 'Matrix', + syntax: ['filter(x, test)'], + description: 'Filter items in a matrix.', + examples: ['isPositive(x) = x > 0', 'filter([6, -2, -1, 4, 3], isPositive)', 'filter([6, -2, 0, 1, 0], x != 0)'], + seealso: ['sort', 'map', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/flatten.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/flatten.js new file mode 100644 index 0000000..971e07f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/flatten.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.flattenDocs = void 0; +const flattenDocs = exports.flattenDocs = { + name: 'flatten', + category: 'Matrix', + syntax: ['flatten(x)'], + description: 'Flatten a multi dimensional matrix into a single dimensional matrix.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'size(a)', 'b = flatten(a)', 'size(b)'], + seealso: ['concat', 'resize', 'size', 'squeeze'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/forEach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/forEach.js new file mode 100644 index 0000000..7e26ff6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/forEach.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.forEachDocs = void 0; +const forEachDocs = exports.forEachDocs = { + name: 'forEach', + category: 'Matrix', + syntax: ['forEach(x, callback)'], + description: 'Iterates over all elements of a matrix/array, and executes the given callback function.', + examples: ['numberOfPets = {}', 'addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;', 'forEach(["Dog","Cat","Cat"], addPet)', 'numberOfPets'], + seealso: ['map', 'sort', 'filter'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/getMatrixDataType.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/getMatrixDataType.js new file mode 100644 index 0000000..6539d57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/getMatrixDataType.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getMatrixDataTypeDocs = void 0; +const getMatrixDataTypeDocs = exports.getMatrixDataTypeDocs = { + name: 'getMatrixDataType', + category: 'Matrix', + syntax: ['getMatrixDataType(x)'], + description: 'Find the data type of all elements in a matrix or array, ' + 'for example "number" if all items are a number ' + 'and "Complex" if all values are complex numbers. ' + 'If a matrix contains more than one data type, it will return "mixed".', + examples: ['getMatrixDataType([1, 2, 3])', 'getMatrixDataType([[5 cm], [2 inch]])', 'getMatrixDataType([1, "text"])', 'getMatrixDataType([1, bignumber(4)])'], + seealso: ['matrix', 'sparse', 'typeOf'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/identity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/identity.js new file mode 100644 index 0000000..b1f3704 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/identity.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.identityDocs = void 0; +const identityDocs = exports.identityDocs = { + name: 'identity', + category: 'Matrix', + syntax: ['identity(n)', 'identity(m, n)', 'identity([m, n])'], + description: 'Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.', + examples: ['identity(3)', 'identity(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'identity(size(a))'], + seealso: ['concat', 'det', 'diag', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ifft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ifft.js new file mode 100644 index 0000000..d86d754 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ifft.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.ifftDocs = void 0; +const ifftDocs = exports.ifftDocs = { + name: 'ifft', + category: 'Matrix', + syntax: ['ifft(x)'], + description: 'Calculate N-dimensional inverse Fourier transform', + examples: ['ifft([[2, 2], [0, 0]])'], + seealso: ['fft'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/inv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/inv.js new file mode 100644 index 0000000..07078d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/inv.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.invDocs = void 0; +const invDocs = exports.invDocs = { + name: 'inv', + category: 'Matrix', + syntax: ['inv(x)'], + description: 'Calculate the inverse of a matrix', + examples: ['inv([1, 2; 3, 4])', 'inv(4)', '1 / 4'], + seealso: ['concat', 'det', 'diag', 'identity', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/kron.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/kron.js new file mode 100644 index 0000000..efd5d50 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/kron.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.kronDocs = void 0; +const kronDocs = exports.kronDocs = { + name: 'kron', + category: 'Matrix', + syntax: ['kron(x, y)'], + description: 'Calculates the Kronecker product of 2 matrices or vectors.', + examples: ['kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])', 'kron([1,1], [2,3,4])'], + seealso: ['multiply', 'dot', 'cross'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/map.js new file mode 100644 index 0000000..248a84f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/map.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mapDocs = void 0; +const mapDocs = exports.mapDocs = { + name: 'map', + category: 'Matrix', + syntax: ['map(x, callback)', 'map(x, y, ..., callback)'], + description: 'Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array or the matrices/arrays.', + examples: ['map([1, 2, 3], square)', 'map([1, 2], [3, 4], f(a,b) = a + b)'], + seealso: ['filter', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromColumns.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromColumns.js new file mode 100644 index 0000000..68bba7e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromColumns.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromColumnsDocs = void 0; +const matrixFromColumnsDocs = exports.matrixFromColumnsDocs = { + name: 'matrixFromColumns', + category: 'Matrix', + syntax: ['matrixFromColumns(...arr)', 'matrixFromColumns(row1, row2)', 'matrixFromColumns(row1, row2, row3)'], + description: 'Create a dense matrix from vectors as individual columns.', + examples: ['matrixFromColumns([1, 2, 3], [[4],[5],[6]])'], + seealso: ['matrix', 'matrixFromRows', 'matrixFromFunction', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromFunction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromFunction.js new file mode 100644 index 0000000..27ec1c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromFunction.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromFunctionDocs = void 0; +const matrixFromFunctionDocs = exports.matrixFromFunctionDocs = { + name: 'matrixFromFunction', + category: 'Matrix', + syntax: ['matrixFromFunction(size, fn)', 'matrixFromFunction(size, fn, format)', 'matrixFromFunction(size, fn, format, datatype)', 'matrixFromFunction(size, format, fn)', 'matrixFromFunction(size, format, datatype, fn)'], + description: 'Create a matrix by evaluating a generating function at each index.', + examples: ['f(I) = I[1] - I[2]', 'matrixFromFunction([3,3], f)', 'g(I) = I[1] - I[2] == 1 ? 4 : 0', 'matrixFromFunction([100, 100], "sparse", g)', 'matrixFromFunction([5], random)'], + seealso: ['matrix', 'matrixFromRows', 'matrixFromColumns', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromRows.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromRows.js new file mode 100644 index 0000000..8447fbe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromRows.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.matrixFromRowsDocs = void 0; +const matrixFromRowsDocs = exports.matrixFromRowsDocs = { + name: 'matrixFromRows', + category: 'Matrix', + syntax: ['matrixFromRows(...arr)', 'matrixFromRows(row1, row2)', 'matrixFromRows(row1, row2, row3)'], + description: 'Create a dense matrix from vectors as individual rows.', + examples: ['matrixFromRows([1, 2, 3], [[4],[5],[6]])'], + seealso: ['matrix', 'matrixFromColumns', 'matrixFromFunction', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ones.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ones.js new file mode 100644 index 0000000..150d59b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ones.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.onesDocs = void 0; +const onesDocs = exports.onesDocs = { + name: 'ones', + category: 'Matrix', + syntax: ['ones(m)', 'ones(m, n)', 'ones(m, n, p, ...)', 'ones([m])', 'ones([m, n])', 'ones([m, n, p, ...])'], + description: 'Create a matrix containing ones.', + examples: ['ones(3)', 'ones(3, 5)', 'ones([2,3]) * 4.5', 'a = [1, 2, 3; 4, 5, 6]', 'ones(size(a))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/partitionSelect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/partitionSelect.js new file mode 100644 index 0000000..ddc8fbe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/partitionSelect.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.partitionSelectDocs = void 0; +const partitionSelectDocs = exports.partitionSelectDocs = { + name: 'partitionSelect', + category: 'Matrix', + syntax: ['partitionSelect(x, k)', 'partitionSelect(x, k, compare)'], + description: 'Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.', + examples: ['partitionSelect([5, 10, 1], 2)', 'partitionSelect(["C", "B", "A", "D"], 1, compareText)', 'arr = [5, 2, 1]', 'partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]', 'arr', 'partitionSelect(arr, 1, \'desc\') # returns 2, arr is now: [5, 2, 1]', 'arr'], + seealso: ['sort'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/pinv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/pinv.js new file mode 100644 index 0000000..84e41db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/pinv.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.pinvDocs = void 0; +const pinvDocs = exports.pinvDocs = { + name: 'pinv', + category: 'Matrix', + syntax: ['pinv(x)'], + description: 'Calculate the Moore–Penrose inverse of a matrix', + examples: ['pinv([1, 2; 3, 4])', 'pinv([[1, 0], [0, 1], [0, 1]])', 'pinv(4)'], + seealso: ['inv'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/range.js new file mode 100644 index 0000000..f16891a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/range.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rangeDocs = void 0; +const rangeDocs = exports.rangeDocs = { + name: 'range', + category: 'Type', + syntax: ['start:end', 'start:step:end', 'range(start, end)', 'range(start, end, step)', 'range(string)'], + description: 'Create a range. Lower bound of the range is included, upper bound is excluded.', + examples: ['1:5', '3:-1:-3', 'range(3, 7)', 'range(0, 12, 2)', 'range("4:10")', 'range(1m, 1m, 3m)', 'a = [1, 2, 3, 4; 5, 6, 7, 8]', 'a[1:2, 1:2]'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/reshape.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/reshape.js new file mode 100644 index 0000000..d61aa0c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/reshape.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.reshapeDocs = void 0; +const reshapeDocs = exports.reshapeDocs = { + name: 'reshape', + category: 'Matrix', + syntax: ['reshape(x, sizes)'], + description: 'Reshape a multi dimensional array to fit the specified dimensions.', + examples: ['reshape([1, 2, 3, 4, 5, 6], [2, 3])', 'reshape([[1, 2], [3, 4]], [1, 4])', 'reshape([[1, 2], [3, 4]], [4])', 'reshape([1, 2, 3, 4], [-1, 2])'], + seealso: ['size', 'squeeze', 'resize'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/resize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/resize.js new file mode 100644 index 0000000..9a75b32 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/resize.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.resizeDocs = void 0; +const resizeDocs = exports.resizeDocs = { + name: 'resize', + category: 'Matrix', + syntax: ['resize(x, size)', 'resize(x, size, defaultValue)'], + description: 'Resize a matrix.', + examples: ['resize([1,2,3,4,5], [3])', 'resize([1,2,3], [5])', 'resize([1,2,3], [5], -1)', 'resize(2, [2, 3])', 'resize("hello", [8], "!")'], + seealso: ['size', 'subset', 'squeeze', 'reshape'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotate.js new file mode 100644 index 0000000..73e0b1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotate.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rotateDocs = void 0; +const rotateDocs = exports.rotateDocs = { + name: 'rotate', + category: 'Matrix', + syntax: ['rotate(w, theta)', 'rotate(w, theta, v)'], + description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.', + examples: ['rotate([1, 0], pi / 2)', 'rotate(matrix([1, 0]), unit("35deg"))', 'rotate([1, 0, 0], unit("90deg"), [0, 0, 1])', 'rotate(matrix([1, 0, 0]), unit("90deg"), matrix([0, 0, 1]))'], + seealso: ['matrix', 'rotationMatrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotationMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotationMatrix.js new file mode 100644 index 0000000..262c13d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotationMatrix.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rotationMatrixDocs = void 0; +const rotationMatrixDocs = exports.rotationMatrixDocs = { + name: 'rotationMatrix', + category: 'Matrix', + syntax: ['rotationMatrix(theta)', 'rotationMatrix(theta, v)', 'rotationMatrix(theta, v, format)'], + description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.', + examples: ['rotationMatrix(pi / 2)', 'rotationMatrix(unit("45deg"), [0, 0, 1])', 'rotationMatrix(1, matrix([0, 0, 1]), "sparse")'], + seealso: ['cos', 'sin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/row.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/row.js new file mode 100644 index 0000000..24ea4ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/row.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.rowDocs = void 0; +const rowDocs = exports.rowDocs = { + name: 'row', + category: 'Matrix', + syntax: ['row(x, index)'], + description: 'Return a row from a matrix or array.', + examples: ['A = [[1, 2], [3, 4]]', 'row(A, 1)', 'row(A, 2)'], + seealso: ['column', 'matrixFromRows'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/size.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/size.js new file mode 100644 index 0000000..3649021 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/size.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sizeDocs = void 0; +const sizeDocs = exports.sizeDocs = { + name: 'size', + category: 'Matrix', + syntax: ['size(x)'], + description: 'Calculate the size of a matrix.', + examples: ['size(2.3)', 'size("hello world")', 'a = [1, 2; 3, 4; 5, 6]', 'size(a)', 'size(1:6)'], + seealso: ['concat', 'count', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/sort.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/sort.js new file mode 100644 index 0000000..e949529 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/sort.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sortDocs = void 0; +const sortDocs = exports.sortDocs = { + name: 'sort', + category: 'Matrix', + syntax: ['sort(x)', 'sort(x, compare)'], + description: 'Sort the items in a matrix. Compare can be a string "asc", "desc", "natural", or a custom sort function.', + examples: ['sort([5, 10, 1])', 'sort(["C", "B", "A", "D"], "natural")', 'sortByLength(a, b) = size(a)[1] - size(b)[1]', 'sort(["Langdon", "Tom", "Sara"], sortByLength)', 'sort(["10", "1", "2"], "natural")'], + seealso: ['map', 'filter', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/squeeze.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/squeeze.js new file mode 100644 index 0000000..35d2a1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/squeeze.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.squeezeDocs = void 0; +const squeezeDocs = exports.squeezeDocs = { + name: 'squeeze', + category: 'Matrix', + syntax: ['squeeze(x)'], + description: 'Remove inner and outer singleton dimensions from a matrix.', + examples: ['a = zeros(3,2,1)', 'size(squeeze(a))', 'b = zeros(1,1,3)', 'size(squeeze(b))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/subset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/subset.js new file mode 100644 index 0000000..c42caa9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/subset.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.subsetDocs = void 0; +const subsetDocs = exports.subsetDocs = { + name: 'subset', + category: 'Matrix', + syntax: ['value(index)', 'value(index) = replacement', 'subset(value, [index])', 'subset(value, [index], replacement)'], + description: 'Get or set a subset of the entries of a matrix or ' + 'characters of a string. ' + 'Indexes are one-based. There should be one index specification for ' + 'each dimension of the target. Each specification can be a single ' + 'index, a list of indices, or a range in colon notation `l:u`. ' + 'In a range, both the lower bound l and upper bound u are included; ' + 'and if a bound is omitted it defaults to the most extreme valid value. ' + 'The cartesian product of the indices specified in each dimension ' + 'determines the target of the operation.', + examples: ['d = [1, 2; 3, 4]', 'e = []', 'e[1, 1:2] = [5, 6]', 'e[2, :] = [7, 8]', 'f = d * e', 'f[2, 1]', 'f[:, 1]', 'f[[1,2], [1,3]] = [9, 10; 11, 12]', 'f'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/trace.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/trace.js new file mode 100644 index 0000000..df95cad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/trace.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.traceDocs = void 0; +const traceDocs = exports.traceDocs = { + name: 'trace', + category: 'Matrix', + syntax: ['trace(A)'], + description: 'Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.', + examples: ['A = [1, 2, 3; -1, 2, 3; 2, 0, 3]', 'trace(A)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/transpose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/transpose.js new file mode 100644 index 0000000..c4ee7ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/transpose.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.transposeDocs = void 0; +const transposeDocs = exports.transposeDocs = { + name: 'transpose', + category: 'Matrix', + syntax: ['x\'', 'transpose(x)'], + description: 'Transpose a matrix', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\'', 'transpose(a)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/zeros.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/zeros.js new file mode 100644 index 0000000..925571f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/zeros.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zerosDocs = void 0; +const zerosDocs = exports.zerosDocs = { + name: 'zeros', + category: 'Matrix', + syntax: ['zeros(m)', 'zeros(m, n)', 'zeros(m, n, p, ...)', 'zeros([m])', 'zeros([m, n])', 'zeros([m, n, p, ...])'], + description: 'Create a matrix containing zeros.', + examples: ['zeros(3)', 'zeros(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'zeros(size(a))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/numeric/solveODE.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/numeric/solveODE.js new file mode 100644 index 0000000..2c5f636 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/numeric/solveODE.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.solveODEDocs = void 0; +const solveODEDocs = exports.solveODEDocs = { + name: 'solveODE', + category: 'Numeric', + syntax: ['solveODE(func, tspan, y0)', 'solveODE(func, tspan, y0, options)'], + description: 'Numerical Integration of Ordinary Differential Equations.', + examples: ['f(t,y) = y', 'tspan = [0, 4]', 'solveODE(f, tspan, 1)', 'solveODE(f, tspan, [1, 2])', 'solveODE(f, tspan, 1, { method:"RK23", maxStep:0.1 })'], + seealso: ['derivative', 'simplifyCore'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinations.js new file mode 100644 index 0000000..ab03458 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinations.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsDocs = void 0; +const combinationsDocs = exports.combinationsDocs = { + name: 'combinations', + category: 'Probability', + syntax: ['combinations(n, k)'], + description: 'Compute the number of combinations of n items taken k at a time', + examples: ['combinations(7, 5)'], + seealso: ['combinationsWithRep', 'permutations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinationsWithRep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinationsWithRep.js new file mode 100644 index 0000000..e23ff36 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinationsWithRep.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsWithRepDocs = void 0; +const combinationsWithRepDocs = exports.combinationsWithRepDocs = { + name: 'combinationsWithRep', + category: 'Probability', + syntax: ['combinationsWithRep(n, k)'], + description: 'Compute the number of combinations of n items taken k at a time with replacements.', + examples: ['combinationsWithRep(7, 5)'], + seealso: ['combinations', 'permutations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/distribution.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/distribution.js new file mode 100644 index 0000000..7e807d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/distribution.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.distributionDocs = void 0; +const distributionDocs = exports.distributionDocs = { + name: 'distribution', + category: 'Probability', + syntax: ['distribution(name)', 'distribution(name, arg1, arg2, ...)'], + description: 'Create a distribution object of a specific type. ' + 'A distribution object contains functions `random([size,] [min,] [max])`, ' + '`randomInt([size,] [min,] [max])` and `pickRandom(array)`. ' + 'Available types of distributions: "uniform", "normal". ' + 'Note that the function distribution is currently not available via the expression parser.', + examples: [], + seealso: ['random', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/factorial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/factorial.js new file mode 100644 index 0000000..9e36255 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/factorial.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.factorialDocs = void 0; +const factorialDocs = exports.factorialDocs = { + name: 'factorial', + category: 'Probability', + syntax: ['n!', 'factorial(n)'], + description: 'Compute the factorial of a value', + examples: ['5!', '5 * 4 * 3 * 2 * 1', '3!'], + seealso: ['combinations', 'combinationsWithRep', 'permutations', 'gamma'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/gamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/gamma.js new file mode 100644 index 0000000..8734aa5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/gamma.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gammaDocs = void 0; +const gammaDocs = exports.gammaDocs = { + name: 'gamma', + category: 'Probability', + syntax: ['gamma(n)'], + description: 'Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.', + examples: ['gamma(4)', '3!', 'gamma(1/2)', 'sqrt(pi)'], + seealso: ['factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/kldivergence.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/kldivergence.js new file mode 100644 index 0000000..1e73b1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/kldivergence.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.kldivergenceDocs = void 0; +const kldivergenceDocs = exports.kldivergenceDocs = { + name: 'kldivergence', + category: 'Probability', + syntax: ['kldivergence(x, y)'], + description: 'Calculate the Kullback-Leibler (KL) divergence between two distributions.', + examples: ['kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/lgamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/lgamma.js new file mode 100644 index 0000000..ba562cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/lgamma.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lgammaDocs = void 0; +const lgammaDocs = exports.lgammaDocs = { + name: 'lgamma', + category: 'Probability', + syntax: ['lgamma(n)'], + description: 'Logarithm of the gamma function for real, positive numbers and complex numbers, ' + 'using Lanczos approximation for numbers and Stirling series for complex numbers.', + examples: ['lgamma(4)', 'lgamma(1/2)', 'lgamma(i)', 'lgamma(complex(1.1, 2))'], + seealso: ['gamma'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/multinomial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/multinomial.js new file mode 100644 index 0000000..bdcadfc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/multinomial.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.multinomialDocs = void 0; +const multinomialDocs = exports.multinomialDocs = { + name: 'multinomial', + category: 'Probability', + syntax: ['multinomial(A)'], + description: 'Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. multinomial takes one array of integers as an argument. The following condition must be enforced: every ai > 0.', + examples: ['multinomial([1, 2, 1])'], + seealso: ['combinations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/permutations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/permutations.js new file mode 100644 index 0000000..1e0663c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/permutations.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.permutationsDocs = void 0; +const permutationsDocs = exports.permutationsDocs = { + name: 'permutations', + category: 'Probability', + syntax: ['permutations(n)', 'permutations(n, k)'], + description: 'Compute the number of permutations of n items taken k at a time', + examples: ['permutations(5)', 'permutations(5, 3)'], + seealso: ['combinations', 'combinationsWithRep', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/pickRandom.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/pickRandom.js new file mode 100644 index 0000000..a1cd990 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/pickRandom.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.pickRandomDocs = void 0; +const pickRandomDocs = exports.pickRandomDocs = { + name: 'pickRandom', + category: 'Probability', + syntax: ['pickRandom(array)', 'pickRandom(array, number)', 'pickRandom(array, weights)', 'pickRandom(array, number, weights)', 'pickRandom(array, weights, number)'], + description: 'Pick a random entry from a given array.', + examples: ['pickRandom(0:10)', 'pickRandom([1, 3, 1, 6])', 'pickRandom([1, 3, 1, 6], 2)', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)'], + seealso: ['random', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/random.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/random.js new file mode 100644 index 0000000..2303843 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/random.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomDocs = void 0; +const randomDocs = exports.randomDocs = { + name: 'random', + category: 'Probability', + syntax: ['random()', 'random(max)', 'random(min, max)', 'random(size)', 'random(size, max)', 'random(size, min, max)'], + description: 'Return a random number.', + examples: ['random()', 'random(10, 20)', 'random([2, 3])'], + seealso: ['pickRandom', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/randomInt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/randomInt.js new file mode 100644 index 0000000..54358ca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/randomInt.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomIntDocs = void 0; +const randomIntDocs = exports.randomIntDocs = { + name: 'randomInt', + category: 'Probability', + syntax: ['randomInt(max)', 'randomInt(min, max)', 'randomInt(size)', 'randomInt(size, max)', 'randomInt(size, min, max)'], + description: 'Return a random integer number', + examples: ['randomInt(10, 20)', 'randomInt([2, 3], 10)'], + seealso: ['pickRandom', 'random'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compare.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compare.js new file mode 100644 index 0000000..931c7a3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compare.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareDocs = void 0; +const compareDocs = exports.compareDocs = { + name: 'compare', + category: 'Relational', + syntax: ['compare(x, y)'], + description: 'Compare two values. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compare(2, 3)', 'compare(3, 2)', 'compare(2, 2)', 'compare(5cm, 40mm)', 'compare(2, [1, 2, 3])'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compareNatural', 'compareText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareNatural.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareNatural.js new file mode 100644 index 0000000..b470f09 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareNatural.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareNaturalDocs = void 0; +const compareNaturalDocs = exports.compareNaturalDocs = { + name: 'compareNatural', + category: 'Relational', + syntax: ['compareNatural(x, y)'], + description: 'Compare two values of any type in a deterministic, natural way. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compareNatural(2, 3)', 'compareNatural(3, 2)', 'compareNatural(2, 2)', 'compareNatural(5cm, 40mm)', 'compareNatural("2", "10")', 'compareNatural(2 + 3i, 2 + 4i)', 'compareNatural([1, 2, 4], [1, 2, 3])', 'compareNatural([1, 5], [1, 2, 3])', 'compareNatural([1, 2], [1, 2])', 'compareNatural({a: 2}, {a: 4})'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare', 'compareText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareText.js new file mode 100644 index 0000000..f27f926 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareText.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareTextDocs = void 0; +const compareTextDocs = exports.compareTextDocs = { + name: 'compareText', + category: 'Relational', + syntax: ['compareText(x, y)'], + description: 'Compare two strings lexically. Comparison is case sensitive. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compareText("B", "A")', 'compareText("A", "B")', 'compareText("A", "A")', 'compareText("2", "10")', 'compare("2", "10")', 'compare(2, 10)', 'compareNatural("2", "10")', 'compareText("B", ["A", "B", "C"])'], + seealso: ['compare', 'compareNatural'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/deepEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/deepEqual.js new file mode 100644 index 0000000..ff2b901 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/deepEqual.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.deepEqualDocs = void 0; +const deepEqualDocs = exports.deepEqualDocs = { + name: 'deepEqual', + category: 'Relational', + syntax: ['deepEqual(x, y)'], + description: 'Check equality of two matrices element wise. Returns true if the size of both matrices is equal and when and each of the elements are equal.', + examples: ['deepEqual([1,3,4], [1,3,4])', 'deepEqual([1,3,4], [1,3])'], + seealso: ['equal', 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equal.js new file mode 100644 index 0000000..f2977e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equal.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalDocs = void 0; +const equalDocs = exports.equalDocs = { + name: 'equal', + category: 'Relational', + syntax: ['x == y', 'equal(x, y)'], + description: 'Check equality of two values. Returns true if the values are equal, and false if not.', + examples: ['2+2 == 3', '2+2 == 4', 'a = 3.2', 'b = 6-2.8', 'a == b', '50cm == 0.5m'], + seealso: ['unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual', 'equalText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equalText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equalText.js new file mode 100644 index 0000000..e94f9cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equalText.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.equalTextDocs = void 0; +const equalTextDocs = exports.equalTextDocs = { + name: 'equalText', + category: 'Relational', + syntax: ['equalText(x, y)'], + description: 'Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.', + examples: ['equalText("Hello", "Hello")', 'equalText("a", "A")', 'equal("2e3", "2000")', 'equalText("2e3", "2000")', 'equalText("B", ["A", "B", "C"])'], + seealso: ['compare', 'compareNatural', 'compareText', 'equal'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/larger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/larger.js new file mode 100644 index 0000000..ec79948 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/larger.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerDocs = void 0; +const largerDocs = exports.largerDocs = { + name: 'larger', + category: 'Relational', + syntax: ['x > y', 'larger(x, y)'], + description: 'Check if value x is larger than y. Returns true if x is larger than y, and false if not.', + examples: ['2 > 3', '5 > 2*2', 'a = 3.3', 'b = 6-2.8', '(a > b)', '(b < a)', '5 cm > 2 inch'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/largerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/largerEq.js new file mode 100644 index 0000000..d93f194 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/largerEq.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.largerEqDocs = void 0; +const largerEqDocs = exports.largerEqDocs = { + name: 'largerEq', + category: 'Relational', + syntax: ['x >= y', 'largerEq(x, y)'], + description: 'Check if value x is larger or equal to y. Returns true if x is larger or equal to y, and false if not.', + examples: ['2 >= 1+1', '2 > 1+1', 'a = 3.2', 'b = 6-2.8', '(a >= b)'], + seealso: ['equal', 'unequal', 'smallerEq', 'smaller', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smaller.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smaller.js new file mode 100644 index 0000000..d185859 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smaller.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerDocs = void 0; +const smallerDocs = exports.smallerDocs = { + name: 'smaller', + category: 'Relational', + syntax: ['x < y', 'smaller(x, y)'], + description: 'Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.', + examples: ['2 < 3', '5 < 2*2', 'a = 3.3', 'b = 6-2.8', '(a < b)', '5 cm < 2 inch'], + seealso: ['equal', 'unequal', 'larger', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smallerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smallerEq.js new file mode 100644 index 0000000..ca9df76 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smallerEq.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.smallerEqDocs = void 0; +const smallerEqDocs = exports.smallerEqDocs = { + name: 'smallerEq', + category: 'Relational', + syntax: ['x <= y', 'smallerEq(x, y)'], + description: 'Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.', + examples: ['2 <= 1+1', '2 < 1+1', 'a = 3.2', 'b = 6-2.8', '(a <= b)'], + seealso: ['equal', 'unequal', 'larger', 'smaller', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/unequal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/unequal.js new file mode 100644 index 0000000..2b0cafe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/unequal.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.unequalDocs = void 0; +const unequalDocs = exports.unequalDocs = { + name: 'unequal', + category: 'Relational', + syntax: ['x != y', 'unequal(x, y)'], + description: 'Check unequality of two values. Returns true if the values are unequal, and false if they are equal.', + examples: ['2+2 != 3', '2+2 != 4', 'a = 3.2', 'b = 6-2.8', 'a != b', '50cm != 0.5m', '5 cm != 2 inch'], + seealso: ['equal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setCartesian.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setCartesian.js new file mode 100644 index 0000000..cec3f68 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setCartesian.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setCartesianDocs = void 0; +const setCartesianDocs = exports.setCartesianDocs = { + name: 'setCartesian', + category: 'Set', + syntax: ['setCartesian(set1, set2)'], + description: 'Create the cartesian product of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays and the values will be sorted in ascending order before the operation.', + examples: ['setCartesian([1, 2], [3, 4])'], + seealso: ['setUnion', 'setIntersect', 'setDifference', 'setPowerset'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDifference.js new file mode 100644 index 0000000..07ebe11 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDifference.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setDifferenceDocs = void 0; +const setDifferenceDocs = exports.setDifferenceDocs = { + name: 'setDifference', + category: 'Set', + syntax: ['setDifference(set1, set2)'], + description: 'Create the difference of two (multi)sets: every element of set1, that is not the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setIntersect', 'setSymDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDistinct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDistinct.js new file mode 100644 index 0000000..c543acd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDistinct.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setDistinctDocs = void 0; +const setDistinctDocs = exports.setDistinctDocs = { + name: 'setDistinct', + category: 'Set', + syntax: ['setDistinct(set)'], + description: 'Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setDistinct([1, 1, 1, 2, 2, 3])'], + seealso: ['setMultiplicity'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIntersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIntersect.js new file mode 100644 index 0000000..2ec82c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIntersect.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setIntersectDocs = void 0; +const setIntersectDocs = exports.setIntersectDocs = { + name: 'setIntersect', + category: 'Set', + syntax: ['setIntersect(set1, set2)'], + description: 'Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setIntersect([1, 2, 3, 4], [3, 4, 5, 6])', 'setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIsSubset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIsSubset.js new file mode 100644 index 0000000..fe4cdef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIsSubset.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setIsSubsetDocs = void 0; +const setIsSubsetDocs = exports.setIsSubsetDocs = { + name: 'setIsSubset', + category: 'Set', + syntax: ['setIsSubset(set1, set2)'], + description: 'Check whether a (multi)set is a subset of another (multi)set: every element of set1 is the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setIsSubset([1, 2], [3, 4, 5, 6])', 'setIsSubset([3, 4], [3, 4, 5, 6])'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setMultiplicity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setMultiplicity.js new file mode 100644 index 0000000..cb8e5af --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setMultiplicity.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setMultiplicityDocs = void 0; +const setMultiplicityDocs = exports.setMultiplicityDocs = { + name: 'setMultiplicity', + category: 'Set', + syntax: ['setMultiplicity(element, set)'], + description: 'Count the multiplicity of an element in a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setMultiplicity(1, [1, 2, 2, 4])', 'setMultiplicity(2, [1, 2, 2, 4])'], + seealso: ['setDistinct', 'setSize'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setPowerset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setPowerset.js new file mode 100644 index 0000000..5792aa3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setPowerset.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setPowersetDocs = void 0; +const setPowersetDocs = exports.setPowersetDocs = { + name: 'setPowerset', + category: 'Set', + syntax: ['setPowerset(set)'], + description: 'Create the powerset of a (multi)set: the powerset contains very possible subsets of a (multi)set. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setPowerset([1, 2, 3])'], + seealso: ['setCartesian'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSize.js new file mode 100644 index 0000000..a6583cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSize.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setSizeDocs = void 0; +const setSizeDocs = exports.setSizeDocs = { + name: 'setSize', + category: 'Set', + syntax: ['setSize(set)', 'setSize(set, unique)'], + description: 'Count the number of elements of a (multi)set. When the second parameter "unique" is true, count only the unique values. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setSize([1, 2, 2, 4])', 'setSize([1, 2, 2, 4], true)'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSymDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSymDifference.js new file mode 100644 index 0000000..fc5082d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSymDifference.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setSymDifferenceDocs = void 0; +const setSymDifferenceDocs = exports.setSymDifferenceDocs = { + name: 'setSymDifference', + category: 'Set', + syntax: ['setSymDifference(set1, set2)'], + description: 'Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setUnion.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setUnion.js new file mode 100644 index 0000000..b04e1a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setUnion.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.setUnionDocs = void 0; +const setUnionDocs = exports.setUnionDocs = { + name: 'setUnion', + category: 'Set', + syntax: ['setUnion(set1, set2)'], + description: 'Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setUnion([1, 2, 3, 4], [3, 4, 5, 6])', 'setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/freqz.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/freqz.js new file mode 100644 index 0000000..29ab618 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/freqz.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.freqzDocs = void 0; +const freqzDocs = exports.freqzDocs = { + name: 'freqz', + category: 'Signal', + syntax: ['freqz(b, a)', 'freqz(b, a, w)'], + description: 'Calculates the frequency response of a filter given its numerator and denominator coefficients.', + examples: ['freqz([1, 2], [1, 2, 3])', 'freqz([1, 2], [1, 2, 3], [0, 1])', 'freqz([1, 2], [1, 2, 3], 512)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/zpk2tf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/zpk2tf.js new file mode 100644 index 0000000..b2c782f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/signal/zpk2tf.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zpk2tfDocs = void 0; +const zpk2tfDocs = exports.zpk2tfDocs = { + name: 'zpk2tf', + category: 'Signal', + syntax: ['zpk2tf(z, p, k)'], + description: 'Compute the transfer function of a zero-pole-gain model.', + examples: ['zpk2tf([1, 2], [-1, -2], 1)', 'zpk2tf([1, 2], [-1, -2])', 'zpk2tf([1 - 3i, 2 + 2i], [-1, -2])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/erf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/erf.js new file mode 100644 index 0000000..1707384 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/erf.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.erfDocs = void 0; +const erfDocs = exports.erfDocs = { + name: 'erf', + category: 'Special', + syntax: ['erf(x)'], + description: 'Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x', + examples: ['erf(0.2)', 'erf(-0.5)', 'erf(4)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/zeta.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/zeta.js new file mode 100644 index 0000000..8a729d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/zeta.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.zetaDocs = void 0; +const zetaDocs = exports.zetaDocs = { + name: 'zeta', + category: 'Special', + syntax: ['zeta(s)'], + description: 'Compute the Riemann Zeta Function using an infinite series and Riemann\'s Functional Equation for the entire complex plane', + examples: ['zeta(0.2)', 'zeta(-0.5)', 'zeta(4)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/corr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/corr.js new file mode 100644 index 0000000..56d061e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/corr.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.corrDocs = void 0; +const corrDocs = exports.corrDocs = { + name: 'corr', + category: 'Statistics', + syntax: ['corr(A,B)'], + description: 'Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.', + examples: ['corr([2, 4, 6, 8],[1, 2, 3, 6])', 'corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'prod', 'std', 'sum'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/cumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/cumsum.js new file mode 100644 index 0000000..7ccc28f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/cumsum.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cumSumDocs = void 0; +const cumSumDocs = exports.cumSumDocs = { + name: 'cumsum', + category: 'Statistics', + syntax: ['cumsum(a, b, c, ...)', 'cumsum(A)'], + description: 'Compute the cumulative sum of all values.', + examples: ['cumsum(2, 3, 4, 1)', 'cumsum([2, 3, 4, 1])', 'cumsum([1, 2; 3, 4])', 'cumsum([1, 2; 3, 4], 1)', 'cumsum([1, 2; 3, 4], 2)'], + seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mad.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mad.js new file mode 100644 index 0000000..f65b29f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mad.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.madDocs = void 0; +const madDocs = exports.madDocs = { + name: 'mad', + category: 'Statistics', + syntax: ['mad(a, b, c, ...)', 'mad(A)'], + description: 'Compute the median absolute deviation of a matrix or a list with values. The median absolute deviation is defined as the median of the absolute deviations from the median.', + examples: ['mad(10, 20, 30)', 'mad([1, 2, 3])'], + seealso: ['mean', 'median', 'std', 'abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/max.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/max.js new file mode 100644 index 0000000..52fca24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/max.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.maxDocs = void 0; +const maxDocs = exports.maxDocs = { + name: 'max', + category: 'Statistics', + syntax: ['max(a, b, c, ...)', 'max(A)', 'max(A, dimension)'], + description: 'Compute the maximum value of a list of values.', + examples: ['max(2, 3, 4, 1)', 'max([2, 3, 4, 1])', 'max([2, 5; 4, 3])', 'max([2, 5; 4, 3], 1)', 'max([2, 5; 4, 3], 2)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)'], + seealso: ['mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mean.js new file mode 100644 index 0000000..746490e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mean.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.meanDocs = void 0; +const meanDocs = exports.meanDocs = { + name: 'mean', + category: 'Statistics', + syntax: ['mean(a, b, c, ...)', 'mean(A)', 'mean(A, dimension)'], + description: 'Compute the arithmetic mean of a list of values.', + examples: ['mean(2, 3, 4, 1)', 'mean([2, 3, 4, 1])', 'mean([2, 5; 4, 3])', 'mean([2, 5; 4, 3], 1)', 'mean([2, 5; 4, 3], 2)', 'mean([1.0, 2.7, 3.2, 4.0])'], + seealso: ['max', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/median.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/median.js new file mode 100644 index 0000000..112d6ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/median.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.medianDocs = void 0; +const medianDocs = exports.medianDocs = { + name: 'median', + category: 'Statistics', + syntax: ['median(a, b, c, ...)', 'median(A)'], + description: 'Compute the median of all values. The values are sorted and the middle value is returned. In case of an even number of values, the average of the two middle values is returned.', + examples: ['median(5, 2, 7)', 'median([3, -1, 5, 7])'], + seealso: ['max', 'mean', 'min', 'prod', 'std', 'sum', 'variance', 'quantileSeq'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/min.js new file mode 100644 index 0000000..17d7bc0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/min.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.minDocs = void 0; +const minDocs = exports.minDocs = { + name: 'min', + category: 'Statistics', + syntax: ['min(a, b, c, ...)', 'min(A)', 'min(A, dimension)'], + description: 'Compute the minimum value of a list of values.', + examples: ['min(2, 3, 4, 1)', 'min([2, 3, 4, 1])', 'min([2, 5; 4, 3])', 'min([2, 5; 4, 3], 1)', 'min([2, 5; 4, 3], 2)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)'], + seealso: ['max', 'mean', 'median', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mode.js new file mode 100644 index 0000000..b086010 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mode.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.modeDocs = void 0; +const modeDocs = exports.modeDocs = { + name: 'mode', + category: 'Statistics', + syntax: ['mode(a, b, c, ...)', 'mode(A)', 'mode(A, a, b, B, c, ...)'], + description: 'Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.', + examples: ['mode(2, 1, 4, 3, 1)', 'mode([1, 2.7, 3.2, 4, 2.7])', 'mode(1, 4, 6, 1, 6)'], + seealso: ['max', 'mean', 'min', 'median', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/prod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/prod.js new file mode 100644 index 0000000..3f9a7d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/prod.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.prodDocs = void 0; +const prodDocs = exports.prodDocs = { + name: 'prod', + category: 'Statistics', + syntax: ['prod(a, b, c, ...)', 'prod(A)'], + description: 'Compute the product of all values.', + examples: ['prod(2, 3, 4)', 'prod([2, 3, 4])', 'prod([2, 5; 4, 3])'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/quantileSeq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/quantileSeq.js new file mode 100644 index 0000000..a72e937 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/quantileSeq.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.quantileSeqDocs = void 0; +const quantileSeqDocs = exports.quantileSeqDocs = { + name: 'quantileSeq', + category: 'Statistics', + syntax: ['quantileSeq(A, prob[, sorted])', 'quantileSeq(A, [prob1, prob2, ...][, sorted])', 'quantileSeq(A, N[, sorted])'], + description: 'Compute the prob order quantile of a matrix or a list with values. The sequence is sorted and the middle value is returned. Supported types of sequence values are: Number, BigNumber, Unit Supported types of probability are: Number, BigNumber. \n\nIn case of a (multi dimensional) array or matrix, the prob order quantile of all elements will be calculated.', + examples: ['quantileSeq([3, -1, 5, 7], 0.5)', 'quantileSeq([3, -1, 5, 7], [1/3, 2/3])', 'quantileSeq([3, -1, 5, 7], 2)', 'quantileSeq([-1, 3, 5, 7], 0.5, true)'], + seealso: ['mean', 'median', 'min', 'max', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/std.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/std.js new file mode 100644 index 0000000..57ddbdc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/std.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.stdDocs = void 0; +const stdDocs = exports.stdDocs = { + name: 'std', + category: 'Statistics', + syntax: ['std(a, b, c, ...)', 'std(A)', 'std(A, dimension)', 'std(A, normalization)', 'std(A, dimension, normalization)'], + description: 'Compute the standard deviation of all values, defined as std(A) = sqrt(variance(A)). Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".', + examples: ['std(2, 4, 6)', 'std([2, 4, 6, 8])', 'std([2, 4, 6, 8], "uncorrected")', 'std([2, 4, 6, 8], "biased")', 'std([1, 2, 3; 4, 5, 6])'], + seealso: ['max', 'mean', 'min', 'median', 'prod', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/sum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/sum.js new file mode 100644 index 0000000..feff15c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/sum.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sumDocs = void 0; +const sumDocs = exports.sumDocs = { + name: 'sum', + category: 'Statistics', + syntax: ['sum(a, b, c, ...)', 'sum(A)', 'sum(A, dimension)'], + description: 'Compute the sum of all values.', + examples: ['sum(2, 3, 4, 1)', 'sum([2, 3, 4, 1])', 'sum([2, 5; 4, 3])'], + seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/variance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/variance.js new file mode 100644 index 0000000..379f051 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/variance.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.varianceDocs = void 0; +const varianceDocs = exports.varianceDocs = { + name: 'variance', + category: 'Statistics', + syntax: ['variance(a, b, c, ...)', 'variance(A)', 'variance(A, dimension)', 'variance(A, normalization)', 'variance(A, dimension, normalization)'], + description: 'Compute the variance of all values. Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".', + examples: ['variance(2, 4, 6)', 'variance([2, 4, 6, 8])', 'variance([2, 4, 6, 8], "uncorrected")', 'variance([2, 4, 6, 8], "biased")', 'variance([1, 2, 3; 4, 5, 6])'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'prod', 'std', 'sum'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acos.js new file mode 100644 index 0000000..05d01c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acos.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acosDocs = void 0; +const acosDocs = exports.acosDocs = { + name: 'acos', + category: 'Trigonometry', + syntax: ['acos(x)'], + description: 'Compute the inverse cosine of a value in radians.', + examples: ['acos(0.5)', 'acos(cos(2.3))'], + seealso: ['cos', 'atan', 'asin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acosh.js new file mode 100644 index 0000000..3ee6f2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acosh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acoshDocs = void 0; +const acoshDocs = exports.acoshDocs = { + name: 'acosh', + category: 'Trigonometry', + syntax: ['acosh(x)'], + description: 'Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.', + examples: ['acosh(1.5)'], + seealso: ['cosh', 'asinh', 'atanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acot.js new file mode 100644 index 0000000..2f35edf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acotDocs = void 0; +const acotDocs = exports.acotDocs = { + name: 'acot', + category: 'Trigonometry', + syntax: ['acot(x)'], + description: 'Calculate the inverse cotangent of a value.', + examples: ['acot(0.5)', 'acot(cot(0.5))', 'acot(2)'], + seealso: ['cot', 'atan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acoth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acoth.js new file mode 100644 index 0000000..13d0eee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acoth.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acothDocs = void 0; +const acothDocs = exports.acothDocs = { + name: 'acoth', + category: 'Trigonometry', + syntax: ['acoth(x)'], + description: 'Calculate the inverse hyperbolic tangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.', + examples: ['acoth(2)', 'acoth(0.5)'], + seealso: ['acsch', 'asech'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsc.js new file mode 100644 index 0000000..9446b55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsc.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acscDocs = void 0; +const acscDocs = exports.acscDocs = { + name: 'acsc', + category: 'Trigonometry', + syntax: ['acsc(x)'], + description: 'Calculate the inverse cotangent of a value.', + examples: ['acsc(2)', 'acsc(csc(0.5))', 'acsc(0.5)'], + seealso: ['csc', 'asin', 'asec'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsch.js new file mode 100644 index 0000000..a89abd9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsch.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acschDocs = void 0; +const acschDocs = exports.acschDocs = { + name: 'acsch', + category: 'Trigonometry', + syntax: ['acsch(x)'], + description: 'Calculate the inverse hyperbolic cosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.', + examples: ['acsch(0.5)'], + seealso: ['asech', 'acoth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asec.js new file mode 100644 index 0000000..2cdd502 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asec.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asecDocs = void 0; +const asecDocs = exports.asecDocs = { + name: 'asec', + category: 'Trigonometry', + syntax: ['asec(x)'], + description: 'Calculate the inverse secant of a value.', + examples: ['asec(0.5)', 'asec(sec(0.5))', 'asec(2)'], + seealso: ['acos', 'acot', 'acsc'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asech.js new file mode 100644 index 0000000..61aad99 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asech.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asechDocs = void 0; +const asechDocs = exports.asechDocs = { + name: 'asech', + category: 'Trigonometry', + syntax: ['asech(x)'], + description: 'Calculate the inverse secant of a value.', + examples: ['asech(0.5)'], + seealso: ['acsch', 'acoth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asin.js new file mode 100644 index 0000000..e2f4a45 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asin.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinDocs = void 0; +const asinDocs = exports.asinDocs = { + name: 'asin', + category: 'Trigonometry', + syntax: ['asin(x)'], + description: 'Compute the inverse sine of a value in radians.', + examples: ['asin(0.5)', 'asin(sin(0.5))'], + seealso: ['sin', 'acos', 'atan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asinh.js new file mode 100644 index 0000000..33a23df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asinh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.asinhDocs = void 0; +const asinhDocs = exports.asinhDocs = { + name: 'asinh', + category: 'Trigonometry', + syntax: ['asinh(x)'], + description: 'Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.', + examples: ['asinh(0.5)'], + seealso: ['acosh', 'atanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan.js new file mode 100644 index 0000000..ab92912 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanDocs = void 0; +const atanDocs = exports.atanDocs = { + name: 'atan', + category: 'Trigonometry', + syntax: ['atan(x)'], + description: 'Compute the inverse tangent of a value in radians.', + examples: ['atan(0.5)', 'atan(tan(0.5))'], + seealso: ['tan', 'acos', 'asin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan2.js new file mode 100644 index 0000000..0c77024 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan2.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atan2Docs = void 0; +const atan2Docs = exports.atan2Docs = { + name: 'atan2', + category: 'Trigonometry', + syntax: ['atan2(y, x)'], + description: 'Computes the principal value of the arc tangent of y/x in radians.', + examples: ['atan2(2, 2) / pi', 'angle = 60 deg in rad', 'x = cos(angle)', 'y = sin(angle)', 'atan2(y, x)'], + seealso: ['sin', 'cos', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atanh.js new file mode 100644 index 0000000..9a40ab9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atanh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.atanhDocs = void 0; +const atanhDocs = exports.atanhDocs = { + name: 'atanh', + category: 'Trigonometry', + syntax: ['atanh(x)'], + description: 'Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.', + examples: ['atanh(0.5)'], + seealso: ['acosh', 'asinh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cos.js new file mode 100644 index 0000000..1d03c53 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cos.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cosDocs = void 0; +const cosDocs = exports.cosDocs = { + name: 'cos', + category: 'Trigonometry', + syntax: ['cos(x)'], + description: 'Compute the cosine of x in radians.', + examples: ['cos(2)', 'cos(pi / 4) ^ 2', 'cos(180 deg)', 'cos(60 deg)', 'sin(0.2)^2 + cos(0.2)^2'], + seealso: ['acos', 'sin', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cosh.js new file mode 100644 index 0000000..8c4974f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cosh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.coshDocs = void 0; +const coshDocs = exports.coshDocs = { + name: 'cosh', + category: 'Trigonometry', + syntax: ['cosh(x)'], + description: 'Compute the hyperbolic cosine of x in radians.', + examples: ['cosh(0.5)'], + seealso: ['sinh', 'tanh', 'coth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cot.js new file mode 100644 index 0000000..dc6d236 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cot.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cotDocs = void 0; +const cotDocs = exports.cotDocs = { + name: 'cot', + category: 'Trigonometry', + syntax: ['cot(x)'], + description: 'Compute the cotangent of x in radians. Defined as 1/tan(x)', + examples: ['cot(2)', '1 / tan(2)'], + seealso: ['sec', 'csc', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/coth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/coth.js new file mode 100644 index 0000000..9befa09 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/coth.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cothDocs = void 0; +const cothDocs = exports.cothDocs = { + name: 'coth', + category: 'Trigonometry', + syntax: ['coth(x)'], + description: 'Compute the hyperbolic cotangent of x in radians.', + examples: ['coth(2)', '1 / tanh(2)'], + seealso: ['sech', 'csch', 'tanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csc.js new file mode 100644 index 0000000..ef78466 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csc.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cscDocs = void 0; +const cscDocs = exports.cscDocs = { + name: 'csc', + category: 'Trigonometry', + syntax: ['csc(x)'], + description: 'Compute the cosecant of x in radians. Defined as 1/sin(x)', + examples: ['csc(2)', '1 / sin(2)'], + seealso: ['sec', 'cot', 'sin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csch.js new file mode 100644 index 0000000..632d002 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csch.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cschDocs = void 0; +const cschDocs = exports.cschDocs = { + name: 'csch', + category: 'Trigonometry', + syntax: ['csch(x)'], + description: 'Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)', + examples: ['csch(2)', '1 / sinh(2)'], + seealso: ['sech', 'coth', 'sinh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sec.js new file mode 100644 index 0000000..5012d7b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sec.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.secDocs = void 0; +const secDocs = exports.secDocs = { + name: 'sec', + category: 'Trigonometry', + syntax: ['sec(x)'], + description: 'Compute the secant of x in radians. Defined as 1/cos(x)', + examples: ['sec(2)', '1 / cos(2)'], + seealso: ['cot', 'csc', 'cos'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sech.js new file mode 100644 index 0000000..8eda9d2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sech.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sechDocs = void 0; +const sechDocs = exports.sechDocs = { + name: 'sech', + category: 'Trigonometry', + syntax: ['sech(x)'], + description: 'Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)', + examples: ['sech(2)', '1 / cosh(2)'], + seealso: ['coth', 'csch', 'cosh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sin.js new file mode 100644 index 0000000..ca704e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sin.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinDocs = void 0; +const sinDocs = exports.sinDocs = { + name: 'sin', + category: 'Trigonometry', + syntax: ['sin(x)'], + description: 'Compute the sine of x in radians.', + examples: ['sin(2)', 'sin(pi / 4) ^ 2', 'sin(90 deg)', 'sin(30 deg)', 'sin(0.2)^2 + cos(0.2)^2'], + seealso: ['asin', 'cos', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sinh.js new file mode 100644 index 0000000..df0303a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sinh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.sinhDocs = void 0; +const sinhDocs = exports.sinhDocs = { + name: 'sinh', + category: 'Trigonometry', + syntax: ['sinh(x)'], + description: 'Compute the hyperbolic sine of x in radians.', + examples: ['sinh(0.5)'], + seealso: ['cosh', 'tanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tan.js new file mode 100644 index 0000000..ab89970 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tan.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanDocs = void 0; +const tanDocs = exports.tanDocs = { + name: 'tan', + category: 'Trigonometry', + syntax: ['tan(x)'], + description: 'Compute the tangent of x in radians.', + examples: ['tan(0.5)', 'sin(0.5) / cos(0.5)', 'tan(pi / 4)', 'tan(45 deg)'], + seealso: ['atan', 'sin', 'cos'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tanh.js new file mode 100644 index 0000000..6c677d8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tanh.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tanhDocs = void 0; +const tanhDocs = exports.tanhDocs = { + name: 'tanh', + category: 'Trigonometry', + syntax: ['tanh(x)'], + description: 'Compute the hyperbolic tangent of x in radians.', + examples: ['tanh(0.5)', 'sinh(0.5) / cosh(0.5)'], + seealso: ['sinh', 'cosh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/units/to.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/units/to.js new file mode 100644 index 0000000..c7c20f0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/units/to.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.toDocs = void 0; +const toDocs = exports.toDocs = { + name: 'to', + category: 'Units', + syntax: ['x to unit', 'to(x, unit)'], + description: 'Change the unit of a value.', + examples: ['5 inch to cm', '3.2kg to g', '16 bytes in bits'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/bin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/bin.js new file mode 100644 index 0000000..fe741e2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/bin.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.binDocs = void 0; +const binDocs = exports.binDocs = { + name: 'bin', + category: 'Utils', + syntax: ['bin(value)'], + description: 'Format a number as binary', + examples: ['bin(2)'], + seealso: ['oct', 'hex'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/clone.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/clone.js new file mode 100644 index 0000000..154ef8b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/clone.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cloneDocs = void 0; +const cloneDocs = exports.cloneDocs = { + name: 'clone', + category: 'Utils', + syntax: ['clone(x)'], + description: 'Clone a variable. Creates a copy of primitive variables, and a deep copy of matrices', + examples: ['clone(3.5)', 'clone(2 - 4i)', 'clone(45 deg)', 'clone([1, 2; 3, 4])', 'clone("hello world")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/format.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/format.js new file mode 100644 index 0000000..283dfb5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/format.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.formatDocs = void 0; +const formatDocs = exports.formatDocs = { + name: 'format', + category: 'Utils', + syntax: ['format(value)', 'format(value, precision)'], + description: 'Format a value of any type as string.', + examples: ['format(2.3)', 'format(3 - 4i)', 'format([])', 'format(pi, 3)'], + seealso: ['print'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hasNumericValue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hasNumericValue.js new file mode 100644 index 0000000..9026b05 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hasNumericValue.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasNumericValueDocs = void 0; +const hasNumericValueDocs = exports.hasNumericValueDocs = { + name: 'hasNumericValue', + category: 'Utils', + syntax: ['hasNumericValue(x)'], + description: 'Test whether a value is an numeric value. ' + 'In case of a string, true is returned if the string contains a numeric value.', + examples: ['hasNumericValue(2)', 'hasNumericValue("2")', 'isNumeric("2")', 'hasNumericValue(0)', 'hasNumericValue(bignumber(500))', 'hasNumericValue(fraction(0.125))', 'hasNumericValue(2 + 3i)', 'hasNumericValue([2.3, "foo", false])'], + seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'isNumeric'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hex.js new file mode 100644 index 0000000..b5733cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hex.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hexDocs = void 0; +const hexDocs = exports.hexDocs = { + name: 'hex', + category: 'Utils', + syntax: ['hex(value)'], + description: 'Format a number as hexadecimal', + examples: ['hex(240)'], + seealso: ['bin', 'oct'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isInteger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isInteger.js new file mode 100644 index 0000000..75108bc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isInteger.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isIntegerDocs = void 0; +const isIntegerDocs = exports.isIntegerDocs = { + name: 'isInteger', + category: 'Utils', + syntax: ['isInteger(x)'], + description: 'Test whether a value is an integer number.', + examples: ['isInteger(2)', 'isInteger(3.5)', 'isInteger([3, 0.5, -2])'], + seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNaN.js new file mode 100644 index 0000000..c1c2060 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNaN.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNaNDocs = void 0; +const isNaNDocs = exports.isNaNDocs = { + name: 'isNaN', + category: 'Utils', + syntax: ['isNaN(x)'], + description: 'Test whether a value is NaN (not a number)', + examples: ['isNaN(2)', 'isNaN(0 / 0)', 'isNaN(NaN)', 'isNaN(Infinity)'], + seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNegative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNegative.js new file mode 100644 index 0000000..d6ce6be --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNegative.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNegativeDocs = void 0; +const isNegativeDocs = exports.isNegativeDocs = { + name: 'isNegative', + category: 'Utils', + syntax: ['isNegative(x)'], + description: 'Test whether a value is negative: smaller than zero.', + examples: ['isNegative(2)', 'isNegative(0)', 'isNegative(-4)', 'isNegative([3, 0.5, -2])'], + seealso: ['isInteger', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNumeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNumeric.js new file mode 100644 index 0000000..669e126 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNumeric.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isNumericDocs = void 0; +const isNumericDocs = exports.isNumericDocs = { + name: 'isNumeric', + category: 'Utils', + syntax: ['isNumeric(x)'], + description: 'Test whether a value is a numeric value. ' + 'Returns true when the input is a number, BigNumber, Fraction, or boolean.', + examples: ['isNumeric(2)', 'isNumeric("2")', 'hasNumericValue("2")', 'isNumeric(0)', 'isNumeric(bignumber(500))', 'isNumeric(fraction(0.125))', 'isNumeric(2 + 3i)', 'isNumeric([2.3, "foo", false])'], + seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'hasNumericValue'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPositive.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPositive.js new file mode 100644 index 0000000..5d0903c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPositive.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPositiveDocs = void 0; +const isPositiveDocs = exports.isPositiveDocs = { + name: 'isPositive', + category: 'Utils', + syntax: ['isPositive(x)'], + description: 'Test whether a value is positive: larger than zero.', + examples: ['isPositive(2)', 'isPositive(0)', 'isPositive(-4)', 'isPositive([3, 0.5, -2])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPrime.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPrime.js new file mode 100644 index 0000000..06c8bbf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPrime.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isPrimeDocs = void 0; +const isPrimeDocs = exports.isPrimeDocs = { + name: 'isPrime', + category: 'Utils', + syntax: ['isPrime(x)'], + description: 'Test whether a value is prime: has no divisors other than itself and one.', + examples: ['isPrime(3)', 'isPrime(-2)', 'isPrime([2, 17, 100])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isZero.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isZero.js new file mode 100644 index 0000000..ecd3ed1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isZero.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isZeroDocs = void 0; +const isZeroDocs = exports.isZeroDocs = { + name: 'isZero', + category: 'Utils', + syntax: ['isZero(x)'], + description: 'Test whether a value is zero.', + examples: ['isZero(2)', 'isZero(0)', 'isZero(-4)', 'isZero([3, 0, -2, 0])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isPositive'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/numeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/numeric.js new file mode 100644 index 0000000..00ff3b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/numeric.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.numericDocs = void 0; +const numericDocs = exports.numericDocs = { + name: 'numeric', + category: 'Utils', + syntax: ['numeric(x)'], + description: 'Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.', + examples: ['numeric("4")', 'numeric("4", "number")', 'numeric("4", "bigint")', 'numeric("4", "BigNumber")', 'numeric("4", "Fraction")', 'numeric(4, "Fraction")', 'numeric(fraction(2, 5), "number")'], + seealso: ['number', 'bigint', 'fraction', 'bignumber', 'string', 'format'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/oct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/oct.js new file mode 100644 index 0000000..f34b41f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/oct.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.octDocs = void 0; +const octDocs = exports.octDocs = { + name: 'oct', + category: 'Utils', + syntax: ['oct(value)'], + description: 'Format a number as octal', + examples: ['oct(56)'], + seealso: ['bin', 'hex'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/print.js new file mode 100644 index 0000000..cfdcef9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/print.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.printDocs = void 0; +const printDocs = exports.printDocs = { + name: 'print', + category: 'Utils', + syntax: ['print(template, values)', 'print(template, values, precision)'], + description: 'Interpolate values into a string template.', + examples: ['print("Lucy is $age years old", {age: 5})', 'print("The value of pi is $pi", {pi: pi}, 3)', 'print("Hello, $user.name!", {user: {name: "John"}})', 'print("Values: $1, $2, $3", [6, 9, 4])'], + seealso: ['format'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/typeOf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/typeOf.js new file mode 100644 index 0000000..a9a8ad4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/typeOf.js @@ -0,0 +1,14 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.typeOfDocs = void 0; +const typeOfDocs = exports.typeOfDocs = { + name: 'typeOf', + category: 'Utils', + syntax: ['typeOf(x)'], + description: 'Get the type of a variable.', + examples: ['typeOf(3.5)', 'typeOf(2 - 4i)', 'typeOf(45 deg)', 'typeOf("hello world")'], + seealso: ['getMatrixDataType'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/compile.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/compile.js new file mode 100644 index 0000000..14a7e02 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/compile.js @@ -0,0 +1,60 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCompile = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'compile'; +const dependencies = ['typed', 'parse']; +const createCompile = exports.createCompile = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + parse + } = _ref; + /** + * Parse and compile an expression. + * Returns a an object with a function `evaluate([scope])` to evaluate the + * compiled expression. + * + * Syntax: + * + * math.compile(expr) // returns one node + * math.compile([expr1, expr2, expr3, ...]) // returns an array with nodes + * + * Examples: + * + * const code1 = math.compile('sqrt(3^2 + 4^2)') + * code1.evaluate() // 5 + * + * let scope = {a: 3, b: 4} + * const code2 = math.compile('a * b') // 12 + * code2.evaluate(scope) // 12 + * scope.a = 5 + * code2.evaluate(scope) // 20 + * + * const nodes = math.compile(['a = 3', 'b = 4', 'a * b']) + * nodes[2].evaluate() // 12 + * + * See also: + * + * parse, evaluate + * + * @param {string | string[] | Array | Matrix} expr + * The expression to be compiled + * @return {{evaluate: Function} | Array.<{evaluate: Function}>} code + * An object with the compiled expression + * @throws {Error} + */ + return typed(name, { + string: function (expr) { + return parse(expr).compile(); + }, + 'Array | Matrix': function (expr) { + return (0, _collection.deepMap)(expr, function (entry) { + return parse(entry).compile(); + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/evaluate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/evaluate.js new file mode 100644 index 0000000..17e4b9d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/evaluate.js @@ -0,0 +1,74 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createEvaluate = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _map = require("../../utils/map.js"); +const name = 'evaluate'; +const dependencies = ['typed', 'parse']; +const createEvaluate = exports.createEvaluate = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + parse + } = _ref; + /** + * Evaluate an expression. + * + * The expression parser does not use JavaScript. Its syntax is close + * to JavaScript but more suited for mathematical expressions. + * See [https://mathjs.org/docs/expressions/syntax.html](https://mathjs.org/docs/expressions/syntax.html) to learn + * the syntax and get an overview of the exact differences from JavaScript. + * + * Note the evaluating arbitrary expressions may involve security risks, + * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information. + * + * Syntax: + * + * math.evaluate(expr) + * math.evaluate(expr, scope) + * math.evaluate([expr1, expr2, expr3, ...]) + * math.evaluate([expr1, expr2, expr3, ...], scope) + * + * Example: + * + * math.evaluate('(2+3)/4') // 1.25 + * math.evaluate('sqrt(3^2 + 4^2)') // 5 + * math.evaluate('sqrt(-4)') // 2i + * math.evaluate(['a=3', 'b=4', 'a*b']) // [3, 4, 12] + * + * let scope = {a:3, b:4} + * math.evaluate('a * b', scope) // 12 + * + * See also: + * + * parse, compile + * + * @param {string | string[] | Matrix} expr The expression to be evaluated + * @param {Object} [scope] Scope to read/write variables + * @return {*} The result of the expression + * @throws {Error} + */ + return typed(name, { + string: function (expr) { + const scope = (0, _map.createEmptyMap)(); + return parse(expr).compile().evaluate(scope); + }, + 'string, Map | Object': function (expr, scope) { + return parse(expr).compile().evaluate(scope); + }, + 'Array | Matrix': function (expr) { + const scope = (0, _map.createEmptyMap)(); + return (0, _collection.deepMap)(expr, function (entry) { + return parse(entry).compile().evaluate(scope); + }); + }, + 'Array | Matrix, Map | Object': function (expr, scope) { + return (0, _collection.deepMap)(expr, function (entry) { + return parse(entry).compile().evaluate(scope); + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/help.js new file mode 100644 index 0000000..1d8948b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/help.js @@ -0,0 +1,72 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createHelp = void 0; +var _factory = require("../../utils/factory.js"); +var _customs = require("../../utils/customs.js"); +var _embeddedDocs = require("../embeddedDocs/embeddedDocs.js"); +var _object = require("../../utils/object.js"); +const name = 'help'; +const dependencies = ['typed', 'mathWithTransform', 'Help']; +const createHelp = exports.createHelp = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + mathWithTransform, + Help + } = _ref; + /** + * Retrieve help on a function or data type. + * Help files are retrieved from the embedded documentation in math.docs. + * + * Syntax: + * + * math.help(search) + * + * Examples: + * + * console.log(math.help('sin').toString()) + * console.log(math.help(math.add).toString()) + * console.log(math.help(math.add).toJSON()) + * + * @param {Function | string | Object} search A function or function name + * for which to get help + * @return {Help} A help object + */ + return typed(name, { + any: function (search) { + let prop; + let searchName = search; + if (typeof search !== 'string') { + for (prop in mathWithTransform) { + // search in functions and constants + if ((0, _object.hasOwnProperty)(mathWithTransform, prop) && search === mathWithTransform[prop]) { + searchName = prop; + break; + } + } + + /* TODO: implement help for data types + if (!text) { + // search data type + for (prop in math.type) { + if (hasOwnProperty(math, prop)) { + if (search === math.type[prop]) { + text = prop + break + } + } + } + } + */ + } + const doc = (0, _customs.getSafeProperty)(_embeddedDocs.embeddedDocs, searchName); + if (!doc) { + const searchText = typeof searchName === 'function' ? searchName.name : searchName; + throw new Error('No documentation found on "' + searchText + '"'); + } + return new Help(doc); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/parser.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/parser.js new file mode 100644 index 0000000..60255e2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/function/parser.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createParser = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'parser'; +const dependencies = ['typed', 'Parser']; +const createParser = exports.createParser = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Parser + } = _ref; + /** + * Create a parser. The function creates a new `math.Parser` object. + * + * Syntax: + * + * math.parser() + * + * Examples: + * + * const parser = new math.parser() + * + * // evaluate expressions + * const a = parser.evaluate('sqrt(3^2 + 4^2)') // 5 + * const b = parser.evaluate('sqrt(-4)') // 2i + * const c = parser.evaluate('2 inch in cm') // 5.08 cm + * const d = parser.evaluate('cos(45 deg)') // 0.7071067811865476 + * + * // define variables and functions + * parser.evaluate('x = 7 / 2') // 3.5 + * parser.evaluate('x + 3') // 6.5 + * parser.evaluate('f(x, y) = x^y') // f(x, y) + * parser.evaluate('f(2, 3)') // 8 + * + * // get and set variables and functions + * const x = parser.get('x') // 3.5 + * const f = parser.get('f') // function + * const g = f(3, 2) // 9 + * parser.set('h', 500) + * const i = parser.evaluate('h / 2') // 250 + * parser.set('hello', function (name) { + * return 'hello, ' + name + '!' + * }) + * parser.evaluate('hello("user")') // "hello, user!" + * + * // clear defined functions and variables + * parser.clear() + * + * See also: + * + * evaluate, compile, parse + * + * @return {Parser} Parser + */ + return typed(name, { + '': function () { + return new Parser(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/keywords.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/keywords.js new file mode 100644 index 0000000..e89262f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/keywords.js @@ -0,0 +1,8 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.keywords = void 0; +// Reserved keywords not allowed to use in the parser +const keywords = exports.keywords = new Set(['end']); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AccessorNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AccessorNode.js new file mode 100644 index 0000000..b916377 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AccessorNode.js @@ -0,0 +1,196 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAccessorNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _customs = require("../../utils/customs.js"); +var _factory = require("../../utils/factory.js"); +var _access = require("./utils/access.js"); +const name = 'AccessorNode'; +const dependencies = ['subset', 'Node']; +const createAccessorNode = exports.createAccessorNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + subset, + Node + } = _ref; + const access = (0, _access.accessFactory)({ + subset + }); + + /** + * Are parenthesis needed? + * @private + */ + function needParenthesis(node) { + // TODO: maybe make a method on the nodes which tells whether they need parenthesis? + return !((0, _is.isAccessorNode)(node) || (0, _is.isArrayNode)(node) || (0, _is.isConstantNode)(node) || (0, _is.isFunctionNode)(node) || (0, _is.isObjectNode)(node) || (0, _is.isParenthesisNode)(node) || (0, _is.isSymbolNode)(node)); + } + class AccessorNode extends Node { + /** + * @constructor AccessorNode + * @extends {Node} + * Access an object property or get a matrix subset + * + * @param {Node} object The object from which to retrieve + * a property or subset. + * @param {IndexNode} index IndexNode containing ranges + */ + constructor(object, index) { + super(); + if (!(0, _is.isNode)(object)) { + throw new TypeError('Node expected for parameter "object"'); + } + if (!(0, _is.isIndexNode)(index)) { + throw new TypeError('IndexNode expected for parameter "index"'); + } + this.object = object; + this.index = index; + } + + // readonly property name + get name() { + if (this.index) { + return this.index.isObjectProperty() ? this.index.getObjectProperty() : ''; + } else { + return this.object.name || ''; + } + } + get type() { + return name; + } + get isAccessorNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalObject = this.object._compile(math, argNames); + const evalIndex = this.index._compile(math, argNames); + if (this.index.isObjectProperty()) { + const prop = this.index.getObjectProperty(); + return function evalAccessorNode(scope, args, context) { + // get a property from an object evaluated using the scope. + return (0, _customs.getSafeProperty)(evalObject(scope, args, context), prop); + }; + } else { + return function evalAccessorNode(scope, args, context) { + const object = evalObject(scope, args, context); + // we pass just object here instead of context: + const index = evalIndex(scope, args, object); + return access(object, index); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.object, 'object', this); + callback(this.index, 'index', this); + } + + /** + * Create a new AccessorNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {AccessorNode} Returns a transformed copy of the node + */ + map(callback) { + return new AccessorNode(this._ifNode(callback(this.object, 'object', this)), this._ifNode(callback(this.index, 'index', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {AccessorNode} + */ + clone() { + return new AccessorNode(this.object, this.index); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} + */ + _toString(options) { + let object = this.object.toString(options); + if (needParenthesis(this.object)) { + object = '(' + object + ')'; + } + return object + this.index.toString(options); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} + */ + _toHTML(options) { + let object = this.object.toHTML(options); + if (needParenthesis(this.object)) { + object = '(' + object + ')'; + } + return object + this.index.toHTML(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} + */ + _toTex(options) { + let object = this.object.toTex(options); + if (needParenthesis(this.object)) { + object = '\\left(\' + object + \'\\right)'; + } + return object + this.index.toTex(options); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + object: this.object, + index: this.index + }; + } + + /** + * Instantiate an AccessorNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "AccessorNode", object: ..., index: ...}`, + * where mathjs is optional + * @returns {AccessorNode} + */ + static fromJSON(json) { + return new AccessorNode(json.object, json.index); + } + } + (0, _defineProperty2.default)(AccessorNode, "name", name); + return AccessorNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ArrayNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ArrayNode.js new file mode 100644 index 0000000..1392b3e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ArrayNode.js @@ -0,0 +1,183 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createArrayNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'ArrayNode'; +const dependencies = ['Node']; +const createArrayNode = exports.createArrayNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + class ArrayNode extends Node { + /** + * @constructor ArrayNode + * @extends {Node} + * Holds an 1-dimensional array with items + * @param {Node[]} [items] 1 dimensional array with items + */ + constructor(items) { + super(); + this.items = items || []; + + // validate input + if (!Array.isArray(this.items) || !this.items.every(_is.isNode)) { + throw new TypeError('Array containing Nodes expected'); + } + } + get type() { + return name; + } + get isArrayNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalItems = (0, _array.map)(this.items, function (item) { + return item._compile(math, argNames); + }); + const asMatrix = math.config.matrix !== 'Array'; + if (asMatrix) { + const matrix = math.matrix; + return function evalArrayNode(scope, args, context) { + return matrix((0, _array.map)(evalItems, function (evalItem) { + return evalItem(scope, args, context); + })); + }; + } else { + return function evalArrayNode(scope, args, context) { + return (0, _array.map)(evalItems, function (evalItem) { + return evalItem(scope, args, context); + }); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (let i = 0; i < this.items.length; i++) { + const node = this.items[i]; + callback(node, 'items[' + i + ']', this); + } + } + + /** + * Create a new ArrayNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ArrayNode} Returns a transformed copy of the node + */ + map(callback) { + const items = []; + for (let i = 0; i < this.items.length; i++) { + items[i] = this._ifNode(callback(this.items[i], 'items[' + i + ']', this)); + } + return new ArrayNode(items); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ArrayNode} + */ + clone() { + return new ArrayNode(this.items.slice(0)); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + const items = this.items.map(function (node) { + return node.toString(options); + }); + return '[' + items.join(', ') + ']'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + items: this.items + }; + } + + /** + * Instantiate an ArrayNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ArrayNode", items: [...]}`, + * where mathjs is optional + * @returns {ArrayNode} + */ + static fromJSON(json) { + return new ArrayNode(json.items); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + const items = this.items.map(function (node) { + return node.toHTML(options); + }); + return '[' + items.join(',') + ']'; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + function itemsToTex(items, nested) { + const mixedItems = items.some(_is.isArrayNode) && !items.every(_is.isArrayNode); + const itemsFormRow = nested || mixedItems; + const itemSep = itemsFormRow ? '&' : '\\\\'; + const itemsTex = items.map(function (node) { + if (node.items) { + return itemsToTex(node.items, !nested); + } else { + return node.toTex(options); + } + }).join(itemSep); + return mixedItems || !itemsFormRow || itemsFormRow && !nested ? '\\begin{bmatrix}' + itemsTex + '\\end{bmatrix}' : itemsTex; + } + return itemsToTex(this.items, false); + } + } + (0, _defineProperty2.default)(ArrayNode, "name", name); + return ArrayNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AssignmentNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AssignmentNode.js new file mode 100644 index 0000000..ec1a7c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/AssignmentNode.js @@ -0,0 +1,313 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAssignmentNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _customs = require("../../utils/customs.js"); +var _factory = require("../../utils/factory.js"); +var _access = require("./utils/access.js"); +var _assign = require("./utils/assign.js"); +var _operators = require("../operators.js"); +const name = 'AssignmentNode'; +const dependencies = ['subset', '?matrix', +// FIXME: should not be needed at all, should be handled by subset +'Node']; +const createAssignmentNode = exports.createAssignmentNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + subset, + matrix, + Node + } = _ref; + const access = (0, _access.accessFactory)({ + subset + }); + const assign = (0, _assign.assignFactory)({ + subset, + matrix + }); + + /* + * Is parenthesis needed? + * @param {node} node + * @param {string} [parenthesis='keep'] + * @param {string} implicit + * @private + */ + function needParenthesis(node, parenthesis, implicit) { + if (!parenthesis) { + parenthesis = 'keep'; + } + const precedence = (0, _operators.getPrecedence)(node, parenthesis, implicit); + const exprPrecedence = (0, _operators.getPrecedence)(node.value, parenthesis, implicit); + return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence; + } + class AssignmentNode extends Node { + /** + * @constructor AssignmentNode + * @extends {Node} + * + * Define a symbol, like `a=3.2`, update a property like `a.b=3.2`, or + * replace a subset of a matrix like `A[2,2]=42`. + * + * Syntax: + * + * new AssignmentNode(symbol, value) + * new AssignmentNode(object, index, value) + * + * Usage: + * + * new AssignmentNode(new SymbolNode('a'), new ConstantNode(2)) // a=2 + * new AssignmentNode(new SymbolNode('a'), + * new IndexNode('b'), + * new ConstantNode(2)) // a.b=2 + * new AssignmentNode(new SymbolNode('a'), + * new IndexNode(1, 2), + * new ConstantNode(3)) // a[1,2]=3 + * + * @param {SymbolNode | AccessorNode} object + * Object on which to assign a value + * @param {IndexNode} [index=null] + * Index, property name or matrix index. Optional. If not provided + * and `object` is a SymbolNode, the property is assigned to the + * global scope. + * @param {Node} value + * The value to be assigned + */ + constructor(object, index, value) { + super(); + this.object = object; + this.index = value ? index : null; + this.value = value || index; + + // validate input + if (!(0, _is.isSymbolNode)(object) && !(0, _is.isAccessorNode)(object)) { + throw new TypeError('SymbolNode or AccessorNode expected as "object"'); + } + if ((0, _is.isSymbolNode)(object) && object.name === 'end') { + throw new Error('Cannot assign to symbol "end"'); + } + if (this.index && !(0, _is.isIndexNode)(this.index)) { + // index is optional + throw new TypeError('IndexNode expected as "index"'); + } + if (!(0, _is.isNode)(this.value)) { + throw new TypeError('Node expected as "value"'); + } + } + + // class name for typing purposes: + + // readonly property name + get name() { + if (this.index) { + return this.index.isObjectProperty() ? this.index.getObjectProperty() : ''; + } else { + return this.object.name || ''; + } + } + get type() { + return name; + } + get isAssignmentNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalObject = this.object._compile(math, argNames); + const evalIndex = this.index ? this.index._compile(math, argNames) : null; + const evalValue = this.value._compile(math, argNames); + const name = this.object.name; + if (!this.index) { + // apply a variable to the scope, for example `a=2` + if (!(0, _is.isSymbolNode)(this.object)) { + throw new TypeError('SymbolNode expected as object'); + } + return function evalAssignmentNode(scope, args, context) { + const value = evalValue(scope, args, context); + scope.set(name, value); + return value; + }; + } else if (this.index.isObjectProperty()) { + // apply an object property for example `a.b=2` + const prop = this.index.getObjectProperty(); + return function evalAssignmentNode(scope, args, context) { + const object = evalObject(scope, args, context); + const value = evalValue(scope, args, context); + (0, _customs.setSafeProperty)(object, prop, value); + return value; + }; + } else if ((0, _is.isSymbolNode)(this.object)) { + // update a matrix subset, for example `a[2]=3` + return function evalAssignmentNode(scope, args, context) { + const childObject = evalObject(scope, args, context); + const value = evalValue(scope, args, context); + // Important: we pass childObject instead of context: + const index = evalIndex(scope, args, childObject); + scope.set(name, assign(childObject, index, value)); + return value; + }; + } else { + // isAccessorNode(node.object) === true + // update a matrix subset, for example `a.b[2]=3` + + // we will not use the compile function of the AccessorNode, but + // compile it ourselves here as we need the parent object of the + // AccessorNode: + // wee need to apply the updated object to parent object + const evalParentObject = this.object.object._compile(math, argNames); + if (this.object.index.isObjectProperty()) { + const parentProp = this.object.index.getObjectProperty(); + return function evalAssignmentNode(scope, args, context) { + const parent = evalParentObject(scope, args, context); + const childObject = (0, _customs.getSafeProperty)(parent, parentProp); + // Important: we pass childObject instead of context: + const index = evalIndex(scope, args, childObject); + const value = evalValue(scope, args, context); + (0, _customs.setSafeProperty)(parent, parentProp, assign(childObject, index, value)); + return value; + }; + } else { + // if some parameters use the 'end' parameter, we need to calculate + // the size + const evalParentIndex = this.object.index._compile(math, argNames); + return function evalAssignmentNode(scope, args, context) { + const parent = evalParentObject(scope, args, context); + // Important: we pass parent instead of context: + const parentIndex = evalParentIndex(scope, args, parent); + const childObject = access(parent, parentIndex); + // Important: we pass childObject instead of context + const index = evalIndex(scope, args, childObject); + const value = evalValue(scope, args, context); + assign(parent, parentIndex, assign(childObject, index, value)); + return value; + }; + } + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.object, 'object', this); + if (this.index) { + callback(this.index, 'index', this); + } + callback(this.value, 'value', this); + } + + /** + * Create a new AssignmentNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {AssignmentNode} Returns a transformed copy of the node + */ + map(callback) { + const object = this._ifNode(callback(this.object, 'object', this)); + const index = this.index ? this._ifNode(callback(this.index, 'index', this)) : null; + const value = this._ifNode(callback(this.value, 'value', this)); + return new AssignmentNode(object, index, value); + } + + /** + * Create a clone of this node, a shallow copy + * @return {AssignmentNode} + */ + clone() { + return new AssignmentNode(this.object, this.index, this.value); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} + */ + _toString(options) { + const object = this.object.toString(options); + const index = this.index ? this.index.toString(options) : ''; + let value = this.value.toString(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = '(' + value + ')'; + } + return object + index + ' = ' + value; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + object: this.object, + index: this.index, + value: this.value + }; + } + + /** + * Instantiate an AssignmentNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "AssignmentNode", object: ..., index: ..., value: ...}`, + * where mathjs is optional + * @returns {AssignmentNode} + */ + static fromJSON(json) { + return new AssignmentNode(json.object, json.index, json.value); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} + */ + _toHTML(options) { + const object = this.object.toHTML(options); + const index = this.index ? this.index.toHTML(options) : ''; + let value = this.value.toHTML(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = '(' + value + ')'; + } + return object + index + '=' + value; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} + */ + _toTex(options) { + const object = this.object.toTex(options); + const index = this.index ? this.index.toTex(options) : ''; + let value = this.value.toTex(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = `\\left(${value}\\right)`; + } + return object + index + '=' + value; + } + } + (0, _defineProperty2.default)(AssignmentNode, "name", name); + return AssignmentNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/BlockNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/BlockNode.js new file mode 100644 index 0000000..38b32e4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/BlockNode.js @@ -0,0 +1,192 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBlockNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'BlockNode'; +const dependencies = ['ResultSet', 'Node']; +const createBlockNode = exports.createBlockNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + ResultSet, + Node + } = _ref; + class BlockNode extends Node { + /** + * @constructor BlockNode + * @extends {Node} + * Holds a set with blocks + * @param {Array.<{node: Node} | {node: Node, visible: boolean}>} blocks + * An array with blocks, where a block is constructed as an + * Object with properties block, which is a Node, and visible, + * which is a boolean. The property visible is optional and + * is true by default + */ + constructor(blocks) { + super(); + // validate input, copy blocks + if (!Array.isArray(blocks)) throw new Error('Array expected'); + this.blocks = blocks.map(function (block) { + const node = block && block.node; + const visible = block && block.visible !== undefined ? block.visible : true; + if (!(0, _is.isNode)(node)) throw new TypeError('Property "node" must be a Node'); + if (typeof visible !== 'boolean') { + throw new TypeError('Property "visible" must be a boolean'); + } + return { + node, + visible + }; + }); + } + get type() { + return name; + } + get isBlockNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalBlocks = (0, _array.map)(this.blocks, function (block) { + return { + evaluate: block.node._compile(math, argNames), + visible: block.visible + }; + }); + return function evalBlockNodes(scope, args, context) { + const results = []; + (0, _array.forEach)(evalBlocks, function evalBlockNode(block) { + const result = block.evaluate(scope, args, context); + if (block.visible) { + results.push(result); + } + }); + return new ResultSet(results); + }; + } + + /** + * Execute a callback for each of the child blocks of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (let i = 0; i < this.blocks.length; i++) { + callback(this.blocks[i].node, 'blocks[' + i + '].node', this); + } + } + + /** + * Create a new BlockNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {BlockNode} Returns a transformed copy of the node + */ + map(callback) { + const blocks = []; + for (let i = 0; i < this.blocks.length; i++) { + const block = this.blocks[i]; + const node = this._ifNode(callback(block.node, 'blocks[' + i + '].node', this)); + blocks[i] = { + node, + visible: block.visible + }; + } + return new BlockNode(blocks); + } + + /** + * Create a clone of this node, a shallow copy + * @return {BlockNode} + */ + clone() { + const blocks = this.blocks.map(function (block) { + return { + node: block.node, + visible: block.visible + }; + }); + return new BlockNode(blocks); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + return this.blocks.map(function (param) { + return param.node.toString(options) + (param.visible ? '' : ';'); + }).join('\n'); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + blocks: this.blocks + }; + } + + /** + * Instantiate an BlockNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "BlockNode", blocks: [{node: ..., visible: false}, ...]}`, + * where mathjs is optional + * @returns {BlockNode} + */ + static fromJSON(json) { + return new BlockNode(json.blocks); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + return this.blocks.map(function (param) { + return param.node.toHTML(options) + (param.visible ? '' : ';'); + }).join('
    '); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + return this.blocks.map(function (param) { + return param.node.toTex(options) + (param.visible ? '' : ';'); + }).join('\\;\\;\n'); + } + } + (0, _defineProperty2.default)(BlockNode, "name", name); + return BlockNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConditionalNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConditionalNode.js new file mode 100644 index 0000000..0839a04 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConditionalNode.js @@ -0,0 +1,232 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createConditionalNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _operators = require("../operators.js"); +const name = 'ConditionalNode'; +const dependencies = ['Node']; +const createConditionalNode = exports.createConditionalNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + /** + * Test whether a condition is met + * @param {*} condition + * @returns {boolean} true if condition is true or non-zero, else false + */ + function testCondition(condition) { + if (typeof condition === 'number' || typeof condition === 'boolean' || typeof condition === 'string') { + return !!condition; + } + if (condition) { + if ((0, _is.isBigNumber)(condition)) { + return !condition.isZero(); + } + if ((0, _is.isComplex)(condition)) { + return !!(condition.re || condition.im); + } + if ((0, _is.isUnit)(condition)) { + return !!condition.value; + } + } + if (condition === null || condition === undefined) { + return false; + } + throw new TypeError('Unsupported type of condition "' + (0, _is.typeOf)(condition) + '"'); + } + class ConditionalNode extends Node { + /** + * A lazy evaluating conditional operator: 'condition ? trueExpr : falseExpr' + * + * @param {Node} condition Condition, must result in a boolean + * @param {Node} trueExpr Expression evaluated when condition is true + * @param {Node} falseExpr Expression evaluated when condition is true + * + * @constructor ConditionalNode + * @extends {Node} + */ + constructor(condition, trueExpr, falseExpr) { + super(); + if (!(0, _is.isNode)(condition)) { + throw new TypeError('Parameter condition must be a Node'); + } + if (!(0, _is.isNode)(trueExpr)) { + throw new TypeError('Parameter trueExpr must be a Node'); + } + if (!(0, _is.isNode)(falseExpr)) { + throw new TypeError('Parameter falseExpr must be a Node'); + } + this.condition = condition; + this.trueExpr = trueExpr; + this.falseExpr = falseExpr; + } + get type() { + return name; + } + get isConditionalNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalCondition = this.condition._compile(math, argNames); + const evalTrueExpr = this.trueExpr._compile(math, argNames); + const evalFalseExpr = this.falseExpr._compile(math, argNames); + return function evalConditionalNode(scope, args, context) { + return testCondition(evalCondition(scope, args, context)) ? evalTrueExpr(scope, args, context) : evalFalseExpr(scope, args, context); + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.condition, 'condition', this); + callback(this.trueExpr, 'trueExpr', this); + callback(this.falseExpr, 'falseExpr', this); + } + + /** + * Create a new ConditionalNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ConditionalNode} Returns a transformed copy of the node + */ + map(callback) { + return new ConditionalNode(this._ifNode(callback(this.condition, 'condition', this)), this._ifNode(callback(this.trueExpr, 'trueExpr', this)), this._ifNode(callback(this.falseExpr, 'falseExpr', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ConditionalNode} + */ + clone() { + return new ConditionalNode(this.condition, this.trueExpr, this.falseExpr); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const precedence = (0, _operators.getPrecedence)(this, parenthesis, options && options.implicit); + + // Enclose Arguments in parentheses if they are an OperatorNode + // or have lower or equal precedence + // NOTE: enclosing all OperatorNodes in parentheses is a decision + // purely based on aesthetics and readability + let condition = this.condition.toString(options); + const conditionPrecedence = (0, _operators.getPrecedence)(this.condition, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) { + condition = '(' + condition + ')'; + } + let trueExpr = this.trueExpr.toString(options); + const truePrecedence = (0, _operators.getPrecedence)(this.trueExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) { + trueExpr = '(' + trueExpr + ')'; + } + let falseExpr = this.falseExpr.toString(options); + const falsePrecedence = (0, _operators.getPrecedence)(this.falseExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) { + falseExpr = '(' + falseExpr + ')'; + } + return condition + ' ? ' + trueExpr + ' : ' + falseExpr; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + condition: this.condition, + trueExpr: this.trueExpr, + falseExpr: this.falseExpr + }; + } + + /** + * Instantiate an ConditionalNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "ConditionalNode", + * "condition": ..., + * "trueExpr": ..., + * "falseExpr": ...} + * ``` + * where mathjs is optional + * @returns {ConditionalNode} + */ + static fromJSON(json) { + return new ConditionalNode(json.condition, json.trueExpr, json.falseExpr); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const precedence = (0, _operators.getPrecedence)(this, parenthesis, options && options.implicit); + + // Enclose Arguments in parentheses if they are an OperatorNode + // or have lower or equal precedence + // NOTE: enclosing all OperatorNodes in parentheses is a decision + // purely based on aesthetics and readability + let condition = this.condition.toHTML(options); + const conditionPrecedence = (0, _operators.getPrecedence)(this.condition, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) { + condition = '(' + condition + ')'; + } + let trueExpr = this.trueExpr.toHTML(options); + const truePrecedence = (0, _operators.getPrecedence)(this.trueExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) { + trueExpr = '(' + trueExpr + ')'; + } + let falseExpr = this.falseExpr.toHTML(options); + const falsePrecedence = (0, _operators.getPrecedence)(this.falseExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) { + falseExpr = '(' + falseExpr + ')'; + } + return condition + '?' + trueExpr + ':' + falseExpr; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + return '\\begin{cases} {' + this.trueExpr.toTex(options) + '}, &\\quad{\\text{if }\\;' + this.condition.toTex(options) + '}\\\\{' + this.falseExpr.toTex(options) + '}, &\\quad{\\text{otherwise}}\\end{cases}'; + } + } + (0, _defineProperty2.default)(ConditionalNode, "name", name); + return ConditionalNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConstantNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConstantNode.js new file mode 100644 index 0000000..7c1bba0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ConstantNode.js @@ -0,0 +1,186 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createConstantNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _string = require("../../utils/string.js"); +var _is = require("../../utils/is.js"); +var _latex = require("../../utils/latex.js"); +var _factory = require("../../utils/factory.js"); +const name = 'ConstantNode'; +const dependencies = ['Node']; +const createConstantNode = exports.createConstantNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + class ConstantNode extends Node { + /** + * A ConstantNode holds a constant value like a number or string. + * + * Usage: + * + * new ConstantNode(2.3) + * new ConstantNode('hello') + * + * @param {*} value Value can be any type (number, BigNumber, bigint, string, ...) + * @constructor ConstantNode + * @extends {Node} + */ + constructor(value) { + super(); + this.value = value; + } + get type() { + return name; + } + get isConstantNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const value = this.value; + return function evalConstantNode() { + return value; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // nothing to do, we don't have any children + } + + /** + * Create a new ConstantNode with children produced by the given callback. + * Trivial because there are no children. + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {ConstantNode} Returns a clone of the node + */ + map(callback) { + return this.clone(); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ConstantNode} + */ + clone() { + return new ConstantNode(this.value); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + return (0, _string.format)(this.value, options); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const value = this._toString(options); + switch ((0, _is.typeOf)(this.value)) { + case 'number': + case 'bigint': + case 'BigNumber': + case 'Fraction': + return '' + value + ''; + case 'string': + return '' + value + ''; + case 'boolean': + return '' + value + ''; + case 'null': + return '' + value + ''; + case 'undefined': + return '' + value + ''; + default: + return '' + value + ''; + } + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + value: this.value + }; + } + + /** + * Instantiate a ConstantNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "SymbolNode", value: 2.3}`, + * where mathjs is optional + * @returns {ConstantNode} + */ + static fromJSON(json) { + return new ConstantNode(json.value); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const value = this._toString(options); + const type = (0, _is.typeOf)(this.value); + switch (type) { + case 'string': + return '\\mathtt{' + (0, _latex.escapeLatex)(value) + '}'; + case 'number': + case 'BigNumber': + { + const finite = type === 'BigNumber' ? this.value.isFinite() : isFinite(this.value); + if (!finite) { + return this.value.valueOf() < 0 ? '-\\infty' : '\\infty'; + } + const index = value.toLowerCase().indexOf('e'); + if (index !== -1) { + return value.substring(0, index) + '\\cdot10^{' + value.substring(index + 1) + '}'; + } + return value; + } + case 'bigint': + { + return value.toString(); + } + case 'Fraction': + return this.value.toLatex(); + default: + return value; + } + } + } + (0, _defineProperty2.default)(ConstantNode, "name", name); + return ConstantNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionAssignmentNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionAssignmentNode.js new file mode 100644 index 0000000..63df6cf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionAssignmentNode.js @@ -0,0 +1,242 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFunctionAssignmentNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _keywords = require("../keywords.js"); +var _string = require("../../utils/string.js"); +var _array = require("../../utils/array.js"); +var _latex = require("../../utils/latex.js"); +var _operators = require("../operators.js"); +var _factory = require("../../utils/factory.js"); +const name = 'FunctionAssignmentNode'; +const dependencies = ['typed', 'Node']; +const createFunctionAssignmentNode = exports.createFunctionAssignmentNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Node + } = _ref; + /** + * Is parenthesis needed? + * @param {Node} node + * @param {Object} parenthesis + * @param {string} implicit + * @private + */ + function needParenthesis(node, parenthesis, implicit) { + const precedence = (0, _operators.getPrecedence)(node, parenthesis, implicit); + const exprPrecedence = (0, _operators.getPrecedence)(node.expr, parenthesis, implicit); + return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence; + } + class FunctionAssignmentNode extends Node { + /** + * @constructor FunctionAssignmentNode + * @extends {Node} + * Function assignment + * + * @param {string} name Function name + * @param {string[] | Array.<{name: string, type: string}>} params + * Array with function parameter names, or an + * array with objects containing the name + * and type of the parameter + * @param {Node} expr The function expression + */ + constructor(name, params, expr) { + super(); + // validate input + if (typeof name !== 'string') { + throw new TypeError('String expected for parameter "name"'); + } + if (!Array.isArray(params)) { + throw new TypeError('Array containing strings or objects expected for parameter "params"'); + } + if (!(0, _is.isNode)(expr)) { + throw new TypeError('Node expected for parameter "expr"'); + } + if (_keywords.keywords.has(name)) { + throw new Error('Illegal function name, "' + name + '" is a reserved keyword'); + } + const paramNames = new Set(); + for (const param of params) { + const name = typeof param === 'string' ? param : param.name; + if (paramNames.has(name)) { + throw new Error(`Duplicate parameter name "${name}"`); + } else { + paramNames.add(name); + } + } + this.name = name; + this.params = params.map(function (param) { + return param && param.name || param; + }); + this.types = params.map(function (param) { + return param && param.type || 'any'; + }); + this.expr = expr; + } + get type() { + return name; + } + get isFunctionAssignmentNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const childArgNames = Object.create(argNames); + (0, _array.forEach)(this.params, function (param) { + childArgNames[param] = true; + }); + + // compile the function expression with the child args + const evalExpr = this.expr._compile(math, childArgNames); + const name = this.name; + const params = this.params; + const signature = (0, _array.join)(this.types, ','); + const syntax = name + '(' + (0, _array.join)(this.params, ', ') + ')'; + return function evalFunctionAssignmentNode(scope, args, context) { + const signatures = {}; + signatures[signature] = function () { + const childArgs = Object.create(args); + for (let i = 0; i < params.length; i++) { + childArgs[params[i]] = arguments[i]; + } + return evalExpr(scope, childArgs, context); + }; + const fn = typed(name, signatures); + fn.syntax = syntax; + scope.set(name, fn); + return fn; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.expr, 'expr', this); + } + + /** + * Create a new FunctionAssignmentNode whose children are the results of + * calling the provided callback function for each child of the original + * node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {FunctionAssignmentNode} Returns a transformed copy of the node + */ + map(callback) { + const expr = this._ifNode(callback(this.expr, 'expr', this)); + return new FunctionAssignmentNode(this.name, this.params.slice(0), expr); + } + + /** + * Create a clone of this node, a shallow copy + * @return {FunctionAssignmentNode} + */ + clone() { + return new FunctionAssignmentNode(this.name, this.params.slice(0), this.expr); + } + + /** + * get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + let expr = this.expr.toString(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = '(' + expr + ')'; + } + return this.name + '(' + this.params.join(', ') + ') = ' + expr; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + const types = this.types; + return { + mathjs: name, + name: this.name, + params: this.params.map(function (param, index) { + return { + name: param, + type: types[index] + }; + }), + expr: this.expr + }; + } + + /** + * Instantiate an FunctionAssignmentNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "FunctionAssignmentNode", + * name: ..., params: ..., expr: ...} + * ``` + * where mathjs is optional + * @returns {FunctionAssignmentNode} + */ + static fromJSON(json) { + return new FunctionAssignmentNode(json.name, json.params, json.expr); + } + + /** + * get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const params = []; + for (let i = 0; i < this.params.length; i++) { + params.push('' + (0, _string.escape)(this.params[i]) + ''); + } + let expr = this.expr.toHTML(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = '(' + expr + ')'; + } + return '' + (0, _string.escape)(this.name) + '' + '(' + params.join(',') + ')' + '=' + expr; + } + + /** + * get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + let expr = this.expr.toTex(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = `\\left(${expr}\\right)`; + } + return '\\mathrm{' + this.name + '}\\left(' + this.params.map(_latex.toSymbol).join(',') + '\\right)=' + expr; + } + } + (0, _defineProperty2.default)(FunctionAssignmentNode, "name", name); + return FunctionAssignmentNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionNode.js new file mode 100644 index 0000000..0d700b0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/FunctionNode.js @@ -0,0 +1,486 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFunctionNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +var _customs = require("../../utils/customs.js"); +var _scope = require("../../utils/scope.js"); +var _factory = require("../../utils/factory.js"); +var _latex = require("../../utils/latex.js"); +const name = 'FunctionNode'; +const dependencies = ['math', 'Node', 'SymbolNode']; +const createFunctionNode = exports.createFunctionNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + var _FunctionNode; + let { + math, + Node, + SymbolNode + } = _ref; + /* format to fixed length */ + const strin = entity => (0, _string.format)(entity, { + truncate: 78 + }); + + /* + * Expand a LaTeX template + * + * @param {string} template + * @param {Node} node + * @param {Object} options + * @private + **/ + function expandTemplate(template, node, options) { + let latex = ''; + + // Match everything of the form ${identifier} or ${identifier[2]} or $$ + // while submatching identifier and 2 (in the second case) + const regex = /\$(?:\{([a-z_][a-z_0-9]*)(?:\[([0-9]+)\])?\}|\$)/gi; + let inputPos = 0; // position in the input string + let match; + while ((match = regex.exec(template)) !== null) { + // go through all matches + // add everything in front of the match to the LaTeX string + latex += template.substring(inputPos, match.index); + inputPos = match.index; + if (match[0] === '$$') { + // escaped dollar sign + latex += '$'; + inputPos++; + } else { + // template parameter + inputPos += match[0].length; + const property = node[match[1]]; + if (!property) { + throw new ReferenceError('Template: Property ' + match[1] + ' does not exist.'); + } + if (match[2] === undefined) { + // no square brackets + switch (typeof property) { + case 'string': + latex += property; + break; + case 'object': + if ((0, _is.isNode)(property)) { + latex += property.toTex(options); + } else if (Array.isArray(property)) { + // make array of Nodes into comma separated list + latex += property.map(function (arg, index) { + if ((0, _is.isNode)(arg)) { + return arg.toTex(options); + } + throw new TypeError('Template: ' + match[1] + '[' + index + '] is not a Node.'); + }).join(','); + } else { + throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes'); + } + break; + default: + throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes'); + } + } else { + // with square brackets + if ((0, _is.isNode)(property[match[2]] && property[match[2]])) { + latex += property[match[2]].toTex(options); + } else { + throw new TypeError('Template: ' + match[1] + '[' + match[2] + '] is not a Node.'); + } + } + } + } + latex += template.slice(inputPos); // append rest of the template + + return latex; + } + class FunctionNode extends Node { + /** + * @constructor FunctionNode + * @extends {./Node} + * invoke a list with arguments on a node + * @param {./Node | string} fn + * Item resolving to a function on which to invoke + * the arguments, typically a SymbolNode or AccessorNode + * @param {./Node[]} args + */ + constructor(fn, args) { + super(); + if (typeof fn === 'string') { + fn = new SymbolNode(fn); + } + + // validate input + if (!(0, _is.isNode)(fn)) throw new TypeError('Node expected as parameter "fn"'); + if (!Array.isArray(args) || !args.every(_is.isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "args"'); + } + this.fn = fn; + this.args = args || []; + } + + // readonly property name + get name() { + return this.fn.name || ''; + } + get type() { + return name; + } + get isFunctionNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // compile arguments + const evalArgs = this.args.map(arg => arg._compile(math, argNames)); + if ((0, _is.isSymbolNode)(this.fn)) { + const name = this.fn.name; + if (!argNames[name]) { + // we can statically determine whether the function + // has the rawArgs property + const fn = name in math ? (0, _customs.getSafeProperty)(math, name) : undefined; + const isRaw = typeof fn === 'function' && fn.rawArgs === true; + const resolveFn = scope => { + let value; + if (scope.has(name)) { + value = scope.get(name); + } else if (name in math) { + value = (0, _customs.getSafeProperty)(math, name); + } else { + return FunctionNode.onUndefinedFunction(name); + } + if (typeof value === 'function') { + return value; + } + throw new TypeError(`'${name}' is not a function; its value is:\n ${strin(value)}`); + }; + if (isRaw) { + // pass unevaluated parameters (nodes) to the function + // "raw" evaluation + const rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + const fn = resolveFn(scope); + + // the original function can be overwritten in the scope with a non-rawArgs function + if (fn.rawArgs === true) { + return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args)); + } else { + // "regular" evaluation + const values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn(...values); + } + }; + } else { + // "regular" evaluation + switch (evalArgs.length) { + case 0: + return function evalFunctionNode(scope, args, context) { + const fn = resolveFn(scope); + return fn(); + }; + case 1: + return function evalFunctionNode(scope, args, context) { + const fn = resolveFn(scope); + const evalArg0 = evalArgs[0]; + return fn(evalArg0(scope, args, context)); + }; + case 2: + return function evalFunctionNode(scope, args, context) { + const fn = resolveFn(scope); + const evalArg0 = evalArgs[0]; + const evalArg1 = evalArgs[1]; + return fn(evalArg0(scope, args, context), evalArg1(scope, args, context)); + }; + default: + return function evalFunctionNode(scope, args, context) { + const fn = resolveFn(scope); + const values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn(...values); + }; + } + } + } else { + // the function symbol is an argName + const rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + const fn = (0, _customs.getSafeProperty)(args, name); + if (typeof fn !== 'function') { + throw new TypeError(`Argument '${name}' was not a function; received: ${strin(fn)}`); + } + if (fn.rawArgs) { + // "Raw" evaluation + return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args)); + } else { + const values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(fn, values); + } + }; + } + } else if ((0, _is.isAccessorNode)(this.fn) && (0, _is.isIndexNode)(this.fn.index) && this.fn.index.isObjectProperty()) { + // execute the function with the right context: + // the object of the AccessorNode + + const evalObject = this.fn.object._compile(math, argNames); + const prop = this.fn.index.getObjectProperty(); + const rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + const object = evalObject(scope, args, context); + const fn = (0, _customs.getSafeMethod)(object, prop); + if (fn !== null && fn !== void 0 && fn.rawArgs) { + // "Raw" evaluation + return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args)); + } else { + // "regular" evaluation + const values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(object, values); + } + }; + } else { + // node.fn.isAccessorNode && !node.fn.index.isObjectProperty() + // we have to dynamically determine whether the function has the + // rawArgs property + const fnExpr = this.fn.toString(); + const evalFn = this.fn._compile(math, argNames); + const rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + const fn = evalFn(scope, args, context); + if (typeof fn !== 'function') { + throw new TypeError(`Expression '${fnExpr}' did not evaluate to a function; value is:` + `\n ${strin(fn)}`); + } + if (fn.rawArgs) { + // "Raw" evaluation + return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args)); + } else { + // "regular" evaluation + const values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(fn, values); + } + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.fn, 'fn', this); + for (let i = 0; i < this.args.length; i++) { + callback(this.args[i], 'args[' + i + ']', this); + } + } + + /** + * Create a new FunctionNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {FunctionNode} Returns a transformed copy of the node + */ + map(callback) { + const fn = this._ifNode(callback(this.fn, 'fn', this)); + const args = []; + for (let i = 0; i < this.args.length; i++) { + args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this)); + } + return new FunctionNode(fn, args); + } + + /** + * Create a clone of this node, a shallow copy + * @return {FunctionNode} + */ + clone() { + return new FunctionNode(this.fn, this.args.slice(0)); + } + + /** + * Throws an error 'Undefined function {name}' + * @param {string} name + */ + + /** + * Get string representation. (wrapper function) + * This overrides parts of Node's toString function. + * If callback is an object containing callbacks, it + * calls the correct callback for the current node, + * otherwise it falls back to calling Node's toString + * function. + * + * @param {Object} options + * @return {string} str + * @override + */ + toString(options) { + let customString; + const name = this.fn.toString(options); + if (options && typeof options.handler === 'object' && (0, _object.hasOwnProperty)(options.handler, name)) { + // callback is a map of callback functions + customString = options.handler[name](this, options); + } + if (typeof customString !== 'undefined') { + return customString; + } + + // fall back to Node's toString + return super.toString(options); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const args = this.args.map(function (arg) { + return arg.toString(options); + }); + const fn = (0, _is.isFunctionAssignmentNode)(this.fn) ? '(' + this.fn.toString(options) + ')' : this.fn.toString(options); + + // format the arguments like "add(2, 4.2)" + return fn + '(' + args.join(', ') + ')'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + fn: this.fn, + args: this.args + }; + } + + /** + * Instantiate an AssignmentNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "FunctionNode", fn: ..., args: ...}`, + * where mathjs is optional + * @returns {FunctionNode} + */ + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const args = this.args.map(function (arg) { + return arg.toHTML(options); + }); + + // format the arguments like "add(2, 4.2)" + return '' + (0, _string.escape)(this.fn) + '(' + args.join(',') + ')'; + } + + /** + * Get LaTeX representation. (wrapper function) + * This overrides parts of Node's toTex function. + * If callback is an object containing callbacks, it + * calls the correct callback for the current node, + * otherwise it falls back to calling Node's toTex + * function. + * + * @param {Object} options + * @return {string} + */ + toTex(options) { + let customTex; + if (options && typeof options.handler === 'object' && (0, _object.hasOwnProperty)(options.handler, this.name)) { + // callback is a map of callback functions + customTex = options.handler[this.name](this, options); + } + if (typeof customTex !== 'undefined') { + return customTex; + } + + // fall back to Node's toTex + return super.toTex(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const args = this.args.map(function (arg) { + // get LaTeX of the arguments + return arg.toTex(options); + }); + let latexConverter; + if (_latex.latexFunctions[this.name]) { + latexConverter = _latex.latexFunctions[this.name]; + } + + // toTex property on the function itself + if (math[this.name] && (typeof math[this.name].toTex === 'function' || typeof math[this.name].toTex === 'object' || typeof math[this.name].toTex === 'string')) { + // .toTex is a callback function + latexConverter = math[this.name].toTex; + } + let customToTex; + switch (typeof latexConverter) { + case 'function': + // a callback function + customToTex = latexConverter(this, options); + break; + case 'string': + // a template string + customToTex = expandTemplate(latexConverter, this, options); + break; + case 'object': + // an object with different "converters" for different + // numbers of arguments + switch (typeof latexConverter[args.length]) { + case 'function': + customToTex = latexConverter[args.length](this, options); + break; + case 'string': + customToTex = expandTemplate(latexConverter[args.length], this, options); + break; + } + } + if (typeof customToTex !== 'undefined') { + return customToTex; + } + return expandTemplate(_latex.defaultTemplate, this, options); + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type + ':' + this.name; + } + } + _FunctionNode = FunctionNode; + (0, _defineProperty2.default)(FunctionNode, "name", name); + (0, _defineProperty2.default)(FunctionNode, "onUndefinedFunction", function (name) { + throw new Error('Undefined function ' + name); + }); + (0, _defineProperty2.default)(FunctionNode, "fromJSON", function (json) { + return new _FunctionNode(json.fn, json.args); + }); + return FunctionNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/IndexNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/IndexNode.js new file mode 100644 index 0000000..aa3a7db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/IndexNode.js @@ -0,0 +1,226 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIndexNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _array = require("../../utils/array.js"); +var _customs = require("../../utils/customs.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _string = require("../../utils/string.js"); +const name = 'IndexNode'; +const dependencies = ['Node', 'size']; +const createIndexNode = exports.createIndexNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node, + size + } = _ref; + class IndexNode extends Node { + /** + * @constructor IndexNode + * @extends Node + * + * Describes a subset of a matrix or an object property. + * Cannot be used on its own, needs to be used within an AccessorNode or + * AssignmentNode. + * + * @param {Node[]} dimensions + * @param {boolean} [dotNotation=false] + * Optional property describing whether this index was written using dot + * notation like `a.b`, or using bracket notation like `a["b"]` + * (which is the default). This property is used for string conversion. + */ + constructor(dimensions, dotNotation) { + super(); + this.dimensions = dimensions; + this.dotNotation = dotNotation || false; + + // validate input + if (!Array.isArray(dimensions) || !dimensions.every(_is.isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "dimensions"'); + } + if (this.dotNotation && !this.isObjectProperty()) { + throw new Error('dotNotation only applicable for object properties'); + } + } + get type() { + return name; + } + get isIndexNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // TODO: implement support for bignumber (currently bignumbers are silently + // reduced to numbers when changing the value to zero-based) + + // TODO: Optimization: when the range values are ConstantNodes, + // we can beforehand resolve the zero-based value + + // optimization for a simple object property + const evalDimensions = (0, _array.map)(this.dimensions, function (dimension, i) { + const needsEnd = dimension.filter(node => node.isSymbolNode && node.name === 'end').length > 0; + if (needsEnd) { + // SymbolNode 'end' is used inside the index, + // like in `A[end]` or `A[end - 2]` + const childArgNames = Object.create(argNames); + childArgNames.end = true; + const _evalDimension = dimension._compile(math, childArgNames); + return function evalDimension(scope, args, context) { + if (!(0, _is.isMatrix)(context) && !(0, _is.isArray)(context) && !(0, _is.isString)(context)) { + throw new TypeError('Cannot resolve "end": ' + 'context must be a Matrix, Array, or string but is ' + (0, _is.typeOf)(context)); + } + const s = size(context).valueOf(); + const childArgs = Object.create(args); + childArgs.end = s[i]; + return _evalDimension(scope, childArgs, context); + }; + } else { + // SymbolNode `end` not used + return dimension._compile(math, argNames); + } + }); + const index = (0, _customs.getSafeProperty)(math, 'index'); + return function evalIndexNode(scope, args, context) { + const dimensions = (0, _array.map)(evalDimensions, function (evalDimension) { + return evalDimension(scope, args, context); + }); + return index(...dimensions); + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (let i = 0; i < this.dimensions.length; i++) { + callback(this.dimensions[i], 'dimensions[' + i + ']', this); + } + } + + /** + * Create a new IndexNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {IndexNode} Returns a transformed copy of the node + */ + map(callback) { + const dimensions = []; + for (let i = 0; i < this.dimensions.length; i++) { + dimensions[i] = this._ifNode(callback(this.dimensions[i], 'dimensions[' + i + ']', this)); + } + return new IndexNode(dimensions, this.dotNotation); + } + + /** + * Create a clone of this node, a shallow copy + * @return {IndexNode} + */ + clone() { + return new IndexNode(this.dimensions.slice(0), this.dotNotation); + } + + /** + * Test whether this IndexNode contains a single property name + * @return {boolean} + */ + isObjectProperty() { + return this.dimensions.length === 1 && (0, _is.isConstantNode)(this.dimensions[0]) && typeof this.dimensions[0].value === 'string'; + } + + /** + * Returns the property name if IndexNode contains a property. + * If not, returns null. + * @return {string | null} + */ + getObjectProperty() { + return this.isObjectProperty() ? this.dimensions[0].value : null; + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + // format the parameters like "[1, 0:5]" + return this.dotNotation ? '.' + this.getObjectProperty() : '[' + this.dimensions.join(', ') + ']'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + dimensions: this.dimensions, + dotNotation: this.dotNotation + }; + } + + /** + * Instantiate an IndexNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "IndexNode", dimensions: [...], dotNotation: false}`, + * where mathjs is optional + * @returns {IndexNode} + */ + static fromJSON(json) { + return new IndexNode(json.dimensions, json.dotNotation); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + // format the parameters like "[1, 0:5]" + const dimensions = []; + for (let i = 0; i < this.dimensions.length; i++) { + dimensions[i] = this.dimensions[i].toHTML(); + } + if (this.dotNotation) { + return '.' + '' + (0, _string.escape)(this.getObjectProperty()) + ''; + } else { + return '[' + dimensions.join(',') + ']'; + } + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const dimensions = this.dimensions.map(function (range) { + return range.toTex(options); + }); + return this.dotNotation ? '.' + this.getObjectProperty() + '' : '_{' + dimensions.join(',') + '}'; + } + } + (0, _defineProperty2.default)(IndexNode, "name", name); + return IndexNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/Node.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/Node.js new file mode 100644 index 0000000..9274295 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/Node.js @@ -0,0 +1,378 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNode = void 0; +var _is = require("../../utils/is.js"); +var _keywords = require("../keywords.js"); +var _object = require("../../utils/object.js"); +var _factory = require("../../utils/factory.js"); +var _map = require("../../utils/map.js"); +const name = 'Node'; +const dependencies = ['mathWithTransform']; +const createNode = exports.createNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + mathWithTransform + } = _ref; + /** + * Validate the symbol names of a scope. + * Throws an error when the scope contains an illegal symbol. + * @param {Object} scope + */ + function _validateScope(scope) { + for (const symbol of [..._keywords.keywords]) { + if (scope.has(symbol)) { + throw new Error('Scope contains an illegal symbol, "' + symbol + '" is a reserved keyword'); + } + } + } + class Node { + get type() { + return 'Node'; + } + get isNode() { + return true; + } + + /** + * Evaluate the node + * @param {Object} [scope] Scope to read/write variables + * @return {*} Returns the result + */ + evaluate(scope) { + return this.compile().evaluate(scope); + } + + /** + * Compile the node into an optimized, evauatable JavaScript function + * @return {{evaluate: function([Object])}} object + * Returns an object with a function 'evaluate', + * which can be invoked as expr.evaluate([scope: Object]), + * where scope is an optional object with + * variables. + */ + compile() { + const expr = this._compile(mathWithTransform, {}); + const args = {}; + const context = null; + function evaluate(scope) { + const s = (0, _map.createMap)(scope); + _validateScope(s); + return expr(s, args, context); + } + return { + evaluate + }; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + throw new Error('Method _compile must be implemented by type ' + this.type); + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // must be implemented by each of the Node implementations + throw new Error('Cannot run forEach on a Node interface'); + } + + /** + * Create a new Node whose children are the results of calling the + * provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {OperatorNode} Returns a transformed copy of the node + */ + map(callback) { + // must be implemented by each of the Node implementations + throw new Error('Cannot run map on a Node interface'); + } + + /** + * Validate whether an object is a Node, for use with map + * @param {Node} node + * @returns {Node} Returns the input if it's a node, else throws an Error + * @protected + */ + _ifNode(node) { + if (!(0, _is.isNode)(node)) { + throw new TypeError('Callback function must return a Node'); + } + return node; + } + + /** + * Recursively traverse all nodes in a node tree. Executes given callback for + * this node and each of its child nodes. + * @param {function(node: Node, path: string, parent: Node)} callback + * A callback called for every node in the node tree. + */ + traverse(callback) { + // execute callback for itself + // eslint-disable-next-line + callback(this, null, null); + + // recursively traverse over all children of a node + function _traverse(node, callback) { + node.forEach(function (child, path, parent) { + callback(child, path, parent); + _traverse(child, callback); + }); + } + _traverse(this, callback); + } + + /** + * Recursively transform a node tree via a transform function. + * + * For example, to replace all nodes of type SymbolNode having name 'x' with + * a ConstantNode with value 2: + * + * const res = Node.transform(function (node, path, parent) { + * if (node && node.isSymbolNode) && (node.name === 'x')) { + * return new ConstantNode(2) + * } + * else { + * return node + * } + * }) + * + * @param {function(node: Node, path: string, parent: Node) : Node} callback + * A mapping function accepting a node, and returning + * a replacement for the node or the original node. The "signature" + * of the callback must be: + * callback(node: Node, index: string, parent: Node) : Node + * @return {Node} Returns the original node or its replacement + */ + transform(callback) { + function _transform(child, path, parent) { + const replacement = callback(child, path, parent); + if (replacement !== child) { + // stop iterating when the node is replaced + return replacement; + } + return child.map(_transform); + } + return _transform(this, null, null); + } + + /** + * Find any node in the node tree matching given filter function. For + * example, to find all nodes of type SymbolNode having name 'x': + * + * const results = Node.filter(function (node) { + * return (node && node.isSymbolNode) && (node.name === 'x') + * }) + * + * @param {function(node: Node, path: string, parent: Node) : Node} callback + * A test function returning true when a node matches, and false + * otherwise. Function signature: + * callback(node: Node, index: string, parent: Node) : boolean + * @return {Node[]} nodes + * An array with nodes matching given filter criteria + */ + filter(callback) { + const nodes = []; + this.traverse(function (node, path, parent) { + if (callback(node, path, parent)) { + nodes.push(node); + } + }); + return nodes; + } + + /** + * Create a shallow clone of this node + * @return {Node} + */ + clone() { + // must be implemented by each of the Node implementations + throw new Error('Cannot clone a Node interface'); + } + + /** + * Create a deep clone of this node + * @return {Node} + */ + cloneDeep() { + return this.map(function (node) { + return node.cloneDeep(); + }); + } + + /** + * Deep compare this node with another node. + * @param {Node} other + * @return {boolean} Returns true when both nodes are of the same type and + * contain the same values (as do their childs) + */ + equals(other) { + return other ? this.type === other.type && (0, _object.deepStrictEqual)(this, other) : false; + } + + /** + * Get string representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)"or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toString(options) { + const customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toString(options); + } + + /** + * Internal function to generate the string output. + * This has to be implemented by every Node + * + * @throws {Error} + */ + _toString() { + // must be implemented by each of the Node implementations + throw new Error('_toString not implemented for ' + this.type); + } + + /** + * Get a JSON representation of the node + * Both .toJSON() and the static .fromJSON(json) should be implemented by all + * implementations of Node + * @returns {Object} + */ + toJSON() { + throw new Error('Cannot serialize object: toJSON not implemented by ' + this.type); + } + + /** + * Get HTML representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)" or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toHTML(options) { + const customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toHTML(options); + } + + /** + * Internal function to generate the HTML output. + * This has to be implemented by every Node + * + * @throws {Error} + */ + _toHTML() { + // must be implemented by each of the Node implementations + throw new Error('_toHTML not implemented for ' + this.type); + } + + /** + * Get LaTeX representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)"or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toTex(options) { + const customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toTex(options); + } + + /** + * Internal function to generate the LaTeX output. + * This has to be implemented by every Node + * + * @param {Object} [options] + * @throws {Error} + */ + _toTex(options) { + // must be implemented by each of the Node implementations + throw new Error('_toTex not implemented for ' + this.type); + } + + /** + * Helper used by `to...` functions. + */ + _getCustomString(options) { + if (options && typeof options === 'object') { + switch (typeof options.handler) { + case 'object': + case 'undefined': + return; + case 'function': + return options.handler(this, options); + default: + throw new TypeError('Object or function expected as callback'); + } + } + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type; + } + + /** + * Get the content of the current Node. + * @return {Node} node + **/ + getContent() { + return this; + } + } + return Node; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ObjectNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ObjectNode.js new file mode 100644 index 0000000..0efc8aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ObjectNode.js @@ -0,0 +1,200 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createObjectNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _customs = require("../../utils/customs.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _string = require("../../utils/string.js"); +const name = 'ObjectNode'; +const dependencies = ['Node']; +const createObjectNode = exports.createObjectNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + class ObjectNode extends Node { + /** + * @constructor ObjectNode + * @extends {Node} + * Holds an object with keys/values + * @param {Object.} [properties] object with key/value pairs + */ + constructor(properties) { + super(); + this.properties = properties || {}; + + // validate input + if (properties) { + if (!(typeof properties === 'object') || !Object.keys(properties).every(function (key) { + return (0, _is.isNode)(properties[key]); + })) { + throw new TypeError('Object containing Nodes expected'); + } + } + } + get type() { + return name; + } + get isObjectNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const evalEntries = {}; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + // we stringify/parse the key here to resolve unicode characters, + // so you cannot create a key like {"co\\u006Estructor": null} + const stringifiedKey = (0, _string.stringify)(key); + const parsedKey = JSON.parse(stringifiedKey); + const prop = (0, _customs.getSafeProperty)(this.properties, key); + evalEntries[parsedKey] = prop._compile(math, argNames); + } + } + return function evalObjectNode(scope, args, context) { + const obj = {}; + for (const key in evalEntries) { + if ((0, _object.hasOwnProperty)(evalEntries, key)) { + obj[key] = evalEntries[key](scope, args, context); + } + } + return obj; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + callback(this.properties[key], 'properties[' + (0, _string.stringify)(key) + ']', this); + } + } + } + + /** + * Create a new ObjectNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ObjectNode} Returns a transformed copy of the node + */ + map(callback) { + const properties = {}; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + properties[key] = this._ifNode(callback(this.properties[key], 'properties[' + (0, _string.stringify)(key) + ']', this)); + } + } + return new ObjectNode(properties); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ObjectNode} + */ + clone() { + const properties = {}; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + properties[key] = this.properties[key]; + } + } + return new ObjectNode(properties); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + const entries = []; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + entries.push((0, _string.stringify)(key) + ': ' + this.properties[key].toString(options)); + } + } + return '{' + entries.join(', ') + '}'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + properties: this.properties + }; + } + + /** + * Instantiate an OperatorNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ObjectNode", "properties": {...}}`, + * where mathjs is optional + * @returns {ObjectNode} + */ + static fromJSON(json) { + return new ObjectNode(json.properties); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + const entries = []; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + entries.push('' + (0, _string.escape)(key) + '' + '' + ':' + this.properties[key].toHTML(options)); + } + } + return '{' + entries.join(',') + '}'; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const entries = []; + for (const key in this.properties) { + if ((0, _object.hasOwnProperty)(this.properties, key)) { + entries.push('\\mathbf{' + key + ':} & ' + this.properties[key].toTex(options) + '\\\\'); + } + } + const tex = '\\left\\{\\begin{array}{ll}' + entries.join('\n') + '\\end{array}\\right\\}'; + return tex; + } + } + (0, _defineProperty2.default)(ObjectNode, "name", name); + return ObjectNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/OperatorNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/OperatorNode.js new file mode 100644 index 0000000..c1d8bdd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/OperatorNode.js @@ -0,0 +1,636 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createOperatorNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _scope = require("../../utils/scope.js"); +var _string = require("../../utils/string.js"); +var _customs = require("../../utils/customs.js"); +var _operators = require("../operators.js"); +var _latex = require("../../utils/latex.js"); +var _factory = require("../../utils/factory.js"); +const name = 'OperatorNode'; +const dependencies = ['Node']; +const createOperatorNode = exports.createOperatorNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + /** + * Returns true if the expression starts with a constant, under + * the current parenthesization: + * @param {Node} expression + * @param {string} parenthesis + * @return {boolean} + */ + function startsWithConstant(expr, parenthesis) { + let curNode = expr; + if (parenthesis === 'auto') { + while ((0, _is.isParenthesisNode)(curNode)) curNode = curNode.content; + } + if ((0, _is.isConstantNode)(curNode)) return true; + if ((0, _is.isOperatorNode)(curNode)) { + return startsWithConstant(curNode.args[0], parenthesis); + } + return false; + } + + /** + * Calculate which parentheses are necessary. Gets an OperatorNode + * (which is the root of the tree) and an Array of Nodes + * (this.args) and returns an array where 'true' means that an argument + * has to be enclosed in parentheses whereas 'false' means the opposite. + * + * @param {OperatorNode} root + * @param {string} parenthesis + * @param {Node[]} args + * @param {boolean} latex + * @return {boolean[]} + * @private + */ + function calculateNecessaryParentheses(root, parenthesis, implicit, args, latex) { + // precedence of the root OperatorNode + const precedence = (0, _operators.getPrecedence)(root, parenthesis, implicit); + const associativity = (0, _operators.getAssociativity)(root, parenthesis); + if (parenthesis === 'all' || args.length > 2 && root.getIdentifier() !== 'OperatorNode:add' && root.getIdentifier() !== 'OperatorNode:multiply') { + return args.map(function (arg) { + switch (arg.getContent().type) { + // Nodes that don't need extra parentheses + case 'ArrayNode': + case 'ConstantNode': + case 'SymbolNode': + case 'ParenthesisNode': + return false; + default: + return true; + } + }); + } + let result; + switch (args.length) { + case 0: + result = []; + break; + case 1: + // unary operators + { + // precedence of the operand + const operandPrecedence = (0, _operators.getPrecedence)(args[0], parenthesis, implicit, root); + + // handle special cases for LaTeX, where some of the parentheses aren't needed + if (latex && operandPrecedence !== null) { + let operandIdentifier; + let rootIdentifier; + if (parenthesis === 'keep') { + operandIdentifier = args[0].getIdentifier(); + rootIdentifier = root.getIdentifier(); + } else { + // Ignore Parenthesis Nodes when not in 'keep' mode + operandIdentifier = args[0].getContent().getIdentifier(); + rootIdentifier = root.getContent().getIdentifier(); + } + if (_operators.properties[precedence][rootIdentifier].latexLeftParens === false) { + result = [false]; + break; + } + if (_operators.properties[operandPrecedence][operandIdentifier].latexParens === false) { + result = [false]; + break; + } + } + if (operandPrecedence === null) { + // if the operand has no defined precedence, no parens are needed + result = [false]; + break; + } + if (operandPrecedence <= precedence) { + // if the operands precedence is lower, parens are needed + result = [true]; + break; + } + + // otherwise, no parens needed + result = [false]; + } + break; + case 2: + // binary operators + { + let lhsParens; // left hand side needs parenthesis? + // precedence of the left hand side + const lhsPrecedence = (0, _operators.getPrecedence)(args[0], parenthesis, implicit, root); + // is the root node associative with the left hand side + const assocWithLhs = (0, _operators.isAssociativeWith)(root, args[0], parenthesis); + if (lhsPrecedence === null) { + // if the left hand side has no defined precedence, no parens are needed + // FunctionNode for example + lhsParens = false; + } else if (lhsPrecedence === precedence && associativity === 'right' && !assocWithLhs) { + // In case of equal precedence, if the root node is left associative + // parens are **never** necessary for the left hand side. + // If it is right associative however, parens are necessary + // if the root node isn't associative with the left hand side + lhsParens = true; + } else if (lhsPrecedence < precedence) { + lhsParens = true; + } else { + lhsParens = false; + } + let rhsParens; // right hand side needs parenthesis? + // precedence of the right hand side + const rhsPrecedence = (0, _operators.getPrecedence)(args[1], parenthesis, implicit, root); + // is the root node associative with the right hand side? + const assocWithRhs = (0, _operators.isAssociativeWith)(root, args[1], parenthesis); + if (rhsPrecedence === null) { + // if the right hand side has no defined precedence, no parens are needed + // FunctionNode for example + rhsParens = false; + } else if (rhsPrecedence === precedence && associativity === 'left' && !assocWithRhs) { + // In case of equal precedence, if the root node is right associative + // parens are **never** necessary for the right hand side. + // If it is left associative however, parens are necessary + // if the root node isn't associative with the right hand side + rhsParens = true; + } else if (rhsPrecedence < precedence) { + rhsParens = true; + } else { + rhsParens = false; + } + + // handle special cases for LaTeX, where some of the parentheses aren't needed + if (latex) { + let rootIdentifier; + let lhsIdentifier; + let rhsIdentifier; + if (parenthesis === 'keep') { + rootIdentifier = root.getIdentifier(); + lhsIdentifier = root.args[0].getIdentifier(); + rhsIdentifier = root.args[1].getIdentifier(); + } else { + // Ignore ParenthesisNodes when not in 'keep' mode + rootIdentifier = root.getContent().getIdentifier(); + lhsIdentifier = root.args[0].getContent().getIdentifier(); + rhsIdentifier = root.args[1].getContent().getIdentifier(); + } + if (lhsPrecedence !== null) { + if (_operators.properties[precedence][rootIdentifier].latexLeftParens === false) { + lhsParens = false; + } + if (_operators.properties[lhsPrecedence][lhsIdentifier].latexParens === false) { + lhsParens = false; + } + } + if (rhsPrecedence !== null) { + if (_operators.properties[precedence][rootIdentifier].latexRightParens === false) { + rhsParens = false; + } + if (_operators.properties[rhsPrecedence][rhsIdentifier].latexParens === false) { + rhsParens = false; + } + } + } + result = [lhsParens, rhsParens]; + } + break; + default: + if (root.getIdentifier() === 'OperatorNode:add' || root.getIdentifier() === 'OperatorNode:multiply') { + result = args.map(function (arg) { + const argPrecedence = (0, _operators.getPrecedence)(arg, parenthesis, implicit, root); + const assocWithArg = (0, _operators.isAssociativeWith)(root, arg, parenthesis); + const argAssociativity = (0, _operators.getAssociativity)(arg, parenthesis); + if (argPrecedence === null) { + // if the argument has no defined precedence, no parens are needed + return false; + } else if (precedence === argPrecedence && associativity === argAssociativity && !assocWithArg) { + return true; + } else if (argPrecedence < precedence) { + return true; + } + return false; + }); + } + break; + } + + // Handles an edge case of parentheses with implicit multiplication + // of ConstantNode. + // In that case, parenthesize ConstantNodes that follow an unparenthesized + // expression, even though they normally wouldn't be printed. + if (args.length >= 2 && root.getIdentifier() === 'OperatorNode:multiply' && root.implicit && parenthesis !== 'all' && implicit === 'hide') { + for (let i = 1; i < result.length; ++i) { + if (startsWithConstant(args[i], parenthesis) && !result[i - 1] && (parenthesis !== 'keep' || !(0, _is.isParenthesisNode)(args[i - 1]))) { + result[i] = true; + } + } + } + return result; + } + class OperatorNode extends Node { + /** + * @constructor OperatorNode + * @extends {Node} + * An operator with two arguments, like 2+3 + * + * @param {string} op Operator name, for example '+' + * @param {string} fn Function name, for example 'add' + * @param {Node[]} args Operator arguments + * @param {boolean} [implicit] Is this an implicit multiplication? + * @param {boolean} [isPercentage] Is this an percentage Operation? + */ + constructor(op, fn, args, implicit, isPercentage) { + super(); + // validate input + if (typeof op !== 'string') { + throw new TypeError('string expected for parameter "op"'); + } + if (typeof fn !== 'string') { + throw new TypeError('string expected for parameter "fn"'); + } + if (!Array.isArray(args) || !args.every(_is.isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "args"'); + } + this.implicit = implicit === true; + this.isPercentage = isPercentage === true; + this.op = op; + this.fn = fn; + this.args = args || []; + } + get type() { + return name; + } + get isOperatorNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // validate fn + if (typeof this.fn !== 'string' || !(0, _customs.isSafeMethod)(math, this.fn)) { + if (!math[this.fn]) { + throw new Error('Function ' + this.fn + ' missing in provided namespace "math"'); + } else { + throw new Error('No access to function "' + this.fn + '"'); + } + } + const fn = (0, _customs.getSafeProperty)(math, this.fn); + const evalArgs = (0, _array.map)(this.args, function (arg) { + return arg._compile(math, argNames); + }); + if (typeof fn === 'function' && fn.rawArgs === true) { + // pass unevaluated parameters (nodes) to the function + // "raw" evaluation + const rawArgs = this.args; + return function evalOperatorNode(scope, args, context) { + return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args)); + }; + } else if (evalArgs.length === 1) { + const evalArg0 = evalArgs[0]; + return function evalOperatorNode(scope, args, context) { + return fn(evalArg0(scope, args, context)); + }; + } else if (evalArgs.length === 2) { + const evalArg0 = evalArgs[0]; + const evalArg1 = evalArgs[1]; + return function evalOperatorNode(scope, args, context) { + return fn(evalArg0(scope, args, context), evalArg1(scope, args, context)); + }; + } else { + return function evalOperatorNode(scope, args, context) { + return fn.apply(null, (0, _array.map)(evalArgs, function (evalArg) { + return evalArg(scope, args, context); + })); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (let i = 0; i < this.args.length; i++) { + callback(this.args[i], 'args[' + i + ']', this); + } + } + + /** + * Create a new OperatorNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {OperatorNode} Returns a transformed copy of the node + */ + map(callback) { + const args = []; + for (let i = 0; i < this.args.length; i++) { + args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this)); + } + return new OperatorNode(this.op, this.fn, args, this.implicit, this.isPercentage); + } + + /** + * Create a clone of this node, a shallow copy + * @return {OperatorNode} + */ + clone() { + return new OperatorNode(this.op, this.fn, this.args.slice(0), this.implicit, this.isPercentage); + } + + /** + * Check whether this is an unary OperatorNode: + * has exactly one argument, like `-a`. + * @return {boolean} + * Returns true when an unary operator node, false otherwise. + */ + isUnary() { + return this.args.length === 1; + } + + /** + * Check whether this is a binary OperatorNode: + * has exactly two arguments, like `a + b`. + * @return {boolean} + * Returns true when a binary operator node, false otherwise. + */ + isBinary() { + return this.args.length === 2; + } + + /** + * Get string representation. + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const implicit = options && options.implicit ? options.implicit : 'hide'; + const args = this.args; + const parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false); + if (args.length === 1) { + // unary operators + const assoc = (0, _operators.getAssociativity)(this, parenthesis); + let operand = args[0].toString(options); + if (parens[0]) { + operand = '(' + operand + ')'; + } + + // for example for "not", we want a space between operand and argument + const opIsNamed = /[a-zA-Z]+/.test(this.op); + if (assoc === 'right') { + // prefix operator + return this.op + (opIsNamed ? ' ' : '') + operand; + } else if (assoc === 'left') { + // postfix + return operand + (opIsNamed ? ' ' : '') + this.op; + } + + // fall back to postfix + return operand + this.op; + } else if (args.length === 2) { + let lhs = args[0].toString(options); // left hand side + let rhs = args[1].toString(options); // right hand side + if (parens[0]) { + // left hand side in parenthesis? + lhs = '(' + lhs + ')'; + } + if (parens[1]) { + // right hand side in parenthesis? + rhs = '(' + rhs + ')'; + } + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return lhs + ' ' + rhs; + } + return lhs + ' ' + this.op + ' ' + rhs; + } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + const stringifiedArgs = args.map(function (arg, index) { + arg = arg.toString(options); + if (parens[index]) { + // put in parenthesis? + arg = '(' + arg + ')'; + } + return arg; + }); + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return stringifiedArgs.join(' '); + } + return stringifiedArgs.join(' ' + this.op + ' '); + } else { + // fallback to formatting as a function call + return this.fn + '(' + this.args.join(', ') + ')'; + } + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + op: this.op, + fn: this.fn, + args: this.args, + implicit: this.implicit, + isPercentage: this.isPercentage + }; + } + + /** + * Instantiate an OperatorNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "OperatorNode", + * "op": "+", "fn": "add", "args": [...], + * "implicit": false, + * "isPercentage":false} + * ``` + * where mathjs is optional + * @returns {OperatorNode} + */ + static fromJSON(json) { + return new OperatorNode(json.op, json.fn, json.args, json.implicit, json.isPercentage); + } + + /** + * Get HTML representation. + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const implicit = options && options.implicit ? options.implicit : 'hide'; + const args = this.args; + const parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false); + if (args.length === 1) { + // unary operators + const assoc = (0, _operators.getAssociativity)(this, parenthesis); + let operand = args[0].toHTML(options); + if (parens[0]) { + operand = '(' + operand + ')'; + } + if (assoc === 'right') { + // prefix operator + return '' + (0, _string.escape)(this.op) + '' + operand; + } else { + // postfix when assoc === 'left' or undefined + return operand + '' + (0, _string.escape)(this.op) + ''; + } + } else if (args.length === 2) { + // binary operatoes + let lhs = args[0].toHTML(options); // left hand side + let rhs = args[1].toHTML(options); // right hand side + if (parens[0]) { + // left hand side in parenthesis? + lhs = '(' + lhs + ')'; + } + if (parens[1]) { + // right hand side in parenthesis? + rhs = '(' + rhs + ')'; + } + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return lhs + '' + rhs; + } + return lhs + '' + (0, _string.escape)(this.op) + '' + rhs; + } else { + const stringifiedArgs = args.map(function (arg, index) { + arg = arg.toHTML(options); + if (parens[index]) { + // put in parenthesis? + arg = '(' + arg + ')'; + } + return arg; + }); + if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return stringifiedArgs.join(''); + } + return stringifiedArgs.join('' + (0, _string.escape)(this.op) + ''); + } else { + // fallback to formatting as a function call + return '' + (0, _string.escape)(this.fn) + '' + '(' + stringifiedArgs.join(',') + ')'; + } + } + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const implicit = options && options.implicit ? options.implicit : 'hide'; + const args = this.args; + const parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, true); + let op = _latex.latexOperators[this.fn]; + op = typeof op === 'undefined' ? this.op : op; // fall back to using this.op + + if (args.length === 1) { + // unary operators + const assoc = (0, _operators.getAssociativity)(this, parenthesis); + let operand = args[0].toTex(options); + if (parens[0]) { + operand = `\\left(${operand}\\right)`; + } + if (assoc === 'right') { + // prefix operator + return op + operand; + } else if (assoc === 'left') { + // postfix operator + return operand + op; + } + + // fall back to postfix + return operand + op; + } else if (args.length === 2) { + // binary operators + const lhs = args[0]; // left hand side + let lhsTex = lhs.toTex(options); + if (parens[0]) { + lhsTex = `\\left(${lhsTex}\\right)`; + } + const rhs = args[1]; // right hand side + let rhsTex = rhs.toTex(options); + if (parens[1]) { + rhsTex = `\\left(${rhsTex}\\right)`; + } + + // handle some exceptions (due to the way LaTeX works) + let lhsIdentifier; + if (parenthesis === 'keep') { + lhsIdentifier = lhs.getIdentifier(); + } else { + // Ignore ParenthesisNodes if in 'keep' mode + lhsIdentifier = lhs.getContent().getIdentifier(); + } + switch (this.getIdentifier()) { + case 'OperatorNode:divide': + // op contains '\\frac' at this point + return op + '{' + lhsTex + '}' + '{' + rhsTex + '}'; + case 'OperatorNode:pow': + lhsTex = '{' + lhsTex + '}'; + rhsTex = '{' + rhsTex + '}'; + switch (lhsIdentifier) { + case 'ConditionalNode': // + case 'OperatorNode:divide': + lhsTex = `\\left(${lhsTex}\\right)`; + } + break; + case 'OperatorNode:multiply': + if (this.implicit && implicit === 'hide') { + return lhsTex + '~' + rhsTex; + } + } + return lhsTex + op + rhsTex; + } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + const texifiedArgs = args.map(function (arg, index) { + arg = arg.toTex(options); + if (parens[index]) { + arg = `\\left(${arg}\\right)`; + } + return arg; + }); + if (this.getIdentifier() === 'OperatorNode:multiply' && this.implicit && implicit === 'hide') { + return texifiedArgs.join('~'); + } + return texifiedArgs.join(op); + } else { + // fall back to formatting as a function call + // as this is a fallback, it doesn't use + // fancy function names + return '\\mathrm{' + this.fn + '}\\left(' + args.map(function (arg) { + return arg.toTex(options); + }).join(',') + '\\right)'; + } + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type + ':' + this.fn; + } + } + (0, _defineProperty2.default)(OperatorNode, "name", name); + return OperatorNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ParenthesisNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ParenthesisNode.js new file mode 100644 index 0000000..f618575 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/ParenthesisNode.js @@ -0,0 +1,159 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createParenthesisNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'ParenthesisNode'; +const dependencies = ['Node']; +const createParenthesisNode = exports.createParenthesisNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + class ParenthesisNode extends Node { + /** + * @constructor ParenthesisNode + * @extends {Node} + * A parenthesis node describes manual parenthesis from the user input + * @param {Node} content + * @extends {Node} + */ + constructor(content) { + super(); + // validate input + if (!(0, _is.isNode)(content)) { + throw new TypeError('Node expected for parameter "content"'); + } + this.content = content; + } + get type() { + return name; + } + get isParenthesisNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + return this.content._compile(math, argNames); + } + + /** + * Get the content of the current Node. + * @return {Node} content + * @override + **/ + getContent() { + return this.content.getContent(); + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.content, 'content', this); + } + + /** + * Create a new ParenthesisNode whose child is the result of calling + * the provided callback function on the child of this node. + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {ParenthesisNode} Returns a clone of the node + */ + map(callback) { + const content = callback(this.content, 'content', this); + return new ParenthesisNode(content); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ParenthesisNode} + */ + clone() { + return new ParenthesisNode(this.content); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return '(' + this.content.toString(options) + ')'; + } + return this.content.toString(options); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + content: this.content + }; + } + + /** + * Instantiate an ParenthesisNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ParenthesisNode", "content": ...}`, + * where mathjs is optional + * @returns {ParenthesisNode} + */ + static fromJSON(json) { + return new ParenthesisNode(json.content); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return '(' + this.content.toHTML(options) + ')'; + } + return this.content.toHTML(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + * @override + */ + _toTex(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return `\\left(${this.content.toTex(options)}\\right)`; + } + return this.content.toTex(options); + } + } + (0, _defineProperty2.default)(ParenthesisNode, "name", name); + return ParenthesisNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RangeNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RangeNode.js new file mode 100644 index 0000000..8d4c09b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RangeNode.js @@ -0,0 +1,257 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRangeNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _operators = require("../operators.js"); +const name = 'RangeNode'; +const dependencies = ['Node']; +const createRangeNode = exports.createRangeNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + /** + * Calculate the necessary parentheses + * @param {Node} node + * @param {string} parenthesis + * @param {string} implicit + * @return {Object} parentheses + * @private + */ + function calculateNecessaryParentheses(node, parenthesis, implicit) { + const precedence = (0, _operators.getPrecedence)(node, parenthesis, implicit); + const parens = {}; + const startPrecedence = (0, _operators.getPrecedence)(node.start, parenthesis, implicit); + parens.start = startPrecedence !== null && startPrecedence <= precedence || parenthesis === 'all'; + if (node.step) { + const stepPrecedence = (0, _operators.getPrecedence)(node.step, parenthesis, implicit); + parens.step = stepPrecedence !== null && stepPrecedence <= precedence || parenthesis === 'all'; + } + const endPrecedence = (0, _operators.getPrecedence)(node.end, parenthesis, implicit); + parens.end = endPrecedence !== null && endPrecedence <= precedence || parenthesis === 'all'; + return parens; + } + class RangeNode extends Node { + /** + * @constructor RangeNode + * @extends {Node} + * create a range + * @param {Node} start included lower-bound + * @param {Node} end included upper-bound + * @param {Node} [step] optional step + */ + constructor(start, end, step) { + super(); + // validate inputs + if (!(0, _is.isNode)(start)) throw new TypeError('Node expected'); + if (!(0, _is.isNode)(end)) throw new TypeError('Node expected'); + if (step && !(0, _is.isNode)(step)) throw new TypeError('Node expected'); + if (arguments.length > 3) throw new Error('Too many arguments'); + this.start = start; // included lower-bound + this.end = end; // included upper-bound + this.step = step || null; // optional step + } + get type() { + return name; + } + get isRangeNode() { + return true; + } + + /** + * Check whether the RangeNode needs the `end` symbol to be defined. + * This end is the size of the Matrix in current dimension. + * @return {boolean} + */ + needsEnd() { + // find all `end` symbols in this RangeNode + const endSymbols = this.filter(function (node) { + return (0, _is.isSymbolNode)(node) && node.name === 'end'; + }); + return endSymbols.length > 0; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const range = math.range; + const evalStart = this.start._compile(math, argNames); + const evalEnd = this.end._compile(math, argNames); + if (this.step) { + const evalStep = this.step._compile(math, argNames); + return function evalRangeNode(scope, args, context) { + return range(evalStart(scope, args, context), evalEnd(scope, args, context), evalStep(scope, args, context)); + }; + } else { + return function evalRangeNode(scope, args, context) { + return range(evalStart(scope, args, context), evalEnd(scope, args, context)); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.start, 'start', this); + callback(this.end, 'end', this); + if (this.step) { + callback(this.step, 'step', this); + } + } + + /** + * Create a new RangeNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {RangeNode} Returns a transformed copy of the node + */ + map(callback) { + return new RangeNode(this._ifNode(callback(this.start, 'start', this)), this._ifNode(callback(this.end, 'end', this)), this.step && this._ifNode(callback(this.step, 'step', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {RangeNode} + */ + clone() { + return new RangeNode(this.start, this.end, this.step && this.step); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + + // format string as start:step:stop + let str; + let start = this.start.toString(options); + if (parens.start) { + start = '(' + start + ')'; + } + str = start; + if (this.step) { + let step = this.step.toString(options); + if (parens.step) { + step = '(' + step + ')'; + } + str += ':' + step; + } + let end = this.end.toString(options); + if (parens.end) { + end = '(' + end + ')'; + } + str += ':' + end; + return str; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + start: this.start, + end: this.end, + step: this.step + }; + } + + /** + * Instantiate an RangeNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "RangeNode", "start": ..., "end": ..., "step": ...}`, + * where mathjs is optional + * @returns {RangeNode} + */ + static fromJSON(json) { + return new RangeNode(json.start, json.end, json.step); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + + // format string as start:step:stop + let str; + let start = this.start.toHTML(options); + if (parens.start) { + start = '(' + start + ')'; + } + str = start; + if (this.step) { + let step = this.step.toHTML(options); + if (parens.step) { + step = '(' + step + ')'; + } + str += ':' + step; + } + let end = this.end.toHTML(options); + if (parens.end) { + end = '(' + end + ')'; + } + str += ':' + end; + return str; + } + + /** + * Get LaTeX representation + * @params {Object} options + * @return {string} str + */ + _toTex(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + let str = this.start.toTex(options); + if (parens.start) { + str = `\\left(${str}\\right)`; + } + if (this.step) { + let step = this.step.toTex(options); + if (parens.step) { + step = `\\left(${step}\\right)`; + } + str += ':' + step; + } + let end = this.end.toTex(options); + if (parens.end) { + end = `\\left(${end}\\right)`; + } + str += ':' + end; + return str; + } + } + (0, _defineProperty2.default)(RangeNode, "name", name); + return RangeNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RelationalNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RelationalNode.js new file mode 100644 index 0000000..b458007 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/RelationalNode.js @@ -0,0 +1,205 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRelationalNode = void 0; +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); +var _operators = require("../operators.js"); +var _string = require("../../utils/string.js"); +var _customs = require("../../utils/customs.js"); +var _latex = require("../../utils/latex.js"); +var _factory = require("../../utils/factory.js"); +const name = 'RelationalNode'; +const dependencies = ['Node']; +const createRelationalNode = exports.createRelationalNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Node + } = _ref; + const operatorMap = { + equal: '==', + unequal: '!=', + smaller: '<', + larger: '>', + smallerEq: '<=', + largerEq: '>=' + }; + class RelationalNode extends Node { + /** + * A node representing a chained conditional expression, such as 'x > y > z' + * + * @param {String[]} conditionals + * An array of conditional operators used to compare the parameters + * @param {Node[]} params + * The parameters that will be compared + * + * @constructor RelationalNode + * @extends {Node} + */ + constructor(conditionals, params) { + super(); + if (!Array.isArray(conditionals)) { + throw new TypeError('Parameter conditionals must be an array'); + } + if (!Array.isArray(params)) { + throw new TypeError('Parameter params must be an array'); + } + if (conditionals.length !== params.length - 1) { + throw new TypeError('Parameter params must contain exactly one more element ' + 'than parameter conditionals'); + } + this.conditionals = conditionals; + this.params = params; + } + get type() { + return name; + } + get isRelationalNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const self = this; + const compiled = this.params.map(p => p._compile(math, argNames)); + return function evalRelationalNode(scope, args, context) { + let evalLhs; + let evalRhs = compiled[0](scope, args, context); + for (let i = 0; i < self.conditionals.length; i++) { + evalLhs = evalRhs; + evalRhs = compiled[i + 1](scope, args, context); + const condFn = (0, _customs.getSafeProperty)(math, self.conditionals[i]); + if (!condFn(evalLhs, evalRhs)) { + return false; + } + } + return true; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + this.params.forEach((n, i) => callback(n, 'params[' + i + ']', this), this); + } + + /** + * Create a new RelationalNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {RelationalNode} Returns a transformed copy of the node + */ + map(callback) { + return new RelationalNode(this.conditionals.slice(), this.params.map((n, i) => this._ifNode(callback(n, 'params[' + i + ']', this)), this)); + } + + /** + * Create a clone of this node, a shallow copy + * @return {RelationalNode} + */ + clone() { + return new RelationalNode(this.conditionals, this.params); + } + + /** + * Get string representation. + * @param {Object} options + * @return {string} str + */ + _toString(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const precedence = (0, _operators.getPrecedence)(this, parenthesis, options && options.implicit); + const paramStrings = this.params.map(function (p, index) { + const paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toString(options) + ')' : p.toString(options); + }); + let ret = paramStrings[0]; + for (let i = 0; i < this.conditionals.length; i++) { + ret += ' ' + operatorMap[this.conditionals[i]]; + ret += ' ' + paramStrings[i + 1]; + } + return ret; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + conditionals: this.conditionals, + params: this.params + }; + } + + /** + * Instantiate a RelationalNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "RelationalNode", "conditionals": ..., "params": ...}`, + * where mathjs is optional + * @returns {RelationalNode} + */ + static fromJSON(json) { + return new RelationalNode(json.conditionals, json.params); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const precedence = (0, _operators.getPrecedence)(this, parenthesis, options && options.implicit); + const paramStrings = this.params.map(function (p, index) { + const paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toHTML(options) + ')' : p.toHTML(options); + }); + let ret = paramStrings[0]; + for (let i = 0; i < this.conditionals.length; i++) { + ret += '' + (0, _string.escape)(operatorMap[this.conditionals[i]]) + '' + paramStrings[i + 1]; + } + return ret; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + const parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + const precedence = (0, _operators.getPrecedence)(this, parenthesis, options && options.implicit); + const paramStrings = this.params.map(function (p, index) { + const paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '\\left(' + p.toTex(options) + '\right)' : p.toTex(options); + }); + let ret = paramStrings[0]; + for (let i = 0; i < this.conditionals.length; i++) { + ret += _latex.latexOperators[this.conditionals[i]] + paramStrings[i + 1]; + } + return ret; + } + } + (0, _defineProperty2.default)(RelationalNode, "name", name); + return RelationalNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/SymbolNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/SymbolNode.js new file mode 100644 index 0000000..90aa5d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/SymbolNode.js @@ -0,0 +1,199 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSymbolNode = void 0; +var _string = require("../../utils/string.js"); +var _customs = require("../../utils/customs.js"); +var _factory = require("../../utils/factory.js"); +var _latex = require("../../utils/latex.js"); +const name = 'SymbolNode'; +const dependencies = ['math', '?Unit', 'Node']; +const createSymbolNode = exports.createSymbolNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + math, + Unit, + Node + } = _ref; + /** + * Check whether some name is a valueless unit like "inch". + * @param {string} name + * @return {boolean} + */ + function isValuelessUnit(name) { + return Unit ? Unit.isValuelessUnit(name) : false; + } + class SymbolNode extends Node { + /** + * @constructor SymbolNode + * @extends {Node} + * A symbol node can hold and resolve a symbol + * @param {string} name + * @extends {Node} + */ + constructor(name) { + super(); + // validate input + if (typeof name !== 'string') { + throw new TypeError('String expected for parameter "name"'); + } + this.name = name; + } + get type() { + return 'SymbolNode'; + } + get isSymbolNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + const name = this.name; + if (argNames[name] === true) { + // this is a FunctionAssignment argument + // (like an x when inside the expression of a function + // assignment `f(x) = ...`) + return function (scope, args, context) { + return (0, _customs.getSafeProperty)(args, name); + }; + } else if (name in math) { + return function (scope, args, context) { + return scope.has(name) ? scope.get(name) : (0, _customs.getSafeProperty)(math, name); + }; + } else { + const isUnit = isValuelessUnit(name); + return function (scope, args, context) { + return scope.has(name) ? scope.get(name) : isUnit ? new Unit(null, name) : SymbolNode.onUndefinedSymbol(name); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // nothing to do, we don't have any children + } + + /** + * Create a new SymbolNode with children produced by the given callback. + * Trivial since a SymbolNode has no children + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {SymbolNode} Returns a clone of the node + */ + map(callback) { + return this.clone(); + } + + /** + * Throws an error 'Undefined symbol {name}' + * @param {string} name + */ + static onUndefinedSymbol(name) { + throw new Error('Undefined symbol ' + name); + } + + /** + * Create a clone of this node, a shallow copy + * @return {SymbolNode} + */ + clone() { + return new SymbolNode(this.name); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + return this.name; + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + const name = (0, _string.escape)(this.name); + if (name === 'true' || name === 'false') { + return '' + name + ''; + } else if (name === 'i') { + return '' + name + ''; + } else if (name === 'Infinity') { + return '' + name + ''; + } else if (name === 'NaN') { + return '' + name + ''; + } else if (name === 'null') { + return '' + name + ''; + } else if (name === 'undefined') { + return '' + name + ''; + } + return '' + name + ''; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: 'SymbolNode', + name: this.name + }; + } + + /** + * Instantiate a SymbolNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "SymbolNode", name: "x"}`, + * where mathjs is optional + * @returns {SymbolNode} + */ + static fromJSON(json) { + return new SymbolNode(json.name); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + * @override + */ + _toTex(options) { + let isUnit = false; + if (typeof math[this.name] === 'undefined' && isValuelessUnit(this.name)) { + isUnit = true; + } + const symbol = (0, _latex.toSymbol)(this.name, isUnit); + if (symbol[0] === '\\') { + // no space needed if the symbol starts with '\' + return symbol; + } + // the space prevents symbols from breaking stuff like '\cdot' + // if it's written right before the symbol + return ' ' + symbol; + } + } + return SymbolNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/access.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/access.js new file mode 100644 index 0000000..1e7b9a0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/access.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.accessFactory = accessFactory; +var _errorTransform = require("../../transform/utils/errorTransform.js"); +var _customs = require("../../../utils/customs.js"); +function accessFactory(_ref) { + let { + subset + } = _ref; + /** + * Retrieve part of an object: + * + * - Retrieve a property from an object + * - Retrieve a part of a string + * - Retrieve a matrix subset + * + * @param {Object | Array | Matrix | string} object + * @param {Index} index + * @return {Object | Array | Matrix | string} Returns the subset + */ + return function access(object, index) { + try { + if (Array.isArray(object)) { + return subset(object, index); + } else if (object && typeof object.subset === 'function') { + // Matrix + return object.subset(index); + } else if (typeof object === 'string') { + // TODO: move getStringSubset into a separate util file, use that + return subset(object, index); + } else if (typeof object === 'object') { + if (!index.isObjectProperty()) { + throw new TypeError('Cannot apply a numeric index as object property'); + } + return (0, _customs.getSafeProperty)(object, index.getObjectProperty()); + } else { + throw new TypeError('Cannot apply index: unsupported type of object'); + } + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/assign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/assign.js new file mode 100644 index 0000000..1e86dab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/node/utils/assign.js @@ -0,0 +1,57 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.assignFactory = assignFactory; +var _errorTransform = require("../../transform/utils/errorTransform.js"); +var _customs = require("../../../utils/customs.js"); +function assignFactory(_ref) { + let { + subset, + matrix + } = _ref; + /** + * Replace part of an object: + * + * - Assign a property to an object + * - Replace a part of a string + * - Replace a matrix subset + * + * @param {Object | Array | Matrix | string} object + * @param {Index} index + * @param {*} value + * @return {Object | Array | Matrix | string} Returns the original object + * except in case of a string + */ + // TODO: change assign to return the value instead of the object + return function assign(object, index, value) { + try { + if (Array.isArray(object)) { + const result = matrix(object).subset(index, value).valueOf(); + + // shallow copy all (updated) items into the original array + result.forEach((item, index) => { + object[index] = item; + }); + return object; + } else if (object && typeof object.subset === 'function') { + // Matrix + return object.subset(index, value); + } else if (typeof object === 'string') { + // TODO: move setStringSubset into a separate util file, use that + return subset(object, index, value); + } else if (typeof object === 'object') { + if (!index.isObjectProperty()) { + throw TypeError('Cannot apply a numeric index as object property'); + } + (0, _customs.setSafeProperty)(object, index.getObjectProperty(), value); + return object; + } else { + throw new TypeError('Cannot apply index: unsupported type of object'); + } + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/operators.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/operators.js new file mode 100644 index 0000000..cf75da4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/operators.js @@ -0,0 +1,388 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getAssociativity = getAssociativity; +exports.getOperator = getOperator; +exports.getPrecedence = getPrecedence; +exports.isAssociativeWith = isAssociativeWith; +exports.properties = void 0; +var _object = require("../utils/object.js"); +var _is = require("../utils/is.js"); +// list of identifiers of nodes in order of their precedence +// also contains information about left/right associativity +// and which other operator the operator is associative with +// Example: +// addition is associative with addition and subtraction, because: +// (a+b)+c=a+(b+c) +// (a+b)-c=a+(b-c) +// +// postfix operators are left associative, prefix operators +// are right associative +// +// It's also possible to set the following properties: +// latexParens: if set to false, this node doesn't need to be enclosed +// in parentheses when using LaTeX +// latexLeftParens: if set to false, this !OperatorNode's! +// left argument doesn't need to be enclosed +// in parentheses +// latexRightParens: the same for the right argument + +const properties = exports.properties = [{ + // assignment + AssignmentNode: {}, + FunctionAssignmentNode: {} +}, { + // conditional expression + ConditionalNode: { + latexLeftParens: false, + latexRightParens: false, + latexParens: false + // conditionals don't need parentheses in LaTeX because + // they are 2 dimensional + } +}, { + // logical or + 'OperatorNode:or': { + op: 'or', + associativity: 'left', + associativeWith: [] + } +}, { + // logical xor + 'OperatorNode:xor': { + op: 'xor', + associativity: 'left', + associativeWith: [] + } +}, { + // logical and + 'OperatorNode:and': { + op: 'and', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise or + 'OperatorNode:bitOr': { + op: '|', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise xor + 'OperatorNode:bitXor': { + op: '^|', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise and + 'OperatorNode:bitAnd': { + op: '&', + associativity: 'left', + associativeWith: [] + } +}, { + // relational operators + 'OperatorNode:equal': { + op: '==', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:unequal': { + op: '!=', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:smaller': { + op: '<', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:larger': { + op: '>', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:smallerEq': { + op: '<=', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:largerEq': { + op: '>=', + associativity: 'left', + associativeWith: [] + }, + RelationalNode: { + associativity: 'left', + associativeWith: [] + } +}, { + // bitshift operators + 'OperatorNode:leftShift': { + op: '<<', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:rightArithShift': { + op: '>>', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:rightLogShift': { + op: '>>>', + associativity: 'left', + associativeWith: [] + } +}, { + // unit conversion + 'OperatorNode:to': { + op: 'to', + associativity: 'left', + associativeWith: [] + } +}, { + // range + RangeNode: {} +}, { + // addition, subtraction + 'OperatorNode:add': { + op: '+', + associativity: 'left', + associativeWith: ['OperatorNode:add', 'OperatorNode:subtract'] + }, + 'OperatorNode:subtract': { + op: '-', + associativity: 'left', + associativeWith: [] + } +}, { + // multiply, divide, modulus + 'OperatorNode:multiply': { + op: '*', + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'Operator:dotMultiply', 'Operator:dotDivide'] + }, + 'OperatorNode:divide': { + op: '/', + associativity: 'left', + associativeWith: [], + latexLeftParens: false, + latexRightParens: false, + latexParens: false + // fractions don't require parentheses because + // they're 2 dimensional, so parens aren't needed + // in LaTeX + }, + 'OperatorNode:dotMultiply': { + op: '.*', + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'OperatorNode:dotMultiply', 'OperatorNode:doDivide'] + }, + 'OperatorNode:dotDivide': { + op: './', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:mod': { + op: 'mod', + associativity: 'left', + associativeWith: [] + } +}, { + // Repeat multiplication for implicit multiplication + 'OperatorNode:multiply': { + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'Operator:dotMultiply', 'Operator:dotDivide'] + } +}, { + // unary prefix operators + 'OperatorNode:unaryPlus': { + op: '+', + associativity: 'right' + }, + 'OperatorNode:unaryMinus': { + op: '-', + associativity: 'right' + }, + 'OperatorNode:bitNot': { + op: '~', + associativity: 'right' + }, + 'OperatorNode:not': { + op: 'not', + associativity: 'right' + } +}, { + // exponentiation + 'OperatorNode:pow': { + op: '^', + associativity: 'right', + associativeWith: [], + latexRightParens: false + // the exponent doesn't need parentheses in + // LaTeX because it's 2 dimensional + // (it's on top) + }, + 'OperatorNode:dotPow': { + op: '.^', + associativity: 'right', + associativeWith: [] + } +}, { + // factorial + 'OperatorNode:factorial': { + op: '!', + associativity: 'left' + } +}, { + // matrix transpose + 'OperatorNode:ctranspose': { + op: "'", + associativity: 'left' + } +}]; + +/** + * Returns the first non-parenthesis internal node, but only + * when the 'parenthesis' option is unset or auto. + * @param {Node} _node + * @param {string} parenthesis + * @return {Node} + */ +function unwrapParen(_node, parenthesis) { + if (!parenthesis || parenthesis !== 'auto') return _node; + let node = _node; + while ((0, _is.isParenthesisNode)(node)) node = node.content; + return node; +} + +/** + * Get the precedence of a Node. + * Higher number for higher precedence, starting with 0. + * Returns null if the precedence is undefined. + * + * @param {Node} _node + * @param {string} parenthesis + * @param {string} implicit + * @param {Node} parent (for determining context for implicit multiplication) + * @return {number | null} + */ +function getPrecedence(_node, parenthesis, implicit, parent) { + let node = _node; + if (parenthesis !== 'keep') { + // ParenthesisNodes are only ignored when not in 'keep' mode + node = _node.getContent(); + } + const identifier = node.getIdentifier(); + let precedence = null; + for (let i = 0; i < properties.length; i++) { + if (identifier in properties[i]) { + precedence = i; + break; + } + } + // Bump up precedence of implicit multiplication, except when preceded + // by a "Rule 2" fraction ( [unaryOp]constant / constant ) + if (identifier === 'OperatorNode:multiply' && node.implicit && implicit !== 'show') { + const leftArg = unwrapParen(node.args[0], parenthesis); + if (!((0, _is.isConstantNode)(leftArg) && parent && parent.getIdentifier() === 'OperatorNode:divide' && (0, _is.rule2Node)(unwrapParen(parent.args[0], parenthesis))) && !(leftArg.getIdentifier() === 'OperatorNode:divide' && (0, _is.rule2Node)(unwrapParen(leftArg.args[0], parenthesis)) && (0, _is.isConstantNode)(unwrapParen(leftArg.args[1])))) { + precedence += 1; + } + } + return precedence; +} + +/** + * Get the associativity of an operator (left or right). + * Returns a string containing 'left' or 'right' or null if + * the associativity is not defined. + * + * @param {Node} _node + * @param {string} parenthesis + * @return {string|null} + * @throws {Error} + */ +function getAssociativity(_node, parenthesis) { + let node = _node; + if (parenthesis !== 'keep') { + // ParenthesisNodes are only ignored when not in 'keep' mode + node = _node.getContent(); + } + const identifier = node.getIdentifier(); + const index = getPrecedence(node, parenthesis); + if (index === null) { + // node isn't in the list + return null; + } + const property = properties[index][identifier]; + if ((0, _object.hasOwnProperty)(property, 'associativity')) { + if (property.associativity === 'left') { + return 'left'; + } + if (property.associativity === 'right') { + return 'right'; + } + // associativity is invalid + throw Error('\'' + identifier + '\' has the invalid associativity \'' + property.associativity + '\'.'); + } + + // associativity is undefined + return null; +} + +/** + * Check if an operator is associative with another operator. + * Returns either true or false or null if not defined. + * + * @param {Node} nodeA + * @param {Node} nodeB + * @param {string} parenthesis + * @return {boolean | null} + */ +function isAssociativeWith(nodeA, nodeB, parenthesis) { + // ParenthesisNodes are only ignored when not in 'keep' mode + const a = parenthesis !== 'keep' ? nodeA.getContent() : nodeA; + const b = parenthesis !== 'keep' ? nodeA.getContent() : nodeB; + const identifierA = a.getIdentifier(); + const identifierB = b.getIdentifier(); + const index = getPrecedence(a, parenthesis); + if (index === null) { + // node isn't in the list + return null; + } + const property = properties[index][identifierA]; + if ((0, _object.hasOwnProperty)(property, 'associativeWith') && property.associativeWith instanceof Array) { + for (let i = 0; i < property.associativeWith.length; i++) { + if (property.associativeWith[i] === identifierB) { + return true; + } + } + return false; + } + + // associativeWith is not defined + return null; +} + +/** + * Get the operator associated with a function name. + * Returns a string with the operator symbol, or null if the + * input is not the name of a function associated with an + * operator. + * + * @param {string} Function name + * @return {string | null} Associated operator symbol, if any + */ +function getOperator(fn) { + const identifier = 'OperatorNode:' + fn; + for (const group of properties) { + if (identifier in group) { + return group[identifier].op; + } + } + return null; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/parse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/parse.js new file mode 100644 index 0000000..0d35cec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/parse.js @@ -0,0 +1,1641 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createParse = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _factory = require("../utils/factory.js"); +var _is = require("../utils/is.js"); +var _collection = require("../utils/collection.js"); +var _number = require("../utils/number.js"); +var _object = require("../utils/object.js"); +const name = 'parse'; +const dependencies = ['typed', 'numeric', 'config', 'AccessorNode', 'ArrayNode', 'AssignmentNode', 'BlockNode', 'ConditionalNode', 'ConstantNode', 'FunctionAssignmentNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'RangeNode', 'RelationalNode', 'SymbolNode']; +const createParse = exports.createParse = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + numeric, + config, + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode + } = _ref; + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(). + * + * Note the evaluating arbitrary expressions may involve security risks, + * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information. + * + * Syntax: + * + * math.parse(expr) + * math.parse(expr, options) + * math.parse([expr1, expr2, expr3, ...]) + * math.parse([expr1, expr2, expr3, ...], options) + * + * Example: + * + * const node1 = math.parse('sqrt(3^2 + 4^2)') + * node1.compile().evaluate() // 5 + * + * let scope = {a:3, b:4} + * const node2 = math.parse('a * b') // 12 + * const code2 = node2.compile() + * code2.evaluate(scope) // 12 + * scope.a = 5 + * code2.evaluate(scope) // 20 + * + * const nodes = math.parse(['a = 3', 'b = 4', 'a * b']) + * nodes[2].compile().evaluate() // 12 + * + * See also: + * + * evaluate, compile + * + * @param {string | string[] | Matrix} expr Expression to be parsed + * @param {{nodes: Object}} [options] Available options: + * - `nodes` a set of custom nodes + * @return {Node | Node[]} node + * @throws {Error} + */ + const parse = typed(name, { + string: function (expression) { + return parseStart(expression, {}); + }, + 'Array | Matrix': function (expressions) { + return parseMultiple(expressions, {}); + }, + 'string, Object': function (expression, options) { + const extraNodes = options.nodes !== undefined ? options.nodes : {}; + return parseStart(expression, extraNodes); + }, + 'Array | Matrix, Object': parseMultiple + }); + function parseMultiple(expressions) { + let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + const extraNodes = options.nodes !== undefined ? options.nodes : {}; + + // parse an array or matrix with expressions + return (0, _collection.deepMap)(expressions, function (elem) { + if (typeof elem !== 'string') throw new TypeError('String expected'); + return parseStart(elem, extraNodes); + }); + } + + // token types enumeration + const TOKENTYPE = { + NULL: 0, + DELIMITER: 1, + NUMBER: 2, + SYMBOL: 3, + UNKNOWN: 4 + }; + + // map with all delimiters + const DELIMITERS = { + ',': true, + '(': true, + ')': true, + '[': true, + ']': true, + '{': true, + '}': true, + '"': true, + '\'': true, + ';': true, + '+': true, + '-': true, + '*': true, + '.*': true, + '/': true, + './': true, + '%': true, + '^': true, + '.^': true, + '~': true, + '!': true, + '&': true, + '|': true, + '^|': true, + '=': true, + ':': true, + '?': true, + '==': true, + '!=': true, + '<': true, + '>': true, + '<=': true, + '>=': true, + '<<': true, + '>>': true, + '>>>': true + }; + + // map with all named delimiters + const NAMED_DELIMITERS = { + mod: true, + to: true, + in: true, + and: true, + xor: true, + or: true, + not: true + }; + const CONSTANTS = { + true: true, + false: false, + null: null, + undefined + }; + const NUMERIC_CONSTANTS = ['NaN', 'Infinity']; + const ESCAPE_CHARACTERS = { + '"': '"', + "'": "'", + '\\': '\\', + '/': '/', + b: '\b', + f: '\f', + n: '\n', + r: '\r', + t: '\t' + // note that \u is handled separately in parseStringToken() + }; + function initialState() { + return { + extraNodes: {}, + // current extra nodes, must be careful not to mutate + expression: '', + // current expression + comment: '', + // last parsed comment + index: 0, + // current index in expr + token: '', + // current token + tokenType: TOKENTYPE.NULL, + // type of the token + nestingLevel: 0, + // level of nesting inside parameters, used to ignore newline characters + conditionalLevel: null // when a conditional is being parsed, the level of the conditional is stored here + }; + } + + /** + * View upto `length` characters of the expression starting at the current character. + * + * @param {Object} state + * @param {number} [length=1] Number of characters to view + * @returns {string} + * @private + */ + function currentString(state, length) { + return state.expression.substr(state.index, length); + } + + /** + * View the current character. Returns '' if end of expression is reached. + * + * @param {Object} state + * @returns {string} + * @private + */ + function currentCharacter(state) { + return currentString(state, 1); + } + + /** + * Get the next character from the expression. + * The character is stored into the char c. If the end of the expression is + * reached, the function puts an empty string in c. + * @private + */ + function next(state) { + state.index++; + } + + /** + * Preview the previous character from the expression. + * @return {string} cNext + * @private + */ + function prevCharacter(state) { + return state.expression.charAt(state.index - 1); + } + + /** + * Preview the next character from the expression. + * @return {string} cNext + * @private + */ + function nextCharacter(state) { + return state.expression.charAt(state.index + 1); + } + + /** + * Get next token in the current string expr. + * The token and token type are available as token and tokenType + * @private + */ + function getToken(state) { + state.tokenType = TOKENTYPE.NULL; + state.token = ''; + state.comment = ''; + + // skip over ignored characters: + while (true) { + // comments: + if (currentCharacter(state) === '#') { + while (currentCharacter(state) !== '\n' && currentCharacter(state) !== '') { + state.comment += currentCharacter(state); + next(state); + } + } + // whitespace: space, tab, and newline when inside parameters + if (parse.isWhitespace(currentCharacter(state), state.nestingLevel)) { + next(state); + } else { + break; + } + } + + // check for end of expression + if (currentCharacter(state) === '') { + // token is still empty + state.tokenType = TOKENTYPE.DELIMITER; + return; + } + + // check for new line character + if (currentCharacter(state) === '\n' && !state.nestingLevel) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = currentCharacter(state); + next(state); + return; + } + const c1 = currentCharacter(state); + const c2 = currentString(state, 2); + const c3 = currentString(state, 3); + if (c3.length === 3 && DELIMITERS[c3]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c3; + next(state); + next(state); + next(state); + return; + } + + // check for delimiters consisting of 2 characters + if (c2.length === 2 && DELIMITERS[c2]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c2; + next(state); + next(state); + return; + } + + // check for delimiters consisting of 1 character + if (DELIMITERS[c1]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c1; + next(state); + return; + } + + // check for a number + if (parse.isDigitDot(c1)) { + state.tokenType = TOKENTYPE.NUMBER; + + // check for binary, octal, or hex + const c2 = currentString(state, 2); + if (c2 === '0b' || c2 === '0o' || c2 === '0x') { + state.token += currentCharacter(state); + next(state); + state.token += currentCharacter(state); + next(state); + while (parse.isHexDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (currentCharacter(state) === '.') { + // this number has a radix point + state.token += '.'; + next(state); + // get the digits after the radix + while (parse.isHexDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } else if (currentCharacter(state) === 'i') { + // this number has a word size suffix + state.token += 'i'; + next(state); + // get the word size + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } + return; + } + + // get number, can have a single dot + if (currentCharacter(state) === '.') { + state.token += currentCharacter(state); + next(state); + if (!parse.isDigit(currentCharacter(state))) { + // this is no number, it is just a dot (can be dot notation) + state.tokenType = TOKENTYPE.DELIMITER; + return; + } + } else { + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + // check for exponential notation like "2.3e-4", "1.23e50" or "2e+4" + if (currentCharacter(state) === 'E' || currentCharacter(state) === 'e') { + if (parse.isDigit(nextCharacter(state)) || nextCharacter(state) === '-' || nextCharacter(state) === '+') { + state.token += currentCharacter(state); + next(state); + if (currentCharacter(state) === '+' || currentCharacter(state) === '-') { + state.token += currentCharacter(state); + next(state); + } + // Scientific notation MUST be followed by an exponent + if (!parse.isDigit(currentCharacter(state))) { + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) { + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + } else if (nextCharacter(state) === '.') { + next(state); + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + } + return; + } + + // check for variables, functions, named operators + if (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state))) { + while (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state)) || parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if ((0, _object.hasOwnProperty)(NAMED_DELIMITERS, state.token)) { + state.tokenType = TOKENTYPE.DELIMITER; + } else { + state.tokenType = TOKENTYPE.SYMBOL; + } + return; + } + + // something unknown is found, wrong characters -> a syntax error + state.tokenType = TOKENTYPE.UNKNOWN; + while (currentCharacter(state) !== '') { + state.token += currentCharacter(state); + next(state); + } + throw createSyntaxError(state, 'Syntax error in part "' + state.token + '"'); + } + + /** + * Get next token and skip newline tokens + */ + function getTokenSkipNewline(state) { + do { + getToken(state); + } while (state.token === '\n'); // eslint-disable-line no-unmodified-loop-condition + } + + /** + * Open parameters. + * New line characters will be ignored until closeParams(state) is called + */ + function openParams(state) { + state.nestingLevel++; + } + + /** + * Close parameters. + * New line characters will no longer be ignored + */ + function closeParams(state) { + state.nestingLevel--; + } + + /** + * Checks whether the current character `c` is a valid alpha character: + * + * - A latin letter (upper or lower case) Ascii: a-z, A-Z + * - An underscore Ascii: _ + * - A dollar sign Ascii: $ + * - A latin letter with accents Unicode: \u00C0 - \u02AF + * - A greek letter Unicode: \u0370 - \u03FF + * - A mathematical alphanumeric symbol Unicode: \u{1D400} - \u{1D7FF} excluding invalid code points + * + * The previous and next characters are needed to determine whether + * this character is part of a unicode surrogate pair. + * + * @param {string} c Current character in the expression + * @param {string} cPrev Previous character + * @param {string} cNext Next character + * @return {boolean} + */ + parse.isAlpha = function isAlpha(c, cPrev, cNext) { + return parse.isValidLatinOrGreek(c) || parse.isValidMathSymbol(c, cNext) || parse.isValidMathSymbol(cPrev, c); + }; + + /** + * Test whether a character is a valid latin, greek, or letter-like character + * @param {string} c + * @return {boolean} + */ + parse.isValidLatinOrGreek = function isValidLatinOrGreek(c) { + return /^[a-zA-Z_$\u00C0-\u02AF\u0370-\u03FF\u2100-\u214F]$/.test(c); + }; + + /** + * Test whether two given 16 bit characters form a surrogate pair of a + * unicode math symbol. + * + * https://unicode-table.com/en/ + * https://www.wikiwand.com/en/Mathematical_operators_and_symbols_in_Unicode + * + * Note: In ES6 will be unicode aware: + * https://stackoverflow.com/questions/280712/javascript-unicode-regexes + * https://mathiasbynens.be/notes/es6-unicode-regex + * + * @param {string} high + * @param {string} low + * @return {boolean} + */ + parse.isValidMathSymbol = function isValidMathSymbol(high, low) { + return /^[\uD835]$/.test(high) && /^[\uDC00-\uDFFF]$/.test(low) && /^[^\uDC55\uDC9D\uDCA0\uDCA1\uDCA3\uDCA4\uDCA7\uDCA8\uDCAD\uDCBA\uDCBC\uDCC4\uDD06\uDD0B\uDD0C\uDD15\uDD1D\uDD3A\uDD3F\uDD45\uDD47-\uDD49\uDD51\uDEA6\uDEA7\uDFCC\uDFCD]$/.test(low); + }; + + /** + * Check whether given character c is a white space character: space, tab, or enter + * @param {string} c + * @param {number} nestingLevel + * @return {boolean} + */ + parse.isWhitespace = function isWhitespace(c, nestingLevel) { + // TODO: also take '\r' carriage return as newline? Or does that give problems on mac? + return c === ' ' || c === '\t' || c === '\n' && nestingLevel > 0; + }; + + /** + * Test whether the character c is a decimal mark (dot). + * This is the case when it's not the start of a delimiter '.*', './', or '.^' + * @param {string} c + * @param {string} cNext + * @return {boolean} + */ + parse.isDecimalMark = function isDecimalMark(c, cNext) { + return c === '.' && cNext !== '/' && cNext !== '*' && cNext !== '^'; + }; + + /** + * checks if the given char c is a digit or dot + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isDigitDot = function isDigitDot(c) { + return c >= '0' && c <= '9' || c === '.'; + }; + + /** + * checks if the given char c is a digit + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isDigit = function isDigit(c) { + return c >= '0' && c <= '9'; + }; + + /** + * checks if the given char c is a hex digit + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isHexDigit = function isHexDigit(c) { + return c >= '0' && c <= '9' || c >= 'a' && c <= 'f' || c >= 'A' && c <= 'F'; + }; + + /** + * Start of the parse levels below, in order of precedence + * @return {Node} node + * @private + */ + function parseStart(expression, extraNodes) { + const state = initialState(); + (0, _extends2.default)(state, { + expression, + extraNodes + }); + getToken(state); + const node = parseBlock(state); + + // check for garbage at the end of the expression + // an expression ends with a empty character '' and tokenType DELIMITER + if (state.token !== '') { + if (state.tokenType === TOKENTYPE.DELIMITER) { + // user entered a not existing operator like "//" + + // TODO: give hints for aliases, for example with "<>" give as hint " did you mean !== ?" + throw createError(state, 'Unexpected operator ' + state.token); + } else { + throw createSyntaxError(state, 'Unexpected part "' + state.token + '"'); + } + } + return node; + } + + /** + * Parse a block with expressions. Expressions can be separated by a newline + * character '\n', or by a semicolon ';'. In case of a semicolon, no output + * of the preceding line is returned. + * @return {Node} node + * @private + */ + function parseBlock(state) { + let node; + const blocks = []; + let visible; + if (state.token !== '' && state.token !== '\n' && state.token !== ';') { + node = parseAssignment(state); + if (state.comment) { + node.comment = state.comment; + } + } + + // TODO: simplify this loop + while (state.token === '\n' || state.token === ';') { + // eslint-disable-line no-unmodified-loop-condition + if (blocks.length === 0 && node) { + visible = state.token !== ';'; + blocks.push({ + node, + visible + }); + } + getToken(state); + if (state.token !== '\n' && state.token !== ';' && state.token !== '') { + node = parseAssignment(state); + if (state.comment) { + node.comment = state.comment; + } + visible = state.token !== ';'; + blocks.push({ + node, + visible + }); + } + } + if (blocks.length > 0) { + return new BlockNode(blocks); + } else { + if (!node) { + node = new ConstantNode(undefined); + if (state.comment) { + node.comment = state.comment; + } + } + return node; + } + } + + /** + * Assignment of a function or variable, + * - can be a variable like 'a=2.3' + * - or a updating an existing variable like 'matrix(2,3:5)=[6,7,8]' + * - defining a function like 'f(x) = x^2' + * @return {Node} node + * @private + */ + function parseAssignment(state) { + let name, args, value, valid; + const node = parseConditional(state); + if (state.token === '=') { + if ((0, _is.isSymbolNode)(node)) { + // parse a variable assignment like 'a = 2/3' + name = node.name; + getTokenSkipNewline(state); + value = parseAssignment(state); + return new AssignmentNode(new SymbolNode(name), value); + } else if ((0, _is.isAccessorNode)(node)) { + // parse a matrix subset assignment like 'A[1,2] = 4' + getTokenSkipNewline(state); + value = parseAssignment(state); + return new AssignmentNode(node.object, node.index, value); + } else if ((0, _is.isFunctionNode)(node) && (0, _is.isSymbolNode)(node.fn)) { + // parse function assignment like 'f(x) = x^2' + valid = true; + args = []; + name = node.name; + node.args.forEach(function (arg, index) { + if ((0, _is.isSymbolNode)(arg)) { + args[index] = arg.name; + } else { + valid = false; + } + }); + if (valid) { + getTokenSkipNewline(state); + value = parseAssignment(state); + return new FunctionAssignmentNode(name, args, value); + } + } + throw createSyntaxError(state, 'Invalid left hand side of assignment operator ='); + } + return node; + } + + /** + * conditional operation + * + * condition ? truePart : falsePart + * + * Note: conditional operator is right-associative + * + * @return {Node} node + * @private + */ + function parseConditional(state) { + let node = parseLogicalOr(state); + while (state.token === '?') { + // eslint-disable-line no-unmodified-loop-condition + // set a conditional level, the range operator will be ignored as long + // as conditionalLevel === state.nestingLevel. + const prev = state.conditionalLevel; + state.conditionalLevel = state.nestingLevel; + getTokenSkipNewline(state); + const condition = node; + const trueExpr = parseAssignment(state); + if (state.token !== ':') throw createSyntaxError(state, 'False part of conditional expression expected'); + state.conditionalLevel = null; + getTokenSkipNewline(state); + const falseExpr = parseAssignment(state); // Note: check for conditional operator again, right associativity + + node = new ConditionalNode(condition, trueExpr, falseExpr); + + // restore the previous conditional level + state.conditionalLevel = prev; + } + return node; + } + + /** + * logical or, 'x or y' + * @return {Node} node + * @private + */ + function parseLogicalOr(state) { + let node = parseLogicalXor(state); + while (state.token === 'or') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('or', 'or', [node, parseLogicalXor(state)]); + } + return node; + } + + /** + * logical exclusive or, 'x xor y' + * @return {Node} node + * @private + */ + function parseLogicalXor(state) { + let node = parseLogicalAnd(state); + while (state.token === 'xor') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('xor', 'xor', [node, parseLogicalAnd(state)]); + } + return node; + } + + /** + * logical and, 'x and y' + * @return {Node} node + * @private + */ + function parseLogicalAnd(state) { + let node = parseBitwiseOr(state); + while (state.token === 'and') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('and', 'and', [node, parseBitwiseOr(state)]); + } + return node; + } + + /** + * bitwise or, 'x | y' + * @return {Node} node + * @private + */ + function parseBitwiseOr(state) { + let node = parseBitwiseXor(state); + while (state.token === '|') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('|', 'bitOr', [node, parseBitwiseXor(state)]); + } + return node; + } + + /** + * bitwise exclusive or (xor), 'x ^| y' + * @return {Node} node + * @private + */ + function parseBitwiseXor(state) { + let node = parseBitwiseAnd(state); + while (state.token === '^|') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('^|', 'bitXor', [node, parseBitwiseAnd(state)]); + } + return node; + } + + /** + * bitwise and, 'x & y' + * @return {Node} node + * @private + */ + function parseBitwiseAnd(state) { + let node = parseRelational(state); + while (state.token === '&') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('&', 'bitAnd', [node, parseRelational(state)]); + } + return node; + } + + /** + * Parse a chained conditional, like 'a > b >= c' + * @return {Node} node + */ + function parseRelational(state) { + const params = [parseShift(state)]; + const conditionals = []; + const operators = { + '==': 'equal', + '!=': 'unequal', + '<': 'smaller', + '>': 'larger', + '<=': 'smallerEq', + '>=': 'largerEq' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + // eslint-disable-line no-unmodified-loop-condition + const cond = { + name: state.token, + fn: operators[state.token] + }; + conditionals.push(cond); + getTokenSkipNewline(state); + params.push(parseShift(state)); + } + if (params.length === 1) { + return params[0]; + } else if (params.length === 2) { + return new OperatorNode(conditionals[0].name, conditionals[0].fn, params); + } else { + return new RelationalNode(conditionals.map(c => c.fn), params); + } + } + + /** + * Bitwise left shift, bitwise right arithmetic shift, bitwise right logical shift + * @return {Node} node + * @private + */ + function parseShift(state) { + let node, name, fn, params; + node = parseConversion(state); + const operators = { + '<<': 'leftShift', + '>>': 'rightArithShift', + '>>>': 'rightLogShift' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + params = [node, parseConversion(state)]; + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * conversion operators 'to' and 'in' + * @return {Node} node + * @private + */ + function parseConversion(state) { + let node, name, fn, params; + node = parseRange(state); + const operators = { + to: 'to', + in: 'to' // alias of 'to' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + if (name === 'in' && state.token === '') { + // end of expression -> this is the unit 'in' ('inch') + node = new OperatorNode('*', 'multiply', [node, new SymbolNode('in')], true); + } else { + // operator 'a to b' or 'a in b' + params = [node, parseRange(state)]; + node = new OperatorNode(name, fn, params); + } + } + return node; + } + + /** + * parse range, "start:end", "start:step:end", ":", "start:", ":end", etc + * @return {Node} node + * @private + */ + function parseRange(state) { + let node; + const params = []; + if (state.token === ':') { + // implicit start=1 (one-based) + node = new ConstantNode(1); + } else { + // explicit start + node = parseAddSubtract(state); + } + if (state.token === ':' && state.conditionalLevel !== state.nestingLevel) { + // we ignore the range operator when a conditional operator is being processed on the same level + params.push(node); + + // parse step and end + while (state.token === ':' && params.length < 3) { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + if (state.token === ')' || state.token === ']' || state.token === ',' || state.token === '') { + // implicit end + params.push(new SymbolNode('end')); + } else { + // explicit end + params.push(parseAddSubtract(state)); + } + } + if (params.length === 3) { + // params = [start, step, end] + node = new RangeNode(params[0], params[2], params[1]); // start, end, step + } else { + // length === 2 + // params = [start, end] + node = new RangeNode(params[0], params[1]); // start, end + } + } + return node; + } + + /** + * add or subtract + * @return {Node} node + * @private + */ + function parseAddSubtract(state) { + let node, name, fn, params; + node = parseMultiplyDivide(state); + const operators = { + '+': 'add', + '-': 'subtract' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + const rightNode = parseMultiplyDivide(state); + if (rightNode.isPercentage) { + params = [node, new OperatorNode('*', 'multiply', [node, rightNode])]; + } else { + params = [node, rightNode]; + } + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * multiply, divide + * @return {Node} node + * @private + */ + function parseMultiplyDivide(state) { + let node, last, name, fn; + node = parseImplicitMultiplication(state); + last = node; + const operators = { + '*': 'multiply', + '.*': 'dotMultiply', + '/': 'divide', + './': 'dotDivide' + }; + while (true) { + if ((0, _object.hasOwnProperty)(operators, state.token)) { + // explicit operators + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + last = parseImplicitMultiplication(state); + node = new OperatorNode(name, fn, [node, last]); + } else { + break; + } + } + return node; + } + + /** + * implicit multiplication + * @return {Node} node + * @private + */ + function parseImplicitMultiplication(state) { + let node, last; + node = parseRule2(state); + last = node; + while (true) { + if (state.tokenType === TOKENTYPE.SYMBOL || state.token === 'in' && (0, _is.isConstantNode)(node) || state.token === 'in' && (0, _is.isOperatorNode)(node) && node.fn === 'unaryMinus' && (0, _is.isConstantNode)(node.args[0]) || state.tokenType === TOKENTYPE.NUMBER && !(0, _is.isConstantNode)(last) && (!(0, _is.isOperatorNode)(last) || last.op === '!') || state.token === '(') { + // parse implicit multiplication + // + // symbol: implicit multiplication like '2a', '(2+3)a', 'a b' + // number: implicit multiplication like '(2+3)2' + // parenthesis: implicit multiplication like '2(3+4)', '(3+4)(1+2)' + last = parseRule2(state); + node = new OperatorNode('*', 'multiply', [node, last], true /* implicit */); + } else { + break; + } + } + return node; + } + + /** + * Infamous "rule 2" as described in https://github.com/josdejong/mathjs/issues/792#issuecomment-361065370 + * And as amended in https://github.com/josdejong/mathjs/issues/2370#issuecomment-1054052164 + * Explicit division gets higher precedence than implicit multiplication + * when the division matches this pattern: + * [unaryPrefixOp]?[number] / [number] [symbol] + * @return {Node} node + * @private + */ + function parseRule2(state) { + let node = parseModulusPercentage(state); + let last = node; + const tokenStates = []; + while (true) { + // Match the "number /" part of the pattern "number / number symbol" + if (state.token === '/' && (0, _is.rule2Node)(last)) { + // Look ahead to see if the next token is a number + tokenStates.push((0, _extends2.default)({}, state)); + getTokenSkipNewline(state); + + // Match the "number / number" part of the pattern + if (state.tokenType === TOKENTYPE.NUMBER) { + // Look ahead again + tokenStates.push((0, _extends2.default)({}, state)); + getTokenSkipNewline(state); + + // Match the "symbol" part of the pattern, or a left parenthesis + if (state.tokenType === TOKENTYPE.SYMBOL || state.token === '(') { + // We've matched the pattern "number / number symbol". + // Rewind once and build the "number / number" node; the symbol will be consumed later + (0, _extends2.default)(state, tokenStates.pop()); + tokenStates.pop(); + last = parseModulusPercentage(state); + node = new OperatorNode('/', 'divide', [node, last]); + } else { + // Not a match, so rewind + tokenStates.pop(); + (0, _extends2.default)(state, tokenStates.pop()); + break; + } + } else { + // Not a match, so rewind + (0, _extends2.default)(state, tokenStates.pop()); + break; + } + } else { + break; + } + } + return node; + } + + /** + * modulus and percentage + * @return {Node} node + * @private + */ + function parseModulusPercentage(state) { + let node, name, fn, params; + node = parseUnary(state); + const operators = { + '%': 'mod', + mod: 'mod' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + if (name === '%' && state.tokenType === TOKENTYPE.DELIMITER && state.token !== '(') { + // If the expression contains only %, then treat that as /100 + node = new OperatorNode('/', 'divide', [node, new ConstantNode(100)], false, true); + } else { + params = [node, parseUnary(state)]; + node = new OperatorNode(name, fn, params); + } + } + return node; + } + + /** + * Unary plus and minus, and logical and bitwise not + * @return {Node} node + * @private + */ + function parseUnary(state) { + let name, params, fn; + const operators = { + '-': 'unaryMinus', + '+': 'unaryPlus', + '~': 'bitNot', + not: 'not' + }; + if ((0, _object.hasOwnProperty)(operators, state.token)) { + fn = operators[state.token]; + name = state.token; + getTokenSkipNewline(state); + params = [parseUnary(state)]; + return new OperatorNode(name, fn, params); + } + return parsePow(state); + } + + /** + * power + * Note: power operator is right associative + * @return {Node} node + * @private + */ + function parsePow(state) { + let node, name, fn, params; + node = parseLeftHandOperators(state); + if (state.token === '^' || state.token === '.^') { + name = state.token; + fn = name === '^' ? 'pow' : 'dotPow'; + getTokenSkipNewline(state); + params = [node, parseUnary(state)]; // Go back to unary, we can have '2^-3' + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * Left hand operators: factorial x!, ctranspose x' + * @return {Node} node + * @private + */ + function parseLeftHandOperators(state) { + let node, name, fn, params; + node = parseCustomNodes(state); + const operators = { + '!': 'factorial', + '\'': 'ctranspose' + }; + while ((0, _object.hasOwnProperty)(operators, state.token)) { + name = state.token; + fn = operators[name]; + getToken(state); + params = [node]; + node = new OperatorNode(name, fn, params); + node = parseAccessors(state, node); + } + return node; + } + + /** + * Parse a custom node handler. A node handler can be used to process + * nodes in a custom way, for example for handling a plot. + * + * A handler must be passed as second argument of the parse function. + * - must extend math.Node + * - must contain a function _compile(defs: Object) : string + * - must contain a function find(filter: Object) : Node[] + * - must contain a function toString() : string + * - the constructor is called with a single argument containing all parameters + * + * For example: + * + * nodes = { + * 'plot': PlotHandler + * } + * + * The constructor of the handler is called as: + * + * node = new PlotHandler(params) + * + * The handler will be invoked when evaluating an expression like: + * + * node = math.parse('plot(sin(x), x)', nodes) + * + * @return {Node} node + * @private + */ + function parseCustomNodes(state) { + let params = []; + if (state.tokenType === TOKENTYPE.SYMBOL && (0, _object.hasOwnProperty)(state.extraNodes, state.token)) { + const CustomNode = state.extraNodes[state.token]; + getToken(state); + + // parse parameters + if (state.token === '(') { + params = []; + openParams(state); + getToken(state); + if (state.token !== ')') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + } + + // create a new custom node + // noinspection JSValidateTypes + return new CustomNode(params); + } + return parseSymbol(state); + } + + /** + * parse symbols: functions, variables, constants, units + * @return {Node} node + * @private + */ + function parseSymbol(state) { + let node, name; + if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) { + name = state.token; + getToken(state); + if ((0, _object.hasOwnProperty)(CONSTANTS, name)) { + // true, false, null, ... + node = new ConstantNode(CONSTANTS[name]); + } else if (NUMERIC_CONSTANTS.includes(name)) { + // NaN, Infinity + node = new ConstantNode(numeric(name, 'number')); + } else { + node = new SymbolNode(name); + } + + // parse function parameters and matrix index + node = parseAccessors(state, node); + return node; + } + return parseString(state); + } + + /** + * parse accessors: + * - function invocation in round brackets (...), for example sqrt(2) + * - index enclosed in square brackets [...], for example A[2,3] + * - dot notation for properties, like foo.bar + * @param {Object} state + * @param {Node} node Node on which to apply the parameters. If there + * are no parameters in the expression, the node + * itself is returned + * @param {string[]} [types] Filter the types of notations + * can be ['(', '[', '.'] + * @return {Node} node + * @private + */ + function parseAccessors(state, node, types) { + let params; + while ((state.token === '(' || state.token === '[' || state.token === '.') && (!types || types.includes(state.token))) { + // eslint-disable-line no-unmodified-loop-condition + params = []; + if (state.token === '(') { + if ((0, _is.isSymbolNode)(node) || (0, _is.isAccessorNode)(node)) { + // function invocation like fn(2, 3) or obj.fn(2, 3) + openParams(state); + getToken(state); + if (state.token !== ')') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + node = new FunctionNode(node, params); + } else { + // implicit multiplication like (2+3)(4+5) or sqrt(2)(1+2) + // don't parse it here but let it be handled by parseImplicitMultiplication + // with correct precedence + return node; + } + } else if (state.token === '[') { + // index notation like variable[2, 3] + openParams(state); + getToken(state); + if (state.token !== ']') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ']') { + throw createSyntaxError(state, 'Parenthesis ] expected'); + } + closeParams(state); + getToken(state); + node = new AccessorNode(node, new IndexNode(params)); + } else { + // dot notation like variable.prop + getToken(state); + const isPropertyName = state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS; + if (!isPropertyName) { + throw createSyntaxError(state, 'Property name expected after dot'); + } + params.push(new ConstantNode(state.token)); + getToken(state); + const dotNotation = true; + node = new AccessorNode(node, new IndexNode(params, dotNotation)); + } + } + return node; + } + + /** + * Parse a single or double quoted string. + * @return {Node} node + * @private + */ + function parseString(state) { + let node, str; + if (state.token === '"' || state.token === "'") { + str = parseStringToken(state, state.token); + + // create constant + node = new ConstantNode(str); + + // parse index parameters + node = parseAccessors(state, node); + return node; + } + return parseMatrix(state); + } + + /** + * Parse a string surrounded by single or double quotes + * @param {Object} state + * @param {"'" | "\""} quote + * @return {string} + */ + function parseStringToken(state, quote) { + let str = ''; + while (currentCharacter(state) !== '' && currentCharacter(state) !== quote) { + if (currentCharacter(state) === '\\') { + next(state); + const char = currentCharacter(state); + const escapeChar = ESCAPE_CHARACTERS[char]; + if (escapeChar !== undefined) { + // an escaped control character like \" or \n + str += escapeChar; + state.index += 1; + } else if (char === 'u') { + // escaped unicode character + const unicode = state.expression.slice(state.index + 1, state.index + 5); + if (/^[0-9A-Fa-f]{4}$/.test(unicode)) { + // test whether the string holds four hexadecimal values + str += String.fromCharCode(parseInt(unicode, 16)); + state.index += 5; + } else { + throw createSyntaxError(state, `Invalid unicode character \\u${unicode}`); + } + } else { + throw createSyntaxError(state, `Bad escape character \\${char}`); + } + } else { + // any regular character + str += currentCharacter(state); + next(state); + } + } + getToken(state); + if (state.token !== quote) { + throw createSyntaxError(state, `End of string ${quote} expected`); + } + getToken(state); + return str; + } + + /** + * parse the matrix + * @return {Node} node + * @private + */ + function parseMatrix(state) { + let array, params, rows, cols; + if (state.token === '[') { + // matrix [...] + openParams(state); + getToken(state); + if (state.token !== ']') { + // this is a non-empty matrix + const row = parseRow(state); + if (state.token === ';') { + // 2 dimensional array + rows = 1; + params = [row]; + + // the rows of the matrix are separated by dot-comma's + while (state.token === ';') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + if (state.token !== ']') { + params[rows] = parseRow(state); + rows++; + } + } + if (state.token !== ']') { + throw createSyntaxError(state, 'End of matrix ] expected'); + } + closeParams(state); + getToken(state); + + // check if the number of columns matches in all rows + cols = params[0].items.length; + for (let r = 1; r < rows; r++) { + if (params[r].items.length !== cols) { + throw createError(state, 'Column dimensions mismatch ' + '(' + params[r].items.length + ' !== ' + cols + ')'); + } + } + array = new ArrayNode(params); + } else { + // 1 dimensional vector + if (state.token !== ']') { + throw createSyntaxError(state, 'End of matrix ] expected'); + } + closeParams(state); + getToken(state); + array = row; + } + } else { + // this is an empty matrix "[ ]" + closeParams(state); + getToken(state); + array = new ArrayNode([]); + } + return parseAccessors(state, array); + } + return parseObject(state); + } + + /** + * Parse a single comma-separated row from a matrix, like 'a, b, c' + * @return {ArrayNode} node + */ + function parseRow(state) { + const params = [parseAssignment(state)]; + let len = 1; + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + + // parse expression + if (state.token !== ']' && state.token !== ';') { + params[len] = parseAssignment(state); + len++; + } + } + return new ArrayNode(params); + } + + /** + * parse an object, enclosed in angle brackets{...}, for example {value: 2} + * @return {Node} node + * @private + */ + function parseObject(state) { + if (state.token === '{') { + openParams(state); + let key; + const properties = {}; + do { + getToken(state); + if (state.token !== '}') { + // parse key + if (state.token === '"' || state.token === "'") { + key = parseStringToken(state, state.token); + } else if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) { + key = state.token; + getToken(state); + } else { + throw createSyntaxError(state, 'Symbol or string expected as object key'); + } + + // parse key/value separator + if (state.token !== ':') { + throw createSyntaxError(state, 'Colon : expected after object key'); + } + getToken(state); + + // parse key + properties[key] = parseAssignment(state); + } + } while (state.token === ','); // eslint-disable-line no-unmodified-loop-condition + + if (state.token !== '}') { + throw createSyntaxError(state, 'Comma , or bracket } expected after object value'); + } + closeParams(state); + getToken(state); + let node = new ObjectNode(properties); + + // parse index parameters + node = parseAccessors(state, node); + return node; + } + return parseNumber(state); + } + + /** + * parse a number + * @return {Node} node + * @private + */ + function parseNumber(state) { + let numberStr; + if (state.tokenType === TOKENTYPE.NUMBER) { + // this is a number + numberStr = state.token; + getToken(state); + const numericType = (0, _number.safeNumberType)(numberStr, config); + const value = numeric(numberStr, numericType); + return new ConstantNode(value); + } + return parseParentheses(state); + } + + /** + * parentheses + * @return {Node} node + * @private + */ + function parseParentheses(state) { + let node; + + // check if it is a parenthesized expression + if (state.token === '(') { + // parentheses (...) + openParams(state); + getToken(state); + node = parseAssignment(state); // start again + + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + node = new ParenthesisNode(node); + node = parseAccessors(state, node); + return node; + } + return parseEnd(state); + } + + /** + * Evaluated when the expression is not yet ended but expected to end + * @return {Node} res + * @private + */ + function parseEnd(state) { + if (state.token === '') { + // syntax error or unexpected end of expression + throw createSyntaxError(state, 'Unexpected end of expression'); + } else { + throw createSyntaxError(state, 'Value expected'); + } + } + + /** + * Shortcut for getting the current row value (one based) + * Returns the line of the currently handled expression + * @private + */ + /* TODO: implement keeping track on the row number + function row () { + return null + } + */ + + /** + * Shortcut for getting the current col value (one based) + * Returns the column (position) where the last state.token starts + * @private + */ + function col(state) { + return state.index - state.token.length + 1; + } + + /** + * Create an error + * @param {Object} state + * @param {string} message + * @return {SyntaxError} instantiated error + * @private + */ + function createSyntaxError(state, message) { + const c = col(state); + const error = new SyntaxError(message + ' (char ' + c + ')'); + error.char = c; + return error; + } + + /** + * Create an error + * @param {Object} state + * @param {string} message + * @return {Error} instantiated error + * @private + */ + function createError(state, message) { + const c = col(state); + const error = new SyntaxError(message + ' (char ' + c + ')'); + error.char = c; + return error; + } + + // Now that we can parse, automatically convert strings to Nodes by parsing + typed.addConversion({ + from: 'string', + to: 'Node', + convert: parse + }); + return parse; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/and.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/and.transform.js new file mode 100644 index 0000000..494f509 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/and.transform.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAndTransform = void 0; +var _and = require("../../function/logical/and.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'and'; +const dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']; +const createAndTransform = exports.createAndTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + const and = (0, _and.createAnd)({ + typed, + matrix, + equalScalar, + zeros, + not, + concat + }); + function andTransform(args, math, scope) { + const condition1 = args[0].compile().evaluate(scope); + if (!(0, _is.isCollection)(condition1) && !and(condition1, true)) { + return false; + } + const condition2 = args[1].compile().evaluate(scope); + return and(condition1, condition2); + } + andTransform.rawArgs = true; + return andTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/apply.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/apply.transform.js new file mode 100644 index 0000000..59aefc8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/apply.transform.js @@ -0,0 +1,50 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createApplyTransform = void 0; +var _errorTransform = require("./utils/errorTransform.js"); +var _factory = require("../../utils/factory.js"); +var _apply = require("../../function/matrix/apply.js"); +var _is = require("../../utils/is.js"); +const name = 'apply'; +const dependencies = ['typed', 'isInteger']; + +/** + * Attach a transform function to math.apply + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function apply + * from one-based to zero based + */ +const createApplyTransform = exports.createApplyTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isInteger + } = _ref; + const apply = (0, _apply.createApply)({ + typed, + isInteger + }); + + // @see: comment of concat itself + return typed('apply', { + '...any': function (args) { + // change dim from one-based to zero-based + const dim = args[1]; + if ((0, _is.isNumber)(dim)) { + args[1] = dim - 1; + } else if ((0, _is.isBigNumber)(dim)) { + args[1] = dim.minus(1); + } + try { + return apply.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitAnd.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitAnd.transform.js new file mode 100644 index 0000000..bd1cb36 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitAnd.transform.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitAndTransform = void 0; +var _bitAnd = require("../../function/bitwise/bitAnd.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'bitAnd'; +const dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']; +const createBitAndTransform = exports.createBitAndTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + const bitAnd = (0, _bitAnd.createBitAnd)({ + typed, + matrix, + equalScalar, + zeros, + not, + concat + }); + function bitAndTransform(args, math, scope) { + const condition1 = args[0].compile().evaluate(scope); + if (!(0, _is.isCollection)(condition1)) { + if (isNaN(condition1)) { + return NaN; + } + if (condition1 === 0 || condition1 === false) { + return 0; + } + } + const condition2 = args[1].compile().evaluate(scope); + return bitAnd(condition1, condition2); + } + bitAndTransform.rawArgs = true; + return bitAndTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitOr.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitOr.transform.js new file mode 100644 index 0000000..41c0927 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/bitOr.transform.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitOrTransform = void 0; +var _bitOr = require("../../function/bitwise/bitOr.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'bitOr'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +const createBitOrTransform = exports.createBitOrTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + const bitOr = (0, _bitOr.createBitOr)({ + typed, + matrix, + equalScalar, + DenseMatrix, + concat + }); + function bitOrTransform(args, math, scope) { + const condition1 = args[0].compile().evaluate(scope); + if (!(0, _is.isCollection)(condition1)) { + if (isNaN(condition1)) { + return NaN; + } + if (condition1 === -1) { + return -1; + } + if (condition1 === true) { + return 1; + } + } + const condition2 = args[1].compile().evaluate(scope); + return bitOr(condition1, condition2); + } + bitOrTransform.rawArgs = true; + return bitOrTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/column.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/column.transform.js new file mode 100644 index 0000000..b03d33c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/column.transform.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createColumnTransform = void 0; +var _errorTransform = require("./utils/errorTransform.js"); +var _factory = require("../../utils/factory.js"); +var _column = require("../../function/matrix/column.js"); +var _is = require("../../utils/is.js"); +const name = 'column'; +const dependencies = ['typed', 'Index', 'matrix', 'range']; + +/** + * Attach a transform function to matrix.column + * Adds a property transform containing the transform function. + * + * This transform changed the last `index` parameter of function column + * from zero-based to one-based + */ +const createColumnTransform = exports.createColumnTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Index, + matrix, + range + } = _ref; + const column = (0, _column.createColumn)({ + typed, + Index, + matrix, + range + }); + + // @see: comment of column itself + return typed('column', { + '...any': function (args) { + // change last argument from zero-based to one-based + const lastIndex = args.length - 1; + const last = args[lastIndex]; + if ((0, _is.isNumber)(last)) { + args[lastIndex] = last - 1; + } + try { + return column.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/concat.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/concat.transform.js new file mode 100644 index 0000000..a715ea5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/concat.transform.js @@ -0,0 +1,51 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createConcatTransform = void 0; +var _is = require("../../utils/is.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _factory = require("../../utils/factory.js"); +var _concat = require("../../function/matrix/concat.js"); +const name = 'concat'; +const dependencies = ['typed', 'matrix', 'isInteger']; +const createConcatTransform = exports.createConcatTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + isInteger + } = _ref; + const concat = (0, _concat.createConcat)({ + typed, + matrix, + isInteger + }); + + /** + * Attach a transform function to math.range + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function concat + * from one-based to zero based + */ + return typed('concat', { + '...any': function (args) { + // change last argument from one-based to zero-based + const lastIndex = args.length - 1; + const last = args[lastIndex]; + if ((0, _is.isNumber)(last)) { + args[lastIndex] = last - 1; + } else if ((0, _is.isBigNumber)(last)) { + args[lastIndex] = last.minus(1); + } + try { + return concat.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/cumsum.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/cumsum.transform.js new file mode 100644 index 0000000..91a6b40 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/cumsum.transform.js @@ -0,0 +1,51 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCumSumTransform = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _cumsum = require("../../function/statistics/cumsum.js"); +/** + * Attach a transform function to math.sum + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function sum + * from one-based to zero based + */ +const name = 'cumsum'; +const dependencies = ['typed', 'add', 'unaryPlus']; +const createCumSumTransform = exports.createCumSumTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + unaryPlus + } = _ref; + const cumsum = (0, _cumsum.createCumSum)({ + typed, + add, + unaryPlus + }); + return typed(name, { + '...any': function (args) { + // change last argument dim from one-based to zero-based + if (args.length === 2 && (0, _is.isCollection)(args[0])) { + const dim = args[1]; + if ((0, _is.isNumber)(dim)) { + args[1] = dim - 1; + } else if ((0, _is.isBigNumber)(dim)) { + args[1] = dim.minus(1); + } + } + try { + return cumsum.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/diff.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/diff.transform.js new file mode 100644 index 0000000..dd0015e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/diff.transform.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDiffTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _diff = require("../../function/matrix/diff.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'diff'; +const dependencies = ['typed', 'matrix', 'subtract', 'number', 'bignumber']; +const createDiffTransform = exports.createDiffTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + subtract, + number, + bignumber + } = _ref; + const diff = (0, _diff.createDiff)({ + typed, + matrix, + subtract, + number, + bignumber + }); + + /** + * Attach a transform function to math.diff + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed(name, { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return diff.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/filter.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/filter.transform.js new file mode 100644 index 0000000..5b816f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/filter.transform.js @@ -0,0 +1,62 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFilterTransform = void 0; +var _filter = require("../../function/matrix/filter.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _compileInlineExpression = require("./utils/compileInlineExpression.js"); +var _transformCallback = require("./utils/transformCallback.js"); +const name = 'filter'; +const dependencies = ['typed']; +const createFilterTransform = exports.createFilterTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Attach a transform function to math.filter + * Adds a property transform containing the transform function. + * + * This transform adds support for equations as test function for math.filter, + * so you can do something like 'filter([3, -2, 5], x > 0)'. + */ + function filterTransform(args, math, scope) { + const filter = (0, _filter.createFilter)({ + typed + }); + const transformCallback = (0, _transformCallback.createTransformCallback)({ + typed + }); + if (args.length === 0) { + return filter(); + } + let x = args[0]; + if (args.length === 1) { + return filter(x); + } + const N = args.length - 1; + let callback = args[N]; + if (x) { + x = _compileAndEvaluate(x, scope); + } + if (callback) { + if ((0, _is.isSymbolNode)(callback) || (0, _is.isFunctionAssignmentNode)(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = (0, _compileInlineExpression.compileInlineExpression)(callback, math, scope); + } + } + return filter(x, transformCallback(callback, N)); + } + filterTransform.rawArgs = true; + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + return filterTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/forEach.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/forEach.transform.js new file mode 100644 index 0000000..e84c4c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/forEach.transform.js @@ -0,0 +1,61 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createForEachTransform = void 0; +var _forEach = require("../../function/matrix/forEach.js"); +var _transformCallback = require("./utils/transformCallback.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _compileInlineExpression = require("./utils/compileInlineExpression.js"); +const name = 'forEach'; +const dependencies = ['typed']; +const createForEachTransform = exports.createForEachTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Attach a transform function to math.forEach + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + const forEach = (0, _forEach.createForEach)({ + typed + }); + const transformCallback = (0, _transformCallback.createTransformCallback)({ + typed + }); + function forEachTransform(args, math, scope) { + if (args.length === 0) { + return forEach(); + } + let x = args[0]; + if (args.length === 1) { + return forEach(x); + } + const N = args.length - 1; + let callback = args[N]; + if (x) { + x = _compileAndEvaluate(x, scope); + } + if (callback) { + if ((0, _is.isSymbolNode)(callback) || (0, _is.isFunctionAssignmentNode)(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = (0, _compileInlineExpression.compileInlineExpression)(callback, math, scope); + } + } + return forEach(x, transformCallback(callback, N)); + } + forEachTransform.rawArgs = true; + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + return forEachTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/index.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/index.transform.js new file mode 100644 index 0000000..d2df23d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/index.transform.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIndexTransform = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'index'; +const dependencies = ['Index', 'getMatrixDataType']; +const createIndexTransform = exports.createIndexTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Index, + getMatrixDataType + } = _ref; + /** + * Attach a transform function to math.index + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + return function indexTransform() { + const args = []; + for (let i = 0, ii = arguments.length; i < ii; i++) { + let arg = arguments[i]; + + // change from one-based to zero based, convert BigNumber to number and leave Array of Booleans as is + if ((0, _is.isRange)(arg)) { + arg.start--; + arg.end -= arg.step > 0 ? 0 : 2; + } else if (arg && arg.isSet === true) { + arg = arg.map(function (v) { + return v - 1; + }); + } else if ((0, _is.isArray)(arg) || (0, _is.isMatrix)(arg)) { + if (getMatrixDataType(arg) !== 'boolean') { + arg = arg.map(function (v) { + return v - 1; + }); + } + } else if ((0, _is.isNumber)(arg)) { + arg--; + } else if ((0, _is.isBigNumber)(arg)) { + arg = arg.toNumber() - 1; + } else if (typeof arg === 'string') { + // leave as is + } else { + throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range'); + } + args[i] = arg; + } + const res = new Index(); + Index.apply(res, args); + return res; + }; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/map.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/map.transform.js new file mode 100644 index 0000000..152eb0d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/map.transform.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMapTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _map = require("../../function/matrix/map.js"); +var _compileInlineExpression = require("./utils/compileInlineExpression.js"); +var _transformCallback = require("./utils/transformCallback.js"); +const name = 'map'; +const dependencies = ['typed']; +const createMapTransform = exports.createMapTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Attach a transform function to math.map + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + const map = (0, _map.createMap)({ + typed + }); + const transformCallback = (0, _transformCallback.createTransformCallback)({ + typed + }); + function mapTransform(args, math, scope) { + if (args.length === 0) { + return map(); + } + if (args.length === 1) { + return map(args[0]); + } + const N = args.length - 1; + let X = args.slice(0, N); + let callback = args[N]; + X = X.map(arg => _compileAndEvaluate(arg, scope)); + if (callback) { + if ((0, _is.isSymbolNode)(callback) || (0, _is.isFunctionAssignmentNode)(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = (0, _compileInlineExpression.compileInlineExpression)(callback, math, scope); + } + } + return map(...X, transformCallback(callback, N)); + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + } + mapTransform.rawArgs = true; + return mapTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/max.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/max.transform.js new file mode 100644 index 0000000..35666ac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/max.transform.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMaxTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _max = require("../../function/statistics/max.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'max'; +const dependencies = ['typed', 'config', 'numeric', 'larger']; +const createMaxTransform = exports.createMaxTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + numeric, + larger + } = _ref; + const max = (0, _max.createMax)({ + typed, + config, + numeric, + larger + }); + + /** + * Attach a transform function to math.max + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function max + * from one-based to zero based + */ + return typed('max', { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return max.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/mean.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/mean.transform.js new file mode 100644 index 0000000..3786f73 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/mean.transform.js @@ -0,0 +1,44 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMeanTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _mean = require("../../function/statistics/mean.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'mean'; +const dependencies = ['typed', 'add', 'divide']; +const createMeanTransform = exports.createMeanTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + divide + } = _ref; + const mean = (0, _mean.createMean)({ + typed, + add, + divide + }); + + /** + * Attach a transform function to math.mean + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function mean + * from one-based to zero based + */ + return typed('mean', { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return mean.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/min.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/min.transform.js new file mode 100644 index 0000000..3548043 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/min.transform.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMinTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _min = require("../../function/statistics/min.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'min'; +const dependencies = ['typed', 'config', 'numeric', 'smaller']; +const createMinTransform = exports.createMinTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + numeric, + smaller + } = _ref; + const min = (0, _min.createMin)({ + typed, + config, + numeric, + smaller + }); + + /** + * Attach a transform function to math.min + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function min + * from one-based to zero based + */ + return typed('min', { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return min.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/or.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/or.transform.js new file mode 100644 index 0000000..08169e7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/or.transform.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createOrTransform = void 0; +var _or = require("../../function/logical/or.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'or'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +const createOrTransform = exports.createOrTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + const or = (0, _or.createOr)({ + typed, + matrix, + equalScalar, + DenseMatrix, + concat + }); + function orTransform(args, math, scope) { + const condition1 = args[0].compile().evaluate(scope); + if (!(0, _is.isCollection)(condition1) && or(condition1, false)) { + return true; + } + const condition2 = args[1].compile().evaluate(scope); + return or(condition1, condition2); + } + orTransform.rawArgs = true; + return orTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/print.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/print.transform.js new file mode 100644 index 0000000..8872817 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/print.transform.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPrintTransform = void 0; +var _print = require("../../function/string/print.js"); +var _factory = require("../../utils/factory.js"); +var _print2 = require("../../utils/print.js"); +const name = 'print'; +const dependencies = ['typed', 'matrix', 'zeros', 'add']; +const createPrintTransform = exports.createPrintTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + zeros, + add + } = _ref; + const print = (0, _print.createPrint)({ + typed, + matrix, + zeros, + add + }); + return typed(name, { + 'string, Object | Array': function (template, values) { + return print(_convertTemplateToZeroBasedIndex(template), values); + }, + 'string, Object | Array, number | Object': function (template, values, options) { + return print(_convertTemplateToZeroBasedIndex(template), values, options); + } + }); + function _convertTemplateToZeroBasedIndex(template) { + return template.replace(_print2.printTemplate, x => { + const parts = x.slice(1).split('.'); + const result = parts.map(function (part) { + if (!isNaN(part) && part.length > 0) { + return parseInt(part) - 1; + } else { + return part; + } + }); + return '$' + result.join('.'); + }); + } +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/quantileSeq.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/quantileSeq.transform.js new file mode 100644 index 0000000..1c5a5aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/quantileSeq.transform.js @@ -0,0 +1,65 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createQuantileSeqTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _quantileSeq = require("../../function/statistics/quantileSeq.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'quantileSeq'; +const dependencies = ['typed', 'bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']; + +/** + * Attach a transform function to math.quantileSeq + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function std + * from one-based to zero based + */ +const createQuantileSeqTransform = exports.createQuantileSeqTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + } = _ref; + const quantileSeq = (0, _quantileSeq.createQuantileSeq)({ + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + }); + return typed('quantileSeq', { + 'Array | Matrix, number | BigNumber': quantileSeq, + 'Array | Matrix, number | BigNumber, number': (arr, prob, dim) => quantileSeq(arr, prob, dimToZeroBase(dim)), + 'Array | Matrix, number | BigNumber, boolean': quantileSeq, + 'Array | Matrix, number | BigNumber, boolean, number': (arr, prob, sorted, dim) => quantileSeq(arr, prob, sorted, dimToZeroBase(dim)), + 'Array | Matrix, Array | Matrix': quantileSeq, + 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => quantileSeq(data, prob, dimToZeroBase(dim)), + 'Array | Matrix, Array | Matrix, boolean': quantileSeq, + 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => quantileSeq(data, prob, sorted, dimToZeroBase(dim)) + }); + function dimToZeroBase(dim) { + // TODO: find a better way, maybe lastDimToZeroBase could apply to more cases. + return (0, _lastDimToZeroBase.lastDimToZeroBase)([[], dim])[1]; + } +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/range.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/range.transform.js new file mode 100644 index 0000000..3facb04 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/range.transform.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRangeTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _range = require("../../function/matrix/range.js"); +const name = 'range'; +const dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']; +const createRangeTransform = exports.createRangeTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + } = _ref; + const range = (0, _range.createRange)({ + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + }); + + /** + * Attach a transform function to math.range + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed('range', { + '...any': function (args) { + const lastIndex = args.length - 1; + const last = args[lastIndex]; + if (typeof last !== 'boolean') { + // append a parameter includeEnd=true + args.push(true); + } + return range.apply(null, args); + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/row.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/row.transform.js new file mode 100644 index 0000000..de1844f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/row.transform.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRowTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _row = require("../../function/matrix/row.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _is = require("../../utils/is.js"); +const name = 'row'; +const dependencies = ['typed', 'Index', 'matrix', 'range']; + +/** + * Attach a transform function to matrix.column + * Adds a property transform containing the transform function. + * + * This transform changed the last `index` parameter of function column + * from zero-based to one-based + */ +const createRowTransform = exports.createRowTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Index, + matrix, + range + } = _ref; + const row = (0, _row.createRow)({ + typed, + Index, + matrix, + range + }); + + // @see: comment of row itself + return typed('row', { + '...any': function (args) { + // change last argument from zero-based to one-based + const lastIndex = args.length - 1; + const last = args[lastIndex]; + if ((0, _is.isNumber)(last)) { + args[lastIndex] = last - 1; + } + try { + return row.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/std.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/std.transform.js new file mode 100644 index 0000000..c8e5138 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/std.transform.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createStdTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _std = require("../../function/statistics/std.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'std'; +const dependencies = ['typed', 'map', 'sqrt', 'variance']; + +/** + * Attach a transform function to math.std + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function std + * from one-based to zero based + */ +const createStdTransform = exports.createStdTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + map, + sqrt, + variance + } = _ref; + const std = (0, _std.createStd)({ + typed, + map, + sqrt, + variance + }); + return typed('std', { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return std.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/subset.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/subset.transform.js new file mode 100644 index 0000000..f15ec68 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/subset.transform.js @@ -0,0 +1,43 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSubsetTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _subset = require("../../function/matrix/subset.js"); +const name = 'subset'; +const dependencies = ['typed', 'matrix', 'zeros', 'add']; +const createSubsetTransform = exports.createSubsetTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + zeros, + add + } = _ref; + const subset = (0, _subset.createSubset)({ + typed, + matrix, + zeros, + add + }); + + /** + * Attach a transform function to math.subset + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed('subset', { + '...any': function (args) { + try { + return subset.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/sum.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/sum.transform.js new file mode 100644 index 0000000..f6a6bd8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/sum.transform.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSumTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _sum = require("../../function/statistics/sum.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +/** + * Attach a transform function to math.sum + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function sum + * from one-based to zero based + */ +const name = 'sum'; +const dependencies = ['typed', 'config', 'add', 'numeric']; +const createSumTransform = exports.createSumTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + add, + numeric + } = _ref; + const sum = (0, _sum.createSum)({ + typed, + config, + add, + numeric + }); + return typed(name, { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return sum.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/compileInlineExpression.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/compileInlineExpression.js new file mode 100644 index 0000000..89b07ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/compileInlineExpression.js @@ -0,0 +1,35 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compileInlineExpression = compileInlineExpression; +var _is = require("../../../utils/is.js"); +var _map = require("../../../utils/map.js"); +/** + * Compile an inline expression like "x > 0" + * @param {Node} expression + * @param {Object} math + * @param {Map} scope + * @return {function} Returns a function with one argument which fills in the + * undefined variable (like "x") and evaluates the expression + */ +function compileInlineExpression(expression, math, scope) { + // find an undefined symbol + const symbol = expression.filter(function (node) { + return (0, _is.isSymbolNode)(node) && !(node.name in math) && !scope.has(node.name); + })[0]; + if (!symbol) { + throw new Error('No undefined variable found in inline expression "' + expression + '"'); + } + + // create a test function for this equation + const name = symbol.name; // variable name + const argsScope = new Map(); + const subScope = new _map.PartitionedMap(scope, argsScope, new Set([name])); + const eq = expression.compile(); + return function inlineExpression(x) { + argsScope.set(name, x); + return eq.evaluate(subScope); + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/dimToZeroBase.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/dimToZeroBase.js new file mode 100644 index 0000000..cbc2cc5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/dimToZeroBase.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.dimToZeroBase = dimToZeroBase; +exports.isNumberOrBigNumber = isNumberOrBigNumber; +var _is = require("../../../utils/is.js"); +/** + * Change last argument dim from one-based to zero-based. + */ +function dimToZeroBase(dim) { + if ((0, _is.isNumber)(dim)) { + return dim - 1; + } else if ((0, _is.isBigNumber)(dim)) { + return dim.minus(1); + } else { + return dim; + } +} +function isNumberOrBigNumber(n) { + return (0, _is.isNumber)(n) || (0, _is.isBigNumber)(n); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/errorTransform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/errorTransform.js new file mode 100644 index 0000000..3e85344 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/errorTransform.js @@ -0,0 +1,18 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.errorTransform = errorTransform; +var _IndexError = require("../../../error/IndexError.js"); +/** + * Transform zero-based indices to one-based indices in errors + * @param {Error} err + * @returns {Error | IndexError} Returns the transformed error + */ +function errorTransform(err) { + if (err && err.isIndexError) { + return new _IndexError.IndexError(err.index + 1, err.min + 1, err.max !== undefined ? err.max + 1 : undefined); + } + return err; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/lastDimToZeroBase.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/lastDimToZeroBase.js new file mode 100644 index 0000000..dc3cdaf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/lastDimToZeroBase.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lastDimToZeroBase = lastDimToZeroBase; +var _is = require("../../../utils/is.js"); +var _dimToZeroBase = require("./dimToZeroBase.js"); +/** + * Change last argument dim from one-based to zero-based. + */ +function lastDimToZeroBase(args) { + if (args.length === 2 && (0, _is.isCollection)(args[0])) { + args = args.slice(); + const dim = args[1]; + if ((0, _dimToZeroBase.isNumberOrBigNumber)(dim)) { + args[1] = (0, _dimToZeroBase.dimToZeroBase)(dim); + } + } + return args; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/transformCallback.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/transformCallback.js new file mode 100644 index 0000000..1fdae2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/utils/transformCallback.js @@ -0,0 +1,101 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTransformCallback = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'transformCallback'; +const dependencies = ['typed']; +const createTransformCallback = exports.createTransformCallback = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Transforms the given callback function based on its type and number of arrays. + * + * @param {Function} callback - The callback function to transform. + * @param {number} numberOfArrays - The number of arrays to pass to the callback function. + * @returns {*} - The transformed callback function. + */ + return function (callback, numberOfArrays) { + if (typed.isTypedFunction(callback)) { + return _transformTypedCallbackFunction(callback, numberOfArrays); + } else { + return _transformCallbackFunction(callback, callback.length, numberOfArrays); + } + }; + + /** + * Transforms the given typed callback function based on the number of arrays. + * + * @param {Function} typedFunction - The typed callback function to transform. + * @param {number} numberOfArrays - The number of arrays to pass to the callback function. + * @returns {*} - The transformed callback function. + */ + function _transformTypedCallbackFunction(typedFunction, numberOfArrays) { + const signatures = Object.fromEntries(Object.entries(typedFunction.signatures).map(_ref2 => { + let [signature, callbackFunction] = _ref2; + const numberOfCallbackInputs = signature.split(',').length; + if (typed.isTypedFunction(callbackFunction)) { + return [signature, _transformTypedCallbackFunction(callbackFunction, numberOfArrays)]; + } else { + return [signature, _transformCallbackFunction(callbackFunction, numberOfCallbackInputs, numberOfArrays)]; + } + })); + if (typeof typedFunction.name === 'string') { + return typed(typedFunction.name, signatures); + } else { + return typed(signatures); + } + } +}); + +/** + * Transforms the callback function based on the number of callback inputs and arrays. + * There are three cases: + * 1. The callback function has N arguments. + * 2. The callback function has N+1 arguments. + * 3. The callback function has 2N+1 arguments. + * + * @param {Function} callbackFunction - The callback function to transform. + * @param {number} numberOfCallbackInputs - The number of callback inputs. + * @param {number} numberOfArrays - The number of arrays. + * @returns {Function} The transformed callback function. + */ +function _transformCallbackFunction(callbackFunction, numberOfCallbackInputs, numberOfArrays) { + if (numberOfCallbackInputs === numberOfArrays) { + return callbackFunction; + } else if (numberOfCallbackInputs === numberOfArrays + 1) { + return function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + const vals = args.slice(0, numberOfArrays); + const idx = _transformDims(args[numberOfArrays]); + return callbackFunction(...vals, idx); + }; + } else if (numberOfCallbackInputs > numberOfArrays + 1) { + return function () { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + const vals = args.slice(0, numberOfArrays); + const idx = _transformDims(args[numberOfArrays]); + const rest = args.slice(numberOfArrays + 1); + return callbackFunction(...vals, idx, ...rest); + }; + } else { + return callbackFunction; + } +} + +/** + * Transforms the dimensions by adding 1 to each dimension. + * + * @param {Array} dims - The dimensions to transform. + * @returns {Array} The transformed dimensions. + */ +function _transformDims(dims) { + return dims.map(dim => dim + 1); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/variance.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/variance.transform.js new file mode 100644 index 0000000..1eaf44e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/expression/transform/variance.transform.js @@ -0,0 +1,52 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createVarianceTransform = void 0; +var _factory = require("../../utils/factory.js"); +var _errorTransform = require("./utils/errorTransform.js"); +var _variance = require("../../function/statistics/variance.js"); +var _lastDimToZeroBase = require("./utils/lastDimToZeroBase.js"); +const name = 'variance'; +const dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']; + +/** + * Attach a transform function to math.var + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function var + * from one-based to zero based + */ +const createVarianceTransform = exports.createVarianceTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + } = _ref; + const variance = (0, _variance.createVariance)({ + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + }); + return typed(name, { + '...any': function (args) { + args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args); + try { + return variance.apply(null, args); + } catch (err) { + throw (0, _errorTransform.errorTransform)(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesAny.js new file mode 100644 index 0000000..71b14f9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesAny.js @@ -0,0 +1,2472 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +Object.defineProperty(exports, "createAbs", { + enumerable: true, + get: function () { + return _abs.createAbs; + } +}); +Object.defineProperty(exports, "createAccessorNode", { + enumerable: true, + get: function () { + return _AccessorNode.createAccessorNode; + } +}); +Object.defineProperty(exports, "createAcos", { + enumerable: true, + get: function () { + return _acos.createAcos; + } +}); +Object.defineProperty(exports, "createAcosh", { + enumerable: true, + get: function () { + return _acosh.createAcosh; + } +}); +Object.defineProperty(exports, "createAcot", { + enumerable: true, + get: function () { + return _acot.createAcot; + } +}); +Object.defineProperty(exports, "createAcoth", { + enumerable: true, + get: function () { + return _acoth.createAcoth; + } +}); +Object.defineProperty(exports, "createAcsc", { + enumerable: true, + get: function () { + return _acsc.createAcsc; + } +}); +Object.defineProperty(exports, "createAcsch", { + enumerable: true, + get: function () { + return _acsch.createAcsch; + } +}); +Object.defineProperty(exports, "createAdd", { + enumerable: true, + get: function () { + return _add.createAdd; + } +}); +Object.defineProperty(exports, "createAddScalar", { + enumerable: true, + get: function () { + return _addScalar.createAddScalar; + } +}); +Object.defineProperty(exports, "createAnd", { + enumerable: true, + get: function () { + return _and.createAnd; + } +}); +Object.defineProperty(exports, "createAndTransform", { + enumerable: true, + get: function () { + return _andTransform.createAndTransform; + } +}); +Object.defineProperty(exports, "createApply", { + enumerable: true, + get: function () { + return _apply.createApply; + } +}); +Object.defineProperty(exports, "createApplyTransform", { + enumerable: true, + get: function () { + return _applyTransform.createApplyTransform; + } +}); +Object.defineProperty(exports, "createArg", { + enumerable: true, + get: function () { + return _arg.createArg; + } +}); +Object.defineProperty(exports, "createArrayNode", { + enumerable: true, + get: function () { + return _ArrayNode.createArrayNode; + } +}); +Object.defineProperty(exports, "createAsec", { + enumerable: true, + get: function () { + return _asec.createAsec; + } +}); +Object.defineProperty(exports, "createAsech", { + enumerable: true, + get: function () { + return _asech.createAsech; + } +}); +Object.defineProperty(exports, "createAsin", { + enumerable: true, + get: function () { + return _asin.createAsin; + } +}); +Object.defineProperty(exports, "createAsinh", { + enumerable: true, + get: function () { + return _asinh.createAsinh; + } +}); +Object.defineProperty(exports, "createAssignmentNode", { + enumerable: true, + get: function () { + return _AssignmentNode.createAssignmentNode; + } +}); +Object.defineProperty(exports, "createAtan", { + enumerable: true, + get: function () { + return _atan.createAtan; + } +}); +Object.defineProperty(exports, "createAtan2", { + enumerable: true, + get: function () { + return _atan2.createAtan2; + } +}); +Object.defineProperty(exports, "createAtanh", { + enumerable: true, + get: function () { + return _atanh.createAtanh; + } +}); +Object.defineProperty(exports, "createAtomicMass", { + enumerable: true, + get: function () { + return _physicalConstants.createAtomicMass; + } +}); +Object.defineProperty(exports, "createAvogadro", { + enumerable: true, + get: function () { + return _physicalConstants.createAvogadro; + } +}); +Object.defineProperty(exports, "createBellNumbers", { + enumerable: true, + get: function () { + return _bellNumbers.createBellNumbers; + } +}); +Object.defineProperty(exports, "createBigNumberClass", { + enumerable: true, + get: function () { + return _BigNumber.createBigNumberClass; + } +}); +Object.defineProperty(exports, "createBigint", { + enumerable: true, + get: function () { + return _bigint.createBigint; + } +}); +Object.defineProperty(exports, "createBignumber", { + enumerable: true, + get: function () { + return _bignumber.createBignumber; + } +}); +Object.defineProperty(exports, "createBin", { + enumerable: true, + get: function () { + return _bin.createBin; + } +}); +Object.defineProperty(exports, "createBitAnd", { + enumerable: true, + get: function () { + return _bitAnd.createBitAnd; + } +}); +Object.defineProperty(exports, "createBitAndTransform", { + enumerable: true, + get: function () { + return _bitAndTransform.createBitAndTransform; + } +}); +Object.defineProperty(exports, "createBitNot", { + enumerable: true, + get: function () { + return _bitNot.createBitNot; + } +}); +Object.defineProperty(exports, "createBitOr", { + enumerable: true, + get: function () { + return _bitOr.createBitOr; + } +}); +Object.defineProperty(exports, "createBitOrTransform", { + enumerable: true, + get: function () { + return _bitOrTransform.createBitOrTransform; + } +}); +Object.defineProperty(exports, "createBitXor", { + enumerable: true, + get: function () { + return _bitXor.createBitXor; + } +}); +Object.defineProperty(exports, "createBlockNode", { + enumerable: true, + get: function () { + return _BlockNode.createBlockNode; + } +}); +Object.defineProperty(exports, "createBohrMagneton", { + enumerable: true, + get: function () { + return _physicalConstants.createBohrMagneton; + } +}); +Object.defineProperty(exports, "createBohrRadius", { + enumerable: true, + get: function () { + return _physicalConstants.createBohrRadius; + } +}); +Object.defineProperty(exports, "createBoltzmann", { + enumerable: true, + get: function () { + return _physicalConstants.createBoltzmann; + } +}); +Object.defineProperty(exports, "createBoolean", { + enumerable: true, + get: function () { + return _boolean.createBoolean; + } +}); +Object.defineProperty(exports, "createCatalan", { + enumerable: true, + get: function () { + return _catalan.createCatalan; + } +}); +Object.defineProperty(exports, "createCbrt", { + enumerable: true, + get: function () { + return _cbrt.createCbrt; + } +}); +Object.defineProperty(exports, "createCeil", { + enumerable: true, + get: function () { + return _ceil.createCeil; + } +}); +Object.defineProperty(exports, "createChain", { + enumerable: true, + get: function () { + return _chain.createChain; + } +}); +Object.defineProperty(exports, "createChainClass", { + enumerable: true, + get: function () { + return _Chain.createChainClass; + } +}); +Object.defineProperty(exports, "createClassicalElectronRadius", { + enumerable: true, + get: function () { + return _physicalConstants.createClassicalElectronRadius; + } +}); +Object.defineProperty(exports, "createClone", { + enumerable: true, + get: function () { + return _clone.createClone; + } +}); +Object.defineProperty(exports, "createColumn", { + enumerable: true, + get: function () { + return _column.createColumn; + } +}); +Object.defineProperty(exports, "createColumnTransform", { + enumerable: true, + get: function () { + return _columnTransform.createColumnTransform; + } +}); +Object.defineProperty(exports, "createCombinations", { + enumerable: true, + get: function () { + return _combinations.createCombinations; + } +}); +Object.defineProperty(exports, "createCombinationsWithRep", { + enumerable: true, + get: function () { + return _combinationsWithRep.createCombinationsWithRep; + } +}); +Object.defineProperty(exports, "createCompare", { + enumerable: true, + get: function () { + return _compare.createCompare; + } +}); +Object.defineProperty(exports, "createCompareNatural", { + enumerable: true, + get: function () { + return _compareNatural.createCompareNatural; + } +}); +Object.defineProperty(exports, "createCompareText", { + enumerable: true, + get: function () { + return _compareText.createCompareText; + } +}); +Object.defineProperty(exports, "createCompile", { + enumerable: true, + get: function () { + return _compile.createCompile; + } +}); +Object.defineProperty(exports, "createComplex", { + enumerable: true, + get: function () { + return _complex.createComplex; + } +}); +Object.defineProperty(exports, "createComplexClass", { + enumerable: true, + get: function () { + return _Complex.createComplexClass; + } +}); +Object.defineProperty(exports, "createComposition", { + enumerable: true, + get: function () { + return _composition.createComposition; + } +}); +Object.defineProperty(exports, "createConcat", { + enumerable: true, + get: function () { + return _concat.createConcat; + } +}); +Object.defineProperty(exports, "createConcatTransform", { + enumerable: true, + get: function () { + return _concatTransform.createConcatTransform; + } +}); +Object.defineProperty(exports, "createConditionalNode", { + enumerable: true, + get: function () { + return _ConditionalNode.createConditionalNode; + } +}); +Object.defineProperty(exports, "createConductanceQuantum", { + enumerable: true, + get: function () { + return _physicalConstants.createConductanceQuantum; + } +}); +Object.defineProperty(exports, "createConj", { + enumerable: true, + get: function () { + return _conj.createConj; + } +}); +Object.defineProperty(exports, "createConstantNode", { + enumerable: true, + get: function () { + return _ConstantNode.createConstantNode; + } +}); +Object.defineProperty(exports, "createCorr", { + enumerable: true, + get: function () { + return _corr.createCorr; + } +}); +Object.defineProperty(exports, "createCos", { + enumerable: true, + get: function () { + return _cos.createCos; + } +}); +Object.defineProperty(exports, "createCosh", { + enumerable: true, + get: function () { + return _cosh.createCosh; + } +}); +Object.defineProperty(exports, "createCot", { + enumerable: true, + get: function () { + return _cot.createCot; + } +}); +Object.defineProperty(exports, "createCoth", { + enumerable: true, + get: function () { + return _coth.createCoth; + } +}); +Object.defineProperty(exports, "createCoulomb", { + enumerable: true, + get: function () { + return _physicalConstants.createCoulomb; + } +}); +Object.defineProperty(exports, "createCount", { + enumerable: true, + get: function () { + return _count.createCount; + } +}); +Object.defineProperty(exports, "createCreateUnit", { + enumerable: true, + get: function () { + return _createUnit.createCreateUnit; + } +}); +Object.defineProperty(exports, "createCross", { + enumerable: true, + get: function () { + return _cross.createCross; + } +}); +Object.defineProperty(exports, "createCsc", { + enumerable: true, + get: function () { + return _csc.createCsc; + } +}); +Object.defineProperty(exports, "createCsch", { + enumerable: true, + get: function () { + return _csch.createCsch; + } +}); +Object.defineProperty(exports, "createCtranspose", { + enumerable: true, + get: function () { + return _ctranspose.createCtranspose; + } +}); +Object.defineProperty(exports, "createCube", { + enumerable: true, + get: function () { + return _cube.createCube; + } +}); +Object.defineProperty(exports, "createCumSum", { + enumerable: true, + get: function () { + return _cumsum.createCumSum; + } +}); +Object.defineProperty(exports, "createCumSumTransform", { + enumerable: true, + get: function () { + return _cumsumTransform.createCumSumTransform; + } +}); +Object.defineProperty(exports, "createDeepEqual", { + enumerable: true, + get: function () { + return _deepEqual.createDeepEqual; + } +}); +Object.defineProperty(exports, "createDenseMatrixClass", { + enumerable: true, + get: function () { + return _DenseMatrix.createDenseMatrixClass; + } +}); +Object.defineProperty(exports, "createDerivative", { + enumerable: true, + get: function () { + return _derivative.createDerivative; + } +}); +Object.defineProperty(exports, "createDet", { + enumerable: true, + get: function () { + return _det.createDet; + } +}); +Object.defineProperty(exports, "createDeuteronMass", { + enumerable: true, + get: function () { + return _physicalConstants.createDeuteronMass; + } +}); +Object.defineProperty(exports, "createDiag", { + enumerable: true, + get: function () { + return _diag.createDiag; + } +}); +Object.defineProperty(exports, "createDiff", { + enumerable: true, + get: function () { + return _diff.createDiff; + } +}); +Object.defineProperty(exports, "createDiffTransform", { + enumerable: true, + get: function () { + return _diffTransform.createDiffTransform; + } +}); +Object.defineProperty(exports, "createDistance", { + enumerable: true, + get: function () { + return _distance.createDistance; + } +}); +Object.defineProperty(exports, "createDivide", { + enumerable: true, + get: function () { + return _divide.createDivide; + } +}); +Object.defineProperty(exports, "createDivideScalar", { + enumerable: true, + get: function () { + return _divideScalar.createDivideScalar; + } +}); +Object.defineProperty(exports, "createDot", { + enumerable: true, + get: function () { + return _dot.createDot; + } +}); +Object.defineProperty(exports, "createDotDivide", { + enumerable: true, + get: function () { + return _dotDivide.createDotDivide; + } +}); +Object.defineProperty(exports, "createDotMultiply", { + enumerable: true, + get: function () { + return _dotMultiply.createDotMultiply; + } +}); +Object.defineProperty(exports, "createDotPow", { + enumerable: true, + get: function () { + return _dotPow.createDotPow; + } +}); +Object.defineProperty(exports, "createE", { + enumerable: true, + get: function () { + return _constants.createE; + } +}); +Object.defineProperty(exports, "createEfimovFactor", { + enumerable: true, + get: function () { + return _physicalConstants.createEfimovFactor; + } +}); +Object.defineProperty(exports, "createEigs", { + enumerable: true, + get: function () { + return _eigs.createEigs; + } +}); +Object.defineProperty(exports, "createElectricConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createElectricConstant; + } +}); +Object.defineProperty(exports, "createElectronMass", { + enumerable: true, + get: function () { + return _physicalConstants.createElectronMass; + } +}); +Object.defineProperty(exports, "createElementaryCharge", { + enumerable: true, + get: function () { + return _physicalConstants.createElementaryCharge; + } +}); +Object.defineProperty(exports, "createEqual", { + enumerable: true, + get: function () { + return _equal.createEqual; + } +}); +Object.defineProperty(exports, "createEqualScalar", { + enumerable: true, + get: function () { + return _equalScalar.createEqualScalar; + } +}); +Object.defineProperty(exports, "createEqualText", { + enumerable: true, + get: function () { + return _equalText.createEqualText; + } +}); +Object.defineProperty(exports, "createErf", { + enumerable: true, + get: function () { + return _erf.createErf; + } +}); +Object.defineProperty(exports, "createEvaluate", { + enumerable: true, + get: function () { + return _evaluate.createEvaluate; + } +}); +Object.defineProperty(exports, "createExp", { + enumerable: true, + get: function () { + return _exp.createExp; + } +}); +Object.defineProperty(exports, "createExpm", { + enumerable: true, + get: function () { + return _expm2.createExpm; + } +}); +Object.defineProperty(exports, "createExpm1", { + enumerable: true, + get: function () { + return _expm.createExpm1; + } +}); +Object.defineProperty(exports, "createFactorial", { + enumerable: true, + get: function () { + return _factorial.createFactorial; + } +}); +Object.defineProperty(exports, "createFalse", { + enumerable: true, + get: function () { + return _constants.createFalse; + } +}); +Object.defineProperty(exports, "createFaraday", { + enumerable: true, + get: function () { + return _physicalConstants.createFaraday; + } +}); +Object.defineProperty(exports, "createFermiCoupling", { + enumerable: true, + get: function () { + return _physicalConstants.createFermiCoupling; + } +}); +Object.defineProperty(exports, "createFft", { + enumerable: true, + get: function () { + return _fft.createFft; + } +}); +Object.defineProperty(exports, "createFibonacciHeapClass", { + enumerable: true, + get: function () { + return _FibonacciHeap.createFibonacciHeapClass; + } +}); +Object.defineProperty(exports, "createFilter", { + enumerable: true, + get: function () { + return _filter.createFilter; + } +}); +Object.defineProperty(exports, "createFilterTransform", { + enumerable: true, + get: function () { + return _filterTransform.createFilterTransform; + } +}); +Object.defineProperty(exports, "createFineStructure", { + enumerable: true, + get: function () { + return _physicalConstants.createFineStructure; + } +}); +Object.defineProperty(exports, "createFirstRadiation", { + enumerable: true, + get: function () { + return _physicalConstants.createFirstRadiation; + } +}); +Object.defineProperty(exports, "createFix", { + enumerable: true, + get: function () { + return _fix.createFix; + } +}); +Object.defineProperty(exports, "createFlatten", { + enumerable: true, + get: function () { + return _flatten.createFlatten; + } +}); +Object.defineProperty(exports, "createFloor", { + enumerable: true, + get: function () { + return _floor.createFloor; + } +}); +Object.defineProperty(exports, "createForEach", { + enumerable: true, + get: function () { + return _forEach.createForEach; + } +}); +Object.defineProperty(exports, "createForEachTransform", { + enumerable: true, + get: function () { + return _forEachTransform.createForEachTransform; + } +}); +Object.defineProperty(exports, "createFormat", { + enumerable: true, + get: function () { + return _format.createFormat; + } +}); +Object.defineProperty(exports, "createFraction", { + enumerable: true, + get: function () { + return _fraction.createFraction; + } +}); +Object.defineProperty(exports, "createFractionClass", { + enumerable: true, + get: function () { + return _Fraction.createFractionClass; + } +}); +Object.defineProperty(exports, "createFreqz", { + enumerable: true, + get: function () { + return _freqz.createFreqz; + } +}); +Object.defineProperty(exports, "createFunctionAssignmentNode", { + enumerable: true, + get: function () { + return _FunctionAssignmentNode.createFunctionAssignmentNode; + } +}); +Object.defineProperty(exports, "createFunctionNode", { + enumerable: true, + get: function () { + return _FunctionNode.createFunctionNode; + } +}); +Object.defineProperty(exports, "createGamma", { + enumerable: true, + get: function () { + return _gamma.createGamma; + } +}); +Object.defineProperty(exports, "createGasConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createGasConstant; + } +}); +Object.defineProperty(exports, "createGcd", { + enumerable: true, + get: function () { + return _gcd.createGcd; + } +}); +Object.defineProperty(exports, "createGetMatrixDataType", { + enumerable: true, + get: function () { + return _getMatrixDataType.createGetMatrixDataType; + } +}); +Object.defineProperty(exports, "createGravitationConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createGravitationConstant; + } +}); +Object.defineProperty(exports, "createGravity", { + enumerable: true, + get: function () { + return _physicalConstants.createGravity; + } +}); +Object.defineProperty(exports, "createHartreeEnergy", { + enumerable: true, + get: function () { + return _physicalConstants.createHartreeEnergy; + } +}); +Object.defineProperty(exports, "createHasNumericValue", { + enumerable: true, + get: function () { + return _hasNumericValue.createHasNumericValue; + } +}); +Object.defineProperty(exports, "createHelp", { + enumerable: true, + get: function () { + return _help.createHelp; + } +}); +Object.defineProperty(exports, "createHelpClass", { + enumerable: true, + get: function () { + return _Help.createHelpClass; + } +}); +Object.defineProperty(exports, "createHex", { + enumerable: true, + get: function () { + return _hex.createHex; + } +}); +Object.defineProperty(exports, "createHypot", { + enumerable: true, + get: function () { + return _hypot.createHypot; + } +}); +Object.defineProperty(exports, "createI", { + enumerable: true, + get: function () { + return _constants.createI; + } +}); +Object.defineProperty(exports, "createIdentity", { + enumerable: true, + get: function () { + return _identity.createIdentity; + } +}); +Object.defineProperty(exports, "createIfft", { + enumerable: true, + get: function () { + return _ifft.createIfft; + } +}); +Object.defineProperty(exports, "createIm", { + enumerable: true, + get: function () { + return _im.createIm; + } +}); +Object.defineProperty(exports, "createImmutableDenseMatrixClass", { + enumerable: true, + get: function () { + return _ImmutableDenseMatrix.createImmutableDenseMatrixClass; + } +}); +Object.defineProperty(exports, "createIndex", { + enumerable: true, + get: function () { + return _index.createIndex; + } +}); +Object.defineProperty(exports, "createIndexClass", { + enumerable: true, + get: function () { + return _MatrixIndex.createIndexClass; + } +}); +Object.defineProperty(exports, "createIndexNode", { + enumerable: true, + get: function () { + return _IndexNode.createIndexNode; + } +}); +Object.defineProperty(exports, "createIndexTransform", { + enumerable: true, + get: function () { + return _indexTransform.createIndexTransform; + } +}); +Object.defineProperty(exports, "createInfinity", { + enumerable: true, + get: function () { + return _constants.createInfinity; + } +}); +Object.defineProperty(exports, "createIntersect", { + enumerable: true, + get: function () { + return _intersect.createIntersect; + } +}); +Object.defineProperty(exports, "createInv", { + enumerable: true, + get: function () { + return _inv.createInv; + } +}); +Object.defineProperty(exports, "createInverseConductanceQuantum", { + enumerable: true, + get: function () { + return _physicalConstants.createInverseConductanceQuantum; + } +}); +Object.defineProperty(exports, "createInvmod", { + enumerable: true, + get: function () { + return _invmod.createInvmod; + } +}); +Object.defineProperty(exports, "createIsInteger", { + enumerable: true, + get: function () { + return _isInteger.createIsInteger; + } +}); +Object.defineProperty(exports, "createIsNaN", { + enumerable: true, + get: function () { + return _isNaN.createIsNaN; + } +}); +Object.defineProperty(exports, "createIsNegative", { + enumerable: true, + get: function () { + return _isNegative.createIsNegative; + } +}); +Object.defineProperty(exports, "createIsNumeric", { + enumerable: true, + get: function () { + return _isNumeric.createIsNumeric; + } +}); +Object.defineProperty(exports, "createIsPositive", { + enumerable: true, + get: function () { + return _isPositive.createIsPositive; + } +}); +Object.defineProperty(exports, "createIsPrime", { + enumerable: true, + get: function () { + return _isPrime.createIsPrime; + } +}); +Object.defineProperty(exports, "createIsZero", { + enumerable: true, + get: function () { + return _isZero.createIsZero; + } +}); +Object.defineProperty(exports, "createKldivergence", { + enumerable: true, + get: function () { + return _kldivergence.createKldivergence; + } +}); +Object.defineProperty(exports, "createKlitzing", { + enumerable: true, + get: function () { + return _physicalConstants.createKlitzing; + } +}); +Object.defineProperty(exports, "createKron", { + enumerable: true, + get: function () { + return _kron.createKron; + } +}); +Object.defineProperty(exports, "createLN10", { + enumerable: true, + get: function () { + return _constants.createLN10; + } +}); +Object.defineProperty(exports, "createLN2", { + enumerable: true, + get: function () { + return _constants.createLN2; + } +}); +Object.defineProperty(exports, "createLOG10E", { + enumerable: true, + get: function () { + return _constants.createLOG10E; + } +}); +Object.defineProperty(exports, "createLOG2E", { + enumerable: true, + get: function () { + return _constants.createLOG2E; + } +}); +Object.defineProperty(exports, "createLarger", { + enumerable: true, + get: function () { + return _larger.createLarger; + } +}); +Object.defineProperty(exports, "createLargerEq", { + enumerable: true, + get: function () { + return _largerEq.createLargerEq; + } +}); +Object.defineProperty(exports, "createLcm", { + enumerable: true, + get: function () { + return _lcm.createLcm; + } +}); +Object.defineProperty(exports, "createLeafCount", { + enumerable: true, + get: function () { + return _leafCount.createLeafCount; + } +}); +Object.defineProperty(exports, "createLeftShift", { + enumerable: true, + get: function () { + return _leftShift.createLeftShift; + } +}); +Object.defineProperty(exports, "createLgamma", { + enumerable: true, + get: function () { + return _lgamma.createLgamma; + } +}); +Object.defineProperty(exports, "createLog", { + enumerable: true, + get: function () { + return _log3.createLog; + } +}); +Object.defineProperty(exports, "createLog10", { + enumerable: true, + get: function () { + return _log.createLog10; + } +}); +Object.defineProperty(exports, "createLog1p", { + enumerable: true, + get: function () { + return _log1p.createLog1p; + } +}); +Object.defineProperty(exports, "createLog2", { + enumerable: true, + get: function () { + return _log2.createLog2; + } +}); +Object.defineProperty(exports, "createLoschmidt", { + enumerable: true, + get: function () { + return _physicalConstants.createLoschmidt; + } +}); +Object.defineProperty(exports, "createLsolve", { + enumerable: true, + get: function () { + return _lsolve.createLsolve; + } +}); +Object.defineProperty(exports, "createLsolveAll", { + enumerable: true, + get: function () { + return _lsolveAll.createLsolveAll; + } +}); +Object.defineProperty(exports, "createLup", { + enumerable: true, + get: function () { + return _lup.createLup; + } +}); +Object.defineProperty(exports, "createLusolve", { + enumerable: true, + get: function () { + return _lusolve.createLusolve; + } +}); +Object.defineProperty(exports, "createLyap", { + enumerable: true, + get: function () { + return _lyap.createLyap; + } +}); +Object.defineProperty(exports, "createMad", { + enumerable: true, + get: function () { + return _mad.createMad; + } +}); +Object.defineProperty(exports, "createMagneticConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createMagneticConstant; + } +}); +Object.defineProperty(exports, "createMagneticFluxQuantum", { + enumerable: true, + get: function () { + return _physicalConstants.createMagneticFluxQuantum; + } +}); +Object.defineProperty(exports, "createMap", { + enumerable: true, + get: function () { + return _map.createMap; + } +}); +Object.defineProperty(exports, "createMapTransform", { + enumerable: true, + get: function () { + return _mapTransform.createMapTransform; + } +}); +Object.defineProperty(exports, "createMatrix", { + enumerable: true, + get: function () { + return _matrix.createMatrix; + } +}); +Object.defineProperty(exports, "createMatrixClass", { + enumerable: true, + get: function () { + return _Matrix.createMatrixClass; + } +}); +Object.defineProperty(exports, "createMatrixFromColumns", { + enumerable: true, + get: function () { + return _matrixFromColumns.createMatrixFromColumns; + } +}); +Object.defineProperty(exports, "createMatrixFromFunction", { + enumerable: true, + get: function () { + return _matrixFromFunction.createMatrixFromFunction; + } +}); +Object.defineProperty(exports, "createMatrixFromRows", { + enumerable: true, + get: function () { + return _matrixFromRows.createMatrixFromRows; + } +}); +Object.defineProperty(exports, "createMax", { + enumerable: true, + get: function () { + return _max.createMax; + } +}); +Object.defineProperty(exports, "createMaxTransform", { + enumerable: true, + get: function () { + return _maxTransform.createMaxTransform; + } +}); +Object.defineProperty(exports, "createMean", { + enumerable: true, + get: function () { + return _mean.createMean; + } +}); +Object.defineProperty(exports, "createMeanTransform", { + enumerable: true, + get: function () { + return _meanTransform.createMeanTransform; + } +}); +Object.defineProperty(exports, "createMedian", { + enumerable: true, + get: function () { + return _median.createMedian; + } +}); +Object.defineProperty(exports, "createMin", { + enumerable: true, + get: function () { + return _min.createMin; + } +}); +Object.defineProperty(exports, "createMinTransform", { + enumerable: true, + get: function () { + return _minTransform.createMinTransform; + } +}); +Object.defineProperty(exports, "createMod", { + enumerable: true, + get: function () { + return _mod.createMod; + } +}); +Object.defineProperty(exports, "createMode", { + enumerable: true, + get: function () { + return _mode.createMode; + } +}); +Object.defineProperty(exports, "createMolarMass", { + enumerable: true, + get: function () { + return _physicalConstants.createMolarMass; + } +}); +Object.defineProperty(exports, "createMolarMassC12", { + enumerable: true, + get: function () { + return _physicalConstants.createMolarMassC12; + } +}); +Object.defineProperty(exports, "createMolarPlanckConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createMolarPlanckConstant; + } +}); +Object.defineProperty(exports, "createMolarVolume", { + enumerable: true, + get: function () { + return _physicalConstants.createMolarVolume; + } +}); +Object.defineProperty(exports, "createMultinomial", { + enumerable: true, + get: function () { + return _multinomial.createMultinomial; + } +}); +Object.defineProperty(exports, "createMultiply", { + enumerable: true, + get: function () { + return _multiply.createMultiply; + } +}); +Object.defineProperty(exports, "createMultiplyScalar", { + enumerable: true, + get: function () { + return _multiplyScalar.createMultiplyScalar; + } +}); +Object.defineProperty(exports, "createNaN", { + enumerable: true, + get: function () { + return _constants.createNaN; + } +}); +Object.defineProperty(exports, "createNeutronMass", { + enumerable: true, + get: function () { + return _physicalConstants.createNeutronMass; + } +}); +Object.defineProperty(exports, "createNode", { + enumerable: true, + get: function () { + return _Node.createNode; + } +}); +Object.defineProperty(exports, "createNorm", { + enumerable: true, + get: function () { + return _norm.createNorm; + } +}); +Object.defineProperty(exports, "createNot", { + enumerable: true, + get: function () { + return _not.createNot; + } +}); +Object.defineProperty(exports, "createNthRoot", { + enumerable: true, + get: function () { + return _nthRoot.createNthRoot; + } +}); +Object.defineProperty(exports, "createNthRoots", { + enumerable: true, + get: function () { + return _nthRoots.createNthRoots; + } +}); +Object.defineProperty(exports, "createNuclearMagneton", { + enumerable: true, + get: function () { + return _physicalConstants.createNuclearMagneton; + } +}); +Object.defineProperty(exports, "createNull", { + enumerable: true, + get: function () { + return _constants.createNull; + } +}); +Object.defineProperty(exports, "createNumber", { + enumerable: true, + get: function () { + return _number.createNumber; + } +}); +Object.defineProperty(exports, "createNumeric", { + enumerable: true, + get: function () { + return _numeric.createNumeric; + } +}); +Object.defineProperty(exports, "createObjectNode", { + enumerable: true, + get: function () { + return _ObjectNode.createObjectNode; + } +}); +Object.defineProperty(exports, "createOct", { + enumerable: true, + get: function () { + return _oct.createOct; + } +}); +Object.defineProperty(exports, "createOnes", { + enumerable: true, + get: function () { + return _ones.createOnes; + } +}); +Object.defineProperty(exports, "createOperatorNode", { + enumerable: true, + get: function () { + return _OperatorNode.createOperatorNode; + } +}); +Object.defineProperty(exports, "createOr", { + enumerable: true, + get: function () { + return _or.createOr; + } +}); +Object.defineProperty(exports, "createOrTransform", { + enumerable: true, + get: function () { + return _orTransform.createOrTransform; + } +}); +Object.defineProperty(exports, "createParenthesisNode", { + enumerable: true, + get: function () { + return _ParenthesisNode.createParenthesisNode; + } +}); +Object.defineProperty(exports, "createParse", { + enumerable: true, + get: function () { + return _parse.createParse; + } +}); +Object.defineProperty(exports, "createParser", { + enumerable: true, + get: function () { + return _parser.createParser; + } +}); +Object.defineProperty(exports, "createParserClass", { + enumerable: true, + get: function () { + return _Parser.createParserClass; + } +}); +Object.defineProperty(exports, "createPartitionSelect", { + enumerable: true, + get: function () { + return _partitionSelect.createPartitionSelect; + } +}); +Object.defineProperty(exports, "createPermutations", { + enumerable: true, + get: function () { + return _permutations.createPermutations; + } +}); +Object.defineProperty(exports, "createPhi", { + enumerable: true, + get: function () { + return _constants.createPhi; + } +}); +Object.defineProperty(exports, "createPi", { + enumerable: true, + get: function () { + return _constants.createPi; + } +}); +Object.defineProperty(exports, "createPickRandom", { + enumerable: true, + get: function () { + return _pickRandom.createPickRandom; + } +}); +Object.defineProperty(exports, "createPinv", { + enumerable: true, + get: function () { + return _pinv.createPinv; + } +}); +Object.defineProperty(exports, "createPlanckCharge", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckCharge; + } +}); +Object.defineProperty(exports, "createPlanckConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckConstant; + } +}); +Object.defineProperty(exports, "createPlanckLength", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckLength; + } +}); +Object.defineProperty(exports, "createPlanckMass", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckMass; + } +}); +Object.defineProperty(exports, "createPlanckTemperature", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckTemperature; + } +}); +Object.defineProperty(exports, "createPlanckTime", { + enumerable: true, + get: function () { + return _physicalConstants.createPlanckTime; + } +}); +Object.defineProperty(exports, "createPolynomialRoot", { + enumerable: true, + get: function () { + return _polynomialRoot.createPolynomialRoot; + } +}); +Object.defineProperty(exports, "createPow", { + enumerable: true, + get: function () { + return _pow.createPow; + } +}); +Object.defineProperty(exports, "createPrint", { + enumerable: true, + get: function () { + return _print.createPrint; + } +}); +Object.defineProperty(exports, "createPrintTransform", { + enumerable: true, + get: function () { + return _printTransform.createPrintTransform; + } +}); +Object.defineProperty(exports, "createProd", { + enumerable: true, + get: function () { + return _prod.createProd; + } +}); +Object.defineProperty(exports, "createProtonMass", { + enumerable: true, + get: function () { + return _physicalConstants.createProtonMass; + } +}); +Object.defineProperty(exports, "createQr", { + enumerable: true, + get: function () { + return _qr.createQr; + } +}); +Object.defineProperty(exports, "createQuantileSeq", { + enumerable: true, + get: function () { + return _quantileSeq.createQuantileSeq; + } +}); +Object.defineProperty(exports, "createQuantileSeqTransform", { + enumerable: true, + get: function () { + return _quantileSeqTransform.createQuantileSeqTransform; + } +}); +Object.defineProperty(exports, "createQuantumOfCirculation", { + enumerable: true, + get: function () { + return _physicalConstants.createQuantumOfCirculation; + } +}); +Object.defineProperty(exports, "createRandom", { + enumerable: true, + get: function () { + return _random.createRandom; + } +}); +Object.defineProperty(exports, "createRandomInt", { + enumerable: true, + get: function () { + return _randomInt.createRandomInt; + } +}); +Object.defineProperty(exports, "createRange", { + enumerable: true, + get: function () { + return _range.createRange; + } +}); +Object.defineProperty(exports, "createRangeClass", { + enumerable: true, + get: function () { + return _Range.createRangeClass; + } +}); +Object.defineProperty(exports, "createRangeNode", { + enumerable: true, + get: function () { + return _RangeNode.createRangeNode; + } +}); +Object.defineProperty(exports, "createRangeTransform", { + enumerable: true, + get: function () { + return _rangeTransform.createRangeTransform; + } +}); +Object.defineProperty(exports, "createRationalize", { + enumerable: true, + get: function () { + return _rationalize.createRationalize; + } +}); +Object.defineProperty(exports, "createRe", { + enumerable: true, + get: function () { + return _re.createRe; + } +}); +Object.defineProperty(exports, "createReducedPlanckConstant", { + enumerable: true, + get: function () { + return _physicalConstants.createReducedPlanckConstant; + } +}); +Object.defineProperty(exports, "createRelationalNode", { + enumerable: true, + get: function () { + return _RelationalNode.createRelationalNode; + } +}); +Object.defineProperty(exports, "createReplacer", { + enumerable: true, + get: function () { + return _replacer.createReplacer; + } +}); +Object.defineProperty(exports, "createReshape", { + enumerable: true, + get: function () { + return _reshape.createReshape; + } +}); +Object.defineProperty(exports, "createResize", { + enumerable: true, + get: function () { + return _resize.createResize; + } +}); +Object.defineProperty(exports, "createResolve", { + enumerable: true, + get: function () { + return _resolve.createResolve; + } +}); +Object.defineProperty(exports, "createResultSet", { + enumerable: true, + get: function () { + return _ResultSet.createResultSet; + } +}); +Object.defineProperty(exports, "createReviver", { + enumerable: true, + get: function () { + return _reviver.createReviver; + } +}); +Object.defineProperty(exports, "createRightArithShift", { + enumerable: true, + get: function () { + return _rightArithShift.createRightArithShift; + } +}); +Object.defineProperty(exports, "createRightLogShift", { + enumerable: true, + get: function () { + return _rightLogShift.createRightLogShift; + } +}); +Object.defineProperty(exports, "createRotate", { + enumerable: true, + get: function () { + return _rotate.createRotate; + } +}); +Object.defineProperty(exports, "createRotationMatrix", { + enumerable: true, + get: function () { + return _rotationMatrix.createRotationMatrix; + } +}); +Object.defineProperty(exports, "createRound", { + enumerable: true, + get: function () { + return _round.createRound; + } +}); +Object.defineProperty(exports, "createRow", { + enumerable: true, + get: function () { + return _row.createRow; + } +}); +Object.defineProperty(exports, "createRowTransform", { + enumerable: true, + get: function () { + return _rowTransform.createRowTransform; + } +}); +Object.defineProperty(exports, "createRydberg", { + enumerable: true, + get: function () { + return _physicalConstants.createRydberg; + } +}); +Object.defineProperty(exports, "createSQRT1_2", { + enumerable: true, + get: function () { + return _constants.createSQRT1_2; + } +}); +Object.defineProperty(exports, "createSQRT2", { + enumerable: true, + get: function () { + return _constants.createSQRT2; + } +}); +Object.defineProperty(exports, "createSackurTetrode", { + enumerable: true, + get: function () { + return _physicalConstants.createSackurTetrode; + } +}); +Object.defineProperty(exports, "createSchur", { + enumerable: true, + get: function () { + return _schur.createSchur; + } +}); +Object.defineProperty(exports, "createSec", { + enumerable: true, + get: function () { + return _sec.createSec; + } +}); +Object.defineProperty(exports, "createSech", { + enumerable: true, + get: function () { + return _sech.createSech; + } +}); +Object.defineProperty(exports, "createSecondRadiation", { + enumerable: true, + get: function () { + return _physicalConstants.createSecondRadiation; + } +}); +Object.defineProperty(exports, "createSetCartesian", { + enumerable: true, + get: function () { + return _setCartesian.createSetCartesian; + } +}); +Object.defineProperty(exports, "createSetDifference", { + enumerable: true, + get: function () { + return _setDifference.createSetDifference; + } +}); +Object.defineProperty(exports, "createSetDistinct", { + enumerable: true, + get: function () { + return _setDistinct.createSetDistinct; + } +}); +Object.defineProperty(exports, "createSetIntersect", { + enumerable: true, + get: function () { + return _setIntersect.createSetIntersect; + } +}); +Object.defineProperty(exports, "createSetIsSubset", { + enumerable: true, + get: function () { + return _setIsSubset.createSetIsSubset; + } +}); +Object.defineProperty(exports, "createSetMultiplicity", { + enumerable: true, + get: function () { + return _setMultiplicity.createSetMultiplicity; + } +}); +Object.defineProperty(exports, "createSetPowerset", { + enumerable: true, + get: function () { + return _setPowerset.createSetPowerset; + } +}); +Object.defineProperty(exports, "createSetSize", { + enumerable: true, + get: function () { + return _setSize.createSetSize; + } +}); +Object.defineProperty(exports, "createSetSymDifference", { + enumerable: true, + get: function () { + return _setSymDifference.createSetSymDifference; + } +}); +Object.defineProperty(exports, "createSetUnion", { + enumerable: true, + get: function () { + return _setUnion.createSetUnion; + } +}); +Object.defineProperty(exports, "createSign", { + enumerable: true, + get: function () { + return _sign.createSign; + } +}); +Object.defineProperty(exports, "createSimplify", { + enumerable: true, + get: function () { + return _simplify.createSimplify; + } +}); +Object.defineProperty(exports, "createSimplifyConstant", { + enumerable: true, + get: function () { + return _simplifyConstant.createSimplifyConstant; + } +}); +Object.defineProperty(exports, "createSimplifyCore", { + enumerable: true, + get: function () { + return _simplifyCore.createSimplifyCore; + } +}); +Object.defineProperty(exports, "createSin", { + enumerable: true, + get: function () { + return _sin.createSin; + } +}); +Object.defineProperty(exports, "createSinh", { + enumerable: true, + get: function () { + return _sinh.createSinh; + } +}); +Object.defineProperty(exports, "createSize", { + enumerable: true, + get: function () { + return _size.createSize; + } +}); +Object.defineProperty(exports, "createSlu", { + enumerable: true, + get: function () { + return _slu.createSlu; + } +}); +Object.defineProperty(exports, "createSmaller", { + enumerable: true, + get: function () { + return _smaller.createSmaller; + } +}); +Object.defineProperty(exports, "createSmallerEq", { + enumerable: true, + get: function () { + return _smallerEq.createSmallerEq; + } +}); +Object.defineProperty(exports, "createSolveODE", { + enumerable: true, + get: function () { + return _solveODE.createSolveODE; + } +}); +Object.defineProperty(exports, "createSort", { + enumerable: true, + get: function () { + return _sort.createSort; + } +}); +Object.defineProperty(exports, "createSpaClass", { + enumerable: true, + get: function () { + return _Spa.createSpaClass; + } +}); +Object.defineProperty(exports, "createSparse", { + enumerable: true, + get: function () { + return _sparse.createSparse; + } +}); +Object.defineProperty(exports, "createSparseMatrixClass", { + enumerable: true, + get: function () { + return _SparseMatrix.createSparseMatrixClass; + } +}); +Object.defineProperty(exports, "createSpeedOfLight", { + enumerable: true, + get: function () { + return _physicalConstants.createSpeedOfLight; + } +}); +Object.defineProperty(exports, "createSplitUnit", { + enumerable: true, + get: function () { + return _splitUnit.createSplitUnit; + } +}); +Object.defineProperty(exports, "createSqrt", { + enumerable: true, + get: function () { + return _sqrt.createSqrt; + } +}); +Object.defineProperty(exports, "createSqrtm", { + enumerable: true, + get: function () { + return _sqrtm.createSqrtm; + } +}); +Object.defineProperty(exports, "createSquare", { + enumerable: true, + get: function () { + return _square.createSquare; + } +}); +Object.defineProperty(exports, "createSqueeze", { + enumerable: true, + get: function () { + return _squeeze.createSqueeze; + } +}); +Object.defineProperty(exports, "createStd", { + enumerable: true, + get: function () { + return _std.createStd; + } +}); +Object.defineProperty(exports, "createStdTransform", { + enumerable: true, + get: function () { + return _stdTransform.createStdTransform; + } +}); +Object.defineProperty(exports, "createStefanBoltzmann", { + enumerable: true, + get: function () { + return _physicalConstants.createStefanBoltzmann; + } +}); +Object.defineProperty(exports, "createStirlingS2", { + enumerable: true, + get: function () { + return _stirlingS.createStirlingS2; + } +}); +Object.defineProperty(exports, "createString", { + enumerable: true, + get: function () { + return _string.createString; + } +}); +Object.defineProperty(exports, "createSubset", { + enumerable: true, + get: function () { + return _subset.createSubset; + } +}); +Object.defineProperty(exports, "createSubsetTransform", { + enumerable: true, + get: function () { + return _subsetTransform.createSubsetTransform; + } +}); +Object.defineProperty(exports, "createSubtract", { + enumerable: true, + get: function () { + return _subtract.createSubtract; + } +}); +Object.defineProperty(exports, "createSubtractScalar", { + enumerable: true, + get: function () { + return _subtractScalar.createSubtractScalar; + } +}); +Object.defineProperty(exports, "createSum", { + enumerable: true, + get: function () { + return _sum.createSum; + } +}); +Object.defineProperty(exports, "createSumTransform", { + enumerable: true, + get: function () { + return _sumTransform.createSumTransform; + } +}); +Object.defineProperty(exports, "createSylvester", { + enumerable: true, + get: function () { + return _sylvester.createSylvester; + } +}); +Object.defineProperty(exports, "createSymbolNode", { + enumerable: true, + get: function () { + return _SymbolNode.createSymbolNode; + } +}); +Object.defineProperty(exports, "createSymbolicEqual", { + enumerable: true, + get: function () { + return _symbolicEqual.createSymbolicEqual; + } +}); +Object.defineProperty(exports, "createTan", { + enumerable: true, + get: function () { + return _tan.createTan; + } +}); +Object.defineProperty(exports, "createTanh", { + enumerable: true, + get: function () { + return _tanh.createTanh; + } +}); +Object.defineProperty(exports, "createTau", { + enumerable: true, + get: function () { + return _constants.createTau; + } +}); +Object.defineProperty(exports, "createThomsonCrossSection", { + enumerable: true, + get: function () { + return _physicalConstants.createThomsonCrossSection; + } +}); +Object.defineProperty(exports, "createTo", { + enumerable: true, + get: function () { + return _to.createTo; + } +}); +Object.defineProperty(exports, "createTrace", { + enumerable: true, + get: function () { + return _trace.createTrace; + } +}); +Object.defineProperty(exports, "createTranspose", { + enumerable: true, + get: function () { + return _transpose.createTranspose; + } +}); +Object.defineProperty(exports, "createTrue", { + enumerable: true, + get: function () { + return _constants.createTrue; + } +}); +Object.defineProperty(exports, "createTypeOf", { + enumerable: true, + get: function () { + return _typeOf.createTypeOf; + } +}); +Object.defineProperty(exports, "createTyped", { + enumerable: true, + get: function () { + return _typed.createTyped; + } +}); +Object.defineProperty(exports, "createUnaryMinus", { + enumerable: true, + get: function () { + return _unaryMinus.createUnaryMinus; + } +}); +Object.defineProperty(exports, "createUnaryPlus", { + enumerable: true, + get: function () { + return _unaryPlus.createUnaryPlus; + } +}); +Object.defineProperty(exports, "createUnequal", { + enumerable: true, + get: function () { + return _unequal.createUnequal; + } +}); +Object.defineProperty(exports, "createUnitClass", { + enumerable: true, + get: function () { + return _Unit.createUnitClass; + } +}); +Object.defineProperty(exports, "createUnitFunction", { + enumerable: true, + get: function () { + return _unit.createUnitFunction; + } +}); +Object.defineProperty(exports, "createUppercaseE", { + enumerable: true, + get: function () { + return _constants.createUppercaseE; + } +}); +Object.defineProperty(exports, "createUppercasePi", { + enumerable: true, + get: function () { + return _constants.createUppercasePi; + } +}); +Object.defineProperty(exports, "createUsolve", { + enumerable: true, + get: function () { + return _usolve.createUsolve; + } +}); +Object.defineProperty(exports, "createUsolveAll", { + enumerable: true, + get: function () { + return _usolveAll.createUsolveAll; + } +}); +Object.defineProperty(exports, "createVacuumImpedance", { + enumerable: true, + get: function () { + return _physicalConstants.createVacuumImpedance; + } +}); +Object.defineProperty(exports, "createVariance", { + enumerable: true, + get: function () { + return _variance.createVariance; + } +}); +Object.defineProperty(exports, "createVarianceTransform", { + enumerable: true, + get: function () { + return _varianceTransform.createVarianceTransform; + } +}); +Object.defineProperty(exports, "createVersion", { + enumerable: true, + get: function () { + return _constants.createVersion; + } +}); +Object.defineProperty(exports, "createWeakMixingAngle", { + enumerable: true, + get: function () { + return _physicalConstants.createWeakMixingAngle; + } +}); +Object.defineProperty(exports, "createWienDisplacement", { + enumerable: true, + get: function () { + return _physicalConstants.createWienDisplacement; + } +}); +Object.defineProperty(exports, "createXgcd", { + enumerable: true, + get: function () { + return _xgcd.createXgcd; + } +}); +Object.defineProperty(exports, "createXor", { + enumerable: true, + get: function () { + return _xor.createXor; + } +}); +Object.defineProperty(exports, "createZeros", { + enumerable: true, + get: function () { + return _zeros.createZeros; + } +}); +Object.defineProperty(exports, "createZeta", { + enumerable: true, + get: function () { + return _zeta.createZeta; + } +}); +Object.defineProperty(exports, "createZpk2tf", { + enumerable: true, + get: function () { + return _zpk2tf.createZpk2tf; + } +}); +var _typed = require("./core/function/typed.js"); +var _ResultSet = require("./type/resultset/ResultSet.js"); +var _BigNumber = require("./type/bignumber/BigNumber.js"); +var _Complex = require("./type/complex/Complex.js"); +var _Fraction = require("./type/fraction/Fraction.js"); +var _Range = require("./type/matrix/Range.js"); +var _Matrix = require("./type/matrix/Matrix.js"); +var _DenseMatrix = require("./type/matrix/DenseMatrix.js"); +var _clone = require("./function/utils/clone.js"); +var _isInteger = require("./function/utils/isInteger.js"); +var _isNegative = require("./function/utils/isNegative.js"); +var _isNumeric = require("./function/utils/isNumeric.js"); +var _hasNumericValue = require("./function/utils/hasNumericValue.js"); +var _isPositive = require("./function/utils/isPositive.js"); +var _isZero = require("./function/utils/isZero.js"); +var _isNaN = require("./function/utils/isNaN.js"); +var _typeOf = require("./function/utils/typeOf.js"); +var _equalScalar = require("./function/relational/equalScalar.js"); +var _SparseMatrix = require("./type/matrix/SparseMatrix.js"); +var _number = require("./type/number.js"); +var _bigint = require("./type/bigint.js"); +var _string = require("./type/string.js"); +var _boolean = require("./type/boolean.js"); +var _bignumber = require("./type/bignumber/function/bignumber.js"); +var _complex = require("./type/complex/function/complex.js"); +var _fraction = require("./type/fraction/function/fraction.js"); +var _matrix = require("./type/matrix/function/matrix.js"); +var _matrixFromFunction = require("./function/matrix/matrixFromFunction.js"); +var _matrixFromRows = require("./function/matrix/matrixFromRows.js"); +var _matrixFromColumns = require("./function/matrix/matrixFromColumns.js"); +var _splitUnit = require("./type/unit/function/splitUnit.js"); +var _unaryMinus = require("./function/arithmetic/unaryMinus.js"); +var _unaryPlus = require("./function/arithmetic/unaryPlus.js"); +var _abs = require("./function/arithmetic/abs.js"); +var _apply = require("./function/matrix/apply.js"); +var _addScalar = require("./function/arithmetic/addScalar.js"); +var _subtractScalar = require("./function/arithmetic/subtractScalar.js"); +var _cbrt = require("./function/arithmetic/cbrt.js"); +var _ceil = require("./function/arithmetic/ceil.js"); +var _cube = require("./function/arithmetic/cube.js"); +var _exp = require("./function/arithmetic/exp.js"); +var _expm = require("./function/arithmetic/expm1.js"); +var _fix = require("./function/arithmetic/fix.js"); +var _floor = require("./function/arithmetic/floor.js"); +var _gcd = require("./function/arithmetic/gcd.js"); +var _lcm = require("./function/arithmetic/lcm.js"); +var _log = require("./function/arithmetic/log10.js"); +var _log2 = require("./function/arithmetic/log2.js"); +var _mod = require("./function/arithmetic/mod.js"); +var _multiplyScalar = require("./function/arithmetic/multiplyScalar.js"); +var _multiply = require("./function/arithmetic/multiply.js"); +var _nthRoot = require("./function/arithmetic/nthRoot.js"); +var _sign = require("./function/arithmetic/sign.js"); +var _sqrt = require("./function/arithmetic/sqrt.js"); +var _square = require("./function/arithmetic/square.js"); +var _subtract = require("./function/arithmetic/subtract.js"); +var _xgcd = require("./function/arithmetic/xgcd.js"); +var _invmod = require("./function/arithmetic/invmod.js"); +var _dotMultiply = require("./function/arithmetic/dotMultiply.js"); +var _bitAnd = require("./function/bitwise/bitAnd.js"); +var _bitNot = require("./function/bitwise/bitNot.js"); +var _bitOr = require("./function/bitwise/bitOr.js"); +var _bitXor = require("./function/bitwise/bitXor.js"); +var _arg = require("./function/complex/arg.js"); +var _conj = require("./function/complex/conj.js"); +var _im = require("./function/complex/im.js"); +var _re = require("./function/complex/re.js"); +var _not = require("./function/logical/not.js"); +var _or = require("./function/logical/or.js"); +var _xor = require("./function/logical/xor.js"); +var _concat = require("./function/matrix/concat.js"); +var _column = require("./function/matrix/column.js"); +var _count = require("./function/matrix/count.js"); +var _cross = require("./function/matrix/cross.js"); +var _diag = require("./function/matrix/diag.js"); +var _filter = require("./function/matrix/filter.js"); +var _flatten = require("./function/matrix/flatten.js"); +var _forEach = require("./function/matrix/forEach.js"); +var _getMatrixDataType = require("./function/matrix/getMatrixDataType.js"); +var _identity = require("./function/matrix/identity.js"); +var _kron = require("./function/matrix/kron.js"); +var _map = require("./function/matrix/map.js"); +var _diff = require("./function/matrix/diff.js"); +var _ones = require("./function/matrix/ones.js"); +var _range = require("./function/matrix/range.js"); +var _reshape = require("./function/matrix/reshape.js"); +var _resize = require("./function/matrix/resize.js"); +var _rotate = require("./function/matrix/rotate.js"); +var _rotationMatrix = require("./function/matrix/rotationMatrix.js"); +var _row = require("./function/matrix/row.js"); +var _size = require("./function/matrix/size.js"); +var _squeeze = require("./function/matrix/squeeze.js"); +var _subset = require("./function/matrix/subset.js"); +var _transpose = require("./function/matrix/transpose.js"); +var _ctranspose = require("./function/matrix/ctranspose.js"); +var _zeros = require("./function/matrix/zeros.js"); +var _fft = require("./function/matrix/fft.js"); +var _ifft = require("./function/matrix/ifft.js"); +var _solveODE = require("./function/numeric/solveODE.js"); +var _erf = require("./function/special/erf.js"); +var _zeta = require("./function/special/zeta.js"); +var _mode = require("./function/statistics/mode.js"); +var _prod = require("./function/statistics/prod.js"); +var _format = require("./function/string/format.js"); +var _bin = require("./function/string/bin.js"); +var _oct = require("./function/string/oct.js"); +var _hex = require("./function/string/hex.js"); +var _print = require("./function/string/print.js"); +var _to = require("./function/unit/to.js"); +var _isPrime = require("./function/utils/isPrime.js"); +var _numeric = require("./function/utils/numeric.js"); +var _divideScalar = require("./function/arithmetic/divideScalar.js"); +var _pow = require("./function/arithmetic/pow.js"); +var _round = require("./function/arithmetic/round.js"); +var _log3 = require("./function/arithmetic/log.js"); +var _log1p = require("./function/arithmetic/log1p.js"); +var _nthRoots = require("./function/arithmetic/nthRoots.js"); +var _dotPow = require("./function/arithmetic/dotPow.js"); +var _dotDivide = require("./function/arithmetic/dotDivide.js"); +var _lsolve = require("./function/algebra/solver/lsolve.js"); +var _usolve = require("./function/algebra/solver/usolve.js"); +var _lsolveAll = require("./function/algebra/solver/lsolveAll.js"); +var _usolveAll = require("./function/algebra/solver/usolveAll.js"); +var _leftShift = require("./function/bitwise/leftShift.js"); +var _rightArithShift = require("./function/bitwise/rightArithShift.js"); +var _rightLogShift = require("./function/bitwise/rightLogShift.js"); +var _and = require("./function/logical/and.js"); +var _compare = require("./function/relational/compare.js"); +var _compareNatural = require("./function/relational/compareNatural.js"); +var _compareText = require("./function/relational/compareText.js"); +var _equal = require("./function/relational/equal.js"); +var _equalText = require("./function/relational/equalText.js"); +var _smaller = require("./function/relational/smaller.js"); +var _smallerEq = require("./function/relational/smallerEq.js"); +var _larger = require("./function/relational/larger.js"); +var _largerEq = require("./function/relational/largerEq.js"); +var _deepEqual = require("./function/relational/deepEqual.js"); +var _unequal = require("./function/relational/unequal.js"); +var _partitionSelect = require("./function/matrix/partitionSelect.js"); +var _sort = require("./function/matrix/sort.js"); +var _max = require("./function/statistics/max.js"); +var _min = require("./function/statistics/min.js"); +var _ImmutableDenseMatrix = require("./type/matrix/ImmutableDenseMatrix.js"); +var _MatrixIndex = require("./type/matrix/MatrixIndex.js"); +var _FibonacciHeap = require("./type/matrix/FibonacciHeap.js"); +var _Spa = require("./type/matrix/Spa.js"); +var _Unit = require("./type/unit/Unit.js"); +var _unit = require("./type/unit/function/unit.js"); +var _sparse = require("./type/matrix/function/sparse.js"); +var _createUnit = require("./type/unit/function/createUnit.js"); +var _acos = require("./function/trigonometry/acos.js"); +var _acosh = require("./function/trigonometry/acosh.js"); +var _acot = require("./function/trigonometry/acot.js"); +var _acoth = require("./function/trigonometry/acoth.js"); +var _acsc = require("./function/trigonometry/acsc.js"); +var _acsch = require("./function/trigonometry/acsch.js"); +var _asec = require("./function/trigonometry/asec.js"); +var _asech = require("./function/trigonometry/asech.js"); +var _asin = require("./function/trigonometry/asin.js"); +var _asinh = require("./function/trigonometry/asinh.js"); +var _atan = require("./function/trigonometry/atan.js"); +var _atan2 = require("./function/trigonometry/atan2.js"); +var _atanh = require("./function/trigonometry/atanh.js"); +var _cos = require("./function/trigonometry/cos.js"); +var _cosh = require("./function/trigonometry/cosh.js"); +var _cot = require("./function/trigonometry/cot.js"); +var _coth = require("./function/trigonometry/coth.js"); +var _csc = require("./function/trigonometry/csc.js"); +var _csch = require("./function/trigonometry/csch.js"); +var _sec = require("./function/trigonometry/sec.js"); +var _sech = require("./function/trigonometry/sech.js"); +var _sin = require("./function/trigonometry/sin.js"); +var _sinh = require("./function/trigonometry/sinh.js"); +var _tan = require("./function/trigonometry/tan.js"); +var _tanh = require("./function/trigonometry/tanh.js"); +var _setCartesian = require("./function/set/setCartesian.js"); +var _setDifference = require("./function/set/setDifference.js"); +var _setDistinct = require("./function/set/setDistinct.js"); +var _setIntersect = require("./function/set/setIntersect.js"); +var _setIsSubset = require("./function/set/setIsSubset.js"); +var _setMultiplicity = require("./function/set/setMultiplicity.js"); +var _setPowerset = require("./function/set/setPowerset.js"); +var _setSize = require("./function/set/setSize.js"); +var _setSymDifference = require("./function/set/setSymDifference.js"); +var _setUnion = require("./function/set/setUnion.js"); +var _add = require("./function/arithmetic/add.js"); +var _hypot = require("./function/arithmetic/hypot.js"); +var _norm = require("./function/arithmetic/norm.js"); +var _dot = require("./function/matrix/dot.js"); +var _trace = require("./function/matrix/trace.js"); +var _index = require("./type/matrix/function/index.js"); +var _Node = require("./expression/node/Node.js"); +var _AccessorNode = require("./expression/node/AccessorNode.js"); +var _ArrayNode = require("./expression/node/ArrayNode.js"); +var _AssignmentNode = require("./expression/node/AssignmentNode.js"); +var _BlockNode = require("./expression/node/BlockNode.js"); +var _ConditionalNode = require("./expression/node/ConditionalNode.js"); +var _ConstantNode = require("./expression/node/ConstantNode.js"); +var _FunctionAssignmentNode = require("./expression/node/FunctionAssignmentNode.js"); +var _IndexNode = require("./expression/node/IndexNode.js"); +var _ObjectNode = require("./expression/node/ObjectNode.js"); +var _OperatorNode = require("./expression/node/OperatorNode.js"); +var _ParenthesisNode = require("./expression/node/ParenthesisNode.js"); +var _RangeNode = require("./expression/node/RangeNode.js"); +var _RelationalNode = require("./expression/node/RelationalNode.js"); +var _SymbolNode = require("./expression/node/SymbolNode.js"); +var _FunctionNode = require("./expression/node/FunctionNode.js"); +var _parse = require("./expression/parse.js"); +var _compile = require("./expression/function/compile.js"); +var _evaluate = require("./expression/function/evaluate.js"); +var _Parser = require("./expression/Parser.js"); +var _parser = require("./expression/function/parser.js"); +var _lup = require("./function/algebra/decomposition/lup.js"); +var _qr = require("./function/algebra/decomposition/qr.js"); +var _slu = require("./function/algebra/decomposition/slu.js"); +var _lusolve = require("./function/algebra/solver/lusolve.js"); +var _polynomialRoot = require("./function/algebra/polynomialRoot.js"); +var _Help = require("./expression/Help.js"); +var _Chain = require("./type/chain/Chain.js"); +var _help = require("./expression/function/help.js"); +var _chain = require("./type/chain/function/chain.js"); +var _det = require("./function/matrix/det.js"); +var _inv = require("./function/matrix/inv.js"); +var _pinv = require("./function/matrix/pinv.js"); +var _eigs = require("./function/matrix/eigs.js"); +var _expm2 = require("./function/matrix/expm.js"); +var _sqrtm = require("./function/matrix/sqrtm.js"); +var _sylvester = require("./function/algebra/sylvester.js"); +var _schur = require("./function/algebra/decomposition/schur.js"); +var _lyap = require("./function/algebra/lyap.js"); +var _divide = require("./function/arithmetic/divide.js"); +var _distance = require("./function/geometry/distance.js"); +var _intersect = require("./function/geometry/intersect.js"); +var _sum = require("./function/statistics/sum.js"); +var _cumsum = require("./function/statistics/cumsum.js"); +var _mean = require("./function/statistics/mean.js"); +var _median = require("./function/statistics/median.js"); +var _mad = require("./function/statistics/mad.js"); +var _variance = require("./function/statistics/variance.js"); +var _quantileSeq = require("./function/statistics/quantileSeq.js"); +var _std = require("./function/statistics/std.js"); +var _corr = require("./function/statistics/corr.js"); +var _combinations = require("./function/probability/combinations.js"); +var _combinationsWithRep = require("./function/probability/combinationsWithRep.js"); +var _gamma = require("./function/probability/gamma.js"); +var _lgamma = require("./function/probability/lgamma.js"); +var _factorial = require("./function/probability/factorial.js"); +var _kldivergence = require("./function/probability/kldivergence.js"); +var _multinomial = require("./function/probability/multinomial.js"); +var _permutations = require("./function/probability/permutations.js"); +var _pickRandom = require("./function/probability/pickRandom.js"); +var _random = require("./function/probability/random.js"); +var _randomInt = require("./function/probability/randomInt.js"); +var _stirlingS = require("./function/combinatorics/stirlingS2.js"); +var _bellNumbers = require("./function/combinatorics/bellNumbers.js"); +var _catalan = require("./function/combinatorics/catalan.js"); +var _composition = require("./function/combinatorics/composition.js"); +var _leafCount = require("./function/algebra/leafCount.js"); +var _simplify = require("./function/algebra/simplify.js"); +var _simplifyConstant = require("./function/algebra/simplifyConstant.js"); +var _simplifyCore = require("./function/algebra/simplifyCore.js"); +var _resolve = require("./function/algebra/resolve.js"); +var _symbolicEqual = require("./function/algebra/symbolicEqual.js"); +var _derivative = require("./function/algebra/derivative.js"); +var _rationalize = require("./function/algebra/rationalize.js"); +var _zpk2tf = require("./function/signal/zpk2tf.js"); +var _freqz = require("./function/signal/freqz.js"); +var _reviver = require("./json/reviver.js"); +var _replacer = require("./json/replacer.js"); +var _constants = require("./constants.js"); +var _physicalConstants = require("./type/unit/physicalConstants.js"); +var _applyTransform = require("./expression/transform/apply.transform.js"); +var _columnTransform = require("./expression/transform/column.transform.js"); +var _filterTransform = require("./expression/transform/filter.transform.js"); +var _forEachTransform = require("./expression/transform/forEach.transform.js"); +var _indexTransform = require("./expression/transform/index.transform.js"); +var _mapTransform = require("./expression/transform/map.transform.js"); +var _maxTransform = require("./expression/transform/max.transform.js"); +var _meanTransform = require("./expression/transform/mean.transform.js"); +var _minTransform = require("./expression/transform/min.transform.js"); +var _rangeTransform = require("./expression/transform/range.transform.js"); +var _rowTransform = require("./expression/transform/row.transform.js"); +var _subsetTransform = require("./expression/transform/subset.transform.js"); +var _concatTransform = require("./expression/transform/concat.transform.js"); +var _diffTransform = require("./expression/transform/diff.transform.js"); +var _stdTransform = require("./expression/transform/std.transform.js"); +var _sumTransform = require("./expression/transform/sum.transform.js"); +var _quantileSeqTransform = require("./expression/transform/quantileSeq.transform.js"); +var _cumsumTransform = require("./expression/transform/cumsum.transform.js"); +var _varianceTransform = require("./expression/transform/variance.transform.js"); +var _printTransform = require("./expression/transform/print.transform.js"); +var _andTransform = require("./expression/transform/and.transform.js"); +var _orTransform = require("./expression/transform/or.transform.js"); +var _bitAndTransform = require("./expression/transform/bitAnd.transform.js"); +var _bitOrTransform = require("./expression/transform/bitOr.transform.js"); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesNumber.js new file mode 100644 index 0000000..01a8f83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/factoriesNumber.js @@ -0,0 +1,1062 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAbs = void 0; +Object.defineProperty(exports, "createAccessorNode", { + enumerable: true, + get: function () { + return _AccessorNode.createAccessorNode; + } +}); +exports.createAnd = exports.createAddScalar = exports.createAdd = exports.createAcsch = exports.createAcsc = exports.createAcoth = exports.createAcot = exports.createAcosh = exports.createAcos = void 0; +Object.defineProperty(exports, "createApply", { + enumerable: true, + get: function () { + return _apply.createApply; + } +}); +Object.defineProperty(exports, "createApplyTransform", { + enumerable: true, + get: function () { + return _applyTransform.createApplyTransform; + } +}); +Object.defineProperty(exports, "createArrayNode", { + enumerable: true, + get: function () { + return _ArrayNode.createArrayNode; + } +}); +exports.createAsinh = exports.createAsin = exports.createAsech = exports.createAsec = void 0; +Object.defineProperty(exports, "createAssignmentNode", { + enumerable: true, + get: function () { + return _AssignmentNode.createAssignmentNode; + } +}); +exports.createAtanh = exports.createAtan2 = exports.createAtan = void 0; +Object.defineProperty(exports, "createBellNumbers", { + enumerable: true, + get: function () { + return _bellNumbers.createBellNumbers; + } +}); +Object.defineProperty(exports, "createBigint", { + enumerable: true, + get: function () { + return _bigint.createBigint; + } +}); +exports.createBitXor = exports.createBitOr = exports.createBitNot = exports.createBitAnd = void 0; +Object.defineProperty(exports, "createBlockNode", { + enumerable: true, + get: function () { + return _BlockNode.createBlockNode; + } +}); +Object.defineProperty(exports, "createBoolean", { + enumerable: true, + get: function () { + return _boolean.createBoolean; + } +}); +Object.defineProperty(exports, "createCatalan", { + enumerable: true, + get: function () { + return _catalan.createCatalan; + } +}); +exports.createCbrt = void 0; +Object.defineProperty(exports, "createCeil", { + enumerable: true, + get: function () { + return _ceil.createCeilNumber; + } +}); +Object.defineProperty(exports, "createChain", { + enumerable: true, + get: function () { + return _chain.createChain; + } +}); +Object.defineProperty(exports, "createChainClass", { + enumerable: true, + get: function () { + return _Chain.createChainClass; + } +}); +Object.defineProperty(exports, "createClone", { + enumerable: true, + get: function () { + return _clone.createClone; + } +}); +exports.createCombinations = void 0; +Object.defineProperty(exports, "createCombinationsWithRep", { + enumerable: true, + get: function () { + return _combinationsWithRep.createCombinationsWithRep; + } +}); +Object.defineProperty(exports, "createCompare", { + enumerable: true, + get: function () { + return _compare.createCompareNumber; + } +}); +Object.defineProperty(exports, "createCompareNatural", { + enumerable: true, + get: function () { + return _compareNatural.createCompareNatural; + } +}); +Object.defineProperty(exports, "createCompareText", { + enumerable: true, + get: function () { + return _compareText.createCompareTextNumber; + } +}); +Object.defineProperty(exports, "createCompile", { + enumerable: true, + get: function () { + return _compile.createCompile; + } +}); +Object.defineProperty(exports, "createComposition", { + enumerable: true, + get: function () { + return _composition.createComposition; + } +}); +Object.defineProperty(exports, "createConditionalNode", { + enumerable: true, + get: function () { + return _ConditionalNode.createConditionalNode; + } +}); +Object.defineProperty(exports, "createConstantNode", { + enumerable: true, + get: function () { + return _ConstantNode.createConstantNode; + } +}); +Object.defineProperty(exports, "createCorr", { + enumerable: true, + get: function () { + return _corr.createCorr; + } +}); +exports.createCube = exports.createCsch = exports.createCsc = exports.createCoth = exports.createCot = exports.createCosh = exports.createCos = void 0; +Object.defineProperty(exports, "createCumSum", { + enumerable: true, + get: function () { + return _cumsum.createCumSum; + } +}); +Object.defineProperty(exports, "createCumSumTransform", { + enumerable: true, + get: function () { + return _cumsumTransform.createCumSumTransform; + } +}); +Object.defineProperty(exports, "createDeepEqual", { + enumerable: true, + get: function () { + return _deepEqual.createDeepEqual; + } +}); +Object.defineProperty(exports, "createDerivative", { + enumerable: true, + get: function () { + return _derivative.createDerivative; + } +}); +exports.createDivideScalar = exports.createDivide = void 0; +Object.defineProperty(exports, "createE", { + enumerable: true, + get: function () { + return _constants.createE; + } +}); +Object.defineProperty(exports, "createEqual", { + enumerable: true, + get: function () { + return _equal.createEqualNumber; + } +}); +Object.defineProperty(exports, "createEqualScalar", { + enumerable: true, + get: function () { + return _equalScalar.createEqualScalarNumber; + } +}); +Object.defineProperty(exports, "createEqualText", { + enumerable: true, + get: function () { + return _equalText.createEqualText; + } +}); +Object.defineProperty(exports, "createErf", { + enumerable: true, + get: function () { + return _erf.createErf; + } +}); +Object.defineProperty(exports, "createEvaluate", { + enumerable: true, + get: function () { + return _evaluate.createEvaluate; + } +}); +exports.createExpm1 = exports.createExp = void 0; +Object.defineProperty(exports, "createFactorial", { + enumerable: true, + get: function () { + return _factorial.createFactorial; + } +}); +Object.defineProperty(exports, "createFalse", { + enumerable: true, + get: function () { + return _constants.createFalse; + } +}); +Object.defineProperty(exports, "createFilter", { + enumerable: true, + get: function () { + return _filter.createFilter; + } +}); +Object.defineProperty(exports, "createFilterTransform", { + enumerable: true, + get: function () { + return _filterTransform.createFilterTransform; + } +}); +Object.defineProperty(exports, "createFix", { + enumerable: true, + get: function () { + return _fix.createFixNumber; + } +}); +Object.defineProperty(exports, "createFloor", { + enumerable: true, + get: function () { + return _floor.createFloorNumber; + } +}); +Object.defineProperty(exports, "createForEach", { + enumerable: true, + get: function () { + return _forEach.createForEach; + } +}); +Object.defineProperty(exports, "createForEachTransform", { + enumerable: true, + get: function () { + return _forEachTransform.createForEachTransform; + } +}); +Object.defineProperty(exports, "createFormat", { + enumerable: true, + get: function () { + return _format.createFormat; + } +}); +Object.defineProperty(exports, "createFunctionAssignmentNode", { + enumerable: true, + get: function () { + return _FunctionAssignmentNode.createFunctionAssignmentNode; + } +}); +Object.defineProperty(exports, "createFunctionNode", { + enumerable: true, + get: function () { + return _FunctionNode.createFunctionNode; + } +}); +exports.createGcd = exports.createGamma = void 0; +Object.defineProperty(exports, "createHasNumericValue", { + enumerable: true, + get: function () { + return _hasNumericValue.createHasNumericValue; + } +}); +Object.defineProperty(exports, "createHelp", { + enumerable: true, + get: function () { + return _help.createHelp; + } +}); +Object.defineProperty(exports, "createHelpClass", { + enumerable: true, + get: function () { + return _Help.createHelpClass; + } +}); +Object.defineProperty(exports, "createHypot", { + enumerable: true, + get: function () { + return _hypot.createHypot; + } +}); +exports.createIndex = void 0; +Object.defineProperty(exports, "createIndexNode", { + enumerable: true, + get: function () { + return _IndexNode.createIndexNode; + } +}); +Object.defineProperty(exports, "createInfinity", { + enumerable: true, + get: function () { + return _constants.createInfinity; + } +}); +exports.createIsNegative = exports.createIsNaN = exports.createIsInteger = void 0; +Object.defineProperty(exports, "createIsNumeric", { + enumerable: true, + get: function () { + return _isNumeric.createIsNumeric; + } +}); +exports.createIsPositive = void 0; +Object.defineProperty(exports, "createIsPrime", { + enumerable: true, + get: function () { + return _isPrime.createIsPrime; + } +}); +exports.createIsZero = void 0; +Object.defineProperty(exports, "createLN10", { + enumerable: true, + get: function () { + return _constants.createLN10; + } +}); +Object.defineProperty(exports, "createLN2", { + enumerable: true, + get: function () { + return _constants.createLN2; + } +}); +Object.defineProperty(exports, "createLOG10E", { + enumerable: true, + get: function () { + return _constants.createLOG10E; + } +}); +Object.defineProperty(exports, "createLOG2E", { + enumerable: true, + get: function () { + return _constants.createLOG2E; + } +}); +Object.defineProperty(exports, "createLarger", { + enumerable: true, + get: function () { + return _larger.createLargerNumber; + } +}); +Object.defineProperty(exports, "createLargerEq", { + enumerable: true, + get: function () { + return _largerEq.createLargerEqNumber; + } +}); +exports.createLog2 = exports.createLog1p = exports.createLog10 = exports.createLog = exports.createLgamma = exports.createLeftShift = exports.createLcm = void 0; +Object.defineProperty(exports, "createMad", { + enumerable: true, + get: function () { + return _mad.createMad; + } +}); +Object.defineProperty(exports, "createMap", { + enumerable: true, + get: function () { + return _map.createMap; + } +}); +Object.defineProperty(exports, "createMapTransform", { + enumerable: true, + get: function () { + return _mapTransform.createMapTransform; + } +}); +exports.createMatrix = void 0; +Object.defineProperty(exports, "createMax", { + enumerable: true, + get: function () { + return _max.createMax; + } +}); +Object.defineProperty(exports, "createMaxTransform", { + enumerable: true, + get: function () { + return _maxTransform.createMaxTransform; + } +}); +Object.defineProperty(exports, "createMean", { + enumerable: true, + get: function () { + return _mean.createMean; + } +}); +Object.defineProperty(exports, "createMeanTransform", { + enumerable: true, + get: function () { + return _meanTransform.createMeanTransform; + } +}); +Object.defineProperty(exports, "createMedian", { + enumerable: true, + get: function () { + return _median.createMedian; + } +}); +Object.defineProperty(exports, "createMin", { + enumerable: true, + get: function () { + return _min.createMin; + } +}); +Object.defineProperty(exports, "createMinTransform", { + enumerable: true, + get: function () { + return _minTransform.createMinTransform; + } +}); +exports.createMod = void 0; +Object.defineProperty(exports, "createMode", { + enumerable: true, + get: function () { + return _mode.createMode; + } +}); +Object.defineProperty(exports, "createMultinomial", { + enumerable: true, + get: function () { + return _multinomial.createMultinomial; + } +}); +exports.createMultiplyScalar = exports.createMultiply = void 0; +Object.defineProperty(exports, "createNaN", { + enumerable: true, + get: function () { + return _constants.createNaN; + } +}); +Object.defineProperty(exports, "createNode", { + enumerable: true, + get: function () { + return _Node.createNode; + } +}); +exports.createNthRoot = exports.createNot = exports.createNorm = void 0; +Object.defineProperty(exports, "createNull", { + enumerable: true, + get: function () { + return _constants.createNull; + } +}); +Object.defineProperty(exports, "createNumber", { + enumerable: true, + get: function () { + return _number.createNumber; + } +}); +Object.defineProperty(exports, "createNumeric", { + enumerable: true, + get: function () { + return _numeric.createNumeric; + } +}); +Object.defineProperty(exports, "createObjectNode", { + enumerable: true, + get: function () { + return _ObjectNode.createObjectNode; + } +}); +Object.defineProperty(exports, "createOperatorNode", { + enumerable: true, + get: function () { + return _OperatorNode.createOperatorNode; + } +}); +exports.createOr = void 0; +Object.defineProperty(exports, "createParenthesisNode", { + enumerable: true, + get: function () { + return _ParenthesisNode.createParenthesisNode; + } +}); +Object.defineProperty(exports, "createParse", { + enumerable: true, + get: function () { + return _parse.createParse; + } +}); +Object.defineProperty(exports, "createParser", { + enumerable: true, + get: function () { + return _parser.createParser; + } +}); +Object.defineProperty(exports, "createParserClass", { + enumerable: true, + get: function () { + return _Parser.createParserClass; + } +}); +Object.defineProperty(exports, "createPartitionSelect", { + enumerable: true, + get: function () { + return _partitionSelect.createPartitionSelect; + } +}); +Object.defineProperty(exports, "createPermutations", { + enumerable: true, + get: function () { + return _permutations.createPermutations; + } +}); +Object.defineProperty(exports, "createPhi", { + enumerable: true, + get: function () { + return _constants.createPhi; + } +}); +Object.defineProperty(exports, "createPi", { + enumerable: true, + get: function () { + return _constants.createPi; + } +}); +Object.defineProperty(exports, "createPickRandom", { + enumerable: true, + get: function () { + return _pickRandom.createPickRandom; + } +}); +exports.createPow = void 0; +Object.defineProperty(exports, "createPrint", { + enumerable: true, + get: function () { + return _print.createPrint; + } +}); +Object.defineProperty(exports, "createProd", { + enumerable: true, + get: function () { + return _prod.createProd; + } +}); +Object.defineProperty(exports, "createQuantileSeq", { + enumerable: true, + get: function () { + return _quantileSeq.createQuantileSeq; + } +}); +Object.defineProperty(exports, "createRandom", { + enumerable: true, + get: function () { + return _random.createRandomNumber; + } +}); +Object.defineProperty(exports, "createRandomInt", { + enumerable: true, + get: function () { + return _randomInt.createRandomInt; + } +}); +Object.defineProperty(exports, "createRange", { + enumerable: true, + get: function () { + return _range.createRange; + } +}); +Object.defineProperty(exports, "createRangeClass", { + enumerable: true, + get: function () { + return _Range.createRangeClass; + } +}); +Object.defineProperty(exports, "createRangeNode", { + enumerable: true, + get: function () { + return _RangeNode.createRangeNode; + } +}); +Object.defineProperty(exports, "createRangeTransform", { + enumerable: true, + get: function () { + return _rangeTransform.createRangeTransform; + } +}); +Object.defineProperty(exports, "createRationalize", { + enumerable: true, + get: function () { + return _rationalize.createRationalize; + } +}); +Object.defineProperty(exports, "createRelationalNode", { + enumerable: true, + get: function () { + return _RelationalNode.createRelationalNode; + } +}); +Object.defineProperty(exports, "createReplacer", { + enumerable: true, + get: function () { + return _replacer.createReplacer; + } +}); +Object.defineProperty(exports, "createResolve", { + enumerable: true, + get: function () { + return _resolve.createResolve; + } +}); +Object.defineProperty(exports, "createResultSet", { + enumerable: true, + get: function () { + return _ResultSet.createResultSet; + } +}); +Object.defineProperty(exports, "createReviver", { + enumerable: true, + get: function () { + return _reviver.createReviver; + } +}); +exports.createRound = exports.createRightLogShift = exports.createRightArithShift = void 0; +Object.defineProperty(exports, "createSQRT1_2", { + enumerable: true, + get: function () { + return _constants.createSQRT1_2; + } +}); +Object.defineProperty(exports, "createSQRT2", { + enumerable: true, + get: function () { + return _constants.createSQRT2; + } +}); +exports.createSign = exports.createSech = exports.createSec = void 0; +Object.defineProperty(exports, "createSimplify", { + enumerable: true, + get: function () { + return _simplify.createSimplify; + } +}); +Object.defineProperty(exports, "createSimplifyConstant", { + enumerable: true, + get: function () { + return _simplifyConstant.createSimplifyConstant; + } +}); +Object.defineProperty(exports, "createSimplifyCore", { + enumerable: true, + get: function () { + return _simplifyCore.createSimplifyCore; + } +}); +exports.createSinh = exports.createSin = void 0; +Object.defineProperty(exports, "createSize", { + enumerable: true, + get: function () { + return _size.createSize; + } +}); +Object.defineProperty(exports, "createSmaller", { + enumerable: true, + get: function () { + return _smaller.createSmallerNumber; + } +}); +Object.defineProperty(exports, "createSmallerEq", { + enumerable: true, + get: function () { + return _smallerEq.createSmallerEqNumber; + } +}); +exports.createSquare = exports.createSqrt = void 0; +Object.defineProperty(exports, "createStd", { + enumerable: true, + get: function () { + return _std.createStd; + } +}); +Object.defineProperty(exports, "createStdTransform", { + enumerable: true, + get: function () { + return _stdTransform.createStdTransform; + } +}); +Object.defineProperty(exports, "createStirlingS2", { + enumerable: true, + get: function () { + return _stirlingS.createStirlingS2; + } +}); +Object.defineProperty(exports, "createString", { + enumerable: true, + get: function () { + return _string.createString; + } +}); +exports.createSubtractScalar = exports.createSubtract = exports.createSubsetTransform = exports.createSubset = void 0; +Object.defineProperty(exports, "createSum", { + enumerable: true, + get: function () { + return _sum.createSum; + } +}); +Object.defineProperty(exports, "createSumTransform", { + enumerable: true, + get: function () { + return _sumTransform.createSumTransform; + } +}); +Object.defineProperty(exports, "createSymbolNode", { + enumerable: true, + get: function () { + return _SymbolNode.createSymbolNode; + } +}); +exports.createTanh = exports.createTan = void 0; +Object.defineProperty(exports, "createTau", { + enumerable: true, + get: function () { + return _constants.createTau; + } +}); +Object.defineProperty(exports, "createTrue", { + enumerable: true, + get: function () { + return _constants.createTrue; + } +}); +Object.defineProperty(exports, "createTypeOf", { + enumerable: true, + get: function () { + return _typeOf.createTypeOf; + } +}); +Object.defineProperty(exports, "createTyped", { + enumerable: true, + get: function () { + return _typed.createTyped; + } +}); +exports.createUnaryPlus = exports.createUnaryMinus = void 0; +Object.defineProperty(exports, "createUnequal", { + enumerable: true, + get: function () { + return _unequal.createUnequalNumber; + } +}); +Object.defineProperty(exports, "createUppercaseE", { + enumerable: true, + get: function () { + return _constants.createUppercaseE; + } +}); +Object.defineProperty(exports, "createUppercasePi", { + enumerable: true, + get: function () { + return _constants.createUppercasePi; + } +}); +Object.defineProperty(exports, "createVariance", { + enumerable: true, + get: function () { + return _variance.createVariance; + } +}); +Object.defineProperty(exports, "createVarianceTransform", { + enumerable: true, + get: function () { + return _varianceTransform.createVarianceTransform; + } +}); +Object.defineProperty(exports, "createVersion", { + enumerable: true, + get: function () { + return _constants.createVersion; + } +}); +exports.createXor = exports.createXgcd = void 0; +Object.defineProperty(exports, "createZeta", { + enumerable: true, + get: function () { + return _zeta.createZeta; + } +}); +var _index = require("./plain/number/index.js"); +var _factory = require("./utils/factory.js"); +var _noop = require("./utils/noop.js"); +var _typed = require("./core/function/typed.js"); +var _ResultSet = require("./type/resultset/ResultSet.js"); +var _Range = require("./type/matrix/Range.js"); +var _Help = require("./expression/Help.js"); +var _Chain = require("./type/chain/Chain.js"); +var _help = require("./expression/function/help.js"); +var _chain = require("./type/chain/function/chain.js"); +var _resolve = require("./function/algebra/resolve.js"); +var _simplify = require("./function/algebra/simplify.js"); +var _simplifyConstant = require("./function/algebra/simplifyConstant.js"); +var _simplifyCore = require("./function/algebra/simplifyCore.js"); +var _derivative = require("./function/algebra/derivative.js"); +var _rationalize = require("./function/algebra/rationalize.js"); +var _ceil = require("./function/arithmetic/ceil.js"); +var _fix = require("./function/arithmetic/fix.js"); +var _floor = require("./function/arithmetic/floor.js"); +var _hypot = require("./function/arithmetic/hypot.js"); +var _stirlingS = require("./function/combinatorics/stirlingS2.js"); +var _bellNumbers = require("./function/combinatorics/bellNumbers.js"); +var _catalan = require("./function/combinatorics/catalan.js"); +var _composition = require("./function/combinatorics/composition.js"); +var _constants = require("./constants.js"); +var _number = require("./type/number.js"); +var _bigint = require("./type/bigint.js"); +var _string = require("./type/string.js"); +var _boolean = require("./type/boolean.js"); +var _parser = require("./expression/function/parser.js"); +var _Node = require("./expression/node/Node.js"); +var _AccessorNode = require("./expression/node/AccessorNode.js"); +var _ArrayNode = require("./expression/node/ArrayNode.js"); +var _AssignmentNode = require("./expression/node/AssignmentNode.js"); +var _BlockNode = require("./expression/node/BlockNode.js"); +var _ConditionalNode = require("./expression/node/ConditionalNode.js"); +var _ConstantNode = require("./expression/node/ConstantNode.js"); +var _FunctionAssignmentNode = require("./expression/node/FunctionAssignmentNode.js"); +var _IndexNode = require("./expression/node/IndexNode.js"); +var _ObjectNode = require("./expression/node/ObjectNode.js"); +var _OperatorNode = require("./expression/node/OperatorNode.js"); +var _ParenthesisNode = require("./expression/node/ParenthesisNode.js"); +var _RangeNode = require("./expression/node/RangeNode.js"); +var _RelationalNode = require("./expression/node/RelationalNode.js"); +var _SymbolNode = require("./expression/node/SymbolNode.js"); +var _FunctionNode = require("./expression/node/FunctionNode.js"); +var _parse = require("./expression/parse.js"); +var _compile = require("./expression/function/compile.js"); +var _evaluate = require("./expression/function/evaluate.js"); +var _Parser = require("./expression/Parser.js"); +var _apply = require("./function/matrix/apply.js"); +var _filter = require("./function/matrix/filter.js"); +var _forEach = require("./function/matrix/forEach.js"); +var _map = require("./function/matrix/map.js"); +var _range = require("./function/matrix/range.js"); +var _size = require("./function/matrix/size.js"); +var _partitionSelect = require("./function/matrix/partitionSelect.js"); +var _combinationsWithRep = require("./function/probability/combinationsWithRep.js"); +var _factorial = require("./function/probability/factorial.js"); +var _multinomial = require("./function/probability/multinomial.js"); +var _permutations = require("./function/probability/permutations.js"); +var _pickRandom = require("./function/probability/pickRandom.js"); +var _random = require("./function/probability/random.js"); +var _randomInt = require("./function/probability/randomInt.js"); +var _equalScalar = require("./function/relational/equalScalar.js"); +var _compare = require("./function/relational/compare.js"); +var _compareNatural = require("./function/relational/compareNatural.js"); +var _compareText = require("./function/relational/compareText.js"); +var _equal = require("./function/relational/equal.js"); +var _equalText = require("./function/relational/equalText.js"); +var _smaller = require("./function/relational/smaller.js"); +var _smallerEq = require("./function/relational/smallerEq.js"); +var _larger = require("./function/relational/larger.js"); +var _largerEq = require("./function/relational/largerEq.js"); +var _deepEqual = require("./function/relational/deepEqual.js"); +var _unequal = require("./function/relational/unequal.js"); +var _erf = require("./function/special/erf.js"); +var _zeta = require("./function/special/zeta.js"); +var _mode = require("./function/statistics/mode.js"); +var _prod = require("./function/statistics/prod.js"); +var _max = require("./function/statistics/max.js"); +var _min = require("./function/statistics/min.js"); +var _sum = require("./function/statistics/sum.js"); +var _cumsum = require("./function/statistics/cumsum.js"); +var _mean = require("./function/statistics/mean.js"); +var _median = require("./function/statistics/median.js"); +var _mad = require("./function/statistics/mad.js"); +var _variance = require("./function/statistics/variance.js"); +var _quantileSeq = require("./function/statistics/quantileSeq.js"); +var _std = require("./function/statistics/std.js"); +var _corr = require("./function/statistics/corr.js"); +var _format = require("./function/string/format.js"); +var _print = require("./function/string/print.js"); +var _applyTransform = require("./expression/transform/apply.transform.js"); +var _filterTransform = require("./expression/transform/filter.transform.js"); +var _forEachTransform = require("./expression/transform/forEach.transform.js"); +var _mapTransform = require("./expression/transform/map.transform.js"); +var _maxTransform = require("./expression/transform/max.transform.js"); +var _meanTransform = require("./expression/transform/mean.transform.js"); +var _minTransform = require("./expression/transform/min.transform.js"); +var _rangeTransform = require("./expression/transform/range.transform.js"); +var _stdTransform = require("./expression/transform/std.transform.js"); +var _sumTransform = require("./expression/transform/sum.transform.js"); +var _cumsumTransform = require("./expression/transform/cumsum.transform.js"); +var _varianceTransform = require("./expression/transform/variance.transform.js"); +var _clone = require("./function/utils/clone.js"); +var _isNumeric = require("./function/utils/isNumeric.js"); +var _hasNumericValue = require("./function/utils/hasNumericValue.js"); +var _typeOf = require("./function/utils/typeOf.js"); +var _isPrime = require("./function/utils/isPrime.js"); +var _numeric = require("./function/utils/numeric.js"); +var _reviver = require("./json/reviver.js"); +var _replacer = require("./json/replacer.js"); +// ---------------------------------------------------------------------------- +// classes and functions + +// core + +// classes + +// algebra + +// arithmetic +const createUnaryMinus = exports.createUnaryMinus = /* #__PURE__ */createNumberFactory('unaryMinus', _index.unaryMinusNumber); +const createUnaryPlus = exports.createUnaryPlus = /* #__PURE__ */createNumberFactory('unaryPlus', _index.unaryPlusNumber); +const createAbs = exports.createAbs = /* #__PURE__ */createNumberFactory('abs', _index.absNumber); +const createAddScalar = exports.createAddScalar = /* #__PURE__ */createNumberFactory('addScalar', _index.addNumber); +const createSubtractScalar = exports.createSubtractScalar = /* #__PURE__ */createNumberFactory('subtractScalar', _index.subtractNumber); +const createCbrt = exports.createCbrt = /* #__PURE__ */createNumberFactory('cbrt', _index.cbrtNumber); +const createCube = exports.createCube = /* #__PURE__ */createNumberFactory('cube', _index.cubeNumber); +const createExp = exports.createExp = /* #__PURE__ */createNumberFactory('exp', _index.expNumber); +const createExpm1 = exports.createExpm1 = /* #__PURE__ */createNumberFactory('expm1', _index.expm1Number); +const createGcd = exports.createGcd = /* #__PURE__ */createNumberFactory('gcd', _index.gcdNumber); +const createLcm = exports.createLcm = /* #__PURE__ */createNumberFactory('lcm', _index.lcmNumber); +const createLog10 = exports.createLog10 = /* #__PURE__ */createNumberFactory('log10', _index.log10Number); +const createLog2 = exports.createLog2 = /* #__PURE__ */createNumberFactory('log2', _index.log2Number); +const createMod = exports.createMod = /* #__PURE__ */createNumberFactory('mod', _index.modNumber); +const createMultiplyScalar = exports.createMultiplyScalar = /* #__PURE__ */createNumberFactory('multiplyScalar', _index.multiplyNumber); +const createMultiply = exports.createMultiply = /* #__PURE__ */createNumberFactory('multiply', _index.multiplyNumber); +const createNthRoot = exports.createNthRoot = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('nthRoot', _index.nthRootNumber); +const createSign = exports.createSign = /* #__PURE__ */createNumberFactory('sign', _index.signNumber); +const createSqrt = exports.createSqrt = /* #__PURE__ */createNumberFactory('sqrt', _index.sqrtNumber); +const createSquare = exports.createSquare = /* #__PURE__ */createNumberFactory('square', _index.squareNumber); +const createSubtract = exports.createSubtract = /* #__PURE__ */createNumberFactory('subtract', _index.subtractNumber); +const createXgcd = exports.createXgcd = /* #__PURE__ */createNumberFactory('xgcd', _index.xgcdNumber); +const createDivideScalar = exports.createDivideScalar = /* #__PURE__ */createNumberFactory('divideScalar', _index.divideNumber); +const createPow = exports.createPow = /* #__PURE__ */createNumberFactory('pow', _index.powNumber); +const createRound = exports.createRound = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('round', _index.roundNumber); +const createLog = exports.createLog = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('log', _index.logNumber); +const createLog1p = exports.createLog1p = /* #__PURE__ */createNumberFactory('log1p', _index.log1pNumber); +const createAdd = exports.createAdd = /* #__PURE__ */createNumberFactory('add', _index.addNumber); +const createNorm = exports.createNorm = /* #__PURE__ */createNumberFactory('norm', _index.normNumber); +const createDivide = exports.createDivide = /* #__PURE__ */createNumberFactory('divide', _index.divideNumber); + +// bitwise +const createBitAnd = exports.createBitAnd = /* #__PURE__ */createNumberFactory('bitAnd', _index.bitAndNumber); +const createBitNot = exports.createBitNot = /* #__PURE__ */createNumberFactory('bitNot', _index.bitNotNumber); +const createBitOr = exports.createBitOr = /* #__PURE__ */createNumberFactory('bitOr', _index.bitOrNumber); +const createBitXor = exports.createBitXor = /* #__PURE__ */createNumberFactory('bitXor', _index.bitXorNumber); +const createLeftShift = exports.createLeftShift = /* #__PURE__ */createNumberFactory('leftShift', _index.leftShiftNumber); +const createRightArithShift = exports.createRightArithShift = /* #__PURE__ */createNumberFactory('rightArithShift', _index.rightArithShiftNumber); +const createRightLogShift = exports.createRightLogShift = /* #__PURE__ */createNumberFactory('rightLogShift', _index.rightLogShiftNumber); + +// combinatorics + +// constants + +// create + +// expression + +// logical +const createAnd = exports.createAnd = /* #__PURE__ */createNumberFactory('and', _index.andNumber); +const createNot = exports.createNot = /* #__PURE__ */createNumberFactory('not', _index.notNumber); +const createOr = exports.createOr = /* #__PURE__ */createNumberFactory('or', _index.orNumber); +const createXor = exports.createXor = /* #__PURE__ */createNumberFactory('xor', _index.xorNumber); + +// matrix + +// FIXME: create a lightweight "number" implementation of subset only supporting plain objects/arrays +const createIndex = exports.createIndex = /* #__PURE__ */(0, _factory.factory)('index', [], () => _noop.noIndex); +const createMatrix = exports.createMatrix = /* #__PURE__ */(0, _factory.factory)('matrix', [], () => _noop.noMatrix); // FIXME: needed now because subset transform needs it. Remove the need for it in subset +const createSubset = exports.createSubset = /* #__PURE__ */(0, _factory.factory)('subset', [], () => _noop.noSubset); +// TODO: provide number+array implementations for map, filter, forEach, zeros, ...? +// TODO: create range implementation for range? + +// probability +const createCombinations = exports.createCombinations = createNumberFactory('combinations', _index.combinationsNumber); +const createGamma = exports.createGamma = createNumberFactory('gamma', _index.gammaNumber); +const createLgamma = exports.createLgamma = createNumberFactory('lgamma', _index.lgammaNumber); + +// relational + +// special + +// statistics + +// string + +// trigonometry +const createAcos = exports.createAcos = /* #__PURE__ */createNumberFactory('acos', _index.acosNumber); +const createAcosh = exports.createAcosh = /* #__PURE__ */createNumberFactory('acosh', _index.acoshNumber); +const createAcot = exports.createAcot = /* #__PURE__ */createNumberFactory('acot', _index.acotNumber); +const createAcoth = exports.createAcoth = /* #__PURE__ */createNumberFactory('acoth', _index.acothNumber); +const createAcsc = exports.createAcsc = /* #__PURE__ */createNumberFactory('acsc', _index.acscNumber); +const createAcsch = exports.createAcsch = /* #__PURE__ */createNumberFactory('acsch', _index.acschNumber); +const createAsec = exports.createAsec = /* #__PURE__ */createNumberFactory('asec', _index.asecNumber); +const createAsech = exports.createAsech = /* #__PURE__ */createNumberFactory('asech', _index.asechNumber); +const createAsin = exports.createAsin = /* #__PURE__ */createNumberFactory('asin', _index.asinNumber); +const createAsinh = exports.createAsinh = /* #__PURE__ */createNumberFactory('asinh', _index.asinhNumber); +const createAtan = exports.createAtan = /* #__PURE__ */createNumberFactory('atan', _index.atanNumber); +const createAtan2 = exports.createAtan2 = /* #__PURE__ */createNumberFactory('atan2', _index.atan2Number); +const createAtanh = exports.createAtanh = /* #__PURE__ */createNumberFactory('atanh', _index.atanhNumber); +const createCos = exports.createCos = /* #__PURE__ */createNumberFactory('cos', _index.cosNumber); +const createCosh = exports.createCosh = /* #__PURE__ */createNumberFactory('cosh', _index.coshNumber); +const createCot = exports.createCot = /* #__PURE__ */createNumberFactory('cot', _index.cotNumber); +const createCoth = exports.createCoth = /* #__PURE__ */createNumberFactory('coth', _index.cothNumber); +const createCsc = exports.createCsc = /* #__PURE__ */createNumberFactory('csc', _index.cscNumber); +const createCsch = exports.createCsch = /* #__PURE__ */createNumberFactory('csch', _index.cschNumber); +const createSec = exports.createSec = /* #__PURE__ */createNumberFactory('sec', _index.secNumber); +const createSech = exports.createSech = /* #__PURE__ */createNumberFactory('sech', _index.sechNumber); +const createSin = exports.createSin = /* #__PURE__ */createNumberFactory('sin', _index.sinNumber); +const createSinh = exports.createSinh = /* #__PURE__ */createNumberFactory('sinh', _index.sinhNumber); +const createTan = exports.createTan = /* #__PURE__ */createNumberFactory('tan', _index.tanNumber); +const createTanh = exports.createTanh = /* #__PURE__ */createNumberFactory('tanh', _index.tanhNumber); + +// transforms + +const createSubsetTransform = exports.createSubsetTransform = /* #__PURE__ */(0, _factory.factory)('subset', [], () => _noop.noSubset, { + isTransformFunction: true +}); + +// utils + +const createIsInteger = exports.createIsInteger = /* #__PURE__ */createNumberFactory('isInteger', _index.isIntegerNumber); +const createIsNegative = exports.createIsNegative = /* #__PURE__ */createNumberFactory('isNegative', _index.isNegativeNumber); +const createIsPositive = exports.createIsPositive = /* #__PURE__ */createNumberFactory('isPositive', _index.isPositiveNumber); +const createIsZero = exports.createIsZero = /* #__PURE__ */createNumberFactory('isZero', _index.isZeroNumber); +const createIsNaN = exports.createIsNaN = /* #__PURE__ */createNumberFactory('isNaN', _index.isNaNNumber); + +// json + +// helper functions to create a factory function for a function which only needs typed-function +function createNumberFactory(name, fn) { + return (0, _factory.factory)(name, ['typed'], _ref => { + let { + typed + } = _ref; + return typed(fn); + }); +} +function createNumberOptionalSecondArgFactory(name, fn) { + return (0, _factory.factory)(name, ['typed'], _ref2 => { + let { + typed + } = _ref2; + return typed({ + number: fn, + 'number,number': fn + }); + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/lup.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/lup.js new file mode 100644 index 0000000..e3327e4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/lup.js @@ -0,0 +1,382 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLup = void 0; +var _object = require("../../../utils/object.js"); +var _factory = require("../../../utils/factory.js"); +const name = 'lup'; +const dependencies = ['typed', 'matrix', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'larger', 'equalScalar', 'unaryMinus', 'DenseMatrix', 'SparseMatrix', 'Spa']; +const createLup = exports.createLup = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + abs, + addScalar, + divideScalar, + multiplyScalar, + subtractScalar, + larger, + equalScalar, + unaryMinus, + DenseMatrix, + SparseMatrix, + Spa + } = _ref; + /** + * Calculate the Matrix LU decomposition with partial pivoting. Matrix `A` is decomposed in two matrices (`L`, `U`) and a + * row permutation vector `p` where `A[p,:] = L * U` + * + * Syntax: + * + * math.lup(A) + * + * Example: + * + * const m = [[2, 1], [1, 4]] + * const r = math.lup(m) + * // r = { + * // L: [[1, 0], [0.5, 1]], + * // U: [[2, 1], [0, 3.5]], + * // P: [0, 1] + * // } + * + * See also: + * + * slu, lsolve, lusolve, usolve + * + * @param {Matrix | Array} A A two dimensional matrix or array for which to get the LUP decomposition. + * + * @return {{L: Array | Matrix, U: Array | Matrix, P: Array.}} The lower triangular matrix, the upper triangular matrix and the permutation matrix. + */ + return typed(name, { + DenseMatrix: function (m) { + return _denseLUP(m); + }, + SparseMatrix: function (m) { + return _sparseLUP(m); + }, + Array: function (a) { + // create dense matrix from array + const m = matrix(a); + // lup, use matrix implementation + const r = _denseLUP(m); + // result + return { + L: r.L.valueOf(), + U: r.U.valueOf(), + p: r.p + }; + } + }); + function _denseLUP(m) { + // rows & columns + const rows = m._size[0]; + const columns = m._size[1]; + // minimum rows and columns + let n = Math.min(rows, columns); + // matrix array, clone original data + const data = (0, _object.clone)(m._data); + // l matrix arrays + const ldata = []; + const lsize = [rows, n]; + // u matrix arrays + const udata = []; + const usize = [n, columns]; + // vars + let i, j, k; + // permutation vector + const p = []; + for (i = 0; i < rows; i++) { + p[i] = i; + } + // loop columns + for (j = 0; j < columns; j++) { + // skip first column in upper triangular matrix + if (j > 0) { + // loop rows + for (i = 0; i < rows; i++) { + // min i,j + const min = Math.min(i, j); + // v[i, j] + let s = 0; + // loop up to min + for (k = 0; k < min; k++) { + // s = l[i, k] - data[k, j] + s = addScalar(s, multiplyScalar(data[i][k], data[k][j])); + } + data[i][j] = subtractScalar(data[i][j], s); + } + } + // row with larger value in cvector, row >= j + let pi = j; + let pabsv = 0; + let vjj = 0; + // loop rows + for (i = j; i < rows; i++) { + // data @ i, j + const v = data[i][j]; + // absolute value + const absv = abs(v); + // value is greater than pivote value + if (larger(absv, pabsv)) { + // store row + pi = i; + // update max value + pabsv = absv; + // value @ [j, j] + vjj = v; + } + } + // swap rows (j <-> pi) + if (j !== pi) { + // swap values j <-> pi in p + p[j] = [p[pi], p[pi] = p[j]][0]; + // swap j <-> pi in data + DenseMatrix._swapRows(j, pi, data); + } + // check column is in lower triangular matrix + if (j < rows) { + // loop rows (lower triangular matrix) + for (i = j + 1; i < rows; i++) { + // value @ i, j + const vij = data[i][j]; + if (!equalScalar(vij, 0)) { + // update data + data[i][j] = divideScalar(data[i][j], vjj); + } + } + } + } + // loop columns + for (j = 0; j < columns; j++) { + // loop rows + for (i = 0; i < rows; i++) { + // initialize row in arrays + if (j === 0) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i] = []; + } + // L + ldata[i] = []; + } + // check we are in the upper triangular matrix + if (i < j) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = data[i][j]; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = 0; + } + continue; + } + // diagonal value + if (i === j) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = data[i][j]; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = 1; + } + continue; + } + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = 0; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = data[i][j]; + } + } + } + // l matrix + const l = new DenseMatrix({ + data: ldata, + size: lsize + }); + // u matrix + const u = new DenseMatrix({ + data: udata, + size: usize + }); + // p vector + const pv = []; + for (i = 0, n = p.length; i < n; i++) { + pv[p[i]] = i; + } + // return matrices + return { + L: l, + U: u, + p: pv, + toString: function () { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\nP: ' + this.p; + } + }; + } + function _sparseLUP(m) { + // rows & columns + const rows = m._size[0]; + const columns = m._size[1]; + // minimum rows and columns + const n = Math.min(rows, columns); + // matrix arrays (will not be modified, thanks to permutation vector) + const values = m._values; + const index = m._index; + const ptr = m._ptr; + // l matrix arrays + const lvalues = []; + const lindex = []; + const lptr = []; + const lsize = [rows, n]; + // u matrix arrays + const uvalues = []; + const uindex = []; + const uptr = []; + const usize = [n, columns]; + // vars + let i, j, k; + // permutation vectors, (current index -> original index) and (original index -> current index) + const pvCo = []; + const pvOc = []; + for (i = 0; i < rows; i++) { + pvCo[i] = i; + pvOc[i] = i; + } + // swap indices in permutation vectors (condition x < y)! + const swapIndeces = function (x, y) { + // find pv indeces getting data from x and y + const kx = pvOc[x]; + const ky = pvOc[y]; + // update permutation vector current -> original + pvCo[kx] = y; + pvCo[ky] = x; + // update permutation vector original -> current + pvOc[x] = ky; + pvOc[y] = kx; + }; + // loop columns + for (j = 0; j < columns; j++) { + // sparse accumulator + const spa = new Spa(); + // check lower triangular matrix has a value @ column j + if (j < rows) { + // update ptr + lptr.push(lvalues.length); + // first value in j column for lower triangular matrix + lvalues.push(1); + lindex.push(j); + } + // update ptr + uptr.push(uvalues.length); + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = ptr[j]; + const k1 = ptr[j + 1]; + // copy column j into sparse accumulator + for (k = k0; k < k1; k++) { + // row + i = index[k]; + // copy column values into sparse accumulator (use permutation vector) + spa.set(pvCo[i], values[k]); + } + // skip first column in upper triangular matrix + if (j > 0) { + // loop rows in column j (above diagonal) + spa.forEach(0, j - 1, function (k, vkj) { + // loop rows in column k (L) + SparseMatrix._forEachRow(k, lvalues, lindex, lptr, function (i, vik) { + // check row is below k + if (i > k) { + // update spa value + spa.accumulate(i, unaryMinus(multiplyScalar(vik, vkj))); + } + }); + }); + } + // row with larger value in spa, row >= j + let pi = j; + let vjj = spa.get(j); + let pabsv = abs(vjj); + // loop values in spa (order by row, below diagonal) + spa.forEach(j + 1, rows - 1, function (x, v) { + // absolute value + const absv = abs(v); + // value is greater than pivote value + if (larger(absv, pabsv)) { + // store row + pi = x; + // update max value + pabsv = absv; + // value @ [j, j] + vjj = v; + } + }); + // swap rows (j <-> pi) + if (j !== pi) { + // swap values j <-> pi in L + SparseMatrix._swapRows(j, pi, lsize[1], lvalues, lindex, lptr); + // swap values j <-> pi in U + SparseMatrix._swapRows(j, pi, usize[1], uvalues, uindex, uptr); + // swap values in spa + spa.swap(j, pi); + // update permutation vector (swap values @ j, pi) + swapIndeces(j, pi); + } + // loop values in spa (order by row) + spa.forEach(0, rows - 1, function (x, v) { + // check we are above diagonal + if (x <= j) { + // update upper triangular matrix + uvalues.push(v); + uindex.push(x); + } else { + // update value + v = divideScalar(v, vjj); + // check value is non zero + if (!equalScalar(v, 0)) { + // update lower triangular matrix + lvalues.push(v); + lindex.push(x); + } + } + }); + } + // update ptrs + uptr.push(uvalues.length); + lptr.push(lvalues.length); + + // return matrices + return { + L: new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: lsize + }), + U: new SparseMatrix({ + values: uvalues, + index: uindex, + ptr: uptr, + size: usize + }), + p: pvCo, + toString: function () { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\nP: ' + this.p; + } + }; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/qr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/qr.js new file mode 100644 index 0000000..09aa2e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/qr.js @@ -0,0 +1,229 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createQr = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _factory = require("../../../utils/factory.js"); +const name = 'qr'; +const dependencies = ['typed', 'matrix', 'zeros', 'identity', 'isZero', 'equal', 'sign', 'sqrt', 'conj', 'unaryMinus', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'complex']; +const createQr = exports.createQr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + zeros, + identity, + isZero, + equal, + sign, + sqrt, + conj, + unaryMinus, + addScalar, + divideScalar, + multiplyScalar, + subtractScalar, + complex + } = _ref; + /** + * Calculate the Matrix QR decomposition. Matrix `A` is decomposed in + * two matrices (`Q`, `R`) where `Q` is an + * orthogonal matrix and `R` is an upper triangular matrix. + * + * Syntax: + * + * math.qr(A) + * + * Example: + * + * const m = [ + * [1, -1, 4], + * [1, 4, -2], + * [1, 4, 2], + * [1, -1, 0] + * ] + * const result = math.qr(m) + * // r = { + * // Q: [ + * // [0.5, -0.5, 0.5], + * // [0.5, 0.5, -0.5], + * // [0.5, 0.5, 0.5], + * // [0.5, -0.5, -0.5], + * // ], + * // R: [ + * // [2, 3, 2], + * // [0, 5, -2], + * // [0, 0, 4], + * // [0, 0, 0] + * // ] + * // } + * + * See also: + * + * lup, lusolve + * + * @param {Matrix | Array} A A two dimensional matrix or array + * for which to get the QR decomposition. + * + * @return {{Q: Array | Matrix, R: Array | Matrix}} Q: the orthogonal + * matrix and R: the upper triangular matrix + */ + return (0, _extends2.default)(typed(name, { + DenseMatrix: function (m) { + return _denseQR(m); + }, + SparseMatrix: function (m) { + return _sparseQR(m); + }, + Array: function (a) { + // create dense matrix from array + const m = matrix(a); + // lup, use matrix implementation + const r = _denseQR(m); + // result + return { + Q: r.Q.valueOf(), + R: r.R.valueOf() + }; + } + }), { + _denseQRimpl + }); + function _denseQRimpl(m) { + // rows & columns (m x n) + const rows = m._size[0]; // m + const cols = m._size[1]; // n + + const Q = identity([rows], 'dense'); + const Qdata = Q._data; + const R = m.clone(); + const Rdata = R._data; + + // vars + let i, j, k; + const w = zeros([rows], ''); + for (k = 0; k < Math.min(cols, rows); ++k) { + /* + * **k-th Household matrix** + * + * The matrix I - 2*v*transpose(v) + * x = first column of A + * x1 = first element of x + * alpha = x1 / |x1| * |x| + * e1 = tranpose([1, 0, 0, ...]) + * u = x - alpha * e1 + * v = u / |u| + * + * Household matrix = I - 2 * v * tranpose(v) + * + * * Initially Q = I and R = A. + * * Household matrix is a reflection in a plane normal to v which + * will zero out all but the top right element in R. + * * Appplying reflection to both Q and R will not change product. + * * Repeat this process on the (1,1) minor to get R as an upper + * triangular matrix. + * * Reflections leave the magnitude of the columns of Q unchanged + * so Q remains othoganal. + * + */ + + const pivot = Rdata[k][k]; + const sgn = unaryMinus(equal(pivot, 0) ? 1 : sign(pivot)); + const conjSgn = conj(sgn); + let alphaSquared = 0; + for (i = k; i < rows; i++) { + alphaSquared = addScalar(alphaSquared, multiplyScalar(Rdata[i][k], conj(Rdata[i][k]))); + } + const alpha = multiplyScalar(sgn, sqrt(alphaSquared)); + if (!isZero(alpha)) { + // first element in vector u + const u1 = subtractScalar(pivot, alpha); + + // w = v * u1 / |u| (only elements k to (rows-1) are used) + w[k] = 1; + for (i = k + 1; i < rows; i++) { + w[i] = divideScalar(Rdata[i][k], u1); + } + + // tau = - conj(u1 / alpha) + const tau = unaryMinus(conj(divideScalar(u1, alpha))); + let s; + + /* + * tau and w have been choosen so that + * + * 2 * v * tranpose(v) = tau * w * tranpose(w) + */ + + /* + * -- calculate R = R - tau * w * tranpose(w) * R -- + * Only do calculation with rows k to (rows-1) + * Additionally columns 0 to (k-1) will not be changed by this + * multiplication so do not bother recalculating them + */ + for (j = k; j < cols; j++) { + s = 0.0; + + // calculate jth element of [tranpose(w) * R] + for (i = k; i < rows; i++) { + s = addScalar(s, multiplyScalar(conj(w[i]), Rdata[i][j])); + } + + // calculate the jth element of [tau * transpose(w) * R] + s = multiplyScalar(s, tau); + for (i = k; i < rows; i++) { + Rdata[i][j] = multiplyScalar(subtractScalar(Rdata[i][j], multiplyScalar(w[i], s)), conjSgn); + } + } + /* + * -- calculate Q = Q - tau * Q * w * transpose(w) -- + * Q is a square matrix (rows x rows) + * Only do calculation with columns k to (rows-1) + * Additionally rows 0 to (k-1) will not be changed by this + * multiplication so do not bother recalculating them + */ + for (i = 0; i < rows; i++) { + s = 0.0; + + // calculate ith element of [Q * w] + for (j = k; j < rows; j++) { + s = addScalar(s, multiplyScalar(Qdata[i][j], w[j])); + } + + // calculate the ith element of [tau * Q * w] + s = multiplyScalar(s, tau); + for (j = k; j < rows; ++j) { + Qdata[i][j] = divideScalar(subtractScalar(Qdata[i][j], multiplyScalar(s, conj(w[j]))), conjSgn); + } + } + } + } + + // return matrices + return { + Q, + R, + toString: function () { + return 'Q: ' + this.Q.toString() + '\nR: ' + this.R.toString(); + } + }; + } + function _denseQR(m) { + const ret = _denseQRimpl(m); + const Rdata = ret.R._data; + if (m._data.length > 0) { + const zero = Rdata[0][0].type === 'Complex' ? complex(0) : 0; + for (let i = 0; i < Rdata.length; ++i) { + for (let j = 0; j < i && j < (Rdata[0] || []).length; ++j) { + Rdata[i][j] = zero; + } + } + } + return ret; + } + function _sparseQR(m) { + throw new Error('qr not implemented for sparse matrices yet'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/schur.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/schur.js new file mode 100644 index 0000000..a00a947 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/schur.js @@ -0,0 +1,76 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSchur = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'schur'; +const dependencies = ['typed', 'matrix', 'identity', 'multiply', 'qr', 'norm', 'subtract']; +const createSchur = exports.createSchur = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + identity, + multiply, + qr, + norm, + subtract + } = _ref; + /** + * + * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal + * and T is upper quasi-triangular. + * https://en.wikipedia.org/wiki/Schur_decomposition + * + * Syntax: + * + * math.schur(A) + * + * Examples: + * + * const A = [[1, 0], [-4, 3]] + * math.schur(A) // returns {T: [[3, 4], [0, 1]], R: [[0, 1], [-1, 0]]} + * + * See also: + * + * sylvester, lyap, qr + * + * @param {Array | Matrix} A Matrix A + * @return {{U: Array | Matrix, T: Array | Matrix}} Object containing both matrix U and T of the Schur Decomposition A=UTU' + */ + return typed(name, { + Array: function (X) { + const r = _schur(matrix(X)); + return { + U: r.U.valueOf(), + T: r.T.valueOf() + }; + }, + Matrix: function (X) { + return _schur(X); + } + }); + function _schur(X) { + const n = X.size()[0]; + let A = X; + let U = identity(n); + let k = 0; + let A0; + do { + A0 = A; + const QR = qr(A); + const Q = QR.Q; + const R = QR.R; + A = multiply(R, Q); + U = multiply(U, Q); + if (k++ > 100) { + break; + } + } while (norm(subtract(A, A0)) > 1e-4); + return { + U, + T: A + }; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/slu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/slu.js new file mode 100644 index 0000000..a471b82 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/decomposition/slu.js @@ -0,0 +1,107 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSlu = void 0; +var _number = require("../../../utils/number.js"); +var _factory = require("../../../utils/factory.js"); +var _csSqr = require("../sparse/csSqr.js"); +var _csLu = require("../sparse/csLu.js"); +const name = 'slu'; +const dependencies = ['typed', 'abs', 'add', 'multiply', 'transpose', 'divideScalar', 'subtract', 'larger', 'largerEq', 'SparseMatrix']; +const createSlu = exports.createSlu = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + add, + multiply, + transpose, + divideScalar, + subtract, + larger, + largerEq, + SparseMatrix + } = _ref; + const csSqr = (0, _csSqr.createCsSqr)({ + add, + multiply, + transpose + }); + const csLu = (0, _csLu.createCsLu)({ + abs, + divideScalar, + multiply, + subtract, + larger, + largerEq, + SparseMatrix + }); + + /** + * Calculate the Sparse Matrix LU decomposition with full pivoting. Sparse Matrix `A` is decomposed in two matrices (`L`, `U`) and two permutation vectors (`pinv`, `q`) where + * + * `P * A * Q = L * U` + * + * Syntax: + * + * math.slu(A, order, threshold) + * + * Examples: + * + * const A = math.sparse([[4,3], [6, 3]]) + * math.slu(A, 1, 0.001) + * // returns: + * // { + * // L: [[1, 0], [1.5, 1]] + * // U: [[4, 3], [0, -1.5]] + * // p: [0, 1] + * // q: [0, 1] + * // } + * + * See also: + * + * lup, lsolve, usolve, lusolve + * + * @param {SparseMatrix} A A two dimensional sparse matrix for which to get the LU decomposition. + * @param {Number} order The Symbolic Ordering and Analysis order: + * 0 - Natural ordering, no permutation vector q is returned + * 1 - Matrix must be square, symbolic ordering and analisis is performed on M = A + A' + * 2 - Symbolic ordering and analisis is performed on M = A' * A. Dense columns from A' are dropped, A recreated from A'. + * This is appropriatefor LU factorization of unsymmetric matrices. + * 3 - Symbolic ordering and analisis is performed on M = A' * A. This is best used for LU factorization is matrix M has no dense rows. + * A dense row is a row with more than 10*sqr(columns) entries. + * @param {Number} threshold Partial pivoting threshold (1 for partial pivoting) + * + * @return {Object} The lower triangular matrix, the upper triangular matrix and the permutation vectors. + */ + return typed(name, { + 'SparseMatrix, number, number': function (a, order, threshold) { + // verify order + if (!(0, _number.isInteger)(order) || order < 0 || order > 3) { + throw new Error('Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]'); + } + // verify threshold + if (threshold < 0 || threshold > 1) { + throw new Error('Partial pivoting threshold must be a number from 0 to 1'); + } + + // perform symbolic ordering and analysis + const s = csSqr(order, a, false); + + // perform lu decomposition + const f = csLu(a, s, threshold); + + // return decomposition + return { + L: f.L, + U: f.U, + p: f.pinv, + q: s.q, + toString: function () { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\np: ' + this.p.toString() + (this.q ? '\nq: ' + this.q.toString() : '') + '\n'; + } + }; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/derivative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/derivative.js new file mode 100644 index 0000000..5e12897 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/derivative.js @@ -0,0 +1,525 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDerivative = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +const name = 'derivative'; +const dependencies = ['typed', 'config', 'parse', 'simplify', 'equal', 'isZero', 'numeric', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +const createDerivative = exports.createDerivative = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + parse, + simplify, + equal, + isZero, + numeric, + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + /** + * Takes the derivative of an expression expressed in parser Nodes. + * The derivative will be taken over the supplied variable in the + * second parameter. If there are multiple variables in the expression, + * it will return a partial derivative. + * + * This uses rules of differentiation which can be found here: + * + * - [Differentiation rules (Wikipedia)](https://en.wikipedia.org/wiki/Differentiation_rules) + * + * Syntax: + * + * math.derivative(expr, variable) + * math.derivative(expr, variable, options) + * + * Examples: + * + * math.derivative('x^2', 'x') // Node '2 * x' + * math.derivative('x^2', 'x', {simplify: false}) // Node '2 * 1 * x ^ (2 - 1)' + * math.derivative('sin(2x)', 'x')) // Node '2 * cos(2 * x)' + * math.derivative('2*x', 'x').evaluate() // number 2 + * math.derivative('x^2', 'x').evaluate({x: 4}) // number 8 + * const f = math.parse('x^2') + * const x = math.parse('x') + * math.derivative(f, x) // Node {2 * x} + * + * See also: + * + * simplify, parse, evaluate + * + * @param {Node | string} expr The expression to differentiate + * @param {SymbolNode | string} variable The variable over which to differentiate + * @param {{simplify: boolean}} [options] + * There is one option available, `simplify`, which + * is true by default. When false, output will not + * be simplified. + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr` + */ + function plainDerivative(expr, variable) { + let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : { + simplify: true + }; + const constNodes = {}; + constTag(constNodes, expr, variable.name); + const res = _derivative(expr, constNodes); + return options.simplify ? simplify(res) : res; + } + function parseIdentifier(string) { + const symbol = parse(string); + if (!symbol.isSymbolNode) { + throw new TypeError('Invalid variable. ' + `Cannot parse ${JSON.stringify(string)} into a variable in function derivative`); + } + return symbol; + } + const derivative = typed(name, { + 'Node, SymbolNode': plainDerivative, + 'Node, SymbolNode, Object': plainDerivative, + 'Node, string': (node, symbol) => plainDerivative(node, parseIdentifier(symbol)), + 'Node, string, Object': (node, symbol, options) => plainDerivative(node, parseIdentifier(symbol), options) + + /* TODO: implement and test syntax with order of derivatives -> implement as an option {order: number} + 'Node, SymbolNode, ConstantNode': function (expr, variable, {order}) { + let res = expr + for (let i = 0; i < order; i++) { + let constNodes = {} + constTag(constNodes, expr, variable.name) + res = _derivative(res, constNodes) + } + return res + } + */ + }); + derivative._simplify = true; + derivative.toTex = function (deriv) { + return _derivTex.apply(null, deriv.args); + }; + + // FIXME: move the toTex method of derivative to latex.js. Difficulty is that it relies on parse. + // NOTE: the optional "order" parameter here is currently unused + const _derivTex = typed('_derivTex', { + 'Node, SymbolNode': function (expr, x) { + if ((0, _is.isConstantNode)(expr) && (0, _is.typeOf)(expr.value) === 'string') { + return _derivTex(parse(expr.value).toString(), x.toString(), 1); + } else { + return _derivTex(expr.toTex(), x.toString(), 1); + } + }, + 'Node, ConstantNode': function (expr, x) { + if ((0, _is.typeOf)(x.value) === 'string') { + return _derivTex(expr, parse(x.value)); + } else { + throw new Error("The second parameter to 'derivative' is a non-string constant"); + } + }, + 'Node, SymbolNode, ConstantNode': function (expr, x, order) { + return _derivTex(expr.toString(), x.name, order.value); + }, + 'string, string, number': function (expr, x, order) { + let d; + if (order === 1) { + d = '{d\\over d' + x + '}'; + } else { + d = '{d^{' + order + '}\\over d' + x + '^{' + order + '}}'; + } + return d + `\\left[${expr}\\right]`; + } + }); + + /** + * Does a depth-first search on the expression tree to identify what Nodes + * are constants (e.g. 2 + 2), and stores the ones that are constants in + * constNodes. Classification is done as follows: + * + * 1. ConstantNodes are constants. + * 2. If there exists a SymbolNode, of which we are differentiating over, + * in the subtree it is not constant. + * + * @param {Object} constNodes Holds the nodes that are constant + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {string} varName Variable that we are differentiating + * @return {boolean} if node is constant + */ + // TODO: can we rewrite constTag into a pure function? + const constTag = typed('constTag', { + 'Object, ConstantNode, string': function (constNodes, node) { + constNodes[node] = true; + return true; + }, + 'Object, SymbolNode, string': function (constNodes, node, varName) { + // Treat other variables like constants. For reasoning, see: + // https://en.wikipedia.org/wiki/Partial_derivative + if (node.name !== varName) { + constNodes[node] = true; + return true; + } + return false; + }, + 'Object, ParenthesisNode, string': function (constNodes, node, varName) { + return constTag(constNodes, node.content, varName); + }, + 'Object, FunctionAssignmentNode, string': function (constNodes, node, varName) { + if (!node.params.includes(varName)) { + constNodes[node] = true; + return true; + } + return constTag(constNodes, node.expr, varName); + }, + 'Object, FunctionNode | OperatorNode, string': function (constNodes, node, varName) { + if (node.args.length > 0) { + let isConst = constTag(constNodes, node.args[0], varName); + for (let i = 1; i < node.args.length; ++i) { + isConst = constTag(constNodes, node.args[i], varName) && isConst; + } + if (isConst) { + constNodes[node] = true; + return true; + } + } + return false; + } + }); + + /** + * Applies differentiation rules. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object} constNodes Holds the nodes that are constant + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr` + */ + const _derivative = typed('_derivative', { + 'ConstantNode, Object': function (node) { + return createConstantNode(0); + }, + 'SymbolNode, Object': function (node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + return createConstantNode(1); + }, + 'ParenthesisNode, Object': function (node, constNodes) { + return new ParenthesisNode(_derivative(node.content, constNodes)); + }, + 'FunctionAssignmentNode, Object': function (node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + return _derivative(node.expr, constNodes); + }, + 'FunctionNode, Object': function (node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + const arg0 = node.args[0]; + let arg1; + let div = false; // is output a fraction? + let negative = false; // is output negative? + + let funcDerivative; + switch (node.name) { + case 'cbrt': + // d/dx(cbrt(x)) = 1 / (3x^(2/3)) + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(3), new OperatorNode('^', 'pow', [arg0, new OperatorNode('/', 'divide', [createConstantNode(2), createConstantNode(3)])])]); + break; + case 'sqrt': + case 'nthRoot': + // d/dx(sqrt(x)) = 1 / (2*sqrt(x)) + if (node.args.length === 1) { + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(2), new FunctionNode('sqrt', [arg0])]); + } else if (node.args.length === 2) { + // Rearrange from nthRoot(x, a) -> x^(1/a) + arg1 = new OperatorNode('/', 'divide', [createConstantNode(1), node.args[1]]); + + // Is a variable? + constNodes[arg1] = constNodes[node.args[1]]; + return _derivative(new OperatorNode('^', 'pow', [arg0, arg1]), constNodes); + } + break; + case 'log10': + arg1 = createConstantNode(10); + /* fall through! */ + case 'log': + if (!arg1 && node.args.length === 1) { + // d/dx(log(x)) = 1 / x + funcDerivative = arg0.clone(); + div = true; + } else if (node.args.length === 1 && arg1 || node.args.length === 2 && constNodes[node.args[1]] !== undefined) { + // d/dx(log(x, c)) = 1 / (x*ln(c)) + funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('log', [arg1 || node.args[1]])]); + div = true; + } else if (node.args.length === 2) { + // d/dx(log(f(x), g(x))) = d/dx(log(f(x)) / log(g(x))) + return _derivative(new OperatorNode('/', 'divide', [new FunctionNode('log', [arg0]), new FunctionNode('log', [node.args[1]])]), constNodes); + } + break; + case 'pow': + if (node.args.length === 2) { + constNodes[arg1] = constNodes[node.args[1]]; + // Pass to pow operator node parser + return _derivative(new OperatorNode('^', 'pow', [arg0, node.args[1]]), constNodes); + } + break; + case 'exp': + // d/dx(e^x) = e^x + funcDerivative = new FunctionNode('exp', [arg0.clone()]); + break; + case 'sin': + // d/dx(sin(x)) = cos(x) + funcDerivative = new FunctionNode('cos', [arg0.clone()]); + break; + case 'cos': + // d/dx(cos(x)) = -sin(x) + funcDerivative = new OperatorNode('-', 'unaryMinus', [new FunctionNode('sin', [arg0.clone()])]); + break; + case 'tan': + // d/dx(tan(x)) = sec(x)^2 + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sec', [arg0.clone()]), createConstantNode(2)]); + break; + case 'sec': + // d/dx(sec(x)) = sec(x)tan(x) + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tan', [arg0.clone()])]); + break; + case 'csc': + // d/dx(csc(x)) = -csc(x)cot(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('cot', [arg0.clone()])]); + break; + case 'cot': + // d/dx(cot(x)) = -csc(x)^2 + negative = true; + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csc', [arg0.clone()]), createConstantNode(2)]); + break; + case 'asin': + // d/dx(asin(x)) = 1 / sqrt(1 - x^2) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]); + break; + case 'acos': + // d/dx(acos(x)) = -1 / sqrt(1 - x^2) + div = true; + negative = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]); + break; + case 'atan': + // d/dx(atan(x)) = 1 / (x^2 + 1) + div = true; + funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]); + break; + case 'asec': + // d/dx(asec(x)) = 1 / (|x|*sqrt(x^2 - 1)) + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acsc': + // d/dx(acsc(x)) = -1 / (|x|*sqrt(x^2 - 1)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acot': + // d/dx(acot(x)) = -1 / (x^2 + 1) + div = true; + negative = true; + funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]); + break; + case 'sinh': + // d/dx(sinh(x)) = cosh(x) + funcDerivative = new FunctionNode('cosh', [arg0.clone()]); + break; + case 'cosh': + // d/dx(cosh(x)) = sinh(x) + funcDerivative = new FunctionNode('sinh', [arg0.clone()]); + break; + case 'tanh': + // d/dx(tanh(x)) = sech(x)^2 + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sech', [arg0.clone()]), createConstantNode(2)]); + break; + case 'sech': + // d/dx(sech(x)) = -sech(x)tanh(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tanh', [arg0.clone()])]); + break; + case 'csch': + // d/dx(csch(x)) = -csch(x)coth(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('coth', [arg0.clone()])]); + break; + case 'coth': + // d/dx(coth(x)) = -csch(x)^2 + negative = true; + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csch', [arg0.clone()]), createConstantNode(2)]); + break; + case 'asinh': + // d/dx(asinh(x)) = 1 / sqrt(x^2 + 1) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]); + break; + case 'acosh': + // d/dx(acosh(x)) = 1 / sqrt(x^2 - 1); XXX potentially only for x >= 1 (the real spectrum) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]); + break; + case 'atanh': + // d/dx(atanh(x)) = 1 / (1 - x^2) + div = true; + funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]); + break; + case 'asech': + // d/dx(asech(x)) = -1 / (x*sqrt(1 - x^2)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])])]); + break; + case 'acsch': + // d/dx(acsch(x)) = -1 / (|x|*sqrt(x^2 + 1)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acoth': + // d/dx(acoth(x)) = -1 / (1 - x^2) + div = true; + negative = true; + funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]); + break; + case 'abs': + // d/dx(abs(x)) = abs(x)/x + funcDerivative = new OperatorNode('/', 'divide', [new FunctionNode(new SymbolNode('abs'), [arg0.clone()]), arg0.clone()]); + break; + case 'gamma': // Needs digamma function, d/dx(gamma(x)) = gamma(x)digamma(x) + default: + throw new Error('Cannot process function "' + node.name + '" in derivative: ' + 'the function is not supported, undefined, or the number of arguments passed to it are not supported'); + } + let op, func; + if (div) { + op = '/'; + func = 'divide'; + } else { + op = '*'; + func = 'multiply'; + } + + /* Apply chain rule to all functions: + F(x) = f(g(x)) + F'(x) = g'(x)*f'(g(x)) */ + let chainDerivative = _derivative(arg0, constNodes); + if (negative) { + chainDerivative = new OperatorNode('-', 'unaryMinus', [chainDerivative]); + } + return new OperatorNode(op, func, [chainDerivative, funcDerivative]); + }, + 'OperatorNode, Object': function (node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + if (node.op === '+') { + // d/dx(sum(f(x)) = sum(f'(x)) + return new OperatorNode(node.op, node.fn, node.args.map(function (arg) { + return _derivative(arg, constNodes); + })); + } + if (node.op === '-') { + // d/dx(+/-f(x)) = +/-f'(x) + if (node.isUnary()) { + return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes)]); + } + + // Linearity of differentiation, d/dx(f(x) +/- g(x)) = f'(x) +/- g'(x) + if (node.isBinary()) { + return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes), _derivative(node.args[1], constNodes)]); + } + } + if (node.op === '*') { + // d/dx(c*f(x)) = c*f'(x) + const constantTerms = node.args.filter(function (arg) { + return constNodes[arg] !== undefined; + }); + if (constantTerms.length > 0) { + const nonConstantTerms = node.args.filter(function (arg) { + return constNodes[arg] === undefined; + }); + const nonConstantNode = nonConstantTerms.length === 1 ? nonConstantTerms[0] : new OperatorNode('*', 'multiply', nonConstantTerms); + const newArgs = constantTerms.concat(_derivative(nonConstantNode, constNodes)); + return new OperatorNode('*', 'multiply', newArgs); + } + + // Product Rule, d/dx(f(x)*g(x)) = f'(x)*g(x) + f(x)*g'(x) + return new OperatorNode('+', 'add', node.args.map(function (argOuter) { + return new OperatorNode('*', 'multiply', node.args.map(function (argInner) { + return argInner === argOuter ? _derivative(argInner, constNodes) : argInner.clone(); + })); + })); + } + if (node.op === '/' && node.isBinary()) { + const arg0 = node.args[0]; + const arg1 = node.args[1]; + + // d/dx(f(x) / c) = f'(x) / c + if (constNodes[arg1] !== undefined) { + return new OperatorNode('/', 'divide', [_derivative(arg0, constNodes), arg1]); + } + + // Reciprocal Rule, d/dx(c / f(x)) = -c(f'(x)/f(x)^2) + if (constNodes[arg0] !== undefined) { + return new OperatorNode('*', 'multiply', [new OperatorNode('-', 'unaryMinus', [arg0]), new OperatorNode('/', 'divide', [_derivative(arg1, constNodes), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])])]); + } + + // Quotient rule, d/dx(f(x) / g(x)) = (f'(x)g(x) - f(x)g'(x)) / g(x)^2 + return new OperatorNode('/', 'divide', [new OperatorNode('-', 'subtract', [new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), arg1.clone()]), new OperatorNode('*', 'multiply', [arg0.clone(), _derivative(arg1, constNodes)])]), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])]); + } + if (node.op === '^' && node.isBinary()) { + const arg0 = node.args[0]; + const arg1 = node.args[1]; + if (constNodes[arg0] !== undefined) { + // If is secretly constant; 0^f(x) = 1 (in JS), 1^f(x) = 1 + if ((0, _is.isConstantNode)(arg0) && (isZero(arg0.value) || equal(arg0.value, 1))) { + return createConstantNode(0); + } + + // d/dx(c^f(x)) = c^f(x)*ln(c)*f'(x) + return new OperatorNode('*', 'multiply', [node, new OperatorNode('*', 'multiply', [new FunctionNode('log', [arg0.clone()]), _derivative(arg1.clone(), constNodes)])]); + } + if (constNodes[arg1] !== undefined) { + if ((0, _is.isConstantNode)(arg1)) { + // If is secretly constant; f(x)^0 = 1 -> d/dx(1) = 0 + if (isZero(arg1.value)) { + return createConstantNode(0); + } + // Ignore exponent; f(x)^1 = f(x) + if (equal(arg1.value, 1)) { + return _derivative(arg0, constNodes); + } + } + + // Elementary Power Rule, d/dx(f(x)^c) = c*f'(x)*f(x)^(c-1) + const powMinusOne = new OperatorNode('^', 'pow', [arg0.clone(), new OperatorNode('-', 'subtract', [arg1, createConstantNode(1)])]); + return new OperatorNode('*', 'multiply', [arg1.clone(), new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), powMinusOne])]); + } + + // Functional Power Rule, d/dx(f^g) = f^g*[f'*(g/f) + g'ln(f)] + return new OperatorNode('*', 'multiply', [new OperatorNode('^', 'pow', [arg0.clone(), arg1.clone()]), new OperatorNode('+', 'add', [new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), new OperatorNode('/', 'divide', [arg1.clone(), arg0.clone()])]), new OperatorNode('*', 'multiply', [_derivative(arg1, constNodes), new FunctionNode('log', [arg0.clone()])])])]); + } + throw new Error('Cannot process operator "' + node.op + '" in derivative: ' + 'the operator is not supported, undefined, or the number of arguments passed to it are not supported'); + } + }); + + /** + * Helper function to create a constant node with a specific type + * (number, BigNumber, Fraction) + * @param {number} value + * @param {string} [valueType] + * @return {ConstantNode} + */ + function createConstantNode(value, valueType) { + return new ConstantNode(numeric(value, valueType || (0, _number.safeNumberType)(String(value), config))); + } + return derivative; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/leafCount.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/leafCount.js new file mode 100644 index 0000000..bb6d65a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/leafCount.js @@ -0,0 +1,60 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLeafCount = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'leafCount'; +const dependencies = ['parse', 'typed']; +const createLeafCount = exports.createLeafCount = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + parse, + typed + } = _ref; + // This does the real work, but we don't have to recurse through + // a typed call if we separate it out + function countLeaves(node) { + let count = 0; + node.forEach(n => { + count += countLeaves(n); + }); + return count || 1; + } + + /** + * Gives the number of "leaf nodes" in the parse tree of the given expression + * A leaf node is one that has no subexpressions, essentially either a + * symbol or a constant. Note that `5!` has just one leaf, the '5'; the + * unary factorial operator does not add a leaf. On the other hand, + * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves. + * + * The `simplify()` function should generally not increase the `leafCount()` + * of an expression, although currently there is no guarantee that it never + * does so. In many cases, `simplify()` reduces the leaf count. + * + * Syntax: + * + * math.leafCount(expr) + * + * Examples: + * + * math.leafCount('x') // 1 + * math.leafCount(math.parse('a*d-b*c')) // 4 + * math.leafCount('[a,b;c,d][0,1]') // 6 + * + * See also: + * + * simplify + * + * @param {Node|string} expr The expression to count the leaves of + * + * @return {number} The number of leaves of `expr` + * + */ + return typed(name, { + Node: function (expr) { + return countLeaves(expr); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/lyap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/lyap.js new file mode 100644 index 0000000..1548e7b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/lyap.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLyap = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'lyap'; +const dependencies = ['typed', 'matrix', 'sylvester', 'multiply', 'transpose']; +const createLyap = exports.createLyap = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + sylvester, + multiply, + transpose + } = _ref; + /** + * + * Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P, where + * Q is an input matrix. When Q is symmetric, P is also symmetric. Notice + * that different equivalent definitions exist for the Continuous-time + * Lyapunov equation. + * https://en.wikipedia.org/wiki/Lyapunov_equation + * + * Syntax: + * + * math.lyap(A, Q) + * + * Examples: + * + * const A = [[-2, 0], [1, -4]] + * const Q = [[3, 1], [1, 3]] + * const P = math.lyap(A, Q) + * + * See also: + * + * sylvester, schur + * + * @param {Matrix | Array} A Matrix A + * @param {Matrix | Array} Q Matrix Q + * @return {Matrix | Array} Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q + */ + return typed(name, { + 'Matrix, Matrix': function (A, Q) { + return sylvester(A, transpose(A), multiply(-1, Q)); + }, + 'Array, Matrix': function (A, Q) { + return sylvester(matrix(A), transpose(matrix(A)), multiply(-1, Q)); + }, + 'Matrix, Array': function (A, Q) { + return sylvester(A, transpose(matrix(A)), matrix(multiply(-1, Q))); + }, + 'Array, Array': function (A, Q) { + return sylvester(matrix(A), transpose(matrix(A)), matrix(multiply(-1, Q))).toArray(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/polynomialRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/polynomialRoot.js new file mode 100644 index 0000000..dc7ec39 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/polynomialRoot.js @@ -0,0 +1,128 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPolynomialRoot = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'polynomialRoot'; +const dependencies = ['typed', 'isZero', 'equalScalar', 'add', 'subtract', 'multiply', 'divide', 'sqrt', 'unaryMinus', 'cbrt', 'typeOf', 'im', 're']; +const createPolynomialRoot = exports.createPolynomialRoot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isZero, + equalScalar, + add, + subtract, + multiply, + divide, + sqrt, + unaryMinus, + cbrt, + typeOf, + im, + re + } = _ref; + /** + * Finds the numerical values of the distinct roots of a polynomial with real or complex coefficients. + * Currently operates only on linear, quadratic, and cubic polynomials using the standard + * formulas for the roots. + * + * Syntax: + * + * math.polynomialRoot(constant, linearCoeff, quadraticCoeff, cubicCoeff) + * + * Examples: + * // linear + * math.polynomialRoot(6, 3) // [-2] + * math.polynomialRoot(math.complex(6,3), 3) // [-2 - i] + * math.polynomialRoot(math.complex(6,3), math.complex(2,1)) // [-3 + 0i] + * // quadratic + * math.polynomialRoot(2, -3, 1) // [2, 1] + * math.polynomialRoot(8, 8, 2) // [-2] + * math.polynomialRoot(-2, 0, 1) // [1.4142135623730951, -1.4142135623730951] + * math.polynomialRoot(2, -2, 1) // [1 + i, 1 - i] + * math.polynomialRoot(math.complex(1,3), math.complex(-3, -2), 1) // [2 + i, 1 + i] + * // cubic + * math.polynomialRoot(-6, 11, -6, 1) // [1, 3, 2] + * math.polynomialRoot(-8, 0, 0, 1) // [-1 - 1.7320508075688774i, 2, -1 + 1.7320508075688774i] + * math.polynomialRoot(0, 8, 8, 2) // [0, -2] + * math.polynomialRoot(1, 1, 1, 1) // [-1 + 0i, 0 - i, 0 + i] + * + * See also: + * cbrt, sqrt + * + * @param {... number | Complex} coeffs + * The coefficients of the polynomial, starting with with the constant coefficent, followed + * by the linear coefficient and subsequent coefficients of increasing powers. + * @return {Array} The distinct roots of the polynomial + */ + + return typed(name, { + 'number|Complex, ...number|Complex': (constant, restCoeffs) => { + const coeffs = [constant, ...restCoeffs]; + while (coeffs.length > 0 && isZero(coeffs[coeffs.length - 1])) { + coeffs.pop(); + } + if (coeffs.length < 2) { + throw new RangeError(`Polynomial [${constant}, ${restCoeffs}] must have a non-zero non-constant coefficient`); + } + switch (coeffs.length) { + case 2: + // linear + return [unaryMinus(divide(coeffs[0], coeffs[1]))]; + case 3: + { + // quadratic + const [c, b, a] = coeffs; + const denom = multiply(2, a); + const d1 = multiply(b, b); + const d2 = multiply(4, a, c); + if (equalScalar(d1, d2)) return [divide(unaryMinus(b), denom)]; + const discriminant = sqrt(subtract(d1, d2)); + return [divide(subtract(discriminant, b), denom), divide(subtract(unaryMinus(discriminant), b), denom)]; + } + case 4: + { + // cubic, cf. https://en.wikipedia.org/wiki/Cubic_equation + const [d, c, b, a] = coeffs; + const denom = unaryMinus(multiply(3, a)); + const D0_1 = multiply(b, b); + const D0_2 = multiply(3, a, c); + const D1_1 = add(multiply(2, b, b, b), multiply(27, a, a, d)); + const D1_2 = multiply(9, a, b, c); + if (equalScalar(D0_1, D0_2) && equalScalar(D1_1, D1_2)) { + return [divide(b, denom)]; + } + const Delta0 = subtract(D0_1, D0_2); + const Delta1 = subtract(D1_1, D1_2); + const discriminant1 = add(multiply(18, a, b, c, d), multiply(b, b, c, c)); + const discriminant2 = add(multiply(4, b, b, b, d), multiply(4, a, c, c, c), multiply(27, a, a, d, d)); + if (equalScalar(discriminant1, discriminant2)) { + return [divide(subtract(multiply(4, a, b, c), add(multiply(9, a, a, d), multiply(b, b, b))), multiply(a, Delta0)), + // simple root + divide(subtract(multiply(9, a, d), multiply(b, c)), multiply(2, Delta0)) // double root + ]; + } + // OK, we have three distinct roots + let Ccubed; + if (equalScalar(D0_1, D0_2)) { + Ccubed = Delta1; + } else { + Ccubed = divide(add(Delta1, sqrt(subtract(multiply(Delta1, Delta1), multiply(4, Delta0, Delta0, Delta0)))), 2); + } + const allRoots = true; + const rawRoots = cbrt(Ccubed, allRoots).toArray().map(C => divide(add(b, C, divide(Delta0, C)), denom)); + return rawRoots.map(r => { + if (typeOf(r) === 'Complex' && equalScalar(re(r), re(r) + im(r))) { + return re(r); + } + return r; + }); + } + default: + throw new RangeError(`only implemented for cubic or lower-order polynomials, not ${coeffs}`); + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/rationalize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/rationalize.js new file mode 100644 index 0000000..49ea9a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/rationalize.js @@ -0,0 +1,825 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRationalize = void 0; +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'rationalize'; +const dependencies = ['config', 'typed', 'equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'parse', 'simplifyConstant', 'simplifyCore', 'simplify', '?bignumber', '?fraction', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode', 'ParenthesisNode']; +const createRationalize = exports.createRationalize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + typed, + equal, + isZero, + add, + subtract, + multiply, + divide, + pow, + parse, + simplifyConstant, + simplifyCore, + simplify, + fraction, + bignumber, + mathWithTransform, + matrix, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + ParenthesisNode + } = _ref; + /** + * Transform a rationalizable expression in a rational fraction. + * If rational fraction is one variable polynomial then converts + * the numerator and denominator in canonical form, with decreasing + * exponents, returning the coefficients of numerator. + * + * Syntax: + * + * math.rationalize(expr) + * math.rationalize(expr, detailed) + * math.rationalize(expr, scope) + * math.rationalize(expr, scope, detailed) + * + * Examples: + * + * math.rationalize('sin(x)+y') + * // Error: There is an unsolved function call + * math.rationalize('2x/y - y/(x+1)') + * // (2*x^2-y^2+2*x)/(x*y+y) + * math.rationalize('(2x+1)^6') + * // 64*x^6+192*x^5+240*x^4+160*x^3+60*x^2+12*x+1 + * math.rationalize('2x/( (2x-1) / (3x+2) ) - 5x/ ( (3x+4) / (2x^2-5) ) + 3') + * // -20*x^4+28*x^3+104*x^2+6*x-12)/(6*x^2+5*x-4) + * math.rationalize('x/(1-x)/(x-2)/(x-3)/(x-4) + 2x/ ( (1-2x)/(2-3x) )/ ((3-4x)/(4-5x) )') = + * // (-30*x^7+344*x^6-1506*x^5+3200*x^4-3472*x^3+1846*x^2-381*x)/ + * // (-8*x^6+90*x^5-383*x^4+780*x^3-797*x^2+390*x-72) + * + * math.rationalize('x+x+x+y',{y:1}) // 3*x+1 + * math.rationalize('x+x+x+y',{}) // 3*x+y + * + * const ret = math.rationalize('x+x+x+y',{},true) + * // ret.expression=3*x+y, ret.variables = ["x","y"] + * const ret = math.rationalize('-2+5x^2',{},true) + * // ret.expression=5*x^2-2, ret.variables = ["x"], ret.coefficients=[-2,0,5] + * + * See also: + * + * simplify + * + * @param {Node|string} expr The expression to check if is a polynomial expression + * @param {Object|boolean} optional scope of expression or true for already evaluated rational expression at input + * @param {Boolean} detailed optional True if return an object, false if return expression node (default) + * + * @return {Object | Node} The rational polynomial of `expr` or an object + * `{expression, numerator, denominator, variables, coefficients}`, where + * `expression` is a `Node` with the node simplified expression, + * `numerator` is a `Node` with the simplified numerator of expression, + * `denominator` is a `Node` or `boolean` with the simplified denominator or `false` (if there is no denominator), + * `variables` is an array with variable names, + * and `coefficients` is an array with coefficients of numerator sorted by increased exponent + * {Expression Node} node simplified expression + * + */ + function _rationalize(expr) { + let scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + let detailed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + const setRules = rulesRationalize(); // Rules for change polynomial in near canonical form + const polyRet = polynomial(expr, scope, true, setRules.firstRules); // Check if expression is a rationalizable polynomial + const nVars = polyRet.variables.length; + const noExactFractions = { + exactFractions: false + }; + const withExactFractions = { + exactFractions: true + }; + expr = polyRet.expression; + if (nVars >= 1) { + // If expression in not a constant + expr = expandPower(expr); // First expand power of polynomials (cannot be made from rules!) + let sBefore; // Previous expression + let rules; + let eDistrDiv = true; + let redoInic = false; + // Apply the initial rules, including succ div rules: + expr = simplify(expr, setRules.firstRules, {}, noExactFractions); + let s; + while (true) { + // Alternate applying successive division rules and distr.div.rules + // until there are no more changes: + rules = eDistrDiv ? setRules.distrDivRules : setRules.sucDivRules; + expr = simplify(expr, rules, {}, withExactFractions); + eDistrDiv = !eDistrDiv; // Swap between Distr.Div and Succ. Div. Rules + + s = expr.toString(); + if (s === sBefore) { + break; // No changes : end of the loop + } + redoInic = true; + sBefore = s; + } + if (redoInic) { + // Apply first rules again without succ div rules (if there are changes) + expr = simplify(expr, setRules.firstRulesAgain, {}, noExactFractions); + } + // Apply final rules: + expr = simplify(expr, setRules.finalRules, {}, noExactFractions); + } // NVars >= 1 + + const coefficients = []; + const retRationalize = {}; + if (expr.type === 'OperatorNode' && expr.isBinary() && expr.op === '/') { + // Separate numerator from denominator + if (nVars === 1) { + expr.args[0] = polyToCanonical(expr.args[0], coefficients); + expr.args[1] = polyToCanonical(expr.args[1]); + } + if (detailed) { + retRationalize.numerator = expr.args[0]; + retRationalize.denominator = expr.args[1]; + } + } else { + if (nVars === 1) { + expr = polyToCanonical(expr, coefficients); + } + if (detailed) { + retRationalize.numerator = expr; + retRationalize.denominator = null; + } + } + // nVars + + if (!detailed) return expr; + retRationalize.coefficients = coefficients; + retRationalize.variables = polyRet.variables; + retRationalize.expression = expr; + return retRationalize; + } + return typed(name, { + Node: _rationalize, + 'Node, boolean': (expr, detailed) => _rationalize(expr, {}, detailed), + 'Node, Object': _rationalize, + 'Node, Object, boolean': _rationalize + }); // end of typed rationalize + + /** + * Function to simplify an expression using an optional scope and + * return it if the expression is a polynomial expression, i.e. + * an expression with one or more variables and the operators + * +, -, *, and ^, where the exponent can only be a positive integer. + * + * Syntax: + * + * polynomial(expr,scope,extended, rules) + * + * @param {Node | string} expr The expression to simplify and check if is polynomial expression + * @param {object} scope Optional scope for expression simplification + * @param {boolean} extended Optional. Default is false. When true allows divide operator. + * @param {array} rules Optional. Default is no rule. + * + * + * @return {Object} + * {Object} node: node simplified expression + * {Array} variables: variable names + */ + function polynomial(expr, scope, extended, rules) { + const variables = []; + const node = simplify(expr, rules, scope, { + exactFractions: false + }); // Resolves any variables and functions with all defined parameters + extended = !!extended; + const oper = '+-*' + (extended ? '/' : ''); + recPoly(node); + const retFunc = {}; + retFunc.expression = node; + retFunc.variables = variables; + return retFunc; + + // ------------------------------------------------------------------------------------------------------- + + /** + * Function to simplify an expression using an optional scope and + * return it if the expression is a polynomial expression, i.e. + * an expression with one or more variables and the operators + * +, -, *, and ^, where the exponent can only be a positive integer. + * + * Syntax: + * + * recPoly(node) + * + * + * @param {Node} node The current sub tree expression in recursion + * + * @return nothing, throw an exception if error + */ + function recPoly(node) { + const tp = node.type; // node type + if (tp === 'FunctionNode') { + // No function call in polynomial expression + throw new Error('There is an unsolved function call'); + } else if (tp === 'OperatorNode') { + if (node.op === '^') { + // TODO: handle negative exponents like in '1/x^(-2)' + if (node.args[1].type !== 'ConstantNode' || !(0, _number.isInteger)(parseFloat(node.args[1].value))) { + throw new Error('There is a non-integer exponent'); + } else { + recPoly(node.args[0]); + } + } else { + if (!oper.includes(node.op)) { + throw new Error('Operator ' + node.op + ' invalid in polynomial expression'); + } + for (let i = 0; i < node.args.length; i++) { + recPoly(node.args[i]); + } + } // type of operator + } else if (tp === 'SymbolNode') { + const name = node.name; // variable name + const pos = variables.indexOf(name); + if (pos === -1) { + // new variable in expression + variables.push(name); + } + } else if (tp === 'ParenthesisNode') { + recPoly(node.content); + } else if (tp !== 'ConstantNode') { + throw new Error('type ' + tp + ' is not allowed in polynomial expression'); + } + } // end of recPoly + } // end of polynomial + + // --------------------------------------------------------------------------------------- + /** + * Return a rule set to rationalize an polynomial expression in rationalize + * + * Syntax: + * + * rulesRationalize() + * + * @return {array} rule set to rationalize an polynomial expression + */ + function rulesRationalize() { + const oldRules = [simplifyCore, + // sCore + { + l: 'n+n', + r: '2*n' + }, { + l: 'n+-n', + r: '0' + }, simplifyConstant, + // sConstant + { + l: 'n*(n1^-1)', + r: 'n/n1' + }, { + l: 'n*n1^-n2', + r: 'n/n1^n2' + }, { + l: 'n1^-1', + r: '1/n1' + }, { + l: 'n*(n1/n2)', + r: '(n*n1)/n2' + }, { + l: '1*n', + r: 'n' + }]; + const rulesFirst = [{ + l: '(-n1)/(-n2)', + r: 'n1/n2' + }, + // Unary division + { + l: '(-n1)*(-n2)', + r: 'n1*n2' + }, + // Unary multiplication + { + l: 'n1--n2', + r: 'n1+n2' + }, + // '--' elimination + { + l: 'n1-n2', + r: 'n1+(-n2)' + }, + // Subtraction turn into add with un�ry minus + { + l: '(n1+n2)*n3', + r: '(n1*n3 + n2*n3)' + }, + // Distributive 1 + { + l: 'n1*(n2+n3)', + r: '(n1*n2+n1*n3)' + }, + // Distributive 2 + { + l: 'c1*n + c2*n', + r: '(c1+c2)*n' + }, + // Joining constants + { + l: 'c1*n + n', + r: '(c1+1)*n' + }, + // Joining constants + { + l: 'c1*n - c2*n', + r: '(c1-c2)*n' + }, + // Joining constants + { + l: 'c1*n - n', + r: '(c1-1)*n' + }, + // Joining constants + { + l: 'v/c', + r: '(1/c)*v' + }, + // variable/constant (new!) + { + l: 'v/-c', + r: '-(1/c)*v' + }, + // variable/constant (new!) + { + l: '-v*-c', + r: 'c*v' + }, + // Inversion constant and variable 1 + { + l: '-v*c', + r: '-c*v' + }, + // Inversion constant and variable 2 + { + l: 'v*-c', + r: '-c*v' + }, + // Inversion constant and variable 3 + { + l: 'v*c', + r: 'c*v' + }, + // Inversion constant and variable 4 + { + l: '-(-n1*n2)', + r: '(n1*n2)' + }, + // Unary propagation + { + l: '-(n1*n2)', + r: '(-n1*n2)' + }, + // Unary propagation + { + l: '-(-n1+n2)', + r: '(n1-n2)' + }, + // Unary propagation + { + l: '-(n1+n2)', + r: '(-n1-n2)' + }, + // Unary propagation + { + l: '(n1^n2)^n3', + r: '(n1^(n2*n3))' + }, + // Power to Power + { + l: '-(-n1/n2)', + r: '(n1/n2)' + }, + // Division and Unary + { + l: '-(n1/n2)', + r: '(-n1/n2)' + }]; // Divisao and Unary + + const rulesDistrDiv = [{ + l: '(n1/n2 + n3/n4)', + r: '((n1*n4 + n3*n2)/(n2*n4))' + }, + // Sum of fractions + { + l: '(n1/n2 + n3)', + r: '((n1 + n3*n2)/n2)' + }, + // Sum fraction with number 1 + { + l: '(n1 + n2/n3)', + r: '((n1*n3 + n2)/n3)' + }]; // Sum fraction with number 1 + + const rulesSucDiv = [{ + l: '(n1/(n2/n3))', + r: '((n1*n3)/n2)' + }, + // Division simplification + { + l: '(n1/n2/n3)', + r: '(n1/(n2*n3))' + }]; + const setRules = {}; // rules set in 4 steps. + + // All rules => infinite loop + // setRules.allRules =oldRules.concat(rulesFirst,rulesDistrDiv,rulesSucDiv) + + setRules.firstRules = oldRules.concat(rulesFirst, rulesSucDiv); // First rule set + setRules.distrDivRules = rulesDistrDiv; // Just distr. div. rules + setRules.sucDivRules = rulesSucDiv; // Jus succ. div. rules + setRules.firstRulesAgain = oldRules.concat(rulesFirst); // Last rules set without succ. div. + + // Division simplification + + // Second rule set. + // There is no aggregate expression with parentesis, but the only variable can be scattered. + setRules.finalRules = [simplifyCore, + // simplify.rules[0] + { + l: 'n*-n', + r: '-n^2' + }, + // Joining multiply with power 1 + { + l: 'n*n', + r: 'n^2' + }, + // Joining multiply with power 2 + simplifyConstant, + // simplify.rules[14] old 3rd index in oldRules + { + l: 'n*-n^n1', + r: '-n^(n1+1)' + }, + // Joining multiply with power 3 + { + l: 'n*n^n1', + r: 'n^(n1+1)' + }, + // Joining multiply with power 4 + { + l: 'n^n1*-n^n2', + r: '-n^(n1+n2)' + }, + // Joining multiply with power 5 + { + l: 'n^n1*n^n2', + r: 'n^(n1+n2)' + }, + // Joining multiply with power 6 + { + l: 'n^n1*-n', + r: '-n^(n1+1)' + }, + // Joining multiply with power 7 + { + l: 'n^n1*n', + r: 'n^(n1+1)' + }, + // Joining multiply with power 8 + { + l: 'n^n1/-n', + r: '-n^(n1-1)' + }, + // Joining multiply with power 8 + { + l: 'n^n1/n', + r: 'n^(n1-1)' + }, + // Joining division with power 1 + { + l: 'n/-n^n1', + r: '-n^(1-n1)' + }, + // Joining division with power 2 + { + l: 'n/n^n1', + r: 'n^(1-n1)' + }, + // Joining division with power 3 + { + l: 'n^n1/-n^n2', + r: 'n^(n1-n2)' + }, + // Joining division with power 4 + { + l: 'n^n1/n^n2', + r: 'n^(n1-n2)' + }, + // Joining division with power 5 + { + l: 'n1+(-n2*n3)', + r: 'n1-n2*n3' + }, + // Solving useless parenthesis 1 + { + l: 'v*(-c)', + r: '-c*v' + }, + // Solving useless unary 2 + { + l: 'n1+-n2', + r: 'n1-n2' + }, + // Solving +- together (new!) + { + l: 'v*c', + r: 'c*v' + }, + // inversion constant with variable + { + l: '(n1^n2)^n3', + r: '(n1^(n2*n3))' + } // Power to Power + ]; + return setRules; + } // End rulesRationalize + + // --------------------------------------------------------------------------------------- + /** + * Expand recursively a tree node for handling with expressions with exponents + * (it's not for constants, symbols or functions with exponents) + * PS: The other parameters are internal for recursion + * + * Syntax: + * + * expandPower(node) + * + * @param {Node} node Current expression node + * @param {node} parent Parent current node inside the recursion + * @param (int} Parent number of chid inside the rercursion + * + * @return {node} node expression with all powers expanded. + */ + function expandPower(node, parent, indParent) { + const tp = node.type; + const internal = arguments.length > 1; // TRUE in internal calls + + if (tp === 'OperatorNode' && node.isBinary()) { + let does = false; + let val; + if (node.op === '^') { + // First operator: Parenthesis or UnaryMinus + if ((node.args[0].type === 'ParenthesisNode' || node.args[0].type === 'OperatorNode') && node.args[1].type === 'ConstantNode') { + // Second operator: Constant + val = parseFloat(node.args[1].value); + does = val >= 2 && (0, _number.isInteger)(val); + } + } + if (does) { + // Exponent >= 2 + // Before: + // operator A --> Subtree + // parent pow + // constant + // + if (val > 2) { + // Exponent > 2, + // AFTER: (exponent > 2) + // operator A --> Subtree + // parent * + // deep clone (operator A --> Subtree + // pow + // constant - 1 + // + const nEsqTopo = node.args[0]; + const nDirTopo = new OperatorNode('^', 'pow', [node.args[0].cloneDeep(), new ConstantNode(val - 1)]); + node = new OperatorNode('*', 'multiply', [nEsqTopo, nDirTopo]); + } else { + // Expo = 2 - no power + // AFTER: (exponent = 2) + // operator A --> Subtree + // parent oper + // deep clone (operator A --> Subtree) + // + node = new OperatorNode('*', 'multiply', [node.args[0], node.args[0].cloneDeep()]); + } + if (internal) { + // Change parent references in internal recursive calls + if (indParent === 'content') { + parent.content = node; + } else { + parent.args[indParent] = node; + } + } + } // does + } // binary OperatorNode + + if (tp === 'ParenthesisNode') { + // Recursion + expandPower(node.content, node, 'content'); + } else if (tp !== 'ConstantNode' && tp !== 'SymbolNode') { + for (let i = 0; i < node.args.length; i++) { + expandPower(node.args[i], node, i); + } + } + if (!internal) { + // return the root node + return node; + } + } // End expandPower + + // --------------------------------------------------------------------------------------- + /** + * Auxilary function for rationalize + * Convert near canonical polynomial in one variable in a canonical polynomial + * with one term for each exponent in decreasing order + * + * Syntax: + * + * polyToCanonical(node [, coefficients]) + * + * @param {Node | string} expr The near canonical polynomial expression to convert in a a canonical polynomial expression + * + * The string or tree expression needs to be at below syntax, with free spaces: + * ( (^(-)? | [+-]? )cte (*)? var (^expo)? | cte )+ + * Where 'var' is one variable with any valid name + * 'cte' are real numeric constants with any value. It can be omitted if equal than 1 + * 'expo' are integers greater than 0. It can be omitted if equal than 1. + * + * @param {array} coefficients Optional returns coefficients sorted by increased exponent + * + * + * @return {node} new node tree with one variable polynomial or string error. + */ + function polyToCanonical(node, coefficients) { + if (coefficients === undefined) { + coefficients = []; + } // coefficients. + + coefficients[0] = 0; // index is the exponent + const o = {}; + o.cte = 1; + o.oper = '+'; + + // fire: mark with * or ^ when finds * or ^ down tree, reset to "" with + and -. + // It is used to deduce the exponent: 1 for *, 0 for "". + o.fire = ''; + let maxExpo = 0; // maximum exponent + let varname = ''; // variable name + + recurPol(node, null, o); + maxExpo = coefficients.length - 1; + let first = true; + let no; + for (let i = maxExpo; i >= 0; i--) { + if (coefficients[i] === 0) continue; + let n1 = new ConstantNode(first ? coefficients[i] : Math.abs(coefficients[i])); + const op = coefficients[i] < 0 ? '-' : '+'; + if (i > 0) { + // Is not a constant without variable + let n2 = new SymbolNode(varname); + if (i > 1) { + const n3 = new ConstantNode(i); + n2 = new OperatorNode('^', 'pow', [n2, n3]); + } + if (coefficients[i] === -1 && first) { + n1 = new OperatorNode('-', 'unaryMinus', [n2]); + } else if (Math.abs(coefficients[i]) === 1) { + n1 = n2; + } else { + n1 = new OperatorNode('*', 'multiply', [n1, n2]); + } + } + if (first) { + no = n1; + } else if (op === '+') { + no = new OperatorNode('+', 'add', [no, n1]); + } else { + no = new OperatorNode('-', 'subtract', [no, n1]); + } + first = false; + } // for + + if (first) { + return new ConstantNode(0); + } else { + return no; + } + + /** + * Recursive auxilary function inside polyToCanonical for + * converting expression in canonical form + * + * Syntax: + * + * recurPol(node, noPai, obj) + * + * @param {Node} node The current subpolynomial expression + * @param {Node | Null} noPai The current parent node + * @param {object} obj Object with many internal flags + * + * @return {} No return. If error, throws an exception + */ + function recurPol(node, noPai, o) { + const tp = node.type; + if (tp === 'FunctionNode') { + // ***** FunctionName ***** + // No function call in polynomial expression + throw new Error('There is an unsolved function call'); + } else if (tp === 'OperatorNode') { + // ***** OperatorName ***** + if (!'+-*^'.includes(node.op)) throw new Error('Operator ' + node.op + ' invalid'); + if (noPai !== null) { + // -(unary),^ : children of *,+,- + if ((node.fn === 'unaryMinus' || node.fn === 'pow') && noPai.fn !== 'add' && noPai.fn !== 'subtract' && noPai.fn !== 'multiply') { + throw new Error('Invalid ' + node.op + ' placing'); + } + + // -,+,* : children of +,- + if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'multiply') && noPai.fn !== 'add' && noPai.fn !== 'subtract') { + throw new Error('Invalid ' + node.op + ' placing'); + } + + // -,+ : first child + if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'unaryMinus') && o.noFil !== 0) { + throw new Error('Invalid ' + node.op + ' placing'); + } + } // Has parent + + // Firers: ^,* Old: ^,&,-(unary): firers + if (node.op === '^' || node.op === '*') { + o.fire = node.op; + } + for (let i = 0; i < node.args.length; i++) { + // +,-: reset fire + if (node.fn === 'unaryMinus') o.oper = '-'; + if (node.op === '+' || node.fn === 'subtract') { + o.fire = ''; + o.cte = 1; // default if there is no constant + o.oper = i === 0 ? '+' : node.op; + } + o.noFil = i; // number of son + recurPol(node.args[i], node, o); + } // for in children + } else if (tp === 'SymbolNode') { + // ***** SymbolName ***** + if (node.name !== varname && varname !== '') { + throw new Error('There is more than one variable'); + } + varname = node.name; + if (noPai === null) { + coefficients[1] = 1; + return; + } + + // ^: Symbol is First child + if (noPai.op === '^' && o.noFil !== 0) { + throw new Error('In power the variable should be the first parameter'); + } + + // *: Symbol is Second child + if (noPai.op === '*' && o.noFil !== 1) { + throw new Error('In multiply the variable should be the second parameter'); + } + + // Symbol: firers '',* => it means there is no exponent above, so it's 1 (cte * var) + if (o.fire === '' || o.fire === '*') { + if (maxExpo < 1) coefficients[1] = 0; + coefficients[1] += o.cte * (o.oper === '+' ? 1 : -1); + maxExpo = Math.max(1, maxExpo); + } + } else if (tp === 'ConstantNode') { + const valor = parseFloat(node.value); + if (noPai === null) { + coefficients[0] = valor; + return; + } + if (noPai.op === '^') { + // cte: second child of power + if (o.noFil !== 1) throw new Error('Constant cannot be powered'); + if (!(0, _number.isInteger)(valor) || valor <= 0) { + throw new Error('Non-integer exponent is not allowed'); + } + for (let i = maxExpo + 1; i < valor; i++) coefficients[i] = 0; + if (valor > maxExpo) coefficients[valor] = 0; + coefficients[valor] += o.cte * (o.oper === '+' ? 1 : -1); + maxExpo = Math.max(valor, maxExpo); + return; + } + o.cte = valor; + + // Cte: firer '' => There is no exponent and no multiplication, so the exponent is 0. + if (o.fire === '') { + coefficients[0] += o.cte * (o.oper === '+' ? 1 : -1); + } + } else { + throw new Error('Type ' + tp + ' is not allowed'); + } + } // End of recurPol + } // End of polyToCanonical +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/resolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/resolve.js new file mode 100644 index 0000000..9fcbfac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/resolve.js @@ -0,0 +1,103 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createResolve = void 0; +var _map = require("../../utils/map.js"); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'resolve'; +const dependencies = ['typed', 'parse', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode']; +const createResolve = exports.createResolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + parse, + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode + } = _ref; + /** + * resolve(expr, scope) replaces variable nodes with their scoped values + * + * Syntax: + * + * math.resolve(expr, scope) + * + * Examples: + * + * math.resolve('x + y', {x:1, y:2}) // Node '1 + 2' + * math.resolve(math.parse('x+y'), {x:1, y:2}) // Node '1 + 2' + * math.simplify('x+y', {x:2, y: math.parse('x+x')}).toString() // "6" + * + * See also: + * + * simplify, evaluate + * + * @param {Node | Node[]} node + * The expression tree (or trees) to be simplified + * @param {Object} scope + * Scope specifying variables to be resolved + * @return {Node | Node[]} Returns `node` with variables recursively substituted. + * @throws {ReferenceError} + * If there is a cyclic dependency among the variables in `scope`, + * resolution is impossible and a ReferenceError is thrown. + */ + function _resolve(node, scope) { + let within = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : new Set(); + // note `within`: + // `within` is not documented, since it is for internal cycle + // detection only + if (!scope) { + return node; + } + if ((0, _is.isSymbolNode)(node)) { + if (within.has(node.name)) { + const variables = Array.from(within).join(', '); + throw new ReferenceError(`recursive loop of variable definitions among {${variables}}`); + } + const value = scope.get(node.name); + if ((0, _is.isNode)(value)) { + const nextWithin = new Set(within); + nextWithin.add(node.name); + return _resolve(value, scope, nextWithin); + } else if (typeof value === 'number') { + return parse(String(value)); + } else if (value !== undefined) { + return new ConstantNode(value); + } else { + return node; + } + } else if ((0, _is.isOperatorNode)(node)) { + const args = node.args.map(function (arg) { + return _resolve(arg, scope, within); + }); + return new OperatorNode(node.op, node.fn, args, node.implicit); + } else if ((0, _is.isParenthesisNode)(node)) { + return new ParenthesisNode(_resolve(node.content, scope, within)); + } else if ((0, _is.isFunctionNode)(node)) { + const args = node.args.map(function (arg) { + return _resolve(arg, scope, within); + }); + return new FunctionNode(node.name, args); + } + + // Otherwise just recursively resolve any children (might also work + // for some of the above special cases) + return node.map(child => _resolve(child, scope, within)); + } + return typed('resolve', { + Node: _resolve, + 'Node, Map | null | undefined': _resolve, + 'Node, Object': (n, scope) => _resolve(n, (0, _map.createMap)(scope)), + // For arrays and matrices, we map `self` rather than `_resolve` + // because resolve is fairly expensive anyway, and this way + // we get nice error messages if one entry in the array has wrong type. + 'Array | Matrix': typed.referToSelf(self => A => A.map(n => self(n))), + 'Array | Matrix, null | undefined': typed.referToSelf(self => A => A.map(n => self(n))), + 'Array, Object': typed.referTo('Array,Map', selfAM => (A, scope) => selfAM(A, (0, _map.createMap)(scope))), + 'Matrix, Object': typed.referTo('Matrix,Map', selfMM => (A, scope) => selfMM(A, (0, _map.createMap)(scope))), + 'Array | Matrix, Map': typed.referToSelf(self => (A, scope) => A.map(n => self(n, scope))) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify.js new file mode 100644 index 0000000..b92efb6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify.js @@ -0,0 +1,1262 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSimplify = void 0; +var _is = require("../../utils/is.js"); +var _wildcards = require("./simplify/wildcards.js"); +var _factory = require("../../utils/factory.js"); +var _util = require("./simplify/util.js"); +var _object = require("../../utils/object.js"); +var _map = require("../../utils/map.js"); +const name = 'simplify'; +const dependencies = ['config', 'typed', 'parse', 'add', 'subtract', 'multiply', 'divide', 'pow', 'isZero', 'equal', 'resolve', 'simplifyConstant', 'simplifyCore', '?fraction', '?bignumber', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +const createSimplify = exports.createSimplify = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + typed, + parse, + add, + subtract, + multiply, + divide, + pow, + isZero, + equal, + resolve, + simplifyConstant, + simplifyCore, + fraction, + bignumber, + mathWithTransform, + matrix, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + const { + hasProperty, + isCommutative, + isAssociative, + mergeContext, + flatten, + unflattenr, + unflattenl, + createMakeNodeFunction, + defaultContext, + realContext, + positiveContext + } = (0, _util.createUtil)({ + FunctionNode, + OperatorNode, + SymbolNode + }); + + /** + * Simplify an expression tree. + * + * A list of rules are applied to an expression, repeating over the list until + * no further changes are made. + * It's possible to pass a custom set of rules to the function as second + * argument. A rule can be specified as an object, string, or function: + * + * const rules = [ + * { l: 'n1*n3 + n2*n3', r: '(n1+n2)*n3' }, + * 'n1*n3 + n2*n3 -> (n1+n2)*n3', + * function (node) { + * // ... return a new node or return the node unchanged + * return node + * } + * ] + * + * String and object rules consist of a left and right pattern. The left is + * used to match against the expression and the right determines what matches + * are replaced with. The main difference between a pattern and a normal + * expression is that variables starting with the following characters are + * interpreted as wildcards: + * + * - 'n' - Matches any node [Node] + * - 'c' - Matches a constant literal (5 or 3.2) [ConstantNode] + * - 'cl' - Matches a constant literal; same as c [ConstantNode] + * - 'cd' - Matches a decimal literal (5 or -3.2) [ConstantNode or unaryMinus wrapping a ConstantNode] + * - 'ce' - Matches a constant expression (-5 or √3) [Expressions consisting of only ConstantNodes, functions, and operators] + * - 'v' - Matches a variable; anything not matched by c (-5 or x) [Node that is not a ConstantNode] + * - 'vl' - Matches a variable literal (x or y) [SymbolNode] + * - 'vd' - Matches a non-decimal expression; anything not matched by cd (x or √3) [Node that is not a ConstantNode or unaryMinus that is wrapping a ConstantNode] + * - 've' - Matches a variable expression; anything not matched by ce (x or 2x) [Expressions that contain a SymbolNode or other non-constant term] + * + * The default list of rules is exposed on the function as `simplify.rules` + * and can be used as a basis to built a set of custom rules. Note that since + * the `simplifyCore` function is in the default list of rules, by default + * simplify will convert any function calls in the expression that have + * operator equivalents to their operator forms. + * + * To specify a rule as a string, separate the left and right pattern by '->' + * When specifying a rule as an object, the following keys are meaningful: + * - l - the left pattern + * - r - the right pattern + * - s - in lieu of l and r, the string form that is broken at -> to give them + * - repeat - whether to repeat this rule until the expression stabilizes + * - assuming - gives a context object, as in the 'context' option to + * simplify. Every property in the context object must match the current + * context in order, or else the rule will not be applied. + * - imposeContext - gives a context object, as in the 'context' option to + * simplify. Any settings specified will override the incoming context + * for all matches of this rule. + * + * For more details on the theory, see: + * + * - [Strategies for simplifying math expressions (Stackoverflow)](https://stackoverflow.com/questions/7540227/strategies-for-simplifying-math-expressions) + * - [Symbolic computation - Simplification (Wikipedia)](https://en.wikipedia.org/wiki/Symbolic_computation#Simplification) + * + * An optional `options` argument can be passed as last argument of `simplify`. + * Currently available options (defaults in parentheses): + * - `consoleDebug` (false): whether to write the expression being simplified + * and any changes to it, along with the rule responsible, to console + * - `context` (simplify.defaultContext): an object giving properties of + * each operator, which determine what simplifications are allowed. The + * currently meaningful properties are commutative, associative, + * total (whether the operation is defined for all arguments), and + * trivial (whether the operation applied to a single argument leaves + * that argument unchanged). The default context is very permissive and + * allows almost all simplifications. Only properties differing from + * the default need to be specified; the default context is used as a + * fallback. Additional contexts `simplify.realContext` and + * `simplify.positiveContext` are supplied to cause simplify to perform + * just simplifications guaranteed to preserve all values of the expression + * assuming all variables and subexpressions are real numbers or + * positive real numbers, respectively. (Note that these are in some cases + * more restrictive than the default context; for example, the default + * context will allow `x/x` to simplify to 1, whereas + * `simplify.realContext` will not, as `0/0` is not equal to 1.) + * - `exactFractions` (true): whether to try to convert all constants to + * exact rational numbers. + * - `fractionsLimit` (10000): when `exactFractions` is true, constants will + * be expressed as fractions only when both numerator and denominator + * are smaller than `fractionsLimit`. + * + * Syntax: + * + * math.simplify(expr) + * math.simplify(expr, rules) + * math.simplify(expr, rules) + * math.simplify(expr, rules, scope) + * math.simplify(expr, rules, scope, options) + * math.simplify(expr, scope) + * math.simplify(expr, scope, options) + * + * Examples: + * + * math.simplify('2 * 1 * x ^ (2 - 1)') // Node "2 * x" + * math.simplify('2 * 3 * x', {x: 4}) // Node "24" + * const f = math.parse('2 * 1 * x ^ (2 - 1)') + * math.simplify(f) // Node "2 * x" + * math.simplify('0.4 * x', {}, {exactFractions: true}) // Node "x * 2 / 5" + * math.simplify('0.4 * x', {}, {exactFractions: false}) // Node "0.4 * x" + * + * See also: + * + * simplifyCore, derivative, evaluate, parse, rationalize, resolve + * + * @param {Node | string} expr + * The expression to be simplified + * @param {SimplifyRule[]} [rules] + * Optional list with custom rules + * @param {Object} [scope] Optional scope with variables + * @param {SimplifyOptions} [options] Optional configuration settings + * @return {Node} Returns the simplified form of `expr` + */ + typed.addConversion({ + from: 'Object', + to: 'Map', + convert: _map.createMap + }); + const simplify = typed('simplify', { + Node: _simplify, + 'Node, Map': (expr, scope) => _simplify(expr, false, scope), + 'Node, Map, Object': (expr, scope, options) => _simplify(expr, false, scope, options), + 'Node, Array': _simplify, + 'Node, Array, Map': _simplify, + 'Node, Array, Map, Object': _simplify + }); + typed.removeConversion({ + from: 'Object', + to: 'Map', + convert: _map.createMap + }); + simplify.defaultContext = defaultContext; + simplify.realContext = realContext; + simplify.positiveContext = positiveContext; + function removeParens(node) { + return node.transform(function (node, path, parent) { + return (0, _is.isParenthesisNode)(node) ? removeParens(node.content) : node; + }); + } + + // All constants that are allowed in rules + const SUPPORTED_CONSTANTS = { + true: true, + false: true, + e: true, + i: true, + Infinity: true, + LN2: true, + LN10: true, + LOG2E: true, + LOG10E: true, + NaN: true, + phi: true, + pi: true, + SQRT1_2: true, + SQRT2: true, + tau: true + // null: false, + // undefined: false, + // version: false, + }; + + // Array of strings, used to build the ruleSet. + // Each l (left side) and r (right side) are parsed by + // the expression parser into a node tree. + // Left hand sides are matched to subtrees within the + // expression to be parsed and replaced with the right + // hand side. + // TODO: Add support for constraints on constants (either in the form of a '=' expression or a callback [callback allows things like comparing symbols alphabetically]) + // To evaluate lhs constants for rhs constants, use: { l: 'c1+c2', r: 'c3', evaluate: 'c3 = c1 + c2' }. Multiple assignments are separated by ';' in block format. + // It is possible to get into an infinite loop with conflicting rules + simplify.rules = [simplifyCore, + // { l: 'n+0', r: 'n' }, // simplifyCore + // { l: 'n^0', r: '1' }, // simplifyCore + // { l: '0*n', r: '0' }, // simplifyCore + // { l: 'n/n', r: '1'}, // simplifyCore + // { l: 'n^1', r: 'n' }, // simplifyCore + // { l: '+n1', r:'n1' }, // simplifyCore + // { l: 'n--n1', r:'n+n1' }, // simplifyCore + { + l: 'log(e)', + r: '1' + }, + // temporary rules + // Note initially we tend constants to the right because like-term + // collection prefers the left, and we would rather collect nonconstants + { + s: 'n-n1 -> n+-n1', + // temporarily replace 'subtract' so we can further flatten the 'add' operator + assuming: { + subtract: { + total: true + } + } + }, { + s: 'n-n -> 0', + // partial alternative when we can't always subtract + assuming: { + subtract: { + total: false + } + } + }, { + s: '-(cl*v) -> v * (-cl)', + // make non-constant terms positive + assuming: { + multiply: { + commutative: true + }, + subtract: { + total: true + } + } + }, { + s: '-(cl*v) -> (-cl) * v', + // non-commutative version, part 1 + assuming: { + multiply: { + commutative: false + }, + subtract: { + total: true + } + } + }, { + s: '-(v*cl) -> v * (-cl)', + // non-commutative version, part 2 + assuming: { + multiply: { + commutative: false + }, + subtract: { + total: true + } + } + }, { + l: '-(n1/n2)', + r: '-n1/n2' + }, { + l: '-v', + r: 'v * (-1)' + }, + // finish making non-constant terms positive + { + l: '(n1 + n2)*(-1)', + r: 'n1*(-1) + n2*(-1)', + repeat: true + }, + // expand negations to achieve as much sign cancellation as possible + { + l: 'n/n1^n2', + r: 'n*n1^-n2' + }, + // temporarily replace 'divide' so we can further flatten the 'multiply' operator + { + l: 'n/n1', + r: 'n*n1^-1' + }, { + s: '(n1*n2)^n3 -> n1^n3 * n2^n3', + assuming: { + multiply: { + commutative: true + } + } + }, { + s: '(n1*n2)^(-1) -> n2^(-1) * n1^(-1)', + assuming: { + multiply: { + commutative: false + } + } + }, + // expand nested exponentiation + { + s: '(n ^ n1) ^ n2 -> n ^ (n1 * n2)', + assuming: { + divide: { + total: true + } + } // 1/(1/n) = n needs 1/n to exist + }, + // collect like factors; into a sum, only do this for nonconstants + { + l: ' vd * ( vd * n1 + n2)', + r: 'vd^2 * n1 + vd * n2' + }, { + s: ' vd * (vd^n4 * n1 + n2) -> vd^(1+n4) * n1 + vd * n2', + assuming: { + divide: { + total: true + } + } // v*1/v = v^(1+-1) needs 1/v + }, { + s: 'vd^n3 * ( vd * n1 + n2) -> vd^(n3+1) * n1 + vd^n3 * n2', + assuming: { + divide: { + total: true + } + } + }, { + s: 'vd^n3 * (vd^n4 * n1 + n2) -> vd^(n3+n4) * n1 + vd^n3 * n2', + assuming: { + divide: { + total: true + } + } + }, { + l: 'n*n', + r: 'n^2' + }, { + s: 'n * n^n1 -> n^(n1+1)', + assuming: { + divide: { + total: true + } + } // n*1/n = n^(-1+1) needs 1/n + }, { + s: 'n^n1 * n^n2 -> n^(n1+n2)', + assuming: { + divide: { + total: true + } + } // ditto for n^2*1/n^2 + }, + // Unfortunately, to deal with more complicated cancellations, it + // becomes necessary to simplify constants twice per pass. It's not + // terribly expensive compared to matching rules, so this should not + // pose a performance problem. + simplifyConstant, + // First: before collecting like terms + + // collect like terms + { + s: 'n+n -> 2*n', + assuming: { + add: { + total: true + } + } // 2 = 1 + 1 needs to exist + }, { + l: 'n+-n', + r: '0' + }, { + l: 'vd*n + vd', + r: 'vd*(n+1)' + }, + // NOTE: leftmost position is special: + { + l: 'n3*n1 + n3*n2', + r: 'n3*(n1+n2)' + }, + // All sub-monomials tried there. + { + l: 'n3^(-n4)*n1 + n3 * n2', + r: 'n3^(-n4)*(n1 + n3^(n4+1) *n2)' + }, { + l: 'n3^(-n4)*n1 + n3^n5 * n2', + r: 'n3^(-n4)*(n1 + n3^(n4+n5)*n2)' + }, + // noncommutative additional cases (term collection & factoring) + { + s: 'n*vd + vd -> (n+1)*vd', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'vd + n*vd -> (1+n)*vd', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3 + n2*n3 -> (n1+n2)*n3', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n^n1 * n -> n^(n1+1)', + assuming: { + divide: { + total: true + }, + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3^(-n4) + n2 * n3 -> (n1 + n2*n3^(n4 + 1))*n3^(-n4)', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)', + assuming: { + multiply: { + commutative: false + } + } + }, { + l: 'n*cd + cd', + r: '(n+1)*cd' + }, { + s: 'cd*n + cd -> cd*(n+1)', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'cd + cd*n -> cd*(1+n)', + assuming: { + multiply: { + commutative: false + } + } + }, simplifyConstant, + // Second: before returning expressions to "standard form" + + // make factors positive (and undo 'make non-constant terms positive') + { + s: '(-n)*n1 -> -(n*n1)', + assuming: { + subtract: { + total: true + } + } + }, { + s: 'n1*(-n) -> -(n1*n)', + // in case * non-commutative + assuming: { + subtract: { + total: true + }, + multiply: { + commutative: false + } + } + }, + // final ordering of constants + { + s: 'ce+ve -> ve+ce', + assuming: { + add: { + commutative: true + } + }, + imposeContext: { + add: { + commutative: false + } + } + }, { + s: 'vd*cd -> cd*vd', + assuming: { + multiply: { + commutative: true + } + }, + imposeContext: { + multiply: { + commutative: false + } + } + }, + // undo temporary rules + // { l: '(-1) * n', r: '-n' }, // #811 added test which proved this is redundant + { + l: 'n+-n1', + r: 'n-n1' + }, + // undo replace 'subtract' + { + l: 'n+-(n1)', + r: 'n-(n1)' + }, { + s: 'n*(n1^-1) -> n/n1', + // undo replace 'divide'; for * commutative + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + s: 'n*n1^-n2 -> n/n1^n2', + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + s: 'n^-1 -> 1/n', + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + l: 'n^1', + r: 'n' + }, + // can be produced by power cancellation + { + s: 'n*(n1/n2) -> (n*n1)/n2', + // '*' before '/' + assuming: { + multiply: { + associative: true + } + } + }, { + s: 'n-(n1+n2) -> n-n1-n2', + // '-' before '+' + assuming: { + addition: { + associative: true, + commutative: true + } + } + }, + // { l: '(n1/n2)/n3', r: 'n1/(n2*n3)' }, + // { l: '(n*n1)/(n*n2)', r: 'n1/n2' }, + + // simplifyConstant can leave an extra factor of 1, which can always + // be eliminated, since the identity always commutes + { + l: '1*n', + r: 'n', + imposeContext: { + multiply: { + commutative: true + } + } + }, { + s: 'n1/(n2/n3) -> (n1*n3)/n2', + assuming: { + multiply: { + associative: true + } + } + }, { + l: 'n1/(-n2)', + r: '-n1/n2' + }]; + + /** + * Takes any rule object as allowed by the specification in simplify + * and puts it in a standard form used by applyRule + */ + function _canonicalizeRule(ruleObject, context) { + const newRule = {}; + if (ruleObject.s) { + const lr = ruleObject.s.split('->'); + if (lr.length === 2) { + newRule.l = lr[0]; + newRule.r = lr[1]; + } else { + throw SyntaxError('Could not parse rule: ' + ruleObject.s); + } + } else { + newRule.l = ruleObject.l; + newRule.r = ruleObject.r; + } + newRule.l = removeParens(parse(newRule.l)); + newRule.r = removeParens(parse(newRule.r)); + for (const prop of ['imposeContext', 'repeat', 'assuming']) { + if (prop in ruleObject) { + newRule[prop] = ruleObject[prop]; + } + } + if (ruleObject.evaluate) { + newRule.evaluate = parse(ruleObject.evaluate); + } + if (isAssociative(newRule.l, context)) { + const nonCommutative = !isCommutative(newRule.l, context); + let leftExpandsym; + // Gen. the LHS placeholder used in this NC-context specific expansion rules + if (nonCommutative) leftExpandsym = _getExpandPlaceholderSymbol(); + const makeNode = createMakeNodeFunction(newRule.l); + const expandsym = _getExpandPlaceholderSymbol(); + newRule.expanded = {}; + newRule.expanded.l = makeNode([newRule.l, expandsym]); + // Push the expandsym into the deepest possible branch. + // This helps to match the newRule against nodes returned from getSplits() later on. + flatten(newRule.expanded.l, context); + unflattenr(newRule.expanded.l, context); + newRule.expanded.r = makeNode([newRule.r, expandsym]); + + // In and for a non-commutative context, attempting with yet additional expansion rules makes + // way for more matches cases of multi-arg expressions; such that associative rules (such as + // 'n*n -> n^2') can be applied to exprs. such as 'a * b * b' and 'a * b * b * a'. + if (nonCommutative) { + // 'Non-commutative' 1: LHS (placeholder) only + newRule.expandedNC1 = {}; + newRule.expandedNC1.l = makeNode([leftExpandsym, newRule.l]); + newRule.expandedNC1.r = makeNode([leftExpandsym, newRule.r]); + // 'Non-commutative' 2: farmost LHS and RHS placeholders + newRule.expandedNC2 = {}; + newRule.expandedNC2.l = makeNode([leftExpandsym, newRule.expanded.l]); + newRule.expandedNC2.r = makeNode([leftExpandsym, newRule.expanded.r]); + } + } + return newRule; + } + + /** + * Parse the string array of rules into nodes + * + * Example syntax for rules: + * + * Position constants to the left in a product: + * { l: 'n1 * c1', r: 'c1 * n1' } + * n1 is any Node, and c1 is a ConstantNode. + * + * Apply difference of squares formula: + * { l: '(n1 - n2) * (n1 + n2)', r: 'n1^2 - n2^2' } + * n1, n2 mean any Node. + * + * Short hand notation: + * 'n1 * c1 -> c1 * n1' + */ + function _buildRules(rules, context) { + // Array of rules to be used to simplify expressions + const ruleSet = []; + for (let i = 0; i < rules.length; i++) { + let rule = rules[i]; + let newRule; + const ruleType = typeof rule; + switch (ruleType) { + case 'string': + rule = { + s: rule + }; + /* falls through */ + case 'object': + newRule = _canonicalizeRule(rule, context); + break; + case 'function': + newRule = rule; + break; + default: + throw TypeError('Unsupported type of rule: ' + ruleType); + } + // console.log('Adding rule: ' + rules[i]) + // console.log(newRule) + ruleSet.push(newRule); + } + return ruleSet; + } + let _lastsym = 0; + function _getExpandPlaceholderSymbol() { + return new SymbolNode('_p' + _lastsym++); + } + function _simplify(expr, rules) { + let scope = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : (0, _map.createEmptyMap)(); + let options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; + const debug = options.consoleDebug; + rules = _buildRules(rules || simplify.rules, options.context); + let res = resolve(expr, scope); + res = removeParens(res); + const visited = {}; + let str = res.toString({ + parenthesis: 'all' + }); + while (!visited[str]) { + visited[str] = true; + _lastsym = 0; // counter for placeholder symbols + let laststr = str; + if (debug) console.log('Working on: ', str); + for (let i = 0; i < rules.length; i++) { + let rulestr = ''; + if (typeof rules[i] === 'function') { + res = rules[i](res, options); + if (debug) rulestr = rules[i].name; + } else { + flatten(res, options.context); + res = applyRule(res, rules[i], options.context); + if (debug) { + rulestr = `${rules[i].l.toString()} -> ${rules[i].r.toString()}`; + } + } + if (debug) { + const newstr = res.toString({ + parenthesis: 'all' + }); + if (newstr !== laststr) { + console.log('Applying', rulestr, 'produced', newstr); + laststr = newstr; + } + } + /* Use left-heavy binary tree internally, + * since custom rule functions may expect it + */ + unflattenl(res, options.context); + } + str = res.toString({ + parenthesis: 'all' + }); + } + return res; + } + function mapRule(nodes, rule, context) { + let resNodes = nodes; + if (nodes) { + for (let i = 0; i < nodes.length; ++i) { + const newNode = applyRule(nodes[i], rule, context); + if (newNode !== nodes[i]) { + if (resNodes === nodes) { + resNodes = nodes.slice(); + } + resNodes[i] = newNode; + } + } + } + return resNodes; + } + + /** + * Returns a simplfied form of node, or the original node if no simplification was possible. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object | Function} rule + * @param {Object} context -- information about assumed properties of operators + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The simplified form of `expr`, or the original node if no simplification was possible. + */ + function applyRule(node, rule, context) { + // console.log('Entering applyRule("', rule.l.toString({parenthesis:'all'}), '->', rule.r.toString({parenthesis:'all'}), '",', node.toString({parenthesis:'all'}),')') + + // check that the assumptions for this rule are satisfied by the current + // context: + if (rule.assuming) { + for (const symbol in rule.assuming) { + for (const property in rule.assuming[symbol]) { + if (hasProperty(symbol, property, context) !== rule.assuming[symbol][property]) { + return node; + } + } + } + } + const mergedContext = mergeContext(rule.imposeContext, context); + + // Do not clone node unless we find a match + let res = node; + + // First replace our child nodes with their simplified versions + // If a child could not be simplified, applying the rule to it + // will have no effect since the node is returned unchanged + if (res instanceof OperatorNode || res instanceof FunctionNode) { + const newArgs = mapRule(res.args, rule, context); + if (newArgs !== res.args) { + res = res.clone(); + res.args = newArgs; + } + } else if (res instanceof ParenthesisNode) { + if (res.content) { + const newContent = applyRule(res.content, rule, context); + if (newContent !== res.content) { + res = new ParenthesisNode(newContent); + } + } + } else if (res instanceof ArrayNode) { + const newItems = mapRule(res.items, rule, context); + if (newItems !== res.items) { + res = new ArrayNode(newItems); + } + } else if (res instanceof AccessorNode) { + let newObj = res.object; + if (res.object) { + newObj = applyRule(res.object, rule, context); + } + let newIndex = res.index; + if (res.index) { + newIndex = applyRule(res.index, rule, context); + } + if (newObj !== res.object || newIndex !== res.index) { + res = new AccessorNode(newObj, newIndex); + } + } else if (res instanceof IndexNode) { + const newDims = mapRule(res.dimensions, rule, context); + if (newDims !== res.dimensions) { + res = new IndexNode(newDims); + } + } else if (res instanceof ObjectNode) { + let changed = false; + const newProps = {}; + for (const prop in res.properties) { + newProps[prop] = applyRule(res.properties[prop], rule, context); + if (newProps[prop] !== res.properties[prop]) { + changed = true; + } + } + if (changed) { + res = new ObjectNode(newProps); + } + } + + // Try to match a rule against this node + let repl = rule.r; + let matches = _ruleMatch(rule.l, res, mergedContext)[0]; + + // If the rule is associative operator, we can try matching it while allowing additional terms. + // This allows us to match rules like 'n+n' to the expression '(1+x)+x' or even 'x+1+x' if the operator is commutative. + if (!matches && rule.expanded) { + repl = rule.expanded.r; + matches = _ruleMatch(rule.expanded.l, res, mergedContext)[0]; + } + // Additional, non-commutative context expansion-rules + if (!matches && rule.expandedNC1) { + repl = rule.expandedNC1.r; + matches = _ruleMatch(rule.expandedNC1.l, res, mergedContext)[0]; + if (!matches) { + // Existence of NC1 implies NC2 + repl = rule.expandedNC2.r; + matches = _ruleMatch(rule.expandedNC2.l, res, mergedContext)[0]; + } + } + if (matches) { + // const before = res.toString({parenthesis: 'all'}) + + // Create a new node by cloning the rhs of the matched rule + // we keep any implicit multiplication state if relevant + const implicit = res.implicit; + res = repl.clone(); + if (implicit && 'implicit' in repl) { + res.implicit = true; + } + + // Replace placeholders with their respective nodes without traversing deeper into the replaced nodes + res = res.transform(function (node) { + if (node.isSymbolNode && (0, _object.hasOwnProperty)(matches.placeholders, node.name)) { + return matches.placeholders[node.name].clone(); + } else { + return node; + } + }); + + // const after = res.toString({parenthesis: 'all'}) + // console.log('Simplified ' + before + ' to ' + after) + } + if (rule.repeat && res !== node) { + res = applyRule(res, rule, context); + } + return res; + } + + /** + * Get (binary) combinations of a flattened binary node + * e.g. +(node1, node2, node3) -> [ + * +(node1, +(node2, node3)), + * +(node2, +(node1, node3)), + * +(node3, +(node1, node2))] + * + */ + function getSplits(node, context) { + const res = []; + let right, rightArgs; + const makeNode = createMakeNodeFunction(node); + if (isCommutative(node, context)) { + for (let i = 0; i < node.args.length; i++) { + rightArgs = node.args.slice(0); + rightArgs.splice(i, 1); + right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs); + res.push(makeNode([node.args[i], right])); + } + } else { + // Keep order, but try all parenthesizations + for (let i = 1; i < node.args.length; i++) { + let left = node.args[0]; + if (i > 1) { + left = makeNode(node.args.slice(0, i)); + } + rightArgs = node.args.slice(i); + right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs); + res.push(makeNode([left, right])); + } + } + return res; + } + + /** + * Returns the set union of two match-placeholders or null if there is a conflict. + */ + function mergeMatch(match1, match2) { + const res = { + placeholders: {} + }; + + // Some matches may not have placeholders; this is OK + if (!match1.placeholders && !match2.placeholders) { + return res; + } else if (!match1.placeholders) { + return match2; + } else if (!match2.placeholders) { + return match1; + } + + // Placeholders with the same key must match exactly + for (const key in match1.placeholders) { + if ((0, _object.hasOwnProperty)(match1.placeholders, key)) { + res.placeholders[key] = match1.placeholders[key]; + if ((0, _object.hasOwnProperty)(match2.placeholders, key)) { + if (!_exactMatch(match1.placeholders[key], match2.placeholders[key])) { + return null; + } + } + } + } + for (const key in match2.placeholders) { + if ((0, _object.hasOwnProperty)(match2.placeholders, key)) { + res.placeholders[key] = match2.placeholders[key]; + } + } + return res; + } + + /** + * Combine two lists of matches by applying mergeMatch to the cartesian product of two lists of matches. + * Each list represents matches found in one child of a node. + */ + function combineChildMatches(list1, list2) { + const res = []; + if (list1.length === 0 || list2.length === 0) { + return res; + } + let merged; + for (let i1 = 0; i1 < list1.length; i1++) { + for (let i2 = 0; i2 < list2.length; i2++) { + merged = mergeMatch(list1[i1], list2[i2]); + if (merged) { + res.push(merged); + } + } + } + return res; + } + + /** + * Combine multiple lists of matches by applying mergeMatch to the cartesian product of two lists of matches. + * Each list represents matches found in one child of a node. + * Returns a list of unique matches. + */ + function mergeChildMatches(childMatches) { + if (childMatches.length === 0) { + return childMatches; + } + const sets = childMatches.reduce(combineChildMatches); + const uniqueSets = []; + const unique = {}; + for (let i = 0; i < sets.length; i++) { + const s = JSON.stringify(sets[i]); + if (!unique[s]) { + unique[s] = true; + uniqueSets.push(sets[i]); + } + } + return uniqueSets; + } + + /** + * Determines whether node matches rule. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} rule + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object} context -- provides assumed properties of operators + * @param {Boolean} isSplit -- whether we are in process of splitting an + * n-ary operator node into possible binary combinations. + * Defaults to false. + * @return {Object} Information about the match, if it exists. + */ + function _ruleMatch(rule, node, context, isSplit) { + // console.log('Entering _ruleMatch(' + JSON.stringify(rule) + ', ' + JSON.stringify(node) + ')') + // console.log('rule = ' + rule) + // console.log('node = ' + node) + + // console.log('Entering _ruleMatch(', rule.toString({parenthesis:'all'}), ', ', node.toString({parenthesis:'all'}), ', ', context, ')') + let res = [{ + placeholders: {} + }]; + if (rule instanceof OperatorNode && node instanceof OperatorNode || rule instanceof FunctionNode && node instanceof FunctionNode) { + // If the rule is an OperatorNode or a FunctionNode, then node must match exactly + if (rule instanceof OperatorNode) { + if (rule.op !== node.op || rule.fn !== node.fn) { + return []; + } + } else if (rule instanceof FunctionNode) { + if (rule.name !== node.name) { + return []; + } + } + + // rule and node match. Search the children of rule and node. + if (node.args.length === 1 && rule.args.length === 1 || !isAssociative(node, context) && node.args.length === rule.args.length || isSplit) { + // Expect non-associative operators to match exactly, + // except in any order if operator is commutative + let childMatches = []; + for (let i = 0; i < rule.args.length; i++) { + const childMatch = _ruleMatch(rule.args[i], node.args[i], context); + if (childMatch.length === 0) { + // Child did not match, so stop searching immediately + break; + } + // The child matched, so add the information returned from the child to our result + childMatches.push(childMatch); + } + if (childMatches.length !== rule.args.length) { + if (!isCommutative(node, context) || + // exact match in order needed + rule.args.length === 1) { + // nothing to commute + return []; + } + if (rule.args.length > 2) { + /* Need to generate all permutations and try them. + * It's a bit complicated, and unlikely to come up since there + * are very few ternary or higher operators. So punt for now. + */ + throw new Error('permuting >2 commutative non-associative rule arguments not yet implemented'); + } + /* Exactly two arguments, try them reversed */ + const leftMatch = _ruleMatch(rule.args[0], node.args[1], context); + if (leftMatch.length === 0) { + return []; + } + const rightMatch = _ruleMatch(rule.args[1], node.args[0], context); + if (rightMatch.length === 0) { + return []; + } + childMatches = [leftMatch, rightMatch]; + } + res = mergeChildMatches(childMatches); + } else if (node.args.length >= 2 && rule.args.length === 2) { + // node is flattened, rule is not + // Associative operators/functions can be split in different ways so we check if the rule + // matches for each of them and return their union. + const splits = getSplits(node, context); + let splitMatches = []; + for (let i = 0; i < splits.length; i++) { + const matchSet = _ruleMatch(rule, splits[i], context, true); // recursing at the same tree depth here + splitMatches = splitMatches.concat(matchSet); + } + return splitMatches; + } else if (rule.args.length > 2) { + throw Error('Unexpected non-binary associative function: ' + rule.toString()); + } else { + // Incorrect number of arguments in rule and node, so no match + return []; + } + } else if (rule instanceof SymbolNode) { + // If the rule is a SymbolNode, then it carries a special meaning + // according to the first one or two characters of the symbol node name. + // These meanings are expalined in the documentation for simplify() + if (rule.name.length === 0) { + throw new Error('Symbol in rule has 0 length...!?'); + } + if (SUPPORTED_CONSTANTS[rule.name]) { + // built-in constant must match exactly + if (rule.name !== node.name) { + return []; + } + } else { + // wildcards are composed of up to two alphabetic or underscore characters + switch (rule.name[1] >= 'a' && rule.name[1] <= 'z' ? rule.name.substring(0, 2) : rule.name[0]) { + case 'n': + case '_p': + // rule matches _anything_, so assign this node to the rule.name placeholder + // Assign node to the rule.name placeholder. + // Our parent will check for matches among placeholders. + res[0].placeholders[rule.name] = node; + break; + case 'c': + case 'cl': + // rule matches a ConstantNode + if ((0, _wildcards.isConstantNode)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'v': + // rule matches anything other than a ConstantNode + if (!(0, _wildcards.isConstantNode)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'vl': + // rule matches VariableNode + if ((0, _wildcards.isVariableNode)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'cd': + // rule matches a ConstantNode or unaryMinus-wrapped ConstantNode + if ((0, _wildcards.isNumericNode)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'vd': + // rule matches anything other than a ConstantNode or unaryMinus-wrapped ConstantNode + if (!(0, _wildcards.isNumericNode)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'ce': + // rule matches expressions that have a constant value + if ((0, _wildcards.isConstantExpression)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 've': + // rule matches expressions that do not have a constant value + if (!(0, _wildcards.isConstantExpression)(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + default: + throw new Error('Invalid symbol in rule: ' + rule.name); + } + } + } else if (rule instanceof ConstantNode) { + // Literal constant must match exactly + if (!equal(rule.value, node.value)) { + return []; + } + } else { + // Some other node was encountered which we aren't prepared for, so no match + return []; + } + + // It's a match! + + // console.log('_ruleMatch(' + rule.toString() + ', ' + node.toString() + ') found a match') + return res; + } + + /** + * Determines whether p and q (and all their children nodes) are identical. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} p + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} q + * @return {Object} Information about the match, if it exists. + */ + function _exactMatch(p, q) { + if (p instanceof ConstantNode && q instanceof ConstantNode) { + if (!equal(p.value, q.value)) { + return false; + } + } else if (p instanceof SymbolNode && q instanceof SymbolNode) { + if (p.name !== q.name) { + return false; + } + } else if (p instanceof OperatorNode && q instanceof OperatorNode || p instanceof FunctionNode && q instanceof FunctionNode) { + if (p instanceof OperatorNode) { + if (p.op !== q.op || p.fn !== q.fn) { + return false; + } + } else if (p instanceof FunctionNode) { + if (p.name !== q.name) { + return false; + } + } + if (p.args.length !== q.args.length) { + return false; + } + for (let i = 0; i < p.args.length; i++) { + if (!_exactMatch(p.args[i], q.args[i])) { + return false; + } + } + } else { + return false; + } + return true; + } + return simplify; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/util.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/util.js new file mode 100644 index 0000000..9c445f4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/util.js @@ -0,0 +1,269 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUtil = void 0; +var _is = require("../../../utils/is.js"); +var _factory = require("../../../utils/factory.js"); +var _object = require("../../../utils/object.js"); +const name = 'simplifyUtil'; +const dependencies = ['FunctionNode', 'OperatorNode', 'SymbolNode']; +const createUtil = exports.createUtil = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + FunctionNode, + OperatorNode, + SymbolNode + } = _ref; + // TODO commutative/associative properties rely on the arguments + // e.g. multiply is not commutative for matrices + // The properties should be calculated from an argument to simplify, or possibly something in math.config + // the other option is for typed() to specify a return type so that we can evaluate the type of arguments + + /* So that properties of an operator fit on one line: */ + const T = true; + const F = false; + const defaultName = 'defaultF'; + const defaultContext = { + /* */add: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /**/unaryPlus: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /* */subtract: { + trivial: F, + total: T, + commutative: F, + associative: F + }, + /* */multiply: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /* */divide: { + trivial: F, + total: T, + commutative: F, + associative: F + }, + /* */paren: { + trivial: T, + total: T, + commutative: T, + associative: F + }, + /* */defaultF: { + trivial: F, + total: T, + commutative: F, + associative: F + } + }; + const realContext = { + divide: { + total: F + }, + log: { + total: F + } + }; + const positiveContext = { + subtract: { + total: F + }, + abs: { + trivial: T + }, + log: { + total: T + } + }; + function hasProperty(nodeOrName, property) { + let context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : defaultContext; + let name = defaultName; + if (typeof nodeOrName === 'string') { + name = nodeOrName; + } else if ((0, _is.isOperatorNode)(nodeOrName)) { + name = nodeOrName.fn.toString(); + } else if ((0, _is.isFunctionNode)(nodeOrName)) { + name = nodeOrName.name; + } else if ((0, _is.isParenthesisNode)(nodeOrName)) { + name = 'paren'; + } + if ((0, _object.hasOwnProperty)(context, name)) { + const properties = context[name]; + if ((0, _object.hasOwnProperty)(properties, property)) { + return properties[property]; + } + if ((0, _object.hasOwnProperty)(defaultContext, name)) { + return defaultContext[name][property]; + } + } + if ((0, _object.hasOwnProperty)(context, defaultName)) { + const properties = context[defaultName]; + if ((0, _object.hasOwnProperty)(properties, property)) { + return properties[property]; + } + return defaultContext[defaultName][property]; + } + /* name not found in context and context has no global default */ + /* So use default context. */ + if ((0, _object.hasOwnProperty)(defaultContext, name)) { + const properties = defaultContext[name]; + if ((0, _object.hasOwnProperty)(properties, property)) { + return properties[property]; + } + } + return defaultContext[defaultName][property]; + } + function isCommutative(node) { + let context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext; + return hasProperty(node, 'commutative', context); + } + function isAssociative(node) { + let context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext; + return hasProperty(node, 'associative', context); + } + + /** + * Merge the given contexts, with primary overriding secondary + * wherever they might conflict + */ + function mergeContext(primary, secondary) { + const merged = { + ...primary + }; + for (const prop in secondary) { + if ((0, _object.hasOwnProperty)(primary, prop)) { + merged[prop] = { + ...secondary[prop], + ...primary[prop] + }; + } else { + merged[prop] = secondary[prop]; + } + } + return merged; + } + + /** + * Flatten all associative operators in an expression tree. + * Assumes parentheses have already been removed. + */ + function flatten(node, context) { + if (!node.args || node.args.length === 0) { + return node; + } + node.args = allChildren(node, context); + for (let i = 0; i < node.args.length; i++) { + flatten(node.args[i], context); + } + } + + /** + * Get the children of a node as if it has been flattened. + * TODO implement for FunctionNodes + */ + function allChildren(node, context) { + let op; + const children = []; + const findChildren = function (node) { + for (let i = 0; i < node.args.length; i++) { + const child = node.args[i]; + if ((0, _is.isOperatorNode)(child) && op === child.op) { + findChildren(child); + } else { + children.push(child); + } + } + }; + if (isAssociative(node, context)) { + op = node.op; + findChildren(node); + return children; + } else { + return node.args; + } + } + + /** + * Unflatten all flattened operators to a right-heavy binary tree. + */ + function unflattenr(node, context) { + if (!node.args || node.args.length === 0) { + return; + } + const makeNode = createMakeNodeFunction(node); + const l = node.args.length; + for (let i = 0; i < l; i++) { + unflattenr(node.args[i], context); + } + if (l > 2 && isAssociative(node, context)) { + let curnode = node.args.pop(); + while (node.args.length > 0) { + curnode = makeNode([node.args.pop(), curnode]); + } + node.args = curnode.args; + } + } + + /** + * Unflatten all flattened operators to a left-heavy binary tree. + */ + function unflattenl(node, context) { + if (!node.args || node.args.length === 0) { + return; + } + const makeNode = createMakeNodeFunction(node); + const l = node.args.length; + for (let i = 0; i < l; i++) { + unflattenl(node.args[i], context); + } + if (l > 2 && isAssociative(node, context)) { + let curnode = node.args.shift(); + while (node.args.length > 0) { + curnode = makeNode([curnode, node.args.shift()]); + } + node.args = curnode.args; + } + } + function createMakeNodeFunction(node) { + if ((0, _is.isOperatorNode)(node)) { + return function (args) { + try { + return new OperatorNode(node.op, node.fn, args, node.implicit); + } catch (err) { + console.error(err); + return []; + } + }; + } else { + return function (args) { + return new FunctionNode(new SymbolNode(node.name), args); + }; + } + } + return { + createMakeNodeFunction, + hasProperty, + isCommutative, + isAssociative, + mergeContext, + flatten, + allChildren, + unflattenr, + unflattenl, + defaultContext, + realContext, + positiveContext + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/wildcards.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/wildcards.js new file mode 100644 index 0000000..b18a248 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplify/wildcards.js @@ -0,0 +1,38 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isConstantExpression = isConstantExpression; +Object.defineProperty(exports, "isConstantNode", { + enumerable: true, + get: function () { + return _is.isConstantNode; + } +}); +exports.isNumericNode = isNumericNode; +Object.defineProperty(exports, "isVariableNode", { + enumerable: true, + get: function () { + return _is.isSymbolNode; + } +}); +var _is = require("../../../utils/is.js"); +function isNumericNode(x) { + return (0, _is.isConstantNode)(x) || (0, _is.isOperatorNode)(x) && x.isUnary() && (0, _is.isConstantNode)(x.args[0]); +} +function isConstantExpression(x) { + if ((0, _is.isConstantNode)(x)) { + // Basic Constant types + return true; + } + if (((0, _is.isFunctionNode)(x) || (0, _is.isOperatorNode)(x)) && x.args.every(isConstantExpression)) { + // Can be constant depending on arguments + return true; + } + if ((0, _is.isParenthesisNode)(x) && isConstantExpression(x.content)) { + // Parenthesis are transparent + return true; + } + return false; // Probably missing some edge cases +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyConstant.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyConstant.js new file mode 100644 index 0000000..cf061a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyConstant.js @@ -0,0 +1,478 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSimplifyConstant = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _util = require("./simplify/util.js"); +var _noop = require("../../utils/noop.js"); +const name = 'simplifyConstant'; +const dependencies = ['typed', 'config', 'mathWithTransform', 'matrix', '?fraction', '?bignumber', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode']; +const createSimplifyConstant = exports.createSimplifyConstant = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + mathWithTransform, + matrix, + fraction, + bignumber, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode + } = _ref; + const { + isCommutative, + isAssociative, + allChildren, + createMakeNodeFunction + } = (0, _util.createUtil)({ + FunctionNode, + OperatorNode, + SymbolNode + }); + + /** + * simplifyConstant() takes a mathjs expression (either a Node representing + * a parse tree or a string which it parses to produce a node), and replaces + * any subexpression of it consisting entirely of constants with the computed + * value of that subexpression. + * + * Syntax: + * + * math.simplifyConstant(expr) + * math.simplifyConstant(expr, options) + * + * Examples: + * + * math.simplifyConstant('x + 4*3/6') // Node "x + 2" + * math.simplifyConstant('z cos(0)') // Node "z 1" + * math.simplifyConstant('(5.2 + 1.08)t', {exactFractions: false}) // Node "6.28 t" + * + * See also: + * + * simplify, simplifyCore, resolve, derivative + * + * @param {Node | string} node + * The expression to be simplified + * @param {Object} options + * Simplification options, as per simplify() + * @return {Node} Returns expression with constant subexpressions evaluated + */ + const simplifyConstant = typed('simplifyConstant', { + Node: node => _ensureNode(foldFraction(node, {})), + 'Node, Object': function (expr, options) { + return _ensureNode(foldFraction(expr, options)); + } + }); + function _removeFractions(thing) { + if ((0, _is.isFraction)(thing)) { + return thing.valueOf(); + } + if (thing instanceof Array) { + return thing.map(_removeFractions); + } + if ((0, _is.isMatrix)(thing)) { + return matrix(_removeFractions(thing.valueOf())); + } + return thing; + } + function _eval(fnname, args, options) { + try { + return mathWithTransform[fnname].apply(null, args); + } catch (ignore) { + // sometimes the implicit type conversion causes the evaluation to fail, so we'll try again after removing Fractions + args = args.map(_removeFractions); + return _toNumber(mathWithTransform[fnname].apply(null, args), options); + } + } + const _toNode = typed({ + Fraction: _fractionToNode, + number: function (n) { + if (n < 0) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); + }, + BigNumber: function (n) { + if (n < 0) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); // old parameters: (n.toString(), 'number') + }, + bigint: function (n) { + if (n < 0n) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); + }, + Complex: function (s) { + throw new Error('Cannot convert Complex number to Node'); + }, + string: function (s) { + return new ConstantNode(s); + }, + Matrix: function (m) { + return new ArrayNode(m.valueOf().map(e => _toNode(e))); + } + }); + function _ensureNode(thing) { + if ((0, _is.isNode)(thing)) { + return thing; + } + return _toNode(thing); + } + + // convert a number to a fraction only if it can be expressed exactly, + // and when both numerator and denominator are small enough + function _exactFraction(n, options) { + const exactFractions = options && options.exactFractions !== false; + if (exactFractions && isFinite(n) && fraction) { + const f = fraction(n); + const fractionsLimit = options && typeof options.fractionsLimit === 'number' ? options.fractionsLimit : Infinity; // no limit by default + + if (f.valueOf() === n && f.n < fractionsLimit && f.d < fractionsLimit) { + return f; + } + } + return n; + } + + // Convert numbers to a preferred number type in preference order: Fraction, number, Complex + // BigNumbers are left alone + const _toNumber = typed({ + 'string, Object': function (s, options) { + const numericType = (0, _number.safeNumberType)(s, config); + if (numericType === 'BigNumber') { + if (bignumber === undefined) { + (0, _noop.noBignumber)(); + } + return bignumber(s); + } else if (numericType === 'bigint') { + return BigInt(s); + } else if (numericType === 'Fraction') { + if (fraction === undefined) { + (0, _noop.noFraction)(); + } + return fraction(s); + } else { + const n = parseFloat(s); + return _exactFraction(n, options); + } + }, + 'Fraction, Object': function (s, options) { + return s; + }, + // we don't need options here + + 'BigNumber, Object': function (s, options) { + return s; + }, + // we don't need options here + + 'number, Object': function (s, options) { + return _exactFraction(s, options); + }, + 'bigint, Object': function (s, options) { + return s; + }, + 'Complex, Object': function (s, options) { + if (s.im !== 0) { + return s; + } + return _exactFraction(s.re, options); + }, + 'Matrix, Object': function (s, options) { + return matrix(_exactFraction(s.valueOf())); + }, + 'Array, Object': function (s, options) { + return s.map(_exactFraction); + } + }); + function unaryMinusNode(n) { + return new OperatorNode('-', 'unaryMinus', [n]); + } + function _fractionToNode(f) { + let n; + const vn = f.s * f.n; + if (vn < 0) { + n = new OperatorNode('-', 'unaryMinus', [new ConstantNode(-vn)]); + } else { + n = new ConstantNode(vn); + } + if (f.d === 1) { + return n; + } + return new OperatorNode('/', 'divide', [n, new ConstantNode(f.d)]); + } + + /* Handles constant indexing of ArrayNodes, matrices, and ObjectNodes */ + function _foldAccessor(obj, index, options) { + if (!(0, _is.isIndexNode)(index)) { + // don't know what to do with that... + return new AccessorNode(_ensureNode(obj), _ensureNode(index)); + } + if ((0, _is.isArrayNode)(obj) || (0, _is.isMatrix)(obj)) { + const remainingDims = Array.from(index.dimensions); + /* We will resolve constant indices one at a time, looking + * just in the first or second dimensions because (a) arrays + * of more than two dimensions are likely rare, and (b) pulling + * out the third or higher dimension would be pretty intricate. + * The price is that we miss simplifying [..3d array][x,y,1] + */ + while (remainingDims.length > 0) { + if ((0, _is.isConstantNode)(remainingDims[0]) && typeof remainingDims[0].value !== 'string') { + const first = _toNumber(remainingDims.shift().value, options); + if ((0, _is.isArrayNode)(obj)) { + obj = obj.items[first - 1]; + } else { + // matrix + obj = obj.valueOf()[first - 1]; + if (obj instanceof Array) { + obj = matrix(obj); + } + } + } else if (remainingDims.length > 1 && (0, _is.isConstantNode)(remainingDims[1]) && typeof remainingDims[1].value !== 'string') { + const second = _toNumber(remainingDims[1].value, options); + const tryItems = []; + const fromItems = (0, _is.isArrayNode)(obj) ? obj.items : obj.valueOf(); + for (const item of fromItems) { + if ((0, _is.isArrayNode)(item)) { + tryItems.push(item.items[second - 1]); + } else if ((0, _is.isMatrix)(obj)) { + tryItems.push(item[second - 1]); + } else { + break; + } + } + if (tryItems.length === fromItems.length) { + if ((0, _is.isArrayNode)(obj)) { + obj = new ArrayNode(tryItems); + } else { + // matrix + obj = matrix(tryItems); + } + remainingDims.splice(1, 1); + } else { + // extracting slice along 2nd dimension failed, give up + break; + } + } else { + // neither 1st or 2nd dimension is constant, give up + break; + } + } + if (remainingDims.length === index.dimensions.length) { + /* No successful constant indexing */ + return new AccessorNode(_ensureNode(obj), index); + } + if (remainingDims.length > 0) { + /* Indexed some but not all dimensions */ + index = new IndexNode(remainingDims); + return new AccessorNode(_ensureNode(obj), index); + } + /* All dimensions were constant, access completely resolved */ + return obj; + } + if ((0, _is.isObjectNode)(obj) && index.dimensions.length === 1 && (0, _is.isConstantNode)(index.dimensions[0])) { + const key = index.dimensions[0].value; + if (key in obj.properties) { + return obj.properties[key]; + } + return new ConstantNode(); // undefined + } + /* Don't know how to index this sort of obj, at least not with this index */ + return new AccessorNode(_ensureNode(obj), index); + } + + /* + * Create a binary tree from a list of Fractions and Nodes. + * Tries to fold Fractions by evaluating them until the first Node in the list is hit, so + * `args` should be sorted to have the Fractions at the start (if the operator is commutative). + * @param args - list of Fractions and Nodes + * @param fn - evaluator for the binary operation evaluator that accepts two Fractions + * @param makeNode - creates a binary OperatorNode/FunctionNode from a list of child Nodes + * if args.length is 1, returns args[0] + * @return - Either a Node representing a binary expression or Fraction + */ + function foldOp(fn, args, makeNode, options) { + const first = args.shift(); + + // In the following reduction, sofar always has one of the three following + // forms: [NODE], [CONSTANT], or [NODE, CONSTANT] + const reduction = args.reduce((sofar, next) => { + if (!(0, _is.isNode)(next)) { + const last = sofar.pop(); + if ((0, _is.isNode)(last)) { + return [last, next]; + } + // Two constants in a row, try to fold them into one + try { + sofar.push(_eval(fn, [last, next], options)); + return sofar; + } catch (ignoreandcontinue) { + sofar.push(last); + // fall through to Node case + } + } + + // Encountered a Node, or failed folding -- + // collapse everything so far into a single tree: + sofar.push(_ensureNode(sofar.pop())); + const newtree = sofar.length === 1 ? sofar[0] : makeNode(sofar); + return [makeNode([newtree, _ensureNode(next)])]; + }, [first]); + if (reduction.length === 1) { + return reduction[0]; + } + // Might end up with a tree and a constant at the end: + return makeNode([reduction[0], _toNode(reduction[1])]); + } + + // destroys the original node and returns a folded one + function foldFraction(node, options) { + switch (node.type) { + case 'SymbolNode': + return node; + case 'ConstantNode': + switch (typeof node.value) { + case 'number': + return _toNumber(node.value, options); + case 'bigint': + return _toNumber(node.value, options); + case 'string': + return node.value; + default: + if (!isNaN(node.value)) return _toNumber(node.value, options); + } + return node; + case 'FunctionNode': + if (mathWithTransform[node.name] && mathWithTransform[node.name].rawArgs) { + return node; + } + { + // Process operators as OperatorNode + const operatorFunctions = ['add', 'multiply']; + if (!operatorFunctions.includes(node.name)) { + const args = node.args.map(arg => foldFraction(arg, options)); + + // If all args are numbers + if (!args.some(_is.isNode)) { + try { + return _eval(node.name, args, options); + } catch (ignoreandcontinue) {} + } + + // Size of a matrix does not depend on entries + if (node.name === 'size' && args.length === 1 && (0, _is.isArrayNode)(args[0])) { + const sz = []; + let section = args[0]; + while ((0, _is.isArrayNode)(section)) { + sz.push(section.items.length); + section = section.items[0]; + } + return matrix(sz); + } + + // Convert all args to nodes and construct a symbolic function call + return new FunctionNode(node.name, args.map(_ensureNode)); + } else { + // treat as operator + } + } + /* falls through */ + case 'OperatorNode': + { + const fn = node.fn.toString(); + let args; + let res; + const makeNode = createMakeNodeFunction(node); + if ((0, _is.isOperatorNode)(node) && node.isUnary()) { + args = [foldFraction(node.args[0], options)]; + if (!(0, _is.isNode)(args[0])) { + res = _eval(fn, args, options); + } else { + res = makeNode(args); + } + } else if (isAssociative(node, options.context)) { + args = allChildren(node, options.context); + args = args.map(arg => foldFraction(arg, options)); + if (isCommutative(fn, options.context)) { + // commutative binary operator + const consts = []; + const vars = []; + for (let i = 0; i < args.length; i++) { + if (!(0, _is.isNode)(args[i])) { + consts.push(args[i]); + } else { + vars.push(args[i]); + } + } + if (consts.length > 1) { + res = foldOp(fn, consts, makeNode, options); + vars.unshift(res); + res = foldOp(fn, vars, makeNode, options); + } else { + // we won't change the children order since it's not neccessary + res = foldOp(fn, args, makeNode, options); + } + } else { + // non-commutative binary operator + res = foldOp(fn, args, makeNode, options); + } + } else { + // non-associative binary operator + args = node.args.map(arg => foldFraction(arg, options)); + res = foldOp(fn, args, makeNode, options); + } + return res; + } + case 'ParenthesisNode': + // remove the uneccessary parenthesis + return foldFraction(node.content, options); + case 'AccessorNode': + return _foldAccessor(foldFraction(node.object, options), foldFraction(node.index, options), options); + case 'ArrayNode': + { + const foldItems = node.items.map(item => foldFraction(item, options)); + if (foldItems.some(_is.isNode)) { + return new ArrayNode(foldItems.map(_ensureNode)); + } + /* All literals -- return a Matrix so we can operate on it */ + return matrix(foldItems); + } + case 'IndexNode': + { + return new IndexNode(node.dimensions.map(n => simplifyConstant(n, options))); + } + case 'ObjectNode': + { + const foldProps = {}; + for (const prop in node.properties) { + foldProps[prop] = simplifyConstant(node.properties[prop], options); + } + return new ObjectNode(foldProps); + } + case 'AssignmentNode': + /* falls through */ + case 'BlockNode': + /* falls through */ + case 'FunctionAssignmentNode': + /* falls through */ + case 'RangeNode': + /* falls through */ + case 'ConditionalNode': + /* falls through */ + default: + throw new Error(`Unimplemented node type in simplifyConstant: ${node.type}`); + } + } + return simplifyConstant; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyCore.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyCore.js new file mode 100644 index 0000000..0e21b5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/simplifyCore.js @@ -0,0 +1,297 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSimplifyCore = void 0; +var _is = require("../../utils/is.js"); +var _operators = require("../../expression/operators.js"); +var _util = require("./simplify/util.js"); +var _factory = require("../../utils/factory.js"); +const name = 'simplifyCore'; +const dependencies = ['typed', 'parse', 'equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +const createSimplifyCore = exports.createSimplifyCore = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + parse, + equal, + isZero, + add, + subtract, + multiply, + divide, + pow, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + const node0 = new ConstantNode(0); + const node1 = new ConstantNode(1); + const nodeT = new ConstantNode(true); + const nodeF = new ConstantNode(false); + // test if a node will always have a boolean value (true/false) + // not sure if this list is complete + function isAlwaysBoolean(node) { + return (0, _is.isOperatorNode)(node) && ['and', 'not', 'or'].includes(node.op); + } + const { + hasProperty, + isCommutative + } = (0, _util.createUtil)({ + FunctionNode, + OperatorNode, + SymbolNode + }); + /** + * simplifyCore() performs single pass simplification suitable for + * applications requiring ultimate performance. To roughly summarize, + * it handles cases along the lines of simplifyConstant() but where + * knowledge of a single argument is sufficient to determine the value. + * In contrast, simplify() extends simplifyCore() with additional passes + * to provide deeper simplification (such as gathering like terms). + * + * Specifically, simplifyCore: + * + * * Converts all function calls with operator equivalents to their + * operator forms. + * * Removes operators or function calls that are guaranteed to have no + * effect (such as unary '+'). + * * Removes double unary '-', '~', and 'not' + * * Eliminates addition/subtraction of 0 and multiplication/division/powers + * by 1 or 0. + * * Converts addition of a negation into subtraction. + * * Eliminates logical operations with constant true or false leading + * arguments. + * * Puts constants on the left of a product, if multiplication is + * considered commutative by the options (which is the default) + * + * Syntax: + * + * math.simplifyCore(expr) + * math.simplifyCore(expr, options) + * + * Examples: + * + * const f = math.parse('2 * 1 * x ^ (1 - 0)') + * math.simplifyCore(f) // Node "2 * x" + * math.simplify('2 * 1 * x ^ (1 - 0)', [math.simplifyCore]) // Node "2 * x" + * + * See also: + * + * simplify, simplifyConstant, resolve, derivative + * + * @param {Node | string} node + * The expression to be simplified + * @param {Object} options + * Simplification options, as per simplify() + * @return {Node} Returns expression with basic simplifications applied + */ + function _simplifyCore(nodeToSimplify) { + let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + const context = options ? options.context : undefined; + if (hasProperty(nodeToSimplify, 'trivial', context)) { + // This node does nothing if it has only one argument, so if so, + // return that argument simplified + if ((0, _is.isFunctionNode)(nodeToSimplify) && nodeToSimplify.args.length === 1) { + return _simplifyCore(nodeToSimplify.args[0], options); + } + // For other node types, we try the generic methods + let simpChild = false; + let childCount = 0; + nodeToSimplify.forEach(c => { + ++childCount; + if (childCount === 1) { + simpChild = _simplifyCore(c, options); + } + }); + if (childCount === 1) { + return simpChild; + } + } + let node = nodeToSimplify; + if ((0, _is.isFunctionNode)(node)) { + const op = (0, _operators.getOperator)(node.name); + if (op) { + // Replace FunctionNode with a new OperatorNode + if (node.args.length > 2 && hasProperty(node, 'associative', context)) { + // unflatten into binary operations since that's what simplifyCore handles + while (node.args.length > 2) { + const last = node.args.pop(); + const seclast = node.args.pop(); + node.args.push(new OperatorNode(op, node.name, [last, seclast])); + } + } + node = new OperatorNode(op, node.name, node.args); + } else { + return new FunctionNode(_simplifyCore(node.fn), node.args.map(n => _simplifyCore(n, options))); + } + } + if ((0, _is.isOperatorNode)(node) && node.isUnary()) { + const a0 = _simplifyCore(node.args[0], options); + if (node.op === '~') { + // bitwise not + if ((0, _is.isOperatorNode)(a0) && a0.isUnary() && a0.op === '~') { + return a0.args[0]; + } + } + if (node.op === 'not') { + // logical not + if ((0, _is.isOperatorNode)(a0) && a0.isUnary() && a0.op === 'not') { + // Has the effect of turning the argument into a boolean + // So can only eliminate the double negation if + // the inside is already boolean + if (isAlwaysBoolean(a0.args[0])) { + return a0.args[0]; + } + } + } + let finish = true; + if (node.op === '-') { + // unary minus + if ((0, _is.isOperatorNode)(a0)) { + if (a0.isBinary() && a0.fn === 'subtract') { + node = new OperatorNode('-', 'subtract', [a0.args[1], a0.args[0]]); + finish = false; // continue to process the new binary node + } + if (a0.isUnary() && a0.op === '-') { + return a0.args[0]; + } + } + } + if (finish) return new OperatorNode(node.op, node.fn, [a0]); + } + if ((0, _is.isOperatorNode)(node) && node.isBinary()) { + const a0 = _simplifyCore(node.args[0], options); + let a1 = _simplifyCore(node.args[1], options); + if (node.op === '+') { + if ((0, _is.isConstantNode)(a0) && isZero(a0.value)) { + return a1; + } + if ((0, _is.isConstantNode)(a1) && isZero(a1.value)) { + return a0; + } + if ((0, _is.isOperatorNode)(a1) && a1.isUnary() && a1.op === '-') { + a1 = a1.args[0]; + node = new OperatorNode('-', 'subtract', [a0, a1]); + } + } + if (node.op === '-') { + if ((0, _is.isOperatorNode)(a1) && a1.isUnary() && a1.op === '-') { + return _simplifyCore(new OperatorNode('+', 'add', [a0, a1.args[0]]), options); + } + if ((0, _is.isConstantNode)(a0) && isZero(a0.value)) { + return _simplifyCore(new OperatorNode('-', 'unaryMinus', [a1])); + } + if ((0, _is.isConstantNode)(a1) && isZero(a1.value)) { + return a0; + } + return new OperatorNode(node.op, node.fn, [a0, a1]); + } + if (node.op === '*') { + if ((0, _is.isConstantNode)(a0)) { + if (isZero(a0.value)) { + return node0; + } else if (equal(a0.value, 1)) { + return a1; + } + } + if ((0, _is.isConstantNode)(a1)) { + if (isZero(a1.value)) { + return node0; + } else if (equal(a1.value, 1)) { + return a0; + } + if (isCommutative(node, context)) { + return new OperatorNode(node.op, node.fn, [a1, a0], node.implicit); // constants on left + } + } + return new OperatorNode(node.op, node.fn, [a0, a1], node.implicit); + } + if (node.op === '/') { + if ((0, _is.isConstantNode)(a0) && isZero(a0.value)) { + return node0; + } + if ((0, _is.isConstantNode)(a1) && equal(a1.value, 1)) { + return a0; + } + return new OperatorNode(node.op, node.fn, [a0, a1]); + } + if (node.op === '^') { + if ((0, _is.isConstantNode)(a1)) { + if (isZero(a1.value)) { + return node1; + } else if (equal(a1.value, 1)) { + return a0; + } + } + } + if (node.op === 'and') { + if ((0, _is.isConstantNode)(a0)) { + if (a0.value) { + if (isAlwaysBoolean(a1)) return a1; + if ((0, _is.isConstantNode)(a1)) { + return a1.value ? nodeT : nodeF; + } + } else { + return nodeF; + } + } + if ((0, _is.isConstantNode)(a1)) { + if (a1.value) { + if (isAlwaysBoolean(a0)) return a0; + } else { + return nodeF; + } + } + } + if (node.op === 'or') { + if ((0, _is.isConstantNode)(a0)) { + if (a0.value) { + return nodeT; + } else { + if (isAlwaysBoolean(a1)) return a1; + } + } + if ((0, _is.isConstantNode)(a1)) { + if (a1.value) { + return nodeT; + } else { + if (isAlwaysBoolean(a0)) return a0; + } + } + } + return new OperatorNode(node.op, node.fn, [a0, a1]); + } + if ((0, _is.isOperatorNode)(node)) { + return new OperatorNode(node.op, node.fn, node.args.map(a => _simplifyCore(a, options))); + } + if ((0, _is.isArrayNode)(node)) { + return new ArrayNode(node.items.map(n => _simplifyCore(n, options))); + } + if ((0, _is.isAccessorNode)(node)) { + return new AccessorNode(_simplifyCore(node.object, options), _simplifyCore(node.index, options)); + } + if ((0, _is.isIndexNode)(node)) { + return new IndexNode(node.dimensions.map(n => _simplifyCore(n, options))); + } + if ((0, _is.isObjectNode)(node)) { + const newProps = {}; + for (const prop in node.properties) { + newProps[prop] = _simplifyCore(node.properties[prop], options); + } + return new ObjectNode(newProps); + } + // cannot simplify + return node; + } + return typed(name, { + Node: _simplifyCore, + 'Node,Object': _simplifyCore + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolve.js new file mode 100644 index 0000000..fb5d6bb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolve.js @@ -0,0 +1,163 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLsolve = void 0; +var _factory = require("../../../utils/factory.js"); +var _solveValidation = require("./utils/solveValidation.js"); +const name = 'lsolve'; +const dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +const createLsolve = exports.createLsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + const solveValidation = (0, _solveValidation.createSolveValidation)({ + DenseMatrix + }); + + /** + * Finds one solution of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. Throws an error if there's no solution. + * + * `L * x = b` + * + * Syntax: + * + * math.lsolve(L, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = lsolve(a, b) // [[-5.5], [20]] + * + * See also: + * + * lsolveAll, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} L A N x N matrix or array (L) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix | Array} A column vector with the linear system solution (x) + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function (m, b) { + return _sparseForwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function (m, b) { + return _denseForwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function (a, b) { + const m = matrix(a); + const r = _denseForwardSubstitution(m, b); + return r.valueOf(); + } + }); + function _denseForwardSubstitution(m, b) { + // validate matrix and vector, return copy of column vector b + b = solveValidation(m, b, true); + const bdata = b._data; + const rows = m._size[0]; + const columns = m._size[1]; + + // result + const x = []; + const mdata = m._data; + + // loop columns + for (let j = 0; j < columns; j++) { + const bj = bdata[j][0] || 0; + let xj; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + const vjj = mdata[j][j]; + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + xj = divideScalar(bj, vjj); + + // loop rows + for (let i = j + 1; i < rows; i++) { + bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]; + } + } else { + // degenerate row, we can choose any value + xj = 0; + } + x[j] = [xj]; + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } + function _sparseForwardSubstitution(m, b) { + // validate matrix and vector, return copy of column vector b + b = solveValidation(m, b, true); + const bdata = b._data; + const rows = m._size[0]; + const columns = m._size[1]; + const values = m._values; + const index = m._index; + const ptr = m._ptr; + + // result + const x = []; + + // loop columns + for (let j = 0; j < columns; j++) { + const bj = bdata[j][0] || 0; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + let vjj = 0; + // matrix values & indices (column j) + const jValues = []; + const jIndices = []; + + // first and last index in the column + const firstIndex = ptr[j]; + const lastIndex = ptr[j + 1]; + + // values in column, find value at [j, j] + for (let k = firstIndex; k < lastIndex; k++) { + const i = index[k]; + + // check row (rows are not sorted!) + if (i === j) { + vjj = values[k]; + } else if (i > j) { + // store lower triangular + jValues.push(values[k]); + jIndices.push(i); + } + } + + // at this point we must have a value in vjj + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + const xj = divideScalar(bj, vjj); + for (let k = 0, l = jIndices.length; k < l; k++) { + const i = jIndices[k]; + bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, jValues[k]))]; + } + x[j] = [xj]; + } else { + // degenerate row, we can choose any value + x[j] = [0]; + } + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolveAll.js new file mode 100644 index 0000000..c2e40e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lsolveAll.js @@ -0,0 +1,192 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLsolveAll = void 0; +var _factory = require("../../../utils/factory.js"); +var _solveValidation = require("./utils/solveValidation.js"); +const name = 'lsolveAll'; +const dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +const createLsolveAll = exports.createLsolveAll = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + const solveValidation = (0, _solveValidation.createSolveValidation)({ + DenseMatrix + }); + + /** + * Finds all solutions of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. + * + * `L * x = b` + * + * Syntax: + * + * math.lsolveAll(L, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = lsolveAll(a, b) // [ [[-5.5], [20]] ] + * + * See also: + * + * lsolve, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} L A N x N matrix or array (L) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function (m, b) { + return _sparseForwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function (m, b) { + return _denseForwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function (a, b) { + const m = matrix(a); + const R = _denseForwardSubstitution(m, b); + return R.map(r => r.valueOf()); + } + }); + function _denseForwardSubstitution(m, b_) { + // the algorithm is derived from + // https://www.overleaf.com/read/csvgqdxggyjv + + // array of right-hand sides + const B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + const M = m._data; + const rows = m._size[0]; + const columns = m._size[1]; + + // loop columns + for (let i = 0; i < columns; i++) { + let L = B.length; + + // loop right-hand sides + for (let k = 0; k < L; k++) { + const b = B[k]; + if (!equalScalar(M[i][i], 0)) { + // non-singular row + + b[i] = divideScalar(b[i], M[i][i]); + for (let j = i + 1; j < columns; j++) { + // b[j] -= b[i] * M[j,i] + b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + const bNew = [...b]; + bNew[i] = 1; + for (let j = i + 1; j < columns; j++) { + bNew[j] = subtractScalar(bNew[j], M[j][i]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } + function _sparseForwardSubstitution(m, b_) { + // array of right-hand sides + const B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + const rows = m._size[0]; + const columns = m._size[1]; + const values = m._values; + const index = m._index; + const ptr = m._ptr; + + // loop columns + for (let i = 0; i < columns; i++) { + let L = B.length; + + // loop right-hand sides + for (let k = 0; k < L; k++) { + const b = B[k]; + + // values & indices (column i) + const iValues = []; + const iIndices = []; + + // first & last indeces in column + const firstIndex = ptr[i]; + const lastIndex = ptr[i + 1]; + + // find the value at [i, i] + let Mii = 0; + for (let j = firstIndex; j < lastIndex; j++) { + const J = index[j]; + // check row + if (J === i) { + Mii = values[j]; + } else if (J > i) { + // store lower triangular + iValues.push(values[j]); + iIndices.push(J); + } + } + if (!equalScalar(Mii, 0)) { + // non-singular row + + b[i] = divideScalar(b[i], Mii); + for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) { + const J = iIndices[j]; + b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + const bNew = [...b]; + bNew[i] = 1; + for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) { + const J = iIndices[j]; + bNew[J] = subtractScalar(bNew[J], iValues[j]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lusolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lusolve.js new file mode 100644 index 0000000..8227019 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/lusolve.js @@ -0,0 +1,114 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLusolve = void 0; +var _is = require("../../../utils/is.js"); +var _factory = require("../../../utils/factory.js"); +var _solveValidation = require("./utils/solveValidation.js"); +var _csIpvec = require("../sparse/csIpvec.js"); +const name = 'lusolve'; +const dependencies = ['typed', 'matrix', 'lup', 'slu', 'usolve', 'lsolve', 'DenseMatrix']; +const createLusolve = exports.createLusolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + lup, + slu, + usolve, + lsolve, + DenseMatrix + } = _ref; + const solveValidation = (0, _solveValidation.createSolveValidation)({ + DenseMatrix + }); + + /** + * Solves the linear system `A * x = b` where `A` is an [n x n] matrix and `b` is a [n] column vector. + * + * Syntax: + * + * math.lusolve(A, b) // returns column vector with the solution to the linear system A * x = b + * math.lusolve(lup, b) // returns column vector with the solution to the linear system A * x = b, lup = math.lup(A) + * + * Examples: + * + * const m = [[1, 0, 0, 0], [0, 2, 0, 0], [0, 0, 3, 0], [0, 0, 0, 4]] + * + * const x = math.lusolve(m, [-1, -1, -1, -1]) // x = [[-1], [-0.5], [-1/3], [-0.25]] + * + * const f = math.lup(m) + * const x1 = math.lusolve(f, [-1, -1, -1, -1]) // x1 = [[-1], [-0.5], [-1/3], [-0.25]] + * const x2 = math.lusolve(f, [1, 2, 1, -1]) // x2 = [[1], [1], [1/3], [-0.25]] + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = math.lusolve(a, b) // [[2], [5]] + * + * See also: + * + * lup, slu, lsolve, usolve + * + * @param {Matrix | Array | Object} A Invertible Matrix or the Matrix LU decomposition + * @param {Matrix | Array} b Column Vector + * @param {number} [order] The Symbolic Ordering and Analysis order, see slu for details. Matrix must be a SparseMatrix + * @param {Number} [threshold] Partial pivoting threshold (1 for partial pivoting), see slu for details. Matrix must be a SparseMatrix. + * + * @return {DenseMatrix | Array} Column vector with the solution to the linear system A * x = b + */ + return typed(name, { + 'Array, Array | Matrix': function (a, b) { + a = matrix(a); + const d = lup(a); + const x = _lusolve(d.L, d.U, d.p, null, b); + return x.valueOf(); + }, + 'DenseMatrix, Array | Matrix': function (a, b) { + const d = lup(a); + return _lusolve(d.L, d.U, d.p, null, b); + }, + 'SparseMatrix, Array | Matrix': function (a, b) { + const d = lup(a); + return _lusolve(d.L, d.U, d.p, null, b); + }, + 'SparseMatrix, Array | Matrix, number, number': function (a, b, order, threshold) { + const d = slu(a, order, threshold); + return _lusolve(d.L, d.U, d.p, d.q, b); + }, + 'Object, Array | Matrix': function (d, b) { + return _lusolve(d.L, d.U, d.p, d.q, b); + } + }); + function _toMatrix(a) { + if ((0, _is.isMatrix)(a)) { + return a; + } + if ((0, _is.isArray)(a)) { + return matrix(a); + } + throw new TypeError('Invalid Matrix LU decomposition'); + } + function _lusolve(l, u, p, q, b) { + // verify decomposition + l = _toMatrix(l); + u = _toMatrix(u); + + // apply row permutations if needed (b is a DenseMatrix) + if (p) { + b = solveValidation(l, b, true); + b._data = (0, _csIpvec.csIpvec)(p, b._data); + } + + // use forward substitution to resolve L * y = b + const y = lsolve(l, b); + // use backward substitution to resolve U * x = y + const x = usolve(u, y); + + // apply column permutations if needed (x is a DenseMatrix) + if (q) { + x._data = (0, _csIpvec.csIpvec)(q, x._data); + } + return x; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolve.js new file mode 100644 index 0000000..e36877d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolve.js @@ -0,0 +1,167 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUsolve = void 0; +var _factory = require("../../../utils/factory.js"); +var _solveValidation = require("./utils/solveValidation.js"); +const name = 'usolve'; +const dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +const createUsolve = exports.createUsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + const solveValidation = (0, _solveValidation.createSolveValidation)({ + DenseMatrix + }); + + /** + * Finds one solution of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. Throws an error if there's no solution. + * + * `U * x = b` + * + * Syntax: + * + * math.usolve(U, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = usolve(a, b) // [[8], [9]] + * + * See also: + * + * usolveAll, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} U A N x N matrix or array (U) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix | Array} A column vector with the linear system solution (x) + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function (m, b) { + return _sparseBackwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function (m, b) { + return _denseBackwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function (a, b) { + const m = matrix(a); + const r = _denseBackwardSubstitution(m, b); + return r.valueOf(); + } + }); + function _denseBackwardSubstitution(m, b) { + // make b into a column vector + b = solveValidation(m, b, true); + const bdata = b._data; + const rows = m._size[0]; + const columns = m._size[1]; + + // result + const x = []; + const mdata = m._data; + // loop columns backwards + for (let j = columns - 1; j >= 0; j--) { + // b[j] + const bj = bdata[j][0] || 0; + // x[j] + let xj; + if (!equalScalar(bj, 0)) { + // value at [j, j] + const vjj = mdata[j][j]; + if (equalScalar(vjj, 0)) { + // system cannot be solved + throw new Error('Linear system cannot be solved since matrix is singular'); + } + xj = divideScalar(bj, vjj); + + // loop rows + for (let i = j - 1; i >= 0; i--) { + // update copy of b + bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]; + } + } else { + // zero value at j + xj = 0; + } + // update x + x[j] = [xj]; + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } + function _sparseBackwardSubstitution(m, b) { + // make b into a column vector + b = solveValidation(m, b, true); + const bdata = b._data; + const rows = m._size[0]; + const columns = m._size[1]; + const values = m._values; + const index = m._index; + const ptr = m._ptr; + + // result + const x = []; + + // loop columns backwards + for (let j = columns - 1; j >= 0; j--) { + const bj = bdata[j][0] || 0; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + let vjj = 0; + + // upper triangular matrix values & index (column j) + const jValues = []; + const jIndices = []; + + // first & last indeces in column + const firstIndex = ptr[j]; + const lastIndex = ptr[j + 1]; + + // values in column, find value at [j, j], loop backwards + for (let k = lastIndex - 1; k >= firstIndex; k--) { + const i = index[k]; + + // check row (rows are not sorted!) + if (i === j) { + vjj = values[k]; + } else if (i < j) { + // store upper triangular + jValues.push(values[k]); + jIndices.push(i); + } + } + + // at this point we must have a value in vjj + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + const xj = divideScalar(bj, vjj); + for (let k = 0, lastIndex = jIndices.length; k < lastIndex; k++) { + const i = jIndices[k]; + bdata[i] = [subtractScalar(bdata[i][0], multiplyScalar(xj, jValues[k]))]; + } + x[j] = [xj]; + } else { + // degenerate row, we can choose any value + x[j] = [0]; + } + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolveAll.js new file mode 100644 index 0000000..5b6b5de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/usolveAll.js @@ -0,0 +1,196 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUsolveAll = void 0; +var _factory = require("../../../utils/factory.js"); +var _solveValidation = require("./utils/solveValidation.js"); +const name = 'usolveAll'; +const dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +const createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + const solveValidation = (0, _solveValidation.createSolveValidation)({ + DenseMatrix + }); + + /** + * Finds all solutions of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. + * + * `U * x = b` + * + * Syntax: + * + * math.usolveAll(U, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = usolveAll(a, b) // [ [[8], [9]] ] + * + * See also: + * + * usolve, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} U A N x N matrix or array (U) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function (m, b) { + return _sparseBackwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function (m, b) { + return _denseBackwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function (a, b) { + const m = matrix(a); + const R = _denseBackwardSubstitution(m, b); + return R.map(r => r.valueOf()); + } + }); + function _denseBackwardSubstitution(m, b_) { + // the algorithm is derived from + // https://www.overleaf.com/read/csvgqdxggyjv + + // array of right-hand sides + const B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + const M = m._data; + const rows = m._size[0]; + const columns = m._size[1]; + + // loop columns backwards + for (let i = columns - 1; i >= 0; i--) { + let L = B.length; + + // loop right-hand sides + for (let k = 0; k < L; k++) { + const b = B[k]; + if (!equalScalar(M[i][i], 0)) { + // non-singular row + + b[i] = divideScalar(b[i], M[i][i]); + for (let j = i - 1; j >= 0; j--) { + // b[j] -= b[i] * M[j,i] + b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + const bNew = [...b]; + bNew[i] = 1; + for (let j = i - 1; j >= 0; j--) { + bNew[j] = subtractScalar(bNew[j], M[j][i]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } + function _sparseBackwardSubstitution(m, b_) { + // array of right-hand sides + const B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + const rows = m._size[0]; + const columns = m._size[1]; + const values = m._values; + const index = m._index; + const ptr = m._ptr; + + // loop columns backwards + for (let i = columns - 1; i >= 0; i--) { + let L = B.length; + + // loop right-hand sides + for (let k = 0; k < L; k++) { + const b = B[k]; + + // values & indices (column i) + const iValues = []; + const iIndices = []; + + // first & last indeces in column + const firstIndex = ptr[i]; + const lastIndex = ptr[i + 1]; + + // find the value at [i, i] + let Mii = 0; + for (let j = lastIndex - 1; j >= firstIndex; j--) { + const J = index[j]; + // check row + if (J === i) { + Mii = values[j]; + } else if (J < i) { + // store upper triangular + iValues.push(values[j]); + iIndices.push(J); + } + } + if (!equalScalar(Mii, 0)) { + // non-singular row + + b[i] = divideScalar(b[i], Mii); + + // loop upper triangular + for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) { + const J = iIndices[j]; + b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + const bNew = [...b]; + bNew[i] = 1; + + // loop upper triangular + for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) { + const J = iIndices[j]; + bNew[J] = subtractScalar(bNew[J], iValues[j]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js new file mode 100644 index 0000000..c0defc6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js @@ -0,0 +1,121 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSolveValidation = createSolveValidation; +var _is = require("../../../../utils/is.js"); +var _array = require("../../../../utils/array.js"); +var _string = require("../../../../utils/string.js"); +function createSolveValidation(_ref) { + let { + DenseMatrix + } = _ref; + /** + * Validates matrix and column vector b for backward/forward substitution algorithms. + * + * @param {Matrix} m An N x N matrix + * @param {Array | Matrix} b A column vector + * @param {Boolean} copy Return a copy of vector b + * + * @return {DenseMatrix} Dense column vector b + */ + return function solveValidation(m, b, copy) { + const mSize = m.size(); + if (mSize.length !== 2) { + throw new RangeError('Matrix must be two dimensional (size: ' + (0, _string.format)(mSize) + ')'); + } + const rows = mSize[0]; + const columns = mSize[1]; + if (rows !== columns) { + throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(mSize) + ')'); + } + let data = []; + if ((0, _is.isMatrix)(b)) { + const bSize = b.size(); + const bdata = b._data; + + // 1-dim vector + if (bSize.length === 1) { + if (bSize[0] !== rows) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (let i = 0; i < rows; i++) { + data[i] = [bdata[i]]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + + // 2-dim column + if (bSize.length === 2) { + if (bSize[0] !== rows || bSize[1] !== 1) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + if ((0, _is.isDenseMatrix)(b)) { + if (copy) { + data = []; + for (let i = 0; i < rows; i++) { + data[i] = [bdata[i][0]]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + return b; + } + if ((0, _is.isSparseMatrix)(b)) { + for (let i = 0; i < rows; i++) { + data[i] = [0]; + } + const values = b._values; + const index = b._index; + const ptr = b._ptr; + for (let k1 = ptr[1], k = ptr[0]; k < k1; k++) { + const i = index[k]; + data[i][0] = values[k]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + } + throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.'); + } + if ((0, _is.isArray)(b)) { + const bsize = (0, _array.arraySize)(b); + if (bsize.length === 1) { + if (bsize[0] !== rows) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (let i = 0; i < rows; i++) { + data[i] = [b[i]]; + } + return new DenseMatrix({ + data, + size: [rows, 1] + }); + } + if (bsize.length === 2) { + if (bsize[0] !== rows || bsize[1] !== 1) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (let i = 0; i < rows; i++) { + data[i] = [b[i][0]]; + } + return new DenseMatrix({ + data, + size: [rows, 1] + }); + } + throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.'); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csAmd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csAmd.js new file mode 100644 index 0000000..5569cdd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csAmd.js @@ -0,0 +1,587 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsAmd = void 0; +var _factory = require("../../../utils/factory.js"); +var _csFkeep = require("./csFkeep.js"); +var _csFlip = require("./csFlip.js"); +var _csTdfs = require("./csTdfs.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csAmd'; +const dependencies = ['add', 'multiply', 'transpose']; +const createCsAmd = exports.createCsAmd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + add, + multiply, + transpose + } = _ref; + /** + * Approximate minimum degree ordering. The minimum degree algorithm is a widely used + * heuristic for finding a permutation P so that P*A*P' has fewer nonzeros in its factorization + * than A. It is a gready method that selects the sparsest pivot row and column during the course + * of a right looking sparse Cholesky factorization. + * + * @param {Number} order 0: Natural, 1: Cholesky, 2: LU, 3: QR + * @param {Matrix} m Sparse Matrix + */ + return function csAmd(order, a) { + // check input parameters + if (!a || order <= 0 || order > 3) { + return null; + } + // a matrix arrays + const asize = a._size; + // rows and columns + const m = asize[0]; + const n = asize[1]; + // initialize vars + let lemax = 0; + // dense threshold + let dense = Math.max(16, 10 * Math.sqrt(n)); + dense = Math.min(n - 2, dense); + // create target matrix C + const cm = _createTargetMatrix(order, a, m, n, dense); + // drop diagonal entries + (0, _csFkeep.csFkeep)(cm, _diag, null); + // C matrix arrays + const cindex = cm._index; + const cptr = cm._ptr; + + // number of nonzero elements in C + let cnz = cptr[n]; + + // allocate result (n+1) + const P = []; + + // create workspace (8 * (n + 1)) + const W = []; + const len = 0; // first n + 1 entries + const nv = n + 1; // next n + 1 entries + const next = 2 * (n + 1); // next n + 1 entries + const head = 3 * (n + 1); // next n + 1 entries + const elen = 4 * (n + 1); // next n + 1 entries + const degree = 5 * (n + 1); // next n + 1 entries + const w = 6 * (n + 1); // next n + 1 entries + const hhead = 7 * (n + 1); // last n + 1 entries + + // use P as workspace for last + const last = P; + + // initialize quotient graph + let mark = _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree); + + // initialize degree lists + let nel = _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next); + + // minimum degree node + let mindeg = 0; + + // vars + let i, j, k, k1, k2, e, pj, ln, nvi, pk, eln, p1, p2, pn, h, d; + + // while (selecting pivots) do + while (nel < n) { + // select node of minimum approximate degree. amd() is now ready to start eliminating the graph. It first + // finds a node k of minimum degree and removes it from its degree list. The variable nel keeps track of thow + // many nodes have been eliminated. + for (k = -1; mindeg < n && (k = W[head + mindeg]) === -1; mindeg++); + if (W[next + k] !== -1) { + last[W[next + k]] = -1; + } + // remove k from degree list + W[head + mindeg] = W[next + k]; + // elenk = |Ek| + const elenk = W[elen + k]; + // # of nodes k represents + let nvk = W[nv + k]; + // W[nv + k] nodes of A eliminated + nel += nvk; + + // Construct a new element. The new element Lk is constructed in place if |Ek| = 0. nv[i] is + // negated for all nodes i in Lk to flag them as members of this set. Each node i is removed from the + // degree lists. All elements e in Ek are absorved into element k. + let dk = 0; + // flag k as in Lk + W[nv + k] = -nvk; + let p = cptr[k]; + // do in place if W[elen + k] === 0 + const pk1 = elenk === 0 ? p : cnz; + let pk2 = pk1; + for (k1 = 1; k1 <= elenk + 1; k1++) { + if (k1 > elenk) { + // search the nodes in k + e = k; + // list of nodes starts at cindex[pj] + pj = p; + // length of list of nodes in k + ln = W[len + k] - elenk; + } else { + // search the nodes in e + e = cindex[p++]; + pj = cptr[e]; + // length of list of nodes in e + ln = W[len + e]; + } + for (k2 = 1; k2 <= ln; k2++) { + i = cindex[pj++]; + // check node i dead, or seen + if ((nvi = W[nv + i]) <= 0) { + continue; + } + // W[degree + Lk] += size of node i + dk += nvi; + // negate W[nv + i] to denote i in Lk + W[nv + i] = -nvi; + // place i in Lk + cindex[pk2++] = i; + if (W[next + i] !== -1) { + last[W[next + i]] = last[i]; + } + // check we need to remove i from degree list + if (last[i] !== -1) { + W[next + last[i]] = W[next + i]; + } else { + W[head + W[degree + i]] = W[next + i]; + } + } + if (e !== k) { + // absorb e into k + cptr[e] = (0, _csFlip.csFlip)(k); + // e is now a dead element + W[w + e] = 0; + } + } + // cindex[cnz...nzmax] is free + if (elenk !== 0) { + cnz = pk2; + } + // external degree of k - |Lk\i| + W[degree + k] = dk; + // element k is in cindex[pk1..pk2-1] + cptr[k] = pk1; + W[len + k] = pk2 - pk1; + // k is now an element + W[elen + k] = -2; + + // Find set differences. The scan1 function now computes the set differences |Le \ Lk| for all elements e. At the start of the + // scan, no entry in the w array is greater than or equal to mark. + + // clear w if necessary + mark = _wclear(mark, lemax, W, w, n); + // scan 1: find |Le\Lk| + for (pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check if W[elen + i] empty, skip it + if ((eln = W[elen + i]) <= 0) { + continue; + } + // W[nv + i] was negated + nvi = -W[nv + i]; + const wnvi = mark - nvi; + // scan Ei + for (p = cptr[i], p1 = cptr[i] + eln - 1; p <= p1; p++) { + e = cindex[p]; + if (W[w + e] >= mark) { + // decrement |Le\Lk| + W[w + e] -= nvi; + } else if (W[w + e] !== 0) { + // ensure e is a live element, 1st time e seen in scan 1 + W[w + e] = W[degree + e] + wnvi; + } + } + } + + // degree update + // The second pass computes the approximate degree di, prunes the sets Ei and Ai, and computes a hash + // function h(i) for all nodes in Lk. + + // scan2: degree update + for (pk = pk1; pk < pk2; pk++) { + // consider node i in Lk + i = cindex[pk]; + p1 = cptr[i]; + p2 = p1 + W[elen + i] - 1; + pn = p1; + // scan Ei + for (h = 0, d = 0, p = p1; p <= p2; p++) { + e = cindex[p]; + // check e is an unabsorbed element + if (W[w + e] !== 0) { + // dext = |Le\Lk| + const dext = W[w + e] - mark; + if (dext > 0) { + // sum up the set differences + d += dext; + // keep e in Ei + cindex[pn++] = e; + // compute the hash of node i + h += e; + } else { + // aggressive absorb. e->k + cptr[e] = (0, _csFlip.csFlip)(k); + // e is a dead element + W[w + e] = 0; + } + } + } + // W[elen + i] = |Ei| + W[elen + i] = pn - p1 + 1; + const p3 = pn; + const p4 = p1 + W[len + i]; + // prune edges in Ai + for (p = p2 + 1; p < p4; p++) { + j = cindex[p]; + // check node j dead or in Lk + const nvj = W[nv + j]; + if (nvj <= 0) { + continue; + } + // degree(i) += |j| + d += nvj; + // place j in node list of i + cindex[pn++] = j; + // compute hash for node i + h += j; + } + // check for mass elimination + if (d === 0) { + // absorb i into k + cptr[i] = (0, _csFlip.csFlip)(k); + nvi = -W[nv + i]; + // |Lk| -= |i| + dk -= nvi; + // |k| += W[nv + i] + nvk += nvi; + nel += nvi; + W[nv + i] = 0; + // node i is dead + W[elen + i] = -1; + } else { + // update degree(i) + W[degree + i] = Math.min(W[degree + i], d); + // move first node to end + cindex[pn] = cindex[p3]; + // move 1st el. to end of Ei + cindex[p3] = cindex[p1]; + // add k as 1st element in of Ei + cindex[p1] = k; + // new len of adj. list of node i + W[len + i] = pn - p1 + 1; + // finalize hash of i + h = (h < 0 ? -h : h) % n; + // place i in hash bucket + W[next + i] = W[hhead + h]; + W[hhead + h] = i; + // save hash of i in last[i] + last[i] = h; + } + } + // finalize |Lk| + W[degree + k] = dk; + lemax = Math.max(lemax, dk); + // clear w + mark = _wclear(mark + lemax, lemax, W, w, n); + + // Supernode detection. Supernode detection relies on the hash function h(i) computed for each node i. + // If two nodes have identical adjacency lists, their hash functions wil be identical. + for (pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check i is dead, skip it + if (W[nv + i] >= 0) { + continue; + } + // scan hash bucket of node i + h = last[i]; + i = W[hhead + h]; + // hash bucket will be empty + W[hhead + h] = -1; + for (; i !== -1 && W[next + i] !== -1; i = W[next + i], mark++) { + ln = W[len + i]; + eln = W[elen + i]; + for (p = cptr[i] + 1; p <= cptr[i] + ln - 1; p++) { + W[w + cindex[p]] = mark; + } + let jlast = i; + // compare i with all j + for (j = W[next + i]; j !== -1;) { + let ok = W[len + j] === ln && W[elen + j] === eln; + for (p = cptr[j] + 1; ok && p <= cptr[j] + ln - 1; p++) { + // compare i and j + if (W[w + cindex[p]] !== mark) { + ok = 0; + } + } + // check i and j are identical + if (ok) { + // absorb j into i + cptr[j] = (0, _csFlip.csFlip)(i); + W[nv + i] += W[nv + j]; + W[nv + j] = 0; + // node j is dead + W[elen + j] = -1; + // delete j from hash bucket + j = W[next + j]; + W[next + jlast] = j; + } else { + // j and i are different + jlast = j; + j = W[next + j]; + } + } + } + } + + // Finalize new element. The elimination of node k is nearly complete. All nodes i in Lk are scanned one last time. + // Node i is removed from Lk if it is dead. The flagged status of nv[i] is cleared. + for (p = pk1, pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check i is dead, skip it + if ((nvi = -W[nv + i]) <= 0) { + continue; + } + // restore W[nv + i] + W[nv + i] = nvi; + // compute external degree(i) + d = W[degree + i] + dk - nvi; + d = Math.min(d, n - nel - nvi); + if (W[head + d] !== -1) { + last[W[head + d]] = i; + } + // put i back in degree list + W[next + i] = W[head + d]; + last[i] = -1; + W[head + d] = i; + // find new minimum degree + mindeg = Math.min(mindeg, d); + W[degree + i] = d; + // place i in Lk + cindex[p++] = i; + } + // # nodes absorbed into k + W[nv + k] = nvk; + // length of adj list of element k + if ((W[len + k] = p - pk1) === 0) { + // k is a root of the tree + cptr[k] = -1; + // k is now a dead element + W[w + k] = 0; + } + if (elenk !== 0) { + // free unused space in Lk + cnz = p; + } + } + + // Postordering. The elimination is complete, but no permutation has been computed. All that is left + // of the graph is the assembly tree (ptr) and a set of dead nodes and elements (i is a dead node if + // nv[i] is zero and a dead element if nv[i] > 0). It is from this information only that the final permutation + // is computed. The tree is restored by unflipping all of ptr. + + // fix assembly tree + for (i = 0; i < n; i++) { + cptr[i] = (0, _csFlip.csFlip)(cptr[i]); + } + for (j = 0; j <= n; j++) { + W[head + j] = -1; + } + // place unordered nodes in lists + for (j = n; j >= 0; j--) { + // skip if j is an element + if (W[nv + j] > 0) { + continue; + } + // place j in list of its parent + W[next + j] = W[head + cptr[j]]; + W[head + cptr[j]] = j; + } + // place elements in lists + for (e = n; e >= 0; e--) { + // skip unless e is an element + if (W[nv + e] <= 0) { + continue; + } + if (cptr[e] !== -1) { + // place e in list of its parent + W[next + e] = W[head + cptr[e]]; + W[head + cptr[e]] = e; + } + } + // postorder the assembly tree + for (k = 0, i = 0; i <= n; i++) { + if (cptr[i] === -1) { + k = (0, _csTdfs.csTdfs)(i, k, W, head, next, P, w); + } + } + // remove last item in array + P.splice(P.length - 1, 1); + // return P + return P; + }; + + /** + * Creates the matrix that will be used by the approximate minimum degree ordering algorithm. The function accepts the matrix M as input and returns a permutation + * vector P. The amd algorithm operates on a symmetrix matrix, so one of three symmetric matrices is formed. + * + * Order: 0 + * A natural ordering P=null matrix is returned. + * + * Order: 1 + * Matrix must be square. This is appropriate for a Cholesky or LU factorization. + * P = M + M' + * + * Order: 2 + * Dense columns from M' are dropped, M recreated from M'. This is appropriatefor LU factorization of unsymmetric matrices. + * P = M' * M + * + * Order: 3 + * This is best used for QR factorization or LU factorization is matrix M has no dense rows. A dense row is a row with more than 10*sqr(columns) entries. + * P = M' * M + */ + function _createTargetMatrix(order, a, m, n, dense) { + // compute A' + const at = transpose(a); + + // check order = 1, matrix must be square + if (order === 1 && n === m) { + // C = A + A' + return add(a, at); + } + + // check order = 2, drop dense columns from M' + if (order === 2) { + // transpose arrays + const tindex = at._index; + const tptr = at._ptr; + // new column index + let p2 = 0; + // loop A' columns (rows) + for (let j = 0; j < m; j++) { + // column j of AT starts here + let p = tptr[j]; + // new column j starts here + tptr[j] = p2; + // skip dense col j + if (tptr[j + 1] - p > dense) { + continue; + } + // map rows in column j of A + for (const p1 = tptr[j + 1]; p < p1; p++) { + tindex[p2++] = tindex[p]; + } + } + // finalize AT + tptr[m] = p2; + // recreate A from new transpose matrix + a = transpose(at); + // use A' * A + return multiply(at, a); + } + + // use A' * A, square or rectangular matrix + return multiply(at, a); + } + + /** + * Initialize quotient graph. There are four kind of nodes and elements that must be represented: + * + * - A live node is a node i (or a supernode) that has not been selected as a pivot nad has not been merged into another supernode. + * - A dead node i is one that has been removed from the graph, having been absorved into r = flip(ptr[i]). + * - A live element e is one that is in the graph, having been formed when node e was selected as the pivot. + * - A dead element e is one that has benn absorved into a subsequent element s = flip(ptr[e]). + */ + function _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree) { + // Initialize quotient graph + for (let k = 0; k < n; k++) { + W[len + k] = cptr[k + 1] - cptr[k]; + } + W[len + n] = 0; + // initialize workspace + for (let i = 0; i <= n; i++) { + // degree list i is empty + W[head + i] = -1; + last[i] = -1; + W[next + i] = -1; + // hash list i is empty + W[hhead + i] = -1; + // node i is just one node + W[nv + i] = 1; + // node i is alive + W[w + i] = 1; + // Ek of node i is empty + W[elen + i] = 0; + // degree of node i + W[degree + i] = W[len + i]; + } + // clear w + const mark = _wclear(0, 0, W, w, n); + // n is a dead element + W[elen + n] = -2; + // n is a root of assembly tree + cptr[n] = -1; + // n is a dead element + W[w + n] = 0; + // return mark + return mark; + } + + /** + * Initialize degree lists. Each node is placed in its degree lists. Nodes of zero degree are eliminated immediately. Nodes with + * degree >= dense are alsol eliminated and merged into a placeholder node n, a dead element. Thes nodes will appera last in the + * output permutation p. + */ + function _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next) { + // result + let nel = 0; + // loop columns + for (let i = 0; i < n; i++) { + // degree @ i + const d = W[degree + i]; + // check node i is empty + if (d === 0) { + // element i is dead + W[elen + i] = -2; + nel++; + // i is a root of assembly tree + cptr[i] = -1; + W[w + i] = 0; + } else if (d > dense) { + // absorb i into element n + W[nv + i] = 0; + // node i is dead + W[elen + i] = -1; + nel++; + cptr[i] = (0, _csFlip.csFlip)(n); + W[nv + n]++; + } else { + const h = W[head + d]; + if (h !== -1) { + last[h] = i; + } + // put node i in degree list d + W[next + i] = W[head + d]; + W[head + d] = i; + } + } + return nel; + } + function _wclear(mark, lemax, W, w, n) { + if (mark < 2 || mark + lemax < 0) { + for (let k = 0; k < n; k++) { + if (W[w + k] !== 0) { + W[w + k] = 1; + } + } + mark = 2; + } + // at this point, W [0..n-1] < mark holds + return mark; + } + function _diag(i, j) { + return i !== j; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csChol.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csChol.js new file mode 100644 index 0000000..a9c7e1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csChol.js @@ -0,0 +1,164 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsChol = void 0; +var _factory = require("../../../utils/factory.js"); +var _csEreach = require("./csEreach.js"); +var _csSymperm = require("./csSymperm.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csChol'; +const dependencies = ['divideScalar', 'sqrt', 'subtract', 'multiply', 'im', 're', 'conj', 'equal', 'smallerEq', 'SparseMatrix']; +const createCsChol = exports.createCsChol = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + divideScalar, + sqrt, + subtract, + multiply, + im, + re, + conj, + equal, + smallerEq, + SparseMatrix + } = _ref; + const csSymperm = (0, _csSymperm.createCsSymperm)({ + conj, + SparseMatrix + }); + + /** + * Computes the Cholesky factorization of matrix A. It computes L and P so + * L * L' = P * A * P' + * + * @param {Matrix} m The A Matrix to factorize, only upper triangular part used + * @param {Object} s The symbolic analysis from cs_schol() + * + * @return {Number} The numeric Cholesky factorization of A or null + */ + return function csChol(m, s) { + // validate input + if (!m) { + return null; + } + // m arrays + const size = m._size; + // columns + const n = size[1]; + // symbolic analysis result + const parent = s.parent; + const cp = s.cp; + const pinv = s.pinv; + // L arrays + const lvalues = []; + const lindex = []; + const lptr = []; + // L + const L = new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: [n, n] + }); + // vars + const c = []; // (2 * n) + const x = []; // (n) + // compute C = P * A * P' + const cm = pinv ? csSymperm(m, pinv, 1) : m; + // C matrix arrays + const cvalues = cm._values; + const cindex = cm._index; + const cptr = cm._ptr; + // vars + let k, p; + // initialize variables + for (k = 0; k < n; k++) { + lptr[k] = c[k] = cp[k]; + } + // compute L(k,:) for L*L' = C + for (k = 0; k < n; k++) { + // nonzero pattern of L(k,:) + let top = (0, _csEreach.csEreach)(cm, k, parent, c); + // x (0:k) is now zero + x[k] = 0; + // x = full(triu(C(:,k))) + for (p = cptr[k]; p < cptr[k + 1]; p++) { + if (cindex[p] <= k) { + x[cindex[p]] = cvalues[p]; + } + } + // d = C(k,k) + let d = x[k]; + // clear x for k+1st iteration + x[k] = 0; + // solve L(0:k-1,0:k-1) * x = C(:,k) + for (; top < n; top++) { + // s[top..n-1] is pattern of L(k,:) + const i = s[top]; + // L(k,i) = x (i) / L(i,i) + const lki = divideScalar(x[i], lvalues[lptr[i]]); + // clear x for k+1st iteration + x[i] = 0; + for (p = lptr[i] + 1; p < c[i]; p++) { + // row + const r = lindex[p]; + // update x[r] + x[r] = subtract(x[r], multiply(lvalues[p], lki)); + } + // d = d - L(k,i)*L(k,i) + d = subtract(d, multiply(lki, conj(lki))); + p = c[i]++; + // store L(k,i) in column i + lindex[p] = k; + lvalues[p] = conj(lki); + } + // compute L(k,k) + if (smallerEq(re(d), 0) || !equal(im(d), 0)) { + // not pos def + return null; + } + p = c[k]++; + // store L(k,k) = sqrt(d) in column k + lindex[p] = k; + lvalues[p] = sqrt(d); + } + // finalize L + lptr[n] = cp[n]; + // P matrix + let P; + // check we need to calculate P + if (pinv) { + // P arrays + const pvalues = []; + const pindex = []; + const pptr = []; + // create P matrix + for (p = 0; p < n; p++) { + // initialize ptr (one value per column) + pptr[p] = p; + // index (apply permutation vector) + pindex.push(pinv[p]); + // value 1 + pvalues.push(1); + } + // update ptr + pptr[n] = n; + // P + P = new SparseMatrix({ + values: pvalues, + index: pindex, + ptr: pptr, + size: [n, n] + }); + } + // return L & P + return { + L, + P + }; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCounts.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCounts.js new file mode 100644 index 0000000..c131993 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCounts.js @@ -0,0 +1,133 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsCounts = void 0; +var _factory = require("../../../utils/factory.js"); +var _csLeaf = require("./csLeaf.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csCounts'; +const dependencies = ['transpose']; +const createCsCounts = exports.createCsCounts = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + transpose + } = _ref; + /** + * Computes the column counts using the upper triangular part of A. + * It transposes A internally, none of the input parameters are modified. + * + * @param {Matrix} a The sparse matrix A + * + * @param {Matrix} ata Count the columns of A'A instead + * + * @return An array of size n of the column counts or null on error + */ + return function (a, parent, post, ata) { + // check inputs + if (!a || !parent || !post) { + return null; + } + // a matrix arrays + const asize = a._size; + // rows and columns + const m = asize[0]; + const n = asize[1]; + // variables + let i, j, k, J, p, p0, p1; + + // workspace size + const s = 4 * n + (ata ? n + m + 1 : 0); + // allocate workspace + const w = []; // (s) + const ancestor = 0; // first n entries + const maxfirst = n; // next n entries + const prevleaf = 2 * n; // next n entries + const first = 3 * n; // next n entries + const head = 4 * n; // next n + 1 entries (used when ata is true) + const next = 5 * n + 1; // last entries in workspace + // clear workspace w[0..s-1] + for (k = 0; k < s; k++) { + w[k] = -1; + } + + // allocate result + const colcount = []; // (n) + + // AT = A' + const at = transpose(a); + // at arrays + const tindex = at._index; + const tptr = at._ptr; + + // find w[first + j] + for (k = 0; k < n; k++) { + j = post[k]; + // colcount[j]=1 if j is a leaf + colcount[j] = w[first + j] === -1 ? 1 : 0; + for (; j !== -1 && w[first + j] === -1; j = parent[j]) { + w[first + j] = k; + } + } + + // initialize ata if needed + if (ata) { + // invert post + for (k = 0; k < n; k++) { + w[post[k]] = k; + } + // loop rows (columns in AT) + for (i = 0; i < m; i++) { + // values in column i of AT + for (k = n, p0 = tptr[i], p1 = tptr[i + 1], p = p0; p < p1; p++) { + k = Math.min(k, w[tindex[p]]); + } + // place row i in linked list k + w[next + i] = w[head + k]; + w[head + k] = i; + } + } + + // each node in its own set + for (i = 0; i < n; i++) { + w[ancestor + i] = i; + } + for (k = 0; k < n; k++) { + // j is the kth node in postordered etree + j = post[k]; + // check j is not a root + if (parent[j] !== -1) { + colcount[parent[j]]--; + } + + // J=j for LL'=A case + for (J = ata ? w[head + k] : j; J !== -1; J = ata ? w[next + J] : -1) { + for (p = tptr[J]; p < tptr[J + 1]; p++) { + i = tindex[p]; + const r = (0, _csLeaf.csLeaf)(i, j, w, first, maxfirst, prevleaf, ancestor); + // check A(i,j) is in skeleton + if (r.jleaf >= 1) { + colcount[j]++; + } + // check account for overlap in q + if (r.jleaf === 2) { + colcount[r.q]--; + } + } + } + if (parent[j] !== -1) { + w[ancestor + j] = parent[j]; + } + } + // sum up colcount's of each child + for (j = 0; j < n; j++) { + if (parent[j] !== -1) { + colcount[parent[j]] += colcount[j]; + } + } + return colcount; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCumsum.js new file mode 100644 index 0000000..2035a26 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csCumsum.js @@ -0,0 +1,34 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csCumsum = csCumsum; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * It sets the p[i] equal to the sum of c[0] through c[i-1]. + * + * @param {Array} ptr The Sparse Matrix ptr array + * @param {Array} c The Sparse Matrix ptr array + * @param {Number} n The number of columns + */ +function csCumsum(ptr, c, n) { + // variables + let i; + let nz = 0; + for (i = 0; i < n; i++) { + // initialize ptr @ i + ptr[i] = nz; + // increment number of nonzeros + nz += c[i]; + // also copy p[0..n-1] back into c[0..n-1] + c[i] = ptr[i]; + } + // finalize ptr + ptr[n] = nz; + // return sum (c [0..n-1]) + return nz; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csDfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csDfs.js new file mode 100644 index 0000000..437e115 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csDfs.js @@ -0,0 +1,82 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csDfs = csDfs; +var _csMarked = require("./csMarked.js"); +var _csMark = require("./csMark.js"); +var _csUnflip = require("./csUnflip.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Depth-first search computes the nonzero pattern xi of the directed graph G (Matrix) starting + * at nodes in B (see csReach()). + * + * @param {Number} j The starting node for the DFS algorithm + * @param {Matrix} g The G matrix to search, ptr array modified, then restored + * @param {Number} top Start index in stack xi[top..n-1] + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b + * + * @return {Number} New value of top + */ +function csDfs(j, g, top, xi, pinv) { + // g arrays + const index = g._index; + const ptr = g._ptr; + const size = g._size; + // columns + const n = size[1]; + // vars + let i, p, p2; + // initialize head + let head = 0; + // initialize the recursion stack + xi[0] = j; + // loop + while (head >= 0) { + // get j from the top of the recursion stack + j = xi[head]; + // apply permutation vector + const jnew = pinv ? pinv[j] : j; + // check node j is marked + if (!(0, _csMarked.csMarked)(ptr, j)) { + // mark node j as visited + (0, _csMark.csMark)(ptr, j); + // update stack (last n entries in xi) + xi[n + head] = jnew < 0 ? 0 : (0, _csUnflip.csUnflip)(ptr[jnew]); + } + // node j done if no unvisited neighbors + let done = 1; + // examine all neighbors of j, stack (last n entries in xi) + for (p = xi[n + head], p2 = jnew < 0 ? 0 : (0, _csUnflip.csUnflip)(ptr[jnew + 1]); p < p2; p++) { + // consider neighbor node i + i = index[p]; + // check we have visited node i, skip it + if ((0, _csMarked.csMarked)(ptr, i)) { + continue; + } + // pause depth-first search of node j, update stack (last n entries in xi) + xi[n + head] = p; + // start dfs at node i + xi[++head] = i; + // node j is not done + done = 0; + // break, to start dfs(i) + break; + } + // check depth-first search at node j is done + if (done) { + // remove j from the recursion stack + head--; + // and place in the output stack + xi[--top] = j; + } + } + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEreach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEreach.js new file mode 100644 index 0000000..022fcf5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEreach.js @@ -0,0 +1,69 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csEreach = csEreach; +var _csMark = require("./csMark.js"); +var _csMarked = require("./csMarked.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Find nonzero pattern of Cholesky L(k,1:k-1) using etree and triu(A(:,k)) + * + * @param {Matrix} a The A matrix + * @param {Number} k The kth column in A + * @param {Array} parent The parent vector from the symbolic analysis result + * @param {Array} w The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * + * @return {Number} The index for the nonzero pattern + */ +function csEreach(a, k, parent, w) { + // a arrays + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + // columns + const n = asize[1]; + // initialize top + let top = n; + // vars + let p, p0, p1, len; + // mark node k as visited + (0, _csMark.csMark)(w, k); + // loop values & index for column k + for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // A(i,k) is nonzero + let i = aindex[p]; + // only use upper triangular part of A + if (i > k) { + continue; + } + // traverse up etree + for (len = 0; !(0, _csMarked.csMarked)(w, i); i = parent[i]) { + // L(k,i) is nonzero, last n entries in w + w[n + len++] = i; + // mark i as visited + (0, _csMark.csMark)(w, i); + } + while (len > 0) { + // decrement top & len + --top; + --len; + // push path onto stack, last n entries in w + w[n + top] = w[n + len]; + } + } + // unmark all nodes + for (p = top; p < n; p++) { + // use stack value, last n entries in w + (0, _csMark.csMark)(w, w[n + p]); + } + // unmark node k + (0, _csMark.csMark)(w, k); + // s[top..n-1] contains pattern of L(k,:) + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEtree.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEtree.js new file mode 100644 index 0000000..d2b7bda --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csEtree.js @@ -0,0 +1,77 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csEtree = csEtree; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Computes the elimination tree of Matrix A (using triu(A)) or the + * elimination tree of A'A without forming A'A. + * + * @param {Matrix} a The A Matrix + * @param {boolean} ata A value of true the function computes the etree of A'A + */ +function csEtree(a, ata) { + // check inputs + if (!a) { + return null; + } + // a arrays + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + // rows & columns + const m = asize[0]; + const n = asize[1]; + + // allocate result + const parent = []; // (n) + + // allocate workspace + const w = []; // (n + (ata ? m : 0)) + const ancestor = 0; // first n entries in w + const prev = n; // last m entries (ata = true) + + let i, inext; + + // check we are calculating A'A + if (ata) { + // initialize workspace + for (i = 0; i < m; i++) { + w[prev + i] = -1; + } + } + // loop columns + for (let k = 0; k < n; k++) { + // node k has no parent yet + parent[k] = -1; + // nor does k have an ancestor + w[ancestor + k] = -1; + // values in column k + for (let p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // row + const r = aindex[p]; + // node + i = ata ? w[prev + r] : r; + // traverse from i to k + for (; i !== -1 && i < k; i = inext) { + // inext = ancestor of i + inext = w[ancestor + i]; + // path compression + w[ancestor + i] = k; + // check no anc., parent is k + if (inext === -1) { + parent[i] = k; + } + } + if (ata) { + w[prev + r] = k; + } + } + } + return parent; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFkeep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFkeep.js new file mode 100644 index 0000000..6d916d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFkeep.js @@ -0,0 +1,64 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csFkeep = csFkeep; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Keeps entries in the matrix when the callback function returns true, removes the entry otherwise + * + * @param {Matrix} a The sparse matrix + * @param {function} callback The callback function, function will be invoked with the following args: + * - The entry row + * - The entry column + * - The entry value + * - The state parameter + * @param {any} other The state + * + * @return The number of nonzero elements in the matrix + */ +function csFkeep(a, callback, other) { + // a arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + // columns + const n = asize[1]; + // nonzero items + let nz = 0; + // loop columns + for (let j = 0; j < n; j++) { + // get current location of col j + let p = aptr[j]; + // record new location of col j + aptr[j] = nz; + for (; p < aptr[j + 1]; p++) { + // check we need to keep this item + if (callback(aindex[p], j, avalues ? avalues[p] : 1, other)) { + // keep A(i,j) + aindex[nz] = aindex[p]; + // check we need to process values (pattern only) + if (avalues) { + avalues[nz] = avalues[p]; + } + // increment nonzero items + nz++; + } + } + } + // finalize A + aptr[n] = nz; + // trim arrays + aindex.splice(nz, aindex.length - nz); + // check we need to process values (pattern only) + if (avalues) { + avalues.splice(nz, avalues.length - nz); + } + // return number of nonzero items + return nz; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFlip.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFlip.js new file mode 100644 index 0000000..bcc13a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csFlip.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csFlip = csFlip; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * This function "flips" its input about the integer -1. + * + * @param {Number} i The value to flip + */ +function csFlip(i) { + // flip the value + return -i - 2; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csIpvec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csIpvec.js new file mode 100644 index 0000000..0d63ef9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csIpvec.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csIpvec = csIpvec; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Permutes a vector; x = P'b. In MATLAB notation, x(p)=b. + * + * @param {Array} p The permutation vector of length n. null value denotes identity + * @param {Array} b The input vector + * + * @return {Array} The output vector x = P'b + */ +function csIpvec(p, b) { + // vars + let k; + const n = b.length; + const x = []; + // check permutation vector was provided, p = null denotes identity + if (p) { + // loop vector + for (k = 0; k < n; k++) { + // apply permutation + x[p[k]] = b[k]; + } + } else { + // loop vector + for (k = 0; k < n; k++) { + // x[i] = b[i] + x[k] = b[k]; + } + } + return x; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLeaf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLeaf.js new file mode 100644 index 0000000..4e4d93b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLeaf.js @@ -0,0 +1,62 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csLeaf = csLeaf; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * This function determines if j is a leaf of the ith row subtree. + * Consider A(i,j), node j in ith row subtree and return lca(jprev,j) + * + * @param {Number} i The ith row subtree + * @param {Number} j The node to test + * @param {Array} w The workspace array + * @param {Number} first The index offset within the workspace for the first array + * @param {Number} maxfirst The index offset within the workspace for the maxfirst array + * @param {Number} prevleaf The index offset within the workspace for the prevleaf array + * @param {Number} ancestor The index offset within the workspace for the ancestor array + * + * @return {Object} + */ +function csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor) { + let s, sparent; + + // our result + let jleaf = 0; + let q; + + // check j is a leaf + if (i <= j || w[first + j] <= w[maxfirst + i]) { + return -1; + } + // update max first[j] seen so far + w[maxfirst + i] = w[first + j]; + // jprev = previous leaf of ith subtree + const jprev = w[prevleaf + i]; + w[prevleaf + i] = j; + + // check j is first or subsequent leaf + if (jprev === -1) { + // 1st leaf, q = root of ith subtree + jleaf = 1; + q = i; + } else { + // update jleaf + jleaf = 2; + // q = least common ancester (jprev,j) + for (q = jprev; q !== w[ancestor + q]; q = w[ancestor + q]); + for (s = jprev; s !== q; s = sparent) { + // path compression + sparent = w[ancestor + s]; + w[ancestor + s] = q; + } + } + return { + jleaf, + q + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLu.js new file mode 100644 index 0000000..e74ca25 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csLu.js @@ -0,0 +1,188 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsLu = void 0; +var _factory = require("../../../utils/factory.js"); +var _csSpsolve = require("./csSpsolve.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csLu'; +const dependencies = ['abs', 'divideScalar', 'multiply', 'subtract', 'larger', 'largerEq', 'SparseMatrix']; +const createCsLu = exports.createCsLu = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + abs, + divideScalar, + multiply, + subtract, + larger, + largerEq, + SparseMatrix + } = _ref; + const csSpsolve = (0, _csSpsolve.createCsSpsolve)({ + divideScalar, + multiply, + subtract + }); + + /** + * Computes the numeric LU factorization of the sparse matrix A. Implements a Left-looking LU factorization + * algorithm that computes L and U one column at a tume. At the kth step, it access columns 1 to k-1 of L + * and column k of A. Given the fill-reducing column ordering q (see parameter s) computes L, U and pinv so + * L * U = A(p, q), where p is the inverse of pinv. + * + * @param {Matrix} m The A Matrix to factorize + * @param {Object} s The symbolic analysis from csSqr(). Provides the fill-reducing + * column ordering q + * @param {Number} tol Partial pivoting threshold (1 for partial pivoting) + * + * @return {Number} The numeric LU factorization of A or null + */ + return function csLu(m, s, tol) { + // validate input + if (!m) { + return null; + } + // m arrays + const size = m._size; + // columns + const n = size[1]; + // symbolic analysis result + let q; + let lnz = 100; + let unz = 100; + // update symbolic analysis parameters + if (s) { + q = s.q; + lnz = s.lnz || lnz; + unz = s.unz || unz; + } + // L arrays + const lvalues = []; // (lnz) + const lindex = []; // (lnz) + const lptr = []; // (n + 1) + // L + const L = new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: [n, n] + }); + // U arrays + const uvalues = []; // (unz) + const uindex = []; // (unz) + const uptr = []; // (n + 1) + // U + const U = new SparseMatrix({ + values: uvalues, + index: uindex, + ptr: uptr, + size: [n, n] + }); + // inverse of permutation vector + const pinv = []; // (n) + // vars + let i, p; + // allocate arrays + const x = []; // (n) + const xi = []; // (2 * n) + // initialize variables + for (i = 0; i < n; i++) { + // clear workspace + x[i] = 0; + // no rows pivotal yet + pinv[i] = -1; + // no cols of L yet + lptr[i + 1] = 0; + } + // reset number of nonzero elements in L and U + lnz = 0; + unz = 0; + // compute L(:,k) and U(:,k) + for (let k = 0; k < n; k++) { + // update ptr + lptr[k] = lnz; + uptr[k] = unz; + // apply column permutations if needed + const col = q ? q[k] : k; + // solve triangular system, x = L\A(:,col) + const top = csSpsolve(L, m, col, xi, x, pinv, 1); + // find pivot + let ipiv = -1; + let a = -1; + // loop xi[] from top -> n + for (p = top; p < n; p++) { + // x[i] is nonzero + i = xi[p]; + // check row i is not yet pivotal + if (pinv[i] < 0) { + // absolute value of x[i] + const xabs = abs(x[i]); + // check absoulte value is greater than pivot value + if (larger(xabs, a)) { + // largest pivot candidate so far + a = xabs; + ipiv = i; + } + } else { + // x(i) is the entry U(pinv[i],k) + uindex[unz] = pinv[i]; + uvalues[unz++] = x[i]; + } + } + // validate we found a valid pivot + if (ipiv === -1 || a <= 0) { + return null; + } + // update actual pivot column, give preference to diagonal value + if (pinv[col] < 0 && largerEq(abs(x[col]), multiply(a, tol))) { + ipiv = col; + } + // the chosen pivot + const pivot = x[ipiv]; + // last entry in U(:,k) is U(k,k) + uindex[unz] = k; + uvalues[unz++] = pivot; + // ipiv is the kth pivot row + pinv[ipiv] = k; + // first entry in L(:,k) is L(k,k) = 1 + lindex[lnz] = ipiv; + lvalues[lnz++] = 1; + // L(k+1:n,k) = x / pivot + for (p = top; p < n; p++) { + // row + i = xi[p]; + // check x(i) is an entry in L(:,k) + if (pinv[i] < 0) { + // save unpermuted row in L + lindex[lnz] = i; + // scale pivot column + lvalues[lnz++] = divideScalar(x[i], pivot); + } + // x[0..n-1] = 0 for next k + x[i] = 0; + } + } + // update ptr + lptr[n] = lnz; + uptr[n] = unz; + // fix row indices of L for final pinv + for (p = 0; p < lnz; p++) { + lindex[p] = pinv[lindex[p]]; + } + // trim arrays + lvalues.splice(lnz, lvalues.length - lnz); + lindex.splice(lnz, lindex.length - lnz); + uvalues.splice(unz, uvalues.length - unz); + uindex.splice(unz, uindex.length - unz); + // return LU factor + return { + L, + U, + pinv + }; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMark.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMark.js new file mode 100644 index 0000000..7845048 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMark.js @@ -0,0 +1,21 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csMark = csMark; +var _csFlip = require("./csFlip.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Marks the node at w[j] + * + * @param {Array} w The array + * @param {Number} j The array index + */ +function csMark(w, j) { + // mark w[j] + w[j] = (0, _csFlip.csFlip)(w[j]); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMarked.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMarked.js new file mode 100644 index 0000000..0c61e7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csMarked.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csMarked = csMarked; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Checks if the node at w[j] is marked + * + * @param {Array} w The array + * @param {Number} j The array index + */ +function csMarked(w, j) { + // check node is marked + return w[j] < 0; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPermute.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPermute.js new file mode 100644 index 0000000..abd5e7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPermute.js @@ -0,0 +1,67 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csPermute = csPermute; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Permutes a sparse matrix C = P * A * Q + * + * @param {SparseMatrix} a The Matrix A + * @param {Array} pinv The row permutation vector + * @param {Array} q The column permutation vector + * @param {boolean} values Create a pattern matrix (false), values and pattern otherwise + * + * @return {Matrix} C = P * A * Q, null on error + */ +function csPermute(a, pinv, q, values) { + // a arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + const adt = a._datatype; + // rows & columns + const m = asize[0]; + const n = asize[1]; + // c arrays + const cvalues = values && a._values ? [] : null; + const cindex = []; // (aptr[n]) + const cptr = []; // (n + 1) + // initialize vars + let nz = 0; + // loop columns + for (let k = 0; k < n; k++) { + // column k of C is column q[k] of A + cptr[k] = nz; + // apply column permutation + const j = q ? q[k] : k; + // loop values in column j of A + for (let t0 = aptr[j], t1 = aptr[j + 1], t = t0; t < t1; t++) { + // row i of A is row pinv[i] of C + const r = pinv ? pinv[aindex[t]] : aindex[t]; + // index + cindex[nz] = r; + // check we need to populate values + if (cvalues) { + cvalues[nz] = avalues[t]; + } + // increment number of nonzero elements + nz++; + } + } + // finalize the last column of C + cptr[n] = nz; + // return C matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [m, n], + datatype: adt + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPost.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPost.js new file mode 100644 index 0000000..384e72b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csPost.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csPost = csPost; +var _csTdfs = require("./csTdfs.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Post order a tree of forest + * + * @param {Array} parent The tree or forest + * @param {Number} n Number of columns + */ +function csPost(parent, n) { + // check inputs + if (!parent) { + return null; + } + // vars + let k = 0; + let j; + // allocate result + const post = []; // (n) + // workspace, head: first n entries, next: next n entries, stack: last n entries + const w = []; // (3 * n) + const head = 0; + const next = n; + const stack = 2 * n; + // initialize workspace + for (j = 0; j < n; j++) { + // empty linked lists + w[head + j] = -1; + } + // traverse nodes in reverse order + for (j = n - 1; j >= 0; j--) { + // check j is a root + if (parent[j] === -1) { + continue; + } + // add j to list of its parent + w[next + j] = w[head + parent[j]]; + w[head + parent[j]] = j; + } + // loop nodes + for (j = 0; j < n; j++) { + // skip j if it is not a root + if (parent[j] !== -1) { + continue; + } + // depth-first search + k = (0, _csTdfs.csTdfs)(j, k, w, head, next, post, stack); + } + return post; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csReach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csReach.js new file mode 100644 index 0000000..2975d6d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csReach.js @@ -0,0 +1,57 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csReach = csReach; +var _csMarked = require("./csMarked.js"); +var _csMark = require("./csMark.js"); +var _csDfs = require("./csDfs.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * The csReach function computes X = Reach(B), where B is the nonzero pattern of the n-by-1 + * sparse column of vector b. The function returns the set of nodes reachable from any node in B. The + * nonzero pattern xi of the solution x to the sparse linear system Lx=b is given by X=Reach(B). + * + * @param {Matrix} g The G matrix + * @param {Matrix} b The B matrix + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} pinv The inverse row permutation vector + * + * @return {Number} The index for the nonzero pattern + */ +function csReach(g, b, k, xi, pinv) { + // g arrays + const gptr = g._ptr; + const gsize = g._size; + // b arrays + const bindex = b._index; + const bptr = b._ptr; + // columns + const n = gsize[1]; + // vars + let p, p0, p1; + // initialize top + let top = n; + // loop column indeces in B + for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { + // node i + const i = bindex[p]; + // check node i is marked + if (!(0, _csMarked.csMarked)(gptr, i)) { + // start a dfs at unmarked node i + top = (0, _csDfs.csDfs)(i, g, top, xi, pinv); + } + } + // loop columns from top -> n - 1 + for (p = top; p < n; p++) { + // restore G + (0, _csMark.csMark)(gptr, xi[p]); + } + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSpsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSpsolve.js new file mode 100644 index 0000000..3e45875 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSpsolve.js @@ -0,0 +1,91 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsSpsolve = void 0; +var _csReach = require("./csReach.js"); +var _factory = require("../../../utils/factory.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csSpsolve'; +const dependencies = ['divideScalar', 'multiply', 'subtract']; +const createCsSpsolve = exports.createCsSpsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + divideScalar, + multiply, + subtract + } = _ref; + /** + * The function csSpsolve() computes the solution to G * x = bk, where bk is the + * kth column of B. When lo is true, the function assumes G = L is lower triangular with the + * diagonal entry as the first entry in each column. When lo is true, the function assumes G = U + * is upper triangular with the diagonal entry as the last entry in each column. + * + * @param {Matrix} g The G matrix + * @param {Matrix} b The B matrix + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} x The soluton to the linear system G * x = b + * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b + * @param {boolean} lo The lower (true) upper triangular (false) flag + * + * @return {Number} The index for the nonzero pattern + */ + return function csSpsolve(g, b, k, xi, x, pinv, lo) { + // g arrays + const gvalues = g._values; + const gindex = g._index; + const gptr = g._ptr; + const gsize = g._size; + // columns + const n = gsize[1]; + // b arrays + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + // vars + let p, p0, p1, q; + // xi[top..n-1] = csReach(B(:,k)) + const top = (0, _csReach.csReach)(g, b, k, xi, pinv); + // clear x + for (p = top; p < n; p++) { + x[xi[p]] = 0; + } + // scatter b + for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { + x[bindex[p]] = bvalues[p]; + } + // loop columns + for (let px = top; px < n; px++) { + // x array index for px + const j = xi[px]; + // apply permutation vector (U x = b), j maps to column J of G + const J = pinv ? pinv[j] : j; + // check column J is empty + if (J < 0) { + continue; + } + // column value indeces in G, p0 <= p < p1 + p0 = gptr[J]; + p1 = gptr[J + 1]; + // x(j) /= G(j,j) + x[j] = divideScalar(x[j], gvalues[lo ? p0 : p1 - 1]); + // first entry L(j,j) + p = lo ? p0 + 1 : p0; + q = lo ? p1 : p1 - 1; + // loop + for (; p < q; p++) { + // row + const i = gindex[p]; + // x(i) -= G(i,j) * x(j) + x[i] = subtract(x[i], multiply(gvalues[p], x[j])); + } + } + // return top of stack + return top; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSqr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSqr.js new file mode 100644 index 0000000..a6bbaa1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSqr.js @@ -0,0 +1,186 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsSqr = void 0; +var _csPermute = require("./csPermute.js"); +var _csPost = require("./csPost.js"); +var _csEtree = require("./csEtree.js"); +var _csAmd = require("./csAmd.js"); +var _csCounts = require("./csCounts.js"); +var _factory = require("../../../utils/factory.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csSqr'; +const dependencies = ['add', 'multiply', 'transpose']; +const createCsSqr = exports.createCsSqr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + add, + multiply, + transpose + } = _ref; + const csAmd = (0, _csAmd.createCsAmd)({ + add, + multiply, + transpose + }); + const csCounts = (0, _csCounts.createCsCounts)({ + transpose + }); + + /** + * Symbolic ordering and analysis for QR and LU decompositions. + * + * @param {Number} order The ordering strategy (see csAmd for more details) + * @param {Matrix} a The A matrix + * @param {boolean} qr Symbolic ordering and analysis for QR decomposition (true) or + * symbolic ordering and analysis for LU decomposition (false) + * + * @return {Object} The Symbolic ordering and analysis for matrix A + */ + return function csSqr(order, a, qr) { + // a arrays + const aptr = a._ptr; + const asize = a._size; + // columns + const n = asize[1]; + // vars + let k; + // symbolic analysis result + const s = {}; + // fill-reducing ordering + s.q = csAmd(order, a); + // validate results + if (order && !s.q) { + return null; + } + // QR symbolic analysis + if (qr) { + // apply permutations if needed + const c = order ? (0, _csPermute.csPermute)(a, null, s.q, 0) : a; + // etree of C'*C, where C=A(:,q) + s.parent = (0, _csEtree.csEtree)(c, 1); + // post order elimination tree + const post = (0, _csPost.csPost)(s.parent, n); + // col counts chol(C'*C) + s.cp = csCounts(c, s.parent, post, 1); + // check we have everything needed to calculate number of nonzero elements + if (c && s.parent && s.cp && _vcount(c, s)) { + // calculate number of nonzero elements + for (s.unz = 0, k = 0; k < n; k++) { + s.unz += s.cp[k]; + } + } + } else { + // for LU factorization only, guess nnz(L) and nnz(U) + s.unz = 4 * aptr[n] + n; + s.lnz = s.unz; + } + // return result S + return s; + }; + + /** + * Compute nnz(V) = s.lnz, s.pinv, s.leftmost, s.m2 from A and s.parent + */ + function _vcount(a, s) { + // a arrays + const aptr = a._ptr; + const aindex = a._index; + const asize = a._size; + // rows & columns + const m = asize[0]; + const n = asize[1]; + // initialize s arrays + s.pinv = []; // (m + n) + s.leftmost = []; // (m) + // vars + const parent = s.parent; + const pinv = s.pinv; + const leftmost = s.leftmost; + // workspace, next: first m entries, head: next n entries, tail: next n entries, nque: next n entries + const w = []; // (m + 3 * n) + const next = 0; + const head = m; + const tail = m + n; + const nque = m + 2 * n; + // vars + let i, k, p, p0, p1; + // initialize w + for (k = 0; k < n; k++) { + // queue k is empty + w[head + k] = -1; + w[tail + k] = -1; + w[nque + k] = 0; + } + // initialize row arrays + for (i = 0; i < m; i++) { + leftmost[i] = -1; + } + // loop columns backwards + for (k = n - 1; k >= 0; k--) { + // values & index for column k + for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // leftmost[i] = min(find(A(i,:))) + leftmost[aindex[p]] = k; + } + } + // scan rows in reverse order + for (i = m - 1; i >= 0; i--) { + // row i is not yet ordered + pinv[i] = -1; + k = leftmost[i]; + // check row i is empty + if (k === -1) { + continue; + } + // first row in queue k + if (w[nque + k]++ === 0) { + w[tail + k] = i; + } + // put i at head of queue k + w[next + i] = w[head + k]; + w[head + k] = i; + } + s.lnz = 0; + s.m2 = m; + // find row permutation and nnz(V) + for (k = 0; k < n; k++) { + // remove row i from queue k + i = w[head + k]; + // count V(k,k) as nonzero + s.lnz++; + // add a fictitious row + if (i < 0) { + i = s.m2++; + } + // associate row i with V(:,k) + pinv[i] = k; + // skip if V(k+1:m,k) is empty + if (--nque[k] <= 0) { + continue; + } + // nque[k] is nnz (V(k+1:m,k)) + s.lnz += w[nque + k]; + // move all rows to parent of k + const pa = parent[k]; + if (pa !== -1) { + if (w[nque + pa] === 0) { + w[tail + pa] = w[tail + k]; + } + w[next + w[tail + k]] = w[head + pa]; + w[head + pa] = w[next + i]; + w[nque + pa] += w[nque + k]; + } + } + for (i = 0; i < m; i++) { + if (pinv[i] < 0) { + pinv[i] = k++; + } + } + return true; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSymperm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSymperm.js new file mode 100644 index 0000000..9f435f5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csSymperm.js @@ -0,0 +1,100 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsSymperm = void 0; +var _csCumsum = require("./csCumsum.js"); +var _factory = require("../../../utils/factory.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +const name = 'csSymperm'; +const dependencies = ['conj', 'SparseMatrix']; +const createCsSymperm = exports.createCsSymperm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + conj, + SparseMatrix + } = _ref; + /** + * Computes the symmetric permutation of matrix A accessing only + * the upper triangular part of A. + * + * C = P * A * P' + * + * @param {Matrix} a The A matrix + * @param {Array} pinv The inverse of permutation vector + * @param {boolean} values Process matrix values (true) + * + * @return {Matrix} The C matrix, C = P * A * P' + */ + return function csSymperm(a, pinv, values) { + // A matrix arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + // columns + const n = asize[1]; + // C matrix arrays + const cvalues = values && avalues ? [] : null; + const cindex = []; // (nz) + const cptr = []; // (n + 1) + // variables + let i, i2, j, j2, p, p0, p1; + // create workspace vector + const w = []; // (n) + // count entries in each column of C + for (j = 0; j < n; j++) { + // column j of A is column j2 of C + j2 = pinv ? pinv[j] : j; + // loop values in column j + for (p0 = aptr[j], p1 = aptr[j + 1], p = p0; p < p1; p++) { + // row + i = aindex[p]; + // skip lower triangular part of A + if (i > j) { + continue; + } + // row i of A is row i2 of C + i2 = pinv ? pinv[i] : i; + // column count of C + w[Math.max(i2, j2)]++; + } + } + // compute column pointers of C + (0, _csCumsum.csCumsum)(cptr, w, n); + // loop columns + for (j = 0; j < n; j++) { + // column j of A is column j2 of C + j2 = pinv ? pinv[j] : j; + // loop values in column j + for (p0 = aptr[j], p1 = aptr[j + 1], p = p0; p < p1; p++) { + // row + i = aindex[p]; + // skip lower triangular part of A + if (i > j) { + continue; + } + // row i of A is row i2 of C + i2 = pinv ? pinv[i] : i; + // C index for column j2 + const q = w[Math.max(i2, j2)]++; + // update C index for entry q + cindex[q] = Math.min(i2, j2); + // check we need to process values + if (cvalues) { + cvalues[q] = i2 <= j2 ? avalues[p] : conj(avalues[p]); + } + } + } + // return C matrix + return new SparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [n, n] + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csTdfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csTdfs.js new file mode 100644 index 0000000..b1fa1aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csTdfs.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csTdfs = csTdfs; +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Depth-first search and postorder of a tree rooted at node j + * + * @param {Number} j The tree node + * @param {Number} k + * @param {Array} w The workspace array + * @param {Number} head The index offset within the workspace for the head array + * @param {Number} next The index offset within the workspace for the next array + * @param {Array} post The post ordering array + * @param {Number} stack The index offset within the workspace for the stack array + */ +function csTdfs(j, k, w, head, next, post, stack) { + // variables + let top = 0; + // place j on the stack + w[stack] = j; + // while (stack is not empty) + while (top >= 0) { + // p = top of stack + const p = w[stack + top]; + // i = youngest child of p + const i = w[head + p]; + if (i === -1) { + // p has no unordered children left + top--; + // node p is the kth postordered node + post[k++] = p; + } else { + // remove i from children of p + w[head + p] = w[next + i]; + // increment top + ++top; + // start dfs on child node i + w[stack + top] = i; + } + } + return k; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csUnflip.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csUnflip.js new file mode 100644 index 0000000..31c0304 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sparse/csUnflip.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.csUnflip = csUnflip; +var _csFlip = require("./csFlip.js"); +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Flips the value if it is negative of returns the same value otherwise. + * + * @param {Number} i The value to flip + */ +function csUnflip(i) { + // flip the value if it is negative + return i < 0 ? (0, _csFlip.csFlip)(i) : i; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sylvester.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sylvester.js new file mode 100644 index 0000000..bf6e311 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/sylvester.js @@ -0,0 +1,124 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSylvester = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'sylvester'; +const dependencies = ['typed', 'schur', 'matrixFromColumns', 'matrix', 'multiply', 'range', 'concat', 'transpose', 'index', 'subset', 'add', 'subtract', 'identity', 'lusolve', 'abs']; +const createSylvester = exports.createSylvester = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + schur, + matrixFromColumns, + matrix, + multiply, + range, + concat, + transpose, + index, + subset, + add, + subtract, + identity, + lusolve, + abs + } = _ref; + /** + * + * Solves the real-valued Sylvester equation AX+XB=C for X, where A, B and C are + * matrices of appropriate dimensions, being A and B squared. Notice that other + * equivalent definitions for the Sylvester equation exist and this function + * assumes the one presented in the original publication of the the Bartels- + * Stewart algorithm, which is implemented by this function. + * https://en.wikipedia.org/wiki/Sylvester_equation + * + * Syntax: + * + * math.sylvester(A, B, C) + * + * Examples: + * + * const A = [[-1, -2], [1, 1]] + * const B = [[2, -1], [1, -2]] + * const C = [[-3, 2], [3, 0]] + * math.sylvester(A, B, C) // returns DenseMatrix [[-0.25, 0.25], [1.5, -1.25]] + * + * See also: + * + * schur, lyap + * + * @param {Matrix | Array} A Matrix A + * @param {Matrix | Array} B Matrix B + * @param {Matrix | Array} C Matrix C + * @return {Matrix | Array} Matrix X, solving the Sylvester equation + */ + return typed(name, { + 'Matrix, Matrix, Matrix': _sylvester, + 'Array, Matrix, Matrix': function (A, B, C) { + return _sylvester(matrix(A), B, C); + }, + 'Array, Array, Matrix': function (A, B, C) { + return _sylvester(matrix(A), matrix(B), C); + }, + 'Array, Matrix, Array': function (A, B, C) { + return _sylvester(matrix(A), B, matrix(C)); + }, + 'Matrix, Array, Matrix': function (A, B, C) { + return _sylvester(A, matrix(B), C); + }, + 'Matrix, Array, Array': function (A, B, C) { + return _sylvester(A, matrix(B), matrix(C)); + }, + 'Matrix, Matrix, Array': function (A, B, C) { + return _sylvester(A, B, matrix(C)); + }, + 'Array, Array, Array': function (A, B, C) { + return _sylvester(matrix(A), matrix(B), matrix(C)).toArray(); + } + }); + function _sylvester(A, B, C) { + const n = B.size()[0]; + const m = A.size()[0]; + const sA = schur(A); + const F = sA.T; + const U = sA.U; + const sB = schur(multiply(-1, B)); + const G = sB.T; + const V = sB.U; + const D = multiply(multiply(transpose(U), C), V); + const all = range(0, m); + const y = []; + const hc = (a, b) => concat(a, b, 1); + const vc = (a, b) => concat(a, b, 0); + for (let k = 0; k < n; k++) { + if (k < n - 1 && abs(subset(G, index(k + 1, k))) > 1e-5) { + let RHS = vc(subset(D, index(all, k)), subset(D, index(all, k + 1))); + for (let j = 0; j < k; j++) { + RHS = add(RHS, vc(multiply(y[j], subset(G, index(j, k))), multiply(y[j], subset(G, index(j, k + 1))))); + } + const gkk = multiply(identity(m), multiply(-1, subset(G, index(k, k)))); + const gmk = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k)))); + const gkm = multiply(identity(m), multiply(-1, subset(G, index(k, k + 1)))); + const gmm = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k + 1)))); + const LHS = vc(hc(add(F, gkk), gmk), hc(gkm, add(F, gmm))); + const yAux = lusolve(LHS, RHS); + y[k] = yAux.subset(index(range(0, m), 0)); + y[k + 1] = yAux.subset(index(range(m, 2 * m), 0)); + k++; + } else { + let RHS = subset(D, index(all, k)); + for (let j = 0; j < k; j++) { + RHS = add(RHS, multiply(y[j], subset(G, index(j, k)))); + } + const gkk = subset(G, index(k, k)); + const LHS = subtract(F, multiply(gkk, identity(m))); + y[k] = lusolve(LHS, RHS); + } + } + const Y = matrix(matrixFromColumns(...y)); + const X = multiply(U, multiply(Y, transpose(V))); + return X; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/symbolicEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/symbolicEqual.js new file mode 100644 index 0000000..30434b3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/algebra/symbolicEqual.js @@ -0,0 +1,66 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSymbolicEqual = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'symbolicEqual'; +const dependencies = ['parse', 'simplify', 'typed', 'OperatorNode']; +const createSymbolicEqual = exports.createSymbolicEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + parse, + simplify, + typed, + OperatorNode + } = _ref; + /** + * Attempts to determine if two expressions are symbolically equal, i.e. + * one is the result of valid algebraic manipulations on the other. + * Currently, this simply checks if the difference of the two expressions + * simplifies down to 0. So there are two important caveats: + * 1. whether two expressions are symbolically equal depends on the + * manipulations allowed. Therefore, this function takes an optional + * third argument, which are the options that control the behavior + * as documented for the `simplify()` function. + * 2. it is in general intractable to find the minimal simplification of + * an arbitrarily complicated expression. So while a `true` value + * of `symbolicEqual` ensures that the two expressions can be manipulated + * to match each other, a `false` value does not absolutely rule this out. + * + * Syntax: + * + * math.symbolicEqual(expr1, expr2) + * math.symbolicEqual(expr1, expr2, options) + * + * Examples: + * + * math.symbolicEqual('x*y', 'y*x') // Returns true + * math.symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}}) // Returns false + * math.symbolicEqual('x/y', '(y*x^(-1))^(-1)') // Returns true + * math.symbolicEqual('abs(x)','x') // Returns false + * math.symbolicEqual('abs(x)','x', simplify.positiveContext) // Returns true + * + * See also: + * + * simplify, evaluate + * + * @param {Node|string} expr1 The first expression to compare + * @param {Node|string} expr2 The second expression to compare + * @param {Object} [options] Optional option object, passed to simplify + * @returns {boolean} + * Returns true if a valid manipulation making the expressions equal + * is found. + */ + function _symbolicEqual(e1, e2) { + let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + const diff = new OperatorNode('-', 'subtract', [e1, e2]); + const simplified = simplify(diff, {}, options); + return (0, _is.isConstantNode)(simplified) && !simplified.value; + } + return typed(name, { + 'Node, Node': _symbolicEqual, + 'Node, Node, Object': _symbolicEqual + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/abs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/abs.js new file mode 100644 index 0000000..dd1a1f0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/abs.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAbs = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +const name = 'abs'; +const dependencies = ['typed']; +const createAbs = exports.createAbs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the absolute value of a number. For matrices, the function is + * evaluated element wise. + * + * Syntax: + * + * math.abs(x) + * + * Examples: + * + * math.abs(3.5) // returns number 3.5 + * math.abs(-4.2) // returns number 4.2 + * + * math.abs([3, -5, -1, 0, 2]) // returns Array [3, 5, 1, 0, 2] + * + * See also: + * + * sign + * + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x + * A number or matrix for which to get the absolute value + * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} + * Absolute value of `x` + */ + return typed(name, { + number: _index.absNumber, + 'Complex | BigNumber | Fraction | Unit': x => x.abs(), + bigint: x => x < 0n ? -x : x, + // deep map collection, skip zeros since abs(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self, true)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/add.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/add.js new file mode 100644 index 0000000..65269f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/add.js @@ -0,0 +1,89 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAdd = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo04xSidSid = require("../../type/matrix/utils/matAlgo04xSidSid.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'add'; +const dependencies = ['typed', 'matrix', 'addScalar', 'equalScalar', 'DenseMatrix', 'SparseMatrix', 'concat']; +const createAdd = exports.createAdd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + addScalar, + equalScalar, + DenseMatrix, + SparseMatrix, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo04xSidSid = (0, _matAlgo04xSidSid.createMatAlgo04xSidSid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + /** + * Add two or more values, `x + y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.add(x, y) + * math.add(x, y, z, ...) + * + * Examples: + * + * math.add(2, 3) // returns number 5 + * math.add(2, 3, 4) // returns number 9 + * + * const a = math.complex(2, 3) + * const b = math.complex(-4, 1) + * math.add(a, b) // returns Complex -2 + 4i + * + * math.add([1, 2, 3], 4) // returns Array [5, 6, 7] + * + * const c = math.unit('5 cm') + * const d = math.unit('2.1 mm') + * math.add(c, d) // returns Unit 52.1 mm + * + * math.add("2.3", "4") // returns number 6.3 + * + * See also: + * + * subtract, sum + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to add + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to add + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Sum of `x` and `y` + */ + return typed(name, { + 'any, any': addScalar, + 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => { + let result = self(x, y); + for (let i = 0; i < rest.length; i++) { + result = self(result, rest[i]); + } + return result; + }) + }, matrixAlgorithmSuite({ + elop: addScalar, + DS: matAlgo01xDSid, + SS: matAlgo04xSidSid, + Ss: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/addScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/addScalar.js new file mode 100644 index 0000000..4bfc050 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/addScalar.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAddScalar = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'addScalar'; +const dependencies = ['typed']; +const createAddScalar = exports.createAddScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Add two scalar values, `x + y`. + * This function is meant for internal use: it is used by the public function + * `add` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to add + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to add + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Sum of `x` and `y` + * @private + */ + return typed(name, { + 'number, number': _index.addNumber, + 'Complex, Complex': function (x, y) { + return x.add(y); + }, + 'BigNumber, BigNumber': function (x, y) { + return x.plus(y); + }, + 'bigint, bigint': function (x, y) { + return x + y; + }, + 'Fraction, Fraction': function (x, y) { + return x.add(y); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (x.value === null || x.value === undefined) { + throw new Error('Parameter x contains a unit with undefined value'); + } + if (y.value === null || y.value === undefined) { + throw new Error('Parameter y contains a unit with undefined value'); + } + if (!x.equalBase(y)) throw new Error('Units do not match'); + const res = x.clone(); + res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value); + res.fixPrefix = false; + return res; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cbrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cbrt.js new file mode 100644 index 0000000..63d962b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cbrt.js @@ -0,0 +1,137 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCbrt = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _index = require("../../plain/number/index.js"); +const name = 'cbrt'; +const dependencies = ['config', 'typed', 'isNegative', 'unaryMinus', 'matrix', 'Complex', 'BigNumber', 'Fraction']; +const createCbrt = exports.createCbrt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + typed, + isNegative, + unaryMinus, + matrix, + Complex, + BigNumber, + Fraction + } = _ref; + /** + * Calculate the cubic root of a value. + * + * To avoid confusion with the matrix cube root, this function does not + * apply to matrices. For a matrix, to take the cube root elementwise, + * see the examples. + * + * Syntax: + * + * math.cbrt(x) + * math.cbrt(x, allRoots) + * + * Examples: + * + * math.cbrt(27) // returns 3 + * math.cube(3) // returns 27 + * math.cbrt(-64) // returns -4 + * math.cbrt(math.unit('27 m^3')) // returns Unit 3 m + * math.map([27, 64, 125], x => math.cbrt(x)) // returns [3, 4, 5] + * + * const x = math.complex('8i') + * math.cbrt(x) // returns Complex 1.7320508075689 + i + * math.cbrt(x, true) // returns Matrix [ + * // 1.7320508075689 + i + * // -1.7320508075689 + i + * // -2i + * // ] + * + * See also: + * + * square, sqrt, cube + * + * @param {number | BigNumber | Complex | Unit} x + * Value for which to calculate the cubic root. + * @param {boolean} [allRoots] Optional, false by default. Only applicable + * when `x` is a number or complex number. If true, all complex + * roots are returned, if false (default) the principal root is + * returned. + * @return {number | BigNumber | Complex | Unit} + * Returns the cubic root of `x` + */ + return typed(name, { + number: _index.cbrtNumber, + // note: signature 'number, boolean' is also supported, + // created by typed as it knows how to convert number to Complex + + Complex: _cbrtComplex, + 'Complex, boolean': _cbrtComplex, + BigNumber: function (x) { + return x.cbrt(); + }, + Unit: _cbrtUnit + }); + + /** + * Calculate the cubic root for a complex number + * @param {Complex} x + * @param {boolean} [allRoots] If true, the function will return an array + * with all three roots. If false or undefined, + * the principal root is returned. + * @returns {Complex | Array. | Matrix.} Returns the cubic root(s) of x + * @private + */ + function _cbrtComplex(x, allRoots) { + // https://www.wikiwand.com/en/Cube_root#/Complex_numbers + + const arg3 = x.arg() / 3; + const abs = x.abs(); + + // principal root: + const principal = new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3).exp()); + if (allRoots) { + const all = [principal, new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3 + Math.PI * 2 / 3).exp()), new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3 - Math.PI * 2 / 3).exp())]; + return config.matrix === 'Array' ? all : matrix(all); + } else { + return principal; + } + } + + /** + * Calculate the cubic root for a Unit + * @param {Unit} x + * @return {Unit} Returns the cubic root of x + * @private + */ + function _cbrtUnit(x) { + if (x.value && (0, _is.isComplex)(x.value)) { + let result = x.clone(); + result.value = 1.0; + result = result.pow(1.0 / 3); // Compute the units + result.value = _cbrtComplex(x.value); // Compute the value + return result; + } else { + const negate = isNegative(x.value); + if (negate) { + x.value = unaryMinus(x.value); + } + + // TODO: create a helper function for this + let third; + if ((0, _is.isBigNumber)(x.value)) { + third = new BigNumber(1).div(3); + } else if ((0, _is.isFraction)(x.value)) { + third = new Fraction(1, 3); + } else { + third = 1 / 3; + } + const result = x.pow(third); + if (negate) { + result.value = unaryMinus(result.value); + } + return result; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/ceil.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/ceil.js new file mode 100644 index 0000000..9a6a556 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/ceil.js @@ -0,0 +1,168 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCeilNumber = exports.createCeil = void 0; +var _decimal = _interopRequireDefault(require("decimal.js")); +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +const name = 'ceil'; +const dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']; +const createCeilNumber = exports.createCeilNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', 'round'], _ref => { + let { + typed, + config, + round + } = _ref; + return typed(name, { + number: function (x) { + if ((0, _number.nearlyEqual)(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return Math.ceil(x); + } + }, + 'number, number': function (x, n) { + if ((0, _number.nearlyEqual)(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + let [number, exponent] = `${x}e`.split('e'); + const result = Math.ceil(Number(`${number}e${Number(exponent) + n}`)); + [number, exponent] = `${result}e`.split('e'); + return Number(`${number}e${Number(exponent) - n}`); + } + } + }); +}); +const createCeil = exports.createCeil = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref2 => { + let { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const ceilNumber = createCeilNumber({ + typed, + config, + round + }); + /** + * Round a value towards plus infinity + * If `x` is complex, both real and imaginary part are rounded towards plus infinity. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.ceil(x) + * math.ceil(x, n) + * + * Examples: + * + * math.ceil(3.2) // returns number 4 + * math.ceil(3.8) // returns number 4 + * math.ceil(-4.2) // returns number -4 + * math.ceil(-4.7) // returns number -4 + * + * math.ceil(3.212, 2) // returns number 3.22 + * math.ceil(3.288, 2) // returns number 3.29 + * math.ceil(-4.212, 2) // returns number -4.21 + * math.ceil(-4.782, 2) // returns number -4.78 + * + * const c = math.complex(3.24, -2.71) + * math.ceil(c) // returns Complex 4 - 2i + * math.ceil(c, 1) // returns Complex 3.3 - 2.7i + * + * math.ceil([3.2, 3.8, -4.7]) // returns Array [4, 4, -4] + * math.ceil([3.21, 3.82, -4.71], 1) // returns Array [3.3, 3.9, -4.7] + * + * See also: + * + * floor, fix, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('ceil', { + number: ceilNumber.signatures.number, + 'number,number': ceilNumber.signatures['number,number'], + Complex: function (x) { + return x.ceil(); + }, + 'Complex, number': function (x, n) { + return x.ceil(n); + }, + 'Complex, BigNumber': function (x, n) { + return x.ceil(n.toNumber()); + }, + BigNumber: function (x) { + if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return x.ceil(); + } + }, + 'BigNumber, BigNumber': function (x, n) { + if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + return x.toDecimalPlaces(n.toNumber(), _decimal.default.ROUND_CEIL); + } + }, + Fraction: function (x) { + return x.ceil(); + }, + 'Fraction, number': function (x, n) { + return x.ceil(n); + }, + 'Fraction, BigNumber': function (x, n) { + return x.ceil(n.toNumber()); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since ceil(0) = 0 + return (0, _collection.deepMap)(x, self, true); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since ceil(0) = 0 + return (0, _collection.deepMap)(x, i => self(i, n), true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cube.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cube.js new file mode 100644 index 0000000..e28c103 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/cube.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCube = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'cube'; +const dependencies = ['typed']; +const createCube = exports.createCube = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the cube of a value, `x * x * x`. + * To avoid confusion with `pow(M,3)`, this function does not apply to matrices. + * If you wish to cube every entry of a matrix, see the examples. + * + * Syntax: + * + * math.cube(x) + * + * Examples: + * + * math.cube(2) // returns number 8 + * math.pow(2, 3) // returns number 8 + * math.cube(4) // returns number 64 + * 4 * 4 * 4 // returns number 64 + * + * math.map([1, 2, 3, 4], math.cube) // returns Array [1, 8, 27, 64] + * + * See also: + * + * multiply, square, pow, cbrt + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Number for which to calculate the cube + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Cube of x + */ + return typed(name, { + number: _index.cubeNumber, + Complex: function (x) { + return x.mul(x).mul(x); // Is faster than pow(x, 3) + }, + BigNumber: function (x) { + return x.times(x).times(x); + }, + bigint: function (x) { + return x * x * x; + }, + Fraction: function (x) { + return x.pow(3); // Is faster than mul()mul()mul() + }, + Unit: function (x) { + return x.pow(3); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divide.js new file mode 100644 index 0000000..22829ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divide.js @@ -0,0 +1,85 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDivide = void 0; +var _factory = require("../../utils/factory.js"); +var _object = require("../../utils/object.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +const name = 'divide'; +const dependencies = ['typed', 'matrix', 'multiply', 'equalScalar', 'divideScalar', 'inv']; +const createDivide = exports.createDivide = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + multiply, + equalScalar, + divideScalar, + inv + } = _ref; + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + + /** + * Divide two values, `x / y`. + * To divide matrices, `x` is multiplied with the inverse of `y`: `x * inv(y)`. + * + * Syntax: + * + * math.divide(x, y) + * + * Examples: + * + * math.divide(2, 3) // returns number 0.6666666666666666 + * + * const a = math.complex(5, 14) + * const b = math.complex(4, 1) + * math.divide(a, b) // returns Complex 2 + 3i + * + * const c = [[7, -6], [13, -4]] + * const d = [[1, 2], [4, 3]] + * math.divide(c, d) // returns Array [[-9, 4], [-11, 6]] + * + * const e = math.unit('18 km') + * math.divide(e, 4.5) // returns Unit 4 km + * + * See also: + * + * multiply + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Numerator + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix} y Denominator + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Quotient, `x / y` + */ + return typed('divide', (0, _object.extend)({ + // we extend the signatures of divideScalar with signatures dealing with matrices + + 'Array | Matrix, Array | Matrix': function (x, y) { + // TODO: implement matrix right division using pseudo inverse + // https://www.mathworks.nl/help/matlab/ref/mrdivide.html + // https://www.gnu.org/software/octave/doc/interpreter/Arithmetic-Ops.html + // https://stackoverflow.com/questions/12263932/how-does-gnu-octave-matrix-division-work-getting-unexpected-behaviour + return multiply(x, inv(y)); + }, + 'DenseMatrix, any': function (x, y) { + return matAlgo14xDs(x, y, divideScalar, false); + }, + 'SparseMatrix, any': function (x, y) { + return matAlgo11xS0s(x, y, divideScalar, false); + }, + 'Array, any': function (x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(x), y, divideScalar, false).valueOf(); + }, + 'any, Array | Matrix': function (x, y) { + return multiply(x, inv(y)); + } + }, divideScalar.signatures)); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divideScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divideScalar.js new file mode 100644 index 0000000..49fd13d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/divideScalar.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDivideScalar = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'divideScalar'; +const dependencies = ['typed', 'numeric']; +const createDivideScalar = exports.createDivideScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + numeric + } = _ref; + /** + * Divide two scalar values, `x / y`. + * This function is meant for internal use: it is used by the public functions + * `divide` and `inv`. + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Numerator + * @param {number | BigNumber | bigint | Fraction | Complex} y Denominator + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Quotient, `x / y` + * @private + */ + return typed(name, { + 'number, number': function (x, y) { + return x / y; + }, + 'Complex, Complex': function (x, y) { + return x.div(y); + }, + 'BigNumber, BigNumber': function (x, y) { + return x.div(y); + }, + 'bigint, bigint': function (x, y) { + return x / y; + }, + 'Fraction, Fraction': function (x, y) { + return x.div(y); + }, + 'Unit, number | Complex | Fraction | BigNumber | Unit': (x, y) => x.divide(y), + 'number | Fraction | Complex | BigNumber, Unit': (x, y) => y.divideInto(x) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotDivide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotDivide.js new file mode 100644 index 0000000..a620bed --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotDivide.js @@ -0,0 +1,84 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDotDivide = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'dotDivide'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'divideScalar', 'DenseMatrix', 'concat']; +const createDotDivide = exports.createDotDivide = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + divideScalar, + DenseMatrix, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Divide two matrices element wise. The function accepts both matrices and + * scalar values. + * + * Syntax: + * + * math.dotDivide(x, y) + * + * Examples: + * + * math.dotDivide(2, 4) // returns 0.5 + * + * a = [[9, 5], [6, 1]] + * b = [[3, 2], [5, 2]] + * + * math.dotDivide(a, b) // returns [[3, 2.5], [1.2, 0.5]] + * math.divide(a, b) // returns [[1.75, 0.75], [-1.75, 2.25]] + * + * See also: + * + * divide, multiply, dotMultiply + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Numerator + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Denominator + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Quotient, `x ./ y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: divideScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotMultiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotMultiply.js new file mode 100644 index 0000000..f98805d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotMultiply.js @@ -0,0 +1,72 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDotMultiply = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo09xS0Sf = require("../../type/matrix/utils/matAlgo09xS0Sf.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'dotMultiply'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'multiplyScalar', 'concat']; +const createDotMultiply = exports.createDotMultiply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + multiplyScalar, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo09xS0Sf = (0, _matAlgo09xS0Sf.createMatAlgo09xS0Sf)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Multiply two matrices element wise. The function accepts both matrices and + * scalar values. + * + * Syntax: + * + * math.dotMultiply(x, y) + * + * Examples: + * + * math.dotMultiply(2, 4) // returns 8 + * + * a = [[9, 5], [6, 1]] + * b = [[3, 2], [5, 2]] + * + * math.dotMultiply(a, b) // returns [[27, 10], [30, 2]] + * math.multiply(a, b) // returns [[52, 28], [23, 14]] + * + * See also: + * + * multiply, divide, dotDivide + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Left hand value + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Right hand value + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: multiplyScalar, + SS: matAlgo09xS0Sf, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotPow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotPow.js new file mode 100644 index 0000000..468a73d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/dotPow.js @@ -0,0 +1,84 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDotPow = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'dotPow'; +const dependencies = ['typed', 'equalScalar', 'matrix', 'pow', 'DenseMatrix', 'concat']; +const createDotPow = exports.createDotPow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar, + matrix, + pow, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const powScalarSignatures = {}; + for (const signature in pow.signatures) { + if (Object.prototype.hasOwnProperty.call(pow.signatures, signature)) { + if (!signature.includes('Matrix') && !signature.includes('Array')) { + powScalarSignatures[signature] = pow.signatures[signature]; + } + } + } + const powScalar = typed(powScalarSignatures); + + /** + * Calculates the power of x to y element wise. + * + * Syntax: + * + * math.dotPow(x, y) + * + * Examples: + * + * math.dotPow(2, 3) // returns number 8 + * + * const a = [[1, 2], [4, 3]] + * math.dotPow(a, 2) // returns Array [[1, 4], [16, 9]] + * math.pow(a, 2) // returns Array [[9, 8], [16, 17]] + * + * See also: + * + * pow, sqrt, multiply + * + * @param {number | BigNumber | Complex | Unit | Array | Matrix} x The base + * @param {number | BigNumber | Complex | Unit | Array | Matrix} y The exponent + * @return {number | BigNumber | Complex | Unit | Array | Matrix} The value of `x` to the power `y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: powScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/exp.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/exp.js new file mode 100644 index 0000000..24670a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/exp.js @@ -0,0 +1,54 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createExp = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'exp'; +const dependencies = ['typed']; +const createExp = exports.createExp = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the exponential of a value. + * For matrices, if you want the matrix exponential of square matrix, use + * the `expm` function; if you want to take the exponential of each element, + * see the examples. + * + * Syntax: + * + * math.exp(x) + * + * Examples: + * + * math.exp(2) // returns number 7.3890560989306495 + * math.pow(math.e, 2) // returns number 7.3890560989306495 + * math.log(math.exp(2)) // returns number 2 + * + * math.map([1, 2, 3], math.exp) + * // returns Array [ + * // 2.718281828459045, + * // 7.3890560989306495, + * // 20.085536923187668 + * // ] + * + * See also: + * + * expm1, expm, log, pow + * + * @param {number | BigNumber | Complex} x A number to exponentiate + * @return {number | BigNumber | Complex} Exponential of `x` + */ + return typed(name, { + number: _index.expNumber, + Complex: function (x) { + return x.exp(); + }, + BigNumber: function (x) { + return x.exp(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/expm1.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/expm1.js new file mode 100644 index 0000000..4a91a7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/expm1.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createExpm1 = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'expm1'; +const dependencies = ['typed', 'Complex']; +const createExpm1 = exports.createExpm1 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Complex + } = _ref; + /** + * Calculate the value of subtracting 1 from the exponential value. + * This function is more accurate than `math.exp(x)-1` when `x` is near 0 + * To avoid ambiguity with the matrix exponential `expm`, this function + * does not operate on matrices; if you wish to apply it elementwise, see + * the examples. + * + * Syntax: + * + * math.expm1(x) + * + * Examples: + * + * math.expm1(2) // returns number 6.38905609893065 + * math.pow(math.e, 2) - 1 // returns number 6.3890560989306495 + * math.expm1(1e-8) // returns number 1.0000000050000001e-8 + * math.exp(1e-8) - 1 // returns number 9.9999999392253e-9 + * math.log(math.expm1(2) + 1) // returns number 2 + * + * math.map([1, 2, 3], math.expm1) + * // returns Array [ + * // 1.718281828459045, + * // 6.3890560989306495, + * // 19.085536923187668 + * // ] + * + * See also: + * + * exp, expm, log, pow + * + * @param {number | BigNumber | Complex} x The number to exponentiate + * @return {number | BigNumber | Complex} Exponential of `x`, minus one + */ + return typed(name, { + number: _index.expm1Number, + Complex: function (x) { + const r = Math.exp(x.re); + return new Complex(r * Math.cos(x.im) - 1, r * Math.sin(x.im)); + }, + BigNumber: function (x) { + return x.exp().minus(1); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/fix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/fix.js new file mode 100644 index 0000000..8da3856 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/fix.js @@ -0,0 +1,132 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFixNumber = exports.createFix = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +const name = 'fix'; +const dependencies = ['typed', 'Complex', 'matrix', 'ceil', 'floor', 'equalScalar', 'zeros', 'DenseMatrix']; +const createFixNumber = exports.createFixNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'ceil', 'floor'], _ref => { + let { + typed, + ceil, + floor + } = _ref; + return typed(name, { + number: function (x) { + return x > 0 ? floor(x) : ceil(x); + }, + 'number, number': function (x, n) { + return x > 0 ? floor(x, n) : ceil(x, n); + } + }); +}); +const createFix = exports.createFix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref2 => { + let { + typed, + Complex, + matrix, + ceil, + floor, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const fixNumber = createFixNumber({ + typed, + ceil, + floor + }); + /** + * Round a value towards zero. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.fix(x) + * math.fix(x,n) + * + * Examples: + * + * math.fix(3.2) // returns number 3 + * math.fix(3.8) // returns number 3 + * math.fix(-4.2) // returns number -4 + * math.fix(-4.7) // returns number -4 + * + * math.fix(3.12, 1) // returns number 3.1 + * math.fix(3.18, 1) // returns number 3.1 + * math.fix(-4.12, 1) // returns number -4.1 + * math.fix(-4.17, 1) // returns number -4.1 + * + * const c = math.complex(3.22, -2.78) + * math.fix(c) // returns Complex 3 - 2i + * math.fix(c, 1) // returns Complex 3.2 -2.7i + * + * math.fix([3.2, 3.8, -4.7]) // returns Array [3, 3, -4] + * math.fix([3.2, 3.8, -4.7], 1) // returns Array [3.2, 3.8, -4.7] + * + * See also: + * + * ceil, floor, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('fix', { + number: fixNumber.signatures.number, + 'number, number | BigNumber': fixNumber.signatures['number,number'], + Complex: function (x) { + return new Complex(x.re > 0 ? Math.floor(x.re) : Math.ceil(x.re), x.im > 0 ? Math.floor(x.im) : Math.ceil(x.im)); + }, + 'Complex, number': function (x, n) { + return new Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n)); + }, + 'Complex, BigNumber': function (x, bn) { + const n = bn.toNumber(); + return new Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n)); + }, + BigNumber: function (x) { + return x.isNegative() ? ceil(x) : floor(x); + }, + 'BigNumber, number | BigNumber': function (x, n) { + return x.isNegative() ? ceil(x, n) : floor(x, n); + }, + Fraction: function (x) { + return x.s < 0 ? x.ceil() : x.floor(); + }, + 'Fraction, number | BigNumber': function (x, n) { + return x.s < 0 ? ceil(x, n) : floor(x, n); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since fix(0) = 0 + return (0, _collection.deepMap)(x, self, true); + }), + 'Array | Matrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since fix(0) = 0 + return (0, _collection.deepMap)(x, i => self(i, n), true); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/floor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/floor.js new file mode 100644 index 0000000..25983c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/floor.js @@ -0,0 +1,171 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFloorNumber = exports.createFloor = void 0; +var _decimal = _interopRequireDefault(require("decimal.js")); +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +const name = 'floor'; +const dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']; +const createFloorNumber = exports.createFloorNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', 'round'], _ref => { + let { + typed, + config, + round + } = _ref; + return typed(name, { + number: function (x) { + if ((0, _number.nearlyEqual)(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return Math.floor(x); + } + }, + 'number, number': function (x, n) { + if ((0, _number.nearlyEqual)(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + let [number, exponent] = `${x}e`.split('e'); + const result = Math.floor(Number(`${number}e${Number(exponent) + n}`)); + [number, exponent] = `${result}e`.split('e'); + return Number(`${number}e${Number(exponent) - n}`); + } + } + }); +}); +const createFloor = exports.createFloor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref2 => { + let { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const floorNumber = createFloorNumber({ + typed, + config, + round + }); + /** + * Round a value towards minus infinity. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.floor(x) + * math.floor(x, n) + * + * Examples: + * + * math.floor(3.2) // returns number 3 + * math.floor(3.8) // returns number 3 + * math.floor(-4.2) // returns number -5 + * math.floor(-4.7) // returns number -5 + * + * math.floor(3.212, 2) // returns number 3.21 + * math.floor(3.288, 2) // returns number 3.28 + * math.floor(-4.212, 2) // returns number -4.22 + * math.floor(-4.782, 2) // returns number -4.79 + * + * const c = math.complex(3.24, -2.71) + * math.floor(c) // returns Complex 3 - 3i + * math.floor(c, 1) // returns Complex 3.2 -2.8i + * + * math.floor([3.2, 3.8, -4.7]) // returns Array [3, 3, -5] + * math.floor([3.21, 3.82, -4.71], 1) // returns Array [3.2, 3.8, -4.8] + * + * math.floor(math.tau, [2, 3]) // returns Array [6.28, 6.283] + * + * // Note that floor(array, array) currently not implemented. + * + * See also: + * + * ceil, fix, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('floor', { + number: floorNumber.signatures.number, + 'number,number': floorNumber.signatures['number,number'], + Complex: function (x) { + return x.floor(); + }, + 'Complex, number': function (x, n) { + return x.floor(n); + }, + 'Complex, BigNumber': function (x, n) { + return x.floor(n.toNumber()); + }, + BigNumber: function (x) { + if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return x.floor(); + } + }, + 'BigNumber, BigNumber': function (x, n) { + if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + return x.toDecimalPlaces(n.toNumber(), _decimal.default.ROUND_FLOOR); + } + }, + Fraction: function (x) { + return x.floor(); + }, + 'Fraction, number': function (x, n) { + return x.floor(n); + }, + 'Fraction, BigNumber': function (x, n) { + return x.floor(n.toNumber()); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since floor(0) = 0 + return (0, _collection.deepMap)(x, self, true); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since ceil(0) = 0 + return (0, _collection.deepMap)(x, i => self(i, n), true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/gcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/gcd.js new file mode 100644 index 0000000..0f9276d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/gcd.js @@ -0,0 +1,159 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createGcd = void 0; +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _mod = require("./mod.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo04xSidSid = require("../../type/matrix/utils/matAlgo04xSidSid.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _ArgumentsError = require("../../error/ArgumentsError.js"); +const name = 'gcd'; +const dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'BigNumber', 'DenseMatrix', 'concat']; +const gcdTypes = 'number | BigNumber | Fraction | Matrix | Array'; +const gcdManyTypesSignature = `${gcdTypes}, ${gcdTypes}, ...${gcdTypes}`; +function is1d(array) { + return !array.some(element => Array.isArray(element)); +} +const createGcd = exports.createGcd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + config, + round, + equalScalar, + zeros, + BigNumber, + DenseMatrix, + concat + } = _ref; + const mod = (0, _mod.createMod)({ + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + }); + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo04xSidSid = (0, _matAlgo04xSidSid.createMatAlgo04xSidSid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Calculate the greatest common divisor for two or more values or arrays. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.gcd(a, b) + * math.gcd(a, b, c, ...) + * + * Examples: + * + * math.gcd(8, 12) // returns 4 + * math.gcd(-4, 6) // returns 2 + * math.gcd(25, 15, -10) // returns 5 + * + * math.gcd([8, -4], [12, 6]) // returns [4, 2] + * + * See also: + * + * lcm, xgcd + * + * @param {... number | BigNumber | Fraction | Array | Matrix} args Two or more integer numbers + * @return {number | BigNumber | Fraction | Array | Matrix} The greatest common divisor + */ + return typed(name, { + 'number, number': _gcdNumber, + 'BigNumber, BigNumber': _gcdBigNumber, + 'Fraction, Fraction': (x, y) => x.gcd(y) + }, matrixAlgorithmSuite({ + SS: matAlgo04xSidSid, + DS: matAlgo01xDSid, + Ss: matAlgo10xSids + }), { + [gcdManyTypesSignature]: typed.referToSelf(self => (a, b, args) => { + let res = self(a, b); + for (let i = 0; i < args.length; i++) { + res = self(res, args[i]); + } + return res; + }), + Array: typed.referToSelf(self => array => { + if (array.length === 1 && Array.isArray(array[0]) && is1d(array[0])) { + return self(...array[0]); + } + if (is1d(array)) { + return self(...array); + } + throw new _ArgumentsError.ArgumentsError('gcd() supports only 1d matrices!'); + }), + Matrix: typed.referToSelf(self => matrix => { + return self(matrix.toArray()); + }) + }); + + /** + * Calculate gcd for numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the greatest common denominator of a and b + * @private + */ + function _gcdNumber(a, b) { + if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + let r; + while (b !== 0) { + r = mod(a, b); + a = b; + b = r; + } + return a < 0 ? -a : a; + } + + /** + * Calculate gcd for BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @returns {BigNumber} Returns greatest common denominator of a and b + * @private + */ + function _gcdBigNumber(a, b) { + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + const zero = new BigNumber(0); + while (!b.isZero()) { + const r = mod(a, b); + a = b; + b = r; + } + return a.lt(zero) ? a.neg() : a; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/hypot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/hypot.js new file mode 100644 index 0000000..2bb014c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/hypot.js @@ -0,0 +1,83 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createHypot = void 0; +var _factory = require("../../utils/factory.js"); +var _array = require("../../utils/array.js"); +var _is = require("../../utils/is.js"); +const name = 'hypot'; +const dependencies = ['typed', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'sqrt', 'smaller', 'isPositive']; +const createHypot = exports.createHypot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + addScalar, + divideScalar, + multiplyScalar, + sqrt, + smaller, + isPositive + } = _ref; + /** + * Calculate the hypotenuse of a list with values. The hypotenuse is defined as: + * + * hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...) + * + * For matrix input, the hypotenuse is calculated for all values in the matrix. + * + * Syntax: + * + * math.hypot(a, b, ...) + * math.hypot([a, b, c, ...]) + * + * Examples: + * + * math.hypot(3, 4) // 5 + * math.hypot(3, 4, 5) // 7.0710678118654755 + * math.hypot([3, 4, 5]) // 7.0710678118654755 + * math.hypot(-2) // 2 + * + * See also: + * + * abs, norm + * + * @param {... number | BigNumber | Array | Matrix} args A list with numeric values or an Array or Matrix. + * Matrix and Array input is flattened and returns a + * single number for the whole matrix. + * @return {number | BigNumber} Returns the hypothenusa of the input values. + */ + return typed(name, { + '... number | BigNumber': _hypot, + Array: _hypot, + Matrix: M => _hypot((0, _array.flatten)(M.toArray())) + }); + + /** + * Calculate the hypotenuse for an Array with values + * @param {Array.} args + * @return {number | BigNumber} Returns the result + * @private + */ + function _hypot(args) { + // code based on `hypot` from es6-shim: + // https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1619-L1633 + let result = 0; + let largest = 0; + for (let i = 0; i < args.length; i++) { + if ((0, _is.isComplex)(args[i])) { + throw new TypeError('Unexpected type of argument to hypot'); + } + const value = abs(args[i]); + if (smaller(largest, value)) { + result = multiplyScalar(result, multiplyScalar(divideScalar(largest, value), divideScalar(largest, value))); + result = addScalar(result, 1); + largest = value; + } else { + result = addScalar(result, isPositive(value) ? multiplyScalar(divideScalar(value, largest), divideScalar(value, largest)) : value); + } + } + return multiplyScalar(largest, sqrt(result)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/invmod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/invmod.js new file mode 100644 index 0000000..d6b8ed2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/invmod.js @@ -0,0 +1,61 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createInvmod = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'invmod'; +const dependencies = ['typed', 'config', 'BigNumber', 'xgcd', 'equal', 'smaller', 'mod', 'add', 'isInteger']; +const createInvmod = exports.createInvmod = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + BigNumber, + xgcd, + equal, + smaller, + mod, + add, + isInteger + } = _ref; + /** + * Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation `ax ≣ 1 (mod b)` + * See https://en.wikipedia.org/wiki/Modular_multiplicative_inverse. + * + * Syntax: + * + * math.invmod(a, b) + * + * Examples: + * + * math.invmod(8, 12) // returns NaN + * math.invmod(7, 13) // returns 2 + * math.invmod(15151, 15122) // returns 10429 + * + * See also: + * + * gcd, xgcd + * + * @param {number | BigNumber} a An integer number + * @param {number | BigNumber} b An integer number + * @return {number | BigNumber } Returns an integer number + * where `invmod(a,b)*a ≣ 1 (mod b)` + */ + return typed(name, { + 'number, number': invmod, + 'BigNumber, BigNumber': invmod + }); + function invmod(a, b) { + if (!isInteger(a) || !isInteger(b)) throw new Error('Parameters in function invmod must be integer numbers'); + a = mod(a, b); + if (equal(b, 0)) throw new Error('Divisor must be non zero'); + let res = xgcd(a, b); + res = res.valueOf(); + let [gcd, inv] = res; + if (!equal(gcd, BigNumber(1))) return NaN; + inv = mod(inv, b); + if (smaller(inv, BigNumber(0))) inv = add(inv, b); + return inv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/lcm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/lcm.js new file mode 100644 index 0000000..a3f30c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/lcm.js @@ -0,0 +1,116 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLcm = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo06xS0S = require("../../type/matrix/utils/matAlgo06xS0S0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'lcm'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'concat']; +const createLcm = exports.createLcm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo06xS0S0 = (0, _matAlgo06xS0S.createMatAlgo06xS0S0)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const lcmTypes = 'number | BigNumber | Fraction | Matrix | Array'; + const lcmManySignature = {}; + lcmManySignature[`${lcmTypes}, ${lcmTypes}, ...${lcmTypes}`] = typed.referToSelf(self => (a, b, args) => { + let res = self(a, b); + for (let i = 0; i < args.length; i++) { + res = self(res, args[i]); + } + return res; + }); + + /** + * Calculate the least common multiple for two or more values or arrays. + * + * lcm is defined as: + * + * lcm(a, b) = abs(a * b) / gcd(a, b) + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.lcm(a, b) + * math.lcm(a, b, c, ...) + * + * Examples: + * + * math.lcm(4, 6) // returns 12 + * math.lcm(6, 21) // returns 42 + * math.lcm(6, 21, 5) // returns 210 + * + * math.lcm([4, 6], [6, 21]) // returns [12, 42] + * + * See also: + * + * gcd, xgcd + * + * @param {... number | BigNumber | Array | Matrix} args Two or more integer numbers + * @return {number | BigNumber | Array | Matrix} The least common multiple + */ + return typed(name, { + 'number, number': _index.lcmNumber, + 'BigNumber, BigNumber': _lcmBigNumber, + 'Fraction, Fraction': (x, y) => x.lcm(y) + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + }), lcmManySignature); + + /** + * Calculate lcm for two BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @returns {BigNumber} Returns the least common multiple of a and b + * @private + */ + function _lcmBigNumber(a, b) { + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function lcm must be integer numbers'); + } + if (a.isZero()) { + return a; + } + if (b.isZero()) { + return b; + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + // evaluate lcm here inline to reduce overhead + const prod = a.times(b); + while (!b.isZero()) { + const t = b; + b = a.mod(t); + a = t; + } + return prod.div(a).abs(); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log.js new file mode 100644 index 0000000..278834a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log.js @@ -0,0 +1,78 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLog = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'log'; +const dependencies = ['config', 'typed', 'divideScalar', 'Complex']; +const createLog = exports.createLog = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + divideScalar, + Complex + } = _ref; + /** + * Calculate the logarithm of a value. + * + * To avoid confusion with the matrix logarithm, this function does not + * apply to matrices. + * + * Syntax: + * + * math.log(x) + * math.log(x, base) + * + * Examples: + * + * math.log(3.5) // returns 1.252762968495368 + * math.exp(math.log(2.4)) // returns 2.4 + * + * math.pow(10, 4) // returns 10000 + * math.log(10000, 10) // returns 4 + * math.log(10000) / math.log(10) // returns 4 + * + * math.log(1024, 2) // returns 10 + * math.pow(2, 10) // returns 1024 + * + * See also: + * + * exp, log2, log10, log1p + * + * @param {number | BigNumber | Complex} x + * Value for which to calculate the logarithm. + * @param {number | BigNumber | Complex} [base=e] + * Optional base for the logarithm. If not provided, the natural + * logarithm of `x` is calculated. + * @return {number | BigNumber | Complex} + * Returns the logarithm of `x` + */ + return typed(name, { + number: function (x) { + if (x >= 0 || config.predictable) { + return (0, _index.logNumber)(x); + } else { + // negative value -> complex value computation + return new Complex(x, 0).log(); + } + }, + Complex: function (x) { + return x.log(); + }, + BigNumber: function (x) { + if (!x.isNegative() || config.predictable) { + return x.ln(); + } else { + // downgrade to number, return Complex valued result + return new Complex(x.toNumber(), 0).log(); + } + }, + 'any, any': typed.referToSelf(self => (x, base) => { + // calculate logarithm for a specified base, log(x, base) + return divideScalar(self(x), self(base)); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log10.js new file mode 100644 index 0000000..8125e79 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log10.js @@ -0,0 +1,65 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLog10 = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +const name = 'log10'; +const dependencies = ['typed', 'config', 'Complex']; +const createLog10 = exports.createLog10 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the 10-base logarithm of a value. This is the same as calculating `log(x, 10)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log10(x) + * + * Examples: + * + * math.log10(0.00001) // returns -5 + * math.log10(10000) // returns 4 + * math.log(10000) / math.log(10) // returns 4 + * math.pow(10, 4) // returns 10000 + * + * See also: + * + * exp, log, log1p, log2 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the 10-base logarithm of `x` + */ + return typed(name, { + number: function (x) { + if (x >= 0 || config.predictable) { + return (0, _index.log10Number)(x); + } else { + // negative value -> complex value computation + return new Complex(x, 0).log().div(Math.LN10); + } + }, + Complex: function (x) { + return new Complex(x).log().div(Math.LN10); + }, + BigNumber: function (x) { + if (!x.isNegative() || config.predictable) { + return x.log(); + } else { + // downgrade to number, return Complex valued result + return new Complex(x.toNumber(), 0).log().div(Math.LN10); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log1p.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log1p.js new file mode 100644 index 0000000..e68a466 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log1p.js @@ -0,0 +1,87 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLog1p = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +const name = 'log1p'; +const dependencies = ['typed', 'config', 'divideScalar', 'log', 'Complex']; +const createLog1p = exports.createLog1p = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + divideScalar, + log, + Complex + } = _ref; + /** + * Calculate the logarithm of a `value+1`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log1p(x) + * math.log1p(x, base) + * + * Examples: + * + * math.log1p(2.5) // returns 1.252762968495368 + * math.exp(math.log1p(1.4)) // returns 2.4 + * + * math.pow(10, 4) // returns 10000 + * math.log1p(9999, 10) // returns 4 + * math.log1p(9999) / math.log(10) // returns 4 + * + * See also: + * + * exp, log, log2, log10 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm of `x+1`. + * @param {number | BigNumber | Complex} [base=e] + * Optional base for the logarithm. If not provided, the natural + * logarithm of `x+1` is calculated. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the logarithm of `x+1` + */ + return typed(name, { + number: function (x) { + if (x >= -1 || config.predictable) { + return (0, _number.log1p)(x); + } else { + // negative value -> complex value computation + return _log1pComplex(new Complex(x, 0)); + } + }, + Complex: _log1pComplex, + BigNumber: function (x) { + const y = x.plus(1); + if (!y.isNegative() || config.predictable) { + return y.ln(); + } else { + // downgrade to number, return Complex valued result + return _log1pComplex(new Complex(x.toNumber(), 0)); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)), + 'any, any': typed.referToSelf(self => (x, base) => { + // calculate logarithm for a specified base, log1p(x, base) + return divideScalar(self(x), log(base)); + }) + }); + + /** + * Calculate the natural logarithm of a complex number + 1 + * @param {Complex} x + * @returns {Complex} + * @private + */ + function _log1pComplex(x) { + const xRe1p = x.re + 1; + return new Complex(Math.log(Math.sqrt(xRe1p * xRe1p + x.im * x.im)), Math.atan2(x.im, xRe1p)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log2.js new file mode 100644 index 0000000..f995b9e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/log2.js @@ -0,0 +1,74 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLog2 = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +const name = 'log2'; +const dependencies = ['typed', 'config', 'Complex']; +const createLog2 = exports.createLog2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log2(x) + * + * Examples: + * + * math.log2(0.03125) // returns -5 + * math.log2(16) // returns 4 + * math.log2(16) / math.log2(2) // returns 4 + * math.pow(2, 4) // returns 16 + * + * See also: + * + * exp, log, log1p, log10 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the 2-base logarithm of `x` + */ + return typed(name, { + number: function (x) { + if (x >= 0 || config.predictable) { + return (0, _index.log2Number)(x); + } else { + // negative value -> complex value computation + return _log2Complex(new Complex(x, 0)); + } + }, + Complex: _log2Complex, + BigNumber: function (x) { + if (!x.isNegative() || config.predictable) { + return x.log(2); + } else { + // downgrade to number, return Complex valued result + return _log2Complex(new Complex(x.toNumber(), 0)); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); + + /** + * Calculate log2 for a complex value + * @param {Complex} x + * @returns {Complex} + * @private + */ + function _log2Complex(x) { + const newX = Math.sqrt(x.re * x.re + x.im * x.im); + return new Complex(Math.log2 ? Math.log2(newX) : Math.log(newX) / Math.LN2, Math.atan2(x.im, x.re) / Math.LN2); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/mod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/mod.js new file mode 100644 index 0000000..3fdc081 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/mod.js @@ -0,0 +1,139 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMod = void 0; +var _factory = require("../../utils/factory.js"); +var _floor = require("./floor.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo05xSfSf = require("../../type/matrix/utils/matAlgo05xSfSf.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'mod'; +const dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +const createMod = exports.createMod = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + const floor = (0, _floor.createFloor)({ + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + }); + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo05xSfSf = (0, _matAlgo05xSfSf.createMatAlgo05xSfSf)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Calculates the modulus, the remainder of an integer division. + * + * For matrices, the function is evaluated element wise. + * + * The modulus is defined as: + * + * x - y * floor(x / y) + * + * See https://en.wikipedia.org/wiki/Modulo_operation. + * + * Syntax: + * + * math.mod(x, y) + * + * Examples: + * + * math.mod(8, 3) // returns 2 + * math.mod(11, 2) // returns 1 + * + * function isOdd(x) { + * return math.mod(x, 2) != 0 + * } + * + * isOdd(2) // returns false + * isOdd(3) // returns true + * + * See also: + * + * divide + * + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Dividend + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} y Divisor + * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the remainder of `x` divided by `y`. + */ + return typed(name, { + 'number, number': _modNumber, + 'BigNumber, BigNumber': function (x, y) { + return y.isZero() ? x : x.sub(y.mul(floor(x.div(y)))); + }, + 'bigint, bigint': function (x, y) { + if (y === 0n) { + return x; + } + if (x < 0) { + const m = x % y; + return m === 0n ? m : m + y; + } + return x % y; + }, + 'Fraction, Fraction': function (x, y) { + return y.equals(0) ? x : x.sub(y.mul(floor(x.div(y)))); + } + }, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); + + /** + * Calculate the modulus of two numbers + * @param {number} x + * @param {number} y + * @returns {number} res + * @private + */ + function _modNumber(x, y) { + // We don't use JavaScript's % operator here as this doesn't work + // correctly for x < 0 and x === 0 + // see https://en.wikipedia.org/wiki/Modulo_operation + + // We use mathjs floor to handle errors associated with + // precision float approximation + return y === 0 ? x : x - y * floor(x / y); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiply.js new file mode 100644 index 0000000..fe11843 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiply.js @@ -0,0 +1,886 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMultiply = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +const name = 'multiply'; +const dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'equalScalar', 'dot']; +const createMultiply = exports.createMultiply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + addScalar, + multiplyScalar, + equalScalar, + dot + } = _ref; + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + function _validateMatrixDimensions(size1, size2) { + // check left operand dimensions + switch (size1.length) { + case 1: + // check size2 + switch (size2.length) { + case 1: + // Vector x Vector + if (size1[0] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Vectors must have the same length'); + } + break; + case 2: + // Vector x Matrix + if (size1[0] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Vector length (' + size1[0] + ') must match Matrix rows (' + size2[0] + ')'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)'); + } + break; + case 2: + // check size2 + switch (size2.length) { + case 1: + // Matrix x Vector + if (size1[1] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Matrix columns (' + size1[1] + ') must match Vector length (' + size2[0] + ')'); + } + break; + case 2: + // Matrix x Matrix + if (size1[1] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Matrix A columns (' + size1[1] + ') must match Matrix B rows (' + size2[0] + ')'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix A has ' + size1.length + ' dimensions)'); + } + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (N) + * @param {Matrix} b Dense Vector (N) + * + * @return {number} Scalar value + */ + function _multiplyVectorVector(a, b, n) { + // check empty vector + if (n === 0) { + throw new Error('Cannot multiply two empty vectors'); + } + return dot(a, b); + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (M) + * @param {Matrix} b Matrix (MxN) + * + * @return {Matrix} Dense Vector (N) + */ + function _multiplyVectorMatrix(a, b) { + // process storage + if (b.storage() !== 'dense') { + throw new Error('Support for SparseMatrix not implemented'); + } + return _multiplyVectorDenseMatrix(a, b); + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (M) + * @param {Matrix} b Dense Matrix (MxN) + * + * @return {Matrix} Dense Vector (N) + */ + function _multiplyVectorDenseMatrix(a, b) { + // a dense + const adata = a._data; + const asize = a._size; + const adt = a._datatype || a.getDataType(); + // b dense + const bdata = b._data; + const bsize = b._size; + const bdt = b._datatype || b.getDataType(); + // rows & columns + const alength = asize[0]; + const bcolumns = bsize[1]; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + const c = []; + + // loop matrix columns + for (let j = 0; j < bcolumns; j++) { + // sum (do not initialize it with zero) + let sum = mf(adata[0], bdata[0][j]); + // loop vector + for (let i = 1; i < alength; i++) { + // multiply & accumulate + sum = af(sum, mf(adata[i], bdata[i][j])); + } + c[j] = sum; + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a Matrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} Dense Vector (M) + */ + const _multiplyMatrixVector = typed('_multiplyMatrixVector', { + 'DenseMatrix, any': _multiplyDenseMatrixVector, + 'SparseMatrix, any': _multiplySparseMatrixVector + }); + + /** + * C = A * B + * + * @param {Matrix} a Matrix (MxN) + * @param {Matrix} b Matrix (NxC) + * + * @return {Matrix} Matrix (MxC) + */ + const _multiplyMatrixMatrix = typed('_multiplyMatrixMatrix', { + 'DenseMatrix, DenseMatrix': _multiplyDenseMatrixDenseMatrix, + 'DenseMatrix, SparseMatrix': _multiplyDenseMatrixSparseMatrix, + 'SparseMatrix, DenseMatrix': _multiplySparseMatrixDenseMatrix, + 'SparseMatrix, SparseMatrix': _multiplySparseMatrixSparseMatrix + }); + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} Dense Vector (M) + */ + function _multiplyDenseMatrixVector(a, b) { + // a dense + const adata = a._data; + const asize = a._size; + const adt = a._datatype || a.getDataType(); + // b dense + const bdata = b._data; + const bdt = b._datatype || b.getDataType(); + // rows & columns + const arows = asize[0]; + const acolumns = asize[1]; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + const c = []; + + // loop matrix a rows + for (let i = 0; i < arows; i++) { + // current row + const row = adata[i]; + // sum (do not initialize it with zero) + let sum = mf(row[0], bdata[0]); + // loop matrix a columns + for (let j = 1; j < acolumns; j++) { + // multiply & accumulate + sum = af(sum, mf(row[j], bdata[j])); + } + c[i] = sum; + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [arows], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b DenseMatrix (NxC) + * + * @return {Matrix} DenseMatrix (MxC) + */ + function _multiplyDenseMatrixDenseMatrix(a, b) { + // getDataType() + // a dense + const adata = a._data; + const asize = a._size; + const adt = a._datatype || a.getDataType(); + // b dense + const bdata = b._data; + const bsize = b._size; + const bdt = b._datatype || b.getDataType(); + // rows & columns + const arows = asize[0]; + const acolumns = asize[1]; + const bcolumns = bsize[1]; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + const c = []; + + // loop matrix a rows + for (let i = 0; i < arows; i++) { + // current row + const row = adata[i]; + // initialize row array + c[i] = []; + // loop matrix b columns + for (let j = 0; j < bcolumns; j++) { + // sum (avoid initializing sum to zero) + let sum = mf(row[0], bdata[0][j]); + // loop matrix a columns + for (let x = 1; x < acolumns; x++) { + // multiply & accumulate + sum = af(sum, mf(row[x], bdata[x][j])); + } + c[i][j] = sum; + } + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b SparseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplyDenseMatrixSparseMatrix(a, b) { + // a dense + const adata = a._data; + const asize = a._size; + const adt = a._datatype || a.getDataType(); + // b sparse + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + // validate b matrix + if (!bvalues) { + throw new Error('Cannot multiply Dense Matrix times Pattern only Matrix'); + } + // rows & columns + const arows = asize[0]; + const bcolumns = bsize[1]; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + // equalScalar signature to use + let eq = equalScalar; + // zero value + let zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // result + const cvalues = []; + const cindex = []; + const cptr = []; + // c matrix + const c = b.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // loop b columns + for (let jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // indeces in column jb + const kb0 = bptr[jb]; + const kb1 = bptr[jb + 1]; + // do not process column jb if no data exists + if (kb1 > kb0) { + // last row mark processed + let last = 0; + // loop a rows + for (let i = 0; i < arows; i++) { + // column mark + const mark = i + 1; + // C[i, jb] + let cij; + // values in b column j + for (let kb = kb0; kb < kb1; kb++) { + // row + const ib = bindex[kb]; + // check value has been initialized + if (last !== mark) { + // first value in column jb + cij = mf(adata[i][ib], bvalues[kb]); + // update mark + last = mark; + } else { + // accumulate value + cij = af(cij, mf(adata[i][ib], bvalues[kb])); + } + } + // check column has been processed and value != 0 + if (last === mark && !eq(cij, zero)) { + // push row & value + cindex.push(i); + cvalues.push(cij); + } + } + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} SparseMatrix (M, 1) + */ + function _multiplySparseMatrixVector(a, b) { + // a sparse + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // validate a matrix + if (!avalues) { + throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix'); + } + // b dense + const bdata = b._data; + const bdt = b._datatype || b.getDataType(); + // rows & columns + const arows = a._size[0]; + const brows = b._size[0]; + // result + const cvalues = []; + const cindex = []; + const cptr = []; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + // equalScalar signature to use + let eq = equalScalar; + // zero value + let zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // workspace + const x = []; + // vector with marks indicating a value x[i] exists in a given column + const w = []; + + // update ptr + cptr[0] = 0; + // rows in b + for (let ib = 0; ib < brows; ib++) { + // b[ib] + const vbi = bdata[ib]; + // check b[ib] != 0, avoid loops + if (!eq(vbi, zero)) { + // A values & index in ib column + for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // a row + const ia = aindex[ka]; + // check value exists in current j + if (!w[ia]) { + // ia is new entry in j + w[ia] = true; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(vbi, avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(vbi, avalues[ka])); + } + } + } + } + // copy values from x to column jb of c + for (let p1 = cindex.length, p = 0; p < p1; p++) { + // row + const ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + // update ptr + cptr[1] = cindex.length; + + // matrix to return + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, 1], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b DenseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplySparseMatrixDenseMatrix(a, b) { + // a sparse + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // validate a matrix + if (!avalues) { + throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix'); + } + // b dense + const bdata = b._data; + const bdt = b._datatype || b.getDataType(); + // rows & columns + const arows = a._size[0]; + const brows = b._size[0]; + const bcolumns = b._size[1]; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + // equalScalar signature to use + let eq = equalScalar; + // zero value + let zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // result + const cvalues = []; + const cindex = []; + const cptr = []; + // c matrix + const c = a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // workspace + const x = []; + // vector with marks indicating a value x[i] exists in a given column + const w = []; + + // loop b columns + for (let jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // mark in workspace for current column + const mark = jb + 1; + // rows in jb + for (let ib = 0; ib < brows; ib++) { + // b[ib, jb] + const vbij = bdata[ib][jb]; + // check b[ib, jb] != 0, avoid loops + if (!eq(vbij, zero)) { + // A values & index in ib column + for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // a row + const ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(vbij, avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(vbij, avalues[ka])); + } + } + } + } + // copy values from x to column jb of c + for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) { + // row + const ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b SparseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplySparseMatrixSparseMatrix(a, b) { + // a sparse + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // b sparse + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // rows & columns + const arows = a._size[0]; + const bcolumns = b._size[1]; + // flag indicating both matrices (a & b) contain data + const values = avalues && bvalues; + + // datatype + let dt; + // addScalar signature to use + let af = addScalar; + // multiplyScalar signature to use + let mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + const cvalues = values ? [] : undefined; + const cindex = []; + const cptr = []; + // c matrix + const c = a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // workspace + const x = values ? [] : undefined; + // vector with marks indicating a value x[i] exists in a given column + const w = []; + // variables + let ka, ka0, ka1, kb, kb0, kb1, ia, ib; + // loop b columns + for (let jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // mark in workspace for current column + const mark = jb + 1; + // B values & index in j + for (kb0 = bptr[jb], kb1 = bptr[jb + 1], kb = kb0; kb < kb1; kb++) { + // b row + ib = bindex[kb]; + // check we need to process values + if (values) { + // loop values in a[:,ib] + for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // row + ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(bvalues[kb], avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(bvalues[kb], avalues[ka])); + } + } + } else { + // loop values in a[:,ib] + for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // row + ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + } + } + } + } + // check we need to process matrix values (pattern matrix) + if (values) { + // copy values from x to column jb of c + for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) { + // row + const ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * Multiply two or more values, `x * y`. + * For matrices, the matrix product is calculated. + * + * Syntax: + * + * math.multiply(x, y) + * math.multiply(x, y, z, ...) + * + * Examples: + * + * math.multiply(4, 5.2) // returns number 20.8 + * math.multiply(2, 3, 4) // returns number 24 + * + * const a = math.complex(2, 3) + * const b = math.complex(4, 1) + * math.multiply(a, b) // returns Complex 5 + 14i + * + * const c = [[1, 2], [4, 3]] + * const d = [[1, 2, 3], [3, -4, 7]] + * math.multiply(c, d) // returns Array [[7, -6, 17], [13, -4, 33]] + * + * const e = math.unit('2.1 km') + * math.multiply(3, e) // returns Unit 6.3 km + * + * See also: + * + * divide, prod, cross, dot + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to multiply + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to multiply + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y` + */ + return typed(name, multiplyScalar, { + // we extend the signatures of multiplyScalar with signatures dealing with matrices + + 'Array, Array': typed.referTo('Matrix, Matrix', selfMM => (x, y) => { + // check dimensions + _validateMatrixDimensions((0, _array.arraySize)(x), (0, _array.arraySize)(y)); + + // use dense matrix implementation + const m = selfMM(matrix(x), matrix(y)); + // return array or scalar + return (0, _is.isMatrix)(m) ? m.valueOf() : m; + }), + 'Matrix, Matrix': function (x, y) { + // dimensions + const xsize = x.size(); + const ysize = y.size(); + + // check dimensions + _validateMatrixDimensions(xsize, ysize); + + // process dimensions + if (xsize.length === 1) { + // process y dimensions + if (ysize.length === 1) { + // Vector * Vector + return _multiplyVectorVector(x, y, xsize[0]); + } + // Vector * Matrix + return _multiplyVectorMatrix(x, y); + } + // process y dimensions + if (ysize.length === 1) { + // Matrix * Vector + return _multiplyMatrixVector(x, y); + } + // Matrix * Matrix + return _multiplyMatrixMatrix(x, y); + }, + 'Matrix, Array': typed.referTo('Matrix,Matrix', selfMM => (x, y) => selfMM(x, matrix(y))), + 'Array, Matrix': typed.referToSelf(self => (x, y) => { + // use Matrix * Matrix implementation + return self(matrix(x, y.storage()), y); + }), + 'SparseMatrix, any': function (x, y) { + return matAlgo11xS0s(x, y, multiplyScalar, false); + }, + 'DenseMatrix, any': function (x, y) { + return matAlgo14xDs(x, y, multiplyScalar, false); + }, + 'any, SparseMatrix': function (x, y) { + return matAlgo11xS0s(y, x, multiplyScalar, true); + }, + 'any, DenseMatrix': function (x, y) { + return matAlgo14xDs(y, x, multiplyScalar, true); + }, + 'Array, any': function (x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(x), y, multiplyScalar, false).valueOf(); + }, + 'any, Array': function (x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, multiplyScalar, true).valueOf(); + }, + 'any, any': multiplyScalar, + 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => { + let result = self(x, y); + for (let i = 0; i < rest.length; i++) { + result = self(result, rest[i]); + } + return result; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiplyScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiplyScalar.js new file mode 100644 index 0000000..9a3c10b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/multiplyScalar.js @@ -0,0 +1,44 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMultiplyScalar = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'multiplyScalar'; +const dependencies = ['typed']; +const createMultiplyScalar = exports.createMultiplyScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Multiply two scalar values, `x * y`. + * This function is meant for internal use: it is used by the public function + * `multiply` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to multiply + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to multiply + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Multiplication of `x` and `y` + * @private + */ + return typed('multiplyScalar', { + 'number, number': _index.multiplyNumber, + 'Complex, Complex': function (x, y) { + return x.mul(y); + }, + 'BigNumber, BigNumber': function (x, y) { + return x.times(y); + }, + 'bigint, bigint': function (x, y) { + return x * y; + }, + 'Fraction, Fraction': function (x, y) { + return x.mul(y); + }, + 'number | Fraction | BigNumber | Complex, Unit': (x, y) => y.multiply(x), + 'Unit, number | Fraction | BigNumber | Complex | Unit': (x, y) => x.multiply(y) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/norm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/norm.js new file mode 100644 index 0000000..997aa8d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/norm.js @@ -0,0 +1,293 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNorm = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'norm'; +const dependencies = ['typed', 'abs', 'add', 'pow', 'conj', 'sqrt', 'multiply', 'equalScalar', 'larger', 'smaller', 'matrix', 'ctranspose', 'eigs']; +const createNorm = exports.createNorm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + add, + pow, + conj, + sqrt, + multiply, + equalScalar, + larger, + smaller, + matrix, + ctranspose, + eigs + } = _ref; + /** + * Calculate the norm of a number, vector or matrix. + * + * The second parameter p is optional. If not provided, it defaults to 2. + * + * Syntax: + * + * math.norm(x) + * math.norm(x, p) + * + * Examples: + * + * math.abs(-3.5) // returns 3.5 + * math.norm(-3.5) // returns 3.5 + * + * math.norm(math.complex(3, -4)) // returns 5 + * + * math.norm([1, 2, -3], Infinity) // returns 3 + * math.norm([1, 2, -3], -Infinity) // returns 1 + * + * math.norm([3, 4], 2) // returns 5 + * + * math.norm([[1, 2], [3, 4]], 1) // returns 6 + * math.norm([[1, 2], [3, 4]], 'inf') // returns 7 + * math.norm([[1, 2], [3, 4]], 'fro') // returns 5.477225575051661 + * + * See also: + * + * abs, hypot + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the norm + * @param {number | BigNumber | string} [p=2] + * Vector space. + * Supported numbers include Infinity and -Infinity. + * Supported strings are: 'inf', '-inf', and 'fro' (The Frobenius norm) + * @return {number | BigNumber} the p-norm + */ + return typed(name, { + number: Math.abs, + Complex: function (x) { + return x.abs(); + }, + BigNumber: function (x) { + // norm(x) = abs(x) + return x.abs(); + }, + boolean: function (x) { + // norm(x) = abs(x) + return Math.abs(x); + }, + Array: function (x) { + return _norm(matrix(x), 2); + }, + Matrix: function (x) { + return _norm(x, 2); + }, + 'Array, number | BigNumber | string': function (x, p) { + return _norm(matrix(x), p); + }, + 'Matrix, number | BigNumber | string': function (x, p) { + return _norm(x, p); + } + }); + + /** + * Calculate the plus infinity norm for a vector + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _vectorNormPlusInfinity(x) { + // norm(x, Infinity) = max(abs(x)) + let pinf = 0; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + const v = abs(value); + if (larger(v, pinf)) { + pinf = v; + } + }, true); + return pinf; + } + + /** + * Calculate the minus infinity norm for a vector + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _vectorNormMinusInfinity(x) { + // norm(x, -Infinity) = min(abs(x)) + let ninf; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + const v = abs(value); + if (!ninf || smaller(v, ninf)) { + ninf = v; + } + }, true); + return ninf || 0; + } + + /** + * Calculate the norm for a vector + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _vectorNorm(x, p) { + // check p + if (p === Number.POSITIVE_INFINITY || p === 'inf') { + return _vectorNormPlusInfinity(x); + } + if (p === Number.NEGATIVE_INFINITY || p === '-inf') { + return _vectorNormMinusInfinity(x); + } + if (p === 'fro') { + return _norm(x, 2); + } + if (typeof p === 'number' && !isNaN(p)) { + // check p != 0 + if (!equalScalar(p, 0)) { + // norm(x, p) = sum(abs(xi) ^ p) ^ 1/p + let n = 0; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + n = add(pow(abs(value), p), n); + }, true); + return pow(n, 1 / p); + } + return Number.POSITIVE_INFINITY; + } + // invalid parameter value + throw new Error('Unsupported parameter value'); + } + + /** + * Calculate the Frobenius norm for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormFrobenius(x) { + // norm(x) = sqrt(sum(diag(x'x))) + let fro = 0; + x.forEach(function (value, index) { + fro = add(fro, multiply(value, conj(value))); + }); + return abs(sqrt(fro)); + } + + /** + * Calculate the norm L1 for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormOne(x) { + // norm(x) = the largest column sum + const c = []; + // result + let maxc = 0; + // skip zeros since abs(0) == 0 + x.forEach(function (value, index) { + const j = index[1]; + const cj = add(c[j] || 0, abs(value)); + if (larger(cj, maxc)) { + maxc = cj; + } + c[j] = cj; + }, true); + return maxc; + } + + /** + * Calculate the norm L2 for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormTwo(x) { + // norm(x) = sqrt( max eigenvalue of A*.A) + const sizeX = x.size(); + if (sizeX[0] !== sizeX[1]) { + throw new RangeError('Invalid matrix dimensions'); + } + const tx = ctranspose(x); + const squaredX = multiply(tx, x); + const eigenVals = eigs(squaredX).values.toArray(); + const rho = eigenVals[eigenVals.length - 1]; + return abs(sqrt(rho)); + } + + /** + * Calculate the infinity norm for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormInfinity(x) { + // norm(x) = the largest row sum + const r = []; + // result + let maxr = 0; + // skip zeros since abs(0) == 0 + x.forEach(function (value, index) { + const i = index[0]; + const ri = add(r[i] || 0, abs(value)); + if (larger(ri, maxr)) { + maxr = ri; + } + r[i] = ri; + }, true); + return maxr; + } + + /** + * Calculate the norm for a 2D Matrix (M*N) + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _matrixNorm(x, p) { + // check p + if (p === 1) { + return _matrixNormOne(x); + } + if (p === Number.POSITIVE_INFINITY || p === 'inf') { + return _matrixNormInfinity(x); + } + if (p === 'fro') { + return _matrixNormFrobenius(x); + } + if (p === 2) { + return _matrixNormTwo(x); + } // invalid parameter value + + throw new Error('Unsupported parameter value ' + p); + } + + /** + * Calculate the norm for an array + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _norm(x, p) { + // size + const sizeX = x.size(); + + // check if it is a vector + if (sizeX.length === 1) { + return _vectorNorm(x, p); + } + // MxN matrix + if (sizeX.length === 2) { + if (sizeX[0] && sizeX[1]) { + return _matrixNorm(x, p); + } else { + throw new RangeError('Invalid matrix dimensions'); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoot.js new file mode 100644 index 0000000..4c53f40 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoot.js @@ -0,0 +1,172 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNthRootNumber = exports.createNthRoot = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo06xS0S = require("../../type/matrix/utils/matAlgo06xS0S0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'nthRoot'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'concat']; +const createNthRoot = exports.createNthRoot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + BigNumber, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo06xS0S0 = (0, _matAlgo06xS0S.createMatAlgo06xS0S0)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Calculate the nth root of a value. + * The principal nth root of a positive real number A, is the positive real + * solution of the equation + * + * x^root = A + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.nthRoot(a) + * math.nthRoot(a, root) + * + * Examples: + * + * math.nthRoot(9, 2) // returns 3 (since 3^2 == 9) + * math.sqrt(9) // returns 3 (since 3^2 == 9) + * math.nthRoot(64, 3) // returns 4 (since 4^3 == 64) + * + * See also: + * + * sqrt, pow + * + * @param {number | BigNumber | Array | Matrix | Complex} a + * Value for which to calculate the nth root + * @param {number | BigNumber} [root=2] The root. + * @return {number | Complex | Array | Matrix} Returns the nth root of `a` + */ + function complexErr() { + throw new Error('Complex number not supported in function nthRoot. Use nthRoots instead.'); + } + return typed(name, { + number: _index.nthRootNumber, + 'number, number': _index.nthRootNumber, + BigNumber: x => _bigNthRoot(x, new BigNumber(2)), + 'BigNumber, BigNumber': _bigNthRoot, + Complex: complexErr, + 'Complex, number': complexErr, + Array: typed.referTo('DenseMatrix,number', selfDn => x => selfDn(matrix(x), 2).valueOf()), + DenseMatrix: typed.referTo('DenseMatrix,number', selfDn => x => selfDn(x, 2)), + SparseMatrix: typed.referTo('SparseMatrix,number', selfSn => x => selfSn(x, 2)), + 'SparseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // sparse + sparse + return matAlgo06xS0S0(x, y, self); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }), + 'DenseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // dense + sparse + return matAlgo01xDSid(x, y, self, false); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }), + 'Array, SparseMatrix': typed.referTo('DenseMatrix,SparseMatrix', selfDS => (x, y) => selfDS(matrix(x), y)), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // sparse - scalar + return matAlgo11xS0s(y, x, self, true); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }) + }, matrixAlgorithmSuite({ + scalar: 'number | BigNumber', + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: false + })); + + /** + * Calculate the nth root of a for BigNumbers, solve x^root == a + * https://rosettacode.org/wiki/Nth_root#JavaScript + * @param {BigNumber} a + * @param {BigNumber} root + * @private + */ + function _bigNthRoot(a, root) { + const precision = BigNumber.precision; + const Big = BigNumber.clone({ + precision: precision + 2 + }); + const zero = new BigNumber(0); + const one = new Big(1); + const inv = root.isNegative(); + if (inv) { + root = root.neg(); + } + if (root.isZero()) { + throw new Error('Root must be non-zero'); + } + if (a.isNegative() && !root.abs().mod(2).equals(1)) { + throw new Error('Root must be odd when a is negative.'); + } + + // edge cases zero and infinity + if (a.isZero()) { + return inv ? new Big(Infinity) : 0; + } + if (!a.isFinite()) { + return inv ? zero : a; + } + let x = a.abs().pow(one.div(root)); + // If a < 0, we require that root is an odd integer, + // so (-1) ^ (1/root) = -1 + x = a.isNeg() ? x.neg() : x; + return new BigNumber((inv ? one.div(x) : x).toPrecision(precision)); + } +}); +const createNthRootNumber = exports.createNthRootNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed'], _ref2 => { + let { + typed + } = _ref2; + return typed(name, { + number: _index.nthRootNumber, + 'number, number': _index.nthRootNumber + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoots.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoots.js new file mode 100644 index 0000000..0718e93 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/nthRoots.js @@ -0,0 +1,117 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNthRoots = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'nthRoots'; +const dependencies = ['config', 'typed', 'divideScalar', 'Complex']; +const createNthRoots = exports.createNthRoots = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + divideScalar, + Complex + } = _ref; + /** + * Each function here returns a real multiple of i as a Complex value. + * @param {number} val + * @return {Complex} val, i*val, -val or -i*val for index 0, 1, 2, 3 + */ + // This is used to fix float artifacts for zero-valued components. + const _calculateExactResult = [function realPos(val) { + return new Complex(val, 0); + }, function imagPos(val) { + return new Complex(0, val); + }, function realNeg(val) { + return new Complex(-val, 0); + }, function imagNeg(val) { + return new Complex(0, -val); + }]; + + /** + * Calculate the nth root of a Complex Number a using De Movire's Theorem. + * @param {Complex} a + * @param {number} root + * @return {Array} array of n Complex Roots + */ + function _nthComplexRoots(a, root) { + if (root < 0) throw new Error('Root must be greater than zero'); + if (root === 0) throw new Error('Root must be non-zero'); + if (root % 1 !== 0) throw new Error('Root must be an integer'); + if (a === 0 || a.abs() === 0) return [new Complex(0, 0)]; + const aIsNumeric = typeof a === 'number'; + let offset; + // determine the offset (argument of a)/(pi/2) + if (aIsNumeric || a.re === 0 || a.im === 0) { + if (aIsNumeric) { + offset = 2 * +(a < 0); // numeric value on the real axis + } else if (a.im === 0) { + offset = 2 * +(a.re < 0); // complex value on the real axis + } else { + offset = 2 * +(a.im < 0) + 1; // complex value on the imaginary axis + } + } + const arg = a.arg(); + const abs = a.abs(); + const roots = []; + const r = Math.pow(abs, 1 / root); + for (let k = 0; k < root; k++) { + const halfPiFactor = (offset + 4 * k) / root; + /** + * If (offset + 4*k)/root is an integral multiple of pi/2 + * then we can produce a more exact result. + */ + if (halfPiFactor === Math.round(halfPiFactor)) { + roots.push(_calculateExactResult[halfPiFactor % 4](r)); + continue; + } + roots.push(new Complex({ + r, + phi: (arg + 2 * Math.PI * k) / root + })); + } + return roots; + } + + /** + * Calculate the nth roots of a value. + * An nth root of a positive real number A, + * is a positive real solution of the equation "x^root = A". + * This function returns an array of complex values. + * + * Syntax: + * + * math.nthRoots(x) + * math.nthRoots(x, root) + * + * Examples: + * + * math.nthRoots(1) + * // returns [ + * // {re: 1, im: 0}, + * // {re: -1, im: 0} + * // ] + * math.nthRoots(1, 3) + * // returns [ + * // { re: 1, im: 0 }, + * // { re: -0.4999999999999998, im: 0.8660254037844387 }, + * // { re: -0.5000000000000004, im: -0.8660254037844385 } + * // ] + * + * See also: + * + * nthRoot, pow, sqrt + * + * @param {number | BigNumber | Fraction | Complex} x Number to be rounded + * @param {number} [root=2] Optional root, default value is 2 + * @return {number | BigNumber | Fraction | Complex} Returns the nth roots + */ + return typed(name, { + Complex: function (x) { + return _nthComplexRoots(x, 2); + }, + 'Complex, number': _nthComplexRoots + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/pow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/pow.js new file mode 100644 index 0000000..f04c7fd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/pow.js @@ -0,0 +1,198 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPow = void 0; +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _array = require("../../utils/array.js"); +var _index = require("../../plain/number/index.js"); +const name = 'pow'; +const dependencies = ['typed', 'config', 'identity', 'multiply', 'matrix', 'inv', 'fraction', 'number', 'Complex']; +const createPow = exports.createPow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + identity, + multiply, + matrix, + inv, + number, + fraction, + Complex + } = _ref; + /** + * Calculates the power of x to y, `x ^ y`. + * + * Matrix exponentiation is supported for square matrices `x` and integers `y`: + * when `y` is nonnegative, `x` may be any square matrix; and when `y` is + * negative, `x` must be invertible, and then this function returns + * inv(x)^(-y). + * + * For cubic roots of negative numbers, the function returns the principal + * root by default. In order to let the function return the real root, + * math.js can be configured with `math.config({predictable: true})`. + * To retrieve all cubic roots of a value, use `math.cbrt(x, true)`. + * + * Syntax: + * + * math.pow(x, y) + * + * Examples: + * + * math.pow(2, 3) // returns number 8 + * + * const a = math.complex(2, 3) + * math.pow(a, 2) // returns Complex -5 + 12i + * + * const b = [[1, 2], [4, 3]] + * math.pow(b, 2) // returns Array [[9, 8], [16, 17]] + * + * const c = [[1, 2], [4, 3]] + * math.pow(c, -1) // returns Array [[-0.6, 0.4], [0.8, -0.2]] + * + * See also: + * + * multiply, sqrt, cbrt, nthRoot + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x The base + * @param {number | BigNumber | bigint | Complex} y The exponent + * @return {number | BigNumber | bigint | Complex | Array | Matrix} The value of `x` to the power `y` + */ + return typed(name, { + 'number, number': _pow, + 'Complex, Complex': function (x, y) { + return x.pow(y); + }, + 'BigNumber, BigNumber': function (x, y) { + if (y.isInteger() || x >= 0 || config.predictable) { + return x.pow(y); + } else { + return new Complex(x.toNumber(), 0).pow(y.toNumber(), 0); + } + }, + 'bigint, bigint': (x, y) => x ** y, + 'Fraction, Fraction': function (x, y) { + const result = x.pow(y); + if (result != null) { + return result; + } + if (config.predictable) { + throw new Error('Result of pow is non-rational and cannot be expressed as a fraction'); + } else { + return _pow(x.valueOf(), y.valueOf()); + } + }, + 'Array, number': _powArray, + 'Array, BigNumber': function (x, y) { + return _powArray(x, y.toNumber()); + }, + 'Matrix, number': _powMatrix, + 'Matrix, BigNumber': function (x, y) { + return _powMatrix(x, y.toNumber()); + }, + 'Unit, number | BigNumber': function (x, y) { + return x.pow(y); + } + }); + + /** + * Calculates the power of x to y, x^y, for two numbers. + * @param {number} x + * @param {number} y + * @return {number | Complex} res + * @private + */ + function _pow(x, y) { + // Alternatively could define a 'realmode' config option or something, but + // 'predictable' will work for now + if (config.predictable && !(0, _number.isInteger)(y) && x < 0) { + // Check to see if y can be represented as a fraction + try { + const yFrac = fraction(y); + const yNum = number(yFrac); + if (y === yNum || Math.abs((y - yNum) / y) < 1e-14) { + if (yFrac.d % 2 === 1) { + return (yFrac.n % 2 === 0 ? 1 : -1) * Math.pow(-x, y); + } + } + } catch (ex) { + // fraction() throws an error if y is Infinity, etc. + } + + // Unable to express y as a fraction, so continue on + } + + // **for predictable mode** x^Infinity === NaN if x < -1 + // N.B. this behavour is different from `Math.pow` which gives + // (-2)^Infinity === Infinity + if (config.predictable && (x < -1 && y === Infinity || x > -1 && x < 0 && y === -Infinity)) { + return NaN; + } + if ((0, _number.isInteger)(y) || x >= 0 || config.predictable) { + return (0, _index.powNumber)(x, y); + } else { + // TODO: the following infinity checks are duplicated from powNumber. Deduplicate this somehow + + // x^Infinity === 0 if -1 < x < 1 + // A real number 0 is returned instead of complex(0) + if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) { + return 0; + } + return new Complex(x, 0).pow(y, 0); + } + } + + /** + * Calculate the power of a 2d array + * @param {Array} x must be a 2 dimensional, square matrix + * @param {number} y a integer value (positive if `x` is not invertible) + * @returns {Array} + * @private + */ + function _powArray(x, y) { + if (!(0, _number.isInteger)(y)) { + throw new TypeError('For A^b, b must be an integer (value is ' + y + ')'); + } + // verify that A is a 2 dimensional square matrix + const s = (0, _array.arraySize)(x); + if (s.length !== 2) { + throw new Error('For A^b, A must be 2 dimensional (A has ' + s.length + ' dimensions)'); + } + if (s[0] !== s[1]) { + throw new Error('For A^b, A must be square (size is ' + s[0] + 'x' + s[1] + ')'); + } + if (y < 0) { + try { + return _powArray(inv(x), -y); + } catch (error) { + if (error.message === 'Cannot calculate inverse, determinant is zero') { + throw new TypeError('For A^b, when A is not invertible, b must be a positive integer (value is ' + y + ')'); + } + throw error; + } + } + let res = identity(s[0]).valueOf(); + let px = x; + while (y >= 1) { + if ((y & 1) === 1) { + res = multiply(px, res); + } + y >>= 1; + px = multiply(px, px); + } + return res; + } + + /** + * Calculate the power of a 2d matrix + * @param {Matrix} x must be a 2 dimensional, square matrix + * @param {number} y a positive, integer value + * @returns {Matrix} + * @private + */ + function _powMatrix(x, y) { + return matrix(_powArray(x.valueOf(), y)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/round.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/round.js new file mode 100644 index 0000000..b9caf45 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/round.js @@ -0,0 +1,208 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRound = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +var _index = require("../../plain/number/index.js"); +const NO_INT = 'Number of decimals in function round must be an integer'; +const name = 'round'; +const dependencies = ['typed', 'config', 'matrix', 'equalScalar', 'zeros', 'BigNumber', 'DenseMatrix']; +const createRound = exports.createRound = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + equalScalar, + zeros, + BigNumber, + DenseMatrix + } = _ref; + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + function toExponent(epsilon) { + return Math.abs((0, _number.splitNumber)(epsilon).exponent); + } + + /** + * Round a value towards the nearest rounded value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.round(x) + * math.round(x, n) + * math.round(unit, valuelessUnit) + * math.round(unit, n, valuelessUnit) + * + * Examples: + * + * math.round(3.22) // returns number 3 + * math.round(3.82) // returns number 4 + * math.round(-4.2) // returns number -4 + * math.round(-4.7) // returns number -5 + * math.round(3.22, 1) // returns number 3.2 + * math.round(3.88, 1) // returns number 3.9 + * math.round(-4.21, 1) // returns number -4.2 + * math.round(-4.71, 1) // returns number -4.7 + * math.round(math.pi, 3) // returns number 3.142 + * math.round(123.45678, 2) // returns number 123.46 + * + * const c = math.complex(3.2, -2.7) + * math.round(c) // returns Complex 3 - 3i + * + * const unit = math.unit('3.241 cm') + * const cm = math.unit('cm') + * const mm = math.unit('mm') + * math.round(unit, 1, cm) // returns Unit 3.2 cm + * math.round(unit, 1, mm) // returns Unit 32.4 mm + * + * math.round([3.2, 3.8, -4.7]) // returns Array [3, 4, -5] + * + * See also: + * + * ceil, fix, floor + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Value to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @param {Unit} [valuelessUnit] A valueless unit + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed(name, { + number: function (x) { + // Handle round off errors by first rounding to relTol precision + const xEpsilon = (0, _index.roundNumber)(x, toExponent(config.relTol)); + const xSelected = (0, _number.nearlyEqual)(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return (0, _index.roundNumber)(xSelected); + }, + 'number, number': function (x, n) { + // Same as number: unless user specifies more decimals than relTol + const epsilonExponent = toExponent(config.relTol); + if (n >= epsilonExponent) { + return (0, _index.roundNumber)(x, n); + } + const xEpsilon = (0, _index.roundNumber)(x, epsilonExponent); + const xSelected = (0, _number.nearlyEqual)(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return (0, _index.roundNumber)(xSelected, n); + }, + 'number, BigNumber': function (x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + return new BigNumber(x).toDecimalPlaces(n.toNumber()); + }, + Complex: function (x) { + return x.round(); + }, + 'Complex, number': function (x, n) { + if (n % 1) { + throw new TypeError(NO_INT); + } + return x.round(n); + }, + 'Complex, BigNumber': function (x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + const _n = n.toNumber(); + return x.round(_n); + }, + BigNumber: function (x) { + // Handle round off errors by first rounding to relTol precision + const xEpsilon = new BigNumber(x).toDecimalPlaces(toExponent(config.relTol)); + const xSelected = (0, _nearlyEqual.nearlyEqual)(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return xSelected.toDecimalPlaces(0); + }, + 'BigNumber, BigNumber': function (x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + + // Same as BigNumber: unless user specifies more decimals than relTol + const epsilonExponent = toExponent(config.relTol); + if (n >= epsilonExponent) { + return x.toDecimalPlaces(n.toNumber()); + } + const xEpsilon = x.toDecimalPlaces(epsilonExponent); + const xSelected = (0, _nearlyEqual.nearlyEqual)(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return xSelected.toDecimalPlaces(n.toNumber()); + }, + Fraction: function (x) { + return x.round(); + }, + 'Fraction, number': function (x, n) { + if (n % 1) { + throw new TypeError(NO_INT); + } + return x.round(n); + }, + 'Fraction, BigNumber': function (x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + return x.round(n.toNumber()); + }, + 'Unit, number, Unit': typed.referToSelf(self => function (x, n, unit) { + const valueless = x.toNumeric(unit); + return unit.multiply(self(valueless, n)); + }), + 'Unit, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)), + 'Unit, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)), + 'Array | Matrix, number, Unit': typed.referToSelf(self => (x, n, unit) => { + // deep map collection, skip zeros since round(0) = 0 + return (0, _collection.deepMap)(x, value => self(value, n, unit), true); + }), + 'Array | Matrix, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)), + 'Array | Matrix, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)), + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since round(0) = 0 + return (0, _collection.deepMap)(x, self, true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + return matAlgo11xS0s(x, n, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + return matAlgo14xDs(x, n, self, false); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // use matrix implementation + return matAlgo14xDs(matrix(x), n, self, false).valueOf(); + }), + 'number | Complex | BigNumber | Fraction, SparseMatrix': typed.referToSelf(self => (x, n) => { + // check scalar is zero + if (equalScalar(x, 0)) { + // do not execute algorithm, result will be a zero matrix + return zeros(n.size(), n.storage()); + } + return matAlgo12xSfs(n, x, self, true); + }), + 'number | Complex | BigNumber | Fraction, DenseMatrix': typed.referToSelf(self => (x, n) => { + // check scalar is zero + if (equalScalar(x, 0)) { + // do not execute algorithm, result will be a zero matrix + return zeros(n.size(), n.storage()); + } + return matAlgo14xDs(n, x, self, true); + }), + 'number | Complex | BigNumber | Fraction, Array': typed.referToSelf(self => (x, n) => { + // use matrix implementation + return matAlgo14xDs(matrix(n), x, self, true).valueOf(); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sign.js new file mode 100644 index 0000000..4347b3d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sign.js @@ -0,0 +1,72 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSign = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +const name = 'sign'; +const dependencies = ['typed', 'BigNumber', 'Fraction', 'complex']; +const createSign = exports.createSign = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber, + complex, + Fraction + } = _ref; + /** + * Compute the sign of a value. The sign of a value x is: + * + * - 1 when x > 0 + * - -1 when x < 0 + * - 0 when x == 0 + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.sign(x) + * + * Examples: + * + * math.sign(3.5) // returns 1 + * math.sign(-4.2) // returns -1 + * math.sign(0) // returns 0 + * + * math.sign([3, 5, -2, 0, 2]) // returns [1, 1, -1, 0, 1] + * + * See also: + * + * abs + * + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x + * The number for which to determine the sign + * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} + * The sign of `x` + */ + return typed(name, { + number: _index.signNumber, + Complex: function (x) { + return x.im === 0 ? complex((0, _index.signNumber)(x.re)) : x.sign(); + }, + BigNumber: function (x) { + return new BigNumber(x.cmp(0)); + }, + bigint: function (x) { + return x > 0n ? 1n : x < 0n ? -1n : 0n; + }, + Fraction: function (x) { + return new Fraction(x.s, 1); + }, + // deep map collection, skip zeros since sign(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self, true)), + Unit: typed.referToSelf(self => x => { + if (!x._isDerived() && x.units[0].unit.offset !== 0) { + throw new TypeError('sign is ambiguous for units with offset'); + } + return typed.find(self, x.valueType())(x.value); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sqrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sqrt.js new file mode 100644 index 0000000..d0a159b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/sqrt.js @@ -0,0 +1,76 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSqrt = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'sqrt'; +const dependencies = ['config', 'typed', 'Complex']; +const createSqrt = exports.createSqrt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + typed, + Complex + } = _ref; + /** + * Calculate the square root of a value. + * + * For matrices, if you want the matrix square root of a square matrix, + * use the `sqrtm` function. If you wish to apply `sqrt` elementwise to + * a matrix M, use `math.map(M, math.sqrt)`. + * + * Syntax: + * + * math.sqrt(x) + * + * Examples: + * + * math.sqrt(25) // returns 5 + * math.square(5) // returns 25 + * math.sqrt(-4) // returns Complex 2i + * + * See also: + * + * square, multiply, cube, cbrt, sqrtm + * + * @param {number | BigNumber | Complex | Unit} x + * Value for which to calculate the square root. + * @return {number | BigNumber | Complex | Unit} + * Returns the square root of `x` + */ + return typed('sqrt', { + number: _sqrtNumber, + Complex: function (x) { + return x.sqrt(); + }, + BigNumber: function (x) { + if (!x.isNegative() || config.predictable) { + return x.sqrt(); + } else { + // negative value -> downgrade to number to do complex value computation + return _sqrtNumber(x.toNumber()); + } + }, + Unit: function (x) { + // Someday will work for complex units when they are implemented + return x.pow(0.5); + } + }); + + /** + * Calculate sqrt for a number + * @param {number} x + * @returns {number | Complex} Returns the square root of x + * @private + */ + function _sqrtNumber(x) { + if (isNaN(x)) { + return NaN; + } else if (x >= 0 || config.predictable) { + return Math.sqrt(x); + } else { + return new Complex(x, 0).sqrt(); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/square.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/square.js new file mode 100644 index 0000000..279334d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/square.js @@ -0,0 +1,61 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSquare = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'square'; +const dependencies = ['typed']; +const createSquare = exports.createSquare = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the square of a value, `x * x`. + * To avoid confusion with multiplying a square matrix by itself, + * this function does not apply to matrices. If you wish to square + * every element of a matrix, see the examples. + * + * Syntax: + * + * math.square(x) + * + * Examples: + * + * math.square(2) // returns number 4 + * math.square(3) // returns number 9 + * math.pow(3, 2) // returns number 9 + * math.multiply(3, 3) // returns number 9 + * + * math.map([1, 2, 3, 4], math.square) // returns Array [1, 4, 9, 16] + * + * See also: + * + * multiply, cube, sqrt, pow + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x + * Number for which to calculate the square + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} + * Squared value + */ + return typed(name, { + number: _index.squareNumber, + Complex: function (x) { + return x.mul(x); + }, + BigNumber: function (x) { + return x.times(x); + }, + bigint: function (x) { + return x * x; + }, + Fraction: function (x) { + return x.mul(x); + }, + Unit: function (x) { + return x.pow(2); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtract.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtract.js new file mode 100644 index 0000000..ebd04a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtract.js @@ -0,0 +1,92 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSubtract = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo05xSfSf = require("../../type/matrix/utils/matAlgo05xSfSf.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'subtract'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'subtractScalar', 'unaryMinus', 'DenseMatrix', 'concat']; +const createSubtract = exports.createSubtract = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + subtractScalar, + unaryMinus, + DenseMatrix, + concat + } = _ref; + // TODO: split function subtract in two: subtract and subtractScalar + + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo05xSfSf = (0, _matAlgo05xSfSf.createMatAlgo05xSfSf)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Subtract two values, `x - y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.subtract(x, y) + * + * Examples: + * + * math.subtract(5.3, 2) // returns number 3.3 + * + * const a = math.complex(2, 3) + * const b = math.complex(4, 1) + * math.subtract(a, b) // returns Complex -2 + 2i + * + * math.subtract([5, 7, 4], 4) // returns Array [1, 3, 0] + * + * const c = math.unit('2.1 km') + * const d = math.unit('500m') + * math.subtract(c, d) // returns Unit 1.6 km + * + * See also: + * + * add + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Initial value + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Value to subtract from `x` + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Subtraction of `x` and `y` + */ + return typed(name, { + 'any, any': subtractScalar + }, matrixAlgorithmSuite({ + elop: subtractScalar, + SS: matAlgo05xSfSf, + DS: matAlgo01xDSid, + SD: matAlgo03xDSf, + Ss: matAlgo12xSfs, + sS: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtractScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtractScalar.js new file mode 100644 index 0000000..6a2da88 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/subtractScalar.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSubtractScalar = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'subtractScalar'; +const dependencies = ['typed']; +const createSubtractScalar = exports.createSubtractScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Subtract two scalar values, `x - y`. + * This function is meant for internal use: it is used by the public function + * `subtract` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to be subtracted from `x` + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Difference of `x` and `y` + * @private + */ + return typed(name, { + 'number, number': _index.subtractNumber, + 'Complex, Complex': function (x, y) { + return x.sub(y); + }, + 'BigNumber, BigNumber': function (x, y) { + return x.minus(y); + }, + 'bigint, bigint': function (x, y) { + return x - y; + }, + 'Fraction, Fraction': function (x, y) { + return x.sub(y); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (x.value === null || x.value === undefined) { + throw new Error('Parameter x contains a unit with undefined value'); + } + if (y.value === null || y.value === undefined) { + throw new Error('Parameter y contains a unit with undefined value'); + } + if (!x.equalBase(y)) throw new Error('Units do not match'); + const res = x.clone(); + res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value); + res.fixPrefix = false; + return res; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryMinus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryMinus.js new file mode 100644 index 0000000..34844db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryMinus.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnaryMinus = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +const name = 'unaryMinus'; +const dependencies = ['typed']; +const createUnaryMinus = exports.createUnaryMinus = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Inverse the sign of a value, apply a unary minus operation. + * + * For matrices, the function is evaluated element wise. Boolean values and + * strings will be converted to a number. For complex numbers, both real and + * complex value are inverted. + * + * Syntax: + * + * math.unaryMinus(x) + * + * Examples: + * + * math.unaryMinus(3.5) // returns -3.5 + * math.unaryMinus(-4.2) // returns 4.2 + * + * See also: + * + * add, subtract, unaryPlus + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Number to be inverted. + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Returns the value with inverted sign. + */ + return typed(name, { + number: _index.unaryMinusNumber, + 'Complex | BigNumber | Fraction': x => x.neg(), + bigint: x => -x, + Unit: typed.referToSelf(self => x => { + const res = x.clone(); + res.value = typed.find(self, res.valueType())(x.value); + return res; + }), + // deep map collection, skip zeros since unaryMinus(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self, true)) + + // TODO: add support for string + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryPlus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryPlus.js new file mode 100644 index 0000000..af6da31 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/unaryPlus.js @@ -0,0 +1,69 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnaryPlus = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +var _index = require("../../plain/number/index.js"); +var _number = require("../../utils/number.js"); +const name = 'unaryPlus'; +const dependencies = ['typed', 'config', 'numeric']; +const createUnaryPlus = exports.createUnaryPlus = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + numeric + } = _ref; + /** + * Unary plus operation. + * Boolean values and strings will be converted to a number, numeric values will be returned as is. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.unaryPlus(x) + * + * Examples: + * + * math.unaryPlus(3.5) // returns 3.5 + * math.unaryPlus(1) // returns 1 + * + * See also: + * + * unaryMinus, add, subtract + * + * @param {number | BigNumber | bigint | Fraction | string | Complex | Unit | Array | Matrix} x + * Input value + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} + * Returns the input value when numeric, converts to a number when input is non-numeric. + */ + return typed(name, { + number: _index.unaryPlusNumber, + Complex: function (x) { + return x; // complex numbers are immutable + }, + BigNumber: function (x) { + return x; // bignumbers are immutable + }, + bigint: function (x) { + return x; + }, + Fraction: function (x) { + return x; // fractions are immutable + }, + Unit: function (x) { + return x.clone(); + }, + // deep map collection, skip zeros since unaryPlus(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self, true)), + boolean: function (x) { + return numeric(x ? 1 : 0, config.number); + }, + string: function (x) { + return numeric(x, (0, _number.safeNumberType)(x, config)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/xgcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/xgcd.js new file mode 100644 index 0000000..e79cd9f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/arithmetic/xgcd.js @@ -0,0 +1,97 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createXgcd = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'xgcd'; +const dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +const createXgcd = exports.createXgcd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Calculate the extended greatest common divisor for two values. + * See https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm. + * + * Syntax: + * + * math.xgcd(a, b) + * + * Examples: + * + * math.xgcd(8, 12) // returns [4, -1, 1] + * math.gcd(8, 12) // returns 4 + * math.xgcd(36163, 21199) // returns [1247, -7, 12] + * + * See also: + * + * gcd, lcm + * + * @param {number | BigNumber} a An integer number + * @param {number | BigNumber} b An integer number + * @return {Array} Returns an array containing 3 integers `[div, m, n]` + * where `div = gcd(a, b)` and `a*m + b*n = div` + */ + return typed(name, { + 'number, number': function (a, b) { + const res = (0, _index.xgcdNumber)(a, b); + return config.matrix === 'Array' ? res : matrix(res); + }, + 'BigNumber, BigNumber': _xgcdBigNumber + // TODO: implement support for Fraction + }); + + /** + * Calculate xgcd for two BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @return {BigNumber[]} result + * @private + */ + function _xgcdBigNumber(a, b) { + // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm + let + // used to swap two variables + t; + let + // quotient + q; + let + // remainder + r; + const zero = new BigNumber(0); + const one = new BigNumber(1); + let x = zero; + let lastx = one; + let y = one; + let lasty = zero; + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function xgcd must be integer numbers'); + } + while (!b.isZero()) { + q = a.div(b).floor(); + r = a.mod(b); + t = x; + x = lastx.minus(q.times(x)); + lastx = t; + t = y; + y = lasty.minus(q.times(y)); + lasty = t; + a = b; + b = r; + } + let res; + if (a.lt(zero)) { + res = [a.neg(), lastx.neg(), lasty.neg()]; + } else { + res = [a, !a.isZero() ? lastx : 0, lasty]; + } + return config.matrix === 'Array' ? res : matrix(res); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitAnd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitAnd.js new file mode 100644 index 0000000..9d419ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitAnd.js @@ -0,0 +1,72 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitAnd = void 0; +var _bitwise = require("../../utils/bignumber/bitwise.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo06xS0S = require("../../type/matrix/utils/matAlgo06xS0S0.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'bitAnd'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'concat']; +const createBitAnd = exports.createBitAnd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo06xS0S0 = (0, _matAlgo06xS0S.createMatAlgo06xS0S0)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Bitwise AND two values, `x & y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.bitAnd(x, y) + * + * Examples: + * + * math.bitAnd(53, 131) // returns number 1 + * + * math.bitAnd([1, 12, 31], 42) // returns Array [0, 8, 10] + * + * See also: + * + * bitNot, bitOr, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to and + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to and + * @return {number | BigNumber | bigint | Array | Matrix} AND of `x` and `y` + */ + return typed(name, { + 'number, number': _index.bitAndNumber, + 'BigNumber, BigNumber': _bitwise.bitAndBigNumber, + 'bigint, bigint': (x, y) => x & y + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitNot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitNot.js new file mode 100644 index 0000000..98aa3e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitNot.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitNot = void 0; +var _bitwise = require("../../utils/bignumber/bitwise.js"); +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'bitNot'; +const dependencies = ['typed']; +const createBitNot = exports.createBitNot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Bitwise NOT value, `~x`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.bitNot(x) + * + * Examples: + * + * math.bitNot(1) // returns number -2 + * + * math.bitNot([2, -3, 4]) // returns Array [-3, 2, -5] + * + * See also: + * + * bitAnd, bitOr, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to not + * @return {number | BigNumber | bigint | Array | Matrix} NOT of `x` + */ + return typed(name, { + number: _index.bitNotNumber, + BigNumber: _bitwise.bitNotBigNumber, + bigint: x => ~x, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitOr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitOr.js new file mode 100644 index 0000000..f269ec2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitOr.js @@ -0,0 +1,73 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitOr = void 0; +var _bitwise = require("../../utils/bignumber/bitwise.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matAlgo04xSidSid = require("../../type/matrix/utils/matAlgo04xSidSid.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'bitOr'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +const createBitOr = exports.createBitOr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo04xSidSid = (0, _matAlgo04xSidSid.createMatAlgo04xSidSid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Bitwise OR two values, `x | y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the lowest print base. + * + * Syntax: + * + * math.bitOr(x, y) + * + * Examples: + * + * math.bitOr(1, 2) // returns number 3 + * + * math.bitOr([1, 2, 3], 4) // returns Array [5, 6, 7] + * + * See also: + * + * bitAnd, bitNot, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to or + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to or + * @return {number | BigNumber | bigint | Array | Matrix} OR of `x` and `y` + */ + return typed(name, { + 'number, number': _index.bitOrNumber, + 'BigNumber, BigNumber': _bitwise.bitOrBigNumber, + 'bigint, bigint': (x, y) => x | y + }, matrixAlgorithmSuite({ + SS: matAlgo04xSidSid, + DS: matAlgo01xDSid, + Ss: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitXor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitXor.js new file mode 100644 index 0000000..94f78b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/bitXor.js @@ -0,0 +1,71 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBitXor = void 0; +var _bitwise = require("../../utils/bignumber/bitwise.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'bitXor'; +const dependencies = ['typed', 'matrix', 'DenseMatrix', 'concat']; +const createBitXor = exports.createBitXor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Bitwise XOR two values, `x ^ y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.bitXor(x, y) + * + * Examples: + * + * math.bitXor(1, 2) // returns number 3 + * + * math.bitXor([2, 3, 4], 4) // returns Array [6, 7, 0] + * + * See also: + * + * bitAnd, bitNot, bitOr, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to xor + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to xor + * @return {number | BigNumber | bigint | Array | Matrix} XOR of `x` and `y` + */ + return typed(name, { + 'number, number': _index.bitXorNumber, + 'BigNumber, BigNumber': _bitwise.bitXor, + 'bigint, bigint': (x, y) => x ^ y + }, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/leftShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/leftShift.js new file mode 100644 index 0000000..e686e6e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/leftShift.js @@ -0,0 +1,121 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLeftShift = void 0; +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matAlgo08xS0Sid = require("../../type/matrix/utils/matAlgo08xS0Sid.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _useMatrixForArrayScalar = require("./useMatrixForArrayScalar.js"); +var _index = require("../../plain/number/index.js"); +var _bitwise = require("../../utils/bignumber/bitwise.js"); +const name = 'leftShift'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +const createLeftShift = exports.createLeftShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo08xS0Sid = (0, _matAlgo08xS0Sid.createMatAlgo08xS0Sid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const useMatrixForArrayScalar = (0, _useMatrixForArrayScalar.createUseMatrixForArrayScalar)({ + typed, + matrix + }); + + /** + * Bitwise left logical shift of a value x by y number of bits, `x << y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.leftShift(x, y) + * + * Examples: + * + * math.leftShift(1, 2) // returns number 4 + * + * math.leftShift([1, 2, 4], 4) // returns Array [16, 32, 64] + * + * See also: + * + * leftShift, bitNot, bitOr, bitXor, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted + * @param {number | BigNumber | bigint} y Amount of shifts + * @return {number | BigNumber | bigint | Array | Matrix} `x` shifted left `y` times + */ + return typed(name, { + 'number, number': _index.leftShiftNumber, + 'BigNumber, BigNumber': _bitwise.leftShiftBigNumber, + 'bigint, bigint': (x, y) => x << y, + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightArithShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightArithShift.js new file mode 100644 index 0000000..2c2af03 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightArithShift.js @@ -0,0 +1,121 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRightArithShift = void 0; +var _bitwise = require("../../utils/bignumber/bitwise.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matAlgo08xS0Sid = require("../../type/matrix/utils/matAlgo08xS0Sid.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _useMatrixForArrayScalar = require("./useMatrixForArrayScalar.js"); +var _index = require("../../plain/number/index.js"); +const name = 'rightArithShift'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +const createRightArithShift = exports.createRightArithShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo08xS0Sid = (0, _matAlgo08xS0Sid.createMatAlgo08xS0Sid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const useMatrixForArrayScalar = (0, _useMatrixForArrayScalar.createUseMatrixForArrayScalar)({ + typed, + matrix + }); + + /** + * Bitwise right arithmetic shift of a value x by y number of bits, `x >> y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.rightArithShift(x, y) + * + * Examples: + * + * math.rightArithShift(4, 2) // returns number 1 + * + * math.rightArithShift([16, -32, 64], 4) // returns Array [1, -2, 4] + * + * See also: + * + * bitAnd, bitNot, bitOr, bitXor, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted + * @param {number | BigNumber | bigint} y Amount of shifts + * @return {number | BigNumber | bigint | Array | Matrix} `x` zero-filled shifted right `y` times + */ + return typed(name, { + 'number, number': _index.rightArithShiftNumber, + 'BigNumber, BigNumber': _bitwise.rightArithShiftBigNumber, + 'bigint, bigint': (x, y) => x >> y, + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightLogShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightLogShift.js new file mode 100644 index 0000000..e35c2cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/rightLogShift.js @@ -0,0 +1,121 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRightLogShift = void 0; +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +var _matAlgo01xDSid = require("../../type/matrix/utils/matAlgo01xDSid.js"); +var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js"); +var _matAlgo08xS0Sid = require("../../type/matrix/utils/matAlgo08xS0Sid.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +var _useMatrixForArrayScalar = require("./useMatrixForArrayScalar.js"); +const name = 'rightLogShift'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +const createRightLogShift = exports.createRightLogShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + const matAlgo01xDSid = (0, _matAlgo01xDSid.createMatAlgo01xDSid)({ + typed + }); + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo08xS0Sid = (0, _matAlgo08xS0Sid.createMatAlgo08xS0Sid)({ + typed, + equalScalar + }); + const matAlgo10xSids = (0, _matAlgo10xSids.createMatAlgo10xSids)({ + typed, + DenseMatrix + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const useMatrixForArrayScalar = (0, _useMatrixForArrayScalar.createUseMatrixForArrayScalar)({ + typed, + matrix + }); + + /** + * Bitwise right logical shift of value x by y number of bits, `x >>> y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.rightLogShift(x, y) + * + * Examples: + * + * math.rightLogShift(4, 2) // returns number 1 + * + * math.rightLogShift([16, 32, 64], 4) // returns Array [1, 2, 4] + * + * See also: + * + * bitAnd, bitNot, bitOr, bitXor, leftShift, rightLogShift + * + * @param {number | Array | Matrix} x Value to be shifted + * @param {number} y Amount of shifts + * @return {number | Array | Matrix} `x` zero-filled shifted right `y` times + */ + + return typed(name, { + 'number, number': _index.rightLogShiftNumber, + // 'BigNumber, BigNumber': ..., // TODO: implement BigNumber support for rightLogShift + + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/useMatrixForArrayScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/useMatrixForArrayScalar.js new file mode 100644 index 0000000..8b1a863 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/bitwise/useMatrixForArrayScalar.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUseMatrixForArrayScalar = void 0; +var _factory = require("../../utils/factory.js"); +const createUseMatrixForArrayScalar = exports.createUseMatrixForArrayScalar = /* #__PURE__ */(0, _factory.factory)('useMatrixForArrayScalar', ['typed', 'matrix'], _ref => { + let { + typed, + matrix + } = _ref; + return { + 'Array, number': typed.referTo('DenseMatrix, number', selfDn => (x, y) => selfDn(matrix(x), y).valueOf()), + 'Array, BigNumber': typed.referTo('DenseMatrix, BigNumber', selfDB => (x, y) => selfDB(matrix(x), y).valueOf()), + 'number, Array': typed.referTo('number, DenseMatrix', selfnD => (x, y) => selfnD(x, matrix(y)).valueOf()), + 'BigNumber, Array': typed.referTo('BigNumber, DenseMatrix', selfBD => (x, y) => selfBD(x, matrix(y)).valueOf()) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/bellNumbers.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/bellNumbers.js new file mode 100644 index 0000000..1dc1b92 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/bellNumbers.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBellNumbers = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'bellNumbers'; +const dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2']; +const createBellNumbers = exports.createBellNumbers = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + isNegative, + isInteger, + stirlingS2 + } = _ref; + /** + * The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. + * bellNumbers only takes integer arguments. + * The following condition must be enforced: n >= 0 + * + * Syntax: + * + * math.bellNumbers(n) + * + * Examples: + * + * math.bellNumbers(3) // returns 5 + * math.bellNumbers(8) // returns 4140 + * + * See also: + * + * stirlingS2 + * + * @param {Number | BigNumber} n Total number of objects in the set + * @return {Number | BigNumber} B(n) + */ + return typed(name, { + 'number | BigNumber': function (n) { + if (!isInteger(n) || isNegative(n)) { + throw new TypeError('Non-negative integer value expected in function bellNumbers'); + } + + // Sum (k=0, n) S(n,k). + let result = 0; + for (let i = 0; i <= n; i++) { + result = addScalar(result, stirlingS2(n, i)); + } + return result; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/catalan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/catalan.js new file mode 100644 index 0000000..3f4646d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/catalan.js @@ -0,0 +1,49 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCatalan = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'catalan'; +const dependencies = ['typed', 'addScalar', 'divideScalar', 'multiplyScalar', 'combinations', 'isNegative', 'isInteger']; +const createCatalan = exports.createCatalan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + divideScalar, + multiplyScalar, + combinations, + isNegative, + isInteger + } = _ref; + /** + * The Catalan Numbers enumerate combinatorial structures of many different types. + * catalan only takes integer arguments. + * The following condition must be enforced: n >= 0 + * + * Syntax: + * + * math.catalan(n) + * + * Examples: + * + * math.catalan(3) // returns 5 + * math.catalan(8) // returns 1430 + * + * See also: + * + * bellNumbers + * + * @param {Number | BigNumber} n nth Catalan number + * @return {Number | BigNumber} Cn(n) + */ + return typed(name, { + 'number | BigNumber': function (n) { + if (!isInteger(n) || isNegative(n)) { + throw new TypeError('Non-negative integer value expected in function catalan'); + } + return divideScalar(combinations(multiplyScalar(n, 2), n), addScalar(n, 1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/composition.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/composition.js new file mode 100644 index 0000000..f13ca1e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/composition.js @@ -0,0 +1,52 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createComposition = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'composition'; +const dependencies = ['typed', 'addScalar', 'combinations', 'isNegative', 'isPositive', 'isInteger', 'larger']; +const createComposition = exports.createComposition = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + combinations, + isPositive, + isNegative, + isInteger, + larger + } = _ref; + /** + * The composition counts of n into k parts. + * + * composition only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.composition(n, k) + * + * Examples: + * + * math.composition(5, 3) // returns 6 + * + * See also: + * + * combinations + * + * @param {Number | BigNumber} n Total number of objects in the set + * @param {Number | BigNumber} k Number of objects in the subset + * @return {Number | BigNumber} Returns the composition counts of n into k parts. + */ + return typed(name, { + 'number | BigNumber, number | BigNumber': function (n, k) { + if (!isInteger(n) || !isPositive(n) || !isInteger(k) || !isPositive(k)) { + throw new TypeError('Positive integer value expected in function composition'); + } else if (larger(k, n)) { + throw new TypeError('k must be less than or equal to n in function composition'); + } + return combinations(addScalar(n, -1), addScalar(k, -1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/stirlingS2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/stirlingS2.js new file mode 100644 index 0000000..7e7dfcc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/combinatorics/stirlingS2.js @@ -0,0 +1,92 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createStirlingS2 = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'stirlingS2'; +const dependencies = ['typed', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'factorial', 'combinations', 'isNegative', 'isInteger', 'number', '?bignumber', 'larger']; +const createStirlingS2 = exports.createStirlingS2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + pow, + factorial, + combinations, + isNegative, + isInteger, + number, + bignumber, + larger + } = _ref; + const smallCache = []; + const bigCache = []; + /** + * The Stirling numbers of the second kind, counts the number of ways to partition + * a set of n labelled objects into k nonempty unlabelled subsets. + * stirlingS2 only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * If n = k or k = 1 <= n, then s(n,k) = 1 + * If k = 0 < n, then s(n,k) = 0 + * + * Note that if either n or k is supplied as a BigNumber, the result will be + * as well. + * + * Syntax: + * + * math.stirlingS2(n, k) + * + * Examples: + * + * math.stirlingS2(5, 3) //returns 25 + * + * See also: + * + * bellNumbers + * + * @param {Number | BigNumber} n Total number of objects in the set + * @param {Number | BigNumber} k Number of objects in the subset + * @return {Number | BigNumber} S(n,k) + */ + return typed(name, { + 'number | BigNumber, number | BigNumber': function (n, k) { + if (!isInteger(n) || isNegative(n) || !isInteger(k) || isNegative(k)) { + throw new TypeError('Non-negative integer value expected in function stirlingS2'); + } else if (larger(k, n)) { + throw new TypeError('k must be less than or equal to n in function stirlingS2'); + } + const big = !((0, _is.isNumber)(n) && (0, _is.isNumber)(k)); + const cache = big ? bigCache : smallCache; + const make = big ? bignumber : number; + const nn = number(n); + const nk = number(k); + /* See if we already have the value: */ + if (cache[nn] && cache[nn].length > nk) { + return cache[nn][nk]; + } + /* Fill the cache */ + for (let m = 0; m <= nn; ++m) { + if (!cache[m]) { + cache[m] = [m === 0 ? make(1) : make(0)]; + } + if (m === 0) continue; + const row = cache[m]; + const prev = cache[m - 1]; + for (let i = row.length; i <= m && i <= nk; ++i) { + if (i === m) { + row[i] = 1; + } else { + row[i] = addScalar(multiplyScalar(make(i), prev[i]), prev[i - 1]); + } + } + } + return cache[nn][nk]; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/arg.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/arg.js new file mode 100644 index 0000000..21c7f90 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/arg.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createArg = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +const name = 'arg'; +const dependencies = ['typed']; +const createArg = exports.createArg = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the argument of a complex value. + * For a complex number `a + bi`, the argument is computed as `atan2(b, a)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.arg(x) + * + * Examples: + * + * const a = math.complex(2, 2) + * math.arg(a) / math.pi // returns number 0.25 + * + * const b = math.complex('2 + 3i') + * math.arg(b) // returns number 0.982793723247329 + * math.atan2(3, 2) // returns number 0.982793723247329 + * + * See also: + * + * re, im, conj, abs + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The argument of x + */ + return typed(name, { + number: function (x) { + return Math.atan2(0, x); + }, + BigNumber: function (x) { + return x.constructor.atan2(0, x); + }, + Complex: function (x) { + return x.arg(); + }, + // TODO: implement BigNumber support for function arg + + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/conj.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/conj.js new file mode 100644 index 0000000..d1eaf03 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/conj.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createConj = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +const name = 'conj'; +const dependencies = ['typed']; +const createConj = exports.createConj = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the complex conjugate of a complex value. + * If `x = a+bi`, the complex conjugate of `x` is `a - bi`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.conj(x) + * + * Examples: + * + * math.conj(math.complex('2 + 3i')) // returns Complex 2 - 3i + * math.conj(math.complex('2 - 3i')) // returns Complex 2 + 3i + * math.conj(math.complex('-5.2i')) // returns Complex 5.2i + * + * See also: + * + * re, im, arg, abs + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Complex | Array | Matrix} + * The complex conjugate of x + */ + return typed(name, { + 'number | BigNumber | Fraction': x => x, + Complex: x => x.conjugate(), + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/im.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/im.js new file mode 100644 index 0000000..f082801 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/im.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIm = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +const name = 'im'; +const dependencies = ['typed']; +const createIm = exports.createIm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Get the imaginary part of a complex number. + * For a complex number `a + bi`, the function returns `b`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.im(x) + * + * Examples: + * + * const a = math.complex(2, 3) + * math.re(a) // returns number 2 + * math.im(a) // returns number 3 + * + * math.re(math.complex('-5.2i')) // returns number -5.2 + * math.re(math.complex(2.4)) // returns number 0 + * + * See also: + * + * re, conj, abs, arg + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The imaginary part of x + */ + return typed(name, { + number: () => 0, + 'BigNumber | Fraction': x => x.mul(0), + Complex: x => x.im, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/re.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/re.js new file mode 100644 index 0000000..9886d65 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/complex/re.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRe = void 0; +var _factory = require("../../utils/factory.js"); +var _collection = require("../../utils/collection.js"); +const name = 're'; +const dependencies = ['typed']; +const createRe = exports.createRe = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Get the real part of a complex number. + * For a complex number `a + bi`, the function returns `a`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.re(x) + * + * Examples: + * + * const a = math.complex(2, 3) + * math.re(a) // returns number 2 + * math.im(a) // returns number 3 + * + * math.re(math.complex('-5.2i')) // returns number 0 + * math.re(math.complex(2.4)) // returns number 2.4 + * + * See also: + * + * im, conj, abs, arg + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The real part of x + */ + return typed(name, { + 'number | BigNumber | Fraction': x => x, + Complex: x => x.re, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/distance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/distance.js new file mode 100644 index 0000000..792453b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/distance.js @@ -0,0 +1,311 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDistance = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'distance'; +const dependencies = ['typed', 'addScalar', 'subtractScalar', 'divideScalar', 'multiplyScalar', 'deepEqual', 'sqrt', 'abs']; +const createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + deepEqual, + sqrt, + abs + } = _ref; + /** + * Calculates: + * The eucledian distance between two points in N-dimensional spaces. + * Distance between point and a line in 2 and 3 dimensional spaces. + * Pairwise distance between a set of 2D or 3D points + * NOTE: + * When substituting coefficients of a line(a, b and c), use ax + by + c = 0 instead of ax + by = c + * For parametric equation of a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, c) + * + * Syntax: + * + * math.distance([x1,y1], [x2,y2]) + * math.distance({pointOneX, pointOneY}, {pointTwoX, pointTwoY}) + * math.distance([x1,y1,z1], [x2,y2,z2]) + * math.distance({pointOneX, pointOneY, pointOneZ}, {pointTwoX, pointTwoY, pointTwoZ}) + * math.distance([x1,y1,z1,a1], [x2,y2,z2,a2]) + * math.distance([[x1,y1], [x2,y2], [x3,y3]]) + * math.distance([[x1,y1,z1], [x2,y2,z2], [x3,y3,z3]]) + * math.distance([pointX,pointY], [a,b,c]) + * math.distance([pointX,pointY], [lineOnePtX,lineOnePtY], [lineTwoPtX,lineTwoPtY]) + * math.distance({pointX, pointY}, {lineOnePtX, lineOnePtY}, {lineTwoPtX, lineTwoPtY}) + * math.distance([pointX,pointY,pointZ], [x0, y0, z0, a, b, c]) + * math.distance({pointX, pointY, pointZ}, {x0, y0, z0, a, b, c}) + * + * Examples: + * math.distance([0,0], [4,4]) // Returns 5.656854249492381 + * math.distance( + * {pointOneX: 0, pointOneY: 0}, + * {pointTwoX: 10, pointTwoY: 10}) // Returns 14.142135623730951 + * math.distance([1, 0, 1], [4, -2, 2]) // Returns 3.7416573867739413 + * math.distance( + * {pointOneX: 4, pointOneY: 5, pointOneZ: 8}, + * {pointTwoX: 2, pointTwoY: 7, pointTwoZ: 9}) // Returns 3 + * math.distance([1, 0, 1, 0], [0, -1, 0, -1]) // Returns 2 + * math.distance([[1, 2], [1, 2], [1, 3]]) // Returns [0, 1, 1] + * math.distance([[1,2,4], [1,2,6], [8,1,3]]) // Returns [2, 7.14142842854285, 7.681145747868608] + * math.distance([10, 10], [8, 1, 3]) // Returns 11.535230316796387 + * math.distance([0, 0], [3, 0], [0, 4]) // Returns 2.4 + * math.distance( + * {pointX: 0, pointY: 0}, + * {lineOnePtX: 3, lineOnePtY: 0}, + * {lineTwoPtX: 0, lineTwoPtY: 4}) // Returns 2.4 + * math.distance([2, 3, 1], [1, 1, 2, 5, 0, 1]) // Returns 2.3204774044612857 + * math.distance( + * {pointX: 2, pointY: 3, pointZ: 1}, + * {x0: 1, y0: 1, z0: 2, a: 5, b: 0, c: 1}) // Returns 2.3204774044612857 + * + * @param {Array | Matrix | Object} x Co-ordinates of first point + * @param {Array | Matrix | Object} y Co-ordinates of second point + * @return {Number | BigNumber} Returns the distance from two/three points + */ + return typed(name, { + 'Array, Array, Array': function (x, y, z) { + // Point to Line 2D (x=Point, y=LinePoint1, z=LinePoint2) + if (x.length === 2 && y.length === 2 && z.length === 2) { + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_2d(y)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument'); + } + if (!_2d(z)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument'); + } + if (deepEqual(y, z)) { + throw new TypeError('LinePoint1 should not be same with LinePoint2'); + } + const xCoeff = subtractScalar(z[1], y[1]); + const yCoeff = subtractScalar(y[0], z[0]); + const constant = subtractScalar(multiplyScalar(z[0], y[1]), multiplyScalar(y[0], z[1])); + return _distancePointLine2D(x[0], x[1], xCoeff, yCoeff, constant); + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Object, Object, Object': function (x, y, z) { + if (Object.keys(x).length === 2 && Object.keys(y).length === 2 && Object.keys(z).length === 2) { + if (!_2d(x)) { + throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers'); + } + if (!_2d(y)) { + throw new TypeError('Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers'); + } + if (!_2d(z)) { + throw new TypeError('Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers'); + } + if (deepEqual(_objectToArray(y), _objectToArray(z))) { + throw new TypeError('LinePoint1 should not be same with LinePoint2'); + } + if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y && 'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) { + const xCoeff = subtractScalar(z.lineTwoPtY, y.lineOnePtY); + const yCoeff = subtractScalar(y.lineOnePtX, z.lineTwoPtX); + const constant = subtractScalar(multiplyScalar(z.lineTwoPtX, y.lineOnePtY), multiplyScalar(y.lineOnePtX, z.lineTwoPtY)); + return _distancePointLine2D(x.pointX, x.pointY, xCoeff, yCoeff, constant); + } else { + throw new TypeError('Key names do not match'); + } + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Array, Array': function (x, y) { + // Point to Line 2D (x=[pointX, pointY], y=[x-coeff, y-coeff, const]) + if (x.length === 2 && y.length === 3) { + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + return _distancePointLine2D(x[0], x[1], y[0], y[1], y[2]); + } else if (x.length === 3 && y.length === 6) { + // Point to Line 3D + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_parametricLine(y)) { + throw new TypeError('Array with 6 numbers or BigNumbers expected for second argument'); + } + return _distancePointLine3D(x[0], x[1], x[2], y[0], y[1], y[2], y[3], y[4], y[5]); + } else if (x.length === y.length && x.length > 0) { + // Point to Point N-dimensions + if (!_containsOnlyNumbers(x)) { + throw new TypeError('All values of an array should be numbers or BigNumbers'); + } + if (!_containsOnlyNumbers(y)) { + throw new TypeError('All values of an array should be numbers or BigNumbers'); + } + return _euclideanDistance(x, y); + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Object, Object': function (x, y) { + if (Object.keys(x).length === 2 && Object.keys(y).length === 3) { + if (!_2d(x)) { + throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers'); + } + if (!_3d(y)) { + throw new TypeError('Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers'); + } + if ('pointX' in x && 'pointY' in x && 'xCoeffLine' in y && 'yCoeffLine' in y && 'constant' in y) { + return _distancePointLine2D(x.pointX, x.pointY, y.xCoeffLine, y.yCoeffLine, y.constant); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 3 && Object.keys(y).length === 6) { + // Point to Line 3D + if (!_3d(x)) { + throw new TypeError('Values of pointX, pointY and pointZ should be numbers or BigNumbers'); + } + if (!_parametricLine(y)) { + throw new TypeError('Values of x0, y0, z0, a, b and c should be numbers or BigNumbers'); + } + if ('pointX' in x && 'pointY' in x && 'x0' in y && 'y0' in y && 'z0' in y && 'a' in y && 'b' in y && 'c' in y) { + return _distancePointLine3D(x.pointX, x.pointY, x.pointZ, y.x0, y.y0, y.z0, y.a, y.b, y.c); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 2 && Object.keys(y).length === 2) { + // Point to Point 2D + if (!_2d(x)) { + throw new TypeError('Values of pointOneX and pointOneY should be numbers or BigNumbers'); + } + if (!_2d(y)) { + throw new TypeError('Values of pointTwoX and pointTwoY should be numbers or BigNumbers'); + } + if ('pointOneX' in x && 'pointOneY' in x && 'pointTwoX' in y && 'pointTwoY' in y) { + return _euclideanDistance([x.pointOneX, x.pointOneY], [y.pointTwoX, y.pointTwoY]); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 3 && Object.keys(y).length === 3) { + // Point to Point 3D + if (!_3d(x)) { + throw new TypeError('Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers'); + } + if (!_3d(y)) { + throw new TypeError('Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers'); + } + if ('pointOneX' in x && 'pointOneY' in x && 'pointOneZ' in x && 'pointTwoX' in y && 'pointTwoY' in y && 'pointTwoZ' in y) { + return _euclideanDistance([x.pointOneX, x.pointOneY, x.pointOneZ], [y.pointTwoX, y.pointTwoY, y.pointTwoZ]); + } else { + throw new TypeError('Key names do not match'); + } + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + Array: function (arr) { + if (!_pairwise(arr)) { + throw new TypeError('Incorrect array format entered for pairwise distance calculation'); + } + return _distancePairwise(arr); + } + }); + function _isNumber(a) { + // distance supports numbers and bignumbers + return typeof a === 'number' || (0, _is.isBigNumber)(a); + } + function _2d(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]); + } + function _3d(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]); + } + function _containsOnlyNumbers(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (!Array.isArray(a)) { + a = _objectToArray(a); + } + return a.every(_isNumber); + } + function _parametricLine(a) { + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]) && _isNumber(a[3]) && _isNumber(a[4]) && _isNumber(a[5]); + } + function _objectToArray(o) { + const keys = Object.keys(o); + const a = []; + for (let i = 0; i < keys.length; i++) { + a.push(o[keys[i]]); + } + return a; + } + function _pairwise(a) { + // checks for valid arguments passed to _distancePairwise(Array) + if (a[0].length === 2 && _isNumber(a[0][0]) && _isNumber(a[0][1])) { + if (a.some(aI => aI.length !== 2 || !_isNumber(aI[0]) || !_isNumber(aI[1]))) { + return false; + } + } else if (a[0].length === 3 && _isNumber(a[0][0]) && _isNumber(a[0][1]) && _isNumber(a[0][2])) { + if (a.some(aI => aI.length !== 3 || !_isNumber(aI[0]) || !_isNumber(aI[1]) || !_isNumber(aI[2]))) { + return false; + } + } else { + return false; + } + return true; + } + function _distancePointLine2D(x, y, a, b, c) { + const num = abs(addScalar(addScalar(multiplyScalar(a, x), multiplyScalar(b, y)), c)); + const den = sqrt(addScalar(multiplyScalar(a, a), multiplyScalar(b, b))); + return divideScalar(num, den); + } + function _distancePointLine3D(x, y, z, x0, y0, z0, a, b, c) { + let num = [subtractScalar(multiplyScalar(subtractScalar(y0, y), c), multiplyScalar(subtractScalar(z0, z), b)), subtractScalar(multiplyScalar(subtractScalar(z0, z), a), multiplyScalar(subtractScalar(x0, x), c)), subtractScalar(multiplyScalar(subtractScalar(x0, x), b), multiplyScalar(subtractScalar(y0, y), a))]; + num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2]))); + const den = sqrt(addScalar(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)), multiplyScalar(c, c))); + return divideScalar(num, den); + } + function _euclideanDistance(x, y) { + const vectorSize = x.length; + let result = 0; + let diff = 0; + for (let i = 0; i < vectorSize; i++) { + diff = subtractScalar(x[i], y[i]); + result = addScalar(multiplyScalar(diff, diff), result); + } + return sqrt(result); + } + function _distancePairwise(a) { + const result = []; + let pointA = []; + let pointB = []; + for (let i = 0; i < a.length - 1; i++) { + for (let j = i + 1; j < a.length; j++) { + if (a[0].length === 2) { + pointA = [a[i][0], a[i][1]]; + pointB = [a[j][0], a[j][1]]; + } else if (a[0].length === 3) { + pointA = [a[i][0], a[i][1], a[i][2]]; + pointB = [a[j][0], a[j][1], a[j][2]]; + } + result.push(_euclideanDistance(pointA, pointB)); + } + } + return result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/intersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/intersect.js new file mode 100644 index 0000000..af857e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/geometry/intersect.js @@ -0,0 +1,206 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIntersect = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'intersect'; +const dependencies = ['typed', 'config', 'abs', 'add', 'addScalar', 'matrix', 'multiply', 'multiplyScalar', 'divideScalar', 'subtract', 'smaller', 'equalScalar', 'flatten', 'isZero', 'isNumeric']; +const createIntersect = exports.createIntersect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + abs, + add, + addScalar, + matrix, + multiply, + multiplyScalar, + divideScalar, + subtract, + smaller, + equalScalar, + flatten, + isZero, + isNumeric + } = _ref; + /** + * Calculates the point of intersection of two lines in two or three dimensions + * and of a line and a plane in three dimensions. The inputs are in the form of + * arrays or 1 dimensional matrices. The line intersection functions return null + * if the lines do not meet. + * + * Note: Fill the plane coefficients as `x + y + z = c` and not as `x + y + z + c = 0`. + * + * Syntax: + * + * math.intersect(endPoint1Line1, endPoint2Line1, endPoint1Line2, endPoint2Line2) + * math.intersect(endPoint1, endPoint2, planeCoefficients) + * + * Examples: + * + * math.intersect([0, 0], [10, 10], [10, 0], [0, 10]) // Returns [5, 5] + * math.intersect([0, 0, 0], [10, 10, 0], [10, 0, 0], [0, 10, 0]) // Returns [5, 5, 0] + * math.intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6]) // Returns [7, -4, 3] + * + * @param {Array | Matrix} w Co-ordinates of first end-point of first line + * @param {Array | Matrix} x Co-ordinates of second end-point of first line + * @param {Array | Matrix} y Co-ordinates of first end-point of second line + * OR Co-efficients of the plane's equation + * @param {Array | Matrix} z Co-ordinates of second end-point of second line + * OR undefined if the calculation is for line and plane + * @return {Array} Returns the point of intersection of lines/lines-planes + */ + return typed('intersect', { + 'Array, Array, Array': _AAA, + 'Array, Array, Array, Array': _AAAA, + 'Matrix, Matrix, Matrix': function (x, y, plane) { + const arr = _AAA(x.valueOf(), y.valueOf(), plane.valueOf()); + return arr === null ? null : matrix(arr); + }, + 'Matrix, Matrix, Matrix, Matrix': function (w, x, y, z) { + // TODO: output matrix type should match input matrix type + const arr = _AAAA(w.valueOf(), x.valueOf(), y.valueOf(), z.valueOf()); + return arr === null ? null : matrix(arr); + } + }); + function _AAA(x, y, plane) { + x = _coerceArr(x); + y = _coerceArr(y); + plane = _coerceArr(plane); + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + if (!_4d(plane)) { + throw new TypeError('Array with 4 numbers expected as third argument'); + } + return _intersectLinePlane(x[0], x[1], x[2], y[0], y[1], y[2], plane[0], plane[1], plane[2], plane[3]); + } + function _AAAA(w, x, y, z) { + w = _coerceArr(w); + x = _coerceArr(x); + y = _coerceArr(y); + z = _coerceArr(z); + if (w.length === 2) { + if (!_2d(w)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument'); + } + if (!_2d(y)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument'); + } + if (!_2d(z)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for fourth argument'); + } + return _intersect2d(w, x, y, z); + } else if (w.length === 3) { + if (!_3d(w)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for third argument'); + } + if (!_3d(z)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for fourth argument'); + } + return _intersect3d(w[0], w[1], w[2], x[0], x[1], x[2], y[0], y[1], y[2], z[0], z[1], z[2]); + } else { + throw new TypeError('Arrays with two or thee dimensional points expected'); + } + } + + /** Coerce row and column 2-dim arrays to 1-dim array */ + function _coerceArr(arr) { + // row matrix + if (arr.length === 1) return arr[0]; + + // column matrix + if (arr.length > 1 && Array.isArray(arr[0])) { + if (arr.every(el => Array.isArray(el) && el.length === 1)) return flatten(arr); + } + return arr; + } + function _2d(x) { + return x.length === 2 && isNumeric(x[0]) && isNumeric(x[1]); + } + function _3d(x) { + return x.length === 3 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]); + } + function _4d(x) { + return x.length === 4 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]) && isNumeric(x[3]); + } + function _intersect2d(p1a, p1b, p2a, p2b) { + const o1 = p1a; + const o2 = p2a; + const d1 = subtract(o1, p1b); + const d2 = subtract(o2, p2b); + const det = subtract(multiplyScalar(d1[0], d2[1]), multiplyScalar(d2[0], d1[1])); + if (isZero(det)) return null; + if (smaller(abs(det), config.relTol)) { + return null; + } + const d20o11 = multiplyScalar(d2[0], o1[1]); + const d21o10 = multiplyScalar(d2[1], o1[0]); + const d20o21 = multiplyScalar(d2[0], o2[1]); + const d21o20 = multiplyScalar(d2[1], o2[0]); + const t = divideScalar(addScalar(subtract(subtract(d20o11, d21o10), d20o21), d21o20), det); + return add(multiply(d1, t), o1); + } + function _intersect3dHelper(a, b, c, d, e, f, g, h, i, j, k, l) { + // (a - b)*(c - d) + (e - f)*(g - h) + (i - j)*(k - l) + const add1 = multiplyScalar(subtract(a, b), subtract(c, d)); + const add2 = multiplyScalar(subtract(e, f), subtract(g, h)); + const add3 = multiplyScalar(subtract(i, j), subtract(k, l)); + return addScalar(addScalar(add1, add2), add3); + } + function _intersect3d(x1, y1, z1, x2, y2, z2, x3, y3, z3, x4, y4, z4) { + const d1343 = _intersect3dHelper(x1, x3, x4, x3, y1, y3, y4, y3, z1, z3, z4, z3); + const d4321 = _intersect3dHelper(x4, x3, x2, x1, y4, y3, y2, y1, z4, z3, z2, z1); + const d1321 = _intersect3dHelper(x1, x3, x2, x1, y1, y3, y2, y1, z1, z3, z2, z1); + const d4343 = _intersect3dHelper(x4, x3, x4, x3, y4, y3, y4, y3, z4, z3, z4, z3); + const d2121 = _intersect3dHelper(x2, x1, x2, x1, y2, y1, y2, y1, z2, z1, z2, z1); + const numerator = subtract(multiplyScalar(d1343, d4321), multiplyScalar(d1321, d4343)); + const denominator = subtract(multiplyScalar(d2121, d4343), multiplyScalar(d4321, d4321)); + if (isZero(denominator)) return null; + const ta = divideScalar(numerator, denominator); + const tb = divideScalar(addScalar(d1343, multiplyScalar(ta, d4321)), d4343); + const pax = addScalar(x1, multiplyScalar(ta, subtract(x2, x1))); + const pay = addScalar(y1, multiplyScalar(ta, subtract(y2, y1))); + const paz = addScalar(z1, multiplyScalar(ta, subtract(z2, z1))); + const pbx = addScalar(x3, multiplyScalar(tb, subtract(x4, x3))); + const pby = addScalar(y3, multiplyScalar(tb, subtract(y4, y3))); + const pbz = addScalar(z3, multiplyScalar(tb, subtract(z4, z3))); + if (equalScalar(pax, pbx) && equalScalar(pay, pby) && equalScalar(paz, pbz)) { + return [pax, pay, paz]; + } else { + return null; + } + } + function _intersectLinePlane(x1, y1, z1, x2, y2, z2, x, y, z, c) { + const x1x = multiplyScalar(x1, x); + const x2x = multiplyScalar(x2, x); + const y1y = multiplyScalar(y1, y); + const y2y = multiplyScalar(y2, y); + const z1z = multiplyScalar(z1, z); + const z2z = multiplyScalar(z2, z); + const numerator = subtract(subtract(subtract(c, x1x), y1y), z1z); + const denominator = subtract(subtract(subtract(addScalar(addScalar(x2x, y2y), z2z), x1x), y1y), z1z); + const t = divideScalar(numerator, denominator); + const px = addScalar(x1, multiplyScalar(t, subtract(x2, x1))); + const py = addScalar(y1, multiplyScalar(t, subtract(y2, y1))); + const pz = addScalar(z1, multiplyScalar(t, subtract(z2, z1))); + return [px, py, pz]; + // TODO: Add cases when line is parallel to the plane: + // (a) no intersection, + // (b) line contained in plane + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/and.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/and.js new file mode 100644 index 0000000..cb92ff1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/and.js @@ -0,0 +1,128 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAnd = void 0; +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js"); +var _matAlgo06xS0S = require("../../type/matrix/utils/matAlgo06xS0S0.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'and'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'not', 'concat']; +const createAnd = exports.createAnd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo06xS0S0 = (0, _matAlgo06xS0S.createMatAlgo06xS0S0)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Logical `and`. Test whether two values are both defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.and(x, y) + * + * Examples: + * + * math.and(2, 4) // returns true + * + * a = [2, 0, 0] + * b = [3, 7, 0] + * c = 0 + * + * math.and(a, b) // returns [true, false, false] + * math.and(a, c) // returns [false, false, false] + * + * See also: + * + * not, or, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when both inputs are defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': _index.andNumber, + 'Complex, Complex': function (x, y) { + return (x.re !== 0 || x.im !== 0) && (y.re !== 0 || y.im !== 0); + }, + 'BigNumber, BigNumber': function (x, y) { + return !x.isZero() && !y.isZero() && !x.isNaN() && !y.isNaN(); + }, + 'bigint, bigint': _index.andNumber, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)), + 'SparseMatrix, any': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(y)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, any': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(y)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo14xDs(x, y, self, false); + }), + 'any, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(x)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo11xS0s(y, x, self, true); + }), + 'any, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(x)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo14xDs(y, x, self, true); + }), + 'Array, any': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return self(matrix(x), y).valueOf(); + }), + 'any, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return self(x, matrix(y)).valueOf(); + }) + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/not.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/not.js new file mode 100644 index 0000000..bc38d42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/not.js @@ -0,0 +1,54 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNot = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'not'; +const dependencies = ['typed']; +const createNot = exports.createNot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Logical `not`. Flips boolean value of a given parameter. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.not(x) + * + * Examples: + * + * math.not(2) // returns false + * math.not(0) // returns true + * math.not(true) // returns false + * + * a = [2, -7, 0] + * math.not(a) // returns [false, false, true] + * + * See also: + * + * and, or, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @return {boolean | Array | Matrix} + * Returns true when input is a zero or empty value. + */ + return typed(name, { + 'null | undefined': () => true, + number: _index.notNumber, + Complex: function (x) { + return x.re === 0 && x.im === 0; + }, + BigNumber: function (x) { + return x.isZero() || x.isNaN(); + }, + bigint: x => !x, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/or.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/or.js new file mode 100644 index 0000000..8680743 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/or.js @@ -0,0 +1,83 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createOr = void 0; +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo05xSfSf = require("../../type/matrix/utils/matAlgo05xSfSf.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'or'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +const createOr = exports.createOr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo05xSfSf = (0, _matAlgo05xSfSf.createMatAlgo05xSfSf)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Logical `or`. Test if at least one value is defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.or(x, y) + * + * Examples: + * + * math.or(2, 4) // returns true + * + * a = [2, 5, 0] + * b = [0, 22, 0] + * c = 0 + * + * math.or(a, b) // returns [true, true, false] + * math.or(b, c) // returns [false, true, false] + * + * See also: + * + * and, not, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when one of the inputs is defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': _index.orNumber, + 'Complex, Complex': function (x, y) { + return x.re !== 0 || x.im !== 0 || y.re !== 0 || y.im !== 0; + }, + 'BigNumber, BigNumber': function (x, y) { + return !x.isZero() && !x.isNaN() || !y.isZero() && !y.isNaN(); + }, + 'bigint, bigint': _index.orNumber, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)) + }, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/xor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/xor.js new file mode 100644 index 0000000..dccfa8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/logical/xor.js @@ -0,0 +1,82 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createXor = void 0; +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _index = require("../../plain/number/index.js"); +const name = 'xor'; +const dependencies = ['typed', 'matrix', 'DenseMatrix', 'concat']; +const createXor = exports.createXor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Logical `xor`. Test whether one and only one value is defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.xor(x, y) + * + * Examples: + * + * math.xor(2, 4) // returns false + * + * a = [2, 0, 0] + * b = [2, 7, 0] + * c = 0 + * + * math.xor(a, b) // returns [false, true, false] + * math.xor(a, c) // returns [true, false, false] + * + * See also: + * + * and, not, or + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when one and only one input is defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': _index.xorNumber, + 'Complex, Complex': function (x, y) { + return (x.re !== 0 || x.im !== 0) !== (y.re !== 0 || y.im !== 0); + }, + 'bigint, bigint': _index.xorNumber, + 'BigNumber, BigNumber': function (x, y) { + return (!x.isZero() && !x.isNaN()) !== (!y.isZero() && !y.isNaN()); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)) + }, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/apply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/apply.js new file mode 100644 index 0000000..4942d9f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/apply.js @@ -0,0 +1,117 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createApply = void 0; +var _factory = require("../../utils/factory.js"); +var _array = require("../../utils/array.js"); +var _is = require("../../utils/is.js"); +var _IndexError = require("../../error/IndexError.js"); +const name = 'apply'; +const dependencies = ['typed', 'isInteger']; +const createApply = exports.createApply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isInteger + } = _ref; + /** + * Apply a function that maps an array to a scalar + * along a given axis of a matrix or array. + * Returns a new matrix or array with one less dimension than the input. + * + * Syntax: + * + * math.apply(A, dim, callback) + * + * Where: + * + * - `dim: number` is a zero-based dimension over which to concatenate the matrices. + * + * Examples: + * + * const A = [[1, 2], [3, 4]] + * const sum = math.sum + * + * math.apply(A, 0, sum) // returns [4, 6] + * math.apply(A, 1, sum) // returns [3, 7] + * + * See also: + * + * map, filter, forEach + * + * @param {Array | Matrix} array The input Matrix + * @param {number} dim The dimension along which the callback is applied + * @param {Function} callback The callback function that is applied. This Function + * should take an array or 1-d matrix as an input and + * return a number. + * @return {Array | Matrix} res The residual matrix with the function applied over some dimension. + */ + return typed(name, { + 'Array | Matrix, number | BigNumber, function': function (mat, dim, callback) { + if (!isInteger(dim)) { + throw new TypeError('Integer number expected for dimension'); + } + const size = Array.isArray(mat) ? (0, _array.arraySize)(mat) : mat.size(); + if (dim < 0 || dim >= size.length) { + throw new _IndexError.IndexError(dim, size.length); + } + if ((0, _is.isMatrix)(mat)) { + return mat.create(_apply(mat.valueOf(), dim, callback), mat.datatype()); + } else { + return _apply(mat, dim, callback); + } + } + }); +}); + +/** + * Recursively reduce a matrix + * @param {Array} mat + * @param {number} dim + * @param {Function} callback + * @returns {Array} ret + * @private + */ +function _apply(mat, dim, callback) { + let i, ret, tran; + if (dim <= 0) { + if (!Array.isArray(mat[0])) { + return callback(mat); + } else { + tran = _switch(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _apply(tran[i], dim - 1, callback); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _apply(mat[i], dim - 1, callback); + } + return ret; + } +} + +/** + * Transpose a matrix + * @param {Array} mat + * @returns {Array} ret + * @private + */ +function _switch(mat) { + const I = mat.length; + const J = mat[0].length; + let i, j; + const ret = []; + for (j = 0; j < J; j++) { + const tmp = []; + for (i = 0; i < I; i++) { + tmp.push(mat[i][j]); + } + ret.push(tmp); + } + return ret; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/column.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/column.js new file mode 100644 index 0000000..9646021 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/column.js @@ -0,0 +1,65 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createColumn = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +const name = 'column'; +const dependencies = ['typed', 'Index', 'matrix', 'range']; +const createColumn = exports.createColumn = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Index, + matrix, + range + } = _ref; + /** + * Return a column from a Matrix. + * + * Syntax: + * + * math.column(value, index) + * + * Example: + * + * // get a column + * const d = [[1, 2], [3, 4]] + * math.column(d, 1) // returns [[2], [4]] + * + * See also: + * + * row + * + * @param {Array | Matrix } value An array or matrix + * @param {number} column The index of the column + * @return {Array | Matrix} The retrieved column + */ + return typed(name, { + 'Matrix, number': _column, + 'Array, number': function (value, column) { + return _column(matrix((0, _object.clone)(value)), column).valueOf(); + } + }); + + /** + * Retrieve a column of a matrix + * @param {Matrix } value A matrix + * @param {number} column The index of the column + * @return {Matrix} The retrieved column + */ + function _column(value, column) { + // check dimensions + if (value.size().length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + (0, _array.validateIndex)(column, value.size()[1]); + const rowRange = range(0, value.size()[0]); + const index = new Index(rowRange, column); + const result = value.subset(index); + return (0, _is.isMatrix)(result) ? result : matrix([[result]]); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/concat.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/concat.js new file mode 100644 index 0000000..785e0e4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/concat.js @@ -0,0 +1,110 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createConcat = void 0; +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +var _IndexError = require("../../error/IndexError.js"); +var _DimensionError = require("../../error/DimensionError.js"); +var _factory = require("../../utils/factory.js"); +const name = 'concat'; +const dependencies = ['typed', 'matrix', 'isInteger']; +const createConcat = exports.createConcat = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + isInteger + } = _ref; + /** + * Concatenate two or more matrices. + * + * Syntax: + * + * math.concat(A, B, C, ...) + * math.concat(A, B, C, ..., dim) + * + * Where: + * + * - `dim: number` is a zero-based dimension over which to concatenate the matrices. + * By default the last dimension of the matrices. + * + * Examples: + * + * const A = [[1, 2], [5, 6]] + * const B = [[3, 4], [7, 8]] + * + * math.concat(A, B) // returns [[1, 2, 3, 4], [5, 6, 7, 8]] + * math.concat(A, B, 0) // returns [[1, 2], [5, 6], [3, 4], [7, 8]] + * math.concat('hello', ' ', 'world') // returns 'hello world' + * + * See also: + * + * size, squeeze, subset, transpose + * + * @param {... Array | Matrix} args Two or more matrices + * @return {Array | Matrix} Concatenated matrix + */ + return typed(name, { + // TODO: change signature to '...Array | Matrix, dim?' when supported + '...Array | Matrix | number | BigNumber': function (args) { + let i; + const len = args.length; + let dim = -1; // zero-based dimension + let prevDim; + let asMatrix = false; + const matrices = []; // contains multi dimensional arrays + + for (i = 0; i < len; i++) { + const arg = args[i]; + + // test whether we need to return a Matrix (if not we return an Array) + if ((0, _is.isMatrix)(arg)) { + asMatrix = true; + } + if ((0, _is.isNumber)(arg) || (0, _is.isBigNumber)(arg)) { + if (i !== len - 1) { + throw new Error('Dimension must be specified as last argument'); + } + + // last argument contains the dimension on which to concatenate + prevDim = dim; + dim = arg.valueOf(); // change BigNumber to number + + if (!isInteger(dim)) { + throw new TypeError('Integer number expected for dimension'); + } + if (dim < 0 || i > 0 && dim > prevDim) { + // TODO: would be more clear when throwing a DimensionError here + throw new _IndexError.IndexError(dim, prevDim + 1); + } + } else { + // this is a matrix or array + const m = (0, _object.clone)(arg).valueOf(); + const size = (0, _array.arraySize)(m); + matrices[i] = m; + prevDim = dim; + dim = size.length - 1; + + // verify whether each of the matrices has the same number of dimensions + if (i > 0 && dim !== prevDim) { + throw new _DimensionError.DimensionError(prevDim + 1, dim + 1); + } + } + } + if (matrices.length === 0) { + throw new SyntaxError('At least one matrix expected'); + } + let res = matrices.shift(); + while (matrices.length) { + res = (0, _array.concat)(res, matrices.shift(), dim); + } + return asMatrix ? matrix(res) : res; + }, + '...string': function (args) { + return args.join(''); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/count.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/count.js new file mode 100644 index 0000000..508d2cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/count.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCount = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'count'; +const dependencies = ['typed', 'size', 'prod']; +const createCount = exports.createCount = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + prod + } = _ref; + /** + * Count the number of elements of a matrix, array or string. + * + * Syntax: + * + * math.count(x) + * + * Examples: + * + * math.count('hello world') // returns 11 + * const A = [[1, 2, 3], [4, 5, 6]] + * math.count(A) // returns 6 + * math.count(math.range(1,6)) // returns 5 + * + * See also: + * + * size + * + * @param {string | Array | Matrix} x A matrix or string + * @return {number} An integer with the elements in `x`. + */ + return typed(name, { + string: function (x) { + return x.length; + }, + 'Matrix | Array': function (x) { + return prod(size(x)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/cross.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/cross.js new file mode 100644 index 0000000..9394464 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/cross.js @@ -0,0 +1,87 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCross = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'cross'; +const dependencies = ['typed', 'matrix', 'subtract', 'multiply']; +const createCross = exports.createCross = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + subtract, + multiply + } = _ref; + /** + * Calculate the cross product for two vectors in three dimensional space. + * The cross product of `A = [a1, a2, a3]` and `B = [b1, b2, b3]` is defined + * as: + * + * cross(A, B) = [ + * a2 * b3 - a3 * b2, + * a3 * b1 - a1 * b3, + * a1 * b2 - a2 * b1 + * ] + * + * If one of the input vectors has a dimension greater than 1, the output + * vector will be a 1x3 (2-dimensional) matrix. + * + * Syntax: + * + * math.cross(x, y) + * + * Examples: + * + * math.cross([1, 1, 0], [0, 1, 1]) // Returns [1, -1, 1] + * math.cross([3, -3, 1], [4, 9, 2]) // Returns [-15, -2, 39] + * math.cross([2, 3, 4], [5, 6, 7]) // Returns [-3, 6, -3] + * math.cross([[1, 2, 3]], [[4], [5], [6]]) // Returns [[-3, 6, -3]] + * + * See also: + * + * dot, multiply + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {Array | Matrix} Returns the cross product of `x` and `y` + */ + return typed(name, { + 'Matrix, Matrix': function (x, y) { + return matrix(_cross(x.toArray(), y.toArray())); + }, + 'Matrix, Array': function (x, y) { + return matrix(_cross(x.toArray(), y)); + }, + 'Array, Matrix': function (x, y) { + return matrix(_cross(x, y.toArray())); + }, + 'Array, Array': _cross + }); + + /** + * Calculate the cross product for two arrays + * @param {Array} x First vector + * @param {Array} y Second vector + * @returns {Array} Returns the cross product of x and y + * @private + */ + function _cross(x, y) { + const highestDimension = Math.max((0, _array.arraySize)(x).length, (0, _array.arraySize)(y).length); + x = (0, _array.squeeze)(x); + y = (0, _array.squeeze)(y); + const xSize = (0, _array.arraySize)(x); + const ySize = (0, _array.arraySize)(y); + if (xSize.length !== 1 || ySize.length !== 1 || xSize[0] !== 3 || ySize[0] !== 3) { + throw new RangeError('Vectors with length 3 expected ' + '(Size A = [' + xSize.join(', ') + '], B = [' + ySize.join(', ') + '])'); + } + const product = [subtract(multiply(x[1], y[2]), multiply(x[2], y[1])), subtract(multiply(x[2], y[0]), multiply(x[0], y[2])), subtract(multiply(x[0], y[1]), multiply(x[1], y[0]))]; + if (highestDimension > 1) { + return [product]; + } else { + return product; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ctranspose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ctranspose.js new file mode 100644 index 0000000..0e85a3b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ctranspose.js @@ -0,0 +1,43 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCtranspose = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'ctranspose'; +const dependencies = ['typed', 'transpose', 'conj']; +const createCtranspose = exports.createCtranspose = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + transpose, + conj + } = _ref; + /** + * Transpose and complex conjugate a matrix. All values of the matrix are + * reflected over its main diagonal and then the complex conjugate is + * taken. This is equivalent to complex conjugation for scalars and + * vectors. + * + * Syntax: + * + * math.ctranspose(x) + * + * Examples: + * + * const A = [[1, 2, 3], [4, 5, math.complex(6,7)]] + * math.ctranspose(A) // returns [[1, 4], [2, 5], [3, {re:6,im:7}]] + * + * See also: + * + * transpose, diag, inv, subset, squeeze + * + * @param {Array | Matrix} x Matrix to be ctransposed + * @return {Array | Matrix} The ctransposed matrix + */ + return typed(name, { + any: function (x) { + return conj(transpose(x)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/det.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/det.js new file mode 100644 index 0000000..81e9eb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/det.js @@ -0,0 +1,148 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDet = void 0; +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +const name = 'det'; +const dependencies = ['typed', 'matrix', 'subtractScalar', 'multiply', 'divideScalar', 'isZero', 'unaryMinus']; +const createDet = exports.createDet = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + subtractScalar, + multiply, + divideScalar, + isZero, + unaryMinus + } = _ref; + /** + * Calculate the determinant of a matrix. + * + * Syntax: + * + * math.det(x) + * + * Examples: + * + * math.det([[1, 2], [3, 4]]) // returns -2 + * + * const A = [ + * [-2, 2, 3], + * [-1, 1, 3], + * [2, 0, -1] + * ] + * math.det(A) // returns 6 + * + * See also: + * + * inv + * + * @param {Array | Matrix} x A matrix + * @return {number} The determinant of `x` + */ + return typed(name, { + any: function (x) { + return (0, _object.clone)(x); + }, + 'Array | Matrix': function det(x) { + let size; + if ((0, _is.isMatrix)(x)) { + size = x.size(); + } else if (Array.isArray(x)) { + x = matrix(x); + size = x.size(); + } else { + // a scalar + size = []; + } + switch (size.length) { + case 0: + // scalar + return (0, _object.clone)(x); + case 1: + // vector + if (size[0] === 1) { + return (0, _object.clone)(x.valueOf()[0]); + } + if (size[0] === 0) { + return 1; // det of an empty matrix is per definition 1 + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + case 2: + { + // two-dimensional array + const rows = size[0]; + const cols = size[1]; + if (rows === cols) { + return _det(x.clone().valueOf(), rows, cols); + } + if (cols === 0) { + return 1; // det of an empty matrix is per definition 1 + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')'); + } + } + }); + + /** + * Calculate the determinant of a matrix + * @param {Array[]} matrix A square, two dimensional matrix + * @param {number} rows Number of rows of the matrix (zero-based) + * @param {number} cols Number of columns of the matrix (zero-based) + * @returns {number} det + * @private + */ + function _det(matrix, rows, cols) { + if (rows === 1) { + // this is a 1 x 1 matrix + return (0, _object.clone)(matrix[0][0]); + } else if (rows === 2) { + // this is a 2 x 2 matrix + // the determinant of [a11,a12;a21,a22] is det = a11*a22-a21*a12 + return subtractScalar(multiply(matrix[0][0], matrix[1][1]), multiply(matrix[1][0], matrix[0][1])); + } else { + // Bareiss algorithm + // this algorithm have same complexity as LUP decomposition (O(n^3)) + // but it preserve precision of floating point more relative to the LUP decomposition + let negated = false; + const rowIndices = new Array(rows).fill(0).map((_, i) => i); // matrix index of row i + for (let k = 0; k < rows; k++) { + let k_ = rowIndices[k]; + if (isZero(matrix[k_][k])) { + let _k; + for (_k = k + 1; _k < rows; _k++) { + if (!isZero(matrix[rowIndices[_k]][k])) { + k_ = rowIndices[_k]; + rowIndices[_k] = rowIndices[k]; + rowIndices[k] = k_; + negated = !negated; + break; + } + } + if (_k === rows) return matrix[k_][k]; // some zero of the type + } + const piv = matrix[k_][k]; + const piv_ = k === 0 ? 1 : matrix[rowIndices[k - 1]][k - 1]; + for (let i = k + 1; i < rows; i++) { + const i_ = rowIndices[i]; + for (let j = k + 1; j < rows; j++) { + matrix[i_][j] = divideScalar(subtractScalar(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_); + } + } + } + const det = matrix[rowIndices[rows - 1]][rows - 1]; + return negated ? unaryMinus(det) : det; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diag.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diag.js new file mode 100644 index 0000000..c87efdd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diag.js @@ -0,0 +1,161 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDiag = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'diag'; +const dependencies = ['typed', 'matrix', 'DenseMatrix', 'SparseMatrix']; +const createDiag = exports.createDiag = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a diagonal matrix or retrieve the diagonal of a matrix + * + * When `x` is a vector, a matrix with vector `x` on the diagonal will be returned. + * When `x` is a two dimensional matrix, the matrixes `k`th diagonal will be returned as vector. + * When k is positive, the values are placed on the super diagonal. + * When k is negative, the values are placed on the sub diagonal. + * + * Syntax: + * + * math.diag(X) + * math.diag(X, format) + * math.diag(X, k) + * math.diag(X, k, format) + * + * Examples: + * + * // create a diagonal matrix + * math.diag([1, 2, 3]) // returns [[1, 0, 0], [0, 2, 0], [0, 0, 3]] + * math.diag([1, 2, 3], 1) // returns [[0, 1, 0, 0], [0, 0, 2, 0], [0, 0, 0, 3]] + * math.diag([1, 2, 3], -1) // returns [[0, 0, 0], [1, 0, 0], [0, 2, 0], [0, 0, 3]] + * + * // retrieve the diagonal from a matrix + * const a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] + * math.diag(a) // returns [1, 5, 9] + * + * See also: + * + * ones, zeros, identity + * + * @param {Matrix | Array} x A two dimensional matrix or a vector + * @param {number | BigNumber} [k=0] The diagonal where the vector will be filled + * in or retrieved. + * @param {string} [format='dense'] The matrix storage format. + * + * @returns {Matrix | Array} Diagonal matrix from input vector, or diagonal from input matrix. + */ + return typed(name, { + // FIXME: simplify this huge amount of signatures as soon as typed-function supports optional arguments + + Array: function (x) { + return _diag(x, 0, (0, _array.arraySize)(x), null); + }, + 'Array, number': function (x, k) { + return _diag(x, k, (0, _array.arraySize)(x), null); + }, + 'Array, BigNumber': function (x, k) { + return _diag(x, k.toNumber(), (0, _array.arraySize)(x), null); + }, + 'Array, string': function (x, format) { + return _diag(x, 0, (0, _array.arraySize)(x), format); + }, + 'Array, number, string': function (x, k, format) { + return _diag(x, k, (0, _array.arraySize)(x), format); + }, + 'Array, BigNumber, string': function (x, k, format) { + return _diag(x, k.toNumber(), (0, _array.arraySize)(x), format); + }, + Matrix: function (x) { + return _diag(x, 0, x.size(), x.storage()); + }, + 'Matrix, number': function (x, k) { + return _diag(x, k, x.size(), x.storage()); + }, + 'Matrix, BigNumber': function (x, k) { + return _diag(x, k.toNumber(), x.size(), x.storage()); + }, + 'Matrix, string': function (x, format) { + return _diag(x, 0, x.size(), format); + }, + 'Matrix, number, string': function (x, k, format) { + return _diag(x, k, x.size(), format); + }, + 'Matrix, BigNumber, string': function (x, k, format) { + return _diag(x, k.toNumber(), x.size(), format); + } + }); + + /** + * Creeate diagonal matrix from a vector or vice versa + * @param {Array | Matrix} x + * @param {number} k + * @param {string} format Storage format for matrix. If null, + * an Array is returned + * @returns {Array | Matrix} + * @private + */ + function _diag(x, k, size, format) { + if (!(0, _number.isInteger)(k)) { + throw new TypeError('Second parameter in function diag must be an integer'); + } + const kSuper = k > 0 ? k : 0; + const kSub = k < 0 ? -k : 0; + + // check dimensions + switch (size.length) { + case 1: + return _createDiagonalMatrix(x, k, format, size[0], kSub, kSuper); + case 2: + return _getDiagonal(x, k, format, size, kSub, kSuper); + } + throw new RangeError('Matrix for function diag must be 2 dimensional'); + } + function _createDiagonalMatrix(x, k, format, l, kSub, kSuper) { + // matrix size + const ms = [l + kSub, l + kSuper]; + if (format && format !== 'sparse' && format !== 'dense') { + throw new TypeError(`Unknown matrix type ${format}"`); + } + + // create diagonal matrix + const m = format === 'sparse' ? SparseMatrix.diagonal(ms, x, k) : DenseMatrix.diagonal(ms, x, k); + // check we need to return a matrix + return format !== null ? m : m.valueOf(); + } + function _getDiagonal(x, k, format, s, kSub, kSuper) { + // check x is a Matrix + if ((0, _is.isMatrix)(x)) { + // get diagonal matrix + const dm = x.diagonal(k); + // check we need to return a matrix + if (format !== null) { + // check we need to change matrix format + if (format !== dm.storage()) { + return matrix(dm, format); + } + return dm; + } + return dm.valueOf(); + } + // vector size + const n = Math.min(s[0] - kSub, s[1] - kSuper); + // diagonal values + const vector = []; + // loop diagonal + for (let i = 0; i < n; i++) { + vector[i] = x[i + kSub][i + kSuper]; + } + // check we need to return a matrix + return format !== null ? matrix(vector) : vector; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diff.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diff.js new file mode 100644 index 0000000..a41ffe8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/diff.js @@ -0,0 +1,169 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDiff = void 0; +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _is = require("../../utils/is.js"); +const name = 'diff'; +const dependencies = ['typed', 'matrix', 'subtract', 'number']; +const createDiff = exports.createDiff = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + subtract, + number + } = _ref; + /** + * Create a new matrix or array of the difference between elements of the given array + * The optional dim parameter lets you specify the dimension to evaluate the difference of + * If no dimension parameter is passed it is assumed as dimension 0 + * + * Dimension is zero-based in javascript and one-based in the parser and can be a number or bignumber + * Arrays must be 'rectangular' meaning arrays like [1, 2] + * If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays + * + * Syntax: + * + * math.diff(arr) + * math.diff(arr, dim) + * + * Examples: + * + * const arr = [1, 2, 4, 7, 0] + * math.diff(arr) // returns [1, 2, 3, -7] (no dimension passed so 0 is assumed) + * math.diff(math.matrix(arr)) // returns Matrix [1, 2, 3, -7] + * + * const arr = [[1, 2, 3, 4, 5], [1, 2, 3, 4, 5], [9, 8, 7, 6, 4]] + * math.diff(arr) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]] + * math.diff(arr, 0) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]] + * math.diff(arr, 1) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]] + * math.diff(arr, math.bignumber(1)) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]] + * + * math.diff(arr, 2) // throws RangeError as arr is 2 dimensional not 3 + * math.diff(arr, -1) // throws RangeError as negative dimensions are not allowed + * + * // These will all produce the same result + * math.diff([[1, 2], [3, 4]]) + * math.diff([math.matrix([1, 2]), math.matrix([3, 4])]) + * math.diff([[1, 2], math.matrix([3, 4])]) + * math.diff([math.matrix([1, 2]), [3, 4]]) + * // They do not produce the same result as math.diff(math.matrix([[1, 2], [3, 4]])) as this returns a matrix + * + * See Also: + * + * sum + * subtract + * partitionSelect + * + * @param {Array | Matrix} arr An array or matrix + * @param {number | BigNumber} dim Dimension + * @return {Array | Matrix} Difference between array elements in given dimension + */ + return typed(name, { + 'Array | Matrix': function (arr) { + // No dimension specified => assume dimension 0 + if ((0, _is.isMatrix)(arr)) { + return matrix(_diff(arr.toArray())); + } else { + return _diff(arr); + } + }, + 'Array | Matrix, number': function (arr, dim) { + if (!(0, _number.isInteger)(dim)) throw new RangeError('Dimension must be a whole number'); + if ((0, _is.isMatrix)(arr)) { + return matrix(_recursive(arr.toArray(), dim)); + } else { + return _recursive(arr, dim); + } + }, + 'Array, BigNumber': typed.referTo('Array,number', selfAn => (arr, dim) => selfAn(arr, number(dim))), + 'Matrix, BigNumber': typed.referTo('Matrix,number', selfMn => (arr, dim) => selfMn(arr, number(dim))) + }); + + /** + * Recursively find the correct dimension in the array/matrix + * Then Apply _diff to that dimension + * + * @param {Array} arr The array + * @param {number} dim Dimension + * @return {Array} resulting array + */ + function _recursive(arr, dim) { + if ((0, _is.isMatrix)(arr)) { + arr = arr.toArray(); // Makes sure arrays like [ matrix([0, 1]), matrix([1, 0]) ] are processed properly + } + if (!Array.isArray(arr)) { + throw RangeError('Array/Matrix does not have that many dimensions'); + } + if (dim > 0) { + const result = []; + arr.forEach(element => { + result.push(_recursive(element, dim - 1)); + }); + return result; + } else if (dim === 0) { + return _diff(arr); + } else { + throw RangeError('Cannot have negative dimension'); + } + } + + /** + * Difference between elements in the array + * + * @param {Array} arr An array + * @return {Array} resulting array + */ + function _diff(arr) { + const result = []; + const size = arr.length; + for (let i = 1; i < size; i++) { + result.push(_ElementDiff(arr[i - 1], arr[i])); + } + return result; + } + + /** + * Difference between 2 objects + * + * @param {Object} obj1 First object + * @param {Object} obj2 Second object + * @return {Array} resulting array + */ + function _ElementDiff(obj1, obj2) { + // Convert matrices to arrays + if ((0, _is.isMatrix)(obj1)) obj1 = obj1.toArray(); + if ((0, _is.isMatrix)(obj2)) obj2 = obj2.toArray(); + const obj1IsArray = Array.isArray(obj1); + const obj2IsArray = Array.isArray(obj2); + if (obj1IsArray && obj2IsArray) { + return _ArrayDiff(obj1, obj2); + } + if (!obj1IsArray && !obj2IsArray) { + return subtract(obj2, obj1); // Difference is (second - first) NOT (first - second) + } + throw TypeError('Cannot calculate difference between 1 array and 1 non-array'); + } + + /** + * Difference of elements in 2 arrays + * + * @param {Array} arr1 Array 1 + * @param {Array} arr2 Array 2 + * @return {Array} resulting array + */ + function _ArrayDiff(arr1, arr2) { + if (arr1.length !== arr2.length) { + throw RangeError('Not all sub-arrays have the same length'); + } + const result = []; + const size = arr1.length; + for (let i = 0; i < size; i++) { + result.push(_ElementDiff(arr1[i], arr2[i])); + } + return result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/dot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/dot.js new file mode 100644 index 0000000..c04627c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/dot.js @@ -0,0 +1,162 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDot = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'dot'; +const dependencies = ['typed', 'addScalar', 'multiplyScalar', 'conj', 'size']; +const createDot = exports.createDot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + addScalar, + multiplyScalar, + conj, + size + } = _ref; + /** + * Calculate the dot product of two vectors. The dot product of + * `A = [a1, a2, ..., an]` and `B = [b1, b2, ..., bn]` is defined as: + * + * dot(A, B) = conj(a1) * b1 + conj(a2) * b2 + ... + conj(an) * bn + * + * Syntax: + * + * math.dot(x, y) + * + * Examples: + * + * math.dot([2, 4, 1], [2, 2, 3]) // returns number 15 + * math.multiply([2, 4, 1], [2, 2, 3]) // returns number 15 + * + * See also: + * + * multiply, cross + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {number} Returns the dot product of `x` and `y` + */ + return typed(name, { + 'Array | DenseMatrix, Array | DenseMatrix': _denseDot, + 'SparseMatrix, SparseMatrix': _sparseDot + }); + function _validateDim(x, y) { + const xSize = _size(x); + const ySize = _size(y); + let xLen, yLen; + if (xSize.length === 1) { + xLen = xSize[0]; + } else if (xSize.length === 2 && xSize[1] === 1) { + xLen = xSize[0]; + } else { + throw new RangeError('Expected a column vector, instead got a matrix of size (' + xSize.join(', ') + ')'); + } + if (ySize.length === 1) { + yLen = ySize[0]; + } else if (ySize.length === 2 && ySize[1] === 1) { + yLen = ySize[0]; + } else { + throw new RangeError('Expected a column vector, instead got a matrix of size (' + ySize.join(', ') + ')'); + } + if (xLen !== yLen) throw new RangeError('Vectors must have equal length (' + xLen + ' != ' + yLen + ')'); + if (xLen === 0) throw new RangeError('Cannot calculate the dot product of empty vectors'); + return xLen; + } + function _denseDot(a, b) { + const N = _validateDim(a, b); + const adata = (0, _is.isMatrix)(a) ? a._data : a; + const adt = (0, _is.isMatrix)(a) ? a._datatype || a.getDataType() : undefined; + const bdata = (0, _is.isMatrix)(b) ? b._data : b; + const bdt = (0, _is.isMatrix)(b) ? b._datatype || b.getDataType() : undefined; + + // are these 2-dimensional column vectors? (as opposed to 1-dimensional vectors) + const aIsColumn = _size(a).length === 2; + const bIsColumn = _size(b).length === 2; + let add = addScalar; + let mul = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + const dt = adt; + // find signatures that matches (dt, dt) + add = typed.find(addScalar, [dt, dt]); + mul = typed.find(multiplyScalar, [dt, dt]); + } + + // both vectors 1-dimensional + if (!aIsColumn && !bIsColumn) { + let c = mul(conj(adata[0]), bdata[0]); + for (let i = 1; i < N; i++) { + c = add(c, mul(conj(adata[i]), bdata[i])); + } + return c; + } + + // a is 1-dim, b is column + if (!aIsColumn && bIsColumn) { + let c = mul(conj(adata[0]), bdata[0][0]); + for (let i = 1; i < N; i++) { + c = add(c, mul(conj(adata[i]), bdata[i][0])); + } + return c; + } + + // a is column, b is 1-dim + if (aIsColumn && !bIsColumn) { + let c = mul(conj(adata[0][0]), bdata[0]); + for (let i = 1; i < N; i++) { + c = add(c, mul(conj(adata[i][0]), bdata[i])); + } + return c; + } + + // both vectors are column + if (aIsColumn && bIsColumn) { + let c = mul(conj(adata[0][0]), bdata[0][0]); + for (let i = 1; i < N; i++) { + c = add(c, mul(conj(adata[i][0]), bdata[i][0])); + } + return c; + } + } + function _sparseDot(x, y) { + _validateDim(x, y); + const xindex = x._index; + const xvalues = x._values; + const yindex = y._index; + const yvalues = y._values; + + // TODO optimize add & mul using datatype + let c = 0; + const add = addScalar; + const mul = multiplyScalar; + let i = 0; + let j = 0; + while (i < xindex.length && j < yindex.length) { + const I = xindex[i]; + const J = yindex[j]; + if (I < J) { + i++; + continue; + } + if (I > J) { + j++; + continue; + } + if (I === J) { + c = add(c, mul(xvalues[i], yvalues[j])); + i++; + j++; + } + } + return c; + } + + // TODO remove this once #1771 is fixed + function _size(x) { + return (0, _is.isMatrix)(x) ? x.size() : size(x); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs.js new file mode 100644 index 0000000..808caf2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs.js @@ -0,0 +1,335 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createEigs = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _factory = require("../../utils/factory.js"); +var _string = require("../../utils/string.js"); +var _complexEigs = require("./eigs/complexEigs.js"); +var _realSymmetric = require("./eigs/realSymmetric.js"); +var _is = require("../../utils/is.js"); +const name = 'eigs'; + +// The absolute state of math.js's dependency system: +const dependencies = ['config', 'typed', 'matrix', 'addScalar', 'equal', 'subtract', 'abs', 'atan', 'cos', 'sin', 'multiplyScalar', 'divideScalar', 'inv', 'bignumber', 'multiply', 'add', 'larger', 'column', 'flatten', 'number', 'complex', 'sqrt', 'diag', 'size', 'reshape', 'qr', 'usolve', 'usolveAll', 'im', 're', 'smaller', 'matrixFromColumns', 'dot']; +const createEigs = exports.createEigs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + typed, + matrix, + addScalar, + subtract, + equal, + abs, + atan, + cos, + sin, + multiplyScalar, + divideScalar, + inv, + bignumber, + multiply, + add, + larger, + column, + flatten, + number, + complex, + sqrt, + diag, + size, + reshape, + qr, + usolve, + usolveAll, + im, + re, + smaller, + matrixFromColumns, + dot + } = _ref; + const doRealSymmetric = (0, _realSymmetric.createRealSymmetric)({ + config, + addScalar, + subtract, + column, + flatten, + equal, + abs, + atan, + cos, + sin, + multiplyScalar, + inv, + bignumber, + complex, + multiply, + add + }); + const doComplexEigs = (0, _complexEigs.createComplexEigs)({ + config, + addScalar, + subtract, + multiply, + multiplyScalar, + flatten, + divideScalar, + sqrt, + abs, + bignumber, + diag, + size, + reshape, + qr, + inv, + usolve, + usolveAll, + equal, + complex, + larger, + smaller, + matrixFromColumns, + dot + }); + + /** + * Compute eigenvalues and optionally eigenvectors of a square matrix. + * The eigenvalues are sorted by their absolute value, ascending, and + * returned as a vector in the `values` property of the returned project. + * An eigenvalue with algebraic multiplicity k will be listed k times, so + * that the returned `values` vector always has length equal to the size + * of the input matrix. + * + * The `eigenvectors` property of the return value provides the eigenvectors. + * It is an array of plain objects: the `value` property of each gives the + * associated eigenvalue, and the `vector` property gives the eigenvector + * itself. Note that the same `value` property will occur as many times in + * the list provided by `eigenvectors` as the geometric multiplicity of + * that value. + * + * If the algorithm fails to converge, it will throw an error – + * in that case, however, you may still find useful information + * in `err.values` and `err.vectors`. + * + * Note that the 'precision' option does not directly specify the _accuracy_ + * of the returned eigenvalues. Rather, it determines how small an entry + * of the iterative approximations to an upper triangular matrix must be + * in order to be considered zero. The actual accuracy of the returned + * eigenvalues may be greater or less than the precision, depending on the + * conditioning of the matrix and how far apart or close the actual + * eigenvalues are. Note that currently, relatively simple, "traditional" + * methods of eigenvalue computation are being used; this is not a modern, + * high-precision eigenvalue computation. That said, it should typically + * produce fairly reasonable results. + * + * Syntax: + * + * math.eigs(x, [prec]) + * math.eigs(x, {options}) + * + * Examples: + * + * const { eigs, multiply, column, transpose, matrixFromColumns } = math + * const H = [[5, 2.3], [2.3, 1]] + * const ans = eigs(H) // returns {values: [E1,E2...sorted], eigenvectors: [{value: E1, vector: v2}, {value: e, vector: v2}, ...] + * const E = ans.values + * const V = ans.eigenvectors + * multiply(H, V[0].vector)) // returns multiply(E[0], V[0].vector)) + * const U = matrixFromColumns(...V.map(obj => obj.vector)) + * const UTxHxU = multiply(transpose(U), H, U) // diagonalizes H if possible + * E[0] == UTxHxU[0][0] // returns true always + * + * // Compute only approximate eigenvalues: + * const {values} = eigs(H, {eigenvectors: false, precision: 1e-6}) + * + * See also: + * + * inv + * + * @param {Array | Matrix} x Matrix to be diagonalized + * + * @param {number | BigNumber | OptsObject} [opts] Object with keys `precision`, defaulting to config.relTol, and `eigenvectors`, defaulting to true and specifying whether to compute eigenvectors. If just a number, specifies precision. + * @return {{values: Array|Matrix, eigenvectors?: Array}} Object containing an array of eigenvalues and an array of {value: number|BigNumber, vector: Array|Matrix} objects. The eigenvectors property is undefined if eigenvectors were not requested. + * + */ + return typed('eigs', { + // The conversion to matrix in the first two implementations, + // just to convert back to an array right away in + // computeValuesAndVectors, is unfortunate, and should perhaps be + // streamlined. It is done because the Matrix object carries some + // type information about its entries, and so constructing the matrix + // is a roundabout way of doing type detection. + Array: function (x) { + return doEigs(matrix(x)); + }, + 'Array, number|BigNumber': function (x, prec) { + return doEigs(matrix(x), { + precision: prec + }); + }, + 'Array, Object'(x, opts) { + return doEigs(matrix(x), opts); + }, + Matrix: function (mat) { + return doEigs(mat, { + matricize: true + }); + }, + 'Matrix, number|BigNumber': function (mat, prec) { + return doEigs(mat, { + precision: prec, + matricize: true + }); + }, + 'Matrix, Object': function (mat, opts) { + const useOpts = { + matricize: true + }; + (0, _extends2.default)(useOpts, opts); + return doEigs(mat, useOpts); + } + }); + function doEigs(mat) { + var _opts$precision; + let opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + const computeVectors = 'eigenvectors' in opts ? opts.eigenvectors : true; + const prec = (_opts$precision = opts.precision) !== null && _opts$precision !== void 0 ? _opts$precision : config.relTol; + const result = computeValuesAndVectors(mat, prec, computeVectors); + if (opts.matricize) { + result.values = matrix(result.values); + if (computeVectors) { + result.eigenvectors = result.eigenvectors.map(_ref2 => { + let { + value, + vector + } = _ref2; + return { + value, + vector: matrix(vector) + }; + }); + } + } + if (computeVectors) { + Object.defineProperty(result, 'vectors', { + enumerable: false, + // to make sure that the eigenvectors can still be + // converted to string. + get: () => { + throw new Error('eigs(M).vectors replaced with eigs(M).eigenvectors'); + } + }); + } + return result; + } + function computeValuesAndVectors(mat, prec, computeVectors) { + const arr = mat.toArray(); // NOTE: arr is guaranteed to be unaliased + // and so safe to modify in place + const asize = mat.size(); + if (asize.length !== 2 || asize[0] !== asize[1]) { + throw new RangeError(`Matrix must be square (size: ${(0, _string.format)(asize)})`); + } + const N = asize[0]; + if (isReal(arr, N, prec)) { + coerceReal(arr, N); // modifies arr by side effect + + if (isSymmetric(arr, N, prec)) { + const type = coerceTypes(mat, arr, N); // modifies arr by side effect + return doRealSymmetric(arr, N, prec, type, computeVectors); + } + } + const type = coerceTypes(mat, arr, N); // modifies arr by side effect + return doComplexEigs(arr, N, prec, type, computeVectors); + } + + /** @return {boolean} */ + function isSymmetric(arr, N, prec) { + for (let i = 0; i < N; i++) { + for (let j = i; j < N; j++) { + // TODO proper comparison of bignum and frac + if (larger(bignumber(abs(subtract(arr[i][j], arr[j][i]))), prec)) { + return false; + } + } + } + return true; + } + + /** @return {boolean} */ + function isReal(arr, N, prec) { + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + // TODO proper comparison of bignum and frac + if (larger(bignumber(abs(im(arr[i][j]))), prec)) { + return false; + } + } + } + return true; + } + function coerceReal(arr, N) { + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + arr[i][j] = re(arr[i][j]); + } + } + } + + /** @return {'number' | 'BigNumber' | 'Complex'} */ + function coerceTypes(mat, arr, N) { + /** @type {string} */ + const type = mat.datatype(); + if (type === 'number' || type === 'BigNumber' || type === 'Complex') { + return type; + } + let hasNumber = false; + let hasBig = false; + let hasComplex = false; + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + const el = arr[i][j]; + if ((0, _is.isNumber)(el) || (0, _is.isFraction)(el)) { + hasNumber = true; + } else if ((0, _is.isBigNumber)(el)) { + hasBig = true; + } else if ((0, _is.isComplex)(el)) { + hasComplex = true; + } else { + throw TypeError('Unsupported type in Matrix: ' + (0, _is.typeOf)(el)); + } + } + } + if (hasBig && hasComplex) { + console.warn('Complex BigNumbers not supported, this operation will lose precission.'); + } + if (hasComplex) { + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + arr[i][j] = complex(arr[i][j]); + } + } + return 'Complex'; + } + if (hasBig) { + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + arr[i][j] = bignumber(arr[i][j]); + } + } + return 'BigNumber'; + } + if (hasNumber) { + for (let i = 0; i < N; i++) { + for (let j = 0; j < N; j++) { + arr[i][j] = number(arr[i][j]); + } + } + return 'number'; + } else { + throw TypeError('Matrix contains unsupported types only.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/complexEigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/complexEigs.js new file mode 100644 index 0000000..d9c7e42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/complexEigs.js @@ -0,0 +1,701 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createComplexEigs = createComplexEigs; +var _object = require("../../../utils/object.js"); +function createComplexEigs(_ref) { + let { + addScalar, + subtract, + flatten, + multiply, + multiplyScalar, + divideScalar, + sqrt, + abs, + bignumber, + diag, + size, + reshape, + inv, + qr, + usolve, + usolveAll, + equal, + complex, + larger, + smaller, + matrixFromColumns, + dot + } = _ref; + /** + * @param {number[][]} arr the matrix to find eigenvalues of + * @param {number} N size of the matrix + * @param {number|BigNumber} prec precision, anything lower will be considered zero + * @param {'number'|'BigNumber'|'Complex'} type + * @param {boolean} findVectors should we find eigenvectors? + * + * @returns {{ values: number[], vectors: number[][] }} + */ + function complexEigs(arr, N, prec, type) { + let findVectors = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; + // TODO check if any row/col are zero except the diagonal + + // make sure corresponding rows and columns have similar magnitude + // important because of numerical stability + // MODIFIES arr by side effect! + const R = balance(arr, N, prec, type, findVectors); + + // R is the row transformation matrix + // arr = A' = R A R^-1, A is the original matrix + // (if findVectors is false, R is undefined) + // (And so to return to original matrix: A = R^-1 arr R) + + // TODO if magnitudes of elements vary over many orders, + // move greatest elements to the top left corner + + // using similarity transformations, reduce the matrix + // to Hessenberg form (upper triangular plus one subdiagonal row) + // updates the transformation matrix R with new row operationsq + // MODIFIES arr by side effect! + reduceToHessenberg(arr, N, prec, type, findVectors, R); + // still true that original A = R^-1 arr R) + + // find eigenvalues + const { + values, + C + } = iterateUntilTriangular(arr, N, prec, type, findVectors); + + // values is the list of eigenvalues, C is the column + // transformation matrix that transforms arr, the hessenberg + // matrix, to upper triangular + // (So U = C^-1 arr C and the relationship between current arr + // and original A is unchanged.) + + if (findVectors) { + const eigenvectors = findEigenvectors(arr, N, C, R, values, prec, type); + return { + values, + eigenvectors + }; + } + return { + values + }; + } + + /** + * @param {number[][]} arr + * @param {number} N + * @param {number} prec + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {number[][]} + */ + function balance(arr, N, prec, type, findVectors) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const realzero = big ? bignumber(0) : 0; + const one = big ? bignumber(1) : cplx ? complex(1) : 1; + const realone = big ? bignumber(1) : 1; + + // base of the floating-point arithmetic + const radix = big ? bignumber(10) : 2; + const radixSq = multiplyScalar(radix, radix); + + // the diagonal transformation matrix R + let Rdiag; + if (findVectors) { + Rdiag = Array(N).fill(one); + } + + // this isn't the only time we loop thru the matrix... + let last = false; + while (!last) { + // ...haha I'm joking! unless... + last = true; + for (let i = 0; i < N; i++) { + // compute the taxicab norm of i-th column and row + // TODO optimize for complex numbers + let colNorm = realzero; + let rowNorm = realzero; + for (let j = 0; j < N; j++) { + if (i === j) continue; + colNorm = addScalar(colNorm, abs(arr[j][i])); + rowNorm = addScalar(rowNorm, abs(arr[i][j])); + } + if (!equal(colNorm, 0) && !equal(rowNorm, 0)) { + // find integer power closest to balancing the matrix + // (we want to scale only by integer powers of radix, + // so that we don't lose any precision due to round-off) + + let f = realone; + let c = colNorm; + const rowDivRadix = divideScalar(rowNorm, radix); + const rowMulRadix = multiplyScalar(rowNorm, radix); + while (smaller(c, rowDivRadix)) { + c = multiplyScalar(c, radixSq); + f = multiplyScalar(f, radix); + } + while (larger(c, rowMulRadix)) { + c = divideScalar(c, radixSq); + f = divideScalar(f, radix); + } + + // check whether balancing is needed + // condition = (c + rowNorm) / f < 0.95 * (colNorm + rowNorm) + const condition = smaller(divideScalar(addScalar(c, rowNorm), f), multiplyScalar(addScalar(colNorm, rowNorm), 0.95)); + + // apply balancing similarity transformation + if (condition) { + // we should loop once again to check whether + // another rebalancing is needed + last = false; + const g = divideScalar(1, f); + for (let j = 0; j < N; j++) { + if (i === j) { + continue; + } + arr[i][j] = multiplyScalar(arr[i][j], g); + arr[j][i] = multiplyScalar(arr[j][i], f); + } + + // keep track of transformations + if (findVectors) { + Rdiag[i] = multiplyScalar(Rdiag[i], g); + } + } + } + } + } + + // return the diagonal row transformation matrix + return findVectors ? diag(Rdiag) : null; + } + + /** + * @param {number[][]} arr + * @param {number} N + * @param {number} prec + * @param {'number'|'BigNumber'|'Complex'} type + * @param {boolean} findVectors + * @param {number[][]} R the row transformation matrix that will be modified + */ + function reduceToHessenberg(arr, N, prec, type, findVectors, R) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const zero = big ? bignumber(0) : cplx ? complex(0) : 0; + if (big) { + prec = bignumber(prec); + } + for (let i = 0; i < N - 2; i++) { + // Find the largest subdiag element in the i-th col + + let maxIndex = 0; + let max = zero; + for (let j = i + 1; j < N; j++) { + const el = arr[j][i]; + if (smaller(abs(max), abs(el))) { + max = el; + maxIndex = j; + } + } + + // This col is pivoted, no need to do anything + if (smaller(abs(max), prec)) { + continue; + } + if (maxIndex !== i + 1) { + // Interchange maxIndex-th and (i+1)-th row + const tmp1 = arr[maxIndex]; + arr[maxIndex] = arr[i + 1]; + arr[i + 1] = tmp1; + + // Interchange maxIndex-th and (i+1)-th column + for (let j = 0; j < N; j++) { + const tmp2 = arr[j][maxIndex]; + arr[j][maxIndex] = arr[j][i + 1]; + arr[j][i + 1] = tmp2; + } + + // keep track of transformations + if (findVectors) { + const tmp3 = R[maxIndex]; + R[maxIndex] = R[i + 1]; + R[i + 1] = tmp3; + } + } + + // Reduce following rows and columns + for (let j = i + 2; j < N; j++) { + const n = divideScalar(arr[j][i], max); + if (n === 0) { + continue; + } + + // from j-th row subtract n-times (i+1)th row + for (let k = 0; k < N; k++) { + arr[j][k] = subtract(arr[j][k], multiplyScalar(n, arr[i + 1][k])); + } + + // to (i+1)th column add n-times j-th column + for (let k = 0; k < N; k++) { + arr[k][i + 1] = addScalar(arr[k][i + 1], multiplyScalar(n, arr[k][j])); + } + + // keep track of transformations + if (findVectors) { + for (let k = 0; k < N; k++) { + R[j][k] = subtract(R[j][k], multiplyScalar(n, R[i + 1][k])); + } + } + } + } + return R; + } + + /** + * @returns {{values: values, C: Matrix}} + * @see Press, Wiliams: Numerical recipes in Fortran 77 + * @see https://en.wikipedia.org/wiki/QR_algorithm + */ + function iterateUntilTriangular(A, N, prec, type, findVectors) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const one = big ? bignumber(1) : cplx ? complex(1) : 1; + if (big) { + prec = bignumber(prec); + } + + // The Francis Algorithm + // The core idea of this algorithm is that doing successive + // A' = QtAQ transformations will eventually converge to block- + // upper-triangular with diagonal blocks either 1x1 or 2x2. + // The Q here is the one from the QR decomposition, A = QR. + // Since the eigenvalues of a block-upper-triangular matrix are + // the eigenvalues of its diagonal blocks and we know how to find + // eigenvalues of a 2x2 matrix, we know the eigenvalues of A. + + let arr = (0, _object.clone)(A); + + // the list of converged eigenvalues + const lambdas = []; + + // size of arr, which will get smaller as eigenvalues converge + let n = N; + + // the diagonal of the block-diagonal matrix that turns + // converged 2x2 matrices into upper triangular matrices + const Sdiag = []; + + // N×N matrix describing the overall transformation done during the QR algorithm + let Qtotal = findVectors ? diag(Array(N).fill(one)) : undefined; + + // nxn matrix describing the QR transformations done since last convergence + let Qpartial = findVectors ? diag(Array(n).fill(one)) : undefined; + + // last eigenvalue converged before this many steps + let lastConvergenceBefore = 0; + while (lastConvergenceBefore <= 100) { + lastConvergenceBefore += 1; + + // TODO if the convergence is slow, do something clever + + // Perform the factorization + + const k = arr[n - 1][n - 1]; // TODO this is apparently a somewhat + // old-fashioned choice; ideally set close to an eigenvalue, or + // perhaps better yet switch to the implicit QR version that is sometimes + // specifically called the "Francis algorithm" that is alluded to + // in the following TODO. (Or perhaps we switch to an independently + // optimized third-party package for the linear algebra operations...) + + for (let i = 0; i < n; i++) { + arr[i][i] = subtract(arr[i][i], k); + } + + // TODO do an implicit QR transformation + const { + Q, + R + } = qr(arr); + arr = multiply(R, Q); + for (let i = 0; i < n; i++) { + arr[i][i] = addScalar(arr[i][i], k); + } + + // keep track of transformations + if (findVectors) { + Qpartial = multiply(Qpartial, Q); + } + + // The rightmost diagonal element converged to an eigenvalue + if (n === 1 || smaller(abs(arr[n - 1][n - 2]), prec)) { + lastConvergenceBefore = 0; + lambdas.push(arr[n - 1][n - 1]); + + // keep track of transformations + if (findVectors) { + Sdiag.unshift([[1]]); + inflateMatrix(Qpartial, N); + Qtotal = multiply(Qtotal, Qpartial); + if (n > 1) { + Qpartial = diag(Array(n - 1).fill(one)); + } + } + + // reduce the matrix size + n -= 1; + arr.pop(); + for (let i = 0; i < n; i++) { + arr[i].pop(); + } + + // The rightmost diagonal 2x2 block converged + } else if (n === 2 || smaller(abs(arr[n - 2][n - 3]), prec)) { + lastConvergenceBefore = 0; + const ll = eigenvalues2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1]); + lambdas.push(...ll); + + // keep track of transformations + if (findVectors) { + Sdiag.unshift(jordanBase2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1], ll[0], ll[1], prec, type)); + inflateMatrix(Qpartial, N); + Qtotal = multiply(Qtotal, Qpartial); + if (n > 2) { + Qpartial = diag(Array(n - 2).fill(one)); + } + } + + // reduce the matrix size + n -= 2; + arr.pop(); + arr.pop(); + for (let i = 0; i < n; i++) { + arr[i].pop(); + arr[i].pop(); + } + } + if (n === 0) { + break; + } + } + + // standard sorting + lambdas.sort((a, b) => +subtract(abs(a), abs(b))); + + // the algorithm didn't converge + if (lastConvergenceBefore > 100) { + const err = Error('The eigenvalues failed to converge. Only found these eigenvalues: ' + lambdas.join(', ')); + err.values = lambdas; + err.vectors = []; + throw err; + } + + // combine the overall QR transformation Qtotal with the subsequent + // transformation S that turns the diagonal 2x2 blocks to upper triangular + const C = findVectors ? multiply(Qtotal, blockDiag(Sdiag, N)) : undefined; + return { + values: lambdas, + C + }; + } + + /** + * @param {Matrix} A hessenberg-form matrix + * @param {number} N size of A + * @param {Matrix} C column transformation matrix that turns A into upper triangular + * @param {Matrix} R similarity that turns original matrix into A + * @param {number[]} values array of eigenvalues of A + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {number[][]} eigenvalues + */ + function findEigenvectors(A, N, C, R, values, prec, type) { + const Cinv = inv(C); + const U = multiply(Cinv, A, C); + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const zero = big ? bignumber(0) : cplx ? complex(0) : 0; + const one = big ? bignumber(1) : cplx ? complex(1) : 1; + + // turn values into a kind of "multiset" + // this way it is easier to find eigenvectors + const uniqueValues = []; + const multiplicities = []; + for (const lambda of values) { + const i = indexOf(uniqueValues, lambda, equal); + if (i === -1) { + uniqueValues.push(lambda); + multiplicities.push(1); + } else { + multiplicities[i] += 1; + } + } + + // find eigenvectors by solving U − lambdaE = 0 + // TODO replace with an iterative eigenvector algorithm + // (this one might fail for imprecise eigenvalues) + + const vectors = []; + const len = uniqueValues.length; + const b = Array(N).fill(zero); + const E = diag(Array(N).fill(one)); + for (let i = 0; i < len; i++) { + const lambda = uniqueValues[i]; + const S = subtract(U, multiply(lambda, E)); // the characteristic matrix + + let solutions = usolveAll(S, b); + solutions.shift(); // ignore the null vector + + // looks like we missed something, try inverse iteration + // But if that fails, just presume that the original matrix truly + // was defective. + while (solutions.length < multiplicities[i]) { + const approxVec = inverseIterate(S, N, solutions, prec, type); + if (approxVec === null) { + break; + } // no more vectors were found + solutions.push(approxVec); + } + + // Transform back into original array coordinates + const correction = multiply(inv(R), C); + solutions = solutions.map(v => multiply(correction, v)); + vectors.push(...solutions.map(v => ({ + value: lambda, + vector: flatten(v) + }))); + } + return vectors; + } + + /** + * Compute the eigenvalues of an 2x2 matrix + * @return {[number,number]} + */ + function eigenvalues2x2(a, b, c, d) { + // lambda_+- = 1/2 trA +- 1/2 sqrt( tr^2 A - 4 detA ) + const trA = addScalar(a, d); + const detA = subtract(multiplyScalar(a, d), multiplyScalar(b, c)); + const x = multiplyScalar(trA, 0.5); + const y = multiplyScalar(sqrt(subtract(multiplyScalar(trA, trA), multiplyScalar(4, detA))), 0.5); + return [addScalar(x, y), subtract(x, y)]; + } + + /** + * For an 2x2 matrix compute the transformation matrix S, + * so that SAS^-1 is an upper triangular matrix + * @return {[[number,number],[number,number]]} + * @see https://math.berkeley.edu/~ogus/old/Math_54-05/webfoils/jordan.pdf + * @see http://people.math.harvard.edu/~knill/teaching/math21b2004/exhibits/2dmatrices/index.html + */ + function jordanBase2x2(a, b, c, d, l1, l2, prec, type) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const zero = big ? bignumber(0) : cplx ? complex(0) : 0; + const one = big ? bignumber(1) : cplx ? complex(1) : 1; + + // matrix is already upper triangular + // return an identity matrix + if (smaller(abs(c), prec)) { + return [[one, zero], [zero, one]]; + } + + // matrix is diagonalizable + // return its eigenvectors as columns + if (larger(abs(subtract(l1, l2)), prec)) { + return [[subtract(l1, d), subtract(l2, d)], [c, c]]; + } + + // matrix is not diagonalizable + // compute diagonal elements of N = A - lambdaI + const na = subtract(a, l1); + const nd = subtract(d, l1); + + // col(N,2) = 0 implies S = ( col(N,1), e_1 ) + // col(N,2) != 0 implies S = ( col(N,2), e_2 ) + + if (smaller(abs(b), prec) && smaller(abs(nd), prec)) { + return [[na, one], [c, zero]]; + } else { + return [[b, zero], [nd, one]]; + } + } + + /** + * Enlarge the matrix from nxn to NxN, setting the new + * elements to 1 on diagonal and 0 elsewhere + */ + function inflateMatrix(arr, N) { + // add columns + for (let i = 0; i < arr.length; i++) { + arr[i].push(...Array(N - arr[i].length).fill(0)); + } + + // add rows + for (let i = arr.length; i < N; i++) { + arr.push(Array(N).fill(0)); + arr[i][i] = 1; + } + return arr; + } + + /** + * Create a block-diagonal matrix with the given square matrices on the diagonal + * @param {Matrix[] | number[][][]} arr array of matrices to be placed on the diagonal + * @param {number} N the size of the resulting matrix + */ + function blockDiag(arr, N) { + const M = []; + for (let i = 0; i < N; i++) { + M[i] = Array(N).fill(0); + } + let I = 0; + for (const sub of arr) { + const n = sub.length; + for (let i = 0; i < n; i++) { + for (let j = 0; j < n; j++) { + M[I + i][I + j] = sub[i][j]; + } + } + I += n; + } + return M; + } + + /** + * Finds the index of an element in an array using a custom equality function + * @template T + * @param {Array} arr array in which to search + * @param {T} el the element to find + * @param {function(T, T): boolean} fn the equality function, first argument is an element of `arr`, the second is always `el` + * @returns {number} the index of `el`, or -1 when it's not in `arr` + */ + function indexOf(arr, el, fn) { + for (let i = 0; i < arr.length; i++) { + if (fn(arr[i], el)) { + return i; + } + } + return -1; + } + + /** + * Provided a near-singular upper-triangular matrix A and a list of vectors, + * finds an eigenvector of A with the smallest eigenvalue, which is orthogonal + * to each vector in the list + * @template T + * @param {T[][]} A near-singular square matrix + * @param {number} N dimension + * @param {T[][]} orthog list of vectors + * @param {number} prec epsilon + * @param {'number'|'BigNumber'|'Complex'} type + * @return {T[] | null} eigenvector + * + * @see Numerical Recipes for Fortran 77 – 11.7 Eigenvalues or Eigenvectors by Inverse Iteration + */ + function inverseIterate(A, N, orthog, prec, type) { + const largeNum = type === 'BigNumber' ? bignumber(1000) : 1000; + let b; // the vector + + // you better choose a random vector before I count to five + let i = 0; + for (; i < 5; ++i) { + b = randomOrthogonalVector(N, orthog, type); + try { + b = usolve(A, b); + } catch (_unused) { + // That direction didn't work, likely because the original matrix + // was defective. But still make the full number of tries... + continue; + } + if (larger(norm(b), largeNum)) { + break; + } + } + if (i >= 5) { + return null; // couldn't find any orthogonal vector in the image + } + + // you better converge before I count to ten + i = 0; + while (true) { + const c = usolve(A, b); + if (smaller(norm(orthogonalComplement(b, [c])), prec)) { + break; + } + if (++i >= 10) { + return null; + } + b = normalize(c); + } + return b; + } + + /** + * Generates a random unit vector of dimension N, orthogonal to each vector in the list + * @template T + * @param {number} N dimension + * @param {T[][]} orthog list of vectors + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {T[]} random vector + */ + function randomOrthogonalVector(N, orthog, type) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + + // generate random vector with the correct type + let v = Array(N).fill(0).map(_ => 2 * Math.random() - 1); + if (big) { + v = v.map(n => bignumber(n)); + } + if (cplx) { + v = v.map(n => complex(n)); + } + + // project to orthogonal complement + v = orthogonalComplement(v, orthog); + + // normalize + return normalize(v, type); + } + + /** + * Project vector v to the orthogonal complement of an array of vectors + */ + function orthogonalComplement(v, orthog) { + const vectorShape = size(v); + for (let w of orthog) { + w = reshape(w, vectorShape); // make sure this is just a vector computation + // v := v − (w, v)/|w|^2 w + v = subtract(v, multiply(divideScalar(dot(w, v), dot(w, w)), w)); + } + return v; + } + + /** + * Calculate the norm of a vector. + * We can't use math.norm because factory can't handle circular dependency. + * Seriously, I'm really fed up with factory. + */ + function norm(v) { + return abs(sqrt(dot(v, v))); + } + + /** + * Normalize a vector + * @template T + * @param {T[]} v + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {T[]} normalized vec + */ + function normalize(v, type) { + const big = type === 'BigNumber'; + const cplx = type === 'Complex'; + const one = big ? bignumber(1) : cplx ? complex(1) : 1; + return multiply(divideScalar(one, norm(v)), v); + } + return complexEigs; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/realSymmetric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/realSymmetric.js new file mode 100644 index 0000000..5ed0f0f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/eigs/realSymmetric.js @@ -0,0 +1,303 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRealSymmetric = createRealSymmetric; +var _object = require("../../../utils/object.js"); +function createRealSymmetric(_ref) { + let { + config, + addScalar, + subtract, + abs, + atan, + cos, + sin, + multiplyScalar, + inv, + bignumber, + multiply, + add + } = _ref; + /** + * @param {number[] | BigNumber[]} arr + * @param {number} N + * @param {number} prec + * @param {'number' | 'BigNumber'} type + */ + function main(arr, N) { + let prec = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : config.relTol; + let type = arguments.length > 3 ? arguments[3] : undefined; + let computeVectors = arguments.length > 4 ? arguments[4] : undefined; + if (type === 'number') { + return diag(arr, prec, computeVectors); + } + if (type === 'BigNumber') { + return diagBig(arr, prec, computeVectors); + } + throw TypeError('Unsupported data type: ' + type); + } + + // diagonalization implementation for number (efficient) + function diag(x, precision, computeVectors) { + const N = x.length; + const e0 = Math.abs(precision / N); + let psi; + let Sij; + if (computeVectors) { + Sij = new Array(N); + // Sij is Identity Matrix + for (let i = 0; i < N; i++) { + Sij[i] = Array(N).fill(0); + Sij[i][i] = 1.0; + } + } + // initial error + let Vab = getAij(x); + while (Math.abs(Vab[1]) >= Math.abs(e0)) { + const i = Vab[0][0]; + const j = Vab[0][1]; + psi = getTheta(x[i][i], x[j][j], x[i][j]); + x = x1(x, psi, i, j); + if (computeVectors) Sij = Sij1(Sij, psi, i, j); + Vab = getAij(x); + } + const Ei = Array(N).fill(0); // eigenvalues + for (let i = 0; i < N; i++) { + Ei[i] = x[i][i]; + } + return sorting((0, _object.clone)(Ei), Sij, computeVectors); + } + + // diagonalization implementation for bigNumber + function diagBig(x, precision, computeVectors) { + const N = x.length; + const e0 = abs(precision / N); + let psi; + let Sij; + if (computeVectors) { + Sij = new Array(N); + // Sij is Identity Matrix + for (let i = 0; i < N; i++) { + Sij[i] = Array(N).fill(0); + Sij[i][i] = 1.0; + } + } + // initial error + let Vab = getAijBig(x); + while (abs(Vab[1]) >= abs(e0)) { + const i = Vab[0][0]; + const j = Vab[0][1]; + psi = getThetaBig(x[i][i], x[j][j], x[i][j]); + x = x1Big(x, psi, i, j); + if (computeVectors) Sij = Sij1Big(Sij, psi, i, j); + Vab = getAijBig(x); + } + const Ei = Array(N).fill(0); // eigenvalues + for (let i = 0; i < N; i++) { + Ei[i] = x[i][i]; + } + // return [clone(Ei), clone(Sij)] + return sorting((0, _object.clone)(Ei), Sij, computeVectors); + } + + // get angle + function getTheta(aii, ajj, aij) { + const denom = ajj - aii; + if (Math.abs(denom) <= config.relTol) { + return Math.PI / 4.0; + } else { + return 0.5 * Math.atan(2.0 * aij / (ajj - aii)); + } + } + + // get angle + function getThetaBig(aii, ajj, aij) { + const denom = subtract(ajj, aii); + if (abs(denom) <= config.relTol) { + return bignumber(-1).acos().div(4); + } else { + return multiplyScalar(0.5, atan(multiply(2.0, aij, inv(denom)))); + } + } + + // update eigvec + function Sij1(Sij, theta, i, j) { + const N = Sij.length; + const c = Math.cos(theta); + const s = Math.sin(theta); + const Ski = Array(N).fill(0); + const Skj = Array(N).fill(0); + for (let k = 0; k < N; k++) { + Ski[k] = c * Sij[k][i] - s * Sij[k][j]; + Skj[k] = s * Sij[k][i] + c * Sij[k][j]; + } + for (let k = 0; k < N; k++) { + Sij[k][i] = Ski[k]; + Sij[k][j] = Skj[k]; + } + return Sij; + } + // update eigvec for overlap + function Sij1Big(Sij, theta, i, j) { + const N = Sij.length; + const c = cos(theta); + const s = sin(theta); + const Ski = Array(N).fill(bignumber(0)); + const Skj = Array(N).fill(bignumber(0)); + for (let k = 0; k < N; k++) { + Ski[k] = subtract(multiplyScalar(c, Sij[k][i]), multiplyScalar(s, Sij[k][j])); + Skj[k] = addScalar(multiplyScalar(s, Sij[k][i]), multiplyScalar(c, Sij[k][j])); + } + for (let k = 0; k < N; k++) { + Sij[k][i] = Ski[k]; + Sij[k][j] = Skj[k]; + } + return Sij; + } + + // update matrix + function x1Big(Hij, theta, i, j) { + const N = Hij.length; + const c = bignumber(cos(theta)); + const s = bignumber(sin(theta)); + const c2 = multiplyScalar(c, c); + const s2 = multiplyScalar(s, s); + const Aki = Array(N).fill(bignumber(0)); + const Akj = Array(N).fill(bignumber(0)); + // 2cs Hij + const csHij = multiply(bignumber(2), c, s, Hij[i][j]); + // Aii + const Aii = addScalar(subtract(multiplyScalar(c2, Hij[i][i]), csHij), multiplyScalar(s2, Hij[j][j])); + const Ajj = add(multiplyScalar(s2, Hij[i][i]), csHij, multiplyScalar(c2, Hij[j][j])); + // 0 to i + for (let k = 0; k < N; k++) { + Aki[k] = subtract(multiplyScalar(c, Hij[i][k]), multiplyScalar(s, Hij[j][k])); + Akj[k] = addScalar(multiplyScalar(s, Hij[i][k]), multiplyScalar(c, Hij[j][k])); + } + // Modify Hij + Hij[i][i] = Aii; + Hij[j][j] = Ajj; + Hij[i][j] = bignumber(0); + Hij[j][i] = bignumber(0); + // 0 to i + for (let k = 0; k < N; k++) { + if (k !== i && k !== j) { + Hij[i][k] = Aki[k]; + Hij[k][i] = Aki[k]; + Hij[j][k] = Akj[k]; + Hij[k][j] = Akj[k]; + } + } + return Hij; + } + + // update matrix + function x1(Hij, theta, i, j) { + const N = Hij.length; + const c = Math.cos(theta); + const s = Math.sin(theta); + const c2 = c * c; + const s2 = s * s; + const Aki = Array(N).fill(0); + const Akj = Array(N).fill(0); + // Aii + const Aii = c2 * Hij[i][i] - 2 * c * s * Hij[i][j] + s2 * Hij[j][j]; + const Ajj = s2 * Hij[i][i] + 2 * c * s * Hij[i][j] + c2 * Hij[j][j]; + // 0 to i + for (let k = 0; k < N; k++) { + Aki[k] = c * Hij[i][k] - s * Hij[j][k]; + Akj[k] = s * Hij[i][k] + c * Hij[j][k]; + } + // Modify Hij + Hij[i][i] = Aii; + Hij[j][j] = Ajj; + Hij[i][j] = 0; + Hij[j][i] = 0; + // 0 to i + for (let k = 0; k < N; k++) { + if (k !== i && k !== j) { + Hij[i][k] = Aki[k]; + Hij[k][i] = Aki[k]; + Hij[j][k] = Akj[k]; + Hij[k][j] = Akj[k]; + } + } + return Hij; + } + + // get max off-diagonal value from Upper Diagonal + function getAij(Mij) { + const N = Mij.length; + let maxMij = 0; + let maxIJ = [0, 1]; + for (let i = 0; i < N; i++) { + for (let j = i + 1; j < N; j++) { + if (Math.abs(maxMij) < Math.abs(Mij[i][j])) { + maxMij = Math.abs(Mij[i][j]); + maxIJ = [i, j]; + } + } + } + return [maxIJ, maxMij]; + } + + // get max off-diagonal value from Upper Diagonal + function getAijBig(Mij) { + const N = Mij.length; + let maxMij = 0; + let maxIJ = [0, 1]; + for (let i = 0; i < N; i++) { + for (let j = i + 1; j < N; j++) { + if (abs(maxMij) < abs(Mij[i][j])) { + maxMij = abs(Mij[i][j]); + maxIJ = [i, j]; + } + } + } + return [maxIJ, maxMij]; + } + + // sort results + function sorting(E, S, computeVectors) { + const N = E.length; + const values = Array(N); + let vecs; + if (computeVectors) { + vecs = Array(N); + for (let k = 0; k < N; k++) { + vecs[k] = Array(N); + } + } + for (let i = 0; i < N; i++) { + let minID = 0; + let minE = E[0]; + for (let j = 0; j < E.length; j++) { + if (abs(E[j]) < abs(minE)) { + minID = j; + minE = E[minID]; + } + } + values[i] = E.splice(minID, 1)[0]; + if (computeVectors) { + for (let k = 0; k < N; k++) { + vecs[i][k] = S[k][minID]; + S[k].splice(minID, 1); + } + } + } + if (!computeVectors) return { + values + }; + const eigenvectors = vecs.map((vector, i) => ({ + value: values[i], + vector + })); + return { + values, + eigenvectors + }; + } + return main; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/expm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/expm.js new file mode 100644 index 0000000..f44e112 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/expm.js @@ -0,0 +1,160 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createExpm = void 0; +var _is = require("../../utils/is.js"); +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +const name = 'expm'; +const dependencies = ['typed', 'abs', 'add', 'identity', 'inv', 'multiply']; +const createExpm = exports.createExpm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + add, + identity, + inv, + multiply + } = _ref; + /** + * Compute the matrix exponential, expm(A) = e^A. The matrix must be square. + * Not to be confused with exp(a), which performs element-wise + * exponentiation. + * + * The exponential is calculated using the Padé approximant with scaling and + * squaring; see "Nineteen Dubious Ways to Compute the Exponential of a + * Matrix," by Moler and Van Loan. + * + * Syntax: + * + * math.expm(x) + * + * Examples: + * + * const A = [[0,2],[0,0]] + * math.expm(A) // returns [[1,2],[0,1]] + * + * See also: + * + * exp + * + * @param {Matrix} x A square Matrix + * @return {Matrix} The exponential of x + */ + return typed(name, { + Matrix: function (A) { + // Check matrix size + const size = A.size(); + if (size.length !== 2 || size[0] !== size[1]) { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + const n = size[0]; + + // Desired accuracy of the approximant (The actual accuracy + // will be affected by round-off error) + const eps = 1e-15; + + // The Padé approximant is not so accurate when the values of A + // are "large", so scale A by powers of two. Then compute the + // exponential, and square the result repeatedly according to + // the identity e^A = (e^(A/m))^m + + // Compute infinity-norm of A, ||A||, to see how "big" it is + const infNorm = infinityNorm(A); + + // Find the optimal scaling factor and number of terms in the + // Padé approximant to reach the desired accuracy + const params = findParams(infNorm, eps); + const q = params.q; + const j = params.j; + + // The Pade approximation to e^A is: + // Rqq(A) = Dqq(A) ^ -1 * Nqq(A) + // where + // Nqq(A) = sum(i=0, q, (2q-i)!p! / [ (2q)!i!(q-i)! ] A^i + // Dqq(A) = sum(i=0, q, (2q-i)!q! / [ (2q)!i!(q-i)! ] (-A)^i + + // Scale A by 1 / 2^j + const Apos = multiply(A, Math.pow(2, -j)); + + // The i=0 term is just the identity matrix + let N = identity(n); + let D = identity(n); + + // Initialization (i=0) + let factor = 1; + + // Initialization (i=1) + let AposToI = Apos; // Cloning not necessary + let alternate = -1; + for (let i = 1; i <= q; i++) { + if (i > 1) { + AposToI = multiply(AposToI, Apos); + alternate = -alternate; + } + factor = factor * (q - i + 1) / ((2 * q - i + 1) * i); + N = add(N, multiply(factor, AposToI)); + D = add(D, multiply(factor * alternate, AposToI)); + } + let R = multiply(inv(D), N); + + // Square j times + for (let i = 0; i < j; i++) { + R = multiply(R, R); + } + return (0, _is.isSparseMatrix)(A) ? A.createSparseMatrix(R) : R; + } + }); + function infinityNorm(A) { + const n = A.size()[0]; + let infNorm = 0; + for (let i = 0; i < n; i++) { + let rowSum = 0; + for (let j = 0; j < n; j++) { + rowSum += abs(A.get([i, j])); + } + infNorm = Math.max(rowSum, infNorm); + } + return infNorm; + } + + /** + * Find the best parameters for the Pade approximant given + * the matrix norm and desired accuracy. Returns the first acceptable + * combination in order of increasing computational load. + */ + function findParams(infNorm, eps) { + const maxSearchSize = 30; + for (let k = 0; k < maxSearchSize; k++) { + for (let q = 0; q <= k; q++) { + const j = k - q; + if (errorEstimate(infNorm, q, j) < eps) { + return { + q, + j + }; + } + } + } + throw new Error('Could not find acceptable parameters to compute the matrix exponential (try increasing maxSearchSize in expm.js)'); + } + + /** + * Returns the estimated error of the Pade approximant for the given + * parameters. + */ + function errorEstimate(infNorm, q, j) { + let qfac = 1; + for (let i = 2; i <= q; i++) { + qfac *= i; + } + let twoqfac = qfac; + for (let i = q + 1; i <= 2 * q; i++) { + twoqfac *= i; + } + const twoqp1fac = twoqfac * (2 * q + 1); + return 8.0 * Math.pow(infNorm / Math.pow(2, j), 2 * q) * qfac * qfac / (twoqfac * twoqp1fac); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/fft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/fft.js new file mode 100644 index 0000000..ddab998 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/fft.js @@ -0,0 +1,134 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFft = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'fft'; +const dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'divideScalar', 'exp', 'tau', 'i', 'dotDivide', 'conj', 'pow', 'ceil', 'log2']; +const createFft = exports.createFft = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + addScalar, + multiplyScalar, + divideScalar, + exp, + tau, + i: I, + dotDivide, + conj, + pow, + ceil, + log2 + } = _ref; + /** + * Calculate N-dimensional Fourier transform + * + * Syntax: + * + * math.fft(arr) + * + * Examples: + * + * math.fft([[1, 0], [1, 0]]) // returns [[{re:2, im:0}, {re:2, im:0}], [{re:0, im:0}, {re:0, im:0}]] + * + * + * See Also: + * + * ifft + * + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + return typed(name, { + Array: _ndFft, + Matrix: function (matrix) { + return matrix.create(_ndFft(matrix.valueOf()), matrix.datatype()); + } + }); + + /** + * Perform an N-dimensional Fourier transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _ndFft(arr) { + const size = (0, _array.arraySize)(arr); + if (size.length === 1) return _fft(arr, size[0]); + // ndFft along dimension 1,...,N-1 then 1dFft along dimension 0 + return _1dFft(arr.map(slice => _ndFft(slice, size.slice(1))), 0); + } + + /** + * Perform an 1-dimensional Fourier transform + * + * @param {Array} arr The array + * @param {number} dim dimension of the array to perform on + * @return {Array} resulting array + */ + function _1dFft(arr, dim) { + const size = (0, _array.arraySize)(arr); + if (dim !== 0) return new Array(size[0]).fill(0).map((_, i) => _1dFft(arr[i], dim - 1)); + if (size.length === 1) return _fft(arr); + function _transpose(arr) { + // Swap first 2 dimensions + const size = (0, _array.arraySize)(arr); + return new Array(size[1]).fill(0).map((_, j) => new Array(size[0]).fill(0).map((_, i) => arr[i][j])); + } + return _transpose(_1dFft(_transpose(arr), 1)); + } + /** + * Perform an 1-dimensional non-power-of-2 Fourier transform using Chirp-Z Transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _czt(arr) { + const n = arr.length; + const w = exp(divideScalar(multiplyScalar(-1, multiplyScalar(I, tau)), n)); + const chirp = []; + for (let i = 1 - n; i < n; i++) { + chirp.push(pow(w, divideScalar(pow(i, 2), 2))); + } + const N2 = pow(2, ceil(log2(n + n - 1))); + const xp = [...new Array(n).fill(0).map((_, i) => multiplyScalar(arr[i], chirp[n - 1 + i])), ...new Array(N2 - n).fill(0)]; + const ichirp = [...new Array(n + n - 1).fill(0).map((_, i) => divideScalar(1, chirp[i])), ...new Array(N2 - (n + n - 1)).fill(0)]; + const fftXp = _fft(xp); + const fftIchirp = _fft(ichirp); + const fftProduct = new Array(N2).fill(0).map((_, i) => multiplyScalar(fftXp[i], fftIchirp[i])); + const ifftProduct = dotDivide(conj(_ndFft(conj(fftProduct))), N2); + const ret = []; + for (let i = n - 1; i < n + n - 1; i++) { + ret.push(multiplyScalar(ifftProduct[i], chirp[i])); + } + return ret; + } + /** + * Perform an 1-dimensional Fourier transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _fft(arr) { + const len = arr.length; + if (len === 1) return [arr[0]]; + if (len % 2 === 0) { + const ret = [..._fft(arr.filter((_, i) => i % 2 === 0), len / 2), ..._fft(arr.filter((_, i) => i % 2 === 1), len / 2)]; + for (let k = 0; k < len / 2; k++) { + const p = ret[k]; + const q = multiplyScalar(ret[k + len / 2], exp(multiplyScalar(multiplyScalar(tau, I), divideScalar(-k, len)))); + ret[k] = addScalar(p, q); + ret[k + len / 2] = addScalar(p, multiplyScalar(-1, q)); + } + return ret; + } else { + // use chirp-z transform for non-power-of-2 FFT + return _czt(arr); + } + // throw new Error('Can only calculate FFT of power-of-two size') + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/filter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/filter.js new file mode 100644 index 0000000..e6d5021 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/filter.js @@ -0,0 +1,70 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFilter = void 0; +var _optimizeCallback = require("../../utils/optimizeCallback.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'filter'; +const dependencies = ['typed']; +const createFilter = exports.createFilter = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Filter the items in an array or one dimensional matrix. + * + * Syntax: + * + * math.filter(x, test) + * + * Examples: + * + * function isPositive (x) { + * return x > 0 + * } + * math.filter([6, -2, -1, 4, 3], isPositive) // returns [6, 4, 3] + * + * math.filter(["23", "foo", "100", "55", "bar"], /[0-9]+/) // returns ["23", "100", "55"] + * + * See also: + * + * forEach, map, sort + * + * @param {Matrix | Array} x A one dimensional matrix or array to filter + * @param {Function | RegExp} test + * A function or regular expression to test items. + * All entries for which `test` returns true are returned. + * When `test` is a function, it is invoked with three parameters: + * the value of the element, the index of the element, and the + * matrix/array being traversed. The function must return a boolean. + * @return {Matrix | Array} Returns the filtered matrix. + */ + return typed('filter', { + 'Array, function': _filterCallback, + 'Matrix, function': function (x, test) { + return x.create(_filterCallback(x.valueOf(), test), x.datatype()); + }, + 'Array, RegExp': _array.filterRegExp, + 'Matrix, RegExp': function (x, test) { + return x.create((0, _array.filterRegExp)(x.valueOf(), test), x.datatype()); + } + }); +}); + +/** + * Filter values in a callback given a callback function + * @param {Array} x + * @param {Function} callback + * @return {Array} Returns the filtered array + * @private + */ +function _filterCallback(x, callback) { + const fastCallback = (0, _optimizeCallback.optimizeCallback)(callback, x, 'filter'); + return (0, _array.filter)(x, function (value, index, array) { + // invoke the callback function with the right number of arguments + return fastCallback(value, [index], array); + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/flatten.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/flatten.js new file mode 100644 index 0000000..8c5fc76 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/flatten.js @@ -0,0 +1,44 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFlatten = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'flatten'; +const dependencies = ['typed']; +const createFlatten = exports.createFlatten = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Flatten a multidimensional matrix into a single dimensional matrix. + * A new matrix is returned, the original matrix is left untouched. + * + * Syntax: + * + * math.flatten(x) + * + * Examples: + * + * math.flatten([[1,2], [3,4]]) // returns [1, 2, 3, 4] + * + * See also: + * + * concat, resize, size, squeeze + * + * @param {Matrix | Array} x Matrix to be flattened + * @return {Matrix | Array} Returns the flattened matrix + */ + return typed(name, { + Array: function (x) { + return (0, _array.flatten)(x); + }, + Matrix: function (x) { + // Return the same matrix type as x (Dense or Sparse Matrix) + // Return the same data type as x + return x.create((0, _array.flatten)(x.toArray()), x.datatype()); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/forEach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/forEach.js new file mode 100644 index 0000000..5f6b40f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/forEach.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createForEach = void 0; +var _optimizeCallback = require("../../utils/optimizeCallback.js"); +var _factory = require("../../utils/factory.js"); +var _array = require("../../utils/array.js"); +const name = 'forEach'; +const dependencies = ['typed']; +const createForEach = exports.createForEach = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Iterate over all elements of a matrix/array, and executes the given callback function. + * + * Syntax: + * + * math.forEach(x, callback) + * + * Examples: + * + * math.forEach([1, 2, 3], function(value) { + * console.log(value) + * }) + * // outputs 1, 2, 3 + * + * See also: + * + * filter, map, sort + * + * @param {Matrix | Array} x The matrix to iterate on. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix/array being traversed. + */ + return typed(name, { + 'Array, function': _forEach, + 'Matrix, function': function (x, callback) { + x.forEach(callback); + } + }); +}); + +/** + * forEach for a multidimensional array + * @param {Array} array + * @param {Function} callback + * @private + */ +function _forEach(array, callback) { + (0, _array.recurse)(array, [], array, (0, _optimizeCallback.optimizeCallback)(callback, array, name)); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/getMatrixDataType.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/getMatrixDataType.js new file mode 100644 index 0000000..0c14716 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/getMatrixDataType.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createGetMatrixDataType = void 0; +var _factory = require("../../utils/factory.js"); +var _array = require("../../utils/array.js"); +var _is = require("../../utils/is.js"); +const name = 'getMatrixDataType'; +const dependencies = ['typed']; +const createGetMatrixDataType = exports.createGetMatrixDataType = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Find the data type of all elements in a matrix or array, + * for example 'number' if all items are a number and 'Complex' if all values + * are complex numbers. + * If a matrix contains more than one data type, it will return 'mixed'. + * + * Syntax: + * + * math.getMatrixDataType(x) + * + * Examples: + * + * const x = [ [1, 2, 3], [4, 5, 6] ] + * const mixedX = [ [1, true], [2, 3] ] + * const fractionX = [ [math.fraction(1, 3)], [math.fraction(1, 3)] ] + * const unitX = [ [math.unit('5cm')], [math.unit('5cm')] ] + * const bigNumberX = [ [math.bignumber(1)], [math.bignumber(0)] ] + * const sparse = math.sparse(x) + * const dense = math.matrix(x) + * math.getMatrixDataType(x) // returns 'number' + * math.getMatrixDataType(sparse) // returns 'number' + * math.getMatrixDataType(dense) // returns 'number' + * math.getMatrixDataType(mixedX) // returns 'mixed' + * math.getMatrixDataType(fractionX) // returns 'Fraction' + * math.getMatrixDataType(unitX) // returns 'Unit' + * math.getMatrixDataType(bigNumberX) // return 'BigNumber' + * + * See also: + * SparseMatrix, DenseMatrix + * + * @param {...Matrix | Array} x The Matrix with values. + * + * @return {string} A string representation of the matrix type + */ + return typed(name, { + Array: function (x) { + return (0, _array.getArrayDataType)(x, _is.typeOf); + }, + Matrix: function (x) { + return x.getDataType(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/identity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/identity.js new file mode 100644 index 0000000..c0f3d71 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/identity.js @@ -0,0 +1,142 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIdentity = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'identity'; +const dependencies = ['typed', 'config', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix']; +const createIdentity = exports.createIdentity = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + BigNumber, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a 2-dimensional identity matrix with size m x n or n x n. + * The matrix has ones on the diagonal and zeros elsewhere. + * + * Syntax: + * + * math.identity(n) + * math.identity(n, format) + * math.identity(m, n) + * math.identity(m, n, format) + * math.identity([m, n]) + * math.identity([m, n], format) + * + * Examples: + * + * math.identity(3) // returns [[1, 0, 0], [0, 1, 0], [0, 0, 1]] + * math.identity(3, 2) // returns [[1, 0], [0, 1], [0, 0]] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.identity(math.size(A)) // returns [[1, 0, 0], [0, 1, 0]] + * + * See also: + * + * diag, ones, zeros, size, range + * + * @param {...number | Matrix | Array} size The size for the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Matrix | Array | number} A matrix with ones on the diagonal. + */ + return typed(name, { + '': function () { + return config.matrix === 'Matrix' ? matrix([]) : []; + }, + string: function (format) { + return matrix(format); + }, + 'number | BigNumber': function (rows) { + return _identity(rows, rows, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber, string': function (rows, format) { + return _identity(rows, rows, format); + }, + 'number | BigNumber, number | BigNumber': function (rows, cols) { + return _identity(rows, cols, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber, number | BigNumber, string': function (rows, cols, format) { + return _identity(rows, cols, format); + }, + Array: function (size) { + return _identityVector(size); + }, + 'Array, string': function (size, format) { + return _identityVector(size, format); + }, + Matrix: function (size) { + return _identityVector(size.valueOf(), size.storage()); + }, + 'Matrix, string': function (size, format) { + return _identityVector(size.valueOf(), format); + } + }); + function _identityVector(size, format) { + switch (size.length) { + case 0: + return format ? matrix(format) : []; + case 1: + return _identity(size[0], size[0], format); + case 2: + return _identity(size[0], size[1], format); + default: + throw new Error('Vector containing two values expected'); + } + } + + /** + * Create an identity matrix + * @param {number | BigNumber} rows + * @param {number | BigNumber} cols + * @param {string} [format] + * @returns {Matrix} + * @private + */ + function _identity(rows, cols, format) { + // BigNumber constructor with the right precision + const Big = (0, _is.isBigNumber)(rows) || (0, _is.isBigNumber)(cols) ? BigNumber : null; + if ((0, _is.isBigNumber)(rows)) rows = rows.toNumber(); + if ((0, _is.isBigNumber)(cols)) cols = cols.toNumber(); + if (!(0, _number.isInteger)(rows) || rows < 1) { + throw new Error('Parameters in function identity must be positive integers'); + } + if (!(0, _number.isInteger)(cols) || cols < 1) { + throw new Error('Parameters in function identity must be positive integers'); + } + const one = Big ? new BigNumber(1) : 1; + const defaultValue = Big ? new Big(0) : 0; + const size = [rows, cols]; + + // check we need to return a matrix + if (format) { + // create diagonal matrix (use optimized implementation for storage format) + if (format === 'sparse') { + return SparseMatrix.diagonal(size, one, 0, defaultValue); + } + if (format === 'dense') { + return DenseMatrix.diagonal(size, one, 0, defaultValue); + } + throw new TypeError(`Unknown matrix type "${format}"`); + } + + // create and resize array + const res = (0, _array.resize)([], size, defaultValue); + // fill in ones on the diagonal + const minimum = rows < cols ? rows : cols; + // fill diagonal + for (let d = 0; d < minimum; d++) { + res[d][d] = one; + } + return res; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ifft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ifft.js new file mode 100644 index 0000000..22bc6e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ifft.js @@ -0,0 +1,43 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIfft = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'ifft'; +const dependencies = ['typed', 'fft', 'dotDivide', 'conj']; +const createIfft = exports.createIfft = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + fft, + dotDivide, + conj + } = _ref; + /** + * Calculate N-dimensional inverse Fourier transform + * + * Syntax: + * + * math.ifft(arr) + * + * Examples: + * + * math.ifft([[2, 2], [0, 0]]) // returns [[{re:1, im:0}, {re:0, im:0}], [{re:1, im:0}, {re:0, im:0}]] + * + * See Also: + * + * fft + * + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + return typed(name, { + 'Array | Matrix': function (arr) { + const size = (0, _is.isMatrix)(arr) ? arr.size() : (0, _array.arraySize)(arr); + return dotDivide(conj(fft(conj(arr))), size.reduce((acc, curr) => acc * curr, 1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/inv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/inv.js new file mode 100644 index 0000000..58947fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/inv.js @@ -0,0 +1,190 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createInv = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _string = require("../../utils/string.js"); +const name = 'inv'; +const dependencies = ['typed', 'matrix', 'divideScalar', 'addScalar', 'multiply', 'unaryMinus', 'det', 'identity', 'abs']; +const createInv = exports.createInv = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divideScalar, + addScalar, + multiply, + unaryMinus, + det, + identity, + abs + } = _ref; + /** + * Calculate the inverse of a square matrix. + * + * Syntax: + * + * math.inv(x) + * + * Examples: + * + * math.inv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]] + * math.inv(4) // returns 0.25 + * 1 / 4 // returns 0.25 + * + * See also: + * + * det, transpose + * + * @param {number | Complex | Array | Matrix} x Matrix to be inversed + * @return {number | Complex | Array | Matrix} The inverse of `x`. + */ + return typed(name, { + 'Array | Matrix': function (x) { + const size = (0, _is.isMatrix)(x) ? x.size() : (0, _array.arraySize)(x); + switch (size.length) { + case 1: + // vector + if (size[0] === 1) { + if ((0, _is.isMatrix)(x)) { + return matrix([divideScalar(1, x.valueOf()[0])]); + } else { + return [divideScalar(1, x[0])]; + } + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + case 2: + // two dimensional array + { + const rows = size[0]; + const cols = size[1]; + if (rows === cols) { + if ((0, _is.isMatrix)(x)) { + return matrix(_inv(x.valueOf(), rows, cols), x.storage()); + } else { + // return an Array + return _inv(x, rows, cols); + } + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')'); + } + }, + any: function (x) { + // scalar + return divideScalar(1, x); // FIXME: create a BigNumber one when configured for bignumbers + } + }); + + /** + * Calculate the inverse of a square matrix + * @param {Array[]} mat A square matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns, must equal rows + * @return {Array[]} inv Inverse matrix + * @private + */ + function _inv(mat, rows, cols) { + let r, s, f, value, temp; + if (rows === 1) { + // this is a 1 x 1 matrix + value = mat[0][0]; + if (value === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + return [[divideScalar(1, value)]]; + } else if (rows === 2) { + // this is a 2 x 2 matrix + const d = det(mat); + if (d === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + return [[divideScalar(mat[1][1], d), divideScalar(unaryMinus(mat[0][1]), d)], [divideScalar(unaryMinus(mat[1][0]), d), divideScalar(mat[0][0], d)]]; + } else { + // this is a matrix of 3 x 3 or larger + // calculate inverse using gauss-jordan elimination + // https://en.wikipedia.org/wiki/Gaussian_elimination + // http://mathworld.wolfram.com/MatrixInverse.html + // http://math.uww.edu/~mcfarlat/inverse.htm + + // make a copy of the matrix (only the arrays, not of the elements) + const A = mat.concat(); + for (r = 0; r < rows; r++) { + A[r] = A[r].concat(); + } + + // create an identity matrix which in the end will contain the + // matrix inverse + const B = identity(rows).valueOf(); + + // loop over all columns, and perform row reductions + for (let c = 0; c < cols; c++) { + // Pivoting: Swap row c with row r, where row r contains the largest element A[r][c] + let ABig = abs(A[c][c]); + let rBig = c; + r = c + 1; + while (r < rows) { + if (abs(A[r][c]) > ABig) { + ABig = abs(A[r][c]); + rBig = r; + } + r++; + } + if (ABig === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + r = rBig; + if (r !== c) { + temp = A[c]; + A[c] = A[r]; + A[r] = temp; + temp = B[c]; + B[c] = B[r]; + B[r] = temp; + } + + // eliminate non-zero values on the other rows at column c + const Ac = A[c]; + const Bc = B[c]; + for (r = 0; r < rows; r++) { + const Ar = A[r]; + const Br = B[r]; + if (r !== c) { + // eliminate value at column c and row r + if (Ar[c] !== 0) { + f = divideScalar(unaryMinus(Ar[c]), Ac[c]); + + // add (f * row c) to row r to eliminate the value + // at column c + for (s = c; s < cols; s++) { + Ar[s] = addScalar(Ar[s], multiply(f, Ac[s])); + } + for (s = 0; s < cols; s++) { + Br[s] = addScalar(Br[s], multiply(f, Bc[s])); + } + } + } else { + // normalize value at Acc to 1, + // divide each value on row r with the value at Acc + f = Ac[c]; + for (s = c; s < cols; s++) { + Ar[s] = divideScalar(Ar[s], f); + } + for (s = 0; s < cols; s++) { + Br[s] = divideScalar(Br[s], f); + } + } + } + } + return B; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/kron.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/kron.js new file mode 100644 index 0000000..bb3f845 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/kron.js @@ -0,0 +1,91 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createKron = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'kron'; +const dependencies = ['typed', 'matrix', 'multiplyScalar']; +const createKron = exports.createKron = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + multiplyScalar + } = _ref; + /** + * Calculates the Kronecker product of 2 matrices or vectors. + * + * NOTE: If a one dimensional vector / matrix is given, it will be + * wrapped so its two dimensions. + * See the examples. + * + * Syntax: + * + * math.kron(x, y) + * + * Examples: + * + * math.kron([[1, 0], [0, 1]], [[1, 2], [3, 4]]) + * // returns [ [ 1, 2, 0, 0 ], [ 3, 4, 0, 0 ], [ 0, 0, 1, 2 ], [ 0, 0, 3, 4 ] ] + * + * math.kron([1,1], [2,3,4]) + * // returns [ [ 2, 3, 4, 2, 3, 4 ] ] + * + * See also: + * + * multiply, dot, cross + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {Array | Matrix} Returns the Kronecker product of `x` and `y` + */ + return typed(name, { + 'Matrix, Matrix': function (x, y) { + return matrix(_kron(x.toArray(), y.toArray())); + }, + 'Matrix, Array': function (x, y) { + return matrix(_kron(x.toArray(), y)); + }, + 'Array, Matrix': function (x, y) { + return matrix(_kron(x, y.toArray())); + }, + 'Array, Array': _kron + }); + + /** + * Calculate the Kronecker product of two matrices / vectors + * @param {Array} a First vector + * @param {Array} b Second vector + * @returns {Array} Returns the Kronecker product of x and y + * @private + */ + function _kron(a, b) { + // Deal with the dimensions of the matricies. + if ((0, _array.arraySize)(a).length === 1) { + // Wrap it in a 2D Matrix + a = [a]; + } + if ((0, _array.arraySize)(b).length === 1) { + // Wrap it in a 2D Matrix + b = [b]; + } + if ((0, _array.arraySize)(a).length > 2 || (0, _array.arraySize)(b).length > 2) { + throw new RangeError('Vectors with dimensions greater then 2 are not supported expected ' + '(Size x = ' + JSON.stringify(a.length) + ', y = ' + JSON.stringify(b.length) + ')'); + } + const t = []; + let r = []; + return a.map(function (a) { + return b.map(function (b) { + r = []; + t.push(r); + return a.map(function (y) { + return b.map(function (x) { + return r.push(multiplyScalar(y, x)); + }); + }); + }); + }) && t; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/map.js new file mode 100644 index 0000000..9f41dca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/map.js @@ -0,0 +1,148 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMap = void 0; +var _optimizeCallback = require("../../utils/optimizeCallback.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'map'; +const dependencies = ['typed']; +const createMap = exports.createMap = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Create a new matrix or array with the results of a callback function executed on + * each entry of a given matrix/array. + * + * For each entry of the input, + * + * the callback is invoked with 2N + 1 arguments: + * the N values of the entry, the index at which that entry occurs, and the N full + * broadcasted matrix/array being traversed where N is the number of matrices being traversed. + * Note that because the matrix/array might be + * multidimensional, the "index" argument is always an array of numbers giving + * the index in each dimension. This is true even for vectors: the "index" + * argument is an array of length 1, rather than simply a number. + * + * Syntax: + * + * math.map(x, callback) + * math.map(x, y, ..., callback) + * + * Examples: + * + * math.map([1, 2, 3], function(value) { + * return value * value + * }) // returns [1, 4, 9] + * math.map([1, 2], [3, 4], function(a, b) { + * return a + b + * }) // returns [4, 6] + * + * // The callback is normally called with three arguments: + * // callback(value, index, Array) + * // If you want to call with only one argument, use: + * math.map([1, 2, 3], x => math.format(x)) // returns ['1', '2', '3'] + * // It can also be called with 2N + 1 arguments: for N arrays + * // callback(value1, value2, index, BroadcastedArray1, BroadcastedArray2) + * + * See also: + * + * filter, forEach, sort + * + * @param {Matrix | Array} x The input to iterate on. + * @param {Function} callback + * The function to call (as described above) on each entry of the input + * @return {Matrix | array} + * Transformed map of x; always has the same type and shape as x + */ + return typed(name, { + 'Array, function': _mapArray, + 'Matrix, function': function (x, callback) { + return x.map(callback); + }, + 'Array|Matrix, Array|Matrix, ...Array|Matrix|function': (A, B, rest) => _mapMultiple([A, B, ...rest.slice(0, rest.length - 1)], rest[rest.length - 1]) + }); + + /** + * Maps over multiple arrays or matrices. + * + * @param {Array} Arrays - An array of arrays or matrices to map over. + * @param {function} multiCallback - The callback function to apply to each element. + * @throws {Error} If the last argument is not a callback function. + * @returns {Array|Matrix} A new array or matrix with each element being the result of the callback function. + * + * @example + * _mapMultiple([[1, 2, 3], [4, 5, 6]], (a, b) => a + b); // Returns [5, 7, 9] + */ + function _mapMultiple(Arrays, multiCallback) { + if (typeof multiCallback !== 'function') { + throw new Error('Last argument must be a callback function'); + } + const firstArrayIsMatrix = Arrays[0].isMatrix; + const newSize = (0, _array.broadcastSizes)(...Arrays.map(M => M.isMatrix ? M.size() : (0, _array.arraySize)(M))); + const _get = firstArrayIsMatrix ? (matrix, idx) => matrix.get(idx) : _array.get; + const broadcastedArrays = firstArrayIsMatrix ? Arrays.map(M => M.isMatrix ? M.create((0, _array.broadcastTo)(M.toArray(), newSize), M.datatype()) : Arrays[0].create((0, _array.broadcastTo)(M.valueOf(), newSize))) : Arrays.map(M => M.isMatrix ? (0, _array.broadcastTo)(M.toArray(), newSize) : (0, _array.broadcastTo)(M, newSize)); + let callback; + if (typed.isTypedFunction(multiCallback)) { + const firstIndex = newSize.map(() => 0); + const firstValues = broadcastedArrays.map(array => _get(array, firstIndex)); + const callbackCase = _getTypedCallbackCase(multiCallback, firstValues, firstIndex, broadcastedArrays); + callback = _getLimitedCallback(callbackCase); + } else { + const numberOfArrays = Arrays.length; + const callbackCase = _getCallbackCase(multiCallback, numberOfArrays); + callback = _getLimitedCallback(callbackCase); + } + const broadcastedArraysCallback = (x, idx) => callback([x, ...broadcastedArrays.slice(1).map(Array => _get(Array, idx))], idx); + if (firstArrayIsMatrix) { + return broadcastedArrays[0].map(broadcastedArraysCallback); + } else { + return _mapArray(broadcastedArrays[0], broadcastedArraysCallback); + } + function _getLimitedCallback(callbackCase) { + switch (callbackCase) { + case 0: + return x => multiCallback(...x); + case 1: + return (x, idx) => multiCallback(...x, idx); + case 2: + return (x, idx) => multiCallback(...x, idx, ...broadcastedArrays); + } + } + function _getCallbackCase(callback, numberOfArrays) { + if (callback.length > numberOfArrays + 1) { + return 2; + } + if (callback.length === numberOfArrays + 1) { + return 1; + } + return 0; + } + function _getTypedCallbackCase(callback, values, idx, arrays) { + if (typed.resolve(callback, [...values, idx, ...arrays]) !== null) { + return 2; + } + if (typed.resolve(callback, [...values, idx]) !== null) { + return 1; + } + if (typed.resolve(callback, values) !== null) { + return 0; + } + // this should never happen + return 0; + } + } + /** + * Map for a multi dimensional array + * @param {Array} array + * @param {Function} callback + * @return {Array} + * @private + */ + function _mapArray(array, callback) { + return (0, _array.recurse)(array, [], array, (0, _optimizeCallback.optimizeCallback)(callback, array, name)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromColumns.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromColumns.js new file mode 100644 index 0000000..f0fad5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromColumns.js @@ -0,0 +1,94 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrixFromColumns = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'matrixFromColumns'; +const dependencies = ['typed', 'matrix', 'flatten', 'size']; +const createMatrixFromColumns = exports.createMatrixFromColumns = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + flatten, + size + } = _ref; + /** + * Create a dense matrix from vectors as individual columns. + * If you pass row vectors, they will be transposed (but not conjugated!) + * + * Syntax: + * + * math.matrixFromColumns(...arr) + * math.matrixFromColumns(col1, col2) + * math.matrixFromColumns(col1, col2, col3) + * + * Examples: + * + * math.matrixFromColumns([1, 2, 3], [[4],[5],[6]]) + * math.matrixFromColumns(...vectors) + * + * See also: + * + * matrix, matrixFromRows, matrixFromFunction, zeros + * + * @param {... Array | Matrix} cols Multiple columns + * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned + */ + return typed(name, { + '...Array': function (arr) { + return _createArray(arr); + }, + '...Matrix': function (arr) { + return matrix(_createArray(arr.map(m => m.toArray()))); + } + + // TODO implement this properly for SparseMatrix + }); + function _createArray(arr) { + if (arr.length === 0) throw new TypeError('At least one column is needed to construct a matrix.'); + const N = checkVectorTypeAndReturnLength(arr[0]); + + // create an array with empty rows + const result = []; + for (let i = 0; i < N; i++) { + result[i] = []; + } + + // loop columns + for (const col of arr) { + const colLength = checkVectorTypeAndReturnLength(col); + if (colLength !== N) { + throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (colLength | 0)); + } + const f = flatten(col); + + // push a value to each row + for (let i = 0; i < N; i++) { + result[i].push(f[i]); + } + } + return result; + } + function checkVectorTypeAndReturnLength(vec) { + const s = size(vec); + if (s.length === 1) { + // 1D vector + return s[0]; + } else if (s.length === 2) { + // 2D vector + if (s[0] === 1) { + // row vector + return s[1]; + } else if (s[1] === 1) { + // col vector + return s[0]; + } else { + throw new TypeError('At least one of the arguments is not a vector.'); + } + } else { + throw new TypeError('Only one- or two-dimensional vectors are supported.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromFunction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromFunction.js new file mode 100644 index 0000000..3075c97 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromFunction.js @@ -0,0 +1,80 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrixFromFunction = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'matrixFromFunction'; +const dependencies = ['typed', 'matrix', 'isZero']; +const createMatrixFromFunction = exports.createMatrixFromFunction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + isZero + } = _ref; + /** + * Create a matrix by evaluating a generating function at each index. + * The simplest overload returns a multi-dimensional array as long as `size` is an array. + * Passing `size` as a Matrix or specifying a `format` will result in returning a Matrix. + * + * Syntax: + * + * math.matrixFromFunction(size, fn) + * math.matrixFromFunction(size, fn, format) + * math.matrixFromFunction(size, fn, format, datatype) + * math.matrixFromFunction(size, format, fn) + * math.matrixFromFunction(size, format, datatype, fn) + * + * Examples: + * + * math.matrixFromFunction([3,3], i => i[0] - i[1]) // an antisymmetric matrix + * math.matrixFromFunction([100, 100], 'sparse', i => i[0] - i[1] === 1 ? 4 : 0) // a sparse subdiagonal matrix + * math.matrixFromFunction([5], i => math.random()) // a random vector + * + * See also: + * + * matrix, zeros + * + * @param {Array | Matrix} size The size of the matrix to be created + * @param {function} fn Callback function invoked for every entry in the matrix + * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'` + * @param {string} [datatype] Type of the values + * @return {Array | Matrix} Returns the created matrix + */ + return typed(name, { + 'Array | Matrix, function, string, string': function (size, fn, format, datatype) { + return _create(size, fn, format, datatype); + }, + 'Array | Matrix, function, string': function (size, fn, format) { + return _create(size, fn, format); + }, + 'Matrix, function': function (size, fn) { + return _create(size, fn, 'dense'); + }, + 'Array, function': function (size, fn) { + return _create(size, fn, 'dense').toArray(); + }, + 'Array | Matrix, string, function': function (size, format, fn) { + return _create(size, fn, format); + }, + 'Array | Matrix, string, string, function': function (size, format, datatype, fn) { + return _create(size, fn, format, datatype); + } + }); + function _create(size, fn, format, datatype) { + let m; + if (datatype !== undefined) { + m = matrix(format, datatype); + } else { + m = matrix(format); + } + m.resize(size); + m.forEach(function (_, index) { + const val = fn(index); + if (isZero(val)) return; + m.set(index, val); + }); + return m; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromRows.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromRows.js new file mode 100644 index 0000000..1b606ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/matrixFromRows.js @@ -0,0 +1,82 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrixFromRows = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'matrixFromRows'; +const dependencies = ['typed', 'matrix', 'flatten', 'size']; +const createMatrixFromRows = exports.createMatrixFromRows = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + flatten, + size + } = _ref; + /** + * Create a dense matrix from vectors as individual rows. + * If you pass column vectors, they will be transposed (but not conjugated!) + * + * Syntax: + * + * math.matrixFromRows(...arr) + * math.matrixFromRows(row1, row2) + * math.matrixFromRows(row1, row2, row3) + * + * Examples: + * + * math.matrixFromRows([1, 2, 3], [[4],[5],[6]]) + * math.matrixFromRows(...vectors) + * + * See also: + * + * matrix, matrixFromColumns, matrixFromFunction, zeros + * + * @param {... Array | Matrix} rows Multiple rows + * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned + */ + return typed(name, { + '...Array': function (arr) { + return _createArray(arr); + }, + '...Matrix': function (arr) { + return matrix(_createArray(arr.map(m => m.toArray()))); + } + + // TODO implement this properly for SparseMatrix + }); + function _createArray(arr) { + if (arr.length === 0) throw new TypeError('At least one row is needed to construct a matrix.'); + const N = checkVectorTypeAndReturnLength(arr[0]); + const result = []; + for (const row of arr) { + const rowLength = checkVectorTypeAndReturnLength(row); + if (rowLength !== N) { + throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (rowLength | 0)); + } + result.push(flatten(row)); + } + return result; + } + function checkVectorTypeAndReturnLength(vec) { + const s = size(vec); + if (s.length === 1) { + // 1D vector + return s[0]; + } else if (s.length === 2) { + // 2D vector + if (s[0] === 1) { + // row vector + return s[1]; + } else if (s[1] === 1) { + // col vector + return s[0]; + } else { + throw new TypeError('At least one of the arguments is not a vector.'); + } + } else { + throw new TypeError('Only one- or two-dimensional vectors are supported.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ones.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ones.js new file mode 100644 index 0000000..05298dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/ones.js @@ -0,0 +1,129 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createOnes = void 0; +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'ones'; +const dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +const createOnes = exports.createOnes = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Create a matrix filled with ones. The created matrix can have one or + * multiple dimensions. + * + * Syntax: + * + * math.ones(m) + * math.ones(m, format) + * math.ones(m, n) + * math.ones(m, n, format) + * math.ones([m, n]) + * math.ones([m, n], format) + * math.ones([m, n, p, ...]) + * math.ones([m, n, p, ...], format) + * + * Examples: + * + * math.ones() // returns [] + * math.ones(3) // returns [1, 1, 1] + * math.ones(3, 2) // returns [[1, 1], [1, 1], [1, 1]] + * math.ones(3, 2, 'dense') // returns Dense Matrix [[1, 1], [1, 1], [1, 1]] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.ones(math.size(A)) // returns [[1, 1, 1], [1, 1, 1]] + * + * See also: + * + * zeros, identity, size, range + * + * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Array | Matrix | number} A matrix filled with ones + */ + return typed('ones', { + '': function () { + return config.matrix === 'Array' ? _ones([]) : _ones([], 'default'); + }, + // math.ones(m, n, p, ..., format) + // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this + '...number | BigNumber | string': function (size) { + const last = size[size.length - 1]; + if (typeof last === 'string') { + const format = size.pop(); + return _ones(size, format); + } else if (config.matrix === 'Array') { + return _ones(size); + } else { + return _ones(size, 'default'); + } + }, + Array: _ones, + Matrix: function (size) { + const format = size.storage(); + return _ones(size.valueOf(), format); + }, + 'Array | Matrix, string': function (size, format) { + return _ones(size.valueOf(), format); + } + }); + + /** + * Create an Array or Matrix with ones + * @param {Array} size + * @param {string} [format='default'] + * @return {Array | Matrix} + * @private + */ + function _ones(size, format) { + const hasBigNumbers = _normalize(size); + const defaultValue = hasBigNumbers ? new BigNumber(1) : 1; + _validate(size); + if (format) { + // return a matrix + const m = matrix(format); + if (size.length > 0) { + return m.resize(size, defaultValue); + } + return m; + } else { + // return an Array + const arr = []; + if (size.length > 0) { + return (0, _array.resize)(arr, size, defaultValue); + } + return arr; + } + } + + // replace BigNumbers with numbers, returns true if size contained BigNumbers + function _normalize(size) { + let hasBigNumbers = false; + size.forEach(function (value, index, arr) { + if ((0, _is.isBigNumber)(value)) { + hasBigNumbers = true; + arr[index] = value.toNumber(); + } + }); + return hasBigNumbers; + } + + // validate arguments + function _validate(size) { + size.forEach(function (value) { + if (typeof value !== 'number' || !(0, _number.isInteger)(value) || value < 0) { + throw new Error('Parameters in function ones must be positive integers'); + } + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/partitionSelect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/partitionSelect.js new file mode 100644 index 0000000..5122e7b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/partitionSelect.js @@ -0,0 +1,149 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPartitionSelect = void 0; +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'partitionSelect'; +const dependencies = ['typed', 'isNumeric', 'isNaN', 'compare']; +const createPartitionSelect = exports.createPartitionSelect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isNumeric, + isNaN, + compare + } = _ref; + const asc = compare; + const desc = (a, b) => -compare(a, b); + + /** + * Partition-based selection of an array or 1D matrix. + * Will find the kth smallest value, and mutates the input array. + * Uses Quickselect. + * + * Syntax: + * + * math.partitionSelect(x, k) + * math.partitionSelect(x, k, compare) + * + * Examples: + * + * math.partitionSelect([5, 10, 1], 2) // returns 10 + * math.partitionSelect(['C', 'B', 'A', 'D'], 1, math.compareText) // returns 'B' + * + * function sortByLength (a, b) { + * return a.length - b.length + * } + * math.partitionSelect(['Langdon', 'Tom', 'Sara'], 2, sortByLength) // returns 'Langdon' + * + * // the input array is mutated + * arr = [5, 2, 1] + * math.partitionSelect(arr, 0) // returns 1, arr is now: [1, 2, 5] + * math.partitionSelect(arr, 1, 'desc') // returns 2, arr is now: [5, 2, 1] + * + * See also: + * + * sort + * + * @param {Matrix | Array} x A one dimensional matrix or array to sort + * @param {Number} k The kth smallest value to be retrieved zero-based index + * @param {Function | 'asc' | 'desc'} [compare='asc'] + * An optional comparator function. The function is called as + * `compare(a, b)`, and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. + * @return {*} Returns the kth lowest value. + */ + return typed(name, { + 'Array | Matrix, number': function (x, k) { + return _partitionSelect(x, k, asc); + }, + 'Array | Matrix, number, string': function (x, k, compare) { + if (compare === 'asc') { + return _partitionSelect(x, k, asc); + } else if (compare === 'desc') { + return _partitionSelect(x, k, desc); + } else { + throw new Error('Compare string must be "asc" or "desc"'); + } + }, + 'Array | Matrix, number, function': _partitionSelect + }); + function _partitionSelect(x, k, compare) { + if (!(0, _number.isInteger)(k) || k < 0) { + throw new Error('k must be a non-negative integer'); + } + if ((0, _is.isMatrix)(x)) { + const size = x.size(); + if (size.length > 1) { + throw new Error('Only one dimensional matrices supported'); + } + return quickSelect(x.valueOf(), k, compare); + } + if (Array.isArray(x)) { + return quickSelect(x, k, compare); + } + } + + /** + * Quickselect algorithm. + * Code adapted from: + * https://blog.teamleadnet.com/2012/07/quick-select-algorithm-find-kth-element.html + * + * @param {Array} arr + * @param {Number} k + * @param {Function} compare + * @private + */ + function quickSelect(arr, k, compare) { + if (k >= arr.length) { + throw new Error('k out of bounds'); + } + + // check for NaN values since these can cause an infinite while loop + for (let i = 0; i < arr.length; i++) { + if (isNumeric(arr[i]) && isNaN(arr[i])) { + return arr[i]; // return NaN + } + } + let from = 0; + let to = arr.length - 1; + + // if from == to we reached the kth element + while (from < to) { + let r = from; + let w = to; + const pivot = arr[Math.floor(Math.random() * (to - from + 1)) + from]; + + // stop if the reader and writer meets + while (r < w) { + // arr[r] >= pivot + if (compare(arr[r], pivot) >= 0) { + // put the large values at the end + const tmp = arr[w]; + arr[w] = arr[r]; + arr[r] = tmp; + --w; + } else { + // the value is smaller than the pivot, skip + ++r; + } + } + + // if we stepped up (r++) we need to step one down (arr[r] > pivot) + if (compare(arr[r], pivot) > 0) { + --r; + } + + // the r pointer is on the end of the first k elements + if (k <= r) { + to = r; + } else { + from = r + 1; + } + } + return arr[k]; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/pinv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/pinv.js new file mode 100644 index 0000000..6b03499 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/pinv.js @@ -0,0 +1,185 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPinv = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +const name = 'pinv'; +const dependencies = ['typed', 'matrix', 'inv', 'deepEqual', 'equal', 'dotDivide', 'dot', 'ctranspose', 'divideScalar', 'multiply', 'add', 'Complex']; +const createPinv = exports.createPinv = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + inv, + deepEqual, + equal, + dotDivide, + dot, + ctranspose, + divideScalar, + multiply, + add, + Complex + } = _ref; + /** + * Calculate the Moore–Penrose inverse of a matrix. + * + * Syntax: + * + * math.pinv(x) + * + * Examples: + * + * math.pinv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]] + * math.pinv([[1, 0], [0, 1], [0, 1]]) // returns [[1, 0, 0], [0, 0.5, 0.5]] + * math.pinv(4) // returns 0.25 + * + * See also: + * + * inv + * + * @param {number | Complex | Array | Matrix} x Matrix to be inversed + * @return {number | Complex | Array | Matrix} The inverse of `x`. + */ + return typed(name, { + 'Array | Matrix': function (x) { + const size = (0, _is.isMatrix)(x) ? x.size() : (0, _array.arraySize)(x); + switch (size.length) { + case 1: + // vector + if (_isZeros(x)) return ctranspose(x); // null vector + if (size[0] === 1) { + return inv(x); // invertible matrix + } else { + return dotDivide(ctranspose(x), dot(x, x)); + } + case 2: + // two dimensional array + { + if (_isZeros(x)) return ctranspose(x); // zero matrixx + const rows = size[0]; + const cols = size[1]; + if (rows === cols) { + try { + return inv(x); // invertible matrix + } catch (err) { + if (err instanceof Error && err.message.match(/Cannot calculate inverse, determinant is zero/)) { + // Expected + } else { + throw err; + } + } + } + if ((0, _is.isMatrix)(x)) { + return matrix(_pinv(x.valueOf(), rows, cols), x.storage()); + } else { + // return an Array + return _pinv(x, rows, cols); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')'); + } + }, + any: function (x) { + // scalar + if (equal(x, 0)) return (0, _object.clone)(x); // zero + return divideScalar(1, x); + } + }); + + /** + * Calculate the Moore–Penrose inverse of a matrix + * @param {Array[]} mat A matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {Array[]} pinv Pseudoinverse matrix + * @private + */ + function _pinv(mat, rows, cols) { + const { + C, + F + } = _rankFact(mat, rows, cols); // TODO: Use SVD instead (may improve precision) + const Cpinv = multiply(inv(multiply(ctranspose(C), C)), ctranspose(C)); + const Fpinv = multiply(ctranspose(F), inv(multiply(F, ctranspose(F)))); + return multiply(Fpinv, Cpinv); + } + + /** + * Calculate the reduced row echelon form of a matrix + * + * Modified from https://rosettacode.org/wiki/Reduced_row_echelon_form + * + * @param {Array[]} mat A matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {Array[]} Reduced row echelon form + * @private + */ + function _rref(mat, rows, cols) { + const M = (0, _object.clone)(mat); + let lead = 0; + for (let r = 0; r < rows; r++) { + if (cols <= lead) { + return M; + } + let i = r; + while (_isZero(M[i][lead])) { + i++; + if (rows === i) { + i = r; + lead++; + if (cols === lead) { + return M; + } + } + } + [M[i], M[r]] = [M[r], M[i]]; + let val = M[r][lead]; + for (let j = 0; j < cols; j++) { + M[r][j] = dotDivide(M[r][j], val); + } + for (let i = 0; i < rows; i++) { + if (i === r) continue; + val = M[i][lead]; + for (let j = 0; j < cols; j++) { + M[i][j] = add(M[i][j], multiply(-1, multiply(val, M[r][j]))); + } + } + lead++; + } + return M; + } + + /** + * Calculate the rank factorization of a matrix + * + * @param {Array[]} mat A matrix (M) + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {{C: Array, F: Array}} rank factorization where M = C F + * @private + */ + function _rankFact(mat, rows, cols) { + const rref = _rref(mat, rows, cols); + const C = mat.map((_, i) => _.filter((_, j) => j < rows && !_isZero(dot(rref[j], rref[j])))); + const F = rref.filter((_, i) => !_isZero(dot(rref[i], rref[i]))); + return { + C, + F + }; + } + function _isZero(x) { + return equal(add(x, Complex(1, 1)), add(0, Complex(1, 1))); + } + function _isZeros(arr) { + return deepEqual(add(arr, Complex(1, 1)), add(multiply(arr, 0), Complex(1, 1))); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/range.js new file mode 100644 index 0000000..9492353 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/range.js @@ -0,0 +1,188 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRange = void 0; +var _factory = require("../../utils/factory.js"); +var _noop = require("../../utils/noop.js"); +const name = 'range'; +const dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']; +const createRange = exports.createRange = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + } = _ref; + /** + * Create an array from a range. + * By default, the range end is excluded. This can be customized by providing + * an extra parameter `includeEnd`. + * + * Syntax: + * + * math.range(str [, includeEnd]) // Create a range from a string, + * // where the string contains the + * // start, optional step, and end, + * // separated by a colon. + * math.range(start, end [, includeEnd]) // Create a range with start and + * // end and a step size of 1. + * math.range(start, end, step [, includeEnd]) // Create a range with start, step, + * // and end. + * + * Where: + * + * - `str: string` + * A string 'start:end' or 'start:step:end' + * - `start: {number | BigNumber | Unit}` + * Start of the range + * - `end: number | BigNumber | Unit` + * End of the range, excluded by default, included when parameter includeEnd=true + * - `step: number | BigNumber | Unit` + * Step size. Default value is 1. + * - `includeEnd: boolean` + * Option to specify whether to include the end or not. False by default. + * + * Examples: + * + * math.range(2, 6) // [2, 3, 4, 5] + * math.range(2, -3, -1) // [2, 1, 0, -1, -2] + * math.range('2:1:6') // [2, 3, 4, 5] + * math.range(2, 6, true) // [2, 3, 4, 5, 6] + * math.range(math.unit(2, 'm'), math.unit(-3, 'm'), math.unit(-1, 'm')) // [2 m, 1 m, 0 m , -1 m, -2 m] + * + * See also: + * + * ones, zeros, size, subset + * + * @param {*} args Parameters describing the ranges `start`, `end`, and optional `step`. + * @return {Array | Matrix} range + */ + return typed(name, { + // TODO: simplify signatures when typed-function supports default values and optional arguments + + // TODO: a number or boolean should not be converted to string here + string: _strRange, + 'string, boolean': _strRange, + 'number, number': function (start, end) { + return _out(_range(start, end, 1, false)); + }, + 'number, number, number': function (start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'number, number, boolean': function (start, end, includeEnd) { + return _out(_range(start, end, 1, includeEnd)); + }, + 'number, number, number, boolean': function (start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + }, + 'BigNumber, BigNumber': function (start, end) { + const BigNumber = start.constructor; + return _out(_range(start, end, new BigNumber(1), false)); + }, + 'BigNumber, BigNumber, BigNumber': function (start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'BigNumber, BigNumber, boolean': function (start, end, includeEnd) { + const BigNumber = start.constructor; + return _out(_range(start, end, new BigNumber(1), includeEnd)); + }, + 'BigNumber, BigNumber, BigNumber, boolean': function (start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + }, + 'Unit, Unit, Unit': function (start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'Unit, Unit, Unit, boolean': function (start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + } + }); + function _out(arr) { + if (config.matrix === 'Matrix') { + return matrix ? matrix(arr) : (0, _noop.noMatrix)(); + } + return arr; + } + function _strRange(str, includeEnd) { + const r = _parse(str); + if (!r) { + throw new SyntaxError('String "' + str + '" is no valid range'); + } + if (config.number === 'BigNumber') { + if (bignumber === undefined) { + (0, _noop.noBignumber)(); + } + return _out(_range(bignumber(r.start), bignumber(r.end), bignumber(r.step)), includeEnd); + } else { + return _out(_range(r.start, r.end, r.step, includeEnd)); + } + } + + /** + * Create a range with numbers or BigNumbers + * @param {number | BigNumber | Unit} start + * @param {number | BigNumber | Unit} end + * @param {number | BigNumber | Unit} step + * @param {boolean} includeEnd + * @returns {Array} range + * @private + */ + function _range(start, end, step, includeEnd) { + const array = []; + const ongoing = isPositive(step) ? includeEnd ? smallerEq : smaller : includeEnd ? largerEq : larger; + let x = start; + while (ongoing(x, end)) { + array.push(x); + x = add(x, step); + } + return array; + } + + /** + * Parse a string into a range, + * The string contains the start, optional step, and end, separated by a colon. + * If the string does not contain a valid range, null is returned. + * For example str='0:2:11'. + * @param {string} str + * @return {{start: number, end: number, step: number} | null} range Object containing properties start, end, step + * @private + */ + function _parse(str) { + const args = str.split(':'); + + // number + const nums = args.map(function (arg) { + // use Number and not parseFloat as Number returns NaN on invalid garbage in the string + return Number(arg); + }); + const invalid = nums.some(function (num) { + return isNaN(num); + }); + if (invalid) { + return null; + } + switch (nums.length) { + case 2: + return { + start: nums[0], + end: nums[1], + step: 1 + }; + case 3: + return { + start: nums[0], + end: nums[2], + step: nums[1] + }; + default: + return null; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/reshape.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/reshape.js new file mode 100644 index 0000000..d8cd4e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/reshape.js @@ -0,0 +1,69 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createReshape = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'reshape'; +const dependencies = ['typed', 'isInteger', 'matrix']; +const createReshape = exports.createReshape = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isInteger + } = _ref; + /** + * Reshape a multi dimensional array to fit the specified dimensions + * + * Syntax: + * + * math.reshape(x, sizes) + * + * Examples: + * + * math.reshape([1, 2, 3, 4, 5, 6], [2, 3]) + * // returns Array [[1, 2, 3], [4, 5, 6]] + * + * math.reshape([[1, 2], [3, 4]], [1, 4]) + * // returns Array [[1, 2, 3, 4]] + * + * math.reshape([[1, 2], [3, 4]], [4]) + * // returns Array [1, 2, 3, 4] + * + * const x = math.matrix([1, 2, 3, 4, 5, 6, 7, 8]) + * math.reshape(x, [2, 2, 2]) + * // returns Matrix [[[1, 2], [3, 4]], [[5, 6], [7, 8]]] + * + * math.reshape([1, 2, 3, 4], [-1, 2]) + * // returns Matrix [[1, 2], [3, 4]] + * + * See also: + * + * size, squeeze, resize + * + * @param {Array | Matrix | *} x Matrix to be reshaped + * @param {number[]} sizes One dimensional array with integral sizes for + * each dimension. One -1 is allowed as wildcard, + * which calculates this dimension automatically. + * + * @return {* | Array | Matrix} A reshaped clone of matrix `x` + * + * @throws {TypeError} If `sizes` does not contain solely integers + * @throws {DimensionError} If the product of the new dimension sizes does + * not equal that of the old ones + */ + return typed(name, { + 'Matrix, Array': function (x, sizes) { + return x.reshape(sizes, true); + }, + 'Array, Array': function (x, sizes) { + sizes.forEach(function (size) { + if (!isInteger(size)) { + throw new TypeError('Invalid size for dimension: ' + size); + } + }); + return (0, _array.reshape)(x, sizes); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/resize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/resize.js new file mode 100644 index 0000000..6b54e85 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/resize.js @@ -0,0 +1,126 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createResize = void 0; +var _is = require("../../utils/is.js"); +var _DimensionError = require("../../error/DimensionError.js"); +var _ArgumentsError = require("../../error/ArgumentsError.js"); +var _number = require("../../utils/number.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'resize'; +const dependencies = ['config', 'matrix']; +const createResize = exports.createResize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + config, + matrix + } = _ref; + /** + * Resize a matrix + * + * Syntax: + * + * math.resize(x, size) + * math.resize(x, size, defaultValue) + * + * Examples: + * + * math.resize([1, 2, 3, 4, 5], [3]) // returns Array [1, 2, 3] + * math.resize([1, 2, 3], [5], 0) // returns Array [1, 2, 3, 0, 0] + * math.resize(2, [2, 3], 0) // returns Matrix [[2, 0, 0], [0, 0, 0]] + * math.resize("hello", [8], "!") // returns string 'hello!!!' + * + * See also: + * + * size, squeeze, subset, reshape + * + * @param {Array | Matrix | *} x Matrix to be resized + * @param {Array | Matrix} size One dimensional array with numbers + * @param {number | string} [defaultValue=0] Zero by default, except in + * case of a string, in that case + * defaultValue = ' ' + * @return {* | Array | Matrix} A resized clone of matrix `x` + */ + // TODO: rework resize to a typed-function + return function resize(x, size, defaultValue) { + if (arguments.length !== 2 && arguments.length !== 3) { + throw new _ArgumentsError.ArgumentsError('resize', arguments.length, 2, 3); + } + if ((0, _is.isMatrix)(size)) { + size = size.valueOf(); // get Array + } + if ((0, _is.isBigNumber)(size[0])) { + // convert bignumbers to numbers + size = size.map(function (value) { + return !(0, _is.isBigNumber)(value) ? value : value.toNumber(); + }); + } + + // check x is a Matrix + if ((0, _is.isMatrix)(x)) { + // use optimized matrix implementation, return copy + return x.resize(size, defaultValue, true); + } + if (typeof x === 'string') { + // resize string + return _resizeString(x, size, defaultValue); + } + + // check result should be a matrix + const asMatrix = Array.isArray(x) ? false : config.matrix !== 'Array'; + if (size.length === 0) { + // output a scalar + while (Array.isArray(x)) { + x = x[0]; + } + return (0, _object.clone)(x); + } else { + // output an array/matrix + if (!Array.isArray(x)) { + x = [x]; + } + x = (0, _object.clone)(x); + const res = (0, _array.resize)(x, size, defaultValue); + return asMatrix ? matrix(res) : res; + } + }; + + /** + * Resize a string + * @param {string} str + * @param {number[]} size + * @param {string} [defaultChar=' '] + * @private + */ + function _resizeString(str, size, defaultChar) { + if (defaultChar !== undefined) { + if (typeof defaultChar !== 'string' || defaultChar.length !== 1) { + throw new TypeError('Single character expected as defaultValue'); + } + } else { + defaultChar = ' '; + } + if (size.length !== 1) { + throw new _DimensionError.DimensionError(size.length, 1); + } + const len = size[0]; + if (typeof len !== 'number' || !(0, _number.isInteger)(len)) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(size) + ')'); + } + if (str.length > len) { + return str.substring(0, len); + } else if (str.length < len) { + let res = str; + for (let i = 0, ii = len - str.length; i < ii; i++) { + res += defaultChar; + } + return res; + } else { + return str; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotate.js new file mode 100644 index 0000000..5a65c61 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotate.js @@ -0,0 +1,77 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRotate = void 0; +var _factory = require("../../utils/factory.js"); +var _array = require("../../utils/array.js"); +const name = 'rotate'; +const dependencies = ['typed', 'multiply', 'rotationMatrix']; +const createRotate = exports.createRotate = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + multiply, + rotationMatrix + } = _ref; + /** + * Rotate a vector of size 1x2 counter-clockwise by a given angle + * Rotate a vector of size 1x3 counter-clockwise by a given angle around the given axis + * + * Syntax: + * + * math.rotate(w, theta) + * math.rotate(w, theta, v) + * + * Examples: + * + * math.rotate([11, 12], math.pi / 2) // returns [-12, 11] + * math.rotate(matrix([11, 12]), math.pi / 2) // returns [-12, 11] + * + * math.rotate([1, 0, 0], unit('90deg'), [0, 0, 1]) // returns [0, 1, 0] + * math.rotate(matrix([1, 0, 0]), unit('90deg'), [0, 0, 1]) // returns Matrix [0, 1, 0] + * + * math.rotate([1, 0], math.complex(1 + i)) // returns [cos(1 + i) - sin(1 + i), sin(1 + i) + cos(1 + i)] + * + * See also: + * + * matrix, rotationMatrix + * + * @param {Array | Matrix} w Vector to rotate + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @return {Array | Matrix} Multiplication of the rotation matrix and w + */ + return typed(name, { + 'Array , number | BigNumber | Complex | Unit': function (w, theta) { + _validateSize(w, 2); + const matrixRes = multiply(rotationMatrix(theta), w); + return matrixRes.toArray(); + }, + 'Matrix , number | BigNumber | Complex | Unit': function (w, theta) { + _validateSize(w, 2); + return multiply(rotationMatrix(theta), w); + }, + 'Array, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) { + _validateSize(w, 3); + const matrixRes = multiply(rotationMatrix(theta, v), w); + return matrixRes; + }, + 'Matrix, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) { + _validateSize(w, 3); + return multiply(rotationMatrix(theta, v), w); + } + }); + function _validateSize(v, expectedSize) { + const actualSize = Array.isArray(v) ? (0, _array.arraySize)(v) : v.size(); + if (actualSize.length > 2) { + throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`); + } + if (actualSize.length === 2 && actualSize[1] !== 1) { + throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`); + } + if (actualSize[0] !== expectedSize) { + throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotationMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotationMatrix.js new file mode 100644 index 0000000..3129f42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/rotationMatrix.js @@ -0,0 +1,166 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRotationMatrix = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'rotationMatrix'; +const dependencies = ['typed', 'config', 'multiplyScalar', 'addScalar', 'unaryMinus', 'norm', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix', 'cos', 'sin']; +const createRotationMatrix = exports.createRotationMatrix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + multiplyScalar, + addScalar, + unaryMinus, + norm, + BigNumber, + matrix, + DenseMatrix, + SparseMatrix, + cos, + sin + } = _ref; + /** + * Create a 2-dimensional counter-clockwise rotation matrix (2x2) for a given angle (expressed in radians). + * Create a 2-dimensional counter-clockwise rotation matrix (3x3) by a given angle (expressed in radians) around a given axis (1x3). + * + * Syntax: + * + * math.rotationMatrix(theta) + * math.rotationMatrix(theta, format) + * math.rotationMatrix(theta, [v]) + * math.rotationMatrix(theta, [v], format) + * + * Examples: + * + * math.rotationMatrix(math.pi / 2) // returns [[0, -1], [1, 0]] + * math.rotationMatrix(math.bignumber(1)) // returns [[bignumber(cos(1)), bignumber(-sin(1))], [bignumber(sin(1)), bignumber(cos(1))]] + * math.rotationMatrix(math.complex(1 + i)) // returns [[cos(1 + i), -sin(1 + i)], [sin(1 + i), cos(1 + i)]] + * math.rotationMatrix(math.unit('1rad')) // returns [[cos(1), -sin(1)], [sin(1), cos(1)]] + * + * math.rotationMatrix(math.pi / 2, [0, 1, 0]) // returns [[0, 0, 1], [0, 1, 0], [-1, 0, 0]] + * math.rotationMatrix(math.pi / 2, matrix([0, 1, 0])) // returns matrix([[0, 0, 1], [0, 1, 0], [-1, 0, 0]]) + * + * + * See also: + * + * matrix, cos, sin + * + * + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @param {string} [format] Result Matrix storage format + * @return {Array | Matrix} Rotation matrix + */ + + return typed(name, { + '': function () { + return config.matrix === 'Matrix' ? matrix([]) : []; + }, + string: function (format) { + return matrix(format); + }, + 'number | BigNumber | Complex | Unit': function (theta) { + return _rotationMatrix2x2(theta, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber | Complex | Unit, string': function (theta, format) { + return _rotationMatrix2x2(theta, format); + }, + 'number | BigNumber | Complex | Unit, Array': function (theta, v) { + const matrixV = matrix(v); + _validateVector(matrixV); + return _rotationMatrix3x3(theta, matrixV, undefined); + }, + 'number | BigNumber | Complex | Unit, Matrix': function (theta, v) { + _validateVector(v); + const storageType = v.storage() || (config.matrix === 'Matrix' ? 'dense' : undefined); + return _rotationMatrix3x3(theta, v, storageType); + }, + 'number | BigNumber | Complex | Unit, Array, string': function (theta, v, format) { + const matrixV = matrix(v); + _validateVector(matrixV); + return _rotationMatrix3x3(theta, matrixV, format); + }, + 'number | BigNumber | Complex | Unit, Matrix, string': function (theta, v, format) { + _validateVector(v); + return _rotationMatrix3x3(theta, v, format); + } + }); + + /** + * Returns 2x2 matrix of 2D rotation of angle theta + * + * @param {number | BigNumber | Complex | Unit} theta The rotation angle + * @param {string} format The result Matrix storage format + * @returns {Matrix} + * @private + */ + function _rotationMatrix2x2(theta, format) { + const Big = (0, _is.isBigNumber)(theta); + const minusOne = Big ? new BigNumber(-1) : -1; + const cosTheta = cos(theta); + const sinTheta = sin(theta); + const data = [[cosTheta, multiplyScalar(minusOne, sinTheta)], [sinTheta, cosTheta]]; + return _convertToFormat(data, format); + } + function _validateVector(v) { + const size = v.size(); + if (size.length < 1 || size[0] !== 3) { + throw new RangeError('Vector must be of dimensions 1x3'); + } + } + function _mul(array) { + return array.reduce((p, curr) => multiplyScalar(p, curr)); + } + function _convertToFormat(data, format) { + if (format) { + if (format === 'sparse') { + return new SparseMatrix(data); + } + if (format === 'dense') { + return new DenseMatrix(data); + } + throw new TypeError(`Unknown matrix type "${format}"`); + } + return data; + } + + /** + * Returns a 3x3 matrix of rotation of angle theta around vector v + * + * @param {number | BigNumber | Complex | Unit} theta The rotation angle + * @param {Matrix} v The rotation axis vector + * @param {string} format The storage format of the resulting matrix + * @returns {Matrix} + * @private + */ + function _rotationMatrix3x3(theta, v, format) { + const normV = norm(v); + if (normV === 0) { + throw new RangeError('Rotation around zero vector'); + } + const Big = (0, _is.isBigNumber)(theta) ? BigNumber : null; + const one = Big ? new Big(1) : 1; + const minusOne = Big ? new Big(-1) : -1; + const vx = Big ? new Big(v.get([0]) / normV) : v.get([0]) / normV; + const vy = Big ? new Big(v.get([1]) / normV) : v.get([1]) / normV; + const vz = Big ? new Big(v.get([2]) / normV) : v.get([2]) / normV; + const c = cos(theta); + const oneMinusC = addScalar(one, unaryMinus(c)); + const s = sin(theta); + const r11 = addScalar(c, _mul([vx, vx, oneMinusC])); + const r12 = addScalar(_mul([vx, vy, oneMinusC]), _mul([minusOne, vz, s])); + const r13 = addScalar(_mul([vx, vz, oneMinusC]), _mul([vy, s])); + const r21 = addScalar(_mul([vx, vy, oneMinusC]), _mul([vz, s])); + const r22 = addScalar(c, _mul([vy, vy, oneMinusC])); + const r23 = addScalar(_mul([vy, vz, oneMinusC]), _mul([minusOne, vx, s])); + const r31 = addScalar(_mul([vx, vz, oneMinusC]), _mul([minusOne, vy, s])); + const r32 = addScalar(_mul([vy, vz, oneMinusC]), _mul([vx, s])); + const r33 = addScalar(c, _mul([vz, vz, oneMinusC])); + const data = [[r11, r12, r13], [r21, r22, r23], [r31, r32, r33]]; + return _convertToFormat(data, format); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/row.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/row.js new file mode 100644 index 0000000..4c8b272 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/row.js @@ -0,0 +1,65 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRow = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +const name = 'row'; +const dependencies = ['typed', 'Index', 'matrix', 'range']; +const createRow = exports.createRow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Index, + matrix, + range + } = _ref; + /** + * Return a row from a Matrix. + * + * Syntax: + * + * math.row(value, index) + * + * Example: + * + * // get a row + * const d = [[1, 2], [3, 4]] + * math.row(d, 1) // returns [[3, 4]] + * + * See also: + * + * column + * + * @param {Array | Matrix } value An array or matrix + * @param {number} row The index of the row + * @return {Array | Matrix} The retrieved row + */ + return typed(name, { + 'Matrix, number': _row, + 'Array, number': function (value, row) { + return _row(matrix((0, _object.clone)(value)), row).valueOf(); + } + }); + + /** + * Retrieve a row of a matrix + * @param {Matrix } value A matrix + * @param {number} row The index of the row + * @return {Matrix} The retrieved row + */ + function _row(value, row) { + // check dimensions + if (value.size().length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + (0, _array.validateIndex)(row, value.size()[0]); + const columnRange = range(0, value.size()[1]); + const index = new Index(row, columnRange); + const result = value.subset(index); + return (0, _is.isMatrix)(result) ? result : matrix([[result]]); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/size.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/size.js new file mode 100644 index 0000000..f40b9a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/size.js @@ -0,0 +1,54 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSize = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _noop = require("../../utils/noop.js"); +const name = 'size'; +const dependencies = ['typed', 'config', '?matrix']; +const createSize = exports.createSize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix + } = _ref; + /** + * Calculate the size of a matrix or scalar. + * + * Syntax: + * + * math.size(x) + * + * Examples: + * + * math.size(2.3) // returns [] + * math.size('hello world') // returns [11] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.size(A) // returns [2, 3] + * math.size(math.range(1,6).toArray()) // returns [5] + * + * See also: + * + * count, resize, squeeze, subset + * + * @param {boolean | number | Complex | Unit | string | Array | Matrix} x A matrix + * @return {Array | Matrix} A vector with size of `x`. + */ + return typed(name, { + Matrix: function (x) { + return x.create(x.size(), 'number'); + }, + Array: _array.arraySize, + string: function (x) { + return config.matrix === 'Array' ? [x.length] : matrix([x.length], 'dense', 'number'); + }, + 'number | Complex | BigNumber | Unit | boolean | null': function (x) { + // scalar + return config.matrix === 'Array' ? [] : matrix ? matrix([], 'dense', 'number') : (0, _noop.noMatrix)(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sort.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sort.js new file mode 100644 index 0000000..6be9626 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sort.js @@ -0,0 +1,119 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSort = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'sort'; +const dependencies = ['typed', 'matrix', 'compare', 'compareNatural']; +const createSort = exports.createSort = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + compare, + compareNatural + } = _ref; + const compareAsc = compare; + const compareDesc = (a, b) => -compare(a, b); + + /** + * Sort the items in a matrix. + * + * Syntax: + * + * math.sort(x) + * math.sort(x, compare) + * + * Examples: + * + * math.sort([5, 10, 1]) // returns [1, 5, 10] + * math.sort(['C', 'B', 'A', 'D'], math.compareNatural) + * // returns ['A', 'B', 'C', 'D'] + * + * function sortByLength (a, b) { + * return a.length - b.length + * } + * math.sort(['Langdon', 'Tom', 'Sara'], sortByLength) + * // returns ['Tom', 'Sara', 'Langdon'] + * + * See also: + * + * filter, forEach, map, compare, compareNatural + * + * @param {Matrix | Array} x A one dimensional matrix or array to sort + * @param {Function | 'asc' | 'desc' | 'natural'} [compare='asc'] + * An optional _comparator function or name. The function is called as + * `compare(a, b)`, and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. + * @return {Matrix | Array} Returns the sorted matrix. + */ + return typed(name, { + Array: function (x) { + _arrayIsVector(x); + return x.sort(compareAsc); + }, + Matrix: function (x) { + _matrixIsVector(x); + return matrix(x.toArray().sort(compareAsc), x.storage()); + }, + 'Array, function': function (x, _comparator) { + _arrayIsVector(x); + return x.sort(_comparator); + }, + 'Matrix, function': function (x, _comparator) { + _matrixIsVector(x); + return matrix(x.toArray().sort(_comparator), x.storage()); + }, + 'Array, string': function (x, order) { + _arrayIsVector(x); + return x.sort(_comparator(order)); + }, + 'Matrix, string': function (x, order) { + _matrixIsVector(x); + return matrix(x.toArray().sort(_comparator(order)), x.storage()); + } + }); + + /** + * Get the comparator for given order ('asc', 'desc', 'natural') + * @param {'asc' | 'desc' | 'natural'} order + * @return {Function} Returns a _comparator function + */ + function _comparator(order) { + if (order === 'asc') { + return compareAsc; + } else if (order === 'desc') { + return compareDesc; + } else if (order === 'natural') { + return compareNatural; + } else { + throw new Error('String "asc", "desc", or "natural" expected'); + } + } + + /** + * Validate whether an array is one dimensional + * Throws an error when this is not the case + * @param {Array} array + * @private + */ + function _arrayIsVector(array) { + if ((0, _array.arraySize)(array).length !== 1) { + throw new Error('One dimensional array expected'); + } + } + + /** + * Validate whether a matrix is one dimensional + * Throws an error when this is not the case + * @param {Matrix} matrix + * @private + */ + function _matrixIsVector(matrix) { + if (matrix.size().length !== 1) { + throw new Error('One dimensional matrix expected'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sqrtm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sqrtm.js new file mode 100644 index 0000000..3c8f271 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/sqrtm.js @@ -0,0 +1,105 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSqrtm = void 0; +var _is = require("../../utils/is.js"); +var _string = require("../../utils/string.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'sqrtm'; +const dependencies = ['typed', 'abs', 'add', 'multiply', 'map', 'sqrt', 'subtract', 'inv', 'size', 'max', 'identity']; +const createSqrtm = exports.createSqrtm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + add, + multiply, + map, + sqrt, + subtract, + inv, + size, + max, + identity + } = _ref; + const _maxIterations = 1e3; + const _tolerance = 1e-6; + + /** + * Calculate the principal square root matrix using the Denman–Beavers iterative method + * + * https://en.wikipedia.org/wiki/Square_root_of_a_matrix#By_Denman–Beavers_iteration + * + * @param {Array | Matrix} A The square matrix `A` + * @return {Array | Matrix} The principal square root of matrix `A` + * @private + */ + function _denmanBeavers(A) { + let error; + let iterations = 0; + let Y = A; + let Z = identity(size(A)); + do { + const Yk = Y; + Y = multiply(0.5, add(Yk, inv(Z))); + Z = multiply(0.5, add(Z, inv(Yk))); + error = max(abs(subtract(Y, Yk))); + if (error > _tolerance && ++iterations > _maxIterations) { + throw new Error('computing square root of matrix: iterative method could not converge'); + } + } while (error > _tolerance); + return Y; + } + + /** + * Calculate the principal square root of a square matrix. + * The principal square root matrix `X` of another matrix `A` is such that `X * X = A`. + * + * https://en.wikipedia.org/wiki/Square_root_of_a_matrix + * + * Syntax: + * + * math.sqrtm(A) + * + * Examples: + * + * math.sqrtm([[33, 24], [48, 57]]) // returns [[5, 2], [4, 7]] + * + * See also: + * + * sqrt, pow + * + * @param {Array | Matrix} A The square matrix `A` + * @return {Array | Matrix} The principal square root of matrix `A` + */ + return typed(name, { + 'Array | Matrix': function (A) { + const size = (0, _is.isMatrix)(A) ? A.size() : (0, _array.arraySize)(A); + switch (size.length) { + case 1: + // Single element Array | Matrix + if (size[0] === 1) { + return map(A, sqrt); + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + case 2: + { + // Two-dimensional Array | Matrix + const rows = size[0]; + const cols = size[1]; + if (rows === cols) { + return _denmanBeavers(A); + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')'); + } + } + default: + // Multi dimensional array + throw new RangeError('Matrix must be at most two dimensional ' + '(size: ' + (0, _string.format)(size) + ')'); + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/squeeze.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/squeeze.js new file mode 100644 index 0000000..78ba0f9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/squeeze.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSqueeze = void 0; +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'squeeze'; +const dependencies = ['typed']; +const createSqueeze = exports.createSqueeze = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Squeeze a matrix, remove inner and outer singleton dimensions from a matrix. + * + * Syntax: + * + * math.squeeze(x) + * + * Examples: + * + * math.squeeze([3]) // returns 3 + * math.squeeze([[3]]) // returns 3 + * + * const A = math.zeros(3, 1) // returns [[0], [0], [0]] (size 3x1) + * math.squeeze(A) // returns [0, 0, 0] (size 3) + * + * const B = math.zeros(1, 3) // returns [[0, 0, 0]] (size 1x3) + * math.squeeze(B) // returns [0, 0, 0] (size 3) + * + * // only inner and outer dimensions are removed + * const C = math.zeros(2, 1, 3) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3) + * math.squeeze(C) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3) + * + * See also: + * + * subset + * + * @param {Matrix | Array} x Matrix to be squeezed + * @return {Matrix | Array} Squeezed matrix + */ + return typed(name, { + Array: function (x) { + return (0, _array.squeeze)((0, _object.clone)(x)); + }, + Matrix: function (x) { + const res = (0, _array.squeeze)(x.toArray()); + // FIXME: return the same type of matrix as the input + return Array.isArray(res) ? x.create(res, x.datatype()) : res; + }, + any: function (x) { + // scalar + return (0, _object.clone)(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/subset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/subset.js new file mode 100644 index 0000000..dd448ee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/subset.js @@ -0,0 +1,279 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSubset = void 0; +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +var _customs = require("../../utils/customs.js"); +var _DimensionError = require("../../error/DimensionError.js"); +var _factory = require("../../utils/factory.js"); +const name = 'subset'; +const dependencies = ['typed', 'matrix', 'zeros', 'add']; +const createSubset = exports.createSubset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + zeros, + add + } = _ref; + /** + * Get or set a subset of a matrix or string. + * + * Syntax: + * math.subset(value, index) // retrieve a subset + * math.subset(value, index, replacement [, defaultValue]) // replace a subset + * + * Examples: + * + * // get a subset + * const d = [[1, 2], [3, 4]] + * math.subset(d, math.index(1, 0)) // returns 3 + * math.subset(d, math.index([0, 1], 1)) // returns [[2], [4]] + * math.subset(d, math.index([false, true], 0)) // returns [[3]] + * + * // replace a subset + * const e = [] + * const f = math.subset(e, math.index(0, [0, 2]), [5, 6]) // f = [[5, 0, 6]] + * const g = math.subset(f, math.index(1, 1), 7, 0) // g = [[5, 0, 6], [0, 7, 0]] + * math.subset(g, math.index([false, true], 1), 8) // returns [[5, 0, 6], [0, 8, 0]] + * + * // get submatrix using ranges + * const M = [ + * [1,2,3], + * [4,5,6], + * [7,8,9] + * ] + * math.subset(M, math.index(math.range(0,2), math.range(0,3))) // [[1, 2, 3], [4, 5, 6]] + * + * See also: + * + * size, resize, squeeze, index + * + * @param {Array | Matrix | string} matrix An array, matrix, or string + * @param {Index} index + * For each dimension of the target, specifies an index or a list of + * indices to fetch or set. `subset` uses the cartesian product of + * the indices specified in each dimension. + * @param {*} [replacement] An array, matrix, or scalar. + * If provided, the subset is replaced with replacement. + * If not provided, the subset is returned + * @param {*} [defaultValue=undefined] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * math.matrix elements will be left undefined. + * @return {Array | Matrix | string} Either the retrieved subset or the updated matrix. + */ + + return typed(name, { + // get subset + 'Matrix, Index': function (value, index) { + if ((0, _array.isEmptyIndex)(index)) { + return matrix(); + } + (0, _array.validateIndexSourceSize)(value, index); + return value.subset(index); + }, + 'Array, Index': typed.referTo('Matrix, Index', function (subsetRef) { + return function (value, index) { + const subsetResult = subsetRef(matrix(value), index); + return index.isScalar() ? subsetResult : subsetResult.valueOf(); + }; + }), + 'Object, Index': _getObjectProperty, + 'string, Index': _getSubstring, + // set subset + 'Matrix, Index, any, any': function (value, index, replacement, defaultValue) { + if ((0, _array.isEmptyIndex)(index)) { + return value; + } + (0, _array.validateIndexSourceSize)(value, index); + return value.clone().subset(index, _broadcastReplacement(replacement, index), defaultValue); + }, + 'Array, Index, any, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement, defaultValue) { + const subsetResult = subsetRef(matrix(value), index, replacement, defaultValue); + return subsetResult.isMatrix ? subsetResult.valueOf() : subsetResult; + }; + }), + 'Array, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement) { + return subsetRef(matrix(value), index, replacement, undefined).valueOf(); + }; + }), + 'Matrix, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement) { + return subsetRef(value, index, replacement, undefined); + }; + }), + 'string, Index, string': _setSubstring, + 'string, Index, string, string': _setSubstring, + 'Object, Index, any': _setObjectProperty + }); + + /** + * Broadcasts a replacment value to be the same size as index + * @param {number | BigNumber | Array | Matrix} replacement Replacement value to try to broadcast + * @param {*} index Index value + * @returns broadcasted replacement that matches the size of index + */ + + function _broadcastReplacement(replacement, index) { + if (typeof replacement === 'string') { + throw new Error('can\'t boradcast a string'); + } + if (index._isScalar) { + return replacement; + } + const indexSize = index.size(); + if (indexSize.every(d => d > 0)) { + try { + return add(replacement, zeros(indexSize)); + } catch (error) { + return replacement; + } + } else { + return replacement; + } + } +}); + +/** + * Retrieve a subset of a string + * @param {string} str string from which to get a substring + * @param {Index} index An index or list of indices (character positions) + * @returns {string} substring + * @private + */ +function _getSubstring(str, index) { + if (!(0, _is.isIndex)(index)) { + // TODO: better error message + throw new TypeError('Index expected'); + } + if ((0, _array.isEmptyIndex)(index)) { + return ''; + } + (0, _array.validateIndexSourceSize)(Array.from(str), index); + if (index.size().length !== 1) { + throw new _DimensionError.DimensionError(index.size().length, 1); + } + + // validate whether the range is out of range + const strLen = str.length; + (0, _array.validateIndex)(index.min()[0], strLen); + (0, _array.validateIndex)(index.max()[0], strLen); + const range = index.dimension(0); + let substr = ''; + range.forEach(function (v) { + substr += str.charAt(v); + }); + return substr; +} + +/** + * Replace a substring in a string + * @param {string} str string to be replaced + * @param {Index} index An index or list of indices (character positions) + * @param {string} replacement Replacement string + * @param {string} [defaultValue] Default value to be used when resizing + * the string. is ' ' by default + * @returns {string} result + * @private + */ +function _setSubstring(str, index, replacement, defaultValue) { + if (!index || index.isIndex !== true) { + // TODO: better error message + throw new TypeError('Index expected'); + } + if ((0, _array.isEmptyIndex)(index)) { + return str; + } + (0, _array.validateIndexSourceSize)(Array.from(str), index); + if (index.size().length !== 1) { + throw new _DimensionError.DimensionError(index.size().length, 1); + } + if (defaultValue !== undefined) { + if (typeof defaultValue !== 'string' || defaultValue.length !== 1) { + throw new TypeError('Single character expected as defaultValue'); + } + } else { + defaultValue = ' '; + } + const range = index.dimension(0); + const len = range.size()[0]; + if (len !== replacement.length) { + throw new _DimensionError.DimensionError(range.size()[0], replacement.length); + } + + // validate whether the range is out of range + const strLen = str.length; + (0, _array.validateIndex)(index.min()[0]); + (0, _array.validateIndex)(index.max()[0]); + + // copy the string into an array with characters + const chars = []; + for (let i = 0; i < strLen; i++) { + chars[i] = str.charAt(i); + } + range.forEach(function (v, i) { + chars[v] = replacement.charAt(i[0]); + }); + + // initialize undefined characters with a space + if (chars.length > strLen) { + for (let i = strLen - 1, len = chars.length; i < len; i++) { + if (!chars[i]) { + chars[i] = defaultValue; + } + } + } + return chars.join(''); +} + +/** + * Retrieve a property from an object + * @param {Object} object + * @param {Index} index + * @return {*} Returns the value of the property + * @private + */ +function _getObjectProperty(object, index) { + if ((0, _array.isEmptyIndex)(index)) { + return undefined; + } + if (index.size().length !== 1) { + throw new _DimensionError.DimensionError(index.size(), 1); + } + const key = index.dimension(0); + if (typeof key !== 'string') { + throw new TypeError('String expected as index to retrieve an object property'); + } + return (0, _customs.getSafeProperty)(object, key); +} + +/** + * Set a property on an object + * @param {Object} object + * @param {Index} index + * @param {*} replacement + * @return {*} Returns the updated object + * @private + */ +function _setObjectProperty(object, index, replacement) { + if ((0, _array.isEmptyIndex)(index)) { + return object; + } + if (index.size().length !== 1) { + throw new _DimensionError.DimensionError(index.size(), 1); + } + const key = index.dimension(0); + if (typeof key !== 'string') { + throw new TypeError('String expected as index to retrieve an object property'); + } + + // clone the object, and apply the property to the clone + const updated = (0, _object.clone)(object); + (0, _customs.setSafeProperty)(updated, key, replacement); + return updated; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/trace.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/trace.js new file mode 100644 index 0000000..d947434 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/trace.js @@ -0,0 +1,134 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTrace = void 0; +var _object = require("../../utils/object.js"); +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +const name = 'trace'; +const dependencies = ['typed', 'matrix', 'add']; +const createTrace = exports.createTrace = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + add + } = _ref; + /** + * Calculate the trace of a matrix: the sum of the elements on the main + * diagonal of a square matrix. + * + * Syntax: + * + * math.trace(x) + * + * Examples: + * + * math.trace([[1, 2], [3, 4]]) // returns 5 + * + * const A = [ + * [1, 2, 3], + * [-1, 2, 3], + * [2, 0, 3] + * ] + * math.trace(A) // returns 6 + * + * See also: + * + * diag + * + * @param {Array | Matrix} x A matrix + * + * @return {number} The trace of `x` + */ + return typed('trace', { + Array: function _arrayTrace(x) { + // use dense matrix implementation + return _denseTrace(matrix(x)); + }, + SparseMatrix: _sparseTrace, + DenseMatrix: _denseTrace, + any: _object.clone + }); + function _denseTrace(m) { + // matrix size & data + const size = m._size; + const data = m._data; + + // process dimensions + switch (size.length) { + case 1: + // vector + if (size[0] === 1) { + // return data[0] + return (0, _object.clone)(data[0]); + } + throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')'); + case 2: + { + // two dimensional + const rows = size[0]; + const cols = size[1]; + if (rows === cols) { + // calulate sum + let sum = 0; + // loop diagonal + for (let i = 0; i < rows; i++) { + sum = add(sum, data[i][i]); + } + // return trace + return sum; + } else { + throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')'); + } + } + default: + // multi dimensional + throw new RangeError('Matrix must be two dimensional (size: ' + (0, _string.format)(size) + ')'); + } + } + function _sparseTrace(m) { + // matrix arrays + const values = m._values; + const index = m._index; + const ptr = m._ptr; + const size = m._size; + // check dimensions + const rows = size[0]; + const columns = size[1]; + // matrix must be square + if (rows === columns) { + // calulate sum + let sum = 0; + // check we have data (avoid looping columns) + if (values.length > 0) { + // loop columns + for (let j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = ptr[j]; + const k1 = ptr[j + 1]; + // loop k within [k0, k1[ + for (let k = k0; k < k1; k++) { + // row index + const i = index[k]; + // check row + if (i === j) { + // accumulate value + sum = add(sum, values[k]); + // exit loop + break; + } + if (i > j) { + // exit loop, no value on the diagonal for column j + break; + } + } + } + } + // return trace + return sum; + } + throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/transpose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/transpose.js new file mode 100644 index 0000000..f7e158d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/transpose.js @@ -0,0 +1,166 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTranspose = void 0; +var _object = require("../../utils/object.js"); +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +const name = 'transpose'; +const dependencies = ['typed', 'matrix']; +const createTranspose = exports.createTranspose = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix + } = _ref; + /** + * Transpose a matrix. All values of the matrix are reflected over its + * main diagonal. Only applicable to two dimensional matrices containing + * a vector (i.e. having size `[1,n]` or `[n,1]`). One dimensional + * vectors and scalars return the input unchanged. + * + * Syntax: + * + * math.transpose(x) + * + * Examples: + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.transpose(A) // returns [[1, 4], [2, 5], [3, 6]] + * + * See also: + * + * diag, inv, subset, squeeze + * + * @param {Array | Matrix} x Matrix to be transposed + * @return {Array | Matrix} The transposed matrix + */ + return typed(name, { + Array: x => transposeMatrix(matrix(x)).valueOf(), + Matrix: transposeMatrix, + any: _object.clone // scalars + }); + function transposeMatrix(x) { + // matrix size + const size = x.size(); + + // result + let c; + + // process dimensions + switch (size.length) { + case 1: + // vector + c = x.clone(); + break; + case 2: + { + // rows and columns + const rows = size[0]; + const columns = size[1]; + + // check columns + if (columns === 0) { + // throw exception + throw new RangeError('Cannot transpose a 2D matrix with no columns (size: ' + (0, _string.format)(size) + ')'); + } + + // process storage format + switch (x.storage()) { + case 'dense': + c = _denseTranspose(x, rows, columns); + break; + case 'sparse': + c = _sparseTranspose(x, rows, columns); + break; + } + } + break; + default: + // multi dimensional + throw new RangeError('Matrix must be a vector or two dimensional (size: ' + (0, _string.format)(size) + ')'); + } + return c; + } + function _denseTranspose(m, rows, columns) { + // matrix array + const data = m._data; + // transposed matrix data + const transposed = []; + let transposedRow; + // loop columns + for (let j = 0; j < columns; j++) { + // initialize row + transposedRow = transposed[j] = []; + // loop rows + for (let i = 0; i < rows; i++) { + // set data + transposedRow[i] = (0, _object.clone)(data[i][j]); + } + } + // return matrix + return m.createDenseMatrix({ + data: transposed, + size: [columns, rows], + datatype: m._datatype + }); + } + function _sparseTranspose(m, rows, columns) { + // matrix arrays + const values = m._values; + const index = m._index; + const ptr = m._ptr; + // result matrices + const cvalues = values ? [] : undefined; + const cindex = []; + const cptr = []; + // row counts + const w = []; + for (let x = 0; x < rows; x++) { + w[x] = 0; + } + // vars + let p, l, j; + // loop values in matrix + for (p = 0, l = index.length; p < l; p++) { + // number of values in row + w[index[p]]++; + } + // cumulative sum + let sum = 0; + // initialize cptr with the cummulative sum of row counts + for (let i = 0; i < rows; i++) { + // update cptr + cptr.push(sum); + // update sum + sum += w[i]; + // update w + w[i] = cptr[i]; + } + // update cptr + cptr.push(sum); + // loop columns + for (j = 0; j < columns; j++) { + // values & index in column + for (let k0 = ptr[j], k1 = ptr[j + 1], k = k0; k < k1; k++) { + // C values & index + const q = w[index[k]]++; + // C[j, i] = A[i, j] + cindex[q] = j; + // check we need to process values (pattern matrix) + if (values) { + cvalues[q] = (0, _object.clone)(values[k]); + } + } + } + // return matrix + return m.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [columns, rows], + datatype: m._datatype + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/zeros.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/zeros.js new file mode 100644 index 0000000..0d072a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/matrix/zeros.js @@ -0,0 +1,129 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createZeros = void 0; +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'zeros'; +const dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +const createZeros = exports.createZeros = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Create a matrix filled with zeros. The created matrix can have one or + * multiple dimensions. + * + * Syntax: + * + * math.zeros(m) + * math.zeros(m, format) + * math.zeros(m, n) + * math.zeros(m, n, format) + * math.zeros([m, n]) + * math.zeros([m, n], format) + * + * Examples: + * + * math.zeros() // returns [] + * math.zeros(3) // returns [0, 0, 0] + * math.zeros(3, 2) // returns [[0, 0], [0, 0], [0, 0]] + * math.zeros(3, 'dense') // returns [0, 0, 0] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.zeros(math.size(A)) // returns [[0, 0, 0], [0, 0, 0]] + * + * See also: + * + * ones, identity, size, range + * + * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Array | Matrix} A matrix filled with zeros + */ + return typed(name, { + '': function () { + return config.matrix === 'Array' ? _zeros([]) : _zeros([], 'default'); + }, + // math.zeros(m, n, p, ..., format) + // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this + '...number | BigNumber | string': function (size) { + const last = size[size.length - 1]; + if (typeof last === 'string') { + const format = size.pop(); + return _zeros(size, format); + } else if (config.matrix === 'Array') { + return _zeros(size); + } else { + return _zeros(size, 'default'); + } + }, + Array: _zeros, + Matrix: function (size) { + const format = size.storage(); + return _zeros(size.valueOf(), format); + }, + 'Array | Matrix, string': function (size, format) { + return _zeros(size.valueOf(), format); + } + }); + + /** + * Create an Array or Matrix with zeros + * @param {Array} size + * @param {string} [format='default'] + * @return {Array | Matrix} + * @private + */ + function _zeros(size, format) { + const hasBigNumbers = _normalize(size); + const defaultValue = hasBigNumbers ? new BigNumber(0) : 0; + _validate(size); + if (format) { + // return a matrix + const m = matrix(format); + if (size.length > 0) { + return m.resize(size, defaultValue); + } + return m; + } else { + // return an Array + const arr = []; + if (size.length > 0) { + return (0, _array.resize)(arr, size, defaultValue); + } + return arr; + } + } + + // replace BigNumbers with numbers, returns true if size contained BigNumbers + function _normalize(size) { + let hasBigNumbers = false; + size.forEach(function (value, index, arr) { + if ((0, _is.isBigNumber)(value)) { + hasBigNumbers = true; + arr[index] = value.toNumber(); + } + }); + return hasBigNumbers; + } + + // validate arguments + function _validate(size) { + size.forEach(function (value) { + if (typeof value !== 'number' || !(0, _number.isInteger)(value) || value < 0) { + throw new Error('Parameters in function zeros must be positive integers'); + } + }); + } +}); + +// TODO: zeros contains almost the same code as ones. Reuse this? \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/numeric/solveODE.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/numeric/solveODE.js new file mode 100644 index 0000000..f55aaad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/numeric/solveODE.js @@ -0,0 +1,289 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSolveODE = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'solveODE'; +const dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'max', 'map', 'abs', 'isPositive', 'isNegative', 'larger', 'smaller', 'matrix', 'bignumber', 'unaryMinus']; +const createSolveODE = exports.createSolveODE = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + subtract, + multiply, + divide, + max, + map, + abs, + isPositive, + isNegative, + larger, + smaller, + matrix, + bignumber, + unaryMinus + } = _ref; + /** + * Numerical Integration of Ordinary Differential Equations + * + * Two variable step methods are provided: + * - "RK23": Bogacki–Shampine method + * - "RK45": Dormand-Prince method RK5(4)7M (default) + * + * The arguments are expected as follows. + * + * - `func` should be the forcing function `f(t, y)` + * - `tspan` should be a vector of two numbers or units `[tStart, tEnd]` + * - `y0` the initial state values, should be a scalar or a flat array + * - `options` should be an object with the following information: + * - `method` ('RK45'): ['RK23', 'RK45'] + * - `tol` (1e-3): Numeric tolerance of the method, the solver keeps the error estimates less than this value + * - `firstStep`: Initial step size + * - `minStep`: minimum step size of the method + * - `maxStep`: maximum step size of the method + * - `minDelta` (0.2): minimum ratio of change for the step + * - `maxDelta` (5): maximum ratio of change for the step + * - `maxIter` (1e4): maximum number of iterations + * + * The returned value is an object with `{t, y}` please note that even though `t` means time, it can represent any other independant variable like `x`: + * - `t` an array of size `[n]` + * - `y` the states array can be in two ways + * - **if `y0` is a scalar:** returns an array-like of size `[n]` + * - **if `y0` is a flat array-like of size [m]:** returns an array like of size `[n, m]` + * + * Syntax: + * + * math.solveODE(func, tspan, y0) + * math.solveODE(func, tspan, y0, options) + * + * Examples: + * + * function func(t, y) {return y} + * const tspan = [0, 4] + * const y0 = 1 + * math.solveODE(func, tspan, y0) + * math.solveODE(func, tspan, [1, 2]) + * math.solveODE(func, tspan, y0, { method:"RK23", maxStep:0.1 }) + * + * See also: + * + * derivative, simplifyCore + * + * @param {function} func The forcing function f(t,y) + * @param {Array | Matrix} tspan The time span + * @param {number | BigNumber | Unit | Array | Matrix} y0 The initial value + * @param {Object} [options] Optional configuration options + * @return {Object} Return an object with t and y values as arrays + */ + + function _rk(butcherTableau) { + // generates an adaptive runge kutta method from it's butcher tableau + + return function (f, tspan, y0, options) { + // adaptive runge kutta methods + const wrongTSpan = !(tspan.length === 2 && (tspan.every(isNumOrBig) || tspan.every(_is.isUnit))); + if (wrongTSpan) { + throw new Error('"tspan" must be an Array of two numeric values or two units [tStart, tEnd]'); + } + const t0 = tspan[0]; // initial time + const tf = tspan[1]; // final time + const isForwards = larger(tf, t0); + const firstStep = options.firstStep; + if (firstStep !== undefined && !isPositive(firstStep)) { + throw new Error('"firstStep" must be positive'); + } + const maxStep = options.maxStep; + if (maxStep !== undefined && !isPositive(maxStep)) { + throw new Error('"maxStep" must be positive'); + } + const minStep = options.minStep; + if (minStep && isNegative(minStep)) { + throw new Error('"minStep" must be positive or zero'); + } + const timeVars = [t0, tf, firstStep, minStep, maxStep].filter(x => x !== undefined); + if (!(timeVars.every(isNumOrBig) || timeVars.every(_is.isUnit))) { + throw new Error('Inconsistent type of "t" dependant variables'); + } + const steps = 1; // divide time in this number of steps + const tol = options.tol ? options.tol : 1e-4; // define a tolerance (must be an option) + const minDelta = options.minDelta ? options.minDelta : 0.2; + const maxDelta = options.maxDelta ? options.maxDelta : 5; + const maxIter = options.maxIter ? options.maxIter : 10000; // stop inifite evaluation if something goes wrong + const hasBigNumbers = [t0, tf, ...y0, maxStep, minStep].some(_is.isBigNumber); + const [a, c, b, bp] = hasBigNumbers ? [bignumber(butcherTableau.a), bignumber(butcherTableau.c), bignumber(butcherTableau.b), bignumber(butcherTableau.bp)] : [butcherTableau.a, butcherTableau.c, butcherTableau.b, butcherTableau.bp]; + let h = firstStep ? isForwards ? firstStep : unaryMinus(firstStep) : divide(subtract(tf, t0), steps); // define the first step size + const t = [t0]; // start the time array + const y = [y0]; // start the solution array + + const deltaB = subtract(b, bp); // b - bp + + let n = 0; + let iter = 0; + const ongoing = _createOngoing(isForwards); + const trimStep = _createTrimStep(isForwards); + // iterate unitil it reaches either the final time or maximum iterations + while (ongoing(t[n], tf)) { + const k = []; + + // trim the time step so that it doesn't overshoot + h = trimStep(t[n], tf, h); + + // calculate the first value of k + k.push(f(t[n], y[n])); + + // calculate the rest of the values of k + for (let i = 1; i < c.length; ++i) { + k.push(f(add(t[n], multiply(c[i], h)), add(y[n], multiply(h, a[i], k)))); + } + + // estimate the error by comparing solutions of different orders + const TE = max(abs(map(multiply(deltaB, k), X => (0, _is.isUnit)(X) ? X.value : X))); + if (TE < tol && tol / TE > 1 / 4) { + // push solution if within tol + t.push(add(t[n], h)); + y.push(add(y[n], multiply(h, b, k))); + n++; + } + + // estimate the delta value that will affect the step size + let delta = 0.84 * (tol / TE) ** (1 / 5); + if (smaller(delta, minDelta)) { + delta = minDelta; + } else if (larger(delta, maxDelta)) { + delta = maxDelta; + } + delta = hasBigNumbers ? bignumber(delta) : delta; + h = multiply(h, delta); + if (maxStep && larger(abs(h), maxStep)) { + h = isForwards ? maxStep : unaryMinus(maxStep); + } else if (minStep && smaller(abs(h), minStep)) { + h = isForwards ? minStep : unaryMinus(minStep); + } + iter++; + if (iter > maxIter) { + throw new Error('Maximum number of iterations reached, try changing options'); + } + } + return { + t, + y + }; + }; + } + function _rk23(f, tspan, y0, options) { + // Bogacki–Shampine method + + // Define the butcher table + const a = [[], [1 / 2], [0, 3 / 4], [2 / 9, 1 / 3, 4 / 9]]; + const c = [null, 1 / 2, 3 / 4, 1]; + const b = [2 / 9, 1 / 3, 4 / 9, 0]; + const bp = [7 / 24, 1 / 4, 1 / 3, 1 / 8]; + const butcherTableau = { + a, + c, + b, + bp + }; + + // Solve an adaptive step size rk method + return _rk(butcherTableau)(f, tspan, y0, options); + } + function _rk45(f, tspan, y0, options) { + // Dormand Prince method + + // Define the butcher tableau + const a = [[], [1 / 5], [3 / 40, 9 / 40], [44 / 45, -56 / 15, 32 / 9], [19372 / 6561, -25360 / 2187, 64448 / 6561, -212 / 729], [9017 / 3168, -355 / 33, 46732 / 5247, 49 / 176, -5103 / 18656], [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84]]; + const c = [null, 1 / 5, 3 / 10, 4 / 5, 8 / 9, 1, 1]; + const b = [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84, 0]; + const bp = [5179 / 57600, 0, 7571 / 16695, 393 / 640, -92097 / 339200, 187 / 2100, 1 / 40]; + const butcherTableau = { + a, + c, + b, + bp + }; + + // Solve an adaptive step size rk method + return _rk(butcherTableau)(f, tspan, y0, options); + } + function _solveODE(f, tspan, y0, opt) { + const method = opt.method ? opt.method : 'RK45'; + const methods = { + RK23: _rk23, + RK45: _rk45 + }; + if (method.toUpperCase() in methods) { + const methodOptions = { + ...opt + }; // clone the options object + delete methodOptions.method; // delete the method as it won't be needed + return methods[method.toUpperCase()](f, tspan, y0, methodOptions); + } else { + // throw an error indicating there is no such method + const methodsWithQuotes = Object.keys(methods).map(x => `"${x}"`); + // generates a string of methods like: "BDF", "RK23" and "RK45" + const availableMethodsString = `${methodsWithQuotes.slice(0, -1).join(', ')} and ${methodsWithQuotes.slice(-1)}`; + throw new Error(`Unavailable method "${method}". Available methods are ${availableMethodsString}`); + } + } + function _createOngoing(isForwards) { + // returns the correct function to test if it's still iterating + return isForwards ? smaller : larger; + } + function _createTrimStep(isForwards) { + const outOfBounds = isForwards ? larger : smaller; + return function (t, tf, h) { + const next = add(t, h); + return outOfBounds(next, tf) ? subtract(tf, t) : h; + }; + } + function isNumOrBig(x) { + // checks if it's a number or bignumber + return (0, _is.isBigNumber)(x) || (0, _is.isNumber)(x); + } + function _matrixSolveODE(f, T, y0, options) { + // receives matrices and returns matrices + const sol = _solveODE(f, T.toArray(), y0.toArray(), options); + return { + t: matrix(sol.t), + y: matrix(sol.y) + }; + } + return typed('solveODE', { + 'function, Array, Array, Object': _solveODE, + 'function, Matrix, Matrix, Object': _matrixSolveODE, + 'function, Array, Array': (f, T, y0) => _solveODE(f, T, y0, {}), + 'function, Matrix, Matrix': (f, T, y0) => _matrixSolveODE(f, T, y0, {}), + 'function, Array, number | BigNumber | Unit': (f, T, y0) => { + const sol = _solveODE(f, T, [y0], {}); + return { + t: sol.t, + y: sol.y.map(Y => Y[0]) + }; + }, + 'function, Matrix, number | BigNumber | Unit': (f, T, y0) => { + const sol = _solveODE(f, T.toArray(), [y0], {}); + return { + t: matrix(sol.t), + y: matrix(sol.y.map(Y => Y[0])) + }; + }, + 'function, Array, number | BigNumber | Unit, Object': (f, T, y0, options) => { + const sol = _solveODE(f, T, [y0], options); + return { + t: sol.t, + y: sol.y.map(Y => Y[0]) + }; + }, + 'function, Matrix, number | BigNumber | Unit, Object': (f, T, y0, options) => { + const sol = _solveODE(f, T.toArray(), [y0], options); + return { + t: matrix(sol.t), + y: matrix(sol.y.map(Y => Y[0])) + }; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinations.js new file mode 100644 index 0000000..bab7bcc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinations.js @@ -0,0 +1,75 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCombinations = void 0; +var _factory = require("../../utils/factory.js"); +var _combinations = require("../../plain/number/combinations.js"); +const name = 'combinations'; +const dependencies = ['typed']; +const createCombinations = exports.createCombinations = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the number of ways of picking `k` unordered outcomes from `n` + * possibilities. + * + * Combinations only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.combinations(n, k) + * + * Examples: + * + * math.combinations(7, 5) // returns 21 + * + * See also: + * + * combinationsWithRep, permutations, factorial + * + * @param {number | BigNumber} n Total number of objects in the set + * @param {number | BigNumber} k Number of objects in the subset + * @return {number | BigNumber} Number of possible combinations. + */ + return typed(name, { + 'number, number': _combinations.combinationsNumber, + 'BigNumber, BigNumber': function (n, k) { + const BigNumber = n.constructor; + let result, i; + const nMinusk = n.minus(k); + const one = new BigNumber(1); + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (k.gt(n)) { + throw new TypeError('k must be less than n in function combinations'); + } + result = one; + if (k.lt(nMinusk)) { + for (i = one; i.lte(nMinusk); i = i.plus(one)) { + result = result.times(k.plus(i)).dividedBy(i); + } + } else { + for (i = one; i.lte(k); i = i.plus(one)) { + result = result.times(nMinusk.plus(i)).dividedBy(i); + } + } + return result; + } + + // TODO: implement support for collection in combinations + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinationsWithRep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinationsWithRep.js new file mode 100644 index 0000000..1890792 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/combinationsWithRep.js @@ -0,0 +1,90 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCombinationsWithRep = void 0; +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _product = require("../../utils/product.js"); +const name = 'combinationsWithRep'; +const dependencies = ['typed']; +const createCombinationsWithRep = exports.createCombinationsWithRep = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the number of ways of picking `k` unordered outcomes from `n` + * possibilities, allowing individual outcomes to be repeated more than once. + * + * CombinationsWithRep only takes integer arguments. + * The following condition must be enforced: k <= n + k -1. + * + * Syntax: + * + * math.combinationsWithRep(n, k) + * + * Examples: + * + * math.combinationsWithRep(7, 5) // returns 462 + * + * See also: + * + * combinations, permutations, factorial + * + * @param {number | BigNumber} n Total number of objects in the set + * @param {number | BigNumber} k Number of objects in the subset + * @return {number | BigNumber} Number of possible combinations with replacement. + */ + return typed(name, { + 'number, number': function (n, k) { + if (!(0, _number.isInteger)(n) || n < 0) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (!(0, _number.isInteger)(k) || k < 0) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (n < 1) { + throw new TypeError('k must be less than or equal to n + k - 1'); + } + if (k < n - 1) { + const prodrange = (0, _product.product)(n, n + k - 1); + return prodrange / (0, _product.product)(1, k); + } + const prodrange = (0, _product.product)(k + 1, n + k - 1); + return prodrange / (0, _product.product)(1, n - 1); + }, + 'BigNumber, BigNumber': function (n, k) { + const BigNumber = n.constructor; + let result, i; + const one = new BigNumber(1); + const nMinusOne = n.minus(one); + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (n.lt(one)) { + throw new TypeError('k must be less than or equal to n + k - 1 in function combinationsWithRep'); + } + result = one; + if (k.lt(nMinusOne)) { + for (i = one; i.lte(nMinusOne); i = i.plus(one)) { + result = result.times(k.plus(i)).dividedBy(i); + } + } else { + for (i = one; i.lte(k); i = i.plus(one)) { + result = result.times(nMinusOne.plus(i)).dividedBy(i); + } + } + return result; + } + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/factorial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/factorial.js new file mode 100644 index 0000000..2932e26 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/factorial.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFactorial = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'factorial'; +const dependencies = ['typed', 'gamma']; +const createFactorial = exports.createFactorial = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + gamma + } = _ref; + /** + * Compute the factorial of a value + * + * Factorial only supports an integer value as argument. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.factorial(n) + * + * Examples: + * + * math.factorial(5) // returns 120 + * math.factorial(3) // returns 6 + * + * See also: + * + * combinations, combinationsWithRep, gamma, permutations + * + * @param {number | BigNumber | Array | Matrix} n An integer number + * @return {number | BigNumber | Array | Matrix} The factorial of `n` + */ + return typed(name, { + number: function (n) { + if (n < 0) { + throw new Error('Value must be non-negative'); + } + return gamma(n + 1); + }, + BigNumber: function (n) { + if (n.isNegative()) { + throw new Error('Value must be non-negative'); + } + return gamma(n.plus(1)); + }, + 'Array | Matrix': typed.referToSelf(self => n => (0, _collection.deepMap)(n, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/gamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/gamma.js new file mode 100644 index 0000000..d9494a6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/gamma.js @@ -0,0 +1,126 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createGamma = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'gamma'; +const dependencies = ['typed', 'config', 'multiplyScalar', 'pow', 'BigNumber', 'Complex']; +const createGamma = exports.createGamma = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + multiplyScalar, + pow, + BigNumber, + Complex + } = _ref; + /** + * Compute the gamma function of a value using Lanczos approximation for + * small values, and an extended Stirling approximation for large values. + * + * To avoid confusion with the matrix Gamma function, this function does + * not apply to matrices. + * + * Syntax: + * + * math.gamma(n) + * + * Examples: + * + * math.gamma(5) // returns 24 + * math.gamma(-0.5) // returns -3.5449077018110335 + * math.gamma(math.i) // returns -0.15494982830180973 - 0.49801566811835596i + * + * See also: + * + * combinations, factorial, permutations + * + * @param {number | BigNumber | Complex} n A real or complex number + * @return {number | BigNumber | Complex} The gamma of `n` + */ + + function gammaComplex(n) { + if (n.im === 0) { + return (0, _index.gammaNumber)(n.re); + } + + // Lanczos approximation doesn't work well with real part lower than 0.5 + // So reflection formula is required + if (n.re < 0.5) { + // Euler's reflection formula + // gamma(1-z) * gamma(z) = PI / sin(PI * z) + // real part of Z should not be integer [sin(PI) == 0 -> 1/0 - undefined] + // thanks to imperfect sin implementation sin(PI * n) != 0 + // we can safely use it anyway + const t = new Complex(1 - n.re, -n.im); + const r = new Complex(Math.PI * n.re, Math.PI * n.im); + return new Complex(Math.PI).div(r.sin()).div(gammaComplex(t)); + } + + // Lanczos approximation + // z -= 1 + n = new Complex(n.re - 1, n.im); + + // x = gammaPval[0] + let x = new Complex(_index.gammaP[0], 0); + // for (i, gammaPval) in enumerate(gammaP): + for (let i = 1; i < _index.gammaP.length; ++i) { + // x += gammaPval / (z + i) + const gammaPval = new Complex(_index.gammaP[i], 0); + x = x.add(gammaPval.div(n.add(i))); + } + // t = z + gammaG + 0.5 + const t = new Complex(n.re + _index.gammaG + 0.5, n.im); + + // y = sqrt(2 * pi) * t ** (z + 0.5) * exp(-t) * x + const twoPiSqrt = Math.sqrt(2 * Math.PI); + const tpow = t.pow(n.add(0.5)); + const expt = t.neg().exp(); + + // y = [x] * [sqrt(2 * pi)] * [t ** (z + 0.5)] * [exp(-t)] + return x.mul(twoPiSqrt).mul(tpow).mul(expt); + } + return typed(name, { + number: _index.gammaNumber, + Complex: gammaComplex, + BigNumber: function (n) { + if (n.isInteger()) { + return n.isNegative() || n.isZero() ? new BigNumber(Infinity) : bigFactorial(n.minus(1)); + } + if (!n.isFinite()) { + return new BigNumber(n.isNegative() ? NaN : Infinity); + } + throw new Error('Integer BigNumber expected'); + } + }); + + /** + * Calculate factorial for a BigNumber + * @param {BigNumber} n + * @returns {BigNumber} Returns the factorial of n + */ + function bigFactorial(n) { + if (n < 8) { + return new BigNumber([1, 1, 2, 6, 24, 120, 720, 5040][n]); + } + const precision = config.precision + (Math.log(n.toNumber()) | 0); + const Big = BigNumber.clone({ + precision + }); + if (n % 2 === 1) { + return n.times(bigFactorial(new BigNumber(n - 1))); + } + let p = n; + let prod = new Big(n); + let sum = n.toNumber(); + while (p > 2) { + p -= 2; + sum += p; + prod = prod.times(sum); + } + return new BigNumber(prod.toPrecision(BigNumber.precision)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/kldivergence.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/kldivergence.js new file mode 100644 index 0000000..41cf6d6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/kldivergence.js @@ -0,0 +1,83 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createKldivergence = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'kldivergence'; +const dependencies = ['typed', 'matrix', 'divide', 'sum', 'multiply', 'map', 'dotDivide', 'log', 'isNumeric']; +const createKldivergence = exports.createKldivergence = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + divide, + sum, + multiply, + map, + dotDivide, + log, + isNumeric + } = _ref; + /** + * Calculate the Kullback-Leibler (KL) divergence between two distributions + * + * Syntax: + * + * math.kldivergence(x, y) + * + * Examples: + * + * math.kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5]) //returns 0.24376698773121153 + * + * + * @param {Array | Matrix} q First vector + * @param {Array | Matrix} p Second vector + * @return {number} Returns distance between q and p + */ + return typed(name, { + 'Array, Array': function (q, p) { + return _kldiv(matrix(q), matrix(p)); + }, + 'Matrix, Array': function (q, p) { + return _kldiv(q, matrix(p)); + }, + 'Array, Matrix': function (q, p) { + return _kldiv(matrix(q), p); + }, + 'Matrix, Matrix': function (q, p) { + return _kldiv(q, p); + } + }); + function _kldiv(q, p) { + const plength = p.size().length; + const qlength = q.size().length; + if (plength > 1) { + throw new Error('first object must be one dimensional'); + } + if (qlength > 1) { + throw new Error('second object must be one dimensional'); + } + if (plength !== qlength) { + throw new Error('Length of two vectors must be equal'); + } + + // Before calculation, apply normalization + const sumq = sum(q); + if (sumq === 0) { + throw new Error('Sum of elements in first object must be non zero'); + } + const sump = sum(p); + if (sump === 0) { + throw new Error('Sum of elements in second object must be non zero'); + } + const qnorm = divide(q, sum(q)); + const pnorm = divide(p, sum(p)); + const result = sum(multiply(qnorm, map(dotDivide(qnorm, pnorm), x => log(x)))); + if (isNumeric(result)) { + return result; + } else { + return Number.NaN; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/lgamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/lgamma.js new file mode 100644 index 0000000..b0664a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/lgamma.js @@ -0,0 +1,143 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLgamma = void 0; +var _index = require("../../plain/number/index.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +/* eslint-disable no-loss-of-precision */ + +// References +// ---------- +// [1] Hare, "Computing the Principal Branch of log-Gamma", Journal of Algorithms, 1997. +// [2] https://math.stackexchange.com/questions/1338753/how-do-i-calculate-values-for-gamma-function-with-complex-arguments + +const name = 'lgamma'; +const dependencies = ['Complex', 'typed']; +const createLgamma = exports.createLgamma = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Complex, + typed + } = _ref; + // Stirling series is non-convergent, we need to use the recurrence `lgamma(z) = lgamma(z+1) - log z` to get + // sufficient accuracy. + // + // These two values are copied from Scipy implementation: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L37 + const SMALL_RE = 7; + const SMALL_IM = 7; + + /** + * The coefficients are B[2*n]/(2*n*(2*n - 1)) where B[2*n] is the (2*n)th Bernoulli number. See (1.1) in [1]. + * + * If you cannot access the paper, can also get these values from the formula in [2]. + * + * 1 / 12 = 0.00833333333333333333333333333333 + * 1 / 360 = 0.00277777777777777777777777777778 + * ... + * 3617 / 133400 = 0.02955065359477124183006535947712 + */ + const coeffs = [-2.955065359477124183e-2, 6.4102564102564102564e-3, -1.9175269175269175269e-3, 8.4175084175084175084e-4, -5.952380952380952381e-4, 7.9365079365079365079e-4, -2.7777777777777777778e-3, 8.3333333333333333333e-2]; + + /** + * Logarithm of the gamma function for real, positive numbers and complex numbers, + * using Lanczos approximation for numbers and Stirling series for complex numbers. + * + * Syntax: + * + * math.lgamma(n) + * + * Examples: + * + * math.lgamma(5) // returns 3.178053830347945 + * math.lgamma(0) // returns Infinity + * math.lgamma(-0.5) // returns NaN + * math.lgamma(math.i) // returns -0.6509231993018536 - 1.8724366472624294i + * + * See also: + * + * gamma + * + * @param {number | Complex} n A real or complex number + * @return {number | Complex} The log gamma of `n` + */ + return typed(name, { + number: _index.lgammaNumber, + Complex: lgammaComplex, + BigNumber: function () { + throw new Error("mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber"); + } + }); + function lgammaComplex(n) { + const TWOPI = 6.2831853071795864769252842; // 2*pi + const LOGPI = 1.1447298858494001741434262; // log(pi) + + const REFLECTION = 0.1; + if (n.isNaN()) { + return new Complex(NaN, NaN); + } else if (n.im === 0) { + return new Complex((0, _index.lgammaNumber)(n.re), 0); + } else if (n.re >= SMALL_RE || Math.abs(n.im) >= SMALL_IM) { + return lgammaStirling(n); + } else if (n.re <= REFLECTION) { + // Reflection formula. see Proposition 3.1 in [1] + const tmp = (0, _number.copysign)(TWOPI, n.im) * Math.floor(0.5 * n.re + 0.25); + const a = n.mul(Math.PI).sin().log(); + const b = lgammaComplex(new Complex(1 - n.re, -n.im)); + return new Complex(LOGPI, tmp).sub(a).sub(b); + } else if (n.im >= 0) { + return lgammaRecurrence(n); + } else { + return lgammaRecurrence(n.conjugate()).conjugate(); + } + } + function lgammaStirling(z) { + // formula ref in [2] + // computation ref: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L101 + + // left part + + // x (log(x) - 1) + 1/2 (log(2PI) - log(x)) + // => (x - 0.5) * log(x) - x + log(2PI) / 2 + const leftPart = z.sub(0.5).mul(z.log()).sub(z).add(_index.lnSqrt2PI); + + // right part + + const rz = new Complex(1, 0).div(z); + const rzz = rz.div(z); + let a = coeffs[0]; + let b = coeffs[1]; + const r = 2 * rzz.re; + const s = rzz.re * rzz.re + rzz.im * rzz.im; + for (let i = 2; i < 8; i++) { + const tmp = b; + b = -s * a + coeffs[i]; + a = r * a + tmp; + } + const rightPart = rz.mul(rzz.mul(a).add(b)); + + // plus left and right + + return leftPart.add(rightPart); + } + function lgammaRecurrence(z) { + // computation ref: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L78 + + let signflips = 0; + let sb = 0; + let shiftprod = z; + z = z.add(1); + while (z.re <= SMALL_RE) { + shiftprod = shiftprod.mul(z); + const nsb = shiftprod.im < 0 ? 1 : 0; + if (nsb !== 0 && sb === 0) signflips++; + sb = nsb; + z = z.add(1); + } + return lgammaStirling(z).sub(shiftprod.log()).sub(new Complex(0, signflips * 2 * Math.PI * 1)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/multinomial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/multinomial.js new file mode 100644 index 0000000..6ef829b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/multinomial.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMultinomial = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'multinomial'; +const dependencies = ['typed', 'add', 'divide', 'multiply', 'factorial', 'isInteger', 'isPositive']; +const createMultinomial = exports.createMultinomial = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + divide, + multiply, + factorial, + isInteger, + isPositive + } = _ref; + /** + * Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. + * + * multinomial takes one array of integers as an argument. + * The following condition must be enforced: every ai <= 0 + * + * Syntax: + * + * math.multinomial(a) // a is an array type + * + * Examples: + * + * math.multinomial([1,2,1]) // returns 12 + * + * See also: + * + * combinations, factorial + * + * @param {number[] | BigNumber[]} a Integer numbers of objects in the subset + * @return {Number | BigNumber} Multinomial coefficient. + */ + return typed(name, { + 'Array | Matrix': function (a) { + let sum = 0; + let denom = 1; + (0, _collection.deepForEach)(a, function (ai) { + if (!isInteger(ai) || !isPositive(ai)) { + throw new TypeError('Positive integer value expected in function multinomial'); + } + sum = add(sum, ai); + denom = multiply(denom, factorial(ai)); + }); + return divide(factorial(sum), denom); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/permutations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/permutations.js new file mode 100644 index 0000000..f1694dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/permutations.js @@ -0,0 +1,84 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPermutations = void 0; +var _number = require("../../utils/number.js"); +var _product = require("../../utils/product.js"); +var _factory = require("../../utils/factory.js"); +const name = 'permutations'; +const dependencies = ['typed', 'factorial']; +const createPermutations = exports.createPermutations = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + factorial + } = _ref; + /** + * Compute the number of ways of obtaining an ordered subset of `k` elements + * from a set of `n` elements. + * + * Permutations only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.permutations(n) + * math.permutations(n, k) + * + * Examples: + * + * math.permutations(5) // 120 + * math.permutations(5, 3) // 60 + * + * See also: + * + * combinations, combinationsWithRep, factorial + * + * @param {number | BigNumber} n The number of objects in total + * @param {number | BigNumber} [k] The number of objects in the subset + * @return {number | BigNumber} The number of permutations + */ + return typed(name, { + 'number | BigNumber': factorial, + 'number, number': function (n, k) { + if (!(0, _number.isInteger)(n) || n < 0) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (!(0, _number.isInteger)(k) || k < 0) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (k > n) { + throw new TypeError('second argument k must be less than or equal to first argument n'); + } + // Permute n objects, k at a time + return (0, _product.product)(n - k + 1, n); + }, + 'BigNumber, BigNumber': function (n, k) { + let result, i; + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (k.gt(n)) { + throw new TypeError('second argument k must be less than or equal to first argument n'); + } + const one = n.mul(0).add(1); + result = one; + for (i = n.minus(k).plus(1); i.lte(n); i = i.plus(1)) { + result = result.times(i); + } + return result; + } + + // TODO: implement support for collection in permutations + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/pickRandom.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/pickRandom.js new file mode 100644 index 0000000..2607481 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/pickRandom.js @@ -0,0 +1,156 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPickRandom = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _seededRNG = require("./util/seededRNG.js"); +const name = 'pickRandom'; +const dependencies = ['typed', 'config', '?on']; +const createPickRandom = exports.createPickRandom = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + let rng = (0, _seededRNG.createRng)(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = (0, _seededRNG.createRng)(curr.randomSeed); + } + }); + } + + /** + * Random pick one or more values from a one dimensional array. + * Array elements are picked using a random function with uniform or weighted distribution. + * + * Syntax: + * + * math.pickRandom(array) + * math.pickRandom(array, number) + * math.pickRandom(array, weights) + * math.pickRandom(array, number, weights) + * math.pickRandom(array, weights, number) + * math.pickRandom(array, { weights, number, elementWise }) + * + * Examples: + * + * math.pickRandom([3, 6, 12, 2]) // returns one of the values in the array + * math.pickRandom([3, 6, 12, 2], 2) // returns an array of two of the values in the array + * math.pickRandom([3, 6, 12, 2], { number: 2 }) // returns an array of two of the values in the array + * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1]) // returns one of the values in the array with weighted distribution + * math.pickRandom([3, 6, 12, 2], 2, [1, 3, 2, 1]) // returns an array of two of the values in the array with weighted distribution + * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1], 2) // returns an array of two of the values in the array with weighted distribution + * + * math.pickRandom([{x: 1.0, y: 2.0}, {x: 1.1, y: 2.0}], { elementWise: false }) + * // returns one of the items in the array + * + * See also: + * + * random, randomInt + * + * @param {Array | Matrix} array A one dimensional array + * @param {Int} number An int or float + * @param {Array | Matrix} weights An array of ints or floats + * @return {number | Array} Returns a single random value from array when number is undefined. + * Returns an array with the configured number of elements when number is defined. + */ + return typed(name, { + 'Array | Matrix': function (possibles) { + return _pickRandom(possibles, {}); + }, + 'Array | Matrix, Object': function (possibles, options) { + return _pickRandom(possibles, options); + }, + 'Array | Matrix, number': function (possibles, number) { + return _pickRandom(possibles, { + number + }); + }, + 'Array | Matrix, Array | Matrix': function (possibles, weights) { + return _pickRandom(possibles, { + weights + }); + }, + 'Array | Matrix, Array | Matrix, number': function (possibles, weights, number) { + return _pickRandom(possibles, { + number, + weights + }); + }, + 'Array | Matrix, number, Array | Matrix': function (possibles, number, weights) { + return _pickRandom(possibles, { + number, + weights + }); + } + }); + + /** + * @param {Array | Matrix} possibles + * @param {{ + * number?: number, + * weights?: Array | Matrix, + * elementWise: boolean + * }} options + * @returns {number | Array} + * @private + */ + function _pickRandom(possibles, _ref2) { + let { + number, + weights, + elementWise = true + } = _ref2; + const single = typeof number === 'undefined'; + if (single) { + number = 1; + } + const createMatrix = (0, _is.isMatrix)(possibles) ? possibles.create : (0, _is.isMatrix)(weights) ? weights.create : null; + possibles = possibles.valueOf(); // get Array + if (weights) { + weights = weights.valueOf(); // get Array + } + if (elementWise === true) { + possibles = (0, _array.flatten)(possibles); + weights = (0, _array.flatten)(weights); + } + let totalWeights = 0; + if (typeof weights !== 'undefined') { + if (weights.length !== possibles.length) { + throw new Error('Weights must have the same length as possibles'); + } + for (let i = 0, len = weights.length; i < len; i++) { + if (!(0, _is.isNumber)(weights[i]) || weights[i] < 0) { + throw new Error('Weights must be an array of positive numbers'); + } + totalWeights += weights[i]; + } + } + const length = possibles.length; + const result = []; + let pick; + while (result.length < number) { + if (typeof weights === 'undefined') { + pick = possibles[Math.floor(rng() * length)]; + } else { + let randKey = rng() * totalWeights; + for (let i = 0, len = possibles.length; i < len; i++) { + randKey -= weights[i]; + if (randKey < 0) { + pick = possibles[i]; + break; + } + } + } + result.push(pick); + } + return single ? result[0] : createMatrix ? createMatrix(result) : result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/random.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/random.js new file mode 100644 index 0000000..e1824a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/random.js @@ -0,0 +1,102 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRandomNumber = exports.createRandom = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +var _seededRNG = require("./util/seededRNG.js"); +var _randomMatrix2 = require("./util/randomMatrix.js"); +const name = 'random'; +const dependencies = ['typed', 'config', '?on']; +const createRandom = exports.createRandom = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + let rng = (0, _seededRNG.createRng)(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = (0, _seededRNG.createRng)(curr.randomSeed); + } + }); + } + + /** + * Return a random number larger or equal to `min` and smaller than `max` + * using a uniform distribution. + * + * Syntax: + * + * math.random() // generate a random number between 0 and 1 + * math.random(max) // generate a random number between 0 and max + * math.random(min, max) // generate a random number between min and max + * math.random(size) // generate a matrix with random numbers between 0 and 1 + * math.random(size, max) // generate a matrix with random numbers between 0 and max + * math.random(size, min, max) // generate a matrix with random numbers between min and max + * + * Examples: + * + * math.random() // returns a random number between 0 and 1 + * math.random(100) // returns a random number between 0 and 100 + * math.random(30, 40) // returns a random number between 30 and 40 + * math.random([2, 3]) // returns a 2x3 matrix with random numbers between 0 and 1 + * + * See also: + * + * randomInt, pickRandom + * + * @param {Array | Matrix} [size] If provided, an array or matrix with given + * size and filled with random values is returned + * @param {number} [min] Minimum boundary for the random value, included + * @param {number} [max] Maximum boundary for the random value, excluded + * @return {number | Array | Matrix} A random number + */ + return typed(name, { + '': () => _random(0, 1), + number: max => _random(0, max), + 'number, number': (min, max) => _random(min, max), + 'Array | Matrix': size => _randomMatrix(size, 0, 1), + 'Array | Matrix, number': (size, max) => _randomMatrix(size, 0, max), + 'Array | Matrix, number, number': (size, min, max) => _randomMatrix(size, min, max) + }); + function _randomMatrix(size, min, max) { + const res = (0, _randomMatrix2.randomMatrix)(size.valueOf(), () => _random(min, max)); + return (0, _is.isMatrix)(size) ? size.create(res, 'number') : res; + } + function _random(min, max) { + return min + rng() * (max - min); + } +}); + +// number only implementation of random, no matrix support +// TODO: there is quite some duplicate code in both createRandom and createRandomNumber, can we improve that? +const createRandomNumber = exports.createRandomNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', '?on'], _ref2 => { + let { + typed, + config, + on, + matrix + } = _ref2; + // seeded pseudo random number generator1 + let rng = (0, _seededRNG.createRng)(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = (0, _seededRNG.createRng)(curr.randomSeed); + } + }); + } + return typed(name, { + '': () => _random(0, 1), + number: max => _random(0, max), + 'number, number': (min, max) => _random(min, max) + }); + function _random(min, max) { + return min + rng() * (max - min); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/randomInt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/randomInt.js new file mode 100644 index 0000000..3bd8f3b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/randomInt.js @@ -0,0 +1,73 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRandomInt = void 0; +var _factory = require("../../utils/factory.js"); +var _randomMatrix = require("./util/randomMatrix.js"); +var _seededRNG = require("./util/seededRNG.js"); +var _is = require("../../utils/is.js"); +const name = 'randomInt'; +const dependencies = ['typed', 'config', '?on']; +const createRandomInt = exports.createRandomInt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + let rng = (0, _seededRNG.createRng)(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = (0, _seededRNG.createRng)(curr.randomSeed); + } + }); + } + + /** + * Return a random integer number larger or equal to `min` and smaller than `max` + * using a uniform distribution. + * + * Syntax: + * + * math.randomInt() // generate a random integer between 0 and 1 + * math.randomInt(max) // generate a random integer between 0 and max + * math.randomInt(min, max) // generate a random integer between min and max + * math.randomInt(size) // generate a matrix with random integer between 0 and 1 + * math.randomInt(size, max) // generate a matrix with random integer between 0 and max + * math.randomInt(size, min, max) // generate a matrix with random integer between min and max + * + * Examples: + * + * math.randomInt(100) // returns a random integer between 0 and 100 + * math.randomInt(30, 40) // returns a random integer between 30 and 40 + * math.randomInt([2, 3]) // returns a 2x3 matrix with random integers between 0 and 1 + * + * See also: + * + * random, pickRandom + * + * @param {Array | Matrix} [size] If provided, an array or matrix with given + * size and filled with random values is returned + * @param {number} [min] Minimum boundary for the random value, included + * @param {number} [max] Maximum boundary for the random value, excluded + * @return {number | Array | Matrix} A random integer value + */ + return typed(name, { + '': () => _randomInt(0, 1), + number: max => _randomInt(0, max), + 'number, number': (min, max) => _randomInt(min, max), + 'Array | Matrix': size => _randomIntMatrix(size, 0, 1), + 'Array | Matrix, number': (size, max) => _randomIntMatrix(size, 0, max), + 'Array | Matrix, number, number': (size, min, max) => _randomIntMatrix(size, min, max) + }); + function _randomIntMatrix(size, min, max) { + const res = (0, _randomMatrix.randomMatrix)(size.valueOf(), () => _randomInt(min, max)); + return (0, _is.isMatrix)(size) ? size.create(res, 'number') : res; + } + function _randomInt(min, max) { + return Math.floor(min + rng() * (max - min)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/randomMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/randomMatrix.js new file mode 100644 index 0000000..76ee766 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/randomMatrix.js @@ -0,0 +1,26 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.randomMatrix = randomMatrix; +/** + * This is a util function for generating a random matrix recursively. + * @param {number[]} size + * @param {function} random + * @returns {Array} + */ +function randomMatrix(size, random) { + const data = []; + size = size.slice(0); + if (size.length > 1) { + for (let i = 0, length = size.shift(); i < length; i++) { + data.push(randomMatrix(size, random)); + } + } else { + for (let i = 0, length = size.shift(); i < length; i++) { + data.push(random()); + } + } + return data; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/seededRNG.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/seededRNG.js new file mode 100644 index 0000000..2d6889d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/probability/util/seededRNG.js @@ -0,0 +1,26 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRng = createRng; +var _seedrandom = _interopRequireDefault(require("seedrandom")); +const singletonRandom = /* #__PURE__ */(0, _seedrandom.default)(Date.now()); +function createRng(randomSeed) { + let random; + + // create a new random generator with given seed + function setSeed(seed) { + random = seed === null ? singletonRandom : (0, _seedrandom.default)(String(seed)); + } + + // initialize a seeded pseudo random number generator with config's random seed + setSeed(randomSeed); + + // wrapper function so the rng can be updated via generator + function rng() { + return random(); + } + return rng; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compare.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compare.js new file mode 100644 index 0000000..4aa2284 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compare.js @@ -0,0 +1,120 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCompareNumber = exports.createCompare = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matAlgo05xSfSf = require("../../type/matrix/utils/matAlgo05xSfSf.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'compare'; +const dependencies = ['typed', 'config', 'matrix', 'equalScalar', 'BigNumber', 'Fraction', 'DenseMatrix', 'concat']; +const createCompare = exports.createCompare = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + equalScalar, + matrix, + BigNumber, + Fraction, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo05xSfSf = (0, _matAlgo05xSfSf.createMatAlgo05xSfSf)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y. + * + * x and y are considered equal when the relative difference between x and y + * is smaller than the configured absTol and relTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.compare(x, y) + * + * Examples: + * + * math.compare(6, 1) // returns 1 + * math.compare(2, 3) // returns -1 + * math.compare(7, 7) // returns 0 + * math.compare('10', '2') // returns 1 + * math.compare('1000', '1e3') // returns 0 + * + * const a = math.unit('5 cm') + * const b = math.unit('40 mm') + * math.compare(a, b) // returns 1 + * + * math.compare(2, [1, 2, 3]) // returns [1, 0, -1] + * + * See also: + * + * equal, unequal, smaller, smallerEq, larger, largerEq, compareNatural, compareText + * + * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} y Second value to compare + * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, createCompareNumber({ + typed, + config + }), { + 'boolean, boolean': function (x, y) { + return x === y ? 0 : x > y ? 1 : -1; + }, + 'BigNumber, BigNumber': function (x, y) { + return (0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol) ? new BigNumber(0) : new BigNumber(x.cmp(y)); + }, + 'bigint, bigint': function (x, y) { + return x === y ? 0n : x > y ? 1n : -1n; + }, + 'Fraction, Fraction': function (x, y) { + return new Fraction(x.compare(y)); + }, + 'Complex, Complex': function () { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createCompareNumber = exports.createCompareNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return (0, _number.nearlyEqual)(x, y, config.relTol, config.absTol) ? 0 : x > y ? 1 : -1; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareNatural.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareNatural.js new file mode 100644 index 0000000..f85ca13 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareNatural.js @@ -0,0 +1,281 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCompareNatural = void 0; +var _javascriptNaturalSort = _interopRequireDefault(require("javascript-natural-sort")); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'compareNatural'; +const dependencies = ['typed', 'compare']; +const createCompareNatural = exports.createCompareNatural = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + compare + } = _ref; + const compareBooleans = compare.signatures['boolean,boolean']; + + /** + * Compare two values of any type in a deterministic, natural way. + * + * For numeric values, the function works the same as `math.compare`. + * For types of values that can't be compared mathematically, + * the function compares in a natural way. + * + * For numeric values, x and y are considered equal when the relative + * difference between x and y is smaller than the configured relTol and absTol. + * The function cannot be used to compare values smaller than + * approximately 2.22e-16. + * + * For Complex numbers, first the real parts are compared. If equal, + * the imaginary parts are compared. + * + * Strings are compared with a natural sorting algorithm, which + * orders strings in a "logic" way following some heuristics. + * This differs from the function `compare`, which converts the string + * into a numeric value and compares that. The function `compareText` + * on the other hand compares text lexically. + * + * Arrays and Matrices are compared value by value until there is an + * unequal pair of values encountered. Objects are compared by sorted + * keys until the keys or their values are unequal. + * + * Syntax: + * + * math.compareNatural(x, y) + * + * Examples: + * + * math.compareNatural(6, 1) // returns 1 + * math.compareNatural(2, 3) // returns -1 + * math.compareNatural(7, 7) // returns 0 + * + * math.compareNatural('10', '2') // returns 1 + * math.compareText('10', '2') // returns -1 + * math.compare('10', '2') // returns 1 + * + * math.compareNatural('Answer: 10', 'Answer: 2') // returns 1 + * math.compareText('Answer: 10', 'Answer: 2') // returns -1 + * math.compare('Answer: 10', 'Answer: 2') + * // Error: Cannot convert "Answer: 10" to a number + * + * const a = math.unit('5 cm') + * const b = math.unit('40 mm') + * math.compareNatural(a, b) // returns 1 + * + * const c = math.complex('2 + 3i') + * const d = math.complex('2 + 4i') + * math.compareNatural(c, d) // returns -1 + * + * math.compareNatural([1, 2, 4], [1, 2, 3]) // returns 1 + * math.compareNatural([1, 2, 3], [1, 2]) // returns 1 + * math.compareNatural([1, 5], [1, 2, 3]) // returns 1 + * math.compareNatural([1, 2], [1, 2]) // returns 0 + * + * math.compareNatural({a: 2}, {a: 4}) // returns -1 + * + * See also: + * + * compare, compareText + * + * @param {*} x First value to compare + * @param {*} y Second value to compare + * @return {number} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, { + 'any, any': _compareNatural + }); // just to check # args + + function _compareNatural(x, y) { + const typeX = (0, _is.typeOf)(x); + const typeY = (0, _is.typeOf)(y); + let c; + + // numeric types + if ((typeX === 'number' || typeX === 'BigNumber' || typeX === 'Fraction') && (typeY === 'number' || typeY === 'BigNumber' || typeY === 'Fraction')) { + c = compare(x, y); + if (c.toString() !== '0') { + // c can be number, BigNumber, or Fraction + return c > 0 ? 1 : -1; // return a number + } else { + return (0, _javascriptNaturalSort.default)(typeX, typeY); + } + } + + // matrix types + const matTypes = ['Array', 'DenseMatrix', 'SparseMatrix']; + if (matTypes.includes(typeX) || matTypes.includes(typeY)) { + c = compareMatricesAndArrays(_compareNatural, x, y); + if (c !== 0) { + return c; + } else { + return (0, _javascriptNaturalSort.default)(typeX, typeY); + } + } + + // in case of different types, order by name of type, i.e. 'BigNumber' < 'Complex' + if (typeX !== typeY) { + return (0, _javascriptNaturalSort.default)(typeX, typeY); + } + if (typeX === 'Complex') { + return compareComplexNumbers(x, y); + } + if (typeX === 'Unit') { + if (x.equalBase(y)) { + return _compareNatural(x.value, y.value); + } + + // compare by units + return compareArrays(_compareNatural, x.formatUnits(), y.formatUnits()); + } + if (typeX === 'boolean') { + return compareBooleans(x, y); + } + if (typeX === 'string') { + return (0, _javascriptNaturalSort.default)(x, y); + } + if (typeX === 'Object') { + return compareObjects(_compareNatural, x, y); + } + if (typeX === 'null') { + return 0; + } + if (typeX === 'undefined') { + return 0; + } + + // this should not occur... + throw new TypeError('Unsupported type of value "' + typeX + '"'); + } + + /** + * Compare mixed matrix/array types, by converting to same-shaped array. + * This comparator is non-deterministic regarding input types. + * @param {Array | SparseMatrix | DenseMatrix | *} x + * @param {Array | SparseMatrix | DenseMatrix | *} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareMatricesAndArrays(compareNatural, x, y) { + if ((0, _is.isSparseMatrix)(x) && (0, _is.isSparseMatrix)(y)) { + return compareArrays(compareNatural, x.toJSON().values, y.toJSON().values); + } + if ((0, _is.isSparseMatrix)(x)) { + // note: convert to array is expensive + return compareMatricesAndArrays(compareNatural, x.toArray(), y); + } + if ((0, _is.isSparseMatrix)(y)) { + // note: convert to array is expensive + return compareMatricesAndArrays(compareNatural, x, y.toArray()); + } + + // convert DenseArray into Array + if ((0, _is.isDenseMatrix)(x)) { + return compareMatricesAndArrays(compareNatural, x.toJSON().data, y); + } + if ((0, _is.isDenseMatrix)(y)) { + return compareMatricesAndArrays(compareNatural, x, y.toJSON().data); + } + + // convert scalars to array + if (!Array.isArray(x)) { + return compareMatricesAndArrays(compareNatural, [x], y); + } + if (!Array.isArray(y)) { + return compareMatricesAndArrays(compareNatural, x, [y]); + } + return compareArrays(compareNatural, x, y); + } + + /** + * Compare two Arrays + * + * - First, compares value by value + * - Next, if all corresponding values are equal, + * look at the length: longest array will be considered largest + * + * @param {Array} x + * @param {Array} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareArrays(compareNatural, x, y) { + // compare each value + for (let i = 0, ii = Math.min(x.length, y.length); i < ii; i++) { + const v = compareNatural(x[i], y[i]); + if (v !== 0) { + return v; + } + } + + // compare the size of the arrays + if (x.length > y.length) { + return 1; + } + if (x.length < y.length) { + return -1; + } + + // both Arrays have equal size and content + return 0; + } + + /** + * Compare two objects + * + * - First, compare sorted property names + * - Next, compare the property values + * + * @param {Object} x + * @param {Object} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareObjects(compareNatural, x, y) { + const keysX = Object.keys(x); + const keysY = Object.keys(y); + + // compare keys + keysX.sort(_javascriptNaturalSort.default); + keysY.sort(_javascriptNaturalSort.default); + const c = compareArrays(compareNatural, keysX, keysY); + if (c !== 0) { + return c; + } + + // compare values + for (let i = 0; i < keysX.length; i++) { + const v = compareNatural(x[keysX[i]], y[keysY[i]]); + if (v !== 0) { + return v; + } + } + return 0; + } +}); + +/** + * Compare two complex numbers, `x` and `y`: + * + * - First, compare the real values of `x` and `y` + * - If equal, compare the imaginary values of `x` and `y` + * + * @params {Complex} x + * @params {Complex} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ +function compareComplexNumbers(x, y) { + if (x.re > y.re) { + return 1; + } + if (x.re < y.re) { + return -1; + } + if (x.im > y.im) { + return 1; + } + if (x.im < y.im) { + return -1; + } + return 0; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareText.js new file mode 100644 index 0000000..588df7e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareText.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCompareTextNumber = exports.createCompareText = void 0; +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'compareText'; +const dependencies = ['typed', 'matrix', 'concat']; +_string.compareText.signature = 'any, any'; +const createCompareText = exports.createCompareText = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + concat + } = _ref; + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Compare two strings lexically. Comparison is case sensitive. + * Returns 1 when x > y, -1 when x < y, and 0 when x == y. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.compareText(x, y) + * + * Examples: + * + * math.compareText('B', 'A') // returns 1 + * math.compareText('2', '10') // returns 1 + * math.compare('2', '10') // returns -1 + * math.compareNatural('2', '10') // returns -1 + * + * math.compareText('B', ['A', 'B', 'C']) // returns [1, 0, -1] + * + * See also: + * + * equal, equalText, compare, compareNatural + * + * @param {string | Array | DenseMatrix} x First string to compare + * @param {string | Array | DenseMatrix} y Second string to compare + * @return {number | Array | DenseMatrix} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, _string.compareText, matrixAlgorithmSuite({ + elop: _string.compareText, + Ds: true + })); +}); +const createCompareTextNumber = exports.createCompareTextNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed'], _ref2 => { + let { + typed + } = _ref2; + return typed(name, _string.compareText); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareUnits.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareUnits.js new file mode 100644 index 0000000..e9d8d57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/compareUnits.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCompareUnits = void 0; +var _factory = require("../../utils/factory.js"); +const createCompareUnits = exports.createCompareUnits = /* #__PURE__ */(0, _factory.factory)('compareUnits', ['typed'], _ref => { + let { + typed + } = _ref; + return { + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (!x.equalBase(y)) { + throw new Error('Cannot compare units with different base'); + } + return typed.find(self, [x.valueType(), y.valueType()])(x.value, y.value); + }) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/deepEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/deepEqual.js new file mode 100644 index 0000000..2fbdc0d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/deepEqual.js @@ -0,0 +1,80 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDeepEqual = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'deepEqual'; +const dependencies = ['typed', 'equal']; +const createDeepEqual = exports.createDeepEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equal + } = _ref; + /** + * Test element wise whether two matrices are equal. + * The function accepts both matrices and scalar values. + * + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.deepEqual(x, y) + * + * Examples: + * + * math.deepEqual(2, 4) // returns false + * + * a = [2, 5, 1] + * b = [2, 7, 1] + * + * math.deepEqual(a, b) // returns false + * math.equal(a, b) // returns [true, false, true] + * + * See also: + * + * equal, unequal + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First matrix to compare + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second matrix to compare + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} + * Returns true when the input matrices have the same size and each of their elements is equal. + */ + return typed(name, { + 'any, any': function (x, y) { + return _deepEqual(x.valueOf(), y.valueOf()); + } + }); + + /** + * Test whether two arrays have the same size and all elements are equal + * @param {Array | *} x + * @param {Array | *} y + * @return {boolean} Returns true if both arrays are deep equal + */ + function _deepEqual(x, y) { + if (Array.isArray(x)) { + if (Array.isArray(y)) { + const len = x.length; + if (len !== y.length) { + return false; + } + for (let i = 0; i < len; i++) { + if (!_deepEqual(x[i], y[i])) { + return false; + } + } + return true; + } else { + return false; + } + } else { + if (Array.isArray(y)) { + return false; + } else { + return equal(x, y); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equal.js new file mode 100644 index 0000000..e4e64b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equal.js @@ -0,0 +1,116 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createEqualNumber = exports.createEqual = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'equal'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +const createEqual = exports.createEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Test whether two values are equal. + * + * The function tests whether the relative difference between x and y is + * smaller than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * In case of complex numbers, x.re must equal y.re, and x.im must equal y.im. + * + * Values `null` and `undefined` are compared strictly, thus `null` is only + * equal to `null` and nothing else, and `undefined` is only equal to + * `undefined` and nothing else. Strings are compared by their numerical value. + * + * Syntax: + * + * math.equal(x, y) + * + * Examples: + * + * math.equal(2 + 2, 3) // returns false + * math.equal(2 + 2, 4) // returns true + * + * const a = math.unit('50 cm') + * const b = math.unit('5 m') + * math.equal(a, b) // returns true + * + * const c = [2, 5, 1] + * const d = [2, 7, 1] + * + * math.equal(c, d) // returns [true, false, true] + * math.deepEqual(c, d) // returns false + * + * math.equal("1000", "1e3") // returns true + * math.equal(0, null) // returns false + * + * See also: + * + * unequal, smaller, smallerEq, larger, largerEq, compare, deepEqual, equalText + * + * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the compared values are equal, else returns false + */ + return typed(name, createEqualNumber({ + typed, + equalScalar + }), matrixAlgorithmSuite({ + elop: equalScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createEqualNumber = exports.createEqualNumber = (0, _factory.factory)(name, ['typed', 'equalScalar'], _ref2 => { + let { + typed, + equalScalar + } = _ref2; + return typed(name, { + 'any, any': function (x, y) { + // strict equality for null and undefined? + if (x === null) { + return y === null; + } + if (y === null) { + return x === null; + } + if (x === undefined) { + return y === undefined; + } + if (y === undefined) { + return x === undefined; + } + return equalScalar(x, y); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalScalar.js new file mode 100644 index 0000000..134f0ee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalScalar.js @@ -0,0 +1,62 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createEqualScalarNumber = exports.createEqualScalar = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _complex = require("../../utils/complex.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'equalScalar'; +const dependencies = ['typed', 'config']; +const createEqualScalar = exports.createEqualScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config + } = _ref; + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Test whether two scalar values are nearly equal. + * + * @param {number | BigNumber | bigint | Fraction | boolean | Complex | Unit} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Complex} y Second value to compare + * @return {boolean} Returns true when the compared values are equal, else returns false + * @private + */ + return typed(name, { + 'boolean, boolean': function (x, y) { + return x === y; + }, + 'number, number': function (x, y) { + return (0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'BigNumber, BigNumber': function (x, y) { + return x.eq(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': function (x, y) { + return x === y; + }, + 'Fraction, Fraction': function (x, y) { + return x.equals(y); + }, + 'Complex, Complex': function (x, y) { + return (0, _complex.complexEquals)(x, y, config.relTol, config.absTol); + } + }, compareUnits); +}); +const createEqualScalarNumber = exports.createEqualScalarNumber = (0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return (0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalText.js new file mode 100644 index 0000000..c7a65d8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/equalText.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createEqualText = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'equalText'; +const dependencies = ['typed', 'compareText', 'isZero']; +const createEqualText = exports.createEqualText = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + compareText, + isZero + } = _ref; + /** + * Check equality of two strings. Comparison is case sensitive. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.equalText(x, y) + * + * Examples: + * + * math.equalText('Hello', 'Hello') // returns true + * math.equalText('a', 'A') // returns false + * math.equal('2e3', '2000') // returns true + * math.equalText('2e3', '2000') // returns false + * + * math.equalText('B', ['A', 'B', 'C']) // returns [false, true, false] + * + * See also: + * + * equal, compareText, compare, compareNatural + * + * @param {string | Array | DenseMatrix} x First string to compare + * @param {string | Array | DenseMatrix} y Second string to compare + * @return {number | Array | DenseMatrix} Returns true if the values are equal, and false if not. + */ + return typed(name, { + 'any, any': function (x, y) { + return isZero(compareText(x, y)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/larger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/larger.js new file mode 100644 index 0000000..c96baaf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/larger.js @@ -0,0 +1,105 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLargerNumber = exports.createLarger = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'larger'; +const dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +const createLarger = exports.createLarger = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Test whether value x is larger than y. + * + * The function returns true when x is larger than y and the relative + * difference between x and y is larger than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.larger(x, y) + * + * Examples: + * + * math.larger(2, 3) // returns false + * math.larger(5, 2 + 2) // returns true + * + * const a = math.unit('5 cm') + * const b = math.unit('2 inch') + * math.larger(a, b) // returns false + * + * See also: + * + * equal, unequal, smaller, smallerEq, largerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is larger than y, else returns false + */ + return typed(name, createLargerNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x > y, + 'BigNumber, BigNumber': function (x, y) { + return x.gt(y) && !(0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x > y, + 'Fraction, Fraction': (x, y) => x.compare(y) === 1, + 'Complex, Complex': function () { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createLargerNumber = exports.createLargerNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return x > y && !(0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/largerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/largerEq.js new file mode 100644 index 0000000..9f4cd47 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/largerEq.js @@ -0,0 +1,103 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createLargerEqNumber = exports.createLargerEq = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'largerEq'; +const dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +const createLargerEq = exports.createLargerEq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Test whether value x is larger or equal to y. + * + * The function returns true when x is larger than y or the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.largerEq(x, y) + * + * Examples: + * + * math.larger(2, 1 + 1) // returns false + * math.largerEq(2, 1 + 1) // returns true + * + * See also: + * + * equal, unequal, smaller, smallerEq, larger, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is larger or equal to y, else returns false + */ + return typed(name, createLargerEqNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x >= y, + 'BigNumber, BigNumber': function (x, y) { + return x.gte(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': function (x, y) { + return x >= y; + }, + 'Fraction, Fraction': (x, y) => x.compare(y) !== -1, + 'Complex, Complex': function () { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createLargerEqNumber = exports.createLargerEqNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return x >= y || (0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smaller.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smaller.js new file mode 100644 index 0000000..a9f7cfd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smaller.js @@ -0,0 +1,105 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSmallerNumber = exports.createSmaller = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'smaller'; +const dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +const createSmaller = exports.createSmaller = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Test whether value x is smaller than y. + * + * The function returns true when x is smaller than y and the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.smaller(x, y) + * + * Examples: + * + * math.smaller(2, 3) // returns true + * math.smaller(5, 2 * 2) // returns false + * + * const a = math.unit('5 cm') + * const b = math.unit('2 inch') + * math.smaller(a, b) // returns true + * + * See also: + * + * equal, unequal, smallerEq, smaller, smallerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false + */ + return typed(name, createSmallerNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x < y, + 'BigNumber, BigNumber': function (x, y) { + return x.lt(y) && !(0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x < y, + 'Fraction, Fraction': (x, y) => x.compare(y) === -1, + 'Complex, Complex': function (x, y) { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createSmallerNumber = exports.createSmallerNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return x < y && !(0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smallerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smallerEq.js new file mode 100644 index 0000000..e32ab5f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/smallerEq.js @@ -0,0 +1,101 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSmallerEqNumber = exports.createSmallerEq = void 0; +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +var _compareUnits = require("./compareUnits.js"); +const name = 'smallerEq'; +const dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +const createSmallerEq = exports.createSmallerEq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + const compareUnits = (0, _compareUnits.createCompareUnits)({ + typed + }); + + /** + * Test whether value x is smaller or equal to y. + * + * The function returns true when x is smaller than y or the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.smallerEq(x, y) + * + * Examples: + * + * math.smaller(1 + 2, 3) // returns false + * math.smallerEq(1 + 2, 3) // returns true + * + * See also: + * + * equal, unequal, smaller, larger, largerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false + */ + return typed(name, createSmallerEqNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x <= y, + 'BigNumber, BigNumber': function (x, y) { + return x.lte(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x <= y, + 'Fraction, Fraction': (x, y) => x.compare(y) !== 1, + 'Complex, Complex': function () { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +const createSmallerEqNumber = exports.createSmallerEqNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], _ref2 => { + let { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function (x, y) { + return x <= y || (0, _number.nearlyEqual)(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/unequal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/unequal.js new file mode 100644 index 0000000..b2842b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/relational/unequal.js @@ -0,0 +1,119 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnequalNumber = exports.createUnequal = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo07xSSf = require("../../type/matrix/utils/matAlgo07xSSf.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'unequal'; +const dependencies = ['typed', 'config', 'equalScalar', 'matrix', 'DenseMatrix', 'concat']; +const createUnequal = exports.createUnequal = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + equalScalar, + matrix, + DenseMatrix, + concat + } = _ref; + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo07xSSf = (0, _matAlgo07xSSf.createMatAlgo07xSSf)({ + typed, + DenseMatrix + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Test whether two values are unequal. + * + * The function tests whether the relative difference between x and y is + * larger than the configured relTol and absTol. The function cannot be used to compare + * values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * In case of complex numbers, x.re must unequal y.re, or x.im must unequal y.im. + * Strings are compared by their numerical value. + * + * Values `null` and `undefined` are compared strictly, thus `null` is unequal + * with everything except `null`, and `undefined` is unequal with everything + * except `undefined`. + * + * Syntax: + * + * math.unequal(x, y) + * + * Examples: + * + * math.unequal(2 + 2, 3) // returns true + * math.unequal(2 + 2, 4) // returns false + * + * const a = math.unit('50 cm') + * const b = math.unit('5 m') + * math.unequal(a, b) // returns false + * + * const c = [2, 5, 1] + * const d = [2, 7, 1] + * + * math.unequal(c, d) // returns [false, true, false] + * math.deepEqual(c, d) // returns false + * + * math.unequal(0, null) // returns true + * See also: + * + * equal, deepEqual, smaller, smallerEq, larger, largerEq, compare + * + * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} x First value to compare + * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the compared values are unequal, else returns false + */ + return typed(name, createUnequalNumber({ + typed, + equalScalar + }), matrixAlgorithmSuite({ + elop: _unequal, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); + function _unequal(x, y) { + return !equalScalar(x, y); + } +}); +const createUnequalNumber = exports.createUnequalNumber = (0, _factory.factory)(name, ['typed', 'equalScalar'], _ref2 => { + let { + typed, + equalScalar + } = _ref2; + return typed(name, { + 'any, any': function (x, y) { + // strict equality for null and undefined? + if (x === null) { + return y !== null; + } + if (y === null) { + return x !== null; + } + if (x === undefined) { + return y !== undefined; + } + if (y === undefined) { + return x !== undefined; + } + return !equalScalar(x, y); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setCartesian.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setCartesian.js new file mode 100644 index 0000000..665cfb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setCartesian.js @@ -0,0 +1,64 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetCartesian = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setCartesian'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +const createSetCartesian = exports.createSetCartesian = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the cartesian product of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays + * and the values will be sorted in ascending order before the operation. + * + * Syntax: + * + * math.setCartesian(set1, set2) + * + * Examples: + * + * math.setCartesian([1, 2], [3, 4]) // returns [[1, 3], [1, 4], [2, 3], [2, 4]] + * math.setCartesian([4, 3], [2, 1]) // returns [[3, 1], [3, 2], [4, 1], [4, 2]] + * + * See also: + * + * setUnion, setIntersect, setDifference, setPowerset + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The cartesian product of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + let result = []; + if (subset(size(a1), new Index(0)) !== 0 && subset(size(a2), new Index(0)) !== 0) { + // if any of them is empty, return empty + const b1 = (0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural); + const b2 = (0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural); + result = []; + for (let i = 0; i < b1.length; i++) { + for (let j = 0; j < b2.length; j++) { + result.push([b1[i], b2[j]]); + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return result; + } + // return a matrix otherwise + return new DenseMatrix(result); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDifference.js new file mode 100644 index 0000000..e6c609b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDifference.js @@ -0,0 +1,77 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetDifference = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setDifference'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +const createSetDifference = exports.createSetDifference = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the difference of two (multi)sets: every element of set1, that is not the element of set2. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setDifference(set1, set2) + * + * Examples: + * + * math.setDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2] + * math.setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2] + * + * See also: + * + * setUnion, setIntersect, setSymDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The difference of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + let result; + if (subset(size(a1), new Index(0)) === 0) { + // empty-anything=empty + result = []; + } else if (subset(size(a2), new Index(0)) === 0) { + // anything-empty=anything + return (0, _array.flatten)(a1.toArray()); + } else { + const b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + const b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + result = []; + let inb2; + for (let i = 0; i < b1.length; i++) { + inb2 = false; + for (let j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + inb2 = true; + break; + } + } + if (!inb2) { + result.push(b1[i]); + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return (0, _array.generalize)(result); + } + // return a matrix otherwise + return new DenseMatrix((0, _array.generalize)(result)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDistinct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDistinct.js new file mode 100644 index 0000000..4a90e86 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setDistinct.js @@ -0,0 +1,63 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetDistinct = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setDistinct'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +const createSetDistinct = exports.createSetDistinct = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Collect the distinct elements of a multiset. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setDistinct(set) + * + * Examples: + * + * math.setDistinct([1, 1, 1, 2, 2, 3]) // returns [1, 2, 3] + * + * See also: + * + * setMultiplicity + * + * @param {Array | Matrix} a A multiset + * @return {Array | Matrix} A set containing the distinc elements of the multiset + */ + return typed(name, { + 'Array | Matrix': function (a) { + let result; + if (subset(size(a), new Index(0)) === 0) { + // if empty, return empty + result = []; + } else { + const b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + result = []; + result.push(b[0]); + for (let i = 1; i < b.length; i++) { + if (compareNatural(b[i], b[i - 1]) !== 0) { + result.push(b[i]); + } + } + } + // return an array, if the input was an array + if (Array.isArray(a)) { + return result; + } + // return a matrix otherwise + return new DenseMatrix(result); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIntersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIntersect.js new file mode 100644 index 0000000..d85c5ab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIntersect.js @@ -0,0 +1,69 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetIntersect = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setIntersect'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +const createSetIntersect = exports.createSetIntersect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the intersection of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setIntersect(set1, set2) + * + * Examples: + * + * math.setIntersect([1, 2, 3, 4], [3, 4, 5, 6]) // returns [3, 4] + * math.setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [3, 4] + * + * See also: + * + * setUnion, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The intersection of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + let result; + if (subset(size(a1), new Index(0)) === 0 || subset(size(a2), new Index(0)) === 0) { + // of any of them is empty, return empty + result = []; + } else { + const b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + const b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + result = []; + for (let i = 0; i < b1.length; i++) { + for (let j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + result.push(b1[i]); + break; + } + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return (0, _array.generalize)(result); + } + // return a matrix otherwise + return new DenseMatrix((0, _array.generalize)(result)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIsSubset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIsSubset.js new file mode 100644 index 0000000..b5f9a78 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setIsSubset.js @@ -0,0 +1,68 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetIsSubset = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setIsSubset'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +const createSetIsSubset = exports.createSetIsSubset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Check whether a (multi)set is a subset of another (multi)set. (Every element of set1 is the element of set2.) + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setIsSubset(set1, set2) + * + * Examples: + * + * math.setIsSubset([1, 2], [3, 4, 5, 6]) // returns false + * math.setIsSubset([3, 4], [3, 4, 5, 6]) // returns true + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {boolean} Returns true when a1 is a subset of a2, returns false otherwise + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // empty is a subset of anything + return true; + } else if (subset(size(a2), new Index(0)) === 0) { + // anything is not a subset of empty + return false; + } + const b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + const b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + let inb2; + for (let i = 0; i < b1.length; i++) { + inb2 = false; + for (let j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + inb2 = true; + break; + } + } + if (inb2 === false) { + return false; + } + } + return true; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setMultiplicity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setMultiplicity.js new file mode 100644 index 0000000..34cb1b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setMultiplicity.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetMultiplicity = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setMultiplicity'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +const createSetMultiplicity = exports.createSetMultiplicity = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Count the multiplicity of an element in a multiset. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setMultiplicity(element, set) + * + * Examples: + * + * math.setMultiplicity(1, [1, 2, 2, 4]) // returns 1 + * math.setMultiplicity(2, [1, 2, 2, 4]) // returns 2 + * + * See also: + * + * setDistinct, setSize + * + * @param {number | BigNumber | Fraction | Complex} e An element in the multiset + * @param {Array | Matrix} a A multiset + * @return {number} The number of how many times the multiset contains the element + */ + return typed(name, { + 'number | BigNumber | Fraction | Complex, Array | Matrix': function (e, a) { + if (subset(size(a), new Index(0)) === 0) { + // if empty, return 0 + return 0; + } + const b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()); + let count = 0; + for (let i = 0; i < b.length; i++) { + if (compareNatural(b[i], e) === 0) { + count++; + } + } + return count; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setPowerset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setPowerset.js new file mode 100644 index 0000000..9edb068 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setPowerset.js @@ -0,0 +1,81 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetPowerset = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setPowerset'; +const dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +const createSetPowerset = exports.createSetPowerset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Create the powerset of a (multi)set. (The powerset contains very possible subsets of a (multi)set.) + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setPowerset(set) + * + * Examples: + * + * math.setPowerset([1, 2, 3]) // returns [[], [1], [2], [3], [1, 2], [1, 3], [2, 3], [1, 2, 3]] + * + * See also: + * + * setCartesian + * + * @param {Array | Matrix} a A (multi)set + * @return {Array} The powerset of the (multi)set + */ + return typed(name, { + 'Array | Matrix': function (a) { + if (subset(size(a), new Index(0)) === 0) { + // if empty, return empty + return []; + } + const b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + const result = []; + let number = 0; + while (number.toString(2).length <= b.length) { + result.push(_subset(b, number.toString(2).split('').reverse())); + number++; + } + // can not return a matrix, because of the different size of the subarrays + return _sort(result); + } + }); + + // create subset + function _subset(array, bitarray) { + const result = []; + for (let i = 0; i < bitarray.length; i++) { + if (bitarray[i] === '1') { + result.push(array[i]); + } + } + return result; + } + + // sort subsests by length + function _sort(array) { + let temp = []; + for (let i = array.length - 1; i > 0; i--) { + for (let j = 0; j < i; j++) { + if (array[j].length > array[j + 1].length) { + temp = array[j]; + array[j] = array[j + 1]; + array[j + 1] = temp; + } + } + } + return array; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSize.js new file mode 100644 index 0000000..a650f69 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSize.js @@ -0,0 +1,57 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetSize = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setSize'; +const dependencies = ['typed', 'compareNatural']; +const createSetSize = exports.createSetSize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + compareNatural + } = _ref; + /** + * Count the number of elements of a (multi)set. When a second parameter is 'true', count only the unique values. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setSize(set) + * math.setSize(set, unique) + * + * Examples: + * + * math.setSize([1, 2, 2, 4]) // returns 4 + * math.setSize([1, 2, 2, 4], true) // returns 3 + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a A multiset + * @param {boolean} [unique] If true, only the unique values are counted. False by default + * @return {number} The number of elements of the (multi)set + */ + return typed(name, { + 'Array | Matrix': function (a) { + return Array.isArray(a) ? (0, _array.flatten)(a).length : (0, _array.flatten)(a.toArray()).length; + }, + 'Array | Matrix, boolean': function (a, unique) { + if (unique === false || a.length === 0) { + return Array.isArray(a) ? (0, _array.flatten)(a).length : (0, _array.flatten)(a.toArray()).length; + } else { + const b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + let count = 1; + for (let i = 1; i < b.length; i++) { + if (compareNatural(b[i], b[i - 1]) !== 0) { + count++; + } + } + return count; + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSymDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSymDifference.js new file mode 100644 index 0000000..5f2e994 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setSymDifference.js @@ -0,0 +1,54 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetSymDifference = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setSymDifference'; +const dependencies = ['typed', 'size', 'concat', 'subset', 'setDifference', 'Index']; +const createSetSymDifference = exports.createSetSymDifference = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + concat, + subset, + setDifference, + Index + } = _ref; + /** + * Create the symmetric difference of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setSymDifference(set1, set2) + * + * Examples: + * + * math.setSymDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 5, 6] + * math.setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 5, 6] + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The symmetric difference of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // if any of them is empty, return the other one + return (0, _array.flatten)(a2); + } else if (subset(size(a2), new Index(0)) === 0) { + return (0, _array.flatten)(a1); + } + const b1 = (0, _array.flatten)(a1); + const b2 = (0, _array.flatten)(a2); + return concat(setDifference(b1, b2), setDifference(b2, b1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setUnion.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setUnion.js new file mode 100644 index 0000000..e573f57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/set/setUnion.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSetUnion = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'setUnion'; +const dependencies = ['typed', 'size', 'concat', 'subset', 'setIntersect', 'setSymDifference', 'Index']; +const createSetUnion = exports.createSetUnion = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + size, + concat, + subset, + setIntersect, + setSymDifference, + Index + } = _ref; + /** + * Create the union of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setUnion(set1, set2) + * + * Examples: + * + * math.setUnion([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 3, 4, 5, 6] + * math.setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 3, 4, 5, 6] + * + * See also: + * + * setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The union of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function (a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // if any of them is empty, return the other one + return (0, _array.flatten)(a2); + } else if (subset(size(a2), new Index(0)) === 0) { + return (0, _array.flatten)(a1); + } + const b1 = (0, _array.flatten)(a1); + const b2 = (0, _array.flatten)(a2); + return concat(setSymDifference(b1, b2), setIntersect(b1, b2)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/freqz.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/freqz.js new file mode 100644 index 0000000..ac8412b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/freqz.js @@ -0,0 +1,121 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFreqz = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'freqz'; +const dependencies = ['typed', 'add', 'multiply', 'Complex', 'divide', 'matrix']; +const createFreqz = exports.createFreqz = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + multiply, + Complex, + divide, + matrix + } = _ref; + /** + * Calculates the frequency response of a filter given its numerator and denominator coefficients. + * + * Syntax: + * math.freqz(b, a) + * math.freqz(b, a, w) + * + * Examples: + * math.freqz([1, 2], [1, 2, 3], 4) // returns { h: [0.5 + 0i, 0.4768589245763655 + 0.2861153547458193i, 0.25000000000000006 + 0.75i, -0.770976571635189 + 0.4625859429811135i], w: [0, 0.7853981633974483, 1.5707963267948966, 2.356194490192345 ] } + * math.freqz([1, 2], [1, 2, 3], [0, 1]) // returns { h: [0.5 + 0i, 0.45436781 + 0.38598051i], w: [0, 1] } + * + * See also: + * zpk2tf + * + * @param {Array.} b The numerator coefficients of the filter. + * @param {Array.} a The denominator coefficients of the filter. + * @param {Array.} [w] A vector of frequencies (in radians/sample) at which the frequency response is to be computed or the number of points to compute (if a number is not provided, the default is 512 points) + * @returns {Object} An object with two properties: h, a vector containing the complex frequency response, and w, a vector containing the normalized frequencies (in radians/sample) at which the response was computed. + * + * + */ + return typed(name, { + 'Array, Array': function (b, a) { + const w = createBins(512); + return _freqz(b, a, w); + }, + 'Array, Array, Array': function (b, a, w) { + return _freqz(b, a, w); + }, + 'Array, Array, number': function (b, a, w) { + if (w < 0) { + throw new Error('w must be a positive number'); + } + const w2 = createBins(w); + return _freqz(b, a, w2); + }, + 'Matrix, Matrix': function (b, a) { + // console.log('here') + const _w = createBins(512); + const { + w, + h + } = _freqz(b.valueOf(), a.valueOf(), _w); + return { + w: matrix(w), + h: matrix(h) + }; + }, + 'Matrix, Matrix, Matrix': function (b, a, w) { + const { + h + } = _freqz(b.valueOf(), a.valueOf(), w.valueOf()); + return { + h: matrix(h), + w: matrix(w) + }; + }, + 'Matrix, Matrix, number': function (b, a, w) { + if (w < 0) { + throw new Error('w must be a positive number'); + } + const _w = createBins(w); + const { + h + } = _freqz(b.valueOf(), a.valueOf(), _w); + return { + h: matrix(h), + w: matrix(_w) + }; + } + }); + function _freqz(b, a, w) { + const num = []; + const den = []; + for (let i = 0; i < w.length; i++) { + let sumNum = Complex(0, 0); + let sumDen = Complex(0, 0); + for (let j = 0; j < b.length; j++) { + sumNum = add(sumNum, multiply(b[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i])))); + } + for (let j = 0; j < a.length; j++) { + sumDen = add(sumDen, multiply(a[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i])))); + } + num.push(sumNum); + den.push(sumDen); + } + const h = []; + for (let i = 0; i < num.length; i++) { + h.push(divide(num[i], den[i])); + } + return { + h, + w + }; + } + function createBins(n) { + const bins = []; + for (let i = 0; i < n; i++) { + bins.push(i / n * Math.PI); + } + return bins; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/zpk2tf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/zpk2tf.js new file mode 100644 index 0000000..2c0ab88 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/signal/zpk2tf.js @@ -0,0 +1,88 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createZpk2tf = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'zpk2tf'; +const dependencies = ['typed', 'add', 'multiply', 'Complex', 'number']; +const createZpk2tf = exports.createZpk2tf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + multiply, + Complex, + number + } = _ref; + /** + * Compute the transfer function of a zero-pole-gain model. + * + * Syntax: + * math.zpk2tf(z, p, k) + * + * Examples: + * math.zpk2tf([1, 2], [-1, -2], 1) // returns [[1, -3, 2], [1, 3, 2]] + * + * See also: + * freqz + * + * @param {Array} z Array of zeros values + * @param {Array} p Array of poles values + * @param {number} k Gain value + * @return {Array} Two dimensional array containing the numerator (first row) and denominator (second row) polynomials + * + */ + return typed(name, { + 'Array,Array,number': function (z, p, k) { + return _zpk2tf(z, p, k); + }, + 'Array,Array': function (z, p) { + return _zpk2tf(z, p, 1); + }, + 'Matrix,Matrix,number': function (z, p, k) { + return _zpk2tf(z.valueOf(), p.valueOf(), k); + }, + 'Matrix,Matrix': function (z, p) { + return _zpk2tf(z.valueOf(), p.valueOf(), 1); + } + }); + function _zpk2tf(z, p, k) { + // if z is bignumber, convert it to number + if (z.some(el => el.type === 'BigNumber')) { + z = z.map(el => number(el)); + } + // if p is bignumber, convert it to number + if (p.some(el => el.type === 'BigNumber')) { + p = p.map(el => number(el)); + } + let num = [Complex(1, 0)]; + let den = [Complex(1, 0)]; + for (let i = 0; i < z.length; i++) { + let zero = z[i]; + if (typeof zero === 'number') zero = Complex(zero, 0); + num = _multiply(num, [Complex(1, 0), Complex(-zero.re, -zero.im)]); + } + for (let i = 0; i < p.length; i++) { + let pole = p[i]; + if (typeof pole === 'number') pole = Complex(pole, 0); + den = _multiply(den, [Complex(1, 0), Complex(-pole.re, -pole.im)]); + } + for (let i = 0; i < num.length; i++) { + num[i] = multiply(num[i], k); + } + return [num, den]; + } + function _multiply(a, b) { + const c = []; + for (let i = 0; i < a.length + b.length - 1; i++) { + c[i] = Complex(0, 0); + for (let j = 0; j < a.length; j++) { + if (i - j >= 0 && i - j < b.length) { + c[i] = add(c[i], multiply(a[j], b[i - j])); + } + } + } + return c; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/erf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/erf.js new file mode 100644 index 0000000..ae57167 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/erf.js @@ -0,0 +1,161 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createErf = void 0; +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +/* eslint-disable no-loss-of-precision */ + +const name = 'erf'; +const dependencies = ['typed']; +const createErf = exports.createErf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Compute the erf function of a value using a rational Chebyshev + * approximations for different intervals of x. + * + * This is a translation of W. J. Cody's Fortran implementation from 1987 + * ( https://www.netlib.org/specfun/erf ). See the AMS publication + * "Rational Chebyshev Approximations for the Error Function" by W. J. Cody + * for an explanation of this process. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.erf(x) + * + * Examples: + * + * math.erf(0.2) // returns 0.22270258921047847 + * math.erf(-0.5) // returns -0.5204998778130465 + * math.erf(4) // returns 0.9999999845827421 + * + * See also: + * zeta + * + * @param {number | Array | Matrix} x A real number + * @return {number | Array | Matrix} The erf of `x` + */ + return typed('name', { + number: function (x) { + const y = Math.abs(x); + if (y >= MAX_NUM) { + return (0, _number.sign)(x); + } + if (y <= THRESH) { + return (0, _number.sign)(x) * erf1(y); + } + if (y <= 4.0) { + return (0, _number.sign)(x) * (1 - erfc2(y)); + } + return (0, _number.sign)(x) * (1 - erfc3(y)); + }, + 'Array | Matrix': typed.referToSelf(self => n => (0, _collection.deepMap)(n, self)) + + // TODO: For complex numbers, use the approximation for the Faddeeva function + // from "More Efficient Computation of the Complex Error Function" (AMS) + }); + + /** + * Approximates the error function erf() for x <= 0.46875 using this function: + * n + * erf(x) = x * sum (p_j * x^(2j)) / (q_j * x^(2j)) + * j=0 + */ + function erf1(y) { + const ysq = y * y; + let xnum = P[0][4] * ysq; + let xden = ysq; + let i; + for (i = 0; i < 3; i += 1) { + xnum = (xnum + P[0][i]) * ysq; + xden = (xden + Q[0][i]) * ysq; + } + return y * (xnum + P[0][3]) / (xden + Q[0][3]); + } + + /** + * Approximates the complement of the error function erfc() for + * 0.46875 <= x <= 4.0 using this function: + * n + * erfc(x) = e^(-x^2) * sum (p_j * x^j) / (q_j * x^j) + * j=0 + */ + function erfc2(y) { + let xnum = P[1][8] * y; + let xden = y; + let i; + for (i = 0; i < 7; i += 1) { + xnum = (xnum + P[1][i]) * y; + xden = (xden + Q[1][i]) * y; + } + const result = (xnum + P[1][7]) / (xden + Q[1][7]); + const ysq = parseInt(y * 16) / 16; + const del = (y - ysq) * (y + ysq); + return Math.exp(-ysq * ysq) * Math.exp(-del) * result; + } + + /** + * Approximates the complement of the error function erfc() for x > 4.0 using + * this function: + * + * erfc(x) = (e^(-x^2) / x) * [ 1/sqrt(pi) + + * n + * 1/(x^2) * sum (p_j * x^(-2j)) / (q_j * x^(-2j)) ] + * j=0 + */ + function erfc3(y) { + let ysq = 1 / (y * y); + let xnum = P[2][5] * ysq; + let xden = ysq; + let i; + for (i = 0; i < 4; i += 1) { + xnum = (xnum + P[2][i]) * ysq; + xden = (xden + Q[2][i]) * ysq; + } + let result = ysq * (xnum + P[2][4]) / (xden + Q[2][4]); + result = (SQRPI - result) / y; + ysq = parseInt(y * 16) / 16; + const del = (y - ysq) * (y + ysq); + return Math.exp(-ysq * ysq) * Math.exp(-del) * result; + } +}); + +/** + * Upper bound for the first approximation interval, 0 <= x <= THRESH + * @constant + */ +const THRESH = 0.46875; + +/** + * Constant used by W. J. Cody's Fortran77 implementation to denote sqrt(pi) + * @constant + */ +const SQRPI = 5.6418958354775628695e-1; + +/** + * Coefficients for each term of the numerator sum (p_j) for each approximation + * interval (see W. J. Cody's paper for more details) + * @constant + */ +const P = [[3.16112374387056560e00, 1.13864154151050156e02, 3.77485237685302021e02, 3.20937758913846947e03, 1.85777706184603153e-1], [5.64188496988670089e-1, 8.88314979438837594e00, 6.61191906371416295e01, 2.98635138197400131e02, 8.81952221241769090e02, 1.71204761263407058e03, 2.05107837782607147e03, 1.23033935479799725e03, 2.15311535474403846e-8], [3.05326634961232344e-1, 3.60344899949804439e-1, 1.25781726111229246e-1, 1.60837851487422766e-2, 6.58749161529837803e-4, 1.63153871373020978e-2]]; + +/** + * Coefficients for each term of the denominator sum (q_j) for each approximation + * interval (see W. J. Cody's paper for more details) + * @constant + */ +const Q = [[2.36012909523441209e01, 2.44024637934444173e02, 1.28261652607737228e03, 2.84423683343917062e03], [1.57449261107098347e01, 1.17693950891312499e02, 5.37181101862009858e02, 1.62138957456669019e03, 3.29079923573345963e03, 4.36261909014324716e03, 3.43936767414372164e03, 1.23033935480374942e03], [2.56852019228982242e00, 1.87295284992346047e00, 5.27905102951428412e-1, 6.05183413124413191e-2, 2.33520497626869185e-3]]; + +/** + * Maximum/minimum safe numbers to input to erf() (in ES6+, this number is + * Number.[MAX|MIN]_SAFE_INTEGER). erf() for all numbers beyond this limit will + * return 1 + */ +const MAX_NUM = Math.pow(2, 53); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/zeta.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/zeta.js new file mode 100644 index 0000000..2dad474 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/special/zeta.js @@ -0,0 +1,154 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createZeta = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'zeta'; +const dependencies = ['typed', 'config', 'multiply', 'pow', 'divide', 'factorial', 'equal', 'smallerEq', 'isNegative', 'gamma', 'sin', 'subtract', 'add', '?Complex', '?BigNumber', 'pi']; +const createZeta = exports.createZeta = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + multiply, + pow, + divide, + factorial, + equal, + smallerEq, + isNegative, + gamma, + sin, + subtract, + add, + Complex, + BigNumber, + pi + } = _ref; + /** + * Compute the Riemann Zeta function of a value using an infinite series for + * all of the complex plane using Riemann's Functional equation. + * + * Based off the paper by Xavier Gourdon and Pascal Sebah + * ( http://numbers.computation.free.fr/Constants/Miscellaneous/zetaevaluations.pdf ) + * + * Implementation and slight modification by Anik Patel + * + * Note: the implementation is accurate up to about 6 digits. + * + * Syntax: + * + * math.zeta(n) + * + * Examples: + * + * math.zeta(5) // returns 1.0369277551433895 + * math.zeta(-0.5) // returns -0.2078862249773449 + * math.zeta(math.i) // returns 0.0033002236853253153 - 0.4181554491413212i + * + * See also: + * erf + * + * @param {number | Complex | BigNumber} s A Real, Complex or BigNumber parameter to the Riemann Zeta Function + * @return {number | Complex | BigNumber} The Riemann Zeta of `s` + */ + return typed(name, { + number: s => zetaNumeric(s, value => value, () => 20), + BigNumber: s => zetaNumeric(s, value => new BigNumber(value), () => { + // relTol is for example 1e-12. Extract the positive exponent 12 from that + return Math.abs(Math.log10(config.relTol)); + }), + Complex: zetaComplex + }); + + /** + * @param {number | BigNumber} s + * @param {(value: number) => number | BigNumber} createValue + * @param {(value: number | BigNumber | Complex) => number} determineDigits + * @returns {number | BigNumber} + */ + function zetaNumeric(s, createValue, determineDigits) { + if (equal(s, 0)) { + return createValue(-0.5); + } + if (equal(s, 1)) { + return createValue(NaN); + } + if (!isFinite(s)) { + return isNegative(s) ? createValue(NaN) : createValue(1); + } + return zeta(s, createValue, determineDigits, s => s); + } + + /** + * @param {Complex} s + * @returns {Complex} + */ + function zetaComplex(s) { + if (s.re === 0 && s.im === 0) { + return new Complex(-0.5); + } + if (s.re === 1) { + return new Complex(NaN, NaN); + } + if (s.re === Infinity && s.im === 0) { + return new Complex(1); + } + if (s.im === Infinity || s.re === -Infinity) { + return new Complex(NaN, NaN); + } + return zeta(s, value => value, s => Math.round(1.3 * 15 + 0.9 * Math.abs(s.im)), s => s.re); + } + + /** + * @param {number | BigNumber | Complex} s + * @param {(value: number) => number | BigNumber | Complex} createValue + * @param {(value: number | BigNumber | Complex) => number} determineDigits + * @param {(value: number | BigNumber | Complex) => number} getRe + * @returns {*|number} + */ + function zeta(s, createValue, determineDigits, getRe) { + const n = determineDigits(s); + if (getRe(s) > -(n - 1) / 2) { + return f(s, createValue(n), createValue); + } else { + // Function Equation for reflection to x < 1 + let c = multiply(pow(2, s), pow(createValue(pi), subtract(s, 1))); + c = multiply(c, sin(multiply(divide(createValue(pi), 2), s))); + c = multiply(c, gamma(subtract(1, s))); + return multiply(c, zeta(subtract(1, s), createValue, determineDigits, getRe)); + } + } + + /** + * Calculate a portion of the sum + * @param {number | BigNumber} k a positive integer + * @param {number | BigNumber} n a positive integer + * @return {number} the portion of the sum + **/ + function d(k, n) { + let S = k; + for (let j = k; smallerEq(j, n); j = add(j, 1)) { + const factor = divide(multiply(factorial(add(n, subtract(j, 1))), pow(4, j)), multiply(factorial(subtract(n, j)), factorial(multiply(2, j)))); + S = add(S, factor); + } + return multiply(n, S); + } + + /** + * Calculate the positive Riemann Zeta function + * @param {number} s a real or complex number with s.re > 1 + * @param {number} n a positive integer + * @param {(number) => number | BigNumber | Complex} createValue + * @return {number} Riemann Zeta of s + **/ + function f(s, n, createValue) { + const c = divide(1, multiply(d(createValue(0), n), subtract(1, pow(2, subtract(1, s))))); + let S = createValue(0); + for (let k = createValue(1); smallerEq(k, n); k = add(k, 1)) { + S = add(S, divide(multiply((-1) ** (k - 1), d(k, n)), pow(k, s))); + } + return multiply(c, S); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/corr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/corr.js new file mode 100644 index 0000000..aecef66 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/corr.js @@ -0,0 +1,90 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCorr = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'corr'; +const dependencies = ['typed', 'matrix', 'mean', 'sqrt', 'sum', 'add', 'subtract', 'multiply', 'pow', 'divide']; +const createCorr = exports.createCorr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + sqrt, + sum, + add, + subtract, + multiply, + pow, + divide + } = _ref; + /** + * Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated. + * + * Syntax: + * + * math.corr(A, B) + * + * Examples: + * + * math.corr([1, 2, 3, 4, 5], [4, 5, 6, 7, 8]) // returns 1 + * math.corr([1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]) //returns 0.9569941688503644 + * math.corr([[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]],[[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]]) // returns [1,1] + * + * See also: + * + * median, mean, min, max, sum, prod, std, variance + * + * @param {Array | Matrix} A The first array or matrix to compute correlation coefficient + * @param {Array | Matrix} B The second array or matrix to compute correlation coefficient + * @return {*} The correlation coefficient + */ + return typed(name, { + 'Array, Array': function (A, B) { + return _corr(A, B); + }, + 'Matrix, Matrix': function (A, B) { + const res = _corr(A.toArray(), B.toArray()); + return Array.isArray(res) ? matrix(res) : res; + } + }); + /** + * Calculate the correlation coefficient between two arrays or matrices. + * @param {Array | Matrix} A + * @param {Array | Matrix} B + * @return {*} correlation coefficient + * @private + */ + function _corr(A, B) { + const correlations = []; + if (Array.isArray(A[0]) && Array.isArray(B[0])) { + if (A.length !== B.length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same length.'); + } + for (let i = 0; i < A.length; i++) { + if (A[i].length !== B[i].length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.'); + } + correlations.push(correlation(A[i], B[i])); + } + return correlations; + } else { + if (A.length !== B.length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.'); + } + return correlation(A, B); + } + } + function correlation(A, B) { + const n = A.length; + const sumX = sum(A); + const sumY = sum(B); + const sumXY = A.reduce((acc, x, index) => add(acc, multiply(x, B[index])), 0); + const sumXSquare = sum(A.map(x => pow(x, 2))); + const sumYSquare = sum(B.map(y => pow(y, 2))); + const numerator = subtract(multiply(n, sumXY), multiply(sumX, sumY)); + const denominator = sqrt(multiply(subtract(multiply(n, sumXSquare), pow(sumX, 2)), subtract(multiply(n, sumYSquare), pow(sumY, 2)))); + return divide(numerator, denominator); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/cumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/cumsum.js new file mode 100644 index 0000000..70151d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/cumsum.js @@ -0,0 +1,129 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCumSum = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _switch2 = require("../../utils/switch.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +var _array = require("../../utils/array.js"); +var _IndexError = require("../../error/IndexError.js"); +const name = 'cumsum'; +const dependencies = ['typed', 'add', 'unaryPlus']; +const createCumSum = exports.createCumSum = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + unaryPlus + } = _ref; + /** + * Compute the cumulative sum of a matrix or a list with values. + * In case of a (multi dimensional) array or matrix, the cumulative sums + * along a specified dimension (defaulting to the first) will be calculated. + * + * Syntax: + * + * math.cumsum(a, b, c, ...) + * math.cumsum(A) + * + * Examples: + * + * math.cumsum(2, 1, 4, 3) // returns [2, 3, 7, 10] + * math.cumsum([2, 1, 4, 3]) // returns [2, 3, 7, 10] + * math.cumsum([[1, 2], [3, 4]]) // returns [[1, 2], [4, 6]] + * math.cumsum([[1, 2], [3, 4]], 0) // returns [[1, 2], [4, 6]] + * math.cumsum([[1, 2], [3, 4]], 1) // returns [[1, 3], [3, 7]] + * math.cumsum([[2, 5], [4, 3], [1, 7]]) // returns [[2, 5], [6, 8], [7, 15]] + * + * See also: + * + * mean, median, min, max, prod, std, variance, sum + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The cumulative sum of all values + */ + return typed(name, { + // sum([a, b, c, d, ...]) + Array: _cumsum, + Matrix: function (matrix) { + return matrix.create(_cumsum(matrix.valueOf(), matrix.datatype())); + }, + // sum([a, b, c, d, ...], dim) + 'Array, number | BigNumber': _ncumSumDim, + 'Matrix, number | BigNumber': function (matrix, dim) { + return matrix.create(_ncumSumDim(matrix.valueOf(), dim), matrix.datatype()); + }, + // cumsum(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('All values expected to be scalar in function cumsum'); + } + return _cumsum(args); + } + }); + + /** + * Recursively calculate the cumulative sum of an n-dimensional array + * @param {Array} array + * @return {number} cumsum + * @private + */ + function _cumsum(array) { + try { + return _cumsummap(array); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, name); + } + } + function _cumsummap(array) { + if (array.length === 0) { + return []; + } + const sums = [unaryPlus(array[0])]; // unaryPlus converts to number if need be + for (let i = 1; i < array.length; ++i) { + // Must use add below and not addScalar for the case of summing a + // 2+-dimensional array along the 0th dimension (the row vectors, + // or higher-d analogues, are literally added to each other). + sums.push(add(sums[i - 1], array[i])); + } + return sums; + } + function _ncumSumDim(array, dim) { + const size = (0, _array.arraySize)(array); + if (dim < 0 || dim >= size.length) { + // TODO: would be more clear when throwing a DimensionError here + throw new _IndexError.IndexError(dim, size.length); + } + try { + return _cumsumDimensional(array, dim); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, name); + } + } + + /* Possible TODO: Refactor _reduce in collection.js to be able to work here as well */ + function _cumsumDimensional(mat, dim) { + let i, ret, tran; + if (dim <= 0) { + const initialValue = mat[0][0]; + if (!Array.isArray(initialValue)) { + return _cumsummap(mat); + } else { + tran = (0, _switch2._switch)(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _cumsumDimensional(tran[i], dim - 1); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _cumsumDimensional(mat[i], dim - 1); + } + return ret; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mad.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mad.js new file mode 100644 index 0000000..2a7e1b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mad.js @@ -0,0 +1,70 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMad = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'mad'; +const dependencies = ['typed', 'abs', 'map', 'median', 'subtract']; +const createMad = exports.createMad = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + abs, + map, + median, + subtract + } = _ref; + /** + * Compute the median absolute deviation of a matrix or a list with values. + * The median absolute deviation is defined as the median of the absolute + * deviations from the median. + * + * Syntax: + * + * math.mad(a, b, c, ...) + * math.mad(A) + * + * Examples: + * + * math.mad(10, 20, 30) // returns 10 + * math.mad([1, 2, 3]) // returns 1 + * math.mad([[1, 2, 3], [4, 5, 6]]) // returns 1.5 + * + * See also: + * + * median, mean, std, abs + * + * @param {Array | Matrix} array + * A single matrix or multiple scalar values. + * @return {*} The median absolute deviation. + */ + return typed(name, { + // mad([a, b, c, d, ...]) + 'Array | Matrix': _mad, + // mad(a, b, c, d, ...) + '...': function (args) { + return _mad(args); + } + }); + function _mad(array) { + array = (0, _array.flatten)(array.valueOf()); + if (array.length === 0) { + throw new Error('Cannot calculate median absolute deviation (mad) of an empty array'); + } + try { + const med = median(array); + return median(map(array, function (value) { + return abs(subtract(value, med)); + })); + } catch (err) { + if (err instanceof TypeError && err.message.includes('median')) { + throw new TypeError(err.message.replace('median', 'mad')); + } else { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mad'); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/max.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/max.js new file mode 100644 index 0000000..f977dff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/max.js @@ -0,0 +1,111 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMax = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'max'; +const dependencies = ['typed', 'config', 'numeric', 'larger']; +const createMax = exports.createMax = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + numeric, + larger + } = _ref; + /** + * Compute the maximum value of a matrix or a list with values. + * In case of a multidimensional array, the maximum of the flattened array + * will be calculated. When `dim` is provided, the maximum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.max(a, b, c, ...) + * math.max(A) + * math.max(A, dimension) + * + * Examples: + * + * math.max(2, 1, 4, 3) // returns 4 + * math.max([2, 1, 4, 3]) // returns 4 + * + * // maximum over a specified dimension (zero-based) + * math.max([[2, 5], [4, 3], [1, 7]], 0) // returns [4, 7] + * math.max([[2, 5], [4, 3], [1, 7]], 1) // returns [5, 4, 7] + * + * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1 + * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5 + * + * See also: + * + * mean, median, min, prod, std, sum, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The maximum value + */ + return typed(name, { + // max([a, b, c, d, ...]) + 'Array | Matrix': _max, + // max([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function (array, dim) { + return (0, _collection.reduce)(array, dim.valueOf(), _largest); + }, + // max(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('Scalar values expected in function max'); + } + return _max(args); + } + }); + + /** + * Return the largest of two values + * @param {*} x + * @param {*} y + * @returns {*} Returns x when x is largest, or y when y is largest + * @private + */ + function _largest(x, y) { + try { + return larger(x, y) ? x : y; + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'max', y); + } + } + + /** + * Recursively calculate the maximum value in an n-dimensional array + * @param {Array} array + * @return {number} max + * @private + */ + function _max(array) { + let res; + (0, _collection.deepForEach)(array, function (value) { + try { + if (isNaN(value) && typeof value === 'number') { + res = NaN; + } else if (res === undefined || larger(value, res)) { + res = value; + } + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'max', value); + } + }); + if (res === undefined) { + throw new Error('Cannot calculate max of an empty array'); + } + + // make sure returning numeric value: parse a string into a numeric value + if (typeof res === 'string') { + res = numeric(res, (0, _number.safeNumberType)(res, config)); + } + return res; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mean.js new file mode 100644 index 0000000..3bc247f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mean.js @@ -0,0 +1,100 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMean = void 0; +var _collection = require("../../utils/collection.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'mean'; +const dependencies = ['typed', 'add', 'divide']; +const createMean = exports.createMean = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + divide + } = _ref; + /** + * Compute the mean value of matrix or a list with values. + * In case of a multidimensional array, the mean of the flattened array + * will be calculated. When `dim` is provided, the maximum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.mean(a, b, c, ...) + * math.mean(A) + * math.mean(A, dimension) + * + * Examples: + * + * math.mean(2, 1, 4, 3) // returns 2.5 + * math.mean([1, 2.7, 3.2, 4]) // returns 2.725 + * + * math.mean([[2, 5], [6, 3], [1, 7]], 0) // returns [3, 5] + * math.mean([[2, 5], [6, 3], [1, 7]], 1) // returns [3.5, 4.5, 4] + * + * See also: + * + * median, min, max, sum, prod, std, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The mean of all values + */ + return typed(name, { + // mean([a, b, c, d, ...]) + 'Array | Matrix': _mean, + // mean([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': _nmeanDim, + // mean(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('Scalar values expected in function mean'); + } + return _mean(args); + } + }); + + /** + * Calculate the mean value in an n-dimensional array, returning a + * n-1 dimensional array + * @param {Array} array + * @param {number} dim + * @return {number} mean + * @private + */ + function _nmeanDim(array, dim) { + try { + const sum = (0, _collection.reduce)(array, dim, add); + const s = Array.isArray(array) ? (0, _array.arraySize)(array) : array.size(); + return divide(sum, s[dim]); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mean'); + } + } + + /** + * Recursively calculate the mean value in an n-dimensional array + * @param {Array} array + * @return {number} mean + * @private + */ + function _mean(array) { + let sum; + let num = 0; + (0, _collection.deepForEach)(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + num++; + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mean', value); + } + }); + if (num === 0) { + throw new Error('Cannot calculate the mean of an empty array'); + } + return divide(sum, num); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/median.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/median.js new file mode 100644 index 0000000..6110dd5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/median.js @@ -0,0 +1,114 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMedian = void 0; +var _collection = require("../../utils/collection.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'median'; +const dependencies = ['typed', 'add', 'divide', 'compare', 'partitionSelect']; +const createMedian = exports.createMedian = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + divide, + compare, + partitionSelect + } = _ref; + /** + * Recursively calculate the median of an n-dimensional array + * @param {Array} array + * @return {Number} median + * @private + */ + function _median(array) { + try { + array = (0, _array.flatten)(array.valueOf()); + const num = array.length; + if (num === 0) { + throw new Error('Cannot calculate median of an empty array'); + } + if (num % 2 === 0) { + // even: return the average of the two middle values + const mid = num / 2 - 1; + const right = partitionSelect(array, mid + 1); + + // array now partitioned at mid + 1, take max of left part + let left = array[mid]; + for (let i = 0; i < mid; ++i) { + if (compare(array[i], left) > 0) { + left = array[i]; + } + } + return middle2(left, right); + } else { + // odd: return the middle value + const m = partitionSelect(array, (num - 1) / 2); + return middle(m); + } + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'median'); + } + } + + // helper function to type check the middle value of the array + const middle = typed({ + 'number | BigNumber | Complex | Unit': function (value) { + return value; + } + }); + + // helper function to type check the two middle value of the array + const middle2 = typed({ + 'number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit': function (left, right) { + return divide(add(left, right), 2); + } + }); + + /** + * Compute the median of a matrix or a list with values. The values are + * sorted and the middle value is returned. In case of an even number of + * values, the average of the two middle values is returned. + * Supported types of values are: Number, BigNumber, Unit + * + * In case of a (multi dimensional) array or matrix, the median of all + * elements will be calculated. + * + * Syntax: + * + * math.median(a, b, c, ...) + * math.median(A) + * + * Examples: + * + * math.median(5, 2, 7) // returns 5 + * math.median([3, -1, 5, 7]) // returns 4 + * + * See also: + * + * mean, min, max, sum, prod, std, variance, quantileSeq + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The median + */ + return typed(name, { + // median([a, b, c, d, ...]) + 'Array | Matrix': _median, + // median([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function (array, dim) { + // TODO: implement median(A, dim) + throw new Error('median(A, dim) is not yet supported'); + // return reduce(arguments[0], arguments[1], ...) + }, + // median(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('Scalar values expected in function median'); + } + return _median(args); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/min.js new file mode 100644 index 0000000..903f906 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/min.js @@ -0,0 +1,111 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMin = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'min'; +const dependencies = ['typed', 'config', 'numeric', 'smaller']; +const createMin = exports.createMin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + numeric, + smaller + } = _ref; + /** + * Compute the minimum value of a matrix or a list of values. + * In case of a multidimensional array, the minimum of the flattened array + * will be calculated. When `dim` is provided, the minimum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.min(a, b, c, ...) + * math.min(A) + * math.min(A, dimension) + * + * Examples: + * + * math.min(2, 1, 4, 3) // returns 1 + * math.min([2, 1, 4, 3]) // returns 1 + * + * // minimum over a specified dimension (zero-based) + * math.min([[2, 5], [4, 3], [1, 7]], 0) // returns [1, 3] + * math.min([[2, 5], [4, 3], [1, 7]], 1) // returns [2, 3, 1] + * + * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1 + * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5 + * + * See also: + * + * mean, median, max, prod, std, sum, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The minimum value + */ + return typed(name, { + // min([a, b, c, d, ...]) + 'Array | Matrix': _min, + // min([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function (array, dim) { + return (0, _collection.reduce)(array, dim.valueOf(), _smallest); + }, + // min(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('Scalar values expected in function min'); + } + return _min(args); + } + }); + + /** + * Return the smallest of two values + * @param {*} x + * @param {*} y + * @returns {*} Returns x when x is smallest, or y when y is smallest + * @private + */ + function _smallest(x, y) { + try { + return smaller(x, y) ? x : y; + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', y); + } + } + + /** + * Recursively calculate the minimum value in an n-dimensional array + * @param {Array} array + * @return {number} min + * @private + */ + function _min(array) { + let min; + (0, _collection.deepForEach)(array, function (value) { + try { + if (isNaN(value) && typeof value === 'number') { + min = NaN; + } else if (min === undefined || smaller(value, min)) { + min = value; + } + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', value); + } + }); + if (min === undefined) { + throw new Error('Cannot calculate min of an empty array'); + } + + // make sure returning numeric value: parse a string into a numeric value + if (typeof min === 'string') { + min = numeric(min, (0, _number.safeNumberType)(min, config)); + } + return min; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mode.js new file mode 100644 index 0000000..74bde64 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/mode.js @@ -0,0 +1,82 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMode = void 0; +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +const name = 'mode'; +const dependencies = ['typed', 'isNaN', 'isNumeric']; +const createMode = exports.createMode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isNaN, + isNumeric + } = _ref; + /** + * Computes the mode of a set of numbers or a list with values(numbers or characters). + * If there are multiple modes, it returns a list of those values. + * + * Syntax: + * + * math.mode(a, b, c, ...) + * math.mode(A) + * + * Examples: + * + * math.mode(2, 1, 4, 3, 1) // returns [1] + * math.mode([1, 2.7, 3.2, 4, 2.7]) // returns [2.7] + * math.mode(1, 4, 6, 1, 6) // returns [1, 6] + * math.mode('a','a','b','c') // returns ["a"] + * math.mode(1, 1.5, 'abc') // returns [1, 1.5, "abc"] + * + * See also: + * + * median, + * mean + * + * @param {... *} args A single matrix + * @return {*} The mode of all values + */ + return typed(name, { + 'Array | Matrix': _mode, + '...': function (args) { + return _mode(args); + } + }); + + /** + * Calculates the mode in an 1-dimensional array + * @param {Array} values + * @return {Array} mode + * @private + */ + function _mode(values) { + values = (0, _array.flatten)(values.valueOf()); + const num = values.length; + if (num === 0) { + throw new Error('Cannot calculate mode of an empty array'); + } + const count = {}; + let mode = []; + let max = 0; + for (let i = 0; i < values.length; i++) { + const value = values[i]; + if (isNumeric(value) && isNaN(value)) { + throw new Error('Cannot calculate mode of an array containing NaN values'); + } + if (!(value in count)) { + count[value] = 0; + } + count[value]++; + if (count[value] === max) { + mode.push(value); + } else if (count[value] > max) { + max = count[value]; + mode = [value]; + } + } + return mode; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/prod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/prod.js new file mode 100644 index 0000000..4506444 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/prod.js @@ -0,0 +1,85 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createProd = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'prod'; +const dependencies = ['typed', 'config', 'multiplyScalar', 'numeric']; +const createProd = exports.createProd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + multiplyScalar, + numeric + } = _ref; + /** + * Compute the product of a matrix or a list with values. + * In case of a multidimensional array or matrix, the sum of all + * elements will be calculated. + * + * Syntax: + * + * math.prod(a, b, c, ...) + * math.prod(A) + * + * Examples: + * + * math.multiply(2, 3) // returns 6 + * math.prod(2, 3) // returns 6 + * math.prod(2, 3, 4) // returns 24 + * math.prod([2, 3, 4]) // returns 24 + * math.prod([[2, 5], [4, 3]]) // returns 120 + * + * See also: + * + * mean, median, min, max, sum, std, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The product of all values + */ + return typed(name, { + // prod([a, b, c, d, ...]) + 'Array | Matrix': _prod, + // prod([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function (array, dim) { + // TODO: implement prod(A, dim) + throw new Error('prod(A, dim) is not yet supported'); + // return reduce(arguments[0], arguments[1], math.prod) + }, + // prod(a, b, c, d, ...) + '...': function (args) { + return _prod(args); + } + }); + + /** + * Recursively calculate the product of an n-dimensional array + * @param {Array} array + * @return {number} prod + * @private + */ + function _prod(array) { + let prod; + (0, _collection.deepForEach)(array, function (value) { + try { + prod = prod === undefined ? value : multiplyScalar(prod, value); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'prod', value); + } + }); + + // make sure returning numeric value: parse a string into a numeric value + if (typeof prod === 'string') { + prod = numeric(prod, (0, _number.safeNumberType)(prod, config)); + } + if (prod === undefined) { + throw new Error('Cannot calculate prod of an empty array'); + } + return prod; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/quantileSeq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/quantileSeq.js new file mode 100644 index 0000000..d2baf20 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/quantileSeq.js @@ -0,0 +1,172 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createQuantileSeq = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _apply = require("../matrix/apply.js"); +const name = 'quantileSeq'; +const dependencies = ['typed', '?bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']; +const createQuantileSeq = exports.createQuantileSeq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + } = _ref; + const apply = (0, _apply.createApply)({ + typed, + isInteger + }); + + /** + * Compute the prob order quantile of a matrix or a list with values. + * The sequence is sorted and the middle value is returned. + * Supported types of sequence values are: Number, BigNumber, Unit + * Supported types of probability are: Number, BigNumber + * + * In case of a multidimensional array or matrix, the prob order quantile + * of all elements will be calculated. + * + * Syntax: + * + * math.quantileSeq(A, prob[, sorted]) + * math.quantileSeq(A, [prob1, prob2, ...][, sorted]) + * math.quantileSeq(A, N[, sorted]) + * + * Examples: + * + * math.quantileSeq([3, -1, 5, 7], 0.5) // returns 4 + * math.quantileSeq([3, -1, 5, 7], [1/3, 2/3]) // returns [3, 5] + * math.quantileSeq([3, -1, 5, 7], 2) // returns [3, 5] + * math.quantileSeq([-1, 3, 5, 7], 0.5, true) // returns 4 + * + * See also: + * + * median, mean, min, max, sum, prod, std, variance + * + * @param {Array, Matrix} data A single matrix or Array + * @param {Number, BigNumber, Array} probOrN prob is the order of the quantile, while N is + * the amount of evenly distributed steps of + * probabilities; only one of these options can + * be provided + * @param {Boolean} sorted=false is data sorted in ascending order + * @return {Number, BigNumber, Unit, Array} Quantile(s) + */ + return typed(name, { + 'Array | Matrix, number | BigNumber': (data, p) => _quantileSeqProbNumber(data, p, false), + 'Array | Matrix, number | BigNumber, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbNumber), + 'Array | Matrix, number | BigNumber, boolean': _quantileSeqProbNumber, + 'Array | Matrix, number | BigNumber, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbNumber), + 'Array | Matrix, Array | Matrix': (data, p) => _quantileSeqProbCollection(data, p, false), + 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbCollection), + 'Array | Matrix, Array | Matrix, boolean': _quantileSeqProbCollection, + 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbCollection) + }); + function _quantileSeqDim(data, prob, sorted, dim, fn) { + return apply(data, dim, x => fn(x, prob, sorted)); + } + function _quantileSeqProbNumber(data, probOrN, sorted) { + let probArr; + const dataArr = data.valueOf(); + if (smaller(probOrN, 0)) { + throw new Error('N/prob must be non-negative'); + } + if (smallerEq(probOrN, 1)) { + // quantileSeq([a, b, c, d, ...], prob[,sorted]) + return (0, _is.isNumber)(probOrN) ? _quantileSeq(dataArr, probOrN, sorted) : bignumber(_quantileSeq(dataArr, probOrN, sorted)); + } + if (larger(probOrN, 1)) { + // quantileSeq([a, b, c, d, ...], N[,sorted]) + if (!isInteger(probOrN)) { + throw new Error('N must be a positive integer'); + } + + // largest possible Array length is 2^32-1 + // 2^32 < 10^15, thus safe conversion guaranteed + if (larger(probOrN, 4294967295)) { + throw new Error('N must be less than or equal to 2^32-1, as that is the maximum length of an Array'); + } + const nPlusOne = add(probOrN, 1); + probArr = []; + for (let i = 0; smaller(i, probOrN); i++) { + const prob = divide(i + 1, nPlusOne); + probArr.push(_quantileSeq(dataArr, prob, sorted)); + } + return (0, _is.isNumber)(probOrN) ? probArr : bignumber(probArr); + } + } + + /** + * Calculate the prob order quantile of an n-dimensional array. + * + * @param {Array, Matrix} array + * @param {Array, Matrix} prob + * @param {Boolean} sorted + * @return {Number, BigNumber, Unit} prob order quantile + * @private + */ + + function _quantileSeqProbCollection(data, probOrN, sorted) { + const dataArr = data.valueOf(); + // quantileSeq([a, b, c, d, ...], [prob1, prob2, ...][,sorted]) + const probOrNArr = probOrN.valueOf(); + const probArr = []; + for (let i = 0; i < probOrNArr.length; ++i) { + probArr.push(_quantileSeq(dataArr, probOrNArr[i], sorted)); + } + return probArr; + } + + /** + * Calculate the prob order quantile of an n-dimensional array. + * + * @param {Array} array + * @param {Number, BigNumber} prob + * @param {Boolean} sorted + * @return {Number, BigNumber, Unit} prob order quantile + * @private + */ + function _quantileSeq(array, prob, sorted) { + const flat = (0, _array.flatten)(array); + const len = flat.length; + if (len === 0) { + throw new Error('Cannot calculate quantile of an empty sequence'); + } + const index = (0, _is.isNumber)(prob) ? prob * (len - 1) : prob.times(len - 1); + const integerPart = (0, _is.isNumber)(prob) ? Math.floor(index) : index.floor().toNumber(); + const fracPart = (0, _is.isNumber)(prob) ? index % 1 : index.minus(integerPart); + if (isInteger(index)) { + return sorted ? flat[index] : partitionSelect(flat, (0, _is.isNumber)(prob) ? index : index.valueOf()); + } + let left; + let right; + if (sorted) { + left = flat[integerPart]; + right = flat[integerPart + 1]; + } else { + right = partitionSelect(flat, integerPart + 1); + + // max of partition is kth largest + left = flat[integerPart]; + for (let i = 0; i < integerPart; ++i) { + if (compare(flat[i], left) > 0) { + left = flat[i]; + } + } + } + // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1] + return add(multiply(left, subtract(1, fracPart)), multiply(right, fracPart)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/std.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/std.js new file mode 100644 index 0000000..9cc1bba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/std.js @@ -0,0 +1,103 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createStd = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'std'; +const dependencies = ['typed', 'map', 'sqrt', 'variance']; +const createStd = exports.createStd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + map, + sqrt, + variance + } = _ref; + /** + * Compute the standard deviation of a matrix or a list with values. + * The standard deviations is defined as the square root of the variance: + * `std(A) = sqrt(variance(A))`. + * In case of a (multi dimensional) array or matrix, the standard deviation + * over all elements will be calculated by default, unless an axis is specified + * in which case the standard deviation will be computed along that axis. + * + * Additionally, it is possible to compute the standard deviation along the rows + * or columns of a matrix by specifying the dimension as the second argument. + * + * Optionally, the type of normalization can be specified as the final + * parameter. The parameter `normalization` can be one of the following values: + * + * - 'unbiased' (default) The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * + * + * Syntax: + * + * math.std(a, b, c, ...) + * math.std(A) + * math.std(A, normalization) + * math.std(A, dimension) + * math.std(A, dimension, normalization) + * + * Examples: + * + * math.std(2, 4, 6) // returns 2 + * math.std([2, 4, 6, 8]) // returns 2.581988897471611 + * math.std([2, 4, 6, 8], 'uncorrected') // returns 2.23606797749979 + * math.std([2, 4, 6, 8], 'biased') // returns 2 + * + * math.std([[1, 2, 3], [4, 5, 6]]) // returns 1.8708286933869707 + * math.std([[1, 2, 3], [4, 6, 8]], 0) // returns [2.1213203435596424, 2.8284271247461903, 3.5355339059327378] + * math.std([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 2] + * math.std([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.7071067811865476, 1.4142135623730951] + * + * See also: + * + * mean, median, max, min, prod, sum, variance + * + * @param {Array | Matrix} array + * A single matrix or or multiple scalar values + * @param {string} [normalization='unbiased'] + * Determines how to normalize the variance. + * Choose 'unbiased' (default), 'uncorrected', or 'biased'. + * @param dimension {number | BigNumber} + * Determines the axis to compute the standard deviation for a matrix + * @return {*} The standard deviation + */ + return typed(name, { + // std([a, b, c, d, ...]) + 'Array | Matrix': _std, + // std([a, b, c, d, ...], normalization) + 'Array | Matrix, string': _std, + // std([a, b, c, c, ...], dim) + 'Array | Matrix, number | BigNumber': _std, + // std([a, b, c, c, ...], dim, normalization) + 'Array | Matrix, number | BigNumber, string': _std, + // std(a, b, c, d, ...) + '...': function (args) { + return _std(args); + } + }); + function _std(array, normalization) { + if (array.length === 0) { + throw new SyntaxError('Function std requires one or more parameters (0 provided)'); + } + try { + const v = variance.apply(null, arguments); + if ((0, _is.isCollection)(v)) { + return map(v, sqrt); + } else { + return sqrt(v); + } + } catch (err) { + if (err instanceof TypeError && err.message.includes(' variance')) { + throw new TypeError(err.message.replace(' variance', ' std')); + } else { + throw err; + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/sum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/sum.js new file mode 100644 index 0000000..533593d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/sum.js @@ -0,0 +1,91 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSum = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const name = 'sum'; +const dependencies = ['typed', 'config', 'add', 'numeric']; +const createSum = exports.createSum = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + add, + numeric + } = _ref; + /** + * Compute the sum of a matrix or a list with values. + * In case of a multidimensional array or matrix, the sum of all + * elements will be calculated. + * + * Syntax: + * + * math.sum(a, b, c, ...) + * math.sum(A) + * math.sum(A, dimension) + * + * Examples: + * + * math.sum(2, 1, 4, 3) // returns 10 + * math.sum([2, 1, 4, 3]) // returns 10 + * math.sum([[2, 5], [4, 3], [1, 7]]) // returns 22 + * + * See also: + * + * mean, median, min, max, prod, std, variance, cumsum + * + * @param {... *} args A single matrix or multiple scalar values + * @return {*} The sum of all values + */ + return typed(name, { + // sum([a, b, c, d, ...]) + 'Array | Matrix': _sum, + // sum([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': _nsumDim, + // sum(a, b, c, d, ...) + '...': function (args) { + if ((0, _collection.containsCollections)(args)) { + throw new TypeError('Scalar values expected in function sum'); + } + return _sum(args); + } + }); + + /** + * Recursively calculate the sum of an n-dimensional array + * @param {Array | Matrix} array + * @return {number} sum + * @private + */ + function _sum(array) { + let sum; + (0, _collection.deepForEach)(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'sum', value); + } + }); + + // make sure returning numeric value: parse a string into a numeric value + if (sum === undefined) { + sum = numeric(0, config.number); + } + if (typeof sum === 'string') { + sum = numeric(sum, (0, _number.safeNumberType)(sum, config)); + } + return sum; + } + function _nsumDim(array, dim) { + try { + const sum = (0, _collection.reduce)(array, dim, add); + return sum; + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'sum'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/utils/improveErrorMessage.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/utils/improveErrorMessage.js new file mode 100644 index 0000000..e411eb8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/utils/improveErrorMessage.js @@ -0,0 +1,30 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.improveErrorMessage = improveErrorMessage; +var _is = require("../../../utils/is.js"); +/** + * Improve error messages for statistics functions. Errors are typically + * thrown in an internally used function like larger, causing the error + * not to mention the function (like max) which is actually used by the user. + * + * @param {Error} err + * @param {String} fnName + * @param {*} [value] + * @return {Error} + */ +function improveErrorMessage(err, fnName, value) { + // TODO: add information with the index (also needs transform in expression parser) + let details; + if (String(err).includes('Unexpected type')) { + details = arguments.length > 2 ? ' (type: ' + (0, _is.typeOf)(value) + ', value: ' + JSON.stringify(value) + ')' : ' (type: ' + err.data.actual + ')'; + return new TypeError('Cannot calculate ' + fnName + ', unexpected type of argument' + details); + } + if (String(err).includes('complex numbers')) { + details = arguments.length > 2 ? ' (type: ' + (0, _is.typeOf)(value) + ', value: ' + JSON.stringify(value) + ')' : ''; + return new TypeError('Cannot calculate ' + fnName + ', no ordering relation is defined for complex numbers' + details); + } + return err; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/variance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/variance.js new file mode 100644 index 0000000..0cd8e09 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/statistics/variance.js @@ -0,0 +1,159 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createVariance = void 0; +var _collection = require("../../utils/collection.js"); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _improveErrorMessage = require("./utils/improveErrorMessage.js"); +const DEFAULT_NORMALIZATION = 'unbiased'; +const name = 'variance'; +const dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']; +const createVariance = exports.createVariance = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + } = _ref; + /** + * Compute the variance of a matrix or a list with values. + * In case of a multidimensional array or matrix, the variance over all + * elements will be calculated. + * + * Additionally, it is possible to compute the variance along the rows + * or columns of a matrix by specifying the dimension as the second argument. + * + * Optionally, the type of normalization can be specified as the final + * parameter. The parameter `normalization` can be one of the following values: + * + * - 'unbiased' (default) The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * + * + * Note that older browser may not like the variable name `var`. In that + * case, the function can be called as `math['var'](...)` instead of + * `math.var(...)`. + * + * Syntax: + * + * math.variance(a, b, c, ...) + * math.variance(A) + * math.variance(A, normalization) + * math.variance(A, dimension) + * math.variance(A, dimension, normalization) + * + * Examples: + * + * math.variance(2, 4, 6) // returns 4 + * math.variance([2, 4, 6, 8]) // returns 6.666666666666667 + * math.variance([2, 4, 6, 8], 'uncorrected') // returns 5 + * math.variance([2, 4, 6, 8], 'biased') // returns 4 + * + * math.variance([[1, 2, 3], [4, 5, 6]]) // returns 3.5 + * math.variance([[1, 2, 3], [4, 6, 8]], 0) // returns [4.5, 8, 12.5] + * math.variance([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 4] + * math.variance([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.5, 2] + * + * See also: + * + * mean, median, max, min, prod, std, sum + * + * @param {Array | Matrix} array + * A single matrix or or multiple scalar values + * @param {string} [normalization='unbiased'] + * Determines how to normalize the variance. + * Choose 'unbiased' (default), 'uncorrected', or 'biased'. + * @param dimension {number | BigNumber} + * Determines the axis to compute the variance for a matrix + * @return {*} The variance + */ + return typed(name, { + // variance([a, b, c, d, ...]) + 'Array | Matrix': function (array) { + return _var(array, DEFAULT_NORMALIZATION); + }, + // variance([a, b, c, d, ...], normalization) + 'Array | Matrix, string': _var, + // variance([a, b, c, c, ...], dim) + 'Array | Matrix, number | BigNumber': function (array, dim) { + return _varDim(array, dim, DEFAULT_NORMALIZATION); + }, + // variance([a, b, c, c, ...], dim, normalization) + 'Array | Matrix, number | BigNumber, string': _varDim, + // variance(a, b, c, d, ...) + '...': function (args) { + return _var(args, DEFAULT_NORMALIZATION); + } + }); + + /** + * Recursively calculate the variance of an n-dimensional array + * @param {Array} array + * @param {string} normalization + * Determines how to normalize the variance: + * - 'unbiased' The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * @return {number | BigNumber} variance + * @private + */ + function _var(array, normalization) { + let sum; + let num = 0; + if (array.length === 0) { + throw new SyntaxError('Function variance requires one or more parameters (0 provided)'); + } + + // calculate the mean and number of elements + (0, _collection.deepForEach)(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + num++; + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'variance', value); + } + }); + if (num === 0) throw new Error('Cannot calculate variance of an empty array'); + const mean = divide(sum, num); + + // calculate the variance + sum = undefined; + (0, _collection.deepForEach)(array, function (value) { + const diff = subtract(value, mean); + sum = sum === undefined ? multiply(diff, diff) : add(sum, multiply(diff, diff)); + }); + if (isNaN(sum)) { + return sum; + } + switch (normalization) { + case 'uncorrected': + return divide(sum, num); + case 'biased': + return divide(sum, num + 1); + case 'unbiased': + { + const zero = (0, _is.isBigNumber)(sum) ? sum.mul(0) : 0; + return num === 1 ? zero : divide(sum, num - 1); + } + default: + throw new Error('Unknown normalization "' + normalization + '". ' + 'Choose "unbiased" (default), "uncorrected", or "biased".'); + } + } + function _varDim(array, dim, normalization) { + try { + if (array.length === 0) { + throw new SyntaxError('Function variance requires one or more parameters (0 provided)'); + } + return apply(array, dim, x => _var(x, normalization)); + } catch (err) { + throw (0, _improveErrorMessage.improveErrorMessage)(err, 'variance'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/bin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/bin.js new file mode 100644 index 0000000..15fb683 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/bin.js @@ -0,0 +1,50 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBin = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'bin'; +const dependencies = ['typed', 'format']; + +/** + * Format a number as binary. + * + * Syntax: + * + * math.bin(value) + * + * Examples: + * + * //the following outputs "0b10" + * math.bin(2) + * + * See also: + * + * oct + * hex + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ +const createBin = exports.createBin = (0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function (n) { + return format(n, { + notation: 'bin' + }); + }, + 'number | BigNumber, number | BigNumber': function (n, wordSize) { + return format(n, { + notation: 'bin', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/format.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/format.js new file mode 100644 index 0000000..8c5db61 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/format.js @@ -0,0 +1,137 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFormat = void 0; +var _string = require("../../utils/string.js"); +var _factory = require("../../utils/factory.js"); +const name = 'format'; +const dependencies = ['typed']; +const createFormat = exports.createFormat = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Format a value of any type into a string. + * + * Syntax: + * + * math.format(value) + * math.format(value, options) + * math.format(value, precision) + * math.format(value, callback) + * + * Where: + * + * - `value: *` + * The value to be formatted + * - `options: Object` + * An object with formatting options. Available options: + * - `notation: string` + * Number notation. Choose from: + * - `'fixed'` + * Always use regular number notation. + * For example `'123.40'` and `'14000000'` + * - `'exponential'` + * Always use exponential notation. + * For example `'1.234e+2'` and `'1.4e+7'` + * - `'engineering'` + * Always use engineering notation: always have exponential notation, + * and select the exponent to be a multiple of `3`. + * For example `'123.4e+0'` and `'14.0e+6'` + * - `'auto'` (default) + * Regular number notation for numbers having an absolute value between + * `lower` and `upper` bounds, and uses exponential notation elsewhere. + * Lower bound is included, upper bound is excluded. + * For example `'123.4'` and `'1.4e7'`. + * - `'bin'`, `'oct'`, or `'hex'` + * Format the number using binary, octal, or hexadecimal notation. + * For example `'0b1101'` and `'0x10fe'`. + * - `wordSize: number | BigNumber` + * The word size in bits to use for formatting in binary, octal, or + * hexadecimal notation. To be used only with `'bin'`, `'oct'`, or `'hex'` + * values for `notation` option. When this option is defined the value + * is formatted as a signed twos complement integer of the given word + * size and the size suffix is appended to the output. + * For example `format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'`. + * Default value is undefined. + * - `precision: number | BigNumber` + * Limit the number of digits of the formatted value. + * For regular numbers, must be a number between `0` and `16`. + * For bignumbers, the maximum depends on the configured precision, + * see function `config()`. + * In case of notations `'exponential'`, `'engineering'`, and `'auto'`, + * `precision` defines the total number of significant digits returned. + * In case of notation `'fixed'`, `precision` defines the number of + * significant digits after the decimal point. + * `precision` is undefined by default. + * - `lowerExp: number` + * Exponent determining the lower boundary for formatting a value with + * an exponent when `notation='auto'`. Default value is `-3`. + * - `upperExp: number` + * Exponent determining the upper boundary for formatting a value with + * an exponent when `notation='auto'`. Default value is `5`. + * - `fraction: string`. Available values: `'ratio'` (default) or `'decimal'`. + * For example `format(fraction(1, 3))` will output `'1/3'` when `'ratio'` + * is configured, and will output `'0.(3)'` when `'decimal'` is configured. + * - `truncate: number`. Specifies the maximum allowed length of the + * returned string. If it had been longer, the excess characters + * are deleted and replaced with `'...'`. + * - `callback: function` + * A custom formatting function, invoked for all numeric elements in `value`, + * for example all elements of a matrix, or the real and imaginary + * parts of a complex number. This callback can be used to override the + * built-in numeric notation with any type of formatting. Function `callback` + * is called with `value` as parameter and must return a string. + * + * When `value` is an Object: + * + * - When the object contains a property `format` being a function, this function + * is invoked as `value.format(options)` and the result is returned. + * - When the object has its own `toString` method, this method is invoked + * and the result is returned. + * - In other cases the function will loop over all object properties and + * return JSON object notation like '{"a": 2, "b": 3}'. + * + * When value is a function: + * + * - When the function has a property `syntax`, it returns this + * syntax description. + * - In other cases, a string `'function'` is returned. + * + * Examples: + * + * math.format(6.4) // returns '6.4' + * math.format(1240000) // returns '1.24e+6' + * math.format(1/3) // returns '0.3333333333333333' + * math.format(1/3, 3) // returns '0.333' + * math.format(21385, 2) // returns '21000' + * math.format(12e8, {notation: 'fixed'}) // returns '1200000000' + * math.format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000' + * math.format(52.8, {notation: 'exponential'}) // returns '5.28e+1' + * math.format(12400, {notation: 'engineering'}) // returns '12.4e+3' + * math.format(2000, {lowerExp: -2, upperExp: 2}) // returns '2e+3' + * + * function formatCurrency(value) { + * // return currency notation with two digits: + * return '$' + value.toFixed(2) + * + * // you could also use math.format inside the callback: + * // return '$' + math.format(value, {notation: 'fixed', precision: 2}) + * } + * math.format([2.1, 3, 0.016], formatCurrency) // returns '[$2.10, $3.00, $0.02]' + * + * See also: + * + * print + * + * @param {*} value Value to be stringified + * @param {Object | Function | number} [options] Formatting options + * @return {string} The formatted value + */ + return typed(name, { + any: _string.format, + 'any, Object | function | number | BigNumber': _string.format + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/hex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/hex.js new file mode 100644 index 0000000..bfad623 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/hex.js @@ -0,0 +1,49 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createHex = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'hex'; +const dependencies = ['typed', 'format']; + +/** + * Format a number as hexadecimal. + * + * Syntax: + * + * math.hex(value) + * + * Examples: + * + * math.hex(240) // returns "0xF0" + * + * See also: + * + * oct + * bin + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ +const createHex = exports.createHex = (0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function (n) { + return format(n, { + notation: 'hex' + }); + }, + 'number | BigNumber, number | BigNumber': function (n, wordSize) { + return format(n, { + notation: 'hex', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/oct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/oct.js new file mode 100644 index 0000000..1330914 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/oct.js @@ -0,0 +1,51 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createOct = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'oct'; +const dependencies = ['typed', 'format']; + +/** + * Format a number as octal. + * + * Syntax: + * + * math.oct(value) + * + * Examples: + * + * //the following outputs "0o70" + * math.oct(56) + * + * See also: + * + * bin + * hex + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ + +const createOct = exports.createOct = (0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function (n) { + return format(n, { + notation: 'oct' + }); + }, + 'number | BigNumber, number | BigNumber': function (n, wordSize) { + return format(n, { + notation: 'oct', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/print.js new file mode 100644 index 0000000..6afddad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/string/print.js @@ -0,0 +1,96 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createPrint = void 0; +var _string = require("../../utils/string.js"); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _print2 = require("../../utils/print.js"); +const name = 'print'; +const dependencies = ['typed']; +const createPrint = exports.createPrint = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Interpolate values into a string template. + * + * Syntax: + * + * math.print(template, values) + * math.print(template, values, precision) + * math.print(template, values, options) + * + * Example usage: + * + * // the following outputs: 'Lucy is 5 years old' + * math.print('Lucy is $age years old', {age: 5}) + * + * // the following outputs: 'The value of pi is 3.141592654' + * math.print('The value of pi is $pi', {pi: math.pi}, 10) + * + * // the following outputs: 'hello Mary! The date is 2013-03-23' + * math.print('Hello $user.name! The date is $date', { + * user: { + * name: 'Mary', + * }, + * date: new Date(2013, 2, 23).toISOString().substring(0, 10) + * }) + * + * // the following outputs: 'My favorite fruits are apples and bananas !' + * math.print('My favorite fruits are $0 and $1 !', [ + * 'apples', + * 'bananas' + * ]) + * + * See also: + * + * format + * + * @param {string} template A string containing variable placeholders. + * @param {Object | Array | Matrix} values An object or array containing variables + * which will be filled in in the template. + * @param {number | Object} [options] Formatting options, + * or the number of digits to format numbers. + * See function math.format for a description + * of all options. + * @return {string} Interpolated string + */ + return typed(name, { + // note: Matrix will be converted automatically to an Array + 'string, Object | Array': _print, + 'string, Object | Array, number | Object': _print + }); +}); + +/** + * Interpolate values into a string template. + * @param {string} template + * @param {Object} values + * @param {number | Object} [options] + * @returns {string} Interpolated string + * @private + */ +function _print(template, values, options) { + return template.replace(_print2.printTemplate, function (original, key) { + const keys = key.split('.'); + let value = values[keys.shift()]; + if (value !== undefined && value.isMatrix) { + value = value.toArray(); + } + while (keys.length && value !== undefined) { + const k = keys.shift(); + value = k ? value[k] : value + '.'; + } + if (value !== undefined) { + if (!(0, _is.isString)(value)) { + return (0, _string.format)(value, options); + } else { + return value; + } + } + return original; + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acos.js new file mode 100644 index 0000000..1d028c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acos.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcos = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'acos'; +const dependencies = ['typed', 'config', 'Complex']; +const createAcos = exports.createAcos = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the inverse cosine of a value. + * + * To avoid confusion with the matrix arccosine, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acos(x) + * + * Examples: + * + * math.acos(0.5) // returns number 1.0471975511965979 + * math.acos(math.cos(1.5)) // returns number 1.5 + * + * math.acos(2) // returns Complex 0 + 1.3169578969248166 i + * + * See also: + * + * cos, atan, asin + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc cosine of x + */ + return typed(name, { + number: function (x) { + if (x >= -1 && x <= 1 || config.predictable) { + return Math.acos(x); + } else { + return new Complex(x, 0).acos(); + } + }, + Complex: function (x) { + return x.acos(); + }, + BigNumber: function (x) { + return x.acos(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acosh.js new file mode 100644 index 0000000..38a2212 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acosh.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcosh = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'acosh'; +const dependencies = ['typed', 'config', 'Complex']; +const createAcosh = exports.createAcosh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the hyperbolic arccos of a value, + * defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.acosh(x) + * + * Examples: + * + * math.acosh(1.5) // returns 0.9624236501192069 + * + * See also: + * + * cosh, asinh, atanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccosine of x + */ + return typed(name, { + number: function (x) { + if (x >= 1 || config.predictable) { + return (0, _index.acoshNumber)(x); + } + if (x <= -1) { + return new Complex(Math.log(Math.sqrt(x * x - 1) - x), Math.PI); + } + return new Complex(x, 0).acosh(); + }, + Complex: function (x) { + return x.acosh(); + }, + BigNumber: function (x) { + return x.acosh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acot.js new file mode 100644 index 0000000..6557853 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acot.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcot = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'acot'; +const dependencies = ['typed', 'BigNumber']; +const createAcot = exports.createAcot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Calculate the inverse cotangent of a value, defined as `acot(x) = atan(1/x)`. + * + * To avoid confusion with the matrix arccotanget, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acot(x) + * + * Examples: + * + * math.acot(0.5) // returns number 1.1071487177940904 + * math.acot(2) // returns number 0.4636476090008061 + * math.acot(math.cot(1.5)) // returns number 1.5 + * + * See also: + * + * cot, atan + * + * @param {number | BigNumber| Complex} x Function input + * @return {number | BigNumber| Complex} The arc cotangent of x + */ + return typed(name, { + number: _index.acotNumber, + Complex: function (x) { + return x.acot(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).atan(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acoth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acoth.js new file mode 100644 index 0000000..2a366f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acoth.js @@ -0,0 +1,54 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcoth = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'acoth'; +const dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +const createAcoth = exports.createAcoth = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex, + BigNumber + } = _ref; + /** + * Calculate the inverse hyperbolic tangent of a value, + * defined as `acoth(x) = atanh(1/x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`. + * + * To avoid confusion with the matrix inverse hyperbolic tangent, this + * function does not apply to matrices. + * + * Syntax: + * + * math.acoth(x) + * + * Examples: + * + * math.acoth(0.5) // returns 0.8047189562170503 + * + * See also: + * + * acsch, asech + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccotangent of x + */ + return typed(name, { + number: function (x) { + if (x >= 1 || x <= -1 || config.predictable) { + return (0, _index.acothNumber)(x); + } + return new Complex(x, 0).acoth(); + }, + Complex: function (x) { + return x.acoth(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).atanh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsc.js new file mode 100644 index 0000000..43a4caf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsc.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcsc = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'acsc'; +const dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +const createAcsc = exports.createAcsc = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex, + BigNumber + } = _ref; + /** + * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`. + * + * To avoid confusion with the matrix arccosecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acsc(x) + * + * Examples: + * + * math.acsc(2) // returns 0.5235987755982989 + * math.acsc(0.5) // returns Complex 1.5707963267948966 -1.3169578969248166i + * math.acsc(math.csc(1.5)) // returns number ~1.5 + * + * See also: + * + * csc, asin, asec + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc cosecant of x + */ + return typed(name, { + number: function (x) { + if (x <= -1 || x >= 1 || config.predictable) { + return (0, _index.acscNumber)(x); + } + return new Complex(x, 0).acsc(); + }, + Complex: function (x) { + return x.acsc(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).asin(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsch.js new file mode 100644 index 0000000..e107e5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/acsch.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAcsch = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'acsch'; +const dependencies = ['typed', 'BigNumber']; +const createAcsch = exports.createAcsch = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Calculate the inverse hyperbolic cosecant of a value, + * defined as `acsch(x) = asinh(1/x) = ln(1/x + sqrt(1/x^2 + 1))`. + * + * To avoid confusion with the matrix inverse hyperbolic cosecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.acsch(x) + * + * Examples: + * + * math.acsch(0.5) // returns 1.4436354751788103 + * + * See also: + * + * asech, acoth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccosecant of x + */ + return typed(name, { + number: _index.acschNumber, + Complex: function (x) { + return x.acsch(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).asinh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asec.js new file mode 100644 index 0000000..0c12783 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asec.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAsec = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'asec'; +const dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +const createAsec = exports.createAsec = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex, + BigNumber + } = _ref; + /** + * Calculate the inverse secant of a value. Defined as `asec(x) = acos(1/x)`. + * + * To avoid confusion with the matrix arcsecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.asec(x) + * + * Examples: + * + * math.asec(2) // returns 1.0471975511965979 + * math.asec(math.sec(1.5)) // returns 1.5 + * + * math.asec(0.5) // returns Complex 0 + 1.3169578969248166i + * + * See also: + * + * acos, acot, acsc + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc secant of x + */ + return typed(name, { + number: function (x) { + if (x <= -1 || x >= 1 || config.predictable) { + return (0, _index.asecNumber)(x); + } + return new Complex(x, 0).asec(); + }, + Complex: function (x) { + return x.asec(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).acos(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asech.js new file mode 100644 index 0000000..de716ce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asech.js @@ -0,0 +1,59 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAsech = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'asech'; +const dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +const createAsech = exports.createAsech = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex, + BigNumber + } = _ref; + /** + * Calculate the hyperbolic arcsecant of a value, + * defined as `asech(x) = acosh(1/x) = ln(sqrt(1/x^2 - 1) + 1/x)`. + * + * To avoid confusion with the matrix hyperbolic arcsecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.asech(x) + * + * Examples: + * + * math.asech(0.5) // returns 1.3169578969248166 + * + * See also: + * + * acsch, acoth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arcsecant of x + */ + return typed(name, { + number: function (x) { + if (x <= 1 && x >= -1 || config.predictable) { + const xInv = 1 / x; + if (xInv > 0 || config.predictable) { + return (0, _index.asechNumber)(x); + } + const ret = Math.sqrt(xInv * xInv - 1); + return new Complex(Math.log(ret - xInv), Math.PI); + } + return new Complex(x, 0).asech(); + }, + Complex: function (x) { + return x.asech(); + }, + BigNumber: function (x) { + return new BigNumber(1).div(x).acosh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asin.js new file mode 100644 index 0000000..123b3e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asin.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAsin = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'asin'; +const dependencies = ['typed', 'config', 'Complex']; +const createAsin = exports.createAsin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the inverse sine of a value. + * + * To avoid confusion with the matric arcsine, this function does not apply + * to matrices. + * + * Syntax: + * + * math.asin(x) + * + * Examples: + * + * math.asin(0.5) // returns number 0.5235987755982989 + * math.asin(math.sin(1.5)) // returns number ~1.5 + * + * math.asin(2) // returns Complex 1.5707963267948966 -1.3169578969248166i + * + * See also: + * + * sin, atan, acos + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc sine of x + */ + return typed(name, { + number: function (x) { + if (x >= -1 && x <= 1 || config.predictable) { + return Math.asin(x); + } else { + return new Complex(x, 0).asin(); + } + }, + Complex: function (x) { + return x.asin(); + }, + BigNumber: function (x) { + return x.asin(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asinh.js new file mode 100644 index 0000000..e0df5cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/asinh.js @@ -0,0 +1,46 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAsinh = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'asinh'; +const dependencies = ['typed']; +const createAsinh = exports.createAsinh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the hyperbolic arcsine of a value, + * defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`. + * + * To avoid confusion with the matrix hyperbolic arcsine, this function + * does not apply to matrices. + * + * Syntax: + * + * math.asinh(x) + * + * Examples: + * + * math.asinh(0.5) // returns 0.48121182505960347 + * + * See also: + * + * acosh, atanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arcsine of x + */ + return typed('asinh', { + number: _index.asinhNumber, + Complex: function (x) { + return x.asinh(); + }, + BigNumber: function (x) { + return x.asinh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan.js new file mode 100644 index 0000000..d1ef90d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAtan = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'atan'; +const dependencies = ['typed']; +const createAtan = exports.createAtan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the inverse tangent of a value. + * + * To avoid confusion with matrix arctangent, this function does not apply + * to matrices. + * + * Syntax: + * + * math.atan(x) + * + * Examples: + * + * math.atan(0.5) // returns number 0.4636476090008061 + * math.atan(2) // returns number 1.1071487177940904 + * math.atan(math.tan(1.5)) // returns number 1.5 + * + * See also: + * + * tan, asin, acos + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc tangent of x + */ + return typed('atan', { + number: function (x) { + return Math.atan(x); + }, + Complex: function (x) { + return x.atan(); + }, + BigNumber: function (x) { + return x.atan(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan2.js new file mode 100644 index 0000000..213382d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atan2.js @@ -0,0 +1,95 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAtan2 = void 0; +var _factory = require("../../utils/factory.js"); +var _matAlgo02xDS = require("../../type/matrix/utils/matAlgo02xDS0.js"); +var _matAlgo03xDSf = require("../../type/matrix/utils/matAlgo03xDSf.js"); +var _matAlgo09xS0Sf = require("../../type/matrix/utils/matAlgo09xS0Sf.js"); +var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js"); +var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'atan2'; +const dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'DenseMatrix', 'concat']; +const createAtan2 = exports.createAtan2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + equalScalar, + BigNumber, + DenseMatrix, + concat + } = _ref; + const matAlgo02xDS0 = (0, _matAlgo02xDS.createMatAlgo02xDS0)({ + typed, + equalScalar + }); + const matAlgo03xDSf = (0, _matAlgo03xDSf.createMatAlgo03xDSf)({ + typed + }); + const matAlgo09xS0Sf = (0, _matAlgo09xS0Sf.createMatAlgo09xS0Sf)({ + typed, + equalScalar + }); + const matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({ + typed, + equalScalar + }); + const matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({ + typed, + DenseMatrix + }); + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Calculate the inverse tangent function with two arguments, y/x. + * By providing two arguments, the right quadrant of the computed angle can be + * determined. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.atan2(y, x) + * + * Examples: + * + * math.atan2(2, 2) / math.pi // returns number 0.25 + * + * const angle = math.unit(60, 'deg') // returns Unit 60 deg + * const x = math.cos(angle) + * const y = math.sin(angle) + * + * math.atan(2) // returns number 1.1071487177940904 + * + * See also: + * + * tan, atan, sin, cos + * + * @param {number | Array | Matrix} y Second dimension + * @param {number | Array | Matrix} x First dimension + * @return {number | Array | Matrix} Four-quadrant inverse tangent + */ + return typed(name, { + 'number, number': Math.atan2, + // Complex numbers doesn't seem to have a reasonable implementation of + // atan2(). Even Matlab removed the support, after they only calculated + // the atan only on base of the real part of the numbers and ignored + // the imaginary. + + 'BigNumber, BigNumber': (y, x) => BigNumber.atan2(y, x) + }, matrixAlgorithmSuite({ + scalar: 'number | BigNumber', + SS: matAlgo09xS0Sf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atanh.js new file mode 100644 index 0000000..4f58486 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/atanh.js @@ -0,0 +1,53 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createAtanh = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'atanh'; +const dependencies = ['typed', 'config', 'Complex']; +const createAtanh = exports.createAtanh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config, + Complex + } = _ref; + /** + * Calculate the hyperbolic arctangent of a value, + * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`. + * + * To avoid confusion with the matrix hyperbolic arctangent, this function + * does not apply to matrices. + * + * Syntax: + * + * math.atanh(x) + * + * Examples: + * + * math.atanh(0.5) // returns 0.5493061443340549 + * + * See also: + * + * acosh, asinh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arctangent of x + */ + return typed(name, { + number: function (x) { + if (x <= 1 && x >= -1 || config.predictable) { + return (0, _index.atanhNumber)(x); + } + return new Complex(x, 0).atanh(); + }, + Complex: function (x) { + return x.atanh(); + }, + BigNumber: function (x) { + return x.atanh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cos.js new file mode 100644 index 0000000..a6eb83c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cos.js @@ -0,0 +1,50 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCos = void 0; +var _factory = require("../../utils/factory.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'cos'; +const dependencies = ['typed']; +const createCos = exports.createCos = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the cosine of a value. + * + * To avoid confusion with the matrix cosine, this function does not + * apply to matrices. + * + * Syntax: + * + * math.cos(x) + * + * Examples: + * + * math.cos(2) // returns number -0.4161468365471422 + * math.cos(math.pi / 4) // returns number 0.7071067811865475 + * math.cos(math.unit(180, 'deg')) // returns number -1 + * math.cos(math.unit(60, 'deg')) // returns number 0.5 + * + * const angle = 0.2 + * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1 + * + * See also: + * + * cos, tan + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Cosine of x + */ + return typed(name, { + number: Math.cos, + 'Complex | BigNumber': x => x.cos() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cosh.js new file mode 100644 index 0000000..1185bea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cosh.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCosh = void 0; +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +const name = 'cosh'; +const dependencies = ['typed']; +const createCosh = exports.createCosh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the hyperbolic cosine of a value, + * defined as `cosh(x) = 1/2 * (exp(x) + exp(-x))`. + * + * To avoid confusion with the matrix hyperbolic cosine, this function does + * not apply to matrices. + * + * Syntax: + * + * math.cosh(x) + * + * Examples: + * + * math.cosh(0.5) // returns number 1.1276259652063807 + * + * See also: + * + * sinh, tanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cosine of x + */ + return typed(name, { + number: _number.cosh, + 'Complex | BigNumber': x => x.cosh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cot.js new file mode 100644 index 0000000..3db5309 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/cot.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCot = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'cot'; +const dependencies = ['typed', 'BigNumber']; +const createCot = exports.createCot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the cotangent of a value. Defined as `cot(x) = 1 / tan(x)`. + * + * To avoid confusion with the matrix cotangent, this function does not + * apply to matrices. + * + * Syntax: + * + * math.cot(x) + * + * Examples: + * + * math.cot(2) // returns number -0.45765755436028577 + * 1 / math.tan(2) // returns number -0.45765755436028577 + * + * See also: + * + * tan, sec, csc + * + * @param {number | Complex | Unit | Array | Matrix} x Function input + * @return {number | Complex | Array | Matrix} Cotangent of x + */ + return typed(name, { + number: _index.cotNumber, + Complex: x => x.cot(), + BigNumber: x => new BigNumber(1).div(x.tan()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/coth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/coth.js new file mode 100644 index 0000000..6471792 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/coth.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCoth = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'coth'; +const dependencies = ['typed', 'BigNumber']; +const createCoth = exports.createCoth = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Calculate the hyperbolic cotangent of a value, + * defined as `coth(x) = 1 / tanh(x)`. + * + * To avoid confusion with the matrix hyperbolic cotangent, this function + * does not apply to matrices. + * + * Syntax: + * + * math.coth(x) + * + * Examples: + * + * // coth(x) = 1 / tanh(x) + * math.coth(2) // returns 1.0373147207275482 + * 1 / math.tanh(2) // returns 1.0373147207275482 + * + * See also: + * + * sinh, tanh, cosh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cotangent of x + */ + return typed(name, { + number: _index.cothNumber, + Complex: x => x.coth(), + BigNumber: x => new BigNumber(1).div(x.tanh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csc.js new file mode 100644 index 0000000..738de7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csc.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsc = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'csc'; +const dependencies = ['typed', 'BigNumber']; +const createCsc = exports.createCsc = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the cosecant of a value, defined as `csc(x) = 1/sin(x)`. + * + * To avoid confusion with the matrix cosecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.csc(x) + * + * Examples: + * + * math.csc(2) // returns number 1.099750170294617 + * 1 / math.sin(2) // returns number 1.099750170294617 + * + * See also: + * + * sin, sec, cot + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Cosecant of x + */ + return typed(name, { + number: _index.cscNumber, + Complex: x => x.csc(), + BigNumber: x => new BigNumber(1).div(x.sin()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csch.js new file mode 100644 index 0000000..e538e34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/csch.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCsch = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'csch'; +const dependencies = ['typed', 'BigNumber']; +const createCsch = exports.createCsch = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Calculate the hyperbolic cosecant of a value, + * defined as `csch(x) = 1 / sinh(x)`. + * + * To avoid confusion with the matrix hyperbolic cosecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.csch(x) + * + * Examples: + * + * // csch(x) = 1/ sinh(x) + * math.csch(0.5) // returns 1.9190347513349437 + * 1 / math.sinh(0.5) // returns 1.9190347513349437 + * + * See also: + * + * sinh, sech, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cosecant of x + */ + return typed(name, { + number: _index.cschNumber, + Complex: x => x.csch(), + BigNumber: x => new BigNumber(1).div(x.sinh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sec.js new file mode 100644 index 0000000..a6a4daa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sec.js @@ -0,0 +1,48 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSec = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'sec'; +const dependencies = ['typed', 'BigNumber']; +const createSec = exports.createSec = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the secant of a value, defined as `sec(x) = 1/cos(x)`. + * + * To avoid confusion with the matrix secant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.sec(x) + * + * Examples: + * + * math.sec(2) // returns number -2.4029979617223822 + * 1 / math.cos(2) // returns number -2.4029979617223822 + * + * See also: + * + * cos, csc, cot + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Secant of x + */ + return typed(name, { + number: _index.secNumber, + Complex: x => x.sec(), + BigNumber: x => new BigNumber(1).div(x.cos()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sech.js new file mode 100644 index 0000000..91d464a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sech.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSech = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'sech'; +const dependencies = ['typed', 'BigNumber']; +const createSech = exports.createSech = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Calculate the hyperbolic secant of a value, + * defined as `sech(x) = 1 / cosh(x)`. + * + * To avoid confusion with the matrix hyperbolic secant, this function does + * not apply to matrices. + * + * Syntax: + * + * math.sech(x) + * + * Examples: + * + * // sech(x) = 1/ cosh(x) + * math.sech(0.5) // returns 0.886818883970074 + * 1 / math.cosh(0.5) // returns 0.886818883970074 + * + * See also: + * + * cosh, csch, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic secant of x + */ + return typed(name, { + number: _index.sechNumber, + Complex: x => x.sech(), + BigNumber: x => new BigNumber(1).div(x.cosh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sin.js new file mode 100644 index 0000000..aad6735 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sin.js @@ -0,0 +1,50 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSin = void 0; +var _factory = require("../../utils/factory.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'sin'; +const dependencies = ['typed']; +const createSin = exports.createSin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the sine of a value. + * + * To avoid confusion with the matrix sine, this function does not apply + * to matrices. + * + * Syntax: + * + * math.sin(x) + * + * Examples: + * + * math.sin(2) // returns number 0.9092974268256813 + * math.sin(math.pi / 4) // returns number 0.7071067811865475 + * math.sin(math.unit(90, 'deg')) // returns number 1 + * math.sin(math.unit(30, 'deg')) // returns number 0.5 + * + * const angle = 0.2 + * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1 + * + * See also: + * + * cos, tan + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Sine of x + */ + return typed(name, { + number: Math.sin, + 'Complex | BigNumber': x => x.sin() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sinh.js new file mode 100644 index 0000000..871d8f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/sinh.js @@ -0,0 +1,41 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSinh = void 0; +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'sinh'; +const dependencies = ['typed']; +const createSinh = exports.createSinh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the hyperbolic sine of a value, + * defined as `sinh(x) = 1/2 * (exp(x) - exp(-x))`. + * + * To avoid confusion with the matrix hyperbolic sine, this function does + * not apply to matrices. + * + * Syntax: + * + * math.sinh(x) + * + * Examples: + * + * math.sinh(0.5) // returns number 0.5210953054937474 + * + * See also: + * + * cosh, tanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic sine of x + */ + return typed(name, { + number: _index.sinhNumber, + 'Complex | BigNumber': x => x.sinh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tan.js new file mode 100644 index 0000000..f9ae346 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tan.js @@ -0,0 +1,47 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTan = void 0; +var _factory = require("../../utils/factory.js"); +var _trigUnit = require("./trigUnit.js"); +const name = 'tan'; +const dependencies = ['typed']; +const createTan = exports.createTan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + const trigUnit = (0, _trigUnit.createTrigUnit)({ + typed + }); + + /** + * Calculate the tangent of a value. `tan(x)` is equal to `sin(x) / cos(x)`. + * + * To avoid confusion with the matrix tangent, this function does not apply + * to matrices. + * + * Syntax: + * + * math.tan(x) + * + * Examples: + * + * math.tan(0.5) // returns number 0.5463024898437905 + * math.sin(0.5) / math.cos(0.5) // returns number 0.5463024898437905 + * math.tan(math.pi / 4) // returns number 1 + * math.tan(math.unit(45, 'deg')) // returns number 1 + * + * See also: + * + * atan, sin, cos + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Tangent of x + */ + return typed(name, { + number: Math.tan, + 'Complex | BigNumber': x => x.tan() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tanh.js new file mode 100644 index 0000000..02e32f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/tanh.js @@ -0,0 +1,44 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTanh = void 0; +var _factory = require("../../utils/factory.js"); +var _number = require("../../utils/number.js"); +const name = 'tanh'; +const dependencies = ['typed']; +const createTanh = exports.createTanh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Calculate the hyperbolic tangent of a value, + * defined as `tanh(x) = (exp(2 * x) - 1) / (exp(2 * x) + 1)`. + * + * To avoid confusion with matrix hyperbolic tangent, this function does + * not apply to matrices. + * + * Syntax: + * + * math.tanh(x) + * + * Examples: + * + * // tanh(x) = sinh(x) / cosh(x) = 1 / coth(x) + * math.tanh(0.5) // returns 0.46211715726000974 + * math.sinh(0.5) / math.cosh(0.5) // returns 0.46211715726000974 + * 1 / math.coth(0.5) // returns 0.46211715726000974 + * + * See also: + * + * sinh, cosh, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic tangent of x + */ + return typed('tanh', { + number: _number.tanh, + 'Complex | BigNumber': x => x.tanh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/trigUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/trigUnit.js new file mode 100644 index 0000000..ae62dc5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/trigonometry/trigUnit.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTrigUnit = void 0; +var _factory = require("../../utils/factory.js"); +const createTrigUnit = exports.createTrigUnit = /* #__PURE__ */(0, _factory.factory)('trigUnit', ['typed'], _ref => { + let { + typed + } = _ref; + return { + Unit: typed.referToSelf(self => x => { + if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) { + throw new TypeError('Unit in function cot is no angle'); + } + return typed.find(self, x.valueType())(x.value); + }) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/unit/to.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/unit/to.js new file mode 100644 index 0000000..d660324 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/unit/to.js @@ -0,0 +1,52 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTo = void 0; +var _factory = require("../../utils/factory.js"); +var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js"); +const name = 'to'; +const dependencies = ['typed', 'matrix', 'concat']; +const createTo = exports.createTo = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix, + concat + } = _ref; + const matrixAlgorithmSuite = (0, _matrixAlgorithmSuite.createMatrixAlgorithmSuite)({ + typed, + matrix, + concat + }); + + /** + * Change the unit of a value. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.to(x, unit) + * + * Examples: + * + * math.to(math.unit('2 inch'), 'cm') // returns Unit 5.08 cm + * math.to(math.unit('2 inch'), math.unit('cm')) // returns Unit 5.08 cm + * math.to(math.unit(16, 'bytes'), 'bits') // returns Unit 128 bits + * + * See also: + * + * unit + * + * @param {Unit | Array | Matrix} x The unit to be converted. + * @param {Unit | Array | Matrix} unit New unit. Can be a string like "cm" + * or a unit without value. + * @return {Unit | Array | Matrix} value with changed, fixed unit. + */ + return typed(name, { + 'Unit, Unit | string': (x, unit) => x.to(unit) + }, matrixAlgorithmSuite({ + Ds: true + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/clone.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/clone.js new file mode 100644 index 0000000..4bc2548 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/clone.js @@ -0,0 +1,36 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createClone = void 0; +var _object = require("../../utils/object.js"); +var _factory = require("../../utils/factory.js"); +const name = 'clone'; +const dependencies = ['typed']; +const createClone = exports.createClone = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Clone an object. Will make a deep copy of the data. + * + * Syntax: + * + * math.clone(x) + * + * Examples: + * + * math.clone(3.5) // returns number 3.5 + * math.clone(math.complex('2-4i')) // returns Complex 2 - 4i + * math.clone(math.unit(45, 'deg')) // returns Unit 45 deg + * math.clone([[1, 2], [3, 4]]) // returns Array [[1, 2], [3, 4]] + * math.clone("hello world") // returns string "hello world" + * + * @param {*} x Object to be cloned + * @return {*} A clone of object x + */ + return typed(name, { + any: _object.clone + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/hasNumericValue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/hasNumericValue.js new file mode 100644 index 0000000..223171a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/hasNumericValue.js @@ -0,0 +1,56 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createHasNumericValue = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'hasNumericValue'; +const dependencies = ['typed', 'isNumeric']; +const createHasNumericValue = exports.createHasNumericValue = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + isNumeric + } = _ref; + /** + * Test whether a value is an numeric value. + * + * In case of a string, true is returned if the string contains a numeric value. + * + * Syntax: + * + * math.hasNumericValue(x) + * + * Examples: + * + * math.hasNumericValue(2) // returns true + * math.hasNumericValue('2') // returns true + * math.isNumeric('2') // returns false + * math.hasNumericValue(0) // returns true + * math.hasNumericValue(math.bignumber('500')) // returns true + * math.hasNumericValue(math.bigint('42')) // returns true + * math.hasNumericValue(42n) // returns true + * math.hasNumericValue(math.fraction(4)) // returns true + * math.hasNumericValue(math.complex('2-4i')) // returns false + * math.hasNumericValue(false) // returns true + * math.hasNumericValue([2.3, 'foo', false]) // returns [true, false, true] + * + * See also: + * + * isZero, isPositive, isNegative, isInteger, isNumeric + * + * @param {*} x Value to be tested + * @return {boolean} Returns true when `x` is a `number`, `BigNumber`, + * `Fraction`, `Boolean`, or a `String` containing number. Returns false for other types. + * Throws an error in case of unknown types. + */ + return typed(name, { + boolean: () => true, + string: function (x) { + return x.trim().length > 0 && !isNaN(Number(x)); + }, + any: function (x) { + return isNumeric(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isInteger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isInteger.js new file mode 100644 index 0000000..a1c82a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isInteger.js @@ -0,0 +1,60 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsInteger = void 0; +var _collection = require("../../utils/collection.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'isInteger'; +const dependencies = ['typed']; +const createIsInteger = exports.createIsInteger = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Test whether a value is an integer number. + * The function supports `number`, `BigNumber`, and `Fraction`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isInteger(x) + * + * Examples: + * + * math.isInteger(2) // returns true + * math.isInteger(0) // returns true + * math.isInteger(0.5) // returns false + * math.isInteger(math.bignumber(500)) // returns true + * math.isInteger(math.fraction(4)) // returns true + * math.isInteger('3') // returns true + * math.isInteger([3, 0.5, -2]) // returns [true, false, true] + * math.isInteger(math.complex('2-4i')) // throws an error + * + * See also: + * + * isNumeric, isPositive, isNegative, isZero + * + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` contains a numeric, integer value. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: _number.isInteger, + // TODO: what to do with isInteger(add(0.1, 0.2)) ? + + BigNumber: function (x) { + return x.isInt(); + }, + bigint: function (x) { + return true; + }, + Fraction: function (x) { + return x.d === 1 && isFinite(x.n); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNaN.js new file mode 100644 index 0000000..5c6678a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNaN.js @@ -0,0 +1,64 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsNaN = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +const name = 'isNaN'; +const dependencies = ['typed']; +const createIsNaN = exports.createIsNaN = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Test whether a value is NaN (not a number). + * The function supports types `number`, `BigNumber`, `Fraction`, `Unit` and `Complex`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNaN(x) + * + * Examples: + * + * math.isNaN(3) // returns false + * math.isNaN(NaN) // returns true + * math.isNaN(0) // returns false + * math.isNaN(math.bignumber(NaN)) // returns true + * math.isNaN(math.bignumber(0)) // returns false + * math.isNaN(math.fraction(-2, 5)) // returns false + * math.isNaN('-2') // returns false + * math.isNaN([2, 0, -3, NaN]) // returns [false, false, false, true] + * + * See also: + * + * isNumeric, isNegative, isPositive, isZero, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is NaN. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: _index.isNaNNumber, + BigNumber: function (x) { + return x.isNaN(); + }, + bigint: function (x) { + return false; + }, + Fraction: function (x) { + return false; + }, + Complex: function (x) { + return x.isNaN(); + }, + Unit: function (x) { + return Number.isNaN(x.value); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNegative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNegative.js new file mode 100644 index 0000000..d647d3e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNegative.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsNegative = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +const name = 'isNegative'; +const dependencies = ['typed', 'config']; +const createIsNegative = exports.createIsNegative = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config + } = _ref; + /** + * Test whether a value is negative: smaller than zero. + * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNegative(x) + * + * Examples: + * + * math.isNegative(3) // returns false + * math.isNegative(-2) // returns true + * math.isNegative(0) // returns false + * math.isNegative(-0) // returns false + * math.isNegative(math.bignumber(2)) // returns false + * math.isNegative(math.fraction(-2, 5)) // returns true + * math.isNegative('-2') // returns true + * math.isNegative([2, 0, -3]) // returns [false, false, true] + * + * See also: + * + * isNumeric, isPositive, isZero, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: x => (0, _number.nearlyEqual)(x, 0, config.relTol, config.absTol) ? false : (0, _index.isNegativeNumber)(x), + BigNumber: x => (0, _nearlyEqual.nearlyEqual)(x, new x.constructor(0), config.relTol, config.absTol) ? false : x.isNeg() && !x.isZero() && !x.isNaN(), + bigint: x => x < 0n, + Fraction: x => x.s < 0, + // It's enough to decide on the sign + + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNumeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNumeric.js new file mode 100644 index 0000000..49c2bea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isNumeric.js @@ -0,0 +1,50 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsNumeric = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'isNumeric'; +const dependencies = ['typed']; +const createIsNumeric = exports.createIsNumeric = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Test whether a value is an numeric value. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNumeric(x) + * + * Examples: + * + * math.isNumeric(2) // returns true + * math.isNumeric('2') // returns false + * math.hasNumericValue('2') // returns true + * math.isNumeric(0) // returns true + * math.isNumeric(math.bignumber('42')) // returns true + * math.isNumeric(math.bigint('42')) // returns true + * math.isNumeric(math.fraction(4)) // returns true + * math.isNumeric(math.complex('2-4i')) // returns false + * math.isNumeric([2.3, 'foo', false]) // returns [true, false, true] + * + * See also: + * + * isZero, isPositive, isNegative, isInteger, hasNumericValue + * + * @param {*} x Value to be tested + * @return {boolean} Returns true when `x` is a `number`, `BigNumber`, + * `Fraction`, or `boolean`. Returns false for other types. + * Throws an error in case of unknown types. + */ + return typed(name, { + 'number | BigNumber | bigint | Fraction | boolean': () => true, + 'Complex | Unit | string | null | undefined | Node': () => false, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPositive.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPositive.js new file mode 100644 index 0000000..a980c60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPositive.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsPositive = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +var _index = require("../../plain/number/index.js"); +var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js"); +var _number = require("../../utils/number.js"); +const name = 'isPositive'; +const dependencies = ['typed', 'config']; +const createIsPositive = exports.createIsPositive = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + config + } = _ref; + /** + * Test whether a value is positive: larger than zero. + * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isPositive(x) + * + * Examples: + * + * math.isPositive(3) // returns true + * math.isPositive(-2) // returns false + * math.isPositive(0) // returns false + * math.isPositive(-0) // returns false + * math.isPositive(0.5) // returns true + * math.isPositive(math.bignumber(2)) // returns true + * math.isPositive(math.fraction(-2, 5)) // returns false + * math.isPositive(math.fraction(1, 3)) // returns true + * math.isPositive('2') // returns true + * math.isPositive([2, 0, -3]) // returns [true, false, false] + * + * See also: + * + * isNumeric, isZero, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: x => (0, _number.nearlyEqual)(x, 0, config.relTol, config.absTol) ? false : (0, _index.isPositiveNumber)(x), + BigNumber: x => (0, _nearlyEqual.nearlyEqual)(x, new x.constructor(0), config.relTol, config.absTol) ? false : !x.isNeg() && !x.isZero() && !x.isNaN(), + bigint: x => x > 0n, + Fraction: x => x.s > 0 && x.n > 0, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPrime.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPrime.js new file mode 100644 index 0000000..0f48389 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isPrime.js @@ -0,0 +1,136 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsPrime = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'isPrime'; +const dependencies = ['typed']; +const createIsPrime = exports.createIsPrime = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Test whether a value is prime: has no divisors other than itself and one. + * The function supports type `number`, `bignumber`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isPrime(x) + * + * Examples: + * + * math.isPrime(3) // returns true + * math.isPrime(-2) // returns false + * math.isPrime(0) // returns false + * math.isPrime(-0) // returns false + * math.isPrime(0.5) // returns false + * math.isPrime('2') // returns true + * math.isPrime([2, 17, 100]) // returns [true, true, false] + * + * See also: + * + * isNumeric, isZero, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: function (x) { + if (x <= 3) { + return x > 1; + } + if (x % 2 === 0 || x % 3 === 0) { + return false; + } + for (let i = 5; i * i <= x; i += 6) { + if (x % i === 0 || x % (i + 2) === 0) { + return false; + } + } + return true; + }, + bigint: function (x) { + if (x <= 3n) { + return x > 1n; + } + if (x % 2n === 0n || x % 3n === 0n) { + return false; + } + for (let i = 5n; i * i <= x; i += 6n) { + if (x % i === 0n || x % (i + 2n) === 0n) { + return false; + } + } + return true; + }, + BigNumber: function (n) { + if (n.lte(3)) return n.gt(1); + if (n.mod(2).eq(0) || n.mod(3).eq(0)) return false; + if (n.lt(Math.pow(2, 32))) { + const x = n.toNumber(); + for (let i = 5; i * i <= x; i += 6) { + if (x % i === 0 || x % (i + 2) === 0) { + return false; + } + } + return true; + } + function modPow(base, exponent, modulus) { + // exponent can be huge, use non-recursive variant + let accumulator = 1; + while (!exponent.eq(0)) { + if (exponent.mod(2).eq(0)) { + exponent = exponent.div(2); + base = base.mul(base).mod(modulus); + } else { + exponent = exponent.sub(1); + accumulator = base.mul(accumulator).mod(modulus); + } + } + return accumulator; + } + + // https://en.wikipedia.org/wiki/Miller%E2%80%93Rabin_primality_test#Deterministic_variants + const Decimal = n.constructor.clone({ + precision: n.toFixed(0).length * 2 + }); + n = new Decimal(n); + let r = 0; + let d = n.sub(1); + while (d.mod(2).eq(0)) { + d = d.div(2); + r += 1; + } + let bases = null; + // https://en.wikipedia.org/wiki/Miller–Rabin_primality_test#Testing_against_small_sets_of_bases + if (n.lt('3317044064679887385961981')) { + bases = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41].filter(x => x < n); + } else { + const max = Math.min(n.toNumber() - 2, Math.floor(2 * Math.pow(n.toFixed(0).length * Math.log(10), 2))); + bases = []; + for (let i = 2; i <= max; i += 1) { + bases.push(max); + } + } + for (let i = 0; i < bases.length; i += 1) { + const a = bases[i]; + const adn = modPow(n.sub(n).add(a), d, n); + if (!adn.eq(1)) { + for (let i = 0, x = adn; !x.eq(n.sub(1)); i += 1, x = x.mul(x).mod(n)) { + if (i === r - 1) { + return false; + } + } + } + } + return true; + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isZero.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isZero.js new file mode 100644 index 0000000..500b9c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/isZero.js @@ -0,0 +1,55 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIsZero = void 0; +var _collection = require("../../utils/collection.js"); +var _factory = require("../../utils/factory.js"); +const name = 'isZero'; +const dependencies = ['typed', 'equalScalar']; +const createIsZero = exports.createIsZero = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Test whether a value is zero. + * The function can check for zero for types `number`, `BigNumber`, `Fraction`, + * `Complex`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isZero(x) + * + * Examples: + * + * math.isZero(0) // returns true + * math.isZero(2) // returns false + * math.isZero(0.5) // returns false + * math.isZero(math.bignumber(0)) // returns true + * math.isZero(math.fraction(0)) // returns true + * math.isZero(math.fraction(1,3)) // returns false + * math.isZero(math.complex('2 - 4i')) // returns false + * math.isZero(math.complex('0i')) // returns true + * math.isZero('0') // returns true + * math.isZero('2') // returns false + * math.isZero([2, 0, -3]) // returns [false, true, false] + * + * See also: + * + * isNumeric, isPositive, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Complex | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + 'number | BigNumber | Complex | Fraction': x => equalScalar(x, 0), + bigint: x => x === 0n, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/numeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/numeric.js new file mode 100644 index 0000000..5ba80a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/numeric.js @@ -0,0 +1,81 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNumeric = void 0; +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _noop = require("../../utils/noop.js"); +const name = 'numeric'; +const dependencies = ['number', '?bignumber', '?fraction']; +const createNumeric = exports.createNumeric = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + number, + bignumber, + fraction + } = _ref; + const validInputTypes = { + string: true, + number: true, + BigNumber: true, + Fraction: true + }; + + // Load the conversion functions for each output type + const validOutputTypes = { + number: x => number(x), + BigNumber: bignumber ? x => bignumber(x) : _noop.noBignumber, + bigint: x => BigInt(x), + Fraction: fraction ? x => fraction(x) : _noop.noFraction + }; + + /** + * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction. + * + * Syntax: + * + * math.numeric(x) + * + * Examples: + * + * math.numeric('4') // returns 4 + * math.numeric('4', 'number') // returns 4 + * math.numeric('4', 'bigint') // returns 4n + * math.numeric('4', 'BigNumber') // returns BigNumber 4 + * math.numeric('4', 'Fraction') // returns Fraction 4 + * math.numeric(4, 'Fraction') // returns Fraction 4 + * math.numeric(math.fraction(2, 5), 'number') // returns 0.4 + * + * See also: + * + * number, fraction, bignumber, bigint, string, format + * + * @param {string | number | BigNumber | bigint | Fraction } value + * A numeric value or a string containing a numeric value + * @param {string} outputType + * Desired numeric output type. + * Available values: 'number', 'BigNumber', or 'Fraction' + * @return {number | BigNumber | bigint | Fraction} + * Returns an instance of the numeric in the requested type + */ + return function numeric(value) { + let outputType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'number'; + let check = arguments.length > 2 ? arguments[2] : undefined; + if (check !== undefined) { + throw new SyntaxError('numeric() takes one or two arguments'); + } + const inputType = (0, _is.typeOf)(value); + if (!(inputType in validInputTypes)) { + throw new TypeError('Cannot convert ' + value + ' of type "' + inputType + '"; valid input types are ' + Object.keys(validInputTypes).join(', ')); + } + if (!(outputType in validOutputTypes)) { + throw new TypeError('Cannot convert ' + value + ' to type "' + outputType + '"; valid output types are ' + Object.keys(validOutputTypes).join(', ')); + } + if (outputType === inputType) { + return value; + } else { + return validOutputTypes[outputType](value); + } + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/typeOf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/typeOf.js new file mode 100644 index 0000000..701477e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/function/utils/typeOf.js @@ -0,0 +1,71 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createTypeOf = void 0; +var _factory = require("../../utils/factory.js"); +var _is = require("../../utils/is.js"); +const name = 'typeOf'; +const dependencies = ['typed']; +const createTypeOf = exports.createTypeOf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Determine the type of an entity. + * + * Syntax: + * + * math.typeOf(x) + * + * Examples: + * + * // This list is intended to include all relevant types, for testing + * // purposes: + * math.typeOf(3.5) // returns 'number' + * math.typeOf(42n) // returns 'bigint' + * math.typeOf(math.complex('2-4i')) // returns 'Complex' + * math.typeOf(math.unit('45 deg')) // returns 'Unit' + * math.typeOf('hello world') // returns 'string' + * math.typeOf(null) // returns 'null' + * math.typeOf(true) // returns 'boolean' + * math.typeOf([1, 2, 3]) // returns 'Array' + * math.typeOf(new Date()) // returns 'Date' + * math.typeOf(function () {}) // returns 'function' + * math.typeOf({a: 2, b: 3}) // returns 'Object' + * math.typeOf(/a regexp/) // returns 'RegExp' + * math.typeOf(undefined) // returns 'undefined' + * math.typeOf(math.bignumber('23e99')) // returns 'BigNumber' + * math.typeOf(math.chain(2)) // returns 'Chain' + * math.typeOf(math.fraction(1, 3)) // returns 'Fraction' + * math.typeOf(math.help('sqrt')) // returns 'Help' + * math.typeOf(math.index(1, 3)) // returns 'Index' + * math.typeOf(math.matrix([[1],[3]])) // returns 'DenseMatrix' + * math.typeOf(math.matrix([],'sparse')) // returns 'SparseMatrix' + * math.typeOf(new math.Range(0, 10)) // returns 'Range' + * math.typeOf(math.evaluate('a=2\na')) // returns 'ResultSet' + * math.typeOf(math.parse('A[2]')) // returns 'AccessorNode' + * math.typeOf(math.parse('[1,2,3]')) // returns 'ArrayNode' + * math.typeOf(math.parse('x=2')) // returns 'AssignmentNode' + * math.typeOf(math.parse('a=2; b=3')) // returns 'BlockNode' + * math.typeOf(math.parse('x<0?-1:1')) // returns 'ConditionalNode' + * math.typeOf(math.parse('2.3')) // returns 'ConstantNode' + * math.typeOf(math.parse('f(x)=x^2')) // returns 'FunctionAssignmentNode' + * math.typeOf(math.parse('sqrt(4)')) // returns 'FunctionNode' + * math.typeOf(math.parse('A[2]').index) // returns 'IndexNode' + * math.typeOf(math.parse('{a:2}')) // returns 'ObjectNode' + * math.typeOf(math.parse('(2+3)')) // returns 'ParenthesisNode' + * math.typeOf(math.parse('1:10')) // returns 'RangeNode' + * math.typeOf(math.parse('a + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy + * of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/index.js new file mode 100644 index 0000000..4b3a856 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/index.js @@ -0,0 +1,16 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _mainAny = require("./entry/mainAny.js"); +Object.keys(_mainAny).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _mainAny[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _mainAny[key]; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/replacer.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/replacer.js new file mode 100644 index 0000000..811a8b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/replacer.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createReplacer = void 0; +var _factory = require("../utils/factory.js"); +const name = 'replacer'; +const dependencies = []; +const createReplacer = exports.createReplacer = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * Stringify data types into their JSON representation. + * Most data types can be serialized using their `.toJSON` method, + * but not all, for example the number `Infinity`. For these cases you have + * to use the replacer. Example usage: + * + * JSON.stringify([2, Infinity], math.replacer) + * + * @param {string} key + * @param {*} value + * @returns {*} Returns the replaced object + */ + return function replacer(key, value) { + // the numeric values Infinitiy, -Infinity, and NaN cannot be serialized to JSON + if (typeof value === 'number' && (!isFinite(value) || isNaN(value))) { + return { + mathjs: 'number', + value: String(value) + }; + } + if (typeof value === 'bigint') { + return { + mathjs: 'bigint', + value: String(value) + }; + } + return value; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/reviver.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/reviver.js new file mode 100644 index 0000000..3e49405 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/json/reviver.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createReviver = void 0; +var _factory = require("../utils/factory.js"); +const name = 'reviver'; +const dependencies = ['classes']; +const createReviver = exports.createReviver = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + classes + } = _ref; + /** + * Instantiate mathjs data types from their JSON representation + * @param {string} key + * @param {*} value + * @returns {*} Returns the revived object + */ + return function reviver(key, value) { + const constructor = classes[value && value.mathjs]; + if (constructor && typeof constructor.fromJSON === 'function') { + return constructor.fromJSON(value); + } + return value; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/number.js new file mode 100644 index 0000000..8272a21 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/number.js @@ -0,0 +1,16 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _mainNumber = require("./entry/mainNumber.js"); +Object.keys(_mainNumber).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _mainNumber[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _mainNumber[key]; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/package.json new file mode 100644 index 0000000..5bbefff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/package.json @@ -0,0 +1,3 @@ +{ + "type": "commonjs" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/arithmetic.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/arithmetic.js new file mode 100644 index 0000000..cd66883 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/arithmetic.js @@ -0,0 +1,32 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.absBigNumber = absBigNumber; +exports.addBigNumber = addBigNumber; +exports.divideBigNumber = divideBigNumber; +exports.multiplyBigNumber = multiplyBigNumber; +exports.subtractBigNumber = subtractBigNumber; +const signature1 = 'BigNumber'; +const signature2 = 'BigNumber, BigNumber'; +function absBigNumber(a) { + return a.abs(); +} +absBigNumber.signature = signature1; +function addBigNumber(a, b) { + return a.add(b); +} +addBigNumber.signature = signature2; +function subtractBigNumber(a, b) { + return a.sub(b); +} +subtractBigNumber.signature = signature2; +function multiplyBigNumber(a, b) { + return a.mul(b); +} +multiplyBigNumber.signature = signature2; +function divideBigNumber(a, b) { + return a.div(b); +} +divideBigNumber.signature = signature2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/index.js new file mode 100644 index 0000000..7b60254 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/bignumber/index.js @@ -0,0 +1,29 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _exportNames = { + bignumber: true +}; +exports.bignumber = bignumber; +var _decimal = _interopRequireDefault(require("decimal.js")); +var _arithmetic = require("./arithmetic.js"); +Object.keys(_arithmetic).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return; + if (key in exports && exports[key] === _arithmetic[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _arithmetic[key]; + } + }); +}); +// TODO: this is ugly. Instead, be able to pass your own isBigNumber function to typed? +const BigNumber = _decimal.default.clone(); +BigNumber.prototype.isBigNumber = true; +function bignumber(x) { + return new BigNumber(x); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/arithmetic.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/arithmetic.js new file mode 100644 index 0000000..1322dbf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/arithmetic.js @@ -0,0 +1,334 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.absNumber = absNumber; +exports.addNumber = addNumber; +exports.cbrtNumber = cbrtNumber; +exports.cubeNumber = cubeNumber; +exports.divideNumber = divideNumber; +exports.expNumber = expNumber; +exports.expm1Number = expm1Number; +exports.gcdNumber = gcdNumber; +exports.lcmNumber = lcmNumber; +exports.log10Number = log10Number; +exports.log1pNumber = log1pNumber; +exports.log2Number = log2Number; +exports.logNumber = logNumber; +exports.modNumber = modNumber; +exports.multiplyNumber = multiplyNumber; +exports.normNumber = normNumber; +exports.nthRootNumber = nthRootNumber; +exports.powNumber = powNumber; +exports.roundNumber = roundNumber; +exports.signNumber = signNumber; +exports.sqrtNumber = sqrtNumber; +exports.squareNumber = squareNumber; +exports.subtractNumber = subtractNumber; +exports.unaryMinusNumber = unaryMinusNumber; +exports.unaryPlusNumber = unaryPlusNumber; +exports.xgcdNumber = xgcdNumber; +var _number = require("../../utils/number.js"); +const n1 = 'number'; +const n2 = 'number, number'; +function absNumber(a) { + return Math.abs(a); +} +absNumber.signature = n1; +function addNumber(a, b) { + return a + b; +} +addNumber.signature = n2; +function subtractNumber(a, b) { + return a - b; +} +subtractNumber.signature = n2; +function multiplyNumber(a, b) { + return a * b; +} +multiplyNumber.signature = n2; +function divideNumber(a, b) { + return a / b; +} +divideNumber.signature = n2; +function unaryMinusNumber(x) { + return -x; +} +unaryMinusNumber.signature = n1; +function unaryPlusNumber(x) { + return x; +} +unaryPlusNumber.signature = n1; +function cbrtNumber(x) { + return (0, _number.cbrt)(x); +} +cbrtNumber.signature = n1; +function cubeNumber(x) { + return x * x * x; +} +cubeNumber.signature = n1; +function expNumber(x) { + return Math.exp(x); +} +expNumber.signature = n1; +function expm1Number(x) { + return (0, _number.expm1)(x); +} +expm1Number.signature = n1; + +/** + * Calculate gcd for numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the greatest common denominator of a and b + */ +function gcdNumber(a, b) { + if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + let r; + while (b !== 0) { + r = a % b; + a = b; + b = r; + } + return a < 0 ? -a : a; +} +gcdNumber.signature = n2; + +/** + * Calculate lcm for two numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the least common multiple of a and b + */ +function lcmNumber(a, b) { + if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) { + throw new Error('Parameters in function lcm must be integer numbers'); + } + if (a === 0 || b === 0) { + return 0; + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + // evaluate lcm here inline to reduce overhead + let t; + const prod = a * b; + while (b !== 0) { + t = b; + b = a % t; + a = t; + } + return Math.abs(prod / a); +} +lcmNumber.signature = n2; + +/** + * Calculate the logarithm of a value, optionally to a given base. + * @param {number} x + * @param {number | null | undefined} base + * @return {number} + */ +function logNumber(x, y) { + if (y) { + return Math.log(x) / Math.log(y); + } + return Math.log(x); +} + +/** + * Calculate the 10-base logarithm of a number + * @param {number} x + * @return {number} + */ +function log10Number(x) { + return (0, _number.log10)(x); +} +log10Number.signature = n1; + +/** + * Calculate the 2-base logarithm of a number + * @param {number} x + * @return {number} + */ +function log2Number(x) { + return (0, _number.log2)(x); +} +log2Number.signature = n1; + +/** + * Calculate the natural logarithm of a `number+1` + * @param {number} x + * @returns {number} + */ +function log1pNumber(x) { + return (0, _number.log1p)(x); +} +log1pNumber.signature = n1; + +/** + * Calculate the modulus of two numbers + * @param {number} x + * @param {number} y + * @returns {number} res + * @private + */ +function modNumber(x, y) { + // We don't use JavaScript's % operator here as this doesn't work + // correctly for x < 0 and x === 0 + // see https://en.wikipedia.org/wiki/Modulo_operation + return y === 0 ? x : x - y * Math.floor(x / y); +} +modNumber.signature = n2; + +/** + * Calculate the nth root of a, solve x^root == a + * http://rosettacode.org/wiki/Nth_root#JavaScript + * @param {number} a + * @param {number} [2] root + * @private + */ +function nthRootNumber(a) { + let root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 2; + const inv = root < 0; + if (inv) { + root = -root; + } + if (root === 0) { + throw new Error('Root must be non-zero'); + } + if (a < 0 && Math.abs(root) % 2 !== 1) { + throw new Error('Root must be odd when a is negative.'); + } + + // edge cases zero and infinity + if (a === 0) { + return inv ? Infinity : 0; + } + if (!isFinite(a)) { + return inv ? 0 : a; + } + let x = Math.pow(Math.abs(a), 1 / root); + // If a < 0, we require that root is an odd integer, + // so (-1) ^ (1/root) = -1 + x = a < 0 ? -x : x; + return inv ? 1 / x : x; + + // Very nice algorithm, but fails with nthRoot(-2, 3). + // Newton's method has some well-known problems at times: + // https://en.wikipedia.org/wiki/Newton%27s_method#Failure_analysis + /* + let x = 1 // Initial guess + let xPrev = 1 + let i = 0 + const iMax = 10000 + do { + const delta = (a / Math.pow(x, root - 1) - x) / root + xPrev = x + x = x + delta + i++ + } + while (xPrev !== x && i < iMax) + if (xPrev !== x) { + throw new Error('Function nthRoot failed to converge') + } + return inv ? 1 / x : x + */ +} +function signNumber(x) { + return (0, _number.sign)(x); +} +signNumber.signature = n1; +function sqrtNumber(x) { + return Math.sqrt(x); +} +sqrtNumber.signature = n1; +function squareNumber(x) { + return x * x; +} +squareNumber.signature = n1; + +/** + * Calculate xgcd for two numbers + * @param {number} a + * @param {number} b + * @return {number} result + * @private + */ +function xgcdNumber(a, b) { + // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm + let t; // used to swap two variables + let q; // quotient + let r; // remainder + let x = 0; + let lastx = 1; + let y = 1; + let lasty = 0; + if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) { + throw new Error('Parameters in function xgcd must be integer numbers'); + } + while (b) { + q = Math.floor(a / b); + r = a - q * b; + t = x; + x = lastx - q * x; + lastx = t; + t = y; + y = lasty - q * y; + lasty = t; + a = b; + b = r; + } + let res; + if (a < 0) { + res = [-a, -lastx, -lasty]; + } else { + res = [a, a ? lastx : 0, lasty]; + } + return res; +} +xgcdNumber.signature = n2; + +/** + * Calculates the power of x to y, x^y, for two numbers. + * @param {number} x + * @param {number} y + * @return {number} res + */ +function powNumber(x, y) { + // x^Infinity === 0 if -1 < x < 1 + // A real number 0 is returned instead of complex(0) + if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) { + return 0; + } + return Math.pow(x, y); +} +powNumber.signature = n2; + +/** + * round a number to the given number of decimals, or to zero if decimals is + * not provided + * @param {number} value + * @param {number} decimals number of decimals, between 0 and 15 (0 by default) + * @return {number} roundedValue + */ +function roundNumber(value) { + let decimals = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; + if (!(0, _number.isInteger)(decimals) || decimals < 0 || decimals > 15) { + throw new Error('Number of decimals in function round must be an integer from 0 to 15 inclusive'); + } + return parseFloat((0, _number.toFixed)(value, decimals)); +} + +/** + * Calculate the norm of a number, the absolute value. + * @param {number} x + * @return {number} + */ +function normNumber(x) { + return Math.abs(x); +} +normNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/bitwise.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/bitwise.js new file mode 100644 index 0000000..36e24cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/bitwise.js @@ -0,0 +1,64 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndNumber = bitAndNumber; +exports.bitNotNumber = bitNotNumber; +exports.bitOrNumber = bitOrNumber; +exports.bitXorNumber = bitXorNumber; +exports.leftShiftNumber = leftShiftNumber; +exports.rightArithShiftNumber = rightArithShiftNumber; +exports.rightLogShiftNumber = rightLogShiftNumber; +var _number = require("../../utils/number.js"); +const n1 = 'number'; +const n2 = 'number, number'; +function bitAndNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function bitAnd'); + } + return x & y; +} +bitAndNumber.signature = n2; +function bitNotNumber(x) { + if (!(0, _number.isInteger)(x)) { + throw new Error('Integer expected in function bitNot'); + } + return ~x; +} +bitNotNumber.signature = n1; +function bitOrNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function bitOr'); + } + return x | y; +} +bitOrNumber.signature = n2; +function bitXorNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function bitXor'); + } + return x ^ y; +} +bitXorNumber.signature = n2; +function leftShiftNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function leftShift'); + } + return x << y; +} +leftShiftNumber.signature = n2; +function rightArithShiftNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function rightArithShift'); + } + return x >> y; +} +rightArithShiftNumber.signature = n2; +function rightLogShiftNumber(x, y) { + if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) { + throw new Error('Integers expected in function rightLogShift'); + } + return x >>> y; +} +rightLogShiftNumber.signature = n2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/combinations.js new file mode 100644 index 0000000..5a66705 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/combinations.js @@ -0,0 +1,39 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.combinationsNumber = combinationsNumber; +var _number = require("../../utils/number.js"); +var _product = require("../../utils/product.js"); +function combinationsNumber(n, k) { + if (!(0, _number.isInteger)(n) || n < 0) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (!(0, _number.isInteger)(k) || k < 0) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (k > n) { + throw new TypeError('k must be less than or equal to n'); + } + const nMinusk = n - k; + let answer = 1; + const firstnumerator = k < nMinusk ? nMinusk + 1 : k + 1; + let nextdivisor = 2; + const lastdivisor = k < nMinusk ? k : nMinusk; + // balance multiplications and divisions to try to keep intermediate values + // in exact-integer range as long as possible + for (let nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) { + answer *= nextnumerator; + while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) { + answer /= nextdivisor; + ++nextdivisor; + } + } + // for big n, k, floating point may have caused weirdness in remainder + if (nextdivisor <= lastdivisor) { + answer /= (0, _product.product)(nextdivisor, lastdivisor); + } + return answer; +} +combinationsNumber.signature = 'number, number'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/constants.js new file mode 100644 index 0000000..e177333 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/constants.js @@ -0,0 +1,10 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.tau = exports.pi = exports.phi = exports.e = void 0; +const pi = exports.pi = Math.PI; +const tau = exports.tau = 2 * Math.PI; +const e = exports.e = Math.E; +const phi = exports.phi = 1.6180339887498948; // eslint-disable-line no-loss-of-precision \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/index.js new file mode 100644 index 0000000..118255a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/index.js @@ -0,0 +1,104 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var _arithmetic = require("./arithmetic.js"); +Object.keys(_arithmetic).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _arithmetic[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _arithmetic[key]; + } + }); +}); +var _bitwise = require("./bitwise.js"); +Object.keys(_bitwise).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _bitwise[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _bitwise[key]; + } + }); +}); +var _combinations = require("./combinations.js"); +Object.keys(_combinations).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _combinations[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _combinations[key]; + } + }); +}); +var _constants = require("./constants.js"); +Object.keys(_constants).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _constants[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _constants[key]; + } + }); +}); +var _logical = require("./logical.js"); +Object.keys(_logical).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _logical[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _logical[key]; + } + }); +}); +var _relational = require("./relational.js"); +Object.keys(_relational).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _relational[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _relational[key]; + } + }); +}); +var _probability = require("./probability.js"); +Object.keys(_probability).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _probability[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _probability[key]; + } + }); +}); +var _trigonometry = require("./trigonometry.js"); +Object.keys(_trigonometry).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _trigonometry[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _trigonometry[key]; + } + }); +}); +var _utils = require("./utils.js"); +Object.keys(_utils).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _utils[key]) return; + Object.defineProperty(exports, key, { + enumerable: true, + get: function () { + return _utils[key]; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/logical.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/logical.js new file mode 100644 index 0000000..b1eb72a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/logical.js @@ -0,0 +1,27 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.andNumber = andNumber; +exports.notNumber = notNumber; +exports.orNumber = orNumber; +exports.xorNumber = xorNumber; +const n1 = 'number'; +const n2 = 'number, number'; +function notNumber(x) { + return !x; +} +notNumber.signature = n1; +function orNumber(x, y) { + return !!(x || y); +} +orNumber.signature = n2; +function xorNumber(x, y) { + return !!x !== !!y; +} +xorNumber.signature = n2; +function andNumber(x, y) { + return !!(x && y); +} +andNumber.signature = n2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/probability.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/probability.js new file mode 100644 index 0000000..72c7f7e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/probability.js @@ -0,0 +1,85 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.gammaG = void 0; +exports.gammaNumber = gammaNumber; +exports.lgammaN = exports.lgammaG = exports.gammaP = void 0; +exports.lgammaNumber = lgammaNumber; +exports.lnSqrt2PI = exports.lgammaSeries = void 0; +var _number = require("../../utils/number.js"); +var _product = require("../../utils/product.js"); +/* eslint-disable no-loss-of-precision */ + +function gammaNumber(n) { + let x; + if ((0, _number.isInteger)(n)) { + if (n <= 0) { + return isFinite(n) ? Infinity : NaN; + } + if (n > 171) { + return Infinity; // Will overflow + } + return (0, _product.product)(1, n - 1); + } + if (n < 0.5) { + return Math.PI / (Math.sin(Math.PI * n) * gammaNumber(1 - n)); + } + if (n >= 171.35) { + return Infinity; // will overflow + } + if (n > 85.0) { + // Extended Stirling Approx + const twoN = n * n; + const threeN = twoN * n; + const fourN = threeN * n; + const fiveN = fourN * n; + return Math.sqrt(2 * Math.PI / n) * Math.pow(n / Math.E, n) * (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) - 571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) + 5246819 / (75246796800 * fiveN * n)); + } + --n; + x = gammaP[0]; + for (let i = 1; i < gammaP.length; ++i) { + x += gammaP[i] / (n + i); + } + const t = n + gammaG + 0.5; + return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x; +} +gammaNumber.signature = 'number'; + +// TODO: comment on the variables g and p + +const gammaG = exports.gammaG = 4.7421875; +const gammaP = exports.gammaP = [0.99999999999999709182, 57.156235665862923517, -59.597960355475491248, 14.136097974741747174, -0.49191381609762019978, 0.33994649984811888699e-4, 0.46523628927048575665e-4, -0.98374475304879564677e-4, 0.15808870322491248884e-3, -0.21026444172410488319e-3, 0.21743961811521264320e-3, -0.16431810653676389022e-3, 0.84418223983852743293e-4, -0.26190838401581408670e-4, 0.36899182659531622704e-5]; + +// lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code + +// log(2 * pi) / 2 +const lnSqrt2PI = exports.lnSqrt2PI = 0.91893853320467274178; +const lgammaG = exports.lgammaG = 5; // Lanczos parameter "g" +const lgammaN = exports.lgammaN = 7; // Range of coefficients "n" + +const lgammaSeries = exports.lgammaSeries = [1.000000000190015, 76.18009172947146, -86.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5]; +function lgammaNumber(n) { + if (n < 0) return NaN; + if (n === 0) return Infinity; + if (!isFinite(n)) return n; + if (n < 0.5) { + // Use Euler's reflection formula: + // gamma(z) = PI / (sin(PI * z) * gamma(1 - z)) + return Math.log(Math.PI / Math.sin(Math.PI * n)) - lgammaNumber(1 - n); + } + + // Compute the logarithm of the Gamma function using the Lanczos method + + n = n - 1; + const base = n + lgammaG + 0.5; // Base of the Lanczos exponential + let sum = lgammaSeries[0]; + + // We start with the terms that have the smallest coefficients and largest denominator + for (let i = lgammaN - 1; i >= 1; i--) { + sum += lgammaSeries[i] / (n + i); + } + return lnSqrt2PI + (n + 0.5) * Math.log(base) - base + Math.log(sum); +} +lgammaNumber.signature = 'number'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/relational.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/relational.js new file mode 100644 index 0000000..9a390c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/relational.js @@ -0,0 +1 @@ +"use strict"; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/trigonometry.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/trigonometry.js new file mode 100644 index 0000000..70c1860 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/trigonometry.js @@ -0,0 +1,142 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.acosNumber = acosNumber; +exports.acoshNumber = acoshNumber; +exports.acotNumber = acotNumber; +exports.acothNumber = acothNumber; +exports.acscNumber = acscNumber; +exports.acschNumber = acschNumber; +exports.asecNumber = asecNumber; +exports.asechNumber = asechNumber; +exports.asinNumber = asinNumber; +exports.asinhNumber = asinhNumber; +exports.atan2Number = atan2Number; +exports.atanNumber = atanNumber; +exports.atanhNumber = atanhNumber; +exports.cosNumber = cosNumber; +exports.coshNumber = coshNumber; +exports.cotNumber = cotNumber; +exports.cothNumber = cothNumber; +exports.cscNumber = cscNumber; +exports.cschNumber = cschNumber; +exports.secNumber = secNumber; +exports.sechNumber = sechNumber; +exports.sinNumber = sinNumber; +exports.sinhNumber = sinhNumber; +exports.tanNumber = tanNumber; +exports.tanhNumber = tanhNumber; +var _number = require("../../utils/number.js"); +const n1 = 'number'; +const n2 = 'number, number'; +function acosNumber(x) { + return Math.acos(x); +} +acosNumber.signature = n1; +function acoshNumber(x) { + return (0, _number.acosh)(x); +} +acoshNumber.signature = n1; +function acotNumber(x) { + return Math.atan(1 / x); +} +acotNumber.signature = n1; +function acothNumber(x) { + return isFinite(x) ? (Math.log((x + 1) / x) + Math.log(x / (x - 1))) / 2 : 0; +} +acothNumber.signature = n1; +function acscNumber(x) { + return Math.asin(1 / x); +} +acscNumber.signature = n1; +function acschNumber(x) { + const xInv = 1 / x; + return Math.log(xInv + Math.sqrt(xInv * xInv + 1)); +} +acschNumber.signature = n1; +function asecNumber(x) { + return Math.acos(1 / x); +} +asecNumber.signature = n1; +function asechNumber(x) { + const xInv = 1 / x; + const ret = Math.sqrt(xInv * xInv - 1); + return Math.log(ret + xInv); +} +asechNumber.signature = n1; +function asinNumber(x) { + return Math.asin(x); +} +asinNumber.signature = n1; +function asinhNumber(x) { + return (0, _number.asinh)(x); +} +asinhNumber.signature = n1; +function atanNumber(x) { + return Math.atan(x); +} +atanNumber.signature = n1; +function atan2Number(y, x) { + return Math.atan2(y, x); +} +atan2Number.signature = n2; +function atanhNumber(x) { + return (0, _number.atanh)(x); +} +atanhNumber.signature = n1; +function cosNumber(x) { + return Math.cos(x); +} +cosNumber.signature = n1; +function coshNumber(x) { + return (0, _number.cosh)(x); +} +coshNumber.signature = n1; +function cotNumber(x) { + return 1 / Math.tan(x); +} +cotNumber.signature = n1; +function cothNumber(x) { + const e = Math.exp(2 * x); + return (e + 1) / (e - 1); +} +cothNumber.signature = n1; +function cscNumber(x) { + return 1 / Math.sin(x); +} +cscNumber.signature = n1; +function cschNumber(x) { + // consider values close to zero (+/-) + if (x === 0) { + return Number.POSITIVE_INFINITY; + } else { + return Math.abs(2 / (Math.exp(x) - Math.exp(-x))) * (0, _number.sign)(x); + } +} +cschNumber.signature = n1; +function secNumber(x) { + return 1 / Math.cos(x); +} +secNumber.signature = n1; +function sechNumber(x) { + return 2 / (Math.exp(x) + Math.exp(-x)); +} +sechNumber.signature = n1; +function sinNumber(x) { + return Math.sin(x); +} +sinNumber.signature = n1; +function sinhNumber(x) { + return (0, _number.sinh)(x); +} +sinhNumber.signature = n1; +function tanNumber(x) { + return Math.tan(x); +} +tanNumber.signature = n1; +function tanhNumber(x) { + return (0, _number.tanh)(x); +} +tanhNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/utils.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/utils.js new file mode 100644 index 0000000..225a74d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/plain/number/utils.js @@ -0,0 +1,32 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isIntegerNumber = isIntegerNumber; +exports.isNaNNumber = isNaNNumber; +exports.isNegativeNumber = isNegativeNumber; +exports.isPositiveNumber = isPositiveNumber; +exports.isZeroNumber = isZeroNumber; +var _number = require("../../utils/number.js"); +const n1 = 'number'; +function isIntegerNumber(x) { + return (0, _number.isInteger)(x); +} +isIntegerNumber.signature = n1; +function isNegativeNumber(x) { + return x < 0; +} +isNegativeNumber.signature = n1; +function isPositiveNumber(x) { + return x > 0; +} +isPositiveNumber.signature = n1; +function isZeroNumber(x) { + return x === 0; +} +isZeroNumber.signature = n1; +function isNaNNumber(x) { + return Number.isNaN(x); +} +isNaNNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bigint.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bigint.js new file mode 100644 index 0000000..7dbbc1f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bigint.js @@ -0,0 +1,71 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBigint = void 0; +var _factory = require("../utils/factory.js"); +var _collection = require("../utils/collection.js"); +const name = 'bigint'; +const dependencies = ['typed']; +const createBigint = exports.createBigint = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Create a bigint or convert a string, boolean, or unit to a bigint. + * When value is a matrix, all elements will be converted to bigint. + * + * Syntax: + * + * math.bigint(value) + * + * Examples: + * + * math.bigint(2) // returns 2n + * math.bigint('123') // returns 123n + * math.bigint(true) // returns 1n + * math.bigint([true, false, true, true]) // returns [1n, 0n, 1n, 1n] + * + * See also: + * + * number, bignumber, boolean, complex, index, matrix, string, unit + * + * @param {string | number | BigNumber | bigint | Fraction | boolean | Array | Matrix | null} [value] Value to be converted + * @return {bigint | Array | Matrix} The created bigint + */ + const bigint = typed('bigint', { + '': function () { + return 0n; + }, + bigint: function (x) { + return x; + }, + number: function (x) { + return BigInt(x.toFixed()); + }, + BigNumber: function (x) { + return BigInt(x.round().toString()); + }, + Fraction: function (x) { + return BigInt(x.valueOf().toFixed()); + }, + 'string | boolean': function (x) { + return BigInt(x); + }, + null: function (x) { + return 0n; + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); + + // reviver function to parse a JSON object like: + // + // {"mathjs":"bigint","value":"123"} + // + // into a bigint 123n + bigint.fromJSON = function (json) { + return BigInt(json.value); + }; + return bigint; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/BigNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/BigNumber.js new file mode 100644 index 0000000..2681d08 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/BigNumber.js @@ -0,0 +1,64 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBigNumberClass = void 0; +var _decimal = _interopRequireDefault(require("decimal.js")); +var _factory = require("../../utils/factory.js"); +const name = 'BigNumber'; +const dependencies = ['?on', 'config']; +const createBigNumberClass = exports.createBigNumberClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + on, + config + } = _ref; + const BigNumber = _decimal.default.clone({ + precision: config.precision, + modulo: _decimal.default.EUCLID + }); + BigNumber.prototype = Object.create(BigNumber.prototype); + + /** + * Attach type information + */ + BigNumber.prototype.type = 'BigNumber'; + BigNumber.prototype.isBigNumber = true; + + /** + * Get a JSON representation of a BigNumber containing + * type information + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "BigNumber", "value": "0.2"}` + */ + BigNumber.prototype.toJSON = function () { + return { + mathjs: 'BigNumber', + value: this.toString() + }; + }; + + /** + * Instantiate a BigNumber from a JSON object + * @param {Object} json a JSON object structured as: + * `{"mathjs": "BigNumber", "value": "0.2"}` + * @return {BigNumber} + */ + BigNumber.fromJSON = function (json) { + return new BigNumber(json.value); + }; + if (on) { + // listen for changed in the configuration, automatically apply changed precision + on('config', function (curr, prev) { + if (curr.precision !== prev.precision) { + BigNumber.config({ + precision: curr.precision + }); + } + }); + } + return BigNumber; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/function/bignumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/function/bignumber.js new file mode 100644 index 0000000..823859a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/bignumber/function/bignumber.js @@ -0,0 +1,88 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBignumber = void 0; +var _factory = require("../../../utils/factory.js"); +var _collection = require("../../../utils/collection.js"); +const name = 'bignumber'; +const dependencies = ['typed', 'BigNumber']; +const createBignumber = exports.createBignumber = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + BigNumber + } = _ref; + /** + * Create a BigNumber, which can store numbers with arbitrary precision. + * When a matrix is provided, all elements will be converted to BigNumber. + * + * Syntax: + * + * math.bignumber(x) + * + * Examples: + * + * 0.1 + 0.2 // returns number 0.30000000000000004 + * math.bignumber(0.1) + math.bignumber(0.2) // returns BigNumber 0.3 + * + * + * 7.2e500 // returns number Infinity + * math.bignumber('7.2e500') // returns BigNumber 7.2e500 + * + * See also: + * + * number, bigint, boolean, complex, index, matrix, string, unit + * + * @param {number | string | Fraction | BigNumber | bigint | Array | Matrix | boolean | null} [value] Value for the big number, + * 0 by default. + * @returns {BigNumber} The created bignumber + */ + return typed('bignumber', { + '': function () { + return new BigNumber(0); + }, + number: function (x) { + // convert to string to prevent errors in case of >15 digits + return new BigNumber(x + ''); + }, + string: function (x) { + const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/); + if (wordSizeSuffixMatch) { + // x has a word size suffix + const size = wordSizeSuffixMatch[2]; + const n = BigNumber(wordSizeSuffixMatch[1]); + const twoPowSize = new BigNumber(2).pow(Number(size)); + if (n.gt(twoPowSize.sub(1))) { + throw new SyntaxError(`String "${x}" is out of range`); + } + const twoPowSizeSubOne = new BigNumber(2).pow(Number(size) - 1); + if (n.gte(twoPowSizeSubOne)) { + return n.sub(twoPowSize); + } else { + return n; + } + } + return new BigNumber(x); + }, + BigNumber: function (x) { + // we assume a BigNumber is immutable + return x; + }, + bigint: function (x) { + return new BigNumber(x.toString()); + }, + Unit: typed.referToSelf(self => x => { + const clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + Fraction: function (x) { + return new BigNumber(x.n).div(x.d).times(x.s); + }, + null: function (x) { + return new BigNumber(0); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/boolean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/boolean.js new file mode 100644 index 0000000..07301c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/boolean.js @@ -0,0 +1,76 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBoolean = void 0; +var _factory = require("../utils/factory.js"); +var _collection = require("../utils/collection.js"); +const name = 'boolean'; +const dependencies = ['typed']; +const createBoolean = exports.createBoolean = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Create a boolean or convert a string or number to a boolean. + * In case of a number, `true` is returned for non-zero numbers, and `false` in + * case of zero. + * Strings can be `'true'` or `'false'`, or can contain a number. + * When value is a matrix, all elements will be converted to boolean. + * + * Syntax: + * + * math.boolean(x) + * + * Examples: + * + * math.boolean(0) // returns false + * math.boolean(1) // returns true + * math.boolean(-3) // returns true + * math.boolean('true') // returns true + * math.boolean('false') // returns false + * math.boolean([1, 0, 1, 1]) // returns [true, false, true, true] + * + * See also: + * + * bignumber, complex, index, matrix, string, unit + * + * @param {string | number | boolean | Array | Matrix | null} value A value of any type + * @return {boolean | Array | Matrix} The boolean value + */ + return typed(name, { + '': function () { + return false; + }, + boolean: function (x) { + return x; + }, + number: function (x) { + return !!x; + }, + null: function (x) { + return false; + }, + BigNumber: function (x) { + return !x.isZero(); + }, + string: function (x) { + // try case insensitive + const lcase = x.toLowerCase(); + if (lcase === 'true') { + return true; + } else if (lcase === 'false') { + return false; + } + + // test whether value is a valid number + const num = Number(x); + if (x !== '' && !isNaN(num)) { + return !!num; + } + throw new Error('Cannot convert "' + x + '" to a boolean'); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/Chain.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/Chain.js new file mode 100644 index 0000000..b592898 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/Chain.js @@ -0,0 +1,216 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createChainClass = void 0; +var _is = require("../../utils/is.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +var _factory = require("../../utils/factory.js"); +const name = 'Chain'; +const dependencies = ['?on', 'math', 'typed']; +const createChainClass = exports.createChainClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + on, + math, + typed + } = _ref; + /** + * @constructor Chain + * Wrap any value in a chain, allowing to perform chained operations on + * the value. + * + * All methods available in the math.js library can be called upon the chain, + * and then will be evaluated with the value itself as first argument. + * The chain can be closed by executing chain.done(), which will return + * the final value. + * + * The Chain has a number of special functions: + * - done() Finalize the chained operation and return the + * chain's value. + * - valueOf() The same as done() + * - toString() Returns a string representation of the chain's value. + * + * @param {*} [value] + */ + function Chain(value) { + if (!(this instanceof Chain)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if ((0, _is.isChain)(value)) { + this.value = value.value; + } else { + this.value = value; + } + } + + /** + * Attach type information + */ + Chain.prototype.type = 'Chain'; + Chain.prototype.isChain = true; + + /** + * Close the chain. Returns the final value. + * Does the same as method valueOf() + * @returns {*} value + */ + Chain.prototype.done = function () { + return this.value; + }; + + /** + * Close the chain. Returns the final value. + * Does the same as method done() + * @returns {*} value + */ + Chain.prototype.valueOf = function () { + return this.value; + }; + + /** + * Get a string representation of the value in the chain + * @returns {string} + */ + Chain.prototype.toString = function () { + return (0, _string.format)(this.value); + }; + + /** + * Get a JSON representation of the chain + * @returns {Object} + */ + Chain.prototype.toJSON = function () { + return { + mathjs: 'Chain', + value: this.value + }; + }; + + /** + * Instantiate a Chain from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "Chain", value: ...}`, + * where mathjs is optional + * @returns {Chain} + */ + Chain.fromJSON = function (json) { + return new Chain(json.value); + }; + + /** + * Create a proxy method for the chain + * @param {string} name + * @param {Function} fn The function to be proxied + * If fn is no function, it is silently ignored. + * @private + */ + function createProxy(name, fn) { + if (typeof fn === 'function') { + Chain.prototype[name] = chainify(fn); + } + } + + /** + * Create a proxy method for the chain + * @param {string} name + * @param {function} resolver The function resolving with the + * function to be proxied + * @private + */ + function createLazyProxy(name, resolver) { + (0, _object.lazy)(Chain.prototype, name, function outerResolver() { + const fn = resolver(); + if (typeof fn === 'function') { + return chainify(fn); + } + return undefined; // if not a function, ignore + }); + } + + /** + * Make a function chainable + * @param {function} fn + * @return {Function} chain function + * @private + */ + function chainify(fn) { + return function () { + // Here, `this` will be the context of a Chain instance + if (arguments.length === 0) { + return new Chain(fn(this.value)); + } + const args = [this.value]; + for (let i = 0; i < arguments.length; i++) { + args[i + 1] = arguments[i]; + } + if (typed.isTypedFunction(fn)) { + const sigObject = typed.resolve(fn, args); + // We want to detect if a rest parameter has matched across the + // value in the chain and the current arguments of this call. + // That is the case if and only if the matching signature has + // exactly one parameter (which then must be a rest parameter + // as it is matching at least two actual arguments). + if (sigObject.params.length === 1) { + throw new Error('chain function ' + fn.name + ' cannot match rest parameter between chain value and additional arguments.'); + } + return new Chain(sigObject.implementation.apply(fn, args)); + } + return new Chain(fn.apply(fn, args)); + }; + } + + /** + * Create a proxy for a single method, or an object with multiple methods. + * Example usage: + * + * Chain.createProxy('add', function add (x, y) {...}) + * Chain.createProxy({ + * add: function add (x, y) {...}, + * subtract: function subtract (x, y) {...} + * } + * + * @param {string | Object} arg0 A name (string), or an object with + * functions + * @param {*} [arg1] A function, when arg0 is a name + */ + Chain.createProxy = function (arg0, arg1) { + if (typeof arg0 === 'string') { + // createProxy(name, value) + createProxy(arg0, arg1); + } else { + // createProxy(values) + for (const name in arg0) { + if ((0, _object.hasOwnProperty)(arg0, name) && excludedNames[name] === undefined) { + createLazyProxy(name, () => arg0[name]); + } + } + } + }; + const excludedNames = { + expression: true, + docs: true, + type: true, + classes: true, + json: true, + error: true, + isChain: true // conflicts with the property isChain of a Chain instance + }; + + // create proxy for everything that is in math.js + Chain.createProxy(math); + + // register on the import event, automatically add a proxy for every imported function. + if (on) { + on('import', function (name, resolver, path) { + if (!path) { + // an imported function (not a data type or something special) + createLazyProxy(name, resolver); + } + }); + } + return Chain; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/function/chain.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/function/chain.js new file mode 100644 index 0000000..7911b64 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/chain/function/chain.js @@ -0,0 +1,58 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createChain = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'chain'; +const dependencies = ['typed', 'Chain']; +const createChain = exports.createChain = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Chain + } = _ref; + /** + * Wrap any value in a chain, allowing to perform chained operations on + * the value. + * + * All methods available in the math.js library can be called upon the chain, + * and then will be evaluated with the value itself as first argument. + * The chain can be closed by executing `chain.done()`, which returns + * the final value. + * + * The chain has a number of special functions: + * + * - `done()` Finalize the chain and return the chain's value. + * - `valueOf()` The same as `done()` + * - `toString()` Executes `math.format()` onto the chain's value, returning + * a string representation of the value. + * + * Syntax: + * + * math.chain(value) + * + * Examples: + * + * math.chain(3) + * .add(4) + * .subtract(2) + * .done() // 5 + * + * math.chain( [[1, 2], [3, 4]] ) + * .subset(math.index(0, 0), 8) + * .multiply(3) + * .done() // [[24, 6], [9, 12]] + * + * @param {*} [value] A value of any type on which to start a chained operation. + * @return {math.Chain} The created chain + */ + return typed(name, { + '': function () { + return new Chain(); + }, + any: function (value) { + return new Chain(value); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/Complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/Complex.js new file mode 100644 index 0000000..d0eecba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/Complex.js @@ -0,0 +1,201 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createComplexClass = void 0; +var _complex = _interopRequireDefault(require("complex.js")); +var _number = require("../../utils/number.js"); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +const name = 'Complex'; +const dependencies = []; +const createComplexClass = exports.createComplexClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * Attach type information + */ + Object.defineProperty(_complex.default, 'name', { + value: 'Complex' + }); + _complex.default.prototype.constructor = _complex.default; + _complex.default.prototype.type = 'Complex'; + _complex.default.prototype.isComplex = true; + + /** + * Get a JSON representation of the complex number + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Complex", "re": 2, "im": 3}` + */ + _complex.default.prototype.toJSON = function () { + return { + mathjs: 'Complex', + re: this.re, + im: this.im + }; + }; + + /* + * Return the value of the complex number in polar notation + * The angle phi will be set in the interval of [-pi, pi]. + * @return {{r: number, phi: number}} Returns and object with properties r and phi. + */ + _complex.default.prototype.toPolar = function () { + return { + r: this.abs(), + phi: this.arg() + }; + }; + + /** + * Get a string representation of the complex number, + * with optional formatting options. + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @return {string} str + */ + _complex.default.prototype.format = function (options) { + let str = ''; + let im = this.im; + let re = this.re; + const strRe = (0, _number.format)(this.re, options); + const strIm = (0, _number.format)(this.im, options); + + // round either re or im when smaller than the configured precision + const precision = (0, _is.isNumber)(options) ? options : options ? options.precision : null; + if (precision !== null) { + const epsilon = Math.pow(10, -precision); + if (Math.abs(re / im) < epsilon) { + re = 0; + } + if (Math.abs(im / re) < epsilon) { + im = 0; + } + } + if (im === 0) { + // real value + str = strRe; + } else if (re === 0) { + // purely complex value + if (im === 1) { + str = 'i'; + } else if (im === -1) { + str = '-i'; + } else { + str = strIm + 'i'; + } + } else { + // complex value + if (im < 0) { + if (im === -1) { + str = strRe + ' - i'; + } else { + str = strRe + ' - ' + strIm.substring(1) + 'i'; + } + } else { + if (im === 1) { + str = strRe + ' + i'; + } else { + str = strRe + ' + ' + strIm + 'i'; + } + } + } + return str; + }; + + /** + * Create a complex number from polar coordinates + * + * Usage: + * + * Complex.fromPolar(r: number, phi: number) : Complex + * Complex.fromPolar({r: number, phi: number}) : Complex + * + * @param {*} args... + * @return {Complex} + */ + _complex.default.fromPolar = function (args) { + switch (arguments.length) { + case 1: + { + const arg = arguments[0]; + if (typeof arg === 'object') { + return (0, _complex.default)(arg); + } else { + throw new TypeError('Input has to be an object with r and phi keys.'); + } + } + case 2: + { + const r = arguments[0]; + let phi = arguments[1]; + if ((0, _is.isNumber)(r)) { + if ((0, _is.isUnit)(phi) && phi.hasBase('ANGLE')) { + // convert unit to a number in radians + phi = phi.toNumber('rad'); + } + if ((0, _is.isNumber)(phi)) { + return new _complex.default({ + r, + phi + }); + } + throw new TypeError('Phi is not a number nor an angle unit.'); + } else { + throw new TypeError('Radius r is not a number.'); + } + } + default: + throw new SyntaxError('Wrong number of arguments in function fromPolar'); + } + }; + _complex.default.prototype.valueOf = _complex.default.prototype.toString; + + /** + * Create a Complex number from a JSON object + * @param {Object} json A JSON Object structured as + * {"mathjs": "Complex", "re": 2, "im": 3} + * All properties are optional, default values + * for `re` and `im` are 0. + * @return {Complex} Returns a new Complex number + */ + _complex.default.fromJSON = function (json) { + return new _complex.default(json); + }; + + /** + * Compare two complex numbers, `a` and `b`: + * + * - Returns 1 when the real part of `a` is larger than the real part of `b` + * - Returns -1 when the real part of `a` is smaller than the real part of `b` + * - Returns 1 when the real parts are equal + * and the imaginary part of `a` is larger than the imaginary part of `b` + * - Returns -1 when the real parts are equal + * and the imaginary part of `a` is smaller than the imaginary part of `b` + * - Returns 0 when both real and imaginary parts are equal. + * + * @params {Complex} a + * @params {Complex} b + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + _complex.default.compare = function (a, b) { + if (a.re > b.re) { + return 1; + } + if (a.re < b.re) { + return -1; + } + if (a.im > b.im) { + return 1; + } + if (a.im < b.im) { + return -1; + } + return 0; + }; + return _complex.default; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/function/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/function/complex.js new file mode 100644 index 0000000..a48a0c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/complex/function/complex.js @@ -0,0 +1,91 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createComplex = void 0; +var _factory = require("../../../utils/factory.js"); +var _collection = require("../../../utils/collection.js"); +const name = 'complex'; +const dependencies = ['typed', 'Complex']; +const createComplex = exports.createComplex = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Complex + } = _ref; + /** + * Create a complex value or convert a value to a complex value. + * + * Syntax: + * + * math.complex() // creates a complex value with zero + * // as real and imaginary part. + * math.complex(re : number, im : string) // creates a complex value with provided + * // values for real and imaginary part. + * math.complex(re : number) // creates a complex value with provided + * // real value and zero imaginary part. + * math.complex(complex : Complex) // clones the provided complex value. + * math.complex(arg : string) // parses a string into a complex value. + * math.complex(array : Array) // converts the elements of the array + * // or matrix element wise into a + * // complex value. + * math.complex({re: number, im: number}) // creates a complex value with provided + * // values for real an imaginary part. + * math.complex({r: number, phi: number}) // creates a complex value with provided + * // polar coordinates + * + * Examples: + * + * const a = math.complex(3, -4) // a = Complex 3 - 4i + * a.re = 5 // a = Complex 5 - 4i + * const i = a.im // Number -4 + * const b = math.complex('2 + 6i') // Complex 2 + 6i + * const c = math.complex() // Complex 0 + 0i + * const d = math.add(a, b) // Complex 5 + 2i + * + * See also: + * + * bignumber, boolean, index, matrix, number, string, unit + * + * @param {* | Array | Matrix} [args] + * Arguments specifying the real and imaginary part of the complex number + * @return {Complex | Array | Matrix} Returns a complex value + */ + return typed('complex', { + '': function () { + return Complex.ZERO; + }, + number: function (x) { + return new Complex(x, 0); + }, + 'number, number': function (re, im) { + return new Complex(re, im); + }, + // TODO: this signature should be redundant + 'BigNumber, BigNumber': function (re, im) { + return new Complex(re.toNumber(), im.toNumber()); + }, + Fraction: function (x) { + return new Complex(x.valueOf(), 0); + }, + Complex: function (x) { + return x.clone(); + }, + string: function (x) { + return Complex(x); // for example '2 + 3i' + }, + null: function (x) { + return Complex(0); + }, + Object: function (x) { + if ('re' in x && 'im' in x) { + return new Complex(x.re, x.im); + } + if ('r' in x && 'phi' in x || 'abs' in x && 'arg' in x) { + return new Complex(x); + } + throw new Error('Expected object with properties (re and im) or (r and phi) or (abs and arg)'); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/Fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/Fraction.js new file mode 100644 index 0000000..88e31c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/Fraction.js @@ -0,0 +1,48 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFractionClass = void 0; +var _fraction = _interopRequireDefault(require("fraction.js")); +var _factory = require("../../utils/factory.js"); +const name = 'Fraction'; +const dependencies = []; +const createFractionClass = exports.createFractionClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * Attach type information + */ + Object.defineProperty(_fraction.default, 'name', { + value: 'Fraction' + }); + _fraction.default.prototype.constructor = _fraction.default; + _fraction.default.prototype.type = 'Fraction'; + _fraction.default.prototype.isFraction = true; + + /** + * Get a JSON representation of a Fraction containing type information + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Fraction", "n": 3, "d": 8}` + */ + _fraction.default.prototype.toJSON = function () { + return { + mathjs: 'Fraction', + n: this.s * this.n, + d: this.d + }; + }; + + /** + * Instantiate a Fraction from a JSON object + * @param {Object} json a JSON object structured as: + * `{"mathjs": "Fraction", "n": 3, "d": 8}` + * @return {BigNumber} + */ + _fraction.default.fromJSON = function (json) { + return new _fraction.default(json); + }; + return _fraction.default; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/function/fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/function/fraction.js new file mode 100644 index 0000000..86e3ce9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/fraction/function/fraction.js @@ -0,0 +1,88 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFraction = void 0; +var _factory = require("../../../utils/factory.js"); +var _collection = require("../../../utils/collection.js"); +const name = 'fraction'; +const dependencies = ['typed', 'Fraction']; +const createFraction = exports.createFraction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Fraction + } = _ref; + /** + * Create a fraction or convert a value to a fraction. + * + * With one numeric argument, produces the closest rational approximation to the + * input. + * With two arguments, the first is the numerator and the second is the denominator, + * and creates the corresponding fraction. Both numerator and denominator must be + * integers. + * With one object argument, looks for the integer numerator as the value of property + * 'n' and the integer denominator as the value of property 'd'. + * With a matrix argument, creates a matrix of the same shape with entries + * converted into fractions. + * + * Syntax: + * math.fraction(value) + * math.fraction(numerator, denominator) + * math.fraction({n: numerator, d: denominator}) + * math.fraction(matrix: Array | Matrix) + * + * Examples: + * + * math.fraction(6.283) // returns Fraction 6283/1000 + * math.fraction(1, 3) // returns Fraction 1/3 + * math.fraction('2/3') // returns Fraction 2/3 + * math.fraction({n: 2, d: 3}) // returns Fraction 2/3 + * math.fraction([0.2, 0.25, 1.25]) // returns Array [1/5, 1/4, 5/4] + * math.fraction(4, 5.1) // throws Error: Parameters must be integer + * + * See also: + * + * bignumber, number, string, unit + * + * @param {number | string | Fraction | BigNumber | bigint | Unit | Array | Matrix} [args] + * Arguments specifying the value, or numerator and denominator of + * the fraction + * @return {Fraction | Array | Matrix} Returns a fraction + */ + return typed('fraction', { + number: function (x) { + if (!isFinite(x) || isNaN(x)) { + throw new Error(x + ' cannot be represented as a fraction'); + } + return new Fraction(x); + }, + string: function (x) { + return new Fraction(x); + }, + 'number, number': function (numerator, denominator) { + return new Fraction(numerator, denominator); + }, + null: function (x) { + return new Fraction(0); + }, + BigNumber: function (x) { + return new Fraction(x.toString()); + }, + bigint: function (x) { + return new Fraction(x.toString()); + }, + Fraction: function (x) { + return x; // fractions are immutable + }, + Unit: typed.referToSelf(self => x => { + const clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + Object: function (x) { + return new Fraction(x); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/DenseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/DenseMatrix.js new file mode 100644 index 0000000..9cb7d4c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/DenseMatrix.js @@ -0,0 +1,974 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createDenseMatrixClass = void 0; +var _is = require("../../utils/is.js"); +var _array = require("../../utils/array.js"); +var _string = require("../../utils/string.js"); +var _number = require("../../utils/number.js"); +var _object = require("../../utils/object.js"); +var _DimensionError = require("../../error/DimensionError.js"); +var _factory = require("../../utils/factory.js"); +var _optimizeCallback = require("../../utils/optimizeCallback.js"); +// deno-lint-ignore-file no-this-alias + +const name = 'DenseMatrix'; +const dependencies = ['Matrix']; +const createDenseMatrixClass = exports.createDenseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + Matrix + } = _ref; + /** + * Dense Matrix implementation. A regular, dense matrix, supporting multi-dimensional matrices. This is the default matrix type. + * @class DenseMatrix + * @enum {{ value, index: number[] }} + */ + function DenseMatrix(data, datatype) { + if (!(this instanceof DenseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !(0, _is.isString)(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if ((0, _is.isMatrix)(data)) { + // check data is a DenseMatrix + if (data.type === 'DenseMatrix') { + // clone data & size + this._data = (0, _object.clone)(data._data); + this._size = (0, _object.clone)(data._size); + this._datatype = datatype || data._datatype; + } else { + // build data from existing matrix + this._data = data.toArray(); + this._size = data.size(); + this._datatype = datatype || data._datatype; + } + } else if (data && (0, _is.isArray)(data.data) && (0, _is.isArray)(data.size)) { + // initialize fields from JSON representation + this._data = data.data; + this._size = data.size; + // verify the dimensions of the array + (0, _array.validate)(this._data, this._size); + this._datatype = datatype || data.datatype; + } else if ((0, _is.isArray)(data)) { + // replace nested Matrices with Arrays + this._data = preprocess(data); + // get the dimensions of the array + this._size = (0, _array.arraySize)(this._data); + // verify the dimensions of the array, TODO: compute size while processing array + (0, _array.validate)(this._data, this._size); + // data type unknown + this._datatype = datatype; + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')'); + } else { + // nothing provided + this._data = []; + this._size = [0]; + this._datatype = datatype; + } + } + DenseMatrix.prototype = new Matrix(); + + /** + * Create a new DenseMatrix + */ + DenseMatrix.prototype.createDenseMatrix = function (data, datatype) { + return new DenseMatrix(data, datatype); + }; + + /** + * Attach type information + */ + Object.defineProperty(DenseMatrix, 'name', { + value: 'DenseMatrix' + }); + DenseMatrix.prototype.constructor = DenseMatrix; + DenseMatrix.prototype.type = 'DenseMatrix'; + DenseMatrix.prototype.isDenseMatrix = true; + + /** + * Get the matrix type + * + * Usage: + * const matrixType = matrix.getDataType() // retrieves the matrix type + * + * @memberOf DenseMatrix + * @return {string} type information; if multiple types are found from the Matrix, it will return "mixed" + */ + DenseMatrix.prototype.getDataType = function () { + return (0, _array.getArrayDataType)(this._data, _is.typeOf); + }; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @memberof DenseMatrix + * @return {string} The storage format. + */ + DenseMatrix.prototype.storage = function () { + return 'dense'; + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @memberof DenseMatrix + * @return {string} The datatype. + */ + DenseMatrix.prototype.datatype = function () { + return this._datatype; + }; + + /** + * Create a new DenseMatrix + * @memberof DenseMatrix + * @param {Array} data + * @param {string} [datatype] + */ + DenseMatrix.prototype.create = function (data, datatype) { + return new DenseMatrix(data, datatype); + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @memberof DenseMatrix + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + DenseMatrix.prototype.subset = function (index, replacement, defaultValue) { + switch (arguments.length) { + case 1: + return _get(this, index); + + // intentional fall through + case 2: + case 3: + return _set(this, index, replacement, defaultValue); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + + /** + * Get a single element from the matrix. + * @memberof DenseMatrix + * @param {number[]} index Zero-based index + * @return {*} value + */ + DenseMatrix.prototype.get = function (index) { + return (0, _array.get)(this._data, index); + }; + + /** + * Replace a single element in the matrix. + * @memberof DenseMatrix + * @param {number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {DenseMatrix} self + */ + DenseMatrix.prototype.set = function (index, value, defaultValue) { + if (!(0, _is.isArray)(index)) { + throw new TypeError('Array expected'); + } + if (index.length < this._size.length) { + throw new _DimensionError.DimensionError(index.length, this._size.length, '<'); + } + let i, ii, indexI; + + // enlarge matrix when needed + const size = index.map(function (i) { + return i + 1; + }); + _fit(this, size, defaultValue); + + // traverse over the dimensions + let data = this._data; + for (i = 0, ii = index.length - 1; i < ii; i++) { + indexI = index[i]; + (0, _array.validateIndex)(indexI, data.length); + data = data[indexI]; + } + + // set new value + indexI = index[index.length - 1]; + (0, _array.validateIndex)(indexI, data.length); + data[indexI] = value; + return this; + }; + + /** + * Get a submatrix of this matrix + * @memberof DenseMatrix + * @param {DenseMatrix} matrix + * @param {Index} index Zero-based index + * @private + */ + function _get(matrix, index) { + if (!(0, _is.isIndex)(index)) { + throw new TypeError('Invalid index'); + } + const isScalar = index.isScalar(); + if (isScalar) { + // return a scalar + return matrix.get(index.min()); + } else { + // validate dimensions + const size = index.size(); + if (size.length !== matrix._size.length) { + throw new _DimensionError.DimensionError(size.length, matrix._size.length); + } + + // validate if any of the ranges in the index is out of range + const min = index.min(); + const max = index.max(); + for (let i = 0, ii = matrix._size.length; i < ii; i++) { + (0, _array.validateIndex)(min[i], matrix._size[i]); + (0, _array.validateIndex)(max[i], matrix._size[i]); + } + + // retrieve submatrix + // TODO: more efficient when creating an empty matrix and setting _data and _size manually + return new DenseMatrix(_getSubmatrix(matrix._data, index, size.length, 0), matrix._datatype); + } + } + + /** + * Recursively get a submatrix of a multi dimensional matrix. + * Index is not checked for correct number or length of dimensions. + * @memberof DenseMatrix + * @param {Array} data + * @param {Index} index + * @param {number} dims Total number of dimensions + * @param {number} dim Current dimension + * @return {Array} submatrix + * @private + */ + function _getSubmatrix(data, index, dims, dim) { + const last = dim === dims - 1; + const range = index.dimension(dim); + if (last) { + return range.map(function (i) { + (0, _array.validateIndex)(i, data.length); + return data[i]; + }).valueOf(); + } else { + return range.map(function (i) { + (0, _array.validateIndex)(i, data.length); + const child = data[i]; + return _getSubmatrix(child, index, dims, dim + 1); + }).valueOf(); + } + } + + /** + * Replace a submatrix in this matrix + * Indexes are zero-based. + * @memberof DenseMatrix + * @param {DenseMatrix} matrix + * @param {Index} index + * @param {DenseMatrix | Array | *} submatrix + * @param {*} defaultValue Default value, filled in on new entries when + * the matrix is resized. + * @return {DenseMatrix} matrix + * @private + */ + function _set(matrix, index, submatrix, defaultValue) { + if (!index || index.isIndex !== true) { + throw new TypeError('Invalid index'); + } + + // get index size and check whether the index contains a single value + const iSize = index.size(); + const isScalar = index.isScalar(); + + // calculate the size of the submatrix, and convert it into an Array if needed + let sSize; + if ((0, _is.isMatrix)(submatrix)) { + sSize = submatrix.size(); + submatrix = submatrix.valueOf(); + } else { + sSize = (0, _array.arraySize)(submatrix); + } + if (isScalar) { + // set a scalar + + // check whether submatrix is a scalar + if (sSize.length !== 0) { + throw new TypeError('Scalar expected'); + } + matrix.set(index.min(), submatrix, defaultValue); + } else { + // set a submatrix + + // broadcast submatrix + if (!(0, _object.deepStrictEqual)(sSize, iSize)) { + try { + if (sSize.length === 0) { + submatrix = (0, _array.broadcastTo)([submatrix], iSize); + } else { + submatrix = (0, _array.broadcastTo)(submatrix, iSize); + } + sSize = (0, _array.arraySize)(submatrix); + } catch (_unused) {} + } + + // validate dimensions + if (iSize.length < matrix._size.length) { + throw new _DimensionError.DimensionError(iSize.length, matrix._size.length, '<'); + } + if (sSize.length < iSize.length) { + // calculate number of missing outer dimensions + let i = 0; + let outer = 0; + while (iSize[i] === 1 && sSize[i] === 1) { + i++; + } + while (iSize[i] === 1) { + outer++; + i++; + } + + // unsqueeze both outer and inner dimensions + submatrix = (0, _array.unsqueeze)(submatrix, iSize.length, outer, sSize); + } + + // check whether the size of the submatrix matches the index size + if (!(0, _object.deepStrictEqual)(iSize, sSize)) { + throw new _DimensionError.DimensionError(iSize, sSize, '>'); + } + + // enlarge matrix when needed + const size = index.max().map(function (i) { + return i + 1; + }); + _fit(matrix, size, defaultValue); + + // insert the sub matrix + const dims = iSize.length; + const dim = 0; + _setSubmatrix(matrix._data, index, submatrix, dims, dim); + } + return matrix; + } + + /** + * Replace a submatrix of a multi dimensional matrix. + * @memberof DenseMatrix + * @param {Array} data + * @param {Index} index + * @param {Array} submatrix + * @param {number} dims Total number of dimensions + * @param {number} dim + * @private + */ + function _setSubmatrix(data, index, submatrix, dims, dim) { + const last = dim === dims - 1; + const range = index.dimension(dim); + if (last) { + range.forEach(function (dataIndex, subIndex) { + (0, _array.validateIndex)(dataIndex); + data[dataIndex] = submatrix[subIndex[0]]; + }); + } else { + range.forEach(function (dataIndex, subIndex) { + (0, _array.validateIndex)(dataIndex); + _setSubmatrix(data[dataIndex], index, submatrix[subIndex[0]], dims, dim + 1); + }); + } + } + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @memberof DenseMatrix + * @param {number[] || Matrix} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + DenseMatrix.prototype.resize = function (size, defaultValue, copy) { + // validate arguments + if (!(0, _is.isCollection)(size)) { + throw new TypeError('Array or Matrix expected'); + } + + // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector + const sizeArray = size.valueOf().map(value => { + return Array.isArray(value) && value.length === 1 ? value[0] : value; + }); + + // matrix to resize + const m = copy ? this.clone() : this; + // resize matrix + return _resize(m, sizeArray, defaultValue); + }; + function _resize(matrix, size, defaultValue) { + // check size + if (size.length === 0) { + // first value in matrix + let v = matrix._data; + // go deep + while ((0, _is.isArray)(v)) { + v = v[0]; + } + return v; + } + // resize matrix + matrix._size = size.slice(0); // copy the array + matrix._data = (0, _array.resize)(matrix._data, matrix._size, defaultValue); + // return matrix + return matrix; + } + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * NOTE: This might be better suited to copy by default, instead of modifying + * in place. For now, it operates in place to remain consistent with + * resize(). + * + * @memberof DenseMatrix + * @param {number[]} size The new size the matrix should have. + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + DenseMatrix.prototype.reshape = function (size, copy) { + const m = copy ? this.clone() : this; + m._data = (0, _array.reshape)(m._data, size); + const currentLength = m._size.reduce((length, size) => length * size); + m._size = (0, _array.processSizesWildcard)(size, currentLength); + return m; + }; + + /** + * Enlarge the matrix when it is smaller than given size. + * If the matrix is larger or equal sized, nothing is done. + * @memberof DenseMatrix + * @param {DenseMatrix} matrix The matrix to be resized + * @param {number[]} size + * @param {*} defaultValue Default value, filled in on new entries. + * @private + */ + function _fit(matrix, size, defaultValue) { + const + // copy the array + newSize = matrix._size.slice(0); + let changed = false; + + // add dimensions when needed + while (newSize.length < size.length) { + newSize.push(0); + changed = true; + } + + // enlarge size when needed + for (let i = 0, ii = size.length; i < ii; i++) { + if (size[i] > newSize[i]) { + newSize[i] = size[i]; + changed = true; + } + } + if (changed) { + // resize only when size is changed + _resize(matrix, newSize, defaultValue); + } + } + + /** + * Create a clone of the matrix + * @memberof DenseMatrix + * @return {DenseMatrix} clone + */ + DenseMatrix.prototype.clone = function () { + const m = new DenseMatrix({ + data: (0, _object.clone)(this._data), + size: (0, _object.clone)(this._size), + datatype: this._datatype + }); + return m; + }; + + /** + * Retrieve the size of the matrix. + * @memberof DenseMatrix + * @returns {number[]} size + */ + DenseMatrix.prototype.size = function () { + return this._size.slice(0); // return a clone of _size + }; + + /** + * Applies a callback function to a reference to each element of the matrix + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: an array, an integer index to that + * array, and the Matrix being traversed. + */ + DenseMatrix.prototype._forEach = function (callback) { + // matrix instance + const me = this; + const s = me.size(); + + // if there is only one dimension, just loop through it + if (s.length === 1) { + for (let i = 0; i < s[0]; i++) { + callback(me._data, i, [i]); + } + return; + } + + // keep track of the current index permutation + const index = Array(s.length).fill(0); + + // store a reference of each dimension of the matrix for faster access + const data = Array(s.length - 1); + const last = data.length - 1; + data[0] = me._data[0]; + for (let i = 0; i < last; i++) { + data[i + 1] = data[i][0]; + } + index[last] = -1; + while (true) { + let i; + for (i = last; i >= 0; i--) { + // march index to the next permutation + index[i]++; + if (index[i] === s[i]) { + index[i] = 0; + continue; + } + + // update references to matrix dimensions + data[i] = i === 0 ? me._data[index[i]] : data[i - 1][index[i]]; + for (let j = i; j < last; j++) { + data[j + 1] = data[j][0]; + } + + // loop through the last dimension and map each value + for (let j = 0; j < s[data.length]; j++) { + index[data.length] = j; + callback(data[last], j, index.slice(0)); + } + break; + } + if (i === -1) { + break; + } + } + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * + * @return {DenseMatrix} matrix + */ + DenseMatrix.prototype.map = function (callback) { + const me = this; + const result = new DenseMatrix(me); + const fastCallback = (0, _optimizeCallback.optimizeCallback)(callback, me._data, 'map'); + result._forEach(function (arr, i, index) { + arr[i] = fastCallback(arr[i], index, me); + }); + return result; + }; + + /** + * Execute a callback function on each entry of the matrix. + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + */ + DenseMatrix.prototype.forEach = function (callback) { + const me = this; + const fastCallback = (0, _optimizeCallback.optimizeCallback)(callback, me._data, 'map'); + me._forEach(function (arr, i, index) { + fastCallback(arr[i], index, me); + }); + }; + + /** + * Iterate over the matrix elements + * @return {Iterable<{ value, index: number[] }>} + */ + DenseMatrix.prototype[Symbol.iterator] = function* () { + const recurse = function* (value, index) { + if ((0, _is.isArray)(value)) { + for (let i = 0; i < value.length; i++) { + yield* recurse(value[i], index.concat(i)); + } + } else { + yield { + value, + index + }; + } + }; + yield* recurse(this._data, []); + }; + + /** + * Returns an array containing the rows of a 2D matrix + * @returns {Array} + */ + DenseMatrix.prototype.rows = function () { + const result = []; + const s = this.size(); + if (s.length !== 2) { + throw new TypeError('Rows can only be returned for a 2D matrix.'); + } + const data = this._data; + for (const row of data) { + result.push(new DenseMatrix([row], this._datatype)); + } + return result; + }; + + /** + * Returns an array containing the columns of a 2D matrix + * @returns {Array} + */ + DenseMatrix.prototype.columns = function () { + const result = []; + const s = this.size(); + if (s.length !== 2) { + throw new TypeError('Rows can only be returned for a 2D matrix.'); + } + const data = this._data; + for (let i = 0; i < s[1]; i++) { + const col = data.map(row => [row[i]]); + result.push(new DenseMatrix(col, this._datatype)); + } + return result; + }; + + /** + * Create an Array with a copy of the data of the DenseMatrix + * @memberof DenseMatrix + * @returns {Array} array + */ + DenseMatrix.prototype.toArray = function () { + return (0, _object.clone)(this._data); + }; + + /** + * Get the primitive value of the DenseMatrix: a multidimensional array + * @memberof DenseMatrix + * @returns {Array} array + */ + DenseMatrix.prototype.valueOf = function () { + return this._data; + }; + + /** + * Get a string representation of the matrix, with optional formatting options. + * @memberof DenseMatrix + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + DenseMatrix.prototype.format = function (options) { + return (0, _string.format)(this._data, options); + }; + + /** + * Get a string representation of the matrix + * @memberof DenseMatrix + * @returns {string} str + */ + DenseMatrix.prototype.toString = function () { + return (0, _string.format)(this._data); + }; + + /** + * Get a JSON representation of the matrix + * @memberof DenseMatrix + * @returns {Object} + */ + DenseMatrix.prototype.toJSON = function () { + return { + mathjs: 'DenseMatrix', + data: this._data, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Get the kth Matrix diagonal. + * + * @memberof DenseMatrix + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved. + * + * @returns {Matrix} The matrix with the diagonal values. + */ + DenseMatrix.prototype.diagonal = function (k) { + // validate k if any + if (k) { + // convert BigNumber to a number + if ((0, _is.isBigNumber)(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + const kSuper = k > 0 ? k : 0; + const kSub = k < 0 ? -k : 0; + + // rows & columns + const rows = this._size[0]; + const columns = this._size[1]; + + // number diagonal values + const n = Math.min(rows - kSub, columns - kSuper); + + // x is a matrix get diagonal from matrix + const data = []; + + // loop rows + for (let i = 0; i < n; i++) { + data[i] = this._data[i + kSub][i + kSuper]; + } + + // create DenseMatrix + return new DenseMatrix({ + data, + size: [n], + datatype: this._datatype + }); + }; + + /** + * Create a diagonal matrix. + * + * @memberof DenseMatrix + * @param {Array} size The matrix size. + * @param {number | Matrix | Array } value The values for the diagonal. + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in. + * @param {number} [defaultValue] The default value for non-diagonal + * @param {string} [datatype] The datatype for the diagonal + * + * @returns {DenseMatrix} + */ + DenseMatrix.diagonal = function (size, value, k, defaultValue) { + if (!(0, _is.isArray)(size)) { + throw new TypeError('Array expected, size parameter'); + } + if (size.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // map size & validate + size = size.map(function (s) { + // check it is a big number + if ((0, _is.isBigNumber)(s)) { + // convert it + s = s.toNumber(); + } + // validate arguments + if (!(0, _is.isNumber)(s) || !(0, _number.isInteger)(s) || s < 1) { + throw new Error('Size values must be positive integers'); + } + return s; + }); + + // validate k if any + if (k) { + // convert BigNumber to a number + if ((0, _is.isBigNumber)(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + const kSuper = k > 0 ? k : 0; + const kSub = k < 0 ? -k : 0; + + // rows and columns + const rows = size[0]; + const columns = size[1]; + + // number of non-zero items + const n = Math.min(rows - kSub, columns - kSuper); + + // value extraction function + let _value; + + // check value + if ((0, _is.isArray)(value)) { + // validate array + if (value.length !== n) { + // number of values in array must be n + throw new Error('Invalid value array length'); + } + // define function + _value = function (i) { + // return value @ i + return value[i]; + }; + } else if ((0, _is.isMatrix)(value)) { + // matrix size + const ms = value.size(); + // validate matrix + if (ms.length !== 1 || ms[0] !== n) { + // number of values in array must be n + throw new Error('Invalid matrix length'); + } + // define function + _value = function (i) { + // return value @ i + return value.get([i]); + }; + } else { + // define function + _value = function () { + // return value + return value; + }; + } + + // discover default value if needed + if (!defaultValue) { + // check first value in array + defaultValue = (0, _is.isBigNumber)(_value(0)) ? _value(0).mul(0) // trick to create a BigNumber with value zero + : 0; + } + + // empty array + let data = []; + + // check we need to resize array + if (size.length > 0) { + // resize array + data = (0, _array.resize)(data, size, defaultValue); + // fill diagonal + for (let d = 0; d < n; d++) { + data[d + kSub][d + kSuper] = _value(d); + } + } + + // create DenseMatrix + return new DenseMatrix({ + data, + size: [rows, columns] + }); + }; + + /** + * Generate a matrix from a JSON object + * @memberof DenseMatrix + * @param {Object} json An object structured like + * `{"mathjs": "DenseMatrix", data: [], size: []}`, + * where mathjs is optional + * @returns {DenseMatrix} + */ + DenseMatrix.fromJSON = function (json) { + return new DenseMatrix(json); + }; + + /** + * Swap rows i and j in Matrix. + * + * @memberof DenseMatrix + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + DenseMatrix.prototype.swapRows = function (i, j) { + // check index + if (!(0, _is.isNumber)(i) || !(0, _number.isInteger)(i) || !(0, _is.isNumber)(j) || !(0, _number.isInteger)(j)) { + throw new Error('Row index must be positive integers'); + } + // check dimensions + if (this._size.length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + // validate index + (0, _array.validateIndex)(i, this._size[0]); + (0, _array.validateIndex)(j, this._size[0]); + + // swap rows + DenseMatrix._swapRows(i, j, this._data); + // return current instance + return this; + }; + + /** + * Swap rows i and j in Dense Matrix data structure. + * + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * @param {Array} data Matrix data + */ + DenseMatrix._swapRows = function (i, j, data) { + // swap values i <-> j + const vi = data[i]; + data[i] = data[j]; + data[j] = vi; + }; + + /** + * Preprocess data, which can be an Array or DenseMatrix with nested Arrays and + * Matrices. Clones all (nested) Arrays, and replaces all nested Matrices with Arrays + * @memberof DenseMatrix + * @param {Array | Matrix} data + * @return {Array} data + */ + function preprocess(data) { + if ((0, _is.isMatrix)(data)) { + return preprocess(data.valueOf()); + } + if ((0, _is.isArray)(data)) { + return data.map(preprocess); + } + return data; + } + return DenseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/FibonacciHeap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/FibonacciHeap.js new file mode 100644 index 0000000..cd83f22 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/FibonacciHeap.js @@ -0,0 +1,357 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createFibonacciHeapClass = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'FibonacciHeap'; +const dependencies = ['smaller', 'larger']; +const createFibonacciHeapClass = exports.createFibonacciHeapClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + smaller, + larger + } = _ref; + const oneOverLogPhi = 1.0 / Math.log((1.0 + Math.sqrt(5.0)) / 2.0); + + /** + * Fibonacci Heap implementation, used interally for Matrix math. + * @class FibonacciHeap + * @constructor FibonacciHeap + */ + function FibonacciHeap() { + if (!(this instanceof FibonacciHeap)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + + // initialize fields + this._minimum = null; + this._size = 0; + } + + /** + * Attach type information + */ + FibonacciHeap.prototype.type = 'FibonacciHeap'; + FibonacciHeap.prototype.isFibonacciHeap = true; + + /** + * Inserts a new data element into the heap. No heap consolidation is + * performed at this time, the new node is simply inserted into the root + * list of this heap. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.insert = function (key, value) { + // create node + const node = { + key, + value, + degree: 0 + }; + // check we have a node in the minimum + if (this._minimum) { + // minimum node + const minimum = this._minimum; + // update left & right of node + node.left = minimum; + node.right = minimum.right; + minimum.right = node; + node.right.left = node; + // update minimum node in heap if needed + if (smaller(key, minimum.key)) { + // node has a smaller key, use it as minimum + this._minimum = node; + } + } else { + // set left & right + node.left = node; + node.right = node; + // this is the first node + this._minimum = node; + } + // increment number of nodes in heap + this._size++; + // return node + return node; + }; + + /** + * Returns the number of nodes in heap. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.size = function () { + return this._size; + }; + + /** + * Removes all elements from this heap. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.clear = function () { + this._minimum = null; + this._size = 0; + }; + + /** + * Returns true if the heap is empty, otherwise false. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.isEmpty = function () { + return this._size === 0; + }; + + /** + * Extracts the node with minimum key from heap. Amortized running + * time: O(log n). + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.extractMinimum = function () { + // node to remove + const node = this._minimum; + // check we have a minimum + if (node === null) { + return node; + } + // current minimum + let minimum = this._minimum; + // get number of children + let numberOfChildren = node.degree; + // pointer to the first child + let x = node.child; + // for each child of node do... + while (numberOfChildren > 0) { + // store node in right side + const tempRight = x.right; + // remove x from child list + x.left.right = x.right; + x.right.left = x.left; + // add x to root list of heap + x.left = minimum; + x.right = minimum.right; + minimum.right = x; + x.right.left = x; + // set Parent[x] to null + x.parent = null; + x = tempRight; + numberOfChildren--; + } + // remove node from root list of heap + node.left.right = node.right; + node.right.left = node.left; + // update minimum + if (node === node.right) { + // empty + minimum = null; + } else { + // update minimum + minimum = node.right; + // we need to update the pointer to the root with minimum key + minimum = _findMinimumNode(minimum, this._size); + } + // decrement size of heap + this._size--; + // update minimum + this._minimum = minimum; + // return node + return node; + }; + + /** + * Removes a node from the heap given the reference to the node. The trees + * in the heap will be consolidated, if necessary. This operation may fail + * to remove the correct element if there are nodes with key value -Infinity. + * Running time: O(log n) amortized. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.remove = function (node) { + // decrease key value + this._minimum = _decreaseKey(this._minimum, node, -1); + // remove the smallest + this.extractMinimum(); + }; + + /** + * Decreases the key value for a heap node, given the new value to take on. + * The structure of the heap may be changed and will not be consolidated. + * Running time: O(1) amortized. + * @memberof FibonacciHeap + */ + function _decreaseKey(minimum, node, key) { + // set node key + node.key = key; + // get parent node + const parent = node.parent; + if (parent && smaller(node.key, parent.key)) { + // remove node from parent + _cut(minimum, node, parent); + // remove all nodes from parent to the root parent + _cascadingCut(minimum, parent); + } + // update minimum node if needed + if (smaller(node.key, minimum.key)) { + minimum = node; + } + // return minimum + return minimum; + } + + /** + * The reverse of the link operation: removes node from the child list of parent. + * This method assumes that min is non-null. Running time: O(1). + * @memberof FibonacciHeap + */ + function _cut(minimum, node, parent) { + // remove node from parent children and decrement Degree[parent] + node.left.right = node.right; + node.right.left = node.left; + parent.degree--; + // reset y.child if necessary + if (parent.child === node) { + parent.child = node.right; + } + // remove child if degree is 0 + if (parent.degree === 0) { + parent.child = null; + } + // add node to root list of heap + node.left = minimum; + node.right = minimum.right; + minimum.right = node; + node.right.left = node; + // set parent[node] to null + node.parent = null; + // set mark[node] to false + node.mark = false; + } + + /** + * Performs a cascading cut operation. This cuts node from its parent and then + * does the same for its parent, and so on up the tree. + * Running time: O(log n); O(1) excluding the recursion. + * @memberof FibonacciHeap + */ + function _cascadingCut(minimum, node) { + // store parent node + const parent = node.parent; + // if there's a parent... + if (!parent) { + return; + } + // if node is unmarked, set it marked + if (!node.mark) { + node.mark = true; + } else { + // it's marked, cut it from parent + _cut(minimum, node, parent); + // cut its parent as well + _cascadingCut(parent); + } + } + + /** + * Make the first node a child of the second one. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + const _linkNodes = function (node, parent) { + // remove node from root list of heap + node.left.right = node.right; + node.right.left = node.left; + // make node a Child of parent + node.parent = parent; + if (!parent.child) { + parent.child = node; + node.right = node; + node.left = node; + } else { + node.left = parent.child; + node.right = parent.child.right; + parent.child.right = node; + node.right.left = node; + } + // increase degree[parent] + parent.degree++; + // set mark[node] false + node.mark = false; + }; + function _findMinimumNode(minimum, size) { + // to find trees of the same degree efficiently we use an array of length O(log n) in which we keep a pointer to one root of each degree + const arraySize = Math.floor(Math.log(size) * oneOverLogPhi) + 1; + // create list with initial capacity + const array = new Array(arraySize); + // find the number of root nodes. + let numRoots = 0; + let x = minimum; + if (x) { + numRoots++; + x = x.right; + while (x !== minimum) { + numRoots++; + x = x.right; + } + } + // vars + let y; + // For each node in root list do... + while (numRoots > 0) { + // access this node's degree.. + let d = x.degree; + // get next node + const next = x.right; + // check if there is a node already in array with the same degree + while (true) { + // get node with the same degree is any + y = array[d]; + if (!y) { + break; + } + // make one node with the same degree a child of the other, do this based on the key value. + if (larger(x.key, y.key)) { + const temp = y; + y = x; + x = temp; + } + // make y a child of x + _linkNodes(y, x); + // we have handled this degree, go to next one. + array[d] = null; + d++; + } + // save this node for later when we might encounter another of the same degree. + array[d] = x; + // move forward through list. + x = next; + numRoots--; + } + // Set min to null (effectively losing the root list) and reconstruct the root list from the array entries in array[]. + minimum = null; + // loop nodes in array + for (let i = 0; i < arraySize; i++) { + // get current node + y = array[i]; + if (!y) { + continue; + } + // check if we have a linked list + if (minimum) { + // First remove node from root list. + y.left.right = y.right; + y.right.left = y.left; + // now add to root list, again. + y.left = minimum; + y.right = minimum.right; + minimum.right = y; + y.right.left = y; + // check if this is a new min. + if (smaller(y.key, minimum.key)) { + minimum = y; + } + } else { + minimum = y; + } + } + return minimum; + } + return FibonacciHeap; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/ImmutableDenseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/ImmutableDenseMatrix.js new file mode 100644 index 0000000..9a43e05 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/ImmutableDenseMatrix.js @@ -0,0 +1,227 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createImmutableDenseMatrixClass = void 0; +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _factory = require("../../utils/factory.js"); +const name = 'ImmutableDenseMatrix'; +const dependencies = ['smaller', 'DenseMatrix']; +const createImmutableDenseMatrixClass = exports.createImmutableDenseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + smaller, + DenseMatrix + } = _ref; + function ImmutableDenseMatrix(data, datatype) { + if (!(this instanceof ImmutableDenseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !(0, _is.isString)(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if ((0, _is.isMatrix)(data) || (0, _is.isArray)(data)) { + // use DenseMatrix implementation + const matrix = new DenseMatrix(data, datatype); + // internal structures + this._data = matrix._data; + this._size = matrix._size; + this._datatype = matrix._datatype; + this._min = null; + this._max = null; + } else if (data && (0, _is.isArray)(data.data) && (0, _is.isArray)(data.size)) { + // initialize fields from JSON representation + this._data = data.data; + this._size = data.size; + this._datatype = data.datatype; + this._min = typeof data.min !== 'undefined' ? data.min : null; + this._max = typeof data.max !== 'undefined' ? data.max : null; + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')'); + } else { + // nothing provided + this._data = []; + this._size = [0]; + this._datatype = datatype; + this._min = null; + this._max = null; + } + } + ImmutableDenseMatrix.prototype = new DenseMatrix(); + + /** + * Attach type information + */ + ImmutableDenseMatrix.prototype.type = 'ImmutableDenseMatrix'; + ImmutableDenseMatrix.prototype.isImmutableDenseMatrix = true; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @param {Index} index + * @param {Array | ImmutableDenseMatrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + ImmutableDenseMatrix.prototype.subset = function (index) { + switch (arguments.length) { + case 1: + { + // use base implementation + const m = DenseMatrix.prototype.subset.call(this, index); + // check result is a matrix + if ((0, _is.isMatrix)(m)) { + // return immutable matrix + return new ImmutableDenseMatrix({ + data: m._data, + size: m._size, + datatype: m._datatype + }); + } + return m; + } + // intentional fall through + case 2: + case 3: + throw new Error('Cannot invoke set subset on an Immutable Matrix instance'); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + + /** + * Replace a single element in the matrix. + * @param {Number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {ImmutableDenseMatrix} self + */ + ImmutableDenseMatrix.prototype.set = function () { + throw new Error('Cannot invoke set on an Immutable Matrix instance'); + }; + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @param {Number[]} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + ImmutableDenseMatrix.prototype.resize = function () { + throw new Error('Cannot invoke resize on an Immutable Matrix instance'); + }; + + /** + * Disallows reshaping in favor of immutability. + * + * @throws {Error} Operation not allowed + */ + ImmutableDenseMatrix.prototype.reshape = function () { + throw new Error('Cannot invoke reshape on an Immutable Matrix instance'); + }; + + /** + * Create a clone of the matrix + * @return {ImmutableDenseMatrix} clone + */ + ImmutableDenseMatrix.prototype.clone = function () { + return new ImmutableDenseMatrix({ + data: (0, _object.clone)(this._data), + size: (0, _object.clone)(this._size), + datatype: this._datatype + }); + }; + + /** + * Get a JSON representation of the matrix + * @returns {Object} + */ + ImmutableDenseMatrix.prototype.toJSON = function () { + return { + mathjs: 'ImmutableDenseMatrix', + data: this._data, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Generate a matrix from a JSON object + * @param {Object} json An object structured like + * `{"mathjs": "ImmutableDenseMatrix", data: [], size: []}`, + * where mathjs is optional + * @returns {ImmutableDenseMatrix} + */ + ImmutableDenseMatrix.fromJSON = function (json) { + return new ImmutableDenseMatrix(json); + }; + + /** + * Swap rows i and j in Matrix. + * + * @param {Number} i Matrix row index 1 + * @param {Number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + ImmutableDenseMatrix.prototype.swapRows = function () { + throw new Error('Cannot invoke swapRows on an Immutable Matrix instance'); + }; + + /** + * Calculate the minimum value in the set + * @return {Number | undefined} min + */ + ImmutableDenseMatrix.prototype.min = function () { + // check min has been calculated before + if (this._min === null) { + // minimum + let m = null; + // compute min + this.forEach(function (v) { + if (m === null || smaller(v, m)) { + m = v; + } + }); + this._min = m !== null ? m : undefined; + } + return this._min; + }; + + /** + * Calculate the maximum value in the set + * @return {Number | undefined} max + */ + ImmutableDenseMatrix.prototype.max = function () { + // check max has been calculated before + if (this._max === null) { + // maximum + let m = null; + // compute max + this.forEach(function (v) { + if (m === null || smaller(m, v)) { + m = v; + } + }); + this._max = m !== null ? m : undefined; + } + return this._max; + }; + return ImmutableDenseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Matrix.js new file mode 100644 index 0000000..2c0344d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Matrix.js @@ -0,0 +1,248 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrixClass = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'Matrix'; +const dependencies = []; +const createMatrixClass = exports.createMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * @constructor Matrix + * + * A Matrix is a wrapper around an Array. A matrix can hold a multi dimensional + * array. A matrix can be constructed as: + * + * let matrix = math.matrix(data) + * + * Matrix contains the functions to resize, get and set values, get the size, + * clone the matrix and to convert the matrix to a vector, array, or scalar. + * Furthermore, one can iterate over the matrix using map and forEach. + * The internal Array of the Matrix can be accessed using the function valueOf. + * + * Example usage: + * + * let matrix = math.matrix([[1, 2], [3, 4]]) + * matix.size() // [2, 2] + * matrix.resize([3, 2], 5) + * matrix.valueOf() // [[1, 2], [3, 4], [5, 5]] + * matrix.subset([1,2]) // 3 (indexes are zero-based) + * + */ + function Matrix() { + if (!(this instanceof Matrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + } + + /** + * Attach type information + */ + Matrix.prototype.type = 'Matrix'; + Matrix.prototype.isMatrix = true; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @return {string} The storage format. + */ + Matrix.prototype.storage = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke storage on a Matrix interface'); + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @return {string} The datatype. + */ + Matrix.prototype.datatype = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke datatype on a Matrix interface'); + }; + + /** + * Create a new Matrix With the type of the current matrix instance + * @param {Array | Object} data + * @param {string} [datatype] + */ + Matrix.prototype.create = function (data, datatype) { + throw new Error('Cannot invoke create on a Matrix interface'); + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + Matrix.prototype.subset = function (index, replacement, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke subset on a Matrix interface'); + }; + + /** + * Get a single element from the matrix. + * @param {number[]} index Zero-based index + * @return {*} value + */ + Matrix.prototype.get = function (index) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke get on a Matrix interface'); + }; + + /** + * Replace a single element in the matrix. + * @param {number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {Matrix} self + */ + Matrix.prototype.set = function (index, value, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke set on a Matrix interface'); + }; + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @param {number[]} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + Matrix.prototype.resize = function (size, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke resize on a Matrix interface'); + }; + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * @param {number[]} size The new size the matrix should have. + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + Matrix.prototype.reshape = function (size, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke reshape on a Matrix interface'); + }; + + /** + * Create a clone of the matrix + * @return {Matrix} clone + */ + Matrix.prototype.clone = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke clone on a Matrix interface'); + }; + + /** + * Retrieve the size of the matrix. + * @returns {number[]} size + */ + Matrix.prototype.size = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke size on a Matrix interface'); + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {Matrix} matrix + */ + Matrix.prototype.map = function (callback, skipZeros) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke map on a Matrix interface'); + }; + + /** + * Execute a callback function on each entry of the matrix. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + */ + Matrix.prototype.forEach = function (callback) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke forEach on a Matrix interface'); + }; + + /** + * Iterate over the matrix elements + * @return {Iterable<{ value, index: number[] }>} + */ + Matrix.prototype[Symbol.iterator] = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot iterate a Matrix interface'); + }; + + /** + * Create an Array with a copy of the data of the Matrix + * @returns {Array} array + */ + Matrix.prototype.toArray = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke toArray on a Matrix interface'); + }; + + /** + * Get the primitive value of the Matrix: a multidimensional array + * @returns {Array} array + */ + Matrix.prototype.valueOf = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke valueOf on a Matrix interface'); + }; + + /** + * Get a string representation of the matrix, with optional formatting options. + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + Matrix.prototype.format = function (options) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke format on a Matrix interface'); + }; + + /** + * Get a string representation of the matrix + * @returns {string} str + */ + Matrix.prototype.toString = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke toString on a Matrix interface'); + }; + return Matrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/MatrixIndex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/MatrixIndex.js new file mode 100644 index 0000000..98f3d78 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/MatrixIndex.js @@ -0,0 +1,304 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIndexClass = void 0; +var _is = require("../../utils/is.js"); +var _object = require("../../utils/object.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'Index'; +const dependencies = ['ImmutableDenseMatrix', 'getMatrixDataType']; +const createIndexClass = exports.createIndexClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + ImmutableDenseMatrix, + getMatrixDataType + } = _ref; + /** + * Create an index. An Index can store ranges and sets for multiple dimensions. + * Matrix.get, Matrix.set, and math.subset accept an Index as input. + * + * Usage: + * const index = new Index(range1, range2, matrix1, array1, ...) + * + * Where each parameter can be any of: + * A number + * A string (containing a name of an object property) + * An instance of Range + * An Array with the Set values + * An Array with Booleans + * A Matrix with the Set values + * A Matrix with Booleans + * + * The parameters start, end, and step must be integer numbers. + * + * @class Index + * @Constructor Index + * @param {...*} ranges + */ + function Index(ranges) { + if (!(this instanceof Index)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this._dimensions = []; + this._sourceSize = []; + this._isScalar = true; + for (let i = 0, ii = arguments.length; i < ii; i++) { + const arg = arguments[i]; + const argIsArray = (0, _is.isArray)(arg); + const argIsMatrix = (0, _is.isMatrix)(arg); + let sourceSize = null; + if ((0, _is.isRange)(arg)) { + this._dimensions.push(arg); + this._isScalar = false; + } else if (argIsArray || argIsMatrix) { + // create matrix + let m; + if (getMatrixDataType(arg) === 'boolean') { + if (argIsArray) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg).valueOf()); + if (argIsMatrix) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg._data).valueOf()); + sourceSize = arg.valueOf().length; + } else { + m = _createImmutableMatrix(arg.valueOf()); + } + this._dimensions.push(m); + // size + const size = m.size(); + // scalar + if (size.length !== 1 || size[0] !== 1 || sourceSize !== null) { + this._isScalar = false; + } + } else if (typeof arg === 'number') { + this._dimensions.push(_createImmutableMatrix([arg])); + } else if (typeof arg === 'string') { + // object property (arguments.count should be 1) + this._dimensions.push(arg); + } else { + throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range'); + } + this._sourceSize.push(sourceSize); + // TODO: implement support for wildcard '*' + } + } + + /** + * Attach type information + */ + Index.prototype.type = 'Index'; + Index.prototype.isIndex = true; + function _createImmutableMatrix(arg) { + // loop array elements + for (let i = 0, l = arg.length; i < l; i++) { + if (typeof arg[i] !== 'number' || !(0, _number.isInteger)(arg[i])) { + throw new TypeError('Index parameters must be positive integer numbers'); + } + } + // create matrix + return new ImmutableDenseMatrix(arg); + } + + /** + * Create a clone of the index + * @memberof Index + * @return {Index} clone + */ + Index.prototype.clone = function () { + const index = new Index(); + index._dimensions = (0, _object.clone)(this._dimensions); + index._isScalar = this._isScalar; + index._sourceSize = this._sourceSize; + return index; + }; + + /** + * Create an index from an array with ranges/numbers + * @memberof Index + * @param {Array.} ranges + * @return {Index} index + * @private + */ + Index.create = function (ranges) { + const index = new Index(); + Index.apply(index, ranges); + return index; + }; + + /** + * Retrieve the size of the index, the number of elements for each dimension. + * @memberof Index + * @returns {number[]} size + */ + Index.prototype.size = function () { + const size = []; + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + const d = this._dimensions[i]; + size[i] = typeof d === 'string' ? 1 : d.size()[0]; + } + return size; + }; + + /** + * Get the maximum value for each of the indexes ranges. + * @memberof Index + * @returns {number[]} max + */ + Index.prototype.max = function () { + const values = []; + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + const range = this._dimensions[i]; + values[i] = typeof range === 'string' ? range : range.max(); + } + return values; + }; + + /** + * Get the minimum value for each of the indexes ranges. + * @memberof Index + * @returns {number[]} min + */ + Index.prototype.min = function () { + const values = []; + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + const range = this._dimensions[i]; + values[i] = typeof range === 'string' ? range : range.min(); + } + return values; + }; + + /** + * Loop over each of the ranges of the index + * @memberof Index + * @param {Function} callback Called for each range with a Range as first + * argument, the dimension as second, and the + * index object as third. + */ + Index.prototype.forEach = function (callback) { + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + callback(this._dimensions[i], i, this); + } + }; + + /** + * Retrieve the dimension for the given index + * @memberof Index + * @param {Number} dim Number of the dimension + * @returns {Range | null} range + */ + Index.prototype.dimension = function (dim) { + return this._dimensions[dim] || null; + }; + + /** + * Test whether this index contains an object property + * @returns {boolean} Returns true if the index is an object property + */ + Index.prototype.isObjectProperty = function () { + return this._dimensions.length === 1 && typeof this._dimensions[0] === 'string'; + }; + + /** + * Returns the object property name when the Index holds a single object property, + * else returns null + * @returns {string | null} + */ + Index.prototype.getObjectProperty = function () { + return this.isObjectProperty() ? this._dimensions[0] : null; + }; + + /** + * Test whether this index contains only a single value. + * + * This is the case when the index is created with only scalar values as ranges, + * not for ranges resolving into a single value. + * @memberof Index + * @return {boolean} isScalar + */ + Index.prototype.isScalar = function () { + return this._isScalar; + }; + + /** + * Expand the Index into an array. + * For example new Index([0,3], [2,7]) returns [[0,1,2], [2,3,4,5,6]] + * @memberof Index + * @returns {Array} array + */ + Index.prototype.toArray = function () { + const array = []; + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + const dimension = this._dimensions[i]; + array.push(typeof dimension === 'string' ? dimension : dimension.toArray()); + } + return array; + }; + + /** + * Get the primitive value of the Index, a two dimensional array. + * Equivalent to Index.toArray(). + * @memberof Index + * @returns {Array} array + */ + Index.prototype.valueOf = Index.prototype.toArray; + + /** + * Get the string representation of the index, for example '[2:6]' or '[0:2:10, 4:7, [1,2,3]]' + * @memberof Index + * @returns {String} str + */ + Index.prototype.toString = function () { + const strings = []; + for (let i = 0, ii = this._dimensions.length; i < ii; i++) { + const dimension = this._dimensions[i]; + if (typeof dimension === 'string') { + strings.push(JSON.stringify(dimension)); + } else { + strings.push(dimension.toString()); + } + } + return '[' + strings.join(', ') + ']'; + }; + + /** + * Get a JSON representation of the Index + * @memberof Index + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Index", "ranges": [{"mathjs": "Range", start: 0, end: 10, step:1}, ...]}` + */ + Index.prototype.toJSON = function () { + return { + mathjs: 'Index', + dimensions: this._dimensions + }; + }; + + /** + * Instantiate an Index from a JSON object + * @memberof Index + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Index", "dimensions": [{"mathjs": "Range", start: 0, end: 10, step:1}, ...]}` + * @return {Index} + */ + Index.fromJSON = function (json) { + return Index.create(json.dimensions); + }; + return Index; +}, { + isClass: true +}); + +/** + * Receives an array of booleans and returns an array of Numbers for Index + * @param {Array} booleanArrayIndex An array of booleans + * @return {Array} A set of numbers ready for index + */ +function _booleansArrayToNumbersForIndex(booleanArrayIndex) { + // gets an array of booleans and returns an array of numbers + const indexOfNumbers = []; + booleanArrayIndex.forEach((bool, idx) => { + if (bool) { + indexOfNumbers.push(idx); + } + }); + return indexOfNumbers; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Range.js new file mode 100644 index 0000000..ed0d58e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Range.js @@ -0,0 +1,310 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createRangeClass = void 0; +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +var _factory = require("../../utils/factory.js"); +const name = 'Range'; +const dependencies = []; +const createRangeClass = exports.createRangeClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * Create a range. A range has a start, step, and end, and contains functions + * to iterate over the range. + * + * A range can be constructed as: + * + * const range = new Range(start, end) + * const range = new Range(start, end, step) + * + * To get the result of the range: + * range.forEach(function (x) { + * console.log(x) + * }) + * range.map(function (x) { + * return math.sin(x) + * }) + * range.toArray() + * + * Example usage: + * + * const c = new Range(2, 6) // 2:1:5 + * c.toArray() // [2, 3, 4, 5] + * const d = new Range(2, -3, -1) // 2:-1:-2 + * d.toArray() // [2, 1, 0, -1, -2] + * + * @class Range + * @constructor Range + * @param {number} start included lower bound + * @param {number} end excluded upper bound + * @param {number} [step] step size, default value is 1 + */ + function Range(start, end, step) { + if (!(this instanceof Range)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + const hasStart = start !== null && start !== undefined; + const hasEnd = end !== null && end !== undefined; + const hasStep = step !== null && step !== undefined; + if (hasStart) { + if ((0, _is.isBigNumber)(start)) { + start = start.toNumber(); + } else if (typeof start !== 'number') { + throw new TypeError('Parameter start must be a number'); + } + } + if (hasEnd) { + if ((0, _is.isBigNumber)(end)) { + end = end.toNumber(); + } else if (typeof end !== 'number') { + throw new TypeError('Parameter end must be a number'); + } + } + if (hasStep) { + if ((0, _is.isBigNumber)(step)) { + step = step.toNumber(); + } else if (typeof step !== 'number') { + throw new TypeError('Parameter step must be a number'); + } + } + this.start = hasStart ? parseFloat(start) : 0; + this.end = hasEnd ? parseFloat(end) : 0; + this.step = hasStep ? parseFloat(step) : 1; + } + + /** + * Attach type information + */ + Range.prototype.type = 'Range'; + Range.prototype.isRange = true; + + /** + * Parse a string into a range, + * The string contains the start, optional step, and end, separated by a colon. + * If the string does not contain a valid range, null is returned. + * For example str='0:2:11'. + * @memberof Range + * @param {string} str + * @return {Range | null} range + */ + Range.parse = function (str) { + if (typeof str !== 'string') { + return null; + } + const args = str.split(':'); + const nums = args.map(function (arg) { + return parseFloat(arg); + }); + const invalid = nums.some(function (num) { + return isNaN(num); + }); + if (invalid) { + return null; + } + switch (nums.length) { + case 2: + return new Range(nums[0], nums[1]); + case 3: + return new Range(nums[0], nums[2], nums[1]); + default: + return null; + } + }; + + /** + * Create a clone of the range + * @return {Range} clone + */ + Range.prototype.clone = function () { + return new Range(this.start, this.end, this.step); + }; + + /** + * Retrieve the size of the range. + * Returns an array containing one number, the number of elements in the range. + * @memberof Range + * @returns {number[]} size + */ + Range.prototype.size = function () { + let len = 0; + const start = this.start; + const step = this.step; + const end = this.end; + const diff = end - start; + if ((0, _number.sign)(step) === (0, _number.sign)(diff)) { + len = Math.ceil(diff / step); + } else if (diff === 0) { + len = 0; + } + if (isNaN(len)) { + len = 0; + } + return [len]; + }; + + /** + * Calculate the minimum value in the range + * @memberof Range + * @return {number | undefined} min + */ + Range.prototype.min = function () { + const size = this.size()[0]; + if (size > 0) { + if (this.step > 0) { + // positive step + return this.start; + } else { + // negative step + return this.start + (size - 1) * this.step; + } + } else { + return undefined; + } + }; + + /** + * Calculate the maximum value in the range + * @memberof Range + * @return {number | undefined} max + */ + Range.prototype.max = function () { + const size = this.size()[0]; + if (size > 0) { + if (this.step > 0) { + // positive step + return this.start + (size - 1) * this.step; + } else { + // negative step + return this.start; + } + } else { + return undefined; + } + }; + + /** + * Execute a callback function for each value in the range. + * @memberof Range + * @param {function} callback The callback method is invoked with three + * parameters: the value of the element, the index + * of the element, and the Range being traversed. + */ + Range.prototype.forEach = function (callback) { + let x = this.start; + const step = this.step; + const end = this.end; + let i = 0; + if (step > 0) { + while (x < end) { + callback(x, [i], this); + x += step; + i++; + } + } else if (step < 0) { + while (x > end) { + callback(x, [i], this); + x += step; + i++; + } + } + }; + + /** + * Execute a callback function for each value in the Range, and return the + * results as an array + * @memberof Range + * @param {function} callback The callback method is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @returns {Array} array + */ + Range.prototype.map = function (callback) { + const array = []; + this.forEach(function (value, index, obj) { + array[index[0]] = callback(value, index, obj); + }); + return array; + }; + + /** + * Create an Array with a copy of the Ranges data + * @memberof Range + * @returns {Array} array + */ + Range.prototype.toArray = function () { + const array = []; + this.forEach(function (value, index) { + array[index[0]] = value; + }); + return array; + }; + + /** + * Get the primitive value of the Range, a one dimensional array + * @memberof Range + * @returns {Array} array + */ + Range.prototype.valueOf = function () { + // TODO: implement a caching mechanism for range.valueOf() + return this.toArray(); + }; + + /** + * Get a string representation of the range, with optional formatting options. + * Output is formatted as 'start:step:end', for example '2:6' or '0:0.2:11' + * @memberof Range + * @param {Object | number | function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + Range.prototype.format = function (options) { + let str = (0, _number.format)(this.start, options); + if (this.step !== 1) { + str += ':' + (0, _number.format)(this.step, options); + } + str += ':' + (0, _number.format)(this.end, options); + return str; + }; + + /** + * Get a string representation of the range. + * @memberof Range + * @returns {string} + */ + Range.prototype.toString = function () { + return this.format(); + }; + + /** + * Get a JSON representation of the range + * @memberof Range + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Range", "start": 2, "end": 4, "step": 1}` + */ + Range.prototype.toJSON = function () { + return { + mathjs: 'Range', + start: this.start, + end: this.end, + step: this.step + }; + }; + + /** + * Instantiate a Range from a JSON object + * @memberof Range + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Range", "start": 2, "end": 4, "step": 1}` + * @return {Range} + */ + Range.fromJSON = function (json) { + return new Range(json.start, json.end, json.step); + }; + return Range; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Spa.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Spa.js new file mode 100644 index 0000000..b38bea2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/Spa.js @@ -0,0 +1,142 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSpaClass = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'Spa'; +const dependencies = ['addScalar', 'equalScalar', 'FibonacciHeap']; +const createSpaClass = exports.createSpaClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + addScalar, + equalScalar, + FibonacciHeap + } = _ref; + /** + * An ordered Sparse Accumulator is a representation for a sparse vector that includes a dense array + * of the vector elements and an ordered list of non-zero elements. + */ + function Spa() { + if (!(this instanceof Spa)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + + // allocate vector, TODO use typed arrays + this._values = []; + this._heap = new FibonacciHeap(); + } + + /** + * Attach type information + */ + Spa.prototype.type = 'Spa'; + Spa.prototype.isSpa = true; + + /** + * Set the value for index i. + * + * @param {number} i The index + * @param {number | BigNumber | Complex} The value at index i + */ + Spa.prototype.set = function (i, v) { + // check we have a value @ i + if (!this._values[i]) { + // insert in heap + const node = this._heap.insert(i, v); + // set the value @ i + this._values[i] = node; + } else { + // update the value @ i + this._values[i].value = v; + } + }; + Spa.prototype.get = function (i) { + const node = this._values[i]; + if (node) { + return node.value; + } + return 0; + }; + Spa.prototype.accumulate = function (i, v) { + // node @ i + let node = this._values[i]; + if (!node) { + // insert in heap + node = this._heap.insert(i, v); + // initialize value + this._values[i] = node; + } else { + // accumulate value + node.value = addScalar(node.value, v); + } + }; + Spa.prototype.forEach = function (from, to, callback) { + // references + const heap = this._heap; + const values = this._values; + // nodes + const nodes = []; + // node with minimum key, save it + let node = heap.extractMinimum(); + if (node) { + nodes.push(node); + } + // extract nodes from heap (ordered) + while (node && node.key <= to) { + // check it is in range + if (node.key >= from) { + // check value is not zero + if (!equalScalar(node.value, 0)) { + // invoke callback + callback(node.key, node.value, this); + } + } + // extract next node, save it + node = heap.extractMinimum(); + if (node) { + nodes.push(node); + } + } + // reinsert all nodes in heap + for (let i = 0; i < nodes.length; i++) { + // current node + const n = nodes[i]; + // insert node in heap + node = heap.insert(n.key, n.value); + // update values + values[node.key] = node; + } + }; + Spa.prototype.swap = function (i, j) { + // node @ i and j + let nodei = this._values[i]; + let nodej = this._values[j]; + // check we need to insert indeces + if (!nodei && nodej) { + // insert in heap + nodei = this._heap.insert(i, nodej.value); + // remove from heap + this._heap.remove(nodej); + // set values + this._values[i] = nodei; + this._values[j] = undefined; + } else if (nodei && !nodej) { + // insert in heap + nodej = this._heap.insert(j, nodei.value); + // remove from heap + this._heap.remove(nodei); + // set values + this._values[j] = nodej; + this._values[i] = undefined; + } else if (nodei && nodej) { + // swap values + const v = nodei.value; + nodei.value = nodej.value; + nodej.value = v; + } + }; + return Spa; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/SparseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/SparseMatrix.js new file mode 100644 index 0000000..328b46c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/SparseMatrix.js @@ -0,0 +1,1492 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSparseMatrixClass = void 0; +var _is = require("../../utils/is.js"); +var _number = require("../../utils/number.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +var _array = require("../../utils/array.js"); +var _factory = require("../../utils/factory.js"); +var _DimensionError = require("../../error/DimensionError.js"); +var _optimizeCallback = require("../../utils/optimizeCallback.js"); +const name = 'SparseMatrix'; +const dependencies = ['typed', 'equalScalar', 'Matrix']; +const createSparseMatrixClass = exports.createSparseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar, + Matrix + } = _ref; + /** + * Sparse Matrix implementation. This type implements + * a [Compressed Column Storage](https://en.wikipedia.org/wiki/Sparse_matrix#Compressed_sparse_column_(CSC_or_CCS)) + * format for two-dimensional sparse matrices. + * @class SparseMatrix + */ + function SparseMatrix(data, datatype) { + if (!(this instanceof SparseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !(0, _is.isString)(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if ((0, _is.isMatrix)(data)) { + // create from matrix + _createFromMatrix(this, data, datatype); + } else if (data && (0, _is.isArray)(data.index) && (0, _is.isArray)(data.ptr) && (0, _is.isArray)(data.size)) { + // initialize fields + this._values = data.values; + this._index = data.index; + this._ptr = data.ptr; + this._size = data.size; + this._datatype = datatype || data.datatype; + } else if ((0, _is.isArray)(data)) { + // create from array + _createFromArray(this, data, datatype); + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')'); + } else { + // nothing provided + this._values = []; + this._index = []; + this._ptr = [0]; + this._size = [0, 0]; + this._datatype = datatype; + } + } + function _createFromMatrix(matrix, source, datatype) { + // check matrix type + if (source.type === 'SparseMatrix') { + // clone arrays + matrix._values = source._values ? (0, _object.clone)(source._values) : undefined; + matrix._index = (0, _object.clone)(source._index); + matrix._ptr = (0, _object.clone)(source._ptr); + matrix._size = (0, _object.clone)(source._size); + matrix._datatype = datatype || source._datatype; + } else { + // build from matrix data + _createFromArray(matrix, source.valueOf(), datatype || source._datatype); + } + } + function _createFromArray(matrix, data, datatype) { + // initialize fields + matrix._values = []; + matrix._index = []; + matrix._ptr = []; + matrix._datatype = datatype; + // discover rows & columns, do not use math.size() to avoid looping array twice + const rows = data.length; + let columns = 0; + + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + if ((0, _is.isString)(datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, datatype); + } + + // check we have rows (empty array) + if (rows > 0) { + // column index + let j = 0; + do { + // store pointer to values index + matrix._ptr.push(matrix._index.length); + // loop rows + for (let i = 0; i < rows; i++) { + // current row + const row = data[i]; + // check row is an array + if ((0, _is.isArray)(row)) { + // update columns if needed (only on first column) + if (j === 0 && columns < row.length) { + columns = row.length; + } + // check row has column + if (j < row.length) { + // value + const v = row[j]; + // check value != 0 + if (!eq(v, zero)) { + // store value + matrix._values.push(v); + // index + matrix._index.push(i); + } + } + } else { + // update columns if needed (only on first column) + if (j === 0 && columns < 1) { + columns = 1; + } + // check value != 0 (row is a scalar) + if (!eq(row, zero)) { + // store value + matrix._values.push(row); + // index + matrix._index.push(i); + } + } + } + // increment index + j++; + } while (j < columns); + } + // store number of values in ptr + matrix._ptr.push(matrix._index.length); + // size + matrix._size = [rows, columns]; + } + SparseMatrix.prototype = new Matrix(); + + /** + * Create a new SparseMatrix + */ + SparseMatrix.prototype.createSparseMatrix = function (data, datatype) { + return new SparseMatrix(data, datatype); + }; + + /** + * Attach type information + */ + Object.defineProperty(SparseMatrix, 'name', { + value: 'SparseMatrix' + }); + SparseMatrix.prototype.constructor = SparseMatrix; + SparseMatrix.prototype.type = 'SparseMatrix'; + SparseMatrix.prototype.isSparseMatrix = true; + + /** + * Get the matrix type + * + * Usage: + * const matrixType = matrix.getDataType() // retrieves the matrix type + * + * @memberOf SparseMatrix + * @return {string} type information; if multiple types are found from the Matrix, it will return "mixed" + */ + SparseMatrix.prototype.getDataType = function () { + return (0, _array.getArrayDataType)(this._values, _is.typeOf); + }; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @memberof SparseMatrix + * @return {string} The storage format. + */ + SparseMatrix.prototype.storage = function () { + return 'sparse'; + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @memberof SparseMatrix + * @return {string} The datatype. + */ + SparseMatrix.prototype.datatype = function () { + return this._datatype; + }; + + /** + * Create a new SparseMatrix + * @memberof SparseMatrix + * @param {Array} data + * @param {string} [datatype] + */ + SparseMatrix.prototype.create = function (data, datatype) { + return new SparseMatrix(data, datatype); + }; + + /** + * Get the matrix density. + * + * Usage: + * const density = matrix.density() // retrieve matrix density + * + * @memberof SparseMatrix + * @return {number} The matrix density. + */ + SparseMatrix.prototype.density = function () { + // rows & columns + const rows = this._size[0]; + const columns = this._size[1]; + // calculate density + return rows !== 0 && columns !== 0 ? this._index.length / (rows * columns) : 0; + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @memberof SparseMatrix + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + SparseMatrix.prototype.subset = function (index, replacement, defaultValue) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke subset on a Pattern only matrix'); + } + + // check arguments + switch (arguments.length) { + case 1: + return _getsubset(this, index); + + // intentional fall through + case 2: + case 3: + return _setsubset(this, index, replacement, defaultValue); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + function _getsubset(matrix, idx) { + // check idx + if (!(0, _is.isIndex)(idx)) { + throw new TypeError('Invalid index'); + } + const isScalar = idx.isScalar(); + if (isScalar) { + // return a scalar + return matrix.get(idx.min()); + } + // validate dimensions + const size = idx.size(); + if (size.length !== matrix._size.length) { + throw new _DimensionError.DimensionError(size.length, matrix._size.length); + } + + // vars + let i, ii, k, kk; + + // validate if any of the ranges in the index is out of range + const min = idx.min(); + const max = idx.max(); + for (i = 0, ii = matrix._size.length; i < ii; i++) { + (0, _array.validateIndex)(min[i], matrix._size[i]); + (0, _array.validateIndex)(max[i], matrix._size[i]); + } + + // matrix arrays + const mvalues = matrix._values; + const mindex = matrix._index; + const mptr = matrix._ptr; + + // rows & columns dimensions for result matrix + const rows = idx.dimension(0); + const columns = idx.dimension(1); + + // workspace & permutation vector + const w = []; + const pv = []; + + // loop rows in resulting matrix + rows.forEach(function (i, r) { + // update permutation vector + pv[i] = r[0]; + // mark i in workspace + w[i] = true; + }); + + // result matrix arrays + const values = mvalues ? [] : undefined; + const index = []; + const ptr = []; + + // loop columns in result matrix + columns.forEach(function (j) { + // update ptr + ptr.push(index.length); + // loop values in column j + for (k = mptr[j], kk = mptr[j + 1]; k < kk; k++) { + // row + i = mindex[k]; + // check row is in result matrix + if (w[i] === true) { + // push index + index.push(pv[i]); + // check we need to process values + if (values) { + values.push(mvalues[k]); + } + } + } + }); + // update ptr + ptr.push(index.length); + + // return matrix + return new SparseMatrix({ + values, + index, + ptr, + size, + datatype: matrix._datatype + }); + } + function _setsubset(matrix, index, submatrix, defaultValue) { + // check index + if (!index || index.isIndex !== true) { + throw new TypeError('Invalid index'); + } + + // get index size and check whether the index contains a single value + const iSize = index.size(); + const isScalar = index.isScalar(); + + // calculate the size of the submatrix, and convert it into an Array if needed + let sSize; + if ((0, _is.isMatrix)(submatrix)) { + // submatrix size + sSize = submatrix.size(); + // use array representation + submatrix = submatrix.toArray(); + } else { + // get submatrix size (array, scalar) + sSize = (0, _array.arraySize)(submatrix); + } + + // check index is a scalar + if (isScalar) { + // verify submatrix is a scalar + if (sSize.length !== 0) { + throw new TypeError('Scalar expected'); + } + // set value + matrix.set(index.min(), submatrix, defaultValue); + } else { + // validate dimensions, index size must be one or two dimensions + if (iSize.length !== 1 && iSize.length !== 2) { + throw new _DimensionError.DimensionError(iSize.length, matrix._size.length, '<'); + } + + // check submatrix and index have the same dimensions + if (sSize.length < iSize.length) { + // calculate number of missing outer dimensions + let i = 0; + let outer = 0; + while (iSize[i] === 1 && sSize[i] === 1) { + i++; + } + while (iSize[i] === 1) { + outer++; + i++; + } + // unsqueeze both outer and inner dimensions + submatrix = (0, _array.unsqueeze)(submatrix, iSize.length, outer, sSize); + } + + // check whether the size of the submatrix matches the index size + if (!(0, _object.deepStrictEqual)(iSize, sSize)) { + throw new _DimensionError.DimensionError(iSize, sSize, '>'); + } + + // insert the sub matrix + if (iSize.length === 1) { + // if the replacement index only has 1 dimension, go trough each one and set its value + const range = index.dimension(0); + range.forEach(function (dataIndex, subIndex) { + (0, _array.validateIndex)(dataIndex); + matrix.set([dataIndex, 0], submatrix[subIndex[0]], defaultValue); + }); + } else { + // if the replacement index has 2 dimensions, go through each one and set the value in the correct index + const firstDimensionRange = index.dimension(0); + const secondDimensionRange = index.dimension(1); + firstDimensionRange.forEach(function (firstDataIndex, firstSubIndex) { + (0, _array.validateIndex)(firstDataIndex); + secondDimensionRange.forEach(function (secondDataIndex, secondSubIndex) { + (0, _array.validateIndex)(secondDataIndex); + matrix.set([firstDataIndex, secondDataIndex], submatrix[firstSubIndex[0]][secondSubIndex[0]], defaultValue); + }); + }); + } + } + return matrix; + } + + /** + * Get a single element from the matrix. + * @memberof SparseMatrix + * @param {number[]} index Zero-based index + * @return {*} value + */ + SparseMatrix.prototype.get = function (index) { + if (!(0, _is.isArray)(index)) { + throw new TypeError('Array expected'); + } + if (index.length !== this._size.length) { + throw new _DimensionError.DimensionError(index.length, this._size.length); + } + + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke get on a Pattern only matrix'); + } + + // row and column + const i = index[0]; + const j = index[1]; + + // check i, j are valid + (0, _array.validateIndex)(i, this._size[0]); + (0, _array.validateIndex)(j, this._size[1]); + + // find value index + const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); + // check k is prior to next column k and it is in the correct row + if (k < this._ptr[j + 1] && this._index[k] === i) { + return this._values[k]; + } + return 0; + }; + + /** + * Replace a single element in the matrix. + * @memberof SparseMatrix + * @param {number[]} index Zero-based index + * @param {*} v + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be set to zero. + * @return {SparseMatrix} self + */ + SparseMatrix.prototype.set = function (index, v, defaultValue) { + if (!(0, _is.isArray)(index)) { + throw new TypeError('Array expected'); + } + if (index.length !== this._size.length) { + throw new _DimensionError.DimensionError(index.length, this._size.length); + } + + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke set on a Pattern only matrix'); + } + + // row and column + const i = index[0]; + const j = index[1]; + + // rows & columns + let rows = this._size[0]; + let columns = this._size[1]; + + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + if ((0, _is.isString)(this._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [this._datatype, this._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, this._datatype); + } + + // check we need to resize matrix + if (i > rows - 1 || j > columns - 1) { + // resize matrix + _resize(this, Math.max(i + 1, rows), Math.max(j + 1, columns), defaultValue); + // update rows & columns + rows = this._size[0]; + columns = this._size[1]; + } + + // check i, j are valid + (0, _array.validateIndex)(i, rows); + (0, _array.validateIndex)(j, columns); + + // find value index + const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); + // check k is prior to next column k and it is in the correct row + if (k < this._ptr[j + 1] && this._index[k] === i) { + // check value != 0 + if (!eq(v, zero)) { + // update value + this._values[k] = v; + } else { + // remove value from matrix + _remove(k, j, this._values, this._index, this._ptr); + } + } else { + if (!eq(v, zero)) { + // insert value @ (i, j) + _insert(k, i, j, v, this._values, this._index, this._ptr); + } + } + return this; + }; + function _getValueIndex(i, top, bottom, index) { + // check row is on the bottom side + if (bottom - top === 0) { + return bottom; + } + // loop rows [top, bottom[ + for (let r = top; r < bottom; r++) { + // check we found value index + if (index[r] === i) { + return r; + } + } + // we did not find row + return top; + } + function _remove(k, j, values, index, ptr) { + // remove value @ k + values.splice(k, 1); + index.splice(k, 1); + // update pointers + for (let x = j + 1; x < ptr.length; x++) { + ptr[x]--; + } + } + function _insert(k, i, j, v, values, index, ptr) { + // insert value + values.splice(k, 0, v); + // update row for k + index.splice(k, 0, i); + // update column pointers + for (let x = j + 1; x < ptr.length; x++) { + ptr[x]++; + } + } + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @memberof SparseMatrix + * @param {number[] | Matrix} size The new size the matrix should have. + * Since sparse matrices are always two-dimensional, + * size must be two numbers in either an array or a matrix + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + SparseMatrix.prototype.resize = function (size, defaultValue, copy) { + // validate arguments + if (!(0, _is.isCollection)(size)) { + throw new TypeError('Array or Matrix expected'); + } + + // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector + const sizeArray = size.valueOf().map(value => { + return Array.isArray(value) && value.length === 1 ? value[0] : value; + }); + if (sizeArray.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // check sizes + sizeArray.forEach(function (value) { + if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value < 0) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(sizeArray) + ')'); + } + }); + + // matrix to resize + const m = copy ? this.clone() : this; + // resize matrix + return _resize(m, sizeArray[0], sizeArray[1], defaultValue); + }; + function _resize(matrix, rows, columns, defaultValue) { + // value to insert at the time of growing matrix + let value = defaultValue || 0; + + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + if ((0, _is.isString)(matrix._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, matrix._datatype); + // convert value to the same datatype + value = typed.convert(value, matrix._datatype); + } + + // should we insert the value? + const ins = !eq(value, zero); + + // old columns and rows + const r = matrix._size[0]; + let c = matrix._size[1]; + let i, j, k; + + // check we need to increase columns + if (columns > c) { + // loop new columns + for (j = c; j < columns; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._values.length; + // check we need to insert matrix._values + if (ins) { + // loop rows + for (i = 0; i < r; i++) { + // add new matrix._values + matrix._values.push(value); + // update matrix._index + matrix._index.push(i); + } + } + } + // store number of matrix._values in matrix._ptr + matrix._ptr[columns] = matrix._values.length; + } else if (columns < c) { + // truncate matrix._ptr + matrix._ptr.splice(columns + 1, c - columns); + // truncate matrix._values and matrix._index + matrix._values.splice(matrix._ptr[columns], matrix._values.length); + matrix._index.splice(matrix._ptr[columns], matrix._index.length); + } + // update columns + c = columns; + + // check we need to increase rows + if (rows > r) { + // check we have to insert values + if (ins) { + // inserts + let n = 0; + // loop columns + for (j = 0; j < c; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._ptr[j] + n; + // where to insert matrix._values + k = matrix._ptr[j + 1] + n; + // pointer + let p = 0; + // loop new rows, initialize pointer + for (i = r; i < rows; i++, p++) { + // add value + matrix._values.splice(k + p, 0, value); + // update matrix._index + matrix._index.splice(k + p, 0, i); + // increment inserts + n++; + } + } + // store number of matrix._values in matrix._ptr + matrix._ptr[c] = matrix._values.length; + } + } else if (rows < r) { + // deletes + let d = 0; + // loop columns + for (j = 0; j < c; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._ptr[j] - d; + // where matrix._values start for next column + const k0 = matrix._ptr[j]; + const k1 = matrix._ptr[j + 1] - d; + // loop matrix._index + for (k = k0; k < k1; k++) { + // row + i = matrix._index[k]; + // check we need to delete value and matrix._index + if (i > rows - 1) { + // remove value + matrix._values.splice(k, 1); + // remove item from matrix._index + matrix._index.splice(k, 1); + // increase deletes + d++; + } + } + } + // update matrix._ptr for current column + matrix._ptr[j] = matrix._values.length; + } + // update matrix._size + matrix._size[0] = rows; + matrix._size[1] = columns; + // return matrix + return matrix; + } + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * NOTE: This might be better suited to copy by default, instead of modifying + * in place. For now, it operates in place to remain consistent with + * resize(). + * + * @memberof SparseMatrix + * @param {number[]} sizes The new size the matrix should have. + * Since sparse matrices are always two-dimensional, + * size must be two numbers in either an array or a matrix + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + SparseMatrix.prototype.reshape = function (sizes, copy) { + // validate arguments + if (!(0, _is.isArray)(sizes)) { + throw new TypeError('Array expected'); + } + if (sizes.length !== 2) { + throw new Error('Sparse matrices can only be reshaped in two dimensions'); + } + + // check sizes + sizes.forEach(function (value) { + if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value <= -2 || value === 0) { + throw new TypeError('Invalid size, must contain positive integers or -1 ' + '(size: ' + (0, _string.format)(sizes) + ')'); + } + }); + const currentLength = this._size[0] * this._size[1]; + sizes = (0, _array.processSizesWildcard)(sizes, currentLength); + const newLength = sizes[0] * sizes[1]; + + // m * n must not change + if (currentLength !== newLength) { + throw new Error('Reshaping sparse matrix will result in the wrong number of elements'); + } + + // matrix to reshape + const m = copy ? this.clone() : this; + + // return unchanged if the same shape + if (this._size[0] === sizes[0] && this._size[1] === sizes[1]) { + return m; + } + + // Convert to COO format (generate a column index) + const colIndex = []; + for (let i = 0; i < m._ptr.length; i++) { + for (let j = 0; j < m._ptr[i + 1] - m._ptr[i]; j++) { + colIndex.push(i); + } + } + + // Clone the values array + const values = m._values.slice(); + + // Clone the row index array + const rowIndex = m._index.slice(); + + // Transform the (row, column) indices + for (let i = 0; i < m._index.length; i++) { + const r1 = rowIndex[i]; + const c1 = colIndex[i]; + const flat = r1 * m._size[1] + c1; + colIndex[i] = flat % sizes[1]; + rowIndex[i] = Math.floor(flat / sizes[1]); + } + + // Now reshaping is supposed to preserve the row-major order, BUT these sparse matrices are stored + // in column-major order, so we have to reorder the value array now. One option is to use a multisort, + // sorting several arrays based on some other array. + + // OR, we could easily just: + + // 1. Remove all values from the matrix + m._values.length = 0; + m._index.length = 0; + m._ptr.length = sizes[1] + 1; + m._size = sizes.slice(); + for (let i = 0; i < m._ptr.length; i++) { + m._ptr[i] = 0; + } + + // 2. Re-insert all elements in the proper order (simplified code from SparseMatrix.prototype.set) + // This step is probably the most time-consuming + for (let h = 0; h < values.length; h++) { + const i = rowIndex[h]; + const j = colIndex[h]; + const v = values[h]; + const k = _getValueIndex(i, m._ptr[j], m._ptr[j + 1], m._index); + _insert(k, i, j, v, m._values, m._index, m._ptr); + } + + // The value indices are inserted out of order, but apparently that's... still OK? + + return m; + }; + + /** + * Create a clone of the matrix + * @memberof SparseMatrix + * @return {SparseMatrix} clone + */ + SparseMatrix.prototype.clone = function () { + const m = new SparseMatrix({ + values: this._values ? (0, _object.clone)(this._values) : undefined, + index: (0, _object.clone)(this._index), + ptr: (0, _object.clone)(this._ptr), + size: (0, _object.clone)(this._size), + datatype: this._datatype + }); + return m; + }; + + /** + * Retrieve the size of the matrix. + * @memberof SparseMatrix + * @returns {number[]} size + */ + SparseMatrix.prototype.size = function () { + return this._size.slice(0); // copy the Array + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @memberof SparseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {SparseMatrix} matrix + */ + SparseMatrix.prototype.map = function (callback, skipZeros) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke map on a Pattern only matrix'); + } + // matrix instance + const me = this; + // rows and columns + const rows = this._size[0]; + const columns = this._size[1]; + const fastCallback = (0, _optimizeCallback.optimizeCallback)(callback, me, 'map'); + // invoke callback + const invoke = function (v, i, j) { + // invoke callback + return fastCallback(v, [i, j], me); + }; + // invoke _map + return _map(this, 0, rows - 1, 0, columns - 1, invoke, skipZeros); + }; + + /** + * Create a new matrix with the results of the callback function executed on the interval + * [minRow..maxRow, minColumn..maxColumn]. + */ + function _map(matrix, minRow, maxRow, minColumn, maxColumn, callback, skipZeros) { + // result arrays + const values = []; + const index = []; + const ptr = []; + + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + if ((0, _is.isString)(matrix._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, matrix._datatype); + } + + // invoke callback + const invoke = function (v, x, y) { + // invoke callback + const value = callback(v, x, y); + // check value != 0 + if (!eq(value, zero)) { + // store value + values.push(value); + // index + index.push(x); + } + }; + // loop columns + for (let j = minColumn; j <= maxColumn; j++) { + // store pointer to values index + ptr.push(values.length); + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = matrix._ptr[j]; + const k1 = matrix._ptr[j + 1]; + if (skipZeros) { + // loop k within [k0, k1[ + for (let k = k0; k < k1; k++) { + // row index + const i = matrix._index[k]; + // check i is in range + if (i >= minRow && i <= maxRow) { + // value @ k + invoke(matrix._values[k], i - minRow, j - minColumn); + } + } + } else { + // create a cache holding all defined values + const values = {}; + for (let k = k0; k < k1; k++) { + const i = matrix._index[k]; + values[i] = matrix._values[k]; + } + + // loop over all rows (indexes can be unordered so we can't use that), + // and either read the value or zero + for (let i = minRow; i <= maxRow; i++) { + const value = i in values ? values[i] : 0; + invoke(value, i - minRow, j - minColumn); + } + } + } + + // store number of values in ptr + ptr.push(values.length); + // return sparse matrix + return new SparseMatrix({ + values, + index, + ptr, + size: [maxRow - minRow + 1, maxColumn - minColumn + 1] + }); + } + + /** + * Execute a callback function on each entry of the matrix. + * @memberof SparseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * If false, the indices are guaranteed to be in order, + * if true, the indices can be unordered. + */ + SparseMatrix.prototype.forEach = function (callback, skipZeros) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke forEach on a Pattern only matrix'); + } + // matrix instance + const me = this; + // rows and columns + const rows = this._size[0]; + const columns = this._size[1]; + const fastCallback = (0, _optimizeCallback.optimizeCallback)(callback, me, 'forEach'); + // loop columns + for (let j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = this._ptr[j]; + const k1 = this._ptr[j + 1]; + if (skipZeros) { + // loop k within [k0, k1[ + for (let k = k0; k < k1; k++) { + // row index + const i = this._index[k]; + + // value @ k + fastCallback(this._values[k], [i, j], me); + } + } else { + // create a cache holding all defined values + const values = {}; + for (let k = k0; k < k1; k++) { + const i = this._index[k]; + values[i] = this._values[k]; + } + + // loop over all rows (indexes can be unordered so we can't use that), + // and either read the value or zero + for (let i = 0; i < rows; i++) { + const value = i in values ? values[i] : 0; + fastCallback(value, [i, j], me); + } + } + } + }; + + /** + * Iterate over the matrix elements, skipping zeros + * @return {Iterable<{ value, index: number[] }>} + */ + SparseMatrix.prototype[Symbol.iterator] = function* () { + if (!this._values) { + throw new Error('Cannot iterate a Pattern only matrix'); + } + const columns = this._size[1]; + for (let j = 0; j < columns; j++) { + const k0 = this._ptr[j]; + const k1 = this._ptr[j + 1]; + for (let k = k0; k < k1; k++) { + // row index + const i = this._index[k]; + yield { + value: this._values[k], + index: [i, j] + }; + } + } + }; + + /** + * Create an Array with a copy of the data of the SparseMatrix + * @memberof SparseMatrix + * @returns {Array} array + */ + SparseMatrix.prototype.toArray = function () { + return _toArray(this._values, this._index, this._ptr, this._size, true); + }; + + /** + * Get the primitive value of the SparseMatrix: a two dimensions array + * @memberof SparseMatrix + * @returns {Array} array + */ + SparseMatrix.prototype.valueOf = function () { + return _toArray(this._values, this._index, this._ptr, this._size, false); + }; + function _toArray(values, index, ptr, size, copy) { + // rows and columns + const rows = size[0]; + const columns = size[1]; + // result + const a = []; + // vars + let i, j; + // initialize array + for (i = 0; i < rows; i++) { + a[i] = []; + for (j = 0; j < columns; j++) { + a[i][j] = 0; + } + } + + // loop columns + for (j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = ptr[j]; + const k1 = ptr[j + 1]; + // loop k within [k0, k1[ + for (let k = k0; k < k1; k++) { + // row index + i = index[k]; + // set value (use one for pattern matrix) + a[i][j] = values ? copy ? (0, _object.clone)(values[k]) : values[k] : 1; + } + } + return a; + } + + /** + * Get a string representation of the matrix, with optional formatting options. + * @memberof SparseMatrix + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + SparseMatrix.prototype.format = function (options) { + // rows and columns + const rows = this._size[0]; + const columns = this._size[1]; + // density + const density = this.density(); + // rows & columns + let str = 'Sparse Matrix [' + (0, _string.format)(rows, options) + ' x ' + (0, _string.format)(columns, options) + '] density: ' + (0, _string.format)(density, options) + '\n'; + // loop columns + for (let j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = this._ptr[j]; + const k1 = this._ptr[j + 1]; + // loop k within [k0, k1[ + for (let k = k0; k < k1; k++) { + // row index + const i = this._index[k]; + // append value + str += '\n (' + (0, _string.format)(i, options) + ', ' + (0, _string.format)(j, options) + ') ==> ' + (this._values ? (0, _string.format)(this._values[k], options) : 'X'); + } + } + return str; + }; + + /** + * Get a string representation of the matrix + * @memberof SparseMatrix + * @returns {string} str + */ + SparseMatrix.prototype.toString = function () { + return (0, _string.format)(this.toArray()); + }; + + /** + * Get a JSON representation of the matrix + * @memberof SparseMatrix + * @returns {Object} + */ + SparseMatrix.prototype.toJSON = function () { + return { + mathjs: 'SparseMatrix', + values: this._values, + index: this._index, + ptr: this._ptr, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Get the kth Matrix diagonal. + * + * @memberof SparseMatrix + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved. + * + * @returns {Matrix} The matrix vector with the diagonal values. + */ + SparseMatrix.prototype.diagonal = function (k) { + // validate k if any + if (k) { + // convert BigNumber to a number + if ((0, _is.isBigNumber)(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + const kSuper = k > 0 ? k : 0; + const kSub = k < 0 ? -k : 0; + + // rows & columns + const rows = this._size[0]; + const columns = this._size[1]; + + // number diagonal values + const n = Math.min(rows - kSub, columns - kSuper); + + // diagonal arrays + const values = []; + const index = []; + const ptr = []; + // initial ptr value + ptr[0] = 0; + // loop columns + for (let j = kSuper; j < columns && values.length < n; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = this._ptr[j]; + const k1 = this._ptr[j + 1]; + // loop x within [k0, k1[ + for (let x = k0; x < k1; x++) { + // row index + const i = this._index[x]; + // check row + if (i === j - kSuper + kSub) { + // value on this column + values.push(this._values[x]); + // store row + index[values.length - 1] = i - kSub; + // exit loop + break; + } + } + } + // close ptr + ptr.push(values.length); + // return matrix + return new SparseMatrix({ + values, + index, + ptr, + size: [n, 1] + }); + }; + + /** + * Generate a matrix from a JSON object + * @memberof SparseMatrix + * @param {Object} json An object structured like + * `{"mathjs": "SparseMatrix", "values": [], "index": [], "ptr": [], "size": []}`, + * where mathjs is optional + * @returns {SparseMatrix} + */ + SparseMatrix.fromJSON = function (json) { + return new SparseMatrix(json); + }; + + /** + * Create a diagonal matrix. + * + * @memberof SparseMatrix + * @param {Array} size The matrix size. + * @param {number | Array | Matrix } value The values for the diagonal. + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in. + * @param {number} [defaultValue] The default value for non-diagonal + * @param {string} [datatype] The Matrix datatype, values must be of this datatype. + * + * @returns {SparseMatrix} + */ + SparseMatrix.diagonal = function (size, value, k, defaultValue, datatype) { + if (!(0, _is.isArray)(size)) { + throw new TypeError('Array expected, size parameter'); + } + if (size.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // map size & validate + size = size.map(function (s) { + // check it is a big number + if ((0, _is.isBigNumber)(s)) { + // convert it + s = s.toNumber(); + } + // validate arguments + if (!(0, _is.isNumber)(s) || !(0, _number.isInteger)(s) || s < 1) { + throw new Error('Size values must be positive integers'); + } + return s; + }); + + // validate k if any + if (k) { + // convert BigNumber to a number + if ((0, _is.isBigNumber)(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + if ((0, _is.isString)(datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, datatype); + } + const kSuper = k > 0 ? k : 0; + const kSub = k < 0 ? -k : 0; + + // rows and columns + const rows = size[0]; + const columns = size[1]; + + // number of non-zero items + const n = Math.min(rows - kSub, columns - kSuper); + + // value extraction function + let _value; + + // check value + if ((0, _is.isArray)(value)) { + // validate array + if (value.length !== n) { + // number of values in array must be n + throw new Error('Invalid value array length'); + } + // define function + _value = function (i) { + // return value @ i + return value[i]; + }; + } else if ((0, _is.isMatrix)(value)) { + // matrix size + const ms = value.size(); + // validate matrix + if (ms.length !== 1 || ms[0] !== n) { + // number of values in array must be n + throw new Error('Invalid matrix length'); + } + // define function + _value = function (i) { + // return value @ i + return value.get([i]); + }; + } else { + // define function + _value = function () { + // return value + return value; + }; + } + + // create arrays + const values = []; + const index = []; + const ptr = []; + + // loop items + for (let j = 0; j < columns; j++) { + // number of rows with value + ptr.push(values.length); + // diagonal index + const i = j - kSuper; + // check we need to set diagonal value + if (i >= 0 && i < n) { + // get value @ i + const v = _value(i); + // check for zero + if (!eq(v, zero)) { + // column + index.push(i + kSub); + // add value + values.push(v); + } + } + } + // last value should be number of values + ptr.push(values.length); + // create SparseMatrix + return new SparseMatrix({ + values, + index, + ptr, + size: [rows, columns] + }); + }; + + /** + * Swap rows i and j in Matrix. + * + * @memberof SparseMatrix + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + SparseMatrix.prototype.swapRows = function (i, j) { + // check index + if (!(0, _is.isNumber)(i) || !(0, _number.isInteger)(i) || !(0, _is.isNumber)(j) || !(0, _number.isInteger)(j)) { + throw new Error('Row index must be positive integers'); + } + // check dimensions + if (this._size.length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + // validate index + (0, _array.validateIndex)(i, this._size[0]); + (0, _array.validateIndex)(j, this._size[0]); + + // swap rows + SparseMatrix._swapRows(i, j, this._size[1], this._values, this._index, this._ptr); + // return current instance + return this; + }; + + /** + * Loop rows with data in column j. + * + * @param {number} j Column + * @param {Array} values Matrix values + * @param {Array} index Matrix row indeces + * @param {Array} ptr Matrix column pointers + * @param {Function} callback Callback function invoked for every row in column j + */ + SparseMatrix._forEachRow = function (j, values, index, ptr, callback) { + // indeces for column j + const k0 = ptr[j]; + const k1 = ptr[j + 1]; + + // loop + for (let k = k0; k < k1; k++) { + // invoke callback + callback(index[k], values[k]); + } + }; + + /** + * Swap rows x and y in Sparse Matrix data structures. + * + * @param {number} x Matrix row index 1 + * @param {number} y Matrix row index 2 + * @param {number} columns Number of columns in matrix + * @param {Array} values Matrix values + * @param {Array} index Matrix row indeces + * @param {Array} ptr Matrix column pointers + */ + SparseMatrix._swapRows = function (x, y, columns, values, index, ptr) { + // loop columns + for (let j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + const k0 = ptr[j]; + const k1 = ptr[j + 1]; + // find value index @ x + const kx = _getValueIndex(x, k0, k1, index); + // find value index @ x + const ky = _getValueIndex(y, k0, k1, index); + // check both rows exist in matrix + if (kx < k1 && ky < k1 && index[kx] === x && index[ky] === y) { + // swap values (check for pattern matrix) + if (values) { + const v = values[kx]; + values[kx] = values[ky]; + values[ky] = v; + } + // next column + continue; + } + // check x row exist & no y row + if (kx < k1 && index[kx] === x && (ky >= k1 || index[ky] !== y)) { + // value @ x (check for pattern matrix) + const vx = values ? values[kx] : undefined; + // insert value @ y + index.splice(ky, 0, y); + if (values) { + values.splice(ky, 0, vx); + } + // remove value @ x (adjust array index if needed) + index.splice(ky <= kx ? kx + 1 : kx, 1); + if (values) { + values.splice(ky <= kx ? kx + 1 : kx, 1); + } + // next column + continue; + } + // check y row exist & no x row + if (ky < k1 && index[ky] === y && (kx >= k1 || index[kx] !== x)) { + // value @ y (check for pattern matrix) + const vy = values ? values[ky] : undefined; + // insert value @ x + index.splice(kx, 0, x); + if (values) { + values.splice(kx, 0, vy); + } + // remove value @ y (adjust array index if needed) + index.splice(kx <= ky ? ky + 1 : ky, 1); + if (values) { + values.splice(kx <= ky ? ky + 1 : ky, 1); + } + } + } + }; + return SparseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/index.js new file mode 100644 index 0000000..fcc8cb0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/index.js @@ -0,0 +1,70 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createIndex = void 0; +var _is = require("../../../utils/is.js"); +var _factory = require("../../../utils/factory.js"); +const name = 'index'; +const dependencies = ['typed', 'Index']; +const createIndex = exports.createIndex = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Index + } = _ref; + /** + * Create an index. An Index can store ranges having start, step, and end + * for multiple dimensions. + * Matrix.get, Matrix.set, and math.subset accept an Index as input. + * + * Syntax: + * + * math.index(range1, range2, ...) + * + * Where each range can be any of: + * + * - A number + * - A string for getting/setting an object property + * - An instance of `Range` + * - A one-dimensional Array or a Matrix with numbers or booleans + * + * Indexes must be zero-based, integer numbers. + * + * Examples: + * + * const b = [1, 2, 3, 4, 5] + * math.subset(b, math.index([1, 2, 3])) // returns [2, 3, 4] + * math.subset(b, math.index([false, true, true, true, false])) // returns [2, 3, 4] + * + * const a = math.matrix([[1, 2], [3, 4]]) + * a.subset(math.index(0, 1)) // returns 2 + * a.subset(math.index(0, [false, true])) // returns 2 + * + * See also: + * + * bignumber, boolean, complex, matrix, number, string, unit + * + * @param {...*} ranges Zero or more ranges or numbers. + * @return {Index} Returns the created index + */ + return typed(name, { + '...number | string | BigNumber | Range | Array | Matrix': function (args) { + const ranges = args.map(function (arg) { + if ((0, _is.isBigNumber)(arg)) { + return arg.toNumber(); // convert BigNumber to Number + } else if ((0, _is.isArray)(arg) || (0, _is.isMatrix)(arg)) { + return arg.map(function (elem) { + // convert BigNumber to Number + return (0, _is.isBigNumber)(elem) ? elem.toNumber() : elem; + }); + } else { + return arg; + } + }); + const res = new Index(); + Index.apply(res, ranges); + return res; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/matrix.js new file mode 100644 index 0000000..0766331 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/matrix.js @@ -0,0 +1,88 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrix = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'matrix'; +const dependencies = ['typed', 'Matrix', 'DenseMatrix', 'SparseMatrix']; +const createMatrix = exports.createMatrix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Matrix, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a Matrix. The function creates a new `math.Matrix` object from + * an `Array`. A Matrix has utility functions to manipulate the data in the + * matrix, like getting the size and getting or setting values in the matrix. + * Supported storage formats are 'dense' and 'sparse'. + * + * Syntax: + * + * math.matrix() // creates an empty matrix using default storage format (dense). + * math.matrix(data) // creates a matrix with initial data using default storage format (dense). + * math.matrix('dense') // creates an empty matrix using the given storage format. + * math.matrix(data, 'dense') // creates a matrix with initial data using the given storage format. + * math.matrix(data, 'sparse') // creates a sparse matrix with initial data. + * math.matrix(data, 'sparse', 'number') // creates a sparse matrix with initial data, number data type. + * + * Examples: + * + * let m = math.matrix([[1, 2], [3, 4]]) + * m.size() // Array [2, 2] + * m.resize([3, 2], 5) + * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]] + * m.get([1, 0]) // number 3 + * + * See also: + * + * bignumber, boolean, complex, index, number, string, unit, sparse + * + * @param {Array | Matrix} [data] A multi dimensional array + * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'` + * @param {string} [datatype] Type of the values + * + * @return {Matrix} The created matrix + */ + return typed(name, { + '': function () { + return _create([]); + }, + string: function (format) { + return _create([], format); + }, + 'string, string': function (format, datatype) { + return _create([], format, datatype); + }, + Array: function (data) { + return _create(data); + }, + Matrix: function (data) { + return _create(data, data.storage()); + }, + 'Array | Matrix, string': _create, + 'Array | Matrix, string, string': _create + }); + + /** + * Create a new Matrix with given storage format + * @param {Array} data + * @param {string} [format] + * @param {string} [datatype] + * @returns {Matrix} Returns a new Matrix + * @private + */ + function _create(data, format, datatype) { + // get storage format constructor + if (format === 'dense' || format === 'default' || format === undefined) { + return new DenseMatrix(data, datatype); + } + if (format === 'sparse') { + return new SparseMatrix(data, datatype); + } + throw new TypeError('Unknown matrix type ' + JSON.stringify(format) + '.'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/sparse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/sparse.js new file mode 100644 index 0000000..38d7ff5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/function/sparse.js @@ -0,0 +1,62 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSparse = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'sparse'; +const dependencies = ['typed', 'SparseMatrix']; +const createSparse = exports.createSparse = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + SparseMatrix + } = _ref; + /** + * Create a Sparse Matrix. The function creates a new `math.Matrix` object from + * an `Array`. A Matrix has utility functions to manipulate the data in the + * matrix, like getting the size and getting or setting values in the matrix. + * Note that a Sparse Matrix is always 2-dimensional, so for example if + * you create one from a plain array of _n_ numbers, you get an _n_ by 1 + * Sparse "column vector". + * + * Syntax: + * + * math.sparse() // creates an empty sparse matrix. + * math.sparse(data) // creates a sparse matrix with initial data. + * math.sparse(data, 'number') // creates a sparse matrix with initial data, number datatype. + * + * Examples: + * + * let m = math.sparse([[1, 2], [3, 4]]) + * m.size() // Array [2, 2] + * m.resize([3, 2], 5) + * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]] + * m.get([1, 0]) // number 3 + * let v = math.sparse([0, 0, 1]) + * v.size() // Array [3, 1] + * v.get([2, 0]) // number 1 + * + * See also: + * + * bignumber, boolean, complex, index, number, string, unit, matrix + * + * @param {Array | Matrix} [data] A two dimensional array + * + * @return {Matrix} The created matrix + */ + return typed(name, { + '': function () { + return new SparseMatrix([]); + }, + string: function (datatype) { + return new SparseMatrix([], datatype); + }, + 'Array | Matrix': function (data) { + return new SparseMatrix(data); + }, + 'Array | Matrix, string': function (data, datatype) { + return new SparseMatrix(data, datatype); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/broadcast.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/broadcast.js new file mode 100644 index 0000000..deb786e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/broadcast.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.broadcast = broadcast; +var _array = require("../../../utils/array.js"); +var _object = require("../../../utils/object.js"); +/** +* Broadcasts two matrices, and return both in an array +* It checks if it's possible with broadcasting rules +* +* @param {Matrix} A First Matrix +* @param {Matrix} B Second Matrix +* +* @return {Matrix[]} [ broadcastedA, broadcastedB ] +*/ + +function broadcast(A, B) { + if ((0, _object.deepStrictEqual)(A.size(), B.size())) { + // If matrices have the same size return them + return [A, B]; + } + + // calculate the broadcasted sizes + const newSize = (0, _array.broadcastSizes)(A.size(), B.size()); + + // return the array with the two broadcasted matrices + return [A, B].map(M => _broadcastTo(M, newSize)); +} + +/** + * Broadcasts a matrix to the given size. + * + * @param {Matrix} M - The matrix to be broadcasted. + * @param {number[]} size - The desired size of the broadcasted matrix. + * @returns {Matrix} The broadcasted matrix. + * @throws {Error} If the size parameter is not an array of numbers. + */ +function _broadcastTo(M, size) { + if ((0, _object.deepStrictEqual)(M.size(), size)) { + return M; + } + return M.create((0, _array.broadcastTo)(M.valueOf(), size), M.datatype()); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo01xDSid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo01xDSid.js new file mode 100644 index 0000000..0df668b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo01xDSid.js @@ -0,0 +1,118 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo01xDSid = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo01xDSid'; +const dependencies = ['typed']; +const createMatAlgo01xDSid = exports.createMatAlgo01xDSid = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij). + * Callback function invoked NNZ times (number of nonzero items in SparseMatrix). + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ Dij ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (S) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function algorithm1(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + const adata = denseMatrix._data; + const asize = denseMatrix._size; + const adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + const bvalues = sparseMatrix._values; + const bindex = sparseMatrix._index; + const bptr = sparseMatrix._ptr; + const bsize = sparseMatrix._size; + const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // process data types + const dt = typeof adt === 'string' && adt !== 'mixed' && adt === bdt ? adt : undefined; + // callback function + const cf = dt ? typed.find(callback, [dt, dt]) : callback; + + // vars + let i, j; + + // result (DenseMatrix) + const cdata = []; + // initialize c + for (i = 0; i < rows; i++) { + cdata[i] = []; + } + + // workspace + const x = []; + // marks indicating we have a value in x for a given column + const w = []; + + // loop columns in b + for (j = 0; j < columns; j++) { + // column mark + const mark = j + 1; + // values in column j + for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // update workspace + x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + // mark i as updated + w[i] = mark; + } + // loop rows + for (i = 0; i < rows; i++) { + // check row is in workspace + if (w[i] === mark) { + // c[i][j] was already calculated + cdata[i][j] = x[i]; + } else { + // item does not exist in S + cdata[i][j] = adata[i][j]; + } + } + } + + // return dense matrix + return denseMatrix.createDenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo02xDS0.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo02xDS0.js new file mode 100644 index 0000000..9f6657e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo02xDS0.js @@ -0,0 +1,122 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo02xDS0 = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo02xDS0'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo02xDS0 = exports.createMatAlgo02xDS0 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij). + * Callback function invoked NNZ times (number of nonzero items in SparseMatrix). + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (S) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function matAlgo02xDS0(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + const adata = denseMatrix._data; + const asize = denseMatrix._size; + const adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + const bvalues = sparseMatrix._values; + const bindex = sparseMatrix._index; + const bptr = sparseMatrix._ptr; + const bsize = sparseMatrix._size; + const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result (SparseMatrix) + const cvalues = []; + const cindex = []; + const cptr = []; + + // loop columns in b + for (let j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // values in column j + for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + const i = bindex[k]; + // update C(i,j) + const cij = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + // check for nonzero + if (!eq(cij, zero)) { + // push i & v + cindex.push(i); + cvalues.push(cij); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return sparseMatrix.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo03xDSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo03xDSf.js new file mode 100644 index 0000000..03de89f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo03xDSf.js @@ -0,0 +1,128 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo03xDSf = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo03xDSf'; +const dependencies = ['typed']; +const createMatAlgo03xDSf = exports.createMatAlgo03xDSf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Iterates over SparseMatrix items and invokes the callback function f(Dij, Sij). + * Callback function invoked M*N times. + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ f(Dij, 0) ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (C) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function matAlgo03xDSf(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + const adata = denseMatrix._data; + const asize = denseMatrix._size; + const adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + const bvalues = sparseMatrix._values; + const bindex = sparseMatrix._index; + const bptr = sparseMatrix._ptr; + const bsize = sparseMatrix._size; + const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result (DenseMatrix) + const cdata = []; + + // initialize dense matrix + for (let z = 0; z < rows; z++) { + // initialize row + cdata[z] = []; + } + + // workspace + const x = []; + // marks indicating we have a value in x for a given column + const w = []; + + // loop columns in b + for (let j = 0; j < columns; j++) { + // column mark + const mark = j + 1; + // values in column j + for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + const i = bindex[k]; + // update workspace + x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + w[i] = mark; + } + // process workspace + for (let y = 0; y < rows; y++) { + // check we have a calculated value for current row + if (w[y] === mark) { + // use calculated value + cdata[y][j] = x[y]; + } else { + // calculate value + cdata[y][j] = inverse ? cf(zero, adata[y][j]) : cf(adata[y][j], zero); + } + } + } + + // return dense matrix + return denseMatrix.createDenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo04xSidSid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo04xSidSid.js new file mode 100644 index 0000000..dde74fe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo04xSidSid.js @@ -0,0 +1,185 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo04xSidSid = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo04xSidSid'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo04xSidSid = exports.createMatAlgo04xSidSid = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0 + * └ B(i,j) ; A(i,j) === 0 + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo04xSidSid(a, b, callback) { + // sparse matrix arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = avalues && bvalues ? [] : undefined; + const cindex = []; + const cptr = []; + + // workspace + const xa = avalues && bvalues ? [] : undefined; + const xb = avalues && bvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + const wa = []; + const wb = []; + + // vars + let i, j, k, k0, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + const mark = j + 1; + // loop A(:,j) + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // update c + cindex.push(i); + // update workspace + wa[i] = mark; + // check we need to process values + if (xa) { + xa[i] = avalues[k]; + } + } + // loop B(:,j) + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // check row exists in A + if (wa[i] === mark) { + // update record in xa @ i + if (xa) { + // invoke callback + const v = cf(xa[i], bvalues[k]); + // check for zero + if (!eq(v, zero)) { + // update workspace + xa[i] = v; + } else { + // remove mark (index will be removed later) + wa[i] = null; + } + } + } else { + // update c + cindex.push(i); + // update workspace + wb[i] = mark; + // check we need to process values + if (xb) { + xb[i] = bvalues[k]; + } + } + } + // check we need to process values (non pattern matrix) + if (xa && xb) { + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // check workspace has value @ i + if (wa[i] === mark) { + // push value (Aij != 0 || (Aij != 0 && Bij != 0)) + cvalues[k] = xa[i]; + // increment pointer + k++; + } else if (wb[i] === mark) { + // push value (bij != 0) + cvalues[k] = xb[i]; + // increment pointer + k++; + } else { + // remove index @ k + cindex.splice(k, 1); + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo05xSfSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo05xSfSf.js new file mode 100644 index 0000000..9b0427c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo05xSfSf.js @@ -0,0 +1,177 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo05xSfSf = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo05xSfSf'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo05xSfSf = exports.createMatAlgo05xSfSf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 || B(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo05xSfSf(a, b, callback) { + // sparse matrix arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = avalues && bvalues ? [] : undefined; + const cindex = []; + const cptr = []; + + // workspaces + const xa = cvalues ? [] : undefined; + const xb = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + const wa = []; + const wb = []; + + // vars + let i, j, k, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + const mark = j + 1; + // loop values A(:,j) + for (k = aptr[j], k1 = aptr[j + 1]; k < k1; k++) { + // row + i = aindex[k]; + // push index + cindex.push(i); + // update workspace + wa[i] = mark; + // check we need to process values + if (xa) { + xa[i] = avalues[k]; + } + } + // loop values B(:,j) + for (k = bptr[j], k1 = bptr[j + 1]; k < k1; k++) { + // row + i = bindex[k]; + // check row existed in A + if (wa[i] !== mark) { + // push index + cindex.push(i); + } + // update workspace + wb[i] = mark; + // check we need to process values + if (xb) { + xb[i] = bvalues[k]; + } + } + // check we need to process values (non pattern matrix) + if (cvalues) { + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // marks + const wai = wa[i]; + const wbi = wb[i]; + // check Aij or Bij are nonzero + if (wai === mark || wbi === mark) { + // matrix values @ i,j + const va = wai === mark ? xa[i] : zero; + const vb = wbi === mark ? xb[i] : zero; + // Cij + const vc = cf(va, vb); + // check for zero + if (!eq(vc, zero)) { + // push value + cvalues.push(vc); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo06xS0S0.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo06xS0S0.js new file mode 100644 index 0000000..664af19 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo06xS0S0.js @@ -0,0 +1,159 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo06xS0S0 = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +var _collection = require("../../../utils/collection.js"); +const name = 'matAlgo06xS0S0'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo06xS0S0 = exports.createMatAlgo06xS0S0 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked (Anz U Bnz) times, where Anz and Bnz are the nonzero elements in both matrices. + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo06xS0S0(a, b, callback) { + // sparse matrix arrays + const avalues = a._values; + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bvalues = b._values; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = avalues && bvalues ? [] : undefined; + const cindex = []; + const cptr = []; + + // workspaces + const x = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + const w = []; + // marks indicating value in a given row has been updated + const u = []; + + // loop columns + for (let j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + const mark = j + 1; + // scatter the values of A(:,j) into workspace + (0, _collection.scatter)(a, j, w, x, u, mark, cindex, cf); + // scatter the values of B(:,j) into workspace + (0, _collection.scatter)(b, j, w, x, u, mark, cindex, cf); + // check we need to process values (non pattern matrix) + if (x) { + // initialize first index in j + let k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + const i = cindex[k]; + // check function was invoked on current row (Aij !=0 && Bij != 0) + if (u[i] === mark) { + // value @ i + const v = x[i]; + // check for zero value + if (!eq(v, zero)) { + // push value + cvalues.push(v); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } else { + // initialize first index in j + let p = cptr[j]; + // loop index in j + while (p < cindex.length) { + // row + const r = cindex[p]; + // check function was invoked on current row (Aij !=0 && Bij != 0) + if (u[r] !== mark) { + // remove value @ i, do not increment pointer + cindex.splice(p, 1); + } else { + // increment pointer + p++; + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo07xSSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo07xSSf.js new file mode 100644 index 0000000..a23e374 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo07xSSf.js @@ -0,0 +1,125 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo07xSSf = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo07xSSf'; +const dependencies = ['typed', 'DenseMatrix']; +const createMatAlgo07xSSf = exports.createMatAlgo07xSSf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B items (zero and nonzero) and invokes the callback function f(Aij, Bij). + * Callback function invoked MxN times. + * + * C(i,j) = f(Aij, Bij) + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo07xSSf(a, b, callback) { + // sparse matrix arrays + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // vars + let i, j; + + // result arrays + const cdata = []; + // initialize c + for (i = 0; i < rows; i++) { + cdata[i] = []; + } + + // workspaces + const xa = []; + const xb = []; + // marks indicating we have a value in x for a given column + const wa = []; + const wb = []; + + // loop columns + for (j = 0; j < columns; j++) { + // columns mark + const mark = j + 1; + // scatter the values of A(:,j) into workspace + _scatter(a, j, wa, xa, mark); + // scatter the values of B(:,j) into workspace + _scatter(b, j, wb, xb, mark); + // loop rows + for (i = 0; i < rows; i++) { + // matrix values @ i,j + const va = wa[i] === mark ? xa[i] : zero; + const vb = wb[i] === mark ? xb[i] : zero; + // invoke callback + cdata[i][j] = cf(va, vb); + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; + function _scatter(m, j, w, x, mark) { + // a arrays + const values = m._values; + const index = m._index; + const ptr = m._ptr; + // loop values in column j + for (let k = ptr[j], k1 = ptr[j + 1]; k < k1; k++) { + // row + const i = index[k]; + // update workspace + w[i] = mark; + x[i] = values[k]; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo08xS0Sid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo08xS0Sid.js new file mode 100644 index 0000000..82bfddb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo08xS0Sid.js @@ -0,0 +1,160 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo08xS0Sid = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo08xS0Sid'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo08xS0Sid = exports.createMatAlgo08xS0Sid = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0 + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo08xS0Sid(a, b, callback) { + // sparse matrix arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!avalues || !bvalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrices'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = []; + const cindex = []; + const cptr = []; + + // workspace + const x = []; + // marks indicating we have a value in x for a given column + const w = []; + + // vars + let k, k0, k1, i; + + // loop columns + for (let j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + const mark = j + 1; + // loop values in a + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // mark workspace + w[i] = mark; + // set value + x[i] = avalues[k]; + // add index + cindex.push(i); + } + // loop values in b + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // check value exists in workspace + if (w[i] === mark) { + // evaluate callback + x[i] = cf(x[i], bvalues[k]); + } + } + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // value @ i + const v = x[i]; + // check for zero value + if (!eq(v, zero)) { + // push value + cvalues.push(v); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo09xS0Sf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo09xS0Sf.js new file mode 100644 index 0000000..cc28ebd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo09xS0Sf.js @@ -0,0 +1,148 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo09xS0Sf = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo09xS0Sf'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo09xS0Sf = exports.createMatAlgo09xS0Sf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and invokes the callback function f(Aij, Bij). + * Callback function invoked NZA times, number of nonzero elements in A. + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo09xS0Sf(a, b, callback) { + // sparse matrix arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + const asize = a._size; + const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + const bvalues = b._values; + const bindex = b._index; + const bptr = b._ptr; + const bsize = b._size; + const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = avalues && bvalues ? [] : undefined; + const cindex = []; + const cptr = []; + + // workspaces + const x = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + const w = []; + + // vars + let i, j, k, k0, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // column mark + const mark = j + 1; + // check we need to process values + if (x) { + // loop B(:,j) + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // update workspace + w[i] = mark; + x[i] = bvalues[k]; + } + } + // loop A(:,j) + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check we need to process values + if (x) { + // b value @ i,j + const vb = w[i] === mark ? x[i] : zero; + // invoke f + const vc = cf(avalues[k], vb); + // check zero value + if (!eq(vc, zero)) { + // push index + cindex.push(i); + // push value + cvalues.push(vc); + } + } else { + // push index + cindex.push(i); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo10xSids.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo10xSids.js new file mode 100644 index 0000000..24031a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo10xSids.js @@ -0,0 +1,111 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo10xSids = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'matAlgo10xSids'; +const dependencies = ['typed', 'DenseMatrix']; +const createMatAlgo10xSids = exports.createMatAlgo10xSids = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked NZ times (number of nonzero items in S). + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ b ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo10xSids(s, b, callback, inverse) { + // sparse matrix arrays + const avalues = s._values; + const aindex = s._index; + const aptr = s._ptr; + const asize = s._size; + const adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cdata = []; + + // workspaces + const x = []; + // marks indicating we have a value in x for a given column + const w = []; + + // loop columns + for (let j = 0; j < columns; j++) { + // columns mark + const mark = j + 1; + // values in j + for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + const r = aindex[k]; + // update workspace + x[r] = avalues[k]; + w[r] = mark; + } + // loop rows + for (let i = 0; i < rows; i++) { + // initialize C on first column + if (j === 0) { + // create row array + cdata[i] = []; + } + // check sparse matrix has a value @ i,j + if (w[i] === mark) { + // invoke callback, update C + cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b); + } else { + // dense matrix value @ i, j + cdata[i][j] = b; + } + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo11xS0s.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo11xS0s.js new file mode 100644 index 0000000..8aae4e8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo11xS0s.js @@ -0,0 +1,109 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo11xS0s = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'matAlgo11xS0s'; +const dependencies = ['typed', 'equalScalar']; +const createMatAlgo11xS0s = exports.createMatAlgo11xS0s = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked NZ times (number of nonzero items in S). + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} SparseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo11xS0s(s, b, callback, inverse) { + // sparse matrix arrays + const avalues = s._values; + const aindex = s._index; + const aptr = s._ptr; + const asize = s._size; + const adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // equal signature to use + let eq = equalScalar; + // zero value + let zero = 0; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cvalues = []; + const cindex = []; + const cptr = []; + + // loop columns + for (let j = 0; j < columns; j++) { + // initialize ptr + cptr[j] = cindex.length; + // values in j + for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + const i = aindex[k]; + // invoke callback + const v = inverse ? cf(b, avalues[k]) : cf(avalues[k], b); + // check value is zero + if (!eq(v, zero)) { + // push index & value + cindex.push(i); + cvalues.push(v); + } + } + } + // update ptr + cptr[columns] = cindex.length; + + // return sparse matrix + return s.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo12xSfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo12xSfs.js new file mode 100644 index 0000000..7090a8c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo12xSfs.js @@ -0,0 +1,111 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo12xSfs = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'matAlgo12xSfs'; +const dependencies = ['typed', 'DenseMatrix']; +const createMatAlgo12xSfs = exports.createMatAlgo12xSfs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked MxN times. + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ f(0, b) ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo12xSfs(s, b, callback, inverse) { + // sparse matrix arrays + const avalues = s._values; + const aindex = s._index; + const aptr = s._ptr; + const asize = s._size; + const adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + const rows = asize[0]; + const columns = asize[1]; + + // datatype + let dt; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + const cdata = []; + + // workspaces + const x = []; + // marks indicating we have a value in x for a given column + const w = []; + + // loop columns + for (let j = 0; j < columns; j++) { + // columns mark + const mark = j + 1; + // values in j + for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + const r = aindex[k]; + // update workspace + x[r] = avalues[k]; + w[r] = mark; + } + // loop rows + for (let i = 0; i < rows; i++) { + // initialize C on first column + if (j === 0) { + // create row array + cdata[i] = []; + } + // check sparse matrix has a value @ i,j + if (w[i] === mark) { + // invoke callback, update C + cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b); + } else { + // dense matrix value @ i, j + cdata[i][j] = inverse ? cf(b, 0) : cf(0, b); + } + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo13xDD.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo13xDD.js new file mode 100644 index 0000000..3c4ce7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo13xDD.js @@ -0,0 +1,100 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo13xDD = void 0; +var _factory = require("../../../utils/factory.js"); +var _DimensionError = require("../../../error/DimensionError.js"); +const name = 'matAlgo13xDD'; +const dependencies = ['typed']; +const createMatAlgo13xDD = exports.createMatAlgo13xDD = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, Bij..z). + * Callback function invoked MxN times. + * + * C(i,j,...z) = f(Aij..z, Bij..z) + * + * @param {Matrix} a The DenseMatrix instance (A) + * @param {Matrix} b The DenseMatrix instance (B) + * @param {Function} callback The f(Aij..z,Bij..z) operation to invoke + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97658658 + */ + return function matAlgo13xDD(a, b, callback) { + // a arrays + const adata = a._data; + const asize = a._size; + const adt = a._datatype; + // b arrays + const bdata = b._data; + const bsize = b._size; + const bdt = b._datatype; + // c arrays + const csize = []; + + // validate dimensions + if (asize.length !== bsize.length) { + throw new _DimensionError.DimensionError(asize.length, bsize.length); + } + + // validate each one of the dimension sizes + for (let s = 0; s < asize.length; s++) { + // must match + if (asize[s] !== bsize[s]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + // update dimension in c + csize[s] = asize[s]; + } + + // datatype + let dt; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt) { + // datatype + dt = adt; + // callback + cf = typed.find(callback, [dt, dt]); + } + + // populate cdata, iterate through dimensions + const cdata = csize.length > 0 ? _iterate(cf, 0, csize, csize[0], adata, bdata) : []; + + // c matrix + return a.createDenseMatrix({ + data: cdata, + size: csize, + datatype: dt + }); + }; + + // recursive function + function _iterate(f, level, s, n, av, bv) { + // initialize array for this level + const cv = []; + // check we reach the last level + if (level === s.length - 1) { + // loop arrays in last level + for (let i = 0; i < n; i++) { + // invoke callback and store value + cv[i] = f(av[i], bv[i]); + } + } else { + // iterate current level + for (let j = 0; j < n; j++) { + // iterate next level + cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv[j]); + } + } + return cv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo14xDs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo14xDs.js new file mode 100644 index 0000000..89033d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matAlgo14xDs.js @@ -0,0 +1,82 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatAlgo14xDs = void 0; +var _factory = require("../../../utils/factory.js"); +var _object = require("../../../utils/object.js"); +const name = 'matAlgo14xDs'; +const dependencies = ['typed']; +const createMatAlgo14xDs = exports.createMatAlgo14xDs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, b). + * Callback function invoked MxN times. + * + * C(i,j,...z) = f(Aij..z, b) + * + * @param {Matrix} a The DenseMatrix instance (A) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij..z,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Aij..z) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97659042 + */ + return function matAlgo14xDs(a, b, callback, inverse) { + // a arrays + const adata = a._data; + const asize = a._size; + const adt = a._datatype; + + // datatype + let dt; + // callback signature to use + let cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // populate cdata, iterate through dimensions + const cdata = asize.length > 0 ? _iterate(cf, 0, asize, asize[0], adata, b, inverse) : []; + + // c matrix + return a.createDenseMatrix({ + data: cdata, + size: (0, _object.clone)(asize), + datatype: dt + }); + }; + + // recursive function + function _iterate(f, level, s, n, av, bv, inverse) { + // initialize array for this level + const cv = []; + // check we reach the last level + if (level === s.length - 1) { + // loop arrays in last level + for (let i = 0; i < n; i++) { + // invoke callback and store value + cv[i] = inverse ? f(bv, av[i]) : f(av[i], bv); + } + } else { + // iterate current level + for (let j = 0; j < n; j++) { + // iterate next level + cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv, inverse); + } + } + return cv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matrixAlgorithmSuite.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matrixAlgorithmSuite.js new file mode 100644 index 0000000..70cabe6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/matrix/utils/matrixAlgorithmSuite.js @@ -0,0 +1,158 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createMatrixAlgorithmSuite = void 0; +var _factory = require("../../../utils/factory.js"); +var _object = require("../../../utils/object.js"); +var _matAlgo13xDD = require("./matAlgo13xDD.js"); +var _matAlgo14xDs = require("./matAlgo14xDs.js"); +var _broadcast = require("./broadcast.js"); +const name = 'matrixAlgorithmSuite'; +const dependencies = ['typed', 'matrix']; +const createMatrixAlgorithmSuite = exports.createMatrixAlgorithmSuite = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + matrix + } = _ref; + const matAlgo13xDD = (0, _matAlgo13xDD.createMatAlgo13xDD)({ + typed + }); + const matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({ + typed + }); + + /** + * Return a signatures object with the usual boilerplate of + * matrix algorithms, based on a plain options object with the + * following properties: + * elop: function -- the elementwise operation to use, defaults to self + * SS: function -- the algorithm to apply for two sparse matrices + * DS: function -- the algorithm to apply for a dense and a sparse matrix + * SD: function -- algo for a sparse and a dense; defaults to SD flipped + * Ss: function -- the algorithm to apply for a sparse matrix and scalar + * sS: function -- algo for scalar and sparse; defaults to Ss flipped + * scalar: string -- typed-function type for scalars, defaults to 'any' + * + * If Ss is not specified, no matrix-scalar signatures are generated. + * + * @param {object} options + * @return {Object} signatures + */ + return function matrixAlgorithmSuite(options) { + const elop = options.elop; + const SD = options.SD || options.DS; + let matrixSignatures; + if (elop) { + // First the dense ones + matrixSignatures = { + 'DenseMatrix, DenseMatrix': (x, y) => matAlgo13xDD(...(0, _broadcast.broadcast)(x, y), elop), + 'Array, Array': (x, y) => matAlgo13xDD(...(0, _broadcast.broadcast)(matrix(x), matrix(y)), elop).valueOf(), + 'Array, DenseMatrix': (x, y) => matAlgo13xDD(...(0, _broadcast.broadcast)(matrix(x), y), elop), + 'DenseMatrix, Array': (x, y) => matAlgo13xDD(...(0, _broadcast.broadcast)(x, matrix(y)), elop) + }; + // Now incorporate sparse matrices + if (options.SS) { + matrixSignatures['SparseMatrix, SparseMatrix'] = (x, y) => options.SS(...(0, _broadcast.broadcast)(x, y), elop, false); + } + if (options.DS) { + matrixSignatures['DenseMatrix, SparseMatrix'] = (x, y) => options.DS(...(0, _broadcast.broadcast)(x, y), elop, false); + matrixSignatures['Array, SparseMatrix'] = (x, y) => options.DS(...(0, _broadcast.broadcast)(matrix(x), y), elop, false); + } + if (SD) { + matrixSignatures['SparseMatrix, DenseMatrix'] = (x, y) => SD(...(0, _broadcast.broadcast)(y, x), elop, true); + matrixSignatures['SparseMatrix, Array'] = (x, y) => SD(...(0, _broadcast.broadcast)(matrix(y), x), elop, true); + } + } else { + // No elop, use this + // First the dense ones + matrixSignatures = { + 'DenseMatrix, DenseMatrix': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...(0, _broadcast.broadcast)(x, y), self); + }), + 'Array, Array': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...(0, _broadcast.broadcast)(matrix(x), matrix(y)), self).valueOf(); + }), + 'Array, DenseMatrix': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...(0, _broadcast.broadcast)(matrix(x), y), self); + }), + 'DenseMatrix, Array': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...(0, _broadcast.broadcast)(x, matrix(y)), self); + }) + }; + // Now incorporate sparse matrices + if (options.SS) { + matrixSignatures['SparseMatrix, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.SS(...(0, _broadcast.broadcast)(x, y), self, false); + }); + } + if (options.DS) { + matrixSignatures['DenseMatrix, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.DS(...(0, _broadcast.broadcast)(x, y), self, false); + }); + matrixSignatures['Array, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.DS(...(0, _broadcast.broadcast)(matrix(x), y), self, false); + }); + } + if (SD) { + matrixSignatures['SparseMatrix, DenseMatrix'] = typed.referToSelf(self => (x, y) => { + return SD(...(0, _broadcast.broadcast)(y, x), self, true); + }); + matrixSignatures['SparseMatrix, Array'] = typed.referToSelf(self => (x, y) => { + return SD(...(0, _broadcast.broadcast)(matrix(y), x), self, true); + }); + } + } + + // Now add the scalars + const scalar = options.scalar || 'any'; + const Ds = options.Ds || options.Ss; + if (Ds) { + if (elop) { + matrixSignatures['DenseMatrix,' + scalar] = (x, y) => matAlgo14xDs(x, y, elop, false); + matrixSignatures[scalar + ', DenseMatrix'] = (x, y) => matAlgo14xDs(y, x, elop, true); + matrixSignatures['Array,' + scalar] = (x, y) => matAlgo14xDs(matrix(x), y, elop, false).valueOf(); + matrixSignatures[scalar + ', Array'] = (x, y) => matAlgo14xDs(matrix(y), x, elop, true).valueOf(); + } else { + matrixSignatures['DenseMatrix,' + scalar] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }); + matrixSignatures[scalar + ', DenseMatrix'] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(y, x, self, true); + }); + matrixSignatures['Array,' + scalar] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(matrix(x), y, self, false).valueOf(); + }); + matrixSignatures[scalar + ', Array'] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }); + } + } + const sS = options.sS !== undefined ? options.sS : options.Ss; + if (elop) { + if (options.Ss) { + matrixSignatures['SparseMatrix,' + scalar] = (x, y) => options.Ss(x, y, elop, false); + } + if (sS) { + matrixSignatures[scalar + ', SparseMatrix'] = (x, y) => sS(y, x, elop, true); + } + } else { + if (options.Ss) { + matrixSignatures['SparseMatrix,' + scalar] = typed.referToSelf(self => (x, y) => { + return options.Ss(x, y, self, false); + }); + } + if (sS) { + matrixSignatures[scalar + ', SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return sS(y, x, self, true); + }); + } + } + // Also pull in the scalar signatures if the operator is a typed function + if (elop && elop.signatures) { + (0, _object.extend)(matrixSignatures, elop.signatures); + } + return matrixSignatures; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/number.js new file mode 100644 index 0000000..d50d677 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/number.js @@ -0,0 +1,156 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createNumber = void 0; +var _factory = require("../utils/factory.js"); +var _collection = require("../utils/collection.js"); +const name = 'number'; +const dependencies = ['typed']; + +/** + * Separates the radix, integer part, and fractional part of a non decimal number string + * @param {string} input string to parse + * @returns {object} the parts of the string or null if not a valid input + */ +function getNonDecimalNumberParts(input) { + const nonDecimalWithRadixMatch = input.match(/(0[box])([0-9a-fA-F]*)\.([0-9a-fA-F]*)/); + if (nonDecimalWithRadixMatch) { + const radix = { + '0b': 2, + '0o': 8, + '0x': 16 + }[nonDecimalWithRadixMatch[1]]; + const integerPart = nonDecimalWithRadixMatch[2]; + const fractionalPart = nonDecimalWithRadixMatch[3]; + return { + input, + radix, + integerPart, + fractionalPart + }; + } else { + return null; + } +} + +/** + * Makes a number from a radix, and integer part, and a fractional part + * @param {parts} [x] parts of the number string (from getNonDecimalNumberParts) + * @returns {number} the number + */ +function makeNumberFromNonDecimalParts(parts) { + const n = parseInt(parts.integerPart, parts.radix); + let f = 0; + for (let i = 0; i < parts.fractionalPart.length; i++) { + const digitValue = parseInt(parts.fractionalPart[i], parts.radix); + f += digitValue / Math.pow(parts.radix, i + 1); + } + const result = n + f; + if (isNaN(result)) { + throw new SyntaxError('String "' + parts.input + '" is not a valid number'); + } + return result; +} +const createNumber = exports.createNumber = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Create a number or convert a string, boolean, or unit to a number. + * When value is a matrix, all elements will be converted to number. + * + * Syntax: + * + * math.number(value) + * math.number(unit, valuelessUnit) + * + * Examples: + * + * math.number(2) // returns number 2 + * math.number('7.2') // returns number 7.2 + * math.number(true) // returns number 1 + * math.number([true, false, true, true]) // returns [1, 0, 1, 1] + * math.number(math.unit('52cm'), 'm') // returns 0.52 + * + * See also: + * + * bignumber, bigint, boolean, numeric, complex, index, matrix, string, unit + * + * @param {string | number | BigNumber | Fraction | boolean | Array | Matrix | Unit | null} [value] Value to be converted + * @param {Unit | string} [valuelessUnit] A valueless unit, used to convert a unit to a number + * @return {number | Array | Matrix} The created number + */ + const number = typed('number', { + '': function () { + return 0; + }, + number: function (x) { + return x; + }, + string: function (x) { + if (x === 'NaN') return NaN; + const nonDecimalNumberParts = getNonDecimalNumberParts(x); + if (nonDecimalNumberParts) { + return makeNumberFromNonDecimalParts(nonDecimalNumberParts); + } + let size = 0; + const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/); + if (wordSizeSuffixMatch) { + // x includes a size suffix like 0xffffi32, so we extract + // the suffix and remove it from x + size = Number(wordSizeSuffixMatch[2]); + x = wordSizeSuffixMatch[1]; + } + let num = Number(x); + if (isNaN(num)) { + throw new SyntaxError('String "' + x + '" is not a valid number'); + } + if (wordSizeSuffixMatch) { + // x is a signed bin, oct, or hex literal + // num is the value of string x if x is interpreted as unsigned + if (num > 2 ** size - 1) { + // literal is too large for size suffix + throw new SyntaxError(`String "${x}" is out of range`); + } + // check if the bit at index size - 1 is set and if so do the twos complement + if (num >= 2 ** (size - 1)) { + num = num - 2 ** size; + } + } + return num; + }, + BigNumber: function (x) { + return x.toNumber(); + }, + bigint: function (x) { + return Number(x); + }, + Fraction: function (x) { + return x.valueOf(); + }, + Unit: typed.referToSelf(self => x => { + const clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + null: function (x) { + return 0; + }, + 'Unit, string | Unit': function (unit, valuelessUnit) { + return unit.toNumber(valuelessUnit); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); + + // reviver function to parse a JSON object like: + // + // {"mathjs":"number","value":"2.3"} + // + // into a number 2.3 + number.fromJSON = function (json) { + return parseFloat(json.value); + }; + return number; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/resultset/ResultSet.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/resultset/ResultSet.js new file mode 100644 index 0000000..1321fb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/resultset/ResultSet.js @@ -0,0 +1,74 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createResultSet = void 0; +var _factory = require("../../utils/factory.js"); +const name = 'ResultSet'; +const dependencies = []; +const createResultSet = exports.createResultSet = /* #__PURE__ */(0, _factory.factory)(name, dependencies, () => { + /** + * A ResultSet contains a list or results + * @class ResultSet + * @param {Array} entries + * @constructor ResultSet + */ + function ResultSet(entries) { + if (!(this instanceof ResultSet)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.entries = entries || []; + } + + /** + * Attach type information + */ + ResultSet.prototype.type = 'ResultSet'; + ResultSet.prototype.isResultSet = true; + + /** + * Returns the array with results hold by this ResultSet + * @memberof ResultSet + * @returns {Array} entries + */ + ResultSet.prototype.valueOf = function () { + return this.entries; + }; + + /** + * Returns the stringified results of the ResultSet + * @memberof ResultSet + * @returns {string} string + */ + ResultSet.prototype.toString = function () { + return '[' + this.entries.join(', ') + ']'; + }; + + /** + * Get a JSON representation of the ResultSet + * @memberof ResultSet + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "ResultSet", "entries": [...]}` + */ + ResultSet.prototype.toJSON = function () { + return { + mathjs: 'ResultSet', + entries: this.entries + }; + }; + + /** + * Instantiate a ResultSet from a JSON object + * @memberof ResultSet + * @param {Object} json A JSON object structured as: + * `{"mathjs": "ResultSet", "entries": [...]}` + * @return {ResultSet} + */ + ResultSet.fromJSON = function (json) { + return new ResultSet(json.entries); + }; + return ResultSet; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/string.js new file mode 100644 index 0000000..8ea43a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/string.js @@ -0,0 +1,60 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createString = void 0; +var _factory = require("../utils/factory.js"); +var _collection = require("../utils/collection.js"); +var _number = require("../utils/number.js"); +const name = 'string'; +const dependencies = ['typed']; +const createString = exports.createString = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Create a string or convert any object into a string. + * Elements of Arrays and Matrices are processed element wise. + * + * Syntax: + * + * math.string(value) + * + * Examples: + * + * math.string(4.2) // returns string '4.2' + * math.string(math.complex(3, 2) // returns string '3 + 2i' + * + * const u = math.unit(5, 'km') + * math.string(u.to('m')) // returns string '5000 m' + * + * math.string([true, false]) // returns ['true', 'false'] + * + * See also: + * + * bignumber, boolean, complex, index, matrix, number, unit + * + * @param {* | Array | Matrix | null} [value] A value to convert to a string + * @return {string | Array | Matrix} The created string + */ + return typed(name, { + '': function () { + return ''; + }, + number: _number.format, + null: function (x) { + return 'null'; + }, + boolean: function (x) { + return x + ''; + }, + string: function (x) { + return x; + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)), + any: function (x) { + return String(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/Unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/Unit.js new file mode 100644 index 0000000..fddc5dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/Unit.js @@ -0,0 +1,3888 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnitClass = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _is = require("../../utils/is.js"); +var _factory = require("../../utils/factory.js"); +var _function = require("../../utils/function.js"); +var _string = require("../../utils/string.js"); +var _object = require("../../utils/object.js"); +var _constants = require("../../utils/bignumber/constants.js"); +const name = 'Unit'; +const dependencies = ['?on', 'config', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'abs', 'fix', 'round', 'equal', 'isNumeric', 'format', 'number', 'Complex', 'BigNumber', 'Fraction']; +const createUnitClass = exports.createUnitClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + on, + config, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + pow, + abs, + fix, + round, + equal, + isNumeric, + format, + number, + Complex, + BigNumber, + Fraction + } = _ref; + const toNumber = number; + /** + * A unit can be constructed in the following ways: + * + * const a = new Unit(value, valuelessUnit) + * const b = new Unit(null, valuelessUnit) + * const c = Unit.parse(str) + * + * Example usage: + * + * const a = new Unit(5, 'cm') // 50 mm + * const b = Unit.parse('23 kg') // 23 kg + * const c = math.in(a, new Unit(null, 'm') // 0.05 m + * const d = new Unit(9.81, "m/s^2") // 9.81 m/s^2 + * + * @class Unit + * @constructor Unit + * @param {number | BigNumber | Fraction | Complex | boolean} [value] A value like 5.2 + * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like "cm" + */ + function Unit(value, valuelessUnit) { + if (!(this instanceof Unit)) { + throw new Error('Constructor must be called with the new operator'); + } + if (!(value === null || value === undefined || isNumeric(value) || (0, _is.isComplex)(value))) { + throw new TypeError('First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined'); + } + this.fixPrefix = false; // if true, function format will not search for the + // best prefix but leave it as initially provided. + // fixPrefix is set true by the method Unit.to + + // The justification behind this is that if the constructor is explicitly called, + // the caller wishes the units to be returned exactly as supplied. + this.skipAutomaticSimplification = true; + if (valuelessUnit === undefined) { + this.units = []; + this.dimensions = BASE_DIMENSIONS.map(x => 0); + } else if (typeof valuelessUnit === 'string') { + const u = Unit.parse(valuelessUnit); + this.units = u.units; + this.dimensions = u.dimensions; + } else if ((0, _is.isUnit)(valuelessUnit) && valuelessUnit.value === null) { + // clone from valuelessUnit + this.fixPrefix = valuelessUnit.fixPrefix; + this.skipAutomaticSimplification = valuelessUnit.skipAutomaticSimplification; + this.dimensions = valuelessUnit.dimensions.slice(0); + this.units = valuelessUnit.units.map(u => (0, _extends2.default)({}, u)); + } else { + throw new TypeError('Second parameter in Unit constructor must be a string or valueless Unit'); + } + this.value = this._normalize(value); + } + + /** + * Attach type information + */ + Object.defineProperty(Unit, 'name', { + value: 'Unit' + }); + Unit.prototype.constructor = Unit; + Unit.prototype.type = 'Unit'; + Unit.prototype.isUnit = true; + + // private variables and functions for the Unit parser + let text, index, c; + function skipWhitespace() { + while (c === ' ' || c === '\t') { + next(); + } + } + function isDigitDot(c) { + return c >= '0' && c <= '9' || c === '.'; + } + function isDigit(c) { + return c >= '0' && c <= '9'; + } + function next() { + index++; + c = text.charAt(index); + } + function revert(oldIndex) { + index = oldIndex; + c = text.charAt(index); + } + function parseNumber() { + let number = ''; + const oldIndex = index; + if (c === '+') { + next(); + } else if (c === '-') { + number += c; + next(); + } + if (!isDigitDot(c)) { + // a + or - must be followed by a digit + revert(oldIndex); + return null; + } + + // get number, can have a single dot + if (c === '.') { + number += c; + next(); + if (!isDigit(c)) { + // this is no legal number, it is just a dot + revert(oldIndex); + return null; + } + } else { + while (isDigit(c)) { + number += c; + next(); + } + if (c === '.') { + number += c; + next(); + } + } + while (isDigit(c)) { + number += c; + next(); + } + + // check for exponential notation like "2.3e-4" or "1.23e50" + if (c === 'E' || c === 'e') { + // The grammar branches here. This could either be part of an exponent or the start of a unit that begins with the letter e, such as "4exabytes" + + let tentativeNumber = ''; + const tentativeIndex = index; + tentativeNumber += c; + next(); + if (c === '+' || c === '-') { + tentativeNumber += c; + next(); + } + + // Scientific notation MUST be followed by an exponent (otherwise we assume it is not scientific notation) + if (!isDigit(c)) { + // The e or E must belong to something else, so return the number without the e or E. + revert(tentativeIndex); + return number; + } + + // We can now safely say that this is scientific notation. + number = number + tentativeNumber; + while (isDigit(c)) { + number += c; + next(); + } + } + return number; + } + function parseUnit() { + let unitName = ''; + + // Alphanumeric characters only; matches [a-zA-Z0-9] + while (isDigit(c) || Unit.isValidAlpha(c)) { + unitName += c; + next(); + } + + // Must begin with [a-zA-Z] + const firstC = unitName.charAt(0); + if (Unit.isValidAlpha(firstC)) { + return unitName; + } else { + return null; + } + } + function parseCharacter(toFind) { + if (c === toFind) { + next(); + return toFind; + } else { + return null; + } + } + + /** + * Parse a string into a unit. The value of the unit is parsed as number, + * BigNumber, or Fraction depending on the math.js config setting `number`. + * + * Throws an exception if the provided string does not contain a valid unit or + * cannot be parsed. + * @memberof Unit + * @param {string} str A string like "5.2 inch", "4e2 cm/s^2" + * @return {Unit} unit + */ + Unit.parse = function (str, options) { + options = options || {}; + text = str; + index = -1; + c = ''; + if (typeof text !== 'string') { + throw new TypeError('Invalid argument in Unit.parse, string expected'); + } + const unit = new Unit(); + unit.units = []; + let powerMultiplierCurrent = 1; + let expectingUnit = false; + + // A unit should follow this pattern: + // [number] ...[ [*/] unit[^number] ] + // unit[^number] ... [ [*/] unit[^number] ] + + // Rules: + // number is any floating point number. + // unit is any alphanumeric string beginning with an alpha. Units with names like e3 should be avoided because they look like the exponent of a floating point number! + // The string may optionally begin with a number. + // Each unit may optionally be followed by ^number. + // Whitespace or a forward slash is recommended between consecutive units, although the following technically is parseable: + // 2m^2kg/s^2 + // it is not good form. If a unit starts with e, then it could be confused as a floating point number: + // 4erg + + next(); + skipWhitespace(); + + // Optional number at the start of the string + const valueStr = parseNumber(); + let value = null; + if (valueStr) { + if (config.number === 'BigNumber') { + value = new BigNumber(valueStr); + } else if (config.number === 'Fraction') { + try { + // not all numbers can be turned in Fractions, for example very small numbers not + value = new Fraction(valueStr); + } catch (err) { + value = parseFloat(valueStr); + } + } else { + // number + value = parseFloat(valueStr); + } + skipWhitespace(); // Whitespace is not required here + + // handle multiplication or division right after the value, like '1/s' + if (parseCharacter('*')) { + powerMultiplierCurrent = 1; + expectingUnit = true; + } else if (parseCharacter('/')) { + powerMultiplierCurrent = -1; + expectingUnit = true; + } + } + + // Stack to keep track of powerMultipliers applied to each parentheses group + const powerMultiplierStack = []; + + // Running product of all elements in powerMultiplierStack + let powerMultiplierStackProduct = 1; + while (true) { + skipWhitespace(); + + // Check for and consume opening parentheses, pushing powerMultiplierCurrent to the stack + // A '(' will always appear directly before a unit. + while (c === '(') { + powerMultiplierStack.push(powerMultiplierCurrent); + powerMultiplierStackProduct *= powerMultiplierCurrent; + powerMultiplierCurrent = 1; + next(); + skipWhitespace(); + } + + // Is there something here? + let uStr; + if (c) { + const oldC = c; + uStr = parseUnit(); + if (uStr === null) { + throw new SyntaxError('Unexpected "' + oldC + '" in "' + text + '" at index ' + index.toString()); + } + } else { + // End of input. + break; + } + + // Verify the unit exists and get the prefix (if any) + const res = _findUnit(uStr); + if (res === null) { + // Unit not found. + throw new SyntaxError('Unit "' + uStr + '" not found.'); + } + let power = powerMultiplierCurrent * powerMultiplierStackProduct; + // Is there a "^ number"? + skipWhitespace(); + if (parseCharacter('^')) { + skipWhitespace(); + const p = parseNumber(); + if (p === null) { + // No valid number found for the power! + throw new SyntaxError('In "' + str + '", "^" must be followed by a floating-point number'); + } + power *= p; + } + + // Add the unit to the list + unit.units.push({ + unit: res.unit, + prefix: res.prefix, + power + }); + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + unit.dimensions[i] += (res.unit.dimensions[i] || 0) * power; + } + + // Check for and consume closing parentheses, popping from the stack. + // A ')' will always follow a unit. + skipWhitespace(); + while (c === ')') { + if (powerMultiplierStack.length === 0) { + throw new SyntaxError('Unmatched ")" in "' + text + '" at index ' + index.toString()); + } + powerMultiplierStackProduct /= powerMultiplierStack.pop(); + next(); + skipWhitespace(); + } + + // "*" and "/" should mean we are expecting something to come next. + // Is there a forward slash? If so, negate powerMultiplierCurrent. The next unit or paren group is in the denominator. + expectingUnit = false; + if (parseCharacter('*')) { + // explicit multiplication + powerMultiplierCurrent = 1; + expectingUnit = true; + } else if (parseCharacter('/')) { + // division + powerMultiplierCurrent = -1; + expectingUnit = true; + } else { + // implicit multiplication + powerMultiplierCurrent = 1; + } + + // Replace the unit into the auto unit system + if (res.unit.base) { + const baseDim = res.unit.base.key; + UNIT_SYSTEMS.auto[baseDim] = { + unit: res.unit, + prefix: res.prefix + }; + } + } + + // Has the string been entirely consumed? + skipWhitespace(); + if (c) { + throw new SyntaxError('Could not parse: "' + str + '"'); + } + + // Is there a trailing slash? + if (expectingUnit) { + throw new SyntaxError('Trailing characters: "' + str + '"'); + } + + // Is the parentheses stack empty? + if (powerMultiplierStack.length !== 0) { + throw new SyntaxError('Unmatched "(" in "' + text + '"'); + } + + // Are there any units at all? + if (unit.units.length === 0 && !options.allowNoUnits) { + throw new SyntaxError('"' + str + '" contains no units'); + } + unit.value = value !== undefined ? unit._normalize(value) : null; + return unit; + }; + + /** + * create a copy of this unit + * @memberof Unit + * @return {Unit} Returns a cloned version of the unit + */ + Unit.prototype.clone = function () { + const unit = new Unit(); + unit.fixPrefix = this.fixPrefix; + unit.skipAutomaticSimplification = this.skipAutomaticSimplification; + unit.value = (0, _object.clone)(this.value); + unit.dimensions = this.dimensions.slice(0); + unit.units = []; + for (let i = 0; i < this.units.length; i++) { + unit.units[i] = {}; + for (const p in this.units[i]) { + if ((0, _object.hasOwnProperty)(this.units[i], p)) { + unit.units[i][p] = this.units[i][p]; + } + } + } + return unit; + }; + + /** + * Return the type of the value of this unit + * + * @memberof Unit + * @return {string} type of the value of the unit + */ + Unit.prototype.valueType = function () { + return (0, _is.typeOf)(this.value); + }; + + /** + * Return whether the unit is derived (such as m/s, or cm^2, but not N) + * @memberof Unit + * @return {boolean} True if the unit is derived + * @private + */ + Unit.prototype._isDerived = function () { + if (this.units.length === 0) { + return false; + } + return this.units.length > 1 || Math.abs(this.units[0].power - 1.0) > 1e-15; + }; + + /** + * Normalize a value, based on its currently set unit(s) + * @memberof Unit + * @param {number | BigNumber | Fraction | boolean} value + * @return {number | BigNumber | Fraction | boolean} normalized value + * @private + */ + Unit.prototype._normalize = function (value) { + if (value === null || value === undefined || this.units.length === 0) { + return value; + } + let res = value; + const convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed + + for (let i = 0; i < this.units.length; i++) { + const unitValue = convert(this.units[i].unit.value); + const unitPrefixValue = convert(this.units[i].prefix.value); + const unitPower = convert(this.units[i].power); + res = multiplyScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower)); + } + return res; + }; + + /** + * Denormalize a value, based on its currently set unit(s) + * @memberof Unit + * @param {number} value + * @param {number} [prefixValue] Optional prefix value to be used (ignored if this is a derived unit) + * @return {number} denormalized value + * @private + */ + Unit.prototype._denormalize = function (value, prefixValue) { + if (value === null || value === undefined || this.units.length === 0) { + return value; + } + let res = value; + const convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed + + for (let i = 0; i < this.units.length; i++) { + const unitValue = convert(this.units[i].unit.value); + const unitPrefixValue = convert(this.units[i].prefix.value); + const unitPower = convert(this.units[i].power); + res = divideScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower)); + } + return res; + }; + + /** + * Find a unit from a string + * @memberof Unit + * @param {string} str A string like 'cm' or 'inch' + * @returns {Object | null} result When found, an object with fields unit and + * prefix is returned. Else, null is returned. + * @private + */ + const _findUnit = (0, _function.memoize)(str => { + // First, match units names exactly. For example, a user could define 'mm' as 10^-4 m, which is silly, but then we would want 'mm' to match the user-defined unit. + if ((0, _object.hasOwnProperty)(UNITS, str)) { + const unit = UNITS[str]; + const prefix = unit.prefixes['']; + return { + unit, + prefix + }; + } + for (const name in UNITS) { + if ((0, _object.hasOwnProperty)(UNITS, name)) { + if ((0, _string.endsWith)(str, name)) { + const unit = UNITS[name]; + const prefixLen = str.length - name.length; + const prefixName = str.substring(0, prefixLen); + const prefix = (0, _object.hasOwnProperty)(unit.prefixes, prefixName) ? unit.prefixes[prefixName] : undefined; + if (prefix !== undefined) { + // store unit, prefix, and value + return { + unit, + prefix + }; + } + } + } + } + return null; + }, { + hasher: args => args[0], + limit: 100 + }); + + /** + * Test if the given expression is a unit. + * The unit can have a prefix but cannot have a value. + * @memberof Unit + * @param {string} name A string to be tested whether it is a value less unit. + * The unit can have prefix, like "cm" + * @return {boolean} true if the given string is a unit + */ + Unit.isValuelessUnit = function (name) { + return _findUnit(name) !== null; + }; + + /** + * check if this unit has given base unit + * If this unit is a derived unit, this will ALWAYS return false, since by definition base units are not derived. + * @memberof Unit + * @param {BASE_UNIT | string | undefined} base + */ + Unit.prototype.hasBase = function (base) { + if (typeof base === 'string') { + base = BASE_UNITS[base]; + } + if (!base) { + return false; + } + + // All dimensions must be the same + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + if (Math.abs((this.dimensions[i] || 0) - (base.dimensions[i] || 0)) > 1e-12) { + return false; + } + } + return true; + }; + + /** + * Check if this unit has a base or bases equal to another base or bases + * For derived units, the exponent on each base also must match + * @memberof Unit + * @param {Unit} other + * @return {boolean} true if equal base + */ + Unit.prototype.equalBase = function (other) { + // All dimensions must be the same + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + if (Math.abs((this.dimensions[i] || 0) - (other.dimensions[i] || 0)) > 1e-12) { + return false; + } + } + return true; + }; + + /** + * Check if this unit equals another unit + * @memberof Unit + * @param {Unit} other + * @return {boolean} true if both units are equal + */ + Unit.prototype.equals = function (other) { + return this.equalBase(other) && equal(this.value, other.value); + }; + + /** + * Multiply this unit with another one or with a scalar + * @memberof Unit + * @param {Unit} other + * @return {Unit} product of this unit and the other unit + */ + Unit.prototype.multiply = function (_other) { + const res = this.clone(); + const other = (0, _is.isUnit)(_other) ? _other : new Unit(_other); + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) + (other.dimensions[i] || 0); + } + + // Append other's units list onto res + for (let i = 0; i < other.units.length; i++) { + // Make a shallow copy of every unit + const inverted = { + ...other.units[i] + }; + res.units.push(inverted); + } + + // If at least one operand has a value, then the result should also have a value + if (this.value !== null || other.value !== null) { + const valThis = this.value === null ? this._normalize(1) : this.value; + const valOther = other.value === null ? other._normalize(1) : other.value; + res.value = multiplyScalar(valThis, valOther); + } else { + res.value = null; + } + if ((0, _is.isUnit)(_other)) { + res.skipAutomaticSimplification = false; + } + return getNumericIfUnitless(res); + }; + + /** + * Divide a number by this unit + * + * @memberof Unit + * @param {numeric} numerator + * @param {unit} result of dividing numerator by this unit + */ + Unit.prototype.divideInto = function (numerator) { + return new Unit(numerator).divide(this); + }; + + /** + * Divide this unit by another one + * @memberof Unit + * @param {Unit | numeric} other + * @return {Unit} result of dividing this unit by the other unit + */ + Unit.prototype.divide = function (_other) { + const res = this.clone(); + const other = (0, _is.isUnit)(_other) ? _other : new Unit(_other); + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) - (other.dimensions[i] || 0); + } + + // Invert and append other's units list onto res + for (let i = 0; i < other.units.length; i++) { + // Make a shallow copy of every unit + const inverted = { + ...other.units[i], + power: -other.units[i].power + }; + res.units.push(inverted); + } + + // If at least one operand has a value, the result should have a value + if (this.value !== null || other.value !== null) { + const valThis = this.value === null ? this._normalize(1) : this.value; + const valOther = other.value === null ? other._normalize(1) : other.value; + res.value = divideScalar(valThis, valOther); + } else { + res.value = null; + } + if ((0, _is.isUnit)(_other)) { + res.skipAutomaticSimplification = false; + } + return getNumericIfUnitless(res); + }; + + /** + * Calculate the power of a unit + * @memberof Unit + * @param {number | Fraction | BigNumber} p + * @returns {Unit} The result: this^p + */ + Unit.prototype.pow = function (p) { + const res = this.clone(); + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) * p; + } + + // Adjust the power of each unit in the list + for (let i = 0; i < res.units.length; i++) { + res.units[i].power *= p; + } + if (res.value !== null) { + res.value = pow(res.value, p); + + // only allow numeric output, we don't want to return a Complex number + // if (!isNumeric(res.value)) { + // res.value = NaN + // } + // Update: Complex supported now + } else { + res.value = null; + } + res.skipAutomaticSimplification = false; + return getNumericIfUnitless(res); + }; + + /** + * Return the numeric value of this unit if it is dimensionless, has a value, and config.predictable == false; or the original unit otherwise + * @param {Unit} unit + * @returns {number | Fraction | BigNumber | Unit} The numeric value of the unit if conditions are met, or the original unit otherwise + */ + function getNumericIfUnitless(unit) { + if (unit.equalBase(BASE_UNITS.NONE) && unit.value !== null && !config.predictable) { + return unit.value; + } else { + return unit; + } + } + + /** + * Calculate the absolute value of a unit + * @memberof Unit + * @param {number | Fraction | BigNumber} x + * @returns {Unit} The result: |x|, absolute value of x + */ + Unit.prototype.abs = function () { + const ret = this.clone(); + if (ret.value !== null) { + if (ret._isDerived() || ret.units.length === 0 || ret.units[0].unit.offset === 0) { + ret.value = abs(ret.value); + } else { + // To give the correct, but unexpected, results for units with an offset. + // For example, abs(-283.15 degC) = -263.15 degC !!! + // We must take the offset into consideration here + const convert = ret._numberConverter(); // convert to Fraction or BigNumber if needed + const unitValue = convert(ret.units[0].unit.value); + const nominalOffset = convert(ret.units[0].unit.offset); + const unitOffset = multiplyScalar(unitValue, nominalOffset); + ret.value = subtractScalar(abs(addScalar(ret.value, unitOffset)), unitOffset); + } + } + for (const i in ret.units) { + if (ret.units[i].unit.name === 'VA' || ret.units[i].unit.name === 'VAR') { + ret.units[i].unit = UNITS.W; + } + } + return ret; + }; + + /** + * Convert the unit to a specific unit name. + * @memberof Unit + * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like "cm" + * @returns {Unit} Returns a clone of the unit with a fixed prefix and unit. + */ + Unit.prototype.to = function (valuelessUnit) { + const value = this.value === null ? this._normalize(1) : this.value; + let other; + if (typeof valuelessUnit === 'string') { + other = Unit.parse(valuelessUnit); + } else if ((0, _is.isUnit)(valuelessUnit)) { + other = valuelessUnit.clone(); + } else { + throw new Error('String or Unit expected as parameter'); + } + if (!this.equalBase(other)) { + throw new Error(`Units do not match ('${other.toString()}' != '${this.toString()}')`); + } + if (other.value !== null) { + throw new Error('Cannot convert to a unit with a value'); + } + if (this.value === null || this._isDerived() || this.units.length === 0 || other.units.length === 0 || this.units[0].unit.offset === other.units[0].unit.offset) { + other.value = (0, _object.clone)(value); + } else { + /* Need to adjust value by difference in offset to convert */ + const convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed + + const thisUnitValue = this.units[0].unit.value; + const thisNominalOffset = this.units[0].unit.offset; + const thisUnitOffset = multiplyScalar(thisUnitValue, thisNominalOffset); + const otherUnitValue = other.units[0].unit.value; + const otherNominalOffset = other.units[0].unit.offset; + const otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset); + other.value = addScalar(value, convert(subtractScalar(thisUnitOffset, otherUnitOffset))); + } + other.fixPrefix = true; + other.skipAutomaticSimplification = true; + return other; + }; + + /** + * Return the value of the unit when represented with given valueless unit + * @memberof Unit + * @param {string | Unit} valuelessUnit For example 'cm' or 'inch' + * @return {number} Returns the unit value as number. + */ + // TODO: deprecate Unit.toNumber? It's always better to use toNumeric + Unit.prototype.toNumber = function (valuelessUnit) { + return toNumber(this.toNumeric(valuelessUnit)); + }; + + /** + * Return the value of the unit in the original numeric type + * @memberof Unit + * @param {string | Unit} valuelessUnit For example 'cm' or 'inch' + * @return {number | BigNumber | Fraction} Returns the unit value + */ + Unit.prototype.toNumeric = function (valuelessUnit) { + let other; + if (valuelessUnit) { + // Allow getting the numeric value without converting to a different unit + other = this.to(valuelessUnit); + } else { + other = this.clone(); + } + if (other._isDerived() || other.units.length === 0) { + return other._denormalize(other.value); + } else { + return other._denormalize(other.value, other.units[0].prefix.value); + } + }; + + /** + * Get a string representation of the unit. + * @memberof Unit + * @return {string} + */ + Unit.prototype.toString = function () { + return this.format(); + }; + + /** + * Get a JSON representation of the unit + * @memberof Unit + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Unit", "value": 2, "unit": "cm", "fixPrefix": false}` + */ + Unit.prototype.toJSON = function () { + return { + mathjs: 'Unit', + value: this._denormalize(this.value), + unit: this.units.length > 0 ? this.formatUnits() : null, + fixPrefix: this.fixPrefix + }; + }; + + /** + * Instantiate a Unit from a JSON object + * @memberof Unit + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Unit", "value": 2, "unit": "cm", "fixPrefix": false}` + * @return {Unit} + */ + Unit.fromJSON = function (json) { + var _json$unit; + const unit = new Unit(json.value, (_json$unit = json.unit) !== null && _json$unit !== void 0 ? _json$unit : undefined); + unit.fixPrefix = json.fixPrefix || false; + return unit; + }; + + /** + * Returns the string representation of the unit. + * @memberof Unit + * @return {string} + */ + Unit.prototype.valueOf = Unit.prototype.toString; + + /** + * Simplify this Unit's unit list and return a new Unit with the simplified list. + * The returned Unit will contain a list of the "best" units for formatting. + */ + Unit.prototype.simplify = function () { + const ret = this.clone(); + const proposedUnitList = []; + + // Search for a matching base + let matchingBase; + for (const key in currentUnitSystem) { + if ((0, _object.hasOwnProperty)(currentUnitSystem, key)) { + if (ret.hasBase(BASE_UNITS[key])) { + matchingBase = key; + break; + } + } + } + if (matchingBase === 'NONE') { + ret.units = []; + } else { + let matchingUnit; + if (matchingBase) { + // Does the unit system have a matching unit? + if ((0, _object.hasOwnProperty)(currentUnitSystem, matchingBase)) { + matchingUnit = currentUnitSystem[matchingBase]; + } + } + if (matchingUnit) { + ret.units = [{ + unit: matchingUnit.unit, + prefix: matchingUnit.prefix, + power: 1.0 + }]; + } else { + // Multiple units or units with powers are formatted like this: + // 5 (kg m^2) / (s^3 mol) + // Build an representation from the base units of the current unit system + let missingBaseDim = false; + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + const baseDim = BASE_DIMENSIONS[i]; + if (Math.abs(ret.dimensions[i] || 0) > 1e-12) { + if ((0, _object.hasOwnProperty)(currentUnitSystem, baseDim)) { + proposedUnitList.push({ + unit: currentUnitSystem[baseDim].unit, + prefix: currentUnitSystem[baseDim].prefix, + power: ret.dimensions[i] || 0 + }); + } else { + missingBaseDim = true; + } + } + } + + // Is the proposed unit list "simpler" than the existing one? + if (proposedUnitList.length < ret.units.length && !missingBaseDim) { + // Replace this unit list with the proposed list + ret.units = proposedUnitList; + } + } + } + return ret; + }; + + /** + * Returns a new Unit in the SI system with the same value as this one + */ + Unit.prototype.toSI = function () { + const ret = this.clone(); + const proposedUnitList = []; + + // Multiple units or units with powers are formatted like this: + // 5 (kg m^2) / (s^3 mol) + // Build an representation from the base units of the SI unit system + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + const baseDim = BASE_DIMENSIONS[i]; + if (Math.abs(ret.dimensions[i] || 0) > 1e-12) { + if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS.si, baseDim)) { + proposedUnitList.push({ + unit: UNIT_SYSTEMS.si[baseDim].unit, + prefix: UNIT_SYSTEMS.si[baseDim].prefix, + power: ret.dimensions[i] || 0 + }); + } else { + throw new Error('Cannot express custom unit ' + baseDim + ' in SI units'); + } + } + } + + // Replace this unit list with the proposed list + ret.units = proposedUnitList; + ret.fixPrefix = true; + ret.skipAutomaticSimplification = true; + if (this.value !== null) { + ret.value = null; + return this.to(ret); + } + return ret; + }; + + /** + * Get a string representation of the units of this Unit, without the value. The unit list is formatted as-is without first being simplified. + * @memberof Unit + * @return {string} + */ + Unit.prototype.formatUnits = function () { + let strNum = ''; + let strDen = ''; + let nNum = 0; + let nDen = 0; + for (let i = 0; i < this.units.length; i++) { + if (this.units[i].power > 0) { + nNum++; + strNum += ' ' + this.units[i].prefix.name + this.units[i].unit.name; + if (Math.abs(this.units[i].power - 1.0) > 1e-15) { + strNum += '^' + this.units[i].power; + } + } else if (this.units[i].power < 0) { + nDen++; + } + } + if (nDen > 0) { + for (let i = 0; i < this.units.length; i++) { + if (this.units[i].power < 0) { + if (nNum > 0) { + strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name; + if (Math.abs(this.units[i].power + 1.0) > 1e-15) { + strDen += '^' + -this.units[i].power; + } + } else { + strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name; + strDen += '^' + this.units[i].power; + } + } + } + } + // Remove leading " " + strNum = strNum.substr(1); + strDen = strDen.substr(1); + + // Add parans for better copy/paste back into evaluate, for example, or for better pretty print formatting + if (nNum > 1 && nDen > 0) { + strNum = '(' + strNum + ')'; + } + if (nDen > 1 && nNum > 0) { + strDen = '(' + strDen + ')'; + } + let str = strNum; + if (nNum > 0 && nDen > 0) { + str += ' / '; + } + str += strDen; + return str; + }; + + /** + * Get a string representation of the Unit, with optional formatting options. + * @memberof Unit + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @return {string} + */ + Unit.prototype.format = function (options) { + // Simplfy the unit list, unless it is valueless or was created directly in the + // constructor or as the result of to or toSI + const simp = this.skipAutomaticSimplification || this.value === null ? this.clone() : this.simplify(); + + // Apply some custom logic for handling VA and VAR. The goal is to express the value of the unit as a real value, if possible. Otherwise, use a real-valued unit instead of a complex-valued one. + let isImaginary = false; + if (typeof simp.value !== 'undefined' && simp.value !== null && (0, _is.isComplex)(simp.value)) { + // TODO: Make this better, for example, use relative magnitude of re and im rather than absolute + isImaginary = Math.abs(simp.value.re) < 1e-14; + } + for (const i in simp.units) { + if ((0, _object.hasOwnProperty)(simp.units, i)) { + if (simp.units[i].unit) { + if (simp.units[i].unit.name === 'VA' && isImaginary) { + simp.units[i].unit = UNITS.VAR; + } else if (simp.units[i].unit.name === 'VAR' && !isImaginary) { + simp.units[i].unit = UNITS.VA; + } + } + } + } + + // Now apply the best prefix + // Units must have only one unit and not have the fixPrefix flag set + if (simp.units.length === 1 && !simp.fixPrefix) { + // Units must have integer powers, otherwise the prefix will change the + // outputted value by not-an-integer-power-of-ten + if (Math.abs(simp.units[0].power - Math.round(simp.units[0].power)) < 1e-14) { + // Apply the best prefix + simp.units[0].prefix = simp._bestPrefix(); + } + } + const value = simp._denormalize(simp.value); + let str = simp.value !== null ? format(value, options || {}) : ''; + const unitStr = simp.formatUnits(); + if (simp.value && (0, _is.isComplex)(simp.value)) { + str = '(' + str + ')'; // Surround complex values with ( ) to enable better parsing + } + if (unitStr.length > 0 && str.length > 0) { + str += ' '; + } + str += unitStr; + return str; + }; + + /** + * Calculate the best prefix using current value. + * @memberof Unit + * @returns {Object} prefix + * @private + */ + Unit.prototype._bestPrefix = function () { + if (this.units.length !== 1) { + throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!'); + } + if (Math.abs(this.units[0].power - Math.round(this.units[0].power)) >= 1e-14) { + throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!'); + } + + // find the best prefix value (resulting in the value of which + // the absolute value of the log10 is closest to zero, + // though with a little offset of 1.2 for nicer values: you get a + // sequence 1mm 100mm 500mm 0.6m 1m 10m 100m 500m 0.6km 1km ... + + // Note: the units value can be any numeric type, but to find the best + // prefix it's enough to work with limited precision of a regular number + // Update: using mathjs abs since we also allow complex numbers + const absValue = this.value !== null ? abs(this.value) : 0; + const absUnitValue = abs(this.units[0].unit.value); + let bestPrefix = this.units[0].prefix; + if (absValue === 0) { + return bestPrefix; + } + const power = this.units[0].power; + let bestDiff = Math.log(absValue / Math.pow(bestPrefix.value * absUnitValue, power)) / Math.LN10 - 1.2; + if (bestDiff > -2.200001 && bestDiff < 1.800001) return bestPrefix; // Allow the original prefix + bestDiff = Math.abs(bestDiff); + const prefixes = this.units[0].unit.prefixes; + for (const p in prefixes) { + if ((0, _object.hasOwnProperty)(prefixes, p)) { + const prefix = prefixes[p]; + if (prefix.scientific) { + const diff = Math.abs(Math.log(absValue / Math.pow(prefix.value * absUnitValue, power)) / Math.LN10 - 1.2); + if (diff < bestDiff || diff === bestDiff && prefix.name.length < bestPrefix.name.length) { + // choose the prefix with the smallest diff, or if equal, choose the one + // with the shortest name (can happen with SHORTLONG for example) + bestPrefix = prefix; + bestDiff = diff; + } + } + } + } + return bestPrefix; + }; + + /** + * Returns an array of units whose sum is equal to this unit + * @memberof Unit + * @param {Array} [parts] An array of strings or valueless units. + * + * Example: + * + * const u = new Unit(1, 'm') + * u.splitUnit(['feet', 'inch']) + * [ 3 feet, 3.3700787401575 inch ] + * + * @return {Array} An array of units. + */ + Unit.prototype.splitUnit = function (parts) { + let x = this.clone(); + const ret = []; + for (let i = 0; i < parts.length; i++) { + // Convert x to the requested unit + x = x.to(parts[i]); + if (i === parts.length - 1) break; + + // Get the numeric value of this unit + const xNumeric = x.toNumeric(); + + // Check to see if xNumeric is nearly equal to an integer, + // since fix can incorrectly round down if there is round-off error + const xRounded = round(xNumeric); + let xFixed; + const isNearlyEqual = equal(xRounded, xNumeric); + if (isNearlyEqual) { + xFixed = xRounded; + } else { + xFixed = fix(x.toNumeric()); + } + const y = new Unit(xFixed, parts[i].toString()); + ret.push(y); + x = subtractScalar(x, y); + } + + // This little bit fixes a bug where the remainder should be 0 but is a little bit off. + // But instead of comparing x, the remainder, with zero--we will compare the sum of + // all the parts so far with the original value. If they are nearly equal, + // we set the remainder to 0. + let testSum = 0; + for (let i = 0; i < ret.length; i++) { + testSum = addScalar(testSum, ret[i].value); + } + if (equal(testSum, this.value)) { + x.value = 0; + } + ret.push(x); + return ret; + }; + const PREFIXES = { + NONE: { + '': { + name: '', + value: 1, + scientific: true + } + }, + SHORT: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e1, + scientific: false + }, + h: { + name: 'h', + value: 1e2, + scientific: false + }, + k: { + name: 'k', + value: 1e3, + scientific: true + }, + M: { + name: 'M', + value: 1e6, + scientific: true + }, + G: { + name: 'G', + value: 1e9, + scientific: true + }, + T: { + name: 'T', + value: 1e12, + scientific: true + }, + P: { + name: 'P', + value: 1e15, + scientific: true + }, + E: { + name: 'E', + value: 1e18, + scientific: true + }, + Z: { + name: 'Z', + value: 1e21, + scientific: true + }, + Y: { + name: 'Y', + value: 1e24, + scientific: true + }, + R: { + name: 'R', + value: 1e27, + scientific: true + }, + Q: { + name: 'Q', + value: 1e30, + scientific: true + }, + d: { + name: 'd', + value: 1e-1, + scientific: false + }, + c: { + name: 'c', + value: 1e-2, + scientific: false + }, + m: { + name: 'm', + value: 1e-3, + scientific: true + }, + u: { + name: 'u', + value: 1e-6, + scientific: true + }, + n: { + name: 'n', + value: 1e-9, + scientific: true + }, + p: { + name: 'p', + value: 1e-12, + scientific: true + }, + f: { + name: 'f', + value: 1e-15, + scientific: true + }, + a: { + name: 'a', + value: 1e-18, + scientific: true + }, + z: { + name: 'z', + value: 1e-21, + scientific: true + }, + y: { + name: 'y', + value: 1e-24, + scientific: true + }, + r: { + name: 'r', + value: 1e-27, + scientific: true + }, + q: { + name: 'q', + value: 1e-30, + scientific: true + } + }, + LONG: { + '': { + name: '', + value: 1, + scientific: true + }, + deca: { + name: 'deca', + value: 1e1, + scientific: false + }, + hecto: { + name: 'hecto', + value: 1e2, + scientific: false + }, + kilo: { + name: 'kilo', + value: 1e3, + scientific: true + }, + mega: { + name: 'mega', + value: 1e6, + scientific: true + }, + giga: { + name: 'giga', + value: 1e9, + scientific: true + }, + tera: { + name: 'tera', + value: 1e12, + scientific: true + }, + peta: { + name: 'peta', + value: 1e15, + scientific: true + }, + exa: { + name: 'exa', + value: 1e18, + scientific: true + }, + zetta: { + name: 'zetta', + value: 1e21, + scientific: true + }, + yotta: { + name: 'yotta', + value: 1e24, + scientific: true + }, + ronna: { + name: 'ronna', + value: 1e27, + scientific: true + }, + quetta: { + name: 'quetta', + value: 1e30, + scientific: true + }, + deci: { + name: 'deci', + value: 1e-1, + scientific: false + }, + centi: { + name: 'centi', + value: 1e-2, + scientific: false + }, + milli: { + name: 'milli', + value: 1e-3, + scientific: true + }, + micro: { + name: 'micro', + value: 1e-6, + scientific: true + }, + nano: { + name: 'nano', + value: 1e-9, + scientific: true + }, + pico: { + name: 'pico', + value: 1e-12, + scientific: true + }, + femto: { + name: 'femto', + value: 1e-15, + scientific: true + }, + atto: { + name: 'atto', + value: 1e-18, + scientific: true + }, + zepto: { + name: 'zepto', + value: 1e-21, + scientific: true + }, + yocto: { + name: 'yocto', + value: 1e-24, + scientific: true + }, + ronto: { + name: 'ronto', + value: 1e-27, + scientific: true + }, + quecto: { + name: 'quecto', + value: 1e-30, + scientific: true + } + }, + SQUARED: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e2, + scientific: false + }, + h: { + name: 'h', + value: 1e4, + scientific: false + }, + k: { + name: 'k', + value: 1e6, + scientific: true + }, + M: { + name: 'M', + value: 1e12, + scientific: true + }, + G: { + name: 'G', + value: 1e18, + scientific: true + }, + T: { + name: 'T', + value: 1e24, + scientific: true + }, + P: { + name: 'P', + value: 1e30, + scientific: true + }, + E: { + name: 'E', + value: 1e36, + scientific: true + }, + Z: { + name: 'Z', + value: 1e42, + scientific: true + }, + Y: { + name: 'Y', + value: 1e48, + scientific: true + }, + R: { + name: 'R', + value: 1e54, + scientific: true + }, + Q: { + name: 'Q', + value: 1e60, + scientific: true + }, + d: { + name: 'd', + value: 1e-2, + scientific: false + }, + c: { + name: 'c', + value: 1e-4, + scientific: false + }, + m: { + name: 'm', + value: 1e-6, + scientific: true + }, + u: { + name: 'u', + value: 1e-12, + scientific: true + }, + n: { + name: 'n', + value: 1e-18, + scientific: true + }, + p: { + name: 'p', + value: 1e-24, + scientific: true + }, + f: { + name: 'f', + value: 1e-30, + scientific: true + }, + a: { + name: 'a', + value: 1e-36, + scientific: true + }, + z: { + name: 'z', + value: 1e-42, + scientific: true + }, + y: { + name: 'y', + value: 1e-48, + scientific: true + }, + r: { + name: 'r', + value: 1e-54, + scientific: true + }, + q: { + name: 'q', + value: 1e-60, + scientific: true + } + }, + CUBIC: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e3, + scientific: false + }, + h: { + name: 'h', + value: 1e6, + scientific: false + }, + k: { + name: 'k', + value: 1e9, + scientific: true + }, + M: { + name: 'M', + value: 1e18, + scientific: true + }, + G: { + name: 'G', + value: 1e27, + scientific: true + }, + T: { + name: 'T', + value: 1e36, + scientific: true + }, + P: { + name: 'P', + value: 1e45, + scientific: true + }, + E: { + name: 'E', + value: 1e54, + scientific: true + }, + Z: { + name: 'Z', + value: 1e63, + scientific: true + }, + Y: { + name: 'Y', + value: 1e72, + scientific: true + }, + R: { + name: 'R', + value: 1e81, + scientific: true + }, + Q: { + name: 'Q', + value: 1e90, + scientific: true + }, + d: { + name: 'd', + value: 1e-3, + scientific: false + }, + c: { + name: 'c', + value: 1e-6, + scientific: false + }, + m: { + name: 'm', + value: 1e-9, + scientific: true + }, + u: { + name: 'u', + value: 1e-18, + scientific: true + }, + n: { + name: 'n', + value: 1e-27, + scientific: true + }, + p: { + name: 'p', + value: 1e-36, + scientific: true + }, + f: { + name: 'f', + value: 1e-45, + scientific: true + }, + a: { + name: 'a', + value: 1e-54, + scientific: true + }, + z: { + name: 'z', + value: 1e-63, + scientific: true + }, + y: { + name: 'y', + value: 1e-72, + scientific: true + }, + r: { + name: 'r', + value: 1e-81, + scientific: true + }, + q: { + name: 'q', + value: 1e-90, + scientific: true + } + }, + BINARY_SHORT_SI: { + '': { + name: '', + value: 1, + scientific: true + }, + k: { + name: 'k', + value: 1e3, + scientific: true + }, + M: { + name: 'M', + value: 1e6, + scientific: true + }, + G: { + name: 'G', + value: 1e9, + scientific: true + }, + T: { + name: 'T', + value: 1e12, + scientific: true + }, + P: { + name: 'P', + value: 1e15, + scientific: true + }, + E: { + name: 'E', + value: 1e18, + scientific: true + }, + Z: { + name: 'Z', + value: 1e21, + scientific: true + }, + Y: { + name: 'Y', + value: 1e24, + scientific: true + } + }, + BINARY_SHORT_IEC: { + '': { + name: '', + value: 1, + scientific: true + }, + Ki: { + name: 'Ki', + value: 1024, + scientific: true + }, + Mi: { + name: 'Mi', + value: Math.pow(1024, 2), + scientific: true + }, + Gi: { + name: 'Gi', + value: Math.pow(1024, 3), + scientific: true + }, + Ti: { + name: 'Ti', + value: Math.pow(1024, 4), + scientific: true + }, + Pi: { + name: 'Pi', + value: Math.pow(1024, 5), + scientific: true + }, + Ei: { + name: 'Ei', + value: Math.pow(1024, 6), + scientific: true + }, + Zi: { + name: 'Zi', + value: Math.pow(1024, 7), + scientific: true + }, + Yi: { + name: 'Yi', + value: Math.pow(1024, 8), + scientific: true + } + }, + BINARY_LONG_SI: { + '': { + name: '', + value: 1, + scientific: true + }, + kilo: { + name: 'kilo', + value: 1e3, + scientific: true + }, + mega: { + name: 'mega', + value: 1e6, + scientific: true + }, + giga: { + name: 'giga', + value: 1e9, + scientific: true + }, + tera: { + name: 'tera', + value: 1e12, + scientific: true + }, + peta: { + name: 'peta', + value: 1e15, + scientific: true + }, + exa: { + name: 'exa', + value: 1e18, + scientific: true + }, + zetta: { + name: 'zetta', + value: 1e21, + scientific: true + }, + yotta: { + name: 'yotta', + value: 1e24, + scientific: true + } + }, + BINARY_LONG_IEC: { + '': { + name: '', + value: 1, + scientific: true + }, + kibi: { + name: 'kibi', + value: 1024, + scientific: true + }, + mebi: { + name: 'mebi', + value: Math.pow(1024, 2), + scientific: true + }, + gibi: { + name: 'gibi', + value: Math.pow(1024, 3), + scientific: true + }, + tebi: { + name: 'tebi', + value: Math.pow(1024, 4), + scientific: true + }, + pebi: { + name: 'pebi', + value: Math.pow(1024, 5), + scientific: true + }, + exi: { + name: 'exi', + value: Math.pow(1024, 6), + scientific: true + }, + zebi: { + name: 'zebi', + value: Math.pow(1024, 7), + scientific: true + }, + yobi: { + name: 'yobi', + value: Math.pow(1024, 8), + scientific: true + } + }, + BTU: { + '': { + name: '', + value: 1, + scientific: true + }, + MM: { + name: 'MM', + value: 1e6, + scientific: true + } + } + }; + PREFIXES.SHORTLONG = (0, _extends2.default)({}, PREFIXES.SHORT, PREFIXES.LONG); + PREFIXES.BINARY_SHORT = (0, _extends2.default)({}, PREFIXES.BINARY_SHORT_SI, PREFIXES.BINARY_SHORT_IEC); + PREFIXES.BINARY_LONG = (0, _extends2.default)({}, PREFIXES.BINARY_LONG_SI, PREFIXES.BINARY_LONG_IEC); + + /* Internally, each unit is represented by a value and a dimension array. The elements of the dimensions array have the following meaning: + * Index Dimension + * ----- --------- + * 0 Length + * 1 Mass + * 2 Time + * 3 Current + * 4 Temperature + * 5 Luminous intensity + * 6 Amount of substance + * 7 Angle + * 8 Bit (digital) + * For example, the unit "298.15 K" is a pure temperature and would have a value of 298.15 and a dimension array of [0, 0, 0, 0, 1, 0, 0, 0, 0]. The unit "1 cal / (gm °C)" can be written in terms of the 9 fundamental dimensions as [length^2] / ([time^2] * [temperature]), and would a value of (after conversion to SI) 4184.0 and a dimensions array of [2, 0, -2, 0, -1, 0, 0, 0, 0]. + * + */ + + const BASE_DIMENSIONS = ['MASS', 'LENGTH', 'TIME', 'CURRENT', 'TEMPERATURE', 'LUMINOUS_INTENSITY', 'AMOUNT_OF_SUBSTANCE', 'ANGLE', 'BIT']; + const BASE_UNITS = { + NONE: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 0] + }, + MASS: { + dimensions: [1, 0, 0, 0, 0, 0, 0, 0, 0] + }, + LENGTH: { + dimensions: [0, 1, 0, 0, 0, 0, 0, 0, 0] + }, + TIME: { + dimensions: [0, 0, 1, 0, 0, 0, 0, 0, 0] + }, + CURRENT: { + dimensions: [0, 0, 0, 1, 0, 0, 0, 0, 0] + }, + TEMPERATURE: { + dimensions: [0, 0, 0, 0, 1, 0, 0, 0, 0] + }, + LUMINOUS_INTENSITY: { + dimensions: [0, 0, 0, 0, 0, 1, 0, 0, 0] + }, + AMOUNT_OF_SUBSTANCE: { + dimensions: [0, 0, 0, 0, 0, 0, 1, 0, 0] + }, + FORCE: { + dimensions: [1, 1, -2, 0, 0, 0, 0, 0, 0] + }, + SURFACE: { + dimensions: [0, 2, 0, 0, 0, 0, 0, 0, 0] + }, + VOLUME: { + dimensions: [0, 3, 0, 0, 0, 0, 0, 0, 0] + }, + ENERGY: { + dimensions: [1, 2, -2, 0, 0, 0, 0, 0, 0] + }, + POWER: { + dimensions: [1, 2, -3, 0, 0, 0, 0, 0, 0] + }, + PRESSURE: { + dimensions: [1, -1, -2, 0, 0, 0, 0, 0, 0] + }, + ELECTRIC_CHARGE: { + dimensions: [0, 0, 1, 1, 0, 0, 0, 0, 0] + }, + ELECTRIC_CAPACITANCE: { + dimensions: [-1, -2, 4, 2, 0, 0, 0, 0, 0] + }, + ELECTRIC_POTENTIAL: { + dimensions: [1, 2, -3, -1, 0, 0, 0, 0, 0] + }, + ELECTRIC_RESISTANCE: { + dimensions: [1, 2, -3, -2, 0, 0, 0, 0, 0] + }, + ELECTRIC_INDUCTANCE: { + dimensions: [1, 2, -2, -2, 0, 0, 0, 0, 0] + }, + ELECTRIC_CONDUCTANCE: { + dimensions: [-1, -2, 3, 2, 0, 0, 0, 0, 0] + }, + MAGNETIC_FLUX: { + dimensions: [1, 2, -2, -1, 0, 0, 0, 0, 0] + }, + MAGNETIC_FLUX_DENSITY: { + dimensions: [1, 0, -2, -1, 0, 0, 0, 0, 0] + }, + FREQUENCY: { + dimensions: [0, 0, -1, 0, 0, 0, 0, 0, 0] + }, + ANGLE: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 1, 0] + }, + BIT: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 1] + } + }; + for (const key in BASE_UNITS) { + if ((0, _object.hasOwnProperty)(BASE_UNITS, key)) { + BASE_UNITS[key].key = key; + } + } + const BASE_UNIT_NONE = {}; + const UNIT_NONE = { + name: '', + base: BASE_UNIT_NONE, + value: 1, + offset: 0, + dimensions: BASE_DIMENSIONS.map(x => 0) + }; + const UNITS = { + // length + meter: { + name: 'meter', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + inch: { + name: 'inch', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0254, + offset: 0 + }, + foot: { + name: 'foot', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.3048, + offset: 0 + }, + yard: { + name: 'yard', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.9144, + offset: 0 + }, + mile: { + name: 'mile', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1609.344, + offset: 0 + }, + link: { + name: 'link', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.201168, + offset: 0 + }, + rod: { + name: 'rod', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 5.0292, + offset: 0 + }, + chain: { + name: 'chain', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 20.1168, + offset: 0 + }, + angstrom: { + name: 'angstrom', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1e-10, + offset: 0 + }, + m: { + name: 'm', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + in: { + name: 'in', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0254, + offset: 0 + }, + ft: { + name: 'ft', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.3048, + offset: 0 + }, + yd: { + name: 'yd', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.9144, + offset: 0 + }, + mi: { + name: 'mi', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1609.344, + offset: 0 + }, + li: { + name: 'li', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.201168, + offset: 0 + }, + rd: { + name: 'rd', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 5.029210, + offset: 0 + }, + ch: { + name: 'ch', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 20.1168, + offset: 0 + }, + mil: { + name: 'mil', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0000254, + offset: 0 + }, + // 1/1000 inch + + // Surface + m2: { + name: 'm2', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.SQUARED, + value: 1, + offset: 0 + }, + sqin: { + name: 'sqin', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.00064516, + offset: 0 + }, + // 645.16 mm2 + sqft: { + name: 'sqft', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.09290304, + offset: 0 + }, + // 0.09290304 m2 + sqyd: { + name: 'sqyd', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.83612736, + offset: 0 + }, + // 0.83612736 m2 + sqmi: { + name: 'sqmi', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 2589988.110336, + offset: 0 + }, + // 2.589988110336 km2 + sqrd: { + name: 'sqrd', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 25.29295, + offset: 0 + }, + // 25.29295 m2 + sqch: { + name: 'sqch', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 404.6873, + offset: 0 + }, + // 404.6873 m2 + sqmil: { + name: 'sqmil', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 6.4516e-10, + offset: 0 + }, + // 6.4516 * 10^-10 m2 + acre: { + name: 'acre', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 4046.86, + offset: 0 + }, + // 4046.86 m2 + hectare: { + name: 'hectare', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 10000, + offset: 0 + }, + // 10000 m2 + + // Volume + m3: { + name: 'm3', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.CUBIC, + value: 1, + offset: 0 + }, + L: { + name: 'L', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + // litre + l: { + name: 'l', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + // litre + litre: { + name: 'litre', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.LONG, + value: 0.001, + offset: 0 + }, + cuin: { + name: 'cuin', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 1.6387064e-5, + offset: 0 + }, + // 1.6387064e-5 m3 + cuft: { + name: 'cuft', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.028316846592, + offset: 0 + }, + // 28.316 846 592 L + cuyd: { + name: 'cuyd', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.764554857984, + offset: 0 + }, + // 764.554 857 984 L + teaspoon: { + name: 'teaspoon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000005, + offset: 0 + }, + // 5 mL + tablespoon: { + name: 'tablespoon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000015, + offset: 0 + }, + // 15 mL + // {name: 'cup', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.000240, offset: 0}, // 240 mL // not possible, we have already another cup + drop: { + name: 'drop', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 5e-8, + offset: 0 + }, + // 0.05 mL = 5e-8 m3 + gtt: { + name: 'gtt', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 5e-8, + offset: 0 + }, + // 0.05 mL = 5e-8 m3 + + // Liquid volume + minim: { + name: 'minim', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000000061611519921875, + offset: 0 + }, + // 1/61440 gallons + fluiddram: { + name: 'fluiddram', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0000036966911953125, + offset: 0 + }, + // 1/1024 gallons + fluidounce: { + name: 'fluidounce', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0000295735295625, + offset: 0 + }, + // 1/128 gallons + gill: { + name: 'gill', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.00011829411825, + offset: 0 + }, + // 1/32 gallons + cc: { + name: 'cc', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 1e-6, + offset: 0 + }, + // 1e-6 L + cup: { + name: 'cup', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0002365882365, + offset: 0 + }, + // 1/16 gallons + pint: { + name: 'pint', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000473176473, + offset: 0 + }, + // 1/8 gallons + quart: { + name: 'quart', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000946352946, + offset: 0 + }, + // 1/4 gallons + gallon: { + name: 'gallon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.003785411784, + offset: 0 + }, + // 3.785411784 L + beerbarrel: { + name: 'beerbarrel', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.117347765304, + offset: 0 + }, + // 31 gallons + oilbarrel: { + name: 'oilbarrel', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.158987294928, + offset: 0 + }, + // 42 gallons + hogshead: { + name: 'hogshead', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.238480942392, + offset: 0 + }, + // 63 gallons + + // Mass + g: { + name: 'g', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + gram: { + name: 'gram', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.LONG, + value: 0.001, + offset: 0 + }, + ton: { + name: 'ton', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 907.18474, + offset: 0 + }, + t: { + name: 't', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 1000, + offset: 0 + }, + tonne: { + name: 'tonne', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.LONG, + value: 1000, + offset: 0 + }, + grain: { + name: 'grain', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 64.79891e-6, + offset: 0 + }, + dram: { + name: 'dram', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 1.7718451953125e-3, + offset: 0 + }, + ounce: { + name: 'ounce', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 28.349523125e-3, + offset: 0 + }, + poundmass: { + name: 'poundmass', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 453.59237e-3, + offset: 0 + }, + hundredweight: { + name: 'hundredweight', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 45.359237, + offset: 0 + }, + stick: { + name: 'stick', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 115e-3, + offset: 0 + }, + stone: { + name: 'stone', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 6.35029318, + offset: 0 + }, + gr: { + name: 'gr', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 64.79891e-6, + offset: 0 + }, + dr: { + name: 'dr', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 1.7718451953125e-3, + offset: 0 + }, + oz: { + name: 'oz', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 28.349523125e-3, + offset: 0 + }, + lbm: { + name: 'lbm', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 453.59237e-3, + offset: 0 + }, + cwt: { + name: 'cwt', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 45.359237, + offset: 0 + }, + // Time + s: { + name: 's', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + min: { + name: 'min', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 60, + offset: 0 + }, + h: { + name: 'h', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3600, + offset: 0 + }, + second: { + name: 'second', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + sec: { + name: 'sec', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + minute: { + name: 'minute', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 60, + offset: 0 + }, + hour: { + name: 'hour', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3600, + offset: 0 + }, + day: { + name: 'day', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 86400, + offset: 0 + }, + week: { + name: 'week', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 7 * 86400, + offset: 0 + }, + month: { + name: 'month', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 2629800, + // 1/12th of Julian year + offset: 0 + }, + year: { + name: 'year', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 31557600, + // Julian year + offset: 0 + }, + decade: { + name: 'decade', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 315576000, + // Julian decade + offset: 0 + }, + century: { + name: 'century', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3155760000, + // Julian century + offset: 0 + }, + millennium: { + name: 'millennium', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 31557600000, + // Julian millennium + offset: 0 + }, + // Frequency + hertz: { + name: 'Hertz', + base: BASE_UNITS.FREQUENCY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0, + reciprocal: true + }, + Hz: { + name: 'Hz', + base: BASE_UNITS.FREQUENCY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0, + reciprocal: true + }, + // Angle + rad: { + name: 'rad', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + radian: { + name: 'radian', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // deg = rad / (2*pi) * 360 = rad / 0.017453292519943295769236907684888 + deg: { + name: 'deg', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + degree: { + name: 'degree', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // grad = rad / (2*pi) * 400 = rad / 0.015707963267948966192313216916399 + grad: { + name: 'grad', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + gradian: { + name: 'gradian', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // cycle = rad / (2*pi) = rad / 6.2831853071795864769252867665793 + cycle: { + name: 'cycle', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // arcsec = rad / (3600 * (360 / 2 * pi)) = rad / 0.0000048481368110953599358991410235795 + arcsec: { + name: 'arcsec', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // arcmin = rad / (60 * (360 / 2 * pi)) = rad / 0.00029088820866572159615394846141477 + arcmin: { + name: 'arcmin', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // Electric current + A: { + name: 'A', + base: BASE_UNITS.CURRENT, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + ampere: { + name: 'ampere', + base: BASE_UNITS.CURRENT, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // Temperature + // K(C) = °C + 273.15 + // K(F) = (°F + 459.67) * (5 / 9) + // K(R) = °R * (5 / 9) + K: { + name: 'K', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + degC: { + name: 'degC', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 273.15 + }, + degF: { + name: 'degF', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: new Fraction(5, 9), + offset: 459.67 + }, + degR: { + name: 'degR', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: new Fraction(5, 9), + offset: 0 + }, + kelvin: { + name: 'kelvin', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + celsius: { + name: 'celsius', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 273.15 + }, + fahrenheit: { + name: 'fahrenheit', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: new Fraction(5, 9), + offset: 459.67 + }, + rankine: { + name: 'rankine', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: new Fraction(5, 9), + offset: 0 + }, + // amount of substance + mol: { + name: 'mol', + base: BASE_UNITS.AMOUNT_OF_SUBSTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + mole: { + name: 'mole', + base: BASE_UNITS.AMOUNT_OF_SUBSTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // luminous intensity + cd: { + name: 'cd', + base: BASE_UNITS.LUMINOUS_INTENSITY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + candela: { + name: 'candela', + base: BASE_UNITS.LUMINOUS_INTENSITY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // TODO: units STERADIAN + // {name: 'sr', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0}, + // {name: 'steradian', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0}, + + // Force + N: { + name: 'N', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + newton: { + name: 'newton', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + dyn: { + name: 'dyn', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.SHORT, + value: 0.00001, + offset: 0 + }, + dyne: { + name: 'dyne', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 0.00001, + offset: 0 + }, + lbf: { + name: 'lbf', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 4.4482216152605, + offset: 0 + }, + poundforce: { + name: 'poundforce', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 4.4482216152605, + offset: 0 + }, + kip: { + name: 'kip', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 4448.2216, + offset: 0 + }, + kilogramforce: { + name: 'kilogramforce', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 9.80665, + offset: 0 + }, + // Energy + J: { + name: 'J', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + joule: { + name: 'joule', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + erg: { + name: 'erg', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORTLONG, + // Both kiloerg and kerg are acceptable + value: 1e-7, + offset: 0 + }, + Wh: { + name: 'Wh', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 3600, + offset: 0 + }, + BTU: { + name: 'BTU', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.BTU, + value: 1055.05585262, + offset: 0 + }, + eV: { + name: 'eV', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 1.602176565e-19, + offset: 0 + }, + electronvolt: { + name: 'electronvolt', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.LONG, + value: 1.602176565e-19, + offset: 0 + }, + // Power + W: { + name: 'W', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + watt: { + name: 'watt', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + hp: { + name: 'hp', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.NONE, + value: 745.6998715386, + offset: 0 + }, + // Electrical power units + VAR: { + name: 'VAR', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: Complex.I, + offset: 0 + }, + VA: { + name: 'VA', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Pressure + Pa: { + name: 'Pa', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + psi: { + name: 'psi', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 6894.75729276459, + offset: 0 + }, + atm: { + name: 'atm', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 101325, + offset: 0 + }, + bar: { + name: 'bar', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.SHORTLONG, + value: 100000, + offset: 0 + }, + torr: { + name: 'torr', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 133.322, + offset: 0 + }, + mmHg: { + name: 'mmHg', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 133.322, + offset: 0 + }, + mmH2O: { + name: 'mmH2O', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 9.80665, + offset: 0 + }, + cmH2O: { + name: 'cmH2O', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 98.0665, + offset: 0 + }, + // Electric charge + coulomb: { + name: 'coulomb', + base: BASE_UNITS.ELECTRIC_CHARGE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + C: { + name: 'C', + base: BASE_UNITS.ELECTRIC_CHARGE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric capacitance + farad: { + name: 'farad', + base: BASE_UNITS.ELECTRIC_CAPACITANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + F: { + name: 'F', + base: BASE_UNITS.ELECTRIC_CAPACITANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric potential + volt: { + name: 'volt', + base: BASE_UNITS.ELECTRIC_POTENTIAL, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + V: { + name: 'V', + base: BASE_UNITS.ELECTRIC_POTENTIAL, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric resistance + ohm: { + name: 'ohm', + base: BASE_UNITS.ELECTRIC_RESISTANCE, + prefixes: PREFIXES.SHORTLONG, + // Both Mohm and megaohm are acceptable + value: 1, + offset: 0 + }, + /* + * Unicode breaks in browsers if charset is not specified + Ω: { + name: 'Ω', + base: BASE_UNITS.ELECTRIC_RESISTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + */ + // Electric inductance + henry: { + name: 'henry', + base: BASE_UNITS.ELECTRIC_INDUCTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + H: { + name: 'H', + base: BASE_UNITS.ELECTRIC_INDUCTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric conductance + siemens: { + name: 'siemens', + base: BASE_UNITS.ELECTRIC_CONDUCTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + S: { + name: 'S', + base: BASE_UNITS.ELECTRIC_CONDUCTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Magnetic flux + weber: { + name: 'weber', + base: BASE_UNITS.MAGNETIC_FLUX, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + Wb: { + name: 'Wb', + base: BASE_UNITS.MAGNETIC_FLUX, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Magnetic flux density + tesla: { + name: 'tesla', + base: BASE_UNITS.MAGNETIC_FLUX_DENSITY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + T: { + name: 'T', + base: BASE_UNITS.MAGNETIC_FLUX_DENSITY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Binary + b: { + name: 'b', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_SHORT, + value: 1, + offset: 0 + }, + bits: { + name: 'bits', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_LONG, + value: 1, + offset: 0 + }, + B: { + name: 'B', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_SHORT, + value: 8, + offset: 0 + }, + bytes: { + name: 'bytes', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_LONG, + value: 8, + offset: 0 + } + }; + + // aliases (formerly plurals) + // note that ALIASES is only used at creation to create more entries in UNITS by copying the aliased units + const ALIASES = { + meters: 'meter', + inches: 'inch', + feet: 'foot', + yards: 'yard', + miles: 'mile', + links: 'link', + rods: 'rod', + chains: 'chain', + angstroms: 'angstrom', + lt: 'l', + litres: 'litre', + liter: 'litre', + liters: 'litre', + teaspoons: 'teaspoon', + tablespoons: 'tablespoon', + minims: 'minim', + fldr: 'fluiddram', + fluiddrams: 'fluiddram', + floz: 'fluidounce', + fluidounces: 'fluidounce', + gi: 'gill', + gills: 'gill', + cp: 'cup', + cups: 'cup', + pt: 'pint', + pints: 'pint', + qt: 'quart', + quarts: 'quart', + gal: 'gallon', + gallons: 'gallon', + bbl: 'beerbarrel', + beerbarrels: 'beerbarrel', + obl: 'oilbarrel', + oilbarrels: 'oilbarrel', + hogsheads: 'hogshead', + gtts: 'gtt', + grams: 'gram', + tons: 'ton', + tonnes: 'tonne', + grains: 'grain', + drams: 'dram', + ounces: 'ounce', + poundmasses: 'poundmass', + hundredweights: 'hundredweight', + sticks: 'stick', + lb: 'lbm', + lbs: 'lbm', + kips: 'kip', + kgf: 'kilogramforce', + acres: 'acre', + hectares: 'hectare', + sqfeet: 'sqft', + sqyard: 'sqyd', + sqmile: 'sqmi', + sqmiles: 'sqmi', + mmhg: 'mmHg', + mmh2o: 'mmH2O', + cmh2o: 'cmH2O', + seconds: 'second', + secs: 'second', + minutes: 'minute', + mins: 'minute', + hours: 'hour', + hr: 'hour', + hrs: 'hour', + days: 'day', + weeks: 'week', + months: 'month', + years: 'year', + decades: 'decade', + centuries: 'century', + millennia: 'millennium', + hertz: 'hertz', + radians: 'radian', + degrees: 'degree', + gradians: 'gradian', + cycles: 'cycle', + arcsecond: 'arcsec', + arcseconds: 'arcsec', + arcminute: 'arcmin', + arcminutes: 'arcmin', + BTUs: 'BTU', + watts: 'watt', + joules: 'joule', + amperes: 'ampere', + amps: 'ampere', + amp: 'ampere', + coulombs: 'coulomb', + volts: 'volt', + ohms: 'ohm', + farads: 'farad', + webers: 'weber', + teslas: 'tesla', + electronvolts: 'electronvolt', + moles: 'mole', + bit: 'bits', + byte: 'bytes' + }; + + /** + * Calculate the values for the angle units. + * Value is calculated as number or BigNumber depending on the configuration + * @param {{number: 'number' | 'BigNumber'}} config + */ + function calculateAngleValues(config) { + if (config.number === 'BigNumber') { + const pi = (0, _constants.createBigNumberPi)(BigNumber); + UNITS.rad.value = new BigNumber(1); + UNITS.deg.value = pi.div(180); // 2 * pi / 360 + UNITS.grad.value = pi.div(200); // 2 * pi / 400 + UNITS.cycle.value = pi.times(2); // 2 * pi + UNITS.arcsec.value = pi.div(648000); // 2 * pi / 360 / 3600 + UNITS.arcmin.value = pi.div(10800); // 2 * pi / 360 / 60 + } else { + // number + UNITS.rad.value = 1; + UNITS.deg.value = Math.PI / 180; // 2 * pi / 360 + UNITS.grad.value = Math.PI / 200; // 2 * pi / 400 + UNITS.cycle.value = Math.PI * 2; // 2 * pi + UNITS.arcsec.value = Math.PI / 648000; // 2 * pi / 360 / 3600 + UNITS.arcmin.value = Math.PI / 10800; // 2 * pi / 360 / 60 + } + + // copy to the full names of the angles + UNITS.radian.value = UNITS.rad.value; + UNITS.degree.value = UNITS.deg.value; + UNITS.gradian.value = UNITS.grad.value; + } + + // apply the angle values now + calculateAngleValues(config); + if (on) { + // recalculate the values on change of configuration + on('config', function (curr, prev) { + if (curr.number !== prev.number) { + calculateAngleValues(curr); + } + }); + } + + /** + * A unit system is a set of dimensionally independent base units plus a set of derived units, formed by multiplication and division of the base units, that are by convention used with the unit system. + * A user perhaps could issue a command to select a preferred unit system, or use the default (see below). + * Auto unit system: The default unit system is updated on the fly anytime a unit is parsed. The corresponding unit in the default unit system is updated, so that answers are given in the same units the user supplies. + */ + const UNIT_SYSTEMS = { + si: { + // Base units + NONE: { + unit: UNIT_NONE, + prefix: PREFIXES.NONE[''] + }, + LENGTH: { + unit: UNITS.m, + prefix: PREFIXES.SHORT[''] + }, + MASS: { + unit: UNITS.g, + prefix: PREFIXES.SHORT.k + }, + TIME: { + unit: UNITS.s, + prefix: PREFIXES.SHORT[''] + }, + CURRENT: { + unit: UNITS.A, + prefix: PREFIXES.SHORT[''] + }, + TEMPERATURE: { + unit: UNITS.K, + prefix: PREFIXES.SHORT[''] + }, + LUMINOUS_INTENSITY: { + unit: UNITS.cd, + prefix: PREFIXES.SHORT[''] + }, + AMOUNT_OF_SUBSTANCE: { + unit: UNITS.mol, + prefix: PREFIXES.SHORT[''] + }, + ANGLE: { + unit: UNITS.rad, + prefix: PREFIXES.SHORT[''] + }, + BIT: { + unit: UNITS.bits, + prefix: PREFIXES.SHORT[''] + }, + // Derived units + FORCE: { + unit: UNITS.N, + prefix: PREFIXES.SHORT[''] + }, + ENERGY: { + unit: UNITS.J, + prefix: PREFIXES.SHORT[''] + }, + POWER: { + unit: UNITS.W, + prefix: PREFIXES.SHORT[''] + }, + PRESSURE: { + unit: UNITS.Pa, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CHARGE: { + unit: UNITS.C, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CAPACITANCE: { + unit: UNITS.F, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_POTENTIAL: { + unit: UNITS.V, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_RESISTANCE: { + unit: UNITS.ohm, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_INDUCTANCE: { + unit: UNITS.H, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CONDUCTANCE: { + unit: UNITS.S, + prefix: PREFIXES.SHORT[''] + }, + MAGNETIC_FLUX: { + unit: UNITS.Wb, + prefix: PREFIXES.SHORT[''] + }, + MAGNETIC_FLUX_DENSITY: { + unit: UNITS.T, + prefix: PREFIXES.SHORT[''] + }, + FREQUENCY: { + unit: UNITS.Hz, + prefix: PREFIXES.SHORT[''] + } + } + }; + + // Clone to create the other unit systems + UNIT_SYSTEMS.cgs = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + UNIT_SYSTEMS.cgs.LENGTH = { + unit: UNITS.m, + prefix: PREFIXES.SHORT.c + }; + UNIT_SYSTEMS.cgs.MASS = { + unit: UNITS.g, + prefix: PREFIXES.SHORT[''] + }; + UNIT_SYSTEMS.cgs.FORCE = { + unit: UNITS.dyn, + prefix: PREFIXES.SHORT[''] + }; + UNIT_SYSTEMS.cgs.ENERGY = { + unit: UNITS.erg, + prefix: PREFIXES.NONE[''] + }; + // there are wholly 4 unique cgs systems for electricity and magnetism, + // so let's not worry about it unless somebody complains + + UNIT_SYSTEMS.us = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + UNIT_SYSTEMS.us.LENGTH = { + unit: UNITS.ft, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.MASS = { + unit: UNITS.lbm, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.TEMPERATURE = { + unit: UNITS.degF, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.FORCE = { + unit: UNITS.lbf, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.ENERGY = { + unit: UNITS.BTU, + prefix: PREFIXES.BTU[''] + }; + UNIT_SYSTEMS.us.POWER = { + unit: UNITS.hp, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.PRESSURE = { + unit: UNITS.psi, + prefix: PREFIXES.NONE[''] + }; + + // Add additional unit systems here. + + // Choose a unit system to seed the auto unit system. + UNIT_SYSTEMS.auto = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + + // Set the current unit system + let currentUnitSystem = UNIT_SYSTEMS.auto; + + /** + * Set a unit system for formatting derived units. + * @memberof Unit + * @param {string} [name] The name of the unit system. + */ + Unit.setUnitSystem = function (name) { + if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS, name)) { + currentUnitSystem = UNIT_SYSTEMS[name]; + } else { + throw new Error('Unit system ' + name + ' does not exist. Choices are: ' + Object.keys(UNIT_SYSTEMS).join(', ')); + } + }; + + /** + * Return the current unit system. + * @memberof Unit + * @return {string} The current unit system. + */ + Unit.getUnitSystem = function () { + for (const key in UNIT_SYSTEMS) { + if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS, key)) { + if (UNIT_SYSTEMS[key] === currentUnitSystem) { + return key; + } + } + } + }; + + /** + * Converters to convert from number to an other numeric type like BigNumber + * or Fraction + */ + Unit.typeConverters = { + BigNumber: function (x) { + if (x !== null && x !== void 0 && x.isFraction) return new BigNumber(x.n).div(x.d).times(x.s); + return new BigNumber(x + ''); // stringify to prevent constructor error + }, + Fraction: function (x) { + return new Fraction(x); + }, + Complex: function (x) { + return x; + }, + number: function (x) { + if (x !== null && x !== void 0 && x.isFraction) return number(x); + return x; + } + }; + + /** + * Retrieve the right converter function corresponding with this unit's + * value + * + * @memberof Unit + * @return {Function} + */ + Unit.prototype._numberConverter = function () { + const convert = Unit.typeConverters[this.valueType()]; + if (convert) { + return convert; + } + throw new TypeError('Unsupported Unit value type "' + this.valueType() + '"'); + }; + + /** + * Retrieve the right convertor function corresponding with the type + * of provided exampleValue. + * + * @param {string} type A string 'number', 'BigNumber', or 'Fraction' + * In case of an unknown type, + * @return {Function} + */ + Unit._getNumberConverter = function (type) { + if (!Unit.typeConverters[type]) { + throw new TypeError('Unsupported type "' + type + '"'); + } + return Unit.typeConverters[type]; + }; + + // Add dimensions to each built-in unit + for (const key in UNITS) { + if ((0, _object.hasOwnProperty)(UNITS, key)) { + const unit = UNITS[key]; + unit.dimensions = unit.base.dimensions; + } + } + + // Create aliases + for (const name in ALIASES) { + if ((0, _object.hasOwnProperty)(ALIASES, name)) { + const unit = UNITS[ALIASES[name]]; + const alias = {}; + for (const key in unit) { + if ((0, _object.hasOwnProperty)(unit, key)) { + alias[key] = unit[key]; + } + } + alias.name = name; + UNITS[name] = alias; + } + } + + /** + * Checks if a character is a valid latin letter (upper or lower case). + * Note that this function can be overridden, for example to allow support of other alphabets. + * @memberof Unit + * @param {string} c Tested character + * @return {boolean} true if the character is a latin letter + */ + Unit.isValidAlpha = function isValidAlpha(c) { + return /^[a-zA-Z]$/.test(c); + }; + function assertUnitNameIsValid(name) { + for (let i = 0; i < name.length; i++) { + c = name.charAt(i); + if (i === 0 && !Unit.isValidAlpha(c)) { + throw new Error('Invalid unit name (must begin with alpha character): "' + name + '"'); + } + if (i > 0 && !(Unit.isValidAlpha(c) || isDigit(c))) { + throw new Error('Invalid unit name (only alphanumeric characters are allowed): "' + name + '"'); + } + } + } + + /** + * Wrapper around createUnitSingle. + * Example: + * createUnit( { + * foo: { + * prefixes: 'long', + * baseName: 'essence-of-foo' + * }, + * bar: '40 foo', + * baz: { + * definition: '1 bar/hour', + * prefixes: 'long' + * } + * }, + * { + * override: true + * }) + * @memberof Unit + * @param {object} obj Object map. Each key becomes a unit which is defined by its value. + * @param {object} options + * @return {Unit} the last created unit + */ + Unit.createUnit = function (obj, options) { + if (typeof obj !== 'object') { + throw new TypeError("createUnit expects first parameter to be of type 'Object'"); + } + + // Remove all units and aliases we are overriding + if (options && options.override) { + for (const key in obj) { + if ((0, _object.hasOwnProperty)(obj, key)) { + Unit.deleteUnit(key); + } + if (obj[key].aliases) { + for (let i = 0; i < obj[key].aliases.length; i++) { + Unit.deleteUnit(obj[key].aliases[i]); + } + } + } + } + + // TODO: traverse multiple times until all units have been added + let lastUnit; + for (const key in obj) { + if ((0, _object.hasOwnProperty)(obj, key)) { + lastUnit = Unit.createUnitSingle(key, obj[key]); + } + } + return lastUnit; + }; + + /** + * Create a user-defined unit and register it with the Unit type. + * Example: + * createUnitSingle('knot', '0.514444444 m/s') + * + * @memberof Unit + * @param {string} name The name of the new unit. Must be unique. Example: 'knot' + * @param {string | Unit | object} definition Definition of the unit in terms + * of existing units. For example, '0.514444444 m / s'. Can be a Unit, a string, + * or an Object. If an Object, may have the following properties: + * - definition {string | Unit} The definition of this unit. + * - prefixes {string} "none", "short", "long", "binary_short", or "binary_long". + * The default is "none". + * - aliases {Array} Array of strings. Example: ['knots', 'kt', 'kts'] + * - offset {Numeric} An offset to apply when converting from the unit. For + * example, the offset for celsius is 273.15 and the offset for farhenheit + * is 459.67. Default is 0. + * - baseName {string} If the unit's dimension does not match that of any other + * base unit, the name of the newly create base unit. Otherwise, this property + * has no effect. + * + * @return {Unit} + */ + Unit.createUnitSingle = function (name, obj) { + if (typeof obj === 'undefined' || obj === null) { + obj = {}; + } + if (typeof name !== 'string') { + throw new TypeError("createUnitSingle expects first parameter to be of type 'string'"); + } + + // Check collisions with existing units + if ((0, _object.hasOwnProperty)(UNITS, name)) { + throw new Error('Cannot create unit "' + name + '": a unit with that name already exists'); + } + + // TODO: Validate name for collisions with other built-in functions (like abs or cos, for example), and for acceptable variable names. For example, '42' is probably not a valid unit. Nor is '%', since it is also an operator. + + assertUnitNameIsValid(name); + let defUnit = null; // The Unit from which the new unit will be created. + let aliases = []; + let offset = 0; + let definition; + let prefixes; + let baseName; + if (obj && obj.type === 'Unit') { + defUnit = obj.clone(); + } else if (typeof obj === 'string') { + if (obj !== '') { + definition = obj; + } + } else if (typeof obj === 'object') { + definition = obj.definition; + prefixes = obj.prefixes; + offset = obj.offset; + baseName = obj.baseName; + if (obj.aliases) { + aliases = obj.aliases.valueOf(); // aliases could be a Matrix, so convert to Array + } + } else { + throw new TypeError('Cannot create unit "' + name + '" from "' + obj.toString() + '": expecting "string" or "Unit" or "Object"'); + } + if (aliases) { + for (let i = 0; i < aliases.length; i++) { + if ((0, _object.hasOwnProperty)(UNITS, aliases[i])) { + throw new Error('Cannot create alias "' + aliases[i] + '": a unit with that name already exists'); + } + } + } + if (definition && typeof definition === 'string' && !defUnit) { + try { + defUnit = Unit.parse(definition, { + allowNoUnits: true + }); + } catch (ex) { + ex.message = 'Could not create unit "' + name + '" from "' + definition + '": ' + ex.message; + throw ex; + } + } else if (definition && definition.type === 'Unit') { + defUnit = definition.clone(); + } + aliases = aliases || []; + offset = offset || 0; + if (prefixes && prefixes.toUpperCase) { + prefixes = PREFIXES[prefixes.toUpperCase()] || PREFIXES.NONE; + } else { + prefixes = PREFIXES.NONE; + } + + // If defUnit is null, it is because the user did not + // specify a defintion. So create a new base dimension. + let newUnit = {}; + if (!defUnit) { + // Add a new base dimension + baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo + if (BASE_DIMENSIONS.indexOf(baseName) >= 0) { + throw new Error('Cannot create new base unit "' + name + '": a base unit with that name already exists (and cannot be overridden)'); + } + BASE_DIMENSIONS.push(baseName); + + // Push 0 onto existing base units + for (const b in BASE_UNITS) { + if ((0, _object.hasOwnProperty)(BASE_UNITS, b)) { + BASE_UNITS[b].dimensions[BASE_DIMENSIONS.length - 1] = 0; + } + } + + // Add the new base unit + const newBaseUnit = { + dimensions: [] + }; + for (let i = 0; i < BASE_DIMENSIONS.length; i++) { + newBaseUnit.dimensions[i] = 0; + } + newBaseUnit.dimensions[BASE_DIMENSIONS.length - 1] = 1; + newBaseUnit.key = baseName; + BASE_UNITS[baseName] = newBaseUnit; + newUnit = { + name, + value: 1, + dimensions: BASE_UNITS[baseName].dimensions.slice(0), + prefixes, + offset, + base: BASE_UNITS[baseName] + }; + currentUnitSystem[baseName] = { + unit: newUnit, + prefix: PREFIXES.NONE[''] + }; + } else { + newUnit = { + name, + value: defUnit.value, + dimensions: defUnit.dimensions.slice(0), + prefixes, + offset + }; + + // Create a new base if no matching base exists + let anyMatch = false; + for (const i in BASE_UNITS) { + if ((0, _object.hasOwnProperty)(BASE_UNITS, i)) { + let match = true; + for (let j = 0; j < BASE_DIMENSIONS.length; j++) { + if (Math.abs((newUnit.dimensions[j] || 0) - (BASE_UNITS[i].dimensions[j] || 0)) > 1e-12) { + match = false; + break; + } + } + if (match) { + anyMatch = true; + newUnit.base = BASE_UNITS[i]; + break; + } + } + } + if (!anyMatch) { + baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo + // Add the new base unit + const newBaseUnit = { + dimensions: defUnit.dimensions.slice(0) + }; + newBaseUnit.key = baseName; + BASE_UNITS[baseName] = newBaseUnit; + currentUnitSystem[baseName] = { + unit: newUnit, + prefix: PREFIXES.NONE[''] + }; + newUnit.base = BASE_UNITS[baseName]; + } + } + Unit.UNITS[name] = newUnit; + for (let i = 0; i < aliases.length; i++) { + const aliasName = aliases[i]; + const alias = {}; + for (const key in newUnit) { + if ((0, _object.hasOwnProperty)(newUnit, key)) { + alias[key] = newUnit[key]; + } + } + alias.name = aliasName; + Unit.UNITS[aliasName] = alias; + } + + // delete the memoization cache because we created a new unit + delete _findUnit.cache; + return new Unit(null, name); + }; + Unit.deleteUnit = function (name) { + delete Unit.UNITS[name]; + + // delete the memoization cache because we deleted a unit + delete _findUnit.cache; + }; + + // expose arrays with prefixes, dimensions, units, systems + Unit.PREFIXES = PREFIXES; + Unit.BASE_DIMENSIONS = BASE_DIMENSIONS; + Unit.BASE_UNITS = BASE_UNITS; + Unit.UNIT_SYSTEMS = UNIT_SYSTEMS; + Unit.UNITS = UNITS; + return Unit; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/createUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/createUnit.js new file mode 100644 index 0000000..1038a3b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/createUnit.js @@ -0,0 +1,85 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createCreateUnit = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'createUnit'; +const dependencies = ['typed', 'Unit']; +const createCreateUnit = exports.createCreateUnit = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Unit + } = _ref; + /** + * Create a user-defined unit and register it with the Unit type. + * + * Syntax: + * + * math.createUnit({ + * baseUnit1: { + * aliases: [string, ...] + * prefixes: object + * }, + * unit2: { + * definition: string, + * aliases: [string, ...] + * prefixes: object, + * offset: number + * }, + * unit3: string // Shortcut + * }) + * + * // Another shortcut: + * math.createUnit(string, unit : string, [object]) + * + * Examples: + * + * math.createUnit('foo') + * math.createUnit('knot', {definition: '0.514444444 m/s', aliases: ['knots', 'kt', 'kts']}) + * math.createUnit('mph', '1 mile/hour') + * math.createUnit('km', math.unit(1000, 'm')) + * + * @param {string} name The name of the new unit. Must be unique. Example: 'knot' + * @param {string, UnitDefinition, Unit} definition Definition of the unit in terms of existing units. For example, '0.514444444 m / s'. + * @param {Object} options (optional) An object containing any of the following properties: + * - `prefixes {string}` "none", "short", "long", "binary_short", or "binary_long". The default is "none". + * - `aliases {Array}` Array of strings. Example: ['knots', 'kt', 'kts'] + * - `offset {Numeric}` An offset to apply when converting from the unit. For example, the offset for celsius is 273.15. Default is 0. + * + * See also: + * + * unit + * + * @return {Unit} The new unit + */ + return typed(name, { + // General function signature. First parameter is an object where each property is the definition of a new unit. The object keys are the unit names and the values are the definitions. The values can be objects, strings, or Units. If a property is an empty object or an empty string, a new base unit is created. The second parameter is the options. + 'Object, Object': function (obj, options) { + return Unit.createUnit(obj, options); + }, + // Same as above but without the options. + Object: function (obj) { + return Unit.createUnit(obj, {}); + }, + // Shortcut method for creating one unit. + 'string, Unit | string | Object, Object': function (name, def, options) { + const obj = {}; + obj[name] = def; + return Unit.createUnit(obj, options); + }, + // Same as above but without the options. + 'string, Unit | string | Object': function (name, def) { + const obj = {}; + obj[name] = def; + return Unit.createUnit(obj, {}); + }, + // Without a definition, creates a base unit. + string: function (name) { + const obj = {}; + obj[name] = {}; + return Unit.createUnit(obj, {}); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/splitUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/splitUnit.js new file mode 100644 index 0000000..b2d0226 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/splitUnit.js @@ -0,0 +1,38 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSplitUnit = void 0; +var _factory = require("../../../utils/factory.js"); +const name = 'splitUnit'; +const dependencies = ['typed']; +const createSplitUnit = exports.createSplitUnit = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed + } = _ref; + /** + * Split a unit in an array of units whose sum is equal to the original unit. + * + * Syntax: + * + * math.splitUnit(unit: Unit, parts: Array.) + * + * Example: + * + * math.splitUnit(new Unit(1, 'm'), ['feet', 'inch']) + * // [ 3 feet, 3.3700787401575 inch ] + * + * See also: + * + * unit + * + * @param {Array} [parts] An array of strings or valueless units. + * @return {Array} An array of units. + */ + return typed(name, { + 'Unit, Array': function (unit, parts) { + return unit.splitUnit(parts); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/unit.js new file mode 100644 index 0000000..cdd12a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/function/unit.js @@ -0,0 +1,66 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createUnitFunction = void 0; +var _factory = require("../../../utils/factory.js"); +var _collection = require("../../../utils/collection.js"); +const name = 'unit'; +const dependencies = ['typed', 'Unit']; + +// This function is named createUnitFunction to prevent a naming conflict with createUnit +const createUnitFunction = exports.createUnitFunction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, _ref => { + let { + typed, + Unit + } = _ref; + /** + * Create a unit. Depending on the passed arguments, the function + * will create and return a new math.Unit object. + * When a matrix is provided, all elements will be converted to units. + * + * Syntax: + * + * math.unit(unit : string) + * math.unit(value : number, valuelessUnit : Unit) + * math.unit(value : number, valuelessUnit : string) + * + * Examples: + * + * const kph = math.unit('km/h') // returns Unit km/h (valueless) + * const v = math.unit(25, kph) // returns Unit 25 km/h + * const a = math.unit(5, 'cm') // returns Unit 50 mm + * const b = math.unit('23 kg') // returns Unit 23 kg + * a.to('m') // returns Unit 0.05 m + * + * See also: + * + * bignumber, boolean, complex, index, matrix, number, string, createUnit + * + * @param {* | Array | Matrix} args A number and unit. + * @return {Unit | Array | Matrix} The created unit + */ + + return typed(name, { + Unit: function (x) { + return x.clone(); + }, + string: function (x) { + if (Unit.isValuelessUnit(x)) { + return new Unit(null, x); // a pure unit + } + return Unit.parse(x, { + allowNoUnits: true + }); // a unit with value, like '5cm' + }, + 'number | BigNumber | Fraction | Complex, string | Unit': function (value, unit) { + return new Unit(value, unit); + }, + 'number | BigNumber | Fraction': function (value) { + // dimensionless + return new Unit(value); + }, + 'Array | Matrix': typed.referToSelf(self => x => (0, _collection.deepMap)(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/physicalConstants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/physicalConstants.js new file mode 100644 index 0000000..a38991b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/type/unit/physicalConstants.js @@ -0,0 +1,106 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createWienDisplacement = exports.createWeakMixingAngle = exports.createVacuumImpedance = exports.createThomsonCrossSection = exports.createStefanBoltzmann = exports.createSpeedOfLight = exports.createSecondRadiation = exports.createSackurTetrode = exports.createRydberg = exports.createReducedPlanckConstant = exports.createQuantumOfCirculation = exports.createProtonMass = exports.createPlanckTime = exports.createPlanckTemperature = exports.createPlanckMass = exports.createPlanckLength = exports.createPlanckConstant = exports.createPlanckCharge = exports.createNuclearMagneton = exports.createNeutronMass = exports.createMolarVolume = exports.createMolarPlanckConstant = exports.createMolarMassC12 = exports.createMolarMass = exports.createMagneticFluxQuantum = exports.createMagneticConstant = exports.createLoschmidt = exports.createKlitzing = exports.createJosephson = exports.createInverseConductanceQuantum = exports.createHartreeEnergy = exports.createGravity = exports.createGravitationConstant = exports.createGasConstant = exports.createFirstRadiation = exports.createFineStructure = exports.createFermiCoupling = exports.createFaraday = exports.createElementaryCharge = exports.createElectronMass = exports.createElectricConstant = exports.createEfimovFactor = exports.createDeuteronMass = exports.createCoulomb = exports.createConductanceQuantum = exports.createClassicalElectronRadius = exports.createBoltzmann = exports.createBohrRadius = exports.createBohrMagneton = exports.createAvogadro = exports.createAtomicMass = void 0; +var _factory = require("../../utils/factory.js"); +// Source: https://en.wikipedia.org/wiki/Physical_constant + +// Universal constants +const createSpeedOfLight = exports.createSpeedOfLight = /* #__PURE__ */unitFactory('speedOfLight', '299792458', 'm s^-1'); +const createGravitationConstant = exports.createGravitationConstant = /* #__PURE__ */unitFactory('gravitationConstant', '6.67430e-11', 'm^3 kg^-1 s^-2'); +const createPlanckConstant = exports.createPlanckConstant = /* #__PURE__ */unitFactory('planckConstant', '6.62607015e-34', 'J s'); +const createReducedPlanckConstant = exports.createReducedPlanckConstant = /* #__PURE__ */unitFactory('reducedPlanckConstant', '1.0545718176461565e-34', 'J s'); + +// Electromagnetic constants +const createMagneticConstant = exports.createMagneticConstant = /* #__PURE__ */unitFactory('magneticConstant', '1.25663706212e-6', 'N A^-2'); +const createElectricConstant = exports.createElectricConstant = /* #__PURE__ */unitFactory('electricConstant', '8.8541878128e-12', 'F m^-1'); +const createVacuumImpedance = exports.createVacuumImpedance = /* #__PURE__ */unitFactory('vacuumImpedance', '376.730313667', 'ohm'); +const createCoulomb = exports.createCoulomb = /* #__PURE__ */unitFactory('coulomb', '8.987551792261171e9', 'N m^2 C^-2'); +const createElementaryCharge = exports.createElementaryCharge = /* #__PURE__ */unitFactory('elementaryCharge', '1.602176634e-19', 'C'); +const createBohrMagneton = exports.createBohrMagneton = /* #__PURE__ */unitFactory('bohrMagneton', '9.2740100783e-24', 'J T^-1'); +const createConductanceQuantum = exports.createConductanceQuantum = /* #__PURE__ */unitFactory('conductanceQuantum', '7.748091729863649e-5', 'S'); +const createInverseConductanceQuantum = exports.createInverseConductanceQuantum = /* #__PURE__ */unitFactory('inverseConductanceQuantum', '12906.403729652257', 'ohm'); +const createMagneticFluxQuantum = exports.createMagneticFluxQuantum = /* #__PURE__ */unitFactory('magneticFluxQuantum', '2.0678338484619295e-15', 'Wb'); +const createNuclearMagneton = exports.createNuclearMagneton = /* #__PURE__ */unitFactory('nuclearMagneton', '5.0507837461e-27', 'J T^-1'); +const createKlitzing = exports.createKlitzing = /* #__PURE__ */unitFactory('klitzing', '25812.807459304513', 'ohm'); +const createJosephson = exports.createJosephson = /* #__PURE__ */unitFactory('josephson', '4.835978484169836e14 Hz V', 'Hz V^-1'); // TODO: support for Hz needed + +// Atomic and nuclear constants +const createBohrRadius = exports.createBohrRadius = /* #__PURE__ */unitFactory('bohrRadius', '5.29177210903e-11', 'm'); +const createClassicalElectronRadius = exports.createClassicalElectronRadius = /* #__PURE__ */unitFactory('classicalElectronRadius', '2.8179403262e-15', 'm'); +const createElectronMass = exports.createElectronMass = /* #__PURE__ */unitFactory('electronMass', '9.1093837015e-31', 'kg'); +const createFermiCoupling = exports.createFermiCoupling = /* #__PURE__ */unitFactory('fermiCoupling', '1.1663787e-5', 'GeV^-2'); +const createFineStructure = exports.createFineStructure = numberFactory('fineStructure', 7.2973525693e-3); +const createHartreeEnergy = exports.createHartreeEnergy = /* #__PURE__ */unitFactory('hartreeEnergy', '4.3597447222071e-18', 'J'); +const createProtonMass = exports.createProtonMass = /* #__PURE__ */unitFactory('protonMass', '1.67262192369e-27', 'kg'); +const createDeuteronMass = exports.createDeuteronMass = /* #__PURE__ */unitFactory('deuteronMass', '3.3435830926e-27', 'kg'); +const createNeutronMass = exports.createNeutronMass = /* #__PURE__ */unitFactory('neutronMass', '1.6749271613e-27', 'kg'); +const createQuantumOfCirculation = exports.createQuantumOfCirculation = /* #__PURE__ */unitFactory('quantumOfCirculation', '3.6369475516e-4', 'm^2 s^-1'); +const createRydberg = exports.createRydberg = /* #__PURE__ */unitFactory('rydberg', '10973731.568160', 'm^-1'); +const createThomsonCrossSection = exports.createThomsonCrossSection = /* #__PURE__ */unitFactory('thomsonCrossSection', '6.6524587321e-29', 'm^2'); +const createWeakMixingAngle = exports.createWeakMixingAngle = numberFactory('weakMixingAngle', 0.22290); +const createEfimovFactor = exports.createEfimovFactor = numberFactory('efimovFactor', 22.7); + +// Physico-chemical constants +const createAtomicMass = exports.createAtomicMass = /* #__PURE__ */unitFactory('atomicMass', '1.66053906660e-27', 'kg'); +const createAvogadro = exports.createAvogadro = /* #__PURE__ */unitFactory('avogadro', '6.02214076e23', 'mol^-1'); +const createBoltzmann = exports.createBoltzmann = /* #__PURE__ */unitFactory('boltzmann', '1.380649e-23', 'J K^-1'); +const createFaraday = exports.createFaraday = /* #__PURE__ */unitFactory('faraday', '96485.33212331001', 'C mol^-1'); +const createFirstRadiation = exports.createFirstRadiation = /* #__PURE__ */unitFactory('firstRadiation', '3.7417718521927573e-16', 'W m^2'); +// TODO spectralRadiance = 1.1910429723971881e-16 W m^2 sr^-1 +const createLoschmidt = exports.createLoschmidt = /* #__PURE__ */unitFactory('loschmidt', '2.686780111798444e25', 'm^-3'); +const createGasConstant = exports.createGasConstant = /* #__PURE__ */unitFactory('gasConstant', '8.31446261815324', 'J K^-1 mol^-1'); +const createMolarPlanckConstant = exports.createMolarPlanckConstant = /* #__PURE__ */unitFactory('molarPlanckConstant', '3.990312712893431e-10', 'J s mol^-1'); +const createMolarVolume = exports.createMolarVolume = /* #__PURE__ */unitFactory('molarVolume', '0.022413969545014137', 'm^3 mol^-1'); +const createSackurTetrode = exports.createSackurTetrode = numberFactory('sackurTetrode', -1.16487052358); +const createSecondRadiation = exports.createSecondRadiation = /* #__PURE__ */unitFactory('secondRadiation', '0.014387768775039337', 'm K'); +const createStefanBoltzmann = exports.createStefanBoltzmann = /* #__PURE__ */unitFactory('stefanBoltzmann', '5.67037441918443e-8', 'W m^-2 K^-4'); +const createWienDisplacement = exports.createWienDisplacement = /* #__PURE__ */unitFactory('wienDisplacement', '2.897771955e-3', 'm K'); + +// Adopted values +const createMolarMass = exports.createMolarMass = /* #__PURE__ */unitFactory('molarMass', '0.99999999965e-3', 'kg mol^-1'); +const createMolarMassC12 = exports.createMolarMassC12 = /* #__PURE__ */unitFactory('molarMassC12', '11.9999999958e-3', 'kg mol^-1'); +const createGravity = exports.createGravity = /* #__PURE__ */unitFactory('gravity', '9.80665', 'm s^-2'); +// atm is defined in Unit.js + +// Natural units +const createPlanckLength = exports.createPlanckLength = /* #__PURE__ */unitFactory('planckLength', '1.616255e-35', 'm'); +const createPlanckMass = exports.createPlanckMass = /* #__PURE__ */unitFactory('planckMass', '2.176435e-8', 'kg'); +const createPlanckTime = exports.createPlanckTime = /* #__PURE__ */unitFactory('planckTime', '5.391245e-44', 's'); +const createPlanckCharge = exports.createPlanckCharge = /* #__PURE__ */unitFactory('planckCharge', '1.87554603778e-18', 'C'); +const createPlanckTemperature = exports.createPlanckTemperature = /* #__PURE__ */unitFactory('planckTemperature', '1.416785e+32', 'K'); + +// helper function to create a factory function which creates a physical constant, +// a Unit with either a number value or a BigNumber value depending on the configuration +function unitFactory(name, valueStr, unitStr) { + const dependencies = ['config', 'Unit', 'BigNumber']; + return (0, _factory.factory)(name, dependencies, _ref => { + let { + config, + Unit, + BigNumber + } = _ref; + // Note that we can parse into number or BigNumber. + // We do not parse into Fractions as that doesn't make sense: we would lose precision of the values + // Therefore we dont use Unit.parse() + const value = config.number === 'BigNumber' ? new BigNumber(valueStr) : parseFloat(valueStr); + const unit = new Unit(value, unitStr); + unit.fixPrefix = true; + return unit; + }); +} + +// helper function to create a factory function which creates a numeric constant, +// either a number or BigNumber depending on the configuration +function numberFactory(name, value) { + const dependencies = ['config', 'BigNumber']; + return (0, _factory.factory)(name, dependencies, _ref2 => { + let { + config, + BigNumber + } = _ref2; + return config.number === 'BigNumber' ? new BigNumber(value) : value; + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/array.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/array.js new file mode 100644 index 0000000..5c57bb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/array.js @@ -0,0 +1,872 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.arraySize = arraySize; +exports.broadcastArrays = broadcastArrays; +exports.broadcastSizes = broadcastSizes; +exports.broadcastTo = broadcastTo; +exports.checkBroadcastingRules = checkBroadcastingRules; +exports.clone = clone; +exports.concat = concat; +exports.filter = filter; +exports.filterRegExp = filterRegExp; +exports.flatten = flatten; +exports.forEach = forEach; +exports.generalize = generalize; +exports.get = get; +exports.getArrayDataType = getArrayDataType; +exports.identify = identify; +exports.initial = initial; +exports.isEmptyIndex = isEmptyIndex; +exports.join = join; +exports.last = last; +exports.map = map; +exports.processSizesWildcard = processSizesWildcard; +exports.recurse = recurse; +exports.reshape = reshape; +exports.resize = resize; +exports.squeeze = squeeze; +exports.stretch = stretch; +exports.unsqueeze = unsqueeze; +exports.validate = validate; +exports.validateIndex = validateIndex; +exports.validateIndexSourceSize = validateIndexSourceSize; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _number = require("./number.js"); +var _is = require("./is.js"); +var _string = require("./string.js"); +var _DimensionError = require("../error/DimensionError.js"); +var _IndexError = require("../error/IndexError.js"); +var _object = require("./object.js"); +/** + * Calculate the size of a multi dimensional array. + * This function checks the size of the first entry, it does not validate + * whether all dimensions match. (use function `validate` for that) + * @param {Array} x + * @Return {Number[]} size + */ +function arraySize(x) { + const s = []; + while (Array.isArray(x)) { + s.push(x.length); + x = x[0]; + } + return s; +} + +/** + * Recursively validate whether each element in a multi dimensional array + * has a size corresponding to the provided size array. + * @param {Array} array Array to be validated + * @param {number[]} size Array with the size of each dimension + * @param {number} dim Current dimension + * @throws DimensionError + * @private + */ +function _validate(array, size, dim) { + let i; + const len = array.length; + if (len !== size[dim]) { + throw new _DimensionError.DimensionError(len, size[dim]); + } + if (dim < size.length - 1) { + // recursively validate each child array + const dimNext = dim + 1; + for (i = 0; i < len; i++) { + const child = array[i]; + if (!Array.isArray(child)) { + throw new _DimensionError.DimensionError(size.length - 1, size.length, '<'); + } + _validate(array[i], size, dimNext); + } + } else { + // last dimension. none of the childs may be an array + for (i = 0; i < len; i++) { + if (Array.isArray(array[i])) { + throw new _DimensionError.DimensionError(size.length + 1, size.length, '>'); + } + } + } +} + +/** + * Validate whether each element in a multi dimensional array has + * a size corresponding to the provided size array. + * @param {Array} array Array to be validated + * @param {number[]} size Array with the size of each dimension + * @throws DimensionError + */ +function validate(array, size) { + const isScalar = size.length === 0; + if (isScalar) { + // scalar + if (Array.isArray(array)) { + throw new _DimensionError.DimensionError(array.length, 0); + } + } else { + // array + _validate(array, size, 0); + } +} + +/** + * Validate whether the source of the index matches the size of the Array + * @param {Array | Matrix} array Array to be validated + * @param {Index} index Index with the source information to validate + * @throws DimensionError + */ +function validateIndexSourceSize(value, index) { + const valueSize = value.isMatrix ? value._size : arraySize(value); + const sourceSize = index._sourceSize; + // checks if the source size is not null and matches the valueSize + sourceSize.forEach((sourceDim, i) => { + if (sourceDim !== null && sourceDim !== valueSize[i]) { + throw new _DimensionError.DimensionError(sourceDim, valueSize[i]); + } + }); +} + +/** + * Test whether index is an integer number with index >= 0 and index < length + * when length is provided + * @param {number} index Zero-based index + * @param {number} [length] Length of the array + */ +function validateIndex(index, length) { + if (index !== undefined) { + if (!(0, _is.isNumber)(index) || !(0, _number.isInteger)(index)) { + throw new TypeError('Index must be an integer (value: ' + index + ')'); + } + if (index < 0 || typeof length === 'number' && index >= length) { + throw new _IndexError.IndexError(index, length); + } + } +} + +/** + * Test if and index has empty values + * @param {number} index Zero-based index + */ +function isEmptyIndex(index) { + for (let i = 0; i < index._dimensions.length; ++i) { + const dimension = index._dimensions[i]; + if (dimension._data && (0, _is.isArray)(dimension._data)) { + if (dimension._size[0] === 0) { + return true; + } + } else if (dimension.isRange) { + if (dimension.start === dimension.end) { + return true; + } + } else if ((0, _is.isString)(dimension)) { + if (dimension.length === 0) { + return true; + } + } + } + return false; +} + +/** + * Resize a multi dimensional array. The resized array is returned. + * @param {Array | number} array Array to be resized + * @param {number[]} size Array with the size of each dimension + * @param {*} [defaultValue=0] Value to be filled in in new entries, + * zero by default. Specify for example `null`, + * to clearly see entries that are not explicitly + * set. + * @return {Array} array The resized array + */ +function resize(array, size, defaultValue) { + // check the type of the arguments + if (!Array.isArray(size)) { + throw new TypeError('Array expected'); + } + if (size.length === 0) { + throw new Error('Resizing to scalar is not supported'); + } + + // check whether size contains positive integers + size.forEach(function (value) { + if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value < 0) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(size) + ')'); + } + }); + + // convert number to an array + if ((0, _is.isNumber)(array) || (0, _is.isBigNumber)(array)) { + array = [array]; + } + + // recursively resize the array + const _defaultValue = defaultValue !== undefined ? defaultValue : 0; + _resize(array, size, 0, _defaultValue); + return array; +} + +/** + * Recursively resize a multi dimensional array + * @param {Array} array Array to be resized + * @param {number[]} size Array with the size of each dimension + * @param {number} dim Current dimension + * @param {*} [defaultValue] Value to be filled in in new entries, + * undefined by default. + * @private + */ +function _resize(array, size, dim, defaultValue) { + let i; + let elem; + const oldLen = array.length; + const newLen = size[dim]; + const minLen = Math.min(oldLen, newLen); + + // apply new length + array.length = newLen; + if (dim < size.length - 1) { + // non-last dimension + const dimNext = dim + 1; + + // resize existing child arrays + for (i = 0; i < minLen; i++) { + // resize child array + elem = array[i]; + if (!Array.isArray(elem)) { + elem = [elem]; // add a dimension + array[i] = elem; + } + _resize(elem, size, dimNext, defaultValue); + } + + // create new child arrays + for (i = minLen; i < newLen; i++) { + // get child array + elem = []; + array[i] = elem; + + // resize new child array + _resize(elem, size, dimNext, defaultValue); + } + } else { + // last dimension + + // remove dimensions of existing values + for (i = 0; i < minLen; i++) { + while (Array.isArray(array[i])) { + array[i] = array[i][0]; + } + } + + // fill new elements with the default value + for (i = minLen; i < newLen; i++) { + array[i] = defaultValue; + } + } +} + +/** + * Re-shape a multi dimensional array to fit the specified dimensions + * @param {Array} array Array to be reshaped + * @param {number[]} sizes List of sizes for each dimension + * @returns {Array} Array whose data has been formatted to fit the + * specified dimensions + * + * @throws {DimensionError} If the product of the new dimension sizes does + * not equal that of the old ones + */ +function reshape(array, sizes) { + const flatArray = flatten(array); + const currentLength = flatArray.length; + if (!Array.isArray(array) || !Array.isArray(sizes)) { + throw new TypeError('Array expected'); + } + if (sizes.length === 0) { + throw new _DimensionError.DimensionError(0, currentLength, '!='); + } + sizes = processSizesWildcard(sizes, currentLength); + const newLength = product(sizes); + if (currentLength !== newLength) { + throw new _DimensionError.DimensionError(newLength, currentLength, '!='); + } + try { + return _reshape(flatArray, sizes); + } catch (e) { + if (e instanceof _DimensionError.DimensionError) { + throw new _DimensionError.DimensionError(newLength, currentLength, '!='); + } + throw e; + } +} + +/** + * Replaces the wildcard -1 in the sizes array. + * @param {number[]} sizes List of sizes for each dimension. At most on wildcard. + * @param {number} currentLength Number of elements in the array. + * @throws {Error} If more than one wildcard or unable to replace it. + * @returns {number[]} The sizes array with wildcard replaced. + */ +function processSizesWildcard(sizes, currentLength) { + const newLength = product(sizes); + const processedSizes = sizes.slice(); + const WILDCARD = -1; + const wildCardIndex = sizes.indexOf(WILDCARD); + const isMoreThanOneWildcard = sizes.indexOf(WILDCARD, wildCardIndex + 1) >= 0; + if (isMoreThanOneWildcard) { + throw new Error('More than one wildcard in sizes'); + } + const hasWildcard = wildCardIndex >= 0; + const canReplaceWildcard = currentLength % newLength === 0; + if (hasWildcard) { + if (canReplaceWildcard) { + processedSizes[wildCardIndex] = -currentLength / newLength; + } else { + throw new Error('Could not replace wildcard, since ' + currentLength + ' is no multiple of ' + -newLength); + } + } + return processedSizes; +} + +/** + * Computes the product of all array elements. + * @param {number[]} array Array of factors + * @returns {number} Product of all elements + */ +function product(array) { + return array.reduce((prev, curr) => prev * curr, 1); +} + +/** + * Iteratively re-shape a multi dimensional array to fit the specified dimensions + * @param {Array} array Array to be reshaped + * @param {number[]} sizes List of sizes for each dimension + * @returns {Array} Array whose data has been formatted to fit the + * specified dimensions + */ + +function _reshape(array, sizes) { + // testing if there are enough elements for the requested shape + let tmpArray = array; + let tmpArray2; + // for each dimensions starting by the last one and ignoring the first one + for (let sizeIndex = sizes.length - 1; sizeIndex > 0; sizeIndex--) { + const size = sizes[sizeIndex]; + tmpArray2 = []; + + // aggregate the elements of the current tmpArray in elements of the requested size + const length = tmpArray.length / size; + for (let i = 0; i < length; i++) { + tmpArray2.push(tmpArray.slice(i * size, (i + 1) * size)); + } + // set it as the new tmpArray for the next loop turn or for return + tmpArray = tmpArray2; + } + return tmpArray; +} + +/** + * Squeeze a multi dimensional array + * @param {Array} array + * @param {Array} [size] + * @returns {Array} returns the array itself + */ +function squeeze(array, size) { + const s = size || arraySize(array); + + // squeeze outer dimensions + while (Array.isArray(array) && array.length === 1) { + array = array[0]; + s.shift(); + } + + // find the first dimension to be squeezed + let dims = s.length; + while (s[dims - 1] === 1) { + dims--; + } + + // squeeze inner dimensions + if (dims < s.length) { + array = _squeeze(array, dims, 0); + s.length = dims; + } + return array; +} + +/** + * Recursively squeeze a multi dimensional array + * @param {Array} array + * @param {number} dims Required number of dimensions + * @param {number} dim Current dimension + * @returns {Array | *} Returns the squeezed array + * @private + */ +function _squeeze(array, dims, dim) { + let i, ii; + if (dim < dims) { + const next = dim + 1; + for (i = 0, ii = array.length; i < ii; i++) { + array[i] = _squeeze(array[i], dims, next); + } + } else { + while (Array.isArray(array)) { + array = array[0]; + } + } + return array; +} + +/** + * Unsqueeze a multi dimensional array: add dimensions when missing + * + * Paramter `size` will be mutated to match the new, unqueezed matrix size. + * + * @param {Array} array + * @param {number} dims Desired number of dimensions of the array + * @param {number} [outer] Number of outer dimensions to be added + * @param {Array} [size] Current size of array. + * @returns {Array} returns the array itself + * @private + */ +function unsqueeze(array, dims, outer, size) { + const s = size || arraySize(array); + + // unsqueeze outer dimensions + if (outer) { + for (let i = 0; i < outer; i++) { + array = [array]; + s.unshift(1); + } + } + + // unsqueeze inner dimensions + array = _unsqueeze(array, dims, 0); + while (s.length < dims) { + s.push(1); + } + return array; +} + +/** + * Recursively unsqueeze a multi dimensional array + * @param {Array} array + * @param {number} dims Required number of dimensions + * @param {number} dim Current dimension + * @returns {Array | *} Returns the squeezed array + * @private + */ +function _unsqueeze(array, dims, dim) { + let i, ii; + if (Array.isArray(array)) { + const next = dim + 1; + for (i = 0, ii = array.length; i < ii; i++) { + array[i] = _unsqueeze(array[i], dims, next); + } + } else { + for (let d = dim; d < dims; d++) { + array = [array]; + } + } + return array; +} +/** + * Flatten a multi dimensional array, put all elements in a one dimensional + * array + * @param {Array} array A multi dimensional array + * @return {Array} The flattened array (1 dimensional) + */ +function flatten(array) { + if (!Array.isArray(array)) { + // if not an array, return as is + return array; + } + const flat = []; + array.forEach(function callback(value) { + if (Array.isArray(value)) { + value.forEach(callback); // traverse through sub-arrays recursively + } else { + flat.push(value); + } + }); + return flat; +} + +/** + * A safe map + * @param {Array} array + * @param {function} callback + */ +function map(array, callback) { + return Array.prototype.map.call(array, callback); +} + +/** + * A safe forEach + * @param {Array} array + * @param {function} callback + */ +function forEach(array, callback) { + Array.prototype.forEach.call(array, callback); +} + +/** + * A safe filter + * @param {Array} array + * @param {function} callback + */ +function filter(array, callback) { + if (arraySize(array).length !== 1) { + throw new Error('Only one dimensional matrices supported'); + } + return Array.prototype.filter.call(array, callback); +} + +/** + * Filter values in a callback given a regular expression + * @param {Array} array + * @param {RegExp} regexp + * @return {Array} Returns the filtered array + * @private + */ +function filterRegExp(array, regexp) { + if (arraySize(array).length !== 1) { + throw new Error('Only one dimensional matrices supported'); + } + return Array.prototype.filter.call(array, entry => regexp.test(entry)); +} + +/** + * A safe join + * @param {Array} array + * @param {string} separator + */ +function join(array, separator) { + return Array.prototype.join.call(array, separator); +} + +/** + * Assign a numeric identifier to every element of a sorted array + * @param {Array} a An array + * @return {Array} An array of objects containing the original value and its identifier + */ +function identify(a) { + if (!Array.isArray(a)) { + throw new TypeError('Array input expected'); + } + if (a.length === 0) { + return a; + } + const b = []; + let count = 0; + b[0] = { + value: a[0], + identifier: 0 + }; + for (let i = 1; i < a.length; i++) { + if (a[i] === a[i - 1]) { + count++; + } else { + count = 0; + } + b.push({ + value: a[i], + identifier: count + }); + } + return b; +} + +/** + * Remove the numeric identifier from the elements + * @param {array} a An array + * @return {array} An array of values without identifiers + */ +function generalize(a) { + if (!Array.isArray(a)) { + throw new TypeError('Array input expected'); + } + if (a.length === 0) { + return a; + } + const b = []; + for (let i = 0; i < a.length; i++) { + b.push(a[i].value); + } + return b; +} + +/** + * Check the datatype of a given object + * This is a low level implementation that should only be used by + * parent Matrix classes such as SparseMatrix or DenseMatrix + * This method does not validate Array Matrix shape + * @param {Array} array + * @param {function} typeOf Callback function to use to determine the type of a value + * @return {string} + */ +function getArrayDataType(array, typeOf) { + let type; // to hold type info + let length = 0; // to hold length value to ensure it has consistent sizes + + for (let i = 0; i < array.length; i++) { + const item = array[i]; + const isArray = Array.isArray(item); + + // Saving the target matrix row size + if (i === 0 && isArray) { + length = item.length; + } + + // If the current item is an array but the length does not equal the targetVectorSize + if (isArray && item.length !== length) { + return undefined; + } + const itemType = isArray ? getArrayDataType(item, typeOf) // recurse into a nested array + : typeOf(item); + if (type === undefined) { + type = itemType; // first item + } else if (type !== itemType) { + return 'mixed'; + } else { + // we're good, everything has the same type so far + } + } + return type; +} + +/** + * Return the last item from an array + * @param {array} + * @returns {*} + */ +function last(array) { + return array[array.length - 1]; +} + +/** + * Get all but the last element of array. + * @param {array} + * @returns {*} + */ +function initial(array) { + return array.slice(0, array.length - 1); +} + +/** + * Recursively concatenate two matrices. + * The contents of the matrices is not cloned. + * @param {Array} a Multi dimensional array + * @param {Array} b Multi dimensional array + * @param {number} concatDim The dimension on which to concatenate (zero-based) + * @param {number} dim The current dim (zero-based) + * @return {Array} c The concatenated matrix + * @private + */ +function concatRecursive(a, b, concatDim, dim) { + if (dim < concatDim) { + // recurse into next dimension + if (a.length !== b.length) { + throw new _DimensionError.DimensionError(a.length, b.length); + } + const c = []; + for (let i = 0; i < a.length; i++) { + c[i] = concatRecursive(a[i], b[i], concatDim, dim + 1); + } + return c; + } else { + // concatenate this dimension + return a.concat(b); + } +} + +/** + * Concatenates many arrays in the specified direction + * @param {...Array} arrays All the arrays to concatenate + * @param {number} concatDim The dimension on which to concatenate (zero-based) + * @returns +*/ +function concat() { + const arrays = Array.prototype.slice.call(arguments, 0, -1); + const concatDim = Array.prototype.slice.call(arguments, -1); + if (arrays.length === 1) { + return arrays[0]; + } + if (arrays.length > 1) { + return arrays.slice(1).reduce(function (A, B) { + return concatRecursive(A, B, concatDim, 0); + }, arrays[0]); + } else { + throw new Error('Wrong number of arguments in function concat'); + } +} + +/** + * Receives two or more sizes and get's the broadcasted size for both. + * @param {...number[]} sizes Sizes to broadcast together + * @returns + */ +function broadcastSizes() { + for (var _len = arguments.length, sizes = new Array(_len), _key = 0; _key < _len; _key++) { + sizes[_key] = arguments[_key]; + } + const dimensions = sizes.map(s => s.length); + const N = Math.max(...dimensions); + const sizeMax = new Array(N).fill(null); + // check for every size + for (let i = 0; i < sizes.length; i++) { + const size = sizes[i]; + const dim = dimensions[i]; + for (let j = 0; j < dim; j++) { + const n = N - dim + j; + if (size[j] > sizeMax[n]) { + sizeMax[n] = size[j]; + } + } + } + for (let i = 0; i < sizes.length; i++) { + checkBroadcastingRules(sizes[i], sizeMax); + } + return sizeMax; +} + +/** + * Checks if it's possible to broadcast a size to another size + * @param {number[]} size The size of the array to check + * @param {number[]} toSize The size of the array to validate if it can be broadcasted to + */ +function checkBroadcastingRules(size, toSize) { + const N = toSize.length; + const dim = size.length; + for (let j = 0; j < dim; j++) { + const n = N - dim + j; + if (size[j] < toSize[n] && size[j] > 1 || size[j] > toSize[n]) { + throw new Error(`shape missmatch: missmatch is found in arg with shape (${size}) not possible to broadcast dimension ${dim} with size ${size[j]} to size ${toSize[n]}`); + } + } +} + +/** + * Broadcasts a single array to a certain size + * @param {array} array Array to be broadcasted + * @param {number[]} toSize Size to broadcast the array + * @returns The broadcasted array + */ +function broadcastTo(array, toSize) { + let Asize = arraySize(array); + if ((0, _object.deepStrictEqual)(Asize, toSize)) { + return array; + } + checkBroadcastingRules(Asize, toSize); + const broadcastedSize = broadcastSizes(Asize, toSize); + const N = broadcastedSize.length; + const paddedSize = [...Array(N - Asize.length).fill(1), ...Asize]; + let A = clone(array); + // reshape A if needed to make it ready for concat + if (Asize.length < N) { + A = reshape(A, paddedSize); + Asize = arraySize(A); + } + + // stretches the array on each dimension to make it the same size as index + for (let dim = 0; dim < N; dim++) { + if (Asize[dim] < broadcastedSize[dim]) { + A = stretch(A, broadcastedSize[dim], dim); + Asize = arraySize(A); + } + } + return A; +} + +/** + * Broadcasts arrays and returns the broadcasted arrays in an array + * @param {...Array | any} arrays + * @returns + */ +function broadcastArrays() { + for (var _len2 = arguments.length, arrays = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + arrays[_key2] = arguments[_key2]; + } + if (arrays.length === 0) { + throw new Error('Insuficient number of argumnets in function broadcastArrays'); + } + if (arrays.length === 1) { + return arrays[0]; + } + const sizes = arrays.map(function (array) { + return arraySize(array); + }); + const broadcastedSize = broadcastSizes(...sizes); + const broadcastedArrays = []; + arrays.forEach(function (array) { + broadcastedArrays.push(broadcastTo(array, broadcastedSize)); + }); + return broadcastedArrays; +} + +/** + * stretches a matrix up to a certain size in a certain dimension + * @param {Array} arrayToStretch + * @param {number[]} sizeToStretch + * @param {number} dimToStretch + * @returns + */ +function stretch(arrayToStretch, sizeToStretch, dimToStretch) { + return concat(...Array(sizeToStretch).fill(arrayToStretch), dimToStretch); +} + +/** +* Retrieves a single element from an array given an index. +* +* @param {Array} array - The array from which to retrieve the value. +* @param {Array} idx - An array of indices specifying the position of the desired element in each dimension. +* @returns {*} - The value at the specified position in the array. +* +* @example +* const arr = [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]; +* const index = [1, 0, 1]; +* console.log(getValue(arr, index)); // 6 +*/ +function get(array, index) { + if (!Array.isArray(array)) { + throw new Error('Array expected'); + } + const size = arraySize(array); + if (index.length !== size.length) { + throw new _DimensionError.DimensionError(index.length, size.length); + } + for (let x = 0; x < index.length; x++) { + validateIndex(index[x], size[x]); + } + return index.reduce((acc, curr) => acc[curr], array); +} + +/** + * Recursive function to map a multi-dimensional array. + * + * @param {*} value - The current value being processed in the array. + * @param {Array} index - The index of the current value being processed in the array. + * @param {Array} array - The array being processed. + * @param {Function} callback - Function that produces the element of the new Array, taking three arguments: the value of the element, the index of the element, and the Array being processed. + * @returns {*} The new array with each element being the result of the callback function. + */ +function recurse(value, index, array, callback) { + if (Array.isArray(value)) { + return value.map(function (child, i) { + // we create a copy of the index array and append the new index value + return recurse(child, index.concat(i), array, callback); + }); + } else { + // invoke the callback function with the right number of arguments + return callback(value, index, array); + } +} + +/** + * Deep clones a multidimensional array + * @param {Array} array + * @returns cloned array + */ +function clone(array) { + return (0, _extends2.default)([], array); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/bitwise.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/bitwise.js new file mode 100644 index 0000000..6cd4440 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/bitwise.js @@ -0,0 +1,411 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.bitAndBigNumber = bitAndBigNumber; +exports.bitNotBigNumber = bitNotBigNumber; +exports.bitOrBigNumber = bitOrBigNumber; +exports.bitXor = bitXor; +exports.bitwise = bitwise; +exports.leftShiftBigNumber = leftShiftBigNumber; +exports.rightArithShiftBigNumber = rightArithShiftBigNumber; +/** + * Bitwise and for Bignumbers + * + * Special Cases: + * N & n = N + * n & 0 = 0 + * n & -1 = n + * n & n = n + * I & I = I + * -I & -I = -I + * I & -I = 0 + * I & n = n + * I & -n = I + * -I & n = 0 + * -I & -n = -I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` & `y`, is fully precise + * @private + */ +function bitAndBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitAnd'); + } + const BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.eq(-1) || x.eq(y)) { + return x; + } + if (y.isZero() || x.eq(-1)) { + return y; + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !y.isFinite()) { + if (x.isNegative() === y.isNegative()) { + return x; + } + return new BigNumber(0); + } + if (!x.isFinite()) { + if (y.isNegative()) { + return x; + } + if (x.isNegative()) { + return new BigNumber(0); + } + return y; + } + if (!y.isFinite()) { + if (x.isNegative()) { + return y; + } + if (y.isNegative()) { + return new BigNumber(0); + } + return x; + } + } + return bitwise(x, y, function (a, b) { + return a & b; + }); +} + +/** + * Bitwise not + * @param {BigNumber} x + * @return {BigNumber} Result of ~`x`, fully precise + * + */ +function bitNotBigNumber(x) { + if (x.isFinite() && !x.isInteger()) { + throw new Error('Integer expected in function bitNot'); + } + const BigNumber = x.constructor; + const prevPrec = BigNumber.precision; + BigNumber.config({ + precision: 1E9 + }); + const result = x.plus(new BigNumber(1)); + result.s = -result.s || null; + BigNumber.config({ + precision: prevPrec + }); + return result; +} + +/** + * Bitwise OR for BigNumbers + * + * Special Cases: + * N | n = N + * n | 0 = n + * n | -1 = -1 + * n | n = n + * I | I = I + * -I | -I = -I + * I | -n = -1 + * I | -I = -1 + * I | n = I + * -I | n = -I + * -I | -n = -n + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` | `y`, fully precise + */ +function bitOrBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitOr'); + } + const BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + const negOne = new BigNumber(-1); + if (x.isZero() || y.eq(negOne) || x.eq(y)) { + return y; + } + if (y.isZero() || x.eq(negOne)) { + return x; + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !x.isNegative() && y.isNegative() || x.isNegative() && !y.isNegative() && !y.isFinite()) { + return negOne; + } + if (x.isNegative() && y.isNegative()) { + return x.isFinite() ? x : y; + } + return x.isFinite() ? y : x; + } + return bitwise(x, y, function (a, b) { + return a | b; + }); +} + +/** + * Applies bitwise function to numbers + * @param {BigNumber} x + * @param {BigNumber} y + * @param {function (a, b)} func + * @return {BigNumber} + */ +function bitwise(x, y, func) { + const BigNumber = x.constructor; + let xBits, yBits; + const xSign = +(x.s < 0); + const ySign = +(y.s < 0); + if (xSign) { + xBits = decCoefficientToBinaryString(bitNotBigNumber(x)); + for (let i = 0; i < xBits.length; ++i) { + xBits[i] ^= 1; + } + } else { + xBits = decCoefficientToBinaryString(x); + } + if (ySign) { + yBits = decCoefficientToBinaryString(bitNotBigNumber(y)); + for (let i = 0; i < yBits.length; ++i) { + yBits[i] ^= 1; + } + } else { + yBits = decCoefficientToBinaryString(y); + } + let minBits, maxBits, minSign; + if (xBits.length <= yBits.length) { + minBits = xBits; + maxBits = yBits; + minSign = xSign; + } else { + minBits = yBits; + maxBits = xBits; + minSign = ySign; + } + let shortLen = minBits.length; + let longLen = maxBits.length; + const expFuncVal = func(xSign, ySign) ^ 1; + let outVal = new BigNumber(expFuncVal ^ 1); + let twoPower = new BigNumber(1); + const two = new BigNumber(2); + const prevPrec = BigNumber.precision; + BigNumber.config({ + precision: 1E9 + }); + while (shortLen > 0) { + if (func(minBits[--shortLen], maxBits[--longLen]) === expFuncVal) { + outVal = outVal.plus(twoPower); + } + twoPower = twoPower.times(two); + } + while (longLen > 0) { + if (func(minSign, maxBits[--longLen]) === expFuncVal) { + outVal = outVal.plus(twoPower); + } + twoPower = twoPower.times(two); + } + BigNumber.config({ + precision: prevPrec + }); + if (expFuncVal === 0) { + outVal.s = -outVal.s; + } + return outVal; +} + +/* Extracted from decimal.js, and edited to specialize. */ +function decCoefficientToBinaryString(x) { + // Convert to string + const a = x.d; // array with digits + let r = a[0] + ''; + for (let i = 1; i < a.length; ++i) { + let s = a[i] + ''; + for (let z = 7 - s.length; z--;) { + s = '0' + s; + } + r += s; + } + let j = r.length; + while (r.charAt(j) === '0') { + j--; + } + let xe = x.e; + let str = r.slice(0, j + 1 || 1); + const strL = str.length; + if (xe > 0) { + if (++xe > strL) { + // Append zeros. + xe -= strL; + while (xe--) { + str += '0'; + } + } else if (xe < strL) { + str = str.slice(0, xe) + '.' + str.slice(xe); + } + } + + // Convert from base 10 (decimal) to base 2 + const arr = [0]; + for (let i = 0; i < str.length;) { + let arrL = arr.length; + while (arrL--) { + arr[arrL] *= 10; + } + arr[0] += parseInt(str.charAt(i++)); // convert to int + for (let j = 0; j < arr.length; ++j) { + if (arr[j] > 1) { + if (arr[j + 1] === null || arr[j + 1] === undefined) { + arr[j + 1] = 0; + } + arr[j + 1] += arr[j] >> 1; + arr[j] &= 1; + } + } + } + return arr.reverse(); +} + +/** + * Bitwise XOR for BigNumbers + * + * Special Cases: + * N ^ n = N + * n ^ 0 = n + * n ^ n = 0 + * n ^ -1 = ~n + * I ^ n = I + * I ^ -n = -I + * I ^ -I = -1 + * -I ^ n = -I + * -I ^ -n = I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` ^ `y`, fully precise + * + */ +function bitXor(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitXor'); + } + const BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + if (x.isZero()) { + return y; + } + if (y.isZero()) { + return x; + } + if (x.eq(y)) { + return new BigNumber(0); + } + const negOne = new BigNumber(-1); + if (x.eq(negOne)) { + return bitNotBigNumber(y); + } + if (y.eq(negOne)) { + return bitNotBigNumber(x); + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !y.isFinite()) { + return negOne; + } + return new BigNumber(x.isNegative() === y.isNegative() ? Infinity : -Infinity); + } + return bitwise(x, y, function (a, b) { + return a ^ b; + }); +} + +/** + * Bitwise left shift + * + * Special Cases: + * n << -n = N + * n << N = N + * N << n = N + * n << 0 = n + * 0 << n = 0 + * I << I = N + * I << n = I + * n << I = I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` << `y` + * + */ +function leftShiftBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function leftShift'); + } + const BigNumber = x.constructor; + if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.isZero()) { + return x; + } + if (!x.isFinite() && !y.isFinite()) { + return new BigNumber(NaN); + } + + // Math.pow(2, y) is fully precise for y < 55, and fast + if (y.lt(55)) { + return x.times(Math.pow(2, y.toNumber()) + ''); + } + return x.times(new BigNumber(2).pow(y)); +} + +/* + * Special Cases: + * n >> -n = N + * n >> N = N + * N >> n = N + * I >> I = N + * n >> 0 = n + * I >> n = I + * -I >> n = -I + * -I >> I = -I + * n >> I = I + * -n >> I = -1 + * 0 >> n = 0 + * + * @param {BigNumber} value + * @param {BigNumber} value + * @return {BigNumber} Result of `x` >> `y` + * + */ +function rightArithShiftBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function rightArithShift'); + } + const BigNumber = x.constructor; + if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.isZero()) { + return x; + } + if (!y.isFinite()) { + if (x.isNegative()) { + return new BigNumber(-1); + } + if (!x.isFinite()) { + return new BigNumber(NaN); + } + return new BigNumber(0); + } + + // Math.pow(2, y) is fully precise for y < 55, and fast + if (y.lt(55)) { + return x.div(Math.pow(2, y.toNumber()) + '').floor(); + } + return x.div(new BigNumber(2).pow(y)).floor(); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/constants.js new file mode 100644 index 0000000..5a3bccd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/constants.js @@ -0,0 +1,62 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createBigNumberTau = exports.createBigNumberPi = exports.createBigNumberPhi = exports.createBigNumberE = void 0; +var _function = require("../function.js"); +/** + * Calculate BigNumber e + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns e + */ +const createBigNumberE = exports.createBigNumberE = (0, _function.memoize)(function (BigNumber) { + return new BigNumber(1).exp(); +}, { + hasher +}); + +/** + * Calculate BigNumber golden ratio, phi = (1+sqrt(5))/2 + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns phi + */ +const createBigNumberPhi = exports.createBigNumberPhi = (0, _function.memoize)(function (BigNumber) { + return new BigNumber(1).plus(new BigNumber(5).sqrt()).div(2); +}, { + hasher +}); + +/** + * Calculate BigNumber pi. + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns pi + */ +const createBigNumberPi = exports.createBigNumberPi = (0, _function.memoize)(function (BigNumber) { + return BigNumber.acos(-1); +}, { + hasher +}); + +/** + * Calculate BigNumber tau, tau = 2 * pi + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns tau + */ +const createBigNumberTau = exports.createBigNumberTau = (0, _function.memoize)(function (BigNumber) { + return createBigNumberPi(BigNumber).times(2); +}, { + hasher +}); + +/** + * Create a hash for a BigNumber constructor function. The created has is + * the configured precision + * @param {Array} args Supposed to contain a single entry with + * a BigNumber constructor + * @return {number} precision + * @private + */ +function hasher(args) { + return args[0].precision; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/formatter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/formatter.js new file mode 100644 index 0000000..c72212a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/formatter.js @@ -0,0 +1,251 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.format = format; +exports.toEngineering = toEngineering; +exports.toExponential = toExponential; +exports.toFixed = toFixed; +var _is = require("../is.js"); +var _number = require("../number.js"); +/** + * Formats a BigNumber in a given base + * @param {BigNumber} n + * @param {number} base + * @param {number} size + * @returns {string} + */ +function formatBigNumberToBase(n, base, size) { + const BigNumberCtor = n.constructor; + const big2 = new BigNumberCtor(2); + let suffix = ''; + if (size) { + if (size < 1) { + throw new Error('size must be in greater than 0'); + } + if (!(0, _number.isInteger)(size)) { + throw new Error('size must be an integer'); + } + if (n.greaterThan(big2.pow(size - 1).sub(1)) || n.lessThan(big2.pow(size - 1).mul(-1))) { + throw new Error(`Value must be in range [-2^${size - 1}, 2^${size - 1}-1]`); + } + if (!n.isInteger()) { + throw new Error('Value must be an integer'); + } + if (n.lessThan(0)) { + n = n.add(big2.pow(size)); + } + suffix = `i${size}`; + } + switch (base) { + case 2: + return `${n.toBinary()}${suffix}`; + case 8: + return `${n.toOctal()}${suffix}`; + case 16: + return `${n.toHexadecimal()}${suffix}`; + default: + throw new Error(`Base ${base} not supported `); + } +} + +/** + * Convert a BigNumber to a formatted string representation. + * + * Syntax: + * + * format(value) + * format(value, options) + * format(value, precision) + * format(value, fn) + * + * Where: + * + * {number} value The value to be formatted + * {Object} options An object with formatting options. Available options: + * {string} notation + * Number notation. Choose from: + * 'fixed' Always use regular number notation. + * For example '123.40' and '14000000' + * 'exponential' Always use exponential notation. + * For example '1.234e+2' and '1.4e+7' + * 'auto' (default) Regular number notation for numbers + * having an absolute value between + * `lower` and `upper` bounds, and uses + * exponential notation elsewhere. + * Lower bound is included, upper bound + * is excluded. + * For example '123.4' and '1.4e7'. + * 'bin', 'oct, or + * 'hex' Format the number using binary, octal, + * or hexadecimal notation. + * For example '0b1101' and '0x10fe'. + * {number} wordSize The word size in bits to use for formatting + * in binary, octal, or hexadecimal notation. + * To be used only with 'bin', 'oct', or 'hex' + * values for 'notation' option. When this option + * is defined the value is formatted as a signed + * twos complement integer of the given word size + * and the size suffix is appended to the output. + * For example + * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'. + * Default value is undefined. + * {number} precision A number between 0 and 16 to round + * the digits of the number. + * In case of notations 'exponential', + * 'engineering', and 'auto', + * `precision` defines the total + * number of significant digits returned. + * In case of notation 'fixed', + * `precision` defines the number of + * significant digits after the decimal + * point. + * `precision` is undefined by default. + * {number} lowerExp Exponent determining the lower boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `-3`. + * {number} upperExp Exponent determining the upper boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `5`. + * {Function} fn A custom formatting function. Can be used to override the + * built-in notations. Function `fn` is called with `value` as + * parameter and must return a string. Is useful for example to + * format all values inside a matrix in a particular way. + * + * Examples: + * + * format(6.4) // '6.4' + * format(1240000) // '1.24e6' + * format(1/3) // '0.3333333333333333' + * format(1/3, 3) // '0.333' + * format(21385, 2) // '21000' + * format(12e8, {notation: 'fixed'}) // returns '1200000000' + * format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000' + * format(52.8, {notation: 'exponential'}) // returns '5.28e+1' + * format(12400, {notation: 'engineering'}) // returns '12.400e+3' + * + * @param {BigNumber} value + * @param {Object | Function | number | BigNumber} [options] + * @return {string} str The formatted value + */ +function format(value, options) { + if (typeof options === 'function') { + // handle format(value, fn) + return options(value); + } + + // handle special cases + if (!value.isFinite()) { + return value.isNaN() ? 'NaN' : value.gt(0) ? 'Infinity' : '-Infinity'; + } + const { + notation, + precision, + wordSize + } = (0, _number.normalizeFormatOptions)(options); + + // handle the various notations + switch (notation) { + case 'fixed': + return toFixed(value, precision); + case 'exponential': + return toExponential(value, precision); + case 'engineering': + return toEngineering(value, precision); + case 'bin': + return formatBigNumberToBase(value, 2, wordSize); + case 'oct': + return formatBigNumberToBase(value, 8, wordSize); + case 'hex': + return formatBigNumberToBase(value, 16, wordSize); + case 'auto': + { + // determine lower and upper bound for exponential notation. + // TODO: implement support for upper and lower to be BigNumbers themselves + const lowerExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.lowerExp, -3); + const upperExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.upperExp, 5); + + // handle special case zero + if (value.isZero()) return '0'; + + // determine whether or not to output exponential notation + let str; + const rounded = value.toSignificantDigits(precision); + const exp = rounded.e; + if (exp >= lowerExp && exp < upperExp) { + // normal number notation + str = rounded.toFixed(); + } else { + // exponential notation + str = toExponential(value, precision); + } + + // remove trailing zeros after the decimal point + return str.replace(/((\.\d*?)(0+))($|e)/, function () { + const digits = arguments[2]; + const e = arguments[4]; + return digits !== '.' ? digits + e : e; + }); + } + default: + throw new Error('Unknown notation "' + notation + '". ' + 'Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.'); + } +} + +/** + * Format a BigNumber in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3' + * @param {BigNumber} value + * @param {number} [precision] Optional number of significant figures to return. + */ +function toEngineering(value, precision) { + // find nearest lower multiple of 3 for exponent + const e = value.e; + const newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3; + + // find difference in exponents, and calculate the value without exponent + const valueWithoutExp = value.mul(Math.pow(10, -newExp)); + let valueStr = valueWithoutExp.toPrecision(precision); + if (valueStr.includes('e')) { + const BigNumber = value.constructor; + valueStr = new BigNumber(valueStr).toFixed(); + } + return valueStr + 'e' + (e >= 0 ? '+' : '') + newExp.toString(); +} + +/** + * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3' + * @param {BigNumber} value + * @param {number} [precision] Number of digits in formatted output. + * If not provided, the maximum available digits + * is used. + * @returns {string} str + */ +function toExponential(value, precision) { + if (precision !== undefined) { + return value.toExponential(precision - 1); // Note the offset of one + } else { + return value.toExponential(); + } +} + +/** + * Format a number with fixed notation. + * @param {BigNumber} value + * @param {number} [precision=undefined] Optional number of decimals after the + * decimal point. Undefined by default. + */ +function toFixed(value, precision) { + return value.toFixed(precision); +} +function _toNumberOrDefault(value, defaultValue) { + if ((0, _is.isNumber)(value)) { + return value; + } else if ((0, _is.isBigNumber)(value)) { + return value.toNumber(); + } else { + return defaultValue; + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/nearlyEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/nearlyEqual.js new file mode 100644 index 0000000..8872358 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/bignumber/nearlyEqual.js @@ -0,0 +1,45 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.nearlyEqual = nearlyEqual; +/** + * Compares two BigNumbers. + * @param {BigNumber} a - First value to compare + * @param {BigNumber} b - Second value to compare + * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0. + * @param {number} [absTol=0] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0. + * @returns {boolean} whether the two numbers are nearly equal + * @throws {Error} If `relTol` is less than or equal to 0. + * @throws {Error} If `absTol` is less than 0. + * + * @example + * nearlyEqual(1.000000001, 1.0, 1e-9); // true + * nearlyEqual(1.000000002, 1.0, 0); // false + * nearlyEqual(1.0, 1.009, undefined, 0.02); // true + * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true + */ +function nearlyEqual(a, b) { + let relTol = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1e-9; + let absTol = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; + if (relTol <= 0) { + throw new Error('Relative tolerance must be greater than 0'); + } + if (absTol < 0) { + throw new Error('Absolute tolerance must be at least 0'); + } + // NaN + if (a.isNaN() || b.isNaN()) { + return false; + } + if (!a.isFinite() || !b.isFinite()) { + return a.eq(b); + } + // use "==" operator, handles infinities + if (a.eq(b)) { + return true; + } + // abs(a-b) <= max(relTol * max(abs(a), abs(b)), absTol) + return a.minus(b).abs().lte(a.constructor.max(a.constructor.max(a.abs(), b.abs()).mul(relTol), absTol)); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/collection.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/collection.js new file mode 100644 index 0000000..2056a37 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/collection.js @@ -0,0 +1,186 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.containsCollections = containsCollections; +exports.deepForEach = deepForEach; +exports.deepMap = deepMap; +exports.reduce = reduce; +exports.scatter = scatter; +var _is = require("./is.js"); +var _IndexError = require("../error/IndexError.js"); +var _array = require("./array.js"); +var _switch2 = require("./switch.js"); +/** + * Test whether an array contains collections + * @param {Array} array + * @returns {boolean} Returns true when the array contains one or multiple + * collections (Arrays or Matrices). Returns false otherwise. + */ +function containsCollections(array) { + for (let i = 0; i < array.length; i++) { + if ((0, _is.isCollection)(array[i])) { + return true; + } + } + return false; +} + +/** + * Recursively loop over all elements in a given multi dimensional array + * and invoke the callback on each of the elements. + * @param {Array | Matrix} array + * @param {Function} callback The callback method is invoked with one + * parameter: the current element in the array + */ +function deepForEach(array, callback) { + if ((0, _is.isMatrix)(array)) { + array = array.valueOf(); + } + for (let i = 0, ii = array.length; i < ii; i++) { + const value = array[i]; + if (Array.isArray(value)) { + deepForEach(value, callback); + } else { + callback(value); + } + } +} + +/** + * Execute the callback function element wise for each element in array and any + * nested array + * Returns an array with the results + * @param {Array | Matrix} array + * @param {Function} callback The callback is called with two parameters: + * value1 and value2, which contain the current + * element of both arrays. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {Array | Matrix} res + */ +function deepMap(array, callback, skipZeros) { + if (array && typeof array.map === 'function') { + // TODO: replace array.map with a for loop to improve performance + return array.map(function (x) { + return deepMap(x, callback, skipZeros); + }); + } else { + return callback(array); + } +} + +/** + * Reduce a given matrix or array to a new matrix or + * array with one less dimension, applying the given + * callback in the selected dimension. + * @param {Array | Matrix} mat + * @param {number} dim + * @param {Function} callback + * @return {Array | Matrix} res + */ +function reduce(mat, dim, callback) { + const size = Array.isArray(mat) ? (0, _array.arraySize)(mat) : mat.size(); + if (dim < 0 || dim >= size.length) { + // TODO: would be more clear when throwing a DimensionError here + throw new _IndexError.IndexError(dim, size.length); + } + if ((0, _is.isMatrix)(mat)) { + return mat.create(_reduce(mat.valueOf(), dim, callback), mat.datatype()); + } else { + return _reduce(mat, dim, callback); + } +} + +/** + * Recursively reduce a matrix + * @param {Array} mat + * @param {number} dim + * @param {Function} callback + * @returns {Array} ret + * @private + */ +function _reduce(mat, dim, callback) { + let i, ret, val, tran; + if (dim <= 0) { + if (!Array.isArray(mat[0])) { + val = mat[0]; + for (i = 1; i < mat.length; i++) { + val = callback(val, mat[i]); + } + return val; + } else { + tran = (0, _switch2._switch)(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _reduce(tran[i], dim - 1, callback); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _reduce(mat[i], dim - 1, callback); + } + return ret; + } +} + +// TODO: document function scatter +function scatter(a, j, w, x, u, mark, cindex, f, inverse, update, value) { + // a arrays + const avalues = a._values; + const aindex = a._index; + const aptr = a._ptr; + + // vars + let k, k0, k1, i; + + // check we need to process values (pattern matrix) + if (x) { + // values in j + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check value exists in current j + if (w[i] !== mark) { + // i is new entry in j + w[i] = mark; + // add i to pattern of C + cindex.push(i); + // x(i) = A, check we need to call function this time + if (update) { + // copy value to workspace calling callback function + x[i] = inverse ? f(avalues[k], value) : f(value, avalues[k]); + // function was called on current row + u[i] = mark; + } else { + // copy value to workspace + x[i] = avalues[k]; + } + } else { + // i exists in C already + x[i] = inverse ? f(avalues[k], x[i]) : f(x[i], avalues[k]); + // function was called on current row + u[i] = mark; + } + } + } else { + // values in j + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check value exists in current j + if (w[i] !== mark) { + // i is new entry in j + w[i] = mark; + // add i to pattern of C + cindex.push(i); + } else { + // indicate function was called on current row + u[i] = mark; + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/complex.js new file mode 100644 index 0000000..6302cf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/complex.js @@ -0,0 +1,19 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.complexEquals = complexEquals; +var _number = require("./number.js"); +/** + * Test whether two complex values are equal provided a given relTol and absTol. + * Does not use or change the global Complex.EPSILON setting + * @param {Complex} x - The first complex number for comparison. + * @param {Complex} y - The second complex number for comparison. + * @param {number} relTol - The relative tolerance for comparison. + * @param {number} absTol - The absolute tolerance for comparison. + * @returns {boolean} - Returns true if the two complex numbers are equal within the given tolerances, otherwise returns false. + */ +function complexEquals(x, y, relTol, absTol) { + return (0, _number.nearlyEqual)(x.re, y.re, relTol, absTol) && (0, _number.nearlyEqual)(x.im, y.im, relTol, absTol); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/customs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/customs.js new file mode 100644 index 0000000..1d03b5e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/customs.js @@ -0,0 +1,151 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getSafeMethod = getSafeMethod; +exports.getSafeProperty = getSafeProperty; +exports.isPlainObject = isPlainObject; +exports.isSafeMethod = isSafeMethod; +exports.isSafeProperty = isSafeProperty; +exports.setSafeProperty = setSafeProperty; +var _object = require("./object.js"); +/** + * Get a property of a plain object + * Throws an error in case the object is not a plain object or the + * property is not defined on the object itself + * @param {Object} object + * @param {string} prop + * @return {*} Returns the property value when safe + */ +function getSafeProperty(object, prop) { + // only allow getting safe properties of a plain object + if (isSafeProperty(object, prop)) { + return object[prop]; + } + if (typeof object[prop] === 'function' && isSafeMethod(object, prop)) { + throw new Error('Cannot access method "' + prop + '" as a property'); + } + throw new Error('No access to property "' + prop + '"'); +} + +/** + * Set a property on a plain object. + * Throws an error in case the object is not a plain object or the + * property would override an inherited property like .constructor or .toString + * @param {Object} object + * @param {string} prop + * @param {*} value + * @return {*} Returns the value + */ +// TODO: merge this function into access.js? +function setSafeProperty(object, prop, value) { + // only allow setting safe properties of a plain object + if (isSafeProperty(object, prop)) { + object[prop] = value; + return value; + } + throw new Error('No access to property "' + prop + '"'); +} + +/** + * Test whether a property is safe to use on an object or Array. + * For example .toString and .constructor are not safe + * @param {Object | Array} object + * @param {string} prop + * @return {boolean} Returns true when safe + */ +function isSafeProperty(object, prop) { + if (!isPlainObject(object) && !Array.isArray(object)) { + return false; + } + // SAFE: whitelisted + // e.g length + if ((0, _object.hasOwnProperty)(safeNativeProperties, prop)) { + return true; + } + // UNSAFE: inherited from Object prototype + // e.g constructor + if (prop in Object.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Object.prototype is a root object + return false; + } + // UNSAFE: inherited from Function prototype + // e.g call, apply + if (prop in Function.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Function.prototype is a root object + return false; + } + return true; +} + +/** + * Validate whether a method is safe. + * Throws an error when that's not the case. + * @param {Object} object + * @param {string} method + * @return {function} Returns the method when valid + */ +function getSafeMethod(object, method) { + if (!isSafeMethod(object, method)) { + throw new Error('No access to method "' + method + '"'); + } + return object[method]; +} + +/** + * Check whether a method is safe. + * Throws an error when that's not the case (for example for `constructor`). + * @param {Object} object + * @param {string} method + * @return {boolean} Returns true when safe, false otherwise + */ +function isSafeMethod(object, method) { + if (object === null || object === undefined || typeof object[method] !== 'function') { + return false; + } + // UNSAFE: ghosted + // e.g overridden toString + // Note that IE10 doesn't support __proto__ and we can't do this check there. + if ((0, _object.hasOwnProperty)(object, method) && Object.getPrototypeOf && method in Object.getPrototypeOf(object)) { + return false; + } + // SAFE: whitelisted + // e.g toString + if ((0, _object.hasOwnProperty)(safeNativeMethods, method)) { + return true; + } + // UNSAFE: inherited from Object prototype + // e.g constructor + if (method in Object.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Object.prototype is a root object + return false; + } + // UNSAFE: inherited from Function prototype + // e.g call, apply + if (method in Function.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Function.prototype is a root object + return false; + } + return true; +} +function isPlainObject(object) { + return typeof object === 'object' && object && object.constructor === Object; +} +const safeNativeProperties = { + length: true, + name: true +}; +const safeNativeMethods = { + toString: true, + valueOf: true, + toLocaleString: true +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/emitter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/emitter.js new file mode 100644 index 0000000..17d650d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/emitter.js @@ -0,0 +1,24 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.mixin = mixin; +var _tinyEmitter = _interopRequireDefault(require("tiny-emitter")); +/** + * Extend given object with emitter functions `on`, `off`, `once`, `emit` + * @param {Object} obj + * @return {Object} obj + */ +function mixin(obj) { + // create event emitter + const emitter = new _tinyEmitter.default(); + + // bind methods to obj (we don't want to expose the emitter.e Array...) + obj.on = emitter.on.bind(emitter); + obj.off = emitter.off.bind(emitter); + obj.once = emitter.once.bind(emitter); + obj.emit = emitter.emit.bind(emitter); + return obj; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/factory.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/factory.js new file mode 100644 index 0000000..620046b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/factory.js @@ -0,0 +1,137 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.assertDependencies = assertDependencies; +exports.create = create; +exports.factory = factory; +exports.isFactory = isFactory; +exports.isOptionalDependency = isOptionalDependency; +exports.sortFactories = sortFactories; +exports.stripOptionalNotation = stripOptionalNotation; +var _object = require("./object.js"); +/** + * Create a factory function, which can be used to inject dependencies. + * + * The created functions are memoized, a consecutive call of the factory + * with the exact same inputs will return the same function instance. + * The memoized cache is exposed on `factory.cache` and can be cleared + * if needed. + * + * Example: + * + * const name = 'log' + * const dependencies = ['config', 'typed', 'divideScalar', 'Complex'] + * + * export const createLog = factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => { + * // ... create the function log here and return it + * } + * + * @param {string} name Name of the function to be created + * @param {string[]} dependencies The names of all required dependencies + * @param {function} create Callback function called with an object with all dependencies + * @param {Object} [meta] Optional object with meta information that will be attached + * to the created factory function as property `meta`. + * @returns {function} + */ +function factory(name, dependencies, create, meta) { + function assertAndCreate(scope) { + // we only pass the requested dependencies to the factory function + // to prevent functions to rely on dependencies that are not explicitly + // requested. + const deps = (0, _object.pickShallow)(scope, dependencies.map(stripOptionalNotation)); + assertDependencies(name, dependencies, scope); + return create(deps); + } + assertAndCreate.isFactory = true; + assertAndCreate.fn = name; + assertAndCreate.dependencies = dependencies.slice().sort(); + if (meta) { + assertAndCreate.meta = meta; + } + return assertAndCreate; +} + +/** + * Sort all factories such that when loading in order, the dependencies are resolved. + * + * @param {Array} factories + * @returns {Array} Returns a new array with the sorted factories. + */ +function sortFactories(factories) { + const factoriesByName = {}; + factories.forEach(factory => { + factoriesByName[factory.fn] = factory; + }); + function containsDependency(factory, dependency) { + // TODO: detect circular references + if (isFactory(factory)) { + if (factory.dependencies.includes(dependency.fn || dependency.name)) { + return true; + } + if (factory.dependencies.some(d => containsDependency(factoriesByName[d], dependency))) { + return true; + } + } + return false; + } + const sorted = []; + function addFactory(factory) { + let index = 0; + while (index < sorted.length && !containsDependency(sorted[index], factory)) { + index++; + } + sorted.splice(index, 0, factory); + } + + // sort regular factory functions + factories.filter(isFactory).forEach(addFactory); + + // sort legacy factory functions AFTER the regular factory functions + factories.filter(factory => !isFactory(factory)).forEach(addFactory); + return sorted; +} + +// TODO: comment or cleanup if unused in the end +function create(factories) { + let scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + sortFactories(factories).forEach(factory => factory(scope)); + return scope; +} + +/** + * Test whether an object is a factory. This is the case when it has + * properties name, dependencies, and a function create. + * @param {*} obj + * @returns {boolean} + */ +function isFactory(obj) { + return typeof obj === 'function' && typeof obj.fn === 'string' && Array.isArray(obj.dependencies); +} + +/** + * Assert that all dependencies of a list with dependencies are available in the provided scope. + * + * Will throw an exception when there are dependencies missing. + * + * @param {string} name Name for the function to be created. Used to generate a useful error message + * @param {string[]} dependencies + * @param {Object} scope + */ +function assertDependencies(name, dependencies, scope) { + const allDefined = dependencies.filter(dependency => !isOptionalDependency(dependency)) // filter optionals + .every(dependency => scope[dependency] !== undefined); + if (!allDefined) { + const missingDependencies = dependencies.filter(dependency => scope[dependency] === undefined); + + // TODO: create a custom error class for this, a MathjsError or something like that + throw new Error(`Cannot create function "${name}", ` + `some dependencies are missing: ${missingDependencies.map(d => `"${d}"`).join(', ')}.`); + } +} +function isOptionalDependency(dependency) { + return dependency && dependency[0] === '?'; +} +function stripOptionalNotation(dependency) { + return dependency && dependency[0] === '?' ? dependency.slice(1) : dependency; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/function.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/function.js new file mode 100644 index 0000000..36e5053 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/function.js @@ -0,0 +1,92 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.memoize = memoize; +exports.memoizeCompare = memoizeCompare; +var _lruQueue = require("./lruQueue.js"); +// function utils + +/** + * Memoize a given function by caching the computed result. + * The cache of a memoized function can be cleared by deleting the `cache` + * property of the function. + * + * @param {function} fn The function to be memoized. + * Must be a pure function. + * @param {Object} [options] + * @param {function(args: Array): string} [options.hasher] + * A custom hash builder. Is JSON.stringify by default. + * @param {number | undefined} [options.limit] + * Maximum number of values that may be cached. Undefined indicates + * unlimited (default) + * @return {function} Returns the memoized function + */ +function memoize(fn) { + let { + hasher, + limit + } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + limit = limit == null ? Number.POSITIVE_INFINITY : limit; + hasher = hasher == null ? JSON.stringify : hasher; + return function memoize() { + if (typeof memoize.cache !== 'object') { + memoize.cache = { + values: new Map(), + lru: (0, _lruQueue.lruQueue)(limit || Number.POSITIVE_INFINITY) + }; + } + const args = []; + for (let i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; + } + const hash = hasher(args); + if (memoize.cache.values.has(hash)) { + memoize.cache.lru.hit(hash); + return memoize.cache.values.get(hash); + } + const newVal = fn.apply(fn, args); + memoize.cache.values.set(hash, newVal); + memoize.cache.values.delete(memoize.cache.lru.hit(hash)); + return newVal; + }; +} + +/** + * Memoize a given function by caching all results and the arguments, + * and comparing against the arguments of previous results before + * executing again. + * This is less performant than `memoize` which calculates a hash, + * which is very fast to compare. Use `memoizeCompare` only when it is + * not possible to create a unique serializable hash from the function + * arguments. + * The isEqual function must compare two sets of arguments + * and return true when equal (can be a deep equality check for example). + * @param {function} fn + * @param {function(a: *, b: *) : boolean} isEqual + * @returns {function} + */ +function memoizeCompare(fn, isEqual) { + const memoize = function memoize() { + const args = []; + for (let i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; + } + for (let c = 0; c < memoize.cache.length; c++) { + const cached = memoize.cache[c]; + if (isEqual(args, cached.args)) { + // TODO: move this cache entry to the top so recently used entries move up? + return cached.res; + } + } + const res = fn.apply(fn, args); + memoize.cache.unshift({ + args, + res + }); + return res; + }; + memoize.cache = []; + return memoize; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/is.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/is.js new file mode 100644 index 0000000..e23b2b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/is.js @@ -0,0 +1,245 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.isAccessorNode = isAccessorNode; +exports.isArray = void 0; +exports.isArrayNode = isArrayNode; +exports.isAssignmentNode = isAssignmentNode; +exports.isBigInt = isBigInt; +exports.isBigNumber = isBigNumber; +exports.isBlockNode = isBlockNode; +exports.isBoolean = isBoolean; +exports.isChain = isChain; +exports.isCollection = isCollection; +exports.isComplex = isComplex; +exports.isConditionalNode = isConditionalNode; +exports.isConstantNode = isConstantNode; +exports.isDate = isDate; +exports.isDenseMatrix = isDenseMatrix; +exports.isFraction = isFraction; +exports.isFunction = isFunction; +exports.isFunctionAssignmentNode = isFunctionAssignmentNode; +exports.isFunctionNode = isFunctionNode; +exports.isHelp = isHelp; +exports.isIndex = isIndex; +exports.isIndexNode = isIndexNode; +exports.isMap = isMap; +exports.isMatrix = isMatrix; +exports.isNode = isNode; +exports.isNull = isNull; +exports.isNumber = isNumber; +exports.isObject = isObject; +exports.isObjectNode = isObjectNode; +exports.isObjectWrappingMap = isObjectWrappingMap; +exports.isOperatorNode = isOperatorNode; +exports.isParenthesisNode = isParenthesisNode; +exports.isPartitionedMap = isPartitionedMap; +exports.isRange = isRange; +exports.isRangeNode = isRangeNode; +exports.isRegExp = isRegExp; +exports.isRelationalNode = isRelationalNode; +exports.isResultSet = isResultSet; +exports.isSparseMatrix = isSparseMatrix; +exports.isString = isString; +exports.isSymbolNode = isSymbolNode; +exports.isUndefined = isUndefined; +exports.isUnit = isUnit; +exports.rule2Node = rule2Node; +exports.typeOf = typeOf; +var _map = require("./map.js"); +// type checks for all known types +// +// note that: +// +// - check by duck-typing on a property like `isUnit`, instead of checking instanceof. +// instanceof cannot be used because that would not allow to pass data from +// one instance of math.js to another since each has it's own instance of Unit. +// - check the `isUnit` property via the constructor, so there will be no +// matches for "fake" instances like plain objects with a property `isUnit`. +// That is important for security reasons. +// - It must not be possible to override the type checks used internally, +// for security reasons, so these functions are not exposed in the expression +// parser. + +function isNumber(x) { + return typeof x === 'number'; +} +function isBigNumber(x) { + if (!x || typeof x !== 'object' || typeof x.constructor !== 'function') { + return false; + } + if (x.isBigNumber === true && typeof x.constructor.prototype === 'object' && x.constructor.prototype.isBigNumber === true) { + return true; + } + if (typeof x.constructor.isDecimal === 'function' && x.constructor.isDecimal(x) === true) { + return true; + } + return false; +} +function isBigInt(x) { + return typeof x === 'bigint'; +} +function isComplex(x) { + return x && typeof x === 'object' && Object.getPrototypeOf(x).isComplex === true || false; +} +function isFraction(x) { + return x && typeof x === 'object' && Object.getPrototypeOf(x).isFraction === true || false; +} +function isUnit(x) { + return x && x.constructor.prototype.isUnit === true || false; +} +function isString(x) { + return typeof x === 'string'; +} +const isArray = exports.isArray = Array.isArray; +function isMatrix(x) { + return x && x.constructor.prototype.isMatrix === true || false; +} + +/** + * Test whether a value is a collection: an Array or Matrix + * @param {*} x + * @returns {boolean} isCollection + */ +function isCollection(x) { + return Array.isArray(x) || isMatrix(x); +} +function isDenseMatrix(x) { + return x && x.isDenseMatrix && x.constructor.prototype.isMatrix === true || false; +} +function isSparseMatrix(x) { + return x && x.isSparseMatrix && x.constructor.prototype.isMatrix === true || false; +} +function isRange(x) { + return x && x.constructor.prototype.isRange === true || false; +} +function isIndex(x) { + return x && x.constructor.prototype.isIndex === true || false; +} +function isBoolean(x) { + return typeof x === 'boolean'; +} +function isResultSet(x) { + return x && x.constructor.prototype.isResultSet === true || false; +} +function isHelp(x) { + return x && x.constructor.prototype.isHelp === true || false; +} +function isFunction(x) { + return typeof x === 'function'; +} +function isDate(x) { + return x instanceof Date; +} +function isRegExp(x) { + return x instanceof RegExp; +} +function isObject(x) { + return !!(x && typeof x === 'object' && x.constructor === Object && !isComplex(x) && !isFraction(x)); +} + +/** + * Returns `true` if the passed object appears to be a Map (i.e. duck typing). + * + * Methods looked for are `get`, `set`, `keys` and `has`. + * + * @param {Map | object} object + * @returns + */ +function isMap(object) { + // We can use the fast instanceof, or a slower duck typing check. + // The duck typing method needs to cover enough methods to not be confused with DenseMatrix. + if (!object) { + return false; + } + return object instanceof Map || object instanceof _map.ObjectWrappingMap || typeof object.set === 'function' && typeof object.get === 'function' && typeof object.keys === 'function' && typeof object.has === 'function'; +} +function isPartitionedMap(object) { + return isMap(object) && isMap(object.a) && isMap(object.b); +} +function isObjectWrappingMap(object) { + return isMap(object) && isObject(object.wrappedObject); +} +function isNull(x) { + return x === null; +} +function isUndefined(x) { + return x === undefined; +} +function isAccessorNode(x) { + return x && x.isAccessorNode === true && x.constructor.prototype.isNode === true || false; +} +function isArrayNode(x) { + return x && x.isArrayNode === true && x.constructor.prototype.isNode === true || false; +} +function isAssignmentNode(x) { + return x && x.isAssignmentNode === true && x.constructor.prototype.isNode === true || false; +} +function isBlockNode(x) { + return x && x.isBlockNode === true && x.constructor.prototype.isNode === true || false; +} +function isConditionalNode(x) { + return x && x.isConditionalNode === true && x.constructor.prototype.isNode === true || false; +} +function isConstantNode(x) { + return x && x.isConstantNode === true && x.constructor.prototype.isNode === true || false; +} + +/* Very specialized: returns true for those nodes which in the numerator of + a fraction means that the division in that fraction has precedence over implicit + multiplication, e.g. -2/3 x parses as (-2/3) x and 3/4 x parses as (3/4) x but + 6!/8 x parses as 6! / (8x). It is located here because it is shared between + parse.js and OperatorNode.js (for parsing and printing, respectively). + + This should *not* be exported from mathjs, unlike most of the tests here. + Its name does not start with 'is' to prevent utils/snapshot.js from thinking + it should be exported. +*/ +function rule2Node(node) { + return isConstantNode(node) || isOperatorNode(node) && node.args.length === 1 && isConstantNode(node.args[0]) && '-+~'.includes(node.op); +} +function isFunctionAssignmentNode(x) { + return x && x.isFunctionAssignmentNode === true && x.constructor.prototype.isNode === true || false; +} +function isFunctionNode(x) { + return x && x.isFunctionNode === true && x.constructor.prototype.isNode === true || false; +} +function isIndexNode(x) { + return x && x.isIndexNode === true && x.constructor.prototype.isNode === true || false; +} +function isNode(x) { + return x && x.isNode === true && x.constructor.prototype.isNode === true || false; +} +function isObjectNode(x) { + return x && x.isObjectNode === true && x.constructor.prototype.isNode === true || false; +} +function isOperatorNode(x) { + return x && x.isOperatorNode === true && x.constructor.prototype.isNode === true || false; +} +function isParenthesisNode(x) { + return x && x.isParenthesisNode === true && x.constructor.prototype.isNode === true || false; +} +function isRangeNode(x) { + return x && x.isRangeNode === true && x.constructor.prototype.isNode === true || false; +} +function isRelationalNode(x) { + return x && x.isRelationalNode === true && x.constructor.prototype.isNode === true || false; +} +function isSymbolNode(x) { + return x && x.isSymbolNode === true && x.constructor.prototype.isNode === true || false; +} +function isChain(x) { + return x && x.constructor.prototype.isChain === true || false; +} +function typeOf(x) { + const t = typeof x; + if (t === 'object') { + if (x === null) return 'null'; + if (isBigNumber(x)) return 'BigNumber'; // Special: weird mashup with Decimal + if (x.constructor && x.constructor.name) return x.constructor.name; + return 'Object'; // just in case + } + return t; // can be 'string', 'number', 'boolean', 'function', 'bigint', ... +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/latex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/latex.js new file mode 100644 index 0000000..adee391 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/latex.js @@ -0,0 +1,497 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.defaultTemplate = void 0; +exports.escapeLatex = escapeLatex; +exports.latexSymbols = exports.latexOperators = exports.latexFunctions = void 0; +exports.toSymbol = toSymbol; +var _escapeLatex = _interopRequireDefault(require("escape-latex")); +var _object = require("./object.js"); +/* eslint no-template-curly-in-string: "off" */ + +const latexSymbols = exports.latexSymbols = { + // GREEK LETTERS + Alpha: 'A', + alpha: '\\alpha', + Beta: 'B', + beta: '\\beta', + Gamma: '\\Gamma', + gamma: '\\gamma', + Delta: '\\Delta', + delta: '\\delta', + Epsilon: 'E', + epsilon: '\\epsilon', + varepsilon: '\\varepsilon', + Zeta: 'Z', + zeta: '\\zeta', + Eta: 'H', + eta: '\\eta', + Theta: '\\Theta', + theta: '\\theta', + vartheta: '\\vartheta', + Iota: 'I', + iota: '\\iota', + Kappa: 'K', + kappa: '\\kappa', + varkappa: '\\varkappa', + Lambda: '\\Lambda', + lambda: '\\lambda', + Mu: 'M', + mu: '\\mu', + Nu: 'N', + nu: '\\nu', + Xi: '\\Xi', + xi: '\\xi', + Omicron: 'O', + omicron: 'o', + Pi: '\\Pi', + pi: '\\pi', + varpi: '\\varpi', + Rho: 'P', + rho: '\\rho', + varrho: '\\varrho', + Sigma: '\\Sigma', + sigma: '\\sigma', + varsigma: '\\varsigma', + Tau: 'T', + tau: '\\tau', + Upsilon: '\\Upsilon', + upsilon: '\\upsilon', + Phi: '\\Phi', + phi: '\\phi', + varphi: '\\varphi', + Chi: 'X', + chi: '\\chi', + Psi: '\\Psi', + psi: '\\psi', + Omega: '\\Omega', + omega: '\\omega', + // logic + true: '\\mathrm{True}', + false: '\\mathrm{False}', + // other + i: 'i', + // TODO use \i ?? + inf: '\\infty', + Inf: '\\infty', + infinity: '\\infty', + Infinity: '\\infty', + oo: '\\infty', + lim: '\\lim', + undefined: '\\mathbf{?}' +}; +const latexOperators = exports.latexOperators = { + transpose: '^\\top', + ctranspose: '^H', + factorial: '!', + pow: '^', + dotPow: '.^\\wedge', + // TODO find ideal solution + unaryPlus: '+', + unaryMinus: '-', + bitNot: '\\~', + // TODO find ideal solution + not: '\\neg', + multiply: '\\cdot', + divide: '\\frac', + // TODO how to handle that properly? + dotMultiply: '.\\cdot', + // TODO find ideal solution + dotDivide: '.:', + // TODO find ideal solution + mod: '\\mod', + add: '+', + subtract: '-', + to: '\\rightarrow', + leftShift: '<<', + rightArithShift: '>>', + rightLogShift: '>>>', + equal: '=', + unequal: '\\neq', + smaller: '<', + larger: '>', + smallerEq: '\\leq', + largerEq: '\\geq', + bitAnd: '\\&', + bitXor: '\\underline{|}', + bitOr: '|', + and: '\\wedge', + xor: '\\veebar', + or: '\\vee' +}; +const latexFunctions = exports.latexFunctions = { + // arithmetic + abs: { + 1: '\\left|${args[0]}\\right|' + }, + add: { + 2: `\\left(\${args[0]}${latexOperators.add}\${args[1]}\\right)` + }, + cbrt: { + 1: '\\sqrt[3]{${args[0]}}' + }, + ceil: { + 1: '\\left\\lceil${args[0]}\\right\\rceil' + }, + cube: { + 1: '\\left(${args[0]}\\right)^3' + }, + divide: { + 2: '\\frac{${args[0]}}{${args[1]}}' + }, + dotDivide: { + 2: `\\left(\${args[0]}${latexOperators.dotDivide}\${args[1]}\\right)` + }, + dotMultiply: { + 2: `\\left(\${args[0]}${latexOperators.dotMultiply}\${args[1]}\\right)` + }, + dotPow: { + 2: `\\left(\${args[0]}${latexOperators.dotPow}\${args[1]}\\right)` + }, + exp: { + 1: '\\exp\\left(${args[0]}\\right)' + }, + expm1: `\\left(e${latexOperators.pow}{\${args[0]}}-1\\right)`, + fix: { + 1: '\\mathrm{${name}}\\left(${args[0]}\\right)' + }, + floor: { + 1: '\\left\\lfloor${args[0]}\\right\\rfloor' + }, + gcd: '\\gcd\\left(${args}\\right)', + hypot: '\\hypot\\left(${args}\\right)', + log: { + 1: '\\ln\\left(${args[0]}\\right)', + 2: '\\log_{${args[1]}}\\left(${args[0]}\\right)' + }, + log10: { + 1: '\\log_{10}\\left(${args[0]}\\right)' + }, + log1p: { + 1: '\\ln\\left(${args[0]}+1\\right)', + 2: '\\log_{${args[1]}}\\left(${args[0]}+1\\right)' + }, + log2: '\\log_{2}\\left(${args[0]}\\right)', + mod: { + 2: `\\left(\${args[0]}${latexOperators.mod}\${args[1]}\\right)` + }, + multiply: { + 2: `\\left(\${args[0]}${latexOperators.multiply}\${args[1]}\\right)` + }, + norm: { + 1: '\\left\\|${args[0]}\\right\\|', + 2: undefined // use default template + }, + nthRoot: { + 2: '\\sqrt[${args[1]}]{${args[0]}}' + }, + nthRoots: { + 2: '\\{y : $y^{args[1]} = {${args[0]}}\\}' + }, + pow: { + 2: `\\left(\${args[0]}\\right)${latexOperators.pow}{\${args[1]}}` + }, + round: { + 1: '\\left\\lfloor${args[0]}\\right\\rceil', + 2: undefined // use default template + }, + sign: { + 1: '\\mathrm{${name}}\\left(${args[0]}\\right)' + }, + sqrt: { + 1: '\\sqrt{${args[0]}}' + }, + square: { + 1: '\\left(${args[0]}\\right)^2' + }, + subtract: { + 2: `\\left(\${args[0]}${latexOperators.subtract}\${args[1]}\\right)` + }, + unaryMinus: { + 1: `${latexOperators.unaryMinus}\\left(\${args[0]}\\right)` + }, + unaryPlus: { + 1: `${latexOperators.unaryPlus}\\left(\${args[0]}\\right)` + }, + // bitwise + bitAnd: { + 2: `\\left(\${args[0]}${latexOperators.bitAnd}\${args[1]}\\right)` + }, + bitNot: { + 1: latexOperators.bitNot + '\\left(${args[0]}\\right)' + }, + bitOr: { + 2: `\\left(\${args[0]}${latexOperators.bitOr}\${args[1]}\\right)` + }, + bitXor: { + 2: `\\left(\${args[0]}${latexOperators.bitXor}\${args[1]}\\right)` + }, + leftShift: { + 2: `\\left(\${args[0]}${latexOperators.leftShift}\${args[1]}\\right)` + }, + rightArithShift: { + 2: `\\left(\${args[0]}${latexOperators.rightArithShift}\${args[1]}\\right)` + }, + rightLogShift: { + 2: `\\left(\${args[0]}${latexOperators.rightLogShift}\${args[1]}\\right)` + }, + // combinatorics + bellNumbers: { + 1: '\\mathrm{B}_{${args[0]}}' + }, + catalan: { + 1: '\\mathrm{C}_{${args[0]}}' + }, + stirlingS2: { + 2: '\\mathrm{S}\\left(${args}\\right)' + }, + // complex + arg: { + 1: '\\arg\\left(${args[0]}\\right)' + }, + conj: { + 1: '\\left(${args[0]}\\right)^*' + }, + im: { + 1: '\\Im\\left\\lbrace${args[0]}\\right\\rbrace' + }, + re: { + 1: '\\Re\\left\\lbrace${args[0]}\\right\\rbrace' + }, + // logical + and: { + 2: `\\left(\${args[0]}${latexOperators.and}\${args[1]}\\right)` + }, + not: { + 1: latexOperators.not + '\\left(${args[0]}\\right)' + }, + or: { + 2: `\\left(\${args[0]}${latexOperators.or}\${args[1]}\\right)` + }, + xor: { + 2: `\\left(\${args[0]}${latexOperators.xor}\${args[1]}\\right)` + }, + // matrix + cross: { + 2: '\\left(${args[0]}\\right)\\times\\left(${args[1]}\\right)' + }, + ctranspose: { + 1: `\\left(\${args[0]}\\right)${latexOperators.ctranspose}` + }, + det: { + 1: '\\det\\left(${args[0]}\\right)' + }, + dot: { + 2: '\\left(${args[0]}\\cdot${args[1]}\\right)' + }, + expm: { + 1: '\\exp\\left(${args[0]}\\right)' + }, + inv: { + 1: '\\left(${args[0]}\\right)^{-1}' + }, + pinv: { + 1: '\\left(${args[0]}\\right)^{+}' + }, + sqrtm: { + 1: `{\${args[0]}}${latexOperators.pow}{\\frac{1}{2}}` + }, + trace: { + 1: '\\mathrm{tr}\\left(${args[0]}\\right)' + }, + transpose: { + 1: `\\left(\${args[0]}\\right)${latexOperators.transpose}` + }, + // probability + combinations: { + 2: '\\binom{${args[0]}}{${args[1]}}' + }, + combinationsWithRep: { + 2: '\\left(\\!\\!{\\binom{${args[0]}}{${args[1]}}}\\!\\!\\right)' + }, + factorial: { + 1: `\\left(\${args[0]}\\right)${latexOperators.factorial}` + }, + gamma: { + 1: '\\Gamma\\left(${args[0]}\\right)' + }, + lgamma: { + 1: '\\ln\\Gamma\\left(${args[0]}\\right)' + }, + // relational + equal: { + 2: `\\left(\${args[0]}${latexOperators.equal}\${args[1]}\\right)` + }, + larger: { + 2: `\\left(\${args[0]}${latexOperators.larger}\${args[1]}\\right)` + }, + largerEq: { + 2: `\\left(\${args[0]}${latexOperators.largerEq}\${args[1]}\\right)` + }, + smaller: { + 2: `\\left(\${args[0]}${latexOperators.smaller}\${args[1]}\\right)` + }, + smallerEq: { + 2: `\\left(\${args[0]}${latexOperators.smallerEq}\${args[1]}\\right)` + }, + unequal: { + 2: `\\left(\${args[0]}${latexOperators.unequal}\${args[1]}\\right)` + }, + // special + erf: { + 1: 'erf\\left(${args[0]}\\right)' + }, + // statistics + max: '\\max\\left(${args}\\right)', + min: '\\min\\left(${args}\\right)', + variance: '\\mathrm{Var}\\left(${args}\\right)', + // trigonometry + acos: { + 1: '\\cos^{-1}\\left(${args[0]}\\right)' + }, + acosh: { + 1: '\\cosh^{-1}\\left(${args[0]}\\right)' + }, + acot: { + 1: '\\cot^{-1}\\left(${args[0]}\\right)' + }, + acoth: { + 1: '\\coth^{-1}\\left(${args[0]}\\right)' + }, + acsc: { + 1: '\\csc^{-1}\\left(${args[0]}\\right)' + }, + acsch: { + 1: '\\mathrm{csch}^{-1}\\left(${args[0]}\\right)' + }, + asec: { + 1: '\\sec^{-1}\\left(${args[0]}\\right)' + }, + asech: { + 1: '\\mathrm{sech}^{-1}\\left(${args[0]}\\right)' + }, + asin: { + 1: '\\sin^{-1}\\left(${args[0]}\\right)' + }, + asinh: { + 1: '\\sinh^{-1}\\left(${args[0]}\\right)' + }, + atan: { + 1: '\\tan^{-1}\\left(${args[0]}\\right)' + }, + atan2: { + 2: '\\mathrm{atan2}\\left(${args}\\right)' + }, + atanh: { + 1: '\\tanh^{-1}\\left(${args[0]}\\right)' + }, + cos: { + 1: '\\cos\\left(${args[0]}\\right)' + }, + cosh: { + 1: '\\cosh\\left(${args[0]}\\right)' + }, + cot: { + 1: '\\cot\\left(${args[0]}\\right)' + }, + coth: { + 1: '\\coth\\left(${args[0]}\\right)' + }, + csc: { + 1: '\\csc\\left(${args[0]}\\right)' + }, + csch: { + 1: '\\mathrm{csch}\\left(${args[0]}\\right)' + }, + sec: { + 1: '\\sec\\left(${args[0]}\\right)' + }, + sech: { + 1: '\\mathrm{sech}\\left(${args[0]}\\right)' + }, + sin: { + 1: '\\sin\\left(${args[0]}\\right)' + }, + sinh: { + 1: '\\sinh\\left(${args[0]}\\right)' + }, + tan: { + 1: '\\tan\\left(${args[0]}\\right)' + }, + tanh: { + 1: '\\tanh\\left(${args[0]}\\right)' + }, + // unit + to: { + 2: `\\left(\${args[0]}${latexOperators.to}\${args[1]}\\right)` + }, + // utils + numeric: function (node, options) { + // Not sure if this is strictly right but should work correctly for the vast majority of use cases. + return node.args[0].toTex(); + }, + // type + number: { + 0: '0', + 1: '\\left(${args[0]}\\right)', + 2: '\\left(\\left(${args[0]}\\right)${args[1]}\\right)' + }, + string: { + 0: '\\mathtt{""}', + 1: '\\mathrm{string}\\left(${args[0]}\\right)' + }, + bignumber: { + 0: '0', + 1: '\\left(${args[0]}\\right)' + }, + bigint: { + 0: '0', + 1: '\\left(${args[0]}\\right)' + }, + complex: { + 0: '0', + 1: '\\left(${args[0]}\\right)', + 2: `\\left(\\left(\${args[0]}\\right)+${latexSymbols.i}\\cdot\\left(\${args[1]}\\right)\\right)` + }, + matrix: { + 0: '\\begin{bmatrix}\\end{bmatrix}', + 1: '\\left(${args[0]}\\right)', + 2: '\\left(${args[0]}\\right)' + }, + sparse: { + 0: '\\begin{bsparse}\\end{bsparse}', + 1: '\\left(${args[0]}\\right)' + }, + unit: { + 1: '\\left(${args[0]}\\right)', + 2: '\\left(\\left(${args[0]}\\right)${args[1]}\\right)' + } +}; +const defaultTemplate = exports.defaultTemplate = '\\mathrm{${name}}\\left(${args}\\right)'; +const latexUnits = { + deg: '^\\circ' +}; +function escapeLatex(string) { + return (0, _escapeLatex.default)(string, { + preserveFormatting: true + }); +} + +// @param {string} name +// @param {boolean} isUnit +function toSymbol(name, isUnit) { + isUnit = typeof isUnit === 'undefined' ? false : isUnit; + if (isUnit) { + if ((0, _object.hasOwnProperty)(latexUnits, name)) { + return latexUnits[name]; + } + return '\\mathrm{' + escapeLatex(name) + '}'; + } + if ((0, _object.hasOwnProperty)(latexSymbols, name)) { + return latexSymbols[name]; + } + return escapeLatex(name); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/log.js new file mode 100644 index 0000000..53705bc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/log.js @@ -0,0 +1,22 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.warnOnce = void 0; +/** + * Log a console.warn message only once + */ +const warnOnce = exports.warnOnce = (() => { + const messages = {}; + return function warnOnce() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + const message = args.join(', '); + if (!messages[message]) { + messages[message] = true; + console.warn('Warning:', ...args); + } + }; +})(); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/lruQueue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/lruQueue.js new file mode 100644 index 0000000..4f8534e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/lruQueue.js @@ -0,0 +1,57 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lruQueue = lruQueue; +// (c) 2018, Mariusz Nowak +// SPDX-License-Identifier: ISC +// Derived from https://github.com/medikoo/lru-queue +function lruQueue(limit) { + let size = 0; + let base = 1; + let queue = Object.create(null); + let map = Object.create(null); + let index = 0; + const del = function (id) { + const oldIndex = map[id]; + if (!oldIndex) return; + delete queue[oldIndex]; + delete map[id]; + --size; + if (base !== oldIndex) return; + if (!size) { + index = 0; + base = 1; + return; + } + while (!Object.prototype.hasOwnProperty.call(queue, ++base)) {/* empty */} + }; + limit = Math.abs(limit); + return { + hit: function (id) { + const oldIndex = map[id]; + const nuIndex = ++index; + queue[nuIndex] = id; + map[id] = nuIndex; + if (!oldIndex) { + ++size; + if (size <= limit) return undefined; + id = queue[base]; + del(id); + return id; + } + delete queue[oldIndex]; + if (base !== oldIndex) return undefined; + while (!Object.prototype.hasOwnProperty.call(queue, ++base)) {/* empty */} + return undefined; + }, + delete: del, + clear: function () { + size = index = 0; + base = 1; + queue = Object.create(null); + map = Object.create(null); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/map.js new file mode 100644 index 0000000..b66191c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/map.js @@ -0,0 +1,214 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.PartitionedMap = exports.ObjectWrappingMap = void 0; +exports.assign = assign; +exports.createEmptyMap = createEmptyMap; +exports.createMap = createMap; +exports.toObject = toObject; +var _customs = require("./customs.js"); +var _is = require("./is.js"); +/** + * A map facade on a bare object. + * + * The small number of methods needed to implement a scope, + * forwarding on to the SafeProperty functions. Over time, the codebase + * will stop using this method, as all objects will be Maps, rather than + * more security prone objects. + */ +class ObjectWrappingMap { + constructor(object) { + this.wrappedObject = object; + this[Symbol.iterator] = this.entries; + } + keys() { + return Object.keys(this.wrappedObject).filter(key => this.has(key)).values(); + } + get(key) { + return (0, _customs.getSafeProperty)(this.wrappedObject, key); + } + set(key, value) { + (0, _customs.setSafeProperty)(this.wrappedObject, key, value); + return this; + } + has(key) { + return (0, _customs.isSafeProperty)(this.wrappedObject, key) && key in this.wrappedObject; + } + entries() { + return mapIterator(this.keys(), key => [key, this.get(key)]); + } + forEach(callback) { + for (const key of this.keys()) { + callback(this.get(key), key, this); + } + } + delete(key) { + if ((0, _customs.isSafeProperty)(this.wrappedObject, key)) { + delete this.wrappedObject[key]; + } + } + clear() { + for (const key of this.keys()) { + this.delete(key); + } + } + get size() { + return Object.keys(this.wrappedObject).length; + } +} + +/** + * Create a map with two partitions: a and b. + * The set with bKeys determines which keys/values are read/written to map b, + * all other values are read/written to map a + * + * For example: + * + * const a = new Map() + * const b = new Map() + * const p = new PartitionedMap(a, b, new Set(['x', 'y'])) + * + * In this case, values `x` and `y` are read/written to map `b`, + * all other values are read/written to map `a`. + */ +exports.ObjectWrappingMap = ObjectWrappingMap; +class PartitionedMap { + /** + * @param {Map} a + * @param {Map} b + * @param {Set} bKeys + */ + constructor(a, b, bKeys) { + this.a = a; + this.b = b; + this.bKeys = bKeys; + this[Symbol.iterator] = this.entries; + } + get(key) { + return this.bKeys.has(key) ? this.b.get(key) : this.a.get(key); + } + set(key, value) { + if (this.bKeys.has(key)) { + this.b.set(key, value); + } else { + this.a.set(key, value); + } + return this; + } + has(key) { + return this.b.has(key) || this.a.has(key); + } + keys() { + return new Set([...this.a.keys(), ...this.b.keys()])[Symbol.iterator](); + } + entries() { + return mapIterator(this.keys(), key => [key, this.get(key)]); + } + forEach(callback) { + for (const key of this.keys()) { + callback(this.get(key), key, this); + } + } + delete(key) { + return this.bKeys.has(key) ? this.b.delete(key) : this.a.delete(key); + } + clear() { + this.a.clear(); + this.b.clear(); + } + get size() { + return [...this.keys()].length; + } +} + +/** + * Create a new iterator that maps over the provided iterator, applying a mapping function to each item + */ +exports.PartitionedMap = PartitionedMap; +function mapIterator(it, callback) { + return { + next: () => { + const n = it.next(); + return n.done ? n : { + value: callback(n.value), + done: false + }; + } + }; +} + +/** + * Creates an empty map, or whatever your platform's polyfill is. + * + * @returns an empty Map or Map like object. + */ +function createEmptyMap() { + return new Map(); +} + +/** + * Creates a Map from the given object. + * + * @param { Map | { [key: string]: unknown } | undefined } mapOrObject + * @returns + */ +function createMap(mapOrObject) { + if (!mapOrObject) { + return createEmptyMap(); + } + if ((0, _is.isMap)(mapOrObject)) { + return mapOrObject; + } + if ((0, _is.isObject)(mapOrObject)) { + return new ObjectWrappingMap(mapOrObject); + } + throw new Error('createMap can create maps from objects or Maps'); +} + +/** + * Unwraps a map into an object. + * + * @param {Map} map + * @returns { [key: string]: unknown } + */ +function toObject(map) { + if (map instanceof ObjectWrappingMap) { + return map.wrappedObject; + } + const object = {}; + for (const key of map.keys()) { + const value = map.get(key); + (0, _customs.setSafeProperty)(object, key, value); + } + return object; +} + +/** + * Copies the contents of key-value pairs from each `objects` in to `map`. + * + * Object is `objects` can be a `Map` or object. + * + * This is the `Map` analog to `Object.assign`. + */ +function assign(map) { + for (var _len = arguments.length, objects = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + objects[_key - 1] = arguments[_key]; + } + for (const args of objects) { + if (!args) { + continue; + } + if ((0, _is.isMap)(args)) { + for (const key of args.keys()) { + map.set(key, args.get(key)); + } + } else if ((0, _is.isObject)(args)) { + for (const key of Object.keys(args)) { + map.set(key, args[key]); + } + } + } + return map; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/noop.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/noop.js new file mode 100644 index 0000000..48c334e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/noop.js @@ -0,0 +1,25 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.noBignumber = noBignumber; +exports.noFraction = noFraction; +exports.noIndex = noIndex; +exports.noMatrix = noMatrix; +exports.noSubset = noSubset; +function noBignumber() { + throw new Error('No "bignumber" implementation available'); +} +function noFraction() { + throw new Error('No "fraction" implementation available'); +} +function noMatrix() { + throw new Error('No "matrix" implementation available'); +} +function noIndex() { + throw new Error('No "index" implementation available'); +} +function noSubset() { + throw new Error('No "matrix" implementation available'); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/number.js new file mode 100644 index 0000000..de9a2e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/number.js @@ -0,0 +1,761 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.cbrt = exports.atanh = exports.asinh = exports.acosh = exports.DBL_EPSILON = void 0; +exports.copysign = copysign; +exports.cosh = void 0; +exports.digits = digits; +exports.expm1 = void 0; +exports.format = format; +exports.isInteger = isInteger; +exports.isIntegerStr = isIntegerStr; +exports.log2 = exports.log1p = exports.log10 = void 0; +exports.nearlyEqual = nearlyEqual; +exports.normalizeFormatOptions = normalizeFormatOptions; +exports.roundDigits = roundDigits; +exports.safeNumberType = safeNumberType; +exports.sinh = exports.sign = void 0; +exports.splitNumber = splitNumber; +exports.tanh = void 0; +exports.toEngineering = toEngineering; +exports.toExponential = toExponential; +exports.toFixed = toFixed; +exports.toPrecision = toPrecision; +var _is = require("./is.js"); +/** + * @typedef {{sign: '+' | '-' | '', coefficients: number[], exponent: number}} SplitValue + */ + +/** + * Check if a number is integer + * @param {number | boolean} value + * @return {boolean} isInteger + */ +function isInteger(value) { + if (typeof value === 'boolean') { + return true; + } + return isFinite(value) ? value === Math.round(value) : false; +} + +/** + * Check if a string contains an integer + * @param {string} str + * @return {boolean} isInteger + */ +function isIntegerStr(str) { + // regex matching strings like "123" and "-123" + return /^-?\d+$/.test(str); +} + +/** + * Ensure the number type is compatible with the provided value. + * If not, return 'number' instead. + * + * For example: + * + * safeNumberType('2.3', { number: 'bigint', numberFallback: 'number' }) + * + * will return 'number' and not 'bigint' because trying to create a bigint with + * value 2.3 would throw an exception. + * + * @param {string} numberStr + * @param {{ + * number: 'number' | 'BigNumber' | 'bigint' | 'Fraction' + * numberFallback: 'number' | 'BigNumber' + * }} config + * @returns {'number' | 'BigNumber' | 'bigint' | 'Fraction'} + */ +function safeNumberType(numberStr, config) { + if (config.number === 'bigint' && !isIntegerStr(numberStr)) { + return config.numberFallback; + } + return config.number; +} + +/** + * Calculate the sign of a number + * @param {number} x + * @returns {number} + */ +const sign = exports.sign = Math.sign || function (x) { + if (x > 0) { + return 1; + } else if (x < 0) { + return -1; + } else { + return 0; + } +}; + +/** + * Calculate the base-2 logarithm of a number + * @param {number} x + * @returns {number} + */ +const log2 = exports.log2 = Math.log2 || function log2(x) { + return Math.log(x) / Math.LN2; +}; + +/** + * Calculate the base-10 logarithm of a number + * @param {number} x + * @returns {number} + */ +const log10 = exports.log10 = Math.log10 || function log10(x) { + return Math.log(x) / Math.LN10; +}; + +/** + * Calculate the natural logarithm of a number + 1 + * @param {number} x + * @returns {number} + */ +const log1p = exports.log1p = Math.log1p || function (x) { + return Math.log(x + 1); +}; + +/** + * Calculate cubic root for a number + * + * Code from es6-shim.js: + * https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1564-L1577 + * + * @param {number} x + * @returns {number} Returns the cubic root of x + */ +const cbrt = exports.cbrt = Math.cbrt || function cbrt(x) { + if (x === 0) { + return x; + } + const negate = x < 0; + let result; + if (negate) { + x = -x; + } + if (isFinite(x)) { + result = Math.exp(Math.log(x) / 3); + // from https://en.wikipedia.org/wiki/Cube_root#Numerical_methods + result = (x / (result * result) + 2 * result) / 3; + } else { + result = x; + } + return negate ? -result : result; +}; + +/** + * Calculates exponentiation minus 1 + * @param {number} x + * @return {number} res + */ +const expm1 = exports.expm1 = Math.expm1 || function expm1(x) { + return x >= 2e-4 || x <= -2e-4 ? Math.exp(x) - 1 : x + x * x / 2 + x * x * x / 6; +}; + +/** + * Formats a number in a given base + * @param {number} n + * @param {number} base + * @param {number} size + * @returns {string} + */ +function formatNumberToBase(n, base, size) { + const prefixes = { + 2: '0b', + 8: '0o', + 16: '0x' + }; + const prefix = prefixes[base]; + let suffix = ''; + if (size) { + if (size < 1) { + throw new Error('size must be in greater than 0'); + } + if (!isInteger(size)) { + throw new Error('size must be an integer'); + } + if (n > 2 ** (size - 1) - 1 || n < -(2 ** (size - 1))) { + throw new Error(`Value must be in range [-2^${size - 1}, 2^${size - 1}-1]`); + } + if (!isInteger(n)) { + throw new Error('Value must be an integer'); + } + if (n < 0) { + n = n + 2 ** size; + } + suffix = `i${size}`; + } + let sign = ''; + if (n < 0) { + n = -n; + sign = '-'; + } + return `${sign}${prefix}${n.toString(base)}${suffix}`; +} + +/** + * Convert a number to a formatted string representation. + * + * Syntax: + * + * format(value) + * format(value, options) + * format(value, precision) + * format(value, fn) + * + * Where: + * + * {number} value The value to be formatted + * {Object} options An object with formatting options. Available options: + * {string} notation + * Number notation. Choose from: + * 'fixed' Always use regular number notation. + * For example '123.40' and '14000000' + * 'exponential' Always use exponential notation. + * For example '1.234e+2' and '1.4e+7' + * 'engineering' Always use engineering notation. + * For example '123.4e+0' and '14.0e+6' + * 'auto' (default) Regular number notation for numbers + * having an absolute value between + * `lowerExp` and `upperExp` bounds, and + * uses exponential notation elsewhere. + * Lower bound is included, upper bound + * is excluded. + * For example '123.4' and '1.4e7'. + * 'bin', 'oct, or + * 'hex' Format the number using binary, octal, + * or hexadecimal notation. + * For example '0b1101' and '0x10fe'. + * {number} wordSize The word size in bits to use for formatting + * in binary, octal, or hexadecimal notation. + * To be used only with 'bin', 'oct', or 'hex' + * values for 'notation' option. When this option + * is defined the value is formatted as a signed + * twos complement integer of the given word size + * and the size suffix is appended to the output. + * For example + * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'. + * Default value is undefined. + * {number} precision A number between 0 and 16 to round + * the digits of the number. + * In case of notations 'exponential', + * 'engineering', and 'auto', + * `precision` defines the total + * number of significant digits returned. + * In case of notation 'fixed', + * `precision` defines the number of + * significant digits after the decimal + * point. + * `precision` is undefined by default, + * not rounding any digits. + * {number} lowerExp Exponent determining the lower boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `-3`. + * {number} upperExp Exponent determining the upper boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `5`. + * {Function} fn A custom formatting function. Can be used to override the + * built-in notations. Function `fn` is called with `value` as + * parameter and must return a string. Is useful for example to + * format all values inside a matrix in a particular way. + * + * Examples: + * + * format(6.4) // '6.4' + * format(1240000) // '1.24e6' + * format(1/3) // '0.3333333333333333' + * format(1/3, 3) // '0.333' + * format(21385, 2) // '21000' + * format(12.071, {notation: 'fixed'}) // '12' + * format(2.3, {notation: 'fixed', precision: 2}) // '2.30' + * format(52.8, {notation: 'exponential'}) // '5.28e+1' + * format(12345678, {notation: 'engineering'}) // '12.345678e+6' + * + * @param {number} value + * @param {Object | Function | number} [options] + * @return {string} str The formatted value + */ +function format(value, options) { + if (typeof options === 'function') { + // handle format(value, fn) + return options(value); + } + + // handle special cases + if (value === Infinity) { + return 'Infinity'; + } else if (value === -Infinity) { + return '-Infinity'; + } else if (isNaN(value)) { + return 'NaN'; + } + const { + notation, + precision, + wordSize + } = normalizeFormatOptions(options); + + // handle the various notations + switch (notation) { + case 'fixed': + return toFixed(value, precision); + case 'exponential': + return toExponential(value, precision); + case 'engineering': + return toEngineering(value, precision); + case 'bin': + return formatNumberToBase(value, 2, wordSize); + case 'oct': + return formatNumberToBase(value, 8, wordSize); + case 'hex': + return formatNumberToBase(value, 16, wordSize); + case 'auto': + // remove trailing zeros after the decimal point + return toPrecision(value, precision, options).replace(/((\.\d*?)(0+))($|e)/, function () { + const digits = arguments[2]; + const e = arguments[4]; + return digits !== '.' ? digits + e : e; + }); + default: + throw new Error('Unknown notation "' + notation + '". ' + 'Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.'); + } +} + +/** + * Normalize format options into an object: + * { + * notation: string, + * precision: number | undefined, + * wordSize: number | undefined + * } + */ +function normalizeFormatOptions(options) { + // default values for options + let notation = 'auto'; + let precision; + let wordSize; + if (options !== undefined) { + if ((0, _is.isNumber)(options)) { + precision = options; + } else if ((0, _is.isBigNumber)(options)) { + precision = options.toNumber(); + } else if ((0, _is.isObject)(options)) { + if (options.precision !== undefined) { + precision = _toNumberOrThrow(options.precision, () => { + throw new Error('Option "precision" must be a number or BigNumber'); + }); + } + if (options.wordSize !== undefined) { + wordSize = _toNumberOrThrow(options.wordSize, () => { + throw new Error('Option "wordSize" must be a number or BigNumber'); + }); + } + if (options.notation) { + notation = options.notation; + } + } else { + throw new Error('Unsupported type of options, number, BigNumber, or object expected'); + } + } + return { + notation, + precision, + wordSize + }; +} + +/** + * Split a number into sign, coefficients, and exponent + * @param {number | string} value + * @return {SplitValue} + * Returns an object containing sign, coefficients, and exponent + */ +function splitNumber(value) { + // parse the input value + const match = String(value).toLowerCase().match(/^(-?)(\d+\.?\d*)(e([+-]?\d+))?$/); + if (!match) { + throw new SyntaxError('Invalid number ' + value); + } + const sign = match[1]; + const digits = match[2]; + let exponent = parseFloat(match[4] || '0'); + const dot = digits.indexOf('.'); + exponent += dot !== -1 ? dot - 1 : digits.length - 1; + const coefficients = digits.replace('.', '') // remove the dot (must be removed before removing leading zeros) + .replace(/^0*/, function (zeros) { + // remove leading zeros, add their count to the exponent + exponent -= zeros.length; + return ''; + }).replace(/0*$/, '') // remove trailing zeros + .split('').map(function (d) { + return parseInt(d); + }); + if (coefficients.length === 0) { + coefficients.push(0); + exponent++; + } + return { + sign, + coefficients, + exponent + }; +} + +/** + * Format a number in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3' + * @param {number | string} value + * @param {number} [precision] Optional number of significant figures to return. + */ +function toEngineering(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + const split = splitNumber(value); + const rounded = roundDigits(split, precision); + const e = rounded.exponent; + const c = rounded.coefficients; + + // find nearest lower multiple of 3 for exponent + const newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3; + if ((0, _is.isNumber)(precision)) { + // add zeroes to give correct sig figs + while (precision > c.length || e - newExp + 1 > c.length) { + c.push(0); + } + } else { + // concatenate coefficients with necessary zeros + // add zeros if necessary (for example: 1e+8 -> 100e+6) + const missingZeros = Math.abs(e - newExp) - (c.length - 1); + for (let i = 0; i < missingZeros; i++) { + c.push(0); + } + } + + // find difference in exponents + let expDiff = Math.abs(e - newExp); + let decimalIdx = 1; + + // push decimal index over by expDiff times + while (expDiff > 0) { + decimalIdx++; + expDiff--; + } + + // if all coefficient values are zero after the decimal point and precision is unset, don't add a decimal value. + // otherwise concat with the rest of the coefficients + const decimals = c.slice(decimalIdx).join(''); + const decimalVal = (0, _is.isNumber)(precision) && decimals.length || decimals.match(/[1-9]/) ? '.' + decimals : ''; + const str = c.slice(0, decimalIdx).join('') + decimalVal + 'e' + (e >= 0 ? '+' : '') + newExp.toString(); + return rounded.sign + str; +} + +/** + * Format a number with fixed notation. + * @param {number | string} value + * @param {number} [precision=undefined] Optional number of decimals after the + * decimal point. null by default. + */ +function toFixed(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + const splitValue = splitNumber(value); + const rounded = typeof precision === 'number' ? roundDigits(splitValue, splitValue.exponent + 1 + precision) : splitValue; + let c = rounded.coefficients; + let p = rounded.exponent + 1; // exponent may have changed + + // append zeros if needed + const pp = p + (precision || 0); + if (c.length < pp) { + c = c.concat(zeros(pp - c.length)); + } + + // prepend zeros if needed + if (p < 0) { + c = zeros(-p + 1).concat(c); + p = 1; + } + + // insert a dot if needed + if (p < c.length) { + c.splice(p, 0, p === 0 ? '0.' : '.'); + } + return rounded.sign + c.join(''); +} + +/** + * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3' + * @param {number | string} value + * @param {number} [precision] Number of digits in formatted output. + * If not provided, the maximum available digits + * is used. + */ +function toExponential(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + + // round if needed, else create a clone + const split = splitNumber(value); + const rounded = precision ? roundDigits(split, precision) : split; + let c = rounded.coefficients; + const e = rounded.exponent; + + // append zeros if needed + if (c.length < precision) { + c = c.concat(zeros(precision - c.length)); + } + + // format as `C.CCCe+EEE` or `C.CCCe-EEE` + const first = c.shift(); + return rounded.sign + first + (c.length > 0 ? '.' + c.join('') : '') + 'e' + (e >= 0 ? '+' : '') + e; +} + +/** + * Format a number with a certain precision + * @param {number | string} value + * @param {number} [precision=undefined] Optional number of digits. + * @param {{lowerExp: number | undefined, upperExp: number | undefined}} [options] + * By default: + * lowerExp = -3 (incl) + * upper = +5 (excl) + * @return {string} + */ +function toPrecision(value, precision, options) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + + // determine lower and upper bound for exponential notation. + const lowerExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.lowerExp, -3); + const upperExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.upperExp, 5); + const split = splitNumber(value); + const rounded = precision ? roundDigits(split, precision) : split; + if (rounded.exponent < lowerExp || rounded.exponent >= upperExp) { + // exponential notation + return toExponential(value, precision); + } else { + let c = rounded.coefficients; + const e = rounded.exponent; + + // append trailing zeros + if (c.length < precision) { + c = c.concat(zeros(precision - c.length)); + } + + // append trailing zeros + // TODO: simplify the next statement + c = c.concat(zeros(e - c.length + 1 + (c.length < precision ? precision - c.length : 0))); + + // prepend zeros + c = zeros(-e).concat(c); + const dot = e > 0 ? e : 0; + if (dot < c.length - 1) { + c.splice(dot + 1, 0, '.'); + } + return rounded.sign + c.join(''); + } +} + +/** + * Round the number of digits of a number * + * @param {SplitValue} split A value split with .splitNumber(value) + * @param {number} precision A positive integer + * @return {SplitValue} + * Returns an object containing sign, coefficients, and exponent + * with rounded digits + */ +function roundDigits(split, precision) { + // create a clone + const rounded = { + sign: split.sign, + coefficients: split.coefficients, + exponent: split.exponent + }; + const c = rounded.coefficients; + + // prepend zeros if needed + while (precision <= 0) { + c.unshift(0); + rounded.exponent++; + precision++; + } + if (c.length > precision) { + const removed = c.splice(precision, c.length - precision); + if (removed[0] >= 5) { + let i = precision - 1; + c[i]++; + while (c[i] === 10) { + c.pop(); + if (i === 0) { + c.unshift(0); + rounded.exponent++; + i++; + } + i--; + c[i]++; + } + } + } + return rounded; +} + +/** + * Create an array filled with zeros. + * @param {number} length + * @return {Array} + */ +function zeros(length) { + const arr = []; + for (let i = 0; i < length; i++) { + arr.push(0); + } + return arr; +} + +/** + * Count the number of significant digits of a number. + * + * For example: + * 2.34 returns 3 + * 0.0034 returns 2 + * 120.5e+30 returns 4 + * + * @param {number} value + * @return {number} digits Number of significant digits + */ +function digits(value) { + return value.toExponential().replace(/e.*$/, '') // remove exponential notation + .replace(/^0\.?0*|\./, '') // remove decimal point and leading zeros + .length; +} + +/** + * Minimum number added to one that makes the result different than one + */ +const DBL_EPSILON = exports.DBL_EPSILON = Number.EPSILON || 2.2204460492503130808472633361816E-16; + +/** + * Compares two floating point numbers. + * @param {number} a - First value to compare + * @param {number} b - Second value to compare + * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0. + * @param {number} [absTol=1e-12] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0. + * @return {boolean} whether the two numbers are nearly equal + * + * @throws {Error} If `relTol` is less than or equal to 0. + * @throws {Error} If `absTol` is less than 0. + * + * @example + * nearlyEqual(1.000000001, 1.0, 1e-8); // true + * nearlyEqual(1.000000002, 1.0, 0); // false + * nearlyEqual(1.0, 1.009, undefined, 0.01); // true + * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true + */ +function nearlyEqual(a, b) { + let relTol = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1e-8; + let absTol = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; + if (relTol <= 0) { + throw new Error('Relative tolerance must be greater than 0'); + } + if (absTol < 0) { + throw new Error('Absolute tolerance must be at least 0'); + } + + // NaN + if (isNaN(a) || isNaN(b)) { + return false; + } + if (!isFinite(a) || !isFinite(b)) { + return a === b; + } + if (a === b) { + return true; + } + + // abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol) + return Math.abs(a - b) <= Math.max(relTol * Math.max(Math.abs(a), Math.abs(b)), absTol); +} + +/** + * Calculate the hyperbolic arccos of a number + * @param {number} x + * @return {number} + */ +const acosh = exports.acosh = Math.acosh || function (x) { + return Math.log(Math.sqrt(x * x - 1) + x); +}; +const asinh = exports.asinh = Math.asinh || function (x) { + return Math.log(Math.sqrt(x * x + 1) + x); +}; + +/** + * Calculate the hyperbolic arctangent of a number + * @param {number} x + * @return {number} + */ +const atanh = exports.atanh = Math.atanh || function (x) { + return Math.log((1 + x) / (1 - x)) / 2; +}; + +/** + * Calculate the hyperbolic cosine of a number + * @param {number} x + * @returns {number} + */ +const cosh = exports.cosh = Math.cosh || function (x) { + return (Math.exp(x) + Math.exp(-x)) / 2; +}; + +/** + * Calculate the hyperbolic sine of a number + * @param {number} x + * @returns {number} + */ +const sinh = exports.sinh = Math.sinh || function (x) { + return (Math.exp(x) - Math.exp(-x)) / 2; +}; + +/** + * Calculate the hyperbolic tangent of a number + * @param {number} x + * @returns {number} + */ +const tanh = exports.tanh = Math.tanh || function (x) { + const e = Math.exp(2 * x); + return (e - 1) / (e + 1); +}; + +/** + * Returns a value with the magnitude of x and the sign of y. + * @param {number} x + * @param {number} y + * @returns {number} + */ +function copysign(x, y) { + const signx = x > 0 ? true : x < 0 ? false : 1 / x === Infinity; + const signy = y > 0 ? true : y < 0 ? false : 1 / y === Infinity; + return signx ^ signy ? -x : x; +} +function _toNumberOrThrow(value, onError) { + if ((0, _is.isNumber)(value)) { + return value; + } else if ((0, _is.isBigNumber)(value)) { + return value.toNumber(); + } else { + onError(); + } +} +function _toNumberOrDefault(value, defaultValue) { + if ((0, _is.isNumber)(value)) { + return value; + } else if ((0, _is.isBigNumber)(value)) { + return value.toNumber(); + } else { + return defaultValue; + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/object.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/object.js new file mode 100644 index 0000000..becc403 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/object.js @@ -0,0 +1,391 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.canDefineProperty = canDefineProperty; +exports.clone = clone; +exports.deepExtend = deepExtend; +exports.deepFlatten = deepFlatten; +exports.deepStrictEqual = deepStrictEqual; +exports.extend = extend; +exports.get = get; +exports.hasOwnProperty = hasOwnProperty; +exports.isLegacyFactory = isLegacyFactory; +exports.lazy = lazy; +exports.mapObject = mapObject; +exports.pick = pick; +exports.pickShallow = pickShallow; +exports.set = set; +exports.traverse = traverse; +var _is = require("./is.js"); +/** + * Clone an object + * + * clone(x) + * + * Can clone any primitive type, array, and object. + * If x has a function clone, this function will be invoked to clone the object. + * + * @param {*} x + * @return {*} clone + */ +function clone(x) { + const type = typeof x; + + // immutable primitive types + if (type === 'number' || type === 'bigint' || type === 'string' || type === 'boolean' || x === null || x === undefined) { + return x; + } + + // use clone function of the object when available + if (typeof x.clone === 'function') { + return x.clone(); + } + + // array + if (Array.isArray(x)) { + return x.map(function (value) { + return clone(value); + }); + } + if (x instanceof Date) return new Date(x.valueOf()); + if ((0, _is.isBigNumber)(x)) return x; // bignumbers are immutable + + // object + if ((0, _is.isObject)(x)) { + return mapObject(x, clone); + } + throw new TypeError(`Cannot clone: unknown type of value (value: ${x})`); +} + +/** + * Apply map to all properties of an object + * @param {Object} object + * @param {function} callback + * @return {Object} Returns a copy of the object with mapped properties + */ +function mapObject(object, callback) { + const clone = {}; + for (const key in object) { + if (hasOwnProperty(object, key)) { + clone[key] = callback(object[key]); + } + } + return clone; +} + +/** + * Extend object a with the properties of object b + * @param {Object} a + * @param {Object} b + * @return {Object} a + */ +function extend(a, b) { + for (const prop in b) { + if (hasOwnProperty(b, prop)) { + a[prop] = b[prop]; + } + } + return a; +} + +/** + * Deep extend an object a with the properties of object b + * @param {Object} a + * @param {Object} b + * @returns {Object} + */ +function deepExtend(a, b) { + // TODO: add support for Arrays to deepExtend + if (Array.isArray(b)) { + throw new TypeError('Arrays are not supported by deepExtend'); + } + for (const prop in b) { + // We check against prop not being in Object.prototype or Function.prototype + // to prevent polluting for example Object.__proto__. + if (hasOwnProperty(b, prop) && !(prop in Object.prototype) && !(prop in Function.prototype)) { + if (b[prop] && b[prop].constructor === Object) { + if (a[prop] === undefined) { + a[prop] = {}; + } + if (a[prop] && a[prop].constructor === Object) { + deepExtend(a[prop], b[prop]); + } else { + a[prop] = b[prop]; + } + } else if (Array.isArray(b[prop])) { + throw new TypeError('Arrays are not supported by deepExtend'); + } else { + a[prop] = b[prop]; + } + } + } + return a; +} + +/** + * Deep test equality of all fields in two pairs of arrays or objects. + * Compares values and functions strictly (ie. 2 is not the same as '2'). + * @param {Array | Object} a + * @param {Array | Object} b + * @returns {boolean} + */ +function deepStrictEqual(a, b) { + let prop, i, len; + if (Array.isArray(a)) { + if (!Array.isArray(b)) { + return false; + } + if (a.length !== b.length) { + return false; + } + for (i = 0, len = a.length; i < len; i++) { + if (!deepStrictEqual(a[i], b[i])) { + return false; + } + } + return true; + } else if (typeof a === 'function') { + return a === b; + } else if (a instanceof Object) { + if (Array.isArray(b) || !(b instanceof Object)) { + return false; + } + for (prop in a) { + // noinspection JSUnfilteredForInLoop + if (!(prop in b) || !deepStrictEqual(a[prop], b[prop])) { + return false; + } + } + for (prop in b) { + // noinspection JSUnfilteredForInLoop + if (!(prop in a)) { + return false; + } + } + return true; + } else { + return a === b; + } +} + +/** + * Recursively flatten a nested object. + * @param {Object} nestedObject + * @return {Object} Returns the flattened object + */ +function deepFlatten(nestedObject) { + const flattenedObject = {}; + _deepFlatten(nestedObject, flattenedObject); + return flattenedObject; +} + +// helper function used by deepFlatten +function _deepFlatten(nestedObject, flattenedObject) { + for (const prop in nestedObject) { + if (hasOwnProperty(nestedObject, prop)) { + const value = nestedObject[prop]; + if (typeof value === 'object' && value !== null) { + _deepFlatten(value, flattenedObject); + } else { + flattenedObject[prop] = value; + } + } + } +} + +/** + * Test whether the current JavaScript engine supports Object.defineProperty + * @returns {boolean} returns true if supported + */ +function canDefineProperty() { + // test needed for broken IE8 implementation + try { + if (Object.defineProperty) { + Object.defineProperty({}, 'x', { + get: function () { + return null; + } + }); + return true; + } + } catch (e) {} + return false; +} + +/** + * Attach a lazy loading property to a constant. + * The given function `fn` is called once when the property is first requested. + * + * @param {Object} object Object where to add the property + * @param {string} prop Property name + * @param {Function} valueResolver Function returning the property value. Called + * without arguments. + */ +function lazy(object, prop, valueResolver) { + let _uninitialized = true; + let _value; + Object.defineProperty(object, prop, { + get: function () { + if (_uninitialized) { + _value = valueResolver(); + _uninitialized = false; + } + return _value; + }, + set: function (value) { + _value = value; + _uninitialized = false; + }, + configurable: true, + enumerable: true + }); +} + +/** + * Traverse a path into an object. + * When a namespace is missing, it will be created + * @param {Object} object + * @param {string | string[]} path A dot separated string like 'name.space' + * @return {Object} Returns the object at the end of the path + */ +function traverse(object, path) { + if (path && typeof path === 'string') { + return traverse(object, path.split('.')); + } + let obj = object; + if (path) { + for (let i = 0; i < path.length; i++) { + const key = path[i]; + if (!(key in obj)) { + obj[key] = {}; + } + obj = obj[key]; + } + } + return obj; +} + +/** + * A safe hasOwnProperty + * @param {Object} object + * @param {string} property + */ +function hasOwnProperty(object, property) { + return object && Object.hasOwnProperty.call(object, property); +} + +/** + * Test whether an object is a factory. a factory has fields: + * + * - factory: function (type: Object, config: Object, load: function, typed: function [, math: Object]) (required) + * - name: string (optional) + * - path: string A dot separated path (optional) + * - math: boolean If true (false by default), the math namespace is passed + * as fifth argument of the factory function + * + * @param {*} object + * @returns {boolean} + */ +function isLegacyFactory(object) { + return object && typeof object.factory === 'function'; +} + +/** + * Get a nested property from an object + * @param {Object} object + * @param {string | string[]} path + * @returns {Object} + */ +function get(object, path) { + if (typeof path === 'string') { + if (isPath(path)) { + return get(object, path.split('.')); + } else { + return object[path]; + } + } + let child = object; + for (let i = 0; i < path.length; i++) { + const key = path[i]; + child = child ? child[key] : undefined; + } + return child; +} + +/** + * Set a nested property in an object + * Mutates the object itself + * If the path doesn't exist, it will be created + * @param {Object} object + * @param {string | string[]} path + * @param {*} value + * @returns {Object} + */ +function set(object, path, value) { + if (typeof path === 'string') { + if (isPath(path)) { + return set(object, path.split('.'), value); + } else { + object[path] = value; + return object; + } + } + let child = object; + for (let i = 0; i < path.length - 1; i++) { + const key = path[i]; + if (child[key] === undefined) { + child[key] = {}; + } + child = child[key]; + } + if (path.length > 0) { + const lastKey = path[path.length - 1]; + child[lastKey] = value; + } + return object; +} + +/** + * Create an object composed of the picked object properties + * @param {Object} object + * @param {string[]} properties + * @param {function} [transform] Optional value to transform a value when picking it + * @return {Object} + */ +function pick(object, properties, transform) { + const copy = {}; + for (let i = 0; i < properties.length; i++) { + const key = properties[i]; + const value = get(object, key); + if (value !== undefined) { + set(copy, key, transform ? transform(value, key) : value); + } + } + return copy; +} + +/** + * Shallow version of pick, creating an object composed of the picked object properties + * but not for nested properties + * @param {Object} object + * @param {string[]} properties + * @return {Object} + */ +function pickShallow(object, properties) { + const copy = {}; + for (let i = 0; i < properties.length; i++) { + const key = properties[i]; + const value = object[key]; + if (value !== undefined) { + copy[key] = value; + } + } + return copy; +} + +// helper function to test whether a string contains a path like 'user.name' +function isPath(str) { + return str.includes('.'); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/optimizeCallback.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/optimizeCallback.js new file mode 100644 index 0000000..1ec3e89 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/optimizeCallback.js @@ -0,0 +1,94 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.optimizeCallback = optimizeCallback; +var _typedFunction = _interopRequireDefault(require("typed-function")); +var _array = require("./array.js"); +var _is = require("./is.js"); +/** + * Simplifies a callback function by reducing its complexity and potentially improving its performance. + * + * @param {Function} callback The original callback function to simplify. + * @param {Array|Matrix} array The array that will be used with the callback function. + * @param {string} name The name of the function that is using the callback. + * @returns {Function} Returns a simplified version of the callback function. + */ +function optimizeCallback(callback, array, name) { + if (_typedFunction.default.isTypedFunction(callback)) { + const firstIndex = (array.isMatrix ? array.size() : (0, _array.arraySize)(array)).map(() => 0); + const firstValue = array.isMatrix ? array.get(firstIndex) : (0, _array.get)(array, firstIndex); + const hasSingleSignature = Object.keys(callback.signatures).length === 1; + const numberOfArguments = _findNumberOfArguments(callback, firstValue, firstIndex, array); + const fastCallback = hasSingleSignature ? Object.values(callback.signatures)[0] : callback; + if (numberOfArguments >= 1 && numberOfArguments <= 3) { + return function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + return _tryFunctionWithArgs(fastCallback, args.slice(0, numberOfArguments), name, callback.name); + }; + } + return function () { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + return _tryFunctionWithArgs(fastCallback, args, name, callback.name); + }; + } + return callback; +} +function _findNumberOfArguments(callback, value, index, array) { + const testArgs = [value, index, array]; + for (let i = 3; i > 0; i--) { + const args = testArgs.slice(0, i); + if (_typedFunction.default.resolve(callback, args) !== null) { + return i; + } + } +} + +/** + * @param {function} func The selected function taken from one of the signatures of the callback function + * @param {Array} args List with arguments to apply to the selected signature + * @param {string} mappingFnName the name of the function that is using the callback + * @param {string} callbackName the name of the callback function + * @returns {*} Returns the return value of the invoked signature + * @throws {TypeError} Throws an error when no matching signature was found + */ +function _tryFunctionWithArgs(func, args, mappingFnName, callbackName) { + try { + return func(...args); + } catch (err) { + _createCallbackError(err, args, mappingFnName, callbackName); + } +} + +/** + * Creates and throws a detailed TypeError when a callback function fails. + * + * @param {Error} err The original error thrown by the callback function. + * @param {Array} args The arguments that were passed to the callback function. + * @param {string} mappingFnName The name of the function that is using the callback. + * @param {string} callbackName The name of the callback function. + * @throws {TypeError} Throws a detailed TypeError with enriched error message. + */ +function _createCallbackError(err, args, mappingFnName, callbackName) { + var _err$data; + // Enrich the error message so the user understands that it took place inside the callback function + if (err instanceof TypeError && ((_err$data = err.data) === null || _err$data === void 0 ? void 0 : _err$data.category) === 'wrongType') { + const argsDesc = []; + argsDesc.push(`value: ${(0, _is.typeOf)(args[0])}`); + if (args.length >= 2) { + argsDesc.push(`index: ${(0, _is.typeOf)(args[1])}`); + } + if (args.length >= 3) { + argsDesc.push(`array: ${(0, _is.typeOf)(args[2])}`); + } + throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` + `${callbackName}(${argsDesc.join(', ')}) at index ${JSON.stringify(args[1])}`); + } else { + throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` + `to function ${callbackName}: ${err.message}`); + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/print.js new file mode 100644 index 0000000..701f0a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/print.js @@ -0,0 +1,7 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.printTemplate = void 0; +const printTemplate = exports.printTemplate = /\$([\w.]+)/g; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/product.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/product.js new file mode 100644 index 0000000..181ea12 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/product.js @@ -0,0 +1,20 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.product = product; +/** @param {number} i + * @param {number} n + * @returns {number} product of i to n + */ +function product(i, n) { + if (n < i) { + return 1; + } + if (n === i) { + return n; + } + const half = n + i >> 1; // divide (n + i) by 2 and truncate to integer + return product(i, half) * product(half + 1, n); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/scope.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/scope.js new file mode 100644 index 0000000..de3b381 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/scope.js @@ -0,0 +1,23 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSubScope = createSubScope; +var _map = require("./map.js"); +/** + * Create a new scope which can access the parent scope, + * but does not affect it when written. This is suitable for variable definitions + * within a block node, or function definition. + * + * If parent scope has a createSubScope method, it delegates to that. Otherwise, + * creates an empty map, and copies the parent scope to it, adding in + * the remaining `args`. + * + * @param {Map} parentScope + * @param {Object} args + * @returns {PartitionedMap} + */ +function createSubScope(parentScope, args) { + return new _map.PartitionedMap(parentScope, new _map.ObjectWrappingMap(args), new Set(Object.keys(args))); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/snapshot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/snapshot.js new file mode 100644 index 0000000..e2d1914 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/snapshot.js @@ -0,0 +1,248 @@ +"use strict"; + +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.createSnapshotFromFactories = createSnapshotFromFactories; +exports.validateBundle = validateBundle; +exports.validateTypeOf = void 0; +var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); +var _assert = _interopRequireDefault(require("assert")); +var allIsFunctions = _interopRequireWildcard(require("./is.js")); +var _create = require("../core/create.js"); +var _string = require("./string.js"); +function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } +function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } +/** + * This file contains helper methods to create expected snapshot structures + * of both instance and ES6 exports. + * + * The files are located here and not under /test or /tools so it's transpiled + * into ES5 code under /lib and can be used straight by node.js + */ + +const validateTypeOf = exports.validateTypeOf = allIsFunctions.typeOf; +function validateBundle(expectedBundleStructure, bundle) { + const originalWarn = console.warn; + console.warn = function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + if (args.join(' ').includes('is moved to') && args.join(' ').includes('Please use the new location instead')) { + // Ignore warnings like: + // Warning: math.type.isNumber is moved to math.isNumber in v6.0.0. Please use the new location instead. + return; + } + originalWarn.apply(console, args); + }; + try { + const issues = []; + + // see whether all expected functions and objects are there + traverse(expectedBundleStructure, (expectedType, path) => { + const actualValue = get(bundle, path); + const actualType = validateTypeOf(actualValue); + const message = actualType === 'undefined' ? 'Missing entry in bundle. ' + `Path: ${JSON.stringify(path)}, expected type: ${expectedType}, actual type: ${actualType}` : 'Unexpected entry type in bundle. ' + `Path: ${JSON.stringify(path)}, expected type: ${expectedType}, actual type: ${actualType}`; + if (actualType !== expectedType) { + issues.push({ + actualType, + expectedType, + message + }); + console.warn(message); + } + }); + + // see whether there are any functions or objects that shouldn't be there + traverse(bundle, (actualValue, path) => { + const actualType = validateTypeOf(actualValue); + const expectedType = get(expectedBundleStructure, path) || 'undefined'; + + // FIXME: ugly to have these special cases + if (path.join('.').includes('docs.')) { + // ignore the contents of docs + return; + } + if (path.join('.').includes('all.')) { + // ignore the contents of all dependencies + return; + } + const message = expectedType === 'undefined' ? 'Unknown entry in bundle. ' + 'Is there a new function added which is missing in this snapshot test? ' + `Path: ${JSON.stringify(path)}, expected type: ${expectedType}, actual type: ${actualType}` : 'Unexpected entry type in bundle. ' + `Path: ${JSON.stringify(path)}, expected type: ${expectedType}, actual type: ${actualType}`; + if (actualType !== expectedType) { + issues.push({ + actualType, + expectedType, + message + }); + console.warn(message); + } + }); + + // assert on the first issue (if any) + if (issues.length > 0) { + const { + actualType, + expectedType, + message + } = issues[0]; + console.warn(`${issues.length} bundle issues found`); + _assert.default.strictEqual(actualType, expectedType, message); + } + } finally { + console.warn = originalWarn; + } +} + +/** + * Based on an object with factory functions, create the expected + * structures for ES6 export and a mathjs instance. + * @param {Object} factories + * @return {{expectedInstanceStructure: Object, expectedES6Structure: Object}} + */ +function createSnapshotFromFactories(factories) { + const math = (0, _create.create)(factories); + const allFactoryFunctions = {}; + const allFunctionsConstantsClasses = {}; + const allFunctionsConstants = {}; + const allTransformFunctions = {}; + const allDependencyCollections = {}; + const allClasses = {}; + const allNodeClasses = {}; + Object.keys(factories).forEach(factoryName => { + const factory = factories[factoryName]; + const name = factory.fn; + const isTransformFunction = factory.meta && factory.meta.isTransformFunction; + const isClass = !isLowerCase(name[0]) && validateTypeOf(math[name]) === 'function'; + const dependenciesName = factory.fn + (isTransformFunction ? 'Transform' : '') + 'Dependencies'; + allFactoryFunctions[factoryName] = 'function'; + allFunctionsConstantsClasses[name] = validateTypeOf(math[name]); + allDependencyCollections[dependenciesName] = 'Object'; + if (isTransformFunction) { + allTransformFunctions[name] = 'function'; + } + if (isClass) { + if ((0, _string.endsWith)(name, 'Node')) { + allNodeClasses[name] = 'function'; + } else { + allClasses[name] = 'function'; + } + } else { + allFunctionsConstants[name] = validateTypeOf(math[name]); + } + }); + let embeddedDocs = {}; + Object.keys(factories).forEach(factoryName => { + const factory = factories[factoryName]; + const name = factory.fn; + if (isLowerCase(factory.fn[0])) { + // ignore class names starting with upper case + embeddedDocs[name] = 'Object'; + } + }); + embeddedDocs = exclude(embeddedDocs, ['equalScalar', 'apply', 'addScalar', 'subtractScalar', 'multiplyScalar', 'print', 'divideScalar', 'parse', 'compile', 'parser', 'chain', 'reviver', 'replacer']); + const allTypeChecks = {}; + Object.keys(allIsFunctions).forEach(name => { + if (name.indexOf('is') === 0) { + allTypeChecks[name] = 'function'; + } + }); + const allErrorClasses = { + ArgumentsError: 'function', + DimensionError: 'function', + IndexError: 'function' + }; + const expectedInstanceStructure = { + ...allFunctionsConstantsClasses, + on: 'function', + off: 'function', + once: 'function', + emit: 'function', + import: 'function', + config: 'function', + create: 'function', + factory: 'function', + ...allTypeChecks, + ...allErrorClasses, + expression: { + transform: { + ...allTransformFunctions + }, + mathWithTransform: { + // note that we don't have classes here, + // only functions and constants are allowed in the editor + ...exclude(allFunctionsConstants, ['chain']), + config: 'function' + } + } + }; + const expectedES6Structure = { + // functions + ...exclude(allFunctionsConstantsClasses, ['E', 'false', 'Infinity', 'NaN', 'null', 'PI', 'true']), + create: 'function', + config: 'function', + factory: 'function', + _true: 'boolean', + _false: 'boolean', + _null: 'null', + _Infinity: 'number', + _NaN: 'number', + ...allTypeChecks, + ...allErrorClasses, + ...allDependencyCollections, + ...allFactoryFunctions, + docs: embeddedDocs + }; + return { + expectedInstanceStructure, + expectedES6Structure + }; +} +function traverse(obj) { + let callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (value, path) => {}; + let path = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : []; + // FIXME: ugly to have these special cases + if (path.length > 0 && path[0].includes('Dependencies')) { + // special case for objects holding a collection of dependencies + callback(obj, path); + } else if (validateTypeOf(obj) === 'Array') { + obj.map((item, index) => traverse(item, callback, path.concat(index))); + } else if (validateTypeOf(obj) === 'Object') { + Object.keys(obj).forEach(key => { + // FIXME: ugly to have these special cases + // ignore special case of deprecated docs + if (key === 'docs' && path.join('.') === 'expression') { + return; + } + traverse(obj[key], callback, path.concat(key)); + }); + } else { + callback(obj, path); + } +} +function get(object, path) { + let child = object; + for (let i = 0; i < path.length; i++) { + const key = path[i]; + child = child ? child[key] : undefined; + } + return child; +} + +/** + * Create a copy of the provided `object` and delete + * all properties listed in `excludedProperties` + * @param {Object} object + * @param {string[]} excludedProperties + * @return {Object} + */ +function exclude(object, excludedProperties) { + const strippedObject = (0, _extends2.default)({}, object); + excludedProperties.forEach(excludedProperty => { + delete strippedObject[excludedProperty]; + }); + return strippedObject; +} +function isLowerCase(text) { + return typeof text === 'string' && text.toLowerCase() === text; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/string.js new file mode 100644 index 0000000..3317d18 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/string.js @@ -0,0 +1,203 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.compareText = compareText; +exports.endsWith = endsWith; +exports.escape = escape; +exports.format = format; +exports.stringify = stringify; +var _is = require("./is.js"); +var _number = require("./number.js"); +var _formatter = require("./bignumber/formatter.js"); +/** + * Check if a text ends with a certain string. + * @param {string} text + * @param {string} search + */ +function endsWith(text, search) { + const start = text.length - search.length; + const end = text.length; + return text.substring(start, end) === search; +} + +/** + * Format a value of any type into a string. + * + * Usage: + * math.format(value) + * math.format(value, precision) + * math.format(value, options) + * + * When value is a function: + * + * - When the function has a property `syntax`, it returns this + * syntax description. + * - In other cases, a string `'function'` is returned. + * + * When `value` is an Object: + * + * - When the object contains a property `format` being a function, this + * function is invoked as `value.format(options)` and the result is returned. + * - When the object has its own `toString` method, this method is invoked + * and the result is returned. + * - In other cases the function will loop over all object properties and + * return JSON object notation like '{"a": 2, "b": 3}'. + * + * Example usage: + * math.format(2/7) // '0.2857142857142857' + * math.format(math.pi, 3) // '3.14' + * math.format(new Complex(2, 3)) // '2 + 3i' + * math.format('hello') // '"hello"' + * + * @param {*} value Value to be stringified + * @param {Object | number | Function} [options] + * Formatting options. See src/utils/number.js:format for a + * description of the available options controlling number output. + * This generic "format" also supports the option property `truncate: NN` + * giving the maximum number NN of characters to return (if there would + * have been more, they are deleted and replaced by an ellipsis). + * @return {string} str + */ +function format(value, options) { + const result = _format(value, options); + if (options && typeof options === 'object' && 'truncate' in options && result.length > options.truncate) { + return result.substring(0, options.truncate - 3) + '...'; + } + return result; +} +function _format(value, options) { + if (typeof value === 'number') { + return (0, _number.format)(value, options); + } + if ((0, _is.isBigNumber)(value)) { + return (0, _formatter.format)(value, options); + } + + // note: we use unsafe duck-typing here to check for Fractions, this is + // ok here since we're only invoking toString or concatenating its values + if (looksLikeFraction(value)) { + if (!options || options.fraction !== 'decimal') { + // output as ratio, like '1/3' + return value.s * value.n + '/' + value.d; + } else { + // output as decimal, like '0.(3)' + return value.toString(); + } + } + if (Array.isArray(value)) { + return formatArray(value, options); + } + if ((0, _is.isString)(value)) { + return stringify(value); + } + if (typeof value === 'function') { + return value.syntax ? String(value.syntax) : 'function'; + } + if (value && typeof value === 'object') { + if (typeof value.format === 'function') { + return value.format(options); + } else if (value && value.toString(options) !== {}.toString()) { + // this object has a non-native toString method, use that one + return value.toString(options); + } else { + const entries = Object.keys(value).map(key => { + return stringify(key) + ': ' + format(value[key], options); + }); + return '{' + entries.join(', ') + '}'; + } + } + return String(value); +} + +/** + * Stringify a value into a string enclosed in double quotes. + * Unescaped double quotes and backslashes inside the value are escaped. + * @param {*} value + * @return {string} + */ +function stringify(value) { + const text = String(value); + let escaped = ''; + let i = 0; + while (i < text.length) { + const c = text.charAt(i); + escaped += c in controlCharacters ? controlCharacters[c] : c; + i++; + } + return '"' + escaped + '"'; +} +const controlCharacters = { + '"': '\\"', + '\\': '\\\\', + '\b': '\\b', + '\f': '\\f', + '\n': '\\n', + '\r': '\\r', + '\t': '\\t' +}; + +/** + * Escape special HTML characters + * @param {*} value + * @return {string} + */ +function escape(value) { + let text = String(value); + text = text.replace(/&/g, '&').replace(/"/g, '"').replace(/'/g, ''').replace(//g, '>'); + return text; +} + +/** + * Recursively format an n-dimensional matrix + * Example output: "[[1, 2], [3, 4]]" + * @param {Array} array + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ +function formatArray(array, options) { + if (Array.isArray(array)) { + let str = '['; + const len = array.length; + for (let i = 0; i < len; i++) { + if (i !== 0) { + str += ', '; + } + str += formatArray(array[i], options); + } + str += ']'; + return str; + } else { + return format(array, options); + } +} + +/** + * Check whether a value looks like a Fraction (unsafe duck-type check) + * @param {*} value + * @return {boolean} + */ +function looksLikeFraction(value) { + return value && typeof value === 'object' && typeof value.s === 'number' && typeof value.n === 'number' && typeof value.d === 'number' || false; +} + +/** + * Compare two strings + * @param {string} x + * @param {string} y + * @returns {number} + */ +function compareText(x, y) { + // we don't want to convert numbers to string, only accept string input + if (!(0, _is.isString)(x)) { + throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + (0, _is.typeOf)(x) + ', index: 0)'); + } + if (!(0, _is.isString)(y)) { + throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + (0, _is.typeOf)(y) + ', index: 1)'); + } + return x === y ? 0 : x > y ? 1 : -1; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/switch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/switch.js new file mode 100644 index 0000000..ad5f8ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/utils/switch.js @@ -0,0 +1,26 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports._switch = _switch; +/** + * Transpose a matrix + * @param {Array} mat + * @returns {Array} ret + * @private + */ +function _switch(mat) { + const I = mat.length; + const J = mat[0].length; + let i, j; + const ret = []; + for (j = 0; j < J; j++) { + const tmp = []; + for (i = 0; i < I; i++) { + tmp.push(mat[i][j]); + } + ret.push(tmp); + } + return ret; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/version.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/version.js new file mode 100644 index 0000000..c9ce638 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/cjs/version.js @@ -0,0 +1,9 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.version = void 0; +const version = exports.version = '13.2.0'; +// Note: This file is automatically generated when building math.js. +// Changes made in this file will be overwritten. \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/constants.js new file mode 100644 index 0000000..8629181 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/constants.js @@ -0,0 +1,124 @@ +import { factory } from './utils/factory.js'; +import { version } from './version.js'; +import { createBigNumberE, createBigNumberPhi, createBigNumberPi, createBigNumberTau } from './utils/bignumber/constants.js'; +import { pi, tau, e, phi } from './plain/number/index.js'; +export var createTrue = /* #__PURE__ */factory('true', [], () => true); +export var createFalse = /* #__PURE__ */factory('false', [], () => false); +export var createNull = /* #__PURE__ */factory('null', [], () => null); +export var createInfinity = /* #__PURE__ */recreateFactory('Infinity', ['config', '?BigNumber'], _ref => { + var { + config, + BigNumber + } = _ref; + return config.number === 'BigNumber' ? new BigNumber(Infinity) : Infinity; +}); +export var createNaN = /* #__PURE__ */recreateFactory('NaN', ['config', '?BigNumber'], _ref2 => { + var { + config, + BigNumber + } = _ref2; + return config.number === 'BigNumber' ? new BigNumber(NaN) : NaN; +}); +export var createPi = /* #__PURE__ */recreateFactory('pi', ['config', '?BigNumber'], _ref3 => { + var { + config, + BigNumber + } = _ref3; + return config.number === 'BigNumber' ? createBigNumberPi(BigNumber) : pi; +}); +export var createTau = /* #__PURE__ */recreateFactory('tau', ['config', '?BigNumber'], _ref4 => { + var { + config, + BigNumber + } = _ref4; + return config.number === 'BigNumber' ? createBigNumberTau(BigNumber) : tau; +}); +export var createE = /* #__PURE__ */recreateFactory('e', ['config', '?BigNumber'], _ref5 => { + var { + config, + BigNumber + } = _ref5; + return config.number === 'BigNumber' ? createBigNumberE(BigNumber) : e; +}); + +// golden ratio, (1+sqrt(5))/2 +export var createPhi = /* #__PURE__ */recreateFactory('phi', ['config', '?BigNumber'], _ref6 => { + var { + config, + BigNumber + } = _ref6; + return config.number === 'BigNumber' ? createBigNumberPhi(BigNumber) : phi; +}); +export var createLN2 = /* #__PURE__ */recreateFactory('LN2', ['config', '?BigNumber'], _ref7 => { + var { + config, + BigNumber + } = _ref7; + return config.number === 'BigNumber' ? new BigNumber(2).ln() : Math.LN2; +}); +export var createLN10 = /* #__PURE__ */recreateFactory('LN10', ['config', '?BigNumber'], _ref8 => { + var { + config, + BigNumber + } = _ref8; + return config.number === 'BigNumber' ? new BigNumber(10).ln() : Math.LN10; +}); +export var createLOG2E = /* #__PURE__ */recreateFactory('LOG2E', ['config', '?BigNumber'], _ref9 => { + var { + config, + BigNumber + } = _ref9; + return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(2).ln()) : Math.LOG2E; +}); +export var createLOG10E = /* #__PURE__ */recreateFactory('LOG10E', ['config', '?BigNumber'], _ref10 => { + var { + config, + BigNumber + } = _ref10; + return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(10).ln()) : Math.LOG10E; +}); +export var createSQRT1_2 = /* #__PURE__ */recreateFactory( +// eslint-disable-line camelcase +'SQRT1_2', ['config', '?BigNumber'], _ref11 => { + var { + config, + BigNumber + } = _ref11; + return config.number === 'BigNumber' ? new BigNumber('0.5').sqrt() : Math.SQRT1_2; +}); +export var createSQRT2 = /* #__PURE__ */recreateFactory('SQRT2', ['config', '?BigNumber'], _ref12 => { + var { + config, + BigNumber + } = _ref12; + return config.number === 'BigNumber' ? new BigNumber(2).sqrt() : Math.SQRT2; +}); +export var createI = /* #__PURE__ */recreateFactory('i', ['Complex'], _ref13 => { + var { + Complex + } = _ref13; + return Complex.I; +}); + +// for backward compatibility with v5 +export var createUppercasePi = /* #__PURE__ */factory('PI', ['pi'], _ref14 => { + var { + pi + } = _ref14; + return pi; +}); +export var createUppercaseE = /* #__PURE__ */factory('E', ['e'], _ref15 => { + var { + e + } = _ref15; + return e; +}); +export var createVersion = /* #__PURE__ */factory('version', [], () => version); + +// helper function to create a factory with a flag recreateOnConfigChange +// idea: allow passing optional properties to be attached to the factory function as 4th argument? +function recreateFactory(name, dependencies, create) { + return factory(name, dependencies, create, { + recreateOnConfigChange: true + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/config.js new file mode 100644 index 0000000..10861f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/config.js @@ -0,0 +1,25 @@ +export var DEFAULT_CONFIG = { + // minimum relative difference between two compared values, + // used by all comparison functions + relTol: 1e-12, + // minimum absolute difference between two compared values, + // used by all comparison functions + absTol: 1e-15, + // type of default matrix output. Choose 'matrix' (default) or 'array' + matrix: 'Matrix', + // type of default number output. Choose 'number' (default) 'BigNumber', 'bigint', or 'Fraction' + number: 'number', + // type of fallback used for config { number: 'bigint' } when a value cannot be represented + // in the configured numeric type. Choose 'number' (default) or 'BigNumber'. + numberFallback: 'number', + // number of significant digits in BigNumbers + precision: 64, + // predictable output type of functions. When true, output type depends only + // on the input types. When false (default), output type can vary depending + // on input values. For example `math.sqrt(-4)` returns `complex('2i')` when + // predictable is false, and returns `NaN` when true. + predictable: false, + // random seed for seeded pseudo random number generation + // null = randomly seed + randomSeed: null +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/create.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/create.js new file mode 100644 index 0000000..15baadf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/create.js @@ -0,0 +1,205 @@ +import _extends from "@babel/runtime/helpers/extends"; +import typedFunction from 'typed-function'; +import { ArgumentsError } from '../error/ArgumentsError.js'; +import { DimensionError } from '../error/DimensionError.js'; +import { IndexError } from '../error/IndexError.js'; +import { factory, isFactory } from '../utils/factory.js'; +import { isAccessorNode, isArray, isArrayNode, isAssignmentNode, isBigInt, isBigNumber, isBlockNode, isBoolean, isChain, isCollection, isComplex, isConditionalNode, isConstantNode, isDate, isDenseMatrix, isFraction, isFunction, isFunctionAssignmentNode, isFunctionNode, isHelp, isIndex, isIndexNode, isMap, isMatrix, isNode, isNull, isNumber, isObject, isObjectNode, isObjectWrappingMap, isOperatorNode, isParenthesisNode, isPartitionedMap, isRange, isRangeNode, isRegExp, isRelationalNode, isResultSet, isSparseMatrix, isString, isSymbolNode, isUndefined, isUnit } from '../utils/is.js'; +import { deepFlatten, isLegacyFactory } from '../utils/object.js'; +import * as emitter from './../utils/emitter.js'; +import { DEFAULT_CONFIG } from './config.js'; +import { configFactory } from './function/config.js'; +import { importFactory } from './function/import.js'; + +/** + * Create a mathjs instance from given factory functions and optionally config + * + * Usage: + * + * const mathjs1 = create({ createAdd, createMultiply, ...}) + * const config = { number: 'BigNumber' } + * const mathjs2 = create(all, config) + * + * @param {Object} [factories] An object with factory functions + * The object can contain nested objects, + * all nested objects will be flattened. + * @param {Object} [config] Available options: + * {number} relTol + * Minimum relative difference between two + * compared values, used by all comparison functions. + * {number} absTol + * Minimum absolute difference between two + * compared values, used by all comparison functions. + * {string} matrix + * A string 'Matrix' (default) or 'Array'. + * {string} number + * A string 'number' (default), 'BigNumber', or 'Fraction' + * {number} precision + * The number of significant digits for BigNumbers. + * Not applicable for Numbers. + * {boolean} predictable + * Predictable output type of functions. When true, + * output type depends only on the input types. When + * false (default), output type can vary depending + * on input values. For example `math.sqrt(-4)` + * returns `complex('2i')` when predictable is false, and + * returns `NaN` when true. + * {string} randomSeed + * Random seed for seeded pseudo random number generator. + * Set to null to randomly seed. + * @returns {Object} Returns a bare-bone math.js instance containing + * functions: + * - `import` to add new functions + * - `config` to change configuration + * - `on`, `off`, `once`, `emit` for events + */ +export function create(factories, config) { + var configInternal = _extends({}, DEFAULT_CONFIG, config); + + // simple test for ES5 support + if (typeof Object.create !== 'function') { + throw new Error('ES5 not supported by this JavaScript engine. ' + 'Please load the es5-shim and es5-sham library for compatibility.'); + } + + // create the mathjs instance + var math = emitter.mixin({ + // only here for backward compatibility for legacy factory functions + isNumber, + isComplex, + isBigNumber, + isBigInt, + isFraction, + isUnit, + isString, + isArray, + isMatrix, + isCollection, + isDenseMatrix, + isSparseMatrix, + isRange, + isIndex, + isBoolean, + isResultSet, + isHelp, + isFunction, + isDate, + isRegExp, + isObject, + isMap, + isPartitionedMap, + isObjectWrappingMap, + isNull, + isUndefined, + isAccessorNode, + isArrayNode, + isAssignmentNode, + isBlockNode, + isConditionalNode, + isConstantNode, + isFunctionAssignmentNode, + isFunctionNode, + isIndexNode, + isNode, + isObjectNode, + isOperatorNode, + isParenthesisNode, + isRangeNode, + isRelationalNode, + isSymbolNode, + isChain + }); + + // load config function and apply provided config + math.config = configFactory(configInternal, math.emit); + math.expression = { + transform: {}, + mathWithTransform: { + config: math.config + } + }; + + // cached factories and instances used by function load + var legacyFactories = []; + var legacyInstances = []; + + /** + * Load a function or data type from a factory. + * If the function or data type already exists, the existing instance is + * returned. + * @param {Function} factory + * @returns {*} + */ + function load(factory) { + if (isFactory(factory)) { + return factory(math); + } + var firstProperty = factory[Object.keys(factory)[0]]; + if (isFactory(firstProperty)) { + return firstProperty(math); + } + if (!isLegacyFactory(factory)) { + console.warn('Factory object with properties `type`, `name`, and `factory` expected', factory); + throw new Error('Factory object with properties `type`, `name`, and `factory` expected'); + } + var index = legacyFactories.indexOf(factory); + var instance; + if (index === -1) { + // doesn't yet exist + if (factory.math === true) { + // pass with math namespace + instance = factory.factory(math.type, configInternal, load, math.typed, math); + } else { + instance = factory.factory(math.type, configInternal, load, math.typed); + } + + // append to the cache + legacyFactories.push(factory); + legacyInstances.push(instance); + } else { + // already existing function, return the cached instance + instance = legacyInstances[index]; + } + return instance; + } + var importedFactories = {}; + + // load the import function + function lazyTyped() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + return math.typed.apply(math.typed, args); + } + lazyTyped.isTypedFunction = typedFunction.isTypedFunction; + var internalImport = importFactory(lazyTyped, load, math, importedFactories); + math.import = internalImport; + + // listen for changes in config, import all functions again when changed + // TODO: move this listener into the import function? + math.on('config', () => { + Object.values(importedFactories).forEach(factory => { + if (factory && factory.meta && factory.meta.recreateOnConfigChange) { + // FIXME: only re-create when the current instance is the same as was initially created + // FIXME: delete the functions/constants before importing them again? + internalImport(factory, { + override: true + }); + } + }); + }); + + // the create function exposed on the mathjs instance is bound to + // the factory functions passed before + math.create = create.bind(null, factories); + + // export factory function + math.factory = factory; + + // import the factory functions like createAdd as an array instead of object, + // else they will get a different naming (`createAdd` instead of `add`). + math.import(Object.values(deepFlatten(factories))); + math.ArgumentsError = ArgumentsError; + math.DimensionError = DimensionError; + math.IndexError = IndexError; + return math; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/config.js new file mode 100644 index 0000000..7c50520 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/config.js @@ -0,0 +1,108 @@ +import { clone, deepExtend } from '../../utils/object.js'; +import { DEFAULT_CONFIG } from '../config.js'; +export var MATRIX_OPTIONS = ['Matrix', 'Array']; // valid values for option matrix +export var NUMBER_OPTIONS = ['number', 'BigNumber', 'Fraction']; // valid values for option number + +export function configFactory(config, emit) { + /** + * Set configuration options for math.js, and get current options. + * Will emit a 'config' event, with arguments (curr, prev, changes). + * + * This function is only available on a mathjs instance created using `create`. + * + * Syntax: + * + * math.config(config: Object): Object + * + * Examples: + * + * + * import { create, all } from 'mathjs' + * + * // create a mathjs instance + * const math = create(all) + * + * math.config().number // outputs 'number' + * math.evaluate('0.4') // outputs number 0.4 + * math.config({number: 'Fraction'}) + * math.evaluate('0.4') // outputs Fraction 2/5 + * + * @param {Object} [options] Available options: + * {number} relTol + * Minimum relative difference between two + * compared values, used by all comparison functions. + * {number} absTol + * Minimum absolute difference between two + * compared values, used by all comparison functions. + * {string} matrix + * A string 'Matrix' (default) or 'Array'. + * {string} number + * A string 'number' (default), 'BigNumber', 'bigint', or 'Fraction' + * {number} precision + * The number of significant digits for BigNumbers. + * Not applicable for Numbers. + * {string} parenthesis + * How to display parentheses in LaTeX and string + * output. + * {string} randomSeed + * Random seed for seeded pseudo random number generator. + * Set to null to randomly seed. + * @return {Object} Returns the current configuration + */ + function _config(options) { + if (options) { + if (options.epsilon !== undefined) { + // this if is only for backwards compatibility, it can be removed in the future. + console.warn('Warning: The configuration option "epsilon" is deprecated. Use "relTol" and "absTol" instead.'); + var optionsFix = clone(options); + optionsFix.relTol = options.epsilon; + optionsFix.absTol = options.epsilon * 1e-3; + delete optionsFix.epsilon; + return _config(optionsFix); + } + var prev = clone(config); + + // validate some of the options + validateOption(options, 'matrix', MATRIX_OPTIONS); + validateOption(options, 'number', NUMBER_OPTIONS); + + // merge options + deepExtend(config, options); + var curr = clone(config); + var changes = clone(options); + + // emit 'config' event + emit('config', curr, prev, changes); + return curr; + } else { + return clone(config); + } + } + + // attach the valid options to the function so they can be extended + _config.MATRIX_OPTIONS = MATRIX_OPTIONS; + _config.NUMBER_OPTIONS = NUMBER_OPTIONS; + + // attach the config properties as readonly properties to the config function + Object.keys(DEFAULT_CONFIG).forEach(key => { + Object.defineProperty(_config, key, { + get: () => config[key], + enumerable: true, + configurable: true + }); + }); + return _config; +} + +/** + * Validate an option + * @param {Object} options Object with options + * @param {string} name Name of the option to validate + * @param {Array.} values Array with valid values for this option + */ +function validateOption(options, name, values) { + if (options[name] !== undefined && !values.includes(options[name])) { + // unknown value + console.warn('Warning: Unknown value "' + options[name] + '" for configuration option "' + name + '". ' + 'Available options: ' + values.map(value => JSON.stringify(value)).join(', ') + '.'); + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/import.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/import.js new file mode 100644 index 0000000..2b1ff64 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/import.js @@ -0,0 +1,325 @@ +import { isBigNumber, isComplex, isFraction, isMatrix, isUnit } from '../../utils/is.js'; +import { isFactory, stripOptionalNotation } from '../../utils/factory.js'; +import { hasOwnProperty, lazy } from '../../utils/object.js'; +import { ArgumentsError } from '../../error/ArgumentsError.js'; +export function importFactory(typed, load, math, importedFactories) { + /** + * Import functions from an object or a module. + * + * This function is only available on a mathjs instance created using `create`. + * + * Syntax: + * + * math.import(functions) + * math.import(functions, options) + * + * Where: + * + * - `functions: Object` + * An object with functions or factories to be imported. + * - `options: Object` An object with import options. Available options: + * - `override: boolean` + * If true, existing functions will be overwritten. False by default. + * - `silent: boolean` + * If true, the function will not throw errors on duplicates or invalid + * types. False by default. + * - `wrap: boolean` + * If true, the functions will be wrapped in a wrapper function + * which converts data types like Matrix to primitive data types like Array. + * The wrapper is needed when extending math.js with libraries which do not + * support these data type. False by default. + * + * Examples: + * + * import { create, all } from 'mathjs' + * import * as numbers from 'numbers' + * + * // create a mathjs instance + * const math = create(all) + * + * // define new functions and variables + * math.import({ + * myvalue: 42, + * hello: function (name) { + * return 'hello, ' + name + '!' + * } + * }) + * + * // use the imported function and variable + * math.myvalue * 2 // 84 + * math.hello('user') // 'hello, user!' + * + * // import the npm module 'numbers' + * // (must be installed first with `npm install numbers`) + * math.import(numbers, {wrap: true}) + * + * math.fibonacci(7) // returns 13 + * + * @param {Object | Array} functions Object with functions to be imported. + * @param {Object} [options] Import options. + */ + function mathImport(functions, options) { + var num = arguments.length; + if (num !== 1 && num !== 2) { + throw new ArgumentsError('import', num, 1, 2); + } + if (!options) { + options = {}; + } + function flattenImports(flatValues, value, name) { + if (Array.isArray(value)) { + value.forEach(item => flattenImports(flatValues, item)); + } else if (typeof value === 'object') { + for (var _name in value) { + if (hasOwnProperty(value, _name)) { + flattenImports(flatValues, value[_name], _name); + } + } + } else if (isFactory(value) || name !== undefined) { + var flatName = isFactory(value) ? isTransformFunctionFactory(value) ? value.fn + '.transform' // TODO: this is ugly + : value.fn : name; + + // we allow importing the same function twice if it points to the same implementation + if (hasOwnProperty(flatValues, flatName) && flatValues[flatName] !== value && !options.silent) { + throw new Error('Cannot import "' + flatName + '" twice'); + } + flatValues[flatName] = value; + } else { + if (!options.silent) { + throw new TypeError('Factory, Object, or Array expected'); + } + } + } + var flatValues = {}; + flattenImports(flatValues, functions); + for (var name in flatValues) { + if (hasOwnProperty(flatValues, name)) { + // console.log('import', name) + var value = flatValues[name]; + if (isFactory(value)) { + // we ignore name here and enforce the name of the factory + // maybe at some point we do want to allow overriding it + // in that case we can implement an option overrideFactoryNames: true + _importFactory(value, options); + } else if (isSupportedType(value)) { + _import(name, value, options); + } else { + if (!options.silent) { + throw new TypeError('Factory, Object, or Array expected'); + } + } + } + } + } + + /** + * Add a property to the math namespace + * @param {string} name + * @param {*} value + * @param {Object} options See import for a description of the options + * @private + */ + function _import(name, value, options) { + // TODO: refactor this function, it's to complicated and contains duplicate code + if (options.wrap && typeof value === 'function') { + // create a wrapper around the function + value = _wrap(value); + } + + // turn a plain function with a typed-function signature into a typed-function + if (hasTypedFunctionSignature(value)) { + value = typed(name, { + [value.signature]: value + }); + } + if (typed.isTypedFunction(math[name]) && typed.isTypedFunction(value)) { + if (options.override) { + // give the typed function the right name + value = typed(name, value.signatures); + } else { + // merge the existing and typed function + value = typed(math[name], value); + } + math[name] = value; + delete importedFactories[name]; + _importTransform(name, value); + math.emit('import', name, function resolver() { + return value; + }); + return; + } + if (math[name] === undefined || options.override) { + math[name] = value; + delete importedFactories[name]; + _importTransform(name, value); + math.emit('import', name, function resolver() { + return value; + }); + return; + } + if (!options.silent) { + throw new Error('Cannot import "' + name + '": already exists'); + } + } + function _importTransform(name, value) { + if (value && typeof value.transform === 'function') { + math.expression.transform[name] = value.transform; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = value.transform; + } + } else { + // remove existing transform + delete math.expression.transform[name]; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = value; + } + } + } + function _deleteTransform(name) { + delete math.expression.transform[name]; + if (allowedInExpressions(name)) { + math.expression.mathWithTransform[name] = math[name]; + } else { + delete math.expression.mathWithTransform[name]; + } + } + + /** + * Create a wrapper a round an function which converts the arguments + * to their primitive values (like convert a Matrix to Array) + * @param {Function} fn + * @return {Function} Returns the wrapped function + * @private + */ + function _wrap(fn) { + var wrapper = function wrapper() { + var args = []; + for (var i = 0, len = arguments.length; i < len; i++) { + var arg = arguments[i]; + args[i] = arg && arg.valueOf(); + } + return fn.apply(math, args); + }; + if (fn.transform) { + wrapper.transform = fn.transform; + } + return wrapper; + } + + /** + * Import an instance of a factory into math.js + * @param {function(scope: object)} factory + * @param {Object} options See import for a description of the options + * @param {string} [name=factory.name] Optional custom name + * @private + */ + function _importFactory(factory, options) { + var name = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : factory.fn; + if (name.includes('.')) { + throw new Error('Factory name should not contain a nested path. ' + 'Name: ' + JSON.stringify(name)); + } + var namespace = isTransformFunctionFactory(factory) ? math.expression.transform : math; + var existingTransform = name in math.expression.transform; + var existing = hasOwnProperty(namespace, name) ? namespace[name] : undefined; + var resolver = function resolver() { + // collect all dependencies, handle finding both functions and classes and other special cases + var dependencies = {}; + factory.dependencies.map(stripOptionalNotation).forEach(dependency => { + if (dependency.includes('.')) { + throw new Error('Factory dependency should not contain a nested path. ' + 'Name: ' + JSON.stringify(dependency)); + } + if (dependency === 'math') { + dependencies.math = math; + } else if (dependency === 'mathWithTransform') { + dependencies.mathWithTransform = math.expression.mathWithTransform; + } else if (dependency === 'classes') { + // special case for json reviver + dependencies.classes = math; + } else { + dependencies[dependency] = math[dependency]; + } + }); + var instance = /* #__PURE__ */factory(dependencies); + if (instance && typeof instance.transform === 'function') { + throw new Error('Transforms cannot be attached to factory functions. ' + 'Please create a separate function for it with export const path = "expression.transform"'); + } + if (existing === undefined || options.override) { + return instance; + } + if (typed.isTypedFunction(existing) && typed.isTypedFunction(instance)) { + // merge the existing and new typed function + return typed(existing, instance); + } + if (options.silent) { + // keep existing, ignore imported function + return existing; + } else { + throw new Error('Cannot import "' + name + '": already exists'); + } + }; + + // TODO: add unit test with non-lazy factory + if (!factory.meta || factory.meta.lazy !== false) { + lazy(namespace, name, resolver); + + // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two) + if (existing && existingTransform) { + _deleteTransform(name); + } else { + if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) { + lazy(math.expression.mathWithTransform, name, () => namespace[name]); + } + } + } else { + namespace[name] = resolver(); + + // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two) + if (existing && existingTransform) { + _deleteTransform(name); + } else { + if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) { + lazy(math.expression.mathWithTransform, name, () => namespace[name]); + } + } + } + + // TODO: improve factories, store a list with imports instead which can be re-played + importedFactories[name] = factory; + math.emit('import', name, resolver); + } + + /** + * Check whether given object is a type which can be imported + * @param {Function | number | string | boolean | null | Unit | Complex} object + * @return {boolean} + * @private + */ + function isSupportedType(object) { + return typeof object === 'function' || typeof object === 'number' || typeof object === 'string' || typeof object === 'boolean' || object === null || isUnit(object) || isComplex(object) || isBigNumber(object) || isFraction(object) || isMatrix(object) || Array.isArray(object); + } + function hasTypedFunctionSignature(fn) { + return typeof fn === 'function' && typeof fn.signature === 'string'; + } + function allowedInExpressions(name) { + return !hasOwnProperty(unsafe, name); + } + function factoryAllowedInExpressions(factory) { + return !factory.fn.includes('.') && + // FIXME: make checking on path redundant, check on meta data instead + !hasOwnProperty(unsafe, factory.fn) && (!factory.meta || !factory.meta.isClass); + } + function isTransformFunctionFactory(factory) { + return factory !== undefined && factory.meta !== undefined && factory.meta.isTransformFunction === true || false; + } + + // namespaces and functions not available in the parser for safety reasons + var unsafe = { + expression: true, + type: true, + docs: true, + error: true, + json: true, + chain: true // chain method not supported. Note that there is a unit chain too. + }; + return mathImport; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/typed.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/typed.js new file mode 100644 index 0000000..8507510 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/core/function/typed.js @@ -0,0 +1,455 @@ +/** + * Create a typed-function which checks the types of the arguments and + * can match them against multiple provided signatures. The typed-function + * automatically converts inputs in order to find a matching signature. + * Typed functions throw informative errors in case of wrong input arguments. + * + * See the library [typed-function](https://github.com/josdejong/typed-function) + * for detailed documentation. + * + * Syntax: + * + * math.typed(name, signatures) : function + * math.typed(signatures) : function + * + * Examples: + * + * // create a typed function with multiple types per argument (type union) + * const fn2 = typed({ + * 'number | boolean': function (b) { + * return 'b is a number or boolean' + * }, + * 'string, number | boolean': function (a, b) { + * return 'a is a string, b is a number or boolean' + * } + * }) + * + * // create a typed function with an any type argument + * const log = typed({ + * 'string, any': function (event, data) { + * console.log('event: ' + event + ', data: ' + JSON.stringify(data)) + * } + * }) + * + * @param {string} [name] Optional name for the typed-function + * @param {Object} signatures Object with one or multiple function signatures + * @returns {function} The created typed-function. + */ + +import typedFunction from 'typed-function'; +import { factory } from '../../utils/factory.js'; +import { isAccessorNode, isArray, isArrayNode, isAssignmentNode, isBigInt, isBigNumber, isBlockNode, isBoolean, isChain, isCollection, isComplex, isConditionalNode, isConstantNode, isDate, isDenseMatrix, isFraction, isFunction, isFunctionAssignmentNode, isFunctionNode, isHelp, isIndex, isIndexNode, isMap, isMatrix, isNode, isNull, isNumber, isObject, isObjectNode, isOperatorNode, isParenthesisNode, isRange, isRangeNode, isRegExp, isRelationalNode, isResultSet, isSparseMatrix, isString, isSymbolNode, isUndefined, isUnit } from '../../utils/is.js'; +import { digits } from '../../utils/number.js'; + +// returns a new instance of typed-function +var _createTyped2 = function _createTyped() { + // initially, return the original instance of typed-function + // consecutively, return a new instance from typed.create. + _createTyped2 = typedFunction.create; + return typedFunction; +}; +var dependencies = ['?BigNumber', '?Complex', '?DenseMatrix', '?Fraction']; + +/** + * Factory function for creating a new typed instance + * @param {Object} dependencies Object with data types like Complex and BigNumber + * @returns {Function} + */ +export var createTyped = /* #__PURE__ */factory('typed', dependencies, function createTyped(_ref) { + var { + BigNumber, + Complex, + DenseMatrix, + Fraction + } = _ref; + // TODO: typed-function must be able to silently ignore signatures with unknown data types + + // get a new instance of typed-function + var typed = _createTyped2(); + + // define all types. The order of the types determines in which order function + // arguments are type-checked (so for performance it's important to put the + // most used types first). + typed.clear(); + typed.addTypes([{ + name: 'number', + test: isNumber + }, { + name: 'Complex', + test: isComplex + }, { + name: 'BigNumber', + test: isBigNumber + }, { + name: 'bigint', + test: isBigInt + }, { + name: 'Fraction', + test: isFraction + }, { + name: 'Unit', + test: isUnit + }, + // The following type matches a valid variable name, i.e., an alphanumeric + // string starting with an alphabetic character. It is used (at least) + // in the definition of the derivative() function, as the argument telling + // what to differentiate over must (currently) be a variable. + // TODO: deprecate the identifier type (it's not used anymore, see https://github.com/josdejong/mathjs/issues/3253) + { + name: 'identifier', + test: s => isString && /^(?:[A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF40\uDF42-\uDF49\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDD70-\uDD7A\uDD7C-\uDD8A\uDD8C-\uDD92\uDD94\uDD95\uDD97-\uDDA1\uDDA3-\uDDB1\uDDB3-\uDDB9\uDDBB\uDDBC\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67\uDF80-\uDF85\uDF87-\uDFB0\uDFB2-\uDFBA]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE35\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2\uDD00-\uDD23\uDE80-\uDEA9\uDEB0\uDEB1\uDF00-\uDF1C\uDF27\uDF30-\uDF45\uDF70-\uDF81\uDFB0-\uDFC4\uDFE0-\uDFF6]|\uD804[\uDC03-\uDC37\uDC71\uDC72\uDC75\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD44\uDD47\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE3F\uDE40\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC5F-\uDC61\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDEB8\uDF00-\uDF1A\uDF40-\uDF46]|\uD806[\uDC00-\uDC2B\uDCA0-\uDCDF\uDCFF-\uDD06\uDD09\uDD0C-\uDD13\uDD15\uDD16\uDD18-\uDD2F\uDD3F\uDD41\uDDA0-\uDDA7\uDDAA-\uDDD0\uDDE1\uDDE3\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE89\uDE9D\uDEB0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46\uDD60-\uDD65\uDD67\uDD68\uDD6A-\uDD89\uDD98\uDEE0-\uDEF2\uDF02\uDF04-\uDF10\uDF12-\uDF33\uDFB0]|\uD808[\uDC00-\uDF99]|\uD809[\uDC80-\uDD43]|\uD80B[\uDF90-\uDFF0]|[\uD80C\uD81C-\uD820\uD822\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879\uD880-\uD883\uD885-\uD887][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2F\uDC41-\uDC46]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE70-\uDEBE\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDE40-\uDE7F\uDF00-\uDF4A\uDF50\uDF93-\uDF9F\uDFE0\uDFE1\uDFE3]|\uD821[\uDC00-\uDFF7]|\uD823[\uDC00-\uDCD5\uDD00-\uDD08]|\uD82B[\uDFF0-\uDFF3\uDFF5-\uDFFB\uDFFD\uDFFE]|\uD82C[\uDC00-\uDD22\uDD32\uDD50-\uDD52\uDD55\uDD64-\uDD67\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD837[\uDF00-\uDF1E\uDF25-\uDF2A]|\uD838[\uDC30-\uDC6D\uDD00-\uDD2C\uDD37-\uDD3D\uDD4E\uDE90-\uDEAD\uDEC0-\uDEEB]|\uD839[\uDCD0-\uDCEB\uDFE0-\uDFE6\uDFE8-\uDFEB\uDFED\uDFEE\uDFF0-\uDFFE]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43\uDD4B]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDEDF\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF39\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0\uDFF0-\uDFFF]|\uD87B[\uDC00-\uDE5D]|\uD87E[\uDC00-\uDE1D]|\uD884[\uDC00-\uDF4A\uDF50-\uDFFF]|\uD888[\uDC00-\uDFAF])(?:[0-9A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF40\uDF42-\uDF49\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDD70-\uDD7A\uDD7C-\uDD8A\uDD8C-\uDD92\uDD94\uDD95\uDD97-\uDDA1\uDDA3-\uDDB1\uDDB3-\uDDB9\uDDBB\uDDBC\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67\uDF80-\uDF85\uDF87-\uDFB0\uDFB2-\uDFBA]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE35\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2\uDD00-\uDD23\uDE80-\uDEA9\uDEB0\uDEB1\uDF00-\uDF1C\uDF27\uDF30-\uDF45\uDF70-\uDF81\uDFB0-\uDFC4\uDFE0-\uDFF6]|\uD804[\uDC03-\uDC37\uDC71\uDC72\uDC75\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD44\uDD47\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE3F\uDE40\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC5F-\uDC61\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDEB8\uDF00-\uDF1A\uDF40-\uDF46]|\uD806[\uDC00-\uDC2B\uDCA0-\uDCDF\uDCFF-\uDD06\uDD09\uDD0C-\uDD13\uDD15\uDD16\uDD18-\uDD2F\uDD3F\uDD41\uDDA0-\uDDA7\uDDAA-\uDDD0\uDDE1\uDDE3\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE89\uDE9D\uDEB0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46\uDD60-\uDD65\uDD67\uDD68\uDD6A-\uDD89\uDD98\uDEE0-\uDEF2\uDF02\uDF04-\uDF10\uDF12-\uDF33\uDFB0]|\uD808[\uDC00-\uDF99]|\uD809[\uDC80-\uDD43]|\uD80B[\uDF90-\uDFF0]|[\uD80C\uD81C-\uD820\uD822\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879\uD880-\uD883\uD885-\uD887][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2F\uDC41-\uDC46]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE70-\uDEBE\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDE40-\uDE7F\uDF00-\uDF4A\uDF50\uDF93-\uDF9F\uDFE0\uDFE1\uDFE3]|\uD821[\uDC00-\uDFF7]|\uD823[\uDC00-\uDCD5\uDD00-\uDD08]|\uD82B[\uDFF0-\uDFF3\uDFF5-\uDFFB\uDFFD\uDFFE]|\uD82C[\uDC00-\uDD22\uDD32\uDD50-\uDD52\uDD55\uDD64-\uDD67\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD837[\uDF00-\uDF1E\uDF25-\uDF2A]|\uD838[\uDC30-\uDC6D\uDD00-\uDD2C\uDD37-\uDD3D\uDD4E\uDE90-\uDEAD\uDEC0-\uDEEB]|\uD839[\uDCD0-\uDCEB\uDFE0-\uDFE6\uDFE8-\uDFEB\uDFED\uDFEE\uDFF0-\uDFFE]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43\uDD4B]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDEDF\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF39\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0\uDFF0-\uDFFF]|\uD87B[\uDC00-\uDE5D]|\uD87E[\uDC00-\uDE1D]|\uD884[\uDC00-\uDF4A\uDF50-\uDFFF]|\uD888[\uDC00-\uDFAF])*$/.test(s) + }, { + name: 'string', + test: isString + }, { + name: 'Chain', + test: isChain + }, { + name: 'Array', + test: isArray + }, { + name: 'Matrix', + test: isMatrix + }, { + name: 'DenseMatrix', + test: isDenseMatrix + }, { + name: 'SparseMatrix', + test: isSparseMatrix + }, { + name: 'Range', + test: isRange + }, { + name: 'Index', + test: isIndex + }, { + name: 'boolean', + test: isBoolean + }, { + name: 'ResultSet', + test: isResultSet + }, { + name: 'Help', + test: isHelp + }, { + name: 'function', + test: isFunction + }, { + name: 'Date', + test: isDate + }, { + name: 'RegExp', + test: isRegExp + }, { + name: 'null', + test: isNull + }, { + name: 'undefined', + test: isUndefined + }, { + name: 'AccessorNode', + test: isAccessorNode + }, { + name: 'ArrayNode', + test: isArrayNode + }, { + name: 'AssignmentNode', + test: isAssignmentNode + }, { + name: 'BlockNode', + test: isBlockNode + }, { + name: 'ConditionalNode', + test: isConditionalNode + }, { + name: 'ConstantNode', + test: isConstantNode + }, { + name: 'FunctionNode', + test: isFunctionNode + }, { + name: 'FunctionAssignmentNode', + test: isFunctionAssignmentNode + }, { + name: 'IndexNode', + test: isIndexNode + }, { + name: 'Node', + test: isNode + }, { + name: 'ObjectNode', + test: isObjectNode + }, { + name: 'OperatorNode', + test: isOperatorNode + }, { + name: 'ParenthesisNode', + test: isParenthesisNode + }, { + name: 'RangeNode', + test: isRangeNode + }, { + name: 'RelationalNode', + test: isRelationalNode + }, { + name: 'SymbolNode', + test: isSymbolNode + }, { + name: 'Map', + test: isMap + }, { + name: 'Object', + test: isObject + } // order 'Object' last, it matches on other classes too + ]); + typed.addConversions([{ + from: 'number', + to: 'BigNumber', + convert: function convert(x) { + if (!BigNumber) { + throwNoBignumber(x); + } + + // note: conversion from number to BigNumber can fail if x has >15 digits + if (digits(x) > 15) { + throw new TypeError('Cannot implicitly convert a number with >15 significant digits to BigNumber ' + '(value: ' + x + '). ' + 'Use function bignumber(x) to convert to BigNumber.'); + } + return new BigNumber(x); + } + }, { + from: 'number', + to: 'Complex', + convert: function convert(x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x, 0); + } + }, { + from: 'BigNumber', + to: 'Complex', + convert: function convert(x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x.toNumber(), 0); + } + }, { + from: 'bigint', + to: 'number', + convert: function convert(x) { + if (x > Number.MAX_SAFE_INTEGER) { + throw new TypeError('Cannot implicitly convert bigint to number: ' + 'value exceeds the max safe integer value (value: ' + x + ')'); + } + return Number(x); + } + }, { + from: 'bigint', + to: 'BigNumber', + convert: function convert(x) { + if (!BigNumber) { + throwNoBignumber(x); + } + return new BigNumber(x.toString()); + } + }, { + from: 'bigint', + to: 'Fraction', + convert: function convert(x) { + if (!Fraction) { + throwNoFraction(x); + } + return new Fraction(x.toString()); + } + }, { + from: 'Fraction', + to: 'BigNumber', + convert: function convert(x) { + throw new TypeError('Cannot implicitly convert a Fraction to BigNumber or vice versa. ' + 'Use function bignumber(x) to convert to BigNumber or fraction(x) to convert to Fraction.'); + } + }, { + from: 'Fraction', + to: 'Complex', + convert: function convert(x) { + if (!Complex) { + throwNoComplex(x); + } + return new Complex(x.valueOf(), 0); + } + }, { + from: 'number', + to: 'Fraction', + convert: function convert(x) { + if (!Fraction) { + throwNoFraction(x); + } + var f = new Fraction(x); + if (f.valueOf() !== x) { + throw new TypeError('Cannot implicitly convert a number to a Fraction when there will be a loss of precision ' + '(value: ' + x + '). ' + 'Use function fraction(x) to convert to Fraction.'); + } + return f; + } + }, { + // FIXME: add conversion from Fraction to number, for example for `sqrt(fraction(1,3))` + // from: 'Fraction', + // to: 'number', + // convert: function (x) { + // return x.valueOf() + // } + // }, { + from: 'string', + to: 'number', + convert: function convert(x) { + var n = Number(x); + if (isNaN(n)) { + throw new Error('Cannot convert "' + x + '" to a number'); + } + return n; + } + }, { + from: 'string', + to: 'BigNumber', + convert: function convert(x) { + if (!BigNumber) { + throwNoBignumber(x); + } + try { + return new BigNumber(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to BigNumber'); + } + } + }, { + from: 'string', + to: 'bigint', + convert: function convert(x) { + try { + return BigInt(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to BigInt'); + } + } + }, { + from: 'string', + to: 'Fraction', + convert: function convert(x) { + if (!Fraction) { + throwNoFraction(x); + } + try { + return new Fraction(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to Fraction'); + } + } + }, { + from: 'string', + to: 'Complex', + convert: function convert(x) { + if (!Complex) { + throwNoComplex(x); + } + try { + return new Complex(x); + } catch (err) { + throw new Error('Cannot convert "' + x + '" to Complex'); + } + } + }, { + from: 'boolean', + to: 'number', + convert: function convert(x) { + return +x; + } + }, { + from: 'boolean', + to: 'BigNumber', + convert: function convert(x) { + if (!BigNumber) { + throwNoBignumber(x); + } + return new BigNumber(+x); + } + }, { + from: 'boolean', + to: 'bigint', + convert: function convert(x) { + return BigInt(+x); + } + }, { + from: 'boolean', + to: 'Fraction', + convert: function convert(x) { + if (!Fraction) { + throwNoFraction(x); + } + return new Fraction(+x); + } + }, { + from: 'boolean', + to: 'string', + convert: function convert(x) { + return String(x); + } + }, { + from: 'Array', + to: 'Matrix', + convert: function convert(array) { + if (!DenseMatrix) { + throwNoMatrix(); + } + return new DenseMatrix(array); + } + }, { + from: 'Matrix', + to: 'Array', + convert: function convert(matrix) { + return matrix.valueOf(); + } + }]); + + // Provide a suggestion on how to call a function elementwise + // This was added primarily as guidance for the v10 -> v11 transition, + // and could potentially be removed in the future if it no longer seems + // to be helpful. + typed.onMismatch = (name, args, signatures) => { + var usualError = typed.createError(name, args, signatures); + if (['wrongType', 'mismatch'].includes(usualError.data.category) && args.length === 1 && isCollection(args[0]) && + // check if the function can be unary: + signatures.some(sig => !sig.params.includes(','))) { + var err = new TypeError("Function '".concat(name, "' doesn't apply to matrices. To call it ") + "elementwise on a matrix 'M', try 'map(M, ".concat(name, ")'.")); + err.data = usualError.data; + throw err; + } + throw usualError; + }; + + // Provide a suggestion on how to call a function elementwise + // This was added primarily as guidance for the v10 -> v11 transition, + // and could potentially be removed in the future if it no longer seems + // to be helpful. + typed.onMismatch = (name, args, signatures) => { + var usualError = typed.createError(name, args, signatures); + if (['wrongType', 'mismatch'].includes(usualError.data.category) && args.length === 1 && isCollection(args[0]) && + // check if the function can be unary: + signatures.some(sig => !sig.params.includes(','))) { + var err = new TypeError("Function '".concat(name, "' doesn't apply to matrices. To call it ") + "elementwise on a matrix 'M', try 'map(M, ".concat(name, ")'.")); + err.data = usualError.data; + throw err; + } + throw usualError; + }; + return typed; +}); +function throwNoBignumber(x) { + throw new Error("Cannot convert value ".concat(x, " into a BigNumber: no class 'BigNumber' provided")); +} +function throwNoComplex(x) { + throw new Error("Cannot convert value ".concat(x, " into a Complex number: no class 'Complex' provided")); +} +function throwNoMatrix() { + throw new Error('Cannot convert array into a Matrix: no class \'DenseMatrix\' provided'); +} +function throwNoFraction(x) { + throw new Error("Cannot convert value ".concat(x, " into a Fraction, no class 'Fraction' provided.")); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/defaultInstance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/defaultInstance.js new file mode 100644 index 0000000..630e984 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/defaultInstance.js @@ -0,0 +1,3 @@ +import * as all from './factoriesAny.js'; +import { create } from './core/create.js'; +export default create(all); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesAny.js new file mode 100644 index 0000000..b4e11fb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesAny.js @@ -0,0 +1,3 @@ +// creating all factories here in a separate file is needed to get tree-shaking working +import * as allFactories from '../factoriesAny.js'; +export var all = allFactories; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesNumber.js new file mode 100644 index 0000000..e4221a3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/allFactoriesNumber.js @@ -0,0 +1,3 @@ +// creating all factories here in a separate file is needed to get tree-shaking working +import * as allFactories from '../factoriesNumber.js'; +export var all = allFactories; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/configReadonly.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/configReadonly.js new file mode 100644 index 0000000..c6f5702 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/configReadonly.js @@ -0,0 +1,15 @@ +import _extends from "@babel/runtime/helpers/extends"; +import { DEFAULT_CONFIG } from '../core/config.js'; +import { MATRIX_OPTIONS, NUMBER_OPTIONS } from '../core/function/config.js'; + +// create a read-only version of config +export var config = function config(options) { + if (options) { + throw new Error('The global config is readonly. \n' + 'Please create a mathjs instance if you want to change the default configuration. \n' + 'Example:\n' + '\n' + ' import { create, all } from \'mathjs\';\n' + ' const mathjs = create(all);\n' + ' mathjs.config({ number: \'BigNumber\' });\n'); + } + return Object.freeze(DEFAULT_CONFIG); +}; +_extends(config, DEFAULT_CONFIG, { + MATRIX_OPTIONS, + NUMBER_OPTIONS +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny.generated.js new file mode 100644 index 0000000..be73c38 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny.generated.js @@ -0,0 +1,367 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +export { absDependencies } from './dependenciesAny/dependenciesAbs.generated.js'; +export { AccessorNodeDependencies } from './dependenciesAny/dependenciesAccessorNode.generated.js'; +export { acosDependencies } from './dependenciesAny/dependenciesAcos.generated.js'; +export { acoshDependencies } from './dependenciesAny/dependenciesAcosh.generated.js'; +export { acotDependencies } from './dependenciesAny/dependenciesAcot.generated.js'; +export { acothDependencies } from './dependenciesAny/dependenciesAcoth.generated.js'; +export { acscDependencies } from './dependenciesAny/dependenciesAcsc.generated.js'; +export { acschDependencies } from './dependenciesAny/dependenciesAcsch.generated.js'; +export { addDependencies } from './dependenciesAny/dependenciesAdd.generated.js'; +export { addScalarDependencies } from './dependenciesAny/dependenciesAddScalar.generated.js'; +export { andDependencies } from './dependenciesAny/dependenciesAnd.generated.js'; +export { andTransformDependencies } from './dependenciesAny/dependenciesAndTransform.generated.js'; +export { applyDependencies } from './dependenciesAny/dependenciesApply.generated.js'; +export { applyTransformDependencies } from './dependenciesAny/dependenciesApplyTransform.generated.js'; +export { argDependencies } from './dependenciesAny/dependenciesArg.generated.js'; +export { ArrayNodeDependencies } from './dependenciesAny/dependenciesArrayNode.generated.js'; +export { asecDependencies } from './dependenciesAny/dependenciesAsec.generated.js'; +export { asechDependencies } from './dependenciesAny/dependenciesAsech.generated.js'; +export { asinDependencies } from './dependenciesAny/dependenciesAsin.generated.js'; +export { asinhDependencies } from './dependenciesAny/dependenciesAsinh.generated.js'; +export { AssignmentNodeDependencies } from './dependenciesAny/dependenciesAssignmentNode.generated.js'; +export { atanDependencies } from './dependenciesAny/dependenciesAtan.generated.js'; +export { atan2Dependencies } from './dependenciesAny/dependenciesAtan2.generated.js'; +export { atanhDependencies } from './dependenciesAny/dependenciesAtanh.generated.js'; +export { atomicMassDependencies } from './dependenciesAny/dependenciesAtomicMass.generated.js'; +export { avogadroDependencies } from './dependenciesAny/dependenciesAvogadro.generated.js'; +export { bellNumbersDependencies } from './dependenciesAny/dependenciesBellNumbers.generated.js'; +export { BigNumberDependencies } from './dependenciesAny/dependenciesBigNumberClass.generated.js'; +export { bigintDependencies } from './dependenciesAny/dependenciesBigint.generated.js'; +export { bignumberDependencies } from './dependenciesAny/dependenciesBignumber.generated.js'; +export { binDependencies } from './dependenciesAny/dependenciesBin.generated.js'; +export { bitAndDependencies } from './dependenciesAny/dependenciesBitAnd.generated.js'; +export { bitAndTransformDependencies } from './dependenciesAny/dependenciesBitAndTransform.generated.js'; +export { bitNotDependencies } from './dependenciesAny/dependenciesBitNot.generated.js'; +export { bitOrDependencies } from './dependenciesAny/dependenciesBitOr.generated.js'; +export { bitOrTransformDependencies } from './dependenciesAny/dependenciesBitOrTransform.generated.js'; +export { bitXorDependencies } from './dependenciesAny/dependenciesBitXor.generated.js'; +export { BlockNodeDependencies } from './dependenciesAny/dependenciesBlockNode.generated.js'; +export { bohrMagnetonDependencies } from './dependenciesAny/dependenciesBohrMagneton.generated.js'; +export { bohrRadiusDependencies } from './dependenciesAny/dependenciesBohrRadius.generated.js'; +export { boltzmannDependencies } from './dependenciesAny/dependenciesBoltzmann.generated.js'; +export { booleanDependencies } from './dependenciesAny/dependenciesBoolean.generated.js'; +export { catalanDependencies } from './dependenciesAny/dependenciesCatalan.generated.js'; +export { cbrtDependencies } from './dependenciesAny/dependenciesCbrt.generated.js'; +export { ceilDependencies } from './dependenciesAny/dependenciesCeil.generated.js'; +export { chainDependencies } from './dependenciesAny/dependenciesChain.generated.js'; +export { ChainDependencies } from './dependenciesAny/dependenciesChainClass.generated.js'; +export { classicalElectronRadiusDependencies } from './dependenciesAny/dependenciesClassicalElectronRadius.generated.js'; +export { cloneDependencies } from './dependenciesAny/dependenciesClone.generated.js'; +export { columnDependencies } from './dependenciesAny/dependenciesColumn.generated.js'; +export { columnTransformDependencies } from './dependenciesAny/dependenciesColumnTransform.generated.js'; +export { combinationsDependencies } from './dependenciesAny/dependenciesCombinations.generated.js'; +export { combinationsWithRepDependencies } from './dependenciesAny/dependenciesCombinationsWithRep.generated.js'; +export { compareDependencies } from './dependenciesAny/dependenciesCompare.generated.js'; +export { compareNaturalDependencies } from './dependenciesAny/dependenciesCompareNatural.generated.js'; +export { compareTextDependencies } from './dependenciesAny/dependenciesCompareText.generated.js'; +export { compileDependencies } from './dependenciesAny/dependenciesCompile.generated.js'; +export { complexDependencies } from './dependenciesAny/dependenciesComplex.generated.js'; +export { ComplexDependencies } from './dependenciesAny/dependenciesComplexClass.generated.js'; +export { compositionDependencies } from './dependenciesAny/dependenciesComposition.generated.js'; +export { concatDependencies } from './dependenciesAny/dependenciesConcat.generated.js'; +export { concatTransformDependencies } from './dependenciesAny/dependenciesConcatTransform.generated.js'; +export { ConditionalNodeDependencies } from './dependenciesAny/dependenciesConditionalNode.generated.js'; +export { conductanceQuantumDependencies } from './dependenciesAny/dependenciesConductanceQuantum.generated.js'; +export { conjDependencies } from './dependenciesAny/dependenciesConj.generated.js'; +export { ConstantNodeDependencies } from './dependenciesAny/dependenciesConstantNode.generated.js'; +export { corrDependencies } from './dependenciesAny/dependenciesCorr.generated.js'; +export { cosDependencies } from './dependenciesAny/dependenciesCos.generated.js'; +export { coshDependencies } from './dependenciesAny/dependenciesCosh.generated.js'; +export { cotDependencies } from './dependenciesAny/dependenciesCot.generated.js'; +export { cothDependencies } from './dependenciesAny/dependenciesCoth.generated.js'; +export { coulombDependencies } from './dependenciesAny/dependenciesCoulomb.generated.js'; +export { countDependencies } from './dependenciesAny/dependenciesCount.generated.js'; +export { createUnitDependencies } from './dependenciesAny/dependenciesCreateUnit.generated.js'; +export { crossDependencies } from './dependenciesAny/dependenciesCross.generated.js'; +export { cscDependencies } from './dependenciesAny/dependenciesCsc.generated.js'; +export { cschDependencies } from './dependenciesAny/dependenciesCsch.generated.js'; +export { ctransposeDependencies } from './dependenciesAny/dependenciesCtranspose.generated.js'; +export { cubeDependencies } from './dependenciesAny/dependenciesCube.generated.js'; +export { cumsumDependencies } from './dependenciesAny/dependenciesCumSum.generated.js'; +export { cumsumTransformDependencies } from './dependenciesAny/dependenciesCumSumTransform.generated.js'; +export { deepEqualDependencies } from './dependenciesAny/dependenciesDeepEqual.generated.js'; +export { DenseMatrixDependencies } from './dependenciesAny/dependenciesDenseMatrixClass.generated.js'; +export { derivativeDependencies } from './dependenciesAny/dependenciesDerivative.generated.js'; +export { detDependencies } from './dependenciesAny/dependenciesDet.generated.js'; +export { deuteronMassDependencies } from './dependenciesAny/dependenciesDeuteronMass.generated.js'; +export { diagDependencies } from './dependenciesAny/dependenciesDiag.generated.js'; +export { diffDependencies } from './dependenciesAny/dependenciesDiff.generated.js'; +export { diffTransformDependencies } from './dependenciesAny/dependenciesDiffTransform.generated.js'; +export { distanceDependencies } from './dependenciesAny/dependenciesDistance.generated.js'; +export { divideDependencies } from './dependenciesAny/dependenciesDivide.generated.js'; +export { divideScalarDependencies } from './dependenciesAny/dependenciesDivideScalar.generated.js'; +export { dotDependencies } from './dependenciesAny/dependenciesDot.generated.js'; +export { dotDivideDependencies } from './dependenciesAny/dependenciesDotDivide.generated.js'; +export { dotMultiplyDependencies } from './dependenciesAny/dependenciesDotMultiply.generated.js'; +export { dotPowDependencies } from './dependenciesAny/dependenciesDotPow.generated.js'; +export { eDependencies } from './dependenciesAny/dependenciesE.generated.js'; +export { efimovFactorDependencies } from './dependenciesAny/dependenciesEfimovFactor.generated.js'; +export { eigsDependencies } from './dependenciesAny/dependenciesEigs.generated.js'; +export { electricConstantDependencies } from './dependenciesAny/dependenciesElectricConstant.generated.js'; +export { electronMassDependencies } from './dependenciesAny/dependenciesElectronMass.generated.js'; +export { elementaryChargeDependencies } from './dependenciesAny/dependenciesElementaryCharge.generated.js'; +export { equalDependencies } from './dependenciesAny/dependenciesEqual.generated.js'; +export { equalScalarDependencies } from './dependenciesAny/dependenciesEqualScalar.generated.js'; +export { equalTextDependencies } from './dependenciesAny/dependenciesEqualText.generated.js'; +export { erfDependencies } from './dependenciesAny/dependenciesErf.generated.js'; +export { evaluateDependencies } from './dependenciesAny/dependenciesEvaluate.generated.js'; +export { expDependencies } from './dependenciesAny/dependenciesExp.generated.js'; +export { expmDependencies } from './dependenciesAny/dependenciesExpm.generated.js'; +export { expm1Dependencies } from './dependenciesAny/dependenciesExpm1.generated.js'; +export { factorialDependencies } from './dependenciesAny/dependenciesFactorial.generated.js'; +export { falseDependencies } from './dependenciesAny/dependenciesFalse.generated.js'; +export { faradayDependencies } from './dependenciesAny/dependenciesFaraday.generated.js'; +export { fermiCouplingDependencies } from './dependenciesAny/dependenciesFermiCoupling.generated.js'; +export { fftDependencies } from './dependenciesAny/dependenciesFft.generated.js'; +export { FibonacciHeapDependencies } from './dependenciesAny/dependenciesFibonacciHeapClass.generated.js'; +export { filterDependencies } from './dependenciesAny/dependenciesFilter.generated.js'; +export { filterTransformDependencies } from './dependenciesAny/dependenciesFilterTransform.generated.js'; +export { fineStructureDependencies } from './dependenciesAny/dependenciesFineStructure.generated.js'; +export { firstRadiationDependencies } from './dependenciesAny/dependenciesFirstRadiation.generated.js'; +export { fixDependencies } from './dependenciesAny/dependenciesFix.generated.js'; +export { flattenDependencies } from './dependenciesAny/dependenciesFlatten.generated.js'; +export { floorDependencies } from './dependenciesAny/dependenciesFloor.generated.js'; +export { forEachDependencies } from './dependenciesAny/dependenciesForEach.generated.js'; +export { forEachTransformDependencies } from './dependenciesAny/dependenciesForEachTransform.generated.js'; +export { formatDependencies } from './dependenciesAny/dependenciesFormat.generated.js'; +export { fractionDependencies } from './dependenciesAny/dependenciesFraction.generated.js'; +export { FractionDependencies } from './dependenciesAny/dependenciesFractionClass.generated.js'; +export { freqzDependencies } from './dependenciesAny/dependenciesFreqz.generated.js'; +export { FunctionAssignmentNodeDependencies } from './dependenciesAny/dependenciesFunctionAssignmentNode.generated.js'; +export { FunctionNodeDependencies } from './dependenciesAny/dependenciesFunctionNode.generated.js'; +export { gammaDependencies } from './dependenciesAny/dependenciesGamma.generated.js'; +export { gasConstantDependencies } from './dependenciesAny/dependenciesGasConstant.generated.js'; +export { gcdDependencies } from './dependenciesAny/dependenciesGcd.generated.js'; +export { getMatrixDataTypeDependencies } from './dependenciesAny/dependenciesGetMatrixDataType.generated.js'; +export { gravitationConstantDependencies } from './dependenciesAny/dependenciesGravitationConstant.generated.js'; +export { gravityDependencies } from './dependenciesAny/dependenciesGravity.generated.js'; +export { hartreeEnergyDependencies } from './dependenciesAny/dependenciesHartreeEnergy.generated.js'; +export { hasNumericValueDependencies } from './dependenciesAny/dependenciesHasNumericValue.generated.js'; +export { helpDependencies } from './dependenciesAny/dependenciesHelp.generated.js'; +export { HelpDependencies } from './dependenciesAny/dependenciesHelpClass.generated.js'; +export { hexDependencies } from './dependenciesAny/dependenciesHex.generated.js'; +export { hypotDependencies } from './dependenciesAny/dependenciesHypot.generated.js'; +export { iDependencies } from './dependenciesAny/dependenciesI.generated.js'; +export { identityDependencies } from './dependenciesAny/dependenciesIdentity.generated.js'; +export { ifftDependencies } from './dependenciesAny/dependenciesIfft.generated.js'; +export { imDependencies } from './dependenciesAny/dependenciesIm.generated.js'; +export { ImmutableDenseMatrixDependencies } from './dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js'; +export { indexDependencies } from './dependenciesAny/dependenciesIndex.generated.js'; +export { IndexDependencies } from './dependenciesAny/dependenciesIndexClass.generated.js'; +export { IndexNodeDependencies } from './dependenciesAny/dependenciesIndexNode.generated.js'; +export { indexTransformDependencies } from './dependenciesAny/dependenciesIndexTransform.generated.js'; +export { InfinityDependencies } from './dependenciesAny/dependenciesInfinity.generated.js'; +export { intersectDependencies } from './dependenciesAny/dependenciesIntersect.generated.js'; +export { invDependencies } from './dependenciesAny/dependenciesInv.generated.js'; +export { inverseConductanceQuantumDependencies } from './dependenciesAny/dependenciesInverseConductanceQuantum.generated.js'; +export { invmodDependencies } from './dependenciesAny/dependenciesInvmod.generated.js'; +export { isIntegerDependencies } from './dependenciesAny/dependenciesIsInteger.generated.js'; +export { isNaNDependencies } from './dependenciesAny/dependenciesIsNaN.generated.js'; +export { isNegativeDependencies } from './dependenciesAny/dependenciesIsNegative.generated.js'; +export { isNumericDependencies } from './dependenciesAny/dependenciesIsNumeric.generated.js'; +export { isPositiveDependencies } from './dependenciesAny/dependenciesIsPositive.generated.js'; +export { isPrimeDependencies } from './dependenciesAny/dependenciesIsPrime.generated.js'; +export { isZeroDependencies } from './dependenciesAny/dependenciesIsZero.generated.js'; +export { kldivergenceDependencies } from './dependenciesAny/dependenciesKldivergence.generated.js'; +export { klitzingDependencies } from './dependenciesAny/dependenciesKlitzing.generated.js'; +export { kronDependencies } from './dependenciesAny/dependenciesKron.generated.js'; +export { LN10Dependencies } from './dependenciesAny/dependenciesLN10.generated.js'; +export { LN2Dependencies } from './dependenciesAny/dependenciesLN2.generated.js'; +export { LOG10EDependencies } from './dependenciesAny/dependenciesLOG10E.generated.js'; +export { LOG2EDependencies } from './dependenciesAny/dependenciesLOG2E.generated.js'; +export { largerDependencies } from './dependenciesAny/dependenciesLarger.generated.js'; +export { largerEqDependencies } from './dependenciesAny/dependenciesLargerEq.generated.js'; +export { lcmDependencies } from './dependenciesAny/dependenciesLcm.generated.js'; +export { leafCountDependencies } from './dependenciesAny/dependenciesLeafCount.generated.js'; +export { leftShiftDependencies } from './dependenciesAny/dependenciesLeftShift.generated.js'; +export { lgammaDependencies } from './dependenciesAny/dependenciesLgamma.generated.js'; +export { logDependencies } from './dependenciesAny/dependenciesLog.generated.js'; +export { log10Dependencies } from './dependenciesAny/dependenciesLog10.generated.js'; +export { log1pDependencies } from './dependenciesAny/dependenciesLog1p.generated.js'; +export { log2Dependencies } from './dependenciesAny/dependenciesLog2.generated.js'; +export { loschmidtDependencies } from './dependenciesAny/dependenciesLoschmidt.generated.js'; +export { lsolveDependencies } from './dependenciesAny/dependenciesLsolve.generated.js'; +export { lsolveAllDependencies } from './dependenciesAny/dependenciesLsolveAll.generated.js'; +export { lupDependencies } from './dependenciesAny/dependenciesLup.generated.js'; +export { lusolveDependencies } from './dependenciesAny/dependenciesLusolve.generated.js'; +export { lyapDependencies } from './dependenciesAny/dependenciesLyap.generated.js'; +export { madDependencies } from './dependenciesAny/dependenciesMad.generated.js'; +export { magneticConstantDependencies } from './dependenciesAny/dependenciesMagneticConstant.generated.js'; +export { magneticFluxQuantumDependencies } from './dependenciesAny/dependenciesMagneticFluxQuantum.generated.js'; +export { mapDependencies } from './dependenciesAny/dependenciesMap.generated.js'; +export { mapTransformDependencies } from './dependenciesAny/dependenciesMapTransform.generated.js'; +export { matrixDependencies } from './dependenciesAny/dependenciesMatrix.generated.js'; +export { MatrixDependencies } from './dependenciesAny/dependenciesMatrixClass.generated.js'; +export { matrixFromColumnsDependencies } from './dependenciesAny/dependenciesMatrixFromColumns.generated.js'; +export { matrixFromFunctionDependencies } from './dependenciesAny/dependenciesMatrixFromFunction.generated.js'; +export { matrixFromRowsDependencies } from './dependenciesAny/dependenciesMatrixFromRows.generated.js'; +export { maxDependencies } from './dependenciesAny/dependenciesMax.generated.js'; +export { maxTransformDependencies } from './dependenciesAny/dependenciesMaxTransform.generated.js'; +export { meanDependencies } from './dependenciesAny/dependenciesMean.generated.js'; +export { meanTransformDependencies } from './dependenciesAny/dependenciesMeanTransform.generated.js'; +export { medianDependencies } from './dependenciesAny/dependenciesMedian.generated.js'; +export { minDependencies } from './dependenciesAny/dependenciesMin.generated.js'; +export { minTransformDependencies } from './dependenciesAny/dependenciesMinTransform.generated.js'; +export { modDependencies } from './dependenciesAny/dependenciesMod.generated.js'; +export { modeDependencies } from './dependenciesAny/dependenciesMode.generated.js'; +export { molarMassDependencies } from './dependenciesAny/dependenciesMolarMass.generated.js'; +export { molarMassC12Dependencies } from './dependenciesAny/dependenciesMolarMassC12.generated.js'; +export { molarPlanckConstantDependencies } from './dependenciesAny/dependenciesMolarPlanckConstant.generated.js'; +export { molarVolumeDependencies } from './dependenciesAny/dependenciesMolarVolume.generated.js'; +export { multinomialDependencies } from './dependenciesAny/dependenciesMultinomial.generated.js'; +export { multiplyDependencies } from './dependenciesAny/dependenciesMultiply.generated.js'; +export { multiplyScalarDependencies } from './dependenciesAny/dependenciesMultiplyScalar.generated.js'; +export { NaNDependencies } from './dependenciesAny/dependenciesNaN.generated.js'; +export { neutronMassDependencies } from './dependenciesAny/dependenciesNeutronMass.generated.js'; +export { NodeDependencies } from './dependenciesAny/dependenciesNode.generated.js'; +export { normDependencies } from './dependenciesAny/dependenciesNorm.generated.js'; +export { notDependencies } from './dependenciesAny/dependenciesNot.generated.js'; +export { nthRootDependencies } from './dependenciesAny/dependenciesNthRoot.generated.js'; +export { nthRootsDependencies } from './dependenciesAny/dependenciesNthRoots.generated.js'; +export { nuclearMagnetonDependencies } from './dependenciesAny/dependenciesNuclearMagneton.generated.js'; +export { nullDependencies } from './dependenciesAny/dependenciesNull.generated.js'; +export { numberDependencies } from './dependenciesAny/dependenciesNumber.generated.js'; +export { numericDependencies } from './dependenciesAny/dependenciesNumeric.generated.js'; +export { ObjectNodeDependencies } from './dependenciesAny/dependenciesObjectNode.generated.js'; +export { octDependencies } from './dependenciesAny/dependenciesOct.generated.js'; +export { onesDependencies } from './dependenciesAny/dependenciesOnes.generated.js'; +export { OperatorNodeDependencies } from './dependenciesAny/dependenciesOperatorNode.generated.js'; +export { orDependencies } from './dependenciesAny/dependenciesOr.generated.js'; +export { orTransformDependencies } from './dependenciesAny/dependenciesOrTransform.generated.js'; +export { ParenthesisNodeDependencies } from './dependenciesAny/dependenciesParenthesisNode.generated.js'; +export { parseDependencies } from './dependenciesAny/dependenciesParse.generated.js'; +export { parserDependencies } from './dependenciesAny/dependenciesParser.generated.js'; +export { ParserDependencies } from './dependenciesAny/dependenciesParserClass.generated.js'; +export { partitionSelectDependencies } from './dependenciesAny/dependenciesPartitionSelect.generated.js'; +export { permutationsDependencies } from './dependenciesAny/dependenciesPermutations.generated.js'; +export { phiDependencies } from './dependenciesAny/dependenciesPhi.generated.js'; +export { piDependencies } from './dependenciesAny/dependenciesPi.generated.js'; +export { pickRandomDependencies } from './dependenciesAny/dependenciesPickRandom.generated.js'; +export { pinvDependencies } from './dependenciesAny/dependenciesPinv.generated.js'; +export { planckChargeDependencies } from './dependenciesAny/dependenciesPlanckCharge.generated.js'; +export { planckConstantDependencies } from './dependenciesAny/dependenciesPlanckConstant.generated.js'; +export { planckLengthDependencies } from './dependenciesAny/dependenciesPlanckLength.generated.js'; +export { planckMassDependencies } from './dependenciesAny/dependenciesPlanckMass.generated.js'; +export { planckTemperatureDependencies } from './dependenciesAny/dependenciesPlanckTemperature.generated.js'; +export { planckTimeDependencies } from './dependenciesAny/dependenciesPlanckTime.generated.js'; +export { polynomialRootDependencies } from './dependenciesAny/dependenciesPolynomialRoot.generated.js'; +export { powDependencies } from './dependenciesAny/dependenciesPow.generated.js'; +export { printDependencies } from './dependenciesAny/dependenciesPrint.generated.js'; +export { printTransformDependencies } from './dependenciesAny/dependenciesPrintTransform.generated.js'; +export { prodDependencies } from './dependenciesAny/dependenciesProd.generated.js'; +export { protonMassDependencies } from './dependenciesAny/dependenciesProtonMass.generated.js'; +export { qrDependencies } from './dependenciesAny/dependenciesQr.generated.js'; +export { quantileSeqDependencies } from './dependenciesAny/dependenciesQuantileSeq.generated.js'; +export { quantileSeqTransformDependencies } from './dependenciesAny/dependenciesQuantileSeqTransform.generated.js'; +export { quantumOfCirculationDependencies } from './dependenciesAny/dependenciesQuantumOfCirculation.generated.js'; +export { randomDependencies } from './dependenciesAny/dependenciesRandom.generated.js'; +export { randomIntDependencies } from './dependenciesAny/dependenciesRandomInt.generated.js'; +export { rangeDependencies } from './dependenciesAny/dependenciesRange.generated.js'; +export { RangeDependencies } from './dependenciesAny/dependenciesRangeClass.generated.js'; +export { RangeNodeDependencies } from './dependenciesAny/dependenciesRangeNode.generated.js'; +export { rangeTransformDependencies } from './dependenciesAny/dependenciesRangeTransform.generated.js'; +export { rationalizeDependencies } from './dependenciesAny/dependenciesRationalize.generated.js'; +export { reDependencies } from './dependenciesAny/dependenciesRe.generated.js'; +export { reducedPlanckConstantDependencies } from './dependenciesAny/dependenciesReducedPlanckConstant.generated.js'; +export { RelationalNodeDependencies } from './dependenciesAny/dependenciesRelationalNode.generated.js'; +export { replacerDependencies } from './dependenciesAny/dependenciesReplacer.generated.js'; +export { reshapeDependencies } from './dependenciesAny/dependenciesReshape.generated.js'; +export { resizeDependencies } from './dependenciesAny/dependenciesResize.generated.js'; +export { resolveDependencies } from './dependenciesAny/dependenciesResolve.generated.js'; +export { ResultSetDependencies } from './dependenciesAny/dependenciesResultSet.generated.js'; +export { reviverDependencies } from './dependenciesAny/dependenciesReviver.generated.js'; +export { rightArithShiftDependencies } from './dependenciesAny/dependenciesRightArithShift.generated.js'; +export { rightLogShiftDependencies } from './dependenciesAny/dependenciesRightLogShift.generated.js'; +export { rotateDependencies } from './dependenciesAny/dependenciesRotate.generated.js'; +export { rotationMatrixDependencies } from './dependenciesAny/dependenciesRotationMatrix.generated.js'; +export { roundDependencies } from './dependenciesAny/dependenciesRound.generated.js'; +export { rowDependencies } from './dependenciesAny/dependenciesRow.generated.js'; +export { rowTransformDependencies } from './dependenciesAny/dependenciesRowTransform.generated.js'; +export { rydbergDependencies } from './dependenciesAny/dependenciesRydberg.generated.js'; +export { SQRT1_2Dependencies } from './dependenciesAny/dependenciesSQRT1_2.generated.js'; // eslint-disable-line camelcase +export { SQRT2Dependencies } from './dependenciesAny/dependenciesSQRT2.generated.js'; +export { sackurTetrodeDependencies } from './dependenciesAny/dependenciesSackurTetrode.generated.js'; +export { schurDependencies } from './dependenciesAny/dependenciesSchur.generated.js'; +export { secDependencies } from './dependenciesAny/dependenciesSec.generated.js'; +export { sechDependencies } from './dependenciesAny/dependenciesSech.generated.js'; +export { secondRadiationDependencies } from './dependenciesAny/dependenciesSecondRadiation.generated.js'; +export { setCartesianDependencies } from './dependenciesAny/dependenciesSetCartesian.generated.js'; +export { setDifferenceDependencies } from './dependenciesAny/dependenciesSetDifference.generated.js'; +export { setDistinctDependencies } from './dependenciesAny/dependenciesSetDistinct.generated.js'; +export { setIntersectDependencies } from './dependenciesAny/dependenciesSetIntersect.generated.js'; +export { setIsSubsetDependencies } from './dependenciesAny/dependenciesSetIsSubset.generated.js'; +export { setMultiplicityDependencies } from './dependenciesAny/dependenciesSetMultiplicity.generated.js'; +export { setPowersetDependencies } from './dependenciesAny/dependenciesSetPowerset.generated.js'; +export { setSizeDependencies } from './dependenciesAny/dependenciesSetSize.generated.js'; +export { setSymDifferenceDependencies } from './dependenciesAny/dependenciesSetSymDifference.generated.js'; +export { setUnionDependencies } from './dependenciesAny/dependenciesSetUnion.generated.js'; +export { signDependencies } from './dependenciesAny/dependenciesSign.generated.js'; +export { simplifyDependencies } from './dependenciesAny/dependenciesSimplify.generated.js'; +export { simplifyConstantDependencies } from './dependenciesAny/dependenciesSimplifyConstant.generated.js'; +export { simplifyCoreDependencies } from './dependenciesAny/dependenciesSimplifyCore.generated.js'; +export { sinDependencies } from './dependenciesAny/dependenciesSin.generated.js'; +export { sinhDependencies } from './dependenciesAny/dependenciesSinh.generated.js'; +export { sizeDependencies } from './dependenciesAny/dependenciesSize.generated.js'; +export { sluDependencies } from './dependenciesAny/dependenciesSlu.generated.js'; +export { smallerDependencies } from './dependenciesAny/dependenciesSmaller.generated.js'; +export { smallerEqDependencies } from './dependenciesAny/dependenciesSmallerEq.generated.js'; +export { solveODEDependencies } from './dependenciesAny/dependenciesSolveODE.generated.js'; +export { sortDependencies } from './dependenciesAny/dependenciesSort.generated.js'; +export { SpaDependencies } from './dependenciesAny/dependenciesSpaClass.generated.js'; +export { sparseDependencies } from './dependenciesAny/dependenciesSparse.generated.js'; +export { SparseMatrixDependencies } from './dependenciesAny/dependenciesSparseMatrixClass.generated.js'; +export { speedOfLightDependencies } from './dependenciesAny/dependenciesSpeedOfLight.generated.js'; +export { splitUnitDependencies } from './dependenciesAny/dependenciesSplitUnit.generated.js'; +export { sqrtDependencies } from './dependenciesAny/dependenciesSqrt.generated.js'; +export { sqrtmDependencies } from './dependenciesAny/dependenciesSqrtm.generated.js'; +export { squareDependencies } from './dependenciesAny/dependenciesSquare.generated.js'; +export { squeezeDependencies } from './dependenciesAny/dependenciesSqueeze.generated.js'; +export { stdDependencies } from './dependenciesAny/dependenciesStd.generated.js'; +export { stdTransformDependencies } from './dependenciesAny/dependenciesStdTransform.generated.js'; +export { stefanBoltzmannDependencies } from './dependenciesAny/dependenciesStefanBoltzmann.generated.js'; +export { stirlingS2Dependencies } from './dependenciesAny/dependenciesStirlingS2.generated.js'; +export { stringDependencies } from './dependenciesAny/dependenciesString.generated.js'; +export { subsetDependencies } from './dependenciesAny/dependenciesSubset.generated.js'; +export { subsetTransformDependencies } from './dependenciesAny/dependenciesSubsetTransform.generated.js'; +export { subtractDependencies } from './dependenciesAny/dependenciesSubtract.generated.js'; +export { subtractScalarDependencies } from './dependenciesAny/dependenciesSubtractScalar.generated.js'; +export { sumDependencies } from './dependenciesAny/dependenciesSum.generated.js'; +export { sumTransformDependencies } from './dependenciesAny/dependenciesSumTransform.generated.js'; +export { sylvesterDependencies } from './dependenciesAny/dependenciesSylvester.generated.js'; +export { SymbolNodeDependencies } from './dependenciesAny/dependenciesSymbolNode.generated.js'; +export { symbolicEqualDependencies } from './dependenciesAny/dependenciesSymbolicEqual.generated.js'; +export { tanDependencies } from './dependenciesAny/dependenciesTan.generated.js'; +export { tanhDependencies } from './dependenciesAny/dependenciesTanh.generated.js'; +export { tauDependencies } from './dependenciesAny/dependenciesTau.generated.js'; +export { thomsonCrossSectionDependencies } from './dependenciesAny/dependenciesThomsonCrossSection.generated.js'; +export { toDependencies } from './dependenciesAny/dependenciesTo.generated.js'; +export { traceDependencies } from './dependenciesAny/dependenciesTrace.generated.js'; +export { transposeDependencies } from './dependenciesAny/dependenciesTranspose.generated.js'; +export { trueDependencies } from './dependenciesAny/dependenciesTrue.generated.js'; +export { typeOfDependencies } from './dependenciesAny/dependenciesTypeOf.generated.js'; +export { typedDependencies } from './dependenciesAny/dependenciesTyped.generated.js'; +export { unaryMinusDependencies } from './dependenciesAny/dependenciesUnaryMinus.generated.js'; +export { unaryPlusDependencies } from './dependenciesAny/dependenciesUnaryPlus.generated.js'; +export { unequalDependencies } from './dependenciesAny/dependenciesUnequal.generated.js'; +export { UnitDependencies } from './dependenciesAny/dependenciesUnitClass.generated.js'; +export { unitDependencies } from './dependenciesAny/dependenciesUnitFunction.generated.js'; +export { EDependencies } from './dependenciesAny/dependenciesUppercaseE.generated.js'; +export { PIDependencies } from './dependenciesAny/dependenciesUppercasePi.generated.js'; +export { usolveDependencies } from './dependenciesAny/dependenciesUsolve.generated.js'; +export { usolveAllDependencies } from './dependenciesAny/dependenciesUsolveAll.generated.js'; +export { vacuumImpedanceDependencies } from './dependenciesAny/dependenciesVacuumImpedance.generated.js'; +export { varianceDependencies } from './dependenciesAny/dependenciesVariance.generated.js'; +export { varianceTransformDependencies } from './dependenciesAny/dependenciesVarianceTransform.generated.js'; +export { versionDependencies } from './dependenciesAny/dependenciesVersion.generated.js'; +export { weakMixingAngleDependencies } from './dependenciesAny/dependenciesWeakMixingAngle.generated.js'; +export { wienDisplacementDependencies } from './dependenciesAny/dependenciesWienDisplacement.generated.js'; +export { xgcdDependencies } from './dependenciesAny/dependenciesXgcd.generated.js'; +export { xorDependencies } from './dependenciesAny/dependenciesXor.generated.js'; +export { zerosDependencies } from './dependenciesAny/dependenciesZeros.generated.js'; +export { zetaDependencies } from './dependenciesAny/dependenciesZeta.generated.js'; +export { zpk2tfDependencies } from './dependenciesAny/dependenciesZpk2tf.generated.js'; +export { all } from './allFactoriesAny.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAbs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAbs.generated.js new file mode 100644 index 0000000..fd8dd2f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAbs.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAbs } from '../../factoriesAny.js'; +export var absDependencies = { + typedDependencies, + createAbs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAccessorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAccessorNode.generated.js new file mode 100644 index 0000000..08601f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAccessorNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { createAccessorNode } from '../../factoriesAny.js'; +export var AccessorNodeDependencies = { + NodeDependencies, + subsetDependencies, + createAccessorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcos.generated.js new file mode 100644 index 0000000..a88d60d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcos.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcos } from '../../factoriesAny.js'; +export var acosDependencies = { + ComplexDependencies, + typedDependencies, + createAcos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcosh.generated.js new file mode 100644 index 0000000..f5ff7aa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcosh.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcosh } from '../../factoriesAny.js'; +export var acoshDependencies = { + ComplexDependencies, + typedDependencies, + createAcosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcot.generated.js new file mode 100644 index 0000000..178f6a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcot.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcot } from '../../factoriesAny.js'; +export var acotDependencies = { + BigNumberDependencies, + typedDependencies, + createAcot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcoth.generated.js new file mode 100644 index 0000000..0bc9997 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcoth.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcoth } from '../../factoriesAny.js'; +export var acothDependencies = { + BigNumberDependencies, + ComplexDependencies, + typedDependencies, + createAcoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsc.generated.js new file mode 100644 index 0000000..cc075d4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsc.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcsc } from '../../factoriesAny.js'; +export var acscDependencies = { + BigNumberDependencies, + ComplexDependencies, + typedDependencies, + createAcsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsch.generated.js new file mode 100644 index 0000000..197e00b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAcsch.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcsch } from '../../factoriesAny.js'; +export var acschDependencies = { + BigNumberDependencies, + typedDependencies, + createAcsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAdd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAdd.generated.js new file mode 100644 index 0000000..2806c0f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAdd.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAdd } from '../../factoriesAny.js'; +export var addDependencies = { + DenseMatrixDependencies, + SparseMatrixDependencies, + addScalarDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createAdd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAddScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAddScalar.generated.js new file mode 100644 index 0000000..d1cb442 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAddScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAddScalar } from '../../factoriesAny.js'; +export var addScalarDependencies = { + typedDependencies, + createAddScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAnd.generated.js new file mode 100644 index 0000000..acc9883 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAnd.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { notDependencies } from './dependenciesNot.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createAnd } from '../../factoriesAny.js'; +export var andDependencies = { + concatDependencies, + equalScalarDependencies, + matrixDependencies, + notDependencies, + typedDependencies, + zerosDependencies, + createAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAndTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAndTransform.generated.js new file mode 100644 index 0000000..d22c0cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAndTransform.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { notDependencies } from './dependenciesNot.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createAndTransform } from '../../factoriesAny.js'; +export var andTransformDependencies = { + addDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + notDependencies, + typedDependencies, + zerosDependencies, + createAndTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApply.generated.js new file mode 100644 index 0000000..46e5c78 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApply.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createApply } from '../../factoriesAny.js'; +export var applyDependencies = { + isIntegerDependencies, + typedDependencies, + createApply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApplyTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApplyTransform.generated.js new file mode 100644 index 0000000..c642ad4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesApplyTransform.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createApplyTransform } from '../../factoriesAny.js'; +export var applyTransformDependencies = { + isIntegerDependencies, + typedDependencies, + createApplyTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArg.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArg.generated.js new file mode 100644 index 0000000..6181dfe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArg.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createArg } from '../../factoriesAny.js'; +export var argDependencies = { + typedDependencies, + createArg +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArrayNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArrayNode.generated.js new file mode 100644 index 0000000..66403fd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesArrayNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createArrayNode } from '../../factoriesAny.js'; +export var ArrayNodeDependencies = { + NodeDependencies, + createArrayNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsec.generated.js new file mode 100644 index 0000000..3173050 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsec.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsec } from '../../factoriesAny.js'; +export var asecDependencies = { + BigNumberDependencies, + ComplexDependencies, + typedDependencies, + createAsec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsech.generated.js new file mode 100644 index 0000000..d061320 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsech.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsech } from '../../factoriesAny.js'; +export var asechDependencies = { + BigNumberDependencies, + ComplexDependencies, + typedDependencies, + createAsech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsin.generated.js new file mode 100644 index 0000000..1367635 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsin.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsin } from '../../factoriesAny.js'; +export var asinDependencies = { + ComplexDependencies, + typedDependencies, + createAsin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsinh.generated.js new file mode 100644 index 0000000..bcce057 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAsinh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsinh } from '../../factoriesAny.js'; +export var asinhDependencies = { + typedDependencies, + createAsinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAssignmentNode.generated.js new file mode 100644 index 0000000..28d47d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAssignmentNode.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { createAssignmentNode } from '../../factoriesAny.js'; +export var AssignmentNodeDependencies = { + matrixDependencies, + NodeDependencies, + subsetDependencies, + createAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan.generated.js new file mode 100644 index 0000000..b9b5fcc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtan } from '../../factoriesAny.js'; +export var atanDependencies = { + typedDependencies, + createAtan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan2.generated.js new file mode 100644 index 0000000..9071251 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtan2.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtan2 } from '../../factoriesAny.js'; +export var atan2Dependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createAtan2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtanh.generated.js new file mode 100644 index 0000000..ab877f5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtanh.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtanh } from '../../factoriesAny.js'; +export var atanhDependencies = { + ComplexDependencies, + typedDependencies, + createAtanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtomicMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtomicMass.generated.js new file mode 100644 index 0000000..84ad047 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAtomicMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createAtomicMass } from '../../factoriesAny.js'; +export var atomicMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createAtomicMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAvogadro.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAvogadro.generated.js new file mode 100644 index 0000000..f2339b0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesAvogadro.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createAvogadro } from '../../factoriesAny.js'; +export var avogadroDependencies = { + BigNumberDependencies, + UnitDependencies, + createAvogadro +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBellNumbers.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBellNumbers.generated.js new file mode 100644 index 0000000..369a7f0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBellNumbers.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { stirlingS2Dependencies } from './dependenciesStirlingS2.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBellNumbers } from '../../factoriesAny.js'; +export var bellNumbersDependencies = { + addScalarDependencies, + isIntegerDependencies, + isNegativeDependencies, + stirlingS2Dependencies, + typedDependencies, + createBellNumbers +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigNumberClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigNumberClass.generated.js new file mode 100644 index 0000000..fcc8438 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigNumberClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createBigNumberClass } from '../../factoriesAny.js'; +export var BigNumberDependencies = { + createBigNumberClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigint.generated.js new file mode 100644 index 0000000..a67aeea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBigint.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBigint } from '../../factoriesAny.js'; +export var bigintDependencies = { + typedDependencies, + createBigint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBignumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBignumber.generated.js new file mode 100644 index 0000000..e9aabaf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBignumber.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBignumber } from '../../factoriesAny.js'; +export var bignumberDependencies = { + BigNumberDependencies, + typedDependencies, + createBignumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBin.generated.js new file mode 100644 index 0000000..37befba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBin.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { formatDependencies } from './dependenciesFormat.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBin } from '../../factoriesAny.js'; +export var binDependencies = { + formatDependencies, + typedDependencies, + createBin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAnd.generated.js new file mode 100644 index 0000000..d248298 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAnd.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitAnd } from '../../factoriesAny.js'; +export var bitAndDependencies = { + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createBitAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAndTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAndTransform.generated.js new file mode 100644 index 0000000..a5f0274 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitAndTransform.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { notDependencies } from './dependenciesNot.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createBitAndTransform } from '../../factoriesAny.js'; +export var bitAndTransformDependencies = { + addDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + notDependencies, + typedDependencies, + zerosDependencies, + createBitAndTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitNot.generated.js new file mode 100644 index 0000000..f4ecf43 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitNot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitNot } from '../../factoriesAny.js'; +export var bitNotDependencies = { + typedDependencies, + createBitNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOr.generated.js new file mode 100644 index 0000000..d24033d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOr.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitOr } from '../../factoriesAny.js'; +export var bitOrDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createBitOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOrTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOrTransform.generated.js new file mode 100644 index 0000000..075aaf6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitOrTransform.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitOrTransform } from '../../factoriesAny.js'; +export var bitOrTransformDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createBitOrTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitXor.generated.js new file mode 100644 index 0000000..7d46ab7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBitXor.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitXor } from '../../factoriesAny.js'; +export var bitXorDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createBitXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBlockNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBlockNode.generated.js new file mode 100644 index 0000000..d55f841 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBlockNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { ResultSetDependencies } from './dependenciesResultSet.generated.js'; +import { createBlockNode } from '../../factoriesAny.js'; +export var BlockNodeDependencies = { + NodeDependencies, + ResultSetDependencies, + createBlockNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrMagneton.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrMagneton.generated.js new file mode 100644 index 0000000..fd4895f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrMagneton.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createBohrMagneton } from '../../factoriesAny.js'; +export var bohrMagnetonDependencies = { + BigNumberDependencies, + UnitDependencies, + createBohrMagneton +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrRadius.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrRadius.generated.js new file mode 100644 index 0000000..aea8671 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBohrRadius.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createBohrRadius } from '../../factoriesAny.js'; +export var bohrRadiusDependencies = { + BigNumberDependencies, + UnitDependencies, + createBohrRadius +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoltzmann.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoltzmann.generated.js new file mode 100644 index 0000000..3ce13ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoltzmann.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createBoltzmann } from '../../factoriesAny.js'; +export var boltzmannDependencies = { + BigNumberDependencies, + UnitDependencies, + createBoltzmann +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoolean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoolean.generated.js new file mode 100644 index 0000000..61e5c46 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesBoolean.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBoolean } from '../../factoriesAny.js'; +export var booleanDependencies = { + typedDependencies, + createBoolean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCatalan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCatalan.generated.js new file mode 100644 index 0000000..06264f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCatalan.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCatalan } from '../../factoriesAny.js'; +export var catalanDependencies = { + addScalarDependencies, + combinationsDependencies, + divideScalarDependencies, + isIntegerDependencies, + isNegativeDependencies, + multiplyScalarDependencies, + typedDependencies, + createCatalan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCbrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCbrt.generated.js new file mode 100644 index 0000000..051d9c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCbrt.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createCbrt } from '../../factoriesAny.js'; +export var cbrtDependencies = { + BigNumberDependencies, + ComplexDependencies, + FractionDependencies, + isNegativeDependencies, + matrixDependencies, + typedDependencies, + unaryMinusDependencies, + createCbrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCeil.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCeil.generated.js new file mode 100644 index 0000000..fa6d3b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCeil.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createCeil } from '../../factoriesAny.js'; +export var ceilDependencies = { + DenseMatrixDependencies, + equalScalarDependencies, + matrixDependencies, + roundDependencies, + typedDependencies, + zerosDependencies, + createCeil +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChain.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChain.generated.js new file mode 100644 index 0000000..8d9e793 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChain.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ChainDependencies } from './dependenciesChainClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createChain } from '../../factoriesAny.js'; +export var chainDependencies = { + ChainDependencies, + typedDependencies, + createChain +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChainClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChainClass.generated.js new file mode 100644 index 0000000..19a1f4b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesChainClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createChainClass } from '../../factoriesAny.js'; +export var ChainDependencies = { + typedDependencies, + createChainClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js new file mode 100644 index 0000000..2de8c67 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createClassicalElectronRadius } from '../../factoriesAny.js'; +export var classicalElectronRadiusDependencies = { + BigNumberDependencies, + UnitDependencies, + createClassicalElectronRadius +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClone.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClone.generated.js new file mode 100644 index 0000000..2e9077b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesClone.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createClone } from '../../factoriesAny.js'; +export var cloneDependencies = { + typedDependencies, + createClone +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumn.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumn.generated.js new file mode 100644 index 0000000..61447d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumn.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { rangeDependencies } from './dependenciesRange.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createColumn } from '../../factoriesAny.js'; +export var columnDependencies = { + IndexDependencies, + matrixDependencies, + rangeDependencies, + typedDependencies, + createColumn +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumnTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumnTransform.generated.js new file mode 100644 index 0000000..d6bc3ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesColumnTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { rangeDependencies } from './dependenciesRange.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createColumnTransform } from '../../factoriesAny.js'; +export var columnTransformDependencies = { + IndexDependencies, + matrixDependencies, + rangeDependencies, + typedDependencies, + createColumnTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinations.generated.js new file mode 100644 index 0000000..926c7cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinations.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCombinations } from '../../factoriesAny.js'; +export var combinationsDependencies = { + typedDependencies, + createCombinations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js new file mode 100644 index 0000000..271eeaf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCombinationsWithRep } from '../../factoriesAny.js'; +export var combinationsWithRepDependencies = { + typedDependencies, + createCombinationsWithRep +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompare.generated.js new file mode 100644 index 0000000..f8acf75 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompare.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompare } from '../../factoriesAny.js'; +export var compareDependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + FractionDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createCompare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareNatural.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareNatural.generated.js new file mode 100644 index 0000000..8ecb045 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareNatural.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompareNatural } from '../../factoriesAny.js'; +export var compareNaturalDependencies = { + compareDependencies, + typedDependencies, + createCompareNatural +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareText.generated.js new file mode 100644 index 0000000..b01987f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompareText.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompareText } from '../../factoriesAny.js'; +export var compareTextDependencies = { + concatDependencies, + matrixDependencies, + typedDependencies, + createCompareText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompile.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompile.generated.js new file mode 100644 index 0000000..c4e6841 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCompile.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompile } from '../../factoriesAny.js'; +export var compileDependencies = { + parseDependencies, + typedDependencies, + createCompile +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplex.generated.js new file mode 100644 index 0000000..42e2055 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplex.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createComplex } from '../../factoriesAny.js'; +export var complexDependencies = { + ComplexDependencies, + typedDependencies, + createComplex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplexClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplexClass.generated.js new file mode 100644 index 0000000..abd54d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComplexClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createComplexClass } from '../../factoriesAny.js'; +export var ComplexDependencies = { + createComplexClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComposition.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComposition.generated.js new file mode 100644 index 0000000..c585659 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesComposition.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createComposition } from '../../factoriesAny.js'; +export var compositionDependencies = { + addScalarDependencies, + combinationsDependencies, + isIntegerDependencies, + isNegativeDependencies, + isPositiveDependencies, + largerDependencies, + typedDependencies, + createComposition +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcat.generated.js new file mode 100644 index 0000000..9a9956c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcat.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createConcat } from '../../factoriesAny.js'; +export var concatDependencies = { + isIntegerDependencies, + matrixDependencies, + typedDependencies, + createConcat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcatTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcatTransform.generated.js new file mode 100644 index 0000000..11baf40 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConcatTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createConcatTransform } from '../../factoriesAny.js'; +export var concatTransformDependencies = { + isIntegerDependencies, + matrixDependencies, + typedDependencies, + createConcatTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConditionalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConditionalNode.generated.js new file mode 100644 index 0000000..8001ce1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConditionalNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createConditionalNode } from '../../factoriesAny.js'; +export var ConditionalNodeDependencies = { + NodeDependencies, + createConditionalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js new file mode 100644 index 0000000..61ef521 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createConductanceQuantum } from '../../factoriesAny.js'; +export var conductanceQuantumDependencies = { + BigNumberDependencies, + UnitDependencies, + createConductanceQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConj.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConj.generated.js new file mode 100644 index 0000000..4d698d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConj.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createConj } from '../../factoriesAny.js'; +export var conjDependencies = { + typedDependencies, + createConj +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConstantNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConstantNode.generated.js new file mode 100644 index 0000000..338fde0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesConstantNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createConstantNode } from '../../factoriesAny.js'; +export var ConstantNodeDependencies = { + NodeDependencies, + createConstantNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCorr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCorr.generated.js new file mode 100644 index 0000000..ffe2fd1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCorr.generated.js @@ -0,0 +1,28 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { meanDependencies } from './dependenciesMean.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { sumDependencies } from './dependenciesSum.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCorr } from '../../factoriesAny.js'; +export var corrDependencies = { + addDependencies, + divideDependencies, + matrixDependencies, + meanDependencies, + multiplyDependencies, + powDependencies, + sqrtDependencies, + subtractDependencies, + sumDependencies, + typedDependencies, + createCorr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCos.generated.js new file mode 100644 index 0000000..ee553b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCos.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCos } from '../../factoriesAny.js'; +export var cosDependencies = { + typedDependencies, + createCos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCosh.generated.js new file mode 100644 index 0000000..4c352e8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCosh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCosh } from '../../factoriesAny.js'; +export var coshDependencies = { + typedDependencies, + createCosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCot.generated.js new file mode 100644 index 0000000..478e8c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCot.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCot } from '../../factoriesAny.js'; +export var cotDependencies = { + BigNumberDependencies, + typedDependencies, + createCot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoth.generated.js new file mode 100644 index 0000000..62f4381 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoth.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCoth } from '../../factoriesAny.js'; +export var cothDependencies = { + BigNumberDependencies, + typedDependencies, + createCoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoulomb.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoulomb.generated.js new file mode 100644 index 0000000..59be861 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCoulomb.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createCoulomb } from '../../factoriesAny.js'; +export var coulombDependencies = { + BigNumberDependencies, + UnitDependencies, + createCoulomb +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCount.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCount.generated.js new file mode 100644 index 0000000..40d37b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCount.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { prodDependencies } from './dependenciesProd.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCount } from '../../factoriesAny.js'; +export var countDependencies = { + prodDependencies, + sizeDependencies, + typedDependencies, + createCount +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCreateUnit.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCreateUnit.generated.js new file mode 100644 index 0000000..cdfe9d8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCreateUnit.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCreateUnit } from '../../factoriesAny.js'; +export var createUnitDependencies = { + UnitDependencies, + typedDependencies, + createCreateUnit +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCross.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCross.generated.js new file mode 100644 index 0000000..91b7ad4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCross.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCross } from '../../factoriesAny.js'; +export var crossDependencies = { + matrixDependencies, + multiplyDependencies, + subtractDependencies, + typedDependencies, + createCross +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsc.generated.js new file mode 100644 index 0000000..5cc6190 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsc.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCsc } from '../../factoriesAny.js'; +export var cscDependencies = { + BigNumberDependencies, + typedDependencies, + createCsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsch.generated.js new file mode 100644 index 0000000..5ce6e0b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCsch.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCsch } from '../../factoriesAny.js'; +export var cschDependencies = { + BigNumberDependencies, + typedDependencies, + createCsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCtranspose.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCtranspose.generated.js new file mode 100644 index 0000000..4d0cec5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCtranspose.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { conjDependencies } from './dependenciesConj.generated.js'; +import { transposeDependencies } from './dependenciesTranspose.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCtranspose } from '../../factoriesAny.js'; +export var ctransposeDependencies = { + conjDependencies, + transposeDependencies, + typedDependencies, + createCtranspose +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCube.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCube.generated.js new file mode 100644 index 0000000..f42092f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCube.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCube } from '../../factoriesAny.js'; +export var cubeDependencies = { + typedDependencies, + createCube +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSum.generated.js new file mode 100644 index 0000000..05941ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSum.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryPlusDependencies } from './dependenciesUnaryPlus.generated.js'; +import { createCumSum } from '../../factoriesAny.js'; +export var cumsumDependencies = { + addDependencies, + typedDependencies, + unaryPlusDependencies, + createCumSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSumTransform.generated.js new file mode 100644 index 0000000..fef6c6e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesCumSumTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryPlusDependencies } from './dependenciesUnaryPlus.generated.js'; +import { createCumSumTransform } from '../../factoriesAny.js'; +export var cumsumTransformDependencies = { + addDependencies, + typedDependencies, + unaryPlusDependencies, + createCumSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeepEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeepEqual.generated.js new file mode 100644 index 0000000..94eb7b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeepEqual.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDeepEqual } from '../../factoriesAny.js'; +export var deepEqualDependencies = { + equalDependencies, + typedDependencies, + createDeepEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js new file mode 100644 index 0000000..bad8bd2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { MatrixDependencies } from './dependenciesMatrixClass.generated.js'; +import { createDenseMatrixClass } from '../../factoriesAny.js'; +export var DenseMatrixDependencies = { + MatrixDependencies, + createDenseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDerivative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDerivative.generated.js new file mode 100644 index 0000000..3ac3894 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDerivative.generated.js @@ -0,0 +1,30 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { simplifyDependencies } from './dependenciesSimplify.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDerivative } from '../../factoriesAny.js'; +export var derivativeDependencies = { + ConstantNodeDependencies, + FunctionNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + equalDependencies, + isZeroDependencies, + numericDependencies, + parseDependencies, + simplifyDependencies, + typedDependencies, + createDerivative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDet.generated.js new file mode 100644 index 0000000..7a706ab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDet.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createDet } from '../../factoriesAny.js'; +export var detDependencies = { + divideScalarDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + subtractScalarDependencies, + typedDependencies, + unaryMinusDependencies, + createDet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeuteronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeuteronMass.generated.js new file mode 100644 index 0000000..605ff5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDeuteronMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createDeuteronMass } from '../../factoriesAny.js'; +export var deuteronMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createDeuteronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiag.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiag.generated.js new file mode 100644 index 0000000..b852edf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiag.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDiag } from '../../factoriesAny.js'; +export var diagDependencies = { + DenseMatrixDependencies, + SparseMatrixDependencies, + matrixDependencies, + typedDependencies, + createDiag +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiff.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiff.generated.js new file mode 100644 index 0000000..433e6b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiff.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDiff } from '../../factoriesAny.js'; +export var diffDependencies = { + matrixDependencies, + numberDependencies, + subtractDependencies, + typedDependencies, + createDiff +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiffTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiffTransform.generated.js new file mode 100644 index 0000000..4781b34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDiffTransform.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDiffTransform } from '../../factoriesAny.js'; +export var diffTransformDependencies = { + bignumberDependencies, + matrixDependencies, + numberDependencies, + subtractDependencies, + typedDependencies, + createDiffTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDistance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDistance.generated.js new file mode 100644 index 0000000..5e034ee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDistance.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { deepEqualDependencies } from './dependenciesDeepEqual.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDistance } from '../../factoriesAny.js'; +export var distanceDependencies = { + absDependencies, + addScalarDependencies, + deepEqualDependencies, + divideScalarDependencies, + multiplyScalarDependencies, + sqrtDependencies, + subtractScalarDependencies, + typedDependencies, + createDistance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivide.generated.js new file mode 100644 index 0000000..4db584f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivide.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDivide } from '../../factoriesAny.js'; +export var divideDependencies = { + divideScalarDependencies, + equalScalarDependencies, + invDependencies, + matrixDependencies, + multiplyDependencies, + typedDependencies, + createDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivideScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivideScalar.generated.js new file mode 100644 index 0000000..8333cb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDivideScalar.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDivideScalar } from '../../factoriesAny.js'; +export var divideScalarDependencies = { + numericDependencies, + typedDependencies, + createDivideScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDot.generated.js new file mode 100644 index 0000000..6f5a94a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDot.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { conjDependencies } from './dependenciesConj.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDot } from '../../factoriesAny.js'; +export var dotDependencies = { + addScalarDependencies, + conjDependencies, + multiplyScalarDependencies, + sizeDependencies, + typedDependencies, + createDot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotDivide.generated.js new file mode 100644 index 0000000..f459313 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotDivide.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDotDivide } from '../../factoriesAny.js'; +export var dotDivideDependencies = { + DenseMatrixDependencies, + concatDependencies, + divideScalarDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createDotDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotMultiply.generated.js new file mode 100644 index 0000000..63b2c77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotMultiply.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDotMultiply } from '../../factoriesAny.js'; +export var dotMultiplyDependencies = { + concatDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + typedDependencies, + createDotMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotPow.generated.js new file mode 100644 index 0000000..2fc4b60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesDotPow.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDotPow } from '../../factoriesAny.js'; +export var dotPowDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + powDependencies, + typedDependencies, + createDotPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesE.generated.js new file mode 100644 index 0000000..d4f8086 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesE.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createE } from '../../factoriesAny.js'; +export var eDependencies = { + BigNumberDependencies, + createE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEfimovFactor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEfimovFactor.generated.js new file mode 100644 index 0000000..e4a46fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEfimovFactor.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createEfimovFactor } from '../../factoriesAny.js'; +export var efimovFactorDependencies = { + BigNumberDependencies, + createEfimovFactor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEigs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEigs.generated.js new file mode 100644 index 0000000..7dacf86 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEigs.generated.js @@ -0,0 +1,72 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { atanDependencies } from './dependenciesAtan.generated.js'; +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { columnDependencies } from './dependenciesColumn.generated.js'; +import { complexDependencies } from './dependenciesComplex.generated.js'; +import { cosDependencies } from './dependenciesCos.generated.js'; +import { diagDependencies } from './dependenciesDiag.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { dotDependencies } from './dependenciesDot.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { flattenDependencies } from './dependenciesFlatten.generated.js'; +import { imDependencies } from './dependenciesIm.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { matrixFromColumnsDependencies } from './dependenciesMatrixFromColumns.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { qrDependencies } from './dependenciesQr.generated.js'; +import { reDependencies } from './dependenciesRe.generated.js'; +import { reshapeDependencies } from './dependenciesReshape.generated.js'; +import { sinDependencies } from './dependenciesSin.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { usolveDependencies } from './dependenciesUsolve.generated.js'; +import { usolveAllDependencies } from './dependenciesUsolveAll.generated.js'; +import { createEigs } from '../../factoriesAny.js'; +export var eigsDependencies = { + absDependencies, + addDependencies, + addScalarDependencies, + atanDependencies, + bignumberDependencies, + columnDependencies, + complexDependencies, + cosDependencies, + diagDependencies, + divideScalarDependencies, + dotDependencies, + equalDependencies, + flattenDependencies, + imDependencies, + invDependencies, + largerDependencies, + matrixDependencies, + matrixFromColumnsDependencies, + multiplyDependencies, + multiplyScalarDependencies, + numberDependencies, + qrDependencies, + reDependencies, + reshapeDependencies, + sinDependencies, + sizeDependencies, + smallerDependencies, + sqrtDependencies, + subtractDependencies, + typedDependencies, + usolveDependencies, + usolveAllDependencies, + createEigs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectricConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectricConstant.generated.js new file mode 100644 index 0000000..711df06 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectricConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createElectricConstant } from '../../factoriesAny.js'; +export var electricConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createElectricConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectronMass.generated.js new file mode 100644 index 0000000..75b98ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElectronMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createElectronMass } from '../../factoriesAny.js'; +export var electronMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createElectronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElementaryCharge.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElementaryCharge.generated.js new file mode 100644 index 0000000..85874ee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesElementaryCharge.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createElementaryCharge } from '../../factoriesAny.js'; +export var elementaryChargeDependencies = { + BigNumberDependencies, + UnitDependencies, + createElementaryCharge +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqual.generated.js new file mode 100644 index 0000000..1489253 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqual.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqual } from '../../factoriesAny.js'; +export var equalDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualScalar.generated.js new file mode 100644 index 0000000..ac93e47 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqualScalar } from '../../factoriesAny.js'; +export var equalScalarDependencies = { + typedDependencies, + createEqualScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualText.generated.js new file mode 100644 index 0000000..7336e81 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEqualText.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareTextDependencies } from './dependenciesCompareText.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqualText } from '../../factoriesAny.js'; +export var equalTextDependencies = { + compareTextDependencies, + isZeroDependencies, + typedDependencies, + createEqualText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesErf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesErf.generated.js new file mode 100644 index 0000000..ff4636e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesErf.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createErf } from '../../factoriesAny.js'; +export var erfDependencies = { + typedDependencies, + createErf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEvaluate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEvaluate.generated.js new file mode 100644 index 0000000..dc0ce5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesEvaluate.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEvaluate } from '../../factoriesAny.js'; +export var evaluateDependencies = { + parseDependencies, + typedDependencies, + createEvaluate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExp.generated.js new file mode 100644 index 0000000..803f469 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExp.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createExp } from '../../factoriesAny.js'; +export var expDependencies = { + typedDependencies, + createExp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm.generated.js new file mode 100644 index 0000000..13c62ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createExpm } from '../../factoriesAny.js'; +export var expmDependencies = { + absDependencies, + addDependencies, + identityDependencies, + invDependencies, + multiplyDependencies, + typedDependencies, + createExpm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm1.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm1.generated.js new file mode 100644 index 0000000..00c7bf4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesExpm1.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createExpm1 } from '../../factoriesAny.js'; +export var expm1Dependencies = { + ComplexDependencies, + typedDependencies, + createExpm1 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFactorial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFactorial.generated.js new file mode 100644 index 0000000..fae74be --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFactorial.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { gammaDependencies } from './dependenciesGamma.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFactorial } from '../../factoriesAny.js'; +export var factorialDependencies = { + gammaDependencies, + typedDependencies, + createFactorial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFalse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFalse.generated.js new file mode 100644 index 0000000..5694706 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFalse.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createFalse } from '../../factoriesAny.js'; +export var falseDependencies = { + createFalse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFaraday.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFaraday.generated.js new file mode 100644 index 0000000..b97f80b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFaraday.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createFaraday } from '../../factoriesAny.js'; +export var faradayDependencies = { + BigNumberDependencies, + UnitDependencies, + createFaraday +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFermiCoupling.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFermiCoupling.generated.js new file mode 100644 index 0000000..daab210 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFermiCoupling.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createFermiCoupling } from '../../factoriesAny.js'; +export var fermiCouplingDependencies = { + BigNumberDependencies, + UnitDependencies, + createFermiCoupling +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFft.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFft.generated.js new file mode 100644 index 0000000..303aa12 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFft.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { ceilDependencies } from './dependenciesCeil.generated.js'; +import { conjDependencies } from './dependenciesConj.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { dotDivideDependencies } from './dependenciesDotDivide.generated.js'; +import { expDependencies } from './dependenciesExp.generated.js'; +import { iDependencies } from './dependenciesI.generated.js'; +import { log2Dependencies } from './dependenciesLog2.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { tauDependencies } from './dependenciesTau.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFft } from '../../factoriesAny.js'; +export var fftDependencies = { + addScalarDependencies, + ceilDependencies, + conjDependencies, + divideScalarDependencies, + dotDivideDependencies, + expDependencies, + iDependencies, + log2Dependencies, + matrixDependencies, + multiplyScalarDependencies, + powDependencies, + tauDependencies, + typedDependencies, + createFft +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js new file mode 100644 index 0000000..7df71d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { createFibonacciHeapClass } from '../../factoriesAny.js'; +export var FibonacciHeapDependencies = { + largerDependencies, + smallerDependencies, + createFibonacciHeapClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilter.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilter.generated.js new file mode 100644 index 0000000..d564159 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilter.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFilter } from '../../factoriesAny.js'; +export var filterDependencies = { + typedDependencies, + createFilter +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilterTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilterTransform.generated.js new file mode 100644 index 0000000..48a768c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFilterTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFilterTransform } from '../../factoriesAny.js'; +export var filterTransformDependencies = { + typedDependencies, + createFilterTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFineStructure.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFineStructure.generated.js new file mode 100644 index 0000000..d30692d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFineStructure.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createFineStructure } from '../../factoriesAny.js'; +export var fineStructureDependencies = { + BigNumberDependencies, + createFineStructure +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFirstRadiation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFirstRadiation.generated.js new file mode 100644 index 0000000..571fb9b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFirstRadiation.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createFirstRadiation } from '../../factoriesAny.js'; +export var firstRadiationDependencies = { + BigNumberDependencies, + UnitDependencies, + createFirstRadiation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFix.generated.js new file mode 100644 index 0000000..390b0d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFix.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { ceilDependencies } from './dependenciesCeil.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { floorDependencies } from './dependenciesFloor.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createFix } from '../../factoriesAny.js'; +export var fixDependencies = { + ComplexDependencies, + DenseMatrixDependencies, + ceilDependencies, + equalScalarDependencies, + floorDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createFix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFlatten.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFlatten.generated.js new file mode 100644 index 0000000..f53888b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFlatten.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFlatten } from '../../factoriesAny.js'; +export var flattenDependencies = { + typedDependencies, + createFlatten +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFloor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFloor.generated.js new file mode 100644 index 0000000..9d681fb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFloor.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createFloor } from '../../factoriesAny.js'; +export var floorDependencies = { + DenseMatrixDependencies, + equalScalarDependencies, + matrixDependencies, + roundDependencies, + typedDependencies, + zerosDependencies, + createFloor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEach.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEach.generated.js new file mode 100644 index 0000000..e39b6fe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEach.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createForEach } from '../../factoriesAny.js'; +export var forEachDependencies = { + typedDependencies, + createForEach +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEachTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEachTransform.generated.js new file mode 100644 index 0000000..1d33837 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesForEachTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createForEachTransform } from '../../factoriesAny.js'; +export var forEachTransformDependencies = { + typedDependencies, + createForEachTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFormat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFormat.generated.js new file mode 100644 index 0000000..d7d47cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFormat.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFormat } from '../../factoriesAny.js'; +export var formatDependencies = { + typedDependencies, + createFormat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFraction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFraction.generated.js new file mode 100644 index 0000000..502b793 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFraction.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFraction } from '../../factoriesAny.js'; +export var fractionDependencies = { + FractionDependencies, + typedDependencies, + createFraction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFractionClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFractionClass.generated.js new file mode 100644 index 0000000..139d2b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFractionClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createFractionClass } from '../../factoriesAny.js'; +export var FractionDependencies = { + createFractionClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFreqz.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFreqz.generated.js new file mode 100644 index 0000000..f60cfd9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFreqz.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFreqz } from '../../factoriesAny.js'; +export var freqzDependencies = { + ComplexDependencies, + addDependencies, + divideDependencies, + matrixDependencies, + multiplyDependencies, + typedDependencies, + createFreqz +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js new file mode 100644 index 0000000..a191dcd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFunctionAssignmentNode } from '../../factoriesAny.js'; +export var FunctionAssignmentNodeDependencies = { + NodeDependencies, + typedDependencies, + createFunctionAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionNode.generated.js new file mode 100644 index 0000000..45d4dbd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesFunctionNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { createFunctionNode } from '../../factoriesAny.js'; +export var FunctionNodeDependencies = { + NodeDependencies, + SymbolNodeDependencies, + createFunctionNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGamma.generated.js new file mode 100644 index 0000000..56cabf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGamma.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createGamma } from '../../factoriesAny.js'; +export var gammaDependencies = { + BigNumberDependencies, + ComplexDependencies, + multiplyScalarDependencies, + powDependencies, + typedDependencies, + createGamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGasConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGasConstant.generated.js new file mode 100644 index 0000000..ffc3038 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGasConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createGasConstant } from '../../factoriesAny.js'; +export var gasConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createGasConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGcd.generated.js new file mode 100644 index 0000000..becb59f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGcd.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createGcd } from '../../factoriesAny.js'; +export var gcdDependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + roundDependencies, + typedDependencies, + zerosDependencies, + createGcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js new file mode 100644 index 0000000..8e7a996 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createGetMatrixDataType } from '../../factoriesAny.js'; +export var getMatrixDataTypeDependencies = { + typedDependencies, + createGetMatrixDataType +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravitationConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravitationConstant.generated.js new file mode 100644 index 0000000..0f7f12a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravitationConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createGravitationConstant } from '../../factoriesAny.js'; +export var gravitationConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createGravitationConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravity.generated.js new file mode 100644 index 0000000..1030929 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesGravity.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createGravity } from '../../factoriesAny.js'; +export var gravityDependencies = { + BigNumberDependencies, + UnitDependencies, + createGravity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js new file mode 100644 index 0000000..76a305d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createHartreeEnergy } from '../../factoriesAny.js'; +export var hartreeEnergyDependencies = { + BigNumberDependencies, + UnitDependencies, + createHartreeEnergy +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHasNumericValue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHasNumericValue.generated.js new file mode 100644 index 0000000..5eb4dfb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHasNumericValue.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHasNumericValue } from '../../factoriesAny.js'; +export var hasNumericValueDependencies = { + isNumericDependencies, + typedDependencies, + createHasNumericValue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelp.generated.js new file mode 100644 index 0000000..58549f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelp.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { HelpDependencies } from './dependenciesHelpClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHelp } from '../../factoriesAny.js'; +export var helpDependencies = { + HelpDependencies, + typedDependencies, + createHelp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelpClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelpClass.generated.js new file mode 100644 index 0000000..9ce8fa2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHelpClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { evaluateDependencies } from './dependenciesEvaluate.generated.js'; +import { createHelpClass } from '../../factoriesAny.js'; +export var HelpDependencies = { + evaluateDependencies, + createHelpClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHex.generated.js new file mode 100644 index 0000000..480205f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHex.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { formatDependencies } from './dependenciesFormat.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHex } from '../../factoriesAny.js'; +export var hexDependencies = { + formatDependencies, + typedDependencies, + createHex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHypot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHypot.generated.js new file mode 100644 index 0000000..8100654 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesHypot.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHypot } from '../../factoriesAny.js'; +export var hypotDependencies = { + absDependencies, + addScalarDependencies, + divideScalarDependencies, + isPositiveDependencies, + multiplyScalarDependencies, + smallerDependencies, + sqrtDependencies, + typedDependencies, + createHypot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesI.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesI.generated.js new file mode 100644 index 0000000..045dbf0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesI.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { createI } from '../../factoriesAny.js'; +export var iDependencies = { + ComplexDependencies, + createI +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIdentity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIdentity.generated.js new file mode 100644 index 0000000..4e118ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIdentity.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIdentity } from '../../factoriesAny.js'; +export var identityDependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + SparseMatrixDependencies, + matrixDependencies, + typedDependencies, + createIdentity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIfft.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIfft.generated.js new file mode 100644 index 0000000..e8d8d9c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIfft.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { conjDependencies } from './dependenciesConj.generated.js'; +import { dotDivideDependencies } from './dependenciesDotDivide.generated.js'; +import { fftDependencies } from './dependenciesFft.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIfft } from '../../factoriesAny.js'; +export var ifftDependencies = { + conjDependencies, + dotDivideDependencies, + fftDependencies, + typedDependencies, + createIfft +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIm.generated.js new file mode 100644 index 0000000..1e7da81 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIm.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIm } from '../../factoriesAny.js'; +export var imDependencies = { + typedDependencies, + createIm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js new file mode 100644 index 0000000..8f5067d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { createImmutableDenseMatrixClass } from '../../factoriesAny.js'; +export var ImmutableDenseMatrixDependencies = { + DenseMatrixDependencies, + smallerDependencies, + createImmutableDenseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndex.generated.js new file mode 100644 index 0000000..900da1e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndex.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIndex } from '../../factoriesAny.js'; +export var indexDependencies = { + IndexDependencies, + typedDependencies, + createIndex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexClass.generated.js new file mode 100644 index 0000000..8b160c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexClass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ImmutableDenseMatrixDependencies } from './dependenciesImmutableDenseMatrixClass.generated.js'; +import { getMatrixDataTypeDependencies } from './dependenciesGetMatrixDataType.generated.js'; +import { createIndexClass } from '../../factoriesAny.js'; +export var IndexDependencies = { + ImmutableDenseMatrixDependencies, + getMatrixDataTypeDependencies, + createIndexClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexNode.generated.js new file mode 100644 index 0000000..8f2bc19 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { createIndexNode } from '../../factoriesAny.js'; +export var IndexNodeDependencies = { + NodeDependencies, + sizeDependencies, + createIndexNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexTransform.generated.js new file mode 100644 index 0000000..3fb64ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIndexTransform.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { getMatrixDataTypeDependencies } from './dependenciesGetMatrixDataType.generated.js'; +import { createIndexTransform } from '../../factoriesAny.js'; +export var indexTransformDependencies = { + IndexDependencies, + getMatrixDataTypeDependencies, + createIndexTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInfinity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInfinity.generated.js new file mode 100644 index 0000000..870e9e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInfinity.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createInfinity } from '../../factoriesAny.js'; +export var InfinityDependencies = { + BigNumberDependencies, + createInfinity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIntersect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIntersect.generated.js new file mode 100644 index 0000000..46ff3fb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIntersect.generated.js @@ -0,0 +1,36 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { flattenDependencies } from './dependenciesFlatten.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIntersect } from '../../factoriesAny.js'; +export var intersectDependencies = { + absDependencies, + addDependencies, + addScalarDependencies, + divideScalarDependencies, + equalScalarDependencies, + flattenDependencies, + isNumericDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + multiplyScalarDependencies, + smallerDependencies, + subtractDependencies, + typedDependencies, + createIntersect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInv.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInv.generated.js new file mode 100644 index 0000000..8a19c5f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInv.generated.js @@ -0,0 +1,26 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { detDependencies } from './dependenciesDet.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createInv } from '../../factoriesAny.js'; +export var invDependencies = { + absDependencies, + addScalarDependencies, + detDependencies, + divideScalarDependencies, + identityDependencies, + matrixDependencies, + multiplyDependencies, + typedDependencies, + unaryMinusDependencies, + createInv +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js new file mode 100644 index 0000000..2cd33b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createInverseConductanceQuantum } from '../../factoriesAny.js'; +export var inverseConductanceQuantumDependencies = { + BigNumberDependencies, + UnitDependencies, + createInverseConductanceQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInvmod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInvmod.generated.js new file mode 100644 index 0000000..461ee3f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesInvmod.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { modDependencies } from './dependenciesMod.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { xgcdDependencies } from './dependenciesXgcd.generated.js'; +import { createInvmod } from '../../factoriesAny.js'; +export var invmodDependencies = { + BigNumberDependencies, + addDependencies, + equalDependencies, + isIntegerDependencies, + modDependencies, + smallerDependencies, + typedDependencies, + xgcdDependencies, + createInvmod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsInteger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsInteger.generated.js new file mode 100644 index 0000000..d71f2b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsInteger.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsInteger } from '../../factoriesAny.js'; +export var isIntegerDependencies = { + typedDependencies, + createIsInteger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNaN.generated.js new file mode 100644 index 0000000..797b48a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNaN.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNaN } from '../../factoriesAny.js'; +export var isNaNDependencies = { + typedDependencies, + createIsNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNegative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNegative.generated.js new file mode 100644 index 0000000..f2b83ad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNegative.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNegative } from '../../factoriesAny.js'; +export var isNegativeDependencies = { + typedDependencies, + createIsNegative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNumeric.generated.js new file mode 100644 index 0000000..00cdec9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsNumeric.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNumeric } from '../../factoriesAny.js'; +export var isNumericDependencies = { + typedDependencies, + createIsNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPositive.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPositive.generated.js new file mode 100644 index 0000000..1aa1b12 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPositive.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsPositive } from '../../factoriesAny.js'; +export var isPositiveDependencies = { + typedDependencies, + createIsPositive +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPrime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPrime.generated.js new file mode 100644 index 0000000..f714257 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsPrime.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsPrime } from '../../factoriesAny.js'; +export var isPrimeDependencies = { + typedDependencies, + createIsPrime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsZero.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsZero.generated.js new file mode 100644 index 0000000..7e28646 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesIsZero.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsZero } from '../../factoriesAny.js'; +export var isZeroDependencies = { + equalScalarDependencies, + typedDependencies, + createIsZero +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKldivergence.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKldivergence.generated.js new file mode 100644 index 0000000..15edb1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKldivergence.generated.js @@ -0,0 +1,26 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { dotDivideDependencies } from './dependenciesDotDivide.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { logDependencies } from './dependenciesLog.generated.js'; +import { mapDependencies } from './dependenciesMap.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { sumDependencies } from './dependenciesSum.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createKldivergence } from '../../factoriesAny.js'; +export var kldivergenceDependencies = { + divideDependencies, + dotDivideDependencies, + isNumericDependencies, + logDependencies, + mapDependencies, + matrixDependencies, + multiplyDependencies, + sumDependencies, + typedDependencies, + createKldivergence +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKlitzing.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKlitzing.generated.js new file mode 100644 index 0000000..c8439b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKlitzing.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createKlitzing } from '../../factoriesAny.js'; +export var klitzingDependencies = { + BigNumberDependencies, + UnitDependencies, + createKlitzing +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKron.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKron.generated.js new file mode 100644 index 0000000..38af28c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesKron.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createKron } from '../../factoriesAny.js'; +export var kronDependencies = { + matrixDependencies, + multiplyScalarDependencies, + typedDependencies, + createKron +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN10.generated.js new file mode 100644 index 0000000..f2d08b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN10.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createLN10 } from '../../factoriesAny.js'; +export var LN10Dependencies = { + BigNumberDependencies, + createLN10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN2.generated.js new file mode 100644 index 0000000..9c5386c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLN2.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createLN2 } from '../../factoriesAny.js'; +export var LN2Dependencies = { + BigNumberDependencies, + createLN2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG10E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG10E.generated.js new file mode 100644 index 0000000..ef35cd55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG10E.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createLOG10E } from '../../factoriesAny.js'; +export var LOG10EDependencies = { + BigNumberDependencies, + createLOG10E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG2E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG2E.generated.js new file mode 100644 index 0000000..c9e71e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLOG2E.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createLOG2E } from '../../factoriesAny.js'; +export var LOG2EDependencies = { + BigNumberDependencies, + createLOG2E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLarger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLarger.generated.js new file mode 100644 index 0000000..6919daa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLarger.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLarger } from '../../factoriesAny.js'; +export var largerDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createLarger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLargerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLargerEq.generated.js new file mode 100644 index 0000000..f73352d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLargerEq.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLargerEq } from '../../factoriesAny.js'; +export var largerEqDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createLargerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLcm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLcm.generated.js new file mode 100644 index 0000000..191be38 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLcm.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLcm } from '../../factoriesAny.js'; +export var lcmDependencies = { + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createLcm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeafCount.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeafCount.generated.js new file mode 100644 index 0000000..29a4a9f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeafCount.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLeafCount } from '../../factoriesAny.js'; +export var leafCountDependencies = { + parseDependencies, + typedDependencies, + createLeafCount +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeftShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeftShift.generated.js new file mode 100644 index 0000000..66b63b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLeftShift.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createLeftShift } from '../../factoriesAny.js'; +export var leftShiftDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createLeftShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLgamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLgamma.generated.js new file mode 100644 index 0000000..de9a2fb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLgamma.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLgamma } from '../../factoriesAny.js'; +export var lgammaDependencies = { + ComplexDependencies, + typedDependencies, + createLgamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog.generated.js new file mode 100644 index 0000000..456850a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog } from '../../factoriesAny.js'; +export var logDependencies = { + ComplexDependencies, + divideScalarDependencies, + typedDependencies, + createLog +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog10.generated.js new file mode 100644 index 0000000..e5db01f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog10.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog10 } from '../../factoriesAny.js'; +export var log10Dependencies = { + ComplexDependencies, + typedDependencies, + createLog10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog1p.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog1p.generated.js new file mode 100644 index 0000000..95cdacf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog1p.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { logDependencies } from './dependenciesLog.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog1p } from '../../factoriesAny.js'; +export var log1pDependencies = { + ComplexDependencies, + divideScalarDependencies, + logDependencies, + typedDependencies, + createLog1p +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog2.generated.js new file mode 100644 index 0000000..0f9eb10 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLog2.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog2 } from '../../factoriesAny.js'; +export var log2Dependencies = { + ComplexDependencies, + typedDependencies, + createLog2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLoschmidt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLoschmidt.generated.js new file mode 100644 index 0000000..e2559c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLoschmidt.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createLoschmidt } from '../../factoriesAny.js'; +export var loschmidtDependencies = { + BigNumberDependencies, + UnitDependencies, + createLoschmidt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolve.generated.js new file mode 100644 index 0000000..5a20446 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolve.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLsolve } from '../../factoriesAny.js'; +export var lsolveDependencies = { + DenseMatrixDependencies, + divideScalarDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + subtractScalarDependencies, + typedDependencies, + createLsolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolveAll.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolveAll.generated.js new file mode 100644 index 0000000..a190c2f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLsolveAll.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLsolveAll } from '../../factoriesAny.js'; +export var lsolveAllDependencies = { + DenseMatrixDependencies, + divideScalarDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + subtractScalarDependencies, + typedDependencies, + createLsolveAll +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLup.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLup.generated.js new file mode 100644 index 0000000..659c798 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLup.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { SpaDependencies } from './dependenciesSpaClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createLup } from '../../factoriesAny.js'; +export var lupDependencies = { + DenseMatrixDependencies, + SpaDependencies, + SparseMatrixDependencies, + absDependencies, + addScalarDependencies, + divideScalarDependencies, + equalScalarDependencies, + largerDependencies, + matrixDependencies, + multiplyScalarDependencies, + subtractScalarDependencies, + typedDependencies, + unaryMinusDependencies, + createLup +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLusolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLusolve.generated.js new file mode 100644 index 0000000..265740a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLusolve.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { lsolveDependencies } from './dependenciesLsolve.generated.js'; +import { lupDependencies } from './dependenciesLup.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { sluDependencies } from './dependenciesSlu.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { usolveDependencies } from './dependenciesUsolve.generated.js'; +import { createLusolve } from '../../factoriesAny.js'; +export var lusolveDependencies = { + DenseMatrixDependencies, + lsolveDependencies, + lupDependencies, + matrixDependencies, + sluDependencies, + typedDependencies, + usolveDependencies, + createLusolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLyap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLyap.generated.js new file mode 100644 index 0000000..799f98d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesLyap.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { sylvesterDependencies } from './dependenciesSylvester.generated.js'; +import { transposeDependencies } from './dependenciesTranspose.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLyap } from '../../factoriesAny.js'; +export var lyapDependencies = { + matrixDependencies, + multiplyDependencies, + sylvesterDependencies, + transposeDependencies, + typedDependencies, + createLyap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMad.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMad.generated.js new file mode 100644 index 0000000..82b4091 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMad.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { mapDependencies } from './dependenciesMap.generated.js'; +import { medianDependencies } from './dependenciesMedian.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMad } from '../../factoriesAny.js'; +export var madDependencies = { + absDependencies, + mapDependencies, + medianDependencies, + subtractDependencies, + typedDependencies, + createMad +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticConstant.generated.js new file mode 100644 index 0000000..3ad2da9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMagneticConstant } from '../../factoriesAny.js'; +export var magneticConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createMagneticConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js new file mode 100644 index 0000000..178fe1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMagneticFluxQuantum } from '../../factoriesAny.js'; +export var magneticFluxQuantumDependencies = { + BigNumberDependencies, + UnitDependencies, + createMagneticFluxQuantum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMap.generated.js new file mode 100644 index 0000000..a3e60dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMap.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMap } from '../../factoriesAny.js'; +export var mapDependencies = { + typedDependencies, + createMap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMapTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMapTransform.generated.js new file mode 100644 index 0000000..dbc5460 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMapTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMapTransform } from '../../factoriesAny.js'; +export var mapTransformDependencies = { + typedDependencies, + createMapTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrix.generated.js new file mode 100644 index 0000000..ab09ac4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrix.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { MatrixDependencies } from './dependenciesMatrixClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMatrix } from '../../factoriesAny.js'; +export var matrixDependencies = { + DenseMatrixDependencies, + MatrixDependencies, + SparseMatrixDependencies, + typedDependencies, + createMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixClass.generated.js new file mode 100644 index 0000000..12ff246 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createMatrixClass } from '../../factoriesAny.js'; +export var MatrixDependencies = { + createMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js new file mode 100644 index 0000000..b63e1b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { flattenDependencies } from './dependenciesFlatten.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMatrixFromColumns } from '../../factoriesAny.js'; +export var matrixFromColumnsDependencies = { + flattenDependencies, + matrixDependencies, + sizeDependencies, + typedDependencies, + createMatrixFromColumns +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js new file mode 100644 index 0000000..a20f85b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMatrixFromFunction } from '../../factoriesAny.js'; +export var matrixFromFunctionDependencies = { + isZeroDependencies, + matrixDependencies, + typedDependencies, + createMatrixFromFunction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js new file mode 100644 index 0000000..adf7c20 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { flattenDependencies } from './dependenciesFlatten.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMatrixFromRows } from '../../factoriesAny.js'; +export var matrixFromRowsDependencies = { + flattenDependencies, + matrixDependencies, + sizeDependencies, + typedDependencies, + createMatrixFromRows +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMax.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMax.generated.js new file mode 100644 index 0000000..9fafc4b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMax.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMax } from '../../factoriesAny.js'; +export var maxDependencies = { + largerDependencies, + numericDependencies, + typedDependencies, + createMax +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMaxTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMaxTransform.generated.js new file mode 100644 index 0000000..701633f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMaxTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMaxTransform } from '../../factoriesAny.js'; +export var maxTransformDependencies = { + largerDependencies, + numericDependencies, + typedDependencies, + createMaxTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMean.generated.js new file mode 100644 index 0000000..1d5b71b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMean.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMean } from '../../factoriesAny.js'; +export var meanDependencies = { + addDependencies, + divideDependencies, + typedDependencies, + createMean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMeanTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMeanTransform.generated.js new file mode 100644 index 0000000..478c6d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMeanTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMeanTransform } from '../../factoriesAny.js'; +export var meanTransformDependencies = { + addDependencies, + divideDependencies, + typedDependencies, + createMeanTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMedian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMedian.generated.js new file mode 100644 index 0000000..6618e5c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMedian.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { partitionSelectDependencies } from './dependenciesPartitionSelect.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMedian } from '../../factoriesAny.js'; +export var medianDependencies = { + addDependencies, + compareDependencies, + divideDependencies, + partitionSelectDependencies, + typedDependencies, + createMedian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMin.generated.js new file mode 100644 index 0000000..2141446 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMin.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMin } from '../../factoriesAny.js'; +export var minDependencies = { + numericDependencies, + smallerDependencies, + typedDependencies, + createMin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMinTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMinTransform.generated.js new file mode 100644 index 0000000..475b810 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMinTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMinTransform } from '../../factoriesAny.js'; +export var minTransformDependencies = { + numericDependencies, + smallerDependencies, + typedDependencies, + createMinTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMod.generated.js new file mode 100644 index 0000000..54cad6f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMod.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createMod } from '../../factoriesAny.js'; +export var modDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + roundDependencies, + typedDependencies, + zerosDependencies, + createMod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMode.generated.js new file mode 100644 index 0000000..1bcd89b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMode.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMode } from '../../factoriesAny.js'; +export var modeDependencies = { + isNaNDependencies, + isNumericDependencies, + typedDependencies, + createMode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMass.generated.js new file mode 100644 index 0000000..f1e27ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMolarMass } from '../../factoriesAny.js'; +export var molarMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createMolarMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMassC12.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMassC12.generated.js new file mode 100644 index 0000000..728a849 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarMassC12.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMolarMassC12 } from '../../factoriesAny.js'; +export var molarMassC12Dependencies = { + BigNumberDependencies, + UnitDependencies, + createMolarMassC12 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js new file mode 100644 index 0000000..288b280 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMolarPlanckConstant } from '../../factoriesAny.js'; +export var molarPlanckConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createMolarPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarVolume.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarVolume.generated.js new file mode 100644 index 0000000..f8f7312 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMolarVolume.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createMolarVolume } from '../../factoriesAny.js'; +export var molarVolumeDependencies = { + BigNumberDependencies, + UnitDependencies, + createMolarVolume +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultinomial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultinomial.generated.js new file mode 100644 index 0000000..f72fb19 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultinomial.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultinomial } from '../../factoriesAny.js'; +export var multinomialDependencies = { + addDependencies, + divideDependencies, + factorialDependencies, + isIntegerDependencies, + isPositiveDependencies, + multiplyDependencies, + typedDependencies, + createMultinomial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiply.generated.js new file mode 100644 index 0000000..5b6a14b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiply.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { dotDependencies } from './dependenciesDot.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultiply } from '../../factoriesAny.js'; +export var multiplyDependencies = { + addScalarDependencies, + dotDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + typedDependencies, + createMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js new file mode 100644 index 0000000..c47ed5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultiplyScalar } from '../../factoriesAny.js'; +export var multiplyScalarDependencies = { + typedDependencies, + createMultiplyScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNaN.generated.js new file mode 100644 index 0000000..159644f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNaN.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createNaN } from '../../factoriesAny.js'; +export var NaNDependencies = { + BigNumberDependencies, + createNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNeutronMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNeutronMass.generated.js new file mode 100644 index 0000000..4e85f4f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNeutronMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createNeutronMass } from '../../factoriesAny.js'; +export var neutronMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createNeutronMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNode.generated.js new file mode 100644 index 0000000..41e5cf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNode.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createNode } from '../../factoriesAny.js'; +export var NodeDependencies = { + createNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNorm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNorm.generated.js new file mode 100644 index 0000000..8acf1ed --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNorm.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { conjDependencies } from './dependenciesConj.generated.js'; +import { ctransposeDependencies } from './dependenciesCtranspose.generated.js'; +import { eigsDependencies } from './dependenciesEigs.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNorm } from '../../factoriesAny.js'; +export var normDependencies = { + absDependencies, + addDependencies, + conjDependencies, + ctransposeDependencies, + eigsDependencies, + equalScalarDependencies, + largerDependencies, + matrixDependencies, + multiplyDependencies, + powDependencies, + smallerDependencies, + sqrtDependencies, + typedDependencies, + createNorm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNot.generated.js new file mode 100644 index 0000000..0954db4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNot } from '../../factoriesAny.js'; +export var notDependencies = { + typedDependencies, + createNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoot.generated.js new file mode 100644 index 0000000..f82ca35 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoot.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNthRoot } from '../../factoriesAny.js'; +export var nthRootDependencies = { + BigNumberDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createNthRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoots.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoots.generated.js new file mode 100644 index 0000000..830652c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNthRoots.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNthRoots } from '../../factoriesAny.js'; +export var nthRootsDependencies = { + ComplexDependencies, + divideScalarDependencies, + typedDependencies, + createNthRoots +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js new file mode 100644 index 0000000..aff4825 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createNuclearMagneton } from '../../factoriesAny.js'; +export var nuclearMagnetonDependencies = { + BigNumberDependencies, + UnitDependencies, + createNuclearMagneton +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNull.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNull.generated.js new file mode 100644 index 0000000..8aa017c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNull.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createNull } from '../../factoriesAny.js'; +export var nullDependencies = { + createNull +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumber.generated.js new file mode 100644 index 0000000..6bde859 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumber.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNumber } from '../../factoriesAny.js'; +export var numberDependencies = { + typedDependencies, + createNumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumeric.generated.js new file mode 100644 index 0000000..cb0b193 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesNumeric.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { fractionDependencies } from './dependenciesFraction.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { createNumeric } from '../../factoriesAny.js'; +export var numericDependencies = { + bignumberDependencies, + fractionDependencies, + numberDependencies, + createNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesObjectNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesObjectNode.generated.js new file mode 100644 index 0000000..d0b0d71 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesObjectNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createObjectNode } from '../../factoriesAny.js'; +export var ObjectNodeDependencies = { + NodeDependencies, + createObjectNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOct.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOct.generated.js new file mode 100644 index 0000000..38c424c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOct.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { formatDependencies } from './dependenciesFormat.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createOct } from '../../factoriesAny.js'; +export var octDependencies = { + formatDependencies, + typedDependencies, + createOct +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOnes.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOnes.generated.js new file mode 100644 index 0000000..d486f28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOnes.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createOnes } from '../../factoriesAny.js'; +export var onesDependencies = { + BigNumberDependencies, + matrixDependencies, + typedDependencies, + createOnes +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOperatorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOperatorNode.generated.js new file mode 100644 index 0000000..64ff770 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOperatorNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createOperatorNode } from '../../factoriesAny.js'; +export var OperatorNodeDependencies = { + NodeDependencies, + createOperatorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOr.generated.js new file mode 100644 index 0000000..9b4a16c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOr.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createOr } from '../../factoriesAny.js'; +export var orDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOrTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOrTransform.generated.js new file mode 100644 index 0000000..852045c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesOrTransform.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createOrTransform } from '../../factoriesAny.js'; +export var orTransformDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createOrTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParenthesisNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParenthesisNode.generated.js new file mode 100644 index 0000000..92d4445 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParenthesisNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createParenthesisNode } from '../../factoriesAny.js'; +export var ParenthesisNodeDependencies = { + NodeDependencies, + createParenthesisNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParse.generated.js new file mode 100644 index 0000000..136168d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParse.generated.js @@ -0,0 +1,42 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { AssignmentNodeDependencies } from './dependenciesAssignmentNode.generated.js'; +import { BlockNodeDependencies } from './dependenciesBlockNode.generated.js'; +import { ConditionalNodeDependencies } from './dependenciesConditionalNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionAssignmentNodeDependencies } from './dependenciesFunctionAssignmentNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { RangeNodeDependencies } from './dependenciesRangeNode.generated.js'; +import { RelationalNodeDependencies } from './dependenciesRelationalNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createParse } from '../../factoriesAny.js'; +export var parseDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + AssignmentNodeDependencies, + BlockNodeDependencies, + ConditionalNodeDependencies, + ConstantNodeDependencies, + FunctionAssignmentNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + RangeNodeDependencies, + RelationalNodeDependencies, + SymbolNodeDependencies, + numericDependencies, + typedDependencies, + createParse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParser.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParser.generated.js new file mode 100644 index 0000000..f50f56a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParser.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ParserDependencies } from './dependenciesParserClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createParser } from '../../factoriesAny.js'; +export var parserDependencies = { + ParserDependencies, + typedDependencies, + createParser +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParserClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParserClass.generated.js new file mode 100644 index 0000000..2922aae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesParserClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { evaluateDependencies } from './dependenciesEvaluate.generated.js'; +import { createParserClass } from '../../factoriesAny.js'; +export var ParserDependencies = { + evaluateDependencies, + createParserClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPartitionSelect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPartitionSelect.generated.js new file mode 100644 index 0000000..ecd2205 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPartitionSelect.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPartitionSelect } from '../../factoriesAny.js'; +export var partitionSelectDependencies = { + compareDependencies, + isNaNDependencies, + isNumericDependencies, + typedDependencies, + createPartitionSelect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPermutations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPermutations.generated.js new file mode 100644 index 0000000..2c5449b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPermutations.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPermutations } from '../../factoriesAny.js'; +export var permutationsDependencies = { + factorialDependencies, + typedDependencies, + createPermutations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPhi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPhi.generated.js new file mode 100644 index 0000000..fa8e2c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPhi.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createPhi } from '../../factoriesAny.js'; +export var phiDependencies = { + BigNumberDependencies, + createPhi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPi.generated.js new file mode 100644 index 0000000..2327874 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPi.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createPi } from '../../factoriesAny.js'; +export var piDependencies = { + BigNumberDependencies, + createPi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPickRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPickRandom.generated.js new file mode 100644 index 0000000..a6809db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPickRandom.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPickRandom } from '../../factoriesAny.js'; +export var pickRandomDependencies = { + typedDependencies, + createPickRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPinv.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPinv.generated.js new file mode 100644 index 0000000..d1dedbc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPinv.generated.js @@ -0,0 +1,32 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { ctransposeDependencies } from './dependenciesCtranspose.generated.js'; +import { deepEqualDependencies } from './dependenciesDeepEqual.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { dotDependencies } from './dependenciesDot.generated.js'; +import { dotDivideDependencies } from './dependenciesDotDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPinv } from '../../factoriesAny.js'; +export var pinvDependencies = { + ComplexDependencies, + addDependencies, + ctransposeDependencies, + deepEqualDependencies, + divideScalarDependencies, + dotDependencies, + dotDivideDependencies, + equalDependencies, + invDependencies, + matrixDependencies, + multiplyDependencies, + typedDependencies, + createPinv +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckCharge.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckCharge.generated.js new file mode 100644 index 0000000..b3849ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckCharge.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckCharge } from '../../factoriesAny.js'; +export var planckChargeDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckCharge +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckConstant.generated.js new file mode 100644 index 0000000..d2c4c62 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckConstant } from '../../factoriesAny.js'; +export var planckConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckLength.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckLength.generated.js new file mode 100644 index 0000000..221d993 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckLength.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckLength } from '../../factoriesAny.js'; +export var planckLengthDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckLength +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckMass.generated.js new file mode 100644 index 0000000..209989d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckMass } from '../../factoriesAny.js'; +export var planckMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js new file mode 100644 index 0000000..7eac32c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckTemperature } from '../../factoriesAny.js'; +export var planckTemperatureDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckTemperature +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTime.generated.js new file mode 100644 index 0000000..9d07160 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPlanckTime.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createPlanckTime } from '../../factoriesAny.js'; +export var planckTimeDependencies = { + BigNumberDependencies, + UnitDependencies, + createPlanckTime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js new file mode 100644 index 0000000..1879945 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPolynomialRoot.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { cbrtDependencies } from './dependenciesCbrt.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { imDependencies } from './dependenciesIm.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { reDependencies } from './dependenciesRe.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typeOfDependencies } from './dependenciesTypeOf.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createPolynomialRoot } from '../../factoriesAny.js'; +export var polynomialRootDependencies = { + addDependencies, + cbrtDependencies, + divideDependencies, + equalScalarDependencies, + imDependencies, + isZeroDependencies, + multiplyDependencies, + reDependencies, + sqrtDependencies, + subtractDependencies, + typeOfDependencies, + typedDependencies, + unaryMinusDependencies, + createPolynomialRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPow.generated.js new file mode 100644 index 0000000..3c84571 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPow.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { fractionDependencies } from './dependenciesFraction.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPow } from '../../factoriesAny.js'; +export var powDependencies = { + ComplexDependencies, + fractionDependencies, + identityDependencies, + invDependencies, + matrixDependencies, + multiplyDependencies, + numberDependencies, + typedDependencies, + createPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrint.generated.js new file mode 100644 index 0000000..731a3bd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrint.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPrint } from '../../factoriesAny.js'; +export var printDependencies = { + typedDependencies, + createPrint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrintTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrintTransform.generated.js new file mode 100644 index 0000000..d80d6c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesPrintTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createPrintTransform } from '../../factoriesAny.js'; +export var printTransformDependencies = { + addDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createPrintTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProd.generated.js new file mode 100644 index 0000000..59fe201 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProd.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createProd } from '../../factoriesAny.js'; +export var prodDependencies = { + multiplyScalarDependencies, + numericDependencies, + typedDependencies, + createProd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProtonMass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProtonMass.generated.js new file mode 100644 index 0000000..351feae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesProtonMass.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createProtonMass } from '../../factoriesAny.js'; +export var protonMassDependencies = { + BigNumberDependencies, + UnitDependencies, + createProtonMass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQr.generated.js new file mode 100644 index 0000000..047a07b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQr.generated.js @@ -0,0 +1,38 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { complexDependencies } from './dependenciesComplex.generated.js'; +import { conjDependencies } from './dependenciesConj.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { signDependencies } from './dependenciesSign.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createQr } from '../../factoriesAny.js'; +export var qrDependencies = { + addScalarDependencies, + complexDependencies, + conjDependencies, + divideScalarDependencies, + equalDependencies, + identityDependencies, + isZeroDependencies, + matrixDependencies, + multiplyScalarDependencies, + signDependencies, + sqrtDependencies, + subtractScalarDependencies, + typedDependencies, + unaryMinusDependencies, + zerosDependencies, + createQr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeq.generated.js new file mode 100644 index 0000000..9e465cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeq.generated.js @@ -0,0 +1,32 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { partitionSelectDependencies } from './dependenciesPartitionSelect.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createQuantileSeq } from '../../factoriesAny.js'; +export var quantileSeqDependencies = { + bignumberDependencies, + addDependencies, + compareDependencies, + divideDependencies, + isIntegerDependencies, + largerDependencies, + multiplyDependencies, + partitionSelectDependencies, + smallerDependencies, + smallerEqDependencies, + subtractDependencies, + typedDependencies, + createQuantileSeq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js new file mode 100644 index 0000000..76750e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantileSeqTransform.generated.js @@ -0,0 +1,32 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { partitionSelectDependencies } from './dependenciesPartitionSelect.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createQuantileSeqTransform } from '../../factoriesAny.js'; +export var quantileSeqTransformDependencies = { + addDependencies, + bignumberDependencies, + compareDependencies, + divideDependencies, + isIntegerDependencies, + largerDependencies, + multiplyDependencies, + partitionSelectDependencies, + smallerDependencies, + smallerEqDependencies, + subtractDependencies, + typedDependencies, + createQuantileSeqTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js new file mode 100644 index 0000000..5f05d77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createQuantumOfCirculation } from '../../factoriesAny.js'; +export var quantumOfCirculationDependencies = { + BigNumberDependencies, + UnitDependencies, + createQuantumOfCirculation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandom.generated.js new file mode 100644 index 0000000..b11fb5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandom.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRandom } from '../../factoriesAny.js'; +export var randomDependencies = { + typedDependencies, + createRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandomInt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandomInt.generated.js new file mode 100644 index 0000000..fb51851 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRandomInt.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRandomInt } from '../../factoriesAny.js'; +export var randomIntDependencies = { + typedDependencies, + createRandomInt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRange.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRange.generated.js new file mode 100644 index 0000000..cddc0d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRange.generated.js @@ -0,0 +1,26 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { largerEqDependencies } from './dependenciesLargerEq.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRange } from '../../factoriesAny.js'; +export var rangeDependencies = { + bignumberDependencies, + matrixDependencies, + addDependencies, + isPositiveDependencies, + largerDependencies, + largerEqDependencies, + smallerDependencies, + smallerEqDependencies, + typedDependencies, + createRange +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeClass.generated.js new file mode 100644 index 0000000..dc28667 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createRangeClass } from '../../factoriesAny.js'; +export var RangeDependencies = { + createRangeClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeNode.generated.js new file mode 100644 index 0000000..829b356 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createRangeNode } from '../../factoriesAny.js'; +export var RangeNodeDependencies = { + NodeDependencies, + createRangeNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeTransform.generated.js new file mode 100644 index 0000000..1ce5802 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRangeTransform.generated.js @@ -0,0 +1,26 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { largerEqDependencies } from './dependenciesLargerEq.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRangeTransform } from '../../factoriesAny.js'; +export var rangeTransformDependencies = { + bignumberDependencies, + matrixDependencies, + addDependencies, + isPositiveDependencies, + largerDependencies, + largerEqDependencies, + smallerDependencies, + smallerEqDependencies, + typedDependencies, + createRangeTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRationalize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRationalize.generated.js new file mode 100644 index 0000000..b444849 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRationalize.generated.js @@ -0,0 +1,56 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { fractionDependencies } from './dependenciesFraction.generated.js'; +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { simplifyDependencies } from './dependenciesSimplify.generated.js'; +import { simplifyConstantDependencies } from './dependenciesSimplifyConstant.generated.js'; +import { simplifyCoreDependencies } from './dependenciesSimplifyCore.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRationalize } from '../../factoriesAny.js'; +export var rationalizeDependencies = { + bignumberDependencies, + fractionDependencies, + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + simplifyDependencies, + simplifyConstantDependencies, + simplifyCoreDependencies, + subtractDependencies, + typedDependencies, + createRationalize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRe.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRe.generated.js new file mode 100644 index 0000000..addd9fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRe.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRe } from '../../factoriesAny.js'; +export var reDependencies = { + typedDependencies, + createRe +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js new file mode 100644 index 0000000..58f1fcd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createReducedPlanckConstant } from '../../factoriesAny.js'; +export var reducedPlanckConstantDependencies = { + BigNumberDependencies, + UnitDependencies, + createReducedPlanckConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRelationalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRelationalNode.generated.js new file mode 100644 index 0000000..f76b3f5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRelationalNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createRelationalNode } from '../../factoriesAny.js'; +export var RelationalNodeDependencies = { + NodeDependencies, + createRelationalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReplacer.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReplacer.generated.js new file mode 100644 index 0000000..6fcdff6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReplacer.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createReplacer } from '../../factoriesAny.js'; +export var replacerDependencies = { + createReplacer +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReshape.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReshape.generated.js new file mode 100644 index 0000000..1668dd9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReshape.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createReshape } from '../../factoriesAny.js'; +export var reshapeDependencies = { + isIntegerDependencies, + matrixDependencies, + typedDependencies, + createReshape +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResize.generated.js new file mode 100644 index 0000000..3ffb8bf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResize.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { createResize } from '../../factoriesAny.js'; +export var resizeDependencies = { + matrixDependencies, + createResize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResolve.generated.js new file mode 100644 index 0000000..4512fae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResolve.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createResolve } from '../../factoriesAny.js'; +export var resolveDependencies = { + ConstantNodeDependencies, + FunctionNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + parseDependencies, + typedDependencies, + createResolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResultSet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResultSet.generated.js new file mode 100644 index 0000000..41f61b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesResultSet.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createResultSet } from '../../factoriesAny.js'; +export var ResultSetDependencies = { + createResultSet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReviver.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReviver.generated.js new file mode 100644 index 0000000..3dd5918 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesReviver.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createReviver } from '../../factoriesAny.js'; +export var reviverDependencies = { + createReviver +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightArithShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightArithShift.generated.js new file mode 100644 index 0000000..daf2347 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightArithShift.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createRightArithShift } from '../../factoriesAny.js'; +export var rightArithShiftDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createRightArithShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightLogShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightLogShift.generated.js new file mode 100644 index 0000000..22dade3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRightLogShift.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createRightLogShift } from '../../factoriesAny.js'; +export var rightLogShiftDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createRightLogShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotate.generated.js new file mode 100644 index 0000000..faf69a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotate.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { rotationMatrixDependencies } from './dependenciesRotationMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRotate } from '../../factoriesAny.js'; +export var rotateDependencies = { + multiplyDependencies, + rotationMatrixDependencies, + typedDependencies, + createRotate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotationMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotationMatrix.generated.js new file mode 100644 index 0000000..667ce47 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRotationMatrix.generated.js @@ -0,0 +1,30 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { cosDependencies } from './dependenciesCos.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { normDependencies } from './dependenciesNorm.generated.js'; +import { sinDependencies } from './dependenciesSin.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createRotationMatrix } from '../../factoriesAny.js'; +export var rotationMatrixDependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + SparseMatrixDependencies, + addScalarDependencies, + cosDependencies, + matrixDependencies, + multiplyScalarDependencies, + normDependencies, + sinDependencies, + typedDependencies, + unaryMinusDependencies, + createRotationMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRound.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRound.generated.js new file mode 100644 index 0000000..38f9715 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRound.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createRound } from '../../factoriesAny.js'; +export var roundDependencies = { + BigNumberDependencies, + DenseMatrixDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createRound +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRow.generated.js new file mode 100644 index 0000000..78165be --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRow.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { rangeDependencies } from './dependenciesRange.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRow } from '../../factoriesAny.js'; +export var rowDependencies = { + IndexDependencies, + matrixDependencies, + rangeDependencies, + typedDependencies, + createRow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRowTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRowTransform.generated.js new file mode 100644 index 0000000..b5d752f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRowTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { rangeDependencies } from './dependenciesRange.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRowTransform } from '../../factoriesAny.js'; +export var rowTransformDependencies = { + IndexDependencies, + matrixDependencies, + rangeDependencies, + typedDependencies, + createRowTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRydberg.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRydberg.generated.js new file mode 100644 index 0000000..7494da9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesRydberg.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createRydberg } from '../../factoriesAny.js'; +export var rydbergDependencies = { + BigNumberDependencies, + UnitDependencies, + createRydberg +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT1_2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT1_2.generated.js new file mode 100644 index 0000000..1b52232 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT1_2.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createSQRT1_2 } from '../../factoriesAny.js'; // eslint-disable-line camelcase + +export var SQRT1_2Dependencies = { + // eslint-disable-line camelcase + BigNumberDependencies, + createSQRT1_2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT2.generated.js new file mode 100644 index 0000000..3ed6f02 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSQRT2.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createSQRT2 } from '../../factoriesAny.js'; +export var SQRT2Dependencies = { + BigNumberDependencies, + createSQRT2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSackurTetrode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSackurTetrode.generated.js new file mode 100644 index 0000000..c5dcbee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSackurTetrode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createSackurTetrode } from '../../factoriesAny.js'; +export var sackurTetrodeDependencies = { + BigNumberDependencies, + createSackurTetrode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSchur.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSchur.generated.js new file mode 100644 index 0000000..d378d60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSchur.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { normDependencies } from './dependenciesNorm.generated.js'; +import { qrDependencies } from './dependenciesQr.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSchur } from '../../factoriesAny.js'; +export var schurDependencies = { + identityDependencies, + matrixDependencies, + multiplyDependencies, + normDependencies, + qrDependencies, + subtractDependencies, + typedDependencies, + createSchur +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSec.generated.js new file mode 100644 index 0000000..cadafe2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSec.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSec } from '../../factoriesAny.js'; +export var secDependencies = { + BigNumberDependencies, + typedDependencies, + createSec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSech.generated.js new file mode 100644 index 0000000..51c336e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSech.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSech } from '../../factoriesAny.js'; +export var sechDependencies = { + BigNumberDependencies, + typedDependencies, + createSech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSecondRadiation.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSecondRadiation.generated.js new file mode 100644 index 0000000..29a2a14 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSecondRadiation.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createSecondRadiation } from '../../factoriesAny.js'; +export var secondRadiationDependencies = { + BigNumberDependencies, + UnitDependencies, + createSecondRadiation +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetCartesian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetCartesian.generated.js new file mode 100644 index 0000000..5156f57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetCartesian.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetCartesian } from '../../factoriesAny.js'; +export var setCartesianDependencies = { + DenseMatrixDependencies, + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetCartesian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDifference.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDifference.generated.js new file mode 100644 index 0000000..da3d014 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDifference.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetDifference } from '../../factoriesAny.js'; +export var setDifferenceDependencies = { + DenseMatrixDependencies, + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetDifference +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDistinct.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDistinct.generated.js new file mode 100644 index 0000000..2fa0712 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetDistinct.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetDistinct } from '../../factoriesAny.js'; +export var setDistinctDependencies = { + DenseMatrixDependencies, + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetDistinct +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIntersect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIntersect.generated.js new file mode 100644 index 0000000..9af570f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIntersect.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetIntersect } from '../../factoriesAny.js'; +export var setIntersectDependencies = { + DenseMatrixDependencies, + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetIntersect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIsSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIsSubset.generated.js new file mode 100644 index 0000000..a868e2e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetIsSubset.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetIsSubset } from '../../factoriesAny.js'; +export var setIsSubsetDependencies = { + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetIsSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js new file mode 100644 index 0000000..4a9cdeb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetMultiplicity } from '../../factoriesAny.js'; +export var setMultiplicityDependencies = { + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetMultiplicity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetPowerset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetPowerset.generated.js new file mode 100644 index 0000000..9914a7d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetPowerset.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetPowerset } from '../../factoriesAny.js'; +export var setPowersetDependencies = { + IndexDependencies, + compareNaturalDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetPowerset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSize.generated.js new file mode 100644 index 0000000..7dcdab9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSize.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetSize } from '../../factoriesAny.js'; +export var setSizeDependencies = { + compareNaturalDependencies, + typedDependencies, + createSetSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSymDifference.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSymDifference.generated.js new file mode 100644 index 0000000..3a3cee2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetSymDifference.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { setDifferenceDependencies } from './dependenciesSetDifference.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetSymDifference } from '../../factoriesAny.js'; +export var setSymDifferenceDependencies = { + IndexDependencies, + concatDependencies, + setDifferenceDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetSymDifference +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetUnion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetUnion.generated.js new file mode 100644 index 0000000..c288bf6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSetUnion.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { IndexDependencies } from './dependenciesIndexClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { setIntersectDependencies } from './dependenciesSetIntersect.generated.js'; +import { setSymDifferenceDependencies } from './dependenciesSetSymDifference.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSetUnion } from '../../factoriesAny.js'; +export var setUnionDependencies = { + IndexDependencies, + concatDependencies, + setIntersectDependencies, + setSymDifferenceDependencies, + sizeDependencies, + subsetDependencies, + typedDependencies, + createSetUnion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSign.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSign.generated.js new file mode 100644 index 0000000..e3f38ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSign.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { complexDependencies } from './dependenciesComplex.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSign } from '../../factoriesAny.js'; +export var signDependencies = { + BigNumberDependencies, + FractionDependencies, + complexDependencies, + typedDependencies, + createSign +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplify.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplify.generated.js new file mode 100644 index 0000000..1256171 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplify.generated.js @@ -0,0 +1,56 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { fractionDependencies } from './dependenciesFraction.generated.js'; +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { resolveDependencies } from './dependenciesResolve.generated.js'; +import { simplifyConstantDependencies } from './dependenciesSimplifyConstant.generated.js'; +import { simplifyCoreDependencies } from './dependenciesSimplifyCore.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplify } from '../../factoriesAny.js'; +export var simplifyDependencies = { + bignumberDependencies, + fractionDependencies, + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + resolveDependencies, + simplifyConstantDependencies, + simplifyCoreDependencies, + subtractDependencies, + typedDependencies, + createSimplify +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js new file mode 100644 index 0000000..e437aa7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyConstant.generated.js @@ -0,0 +1,32 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { fractionDependencies } from './dependenciesFraction.generated.js'; +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplifyConstant } from '../../factoriesAny.js'; +export var simplifyConstantDependencies = { + bignumberDependencies, + fractionDependencies, + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + SymbolNodeDependencies, + matrixDependencies, + typedDependencies, + createSimplifyConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyCore.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyCore.generated.js new file mode 100644 index 0000000..aea2f14 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSimplifyCore.generated.js @@ -0,0 +1,44 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplifyCore } from '../../factoriesAny.js'; +export var simplifyCoreDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + subtractDependencies, + typedDependencies, + createSimplifyCore +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSin.generated.js new file mode 100644 index 0000000..44dc216 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSin.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSin } from '../../factoriesAny.js'; +export var sinDependencies = { + typedDependencies, + createSin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSinh.generated.js new file mode 100644 index 0000000..6eacc28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSinh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSinh } from '../../factoriesAny.js'; +export var sinhDependencies = { + typedDependencies, + createSinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSize.generated.js new file mode 100644 index 0000000..19d3a80 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSize.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSize } from '../../factoriesAny.js'; +export var sizeDependencies = { + matrixDependencies, + typedDependencies, + createSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSlu.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSlu.generated.js new file mode 100644 index 0000000..a348ceb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSlu.generated.js @@ -0,0 +1,28 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { largerEqDependencies } from './dependenciesLargerEq.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { transposeDependencies } from './dependenciesTranspose.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSlu } from '../../factoriesAny.js'; +export var sluDependencies = { + SparseMatrixDependencies, + absDependencies, + addDependencies, + divideScalarDependencies, + largerDependencies, + largerEqDependencies, + multiplyDependencies, + subtractDependencies, + transposeDependencies, + typedDependencies, + createSlu +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmaller.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmaller.generated.js new file mode 100644 index 0000000..c82629e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmaller.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSmaller } from '../../factoriesAny.js'; +export var smallerDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createSmaller +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmallerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmallerEq.generated.js new file mode 100644 index 0000000..9c417da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSmallerEq.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSmallerEq } from '../../factoriesAny.js'; +export var smallerEqDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createSmallerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSolveODE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSolveODE.generated.js new file mode 100644 index 0000000..622f62c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSolveODE.generated.js @@ -0,0 +1,38 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { mapDependencies } from './dependenciesMap.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { maxDependencies } from './dependenciesMax.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createSolveODE } from '../../factoriesAny.js'; +export var solveODEDependencies = { + absDependencies, + addDependencies, + bignumberDependencies, + divideDependencies, + isNegativeDependencies, + isPositiveDependencies, + largerDependencies, + mapDependencies, + matrixDependencies, + maxDependencies, + multiplyDependencies, + smallerDependencies, + subtractDependencies, + typedDependencies, + unaryMinusDependencies, + createSolveODE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSort.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSort.generated.js new file mode 100644 index 0000000..7ce4fa8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSort.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { compareNaturalDependencies } from './dependenciesCompareNatural.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSort } from '../../factoriesAny.js'; +export var sortDependencies = { + compareDependencies, + compareNaturalDependencies, + matrixDependencies, + typedDependencies, + createSort +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpaClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpaClass.generated.js new file mode 100644 index 0000000..2a2c95c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpaClass.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { FibonacciHeapDependencies } from './dependenciesFibonacciHeapClass.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { createSpaClass } from '../../factoriesAny.js'; +export var SpaDependencies = { + FibonacciHeapDependencies, + addScalarDependencies, + equalScalarDependencies, + createSpaClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparse.generated.js new file mode 100644 index 0000000..2166043 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparse.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { SparseMatrixDependencies } from './dependenciesSparseMatrixClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSparse } from '../../factoriesAny.js'; +export var sparseDependencies = { + SparseMatrixDependencies, + typedDependencies, + createSparse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js new file mode 100644 index 0000000..220d4be --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { MatrixDependencies } from './dependenciesMatrixClass.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSparseMatrixClass } from '../../factoriesAny.js'; +export var SparseMatrixDependencies = { + MatrixDependencies, + equalScalarDependencies, + typedDependencies, + createSparseMatrixClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js new file mode 100644 index 0000000..963a387 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createSpeedOfLight } from '../../factoriesAny.js'; +export var speedOfLightDependencies = { + BigNumberDependencies, + UnitDependencies, + createSpeedOfLight +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSplitUnit.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSplitUnit.generated.js new file mode 100644 index 0000000..67bfa6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSplitUnit.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSplitUnit } from '../../factoriesAny.js'; +export var splitUnitDependencies = { + typedDependencies, + createSplitUnit +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrt.generated.js new file mode 100644 index 0000000..f2a68df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrt.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSqrt } from '../../factoriesAny.js'; +export var sqrtDependencies = { + ComplexDependencies, + typedDependencies, + createSqrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrtm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrtm.generated.js new file mode 100644 index 0000000..ad6688f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqrtm.generated.js @@ -0,0 +1,30 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { invDependencies } from './dependenciesInv.generated.js'; +import { mapDependencies } from './dependenciesMap.generated.js'; +import { maxDependencies } from './dependenciesMax.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSqrtm } from '../../factoriesAny.js'; +export var sqrtmDependencies = { + absDependencies, + addDependencies, + identityDependencies, + invDependencies, + mapDependencies, + maxDependencies, + multiplyDependencies, + sizeDependencies, + sqrtDependencies, + subtractDependencies, + typedDependencies, + createSqrtm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSquare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSquare.generated.js new file mode 100644 index 0000000..8c24c0e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSquare.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSquare } from '../../factoriesAny.js'; +export var squareDependencies = { + typedDependencies, + createSquare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqueeze.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqueeze.generated.js new file mode 100644 index 0000000..09c4252 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSqueeze.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSqueeze } from '../../factoriesAny.js'; +export var squeezeDependencies = { + typedDependencies, + createSqueeze +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStd.generated.js new file mode 100644 index 0000000..ae94431 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStd.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { mapDependencies } from './dependenciesMap.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { varianceDependencies } from './dependenciesVariance.generated.js'; +import { createStd } from '../../factoriesAny.js'; +export var stdDependencies = { + mapDependencies, + sqrtDependencies, + typedDependencies, + varianceDependencies, + createStd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStdTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStdTransform.generated.js new file mode 100644 index 0000000..c2ff940 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStdTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { mapDependencies } from './dependenciesMap.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { varianceDependencies } from './dependenciesVariance.generated.js'; +import { createStdTransform } from '../../factoriesAny.js'; +export var stdTransformDependencies = { + mapDependencies, + sqrtDependencies, + typedDependencies, + varianceDependencies, + createStdTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js new file mode 100644 index 0000000..ee5c4d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createStefanBoltzmann } from '../../factoriesAny.js'; +export var stefanBoltzmannDependencies = { + BigNumberDependencies, + UnitDependencies, + createStefanBoltzmann +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStirlingS2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStirlingS2.generated.js new file mode 100644 index 0000000..de8a193 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesStirlingS2.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { bignumberDependencies } from './dependenciesBignumber.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createStirlingS2 } from '../../factoriesAny.js'; +export var stirlingS2Dependencies = { + bignumberDependencies, + addScalarDependencies, + combinationsDependencies, + divideScalarDependencies, + factorialDependencies, + isIntegerDependencies, + isNegativeDependencies, + largerDependencies, + multiplyScalarDependencies, + numberDependencies, + powDependencies, + subtractScalarDependencies, + typedDependencies, + createStirlingS2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesString.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesString.generated.js new file mode 100644 index 0000000..e7d173e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesString.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createString } from '../../factoriesAny.js'; +export var stringDependencies = { + typedDependencies, + createString +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubset.generated.js new file mode 100644 index 0000000..0b4285d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubset.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createSubset } from '../../factoriesAny.js'; +export var subsetDependencies = { + addDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubsetTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubsetTransform.generated.js new file mode 100644 index 0000000..0fb19e5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubsetTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { zerosDependencies } from './dependenciesZeros.generated.js'; +import { createSubsetTransform } from '../../factoriesAny.js'; +export var subsetTransformDependencies = { + addDependencies, + matrixDependencies, + typedDependencies, + zerosDependencies, + createSubsetTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtract.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtract.generated.js new file mode 100644 index 0000000..a10379a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtract.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js'; +import { createSubtract } from '../../factoriesAny.js'; +export var subtractDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + subtractScalarDependencies, + typedDependencies, + unaryMinusDependencies, + createSubtract +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtractScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtractScalar.generated.js new file mode 100644 index 0000000..b339578 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSubtractScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSubtractScalar } from '../../factoriesAny.js'; +export var subtractScalarDependencies = { + typedDependencies, + createSubtractScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSum.generated.js new file mode 100644 index 0000000..49fc33d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSum.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSum } from '../../factoriesAny.js'; +export var sumDependencies = { + addDependencies, + numericDependencies, + typedDependencies, + createSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSumTransform.generated.js new file mode 100644 index 0000000..a21526f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSumTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSumTransform } from '../../factoriesAny.js'; +export var sumTransformDependencies = { + addDependencies, + numericDependencies, + typedDependencies, + createSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSylvester.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSylvester.generated.js new file mode 100644 index 0000000..371d0c5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSylvester.generated.js @@ -0,0 +1,38 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { identityDependencies } from './dependenciesIdentity.generated.js'; +import { indexDependencies } from './dependenciesIndex.generated.js'; +import { lusolveDependencies } from './dependenciesLusolve.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { matrixFromColumnsDependencies } from './dependenciesMatrixFromColumns.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { rangeDependencies } from './dependenciesRange.generated.js'; +import { schurDependencies } from './dependenciesSchur.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { transposeDependencies } from './dependenciesTranspose.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSylvester } from '../../factoriesAny.js'; +export var sylvesterDependencies = { + absDependencies, + addDependencies, + concatDependencies, + identityDependencies, + indexDependencies, + lusolveDependencies, + matrixDependencies, + matrixFromColumnsDependencies, + multiplyDependencies, + rangeDependencies, + schurDependencies, + subsetDependencies, + subtractDependencies, + transposeDependencies, + typedDependencies, + createSylvester +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolNode.generated.js new file mode 100644 index 0000000..dcde6cf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createSymbolNode } from '../../factoriesAny.js'; +export var SymbolNodeDependencies = { + UnitDependencies, + NodeDependencies, + createSymbolNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js new file mode 100644 index 0000000..6f529c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { simplifyDependencies } from './dependenciesSimplify.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSymbolicEqual } from '../../factoriesAny.js'; +export var symbolicEqualDependencies = { + OperatorNodeDependencies, + parseDependencies, + simplifyDependencies, + typedDependencies, + createSymbolicEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTan.generated.js new file mode 100644 index 0000000..e445666 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTan.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTan } from '../../factoriesAny.js'; +export var tanDependencies = { + typedDependencies, + createTan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTanh.generated.js new file mode 100644 index 0000000..d770f24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTanh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTanh } from '../../factoriesAny.js'; +export var tanhDependencies = { + typedDependencies, + createTanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTau.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTau.generated.js new file mode 100644 index 0000000..8cf5bda --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTau.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createTau } from '../../factoriesAny.js'; +export var tauDependencies = { + BigNumberDependencies, + createTau +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js new file mode 100644 index 0000000..92d52f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createThomsonCrossSection } from '../../factoriesAny.js'; +export var thomsonCrossSectionDependencies = { + BigNumberDependencies, + UnitDependencies, + createThomsonCrossSection +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTo.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTo.generated.js new file mode 100644 index 0000000..c1f15e7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTo.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTo } from '../../factoriesAny.js'; +export var toDependencies = { + concatDependencies, + matrixDependencies, + typedDependencies, + createTo +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrace.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrace.generated.js new file mode 100644 index 0000000..48b6db0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrace.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTrace } from '../../factoriesAny.js'; +export var traceDependencies = { + addDependencies, + matrixDependencies, + typedDependencies, + createTrace +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTranspose.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTranspose.generated.js new file mode 100644 index 0000000..d89ace7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTranspose.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTranspose } from '../../factoriesAny.js'; +export var transposeDependencies = { + matrixDependencies, + typedDependencies, + createTranspose +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrue.generated.js new file mode 100644 index 0000000..c4e92e0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTrue.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createTrue } from '../../factoriesAny.js'; +export var trueDependencies = { + createTrue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTypeOf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTypeOf.generated.js new file mode 100644 index 0000000..d9aa68b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTypeOf.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTypeOf } from '../../factoriesAny.js'; +export var typeOfDependencies = { + typedDependencies, + createTypeOf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTyped.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTyped.generated.js new file mode 100644 index 0000000..61e4723 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesTyped.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { createTyped } from '../../factoriesAny.js'; +export var typedDependencies = { + BigNumberDependencies, + ComplexDependencies, + DenseMatrixDependencies, + FractionDependencies, + createTyped +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryMinus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryMinus.generated.js new file mode 100644 index 0000000..465375d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryMinus.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnaryMinus } from '../../factoriesAny.js'; +export var unaryMinusDependencies = { + typedDependencies, + createUnaryMinus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryPlus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryPlus.generated.js new file mode 100644 index 0000000..5b63a38 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnaryPlus.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnaryPlus } from '../../factoriesAny.js'; +export var unaryPlusDependencies = { + numericDependencies, + typedDependencies, + createUnaryPlus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnequal.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnequal.generated.js new file mode 100644 index 0000000..6cd3b05 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnequal.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnequal } from '../../factoriesAny.js'; +export var unequalDependencies = { + DenseMatrixDependencies, + concatDependencies, + equalScalarDependencies, + matrixDependencies, + typedDependencies, + createUnequal +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitClass.generated.js new file mode 100644 index 0000000..dd979b4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitClass.generated.js @@ -0,0 +1,38 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { FractionDependencies } from './dependenciesFractionClass.generated.js'; +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { fixDependencies } from './dependenciesFix.generated.js'; +import { formatDependencies } from './dependenciesFormat.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { roundDependencies } from './dependenciesRound.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { createUnitClass } from '../../factoriesAny.js'; +export var UnitDependencies = { + BigNumberDependencies, + ComplexDependencies, + FractionDependencies, + absDependencies, + addScalarDependencies, + divideScalarDependencies, + equalDependencies, + fixDependencies, + formatDependencies, + isNumericDependencies, + multiplyScalarDependencies, + numberDependencies, + powDependencies, + roundDependencies, + subtractScalarDependencies, + createUnitClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitFunction.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitFunction.generated.js new file mode 100644 index 0000000..2b82164 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUnitFunction.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnitFunction } from '../../factoriesAny.js'; +export var unitDependencies = { + UnitDependencies, + typedDependencies, + createUnitFunction +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercaseE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercaseE.generated.js new file mode 100644 index 0000000..2c7a8a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercaseE.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { eDependencies } from './dependenciesE.generated.js'; +import { createUppercaseE } from '../../factoriesAny.js'; +export var EDependencies = { + eDependencies, + createUppercaseE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercasePi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercasePi.generated.js new file mode 100644 index 0000000..fe09896 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUppercasePi.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { piDependencies } from './dependenciesPi.generated.js'; +import { createUppercasePi } from '../../factoriesAny.js'; +export var PIDependencies = { + piDependencies, + createUppercasePi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolve.generated.js new file mode 100644 index 0000000..ca89b20 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolve.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUsolve } from '../../factoriesAny.js'; +export var usolveDependencies = { + DenseMatrixDependencies, + divideScalarDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + subtractScalarDependencies, + typedDependencies, + createUsolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolveAll.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolveAll.generated.js new file mode 100644 index 0000000..263b99f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesUsolveAll.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUsolveAll } from '../../factoriesAny.js'; +export var usolveAllDependencies = { + DenseMatrixDependencies, + divideScalarDependencies, + equalScalarDependencies, + matrixDependencies, + multiplyScalarDependencies, + subtractScalarDependencies, + typedDependencies, + createUsolveAll +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js new file mode 100644 index 0000000..6be2fb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createVacuumImpedance } from '../../factoriesAny.js'; +export var vacuumImpedanceDependencies = { + BigNumberDependencies, + UnitDependencies, + createVacuumImpedance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVariance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVariance.generated.js new file mode 100644 index 0000000..49151a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVariance.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { applyDependencies } from './dependenciesApply.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createVariance } from '../../factoriesAny.js'; +export var varianceDependencies = { + addDependencies, + applyDependencies, + divideDependencies, + isNaNDependencies, + multiplyDependencies, + subtractDependencies, + typedDependencies, + createVariance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVarianceTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVarianceTransform.generated.js new file mode 100644 index 0000000..6095933 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVarianceTransform.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { applyDependencies } from './dependenciesApply.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createVarianceTransform } from '../../factoriesAny.js'; +export var varianceTransformDependencies = { + addDependencies, + applyDependencies, + divideDependencies, + isNaNDependencies, + multiplyDependencies, + subtractDependencies, + typedDependencies, + createVarianceTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVersion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVersion.generated.js new file mode 100644 index 0000000..7c895fe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesVersion.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createVersion } from '../../factoriesAny.js'; +export var versionDependencies = { + createVersion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js new file mode 100644 index 0000000..716bbf1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { createWeakMixingAngle } from '../../factoriesAny.js'; +export var weakMixingAngleDependencies = { + BigNumberDependencies, + createWeakMixingAngle +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWienDisplacement.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWienDisplacement.generated.js new file mode 100644 index 0000000..221b0b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesWienDisplacement.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { UnitDependencies } from './dependenciesUnitClass.generated.js'; +import { createWienDisplacement } from '../../factoriesAny.js'; +export var wienDisplacementDependencies = { + BigNumberDependencies, + UnitDependencies, + createWienDisplacement +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXgcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXgcd.generated.js new file mode 100644 index 0000000..a2e24d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXgcd.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createXgcd } from '../../factoriesAny.js'; +export var xgcdDependencies = { + BigNumberDependencies, + matrixDependencies, + typedDependencies, + createXgcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXor.generated.js new file mode 100644 index 0000000..caed806 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesXor.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js'; +import { concatDependencies } from './dependenciesConcat.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createXor } from '../../factoriesAny.js'; +export var xorDependencies = { + DenseMatrixDependencies, + concatDependencies, + matrixDependencies, + typedDependencies, + createXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeros.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeros.generated.js new file mode 100644 index 0000000..de21eba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeros.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createZeros } from '../../factoriesAny.js'; +export var zerosDependencies = { + BigNumberDependencies, + matrixDependencies, + typedDependencies, + createZeros +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeta.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeta.generated.js new file mode 100644 index 0000000..b75ed9f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZeta.generated.js @@ -0,0 +1,38 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { BigNumberDependencies } from './dependenciesBigNumberClass.generated.js'; +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { gammaDependencies } from './dependenciesGamma.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { piDependencies } from './dependenciesPi.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { sinDependencies } from './dependenciesSin.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createZeta } from '../../factoriesAny.js'; +export var zetaDependencies = { + BigNumberDependencies, + ComplexDependencies, + addDependencies, + divideDependencies, + equalDependencies, + factorialDependencies, + gammaDependencies, + isNegativeDependencies, + multiplyDependencies, + piDependencies, + powDependencies, + sinDependencies, + smallerEqDependencies, + subtractDependencies, + typedDependencies, + createZeta +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZpk2tf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZpk2tf.generated.js new file mode 100644 index 0000000..bae859a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesAny/dependenciesZpk2tf.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ComplexDependencies } from './dependenciesComplexClass.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createZpk2tf } from '../../factoriesAny.js'; +export var zpk2tfDependencies = { + ComplexDependencies, + addDependencies, + multiplyDependencies, + numberDependencies, + typedDependencies, + createZpk2tf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber.generated.js new file mode 100644 index 0000000..a77adfe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber.generated.js @@ -0,0 +1,210 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +export { absDependencies } from './dependenciesNumber/dependenciesAbs.generated.js'; +export { AccessorNodeDependencies } from './dependenciesNumber/dependenciesAccessorNode.generated.js'; +export { acosDependencies } from './dependenciesNumber/dependenciesAcos.generated.js'; +export { acoshDependencies } from './dependenciesNumber/dependenciesAcosh.generated.js'; +export { acotDependencies } from './dependenciesNumber/dependenciesAcot.generated.js'; +export { acothDependencies } from './dependenciesNumber/dependenciesAcoth.generated.js'; +export { acscDependencies } from './dependenciesNumber/dependenciesAcsc.generated.js'; +export { acschDependencies } from './dependenciesNumber/dependenciesAcsch.generated.js'; +export { addDependencies } from './dependenciesNumber/dependenciesAdd.generated.js'; +export { addScalarDependencies } from './dependenciesNumber/dependenciesAddScalar.generated.js'; +export { andDependencies } from './dependenciesNumber/dependenciesAnd.generated.js'; +export { applyDependencies } from './dependenciesNumber/dependenciesApply.generated.js'; +export { applyTransformDependencies } from './dependenciesNumber/dependenciesApplyTransform.generated.js'; +export { ArrayNodeDependencies } from './dependenciesNumber/dependenciesArrayNode.generated.js'; +export { asecDependencies } from './dependenciesNumber/dependenciesAsec.generated.js'; +export { asechDependencies } from './dependenciesNumber/dependenciesAsech.generated.js'; +export { asinDependencies } from './dependenciesNumber/dependenciesAsin.generated.js'; +export { asinhDependencies } from './dependenciesNumber/dependenciesAsinh.generated.js'; +export { AssignmentNodeDependencies } from './dependenciesNumber/dependenciesAssignmentNode.generated.js'; +export { atanDependencies } from './dependenciesNumber/dependenciesAtan.generated.js'; +export { atan2Dependencies } from './dependenciesNumber/dependenciesAtan2.generated.js'; +export { atanhDependencies } from './dependenciesNumber/dependenciesAtanh.generated.js'; +export { bellNumbersDependencies } from './dependenciesNumber/dependenciesBellNumbers.generated.js'; +export { bigintDependencies } from './dependenciesNumber/dependenciesBigint.generated.js'; +export { bitAndDependencies } from './dependenciesNumber/dependenciesBitAnd.generated.js'; +export { bitNotDependencies } from './dependenciesNumber/dependenciesBitNot.generated.js'; +export { bitOrDependencies } from './dependenciesNumber/dependenciesBitOr.generated.js'; +export { bitXorDependencies } from './dependenciesNumber/dependenciesBitXor.generated.js'; +export { BlockNodeDependencies } from './dependenciesNumber/dependenciesBlockNode.generated.js'; +export { booleanDependencies } from './dependenciesNumber/dependenciesBoolean.generated.js'; +export { catalanDependencies } from './dependenciesNumber/dependenciesCatalan.generated.js'; +export { cbrtDependencies } from './dependenciesNumber/dependenciesCbrt.generated.js'; +export { ceilDependencies } from './dependenciesNumber/dependenciesCeil.generated.js'; +export { chainDependencies } from './dependenciesNumber/dependenciesChain.generated.js'; +export { ChainDependencies } from './dependenciesNumber/dependenciesChainClass.generated.js'; +export { cloneDependencies } from './dependenciesNumber/dependenciesClone.generated.js'; +export { combinationsDependencies } from './dependenciesNumber/dependenciesCombinations.generated.js'; +export { combinationsWithRepDependencies } from './dependenciesNumber/dependenciesCombinationsWithRep.generated.js'; +export { compareDependencies } from './dependenciesNumber/dependenciesCompare.generated.js'; +export { compareNaturalDependencies } from './dependenciesNumber/dependenciesCompareNatural.generated.js'; +export { compareTextDependencies } from './dependenciesNumber/dependenciesCompareText.generated.js'; +export { compileDependencies } from './dependenciesNumber/dependenciesCompile.generated.js'; +export { compositionDependencies } from './dependenciesNumber/dependenciesComposition.generated.js'; +export { ConditionalNodeDependencies } from './dependenciesNumber/dependenciesConditionalNode.generated.js'; +export { ConstantNodeDependencies } from './dependenciesNumber/dependenciesConstantNode.generated.js'; +export { corrDependencies } from './dependenciesNumber/dependenciesCorr.generated.js'; +export { cosDependencies } from './dependenciesNumber/dependenciesCos.generated.js'; +export { coshDependencies } from './dependenciesNumber/dependenciesCosh.generated.js'; +export { cotDependencies } from './dependenciesNumber/dependenciesCot.generated.js'; +export { cothDependencies } from './dependenciesNumber/dependenciesCoth.generated.js'; +export { cscDependencies } from './dependenciesNumber/dependenciesCsc.generated.js'; +export { cschDependencies } from './dependenciesNumber/dependenciesCsch.generated.js'; +export { cubeDependencies } from './dependenciesNumber/dependenciesCube.generated.js'; +export { cumsumDependencies } from './dependenciesNumber/dependenciesCumSum.generated.js'; +export { cumsumTransformDependencies } from './dependenciesNumber/dependenciesCumSumTransform.generated.js'; +export { deepEqualDependencies } from './dependenciesNumber/dependenciesDeepEqual.generated.js'; +export { derivativeDependencies } from './dependenciesNumber/dependenciesDerivative.generated.js'; +export { divideDependencies } from './dependenciesNumber/dependenciesDivide.generated.js'; +export { divideScalarDependencies } from './dependenciesNumber/dependenciesDivideScalar.generated.js'; +export { eDependencies } from './dependenciesNumber/dependenciesE.generated.js'; +export { equalDependencies } from './dependenciesNumber/dependenciesEqual.generated.js'; +export { equalScalarDependencies } from './dependenciesNumber/dependenciesEqualScalar.generated.js'; +export { equalTextDependencies } from './dependenciesNumber/dependenciesEqualText.generated.js'; +export { erfDependencies } from './dependenciesNumber/dependenciesErf.generated.js'; +export { evaluateDependencies } from './dependenciesNumber/dependenciesEvaluate.generated.js'; +export { expDependencies } from './dependenciesNumber/dependenciesExp.generated.js'; +export { expm1Dependencies } from './dependenciesNumber/dependenciesExpm1.generated.js'; +export { factorialDependencies } from './dependenciesNumber/dependenciesFactorial.generated.js'; +export { falseDependencies } from './dependenciesNumber/dependenciesFalse.generated.js'; +export { filterDependencies } from './dependenciesNumber/dependenciesFilter.generated.js'; +export { filterTransformDependencies } from './dependenciesNumber/dependenciesFilterTransform.generated.js'; +export { fixDependencies } from './dependenciesNumber/dependenciesFix.generated.js'; +export { floorDependencies } from './dependenciesNumber/dependenciesFloor.generated.js'; +export { forEachDependencies } from './dependenciesNumber/dependenciesForEach.generated.js'; +export { forEachTransformDependencies } from './dependenciesNumber/dependenciesForEachTransform.generated.js'; +export { formatDependencies } from './dependenciesNumber/dependenciesFormat.generated.js'; +export { FunctionAssignmentNodeDependencies } from './dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js'; +export { FunctionNodeDependencies } from './dependenciesNumber/dependenciesFunctionNode.generated.js'; +export { gammaDependencies } from './dependenciesNumber/dependenciesGamma.generated.js'; +export { gcdDependencies } from './dependenciesNumber/dependenciesGcd.generated.js'; +export { hasNumericValueDependencies } from './dependenciesNumber/dependenciesHasNumericValue.generated.js'; +export { helpDependencies } from './dependenciesNumber/dependenciesHelp.generated.js'; +export { HelpDependencies } from './dependenciesNumber/dependenciesHelpClass.generated.js'; +export { hypotDependencies } from './dependenciesNumber/dependenciesHypot.generated.js'; +export { indexDependencies } from './dependenciesNumber/dependenciesIndex.generated.js'; +export { IndexNodeDependencies } from './dependenciesNumber/dependenciesIndexNode.generated.js'; +export { InfinityDependencies } from './dependenciesNumber/dependenciesInfinity.generated.js'; +export { isIntegerDependencies } from './dependenciesNumber/dependenciesIsInteger.generated.js'; +export { isNaNDependencies } from './dependenciesNumber/dependenciesIsNaN.generated.js'; +export { isNegativeDependencies } from './dependenciesNumber/dependenciesIsNegative.generated.js'; +export { isNumericDependencies } from './dependenciesNumber/dependenciesIsNumeric.generated.js'; +export { isPositiveDependencies } from './dependenciesNumber/dependenciesIsPositive.generated.js'; +export { isPrimeDependencies } from './dependenciesNumber/dependenciesIsPrime.generated.js'; +export { isZeroDependencies } from './dependenciesNumber/dependenciesIsZero.generated.js'; +export { LN10Dependencies } from './dependenciesNumber/dependenciesLN10.generated.js'; +export { LN2Dependencies } from './dependenciesNumber/dependenciesLN2.generated.js'; +export { LOG10EDependencies } from './dependenciesNumber/dependenciesLOG10E.generated.js'; +export { LOG2EDependencies } from './dependenciesNumber/dependenciesLOG2E.generated.js'; +export { largerDependencies } from './dependenciesNumber/dependenciesLarger.generated.js'; +export { largerEqDependencies } from './dependenciesNumber/dependenciesLargerEq.generated.js'; +export { lcmDependencies } from './dependenciesNumber/dependenciesLcm.generated.js'; +export { leftShiftDependencies } from './dependenciesNumber/dependenciesLeftShift.generated.js'; +export { lgammaDependencies } from './dependenciesNumber/dependenciesLgamma.generated.js'; +export { logDependencies } from './dependenciesNumber/dependenciesLog.generated.js'; +export { log10Dependencies } from './dependenciesNumber/dependenciesLog10.generated.js'; +export { log1pDependencies } from './dependenciesNumber/dependenciesLog1p.generated.js'; +export { log2Dependencies } from './dependenciesNumber/dependenciesLog2.generated.js'; +export { madDependencies } from './dependenciesNumber/dependenciesMad.generated.js'; +export { mapDependencies } from './dependenciesNumber/dependenciesMap.generated.js'; +export { mapTransformDependencies } from './dependenciesNumber/dependenciesMapTransform.generated.js'; +export { matrixDependencies } from './dependenciesNumber/dependenciesMatrix.generated.js'; +export { maxDependencies } from './dependenciesNumber/dependenciesMax.generated.js'; +export { maxTransformDependencies } from './dependenciesNumber/dependenciesMaxTransform.generated.js'; +export { meanDependencies } from './dependenciesNumber/dependenciesMean.generated.js'; +export { meanTransformDependencies } from './dependenciesNumber/dependenciesMeanTransform.generated.js'; +export { medianDependencies } from './dependenciesNumber/dependenciesMedian.generated.js'; +export { minDependencies } from './dependenciesNumber/dependenciesMin.generated.js'; +export { minTransformDependencies } from './dependenciesNumber/dependenciesMinTransform.generated.js'; +export { modDependencies } from './dependenciesNumber/dependenciesMod.generated.js'; +export { modeDependencies } from './dependenciesNumber/dependenciesMode.generated.js'; +export { multinomialDependencies } from './dependenciesNumber/dependenciesMultinomial.generated.js'; +export { multiplyDependencies } from './dependenciesNumber/dependenciesMultiply.generated.js'; +export { multiplyScalarDependencies } from './dependenciesNumber/dependenciesMultiplyScalar.generated.js'; +export { NaNDependencies } from './dependenciesNumber/dependenciesNaN.generated.js'; +export { NodeDependencies } from './dependenciesNumber/dependenciesNode.generated.js'; +export { normDependencies } from './dependenciesNumber/dependenciesNorm.generated.js'; +export { notDependencies } from './dependenciesNumber/dependenciesNot.generated.js'; +export { nthRootDependencies } from './dependenciesNumber/dependenciesNthRoot.generated.js'; +export { nullDependencies } from './dependenciesNumber/dependenciesNull.generated.js'; +export { numberDependencies } from './dependenciesNumber/dependenciesNumber.generated.js'; +export { numericDependencies } from './dependenciesNumber/dependenciesNumeric.generated.js'; +export { ObjectNodeDependencies } from './dependenciesNumber/dependenciesObjectNode.generated.js'; +export { OperatorNodeDependencies } from './dependenciesNumber/dependenciesOperatorNode.generated.js'; +export { orDependencies } from './dependenciesNumber/dependenciesOr.generated.js'; +export { ParenthesisNodeDependencies } from './dependenciesNumber/dependenciesParenthesisNode.generated.js'; +export { parseDependencies } from './dependenciesNumber/dependenciesParse.generated.js'; +export { parserDependencies } from './dependenciesNumber/dependenciesParser.generated.js'; +export { ParserDependencies } from './dependenciesNumber/dependenciesParserClass.generated.js'; +export { partitionSelectDependencies } from './dependenciesNumber/dependenciesPartitionSelect.generated.js'; +export { permutationsDependencies } from './dependenciesNumber/dependenciesPermutations.generated.js'; +export { phiDependencies } from './dependenciesNumber/dependenciesPhi.generated.js'; +export { piDependencies } from './dependenciesNumber/dependenciesPi.generated.js'; +export { pickRandomDependencies } from './dependenciesNumber/dependenciesPickRandom.generated.js'; +export { powDependencies } from './dependenciesNumber/dependenciesPow.generated.js'; +export { printDependencies } from './dependenciesNumber/dependenciesPrint.generated.js'; +export { prodDependencies } from './dependenciesNumber/dependenciesProd.generated.js'; +export { quantileSeqDependencies } from './dependenciesNumber/dependenciesQuantileSeq.generated.js'; +export { randomDependencies } from './dependenciesNumber/dependenciesRandom.generated.js'; +export { randomIntDependencies } from './dependenciesNumber/dependenciesRandomInt.generated.js'; +export { rangeDependencies } from './dependenciesNumber/dependenciesRange.generated.js'; +export { RangeDependencies } from './dependenciesNumber/dependenciesRangeClass.generated.js'; +export { RangeNodeDependencies } from './dependenciesNumber/dependenciesRangeNode.generated.js'; +export { rangeTransformDependencies } from './dependenciesNumber/dependenciesRangeTransform.generated.js'; +export { rationalizeDependencies } from './dependenciesNumber/dependenciesRationalize.generated.js'; +export { RelationalNodeDependencies } from './dependenciesNumber/dependenciesRelationalNode.generated.js'; +export { replacerDependencies } from './dependenciesNumber/dependenciesReplacer.generated.js'; +export { resolveDependencies } from './dependenciesNumber/dependenciesResolve.generated.js'; +export { ResultSetDependencies } from './dependenciesNumber/dependenciesResultSet.generated.js'; +export { reviverDependencies } from './dependenciesNumber/dependenciesReviver.generated.js'; +export { rightArithShiftDependencies } from './dependenciesNumber/dependenciesRightArithShift.generated.js'; +export { rightLogShiftDependencies } from './dependenciesNumber/dependenciesRightLogShift.generated.js'; +export { roundDependencies } from './dependenciesNumber/dependenciesRound.generated.js'; +export { SQRT1_2Dependencies } from './dependenciesNumber/dependenciesSQRT1_2.generated.js'; // eslint-disable-line camelcase +export { SQRT2Dependencies } from './dependenciesNumber/dependenciesSQRT2.generated.js'; +export { secDependencies } from './dependenciesNumber/dependenciesSec.generated.js'; +export { sechDependencies } from './dependenciesNumber/dependenciesSech.generated.js'; +export { signDependencies } from './dependenciesNumber/dependenciesSign.generated.js'; +export { simplifyDependencies } from './dependenciesNumber/dependenciesSimplify.generated.js'; +export { simplifyConstantDependencies } from './dependenciesNumber/dependenciesSimplifyConstant.generated.js'; +export { simplifyCoreDependencies } from './dependenciesNumber/dependenciesSimplifyCore.generated.js'; +export { sinDependencies } from './dependenciesNumber/dependenciesSin.generated.js'; +export { sinhDependencies } from './dependenciesNumber/dependenciesSinh.generated.js'; +export { sizeDependencies } from './dependenciesNumber/dependenciesSize.generated.js'; +export { smallerDependencies } from './dependenciesNumber/dependenciesSmaller.generated.js'; +export { smallerEqDependencies } from './dependenciesNumber/dependenciesSmallerEq.generated.js'; +export { sqrtDependencies } from './dependenciesNumber/dependenciesSqrt.generated.js'; +export { squareDependencies } from './dependenciesNumber/dependenciesSquare.generated.js'; +export { stdDependencies } from './dependenciesNumber/dependenciesStd.generated.js'; +export { stdTransformDependencies } from './dependenciesNumber/dependenciesStdTransform.generated.js'; +export { stirlingS2Dependencies } from './dependenciesNumber/dependenciesStirlingS2.generated.js'; +export { stringDependencies } from './dependenciesNumber/dependenciesString.generated.js'; +export { subsetDependencies } from './dependenciesNumber/dependenciesSubset.generated.js'; +export { subsetTransformDependencies } from './dependenciesNumber/dependenciesSubsetTransform.generated.js'; +export { subtractDependencies } from './dependenciesNumber/dependenciesSubtract.generated.js'; +export { subtractScalarDependencies } from './dependenciesNumber/dependenciesSubtractScalar.generated.js'; +export { sumDependencies } from './dependenciesNumber/dependenciesSum.generated.js'; +export { sumTransformDependencies } from './dependenciesNumber/dependenciesSumTransform.generated.js'; +export { SymbolNodeDependencies } from './dependenciesNumber/dependenciesSymbolNode.generated.js'; +export { tanDependencies } from './dependenciesNumber/dependenciesTan.generated.js'; +export { tanhDependencies } from './dependenciesNumber/dependenciesTanh.generated.js'; +export { tauDependencies } from './dependenciesNumber/dependenciesTau.generated.js'; +export { trueDependencies } from './dependenciesNumber/dependenciesTrue.generated.js'; +export { typeOfDependencies } from './dependenciesNumber/dependenciesTypeOf.generated.js'; +export { typedDependencies } from './dependenciesNumber/dependenciesTyped.generated.js'; +export { unaryMinusDependencies } from './dependenciesNumber/dependenciesUnaryMinus.generated.js'; +export { unaryPlusDependencies } from './dependenciesNumber/dependenciesUnaryPlus.generated.js'; +export { unequalDependencies } from './dependenciesNumber/dependenciesUnequal.generated.js'; +export { EDependencies } from './dependenciesNumber/dependenciesUppercaseE.generated.js'; +export { PIDependencies } from './dependenciesNumber/dependenciesUppercasePi.generated.js'; +export { varianceDependencies } from './dependenciesNumber/dependenciesVariance.generated.js'; +export { varianceTransformDependencies } from './dependenciesNumber/dependenciesVarianceTransform.generated.js'; +export { versionDependencies } from './dependenciesNumber/dependenciesVersion.generated.js'; +export { xgcdDependencies } from './dependenciesNumber/dependenciesXgcd.generated.js'; +export { xorDependencies } from './dependenciesNumber/dependenciesXor.generated.js'; +export { zetaDependencies } from './dependenciesNumber/dependenciesZeta.generated.js'; +export { all } from './allFactoriesNumber.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAbs.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAbs.generated.js new file mode 100644 index 0000000..8e76a18 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAbs.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAbs } from '../../factoriesNumber.js'; +export var absDependencies = { + typedDependencies, + createAbs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAccessorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAccessorNode.generated.js new file mode 100644 index 0000000..eb1fee5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAccessorNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { createAccessorNode } from '../../factoriesNumber.js'; +export var AccessorNodeDependencies = { + NodeDependencies, + subsetDependencies, + createAccessorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcos.generated.js new file mode 100644 index 0000000..898a51e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcos.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcos } from '../../factoriesNumber.js'; +export var acosDependencies = { + typedDependencies, + createAcos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcosh.generated.js new file mode 100644 index 0000000..b84cc05 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcosh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcosh } from '../../factoriesNumber.js'; +export var acoshDependencies = { + typedDependencies, + createAcosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcot.generated.js new file mode 100644 index 0000000..f8db302 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcot } from '../../factoriesNumber.js'; +export var acotDependencies = { + typedDependencies, + createAcot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcoth.generated.js new file mode 100644 index 0000000..a14ff92 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcoth.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcoth } from '../../factoriesNumber.js'; +export var acothDependencies = { + typedDependencies, + createAcoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsc.generated.js new file mode 100644 index 0000000..bc87242 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsc.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcsc } from '../../factoriesNumber.js'; +export var acscDependencies = { + typedDependencies, + createAcsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsch.generated.js new file mode 100644 index 0000000..3faae99 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAcsch.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAcsch } from '../../factoriesNumber.js'; +export var acschDependencies = { + typedDependencies, + createAcsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAdd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAdd.generated.js new file mode 100644 index 0000000..a440e5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAdd.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAdd } from '../../factoriesNumber.js'; +export var addDependencies = { + typedDependencies, + createAdd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAddScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAddScalar.generated.js new file mode 100644 index 0000000..47cb618 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAddScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAddScalar } from '../../factoriesNumber.js'; +export var addScalarDependencies = { + typedDependencies, + createAddScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAnd.generated.js new file mode 100644 index 0000000..045289d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAnd.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAnd } from '../../factoriesNumber.js'; +export var andDependencies = { + typedDependencies, + createAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApply.generated.js new file mode 100644 index 0000000..fac00eb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApply.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createApply } from '../../factoriesNumber.js'; +export var applyDependencies = { + isIntegerDependencies, + typedDependencies, + createApply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApplyTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApplyTransform.generated.js new file mode 100644 index 0000000..003efa3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesApplyTransform.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createApplyTransform } from '../../factoriesNumber.js'; +export var applyTransformDependencies = { + isIntegerDependencies, + typedDependencies, + createApplyTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesArrayNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesArrayNode.generated.js new file mode 100644 index 0000000..0651558 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesArrayNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createArrayNode } from '../../factoriesNumber.js'; +export var ArrayNodeDependencies = { + NodeDependencies, + createArrayNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsec.generated.js new file mode 100644 index 0000000..79fafbe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsec.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsec } from '../../factoriesNumber.js'; +export var asecDependencies = { + typedDependencies, + createAsec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsech.generated.js new file mode 100644 index 0000000..607f607 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsech.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsech } from '../../factoriesNumber.js'; +export var asechDependencies = { + typedDependencies, + createAsech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsin.generated.js new file mode 100644 index 0000000..631c616 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsin.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsin } from '../../factoriesNumber.js'; +export var asinDependencies = { + typedDependencies, + createAsin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsinh.generated.js new file mode 100644 index 0000000..d55d45e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAsinh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAsinh } from '../../factoriesNumber.js'; +export var asinhDependencies = { + typedDependencies, + createAsinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js new file mode 100644 index 0000000..7f83cec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAssignmentNode.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { subsetDependencies } from './dependenciesSubset.generated.js'; +import { createAssignmentNode } from '../../factoriesNumber.js'; +export var AssignmentNodeDependencies = { + matrixDependencies, + NodeDependencies, + subsetDependencies, + createAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan.generated.js new file mode 100644 index 0000000..ed88d81 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtan } from '../../factoriesNumber.js'; +export var atanDependencies = { + typedDependencies, + createAtan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan2.generated.js new file mode 100644 index 0000000..8aaaafa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtan2.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtan2 } from '../../factoriesNumber.js'; +export var atan2Dependencies = { + typedDependencies, + createAtan2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtanh.generated.js new file mode 100644 index 0000000..d5b8076 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesAtanh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createAtanh } from '../../factoriesNumber.js'; +export var atanhDependencies = { + typedDependencies, + createAtanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBellNumbers.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBellNumbers.generated.js new file mode 100644 index 0000000..5464e7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBellNumbers.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { stirlingS2Dependencies } from './dependenciesStirlingS2.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBellNumbers } from '../../factoriesNumber.js'; +export var bellNumbersDependencies = { + addScalarDependencies, + isIntegerDependencies, + isNegativeDependencies, + stirlingS2Dependencies, + typedDependencies, + createBellNumbers +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBigint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBigint.generated.js new file mode 100644 index 0000000..77f9760 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBigint.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBigint } from '../../factoriesNumber.js'; +export var bigintDependencies = { + typedDependencies, + createBigint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitAnd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitAnd.generated.js new file mode 100644 index 0000000..68268db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitAnd.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitAnd } from '../../factoriesNumber.js'; +export var bitAndDependencies = { + typedDependencies, + createBitAnd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitNot.generated.js new file mode 100644 index 0000000..a8c3bdc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitNot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitNot } from '../../factoriesNumber.js'; +export var bitNotDependencies = { + typedDependencies, + createBitNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitOr.generated.js new file mode 100644 index 0000000..4aeaeda --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitOr.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitOr } from '../../factoriesNumber.js'; +export var bitOrDependencies = { + typedDependencies, + createBitOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitXor.generated.js new file mode 100644 index 0000000..81badcb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBitXor.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBitXor } from '../../factoriesNumber.js'; +export var bitXorDependencies = { + typedDependencies, + createBitXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBlockNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBlockNode.generated.js new file mode 100644 index 0000000..0043939 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBlockNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { ResultSetDependencies } from './dependenciesResultSet.generated.js'; +import { createBlockNode } from '../../factoriesNumber.js'; +export var BlockNodeDependencies = { + NodeDependencies, + ResultSetDependencies, + createBlockNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBoolean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBoolean.generated.js new file mode 100644 index 0000000..f25ec83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesBoolean.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createBoolean } from '../../factoriesNumber.js'; +export var booleanDependencies = { + typedDependencies, + createBoolean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCatalan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCatalan.generated.js new file mode 100644 index 0000000..1933851 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCatalan.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCatalan } from '../../factoriesNumber.js'; +export var catalanDependencies = { + addScalarDependencies, + combinationsDependencies, + divideScalarDependencies, + isIntegerDependencies, + isNegativeDependencies, + multiplyScalarDependencies, + typedDependencies, + createCatalan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCbrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCbrt.generated.js new file mode 100644 index 0000000..48c4f97 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCbrt.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCbrt } from '../../factoriesNumber.js'; +export var cbrtDependencies = { + typedDependencies, + createCbrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCeil.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCeil.generated.js new file mode 100644 index 0000000..8563817 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCeil.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCeil } from '../../factoriesNumber.js'; +export var ceilDependencies = { + roundDependencies, + typedDependencies, + createCeil +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChain.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChain.generated.js new file mode 100644 index 0000000..71e7b15 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChain.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ChainDependencies } from './dependenciesChainClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createChain } from '../../factoriesNumber.js'; +export var chainDependencies = { + ChainDependencies, + typedDependencies, + createChain +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChainClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChainClass.generated.js new file mode 100644 index 0000000..6a1b57f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesChainClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createChainClass } from '../../factoriesNumber.js'; +export var ChainDependencies = { + typedDependencies, + createChainClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesClone.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesClone.generated.js new file mode 100644 index 0000000..8041edc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesClone.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createClone } from '../../factoriesNumber.js'; +export var cloneDependencies = { + typedDependencies, + createClone +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinations.generated.js new file mode 100644 index 0000000..9cda3b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinations.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCombinations } from '../../factoriesNumber.js'; +export var combinationsDependencies = { + typedDependencies, + createCombinations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js new file mode 100644 index 0000000..e1e4790 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCombinationsWithRep.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCombinationsWithRep } from '../../factoriesNumber.js'; +export var combinationsWithRepDependencies = { + typedDependencies, + createCombinationsWithRep +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompare.generated.js new file mode 100644 index 0000000..c884350 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompare.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompare } from '../../factoriesNumber.js'; +export var compareDependencies = { + typedDependencies, + createCompare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareNatural.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareNatural.generated.js new file mode 100644 index 0000000..9755e62 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareNatural.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompareNatural } from '../../factoriesNumber.js'; +export var compareNaturalDependencies = { + compareDependencies, + typedDependencies, + createCompareNatural +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareText.generated.js new file mode 100644 index 0000000..ea978ce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompareText.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompareText } from '../../factoriesNumber.js'; +export var compareTextDependencies = { + typedDependencies, + createCompareText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompile.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompile.generated.js new file mode 100644 index 0000000..542a1f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCompile.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCompile } from '../../factoriesNumber.js'; +export var compileDependencies = { + parseDependencies, + typedDependencies, + createCompile +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesComposition.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesComposition.generated.js new file mode 100644 index 0000000..f330d8e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesComposition.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createComposition } from '../../factoriesNumber.js'; +export var compositionDependencies = { + addScalarDependencies, + combinationsDependencies, + isIntegerDependencies, + isNegativeDependencies, + isPositiveDependencies, + largerDependencies, + typedDependencies, + createComposition +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConditionalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConditionalNode.generated.js new file mode 100644 index 0000000..4c34e6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConditionalNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createConditionalNode } from '../../factoriesNumber.js'; +export var ConditionalNodeDependencies = { + NodeDependencies, + createConditionalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConstantNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConstantNode.generated.js new file mode 100644 index 0000000..475a167 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesConstantNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createConstantNode } from '../../factoriesNumber.js'; +export var ConstantNodeDependencies = { + NodeDependencies, + createConstantNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCorr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCorr.generated.js new file mode 100644 index 0000000..d5c9449 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCorr.generated.js @@ -0,0 +1,28 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { meanDependencies } from './dependenciesMean.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { sumDependencies } from './dependenciesSum.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCorr } from '../../factoriesNumber.js'; +export var corrDependencies = { + addDependencies, + divideDependencies, + matrixDependencies, + meanDependencies, + multiplyDependencies, + powDependencies, + sqrtDependencies, + subtractDependencies, + sumDependencies, + typedDependencies, + createCorr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCos.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCos.generated.js new file mode 100644 index 0000000..3e5005c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCos.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCos } from '../../factoriesNumber.js'; +export var cosDependencies = { + typedDependencies, + createCos +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCosh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCosh.generated.js new file mode 100644 index 0000000..2baafcc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCosh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCosh } from '../../factoriesNumber.js'; +export var coshDependencies = { + typedDependencies, + createCosh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCot.generated.js new file mode 100644 index 0000000..674ee60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCot } from '../../factoriesNumber.js'; +export var cotDependencies = { + typedDependencies, + createCot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCoth.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCoth.generated.js new file mode 100644 index 0000000..7a0499a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCoth.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCoth } from '../../factoriesNumber.js'; +export var cothDependencies = { + typedDependencies, + createCoth +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsc.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsc.generated.js new file mode 100644 index 0000000..9f657c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsc.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCsc } from '../../factoriesNumber.js'; +export var cscDependencies = { + typedDependencies, + createCsc +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsch.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsch.generated.js new file mode 100644 index 0000000..1744426 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCsch.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCsch } from '../../factoriesNumber.js'; +export var cschDependencies = { + typedDependencies, + createCsch +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCube.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCube.generated.js new file mode 100644 index 0000000..c4ae1d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCube.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createCube } from '../../factoriesNumber.js'; +export var cubeDependencies = { + typedDependencies, + createCube +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSum.generated.js new file mode 100644 index 0000000..fb98496 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSum.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryPlusDependencies } from './dependenciesUnaryPlus.generated.js'; +import { createCumSum } from '../../factoriesNumber.js'; +export var cumsumDependencies = { + addDependencies, + typedDependencies, + unaryPlusDependencies, + createCumSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js new file mode 100644 index 0000000..4bc32c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesCumSumTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { unaryPlusDependencies } from './dependenciesUnaryPlus.generated.js'; +import { createCumSumTransform } from '../../factoriesNumber.js'; +export var cumsumTransformDependencies = { + addDependencies, + typedDependencies, + unaryPlusDependencies, + createCumSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDeepEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDeepEqual.generated.js new file mode 100644 index 0000000..994ed63 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDeepEqual.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDeepEqual } from '../../factoriesNumber.js'; +export var deepEqualDependencies = { + equalDependencies, + typedDependencies, + createDeepEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDerivative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDerivative.generated.js new file mode 100644 index 0000000..388309d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDerivative.generated.js @@ -0,0 +1,30 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { simplifyDependencies } from './dependenciesSimplify.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDerivative } from '../../factoriesNumber.js'; +export var derivativeDependencies = { + ConstantNodeDependencies, + FunctionNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + equalDependencies, + isZeroDependencies, + numericDependencies, + parseDependencies, + simplifyDependencies, + typedDependencies, + createDerivative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivide.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivide.generated.js new file mode 100644 index 0000000..cc18b98 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivide.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDivide } from '../../factoriesNumber.js'; +export var divideDependencies = { + typedDependencies, + createDivide +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivideScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivideScalar.generated.js new file mode 100644 index 0000000..7471996 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesDivideScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createDivideScalar } from '../../factoriesNumber.js'; +export var divideScalarDependencies = { + typedDependencies, + createDivideScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesE.generated.js new file mode 100644 index 0000000..734a86c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesE.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createE } from '../../factoriesNumber.js'; +export var eDependencies = { + createE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqual.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqual.generated.js new file mode 100644 index 0000000..f6efd58 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqual.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqual } from '../../factoriesNumber.js'; +export var equalDependencies = { + equalScalarDependencies, + typedDependencies, + createEqual +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualScalar.generated.js new file mode 100644 index 0000000..e8985ab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqualScalar } from '../../factoriesNumber.js'; +export var equalScalarDependencies = { + typedDependencies, + createEqualScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualText.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualText.generated.js new file mode 100644 index 0000000..cfcbd90 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEqualText.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareTextDependencies } from './dependenciesCompareText.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEqualText } from '../../factoriesNumber.js'; +export var equalTextDependencies = { + compareTextDependencies, + isZeroDependencies, + typedDependencies, + createEqualText +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesErf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesErf.generated.js new file mode 100644 index 0000000..ccc3714 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesErf.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createErf } from '../../factoriesNumber.js'; +export var erfDependencies = { + typedDependencies, + createErf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEvaluate.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEvaluate.generated.js new file mode 100644 index 0000000..b843c1c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesEvaluate.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createEvaluate } from '../../factoriesNumber.js'; +export var evaluateDependencies = { + parseDependencies, + typedDependencies, + createEvaluate +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExp.generated.js new file mode 100644 index 0000000..f1af13b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExp.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createExp } from '../../factoriesNumber.js'; +export var expDependencies = { + typedDependencies, + createExp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExpm1.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExpm1.generated.js new file mode 100644 index 0000000..5379c46 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesExpm1.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createExpm1 } from '../../factoriesNumber.js'; +export var expm1Dependencies = { + typedDependencies, + createExpm1 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFactorial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFactorial.generated.js new file mode 100644 index 0000000..9fe7608 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFactorial.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { gammaDependencies } from './dependenciesGamma.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFactorial } from '../../factoriesNumber.js'; +export var factorialDependencies = { + gammaDependencies, + typedDependencies, + createFactorial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFalse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFalse.generated.js new file mode 100644 index 0000000..ba9c2d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFalse.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createFalse } from '../../factoriesNumber.js'; +export var falseDependencies = { + createFalse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilter.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilter.generated.js new file mode 100644 index 0000000..365fbe3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilter.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFilter } from '../../factoriesNumber.js'; +export var filterDependencies = { + typedDependencies, + createFilter +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilterTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilterTransform.generated.js new file mode 100644 index 0000000..9195d5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFilterTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFilterTransform } from '../../factoriesNumber.js'; +export var filterTransformDependencies = { + typedDependencies, + createFilterTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFix.generated.js new file mode 100644 index 0000000..b0599c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFix.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ceilDependencies } from './dependenciesCeil.generated.js'; +import { floorDependencies } from './dependenciesFloor.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFix } from '../../factoriesNumber.js'; +export var fixDependencies = { + ceilDependencies, + floorDependencies, + typedDependencies, + createFix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFloor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFloor.generated.js new file mode 100644 index 0000000..d0a65ab --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFloor.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { roundDependencies } from './dependenciesRound.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFloor } from '../../factoriesNumber.js'; +export var floorDependencies = { + roundDependencies, + typedDependencies, + createFloor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEach.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEach.generated.js new file mode 100644 index 0000000..7bbdc94 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEach.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createForEach } from '../../factoriesNumber.js'; +export var forEachDependencies = { + typedDependencies, + createForEach +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEachTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEachTransform.generated.js new file mode 100644 index 0000000..f300f41 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesForEachTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createForEachTransform } from '../../factoriesNumber.js'; +export var forEachTransformDependencies = { + typedDependencies, + createForEachTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFormat.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFormat.generated.js new file mode 100644 index 0000000..7be7c47 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFormat.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFormat } from '../../factoriesNumber.js'; +export var formatDependencies = { + typedDependencies, + createFormat +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js new file mode 100644 index 0000000..fd579c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionAssignmentNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createFunctionAssignmentNode } from '../../factoriesNumber.js'; +export var FunctionAssignmentNodeDependencies = { + NodeDependencies, + typedDependencies, + createFunctionAssignmentNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionNode.generated.js new file mode 100644 index 0000000..24ec5d6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesFunctionNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { createFunctionNode } from '../../factoriesNumber.js'; +export var FunctionNodeDependencies = { + NodeDependencies, + SymbolNodeDependencies, + createFunctionNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGamma.generated.js new file mode 100644 index 0000000..c380fe5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGamma.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createGamma } from '../../factoriesNumber.js'; +export var gammaDependencies = { + typedDependencies, + createGamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGcd.generated.js new file mode 100644 index 0000000..47feec3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesGcd.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createGcd } from '../../factoriesNumber.js'; +export var gcdDependencies = { + typedDependencies, + createGcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js new file mode 100644 index 0000000..d742528 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHasNumericValue.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHasNumericValue } from '../../factoriesNumber.js'; +export var hasNumericValueDependencies = { + isNumericDependencies, + typedDependencies, + createHasNumericValue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelp.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelp.generated.js new file mode 100644 index 0000000..6afd037 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelp.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { HelpDependencies } from './dependenciesHelpClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHelp } from '../../factoriesNumber.js'; +export var helpDependencies = { + HelpDependencies, + typedDependencies, + createHelp +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelpClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelpClass.generated.js new file mode 100644 index 0000000..79b6fa0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHelpClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { evaluateDependencies } from './dependenciesEvaluate.generated.js'; +import { createHelpClass } from '../../factoriesNumber.js'; +export var HelpDependencies = { + evaluateDependencies, + createHelpClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHypot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHypot.generated.js new file mode 100644 index 0000000..fc777ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesHypot.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createHypot } from '../../factoriesNumber.js'; +export var hypotDependencies = { + absDependencies, + addScalarDependencies, + divideScalarDependencies, + isPositiveDependencies, + multiplyScalarDependencies, + smallerDependencies, + sqrtDependencies, + typedDependencies, + createHypot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndex.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndex.generated.js new file mode 100644 index 0000000..52f74db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndex.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createIndex } from '../../factoriesNumber.js'; +export var indexDependencies = { + createIndex +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndexNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndexNode.generated.js new file mode 100644 index 0000000..2d83eb2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIndexNode.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { sizeDependencies } from './dependenciesSize.generated.js'; +import { createIndexNode } from '../../factoriesNumber.js'; +export var IndexNodeDependencies = { + NodeDependencies, + sizeDependencies, + createIndexNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesInfinity.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesInfinity.generated.js new file mode 100644 index 0000000..9e44daf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesInfinity.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createInfinity } from '../../factoriesNumber.js'; +export var InfinityDependencies = { + createInfinity +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsInteger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsInteger.generated.js new file mode 100644 index 0000000..e00294f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsInteger.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsInteger } from '../../factoriesNumber.js'; +export var isIntegerDependencies = { + typedDependencies, + createIsInteger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNaN.generated.js new file mode 100644 index 0000000..abb7251 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNaN.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNaN } from '../../factoriesNumber.js'; +export var isNaNDependencies = { + typedDependencies, + createIsNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNegative.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNegative.generated.js new file mode 100644 index 0000000..853c1cb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNegative.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNegative } from '../../factoriesNumber.js'; +export var isNegativeDependencies = { + typedDependencies, + createIsNegative +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNumeric.generated.js new file mode 100644 index 0000000..92559b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsNumeric.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsNumeric } from '../../factoriesNumber.js'; +export var isNumericDependencies = { + typedDependencies, + createIsNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPositive.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPositive.generated.js new file mode 100644 index 0000000..f0364ca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPositive.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsPositive } from '../../factoriesNumber.js'; +export var isPositiveDependencies = { + typedDependencies, + createIsPositive +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPrime.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPrime.generated.js new file mode 100644 index 0000000..6640f72 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsPrime.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsPrime } from '../../factoriesNumber.js'; +export var isPrimeDependencies = { + typedDependencies, + createIsPrime +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsZero.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsZero.generated.js new file mode 100644 index 0000000..5421b80 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesIsZero.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createIsZero } from '../../factoriesNumber.js'; +export var isZeroDependencies = { + typedDependencies, + createIsZero +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN10.generated.js new file mode 100644 index 0000000..1400488 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN10.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createLN10 } from '../../factoriesNumber.js'; +export var LN10Dependencies = { + createLN10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN2.generated.js new file mode 100644 index 0000000..c2d6f69 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLN2.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createLN2 } from '../../factoriesNumber.js'; +export var LN2Dependencies = { + createLN2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG10E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG10E.generated.js new file mode 100644 index 0000000..c2b3459 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG10E.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createLOG10E } from '../../factoriesNumber.js'; +export var LOG10EDependencies = { + createLOG10E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG2E.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG2E.generated.js new file mode 100644 index 0000000..f3160ad --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLOG2E.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createLOG2E } from '../../factoriesNumber.js'; +export var LOG2EDependencies = { + createLOG2E +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLarger.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLarger.generated.js new file mode 100644 index 0000000..2f61473 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLarger.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLarger } from '../../factoriesNumber.js'; +export var largerDependencies = { + typedDependencies, + createLarger +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLargerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLargerEq.generated.js new file mode 100644 index 0000000..a4bb0d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLargerEq.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLargerEq } from '../../factoriesNumber.js'; +export var largerEqDependencies = { + typedDependencies, + createLargerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLcm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLcm.generated.js new file mode 100644 index 0000000..e4bd1f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLcm.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLcm } from '../../factoriesNumber.js'; +export var lcmDependencies = { + typedDependencies, + createLcm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLeftShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLeftShift.generated.js new file mode 100644 index 0000000..73200ac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLeftShift.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLeftShift } from '../../factoriesNumber.js'; +export var leftShiftDependencies = { + typedDependencies, + createLeftShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLgamma.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLgamma.generated.js new file mode 100644 index 0000000..6efa8be --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLgamma.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLgamma } from '../../factoriesNumber.js'; +export var lgammaDependencies = { + typedDependencies, + createLgamma +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog.generated.js new file mode 100644 index 0000000..cb01c2e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog } from '../../factoriesNumber.js'; +export var logDependencies = { + typedDependencies, + createLog +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog10.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog10.generated.js new file mode 100644 index 0000000..1fe8881 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog10.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog10 } from '../../factoriesNumber.js'; +export var log10Dependencies = { + typedDependencies, + createLog10 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog1p.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog1p.generated.js new file mode 100644 index 0000000..ca3d2c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog1p.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog1p } from '../../factoriesNumber.js'; +export var log1pDependencies = { + typedDependencies, + createLog1p +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog2.generated.js new file mode 100644 index 0000000..b05a6f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesLog2.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createLog2 } from '../../factoriesNumber.js'; +export var log2Dependencies = { + typedDependencies, + createLog2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMad.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMad.generated.js new file mode 100644 index 0000000..b0f4b23 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMad.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { absDependencies } from './dependenciesAbs.generated.js'; +import { mapDependencies } from './dependenciesMap.generated.js'; +import { medianDependencies } from './dependenciesMedian.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMad } from '../../factoriesNumber.js'; +export var madDependencies = { + absDependencies, + mapDependencies, + medianDependencies, + subtractDependencies, + typedDependencies, + createMad +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMap.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMap.generated.js new file mode 100644 index 0000000..471b19e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMap.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMap } from '../../factoriesNumber.js'; +export var mapDependencies = { + typedDependencies, + createMap +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMapTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMapTransform.generated.js new file mode 100644 index 0000000..5164952 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMapTransform.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMapTransform } from '../../factoriesNumber.js'; +export var mapTransformDependencies = { + typedDependencies, + createMapTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMatrix.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMatrix.generated.js new file mode 100644 index 0000000..243ce4d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMatrix.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createMatrix } from '../../factoriesNumber.js'; +export var matrixDependencies = { + createMatrix +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMax.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMax.generated.js new file mode 100644 index 0000000..ef1a6c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMax.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMax } from '../../factoriesNumber.js'; +export var maxDependencies = { + largerDependencies, + numericDependencies, + typedDependencies, + createMax +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMaxTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMaxTransform.generated.js new file mode 100644 index 0000000..0a8a682 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMaxTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMaxTransform } from '../../factoriesNumber.js'; +export var maxTransformDependencies = { + largerDependencies, + numericDependencies, + typedDependencies, + createMaxTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMean.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMean.generated.js new file mode 100644 index 0000000..b98f47c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMean.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMean } from '../../factoriesNumber.js'; +export var meanDependencies = { + addDependencies, + divideDependencies, + typedDependencies, + createMean +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMeanTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMeanTransform.generated.js new file mode 100644 index 0000000..303d649 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMeanTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMeanTransform } from '../../factoriesNumber.js'; +export var meanTransformDependencies = { + addDependencies, + divideDependencies, + typedDependencies, + createMeanTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMedian.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMedian.generated.js new file mode 100644 index 0000000..901be99 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMedian.generated.js @@ -0,0 +1,18 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { partitionSelectDependencies } from './dependenciesPartitionSelect.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMedian } from '../../factoriesNumber.js'; +export var medianDependencies = { + addDependencies, + compareDependencies, + divideDependencies, + partitionSelectDependencies, + typedDependencies, + createMedian +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMin.generated.js new file mode 100644 index 0000000..ad5a53e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMin.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMin } from '../../factoriesNumber.js'; +export var minDependencies = { + numericDependencies, + smallerDependencies, + typedDependencies, + createMin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMinTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMinTransform.generated.js new file mode 100644 index 0000000..9443dd3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMinTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMinTransform } from '../../factoriesNumber.js'; +export var minTransformDependencies = { + numericDependencies, + smallerDependencies, + typedDependencies, + createMinTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMod.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMod.generated.js new file mode 100644 index 0000000..05a3684 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMod.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMod } from '../../factoriesNumber.js'; +export var modDependencies = { + typedDependencies, + createMod +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMode.generated.js new file mode 100644 index 0000000..536d896 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMode.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMode } from '../../factoriesNumber.js'; +export var modeDependencies = { + isNaNDependencies, + isNumericDependencies, + typedDependencies, + createMode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultinomial.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultinomial.generated.js new file mode 100644 index 0000000..58da7ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultinomial.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultinomial } from '../../factoriesNumber.js'; +export var multinomialDependencies = { + addDependencies, + divideDependencies, + factorialDependencies, + isIntegerDependencies, + isPositiveDependencies, + multiplyDependencies, + typedDependencies, + createMultinomial +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiply.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiply.generated.js new file mode 100644 index 0000000..85e70b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiply.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultiply } from '../../factoriesNumber.js'; +export var multiplyDependencies = { + typedDependencies, + createMultiply +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js new file mode 100644 index 0000000..9227ace --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesMultiplyScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createMultiplyScalar } from '../../factoriesNumber.js'; +export var multiplyScalarDependencies = { + typedDependencies, + createMultiplyScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNaN.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNaN.generated.js new file mode 100644 index 0000000..f1d9672 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNaN.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createNaN } from '../../factoriesNumber.js'; +export var NaNDependencies = { + createNaN +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNode.generated.js new file mode 100644 index 0000000..65103e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNode.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createNode } from '../../factoriesNumber.js'; +export var NodeDependencies = { + createNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNorm.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNorm.generated.js new file mode 100644 index 0000000..c717d33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNorm.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNorm } from '../../factoriesNumber.js'; +export var normDependencies = { + typedDependencies, + createNorm +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNot.generated.js new file mode 100644 index 0000000..7dd2bfb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNot } from '../../factoriesNumber.js'; +export var notDependencies = { + typedDependencies, + createNot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNthRoot.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNthRoot.generated.js new file mode 100644 index 0000000..7ec9c5d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNthRoot.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNthRoot } from '../../factoriesNumber.js'; +export var nthRootDependencies = { + typedDependencies, + createNthRoot +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNull.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNull.generated.js new file mode 100644 index 0000000..4fa0bcb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNull.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createNull } from '../../factoriesNumber.js'; +export var nullDependencies = { + createNull +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumber.generated.js new file mode 100644 index 0000000..c694992 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumber.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createNumber } from '../../factoriesNumber.js'; +export var numberDependencies = { + typedDependencies, + createNumber +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumeric.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumeric.generated.js new file mode 100644 index 0000000..525b859 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesNumeric.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { createNumeric } from '../../factoriesNumber.js'; +export var numericDependencies = { + numberDependencies, + createNumeric +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesObjectNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesObjectNode.generated.js new file mode 100644 index 0000000..4575c9e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesObjectNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createObjectNode } from '../../factoriesNumber.js'; +export var ObjectNodeDependencies = { + NodeDependencies, + createObjectNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOperatorNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOperatorNode.generated.js new file mode 100644 index 0000000..a694cce --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOperatorNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createOperatorNode } from '../../factoriesNumber.js'; +export var OperatorNodeDependencies = { + NodeDependencies, + createOperatorNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOr.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOr.generated.js new file mode 100644 index 0000000..6c4cd33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesOr.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createOr } from '../../factoriesNumber.js'; +export var orDependencies = { + typedDependencies, + createOr +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js new file mode 100644 index 0000000..e21611e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParenthesisNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createParenthesisNode } from '../../factoriesNumber.js'; +export var ParenthesisNodeDependencies = { + NodeDependencies, + createParenthesisNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParse.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParse.generated.js new file mode 100644 index 0000000..63c742e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParse.generated.js @@ -0,0 +1,42 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { AssignmentNodeDependencies } from './dependenciesAssignmentNode.generated.js'; +import { BlockNodeDependencies } from './dependenciesBlockNode.generated.js'; +import { ConditionalNodeDependencies } from './dependenciesConditionalNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionAssignmentNodeDependencies } from './dependenciesFunctionAssignmentNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { RangeNodeDependencies } from './dependenciesRangeNode.generated.js'; +import { RelationalNodeDependencies } from './dependenciesRelationalNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createParse } from '../../factoriesNumber.js'; +export var parseDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + AssignmentNodeDependencies, + BlockNodeDependencies, + ConditionalNodeDependencies, + ConstantNodeDependencies, + FunctionAssignmentNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + RangeNodeDependencies, + RelationalNodeDependencies, + SymbolNodeDependencies, + numericDependencies, + typedDependencies, + createParse +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParser.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParser.generated.js new file mode 100644 index 0000000..b7c3dba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParser.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ParserDependencies } from './dependenciesParserClass.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createParser } from '../../factoriesNumber.js'; +export var parserDependencies = { + ParserDependencies, + typedDependencies, + createParser +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParserClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParserClass.generated.js new file mode 100644 index 0000000..bba1cc8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesParserClass.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { evaluateDependencies } from './dependenciesEvaluate.generated.js'; +import { createParserClass } from '../../factoriesNumber.js'; +export var ParserDependencies = { + evaluateDependencies, + createParserClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js new file mode 100644 index 0000000..87a18c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPartitionSelect.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { isNumericDependencies } from './dependenciesIsNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPartitionSelect } from '../../factoriesNumber.js'; +export var partitionSelectDependencies = { + compareDependencies, + isNaNDependencies, + isNumericDependencies, + typedDependencies, + createPartitionSelect +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPermutations.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPermutations.generated.js new file mode 100644 index 0000000..319d5b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPermutations.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPermutations } from '../../factoriesNumber.js'; +export var permutationsDependencies = { + factorialDependencies, + typedDependencies, + createPermutations +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPhi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPhi.generated.js new file mode 100644 index 0000000..085d93e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPhi.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createPhi } from '../../factoriesNumber.js'; +export var phiDependencies = { + createPhi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPi.generated.js new file mode 100644 index 0000000..76ba1ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPi.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createPi } from '../../factoriesNumber.js'; +export var piDependencies = { + createPi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPickRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPickRandom.generated.js new file mode 100644 index 0000000..9d030e5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPickRandom.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPickRandom } from '../../factoriesNumber.js'; +export var pickRandomDependencies = { + typedDependencies, + createPickRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPow.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPow.generated.js new file mode 100644 index 0000000..afa55f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPow.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPow } from '../../factoriesNumber.js'; +export var powDependencies = { + typedDependencies, + createPow +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPrint.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPrint.generated.js new file mode 100644 index 0000000..2c84688 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesPrint.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createPrint } from '../../factoriesNumber.js'; +export var printDependencies = { + typedDependencies, + createPrint +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesProd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesProd.generated.js new file mode 100644 index 0000000..c510314 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesProd.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createProd } from '../../factoriesNumber.js'; +export var prodDependencies = { + multiplyScalarDependencies, + numericDependencies, + typedDependencies, + createProd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js new file mode 100644 index 0000000..8e177e4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesQuantileSeq.generated.js @@ -0,0 +1,30 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { compareDependencies } from './dependenciesCompare.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { partitionSelectDependencies } from './dependenciesPartitionSelect.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createQuantileSeq } from '../../factoriesNumber.js'; +export var quantileSeqDependencies = { + addDependencies, + compareDependencies, + divideDependencies, + isIntegerDependencies, + largerDependencies, + multiplyDependencies, + partitionSelectDependencies, + smallerDependencies, + smallerEqDependencies, + subtractDependencies, + typedDependencies, + createQuantileSeq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandom.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandom.generated.js new file mode 100644 index 0000000..604e834 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandom.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRandom } from '../../factoriesNumber.js'; +export var randomDependencies = { + typedDependencies, + createRandom +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandomInt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandomInt.generated.js new file mode 100644 index 0000000..d0e737d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRandomInt.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRandomInt } from '../../factoriesNumber.js'; +export var randomIntDependencies = { + typedDependencies, + createRandomInt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRange.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRange.generated.js new file mode 100644 index 0000000..ad9ff5e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRange.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { largerEqDependencies } from './dependenciesLargerEq.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRange } from '../../factoriesNumber.js'; +export var rangeDependencies = { + matrixDependencies, + addDependencies, + isPositiveDependencies, + largerDependencies, + largerEqDependencies, + smallerDependencies, + smallerEqDependencies, + typedDependencies, + createRange +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeClass.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeClass.generated.js new file mode 100644 index 0000000..51eb295 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeClass.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createRangeClass } from '../../factoriesNumber.js'; +export var RangeDependencies = { + createRangeClass +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeNode.generated.js new file mode 100644 index 0000000..78457e1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createRangeNode } from '../../factoriesNumber.js'; +export var RangeNodeDependencies = { + NodeDependencies, + createRangeNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeTransform.generated.js new file mode 100644 index 0000000..92c2248 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRangeTransform.generated.js @@ -0,0 +1,24 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { isPositiveDependencies } from './dependenciesIsPositive.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { largerEqDependencies } from './dependenciesLargerEq.generated.js'; +import { smallerDependencies } from './dependenciesSmaller.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRangeTransform } from '../../factoriesNumber.js'; +export var rangeTransformDependencies = { + matrixDependencies, + addDependencies, + isPositiveDependencies, + largerDependencies, + largerEqDependencies, + smallerDependencies, + smallerEqDependencies, + typedDependencies, + createRangeTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRationalize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRationalize.generated.js new file mode 100644 index 0000000..1d0831a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRationalize.generated.js @@ -0,0 +1,52 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { simplifyDependencies } from './dependenciesSimplify.generated.js'; +import { simplifyConstantDependencies } from './dependenciesSimplifyConstant.generated.js'; +import { simplifyCoreDependencies } from './dependenciesSimplifyCore.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRationalize } from '../../factoriesNumber.js'; +export var rationalizeDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + simplifyDependencies, + simplifyConstantDependencies, + simplifyCoreDependencies, + subtractDependencies, + typedDependencies, + createRationalize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRelationalNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRelationalNode.generated.js new file mode 100644 index 0000000..b833c77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRelationalNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createRelationalNode } from '../../factoriesNumber.js'; +export var RelationalNodeDependencies = { + NodeDependencies, + createRelationalNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReplacer.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReplacer.generated.js new file mode 100644 index 0000000..93af6ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReplacer.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createReplacer } from '../../factoriesNumber.js'; +export var replacerDependencies = { + createReplacer +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResolve.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResolve.generated.js new file mode 100644 index 0000000..420973d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResolve.generated.js @@ -0,0 +1,20 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createResolve } from '../../factoriesNumber.js'; +export var resolveDependencies = { + ConstantNodeDependencies, + FunctionNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + parseDependencies, + typedDependencies, + createResolve +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResultSet.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResultSet.generated.js new file mode 100644 index 0000000..859c522 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesResultSet.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createResultSet } from '../../factoriesNumber.js'; +export var ResultSetDependencies = { + createResultSet +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReviver.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReviver.generated.js new file mode 100644 index 0000000..00bc722 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesReviver.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createReviver } from '../../factoriesNumber.js'; +export var reviverDependencies = { + createReviver +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightArithShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightArithShift.generated.js new file mode 100644 index 0000000..335469c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightArithShift.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRightArithShift } from '../../factoriesNumber.js'; +export var rightArithShiftDependencies = { + typedDependencies, + createRightArithShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightLogShift.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightLogShift.generated.js new file mode 100644 index 0000000..e07b745 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRightLogShift.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRightLogShift } from '../../factoriesNumber.js'; +export var rightLogShiftDependencies = { + typedDependencies, + createRightLogShift +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRound.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRound.generated.js new file mode 100644 index 0000000..6a77140 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesRound.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createRound } from '../../factoriesNumber.js'; +export var roundDependencies = { + typedDependencies, + createRound +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js new file mode 100644 index 0000000..38a4da2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT1_2.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createSQRT1_2 } from '../../factoriesNumber.js'; // eslint-disable-line camelcase + +export var SQRT1_2Dependencies = { + // eslint-disable-line camelcase + createSQRT1_2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT2.generated.js new file mode 100644 index 0000000..5898c96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSQRT2.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createSQRT2 } from '../../factoriesNumber.js'; +export var SQRT2Dependencies = { + createSQRT2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSec.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSec.generated.js new file mode 100644 index 0000000..037c4d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSec.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSec } from '../../factoriesNumber.js'; +export var secDependencies = { + typedDependencies, + createSec +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSech.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSech.generated.js new file mode 100644 index 0000000..b37d296 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSech.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSech } from '../../factoriesNumber.js'; +export var sechDependencies = { + typedDependencies, + createSech +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSign.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSign.generated.js new file mode 100644 index 0000000..27bf617 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSign.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSign } from '../../factoriesNumber.js'; +export var signDependencies = { + typedDependencies, + createSign +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplify.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplify.generated.js new file mode 100644 index 0000000..e3b97a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplify.generated.js @@ -0,0 +1,52 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { resolveDependencies } from './dependenciesResolve.generated.js'; +import { simplifyConstantDependencies } from './dependenciesSimplifyConstant.generated.js'; +import { simplifyCoreDependencies } from './dependenciesSimplifyCore.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplify } from '../../factoriesNumber.js'; +export var simplifyDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + matrixDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + resolveDependencies, + simplifyConstantDependencies, + simplifyCoreDependencies, + subtractDependencies, + typedDependencies, + createSimplify +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js new file mode 100644 index 0000000..ddd2810 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyConstant.generated.js @@ -0,0 +1,28 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplifyConstant } from '../../factoriesNumber.js'; +export var simplifyConstantDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + SymbolNodeDependencies, + matrixDependencies, + typedDependencies, + createSimplifyConstant +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js new file mode 100644 index 0000000..19208d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSimplifyCore.generated.js @@ -0,0 +1,44 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { AccessorNodeDependencies } from './dependenciesAccessorNode.generated.js'; +import { ArrayNodeDependencies } from './dependenciesArrayNode.generated.js'; +import { ConstantNodeDependencies } from './dependenciesConstantNode.generated.js'; +import { FunctionNodeDependencies } from './dependenciesFunctionNode.generated.js'; +import { IndexNodeDependencies } from './dependenciesIndexNode.generated.js'; +import { ObjectNodeDependencies } from './dependenciesObjectNode.generated.js'; +import { OperatorNodeDependencies } from './dependenciesOperatorNode.generated.js'; +import { ParenthesisNodeDependencies } from './dependenciesParenthesisNode.generated.js'; +import { SymbolNodeDependencies } from './dependenciesSymbolNode.generated.js'; +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { isZeroDependencies } from './dependenciesIsZero.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { parseDependencies } from './dependenciesParse.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSimplifyCore } from '../../factoriesNumber.js'; +export var simplifyCoreDependencies = { + AccessorNodeDependencies, + ArrayNodeDependencies, + ConstantNodeDependencies, + FunctionNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + SymbolNodeDependencies, + addDependencies, + divideDependencies, + equalDependencies, + isZeroDependencies, + multiplyDependencies, + parseDependencies, + powDependencies, + subtractDependencies, + typedDependencies, + createSimplifyCore +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSin.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSin.generated.js new file mode 100644 index 0000000..36e19f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSin.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSin } from '../../factoriesNumber.js'; +export var sinDependencies = { + typedDependencies, + createSin +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSinh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSinh.generated.js new file mode 100644 index 0000000..526371a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSinh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSinh } from '../../factoriesNumber.js'; +export var sinhDependencies = { + typedDependencies, + createSinh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSize.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSize.generated.js new file mode 100644 index 0000000..7bf5f8c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSize.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { matrixDependencies } from './dependenciesMatrix.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSize } from '../../factoriesNumber.js'; +export var sizeDependencies = { + matrixDependencies, + typedDependencies, + createSize +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmaller.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmaller.generated.js new file mode 100644 index 0000000..c1a70ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmaller.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSmaller } from '../../factoriesNumber.js'; +export var smallerDependencies = { + typedDependencies, + createSmaller +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmallerEq.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmallerEq.generated.js new file mode 100644 index 0000000..8cea526 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSmallerEq.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSmallerEq } from '../../factoriesNumber.js'; +export var smallerEqDependencies = { + typedDependencies, + createSmallerEq +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSqrt.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSqrt.generated.js new file mode 100644 index 0000000..4da7267 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSqrt.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSqrt } from '../../factoriesNumber.js'; +export var sqrtDependencies = { + typedDependencies, + createSqrt +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSquare.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSquare.generated.js new file mode 100644 index 0000000..71799ed --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSquare.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSquare } from '../../factoriesNumber.js'; +export var squareDependencies = { + typedDependencies, + createSquare +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStd.generated.js new file mode 100644 index 0000000..b279cf6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStd.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { mapDependencies } from './dependenciesMap.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { varianceDependencies } from './dependenciesVariance.generated.js'; +import { createStd } from '../../factoriesNumber.js'; +export var stdDependencies = { + mapDependencies, + sqrtDependencies, + typedDependencies, + varianceDependencies, + createStd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStdTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStdTransform.generated.js new file mode 100644 index 0000000..4d7be6c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStdTransform.generated.js @@ -0,0 +1,16 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { mapDependencies } from './dependenciesMap.generated.js'; +import { sqrtDependencies } from './dependenciesSqrt.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { varianceDependencies } from './dependenciesVariance.generated.js'; +import { createStdTransform } from '../../factoriesNumber.js'; +export var stdTransformDependencies = { + mapDependencies, + sqrtDependencies, + typedDependencies, + varianceDependencies, + createStdTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStirlingS2.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStirlingS2.generated.js new file mode 100644 index 0000000..0c958b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesStirlingS2.generated.js @@ -0,0 +1,32 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addScalarDependencies } from './dependenciesAddScalar.generated.js'; +import { combinationsDependencies } from './dependenciesCombinations.generated.js'; +import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { isIntegerDependencies } from './dependenciesIsInteger.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { largerDependencies } from './dependenciesLarger.generated.js'; +import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js'; +import { numberDependencies } from './dependenciesNumber.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createStirlingS2 } from '../../factoriesNumber.js'; +export var stirlingS2Dependencies = { + addScalarDependencies, + combinationsDependencies, + divideScalarDependencies, + factorialDependencies, + isIntegerDependencies, + isNegativeDependencies, + largerDependencies, + multiplyScalarDependencies, + numberDependencies, + powDependencies, + subtractScalarDependencies, + typedDependencies, + createStirlingS2 +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesString.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesString.generated.js new file mode 100644 index 0000000..57db84e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesString.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createString } from '../../factoriesNumber.js'; +export var stringDependencies = { + typedDependencies, + createString +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubset.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubset.generated.js new file mode 100644 index 0000000..668726f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubset.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createSubset } from '../../factoriesNumber.js'; +export var subsetDependencies = { + createSubset +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js new file mode 100644 index 0000000..6a3251a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubsetTransform.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createSubsetTransform } from '../../factoriesNumber.js'; +export var subsetTransformDependencies = { + createSubsetTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtract.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtract.generated.js new file mode 100644 index 0000000..3f3e157 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtract.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSubtract } from '../../factoriesNumber.js'; +export var subtractDependencies = { + typedDependencies, + createSubtract +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js new file mode 100644 index 0000000..7f69b07 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSubtractScalar } from '../../factoriesNumber.js'; +export var subtractScalarDependencies = { + typedDependencies, + createSubtractScalar +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSum.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSum.generated.js new file mode 100644 index 0000000..9aa4cf5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSum.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSum } from '../../factoriesNumber.js'; +export var sumDependencies = { + addDependencies, + numericDependencies, + typedDependencies, + createSum +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSumTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSumTransform.generated.js new file mode 100644 index 0000000..19b997f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSumTransform.generated.js @@ -0,0 +1,14 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { numericDependencies } from './dependenciesNumeric.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createSumTransform } from '../../factoriesNumber.js'; +export var sumTransformDependencies = { + addDependencies, + numericDependencies, + typedDependencies, + createSumTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSymbolNode.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSymbolNode.generated.js new file mode 100644 index 0000000..aca084a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesSymbolNode.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { NodeDependencies } from './dependenciesNode.generated.js'; +import { createSymbolNode } from '../../factoriesNumber.js'; +export var SymbolNodeDependencies = { + NodeDependencies, + createSymbolNode +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTan.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTan.generated.js new file mode 100644 index 0000000..cf31167 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTan.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTan } from '../../factoriesNumber.js'; +export var tanDependencies = { + typedDependencies, + createTan +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTanh.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTanh.generated.js new file mode 100644 index 0000000..701f718 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTanh.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTanh } from '../../factoriesNumber.js'; +export var tanhDependencies = { + typedDependencies, + createTanh +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTau.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTau.generated.js new file mode 100644 index 0000000..ca81ba7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTau.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createTau } from '../../factoriesNumber.js'; +export var tauDependencies = { + createTau +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTrue.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTrue.generated.js new file mode 100644 index 0000000..c29345a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTrue.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createTrue } from '../../factoriesNumber.js'; +export var trueDependencies = { + createTrue +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTypeOf.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTypeOf.generated.js new file mode 100644 index 0000000..dd137bd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTypeOf.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createTypeOf } from '../../factoriesNumber.js'; +export var typeOfDependencies = { + typedDependencies, + createTypeOf +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTyped.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTyped.generated.js new file mode 100644 index 0000000..2daf5ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesTyped.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createTyped } from '../../factoriesNumber.js'; +export var typedDependencies = { + createTyped +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js new file mode 100644 index 0000000..a7a3254 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryMinus.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnaryMinus } from '../../factoriesNumber.js'; +export var unaryMinusDependencies = { + typedDependencies, + createUnaryMinus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js new file mode 100644 index 0000000..dd0851d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnaryPlus.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnaryPlus } from '../../factoriesNumber.js'; +export var unaryPlusDependencies = { + typedDependencies, + createUnaryPlus +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnequal.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnequal.generated.js new file mode 100644 index 0000000..cff54df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUnequal.generated.js @@ -0,0 +1,12 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createUnequal } from '../../factoriesNumber.js'; +export var unequalDependencies = { + equalScalarDependencies, + typedDependencies, + createUnequal +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercaseE.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercaseE.generated.js new file mode 100644 index 0000000..152876b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercaseE.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { eDependencies } from './dependenciesE.generated.js'; +import { createUppercaseE } from '../../factoriesNumber.js'; +export var EDependencies = { + eDependencies, + createUppercaseE +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercasePi.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercasePi.generated.js new file mode 100644 index 0000000..02189a3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesUppercasePi.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { piDependencies } from './dependenciesPi.generated.js'; +import { createUppercasePi } from '../../factoriesNumber.js'; +export var PIDependencies = { + piDependencies, + createUppercasePi +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVariance.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVariance.generated.js new file mode 100644 index 0000000..c13bfbe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVariance.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { applyDependencies } from './dependenciesApply.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createVariance } from '../../factoriesNumber.js'; +export var varianceDependencies = { + addDependencies, + applyDependencies, + divideDependencies, + isNaNDependencies, + multiplyDependencies, + subtractDependencies, + typedDependencies, + createVariance +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js new file mode 100644 index 0000000..596bb1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVarianceTransform.generated.js @@ -0,0 +1,22 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { applyDependencies } from './dependenciesApply.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { isNaNDependencies } from './dependenciesIsNaN.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createVarianceTransform } from '../../factoriesNumber.js'; +export var varianceTransformDependencies = { + addDependencies, + applyDependencies, + divideDependencies, + isNaNDependencies, + multiplyDependencies, + subtractDependencies, + typedDependencies, + createVarianceTransform +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVersion.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVersion.generated.js new file mode 100644 index 0000000..c16c379 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesVersion.generated.js @@ -0,0 +1,8 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { createVersion } from '../../factoriesNumber.js'; +export var versionDependencies = { + createVersion +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXgcd.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXgcd.generated.js new file mode 100644 index 0000000..749e8e8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXgcd.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createXgcd } from '../../factoriesNumber.js'; +export var xgcdDependencies = { + typedDependencies, + createXgcd +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXor.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXor.generated.js new file mode 100644 index 0000000..192daf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesXor.generated.js @@ -0,0 +1,10 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createXor } from '../../factoriesNumber.js'; +export var xorDependencies = { + typedDependencies, + createXor +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesZeta.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesZeta.generated.js new file mode 100644 index 0000000..02d3083 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/dependenciesNumber/dependenciesZeta.generated.js @@ -0,0 +1,34 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { addDependencies } from './dependenciesAdd.generated.js'; +import { divideDependencies } from './dependenciesDivide.generated.js'; +import { equalDependencies } from './dependenciesEqual.generated.js'; +import { factorialDependencies } from './dependenciesFactorial.generated.js'; +import { gammaDependencies } from './dependenciesGamma.generated.js'; +import { isNegativeDependencies } from './dependenciesIsNegative.generated.js'; +import { multiplyDependencies } from './dependenciesMultiply.generated.js'; +import { piDependencies } from './dependenciesPi.generated.js'; +import { powDependencies } from './dependenciesPow.generated.js'; +import { sinDependencies } from './dependenciesSin.generated.js'; +import { smallerEqDependencies } from './dependenciesSmallerEq.generated.js'; +import { subtractDependencies } from './dependenciesSubtract.generated.js'; +import { typedDependencies } from './dependenciesTyped.generated.js'; +import { createZeta } from '../../factoriesNumber.js'; +export var zetaDependencies = { + addDependencies, + divideDependencies, + equalDependencies, + factorialDependencies, + gammaDependencies, + isNegativeDependencies, + multiplyDependencies, + piDependencies, + powDependencies, + sinDependencies, + smallerEqDependencies, + subtractDependencies, + typedDependencies, + createZeta +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsAny.generated.js new file mode 100644 index 0000000..6ebe60c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsAny.generated.js @@ -0,0 +1,751 @@ +import _extends from "@babel/runtime/helpers/extends"; +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { config } from './configReadonly.js'; +import { createNode, createObjectNode, createOperatorNode, createParenthesisNode, createRelationalNode, createArrayNode, createBlockNode, createConditionalNode, createConstantNode, createRangeNode, createReviver, createChainClass, createFunctionAssignmentNode, createChain, createIndexNode, createAccessorNode, createAssignmentNode, createSymbolNode, createFunctionNode, createParse, createResolve, createSimplifyConstant, createCompile, createSimplifyCore, createEvaluate, createHelpClass, createParserClass, createSimplify, createSymbolicEqual, createLeafCount, createParser, createRationalize, createDerivative, createHelp, createFilterTransform, createForEachTransform, createMapTransform, createApplyTransform, createOrTransform, createAndTransform, createConcatTransform, createMaxTransform, createPrintTransform, createBitAndTransform, createDiffTransform, createMinTransform, createSubsetTransform, createBitOrTransform, createCumSumTransform, createIndexTransform, createSumTransform, createRangeTransform, createRowTransform, createColumnTransform, createMeanTransform, createQuantileSeqTransform, createVarianceTransform, createStdTransform } from '../factoriesAny.js'; +import { BigNumber, Complex, e, _false, fineStructure, Fraction, i, _Infinity, LN10, LOG10E, Matrix, _NaN, _null, phi, Range, ResultSet, SQRT1_2, +// eslint-disable-line camelcase +sackurTetrode, tau, _true, version, DenseMatrix, efimovFactor, LN2, pi, replacer, SQRT2, typed, weakMixingAngle, abs, acos, acot, acsc, addScalar, arg, asech, asinh, atan, atanh, bigint, bitNot, boolean, clone, combinations, complex, conj, cos, cot, csc, cube, equalScalar, erf, exp, expm1, filter, flatten, forEach, format, getMatrixDataType, hex, im, isInteger, isNegative, isPositive, isZero, LOG2E, lgamma, log10, log2, map, multiplyScalar, not, number, oct, pickRandom, print, random, re, sec, sign, sin, SparseMatrix, splitUnit, square, string, subtractScalar, tan, typeOf, acosh, acsch, apply, asec, bignumber, combinationsWithRep, cosh, csch, isNaN, isPrime, randomInt, sech, sinh, sparse, sqrt, squeeze, tanh, unaryMinus, acoth, bin, coth, fraction, isNumeric, matrix, matrixFromFunction, mode, numeric, prod, reshape, size, transpose, xgcd, zeros, asin, cbrt, concat, count, ctranspose, diag, divideScalar, dotDivide, equal, hasNumericValue, identity, kron, largerEq, leftShift, lsolve, matrixFromColumns, nthRoot, ones, qr, resize, rightArithShift, round, smaller, subtract, to, unaryPlus, usolve, xor, add, atan2, bitAnd, bitOr, bitXor, catalan, compare, compareText, cumsum, deepEqual, diff, distance, dot, equalText, floor, gcd, hypot, ImmutableDenseMatrix, Index, larger, log, lsolveAll, matrixFromRows, min, mod, multiply, nthRoots, or, partitionSelect, rightLogShift, slu, subset, sum, trace, usolveAll, zpk2tf, ceil, compareNatural, composition, cross, det, dotMultiply, FibonacciHeap, fix, index, intersect, invmod, lcm, log1p, max, setCartesian, setDistinct, setIsSubset, setPowerset, smallerEq, sort, unequal, and, range, row, setDifference, setMultiplicity, setSymDifference, Spa, column, inv, lup, pinv, pow, setIntersect, setUnion, sqrtm, Unit, vacuumImpedance, wienDisplacement, atomicMass, bohrMagneton, boltzmann, conductanceQuantum, coulomb, deuteronMass, dotPow, electricConstant, elementaryCharge, expm, faraday, fft, gamma, gravitationConstant, hartreeEnergy, ifft, klitzing, loschmidt, magneticConstant, molarMass, molarPlanckConstant, neutronMass, nuclearMagneton, planckCharge, planckLength, planckTemperature, protonMass, quantumOfCirculation, reducedPlanckConstant, rydberg, secondRadiation, speedOfLight, stefanBoltzmann, thomsonCrossSection, avogadro, bohrRadius, createUnit, divide, electronMass, factorial, firstRadiation, gravity, inverseConductanceQuantum, lusolve, magneticFluxQuantum, molarMassC12, multinomial, permutations, planckMass, polynomialRoot, setSize, solveODE, stirlingS2, unit, bellNumbers, eigs, fermiCoupling, gasConstant, kldivergence, mean, molarVolume, planckConstant, quantileSeq, variance, classicalElectronRadius, median, corr, freqz, mad, std, zeta, norm, rotationMatrix, planckTime, schur, rotate, sylvester, lyap } from './pureFunctionsAny.generated.js'; +var math = {}; // NOT pure! +var mathWithTransform = {}; // NOT pure! +var classes = {}; // NOT pure! + +export var Node = createNode({ + mathWithTransform +}); +export var ObjectNode = createObjectNode({ + Node +}); +export var OperatorNode = createOperatorNode({ + Node +}); +export var ParenthesisNode = createParenthesisNode({ + Node +}); +export var RelationalNode = createRelationalNode({ + Node +}); +export var ArrayNode = createArrayNode({ + Node +}); +export var BlockNode = createBlockNode({ + Node, + ResultSet +}); +export var ConditionalNode = createConditionalNode({ + Node +}); +export var ConstantNode = createConstantNode({ + Node +}); +export var RangeNode = createRangeNode({ + Node +}); +export var reviver = createReviver({ + classes +}); +export var Chain = createChainClass({ + math, + typed +}); +export var FunctionAssignmentNode = createFunctionAssignmentNode({ + Node, + typed +}); +export var chain = createChain({ + Chain, + typed +}); +export var IndexNode = createIndexNode({ + Node, + size +}); +export var AccessorNode = createAccessorNode({ + Node, + subset +}); +export var AssignmentNode = createAssignmentNode({ + matrix, + Node, + subset +}); +export var SymbolNode = createSymbolNode({ + Unit, + Node, + math +}); +export var FunctionNode = createFunctionNode({ + Node, + SymbolNode, + math +}); +export var parse = createParse({ + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode, + config, + numeric, + typed +}); +export var resolve = createResolve({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + parse, + typed +}); +export var simplifyConstant = createSimplifyConstant({ + bignumber, + fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + config, + mathWithTransform, + matrix, + typed +}); +export var compile = createCompile({ + parse, + typed +}); +export var simplifyCore = createSimplifyCore({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + divide, + equal, + isZero, + multiply, + parse, + pow, + subtract, + typed +}); +export var evaluate = createEvaluate({ + parse, + typed +}); +export var Help = createHelpClass({ + evaluate +}); +export var Parser = createParserClass({ + evaluate +}); +export var simplify = createSimplify({ + bignumber, + fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + config, + divide, + equal, + isZero, + mathWithTransform, + matrix, + multiply, + parse, + pow, + resolve, + simplifyConstant, + simplifyCore, + subtract, + typed +}); +export var symbolicEqual = createSymbolicEqual({ + OperatorNode, + parse, + simplify, + typed +}); +export var leafCount = createLeafCount({ + parse, + typed +}); +export var parser = createParser({ + Parser, + typed +}); +export var rationalize = createRationalize({ + bignumber, + fraction, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + config, + divide, + equal, + isZero, + mathWithTransform, + matrix, + multiply, + parse, + pow, + simplify, + simplifyConstant, + simplifyCore, + subtract, + typed +}); +export var derivative = createDerivative({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + config, + equal, + isZero, + numeric, + parse, + simplify, + typed +}); +export var help = createHelp({ + Help, + mathWithTransform, + typed +}); +_extends(math, { + e, + false: _false, + fineStructure, + i, + Infinity: _Infinity, + LN10, + LOG10E, + NaN: _NaN, + null: _null, + phi, + SQRT1_2, + sackurTetrode, + tau, + true: _true, + 'E': e, + version, + efimovFactor, + LN2, + pi, + replacer, + reviver, + SQRT2, + typed, + 'PI': pi, + weakMixingAngle, + abs, + acos, + acot, + acsc, + addScalar, + arg, + asech, + asinh, + atan, + atanh, + bigint, + bitNot, + boolean, + clone, + combinations, + complex, + conj, + cos, + cot, + csc, + cube, + equalScalar, + erf, + exp, + expm1, + filter, + flatten, + forEach, + format, + getMatrixDataType, + hex, + im, + isInteger, + isNegative, + isPositive, + isZero, + LOG2E, + lgamma, + log10, + log2, + map, + multiplyScalar, + not, + number, + oct, + pickRandom, + print, + random, + re, + sec, + sign, + sin, + splitUnit, + square, + string, + subtractScalar, + tan, + typeOf, + acosh, + acsch, + apply, + asec, + bignumber, + chain, + combinationsWithRep, + cosh, + csch, + isNaN, + isPrime, + randomInt, + sech, + sinh, + sparse, + sqrt, + squeeze, + tanh, + unaryMinus, + acoth, + bin, + coth, + fraction, + isNumeric, + matrix, + matrixFromFunction, + mode, + numeric, + prod, + reshape, + size, + transpose, + xgcd, + zeros, + asin, + cbrt, + concat, + count, + ctranspose, + diag, + divideScalar, + dotDivide, + equal, + hasNumericValue, + identity, + kron, + largerEq, + leftShift, + lsolve, + matrixFromColumns, + nthRoot, + ones, + qr, + resize, + rightArithShift, + round, + smaller, + subtract, + to, + unaryPlus, + usolve, + xor, + add, + atan2, + bitAnd, + bitOr, + bitXor, + catalan, + compare, + compareText, + cumsum, + deepEqual, + diff, + distance, + dot, + equalText, + floor, + gcd, + hypot, + larger, + log, + lsolveAll, + matrixFromRows, + min, + mod, + multiply, + nthRoots, + or, + partitionSelect, + rightLogShift, + slu, + subset, + sum, + trace, + usolveAll, + zpk2tf, + ceil, + compareNatural, + composition, + cross, + det, + dotMultiply, + fix, + index, + intersect, + invmod, + lcm, + log1p, + max, + setCartesian, + setDistinct, + setIsSubset, + setPowerset, + smallerEq, + sort, + unequal, + and, + range, + row, + setDifference, + setMultiplicity, + setSymDifference, + column, + inv, + lup, + pinv, + pow, + setIntersect, + setUnion, + sqrtm, + vacuumImpedance, + wienDisplacement, + atomicMass, + bohrMagneton, + boltzmann, + conductanceQuantum, + coulomb, + deuteronMass, + dotPow, + electricConstant, + elementaryCharge, + expm, + faraday, + fft, + gamma, + gravitationConstant, + hartreeEnergy, + ifft, + klitzing, + loschmidt, + magneticConstant, + molarMass, + molarPlanckConstant, + neutronMass, + nuclearMagneton, + planckCharge, + planckLength, + planckTemperature, + protonMass, + quantumOfCirculation, + reducedPlanckConstant, + rydberg, + secondRadiation, + speedOfLight, + stefanBoltzmann, + thomsonCrossSection, + avogadro, + bohrRadius, + createUnit, + divide, + electronMass, + factorial, + firstRadiation, + gravity, + inverseConductanceQuantum, + lusolve, + magneticFluxQuantum, + molarMassC12, + multinomial, + parse, + permutations, + planckMass, + polynomialRoot, + resolve, + setSize, + simplifyConstant, + solveODE, + stirlingS2, + unit, + bellNumbers, + compile, + eigs, + fermiCoupling, + gasConstant, + kldivergence, + mean, + molarVolume, + planckConstant, + quantileSeq, + simplifyCore, + variance, + classicalElectronRadius, + evaluate, + median, + simplify, + symbolicEqual, + corr, + freqz, + leafCount, + mad, + parser, + rationalize, + std, + zeta, + derivative, + norm, + rotationMatrix, + help, + planckTime, + schur, + rotate, + sylvester, + lyap, + config +}); +_extends(mathWithTransform, math, { + filter: createFilterTransform({ + typed + }), + forEach: createForEachTransform({ + typed + }), + map: createMapTransform({ + typed + }), + apply: createApplyTransform({ + isInteger, + typed + }), + or: createOrTransform({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed + }), + and: createAndTransform({ + add, + concat, + equalScalar, + matrix, + not, + typed, + zeros + }), + concat: createConcatTransform({ + isInteger, + matrix, + typed + }), + max: createMaxTransform({ + config, + larger, + numeric, + typed + }), + print: createPrintTransform({ + add, + matrix, + typed, + zeros + }), + bitAnd: createBitAndTransform({ + add, + concat, + equalScalar, + matrix, + not, + typed, + zeros + }), + diff: createDiffTransform({ + bignumber, + matrix, + number, + subtract, + typed + }), + min: createMinTransform({ + config, + numeric, + smaller, + typed + }), + subset: createSubsetTransform({ + add, + matrix, + typed, + zeros + }), + bitOr: createBitOrTransform({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed + }), + cumsum: createCumSumTransform({ + add, + typed, + unaryPlus + }), + index: createIndexTransform({ + Index, + getMatrixDataType + }), + sum: createSumTransform({ + add, + config, + numeric, + typed + }), + range: createRangeTransform({ + bignumber, + matrix, + add, + config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed + }), + row: createRowTransform({ + Index, + matrix, + range, + typed + }), + column: createColumnTransform({ + Index, + matrix, + range, + typed + }), + mean: createMeanTransform({ + add, + divide, + typed + }), + quantileSeq: createQuantileSeqTransform({ + add, + bignumber, + compare, + divide, + isInteger, + larger, + multiply, + partitionSelect, + smaller, + smallerEq, + subtract, + typed + }), + variance: createVarianceTransform({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed + }), + std: createStdTransform({ + map, + sqrt, + typed, + variance + }) +}); +_extends(classes, { + BigNumber, + Complex, + Fraction, + Matrix, + Node, + ObjectNode, + OperatorNode, + ParenthesisNode, + Range, + RelationalNode, + ResultSet, + ArrayNode, + BlockNode, + ConditionalNode, + ConstantNode, + DenseMatrix, + RangeNode, + Chain, + FunctionAssignmentNode, + SparseMatrix, + IndexNode, + ImmutableDenseMatrix, + Index, + AccessorNode, + AssignmentNode, + FibonacciHeap, + Spa, + Unit, + SymbolNode, + FunctionNode, + Help, + Parser +}); +Chain.createProxy(math); +export { embeddedDocs as docs } from '../expression/embeddedDocs/embeddedDocs.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsNumber.generated.js new file mode 100644 index 0000000..d67565b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/impureFunctionsNumber.generated.js @@ -0,0 +1,502 @@ +import _extends from "@babel/runtime/helpers/extends"; +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { config } from './configReadonly.js'; +import { createChainClass, createNode, createObjectNode, createRangeNode, createRelationalNode, createReviver, createSymbolNode, createAccessorNode, createAssignmentNode, createBlockNode, createChain, createConditionalNode, createFunctionNode, createIndexNode, createOperatorNode, createConstantNode, createFunctionAssignmentNode, createParenthesisNode, createArrayNode, createSimplifyConstant, createParse, createResolve, createSimplifyCore, createCompile, createEvaluate, createHelpClass, createParserClass, createSimplify, createDerivative, createRationalize, createHelp, createParser, createCumSumTransform, createApplyTransform, createFilterTransform, createForEachTransform, createMapTransform, createMeanTransform, createSubsetTransform, createRangeTransform, createStdTransform, createSumTransform, createMaxTransform, createMinTransform, createVarianceTransform } from '../factoriesNumber.js'; +import { e, _false, index, _Infinity, LN10, LOG10E, matrix, _NaN, _null, phi, Range, replacer, ResultSet, SQRT1_2, +// eslint-disable-line camelcase +subset, tau, typed, unaryPlus, version, xor, abs, acos, acot, acsc, add, and, asec, asin, atan, atanh, bigint, bitNot, bitXor, boolean, cbrt, combinations, compare, compareText, cos, cot, csc, cube, divide, equalScalar, erf, exp, filter, forEach, format, gamma, isInteger, isNegative, isPositive, isZero, LOG2E, largerEq, leftShift, log, log1p, map, mean, mod, multiply, not, number, or, pi, pow, random, rightLogShift, SQRT2, sech, sin, size, smallerEq, square, string, subtract, tanh, typeOf, unequal, xgcd, acoth, addScalar, asech, bitAnd, combinationsWithRep, cosh, csch, divideScalar, equalText, expm1, isNumeric, LN2, lcm, log10, multiplyScalar, nthRoot, pickRandom, randomInt, rightArithShift, sec, sinh, sqrt, tan, unaryMinus, acosh, apply, asinh, bitOr, clone, coth, equal, factorial, hasNumericValue, isNaN, larger, log2, mode, norm, partitionSelect, print, round, smaller, subtractScalar, _true, variance, zeta, acsch, atan2, catalan, compareNatural, composition, cumsum, floor, hypot, lgamma, median, multinomial, permutations, quantileSeq, sign, std, stirlingS2, ceil, deepEqual, fix, isPrime, numeric, prod, bellNumbers, gcd, mad, range, sum, corr, max, min } from './pureFunctionsNumber.generated.js'; +var math = {}; // NOT pure! +var mathWithTransform = {}; // NOT pure! +var classes = {}; // NOT pure! + +export var Chain = createChainClass({ + math, + typed +}); +export var Node = createNode({ + mathWithTransform +}); +export var ObjectNode = createObjectNode({ + Node +}); +export var RangeNode = createRangeNode({ + Node +}); +export var RelationalNode = createRelationalNode({ + Node +}); +export var reviver = createReviver({ + classes +}); +export var SymbolNode = createSymbolNode({ + Node, + math +}); +export var AccessorNode = createAccessorNode({ + Node, + subset +}); +export var AssignmentNode = createAssignmentNode({ + matrix, + Node, + subset +}); +export var BlockNode = createBlockNode({ + Node, + ResultSet +}); +export var chain = createChain({ + Chain, + typed +}); +export var ConditionalNode = createConditionalNode({ + Node +}); +export var FunctionNode = createFunctionNode({ + Node, + SymbolNode, + math +}); +export var IndexNode = createIndexNode({ + Node, + size +}); +export var OperatorNode = createOperatorNode({ + Node +}); +export var ConstantNode = createConstantNode({ + Node +}); +export var FunctionAssignmentNode = createFunctionAssignmentNode({ + Node, + typed +}); +export var ParenthesisNode = createParenthesisNode({ + Node +}); +export var ArrayNode = createArrayNode({ + Node +}); +export var simplifyConstant = createSimplifyConstant({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + config, + mathWithTransform, + matrix, + typed +}); +export var parse = createParse({ + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode, + config, + numeric, + typed +}); +export var resolve = createResolve({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + parse, + typed +}); +export var simplifyCore = createSimplifyCore({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + divide, + equal, + isZero, + multiply, + parse, + pow, + subtract, + typed +}); +export var compile = createCompile({ + parse, + typed +}); +export var evaluate = createEvaluate({ + parse, + typed +}); +export var Help = createHelpClass({ + evaluate +}); +export var Parser = createParserClass({ + evaluate +}); +export var simplify = createSimplify({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + config, + divide, + equal, + isZero, + mathWithTransform, + matrix, + multiply, + parse, + pow, + resolve, + simplifyConstant, + simplifyCore, + subtract, + typed +}); +export var derivative = createDerivative({ + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + config, + equal, + isZero, + numeric, + parse, + simplify, + typed +}); +export var rationalize = createRationalize({ + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode, + add, + config, + divide, + equal, + isZero, + mathWithTransform, + matrix, + multiply, + parse, + pow, + simplify, + simplifyConstant, + simplifyCore, + subtract, + typed +}); +export var help = createHelp({ + Help, + mathWithTransform, + typed +}); +export var parser = createParser({ + Parser, + typed +}); +_extends(math, { + e, + false: _false, + index, + Infinity: _Infinity, + LN10, + LOG10E, + matrix, + NaN: _NaN, + null: _null, + phi, + replacer, + SQRT1_2, + subset, + tau, + typed, + unaryPlus, + 'E': e, + version, + xor, + abs, + acos, + acot, + acsc, + add, + and, + asec, + asin, + atan, + atanh, + bigint, + bitNot, + bitXor, + boolean, + cbrt, + combinations, + compare, + compareText, + cos, + cot, + csc, + cube, + divide, + equalScalar, + erf, + exp, + filter, + forEach, + format, + gamma, + isInteger, + isNegative, + isPositive, + isZero, + LOG2E, + largerEq, + leftShift, + log, + log1p, + map, + mean, + mod, + multiply, + not, + number, + or, + pi, + pow, + random, + reviver, + rightLogShift, + SQRT2, + sech, + sin, + size, + smallerEq, + square, + string, + subtract, + tanh, + typeOf, + unequal, + xgcd, + acoth, + addScalar, + asech, + bitAnd, + chain, + combinationsWithRep, + cosh, + csch, + divideScalar, + equalText, + expm1, + isNumeric, + LN2, + lcm, + log10, + multiplyScalar, + nthRoot, + pickRandom, + randomInt, + rightArithShift, + sec, + sinh, + sqrt, + tan, + unaryMinus, + acosh, + apply, + asinh, + bitOr, + clone, + coth, + equal, + factorial, + hasNumericValue, + isNaN, + larger, + log2, + mode, + norm, + partitionSelect, + print, + round, + smaller, + subtractScalar, + true: _true, + variance, + zeta, + acsch, + atan2, + catalan, + compareNatural, + composition, + cumsum, + floor, + hypot, + lgamma, + median, + multinomial, + permutations, + quantileSeq, + sign, + std, + stirlingS2, + 'PI': pi, + ceil, + deepEqual, + fix, + isPrime, + numeric, + prod, + simplifyConstant, + bellNumbers, + gcd, + mad, + range, + sum, + corr, + max, + parse, + resolve, + simplifyCore, + compile, + evaluate, + simplify, + derivative, + min, + rationalize, + help, + parser, + config +}); +_extends(mathWithTransform, math, { + cumsum: createCumSumTransform({ + add, + typed, + unaryPlus + }), + apply: createApplyTransform({ + isInteger, + typed + }), + filter: createFilterTransform({ + typed + }), + forEach: createForEachTransform({ + typed + }), + map: createMapTransform({ + typed + }), + mean: createMeanTransform({ + add, + divide, + typed + }), + subset: createSubsetTransform({}), + range: createRangeTransform({ + matrix, + add, + config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed + }), + std: createStdTransform({ + map, + sqrt, + typed, + variance + }), + sum: createSumTransform({ + add, + config, + numeric, + typed + }), + max: createMaxTransform({ + config, + larger, + numeric, + typed + }), + min: createMinTransform({ + config, + numeric, + smaller, + typed + }), + variance: createVarianceTransform({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed + }) +}); +_extends(classes, { + Range, + ResultSet, + Chain, + Node, + ObjectNode, + RangeNode, + RelationalNode, + SymbolNode, + AccessorNode, + AssignmentNode, + BlockNode, + ConditionalNode, + FunctionNode, + IndexNode, + OperatorNode, + ConstantNode, + FunctionAssignmentNode, + ParenthesisNode, + ArrayNode, + Help, + Parser +}); +Chain.createProxy(math); +export { embeddedDocs as docs } from '../expression/embeddedDocs/embeddedDocs.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainAny.js new file mode 100644 index 0000000..c45eb98 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainAny.js @@ -0,0 +1,22 @@ +// configuration +export { config } from './configReadonly.js'; + +// functions and constants +export * from './pureFunctionsAny.generated.js'; +export * from './impureFunctionsAny.generated.js'; +export * from './typeChecks.js'; + +// error classes +export { IndexError } from '../error/IndexError.js'; +export { DimensionError } from '../error/DimensionError.js'; +export { ArgumentsError } from '../error/ArgumentsError.js'; + +// dependency groups +export * from './dependenciesAny.generated.js'; + +// factory functions +export * from '../factoriesAny.js'; + +// core +export { create } from '../core/create.js'; +export { factory } from '../utils/factory.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainNumber.js new file mode 100644 index 0000000..e9e3ee0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/mainNumber.js @@ -0,0 +1,22 @@ +// configuration +export { config } from './configReadonly.js'; + +// functions and constants +export * from './pureFunctionsNumber.generated.js'; +export * from './impureFunctionsNumber.generated.js'; +export * from './typeChecks.js'; + +// error classes +export { IndexError } from '../error/IndexError.js'; +export { DimensionError } from '../error/DimensionError.js'; +export { ArgumentsError } from '../error/ArgumentsError.js'; + +// dependency groups +export * from './dependenciesNumber.generated.js'; + +// factory functions +export * from '../factoriesNumber.js'; + +// core +export { create } from '../core/create.js'; +export { factory } from '../utils/factory.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsAny.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsAny.generated.js new file mode 100644 index 0000000..5e32edd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsAny.generated.js @@ -0,0 +1,1793 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { config } from './configReadonly.js'; +import { createBigNumberClass, createComplexClass, createE, createFalse, createFineStructure, createFractionClass, createI, createInfinity, createLN10, createLOG10E, createMatrixClass, createNaN, createNull, createPhi, createRangeClass, createResultSet, createSQRT1_2, +// eslint-disable-line camelcase +createSackurTetrode, createTau, createTrue, createVersion, createDenseMatrixClass, createEfimovFactor, createLN2, createPi, createReplacer, createSQRT2, createTyped, createWeakMixingAngle, createAbs, createAcos, createAcot, createAcsc, createAddScalar, createArg, createAsech, createAsinh, createAtan, createAtanh, createBigint, createBitNot, createBoolean, createClone, createCombinations, createComplex, createConj, createCos, createCot, createCsc, createCube, createEqualScalar, createErf, createExp, createExpm1, createFilter, createFlatten, createForEach, createFormat, createGetMatrixDataType, createHex, createIm, createIsInteger, createIsNegative, createIsPositive, createIsZero, createLOG2E, createLgamma, createLog10, createLog2, createMap, createMultiplyScalar, createNot, createNumber, createOct, createPickRandom, createPrint, createRandom, createRe, createSec, createSign, createSin, createSparseMatrixClass, createSplitUnit, createSquare, createString, createSubtractScalar, createTan, createTypeOf, createAcosh, createAcsch, createApply, createAsec, createBignumber, createCombinationsWithRep, createCosh, createCsch, createIsNaN, createIsPrime, createRandomInt, createSech, createSinh, createSparse, createSqrt, createSqueeze, createTanh, createUnaryMinus, createAcoth, createBin, createCoth, createFraction, createIsNumeric, createMatrix, createMatrixFromFunction, createMode, createNumeric, createProd, createReshape, createSize, createTranspose, createXgcd, createZeros, createAsin, createCbrt, createConcat, createCount, createCtranspose, createDiag, createDivideScalar, createDotDivide, createEqual, createHasNumericValue, createIdentity, createKron, createLargerEq, createLeftShift, createLsolve, createMatrixFromColumns, createNthRoot, createOnes, createQr, createResize, createRightArithShift, createRound, createSmaller, createSubtract, createTo, createUnaryPlus, createUsolve, createXor, createAdd, createAtan2, createBitAnd, createBitOr, createBitXor, createCatalan, createCompare, createCompareText, createCumSum, createDeepEqual, createDiff, createDistance, createDot, createEqualText, createFloor, createGcd, createHypot, createImmutableDenseMatrixClass, createIndexClass, createLarger, createLog, createLsolveAll, createMatrixFromRows, createMin, createMod, createMultiply, createNthRoots, createOr, createPartitionSelect, createRightLogShift, createSlu, createSubset, createSum, createTrace, createUsolveAll, createZpk2tf, createCeil, createCompareNatural, createComposition, createCross, createDet, createDotMultiply, createFibonacciHeapClass, createFix, createIndex, createIntersect, createInvmod, createLcm, createLog1p, createMax, createSetCartesian, createSetDistinct, createSetIsSubset, createSetPowerset, createSmallerEq, createSort, createUnequal, createAnd, createRange, createRow, createSetDifference, createSetMultiplicity, createSetSymDifference, createSpaClass, createColumn, createInv, createLup, createPinv, createPow, createSetIntersect, createSetUnion, createSqrtm, createUnitClass, createVacuumImpedance, createWienDisplacement, createAtomicMass, createBohrMagneton, createBoltzmann, createConductanceQuantum, createCoulomb, createDeuteronMass, createDotPow, createElectricConstant, createElementaryCharge, createExpm, createFaraday, createFft, createGamma, createGravitationConstant, createHartreeEnergy, createIfft, createKlitzing, createLoschmidt, createMagneticConstant, createMolarMass, createMolarPlanckConstant, createNeutronMass, createNuclearMagneton, createPlanckCharge, createPlanckLength, createPlanckTemperature, createProtonMass, createQuantumOfCirculation, createReducedPlanckConstant, createRydberg, createSecondRadiation, createSpeedOfLight, createStefanBoltzmann, createThomsonCrossSection, createAvogadro, createBohrRadius, createCreateUnit, createDivide, createElectronMass, createFactorial, createFirstRadiation, createGravity, createInverseConductanceQuantum, createLusolve, createMagneticFluxQuantum, createMolarMassC12, createMultinomial, createPermutations, createPlanckMass, createPolynomialRoot, createSetSize, createSolveODE, createStirlingS2, createUnitFunction, createBellNumbers, createEigs, createFermiCoupling, createGasConstant, createKldivergence, createMean, createMolarVolume, createPlanckConstant, createQuantileSeq, createVariance, createClassicalElectronRadius, createMedian, createCorr, createFreqz, createMad, createStd, createZeta, createNorm, createRotationMatrix, createPlanckTime, createSchur, createRotate, createSylvester, createLyap } from '../factoriesAny.js'; +export var BigNumber = /* #__PURE__ */createBigNumberClass({ + config +}); +export var Complex = /* #__PURE__ */createComplexClass({}); +export var e = /* #__PURE__ */createE({ + BigNumber, + config +}); +export var _false = /* #__PURE__ */createFalse({}); +export var fineStructure = /* #__PURE__ */createFineStructure({ + BigNumber, + config +}); +export var Fraction = /* #__PURE__ */createFractionClass({}); +export var i = /* #__PURE__ */createI({ + Complex +}); +export var _Infinity = /* #__PURE__ */createInfinity({ + BigNumber, + config +}); +export var LN10 = /* #__PURE__ */createLN10({ + BigNumber, + config +}); +export var LOG10E = /* #__PURE__ */createLOG10E({ + BigNumber, + config +}); +export var Matrix = /* #__PURE__ */createMatrixClass({}); +export var _NaN = /* #__PURE__ */createNaN({ + BigNumber, + config +}); +export var _null = /* #__PURE__ */createNull({}); +export var phi = /* #__PURE__ */createPhi({ + BigNumber, + config +}); +export var Range = /* #__PURE__ */createRangeClass({}); +export var ResultSet = /* #__PURE__ */createResultSet({}); +export var SQRT1_2 = /* #__PURE__ */createSQRT1_2({ + BigNumber, + config +}); +export var sackurTetrode = /* #__PURE__ */createSackurTetrode({ + BigNumber, + config +}); +export var tau = /* #__PURE__ */createTau({ + BigNumber, + config +}); +export var _true = /* #__PURE__ */createTrue({}); +export var version = /* #__PURE__ */createVersion({}); +export var DenseMatrix = /* #__PURE__ */createDenseMatrixClass({ + Matrix +}); +export var efimovFactor = /* #__PURE__ */createEfimovFactor({ + BigNumber, + config +}); +export var LN2 = /* #__PURE__ */createLN2({ + BigNumber, + config +}); +export var pi = /* #__PURE__ */createPi({ + BigNumber, + config +}); +export var replacer = /* #__PURE__ */createReplacer({}); +export var SQRT2 = /* #__PURE__ */createSQRT2({ + BigNumber, + config +}); +export var typed = /* #__PURE__ */createTyped({ + BigNumber, + Complex, + DenseMatrix, + Fraction +}); +export var weakMixingAngle = /* #__PURE__ */createWeakMixingAngle({ + BigNumber, + config +}); +export var abs = /* #__PURE__ */createAbs({ + typed +}); +export var acos = /* #__PURE__ */createAcos({ + Complex, + config, + typed +}); +export var acot = /* #__PURE__ */createAcot({ + BigNumber, + typed +}); +export var acsc = /* #__PURE__ */createAcsc({ + BigNumber, + Complex, + config, + typed +}); +export var addScalar = /* #__PURE__ */createAddScalar({ + typed +}); +export var arg = /* #__PURE__ */createArg({ + typed +}); +export var asech = /* #__PURE__ */createAsech({ + BigNumber, + Complex, + config, + typed +}); +export var asinh = /* #__PURE__ */createAsinh({ + typed +}); +export var atan = /* #__PURE__ */createAtan({ + typed +}); +export var atanh = /* #__PURE__ */createAtanh({ + Complex, + config, + typed +}); +export var bigint = /* #__PURE__ */createBigint({ + typed +}); +export var bitNot = /* #__PURE__ */createBitNot({ + typed +}); +export var boolean = /* #__PURE__ */createBoolean({ + typed +}); +export var clone = /* #__PURE__ */createClone({ + typed +}); +export var combinations = /* #__PURE__ */createCombinations({ + typed +}); +export var complex = /* #__PURE__ */createComplex({ + Complex, + typed +}); +export var conj = /* #__PURE__ */createConj({ + typed +}); +export var cos = /* #__PURE__ */createCos({ + typed +}); +export var cot = /* #__PURE__ */createCot({ + BigNumber, + typed +}); +export var csc = /* #__PURE__ */createCsc({ + BigNumber, + typed +}); +export var cube = /* #__PURE__ */createCube({ + typed +}); +export var equalScalar = /* #__PURE__ */createEqualScalar({ + config, + typed +}); +export var erf = /* #__PURE__ */createErf({ + typed +}); +export var exp = /* #__PURE__ */createExp({ + typed +}); +export var expm1 = /* #__PURE__ */createExpm1({ + Complex, + typed +}); +export var filter = /* #__PURE__ */createFilter({ + typed +}); +export var flatten = /* #__PURE__ */createFlatten({ + typed +}); +export var forEach = /* #__PURE__ */createForEach({ + typed +}); +export var format = /* #__PURE__ */createFormat({ + typed +}); +export var getMatrixDataType = /* #__PURE__ */createGetMatrixDataType({ + typed +}); +export var hex = /* #__PURE__ */createHex({ + format, + typed +}); +export var im = /* #__PURE__ */createIm({ + typed +}); +export var isInteger = /* #__PURE__ */createIsInteger({ + typed +}); +export var isNegative = /* #__PURE__ */createIsNegative({ + config, + typed +}); +export var isPositive = /* #__PURE__ */createIsPositive({ + config, + typed +}); +export var isZero = /* #__PURE__ */createIsZero({ + equalScalar, + typed +}); +export var LOG2E = /* #__PURE__ */createLOG2E({ + BigNumber, + config +}); +export var lgamma = /* #__PURE__ */createLgamma({ + Complex, + typed +}); +export var log10 = /* #__PURE__ */createLog10({ + Complex, + config, + typed +}); +export var log2 = /* #__PURE__ */createLog2({ + Complex, + config, + typed +}); +export var map = /* #__PURE__ */createMap({ + typed +}); +export var multiplyScalar = /* #__PURE__ */createMultiplyScalar({ + typed +}); +export var not = /* #__PURE__ */createNot({ + typed +}); +export var number = /* #__PURE__ */createNumber({ + typed +}); +export var oct = /* #__PURE__ */createOct({ + format, + typed +}); +export var pickRandom = /* #__PURE__ */createPickRandom({ + config, + typed +}); +export var print = /* #__PURE__ */createPrint({ + typed +}); +export var random = /* #__PURE__ */createRandom({ + config, + typed +}); +export var re = /* #__PURE__ */createRe({ + typed +}); +export var sec = /* #__PURE__ */createSec({ + BigNumber, + typed +}); +export var sign = /* #__PURE__ */createSign({ + BigNumber, + Fraction, + complex, + typed +}); +export var sin = /* #__PURE__ */createSin({ + typed +}); +export var SparseMatrix = /* #__PURE__ */createSparseMatrixClass({ + Matrix, + equalScalar, + typed +}); +export var splitUnit = /* #__PURE__ */createSplitUnit({ + typed +}); +export var square = /* #__PURE__ */createSquare({ + typed +}); +export var string = /* #__PURE__ */createString({ + typed +}); +export var subtractScalar = /* #__PURE__ */createSubtractScalar({ + typed +}); +export var tan = /* #__PURE__ */createTan({ + typed +}); +export var typeOf = /* #__PURE__ */createTypeOf({ + typed +}); +export var acosh = /* #__PURE__ */createAcosh({ + Complex, + config, + typed +}); +export var acsch = /* #__PURE__ */createAcsch({ + BigNumber, + typed +}); +export var apply = /* #__PURE__ */createApply({ + isInteger, + typed +}); +export var asec = /* #__PURE__ */createAsec({ + BigNumber, + Complex, + config, + typed +}); +export var bignumber = /* #__PURE__ */createBignumber({ + BigNumber, + typed +}); +export var combinationsWithRep = /* #__PURE__ */createCombinationsWithRep({ + typed +}); +export var cosh = /* #__PURE__ */createCosh({ + typed +}); +export var csch = /* #__PURE__ */createCsch({ + BigNumber, + typed +}); +export var isNaN = /* #__PURE__ */createIsNaN({ + typed +}); +export var isPrime = /* #__PURE__ */createIsPrime({ + typed +}); +export var randomInt = /* #__PURE__ */createRandomInt({ + config, + typed +}); +export var sech = /* #__PURE__ */createSech({ + BigNumber, + typed +}); +export var sinh = /* #__PURE__ */createSinh({ + typed +}); +export var sparse = /* #__PURE__ */createSparse({ + SparseMatrix, + typed +}); +export var sqrt = /* #__PURE__ */createSqrt({ + Complex, + config, + typed +}); +export var squeeze = /* #__PURE__ */createSqueeze({ + typed +}); +export var tanh = /* #__PURE__ */createTanh({ + typed +}); +export var unaryMinus = /* #__PURE__ */createUnaryMinus({ + typed +}); +export var acoth = /* #__PURE__ */createAcoth({ + BigNumber, + Complex, + config, + typed +}); +export var bin = /* #__PURE__ */createBin({ + format, + typed +}); +export var coth = /* #__PURE__ */createCoth({ + BigNumber, + typed +}); +export var fraction = /* #__PURE__ */createFraction({ + Fraction, + typed +}); +export var isNumeric = /* #__PURE__ */createIsNumeric({ + typed +}); +export var matrix = /* #__PURE__ */createMatrix({ + DenseMatrix, + Matrix, + SparseMatrix, + typed +}); +export var matrixFromFunction = /* #__PURE__ */createMatrixFromFunction({ + isZero, + matrix, + typed +}); +export var mode = /* #__PURE__ */createMode({ + isNaN, + isNumeric, + typed +}); +export var numeric = /* #__PURE__ */createNumeric({ + bignumber, + fraction, + number +}); +export var prod = /* #__PURE__ */createProd({ + config, + multiplyScalar, + numeric, + typed +}); +export var reshape = /* #__PURE__ */createReshape({ + isInteger, + matrix, + typed +}); +export var size = /* #__PURE__ */createSize({ + matrix, + config, + typed +}); +export var transpose = /* #__PURE__ */createTranspose({ + matrix, + typed +}); +export var xgcd = /* #__PURE__ */createXgcd({ + BigNumber, + config, + matrix, + typed +}); +export var zeros = /* #__PURE__ */createZeros({ + BigNumber, + config, + matrix, + typed +}); +export var asin = /* #__PURE__ */createAsin({ + Complex, + config, + typed +}); +export var cbrt = /* #__PURE__ */createCbrt({ + BigNumber, + Complex, + Fraction, + config, + isNegative, + matrix, + typed, + unaryMinus +}); +export var concat = /* #__PURE__ */createConcat({ + isInteger, + matrix, + typed +}); +export var count = /* #__PURE__ */createCount({ + prod, + size, + typed +}); +export var ctranspose = /* #__PURE__ */createCtranspose({ + conj, + transpose, + typed +}); +export var diag = /* #__PURE__ */createDiag({ + DenseMatrix, + SparseMatrix, + matrix, + typed +}); +export var divideScalar = /* #__PURE__ */createDivideScalar({ + numeric, + typed +}); +export var dotDivide = /* #__PURE__ */createDotDivide({ + DenseMatrix, + concat, + divideScalar, + equalScalar, + matrix, + typed +}); +export var equal = /* #__PURE__ */createEqual({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +export var hasNumericValue = /* #__PURE__ */createHasNumericValue({ + isNumeric, + typed +}); +export var identity = /* #__PURE__ */createIdentity({ + BigNumber, + DenseMatrix, + SparseMatrix, + config, + matrix, + typed +}); +export var kron = /* #__PURE__ */createKron({ + matrix, + multiplyScalar, + typed +}); +export var largerEq = /* #__PURE__ */createLargerEq({ + DenseMatrix, + concat, + config, + matrix, + typed +}); +export var leftShift = /* #__PURE__ */createLeftShift({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +export var lsolve = /* #__PURE__ */createLsolve({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +export var matrixFromColumns = /* #__PURE__ */createMatrixFromColumns({ + flatten, + matrix, + size, + typed +}); +export var nthRoot = /* #__PURE__ */createNthRoot({ + BigNumber, + concat, + equalScalar, + matrix, + typed +}); +export var ones = /* #__PURE__ */createOnes({ + BigNumber, + config, + matrix, + typed +}); +export var qr = /* #__PURE__ */createQr({ + addScalar, + complex, + conj, + divideScalar, + equal, + identity, + isZero, + matrix, + multiplyScalar, + sign, + sqrt, + subtractScalar, + typed, + unaryMinus, + zeros +}); +export var resize = /* #__PURE__ */createResize({ + config, + matrix +}); +export var rightArithShift = /* #__PURE__ */createRightArithShift({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +export var round = /* #__PURE__ */createRound({ + BigNumber, + DenseMatrix, + config, + equalScalar, + matrix, + typed, + zeros +}); +export var smaller = /* #__PURE__ */createSmaller({ + DenseMatrix, + concat, + config, + matrix, + typed +}); +export var subtract = /* #__PURE__ */createSubtract({ + DenseMatrix, + concat, + equalScalar, + matrix, + subtractScalar, + typed, + unaryMinus +}); +export var to = /* #__PURE__ */createTo({ + concat, + matrix, + typed +}); +export var unaryPlus = /* #__PURE__ */createUnaryPlus({ + config, + numeric, + typed +}); +export var usolve = /* #__PURE__ */createUsolve({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +export var xor = /* #__PURE__ */createXor({ + DenseMatrix, + concat, + matrix, + typed +}); +export var add = /* #__PURE__ */createAdd({ + DenseMatrix, + SparseMatrix, + addScalar, + concat, + equalScalar, + matrix, + typed +}); +export var atan2 = /* #__PURE__ */createAtan2({ + BigNumber, + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +export var bitAnd = /* #__PURE__ */createBitAnd({ + concat, + equalScalar, + matrix, + typed +}); +export var bitOr = /* #__PURE__ */createBitOr({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +export var bitXor = /* #__PURE__ */createBitXor({ + DenseMatrix, + concat, + matrix, + typed +}); +export var catalan = /* #__PURE__ */createCatalan({ + addScalar, + combinations, + divideScalar, + isInteger, + isNegative, + multiplyScalar, + typed +}); +export var compare = /* #__PURE__ */createCompare({ + BigNumber, + DenseMatrix, + Fraction, + concat, + config, + equalScalar, + matrix, + typed +}); +export var compareText = /* #__PURE__ */createCompareText({ + concat, + matrix, + typed +}); +export var cumsum = /* #__PURE__ */createCumSum({ + add, + typed, + unaryPlus +}); +export var deepEqual = /* #__PURE__ */createDeepEqual({ + equal, + typed +}); +export var diff = /* #__PURE__ */createDiff({ + matrix, + number, + subtract, + typed +}); +export var distance = /* #__PURE__ */createDistance({ + abs, + addScalar, + deepEqual, + divideScalar, + multiplyScalar, + sqrt, + subtractScalar, + typed +}); +export var dot = /* #__PURE__ */createDot({ + addScalar, + conj, + multiplyScalar, + size, + typed +}); +export var equalText = /* #__PURE__ */createEqualText({ + compareText, + isZero, + typed +}); +export var floor = /* #__PURE__ */createFloor({ + DenseMatrix, + config, + equalScalar, + matrix, + round, + typed, + zeros +}); +export var gcd = /* #__PURE__ */createGcd({ + BigNumber, + DenseMatrix, + concat, + config, + equalScalar, + matrix, + round, + typed, + zeros +}); +export var hypot = /* #__PURE__ */createHypot({ + abs, + addScalar, + divideScalar, + isPositive, + multiplyScalar, + smaller, + sqrt, + typed +}); +export var ImmutableDenseMatrix = /* #__PURE__ */createImmutableDenseMatrixClass({ + DenseMatrix, + smaller +}); +export var Index = /* #__PURE__ */createIndexClass({ + ImmutableDenseMatrix, + getMatrixDataType +}); +export var larger = /* #__PURE__ */createLarger({ + DenseMatrix, + concat, + config, + matrix, + typed +}); +export var log = /* #__PURE__ */createLog({ + Complex, + config, + divideScalar, + typed +}); +export var lsolveAll = /* #__PURE__ */createLsolveAll({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +export var matrixFromRows = /* #__PURE__ */createMatrixFromRows({ + flatten, + matrix, + size, + typed +}); +export var min = /* #__PURE__ */createMin({ + config, + numeric, + smaller, + typed +}); +export var mod = /* #__PURE__ */createMod({ + DenseMatrix, + concat, + config, + equalScalar, + matrix, + round, + typed, + zeros +}); +export var multiply = /* #__PURE__ */createMultiply({ + addScalar, + dot, + equalScalar, + matrix, + multiplyScalar, + typed +}); +export var nthRoots = /* #__PURE__ */createNthRoots({ + Complex, + config, + divideScalar, + typed +}); +export var or = /* #__PURE__ */createOr({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed +}); +export var partitionSelect = /* #__PURE__ */createPartitionSelect({ + compare, + isNaN, + isNumeric, + typed +}); +export var rightLogShift = /* #__PURE__ */createRightLogShift({ + DenseMatrix, + concat, + equalScalar, + matrix, + typed, + zeros +}); +export var slu = /* #__PURE__ */createSlu({ + SparseMatrix, + abs, + add, + divideScalar, + larger, + largerEq, + multiply, + subtract, + transpose, + typed +}); +export var subset = /* #__PURE__ */createSubset({ + add, + matrix, + typed, + zeros +}); +export var sum = /* #__PURE__ */createSum({ + add, + config, + numeric, + typed +}); +export var trace = /* #__PURE__ */createTrace({ + add, + matrix, + typed +}); +export var usolveAll = /* #__PURE__ */createUsolveAll({ + DenseMatrix, + divideScalar, + equalScalar, + matrix, + multiplyScalar, + subtractScalar, + typed +}); +export var zpk2tf = /* #__PURE__ */createZpk2tf({ + Complex, + add, + multiply, + number, + typed +}); +export var ceil = /* #__PURE__ */createCeil({ + DenseMatrix, + config, + equalScalar, + matrix, + round, + typed, + zeros +}); +export var compareNatural = /* #__PURE__ */createCompareNatural({ + compare, + typed +}); +export var composition = /* #__PURE__ */createComposition({ + addScalar, + combinations, + isInteger, + isNegative, + isPositive, + larger, + typed +}); +export var cross = /* #__PURE__ */createCross({ + matrix, + multiply, + subtract, + typed +}); +export var det = /* #__PURE__ */createDet({ + divideScalar, + isZero, + matrix, + multiply, + subtractScalar, + typed, + unaryMinus +}); +export var dotMultiply = /* #__PURE__ */createDotMultiply({ + concat, + equalScalar, + matrix, + multiplyScalar, + typed +}); +export var FibonacciHeap = /* #__PURE__ */createFibonacciHeapClass({ + larger, + smaller +}); +export var fix = /* #__PURE__ */createFix({ + Complex, + DenseMatrix, + ceil, + equalScalar, + floor, + matrix, + typed, + zeros +}); +export var index = /* #__PURE__ */createIndex({ + Index, + typed +}); +export var intersect = /* #__PURE__ */createIntersect({ + abs, + add, + addScalar, + config, + divideScalar, + equalScalar, + flatten, + isNumeric, + isZero, + matrix, + multiply, + multiplyScalar, + smaller, + subtract, + typed +}); +export var invmod = /* #__PURE__ */createInvmod({ + BigNumber, + add, + config, + equal, + isInteger, + mod, + smaller, + typed, + xgcd +}); +export var lcm = /* #__PURE__ */createLcm({ + concat, + equalScalar, + matrix, + typed +}); +export var log1p = /* #__PURE__ */createLog1p({ + Complex, + config, + divideScalar, + log, + typed +}); +export var max = /* #__PURE__ */createMax({ + config, + larger, + numeric, + typed +}); +export var setCartesian = /* #__PURE__ */createSetCartesian({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +export var setDistinct = /* #__PURE__ */createSetDistinct({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +export var setIsSubset = /* #__PURE__ */createSetIsSubset({ + Index, + compareNatural, + size, + subset, + typed +}); +export var setPowerset = /* #__PURE__ */createSetPowerset({ + Index, + compareNatural, + size, + subset, + typed +}); +export var smallerEq = /* #__PURE__ */createSmallerEq({ + DenseMatrix, + concat, + config, + matrix, + typed +}); +export var sort = /* #__PURE__ */createSort({ + compare, + compareNatural, + matrix, + typed +}); +export var unequal = /* #__PURE__ */createUnequal({ + DenseMatrix, + concat, + config, + equalScalar, + matrix, + typed +}); +export var and = /* #__PURE__ */createAnd({ + concat, + equalScalar, + matrix, + not, + typed, + zeros +}); +export var range = /* #__PURE__ */createRange({ + bignumber, + matrix, + add, + config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed +}); +export var row = /* #__PURE__ */createRow({ + Index, + matrix, + range, + typed +}); +export var setDifference = /* #__PURE__ */createSetDifference({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +export var setMultiplicity = /* #__PURE__ */createSetMultiplicity({ + Index, + compareNatural, + size, + subset, + typed +}); +export var setSymDifference = /* #__PURE__ */createSetSymDifference({ + Index, + concat, + setDifference, + size, + subset, + typed +}); +export var Spa = /* #__PURE__ */createSpaClass({ + FibonacciHeap, + addScalar, + equalScalar +}); +export var column = /* #__PURE__ */createColumn({ + Index, + matrix, + range, + typed +}); +export var inv = /* #__PURE__ */createInv({ + abs, + addScalar, + det, + divideScalar, + identity, + matrix, + multiply, + typed, + unaryMinus +}); +export var lup = /* #__PURE__ */createLup({ + DenseMatrix, + Spa, + SparseMatrix, + abs, + addScalar, + divideScalar, + equalScalar, + larger, + matrix, + multiplyScalar, + subtractScalar, + typed, + unaryMinus +}); +export var pinv = /* #__PURE__ */createPinv({ + Complex, + add, + ctranspose, + deepEqual, + divideScalar, + dot, + dotDivide, + equal, + inv, + matrix, + multiply, + typed +}); +export var pow = /* #__PURE__ */createPow({ + Complex, + config, + fraction, + identity, + inv, + matrix, + multiply, + number, + typed +}); +export var setIntersect = /* #__PURE__ */createSetIntersect({ + DenseMatrix, + Index, + compareNatural, + size, + subset, + typed +}); +export var setUnion = /* #__PURE__ */createSetUnion({ + Index, + concat, + setIntersect, + setSymDifference, + size, + subset, + typed +}); +export var sqrtm = /* #__PURE__ */createSqrtm({ + abs, + add, + identity, + inv, + map, + max, + multiply, + size, + sqrt, + subtract, + typed +}); +export var Unit = /* #__PURE__ */createUnitClass({ + BigNumber, + Complex, + Fraction, + abs, + addScalar, + config, + divideScalar, + equal, + fix, + format, + isNumeric, + multiplyScalar, + number, + pow, + round, + subtractScalar +}); +export var vacuumImpedance = /* #__PURE__ */createVacuumImpedance({ + BigNumber, + Unit, + config +}); +export var wienDisplacement = /* #__PURE__ */createWienDisplacement({ + BigNumber, + Unit, + config +}); +export var atomicMass = /* #__PURE__ */createAtomicMass({ + BigNumber, + Unit, + config +}); +export var bohrMagneton = /* #__PURE__ */createBohrMagneton({ + BigNumber, + Unit, + config +}); +export var boltzmann = /* #__PURE__ */createBoltzmann({ + BigNumber, + Unit, + config +}); +export var conductanceQuantum = /* #__PURE__ */createConductanceQuantum({ + BigNumber, + Unit, + config +}); +export var coulomb = /* #__PURE__ */createCoulomb({ + BigNumber, + Unit, + config +}); +export var deuteronMass = /* #__PURE__ */createDeuteronMass({ + BigNumber, + Unit, + config +}); +export var dotPow = /* #__PURE__ */createDotPow({ + DenseMatrix, + concat, + equalScalar, + matrix, + pow, + typed +}); +export var electricConstant = /* #__PURE__ */createElectricConstant({ + BigNumber, + Unit, + config +}); +export var elementaryCharge = /* #__PURE__ */createElementaryCharge({ + BigNumber, + Unit, + config +}); +export var expm = /* #__PURE__ */createExpm({ + abs, + add, + identity, + inv, + multiply, + typed +}); +export var faraday = /* #__PURE__ */createFaraday({ + BigNumber, + Unit, + config +}); +export var fft = /* #__PURE__ */createFft({ + addScalar, + ceil, + conj, + divideScalar, + dotDivide, + exp, + i, + log2, + matrix, + multiplyScalar, + pow, + tau, + typed +}); +export var gamma = /* #__PURE__ */createGamma({ + BigNumber, + Complex, + config, + multiplyScalar, + pow, + typed +}); +export var gravitationConstant = /* #__PURE__ */createGravitationConstant({ + BigNumber, + Unit, + config +}); +export var hartreeEnergy = /* #__PURE__ */createHartreeEnergy({ + BigNumber, + Unit, + config +}); +export var ifft = /* #__PURE__ */createIfft({ + conj, + dotDivide, + fft, + typed +}); +export var klitzing = /* #__PURE__ */createKlitzing({ + BigNumber, + Unit, + config +}); +export var loschmidt = /* #__PURE__ */createLoschmidt({ + BigNumber, + Unit, + config +}); +export var magneticConstant = /* #__PURE__ */createMagneticConstant({ + BigNumber, + Unit, + config +}); +export var molarMass = /* #__PURE__ */createMolarMass({ + BigNumber, + Unit, + config +}); +export var molarPlanckConstant = /* #__PURE__ */createMolarPlanckConstant({ + BigNumber, + Unit, + config +}); +export var neutronMass = /* #__PURE__ */createNeutronMass({ + BigNumber, + Unit, + config +}); +export var nuclearMagneton = /* #__PURE__ */createNuclearMagneton({ + BigNumber, + Unit, + config +}); +export var planckCharge = /* #__PURE__ */createPlanckCharge({ + BigNumber, + Unit, + config +}); +export var planckLength = /* #__PURE__ */createPlanckLength({ + BigNumber, + Unit, + config +}); +export var planckTemperature = /* #__PURE__ */createPlanckTemperature({ + BigNumber, + Unit, + config +}); +export var protonMass = /* #__PURE__ */createProtonMass({ + BigNumber, + Unit, + config +}); +export var quantumOfCirculation = /* #__PURE__ */createQuantumOfCirculation({ + BigNumber, + Unit, + config +}); +export var reducedPlanckConstant = /* #__PURE__ */createReducedPlanckConstant({ + BigNumber, + Unit, + config +}); +export var rydberg = /* #__PURE__ */createRydberg({ + BigNumber, + Unit, + config +}); +export var secondRadiation = /* #__PURE__ */createSecondRadiation({ + BigNumber, + Unit, + config +}); +export var speedOfLight = /* #__PURE__ */createSpeedOfLight({ + BigNumber, + Unit, + config +}); +export var stefanBoltzmann = /* #__PURE__ */createStefanBoltzmann({ + BigNumber, + Unit, + config +}); +export var thomsonCrossSection = /* #__PURE__ */createThomsonCrossSection({ + BigNumber, + Unit, + config +}); +export var avogadro = /* #__PURE__ */createAvogadro({ + BigNumber, + Unit, + config +}); +export var bohrRadius = /* #__PURE__ */createBohrRadius({ + BigNumber, + Unit, + config +}); +export var createUnit = /* #__PURE__ */createCreateUnit({ + Unit, + typed +}); +export var divide = /* #__PURE__ */createDivide({ + divideScalar, + equalScalar, + inv, + matrix, + multiply, + typed +}); +export var electronMass = /* #__PURE__ */createElectronMass({ + BigNumber, + Unit, + config +}); +export var factorial = /* #__PURE__ */createFactorial({ + gamma, + typed +}); +export var firstRadiation = /* #__PURE__ */createFirstRadiation({ + BigNumber, + Unit, + config +}); +export var gravity = /* #__PURE__ */createGravity({ + BigNumber, + Unit, + config +}); +export var inverseConductanceQuantum = /* #__PURE__ */createInverseConductanceQuantum({ + BigNumber, + Unit, + config +}); +export var lusolve = /* #__PURE__ */createLusolve({ + DenseMatrix, + lsolve, + lup, + matrix, + slu, + typed, + usolve +}); +export var magneticFluxQuantum = /* #__PURE__ */createMagneticFluxQuantum({ + BigNumber, + Unit, + config +}); +export var molarMassC12 = /* #__PURE__ */createMolarMassC12({ + BigNumber, + Unit, + config +}); +export var multinomial = /* #__PURE__ */createMultinomial({ + add, + divide, + factorial, + isInteger, + isPositive, + multiply, + typed +}); +export var permutations = /* #__PURE__ */createPermutations({ + factorial, + typed +}); +export var planckMass = /* #__PURE__ */createPlanckMass({ + BigNumber, + Unit, + config +}); +export var polynomialRoot = /* #__PURE__ */createPolynomialRoot({ + add, + cbrt, + divide, + equalScalar, + im, + isZero, + multiply, + re, + sqrt, + subtract, + typeOf, + typed, + unaryMinus +}); +export var setSize = /* #__PURE__ */createSetSize({ + compareNatural, + typed +}); +export var solveODE = /* #__PURE__ */createSolveODE({ + abs, + add, + bignumber, + divide, + isNegative, + isPositive, + larger, + map, + matrix, + max, + multiply, + smaller, + subtract, + typed, + unaryMinus +}); +export var stirlingS2 = /* #__PURE__ */createStirlingS2({ + bignumber, + addScalar, + combinations, + divideScalar, + factorial, + isInteger, + isNegative, + larger, + multiplyScalar, + number, + pow, + subtractScalar, + typed +}); +export var unit = /* #__PURE__ */createUnitFunction({ + Unit, + typed +}); +export var bellNumbers = /* #__PURE__ */createBellNumbers({ + addScalar, + isInteger, + isNegative, + stirlingS2, + typed +}); +export var eigs = /* #__PURE__ */createEigs({ + abs, + add, + addScalar, + atan, + bignumber, + column, + complex, + config, + cos, + diag, + divideScalar, + dot, + equal, + flatten, + im, + inv, + larger, + matrix, + matrixFromColumns, + multiply, + multiplyScalar, + number, + qr, + re, + reshape, + sin, + size, + smaller, + sqrt, + subtract, + typed, + usolve, + usolveAll +}); +export var fermiCoupling = /* #__PURE__ */createFermiCoupling({ + BigNumber, + Unit, + config +}); +export var gasConstant = /* #__PURE__ */createGasConstant({ + BigNumber, + Unit, + config +}); +export var kldivergence = /* #__PURE__ */createKldivergence({ + divide, + dotDivide, + isNumeric, + log, + map, + matrix, + multiply, + sum, + typed +}); +export var mean = /* #__PURE__ */createMean({ + add, + divide, + typed +}); +export var molarVolume = /* #__PURE__ */createMolarVolume({ + BigNumber, + Unit, + config +}); +export var planckConstant = /* #__PURE__ */createPlanckConstant({ + BigNumber, + Unit, + config +}); +export var quantileSeq = /* #__PURE__ */createQuantileSeq({ + bignumber, + add, + compare, + divide, + isInteger, + larger, + multiply, + partitionSelect, + smaller, + smallerEq, + subtract, + typed +}); +export var variance = /* #__PURE__ */createVariance({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed +}); +export var classicalElectronRadius = /* #__PURE__ */createClassicalElectronRadius({ + BigNumber, + Unit, + config +}); +export var median = /* #__PURE__ */createMedian({ + add, + compare, + divide, + partitionSelect, + typed +}); +export var corr = /* #__PURE__ */createCorr({ + add, + divide, + matrix, + mean, + multiply, + pow, + sqrt, + subtract, + sum, + typed +}); +export var freqz = /* #__PURE__ */createFreqz({ + Complex, + add, + divide, + matrix, + multiply, + typed +}); +export var mad = /* #__PURE__ */createMad({ + abs, + map, + median, + subtract, + typed +}); +export var std = /* #__PURE__ */createStd({ + map, + sqrt, + typed, + variance +}); +export var zeta = /* #__PURE__ */createZeta({ + BigNumber, + Complex, + add, + config, + divide, + equal, + factorial, + gamma, + isNegative, + multiply, + pi, + pow, + sin, + smallerEq, + subtract, + typed +}); +export var norm = /* #__PURE__ */createNorm({ + abs, + add, + conj, + ctranspose, + eigs, + equalScalar, + larger, + matrix, + multiply, + pow, + smaller, + sqrt, + typed +}); +export var rotationMatrix = /* #__PURE__ */createRotationMatrix({ + BigNumber, + DenseMatrix, + SparseMatrix, + addScalar, + config, + cos, + matrix, + multiplyScalar, + norm, + sin, + typed, + unaryMinus +}); +export var planckTime = /* #__PURE__ */createPlanckTime({ + BigNumber, + Unit, + config +}); +export var schur = /* #__PURE__ */createSchur({ + identity, + matrix, + multiply, + norm, + qr, + subtract, + typed +}); +export var rotate = /* #__PURE__ */createRotate({ + multiply, + rotationMatrix, + typed +}); +export var sylvester = /* #__PURE__ */createSylvester({ + abs, + add, + concat, + identity, + index, + lusolve, + matrix, + matrixFromColumns, + multiply, + range, + schur, + subset, + subtract, + transpose, + typed +}); +export var lyap = /* #__PURE__ */createLyap({ + matrix, + multiply, + sylvester, + transpose, + typed +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsNumber.generated.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsNumber.generated.js new file mode 100644 index 0000000..2dddca6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/pureFunctionsNumber.generated.js @@ -0,0 +1,605 @@ +/** + * THIS FILE IS AUTO-GENERATED + * DON'T MAKE CHANGES HERE + */ +import { config } from './configReadonly.js'; +import { createE, createFalse, createIndex, createInfinity, createLN10, createLOG10E, createMatrix, createNaN, createNull, createPhi, createRangeClass, createReplacer, createResultSet, createSQRT1_2, +// eslint-disable-line camelcase +createSubset, createTau, createTyped, createUnaryPlus, createVersion, createXor, createAbs, createAcos, createAcot, createAcsc, createAdd, createAnd, createAsec, createAsin, createAtan, createAtanh, createBigint, createBitNot, createBitXor, createBoolean, createCbrt, createCombinations, createCompare, createCompareText, createCos, createCot, createCsc, createCube, createDivide, createEqualScalar, createErf, createExp, createFilter, createForEach, createFormat, createGamma, createIsInteger, createIsNegative, createIsPositive, createIsZero, createLOG2E, createLargerEq, createLeftShift, createLog, createLog1p, createMap, createMean, createMod, createMultiply, createNot, createNumber, createOr, createPi, createPow, createRandom, createRightLogShift, createSQRT2, createSech, createSin, createSize, createSmallerEq, createSquare, createString, createSubtract, createTanh, createTypeOf, createUnequal, createXgcd, createAcoth, createAddScalar, createAsech, createBitAnd, createCombinationsWithRep, createCosh, createCsch, createDivideScalar, createEqualText, createExpm1, createIsNumeric, createLN2, createLcm, createLog10, createMultiplyScalar, createNthRoot, createPickRandom, createRandomInt, createRightArithShift, createSec, createSinh, createSqrt, createTan, createUnaryMinus, createAcosh, createApply, createAsinh, createBitOr, createClone, createCoth, createEqual, createFactorial, createHasNumericValue, createIsNaN, createLarger, createLog2, createMode, createNorm, createPartitionSelect, createPrint, createRound, createSmaller, createSubtractScalar, createTrue, createVariance, createZeta, createAcsch, createAtan2, createCatalan, createCompareNatural, createComposition, createCumSum, createFloor, createHypot, createLgamma, createMedian, createMultinomial, createPermutations, createQuantileSeq, createSign, createStd, createStirlingS2, createCeil, createDeepEqual, createFix, createIsPrime, createNumeric, createProd, createBellNumbers, createGcd, createMad, createRange, createSum, createCorr, createMax, createMin } from '../factoriesNumber.js'; +export var e = /* #__PURE__ */createE({ + config +}); +export var _false = /* #__PURE__ */createFalse({}); +export var index = /* #__PURE__ */createIndex({}); +export var _Infinity = /* #__PURE__ */createInfinity({ + config +}); +export var LN10 = /* #__PURE__ */createLN10({ + config +}); +export var LOG10E = /* #__PURE__ */createLOG10E({ + config +}); +export var matrix = /* #__PURE__ */createMatrix({}); +export var _NaN = /* #__PURE__ */createNaN({ + config +}); +export var _null = /* #__PURE__ */createNull({}); +export var phi = /* #__PURE__ */createPhi({ + config +}); +export var Range = /* #__PURE__ */createRangeClass({}); +export var replacer = /* #__PURE__ */createReplacer({}); +export var ResultSet = /* #__PURE__ */createResultSet({}); +export var SQRT1_2 = /* #__PURE__ */createSQRT1_2({ + config +}); +export var subset = /* #__PURE__ */createSubset({}); +export var tau = /* #__PURE__ */createTau({ + config +}); +export var typed = /* #__PURE__ */createTyped({}); +export var unaryPlus = /* #__PURE__ */createUnaryPlus({ + typed +}); +export var version = /* #__PURE__ */createVersion({}); +export var xor = /* #__PURE__ */createXor({ + typed +}); +export var abs = /* #__PURE__ */createAbs({ + typed +}); +export var acos = /* #__PURE__ */createAcos({ + typed +}); +export var acot = /* #__PURE__ */createAcot({ + typed +}); +export var acsc = /* #__PURE__ */createAcsc({ + typed +}); +export var add = /* #__PURE__ */createAdd({ + typed +}); +export var and = /* #__PURE__ */createAnd({ + typed +}); +export var asec = /* #__PURE__ */createAsec({ + typed +}); +export var asin = /* #__PURE__ */createAsin({ + typed +}); +export var atan = /* #__PURE__ */createAtan({ + typed +}); +export var atanh = /* #__PURE__ */createAtanh({ + typed +}); +export var bigint = /* #__PURE__ */createBigint({ + typed +}); +export var bitNot = /* #__PURE__ */createBitNot({ + typed +}); +export var bitXor = /* #__PURE__ */createBitXor({ + typed +}); +export var boolean = /* #__PURE__ */createBoolean({ + typed +}); +export var cbrt = /* #__PURE__ */createCbrt({ + typed +}); +export var combinations = /* #__PURE__ */createCombinations({ + typed +}); +export var compare = /* #__PURE__ */createCompare({ + config, + typed +}); +export var compareText = /* #__PURE__ */createCompareText({ + typed +}); +export var cos = /* #__PURE__ */createCos({ + typed +}); +export var cot = /* #__PURE__ */createCot({ + typed +}); +export var csc = /* #__PURE__ */createCsc({ + typed +}); +export var cube = /* #__PURE__ */createCube({ + typed +}); +export var divide = /* #__PURE__ */createDivide({ + typed +}); +export var equalScalar = /* #__PURE__ */createEqualScalar({ + config, + typed +}); +export var erf = /* #__PURE__ */createErf({ + typed +}); +export var exp = /* #__PURE__ */createExp({ + typed +}); +export var filter = /* #__PURE__ */createFilter({ + typed +}); +export var forEach = /* #__PURE__ */createForEach({ + typed +}); +export var format = /* #__PURE__ */createFormat({ + typed +}); +export var gamma = /* #__PURE__ */createGamma({ + typed +}); +export var isInteger = /* #__PURE__ */createIsInteger({ + typed +}); +export var isNegative = /* #__PURE__ */createIsNegative({ + typed +}); +export var isPositive = /* #__PURE__ */createIsPositive({ + typed +}); +export var isZero = /* #__PURE__ */createIsZero({ + typed +}); +export var LOG2E = /* #__PURE__ */createLOG2E({ + config +}); +export var largerEq = /* #__PURE__ */createLargerEq({ + config, + typed +}); +export var leftShift = /* #__PURE__ */createLeftShift({ + typed +}); +export var log = /* #__PURE__ */createLog({ + typed +}); +export var log1p = /* #__PURE__ */createLog1p({ + typed +}); +export var map = /* #__PURE__ */createMap({ + typed +}); +export var mean = /* #__PURE__ */createMean({ + add, + divide, + typed +}); +export var mod = /* #__PURE__ */createMod({ + typed +}); +export var multiply = /* #__PURE__ */createMultiply({ + typed +}); +export var not = /* #__PURE__ */createNot({ + typed +}); +export var number = /* #__PURE__ */createNumber({ + typed +}); +export var or = /* #__PURE__ */createOr({ + typed +}); +export var pi = /* #__PURE__ */createPi({ + config +}); +export var pow = /* #__PURE__ */createPow({ + typed +}); +export var random = /* #__PURE__ */createRandom({ + config, + typed +}); +export var rightLogShift = /* #__PURE__ */createRightLogShift({ + typed +}); +export var SQRT2 = /* #__PURE__ */createSQRT2({ + config +}); +export var sech = /* #__PURE__ */createSech({ + typed +}); +export var sin = /* #__PURE__ */createSin({ + typed +}); +export var size = /* #__PURE__ */createSize({ + matrix, + config, + typed +}); +export var smallerEq = /* #__PURE__ */createSmallerEq({ + config, + typed +}); +export var square = /* #__PURE__ */createSquare({ + typed +}); +export var string = /* #__PURE__ */createString({ + typed +}); +export var subtract = /* #__PURE__ */createSubtract({ + typed +}); +export var tanh = /* #__PURE__ */createTanh({ + typed +}); +export var typeOf = /* #__PURE__ */createTypeOf({ + typed +}); +export var unequal = /* #__PURE__ */createUnequal({ + equalScalar, + typed +}); +export var xgcd = /* #__PURE__ */createXgcd({ + typed +}); +export var acoth = /* #__PURE__ */createAcoth({ + typed +}); +export var addScalar = /* #__PURE__ */createAddScalar({ + typed +}); +export var asech = /* #__PURE__ */createAsech({ + typed +}); +export var bitAnd = /* #__PURE__ */createBitAnd({ + typed +}); +export var combinationsWithRep = /* #__PURE__ */createCombinationsWithRep({ + typed +}); +export var cosh = /* #__PURE__ */createCosh({ + typed +}); +export var csch = /* #__PURE__ */createCsch({ + typed +}); +export var divideScalar = /* #__PURE__ */createDivideScalar({ + typed +}); +export var equalText = /* #__PURE__ */createEqualText({ + compareText, + isZero, + typed +}); +export var expm1 = /* #__PURE__ */createExpm1({ + typed +}); +export var isNumeric = /* #__PURE__ */createIsNumeric({ + typed +}); +export var LN2 = /* #__PURE__ */createLN2({ + config +}); +export var lcm = /* #__PURE__ */createLcm({ + typed +}); +export var log10 = /* #__PURE__ */createLog10({ + typed +}); +export var multiplyScalar = /* #__PURE__ */createMultiplyScalar({ + typed +}); +export var nthRoot = /* #__PURE__ */createNthRoot({ + typed +}); +export var pickRandom = /* #__PURE__ */createPickRandom({ + config, + typed +}); +export var randomInt = /* #__PURE__ */createRandomInt({ + config, + typed +}); +export var rightArithShift = /* #__PURE__ */createRightArithShift({ + typed +}); +export var sec = /* #__PURE__ */createSec({ + typed +}); +export var sinh = /* #__PURE__ */createSinh({ + typed +}); +export var sqrt = /* #__PURE__ */createSqrt({ + typed +}); +export var tan = /* #__PURE__ */createTan({ + typed +}); +export var unaryMinus = /* #__PURE__ */createUnaryMinus({ + typed +}); +export var acosh = /* #__PURE__ */createAcosh({ + typed +}); +export var apply = /* #__PURE__ */createApply({ + isInteger, + typed +}); +export var asinh = /* #__PURE__ */createAsinh({ + typed +}); +export var bitOr = /* #__PURE__ */createBitOr({ + typed +}); +export var clone = /* #__PURE__ */createClone({ + typed +}); +export var coth = /* #__PURE__ */createCoth({ + typed +}); +export var equal = /* #__PURE__ */createEqual({ + equalScalar, + typed +}); +export var factorial = /* #__PURE__ */createFactorial({ + gamma, + typed +}); +export var hasNumericValue = /* #__PURE__ */createHasNumericValue({ + isNumeric, + typed +}); +export var isNaN = /* #__PURE__ */createIsNaN({ + typed +}); +export var larger = /* #__PURE__ */createLarger({ + config, + typed +}); +export var log2 = /* #__PURE__ */createLog2({ + typed +}); +export var mode = /* #__PURE__ */createMode({ + isNaN, + isNumeric, + typed +}); +export var norm = /* #__PURE__ */createNorm({ + typed +}); +export var partitionSelect = /* #__PURE__ */createPartitionSelect({ + compare, + isNaN, + isNumeric, + typed +}); +export var print = /* #__PURE__ */createPrint({ + typed +}); +export var round = /* #__PURE__ */createRound({ + typed +}); +export var smaller = /* #__PURE__ */createSmaller({ + config, + typed +}); +export var subtractScalar = /* #__PURE__ */createSubtractScalar({ + typed +}); +export var _true = /* #__PURE__ */createTrue({}); +export var variance = /* #__PURE__ */createVariance({ + add, + apply, + divide, + isNaN, + multiply, + subtract, + typed +}); +export var zeta = /* #__PURE__ */createZeta({ + add, + config, + divide, + equal, + factorial, + gamma, + isNegative, + multiply, + pi, + pow, + sin, + smallerEq, + subtract, + typed +}); +export var acsch = /* #__PURE__ */createAcsch({ + typed +}); +export var atan2 = /* #__PURE__ */createAtan2({ + typed +}); +export var catalan = /* #__PURE__ */createCatalan({ + addScalar, + combinations, + divideScalar, + isInteger, + isNegative, + multiplyScalar, + typed +}); +export var compareNatural = /* #__PURE__ */createCompareNatural({ + compare, + typed +}); +export var composition = /* #__PURE__ */createComposition({ + addScalar, + combinations, + isInteger, + isNegative, + isPositive, + larger, + typed +}); +export var cumsum = /* #__PURE__ */createCumSum({ + add, + typed, + unaryPlus +}); +export var floor = /* #__PURE__ */createFloor({ + config, + round, + typed +}); +export var hypot = /* #__PURE__ */createHypot({ + abs, + addScalar, + divideScalar, + isPositive, + multiplyScalar, + smaller, + sqrt, + typed +}); +export var lgamma = /* #__PURE__ */createLgamma({ + typed +}); +export var median = /* #__PURE__ */createMedian({ + add, + compare, + divide, + partitionSelect, + typed +}); +export var multinomial = /* #__PURE__ */createMultinomial({ + add, + divide, + factorial, + isInteger, + isPositive, + multiply, + typed +}); +export var permutations = /* #__PURE__ */createPermutations({ + factorial, + typed +}); +export var quantileSeq = /* #__PURE__ */createQuantileSeq({ + add, + compare, + divide, + isInteger, + larger, + multiply, + partitionSelect, + smaller, + smallerEq, + subtract, + typed +}); +export var sign = /* #__PURE__ */createSign({ + typed +}); +export var std = /* #__PURE__ */createStd({ + map, + sqrt, + typed, + variance +}); +export var stirlingS2 = /* #__PURE__ */createStirlingS2({ + addScalar, + combinations, + divideScalar, + factorial, + isInteger, + isNegative, + larger, + multiplyScalar, + number, + pow, + subtractScalar, + typed +}); +export var ceil = /* #__PURE__ */createCeil({ + config, + round, + typed +}); +export var deepEqual = /* #__PURE__ */createDeepEqual({ + equal, + typed +}); +export var fix = /* #__PURE__ */createFix({ + ceil, + floor, + typed +}); +export var isPrime = /* #__PURE__ */createIsPrime({ + typed +}); +export var numeric = /* #__PURE__ */createNumeric({ + number +}); +export var prod = /* #__PURE__ */createProd({ + config, + multiplyScalar, + numeric, + typed +}); +export var bellNumbers = /* #__PURE__ */createBellNumbers({ + addScalar, + isInteger, + isNegative, + stirlingS2, + typed +}); +export var gcd = /* #__PURE__ */createGcd({ + typed +}); +export var mad = /* #__PURE__ */createMad({ + abs, + map, + median, + subtract, + typed +}); +export var range = /* #__PURE__ */createRange({ + matrix, + add, + config, + isPositive, + larger, + largerEq, + smaller, + smallerEq, + typed +}); +export var sum = /* #__PURE__ */createSum({ + add, + config, + numeric, + typed +}); +export var corr = /* #__PURE__ */createCorr({ + add, + divide, + matrix, + mean, + multiply, + pow, + sqrt, + subtract, + sum, + typed +}); +export var max = /* #__PURE__ */createMax({ + config, + larger, + numeric, + typed +}); +export var min = /* #__PURE__ */createMin({ + config, + numeric, + smaller, + typed +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/typeChecks.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/typeChecks.js new file mode 100644 index 0000000..3071835 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/entry/typeChecks.js @@ -0,0 +1,2 @@ +// util functions +export { isAccessorNode, isArray, isArrayNode, isAssignmentNode, isBigNumber, isBigInt, isBlockNode, isBoolean, isChain, isCollection, isComplex, isConditionalNode, isConstantNode, isDate, isDenseMatrix, isFraction, isFunction, isFunctionAssignmentNode, isFunctionNode, isHelp, isIndex, isIndexNode, isMatrix, isNode, isNull, isNumber, isString, isUndefined, isObject, isMap, isPartitionedMap, isObjectWrappingMap, isObjectNode, isOperatorNode, isParenthesisNode, isRange, isRangeNode, isRelationalNode, isRegExp, isResultSet, isSparseMatrix, isSymbolNode, isUnit } from '../utils/is.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/ArgumentsError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/ArgumentsError.js new file mode 100644 index 0000000..82da95e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/ArgumentsError.js @@ -0,0 +1,24 @@ +/** + * Create a syntax error with the message: + * 'Wrong number of arguments in function ( provided, - expected)' + * @param {string} fn Function name + * @param {number} count Actual argument count + * @param {number} min Minimum required argument count + * @param {number} [max] Maximum required argument count + * @extends Error + */ +export function ArgumentsError(fn, count, min, max) { + if (!(this instanceof ArgumentsError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.fn = fn; + this.count = count; + this.min = min; + this.max = max; + this.message = 'Wrong number of arguments in function ' + fn + ' (' + count + ' provided, ' + min + (max !== undefined && max !== null ? '-' + max : '') + ' expected)'; + this.stack = new Error().stack; +} +ArgumentsError.prototype = new Error(); +ArgumentsError.prototype.constructor = Error; +ArgumentsError.prototype.name = 'ArgumentsError'; +ArgumentsError.prototype.isArgumentsError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/DimensionError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/DimensionError.js new file mode 100644 index 0000000..f488487 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/DimensionError.js @@ -0,0 +1,23 @@ +/** + * Create a range error with the message: + * 'Dimension mismatch ( != )' + * @param {number | number[]} actual The actual size + * @param {number | number[]} expected The expected size + * @param {string} [relation='!='] Optional relation between actual + * and expected size: '!=', '<', etc. + * @extends RangeError + */ +export function DimensionError(actual, expected, relation) { + if (!(this instanceof DimensionError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.actual = actual; + this.expected = expected; + this.relation = relation; + this.message = 'Dimension mismatch (' + (Array.isArray(actual) ? '[' + actual.join(', ') + ']' : actual) + ' ' + (this.relation || '!=') + ' ' + (Array.isArray(expected) ? '[' + expected.join(', ') + ']' : expected) + ')'; + this.stack = new Error().stack; +} +DimensionError.prototype = new RangeError(); +DimensionError.prototype.constructor = RangeError; +DimensionError.prototype.name = 'DimensionError'; +DimensionError.prototype.isDimensionError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/IndexError.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/IndexError.js new file mode 100644 index 0000000..9755958 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/error/IndexError.js @@ -0,0 +1,35 @@ +/** + * Create a range error with the message: + * 'Index out of range (index < min)' + * 'Index out of range (index < max)' + * + * @param {number} index The actual index + * @param {number} [min=0] Minimum index (included) + * @param {number} [max] Maximum index (excluded) + * @extends RangeError + */ +export function IndexError(index, min, max) { + if (!(this instanceof IndexError)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.index = index; + if (arguments.length < 3) { + this.min = 0; + this.max = min; + } else { + this.min = min; + this.max = max; + } + if (this.min !== undefined && this.index < this.min) { + this.message = 'Index out of range (' + this.index + ' < ' + this.min + ')'; + } else if (this.max !== undefined && this.index >= this.max) { + this.message = 'Index out of range (' + this.index + ' > ' + (this.max - 1) + ')'; + } else { + this.message = 'Index out of range (' + this.index + ')'; + } + this.stack = new Error().stack; +} +IndexError.prototype = new RangeError(); +IndexError.prototype.constructor = RangeError; +IndexError.prototype.name = 'IndexError'; +IndexError.prototype.isIndexError = true; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Help.js new file mode 100644 index 0000000..5f18914 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Help.js @@ -0,0 +1,132 @@ +import { isHelp } from '../utils/is.js'; +import { clone } from '../utils/object.js'; +import { format } from '../utils/string.js'; +import { factory } from '../utils/factory.js'; +var name = 'Help'; +var dependencies = ['evaluate']; +export var createHelpClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + evaluate + } = _ref; + /** + * Documentation object + * @param {Object} doc Object containing properties: + * {string} name + * {string} category + * {string} description + * {string[]} syntax + * {string[]} examples + * {string[]} seealso + * @constructor + */ + function Help(doc) { + if (!(this instanceof Help)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (!doc) throw new Error('Argument "doc" missing'); + this.doc = doc; + } + + /** + * Attach type information + */ + Help.prototype.type = 'Help'; + Help.prototype.isHelp = true; + + /** + * Generate a string representation of the Help object + * @return {string} Returns a string + * @private + */ + Help.prototype.toString = function () { + var doc = this.doc || {}; + var desc = '\n'; + if (doc.name) { + desc += 'Name: ' + doc.name + '\n\n'; + } + if (doc.category) { + desc += 'Category: ' + doc.category + '\n\n'; + } + if (doc.description) { + desc += 'Description:\n ' + doc.description + '\n\n'; + } + if (doc.syntax) { + desc += 'Syntax:\n ' + doc.syntax.join('\n ') + '\n\n'; + } + if (doc.examples) { + desc += 'Examples:\n'; + + // after evaluating the examples, we restore config in case the examples + // did change the config. + var configChanged = false; + var originalConfig = evaluate('config()'); + var scope = { + config: newConfig => { + configChanged = true; + return evaluate('config(newConfig)', { + newConfig + }); + } + }; + for (var i = 0; i < doc.examples.length; i++) { + var expr = doc.examples[i]; + desc += ' ' + expr + '\n'; + var res = void 0; + try { + // note: res can be undefined when `expr` is an empty string + res = evaluate(expr, scope); + } catch (e) { + res = e; + } + if (res !== undefined && !isHelp(res)) { + desc += ' ' + format(res, { + precision: 14 + }) + '\n'; + } + } + desc += '\n'; + if (configChanged) { + evaluate('config(originalConfig)', { + originalConfig + }); + } + } + if (doc.mayThrow && doc.mayThrow.length) { + desc += 'Throws: ' + doc.mayThrow.join(', ') + '\n\n'; + } + if (doc.seealso && doc.seealso.length) { + desc += 'See also: ' + doc.seealso.join(', ') + '\n'; + } + return desc; + }; + + /** + * Export the help object to JSON + */ + Help.prototype.toJSON = function () { + var obj = clone(this.doc); + obj.mathjs = 'Help'; + return obj; + }; + + /** + * Instantiate a Help object from a JSON object + * @param {Object} json + * @returns {Help} Returns a new Help object + */ + Help.fromJSON = function (json) { + var doc = {}; + Object.keys(json).filter(prop => prop !== 'mathjs').forEach(prop => { + doc[prop] = json[prop]; + }); + return new Help(doc); + }; + + /** + * Returns a string representation of the Help object + */ + Help.prototype.valueOf = Help.prototype.toString; + return Help; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Parser.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Parser.js new file mode 100644 index 0000000..ac50bf7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/Parser.js @@ -0,0 +1,141 @@ +import { factory } from '../utils/factory.js'; +import { createEmptyMap, toObject } from '../utils/map.js'; +var name = 'Parser'; +var dependencies = ['evaluate']; +export var createParserClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + evaluate + } = _ref; + /** + * @constructor Parser + * Parser contains methods to evaluate or parse expressions, and has a number + * of convenience methods to get, set, and remove variables from memory. Parser + * keeps a scope containing variables in memory, which is used for all + * evaluations. + * + * Methods: + * const result = parser.evaluate(expr) // evaluate an expression + * const value = parser.get(name) // retrieve a variable from the parser + * const values = parser.getAll() // retrieve all defined variables + * parser.set(name, value) // set a variable in the parser + * parser.remove(name) // clear a variable from the + * // parsers scope + * parser.clear() // clear the parsers scope + * + * Example usage: + * const parser = new Parser() + * // Note: there is a convenience method which can be used instead: + * // const parser = new math.parser() + * + * // evaluate expressions + * parser.evaluate('sqrt(3^2 + 4^2)') // 5 + * parser.evaluate('sqrt(-4)') // 2i + * parser.evaluate('2 inch in cm') // 5.08 cm + * parser.evaluate('cos(45 deg)') // 0.7071067811865476 + * + * // define variables and functions + * parser.evaluate('x = 7 / 2') // 3.5 + * parser.evaluate('x + 3') // 6.5 + * parser.evaluate('f(x, y) = x^y') // f(x, y) + * parser.evaluate('f(2, 3)') // 8 + * + * // get and set variables and functions + * const x = parser.get('x') // 3.5 + * const f = parser.get('f') // function + * const g = f(3, 2) // 9 + * parser.set('h', 500) + * const i = parser.evaluate('h / 2') // 250 + * parser.set('hello', function (name) { + * return 'hello, ' + name + '!' + * }) + * parser.evaluate('hello("user")') // "hello, user!" + * + * // clear defined functions and variables + * parser.clear() + * + */ + function Parser() { + if (!(this instanceof Parser)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + Object.defineProperty(this, 'scope', { + value: createEmptyMap(), + writable: false + }); + } + + /** + * Attach type information + */ + Parser.prototype.type = 'Parser'; + Parser.prototype.isParser = true; + + /** + * Parse and evaluate the given expression + * @param {string | string[]} expr A string containing an expression, + * for example "2+3", or a list with expressions + * @return {*} result The result, or undefined when the expression was empty + * @throws {Error} + */ + Parser.prototype.evaluate = function (expr) { + // TODO: validate arguments + return evaluate(expr, this.scope); + }; + + /** + * Get a variable (a function or variable) by name from the parsers scope. + * Returns undefined when not found + * @param {string} name + * @return {* | undefined} value + */ + Parser.prototype.get = function (name) { + // TODO: validate arguments + if (this.scope.has(name)) { + return this.scope.get(name); + } + }; + + /** + * Get a map with all defined variables + * @return {Object} values + */ + Parser.prototype.getAll = function () { + return toObject(this.scope); + }; + + /** + * Get a map with all defined variables + * @return {Map} values + */ + Parser.prototype.getAllAsMap = function () { + return this.scope; + }; + + /** + * Set a symbol (a function or variable) by name from the parsers scope. + * @param {string} name + * @param {* | undefined} value + */ + Parser.prototype.set = function (name, value) { + this.scope.set(name, value); + return value; + }; + + /** + * Remove a variable from the parsers scope + * @param {string} name + */ + Parser.prototype.remove = function (name) { + this.scope.delete(name); + }; + + /** + * Clear the scope with variables and functions + */ + Parser.prototype.clear = function () { + this.scope.clear(); + }; + return Parser; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/Infinity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/Infinity.js new file mode 100644 index 0000000..665c06c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/Infinity.js @@ -0,0 +1,8 @@ +export var InfinityDocs = { + name: 'Infinity', + category: 'Constants', + syntax: ['Infinity'], + description: 'Infinity, a number which is larger than the maximum number that can be handled by a floating point number.', + examples: ['Infinity', '1 / 0'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN10.js new file mode 100644 index 0000000..14cee58 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN10.js @@ -0,0 +1,8 @@ +export var LN10Docs = { + name: 'LN10', + category: 'Constants', + syntax: ['LN10'], + description: 'Returns the natural logarithm of 10, approximately equal to 2.302', + examples: ['LN10', 'log(10)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN2.js new file mode 100644 index 0000000..4cdd420 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LN2.js @@ -0,0 +1,8 @@ +export var LN2Docs = { + name: 'LN2', + category: 'Constants', + syntax: ['LN2'], + description: 'Returns the natural logarithm of 2, approximately equal to 0.693', + examples: ['LN2', 'log(2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG10E.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG10E.js new file mode 100644 index 0000000..2bc29fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG10E.js @@ -0,0 +1,8 @@ +export var LOG10EDocs = { + name: 'LOG10E', + category: 'Constants', + syntax: ['LOG10E'], + description: 'Returns the base-10 logarithm of E, approximately equal to 0.434', + examples: ['LOG10E', 'log(e, 10)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG2E.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG2E.js new file mode 100644 index 0000000..91352dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/LOG2E.js @@ -0,0 +1,8 @@ +export var LOG2EDocs = { + name: 'LOG2E', + category: 'Constants', + syntax: ['LOG2E'], + description: 'Returns the base-2 logarithm of E, approximately equal to 1.442', + examples: ['LOG2E', 'log(e, 2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/NaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/NaN.js new file mode 100644 index 0000000..f44bd42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/NaN.js @@ -0,0 +1,8 @@ +export var NaNDocs = { + name: 'NaN', + category: 'Constants', + syntax: ['NaN'], + description: 'Not a number', + examples: ['NaN', '0 / 0'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT1_2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT1_2.js new file mode 100644 index 0000000..c08a377 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT1_2.js @@ -0,0 +1,8 @@ +export var SQRT12Docs = { + name: 'SQRT1_2', + category: 'Constants', + syntax: ['SQRT1_2'], + description: 'Returns the square root of 1/2, approximately equal to 0.707', + examples: ['SQRT1_2', 'sqrt(1/2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT2.js new file mode 100644 index 0000000..638c4b2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/SQRT2.js @@ -0,0 +1,8 @@ +export var SQRT2Docs = { + name: 'SQRT2', + category: 'Constants', + syntax: ['SQRT2'], + description: 'Returns the square root of 2, approximately equal to 1.414', + examples: ['SQRT2', 'sqrt(2)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/e.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/e.js new file mode 100644 index 0000000..e82480a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/e.js @@ -0,0 +1,8 @@ +export var eDocs = { + name: 'e', + category: 'Constants', + syntax: ['e'], + description: 'Euler\'s number, the base of the natural logarithm. Approximately equal to 2.71828', + examples: ['e', 'e ^ 2', 'exp(2)', 'log(e)'], + seealso: ['exp'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/false.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/false.js new file mode 100644 index 0000000..78c1791 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/false.js @@ -0,0 +1,8 @@ +export var falseDocs = { + name: 'false', + category: 'Constants', + syntax: ['false'], + description: 'Boolean value false', + examples: ['false'], + seealso: ['true'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/i.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/i.js new file mode 100644 index 0000000..69d62ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/i.js @@ -0,0 +1,8 @@ +export var iDocs = { + name: 'i', + category: 'Constants', + syntax: ['i'], + description: 'Imaginary unit, defined as i*i=-1. A complex number is described as a + b*i, where a is the real part, and b is the imaginary part.', + examples: ['i', 'i * i', 'sqrt(-1)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/null.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/null.js new file mode 100644 index 0000000..1d6a721 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/null.js @@ -0,0 +1,8 @@ +export var nullDocs = { + name: 'null', + category: 'Constants', + syntax: ['null'], + description: 'Value null', + examples: ['null'], + seealso: ['true', 'false'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/phi.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/phi.js new file mode 100644 index 0000000..bb48c9a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/phi.js @@ -0,0 +1,8 @@ +export var phiDocs = { + name: 'phi', + category: 'Constants', + syntax: ['phi'], + description: 'Phi is the golden ratio. Two quantities are in the golden ratio if their ratio is the same as the ratio of their sum to the larger of the two quantities. Phi is defined as `(1 + sqrt(5)) / 2` and is approximately 1.618034...', + examples: ['phi'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/pi.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/pi.js new file mode 100644 index 0000000..c34ae2e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/pi.js @@ -0,0 +1,8 @@ +export var piDocs = { + name: 'pi', + category: 'Constants', + syntax: ['pi'], + description: 'The number pi is a mathematical constant that is the ratio of a circle\'s circumference to its diameter, and is approximately equal to 3.14159', + examples: ['pi', 'sin(pi/2)'], + seealso: ['tau'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/tau.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/tau.js new file mode 100644 index 0000000..0256449 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/tau.js @@ -0,0 +1,8 @@ +export var tauDocs = { + name: 'tau', + category: 'Constants', + syntax: ['tau'], + description: 'Tau is the ratio constant of a circle\'s circumference to radius, equal to 2 * pi, approximately 6.2832.', + examples: ['tau', '2 * pi'], + seealso: ['pi'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/true.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/true.js new file mode 100644 index 0000000..52c8f1f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/true.js @@ -0,0 +1,8 @@ +export var trueDocs = { + name: 'true', + category: 'Constants', + syntax: ['true'], + description: 'Boolean value true', + examples: ['true'], + seealso: ['false'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/version.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/version.js new file mode 100644 index 0000000..c58c20a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/constants/version.js @@ -0,0 +1,8 @@ +export var versionDocs = { + name: 'version', + category: 'Constants', + syntax: ['version'], + description: 'A string with the version number of math.js', + examples: ['version'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bigint.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bigint.js new file mode 100644 index 0000000..8d965b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bigint.js @@ -0,0 +1,8 @@ +export var bigintDocs = { + name: 'bigint', + category: 'Construction', + syntax: ['bigint(x)'], + description: 'Create a bigint, an integer with an arbitrary number of digits, from a number or string.', + examples: ['123123123123123123 # a large number will lose digits', 'bigint("123123123123123123")', 'bignumber(["1", "3", "5"])'], + seealso: ['boolean', 'bignumber', 'number', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bignumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bignumber.js new file mode 100644 index 0000000..e2e58e8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/bignumber.js @@ -0,0 +1,8 @@ +export var bignumberDocs = { + name: 'bignumber', + category: 'Construction', + syntax: ['bignumber(x)'], + description: 'Create a big number from a number or string.', + examples: ['0.1 + 0.2', 'bignumber(0.1) + bignumber(0.2)', 'bignumber("7.2")', 'bignumber("7.2e500")', 'bignumber([0.1, 0.2, 0.3])'], + seealso: ['boolean', 'bigint', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/boolean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/boolean.js new file mode 100644 index 0000000..38f2053 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/boolean.js @@ -0,0 +1,8 @@ +export var booleanDocs = { + name: 'boolean', + category: 'Construction', + syntax: ['x', 'boolean(x)'], + description: 'Convert a string or number into a boolean.', + examples: ['boolean(0)', 'boolean(1)', 'boolean(3)', 'boolean("true")', 'boolean("false")', 'boolean([1, 0, 1, 1])'], + seealso: ['bignumber', 'complex', 'index', 'matrix', 'number', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/complex.js new file mode 100644 index 0000000..abbc0f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/complex.js @@ -0,0 +1,8 @@ +export var complexDocs = { + name: 'complex', + category: 'Construction', + syntax: ['complex()', 'complex(re, im)', 'complex(string)'], + description: 'Create a complex number.', + examples: ['complex()', 'complex(2, 3)', 'complex("7 - 2i")'], + seealso: ['bignumber', 'boolean', 'index', 'matrix', 'number', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/createUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/createUnit.js new file mode 100644 index 0000000..444836d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/createUnit.js @@ -0,0 +1,8 @@ +export var createUnitDocs = { + name: 'createUnit', + category: 'Construction', + syntax: ['createUnit(definitions)', 'createUnit(name, definition)'], + description: 'Create a user-defined unit and register it with the Unit type.', + examples: ['createUnit("foo")', 'createUnit("knot", {definition: "0.514444444 m/s", aliases: ["knots", "kt", "kts"]})', 'createUnit("mph", "1 mile/hour")'], + seealso: ['unit', 'splitUnit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/fraction.js new file mode 100644 index 0000000..922eb1a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/fraction.js @@ -0,0 +1,8 @@ +export var fractionDocs = { + name: 'fraction', + category: 'Construction', + syntax: ['fraction(num)', 'fraction(matrix)', 'fraction(num,den)', 'fraction({n: num, d: den})'], + description: 'Create a fraction from a number or from integer numerator and denominator.', + examples: ['fraction(0.125)', 'fraction(1, 3) + fraction(2, 5)', 'fraction({n: 333, d: 53})', 'fraction([sqrt(9), sqrt(10), sqrt(11)])'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/index.js new file mode 100644 index 0000000..d5ab029 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/index.js @@ -0,0 +1,8 @@ +export var indexDocs = { + name: 'index', + category: 'Construction', + syntax: ['[start]', '[start:end]', '[start:step:end]', '[start1, start 2, ...]', '[start1:end1, start2:end2, ...]', '[start1:step1:end1, start2:step2:end2, ...]'], + description: 'Create an index to get or replace a subset of a matrix', + examples: ['A = [1, 2, 3; 4, 5, 6]', 'A[1, :]', 'A[1, 2] = 50', 'A[1:2, 1:2] = 1', 'B = [1, 2, 3]', 'B[B>1 and B<3]'], + seealso: ['bignumber', 'boolean', 'complex', 'matrix,', 'number', 'range', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/matrix.js new file mode 100644 index 0000000..bb51892 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/matrix.js @@ -0,0 +1,8 @@ +export var matrixDocs = { + name: 'matrix', + category: 'Construction', + syntax: ['[]', '[a1, b1, ...; a2, b2, ...]', 'matrix()', 'matrix("dense")', 'matrix([...])'], + description: 'Create a matrix.', + examples: ['[]', '[1, 2, 3]', '[1, 2, 3; 4, 5, 6]', 'matrix()', 'matrix([3, 4])', 'matrix([3, 4; 5, 6], "sparse")', 'matrix([3, 4; 5, 6], "sparse", "number")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/number.js new file mode 100644 index 0000000..4219ce5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/number.js @@ -0,0 +1,8 @@ +export var numberDocs = { + name: 'number', + category: 'Construction', + syntax: ['x', 'number(x)', 'number(unit, valuelessUnit)'], + description: 'Create a number or convert a string or boolean into a number.', + examples: ['2', '2e3', '4.05', 'number(2)', 'number("7.2")', 'number(true)', 'number([true, false, true, true])', 'number(unit("52cm"), "m")'], + seealso: ['bignumber', 'bigint', 'boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/sparse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/sparse.js new file mode 100644 index 0000000..b6a776c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/sparse.js @@ -0,0 +1,8 @@ +export var sparseDocs = { + name: 'sparse', + category: 'Construction', + syntax: ['sparse()', 'sparse([a1, b1, ...; a1, b2, ...])', 'sparse([a1, b1, ...; a1, b2, ...], "number")'], + description: 'Create a sparse matrix.', + examples: ['sparse()', 'sparse([3, 4; 5, 6])', 'sparse([3, 0; 5, 0], "number")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'matrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/splitUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/splitUnit.js new file mode 100644 index 0000000..2b1354b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/splitUnit.js @@ -0,0 +1,8 @@ +export var splitUnitDocs = { + name: 'splitUnit', + category: 'Construction', + syntax: ['splitUnit(unit: Unit, parts: Unit[])'], + description: 'Split a unit in an array of units whose sum is equal to the original unit.', + examples: ['splitUnit(1 m, ["feet", "inch"])'], + seealso: ['unit', 'createUnit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/string.js new file mode 100644 index 0000000..deb8406 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/string.js @@ -0,0 +1,8 @@ +export var stringDocs = { + name: 'string', + category: 'Construction', + syntax: ['"text"', 'string(x)'], + description: 'Create a string or convert a value to a string', + examples: ['"Hello World!"', 'string(4.2)', 'string(3 + 2i)'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'unit'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/unit.js new file mode 100644 index 0000000..197f655 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/construction/unit.js @@ -0,0 +1,8 @@ +export var unitDocs = { + name: 'unit', + category: 'Construction', + syntax: ['value unit', 'unit(value, unit)', 'unit(string)'], + description: 'Create a unit.', + examples: ['5.5 mm', '3 inch', 'unit(7.1, "kilogram")', 'unit("23 deg")'], + seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'string'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/config.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/config.js new file mode 100644 index 0000000..3864bfd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/config.js @@ -0,0 +1,8 @@ +export var configDocs = { + name: 'config', + category: 'Core', + syntax: ['config()', 'config(options)'], + description: 'Get configuration or change configuration.', + examples: ['config()', '1/3 + 1/4', 'config({number: "Fraction"})', '1/3 + 1/4'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/import.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/import.js new file mode 100644 index 0000000..35df7c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/import.js @@ -0,0 +1,8 @@ +export var importDocs = { + name: 'import', + category: 'Core', + syntax: ['import(functions)', 'import(functions, options)'], + description: 'Import functions or constants from an object.', + examples: ['import({myFn: f(x)=x^2, myConstant: 32 })', 'myFn(2)', 'myConstant'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/typed.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/typed.js new file mode 100644 index 0000000..1e73879 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/core/typed.js @@ -0,0 +1,8 @@ +export var typedDocs = { + name: 'typed', + category: 'Core', + syntax: ['typed(signatures)', 'typed(name, signatures)'], + description: 'Create a typed function.', + examples: ['double = typed({ "number": f(x)=x+x, "string": f(x)=concat(x,x) })', 'double(2)', 'double("hello")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/embeddedDocs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/embeddedDocs.js new file mode 100644 index 0000000..aae57ac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/embeddedDocs.js @@ -0,0 +1,720 @@ +import { eDocs } from './constants/e.js'; +import { falseDocs } from './constants/false.js'; +import { iDocs } from './constants/i.js'; +import { InfinityDocs } from './constants/Infinity.js'; +import { LN10Docs } from './constants/LN10.js'; +import { LN2Docs } from './constants/LN2.js'; +import { LOG10EDocs } from './constants/LOG10E.js'; +import { LOG2EDocs } from './constants/LOG2E.js'; +import { NaNDocs } from './constants/NaN.js'; +import { nullDocs } from './constants/null.js'; +import { phiDocs } from './constants/phi.js'; +import { piDocs } from './constants/pi.js'; +import { SQRT12Docs } from './constants/SQRT1_2.js'; +import { SQRT2Docs } from './constants/SQRT2.js'; +import { tauDocs } from './constants/tau.js'; +import { trueDocs } from './constants/true.js'; +import { versionDocs } from './constants/version.js'; +import { bignumberDocs } from './construction/bignumber.js'; +import { bigintDocs } from './construction/bigint.js'; +import { booleanDocs } from './construction/boolean.js'; +import { complexDocs } from './construction/complex.js'; +import { createUnitDocs } from './construction/createUnit.js'; +import { fractionDocs } from './construction/fraction.js'; +import { indexDocs } from './construction/index.js'; +import { matrixDocs } from './construction/matrix.js'; +import { numberDocs } from './construction/number.js'; +import { sparseDocs } from './construction/sparse.js'; +import { splitUnitDocs } from './construction/splitUnit.js'; +import { stringDocs } from './construction/string.js'; +import { unitDocs } from './construction/unit.js'; +import { configDocs } from './core/config.js'; +import { importDocs } from './core/import.js'; +import { typedDocs } from './core/typed.js'; +import { derivativeDocs } from './function/algebra/derivative.js'; +import { leafCountDocs } from './function/algebra/leafCount.js'; +import { lsolveDocs } from './function/algebra/lsolve.js'; +import { lsolveAllDocs } from './function/algebra/lsolveAll.js'; +import { lupDocs } from './function/algebra/lup.js'; +import { lusolveDocs } from './function/algebra/lusolve.js'; +import { polynomialRootDocs } from './function/algebra/polynomialRoot.js'; +import { qrDocs } from './function/algebra/qr.js'; +import { rationalizeDocs } from './function/algebra/rationalize.js'; +import { resolveDocs } from './function/algebra/resolve.js'; +import { simplifyDocs } from './function/algebra/simplify.js'; +import { simplifyConstantDocs } from './function/algebra/simplifyConstant.js'; +import { simplifyCoreDocs } from './function/algebra/simplifyCore.js'; +import { sluDocs } from './function/algebra/slu.js'; +import { symbolicEqualDocs } from './function/algebra/symbolicEqual.js'; +import { usolveDocs } from './function/algebra/usolve.js'; +import { usolveAllDocs } from './function/algebra/usolveAll.js'; +import { absDocs } from './function/arithmetic/abs.js'; +import { addDocs } from './function/arithmetic/add.js'; +import { cbrtDocs } from './function/arithmetic/cbrt.js'; +import { ceilDocs } from './function/arithmetic/ceil.js'; +import { cubeDocs } from './function/arithmetic/cube.js'; +import { divideDocs } from './function/arithmetic/divide.js'; +import { dotDivideDocs } from './function/arithmetic/dotDivide.js'; +import { dotMultiplyDocs } from './function/arithmetic/dotMultiply.js'; +import { dotPowDocs } from './function/arithmetic/dotPow.js'; +import { expDocs } from './function/arithmetic/exp.js'; +import { expmDocs } from './function/arithmetic/expm.js'; +import { expm1Docs } from './function/arithmetic/expm1.js'; +import { fixDocs } from './function/arithmetic/fix.js'; +import { floorDocs } from './function/arithmetic/floor.js'; +import { gcdDocs } from './function/arithmetic/gcd.js'; +import { hypotDocs } from './function/arithmetic/hypot.js'; +import { invmodDocs } from './function/arithmetic/invmod.js'; +import { lcmDocs } from './function/arithmetic/lcm.js'; +import { logDocs } from './function/arithmetic/log.js'; +import { log10Docs } from './function/arithmetic/log10.js'; +import { log1pDocs } from './function/arithmetic/log1p.js'; +import { log2Docs } from './function/arithmetic/log2.js'; +import { modDocs } from './function/arithmetic/mod.js'; +import { multiplyDocs } from './function/arithmetic/multiply.js'; +import { normDocs } from './function/arithmetic/norm.js'; +import { nthRootDocs } from './function/arithmetic/nthRoot.js'; +import { nthRootsDocs } from './function/arithmetic/nthRoots.js'; +import { powDocs } from './function/arithmetic/pow.js'; +import { roundDocs } from './function/arithmetic/round.js'; +import { signDocs } from './function/arithmetic/sign.js'; +import { sqrtDocs } from './function/arithmetic/sqrt.js'; +import { sqrtmDocs } from './function/arithmetic/sqrtm.js'; +import { sylvesterDocs } from './function/algebra/sylvester.js'; +import { schurDocs } from './function/algebra/schur.js'; +import { lyapDocs } from './function/algebra/lyap.js'; +import { squareDocs } from './function/arithmetic/square.js'; +import { subtractDocs } from './function/arithmetic/subtract.js'; +import { unaryMinusDocs } from './function/arithmetic/unaryMinus.js'; +import { unaryPlusDocs } from './function/arithmetic/unaryPlus.js'; +import { xgcdDocs } from './function/arithmetic/xgcd.js'; +import { bitAndDocs } from './function/bitwise/bitAnd.js'; +import { bitNotDocs } from './function/bitwise/bitNot.js'; +import { bitOrDocs } from './function/bitwise/bitOr.js'; +import { bitXorDocs } from './function/bitwise/bitXor.js'; +import { leftShiftDocs } from './function/bitwise/leftShift.js'; +import { rightArithShiftDocs } from './function/bitwise/rightArithShift.js'; +import { rightLogShiftDocs } from './function/bitwise/rightLogShift.js'; +import { bellNumbersDocs } from './function/combinatorics/bellNumbers.js'; +import { catalanDocs } from './function/combinatorics/catalan.js'; +import { compositionDocs } from './function/combinatorics/composition.js'; +import { stirlingS2Docs } from './function/combinatorics/stirlingS2.js'; +import { argDocs } from './function/complex/arg.js'; +import { conjDocs } from './function/complex/conj.js'; +import { imDocs } from './function/complex/im.js'; +import { reDocs } from './function/complex/re.js'; +import { evaluateDocs } from './function/expression/evaluate.js'; +import { helpDocs } from './function/expression/help.js'; +import { distanceDocs } from './function/geometry/distance.js'; +import { intersectDocs } from './function/geometry/intersect.js'; +import { andDocs } from './function/logical/and.js'; +import { notDocs } from './function/logical/not.js'; +import { orDocs } from './function/logical/or.js'; +import { xorDocs } from './function/logical/xor.js'; +import { columnDocs } from './function/matrix/column.js'; +import { concatDocs } from './function/matrix/concat.js'; +import { countDocs } from './function/matrix/count.js'; +import { crossDocs } from './function/matrix/cross.js'; +import { ctransposeDocs } from './function/matrix/ctranspose.js'; +import { detDocs } from './function/matrix/det.js'; +import { diagDocs } from './function/matrix/diag.js'; +import { diffDocs } from './function/matrix/diff.js'; +import { dotDocs } from './function/matrix/dot.js'; +import { eigsDocs } from './function/matrix/eigs.js'; +import { filterDocs } from './function/matrix/filter.js'; +import { flattenDocs } from './function/matrix/flatten.js'; +import { forEachDocs } from './function/matrix/forEach.js'; +import { getMatrixDataTypeDocs } from './function/matrix/getMatrixDataType.js'; +import { identityDocs } from './function/matrix/identity.js'; +import { invDocs } from './function/matrix/inv.js'; +import { pinvDocs } from './function/matrix/pinv.js'; +import { kronDocs } from './function/matrix/kron.js'; +import { mapDocs } from './function/matrix/map.js'; +import { matrixFromColumnsDocs } from './function/matrix/matrixFromColumns.js'; +import { matrixFromFunctionDocs } from './function/matrix/matrixFromFunction.js'; +import { matrixFromRowsDocs } from './function/matrix/matrixFromRows.js'; +import { onesDocs } from './function/matrix/ones.js'; +import { partitionSelectDocs } from './function/matrix/partitionSelect.js'; +import { rangeDocs } from './function/matrix/range.js'; +import { reshapeDocs } from './function/matrix/reshape.js'; +import { resizeDocs } from './function/matrix/resize.js'; +import { rotateDocs } from './function/matrix/rotate.js'; +import { rotationMatrixDocs } from './function/matrix/rotationMatrix.js'; +import { rowDocs } from './function/matrix/row.js'; +import { sizeDocs } from './function/matrix/size.js'; +import { sortDocs } from './function/matrix/sort.js'; +import { squeezeDocs } from './function/matrix/squeeze.js'; +import { subsetDocs } from './function/matrix/subset.js'; +import { traceDocs } from './function/matrix/trace.js'; +import { transposeDocs } from './function/matrix/transpose.js'; +import { zerosDocs } from './function/matrix/zeros.js'; +import { fftDocs } from './function/matrix/fft.js'; +import { ifftDocs } from './function/matrix/ifft.js'; +import { combinationsDocs } from './function/probability/combinations.js'; +import { combinationsWithRepDocs } from './function/probability/combinationsWithRep.js'; +import { factorialDocs } from './function/probability/factorial.js'; +import { gammaDocs } from './function/probability/gamma.js'; +import { lgammaDocs } from './function/probability/lgamma.js'; +import { kldivergenceDocs } from './function/probability/kldivergence.js'; +import { multinomialDocs } from './function/probability/multinomial.js'; +import { permutationsDocs } from './function/probability/permutations.js'; +import { pickRandomDocs } from './function/probability/pickRandom.js'; +import { randomDocs } from './function/probability/random.js'; +import { randomIntDocs } from './function/probability/randomInt.js'; +import { compareDocs } from './function/relational/compare.js'; +import { compareNaturalDocs } from './function/relational/compareNatural.js'; +import { compareTextDocs } from './function/relational/compareText.js'; +import { deepEqualDocs } from './function/relational/deepEqual.js'; +import { equalDocs } from './function/relational/equal.js'; +import { equalTextDocs } from './function/relational/equalText.js'; +import { largerDocs } from './function/relational/larger.js'; +import { largerEqDocs } from './function/relational/largerEq.js'; +import { smallerDocs } from './function/relational/smaller.js'; +import { smallerEqDocs } from './function/relational/smallerEq.js'; +import { unequalDocs } from './function/relational/unequal.js'; +import { setCartesianDocs } from './function/set/setCartesian.js'; +import { setDifferenceDocs } from './function/set/setDifference.js'; +import { setDistinctDocs } from './function/set/setDistinct.js'; +import { setIntersectDocs } from './function/set/setIntersect.js'; +import { setIsSubsetDocs } from './function/set/setIsSubset.js'; +import { setMultiplicityDocs } from './function/set/setMultiplicity.js'; +import { setPowersetDocs } from './function/set/setPowerset.js'; +import { setSizeDocs } from './function/set/setSize.js'; +import { setSymDifferenceDocs } from './function/set/setSymDifference.js'; +import { setUnionDocs } from './function/set/setUnion.js'; +import { zpk2tfDocs } from './function/signal/zpk2tf.js'; +import { freqzDocs } from './function/signal/freqz.js'; +import { erfDocs } from './function/special/erf.js'; +import { zetaDocs } from './function/special/zeta.js'; +import { madDocs } from './function/statistics/mad.js'; +import { maxDocs } from './function/statistics/max.js'; +import { meanDocs } from './function/statistics/mean.js'; +import { medianDocs } from './function/statistics/median.js'; +import { minDocs } from './function/statistics/min.js'; +import { modeDocs } from './function/statistics/mode.js'; +import { prodDocs } from './function/statistics/prod.js'; +import { quantileSeqDocs } from './function/statistics/quantileSeq.js'; +import { stdDocs } from './function/statistics/std.js'; +import { cumSumDocs } from './function/statistics/cumsum.js'; +import { sumDocs } from './function/statistics/sum.js'; +import { varianceDocs } from './function/statistics/variance.js'; +import { corrDocs } from './function/statistics/corr.js'; +import { acosDocs } from './function/trigonometry/acos.js'; +import { acoshDocs } from './function/trigonometry/acosh.js'; +import { acotDocs } from './function/trigonometry/acot.js'; +import { acothDocs } from './function/trigonometry/acoth.js'; +import { acscDocs } from './function/trigonometry/acsc.js'; +import { acschDocs } from './function/trigonometry/acsch.js'; +import { asecDocs } from './function/trigonometry/asec.js'; +import { asechDocs } from './function/trigonometry/asech.js'; +import { asinDocs } from './function/trigonometry/asin.js'; +import { asinhDocs } from './function/trigonometry/asinh.js'; +import { atanDocs } from './function/trigonometry/atan.js'; +import { atan2Docs } from './function/trigonometry/atan2.js'; +import { atanhDocs } from './function/trigonometry/atanh.js'; +import { cosDocs } from './function/trigonometry/cos.js'; +import { coshDocs } from './function/trigonometry/cosh.js'; +import { cotDocs } from './function/trigonometry/cot.js'; +import { cothDocs } from './function/trigonometry/coth.js'; +import { cscDocs } from './function/trigonometry/csc.js'; +import { cschDocs } from './function/trigonometry/csch.js'; +import { secDocs } from './function/trigonometry/sec.js'; +import { sechDocs } from './function/trigonometry/sech.js'; +import { sinDocs } from './function/trigonometry/sin.js'; +import { sinhDocs } from './function/trigonometry/sinh.js'; +import { tanDocs } from './function/trigonometry/tan.js'; +import { tanhDocs } from './function/trigonometry/tanh.js'; +import { toDocs } from './function/units/to.js'; +import { binDocs } from './function/utils/bin.js'; +import { cloneDocs } from './function/utils/clone.js'; +import { formatDocs } from './function/utils/format.js'; +import { hasNumericValueDocs } from './function/utils/hasNumericValue.js'; +import { hexDocs } from './function/utils/hex.js'; +import { isIntegerDocs } from './function/utils/isInteger.js'; +import { isNaNDocs } from './function/utils/isNaN.js'; +import { isNegativeDocs } from './function/utils/isNegative.js'; +import { isNumericDocs } from './function/utils/isNumeric.js'; +import { isPositiveDocs } from './function/utils/isPositive.js'; +import { isPrimeDocs } from './function/utils/isPrime.js'; +import { isZeroDocs } from './function/utils/isZero.js'; +import { numericDocs } from './function/utils/numeric.js'; +import { octDocs } from './function/utils/oct.js'; +import { printDocs } from './function/utils/print.js'; +import { typeOfDocs } from './function/utils/typeOf.js'; +import { solveODEDocs } from './function/numeric/solveODE.js'; +export var embeddedDocs = { + // construction functions + bignumber: bignumberDocs, + bigint: bigintDocs, + boolean: booleanDocs, + complex: complexDocs, + createUnit: createUnitDocs, + fraction: fractionDocs, + index: indexDocs, + matrix: matrixDocs, + number: numberDocs, + sparse: sparseDocs, + splitUnit: splitUnitDocs, + string: stringDocs, + unit: unitDocs, + // constants + e: eDocs, + E: eDocs, + false: falseDocs, + i: iDocs, + Infinity: InfinityDocs, + LN2: LN2Docs, + LN10: LN10Docs, + LOG2E: LOG2EDocs, + LOG10E: LOG10EDocs, + NaN: NaNDocs, + null: nullDocs, + pi: piDocs, + PI: piDocs, + phi: phiDocs, + SQRT1_2: SQRT12Docs, + SQRT2: SQRT2Docs, + tau: tauDocs, + true: trueDocs, + version: versionDocs, + // physical constants + // TODO: more detailed docs for physical constants + speedOfLight: { + description: 'Speed of light in vacuum', + examples: ['speedOfLight'] + }, + gravitationConstant: { + description: 'Newtonian constant of gravitation', + examples: ['gravitationConstant'] + }, + planckConstant: { + description: 'Planck constant', + examples: ['planckConstant'] + }, + reducedPlanckConstant: { + description: 'Reduced Planck constant', + examples: ['reducedPlanckConstant'] + }, + magneticConstant: { + description: 'Magnetic constant (vacuum permeability)', + examples: ['magneticConstant'] + }, + electricConstant: { + description: 'Electric constant (vacuum permeability)', + examples: ['electricConstant'] + }, + vacuumImpedance: { + description: 'Characteristic impedance of vacuum', + examples: ['vacuumImpedance'] + }, + coulomb: { + description: 'Coulomb\'s constant', + examples: ['coulomb'] + }, + elementaryCharge: { + description: 'Elementary charge', + examples: ['elementaryCharge'] + }, + bohrMagneton: { + description: 'Bohr magneton', + examples: ['bohrMagneton'] + }, + conductanceQuantum: { + description: 'Conductance quantum', + examples: ['conductanceQuantum'] + }, + inverseConductanceQuantum: { + description: 'Inverse conductance quantum', + examples: ['inverseConductanceQuantum'] + }, + // josephson: {description: 'Josephson constant', examples: ['josephson']}, + magneticFluxQuantum: { + description: 'Magnetic flux quantum', + examples: ['magneticFluxQuantum'] + }, + nuclearMagneton: { + description: 'Nuclear magneton', + examples: ['nuclearMagneton'] + }, + klitzing: { + description: 'Von Klitzing constant', + examples: ['klitzing'] + }, + bohrRadius: { + description: 'Bohr radius', + examples: ['bohrRadius'] + }, + classicalElectronRadius: { + description: 'Classical electron radius', + examples: ['classicalElectronRadius'] + }, + electronMass: { + description: 'Electron mass', + examples: ['electronMass'] + }, + fermiCoupling: { + description: 'Fermi coupling constant', + examples: ['fermiCoupling'] + }, + fineStructure: { + description: 'Fine-structure constant', + examples: ['fineStructure'] + }, + hartreeEnergy: { + description: 'Hartree energy', + examples: ['hartreeEnergy'] + }, + protonMass: { + description: 'Proton mass', + examples: ['protonMass'] + }, + deuteronMass: { + description: 'Deuteron Mass', + examples: ['deuteronMass'] + }, + neutronMass: { + description: 'Neutron mass', + examples: ['neutronMass'] + }, + quantumOfCirculation: { + description: 'Quantum of circulation', + examples: ['quantumOfCirculation'] + }, + rydberg: { + description: 'Rydberg constant', + examples: ['rydberg'] + }, + thomsonCrossSection: { + description: 'Thomson cross section', + examples: ['thomsonCrossSection'] + }, + weakMixingAngle: { + description: 'Weak mixing angle', + examples: ['weakMixingAngle'] + }, + efimovFactor: { + description: 'Efimov factor', + examples: ['efimovFactor'] + }, + atomicMass: { + description: 'Atomic mass constant', + examples: ['atomicMass'] + }, + avogadro: { + description: 'Avogadro\'s number', + examples: ['avogadro'] + }, + boltzmann: { + description: 'Boltzmann constant', + examples: ['boltzmann'] + }, + faraday: { + description: 'Faraday constant', + examples: ['faraday'] + }, + firstRadiation: { + description: 'First radiation constant', + examples: ['firstRadiation'] + }, + loschmidt: { + description: 'Loschmidt constant at T=273.15 K and p=101.325 kPa', + examples: ['loschmidt'] + }, + gasConstant: { + description: 'Gas constant', + examples: ['gasConstant'] + }, + molarPlanckConstant: { + description: 'Molar Planck constant', + examples: ['molarPlanckConstant'] + }, + molarVolume: { + description: 'Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa', + examples: ['molarVolume'] + }, + sackurTetrode: { + description: 'Sackur-Tetrode constant at T=1 K and p=101.325 kPa', + examples: ['sackurTetrode'] + }, + secondRadiation: { + description: 'Second radiation constant', + examples: ['secondRadiation'] + }, + stefanBoltzmann: { + description: 'Stefan-Boltzmann constant', + examples: ['stefanBoltzmann'] + }, + wienDisplacement: { + description: 'Wien displacement law constant', + examples: ['wienDisplacement'] + }, + // spectralRadiance: {description: 'First radiation constant for spectral radiance', examples: ['spectralRadiance']}, + + molarMass: { + description: 'Molar mass constant', + examples: ['molarMass'] + }, + molarMassC12: { + description: 'Molar mass constant of carbon-12', + examples: ['molarMassC12'] + }, + gravity: { + description: 'Standard acceleration of gravity (standard acceleration of free-fall on Earth)', + examples: ['gravity'] + }, + planckLength: { + description: 'Planck length', + examples: ['planckLength'] + }, + planckMass: { + description: 'Planck mass', + examples: ['planckMass'] + }, + planckTime: { + description: 'Planck time', + examples: ['planckTime'] + }, + planckCharge: { + description: 'Planck charge', + examples: ['planckCharge'] + }, + planckTemperature: { + description: 'Planck temperature', + examples: ['planckTemperature'] + }, + // functions - algebra + derivative: derivativeDocs, + lsolve: lsolveDocs, + lsolveAll: lsolveAllDocs, + lup: lupDocs, + lusolve: lusolveDocs, + leafCount: leafCountDocs, + polynomialRoot: polynomialRootDocs, + resolve: resolveDocs, + simplify: simplifyDocs, + simplifyConstant: simplifyConstantDocs, + simplifyCore: simplifyCoreDocs, + symbolicEqual: symbolicEqualDocs, + rationalize: rationalizeDocs, + slu: sluDocs, + usolve: usolveDocs, + usolveAll: usolveAllDocs, + qr: qrDocs, + // functions - arithmetic + abs: absDocs, + add: addDocs, + cbrt: cbrtDocs, + ceil: ceilDocs, + cube: cubeDocs, + divide: divideDocs, + dotDivide: dotDivideDocs, + dotMultiply: dotMultiplyDocs, + dotPow: dotPowDocs, + exp: expDocs, + expm: expmDocs, + expm1: expm1Docs, + fix: fixDocs, + floor: floorDocs, + gcd: gcdDocs, + hypot: hypotDocs, + lcm: lcmDocs, + log: logDocs, + log2: log2Docs, + log1p: log1pDocs, + log10: log10Docs, + mod: modDocs, + multiply: multiplyDocs, + norm: normDocs, + nthRoot: nthRootDocs, + nthRoots: nthRootsDocs, + pow: powDocs, + round: roundDocs, + sign: signDocs, + sqrt: sqrtDocs, + sqrtm: sqrtmDocs, + square: squareDocs, + subtract: subtractDocs, + unaryMinus: unaryMinusDocs, + unaryPlus: unaryPlusDocs, + xgcd: xgcdDocs, + invmod: invmodDocs, + // functions - bitwise + bitAnd: bitAndDocs, + bitNot: bitNotDocs, + bitOr: bitOrDocs, + bitXor: bitXorDocs, + leftShift: leftShiftDocs, + rightArithShift: rightArithShiftDocs, + rightLogShift: rightLogShiftDocs, + // functions - combinatorics + bellNumbers: bellNumbersDocs, + catalan: catalanDocs, + composition: compositionDocs, + stirlingS2: stirlingS2Docs, + // functions - core + config: configDocs, + import: importDocs, + typed: typedDocs, + // functions - complex + arg: argDocs, + conj: conjDocs, + re: reDocs, + im: imDocs, + // functions - expression + evaluate: evaluateDocs, + help: helpDocs, + // functions - geometry + distance: distanceDocs, + intersect: intersectDocs, + // functions - logical + and: andDocs, + not: notDocs, + or: orDocs, + xor: xorDocs, + // functions - matrix + concat: concatDocs, + count: countDocs, + cross: crossDocs, + column: columnDocs, + ctranspose: ctransposeDocs, + det: detDocs, + diag: diagDocs, + diff: diffDocs, + dot: dotDocs, + getMatrixDataType: getMatrixDataTypeDocs, + identity: identityDocs, + filter: filterDocs, + flatten: flattenDocs, + forEach: forEachDocs, + inv: invDocs, + pinv: pinvDocs, + eigs: eigsDocs, + kron: kronDocs, + matrixFromFunction: matrixFromFunctionDocs, + matrixFromRows: matrixFromRowsDocs, + matrixFromColumns: matrixFromColumnsDocs, + map: mapDocs, + ones: onesDocs, + partitionSelect: partitionSelectDocs, + range: rangeDocs, + resize: resizeDocs, + reshape: reshapeDocs, + rotate: rotateDocs, + rotationMatrix: rotationMatrixDocs, + row: rowDocs, + size: sizeDocs, + sort: sortDocs, + squeeze: squeezeDocs, + subset: subsetDocs, + trace: traceDocs, + transpose: transposeDocs, + zeros: zerosDocs, + fft: fftDocs, + ifft: ifftDocs, + sylvester: sylvesterDocs, + schur: schurDocs, + lyap: lyapDocs, + // functions - numeric + solveODE: solveODEDocs, + // functions - probability + combinations: combinationsDocs, + combinationsWithRep: combinationsWithRepDocs, + // distribution: distributionDocs, + factorial: factorialDocs, + gamma: gammaDocs, + kldivergence: kldivergenceDocs, + lgamma: lgammaDocs, + multinomial: multinomialDocs, + permutations: permutationsDocs, + pickRandom: pickRandomDocs, + random: randomDocs, + randomInt: randomIntDocs, + // functions - relational + compare: compareDocs, + compareNatural: compareNaturalDocs, + compareText: compareTextDocs, + deepEqual: deepEqualDocs, + equal: equalDocs, + equalText: equalTextDocs, + larger: largerDocs, + largerEq: largerEqDocs, + smaller: smallerDocs, + smallerEq: smallerEqDocs, + unequal: unequalDocs, + // functions - set + setCartesian: setCartesianDocs, + setDifference: setDifferenceDocs, + setDistinct: setDistinctDocs, + setIntersect: setIntersectDocs, + setIsSubset: setIsSubsetDocs, + setMultiplicity: setMultiplicityDocs, + setPowerset: setPowersetDocs, + setSize: setSizeDocs, + setSymDifference: setSymDifferenceDocs, + setUnion: setUnionDocs, + // functions - signal + zpk2tf: zpk2tfDocs, + freqz: freqzDocs, + // functions - special + erf: erfDocs, + zeta: zetaDocs, + // functions - statistics + cumsum: cumSumDocs, + mad: madDocs, + max: maxDocs, + mean: meanDocs, + median: medianDocs, + min: minDocs, + mode: modeDocs, + prod: prodDocs, + quantileSeq: quantileSeqDocs, + std: stdDocs, + sum: sumDocs, + variance: varianceDocs, + corr: corrDocs, + // functions - trigonometry + acos: acosDocs, + acosh: acoshDocs, + acot: acotDocs, + acoth: acothDocs, + acsc: acscDocs, + acsch: acschDocs, + asec: asecDocs, + asech: asechDocs, + asin: asinDocs, + asinh: asinhDocs, + atan: atanDocs, + atanh: atanhDocs, + atan2: atan2Docs, + cos: cosDocs, + cosh: coshDocs, + cot: cotDocs, + coth: cothDocs, + csc: cscDocs, + csch: cschDocs, + sec: secDocs, + sech: sechDocs, + sin: sinDocs, + sinh: sinhDocs, + tan: tanDocs, + tanh: tanhDocs, + // functions - units + to: toDocs, + // functions - utils + clone: cloneDocs, + format: formatDocs, + bin: binDocs, + oct: octDocs, + hex: hexDocs, + isNaN: isNaNDocs, + isInteger: isIntegerDocs, + isNegative: isNegativeDocs, + isNumeric: isNumericDocs, + hasNumericValue: hasNumericValueDocs, + isPositive: isPositiveDocs, + isPrime: isPrimeDocs, + isZero: isZeroDocs, + print: printDocs, + typeOf: typeOfDocs, + numeric: numericDocs +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/derivative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/derivative.js new file mode 100644 index 0000000..755c5db --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/derivative.js @@ -0,0 +1,8 @@ +export var derivativeDocs = { + name: 'derivative', + category: 'Algebra', + syntax: ['derivative(expr, variable)', 'derivative(expr, variable, {simplify: boolean})'], + description: 'Takes the derivative of an expression expressed in parser Nodes. The derivative will be taken over the supplied variable in the second parameter. If there are multiple variables in the expression, it will return a partial derivative.', + examples: ['derivative("2x^3", "x")', 'derivative("2x^3", "x", {simplify: false})', 'derivative("2x^2 + 3x + 4", "x")', 'derivative("sin(2x)", "x")', 'f = parse("x^2 + x")', 'x = parse("x")', 'df = derivative(f, x)', 'df.evaluate({x: 3})'], + seealso: ['simplify', 'parse', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/leafCount.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/leafCount.js new file mode 100644 index 0000000..5b7acd8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/leafCount.js @@ -0,0 +1,8 @@ +export var leafCountDocs = { + name: 'leafCount', + category: 'Algebra', + syntax: ['leafCount(expr)'], + description: 'Computes the number of leaves in the parse tree of the given expression', + examples: ['leafCount("e^(i*pi)-1")', 'leafCount(parse("{a: 22/7, b: 10^(1/2)}"))'], + seealso: ['simplify'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolve.js new file mode 100644 index 0000000..e45f544 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolve.js @@ -0,0 +1,8 @@ +export var lsolveDocs = { + name: 'lsolve', + category: 'Algebra', + syntax: ['x=lsolve(L, b)'], + description: 'Finds one solution of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'], + seealso: ['lsolveAll', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolveAll.js new file mode 100644 index 0000000..2bdf1d1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lsolveAll.js @@ -0,0 +1,8 @@ +export var lsolveAllDocs = { + name: 'lsolveAll', + category: 'Algebra', + syntax: ['x=lsolveAll(L, b)'], + description: 'Finds all solutions of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'], + seealso: ['lsolve', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lup.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lup.js new file mode 100644 index 0000000..4b3af50 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lup.js @@ -0,0 +1,8 @@ +export var lupDocs = { + name: 'lup', + category: 'Algebra', + syntax: ['lup(m)'], + description: 'Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U', + examples: ['lup([[2, 1], [1, 4]])', 'lup(matrix([[2, 1], [1, 4]]))', 'lup(sparse([[2, 1], [1, 4]]))'], + seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'slu', 'qr'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lusolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lusolve.js new file mode 100644 index 0000000..25a4709 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lusolve.js @@ -0,0 +1,8 @@ +export var lusolveDocs = { + name: 'lusolve', + category: 'Algebra', + syntax: ['x=lusolve(A, b)', 'x=lusolve(lu, b)'], + description: 'Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.', + examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lusolve(a, b)'], + seealso: ['lup', 'slu', 'lsolve', 'usolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lyap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lyap.js new file mode 100644 index 0000000..5d92c34 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/lyap.js @@ -0,0 +1,8 @@ +export var lyapDocs = { + name: 'lyap', + category: 'Algebra', + syntax: ['lyap(A,Q)'], + description: 'Solves the Continuous-time Lyapunov equation AP+PA\'+Q=0 for P', + examples: ['lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])', 'A = [[-2, 0], [1, -4]]', 'Q = [[3, 1], [1, 3]]', 'lyap(A,Q)'], + seealso: ['schur', 'sylvester'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/polynomialRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/polynomialRoot.js new file mode 100644 index 0000000..015c69b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/polynomialRoot.js @@ -0,0 +1,8 @@ +export var polynomialRootDocs = { + name: 'polynomialRoot', + category: 'Algebra', + syntax: ['x=polynomialRoot(-6, 3)', 'x=polynomialRoot(4, -4, 1)', 'x=polynomialRoot(-8, 12, -6, 1)'], + description: 'Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.', + examples: ['a = polynomialRoot(-6, 11, -6, 1)'], + seealso: ['cbrt', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/qr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/qr.js new file mode 100644 index 0000000..f6e2433 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/qr.js @@ -0,0 +1,8 @@ +export var qrDocs = { + name: 'qr', + category: 'Algebra', + syntax: ['qr(A)'], + description: 'Calculates the Matrix QR decomposition. Matrix `A` is decomposed in two matrices (`Q`, `R`) where `Q` is an orthogonal matrix and `R` is an upper triangular matrix.', + examples: ['qr([[1, -1, 4], [1, 4, -2], [1, 4, 2], [1, -1, 0]])'], + seealso: ['lup', 'slu', 'matrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/rationalize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/rationalize.js new file mode 100644 index 0000000..0e93662 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/rationalize.js @@ -0,0 +1,8 @@ +export var rationalizeDocs = { + name: 'rationalize', + category: 'Algebra', + syntax: ['rationalize(expr)', 'rationalize(expr, scope)', 'rationalize(expr, scope, detailed)'], + description: 'Transform a rationalizable expression in a rational fraction. If rational fraction is one variable polynomial then converts the numerator and denominator in canonical form, with decreasing exponents, returning the coefficients of numerator.', + examples: ['rationalize("2x/y - y/(x+1)")', 'rationalize("2x/y - y/(x+1)", true)'], + seealso: ['simplify'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/resolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/resolve.js new file mode 100644 index 0000000..05cf54d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/resolve.js @@ -0,0 +1,9 @@ +export var resolveDocs = { + name: 'resolve', + category: 'Algebra', + syntax: ['resolve(node, scope)'], + description: 'Recursively substitute variables in an expression tree.', + examples: ['resolve(parse("1 + x"), { x: 7 })', 'resolve(parse("size(text)"), { text: "Hello World" })', 'resolve(parse("x + y"), { x: parse("3z") })', 'resolve(parse("3x"), { x: parse("y+z"), z: parse("w^y") })'], + seealso: ['simplify', 'evaluate'], + mayThrow: ['ReferenceError'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/schur.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/schur.js new file mode 100644 index 0000000..45de73d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/schur.js @@ -0,0 +1,8 @@ +export var schurDocs = { + name: 'schur', + category: 'Algebra', + syntax: ['schur(A)'], + description: 'Performs a real Schur decomposition of the real matrix A = UTU\'', + examples: ['schur([[1, 0], [-4, 3]])', 'A = [[1, 0], [-4, 3]]', 'schur(A)'], + seealso: ['lyap', 'sylvester'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplify.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplify.js new file mode 100644 index 0000000..a777a97 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplify.js @@ -0,0 +1,8 @@ +export var simplifyDocs = { + name: 'simplify', + category: 'Algebra', + syntax: ['simplify(expr)', 'simplify(expr, rules)'], + description: 'Simplify an expression tree.', + examples: ['simplify("3 + 2 / 4")', 'simplify("2x + x")', 'f = parse("x * (x + 2 + x)")', 'simplified = simplify(f)', 'simplified.evaluate({x: 2})'], + seealso: ['simplifyCore', 'derivative', 'evaluate', 'parse', 'rationalize', 'resolve'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyConstant.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyConstant.js new file mode 100644 index 0000000..8881281 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyConstant.js @@ -0,0 +1,8 @@ +export var simplifyConstantDocs = { + name: 'simplifyConstant', + category: 'Algebra', + syntax: ['simplifyConstant(expr)', 'simplifyConstant(expr, options)'], + description: 'Replace constant subexpressions of node with their values.', + examples: ['simplifyConstant("(3-3)*x")', 'simplifyConstant(parse("z-cos(tau/8)"))'], + seealso: ['simplify', 'simplifyCore', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyCore.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyCore.js new file mode 100644 index 0000000..4eed2a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/simplifyCore.js @@ -0,0 +1,8 @@ +export var simplifyCoreDocs = { + name: 'simplifyCore', + category: 'Algebra', + syntax: ['simplifyCore(node)'], + description: 'Perform simple one-pass simplifications on an expression tree.', + examples: ['simplifyCore(parse("0*x"))', 'simplifyCore(parse("(x+0)*2"))'], + seealso: ['simplify', 'simplifyConstant', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/slu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/slu.js new file mode 100644 index 0000000..f1527e2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/slu.js @@ -0,0 +1,8 @@ +export var sluDocs = { + name: 'slu', + category: 'Algebra', + syntax: ['slu(A, order, threshold)'], + description: 'Calculate the Matrix LU decomposition with full pivoting. Matrix A is decomposed in two matrices (L, U) and two permutation vectors (pinv, q) where P * A * Q = L * U', + examples: ['slu(sparse([4.5, 0, 3.2, 0; 3.1, 2.9, 0, 0.9; 0, 1.7, 3, 0; 3.5, 0.4, 0, 1]), 1, 0.001)'], + seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'lup', 'qr'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/sylvester.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/sylvester.js new file mode 100644 index 0000000..6b42976 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/sylvester.js @@ -0,0 +1,8 @@ +export var sylvesterDocs = { + name: 'sylvester', + category: 'Algebra', + syntax: ['sylvester(A,B,C)'], + description: 'Solves the real-valued Sylvester equation AX+XB=C for X', + examples: ['sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])', 'A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]', 'sylvester(A, B, C)'], + seealso: ['schur', 'lyap'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/symbolicEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/symbolicEqual.js new file mode 100644 index 0000000..87b25fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/symbolicEqual.js @@ -0,0 +1,8 @@ +export var symbolicEqualDocs = { + name: 'symbolicEqual', + category: 'Algebra', + syntax: ['symbolicEqual(expr1, expr2)', 'symbolicEqual(expr1, expr2, options)'], + description: 'Returns true if the difference of the expressions simplifies to 0', + examples: ['symbolicEqual("x*y","y*x")', 'symbolicEqual("abs(x^2)", "x^2")', 'symbolicEqual("abs(x)", "x", {context: {abs: {trivial: true}}})'], + seealso: ['simplify', 'evaluate'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolve.js new file mode 100644 index 0000000..4020054 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolve.js @@ -0,0 +1,8 @@ +export var usolveDocs = { + name: 'usolve', + category: 'Algebra', + syntax: ['x=usolve(U, b)'], + description: 'Finds one solution of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.', + examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'], + seealso: ['usolveAll', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolveAll.js new file mode 100644 index 0000000..b05833a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/algebra/usolveAll.js @@ -0,0 +1,8 @@ +export var usolveAllDocs = { + name: 'usolveAll', + category: 'Algebra', + syntax: ['x=usolve(U, b)'], + description: 'Finds all solutions of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.', + examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'], + seealso: ['usolve', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/abs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/abs.js new file mode 100644 index 0000000..27c8f89 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/abs.js @@ -0,0 +1,8 @@ +export var absDocs = { + name: 'abs', + category: 'Arithmetic', + syntax: ['abs(x)'], + description: 'Compute the absolute value.', + examples: ['abs(3.5)', 'abs(-4.2)'], + seealso: ['sign'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/add.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/add.js new file mode 100644 index 0000000..50c902b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/add.js @@ -0,0 +1,8 @@ +export var addDocs = { + name: 'add', + category: 'Operators', + syntax: ['x + y', 'add(x, y)'], + description: 'Add two values.', + examples: ['a = 2.1 + 3.6', 'a - 3.6', '3 + 2i', '3 cm + 2 inch', '"2.3" + "4"'], + seealso: ['subtract'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cbrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cbrt.js new file mode 100644 index 0000000..225cd12 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cbrt.js @@ -0,0 +1,8 @@ +export var cbrtDocs = { + name: 'cbrt', + category: 'Arithmetic', + syntax: ['cbrt(x)', 'cbrt(x, allRoots)'], + description: 'Compute the cubic root value. If x = y * y * y, then y is the cubic root of x. When `x` is a number or complex number, an optional second argument `allRoots` can be provided to return all three cubic roots. If not provided, the principal root is returned', + examples: ['cbrt(64)', 'cube(4)', 'cbrt(-8)', 'cbrt(2 + 3i)', 'cbrt(8i)', 'cbrt(8i, true)', 'cbrt(27 m^3)'], + seealso: ['square', 'sqrt', 'cube', 'multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/ceil.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/ceil.js new file mode 100644 index 0000000..e38bb35 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/ceil.js @@ -0,0 +1,8 @@ +export var ceilDocs = { + name: 'ceil', + category: 'Arithmetic', + syntax: ['ceil(x)'], + description: 'Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.', + examples: ['ceil(3.2)', 'ceil(3.8)', 'ceil(-4.2)'], + seealso: ['floor', 'fix', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cube.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cube.js new file mode 100644 index 0000000..db2ea35 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/cube.js @@ -0,0 +1,8 @@ +export var cubeDocs = { + name: 'cube', + category: 'Arithmetic', + syntax: ['cube(x)'], + description: 'Compute the cube of a value. The cube of x is x * x * x.', + examples: ['cube(2)', '2^3', '2 * 2 * 2'], + seealso: ['multiply', 'square', 'pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/divide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/divide.js new file mode 100644 index 0000000..350eaa2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/divide.js @@ -0,0 +1,8 @@ +export var divideDocs = { + name: 'divide', + category: 'Operators', + syntax: ['x / y', 'divide(x, y)'], + description: 'Divide two values.', + examples: ['a = 2 / 3', 'a * 3', '4.5 / 2', '3 + 4 / 2', '(3 + 4) / 2', '18 km / 4.5'], + seealso: ['multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotDivide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotDivide.js new file mode 100644 index 0000000..d0124ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotDivide.js @@ -0,0 +1,8 @@ +export var dotDivideDocs = { + name: 'dotDivide', + category: 'Operators', + syntax: ['x ./ y', 'dotDivide(x, y)'], + description: 'Divide two values element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a ./ b'], + seealso: ['multiply', 'dotMultiply', 'divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotMultiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotMultiply.js new file mode 100644 index 0000000..f66bba9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotMultiply.js @@ -0,0 +1,8 @@ +export var dotMultiplyDocs = { + name: 'dotMultiply', + category: 'Operators', + syntax: ['x .* y', 'dotMultiply(x, y)'], + description: 'Multiply two values element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a .* b'], + seealso: ['multiply', 'divide', 'dotDivide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotPow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotPow.js new file mode 100644 index 0000000..a977c1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/dotPow.js @@ -0,0 +1,8 @@ +export var dotPowDocs = { + name: 'dotPow', + category: 'Operators', + syntax: ['x .^ y', 'dotPow(x, y)'], + description: 'Calculates the power of x to y element wise.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a .^ 2'], + seealso: ['pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/exp.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/exp.js new file mode 100644 index 0000000..0067c84 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/exp.js @@ -0,0 +1,8 @@ +export var expDocs = { + name: 'exp', + category: 'Arithmetic', + syntax: ['exp(x)'], + description: 'Calculate the exponent of a value.', + examples: ['exp(1.3)', 'e ^ 1.3', 'log(exp(1.3))', 'x = 2.4', '(exp(i*x) == cos(x) + i*sin(x)) # Euler\'s formula'], + seealso: ['expm', 'expm1', 'pow', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm.js new file mode 100644 index 0000000..8fc045c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm.js @@ -0,0 +1,8 @@ +export var expmDocs = { + name: 'expm', + category: 'Arithmetic', + syntax: ['exp(x)'], + description: 'Compute the matrix exponential, expm(A) = e^A. ' + 'The matrix must be square. ' + 'Not to be confused with exp(a), which performs element-wise exponentiation.', + examples: ['expm([[0,2],[0,0]])'], + seealso: ['exp'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm1.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm1.js new file mode 100644 index 0000000..28098a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/expm1.js @@ -0,0 +1,8 @@ +export var expm1Docs = { + name: 'expm1', + category: 'Arithmetic', + syntax: ['expm1(x)'], + description: 'Calculate the value of subtracting 1 from the exponential value.', + examples: ['expm1(2)', 'pow(e, 2) - 1', 'log(expm1(2) + 1)'], + seealso: ['exp', 'pow', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/fix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/fix.js new file mode 100644 index 0000000..69ad27d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/fix.js @@ -0,0 +1,8 @@ +export var fixDocs = { + name: 'fix', + category: 'Arithmetic', + syntax: ['fix(x)'], + description: 'Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.', + examples: ['fix(3.2)', 'fix(3.8)', 'fix(-4.2)', 'fix(-4.8)'], + seealso: ['ceil', 'floor', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/floor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/floor.js new file mode 100644 index 0000000..e004fe4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/floor.js @@ -0,0 +1,8 @@ +export var floorDocs = { + name: 'floor', + category: 'Arithmetic', + syntax: ['floor(x)'], + description: 'Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.', + examples: ['floor(3.2)', 'floor(3.8)', 'floor(-4.2)'], + seealso: ['ceil', 'fix', 'round'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/gcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/gcd.js new file mode 100644 index 0000000..3944fc2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/gcd.js @@ -0,0 +1,8 @@ +export var gcdDocs = { + name: 'gcd', + category: 'Arithmetic', + syntax: ['gcd(a, b)', 'gcd(a, b, c, ...)'], + description: 'Compute the greatest common divisor.', + examples: ['gcd(8, 12)', 'gcd(-4, 6)', 'gcd(25, 15, -10)'], + seealso: ['lcm', 'xgcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/hypot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/hypot.js new file mode 100644 index 0000000..fa65019 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/hypot.js @@ -0,0 +1,8 @@ +export var hypotDocs = { + name: 'hypot', + category: 'Arithmetic', + syntax: ['hypot(a, b, c, ...)', 'hypot([a, b, c, ...])'], + description: 'Calculate the hypotenuse of a list with values.', + examples: ['hypot(3, 4)', 'sqrt(3^2 + 4^2)', 'hypot(-2)', 'hypot([3, 4, 5])'], + seealso: ['abs', 'norm'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/invmod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/invmod.js new file mode 100644 index 0000000..3ad8e2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/invmod.js @@ -0,0 +1,8 @@ +export var invmodDocs = { + name: 'invmod', + category: 'Arithmetic', + syntax: ['invmod(a, b)'], + description: 'Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)', + examples: ['invmod(8, 12)', 'invmod(7, 13)', 'invmod(15151, 15122)'], + seealso: ['gcd', 'xgcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/lcm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/lcm.js new file mode 100644 index 0000000..3b6309f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/lcm.js @@ -0,0 +1,8 @@ +export var lcmDocs = { + name: 'lcm', + category: 'Arithmetic', + syntax: ['lcm(x, y)'], + description: 'Compute the least common multiple.', + examples: ['lcm(4, 6)', 'lcm(6, 21)', 'lcm(6, 21, 5)'], + seealso: ['gcd'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log.js new file mode 100644 index 0000000..af228dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log.js @@ -0,0 +1,8 @@ +export var logDocs = { + name: 'log', + category: 'Arithmetic', + syntax: ['log(x)', 'log(x, base)'], + description: 'Compute the logarithm of a value. If no base is provided, the natural logarithm of x is calculated. If base if provided, the logarithm is calculated for the specified base. log(x, base) is defined as log(x) / log(base).', + examples: ['log(3.5)', 'a = log(2.4)', 'exp(a)', '10 ^ 4', 'log(10000, 10)', 'log(10000) / log(10)', 'b = log(1024, 2)', '2 ^ b'], + seealso: ['exp', 'log1p', 'log2', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log10.js new file mode 100644 index 0000000..4687c87 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log10.js @@ -0,0 +1,8 @@ +export var log10Docs = { + name: 'log10', + category: 'Arithmetic', + syntax: ['log10(x)'], + description: 'Compute the 10-base logarithm of a value.', + examples: ['log10(0.00001)', 'log10(10000)', '10 ^ 4', 'log(10000) / log(10)', 'log(10000, 10)'], + seealso: ['exp', 'log'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log1p.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log1p.js new file mode 100644 index 0000000..4c0a5cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log1p.js @@ -0,0 +1,8 @@ +export var log1pDocs = { + name: 'log1p', + category: 'Arithmetic', + syntax: ['log1p(x)', 'log1p(x, base)'], + description: 'Calculate the logarithm of a `value+1`', + examples: ['log1p(2.5)', 'exp(log1p(1.4))', 'pow(10, 4)', 'log1p(9999, 10)', 'log1p(9999) / log(10)'], + seealso: ['exp', 'log', 'log2', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log2.js new file mode 100644 index 0000000..faf07cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/log2.js @@ -0,0 +1,8 @@ +export var log2Docs = { + name: 'log2', + category: 'Arithmetic', + syntax: ['log2(x)'], + description: 'Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.', + examples: ['log2(0.03125)', 'log2(16)', 'log2(16) / log2(2)', 'pow(2, 4)'], + seealso: ['exp', 'log1p', 'log', 'log10'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/mod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/mod.js new file mode 100644 index 0000000..f8eda30 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/mod.js @@ -0,0 +1,8 @@ +export var modDocs = { + name: 'mod', + category: 'Operators', + syntax: ['x % y', 'x mod y', 'mod(x, y)'], + description: 'Calculates the modulus, the remainder of an integer division.', + examples: ['7 % 3', '11 % 2', '10 mod 4', 'isOdd(x) = x % 2', 'isOdd(2)', 'isOdd(3)'], + seealso: ['divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/multiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/multiply.js new file mode 100644 index 0000000..1f28098 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/multiply.js @@ -0,0 +1,8 @@ +export var multiplyDocs = { + name: 'multiply', + category: 'Operators', + syntax: ['x * y', 'multiply(x, y)'], + description: 'multiply two values.', + examples: ['a = 2.1 * 3.4', 'a / 3.4', '2 * 3 + 4', '2 * (3 + 4)', '3 * 2.1 km'], + seealso: ['divide'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/norm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/norm.js new file mode 100644 index 0000000..129579e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/norm.js @@ -0,0 +1,7 @@ +export var normDocs = { + name: 'norm', + category: 'Arithmetic', + syntax: ['norm(x)', 'norm(x, p)'], + description: 'Calculate the norm of a number, vector or matrix.', + examples: ['abs(-3.5)', 'norm(-3.5)', 'norm(3 - 4i)', 'norm([1, 2, -3], Infinity)', 'norm([1, 2, -3], -Infinity)', 'norm([3, 4], 2)', 'norm([[1, 2], [3, 4]], 1)', 'norm([[1, 2], [3, 4]], "inf")', 'norm([[1, 2], [3, 4]], "fro")'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoot.js new file mode 100644 index 0000000..9cf2442 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoot.js @@ -0,0 +1,8 @@ +export var nthRootDocs = { + name: 'nthRoot', + category: 'Arithmetic', + syntax: ['nthRoot(a)', 'nthRoot(a, root)'], + description: 'Calculate the nth root of a value. ' + 'The principal nth root of a positive real number A, ' + 'is the positive real solution of the equation "x^root = A".', + examples: ['4 ^ 3', 'nthRoot(64, 3)', 'nthRoot(9, 2)', 'sqrt(9)'], + seealso: ['nthRoots', 'pow', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoots.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoots.js new file mode 100644 index 0000000..2b5de3c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/nthRoots.js @@ -0,0 +1,8 @@ +export var nthRootsDocs = { + name: 'nthRoots', + category: 'Arithmetic', + syntax: ['nthRoots(A)', 'nthRoots(A, root)'], + description: '' + 'Calculate the nth roots of a value. ' + 'An nth root of a positive real number A, ' + 'is a positive real solution of the equation "x^root = A". ' + 'This function returns an array of complex values.', + examples: ['nthRoots(1)', 'nthRoots(1, 3)'], + seealso: ['sqrt', 'pow', 'nthRoot'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/pow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/pow.js new file mode 100644 index 0000000..3924b92 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/pow.js @@ -0,0 +1,8 @@ +export var powDocs = { + name: 'pow', + category: 'Operators', + syntax: ['x ^ y', 'pow(x, y)'], + description: 'Calculates the power of x to y, x^y.', + examples: ['2^3', '2*2*2', '1 + e ^ (pi * i)', 'pow([[1, 2], [4, 3]], 2)', 'pow([[1, 2], [4, 3]], -1)'], + seealso: ['multiply', 'nthRoot', 'nthRoots', 'sqrt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/round.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/round.js new file mode 100644 index 0000000..aefd523 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/round.js @@ -0,0 +1,8 @@ +export var roundDocs = { + name: 'round', + category: 'Arithmetic', + syntax: ['round(x)', 'round(x, n)', 'round(unit, valuelessUnit)', 'round(unit, n, valuelessUnit)'], + description: 'round a value towards the nearest integer.If x is complex, both real and imaginary part are rounded towards the nearest integer. When n is specified, the value is rounded to n decimals.', + examples: ['round(3.2)', 'round(3.8)', 'round(-4.2)', 'round(-4.8)', 'round(pi, 3)', 'round(123.45678, 2)', 'round(3.241cm, 2, cm)', 'round([3.2, 3.8, -4.7])'], + seealso: ['ceil', 'floor', 'fix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sign.js new file mode 100644 index 0000000..8972a5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sign.js @@ -0,0 +1,8 @@ +export var signDocs = { + name: 'sign', + category: 'Arithmetic', + syntax: ['sign(x)'], + description: 'Compute the sign of a value. The sign of a value x is 1 when x>1, -1 when x<0, and 0 when x=0.', + examples: ['sign(3.5)', 'sign(-4.2)', 'sign(0)'], + seealso: ['abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrt.js new file mode 100644 index 0000000..9fc19ac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrt.js @@ -0,0 +1,8 @@ +export var sqrtDocs = { + name: 'sqrt', + category: 'Arithmetic', + syntax: ['sqrt(x)'], + description: 'Compute the square root value. If x = y * y, then y is the square root of x.', + examples: ['sqrt(25)', '5 * 5', 'sqrt(-1)'], + seealso: ['square', 'sqrtm', 'multiply', 'nthRoot', 'nthRoots', 'pow'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrtm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrtm.js new file mode 100644 index 0000000..859deb3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/sqrtm.js @@ -0,0 +1,8 @@ +export var sqrtmDocs = { + name: 'sqrtm', + category: 'Arithmetic', + syntax: ['sqrtm(x)'], + description: 'Calculate the principal square root of a square matrix. The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.', + examples: ['sqrtm([[33, 24], [48, 57]])'], + seealso: ['sqrt', 'abs', 'square', 'multiply'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/square.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/square.js new file mode 100644 index 0000000..5c858f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/square.js @@ -0,0 +1,8 @@ +export var squareDocs = { + name: 'square', + category: 'Arithmetic', + syntax: ['square(x)'], + description: 'Compute the square of a value. The square of x is x * x.', + examples: ['square(3)', 'sqrt(9)', '3^2', '3 * 3'], + seealso: ['multiply', 'pow', 'sqrt', 'cube'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/subtract.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/subtract.js new file mode 100644 index 0000000..c6a2084 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/subtract.js @@ -0,0 +1,8 @@ +export var subtractDocs = { + name: 'subtract', + category: 'Operators', + syntax: ['x - y', 'subtract(x, y)'], + description: 'subtract two values.', + examples: ['a = 5.3 - 2', 'a + 2', '2/3 - 1/6', '2 * 3 - 3', '2.1 km - 500m'], + seealso: ['add'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryMinus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryMinus.js new file mode 100644 index 0000000..e4dcbaf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryMinus.js @@ -0,0 +1,8 @@ +export var unaryMinusDocs = { + name: 'unaryMinus', + category: 'Operators', + syntax: ['-x', 'unaryMinus(x)'], + description: 'Inverse the sign of a value. Converts booleans and strings to numbers.', + examples: ['-4.5', '-(-5.6)', '-"22"'], + seealso: ['add', 'subtract', 'unaryPlus'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryPlus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryPlus.js new file mode 100644 index 0000000..783efc4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/unaryPlus.js @@ -0,0 +1,8 @@ +export var unaryPlusDocs = { + name: 'unaryPlus', + category: 'Operators', + syntax: ['+x', 'unaryPlus(x)'], + description: 'Converts booleans and strings to numbers.', + examples: ['+true', '+"2"'], + seealso: ['add', 'subtract', 'unaryMinus'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/xgcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/xgcd.js new file mode 100644 index 0000000..a0ec1de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/arithmetic/xgcd.js @@ -0,0 +1,8 @@ +export var xgcdDocs = { + name: 'xgcd', + category: 'Arithmetic', + syntax: ['xgcd(a, b)'], + description: 'Calculate the extended greatest common divisor for two values. The result is an array [d, x, y] with 3 entries, where d is the greatest common divisor, and d = x * a + y * b.', + examples: ['xgcd(8, 12)', 'gcd(8, 12)', 'xgcd(36163, 21199)'], + seealso: ['gcd', 'lcm'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitAnd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitAnd.js new file mode 100644 index 0000000..5e4af2a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitAnd.js @@ -0,0 +1,8 @@ +export var bitAndDocs = { + name: 'bitAnd', + category: 'Bitwise', + syntax: ['x & y', 'bitAnd(x, y)'], + description: 'Bitwise AND operation. Performs the logical AND operation on each pair of the corresponding bits of the two given values by multiplying them. If both bits in the compared position are 1, the bit in the resulting binary representation is 1, otherwise, the result is 0', + examples: ['5 & 3', 'bitAnd(53, 131)', '[1, 12, 31] & 42'], + seealso: ['bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitNot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitNot.js new file mode 100644 index 0000000..905841f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitNot.js @@ -0,0 +1,8 @@ +export var bitNotDocs = { + name: 'bitNot', + category: 'Bitwise', + syntax: ['~x', 'bitNot(x)'], + description: 'Bitwise NOT operation. Performs a logical negation on each bit of the given value. Bits that are 0 become 1, and those that are 1 become 0.', + examples: ['~1', '~2', 'bitNot([2, -3, 4])'], + seealso: ['bitAnd', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitOr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitOr.js new file mode 100644 index 0000000..2e98ee5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitOr.js @@ -0,0 +1,8 @@ +export var bitOrDocs = { + name: 'bitOr', + category: 'Bitwise', + syntax: ['x | y', 'bitOr(x, y)'], + description: 'Bitwise OR operation. Performs the logical inclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if the first bit is 1 or the second bit is 1 or both bits are 1, otherwise, the result is 0.', + examples: ['5 | 3', 'bitOr([1, 2, 3], 4)'], + seealso: ['bitAnd', 'bitNot', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitXor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitXor.js new file mode 100644 index 0000000..4be877e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/bitXor.js @@ -0,0 +1,8 @@ +export var bitXorDocs = { + name: 'bitXor', + category: 'Bitwise', + syntax: ['bitXor(x, y)'], + description: 'Bitwise XOR operation, exclusive OR. Performs the logical exclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if only the first bit is 1 or only the second bit is 1, but will be 0 if both are 0 or both are 1.', + examples: ['bitOr(1, 2)', 'bitXor([2, 3, 4], 4)'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'leftShift', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/leftShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/leftShift.js new file mode 100644 index 0000000..a693a22 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/leftShift.js @@ -0,0 +1,8 @@ +export var leftShiftDocs = { + name: 'leftShift', + category: 'Bitwise', + syntax: ['x << y', 'leftShift(x, y)'], + description: 'Bitwise left logical shift of a value x by y number of bits.', + examples: ['4 << 1', '8 >> 1'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'rightArithShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightArithShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightArithShift.js new file mode 100644 index 0000000..107a877 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightArithShift.js @@ -0,0 +1,8 @@ +export var rightArithShiftDocs = { + name: 'rightArithShift', + category: 'Bitwise', + syntax: ['x >> y', 'rightArithShift(x, y)'], + description: 'Bitwise right arithmetic shift of a value x by y number of bits.', + examples: ['8 >> 1', '4 << 1', '-12 >> 2'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightLogShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightLogShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightLogShift.js new file mode 100644 index 0000000..fed62da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/bitwise/rightLogShift.js @@ -0,0 +1,8 @@ +export var rightLogShiftDocs = { + name: 'rightLogShift', + category: 'Bitwise', + syntax: ['x >>> y', 'rightLogShift(x, y)'], + description: 'Bitwise right logical shift of a value x by y number of bits.', + examples: ['8 >>> 1', '4 << 1', '-12 >>> 2'], + seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/bellNumbers.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/bellNumbers.js new file mode 100644 index 0000000..2a24de3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/bellNumbers.js @@ -0,0 +1,8 @@ +export var bellNumbersDocs = { + name: 'bellNumbers', + category: 'Combinatorics', + syntax: ['bellNumbers(n)'], + description: 'The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. `bellNumbers` only takes integer arguments. The following condition must be enforced: n >= 0.', + examples: ['bellNumbers(3)', 'bellNumbers(8)'], + seealso: ['stirlingS2'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/catalan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/catalan.js new file mode 100644 index 0000000..e68903b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/catalan.js @@ -0,0 +1,8 @@ +export var catalanDocs = { + name: 'catalan', + category: 'Combinatorics', + syntax: ['catalan(n)'], + description: 'The Catalan Numbers enumerate combinatorial structures of many different types. catalan only takes integer arguments. The following condition must be enforced: n >= 0.', + examples: ['catalan(3)', 'catalan(8)'], + seealso: ['bellNumbers'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/composition.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/composition.js new file mode 100644 index 0000000..17ddea5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/composition.js @@ -0,0 +1,8 @@ +export var compositionDocs = { + name: 'composition', + category: 'Combinatorics', + syntax: ['composition(n, k)'], + description: 'The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.', + examples: ['composition(5, 3)'], + seealso: ['combinations'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/stirlingS2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/stirlingS2.js new file mode 100644 index 0000000..42da118 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/combinatorics/stirlingS2.js @@ -0,0 +1,8 @@ +export var stirlingS2Docs = { + name: 'stirlingS2', + category: 'Combinatorics', + syntax: ['stirlingS2(n, k)'], + description: 'he Stirling numbers of the second kind, counts the number of ways to partition a set of n labelled objects into k nonempty unlabelled subsets. `stirlingS2` only takes integer arguments. The following condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = 1.', + examples: ['stirlingS2(5, 3)'], + seealso: ['bellNumbers'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/arg.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/arg.js new file mode 100644 index 0000000..365d159 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/arg.js @@ -0,0 +1,8 @@ +export var argDocs = { + name: 'arg', + category: 'Complex', + syntax: ['arg(x)'], + description: 'Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).', + examples: ['arg(2 + 2i)', 'atan2(3, 2)', 'arg(2 + 3i)'], + seealso: ['re', 'im', 'conj', 'abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/conj.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/conj.js new file mode 100644 index 0000000..95d6966 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/conj.js @@ -0,0 +1,8 @@ +export var conjDocs = { + name: 'conj', + category: 'Complex', + syntax: ['conj(x)'], + description: 'Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.', + examples: ['conj(2 + 3i)', 'conj(2 - 3i)', 'conj(-5.2i)'], + seealso: ['re', 'im', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/im.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/im.js new file mode 100644 index 0000000..1ef8686 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/im.js @@ -0,0 +1,8 @@ +export var imDocs = { + name: 'im', + category: 'Complex', + syntax: ['im(x)'], + description: 'Get the imaginary part of a complex number.', + examples: ['im(2 + 3i)', 're(2 + 3i)', 'im(-5.2i)', 'im(2.4)'], + seealso: ['re', 'conj', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/re.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/re.js new file mode 100644 index 0000000..5ba0074 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/complex/re.js @@ -0,0 +1,8 @@ +export var reDocs = { + name: 're', + category: 'Complex', + syntax: ['re(x)'], + description: 'Get the real part of a complex number.', + examples: ['re(2 + 3i)', 'im(2 + 3i)', 're(-5.2i)', 're(2.4)'], + seealso: ['im', 'conj', 'abs', 'arg'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/evaluate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/evaluate.js new file mode 100644 index 0000000..8462482 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/evaluate.js @@ -0,0 +1,8 @@ +export var evaluateDocs = { + name: 'evaluate', + category: 'Expression', + syntax: ['evaluate(expression)', 'evaluate(expression, scope)', 'evaluate([expr1, expr2, expr3, ...])', 'evaluate([expr1, expr2, expr3, ...], scope)'], + description: 'Evaluate an expression or an array with expressions.', + examples: ['evaluate("2 + 3")', 'evaluate("sqrt(16)")', 'evaluate("2 inch to cm")', 'evaluate("sin(x * pi)", { "x": 1/2 })', 'evaluate(["width=2", "height=4","width*height"])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/help.js new file mode 100644 index 0000000..51d9401 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/expression/help.js @@ -0,0 +1,8 @@ +export var helpDocs = { + name: 'help', + category: 'Expression', + syntax: ['help(object)', 'help(string)'], + description: 'Display documentation on a function or data type.', + examples: ['help(sqrt)', 'help("complex")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/distance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/distance.js new file mode 100644 index 0000000..f372020 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/distance.js @@ -0,0 +1,8 @@ +export var distanceDocs = { + name: 'distance', + category: 'Geometry', + syntax: ['distance([x1, y1], [x2, y2])', 'distance([[x1, y1], [x2, y2]])'], + description: 'Calculates the Euclidean distance between two points.', + examples: ['distance([0,0], [4,4])', 'distance([[0,0], [4,4]])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/intersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/intersect.js new file mode 100644 index 0000000..ebf61d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/geometry/intersect.js @@ -0,0 +1,8 @@ +export var intersectDocs = { + name: 'intersect', + category: 'Geometry', + syntax: ['intersect(expr1, expr2, expr3, expr4)', 'intersect(expr1, expr2, expr3)'], + description: 'Computes the intersection point of lines and/or planes.', + examples: ['intersect([0, 0], [10, 10], [10, 0], [0, 10])', 'intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/and.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/and.js new file mode 100644 index 0000000..88112d0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/and.js @@ -0,0 +1,8 @@ +export var andDocs = { + name: 'and', + category: 'Logical', + syntax: ['x and y', 'and(x, y)'], + description: 'Logical and. Test whether two values are both defined with a nonzero/nonempty value.', + examples: ['true and false', 'true and true', '2 and 4'], + seealso: ['not', 'or', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/not.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/not.js new file mode 100644 index 0000000..e5a7c58 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/not.js @@ -0,0 +1,8 @@ +export var notDocs = { + name: 'not', + category: 'Logical', + syntax: ['not x', 'not(x)'], + description: 'Logical not. Flips the boolean value of given argument.', + examples: ['not true', 'not false', 'not 2', 'not 0'], + seealso: ['and', 'or', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/or.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/or.js new file mode 100644 index 0000000..dbcd620 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/or.js @@ -0,0 +1,8 @@ +export var orDocs = { + name: 'or', + category: 'Logical', + syntax: ['x or y', 'or(x, y)'], + description: 'Logical or. Test if at least one value is defined with a nonzero/nonempty value.', + examples: ['true or false', 'false or false', '0 or 4'], + seealso: ['not', 'and', 'xor'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/xor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/xor.js new file mode 100644 index 0000000..c362d93 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/logical/xor.js @@ -0,0 +1,8 @@ +export var xorDocs = { + name: 'xor', + category: 'Logical', + syntax: ['x xor y', 'xor(x, y)'], + description: 'Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.', + examples: ['true xor false', 'false xor false', 'true xor true', '0 xor 4'], + seealso: ['not', 'and', 'or'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/column.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/column.js new file mode 100644 index 0000000..2a2ee86 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/column.js @@ -0,0 +1,8 @@ +export var columnDocs = { + name: 'column', + category: 'Matrix', + syntax: ['column(x, index)'], + description: 'Return a column from a matrix or array.', + examples: ['A = [[1, 2], [3, 4]]', 'column(A, 1)', 'column(A, 2)'], + seealso: ['row', 'matrixFromColumns'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/concat.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/concat.js new file mode 100644 index 0000000..b865da7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/concat.js @@ -0,0 +1,8 @@ +export var concatDocs = { + name: 'concat', + category: 'Matrix', + syntax: ['concat(A, B, C, ...)', 'concat(A, B, C, ..., dim)'], + description: 'Concatenate matrices. By default, the matrices are concatenated by the last dimension. The dimension on which to concatenate can be provided as last argument.', + examples: ['A = [1, 2; 5, 6]', 'B = [3, 4; 7, 8]', 'concat(A, B)', 'concat(A, B, 1)', 'concat(A, B, 2)'], + seealso: ['det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/count.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/count.js new file mode 100644 index 0000000..6237021 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/count.js @@ -0,0 +1,8 @@ +export var countDocs = { + name: 'count', + category: 'Matrix', + syntax: ['count(x)'], + description: 'Count the number of elements of a matrix, array or string.', + examples: ['a = [1, 2; 3, 4; 5, 6]', 'count(a)', 'size(a)', 'count("hello world")'], + seealso: ['size'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/cross.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/cross.js new file mode 100644 index 0000000..c9eed54 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/cross.js @@ -0,0 +1,8 @@ +export var crossDocs = { + name: 'cross', + category: 'Matrix', + syntax: ['cross(A, B)'], + description: 'Calculate the cross product for two vectors in three dimensional space.', + examples: ['cross([1, 1, 0], [0, 1, 1])', 'cross([3, -3, 1], [4, 9, 2])', 'cross([2, 3, 4], [5, 6, 7])'], + seealso: ['multiply', 'dot'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ctranspose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ctranspose.js new file mode 100644 index 0000000..730680e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ctranspose.js @@ -0,0 +1,8 @@ +export var ctransposeDocs = { + name: 'ctranspose', + category: 'Matrix', + syntax: ['x\'', 'ctranspose(x)'], + description: 'Complex Conjugate and Transpose a matrix', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\'', 'ctranspose(a)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/det.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/det.js new file mode 100644 index 0000000..79e0c92 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/det.js @@ -0,0 +1,8 @@ +export var detDocs = { + name: 'det', + category: 'Matrix', + syntax: ['det(x)'], + description: 'Calculate the determinant of a matrix', + examples: ['det([1, 2; 3, 4])', 'det([-2, 2, 3; -1, 1, 3; 2, 0, -1])'], + seealso: ['concat', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diag.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diag.js new file mode 100644 index 0000000..b6f65c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diag.js @@ -0,0 +1,8 @@ +export var diagDocs = { + name: 'diag', + category: 'Matrix', + syntax: ['diag(x)', 'diag(x, k)'], + description: 'Create a diagonal matrix or retrieve the diagonal of a matrix. When x is a vector, a matrix with the vector values on the diagonal will be returned. When x is a matrix, a vector with the diagonal values of the matrix is returned. When k is provided, the k-th diagonal will be filled in or retrieved, if k is positive, the values are placed on the super diagonal. When k is negative, the values are placed on the sub diagonal.', + examples: ['diag(1:3)', 'diag(1:3, 1)', 'a = [1, 2, 3; 4, 5, 6; 7, 8, 9]', 'diag(a)'], + seealso: ['concat', 'det', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diff.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diff.js new file mode 100644 index 0000000..518aa59 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/diff.js @@ -0,0 +1,8 @@ +export var diffDocs = { + name: 'diff', + category: 'Matrix', + syntax: ['diff(arr)', 'diff(arr, dim)'], + description: ['Create a new matrix or array with the difference of the passed matrix or array.', 'Dim parameter is optional and used to indicate the dimension of the array/matrix to apply the difference', 'If no dimension parameter is passed it is assumed as dimension 0', 'Dimension is zero-based in javascript and one-based in the parser', 'Arrays must be \'rectangular\' meaning arrays like [1, 2]', 'If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays'], + examples: ['A = [1, 2, 4, 7, 0]', 'diff(A)', 'diff(A, 1)', 'B = [[1, 2], [3, 4]]', 'diff(B)', 'diff(B, 1)', 'diff(B, 2)', 'diff(B, bignumber(2))', 'diff([[1, 2], matrix([3, 4])], 2)'], + seealso: ['subtract', 'partitionSelect'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/dot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/dot.js new file mode 100644 index 0000000..05d137d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/dot.js @@ -0,0 +1,8 @@ +export var dotDocs = { + name: 'dot', + category: 'Matrix', + syntax: ['dot(A, B)', 'A * B'], + description: 'Calculate the dot product of two vectors. ' + 'The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] ' + 'is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn', + examples: ['dot([2, 4, 1], [2, 2, 3])', '[2, 4, 1] * [2, 2, 3]'], + seealso: ['multiply', 'cross'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/eigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/eigs.js new file mode 100644 index 0000000..56bfea9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/eigs.js @@ -0,0 +1,8 @@ +export var eigsDocs = { + name: 'eigs', + category: 'Matrix', + syntax: ['eigs(x)'], + description: 'Calculate the eigenvalues and optionally eigenvectors of a square matrix', + examples: ['eigs([[5, 2.3], [2.3, 1]])', 'eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })'], + seealso: ['inv'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/fft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/fft.js new file mode 100644 index 0000000..6a372a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/fft.js @@ -0,0 +1,8 @@ +export var fftDocs = { + name: 'fft', + category: 'Matrix', + syntax: ['fft(x)'], + description: 'Calculate N-dimensional Fourier transform', + examples: ['fft([[1, 0], [1, 0]])'], + seealso: ['ifft'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/filter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/filter.js new file mode 100644 index 0000000..01658cd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/filter.js @@ -0,0 +1,8 @@ +export var filterDocs = { + name: 'filter', + category: 'Matrix', + syntax: ['filter(x, test)'], + description: 'Filter items in a matrix.', + examples: ['isPositive(x) = x > 0', 'filter([6, -2, -1, 4, 3], isPositive)', 'filter([6, -2, 0, 1, 0], x != 0)'], + seealso: ['sort', 'map', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/flatten.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/flatten.js new file mode 100644 index 0000000..02660a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/flatten.js @@ -0,0 +1,8 @@ +export var flattenDocs = { + name: 'flatten', + category: 'Matrix', + syntax: ['flatten(x)'], + description: 'Flatten a multi dimensional matrix into a single dimensional matrix.', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'size(a)', 'b = flatten(a)', 'size(b)'], + seealso: ['concat', 'resize', 'size', 'squeeze'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/forEach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/forEach.js new file mode 100644 index 0000000..11f11dc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/forEach.js @@ -0,0 +1,8 @@ +export var forEachDocs = { + name: 'forEach', + category: 'Matrix', + syntax: ['forEach(x, callback)'], + description: 'Iterates over all elements of a matrix/array, and executes the given callback function.', + examples: ['numberOfPets = {}', 'addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;', 'forEach(["Dog","Cat","Cat"], addPet)', 'numberOfPets'], + seealso: ['map', 'sort', 'filter'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/getMatrixDataType.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/getMatrixDataType.js new file mode 100644 index 0000000..cc1daa2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/getMatrixDataType.js @@ -0,0 +1,8 @@ +export var getMatrixDataTypeDocs = { + name: 'getMatrixDataType', + category: 'Matrix', + syntax: ['getMatrixDataType(x)'], + description: 'Find the data type of all elements in a matrix or array, ' + 'for example "number" if all items are a number ' + 'and "Complex" if all values are complex numbers. ' + 'If a matrix contains more than one data type, it will return "mixed".', + examples: ['getMatrixDataType([1, 2, 3])', 'getMatrixDataType([[5 cm], [2 inch]])', 'getMatrixDataType([1, "text"])', 'getMatrixDataType([1, bignumber(4)])'], + seealso: ['matrix', 'sparse', 'typeOf'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/identity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/identity.js new file mode 100644 index 0000000..c3d717e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/identity.js @@ -0,0 +1,8 @@ +export var identityDocs = { + name: 'identity', + category: 'Matrix', + syntax: ['identity(n)', 'identity(m, n)', 'identity([m, n])'], + description: 'Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.', + examples: ['identity(3)', 'identity(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'identity(size(a))'], + seealso: ['concat', 'det', 'diag', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ifft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ifft.js new file mode 100644 index 0000000..99b6ce8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ifft.js @@ -0,0 +1,8 @@ +export var ifftDocs = { + name: 'ifft', + category: 'Matrix', + syntax: ['ifft(x)'], + description: 'Calculate N-dimensional inverse Fourier transform', + examples: ['ifft([[2, 2], [0, 0]])'], + seealso: ['fft'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/inv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/inv.js new file mode 100644 index 0000000..db48c64 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/inv.js @@ -0,0 +1,8 @@ +export var invDocs = { + name: 'inv', + category: 'Matrix', + syntax: ['inv(x)'], + description: 'Calculate the inverse of a matrix', + examples: ['inv([1, 2; 3, 4])', 'inv(4)', '1 / 4'], + seealso: ['concat', 'det', 'diag', 'identity', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/kron.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/kron.js new file mode 100644 index 0000000..9d655ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/kron.js @@ -0,0 +1,8 @@ +export var kronDocs = { + name: 'kron', + category: 'Matrix', + syntax: ['kron(x, y)'], + description: 'Calculates the Kronecker product of 2 matrices or vectors.', + examples: ['kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])', 'kron([1,1], [2,3,4])'], + seealso: ['multiply', 'dot', 'cross'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/map.js new file mode 100644 index 0000000..711294e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/map.js @@ -0,0 +1,8 @@ +export var mapDocs = { + name: 'map', + category: 'Matrix', + syntax: ['map(x, callback)', 'map(x, y, ..., callback)'], + description: 'Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array or the matrices/arrays.', + examples: ['map([1, 2, 3], square)', 'map([1, 2], [3, 4], f(a,b) = a + b)'], + seealso: ['filter', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromColumns.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromColumns.js new file mode 100644 index 0000000..7d9a8e4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromColumns.js @@ -0,0 +1,8 @@ +export var matrixFromColumnsDocs = { + name: 'matrixFromColumns', + category: 'Matrix', + syntax: ['matrixFromColumns(...arr)', 'matrixFromColumns(row1, row2)', 'matrixFromColumns(row1, row2, row3)'], + description: 'Create a dense matrix from vectors as individual columns.', + examples: ['matrixFromColumns([1, 2, 3], [[4],[5],[6]])'], + seealso: ['matrix', 'matrixFromRows', 'matrixFromFunction', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromFunction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromFunction.js new file mode 100644 index 0000000..b872299 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromFunction.js @@ -0,0 +1,8 @@ +export var matrixFromFunctionDocs = { + name: 'matrixFromFunction', + category: 'Matrix', + syntax: ['matrixFromFunction(size, fn)', 'matrixFromFunction(size, fn, format)', 'matrixFromFunction(size, fn, format, datatype)', 'matrixFromFunction(size, format, fn)', 'matrixFromFunction(size, format, datatype, fn)'], + description: 'Create a matrix by evaluating a generating function at each index.', + examples: ['f(I) = I[1] - I[2]', 'matrixFromFunction([3,3], f)', 'g(I) = I[1] - I[2] == 1 ? 4 : 0', 'matrixFromFunction([100, 100], "sparse", g)', 'matrixFromFunction([5], random)'], + seealso: ['matrix', 'matrixFromRows', 'matrixFromColumns', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromRows.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromRows.js new file mode 100644 index 0000000..2ffdb7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/matrixFromRows.js @@ -0,0 +1,8 @@ +export var matrixFromRowsDocs = { + name: 'matrixFromRows', + category: 'Matrix', + syntax: ['matrixFromRows(...arr)', 'matrixFromRows(row1, row2)', 'matrixFromRows(row1, row2, row3)'], + description: 'Create a dense matrix from vectors as individual rows.', + examples: ['matrixFromRows([1, 2, 3], [[4],[5],[6]])'], + seealso: ['matrix', 'matrixFromColumns', 'matrixFromFunction', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ones.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ones.js new file mode 100644 index 0000000..793db0e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/ones.js @@ -0,0 +1,8 @@ +export var onesDocs = { + name: 'ones', + category: 'Matrix', + syntax: ['ones(m)', 'ones(m, n)', 'ones(m, n, p, ...)', 'ones([m])', 'ones([m, n])', 'ones([m, n, p, ...])'], + description: 'Create a matrix containing ones.', + examples: ['ones(3)', 'ones(3, 5)', 'ones([2,3]) * 4.5', 'a = [1, 2, 3; 4, 5, 6]', 'ones(size(a))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/partitionSelect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/partitionSelect.js new file mode 100644 index 0000000..b896b3f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/partitionSelect.js @@ -0,0 +1,8 @@ +export var partitionSelectDocs = { + name: 'partitionSelect', + category: 'Matrix', + syntax: ['partitionSelect(x, k)', 'partitionSelect(x, k, compare)'], + description: 'Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.', + examples: ['partitionSelect([5, 10, 1], 2)', 'partitionSelect(["C", "B", "A", "D"], 1, compareText)', 'arr = [5, 2, 1]', 'partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]', 'arr', 'partitionSelect(arr, 1, \'desc\') # returns 2, arr is now: [5, 2, 1]', 'arr'], + seealso: ['sort'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/pinv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/pinv.js new file mode 100644 index 0000000..93a7a43 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/pinv.js @@ -0,0 +1,8 @@ +export var pinvDocs = { + name: 'pinv', + category: 'Matrix', + syntax: ['pinv(x)'], + description: 'Calculate the Moore–Penrose inverse of a matrix', + examples: ['pinv([1, 2; 3, 4])', 'pinv([[1, 0], [0, 1], [0, 1]])', 'pinv(4)'], + seealso: ['inv'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/range.js new file mode 100644 index 0000000..d059efc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/range.js @@ -0,0 +1,8 @@ +export var rangeDocs = { + name: 'range', + category: 'Type', + syntax: ['start:end', 'start:step:end', 'range(start, end)', 'range(start, end, step)', 'range(string)'], + description: 'Create a range. Lower bound of the range is included, upper bound is excluded.', + examples: ['1:5', '3:-1:-3', 'range(3, 7)', 'range(0, 12, 2)', 'range("4:10")', 'range(1m, 1m, 3m)', 'a = [1, 2, 3, 4; 5, 6, 7, 8]', 'a[1:2, 1:2]'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/reshape.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/reshape.js new file mode 100644 index 0000000..4a7e1da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/reshape.js @@ -0,0 +1,8 @@ +export var reshapeDocs = { + name: 'reshape', + category: 'Matrix', + syntax: ['reshape(x, sizes)'], + description: 'Reshape a multi dimensional array to fit the specified dimensions.', + examples: ['reshape([1, 2, 3, 4, 5, 6], [2, 3])', 'reshape([[1, 2], [3, 4]], [1, 4])', 'reshape([[1, 2], [3, 4]], [4])', 'reshape([1, 2, 3, 4], [-1, 2])'], + seealso: ['size', 'squeeze', 'resize'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/resize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/resize.js new file mode 100644 index 0000000..8ff141a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/resize.js @@ -0,0 +1,8 @@ +export var resizeDocs = { + name: 'resize', + category: 'Matrix', + syntax: ['resize(x, size)', 'resize(x, size, defaultValue)'], + description: 'Resize a matrix.', + examples: ['resize([1,2,3,4,5], [3])', 'resize([1,2,3], [5])', 'resize([1,2,3], [5], -1)', 'resize(2, [2, 3])', 'resize("hello", [8], "!")'], + seealso: ['size', 'subset', 'squeeze', 'reshape'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotate.js new file mode 100644 index 0000000..8d45123 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotate.js @@ -0,0 +1,8 @@ +export var rotateDocs = { + name: 'rotate', + category: 'Matrix', + syntax: ['rotate(w, theta)', 'rotate(w, theta, v)'], + description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.', + examples: ['rotate([1, 0], pi / 2)', 'rotate(matrix([1, 0]), unit("35deg"))', 'rotate([1, 0, 0], unit("90deg"), [0, 0, 1])', 'rotate(matrix([1, 0, 0]), unit("90deg"), matrix([0, 0, 1]))'], + seealso: ['matrix', 'rotationMatrix'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotationMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotationMatrix.js new file mode 100644 index 0000000..52c553d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/rotationMatrix.js @@ -0,0 +1,8 @@ +export var rotationMatrixDocs = { + name: 'rotationMatrix', + category: 'Matrix', + syntax: ['rotationMatrix(theta)', 'rotationMatrix(theta, v)', 'rotationMatrix(theta, v, format)'], + description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.', + examples: ['rotationMatrix(pi / 2)', 'rotationMatrix(unit("45deg"), [0, 0, 1])', 'rotationMatrix(1, matrix([0, 0, 1]), "sparse")'], + seealso: ['cos', 'sin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/row.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/row.js new file mode 100644 index 0000000..ca6626b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/row.js @@ -0,0 +1,8 @@ +export var rowDocs = { + name: 'row', + category: 'Matrix', + syntax: ['row(x, index)'], + description: 'Return a row from a matrix or array.', + examples: ['A = [[1, 2], [3, 4]]', 'row(A, 1)', 'row(A, 2)'], + seealso: ['column', 'matrixFromRows'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/size.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/size.js new file mode 100644 index 0000000..a93282e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/size.js @@ -0,0 +1,8 @@ +export var sizeDocs = { + name: 'size', + category: 'Matrix', + syntax: ['size(x)'], + description: 'Calculate the size of a matrix.', + examples: ['size(2.3)', 'size("hello world")', 'a = [1, 2; 3, 4; 5, 6]', 'size(a)', 'size(1:6)'], + seealso: ['concat', 'count', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/sort.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/sort.js new file mode 100644 index 0000000..5f21063 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/sort.js @@ -0,0 +1,8 @@ +export var sortDocs = { + name: 'sort', + category: 'Matrix', + syntax: ['sort(x)', 'sort(x, compare)'], + description: 'Sort the items in a matrix. Compare can be a string "asc", "desc", "natural", or a custom sort function.', + examples: ['sort([5, 10, 1])', 'sort(["C", "B", "A", "D"], "natural")', 'sortByLength(a, b) = size(a)[1] - size(b)[1]', 'sort(["Langdon", "Tom", "Sara"], sortByLength)', 'sort(["10", "1", "2"], "natural")'], + seealso: ['map', 'filter', 'forEach'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/squeeze.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/squeeze.js new file mode 100644 index 0000000..bd699fe --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/squeeze.js @@ -0,0 +1,8 @@ +export var squeezeDocs = { + name: 'squeeze', + category: 'Matrix', + syntax: ['squeeze(x)'], + description: 'Remove inner and outer singleton dimensions from a matrix.', + examples: ['a = zeros(3,2,1)', 'size(squeeze(a))', 'b = zeros(1,1,3)', 'size(squeeze(b))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'subset', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/subset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/subset.js new file mode 100644 index 0000000..9c3907e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/subset.js @@ -0,0 +1,8 @@ +export var subsetDocs = { + name: 'subset', + category: 'Matrix', + syntax: ['value(index)', 'value(index) = replacement', 'subset(value, [index])', 'subset(value, [index], replacement)'], + description: 'Get or set a subset of the entries of a matrix or ' + 'characters of a string. ' + 'Indexes are one-based. There should be one index specification for ' + 'each dimension of the target. Each specification can be a single ' + 'index, a list of indices, or a range in colon notation `l:u`. ' + 'In a range, both the lower bound l and upper bound u are included; ' + 'and if a bound is omitted it defaults to the most extreme valid value. ' + 'The cartesian product of the indices specified in each dimension ' + 'determines the target of the operation.', + examples: ['d = [1, 2; 3, 4]', 'e = []', 'e[1, 1:2] = [5, 6]', 'e[2, :] = [7, 8]', 'f = d * e', 'f[2, 1]', 'f[:, 1]', 'f[[1,2], [1,3]] = [9, 10; 11, 12]', 'f'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'trace', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/trace.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/trace.js new file mode 100644 index 0000000..863f7f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/trace.js @@ -0,0 +1,8 @@ +export var traceDocs = { + name: 'trace', + category: 'Matrix', + syntax: ['trace(A)'], + description: 'Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.', + examples: ['A = [1, 2, 3; -1, 2, 3; 2, 0, 3]', 'trace(A)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'transpose', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/transpose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/transpose.js new file mode 100644 index 0000000..a565ec5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/transpose.js @@ -0,0 +1,8 @@ +export var transposeDocs = { + name: 'transpose', + category: 'Matrix', + syntax: ['x\'', 'transpose(x)'], + description: 'Transpose a matrix', + examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\'', 'transpose(a)'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/zeros.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/zeros.js new file mode 100644 index 0000000..c6bbeb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/matrix/zeros.js @@ -0,0 +1,8 @@ +export var zerosDocs = { + name: 'zeros', + category: 'Matrix', + syntax: ['zeros(m)', 'zeros(m, n)', 'zeros(m, n, p, ...)', 'zeros([m])', 'zeros([m, n])', 'zeros([m, n, p, ...])'], + description: 'Create a matrix containing zeros.', + examples: ['zeros(3)', 'zeros(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'zeros(size(a))'], + seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/numeric/solveODE.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/numeric/solveODE.js new file mode 100644 index 0000000..412cac9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/numeric/solveODE.js @@ -0,0 +1,8 @@ +export var solveODEDocs = { + name: 'solveODE', + category: 'Numeric', + syntax: ['solveODE(func, tspan, y0)', 'solveODE(func, tspan, y0, options)'], + description: 'Numerical Integration of Ordinary Differential Equations.', + examples: ['f(t,y) = y', 'tspan = [0, 4]', 'solveODE(f, tspan, 1)', 'solveODE(f, tspan, [1, 2])', 'solveODE(f, tspan, 1, { method:"RK23", maxStep:0.1 })'], + seealso: ['derivative', 'simplifyCore'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinations.js new file mode 100644 index 0000000..e9d3396 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinations.js @@ -0,0 +1,8 @@ +export var combinationsDocs = { + name: 'combinations', + category: 'Probability', + syntax: ['combinations(n, k)'], + description: 'Compute the number of combinations of n items taken k at a time', + examples: ['combinations(7, 5)'], + seealso: ['combinationsWithRep', 'permutations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinationsWithRep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinationsWithRep.js new file mode 100644 index 0000000..1938bf8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/combinationsWithRep.js @@ -0,0 +1,8 @@ +export var combinationsWithRepDocs = { + name: 'combinationsWithRep', + category: 'Probability', + syntax: ['combinationsWithRep(n, k)'], + description: 'Compute the number of combinations of n items taken k at a time with replacements.', + examples: ['combinationsWithRep(7, 5)'], + seealso: ['combinations', 'permutations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/distribution.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/distribution.js new file mode 100644 index 0000000..fce3ffb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/distribution.js @@ -0,0 +1,8 @@ +export var distributionDocs = { + name: 'distribution', + category: 'Probability', + syntax: ['distribution(name)', 'distribution(name, arg1, arg2, ...)'], + description: 'Create a distribution object of a specific type. ' + 'A distribution object contains functions `random([size,] [min,] [max])`, ' + '`randomInt([size,] [min,] [max])` and `pickRandom(array)`. ' + 'Available types of distributions: "uniform", "normal". ' + 'Note that the function distribution is currently not available via the expression parser.', + examples: [], + seealso: ['random', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/factorial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/factorial.js new file mode 100644 index 0000000..a3086a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/factorial.js @@ -0,0 +1,8 @@ +export var factorialDocs = { + name: 'factorial', + category: 'Probability', + syntax: ['n!', 'factorial(n)'], + description: 'Compute the factorial of a value', + examples: ['5!', '5 * 4 * 3 * 2 * 1', '3!'], + seealso: ['combinations', 'combinationsWithRep', 'permutations', 'gamma'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/gamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/gamma.js new file mode 100644 index 0000000..a5101a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/gamma.js @@ -0,0 +1,8 @@ +export var gammaDocs = { + name: 'gamma', + category: 'Probability', + syntax: ['gamma(n)'], + description: 'Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.', + examples: ['gamma(4)', '3!', 'gamma(1/2)', 'sqrt(pi)'], + seealso: ['factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/kldivergence.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/kldivergence.js new file mode 100644 index 0000000..f9e967a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/kldivergence.js @@ -0,0 +1,8 @@ +export var kldivergenceDocs = { + name: 'kldivergence', + category: 'Probability', + syntax: ['kldivergence(x, y)'], + description: 'Calculate the Kullback-Leibler (KL) divergence between two distributions.', + examples: ['kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/lgamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/lgamma.js new file mode 100644 index 0000000..0c9c7ca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/lgamma.js @@ -0,0 +1,8 @@ +export var lgammaDocs = { + name: 'lgamma', + category: 'Probability', + syntax: ['lgamma(n)'], + description: 'Logarithm of the gamma function for real, positive numbers and complex numbers, ' + 'using Lanczos approximation for numbers and Stirling series for complex numbers.', + examples: ['lgamma(4)', 'lgamma(1/2)', 'lgamma(i)', 'lgamma(complex(1.1, 2))'], + seealso: ['gamma'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/multinomial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/multinomial.js new file mode 100644 index 0000000..d32e1f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/multinomial.js @@ -0,0 +1,8 @@ +export var multinomialDocs = { + name: 'multinomial', + category: 'Probability', + syntax: ['multinomial(A)'], + description: 'Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. multinomial takes one array of integers as an argument. The following condition must be enforced: every ai > 0.', + examples: ['multinomial([1, 2, 1])'], + seealso: ['combinations', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/permutations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/permutations.js new file mode 100644 index 0000000..f955d24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/permutations.js @@ -0,0 +1,8 @@ +export var permutationsDocs = { + name: 'permutations', + category: 'Probability', + syntax: ['permutations(n)', 'permutations(n, k)'], + description: 'Compute the number of permutations of n items taken k at a time', + examples: ['permutations(5)', 'permutations(5, 3)'], + seealso: ['combinations', 'combinationsWithRep', 'factorial'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/pickRandom.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/pickRandom.js new file mode 100644 index 0000000..4acf5dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/pickRandom.js @@ -0,0 +1,8 @@ +export var pickRandomDocs = { + name: 'pickRandom', + category: 'Probability', + syntax: ['pickRandom(array)', 'pickRandom(array, number)', 'pickRandom(array, weights)', 'pickRandom(array, number, weights)', 'pickRandom(array, weights, number)'], + description: 'Pick a random entry from a given array.', + examples: ['pickRandom(0:10)', 'pickRandom([1, 3, 1, 6])', 'pickRandom([1, 3, 1, 6], 2)', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)'], + seealso: ['random', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/random.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/random.js new file mode 100644 index 0000000..69d6711 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/random.js @@ -0,0 +1,8 @@ +export var randomDocs = { + name: 'random', + category: 'Probability', + syntax: ['random()', 'random(max)', 'random(min, max)', 'random(size)', 'random(size, max)', 'random(size, min, max)'], + description: 'Return a random number.', + examples: ['random()', 'random(10, 20)', 'random([2, 3])'], + seealso: ['pickRandom', 'randomInt'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/randomInt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/randomInt.js new file mode 100644 index 0000000..6518fc3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/probability/randomInt.js @@ -0,0 +1,8 @@ +export var randomIntDocs = { + name: 'randomInt', + category: 'Probability', + syntax: ['randomInt(max)', 'randomInt(min, max)', 'randomInt(size)', 'randomInt(size, max)', 'randomInt(size, min, max)'], + description: 'Return a random integer number', + examples: ['randomInt(10, 20)', 'randomInt([2, 3], 10)'], + seealso: ['pickRandom', 'random'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compare.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compare.js new file mode 100644 index 0000000..17361a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compare.js @@ -0,0 +1,8 @@ +export var compareDocs = { + name: 'compare', + category: 'Relational', + syntax: ['compare(x, y)'], + description: 'Compare two values. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compare(2, 3)', 'compare(3, 2)', 'compare(2, 2)', 'compare(5cm, 40mm)', 'compare(2, [1, 2, 3])'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compareNatural', 'compareText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareNatural.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareNatural.js new file mode 100644 index 0000000..c4202df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareNatural.js @@ -0,0 +1,8 @@ +export var compareNaturalDocs = { + name: 'compareNatural', + category: 'Relational', + syntax: ['compareNatural(x, y)'], + description: 'Compare two values of any type in a deterministic, natural way. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compareNatural(2, 3)', 'compareNatural(3, 2)', 'compareNatural(2, 2)', 'compareNatural(5cm, 40mm)', 'compareNatural("2", "10")', 'compareNatural(2 + 3i, 2 + 4i)', 'compareNatural([1, 2, 4], [1, 2, 3])', 'compareNatural([1, 5], [1, 2, 3])', 'compareNatural([1, 2], [1, 2])', 'compareNatural({a: 2}, {a: 4})'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare', 'compareText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareText.js new file mode 100644 index 0000000..7225760 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/compareText.js @@ -0,0 +1,8 @@ +export var compareTextDocs = { + name: 'compareText', + category: 'Relational', + syntax: ['compareText(x, y)'], + description: 'Compare two strings lexically. Comparison is case sensitive. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.', + examples: ['compareText("B", "A")', 'compareText("A", "B")', 'compareText("A", "A")', 'compareText("2", "10")', 'compare("2", "10")', 'compare(2, 10)', 'compareNatural("2", "10")', 'compareText("B", ["A", "B", "C"])'], + seealso: ['compare', 'compareNatural'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/deepEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/deepEqual.js new file mode 100644 index 0000000..7332e8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/deepEqual.js @@ -0,0 +1,8 @@ +export var deepEqualDocs = { + name: 'deepEqual', + category: 'Relational', + syntax: ['deepEqual(x, y)'], + description: 'Check equality of two matrices element wise. Returns true if the size of both matrices is equal and when and each of the elements are equal.', + examples: ['deepEqual([1,3,4], [1,3,4])', 'deepEqual([1,3,4], [1,3])'], + seealso: ['equal', 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equal.js new file mode 100644 index 0000000..e0c956d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equal.js @@ -0,0 +1,8 @@ +export var equalDocs = { + name: 'equal', + category: 'Relational', + syntax: ['x == y', 'equal(x, y)'], + description: 'Check equality of two values. Returns true if the values are equal, and false if not.', + examples: ['2+2 == 3', '2+2 == 4', 'a = 3.2', 'b = 6-2.8', 'a == b', '50cm == 0.5m'], + seealso: ['unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual', 'equalText'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equalText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equalText.js new file mode 100644 index 0000000..f02230e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/equalText.js @@ -0,0 +1,8 @@ +export var equalTextDocs = { + name: 'equalText', + category: 'Relational', + syntax: ['equalText(x, y)'], + description: 'Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.', + examples: ['equalText("Hello", "Hello")', 'equalText("a", "A")', 'equal("2e3", "2000")', 'equalText("2e3", "2000")', 'equalText("B", ["A", "B", "C"])'], + seealso: ['compare', 'compareNatural', 'compareText', 'equal'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/larger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/larger.js new file mode 100644 index 0000000..355fcb7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/larger.js @@ -0,0 +1,8 @@ +export var largerDocs = { + name: 'larger', + category: 'Relational', + syntax: ['x > y', 'larger(x, y)'], + description: 'Check if value x is larger than y. Returns true if x is larger than y, and false if not.', + examples: ['2 > 3', '5 > 2*2', 'a = 3.3', 'b = 6-2.8', '(a > b)', '(b < a)', '5 cm > 2 inch'], + seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/largerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/largerEq.js new file mode 100644 index 0000000..22fc8e2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/largerEq.js @@ -0,0 +1,8 @@ +export var largerEqDocs = { + name: 'largerEq', + category: 'Relational', + syntax: ['x >= y', 'largerEq(x, y)'], + description: 'Check if value x is larger or equal to y. Returns true if x is larger or equal to y, and false if not.', + examples: ['2 >= 1+1', '2 > 1+1', 'a = 3.2', 'b = 6-2.8', '(a >= b)'], + seealso: ['equal', 'unequal', 'smallerEq', 'smaller', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smaller.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smaller.js new file mode 100644 index 0000000..7776324 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smaller.js @@ -0,0 +1,8 @@ +export var smallerDocs = { + name: 'smaller', + category: 'Relational', + syntax: ['x < y', 'smaller(x, y)'], + description: 'Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.', + examples: ['2 < 3', '5 < 2*2', 'a = 3.3', 'b = 6-2.8', '(a < b)', '5 cm < 2 inch'], + seealso: ['equal', 'unequal', 'larger', 'smallerEq', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smallerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smallerEq.js new file mode 100644 index 0000000..c0a7b0a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/smallerEq.js @@ -0,0 +1,8 @@ +export var smallerEqDocs = { + name: 'smallerEq', + category: 'Relational', + syntax: ['x <= y', 'smallerEq(x, y)'], + description: 'Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.', + examples: ['2 <= 1+1', '2 < 1+1', 'a = 3.2', 'b = 6-2.8', '(a <= b)'], + seealso: ['equal', 'unequal', 'larger', 'smaller', 'largerEq', 'compare'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/unequal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/unequal.js new file mode 100644 index 0000000..df7b95b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/relational/unequal.js @@ -0,0 +1,8 @@ +export var unequalDocs = { + name: 'unequal', + category: 'Relational', + syntax: ['x != y', 'unequal(x, y)'], + description: 'Check unequality of two values. Returns true if the values are unequal, and false if they are equal.', + examples: ['2+2 != 3', '2+2 != 4', 'a = 3.2', 'b = 6-2.8', 'a != b', '50cm != 0.5m', '5 cm != 2 inch'], + seealso: ['equal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setCartesian.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setCartesian.js new file mode 100644 index 0000000..2c80f7b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setCartesian.js @@ -0,0 +1,8 @@ +export var setCartesianDocs = { + name: 'setCartesian', + category: 'Set', + syntax: ['setCartesian(set1, set2)'], + description: 'Create the cartesian product of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays and the values will be sorted in ascending order before the operation.', + examples: ['setCartesian([1, 2], [3, 4])'], + seealso: ['setUnion', 'setIntersect', 'setDifference', 'setPowerset'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDifference.js new file mode 100644 index 0000000..844f47b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDifference.js @@ -0,0 +1,8 @@ +export var setDifferenceDocs = { + name: 'setDifference', + category: 'Set', + syntax: ['setDifference(set1, set2)'], + description: 'Create the difference of two (multi)sets: every element of set1, that is not the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setIntersect', 'setSymDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDistinct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDistinct.js new file mode 100644 index 0000000..50d839e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setDistinct.js @@ -0,0 +1,8 @@ +export var setDistinctDocs = { + name: 'setDistinct', + category: 'Set', + syntax: ['setDistinct(set)'], + description: 'Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setDistinct([1, 1, 1, 2, 2, 3])'], + seealso: ['setMultiplicity'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIntersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIntersect.js new file mode 100644 index 0000000..b8dd9eb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIntersect.js @@ -0,0 +1,8 @@ +export var setIntersectDocs = { + name: 'setIntersect', + category: 'Set', + syntax: ['setIntersect(set1, set2)'], + description: 'Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setIntersect([1, 2, 3, 4], [3, 4, 5, 6])', 'setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIsSubset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIsSubset.js new file mode 100644 index 0000000..095c83f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setIsSubset.js @@ -0,0 +1,8 @@ +export var setIsSubsetDocs = { + name: 'setIsSubset', + category: 'Set', + syntax: ['setIsSubset(set1, set2)'], + description: 'Check whether a (multi)set is a subset of another (multi)set: every element of set1 is the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setIsSubset([1, 2], [3, 4, 5, 6])', 'setIsSubset([3, 4], [3, 4, 5, 6])'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setMultiplicity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setMultiplicity.js new file mode 100644 index 0000000..8ad1670 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setMultiplicity.js @@ -0,0 +1,8 @@ +export var setMultiplicityDocs = { + name: 'setMultiplicity', + category: 'Set', + syntax: ['setMultiplicity(element, set)'], + description: 'Count the multiplicity of an element in a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setMultiplicity(1, [1, 2, 2, 4])', 'setMultiplicity(2, [1, 2, 2, 4])'], + seealso: ['setDistinct', 'setSize'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setPowerset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setPowerset.js new file mode 100644 index 0000000..b868e6e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setPowerset.js @@ -0,0 +1,8 @@ +export var setPowersetDocs = { + name: 'setPowerset', + category: 'Set', + syntax: ['setPowerset(set)'], + description: 'Create the powerset of a (multi)set: the powerset contains very possible subsets of a (multi)set. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setPowerset([1, 2, 3])'], + seealso: ['setCartesian'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSize.js new file mode 100644 index 0000000..dbeff60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSize.js @@ -0,0 +1,8 @@ +export var setSizeDocs = { + name: 'setSize', + category: 'Set', + syntax: ['setSize(set)', 'setSize(set, unique)'], + description: 'Count the number of elements of a (multi)set. When the second parameter "unique" is true, count only the unique values. A multi-dimension array will be converted to a single-dimension array before the operation.', + examples: ['setSize([1, 2, 2, 4])', 'setSize([1, 2, 2, 4], true)'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSymDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSymDifference.js new file mode 100644 index 0000000..f3bdcd6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setSymDifference.js @@ -0,0 +1,8 @@ +export var setSymDifferenceDocs = { + name: 'setSymDifference', + category: 'Set', + syntax: ['setSymDifference(set1, set2)'], + description: 'Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setUnion', 'setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setUnion.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setUnion.js new file mode 100644 index 0000000..fadee5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/set/setUnion.js @@ -0,0 +1,8 @@ +export var setUnionDocs = { + name: 'setUnion', + category: 'Set', + syntax: ['setUnion(set1, set2)'], + description: 'Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.', + examples: ['setUnion([1, 2, 3, 4], [3, 4, 5, 6])', 'setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])'], + seealso: ['setIntersect', 'setDifference'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/freqz.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/freqz.js new file mode 100644 index 0000000..f175874 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/freqz.js @@ -0,0 +1,8 @@ +export var freqzDocs = { + name: 'freqz', + category: 'Signal', + syntax: ['freqz(b, a)', 'freqz(b, a, w)'], + description: 'Calculates the frequency response of a filter given its numerator and denominator coefficients.', + examples: ['freqz([1, 2], [1, 2, 3])', 'freqz([1, 2], [1, 2, 3], [0, 1])', 'freqz([1, 2], [1, 2, 3], 512)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/zpk2tf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/zpk2tf.js new file mode 100644 index 0000000..7d39325 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/signal/zpk2tf.js @@ -0,0 +1,8 @@ +export var zpk2tfDocs = { + name: 'zpk2tf', + category: 'Signal', + syntax: ['zpk2tf(z, p, k)'], + description: 'Compute the transfer function of a zero-pole-gain model.', + examples: ['zpk2tf([1, 2], [-1, -2], 1)', 'zpk2tf([1, 2], [-1, -2])', 'zpk2tf([1 - 3i, 2 + 2i], [-1, -2])'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/erf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/erf.js new file mode 100644 index 0000000..2a2f63b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/erf.js @@ -0,0 +1,8 @@ +export var erfDocs = { + name: 'erf', + category: 'Special', + syntax: ['erf(x)'], + description: 'Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x', + examples: ['erf(0.2)', 'erf(-0.5)', 'erf(4)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/zeta.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/zeta.js new file mode 100644 index 0000000..fd0d020 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/special/zeta.js @@ -0,0 +1,8 @@ +export var zetaDocs = { + name: 'zeta', + category: 'Special', + syntax: ['zeta(s)'], + description: 'Compute the Riemann Zeta Function using an infinite series and Riemann\'s Functional Equation for the entire complex plane', + examples: ['zeta(0.2)', 'zeta(-0.5)', 'zeta(4)'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/corr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/corr.js new file mode 100644 index 0000000..9509463 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/corr.js @@ -0,0 +1,8 @@ +export var corrDocs = { + name: 'corr', + category: 'Statistics', + syntax: ['corr(A,B)'], + description: 'Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.', + examples: ['corr([2, 4, 6, 8],[1, 2, 3, 6])', 'corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'prod', 'std', 'sum'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/cumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/cumsum.js new file mode 100644 index 0000000..18c3556 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/cumsum.js @@ -0,0 +1,8 @@ +export var cumSumDocs = { + name: 'cumsum', + category: 'Statistics', + syntax: ['cumsum(a, b, c, ...)', 'cumsum(A)'], + description: 'Compute the cumulative sum of all values.', + examples: ['cumsum(2, 3, 4, 1)', 'cumsum([2, 3, 4, 1])', 'cumsum([1, 2; 3, 4])', 'cumsum([1, 2; 3, 4], 1)', 'cumsum([1, 2; 3, 4], 2)'], + seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mad.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mad.js new file mode 100644 index 0000000..3ad0341 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mad.js @@ -0,0 +1,8 @@ +export var madDocs = { + name: 'mad', + category: 'Statistics', + syntax: ['mad(a, b, c, ...)', 'mad(A)'], + description: 'Compute the median absolute deviation of a matrix or a list with values. The median absolute deviation is defined as the median of the absolute deviations from the median.', + examples: ['mad(10, 20, 30)', 'mad([1, 2, 3])'], + seealso: ['mean', 'median', 'std', 'abs'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/max.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/max.js new file mode 100644 index 0000000..502d572 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/max.js @@ -0,0 +1,8 @@ +export var maxDocs = { + name: 'max', + category: 'Statistics', + syntax: ['max(a, b, c, ...)', 'max(A)', 'max(A, dimension)'], + description: 'Compute the maximum value of a list of values.', + examples: ['max(2, 3, 4, 1)', 'max([2, 3, 4, 1])', 'max([2, 5; 4, 3])', 'max([2, 5; 4, 3], 1)', 'max([2, 5; 4, 3], 2)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)'], + seealso: ['mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mean.js new file mode 100644 index 0000000..3ae39f4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mean.js @@ -0,0 +1,8 @@ +export var meanDocs = { + name: 'mean', + category: 'Statistics', + syntax: ['mean(a, b, c, ...)', 'mean(A)', 'mean(A, dimension)'], + description: 'Compute the arithmetic mean of a list of values.', + examples: ['mean(2, 3, 4, 1)', 'mean([2, 3, 4, 1])', 'mean([2, 5; 4, 3])', 'mean([2, 5; 4, 3], 1)', 'mean([2, 5; 4, 3], 2)', 'mean([1.0, 2.7, 3.2, 4.0])'], + seealso: ['max', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/median.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/median.js new file mode 100644 index 0000000..7461756 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/median.js @@ -0,0 +1,8 @@ +export var medianDocs = { + name: 'median', + category: 'Statistics', + syntax: ['median(a, b, c, ...)', 'median(A)'], + description: 'Compute the median of all values. The values are sorted and the middle value is returned. In case of an even number of values, the average of the two middle values is returned.', + examples: ['median(5, 2, 7)', 'median([3, -1, 5, 7])'], + seealso: ['max', 'mean', 'min', 'prod', 'std', 'sum', 'variance', 'quantileSeq'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/min.js new file mode 100644 index 0000000..d7fb06b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/min.js @@ -0,0 +1,8 @@ +export var minDocs = { + name: 'min', + category: 'Statistics', + syntax: ['min(a, b, c, ...)', 'min(A)', 'min(A, dimension)'], + description: 'Compute the minimum value of a list of values.', + examples: ['min(2, 3, 4, 1)', 'min([2, 3, 4, 1])', 'min([2, 5; 4, 3])', 'min([2, 5; 4, 3], 1)', 'min([2, 5; 4, 3], 2)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)'], + seealso: ['max', 'mean', 'median', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mode.js new file mode 100644 index 0000000..e61e57c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/mode.js @@ -0,0 +1,8 @@ +export var modeDocs = { + name: 'mode', + category: 'Statistics', + syntax: ['mode(a, b, c, ...)', 'mode(A)', 'mode(A, a, b, B, c, ...)'], + description: 'Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.', + examples: ['mode(2, 1, 4, 3, 1)', 'mode([1, 2.7, 3.2, 4, 2.7])', 'mode(1, 4, 6, 1, 6)'], + seealso: ['max', 'mean', 'min', 'median', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/prod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/prod.js new file mode 100644 index 0000000..7f86d23 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/prod.js @@ -0,0 +1,8 @@ +export var prodDocs = { + name: 'prod', + category: 'Statistics', + syntax: ['prod(a, b, c, ...)', 'prod(A)'], + description: 'Compute the product of all values.', + examples: ['prod(2, 3, 4)', 'prod([2, 3, 4])', 'prod([2, 5; 4, 3])'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/quantileSeq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/quantileSeq.js new file mode 100644 index 0000000..e95eaac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/quantileSeq.js @@ -0,0 +1,8 @@ +export var quantileSeqDocs = { + name: 'quantileSeq', + category: 'Statistics', + syntax: ['quantileSeq(A, prob[, sorted])', 'quantileSeq(A, [prob1, prob2, ...][, sorted])', 'quantileSeq(A, N[, sorted])'], + description: 'Compute the prob order quantile of a matrix or a list with values. The sequence is sorted and the middle value is returned. Supported types of sequence values are: Number, BigNumber, Unit Supported types of probability are: Number, BigNumber. \n\nIn case of a (multi dimensional) array or matrix, the prob order quantile of all elements will be calculated.', + examples: ['quantileSeq([3, -1, 5, 7], 0.5)', 'quantileSeq([3, -1, 5, 7], [1/3, 2/3])', 'quantileSeq([3, -1, 5, 7], 2)', 'quantileSeq([-1, 3, 5, 7], 0.5, true)'], + seealso: ['mean', 'median', 'min', 'max', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/std.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/std.js new file mode 100644 index 0000000..8149980 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/std.js @@ -0,0 +1,8 @@ +export var stdDocs = { + name: 'std', + category: 'Statistics', + syntax: ['std(a, b, c, ...)', 'std(A)', 'std(A, dimension)', 'std(A, normalization)', 'std(A, dimension, normalization)'], + description: 'Compute the standard deviation of all values, defined as std(A) = sqrt(variance(A)). Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".', + examples: ['std(2, 4, 6)', 'std([2, 4, 6, 8])', 'std([2, 4, 6, 8], "uncorrected")', 'std([2, 4, 6, 8], "biased")', 'std([1, 2, 3; 4, 5, 6])'], + seealso: ['max', 'mean', 'min', 'median', 'prod', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/sum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/sum.js new file mode 100644 index 0000000..b84cc33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/sum.js @@ -0,0 +1,8 @@ +export var sumDocs = { + name: 'sum', + category: 'Statistics', + syntax: ['sum(a, b, c, ...)', 'sum(A)', 'sum(A, dimension)'], + description: 'Compute the sum of all values.', + examples: ['sum(2, 3, 4, 1)', 'sum([2, 3, 4, 1])', 'sum([2, 5; 4, 3])'], + seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/variance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/variance.js new file mode 100644 index 0000000..1158062 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/statistics/variance.js @@ -0,0 +1,8 @@ +export var varianceDocs = { + name: 'variance', + category: 'Statistics', + syntax: ['variance(a, b, c, ...)', 'variance(A)', 'variance(A, dimension)', 'variance(A, normalization)', 'variance(A, dimension, normalization)'], + description: 'Compute the variance of all values. Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".', + examples: ['variance(2, 4, 6)', 'variance([2, 4, 6, 8])', 'variance([2, 4, 6, 8], "uncorrected")', 'variance([2, 4, 6, 8], "biased")', 'variance([1, 2, 3; 4, 5, 6])'], + seealso: ['max', 'mean', 'min', 'median', 'min', 'prod', 'std', 'sum'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acos.js new file mode 100644 index 0000000..f2aafc9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acos.js @@ -0,0 +1,8 @@ +export var acosDocs = { + name: 'acos', + category: 'Trigonometry', + syntax: ['acos(x)'], + description: 'Compute the inverse cosine of a value in radians.', + examples: ['acos(0.5)', 'acos(cos(2.3))'], + seealso: ['cos', 'atan', 'asin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acosh.js new file mode 100644 index 0000000..e8be448 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acosh.js @@ -0,0 +1,8 @@ +export var acoshDocs = { + name: 'acosh', + category: 'Trigonometry', + syntax: ['acosh(x)'], + description: 'Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.', + examples: ['acosh(1.5)'], + seealso: ['cosh', 'asinh', 'atanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acot.js new file mode 100644 index 0000000..96dc7df --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acot.js @@ -0,0 +1,8 @@ +export var acotDocs = { + name: 'acot', + category: 'Trigonometry', + syntax: ['acot(x)'], + description: 'Calculate the inverse cotangent of a value.', + examples: ['acot(0.5)', 'acot(cot(0.5))', 'acot(2)'], + seealso: ['cot', 'atan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acoth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acoth.js new file mode 100644 index 0000000..85d3955 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acoth.js @@ -0,0 +1,8 @@ +export var acothDocs = { + name: 'acoth', + category: 'Trigonometry', + syntax: ['acoth(x)'], + description: 'Calculate the inverse hyperbolic tangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.', + examples: ['acoth(2)', 'acoth(0.5)'], + seealso: ['acsch', 'asech'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsc.js new file mode 100644 index 0000000..9d93a03 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsc.js @@ -0,0 +1,8 @@ +export var acscDocs = { + name: 'acsc', + category: 'Trigonometry', + syntax: ['acsc(x)'], + description: 'Calculate the inverse cotangent of a value.', + examples: ['acsc(2)', 'acsc(csc(0.5))', 'acsc(0.5)'], + seealso: ['csc', 'asin', 'asec'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsch.js new file mode 100644 index 0000000..492b548 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/acsch.js @@ -0,0 +1,8 @@ +export var acschDocs = { + name: 'acsch', + category: 'Trigonometry', + syntax: ['acsch(x)'], + description: 'Calculate the inverse hyperbolic cosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.', + examples: ['acsch(0.5)'], + seealso: ['asech', 'acoth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asec.js new file mode 100644 index 0000000..2b3a0c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asec.js @@ -0,0 +1,8 @@ +export var asecDocs = { + name: 'asec', + category: 'Trigonometry', + syntax: ['asec(x)'], + description: 'Calculate the inverse secant of a value.', + examples: ['asec(0.5)', 'asec(sec(0.5))', 'asec(2)'], + seealso: ['acos', 'acot', 'acsc'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asech.js new file mode 100644 index 0000000..ed223d8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asech.js @@ -0,0 +1,8 @@ +export var asechDocs = { + name: 'asech', + category: 'Trigonometry', + syntax: ['asech(x)'], + description: 'Calculate the inverse secant of a value.', + examples: ['asech(0.5)'], + seealso: ['acsch', 'acoth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asin.js new file mode 100644 index 0000000..4d956e9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asin.js @@ -0,0 +1,8 @@ +export var asinDocs = { + name: 'asin', + category: 'Trigonometry', + syntax: ['asin(x)'], + description: 'Compute the inverse sine of a value in radians.', + examples: ['asin(0.5)', 'asin(sin(0.5))'], + seealso: ['sin', 'acos', 'atan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asinh.js new file mode 100644 index 0000000..ae60da9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/asinh.js @@ -0,0 +1,8 @@ +export var asinhDocs = { + name: 'asinh', + category: 'Trigonometry', + syntax: ['asinh(x)'], + description: 'Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.', + examples: ['asinh(0.5)'], + seealso: ['acosh', 'atanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan.js new file mode 100644 index 0000000..3b94dc6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan.js @@ -0,0 +1,8 @@ +export var atanDocs = { + name: 'atan', + category: 'Trigonometry', + syntax: ['atan(x)'], + description: 'Compute the inverse tangent of a value in radians.', + examples: ['atan(0.5)', 'atan(tan(0.5))'], + seealso: ['tan', 'acos', 'asin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan2.js new file mode 100644 index 0000000..2489919 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atan2.js @@ -0,0 +1,8 @@ +export var atan2Docs = { + name: 'atan2', + category: 'Trigonometry', + syntax: ['atan2(y, x)'], + description: 'Computes the principal value of the arc tangent of y/x in radians.', + examples: ['atan2(2, 2) / pi', 'angle = 60 deg in rad', 'x = cos(angle)', 'y = sin(angle)', 'atan2(y, x)'], + seealso: ['sin', 'cos', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atanh.js new file mode 100644 index 0000000..3065fd7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/atanh.js @@ -0,0 +1,8 @@ +export var atanhDocs = { + name: 'atanh', + category: 'Trigonometry', + syntax: ['atanh(x)'], + description: 'Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.', + examples: ['atanh(0.5)'], + seealso: ['acosh', 'asinh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cos.js new file mode 100644 index 0000000..6fecbbc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cos.js @@ -0,0 +1,8 @@ +export var cosDocs = { + name: 'cos', + category: 'Trigonometry', + syntax: ['cos(x)'], + description: 'Compute the cosine of x in radians.', + examples: ['cos(2)', 'cos(pi / 4) ^ 2', 'cos(180 deg)', 'cos(60 deg)', 'sin(0.2)^2 + cos(0.2)^2'], + seealso: ['acos', 'sin', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cosh.js new file mode 100644 index 0000000..b9b6a81 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cosh.js @@ -0,0 +1,8 @@ +export var coshDocs = { + name: 'cosh', + category: 'Trigonometry', + syntax: ['cosh(x)'], + description: 'Compute the hyperbolic cosine of x in radians.', + examples: ['cosh(0.5)'], + seealso: ['sinh', 'tanh', 'coth'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cot.js new file mode 100644 index 0000000..3b48e1f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/cot.js @@ -0,0 +1,8 @@ +export var cotDocs = { + name: 'cot', + category: 'Trigonometry', + syntax: ['cot(x)'], + description: 'Compute the cotangent of x in radians. Defined as 1/tan(x)', + examples: ['cot(2)', '1 / tan(2)'], + seealso: ['sec', 'csc', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/coth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/coth.js new file mode 100644 index 0000000..605e125 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/coth.js @@ -0,0 +1,8 @@ +export var cothDocs = { + name: 'coth', + category: 'Trigonometry', + syntax: ['coth(x)'], + description: 'Compute the hyperbolic cotangent of x in radians.', + examples: ['coth(2)', '1 / tanh(2)'], + seealso: ['sech', 'csch', 'tanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csc.js new file mode 100644 index 0000000..0ab3e1d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csc.js @@ -0,0 +1,8 @@ +export var cscDocs = { + name: 'csc', + category: 'Trigonometry', + syntax: ['csc(x)'], + description: 'Compute the cosecant of x in radians. Defined as 1/sin(x)', + examples: ['csc(2)', '1 / sin(2)'], + seealso: ['sec', 'cot', 'sin'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csch.js new file mode 100644 index 0000000..7c1e0f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/csch.js @@ -0,0 +1,8 @@ +export var cschDocs = { + name: 'csch', + category: 'Trigonometry', + syntax: ['csch(x)'], + description: 'Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)', + examples: ['csch(2)', '1 / sinh(2)'], + seealso: ['sech', 'coth', 'sinh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sec.js new file mode 100644 index 0000000..68e37dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sec.js @@ -0,0 +1,8 @@ +export var secDocs = { + name: 'sec', + category: 'Trigonometry', + syntax: ['sec(x)'], + description: 'Compute the secant of x in radians. Defined as 1/cos(x)', + examples: ['sec(2)', '1 / cos(2)'], + seealso: ['cot', 'csc', 'cos'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sech.js new file mode 100644 index 0000000..3a51e19 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sech.js @@ -0,0 +1,8 @@ +export var sechDocs = { + name: 'sech', + category: 'Trigonometry', + syntax: ['sech(x)'], + description: 'Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)', + examples: ['sech(2)', '1 / cosh(2)'], + seealso: ['coth', 'csch', 'cosh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sin.js new file mode 100644 index 0000000..79de9f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sin.js @@ -0,0 +1,8 @@ +export var sinDocs = { + name: 'sin', + category: 'Trigonometry', + syntax: ['sin(x)'], + description: 'Compute the sine of x in radians.', + examples: ['sin(2)', 'sin(pi / 4) ^ 2', 'sin(90 deg)', 'sin(30 deg)', 'sin(0.2)^2 + cos(0.2)^2'], + seealso: ['asin', 'cos', 'tan'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sinh.js new file mode 100644 index 0000000..4656c82 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/sinh.js @@ -0,0 +1,8 @@ +export var sinhDocs = { + name: 'sinh', + category: 'Trigonometry', + syntax: ['sinh(x)'], + description: 'Compute the hyperbolic sine of x in radians.', + examples: ['sinh(0.5)'], + seealso: ['cosh', 'tanh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tan.js new file mode 100644 index 0000000..0a96d8e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tan.js @@ -0,0 +1,8 @@ +export var tanDocs = { + name: 'tan', + category: 'Trigonometry', + syntax: ['tan(x)'], + description: 'Compute the tangent of x in radians.', + examples: ['tan(0.5)', 'sin(0.5) / cos(0.5)', 'tan(pi / 4)', 'tan(45 deg)'], + seealso: ['atan', 'sin', 'cos'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tanh.js new file mode 100644 index 0000000..61cf2dd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/trigonometry/tanh.js @@ -0,0 +1,8 @@ +export var tanhDocs = { + name: 'tanh', + category: 'Trigonometry', + syntax: ['tanh(x)'], + description: 'Compute the hyperbolic tangent of x in radians.', + examples: ['tanh(0.5)', 'sinh(0.5) / cosh(0.5)'], + seealso: ['sinh', 'cosh'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/units/to.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/units/to.js new file mode 100644 index 0000000..090ebee --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/units/to.js @@ -0,0 +1,8 @@ +export var toDocs = { + name: 'to', + category: 'Units', + syntax: ['x to unit', 'to(x, unit)'], + description: 'Change the unit of a value.', + examples: ['5 inch to cm', '3.2kg to g', '16 bytes in bits'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/bin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/bin.js new file mode 100644 index 0000000..e7f1ac2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/bin.js @@ -0,0 +1,8 @@ +export var binDocs = { + name: 'bin', + category: 'Utils', + syntax: ['bin(value)'], + description: 'Format a number as binary', + examples: ['bin(2)'], + seealso: ['oct', 'hex'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/clone.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/clone.js new file mode 100644 index 0000000..17685b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/clone.js @@ -0,0 +1,8 @@ +export var cloneDocs = { + name: 'clone', + category: 'Utils', + syntax: ['clone(x)'], + description: 'Clone a variable. Creates a copy of primitive variables, and a deep copy of matrices', + examples: ['clone(3.5)', 'clone(2 - 4i)', 'clone(45 deg)', 'clone([1, 2; 3, 4])', 'clone("hello world")'], + seealso: [] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/format.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/format.js new file mode 100644 index 0000000..a2d5544 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/format.js @@ -0,0 +1,8 @@ +export var formatDocs = { + name: 'format', + category: 'Utils', + syntax: ['format(value)', 'format(value, precision)'], + description: 'Format a value of any type as string.', + examples: ['format(2.3)', 'format(3 - 4i)', 'format([])', 'format(pi, 3)'], + seealso: ['print'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hasNumericValue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hasNumericValue.js new file mode 100644 index 0000000..fdc397c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hasNumericValue.js @@ -0,0 +1,8 @@ +export var hasNumericValueDocs = { + name: 'hasNumericValue', + category: 'Utils', + syntax: ['hasNumericValue(x)'], + description: 'Test whether a value is an numeric value. ' + 'In case of a string, true is returned if the string contains a numeric value.', + examples: ['hasNumericValue(2)', 'hasNumericValue("2")', 'isNumeric("2")', 'hasNumericValue(0)', 'hasNumericValue(bignumber(500))', 'hasNumericValue(fraction(0.125))', 'hasNumericValue(2 + 3i)', 'hasNumericValue([2.3, "foo", false])'], + seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'isNumeric'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hex.js new file mode 100644 index 0000000..9764dc4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/hex.js @@ -0,0 +1,8 @@ +export var hexDocs = { + name: 'hex', + category: 'Utils', + syntax: ['hex(value)'], + description: 'Format a number as hexadecimal', + examples: ['hex(240)'], + seealso: ['bin', 'oct'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isInteger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isInteger.js new file mode 100644 index 0000000..5b87586 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isInteger.js @@ -0,0 +1,8 @@ +export var isIntegerDocs = { + name: 'isInteger', + category: 'Utils', + syntax: ['isInteger(x)'], + description: 'Test whether a value is an integer number.', + examples: ['isInteger(2)', 'isInteger(3.5)', 'isInteger([3, 0.5, -2])'], + seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNaN.js new file mode 100644 index 0000000..87bc055 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNaN.js @@ -0,0 +1,8 @@ +export var isNaNDocs = { + name: 'isNaN', + category: 'Utils', + syntax: ['isNaN(x)'], + description: 'Test whether a value is NaN (not a number)', + examples: ['isNaN(2)', 'isNaN(0 / 0)', 'isNaN(NaN)', 'isNaN(Infinity)'], + seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNegative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNegative.js new file mode 100644 index 0000000..a0f90c5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNegative.js @@ -0,0 +1,8 @@ +export var isNegativeDocs = { + name: 'isNegative', + category: 'Utils', + syntax: ['isNegative(x)'], + description: 'Test whether a value is negative: smaller than zero.', + examples: ['isNegative(2)', 'isNegative(0)', 'isNegative(-4)', 'isNegative([3, 0.5, -2])'], + seealso: ['isInteger', 'isNumeric', 'isPositive', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNumeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNumeric.js new file mode 100644 index 0000000..9ecb3d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isNumeric.js @@ -0,0 +1,8 @@ +export var isNumericDocs = { + name: 'isNumeric', + category: 'Utils', + syntax: ['isNumeric(x)'], + description: 'Test whether a value is a numeric value. ' + 'Returns true when the input is a number, BigNumber, Fraction, or boolean.', + examples: ['isNumeric(2)', 'isNumeric("2")', 'hasNumericValue("2")', 'isNumeric(0)', 'isNumeric(bignumber(500))', 'isNumeric(fraction(0.125))', 'isNumeric(2 + 3i)', 'isNumeric([2.3, "foo", false])'], + seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'hasNumericValue'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPositive.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPositive.js new file mode 100644 index 0000000..3af6886 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPositive.js @@ -0,0 +1,8 @@ +export var isPositiveDocs = { + name: 'isPositive', + category: 'Utils', + syntax: ['isPositive(x)'], + description: 'Test whether a value is positive: larger than zero.', + examples: ['isPositive(2)', 'isPositive(0)', 'isPositive(-4)', 'isPositive([3, 0.5, -2])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPrime.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPrime.js new file mode 100644 index 0000000..a46ed17 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isPrime.js @@ -0,0 +1,8 @@ +export var isPrimeDocs = { + name: 'isPrime', + category: 'Utils', + syntax: ['isPrime(x)'], + description: 'Test whether a value is prime: has no divisors other than itself and one.', + examples: ['isPrime(3)', 'isPrime(-2)', 'isPrime([2, 17, 100])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isZero.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isZero.js new file mode 100644 index 0000000..3e08770 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/isZero.js @@ -0,0 +1,8 @@ +export var isZeroDocs = { + name: 'isZero', + category: 'Utils', + syntax: ['isZero(x)'], + description: 'Test whether a value is zero.', + examples: ['isZero(2)', 'isZero(0)', 'isZero(-4)', 'isZero([3, 0, -2, 0])'], + seealso: ['isInteger', 'isNumeric', 'isNegative', 'isPositive'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/numeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/numeric.js new file mode 100644 index 0000000..382f6c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/numeric.js @@ -0,0 +1,8 @@ +export var numericDocs = { + name: 'numeric', + category: 'Utils', + syntax: ['numeric(x)'], + description: 'Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.', + examples: ['numeric("4")', 'numeric("4", "number")', 'numeric("4", "bigint")', 'numeric("4", "BigNumber")', 'numeric("4", "Fraction")', 'numeric(4, "Fraction")', 'numeric(fraction(2, 5), "number")'], + seealso: ['number', 'bigint', 'fraction', 'bignumber', 'string', 'format'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/oct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/oct.js new file mode 100644 index 0000000..535a28b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/oct.js @@ -0,0 +1,8 @@ +export var octDocs = { + name: 'oct', + category: 'Utils', + syntax: ['oct(value)'], + description: 'Format a number as octal', + examples: ['oct(56)'], + seealso: ['bin', 'hex'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/print.js new file mode 100644 index 0000000..6671b0c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/print.js @@ -0,0 +1,8 @@ +export var printDocs = { + name: 'print', + category: 'Utils', + syntax: ['print(template, values)', 'print(template, values, precision)'], + description: 'Interpolate values into a string template.', + examples: ['print("Lucy is $age years old", {age: 5})', 'print("The value of pi is $pi", {pi: pi}, 3)', 'print("Hello, $user.name!", {user: {name: "John"}})', 'print("Values: $1, $2, $3", [6, 9, 4])'], + seealso: ['format'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/typeOf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/typeOf.js new file mode 100644 index 0000000..91629c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/embeddedDocs/function/utils/typeOf.js @@ -0,0 +1,8 @@ +export var typeOfDocs = { + name: 'typeOf', + category: 'Utils', + syntax: ['typeOf(x)'], + description: 'Get the type of a variable.', + examples: ['typeOf(3.5)', 'typeOf(2 - 4i)', 'typeOf(45 deg)', 'typeOf("hello world")'], + seealso: ['getMatrixDataType'] +}; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/compile.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/compile.js new file mode 100644 index 0000000..b9441a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/compile.js @@ -0,0 +1,54 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'compile'; +var dependencies = ['typed', 'parse']; +export var createCompile = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + parse + } = _ref; + /** + * Parse and compile an expression. + * Returns a an object with a function `evaluate([scope])` to evaluate the + * compiled expression. + * + * Syntax: + * + * math.compile(expr) // returns one node + * math.compile([expr1, expr2, expr3, ...]) // returns an array with nodes + * + * Examples: + * + * const code1 = math.compile('sqrt(3^2 + 4^2)') + * code1.evaluate() // 5 + * + * let scope = {a: 3, b: 4} + * const code2 = math.compile('a * b') // 12 + * code2.evaluate(scope) // 12 + * scope.a = 5 + * code2.evaluate(scope) // 20 + * + * const nodes = math.compile(['a = 3', 'b = 4', 'a * b']) + * nodes[2].evaluate() // 12 + * + * See also: + * + * parse, evaluate + * + * @param {string | string[] | Array | Matrix} expr + * The expression to be compiled + * @return {{evaluate: Function} | Array.<{evaluate: Function}>} code + * An object with the compiled expression + * @throws {Error} + */ + return typed(name, { + string: function string(expr) { + return parse(expr).compile(); + }, + 'Array | Matrix': function Array__Matrix(expr) { + return deepMap(expr, function (entry) { + return parse(entry).compile(); + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/evaluate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/evaluate.js new file mode 100644 index 0000000..a4a68d0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/evaluate.js @@ -0,0 +1,68 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { createEmptyMap } from '../../utils/map.js'; +var name = 'evaluate'; +var dependencies = ['typed', 'parse']; +export var createEvaluate = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + parse + } = _ref; + /** + * Evaluate an expression. + * + * The expression parser does not use JavaScript. Its syntax is close + * to JavaScript but more suited for mathematical expressions. + * See [https://mathjs.org/docs/expressions/syntax.html](https://mathjs.org/docs/expressions/syntax.html) to learn + * the syntax and get an overview of the exact differences from JavaScript. + * + * Note the evaluating arbitrary expressions may involve security risks, + * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information. + * + * Syntax: + * + * math.evaluate(expr) + * math.evaluate(expr, scope) + * math.evaluate([expr1, expr2, expr3, ...]) + * math.evaluate([expr1, expr2, expr3, ...], scope) + * + * Example: + * + * math.evaluate('(2+3)/4') // 1.25 + * math.evaluate('sqrt(3^2 + 4^2)') // 5 + * math.evaluate('sqrt(-4)') // 2i + * math.evaluate(['a=3', 'b=4', 'a*b']) // [3, 4, 12] + * + * let scope = {a:3, b:4} + * math.evaluate('a * b', scope) // 12 + * + * See also: + * + * parse, compile + * + * @param {string | string[] | Matrix} expr The expression to be evaluated + * @param {Object} [scope] Scope to read/write variables + * @return {*} The result of the expression + * @throws {Error} + */ + return typed(name, { + string: function string(expr) { + var scope = createEmptyMap(); + return parse(expr).compile().evaluate(scope); + }, + 'string, Map | Object': function string_Map__Object(expr, scope) { + return parse(expr).compile().evaluate(scope); + }, + 'Array | Matrix': function Array__Matrix(expr) { + var scope = createEmptyMap(); + return deepMap(expr, function (entry) { + return parse(entry).compile().evaluate(scope); + }); + }, + 'Array | Matrix, Map | Object': function Array__Matrix_Map__Object(expr, scope) { + return deepMap(expr, function (entry) { + return parse(entry).compile().evaluate(scope); + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/help.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/help.js new file mode 100644 index 0000000..8252aba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/help.js @@ -0,0 +1,66 @@ +import { factory } from '../../utils/factory.js'; +import { getSafeProperty } from '../../utils/customs.js'; +import { embeddedDocs } from '../embeddedDocs/embeddedDocs.js'; +import { hasOwnProperty } from '../../utils/object.js'; +var name = 'help'; +var dependencies = ['typed', 'mathWithTransform', 'Help']; +export var createHelp = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + mathWithTransform, + Help + } = _ref; + /** + * Retrieve help on a function or data type. + * Help files are retrieved from the embedded documentation in math.docs. + * + * Syntax: + * + * math.help(search) + * + * Examples: + * + * console.log(math.help('sin').toString()) + * console.log(math.help(math.add).toString()) + * console.log(math.help(math.add).toJSON()) + * + * @param {Function | string | Object} search A function or function name + * for which to get help + * @return {Help} A help object + */ + return typed(name, { + any: function any(search) { + var prop; + var searchName = search; + if (typeof search !== 'string') { + for (prop in mathWithTransform) { + // search in functions and constants + if (hasOwnProperty(mathWithTransform, prop) && search === mathWithTransform[prop]) { + searchName = prop; + break; + } + } + + /* TODO: implement help for data types + if (!text) { + // search data type + for (prop in math.type) { + if (hasOwnProperty(math, prop)) { + if (search === math.type[prop]) { + text = prop + break + } + } + } + } + */ + } + var doc = getSafeProperty(embeddedDocs, searchName); + if (!doc) { + var searchText = typeof searchName === 'function' ? searchName.name : searchName; + throw new Error('No documentation found on "' + searchText + '"'); + } + return new Help(doc); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/parser.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/parser.js new file mode 100644 index 0000000..a976cec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/function/parser.js @@ -0,0 +1,57 @@ +import { factory } from '../../utils/factory.js'; +var name = 'parser'; +var dependencies = ['typed', 'Parser']; +export var createParser = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Parser + } = _ref; + /** + * Create a parser. The function creates a new `math.Parser` object. + * + * Syntax: + * + * math.parser() + * + * Examples: + * + * const parser = new math.parser() + * + * // evaluate expressions + * const a = parser.evaluate('sqrt(3^2 + 4^2)') // 5 + * const b = parser.evaluate('sqrt(-4)') // 2i + * const c = parser.evaluate('2 inch in cm') // 5.08 cm + * const d = parser.evaluate('cos(45 deg)') // 0.7071067811865476 + * + * // define variables and functions + * parser.evaluate('x = 7 / 2') // 3.5 + * parser.evaluate('x + 3') // 6.5 + * parser.evaluate('f(x, y) = x^y') // f(x, y) + * parser.evaluate('f(2, 3)') // 8 + * + * // get and set variables and functions + * const x = parser.get('x') // 3.5 + * const f = parser.get('f') // function + * const g = f(3, 2) // 9 + * parser.set('h', 500) + * const i = parser.evaluate('h / 2') // 250 + * parser.set('hello', function (name) { + * return 'hello, ' + name + '!' + * }) + * parser.evaluate('hello("user")') // "hello, user!" + * + * // clear defined functions and variables + * parser.clear() + * + * See also: + * + * evaluate, compile, parse + * + * @return {Parser} Parser + */ + return typed(name, { + '': function _() { + return new Parser(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/keywords.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/keywords.js new file mode 100644 index 0000000..4ab02b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/keywords.js @@ -0,0 +1,2 @@ +// Reserved keywords not allowed to use in the parser +export var keywords = new Set(['end']); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AccessorNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AccessorNode.js new file mode 100644 index 0000000..de4b92d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AccessorNode.js @@ -0,0 +1,189 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isAccessorNode, isArrayNode, isConstantNode, isFunctionNode, isIndexNode, isNode, isObjectNode, isParenthesisNode, isSymbolNode } from '../../utils/is.js'; +import { getSafeProperty } from '../../utils/customs.js'; +import { factory } from '../../utils/factory.js'; +import { accessFactory } from './utils/access.js'; +var name = 'AccessorNode'; +var dependencies = ['subset', 'Node']; +export var createAccessorNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + subset, + Node + } = _ref; + var access = accessFactory({ + subset + }); + + /** + * Are parenthesis needed? + * @private + */ + function needParenthesis(node) { + // TODO: maybe make a method on the nodes which tells whether they need parenthesis? + return !(isAccessorNode(node) || isArrayNode(node) || isConstantNode(node) || isFunctionNode(node) || isObjectNode(node) || isParenthesisNode(node) || isSymbolNode(node)); + } + class AccessorNode extends Node { + /** + * @constructor AccessorNode + * @extends {Node} + * Access an object property or get a matrix subset + * + * @param {Node} object The object from which to retrieve + * a property or subset. + * @param {IndexNode} index IndexNode containing ranges + */ + constructor(object, index) { + super(); + if (!isNode(object)) { + throw new TypeError('Node expected for parameter "object"'); + } + if (!isIndexNode(index)) { + throw new TypeError('IndexNode expected for parameter "index"'); + } + this.object = object; + this.index = index; + } + + // readonly property name + get name() { + if (this.index) { + return this.index.isObjectProperty() ? this.index.getObjectProperty() : ''; + } else { + return this.object.name || ''; + } + } + get type() { + return name; + } + get isAccessorNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalObject = this.object._compile(math, argNames); + var evalIndex = this.index._compile(math, argNames); + if (this.index.isObjectProperty()) { + var prop = this.index.getObjectProperty(); + return function evalAccessorNode(scope, args, context) { + // get a property from an object evaluated using the scope. + return getSafeProperty(evalObject(scope, args, context), prop); + }; + } else { + return function evalAccessorNode(scope, args, context) { + var object = evalObject(scope, args, context); + // we pass just object here instead of context: + var index = evalIndex(scope, args, object); + return access(object, index); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.object, 'object', this); + callback(this.index, 'index', this); + } + + /** + * Create a new AccessorNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {AccessorNode} Returns a transformed copy of the node + */ + map(callback) { + return new AccessorNode(this._ifNode(callback(this.object, 'object', this)), this._ifNode(callback(this.index, 'index', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {AccessorNode} + */ + clone() { + return new AccessorNode(this.object, this.index); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} + */ + _toString(options) { + var object = this.object.toString(options); + if (needParenthesis(this.object)) { + object = '(' + object + ')'; + } + return object + this.index.toString(options); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} + */ + _toHTML(options) { + var object = this.object.toHTML(options); + if (needParenthesis(this.object)) { + object = '(' + object + ')'; + } + return object + this.index.toHTML(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} + */ + _toTex(options) { + var object = this.object.toTex(options); + if (needParenthesis(this.object)) { + object = '\\left(\' + object + \'\\right)'; + } + return object + this.index.toTex(options); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + object: this.object, + index: this.index + }; + } + + /** + * Instantiate an AccessorNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "AccessorNode", object: ..., index: ...}`, + * where mathjs is optional + * @returns {AccessorNode} + */ + static fromJSON(json) { + return new AccessorNode(json.object, json.index); + } + } + _defineProperty(AccessorNode, "name", name); + return AccessorNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ArrayNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ArrayNode.js new file mode 100644 index 0000000..9382a2c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ArrayNode.js @@ -0,0 +1,176 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isArrayNode, isNode } from '../../utils/is.js'; +import { map } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'ArrayNode'; +var dependencies = ['Node']; +export var createArrayNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + class ArrayNode extends Node { + /** + * @constructor ArrayNode + * @extends {Node} + * Holds an 1-dimensional array with items + * @param {Node[]} [items] 1 dimensional array with items + */ + constructor(items) { + super(); + this.items = items || []; + + // validate input + if (!Array.isArray(this.items) || !this.items.every(isNode)) { + throw new TypeError('Array containing Nodes expected'); + } + } + get type() { + return name; + } + get isArrayNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalItems = map(this.items, function (item) { + return item._compile(math, argNames); + }); + var asMatrix = math.config.matrix !== 'Array'; + if (asMatrix) { + var matrix = math.matrix; + return function evalArrayNode(scope, args, context) { + return matrix(map(evalItems, function (evalItem) { + return evalItem(scope, args, context); + })); + }; + } else { + return function evalArrayNode(scope, args, context) { + return map(evalItems, function (evalItem) { + return evalItem(scope, args, context); + }); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (var i = 0; i < this.items.length; i++) { + var node = this.items[i]; + callback(node, 'items[' + i + ']', this); + } + } + + /** + * Create a new ArrayNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ArrayNode} Returns a transformed copy of the node + */ + map(callback) { + var items = []; + for (var i = 0; i < this.items.length; i++) { + items[i] = this._ifNode(callback(this.items[i], 'items[' + i + ']', this)); + } + return new ArrayNode(items); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ArrayNode} + */ + clone() { + return new ArrayNode(this.items.slice(0)); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + var items = this.items.map(function (node) { + return node.toString(options); + }); + return '[' + items.join(', ') + ']'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + items: this.items + }; + } + + /** + * Instantiate an ArrayNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ArrayNode", items: [...]}`, + * where mathjs is optional + * @returns {ArrayNode} + */ + static fromJSON(json) { + return new ArrayNode(json.items); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + var items = this.items.map(function (node) { + return node.toHTML(options); + }); + return '[' + items.join(',') + ']'; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + function itemsToTex(items, nested) { + var mixedItems = items.some(isArrayNode) && !items.every(isArrayNode); + var itemsFormRow = nested || mixedItems; + var itemSep = itemsFormRow ? '&' : '\\\\'; + var itemsTex = items.map(function (node) { + if (node.items) { + return itemsToTex(node.items, !nested); + } else { + return node.toTex(options); + } + }).join(itemSep); + return mixedItems || !itemsFormRow || itemsFormRow && !nested ? '\\begin{bmatrix}' + itemsTex + '\\end{bmatrix}' : itemsTex; + } + return itemsToTex(this.items, false); + } + } + _defineProperty(ArrayNode, "name", name); + return ArrayNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AssignmentNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AssignmentNode.js new file mode 100644 index 0000000..dacaadb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/AssignmentNode.js @@ -0,0 +1,306 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isAccessorNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'; +import { getSafeProperty, setSafeProperty } from '../../utils/customs.js'; +import { factory } from '../../utils/factory.js'; +import { accessFactory } from './utils/access.js'; +import { assignFactory } from './utils/assign.js'; +import { getPrecedence } from '../operators.js'; +var name = 'AssignmentNode'; +var dependencies = ['subset', '?matrix', +// FIXME: should not be needed at all, should be handled by subset +'Node']; +export var createAssignmentNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + subset, + matrix, + Node + } = _ref; + var access = accessFactory({ + subset + }); + var assign = assignFactory({ + subset, + matrix + }); + + /* + * Is parenthesis needed? + * @param {node} node + * @param {string} [parenthesis='keep'] + * @param {string} implicit + * @private + */ + function needParenthesis(node, parenthesis, implicit) { + if (!parenthesis) { + parenthesis = 'keep'; + } + var precedence = getPrecedence(node, parenthesis, implicit); + var exprPrecedence = getPrecedence(node.value, parenthesis, implicit); + return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence; + } + class AssignmentNode extends Node { + /** + * @constructor AssignmentNode + * @extends {Node} + * + * Define a symbol, like `a=3.2`, update a property like `a.b=3.2`, or + * replace a subset of a matrix like `A[2,2]=42`. + * + * Syntax: + * + * new AssignmentNode(symbol, value) + * new AssignmentNode(object, index, value) + * + * Usage: + * + * new AssignmentNode(new SymbolNode('a'), new ConstantNode(2)) // a=2 + * new AssignmentNode(new SymbolNode('a'), + * new IndexNode('b'), + * new ConstantNode(2)) // a.b=2 + * new AssignmentNode(new SymbolNode('a'), + * new IndexNode(1, 2), + * new ConstantNode(3)) // a[1,2]=3 + * + * @param {SymbolNode | AccessorNode} object + * Object on which to assign a value + * @param {IndexNode} [index=null] + * Index, property name or matrix index. Optional. If not provided + * and `object` is a SymbolNode, the property is assigned to the + * global scope. + * @param {Node} value + * The value to be assigned + */ + constructor(object, index, value) { + super(); + this.object = object; + this.index = value ? index : null; + this.value = value || index; + + // validate input + if (!isSymbolNode(object) && !isAccessorNode(object)) { + throw new TypeError('SymbolNode or AccessorNode expected as "object"'); + } + if (isSymbolNode(object) && object.name === 'end') { + throw new Error('Cannot assign to symbol "end"'); + } + if (this.index && !isIndexNode(this.index)) { + // index is optional + throw new TypeError('IndexNode expected as "index"'); + } + if (!isNode(this.value)) { + throw new TypeError('Node expected as "value"'); + } + } + + // class name for typing purposes: + + // readonly property name + get name() { + if (this.index) { + return this.index.isObjectProperty() ? this.index.getObjectProperty() : ''; + } else { + return this.object.name || ''; + } + } + get type() { + return name; + } + get isAssignmentNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalObject = this.object._compile(math, argNames); + var evalIndex = this.index ? this.index._compile(math, argNames) : null; + var evalValue = this.value._compile(math, argNames); + var name = this.object.name; + if (!this.index) { + // apply a variable to the scope, for example `a=2` + if (!isSymbolNode(this.object)) { + throw new TypeError('SymbolNode expected as object'); + } + return function evalAssignmentNode(scope, args, context) { + var value = evalValue(scope, args, context); + scope.set(name, value); + return value; + }; + } else if (this.index.isObjectProperty()) { + // apply an object property for example `a.b=2` + var prop = this.index.getObjectProperty(); + return function evalAssignmentNode(scope, args, context) { + var object = evalObject(scope, args, context); + var value = evalValue(scope, args, context); + setSafeProperty(object, prop, value); + return value; + }; + } else if (isSymbolNode(this.object)) { + // update a matrix subset, for example `a[2]=3` + return function evalAssignmentNode(scope, args, context) { + var childObject = evalObject(scope, args, context); + var value = evalValue(scope, args, context); + // Important: we pass childObject instead of context: + var index = evalIndex(scope, args, childObject); + scope.set(name, assign(childObject, index, value)); + return value; + }; + } else { + // isAccessorNode(node.object) === true + // update a matrix subset, for example `a.b[2]=3` + + // we will not use the compile function of the AccessorNode, but + // compile it ourselves here as we need the parent object of the + // AccessorNode: + // wee need to apply the updated object to parent object + var evalParentObject = this.object.object._compile(math, argNames); + if (this.object.index.isObjectProperty()) { + var parentProp = this.object.index.getObjectProperty(); + return function evalAssignmentNode(scope, args, context) { + var parent = evalParentObject(scope, args, context); + var childObject = getSafeProperty(parent, parentProp); + // Important: we pass childObject instead of context: + var index = evalIndex(scope, args, childObject); + var value = evalValue(scope, args, context); + setSafeProperty(parent, parentProp, assign(childObject, index, value)); + return value; + }; + } else { + // if some parameters use the 'end' parameter, we need to calculate + // the size + var evalParentIndex = this.object.index._compile(math, argNames); + return function evalAssignmentNode(scope, args, context) { + var parent = evalParentObject(scope, args, context); + // Important: we pass parent instead of context: + var parentIndex = evalParentIndex(scope, args, parent); + var childObject = access(parent, parentIndex); + // Important: we pass childObject instead of context + var index = evalIndex(scope, args, childObject); + var value = evalValue(scope, args, context); + assign(parent, parentIndex, assign(childObject, index, value)); + return value; + }; + } + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.object, 'object', this); + if (this.index) { + callback(this.index, 'index', this); + } + callback(this.value, 'value', this); + } + + /** + * Create a new AssignmentNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {AssignmentNode} Returns a transformed copy of the node + */ + map(callback) { + var object = this._ifNode(callback(this.object, 'object', this)); + var index = this.index ? this._ifNode(callback(this.index, 'index', this)) : null; + var value = this._ifNode(callback(this.value, 'value', this)); + return new AssignmentNode(object, index, value); + } + + /** + * Create a clone of this node, a shallow copy + * @return {AssignmentNode} + */ + clone() { + return new AssignmentNode(this.object, this.index, this.value); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} + */ + _toString(options) { + var object = this.object.toString(options); + var index = this.index ? this.index.toString(options) : ''; + var value = this.value.toString(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = '(' + value + ')'; + } + return object + index + ' = ' + value; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + object: this.object, + index: this.index, + value: this.value + }; + } + + /** + * Instantiate an AssignmentNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "AssignmentNode", object: ..., index: ..., value: ...}`, + * where mathjs is optional + * @returns {AssignmentNode} + */ + static fromJSON(json) { + return new AssignmentNode(json.object, json.index, json.value); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} + */ + _toHTML(options) { + var object = this.object.toHTML(options); + var index = this.index ? this.index.toHTML(options) : ''; + var value = this.value.toHTML(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = '(' + value + ')'; + } + return object + index + '=' + value; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} + */ + _toTex(options) { + var object = this.object.toTex(options); + var index = this.index ? this.index.toTex(options) : ''; + var value = this.value.toTex(options); + if (needParenthesis(this, options && options.parenthesis, options && options.implicit)) { + value = "\\left(".concat(value, "\\right)"); + } + return object + index + '=' + value; + } + } + _defineProperty(AssignmentNode, "name", name); + return AssignmentNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/BlockNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/BlockNode.js new file mode 100644 index 0000000..e32f428 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/BlockNode.js @@ -0,0 +1,185 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isNode } from '../../utils/is.js'; +import { forEach, map } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'BlockNode'; +var dependencies = ['ResultSet', 'Node']; +export var createBlockNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + ResultSet, + Node + } = _ref; + class BlockNode extends Node { + /** + * @constructor BlockNode + * @extends {Node} + * Holds a set with blocks + * @param {Array.<{node: Node} | {node: Node, visible: boolean}>} blocks + * An array with blocks, where a block is constructed as an + * Object with properties block, which is a Node, and visible, + * which is a boolean. The property visible is optional and + * is true by default + */ + constructor(blocks) { + super(); + // validate input, copy blocks + if (!Array.isArray(blocks)) throw new Error('Array expected'); + this.blocks = blocks.map(function (block) { + var node = block && block.node; + var visible = block && block.visible !== undefined ? block.visible : true; + if (!isNode(node)) throw new TypeError('Property "node" must be a Node'); + if (typeof visible !== 'boolean') { + throw new TypeError('Property "visible" must be a boolean'); + } + return { + node, + visible + }; + }); + } + get type() { + return name; + } + get isBlockNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalBlocks = map(this.blocks, function (block) { + return { + evaluate: block.node._compile(math, argNames), + visible: block.visible + }; + }); + return function evalBlockNodes(scope, args, context) { + var results = []; + forEach(evalBlocks, function evalBlockNode(block) { + var result = block.evaluate(scope, args, context); + if (block.visible) { + results.push(result); + } + }); + return new ResultSet(results); + }; + } + + /** + * Execute a callback for each of the child blocks of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (var i = 0; i < this.blocks.length; i++) { + callback(this.blocks[i].node, 'blocks[' + i + '].node', this); + } + } + + /** + * Create a new BlockNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {BlockNode} Returns a transformed copy of the node + */ + map(callback) { + var blocks = []; + for (var i = 0; i < this.blocks.length; i++) { + var block = this.blocks[i]; + var node = this._ifNode(callback(block.node, 'blocks[' + i + '].node', this)); + blocks[i] = { + node, + visible: block.visible + }; + } + return new BlockNode(blocks); + } + + /** + * Create a clone of this node, a shallow copy + * @return {BlockNode} + */ + clone() { + var blocks = this.blocks.map(function (block) { + return { + node: block.node, + visible: block.visible + }; + }); + return new BlockNode(blocks); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + return this.blocks.map(function (param) { + return param.node.toString(options) + (param.visible ? '' : ';'); + }).join('\n'); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + blocks: this.blocks + }; + } + + /** + * Instantiate an BlockNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "BlockNode", blocks: [{node: ..., visible: false}, ...]}`, + * where mathjs is optional + * @returns {BlockNode} + */ + static fromJSON(json) { + return new BlockNode(json.blocks); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + return this.blocks.map(function (param) { + return param.node.toHTML(options) + (param.visible ? '' : ';'); + }).join('
    '); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + return this.blocks.map(function (param) { + return param.node.toTex(options) + (param.visible ? '' : ';'); + }).join('\\;\\;\n'); + } + } + _defineProperty(BlockNode, "name", name); + return BlockNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConditionalNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConditionalNode.js new file mode 100644 index 0000000..3dfb8c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConditionalNode.js @@ -0,0 +1,225 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isBigNumber, isComplex, isNode, isUnit, typeOf } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { getPrecedence } from '../operators.js'; +var name = 'ConditionalNode'; +var dependencies = ['Node']; +export var createConditionalNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + /** + * Test whether a condition is met + * @param {*} condition + * @returns {boolean} true if condition is true or non-zero, else false + */ + function testCondition(condition) { + if (typeof condition === 'number' || typeof condition === 'boolean' || typeof condition === 'string') { + return !!condition; + } + if (condition) { + if (isBigNumber(condition)) { + return !condition.isZero(); + } + if (isComplex(condition)) { + return !!(condition.re || condition.im); + } + if (isUnit(condition)) { + return !!condition.value; + } + } + if (condition === null || condition === undefined) { + return false; + } + throw new TypeError('Unsupported type of condition "' + typeOf(condition) + '"'); + } + class ConditionalNode extends Node { + /** + * A lazy evaluating conditional operator: 'condition ? trueExpr : falseExpr' + * + * @param {Node} condition Condition, must result in a boolean + * @param {Node} trueExpr Expression evaluated when condition is true + * @param {Node} falseExpr Expression evaluated when condition is true + * + * @constructor ConditionalNode + * @extends {Node} + */ + constructor(condition, trueExpr, falseExpr) { + super(); + if (!isNode(condition)) { + throw new TypeError('Parameter condition must be a Node'); + } + if (!isNode(trueExpr)) { + throw new TypeError('Parameter trueExpr must be a Node'); + } + if (!isNode(falseExpr)) { + throw new TypeError('Parameter falseExpr must be a Node'); + } + this.condition = condition; + this.trueExpr = trueExpr; + this.falseExpr = falseExpr; + } + get type() { + return name; + } + get isConditionalNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalCondition = this.condition._compile(math, argNames); + var evalTrueExpr = this.trueExpr._compile(math, argNames); + var evalFalseExpr = this.falseExpr._compile(math, argNames); + return function evalConditionalNode(scope, args, context) { + return testCondition(evalCondition(scope, args, context)) ? evalTrueExpr(scope, args, context) : evalFalseExpr(scope, args, context); + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.condition, 'condition', this); + callback(this.trueExpr, 'trueExpr', this); + callback(this.falseExpr, 'falseExpr', this); + } + + /** + * Create a new ConditionalNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ConditionalNode} Returns a transformed copy of the node + */ + map(callback) { + return new ConditionalNode(this._ifNode(callback(this.condition, 'condition', this)), this._ifNode(callback(this.trueExpr, 'trueExpr', this)), this._ifNode(callback(this.falseExpr, 'falseExpr', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ConditionalNode} + */ + clone() { + return new ConditionalNode(this.condition, this.trueExpr, this.falseExpr); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var precedence = getPrecedence(this, parenthesis, options && options.implicit); + + // Enclose Arguments in parentheses if they are an OperatorNode + // or have lower or equal precedence + // NOTE: enclosing all OperatorNodes in parentheses is a decision + // purely based on aesthetics and readability + var condition = this.condition.toString(options); + var conditionPrecedence = getPrecedence(this.condition, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) { + condition = '(' + condition + ')'; + } + var trueExpr = this.trueExpr.toString(options); + var truePrecedence = getPrecedence(this.trueExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) { + trueExpr = '(' + trueExpr + ')'; + } + var falseExpr = this.falseExpr.toString(options); + var falsePrecedence = getPrecedence(this.falseExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) { + falseExpr = '(' + falseExpr + ')'; + } + return condition + ' ? ' + trueExpr + ' : ' + falseExpr; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + condition: this.condition, + trueExpr: this.trueExpr, + falseExpr: this.falseExpr + }; + } + + /** + * Instantiate an ConditionalNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "ConditionalNode", + * "condition": ..., + * "trueExpr": ..., + * "falseExpr": ...} + * ``` + * where mathjs is optional + * @returns {ConditionalNode} + */ + static fromJSON(json) { + return new ConditionalNode(json.condition, json.trueExpr, json.falseExpr); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var precedence = getPrecedence(this, parenthesis, options && options.implicit); + + // Enclose Arguments in parentheses if they are an OperatorNode + // or have lower or equal precedence + // NOTE: enclosing all OperatorNodes in parentheses is a decision + // purely based on aesthetics and readability + var condition = this.condition.toHTML(options); + var conditionPrecedence = getPrecedence(this.condition, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) { + condition = '(' + condition + ')'; + } + var trueExpr = this.trueExpr.toHTML(options); + var truePrecedence = getPrecedence(this.trueExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) { + trueExpr = '(' + trueExpr + ')'; + } + var falseExpr = this.falseExpr.toHTML(options); + var falsePrecedence = getPrecedence(this.falseExpr, parenthesis, options && options.implicit); + if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) { + falseExpr = '(' + falseExpr + ')'; + } + return condition + '?' + trueExpr + ':' + falseExpr; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + return '\\begin{cases} {' + this.trueExpr.toTex(options) + '}, &\\quad{\\text{if }\\;' + this.condition.toTex(options) + '}\\\\{' + this.falseExpr.toTex(options) + '}, &\\quad{\\text{otherwise}}\\end{cases}'; + } + } + _defineProperty(ConditionalNode, "name", name); + return ConditionalNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConstantNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConstantNode.js new file mode 100644 index 0000000..908eb87 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ConstantNode.js @@ -0,0 +1,179 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { format } from '../../utils/string.js'; +import { typeOf } from '../../utils/is.js'; +import { escapeLatex } from '../../utils/latex.js'; +import { factory } from '../../utils/factory.js'; +var name = 'ConstantNode'; +var dependencies = ['Node']; +export var createConstantNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + class ConstantNode extends Node { + /** + * A ConstantNode holds a constant value like a number or string. + * + * Usage: + * + * new ConstantNode(2.3) + * new ConstantNode('hello') + * + * @param {*} value Value can be any type (number, BigNumber, bigint, string, ...) + * @constructor ConstantNode + * @extends {Node} + */ + constructor(value) { + super(); + this.value = value; + } + get type() { + return name; + } + get isConstantNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var value = this.value; + return function evalConstantNode() { + return value; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // nothing to do, we don't have any children + } + + /** + * Create a new ConstantNode with children produced by the given callback. + * Trivial because there are no children. + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {ConstantNode} Returns a clone of the node + */ + map(callback) { + return this.clone(); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ConstantNode} + */ + clone() { + return new ConstantNode(this.value); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + return format(this.value, options); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var value = this._toString(options); + switch (typeOf(this.value)) { + case 'number': + case 'bigint': + case 'BigNumber': + case 'Fraction': + return '' + value + ''; + case 'string': + return '' + value + ''; + case 'boolean': + return '' + value + ''; + case 'null': + return '' + value + ''; + case 'undefined': + return '' + value + ''; + default: + return '' + value + ''; + } + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + value: this.value + }; + } + + /** + * Instantiate a ConstantNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "SymbolNode", value: 2.3}`, + * where mathjs is optional + * @returns {ConstantNode} + */ + static fromJSON(json) { + return new ConstantNode(json.value); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var value = this._toString(options); + var type = typeOf(this.value); + switch (type) { + case 'string': + return '\\mathtt{' + escapeLatex(value) + '}'; + case 'number': + case 'BigNumber': + { + var finite = type === 'BigNumber' ? this.value.isFinite() : isFinite(this.value); + if (!finite) { + return this.value.valueOf() < 0 ? '-\\infty' : '\\infty'; + } + var index = value.toLowerCase().indexOf('e'); + if (index !== -1) { + return value.substring(0, index) + '\\cdot10^{' + value.substring(index + 1) + '}'; + } + return value; + } + case 'bigint': + { + return value.toString(); + } + case 'Fraction': + return this.value.toLatex(); + default: + return value; + } + } + } + _defineProperty(ConstantNode, "name", name); + return ConstantNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionAssignmentNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionAssignmentNode.js new file mode 100644 index 0000000..c05a53a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionAssignmentNode.js @@ -0,0 +1,235 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isNode } from '../../utils/is.js'; +import { keywords } from '../keywords.js'; +import { escape } from '../../utils/string.js'; +import { forEach, join } from '../../utils/array.js'; +import { toSymbol } from '../../utils/latex.js'; +import { getPrecedence } from '../operators.js'; +import { factory } from '../../utils/factory.js'; +var name = 'FunctionAssignmentNode'; +var dependencies = ['typed', 'Node']; +export var createFunctionAssignmentNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Node + } = _ref; + /** + * Is parenthesis needed? + * @param {Node} node + * @param {Object} parenthesis + * @param {string} implicit + * @private + */ + function needParenthesis(node, parenthesis, implicit) { + var precedence = getPrecedence(node, parenthesis, implicit); + var exprPrecedence = getPrecedence(node.expr, parenthesis, implicit); + return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence; + } + class FunctionAssignmentNode extends Node { + /** + * @constructor FunctionAssignmentNode + * @extends {Node} + * Function assignment + * + * @param {string} name Function name + * @param {string[] | Array.<{name: string, type: string}>} params + * Array with function parameter names, or an + * array with objects containing the name + * and type of the parameter + * @param {Node} expr The function expression + */ + constructor(name, params, expr) { + super(); + // validate input + if (typeof name !== 'string') { + throw new TypeError('String expected for parameter "name"'); + } + if (!Array.isArray(params)) { + throw new TypeError('Array containing strings or objects expected for parameter "params"'); + } + if (!isNode(expr)) { + throw new TypeError('Node expected for parameter "expr"'); + } + if (keywords.has(name)) { + throw new Error('Illegal function name, "' + name + '" is a reserved keyword'); + } + var paramNames = new Set(); + for (var param of params) { + var _name = typeof param === 'string' ? param : param.name; + if (paramNames.has(_name)) { + throw new Error("Duplicate parameter name \"".concat(_name, "\"")); + } else { + paramNames.add(_name); + } + } + this.name = name; + this.params = params.map(function (param) { + return param && param.name || param; + }); + this.types = params.map(function (param) { + return param && param.type || 'any'; + }); + this.expr = expr; + } + get type() { + return name; + } + get isFunctionAssignmentNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var childArgNames = Object.create(argNames); + forEach(this.params, function (param) { + childArgNames[param] = true; + }); + + // compile the function expression with the child args + var evalExpr = this.expr._compile(math, childArgNames); + var name = this.name; + var params = this.params; + var signature = join(this.types, ','); + var syntax = name + '(' + join(this.params, ', ') + ')'; + return function evalFunctionAssignmentNode(scope, args, context) { + var signatures = {}; + signatures[signature] = function () { + var childArgs = Object.create(args); + for (var i = 0; i < params.length; i++) { + childArgs[params[i]] = arguments[i]; + } + return evalExpr(scope, childArgs, context); + }; + var fn = typed(name, signatures); + fn.syntax = syntax; + scope.set(name, fn); + return fn; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.expr, 'expr', this); + } + + /** + * Create a new FunctionAssignmentNode whose children are the results of + * calling the provided callback function for each child of the original + * node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {FunctionAssignmentNode} Returns a transformed copy of the node + */ + map(callback) { + var expr = this._ifNode(callback(this.expr, 'expr', this)); + return new FunctionAssignmentNode(this.name, this.params.slice(0), expr); + } + + /** + * Create a clone of this node, a shallow copy + * @return {FunctionAssignmentNode} + */ + clone() { + return new FunctionAssignmentNode(this.name, this.params.slice(0), this.expr); + } + + /** + * get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var expr = this.expr.toString(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = '(' + expr + ')'; + } + return this.name + '(' + this.params.join(', ') + ') = ' + expr; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + var types = this.types; + return { + mathjs: name, + name: this.name, + params: this.params.map(function (param, index) { + return { + name: param, + type: types[index] + }; + }), + expr: this.expr + }; + } + + /** + * Instantiate an FunctionAssignmentNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "FunctionAssignmentNode", + * name: ..., params: ..., expr: ...} + * ``` + * where mathjs is optional + * @returns {FunctionAssignmentNode} + */ + static fromJSON(json) { + return new FunctionAssignmentNode(json.name, json.params, json.expr); + } + + /** + * get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var params = []; + for (var i = 0; i < this.params.length; i++) { + params.push('' + escape(this.params[i]) + ''); + } + var expr = this.expr.toHTML(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = '(' + expr + ')'; + } + return '' + escape(this.name) + '' + '(' + params.join(',') + ')' + '=' + expr; + } + + /** + * get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var expr = this.expr.toTex(options); + if (needParenthesis(this, parenthesis, options && options.implicit)) { + expr = "\\left(".concat(expr, "\\right)"); + } + return '\\mathrm{' + this.name + '}\\left(' + this.params.map(toSymbol).join(',') + '\\right)=' + expr; + } + } + _defineProperty(FunctionAssignmentNode, "name", name); + return FunctionAssignmentNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionNode.js new file mode 100644 index 0000000..19e896d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/FunctionNode.js @@ -0,0 +1,479 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isAccessorNode, isFunctionAssignmentNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'; +import { escape, format } from '../../utils/string.js'; +import { hasOwnProperty } from '../../utils/object.js'; +import { getSafeProperty, getSafeMethod } from '../../utils/customs.js'; +import { createSubScope } from '../../utils/scope.js'; +import { factory } from '../../utils/factory.js'; +import { defaultTemplate, latexFunctions } from '../../utils/latex.js'; +var name = 'FunctionNode'; +var dependencies = ['math', 'Node', 'SymbolNode']; +export var createFunctionNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var _FunctionNode; + var { + math, + Node, + SymbolNode + } = _ref; + /* format to fixed length */ + var strin = entity => format(entity, { + truncate: 78 + }); + + /* + * Expand a LaTeX template + * + * @param {string} template + * @param {Node} node + * @param {Object} options + * @private + **/ + function expandTemplate(template, node, options) { + var latex = ''; + + // Match everything of the form ${identifier} or ${identifier[2]} or $$ + // while submatching identifier and 2 (in the second case) + var regex = /\$(?:\{([a-z_][a-z_0-9]*)(?:\[([0-9]+)\])?\}|\$)/gi; + var inputPos = 0; // position in the input string + var match; + while ((match = regex.exec(template)) !== null) { + // go through all matches + // add everything in front of the match to the LaTeX string + latex += template.substring(inputPos, match.index); + inputPos = match.index; + if (match[0] === '$$') { + // escaped dollar sign + latex += '$'; + inputPos++; + } else { + // template parameter + inputPos += match[0].length; + var property = node[match[1]]; + if (!property) { + throw new ReferenceError('Template: Property ' + match[1] + ' does not exist.'); + } + if (match[2] === undefined) { + // no square brackets + switch (typeof property) { + case 'string': + latex += property; + break; + case 'object': + if (isNode(property)) { + latex += property.toTex(options); + } else if (Array.isArray(property)) { + // make array of Nodes into comma separated list + latex += property.map(function (arg, index) { + if (isNode(arg)) { + return arg.toTex(options); + } + throw new TypeError('Template: ' + match[1] + '[' + index + '] is not a Node.'); + }).join(','); + } else { + throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes'); + } + break; + default: + throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes'); + } + } else { + // with square brackets + if (isNode(property[match[2]] && property[match[2]])) { + latex += property[match[2]].toTex(options); + } else { + throw new TypeError('Template: ' + match[1] + '[' + match[2] + '] is not a Node.'); + } + } + } + } + latex += template.slice(inputPos); // append rest of the template + + return latex; + } + class FunctionNode extends Node { + /** + * @constructor FunctionNode + * @extends {./Node} + * invoke a list with arguments on a node + * @param {./Node | string} fn + * Item resolving to a function on which to invoke + * the arguments, typically a SymbolNode or AccessorNode + * @param {./Node[]} args + */ + constructor(fn, args) { + super(); + if (typeof fn === 'string') { + fn = new SymbolNode(fn); + } + + // validate input + if (!isNode(fn)) throw new TypeError('Node expected as parameter "fn"'); + if (!Array.isArray(args) || !args.every(isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "args"'); + } + this.fn = fn; + this.args = args || []; + } + + // readonly property name + get name() { + return this.fn.name || ''; + } + get type() { + return name; + } + get isFunctionNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // compile arguments + var evalArgs = this.args.map(arg => arg._compile(math, argNames)); + if (isSymbolNode(this.fn)) { + var _name = this.fn.name; + if (!argNames[_name]) { + // we can statically determine whether the function + // has the rawArgs property + var fn = _name in math ? getSafeProperty(math, _name) : undefined; + var isRaw = typeof fn === 'function' && fn.rawArgs === true; + var resolveFn = scope => { + var value; + if (scope.has(_name)) { + value = scope.get(_name); + } else if (_name in math) { + value = getSafeProperty(math, _name); + } else { + return FunctionNode.onUndefinedFunction(_name); + } + if (typeof value === 'function') { + return value; + } + throw new TypeError("'".concat(_name, "' is not a function; its value is:\n ").concat(strin(value))); + }; + if (isRaw) { + // pass unevaluated parameters (nodes) to the function + // "raw" evaluation + var rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + var fn = resolveFn(scope); + + // the original function can be overwritten in the scope with a non-rawArgs function + if (fn.rawArgs === true) { + return fn(rawArgs, math, createSubScope(scope, args)); + } else { + // "regular" evaluation + var values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn(...values); + } + }; + } else { + // "regular" evaluation + switch (evalArgs.length) { + case 0: + return function evalFunctionNode(scope, args, context) { + var fn = resolveFn(scope); + return fn(); + }; + case 1: + return function evalFunctionNode(scope, args, context) { + var fn = resolveFn(scope); + var evalArg0 = evalArgs[0]; + return fn(evalArg0(scope, args, context)); + }; + case 2: + return function evalFunctionNode(scope, args, context) { + var fn = resolveFn(scope); + var evalArg0 = evalArgs[0]; + var evalArg1 = evalArgs[1]; + return fn(evalArg0(scope, args, context), evalArg1(scope, args, context)); + }; + default: + return function evalFunctionNode(scope, args, context) { + var fn = resolveFn(scope); + var values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn(...values); + }; + } + } + } else { + // the function symbol is an argName + var _rawArgs = this.args; + return function evalFunctionNode(scope, args, context) { + var fn = getSafeProperty(args, _name); + if (typeof fn !== 'function') { + throw new TypeError("Argument '".concat(_name, "' was not a function; received: ").concat(strin(fn))); + } + if (fn.rawArgs) { + // "Raw" evaluation + return fn(_rawArgs, math, createSubScope(scope, args)); + } else { + var values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(fn, values); + } + }; + } + } else if (isAccessorNode(this.fn) && isIndexNode(this.fn.index) && this.fn.index.isObjectProperty()) { + // execute the function with the right context: + // the object of the AccessorNode + + var evalObject = this.fn.object._compile(math, argNames); + var prop = this.fn.index.getObjectProperty(); + var _rawArgs2 = this.args; + return function evalFunctionNode(scope, args, context) { + var object = evalObject(scope, args, context); + var fn = getSafeMethod(object, prop); + if (fn !== null && fn !== void 0 && fn.rawArgs) { + // "Raw" evaluation + return fn(_rawArgs2, math, createSubScope(scope, args)); + } else { + // "regular" evaluation + var values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(object, values); + } + }; + } else { + // node.fn.isAccessorNode && !node.fn.index.isObjectProperty() + // we have to dynamically determine whether the function has the + // rawArgs property + var fnExpr = this.fn.toString(); + var evalFn = this.fn._compile(math, argNames); + var _rawArgs3 = this.args; + return function evalFunctionNode(scope, args, context) { + var fn = evalFn(scope, args, context); + if (typeof fn !== 'function') { + throw new TypeError("Expression '".concat(fnExpr, "' did not evaluate to a function; value is:") + "\n ".concat(strin(fn))); + } + if (fn.rawArgs) { + // "Raw" evaluation + return fn(_rawArgs3, math, createSubScope(scope, args)); + } else { + // "regular" evaluation + var values = evalArgs.map(evalArg => evalArg(scope, args, context)); + return fn.apply(fn, values); + } + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.fn, 'fn', this); + for (var i = 0; i < this.args.length; i++) { + callback(this.args[i], 'args[' + i + ']', this); + } + } + + /** + * Create a new FunctionNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {FunctionNode} Returns a transformed copy of the node + */ + map(callback) { + var fn = this._ifNode(callback(this.fn, 'fn', this)); + var args = []; + for (var i = 0; i < this.args.length; i++) { + args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this)); + } + return new FunctionNode(fn, args); + } + + /** + * Create a clone of this node, a shallow copy + * @return {FunctionNode} + */ + clone() { + return new FunctionNode(this.fn, this.args.slice(0)); + } + + /** + * Throws an error 'Undefined function {name}' + * @param {string} name + */ + + /** + * Get string representation. (wrapper function) + * This overrides parts of Node's toString function. + * If callback is an object containing callbacks, it + * calls the correct callback for the current node, + * otherwise it falls back to calling Node's toString + * function. + * + * @param {Object} options + * @return {string} str + * @override + */ + toString(options) { + var customString; + var name = this.fn.toString(options); + if (options && typeof options.handler === 'object' && hasOwnProperty(options.handler, name)) { + // callback is a map of callback functions + customString = options.handler[name](this, options); + } + if (typeof customString !== 'undefined') { + return customString; + } + + // fall back to Node's toString + return super.toString(options); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var args = this.args.map(function (arg) { + return arg.toString(options); + }); + var fn = isFunctionAssignmentNode(this.fn) ? '(' + this.fn.toString(options) + ')' : this.fn.toString(options); + + // format the arguments like "add(2, 4.2)" + return fn + '(' + args.join(', ') + ')'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + fn: this.fn, + args: this.args + }; + } + + /** + * Instantiate an AssignmentNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "FunctionNode", fn: ..., args: ...}`, + * where mathjs is optional + * @returns {FunctionNode} + */ + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var args = this.args.map(function (arg) { + return arg.toHTML(options); + }); + + // format the arguments like "add(2, 4.2)" + return '' + escape(this.fn) + '(' + args.join(',') + ')'; + } + + /** + * Get LaTeX representation. (wrapper function) + * This overrides parts of Node's toTex function. + * If callback is an object containing callbacks, it + * calls the correct callback for the current node, + * otherwise it falls back to calling Node's toTex + * function. + * + * @param {Object} options + * @return {string} + */ + toTex(options) { + var customTex; + if (options && typeof options.handler === 'object' && hasOwnProperty(options.handler, this.name)) { + // callback is a map of callback functions + customTex = options.handler[this.name](this, options); + } + if (typeof customTex !== 'undefined') { + return customTex; + } + + // fall back to Node's toTex + return super.toTex(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var args = this.args.map(function (arg) { + // get LaTeX of the arguments + return arg.toTex(options); + }); + var latexConverter; + if (latexFunctions[this.name]) { + latexConverter = latexFunctions[this.name]; + } + + // toTex property on the function itself + if (math[this.name] && (typeof math[this.name].toTex === 'function' || typeof math[this.name].toTex === 'object' || typeof math[this.name].toTex === 'string')) { + // .toTex is a callback function + latexConverter = math[this.name].toTex; + } + var customToTex; + switch (typeof latexConverter) { + case 'function': + // a callback function + customToTex = latexConverter(this, options); + break; + case 'string': + // a template string + customToTex = expandTemplate(latexConverter, this, options); + break; + case 'object': + // an object with different "converters" for different + // numbers of arguments + switch (typeof latexConverter[args.length]) { + case 'function': + customToTex = latexConverter[args.length](this, options); + break; + case 'string': + customToTex = expandTemplate(latexConverter[args.length], this, options); + break; + } + } + if (typeof customToTex !== 'undefined') { + return customToTex; + } + return expandTemplate(defaultTemplate, this, options); + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type + ':' + this.name; + } + } + _FunctionNode = FunctionNode; + _defineProperty(FunctionNode, "name", name); + _defineProperty(FunctionNode, "onUndefinedFunction", function (name) { + throw new Error('Undefined function ' + name); + }); + _defineProperty(FunctionNode, "fromJSON", function (json) { + return new _FunctionNode(json.fn, json.args); + }); + return FunctionNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/IndexNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/IndexNode.js new file mode 100644 index 0000000..5c91a21 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/IndexNode.js @@ -0,0 +1,219 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { map } from '../../utils/array.js'; +import { getSafeProperty } from '../../utils/customs.js'; +import { factory } from '../../utils/factory.js'; +import { isArray, isConstantNode, isMatrix, isNode, isString, typeOf } from '../../utils/is.js'; +import { escape } from '../../utils/string.js'; +var name = 'IndexNode'; +var dependencies = ['Node', 'size']; +export var createIndexNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node, + size + } = _ref; + class IndexNode extends Node { + /** + * @constructor IndexNode + * @extends Node + * + * Describes a subset of a matrix or an object property. + * Cannot be used on its own, needs to be used within an AccessorNode or + * AssignmentNode. + * + * @param {Node[]} dimensions + * @param {boolean} [dotNotation=false] + * Optional property describing whether this index was written using dot + * notation like `a.b`, or using bracket notation like `a["b"]` + * (which is the default). This property is used for string conversion. + */ + constructor(dimensions, dotNotation) { + super(); + this.dimensions = dimensions; + this.dotNotation = dotNotation || false; + + // validate input + if (!Array.isArray(dimensions) || !dimensions.every(isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "dimensions"'); + } + if (this.dotNotation && !this.isObjectProperty()) { + throw new Error('dotNotation only applicable for object properties'); + } + } + get type() { + return name; + } + get isIndexNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // TODO: implement support for bignumber (currently bignumbers are silently + // reduced to numbers when changing the value to zero-based) + + // TODO: Optimization: when the range values are ConstantNodes, + // we can beforehand resolve the zero-based value + + // optimization for a simple object property + var evalDimensions = map(this.dimensions, function (dimension, i) { + var needsEnd = dimension.filter(node => node.isSymbolNode && node.name === 'end').length > 0; + if (needsEnd) { + // SymbolNode 'end' is used inside the index, + // like in `A[end]` or `A[end - 2]` + var childArgNames = Object.create(argNames); + childArgNames.end = true; + var _evalDimension = dimension._compile(math, childArgNames); + return function evalDimension(scope, args, context) { + if (!isMatrix(context) && !isArray(context) && !isString(context)) { + throw new TypeError('Cannot resolve "end": ' + 'context must be a Matrix, Array, or string but is ' + typeOf(context)); + } + var s = size(context).valueOf(); + var childArgs = Object.create(args); + childArgs.end = s[i]; + return _evalDimension(scope, childArgs, context); + }; + } else { + // SymbolNode `end` not used + return dimension._compile(math, argNames); + } + }); + var index = getSafeProperty(math, 'index'); + return function evalIndexNode(scope, args, context) { + var dimensions = map(evalDimensions, function (evalDimension) { + return evalDimension(scope, args, context); + }); + return index(...dimensions); + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (var i = 0; i < this.dimensions.length; i++) { + callback(this.dimensions[i], 'dimensions[' + i + ']', this); + } + } + + /** + * Create a new IndexNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {IndexNode} Returns a transformed copy of the node + */ + map(callback) { + var dimensions = []; + for (var i = 0; i < this.dimensions.length; i++) { + dimensions[i] = this._ifNode(callback(this.dimensions[i], 'dimensions[' + i + ']', this)); + } + return new IndexNode(dimensions, this.dotNotation); + } + + /** + * Create a clone of this node, a shallow copy + * @return {IndexNode} + */ + clone() { + return new IndexNode(this.dimensions.slice(0), this.dotNotation); + } + + /** + * Test whether this IndexNode contains a single property name + * @return {boolean} + */ + isObjectProperty() { + return this.dimensions.length === 1 && isConstantNode(this.dimensions[0]) && typeof this.dimensions[0].value === 'string'; + } + + /** + * Returns the property name if IndexNode contains a property. + * If not, returns null. + * @return {string | null} + */ + getObjectProperty() { + return this.isObjectProperty() ? this.dimensions[0].value : null; + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + // format the parameters like "[1, 0:5]" + return this.dotNotation ? '.' + this.getObjectProperty() : '[' + this.dimensions.join(', ') + ']'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + dimensions: this.dimensions, + dotNotation: this.dotNotation + }; + } + + /** + * Instantiate an IndexNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "IndexNode", dimensions: [...], dotNotation: false}`, + * where mathjs is optional + * @returns {IndexNode} + */ + static fromJSON(json) { + return new IndexNode(json.dimensions, json.dotNotation); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + // format the parameters like "[1, 0:5]" + var dimensions = []; + for (var i = 0; i < this.dimensions.length; i++) { + dimensions[i] = this.dimensions[i].toHTML(); + } + if (this.dotNotation) { + return '.' + '' + escape(this.getObjectProperty()) + ''; + } else { + return '[' + dimensions.join(',') + ']'; + } + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var dimensions = this.dimensions.map(function (range) { + return range.toTex(options); + }); + return this.dotNotation ? '.' + this.getObjectProperty() + '' : '_{' + dimensions.join(',') + '}'; + } + } + _defineProperty(IndexNode, "name", name); + return IndexNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/Node.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/Node.js new file mode 100644 index 0000000..17a7671 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/Node.js @@ -0,0 +1,372 @@ +import { isNode } from '../../utils/is.js'; +import { keywords } from '../keywords.js'; +import { deepStrictEqual } from '../../utils/object.js'; +import { factory } from '../../utils/factory.js'; +import { createMap } from '../../utils/map.js'; +var name = 'Node'; +var dependencies = ['mathWithTransform']; +export var createNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + mathWithTransform + } = _ref; + /** + * Validate the symbol names of a scope. + * Throws an error when the scope contains an illegal symbol. + * @param {Object} scope + */ + function _validateScope(scope) { + for (var symbol of [...keywords]) { + if (scope.has(symbol)) { + throw new Error('Scope contains an illegal symbol, "' + symbol + '" is a reserved keyword'); + } + } + } + class Node { + get type() { + return 'Node'; + } + get isNode() { + return true; + } + + /** + * Evaluate the node + * @param {Object} [scope] Scope to read/write variables + * @return {*} Returns the result + */ + evaluate(scope) { + return this.compile().evaluate(scope); + } + + /** + * Compile the node into an optimized, evauatable JavaScript function + * @return {{evaluate: function([Object])}} object + * Returns an object with a function 'evaluate', + * which can be invoked as expr.evaluate([scope: Object]), + * where scope is an optional object with + * variables. + */ + compile() { + var expr = this._compile(mathWithTransform, {}); + var args = {}; + var context = null; + function evaluate(scope) { + var s = createMap(scope); + _validateScope(s); + return expr(s, args, context); + } + return { + evaluate + }; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + throw new Error('Method _compile must be implemented by type ' + this.type); + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // must be implemented by each of the Node implementations + throw new Error('Cannot run forEach on a Node interface'); + } + + /** + * Create a new Node whose children are the results of calling the + * provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {OperatorNode} Returns a transformed copy of the node + */ + map(callback) { + // must be implemented by each of the Node implementations + throw new Error('Cannot run map on a Node interface'); + } + + /** + * Validate whether an object is a Node, for use with map + * @param {Node} node + * @returns {Node} Returns the input if it's a node, else throws an Error + * @protected + */ + _ifNode(node) { + if (!isNode(node)) { + throw new TypeError('Callback function must return a Node'); + } + return node; + } + + /** + * Recursively traverse all nodes in a node tree. Executes given callback for + * this node and each of its child nodes. + * @param {function(node: Node, path: string, parent: Node)} callback + * A callback called for every node in the node tree. + */ + traverse(callback) { + // execute callback for itself + // eslint-disable-next-line + callback(this, null, null); + + // recursively traverse over all children of a node + function _traverse(node, callback) { + node.forEach(function (child, path, parent) { + callback(child, path, parent); + _traverse(child, callback); + }); + } + _traverse(this, callback); + } + + /** + * Recursively transform a node tree via a transform function. + * + * For example, to replace all nodes of type SymbolNode having name 'x' with + * a ConstantNode with value 2: + * + * const res = Node.transform(function (node, path, parent) { + * if (node && node.isSymbolNode) && (node.name === 'x')) { + * return new ConstantNode(2) + * } + * else { + * return node + * } + * }) + * + * @param {function(node: Node, path: string, parent: Node) : Node} callback + * A mapping function accepting a node, and returning + * a replacement for the node or the original node. The "signature" + * of the callback must be: + * callback(node: Node, index: string, parent: Node) : Node + * @return {Node} Returns the original node or its replacement + */ + transform(callback) { + function _transform(child, path, parent) { + var replacement = callback(child, path, parent); + if (replacement !== child) { + // stop iterating when the node is replaced + return replacement; + } + return child.map(_transform); + } + return _transform(this, null, null); + } + + /** + * Find any node in the node tree matching given filter function. For + * example, to find all nodes of type SymbolNode having name 'x': + * + * const results = Node.filter(function (node) { + * return (node && node.isSymbolNode) && (node.name === 'x') + * }) + * + * @param {function(node: Node, path: string, parent: Node) : Node} callback + * A test function returning true when a node matches, and false + * otherwise. Function signature: + * callback(node: Node, index: string, parent: Node) : boolean + * @return {Node[]} nodes + * An array with nodes matching given filter criteria + */ + filter(callback) { + var nodes = []; + this.traverse(function (node, path, parent) { + if (callback(node, path, parent)) { + nodes.push(node); + } + }); + return nodes; + } + + /** + * Create a shallow clone of this node + * @return {Node} + */ + clone() { + // must be implemented by each of the Node implementations + throw new Error('Cannot clone a Node interface'); + } + + /** + * Create a deep clone of this node + * @return {Node} + */ + cloneDeep() { + return this.map(function (node) { + return node.cloneDeep(); + }); + } + + /** + * Deep compare this node with another node. + * @param {Node} other + * @return {boolean} Returns true when both nodes are of the same type and + * contain the same values (as do their childs) + */ + equals(other) { + return other ? this.type === other.type && deepStrictEqual(this, other) : false; + } + + /** + * Get string representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)"or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toString(options) { + var customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toString(options); + } + + /** + * Internal function to generate the string output. + * This has to be implemented by every Node + * + * @throws {Error} + */ + _toString() { + // must be implemented by each of the Node implementations + throw new Error('_toString not implemented for ' + this.type); + } + + /** + * Get a JSON representation of the node + * Both .toJSON() and the static .fromJSON(json) should be implemented by all + * implementations of Node + * @returns {Object} + */ + toJSON() { + throw new Error('Cannot serialize object: toJSON not implemented by ' + this.type); + } + + /** + * Get HTML representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)" or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toHTML(options) { + var customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toHTML(options); + } + + /** + * Internal function to generate the HTML output. + * This has to be implemented by every Node + * + * @throws {Error} + */ + _toHTML() { + // must be implemented by each of the Node implementations + throw new Error('_toHTML not implemented for ' + this.type); + } + + /** + * Get LaTeX representation. (wrapper function) + * + * This function can get an object of the following form: + * { + * handler: //This can be a callback function of the form + * // "function callback(node, options)"or + * // a map that maps function names (used in FunctionNodes) + * // to callbacks + * parenthesis: "keep" //the parenthesis option (This is optional) + * } + * + * @param {Object} [options] + * @return {string} + */ + toTex(options) { + var customString = this._getCustomString(options); + if (typeof customString !== 'undefined') { + return customString; + } + return this._toTex(options); + } + + /** + * Internal function to generate the LaTeX output. + * This has to be implemented by every Node + * + * @param {Object} [options] + * @throws {Error} + */ + _toTex(options) { + // must be implemented by each of the Node implementations + throw new Error('_toTex not implemented for ' + this.type); + } + + /** + * Helper used by `to...` functions. + */ + _getCustomString(options) { + if (options && typeof options === 'object') { + switch (typeof options.handler) { + case 'object': + case 'undefined': + return; + case 'function': + return options.handler(this, options); + default: + throw new TypeError('Object or function expected as callback'); + } + } + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type; + } + + /** + * Get the content of the current Node. + * @return {Node} node + **/ + getContent() { + return this; + } + } + return Node; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ObjectNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ObjectNode.js new file mode 100644 index 0000000..c5156ef --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ObjectNode.js @@ -0,0 +1,193 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { getSafeProperty } from '../../utils/customs.js'; +import { factory } from '../../utils/factory.js'; +import { isNode } from '../../utils/is.js'; +import { hasOwnProperty } from '../../utils/object.js'; +import { escape, stringify } from '../../utils/string.js'; +var name = 'ObjectNode'; +var dependencies = ['Node']; +export var createObjectNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + class ObjectNode extends Node { + /** + * @constructor ObjectNode + * @extends {Node} + * Holds an object with keys/values + * @param {Object.} [properties] object with key/value pairs + */ + constructor(properties) { + super(); + this.properties = properties || {}; + + // validate input + if (properties) { + if (!(typeof properties === 'object') || !Object.keys(properties).every(function (key) { + return isNode(properties[key]); + })) { + throw new TypeError('Object containing Nodes expected'); + } + } + } + get type() { + return name; + } + get isObjectNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var evalEntries = {}; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + // we stringify/parse the key here to resolve unicode characters, + // so you cannot create a key like {"co\\u006Estructor": null} + var stringifiedKey = stringify(key); + var parsedKey = JSON.parse(stringifiedKey); + var prop = getSafeProperty(this.properties, key); + evalEntries[parsedKey] = prop._compile(math, argNames); + } + } + return function evalObjectNode(scope, args, context) { + var obj = {}; + for (var _key in evalEntries) { + if (hasOwnProperty(evalEntries, _key)) { + obj[_key] = evalEntries[_key](scope, args, context); + } + } + return obj; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + callback(this.properties[key], 'properties[' + stringify(key) + ']', this); + } + } + } + + /** + * Create a new ObjectNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {ObjectNode} Returns a transformed copy of the node + */ + map(callback) { + var properties = {}; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + properties[key] = this._ifNode(callback(this.properties[key], 'properties[' + stringify(key) + ']', this)); + } + } + return new ObjectNode(properties); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ObjectNode} + */ + clone() { + var properties = {}; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + properties[key] = this.properties[key]; + } + } + return new ObjectNode(properties); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + var entries = []; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + entries.push(stringify(key) + ': ' + this.properties[key].toString(options)); + } + } + return '{' + entries.join(', ') + '}'; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + properties: this.properties + }; + } + + /** + * Instantiate an OperatorNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ObjectNode", "properties": {...}}`, + * where mathjs is optional + * @returns {ObjectNode} + */ + static fromJSON(json) { + return new ObjectNode(json.properties); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + var entries = []; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + entries.push('' + escape(key) + '' + '' + ':' + this.properties[key].toHTML(options)); + } + } + return '{' + entries.join(',') + '}'; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var entries = []; + for (var key in this.properties) { + if (hasOwnProperty(this.properties, key)) { + entries.push('\\mathbf{' + key + ':} & ' + this.properties[key].toTex(options) + '\\\\'); + } + } + var tex = '\\left\\{\\begin{array}{ll}' + entries.join('\n') + '\\end{array}\\right\\}'; + return tex; + } + } + _defineProperty(ObjectNode, "name", name); + return ObjectNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/OperatorNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/OperatorNode.js new file mode 100644 index 0000000..61a8339 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/OperatorNode.js @@ -0,0 +1,629 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isNode, isConstantNode, isOperatorNode, isParenthesisNode } from '../../utils/is.js'; +import { map } from '../../utils/array.js'; +import { createSubScope } from '../../utils/scope.js'; +import { escape } from '../../utils/string.js'; +import { getSafeProperty, isSafeMethod } from '../../utils/customs.js'; +import { getAssociativity, getPrecedence, isAssociativeWith, properties } from '../operators.js'; +import { latexOperators } from '../../utils/latex.js'; +import { factory } from '../../utils/factory.js'; +var name = 'OperatorNode'; +var dependencies = ['Node']; +export var createOperatorNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + /** + * Returns true if the expression starts with a constant, under + * the current parenthesization: + * @param {Node} expression + * @param {string} parenthesis + * @return {boolean} + */ + function startsWithConstant(expr, parenthesis) { + var curNode = expr; + if (parenthesis === 'auto') { + while (isParenthesisNode(curNode)) curNode = curNode.content; + } + if (isConstantNode(curNode)) return true; + if (isOperatorNode(curNode)) { + return startsWithConstant(curNode.args[0], parenthesis); + } + return false; + } + + /** + * Calculate which parentheses are necessary. Gets an OperatorNode + * (which is the root of the tree) and an Array of Nodes + * (this.args) and returns an array where 'true' means that an argument + * has to be enclosed in parentheses whereas 'false' means the opposite. + * + * @param {OperatorNode} root + * @param {string} parenthesis + * @param {Node[]} args + * @param {boolean} latex + * @return {boolean[]} + * @private + */ + function calculateNecessaryParentheses(root, parenthesis, implicit, args, latex) { + // precedence of the root OperatorNode + var precedence = getPrecedence(root, parenthesis, implicit); + var associativity = getAssociativity(root, parenthesis); + if (parenthesis === 'all' || args.length > 2 && root.getIdentifier() !== 'OperatorNode:add' && root.getIdentifier() !== 'OperatorNode:multiply') { + return args.map(function (arg) { + switch (arg.getContent().type) { + // Nodes that don't need extra parentheses + case 'ArrayNode': + case 'ConstantNode': + case 'SymbolNode': + case 'ParenthesisNode': + return false; + default: + return true; + } + }); + } + var result; + switch (args.length) { + case 0: + result = []; + break; + case 1: + // unary operators + { + // precedence of the operand + var operandPrecedence = getPrecedence(args[0], parenthesis, implicit, root); + + // handle special cases for LaTeX, where some of the parentheses aren't needed + if (latex && operandPrecedence !== null) { + var operandIdentifier; + var rootIdentifier; + if (parenthesis === 'keep') { + operandIdentifier = args[0].getIdentifier(); + rootIdentifier = root.getIdentifier(); + } else { + // Ignore Parenthesis Nodes when not in 'keep' mode + operandIdentifier = args[0].getContent().getIdentifier(); + rootIdentifier = root.getContent().getIdentifier(); + } + if (properties[precedence][rootIdentifier].latexLeftParens === false) { + result = [false]; + break; + } + if (properties[operandPrecedence][operandIdentifier].latexParens === false) { + result = [false]; + break; + } + } + if (operandPrecedence === null) { + // if the operand has no defined precedence, no parens are needed + result = [false]; + break; + } + if (operandPrecedence <= precedence) { + // if the operands precedence is lower, parens are needed + result = [true]; + break; + } + + // otherwise, no parens needed + result = [false]; + } + break; + case 2: + // binary operators + { + var lhsParens; // left hand side needs parenthesis? + // precedence of the left hand side + var lhsPrecedence = getPrecedence(args[0], parenthesis, implicit, root); + // is the root node associative with the left hand side + var assocWithLhs = isAssociativeWith(root, args[0], parenthesis); + if (lhsPrecedence === null) { + // if the left hand side has no defined precedence, no parens are needed + // FunctionNode for example + lhsParens = false; + } else if (lhsPrecedence === precedence && associativity === 'right' && !assocWithLhs) { + // In case of equal precedence, if the root node is left associative + // parens are **never** necessary for the left hand side. + // If it is right associative however, parens are necessary + // if the root node isn't associative with the left hand side + lhsParens = true; + } else if (lhsPrecedence < precedence) { + lhsParens = true; + } else { + lhsParens = false; + } + var rhsParens; // right hand side needs parenthesis? + // precedence of the right hand side + var rhsPrecedence = getPrecedence(args[1], parenthesis, implicit, root); + // is the root node associative with the right hand side? + var assocWithRhs = isAssociativeWith(root, args[1], parenthesis); + if (rhsPrecedence === null) { + // if the right hand side has no defined precedence, no parens are needed + // FunctionNode for example + rhsParens = false; + } else if (rhsPrecedence === precedence && associativity === 'left' && !assocWithRhs) { + // In case of equal precedence, if the root node is right associative + // parens are **never** necessary for the right hand side. + // If it is left associative however, parens are necessary + // if the root node isn't associative with the right hand side + rhsParens = true; + } else if (rhsPrecedence < precedence) { + rhsParens = true; + } else { + rhsParens = false; + } + + // handle special cases for LaTeX, where some of the parentheses aren't needed + if (latex) { + var _rootIdentifier; + var lhsIdentifier; + var rhsIdentifier; + if (parenthesis === 'keep') { + _rootIdentifier = root.getIdentifier(); + lhsIdentifier = root.args[0].getIdentifier(); + rhsIdentifier = root.args[1].getIdentifier(); + } else { + // Ignore ParenthesisNodes when not in 'keep' mode + _rootIdentifier = root.getContent().getIdentifier(); + lhsIdentifier = root.args[0].getContent().getIdentifier(); + rhsIdentifier = root.args[1].getContent().getIdentifier(); + } + if (lhsPrecedence !== null) { + if (properties[precedence][_rootIdentifier].latexLeftParens === false) { + lhsParens = false; + } + if (properties[lhsPrecedence][lhsIdentifier].latexParens === false) { + lhsParens = false; + } + } + if (rhsPrecedence !== null) { + if (properties[precedence][_rootIdentifier].latexRightParens === false) { + rhsParens = false; + } + if (properties[rhsPrecedence][rhsIdentifier].latexParens === false) { + rhsParens = false; + } + } + } + result = [lhsParens, rhsParens]; + } + break; + default: + if (root.getIdentifier() === 'OperatorNode:add' || root.getIdentifier() === 'OperatorNode:multiply') { + result = args.map(function (arg) { + var argPrecedence = getPrecedence(arg, parenthesis, implicit, root); + var assocWithArg = isAssociativeWith(root, arg, parenthesis); + var argAssociativity = getAssociativity(arg, parenthesis); + if (argPrecedence === null) { + // if the argument has no defined precedence, no parens are needed + return false; + } else if (precedence === argPrecedence && associativity === argAssociativity && !assocWithArg) { + return true; + } else if (argPrecedence < precedence) { + return true; + } + return false; + }); + } + break; + } + + // Handles an edge case of parentheses with implicit multiplication + // of ConstantNode. + // In that case, parenthesize ConstantNodes that follow an unparenthesized + // expression, even though they normally wouldn't be printed. + if (args.length >= 2 && root.getIdentifier() === 'OperatorNode:multiply' && root.implicit && parenthesis !== 'all' && implicit === 'hide') { + for (var i = 1; i < result.length; ++i) { + if (startsWithConstant(args[i], parenthesis) && !result[i - 1] && (parenthesis !== 'keep' || !isParenthesisNode(args[i - 1]))) { + result[i] = true; + } + } + } + return result; + } + class OperatorNode extends Node { + /** + * @constructor OperatorNode + * @extends {Node} + * An operator with two arguments, like 2+3 + * + * @param {string} op Operator name, for example '+' + * @param {string} fn Function name, for example 'add' + * @param {Node[]} args Operator arguments + * @param {boolean} [implicit] Is this an implicit multiplication? + * @param {boolean} [isPercentage] Is this an percentage Operation? + */ + constructor(op, fn, args, implicit, isPercentage) { + super(); + // validate input + if (typeof op !== 'string') { + throw new TypeError('string expected for parameter "op"'); + } + if (typeof fn !== 'string') { + throw new TypeError('string expected for parameter "fn"'); + } + if (!Array.isArray(args) || !args.every(isNode)) { + throw new TypeError('Array containing Nodes expected for parameter "args"'); + } + this.implicit = implicit === true; + this.isPercentage = isPercentage === true; + this.op = op; + this.fn = fn; + this.args = args || []; + } + get type() { + return name; + } + get isOperatorNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + // validate fn + if (typeof this.fn !== 'string' || !isSafeMethod(math, this.fn)) { + if (!math[this.fn]) { + throw new Error('Function ' + this.fn + ' missing in provided namespace "math"'); + } else { + throw new Error('No access to function "' + this.fn + '"'); + } + } + var fn = getSafeProperty(math, this.fn); + var evalArgs = map(this.args, function (arg) { + return arg._compile(math, argNames); + }); + if (typeof fn === 'function' && fn.rawArgs === true) { + // pass unevaluated parameters (nodes) to the function + // "raw" evaluation + var rawArgs = this.args; + return function evalOperatorNode(scope, args, context) { + return fn(rawArgs, math, createSubScope(scope, args)); + }; + } else if (evalArgs.length === 1) { + var evalArg0 = evalArgs[0]; + return function evalOperatorNode(scope, args, context) { + return fn(evalArg0(scope, args, context)); + }; + } else if (evalArgs.length === 2) { + var _evalArg = evalArgs[0]; + var evalArg1 = evalArgs[1]; + return function evalOperatorNode(scope, args, context) { + return fn(_evalArg(scope, args, context), evalArg1(scope, args, context)); + }; + } else { + return function evalOperatorNode(scope, args, context) { + return fn.apply(null, map(evalArgs, function (evalArg) { + return evalArg(scope, args, context); + })); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + for (var i = 0; i < this.args.length; i++) { + callback(this.args[i], 'args[' + i + ']', this); + } + } + + /** + * Create a new OperatorNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {OperatorNode} Returns a transformed copy of the node + */ + map(callback) { + var args = []; + for (var i = 0; i < this.args.length; i++) { + args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this)); + } + return new OperatorNode(this.op, this.fn, args, this.implicit, this.isPercentage); + } + + /** + * Create a clone of this node, a shallow copy + * @return {OperatorNode} + */ + clone() { + return new OperatorNode(this.op, this.fn, this.args.slice(0), this.implicit, this.isPercentage); + } + + /** + * Check whether this is an unary OperatorNode: + * has exactly one argument, like `-a`. + * @return {boolean} + * Returns true when an unary operator node, false otherwise. + */ + isUnary() { + return this.args.length === 1; + } + + /** + * Check whether this is a binary OperatorNode: + * has exactly two arguments, like `a + b`. + * @return {boolean} + * Returns true when a binary operator node, false otherwise. + */ + isBinary() { + return this.args.length === 2; + } + + /** + * Get string representation. + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var implicit = options && options.implicit ? options.implicit : 'hide'; + var args = this.args; + var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false); + if (args.length === 1) { + // unary operators + var assoc = getAssociativity(this, parenthesis); + var operand = args[0].toString(options); + if (parens[0]) { + operand = '(' + operand + ')'; + } + + // for example for "not", we want a space between operand and argument + var opIsNamed = /[a-zA-Z]+/.test(this.op); + if (assoc === 'right') { + // prefix operator + return this.op + (opIsNamed ? ' ' : '') + operand; + } else if (assoc === 'left') { + // postfix + return operand + (opIsNamed ? ' ' : '') + this.op; + } + + // fall back to postfix + return operand + this.op; + } else if (args.length === 2) { + var lhs = args[0].toString(options); // left hand side + var rhs = args[1].toString(options); // right hand side + if (parens[0]) { + // left hand side in parenthesis? + lhs = '(' + lhs + ')'; + } + if (parens[1]) { + // right hand side in parenthesis? + rhs = '(' + rhs + ')'; + } + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return lhs + ' ' + rhs; + } + return lhs + ' ' + this.op + ' ' + rhs; + } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + var stringifiedArgs = args.map(function (arg, index) { + arg = arg.toString(options); + if (parens[index]) { + // put in parenthesis? + arg = '(' + arg + ')'; + } + return arg; + }); + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return stringifiedArgs.join(' '); + } + return stringifiedArgs.join(' ' + this.op + ' '); + } else { + // fallback to formatting as a function call + return this.fn + '(' + this.args.join(', ') + ')'; + } + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + op: this.op, + fn: this.fn, + args: this.args, + implicit: this.implicit, + isPercentage: this.isPercentage + }; + } + + /** + * Instantiate an OperatorNode from its JSON representation + * @param {Object} json + * An object structured like + * ``` + * {"mathjs": "OperatorNode", + * "op": "+", "fn": "add", "args": [...], + * "implicit": false, + * "isPercentage":false} + * ``` + * where mathjs is optional + * @returns {OperatorNode} + */ + static fromJSON(json) { + return new OperatorNode(json.op, json.fn, json.args, json.implicit, json.isPercentage); + } + + /** + * Get HTML representation. + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var implicit = options && options.implicit ? options.implicit : 'hide'; + var args = this.args; + var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false); + if (args.length === 1) { + // unary operators + var assoc = getAssociativity(this, parenthesis); + var operand = args[0].toHTML(options); + if (parens[0]) { + operand = '(' + operand + ')'; + } + if (assoc === 'right') { + // prefix operator + return '' + escape(this.op) + '' + operand; + } else { + // postfix when assoc === 'left' or undefined + return operand + '' + escape(this.op) + ''; + } + } else if (args.length === 2) { + // binary operatoes + var lhs = args[0].toHTML(options); // left hand side + var rhs = args[1].toHTML(options); // right hand side + if (parens[0]) { + // left hand side in parenthesis? + lhs = '(' + lhs + ')'; + } + if (parens[1]) { + // right hand side in parenthesis? + rhs = '(' + rhs + ')'; + } + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return lhs + '' + rhs; + } + return lhs + '' + escape(this.op) + '' + rhs; + } else { + var stringifiedArgs = args.map(function (arg, index) { + arg = arg.toHTML(options); + if (parens[index]) { + // put in parenthesis? + arg = '(' + arg + ')'; + } + return arg; + }); + if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') { + return stringifiedArgs.join(''); + } + return stringifiedArgs.join('' + escape(this.op) + ''); + } else { + // fallback to formatting as a function call + return '' + escape(this.fn) + '' + '(' + stringifiedArgs.join(',') + ')'; + } + } + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var implicit = options && options.implicit ? options.implicit : 'hide'; + var args = this.args; + var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, true); + var op = latexOperators[this.fn]; + op = typeof op === 'undefined' ? this.op : op; // fall back to using this.op + + if (args.length === 1) { + // unary operators + var assoc = getAssociativity(this, parenthesis); + var operand = args[0].toTex(options); + if (parens[0]) { + operand = "\\left(".concat(operand, "\\right)"); + } + if (assoc === 'right') { + // prefix operator + return op + operand; + } else if (assoc === 'left') { + // postfix operator + return operand + op; + } + + // fall back to postfix + return operand + op; + } else if (args.length === 2) { + // binary operators + var lhs = args[0]; // left hand side + var lhsTex = lhs.toTex(options); + if (parens[0]) { + lhsTex = "\\left(".concat(lhsTex, "\\right)"); + } + var rhs = args[1]; // right hand side + var rhsTex = rhs.toTex(options); + if (parens[1]) { + rhsTex = "\\left(".concat(rhsTex, "\\right)"); + } + + // handle some exceptions (due to the way LaTeX works) + var lhsIdentifier; + if (parenthesis === 'keep') { + lhsIdentifier = lhs.getIdentifier(); + } else { + // Ignore ParenthesisNodes if in 'keep' mode + lhsIdentifier = lhs.getContent().getIdentifier(); + } + switch (this.getIdentifier()) { + case 'OperatorNode:divide': + // op contains '\\frac' at this point + return op + '{' + lhsTex + '}' + '{' + rhsTex + '}'; + case 'OperatorNode:pow': + lhsTex = '{' + lhsTex + '}'; + rhsTex = '{' + rhsTex + '}'; + switch (lhsIdentifier) { + case 'ConditionalNode': // + case 'OperatorNode:divide': + lhsTex = "\\left(".concat(lhsTex, "\\right)"); + } + break; + case 'OperatorNode:multiply': + if (this.implicit && implicit === 'hide') { + return lhsTex + '~' + rhsTex; + } + } + return lhsTex + op + rhsTex; + } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) { + var texifiedArgs = args.map(function (arg, index) { + arg = arg.toTex(options); + if (parens[index]) { + arg = "\\left(".concat(arg, "\\right)"); + } + return arg; + }); + if (this.getIdentifier() === 'OperatorNode:multiply' && this.implicit && implicit === 'hide') { + return texifiedArgs.join('~'); + } + return texifiedArgs.join(op); + } else { + // fall back to formatting as a function call + // as this is a fallback, it doesn't use + // fancy function names + return '\\mathrm{' + this.fn + '}\\left(' + args.map(function (arg) { + return arg.toTex(options); + }).join(',') + '\\right)'; + } + } + + /** + * Get identifier. + * @return {string} + */ + getIdentifier() { + return this.type + ':' + this.fn; + } + } + _defineProperty(OperatorNode, "name", name); + return OperatorNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ParenthesisNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ParenthesisNode.js new file mode 100644 index 0000000..630f44b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/ParenthesisNode.js @@ -0,0 +1,152 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isNode } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'ParenthesisNode'; +var dependencies = ['Node']; +export var createParenthesisNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + class ParenthesisNode extends Node { + /** + * @constructor ParenthesisNode + * @extends {Node} + * A parenthesis node describes manual parenthesis from the user input + * @param {Node} content + * @extends {Node} + */ + constructor(content) { + super(); + // validate input + if (!isNode(content)) { + throw new TypeError('Node expected for parameter "content"'); + } + this.content = content; + } + get type() { + return name; + } + get isParenthesisNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + return this.content._compile(math, argNames); + } + + /** + * Get the content of the current Node. + * @return {Node} content + * @override + **/ + getContent() { + return this.content.getContent(); + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.content, 'content', this); + } + + /** + * Create a new ParenthesisNode whose child is the result of calling + * the provided callback function on the child of this node. + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {ParenthesisNode} Returns a clone of the node + */ + map(callback) { + var content = callback(this.content, 'content', this); + return new ParenthesisNode(content); + } + + /** + * Create a clone of this node, a shallow copy + * @return {ParenthesisNode} + */ + clone() { + return new ParenthesisNode(this.content); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return '(' + this.content.toString(options) + ')'; + } + return this.content.toString(options); + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + content: this.content + }; + } + + /** + * Instantiate an ParenthesisNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "ParenthesisNode", "content": ...}`, + * where mathjs is optional + * @returns {ParenthesisNode} + */ + static fromJSON(json) { + return new ParenthesisNode(json.content); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return '(' + this.content.toHTML(options) + ')'; + } + return this.content.toHTML(options); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + * @override + */ + _toTex(options) { + if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') { + return "\\left(".concat(this.content.toTex(options), "\\right)"); + } + return this.content.toTex(options); + } + } + _defineProperty(ParenthesisNode, "name", name); + return ParenthesisNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RangeNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RangeNode.js new file mode 100644 index 0000000..e30edf7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RangeNode.js @@ -0,0 +1,250 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { isNode, isSymbolNode } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { getPrecedence } from '../operators.js'; +var name = 'RangeNode'; +var dependencies = ['Node']; +export var createRangeNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + /** + * Calculate the necessary parentheses + * @param {Node} node + * @param {string} parenthesis + * @param {string} implicit + * @return {Object} parentheses + * @private + */ + function calculateNecessaryParentheses(node, parenthesis, implicit) { + var precedence = getPrecedence(node, parenthesis, implicit); + var parens = {}; + var startPrecedence = getPrecedence(node.start, parenthesis, implicit); + parens.start = startPrecedence !== null && startPrecedence <= precedence || parenthesis === 'all'; + if (node.step) { + var stepPrecedence = getPrecedence(node.step, parenthesis, implicit); + parens.step = stepPrecedence !== null && stepPrecedence <= precedence || parenthesis === 'all'; + } + var endPrecedence = getPrecedence(node.end, parenthesis, implicit); + parens.end = endPrecedence !== null && endPrecedence <= precedence || parenthesis === 'all'; + return parens; + } + class RangeNode extends Node { + /** + * @constructor RangeNode + * @extends {Node} + * create a range + * @param {Node} start included lower-bound + * @param {Node} end included upper-bound + * @param {Node} [step] optional step + */ + constructor(start, end, step) { + super(); + // validate inputs + if (!isNode(start)) throw new TypeError('Node expected'); + if (!isNode(end)) throw new TypeError('Node expected'); + if (step && !isNode(step)) throw new TypeError('Node expected'); + if (arguments.length > 3) throw new Error('Too many arguments'); + this.start = start; // included lower-bound + this.end = end; // included upper-bound + this.step = step || null; // optional step + } + get type() { + return name; + } + get isRangeNode() { + return true; + } + + /** + * Check whether the RangeNode needs the `end` symbol to be defined. + * This end is the size of the Matrix in current dimension. + * @return {boolean} + */ + needsEnd() { + // find all `end` symbols in this RangeNode + var endSymbols = this.filter(function (node) { + return isSymbolNode(node) && node.name === 'end'; + }); + return endSymbols.length > 0; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var range = math.range; + var evalStart = this.start._compile(math, argNames); + var evalEnd = this.end._compile(math, argNames); + if (this.step) { + var evalStep = this.step._compile(math, argNames); + return function evalRangeNode(scope, args, context) { + return range(evalStart(scope, args, context), evalEnd(scope, args, context), evalStep(scope, args, context)); + }; + } else { + return function evalRangeNode(scope, args, context) { + return range(evalStart(scope, args, context), evalEnd(scope, args, context)); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + callback(this.start, 'start', this); + callback(this.end, 'end', this); + if (this.step) { + callback(this.step, 'step', this); + } + } + + /** + * Create a new RangeNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {RangeNode} Returns a transformed copy of the node + */ + map(callback) { + return new RangeNode(this._ifNode(callback(this.start, 'start', this)), this._ifNode(callback(this.end, 'end', this)), this.step && this._ifNode(callback(this.step, 'step', this))); + } + + /** + * Create a clone of this node, a shallow copy + * @return {RangeNode} + */ + clone() { + return new RangeNode(this.start, this.end, this.step && this.step); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + + // format string as start:step:stop + var str; + var start = this.start.toString(options); + if (parens.start) { + start = '(' + start + ')'; + } + str = start; + if (this.step) { + var step = this.step.toString(options); + if (parens.step) { + step = '(' + step + ')'; + } + str += ':' + step; + } + var end = this.end.toString(options); + if (parens.end) { + end = '(' + end + ')'; + } + str += ':' + end; + return str; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + start: this.start, + end: this.end, + step: this.step + }; + } + + /** + * Instantiate an RangeNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "RangeNode", "start": ..., "end": ..., "step": ...}`, + * where mathjs is optional + * @returns {RangeNode} + */ + static fromJSON(json) { + return new RangeNode(json.start, json.end, json.step); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + + // format string as start:step:stop + var str; + var start = this.start.toHTML(options); + if (parens.start) { + start = '(' + start + ')'; + } + str = start; + if (this.step) { + var step = this.step.toHTML(options); + if (parens.step) { + step = '(' + step + ')'; + } + str += ':' + step; + } + var end = this.end.toHTML(options); + if (parens.end) { + end = '(' + end + ')'; + } + str += ':' + end; + return str; + } + + /** + * Get LaTeX representation + * @params {Object} options + * @return {string} str + */ + _toTex(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var parens = calculateNecessaryParentheses(this, parenthesis, options && options.implicit); + var str = this.start.toTex(options); + if (parens.start) { + str = "\\left(".concat(str, "\\right)"); + } + if (this.step) { + var step = this.step.toTex(options); + if (parens.step) { + step = "\\left(".concat(step, "\\right)"); + } + str += ':' + step; + } + var end = this.end.toTex(options); + if (parens.end) { + end = "\\left(".concat(end, "\\right)"); + } + str += ':' + end; + return str; + } + } + _defineProperty(RangeNode, "name", name); + return RangeNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RelationalNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RelationalNode.js new file mode 100644 index 0000000..dd654c7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/RelationalNode.js @@ -0,0 +1,198 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import { getPrecedence } from '../operators.js'; +import { escape } from '../../utils/string.js'; +import { getSafeProperty } from '../../utils/customs.js'; +import { latexOperators } from '../../utils/latex.js'; +import { factory } from '../../utils/factory.js'; +var name = 'RelationalNode'; +var dependencies = ['Node']; +export var createRelationalNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Node + } = _ref; + var operatorMap = { + equal: '==', + unequal: '!=', + smaller: '<', + larger: '>', + smallerEq: '<=', + largerEq: '>=' + }; + class RelationalNode extends Node { + /** + * A node representing a chained conditional expression, such as 'x > y > z' + * + * @param {String[]} conditionals + * An array of conditional operators used to compare the parameters + * @param {Node[]} params + * The parameters that will be compared + * + * @constructor RelationalNode + * @extends {Node} + */ + constructor(conditionals, params) { + super(); + if (!Array.isArray(conditionals)) { + throw new TypeError('Parameter conditionals must be an array'); + } + if (!Array.isArray(params)) { + throw new TypeError('Parameter params must be an array'); + } + if (conditionals.length !== params.length - 1) { + throw new TypeError('Parameter params must contain exactly one more element ' + 'than parameter conditionals'); + } + this.conditionals = conditionals; + this.params = params; + } + get type() { + return name; + } + get isRelationalNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var self = this; + var compiled = this.params.map(p => p._compile(math, argNames)); + return function evalRelationalNode(scope, args, context) { + var evalLhs; + var evalRhs = compiled[0](scope, args, context); + for (var i = 0; i < self.conditionals.length; i++) { + evalLhs = evalRhs; + evalRhs = compiled[i + 1](scope, args, context); + var condFn = getSafeProperty(math, self.conditionals[i]); + if (!condFn(evalLhs, evalRhs)) { + return false; + } + } + return true; + }; + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + this.params.forEach((n, i) => callback(n, 'params[' + i + ']', this), this); + } + + /** + * Create a new RelationalNode whose children are the results of calling + * the provided callback function for each child of the original node. + * @param {function(child: Node, path: string, parent: Node): Node} callback + * @returns {RelationalNode} Returns a transformed copy of the node + */ + map(callback) { + return new RelationalNode(this.conditionals.slice(), this.params.map((n, i) => this._ifNode(callback(n, 'params[' + i + ']', this)), this)); + } + + /** + * Create a clone of this node, a shallow copy + * @return {RelationalNode} + */ + clone() { + return new RelationalNode(this.conditionals, this.params); + } + + /** + * Get string representation. + * @param {Object} options + * @return {string} str + */ + _toString(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var precedence = getPrecedence(this, parenthesis, options && options.implicit); + var paramStrings = this.params.map(function (p, index) { + var paramPrecedence = getPrecedence(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toString(options) + ')' : p.toString(options); + }); + var ret = paramStrings[0]; + for (var i = 0; i < this.conditionals.length; i++) { + ret += ' ' + operatorMap[this.conditionals[i]]; + ret += ' ' + paramStrings[i + 1]; + } + return ret; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: name, + conditionals: this.conditionals, + params: this.params + }; + } + + /** + * Instantiate a RelationalNode from its JSON representation + * @param {Object} json + * An object structured like + * `{"mathjs": "RelationalNode", "conditionals": ..., "params": ...}`, + * where mathjs is optional + * @returns {RelationalNode} + */ + static fromJSON(json) { + return new RelationalNode(json.conditionals, json.params); + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + */ + _toHTML(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var precedence = getPrecedence(this, parenthesis, options && options.implicit); + var paramStrings = this.params.map(function (p, index) { + var paramPrecedence = getPrecedence(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toHTML(options) + ')' : p.toHTML(options); + }); + var ret = paramStrings[0]; + for (var i = 0; i < this.conditionals.length; i++) { + ret += '' + escape(operatorMap[this.conditionals[i]]) + '' + paramStrings[i + 1]; + } + return ret; + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + */ + _toTex(options) { + var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep'; + var precedence = getPrecedence(this, parenthesis, options && options.implicit); + var paramStrings = this.params.map(function (p, index) { + var paramPrecedence = getPrecedence(p, parenthesis, options && options.implicit); + return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '\\left(' + p.toTex(options) + '\right)' : p.toTex(options); + }); + var ret = paramStrings[0]; + for (var i = 0; i < this.conditionals.length; i++) { + ret += latexOperators[this.conditionals[i]] + paramStrings[i + 1]; + } + return ret; + } + } + _defineProperty(RelationalNode, "name", name); + return RelationalNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/SymbolNode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/SymbolNode.js new file mode 100644 index 0000000..1f46062 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/SymbolNode.js @@ -0,0 +1,193 @@ +import { escape } from '../../utils/string.js'; +import { getSafeProperty } from '../../utils/customs.js'; +import { factory } from '../../utils/factory.js'; +import { toSymbol } from '../../utils/latex.js'; +var name = 'SymbolNode'; +var dependencies = ['math', '?Unit', 'Node']; +export var createSymbolNode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + math, + Unit, + Node + } = _ref; + /** + * Check whether some name is a valueless unit like "inch". + * @param {string} name + * @return {boolean} + */ + function isValuelessUnit(name) { + return Unit ? Unit.isValuelessUnit(name) : false; + } + class SymbolNode extends Node { + /** + * @constructor SymbolNode + * @extends {Node} + * A symbol node can hold and resolve a symbol + * @param {string} name + * @extends {Node} + */ + constructor(name) { + super(); + // validate input + if (typeof name !== 'string') { + throw new TypeError('String expected for parameter "name"'); + } + this.name = name; + } + get type() { + return 'SymbolNode'; + } + get isSymbolNode() { + return true; + } + + /** + * Compile a node into a JavaScript function. + * This basically pre-calculates as much as possible and only leaves open + * calculations which depend on a dynamic scope with variables. + * @param {Object} math Math.js namespace with functions and constants. + * @param {Object} argNames An object with argument names as key and `true` + * as value. Used in the SymbolNode to optimize + * for arguments from user assigned functions + * (see FunctionAssignmentNode) or special symbols + * like `end` (see IndexNode). + * @return {function} Returns a function which can be called like: + * evalNode(scope: Object, args: Object, context: *) + */ + _compile(math, argNames) { + var name = this.name; + if (argNames[name] === true) { + // this is a FunctionAssignment argument + // (like an x when inside the expression of a function + // assignment `f(x) = ...`) + return function (scope, args, context) { + return getSafeProperty(args, name); + }; + } else if (name in math) { + return function (scope, args, context) { + return scope.has(name) ? scope.get(name) : getSafeProperty(math, name); + }; + } else { + var isUnit = isValuelessUnit(name); + return function (scope, args, context) { + return scope.has(name) ? scope.get(name) : isUnit ? new Unit(null, name) : SymbolNode.onUndefinedSymbol(name); + }; + } + } + + /** + * Execute a callback for each of the child nodes of this node + * @param {function(child: Node, path: string, parent: Node)} callback + */ + forEach(callback) { + // nothing to do, we don't have any children + } + + /** + * Create a new SymbolNode with children produced by the given callback. + * Trivial since a SymbolNode has no children + * @param {function(child: Node, path: string, parent: Node) : Node} callback + * @returns {SymbolNode} Returns a clone of the node + */ + map(callback) { + return this.clone(); + } + + /** + * Throws an error 'Undefined symbol {name}' + * @param {string} name + */ + static onUndefinedSymbol(name) { + throw new Error('Undefined symbol ' + name); + } + + /** + * Create a clone of this node, a shallow copy + * @return {SymbolNode} + */ + clone() { + return new SymbolNode(this.name); + } + + /** + * Get string representation + * @param {Object} options + * @return {string} str + * @override + */ + _toString(options) { + return this.name; + } + + /** + * Get HTML representation + * @param {Object} options + * @return {string} str + * @override + */ + _toHTML(options) { + var name = escape(this.name); + if (name === 'true' || name === 'false') { + return '' + name + ''; + } else if (name === 'i') { + return '' + name + ''; + } else if (name === 'Infinity') { + return '' + name + ''; + } else if (name === 'NaN') { + return '' + name + ''; + } else if (name === 'null') { + return '' + name + ''; + } else if (name === 'undefined') { + return '' + name + ''; + } + return '' + name + ''; + } + + /** + * Get a JSON representation of the node + * @returns {Object} + */ + toJSON() { + return { + mathjs: 'SymbolNode', + name: this.name + }; + } + + /** + * Instantiate a SymbolNode from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "SymbolNode", name: "x"}`, + * where mathjs is optional + * @returns {SymbolNode} + */ + static fromJSON(json) { + return new SymbolNode(json.name); + } + + /** + * Get LaTeX representation + * @param {Object} options + * @return {string} str + * @override + */ + _toTex(options) { + var isUnit = false; + if (typeof math[this.name] === 'undefined' && isValuelessUnit(this.name)) { + isUnit = true; + } + var symbol = toSymbol(this.name, isUnit); + if (symbol[0] === '\\') { + // no space needed if the symbol starts with '\' + return symbol; + } + // the space prevents symbols from breaking stuff like '\cdot' + // if it's written right before the symbol + return ' ' + symbol; + } + } + return SymbolNode; +}, { + isClass: true, + isNode: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/access.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/access.js new file mode 100644 index 0000000..4da61c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/access.js @@ -0,0 +1,40 @@ +import { errorTransform } from '../../transform/utils/errorTransform.js'; +import { getSafeProperty } from '../../../utils/customs.js'; +export function accessFactory(_ref) { + var { + subset + } = _ref; + /** + * Retrieve part of an object: + * + * - Retrieve a property from an object + * - Retrieve a part of a string + * - Retrieve a matrix subset + * + * @param {Object | Array | Matrix | string} object + * @param {Index} index + * @return {Object | Array | Matrix | string} Returns the subset + */ + return function access(object, index) { + try { + if (Array.isArray(object)) { + return subset(object, index); + } else if (object && typeof object.subset === 'function') { + // Matrix + return object.subset(index); + } else if (typeof object === 'string') { + // TODO: move getStringSubset into a separate util file, use that + return subset(object, index); + } else if (typeof object === 'object') { + if (!index.isObjectProperty()) { + throw new TypeError('Cannot apply a numeric index as object property'); + } + return getSafeProperty(object, index.getObjectProperty()); + } else { + throw new TypeError('Cannot apply index: unsupported type of object'); + } + } catch (err) { + throw errorTransform(err); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/assign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/assign.js new file mode 100644 index 0000000..84fd91c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/node/utils/assign.js @@ -0,0 +1,51 @@ +import { errorTransform } from '../../transform/utils/errorTransform.js'; +import { setSafeProperty } from '../../../utils/customs.js'; +export function assignFactory(_ref) { + var { + subset, + matrix + } = _ref; + /** + * Replace part of an object: + * + * - Assign a property to an object + * - Replace a part of a string + * - Replace a matrix subset + * + * @param {Object | Array | Matrix | string} object + * @param {Index} index + * @param {*} value + * @return {Object | Array | Matrix | string} Returns the original object + * except in case of a string + */ + // TODO: change assign to return the value instead of the object + return function assign(object, index, value) { + try { + if (Array.isArray(object)) { + var result = matrix(object).subset(index, value).valueOf(); + + // shallow copy all (updated) items into the original array + result.forEach((item, index) => { + object[index] = item; + }); + return object; + } else if (object && typeof object.subset === 'function') { + // Matrix + return object.subset(index, value); + } else if (typeof object === 'string') { + // TODO: move setStringSubset into a separate util file, use that + return subset(object, index, value); + } else if (typeof object === 'object') { + if (!index.isObjectProperty()) { + throw TypeError('Cannot apply a numeric index as object property'); + } + setSafeProperty(object, index.getObjectProperty(), value); + return object; + } else { + throw new TypeError('Cannot apply index: unsupported type of object'); + } + } catch (err) { + throw errorTransform(err); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/operators.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/operators.js new file mode 100644 index 0000000..91ea92d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/operators.js @@ -0,0 +1,377 @@ +// list of identifiers of nodes in order of their precedence +// also contains information about left/right associativity +// and which other operator the operator is associative with +// Example: +// addition is associative with addition and subtraction, because: +// (a+b)+c=a+(b+c) +// (a+b)-c=a+(b-c) +// +// postfix operators are left associative, prefix operators +// are right associative +// +// It's also possible to set the following properties: +// latexParens: if set to false, this node doesn't need to be enclosed +// in parentheses when using LaTeX +// latexLeftParens: if set to false, this !OperatorNode's! +// left argument doesn't need to be enclosed +// in parentheses +// latexRightParens: the same for the right argument +import { hasOwnProperty } from '../utils/object.js'; +import { isConstantNode, isParenthesisNode, rule2Node } from '../utils/is.js'; +export var properties = [{ + // assignment + AssignmentNode: {}, + FunctionAssignmentNode: {} +}, { + // conditional expression + ConditionalNode: { + latexLeftParens: false, + latexRightParens: false, + latexParens: false + // conditionals don't need parentheses in LaTeX because + // they are 2 dimensional + } +}, { + // logical or + 'OperatorNode:or': { + op: 'or', + associativity: 'left', + associativeWith: [] + } +}, { + // logical xor + 'OperatorNode:xor': { + op: 'xor', + associativity: 'left', + associativeWith: [] + } +}, { + // logical and + 'OperatorNode:and': { + op: 'and', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise or + 'OperatorNode:bitOr': { + op: '|', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise xor + 'OperatorNode:bitXor': { + op: '^|', + associativity: 'left', + associativeWith: [] + } +}, { + // bitwise and + 'OperatorNode:bitAnd': { + op: '&', + associativity: 'left', + associativeWith: [] + } +}, { + // relational operators + 'OperatorNode:equal': { + op: '==', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:unequal': { + op: '!=', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:smaller': { + op: '<', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:larger': { + op: '>', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:smallerEq': { + op: '<=', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:largerEq': { + op: '>=', + associativity: 'left', + associativeWith: [] + }, + RelationalNode: { + associativity: 'left', + associativeWith: [] + } +}, { + // bitshift operators + 'OperatorNode:leftShift': { + op: '<<', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:rightArithShift': { + op: '>>', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:rightLogShift': { + op: '>>>', + associativity: 'left', + associativeWith: [] + } +}, { + // unit conversion + 'OperatorNode:to': { + op: 'to', + associativity: 'left', + associativeWith: [] + } +}, { + // range + RangeNode: {} +}, { + // addition, subtraction + 'OperatorNode:add': { + op: '+', + associativity: 'left', + associativeWith: ['OperatorNode:add', 'OperatorNode:subtract'] + }, + 'OperatorNode:subtract': { + op: '-', + associativity: 'left', + associativeWith: [] + } +}, { + // multiply, divide, modulus + 'OperatorNode:multiply': { + op: '*', + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'Operator:dotMultiply', 'Operator:dotDivide'] + }, + 'OperatorNode:divide': { + op: '/', + associativity: 'left', + associativeWith: [], + latexLeftParens: false, + latexRightParens: false, + latexParens: false + // fractions don't require parentheses because + // they're 2 dimensional, so parens aren't needed + // in LaTeX + }, + 'OperatorNode:dotMultiply': { + op: '.*', + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'OperatorNode:dotMultiply', 'OperatorNode:doDivide'] + }, + 'OperatorNode:dotDivide': { + op: './', + associativity: 'left', + associativeWith: [] + }, + 'OperatorNode:mod': { + op: 'mod', + associativity: 'left', + associativeWith: [] + } +}, { + // Repeat multiplication for implicit multiplication + 'OperatorNode:multiply': { + associativity: 'left', + associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'Operator:dotMultiply', 'Operator:dotDivide'] + } +}, { + // unary prefix operators + 'OperatorNode:unaryPlus': { + op: '+', + associativity: 'right' + }, + 'OperatorNode:unaryMinus': { + op: '-', + associativity: 'right' + }, + 'OperatorNode:bitNot': { + op: '~', + associativity: 'right' + }, + 'OperatorNode:not': { + op: 'not', + associativity: 'right' + } +}, { + // exponentiation + 'OperatorNode:pow': { + op: '^', + associativity: 'right', + associativeWith: [], + latexRightParens: false + // the exponent doesn't need parentheses in + // LaTeX because it's 2 dimensional + // (it's on top) + }, + 'OperatorNode:dotPow': { + op: '.^', + associativity: 'right', + associativeWith: [] + } +}, { + // factorial + 'OperatorNode:factorial': { + op: '!', + associativity: 'left' + } +}, { + // matrix transpose + 'OperatorNode:ctranspose': { + op: "'", + associativity: 'left' + } +}]; + +/** + * Returns the first non-parenthesis internal node, but only + * when the 'parenthesis' option is unset or auto. + * @param {Node} _node + * @param {string} parenthesis + * @return {Node} + */ +function unwrapParen(_node, parenthesis) { + if (!parenthesis || parenthesis !== 'auto') return _node; + var node = _node; + while (isParenthesisNode(node)) node = node.content; + return node; +} + +/** + * Get the precedence of a Node. + * Higher number for higher precedence, starting with 0. + * Returns null if the precedence is undefined. + * + * @param {Node} _node + * @param {string} parenthesis + * @param {string} implicit + * @param {Node} parent (for determining context for implicit multiplication) + * @return {number | null} + */ +export function getPrecedence(_node, parenthesis, implicit, parent) { + var node = _node; + if (parenthesis !== 'keep') { + // ParenthesisNodes are only ignored when not in 'keep' mode + node = _node.getContent(); + } + var identifier = node.getIdentifier(); + var precedence = null; + for (var i = 0; i < properties.length; i++) { + if (identifier in properties[i]) { + precedence = i; + break; + } + } + // Bump up precedence of implicit multiplication, except when preceded + // by a "Rule 2" fraction ( [unaryOp]constant / constant ) + if (identifier === 'OperatorNode:multiply' && node.implicit && implicit !== 'show') { + var leftArg = unwrapParen(node.args[0], parenthesis); + if (!(isConstantNode(leftArg) && parent && parent.getIdentifier() === 'OperatorNode:divide' && rule2Node(unwrapParen(parent.args[0], parenthesis))) && !(leftArg.getIdentifier() === 'OperatorNode:divide' && rule2Node(unwrapParen(leftArg.args[0], parenthesis)) && isConstantNode(unwrapParen(leftArg.args[1])))) { + precedence += 1; + } + } + return precedence; +} + +/** + * Get the associativity of an operator (left or right). + * Returns a string containing 'left' or 'right' or null if + * the associativity is not defined. + * + * @param {Node} _node + * @param {string} parenthesis + * @return {string|null} + * @throws {Error} + */ +export function getAssociativity(_node, parenthesis) { + var node = _node; + if (parenthesis !== 'keep') { + // ParenthesisNodes are only ignored when not in 'keep' mode + node = _node.getContent(); + } + var identifier = node.getIdentifier(); + var index = getPrecedence(node, parenthesis); + if (index === null) { + // node isn't in the list + return null; + } + var property = properties[index][identifier]; + if (hasOwnProperty(property, 'associativity')) { + if (property.associativity === 'left') { + return 'left'; + } + if (property.associativity === 'right') { + return 'right'; + } + // associativity is invalid + throw Error('\'' + identifier + '\' has the invalid associativity \'' + property.associativity + '\'.'); + } + + // associativity is undefined + return null; +} + +/** + * Check if an operator is associative with another operator. + * Returns either true or false or null if not defined. + * + * @param {Node} nodeA + * @param {Node} nodeB + * @param {string} parenthesis + * @return {boolean | null} + */ +export function isAssociativeWith(nodeA, nodeB, parenthesis) { + // ParenthesisNodes are only ignored when not in 'keep' mode + var a = parenthesis !== 'keep' ? nodeA.getContent() : nodeA; + var b = parenthesis !== 'keep' ? nodeA.getContent() : nodeB; + var identifierA = a.getIdentifier(); + var identifierB = b.getIdentifier(); + var index = getPrecedence(a, parenthesis); + if (index === null) { + // node isn't in the list + return null; + } + var property = properties[index][identifierA]; + if (hasOwnProperty(property, 'associativeWith') && property.associativeWith instanceof Array) { + for (var i = 0; i < property.associativeWith.length; i++) { + if (property.associativeWith[i] === identifierB) { + return true; + } + } + return false; + } + + // associativeWith is not defined + return null; +} + +/** + * Get the operator associated with a function name. + * Returns a string with the operator symbol, or null if the + * input is not the name of a function associated with an + * operator. + * + * @param {string} Function name + * @return {string | null} Associated operator symbol, if any + */ +export function getOperator(fn) { + var identifier = 'OperatorNode:' + fn; + for (var group of properties) { + if (identifier in group) { + return group[identifier].op; + } + } + return null; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/parse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/parse.js new file mode 100644 index 0000000..9feff95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/parse.js @@ -0,0 +1,1634 @@ +import _extends from "@babel/runtime/helpers/extends"; +import { factory } from '../utils/factory.js'; +import { isAccessorNode, isConstantNode, isFunctionNode, isOperatorNode, isSymbolNode, rule2Node } from '../utils/is.js'; +import { deepMap } from '../utils/collection.js'; +import { safeNumberType } from '../utils/number.js'; +import { hasOwnProperty } from '../utils/object.js'; +var name = 'parse'; +var dependencies = ['typed', 'numeric', 'config', 'AccessorNode', 'ArrayNode', 'AssignmentNode', 'BlockNode', 'ConditionalNode', 'ConstantNode', 'FunctionAssignmentNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'RangeNode', 'RelationalNode', 'SymbolNode']; +export var createParse = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + numeric, + config, + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode + } = _ref; + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(). + * + * Note the evaluating arbitrary expressions may involve security risks, + * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information. + * + * Syntax: + * + * math.parse(expr) + * math.parse(expr, options) + * math.parse([expr1, expr2, expr3, ...]) + * math.parse([expr1, expr2, expr3, ...], options) + * + * Example: + * + * const node1 = math.parse('sqrt(3^2 + 4^2)') + * node1.compile().evaluate() // 5 + * + * let scope = {a:3, b:4} + * const node2 = math.parse('a * b') // 12 + * const code2 = node2.compile() + * code2.evaluate(scope) // 12 + * scope.a = 5 + * code2.evaluate(scope) // 20 + * + * const nodes = math.parse(['a = 3', 'b = 4', 'a * b']) + * nodes[2].compile().evaluate() // 12 + * + * See also: + * + * evaluate, compile + * + * @param {string | string[] | Matrix} expr Expression to be parsed + * @param {{nodes: Object}} [options] Available options: + * - `nodes` a set of custom nodes + * @return {Node | Node[]} node + * @throws {Error} + */ + var parse = typed(name, { + string: function string(expression) { + return parseStart(expression, {}); + }, + 'Array | Matrix': function Array__Matrix(expressions) { + return parseMultiple(expressions, {}); + }, + 'string, Object': function string_Object(expression, options) { + var extraNodes = options.nodes !== undefined ? options.nodes : {}; + return parseStart(expression, extraNodes); + }, + 'Array | Matrix, Object': parseMultiple + }); + function parseMultiple(expressions) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var extraNodes = options.nodes !== undefined ? options.nodes : {}; + + // parse an array or matrix with expressions + return deepMap(expressions, function (elem) { + if (typeof elem !== 'string') throw new TypeError('String expected'); + return parseStart(elem, extraNodes); + }); + } + + // token types enumeration + var TOKENTYPE = { + NULL: 0, + DELIMITER: 1, + NUMBER: 2, + SYMBOL: 3, + UNKNOWN: 4 + }; + + // map with all delimiters + var DELIMITERS = { + ',': true, + '(': true, + ')': true, + '[': true, + ']': true, + '{': true, + '}': true, + '"': true, + '\'': true, + ';': true, + '+': true, + '-': true, + '*': true, + '.*': true, + '/': true, + './': true, + '%': true, + '^': true, + '.^': true, + '~': true, + '!': true, + '&': true, + '|': true, + '^|': true, + '=': true, + ':': true, + '?': true, + '==': true, + '!=': true, + '<': true, + '>': true, + '<=': true, + '>=': true, + '<<': true, + '>>': true, + '>>>': true + }; + + // map with all named delimiters + var NAMED_DELIMITERS = { + mod: true, + to: true, + in: true, + and: true, + xor: true, + or: true, + not: true + }; + var CONSTANTS = { + true: true, + false: false, + null: null, + undefined + }; + var NUMERIC_CONSTANTS = ['NaN', 'Infinity']; + var ESCAPE_CHARACTERS = { + '"': '"', + "'": "'", + '\\': '\\', + '/': '/', + b: '\b', + f: '\f', + n: '\n', + r: '\r', + t: '\t' + // note that \u is handled separately in parseStringToken() + }; + function initialState() { + return { + extraNodes: {}, + // current extra nodes, must be careful not to mutate + expression: '', + // current expression + comment: '', + // last parsed comment + index: 0, + // current index in expr + token: '', + // current token + tokenType: TOKENTYPE.NULL, + // type of the token + nestingLevel: 0, + // level of nesting inside parameters, used to ignore newline characters + conditionalLevel: null // when a conditional is being parsed, the level of the conditional is stored here + }; + } + + /** + * View upto `length` characters of the expression starting at the current character. + * + * @param {Object} state + * @param {number} [length=1] Number of characters to view + * @returns {string} + * @private + */ + function currentString(state, length) { + return state.expression.substr(state.index, length); + } + + /** + * View the current character. Returns '' if end of expression is reached. + * + * @param {Object} state + * @returns {string} + * @private + */ + function currentCharacter(state) { + return currentString(state, 1); + } + + /** + * Get the next character from the expression. + * The character is stored into the char c. If the end of the expression is + * reached, the function puts an empty string in c. + * @private + */ + function next(state) { + state.index++; + } + + /** + * Preview the previous character from the expression. + * @return {string} cNext + * @private + */ + function prevCharacter(state) { + return state.expression.charAt(state.index - 1); + } + + /** + * Preview the next character from the expression. + * @return {string} cNext + * @private + */ + function nextCharacter(state) { + return state.expression.charAt(state.index + 1); + } + + /** + * Get next token in the current string expr. + * The token and token type are available as token and tokenType + * @private + */ + function getToken(state) { + state.tokenType = TOKENTYPE.NULL; + state.token = ''; + state.comment = ''; + + // skip over ignored characters: + while (true) { + // comments: + if (currentCharacter(state) === '#') { + while (currentCharacter(state) !== '\n' && currentCharacter(state) !== '') { + state.comment += currentCharacter(state); + next(state); + } + } + // whitespace: space, tab, and newline when inside parameters + if (parse.isWhitespace(currentCharacter(state), state.nestingLevel)) { + next(state); + } else { + break; + } + } + + // check for end of expression + if (currentCharacter(state) === '') { + // token is still empty + state.tokenType = TOKENTYPE.DELIMITER; + return; + } + + // check for new line character + if (currentCharacter(state) === '\n' && !state.nestingLevel) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = currentCharacter(state); + next(state); + return; + } + var c1 = currentCharacter(state); + var c2 = currentString(state, 2); + var c3 = currentString(state, 3); + if (c3.length === 3 && DELIMITERS[c3]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c3; + next(state); + next(state); + next(state); + return; + } + + // check for delimiters consisting of 2 characters + if (c2.length === 2 && DELIMITERS[c2]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c2; + next(state); + next(state); + return; + } + + // check for delimiters consisting of 1 character + if (DELIMITERS[c1]) { + state.tokenType = TOKENTYPE.DELIMITER; + state.token = c1; + next(state); + return; + } + + // check for a number + if (parse.isDigitDot(c1)) { + state.tokenType = TOKENTYPE.NUMBER; + + // check for binary, octal, or hex + var _c = currentString(state, 2); + if (_c === '0b' || _c === '0o' || _c === '0x') { + state.token += currentCharacter(state); + next(state); + state.token += currentCharacter(state); + next(state); + while (parse.isHexDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (currentCharacter(state) === '.') { + // this number has a radix point + state.token += '.'; + next(state); + // get the digits after the radix + while (parse.isHexDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } else if (currentCharacter(state) === 'i') { + // this number has a word size suffix + state.token += 'i'; + next(state); + // get the word size + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } + return; + } + + // get number, can have a single dot + if (currentCharacter(state) === '.') { + state.token += currentCharacter(state); + next(state); + if (!parse.isDigit(currentCharacter(state))) { + // this is no number, it is just a dot (can be dot notation) + state.tokenType = TOKENTYPE.DELIMITER; + return; + } + } else { + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + } + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + // check for exponential notation like "2.3e-4", "1.23e50" or "2e+4" + if (currentCharacter(state) === 'E' || currentCharacter(state) === 'e') { + if (parse.isDigit(nextCharacter(state)) || nextCharacter(state) === '-' || nextCharacter(state) === '+') { + state.token += currentCharacter(state); + next(state); + if (currentCharacter(state) === '+' || currentCharacter(state) === '-') { + state.token += currentCharacter(state); + next(state); + } + // Scientific notation MUST be followed by an exponent + if (!parse.isDigit(currentCharacter(state))) { + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + while (parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) { + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + } else if (nextCharacter(state) === '.') { + next(state); + throw createSyntaxError(state, 'Digit expected, got "' + currentCharacter(state) + '"'); + } + } + return; + } + + // check for variables, functions, named operators + if (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state))) { + while (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state)) || parse.isDigit(currentCharacter(state))) { + state.token += currentCharacter(state); + next(state); + } + if (hasOwnProperty(NAMED_DELIMITERS, state.token)) { + state.tokenType = TOKENTYPE.DELIMITER; + } else { + state.tokenType = TOKENTYPE.SYMBOL; + } + return; + } + + // something unknown is found, wrong characters -> a syntax error + state.tokenType = TOKENTYPE.UNKNOWN; + while (currentCharacter(state) !== '') { + state.token += currentCharacter(state); + next(state); + } + throw createSyntaxError(state, 'Syntax error in part "' + state.token + '"'); + } + + /** + * Get next token and skip newline tokens + */ + function getTokenSkipNewline(state) { + do { + getToken(state); + } while (state.token === '\n'); // eslint-disable-line no-unmodified-loop-condition + } + + /** + * Open parameters. + * New line characters will be ignored until closeParams(state) is called + */ + function openParams(state) { + state.nestingLevel++; + } + + /** + * Close parameters. + * New line characters will no longer be ignored + */ + function closeParams(state) { + state.nestingLevel--; + } + + /** + * Checks whether the current character `c` is a valid alpha character: + * + * - A latin letter (upper or lower case) Ascii: a-z, A-Z + * - An underscore Ascii: _ + * - A dollar sign Ascii: $ + * - A latin letter with accents Unicode: \u00C0 - \u02AF + * - A greek letter Unicode: \u0370 - \u03FF + * - A mathematical alphanumeric symbol Unicode: \u{1D400} - \u{1D7FF} excluding invalid code points + * + * The previous and next characters are needed to determine whether + * this character is part of a unicode surrogate pair. + * + * @param {string} c Current character in the expression + * @param {string} cPrev Previous character + * @param {string} cNext Next character + * @return {boolean} + */ + parse.isAlpha = function isAlpha(c, cPrev, cNext) { + return parse.isValidLatinOrGreek(c) || parse.isValidMathSymbol(c, cNext) || parse.isValidMathSymbol(cPrev, c); + }; + + /** + * Test whether a character is a valid latin, greek, or letter-like character + * @param {string} c + * @return {boolean} + */ + parse.isValidLatinOrGreek = function isValidLatinOrGreek(c) { + return /^[a-zA-Z_$\u00C0-\u02AF\u0370-\u03FF\u2100-\u214F]$/.test(c); + }; + + /** + * Test whether two given 16 bit characters form a surrogate pair of a + * unicode math symbol. + * + * https://unicode-table.com/en/ + * https://www.wikiwand.com/en/Mathematical_operators_and_symbols_in_Unicode + * + * Note: In ES6 will be unicode aware: + * https://stackoverflow.com/questions/280712/javascript-unicode-regexes + * https://mathiasbynens.be/notes/es6-unicode-regex + * + * @param {string} high + * @param {string} low + * @return {boolean} + */ + parse.isValidMathSymbol = function isValidMathSymbol(high, low) { + return /^[\uD835]$/.test(high) && /^[\uDC00-\uDFFF]$/.test(low) && /^[^\uDC55\uDC9D\uDCA0\uDCA1\uDCA3\uDCA4\uDCA7\uDCA8\uDCAD\uDCBA\uDCBC\uDCC4\uDD06\uDD0B\uDD0C\uDD15\uDD1D\uDD3A\uDD3F\uDD45\uDD47-\uDD49\uDD51\uDEA6\uDEA7\uDFCC\uDFCD]$/.test(low); + }; + + /** + * Check whether given character c is a white space character: space, tab, or enter + * @param {string} c + * @param {number} nestingLevel + * @return {boolean} + */ + parse.isWhitespace = function isWhitespace(c, nestingLevel) { + // TODO: also take '\r' carriage return as newline? Or does that give problems on mac? + return c === ' ' || c === '\t' || c === '\n' && nestingLevel > 0; + }; + + /** + * Test whether the character c is a decimal mark (dot). + * This is the case when it's not the start of a delimiter '.*', './', or '.^' + * @param {string} c + * @param {string} cNext + * @return {boolean} + */ + parse.isDecimalMark = function isDecimalMark(c, cNext) { + return c === '.' && cNext !== '/' && cNext !== '*' && cNext !== '^'; + }; + + /** + * checks if the given char c is a digit or dot + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isDigitDot = function isDigitDot(c) { + return c >= '0' && c <= '9' || c === '.'; + }; + + /** + * checks if the given char c is a digit + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isDigit = function isDigit(c) { + return c >= '0' && c <= '9'; + }; + + /** + * checks if the given char c is a hex digit + * @param {string} c a string with one character + * @return {boolean} + */ + parse.isHexDigit = function isHexDigit(c) { + return c >= '0' && c <= '9' || c >= 'a' && c <= 'f' || c >= 'A' && c <= 'F'; + }; + + /** + * Start of the parse levels below, in order of precedence + * @return {Node} node + * @private + */ + function parseStart(expression, extraNodes) { + var state = initialState(); + _extends(state, { + expression, + extraNodes + }); + getToken(state); + var node = parseBlock(state); + + // check for garbage at the end of the expression + // an expression ends with a empty character '' and tokenType DELIMITER + if (state.token !== '') { + if (state.tokenType === TOKENTYPE.DELIMITER) { + // user entered a not existing operator like "//" + + // TODO: give hints for aliases, for example with "<>" give as hint " did you mean !== ?" + throw createError(state, 'Unexpected operator ' + state.token); + } else { + throw createSyntaxError(state, 'Unexpected part "' + state.token + '"'); + } + } + return node; + } + + /** + * Parse a block with expressions. Expressions can be separated by a newline + * character '\n', or by a semicolon ';'. In case of a semicolon, no output + * of the preceding line is returned. + * @return {Node} node + * @private + */ + function parseBlock(state) { + var node; + var blocks = []; + var visible; + if (state.token !== '' && state.token !== '\n' && state.token !== ';') { + node = parseAssignment(state); + if (state.comment) { + node.comment = state.comment; + } + } + + // TODO: simplify this loop + while (state.token === '\n' || state.token === ';') { + // eslint-disable-line no-unmodified-loop-condition + if (blocks.length === 0 && node) { + visible = state.token !== ';'; + blocks.push({ + node, + visible + }); + } + getToken(state); + if (state.token !== '\n' && state.token !== ';' && state.token !== '') { + node = parseAssignment(state); + if (state.comment) { + node.comment = state.comment; + } + visible = state.token !== ';'; + blocks.push({ + node, + visible + }); + } + } + if (blocks.length > 0) { + return new BlockNode(blocks); + } else { + if (!node) { + node = new ConstantNode(undefined); + if (state.comment) { + node.comment = state.comment; + } + } + return node; + } + } + + /** + * Assignment of a function or variable, + * - can be a variable like 'a=2.3' + * - or a updating an existing variable like 'matrix(2,3:5)=[6,7,8]' + * - defining a function like 'f(x) = x^2' + * @return {Node} node + * @private + */ + function parseAssignment(state) { + var name, args, value, valid; + var node = parseConditional(state); + if (state.token === '=') { + if (isSymbolNode(node)) { + // parse a variable assignment like 'a = 2/3' + name = node.name; + getTokenSkipNewline(state); + value = parseAssignment(state); + return new AssignmentNode(new SymbolNode(name), value); + } else if (isAccessorNode(node)) { + // parse a matrix subset assignment like 'A[1,2] = 4' + getTokenSkipNewline(state); + value = parseAssignment(state); + return new AssignmentNode(node.object, node.index, value); + } else if (isFunctionNode(node) && isSymbolNode(node.fn)) { + // parse function assignment like 'f(x) = x^2' + valid = true; + args = []; + name = node.name; + node.args.forEach(function (arg, index) { + if (isSymbolNode(arg)) { + args[index] = arg.name; + } else { + valid = false; + } + }); + if (valid) { + getTokenSkipNewline(state); + value = parseAssignment(state); + return new FunctionAssignmentNode(name, args, value); + } + } + throw createSyntaxError(state, 'Invalid left hand side of assignment operator ='); + } + return node; + } + + /** + * conditional operation + * + * condition ? truePart : falsePart + * + * Note: conditional operator is right-associative + * + * @return {Node} node + * @private + */ + function parseConditional(state) { + var node = parseLogicalOr(state); + while (state.token === '?') { + // eslint-disable-line no-unmodified-loop-condition + // set a conditional level, the range operator will be ignored as long + // as conditionalLevel === state.nestingLevel. + var prev = state.conditionalLevel; + state.conditionalLevel = state.nestingLevel; + getTokenSkipNewline(state); + var condition = node; + var trueExpr = parseAssignment(state); + if (state.token !== ':') throw createSyntaxError(state, 'False part of conditional expression expected'); + state.conditionalLevel = null; + getTokenSkipNewline(state); + var falseExpr = parseAssignment(state); // Note: check for conditional operator again, right associativity + + node = new ConditionalNode(condition, trueExpr, falseExpr); + + // restore the previous conditional level + state.conditionalLevel = prev; + } + return node; + } + + /** + * logical or, 'x or y' + * @return {Node} node + * @private + */ + function parseLogicalOr(state) { + var node = parseLogicalXor(state); + while (state.token === 'or') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('or', 'or', [node, parseLogicalXor(state)]); + } + return node; + } + + /** + * logical exclusive or, 'x xor y' + * @return {Node} node + * @private + */ + function parseLogicalXor(state) { + var node = parseLogicalAnd(state); + while (state.token === 'xor') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('xor', 'xor', [node, parseLogicalAnd(state)]); + } + return node; + } + + /** + * logical and, 'x and y' + * @return {Node} node + * @private + */ + function parseLogicalAnd(state) { + var node = parseBitwiseOr(state); + while (state.token === 'and') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('and', 'and', [node, parseBitwiseOr(state)]); + } + return node; + } + + /** + * bitwise or, 'x | y' + * @return {Node} node + * @private + */ + function parseBitwiseOr(state) { + var node = parseBitwiseXor(state); + while (state.token === '|') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('|', 'bitOr', [node, parseBitwiseXor(state)]); + } + return node; + } + + /** + * bitwise exclusive or (xor), 'x ^| y' + * @return {Node} node + * @private + */ + function parseBitwiseXor(state) { + var node = parseBitwiseAnd(state); + while (state.token === '^|') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('^|', 'bitXor', [node, parseBitwiseAnd(state)]); + } + return node; + } + + /** + * bitwise and, 'x & y' + * @return {Node} node + * @private + */ + function parseBitwiseAnd(state) { + var node = parseRelational(state); + while (state.token === '&') { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + node = new OperatorNode('&', 'bitAnd', [node, parseRelational(state)]); + } + return node; + } + + /** + * Parse a chained conditional, like 'a > b >= c' + * @return {Node} node + */ + function parseRelational(state) { + var params = [parseShift(state)]; + var conditionals = []; + var operators = { + '==': 'equal', + '!=': 'unequal', + '<': 'smaller', + '>': 'larger', + '<=': 'smallerEq', + '>=': 'largerEq' + }; + while (hasOwnProperty(operators, state.token)) { + // eslint-disable-line no-unmodified-loop-condition + var cond = { + name: state.token, + fn: operators[state.token] + }; + conditionals.push(cond); + getTokenSkipNewline(state); + params.push(parseShift(state)); + } + if (params.length === 1) { + return params[0]; + } else if (params.length === 2) { + return new OperatorNode(conditionals[0].name, conditionals[0].fn, params); + } else { + return new RelationalNode(conditionals.map(c => c.fn), params); + } + } + + /** + * Bitwise left shift, bitwise right arithmetic shift, bitwise right logical shift + * @return {Node} node + * @private + */ + function parseShift(state) { + var node, name, fn, params; + node = parseConversion(state); + var operators = { + '<<': 'leftShift', + '>>': 'rightArithShift', + '>>>': 'rightLogShift' + }; + while (hasOwnProperty(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + params = [node, parseConversion(state)]; + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * conversion operators 'to' and 'in' + * @return {Node} node + * @private + */ + function parseConversion(state) { + var node, name, fn, params; + node = parseRange(state); + var operators = { + to: 'to', + in: 'to' // alias of 'to' + }; + while (hasOwnProperty(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + if (name === 'in' && state.token === '') { + // end of expression -> this is the unit 'in' ('inch') + node = new OperatorNode('*', 'multiply', [node, new SymbolNode('in')], true); + } else { + // operator 'a to b' or 'a in b' + params = [node, parseRange(state)]; + node = new OperatorNode(name, fn, params); + } + } + return node; + } + + /** + * parse range, "start:end", "start:step:end", ":", "start:", ":end", etc + * @return {Node} node + * @private + */ + function parseRange(state) { + var node; + var params = []; + if (state.token === ':') { + // implicit start=1 (one-based) + node = new ConstantNode(1); + } else { + // explicit start + node = parseAddSubtract(state); + } + if (state.token === ':' && state.conditionalLevel !== state.nestingLevel) { + // we ignore the range operator when a conditional operator is being processed on the same level + params.push(node); + + // parse step and end + while (state.token === ':' && params.length < 3) { + // eslint-disable-line no-unmodified-loop-condition + getTokenSkipNewline(state); + if (state.token === ')' || state.token === ']' || state.token === ',' || state.token === '') { + // implicit end + params.push(new SymbolNode('end')); + } else { + // explicit end + params.push(parseAddSubtract(state)); + } + } + if (params.length === 3) { + // params = [start, step, end] + node = new RangeNode(params[0], params[2], params[1]); // start, end, step + } else { + // length === 2 + // params = [start, end] + node = new RangeNode(params[0], params[1]); // start, end + } + } + return node; + } + + /** + * add or subtract + * @return {Node} node + * @private + */ + function parseAddSubtract(state) { + var node, name, fn, params; + node = parseMultiplyDivide(state); + var operators = { + '+': 'add', + '-': 'subtract' + }; + while (hasOwnProperty(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + var rightNode = parseMultiplyDivide(state); + if (rightNode.isPercentage) { + params = [node, new OperatorNode('*', 'multiply', [node, rightNode])]; + } else { + params = [node, rightNode]; + } + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * multiply, divide + * @return {Node} node + * @private + */ + function parseMultiplyDivide(state) { + var node, last, name, fn; + node = parseImplicitMultiplication(state); + last = node; + var operators = { + '*': 'multiply', + '.*': 'dotMultiply', + '/': 'divide', + './': 'dotDivide' + }; + while (true) { + if (hasOwnProperty(operators, state.token)) { + // explicit operators + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + last = parseImplicitMultiplication(state); + node = new OperatorNode(name, fn, [node, last]); + } else { + break; + } + } + return node; + } + + /** + * implicit multiplication + * @return {Node} node + * @private + */ + function parseImplicitMultiplication(state) { + var node, last; + node = parseRule2(state); + last = node; + while (true) { + if (state.tokenType === TOKENTYPE.SYMBOL || state.token === 'in' && isConstantNode(node) || state.token === 'in' && isOperatorNode(node) && node.fn === 'unaryMinus' && isConstantNode(node.args[0]) || state.tokenType === TOKENTYPE.NUMBER && !isConstantNode(last) && (!isOperatorNode(last) || last.op === '!') || state.token === '(') { + // parse implicit multiplication + // + // symbol: implicit multiplication like '2a', '(2+3)a', 'a b' + // number: implicit multiplication like '(2+3)2' + // parenthesis: implicit multiplication like '2(3+4)', '(3+4)(1+2)' + last = parseRule2(state); + node = new OperatorNode('*', 'multiply', [node, last], true /* implicit */); + } else { + break; + } + } + return node; + } + + /** + * Infamous "rule 2" as described in https://github.com/josdejong/mathjs/issues/792#issuecomment-361065370 + * And as amended in https://github.com/josdejong/mathjs/issues/2370#issuecomment-1054052164 + * Explicit division gets higher precedence than implicit multiplication + * when the division matches this pattern: + * [unaryPrefixOp]?[number] / [number] [symbol] + * @return {Node} node + * @private + */ + function parseRule2(state) { + var node = parseModulusPercentage(state); + var last = node; + var tokenStates = []; + while (true) { + // Match the "number /" part of the pattern "number / number symbol" + if (state.token === '/' && rule2Node(last)) { + // Look ahead to see if the next token is a number + tokenStates.push(_extends({}, state)); + getTokenSkipNewline(state); + + // Match the "number / number" part of the pattern + if (state.tokenType === TOKENTYPE.NUMBER) { + // Look ahead again + tokenStates.push(_extends({}, state)); + getTokenSkipNewline(state); + + // Match the "symbol" part of the pattern, or a left parenthesis + if (state.tokenType === TOKENTYPE.SYMBOL || state.token === '(') { + // We've matched the pattern "number / number symbol". + // Rewind once and build the "number / number" node; the symbol will be consumed later + _extends(state, tokenStates.pop()); + tokenStates.pop(); + last = parseModulusPercentage(state); + node = new OperatorNode('/', 'divide', [node, last]); + } else { + // Not a match, so rewind + tokenStates.pop(); + _extends(state, tokenStates.pop()); + break; + } + } else { + // Not a match, so rewind + _extends(state, tokenStates.pop()); + break; + } + } else { + break; + } + } + return node; + } + + /** + * modulus and percentage + * @return {Node} node + * @private + */ + function parseModulusPercentage(state) { + var node, name, fn, params; + node = parseUnary(state); + var operators = { + '%': 'mod', + mod: 'mod' + }; + while (hasOwnProperty(operators, state.token)) { + name = state.token; + fn = operators[name]; + getTokenSkipNewline(state); + if (name === '%' && state.tokenType === TOKENTYPE.DELIMITER && state.token !== '(') { + // If the expression contains only %, then treat that as /100 + node = new OperatorNode('/', 'divide', [node, new ConstantNode(100)], false, true); + } else { + params = [node, parseUnary(state)]; + node = new OperatorNode(name, fn, params); + } + } + return node; + } + + /** + * Unary plus and minus, and logical and bitwise not + * @return {Node} node + * @private + */ + function parseUnary(state) { + var name, params, fn; + var operators = { + '-': 'unaryMinus', + '+': 'unaryPlus', + '~': 'bitNot', + not: 'not' + }; + if (hasOwnProperty(operators, state.token)) { + fn = operators[state.token]; + name = state.token; + getTokenSkipNewline(state); + params = [parseUnary(state)]; + return new OperatorNode(name, fn, params); + } + return parsePow(state); + } + + /** + * power + * Note: power operator is right associative + * @return {Node} node + * @private + */ + function parsePow(state) { + var node, name, fn, params; + node = parseLeftHandOperators(state); + if (state.token === '^' || state.token === '.^') { + name = state.token; + fn = name === '^' ? 'pow' : 'dotPow'; + getTokenSkipNewline(state); + params = [node, parseUnary(state)]; // Go back to unary, we can have '2^-3' + node = new OperatorNode(name, fn, params); + } + return node; + } + + /** + * Left hand operators: factorial x!, ctranspose x' + * @return {Node} node + * @private + */ + function parseLeftHandOperators(state) { + var node, name, fn, params; + node = parseCustomNodes(state); + var operators = { + '!': 'factorial', + '\'': 'ctranspose' + }; + while (hasOwnProperty(operators, state.token)) { + name = state.token; + fn = operators[name]; + getToken(state); + params = [node]; + node = new OperatorNode(name, fn, params); + node = parseAccessors(state, node); + } + return node; + } + + /** + * Parse a custom node handler. A node handler can be used to process + * nodes in a custom way, for example for handling a plot. + * + * A handler must be passed as second argument of the parse function. + * - must extend math.Node + * - must contain a function _compile(defs: Object) : string + * - must contain a function find(filter: Object) : Node[] + * - must contain a function toString() : string + * - the constructor is called with a single argument containing all parameters + * + * For example: + * + * nodes = { + * 'plot': PlotHandler + * } + * + * The constructor of the handler is called as: + * + * node = new PlotHandler(params) + * + * The handler will be invoked when evaluating an expression like: + * + * node = math.parse('plot(sin(x), x)', nodes) + * + * @return {Node} node + * @private + */ + function parseCustomNodes(state) { + var params = []; + if (state.tokenType === TOKENTYPE.SYMBOL && hasOwnProperty(state.extraNodes, state.token)) { + var CustomNode = state.extraNodes[state.token]; + getToken(state); + + // parse parameters + if (state.token === '(') { + params = []; + openParams(state); + getToken(state); + if (state.token !== ')') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + } + + // create a new custom node + // noinspection JSValidateTypes + return new CustomNode(params); + } + return parseSymbol(state); + } + + /** + * parse symbols: functions, variables, constants, units + * @return {Node} node + * @private + */ + function parseSymbol(state) { + var node, name; + if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) { + name = state.token; + getToken(state); + if (hasOwnProperty(CONSTANTS, name)) { + // true, false, null, ... + node = new ConstantNode(CONSTANTS[name]); + } else if (NUMERIC_CONSTANTS.includes(name)) { + // NaN, Infinity + node = new ConstantNode(numeric(name, 'number')); + } else { + node = new SymbolNode(name); + } + + // parse function parameters and matrix index + node = parseAccessors(state, node); + return node; + } + return parseString(state); + } + + /** + * parse accessors: + * - function invocation in round brackets (...), for example sqrt(2) + * - index enclosed in square brackets [...], for example A[2,3] + * - dot notation for properties, like foo.bar + * @param {Object} state + * @param {Node} node Node on which to apply the parameters. If there + * are no parameters in the expression, the node + * itself is returned + * @param {string[]} [types] Filter the types of notations + * can be ['(', '[', '.'] + * @return {Node} node + * @private + */ + function parseAccessors(state, node, types) { + var params; + while ((state.token === '(' || state.token === '[' || state.token === '.') && (!types || types.includes(state.token))) { + // eslint-disable-line no-unmodified-loop-condition + params = []; + if (state.token === '(') { + if (isSymbolNode(node) || isAccessorNode(node)) { + // function invocation like fn(2, 3) or obj.fn(2, 3) + openParams(state); + getToken(state); + if (state.token !== ')') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + node = new FunctionNode(node, params); + } else { + // implicit multiplication like (2+3)(4+5) or sqrt(2)(1+2) + // don't parse it here but let it be handled by parseImplicitMultiplication + // with correct precedence + return node; + } + } else if (state.token === '[') { + // index notation like variable[2, 3] + openParams(state); + getToken(state); + if (state.token !== ']') { + params.push(parseAssignment(state)); + + // parse a list with parameters + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + params.push(parseAssignment(state)); + } + } + if (state.token !== ']') { + throw createSyntaxError(state, 'Parenthesis ] expected'); + } + closeParams(state); + getToken(state); + node = new AccessorNode(node, new IndexNode(params)); + } else { + // dot notation like variable.prop + getToken(state); + var isPropertyName = state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS; + if (!isPropertyName) { + throw createSyntaxError(state, 'Property name expected after dot'); + } + params.push(new ConstantNode(state.token)); + getToken(state); + var dotNotation = true; + node = new AccessorNode(node, new IndexNode(params, dotNotation)); + } + } + return node; + } + + /** + * Parse a single or double quoted string. + * @return {Node} node + * @private + */ + function parseString(state) { + var node, str; + if (state.token === '"' || state.token === "'") { + str = parseStringToken(state, state.token); + + // create constant + node = new ConstantNode(str); + + // parse index parameters + node = parseAccessors(state, node); + return node; + } + return parseMatrix(state); + } + + /** + * Parse a string surrounded by single or double quotes + * @param {Object} state + * @param {"'" | "\""} quote + * @return {string} + */ + function parseStringToken(state, quote) { + var str = ''; + while (currentCharacter(state) !== '' && currentCharacter(state) !== quote) { + if (currentCharacter(state) === '\\') { + next(state); + var char = currentCharacter(state); + var escapeChar = ESCAPE_CHARACTERS[char]; + if (escapeChar !== undefined) { + // an escaped control character like \" or \n + str += escapeChar; + state.index += 1; + } else if (char === 'u') { + // escaped unicode character + var unicode = state.expression.slice(state.index + 1, state.index + 5); + if (/^[0-9A-Fa-f]{4}$/.test(unicode)) { + // test whether the string holds four hexadecimal values + str += String.fromCharCode(parseInt(unicode, 16)); + state.index += 5; + } else { + throw createSyntaxError(state, "Invalid unicode character \\u".concat(unicode)); + } + } else { + throw createSyntaxError(state, "Bad escape character \\".concat(char)); + } + } else { + // any regular character + str += currentCharacter(state); + next(state); + } + } + getToken(state); + if (state.token !== quote) { + throw createSyntaxError(state, "End of string ".concat(quote, " expected")); + } + getToken(state); + return str; + } + + /** + * parse the matrix + * @return {Node} node + * @private + */ + function parseMatrix(state) { + var array, params, rows, cols; + if (state.token === '[') { + // matrix [...] + openParams(state); + getToken(state); + if (state.token !== ']') { + // this is a non-empty matrix + var row = parseRow(state); + if (state.token === ';') { + // 2 dimensional array + rows = 1; + params = [row]; + + // the rows of the matrix are separated by dot-comma's + while (state.token === ';') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + if (state.token !== ']') { + params[rows] = parseRow(state); + rows++; + } + } + if (state.token !== ']') { + throw createSyntaxError(state, 'End of matrix ] expected'); + } + closeParams(state); + getToken(state); + + // check if the number of columns matches in all rows + cols = params[0].items.length; + for (var r = 1; r < rows; r++) { + if (params[r].items.length !== cols) { + throw createError(state, 'Column dimensions mismatch ' + '(' + params[r].items.length + ' !== ' + cols + ')'); + } + } + array = new ArrayNode(params); + } else { + // 1 dimensional vector + if (state.token !== ']') { + throw createSyntaxError(state, 'End of matrix ] expected'); + } + closeParams(state); + getToken(state); + array = row; + } + } else { + // this is an empty matrix "[ ]" + closeParams(state); + getToken(state); + array = new ArrayNode([]); + } + return parseAccessors(state, array); + } + return parseObject(state); + } + + /** + * Parse a single comma-separated row from a matrix, like 'a, b, c' + * @return {ArrayNode} node + */ + function parseRow(state) { + var params = [parseAssignment(state)]; + var len = 1; + while (state.token === ',') { + // eslint-disable-line no-unmodified-loop-condition + getToken(state); + + // parse expression + if (state.token !== ']' && state.token !== ';') { + params[len] = parseAssignment(state); + len++; + } + } + return new ArrayNode(params); + } + + /** + * parse an object, enclosed in angle brackets{...}, for example {value: 2} + * @return {Node} node + * @private + */ + function parseObject(state) { + if (state.token === '{') { + openParams(state); + var key; + var properties = {}; + do { + getToken(state); + if (state.token !== '}') { + // parse key + if (state.token === '"' || state.token === "'") { + key = parseStringToken(state, state.token); + } else if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) { + key = state.token; + getToken(state); + } else { + throw createSyntaxError(state, 'Symbol or string expected as object key'); + } + + // parse key/value separator + if (state.token !== ':') { + throw createSyntaxError(state, 'Colon : expected after object key'); + } + getToken(state); + + // parse key + properties[key] = parseAssignment(state); + } + } while (state.token === ','); // eslint-disable-line no-unmodified-loop-condition + + if (state.token !== '}') { + throw createSyntaxError(state, 'Comma , or bracket } expected after object value'); + } + closeParams(state); + getToken(state); + var node = new ObjectNode(properties); + + // parse index parameters + node = parseAccessors(state, node); + return node; + } + return parseNumber(state); + } + + /** + * parse a number + * @return {Node} node + * @private + */ + function parseNumber(state) { + var numberStr; + if (state.tokenType === TOKENTYPE.NUMBER) { + // this is a number + numberStr = state.token; + getToken(state); + var numericType = safeNumberType(numberStr, config); + var value = numeric(numberStr, numericType); + return new ConstantNode(value); + } + return parseParentheses(state); + } + + /** + * parentheses + * @return {Node} node + * @private + */ + function parseParentheses(state) { + var node; + + // check if it is a parenthesized expression + if (state.token === '(') { + // parentheses (...) + openParams(state); + getToken(state); + node = parseAssignment(state); // start again + + if (state.token !== ')') { + throw createSyntaxError(state, 'Parenthesis ) expected'); + } + closeParams(state); + getToken(state); + node = new ParenthesisNode(node); + node = parseAccessors(state, node); + return node; + } + return parseEnd(state); + } + + /** + * Evaluated when the expression is not yet ended but expected to end + * @return {Node} res + * @private + */ + function parseEnd(state) { + if (state.token === '') { + // syntax error or unexpected end of expression + throw createSyntaxError(state, 'Unexpected end of expression'); + } else { + throw createSyntaxError(state, 'Value expected'); + } + } + + /** + * Shortcut for getting the current row value (one based) + * Returns the line of the currently handled expression + * @private + */ + /* TODO: implement keeping track on the row number + function row () { + return null + } + */ + + /** + * Shortcut for getting the current col value (one based) + * Returns the column (position) where the last state.token starts + * @private + */ + function col(state) { + return state.index - state.token.length + 1; + } + + /** + * Create an error + * @param {Object} state + * @param {string} message + * @return {SyntaxError} instantiated error + * @private + */ + function createSyntaxError(state, message) { + var c = col(state); + var error = new SyntaxError(message + ' (char ' + c + ')'); + error.char = c; + return error; + } + + /** + * Create an error + * @param {Object} state + * @param {string} message + * @return {Error} instantiated error + * @private + */ + function createError(state, message) { + var c = col(state); + var error = new SyntaxError(message + ' (char ' + c + ')'); + error.char = c; + return error; + } + + // Now that we can parse, automatically convert strings to Nodes by parsing + typed.addConversion({ + from: 'string', + to: 'Node', + convert: parse + }); + return parse; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/and.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/and.transform.js new file mode 100644 index 0000000..9c80960 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/and.transform.js @@ -0,0 +1,35 @@ +import { createAnd } from '../../function/logical/and.js'; +import { factory } from '../../utils/factory.js'; +import { isCollection } from '../../utils/is.js'; +var name = 'and'; +var dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']; +export var createAndTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + var and = createAnd({ + typed, + matrix, + equalScalar, + zeros, + not, + concat + }); + function andTransform(args, math, scope) { + var condition1 = args[0].compile().evaluate(scope); + if (!isCollection(condition1) && !and(condition1, true)) { + return false; + } + var condition2 = args[1].compile().evaluate(scope); + return and(condition1, condition2); + } + andTransform.rawArgs = true; + return andTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/apply.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/apply.transform.js new file mode 100644 index 0000000..cef65c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/apply.transform.js @@ -0,0 +1,44 @@ +import { errorTransform } from './utils/errorTransform.js'; +import { factory } from '../../utils/factory.js'; +import { createApply } from '../../function/matrix/apply.js'; +import { isBigNumber, isNumber } from '../../utils/is.js'; +var name = 'apply'; +var dependencies = ['typed', 'isInteger']; + +/** + * Attach a transform function to math.apply + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function apply + * from one-based to zero based + */ +export var createApplyTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isInteger + } = _ref; + var apply = createApply({ + typed, + isInteger + }); + + // @see: comment of concat itself + return typed('apply', { + '...any': function any(args) { + // change dim from one-based to zero-based + var dim = args[1]; + if (isNumber(dim)) { + args[1] = dim - 1; + } else if (isBigNumber(dim)) { + args[1] = dim.minus(1); + } + try { + return apply.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitAnd.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitAnd.transform.js new file mode 100644 index 0000000..0985a33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitAnd.transform.js @@ -0,0 +1,40 @@ +import { createBitAnd } from '../../function/bitwise/bitAnd.js'; +import { factory } from '../../utils/factory.js'; +import { isCollection } from '../../utils/is.js'; +var name = 'bitAnd'; +var dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']; +export var createBitAndTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + var bitAnd = createBitAnd({ + typed, + matrix, + equalScalar, + zeros, + not, + concat + }); + function bitAndTransform(args, math, scope) { + var condition1 = args[0].compile().evaluate(scope); + if (!isCollection(condition1)) { + if (isNaN(condition1)) { + return NaN; + } + if (condition1 === 0 || condition1 === false) { + return 0; + } + } + var condition2 = args[1].compile().evaluate(scope); + return bitAnd(condition1, condition2); + } + bitAndTransform.rawArgs = true; + return bitAndTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitOr.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitOr.transform.js new file mode 100644 index 0000000..9f154f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/bitOr.transform.js @@ -0,0 +1,41 @@ +import { createBitOr } from '../../function/bitwise/bitOr.js'; +import { factory } from '../../utils/factory.js'; +import { isCollection } from '../../utils/is.js'; +var name = 'bitOr'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +export var createBitOrTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + var bitOr = createBitOr({ + typed, + matrix, + equalScalar, + DenseMatrix, + concat + }); + function bitOrTransform(args, math, scope) { + var condition1 = args[0].compile().evaluate(scope); + if (!isCollection(condition1)) { + if (isNaN(condition1)) { + return NaN; + } + if (condition1 === -1) { + return -1; + } + if (condition1 === true) { + return 1; + } + } + var condition2 = args[1].compile().evaluate(scope); + return bitOr(condition1, condition2); + } + bitOrTransform.rawArgs = true; + return bitOrTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/column.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/column.transform.js new file mode 100644 index 0000000..ccfb0a3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/column.transform.js @@ -0,0 +1,47 @@ +import { errorTransform } from './utils/errorTransform.js'; +import { factory } from '../../utils/factory.js'; +import { createColumn } from '../../function/matrix/column.js'; +import { isNumber } from '../../utils/is.js'; +var name = 'column'; +var dependencies = ['typed', 'Index', 'matrix', 'range']; + +/** + * Attach a transform function to matrix.column + * Adds a property transform containing the transform function. + * + * This transform changed the last `index` parameter of function column + * from zero-based to one-based + */ +export var createColumnTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Index, + matrix, + range + } = _ref; + var column = createColumn({ + typed, + Index, + matrix, + range + }); + + // @see: comment of column itself + return typed('column', { + '...any': function any(args) { + // change last argument from zero-based to one-based + var lastIndex = args.length - 1; + var last = args[lastIndex]; + if (isNumber(last)) { + args[lastIndex] = last - 1; + } + try { + return column.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/concat.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/concat.transform.js new file mode 100644 index 0000000..737876d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/concat.transform.js @@ -0,0 +1,45 @@ +import { isBigNumber, isNumber } from '../../utils/is.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { factory } from '../../utils/factory.js'; +import { createConcat } from '../../function/matrix/concat.js'; +var name = 'concat'; +var dependencies = ['typed', 'matrix', 'isInteger']; +export var createConcatTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + isInteger + } = _ref; + var concat = createConcat({ + typed, + matrix, + isInteger + }); + + /** + * Attach a transform function to math.range + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function concat + * from one-based to zero based + */ + return typed('concat', { + '...any': function any(args) { + // change last argument from one-based to zero-based + var lastIndex = args.length - 1; + var last = args[lastIndex]; + if (isNumber(last)) { + args[lastIndex] = last - 1; + } else if (isBigNumber(last)) { + args[lastIndex] = last.minus(1); + } + try { + return concat.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/cumsum.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/cumsum.transform.js new file mode 100644 index 0000000..049dc14 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/cumsum.transform.js @@ -0,0 +1,46 @@ +import { isBigNumber, isCollection, isNumber } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createCumSum } from '../../function/statistics/cumsum.js'; + +/** + * Attach a transform function to math.sum + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function sum + * from one-based to zero based + */ +var name = 'cumsum'; +var dependencies = ['typed', 'add', 'unaryPlus']; +export var createCumSumTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + unaryPlus + } = _ref; + var cumsum = createCumSum({ + typed, + add, + unaryPlus + }); + return typed(name, { + '...any': function any(args) { + // change last argument dim from one-based to zero-based + if (args.length === 2 && isCollection(args[0])) { + var dim = args[1]; + if (isNumber(dim)) { + args[1] = dim - 1; + } else if (isBigNumber(dim)) { + args[1] = dim.minus(1); + } + } + try { + return cumsum.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/diff.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/diff.transform.js new file mode 100644 index 0000000..970cf80 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/diff.transform.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createDiff } from '../../function/matrix/diff.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'diff'; +var dependencies = ['typed', 'matrix', 'subtract', 'number', 'bignumber']; +export var createDiffTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + subtract, + number, + bignumber + } = _ref; + var diff = createDiff({ + typed, + matrix, + subtract, + number, + bignumber + }); + + /** + * Attach a transform function to math.diff + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed(name, { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return diff.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/filter.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/filter.transform.js new file mode 100644 index 0000000..33e383f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/filter.transform.js @@ -0,0 +1,56 @@ +import { createFilter } from '../../function/matrix/filter.js'; +import { factory } from '../../utils/factory.js'; +import { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'; +import { compileInlineExpression } from './utils/compileInlineExpression.js'; +import { createTransformCallback } from './utils/transformCallback.js'; +var name = 'filter'; +var dependencies = ['typed']; +export var createFilterTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Attach a transform function to math.filter + * Adds a property transform containing the transform function. + * + * This transform adds support for equations as test function for math.filter, + * so you can do something like 'filter([3, -2, 5], x > 0)'. + */ + function filterTransform(args, math, scope) { + var filter = createFilter({ + typed + }); + var transformCallback = createTransformCallback({ + typed + }); + if (args.length === 0) { + return filter(); + } + var x = args[0]; + if (args.length === 1) { + return filter(x); + } + var N = args.length - 1; + var callback = args[N]; + if (x) { + x = _compileAndEvaluate(x, scope); + } + if (callback) { + if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = compileInlineExpression(callback, math, scope); + } + } + return filter(x, transformCallback(callback, N)); + } + filterTransform.rawArgs = true; + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + return filterTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/forEach.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/forEach.transform.js new file mode 100644 index 0000000..4934561 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/forEach.transform.js @@ -0,0 +1,55 @@ +import { createForEach } from '../../function/matrix/forEach.js'; +import { createTransformCallback } from './utils/transformCallback.js'; +import { factory } from '../../utils/factory.js'; +import { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'; +import { compileInlineExpression } from './utils/compileInlineExpression.js'; +var name = 'forEach'; +var dependencies = ['typed']; +export var createForEachTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Attach a transform function to math.forEach + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + var forEach = createForEach({ + typed + }); + var transformCallback = createTransformCallback({ + typed + }); + function forEachTransform(args, math, scope) { + if (args.length === 0) { + return forEach(); + } + var x = args[0]; + if (args.length === 1) { + return forEach(x); + } + var N = args.length - 1; + var callback = args[N]; + if (x) { + x = _compileAndEvaluate(x, scope); + } + if (callback) { + if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = compileInlineExpression(callback, math, scope); + } + } + return forEach(x, transformCallback(callback, N)); + } + forEachTransform.rawArgs = true; + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + return forEachTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/index.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/index.transform.js new file mode 100644 index 0000000..9655a70 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/index.transform.js @@ -0,0 +1,52 @@ +import { isArray, isBigNumber, isMatrix, isNumber, isRange } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'index'; +var dependencies = ['Index', 'getMatrixDataType']; +export var createIndexTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Index, + getMatrixDataType + } = _ref; + /** + * Attach a transform function to math.index + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + return function indexTransform() { + var args = []; + for (var i = 0, ii = arguments.length; i < ii; i++) { + var arg = arguments[i]; + + // change from one-based to zero based, convert BigNumber to number and leave Array of Booleans as is + if (isRange(arg)) { + arg.start--; + arg.end -= arg.step > 0 ? 0 : 2; + } else if (arg && arg.isSet === true) { + arg = arg.map(function (v) { + return v - 1; + }); + } else if (isArray(arg) || isMatrix(arg)) { + if (getMatrixDataType(arg) !== 'boolean') { + arg = arg.map(function (v) { + return v - 1; + }); + } + } else if (isNumber(arg)) { + arg--; + } else if (isBigNumber(arg)) { + arg = arg.toNumber() - 1; + } else if (typeof arg === 'string') { + // leave as is + } else { + throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range'); + } + args[i] = arg; + } + var res = new Index(); + Index.apply(res, args); + return res; + }; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/map.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/map.transform.js new file mode 100644 index 0000000..252a862 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/map.transform.js @@ -0,0 +1,53 @@ +import { factory } from '../../utils/factory.js'; +import { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'; +import { createMap } from '../../function/matrix/map.js'; +import { compileInlineExpression } from './utils/compileInlineExpression.js'; +import { createTransformCallback } from './utils/transformCallback.js'; +var name = 'map'; +var dependencies = ['typed']; +export var createMapTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Attach a transform function to math.map + * Adds a property transform containing the transform function. + * + * This transform creates a one-based index instead of a zero-based index + */ + var map = createMap({ + typed + }); + var transformCallback = createTransformCallback({ + typed + }); + function mapTransform(args, math, scope) { + if (args.length === 0) { + return map(); + } + if (args.length === 1) { + return map(args[0]); + } + var N = args.length - 1; + var X = args.slice(0, N); + var callback = args[N]; + X = X.map(arg => _compileAndEvaluate(arg, scope)); + if (callback) { + if (isSymbolNode(callback) || isFunctionAssignmentNode(callback)) { + // a function pointer, like filter([3, -2, 5], myTestFunction) + callback = _compileAndEvaluate(callback, scope); + } else { + // an expression like filter([3, -2, 5], x > 0) + callback = compileInlineExpression(callback, math, scope); + } + } + return map(...X, transformCallback(callback, N)); + function _compileAndEvaluate(arg, scope) { + return arg.compile().evaluate(scope); + } + } + mapTransform.rawArgs = true; + return mapTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/max.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/max.transform.js new file mode 100644 index 0000000..781e5da --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/max.transform.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createMax } from '../../function/statistics/max.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'max'; +var dependencies = ['typed', 'config', 'numeric', 'larger']; +export var createMaxTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + numeric, + larger + } = _ref; + var max = createMax({ + typed, + config, + numeric, + larger + }); + + /** + * Attach a transform function to math.max + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function max + * from one-based to zero based + */ + return typed('max', { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return max.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/mean.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/mean.transform.js new file mode 100644 index 0000000..8d080f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/mean.transform.js @@ -0,0 +1,38 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createMean } from '../../function/statistics/mean.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'mean'; +var dependencies = ['typed', 'add', 'divide']; +export var createMeanTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + divide + } = _ref; + var mean = createMean({ + typed, + add, + divide + }); + + /** + * Attach a transform function to math.mean + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function mean + * from one-based to zero based + */ + return typed('mean', { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return mean.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/min.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/min.transform.js new file mode 100644 index 0000000..b0afc80 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/min.transform.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createMin } from '../../function/statistics/min.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'min'; +var dependencies = ['typed', 'config', 'numeric', 'smaller']; +export var createMinTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + numeric, + smaller + } = _ref; + var min = createMin({ + typed, + config, + numeric, + smaller + }); + + /** + * Attach a transform function to math.min + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function min + * from one-based to zero based + */ + return typed('min', { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return min.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/or.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/or.transform.js new file mode 100644 index 0000000..1b1920e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/or.transform.js @@ -0,0 +1,33 @@ +import { createOr } from '../../function/logical/or.js'; +import { factory } from '../../utils/factory.js'; +import { isCollection } from '../../utils/is.js'; +var name = 'or'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +export var createOrTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + var or = createOr({ + typed, + matrix, + equalScalar, + DenseMatrix, + concat + }); + function orTransform(args, math, scope) { + var condition1 = args[0].compile().evaluate(scope); + if (!isCollection(condition1) && or(condition1, false)) { + return true; + } + var condition2 = args[1].compile().evaluate(scope); + return or(condition1, condition2); + } + orTransform.rawArgs = true; + return orTransform; +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/print.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/print.transform.js new file mode 100644 index 0000000..645000d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/print.transform.js @@ -0,0 +1,42 @@ +import { createPrint } from '../../function/string/print.js'; +import { factory } from '../../utils/factory.js'; +import { printTemplate } from '../../utils/print.js'; +var name = 'print'; +var dependencies = ['typed', 'matrix', 'zeros', 'add']; +export var createPrintTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + zeros, + add + } = _ref; + var print = createPrint({ + typed, + matrix, + zeros, + add + }); + return typed(name, { + 'string, Object | Array': function string_Object__Array(template, values) { + return print(_convertTemplateToZeroBasedIndex(template), values); + }, + 'string, Object | Array, number | Object': function string_Object__Array_number__Object(template, values, options) { + return print(_convertTemplateToZeroBasedIndex(template), values, options); + } + }); + function _convertTemplateToZeroBasedIndex(template) { + return template.replace(printTemplate, x => { + var parts = x.slice(1).split('.'); + var result = parts.map(function (part) { + if (!isNaN(part) && part.length > 0) { + return parseInt(part) - 1; + } else { + return part; + } + }); + return '$' + result.join('.'); + }); + } +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/quantileSeq.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/quantileSeq.transform.js new file mode 100644 index 0000000..2e6a00f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/quantileSeq.transform.js @@ -0,0 +1,59 @@ +import { factory } from '../../utils/factory.js'; +import { createQuantileSeq } from '../../function/statistics/quantileSeq.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'quantileSeq'; +var dependencies = ['typed', 'bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']; + +/** + * Attach a transform function to math.quantileSeq + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function std + * from one-based to zero based + */ +export var createQuantileSeqTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + } = _ref; + var quantileSeq = createQuantileSeq({ + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + }); + return typed('quantileSeq', { + 'Array | Matrix, number | BigNumber': quantileSeq, + 'Array | Matrix, number | BigNumber, number': (arr, prob, dim) => quantileSeq(arr, prob, dimToZeroBase(dim)), + 'Array | Matrix, number | BigNumber, boolean': quantileSeq, + 'Array | Matrix, number | BigNumber, boolean, number': (arr, prob, sorted, dim) => quantileSeq(arr, prob, sorted, dimToZeroBase(dim)), + 'Array | Matrix, Array | Matrix': quantileSeq, + 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => quantileSeq(data, prob, dimToZeroBase(dim)), + 'Array | Matrix, Array | Matrix, boolean': quantileSeq, + 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => quantileSeq(data, prob, sorted, dimToZeroBase(dim)) + }); + function dimToZeroBase(dim) { + // TODO: find a better way, maybe lastDimToZeroBase could apply to more cases. + return lastDimToZeroBase([[], dim])[1]; + } +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/range.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/range.transform.js new file mode 100644 index 0000000..aa3468e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/range.transform.js @@ -0,0 +1,50 @@ +import { factory } from '../../utils/factory.js'; +import { createRange } from '../../function/matrix/range.js'; +var name = 'range'; +var dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']; +export var createRangeTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + } = _ref; + var range = createRange({ + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + }); + + /** + * Attach a transform function to math.range + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed('range', { + '...any': function any(args) { + var lastIndex = args.length - 1; + var last = args[lastIndex]; + if (typeof last !== 'boolean') { + // append a parameter includeEnd=true + args.push(true); + } + return range.apply(null, args); + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/row.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/row.transform.js new file mode 100644 index 0000000..2bb7084 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/row.transform.js @@ -0,0 +1,47 @@ +import { factory } from '../../utils/factory.js'; +import { createRow } from '../../function/matrix/row.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { isNumber } from '../../utils/is.js'; +var name = 'row'; +var dependencies = ['typed', 'Index', 'matrix', 'range']; + +/** + * Attach a transform function to matrix.column + * Adds a property transform containing the transform function. + * + * This transform changed the last `index` parameter of function column + * from zero-based to one-based + */ +export var createRowTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Index, + matrix, + range + } = _ref; + var row = createRow({ + typed, + Index, + matrix, + range + }); + + // @see: comment of row itself + return typed('row', { + '...any': function any(args) { + // change last argument from zero-based to one-based + var lastIndex = args.length - 1; + var last = args[lastIndex]; + if (isNumber(last)) { + args[lastIndex] = last - 1; + } + try { + return row.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/std.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/std.transform.js new file mode 100644 index 0000000..5e83737 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/std.transform.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +import { createStd } from '../../function/statistics/std.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'std'; +var dependencies = ['typed', 'map', 'sqrt', 'variance']; + +/** + * Attach a transform function to math.std + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function std + * from one-based to zero based + */ +export var createStdTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + map, + sqrt, + variance + } = _ref; + var std = createStd({ + typed, + map, + sqrt, + variance + }); + return typed('std', { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return std.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/subset.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/subset.transform.js new file mode 100644 index 0000000..23f29cf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/subset.transform.js @@ -0,0 +1,37 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createSubset } from '../../function/matrix/subset.js'; +var name = 'subset'; +var dependencies = ['typed', 'matrix', 'zeros', 'add']; +export var createSubsetTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + zeros, + add + } = _ref; + var subset = createSubset({ + typed, + matrix, + zeros, + add + }); + + /** + * Attach a transform function to math.subset + * Adds a property transform containing the transform function. + * + * This transform creates a range which includes the end value + */ + return typed('subset', { + '...any': function any(args) { + try { + return subset.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/sum.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/sum.transform.js new file mode 100644 index 0000000..d5a27f8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/sum.transform.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createSum } from '../../function/statistics/sum.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; + +/** + * Attach a transform function to math.sum + * Adds a property transform containing the transform function. + * + * This transform changed the last `dim` parameter of function sum + * from one-based to zero based + */ +var name = 'sum'; +var dependencies = ['typed', 'config', 'add', 'numeric']; +export var createSumTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + add, + numeric + } = _ref; + var sum = createSum({ + typed, + config, + add, + numeric + }); + return typed(name, { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return sum.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/compileInlineExpression.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/compileInlineExpression.js new file mode 100644 index 0000000..96f7c32 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/compileInlineExpression.js @@ -0,0 +1,30 @@ +import { isSymbolNode } from '../../../utils/is.js'; +import { PartitionedMap } from '../../../utils/map.js'; + +/** + * Compile an inline expression like "x > 0" + * @param {Node} expression + * @param {Object} math + * @param {Map} scope + * @return {function} Returns a function with one argument which fills in the + * undefined variable (like "x") and evaluates the expression + */ +export function compileInlineExpression(expression, math, scope) { + // find an undefined symbol + var symbol = expression.filter(function (node) { + return isSymbolNode(node) && !(node.name in math) && !scope.has(node.name); + })[0]; + if (!symbol) { + throw new Error('No undefined variable found in inline expression "' + expression + '"'); + } + + // create a test function for this equation + var name = symbol.name; // variable name + var argsScope = new Map(); + var subScope = new PartitionedMap(scope, argsScope, new Set([name])); + var eq = expression.compile(); + return function inlineExpression(x) { + argsScope.set(name, x); + return eq.evaluate(subScope); + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/dimToZeroBase.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/dimToZeroBase.js new file mode 100644 index 0000000..6c17d76 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/dimToZeroBase.js @@ -0,0 +1,16 @@ +import { isNumber, isBigNumber } from '../../../utils/is.js'; +/** + * Change last argument dim from one-based to zero-based. + */ +export function dimToZeroBase(dim) { + if (isNumber(dim)) { + return dim - 1; + } else if (isBigNumber(dim)) { + return dim.minus(1); + } else { + return dim; + } +} +export function isNumberOrBigNumber(n) { + return isNumber(n) || isBigNumber(n); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/errorTransform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/errorTransform.js new file mode 100644 index 0000000..b64f7ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/errorTransform.js @@ -0,0 +1,13 @@ +import { IndexError } from '../../../error/IndexError.js'; + +/** + * Transform zero-based indices to one-based indices in errors + * @param {Error} err + * @returns {Error | IndexError} Returns the transformed error + */ +export function errorTransform(err) { + if (err && err.isIndexError) { + return new IndexError(err.index + 1, err.min + 1, err.max !== undefined ? err.max + 1 : undefined); + } + return err; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/lastDimToZeroBase.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/lastDimToZeroBase.js new file mode 100644 index 0000000..d2d939c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/lastDimToZeroBase.js @@ -0,0 +1,15 @@ +import { isCollection } from '../../../utils/is.js'; +import { dimToZeroBase, isNumberOrBigNumber } from './dimToZeroBase.js'; +/** + * Change last argument dim from one-based to zero-based. + */ +export function lastDimToZeroBase(args) { + if (args.length === 2 && isCollection(args[0])) { + args = args.slice(); + var dim = args[1]; + if (isNumberOrBigNumber(dim)) { + args[1] = dimToZeroBase(dim); + } + } + return args; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/transformCallback.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/transformCallback.js new file mode 100644 index 0000000..090a0c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/utils/transformCallback.js @@ -0,0 +1,95 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'transformCallback'; +var dependencies = ['typed']; +export var createTransformCallback = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Transforms the given callback function based on its type and number of arrays. + * + * @param {Function} callback - The callback function to transform. + * @param {number} numberOfArrays - The number of arrays to pass to the callback function. + * @returns {*} - The transformed callback function. + */ + return function (callback, numberOfArrays) { + if (typed.isTypedFunction(callback)) { + return _transformTypedCallbackFunction(callback, numberOfArrays); + } else { + return _transformCallbackFunction(callback, callback.length, numberOfArrays); + } + }; + + /** + * Transforms the given typed callback function based on the number of arrays. + * + * @param {Function} typedFunction - The typed callback function to transform. + * @param {number} numberOfArrays - The number of arrays to pass to the callback function. + * @returns {*} - The transformed callback function. + */ + function _transformTypedCallbackFunction(typedFunction, numberOfArrays) { + var signatures = Object.fromEntries(Object.entries(typedFunction.signatures).map(_ref2 => { + var [signature, callbackFunction] = _ref2; + var numberOfCallbackInputs = signature.split(',').length; + if (typed.isTypedFunction(callbackFunction)) { + return [signature, _transformTypedCallbackFunction(callbackFunction, numberOfArrays)]; + } else { + return [signature, _transformCallbackFunction(callbackFunction, numberOfCallbackInputs, numberOfArrays)]; + } + })); + if (typeof typedFunction.name === 'string') { + return typed(typedFunction.name, signatures); + } else { + return typed(signatures); + } + } +}); + +/** + * Transforms the callback function based on the number of callback inputs and arrays. + * There are three cases: + * 1. The callback function has N arguments. + * 2. The callback function has N+1 arguments. + * 3. The callback function has 2N+1 arguments. + * + * @param {Function} callbackFunction - The callback function to transform. + * @param {number} numberOfCallbackInputs - The number of callback inputs. + * @param {number} numberOfArrays - The number of arrays. + * @returns {Function} The transformed callback function. + */ +function _transformCallbackFunction(callbackFunction, numberOfCallbackInputs, numberOfArrays) { + if (numberOfCallbackInputs === numberOfArrays) { + return callbackFunction; + } else if (numberOfCallbackInputs === numberOfArrays + 1) { + return function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + var vals = args.slice(0, numberOfArrays); + var idx = _transformDims(args[numberOfArrays]); + return callbackFunction(...vals, idx); + }; + } else if (numberOfCallbackInputs > numberOfArrays + 1) { + return function () { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + var vals = args.slice(0, numberOfArrays); + var idx = _transformDims(args[numberOfArrays]); + var rest = args.slice(numberOfArrays + 1); + return callbackFunction(...vals, idx, ...rest); + }; + } else { + return callbackFunction; + } +} + +/** + * Transforms the dimensions by adding 1 to each dimension. + * + * @param {Array} dims - The dimensions to transform. + * @returns {Array} The transformed dimensions. + */ +function _transformDims(dims) { + return dims.map(dim => dim + 1); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/variance.transform.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/variance.transform.js new file mode 100644 index 0000000..c17d970 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/expression/transform/variance.transform.js @@ -0,0 +1,46 @@ +import { factory } from '../../utils/factory.js'; +import { errorTransform } from './utils/errorTransform.js'; +import { createVariance } from '../../function/statistics/variance.js'; +import { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'; +var name = 'variance'; +var dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']; + +/** + * Attach a transform function to math.var + * Adds a property transform containing the transform function. + * + * This transform changed the `dim` parameter of function var + * from one-based to zero based + */ +export var createVarianceTransform = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + } = _ref; + var variance = createVariance({ + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + }); + return typed(name, { + '...any': function any(args) { + args = lastDimToZeroBase(args); + try { + return variance.apply(null, args); + } catch (err) { + throw errorTransform(err); + } + } + }); +}, { + isTransformFunction: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesAny.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesAny.js new file mode 100644 index 0000000..ee47917 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesAny.js @@ -0,0 +1,297 @@ +export { createTyped } from './core/function/typed.js'; +export { createResultSet } from './type/resultset/ResultSet.js'; +export { createBigNumberClass } from './type/bignumber/BigNumber.js'; +export { createComplexClass } from './type/complex/Complex.js'; +export { createFractionClass } from './type/fraction/Fraction.js'; +export { createRangeClass } from './type/matrix/Range.js'; +export { createMatrixClass } from './type/matrix/Matrix.js'; +export { createDenseMatrixClass } from './type/matrix/DenseMatrix.js'; +export { createClone } from './function/utils/clone.js'; +export { createIsInteger } from './function/utils/isInteger.js'; +export { createIsNegative } from './function/utils/isNegative.js'; +export { createIsNumeric } from './function/utils/isNumeric.js'; +export { createHasNumericValue } from './function/utils/hasNumericValue.js'; +export { createIsPositive } from './function/utils/isPositive.js'; +export { createIsZero } from './function/utils/isZero.js'; +export { createIsNaN } from './function/utils/isNaN.js'; +export { createTypeOf } from './function/utils/typeOf.js'; +export { createEqualScalar } from './function/relational/equalScalar.js'; +export { createSparseMatrixClass } from './type/matrix/SparseMatrix.js'; +export { createNumber } from './type/number.js'; +export { createBigint } from './type/bigint.js'; +export { createString } from './type/string.js'; +export { createBoolean } from './type/boolean.js'; +export { createBignumber } from './type/bignumber/function/bignumber.js'; +export { createComplex } from './type/complex/function/complex.js'; +export { createFraction } from './type/fraction/function/fraction.js'; +export { createMatrix } from './type/matrix/function/matrix.js'; +export { createMatrixFromFunction } from './function/matrix/matrixFromFunction.js'; +export { createMatrixFromRows } from './function/matrix/matrixFromRows.js'; +export { createMatrixFromColumns } from './function/matrix/matrixFromColumns.js'; +export { createSplitUnit } from './type/unit/function/splitUnit.js'; +export { createUnaryMinus } from './function/arithmetic/unaryMinus.js'; +export { createUnaryPlus } from './function/arithmetic/unaryPlus.js'; +export { createAbs } from './function/arithmetic/abs.js'; +export { createApply } from './function/matrix/apply.js'; +export { createAddScalar } from './function/arithmetic/addScalar.js'; +export { createSubtractScalar } from './function/arithmetic/subtractScalar.js'; +export { createCbrt } from './function/arithmetic/cbrt.js'; +export { createCeil } from './function/arithmetic/ceil.js'; +export { createCube } from './function/arithmetic/cube.js'; +export { createExp } from './function/arithmetic/exp.js'; +export { createExpm1 } from './function/arithmetic/expm1.js'; +export { createFix } from './function/arithmetic/fix.js'; +export { createFloor } from './function/arithmetic/floor.js'; +export { createGcd } from './function/arithmetic/gcd.js'; +export { createLcm } from './function/arithmetic/lcm.js'; +export { createLog10 } from './function/arithmetic/log10.js'; +export { createLog2 } from './function/arithmetic/log2.js'; +export { createMod } from './function/arithmetic/mod.js'; +export { createMultiplyScalar } from './function/arithmetic/multiplyScalar.js'; +export { createMultiply } from './function/arithmetic/multiply.js'; +export { createNthRoot } from './function/arithmetic/nthRoot.js'; +export { createSign } from './function/arithmetic/sign.js'; +export { createSqrt } from './function/arithmetic/sqrt.js'; +export { createSquare } from './function/arithmetic/square.js'; +export { createSubtract } from './function/arithmetic/subtract.js'; +export { createXgcd } from './function/arithmetic/xgcd.js'; +export { createInvmod } from './function/arithmetic/invmod.js'; +export { createDotMultiply } from './function/arithmetic/dotMultiply.js'; +export { createBitAnd } from './function/bitwise/bitAnd.js'; +export { createBitNot } from './function/bitwise/bitNot.js'; +export { createBitOr } from './function/bitwise/bitOr.js'; +export { createBitXor } from './function/bitwise/bitXor.js'; +export { createArg } from './function/complex/arg.js'; +export { createConj } from './function/complex/conj.js'; +export { createIm } from './function/complex/im.js'; +export { createRe } from './function/complex/re.js'; +export { createNot } from './function/logical/not.js'; +export { createOr } from './function/logical/or.js'; +export { createXor } from './function/logical/xor.js'; +export { createConcat } from './function/matrix/concat.js'; +export { createColumn } from './function/matrix/column.js'; +export { createCount } from './function/matrix/count.js'; +export { createCross } from './function/matrix/cross.js'; +export { createDiag } from './function/matrix/diag.js'; +export { createFilter } from './function/matrix/filter.js'; +export { createFlatten } from './function/matrix/flatten.js'; +export { createForEach } from './function/matrix/forEach.js'; +export { createGetMatrixDataType } from './function/matrix/getMatrixDataType.js'; +export { createIdentity } from './function/matrix/identity.js'; +export { createKron } from './function/matrix/kron.js'; +export { createMap } from './function/matrix/map.js'; +export { createDiff } from './function/matrix/diff.js'; +export { createOnes } from './function/matrix/ones.js'; +export { createRange } from './function/matrix/range.js'; +export { createReshape } from './function/matrix/reshape.js'; +export { createResize } from './function/matrix/resize.js'; +export { createRotate } from './function/matrix/rotate.js'; +export { createRotationMatrix } from './function/matrix/rotationMatrix.js'; +export { createRow } from './function/matrix/row.js'; +export { createSize } from './function/matrix/size.js'; +export { createSqueeze } from './function/matrix/squeeze.js'; +export { createSubset } from './function/matrix/subset.js'; +export { createTranspose } from './function/matrix/transpose.js'; +export { createCtranspose } from './function/matrix/ctranspose.js'; +export { createZeros } from './function/matrix/zeros.js'; +export { createFft } from './function/matrix/fft.js'; +export { createIfft } from './function/matrix/ifft.js'; +export { createSolveODE } from './function/numeric/solveODE.js'; +export { createErf } from './function/special/erf.js'; +export { createZeta } from './function/special/zeta.js'; +export { createMode } from './function/statistics/mode.js'; +export { createProd } from './function/statistics/prod.js'; +export { createFormat } from './function/string/format.js'; +export { createBin } from './function/string/bin.js'; +export { createOct } from './function/string/oct.js'; +export { createHex } from './function/string/hex.js'; +export { createPrint } from './function/string/print.js'; +export { createTo } from './function/unit/to.js'; +export { createIsPrime } from './function/utils/isPrime.js'; +export { createNumeric } from './function/utils/numeric.js'; +export { createDivideScalar } from './function/arithmetic/divideScalar.js'; +export { createPow } from './function/arithmetic/pow.js'; +export { createRound } from './function/arithmetic/round.js'; +export { createLog } from './function/arithmetic/log.js'; +export { createLog1p } from './function/arithmetic/log1p.js'; +export { createNthRoots } from './function/arithmetic/nthRoots.js'; +export { createDotPow } from './function/arithmetic/dotPow.js'; +export { createDotDivide } from './function/arithmetic/dotDivide.js'; +export { createLsolve } from './function/algebra/solver/lsolve.js'; +export { createUsolve } from './function/algebra/solver/usolve.js'; +export { createLsolveAll } from './function/algebra/solver/lsolveAll.js'; +export { createUsolveAll } from './function/algebra/solver/usolveAll.js'; +export { createLeftShift } from './function/bitwise/leftShift.js'; +export { createRightArithShift } from './function/bitwise/rightArithShift.js'; +export { createRightLogShift } from './function/bitwise/rightLogShift.js'; +export { createAnd } from './function/logical/and.js'; +export { createCompare } from './function/relational/compare.js'; +export { createCompareNatural } from './function/relational/compareNatural.js'; +export { createCompareText } from './function/relational/compareText.js'; +export { createEqual } from './function/relational/equal.js'; +export { createEqualText } from './function/relational/equalText.js'; +export { createSmaller } from './function/relational/smaller.js'; +export { createSmallerEq } from './function/relational/smallerEq.js'; +export { createLarger } from './function/relational/larger.js'; +export { createLargerEq } from './function/relational/largerEq.js'; +export { createDeepEqual } from './function/relational/deepEqual.js'; +export { createUnequal } from './function/relational/unequal.js'; +export { createPartitionSelect } from './function/matrix/partitionSelect.js'; +export { createSort } from './function/matrix/sort.js'; +export { createMax } from './function/statistics/max.js'; +export { createMin } from './function/statistics/min.js'; +export { createImmutableDenseMatrixClass } from './type/matrix/ImmutableDenseMatrix.js'; +export { createIndexClass } from './type/matrix/MatrixIndex.js'; +export { createFibonacciHeapClass } from './type/matrix/FibonacciHeap.js'; +export { createSpaClass } from './type/matrix/Spa.js'; +export { createUnitClass } from './type/unit/Unit.js'; +export { createUnitFunction } from './type/unit/function/unit.js'; +export { createSparse } from './type/matrix/function/sparse.js'; +export { createCreateUnit } from './type/unit/function/createUnit.js'; +export { createAcos } from './function/trigonometry/acos.js'; +export { createAcosh } from './function/trigonometry/acosh.js'; +export { createAcot } from './function/trigonometry/acot.js'; +export { createAcoth } from './function/trigonometry/acoth.js'; +export { createAcsc } from './function/trigonometry/acsc.js'; +export { createAcsch } from './function/trigonometry/acsch.js'; +export { createAsec } from './function/trigonometry/asec.js'; +export { createAsech } from './function/trigonometry/asech.js'; +export { createAsin } from './function/trigonometry/asin.js'; +export { createAsinh } from './function/trigonometry/asinh.js'; +export { createAtan } from './function/trigonometry/atan.js'; +export { createAtan2 } from './function/trigonometry/atan2.js'; +export { createAtanh } from './function/trigonometry/atanh.js'; +export { createCos } from './function/trigonometry/cos.js'; +export { createCosh } from './function/trigonometry/cosh.js'; +export { createCot } from './function/trigonometry/cot.js'; +export { createCoth } from './function/trigonometry/coth.js'; +export { createCsc } from './function/trigonometry/csc.js'; +export { createCsch } from './function/trigonometry/csch.js'; +export { createSec } from './function/trigonometry/sec.js'; +export { createSech } from './function/trigonometry/sech.js'; +export { createSin } from './function/trigonometry/sin.js'; +export { createSinh } from './function/trigonometry/sinh.js'; +export { createTan } from './function/trigonometry/tan.js'; +export { createTanh } from './function/trigonometry/tanh.js'; +export { createSetCartesian } from './function/set/setCartesian.js'; +export { createSetDifference } from './function/set/setDifference.js'; +export { createSetDistinct } from './function/set/setDistinct.js'; +export { createSetIntersect } from './function/set/setIntersect.js'; +export { createSetIsSubset } from './function/set/setIsSubset.js'; +export { createSetMultiplicity } from './function/set/setMultiplicity.js'; +export { createSetPowerset } from './function/set/setPowerset.js'; +export { createSetSize } from './function/set/setSize.js'; +export { createSetSymDifference } from './function/set/setSymDifference.js'; +export { createSetUnion } from './function/set/setUnion.js'; +export { createAdd } from './function/arithmetic/add.js'; +export { createHypot } from './function/arithmetic/hypot.js'; +export { createNorm } from './function/arithmetic/norm.js'; +export { createDot } from './function/matrix/dot.js'; +export { createTrace } from './function/matrix/trace.js'; +export { createIndex } from './type/matrix/function/index.js'; +export { createNode } from './expression/node/Node.js'; +export { createAccessorNode } from './expression/node/AccessorNode.js'; +export { createArrayNode } from './expression/node/ArrayNode.js'; +export { createAssignmentNode } from './expression/node/AssignmentNode.js'; +export { createBlockNode } from './expression/node/BlockNode.js'; +export { createConditionalNode } from './expression/node/ConditionalNode.js'; +export { createConstantNode } from './expression/node/ConstantNode.js'; +export { createFunctionAssignmentNode } from './expression/node/FunctionAssignmentNode.js'; +export { createIndexNode } from './expression/node/IndexNode.js'; +export { createObjectNode } from './expression/node/ObjectNode.js'; +export { createOperatorNode } from './expression/node/OperatorNode.js'; +export { createParenthesisNode } from './expression/node/ParenthesisNode.js'; +export { createRangeNode } from './expression/node/RangeNode.js'; +export { createRelationalNode } from './expression/node/RelationalNode.js'; +export { createSymbolNode } from './expression/node/SymbolNode.js'; +export { createFunctionNode } from './expression/node/FunctionNode.js'; +export { createParse } from './expression/parse.js'; +export { createCompile } from './expression/function/compile.js'; +export { createEvaluate } from './expression/function/evaluate.js'; +export { createParserClass } from './expression/Parser.js'; +export { createParser } from './expression/function/parser.js'; +export { createLup } from './function/algebra/decomposition/lup.js'; +export { createQr } from './function/algebra/decomposition/qr.js'; +export { createSlu } from './function/algebra/decomposition/slu.js'; +export { createLusolve } from './function/algebra/solver/lusolve.js'; +export { createPolynomialRoot } from './function/algebra/polynomialRoot.js'; +export { createHelpClass } from './expression/Help.js'; +export { createChainClass } from './type/chain/Chain.js'; +export { createHelp } from './expression/function/help.js'; +export { createChain } from './type/chain/function/chain.js'; +export { createDet } from './function/matrix/det.js'; +export { createInv } from './function/matrix/inv.js'; +export { createPinv } from './function/matrix/pinv.js'; +export { createEigs } from './function/matrix/eigs.js'; +export { createExpm } from './function/matrix/expm.js'; +export { createSqrtm } from './function/matrix/sqrtm.js'; +export { createSylvester } from './function/algebra/sylvester.js'; +export { createSchur } from './function/algebra/decomposition/schur.js'; +export { createLyap } from './function/algebra/lyap.js'; +export { createDivide } from './function/arithmetic/divide.js'; +export { createDistance } from './function/geometry/distance.js'; +export { createIntersect } from './function/geometry/intersect.js'; +export { createSum } from './function/statistics/sum.js'; +export { createCumSum } from './function/statistics/cumsum.js'; +export { createMean } from './function/statistics/mean.js'; +export { createMedian } from './function/statistics/median.js'; +export { createMad } from './function/statistics/mad.js'; +export { createVariance } from './function/statistics/variance.js'; +export { createQuantileSeq } from './function/statistics/quantileSeq.js'; +export { createStd } from './function/statistics/std.js'; +export { createCorr } from './function/statistics/corr.js'; +export { createCombinations } from './function/probability/combinations.js'; +export { createCombinationsWithRep } from './function/probability/combinationsWithRep.js'; +export { createGamma } from './function/probability/gamma.js'; +export { createLgamma } from './function/probability/lgamma.js'; +export { createFactorial } from './function/probability/factorial.js'; +export { createKldivergence } from './function/probability/kldivergence.js'; +export { createMultinomial } from './function/probability/multinomial.js'; +export { createPermutations } from './function/probability/permutations.js'; +export { createPickRandom } from './function/probability/pickRandom.js'; +export { createRandom } from './function/probability/random.js'; +export { createRandomInt } from './function/probability/randomInt.js'; +export { createStirlingS2 } from './function/combinatorics/stirlingS2.js'; +export { createBellNumbers } from './function/combinatorics/bellNumbers.js'; +export { createCatalan } from './function/combinatorics/catalan.js'; +export { createComposition } from './function/combinatorics/composition.js'; +export { createLeafCount } from './function/algebra/leafCount.js'; +export { createSimplify } from './function/algebra/simplify.js'; +export { createSimplifyConstant } from './function/algebra/simplifyConstant.js'; +export { createSimplifyCore } from './function/algebra/simplifyCore.js'; +export { createResolve } from './function/algebra/resolve.js'; +export { createSymbolicEqual } from './function/algebra/symbolicEqual.js'; +export { createDerivative } from './function/algebra/derivative.js'; +export { createRationalize } from './function/algebra/rationalize.js'; +export { createZpk2tf } from './function/signal/zpk2tf.js'; +export { createFreqz } from './function/signal/freqz.js'; +export { createReviver } from './json/reviver.js'; +export { createReplacer } from './json/replacer.js'; +export { createE, createUppercaseE, createFalse, createI, createInfinity, createLN10, createLN2, createLOG10E, createLOG2E, createNaN, createNull, createPhi, createPi, createUppercasePi, createSQRT1_2, +// eslint-disable-line camelcase +createSQRT2, createTau, createTrue, createVersion } from './constants.js'; +export { createAtomicMass, createAvogadro, createBohrMagneton, createBohrRadius, createBoltzmann, createClassicalElectronRadius, createConductanceQuantum, createCoulomb, createDeuteronMass, createEfimovFactor, createElectricConstant, createElectronMass, createElementaryCharge, createFaraday, createFermiCoupling, createFineStructure, createFirstRadiation, createGasConstant, createGravitationConstant, createGravity, createHartreeEnergy, createInverseConductanceQuantum, createKlitzing, createLoschmidt, createMagneticConstant, createMagneticFluxQuantum, createMolarMass, createMolarMassC12, createMolarPlanckConstant, createMolarVolume, createNeutronMass, createNuclearMagneton, createPlanckCharge, createPlanckConstant, createPlanckLength, createPlanckMass, createPlanckTemperature, createPlanckTime, createProtonMass, createQuantumOfCirculation, createReducedPlanckConstant, createRydberg, createSackurTetrode, createSecondRadiation, createSpeedOfLight, createStefanBoltzmann, createThomsonCrossSection, createVacuumImpedance, createWeakMixingAngle, createWienDisplacement } from './type/unit/physicalConstants.js'; +export { createApplyTransform } from './expression/transform/apply.transform.js'; +export { createColumnTransform } from './expression/transform/column.transform.js'; +export { createFilterTransform } from './expression/transform/filter.transform.js'; +export { createForEachTransform } from './expression/transform/forEach.transform.js'; +export { createIndexTransform } from './expression/transform/index.transform.js'; +export { createMapTransform } from './expression/transform/map.transform.js'; +export { createMaxTransform } from './expression/transform/max.transform.js'; +export { createMeanTransform } from './expression/transform/mean.transform.js'; +export { createMinTransform } from './expression/transform/min.transform.js'; +export { createRangeTransform } from './expression/transform/range.transform.js'; +export { createRowTransform } from './expression/transform/row.transform.js'; +export { createSubsetTransform } from './expression/transform/subset.transform.js'; +export { createConcatTransform } from './expression/transform/concat.transform.js'; +export { createDiffTransform } from './expression/transform/diff.transform.js'; +export { createStdTransform } from './expression/transform/std.transform.js'; +export { createSumTransform } from './expression/transform/sum.transform.js'; +export { createQuantileSeqTransform } from './expression/transform/quantileSeq.transform.js'; +export { createCumSumTransform } from './expression/transform/cumsum.transform.js'; +export { createVarianceTransform } from './expression/transform/variance.transform.js'; +export { createPrintTransform } from './expression/transform/print.transform.js'; +export { createAndTransform } from './expression/transform/and.transform.js'; +export { createOrTransform } from './expression/transform/or.transform.js'; +export { createBitAndTransform } from './expression/transform/bitAnd.transform.js'; +export { createBitOrTransform } from './expression/transform/bitOr.transform.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesNumber.js new file mode 100644 index 0000000..8b81648 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/factoriesNumber.js @@ -0,0 +1,266 @@ +import { absNumber, acoshNumber, acosNumber, acothNumber, acotNumber, acschNumber, acscNumber, addNumber, andNumber, asechNumber, asecNumber, asinhNumber, asinNumber, atan2Number, atanhNumber, atanNumber, bitAndNumber, bitNotNumber, bitOrNumber, bitXorNumber, cbrtNumber, combinationsNumber, coshNumber, cosNumber, cothNumber, cotNumber, cschNumber, cscNumber, cubeNumber, divideNumber, expm1Number, expNumber, gammaNumber, gcdNumber, isIntegerNumber, isNaNNumber, isNegativeNumber, isPositiveNumber, isZeroNumber, lcmNumber, leftShiftNumber, lgammaNumber, log10Number, log1pNumber, log2Number, logNumber, modNumber, multiplyNumber, normNumber, notNumber, nthRootNumber, orNumber, powNumber, rightArithShiftNumber, rightLogShiftNumber, roundNumber, sechNumber, secNumber, signNumber, sinhNumber, sinNumber, sqrtNumber, squareNumber, subtractNumber, tanhNumber, tanNumber, unaryMinusNumber, unaryPlusNumber, xgcdNumber, xorNumber } from './plain/number/index.js'; +import { factory } from './utils/factory.js'; +import { noIndex, noMatrix, noSubset } from './utils/noop.js'; + +// ---------------------------------------------------------------------------- +// classes and functions + +// core +export { createTyped } from './core/function/typed.js'; + +// classes +export { createResultSet } from './type/resultset/ResultSet.js'; +export { createRangeClass } from './type/matrix/Range.js'; +export { createHelpClass } from './expression/Help.js'; +export { createChainClass } from './type/chain/Chain.js'; +export { createHelp } from './expression/function/help.js'; +export { createChain } from './type/chain/function/chain.js'; + +// algebra +export { createResolve } from './function/algebra/resolve.js'; +export { createSimplify } from './function/algebra/simplify.js'; +export { createSimplifyConstant } from './function/algebra/simplifyConstant.js'; +export { createSimplifyCore } from './function/algebra/simplifyCore.js'; +export { createDerivative } from './function/algebra/derivative.js'; +export { createRationalize } from './function/algebra/rationalize.js'; + +// arithmetic +export var createUnaryMinus = /* #__PURE__ */createNumberFactory('unaryMinus', unaryMinusNumber); +export var createUnaryPlus = /* #__PURE__ */createNumberFactory('unaryPlus', unaryPlusNumber); +export var createAbs = /* #__PURE__ */createNumberFactory('abs', absNumber); +export var createAddScalar = /* #__PURE__ */createNumberFactory('addScalar', addNumber); +export var createSubtractScalar = /* #__PURE__ */createNumberFactory('subtractScalar', subtractNumber); +export var createCbrt = /* #__PURE__ */createNumberFactory('cbrt', cbrtNumber); +export { createCeilNumber as createCeil } from './function/arithmetic/ceil.js'; +export var createCube = /* #__PURE__ */createNumberFactory('cube', cubeNumber); +export var createExp = /* #__PURE__ */createNumberFactory('exp', expNumber); +export var createExpm1 = /* #__PURE__ */createNumberFactory('expm1', expm1Number); +export { createFixNumber as createFix } from './function/arithmetic/fix.js'; +export { createFloorNumber as createFloor } from './function/arithmetic/floor.js'; +export var createGcd = /* #__PURE__ */createNumberFactory('gcd', gcdNumber); +export var createLcm = /* #__PURE__ */createNumberFactory('lcm', lcmNumber); +export var createLog10 = /* #__PURE__ */createNumberFactory('log10', log10Number); +export var createLog2 = /* #__PURE__ */createNumberFactory('log2', log2Number); +export var createMod = /* #__PURE__ */createNumberFactory('mod', modNumber); +export var createMultiplyScalar = /* #__PURE__ */createNumberFactory('multiplyScalar', multiplyNumber); +export var createMultiply = /* #__PURE__ */createNumberFactory('multiply', multiplyNumber); +export var createNthRoot = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('nthRoot', nthRootNumber); +export var createSign = /* #__PURE__ */createNumberFactory('sign', signNumber); +export var createSqrt = /* #__PURE__ */createNumberFactory('sqrt', sqrtNumber); +export var createSquare = /* #__PURE__ */createNumberFactory('square', squareNumber); +export var createSubtract = /* #__PURE__ */createNumberFactory('subtract', subtractNumber); +export var createXgcd = /* #__PURE__ */createNumberFactory('xgcd', xgcdNumber); +export var createDivideScalar = /* #__PURE__ */createNumberFactory('divideScalar', divideNumber); +export var createPow = /* #__PURE__ */createNumberFactory('pow', powNumber); +export var createRound = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('round', roundNumber); +export var createLog = /* #__PURE__ */ +createNumberOptionalSecondArgFactory('log', logNumber); +export var createLog1p = /* #__PURE__ */createNumberFactory('log1p', log1pNumber); +export var createAdd = /* #__PURE__ */createNumberFactory('add', addNumber); +export { createHypot } from './function/arithmetic/hypot.js'; +export var createNorm = /* #__PURE__ */createNumberFactory('norm', normNumber); +export var createDivide = /* #__PURE__ */createNumberFactory('divide', divideNumber); + +// bitwise +export var createBitAnd = /* #__PURE__ */createNumberFactory('bitAnd', bitAndNumber); +export var createBitNot = /* #__PURE__ */createNumberFactory('bitNot', bitNotNumber); +export var createBitOr = /* #__PURE__ */createNumberFactory('bitOr', bitOrNumber); +export var createBitXor = /* #__PURE__ */createNumberFactory('bitXor', bitXorNumber); +export var createLeftShift = /* #__PURE__ */createNumberFactory('leftShift', leftShiftNumber); +export var createRightArithShift = /* #__PURE__ */createNumberFactory('rightArithShift', rightArithShiftNumber); +export var createRightLogShift = /* #__PURE__ */createNumberFactory('rightLogShift', rightLogShiftNumber); + +// combinatorics +export { createStirlingS2 } from './function/combinatorics/stirlingS2.js'; +export { createBellNumbers } from './function/combinatorics/bellNumbers.js'; +export { createCatalan } from './function/combinatorics/catalan.js'; +export { createComposition } from './function/combinatorics/composition.js'; + +// constants +export { createE, createUppercaseE, createFalse, +// createI, +createInfinity, createLN10, createLN2, createLOG10E, createLOG2E, createNaN, createNull, createPhi, createPi, createUppercasePi, createSQRT1_2, +// eslint-disable-line camelcase +createSQRT2, createTau, createTrue, createVersion } from './constants.js'; + +// create +export { createNumber } from './type/number.js'; +export { createBigint } from './type/bigint.js'; +export { createString } from './type/string.js'; +export { createBoolean } from './type/boolean.js'; +export { createParser } from './expression/function/parser.js'; + +// expression +export { createNode } from './expression/node/Node.js'; +export { createAccessorNode } from './expression/node/AccessorNode.js'; +export { createArrayNode } from './expression/node/ArrayNode.js'; +export { createAssignmentNode } from './expression/node/AssignmentNode.js'; +export { createBlockNode } from './expression/node/BlockNode.js'; +export { createConditionalNode } from './expression/node/ConditionalNode.js'; +export { createConstantNode } from './expression/node/ConstantNode.js'; +export { createFunctionAssignmentNode } from './expression/node/FunctionAssignmentNode.js'; +export { createIndexNode } from './expression/node/IndexNode.js'; +export { createObjectNode } from './expression/node/ObjectNode.js'; +export { createOperatorNode } from './expression/node/OperatorNode.js'; +export { createParenthesisNode } from './expression/node/ParenthesisNode.js'; +export { createRangeNode } from './expression/node/RangeNode.js'; +export { createRelationalNode } from './expression/node/RelationalNode.js'; +export { createSymbolNode } from './expression/node/SymbolNode.js'; +export { createFunctionNode } from './expression/node/FunctionNode.js'; +export { createParse } from './expression/parse.js'; +export { createCompile } from './expression/function/compile.js'; +export { createEvaluate } from './expression/function/evaluate.js'; +export { createParserClass } from './expression/Parser.js'; + +// logical +export var createAnd = /* #__PURE__ */createNumberFactory('and', andNumber); +export var createNot = /* #__PURE__ */createNumberFactory('not', notNumber); +export var createOr = /* #__PURE__ */createNumberFactory('or', orNumber); +export var createXor = /* #__PURE__ */createNumberFactory('xor', xorNumber); + +// matrix +export { createApply } from './function/matrix/apply.js'; +export { createFilter } from './function/matrix/filter.js'; +export { createForEach } from './function/matrix/forEach.js'; +export { createMap } from './function/matrix/map.js'; +export { createRange } from './function/matrix/range.js'; +export { createSize } from './function/matrix/size.js'; +// FIXME: create a lightweight "number" implementation of subset only supporting plain objects/arrays +export var createIndex = /* #__PURE__ */factory('index', [], () => noIndex); +export var createMatrix = /* #__PURE__ */factory('matrix', [], () => noMatrix); // FIXME: needed now because subset transform needs it. Remove the need for it in subset +export var createSubset = /* #__PURE__ */factory('subset', [], () => noSubset); +// TODO: provide number+array implementations for map, filter, forEach, zeros, ...? +// TODO: create range implementation for range? +export { createPartitionSelect } from './function/matrix/partitionSelect.js'; + +// probability +export var createCombinations = createNumberFactory('combinations', combinationsNumber); +export var createGamma = createNumberFactory('gamma', gammaNumber); +export var createLgamma = createNumberFactory('lgamma', lgammaNumber); +export { createCombinationsWithRep } from './function/probability/combinationsWithRep.js'; +export { createFactorial } from './function/probability/factorial.js'; +export { createMultinomial } from './function/probability/multinomial.js'; +export { createPermutations } from './function/probability/permutations.js'; +export { createPickRandom } from './function/probability/pickRandom.js'; +export { createRandomNumber as createRandom } from './function/probability/random.js'; +export { createRandomInt } from './function/probability/randomInt.js'; + +// relational +export { createEqualScalarNumber as createEqualScalar } from './function/relational/equalScalar.js'; +export { createCompareNumber as createCompare } from './function/relational/compare.js'; +export { createCompareNatural } from './function/relational/compareNatural.js'; +export { createCompareTextNumber as createCompareText } from './function/relational/compareText.js'; +export { createEqualNumber as createEqual } from './function/relational/equal.js'; +export { createEqualText } from './function/relational/equalText.js'; +export { createSmallerNumber as createSmaller } from './function/relational/smaller.js'; +export { createSmallerEqNumber as createSmallerEq } from './function/relational/smallerEq.js'; +export { createLargerNumber as createLarger } from './function/relational/larger.js'; +export { createLargerEqNumber as createLargerEq } from './function/relational/largerEq.js'; +export { createDeepEqual } from './function/relational/deepEqual.js'; +export { createUnequalNumber as createUnequal } from './function/relational/unequal.js'; + +// special +export { createErf } from './function/special/erf.js'; +export { createZeta } from './function/special/zeta.js'; +// statistics +export { createMode } from './function/statistics/mode.js'; +export { createProd } from './function/statistics/prod.js'; +export { createMax } from './function/statistics/max.js'; +export { createMin } from './function/statistics/min.js'; +export { createSum } from './function/statistics/sum.js'; +export { createCumSum } from './function/statistics/cumsum.js'; +export { createMean } from './function/statistics/mean.js'; +export { createMedian } from './function/statistics/median.js'; +export { createMad } from './function/statistics/mad.js'; +export { createVariance } from './function/statistics/variance.js'; +export { createQuantileSeq } from './function/statistics/quantileSeq.js'; +export { createStd } from './function/statistics/std.js'; +export { createCorr } from './function/statistics/corr.js'; + +// string +export { createFormat } from './function/string/format.js'; +export { createPrint } from './function/string/print.js'; + +// trigonometry +export var createAcos = /* #__PURE__ */createNumberFactory('acos', acosNumber); +export var createAcosh = /* #__PURE__ */createNumberFactory('acosh', acoshNumber); +export var createAcot = /* #__PURE__ */createNumberFactory('acot', acotNumber); +export var createAcoth = /* #__PURE__ */createNumberFactory('acoth', acothNumber); +export var createAcsc = /* #__PURE__ */createNumberFactory('acsc', acscNumber); +export var createAcsch = /* #__PURE__ */createNumberFactory('acsch', acschNumber); +export var createAsec = /* #__PURE__ */createNumberFactory('asec', asecNumber); +export var createAsech = /* #__PURE__ */createNumberFactory('asech', asechNumber); +export var createAsin = /* #__PURE__ */createNumberFactory('asin', asinNumber); +export var createAsinh = /* #__PURE__ */createNumberFactory('asinh', asinhNumber); +export var createAtan = /* #__PURE__ */createNumberFactory('atan', atanNumber); +export var createAtan2 = /* #__PURE__ */createNumberFactory('atan2', atan2Number); +export var createAtanh = /* #__PURE__ */createNumberFactory('atanh', atanhNumber); +export var createCos = /* #__PURE__ */createNumberFactory('cos', cosNumber); +export var createCosh = /* #__PURE__ */createNumberFactory('cosh', coshNumber); +export var createCot = /* #__PURE__ */createNumberFactory('cot', cotNumber); +export var createCoth = /* #__PURE__ */createNumberFactory('coth', cothNumber); +export var createCsc = /* #__PURE__ */createNumberFactory('csc', cscNumber); +export var createCsch = /* #__PURE__ */createNumberFactory('csch', cschNumber); +export var createSec = /* #__PURE__ */createNumberFactory('sec', secNumber); +export var createSech = /* #__PURE__ */createNumberFactory('sech', sechNumber); +export var createSin = /* #__PURE__ */createNumberFactory('sin', sinNumber); +export var createSinh = /* #__PURE__ */createNumberFactory('sinh', sinhNumber); +export var createTan = /* #__PURE__ */createNumberFactory('tan', tanNumber); +export var createTanh = /* #__PURE__ */createNumberFactory('tanh', tanhNumber); + +// transforms +export { createApplyTransform } from './expression/transform/apply.transform.js'; +export { createFilterTransform } from './expression/transform/filter.transform.js'; +export { createForEachTransform } from './expression/transform/forEach.transform.js'; +export { createMapTransform } from './expression/transform/map.transform.js'; +export { createMaxTransform } from './expression/transform/max.transform.js'; +export { createMeanTransform } from './expression/transform/mean.transform.js'; +export { createMinTransform } from './expression/transform/min.transform.js'; +export { createRangeTransform } from './expression/transform/range.transform.js'; +export var createSubsetTransform = /* #__PURE__ */factory('subset', [], () => noSubset, { + isTransformFunction: true +}); +export { createStdTransform } from './expression/transform/std.transform.js'; +export { createSumTransform } from './expression/transform/sum.transform.js'; +export { createCumSumTransform } from './expression/transform/cumsum.transform.js'; +export { createVarianceTransform } from './expression/transform/variance.transform.js'; + +// utils +export { createClone } from './function/utils/clone.js'; +export var createIsInteger = /* #__PURE__ */createNumberFactory('isInteger', isIntegerNumber); +export var createIsNegative = /* #__PURE__ */createNumberFactory('isNegative', isNegativeNumber); +export { createIsNumeric } from './function/utils/isNumeric.js'; +export { createHasNumericValue } from './function/utils/hasNumericValue.js'; +export var createIsPositive = /* #__PURE__ */createNumberFactory('isPositive', isPositiveNumber); +export var createIsZero = /* #__PURE__ */createNumberFactory('isZero', isZeroNumber); +export var createIsNaN = /* #__PURE__ */createNumberFactory('isNaN', isNaNNumber); +export { createTypeOf } from './function/utils/typeOf.js'; +export { createIsPrime } from './function/utils/isPrime.js'; +export { createNumeric } from './function/utils/numeric.js'; + +// json +export { createReviver } from './json/reviver.js'; +export { createReplacer } from './json/replacer.js'; + +// helper functions to create a factory function for a function which only needs typed-function +function createNumberFactory(name, fn) { + return factory(name, ['typed'], _ref => { + var { + typed + } = _ref; + return typed(fn); + }); +} +function createNumberOptionalSecondArgFactory(name, fn) { + return factory(name, ['typed'], _ref2 => { + var { + typed + } = _ref2; + return typed({ + number: fn, + 'number,number': fn + }); + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/lup.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/lup.js new file mode 100644 index 0000000..aa4c6b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/lup.js @@ -0,0 +1,379 @@ +import { clone } from '../../../utils/object.js'; +import { factory } from '../../../utils/factory.js'; +var name = 'lup'; +var dependencies = ['typed', 'matrix', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'larger', 'equalScalar', 'unaryMinus', 'DenseMatrix', 'SparseMatrix', 'Spa']; +export var createLup = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + abs, + addScalar, + divideScalar, + multiplyScalar, + subtractScalar, + larger, + equalScalar, + unaryMinus, + DenseMatrix, + SparseMatrix, + Spa + } = _ref; + /** + * Calculate the Matrix LU decomposition with partial pivoting. Matrix `A` is decomposed in two matrices (`L`, `U`) and a + * row permutation vector `p` where `A[p,:] = L * U` + * + * Syntax: + * + * math.lup(A) + * + * Example: + * + * const m = [[2, 1], [1, 4]] + * const r = math.lup(m) + * // r = { + * // L: [[1, 0], [0.5, 1]], + * // U: [[2, 1], [0, 3.5]], + * // P: [0, 1] + * // } + * + * See also: + * + * slu, lsolve, lusolve, usolve + * + * @param {Matrix | Array} A A two dimensional matrix or array for which to get the LUP decomposition. + * + * @return {{L: Array | Matrix, U: Array | Matrix, P: Array.}} The lower triangular matrix, the upper triangular matrix and the permutation matrix. + */ + return typed(name, { + DenseMatrix: function DenseMatrix(m) { + return _denseLUP(m); + }, + SparseMatrix: function SparseMatrix(m) { + return _sparseLUP(m); + }, + Array: function Array(a) { + // create dense matrix from array + var m = matrix(a); + // lup, use matrix implementation + var r = _denseLUP(m); + // result + return { + L: r.L.valueOf(), + U: r.U.valueOf(), + p: r.p + }; + } + }); + function _denseLUP(m) { + // rows & columns + var rows = m._size[0]; + var columns = m._size[1]; + // minimum rows and columns + var n = Math.min(rows, columns); + // matrix array, clone original data + var data = clone(m._data); + // l matrix arrays + var ldata = []; + var lsize = [rows, n]; + // u matrix arrays + var udata = []; + var usize = [n, columns]; + // vars + var i, j, k; + // permutation vector + var p = []; + for (i = 0; i < rows; i++) { + p[i] = i; + } + // loop columns + for (j = 0; j < columns; j++) { + // skip first column in upper triangular matrix + if (j > 0) { + // loop rows + for (i = 0; i < rows; i++) { + // min i,j + var min = Math.min(i, j); + // v[i, j] + var s = 0; + // loop up to min + for (k = 0; k < min; k++) { + // s = l[i, k] - data[k, j] + s = addScalar(s, multiplyScalar(data[i][k], data[k][j])); + } + data[i][j] = subtractScalar(data[i][j], s); + } + } + // row with larger value in cvector, row >= j + var pi = j; + var pabsv = 0; + var vjj = 0; + // loop rows + for (i = j; i < rows; i++) { + // data @ i, j + var v = data[i][j]; + // absolute value + var absv = abs(v); + // value is greater than pivote value + if (larger(absv, pabsv)) { + // store row + pi = i; + // update max value + pabsv = absv; + // value @ [j, j] + vjj = v; + } + } + // swap rows (j <-> pi) + if (j !== pi) { + // swap values j <-> pi in p + p[j] = [p[pi], p[pi] = p[j]][0]; + // swap j <-> pi in data + DenseMatrix._swapRows(j, pi, data); + } + // check column is in lower triangular matrix + if (j < rows) { + // loop rows (lower triangular matrix) + for (i = j + 1; i < rows; i++) { + // value @ i, j + var vij = data[i][j]; + if (!equalScalar(vij, 0)) { + // update data + data[i][j] = divideScalar(data[i][j], vjj); + } + } + } + } + // loop columns + for (j = 0; j < columns; j++) { + // loop rows + for (i = 0; i < rows; i++) { + // initialize row in arrays + if (j === 0) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i] = []; + } + // L + ldata[i] = []; + } + // check we are in the upper triangular matrix + if (i < j) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = data[i][j]; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = 0; + } + continue; + } + // diagonal value + if (i === j) { + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = data[i][j]; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = 1; + } + continue; + } + // check row exists in upper triangular matrix + if (i < columns) { + // U + udata[i][j] = 0; + } + // check column exists in lower triangular matrix + if (j < rows) { + // L + ldata[i][j] = data[i][j]; + } + } + } + // l matrix + var l = new DenseMatrix({ + data: ldata, + size: lsize + }); + // u matrix + var u = new DenseMatrix({ + data: udata, + size: usize + }); + // p vector + var pv = []; + for (i = 0, n = p.length; i < n; i++) { + pv[p[i]] = i; + } + // return matrices + return { + L: l, + U: u, + p: pv, + toString: function toString() { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\nP: ' + this.p; + } + }; + } + function _sparseLUP(m) { + // rows & columns + var rows = m._size[0]; + var columns = m._size[1]; + // minimum rows and columns + var n = Math.min(rows, columns); + // matrix arrays (will not be modified, thanks to permutation vector) + var values = m._values; + var index = m._index; + var ptr = m._ptr; + // l matrix arrays + var lvalues = []; + var lindex = []; + var lptr = []; + var lsize = [rows, n]; + // u matrix arrays + var uvalues = []; + var uindex = []; + var uptr = []; + var usize = [n, columns]; + // vars + var i, j, k; + // permutation vectors, (current index -> original index) and (original index -> current index) + var pvCo = []; + var pvOc = []; + for (i = 0; i < rows; i++) { + pvCo[i] = i; + pvOc[i] = i; + } + // swap indices in permutation vectors (condition x < y)! + var swapIndeces = function swapIndeces(x, y) { + // find pv indeces getting data from x and y + var kx = pvOc[x]; + var ky = pvOc[y]; + // update permutation vector current -> original + pvCo[kx] = y; + pvCo[ky] = x; + // update permutation vector original -> current + pvOc[x] = ky; + pvOc[y] = kx; + }; + // loop columns + var _loop = function _loop() { + // sparse accumulator + var spa = new Spa(); + // check lower triangular matrix has a value @ column j + if (j < rows) { + // update ptr + lptr.push(lvalues.length); + // first value in j column for lower triangular matrix + lvalues.push(1); + lindex.push(j); + } + // update ptr + uptr.push(uvalues.length); + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = ptr[j]; + var k1 = ptr[j + 1]; + // copy column j into sparse accumulator + for (k = k0; k < k1; k++) { + // row + i = index[k]; + // copy column values into sparse accumulator (use permutation vector) + spa.set(pvCo[i], values[k]); + } + // skip first column in upper triangular matrix + if (j > 0) { + // loop rows in column j (above diagonal) + spa.forEach(0, j - 1, function (k, vkj) { + // loop rows in column k (L) + SparseMatrix._forEachRow(k, lvalues, lindex, lptr, function (i, vik) { + // check row is below k + if (i > k) { + // update spa value + spa.accumulate(i, unaryMinus(multiplyScalar(vik, vkj))); + } + }); + }); + } + // row with larger value in spa, row >= j + var pi = j; + var vjj = spa.get(j); + var pabsv = abs(vjj); + // loop values in spa (order by row, below diagonal) + spa.forEach(j + 1, rows - 1, function (x, v) { + // absolute value + var absv = abs(v); + // value is greater than pivote value + if (larger(absv, pabsv)) { + // store row + pi = x; + // update max value + pabsv = absv; + // value @ [j, j] + vjj = v; + } + }); + // swap rows (j <-> pi) + if (j !== pi) { + // swap values j <-> pi in L + SparseMatrix._swapRows(j, pi, lsize[1], lvalues, lindex, lptr); + // swap values j <-> pi in U + SparseMatrix._swapRows(j, pi, usize[1], uvalues, uindex, uptr); + // swap values in spa + spa.swap(j, pi); + // update permutation vector (swap values @ j, pi) + swapIndeces(j, pi); + } + // loop values in spa (order by row) + spa.forEach(0, rows - 1, function (x, v) { + // check we are above diagonal + if (x <= j) { + // update upper triangular matrix + uvalues.push(v); + uindex.push(x); + } else { + // update value + v = divideScalar(v, vjj); + // check value is non zero + if (!equalScalar(v, 0)) { + // update lower triangular matrix + lvalues.push(v); + lindex.push(x); + } + } + }); + }; + for (j = 0; j < columns; j++) { + _loop(); + } + // update ptrs + uptr.push(uvalues.length); + lptr.push(lvalues.length); + + // return matrices + return { + L: new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: lsize + }), + U: new SparseMatrix({ + values: uvalues, + index: uindex, + ptr: uptr, + size: usize + }), + p: pvCo, + toString: function toString() { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\nP: ' + this.p; + } + }; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/qr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/qr.js new file mode 100644 index 0000000..ad79a33 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/qr.js @@ -0,0 +1,222 @@ +import _extends from "@babel/runtime/helpers/extends"; +import { factory } from '../../../utils/factory.js'; +var name = 'qr'; +var dependencies = ['typed', 'matrix', 'zeros', 'identity', 'isZero', 'equal', 'sign', 'sqrt', 'conj', 'unaryMinus', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'complex']; +export var createQr = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + zeros, + identity, + isZero, + equal, + sign, + sqrt, + conj, + unaryMinus, + addScalar, + divideScalar, + multiplyScalar, + subtractScalar, + complex + } = _ref; + /** + * Calculate the Matrix QR decomposition. Matrix `A` is decomposed in + * two matrices (`Q`, `R`) where `Q` is an + * orthogonal matrix and `R` is an upper triangular matrix. + * + * Syntax: + * + * math.qr(A) + * + * Example: + * + * const m = [ + * [1, -1, 4], + * [1, 4, -2], + * [1, 4, 2], + * [1, -1, 0] + * ] + * const result = math.qr(m) + * // r = { + * // Q: [ + * // [0.5, -0.5, 0.5], + * // [0.5, 0.5, -0.5], + * // [0.5, 0.5, 0.5], + * // [0.5, -0.5, -0.5], + * // ], + * // R: [ + * // [2, 3, 2], + * // [0, 5, -2], + * // [0, 0, 4], + * // [0, 0, 0] + * // ] + * // } + * + * See also: + * + * lup, lusolve + * + * @param {Matrix | Array} A A two dimensional matrix or array + * for which to get the QR decomposition. + * + * @return {{Q: Array | Matrix, R: Array | Matrix}} Q: the orthogonal + * matrix and R: the upper triangular matrix + */ + return _extends(typed(name, { + DenseMatrix: function DenseMatrix(m) { + return _denseQR(m); + }, + SparseMatrix: function SparseMatrix(m) { + return _sparseQR(m); + }, + Array: function Array(a) { + // create dense matrix from array + var m = matrix(a); + // lup, use matrix implementation + var r = _denseQR(m); + // result + return { + Q: r.Q.valueOf(), + R: r.R.valueOf() + }; + } + }), { + _denseQRimpl + }); + function _denseQRimpl(m) { + // rows & columns (m x n) + var rows = m._size[0]; // m + var cols = m._size[1]; // n + + var Q = identity([rows], 'dense'); + var Qdata = Q._data; + var R = m.clone(); + var Rdata = R._data; + + // vars + var i, j, k; + var w = zeros([rows], ''); + for (k = 0; k < Math.min(cols, rows); ++k) { + /* + * **k-th Household matrix** + * + * The matrix I - 2*v*transpose(v) + * x = first column of A + * x1 = first element of x + * alpha = x1 / |x1| * |x| + * e1 = tranpose([1, 0, 0, ...]) + * u = x - alpha * e1 + * v = u / |u| + * + * Household matrix = I - 2 * v * tranpose(v) + * + * * Initially Q = I and R = A. + * * Household matrix is a reflection in a plane normal to v which + * will zero out all but the top right element in R. + * * Appplying reflection to both Q and R will not change product. + * * Repeat this process on the (1,1) minor to get R as an upper + * triangular matrix. + * * Reflections leave the magnitude of the columns of Q unchanged + * so Q remains othoganal. + * + */ + + var pivot = Rdata[k][k]; + var sgn = unaryMinus(equal(pivot, 0) ? 1 : sign(pivot)); + var conjSgn = conj(sgn); + var alphaSquared = 0; + for (i = k; i < rows; i++) { + alphaSquared = addScalar(alphaSquared, multiplyScalar(Rdata[i][k], conj(Rdata[i][k]))); + } + var alpha = multiplyScalar(sgn, sqrt(alphaSquared)); + if (!isZero(alpha)) { + // first element in vector u + var u1 = subtractScalar(pivot, alpha); + + // w = v * u1 / |u| (only elements k to (rows-1) are used) + w[k] = 1; + for (i = k + 1; i < rows; i++) { + w[i] = divideScalar(Rdata[i][k], u1); + } + + // tau = - conj(u1 / alpha) + var tau = unaryMinus(conj(divideScalar(u1, alpha))); + var s = void 0; + + /* + * tau and w have been choosen so that + * + * 2 * v * tranpose(v) = tau * w * tranpose(w) + */ + + /* + * -- calculate R = R - tau * w * tranpose(w) * R -- + * Only do calculation with rows k to (rows-1) + * Additionally columns 0 to (k-1) will not be changed by this + * multiplication so do not bother recalculating them + */ + for (j = k; j < cols; j++) { + s = 0.0; + + // calculate jth element of [tranpose(w) * R] + for (i = k; i < rows; i++) { + s = addScalar(s, multiplyScalar(conj(w[i]), Rdata[i][j])); + } + + // calculate the jth element of [tau * transpose(w) * R] + s = multiplyScalar(s, tau); + for (i = k; i < rows; i++) { + Rdata[i][j] = multiplyScalar(subtractScalar(Rdata[i][j], multiplyScalar(w[i], s)), conjSgn); + } + } + /* + * -- calculate Q = Q - tau * Q * w * transpose(w) -- + * Q is a square matrix (rows x rows) + * Only do calculation with columns k to (rows-1) + * Additionally rows 0 to (k-1) will not be changed by this + * multiplication so do not bother recalculating them + */ + for (i = 0; i < rows; i++) { + s = 0.0; + + // calculate ith element of [Q * w] + for (j = k; j < rows; j++) { + s = addScalar(s, multiplyScalar(Qdata[i][j], w[j])); + } + + // calculate the ith element of [tau * Q * w] + s = multiplyScalar(s, tau); + for (j = k; j < rows; ++j) { + Qdata[i][j] = divideScalar(subtractScalar(Qdata[i][j], multiplyScalar(s, conj(w[j]))), conjSgn); + } + } + } + } + + // return matrices + return { + Q, + R, + toString: function toString() { + return 'Q: ' + this.Q.toString() + '\nR: ' + this.R.toString(); + } + }; + } + function _denseQR(m) { + var ret = _denseQRimpl(m); + var Rdata = ret.R._data; + if (m._data.length > 0) { + var zero = Rdata[0][0].type === 'Complex' ? complex(0) : 0; + for (var i = 0; i < Rdata.length; ++i) { + for (var j = 0; j < i && j < (Rdata[0] || []).length; ++j) { + Rdata[i][j] = zero; + } + } + } + return ret; + } + function _sparseQR(m) { + throw new Error('qr not implemented for sparse matrices yet'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/schur.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/schur.js new file mode 100644 index 0000000..a3ee46f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/schur.js @@ -0,0 +1,70 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'schur'; +var dependencies = ['typed', 'matrix', 'identity', 'multiply', 'qr', 'norm', 'subtract']; +export var createSchur = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + identity, + multiply, + qr, + norm, + subtract + } = _ref; + /** + * + * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal + * and T is upper quasi-triangular. + * https://en.wikipedia.org/wiki/Schur_decomposition + * + * Syntax: + * + * math.schur(A) + * + * Examples: + * + * const A = [[1, 0], [-4, 3]] + * math.schur(A) // returns {T: [[3, 4], [0, 1]], R: [[0, 1], [-1, 0]]} + * + * See also: + * + * sylvester, lyap, qr + * + * @param {Array | Matrix} A Matrix A + * @return {{U: Array | Matrix, T: Array | Matrix}} Object containing both matrix U and T of the Schur Decomposition A=UTU' + */ + return typed(name, { + Array: function Array(X) { + var r = _schur(matrix(X)); + return { + U: r.U.valueOf(), + T: r.T.valueOf() + }; + }, + Matrix: function Matrix(X) { + return _schur(X); + } + }); + function _schur(X) { + var n = X.size()[0]; + var A = X; + var U = identity(n); + var k = 0; + var A0; + do { + A0 = A; + var QR = qr(A); + var Q = QR.Q; + var R = QR.R; + A = multiply(R, Q); + U = multiply(U, Q); + if (k++ > 100) { + break; + } + } while (norm(subtract(A, A0)) > 1e-4); + return { + U, + T: A + }; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/slu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/slu.js new file mode 100644 index 0000000..13f07f9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/decomposition/slu.js @@ -0,0 +1,101 @@ +import { isInteger } from '../../../utils/number.js'; +import { factory } from '../../../utils/factory.js'; +import { createCsSqr } from '../sparse/csSqr.js'; +import { createCsLu } from '../sparse/csLu.js'; +var name = 'slu'; +var dependencies = ['typed', 'abs', 'add', 'multiply', 'transpose', 'divideScalar', 'subtract', 'larger', 'largerEq', 'SparseMatrix']; +export var createSlu = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + add, + multiply, + transpose, + divideScalar, + subtract, + larger, + largerEq, + SparseMatrix + } = _ref; + var csSqr = createCsSqr({ + add, + multiply, + transpose + }); + var csLu = createCsLu({ + abs, + divideScalar, + multiply, + subtract, + larger, + largerEq, + SparseMatrix + }); + + /** + * Calculate the Sparse Matrix LU decomposition with full pivoting. Sparse Matrix `A` is decomposed in two matrices (`L`, `U`) and two permutation vectors (`pinv`, `q`) where + * + * `P * A * Q = L * U` + * + * Syntax: + * + * math.slu(A, order, threshold) + * + * Examples: + * + * const A = math.sparse([[4,3], [6, 3]]) + * math.slu(A, 1, 0.001) + * // returns: + * // { + * // L: [[1, 0], [1.5, 1]] + * // U: [[4, 3], [0, -1.5]] + * // p: [0, 1] + * // q: [0, 1] + * // } + * + * See also: + * + * lup, lsolve, usolve, lusolve + * + * @param {SparseMatrix} A A two dimensional sparse matrix for which to get the LU decomposition. + * @param {Number} order The Symbolic Ordering and Analysis order: + * 0 - Natural ordering, no permutation vector q is returned + * 1 - Matrix must be square, symbolic ordering and analisis is performed on M = A + A' + * 2 - Symbolic ordering and analisis is performed on M = A' * A. Dense columns from A' are dropped, A recreated from A'. + * This is appropriatefor LU factorization of unsymmetric matrices. + * 3 - Symbolic ordering and analisis is performed on M = A' * A. This is best used for LU factorization is matrix M has no dense rows. + * A dense row is a row with more than 10*sqr(columns) entries. + * @param {Number} threshold Partial pivoting threshold (1 for partial pivoting) + * + * @return {Object} The lower triangular matrix, the upper triangular matrix and the permutation vectors. + */ + return typed(name, { + 'SparseMatrix, number, number': function SparseMatrix_number_number(a, order, threshold) { + // verify order + if (!isInteger(order) || order < 0 || order > 3) { + throw new Error('Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]'); + } + // verify threshold + if (threshold < 0 || threshold > 1) { + throw new Error('Partial pivoting threshold must be a number from 0 to 1'); + } + + // perform symbolic ordering and analysis + var s = csSqr(order, a, false); + + // perform lu decomposition + var f = csLu(a, s, threshold); + + // return decomposition + return { + L: f.L, + U: f.U, + p: f.pinv, + q: s.q, + toString: function toString() { + return 'L: ' + this.L.toString() + '\nU: ' + this.U.toString() + '\np: ' + this.p.toString() + (this.q ? '\nq: ' + this.q.toString() : '') + '\n'; + } + }; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/derivative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/derivative.js new file mode 100644 index 0000000..6291d6d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/derivative.js @@ -0,0 +1,519 @@ +import { isConstantNode, typeOf } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +var name = 'derivative'; +var dependencies = ['typed', 'config', 'parse', 'simplify', 'equal', 'isZero', 'numeric', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +export var createDerivative = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + parse, + simplify, + equal, + isZero, + numeric, + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + /** + * Takes the derivative of an expression expressed in parser Nodes. + * The derivative will be taken over the supplied variable in the + * second parameter. If there are multiple variables in the expression, + * it will return a partial derivative. + * + * This uses rules of differentiation which can be found here: + * + * - [Differentiation rules (Wikipedia)](https://en.wikipedia.org/wiki/Differentiation_rules) + * + * Syntax: + * + * math.derivative(expr, variable) + * math.derivative(expr, variable, options) + * + * Examples: + * + * math.derivative('x^2', 'x') // Node '2 * x' + * math.derivative('x^2', 'x', {simplify: false}) // Node '2 * 1 * x ^ (2 - 1)' + * math.derivative('sin(2x)', 'x')) // Node '2 * cos(2 * x)' + * math.derivative('2*x', 'x').evaluate() // number 2 + * math.derivative('x^2', 'x').evaluate({x: 4}) // number 8 + * const f = math.parse('x^2') + * const x = math.parse('x') + * math.derivative(f, x) // Node {2 * x} + * + * See also: + * + * simplify, parse, evaluate + * + * @param {Node | string} expr The expression to differentiate + * @param {SymbolNode | string} variable The variable over which to differentiate + * @param {{simplify: boolean}} [options] + * There is one option available, `simplify`, which + * is true by default. When false, output will not + * be simplified. + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr` + */ + function plainDerivative(expr, variable) { + var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : { + simplify: true + }; + var constNodes = {}; + constTag(constNodes, expr, variable.name); + var res = _derivative(expr, constNodes); + return options.simplify ? simplify(res) : res; + } + function parseIdentifier(string) { + var symbol = parse(string); + if (!symbol.isSymbolNode) { + throw new TypeError('Invalid variable. ' + "Cannot parse ".concat(JSON.stringify(string), " into a variable in function derivative")); + } + return symbol; + } + var derivative = typed(name, { + 'Node, SymbolNode': plainDerivative, + 'Node, SymbolNode, Object': plainDerivative, + 'Node, string': (node, symbol) => plainDerivative(node, parseIdentifier(symbol)), + 'Node, string, Object': (node, symbol, options) => plainDerivative(node, parseIdentifier(symbol), options) + + /* TODO: implement and test syntax with order of derivatives -> implement as an option {order: number} + 'Node, SymbolNode, ConstantNode': function (expr, variable, {order}) { + let res = expr + for (let i = 0; i < order; i++) { + let constNodes = {} + constTag(constNodes, expr, variable.name) + res = _derivative(res, constNodes) + } + return res + } + */ + }); + derivative._simplify = true; + derivative.toTex = function (deriv) { + return _derivTex.apply(null, deriv.args); + }; + + // FIXME: move the toTex method of derivative to latex.js. Difficulty is that it relies on parse. + // NOTE: the optional "order" parameter here is currently unused + var _derivTex = typed('_derivTex', { + 'Node, SymbolNode': function Node_SymbolNode(expr, x) { + if (isConstantNode(expr) && typeOf(expr.value) === 'string') { + return _derivTex(parse(expr.value).toString(), x.toString(), 1); + } else { + return _derivTex(expr.toTex(), x.toString(), 1); + } + }, + 'Node, ConstantNode': function Node_ConstantNode(expr, x) { + if (typeOf(x.value) === 'string') { + return _derivTex(expr, parse(x.value)); + } else { + throw new Error("The second parameter to 'derivative' is a non-string constant"); + } + }, + 'Node, SymbolNode, ConstantNode': function Node_SymbolNode_ConstantNode(expr, x, order) { + return _derivTex(expr.toString(), x.name, order.value); + }, + 'string, string, number': function string_string_number(expr, x, order) { + var d; + if (order === 1) { + d = '{d\\over d' + x + '}'; + } else { + d = '{d^{' + order + '}\\over d' + x + '^{' + order + '}}'; + } + return d + "\\left[".concat(expr, "\\right]"); + } + }); + + /** + * Does a depth-first search on the expression tree to identify what Nodes + * are constants (e.g. 2 + 2), and stores the ones that are constants in + * constNodes. Classification is done as follows: + * + * 1. ConstantNodes are constants. + * 2. If there exists a SymbolNode, of which we are differentiating over, + * in the subtree it is not constant. + * + * @param {Object} constNodes Holds the nodes that are constant + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {string} varName Variable that we are differentiating + * @return {boolean} if node is constant + */ + // TODO: can we rewrite constTag into a pure function? + var constTag = typed('constTag', { + 'Object, ConstantNode, string': function Object_ConstantNode_string(constNodes, node) { + constNodes[node] = true; + return true; + }, + 'Object, SymbolNode, string': function Object_SymbolNode_string(constNodes, node, varName) { + // Treat other variables like constants. For reasoning, see: + // https://en.wikipedia.org/wiki/Partial_derivative + if (node.name !== varName) { + constNodes[node] = true; + return true; + } + return false; + }, + 'Object, ParenthesisNode, string': function Object_ParenthesisNode_string(constNodes, node, varName) { + return constTag(constNodes, node.content, varName); + }, + 'Object, FunctionAssignmentNode, string': function Object_FunctionAssignmentNode_string(constNodes, node, varName) { + if (!node.params.includes(varName)) { + constNodes[node] = true; + return true; + } + return constTag(constNodes, node.expr, varName); + }, + 'Object, FunctionNode | OperatorNode, string': function Object_FunctionNode__OperatorNode_string(constNodes, node, varName) { + if (node.args.length > 0) { + var isConst = constTag(constNodes, node.args[0], varName); + for (var i = 1; i < node.args.length; ++i) { + isConst = constTag(constNodes, node.args[i], varName) && isConst; + } + if (isConst) { + constNodes[node] = true; + return true; + } + } + return false; + } + }); + + /** + * Applies differentiation rules. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object} constNodes Holds the nodes that are constant + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr` + */ + var _derivative = typed('_derivative', { + 'ConstantNode, Object': function ConstantNode_Object(node) { + return createConstantNode(0); + }, + 'SymbolNode, Object': function SymbolNode_Object(node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + return createConstantNode(1); + }, + 'ParenthesisNode, Object': function ParenthesisNode_Object(node, constNodes) { + return new ParenthesisNode(_derivative(node.content, constNodes)); + }, + 'FunctionAssignmentNode, Object': function FunctionAssignmentNode_Object(node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + return _derivative(node.expr, constNodes); + }, + 'FunctionNode, Object': function FunctionNode_Object(node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + var arg0 = node.args[0]; + var arg1; + var div = false; // is output a fraction? + var negative = false; // is output negative? + + var funcDerivative; + switch (node.name) { + case 'cbrt': + // d/dx(cbrt(x)) = 1 / (3x^(2/3)) + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(3), new OperatorNode('^', 'pow', [arg0, new OperatorNode('/', 'divide', [createConstantNode(2), createConstantNode(3)])])]); + break; + case 'sqrt': + case 'nthRoot': + // d/dx(sqrt(x)) = 1 / (2*sqrt(x)) + if (node.args.length === 1) { + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(2), new FunctionNode('sqrt', [arg0])]); + } else if (node.args.length === 2) { + // Rearrange from nthRoot(x, a) -> x^(1/a) + arg1 = new OperatorNode('/', 'divide', [createConstantNode(1), node.args[1]]); + + // Is a variable? + constNodes[arg1] = constNodes[node.args[1]]; + return _derivative(new OperatorNode('^', 'pow', [arg0, arg1]), constNodes); + } + break; + case 'log10': + arg1 = createConstantNode(10); + /* fall through! */ + case 'log': + if (!arg1 && node.args.length === 1) { + // d/dx(log(x)) = 1 / x + funcDerivative = arg0.clone(); + div = true; + } else if (node.args.length === 1 && arg1 || node.args.length === 2 && constNodes[node.args[1]] !== undefined) { + // d/dx(log(x, c)) = 1 / (x*ln(c)) + funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('log', [arg1 || node.args[1]])]); + div = true; + } else if (node.args.length === 2) { + // d/dx(log(f(x), g(x))) = d/dx(log(f(x)) / log(g(x))) + return _derivative(new OperatorNode('/', 'divide', [new FunctionNode('log', [arg0]), new FunctionNode('log', [node.args[1]])]), constNodes); + } + break; + case 'pow': + if (node.args.length === 2) { + constNodes[arg1] = constNodes[node.args[1]]; + // Pass to pow operator node parser + return _derivative(new OperatorNode('^', 'pow', [arg0, node.args[1]]), constNodes); + } + break; + case 'exp': + // d/dx(e^x) = e^x + funcDerivative = new FunctionNode('exp', [arg0.clone()]); + break; + case 'sin': + // d/dx(sin(x)) = cos(x) + funcDerivative = new FunctionNode('cos', [arg0.clone()]); + break; + case 'cos': + // d/dx(cos(x)) = -sin(x) + funcDerivative = new OperatorNode('-', 'unaryMinus', [new FunctionNode('sin', [arg0.clone()])]); + break; + case 'tan': + // d/dx(tan(x)) = sec(x)^2 + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sec', [arg0.clone()]), createConstantNode(2)]); + break; + case 'sec': + // d/dx(sec(x)) = sec(x)tan(x) + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tan', [arg0.clone()])]); + break; + case 'csc': + // d/dx(csc(x)) = -csc(x)cot(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('cot', [arg0.clone()])]); + break; + case 'cot': + // d/dx(cot(x)) = -csc(x)^2 + negative = true; + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csc', [arg0.clone()]), createConstantNode(2)]); + break; + case 'asin': + // d/dx(asin(x)) = 1 / sqrt(1 - x^2) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]); + break; + case 'acos': + // d/dx(acos(x)) = -1 / sqrt(1 - x^2) + div = true; + negative = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]); + break; + case 'atan': + // d/dx(atan(x)) = 1 / (x^2 + 1) + div = true; + funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]); + break; + case 'asec': + // d/dx(asec(x)) = 1 / (|x|*sqrt(x^2 - 1)) + div = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acsc': + // d/dx(acsc(x)) = -1 / (|x|*sqrt(x^2 - 1)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acot': + // d/dx(acot(x)) = -1 / (x^2 + 1) + div = true; + negative = true; + funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]); + break; + case 'sinh': + // d/dx(sinh(x)) = cosh(x) + funcDerivative = new FunctionNode('cosh', [arg0.clone()]); + break; + case 'cosh': + // d/dx(cosh(x)) = sinh(x) + funcDerivative = new FunctionNode('sinh', [arg0.clone()]); + break; + case 'tanh': + // d/dx(tanh(x)) = sech(x)^2 + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sech', [arg0.clone()]), createConstantNode(2)]); + break; + case 'sech': + // d/dx(sech(x)) = -sech(x)tanh(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tanh', [arg0.clone()])]); + break; + case 'csch': + // d/dx(csch(x)) = -csch(x)coth(x) + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('coth', [arg0.clone()])]); + break; + case 'coth': + // d/dx(coth(x)) = -csch(x)^2 + negative = true; + funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csch', [arg0.clone()]), createConstantNode(2)]); + break; + case 'asinh': + // d/dx(asinh(x)) = 1 / sqrt(x^2 + 1) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]); + break; + case 'acosh': + // d/dx(acosh(x)) = 1 / sqrt(x^2 - 1); XXX potentially only for x >= 1 (the real spectrum) + div = true; + funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]); + break; + case 'atanh': + // d/dx(atanh(x)) = 1 / (1 - x^2) + div = true; + funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]); + break; + case 'asech': + // d/dx(asech(x)) = -1 / (x*sqrt(1 - x^2)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])])]); + break; + case 'acsch': + // d/dx(acsch(x)) = -1 / (|x|*sqrt(x^2 + 1)) + div = true; + negative = true; + funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]); + break; + case 'acoth': + // d/dx(acoth(x)) = -1 / (1 - x^2) + div = true; + negative = true; + funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]); + break; + case 'abs': + // d/dx(abs(x)) = abs(x)/x + funcDerivative = new OperatorNode('/', 'divide', [new FunctionNode(new SymbolNode('abs'), [arg0.clone()]), arg0.clone()]); + break; + case 'gamma': // Needs digamma function, d/dx(gamma(x)) = gamma(x)digamma(x) + default: + throw new Error('Cannot process function "' + node.name + '" in derivative: ' + 'the function is not supported, undefined, or the number of arguments passed to it are not supported'); + } + var op, func; + if (div) { + op = '/'; + func = 'divide'; + } else { + op = '*'; + func = 'multiply'; + } + + /* Apply chain rule to all functions: + F(x) = f(g(x)) + F'(x) = g'(x)*f'(g(x)) */ + var chainDerivative = _derivative(arg0, constNodes); + if (negative) { + chainDerivative = new OperatorNode('-', 'unaryMinus', [chainDerivative]); + } + return new OperatorNode(op, func, [chainDerivative, funcDerivative]); + }, + 'OperatorNode, Object': function OperatorNode_Object(node, constNodes) { + if (constNodes[node] !== undefined) { + return createConstantNode(0); + } + if (node.op === '+') { + // d/dx(sum(f(x)) = sum(f'(x)) + return new OperatorNode(node.op, node.fn, node.args.map(function (arg) { + return _derivative(arg, constNodes); + })); + } + if (node.op === '-') { + // d/dx(+/-f(x)) = +/-f'(x) + if (node.isUnary()) { + return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes)]); + } + + // Linearity of differentiation, d/dx(f(x) +/- g(x)) = f'(x) +/- g'(x) + if (node.isBinary()) { + return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes), _derivative(node.args[1], constNodes)]); + } + } + if (node.op === '*') { + // d/dx(c*f(x)) = c*f'(x) + var constantTerms = node.args.filter(function (arg) { + return constNodes[arg] !== undefined; + }); + if (constantTerms.length > 0) { + var nonConstantTerms = node.args.filter(function (arg) { + return constNodes[arg] === undefined; + }); + var nonConstantNode = nonConstantTerms.length === 1 ? nonConstantTerms[0] : new OperatorNode('*', 'multiply', nonConstantTerms); + var newArgs = constantTerms.concat(_derivative(nonConstantNode, constNodes)); + return new OperatorNode('*', 'multiply', newArgs); + } + + // Product Rule, d/dx(f(x)*g(x)) = f'(x)*g(x) + f(x)*g'(x) + return new OperatorNode('+', 'add', node.args.map(function (argOuter) { + return new OperatorNode('*', 'multiply', node.args.map(function (argInner) { + return argInner === argOuter ? _derivative(argInner, constNodes) : argInner.clone(); + })); + })); + } + if (node.op === '/' && node.isBinary()) { + var arg0 = node.args[0]; + var arg1 = node.args[1]; + + // d/dx(f(x) / c) = f'(x) / c + if (constNodes[arg1] !== undefined) { + return new OperatorNode('/', 'divide', [_derivative(arg0, constNodes), arg1]); + } + + // Reciprocal Rule, d/dx(c / f(x)) = -c(f'(x)/f(x)^2) + if (constNodes[arg0] !== undefined) { + return new OperatorNode('*', 'multiply', [new OperatorNode('-', 'unaryMinus', [arg0]), new OperatorNode('/', 'divide', [_derivative(arg1, constNodes), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])])]); + } + + // Quotient rule, d/dx(f(x) / g(x)) = (f'(x)g(x) - f(x)g'(x)) / g(x)^2 + return new OperatorNode('/', 'divide', [new OperatorNode('-', 'subtract', [new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), arg1.clone()]), new OperatorNode('*', 'multiply', [arg0.clone(), _derivative(arg1, constNodes)])]), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])]); + } + if (node.op === '^' && node.isBinary()) { + var _arg = node.args[0]; + var _arg2 = node.args[1]; + if (constNodes[_arg] !== undefined) { + // If is secretly constant; 0^f(x) = 1 (in JS), 1^f(x) = 1 + if (isConstantNode(_arg) && (isZero(_arg.value) || equal(_arg.value, 1))) { + return createConstantNode(0); + } + + // d/dx(c^f(x)) = c^f(x)*ln(c)*f'(x) + return new OperatorNode('*', 'multiply', [node, new OperatorNode('*', 'multiply', [new FunctionNode('log', [_arg.clone()]), _derivative(_arg2.clone(), constNodes)])]); + } + if (constNodes[_arg2] !== undefined) { + if (isConstantNode(_arg2)) { + // If is secretly constant; f(x)^0 = 1 -> d/dx(1) = 0 + if (isZero(_arg2.value)) { + return createConstantNode(0); + } + // Ignore exponent; f(x)^1 = f(x) + if (equal(_arg2.value, 1)) { + return _derivative(_arg, constNodes); + } + } + + // Elementary Power Rule, d/dx(f(x)^c) = c*f'(x)*f(x)^(c-1) + var powMinusOne = new OperatorNode('^', 'pow', [_arg.clone(), new OperatorNode('-', 'subtract', [_arg2, createConstantNode(1)])]); + return new OperatorNode('*', 'multiply', [_arg2.clone(), new OperatorNode('*', 'multiply', [_derivative(_arg, constNodes), powMinusOne])]); + } + + // Functional Power Rule, d/dx(f^g) = f^g*[f'*(g/f) + g'ln(f)] + return new OperatorNode('*', 'multiply', [new OperatorNode('^', 'pow', [_arg.clone(), _arg2.clone()]), new OperatorNode('+', 'add', [new OperatorNode('*', 'multiply', [_derivative(_arg, constNodes), new OperatorNode('/', 'divide', [_arg2.clone(), _arg.clone()])]), new OperatorNode('*', 'multiply', [_derivative(_arg2, constNodes), new FunctionNode('log', [_arg.clone()])])])]); + } + throw new Error('Cannot process operator "' + node.op + '" in derivative: ' + 'the operator is not supported, undefined, or the number of arguments passed to it are not supported'); + } + }); + + /** + * Helper function to create a constant node with a specific type + * (number, BigNumber, Fraction) + * @param {number} value + * @param {string} [valueType] + * @return {ConstantNode} + */ + function createConstantNode(value, valueType) { + return new ConstantNode(numeric(value, valueType || safeNumberType(String(value), config))); + } + return derivative; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/leafCount.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/leafCount.js new file mode 100644 index 0000000..b8ea7d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/leafCount.js @@ -0,0 +1,54 @@ +import { factory } from '../../utils/factory.js'; +var name = 'leafCount'; +var dependencies = ['parse', 'typed']; +export var createLeafCount = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + parse, + typed + } = _ref; + // This does the real work, but we don't have to recurse through + // a typed call if we separate it out + function countLeaves(node) { + var count = 0; + node.forEach(n => { + count += countLeaves(n); + }); + return count || 1; + } + + /** + * Gives the number of "leaf nodes" in the parse tree of the given expression + * A leaf node is one that has no subexpressions, essentially either a + * symbol or a constant. Note that `5!` has just one leaf, the '5'; the + * unary factorial operator does not add a leaf. On the other hand, + * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves. + * + * The `simplify()` function should generally not increase the `leafCount()` + * of an expression, although currently there is no guarantee that it never + * does so. In many cases, `simplify()` reduces the leaf count. + * + * Syntax: + * + * math.leafCount(expr) + * + * Examples: + * + * math.leafCount('x') // 1 + * math.leafCount(math.parse('a*d-b*c')) // 4 + * math.leafCount('[a,b;c,d][0,1]') // 6 + * + * See also: + * + * simplify + * + * @param {Node|string} expr The expression to count the leaves of + * + * @return {number} The number of leaves of `expr` + * + */ + return typed(name, { + Node: function Node(expr) { + return countLeaves(expr); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/lyap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/lyap.js new file mode 100644 index 0000000..007a006 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/lyap.js @@ -0,0 +1,52 @@ +import { factory } from '../../utils/factory.js'; +var name = 'lyap'; +var dependencies = ['typed', 'matrix', 'sylvester', 'multiply', 'transpose']; +export var createLyap = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + sylvester, + multiply, + transpose + } = _ref; + /** + * + * Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P, where + * Q is an input matrix. When Q is symmetric, P is also symmetric. Notice + * that different equivalent definitions exist for the Continuous-time + * Lyapunov equation. + * https://en.wikipedia.org/wiki/Lyapunov_equation + * + * Syntax: + * + * math.lyap(A, Q) + * + * Examples: + * + * const A = [[-2, 0], [1, -4]] + * const Q = [[3, 1], [1, 3]] + * const P = math.lyap(A, Q) + * + * See also: + * + * sylvester, schur + * + * @param {Matrix | Array} A Matrix A + * @param {Matrix | Array} Q Matrix Q + * @return {Matrix | Array} Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q + */ + return typed(name, { + 'Matrix, Matrix': function Matrix_Matrix(A, Q) { + return sylvester(A, transpose(A), multiply(-1, Q)); + }, + 'Array, Matrix': function Array_Matrix(A, Q) { + return sylvester(matrix(A), transpose(matrix(A)), multiply(-1, Q)); + }, + 'Matrix, Array': function Matrix_Array(A, Q) { + return sylvester(A, transpose(matrix(A)), matrix(multiply(-1, Q))); + }, + 'Array, Array': function Array_Array(A, Q) { + return sylvester(matrix(A), transpose(matrix(A)), matrix(multiply(-1, Q))).toArray(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/polynomialRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/polynomialRoot.js new file mode 100644 index 0000000..d195254 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/polynomialRoot.js @@ -0,0 +1,122 @@ +import { factory } from '../../utils/factory.js'; +var name = 'polynomialRoot'; +var dependencies = ['typed', 'isZero', 'equalScalar', 'add', 'subtract', 'multiply', 'divide', 'sqrt', 'unaryMinus', 'cbrt', 'typeOf', 'im', 're']; +export var createPolynomialRoot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isZero, + equalScalar, + add, + subtract, + multiply, + divide, + sqrt, + unaryMinus, + cbrt, + typeOf, + im, + re + } = _ref; + /** + * Finds the numerical values of the distinct roots of a polynomial with real or complex coefficients. + * Currently operates only on linear, quadratic, and cubic polynomials using the standard + * formulas for the roots. + * + * Syntax: + * + * math.polynomialRoot(constant, linearCoeff, quadraticCoeff, cubicCoeff) + * + * Examples: + * // linear + * math.polynomialRoot(6, 3) // [-2] + * math.polynomialRoot(math.complex(6,3), 3) // [-2 - i] + * math.polynomialRoot(math.complex(6,3), math.complex(2,1)) // [-3 + 0i] + * // quadratic + * math.polynomialRoot(2, -3, 1) // [2, 1] + * math.polynomialRoot(8, 8, 2) // [-2] + * math.polynomialRoot(-2, 0, 1) // [1.4142135623730951, -1.4142135623730951] + * math.polynomialRoot(2, -2, 1) // [1 + i, 1 - i] + * math.polynomialRoot(math.complex(1,3), math.complex(-3, -2), 1) // [2 + i, 1 + i] + * // cubic + * math.polynomialRoot(-6, 11, -6, 1) // [1, 3, 2] + * math.polynomialRoot(-8, 0, 0, 1) // [-1 - 1.7320508075688774i, 2, -1 + 1.7320508075688774i] + * math.polynomialRoot(0, 8, 8, 2) // [0, -2] + * math.polynomialRoot(1, 1, 1, 1) // [-1 + 0i, 0 - i, 0 + i] + * + * See also: + * cbrt, sqrt + * + * @param {... number | Complex} coeffs + * The coefficients of the polynomial, starting with with the constant coefficent, followed + * by the linear coefficient and subsequent coefficients of increasing powers. + * @return {Array} The distinct roots of the polynomial + */ + + return typed(name, { + 'number|Complex, ...number|Complex': (constant, restCoeffs) => { + var coeffs = [constant, ...restCoeffs]; + while (coeffs.length > 0 && isZero(coeffs[coeffs.length - 1])) { + coeffs.pop(); + } + if (coeffs.length < 2) { + throw new RangeError("Polynomial [".concat(constant, ", ").concat(restCoeffs, "] must have a non-zero non-constant coefficient")); + } + switch (coeffs.length) { + case 2: + // linear + return [unaryMinus(divide(coeffs[0], coeffs[1]))]; + case 3: + { + // quadratic + var [c, b, a] = coeffs; + var denom = multiply(2, a); + var d1 = multiply(b, b); + var d2 = multiply(4, a, c); + if (equalScalar(d1, d2)) return [divide(unaryMinus(b), denom)]; + var discriminant = sqrt(subtract(d1, d2)); + return [divide(subtract(discriminant, b), denom), divide(subtract(unaryMinus(discriminant), b), denom)]; + } + case 4: + { + // cubic, cf. https://en.wikipedia.org/wiki/Cubic_equation + var [d, _c, _b, _a] = coeffs; + var _denom = unaryMinus(multiply(3, _a)); + var D0_1 = multiply(_b, _b); + var D0_2 = multiply(3, _a, _c); + var D1_1 = add(multiply(2, _b, _b, _b), multiply(27, _a, _a, d)); + var D1_2 = multiply(9, _a, _b, _c); + if (equalScalar(D0_1, D0_2) && equalScalar(D1_1, D1_2)) { + return [divide(_b, _denom)]; + } + var Delta0 = subtract(D0_1, D0_2); + var Delta1 = subtract(D1_1, D1_2); + var discriminant1 = add(multiply(18, _a, _b, _c, d), multiply(_b, _b, _c, _c)); + var discriminant2 = add(multiply(4, _b, _b, _b, d), multiply(4, _a, _c, _c, _c), multiply(27, _a, _a, d, d)); + if (equalScalar(discriminant1, discriminant2)) { + return [divide(subtract(multiply(4, _a, _b, _c), add(multiply(9, _a, _a, d), multiply(_b, _b, _b))), multiply(_a, Delta0)), + // simple root + divide(subtract(multiply(9, _a, d), multiply(_b, _c)), multiply(2, Delta0)) // double root + ]; + } + // OK, we have three distinct roots + var Ccubed; + if (equalScalar(D0_1, D0_2)) { + Ccubed = Delta1; + } else { + Ccubed = divide(add(Delta1, sqrt(subtract(multiply(Delta1, Delta1), multiply(4, Delta0, Delta0, Delta0)))), 2); + } + var allRoots = true; + var rawRoots = cbrt(Ccubed, allRoots).toArray().map(C => divide(add(_b, C, divide(Delta0, C)), _denom)); + return rawRoots.map(r => { + if (typeOf(r) === 'Complex' && equalScalar(re(r), re(r) + im(r))) { + return re(r); + } + return r; + }); + } + default: + throw new RangeError("only implemented for cubic or lower-order polynomials, not ".concat(coeffs)); + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/rationalize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/rationalize.js new file mode 100644 index 0000000..ef702ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/rationalize.js @@ -0,0 +1,819 @@ +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'rationalize'; +var dependencies = ['config', 'typed', 'equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'parse', 'simplifyConstant', 'simplifyCore', 'simplify', '?bignumber', '?fraction', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode', 'ParenthesisNode']; +export var createRationalize = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + typed, + equal, + isZero, + add, + subtract, + multiply, + divide, + pow, + parse, + simplifyConstant, + simplifyCore, + simplify, + fraction, + bignumber, + mathWithTransform, + matrix, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode, + ParenthesisNode + } = _ref; + /** + * Transform a rationalizable expression in a rational fraction. + * If rational fraction is one variable polynomial then converts + * the numerator and denominator in canonical form, with decreasing + * exponents, returning the coefficients of numerator. + * + * Syntax: + * + * math.rationalize(expr) + * math.rationalize(expr, detailed) + * math.rationalize(expr, scope) + * math.rationalize(expr, scope, detailed) + * + * Examples: + * + * math.rationalize('sin(x)+y') + * // Error: There is an unsolved function call + * math.rationalize('2x/y - y/(x+1)') + * // (2*x^2-y^2+2*x)/(x*y+y) + * math.rationalize('(2x+1)^6') + * // 64*x^6+192*x^5+240*x^4+160*x^3+60*x^2+12*x+1 + * math.rationalize('2x/( (2x-1) / (3x+2) ) - 5x/ ( (3x+4) / (2x^2-5) ) + 3') + * // -20*x^4+28*x^3+104*x^2+6*x-12)/(6*x^2+5*x-4) + * math.rationalize('x/(1-x)/(x-2)/(x-3)/(x-4) + 2x/ ( (1-2x)/(2-3x) )/ ((3-4x)/(4-5x) )') = + * // (-30*x^7+344*x^6-1506*x^5+3200*x^4-3472*x^3+1846*x^2-381*x)/ + * // (-8*x^6+90*x^5-383*x^4+780*x^3-797*x^2+390*x-72) + * + * math.rationalize('x+x+x+y',{y:1}) // 3*x+1 + * math.rationalize('x+x+x+y',{}) // 3*x+y + * + * const ret = math.rationalize('x+x+x+y',{},true) + * // ret.expression=3*x+y, ret.variables = ["x","y"] + * const ret = math.rationalize('-2+5x^2',{},true) + * // ret.expression=5*x^2-2, ret.variables = ["x"], ret.coefficients=[-2,0,5] + * + * See also: + * + * simplify + * + * @param {Node|string} expr The expression to check if is a polynomial expression + * @param {Object|boolean} optional scope of expression or true for already evaluated rational expression at input + * @param {Boolean} detailed optional True if return an object, false if return expression node (default) + * + * @return {Object | Node} The rational polynomial of `expr` or an object + * `{expression, numerator, denominator, variables, coefficients}`, where + * `expression` is a `Node` with the node simplified expression, + * `numerator` is a `Node` with the simplified numerator of expression, + * `denominator` is a `Node` or `boolean` with the simplified denominator or `false` (if there is no denominator), + * `variables` is an array with variable names, + * and `coefficients` is an array with coefficients of numerator sorted by increased exponent + * {Expression Node} node simplified expression + * + */ + function _rationalize(expr) { + var scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var detailed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + var setRules = rulesRationalize(); // Rules for change polynomial in near canonical form + var polyRet = polynomial(expr, scope, true, setRules.firstRules); // Check if expression is a rationalizable polynomial + var nVars = polyRet.variables.length; + var noExactFractions = { + exactFractions: false + }; + var withExactFractions = { + exactFractions: true + }; + expr = polyRet.expression; + if (nVars >= 1) { + // If expression in not a constant + expr = expandPower(expr); // First expand power of polynomials (cannot be made from rules!) + var sBefore; // Previous expression + var rules; + var eDistrDiv = true; + var redoInic = false; + // Apply the initial rules, including succ div rules: + expr = simplify(expr, setRules.firstRules, {}, noExactFractions); + var s; + while (true) { + // Alternate applying successive division rules and distr.div.rules + // until there are no more changes: + rules = eDistrDiv ? setRules.distrDivRules : setRules.sucDivRules; + expr = simplify(expr, rules, {}, withExactFractions); + eDistrDiv = !eDistrDiv; // Swap between Distr.Div and Succ. Div. Rules + + s = expr.toString(); + if (s === sBefore) { + break; // No changes : end of the loop + } + redoInic = true; + sBefore = s; + } + if (redoInic) { + // Apply first rules again without succ div rules (if there are changes) + expr = simplify(expr, setRules.firstRulesAgain, {}, noExactFractions); + } + // Apply final rules: + expr = simplify(expr, setRules.finalRules, {}, noExactFractions); + } // NVars >= 1 + + var coefficients = []; + var retRationalize = {}; + if (expr.type === 'OperatorNode' && expr.isBinary() && expr.op === '/') { + // Separate numerator from denominator + if (nVars === 1) { + expr.args[0] = polyToCanonical(expr.args[0], coefficients); + expr.args[1] = polyToCanonical(expr.args[1]); + } + if (detailed) { + retRationalize.numerator = expr.args[0]; + retRationalize.denominator = expr.args[1]; + } + } else { + if (nVars === 1) { + expr = polyToCanonical(expr, coefficients); + } + if (detailed) { + retRationalize.numerator = expr; + retRationalize.denominator = null; + } + } + // nVars + + if (!detailed) return expr; + retRationalize.coefficients = coefficients; + retRationalize.variables = polyRet.variables; + retRationalize.expression = expr; + return retRationalize; + } + return typed(name, { + Node: _rationalize, + 'Node, boolean': (expr, detailed) => _rationalize(expr, {}, detailed), + 'Node, Object': _rationalize, + 'Node, Object, boolean': _rationalize + }); // end of typed rationalize + + /** + * Function to simplify an expression using an optional scope and + * return it if the expression is a polynomial expression, i.e. + * an expression with one or more variables and the operators + * +, -, *, and ^, where the exponent can only be a positive integer. + * + * Syntax: + * + * polynomial(expr,scope,extended, rules) + * + * @param {Node | string} expr The expression to simplify and check if is polynomial expression + * @param {object} scope Optional scope for expression simplification + * @param {boolean} extended Optional. Default is false. When true allows divide operator. + * @param {array} rules Optional. Default is no rule. + * + * + * @return {Object} + * {Object} node: node simplified expression + * {Array} variables: variable names + */ + function polynomial(expr, scope, extended, rules) { + var variables = []; + var node = simplify(expr, rules, scope, { + exactFractions: false + }); // Resolves any variables and functions with all defined parameters + extended = !!extended; + var oper = '+-*' + (extended ? '/' : ''); + recPoly(node); + var retFunc = {}; + retFunc.expression = node; + retFunc.variables = variables; + return retFunc; + + // ------------------------------------------------------------------------------------------------------- + + /** + * Function to simplify an expression using an optional scope and + * return it if the expression is a polynomial expression, i.e. + * an expression with one or more variables and the operators + * +, -, *, and ^, where the exponent can only be a positive integer. + * + * Syntax: + * + * recPoly(node) + * + * + * @param {Node} node The current sub tree expression in recursion + * + * @return nothing, throw an exception if error + */ + function recPoly(node) { + var tp = node.type; // node type + if (tp === 'FunctionNode') { + // No function call in polynomial expression + throw new Error('There is an unsolved function call'); + } else if (tp === 'OperatorNode') { + if (node.op === '^') { + // TODO: handle negative exponents like in '1/x^(-2)' + if (node.args[1].type !== 'ConstantNode' || !isInteger(parseFloat(node.args[1].value))) { + throw new Error('There is a non-integer exponent'); + } else { + recPoly(node.args[0]); + } + } else { + if (!oper.includes(node.op)) { + throw new Error('Operator ' + node.op + ' invalid in polynomial expression'); + } + for (var i = 0; i < node.args.length; i++) { + recPoly(node.args[i]); + } + } // type of operator + } else if (tp === 'SymbolNode') { + var _name = node.name; // variable name + var pos = variables.indexOf(_name); + if (pos === -1) { + // new variable in expression + variables.push(_name); + } + } else if (tp === 'ParenthesisNode') { + recPoly(node.content); + } else if (tp !== 'ConstantNode') { + throw new Error('type ' + tp + ' is not allowed in polynomial expression'); + } + } // end of recPoly + } // end of polynomial + + // --------------------------------------------------------------------------------------- + /** + * Return a rule set to rationalize an polynomial expression in rationalize + * + * Syntax: + * + * rulesRationalize() + * + * @return {array} rule set to rationalize an polynomial expression + */ + function rulesRationalize() { + var oldRules = [simplifyCore, + // sCore + { + l: 'n+n', + r: '2*n' + }, { + l: 'n+-n', + r: '0' + }, simplifyConstant, + // sConstant + { + l: 'n*(n1^-1)', + r: 'n/n1' + }, { + l: 'n*n1^-n2', + r: 'n/n1^n2' + }, { + l: 'n1^-1', + r: '1/n1' + }, { + l: 'n*(n1/n2)', + r: '(n*n1)/n2' + }, { + l: '1*n', + r: 'n' + }]; + var rulesFirst = [{ + l: '(-n1)/(-n2)', + r: 'n1/n2' + }, + // Unary division + { + l: '(-n1)*(-n2)', + r: 'n1*n2' + }, + // Unary multiplication + { + l: 'n1--n2', + r: 'n1+n2' + }, + // '--' elimination + { + l: 'n1-n2', + r: 'n1+(-n2)' + }, + // Subtraction turn into add with un�ry minus + { + l: '(n1+n2)*n3', + r: '(n1*n3 + n2*n3)' + }, + // Distributive 1 + { + l: 'n1*(n2+n3)', + r: '(n1*n2+n1*n3)' + }, + // Distributive 2 + { + l: 'c1*n + c2*n', + r: '(c1+c2)*n' + }, + // Joining constants + { + l: 'c1*n + n', + r: '(c1+1)*n' + }, + // Joining constants + { + l: 'c1*n - c2*n', + r: '(c1-c2)*n' + }, + // Joining constants + { + l: 'c1*n - n', + r: '(c1-1)*n' + }, + // Joining constants + { + l: 'v/c', + r: '(1/c)*v' + }, + // variable/constant (new!) + { + l: 'v/-c', + r: '-(1/c)*v' + }, + // variable/constant (new!) + { + l: '-v*-c', + r: 'c*v' + }, + // Inversion constant and variable 1 + { + l: '-v*c', + r: '-c*v' + }, + // Inversion constant and variable 2 + { + l: 'v*-c', + r: '-c*v' + }, + // Inversion constant and variable 3 + { + l: 'v*c', + r: 'c*v' + }, + // Inversion constant and variable 4 + { + l: '-(-n1*n2)', + r: '(n1*n2)' + }, + // Unary propagation + { + l: '-(n1*n2)', + r: '(-n1*n2)' + }, + // Unary propagation + { + l: '-(-n1+n2)', + r: '(n1-n2)' + }, + // Unary propagation + { + l: '-(n1+n2)', + r: '(-n1-n2)' + }, + // Unary propagation + { + l: '(n1^n2)^n3', + r: '(n1^(n2*n3))' + }, + // Power to Power + { + l: '-(-n1/n2)', + r: '(n1/n2)' + }, + // Division and Unary + { + l: '-(n1/n2)', + r: '(-n1/n2)' + }]; // Divisao and Unary + + var rulesDistrDiv = [{ + l: '(n1/n2 + n3/n4)', + r: '((n1*n4 + n3*n2)/(n2*n4))' + }, + // Sum of fractions + { + l: '(n1/n2 + n3)', + r: '((n1 + n3*n2)/n2)' + }, + // Sum fraction with number 1 + { + l: '(n1 + n2/n3)', + r: '((n1*n3 + n2)/n3)' + }]; // Sum fraction with number 1 + + var rulesSucDiv = [{ + l: '(n1/(n2/n3))', + r: '((n1*n3)/n2)' + }, + // Division simplification + { + l: '(n1/n2/n3)', + r: '(n1/(n2*n3))' + }]; + var setRules = {}; // rules set in 4 steps. + + // All rules => infinite loop + // setRules.allRules =oldRules.concat(rulesFirst,rulesDistrDiv,rulesSucDiv) + + setRules.firstRules = oldRules.concat(rulesFirst, rulesSucDiv); // First rule set + setRules.distrDivRules = rulesDistrDiv; // Just distr. div. rules + setRules.sucDivRules = rulesSucDiv; // Jus succ. div. rules + setRules.firstRulesAgain = oldRules.concat(rulesFirst); // Last rules set without succ. div. + + // Division simplification + + // Second rule set. + // There is no aggregate expression with parentesis, but the only variable can be scattered. + setRules.finalRules = [simplifyCore, + // simplify.rules[0] + { + l: 'n*-n', + r: '-n^2' + }, + // Joining multiply with power 1 + { + l: 'n*n', + r: 'n^2' + }, + // Joining multiply with power 2 + simplifyConstant, + // simplify.rules[14] old 3rd index in oldRules + { + l: 'n*-n^n1', + r: '-n^(n1+1)' + }, + // Joining multiply with power 3 + { + l: 'n*n^n1', + r: 'n^(n1+1)' + }, + // Joining multiply with power 4 + { + l: 'n^n1*-n^n2', + r: '-n^(n1+n2)' + }, + // Joining multiply with power 5 + { + l: 'n^n1*n^n2', + r: 'n^(n1+n2)' + }, + // Joining multiply with power 6 + { + l: 'n^n1*-n', + r: '-n^(n1+1)' + }, + // Joining multiply with power 7 + { + l: 'n^n1*n', + r: 'n^(n1+1)' + }, + // Joining multiply with power 8 + { + l: 'n^n1/-n', + r: '-n^(n1-1)' + }, + // Joining multiply with power 8 + { + l: 'n^n1/n', + r: 'n^(n1-1)' + }, + // Joining division with power 1 + { + l: 'n/-n^n1', + r: '-n^(1-n1)' + }, + // Joining division with power 2 + { + l: 'n/n^n1', + r: 'n^(1-n1)' + }, + // Joining division with power 3 + { + l: 'n^n1/-n^n2', + r: 'n^(n1-n2)' + }, + // Joining division with power 4 + { + l: 'n^n1/n^n2', + r: 'n^(n1-n2)' + }, + // Joining division with power 5 + { + l: 'n1+(-n2*n3)', + r: 'n1-n2*n3' + }, + // Solving useless parenthesis 1 + { + l: 'v*(-c)', + r: '-c*v' + }, + // Solving useless unary 2 + { + l: 'n1+-n2', + r: 'n1-n2' + }, + // Solving +- together (new!) + { + l: 'v*c', + r: 'c*v' + }, + // inversion constant with variable + { + l: '(n1^n2)^n3', + r: '(n1^(n2*n3))' + } // Power to Power + ]; + return setRules; + } // End rulesRationalize + + // --------------------------------------------------------------------------------------- + /** + * Expand recursively a tree node for handling with expressions with exponents + * (it's not for constants, symbols or functions with exponents) + * PS: The other parameters are internal for recursion + * + * Syntax: + * + * expandPower(node) + * + * @param {Node} node Current expression node + * @param {node} parent Parent current node inside the recursion + * @param (int} Parent number of chid inside the rercursion + * + * @return {node} node expression with all powers expanded. + */ + function expandPower(node, parent, indParent) { + var tp = node.type; + var internal = arguments.length > 1; // TRUE in internal calls + + if (tp === 'OperatorNode' && node.isBinary()) { + var does = false; + var val; + if (node.op === '^') { + // First operator: Parenthesis or UnaryMinus + if ((node.args[0].type === 'ParenthesisNode' || node.args[0].type === 'OperatorNode') && node.args[1].type === 'ConstantNode') { + // Second operator: Constant + val = parseFloat(node.args[1].value); + does = val >= 2 && isInteger(val); + } + } + if (does) { + // Exponent >= 2 + // Before: + // operator A --> Subtree + // parent pow + // constant + // + if (val > 2) { + // Exponent > 2, + // AFTER: (exponent > 2) + // operator A --> Subtree + // parent * + // deep clone (operator A --> Subtree + // pow + // constant - 1 + // + var nEsqTopo = node.args[0]; + var nDirTopo = new OperatorNode('^', 'pow', [node.args[0].cloneDeep(), new ConstantNode(val - 1)]); + node = new OperatorNode('*', 'multiply', [nEsqTopo, nDirTopo]); + } else { + // Expo = 2 - no power + // AFTER: (exponent = 2) + // operator A --> Subtree + // parent oper + // deep clone (operator A --> Subtree) + // + node = new OperatorNode('*', 'multiply', [node.args[0], node.args[0].cloneDeep()]); + } + if (internal) { + // Change parent references in internal recursive calls + if (indParent === 'content') { + parent.content = node; + } else { + parent.args[indParent] = node; + } + } + } // does + } // binary OperatorNode + + if (tp === 'ParenthesisNode') { + // Recursion + expandPower(node.content, node, 'content'); + } else if (tp !== 'ConstantNode' && tp !== 'SymbolNode') { + for (var i = 0; i < node.args.length; i++) { + expandPower(node.args[i], node, i); + } + } + if (!internal) { + // return the root node + return node; + } + } // End expandPower + + // --------------------------------------------------------------------------------------- + /** + * Auxilary function for rationalize + * Convert near canonical polynomial in one variable in a canonical polynomial + * with one term for each exponent in decreasing order + * + * Syntax: + * + * polyToCanonical(node [, coefficients]) + * + * @param {Node | string} expr The near canonical polynomial expression to convert in a a canonical polynomial expression + * + * The string or tree expression needs to be at below syntax, with free spaces: + * ( (^(-)? | [+-]? )cte (*)? var (^expo)? | cte )+ + * Where 'var' is one variable with any valid name + * 'cte' are real numeric constants with any value. It can be omitted if equal than 1 + * 'expo' are integers greater than 0. It can be omitted if equal than 1. + * + * @param {array} coefficients Optional returns coefficients sorted by increased exponent + * + * + * @return {node} new node tree with one variable polynomial or string error. + */ + function polyToCanonical(node, coefficients) { + if (coefficients === undefined) { + coefficients = []; + } // coefficients. + + coefficients[0] = 0; // index is the exponent + var o = {}; + o.cte = 1; + o.oper = '+'; + + // fire: mark with * or ^ when finds * or ^ down tree, reset to "" with + and -. + // It is used to deduce the exponent: 1 for *, 0 for "". + o.fire = ''; + var maxExpo = 0; // maximum exponent + var varname = ''; // variable name + + recurPol(node, null, o); + maxExpo = coefficients.length - 1; + var first = true; + var no; + for (var i = maxExpo; i >= 0; i--) { + if (coefficients[i] === 0) continue; + var n1 = new ConstantNode(first ? coefficients[i] : Math.abs(coefficients[i])); + var op = coefficients[i] < 0 ? '-' : '+'; + if (i > 0) { + // Is not a constant without variable + var n2 = new SymbolNode(varname); + if (i > 1) { + var n3 = new ConstantNode(i); + n2 = new OperatorNode('^', 'pow', [n2, n3]); + } + if (coefficients[i] === -1 && first) { + n1 = new OperatorNode('-', 'unaryMinus', [n2]); + } else if (Math.abs(coefficients[i]) === 1) { + n1 = n2; + } else { + n1 = new OperatorNode('*', 'multiply', [n1, n2]); + } + } + if (first) { + no = n1; + } else if (op === '+') { + no = new OperatorNode('+', 'add', [no, n1]); + } else { + no = new OperatorNode('-', 'subtract', [no, n1]); + } + first = false; + } // for + + if (first) { + return new ConstantNode(0); + } else { + return no; + } + + /** + * Recursive auxilary function inside polyToCanonical for + * converting expression in canonical form + * + * Syntax: + * + * recurPol(node, noPai, obj) + * + * @param {Node} node The current subpolynomial expression + * @param {Node | Null} noPai The current parent node + * @param {object} obj Object with many internal flags + * + * @return {} No return. If error, throws an exception + */ + function recurPol(node, noPai, o) { + var tp = node.type; + if (tp === 'FunctionNode') { + // ***** FunctionName ***** + // No function call in polynomial expression + throw new Error('There is an unsolved function call'); + } else if (tp === 'OperatorNode') { + // ***** OperatorName ***** + if (!'+-*^'.includes(node.op)) throw new Error('Operator ' + node.op + ' invalid'); + if (noPai !== null) { + // -(unary),^ : children of *,+,- + if ((node.fn === 'unaryMinus' || node.fn === 'pow') && noPai.fn !== 'add' && noPai.fn !== 'subtract' && noPai.fn !== 'multiply') { + throw new Error('Invalid ' + node.op + ' placing'); + } + + // -,+,* : children of +,- + if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'multiply') && noPai.fn !== 'add' && noPai.fn !== 'subtract') { + throw new Error('Invalid ' + node.op + ' placing'); + } + + // -,+ : first child + if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'unaryMinus') && o.noFil !== 0) { + throw new Error('Invalid ' + node.op + ' placing'); + } + } // Has parent + + // Firers: ^,* Old: ^,&,-(unary): firers + if (node.op === '^' || node.op === '*') { + o.fire = node.op; + } + for (var _i = 0; _i < node.args.length; _i++) { + // +,-: reset fire + if (node.fn === 'unaryMinus') o.oper = '-'; + if (node.op === '+' || node.fn === 'subtract') { + o.fire = ''; + o.cte = 1; // default if there is no constant + o.oper = _i === 0 ? '+' : node.op; + } + o.noFil = _i; // number of son + recurPol(node.args[_i], node, o); + } // for in children + } else if (tp === 'SymbolNode') { + // ***** SymbolName ***** + if (node.name !== varname && varname !== '') { + throw new Error('There is more than one variable'); + } + varname = node.name; + if (noPai === null) { + coefficients[1] = 1; + return; + } + + // ^: Symbol is First child + if (noPai.op === '^' && o.noFil !== 0) { + throw new Error('In power the variable should be the first parameter'); + } + + // *: Symbol is Second child + if (noPai.op === '*' && o.noFil !== 1) { + throw new Error('In multiply the variable should be the second parameter'); + } + + // Symbol: firers '',* => it means there is no exponent above, so it's 1 (cte * var) + if (o.fire === '' || o.fire === '*') { + if (maxExpo < 1) coefficients[1] = 0; + coefficients[1] += o.cte * (o.oper === '+' ? 1 : -1); + maxExpo = Math.max(1, maxExpo); + } + } else if (tp === 'ConstantNode') { + var valor = parseFloat(node.value); + if (noPai === null) { + coefficients[0] = valor; + return; + } + if (noPai.op === '^') { + // cte: second child of power + if (o.noFil !== 1) throw new Error('Constant cannot be powered'); + if (!isInteger(valor) || valor <= 0) { + throw new Error('Non-integer exponent is not allowed'); + } + for (var _i2 = maxExpo + 1; _i2 < valor; _i2++) coefficients[_i2] = 0; + if (valor > maxExpo) coefficients[valor] = 0; + coefficients[valor] += o.cte * (o.oper === '+' ? 1 : -1); + maxExpo = Math.max(valor, maxExpo); + return; + } + o.cte = valor; + + // Cte: firer '' => There is no exponent and no multiplication, so the exponent is 0. + if (o.fire === '') { + coefficients[0] += o.cte * (o.oper === '+' ? 1 : -1); + } + } else { + throw new Error('Type ' + tp + ' is not allowed'); + } + } // End of recurPol + } // End of polyToCanonical +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/resolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/resolve.js new file mode 100644 index 0000000..925cdb5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/resolve.js @@ -0,0 +1,97 @@ +import { createMap } from '../../utils/map.js'; +import { isFunctionNode, isNode, isOperatorNode, isParenthesisNode, isSymbolNode } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'resolve'; +var dependencies = ['typed', 'parse', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode']; +export var createResolve = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + parse, + ConstantNode, + FunctionNode, + OperatorNode, + ParenthesisNode + } = _ref; + /** + * resolve(expr, scope) replaces variable nodes with their scoped values + * + * Syntax: + * + * math.resolve(expr, scope) + * + * Examples: + * + * math.resolve('x + y', {x:1, y:2}) // Node '1 + 2' + * math.resolve(math.parse('x+y'), {x:1, y:2}) // Node '1 + 2' + * math.simplify('x+y', {x:2, y: math.parse('x+x')}).toString() // "6" + * + * See also: + * + * simplify, evaluate + * + * @param {Node | Node[]} node + * The expression tree (or trees) to be simplified + * @param {Object} scope + * Scope specifying variables to be resolved + * @return {Node | Node[]} Returns `node` with variables recursively substituted. + * @throws {ReferenceError} + * If there is a cyclic dependency among the variables in `scope`, + * resolution is impossible and a ReferenceError is thrown. + */ + function _resolve(node, scope) { + var within = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : new Set(); + // note `within`: + // `within` is not documented, since it is for internal cycle + // detection only + if (!scope) { + return node; + } + if (isSymbolNode(node)) { + if (within.has(node.name)) { + var variables = Array.from(within).join(', '); + throw new ReferenceError("recursive loop of variable definitions among {".concat(variables, "}")); + } + var value = scope.get(node.name); + if (isNode(value)) { + var nextWithin = new Set(within); + nextWithin.add(node.name); + return _resolve(value, scope, nextWithin); + } else if (typeof value === 'number') { + return parse(String(value)); + } else if (value !== undefined) { + return new ConstantNode(value); + } else { + return node; + } + } else if (isOperatorNode(node)) { + var args = node.args.map(function (arg) { + return _resolve(arg, scope, within); + }); + return new OperatorNode(node.op, node.fn, args, node.implicit); + } else if (isParenthesisNode(node)) { + return new ParenthesisNode(_resolve(node.content, scope, within)); + } else if (isFunctionNode(node)) { + var _args = node.args.map(function (arg) { + return _resolve(arg, scope, within); + }); + return new FunctionNode(node.name, _args); + } + + // Otherwise just recursively resolve any children (might also work + // for some of the above special cases) + return node.map(child => _resolve(child, scope, within)); + } + return typed('resolve', { + Node: _resolve, + 'Node, Map | null | undefined': _resolve, + 'Node, Object': (n, scope) => _resolve(n, createMap(scope)), + // For arrays and matrices, we map `self` rather than `_resolve` + // because resolve is fairly expensive anyway, and this way + // we get nice error messages if one entry in the array has wrong type. + 'Array | Matrix': typed.referToSelf(self => A => A.map(n => self(n))), + 'Array | Matrix, null | undefined': typed.referToSelf(self => A => A.map(n => self(n))), + 'Array, Object': typed.referTo('Array,Map', selfAM => (A, scope) => selfAM(A, createMap(scope))), + 'Matrix, Object': typed.referTo('Matrix,Map', selfMM => (A, scope) => selfMM(A, createMap(scope))), + 'Array | Matrix, Map': typed.referToSelf(self => (A, scope) => A.map(n => self(n, scope))) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify.js new file mode 100644 index 0000000..3adef7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify.js @@ -0,0 +1,1256 @@ +import { isParenthesisNode } from '../../utils/is.js'; +import { isConstantNode, isVariableNode, isNumericNode, isConstantExpression } from './simplify/wildcards.js'; +import { factory } from '../../utils/factory.js'; +import { createUtil } from './simplify/util.js'; +import { hasOwnProperty } from '../../utils/object.js'; +import { createEmptyMap, createMap } from '../../utils/map.js'; +var name = 'simplify'; +var dependencies = ['config', 'typed', 'parse', 'add', 'subtract', 'multiply', 'divide', 'pow', 'isZero', 'equal', 'resolve', 'simplifyConstant', 'simplifyCore', '?fraction', '?bignumber', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +export var createSimplify = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + typed, + parse, + add, + subtract, + multiply, + divide, + pow, + isZero, + equal, + resolve, + simplifyConstant, + simplifyCore, + fraction, + bignumber, + mathWithTransform, + matrix, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + var { + hasProperty, + isCommutative, + isAssociative, + mergeContext, + flatten, + unflattenr, + unflattenl, + createMakeNodeFunction, + defaultContext, + realContext, + positiveContext + } = createUtil({ + FunctionNode, + OperatorNode, + SymbolNode + }); + + /** + * Simplify an expression tree. + * + * A list of rules are applied to an expression, repeating over the list until + * no further changes are made. + * It's possible to pass a custom set of rules to the function as second + * argument. A rule can be specified as an object, string, or function: + * + * const rules = [ + * { l: 'n1*n3 + n2*n3', r: '(n1+n2)*n3' }, + * 'n1*n3 + n2*n3 -> (n1+n2)*n3', + * function (node) { + * // ... return a new node or return the node unchanged + * return node + * } + * ] + * + * String and object rules consist of a left and right pattern. The left is + * used to match against the expression and the right determines what matches + * are replaced with. The main difference between a pattern and a normal + * expression is that variables starting with the following characters are + * interpreted as wildcards: + * + * - 'n' - Matches any node [Node] + * - 'c' - Matches a constant literal (5 or 3.2) [ConstantNode] + * - 'cl' - Matches a constant literal; same as c [ConstantNode] + * - 'cd' - Matches a decimal literal (5 or -3.2) [ConstantNode or unaryMinus wrapping a ConstantNode] + * - 'ce' - Matches a constant expression (-5 or √3) [Expressions consisting of only ConstantNodes, functions, and operators] + * - 'v' - Matches a variable; anything not matched by c (-5 or x) [Node that is not a ConstantNode] + * - 'vl' - Matches a variable literal (x or y) [SymbolNode] + * - 'vd' - Matches a non-decimal expression; anything not matched by cd (x or √3) [Node that is not a ConstantNode or unaryMinus that is wrapping a ConstantNode] + * - 've' - Matches a variable expression; anything not matched by ce (x or 2x) [Expressions that contain a SymbolNode or other non-constant term] + * + * The default list of rules is exposed on the function as `simplify.rules` + * and can be used as a basis to built a set of custom rules. Note that since + * the `simplifyCore` function is in the default list of rules, by default + * simplify will convert any function calls in the expression that have + * operator equivalents to their operator forms. + * + * To specify a rule as a string, separate the left and right pattern by '->' + * When specifying a rule as an object, the following keys are meaningful: + * - l - the left pattern + * - r - the right pattern + * - s - in lieu of l and r, the string form that is broken at -> to give them + * - repeat - whether to repeat this rule until the expression stabilizes + * - assuming - gives a context object, as in the 'context' option to + * simplify. Every property in the context object must match the current + * context in order, or else the rule will not be applied. + * - imposeContext - gives a context object, as in the 'context' option to + * simplify. Any settings specified will override the incoming context + * for all matches of this rule. + * + * For more details on the theory, see: + * + * - [Strategies for simplifying math expressions (Stackoverflow)](https://stackoverflow.com/questions/7540227/strategies-for-simplifying-math-expressions) + * - [Symbolic computation - Simplification (Wikipedia)](https://en.wikipedia.org/wiki/Symbolic_computation#Simplification) + * + * An optional `options` argument can be passed as last argument of `simplify`. + * Currently available options (defaults in parentheses): + * - `consoleDebug` (false): whether to write the expression being simplified + * and any changes to it, along with the rule responsible, to console + * - `context` (simplify.defaultContext): an object giving properties of + * each operator, which determine what simplifications are allowed. The + * currently meaningful properties are commutative, associative, + * total (whether the operation is defined for all arguments), and + * trivial (whether the operation applied to a single argument leaves + * that argument unchanged). The default context is very permissive and + * allows almost all simplifications. Only properties differing from + * the default need to be specified; the default context is used as a + * fallback. Additional contexts `simplify.realContext` and + * `simplify.positiveContext` are supplied to cause simplify to perform + * just simplifications guaranteed to preserve all values of the expression + * assuming all variables and subexpressions are real numbers or + * positive real numbers, respectively. (Note that these are in some cases + * more restrictive than the default context; for example, the default + * context will allow `x/x` to simplify to 1, whereas + * `simplify.realContext` will not, as `0/0` is not equal to 1.) + * - `exactFractions` (true): whether to try to convert all constants to + * exact rational numbers. + * - `fractionsLimit` (10000): when `exactFractions` is true, constants will + * be expressed as fractions only when both numerator and denominator + * are smaller than `fractionsLimit`. + * + * Syntax: + * + * math.simplify(expr) + * math.simplify(expr, rules) + * math.simplify(expr, rules) + * math.simplify(expr, rules, scope) + * math.simplify(expr, rules, scope, options) + * math.simplify(expr, scope) + * math.simplify(expr, scope, options) + * + * Examples: + * + * math.simplify('2 * 1 * x ^ (2 - 1)') // Node "2 * x" + * math.simplify('2 * 3 * x', {x: 4}) // Node "24" + * const f = math.parse('2 * 1 * x ^ (2 - 1)') + * math.simplify(f) // Node "2 * x" + * math.simplify('0.4 * x', {}, {exactFractions: true}) // Node "x * 2 / 5" + * math.simplify('0.4 * x', {}, {exactFractions: false}) // Node "0.4 * x" + * + * See also: + * + * simplifyCore, derivative, evaluate, parse, rationalize, resolve + * + * @param {Node | string} expr + * The expression to be simplified + * @param {SimplifyRule[]} [rules] + * Optional list with custom rules + * @param {Object} [scope] Optional scope with variables + * @param {SimplifyOptions} [options] Optional configuration settings + * @return {Node} Returns the simplified form of `expr` + */ + typed.addConversion({ + from: 'Object', + to: 'Map', + convert: createMap + }); + var simplify = typed('simplify', { + Node: _simplify, + 'Node, Map': (expr, scope) => _simplify(expr, false, scope), + 'Node, Map, Object': (expr, scope, options) => _simplify(expr, false, scope, options), + 'Node, Array': _simplify, + 'Node, Array, Map': _simplify, + 'Node, Array, Map, Object': _simplify + }); + typed.removeConversion({ + from: 'Object', + to: 'Map', + convert: createMap + }); + simplify.defaultContext = defaultContext; + simplify.realContext = realContext; + simplify.positiveContext = positiveContext; + function removeParens(node) { + return node.transform(function (node, path, parent) { + return isParenthesisNode(node) ? removeParens(node.content) : node; + }); + } + + // All constants that are allowed in rules + var SUPPORTED_CONSTANTS = { + true: true, + false: true, + e: true, + i: true, + Infinity: true, + LN2: true, + LN10: true, + LOG2E: true, + LOG10E: true, + NaN: true, + phi: true, + pi: true, + SQRT1_2: true, + SQRT2: true, + tau: true + // null: false, + // undefined: false, + // version: false, + }; + + // Array of strings, used to build the ruleSet. + // Each l (left side) and r (right side) are parsed by + // the expression parser into a node tree. + // Left hand sides are matched to subtrees within the + // expression to be parsed and replaced with the right + // hand side. + // TODO: Add support for constraints on constants (either in the form of a '=' expression or a callback [callback allows things like comparing symbols alphabetically]) + // To evaluate lhs constants for rhs constants, use: { l: 'c1+c2', r: 'c3', evaluate: 'c3 = c1 + c2' }. Multiple assignments are separated by ';' in block format. + // It is possible to get into an infinite loop with conflicting rules + simplify.rules = [simplifyCore, + // { l: 'n+0', r: 'n' }, // simplifyCore + // { l: 'n^0', r: '1' }, // simplifyCore + // { l: '0*n', r: '0' }, // simplifyCore + // { l: 'n/n', r: '1'}, // simplifyCore + // { l: 'n^1', r: 'n' }, // simplifyCore + // { l: '+n1', r:'n1' }, // simplifyCore + // { l: 'n--n1', r:'n+n1' }, // simplifyCore + { + l: 'log(e)', + r: '1' + }, + // temporary rules + // Note initially we tend constants to the right because like-term + // collection prefers the left, and we would rather collect nonconstants + { + s: 'n-n1 -> n+-n1', + // temporarily replace 'subtract' so we can further flatten the 'add' operator + assuming: { + subtract: { + total: true + } + } + }, { + s: 'n-n -> 0', + // partial alternative when we can't always subtract + assuming: { + subtract: { + total: false + } + } + }, { + s: '-(cl*v) -> v * (-cl)', + // make non-constant terms positive + assuming: { + multiply: { + commutative: true + }, + subtract: { + total: true + } + } + }, { + s: '-(cl*v) -> (-cl) * v', + // non-commutative version, part 1 + assuming: { + multiply: { + commutative: false + }, + subtract: { + total: true + } + } + }, { + s: '-(v*cl) -> v * (-cl)', + // non-commutative version, part 2 + assuming: { + multiply: { + commutative: false + }, + subtract: { + total: true + } + } + }, { + l: '-(n1/n2)', + r: '-n1/n2' + }, { + l: '-v', + r: 'v * (-1)' + }, + // finish making non-constant terms positive + { + l: '(n1 + n2)*(-1)', + r: 'n1*(-1) + n2*(-1)', + repeat: true + }, + // expand negations to achieve as much sign cancellation as possible + { + l: 'n/n1^n2', + r: 'n*n1^-n2' + }, + // temporarily replace 'divide' so we can further flatten the 'multiply' operator + { + l: 'n/n1', + r: 'n*n1^-1' + }, { + s: '(n1*n2)^n3 -> n1^n3 * n2^n3', + assuming: { + multiply: { + commutative: true + } + } + }, { + s: '(n1*n2)^(-1) -> n2^(-1) * n1^(-1)', + assuming: { + multiply: { + commutative: false + } + } + }, + // expand nested exponentiation + { + s: '(n ^ n1) ^ n2 -> n ^ (n1 * n2)', + assuming: { + divide: { + total: true + } + } // 1/(1/n) = n needs 1/n to exist + }, + // collect like factors; into a sum, only do this for nonconstants + { + l: ' vd * ( vd * n1 + n2)', + r: 'vd^2 * n1 + vd * n2' + }, { + s: ' vd * (vd^n4 * n1 + n2) -> vd^(1+n4) * n1 + vd * n2', + assuming: { + divide: { + total: true + } + } // v*1/v = v^(1+-1) needs 1/v + }, { + s: 'vd^n3 * ( vd * n1 + n2) -> vd^(n3+1) * n1 + vd^n3 * n2', + assuming: { + divide: { + total: true + } + } + }, { + s: 'vd^n3 * (vd^n4 * n1 + n2) -> vd^(n3+n4) * n1 + vd^n3 * n2', + assuming: { + divide: { + total: true + } + } + }, { + l: 'n*n', + r: 'n^2' + }, { + s: 'n * n^n1 -> n^(n1+1)', + assuming: { + divide: { + total: true + } + } // n*1/n = n^(-1+1) needs 1/n + }, { + s: 'n^n1 * n^n2 -> n^(n1+n2)', + assuming: { + divide: { + total: true + } + } // ditto for n^2*1/n^2 + }, + // Unfortunately, to deal with more complicated cancellations, it + // becomes necessary to simplify constants twice per pass. It's not + // terribly expensive compared to matching rules, so this should not + // pose a performance problem. + simplifyConstant, + // First: before collecting like terms + + // collect like terms + { + s: 'n+n -> 2*n', + assuming: { + add: { + total: true + } + } // 2 = 1 + 1 needs to exist + }, { + l: 'n+-n', + r: '0' + }, { + l: 'vd*n + vd', + r: 'vd*(n+1)' + }, + // NOTE: leftmost position is special: + { + l: 'n3*n1 + n3*n2', + r: 'n3*(n1+n2)' + }, + // All sub-monomials tried there. + { + l: 'n3^(-n4)*n1 + n3 * n2', + r: 'n3^(-n4)*(n1 + n3^(n4+1) *n2)' + }, { + l: 'n3^(-n4)*n1 + n3^n5 * n2', + r: 'n3^(-n4)*(n1 + n3^(n4+n5)*n2)' + }, + // noncommutative additional cases (term collection & factoring) + { + s: 'n*vd + vd -> (n+1)*vd', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'vd + n*vd -> (1+n)*vd', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3 + n2*n3 -> (n1+n2)*n3', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n^n1 * n -> n^(n1+1)', + assuming: { + divide: { + total: true + }, + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3^(-n4) + n2 * n3 -> (n1 + n2*n3^(n4 + 1))*n3^(-n4)', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)', + assuming: { + multiply: { + commutative: false + } + } + }, { + l: 'n*cd + cd', + r: '(n+1)*cd' + }, { + s: 'cd*n + cd -> cd*(n+1)', + assuming: { + multiply: { + commutative: false + } + } + }, { + s: 'cd + cd*n -> cd*(1+n)', + assuming: { + multiply: { + commutative: false + } + } + }, simplifyConstant, + // Second: before returning expressions to "standard form" + + // make factors positive (and undo 'make non-constant terms positive') + { + s: '(-n)*n1 -> -(n*n1)', + assuming: { + subtract: { + total: true + } + } + }, { + s: 'n1*(-n) -> -(n1*n)', + // in case * non-commutative + assuming: { + subtract: { + total: true + }, + multiply: { + commutative: false + } + } + }, + // final ordering of constants + { + s: 'ce+ve -> ve+ce', + assuming: { + add: { + commutative: true + } + }, + imposeContext: { + add: { + commutative: false + } + } + }, { + s: 'vd*cd -> cd*vd', + assuming: { + multiply: { + commutative: true + } + }, + imposeContext: { + multiply: { + commutative: false + } + } + }, + // undo temporary rules + // { l: '(-1) * n', r: '-n' }, // #811 added test which proved this is redundant + { + l: 'n+-n1', + r: 'n-n1' + }, + // undo replace 'subtract' + { + l: 'n+-(n1)', + r: 'n-(n1)' + }, { + s: 'n*(n1^-1) -> n/n1', + // undo replace 'divide'; for * commutative + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + s: 'n*n1^-n2 -> n/n1^n2', + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + s: 'n^-1 -> 1/n', + assuming: { + multiply: { + commutative: true + } + } // o.w. / not conventional + }, { + l: 'n^1', + r: 'n' + }, + // can be produced by power cancellation + { + s: 'n*(n1/n2) -> (n*n1)/n2', + // '*' before '/' + assuming: { + multiply: { + associative: true + } + } + }, { + s: 'n-(n1+n2) -> n-n1-n2', + // '-' before '+' + assuming: { + addition: { + associative: true, + commutative: true + } + } + }, + // { l: '(n1/n2)/n3', r: 'n1/(n2*n3)' }, + // { l: '(n*n1)/(n*n2)', r: 'n1/n2' }, + + // simplifyConstant can leave an extra factor of 1, which can always + // be eliminated, since the identity always commutes + { + l: '1*n', + r: 'n', + imposeContext: { + multiply: { + commutative: true + } + } + }, { + s: 'n1/(n2/n3) -> (n1*n3)/n2', + assuming: { + multiply: { + associative: true + } + } + }, { + l: 'n1/(-n2)', + r: '-n1/n2' + }]; + + /** + * Takes any rule object as allowed by the specification in simplify + * and puts it in a standard form used by applyRule + */ + function _canonicalizeRule(ruleObject, context) { + var newRule = {}; + if (ruleObject.s) { + var lr = ruleObject.s.split('->'); + if (lr.length === 2) { + newRule.l = lr[0]; + newRule.r = lr[1]; + } else { + throw SyntaxError('Could not parse rule: ' + ruleObject.s); + } + } else { + newRule.l = ruleObject.l; + newRule.r = ruleObject.r; + } + newRule.l = removeParens(parse(newRule.l)); + newRule.r = removeParens(parse(newRule.r)); + for (var prop of ['imposeContext', 'repeat', 'assuming']) { + if (prop in ruleObject) { + newRule[prop] = ruleObject[prop]; + } + } + if (ruleObject.evaluate) { + newRule.evaluate = parse(ruleObject.evaluate); + } + if (isAssociative(newRule.l, context)) { + var nonCommutative = !isCommutative(newRule.l, context); + var leftExpandsym; + // Gen. the LHS placeholder used in this NC-context specific expansion rules + if (nonCommutative) leftExpandsym = _getExpandPlaceholderSymbol(); + var makeNode = createMakeNodeFunction(newRule.l); + var expandsym = _getExpandPlaceholderSymbol(); + newRule.expanded = {}; + newRule.expanded.l = makeNode([newRule.l, expandsym]); + // Push the expandsym into the deepest possible branch. + // This helps to match the newRule against nodes returned from getSplits() later on. + flatten(newRule.expanded.l, context); + unflattenr(newRule.expanded.l, context); + newRule.expanded.r = makeNode([newRule.r, expandsym]); + + // In and for a non-commutative context, attempting with yet additional expansion rules makes + // way for more matches cases of multi-arg expressions; such that associative rules (such as + // 'n*n -> n^2') can be applied to exprs. such as 'a * b * b' and 'a * b * b * a'. + if (nonCommutative) { + // 'Non-commutative' 1: LHS (placeholder) only + newRule.expandedNC1 = {}; + newRule.expandedNC1.l = makeNode([leftExpandsym, newRule.l]); + newRule.expandedNC1.r = makeNode([leftExpandsym, newRule.r]); + // 'Non-commutative' 2: farmost LHS and RHS placeholders + newRule.expandedNC2 = {}; + newRule.expandedNC2.l = makeNode([leftExpandsym, newRule.expanded.l]); + newRule.expandedNC2.r = makeNode([leftExpandsym, newRule.expanded.r]); + } + } + return newRule; + } + + /** + * Parse the string array of rules into nodes + * + * Example syntax for rules: + * + * Position constants to the left in a product: + * { l: 'n1 * c1', r: 'c1 * n1' } + * n1 is any Node, and c1 is a ConstantNode. + * + * Apply difference of squares formula: + * { l: '(n1 - n2) * (n1 + n2)', r: 'n1^2 - n2^2' } + * n1, n2 mean any Node. + * + * Short hand notation: + * 'n1 * c1 -> c1 * n1' + */ + function _buildRules(rules, context) { + // Array of rules to be used to simplify expressions + var ruleSet = []; + for (var i = 0; i < rules.length; i++) { + var rule = rules[i]; + var newRule = void 0; + var ruleType = typeof rule; + switch (ruleType) { + case 'string': + rule = { + s: rule + }; + /* falls through */ + case 'object': + newRule = _canonicalizeRule(rule, context); + break; + case 'function': + newRule = rule; + break; + default: + throw TypeError('Unsupported type of rule: ' + ruleType); + } + // console.log('Adding rule: ' + rules[i]) + // console.log(newRule) + ruleSet.push(newRule); + } + return ruleSet; + } + var _lastsym = 0; + function _getExpandPlaceholderSymbol() { + return new SymbolNode('_p' + _lastsym++); + } + function _simplify(expr, rules) { + var scope = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : createEmptyMap(); + var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; + var debug = options.consoleDebug; + rules = _buildRules(rules || simplify.rules, options.context); + var res = resolve(expr, scope); + res = removeParens(res); + var visited = {}; + var str = res.toString({ + parenthesis: 'all' + }); + while (!visited[str]) { + visited[str] = true; + _lastsym = 0; // counter for placeholder symbols + var laststr = str; + if (debug) console.log('Working on: ', str); + for (var i = 0; i < rules.length; i++) { + var rulestr = ''; + if (typeof rules[i] === 'function') { + res = rules[i](res, options); + if (debug) rulestr = rules[i].name; + } else { + flatten(res, options.context); + res = applyRule(res, rules[i], options.context); + if (debug) { + rulestr = "".concat(rules[i].l.toString(), " -> ").concat(rules[i].r.toString()); + } + } + if (debug) { + var newstr = res.toString({ + parenthesis: 'all' + }); + if (newstr !== laststr) { + console.log('Applying', rulestr, 'produced', newstr); + laststr = newstr; + } + } + /* Use left-heavy binary tree internally, + * since custom rule functions may expect it + */ + unflattenl(res, options.context); + } + str = res.toString({ + parenthesis: 'all' + }); + } + return res; + } + function mapRule(nodes, rule, context) { + var resNodes = nodes; + if (nodes) { + for (var i = 0; i < nodes.length; ++i) { + var newNode = applyRule(nodes[i], rule, context); + if (newNode !== nodes[i]) { + if (resNodes === nodes) { + resNodes = nodes.slice(); + } + resNodes[i] = newNode; + } + } + } + return resNodes; + } + + /** + * Returns a simplfied form of node, or the original node if no simplification was possible. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object | Function} rule + * @param {Object} context -- information about assumed properties of operators + * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The simplified form of `expr`, or the original node if no simplification was possible. + */ + function applyRule(node, rule, context) { + // console.log('Entering applyRule("', rule.l.toString({parenthesis:'all'}), '->', rule.r.toString({parenthesis:'all'}), '",', node.toString({parenthesis:'all'}),')') + + // check that the assumptions for this rule are satisfied by the current + // context: + if (rule.assuming) { + for (var symbol in rule.assuming) { + for (var property in rule.assuming[symbol]) { + if (hasProperty(symbol, property, context) !== rule.assuming[symbol][property]) { + return node; + } + } + } + } + var mergedContext = mergeContext(rule.imposeContext, context); + + // Do not clone node unless we find a match + var res = node; + + // First replace our child nodes with their simplified versions + // If a child could not be simplified, applying the rule to it + // will have no effect since the node is returned unchanged + if (res instanceof OperatorNode || res instanceof FunctionNode) { + var newArgs = mapRule(res.args, rule, context); + if (newArgs !== res.args) { + res = res.clone(); + res.args = newArgs; + } + } else if (res instanceof ParenthesisNode) { + if (res.content) { + var newContent = applyRule(res.content, rule, context); + if (newContent !== res.content) { + res = new ParenthesisNode(newContent); + } + } + } else if (res instanceof ArrayNode) { + var newItems = mapRule(res.items, rule, context); + if (newItems !== res.items) { + res = new ArrayNode(newItems); + } + } else if (res instanceof AccessorNode) { + var newObj = res.object; + if (res.object) { + newObj = applyRule(res.object, rule, context); + } + var newIndex = res.index; + if (res.index) { + newIndex = applyRule(res.index, rule, context); + } + if (newObj !== res.object || newIndex !== res.index) { + res = new AccessorNode(newObj, newIndex); + } + } else if (res instanceof IndexNode) { + var newDims = mapRule(res.dimensions, rule, context); + if (newDims !== res.dimensions) { + res = new IndexNode(newDims); + } + } else if (res instanceof ObjectNode) { + var changed = false; + var newProps = {}; + for (var prop in res.properties) { + newProps[prop] = applyRule(res.properties[prop], rule, context); + if (newProps[prop] !== res.properties[prop]) { + changed = true; + } + } + if (changed) { + res = new ObjectNode(newProps); + } + } + + // Try to match a rule against this node + var repl = rule.r; + var matches = _ruleMatch(rule.l, res, mergedContext)[0]; + + // If the rule is associative operator, we can try matching it while allowing additional terms. + // This allows us to match rules like 'n+n' to the expression '(1+x)+x' or even 'x+1+x' if the operator is commutative. + if (!matches && rule.expanded) { + repl = rule.expanded.r; + matches = _ruleMatch(rule.expanded.l, res, mergedContext)[0]; + } + // Additional, non-commutative context expansion-rules + if (!matches && rule.expandedNC1) { + repl = rule.expandedNC1.r; + matches = _ruleMatch(rule.expandedNC1.l, res, mergedContext)[0]; + if (!matches) { + // Existence of NC1 implies NC2 + repl = rule.expandedNC2.r; + matches = _ruleMatch(rule.expandedNC2.l, res, mergedContext)[0]; + } + } + if (matches) { + // const before = res.toString({parenthesis: 'all'}) + + // Create a new node by cloning the rhs of the matched rule + // we keep any implicit multiplication state if relevant + var implicit = res.implicit; + res = repl.clone(); + if (implicit && 'implicit' in repl) { + res.implicit = true; + } + + // Replace placeholders with their respective nodes without traversing deeper into the replaced nodes + res = res.transform(function (node) { + if (node.isSymbolNode && hasOwnProperty(matches.placeholders, node.name)) { + return matches.placeholders[node.name].clone(); + } else { + return node; + } + }); + + // const after = res.toString({parenthesis: 'all'}) + // console.log('Simplified ' + before + ' to ' + after) + } + if (rule.repeat && res !== node) { + res = applyRule(res, rule, context); + } + return res; + } + + /** + * Get (binary) combinations of a flattened binary node + * e.g. +(node1, node2, node3) -> [ + * +(node1, +(node2, node3)), + * +(node2, +(node1, node3)), + * +(node3, +(node1, node2))] + * + */ + function getSplits(node, context) { + var res = []; + var right, rightArgs; + var makeNode = createMakeNodeFunction(node); + if (isCommutative(node, context)) { + for (var i = 0; i < node.args.length; i++) { + rightArgs = node.args.slice(0); + rightArgs.splice(i, 1); + right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs); + res.push(makeNode([node.args[i], right])); + } + } else { + // Keep order, but try all parenthesizations + for (var _i = 1; _i < node.args.length; _i++) { + var left = node.args[0]; + if (_i > 1) { + left = makeNode(node.args.slice(0, _i)); + } + rightArgs = node.args.slice(_i); + right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs); + res.push(makeNode([left, right])); + } + } + return res; + } + + /** + * Returns the set union of two match-placeholders or null if there is a conflict. + */ + function mergeMatch(match1, match2) { + var res = { + placeholders: {} + }; + + // Some matches may not have placeholders; this is OK + if (!match1.placeholders && !match2.placeholders) { + return res; + } else if (!match1.placeholders) { + return match2; + } else if (!match2.placeholders) { + return match1; + } + + // Placeholders with the same key must match exactly + for (var key in match1.placeholders) { + if (hasOwnProperty(match1.placeholders, key)) { + res.placeholders[key] = match1.placeholders[key]; + if (hasOwnProperty(match2.placeholders, key)) { + if (!_exactMatch(match1.placeholders[key], match2.placeholders[key])) { + return null; + } + } + } + } + for (var _key in match2.placeholders) { + if (hasOwnProperty(match2.placeholders, _key)) { + res.placeholders[_key] = match2.placeholders[_key]; + } + } + return res; + } + + /** + * Combine two lists of matches by applying mergeMatch to the cartesian product of two lists of matches. + * Each list represents matches found in one child of a node. + */ + function combineChildMatches(list1, list2) { + var res = []; + if (list1.length === 0 || list2.length === 0) { + return res; + } + var merged; + for (var i1 = 0; i1 < list1.length; i1++) { + for (var i2 = 0; i2 < list2.length; i2++) { + merged = mergeMatch(list1[i1], list2[i2]); + if (merged) { + res.push(merged); + } + } + } + return res; + } + + /** + * Combine multiple lists of matches by applying mergeMatch to the cartesian product of two lists of matches. + * Each list represents matches found in one child of a node. + * Returns a list of unique matches. + */ + function mergeChildMatches(childMatches) { + if (childMatches.length === 0) { + return childMatches; + } + var sets = childMatches.reduce(combineChildMatches); + var uniqueSets = []; + var unique = {}; + for (var i = 0; i < sets.length; i++) { + var s = JSON.stringify(sets[i]); + if (!unique[s]) { + unique[s] = true; + uniqueSets.push(sets[i]); + } + } + return uniqueSets; + } + + /** + * Determines whether node matches rule. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} rule + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node + * @param {Object} context -- provides assumed properties of operators + * @param {Boolean} isSplit -- whether we are in process of splitting an + * n-ary operator node into possible binary combinations. + * Defaults to false. + * @return {Object} Information about the match, if it exists. + */ + function _ruleMatch(rule, node, context, isSplit) { + // console.log('Entering _ruleMatch(' + JSON.stringify(rule) + ', ' + JSON.stringify(node) + ')') + // console.log('rule = ' + rule) + // console.log('node = ' + node) + + // console.log('Entering _ruleMatch(', rule.toString({parenthesis:'all'}), ', ', node.toString({parenthesis:'all'}), ', ', context, ')') + var res = [{ + placeholders: {} + }]; + if (rule instanceof OperatorNode && node instanceof OperatorNode || rule instanceof FunctionNode && node instanceof FunctionNode) { + // If the rule is an OperatorNode or a FunctionNode, then node must match exactly + if (rule instanceof OperatorNode) { + if (rule.op !== node.op || rule.fn !== node.fn) { + return []; + } + } else if (rule instanceof FunctionNode) { + if (rule.name !== node.name) { + return []; + } + } + + // rule and node match. Search the children of rule and node. + if (node.args.length === 1 && rule.args.length === 1 || !isAssociative(node, context) && node.args.length === rule.args.length || isSplit) { + // Expect non-associative operators to match exactly, + // except in any order if operator is commutative + var childMatches = []; + for (var i = 0; i < rule.args.length; i++) { + var childMatch = _ruleMatch(rule.args[i], node.args[i], context); + if (childMatch.length === 0) { + // Child did not match, so stop searching immediately + break; + } + // The child matched, so add the information returned from the child to our result + childMatches.push(childMatch); + } + if (childMatches.length !== rule.args.length) { + if (!isCommutative(node, context) || + // exact match in order needed + rule.args.length === 1) { + // nothing to commute + return []; + } + if (rule.args.length > 2) { + /* Need to generate all permutations and try them. + * It's a bit complicated, and unlikely to come up since there + * are very few ternary or higher operators. So punt for now. + */ + throw new Error('permuting >2 commutative non-associative rule arguments not yet implemented'); + } + /* Exactly two arguments, try them reversed */ + var leftMatch = _ruleMatch(rule.args[0], node.args[1], context); + if (leftMatch.length === 0) { + return []; + } + var rightMatch = _ruleMatch(rule.args[1], node.args[0], context); + if (rightMatch.length === 0) { + return []; + } + childMatches = [leftMatch, rightMatch]; + } + res = mergeChildMatches(childMatches); + } else if (node.args.length >= 2 && rule.args.length === 2) { + // node is flattened, rule is not + // Associative operators/functions can be split in different ways so we check if the rule + // matches for each of them and return their union. + var splits = getSplits(node, context); + var splitMatches = []; + for (var _i2 = 0; _i2 < splits.length; _i2++) { + var matchSet = _ruleMatch(rule, splits[_i2], context, true); // recursing at the same tree depth here + splitMatches = splitMatches.concat(matchSet); + } + return splitMatches; + } else if (rule.args.length > 2) { + throw Error('Unexpected non-binary associative function: ' + rule.toString()); + } else { + // Incorrect number of arguments in rule and node, so no match + return []; + } + } else if (rule instanceof SymbolNode) { + // If the rule is a SymbolNode, then it carries a special meaning + // according to the first one or two characters of the symbol node name. + // These meanings are expalined in the documentation for simplify() + if (rule.name.length === 0) { + throw new Error('Symbol in rule has 0 length...!?'); + } + if (SUPPORTED_CONSTANTS[rule.name]) { + // built-in constant must match exactly + if (rule.name !== node.name) { + return []; + } + } else { + // wildcards are composed of up to two alphabetic or underscore characters + switch (rule.name[1] >= 'a' && rule.name[1] <= 'z' ? rule.name.substring(0, 2) : rule.name[0]) { + case 'n': + case '_p': + // rule matches _anything_, so assign this node to the rule.name placeholder + // Assign node to the rule.name placeholder. + // Our parent will check for matches among placeholders. + res[0].placeholders[rule.name] = node; + break; + case 'c': + case 'cl': + // rule matches a ConstantNode + if (isConstantNode(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'v': + // rule matches anything other than a ConstantNode + if (!isConstantNode(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'vl': + // rule matches VariableNode + if (isVariableNode(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'cd': + // rule matches a ConstantNode or unaryMinus-wrapped ConstantNode + if (isNumericNode(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'vd': + // rule matches anything other than a ConstantNode or unaryMinus-wrapped ConstantNode + if (!isNumericNode(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 'ce': + // rule matches expressions that have a constant value + if (isConstantExpression(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + case 've': + // rule matches expressions that do not have a constant value + if (!isConstantExpression(node)) { + res[0].placeholders[rule.name] = node; + } else { + // mis-match: rule does not encompass current node + return []; + } + break; + default: + throw new Error('Invalid symbol in rule: ' + rule.name); + } + } + } else if (rule instanceof ConstantNode) { + // Literal constant must match exactly + if (!equal(rule.value, node.value)) { + return []; + } + } else { + // Some other node was encountered which we aren't prepared for, so no match + return []; + } + + // It's a match! + + // console.log('_ruleMatch(' + rule.toString() + ', ' + node.toString() + ') found a match') + return res; + } + + /** + * Determines whether p and q (and all their children nodes) are identical. + * + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} p + * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} q + * @return {Object} Information about the match, if it exists. + */ + function _exactMatch(p, q) { + if (p instanceof ConstantNode && q instanceof ConstantNode) { + if (!equal(p.value, q.value)) { + return false; + } + } else if (p instanceof SymbolNode && q instanceof SymbolNode) { + if (p.name !== q.name) { + return false; + } + } else if (p instanceof OperatorNode && q instanceof OperatorNode || p instanceof FunctionNode && q instanceof FunctionNode) { + if (p instanceof OperatorNode) { + if (p.op !== q.op || p.fn !== q.fn) { + return false; + } + } else if (p instanceof FunctionNode) { + if (p.name !== q.name) { + return false; + } + } + if (p.args.length !== q.args.length) { + return false; + } + for (var i = 0; i < p.args.length; i++) { + if (!_exactMatch(p.args[i], q.args[i])) { + return false; + } + } + } else { + return false; + } + return true; + } + return simplify; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/util.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/util.js new file mode 100644 index 0000000..5d63949 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/util.js @@ -0,0 +1,261 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +import { isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'; +import { factory } from '../../../utils/factory.js'; +import { hasOwnProperty } from '../../../utils/object.js'; +var name = 'simplifyUtil'; +var dependencies = ['FunctionNode', 'OperatorNode', 'SymbolNode']; +export var createUtil = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + FunctionNode, + OperatorNode, + SymbolNode + } = _ref; + // TODO commutative/associative properties rely on the arguments + // e.g. multiply is not commutative for matrices + // The properties should be calculated from an argument to simplify, or possibly something in math.config + // the other option is for typed() to specify a return type so that we can evaluate the type of arguments + + /* So that properties of an operator fit on one line: */ + var T = true; + var F = false; + var defaultName = 'defaultF'; + var defaultContext = { + /* */add: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /**/unaryPlus: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /* */subtract: { + trivial: F, + total: T, + commutative: F, + associative: F + }, + /* */multiply: { + trivial: T, + total: T, + commutative: T, + associative: T + }, + /* */divide: { + trivial: F, + total: T, + commutative: F, + associative: F + }, + /* */paren: { + trivial: T, + total: T, + commutative: T, + associative: F + }, + /* */defaultF: { + trivial: F, + total: T, + commutative: F, + associative: F + } + }; + var realContext = { + divide: { + total: F + }, + log: { + total: F + } + }; + var positiveContext = { + subtract: { + total: F + }, + abs: { + trivial: T + }, + log: { + total: T + } + }; + function hasProperty(nodeOrName, property) { + var context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : defaultContext; + var name = defaultName; + if (typeof nodeOrName === 'string') { + name = nodeOrName; + } else if (isOperatorNode(nodeOrName)) { + name = nodeOrName.fn.toString(); + } else if (isFunctionNode(nodeOrName)) { + name = nodeOrName.name; + } else if (isParenthesisNode(nodeOrName)) { + name = 'paren'; + } + if (hasOwnProperty(context, name)) { + var properties = context[name]; + if (hasOwnProperty(properties, property)) { + return properties[property]; + } + if (hasOwnProperty(defaultContext, name)) { + return defaultContext[name][property]; + } + } + if (hasOwnProperty(context, defaultName)) { + var _properties = context[defaultName]; + if (hasOwnProperty(_properties, property)) { + return _properties[property]; + } + return defaultContext[defaultName][property]; + } + /* name not found in context and context has no global default */ + /* So use default context. */ + if (hasOwnProperty(defaultContext, name)) { + var _properties2 = defaultContext[name]; + if (hasOwnProperty(_properties2, property)) { + return _properties2[property]; + } + } + return defaultContext[defaultName][property]; + } + function isCommutative(node) { + var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext; + return hasProperty(node, 'commutative', context); + } + function isAssociative(node) { + var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext; + return hasProperty(node, 'associative', context); + } + + /** + * Merge the given contexts, with primary overriding secondary + * wherever they might conflict + */ + function mergeContext(primary, secondary) { + var merged = _objectSpread({}, primary); + for (var prop in secondary) { + if (hasOwnProperty(primary, prop)) { + merged[prop] = _objectSpread(_objectSpread({}, secondary[prop]), primary[prop]); + } else { + merged[prop] = secondary[prop]; + } + } + return merged; + } + + /** + * Flatten all associative operators in an expression tree. + * Assumes parentheses have already been removed. + */ + function flatten(node, context) { + if (!node.args || node.args.length === 0) { + return node; + } + node.args = allChildren(node, context); + for (var i = 0; i < node.args.length; i++) { + flatten(node.args[i], context); + } + } + + /** + * Get the children of a node as if it has been flattened. + * TODO implement for FunctionNodes + */ + function allChildren(node, context) { + var op; + var children = []; + var _findChildren = function findChildren(node) { + for (var i = 0; i < node.args.length; i++) { + var child = node.args[i]; + if (isOperatorNode(child) && op === child.op) { + _findChildren(child); + } else { + children.push(child); + } + } + }; + if (isAssociative(node, context)) { + op = node.op; + _findChildren(node); + return children; + } else { + return node.args; + } + } + + /** + * Unflatten all flattened operators to a right-heavy binary tree. + */ + function unflattenr(node, context) { + if (!node.args || node.args.length === 0) { + return; + } + var makeNode = createMakeNodeFunction(node); + var l = node.args.length; + for (var i = 0; i < l; i++) { + unflattenr(node.args[i], context); + } + if (l > 2 && isAssociative(node, context)) { + var curnode = node.args.pop(); + while (node.args.length > 0) { + curnode = makeNode([node.args.pop(), curnode]); + } + node.args = curnode.args; + } + } + + /** + * Unflatten all flattened operators to a left-heavy binary tree. + */ + function unflattenl(node, context) { + if (!node.args || node.args.length === 0) { + return; + } + var makeNode = createMakeNodeFunction(node); + var l = node.args.length; + for (var i = 0; i < l; i++) { + unflattenl(node.args[i], context); + } + if (l > 2 && isAssociative(node, context)) { + var curnode = node.args.shift(); + while (node.args.length > 0) { + curnode = makeNode([curnode, node.args.shift()]); + } + node.args = curnode.args; + } + } + function createMakeNodeFunction(node) { + if (isOperatorNode(node)) { + return function (args) { + try { + return new OperatorNode(node.op, node.fn, args, node.implicit); + } catch (err) { + console.error(err); + return []; + } + }; + } else { + return function (args) { + return new FunctionNode(new SymbolNode(node.name), args); + }; + } + } + return { + createMakeNodeFunction, + hasProperty, + isCommutative, + isAssociative, + mergeContext, + flatten, + allChildren, + unflattenr, + unflattenl, + defaultContext, + realContext, + positiveContext + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/wildcards.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/wildcards.js new file mode 100644 index 0000000..557ac1c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplify/wildcards.js @@ -0,0 +1,20 @@ +import { isConstantNode, isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'; +export { isConstantNode, isSymbolNode as isVariableNode } from '../../../utils/is.js'; +export function isNumericNode(x) { + return isConstantNode(x) || isOperatorNode(x) && x.isUnary() && isConstantNode(x.args[0]); +} +export function isConstantExpression(x) { + if (isConstantNode(x)) { + // Basic Constant types + return true; + } + if ((isFunctionNode(x) || isOperatorNode(x)) && x.args.every(isConstantExpression)) { + // Can be constant depending on arguments + return true; + } + if (isParenthesisNode(x) && isConstantExpression(x.content)) { + // Parenthesis are transparent + return true; + } + return false; // Probably missing some edge cases +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyConstant.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyConstant.js new file mode 100644 index 0000000..e160337 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyConstant.js @@ -0,0 +1,472 @@ +import { isFraction, isMatrix, isNode, isArrayNode, isConstantNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +import { createUtil } from './simplify/util.js'; +import { noBignumber, noFraction } from '../../utils/noop.js'; +var name = 'simplifyConstant'; +var dependencies = ['typed', 'config', 'mathWithTransform', 'matrix', '?fraction', '?bignumber', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode']; +export var createSimplifyConstant = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + mathWithTransform, + matrix, + fraction, + bignumber, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + SymbolNode + } = _ref; + var { + isCommutative, + isAssociative, + allChildren, + createMakeNodeFunction + } = createUtil({ + FunctionNode, + OperatorNode, + SymbolNode + }); + + /** + * simplifyConstant() takes a mathjs expression (either a Node representing + * a parse tree or a string which it parses to produce a node), and replaces + * any subexpression of it consisting entirely of constants with the computed + * value of that subexpression. + * + * Syntax: + * + * math.simplifyConstant(expr) + * math.simplifyConstant(expr, options) + * + * Examples: + * + * math.simplifyConstant('x + 4*3/6') // Node "x + 2" + * math.simplifyConstant('z cos(0)') // Node "z 1" + * math.simplifyConstant('(5.2 + 1.08)t', {exactFractions: false}) // Node "6.28 t" + * + * See also: + * + * simplify, simplifyCore, resolve, derivative + * + * @param {Node | string} node + * The expression to be simplified + * @param {Object} options + * Simplification options, as per simplify() + * @return {Node} Returns expression with constant subexpressions evaluated + */ + var simplifyConstant = typed('simplifyConstant', { + Node: node => _ensureNode(foldFraction(node, {})), + 'Node, Object': function Node_Object(expr, options) { + return _ensureNode(foldFraction(expr, options)); + } + }); + function _removeFractions(thing) { + if (isFraction(thing)) { + return thing.valueOf(); + } + if (thing instanceof Array) { + return thing.map(_removeFractions); + } + if (isMatrix(thing)) { + return matrix(_removeFractions(thing.valueOf())); + } + return thing; + } + function _eval(fnname, args, options) { + try { + return mathWithTransform[fnname].apply(null, args); + } catch (ignore) { + // sometimes the implicit type conversion causes the evaluation to fail, so we'll try again after removing Fractions + args = args.map(_removeFractions); + return _toNumber(mathWithTransform[fnname].apply(null, args), options); + } + } + var _toNode = typed({ + Fraction: _fractionToNode, + number: function number(n) { + if (n < 0) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); + }, + BigNumber: function BigNumber(n) { + if (n < 0) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); // old parameters: (n.toString(), 'number') + }, + bigint: function bigint(n) { + if (n < 0n) { + return unaryMinusNode(new ConstantNode(-n)); + } + return new ConstantNode(n); + }, + Complex: function Complex(s) { + throw new Error('Cannot convert Complex number to Node'); + }, + string: function string(s) { + return new ConstantNode(s); + }, + Matrix: function Matrix(m) { + return new ArrayNode(m.valueOf().map(e => _toNode(e))); + } + }); + function _ensureNode(thing) { + if (isNode(thing)) { + return thing; + } + return _toNode(thing); + } + + // convert a number to a fraction only if it can be expressed exactly, + // and when both numerator and denominator are small enough + function _exactFraction(n, options) { + var exactFractions = options && options.exactFractions !== false; + if (exactFractions && isFinite(n) && fraction) { + var f = fraction(n); + var fractionsLimit = options && typeof options.fractionsLimit === 'number' ? options.fractionsLimit : Infinity; // no limit by default + + if (f.valueOf() === n && f.n < fractionsLimit && f.d < fractionsLimit) { + return f; + } + } + return n; + } + + // Convert numbers to a preferred number type in preference order: Fraction, number, Complex + // BigNumbers are left alone + var _toNumber = typed({ + 'string, Object': function string_Object(s, options) { + var numericType = safeNumberType(s, config); + if (numericType === 'BigNumber') { + if (bignumber === undefined) { + noBignumber(); + } + return bignumber(s); + } else if (numericType === 'bigint') { + return BigInt(s); + } else if (numericType === 'Fraction') { + if (fraction === undefined) { + noFraction(); + } + return fraction(s); + } else { + var n = parseFloat(s); + return _exactFraction(n, options); + } + }, + 'Fraction, Object': function Fraction_Object(s, options) { + return s; + }, + // we don't need options here + + 'BigNumber, Object': function BigNumber_Object(s, options) { + return s; + }, + // we don't need options here + + 'number, Object': function number_Object(s, options) { + return _exactFraction(s, options); + }, + 'bigint, Object': function bigint_Object(s, options) { + return s; + }, + 'Complex, Object': function Complex_Object(s, options) { + if (s.im !== 0) { + return s; + } + return _exactFraction(s.re, options); + }, + 'Matrix, Object': function Matrix_Object(s, options) { + return matrix(_exactFraction(s.valueOf())); + }, + 'Array, Object': function Array_Object(s, options) { + return s.map(_exactFraction); + } + }); + function unaryMinusNode(n) { + return new OperatorNode('-', 'unaryMinus', [n]); + } + function _fractionToNode(f) { + var n; + var vn = f.s * f.n; + if (vn < 0) { + n = new OperatorNode('-', 'unaryMinus', [new ConstantNode(-vn)]); + } else { + n = new ConstantNode(vn); + } + if (f.d === 1) { + return n; + } + return new OperatorNode('/', 'divide', [n, new ConstantNode(f.d)]); + } + + /* Handles constant indexing of ArrayNodes, matrices, and ObjectNodes */ + function _foldAccessor(obj, index, options) { + if (!isIndexNode(index)) { + // don't know what to do with that... + return new AccessorNode(_ensureNode(obj), _ensureNode(index)); + } + if (isArrayNode(obj) || isMatrix(obj)) { + var remainingDims = Array.from(index.dimensions); + /* We will resolve constant indices one at a time, looking + * just in the first or second dimensions because (a) arrays + * of more than two dimensions are likely rare, and (b) pulling + * out the third or higher dimension would be pretty intricate. + * The price is that we miss simplifying [..3d array][x,y,1] + */ + while (remainingDims.length > 0) { + if (isConstantNode(remainingDims[0]) && typeof remainingDims[0].value !== 'string') { + var first = _toNumber(remainingDims.shift().value, options); + if (isArrayNode(obj)) { + obj = obj.items[first - 1]; + } else { + // matrix + obj = obj.valueOf()[first - 1]; + if (obj instanceof Array) { + obj = matrix(obj); + } + } + } else if (remainingDims.length > 1 && isConstantNode(remainingDims[1]) && typeof remainingDims[1].value !== 'string') { + var second = _toNumber(remainingDims[1].value, options); + var tryItems = []; + var fromItems = isArrayNode(obj) ? obj.items : obj.valueOf(); + for (var item of fromItems) { + if (isArrayNode(item)) { + tryItems.push(item.items[second - 1]); + } else if (isMatrix(obj)) { + tryItems.push(item[second - 1]); + } else { + break; + } + } + if (tryItems.length === fromItems.length) { + if (isArrayNode(obj)) { + obj = new ArrayNode(tryItems); + } else { + // matrix + obj = matrix(tryItems); + } + remainingDims.splice(1, 1); + } else { + // extracting slice along 2nd dimension failed, give up + break; + } + } else { + // neither 1st or 2nd dimension is constant, give up + break; + } + } + if (remainingDims.length === index.dimensions.length) { + /* No successful constant indexing */ + return new AccessorNode(_ensureNode(obj), index); + } + if (remainingDims.length > 0) { + /* Indexed some but not all dimensions */ + index = new IndexNode(remainingDims); + return new AccessorNode(_ensureNode(obj), index); + } + /* All dimensions were constant, access completely resolved */ + return obj; + } + if (isObjectNode(obj) && index.dimensions.length === 1 && isConstantNode(index.dimensions[0])) { + var key = index.dimensions[0].value; + if (key in obj.properties) { + return obj.properties[key]; + } + return new ConstantNode(); // undefined + } + /* Don't know how to index this sort of obj, at least not with this index */ + return new AccessorNode(_ensureNode(obj), index); + } + + /* + * Create a binary tree from a list of Fractions and Nodes. + * Tries to fold Fractions by evaluating them until the first Node in the list is hit, so + * `args` should be sorted to have the Fractions at the start (if the operator is commutative). + * @param args - list of Fractions and Nodes + * @param fn - evaluator for the binary operation evaluator that accepts two Fractions + * @param makeNode - creates a binary OperatorNode/FunctionNode from a list of child Nodes + * if args.length is 1, returns args[0] + * @return - Either a Node representing a binary expression or Fraction + */ + function foldOp(fn, args, makeNode, options) { + var first = args.shift(); + + // In the following reduction, sofar always has one of the three following + // forms: [NODE], [CONSTANT], or [NODE, CONSTANT] + var reduction = args.reduce((sofar, next) => { + if (!isNode(next)) { + var last = sofar.pop(); + if (isNode(last)) { + return [last, next]; + } + // Two constants in a row, try to fold them into one + try { + sofar.push(_eval(fn, [last, next], options)); + return sofar; + } catch (ignoreandcontinue) { + sofar.push(last); + // fall through to Node case + } + } + + // Encountered a Node, or failed folding -- + // collapse everything so far into a single tree: + sofar.push(_ensureNode(sofar.pop())); + var newtree = sofar.length === 1 ? sofar[0] : makeNode(sofar); + return [makeNode([newtree, _ensureNode(next)])]; + }, [first]); + if (reduction.length === 1) { + return reduction[0]; + } + // Might end up with a tree and a constant at the end: + return makeNode([reduction[0], _toNode(reduction[1])]); + } + + // destroys the original node and returns a folded one + function foldFraction(node, options) { + switch (node.type) { + case 'SymbolNode': + return node; + case 'ConstantNode': + switch (typeof node.value) { + case 'number': + return _toNumber(node.value, options); + case 'bigint': + return _toNumber(node.value, options); + case 'string': + return node.value; + default: + if (!isNaN(node.value)) return _toNumber(node.value, options); + } + return node; + case 'FunctionNode': + if (mathWithTransform[node.name] && mathWithTransform[node.name].rawArgs) { + return node; + } + { + // Process operators as OperatorNode + var operatorFunctions = ['add', 'multiply']; + if (!operatorFunctions.includes(node.name)) { + var args = node.args.map(arg => foldFraction(arg, options)); + + // If all args are numbers + if (!args.some(isNode)) { + try { + return _eval(node.name, args, options); + } catch (ignoreandcontinue) {} + } + + // Size of a matrix does not depend on entries + if (node.name === 'size' && args.length === 1 && isArrayNode(args[0])) { + var sz = []; + var section = args[0]; + while (isArrayNode(section)) { + sz.push(section.items.length); + section = section.items[0]; + } + return matrix(sz); + } + + // Convert all args to nodes and construct a symbolic function call + return new FunctionNode(node.name, args.map(_ensureNode)); + } else { + // treat as operator + } + } + /* falls through */ + case 'OperatorNode': + { + var fn = node.fn.toString(); + var _args; + var res; + var makeNode = createMakeNodeFunction(node); + if (isOperatorNode(node) && node.isUnary()) { + _args = [foldFraction(node.args[0], options)]; + if (!isNode(_args[0])) { + res = _eval(fn, _args, options); + } else { + res = makeNode(_args); + } + } else if (isAssociative(node, options.context)) { + _args = allChildren(node, options.context); + _args = _args.map(arg => foldFraction(arg, options)); + if (isCommutative(fn, options.context)) { + // commutative binary operator + var consts = []; + var vars = []; + for (var i = 0; i < _args.length; i++) { + if (!isNode(_args[i])) { + consts.push(_args[i]); + } else { + vars.push(_args[i]); + } + } + if (consts.length > 1) { + res = foldOp(fn, consts, makeNode, options); + vars.unshift(res); + res = foldOp(fn, vars, makeNode, options); + } else { + // we won't change the children order since it's not neccessary + res = foldOp(fn, _args, makeNode, options); + } + } else { + // non-commutative binary operator + res = foldOp(fn, _args, makeNode, options); + } + } else { + // non-associative binary operator + _args = node.args.map(arg => foldFraction(arg, options)); + res = foldOp(fn, _args, makeNode, options); + } + return res; + } + case 'ParenthesisNode': + // remove the uneccessary parenthesis + return foldFraction(node.content, options); + case 'AccessorNode': + return _foldAccessor(foldFraction(node.object, options), foldFraction(node.index, options), options); + case 'ArrayNode': + { + var foldItems = node.items.map(item => foldFraction(item, options)); + if (foldItems.some(isNode)) { + return new ArrayNode(foldItems.map(_ensureNode)); + } + /* All literals -- return a Matrix so we can operate on it */ + return matrix(foldItems); + } + case 'IndexNode': + { + return new IndexNode(node.dimensions.map(n => simplifyConstant(n, options))); + } + case 'ObjectNode': + { + var foldProps = {}; + for (var prop in node.properties) { + foldProps[prop] = simplifyConstant(node.properties[prop], options); + } + return new ObjectNode(foldProps); + } + case 'AssignmentNode': + /* falls through */ + case 'BlockNode': + /* falls through */ + case 'FunctionAssignmentNode': + /* falls through */ + case 'RangeNode': + /* falls through */ + case 'ConditionalNode': + /* falls through */ + default: + throw new Error("Unimplemented node type in simplifyConstant: ".concat(node.type)); + } + } + return simplifyConstant; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyCore.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyCore.js new file mode 100644 index 0000000..07139bc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/simplifyCore.js @@ -0,0 +1,291 @@ +import { isAccessorNode, isArrayNode, isConstantNode, isFunctionNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'; +import { getOperator } from '../../expression/operators.js'; +import { createUtil } from './simplify/util.js'; +import { factory } from '../../utils/factory.js'; +var name = 'simplifyCore'; +var dependencies = ['typed', 'parse', 'equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode']; +export var createSimplifyCore = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + parse, + equal, + isZero, + add, + subtract, + multiply, + divide, + pow, + AccessorNode, + ArrayNode, + ConstantNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + SymbolNode + } = _ref; + var node0 = new ConstantNode(0); + var node1 = new ConstantNode(1); + var nodeT = new ConstantNode(true); + var nodeF = new ConstantNode(false); + // test if a node will always have a boolean value (true/false) + // not sure if this list is complete + function isAlwaysBoolean(node) { + return isOperatorNode(node) && ['and', 'not', 'or'].includes(node.op); + } + var { + hasProperty, + isCommutative + } = createUtil({ + FunctionNode, + OperatorNode, + SymbolNode + }); + /** + * simplifyCore() performs single pass simplification suitable for + * applications requiring ultimate performance. To roughly summarize, + * it handles cases along the lines of simplifyConstant() but where + * knowledge of a single argument is sufficient to determine the value. + * In contrast, simplify() extends simplifyCore() with additional passes + * to provide deeper simplification (such as gathering like terms). + * + * Specifically, simplifyCore: + * + * * Converts all function calls with operator equivalents to their + * operator forms. + * * Removes operators or function calls that are guaranteed to have no + * effect (such as unary '+'). + * * Removes double unary '-', '~', and 'not' + * * Eliminates addition/subtraction of 0 and multiplication/division/powers + * by 1 or 0. + * * Converts addition of a negation into subtraction. + * * Eliminates logical operations with constant true or false leading + * arguments. + * * Puts constants on the left of a product, if multiplication is + * considered commutative by the options (which is the default) + * + * Syntax: + * + * math.simplifyCore(expr) + * math.simplifyCore(expr, options) + * + * Examples: + * + * const f = math.parse('2 * 1 * x ^ (1 - 0)') + * math.simplifyCore(f) // Node "2 * x" + * math.simplify('2 * 1 * x ^ (1 - 0)', [math.simplifyCore]) // Node "2 * x" + * + * See also: + * + * simplify, simplifyConstant, resolve, derivative + * + * @param {Node | string} node + * The expression to be simplified + * @param {Object} options + * Simplification options, as per simplify() + * @return {Node} Returns expression with basic simplifications applied + */ + function _simplifyCore(nodeToSimplify) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var context = options ? options.context : undefined; + if (hasProperty(nodeToSimplify, 'trivial', context)) { + // This node does nothing if it has only one argument, so if so, + // return that argument simplified + if (isFunctionNode(nodeToSimplify) && nodeToSimplify.args.length === 1) { + return _simplifyCore(nodeToSimplify.args[0], options); + } + // For other node types, we try the generic methods + var simpChild = false; + var childCount = 0; + nodeToSimplify.forEach(c => { + ++childCount; + if (childCount === 1) { + simpChild = _simplifyCore(c, options); + } + }); + if (childCount === 1) { + return simpChild; + } + } + var node = nodeToSimplify; + if (isFunctionNode(node)) { + var op = getOperator(node.name); + if (op) { + // Replace FunctionNode with a new OperatorNode + if (node.args.length > 2 && hasProperty(node, 'associative', context)) { + // unflatten into binary operations since that's what simplifyCore handles + while (node.args.length > 2) { + var last = node.args.pop(); + var seclast = node.args.pop(); + node.args.push(new OperatorNode(op, node.name, [last, seclast])); + } + } + node = new OperatorNode(op, node.name, node.args); + } else { + return new FunctionNode(_simplifyCore(node.fn), node.args.map(n => _simplifyCore(n, options))); + } + } + if (isOperatorNode(node) && node.isUnary()) { + var a0 = _simplifyCore(node.args[0], options); + if (node.op === '~') { + // bitwise not + if (isOperatorNode(a0) && a0.isUnary() && a0.op === '~') { + return a0.args[0]; + } + } + if (node.op === 'not') { + // logical not + if (isOperatorNode(a0) && a0.isUnary() && a0.op === 'not') { + // Has the effect of turning the argument into a boolean + // So can only eliminate the double negation if + // the inside is already boolean + if (isAlwaysBoolean(a0.args[0])) { + return a0.args[0]; + } + } + } + var finish = true; + if (node.op === '-') { + // unary minus + if (isOperatorNode(a0)) { + if (a0.isBinary() && a0.fn === 'subtract') { + node = new OperatorNode('-', 'subtract', [a0.args[1], a0.args[0]]); + finish = false; // continue to process the new binary node + } + if (a0.isUnary() && a0.op === '-') { + return a0.args[0]; + } + } + } + if (finish) return new OperatorNode(node.op, node.fn, [a0]); + } + if (isOperatorNode(node) && node.isBinary()) { + var _a = _simplifyCore(node.args[0], options); + var a1 = _simplifyCore(node.args[1], options); + if (node.op === '+') { + if (isConstantNode(_a) && isZero(_a.value)) { + return a1; + } + if (isConstantNode(a1) && isZero(a1.value)) { + return _a; + } + if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') { + a1 = a1.args[0]; + node = new OperatorNode('-', 'subtract', [_a, a1]); + } + } + if (node.op === '-') { + if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') { + return _simplifyCore(new OperatorNode('+', 'add', [_a, a1.args[0]]), options); + } + if (isConstantNode(_a) && isZero(_a.value)) { + return _simplifyCore(new OperatorNode('-', 'unaryMinus', [a1])); + } + if (isConstantNode(a1) && isZero(a1.value)) { + return _a; + } + return new OperatorNode(node.op, node.fn, [_a, a1]); + } + if (node.op === '*') { + if (isConstantNode(_a)) { + if (isZero(_a.value)) { + return node0; + } else if (equal(_a.value, 1)) { + return a1; + } + } + if (isConstantNode(a1)) { + if (isZero(a1.value)) { + return node0; + } else if (equal(a1.value, 1)) { + return _a; + } + if (isCommutative(node, context)) { + return new OperatorNode(node.op, node.fn, [a1, _a], node.implicit); // constants on left + } + } + return new OperatorNode(node.op, node.fn, [_a, a1], node.implicit); + } + if (node.op === '/') { + if (isConstantNode(_a) && isZero(_a.value)) { + return node0; + } + if (isConstantNode(a1) && equal(a1.value, 1)) { + return _a; + } + return new OperatorNode(node.op, node.fn, [_a, a1]); + } + if (node.op === '^') { + if (isConstantNode(a1)) { + if (isZero(a1.value)) { + return node1; + } else if (equal(a1.value, 1)) { + return _a; + } + } + } + if (node.op === 'and') { + if (isConstantNode(_a)) { + if (_a.value) { + if (isAlwaysBoolean(a1)) return a1; + if (isConstantNode(a1)) { + return a1.value ? nodeT : nodeF; + } + } else { + return nodeF; + } + } + if (isConstantNode(a1)) { + if (a1.value) { + if (isAlwaysBoolean(_a)) return _a; + } else { + return nodeF; + } + } + } + if (node.op === 'or') { + if (isConstantNode(_a)) { + if (_a.value) { + return nodeT; + } else { + if (isAlwaysBoolean(a1)) return a1; + } + } + if (isConstantNode(a1)) { + if (a1.value) { + return nodeT; + } else { + if (isAlwaysBoolean(_a)) return _a; + } + } + } + return new OperatorNode(node.op, node.fn, [_a, a1]); + } + if (isOperatorNode(node)) { + return new OperatorNode(node.op, node.fn, node.args.map(a => _simplifyCore(a, options))); + } + if (isArrayNode(node)) { + return new ArrayNode(node.items.map(n => _simplifyCore(n, options))); + } + if (isAccessorNode(node)) { + return new AccessorNode(_simplifyCore(node.object, options), _simplifyCore(node.index, options)); + } + if (isIndexNode(node)) { + return new IndexNode(node.dimensions.map(n => _simplifyCore(n, options))); + } + if (isObjectNode(node)) { + var newProps = {}; + for (var prop in node.properties) { + newProps[prop] = _simplifyCore(node.properties[prop], options); + } + return new ObjectNode(newProps); + } + // cannot simplify + return node; + } + return typed(name, { + Node: _simplifyCore, + 'Node,Object': _simplifyCore + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolve.js new file mode 100644 index 0000000..ed0bc60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolve.js @@ -0,0 +1,157 @@ +import { factory } from '../../../utils/factory.js'; +import { createSolveValidation } from './utils/solveValidation.js'; +var name = 'lsolve'; +var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +export var createLsolve = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + var solveValidation = createSolveValidation({ + DenseMatrix + }); + + /** + * Finds one solution of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. Throws an error if there's no solution. + * + * `L * x = b` + * + * Syntax: + * + * math.lsolve(L, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = lsolve(a, b) // [[-5.5], [20]] + * + * See also: + * + * lsolveAll, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} L A N x N matrix or array (L) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix | Array} A column vector with the linear system solution (x) + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function SparseMatrix_Array__Matrix(m, b) { + return _sparseForwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function DenseMatrix_Array__Matrix(m, b) { + return _denseForwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function Array_Array__Matrix(a, b) { + var m = matrix(a); + var r = _denseForwardSubstitution(m, b); + return r.valueOf(); + } + }); + function _denseForwardSubstitution(m, b) { + // validate matrix and vector, return copy of column vector b + b = solveValidation(m, b, true); + var bdata = b._data; + var rows = m._size[0]; + var columns = m._size[1]; + + // result + var x = []; + var mdata = m._data; + + // loop columns + for (var j = 0; j < columns; j++) { + var bj = bdata[j][0] || 0; + var xj = void 0; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + var vjj = mdata[j][j]; + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + xj = divideScalar(bj, vjj); + + // loop rows + for (var i = j + 1; i < rows; i++) { + bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]; + } + } else { + // degenerate row, we can choose any value + xj = 0; + } + x[j] = [xj]; + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } + function _sparseForwardSubstitution(m, b) { + // validate matrix and vector, return copy of column vector b + b = solveValidation(m, b, true); + var bdata = b._data; + var rows = m._size[0]; + var columns = m._size[1]; + var values = m._values; + var index = m._index; + var ptr = m._ptr; + + // result + var x = []; + + // loop columns + for (var j = 0; j < columns; j++) { + var bj = bdata[j][0] || 0; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + var vjj = 0; + // matrix values & indices (column j) + var jValues = []; + var jIndices = []; + + // first and last index in the column + var firstIndex = ptr[j]; + var lastIndex = ptr[j + 1]; + + // values in column, find value at [j, j] + for (var k = firstIndex; k < lastIndex; k++) { + var i = index[k]; + + // check row (rows are not sorted!) + if (i === j) { + vjj = values[k]; + } else if (i > j) { + // store lower triangular + jValues.push(values[k]); + jIndices.push(i); + } + } + + // at this point we must have a value in vjj + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + var xj = divideScalar(bj, vjj); + for (var _k = 0, l = jIndices.length; _k < l; _k++) { + var _i = jIndices[_k]; + bdata[_i] = [subtractScalar(bdata[_i][0] || 0, multiplyScalar(xj, jValues[_k]))]; + } + x[j] = [xj]; + } else { + // degenerate row, we can choose any value + x[j] = [0]; + } + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolveAll.js new file mode 100644 index 0000000..a6f2d8c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lsolveAll.js @@ -0,0 +1,186 @@ +import { factory } from '../../../utils/factory.js'; +import { createSolveValidation } from './utils/solveValidation.js'; +var name = 'lsolveAll'; +var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +export var createLsolveAll = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + var solveValidation = createSolveValidation({ + DenseMatrix + }); + + /** + * Finds all solutions of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. + * + * `L * x = b` + * + * Syntax: + * + * math.lsolveAll(L, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = lsolveAll(a, b) // [ [[-5.5], [20]] ] + * + * See also: + * + * lsolve, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} L A N x N matrix or array (L) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function SparseMatrix_Array__Matrix(m, b) { + return _sparseForwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function DenseMatrix_Array__Matrix(m, b) { + return _denseForwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function Array_Array__Matrix(a, b) { + var m = matrix(a); + var R = _denseForwardSubstitution(m, b); + return R.map(r => r.valueOf()); + } + }); + function _denseForwardSubstitution(m, b_) { + // the algorithm is derived from + // https://www.overleaf.com/read/csvgqdxggyjv + + // array of right-hand sides + var B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + var M = m._data; + var rows = m._size[0]; + var columns = m._size[1]; + + // loop columns + for (var i = 0; i < columns; i++) { + var L = B.length; + + // loop right-hand sides + for (var k = 0; k < L; k++) { + var b = B[k]; + if (!equalScalar(M[i][i], 0)) { + // non-singular row + + b[i] = divideScalar(b[i], M[i][i]); + for (var j = i + 1; j < columns; j++) { + // b[j] -= b[i] * M[j,i] + b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + var bNew = [...b]; + bNew[i] = 1; + for (var _j = i + 1; _j < columns; _j++) { + bNew[_j] = subtractScalar(bNew[_j], M[_j][i]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } + function _sparseForwardSubstitution(m, b_) { + // array of right-hand sides + var B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + var rows = m._size[0]; + var columns = m._size[1]; + var values = m._values; + var index = m._index; + var ptr = m._ptr; + + // loop columns + for (var i = 0; i < columns; i++) { + var L = B.length; + + // loop right-hand sides + for (var k = 0; k < L; k++) { + var b = B[k]; + + // values & indices (column i) + var iValues = []; + var iIndices = []; + + // first & last indeces in column + var firstIndex = ptr[i]; + var lastIndex = ptr[i + 1]; + + // find the value at [i, i] + var Mii = 0; + for (var j = firstIndex; j < lastIndex; j++) { + var J = index[j]; + // check row + if (J === i) { + Mii = values[j]; + } else if (J > i) { + // store lower triangular + iValues.push(values[j]); + iIndices.push(J); + } + } + if (!equalScalar(Mii, 0)) { + // non-singular row + + b[i] = divideScalar(b[i], Mii); + for (var _j2 = 0, _lastIndex = iIndices.length; _j2 < _lastIndex; _j2++) { + var _J = iIndices[_j2]; + b[_J] = subtractScalar(b[_J], multiplyScalar(b[i], iValues[_j2])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + var bNew = [...b]; + bNew[i] = 1; + for (var _j3 = 0, _lastIndex2 = iIndices.length; _j3 < _lastIndex2; _j3++) { + var _J2 = iIndices[_j3]; + bNew[_J2] = subtractScalar(bNew[_J2], iValues[_j3]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lusolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lusolve.js new file mode 100644 index 0000000..a0109e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/lusolve.js @@ -0,0 +1,108 @@ +import { isArray, isMatrix } from '../../../utils/is.js'; +import { factory } from '../../../utils/factory.js'; +import { createSolveValidation } from './utils/solveValidation.js'; +import { csIpvec } from '../sparse/csIpvec.js'; +var name = 'lusolve'; +var dependencies = ['typed', 'matrix', 'lup', 'slu', 'usolve', 'lsolve', 'DenseMatrix']; +export var createLusolve = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + lup, + slu, + usolve, + lsolve, + DenseMatrix + } = _ref; + var solveValidation = createSolveValidation({ + DenseMatrix + }); + + /** + * Solves the linear system `A * x = b` where `A` is an [n x n] matrix and `b` is a [n] column vector. + * + * Syntax: + * + * math.lusolve(A, b) // returns column vector with the solution to the linear system A * x = b + * math.lusolve(lup, b) // returns column vector with the solution to the linear system A * x = b, lup = math.lup(A) + * + * Examples: + * + * const m = [[1, 0, 0, 0], [0, 2, 0, 0], [0, 0, 3, 0], [0, 0, 0, 4]] + * + * const x = math.lusolve(m, [-1, -1, -1, -1]) // x = [[-1], [-0.5], [-1/3], [-0.25]] + * + * const f = math.lup(m) + * const x1 = math.lusolve(f, [-1, -1, -1, -1]) // x1 = [[-1], [-0.5], [-1/3], [-0.25]] + * const x2 = math.lusolve(f, [1, 2, 1, -1]) // x2 = [[1], [1], [1/3], [-0.25]] + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = math.lusolve(a, b) // [[2], [5]] + * + * See also: + * + * lup, slu, lsolve, usolve + * + * @param {Matrix | Array | Object} A Invertible Matrix or the Matrix LU decomposition + * @param {Matrix | Array} b Column Vector + * @param {number} [order] The Symbolic Ordering and Analysis order, see slu for details. Matrix must be a SparseMatrix + * @param {Number} [threshold] Partial pivoting threshold (1 for partial pivoting), see slu for details. Matrix must be a SparseMatrix. + * + * @return {DenseMatrix | Array} Column vector with the solution to the linear system A * x = b + */ + return typed(name, { + 'Array, Array | Matrix': function Array_Array__Matrix(a, b) { + a = matrix(a); + var d = lup(a); + var x = _lusolve(d.L, d.U, d.p, null, b); + return x.valueOf(); + }, + 'DenseMatrix, Array | Matrix': function DenseMatrix_Array__Matrix(a, b) { + var d = lup(a); + return _lusolve(d.L, d.U, d.p, null, b); + }, + 'SparseMatrix, Array | Matrix': function SparseMatrix_Array__Matrix(a, b) { + var d = lup(a); + return _lusolve(d.L, d.U, d.p, null, b); + }, + 'SparseMatrix, Array | Matrix, number, number': function SparseMatrix_Array__Matrix_number_number(a, b, order, threshold) { + var d = slu(a, order, threshold); + return _lusolve(d.L, d.U, d.p, d.q, b); + }, + 'Object, Array | Matrix': function Object_Array__Matrix(d, b) { + return _lusolve(d.L, d.U, d.p, d.q, b); + } + }); + function _toMatrix(a) { + if (isMatrix(a)) { + return a; + } + if (isArray(a)) { + return matrix(a); + } + throw new TypeError('Invalid Matrix LU decomposition'); + } + function _lusolve(l, u, p, q, b) { + // verify decomposition + l = _toMatrix(l); + u = _toMatrix(u); + + // apply row permutations if needed (b is a DenseMatrix) + if (p) { + b = solveValidation(l, b, true); + b._data = csIpvec(p, b._data); + } + + // use forward substitution to resolve L * y = b + var y = lsolve(l, b); + // use backward substitution to resolve U * x = y + var x = usolve(u, y); + + // apply column permutations if needed (x is a DenseMatrix) + if (q) { + x._data = csIpvec(q, x._data); + } + return x; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolve.js new file mode 100644 index 0000000..5ca5d9d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolve.js @@ -0,0 +1,161 @@ +import { factory } from '../../../utils/factory.js'; +import { createSolveValidation } from './utils/solveValidation.js'; +var name = 'usolve'; +var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +export var createUsolve = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + var solveValidation = createSolveValidation({ + DenseMatrix + }); + + /** + * Finds one solution of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. Throws an error if there's no solution. + * + * `U * x = b` + * + * Syntax: + * + * math.usolve(U, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = usolve(a, b) // [[8], [9]] + * + * See also: + * + * usolveAll, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} U A N x N matrix or array (U) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix | Array} A column vector with the linear system solution (x) + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function SparseMatrix_Array__Matrix(m, b) { + return _sparseBackwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function DenseMatrix_Array__Matrix(m, b) { + return _denseBackwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function Array_Array__Matrix(a, b) { + var m = matrix(a); + var r = _denseBackwardSubstitution(m, b); + return r.valueOf(); + } + }); + function _denseBackwardSubstitution(m, b) { + // make b into a column vector + b = solveValidation(m, b, true); + var bdata = b._data; + var rows = m._size[0]; + var columns = m._size[1]; + + // result + var x = []; + var mdata = m._data; + // loop columns backwards + for (var j = columns - 1; j >= 0; j--) { + // b[j] + var bj = bdata[j][0] || 0; + // x[j] + var xj = void 0; + if (!equalScalar(bj, 0)) { + // value at [j, j] + var vjj = mdata[j][j]; + if (equalScalar(vjj, 0)) { + // system cannot be solved + throw new Error('Linear system cannot be solved since matrix is singular'); + } + xj = divideScalar(bj, vjj); + + // loop rows + for (var i = j - 1; i >= 0; i--) { + // update copy of b + bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]; + } + } else { + // zero value at j + xj = 0; + } + // update x + x[j] = [xj]; + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } + function _sparseBackwardSubstitution(m, b) { + // make b into a column vector + b = solveValidation(m, b, true); + var bdata = b._data; + var rows = m._size[0]; + var columns = m._size[1]; + var values = m._values; + var index = m._index; + var ptr = m._ptr; + + // result + var x = []; + + // loop columns backwards + for (var j = columns - 1; j >= 0; j--) { + var bj = bdata[j][0] || 0; + if (!equalScalar(bj, 0)) { + // non-degenerate row, find solution + + var vjj = 0; + + // upper triangular matrix values & index (column j) + var jValues = []; + var jIndices = []; + + // first & last indeces in column + var firstIndex = ptr[j]; + var lastIndex = ptr[j + 1]; + + // values in column, find value at [j, j], loop backwards + for (var k = lastIndex - 1; k >= firstIndex; k--) { + var i = index[k]; + + // check row (rows are not sorted!) + if (i === j) { + vjj = values[k]; + } else if (i < j) { + // store upper triangular + jValues.push(values[k]); + jIndices.push(i); + } + } + + // at this point we must have a value in vjj + if (equalScalar(vjj, 0)) { + throw new Error('Linear system cannot be solved since matrix is singular'); + } + var xj = divideScalar(bj, vjj); + for (var _k = 0, _lastIndex = jIndices.length; _k < _lastIndex; _k++) { + var _i = jIndices[_k]; + bdata[_i] = [subtractScalar(bdata[_i][0], multiplyScalar(xj, jValues[_k]))]; + } + x[j] = [xj]; + } else { + // degenerate row, we can choose any value + x[j] = [0]; + } + } + return new DenseMatrix({ + data: x, + size: [rows, 1] + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolveAll.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolveAll.js new file mode 100644 index 0000000..39366c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/usolveAll.js @@ -0,0 +1,190 @@ +import { factory } from '../../../utils/factory.js'; +import { createSolveValidation } from './utils/solveValidation.js'; +var name = 'usolveAll'; +var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix']; +export var createUsolveAll = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divideScalar, + multiplyScalar, + subtractScalar, + equalScalar, + DenseMatrix + } = _ref; + var solveValidation = createSolveValidation({ + DenseMatrix + }); + + /** + * Finds all solutions of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. + * + * `U * x = b` + * + * Syntax: + * + * math.usolveAll(U, b) + * + * Examples: + * + * const a = [[-2, 3], [2, 1]] + * const b = [11, 9] + * const x = usolveAll(a, b) // [ [[8], [9]] ] + * + * See also: + * + * usolve, lup, slu, usolve, lusolve + * + * @param {Matrix, Array} U A N x N matrix or array (U) + * @param {Matrix, Array} b A column vector with the b values + * + * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system + */ + return typed(name, { + 'SparseMatrix, Array | Matrix': function SparseMatrix_Array__Matrix(m, b) { + return _sparseBackwardSubstitution(m, b); + }, + 'DenseMatrix, Array | Matrix': function DenseMatrix_Array__Matrix(m, b) { + return _denseBackwardSubstitution(m, b); + }, + 'Array, Array | Matrix': function Array_Array__Matrix(a, b) { + var m = matrix(a); + var R = _denseBackwardSubstitution(m, b); + return R.map(r => r.valueOf()); + } + }); + function _denseBackwardSubstitution(m, b_) { + // the algorithm is derived from + // https://www.overleaf.com/read/csvgqdxggyjv + + // array of right-hand sides + var B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + var M = m._data; + var rows = m._size[0]; + var columns = m._size[1]; + + // loop columns backwards + for (var i = columns - 1; i >= 0; i--) { + var L = B.length; + + // loop right-hand sides + for (var k = 0; k < L; k++) { + var b = B[k]; + if (!equalScalar(M[i][i], 0)) { + // non-singular row + + b[i] = divideScalar(b[i], M[i][i]); + for (var j = i - 1; j >= 0; j--) { + // b[j] -= b[i] * M[j,i] + b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + var bNew = [...b]; + bNew[i] = 1; + for (var _j = i - 1; _j >= 0; _j--) { + bNew[_j] = subtractScalar(bNew[_j], M[_j][i]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } + function _sparseBackwardSubstitution(m, b_) { + // array of right-hand sides + var B = [solveValidation(m, b_, true)._data.map(e => e[0])]; + var rows = m._size[0]; + var columns = m._size[1]; + var values = m._values; + var index = m._index; + var ptr = m._ptr; + + // loop columns backwards + for (var i = columns - 1; i >= 0; i--) { + var L = B.length; + + // loop right-hand sides + for (var k = 0; k < L; k++) { + var b = B[k]; + + // values & indices (column i) + var iValues = []; + var iIndices = []; + + // first & last indeces in column + var firstIndex = ptr[i]; + var lastIndex = ptr[i + 1]; + + // find the value at [i, i] + var Mii = 0; + for (var j = lastIndex - 1; j >= firstIndex; j--) { + var J = index[j]; + // check row + if (J === i) { + Mii = values[j]; + } else if (J < i) { + // store upper triangular + iValues.push(values[j]); + iIndices.push(J); + } + } + if (!equalScalar(Mii, 0)) { + // non-singular row + + b[i] = divideScalar(b[i], Mii); + + // loop upper triangular + for (var _j2 = 0, _lastIndex = iIndices.length; _j2 < _lastIndex; _j2++) { + var _J = iIndices[_j2]; + b[_J] = subtractScalar(b[_J], multiplyScalar(b[i], iValues[_j2])); + } + } else if (!equalScalar(b[i], 0)) { + // singular row, nonzero RHS + + if (k === 0) { + // There is no valid solution + return []; + } else { + // This RHS is invalid but other solutions may still exist + B.splice(k, 1); + k -= 1; + L -= 1; + } + } else if (k === 0) { + // singular row, RHS is zero + + var bNew = [...b]; + bNew[i] = 1; + + // loop upper triangular + for (var _j3 = 0, _lastIndex2 = iIndices.length; _j3 < _lastIndex2; _j3++) { + var _J2 = iIndices[_j3]; + bNew[_J2] = subtractScalar(bNew[_J2], iValues[_j3]); + } + B.push(bNew); + } + } + } + return B.map(x => new DenseMatrix({ + data: x.map(e => [e]), + size: [rows, 1] + })); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/utils/solveValidation.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/utils/solveValidation.js new file mode 100644 index 0000000..42239a1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/solver/utils/solveValidation.js @@ -0,0 +1,115 @@ +import { isArray, isMatrix, isDenseMatrix, isSparseMatrix } from '../../../../utils/is.js'; +import { arraySize } from '../../../../utils/array.js'; +import { format } from '../../../../utils/string.js'; +export function createSolveValidation(_ref) { + var { + DenseMatrix + } = _ref; + /** + * Validates matrix and column vector b for backward/forward substitution algorithms. + * + * @param {Matrix} m An N x N matrix + * @param {Array | Matrix} b A column vector + * @param {Boolean} copy Return a copy of vector b + * + * @return {DenseMatrix} Dense column vector b + */ + return function solveValidation(m, b, copy) { + var mSize = m.size(); + if (mSize.length !== 2) { + throw new RangeError('Matrix must be two dimensional (size: ' + format(mSize) + ')'); + } + var rows = mSize[0]; + var columns = mSize[1]; + if (rows !== columns) { + throw new RangeError('Matrix must be square (size: ' + format(mSize) + ')'); + } + var data = []; + if (isMatrix(b)) { + var bSize = b.size(); + var bdata = b._data; + + // 1-dim vector + if (bSize.length === 1) { + if (bSize[0] !== rows) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (var i = 0; i < rows; i++) { + data[i] = [bdata[i]]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + + // 2-dim column + if (bSize.length === 2) { + if (bSize[0] !== rows || bSize[1] !== 1) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + if (isDenseMatrix(b)) { + if (copy) { + data = []; + for (var _i = 0; _i < rows; _i++) { + data[_i] = [bdata[_i][0]]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + return b; + } + if (isSparseMatrix(b)) { + for (var _i2 = 0; _i2 < rows; _i2++) { + data[_i2] = [0]; + } + var values = b._values; + var index = b._index; + var ptr = b._ptr; + for (var k1 = ptr[1], k = ptr[0]; k < k1; k++) { + var _i3 = index[k]; + data[_i3][0] = values[k]; + } + return new DenseMatrix({ + data, + size: [rows, 1], + datatype: b._datatype + }); + } + } + throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.'); + } + if (isArray(b)) { + var bsize = arraySize(b); + if (bsize.length === 1) { + if (bsize[0] !== rows) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (var _i4 = 0; _i4 < rows; _i4++) { + data[_i4] = [b[_i4]]; + } + return new DenseMatrix({ + data, + size: [rows, 1] + }); + } + if (bsize.length === 2) { + if (bsize[0] !== rows || bsize[1] !== 1) { + throw new RangeError('Dimension mismatch. Matrix columns must match vector length.'); + } + for (var _i5 = 0; _i5 < rows; _i5++) { + data[_i5] = [b[_i5][0]]; + } + return new DenseMatrix({ + data, + size: [rows, 1] + }); + } + throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.'); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csAmd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csAmd.js new file mode 100644 index 0000000..c83299c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csAmd.js @@ -0,0 +1,580 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { factory } from '../../../utils/factory.js'; +import { csFkeep } from './csFkeep.js'; +import { csFlip } from './csFlip.js'; +import { csTdfs } from './csTdfs.js'; +var name = 'csAmd'; +var dependencies = ['add', 'multiply', 'transpose']; +export var createCsAmd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + add, + multiply, + transpose + } = _ref; + /** + * Approximate minimum degree ordering. The minimum degree algorithm is a widely used + * heuristic for finding a permutation P so that P*A*P' has fewer nonzeros in its factorization + * than A. It is a gready method that selects the sparsest pivot row and column during the course + * of a right looking sparse Cholesky factorization. + * + * @param {Number} order 0: Natural, 1: Cholesky, 2: LU, 3: QR + * @param {Matrix} m Sparse Matrix + */ + return function csAmd(order, a) { + // check input parameters + if (!a || order <= 0 || order > 3) { + return null; + } + // a matrix arrays + var asize = a._size; + // rows and columns + var m = asize[0]; + var n = asize[1]; + // initialize vars + var lemax = 0; + // dense threshold + var dense = Math.max(16, 10 * Math.sqrt(n)); + dense = Math.min(n - 2, dense); + // create target matrix C + var cm = _createTargetMatrix(order, a, m, n, dense); + // drop diagonal entries + csFkeep(cm, _diag, null); + // C matrix arrays + var cindex = cm._index; + var cptr = cm._ptr; + + // number of nonzero elements in C + var cnz = cptr[n]; + + // allocate result (n+1) + var P = []; + + // create workspace (8 * (n + 1)) + var W = []; + var len = 0; // first n + 1 entries + var nv = n + 1; // next n + 1 entries + var next = 2 * (n + 1); // next n + 1 entries + var head = 3 * (n + 1); // next n + 1 entries + var elen = 4 * (n + 1); // next n + 1 entries + var degree = 5 * (n + 1); // next n + 1 entries + var w = 6 * (n + 1); // next n + 1 entries + var hhead = 7 * (n + 1); // last n + 1 entries + + // use P as workspace for last + var last = P; + + // initialize quotient graph + var mark = _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree); + + // initialize degree lists + var nel = _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next); + + // minimum degree node + var mindeg = 0; + + // vars + var i, j, k, k1, k2, e, pj, ln, nvi, pk, eln, p1, p2, pn, h, d; + + // while (selecting pivots) do + while (nel < n) { + // select node of minimum approximate degree. amd() is now ready to start eliminating the graph. It first + // finds a node k of minimum degree and removes it from its degree list. The variable nel keeps track of thow + // many nodes have been eliminated. + for (k = -1; mindeg < n && (k = W[head + mindeg]) === -1; mindeg++); + if (W[next + k] !== -1) { + last[W[next + k]] = -1; + } + // remove k from degree list + W[head + mindeg] = W[next + k]; + // elenk = |Ek| + var elenk = W[elen + k]; + // # of nodes k represents + var nvk = W[nv + k]; + // W[nv + k] nodes of A eliminated + nel += nvk; + + // Construct a new element. The new element Lk is constructed in place if |Ek| = 0. nv[i] is + // negated for all nodes i in Lk to flag them as members of this set. Each node i is removed from the + // degree lists. All elements e in Ek are absorved into element k. + var dk = 0; + // flag k as in Lk + W[nv + k] = -nvk; + var p = cptr[k]; + // do in place if W[elen + k] === 0 + var pk1 = elenk === 0 ? p : cnz; + var pk2 = pk1; + for (k1 = 1; k1 <= elenk + 1; k1++) { + if (k1 > elenk) { + // search the nodes in k + e = k; + // list of nodes starts at cindex[pj] + pj = p; + // length of list of nodes in k + ln = W[len + k] - elenk; + } else { + // search the nodes in e + e = cindex[p++]; + pj = cptr[e]; + // length of list of nodes in e + ln = W[len + e]; + } + for (k2 = 1; k2 <= ln; k2++) { + i = cindex[pj++]; + // check node i dead, or seen + if ((nvi = W[nv + i]) <= 0) { + continue; + } + // W[degree + Lk] += size of node i + dk += nvi; + // negate W[nv + i] to denote i in Lk + W[nv + i] = -nvi; + // place i in Lk + cindex[pk2++] = i; + if (W[next + i] !== -1) { + last[W[next + i]] = last[i]; + } + // check we need to remove i from degree list + if (last[i] !== -1) { + W[next + last[i]] = W[next + i]; + } else { + W[head + W[degree + i]] = W[next + i]; + } + } + if (e !== k) { + // absorb e into k + cptr[e] = csFlip(k); + // e is now a dead element + W[w + e] = 0; + } + } + // cindex[cnz...nzmax] is free + if (elenk !== 0) { + cnz = pk2; + } + // external degree of k - |Lk\i| + W[degree + k] = dk; + // element k is in cindex[pk1..pk2-1] + cptr[k] = pk1; + W[len + k] = pk2 - pk1; + // k is now an element + W[elen + k] = -2; + + // Find set differences. The scan1 function now computes the set differences |Le \ Lk| for all elements e. At the start of the + // scan, no entry in the w array is greater than or equal to mark. + + // clear w if necessary + mark = _wclear(mark, lemax, W, w, n); + // scan 1: find |Le\Lk| + for (pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check if W[elen + i] empty, skip it + if ((eln = W[elen + i]) <= 0) { + continue; + } + // W[nv + i] was negated + nvi = -W[nv + i]; + var wnvi = mark - nvi; + // scan Ei + for (p = cptr[i], p1 = cptr[i] + eln - 1; p <= p1; p++) { + e = cindex[p]; + if (W[w + e] >= mark) { + // decrement |Le\Lk| + W[w + e] -= nvi; + } else if (W[w + e] !== 0) { + // ensure e is a live element, 1st time e seen in scan 1 + W[w + e] = W[degree + e] + wnvi; + } + } + } + + // degree update + // The second pass computes the approximate degree di, prunes the sets Ei and Ai, and computes a hash + // function h(i) for all nodes in Lk. + + // scan2: degree update + for (pk = pk1; pk < pk2; pk++) { + // consider node i in Lk + i = cindex[pk]; + p1 = cptr[i]; + p2 = p1 + W[elen + i] - 1; + pn = p1; + // scan Ei + for (h = 0, d = 0, p = p1; p <= p2; p++) { + e = cindex[p]; + // check e is an unabsorbed element + if (W[w + e] !== 0) { + // dext = |Le\Lk| + var dext = W[w + e] - mark; + if (dext > 0) { + // sum up the set differences + d += dext; + // keep e in Ei + cindex[pn++] = e; + // compute the hash of node i + h += e; + } else { + // aggressive absorb. e->k + cptr[e] = csFlip(k); + // e is a dead element + W[w + e] = 0; + } + } + } + // W[elen + i] = |Ei| + W[elen + i] = pn - p1 + 1; + var p3 = pn; + var p4 = p1 + W[len + i]; + // prune edges in Ai + for (p = p2 + 1; p < p4; p++) { + j = cindex[p]; + // check node j dead or in Lk + var nvj = W[nv + j]; + if (nvj <= 0) { + continue; + } + // degree(i) += |j| + d += nvj; + // place j in node list of i + cindex[pn++] = j; + // compute hash for node i + h += j; + } + // check for mass elimination + if (d === 0) { + // absorb i into k + cptr[i] = csFlip(k); + nvi = -W[nv + i]; + // |Lk| -= |i| + dk -= nvi; + // |k| += W[nv + i] + nvk += nvi; + nel += nvi; + W[nv + i] = 0; + // node i is dead + W[elen + i] = -1; + } else { + // update degree(i) + W[degree + i] = Math.min(W[degree + i], d); + // move first node to end + cindex[pn] = cindex[p3]; + // move 1st el. to end of Ei + cindex[p3] = cindex[p1]; + // add k as 1st element in of Ei + cindex[p1] = k; + // new len of adj. list of node i + W[len + i] = pn - p1 + 1; + // finalize hash of i + h = (h < 0 ? -h : h) % n; + // place i in hash bucket + W[next + i] = W[hhead + h]; + W[hhead + h] = i; + // save hash of i in last[i] + last[i] = h; + } + } + // finalize |Lk| + W[degree + k] = dk; + lemax = Math.max(lemax, dk); + // clear w + mark = _wclear(mark + lemax, lemax, W, w, n); + + // Supernode detection. Supernode detection relies on the hash function h(i) computed for each node i. + // If two nodes have identical adjacency lists, their hash functions wil be identical. + for (pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check i is dead, skip it + if (W[nv + i] >= 0) { + continue; + } + // scan hash bucket of node i + h = last[i]; + i = W[hhead + h]; + // hash bucket will be empty + W[hhead + h] = -1; + for (; i !== -1 && W[next + i] !== -1; i = W[next + i], mark++) { + ln = W[len + i]; + eln = W[elen + i]; + for (p = cptr[i] + 1; p <= cptr[i] + ln - 1; p++) { + W[w + cindex[p]] = mark; + } + var jlast = i; + // compare i with all j + for (j = W[next + i]; j !== -1;) { + var ok = W[len + j] === ln && W[elen + j] === eln; + for (p = cptr[j] + 1; ok && p <= cptr[j] + ln - 1; p++) { + // compare i and j + if (W[w + cindex[p]] !== mark) { + ok = 0; + } + } + // check i and j are identical + if (ok) { + // absorb j into i + cptr[j] = csFlip(i); + W[nv + i] += W[nv + j]; + W[nv + j] = 0; + // node j is dead + W[elen + j] = -1; + // delete j from hash bucket + j = W[next + j]; + W[next + jlast] = j; + } else { + // j and i are different + jlast = j; + j = W[next + j]; + } + } + } + } + + // Finalize new element. The elimination of node k is nearly complete. All nodes i in Lk are scanned one last time. + // Node i is removed from Lk if it is dead. The flagged status of nv[i] is cleared. + for (p = pk1, pk = pk1; pk < pk2; pk++) { + i = cindex[pk]; + // check i is dead, skip it + if ((nvi = -W[nv + i]) <= 0) { + continue; + } + // restore W[nv + i] + W[nv + i] = nvi; + // compute external degree(i) + d = W[degree + i] + dk - nvi; + d = Math.min(d, n - nel - nvi); + if (W[head + d] !== -1) { + last[W[head + d]] = i; + } + // put i back in degree list + W[next + i] = W[head + d]; + last[i] = -1; + W[head + d] = i; + // find new minimum degree + mindeg = Math.min(mindeg, d); + W[degree + i] = d; + // place i in Lk + cindex[p++] = i; + } + // # nodes absorbed into k + W[nv + k] = nvk; + // length of adj list of element k + if ((W[len + k] = p - pk1) === 0) { + // k is a root of the tree + cptr[k] = -1; + // k is now a dead element + W[w + k] = 0; + } + if (elenk !== 0) { + // free unused space in Lk + cnz = p; + } + } + + // Postordering. The elimination is complete, but no permutation has been computed. All that is left + // of the graph is the assembly tree (ptr) and a set of dead nodes and elements (i is a dead node if + // nv[i] is zero and a dead element if nv[i] > 0). It is from this information only that the final permutation + // is computed. The tree is restored by unflipping all of ptr. + + // fix assembly tree + for (i = 0; i < n; i++) { + cptr[i] = csFlip(cptr[i]); + } + for (j = 0; j <= n; j++) { + W[head + j] = -1; + } + // place unordered nodes in lists + for (j = n; j >= 0; j--) { + // skip if j is an element + if (W[nv + j] > 0) { + continue; + } + // place j in list of its parent + W[next + j] = W[head + cptr[j]]; + W[head + cptr[j]] = j; + } + // place elements in lists + for (e = n; e >= 0; e--) { + // skip unless e is an element + if (W[nv + e] <= 0) { + continue; + } + if (cptr[e] !== -1) { + // place e in list of its parent + W[next + e] = W[head + cptr[e]]; + W[head + cptr[e]] = e; + } + } + // postorder the assembly tree + for (k = 0, i = 0; i <= n; i++) { + if (cptr[i] === -1) { + k = csTdfs(i, k, W, head, next, P, w); + } + } + // remove last item in array + P.splice(P.length - 1, 1); + // return P + return P; + }; + + /** + * Creates the matrix that will be used by the approximate minimum degree ordering algorithm. The function accepts the matrix M as input and returns a permutation + * vector P. The amd algorithm operates on a symmetrix matrix, so one of three symmetric matrices is formed. + * + * Order: 0 + * A natural ordering P=null matrix is returned. + * + * Order: 1 + * Matrix must be square. This is appropriate for a Cholesky or LU factorization. + * P = M + M' + * + * Order: 2 + * Dense columns from M' are dropped, M recreated from M'. This is appropriatefor LU factorization of unsymmetric matrices. + * P = M' * M + * + * Order: 3 + * This is best used for QR factorization or LU factorization is matrix M has no dense rows. A dense row is a row with more than 10*sqr(columns) entries. + * P = M' * M + */ + function _createTargetMatrix(order, a, m, n, dense) { + // compute A' + var at = transpose(a); + + // check order = 1, matrix must be square + if (order === 1 && n === m) { + // C = A + A' + return add(a, at); + } + + // check order = 2, drop dense columns from M' + if (order === 2) { + // transpose arrays + var tindex = at._index; + var tptr = at._ptr; + // new column index + var p2 = 0; + // loop A' columns (rows) + for (var j = 0; j < m; j++) { + // column j of AT starts here + var p = tptr[j]; + // new column j starts here + tptr[j] = p2; + // skip dense col j + if (tptr[j + 1] - p > dense) { + continue; + } + // map rows in column j of A + for (var p1 = tptr[j + 1]; p < p1; p++) { + tindex[p2++] = tindex[p]; + } + } + // finalize AT + tptr[m] = p2; + // recreate A from new transpose matrix + a = transpose(at); + // use A' * A + return multiply(at, a); + } + + // use A' * A, square or rectangular matrix + return multiply(at, a); + } + + /** + * Initialize quotient graph. There are four kind of nodes and elements that must be represented: + * + * - A live node is a node i (or a supernode) that has not been selected as a pivot nad has not been merged into another supernode. + * - A dead node i is one that has been removed from the graph, having been absorved into r = flip(ptr[i]). + * - A live element e is one that is in the graph, having been formed when node e was selected as the pivot. + * - A dead element e is one that has benn absorved into a subsequent element s = flip(ptr[e]). + */ + function _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree) { + // Initialize quotient graph + for (var k = 0; k < n; k++) { + W[len + k] = cptr[k + 1] - cptr[k]; + } + W[len + n] = 0; + // initialize workspace + for (var i = 0; i <= n; i++) { + // degree list i is empty + W[head + i] = -1; + last[i] = -1; + W[next + i] = -1; + // hash list i is empty + W[hhead + i] = -1; + // node i is just one node + W[nv + i] = 1; + // node i is alive + W[w + i] = 1; + // Ek of node i is empty + W[elen + i] = 0; + // degree of node i + W[degree + i] = W[len + i]; + } + // clear w + var mark = _wclear(0, 0, W, w, n); + // n is a dead element + W[elen + n] = -2; + // n is a root of assembly tree + cptr[n] = -1; + // n is a dead element + W[w + n] = 0; + // return mark + return mark; + } + + /** + * Initialize degree lists. Each node is placed in its degree lists. Nodes of zero degree are eliminated immediately. Nodes with + * degree >= dense are alsol eliminated and merged into a placeholder node n, a dead element. Thes nodes will appera last in the + * output permutation p. + */ + function _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next) { + // result + var nel = 0; + // loop columns + for (var i = 0; i < n; i++) { + // degree @ i + var d = W[degree + i]; + // check node i is empty + if (d === 0) { + // element i is dead + W[elen + i] = -2; + nel++; + // i is a root of assembly tree + cptr[i] = -1; + W[w + i] = 0; + } else if (d > dense) { + // absorb i into element n + W[nv + i] = 0; + // node i is dead + W[elen + i] = -1; + nel++; + cptr[i] = csFlip(n); + W[nv + n]++; + } else { + var h = W[head + d]; + if (h !== -1) { + last[h] = i; + } + // put node i in degree list d + W[next + i] = W[head + d]; + W[head + d] = i; + } + } + return nel; + } + function _wclear(mark, lemax, W, w, n) { + if (mark < 2 || mark + lemax < 0) { + for (var k = 0; k < n; k++) { + if (W[w + k] !== 0) { + W[w + k] = 1; + } + } + mark = 2; + } + // at this point, W [0..n-1] < mark holds + return mark; + } + function _diag(i, j) { + return i !== j; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csChol.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csChol.js new file mode 100644 index 0000000..3ea2422 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csChol.js @@ -0,0 +1,157 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { factory } from '../../../utils/factory.js'; +import { csEreach } from './csEreach.js'; +import { createCsSymperm } from './csSymperm.js'; +var name = 'csChol'; +var dependencies = ['divideScalar', 'sqrt', 'subtract', 'multiply', 'im', 're', 'conj', 'equal', 'smallerEq', 'SparseMatrix']; +export var createCsChol = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + divideScalar, + sqrt, + subtract, + multiply, + im, + re, + conj, + equal, + smallerEq, + SparseMatrix + } = _ref; + var csSymperm = createCsSymperm({ + conj, + SparseMatrix + }); + + /** + * Computes the Cholesky factorization of matrix A. It computes L and P so + * L * L' = P * A * P' + * + * @param {Matrix} m The A Matrix to factorize, only upper triangular part used + * @param {Object} s The symbolic analysis from cs_schol() + * + * @return {Number} The numeric Cholesky factorization of A or null + */ + return function csChol(m, s) { + // validate input + if (!m) { + return null; + } + // m arrays + var size = m._size; + // columns + var n = size[1]; + // symbolic analysis result + var parent = s.parent; + var cp = s.cp; + var pinv = s.pinv; + // L arrays + var lvalues = []; + var lindex = []; + var lptr = []; + // L + var L = new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: [n, n] + }); + // vars + var c = []; // (2 * n) + var x = []; // (n) + // compute C = P * A * P' + var cm = pinv ? csSymperm(m, pinv, 1) : m; + // C matrix arrays + var cvalues = cm._values; + var cindex = cm._index; + var cptr = cm._ptr; + // vars + var k, p; + // initialize variables + for (k = 0; k < n; k++) { + lptr[k] = c[k] = cp[k]; + } + // compute L(k,:) for L*L' = C + for (k = 0; k < n; k++) { + // nonzero pattern of L(k,:) + var top = csEreach(cm, k, parent, c); + // x (0:k) is now zero + x[k] = 0; + // x = full(triu(C(:,k))) + for (p = cptr[k]; p < cptr[k + 1]; p++) { + if (cindex[p] <= k) { + x[cindex[p]] = cvalues[p]; + } + } + // d = C(k,k) + var d = x[k]; + // clear x for k+1st iteration + x[k] = 0; + // solve L(0:k-1,0:k-1) * x = C(:,k) + for (; top < n; top++) { + // s[top..n-1] is pattern of L(k,:) + var i = s[top]; + // L(k,i) = x (i) / L(i,i) + var lki = divideScalar(x[i], lvalues[lptr[i]]); + // clear x for k+1st iteration + x[i] = 0; + for (p = lptr[i] + 1; p < c[i]; p++) { + // row + var r = lindex[p]; + // update x[r] + x[r] = subtract(x[r], multiply(lvalues[p], lki)); + } + // d = d - L(k,i)*L(k,i) + d = subtract(d, multiply(lki, conj(lki))); + p = c[i]++; + // store L(k,i) in column i + lindex[p] = k; + lvalues[p] = conj(lki); + } + // compute L(k,k) + if (smallerEq(re(d), 0) || !equal(im(d), 0)) { + // not pos def + return null; + } + p = c[k]++; + // store L(k,k) = sqrt(d) in column k + lindex[p] = k; + lvalues[p] = sqrt(d); + } + // finalize L + lptr[n] = cp[n]; + // P matrix + var P; + // check we need to calculate P + if (pinv) { + // P arrays + var pvalues = []; + var pindex = []; + var pptr = []; + // create P matrix + for (p = 0; p < n; p++) { + // initialize ptr (one value per column) + pptr[p] = p; + // index (apply permutation vector) + pindex.push(pinv[p]); + // value 1 + pvalues.push(1); + } + // update ptr + pptr[n] = n; + // P + P = new SparseMatrix({ + values: pvalues, + index: pindex, + ptr: pptr, + size: [n, n] + }); + } + // return L & P + return { + L, + P + }; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCounts.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCounts.js new file mode 100644 index 0000000..9eaa2bd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCounts.js @@ -0,0 +1,126 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { factory } from '../../../utils/factory.js'; +import { csLeaf } from './csLeaf.js'; +var name = 'csCounts'; +var dependencies = ['transpose']; +export var createCsCounts = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + transpose + } = _ref; + /** + * Computes the column counts using the upper triangular part of A. + * It transposes A internally, none of the input parameters are modified. + * + * @param {Matrix} a The sparse matrix A + * + * @param {Matrix} ata Count the columns of A'A instead + * + * @return An array of size n of the column counts or null on error + */ + return function (a, parent, post, ata) { + // check inputs + if (!a || !parent || !post) { + return null; + } + // a matrix arrays + var asize = a._size; + // rows and columns + var m = asize[0]; + var n = asize[1]; + // variables + var i, j, k, J, p, p0, p1; + + // workspace size + var s = 4 * n + (ata ? n + m + 1 : 0); + // allocate workspace + var w = []; // (s) + var ancestor = 0; // first n entries + var maxfirst = n; // next n entries + var prevleaf = 2 * n; // next n entries + var first = 3 * n; // next n entries + var head = 4 * n; // next n + 1 entries (used when ata is true) + var next = 5 * n + 1; // last entries in workspace + // clear workspace w[0..s-1] + for (k = 0; k < s; k++) { + w[k] = -1; + } + + // allocate result + var colcount = []; // (n) + + // AT = A' + var at = transpose(a); + // at arrays + var tindex = at._index; + var tptr = at._ptr; + + // find w[first + j] + for (k = 0; k < n; k++) { + j = post[k]; + // colcount[j]=1 if j is a leaf + colcount[j] = w[first + j] === -1 ? 1 : 0; + for (; j !== -1 && w[first + j] === -1; j = parent[j]) { + w[first + j] = k; + } + } + + // initialize ata if needed + if (ata) { + // invert post + for (k = 0; k < n; k++) { + w[post[k]] = k; + } + // loop rows (columns in AT) + for (i = 0; i < m; i++) { + // values in column i of AT + for (k = n, p0 = tptr[i], p1 = tptr[i + 1], p = p0; p < p1; p++) { + k = Math.min(k, w[tindex[p]]); + } + // place row i in linked list k + w[next + i] = w[head + k]; + w[head + k] = i; + } + } + + // each node in its own set + for (i = 0; i < n; i++) { + w[ancestor + i] = i; + } + for (k = 0; k < n; k++) { + // j is the kth node in postordered etree + j = post[k]; + // check j is not a root + if (parent[j] !== -1) { + colcount[parent[j]]--; + } + + // J=j for LL'=A case + for (J = ata ? w[head + k] : j; J !== -1; J = ata ? w[next + J] : -1) { + for (p = tptr[J]; p < tptr[J + 1]; p++) { + i = tindex[p]; + var r = csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor); + // check A(i,j) is in skeleton + if (r.jleaf >= 1) { + colcount[j]++; + } + // check account for overlap in q + if (r.jleaf === 2) { + colcount[r.q]--; + } + } + } + if (parent[j] !== -1) { + w[ancestor + j] = parent[j]; + } + } + // sum up colcount's of each child + for (j = 0; j < n; j++) { + if (parent[j] !== -1) { + colcount[parent[j]] += colcount[j]; + } + } + return colcount; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCumsum.js new file mode 100644 index 0000000..1c89ada --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csCumsum.js @@ -0,0 +1,28 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * It sets the p[i] equal to the sum of c[0] through c[i-1]. + * + * @param {Array} ptr The Sparse Matrix ptr array + * @param {Array} c The Sparse Matrix ptr array + * @param {Number} n The number of columns + */ +export function csCumsum(ptr, c, n) { + // variables + var i; + var nz = 0; + for (i = 0; i < n; i++) { + // initialize ptr @ i + ptr[i] = nz; + // increment number of nonzeros + nz += c[i]; + // also copy p[0..n-1] back into c[0..n-1] + c[i] = ptr[i]; + } + // finalize ptr + ptr[n] = nz; + // return sum (c [0..n-1]) + return nz; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csDfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csDfs.js new file mode 100644 index 0000000..79e3f96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csDfs.js @@ -0,0 +1,76 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csMarked } from './csMarked.js'; +import { csMark } from './csMark.js'; +import { csUnflip } from './csUnflip.js'; + +/** + * Depth-first search computes the nonzero pattern xi of the directed graph G (Matrix) starting + * at nodes in B (see csReach()). + * + * @param {Number} j The starting node for the DFS algorithm + * @param {Matrix} g The G matrix to search, ptr array modified, then restored + * @param {Number} top Start index in stack xi[top..n-1] + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b + * + * @return {Number} New value of top + */ +export function csDfs(j, g, top, xi, pinv) { + // g arrays + var index = g._index; + var ptr = g._ptr; + var size = g._size; + // columns + var n = size[1]; + // vars + var i, p, p2; + // initialize head + var head = 0; + // initialize the recursion stack + xi[0] = j; + // loop + while (head >= 0) { + // get j from the top of the recursion stack + j = xi[head]; + // apply permutation vector + var jnew = pinv ? pinv[j] : j; + // check node j is marked + if (!csMarked(ptr, j)) { + // mark node j as visited + csMark(ptr, j); + // update stack (last n entries in xi) + xi[n + head] = jnew < 0 ? 0 : csUnflip(ptr[jnew]); + } + // node j done if no unvisited neighbors + var done = 1; + // examine all neighbors of j, stack (last n entries in xi) + for (p = xi[n + head], p2 = jnew < 0 ? 0 : csUnflip(ptr[jnew + 1]); p < p2; p++) { + // consider neighbor node i + i = index[p]; + // check we have visited node i, skip it + if (csMarked(ptr, i)) { + continue; + } + // pause depth-first search of node j, update stack (last n entries in xi) + xi[n + head] = p; + // start dfs at node i + xi[++head] = i; + // node j is not done + done = 0; + // break, to start dfs(i) + break; + } + // check depth-first search at node j is done + if (done) { + // remove j from the recursion stack + head--; + // and place in the output stack + xi[--top] = j; + } + } + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEreach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEreach.js new file mode 100644 index 0000000..3d16615 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEreach.js @@ -0,0 +1,63 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csMark } from './csMark.js'; +import { csMarked } from './csMarked.js'; + +/** + * Find nonzero pattern of Cholesky L(k,1:k-1) using etree and triu(A(:,k)) + * + * @param {Matrix} a The A matrix + * @param {Number} k The kth column in A + * @param {Array} parent The parent vector from the symbolic analysis result + * @param {Array} w The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * + * @return {Number} The index for the nonzero pattern + */ +export function csEreach(a, k, parent, w) { + // a arrays + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + // columns + var n = asize[1]; + // initialize top + var top = n; + // vars + var p, p0, p1, len; + // mark node k as visited + csMark(w, k); + // loop values & index for column k + for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // A(i,k) is nonzero + var i = aindex[p]; + // only use upper triangular part of A + if (i > k) { + continue; + } + // traverse up etree + for (len = 0; !csMarked(w, i); i = parent[i]) { + // L(k,i) is nonzero, last n entries in w + w[n + len++] = i; + // mark i as visited + csMark(w, i); + } + while (len > 0) { + // decrement top & len + --top; + --len; + // push path onto stack, last n entries in w + w[n + top] = w[n + len]; + } + } + // unmark all nodes + for (p = top; p < n; p++) { + // use stack value, last n entries in w + csMark(w, w[n + p]); + } + // unmark node k + csMark(w, k); + // s[top..n-1] contains pattern of L(k,:) + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEtree.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEtree.js new file mode 100644 index 0000000..0b0b29c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csEtree.js @@ -0,0 +1,71 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Computes the elimination tree of Matrix A (using triu(A)) or the + * elimination tree of A'A without forming A'A. + * + * @param {Matrix} a The A Matrix + * @param {boolean} ata A value of true the function computes the etree of A'A + */ +export function csEtree(a, ata) { + // check inputs + if (!a) { + return null; + } + // a arrays + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + // rows & columns + var m = asize[0]; + var n = asize[1]; + + // allocate result + var parent = []; // (n) + + // allocate workspace + var w = []; // (n + (ata ? m : 0)) + var ancestor = 0; // first n entries in w + var prev = n; // last m entries (ata = true) + + var i, inext; + + // check we are calculating A'A + if (ata) { + // initialize workspace + for (i = 0; i < m; i++) { + w[prev + i] = -1; + } + } + // loop columns + for (var k = 0; k < n; k++) { + // node k has no parent yet + parent[k] = -1; + // nor does k have an ancestor + w[ancestor + k] = -1; + // values in column k + for (var p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // row + var r = aindex[p]; + // node + i = ata ? w[prev + r] : r; + // traverse from i to k + for (; i !== -1 && i < k; i = inext) { + // inext = ancestor of i + inext = w[ancestor + i]; + // path compression + w[ancestor + i] = k; + // check no anc., parent is k + if (inext === -1) { + parent[i] = k; + } + } + if (ata) { + w[prev + r] = k; + } + } + } + return parent; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFkeep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFkeep.js new file mode 100644 index 0000000..cd1e003 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFkeep.js @@ -0,0 +1,58 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Keeps entries in the matrix when the callback function returns true, removes the entry otherwise + * + * @param {Matrix} a The sparse matrix + * @param {function} callback The callback function, function will be invoked with the following args: + * - The entry row + * - The entry column + * - The entry value + * - The state parameter + * @param {any} other The state + * + * @return The number of nonzero elements in the matrix + */ +export function csFkeep(a, callback, other) { + // a arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + // columns + var n = asize[1]; + // nonzero items + var nz = 0; + // loop columns + for (var j = 0; j < n; j++) { + // get current location of col j + var p = aptr[j]; + // record new location of col j + aptr[j] = nz; + for (; p < aptr[j + 1]; p++) { + // check we need to keep this item + if (callback(aindex[p], j, avalues ? avalues[p] : 1, other)) { + // keep A(i,j) + aindex[nz] = aindex[p]; + // check we need to process values (pattern only) + if (avalues) { + avalues[nz] = avalues[p]; + } + // increment nonzero items + nz++; + } + } + } + // finalize A + aptr[n] = nz; + // trim arrays + aindex.splice(nz, aindex.length - nz); + // check we need to process values (pattern only) + if (avalues) { + avalues.splice(nz, avalues.length - nz); + } + // return number of nonzero items + return nz; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFlip.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFlip.js new file mode 100644 index 0000000..f375c03 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csFlip.js @@ -0,0 +1,13 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * This function "flips" its input about the integer -1. + * + * @param {Number} i The value to flip + */ +export function csFlip(i) { + // flip the value + return -i - 2; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csIpvec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csIpvec.js new file mode 100644 index 0000000..8a4eb24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csIpvec.js @@ -0,0 +1,33 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Permutes a vector; x = P'b. In MATLAB notation, x(p)=b. + * + * @param {Array} p The permutation vector of length n. null value denotes identity + * @param {Array} b The input vector + * + * @return {Array} The output vector x = P'b + */ +export function csIpvec(p, b) { + // vars + var k; + var n = b.length; + var x = []; + // check permutation vector was provided, p = null denotes identity + if (p) { + // loop vector + for (k = 0; k < n; k++) { + // apply permutation + x[p[k]] = b[k]; + } + } else { + // loop vector + for (k = 0; k < n; k++) { + // x[i] = b[i] + x[k] = b[k]; + } + } + return x; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLeaf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLeaf.js new file mode 100644 index 0000000..9b23e52 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLeaf.js @@ -0,0 +1,56 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * This function determines if j is a leaf of the ith row subtree. + * Consider A(i,j), node j in ith row subtree and return lca(jprev,j) + * + * @param {Number} i The ith row subtree + * @param {Number} j The node to test + * @param {Array} w The workspace array + * @param {Number} first The index offset within the workspace for the first array + * @param {Number} maxfirst The index offset within the workspace for the maxfirst array + * @param {Number} prevleaf The index offset within the workspace for the prevleaf array + * @param {Number} ancestor The index offset within the workspace for the ancestor array + * + * @return {Object} + */ +export function csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor) { + var s, sparent; + + // our result + var jleaf = 0; + var q; + + // check j is a leaf + if (i <= j || w[first + j] <= w[maxfirst + i]) { + return -1; + } + // update max first[j] seen so far + w[maxfirst + i] = w[first + j]; + // jprev = previous leaf of ith subtree + var jprev = w[prevleaf + i]; + w[prevleaf + i] = j; + + // check j is first or subsequent leaf + if (jprev === -1) { + // 1st leaf, q = root of ith subtree + jleaf = 1; + q = i; + } else { + // update jleaf + jleaf = 2; + // q = least common ancester (jprev,j) + for (q = jprev; q !== w[ancestor + q]; q = w[ancestor + q]); + for (s = jprev; s !== q; s = sparent) { + // path compression + sparent = w[ancestor + s]; + w[ancestor + s] = q; + } + } + return { + jleaf, + q + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLu.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLu.js new file mode 100644 index 0000000..544f4fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csLu.js @@ -0,0 +1,182 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +import { factory } from '../../../utils/factory.js'; +import { createCsSpsolve } from './csSpsolve.js'; +var name = 'csLu'; +var dependencies = ['abs', 'divideScalar', 'multiply', 'subtract', 'larger', 'largerEq', 'SparseMatrix']; +export var createCsLu = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + abs, + divideScalar, + multiply, + subtract, + larger, + largerEq, + SparseMatrix + } = _ref; + var csSpsolve = createCsSpsolve({ + divideScalar, + multiply, + subtract + }); + + /** + * Computes the numeric LU factorization of the sparse matrix A. Implements a Left-looking LU factorization + * algorithm that computes L and U one column at a tume. At the kth step, it access columns 1 to k-1 of L + * and column k of A. Given the fill-reducing column ordering q (see parameter s) computes L, U and pinv so + * L * U = A(p, q), where p is the inverse of pinv. + * + * @param {Matrix} m The A Matrix to factorize + * @param {Object} s The symbolic analysis from csSqr(). Provides the fill-reducing + * column ordering q + * @param {Number} tol Partial pivoting threshold (1 for partial pivoting) + * + * @return {Number} The numeric LU factorization of A or null + */ + return function csLu(m, s, tol) { + // validate input + if (!m) { + return null; + } + // m arrays + var size = m._size; + // columns + var n = size[1]; + // symbolic analysis result + var q; + var lnz = 100; + var unz = 100; + // update symbolic analysis parameters + if (s) { + q = s.q; + lnz = s.lnz || lnz; + unz = s.unz || unz; + } + // L arrays + var lvalues = []; // (lnz) + var lindex = []; // (lnz) + var lptr = []; // (n + 1) + // L + var L = new SparseMatrix({ + values: lvalues, + index: lindex, + ptr: lptr, + size: [n, n] + }); + // U arrays + var uvalues = []; // (unz) + var uindex = []; // (unz) + var uptr = []; // (n + 1) + // U + var U = new SparseMatrix({ + values: uvalues, + index: uindex, + ptr: uptr, + size: [n, n] + }); + // inverse of permutation vector + var pinv = []; // (n) + // vars + var i, p; + // allocate arrays + var x = []; // (n) + var xi = []; // (2 * n) + // initialize variables + for (i = 0; i < n; i++) { + // clear workspace + x[i] = 0; + // no rows pivotal yet + pinv[i] = -1; + // no cols of L yet + lptr[i + 1] = 0; + } + // reset number of nonzero elements in L and U + lnz = 0; + unz = 0; + // compute L(:,k) and U(:,k) + for (var k = 0; k < n; k++) { + // update ptr + lptr[k] = lnz; + uptr[k] = unz; + // apply column permutations if needed + var col = q ? q[k] : k; + // solve triangular system, x = L\A(:,col) + var top = csSpsolve(L, m, col, xi, x, pinv, 1); + // find pivot + var ipiv = -1; + var a = -1; + // loop xi[] from top -> n + for (p = top; p < n; p++) { + // x[i] is nonzero + i = xi[p]; + // check row i is not yet pivotal + if (pinv[i] < 0) { + // absolute value of x[i] + var xabs = abs(x[i]); + // check absoulte value is greater than pivot value + if (larger(xabs, a)) { + // largest pivot candidate so far + a = xabs; + ipiv = i; + } + } else { + // x(i) is the entry U(pinv[i],k) + uindex[unz] = pinv[i]; + uvalues[unz++] = x[i]; + } + } + // validate we found a valid pivot + if (ipiv === -1 || a <= 0) { + return null; + } + // update actual pivot column, give preference to diagonal value + if (pinv[col] < 0 && largerEq(abs(x[col]), multiply(a, tol))) { + ipiv = col; + } + // the chosen pivot + var pivot = x[ipiv]; + // last entry in U(:,k) is U(k,k) + uindex[unz] = k; + uvalues[unz++] = pivot; + // ipiv is the kth pivot row + pinv[ipiv] = k; + // first entry in L(:,k) is L(k,k) = 1 + lindex[lnz] = ipiv; + lvalues[lnz++] = 1; + // L(k+1:n,k) = x / pivot + for (p = top; p < n; p++) { + // row + i = xi[p]; + // check x(i) is an entry in L(:,k) + if (pinv[i] < 0) { + // save unpermuted row in L + lindex[lnz] = i; + // scale pivot column + lvalues[lnz++] = divideScalar(x[i], pivot); + } + // x[0..n-1] = 0 for next k + x[i] = 0; + } + } + // update ptr + lptr[n] = lnz; + uptr[n] = unz; + // fix row indices of L for final pinv + for (p = 0; p < lnz; p++) { + lindex[p] = pinv[lindex[p]]; + } + // trim arrays + lvalues.splice(lnz, lvalues.length - lnz); + lindex.splice(lnz, lindex.length - lnz); + uvalues.splice(unz, uvalues.length - unz); + uindex.splice(unz, uindex.length - unz); + // return LU factor + return { + L, + U, + pinv + }; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMark.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMark.js new file mode 100644 index 0000000..ace68c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMark.js @@ -0,0 +1,16 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +import { csFlip } from './csFlip.js'; + +/** + * Marks the node at w[j] + * + * @param {Array} w The array + * @param {Number} j The array index + */ +export function csMark(w, j) { + // mark w[j] + w[j] = csFlip(w[j]); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMarked.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMarked.js new file mode 100644 index 0000000..0d0e5b5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csMarked.js @@ -0,0 +1,14 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Checks if the node at w[j] is marked + * + * @param {Array} w The array + * @param {Number} j The array index + */ +export function csMarked(w, j) { + // check node is marked + return w[j] < 0; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPermute.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPermute.js new file mode 100644 index 0000000..044b656 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPermute.js @@ -0,0 +1,61 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Permutes a sparse matrix C = P * A * Q + * + * @param {SparseMatrix} a The Matrix A + * @param {Array} pinv The row permutation vector + * @param {Array} q The column permutation vector + * @param {boolean} values Create a pattern matrix (false), values and pattern otherwise + * + * @return {Matrix} C = P * A * Q, null on error + */ +export function csPermute(a, pinv, q, values) { + // a arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + var adt = a._datatype; + // rows & columns + var m = asize[0]; + var n = asize[1]; + // c arrays + var cvalues = values && a._values ? [] : null; + var cindex = []; // (aptr[n]) + var cptr = []; // (n + 1) + // initialize vars + var nz = 0; + // loop columns + for (var k = 0; k < n; k++) { + // column k of C is column q[k] of A + cptr[k] = nz; + // apply column permutation + var j = q ? q[k] : k; + // loop values in column j of A + for (var t0 = aptr[j], t1 = aptr[j + 1], t = t0; t < t1; t++) { + // row i of A is row pinv[i] of C + var r = pinv ? pinv[aindex[t]] : aindex[t]; + // index + cindex[nz] = r; + // check we need to populate values + if (cvalues) { + cvalues[nz] = avalues[t]; + } + // increment number of nonzero elements + nz++; + } + } + // finalize the last column of C + cptr[n] = nz; + // return C matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [m, n], + datatype: adt + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPost.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPost.js new file mode 100644 index 0000000..6ff7c3f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csPost.js @@ -0,0 +1,52 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csTdfs } from './csTdfs.js'; + +/** + * Post order a tree of forest + * + * @param {Array} parent The tree or forest + * @param {Number} n Number of columns + */ +export function csPost(parent, n) { + // check inputs + if (!parent) { + return null; + } + // vars + var k = 0; + var j; + // allocate result + var post = []; // (n) + // workspace, head: first n entries, next: next n entries, stack: last n entries + var w = []; // (3 * n) + var head = 0; + var next = n; + var stack = 2 * n; + // initialize workspace + for (j = 0; j < n; j++) { + // empty linked lists + w[head + j] = -1; + } + // traverse nodes in reverse order + for (j = n - 1; j >= 0; j--) { + // check j is a root + if (parent[j] === -1) { + continue; + } + // add j to list of its parent + w[next + j] = w[head + parent[j]]; + w[head + parent[j]] = j; + } + // loop nodes + for (j = 0; j < n; j++) { + // skip j if it is not a root + if (parent[j] !== -1) { + continue; + } + // depth-first search + k = csTdfs(j, k, w, head, next, post, stack); + } + return post; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csReach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csReach.js new file mode 100644 index 0000000..2f49fb9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csReach.js @@ -0,0 +1,52 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +import { csMarked } from './csMarked.js'; +import { csMark } from './csMark.js'; +import { csDfs } from './csDfs.js'; + +/** + * The csReach function computes X = Reach(B), where B is the nonzero pattern of the n-by-1 + * sparse column of vector b. The function returns the set of nodes reachable from any node in B. The + * nonzero pattern xi of the solution x to the sparse linear system Lx=b is given by X=Reach(B). + * + * @param {Matrix} g The G matrix + * @param {Matrix} b The B matrix + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} pinv The inverse row permutation vector + * + * @return {Number} The index for the nonzero pattern + */ +export function csReach(g, b, k, xi, pinv) { + // g arrays + var gptr = g._ptr; + var gsize = g._size; + // b arrays + var bindex = b._index; + var bptr = b._ptr; + // columns + var n = gsize[1]; + // vars + var p, p0, p1; + // initialize top + var top = n; + // loop column indeces in B + for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { + // node i + var i = bindex[p]; + // check node i is marked + if (!csMarked(gptr, i)) { + // start a dfs at unmarked node i + top = csDfs(i, g, top, xi, pinv); + } + } + // loop columns from top -> n - 1 + for (p = top; p < n; p++) { + // restore G + csMark(gptr, xi[p]); + } + return top; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSpsolve.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSpsolve.js new file mode 100644 index 0000000..82f6f6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSpsolve.js @@ -0,0 +1,84 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csReach } from './csReach.js'; +import { factory } from '../../../utils/factory.js'; +var name = 'csSpsolve'; +var dependencies = ['divideScalar', 'multiply', 'subtract']; +export var createCsSpsolve = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + divideScalar, + multiply, + subtract + } = _ref; + /** + * The function csSpsolve() computes the solution to G * x = bk, where bk is the + * kth column of B. When lo is true, the function assumes G = L is lower triangular with the + * diagonal entry as the first entry in each column. When lo is true, the function assumes G = U + * is upper triangular with the diagonal entry as the last entry in each column. + * + * @param {Matrix} g The G matrix + * @param {Matrix} b The B matrix + * @param {Number} k The kth column in B + * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n + * The first n entries is the nonzero pattern, the last n entries is the stack + * @param {Array} x The soluton to the linear system G * x = b + * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b + * @param {boolean} lo The lower (true) upper triangular (false) flag + * + * @return {Number} The index for the nonzero pattern + */ + return function csSpsolve(g, b, k, xi, x, pinv, lo) { + // g arrays + var gvalues = g._values; + var gindex = g._index; + var gptr = g._ptr; + var gsize = g._size; + // columns + var n = gsize[1]; + // b arrays + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + // vars + var p, p0, p1, q; + // xi[top..n-1] = csReach(B(:,k)) + var top = csReach(g, b, k, xi, pinv); + // clear x + for (p = top; p < n; p++) { + x[xi[p]] = 0; + } + // scatter b + for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { + x[bindex[p]] = bvalues[p]; + } + // loop columns + for (var px = top; px < n; px++) { + // x array index for px + var j = xi[px]; + // apply permutation vector (U x = b), j maps to column J of G + var J = pinv ? pinv[j] : j; + // check column J is empty + if (J < 0) { + continue; + } + // column value indeces in G, p0 <= p < p1 + p0 = gptr[J]; + p1 = gptr[J + 1]; + // x(j) /= G(j,j) + x[j] = divideScalar(x[j], gvalues[lo ? p0 : p1 - 1]); + // first entry L(j,j) + p = lo ? p0 + 1 : p0; + q = lo ? p1 : p1 - 1; + // loop + for (; p < q; p++) { + // row + var i = gindex[p]; + // x(i) -= G(i,j) * x(j) + x[i] = subtract(x[i], multiply(gvalues[p], x[j])); + } + } + // return top of stack + return top; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSqr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSqr.js new file mode 100644 index 0000000..a26579a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSqr.js @@ -0,0 +1,179 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csPermute } from './csPermute.js'; +import { csPost } from './csPost.js'; +import { csEtree } from './csEtree.js'; +import { createCsAmd } from './csAmd.js'; +import { createCsCounts } from './csCounts.js'; +import { factory } from '../../../utils/factory.js'; +var name = 'csSqr'; +var dependencies = ['add', 'multiply', 'transpose']; +export var createCsSqr = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + add, + multiply, + transpose + } = _ref; + var csAmd = createCsAmd({ + add, + multiply, + transpose + }); + var csCounts = createCsCounts({ + transpose + }); + + /** + * Symbolic ordering and analysis for QR and LU decompositions. + * + * @param {Number} order The ordering strategy (see csAmd for more details) + * @param {Matrix} a The A matrix + * @param {boolean} qr Symbolic ordering and analysis for QR decomposition (true) or + * symbolic ordering and analysis for LU decomposition (false) + * + * @return {Object} The Symbolic ordering and analysis for matrix A + */ + return function csSqr(order, a, qr) { + // a arrays + var aptr = a._ptr; + var asize = a._size; + // columns + var n = asize[1]; + // vars + var k; + // symbolic analysis result + var s = {}; + // fill-reducing ordering + s.q = csAmd(order, a); + // validate results + if (order && !s.q) { + return null; + } + // QR symbolic analysis + if (qr) { + // apply permutations if needed + var c = order ? csPermute(a, null, s.q, 0) : a; + // etree of C'*C, where C=A(:,q) + s.parent = csEtree(c, 1); + // post order elimination tree + var post = csPost(s.parent, n); + // col counts chol(C'*C) + s.cp = csCounts(c, s.parent, post, 1); + // check we have everything needed to calculate number of nonzero elements + if (c && s.parent && s.cp && _vcount(c, s)) { + // calculate number of nonzero elements + for (s.unz = 0, k = 0; k < n; k++) { + s.unz += s.cp[k]; + } + } + } else { + // for LU factorization only, guess nnz(L) and nnz(U) + s.unz = 4 * aptr[n] + n; + s.lnz = s.unz; + } + // return result S + return s; + }; + + /** + * Compute nnz(V) = s.lnz, s.pinv, s.leftmost, s.m2 from A and s.parent + */ + function _vcount(a, s) { + // a arrays + var aptr = a._ptr; + var aindex = a._index; + var asize = a._size; + // rows & columns + var m = asize[0]; + var n = asize[1]; + // initialize s arrays + s.pinv = []; // (m + n) + s.leftmost = []; // (m) + // vars + var parent = s.parent; + var pinv = s.pinv; + var leftmost = s.leftmost; + // workspace, next: first m entries, head: next n entries, tail: next n entries, nque: next n entries + var w = []; // (m + 3 * n) + var next = 0; + var head = m; + var tail = m + n; + var nque = m + 2 * n; + // vars + var i, k, p, p0, p1; + // initialize w + for (k = 0; k < n; k++) { + // queue k is empty + w[head + k] = -1; + w[tail + k] = -1; + w[nque + k] = 0; + } + // initialize row arrays + for (i = 0; i < m; i++) { + leftmost[i] = -1; + } + // loop columns backwards + for (k = n - 1; k >= 0; k--) { + // values & index for column k + for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) { + // leftmost[i] = min(find(A(i,:))) + leftmost[aindex[p]] = k; + } + } + // scan rows in reverse order + for (i = m - 1; i >= 0; i--) { + // row i is not yet ordered + pinv[i] = -1; + k = leftmost[i]; + // check row i is empty + if (k === -1) { + continue; + } + // first row in queue k + if (w[nque + k]++ === 0) { + w[tail + k] = i; + } + // put i at head of queue k + w[next + i] = w[head + k]; + w[head + k] = i; + } + s.lnz = 0; + s.m2 = m; + // find row permutation and nnz(V) + for (k = 0; k < n; k++) { + // remove row i from queue k + i = w[head + k]; + // count V(k,k) as nonzero + s.lnz++; + // add a fictitious row + if (i < 0) { + i = s.m2++; + } + // associate row i with V(:,k) + pinv[i] = k; + // skip if V(k+1:m,k) is empty + if (--nque[k] <= 0) { + continue; + } + // nque[k] is nnz (V(k+1:m,k)) + s.lnz += w[nque + k]; + // move all rows to parent of k + var pa = parent[k]; + if (pa !== -1) { + if (w[nque + pa] === 0) { + w[tail + pa] = w[tail + k]; + } + w[next + w[tail + k]] = w[head + pa]; + w[head + pa] = w[next + i]; + w[nque + pa] += w[nque + k]; + } + } + for (i = 0; i < m; i++) { + if (pinv[i] < 0) { + pinv[i] = k++; + } + } + return true; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSymperm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSymperm.js new file mode 100644 index 0000000..f1b0321 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csSymperm.js @@ -0,0 +1,93 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csCumsum } from './csCumsum.js'; +import { factory } from '../../../utils/factory.js'; +var name = 'csSymperm'; +var dependencies = ['conj', 'SparseMatrix']; +export var createCsSymperm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + conj, + SparseMatrix + } = _ref; + /** + * Computes the symmetric permutation of matrix A accessing only + * the upper triangular part of A. + * + * C = P * A * P' + * + * @param {Matrix} a The A matrix + * @param {Array} pinv The inverse of permutation vector + * @param {boolean} values Process matrix values (true) + * + * @return {Matrix} The C matrix, C = P * A * P' + */ + return function csSymperm(a, pinv, values) { + // A matrix arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + // columns + var n = asize[1]; + // C matrix arrays + var cvalues = values && avalues ? [] : null; + var cindex = []; // (nz) + var cptr = []; // (n + 1) + // variables + var i, i2, j, j2, p, p0, p1; + // create workspace vector + var w = []; // (n) + // count entries in each column of C + for (j = 0; j < n; j++) { + // column j of A is column j2 of C + j2 = pinv ? pinv[j] : j; + // loop values in column j + for (p0 = aptr[j], p1 = aptr[j + 1], p = p0; p < p1; p++) { + // row + i = aindex[p]; + // skip lower triangular part of A + if (i > j) { + continue; + } + // row i of A is row i2 of C + i2 = pinv ? pinv[i] : i; + // column count of C + w[Math.max(i2, j2)]++; + } + } + // compute column pointers of C + csCumsum(cptr, w, n); + // loop columns + for (j = 0; j < n; j++) { + // column j of A is column j2 of C + j2 = pinv ? pinv[j] : j; + // loop values in column j + for (p0 = aptr[j], p1 = aptr[j + 1], p = p0; p < p1; p++) { + // row + i = aindex[p]; + // skip lower triangular part of A + if (i > j) { + continue; + } + // row i of A is row i2 of C + i2 = pinv ? pinv[i] : i; + // C index for column j2 + var q = w[Math.max(i2, j2)]++; + // update C index for entry q + cindex[q] = Math.min(i2, j2); + // check we need to process values + if (cvalues) { + cvalues[q] = i2 <= j2 ? avalues[p] : conj(avalues[p]); + } + } + } + // return C matrix + return new SparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [n, n] + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csTdfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csTdfs.js new file mode 100644 index 0000000..d4b851c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csTdfs.js @@ -0,0 +1,42 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source + +/** + * Depth-first search and postorder of a tree rooted at node j + * + * @param {Number} j The tree node + * @param {Number} k + * @param {Array} w The workspace array + * @param {Number} head The index offset within the workspace for the head array + * @param {Number} next The index offset within the workspace for the next array + * @param {Array} post The post ordering array + * @param {Number} stack The index offset within the workspace for the stack array + */ +export function csTdfs(j, k, w, head, next, post, stack) { + // variables + var top = 0; + // place j on the stack + w[stack] = j; + // while (stack is not empty) + while (top >= 0) { + // p = top of stack + var p = w[stack + top]; + // i = youngest child of p + var i = w[head + p]; + if (i === -1) { + // p has no unordered children left + top--; + // node p is the kth postordered node + post[k++] = p; + } else { + // remove i from children of p + w[head + p] = w[next + i]; + // increment top + ++top; + // start dfs on child node i + w[stack + top] = i; + } + } + return k; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csUnflip.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csUnflip.js new file mode 100644 index 0000000..923dc28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sparse/csUnflip.js @@ -0,0 +1,14 @@ +// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved. +// SPDX-License-Identifier: LGPL-2.1+ +// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source +import { csFlip } from './csFlip.js'; + +/** + * Flips the value if it is negative of returns the same value otherwise. + * + * @param {Number} i The value to flip + */ +export function csUnflip(i) { + // flip the value if it is negative + return i < 0 ? csFlip(i) : i; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sylvester.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sylvester.js new file mode 100644 index 0000000..7db0b93 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/sylvester.js @@ -0,0 +1,118 @@ +import { factory } from '../../utils/factory.js'; +var name = 'sylvester'; +var dependencies = ['typed', 'schur', 'matrixFromColumns', 'matrix', 'multiply', 'range', 'concat', 'transpose', 'index', 'subset', 'add', 'subtract', 'identity', 'lusolve', 'abs']; +export var createSylvester = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + schur, + matrixFromColumns, + matrix, + multiply, + range, + concat, + transpose, + index, + subset, + add, + subtract, + identity, + lusolve, + abs + } = _ref; + /** + * + * Solves the real-valued Sylvester equation AX+XB=C for X, where A, B and C are + * matrices of appropriate dimensions, being A and B squared. Notice that other + * equivalent definitions for the Sylvester equation exist and this function + * assumes the one presented in the original publication of the the Bartels- + * Stewart algorithm, which is implemented by this function. + * https://en.wikipedia.org/wiki/Sylvester_equation + * + * Syntax: + * + * math.sylvester(A, B, C) + * + * Examples: + * + * const A = [[-1, -2], [1, 1]] + * const B = [[2, -1], [1, -2]] + * const C = [[-3, 2], [3, 0]] + * math.sylvester(A, B, C) // returns DenseMatrix [[-0.25, 0.25], [1.5, -1.25]] + * + * See also: + * + * schur, lyap + * + * @param {Matrix | Array} A Matrix A + * @param {Matrix | Array} B Matrix B + * @param {Matrix | Array} C Matrix C + * @return {Matrix | Array} Matrix X, solving the Sylvester equation + */ + return typed(name, { + 'Matrix, Matrix, Matrix': _sylvester, + 'Array, Matrix, Matrix': function Array_Matrix_Matrix(A, B, C) { + return _sylvester(matrix(A), B, C); + }, + 'Array, Array, Matrix': function Array_Array_Matrix(A, B, C) { + return _sylvester(matrix(A), matrix(B), C); + }, + 'Array, Matrix, Array': function Array_Matrix_Array(A, B, C) { + return _sylvester(matrix(A), B, matrix(C)); + }, + 'Matrix, Array, Matrix': function Matrix_Array_Matrix(A, B, C) { + return _sylvester(A, matrix(B), C); + }, + 'Matrix, Array, Array': function Matrix_Array_Array(A, B, C) { + return _sylvester(A, matrix(B), matrix(C)); + }, + 'Matrix, Matrix, Array': function Matrix_Matrix_Array(A, B, C) { + return _sylvester(A, B, matrix(C)); + }, + 'Array, Array, Array': function Array_Array_Array(A, B, C) { + return _sylvester(matrix(A), matrix(B), matrix(C)).toArray(); + } + }); + function _sylvester(A, B, C) { + var n = B.size()[0]; + var m = A.size()[0]; + var sA = schur(A); + var F = sA.T; + var U = sA.U; + var sB = schur(multiply(-1, B)); + var G = sB.T; + var V = sB.U; + var D = multiply(multiply(transpose(U), C), V); + var all = range(0, m); + var y = []; + var hc = (a, b) => concat(a, b, 1); + var vc = (a, b) => concat(a, b, 0); + for (var k = 0; k < n; k++) { + if (k < n - 1 && abs(subset(G, index(k + 1, k))) > 1e-5) { + var RHS = vc(subset(D, index(all, k)), subset(D, index(all, k + 1))); + for (var j = 0; j < k; j++) { + RHS = add(RHS, vc(multiply(y[j], subset(G, index(j, k))), multiply(y[j], subset(G, index(j, k + 1))))); + } + var gkk = multiply(identity(m), multiply(-1, subset(G, index(k, k)))); + var gmk = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k)))); + var gkm = multiply(identity(m), multiply(-1, subset(G, index(k, k + 1)))); + var gmm = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k + 1)))); + var LHS = vc(hc(add(F, gkk), gmk), hc(gkm, add(F, gmm))); + var yAux = lusolve(LHS, RHS); + y[k] = yAux.subset(index(range(0, m), 0)); + y[k + 1] = yAux.subset(index(range(m, 2 * m), 0)); + k++; + } else { + var _RHS = subset(D, index(all, k)); + for (var _j = 0; _j < k; _j++) { + _RHS = add(_RHS, multiply(y[_j], subset(G, index(_j, k)))); + } + var _gkk = subset(G, index(k, k)); + var _LHS = subtract(F, multiply(_gkk, identity(m))); + y[k] = lusolve(_LHS, _RHS); + } + } + var Y = matrix(matrixFromColumns(...y)); + var X = multiply(U, multiply(Y, transpose(V))); + return X; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/symbolicEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/symbolicEqual.js new file mode 100644 index 0000000..ad92304 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/algebra/symbolicEqual.js @@ -0,0 +1,60 @@ +import { isConstantNode } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'symbolicEqual'; +var dependencies = ['parse', 'simplify', 'typed', 'OperatorNode']; +export var createSymbolicEqual = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + parse, + simplify, + typed, + OperatorNode + } = _ref; + /** + * Attempts to determine if two expressions are symbolically equal, i.e. + * one is the result of valid algebraic manipulations on the other. + * Currently, this simply checks if the difference of the two expressions + * simplifies down to 0. So there are two important caveats: + * 1. whether two expressions are symbolically equal depends on the + * manipulations allowed. Therefore, this function takes an optional + * third argument, which are the options that control the behavior + * as documented for the `simplify()` function. + * 2. it is in general intractable to find the minimal simplification of + * an arbitrarily complicated expression. So while a `true` value + * of `symbolicEqual` ensures that the two expressions can be manipulated + * to match each other, a `false` value does not absolutely rule this out. + * + * Syntax: + * + * math.symbolicEqual(expr1, expr2) + * math.symbolicEqual(expr1, expr2, options) + * + * Examples: + * + * math.symbolicEqual('x*y', 'y*x') // Returns true + * math.symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}}) // Returns false + * math.symbolicEqual('x/y', '(y*x^(-1))^(-1)') // Returns true + * math.symbolicEqual('abs(x)','x') // Returns false + * math.symbolicEqual('abs(x)','x', simplify.positiveContext) // Returns true + * + * See also: + * + * simplify, evaluate + * + * @param {Node|string} expr1 The first expression to compare + * @param {Node|string} expr2 The second expression to compare + * @param {Object} [options] Optional option object, passed to simplify + * @returns {boolean} + * Returns true if a valid manipulation making the expressions equal + * is found. + */ + function _symbolicEqual(e1, e2) { + var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var diff = new OperatorNode('-', 'subtract', [e1, e2]); + var simplified = simplify(diff, {}, options); + return isConstantNode(simplified) && !simplified.value; + } + return typed(name, { + 'Node, Node': _symbolicEqual, + 'Node, Node, Object': _symbolicEqual + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/abs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/abs.js new file mode 100644 index 0000000..8a89a06 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/abs.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { absNumber } from '../../plain/number/index.js'; +var name = 'abs'; +var dependencies = ['typed']; +export var createAbs = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the absolute value of a number. For matrices, the function is + * evaluated element wise. + * + * Syntax: + * + * math.abs(x) + * + * Examples: + * + * math.abs(3.5) // returns number 3.5 + * math.abs(-4.2) // returns number 4.2 + * + * math.abs([3, -5, -1, 0, 2]) // returns Array [3, 5, 1, 0, 2] + * + * See also: + * + * sign + * + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x + * A number or matrix for which to get the absolute value + * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} + * Absolute value of `x` + */ + return typed(name, { + number: absNumber, + 'Complex | BigNumber | Fraction | Unit': x => x.abs(), + bigint: x => x < 0n ? -x : x, + // deep map collection, skip zeros since abs(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/add.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/add.js new file mode 100644 index 0000000..e3bce06 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/add.js @@ -0,0 +1,83 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'add'; +var dependencies = ['typed', 'matrix', 'addScalar', 'equalScalar', 'DenseMatrix', 'SparseMatrix', 'concat']; +export var createAdd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + addScalar, + equalScalar, + DenseMatrix, + SparseMatrix, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo04xSidSid = createMatAlgo04xSidSid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + /** + * Add two or more values, `x + y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.add(x, y) + * math.add(x, y, z, ...) + * + * Examples: + * + * math.add(2, 3) // returns number 5 + * math.add(2, 3, 4) // returns number 9 + * + * const a = math.complex(2, 3) + * const b = math.complex(-4, 1) + * math.add(a, b) // returns Complex -2 + 4i + * + * math.add([1, 2, 3], 4) // returns Array [5, 6, 7] + * + * const c = math.unit('5 cm') + * const d = math.unit('2.1 mm') + * math.add(c, d) // returns Unit 52.1 mm + * + * math.add("2.3", "4") // returns number 6.3 + * + * See also: + * + * subtract, sum + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to add + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to add + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Sum of `x` and `y` + */ + return typed(name, { + 'any, any': addScalar, + 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => { + var result = self(x, y); + for (var i = 0; i < rest.length; i++) { + result = self(result, rest[i]); + } + return result; + }) + }, matrixAlgorithmSuite({ + elop: addScalar, + DS: matAlgo01xDSid, + SS: matAlgo04xSidSid, + Ss: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/addScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/addScalar.js new file mode 100644 index 0000000..490e90b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/addScalar.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +import { addNumber } from '../../plain/number/index.js'; +var name = 'addScalar'; +var dependencies = ['typed']; +export var createAddScalar = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Add two scalar values, `x + y`. + * This function is meant for internal use: it is used by the public function + * `add` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to add + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to add + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Sum of `x` and `y` + * @private + */ + return typed(name, { + 'number, number': addNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.add(y); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.plus(y); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x + y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return x.add(y); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (x.value === null || x.value === undefined) { + throw new Error('Parameter x contains a unit with undefined value'); + } + if (y.value === null || y.value === undefined) { + throw new Error('Parameter y contains a unit with undefined value'); + } + if (!x.equalBase(y)) throw new Error('Units do not match'); + var res = x.clone(); + res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value); + res.fixPrefix = false; + return res; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cbrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cbrt.js new file mode 100644 index 0000000..1038b2b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cbrt.js @@ -0,0 +1,131 @@ +import { factory } from '../../utils/factory.js'; +import { isBigNumber, isComplex, isFraction } from '../../utils/is.js'; +import { cbrtNumber } from '../../plain/number/index.js'; +var name = 'cbrt'; +var dependencies = ['config', 'typed', 'isNegative', 'unaryMinus', 'matrix', 'Complex', 'BigNumber', 'Fraction']; +export var createCbrt = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + typed, + isNegative, + unaryMinus, + matrix, + Complex, + BigNumber, + Fraction + } = _ref; + /** + * Calculate the cubic root of a value. + * + * To avoid confusion with the matrix cube root, this function does not + * apply to matrices. For a matrix, to take the cube root elementwise, + * see the examples. + * + * Syntax: + * + * math.cbrt(x) + * math.cbrt(x, allRoots) + * + * Examples: + * + * math.cbrt(27) // returns 3 + * math.cube(3) // returns 27 + * math.cbrt(-64) // returns -4 + * math.cbrt(math.unit('27 m^3')) // returns Unit 3 m + * math.map([27, 64, 125], x => math.cbrt(x)) // returns [3, 4, 5] + * + * const x = math.complex('8i') + * math.cbrt(x) // returns Complex 1.7320508075689 + i + * math.cbrt(x, true) // returns Matrix [ + * // 1.7320508075689 + i + * // -1.7320508075689 + i + * // -2i + * // ] + * + * See also: + * + * square, sqrt, cube + * + * @param {number | BigNumber | Complex | Unit} x + * Value for which to calculate the cubic root. + * @param {boolean} [allRoots] Optional, false by default. Only applicable + * when `x` is a number or complex number. If true, all complex + * roots are returned, if false (default) the principal root is + * returned. + * @return {number | BigNumber | Complex | Unit} + * Returns the cubic root of `x` + */ + return typed(name, { + number: cbrtNumber, + // note: signature 'number, boolean' is also supported, + // created by typed as it knows how to convert number to Complex + + Complex: _cbrtComplex, + 'Complex, boolean': _cbrtComplex, + BigNumber: function BigNumber(x) { + return x.cbrt(); + }, + Unit: _cbrtUnit + }); + + /** + * Calculate the cubic root for a complex number + * @param {Complex} x + * @param {boolean} [allRoots] If true, the function will return an array + * with all three roots. If false or undefined, + * the principal root is returned. + * @returns {Complex | Array. | Matrix.} Returns the cubic root(s) of x + * @private + */ + function _cbrtComplex(x, allRoots) { + // https://www.wikiwand.com/en/Cube_root#/Complex_numbers + + var arg3 = x.arg() / 3; + var abs = x.abs(); + + // principal root: + var principal = new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3).exp()); + if (allRoots) { + var all = [principal, new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 + Math.PI * 2 / 3).exp()), new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 - Math.PI * 2 / 3).exp())]; + return config.matrix === 'Array' ? all : matrix(all); + } else { + return principal; + } + } + + /** + * Calculate the cubic root for a Unit + * @param {Unit} x + * @return {Unit} Returns the cubic root of x + * @private + */ + function _cbrtUnit(x) { + if (x.value && isComplex(x.value)) { + var result = x.clone(); + result.value = 1.0; + result = result.pow(1.0 / 3); // Compute the units + result.value = _cbrtComplex(x.value); // Compute the value + return result; + } else { + var negate = isNegative(x.value); + if (negate) { + x.value = unaryMinus(x.value); + } + + // TODO: create a helper function for this + var third; + if (isBigNumber(x.value)) { + third = new BigNumber(1).div(3); + } else if (isFraction(x.value)) { + third = new Fraction(1, 3); + } else { + third = 1 / 3; + } + var _result = x.pow(third); + if (negate) { + _result.value = unaryMinus(_result.value); + } + return _result; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/ceil.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/ceil.js new file mode 100644 index 0000000..3eb1a0a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/ceil.js @@ -0,0 +1,161 @@ +import Decimal from 'decimal.js'; +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +var name = 'ceil'; +var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']; +export var createCeilNumber = /* #__PURE__ */factory(name, ['typed', 'config', 'round'], _ref => { + var { + typed, + config, + round + } = _ref; + return typed(name, { + number: function number(x) { + if (nearlyEqual(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return Math.ceil(x); + } + }, + 'number, number': function number_number(x, n) { + if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + var [number, exponent] = "".concat(x, "e").split('e'); + var result = Math.ceil(Number("".concat(number, "e").concat(Number(exponent) + n))); + [number, exponent] = "".concat(result, "e").split('e'); + return Number("".concat(number, "e").concat(Number(exponent) - n)); + } + } + }); +}); +export var createCeil = /* #__PURE__ */factory(name, dependencies, _ref2 => { + var { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var ceilNumber = createCeilNumber({ + typed, + config, + round + }); + /** + * Round a value towards plus infinity + * If `x` is complex, both real and imaginary part are rounded towards plus infinity. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.ceil(x) + * math.ceil(x, n) + * + * Examples: + * + * math.ceil(3.2) // returns number 4 + * math.ceil(3.8) // returns number 4 + * math.ceil(-4.2) // returns number -4 + * math.ceil(-4.7) // returns number -4 + * + * math.ceil(3.212, 2) // returns number 3.22 + * math.ceil(3.288, 2) // returns number 3.29 + * math.ceil(-4.212, 2) // returns number -4.21 + * math.ceil(-4.782, 2) // returns number -4.78 + * + * const c = math.complex(3.24, -2.71) + * math.ceil(c) // returns Complex 4 - 2i + * math.ceil(c, 1) // returns Complex 3.3 - 2.7i + * + * math.ceil([3.2, 3.8, -4.7]) // returns Array [4, 4, -4] + * math.ceil([3.21, 3.82, -4.71], 1) // returns Array [3.3, 3.9, -4.7] + * + * See also: + * + * floor, fix, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('ceil', { + number: ceilNumber.signatures.number, + 'number,number': ceilNumber.signatures['number,number'], + Complex: function Complex(x) { + return x.ceil(); + }, + 'Complex, number': function Complex_number(x, n) { + return x.ceil(n); + }, + 'Complex, BigNumber': function Complex_BigNumber(x, n) { + return x.ceil(n.toNumber()); + }, + BigNumber: function BigNumber(x) { + if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return x.ceil(); + } + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, n) { + if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_CEIL); + } + }, + Fraction: function Fraction(x) { + return x.ceil(); + }, + 'Fraction, number': function Fraction_number(x, n) { + return x.ceil(n); + }, + 'Fraction, BigNumber': function Fraction_BigNumber(x, n) { + return x.ceil(n.toNumber()); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since ceil(0) = 0 + return deepMap(x, self, true); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since ceil(0) = 0 + return deepMap(x, i => self(i, n), true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cube.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cube.js new file mode 100644 index 0000000..71aad9e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/cube.js @@ -0,0 +1,52 @@ +import { factory } from '../../utils/factory.js'; +import { cubeNumber } from '../../plain/number/index.js'; +var name = 'cube'; +var dependencies = ['typed']; +export var createCube = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the cube of a value, `x * x * x`. + * To avoid confusion with `pow(M,3)`, this function does not apply to matrices. + * If you wish to cube every entry of a matrix, see the examples. + * + * Syntax: + * + * math.cube(x) + * + * Examples: + * + * math.cube(2) // returns number 8 + * math.pow(2, 3) // returns number 8 + * math.cube(4) // returns number 64 + * 4 * 4 * 4 // returns number 64 + * + * math.map([1, 2, 3, 4], math.cube) // returns Array [1, 8, 27, 64] + * + * See also: + * + * multiply, square, pow, cbrt + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Number for which to calculate the cube + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Cube of x + */ + return typed(name, { + number: cubeNumber, + Complex: function Complex(x) { + return x.mul(x).mul(x); // Is faster than pow(x, 3) + }, + BigNumber: function BigNumber(x) { + return x.times(x).times(x); + }, + bigint: function bigint(x) { + return x * x * x; + }, + Fraction: function Fraction(x) { + return x.pow(3); // Is faster than mul()mul()mul() + }, + Unit: function Unit(x) { + return x.pow(3); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divide.js new file mode 100644 index 0000000..9c2001e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divide.js @@ -0,0 +1,79 @@ +import { factory } from '../../utils/factory.js'; +import { extend } from '../../utils/object.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +var name = 'divide'; +var dependencies = ['typed', 'matrix', 'multiply', 'equalScalar', 'divideScalar', 'inv']; +export var createDivide = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + multiply, + equalScalar, + divideScalar, + inv + } = _ref; + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + + /** + * Divide two values, `x / y`. + * To divide matrices, `x` is multiplied with the inverse of `y`: `x * inv(y)`. + * + * Syntax: + * + * math.divide(x, y) + * + * Examples: + * + * math.divide(2, 3) // returns number 0.6666666666666666 + * + * const a = math.complex(5, 14) + * const b = math.complex(4, 1) + * math.divide(a, b) // returns Complex 2 + 3i + * + * const c = [[7, -6], [13, -4]] + * const d = [[1, 2], [4, 3]] + * math.divide(c, d) // returns Array [[-9, 4], [-11, 6]] + * + * const e = math.unit('18 km') + * math.divide(e, 4.5) // returns Unit 4 km + * + * See also: + * + * multiply + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Numerator + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix} y Denominator + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Quotient, `x / y` + */ + return typed('divide', extend({ + // we extend the signatures of divideScalar with signatures dealing with matrices + + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(x, y) { + // TODO: implement matrix right division using pseudo inverse + // https://www.mathworks.nl/help/matlab/ref/mrdivide.html + // https://www.gnu.org/software/octave/doc/interpreter/Arithmetic-Ops.html + // https://stackoverflow.com/questions/12263932/how-does-gnu-octave-matrix-division-work-getting-unexpected-behaviour + return multiply(x, inv(y)); + }, + 'DenseMatrix, any': function DenseMatrix_any(x, y) { + return matAlgo14xDs(x, y, divideScalar, false); + }, + 'SparseMatrix, any': function SparseMatrix_any(x, y) { + return matAlgo11xS0s(x, y, divideScalar, false); + }, + 'Array, any': function Array_any(x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(x), y, divideScalar, false).valueOf(); + }, + 'any, Array | Matrix': function any_Array__Matrix(x, y) { + return multiply(x, inv(y)); + } + }, divideScalar.signatures)); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divideScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divideScalar.js new file mode 100644 index 0000000..bec7bac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/divideScalar.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +var name = 'divideScalar'; +var dependencies = ['typed', 'numeric']; +export var createDivideScalar = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + numeric + } = _ref; + /** + * Divide two scalar values, `x / y`. + * This function is meant for internal use: it is used by the public functions + * `divide` and `inv`. + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x Numerator + * @param {number | BigNumber | bigint | Fraction | Complex} y Denominator + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Quotient, `x / y` + * @private + */ + return typed(name, { + 'number, number': function number_number(x, y) { + return x / y; + }, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.div(y); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.div(y); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x / y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return x.div(y); + }, + 'Unit, number | Complex | Fraction | BigNumber | Unit': (x, y) => x.divide(y), + 'number | Fraction | Complex | BigNumber, Unit': (x, y) => y.divideInto(x) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotDivide.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotDivide.js new file mode 100644 index 0000000..526c4f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotDivide.js @@ -0,0 +1,78 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'dotDivide'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'divideScalar', 'DenseMatrix', 'concat']; +export var createDotDivide = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + divideScalar, + DenseMatrix, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Divide two matrices element wise. The function accepts both matrices and + * scalar values. + * + * Syntax: + * + * math.dotDivide(x, y) + * + * Examples: + * + * math.dotDivide(2, 4) // returns 0.5 + * + * a = [[9, 5], [6, 1]] + * b = [[3, 2], [5, 2]] + * + * math.dotDivide(a, b) // returns [[3, 2.5], [1.2, 0.5]] + * math.divide(a, b) // returns [[1.75, 0.75], [-1.75, 2.25]] + * + * See also: + * + * divide, multiply, dotMultiply + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Numerator + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Denominator + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Quotient, `x ./ y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: divideScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotMultiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotMultiply.js new file mode 100644 index 0000000..8e60c9a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotMultiply.js @@ -0,0 +1,66 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'dotMultiply'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'multiplyScalar', 'concat']; +export var createDotMultiply = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + multiplyScalar, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo09xS0Sf = createMatAlgo09xS0Sf({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Multiply two matrices element wise. The function accepts both matrices and + * scalar values. + * + * Syntax: + * + * math.dotMultiply(x, y) + * + * Examples: + * + * math.dotMultiply(2, 4) // returns 8 + * + * a = [[9, 5], [6, 1]] + * b = [[3, 2], [5, 2]] + * + * math.dotMultiply(a, b) // returns [[27, 10], [30, 2]] + * math.multiply(a, b) // returns [[52, 28], [23, 14]] + * + * See also: + * + * multiply, divide, dotDivide + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Left hand value + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Right hand value + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: multiplyScalar, + SS: matAlgo09xS0Sf, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotPow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotPow.js new file mode 100644 index 0000000..9f4d3f7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/dotPow.js @@ -0,0 +1,78 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'dotPow'; +var dependencies = ['typed', 'equalScalar', 'matrix', 'pow', 'DenseMatrix', 'concat']; +export var createDotPow = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar, + matrix, + pow, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var powScalarSignatures = {}; + for (var signature in pow.signatures) { + if (Object.prototype.hasOwnProperty.call(pow.signatures, signature)) { + if (!signature.includes('Matrix') && !signature.includes('Array')) { + powScalarSignatures[signature] = pow.signatures[signature]; + } + } + } + var powScalar = typed(powScalarSignatures); + + /** + * Calculates the power of x to y element wise. + * + * Syntax: + * + * math.dotPow(x, y) + * + * Examples: + * + * math.dotPow(2, 3) // returns number 8 + * + * const a = [[1, 2], [4, 3]] + * math.dotPow(a, 2) // returns Array [[1, 4], [16, 9]] + * math.pow(a, 2) // returns Array [[9, 8], [16, 17]] + * + * See also: + * + * pow, sqrt, multiply + * + * @param {number | BigNumber | Complex | Unit | Array | Matrix} x The base + * @param {number | BigNumber | Complex | Unit | Array | Matrix} y The exponent + * @return {number | BigNumber | Complex | Unit | Array | Matrix} The value of `x` to the power `y` + */ + return typed(name, matrixAlgorithmSuite({ + elop: powScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/exp.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/exp.js new file mode 100644 index 0000000..50f3c6c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/exp.js @@ -0,0 +1,48 @@ +import { factory } from '../../utils/factory.js'; +import { expNumber } from '../../plain/number/index.js'; +var name = 'exp'; +var dependencies = ['typed']; +export var createExp = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the exponential of a value. + * For matrices, if you want the matrix exponential of square matrix, use + * the `expm` function; if you want to take the exponential of each element, + * see the examples. + * + * Syntax: + * + * math.exp(x) + * + * Examples: + * + * math.exp(2) // returns number 7.3890560989306495 + * math.pow(math.e, 2) // returns number 7.3890560989306495 + * math.log(math.exp(2)) // returns number 2 + * + * math.map([1, 2, 3], math.exp) + * // returns Array [ + * // 2.718281828459045, + * // 7.3890560989306495, + * // 20.085536923187668 + * // ] + * + * See also: + * + * expm1, expm, log, pow + * + * @param {number | BigNumber | Complex} x A number to exponentiate + * @return {number | BigNumber | Complex} Exponential of `x` + */ + return typed(name, { + number: expNumber, + Complex: function Complex(x) { + return x.exp(); + }, + BigNumber: function BigNumber(x) { + return x.exp(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/expm1.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/expm1.js new file mode 100644 index 0000000..6515327 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/expm1.js @@ -0,0 +1,53 @@ +import { factory } from '../../utils/factory.js'; +import { expm1Number } from '../../plain/number/index.js'; +var name = 'expm1'; +var dependencies = ['typed', 'Complex']; +export var createExpm1 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Complex: _Complex + } = _ref; + /** + * Calculate the value of subtracting 1 from the exponential value. + * This function is more accurate than `math.exp(x)-1` when `x` is near 0 + * To avoid ambiguity with the matrix exponential `expm`, this function + * does not operate on matrices; if you wish to apply it elementwise, see + * the examples. + * + * Syntax: + * + * math.expm1(x) + * + * Examples: + * + * math.expm1(2) // returns number 6.38905609893065 + * math.pow(math.e, 2) - 1 // returns number 6.3890560989306495 + * math.expm1(1e-8) // returns number 1.0000000050000001e-8 + * math.exp(1e-8) - 1 // returns number 9.9999999392253e-9 + * math.log(math.expm1(2) + 1) // returns number 2 + * + * math.map([1, 2, 3], math.expm1) + * // returns Array [ + * // 1.718281828459045, + * // 6.3890560989306495, + * // 19.085536923187668 + * // ] + * + * See also: + * + * exp, expm, log, pow + * + * @param {number | BigNumber | Complex} x The number to exponentiate + * @return {number | BigNumber | Complex} Exponential of `x`, minus one + */ + return typed(name, { + number: expm1Number, + Complex: function Complex(x) { + var r = Math.exp(x.re); + return new _Complex(r * Math.cos(x.im) - 1, r * Math.sin(x.im)); + }, + BigNumber: function BigNumber(x) { + return x.exp().minus(1); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/fix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/fix.js new file mode 100644 index 0000000..648eacf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/fix.js @@ -0,0 +1,126 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +var name = 'fix'; +var dependencies = ['typed', 'Complex', 'matrix', 'ceil', 'floor', 'equalScalar', 'zeros', 'DenseMatrix']; +export var createFixNumber = /* #__PURE__ */factory(name, ['typed', 'ceil', 'floor'], _ref => { + var { + typed, + ceil, + floor + } = _ref; + return typed(name, { + number: function number(x) { + return x > 0 ? floor(x) : ceil(x); + }, + 'number, number': function number_number(x, n) { + return x > 0 ? floor(x, n) : ceil(x, n); + } + }); +}); +export var createFix = /* #__PURE__ */factory(name, dependencies, _ref2 => { + var { + typed, + Complex: _Complex, + matrix, + ceil, + floor, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var fixNumber = createFixNumber({ + typed, + ceil, + floor + }); + /** + * Round a value towards zero. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.fix(x) + * math.fix(x,n) + * + * Examples: + * + * math.fix(3.2) // returns number 3 + * math.fix(3.8) // returns number 3 + * math.fix(-4.2) // returns number -4 + * math.fix(-4.7) // returns number -4 + * + * math.fix(3.12, 1) // returns number 3.1 + * math.fix(3.18, 1) // returns number 3.1 + * math.fix(-4.12, 1) // returns number -4.1 + * math.fix(-4.17, 1) // returns number -4.1 + * + * const c = math.complex(3.22, -2.78) + * math.fix(c) // returns Complex 3 - 2i + * math.fix(c, 1) // returns Complex 3.2 -2.7i + * + * math.fix([3.2, 3.8, -4.7]) // returns Array [3, 3, -4] + * math.fix([3.2, 3.8, -4.7], 1) // returns Array [3.2, 3.8, -4.7] + * + * See also: + * + * ceil, floor, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('fix', { + number: fixNumber.signatures.number, + 'number, number | BigNumber': fixNumber.signatures['number,number'], + Complex: function Complex(x) { + return new _Complex(x.re > 0 ? Math.floor(x.re) : Math.ceil(x.re), x.im > 0 ? Math.floor(x.im) : Math.ceil(x.im)); + }, + 'Complex, number': function Complex_number(x, n) { + return new _Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n)); + }, + 'Complex, BigNumber': function Complex_BigNumber(x, bn) { + var n = bn.toNumber(); + return new _Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n)); + }, + BigNumber: function BigNumber(x) { + return x.isNegative() ? ceil(x) : floor(x); + }, + 'BigNumber, number | BigNumber': function BigNumber_number__BigNumber(x, n) { + return x.isNegative() ? ceil(x, n) : floor(x, n); + }, + Fraction: function Fraction(x) { + return x.s < 0 ? x.ceil() : x.floor(); + }, + 'Fraction, number | BigNumber': function Fraction_number__BigNumber(x, n) { + return x.s < 0 ? ceil(x, n) : floor(x, n); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since fix(0) = 0 + return deepMap(x, self, true); + }), + 'Array | Matrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since fix(0) = 0 + return deepMap(x, i => self(i, n), true); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/floor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/floor.js new file mode 100644 index 0000000..7c9b08e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/floor.js @@ -0,0 +1,164 @@ +import Decimal from 'decimal.js'; +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +var name = 'floor'; +var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']; +export var createFloorNumber = /* #__PURE__ */factory(name, ['typed', 'config', 'round'], _ref => { + var { + typed, + config, + round + } = _ref; + return typed(name, { + number: function number(x) { + if (nearlyEqual(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return Math.floor(x); + } + }, + 'number, number': function number_number(x, n) { + if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + var [number, exponent] = "".concat(x, "e").split('e'); + var result = Math.floor(Number("".concat(number, "e").concat(Number(exponent) + n))); + [number, exponent] = "".concat(result, "e").split('e'); + return Number("".concat(number, "e").concat(Number(exponent) - n)); + } + } + }); +}); +export var createFloor = /* #__PURE__ */factory(name, dependencies, _ref2 => { + var { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + } = _ref2; + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var floorNumber = createFloorNumber({ + typed, + config, + round + }); + /** + * Round a value towards minus infinity. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.floor(x) + * math.floor(x, n) + * + * Examples: + * + * math.floor(3.2) // returns number 3 + * math.floor(3.8) // returns number 3 + * math.floor(-4.2) // returns number -5 + * math.floor(-4.7) // returns number -5 + * + * math.floor(3.212, 2) // returns number 3.21 + * math.floor(3.288, 2) // returns number 3.28 + * math.floor(-4.212, 2) // returns number -4.22 + * math.floor(-4.782, 2) // returns number -4.79 + * + * const c = math.complex(3.24, -2.71) + * math.floor(c) // returns Complex 3 - 3i + * math.floor(c, 1) // returns Complex 3.2 -2.8i + * + * math.floor([3.2, 3.8, -4.7]) // returns Array [3, 3, -5] + * math.floor([3.21, 3.82, -4.71], 1) // returns Array [3.2, 3.8, -4.8] + * + * math.floor(math.tau, [2, 3]) // returns Array [6.28, 6.283] + * + * // Note that floor(array, array) currently not implemented. + * + * See also: + * + * ceil, fix, round + * + * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed('floor', { + number: floorNumber.signatures.number, + 'number,number': floorNumber.signatures['number,number'], + Complex: function Complex(x) { + return x.floor(); + }, + 'Complex, number': function Complex_number(x, n) { + return x.floor(n); + }, + 'Complex, BigNumber': function Complex_BigNumber(x, n) { + return x.floor(n.toNumber()); + }, + BigNumber: function BigNumber(x) { + if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) { + return round(x); + } else { + return x.floor(); + } + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, n) { + if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) { + return round(x, n); + } else { + return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_FLOOR); + } + }, + Fraction: function Fraction(x) { + return x.floor(); + }, + 'Fraction, number': function Fraction_number(x, n) { + return x.floor(n); + }, + 'Fraction, BigNumber': function Fraction_BigNumber(x, n) { + return x.floor(n.toNumber()); + }, + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since floor(0) = 0 + return deepMap(x, self, true); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // deep map collection, skip zeros since ceil(0) = 0 + return deepMap(x, i => self(i, n), true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }), + 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }), + 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(self => (x, y) => { + if (equalScalar(x, 0)) return zeros(y.size(), y.storage()); + if (y.storage() === 'dense') { + return matAlgo14xDs(y, x, self, true); + } + return matAlgo12xSfs(y, x, self, true); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/gcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/gcd.js new file mode 100644 index 0000000..6214af1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/gcd.js @@ -0,0 +1,153 @@ +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMod } from './mod.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { ArgumentsError } from '../../error/ArgumentsError.js'; +var name = 'gcd'; +var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'BigNumber', 'DenseMatrix', 'concat']; +var gcdTypes = 'number | BigNumber | Fraction | Matrix | Array'; +var gcdManyTypesSignature = "".concat(gcdTypes, ", ").concat(gcdTypes, ", ...").concat(gcdTypes); +function is1d(array) { + return !array.some(element => Array.isArray(element)); +} +export var createGcd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + config, + round, + equalScalar, + zeros, + BigNumber, + DenseMatrix, + concat + } = _ref; + var mod = createMod({ + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + }); + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo04xSidSid = createMatAlgo04xSidSid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Calculate the greatest common divisor for two or more values or arrays. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.gcd(a, b) + * math.gcd(a, b, c, ...) + * + * Examples: + * + * math.gcd(8, 12) // returns 4 + * math.gcd(-4, 6) // returns 2 + * math.gcd(25, 15, -10) // returns 5 + * + * math.gcd([8, -4], [12, 6]) // returns [4, 2] + * + * See also: + * + * lcm, xgcd + * + * @param {... number | BigNumber | Fraction | Array | Matrix} args Two or more integer numbers + * @return {number | BigNumber | Fraction | Array | Matrix} The greatest common divisor + */ + return typed(name, { + 'number, number': _gcdNumber, + 'BigNumber, BigNumber': _gcdBigNumber, + 'Fraction, Fraction': (x, y) => x.gcd(y) + }, matrixAlgorithmSuite({ + SS: matAlgo04xSidSid, + DS: matAlgo01xDSid, + Ss: matAlgo10xSids + }), { + [gcdManyTypesSignature]: typed.referToSelf(self => (a, b, args) => { + var res = self(a, b); + for (var i = 0; i < args.length; i++) { + res = self(res, args[i]); + } + return res; + }), + Array: typed.referToSelf(self => array => { + if (array.length === 1 && Array.isArray(array[0]) && is1d(array[0])) { + return self(...array[0]); + } + if (is1d(array)) { + return self(...array); + } + throw new ArgumentsError('gcd() supports only 1d matrices!'); + }), + Matrix: typed.referToSelf(self => matrix => { + return self(matrix.toArray()); + }) + }); + + /** + * Calculate gcd for numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the greatest common denominator of a and b + * @private + */ + function _gcdNumber(a, b) { + if (!isInteger(a) || !isInteger(b)) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + var r; + while (b !== 0) { + r = mod(a, b); + a = b; + b = r; + } + return a < 0 ? -a : a; + } + + /** + * Calculate gcd for BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @returns {BigNumber} Returns greatest common denominator of a and b + * @private + */ + function _gcdBigNumber(a, b) { + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + var zero = new BigNumber(0); + while (!b.isZero()) { + var r = mod(a, b); + a = b; + b = r; + } + return a.lt(zero) ? a.neg() : a; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/hypot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/hypot.js new file mode 100644 index 0000000..081ac3e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/hypot.js @@ -0,0 +1,77 @@ +import { factory } from '../../utils/factory.js'; +import { flatten } from '../../utils/array.js'; +import { isComplex } from '../../utils/is.js'; +var name = 'hypot'; +var dependencies = ['typed', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'sqrt', 'smaller', 'isPositive']; +export var createHypot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + addScalar, + divideScalar, + multiplyScalar, + sqrt, + smaller, + isPositive + } = _ref; + /** + * Calculate the hypotenuse of a list with values. The hypotenuse is defined as: + * + * hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...) + * + * For matrix input, the hypotenuse is calculated for all values in the matrix. + * + * Syntax: + * + * math.hypot(a, b, ...) + * math.hypot([a, b, c, ...]) + * + * Examples: + * + * math.hypot(3, 4) // 5 + * math.hypot(3, 4, 5) // 7.0710678118654755 + * math.hypot([3, 4, 5]) // 7.0710678118654755 + * math.hypot(-2) // 2 + * + * See also: + * + * abs, norm + * + * @param {... number | BigNumber | Array | Matrix} args A list with numeric values or an Array or Matrix. + * Matrix and Array input is flattened and returns a + * single number for the whole matrix. + * @return {number | BigNumber} Returns the hypothenusa of the input values. + */ + return typed(name, { + '... number | BigNumber': _hypot, + Array: _hypot, + Matrix: M => _hypot(flatten(M.toArray())) + }); + + /** + * Calculate the hypotenuse for an Array with values + * @param {Array.} args + * @return {number | BigNumber} Returns the result + * @private + */ + function _hypot(args) { + // code based on `hypot` from es6-shim: + // https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1619-L1633 + var result = 0; + var largest = 0; + for (var i = 0; i < args.length; i++) { + if (isComplex(args[i])) { + throw new TypeError('Unexpected type of argument to hypot'); + } + var value = abs(args[i]); + if (smaller(largest, value)) { + result = multiplyScalar(result, multiplyScalar(divideScalar(largest, value), divideScalar(largest, value))); + result = addScalar(result, 1); + largest = value; + } else { + result = addScalar(result, isPositive(value) ? multiplyScalar(divideScalar(value, largest), divideScalar(value, largest)) : value); + } + } + return multiplyScalar(largest, sqrt(result)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/invmod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/invmod.js new file mode 100644 index 0000000..18ba0c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/invmod.js @@ -0,0 +1,55 @@ +import { factory } from '../../utils/factory.js'; +var name = 'invmod'; +var dependencies = ['typed', 'config', 'BigNumber', 'xgcd', 'equal', 'smaller', 'mod', 'add', 'isInteger']; +export var createInvmod = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + BigNumber, + xgcd, + equal, + smaller, + mod, + add, + isInteger + } = _ref; + /** + * Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation `ax ≣ 1 (mod b)` + * See https://en.wikipedia.org/wiki/Modular_multiplicative_inverse. + * + * Syntax: + * + * math.invmod(a, b) + * + * Examples: + * + * math.invmod(8, 12) // returns NaN + * math.invmod(7, 13) // returns 2 + * math.invmod(15151, 15122) // returns 10429 + * + * See also: + * + * gcd, xgcd + * + * @param {number | BigNumber} a An integer number + * @param {number | BigNumber} b An integer number + * @return {number | BigNumber } Returns an integer number + * where `invmod(a,b)*a ≣ 1 (mod b)` + */ + return typed(name, { + 'number, number': invmod, + 'BigNumber, BigNumber': invmod + }); + function invmod(a, b) { + if (!isInteger(a) || !isInteger(b)) throw new Error('Parameters in function invmod must be integer numbers'); + a = mod(a, b); + if (equal(b, 0)) throw new Error('Divisor must be non zero'); + var res = xgcd(a, b); + res = res.valueOf(); + var [gcd, inv] = res; + if (!equal(gcd, BigNumber(1))) return NaN; + inv = mod(inv, b); + if (smaller(inv, BigNumber(0))) inv = add(inv, b); + return inv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/lcm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/lcm.js new file mode 100644 index 0000000..b82301a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/lcm.js @@ -0,0 +1,110 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { lcmNumber } from '../../plain/number/index.js'; +var name = 'lcm'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'concat']; +export var createLcm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo06xS0S0 = createMatAlgo06xS0S0({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var lcmTypes = 'number | BigNumber | Fraction | Matrix | Array'; + var lcmManySignature = {}; + lcmManySignature["".concat(lcmTypes, ", ").concat(lcmTypes, ", ...").concat(lcmTypes)] = typed.referToSelf(self => (a, b, args) => { + var res = self(a, b); + for (var i = 0; i < args.length; i++) { + res = self(res, args[i]); + } + return res; + }); + + /** + * Calculate the least common multiple for two or more values or arrays. + * + * lcm is defined as: + * + * lcm(a, b) = abs(a * b) / gcd(a, b) + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.lcm(a, b) + * math.lcm(a, b, c, ...) + * + * Examples: + * + * math.lcm(4, 6) // returns 12 + * math.lcm(6, 21) // returns 42 + * math.lcm(6, 21, 5) // returns 210 + * + * math.lcm([4, 6], [6, 21]) // returns [12, 42] + * + * See also: + * + * gcd, xgcd + * + * @param {... number | BigNumber | Array | Matrix} args Two or more integer numbers + * @return {number | BigNumber | Array | Matrix} The least common multiple + */ + return typed(name, { + 'number, number': lcmNumber, + 'BigNumber, BigNumber': _lcmBigNumber, + 'Fraction, Fraction': (x, y) => x.lcm(y) + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + }), lcmManySignature); + + /** + * Calculate lcm for two BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @returns {BigNumber} Returns the least common multiple of a and b + * @private + */ + function _lcmBigNumber(a, b) { + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function lcm must be integer numbers'); + } + if (a.isZero()) { + return a; + } + if (b.isZero()) { + return b; + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + // evaluate lcm here inline to reduce overhead + var prod = a.times(b); + while (!b.isZero()) { + var t = b; + b = a.mod(t); + a = t; + } + return prod.div(a).abs(); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log.js new file mode 100644 index 0000000..7a0e9f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log.js @@ -0,0 +1,72 @@ +import { factory } from '../../utils/factory.js'; +import { logNumber } from '../../plain/number/index.js'; +var name = 'log'; +var dependencies = ['config', 'typed', 'divideScalar', 'Complex']; +export var createLog = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + divideScalar, + Complex + } = _ref; + /** + * Calculate the logarithm of a value. + * + * To avoid confusion with the matrix logarithm, this function does not + * apply to matrices. + * + * Syntax: + * + * math.log(x) + * math.log(x, base) + * + * Examples: + * + * math.log(3.5) // returns 1.252762968495368 + * math.exp(math.log(2.4)) // returns 2.4 + * + * math.pow(10, 4) // returns 10000 + * math.log(10000, 10) // returns 4 + * math.log(10000) / math.log(10) // returns 4 + * + * math.log(1024, 2) // returns 10 + * math.pow(2, 10) // returns 1024 + * + * See also: + * + * exp, log2, log10, log1p + * + * @param {number | BigNumber | Complex} x + * Value for which to calculate the logarithm. + * @param {number | BigNumber | Complex} [base=e] + * Optional base for the logarithm. If not provided, the natural + * logarithm of `x` is calculated. + * @return {number | BigNumber | Complex} + * Returns the logarithm of `x` + */ + return typed(name, { + number: function number(x) { + if (x >= 0 || config.predictable) { + return logNumber(x); + } else { + // negative value -> complex value computation + return new Complex(x, 0).log(); + } + }, + Complex: function Complex(x) { + return x.log(); + }, + BigNumber: function BigNumber(x) { + if (!x.isNegative() || config.predictable) { + return x.ln(); + } else { + // downgrade to number, return Complex valued result + return new Complex(x.toNumber(), 0).log(); + } + }, + 'any, any': typed.referToSelf(self => (x, base) => { + // calculate logarithm for a specified base, log(x, base) + return divideScalar(self(x), self(base)); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log10.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log10.js new file mode 100644 index 0000000..66bd62f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log10.js @@ -0,0 +1,59 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { log10Number } from '../../plain/number/index.js'; +var name = 'log10'; +var dependencies = ['typed', 'config', 'Complex']; +export var createLog10 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex: _Complex + } = _ref; + /** + * Calculate the 10-base logarithm of a value. This is the same as calculating `log(x, 10)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log10(x) + * + * Examples: + * + * math.log10(0.00001) // returns -5 + * math.log10(10000) // returns 4 + * math.log(10000) / math.log(10) // returns 4 + * math.pow(10, 4) // returns 10000 + * + * See also: + * + * exp, log, log1p, log2 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the 10-base logarithm of `x` + */ + return typed(name, { + number: function number(x) { + if (x >= 0 || config.predictable) { + return log10Number(x); + } else { + // negative value -> complex value computation + return new _Complex(x, 0).log().div(Math.LN10); + } + }, + Complex: function Complex(x) { + return new _Complex(x).log().div(Math.LN10); + }, + BigNumber: function BigNumber(x) { + if (!x.isNegative() || config.predictable) { + return x.log(); + } else { + // downgrade to number, return Complex valued result + return new _Complex(x.toNumber(), 0).log().div(Math.LN10); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log1p.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log1p.js new file mode 100644 index 0000000..284d7f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log1p.js @@ -0,0 +1,81 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { log1p as _log1p } from '../../utils/number.js'; +var name = 'log1p'; +var dependencies = ['typed', 'config', 'divideScalar', 'log', 'Complex']; +export var createLog1p = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + divideScalar, + log, + Complex + } = _ref; + /** + * Calculate the logarithm of a `value+1`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log1p(x) + * math.log1p(x, base) + * + * Examples: + * + * math.log1p(2.5) // returns 1.252762968495368 + * math.exp(math.log1p(1.4)) // returns 2.4 + * + * math.pow(10, 4) // returns 10000 + * math.log1p(9999, 10) // returns 4 + * math.log1p(9999) / math.log(10) // returns 4 + * + * See also: + * + * exp, log, log2, log10 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm of `x+1`. + * @param {number | BigNumber | Complex} [base=e] + * Optional base for the logarithm. If not provided, the natural + * logarithm of `x+1` is calculated. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the logarithm of `x+1` + */ + return typed(name, { + number: function number(x) { + if (x >= -1 || config.predictable) { + return _log1p(x); + } else { + // negative value -> complex value computation + return _log1pComplex(new Complex(x, 0)); + } + }, + Complex: _log1pComplex, + BigNumber: function BigNumber(x) { + var y = x.plus(1); + if (!y.isNegative() || config.predictable) { + return y.ln(); + } else { + // downgrade to number, return Complex valued result + return _log1pComplex(new Complex(x.toNumber(), 0)); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)), + 'any, any': typed.referToSelf(self => (x, base) => { + // calculate logarithm for a specified base, log1p(x, base) + return divideScalar(self(x), log(base)); + }) + }); + + /** + * Calculate the natural logarithm of a complex number + 1 + * @param {Complex} x + * @returns {Complex} + * @private + */ + function _log1pComplex(x) { + var xRe1p = x.re + 1; + return new Complex(Math.log(Math.sqrt(xRe1p * xRe1p + x.im * x.im)), Math.atan2(x.im, xRe1p)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log2.js new file mode 100644 index 0000000..0264916 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/log2.js @@ -0,0 +1,68 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { log2Number } from '../../plain/number/index.js'; +var name = 'log2'; +var dependencies = ['typed', 'config', 'Complex']; +export var createLog2 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex + } = _ref; + /** + * Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.log2(x) + * + * Examples: + * + * math.log2(0.03125) // returns -5 + * math.log2(16) // returns 4 + * math.log2(16) / math.log2(2) // returns 4 + * math.pow(2, 4) // returns 16 + * + * See also: + * + * exp, log, log1p, log10 + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the logarithm. + * @return {number | BigNumber | Complex | Array | Matrix} + * Returns the 2-base logarithm of `x` + */ + return typed(name, { + number: function number(x) { + if (x >= 0 || config.predictable) { + return log2Number(x); + } else { + // negative value -> complex value computation + return _log2Complex(new Complex(x, 0)); + } + }, + Complex: _log2Complex, + BigNumber: function BigNumber(x) { + if (!x.isNegative() || config.predictable) { + return x.log(2); + } else { + // downgrade to number, return Complex valued result + return _log2Complex(new Complex(x.toNumber(), 0)); + } + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); + + /** + * Calculate log2 for a complex value + * @param {Complex} x + * @returns {Complex} + * @private + */ + function _log2Complex(x) { + var newX = Math.sqrt(x.re * x.re + x.im * x.im); + return new Complex(Math.log2 ? Math.log2(newX) : Math.log(newX) / Math.LN2, Math.atan2(x.im, x.re) / Math.LN2); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/mod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/mod.js new file mode 100644 index 0000000..18953f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/mod.js @@ -0,0 +1,133 @@ +import { factory } from '../../utils/factory.js'; +import { createFloor } from './floor.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'mod'; +var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +export var createMod = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + var floor = createFloor({ + typed, + config, + round, + matrix, + equalScalar, + zeros, + DenseMatrix + }); + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo05xSfSf = createMatAlgo05xSfSf({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Calculates the modulus, the remainder of an integer division. + * + * For matrices, the function is evaluated element wise. + * + * The modulus is defined as: + * + * x - y * floor(x / y) + * + * See https://en.wikipedia.org/wiki/Modulo_operation. + * + * Syntax: + * + * math.mod(x, y) + * + * Examples: + * + * math.mod(8, 3) // returns 2 + * math.mod(11, 2) // returns 1 + * + * function isOdd(x) { + * return math.mod(x, 2) != 0 + * } + * + * isOdd(2) // returns false + * isOdd(3) // returns true + * + * See also: + * + * divide + * + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Dividend + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} y Divisor + * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the remainder of `x` divided by `y`. + */ + return typed(name, { + 'number, number': _modNumber, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return y.isZero() ? x : x.sub(y.mul(floor(x.div(y)))); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + if (y === 0n) { + return x; + } + if (x < 0) { + var m = x % y; + return m === 0n ? m : m + y; + } + return x % y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return y.equals(0) ? x : x.sub(y.mul(floor(x.div(y)))); + } + }, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); + + /** + * Calculate the modulus of two numbers + * @param {number} x + * @param {number} y + * @returns {number} res + * @private + */ + function _modNumber(x, y) { + // We don't use JavaScript's % operator here as this doesn't work + // correctly for x < 0 and x === 0 + // see https://en.wikipedia.org/wiki/Modulo_operation + + // We use mathjs floor to handle errors associated with + // precision float approximation + return y === 0 ? x : x - y * floor(x / y); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiply.js new file mode 100644 index 0000000..ddcafc3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiply.js @@ -0,0 +1,880 @@ +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +import { arraySize } from '../../utils/array.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +var name = 'multiply'; +var dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'equalScalar', 'dot']; +export var createMultiply = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + addScalar, + multiplyScalar, + equalScalar, + dot + } = _ref; + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + function _validateMatrixDimensions(size1, size2) { + // check left operand dimensions + switch (size1.length) { + case 1: + // check size2 + switch (size2.length) { + case 1: + // Vector x Vector + if (size1[0] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Vectors must have the same length'); + } + break; + case 2: + // Vector x Matrix + if (size1[0] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Vector length (' + size1[0] + ') must match Matrix rows (' + size2[0] + ')'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)'); + } + break; + case 2: + // check size2 + switch (size2.length) { + case 1: + // Matrix x Vector + if (size1[1] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Matrix columns (' + size1[1] + ') must match Vector length (' + size2[0] + ')'); + } + break; + case 2: + // Matrix x Matrix + if (size1[1] !== size2[0]) { + // throw error + throw new RangeError('Dimension mismatch in multiplication. Matrix A columns (' + size1[1] + ') must match Matrix B rows (' + size2[0] + ')'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)'); + } + break; + default: + throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix A has ' + size1.length + ' dimensions)'); + } + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (N) + * @param {Matrix} b Dense Vector (N) + * + * @return {number} Scalar value + */ + function _multiplyVectorVector(a, b, n) { + // check empty vector + if (n === 0) { + throw new Error('Cannot multiply two empty vectors'); + } + return dot(a, b); + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (M) + * @param {Matrix} b Matrix (MxN) + * + * @return {Matrix} Dense Vector (N) + */ + function _multiplyVectorMatrix(a, b) { + // process storage + if (b.storage() !== 'dense') { + throw new Error('Support for SparseMatrix not implemented'); + } + return _multiplyVectorDenseMatrix(a, b); + } + + /** + * C = A * B + * + * @param {Matrix} a Dense Vector (M) + * @param {Matrix} b Dense Matrix (MxN) + * + * @return {Matrix} Dense Vector (N) + */ + function _multiplyVectorDenseMatrix(a, b) { + // a dense + var adata = a._data; + var asize = a._size; + var adt = a._datatype || a.getDataType(); + // b dense + var bdata = b._data; + var bsize = b._size; + var bdt = b._datatype || b.getDataType(); + // rows & columns + var alength = asize[0]; + var bcolumns = bsize[1]; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + var c = []; + + // loop matrix columns + for (var j = 0; j < bcolumns; j++) { + // sum (do not initialize it with zero) + var sum = mf(adata[0], bdata[0][j]); + // loop vector + for (var i = 1; i < alength; i++) { + // multiply & accumulate + sum = af(sum, mf(adata[i], bdata[i][j])); + } + c[j] = sum; + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a Matrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} Dense Vector (M) + */ + var _multiplyMatrixVector = typed('_multiplyMatrixVector', { + 'DenseMatrix, any': _multiplyDenseMatrixVector, + 'SparseMatrix, any': _multiplySparseMatrixVector + }); + + /** + * C = A * B + * + * @param {Matrix} a Matrix (MxN) + * @param {Matrix} b Matrix (NxC) + * + * @return {Matrix} Matrix (MxC) + */ + var _multiplyMatrixMatrix = typed('_multiplyMatrixMatrix', { + 'DenseMatrix, DenseMatrix': _multiplyDenseMatrixDenseMatrix, + 'DenseMatrix, SparseMatrix': _multiplyDenseMatrixSparseMatrix, + 'SparseMatrix, DenseMatrix': _multiplySparseMatrixDenseMatrix, + 'SparseMatrix, SparseMatrix': _multiplySparseMatrixSparseMatrix + }); + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} Dense Vector (M) + */ + function _multiplyDenseMatrixVector(a, b) { + // a dense + var adata = a._data; + var asize = a._size; + var adt = a._datatype || a.getDataType(); + // b dense + var bdata = b._data; + var bdt = b._datatype || b.getDataType(); + // rows & columns + var arows = asize[0]; + var acolumns = asize[1]; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + var c = []; + + // loop matrix a rows + for (var i = 0; i < arows; i++) { + // current row + var row = adata[i]; + // sum (do not initialize it with zero) + var sum = mf(row[0], bdata[0]); + // loop matrix a columns + for (var j = 1; j < acolumns; j++) { + // multiply & accumulate + sum = af(sum, mf(row[j], bdata[j])); + } + c[i] = sum; + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [arows], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b DenseMatrix (NxC) + * + * @return {Matrix} DenseMatrix (MxC) + */ + function _multiplyDenseMatrixDenseMatrix(a, b) { + // getDataType() + // a dense + var adata = a._data; + var asize = a._size; + var adt = a._datatype || a.getDataType(); + // b dense + var bdata = b._data; + var bsize = b._size; + var bdt = b._datatype || b.getDataType(); + // rows & columns + var arows = asize[0]; + var acolumns = asize[1]; + var bcolumns = bsize[1]; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + var c = []; + + // loop matrix a rows + for (var i = 0; i < arows; i++) { + // current row + var row = adata[i]; + // initialize row array + c[i] = []; + // loop matrix b columns + for (var j = 0; j < bcolumns; j++) { + // sum (avoid initializing sum to zero) + var sum = mf(row[0], bdata[0][j]); + // loop matrix a columns + for (var x = 1; x < acolumns; x++) { + // multiply & accumulate + sum = af(sum, mf(row[x], bdata[x][j])); + } + c[i][j] = sum; + } + } + + // return matrix + return a.createDenseMatrix({ + data: c, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a DenseMatrix (MxN) + * @param {Matrix} b SparseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplyDenseMatrixSparseMatrix(a, b) { + // a dense + var adata = a._data; + var asize = a._size; + var adt = a._datatype || a.getDataType(); + // b sparse + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + // validate b matrix + if (!bvalues) { + throw new Error('Cannot multiply Dense Matrix times Pattern only Matrix'); + } + // rows & columns + var arows = asize[0]; + var bcolumns = bsize[1]; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + // equalScalar signature to use + var eq = equalScalar; + // zero value + var zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // result + var cvalues = []; + var cindex = []; + var cptr = []; + // c matrix + var c = b.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // loop b columns + for (var jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // indeces in column jb + var kb0 = bptr[jb]; + var kb1 = bptr[jb + 1]; + // do not process column jb if no data exists + if (kb1 > kb0) { + // last row mark processed + var last = 0; + // loop a rows + for (var i = 0; i < arows; i++) { + // column mark + var mark = i + 1; + // C[i, jb] + var cij = void 0; + // values in b column j + for (var kb = kb0; kb < kb1; kb++) { + // row + var ib = bindex[kb]; + // check value has been initialized + if (last !== mark) { + // first value in column jb + cij = mf(adata[i][ib], bvalues[kb]); + // update mark + last = mark; + } else { + // accumulate value + cij = af(cij, mf(adata[i][ib], bvalues[kb])); + } + } + // check column has been processed and value != 0 + if (last === mark && !eq(cij, zero)) { + // push row & value + cindex.push(i); + cvalues.push(cij); + } + } + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b Dense Vector (N) + * + * @return {Matrix} SparseMatrix (M, 1) + */ + function _multiplySparseMatrixVector(a, b) { + // a sparse + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // validate a matrix + if (!avalues) { + throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix'); + } + // b dense + var bdata = b._data; + var bdt = b._datatype || b.getDataType(); + // rows & columns + var arows = a._size[0]; + var brows = b._size[0]; + // result + var cvalues = []; + var cindex = []; + var cptr = []; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + // equalScalar signature to use + var eq = equalScalar; + // zero value + var zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // workspace + var x = []; + // vector with marks indicating a value x[i] exists in a given column + var w = []; + + // update ptr + cptr[0] = 0; + // rows in b + for (var ib = 0; ib < brows; ib++) { + // b[ib] + var vbi = bdata[ib]; + // check b[ib] != 0, avoid loops + if (!eq(vbi, zero)) { + // A values & index in ib column + for (var ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // a row + var ia = aindex[ka]; + // check value exists in current j + if (!w[ia]) { + // ia is new entry in j + w[ia] = true; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(vbi, avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(vbi, avalues[ka])); + } + } + } + } + // copy values from x to column jb of c + for (var p1 = cindex.length, p = 0; p < p1; p++) { + // row + var ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + // update ptr + cptr[1] = cindex.length; + + // matrix to return + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, 1], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b DenseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplySparseMatrixDenseMatrix(a, b) { + // a sparse + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // validate a matrix + if (!avalues) { + throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix'); + } + // b dense + var bdata = b._data; + var bdt = b._datatype || b.getDataType(); + // rows & columns + var arows = a._size[0]; + var brows = b._size[0]; + var bcolumns = b._size[1]; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + // equalScalar signature to use + var eq = equalScalar; + // zero value + var zero = 0; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + } + + // result + var cvalues = []; + var cindex = []; + var cptr = []; + // c matrix + var c = a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // workspace + var x = []; + // vector with marks indicating a value x[i] exists in a given column + var w = []; + + // loop b columns + for (var jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // mark in workspace for current column + var mark = jb + 1; + // rows in jb + for (var ib = 0; ib < brows; ib++) { + // b[ib, jb] + var vbij = bdata[ib][jb]; + // check b[ib, jb] != 0, avoid loops + if (!eq(vbij, zero)) { + // A values & index in ib column + for (var ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // a row + var ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(vbij, avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(vbij, avalues[ka])); + } + } + } + } + // copy values from x to column jb of c + for (var p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) { + // row + var ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * C = A * B + * + * @param {Matrix} a SparseMatrix (MxN) + * @param {Matrix} b SparseMatrix (NxC) + * + * @return {Matrix} SparseMatrix (MxC) + */ + function _multiplySparseMatrixSparseMatrix(a, b) { + // a sparse + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // b sparse + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // rows & columns + var arows = a._size[0]; + var bcolumns = b._size[1]; + // flag indicating both matrices (a & b) contain data + var values = avalues && bvalues; + + // datatype + var dt; + // addScalar signature to use + var af = addScalar; + // multiplyScalar signature to use + var mf = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + // datatype + dt = adt; + // find signatures that matches (dt, dt) + af = typed.find(addScalar, [dt, dt]); + mf = typed.find(multiplyScalar, [dt, dt]); + } + + // result + var cvalues = values ? [] : undefined; + var cindex = []; + var cptr = []; + // c matrix + var c = a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [arows, bcolumns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + + // workspace + var x = values ? [] : undefined; + // vector with marks indicating a value x[i] exists in a given column + var w = []; + // variables + var ka, ka0, ka1, kb, kb0, kb1, ia, ib; + // loop b columns + for (var jb = 0; jb < bcolumns; jb++) { + // update ptr + cptr[jb] = cindex.length; + // mark in workspace for current column + var mark = jb + 1; + // B values & index in j + for (kb0 = bptr[jb], kb1 = bptr[jb + 1], kb = kb0; kb < kb1; kb++) { + // b row + ib = bindex[kb]; + // check we need to process values + if (values) { + // loop values in a[:,ib] + for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // row + ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + // x(ia) = A + x[ia] = mf(bvalues[kb], avalues[ka]); + } else { + // i exists in C already + x[ia] = af(x[ia], mf(bvalues[kb], avalues[ka])); + } + } + } else { + // loop values in a[:,ib] + for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) { + // row + ia = aindex[ka]; + // check value exists in current j + if (w[ia] !== mark) { + // ia is new entry in j + w[ia] = mark; + // add i to pattern of C + cindex.push(ia); + } + } + } + } + // check we need to process matrix values (pattern matrix) + if (values) { + // copy values from x to column jb of c + for (var p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) { + // row + var ic = cindex[p]; + // copy value + cvalues[p] = x[ic]; + } + } + } + // update ptr + cptr[bcolumns] = cindex.length; + + // return sparse matrix + return c; + } + + /** + * Multiply two or more values, `x * y`. + * For matrices, the matrix product is calculated. + * + * Syntax: + * + * math.multiply(x, y) + * math.multiply(x, y, z, ...) + * + * Examples: + * + * math.multiply(4, 5.2) // returns number 20.8 + * math.multiply(2, 3, 4) // returns number 24 + * + * const a = math.complex(2, 3) + * const b = math.complex(4, 1) + * math.multiply(a, b) // returns Complex 5 + 14i + * + * const c = [[1, 2], [4, 3]] + * const d = [[1, 2, 3], [3, -4, 7]] + * math.multiply(c, d) // returns Array [[7, -6, 17], [13, -4, 33]] + * + * const e = math.unit('2.1 km') + * math.multiply(3, e) // returns Unit 6.3 km + * + * See also: + * + * divide, prod, cross, dot + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to multiply + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to multiply + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y` + */ + return typed(name, multiplyScalar, { + // we extend the signatures of multiplyScalar with signatures dealing with matrices + + 'Array, Array': typed.referTo('Matrix, Matrix', selfMM => (x, y) => { + // check dimensions + _validateMatrixDimensions(arraySize(x), arraySize(y)); + + // use dense matrix implementation + var m = selfMM(matrix(x), matrix(y)); + // return array or scalar + return isMatrix(m) ? m.valueOf() : m; + }), + 'Matrix, Matrix': function Matrix_Matrix(x, y) { + // dimensions + var xsize = x.size(); + var ysize = y.size(); + + // check dimensions + _validateMatrixDimensions(xsize, ysize); + + // process dimensions + if (xsize.length === 1) { + // process y dimensions + if (ysize.length === 1) { + // Vector * Vector + return _multiplyVectorVector(x, y, xsize[0]); + } + // Vector * Matrix + return _multiplyVectorMatrix(x, y); + } + // process y dimensions + if (ysize.length === 1) { + // Matrix * Vector + return _multiplyMatrixVector(x, y); + } + // Matrix * Matrix + return _multiplyMatrixMatrix(x, y); + }, + 'Matrix, Array': typed.referTo('Matrix,Matrix', selfMM => (x, y) => selfMM(x, matrix(y))), + 'Array, Matrix': typed.referToSelf(self => (x, y) => { + // use Matrix * Matrix implementation + return self(matrix(x, y.storage()), y); + }), + 'SparseMatrix, any': function SparseMatrix_any(x, y) { + return matAlgo11xS0s(x, y, multiplyScalar, false); + }, + 'DenseMatrix, any': function DenseMatrix_any(x, y) { + return matAlgo14xDs(x, y, multiplyScalar, false); + }, + 'any, SparseMatrix': function any_SparseMatrix(x, y) { + return matAlgo11xS0s(y, x, multiplyScalar, true); + }, + 'any, DenseMatrix': function any_DenseMatrix(x, y) { + return matAlgo14xDs(y, x, multiplyScalar, true); + }, + 'Array, any': function Array_any(x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(x), y, multiplyScalar, false).valueOf(); + }, + 'any, Array': function any_Array(x, y) { + // use matrix implementation + return matAlgo14xDs(matrix(y), x, multiplyScalar, true).valueOf(); + }, + 'any, any': multiplyScalar, + 'any, any, ...any': typed.referToSelf(self => (x, y, rest) => { + var result = self(x, y); + for (var i = 0; i < rest.length; i++) { + result = self(result, rest[i]); + } + return result; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiplyScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiplyScalar.js new file mode 100644 index 0000000..f46b18f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/multiplyScalar.js @@ -0,0 +1,38 @@ +import { factory } from '../../utils/factory.js'; +import { multiplyNumber } from '../../plain/number/index.js'; +var name = 'multiplyScalar'; +var dependencies = ['typed']; +export var createMultiplyScalar = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Multiply two scalar values, `x * y`. + * This function is meant for internal use: it is used by the public function + * `multiply` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value to multiply + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to multiply + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Multiplication of `x` and `y` + * @private + */ + return typed('multiplyScalar', { + 'number, number': multiplyNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.mul(y); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.times(y); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x * y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return x.mul(y); + }, + 'number | Fraction | BigNumber | Complex, Unit': (x, y) => y.multiply(x), + 'Unit, number | Fraction | BigNumber | Complex | Unit': (x, y) => x.multiply(y) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/norm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/norm.js new file mode 100644 index 0000000..c307ca3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/norm.js @@ -0,0 +1,287 @@ +import { factory } from '../../utils/factory.js'; +var name = 'norm'; +var dependencies = ['typed', 'abs', 'add', 'pow', 'conj', 'sqrt', 'multiply', 'equalScalar', 'larger', 'smaller', 'matrix', 'ctranspose', 'eigs']; +export var createNorm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + add, + pow, + conj, + sqrt, + multiply, + equalScalar, + larger, + smaller, + matrix, + ctranspose, + eigs + } = _ref; + /** + * Calculate the norm of a number, vector or matrix. + * + * The second parameter p is optional. If not provided, it defaults to 2. + * + * Syntax: + * + * math.norm(x) + * math.norm(x, p) + * + * Examples: + * + * math.abs(-3.5) // returns 3.5 + * math.norm(-3.5) // returns 3.5 + * + * math.norm(math.complex(3, -4)) // returns 5 + * + * math.norm([1, 2, -3], Infinity) // returns 3 + * math.norm([1, 2, -3], -Infinity) // returns 1 + * + * math.norm([3, 4], 2) // returns 5 + * + * math.norm([[1, 2], [3, 4]], 1) // returns 6 + * math.norm([[1, 2], [3, 4]], 'inf') // returns 7 + * math.norm([[1, 2], [3, 4]], 'fro') // returns 5.477225575051661 + * + * See also: + * + * abs, hypot + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * Value for which to calculate the norm + * @param {number | BigNumber | string} [p=2] + * Vector space. + * Supported numbers include Infinity and -Infinity. + * Supported strings are: 'inf', '-inf', and 'fro' (The Frobenius norm) + * @return {number | BigNumber} the p-norm + */ + return typed(name, { + number: Math.abs, + Complex: function Complex(x) { + return x.abs(); + }, + BigNumber: function BigNumber(x) { + // norm(x) = abs(x) + return x.abs(); + }, + boolean: function boolean(x) { + // norm(x) = abs(x) + return Math.abs(x); + }, + Array: function Array(x) { + return _norm(matrix(x), 2); + }, + Matrix: function Matrix(x) { + return _norm(x, 2); + }, + 'Array, number | BigNumber | string': function Array_number__BigNumber__string(x, p) { + return _norm(matrix(x), p); + }, + 'Matrix, number | BigNumber | string': function Matrix_number__BigNumber__string(x, p) { + return _norm(x, p); + } + }); + + /** + * Calculate the plus infinity norm for a vector + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _vectorNormPlusInfinity(x) { + // norm(x, Infinity) = max(abs(x)) + var pinf = 0; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + var v = abs(value); + if (larger(v, pinf)) { + pinf = v; + } + }, true); + return pinf; + } + + /** + * Calculate the minus infinity norm for a vector + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _vectorNormMinusInfinity(x) { + // norm(x, -Infinity) = min(abs(x)) + var ninf; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + var v = abs(value); + if (!ninf || smaller(v, ninf)) { + ninf = v; + } + }, true); + return ninf || 0; + } + + /** + * Calculate the norm for a vector + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _vectorNorm(x, p) { + // check p + if (p === Number.POSITIVE_INFINITY || p === 'inf') { + return _vectorNormPlusInfinity(x); + } + if (p === Number.NEGATIVE_INFINITY || p === '-inf') { + return _vectorNormMinusInfinity(x); + } + if (p === 'fro') { + return _norm(x, 2); + } + if (typeof p === 'number' && !isNaN(p)) { + // check p != 0 + if (!equalScalar(p, 0)) { + // norm(x, p) = sum(abs(xi) ^ p) ^ 1/p + var n = 0; + // skip zeros since abs(0) === 0 + x.forEach(function (value) { + n = add(pow(abs(value), p), n); + }, true); + return pow(n, 1 / p); + } + return Number.POSITIVE_INFINITY; + } + // invalid parameter value + throw new Error('Unsupported parameter value'); + } + + /** + * Calculate the Frobenius norm for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormFrobenius(x) { + // norm(x) = sqrt(sum(diag(x'x))) + var fro = 0; + x.forEach(function (value, index) { + fro = add(fro, multiply(value, conj(value))); + }); + return abs(sqrt(fro)); + } + + /** + * Calculate the norm L1 for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormOne(x) { + // norm(x) = the largest column sum + var c = []; + // result + var maxc = 0; + // skip zeros since abs(0) == 0 + x.forEach(function (value, index) { + var j = index[1]; + var cj = add(c[j] || 0, abs(value)); + if (larger(cj, maxc)) { + maxc = cj; + } + c[j] = cj; + }, true); + return maxc; + } + + /** + * Calculate the norm L2 for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormTwo(x) { + // norm(x) = sqrt( max eigenvalue of A*.A) + var sizeX = x.size(); + if (sizeX[0] !== sizeX[1]) { + throw new RangeError('Invalid matrix dimensions'); + } + var tx = ctranspose(x); + var squaredX = multiply(tx, x); + var eigenVals = eigs(squaredX).values.toArray(); + var rho = eigenVals[eigenVals.length - 1]; + return abs(sqrt(rho)); + } + + /** + * Calculate the infinity norm for a matrix + * @param {Matrix} x + * @returns {number} Returns the norm + * @private + */ + function _matrixNormInfinity(x) { + // norm(x) = the largest row sum + var r = []; + // result + var maxr = 0; + // skip zeros since abs(0) == 0 + x.forEach(function (value, index) { + var i = index[0]; + var ri = add(r[i] || 0, abs(value)); + if (larger(ri, maxr)) { + maxr = ri; + } + r[i] = ri; + }, true); + return maxr; + } + + /** + * Calculate the norm for a 2D Matrix (M*N) + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _matrixNorm(x, p) { + // check p + if (p === 1) { + return _matrixNormOne(x); + } + if (p === Number.POSITIVE_INFINITY || p === 'inf') { + return _matrixNormInfinity(x); + } + if (p === 'fro') { + return _matrixNormFrobenius(x); + } + if (p === 2) { + return _matrixNormTwo(x); + } // invalid parameter value + + throw new Error('Unsupported parameter value ' + p); + } + + /** + * Calculate the norm for an array + * @param {Matrix} x + * @param {number | string} p + * @returns {number} Returns the norm + * @private + */ + function _norm(x, p) { + // size + var sizeX = x.size(); + + // check if it is a vector + if (sizeX.length === 1) { + return _vectorNorm(x, p); + } + // MxN matrix + if (sizeX.length === 2) { + if (sizeX[0] && sizeX[1]) { + return _matrixNorm(x, p); + } else { + throw new RangeError('Invalid matrix dimensions'); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoot.js new file mode 100644 index 0000000..505e18b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoot.js @@ -0,0 +1,166 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { nthRootNumber } from '../../plain/number/index.js'; +var name = 'nthRoot'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'concat']; +export var createNthRoot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + BigNumber: _BigNumber, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo06xS0S0 = createMatAlgo06xS0S0({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Calculate the nth root of a value. + * The principal nth root of a positive real number A, is the positive real + * solution of the equation + * + * x^root = A + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.nthRoot(a) + * math.nthRoot(a, root) + * + * Examples: + * + * math.nthRoot(9, 2) // returns 3 (since 3^2 == 9) + * math.sqrt(9) // returns 3 (since 3^2 == 9) + * math.nthRoot(64, 3) // returns 4 (since 4^3 == 64) + * + * See also: + * + * sqrt, pow + * + * @param {number | BigNumber | Array | Matrix | Complex} a + * Value for which to calculate the nth root + * @param {number | BigNumber} [root=2] The root. + * @return {number | Complex | Array | Matrix} Returns the nth root of `a` + */ + function complexErr() { + throw new Error('Complex number not supported in function nthRoot. Use nthRoots instead.'); + } + return typed(name, { + number: nthRootNumber, + 'number, number': nthRootNumber, + BigNumber: x => _bigNthRoot(x, new _BigNumber(2)), + 'BigNumber, BigNumber': _bigNthRoot, + Complex: complexErr, + 'Complex, number': complexErr, + Array: typed.referTo('DenseMatrix,number', selfDn => x => selfDn(matrix(x), 2).valueOf()), + DenseMatrix: typed.referTo('DenseMatrix,number', selfDn => x => selfDn(x, 2)), + SparseMatrix: typed.referTo('SparseMatrix,number', selfSn => x => selfSn(x, 2)), + 'SparseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // sparse + sparse + return matAlgo06xS0S0(x, y, self); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }), + 'DenseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // dense + sparse + return matAlgo01xDSid(x, y, self, false); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }), + 'Array, SparseMatrix': typed.referTo('DenseMatrix,SparseMatrix', selfDS => (x, y) => selfDS(matrix(x), y)), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // density must be one (no zeros in matrix) + if (y.density() === 1) { + // sparse - scalar + return matAlgo11xS0s(y, x, self, true); + } else { + // throw exception + throw new Error('Root must be non-zero'); + } + }) + }, matrixAlgorithmSuite({ + scalar: 'number | BigNumber', + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: false + })); + + /** + * Calculate the nth root of a for BigNumbers, solve x^root == a + * https://rosettacode.org/wiki/Nth_root#JavaScript + * @param {BigNumber} a + * @param {BigNumber} root + * @private + */ + function _bigNthRoot(a, root) { + var precision = _BigNumber.precision; + var Big = _BigNumber.clone({ + precision: precision + 2 + }); + var zero = new _BigNumber(0); + var one = new Big(1); + var inv = root.isNegative(); + if (inv) { + root = root.neg(); + } + if (root.isZero()) { + throw new Error('Root must be non-zero'); + } + if (a.isNegative() && !root.abs().mod(2).equals(1)) { + throw new Error('Root must be odd when a is negative.'); + } + + // edge cases zero and infinity + if (a.isZero()) { + return inv ? new Big(Infinity) : 0; + } + if (!a.isFinite()) { + return inv ? zero : a; + } + var x = a.abs().pow(one.div(root)); + // If a < 0, we require that root is an odd integer, + // so (-1) ^ (1/root) = -1 + x = a.isNeg() ? x.neg() : x; + return new _BigNumber((inv ? one.div(x) : x).toPrecision(precision)); + } +}); +export var createNthRootNumber = /* #__PURE__ */factory(name, ['typed'], _ref2 => { + var { + typed + } = _ref2; + return typed(name, { + number: nthRootNumber, + 'number, number': nthRootNumber + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoots.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoots.js new file mode 100644 index 0000000..f84347b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/nthRoots.js @@ -0,0 +1,111 @@ +import { factory } from '../../utils/factory.js'; +var name = 'nthRoots'; +var dependencies = ['config', 'typed', 'divideScalar', 'Complex']; +export var createNthRoots = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + divideScalar, + Complex + } = _ref; + /** + * Each function here returns a real multiple of i as a Complex value. + * @param {number} val + * @return {Complex} val, i*val, -val or -i*val for index 0, 1, 2, 3 + */ + // This is used to fix float artifacts for zero-valued components. + var _calculateExactResult = [function realPos(val) { + return new Complex(val, 0); + }, function imagPos(val) { + return new Complex(0, val); + }, function realNeg(val) { + return new Complex(-val, 0); + }, function imagNeg(val) { + return new Complex(0, -val); + }]; + + /** + * Calculate the nth root of a Complex Number a using De Movire's Theorem. + * @param {Complex} a + * @param {number} root + * @return {Array} array of n Complex Roots + */ + function _nthComplexRoots(a, root) { + if (root < 0) throw new Error('Root must be greater than zero'); + if (root === 0) throw new Error('Root must be non-zero'); + if (root % 1 !== 0) throw new Error('Root must be an integer'); + if (a === 0 || a.abs() === 0) return [new Complex(0, 0)]; + var aIsNumeric = typeof a === 'number'; + var offset; + // determine the offset (argument of a)/(pi/2) + if (aIsNumeric || a.re === 0 || a.im === 0) { + if (aIsNumeric) { + offset = 2 * +(a < 0); // numeric value on the real axis + } else if (a.im === 0) { + offset = 2 * +(a.re < 0); // complex value on the real axis + } else { + offset = 2 * +(a.im < 0) + 1; // complex value on the imaginary axis + } + } + var arg = a.arg(); + var abs = a.abs(); + var roots = []; + var r = Math.pow(abs, 1 / root); + for (var k = 0; k < root; k++) { + var halfPiFactor = (offset + 4 * k) / root; + /** + * If (offset + 4*k)/root is an integral multiple of pi/2 + * then we can produce a more exact result. + */ + if (halfPiFactor === Math.round(halfPiFactor)) { + roots.push(_calculateExactResult[halfPiFactor % 4](r)); + continue; + } + roots.push(new Complex({ + r, + phi: (arg + 2 * Math.PI * k) / root + })); + } + return roots; + } + + /** + * Calculate the nth roots of a value. + * An nth root of a positive real number A, + * is a positive real solution of the equation "x^root = A". + * This function returns an array of complex values. + * + * Syntax: + * + * math.nthRoots(x) + * math.nthRoots(x, root) + * + * Examples: + * + * math.nthRoots(1) + * // returns [ + * // {re: 1, im: 0}, + * // {re: -1, im: 0} + * // ] + * math.nthRoots(1, 3) + * // returns [ + * // { re: 1, im: 0 }, + * // { re: -0.4999999999999998, im: 0.8660254037844387 }, + * // { re: -0.5000000000000004, im: -0.8660254037844385 } + * // ] + * + * See also: + * + * nthRoot, pow, sqrt + * + * @param {number | BigNumber | Fraction | Complex} x Number to be rounded + * @param {number} [root=2] Optional root, default value is 2 + * @return {number | BigNumber | Fraction | Complex} Returns the nth roots + */ + return typed(name, { + Complex: function Complex(x) { + return _nthComplexRoots(x, 2); + }, + 'Complex, number': _nthComplexRoots + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/pow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/pow.js new file mode 100644 index 0000000..5719de7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/pow.js @@ -0,0 +1,192 @@ +import { factory } from '../../utils/factory.js'; +import { isInteger } from '../../utils/number.js'; +import { arraySize as size } from '../../utils/array.js'; +import { powNumber } from '../../plain/number/index.js'; +var name = 'pow'; +var dependencies = ['typed', 'config', 'identity', 'multiply', 'matrix', 'inv', 'fraction', 'number', 'Complex']; +export var createPow = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + identity, + multiply, + matrix, + inv, + number, + fraction, + Complex + } = _ref; + /** + * Calculates the power of x to y, `x ^ y`. + * + * Matrix exponentiation is supported for square matrices `x` and integers `y`: + * when `y` is nonnegative, `x` may be any square matrix; and when `y` is + * negative, `x` must be invertible, and then this function returns + * inv(x)^(-y). + * + * For cubic roots of negative numbers, the function returns the principal + * root by default. In order to let the function return the real root, + * math.js can be configured with `math.config({predictable: true})`. + * To retrieve all cubic roots of a value, use `math.cbrt(x, true)`. + * + * Syntax: + * + * math.pow(x, y) + * + * Examples: + * + * math.pow(2, 3) // returns number 8 + * + * const a = math.complex(2, 3) + * math.pow(a, 2) // returns Complex -5 + 12i + * + * const b = [[1, 2], [4, 3]] + * math.pow(b, 2) // returns Array [[9, 8], [16, 17]] + * + * const c = [[1, 2], [4, 3]] + * math.pow(c, -1) // returns Array [[-0.6, 0.4], [0.8, -0.2]] + * + * See also: + * + * multiply, sqrt, cbrt, nthRoot + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x The base + * @param {number | BigNumber | bigint | Complex} y The exponent + * @return {number | BigNumber | bigint | Complex | Array | Matrix} The value of `x` to the power `y` + */ + return typed(name, { + 'number, number': _pow, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.pow(y); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + if (y.isInteger() || x >= 0 || config.predictable) { + return x.pow(y); + } else { + return new Complex(x.toNumber(), 0).pow(y.toNumber(), 0); + } + }, + 'bigint, bigint': (x, y) => x ** y, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + var result = x.pow(y); + if (result != null) { + return result; + } + if (config.predictable) { + throw new Error('Result of pow is non-rational and cannot be expressed as a fraction'); + } else { + return _pow(x.valueOf(), y.valueOf()); + } + }, + 'Array, number': _powArray, + 'Array, BigNumber': function Array_BigNumber(x, y) { + return _powArray(x, y.toNumber()); + }, + 'Matrix, number': _powMatrix, + 'Matrix, BigNumber': function Matrix_BigNumber(x, y) { + return _powMatrix(x, y.toNumber()); + }, + 'Unit, number | BigNumber': function Unit_number__BigNumber(x, y) { + return x.pow(y); + } + }); + + /** + * Calculates the power of x to y, x^y, for two numbers. + * @param {number} x + * @param {number} y + * @return {number | Complex} res + * @private + */ + function _pow(x, y) { + // Alternatively could define a 'realmode' config option or something, but + // 'predictable' will work for now + if (config.predictable && !isInteger(y) && x < 0) { + // Check to see if y can be represented as a fraction + try { + var yFrac = fraction(y); + var yNum = number(yFrac); + if (y === yNum || Math.abs((y - yNum) / y) < 1e-14) { + if (yFrac.d % 2 === 1) { + return (yFrac.n % 2 === 0 ? 1 : -1) * Math.pow(-x, y); + } + } + } catch (ex) { + // fraction() throws an error if y is Infinity, etc. + } + + // Unable to express y as a fraction, so continue on + } + + // **for predictable mode** x^Infinity === NaN if x < -1 + // N.B. this behavour is different from `Math.pow` which gives + // (-2)^Infinity === Infinity + if (config.predictable && (x < -1 && y === Infinity || x > -1 && x < 0 && y === -Infinity)) { + return NaN; + } + if (isInteger(y) || x >= 0 || config.predictable) { + return powNumber(x, y); + } else { + // TODO: the following infinity checks are duplicated from powNumber. Deduplicate this somehow + + // x^Infinity === 0 if -1 < x < 1 + // A real number 0 is returned instead of complex(0) + if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) { + return 0; + } + return new Complex(x, 0).pow(y, 0); + } + } + + /** + * Calculate the power of a 2d array + * @param {Array} x must be a 2 dimensional, square matrix + * @param {number} y a integer value (positive if `x` is not invertible) + * @returns {Array} + * @private + */ + function _powArray(x, y) { + if (!isInteger(y)) { + throw new TypeError('For A^b, b must be an integer (value is ' + y + ')'); + } + // verify that A is a 2 dimensional square matrix + var s = size(x); + if (s.length !== 2) { + throw new Error('For A^b, A must be 2 dimensional (A has ' + s.length + ' dimensions)'); + } + if (s[0] !== s[1]) { + throw new Error('For A^b, A must be square (size is ' + s[0] + 'x' + s[1] + ')'); + } + if (y < 0) { + try { + return _powArray(inv(x), -y); + } catch (error) { + if (error.message === 'Cannot calculate inverse, determinant is zero') { + throw new TypeError('For A^b, when A is not invertible, b must be a positive integer (value is ' + y + ')'); + } + throw error; + } + } + var res = identity(s[0]).valueOf(); + var px = x; + while (y >= 1) { + if ((y & 1) === 1) { + res = multiply(px, res); + } + y >>= 1; + px = multiply(px, px); + } + return res; + } + + /** + * Calculate the power of a 2d matrix + * @param {Matrix} x must be a 2 dimensional, square matrix + * @param {number} y a positive, integer value + * @returns {Matrix} + * @private + */ + function _powMatrix(x, y) { + return matrix(_powArray(x.valueOf(), y)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/round.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/round.js new file mode 100644 index 0000000..91a9db2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/round.js @@ -0,0 +1,202 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { nearlyEqual, splitNumber } from '../../utils/number.js'; +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +import { roundNumber } from '../../plain/number/index.js'; +var NO_INT = 'Number of decimals in function round must be an integer'; +var name = 'round'; +var dependencies = ['typed', 'config', 'matrix', 'equalScalar', 'zeros', 'BigNumber', 'DenseMatrix']; +export var createRound = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + equalScalar, + zeros, + BigNumber: _BigNumber, + DenseMatrix + } = _ref; + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + function toExponent(epsilon) { + return Math.abs(splitNumber(epsilon).exponent); + } + + /** + * Round a value towards the nearest rounded value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.round(x) + * math.round(x, n) + * math.round(unit, valuelessUnit) + * math.round(unit, n, valuelessUnit) + * + * Examples: + * + * math.round(3.22) // returns number 3 + * math.round(3.82) // returns number 4 + * math.round(-4.2) // returns number -4 + * math.round(-4.7) // returns number -5 + * math.round(3.22, 1) // returns number 3.2 + * math.round(3.88, 1) // returns number 3.9 + * math.round(-4.21, 1) // returns number -4.2 + * math.round(-4.71, 1) // returns number -4.7 + * math.round(math.pi, 3) // returns number 3.142 + * math.round(123.45678, 2) // returns number 123.46 + * + * const c = math.complex(3.2, -2.7) + * math.round(c) // returns Complex 3 - 3i + * + * const unit = math.unit('3.241 cm') + * const cm = math.unit('cm') + * const mm = math.unit('mm') + * math.round(unit, 1, cm) // returns Unit 3.2 cm + * math.round(unit, 1, mm) // returns Unit 32.4 mm + * + * math.round([3.2, 3.8, -4.7]) // returns Array [3, 4, -5] + * + * See also: + * + * ceil, fix, floor + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Value to be rounded + * @param {number | BigNumber | Array} [n=0] Number of decimals + * @param {Unit} [valuelessUnit] A valueless unit + * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value + */ + return typed(name, { + number: function number(x) { + // Handle round off errors by first rounding to relTol precision + var xEpsilon = roundNumber(x, toExponent(config.relTol)); + var xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return roundNumber(xSelected); + }, + 'number, number': function number_number(x, n) { + // Same as number: unless user specifies more decimals than relTol + var epsilonExponent = toExponent(config.relTol); + if (n >= epsilonExponent) { + return roundNumber(x, n); + } + var xEpsilon = roundNumber(x, epsilonExponent); + var xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return roundNumber(xSelected, n); + }, + 'number, BigNumber': function number_BigNumber(x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + return new _BigNumber(x).toDecimalPlaces(n.toNumber()); + }, + Complex: function Complex(x) { + return x.round(); + }, + 'Complex, number': function Complex_number(x, n) { + if (n % 1) { + throw new TypeError(NO_INT); + } + return x.round(n); + }, + 'Complex, BigNumber': function Complex_BigNumber(x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + var _n = n.toNumber(); + return x.round(_n); + }, + BigNumber: function BigNumber(x) { + // Handle round off errors by first rounding to relTol precision + var xEpsilon = new _BigNumber(x).toDecimalPlaces(toExponent(config.relTol)); + var xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return xSelected.toDecimalPlaces(0); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + + // Same as BigNumber: unless user specifies more decimals than relTol + var epsilonExponent = toExponent(config.relTol); + if (n >= epsilonExponent) { + return x.toDecimalPlaces(n.toNumber()); + } + var xEpsilon = x.toDecimalPlaces(epsilonExponent); + var xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x; + return xSelected.toDecimalPlaces(n.toNumber()); + }, + Fraction: function Fraction(x) { + return x.round(); + }, + 'Fraction, number': function Fraction_number(x, n) { + if (n % 1) { + throw new TypeError(NO_INT); + } + return x.round(n); + }, + 'Fraction, BigNumber': function Fraction_BigNumber(x, n) { + if (!n.isInteger()) { + throw new TypeError(NO_INT); + } + return x.round(n.toNumber()); + }, + 'Unit, number, Unit': typed.referToSelf(self => function (x, n, unit) { + var valueless = x.toNumeric(unit); + return unit.multiply(self(valueless, n)); + }), + 'Unit, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)), + 'Unit, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)), + 'Array | Matrix, number, Unit': typed.referToSelf(self => (x, n, unit) => { + // deep map collection, skip zeros since round(0) = 0 + return deepMap(x, value => self(value, n, unit), true); + }), + 'Array | Matrix, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)), + 'Array | Matrix, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)), + 'Array | Matrix': typed.referToSelf(self => x => { + // deep map collection, skip zeros since round(0) = 0 + return deepMap(x, self, true); + }), + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + return matAlgo11xS0s(x, n, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => { + return matAlgo14xDs(x, n, self, false); + }), + 'Array, number | BigNumber': typed.referToSelf(self => (x, n) => { + // use matrix implementation + return matAlgo14xDs(matrix(x), n, self, false).valueOf(); + }), + 'number | Complex | BigNumber | Fraction, SparseMatrix': typed.referToSelf(self => (x, n) => { + // check scalar is zero + if (equalScalar(x, 0)) { + // do not execute algorithm, result will be a zero matrix + return zeros(n.size(), n.storage()); + } + return matAlgo12xSfs(n, x, self, true); + }), + 'number | Complex | BigNumber | Fraction, DenseMatrix': typed.referToSelf(self => (x, n) => { + // check scalar is zero + if (equalScalar(x, 0)) { + // do not execute algorithm, result will be a zero matrix + return zeros(n.size(), n.storage()); + } + return matAlgo14xDs(n, x, self, true); + }), + 'number | Complex | BigNumber | Fraction, Array': typed.referToSelf(self => (x, n) => { + // use matrix implementation + return matAlgo14xDs(matrix(n), x, self, true).valueOf(); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sign.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sign.js new file mode 100644 index 0000000..80cce7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sign.js @@ -0,0 +1,66 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { signNumber } from '../../plain/number/index.js'; +var name = 'sign'; +var dependencies = ['typed', 'BigNumber', 'Fraction', 'complex']; +export var createSign = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber, + complex, + Fraction: _Fraction + } = _ref; + /** + * Compute the sign of a value. The sign of a value x is: + * + * - 1 when x > 0 + * - -1 when x < 0 + * - 0 when x == 0 + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.sign(x) + * + * Examples: + * + * math.sign(3.5) // returns 1 + * math.sign(-4.2) // returns -1 + * math.sign(0) // returns 0 + * + * math.sign([3, 5, -2, 0, 2]) // returns [1, 1, -1, 0, 1] + * + * See also: + * + * abs + * + * @param {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} x + * The number for which to determine the sign + * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit} + * The sign of `x` + */ + return typed(name, { + number: signNumber, + Complex: function Complex(x) { + return x.im === 0 ? complex(signNumber(x.re)) : x.sign(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(x.cmp(0)); + }, + bigint: function bigint(x) { + return x > 0n ? 1n : x < 0n ? -1n : 0n; + }, + Fraction: function Fraction(x) { + return new _Fraction(x.s, 1); + }, + // deep map collection, skip zeros since sign(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)), + Unit: typed.referToSelf(self => x => { + if (!x._isDerived() && x.units[0].unit.offset !== 0) { + throw new TypeError('sign is ambiguous for units with offset'); + } + return typed.find(self, x.valueType())(x.value); + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sqrt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sqrt.js new file mode 100644 index 0000000..af7a1c1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/sqrt.js @@ -0,0 +1,70 @@ +import { factory } from '../../utils/factory.js'; +var name = 'sqrt'; +var dependencies = ['config', 'typed', 'Complex']; +export var createSqrt = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + typed, + Complex + } = _ref; + /** + * Calculate the square root of a value. + * + * For matrices, if you want the matrix square root of a square matrix, + * use the `sqrtm` function. If you wish to apply `sqrt` elementwise to + * a matrix M, use `math.map(M, math.sqrt)`. + * + * Syntax: + * + * math.sqrt(x) + * + * Examples: + * + * math.sqrt(25) // returns 5 + * math.square(5) // returns 25 + * math.sqrt(-4) // returns Complex 2i + * + * See also: + * + * square, multiply, cube, cbrt, sqrtm + * + * @param {number | BigNumber | Complex | Unit} x + * Value for which to calculate the square root. + * @return {number | BigNumber | Complex | Unit} + * Returns the square root of `x` + */ + return typed('sqrt', { + number: _sqrtNumber, + Complex: function Complex(x) { + return x.sqrt(); + }, + BigNumber: function BigNumber(x) { + if (!x.isNegative() || config.predictable) { + return x.sqrt(); + } else { + // negative value -> downgrade to number to do complex value computation + return _sqrtNumber(x.toNumber()); + } + }, + Unit: function Unit(x) { + // Someday will work for complex units when they are implemented + return x.pow(0.5); + } + }); + + /** + * Calculate sqrt for a number + * @param {number} x + * @returns {number | Complex} Returns the square root of x + * @private + */ + function _sqrtNumber(x) { + if (isNaN(x)) { + return NaN; + } else if (x >= 0 || config.predictable) { + return Math.sqrt(x); + } else { + return new Complex(x, 0).sqrt(); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/square.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/square.js new file mode 100644 index 0000000..373b11f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/square.js @@ -0,0 +1,55 @@ +import { factory } from '../../utils/factory.js'; +import { squareNumber } from '../../plain/number/index.js'; +var name = 'square'; +var dependencies = ['typed']; +export var createSquare = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the square of a value, `x * x`. + * To avoid confusion with multiplying a square matrix by itself, + * this function does not apply to matrices. If you wish to square + * every element of a matrix, see the examples. + * + * Syntax: + * + * math.square(x) + * + * Examples: + * + * math.square(2) // returns number 4 + * math.square(3) // returns number 9 + * math.pow(3, 2) // returns number 9 + * math.multiply(3, 3) // returns number 9 + * + * math.map([1, 2, 3, 4], math.square) // returns Array [1, 4, 9, 16] + * + * See also: + * + * multiply, cube, sqrt, pow + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x + * Number for which to calculate the square + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} + * Squared value + */ + return typed(name, { + number: squareNumber, + Complex: function Complex(x) { + return x.mul(x); + }, + BigNumber: function BigNumber(x) { + return x.times(x); + }, + bigint: function bigint(x) { + return x * x; + }, + Fraction: function Fraction(x) { + return x.mul(x); + }, + Unit: function Unit(x) { + return x.pow(2); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtract.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtract.js new file mode 100644 index 0000000..e5cee04 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtract.js @@ -0,0 +1,86 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'subtract'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'subtractScalar', 'unaryMinus', 'DenseMatrix', 'concat']; +export var createSubtract = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + subtractScalar, + unaryMinus, + DenseMatrix, + concat + } = _ref; + // TODO: split function subtract in two: subtract and subtractScalar + + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo05xSfSf = createMatAlgo05xSfSf({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Subtract two values, `x - y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.subtract(x, y) + * + * Examples: + * + * math.subtract(5.3, 2) // returns number 3.3 + * + * const a = math.complex(2, 3) + * const b = math.complex(4, 1) + * math.subtract(a, b) // returns Complex -2 + 2i + * + * math.subtract([5, 7, 4], 4) // returns Array [1, 3, 0] + * + * const c = math.unit('2.1 km') + * const d = math.unit('500m') + * math.subtract(c, d) // returns Unit 1.6 km + * + * See also: + * + * add + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Initial value + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Value to subtract from `x` + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Subtraction of `x` and `y` + */ + return typed(name, { + 'any, any': subtractScalar + }, matrixAlgorithmSuite({ + elop: subtractScalar, + SS: matAlgo05xSfSf, + DS: matAlgo01xDSid, + SD: matAlgo03xDSf, + Ss: matAlgo12xSfs, + sS: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtractScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtractScalar.js new file mode 100644 index 0000000..44b07c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/subtractScalar.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +import { subtractNumber } from '../../plain/number/index.js'; +var name = 'subtractScalar'; +var dependencies = ['typed']; +export var createSubtractScalar = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Subtract two scalar values, `x - y`. + * This function is meant for internal use: it is used by the public function + * `subtract` + * + * This function does not support collections (Array or Matrix). + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit} x First value + * @param {number | BigNumber | bigint | Fraction | Complex} y Second value to be subtracted from `x` + * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Difference of `x` and `y` + * @private + */ + return typed(name, { + 'number, number': subtractNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.sub(y); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.minus(y); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x - y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return x.sub(y); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (x.value === null || x.value === undefined) { + throw new Error('Parameter x contains a unit with undefined value'); + } + if (y.value === null || y.value === undefined) { + throw new Error('Parameter y contains a unit with undefined value'); + } + if (!x.equalBase(y)) throw new Error('Units do not match'); + var res = x.clone(); + res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value); + res.fixPrefix = false; + return res; + }) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryMinus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryMinus.js new file mode 100644 index 0000000..696c665 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryMinus.js @@ -0,0 +1,47 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { unaryMinusNumber } from '../../plain/number/index.js'; +var name = 'unaryMinus'; +var dependencies = ['typed']; +export var createUnaryMinus = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Inverse the sign of a value, apply a unary minus operation. + * + * For matrices, the function is evaluated element wise. Boolean values and + * strings will be converted to a number. For complex numbers, both real and + * complex value are inverted. + * + * Syntax: + * + * math.unaryMinus(x) + * + * Examples: + * + * math.unaryMinus(3.5) // returns -3.5 + * math.unaryMinus(-4.2) // returns 4.2 + * + * See also: + * + * add, subtract, unaryPlus + * + * @param {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} x Number to be inverted. + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Returns the value with inverted sign. + */ + return typed(name, { + number: unaryMinusNumber, + 'Complex | BigNumber | Fraction': x => x.neg(), + bigint: x => -x, + Unit: typed.referToSelf(self => x => { + var res = x.clone(); + res.value = typed.find(self, res.valueType())(x.value); + return res; + }), + // deep map collection, skip zeros since unaryMinus(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)) + + // TODO: add support for string + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryPlus.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryPlus.js new file mode 100644 index 0000000..411b331 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/unaryPlus.js @@ -0,0 +1,63 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +import { unaryPlusNumber } from '../../plain/number/index.js'; +import { safeNumberType } from '../../utils/number.js'; +var name = 'unaryPlus'; +var dependencies = ['typed', 'config', 'numeric']; +export var createUnaryPlus = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + numeric + } = _ref; + /** + * Unary plus operation. + * Boolean values and strings will be converted to a number, numeric values will be returned as is. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.unaryPlus(x) + * + * Examples: + * + * math.unaryPlus(3.5) // returns 3.5 + * math.unaryPlus(1) // returns 1 + * + * See also: + * + * unaryMinus, add, subtract + * + * @param {number | BigNumber | bigint | Fraction | string | Complex | Unit | Array | Matrix} x + * Input value + * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} + * Returns the input value when numeric, converts to a number when input is non-numeric. + */ + return typed(name, { + number: unaryPlusNumber, + Complex: function Complex(x) { + return x; // complex numbers are immutable + }, + BigNumber: function BigNumber(x) { + return x; // bignumbers are immutable + }, + bigint: function bigint(x) { + return x; + }, + Fraction: function Fraction(x) { + return x; // fractions are immutable + }, + Unit: function Unit(x) { + return x.clone(); + }, + // deep map collection, skip zeros since unaryPlus(0) = 0 + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)), + boolean: function boolean(x) { + return numeric(x ? 1 : 0, config.number); + }, + string: function string(x) { + return numeric(x, safeNumberType(x, config)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/xgcd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/xgcd.js new file mode 100644 index 0000000..5cabe42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/arithmetic/xgcd.js @@ -0,0 +1,91 @@ +import { factory } from '../../utils/factory.js'; +import { xgcdNumber } from '../../plain/number/index.js'; +var name = 'xgcd'; +var dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +export var createXgcd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Calculate the extended greatest common divisor for two values. + * See https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm. + * + * Syntax: + * + * math.xgcd(a, b) + * + * Examples: + * + * math.xgcd(8, 12) // returns [4, -1, 1] + * math.gcd(8, 12) // returns 4 + * math.xgcd(36163, 21199) // returns [1247, -7, 12] + * + * See also: + * + * gcd, lcm + * + * @param {number | BigNumber} a An integer number + * @param {number | BigNumber} b An integer number + * @return {Array} Returns an array containing 3 integers `[div, m, n]` + * where `div = gcd(a, b)` and `a*m + b*n = div` + */ + return typed(name, { + 'number, number': function number_number(a, b) { + var res = xgcdNumber(a, b); + return config.matrix === 'Array' ? res : matrix(res); + }, + 'BigNumber, BigNumber': _xgcdBigNumber + // TODO: implement support for Fraction + }); + + /** + * Calculate xgcd for two BigNumbers + * @param {BigNumber} a + * @param {BigNumber} b + * @return {BigNumber[]} result + * @private + */ + function _xgcdBigNumber(a, b) { + // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm + var + // used to swap two variables + t; + var + // quotient + q; + var + // remainder + r; + var zero = new BigNumber(0); + var one = new BigNumber(1); + var x = zero; + var lastx = one; + var y = one; + var lasty = zero; + if (!a.isInt() || !b.isInt()) { + throw new Error('Parameters in function xgcd must be integer numbers'); + } + while (!b.isZero()) { + q = a.div(b).floor(); + r = a.mod(b); + t = x; + x = lastx.minus(q.times(x)); + lastx = t; + t = y; + y = lasty.minus(q.times(y)); + lasty = t; + a = b; + b = r; + } + var res; + if (a.lt(zero)) { + res = [a.neg(), lastx.neg(), lasty.neg()]; + } else { + res = [a, !a.isZero() ? lastx : 0, lasty]; + } + return config.matrix === 'Array' ? res : matrix(res); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitAnd.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitAnd.js new file mode 100644 index 0000000..e96ab8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitAnd.js @@ -0,0 +1,66 @@ +import { bitAndBigNumber } from '../../utils/bignumber/bitwise.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { bitAndNumber } from '../../plain/number/index.js'; +var name = 'bitAnd'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'concat']; +export var createBitAnd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo06xS0S0 = createMatAlgo06xS0S0({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Bitwise AND two values, `x & y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.bitAnd(x, y) + * + * Examples: + * + * math.bitAnd(53, 131) // returns number 1 + * + * math.bitAnd([1, 12, 31], 42) // returns Array [0, 8, 10] + * + * See also: + * + * bitNot, bitOr, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to and + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to and + * @return {number | BigNumber | bigint | Array | Matrix} AND of `x` and `y` + */ + return typed(name, { + 'number, number': bitAndNumber, + 'BigNumber, BigNumber': bitAndBigNumber, + 'bigint, bigint': (x, y) => x & y + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0, + Ss: matAlgo11xS0s + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitNot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitNot.js new file mode 100644 index 0000000..98b3bcd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitNot.js @@ -0,0 +1,39 @@ +import { bitNotBigNumber } from '../../utils/bignumber/bitwise.js'; +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { bitNotNumber } from '../../plain/number/index.js'; +var name = 'bitNot'; +var dependencies = ['typed']; +export var createBitNot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Bitwise NOT value, `~x`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.bitNot(x) + * + * Examples: + * + * math.bitNot(1) // returns number -2 + * + * math.bitNot([2, -3, 4]) // returns Array [-3, 2, -5] + * + * See also: + * + * bitAnd, bitOr, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to not + * @return {number | BigNumber | bigint | Array | Matrix} NOT of `x` + */ + return typed(name, { + number: bitNotNumber, + BigNumber: bitNotBigNumber, + bigint: x => ~x, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitOr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitOr.js new file mode 100644 index 0000000..2b43619 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitOr.js @@ -0,0 +1,67 @@ +import { bitOrBigNumber } from '../../utils/bignumber/bitwise.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { bitOrNumber } from '../../plain/number/index.js'; +var name = 'bitOr'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +export var createBitOr = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo04xSidSid = createMatAlgo04xSidSid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Bitwise OR two values, `x | y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the lowest print base. + * + * Syntax: + * + * math.bitOr(x, y) + * + * Examples: + * + * math.bitOr(1, 2) // returns number 3 + * + * math.bitOr([1, 2, 3], 4) // returns Array [5, 6, 7] + * + * See also: + * + * bitAnd, bitNot, bitXor, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to or + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to or + * @return {number | BigNumber | bigint | Array | Matrix} OR of `x` and `y` + */ + return typed(name, { + 'number, number': bitOrNumber, + 'BigNumber, BigNumber': bitOrBigNumber, + 'bigint, bigint': (x, y) => x | y + }, matrixAlgorithmSuite({ + SS: matAlgo04xSidSid, + DS: matAlgo01xDSid, + Ss: matAlgo10xSids + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitXor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitXor.js new file mode 100644 index 0000000..903a1a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/bitXor.js @@ -0,0 +1,65 @@ +import { bitXor as bigBitXor } from '../../utils/bignumber/bitwise.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { bitXorNumber } from '../../plain/number/index.js'; +var name = 'bitXor'; +var dependencies = ['typed', 'matrix', 'DenseMatrix', 'concat']; +export var createBitXor = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Bitwise XOR two values, `x ^ y`. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.bitXor(x, y) + * + * Examples: + * + * math.bitXor(1, 2) // returns number 3 + * + * math.bitXor([2, 3, 4], 4) // returns Array [6, 7, 0] + * + * See also: + * + * bitAnd, bitNot, bitOr, leftShift, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x First value to xor + * @param {number | BigNumber | bigint | Array | Matrix} y Second value to xor + * @return {number | BigNumber | bigint | Array | Matrix} XOR of `x` and `y` + */ + return typed(name, { + 'number, number': bitXorNumber, + 'BigNumber, BigNumber': bigBitXor, + 'bigint, bigint': (x, y) => x ^ y + }, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/leftShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/leftShift.js new file mode 100644 index 0000000..bbcc6e0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/leftShift.js @@ -0,0 +1,115 @@ +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'; +import { leftShiftNumber } from '../../plain/number/index.js'; +import { leftShiftBigNumber } from '../../utils/bignumber/bitwise.js'; +var name = 'leftShift'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +export var createLeftShift = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo08xS0Sid = createMatAlgo08xS0Sid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var useMatrixForArrayScalar = createUseMatrixForArrayScalar({ + typed, + matrix + }); + + /** + * Bitwise left logical shift of a value x by y number of bits, `x << y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.leftShift(x, y) + * + * Examples: + * + * math.leftShift(1, 2) // returns number 4 + * + * math.leftShift([1, 2, 4], 4) // returns Array [16, 32, 64] + * + * See also: + * + * leftShift, bitNot, bitOr, bitXor, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted + * @param {number | BigNumber | bigint} y Amount of shifts + * @return {number | BigNumber | bigint | Array | Matrix} `x` shifted left `y` times + */ + return typed(name, { + 'number, number': leftShiftNumber, + 'BigNumber, BigNumber': leftShiftBigNumber, + 'bigint, bigint': (x, y) => x << y, + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightArithShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightArithShift.js new file mode 100644 index 0000000..03eaacf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightArithShift.js @@ -0,0 +1,115 @@ +import { rightArithShiftBigNumber } from '../../utils/bignumber/bitwise.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'; +import { rightArithShiftNumber } from '../../plain/number/index.js'; +var name = 'rightArithShift'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +export var createRightArithShift = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo08xS0Sid = createMatAlgo08xS0Sid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var useMatrixForArrayScalar = createUseMatrixForArrayScalar({ + typed, + matrix + }); + + /** + * Bitwise right arithmetic shift of a value x by y number of bits, `x >> y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.rightArithShift(x, y) + * + * Examples: + * + * math.rightArithShift(4, 2) // returns number 1 + * + * math.rightArithShift([16, -32, 64], 4) // returns Array [1, -2, 4] + * + * See also: + * + * bitAnd, bitNot, bitOr, bitXor, rightArithShift, rightLogShift + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be shifted + * @param {number | BigNumber | bigint} y Amount of shifts + * @return {number | BigNumber | bigint | Array | Matrix} `x` zero-filled shifted right `y` times + */ + return typed(name, { + 'number, number': rightArithShiftNumber, + 'BigNumber, BigNumber': rightArithShiftBigNumber, + 'bigint, bigint': (x, y) => x >> y, + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightLogShift.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightLogShift.js new file mode 100644 index 0000000..b849509 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/rightLogShift.js @@ -0,0 +1,115 @@ +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +import { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'; +import { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'; +import { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { rightLogShiftNumber } from '../../plain/number/index.js'; +import { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'; +var name = 'rightLogShift'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix', 'concat']; +export var createRightLogShift = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + DenseMatrix, + concat + } = _ref; + var matAlgo01xDSid = createMatAlgo01xDSid({ + typed + }); + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo08xS0Sid = createMatAlgo08xS0Sid({ + typed, + equalScalar + }); + var matAlgo10xSids = createMatAlgo10xSids({ + typed, + DenseMatrix + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var useMatrixForArrayScalar = createUseMatrixForArrayScalar({ + typed, + matrix + }); + + /** + * Bitwise right logical shift of value x by y number of bits, `x >>> y`. + * For matrices, the function is evaluated element wise. + * For units, the function is evaluated on the best prefix base. + * + * Syntax: + * + * math.rightLogShift(x, y) + * + * Examples: + * + * math.rightLogShift(4, 2) // returns number 1 + * + * math.rightLogShift([16, 32, 64], 4) // returns Array [1, 2, 4] + * + * See also: + * + * bitAnd, bitNot, bitOr, bitXor, leftShift, rightLogShift + * + * @param {number | Array | Matrix} x Value to be shifted + * @param {number} y Amount of shifts + * @return {number | Array | Matrix} `x` zero-filled shifted right `y` times + */ + + return typed(name, { + 'number, number': rightLogShiftNumber, + // 'BigNumber, BigNumber': ..., // TODO: implement BigNumber support for rightLogShift + + 'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(y, 0)) { + return x.clone(); + } + return matAlgo14xDs(x, y, self, false); + }), + 'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo10xSids(y, x, self, true); + }), + 'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (equalScalar(x, 0)) { + return zeros(y.size(), y.storage()); + } + return matAlgo14xDs(y, x, self, true); + }) + }, useMatrixForArrayScalar, matrixAlgorithmSuite({ + SS: matAlgo08xS0Sid, + DS: matAlgo01xDSid, + SD: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/useMatrixForArrayScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/useMatrixForArrayScalar.js new file mode 100644 index 0000000..5cd79ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/bitwise/useMatrixForArrayScalar.js @@ -0,0 +1,13 @@ +import { factory } from '../../utils/factory.js'; +export var createUseMatrixForArrayScalar = /* #__PURE__ */factory('useMatrixForArrayScalar', ['typed', 'matrix'], _ref => { + var { + typed, + matrix + } = _ref; + return { + 'Array, number': typed.referTo('DenseMatrix, number', selfDn => (x, y) => selfDn(matrix(x), y).valueOf()), + 'Array, BigNumber': typed.referTo('DenseMatrix, BigNumber', selfDB => (x, y) => selfDB(matrix(x), y).valueOf()), + 'number, Array': typed.referTo('number, DenseMatrix', selfnD => (x, y) => selfnD(x, matrix(y)).valueOf()), + 'BigNumber, Array': typed.referTo('BigNumber, DenseMatrix', selfBD => (x, y) => selfBD(x, matrix(y)).valueOf()) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/bellNumbers.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/bellNumbers.js new file mode 100644 index 0000000..8b0b07d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/bellNumbers.js @@ -0,0 +1,47 @@ +import { factory } from '../../utils/factory.js'; +var name = 'bellNumbers'; +var dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2']; +export var createBellNumbers = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + isNegative, + isInteger, + stirlingS2 + } = _ref; + /** + * The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. + * bellNumbers only takes integer arguments. + * The following condition must be enforced: n >= 0 + * + * Syntax: + * + * math.bellNumbers(n) + * + * Examples: + * + * math.bellNumbers(3) // returns 5 + * math.bellNumbers(8) // returns 4140 + * + * See also: + * + * stirlingS2 + * + * @param {Number | BigNumber} n Total number of objects in the set + * @return {Number | BigNumber} B(n) + */ + return typed(name, { + 'number | BigNumber': function number__BigNumber(n) { + if (!isInteger(n) || isNegative(n)) { + throw new TypeError('Non-negative integer value expected in function bellNumbers'); + } + + // Sum (k=0, n) S(n,k). + var result = 0; + for (var i = 0; i <= n; i++) { + result = addScalar(result, stirlingS2(n, i)); + } + return result; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/catalan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/catalan.js new file mode 100644 index 0000000..986d076 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/catalan.js @@ -0,0 +1,43 @@ +import { factory } from '../../utils/factory.js'; +var name = 'catalan'; +var dependencies = ['typed', 'addScalar', 'divideScalar', 'multiplyScalar', 'combinations', 'isNegative', 'isInteger']; +export var createCatalan = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + divideScalar, + multiplyScalar, + combinations, + isNegative, + isInteger + } = _ref; + /** + * The Catalan Numbers enumerate combinatorial structures of many different types. + * catalan only takes integer arguments. + * The following condition must be enforced: n >= 0 + * + * Syntax: + * + * math.catalan(n) + * + * Examples: + * + * math.catalan(3) // returns 5 + * math.catalan(8) // returns 1430 + * + * See also: + * + * bellNumbers + * + * @param {Number | BigNumber} n nth Catalan number + * @return {Number | BigNumber} Cn(n) + */ + return typed(name, { + 'number | BigNumber': function number__BigNumber(n) { + if (!isInteger(n) || isNegative(n)) { + throw new TypeError('Non-negative integer value expected in function catalan'); + } + return divideScalar(combinations(multiplyScalar(n, 2), n), addScalar(n, 1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/composition.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/composition.js new file mode 100644 index 0000000..a7ff05c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/composition.js @@ -0,0 +1,46 @@ +import { factory } from '../../utils/factory.js'; +var name = 'composition'; +var dependencies = ['typed', 'addScalar', 'combinations', 'isNegative', 'isPositive', 'isInteger', 'larger']; +export var createComposition = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + combinations, + isPositive, + isNegative, + isInteger, + larger + } = _ref; + /** + * The composition counts of n into k parts. + * + * composition only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.composition(n, k) + * + * Examples: + * + * math.composition(5, 3) // returns 6 + * + * See also: + * + * combinations + * + * @param {Number | BigNumber} n Total number of objects in the set + * @param {Number | BigNumber} k Number of objects in the subset + * @return {Number | BigNumber} Returns the composition counts of n into k parts. + */ + return typed(name, { + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(n, k) { + if (!isInteger(n) || !isPositive(n) || !isInteger(k) || !isPositive(k)) { + throw new TypeError('Positive integer value expected in function composition'); + } else if (larger(k, n)) { + throw new TypeError('k must be less than or equal to n in function composition'); + } + return combinations(addScalar(n, -1), addScalar(k, -1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/stirlingS2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/stirlingS2.js new file mode 100644 index 0000000..539bcac --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/combinatorics/stirlingS2.js @@ -0,0 +1,86 @@ +import { factory } from '../../utils/factory.js'; +import { isNumber } from '../../utils/is.js'; +var name = 'stirlingS2'; +var dependencies = ['typed', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'factorial', 'combinations', 'isNegative', 'isInteger', 'number', '?bignumber', 'larger']; +export var createStirlingS2 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + pow, + factorial, + combinations, + isNegative, + isInteger, + number, + bignumber, + larger + } = _ref; + var smallCache = []; + var bigCache = []; + /** + * The Stirling numbers of the second kind, counts the number of ways to partition + * a set of n labelled objects into k nonempty unlabelled subsets. + * stirlingS2 only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * If n = k or k = 1 <= n, then s(n,k) = 1 + * If k = 0 < n, then s(n,k) = 0 + * + * Note that if either n or k is supplied as a BigNumber, the result will be + * as well. + * + * Syntax: + * + * math.stirlingS2(n, k) + * + * Examples: + * + * math.stirlingS2(5, 3) //returns 25 + * + * See also: + * + * bellNumbers + * + * @param {Number | BigNumber} n Total number of objects in the set + * @param {Number | BigNumber} k Number of objects in the subset + * @return {Number | BigNumber} S(n,k) + */ + return typed(name, { + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(n, k) { + if (!isInteger(n) || isNegative(n) || !isInteger(k) || isNegative(k)) { + throw new TypeError('Non-negative integer value expected in function stirlingS2'); + } else if (larger(k, n)) { + throw new TypeError('k must be less than or equal to n in function stirlingS2'); + } + var big = !(isNumber(n) && isNumber(k)); + var cache = big ? bigCache : smallCache; + var make = big ? bignumber : number; + var nn = number(n); + var nk = number(k); + /* See if we already have the value: */ + if (cache[nn] && cache[nn].length > nk) { + return cache[nn][nk]; + } + /* Fill the cache */ + for (var m = 0; m <= nn; ++m) { + if (!cache[m]) { + cache[m] = [m === 0 ? make(1) : make(0)]; + } + if (m === 0) continue; + var row = cache[m]; + var prev = cache[m - 1]; + for (var i = row.length; i <= m && i <= nk; ++i) { + if (i === m) { + row[i] = 1; + } else { + row[i] = addScalar(multiplyScalar(make(i), prev[i]), prev[i - 1]); + } + } + } + return cache[nn][nk]; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/arg.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/arg.js new file mode 100644 index 0000000..d3d10c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/arg.js @@ -0,0 +1,50 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +var name = 'arg'; +var dependencies = ['typed']; +export var createArg = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the argument of a complex value. + * For a complex number `a + bi`, the argument is computed as `atan2(b, a)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.arg(x) + * + * Examples: + * + * const a = math.complex(2, 2) + * math.arg(a) / math.pi // returns number 0.25 + * + * const b = math.complex('2 + 3i') + * math.arg(b) // returns number 0.982793723247329 + * math.atan2(3, 2) // returns number 0.982793723247329 + * + * See also: + * + * re, im, conj, abs + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The argument of x + */ + return typed(name, { + number: function number(x) { + return Math.atan2(0, x); + }, + BigNumber: function BigNumber(x) { + return x.constructor.atan2(0, x); + }, + Complex: function Complex(x) { + return x.arg(); + }, + // TODO: implement BigNumber support for function arg + + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/conj.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/conj.js new file mode 100644 index 0000000..e205d27 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/conj.js @@ -0,0 +1,39 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +var name = 'conj'; +var dependencies = ['typed']; +export var createConj = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the complex conjugate of a complex value. + * If `x = a+bi`, the complex conjugate of `x` is `a - bi`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.conj(x) + * + * Examples: + * + * math.conj(math.complex('2 + 3i')) // returns Complex 2 - 3i + * math.conj(math.complex('2 - 3i')) // returns Complex 2 + 3i + * math.conj(math.complex('-5.2i')) // returns Complex 5.2i + * + * See also: + * + * re, im, arg, abs + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Complex | Array | Matrix} + * The complex conjugate of x + */ + return typed(name, { + 'number | BigNumber | Fraction': x => x, + Complex: x => x.conjugate(), + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/im.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/im.js new file mode 100644 index 0000000..8501b57 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/im.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +var name = 'im'; +var dependencies = ['typed']; +export var createIm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Get the imaginary part of a complex number. + * For a complex number `a + bi`, the function returns `b`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.im(x) + * + * Examples: + * + * const a = math.complex(2, 3) + * math.re(a) // returns number 2 + * math.im(a) // returns number 3 + * + * math.re(math.complex('-5.2i')) // returns number -5.2 + * math.re(math.complex(2.4)) // returns number 0 + * + * See also: + * + * re, conj, abs, arg + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The imaginary part of x + */ + return typed(name, { + number: () => 0, + 'BigNumber | Fraction': x => x.mul(0), + Complex: x => x.im, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/re.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/re.js new file mode 100644 index 0000000..148f0c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/complex/re.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +import { deepMap } from '../../utils/collection.js'; +var name = 're'; +var dependencies = ['typed']; +export var createRe = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Get the real part of a complex number. + * For a complex number `a + bi`, the function returns `a`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.re(x) + * + * Examples: + * + * const a = math.complex(2, 3) + * math.re(a) // returns number 2 + * math.im(a) // returns number 3 + * + * math.re(math.complex('-5.2i')) // returns number 0 + * math.re(math.complex(2.4)) // returns number 2.4 + * + * See also: + * + * im, conj, abs, arg + * + * @param {number | BigNumber | Complex | Array | Matrix} x + * A complex number or array with complex numbers + * @return {number | BigNumber | Array | Matrix} The real part of x + */ + return typed(name, { + 'number | BigNumber | Fraction': x => x, + Complex: x => x.re, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/distance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/distance.js new file mode 100644 index 0000000..dc7d83c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/distance.js @@ -0,0 +1,305 @@ +import { isBigNumber } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'distance'; +var dependencies = ['typed', 'addScalar', 'subtractScalar', 'divideScalar', 'multiplyScalar', 'deepEqual', 'sqrt', 'abs']; +export var createDistance = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + deepEqual, + sqrt, + abs + } = _ref; + /** + * Calculates: + * The eucledian distance between two points in N-dimensional spaces. + * Distance between point and a line in 2 and 3 dimensional spaces. + * Pairwise distance between a set of 2D or 3D points + * NOTE: + * When substituting coefficients of a line(a, b and c), use ax + by + c = 0 instead of ax + by = c + * For parametric equation of a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, c) + * + * Syntax: + * + * math.distance([x1,y1], [x2,y2]) + * math.distance({pointOneX, pointOneY}, {pointTwoX, pointTwoY}) + * math.distance([x1,y1,z1], [x2,y2,z2]) + * math.distance({pointOneX, pointOneY, pointOneZ}, {pointTwoX, pointTwoY, pointTwoZ}) + * math.distance([x1,y1,z1,a1], [x2,y2,z2,a2]) + * math.distance([[x1,y1], [x2,y2], [x3,y3]]) + * math.distance([[x1,y1,z1], [x2,y2,z2], [x3,y3,z3]]) + * math.distance([pointX,pointY], [a,b,c]) + * math.distance([pointX,pointY], [lineOnePtX,lineOnePtY], [lineTwoPtX,lineTwoPtY]) + * math.distance({pointX, pointY}, {lineOnePtX, lineOnePtY}, {lineTwoPtX, lineTwoPtY}) + * math.distance([pointX,pointY,pointZ], [x0, y0, z0, a, b, c]) + * math.distance({pointX, pointY, pointZ}, {x0, y0, z0, a, b, c}) + * + * Examples: + * math.distance([0,0], [4,4]) // Returns 5.656854249492381 + * math.distance( + * {pointOneX: 0, pointOneY: 0}, + * {pointTwoX: 10, pointTwoY: 10}) // Returns 14.142135623730951 + * math.distance([1, 0, 1], [4, -2, 2]) // Returns 3.7416573867739413 + * math.distance( + * {pointOneX: 4, pointOneY: 5, pointOneZ: 8}, + * {pointTwoX: 2, pointTwoY: 7, pointTwoZ: 9}) // Returns 3 + * math.distance([1, 0, 1, 0], [0, -1, 0, -1]) // Returns 2 + * math.distance([[1, 2], [1, 2], [1, 3]]) // Returns [0, 1, 1] + * math.distance([[1,2,4], [1,2,6], [8,1,3]]) // Returns [2, 7.14142842854285, 7.681145747868608] + * math.distance([10, 10], [8, 1, 3]) // Returns 11.535230316796387 + * math.distance([0, 0], [3, 0], [0, 4]) // Returns 2.4 + * math.distance( + * {pointX: 0, pointY: 0}, + * {lineOnePtX: 3, lineOnePtY: 0}, + * {lineTwoPtX: 0, lineTwoPtY: 4}) // Returns 2.4 + * math.distance([2, 3, 1], [1, 1, 2, 5, 0, 1]) // Returns 2.3204774044612857 + * math.distance( + * {pointX: 2, pointY: 3, pointZ: 1}, + * {x0: 1, y0: 1, z0: 2, a: 5, b: 0, c: 1}) // Returns 2.3204774044612857 + * + * @param {Array | Matrix | Object} x Co-ordinates of first point + * @param {Array | Matrix | Object} y Co-ordinates of second point + * @return {Number | BigNumber} Returns the distance from two/three points + */ + return typed(name, { + 'Array, Array, Array': function Array_Array_Array(x, y, z) { + // Point to Line 2D (x=Point, y=LinePoint1, z=LinePoint2) + if (x.length === 2 && y.length === 2 && z.length === 2) { + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_2d(y)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument'); + } + if (!_2d(z)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument'); + } + if (deepEqual(y, z)) { + throw new TypeError('LinePoint1 should not be same with LinePoint2'); + } + var xCoeff = subtractScalar(z[1], y[1]); + var yCoeff = subtractScalar(y[0], z[0]); + var constant = subtractScalar(multiplyScalar(z[0], y[1]), multiplyScalar(y[0], z[1])); + return _distancePointLine2D(x[0], x[1], xCoeff, yCoeff, constant); + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Object, Object, Object': function Object_Object_Object(x, y, z) { + if (Object.keys(x).length === 2 && Object.keys(y).length === 2 && Object.keys(z).length === 2) { + if (!_2d(x)) { + throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers'); + } + if (!_2d(y)) { + throw new TypeError('Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers'); + } + if (!_2d(z)) { + throw new TypeError('Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers'); + } + if (deepEqual(_objectToArray(y), _objectToArray(z))) { + throw new TypeError('LinePoint1 should not be same with LinePoint2'); + } + if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y && 'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) { + var xCoeff = subtractScalar(z.lineTwoPtY, y.lineOnePtY); + var yCoeff = subtractScalar(y.lineOnePtX, z.lineTwoPtX); + var constant = subtractScalar(multiplyScalar(z.lineTwoPtX, y.lineOnePtY), multiplyScalar(y.lineOnePtX, z.lineTwoPtY)); + return _distancePointLine2D(x.pointX, x.pointY, xCoeff, yCoeff, constant); + } else { + throw new TypeError('Key names do not match'); + } + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Array, Array': function Array_Array(x, y) { + // Point to Line 2D (x=[pointX, pointY], y=[x-coeff, y-coeff, const]) + if (x.length === 2 && y.length === 3) { + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + return _distancePointLine2D(x[0], x[1], y[0], y[1], y[2]); + } else if (x.length === 3 && y.length === 6) { + // Point to Line 3D + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_parametricLine(y)) { + throw new TypeError('Array with 6 numbers or BigNumbers expected for second argument'); + } + return _distancePointLine3D(x[0], x[1], x[2], y[0], y[1], y[2], y[3], y[4], y[5]); + } else if (x.length === y.length && x.length > 0) { + // Point to Point N-dimensions + if (!_containsOnlyNumbers(x)) { + throw new TypeError('All values of an array should be numbers or BigNumbers'); + } + if (!_containsOnlyNumbers(y)) { + throw new TypeError('All values of an array should be numbers or BigNumbers'); + } + return _euclideanDistance(x, y); + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + 'Object, Object': function Object_Object(x, y) { + if (Object.keys(x).length === 2 && Object.keys(y).length === 3) { + if (!_2d(x)) { + throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers'); + } + if (!_3d(y)) { + throw new TypeError('Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers'); + } + if ('pointX' in x && 'pointY' in x && 'xCoeffLine' in y && 'yCoeffLine' in y && 'constant' in y) { + return _distancePointLine2D(x.pointX, x.pointY, y.xCoeffLine, y.yCoeffLine, y.constant); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 3 && Object.keys(y).length === 6) { + // Point to Line 3D + if (!_3d(x)) { + throw new TypeError('Values of pointX, pointY and pointZ should be numbers or BigNumbers'); + } + if (!_parametricLine(y)) { + throw new TypeError('Values of x0, y0, z0, a, b and c should be numbers or BigNumbers'); + } + if ('pointX' in x && 'pointY' in x && 'x0' in y && 'y0' in y && 'z0' in y && 'a' in y && 'b' in y && 'c' in y) { + return _distancePointLine3D(x.pointX, x.pointY, x.pointZ, y.x0, y.y0, y.z0, y.a, y.b, y.c); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 2 && Object.keys(y).length === 2) { + // Point to Point 2D + if (!_2d(x)) { + throw new TypeError('Values of pointOneX and pointOneY should be numbers or BigNumbers'); + } + if (!_2d(y)) { + throw new TypeError('Values of pointTwoX and pointTwoY should be numbers or BigNumbers'); + } + if ('pointOneX' in x && 'pointOneY' in x && 'pointTwoX' in y && 'pointTwoY' in y) { + return _euclideanDistance([x.pointOneX, x.pointOneY], [y.pointTwoX, y.pointTwoY]); + } else { + throw new TypeError('Key names do not match'); + } + } else if (Object.keys(x).length === 3 && Object.keys(y).length === 3) { + // Point to Point 3D + if (!_3d(x)) { + throw new TypeError('Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers'); + } + if (!_3d(y)) { + throw new TypeError('Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers'); + } + if ('pointOneX' in x && 'pointOneY' in x && 'pointOneZ' in x && 'pointTwoX' in y && 'pointTwoY' in y && 'pointTwoZ' in y) { + return _euclideanDistance([x.pointOneX, x.pointOneY, x.pointOneZ], [y.pointTwoX, y.pointTwoY, y.pointTwoZ]); + } else { + throw new TypeError('Key names do not match'); + } + } else { + throw new TypeError('Invalid Arguments: Try again'); + } + }, + Array: function Array(arr) { + if (!_pairwise(arr)) { + throw new TypeError('Incorrect array format entered for pairwise distance calculation'); + } + return _distancePairwise(arr); + } + }); + function _isNumber(a) { + // distance supports numbers and bignumbers + return typeof a === 'number' || isBigNumber(a); + } + function _2d(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]); + } + function _3d(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]); + } + function _containsOnlyNumbers(a) { + // checks if the number of arguments are correct in count and are valid (should be numbers) + if (!Array.isArray(a)) { + a = _objectToArray(a); + } + return a.every(_isNumber); + } + function _parametricLine(a) { + if (a.constructor !== Array) { + a = _objectToArray(a); + } + return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]) && _isNumber(a[3]) && _isNumber(a[4]) && _isNumber(a[5]); + } + function _objectToArray(o) { + var keys = Object.keys(o); + var a = []; + for (var i = 0; i < keys.length; i++) { + a.push(o[keys[i]]); + } + return a; + } + function _pairwise(a) { + // checks for valid arguments passed to _distancePairwise(Array) + if (a[0].length === 2 && _isNumber(a[0][0]) && _isNumber(a[0][1])) { + if (a.some(aI => aI.length !== 2 || !_isNumber(aI[0]) || !_isNumber(aI[1]))) { + return false; + } + } else if (a[0].length === 3 && _isNumber(a[0][0]) && _isNumber(a[0][1]) && _isNumber(a[0][2])) { + if (a.some(aI => aI.length !== 3 || !_isNumber(aI[0]) || !_isNumber(aI[1]) || !_isNumber(aI[2]))) { + return false; + } + } else { + return false; + } + return true; + } + function _distancePointLine2D(x, y, a, b, c) { + var num = abs(addScalar(addScalar(multiplyScalar(a, x), multiplyScalar(b, y)), c)); + var den = sqrt(addScalar(multiplyScalar(a, a), multiplyScalar(b, b))); + return divideScalar(num, den); + } + function _distancePointLine3D(x, y, z, x0, y0, z0, a, b, c) { + var num = [subtractScalar(multiplyScalar(subtractScalar(y0, y), c), multiplyScalar(subtractScalar(z0, z), b)), subtractScalar(multiplyScalar(subtractScalar(z0, z), a), multiplyScalar(subtractScalar(x0, x), c)), subtractScalar(multiplyScalar(subtractScalar(x0, x), b), multiplyScalar(subtractScalar(y0, y), a))]; + num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2]))); + var den = sqrt(addScalar(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)), multiplyScalar(c, c))); + return divideScalar(num, den); + } + function _euclideanDistance(x, y) { + var vectorSize = x.length; + var result = 0; + var diff = 0; + for (var i = 0; i < vectorSize; i++) { + diff = subtractScalar(x[i], y[i]); + result = addScalar(multiplyScalar(diff, diff), result); + } + return sqrt(result); + } + function _distancePairwise(a) { + var result = []; + var pointA = []; + var pointB = []; + for (var i = 0; i < a.length - 1; i++) { + for (var j = i + 1; j < a.length; j++) { + if (a[0].length === 2) { + pointA = [a[i][0], a[i][1]]; + pointB = [a[j][0], a[j][1]]; + } else if (a[0].length === 3) { + pointA = [a[i][0], a[i][1], a[i][2]]; + pointB = [a[j][0], a[j][1], a[j][2]]; + } + result.push(_euclideanDistance(pointA, pointB)); + } + } + return result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/intersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/intersect.js new file mode 100644 index 0000000..6d6a772 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/geometry/intersect.js @@ -0,0 +1,200 @@ +import { factory } from '../../utils/factory.js'; +var name = 'intersect'; +var dependencies = ['typed', 'config', 'abs', 'add', 'addScalar', 'matrix', 'multiply', 'multiplyScalar', 'divideScalar', 'subtract', 'smaller', 'equalScalar', 'flatten', 'isZero', 'isNumeric']; +export var createIntersect = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + abs, + add, + addScalar, + matrix, + multiply, + multiplyScalar, + divideScalar, + subtract, + smaller, + equalScalar, + flatten, + isZero, + isNumeric + } = _ref; + /** + * Calculates the point of intersection of two lines in two or three dimensions + * and of a line and a plane in three dimensions. The inputs are in the form of + * arrays or 1 dimensional matrices. The line intersection functions return null + * if the lines do not meet. + * + * Note: Fill the plane coefficients as `x + y + z = c` and not as `x + y + z + c = 0`. + * + * Syntax: + * + * math.intersect(endPoint1Line1, endPoint2Line1, endPoint1Line2, endPoint2Line2) + * math.intersect(endPoint1, endPoint2, planeCoefficients) + * + * Examples: + * + * math.intersect([0, 0], [10, 10], [10, 0], [0, 10]) // Returns [5, 5] + * math.intersect([0, 0, 0], [10, 10, 0], [10, 0, 0], [0, 10, 0]) // Returns [5, 5, 0] + * math.intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6]) // Returns [7, -4, 3] + * + * @param {Array | Matrix} w Co-ordinates of first end-point of first line + * @param {Array | Matrix} x Co-ordinates of second end-point of first line + * @param {Array | Matrix} y Co-ordinates of first end-point of second line + * OR Co-efficients of the plane's equation + * @param {Array | Matrix} z Co-ordinates of second end-point of second line + * OR undefined if the calculation is for line and plane + * @return {Array} Returns the point of intersection of lines/lines-planes + */ + return typed('intersect', { + 'Array, Array, Array': _AAA, + 'Array, Array, Array, Array': _AAAA, + 'Matrix, Matrix, Matrix': function Matrix_Matrix_Matrix(x, y, plane) { + var arr = _AAA(x.valueOf(), y.valueOf(), plane.valueOf()); + return arr === null ? null : matrix(arr); + }, + 'Matrix, Matrix, Matrix, Matrix': function Matrix_Matrix_Matrix_Matrix(w, x, y, z) { + // TODO: output matrix type should match input matrix type + var arr = _AAAA(w.valueOf(), x.valueOf(), y.valueOf(), z.valueOf()); + return arr === null ? null : matrix(arr); + } + }); + function _AAA(x, y, plane) { + x = _coerceArr(x); + y = _coerceArr(y); + plane = _coerceArr(plane); + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + if (!_4d(plane)) { + throw new TypeError('Array with 4 numbers expected as third argument'); + } + return _intersectLinePlane(x[0], x[1], x[2], y[0], y[1], y[2], plane[0], plane[1], plane[2], plane[3]); + } + function _AAAA(w, x, y, z) { + w = _coerceArr(w); + x = _coerceArr(x); + y = _coerceArr(y); + z = _coerceArr(z); + if (w.length === 2) { + if (!_2d(w)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument'); + } + if (!_2d(x)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument'); + } + if (!_2d(y)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument'); + } + if (!_2d(z)) { + throw new TypeError('Array with 2 numbers or BigNumbers expected for fourth argument'); + } + return _intersect2d(w, x, y, z); + } else if (w.length === 3) { + if (!_3d(w)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument'); + } + if (!_3d(x)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument'); + } + if (!_3d(y)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for third argument'); + } + if (!_3d(z)) { + throw new TypeError('Array with 3 numbers or BigNumbers expected for fourth argument'); + } + return _intersect3d(w[0], w[1], w[2], x[0], x[1], x[2], y[0], y[1], y[2], z[0], z[1], z[2]); + } else { + throw new TypeError('Arrays with two or thee dimensional points expected'); + } + } + + /** Coerce row and column 2-dim arrays to 1-dim array */ + function _coerceArr(arr) { + // row matrix + if (arr.length === 1) return arr[0]; + + // column matrix + if (arr.length > 1 && Array.isArray(arr[0])) { + if (arr.every(el => Array.isArray(el) && el.length === 1)) return flatten(arr); + } + return arr; + } + function _2d(x) { + return x.length === 2 && isNumeric(x[0]) && isNumeric(x[1]); + } + function _3d(x) { + return x.length === 3 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]); + } + function _4d(x) { + return x.length === 4 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]) && isNumeric(x[3]); + } + function _intersect2d(p1a, p1b, p2a, p2b) { + var o1 = p1a; + var o2 = p2a; + var d1 = subtract(o1, p1b); + var d2 = subtract(o2, p2b); + var det = subtract(multiplyScalar(d1[0], d2[1]), multiplyScalar(d2[0], d1[1])); + if (isZero(det)) return null; + if (smaller(abs(det), config.relTol)) { + return null; + } + var d20o11 = multiplyScalar(d2[0], o1[1]); + var d21o10 = multiplyScalar(d2[1], o1[0]); + var d20o21 = multiplyScalar(d2[0], o2[1]); + var d21o20 = multiplyScalar(d2[1], o2[0]); + var t = divideScalar(addScalar(subtract(subtract(d20o11, d21o10), d20o21), d21o20), det); + return add(multiply(d1, t), o1); + } + function _intersect3dHelper(a, b, c, d, e, f, g, h, i, j, k, l) { + // (a - b)*(c - d) + (e - f)*(g - h) + (i - j)*(k - l) + var add1 = multiplyScalar(subtract(a, b), subtract(c, d)); + var add2 = multiplyScalar(subtract(e, f), subtract(g, h)); + var add3 = multiplyScalar(subtract(i, j), subtract(k, l)); + return addScalar(addScalar(add1, add2), add3); + } + function _intersect3d(x1, y1, z1, x2, y2, z2, x3, y3, z3, x4, y4, z4) { + var d1343 = _intersect3dHelper(x1, x3, x4, x3, y1, y3, y4, y3, z1, z3, z4, z3); + var d4321 = _intersect3dHelper(x4, x3, x2, x1, y4, y3, y2, y1, z4, z3, z2, z1); + var d1321 = _intersect3dHelper(x1, x3, x2, x1, y1, y3, y2, y1, z1, z3, z2, z1); + var d4343 = _intersect3dHelper(x4, x3, x4, x3, y4, y3, y4, y3, z4, z3, z4, z3); + var d2121 = _intersect3dHelper(x2, x1, x2, x1, y2, y1, y2, y1, z2, z1, z2, z1); + var numerator = subtract(multiplyScalar(d1343, d4321), multiplyScalar(d1321, d4343)); + var denominator = subtract(multiplyScalar(d2121, d4343), multiplyScalar(d4321, d4321)); + if (isZero(denominator)) return null; + var ta = divideScalar(numerator, denominator); + var tb = divideScalar(addScalar(d1343, multiplyScalar(ta, d4321)), d4343); + var pax = addScalar(x1, multiplyScalar(ta, subtract(x2, x1))); + var pay = addScalar(y1, multiplyScalar(ta, subtract(y2, y1))); + var paz = addScalar(z1, multiplyScalar(ta, subtract(z2, z1))); + var pbx = addScalar(x3, multiplyScalar(tb, subtract(x4, x3))); + var pby = addScalar(y3, multiplyScalar(tb, subtract(y4, y3))); + var pbz = addScalar(z3, multiplyScalar(tb, subtract(z4, z3))); + if (equalScalar(pax, pbx) && equalScalar(pay, pby) && equalScalar(paz, pbz)) { + return [pax, pay, paz]; + } else { + return null; + } + } + function _intersectLinePlane(x1, y1, z1, x2, y2, z2, x, y, z, c) { + var x1x = multiplyScalar(x1, x); + var x2x = multiplyScalar(x2, x); + var y1y = multiplyScalar(y1, y); + var y2y = multiplyScalar(y2, y); + var z1z = multiplyScalar(z1, z); + var z2z = multiplyScalar(z2, z); + var numerator = subtract(subtract(subtract(c, x1x), y1y), z1z); + var denominator = subtract(subtract(subtract(addScalar(addScalar(x2x, y2y), z2z), x1x), y1y), z1z); + var t = divideScalar(numerator, denominator); + var px = addScalar(x1, multiplyScalar(t, subtract(x2, x1))); + var py = addScalar(y1, multiplyScalar(t, subtract(y2, y1))); + var pz = addScalar(z1, multiplyScalar(t, subtract(z2, z1))); + return [px, py, pz]; + // TODO: Add cases when line is parallel to the plane: + // (a) no intersection, + // (b) line contained in plane + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/and.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/and.js new file mode 100644 index 0000000..33c7f5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/and.js @@ -0,0 +1,122 @@ +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'; +import { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { andNumber } from '../../plain/number/index.js'; +var name = 'and'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'not', 'concat']; +export var createAnd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + zeros, + not, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo06xS0S0 = createMatAlgo06xS0S0({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Logical `and`. Test whether two values are both defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.and(x, y) + * + * Examples: + * + * math.and(2, 4) // returns true + * + * a = [2, 0, 0] + * b = [3, 7, 0] + * c = 0 + * + * math.and(a, b) // returns [true, false, false] + * math.and(a, c) // returns [false, false, false] + * + * See also: + * + * not, or, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when both inputs are defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': andNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return (x.re !== 0 || x.im !== 0) && (y.re !== 0 || y.im !== 0); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return !x.isZero() && !y.isZero() && !x.isNaN() && !y.isNaN(); + }, + 'bigint, bigint': andNumber, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)), + 'SparseMatrix, any': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(y)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo11xS0s(x, y, self, false); + }), + 'DenseMatrix, any': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(y)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo14xDs(x, y, self, false); + }), + 'any, SparseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(x)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo11xS0s(y, x, self, true); + }), + 'any, DenseMatrix': typed.referToSelf(self => (x, y) => { + // check scalar + if (not(x)) { + // return zero matrix + return zeros(x.size(), x.storage()); + } + return matAlgo14xDs(y, x, self, true); + }), + 'Array, any': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return self(matrix(x), y).valueOf(); + }), + 'any, Array': typed.referToSelf(self => (x, y) => { + // use matrix implementation + return self(x, matrix(y)).valueOf(); + }) + }, matrixAlgorithmSuite({ + SS: matAlgo06xS0S0, + DS: matAlgo02xDS0 + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/not.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/not.js new file mode 100644 index 0000000..5e0ae17 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/not.js @@ -0,0 +1,48 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { notNumber } from '../../plain/number/index.js'; +var name = 'not'; +var dependencies = ['typed']; +export var createNot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Logical `not`. Flips boolean value of a given parameter. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.not(x) + * + * Examples: + * + * math.not(2) // returns false + * math.not(0) // returns true + * math.not(true) // returns false + * + * a = [2, -7, 0] + * math.not(a) // returns [false, false, true] + * + * See also: + * + * and, or, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @return {boolean | Array | Matrix} + * Returns true when input is a zero or empty value. + */ + return typed(name, { + 'null | undefined': () => true, + number: notNumber, + Complex: function Complex(x) { + return x.re === 0 && x.im === 0; + }, + BigNumber: function BigNumber(x) { + return x.isZero() || x.isNaN(); + }, + bigint: x => !x, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/or.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/or.js new file mode 100644 index 0000000..94fef72 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/or.js @@ -0,0 +1,77 @@ +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { orNumber } from '../../plain/number/index.js'; +var name = 'or'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +export var createOr = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo05xSfSf = createMatAlgo05xSfSf({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Logical `or`. Test if at least one value is defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.or(x, y) + * + * Examples: + * + * math.or(2, 4) // returns true + * + * a = [2, 5, 0] + * b = [0, 22, 0] + * c = 0 + * + * math.or(a, b) // returns [true, true, false] + * math.or(b, c) // returns [false, true, false] + * + * See also: + * + * and, not, xor + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when one of the inputs is defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': orNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return x.re !== 0 || x.im !== 0 || y.re !== 0 || y.im !== 0; + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return !x.isZero() && !x.isNaN() || !y.isZero() && !y.isNaN(); + }, + 'bigint, bigint': orNumber, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)) + }, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/xor.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/xor.js new file mode 100644 index 0000000..dc5d772 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/logical/xor.js @@ -0,0 +1,76 @@ +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { xorNumber } from '../../plain/number/index.js'; +var name = 'xor'; +var dependencies = ['typed', 'matrix', 'DenseMatrix', 'concat']; +export var createXor = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Logical `xor`. Test whether one and only one value is defined with a nonzero/nonempty value. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.xor(x, y) + * + * Examples: + * + * math.xor(2, 4) // returns false + * + * a = [2, 0, 0] + * b = [2, 7, 0] + * c = 0 + * + * math.xor(a, b) // returns [false, true, false] + * math.xor(a, c) // returns [true, false, false] + * + * See also: + * + * and, not, or + * + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} x First value to check + * @param {number | BigNumber | bigint | Complex | Unit | Array | Matrix} y Second value to check + * @return {boolean | Array | Matrix} + * Returns true when one and only one input is defined with a nonzero/nonempty value. + */ + return typed(name, { + 'number, number': xorNumber, + 'Complex, Complex': function Complex_Complex(x, y) { + return (x.re !== 0 || x.im !== 0) !== (y.re !== 0 || y.im !== 0); + }, + 'bigint, bigint': xorNumber, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return (!x.isZero() && !x.isNaN()) !== (!y.isZero() && !y.isNaN()); + }, + 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0)) + }, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/apply.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/apply.js new file mode 100644 index 0000000..f4badc7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/apply.js @@ -0,0 +1,111 @@ +import { factory } from '../../utils/factory.js'; +import { arraySize } from '../../utils/array.js'; +import { isMatrix } from '../../utils/is.js'; +import { IndexError } from '../../error/IndexError.js'; +var name = 'apply'; +var dependencies = ['typed', 'isInteger']; +export var createApply = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isInteger + } = _ref; + /** + * Apply a function that maps an array to a scalar + * along a given axis of a matrix or array. + * Returns a new matrix or array with one less dimension than the input. + * + * Syntax: + * + * math.apply(A, dim, callback) + * + * Where: + * + * - `dim: number` is a zero-based dimension over which to concatenate the matrices. + * + * Examples: + * + * const A = [[1, 2], [3, 4]] + * const sum = math.sum + * + * math.apply(A, 0, sum) // returns [4, 6] + * math.apply(A, 1, sum) // returns [3, 7] + * + * See also: + * + * map, filter, forEach + * + * @param {Array | Matrix} array The input Matrix + * @param {number} dim The dimension along which the callback is applied + * @param {Function} callback The callback function that is applied. This Function + * should take an array or 1-d matrix as an input and + * return a number. + * @return {Array | Matrix} res The residual matrix with the function applied over some dimension. + */ + return typed(name, { + 'Array | Matrix, number | BigNumber, function': function Array__Matrix_number__BigNumber_function(mat, dim, callback) { + if (!isInteger(dim)) { + throw new TypeError('Integer number expected for dimension'); + } + var size = Array.isArray(mat) ? arraySize(mat) : mat.size(); + if (dim < 0 || dim >= size.length) { + throw new IndexError(dim, size.length); + } + if (isMatrix(mat)) { + return mat.create(_apply(mat.valueOf(), dim, callback), mat.datatype()); + } else { + return _apply(mat, dim, callback); + } + } + }); +}); + +/** + * Recursively reduce a matrix + * @param {Array} mat + * @param {number} dim + * @param {Function} callback + * @returns {Array} ret + * @private + */ +function _apply(mat, dim, callback) { + var i, ret, tran; + if (dim <= 0) { + if (!Array.isArray(mat[0])) { + return callback(mat); + } else { + tran = _switch(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _apply(tran[i], dim - 1, callback); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _apply(mat[i], dim - 1, callback); + } + return ret; + } +} + +/** + * Transpose a matrix + * @param {Array} mat + * @returns {Array} ret + * @private + */ +function _switch(mat) { + var I = mat.length; + var J = mat[0].length; + var i, j; + var ret = []; + for (j = 0; j < J; j++) { + var tmp = []; + for (i = 0; i < I; i++) { + tmp.push(mat[i][j]); + } + ret.push(tmp); + } + return ret; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/column.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/column.js new file mode 100644 index 0000000..d0b4a24 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/column.js @@ -0,0 +1,59 @@ +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { validateIndex } from '../../utils/array.js'; +var name = 'column'; +var dependencies = ['typed', 'Index', 'matrix', 'range']; +export var createColumn = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Index, + matrix, + range + } = _ref; + /** + * Return a column from a Matrix. + * + * Syntax: + * + * math.column(value, index) + * + * Example: + * + * // get a column + * const d = [[1, 2], [3, 4]] + * math.column(d, 1) // returns [[2], [4]] + * + * See also: + * + * row + * + * @param {Array | Matrix } value An array or matrix + * @param {number} column The index of the column + * @return {Array | Matrix} The retrieved column + */ + return typed(name, { + 'Matrix, number': _column, + 'Array, number': function Array_number(value, column) { + return _column(matrix(clone(value)), column).valueOf(); + } + }); + + /** + * Retrieve a column of a matrix + * @param {Matrix } value A matrix + * @param {number} column The index of the column + * @return {Matrix} The retrieved column + */ + function _column(value, column) { + // check dimensions + if (value.size().length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + validateIndex(column, value.size()[1]); + var rowRange = range(0, value.size()[0]); + var index = new Index(rowRange, column); + var result = value.subset(index); + return isMatrix(result) ? result : matrix([[result]]); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/concat.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/concat.js new file mode 100644 index 0000000..4c8d793 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/concat.js @@ -0,0 +1,104 @@ +import { isBigNumber, isMatrix, isNumber } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { arraySize, concat as _concat } from '../../utils/array.js'; +import { IndexError } from '../../error/IndexError.js'; +import { DimensionError } from '../../error/DimensionError.js'; +import { factory } from '../../utils/factory.js'; +var name = 'concat'; +var dependencies = ['typed', 'matrix', 'isInteger']; +export var createConcat = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + isInteger + } = _ref; + /** + * Concatenate two or more matrices. + * + * Syntax: + * + * math.concat(A, B, C, ...) + * math.concat(A, B, C, ..., dim) + * + * Where: + * + * - `dim: number` is a zero-based dimension over which to concatenate the matrices. + * By default the last dimension of the matrices. + * + * Examples: + * + * const A = [[1, 2], [5, 6]] + * const B = [[3, 4], [7, 8]] + * + * math.concat(A, B) // returns [[1, 2, 3, 4], [5, 6, 7, 8]] + * math.concat(A, B, 0) // returns [[1, 2], [5, 6], [3, 4], [7, 8]] + * math.concat('hello', ' ', 'world') // returns 'hello world' + * + * See also: + * + * size, squeeze, subset, transpose + * + * @param {... Array | Matrix} args Two or more matrices + * @return {Array | Matrix} Concatenated matrix + */ + return typed(name, { + // TODO: change signature to '...Array | Matrix, dim?' when supported + '...Array | Matrix | number | BigNumber': function Array__Matrix__number__BigNumber(args) { + var i; + var len = args.length; + var dim = -1; // zero-based dimension + var prevDim; + var asMatrix = false; + var matrices = []; // contains multi dimensional arrays + + for (i = 0; i < len; i++) { + var arg = args[i]; + + // test whether we need to return a Matrix (if not we return an Array) + if (isMatrix(arg)) { + asMatrix = true; + } + if (isNumber(arg) || isBigNumber(arg)) { + if (i !== len - 1) { + throw new Error('Dimension must be specified as last argument'); + } + + // last argument contains the dimension on which to concatenate + prevDim = dim; + dim = arg.valueOf(); // change BigNumber to number + + if (!isInteger(dim)) { + throw new TypeError('Integer number expected for dimension'); + } + if (dim < 0 || i > 0 && dim > prevDim) { + // TODO: would be more clear when throwing a DimensionError here + throw new IndexError(dim, prevDim + 1); + } + } else { + // this is a matrix or array + var m = clone(arg).valueOf(); + var size = arraySize(m); + matrices[i] = m; + prevDim = dim; + dim = size.length - 1; + + // verify whether each of the matrices has the same number of dimensions + if (i > 0 && dim !== prevDim) { + throw new DimensionError(prevDim + 1, dim + 1); + } + } + } + if (matrices.length === 0) { + throw new SyntaxError('At least one matrix expected'); + } + var res = matrices.shift(); + while (matrices.length) { + res = _concat(res, matrices.shift(), dim); + } + return asMatrix ? matrix(res) : res; + }, + '...string': function string(args) { + return args.join(''); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/count.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/count.js new file mode 100644 index 0000000..c611970 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/count.js @@ -0,0 +1,39 @@ +import { factory } from '../../utils/factory.js'; +var name = 'count'; +var dependencies = ['typed', 'size', 'prod']; +export var createCount = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + prod + } = _ref; + /** + * Count the number of elements of a matrix, array or string. + * + * Syntax: + * + * math.count(x) + * + * Examples: + * + * math.count('hello world') // returns 11 + * const A = [[1, 2, 3], [4, 5, 6]] + * math.count(A) // returns 6 + * math.count(math.range(1,6)) // returns 5 + * + * See also: + * + * size + * + * @param {string | Array | Matrix} x A matrix or string + * @return {number} An integer with the elements in `x`. + */ + return typed(name, { + string: function string(x) { + return x.length; + }, + 'Matrix | Array': function Matrix__Array(x) { + return prod(size(x)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/cross.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/cross.js new file mode 100644 index 0000000..43647f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/cross.js @@ -0,0 +1,81 @@ +import { arraySize, squeeze } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'cross'; +var dependencies = ['typed', 'matrix', 'subtract', 'multiply']; +export var createCross = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + subtract, + multiply + } = _ref; + /** + * Calculate the cross product for two vectors in three dimensional space. + * The cross product of `A = [a1, a2, a3]` and `B = [b1, b2, b3]` is defined + * as: + * + * cross(A, B) = [ + * a2 * b3 - a3 * b2, + * a3 * b1 - a1 * b3, + * a1 * b2 - a2 * b1 + * ] + * + * If one of the input vectors has a dimension greater than 1, the output + * vector will be a 1x3 (2-dimensional) matrix. + * + * Syntax: + * + * math.cross(x, y) + * + * Examples: + * + * math.cross([1, 1, 0], [0, 1, 1]) // Returns [1, -1, 1] + * math.cross([3, -3, 1], [4, 9, 2]) // Returns [-15, -2, 39] + * math.cross([2, 3, 4], [5, 6, 7]) // Returns [-3, 6, -3] + * math.cross([[1, 2, 3]], [[4], [5], [6]]) // Returns [[-3, 6, -3]] + * + * See also: + * + * dot, multiply + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {Array | Matrix} Returns the cross product of `x` and `y` + */ + return typed(name, { + 'Matrix, Matrix': function Matrix_Matrix(x, y) { + return matrix(_cross(x.toArray(), y.toArray())); + }, + 'Matrix, Array': function Matrix_Array(x, y) { + return matrix(_cross(x.toArray(), y)); + }, + 'Array, Matrix': function Array_Matrix(x, y) { + return matrix(_cross(x, y.toArray())); + }, + 'Array, Array': _cross + }); + + /** + * Calculate the cross product for two arrays + * @param {Array} x First vector + * @param {Array} y Second vector + * @returns {Array} Returns the cross product of x and y + * @private + */ + function _cross(x, y) { + var highestDimension = Math.max(arraySize(x).length, arraySize(y).length); + x = squeeze(x); + y = squeeze(y); + var xSize = arraySize(x); + var ySize = arraySize(y); + if (xSize.length !== 1 || ySize.length !== 1 || xSize[0] !== 3 || ySize[0] !== 3) { + throw new RangeError('Vectors with length 3 expected ' + '(Size A = [' + xSize.join(', ') + '], B = [' + ySize.join(', ') + '])'); + } + var product = [subtract(multiply(x[1], y[2]), multiply(x[2], y[1])), subtract(multiply(x[2], y[0]), multiply(x[0], y[2])), subtract(multiply(x[0], y[1]), multiply(x[1], y[0]))]; + if (highestDimension > 1) { + return [product]; + } else { + return product; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ctranspose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ctranspose.js new file mode 100644 index 0000000..19836d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ctranspose.js @@ -0,0 +1,37 @@ +import { factory } from '../../utils/factory.js'; +var name = 'ctranspose'; +var dependencies = ['typed', 'transpose', 'conj']; +export var createCtranspose = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + transpose, + conj + } = _ref; + /** + * Transpose and complex conjugate a matrix. All values of the matrix are + * reflected over its main diagonal and then the complex conjugate is + * taken. This is equivalent to complex conjugation for scalars and + * vectors. + * + * Syntax: + * + * math.ctranspose(x) + * + * Examples: + * + * const A = [[1, 2, 3], [4, 5, math.complex(6,7)]] + * math.ctranspose(A) // returns [[1, 4], [2, 5], [3, {re:6,im:7}]] + * + * See also: + * + * transpose, diag, inv, subset, squeeze + * + * @param {Array | Matrix} x Matrix to be ctransposed + * @return {Array | Matrix} The ctransposed matrix + */ + return typed(name, { + any: function any(x) { + return conj(transpose(x)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/det.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/det.js new file mode 100644 index 0000000..a90df04 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/det.js @@ -0,0 +1,142 @@ +import { isMatrix } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { format } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +var name = 'det'; +var dependencies = ['typed', 'matrix', 'subtractScalar', 'multiply', 'divideScalar', 'isZero', 'unaryMinus']; +export var createDet = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + subtractScalar, + multiply, + divideScalar, + isZero, + unaryMinus + } = _ref; + /** + * Calculate the determinant of a matrix. + * + * Syntax: + * + * math.det(x) + * + * Examples: + * + * math.det([[1, 2], [3, 4]]) // returns -2 + * + * const A = [ + * [-2, 2, 3], + * [-1, 1, 3], + * [2, 0, -1] + * ] + * math.det(A) // returns 6 + * + * See also: + * + * inv + * + * @param {Array | Matrix} x A matrix + * @return {number} The determinant of `x` + */ + return typed(name, { + any: function any(x) { + return clone(x); + }, + 'Array | Matrix': function det(x) { + var size; + if (isMatrix(x)) { + size = x.size(); + } else if (Array.isArray(x)) { + x = matrix(x); + size = x.size(); + } else { + // a scalar + size = []; + } + switch (size.length) { + case 0: + // scalar + return clone(x); + case 1: + // vector + if (size[0] === 1) { + return clone(x.valueOf()[0]); + } + if (size[0] === 0) { + return 1; // det of an empty matrix is per definition 1 + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + case 2: + { + // two-dimensional array + var rows = size[0]; + var cols = size[1]; + if (rows === cols) { + return _det(x.clone().valueOf(), rows, cols); + } + if (cols === 0) { + return 1; // det of an empty matrix is per definition 1 + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + format(size) + ')'); + } + } + }); + + /** + * Calculate the determinant of a matrix + * @param {Array[]} matrix A square, two dimensional matrix + * @param {number} rows Number of rows of the matrix (zero-based) + * @param {number} cols Number of columns of the matrix (zero-based) + * @returns {number} det + * @private + */ + function _det(matrix, rows, cols) { + if (rows === 1) { + // this is a 1 x 1 matrix + return clone(matrix[0][0]); + } else if (rows === 2) { + // this is a 2 x 2 matrix + // the determinant of [a11,a12;a21,a22] is det = a11*a22-a21*a12 + return subtractScalar(multiply(matrix[0][0], matrix[1][1]), multiply(matrix[1][0], matrix[0][1])); + } else { + // Bareiss algorithm + // this algorithm have same complexity as LUP decomposition (O(n^3)) + // but it preserve precision of floating point more relative to the LUP decomposition + var negated = false; + var rowIndices = new Array(rows).fill(0).map((_, i) => i); // matrix index of row i + for (var k = 0; k < rows; k++) { + var k_ = rowIndices[k]; + if (isZero(matrix[k_][k])) { + var _k = void 0; + for (_k = k + 1; _k < rows; _k++) { + if (!isZero(matrix[rowIndices[_k]][k])) { + k_ = rowIndices[_k]; + rowIndices[_k] = rowIndices[k]; + rowIndices[k] = k_; + negated = !negated; + break; + } + } + if (_k === rows) return matrix[k_][k]; // some zero of the type + } + var piv = matrix[k_][k]; + var piv_ = k === 0 ? 1 : matrix[rowIndices[k - 1]][k - 1]; + for (var i = k + 1; i < rows; i++) { + var i_ = rowIndices[i]; + for (var j = k + 1; j < rows; j++) { + matrix[i_][j] = divideScalar(subtractScalar(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_); + } + } + } + var det = matrix[rowIndices[rows - 1]][rows - 1]; + return negated ? unaryMinus(det) : det; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diag.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diag.js new file mode 100644 index 0000000..af27a95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diag.js @@ -0,0 +1,155 @@ +import { isMatrix } from '../../utils/is.js'; +import { arraySize } from '../../utils/array.js'; +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'diag'; +var dependencies = ['typed', 'matrix', 'DenseMatrix', 'SparseMatrix']; +export var createDiag = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a diagonal matrix or retrieve the diagonal of a matrix + * + * When `x` is a vector, a matrix with vector `x` on the diagonal will be returned. + * When `x` is a two dimensional matrix, the matrixes `k`th diagonal will be returned as vector. + * When k is positive, the values are placed on the super diagonal. + * When k is negative, the values are placed on the sub diagonal. + * + * Syntax: + * + * math.diag(X) + * math.diag(X, format) + * math.diag(X, k) + * math.diag(X, k, format) + * + * Examples: + * + * // create a diagonal matrix + * math.diag([1, 2, 3]) // returns [[1, 0, 0], [0, 2, 0], [0, 0, 3]] + * math.diag([1, 2, 3], 1) // returns [[0, 1, 0, 0], [0, 0, 2, 0], [0, 0, 0, 3]] + * math.diag([1, 2, 3], -1) // returns [[0, 0, 0], [1, 0, 0], [0, 2, 0], [0, 0, 3]] + * + * // retrieve the diagonal from a matrix + * const a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] + * math.diag(a) // returns [1, 5, 9] + * + * See also: + * + * ones, zeros, identity + * + * @param {Matrix | Array} x A two dimensional matrix or a vector + * @param {number | BigNumber} [k=0] The diagonal where the vector will be filled + * in or retrieved. + * @param {string} [format='dense'] The matrix storage format. + * + * @returns {Matrix | Array} Diagonal matrix from input vector, or diagonal from input matrix. + */ + return typed(name, { + // FIXME: simplify this huge amount of signatures as soon as typed-function supports optional arguments + + Array: function Array(x) { + return _diag(x, 0, arraySize(x), null); + }, + 'Array, number': function Array_number(x, k) { + return _diag(x, k, arraySize(x), null); + }, + 'Array, BigNumber': function Array_BigNumber(x, k) { + return _diag(x, k.toNumber(), arraySize(x), null); + }, + 'Array, string': function Array_string(x, format) { + return _diag(x, 0, arraySize(x), format); + }, + 'Array, number, string': function Array_number_string(x, k, format) { + return _diag(x, k, arraySize(x), format); + }, + 'Array, BigNumber, string': function Array_BigNumber_string(x, k, format) { + return _diag(x, k.toNumber(), arraySize(x), format); + }, + Matrix: function Matrix(x) { + return _diag(x, 0, x.size(), x.storage()); + }, + 'Matrix, number': function Matrix_number(x, k) { + return _diag(x, k, x.size(), x.storage()); + }, + 'Matrix, BigNumber': function Matrix_BigNumber(x, k) { + return _diag(x, k.toNumber(), x.size(), x.storage()); + }, + 'Matrix, string': function Matrix_string(x, format) { + return _diag(x, 0, x.size(), format); + }, + 'Matrix, number, string': function Matrix_number_string(x, k, format) { + return _diag(x, k, x.size(), format); + }, + 'Matrix, BigNumber, string': function Matrix_BigNumber_string(x, k, format) { + return _diag(x, k.toNumber(), x.size(), format); + } + }); + + /** + * Creeate diagonal matrix from a vector or vice versa + * @param {Array | Matrix} x + * @param {number} k + * @param {string} format Storage format for matrix. If null, + * an Array is returned + * @returns {Array | Matrix} + * @private + */ + function _diag(x, k, size, format) { + if (!isInteger(k)) { + throw new TypeError('Second parameter in function diag must be an integer'); + } + var kSuper = k > 0 ? k : 0; + var kSub = k < 0 ? -k : 0; + + // check dimensions + switch (size.length) { + case 1: + return _createDiagonalMatrix(x, k, format, size[0], kSub, kSuper); + case 2: + return _getDiagonal(x, k, format, size, kSub, kSuper); + } + throw new RangeError('Matrix for function diag must be 2 dimensional'); + } + function _createDiagonalMatrix(x, k, format, l, kSub, kSuper) { + // matrix size + var ms = [l + kSub, l + kSuper]; + if (format && format !== 'sparse' && format !== 'dense') { + throw new TypeError("Unknown matrix type ".concat(format, "\"")); + } + + // create diagonal matrix + var m = format === 'sparse' ? SparseMatrix.diagonal(ms, x, k) : DenseMatrix.diagonal(ms, x, k); + // check we need to return a matrix + return format !== null ? m : m.valueOf(); + } + function _getDiagonal(x, k, format, s, kSub, kSuper) { + // check x is a Matrix + if (isMatrix(x)) { + // get diagonal matrix + var dm = x.diagonal(k); + // check we need to return a matrix + if (format !== null) { + // check we need to change matrix format + if (format !== dm.storage()) { + return matrix(dm, format); + } + return dm; + } + return dm.valueOf(); + } + // vector size + var n = Math.min(s[0] - kSub, s[1] - kSuper); + // diagonal values + var vector = []; + // loop diagonal + for (var i = 0; i < n; i++) { + vector[i] = x[i + kSub][i + kSuper]; + } + // check we need to return a matrix + return format !== null ? matrix(vector) : vector; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diff.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diff.js new file mode 100644 index 0000000..ca211d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/diff.js @@ -0,0 +1,163 @@ +import { factory } from '../../utils/factory.js'; +import { isInteger } from '../../utils/number.js'; +import { isMatrix } from '../../utils/is.js'; +var name = 'diff'; +var dependencies = ['typed', 'matrix', 'subtract', 'number']; +export var createDiff = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + subtract, + number + } = _ref; + /** + * Create a new matrix or array of the difference between elements of the given array + * The optional dim parameter lets you specify the dimension to evaluate the difference of + * If no dimension parameter is passed it is assumed as dimension 0 + * + * Dimension is zero-based in javascript and one-based in the parser and can be a number or bignumber + * Arrays must be 'rectangular' meaning arrays like [1, 2] + * If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays + * + * Syntax: + * + * math.diff(arr) + * math.diff(arr, dim) + * + * Examples: + * + * const arr = [1, 2, 4, 7, 0] + * math.diff(arr) // returns [1, 2, 3, -7] (no dimension passed so 0 is assumed) + * math.diff(math.matrix(arr)) // returns Matrix [1, 2, 3, -7] + * + * const arr = [[1, 2, 3, 4, 5], [1, 2, 3, 4, 5], [9, 8, 7, 6, 4]] + * math.diff(arr) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]] + * math.diff(arr, 0) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]] + * math.diff(arr, 1) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]] + * math.diff(arr, math.bignumber(1)) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]] + * + * math.diff(arr, 2) // throws RangeError as arr is 2 dimensional not 3 + * math.diff(arr, -1) // throws RangeError as negative dimensions are not allowed + * + * // These will all produce the same result + * math.diff([[1, 2], [3, 4]]) + * math.diff([math.matrix([1, 2]), math.matrix([3, 4])]) + * math.diff([[1, 2], math.matrix([3, 4])]) + * math.diff([math.matrix([1, 2]), [3, 4]]) + * // They do not produce the same result as math.diff(math.matrix([[1, 2], [3, 4]])) as this returns a matrix + * + * See Also: + * + * sum + * subtract + * partitionSelect + * + * @param {Array | Matrix} arr An array or matrix + * @param {number | BigNumber} dim Dimension + * @return {Array | Matrix} Difference between array elements in given dimension + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(arr) { + // No dimension specified => assume dimension 0 + if (isMatrix(arr)) { + return matrix(_diff(arr.toArray())); + } else { + return _diff(arr); + } + }, + 'Array | Matrix, number': function Array__Matrix_number(arr, dim) { + if (!isInteger(dim)) throw new RangeError('Dimension must be a whole number'); + if (isMatrix(arr)) { + return matrix(_recursive(arr.toArray(), dim)); + } else { + return _recursive(arr, dim); + } + }, + 'Array, BigNumber': typed.referTo('Array,number', selfAn => (arr, dim) => selfAn(arr, number(dim))), + 'Matrix, BigNumber': typed.referTo('Matrix,number', selfMn => (arr, dim) => selfMn(arr, number(dim))) + }); + + /** + * Recursively find the correct dimension in the array/matrix + * Then Apply _diff to that dimension + * + * @param {Array} arr The array + * @param {number} dim Dimension + * @return {Array} resulting array + */ + function _recursive(arr, dim) { + if (isMatrix(arr)) { + arr = arr.toArray(); // Makes sure arrays like [ matrix([0, 1]), matrix([1, 0]) ] are processed properly + } + if (!Array.isArray(arr)) { + throw RangeError('Array/Matrix does not have that many dimensions'); + } + if (dim > 0) { + var result = []; + arr.forEach(element => { + result.push(_recursive(element, dim - 1)); + }); + return result; + } else if (dim === 0) { + return _diff(arr); + } else { + throw RangeError('Cannot have negative dimension'); + } + } + + /** + * Difference between elements in the array + * + * @param {Array} arr An array + * @return {Array} resulting array + */ + function _diff(arr) { + var result = []; + var size = arr.length; + for (var i = 1; i < size; i++) { + result.push(_ElementDiff(arr[i - 1], arr[i])); + } + return result; + } + + /** + * Difference between 2 objects + * + * @param {Object} obj1 First object + * @param {Object} obj2 Second object + * @return {Array} resulting array + */ + function _ElementDiff(obj1, obj2) { + // Convert matrices to arrays + if (isMatrix(obj1)) obj1 = obj1.toArray(); + if (isMatrix(obj2)) obj2 = obj2.toArray(); + var obj1IsArray = Array.isArray(obj1); + var obj2IsArray = Array.isArray(obj2); + if (obj1IsArray && obj2IsArray) { + return _ArrayDiff(obj1, obj2); + } + if (!obj1IsArray && !obj2IsArray) { + return subtract(obj2, obj1); // Difference is (second - first) NOT (first - second) + } + throw TypeError('Cannot calculate difference between 1 array and 1 non-array'); + } + + /** + * Difference of elements in 2 arrays + * + * @param {Array} arr1 Array 1 + * @param {Array} arr2 Array 2 + * @return {Array} resulting array + */ + function _ArrayDiff(arr1, arr2) { + if (arr1.length !== arr2.length) { + throw RangeError('Not all sub-arrays have the same length'); + } + var result = []; + var size = arr1.length; + for (var i = 0; i < size; i++) { + result.push(_ElementDiff(arr1[i], arr2[i])); + } + return result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/dot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/dot.js new file mode 100644 index 0000000..8bc4793 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/dot.js @@ -0,0 +1,156 @@ +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +var name = 'dot'; +var dependencies = ['typed', 'addScalar', 'multiplyScalar', 'conj', 'size']; +export var createDot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + addScalar, + multiplyScalar, + conj, + size + } = _ref; + /** + * Calculate the dot product of two vectors. The dot product of + * `A = [a1, a2, ..., an]` and `B = [b1, b2, ..., bn]` is defined as: + * + * dot(A, B) = conj(a1) * b1 + conj(a2) * b2 + ... + conj(an) * bn + * + * Syntax: + * + * math.dot(x, y) + * + * Examples: + * + * math.dot([2, 4, 1], [2, 2, 3]) // returns number 15 + * math.multiply([2, 4, 1], [2, 2, 3]) // returns number 15 + * + * See also: + * + * multiply, cross + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {number} Returns the dot product of `x` and `y` + */ + return typed(name, { + 'Array | DenseMatrix, Array | DenseMatrix': _denseDot, + 'SparseMatrix, SparseMatrix': _sparseDot + }); + function _validateDim(x, y) { + var xSize = _size(x); + var ySize = _size(y); + var xLen, yLen; + if (xSize.length === 1) { + xLen = xSize[0]; + } else if (xSize.length === 2 && xSize[1] === 1) { + xLen = xSize[0]; + } else { + throw new RangeError('Expected a column vector, instead got a matrix of size (' + xSize.join(', ') + ')'); + } + if (ySize.length === 1) { + yLen = ySize[0]; + } else if (ySize.length === 2 && ySize[1] === 1) { + yLen = ySize[0]; + } else { + throw new RangeError('Expected a column vector, instead got a matrix of size (' + ySize.join(', ') + ')'); + } + if (xLen !== yLen) throw new RangeError('Vectors must have equal length (' + xLen + ' != ' + yLen + ')'); + if (xLen === 0) throw new RangeError('Cannot calculate the dot product of empty vectors'); + return xLen; + } + function _denseDot(a, b) { + var N = _validateDim(a, b); + var adata = isMatrix(a) ? a._data : a; + var adt = isMatrix(a) ? a._datatype || a.getDataType() : undefined; + var bdata = isMatrix(b) ? b._data : b; + var bdt = isMatrix(b) ? b._datatype || b.getDataType() : undefined; + + // are these 2-dimensional column vectors? (as opposed to 1-dimensional vectors) + var aIsColumn = _size(a).length === 2; + var bIsColumn = _size(b).length === 2; + var add = addScalar; + var mul = multiplyScalar; + + // process data types + if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') { + var dt = adt; + // find signatures that matches (dt, dt) + add = typed.find(addScalar, [dt, dt]); + mul = typed.find(multiplyScalar, [dt, dt]); + } + + // both vectors 1-dimensional + if (!aIsColumn && !bIsColumn) { + var c = mul(conj(adata[0]), bdata[0]); + for (var i = 1; i < N; i++) { + c = add(c, mul(conj(adata[i]), bdata[i])); + } + return c; + } + + // a is 1-dim, b is column + if (!aIsColumn && bIsColumn) { + var _c = mul(conj(adata[0]), bdata[0][0]); + for (var _i = 1; _i < N; _i++) { + _c = add(_c, mul(conj(adata[_i]), bdata[_i][0])); + } + return _c; + } + + // a is column, b is 1-dim + if (aIsColumn && !bIsColumn) { + var _c2 = mul(conj(adata[0][0]), bdata[0]); + for (var _i2 = 1; _i2 < N; _i2++) { + _c2 = add(_c2, mul(conj(adata[_i2][0]), bdata[_i2])); + } + return _c2; + } + + // both vectors are column + if (aIsColumn && bIsColumn) { + var _c3 = mul(conj(adata[0][0]), bdata[0][0]); + for (var _i3 = 1; _i3 < N; _i3++) { + _c3 = add(_c3, mul(conj(adata[_i3][0]), bdata[_i3][0])); + } + return _c3; + } + } + function _sparseDot(x, y) { + _validateDim(x, y); + var xindex = x._index; + var xvalues = x._values; + var yindex = y._index; + var yvalues = y._values; + + // TODO optimize add & mul using datatype + var c = 0; + var add = addScalar; + var mul = multiplyScalar; + var i = 0; + var j = 0; + while (i < xindex.length && j < yindex.length) { + var I = xindex[i]; + var J = yindex[j]; + if (I < J) { + i++; + continue; + } + if (I > J) { + j++; + continue; + } + if (I === J) { + c = add(c, mul(xvalues[i], yvalues[j])); + i++; + j++; + } + } + return c; + } + + // TODO remove this once #1771 is fixed + function _size(x) { + return isMatrix(x) ? x.size() : size(x); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs.js new file mode 100644 index 0000000..fdde565 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs.js @@ -0,0 +1,328 @@ +import _extends from "@babel/runtime/helpers/extends"; +import { factory } from '../../utils/factory.js'; +import { format } from '../../utils/string.js'; +import { createComplexEigs } from './eigs/complexEigs.js'; +import { createRealSymmetric } from './eigs/realSymmetric.js'; +import { typeOf, isNumber, isBigNumber, isComplex, isFraction } from '../../utils/is.js'; +var name = 'eigs'; + +// The absolute state of math.js's dependency system: +var dependencies = ['config', 'typed', 'matrix', 'addScalar', 'equal', 'subtract', 'abs', 'atan', 'cos', 'sin', 'multiplyScalar', 'divideScalar', 'inv', 'bignumber', 'multiply', 'add', 'larger', 'column', 'flatten', 'number', 'complex', 'sqrt', 'diag', 'size', 'reshape', 'qr', 'usolve', 'usolveAll', 'im', 're', 'smaller', 'matrixFromColumns', 'dot']; +export var createEigs = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + typed, + matrix, + addScalar, + subtract, + equal, + abs, + atan, + cos, + sin, + multiplyScalar, + divideScalar, + inv, + bignumber, + multiply, + add, + larger, + column, + flatten, + number, + complex, + sqrt, + diag, + size, + reshape, + qr, + usolve, + usolveAll, + im, + re, + smaller, + matrixFromColumns, + dot + } = _ref; + var doRealSymmetric = createRealSymmetric({ + config, + addScalar, + subtract, + column, + flatten, + equal, + abs, + atan, + cos, + sin, + multiplyScalar, + inv, + bignumber, + complex, + multiply, + add + }); + var doComplexEigs = createComplexEigs({ + config, + addScalar, + subtract, + multiply, + multiplyScalar, + flatten, + divideScalar, + sqrt, + abs, + bignumber, + diag, + size, + reshape, + qr, + inv, + usolve, + usolveAll, + equal, + complex, + larger, + smaller, + matrixFromColumns, + dot + }); + + /** + * Compute eigenvalues and optionally eigenvectors of a square matrix. + * The eigenvalues are sorted by their absolute value, ascending, and + * returned as a vector in the `values` property of the returned project. + * An eigenvalue with algebraic multiplicity k will be listed k times, so + * that the returned `values` vector always has length equal to the size + * of the input matrix. + * + * The `eigenvectors` property of the return value provides the eigenvectors. + * It is an array of plain objects: the `value` property of each gives the + * associated eigenvalue, and the `vector` property gives the eigenvector + * itself. Note that the same `value` property will occur as many times in + * the list provided by `eigenvectors` as the geometric multiplicity of + * that value. + * + * If the algorithm fails to converge, it will throw an error – + * in that case, however, you may still find useful information + * in `err.values` and `err.vectors`. + * + * Note that the 'precision' option does not directly specify the _accuracy_ + * of the returned eigenvalues. Rather, it determines how small an entry + * of the iterative approximations to an upper triangular matrix must be + * in order to be considered zero. The actual accuracy of the returned + * eigenvalues may be greater or less than the precision, depending on the + * conditioning of the matrix and how far apart or close the actual + * eigenvalues are. Note that currently, relatively simple, "traditional" + * methods of eigenvalue computation are being used; this is not a modern, + * high-precision eigenvalue computation. That said, it should typically + * produce fairly reasonable results. + * + * Syntax: + * + * math.eigs(x, [prec]) + * math.eigs(x, {options}) + * + * Examples: + * + * const { eigs, multiply, column, transpose, matrixFromColumns } = math + * const H = [[5, 2.3], [2.3, 1]] + * const ans = eigs(H) // returns {values: [E1,E2...sorted], eigenvectors: [{value: E1, vector: v2}, {value: e, vector: v2}, ...] + * const E = ans.values + * const V = ans.eigenvectors + * multiply(H, V[0].vector)) // returns multiply(E[0], V[0].vector)) + * const U = matrixFromColumns(...V.map(obj => obj.vector)) + * const UTxHxU = multiply(transpose(U), H, U) // diagonalizes H if possible + * E[0] == UTxHxU[0][0] // returns true always + * + * // Compute only approximate eigenvalues: + * const {values} = eigs(H, {eigenvectors: false, precision: 1e-6}) + * + * See also: + * + * inv + * + * @param {Array | Matrix} x Matrix to be diagonalized + * + * @param {number | BigNumber | OptsObject} [opts] Object with keys `precision`, defaulting to config.relTol, and `eigenvectors`, defaulting to true and specifying whether to compute eigenvectors. If just a number, specifies precision. + * @return {{values: Array|Matrix, eigenvectors?: Array}} Object containing an array of eigenvalues and an array of {value: number|BigNumber, vector: Array|Matrix} objects. The eigenvectors property is undefined if eigenvectors were not requested. + * + */ + return typed('eigs', { + // The conversion to matrix in the first two implementations, + // just to convert back to an array right away in + // computeValuesAndVectors, is unfortunate, and should perhaps be + // streamlined. It is done because the Matrix object carries some + // type information about its entries, and so constructing the matrix + // is a roundabout way of doing type detection. + Array: function Array(x) { + return doEigs(matrix(x)); + }, + 'Array, number|BigNumber': function Array_numberBigNumber(x, prec) { + return doEigs(matrix(x), { + precision: prec + }); + }, + 'Array, Object'(x, opts) { + return doEigs(matrix(x), opts); + }, + Matrix: function Matrix(mat) { + return doEigs(mat, { + matricize: true + }); + }, + 'Matrix, number|BigNumber': function Matrix_numberBigNumber(mat, prec) { + return doEigs(mat, { + precision: prec, + matricize: true + }); + }, + 'Matrix, Object': function Matrix_Object(mat, opts) { + var useOpts = { + matricize: true + }; + _extends(useOpts, opts); + return doEigs(mat, useOpts); + } + }); + function doEigs(mat) { + var _opts$precision; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var computeVectors = 'eigenvectors' in opts ? opts.eigenvectors : true; + var prec = (_opts$precision = opts.precision) !== null && _opts$precision !== void 0 ? _opts$precision : config.relTol; + var result = computeValuesAndVectors(mat, prec, computeVectors); + if (opts.matricize) { + result.values = matrix(result.values); + if (computeVectors) { + result.eigenvectors = result.eigenvectors.map(_ref2 => { + var { + value, + vector + } = _ref2; + return { + value, + vector: matrix(vector) + }; + }); + } + } + if (computeVectors) { + Object.defineProperty(result, 'vectors', { + enumerable: false, + // to make sure that the eigenvectors can still be + // converted to string. + get: () => { + throw new Error('eigs(M).vectors replaced with eigs(M).eigenvectors'); + } + }); + } + return result; + } + function computeValuesAndVectors(mat, prec, computeVectors) { + var arr = mat.toArray(); // NOTE: arr is guaranteed to be unaliased + // and so safe to modify in place + var asize = mat.size(); + if (asize.length !== 2 || asize[0] !== asize[1]) { + throw new RangeError("Matrix must be square (size: ".concat(format(asize), ")")); + } + var N = asize[0]; + if (isReal(arr, N, prec)) { + coerceReal(arr, N); // modifies arr by side effect + + if (isSymmetric(arr, N, prec)) { + var _type = coerceTypes(mat, arr, N); // modifies arr by side effect + return doRealSymmetric(arr, N, prec, _type, computeVectors); + } + } + var type = coerceTypes(mat, arr, N); // modifies arr by side effect + return doComplexEigs(arr, N, prec, type, computeVectors); + } + + /** @return {boolean} */ + function isSymmetric(arr, N, prec) { + for (var i = 0; i < N; i++) { + for (var j = i; j < N; j++) { + // TODO proper comparison of bignum and frac + if (larger(bignumber(abs(subtract(arr[i][j], arr[j][i]))), prec)) { + return false; + } + } + } + return true; + } + + /** @return {boolean} */ + function isReal(arr, N, prec) { + for (var i = 0; i < N; i++) { + for (var j = 0; j < N; j++) { + // TODO proper comparison of bignum and frac + if (larger(bignumber(abs(im(arr[i][j]))), prec)) { + return false; + } + } + } + return true; + } + function coerceReal(arr, N) { + for (var i = 0; i < N; i++) { + for (var j = 0; j < N; j++) { + arr[i][j] = re(arr[i][j]); + } + } + } + + /** @return {'number' | 'BigNumber' | 'Complex'} */ + function coerceTypes(mat, arr, N) { + /** @type {string} */ + var type = mat.datatype(); + if (type === 'number' || type === 'BigNumber' || type === 'Complex') { + return type; + } + var hasNumber = false; + var hasBig = false; + var hasComplex = false; + for (var i = 0; i < N; i++) { + for (var j = 0; j < N; j++) { + var el = arr[i][j]; + if (isNumber(el) || isFraction(el)) { + hasNumber = true; + } else if (isBigNumber(el)) { + hasBig = true; + } else if (isComplex(el)) { + hasComplex = true; + } else { + throw TypeError('Unsupported type in Matrix: ' + typeOf(el)); + } + } + } + if (hasBig && hasComplex) { + console.warn('Complex BigNumbers not supported, this operation will lose precission.'); + } + if (hasComplex) { + for (var _i = 0; _i < N; _i++) { + for (var _j = 0; _j < N; _j++) { + arr[_i][_j] = complex(arr[_i][_j]); + } + } + return 'Complex'; + } + if (hasBig) { + for (var _i2 = 0; _i2 < N; _i2++) { + for (var _j2 = 0; _j2 < N; _j2++) { + arr[_i2][_j2] = bignumber(arr[_i2][_j2]); + } + } + return 'BigNumber'; + } + if (hasNumber) { + for (var _i3 = 0; _i3 < N; _i3++) { + for (var _j3 = 0; _j3 < N; _j3++) { + arr[_i3][_j3] = number(arr[_i3][_j3]); + } + } + return 'number'; + } else { + throw TypeError('Matrix contains unsupported types only.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/complexEigs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/complexEigs.js new file mode 100644 index 0000000..2463c42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/complexEigs.js @@ -0,0 +1,698 @@ +import { clone } from '../../../utils/object.js'; +export function createComplexEigs(_ref) { + var { + addScalar, + subtract, + flatten, + multiply, + multiplyScalar, + divideScalar, + sqrt, + abs, + bignumber, + diag, + size, + reshape, + inv, + qr, + usolve, + usolveAll, + equal, + complex, + larger, + smaller, + matrixFromColumns, + dot + } = _ref; + /** + * @param {number[][]} arr the matrix to find eigenvalues of + * @param {number} N size of the matrix + * @param {number|BigNumber} prec precision, anything lower will be considered zero + * @param {'number'|'BigNumber'|'Complex'} type + * @param {boolean} findVectors should we find eigenvectors? + * + * @returns {{ values: number[], vectors: number[][] }} + */ + function complexEigs(arr, N, prec, type) { + var findVectors = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; + // TODO check if any row/col are zero except the diagonal + + // make sure corresponding rows and columns have similar magnitude + // important because of numerical stability + // MODIFIES arr by side effect! + var R = balance(arr, N, prec, type, findVectors); + + // R is the row transformation matrix + // arr = A' = R A R^-1, A is the original matrix + // (if findVectors is false, R is undefined) + // (And so to return to original matrix: A = R^-1 arr R) + + // TODO if magnitudes of elements vary over many orders, + // move greatest elements to the top left corner + + // using similarity transformations, reduce the matrix + // to Hessenberg form (upper triangular plus one subdiagonal row) + // updates the transformation matrix R with new row operationsq + // MODIFIES arr by side effect! + reduceToHessenberg(arr, N, prec, type, findVectors, R); + // still true that original A = R^-1 arr R) + + // find eigenvalues + var { + values, + C + } = iterateUntilTriangular(arr, N, prec, type, findVectors); + + // values is the list of eigenvalues, C is the column + // transformation matrix that transforms arr, the hessenberg + // matrix, to upper triangular + // (So U = C^-1 arr C and the relationship between current arr + // and original A is unchanged.) + + if (findVectors) { + var eigenvectors = findEigenvectors(arr, N, C, R, values, prec, type); + return { + values, + eigenvectors + }; + } + return { + values + }; + } + + /** + * @param {number[][]} arr + * @param {number} N + * @param {number} prec + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {number[][]} + */ + function balance(arr, N, prec, type, findVectors) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var realzero = big ? bignumber(0) : 0; + var one = big ? bignumber(1) : cplx ? complex(1) : 1; + var realone = big ? bignumber(1) : 1; + + // base of the floating-point arithmetic + var radix = big ? bignumber(10) : 2; + var radixSq = multiplyScalar(radix, radix); + + // the diagonal transformation matrix R + var Rdiag; + if (findVectors) { + Rdiag = Array(N).fill(one); + } + + // this isn't the only time we loop thru the matrix... + var last = false; + while (!last) { + // ...haha I'm joking! unless... + last = true; + for (var i = 0; i < N; i++) { + // compute the taxicab norm of i-th column and row + // TODO optimize for complex numbers + var colNorm = realzero; + var rowNorm = realzero; + for (var j = 0; j < N; j++) { + if (i === j) continue; + colNorm = addScalar(colNorm, abs(arr[j][i])); + rowNorm = addScalar(rowNorm, abs(arr[i][j])); + } + if (!equal(colNorm, 0) && !equal(rowNorm, 0)) { + // find integer power closest to balancing the matrix + // (we want to scale only by integer powers of radix, + // so that we don't lose any precision due to round-off) + + var f = realone; + var c = colNorm; + var rowDivRadix = divideScalar(rowNorm, radix); + var rowMulRadix = multiplyScalar(rowNorm, radix); + while (smaller(c, rowDivRadix)) { + c = multiplyScalar(c, radixSq); + f = multiplyScalar(f, radix); + } + while (larger(c, rowMulRadix)) { + c = divideScalar(c, radixSq); + f = divideScalar(f, radix); + } + + // check whether balancing is needed + // condition = (c + rowNorm) / f < 0.95 * (colNorm + rowNorm) + var condition = smaller(divideScalar(addScalar(c, rowNorm), f), multiplyScalar(addScalar(colNorm, rowNorm), 0.95)); + + // apply balancing similarity transformation + if (condition) { + // we should loop once again to check whether + // another rebalancing is needed + last = false; + var g = divideScalar(1, f); + for (var _j = 0; _j < N; _j++) { + if (i === _j) { + continue; + } + arr[i][_j] = multiplyScalar(arr[i][_j], g); + arr[_j][i] = multiplyScalar(arr[_j][i], f); + } + + // keep track of transformations + if (findVectors) { + Rdiag[i] = multiplyScalar(Rdiag[i], g); + } + } + } + } + } + + // return the diagonal row transformation matrix + return findVectors ? diag(Rdiag) : null; + } + + /** + * @param {number[][]} arr + * @param {number} N + * @param {number} prec + * @param {'number'|'BigNumber'|'Complex'} type + * @param {boolean} findVectors + * @param {number[][]} R the row transformation matrix that will be modified + */ + function reduceToHessenberg(arr, N, prec, type, findVectors, R) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var zero = big ? bignumber(0) : cplx ? complex(0) : 0; + if (big) { + prec = bignumber(prec); + } + for (var i = 0; i < N - 2; i++) { + // Find the largest subdiag element in the i-th col + + var maxIndex = 0; + var max = zero; + for (var j = i + 1; j < N; j++) { + var el = arr[j][i]; + if (smaller(abs(max), abs(el))) { + max = el; + maxIndex = j; + } + } + + // This col is pivoted, no need to do anything + if (smaller(abs(max), prec)) { + continue; + } + if (maxIndex !== i + 1) { + // Interchange maxIndex-th and (i+1)-th row + var tmp1 = arr[maxIndex]; + arr[maxIndex] = arr[i + 1]; + arr[i + 1] = tmp1; + + // Interchange maxIndex-th and (i+1)-th column + for (var _j2 = 0; _j2 < N; _j2++) { + var tmp2 = arr[_j2][maxIndex]; + arr[_j2][maxIndex] = arr[_j2][i + 1]; + arr[_j2][i + 1] = tmp2; + } + + // keep track of transformations + if (findVectors) { + var tmp3 = R[maxIndex]; + R[maxIndex] = R[i + 1]; + R[i + 1] = tmp3; + } + } + + // Reduce following rows and columns + for (var _j3 = i + 2; _j3 < N; _j3++) { + var n = divideScalar(arr[_j3][i], max); + if (n === 0) { + continue; + } + + // from j-th row subtract n-times (i+1)th row + for (var k = 0; k < N; k++) { + arr[_j3][k] = subtract(arr[_j3][k], multiplyScalar(n, arr[i + 1][k])); + } + + // to (i+1)th column add n-times j-th column + for (var _k = 0; _k < N; _k++) { + arr[_k][i + 1] = addScalar(arr[_k][i + 1], multiplyScalar(n, arr[_k][_j3])); + } + + // keep track of transformations + if (findVectors) { + for (var _k2 = 0; _k2 < N; _k2++) { + R[_j3][_k2] = subtract(R[_j3][_k2], multiplyScalar(n, R[i + 1][_k2])); + } + } + } + } + return R; + } + + /** + * @returns {{values: values, C: Matrix}} + * @see Press, Wiliams: Numerical recipes in Fortran 77 + * @see https://en.wikipedia.org/wiki/QR_algorithm + */ + function iterateUntilTriangular(A, N, prec, type, findVectors) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var one = big ? bignumber(1) : cplx ? complex(1) : 1; + if (big) { + prec = bignumber(prec); + } + + // The Francis Algorithm + // The core idea of this algorithm is that doing successive + // A' = QtAQ transformations will eventually converge to block- + // upper-triangular with diagonal blocks either 1x1 or 2x2. + // The Q here is the one from the QR decomposition, A = QR. + // Since the eigenvalues of a block-upper-triangular matrix are + // the eigenvalues of its diagonal blocks and we know how to find + // eigenvalues of a 2x2 matrix, we know the eigenvalues of A. + + var arr = clone(A); + + // the list of converged eigenvalues + var lambdas = []; + + // size of arr, which will get smaller as eigenvalues converge + var n = N; + + // the diagonal of the block-diagonal matrix that turns + // converged 2x2 matrices into upper triangular matrices + var Sdiag = []; + + // N×N matrix describing the overall transformation done during the QR algorithm + var Qtotal = findVectors ? diag(Array(N).fill(one)) : undefined; + + // nxn matrix describing the QR transformations done since last convergence + var Qpartial = findVectors ? diag(Array(n).fill(one)) : undefined; + + // last eigenvalue converged before this many steps + var lastConvergenceBefore = 0; + while (lastConvergenceBefore <= 100) { + lastConvergenceBefore += 1; + + // TODO if the convergence is slow, do something clever + + // Perform the factorization + + var k = arr[n - 1][n - 1]; // TODO this is apparently a somewhat + // old-fashioned choice; ideally set close to an eigenvalue, or + // perhaps better yet switch to the implicit QR version that is sometimes + // specifically called the "Francis algorithm" that is alluded to + // in the following TODO. (Or perhaps we switch to an independently + // optimized third-party package for the linear algebra operations...) + + for (var i = 0; i < n; i++) { + arr[i][i] = subtract(arr[i][i], k); + } + + // TODO do an implicit QR transformation + var { + Q, + R + } = qr(arr); + arr = multiply(R, Q); + for (var _i = 0; _i < n; _i++) { + arr[_i][_i] = addScalar(arr[_i][_i], k); + } + + // keep track of transformations + if (findVectors) { + Qpartial = multiply(Qpartial, Q); + } + + // The rightmost diagonal element converged to an eigenvalue + if (n === 1 || smaller(abs(arr[n - 1][n - 2]), prec)) { + lastConvergenceBefore = 0; + lambdas.push(arr[n - 1][n - 1]); + + // keep track of transformations + if (findVectors) { + Sdiag.unshift([[1]]); + inflateMatrix(Qpartial, N); + Qtotal = multiply(Qtotal, Qpartial); + if (n > 1) { + Qpartial = diag(Array(n - 1).fill(one)); + } + } + + // reduce the matrix size + n -= 1; + arr.pop(); + for (var _i2 = 0; _i2 < n; _i2++) { + arr[_i2].pop(); + } + + // The rightmost diagonal 2x2 block converged + } else if (n === 2 || smaller(abs(arr[n - 2][n - 3]), prec)) { + lastConvergenceBefore = 0; + var ll = eigenvalues2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1]); + lambdas.push(...ll); + + // keep track of transformations + if (findVectors) { + Sdiag.unshift(jordanBase2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1], ll[0], ll[1], prec, type)); + inflateMatrix(Qpartial, N); + Qtotal = multiply(Qtotal, Qpartial); + if (n > 2) { + Qpartial = diag(Array(n - 2).fill(one)); + } + } + + // reduce the matrix size + n -= 2; + arr.pop(); + arr.pop(); + for (var _i3 = 0; _i3 < n; _i3++) { + arr[_i3].pop(); + arr[_i3].pop(); + } + } + if (n === 0) { + break; + } + } + + // standard sorting + lambdas.sort((a, b) => +subtract(abs(a), abs(b))); + + // the algorithm didn't converge + if (lastConvergenceBefore > 100) { + var err = Error('The eigenvalues failed to converge. Only found these eigenvalues: ' + lambdas.join(', ')); + err.values = lambdas; + err.vectors = []; + throw err; + } + + // combine the overall QR transformation Qtotal with the subsequent + // transformation S that turns the diagonal 2x2 blocks to upper triangular + var C = findVectors ? multiply(Qtotal, blockDiag(Sdiag, N)) : undefined; + return { + values: lambdas, + C + }; + } + + /** + * @param {Matrix} A hessenberg-form matrix + * @param {number} N size of A + * @param {Matrix} C column transformation matrix that turns A into upper triangular + * @param {Matrix} R similarity that turns original matrix into A + * @param {number[]} values array of eigenvalues of A + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {number[][]} eigenvalues + */ + function findEigenvectors(A, N, C, R, values, prec, type) { + var Cinv = inv(C); + var U = multiply(Cinv, A, C); + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var zero = big ? bignumber(0) : cplx ? complex(0) : 0; + var one = big ? bignumber(1) : cplx ? complex(1) : 1; + + // turn values into a kind of "multiset" + // this way it is easier to find eigenvectors + var uniqueValues = []; + var multiplicities = []; + for (var lambda of values) { + var i = indexOf(uniqueValues, lambda, equal); + if (i === -1) { + uniqueValues.push(lambda); + multiplicities.push(1); + } else { + multiplicities[i] += 1; + } + } + + // find eigenvectors by solving U − lambdaE = 0 + // TODO replace with an iterative eigenvector algorithm + // (this one might fail for imprecise eigenvalues) + + var vectors = []; + var len = uniqueValues.length; + var b = Array(N).fill(zero); + var E = diag(Array(N).fill(one)); + var _loop = function _loop() { + var lambda = uniqueValues[_i4]; + var S = subtract(U, multiply(lambda, E)); // the characteristic matrix + + var solutions = usolveAll(S, b); + solutions.shift(); // ignore the null vector + + // looks like we missed something, try inverse iteration + // But if that fails, just presume that the original matrix truly + // was defective. + while (solutions.length < multiplicities[_i4]) { + var approxVec = inverseIterate(S, N, solutions, prec, type); + if (approxVec === null) { + break; + } // no more vectors were found + solutions.push(approxVec); + } + + // Transform back into original array coordinates + var correction = multiply(inv(R), C); + solutions = solutions.map(v => multiply(correction, v)); + vectors.push(...solutions.map(v => ({ + value: lambda, + vector: flatten(v) + }))); + }; + for (var _i4 = 0; _i4 < len; _i4++) { + _loop(); + } + return vectors; + } + + /** + * Compute the eigenvalues of an 2x2 matrix + * @return {[number,number]} + */ + function eigenvalues2x2(a, b, c, d) { + // lambda_+- = 1/2 trA +- 1/2 sqrt( tr^2 A - 4 detA ) + var trA = addScalar(a, d); + var detA = subtract(multiplyScalar(a, d), multiplyScalar(b, c)); + var x = multiplyScalar(trA, 0.5); + var y = multiplyScalar(sqrt(subtract(multiplyScalar(trA, trA), multiplyScalar(4, detA))), 0.5); + return [addScalar(x, y), subtract(x, y)]; + } + + /** + * For an 2x2 matrix compute the transformation matrix S, + * so that SAS^-1 is an upper triangular matrix + * @return {[[number,number],[number,number]]} + * @see https://math.berkeley.edu/~ogus/old/Math_54-05/webfoils/jordan.pdf + * @see http://people.math.harvard.edu/~knill/teaching/math21b2004/exhibits/2dmatrices/index.html + */ + function jordanBase2x2(a, b, c, d, l1, l2, prec, type) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var zero = big ? bignumber(0) : cplx ? complex(0) : 0; + var one = big ? bignumber(1) : cplx ? complex(1) : 1; + + // matrix is already upper triangular + // return an identity matrix + if (smaller(abs(c), prec)) { + return [[one, zero], [zero, one]]; + } + + // matrix is diagonalizable + // return its eigenvectors as columns + if (larger(abs(subtract(l1, l2)), prec)) { + return [[subtract(l1, d), subtract(l2, d)], [c, c]]; + } + + // matrix is not diagonalizable + // compute diagonal elements of N = A - lambdaI + var na = subtract(a, l1); + var nd = subtract(d, l1); + + // col(N,2) = 0 implies S = ( col(N,1), e_1 ) + // col(N,2) != 0 implies S = ( col(N,2), e_2 ) + + if (smaller(abs(b), prec) && smaller(abs(nd), prec)) { + return [[na, one], [c, zero]]; + } else { + return [[b, zero], [nd, one]]; + } + } + + /** + * Enlarge the matrix from nxn to NxN, setting the new + * elements to 1 on diagonal and 0 elsewhere + */ + function inflateMatrix(arr, N) { + // add columns + for (var i = 0; i < arr.length; i++) { + arr[i].push(...Array(N - arr[i].length).fill(0)); + } + + // add rows + for (var _i5 = arr.length; _i5 < N; _i5++) { + arr.push(Array(N).fill(0)); + arr[_i5][_i5] = 1; + } + return arr; + } + + /** + * Create a block-diagonal matrix with the given square matrices on the diagonal + * @param {Matrix[] | number[][][]} arr array of matrices to be placed on the diagonal + * @param {number} N the size of the resulting matrix + */ + function blockDiag(arr, N) { + var M = []; + for (var i = 0; i < N; i++) { + M[i] = Array(N).fill(0); + } + var I = 0; + for (var sub of arr) { + var n = sub.length; + for (var _i6 = 0; _i6 < n; _i6++) { + for (var j = 0; j < n; j++) { + M[I + _i6][I + j] = sub[_i6][j]; + } + } + I += n; + } + return M; + } + + /** + * Finds the index of an element in an array using a custom equality function + * @template T + * @param {Array} arr array in which to search + * @param {T} el the element to find + * @param {function(T, T): boolean} fn the equality function, first argument is an element of `arr`, the second is always `el` + * @returns {number} the index of `el`, or -1 when it's not in `arr` + */ + function indexOf(arr, el, fn) { + for (var i = 0; i < arr.length; i++) { + if (fn(arr[i], el)) { + return i; + } + } + return -1; + } + + /** + * Provided a near-singular upper-triangular matrix A and a list of vectors, + * finds an eigenvector of A with the smallest eigenvalue, which is orthogonal + * to each vector in the list + * @template T + * @param {T[][]} A near-singular square matrix + * @param {number} N dimension + * @param {T[][]} orthog list of vectors + * @param {number} prec epsilon + * @param {'number'|'BigNumber'|'Complex'} type + * @return {T[] | null} eigenvector + * + * @see Numerical Recipes for Fortran 77 – 11.7 Eigenvalues or Eigenvectors by Inverse Iteration + */ + function inverseIterate(A, N, orthog, prec, type) { + var largeNum = type === 'BigNumber' ? bignumber(1000) : 1000; + var b; // the vector + + // you better choose a random vector before I count to five + var i = 0; + for (; i < 5; ++i) { + b = randomOrthogonalVector(N, orthog, type); + try { + b = usolve(A, b); + } catch (_unused) { + // That direction didn't work, likely because the original matrix + // was defective. But still make the full number of tries... + continue; + } + if (larger(norm(b), largeNum)) { + break; + } + } + if (i >= 5) { + return null; // couldn't find any orthogonal vector in the image + } + + // you better converge before I count to ten + i = 0; + while (true) { + var c = usolve(A, b); + if (smaller(norm(orthogonalComplement(b, [c])), prec)) { + break; + } + if (++i >= 10) { + return null; + } + b = normalize(c); + } + return b; + } + + /** + * Generates a random unit vector of dimension N, orthogonal to each vector in the list + * @template T + * @param {number} N dimension + * @param {T[][]} orthog list of vectors + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {T[]} random vector + */ + function randomOrthogonalVector(N, orthog, type) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + + // generate random vector with the correct type + var v = Array(N).fill(0).map(_ => 2 * Math.random() - 1); + if (big) { + v = v.map(n => bignumber(n)); + } + if (cplx) { + v = v.map(n => complex(n)); + } + + // project to orthogonal complement + v = orthogonalComplement(v, orthog); + + // normalize + return normalize(v, type); + } + + /** + * Project vector v to the orthogonal complement of an array of vectors + */ + function orthogonalComplement(v, orthog) { + var vectorShape = size(v); + for (var w of orthog) { + w = reshape(w, vectorShape); // make sure this is just a vector computation + // v := v − (w, v)/|w|^2 w + v = subtract(v, multiply(divideScalar(dot(w, v), dot(w, w)), w)); + } + return v; + } + + /** + * Calculate the norm of a vector. + * We can't use math.norm because factory can't handle circular dependency. + * Seriously, I'm really fed up with factory. + */ + function norm(v) { + return abs(sqrt(dot(v, v))); + } + + /** + * Normalize a vector + * @template T + * @param {T[]} v + * @param {'number'|'BigNumber'|'Complex'} type + * @returns {T[]} normalized vec + */ + function normalize(v, type) { + var big = type === 'BigNumber'; + var cplx = type === 'Complex'; + var one = big ? bignumber(1) : cplx ? complex(1) : 1; + return multiply(divideScalar(one, norm(v)), v); + } + return complexEigs; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/realSymmetric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/realSymmetric.js new file mode 100644 index 0000000..0b38087 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/eigs/realSymmetric.js @@ -0,0 +1,297 @@ +import { clone } from '../../../utils/object.js'; +export function createRealSymmetric(_ref) { + var { + config, + addScalar, + subtract, + abs, + atan, + cos, + sin, + multiplyScalar, + inv, + bignumber, + multiply, + add + } = _ref; + /** + * @param {number[] | BigNumber[]} arr + * @param {number} N + * @param {number} prec + * @param {'number' | 'BigNumber'} type + */ + function main(arr, N) { + var prec = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : config.relTol; + var type = arguments.length > 3 ? arguments[3] : undefined; + var computeVectors = arguments.length > 4 ? arguments[4] : undefined; + if (type === 'number') { + return diag(arr, prec, computeVectors); + } + if (type === 'BigNumber') { + return diagBig(arr, prec, computeVectors); + } + throw TypeError('Unsupported data type: ' + type); + } + + // diagonalization implementation for number (efficient) + function diag(x, precision, computeVectors) { + var N = x.length; + var e0 = Math.abs(precision / N); + var psi; + var Sij; + if (computeVectors) { + Sij = new Array(N); + // Sij is Identity Matrix + for (var i = 0; i < N; i++) { + Sij[i] = Array(N).fill(0); + Sij[i][i] = 1.0; + } + } + // initial error + var Vab = getAij(x); + while (Math.abs(Vab[1]) >= Math.abs(e0)) { + var _i = Vab[0][0]; + var j = Vab[0][1]; + psi = getTheta(x[_i][_i], x[j][j], x[_i][j]); + x = x1(x, psi, _i, j); + if (computeVectors) Sij = Sij1(Sij, psi, _i, j); + Vab = getAij(x); + } + var Ei = Array(N).fill(0); // eigenvalues + for (var _i2 = 0; _i2 < N; _i2++) { + Ei[_i2] = x[_i2][_i2]; + } + return sorting(clone(Ei), Sij, computeVectors); + } + + // diagonalization implementation for bigNumber + function diagBig(x, precision, computeVectors) { + var N = x.length; + var e0 = abs(precision / N); + var psi; + var Sij; + if (computeVectors) { + Sij = new Array(N); + // Sij is Identity Matrix + for (var i = 0; i < N; i++) { + Sij[i] = Array(N).fill(0); + Sij[i][i] = 1.0; + } + } + // initial error + var Vab = getAijBig(x); + while (abs(Vab[1]) >= abs(e0)) { + var _i3 = Vab[0][0]; + var j = Vab[0][1]; + psi = getThetaBig(x[_i3][_i3], x[j][j], x[_i3][j]); + x = x1Big(x, psi, _i3, j); + if (computeVectors) Sij = Sij1Big(Sij, psi, _i3, j); + Vab = getAijBig(x); + } + var Ei = Array(N).fill(0); // eigenvalues + for (var _i4 = 0; _i4 < N; _i4++) { + Ei[_i4] = x[_i4][_i4]; + } + // return [clone(Ei), clone(Sij)] + return sorting(clone(Ei), Sij, computeVectors); + } + + // get angle + function getTheta(aii, ajj, aij) { + var denom = ajj - aii; + if (Math.abs(denom) <= config.relTol) { + return Math.PI / 4.0; + } else { + return 0.5 * Math.atan(2.0 * aij / (ajj - aii)); + } + } + + // get angle + function getThetaBig(aii, ajj, aij) { + var denom = subtract(ajj, aii); + if (abs(denom) <= config.relTol) { + return bignumber(-1).acos().div(4); + } else { + return multiplyScalar(0.5, atan(multiply(2.0, aij, inv(denom)))); + } + } + + // update eigvec + function Sij1(Sij, theta, i, j) { + var N = Sij.length; + var c = Math.cos(theta); + var s = Math.sin(theta); + var Ski = Array(N).fill(0); + var Skj = Array(N).fill(0); + for (var k = 0; k < N; k++) { + Ski[k] = c * Sij[k][i] - s * Sij[k][j]; + Skj[k] = s * Sij[k][i] + c * Sij[k][j]; + } + for (var _k = 0; _k < N; _k++) { + Sij[_k][i] = Ski[_k]; + Sij[_k][j] = Skj[_k]; + } + return Sij; + } + // update eigvec for overlap + function Sij1Big(Sij, theta, i, j) { + var N = Sij.length; + var c = cos(theta); + var s = sin(theta); + var Ski = Array(N).fill(bignumber(0)); + var Skj = Array(N).fill(bignumber(0)); + for (var k = 0; k < N; k++) { + Ski[k] = subtract(multiplyScalar(c, Sij[k][i]), multiplyScalar(s, Sij[k][j])); + Skj[k] = addScalar(multiplyScalar(s, Sij[k][i]), multiplyScalar(c, Sij[k][j])); + } + for (var _k2 = 0; _k2 < N; _k2++) { + Sij[_k2][i] = Ski[_k2]; + Sij[_k2][j] = Skj[_k2]; + } + return Sij; + } + + // update matrix + function x1Big(Hij, theta, i, j) { + var N = Hij.length; + var c = bignumber(cos(theta)); + var s = bignumber(sin(theta)); + var c2 = multiplyScalar(c, c); + var s2 = multiplyScalar(s, s); + var Aki = Array(N).fill(bignumber(0)); + var Akj = Array(N).fill(bignumber(0)); + // 2cs Hij + var csHij = multiply(bignumber(2), c, s, Hij[i][j]); + // Aii + var Aii = addScalar(subtract(multiplyScalar(c2, Hij[i][i]), csHij), multiplyScalar(s2, Hij[j][j])); + var Ajj = add(multiplyScalar(s2, Hij[i][i]), csHij, multiplyScalar(c2, Hij[j][j])); + // 0 to i + for (var k = 0; k < N; k++) { + Aki[k] = subtract(multiplyScalar(c, Hij[i][k]), multiplyScalar(s, Hij[j][k])); + Akj[k] = addScalar(multiplyScalar(s, Hij[i][k]), multiplyScalar(c, Hij[j][k])); + } + // Modify Hij + Hij[i][i] = Aii; + Hij[j][j] = Ajj; + Hij[i][j] = bignumber(0); + Hij[j][i] = bignumber(0); + // 0 to i + for (var _k3 = 0; _k3 < N; _k3++) { + if (_k3 !== i && _k3 !== j) { + Hij[i][_k3] = Aki[_k3]; + Hij[_k3][i] = Aki[_k3]; + Hij[j][_k3] = Akj[_k3]; + Hij[_k3][j] = Akj[_k3]; + } + } + return Hij; + } + + // update matrix + function x1(Hij, theta, i, j) { + var N = Hij.length; + var c = Math.cos(theta); + var s = Math.sin(theta); + var c2 = c * c; + var s2 = s * s; + var Aki = Array(N).fill(0); + var Akj = Array(N).fill(0); + // Aii + var Aii = c2 * Hij[i][i] - 2 * c * s * Hij[i][j] + s2 * Hij[j][j]; + var Ajj = s2 * Hij[i][i] + 2 * c * s * Hij[i][j] + c2 * Hij[j][j]; + // 0 to i + for (var k = 0; k < N; k++) { + Aki[k] = c * Hij[i][k] - s * Hij[j][k]; + Akj[k] = s * Hij[i][k] + c * Hij[j][k]; + } + // Modify Hij + Hij[i][i] = Aii; + Hij[j][j] = Ajj; + Hij[i][j] = 0; + Hij[j][i] = 0; + // 0 to i + for (var _k4 = 0; _k4 < N; _k4++) { + if (_k4 !== i && _k4 !== j) { + Hij[i][_k4] = Aki[_k4]; + Hij[_k4][i] = Aki[_k4]; + Hij[j][_k4] = Akj[_k4]; + Hij[_k4][j] = Akj[_k4]; + } + } + return Hij; + } + + // get max off-diagonal value from Upper Diagonal + function getAij(Mij) { + var N = Mij.length; + var maxMij = 0; + var maxIJ = [0, 1]; + for (var i = 0; i < N; i++) { + for (var j = i + 1; j < N; j++) { + if (Math.abs(maxMij) < Math.abs(Mij[i][j])) { + maxMij = Math.abs(Mij[i][j]); + maxIJ = [i, j]; + } + } + } + return [maxIJ, maxMij]; + } + + // get max off-diagonal value from Upper Diagonal + function getAijBig(Mij) { + var N = Mij.length; + var maxMij = 0; + var maxIJ = [0, 1]; + for (var i = 0; i < N; i++) { + for (var j = i + 1; j < N; j++) { + if (abs(maxMij) < abs(Mij[i][j])) { + maxMij = abs(Mij[i][j]); + maxIJ = [i, j]; + } + } + } + return [maxIJ, maxMij]; + } + + // sort results + function sorting(E, S, computeVectors) { + var N = E.length; + var values = Array(N); + var vecs; + if (computeVectors) { + vecs = Array(N); + for (var k = 0; k < N; k++) { + vecs[k] = Array(N); + } + } + for (var i = 0; i < N; i++) { + var minID = 0; + var minE = E[0]; + for (var j = 0; j < E.length; j++) { + if (abs(E[j]) < abs(minE)) { + minID = j; + minE = E[minID]; + } + } + values[i] = E.splice(minID, 1)[0]; + if (computeVectors) { + for (var _k5 = 0; _k5 < N; _k5++) { + vecs[i][_k5] = S[_k5][minID]; + S[_k5].splice(minID, 1); + } + } + } + if (!computeVectors) return { + values + }; + var eigenvectors = vecs.map((vector, i) => ({ + value: values[i], + vector + })); + return { + values, + eigenvectors + }; + } + return main; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/expm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/expm.js new file mode 100644 index 0000000..23a2ce9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/expm.js @@ -0,0 +1,154 @@ +import { isSparseMatrix } from '../../utils/is.js'; +import { format } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +var name = 'expm'; +var dependencies = ['typed', 'abs', 'add', 'identity', 'inv', 'multiply']; +export var createExpm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + add, + identity, + inv, + multiply + } = _ref; + /** + * Compute the matrix exponential, expm(A) = e^A. The matrix must be square. + * Not to be confused with exp(a), which performs element-wise + * exponentiation. + * + * The exponential is calculated using the Padé approximant with scaling and + * squaring; see "Nineteen Dubious Ways to Compute the Exponential of a + * Matrix," by Moler and Van Loan. + * + * Syntax: + * + * math.expm(x) + * + * Examples: + * + * const A = [[0,2],[0,0]] + * math.expm(A) // returns [[1,2],[0,1]] + * + * See also: + * + * exp + * + * @param {Matrix} x A square Matrix + * @return {Matrix} The exponential of x + */ + return typed(name, { + Matrix: function Matrix(A) { + // Check matrix size + var size = A.size(); + if (size.length !== 2 || size[0] !== size[1]) { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + var n = size[0]; + + // Desired accuracy of the approximant (The actual accuracy + // will be affected by round-off error) + var eps = 1e-15; + + // The Padé approximant is not so accurate when the values of A + // are "large", so scale A by powers of two. Then compute the + // exponential, and square the result repeatedly according to + // the identity e^A = (e^(A/m))^m + + // Compute infinity-norm of A, ||A||, to see how "big" it is + var infNorm = infinityNorm(A); + + // Find the optimal scaling factor and number of terms in the + // Padé approximant to reach the desired accuracy + var params = findParams(infNorm, eps); + var q = params.q; + var j = params.j; + + // The Pade approximation to e^A is: + // Rqq(A) = Dqq(A) ^ -1 * Nqq(A) + // where + // Nqq(A) = sum(i=0, q, (2q-i)!p! / [ (2q)!i!(q-i)! ] A^i + // Dqq(A) = sum(i=0, q, (2q-i)!q! / [ (2q)!i!(q-i)! ] (-A)^i + + // Scale A by 1 / 2^j + var Apos = multiply(A, Math.pow(2, -j)); + + // The i=0 term is just the identity matrix + var N = identity(n); + var D = identity(n); + + // Initialization (i=0) + var factor = 1; + + // Initialization (i=1) + var AposToI = Apos; // Cloning not necessary + var alternate = -1; + for (var i = 1; i <= q; i++) { + if (i > 1) { + AposToI = multiply(AposToI, Apos); + alternate = -alternate; + } + factor = factor * (q - i + 1) / ((2 * q - i + 1) * i); + N = add(N, multiply(factor, AposToI)); + D = add(D, multiply(factor * alternate, AposToI)); + } + var R = multiply(inv(D), N); + + // Square j times + for (var _i = 0; _i < j; _i++) { + R = multiply(R, R); + } + return isSparseMatrix(A) ? A.createSparseMatrix(R) : R; + } + }); + function infinityNorm(A) { + var n = A.size()[0]; + var infNorm = 0; + for (var i = 0; i < n; i++) { + var rowSum = 0; + for (var j = 0; j < n; j++) { + rowSum += abs(A.get([i, j])); + } + infNorm = Math.max(rowSum, infNorm); + } + return infNorm; + } + + /** + * Find the best parameters for the Pade approximant given + * the matrix norm and desired accuracy. Returns the first acceptable + * combination in order of increasing computational load. + */ + function findParams(infNorm, eps) { + var maxSearchSize = 30; + for (var k = 0; k < maxSearchSize; k++) { + for (var q = 0; q <= k; q++) { + var j = k - q; + if (errorEstimate(infNorm, q, j) < eps) { + return { + q, + j + }; + } + } + } + throw new Error('Could not find acceptable parameters to compute the matrix exponential (try increasing maxSearchSize in expm.js)'); + } + + /** + * Returns the estimated error of the Pade approximant for the given + * parameters. + */ + function errorEstimate(infNorm, q, j) { + var qfac = 1; + for (var i = 2; i <= q; i++) { + qfac *= i; + } + var twoqfac = qfac; + for (var _i2 = q + 1; _i2 <= 2 * q; _i2++) { + twoqfac *= _i2; + } + var twoqp1fac = twoqfac * (2 * q + 1); + return 8.0 * Math.pow(infNorm / Math.pow(2, j), 2 * q) * qfac * qfac / (twoqfac * twoqp1fac); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/fft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/fft.js new file mode 100644 index 0000000..3036178 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/fft.js @@ -0,0 +1,128 @@ +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'fft'; +var dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'divideScalar', 'exp', 'tau', 'i', 'dotDivide', 'conj', 'pow', 'ceil', 'log2']; +export var createFft = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + addScalar, + multiplyScalar, + divideScalar, + exp, + tau, + i: I, + dotDivide, + conj, + pow, + ceil, + log2 + } = _ref; + /** + * Calculate N-dimensional Fourier transform + * + * Syntax: + * + * math.fft(arr) + * + * Examples: + * + * math.fft([[1, 0], [1, 0]]) // returns [[{re:2, im:0}, {re:2, im:0}], [{re:0, im:0}, {re:0, im:0}]] + * + * + * See Also: + * + * ifft + * + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + return typed(name, { + Array: _ndFft, + Matrix: function Matrix(matrix) { + return matrix.create(_ndFft(matrix.valueOf()), matrix.datatype()); + } + }); + + /** + * Perform an N-dimensional Fourier transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _ndFft(arr) { + var size = arraySize(arr); + if (size.length === 1) return _fft(arr, size[0]); + // ndFft along dimension 1,...,N-1 then 1dFft along dimension 0 + return _1dFft(arr.map(slice => _ndFft(slice, size.slice(1))), 0); + } + + /** + * Perform an 1-dimensional Fourier transform + * + * @param {Array} arr The array + * @param {number} dim dimension of the array to perform on + * @return {Array} resulting array + */ + function _1dFft(arr, dim) { + var size = arraySize(arr); + if (dim !== 0) return new Array(size[0]).fill(0).map((_, i) => _1dFft(arr[i], dim - 1)); + if (size.length === 1) return _fft(arr); + function _transpose(arr) { + // Swap first 2 dimensions + var size = arraySize(arr); + return new Array(size[1]).fill(0).map((_, j) => new Array(size[0]).fill(0).map((_, i) => arr[i][j])); + } + return _transpose(_1dFft(_transpose(arr), 1)); + } + /** + * Perform an 1-dimensional non-power-of-2 Fourier transform using Chirp-Z Transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _czt(arr) { + var n = arr.length; + var w = exp(divideScalar(multiplyScalar(-1, multiplyScalar(I, tau)), n)); + var chirp = []; + for (var i = 1 - n; i < n; i++) { + chirp.push(pow(w, divideScalar(pow(i, 2), 2))); + } + var N2 = pow(2, ceil(log2(n + n - 1))); + var xp = [...new Array(n).fill(0).map((_, i) => multiplyScalar(arr[i], chirp[n - 1 + i])), ...new Array(N2 - n).fill(0)]; + var ichirp = [...new Array(n + n - 1).fill(0).map((_, i) => divideScalar(1, chirp[i])), ...new Array(N2 - (n + n - 1)).fill(0)]; + var fftXp = _fft(xp); + var fftIchirp = _fft(ichirp); + var fftProduct = new Array(N2).fill(0).map((_, i) => multiplyScalar(fftXp[i], fftIchirp[i])); + var ifftProduct = dotDivide(conj(_ndFft(conj(fftProduct))), N2); + var ret = []; + for (var _i = n - 1; _i < n + n - 1; _i++) { + ret.push(multiplyScalar(ifftProduct[_i], chirp[_i])); + } + return ret; + } + /** + * Perform an 1-dimensional Fourier transform + * + * @param {Array} arr The array + * @return {Array} resulting array + */ + function _fft(arr) { + var len = arr.length; + if (len === 1) return [arr[0]]; + if (len % 2 === 0) { + var ret = [..._fft(arr.filter((_, i) => i % 2 === 0), len / 2), ..._fft(arr.filter((_, i) => i % 2 === 1), len / 2)]; + for (var k = 0; k < len / 2; k++) { + var p = ret[k]; + var q = multiplyScalar(ret[k + len / 2], exp(multiplyScalar(multiplyScalar(tau, I), divideScalar(-k, len)))); + ret[k] = addScalar(p, q); + ret[k + len / 2] = addScalar(p, multiplyScalar(-1, q)); + } + return ret; + } else { + // use chirp-z transform for non-power-of-2 FFT + return _czt(arr); + } + // throw new Error('Can only calculate FFT of power-of-two size') + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/filter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/filter.js new file mode 100644 index 0000000..b3344b8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/filter.js @@ -0,0 +1,64 @@ +import { optimizeCallback } from '../../utils/optimizeCallback.js'; +import { filter, filterRegExp } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'filter'; +var dependencies = ['typed']; +export var createFilter = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Filter the items in an array or one dimensional matrix. + * + * Syntax: + * + * math.filter(x, test) + * + * Examples: + * + * function isPositive (x) { + * return x > 0 + * } + * math.filter([6, -2, -1, 4, 3], isPositive) // returns [6, 4, 3] + * + * math.filter(["23", "foo", "100", "55", "bar"], /[0-9]+/) // returns ["23", "100", "55"] + * + * See also: + * + * forEach, map, sort + * + * @param {Matrix | Array} x A one dimensional matrix or array to filter + * @param {Function | RegExp} test + * A function or regular expression to test items. + * All entries for which `test` returns true are returned. + * When `test` is a function, it is invoked with three parameters: + * the value of the element, the index of the element, and the + * matrix/array being traversed. The function must return a boolean. + * @return {Matrix | Array} Returns the filtered matrix. + */ + return typed('filter', { + 'Array, function': _filterCallback, + 'Matrix, function': function Matrix_function(x, test) { + return x.create(_filterCallback(x.valueOf(), test), x.datatype()); + }, + 'Array, RegExp': filterRegExp, + 'Matrix, RegExp': function Matrix_RegExp(x, test) { + return x.create(filterRegExp(x.valueOf(), test), x.datatype()); + } + }); +}); + +/** + * Filter values in a callback given a callback function + * @param {Array} x + * @param {Function} callback + * @return {Array} Returns the filtered array + * @private + */ +function _filterCallback(x, callback) { + var fastCallback = optimizeCallback(callback, x, 'filter'); + return filter(x, function (value, index, array) { + // invoke the callback function with the right number of arguments + return fastCallback(value, [index], array); + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/flatten.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/flatten.js new file mode 100644 index 0000000..4c3689d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/flatten.js @@ -0,0 +1,38 @@ +import { flatten as flattenArray } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'flatten'; +var dependencies = ['typed']; +export var createFlatten = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Flatten a multidimensional matrix into a single dimensional matrix. + * A new matrix is returned, the original matrix is left untouched. + * + * Syntax: + * + * math.flatten(x) + * + * Examples: + * + * math.flatten([[1,2], [3,4]]) // returns [1, 2, 3, 4] + * + * See also: + * + * concat, resize, size, squeeze + * + * @param {Matrix | Array} x Matrix to be flattened + * @return {Matrix | Array} Returns the flattened matrix + */ + return typed(name, { + Array: function Array(x) { + return flattenArray(x); + }, + Matrix: function Matrix(x) { + // Return the same matrix type as x (Dense or Sparse Matrix) + // Return the same data type as x + return x.create(flattenArray(x.toArray()), x.datatype()); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/forEach.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/forEach.js new file mode 100644 index 0000000..1b939f0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/forEach.js @@ -0,0 +1,49 @@ +import { optimizeCallback } from '../../utils/optimizeCallback.js'; +import { factory } from '../../utils/factory.js'; +import { recurse } from '../../utils/array.js'; +var name = 'forEach'; +var dependencies = ['typed']; +export var createForEach = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Iterate over all elements of a matrix/array, and executes the given callback function. + * + * Syntax: + * + * math.forEach(x, callback) + * + * Examples: + * + * math.forEach([1, 2, 3], function(value) { + * console.log(value) + * }) + * // outputs 1, 2, 3 + * + * See also: + * + * filter, map, sort + * + * @param {Matrix | Array} x The matrix to iterate on. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix/array being traversed. + */ + return typed(name, { + 'Array, function': _forEach, + 'Matrix, function': function Matrix_function(x, callback) { + x.forEach(callback); + } + }); +}); + +/** + * forEach for a multidimensional array + * @param {Array} array + * @param {Function} callback + * @private + */ +function _forEach(array, callback) { + recurse(array, [], array, optimizeCallback(callback, array, name)); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/getMatrixDataType.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/getMatrixDataType.js new file mode 100644 index 0000000..5bc7862 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/getMatrixDataType.js @@ -0,0 +1,52 @@ +import { factory } from '../../utils/factory.js'; +import { getArrayDataType } from '../../utils/array.js'; +import { typeOf } from '../../utils/is.js'; +var name = 'getMatrixDataType'; +var dependencies = ['typed']; +export var createGetMatrixDataType = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Find the data type of all elements in a matrix or array, + * for example 'number' if all items are a number and 'Complex' if all values + * are complex numbers. + * If a matrix contains more than one data type, it will return 'mixed'. + * + * Syntax: + * + * math.getMatrixDataType(x) + * + * Examples: + * + * const x = [ [1, 2, 3], [4, 5, 6] ] + * const mixedX = [ [1, true], [2, 3] ] + * const fractionX = [ [math.fraction(1, 3)], [math.fraction(1, 3)] ] + * const unitX = [ [math.unit('5cm')], [math.unit('5cm')] ] + * const bigNumberX = [ [math.bignumber(1)], [math.bignumber(0)] ] + * const sparse = math.sparse(x) + * const dense = math.matrix(x) + * math.getMatrixDataType(x) // returns 'number' + * math.getMatrixDataType(sparse) // returns 'number' + * math.getMatrixDataType(dense) // returns 'number' + * math.getMatrixDataType(mixedX) // returns 'mixed' + * math.getMatrixDataType(fractionX) // returns 'Fraction' + * math.getMatrixDataType(unitX) // returns 'Unit' + * math.getMatrixDataType(bigNumberX) // return 'BigNumber' + * + * See also: + * SparseMatrix, DenseMatrix + * + * @param {...Matrix | Array} x The Matrix with values. + * + * @return {string} A string representation of the matrix type + */ + return typed(name, { + Array: function Array(x) { + return getArrayDataType(x, typeOf); + }, + Matrix: function Matrix(x) { + return x.getDataType(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/identity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/identity.js new file mode 100644 index 0000000..8211793 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/identity.js @@ -0,0 +1,136 @@ +import { isBigNumber } from '../../utils/is.js'; +import { resize } from '../../utils/array.js'; +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'identity'; +var dependencies = ['typed', 'config', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix']; +export var createIdentity = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + BigNumber, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a 2-dimensional identity matrix with size m x n or n x n. + * The matrix has ones on the diagonal and zeros elsewhere. + * + * Syntax: + * + * math.identity(n) + * math.identity(n, format) + * math.identity(m, n) + * math.identity(m, n, format) + * math.identity([m, n]) + * math.identity([m, n], format) + * + * Examples: + * + * math.identity(3) // returns [[1, 0, 0], [0, 1, 0], [0, 0, 1]] + * math.identity(3, 2) // returns [[1, 0], [0, 1], [0, 0]] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.identity(math.size(A)) // returns [[1, 0, 0], [0, 1, 0]] + * + * See also: + * + * diag, ones, zeros, size, range + * + * @param {...number | Matrix | Array} size The size for the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Matrix | Array | number} A matrix with ones on the diagonal. + */ + return typed(name, { + '': function _() { + return config.matrix === 'Matrix' ? matrix([]) : []; + }, + string: function string(format) { + return matrix(format); + }, + 'number | BigNumber': function number__BigNumber(rows) { + return _identity(rows, rows, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber, string': function number__BigNumber_string(rows, format) { + return _identity(rows, rows, format); + }, + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(rows, cols) { + return _identity(rows, cols, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber, number | BigNumber, string': function number__BigNumber_number__BigNumber_string(rows, cols, format) { + return _identity(rows, cols, format); + }, + Array: function Array(size) { + return _identityVector(size); + }, + 'Array, string': function Array_string(size, format) { + return _identityVector(size, format); + }, + Matrix: function Matrix(size) { + return _identityVector(size.valueOf(), size.storage()); + }, + 'Matrix, string': function Matrix_string(size, format) { + return _identityVector(size.valueOf(), format); + } + }); + function _identityVector(size, format) { + switch (size.length) { + case 0: + return format ? matrix(format) : []; + case 1: + return _identity(size[0], size[0], format); + case 2: + return _identity(size[0], size[1], format); + default: + throw new Error('Vector containing two values expected'); + } + } + + /** + * Create an identity matrix + * @param {number | BigNumber} rows + * @param {number | BigNumber} cols + * @param {string} [format] + * @returns {Matrix} + * @private + */ + function _identity(rows, cols, format) { + // BigNumber constructor with the right precision + var Big = isBigNumber(rows) || isBigNumber(cols) ? BigNumber : null; + if (isBigNumber(rows)) rows = rows.toNumber(); + if (isBigNumber(cols)) cols = cols.toNumber(); + if (!isInteger(rows) || rows < 1) { + throw new Error('Parameters in function identity must be positive integers'); + } + if (!isInteger(cols) || cols < 1) { + throw new Error('Parameters in function identity must be positive integers'); + } + var one = Big ? new BigNumber(1) : 1; + var defaultValue = Big ? new Big(0) : 0; + var size = [rows, cols]; + + // check we need to return a matrix + if (format) { + // create diagonal matrix (use optimized implementation for storage format) + if (format === 'sparse') { + return SparseMatrix.diagonal(size, one, 0, defaultValue); + } + if (format === 'dense') { + return DenseMatrix.diagonal(size, one, 0, defaultValue); + } + throw new TypeError("Unknown matrix type \"".concat(format, "\"")); + } + + // create and resize array + var res = resize([], size, defaultValue); + // fill in ones on the diagonal + var minimum = rows < cols ? rows : cols; + // fill diagonal + for (var d = 0; d < minimum; d++) { + res[d][d] = one; + } + return res; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ifft.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ifft.js new file mode 100644 index 0000000..b5c8101 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ifft.js @@ -0,0 +1,37 @@ +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +var name = 'ifft'; +var dependencies = ['typed', 'fft', 'dotDivide', 'conj']; +export var createIfft = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + fft, + dotDivide, + conj + } = _ref; + /** + * Calculate N-dimensional inverse Fourier transform + * + * Syntax: + * + * math.ifft(arr) + * + * Examples: + * + * math.ifft([[2, 2], [0, 0]]) // returns [[{re:1, im:0}, {re:0, im:0}], [{re:1, im:0}, {re:0, im:0}]] + * + * See Also: + * + * fft + * + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(arr) { + var size = isMatrix(arr) ? arr.size() : arraySize(arr); + return dotDivide(conj(fft(conj(arr))), size.reduce((acc, curr) => acc * curr, 1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/inv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/inv.js new file mode 100644 index 0000000..9aab431 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/inv.js @@ -0,0 +1,184 @@ +import { isMatrix } from '../../utils/is.js'; +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { format } from '../../utils/string.js'; +var name = 'inv'; +var dependencies = ['typed', 'matrix', 'divideScalar', 'addScalar', 'multiply', 'unaryMinus', 'det', 'identity', 'abs']; +export var createInv = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divideScalar, + addScalar, + multiply, + unaryMinus, + det, + identity, + abs + } = _ref; + /** + * Calculate the inverse of a square matrix. + * + * Syntax: + * + * math.inv(x) + * + * Examples: + * + * math.inv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]] + * math.inv(4) // returns 0.25 + * 1 / 4 // returns 0.25 + * + * See also: + * + * det, transpose + * + * @param {number | Complex | Array | Matrix} x Matrix to be inversed + * @return {number | Complex | Array | Matrix} The inverse of `x`. + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(x) { + var size = isMatrix(x) ? x.size() : arraySize(x); + switch (size.length) { + case 1: + // vector + if (size[0] === 1) { + if (isMatrix(x)) { + return matrix([divideScalar(1, x.valueOf()[0])]); + } else { + return [divideScalar(1, x[0])]; + } + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + case 2: + // two dimensional array + { + var rows = size[0]; + var cols = size[1]; + if (rows === cols) { + if (isMatrix(x)) { + return matrix(_inv(x.valueOf(), rows, cols), x.storage()); + } else { + // return an Array + return _inv(x, rows, cols); + } + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + format(size) + ')'); + } + }, + any: function any(x) { + // scalar + return divideScalar(1, x); // FIXME: create a BigNumber one when configured for bignumbers + } + }); + + /** + * Calculate the inverse of a square matrix + * @param {Array[]} mat A square matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns, must equal rows + * @return {Array[]} inv Inverse matrix + * @private + */ + function _inv(mat, rows, cols) { + var r, s, f, value, temp; + if (rows === 1) { + // this is a 1 x 1 matrix + value = mat[0][0]; + if (value === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + return [[divideScalar(1, value)]]; + } else if (rows === 2) { + // this is a 2 x 2 matrix + var d = det(mat); + if (d === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + return [[divideScalar(mat[1][1], d), divideScalar(unaryMinus(mat[0][1]), d)], [divideScalar(unaryMinus(mat[1][0]), d), divideScalar(mat[0][0], d)]]; + } else { + // this is a matrix of 3 x 3 or larger + // calculate inverse using gauss-jordan elimination + // https://en.wikipedia.org/wiki/Gaussian_elimination + // http://mathworld.wolfram.com/MatrixInverse.html + // http://math.uww.edu/~mcfarlat/inverse.htm + + // make a copy of the matrix (only the arrays, not of the elements) + var A = mat.concat(); + for (r = 0; r < rows; r++) { + A[r] = A[r].concat(); + } + + // create an identity matrix which in the end will contain the + // matrix inverse + var B = identity(rows).valueOf(); + + // loop over all columns, and perform row reductions + for (var c = 0; c < cols; c++) { + // Pivoting: Swap row c with row r, where row r contains the largest element A[r][c] + var ABig = abs(A[c][c]); + var rBig = c; + r = c + 1; + while (r < rows) { + if (abs(A[r][c]) > ABig) { + ABig = abs(A[r][c]); + rBig = r; + } + r++; + } + if (ABig === 0) { + throw Error('Cannot calculate inverse, determinant is zero'); + } + r = rBig; + if (r !== c) { + temp = A[c]; + A[c] = A[r]; + A[r] = temp; + temp = B[c]; + B[c] = B[r]; + B[r] = temp; + } + + // eliminate non-zero values on the other rows at column c + var Ac = A[c]; + var Bc = B[c]; + for (r = 0; r < rows; r++) { + var Ar = A[r]; + var Br = B[r]; + if (r !== c) { + // eliminate value at column c and row r + if (Ar[c] !== 0) { + f = divideScalar(unaryMinus(Ar[c]), Ac[c]); + + // add (f * row c) to row r to eliminate the value + // at column c + for (s = c; s < cols; s++) { + Ar[s] = addScalar(Ar[s], multiply(f, Ac[s])); + } + for (s = 0; s < cols; s++) { + Br[s] = addScalar(Br[s], multiply(f, Bc[s])); + } + } + } else { + // normalize value at Acc to 1, + // divide each value on row r with the value at Acc + f = Ac[c]; + for (s = c; s < cols; s++) { + Ar[s] = divideScalar(Ar[s], f); + } + for (s = 0; s < cols; s++) { + Br[s] = divideScalar(Br[s], f); + } + } + } + } + return B; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/kron.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/kron.js new file mode 100644 index 0000000..6e7ae27 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/kron.js @@ -0,0 +1,85 @@ +import { arraySize as size } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'kron'; +var dependencies = ['typed', 'matrix', 'multiplyScalar']; +export var createKron = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + multiplyScalar + } = _ref; + /** + * Calculates the Kronecker product of 2 matrices or vectors. + * + * NOTE: If a one dimensional vector / matrix is given, it will be + * wrapped so its two dimensions. + * See the examples. + * + * Syntax: + * + * math.kron(x, y) + * + * Examples: + * + * math.kron([[1, 0], [0, 1]], [[1, 2], [3, 4]]) + * // returns [ [ 1, 2, 0, 0 ], [ 3, 4, 0, 0 ], [ 0, 0, 1, 2 ], [ 0, 0, 3, 4 ] ] + * + * math.kron([1,1], [2,3,4]) + * // returns [ [ 2, 3, 4, 2, 3, 4 ] ] + * + * See also: + * + * multiply, dot, cross + * + * @param {Array | Matrix} x First vector + * @param {Array | Matrix} y Second vector + * @return {Array | Matrix} Returns the Kronecker product of `x` and `y` + */ + return typed(name, { + 'Matrix, Matrix': function Matrix_Matrix(x, y) { + return matrix(_kron(x.toArray(), y.toArray())); + }, + 'Matrix, Array': function Matrix_Array(x, y) { + return matrix(_kron(x.toArray(), y)); + }, + 'Array, Matrix': function Array_Matrix(x, y) { + return matrix(_kron(x, y.toArray())); + }, + 'Array, Array': _kron + }); + + /** + * Calculate the Kronecker product of two matrices / vectors + * @param {Array} a First vector + * @param {Array} b Second vector + * @returns {Array} Returns the Kronecker product of x and y + * @private + */ + function _kron(a, b) { + // Deal with the dimensions of the matricies. + if (size(a).length === 1) { + // Wrap it in a 2D Matrix + a = [a]; + } + if (size(b).length === 1) { + // Wrap it in a 2D Matrix + b = [b]; + } + if (size(a).length > 2 || size(b).length > 2) { + throw new RangeError('Vectors with dimensions greater then 2 are not supported expected ' + '(Size x = ' + JSON.stringify(a.length) + ', y = ' + JSON.stringify(b.length) + ')'); + } + var t = []; + var r = []; + return a.map(function (a) { + return b.map(function (b) { + r = []; + t.push(r); + return a.map(function (y) { + return b.map(function (x) { + return r.push(multiplyScalar(y, x)); + }); + }); + }); + }) && t; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/map.js new file mode 100644 index 0000000..cafd03c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/map.js @@ -0,0 +1,142 @@ +import { optimizeCallback } from '../../utils/optimizeCallback.js'; +import { arraySize, broadcastSizes, broadcastTo, get, recurse } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'map'; +var dependencies = ['typed']; +export var createMap = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Create a new matrix or array with the results of a callback function executed on + * each entry of a given matrix/array. + * + * For each entry of the input, + * + * the callback is invoked with 2N + 1 arguments: + * the N values of the entry, the index at which that entry occurs, and the N full + * broadcasted matrix/array being traversed where N is the number of matrices being traversed. + * Note that because the matrix/array might be + * multidimensional, the "index" argument is always an array of numbers giving + * the index in each dimension. This is true even for vectors: the "index" + * argument is an array of length 1, rather than simply a number. + * + * Syntax: + * + * math.map(x, callback) + * math.map(x, y, ..., callback) + * + * Examples: + * + * math.map([1, 2, 3], function(value) { + * return value * value + * }) // returns [1, 4, 9] + * math.map([1, 2], [3, 4], function(a, b) { + * return a + b + * }) // returns [4, 6] + * + * // The callback is normally called with three arguments: + * // callback(value, index, Array) + * // If you want to call with only one argument, use: + * math.map([1, 2, 3], x => math.format(x)) // returns ['1', '2', '3'] + * // It can also be called with 2N + 1 arguments: for N arrays + * // callback(value1, value2, index, BroadcastedArray1, BroadcastedArray2) + * + * See also: + * + * filter, forEach, sort + * + * @param {Matrix | Array} x The input to iterate on. + * @param {Function} callback + * The function to call (as described above) on each entry of the input + * @return {Matrix | array} + * Transformed map of x; always has the same type and shape as x + */ + return typed(name, { + 'Array, function': _mapArray, + 'Matrix, function': function Matrix_function(x, callback) { + return x.map(callback); + }, + 'Array|Matrix, Array|Matrix, ...Array|Matrix|function': (A, B, rest) => _mapMultiple([A, B, ...rest.slice(0, rest.length - 1)], rest[rest.length - 1]) + }); + + /** + * Maps over multiple arrays or matrices. + * + * @param {Array} Arrays - An array of arrays or matrices to map over. + * @param {function} multiCallback - The callback function to apply to each element. + * @throws {Error} If the last argument is not a callback function. + * @returns {Array|Matrix} A new array or matrix with each element being the result of the callback function. + * + * @example + * _mapMultiple([[1, 2, 3], [4, 5, 6]], (a, b) => a + b); // Returns [5, 7, 9] + */ + function _mapMultiple(Arrays, multiCallback) { + if (typeof multiCallback !== 'function') { + throw new Error('Last argument must be a callback function'); + } + var firstArrayIsMatrix = Arrays[0].isMatrix; + var newSize = broadcastSizes(...Arrays.map(M => M.isMatrix ? M.size() : arraySize(M))); + var _get = firstArrayIsMatrix ? (matrix, idx) => matrix.get(idx) : get; + var broadcastedArrays = firstArrayIsMatrix ? Arrays.map(M => M.isMatrix ? M.create(broadcastTo(M.toArray(), newSize), M.datatype()) : Arrays[0].create(broadcastTo(M.valueOf(), newSize))) : Arrays.map(M => M.isMatrix ? broadcastTo(M.toArray(), newSize) : broadcastTo(M, newSize)); + var callback; + if (typed.isTypedFunction(multiCallback)) { + var firstIndex = newSize.map(() => 0); + var firstValues = broadcastedArrays.map(array => _get(array, firstIndex)); + var callbackCase = _getTypedCallbackCase(multiCallback, firstValues, firstIndex, broadcastedArrays); + callback = _getLimitedCallback(callbackCase); + } else { + var numberOfArrays = Arrays.length; + var _callbackCase = _getCallbackCase(multiCallback, numberOfArrays); + callback = _getLimitedCallback(_callbackCase); + } + var broadcastedArraysCallback = (x, idx) => callback([x, ...broadcastedArrays.slice(1).map(Array => _get(Array, idx))], idx); + if (firstArrayIsMatrix) { + return broadcastedArrays[0].map(broadcastedArraysCallback); + } else { + return _mapArray(broadcastedArrays[0], broadcastedArraysCallback); + } + function _getLimitedCallback(callbackCase) { + switch (callbackCase) { + case 0: + return x => multiCallback(...x); + case 1: + return (x, idx) => multiCallback(...x, idx); + case 2: + return (x, idx) => multiCallback(...x, idx, ...broadcastedArrays); + } + } + function _getCallbackCase(callback, numberOfArrays) { + if (callback.length > numberOfArrays + 1) { + return 2; + } + if (callback.length === numberOfArrays + 1) { + return 1; + } + return 0; + } + function _getTypedCallbackCase(callback, values, idx, arrays) { + if (typed.resolve(callback, [...values, idx, ...arrays]) !== null) { + return 2; + } + if (typed.resolve(callback, [...values, idx]) !== null) { + return 1; + } + if (typed.resolve(callback, values) !== null) { + return 0; + } + // this should never happen + return 0; + } + } + /** + * Map for a multi dimensional array + * @param {Array} array + * @param {Function} callback + * @return {Array} + * @private + */ + function _mapArray(array, callback) { + return recurse(array, [], array, optimizeCallback(callback, array, name)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromColumns.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromColumns.js new file mode 100644 index 0000000..8a0e9ea --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromColumns.js @@ -0,0 +1,88 @@ +import { factory } from '../../utils/factory.js'; +var name = 'matrixFromColumns'; +var dependencies = ['typed', 'matrix', 'flatten', 'size']; +export var createMatrixFromColumns = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + flatten, + size + } = _ref; + /** + * Create a dense matrix from vectors as individual columns. + * If you pass row vectors, they will be transposed (but not conjugated!) + * + * Syntax: + * + * math.matrixFromColumns(...arr) + * math.matrixFromColumns(col1, col2) + * math.matrixFromColumns(col1, col2, col3) + * + * Examples: + * + * math.matrixFromColumns([1, 2, 3], [[4],[5],[6]]) + * math.matrixFromColumns(...vectors) + * + * See also: + * + * matrix, matrixFromRows, matrixFromFunction, zeros + * + * @param {... Array | Matrix} cols Multiple columns + * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned + */ + return typed(name, { + '...Array': function Array(arr) { + return _createArray(arr); + }, + '...Matrix': function Matrix(arr) { + return matrix(_createArray(arr.map(m => m.toArray()))); + } + + // TODO implement this properly for SparseMatrix + }); + function _createArray(arr) { + if (arr.length === 0) throw new TypeError('At least one column is needed to construct a matrix.'); + var N = checkVectorTypeAndReturnLength(arr[0]); + + // create an array with empty rows + var result = []; + for (var i = 0; i < N; i++) { + result[i] = []; + } + + // loop columns + for (var col of arr) { + var colLength = checkVectorTypeAndReturnLength(col); + if (colLength !== N) { + throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (colLength | 0)); + } + var f = flatten(col); + + // push a value to each row + for (var _i = 0; _i < N; _i++) { + result[_i].push(f[_i]); + } + } + return result; + } + function checkVectorTypeAndReturnLength(vec) { + var s = size(vec); + if (s.length === 1) { + // 1D vector + return s[0]; + } else if (s.length === 2) { + // 2D vector + if (s[0] === 1) { + // row vector + return s[1]; + } else if (s[1] === 1) { + // col vector + return s[0]; + } else { + throw new TypeError('At least one of the arguments is not a vector.'); + } + } else { + throw new TypeError('Only one- or two-dimensional vectors are supported.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromFunction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromFunction.js new file mode 100644 index 0000000..349301d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromFunction.js @@ -0,0 +1,74 @@ +import { factory } from '../../utils/factory.js'; +var name = 'matrixFromFunction'; +var dependencies = ['typed', 'matrix', 'isZero']; +export var createMatrixFromFunction = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + isZero + } = _ref; + /** + * Create a matrix by evaluating a generating function at each index. + * The simplest overload returns a multi-dimensional array as long as `size` is an array. + * Passing `size` as a Matrix or specifying a `format` will result in returning a Matrix. + * + * Syntax: + * + * math.matrixFromFunction(size, fn) + * math.matrixFromFunction(size, fn, format) + * math.matrixFromFunction(size, fn, format, datatype) + * math.matrixFromFunction(size, format, fn) + * math.matrixFromFunction(size, format, datatype, fn) + * + * Examples: + * + * math.matrixFromFunction([3,3], i => i[0] - i[1]) // an antisymmetric matrix + * math.matrixFromFunction([100, 100], 'sparse', i => i[0] - i[1] === 1 ? 4 : 0) // a sparse subdiagonal matrix + * math.matrixFromFunction([5], i => math.random()) // a random vector + * + * See also: + * + * matrix, zeros + * + * @param {Array | Matrix} size The size of the matrix to be created + * @param {function} fn Callback function invoked for every entry in the matrix + * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'` + * @param {string} [datatype] Type of the values + * @return {Array | Matrix} Returns the created matrix + */ + return typed(name, { + 'Array | Matrix, function, string, string': function Array__Matrix_function_string_string(size, fn, format, datatype) { + return _create(size, fn, format, datatype); + }, + 'Array | Matrix, function, string': function Array__Matrix_function_string(size, fn, format) { + return _create(size, fn, format); + }, + 'Matrix, function': function Matrix_function(size, fn) { + return _create(size, fn, 'dense'); + }, + 'Array, function': function Array_function(size, fn) { + return _create(size, fn, 'dense').toArray(); + }, + 'Array | Matrix, string, function': function Array__Matrix_string_function(size, format, fn) { + return _create(size, fn, format); + }, + 'Array | Matrix, string, string, function': function Array__Matrix_string_string_function(size, format, datatype, fn) { + return _create(size, fn, format, datatype); + } + }); + function _create(size, fn, format, datatype) { + var m; + if (datatype !== undefined) { + m = matrix(format, datatype); + } else { + m = matrix(format); + } + m.resize(size); + m.forEach(function (_, index) { + var val = fn(index); + if (isZero(val)) return; + m.set(index, val); + }); + return m; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromRows.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromRows.js new file mode 100644 index 0000000..33e9b97 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/matrixFromRows.js @@ -0,0 +1,76 @@ +import { factory } from '../../utils/factory.js'; +var name = 'matrixFromRows'; +var dependencies = ['typed', 'matrix', 'flatten', 'size']; +export var createMatrixFromRows = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + flatten, + size + } = _ref; + /** + * Create a dense matrix from vectors as individual rows. + * If you pass column vectors, they will be transposed (but not conjugated!) + * + * Syntax: + * + * math.matrixFromRows(...arr) + * math.matrixFromRows(row1, row2) + * math.matrixFromRows(row1, row2, row3) + * + * Examples: + * + * math.matrixFromRows([1, 2, 3], [[4],[5],[6]]) + * math.matrixFromRows(...vectors) + * + * See also: + * + * matrix, matrixFromColumns, matrixFromFunction, zeros + * + * @param {... Array | Matrix} rows Multiple rows + * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned + */ + return typed(name, { + '...Array': function Array(arr) { + return _createArray(arr); + }, + '...Matrix': function Matrix(arr) { + return matrix(_createArray(arr.map(m => m.toArray()))); + } + + // TODO implement this properly for SparseMatrix + }); + function _createArray(arr) { + if (arr.length === 0) throw new TypeError('At least one row is needed to construct a matrix.'); + var N = checkVectorTypeAndReturnLength(arr[0]); + var result = []; + for (var row of arr) { + var rowLength = checkVectorTypeAndReturnLength(row); + if (rowLength !== N) { + throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (rowLength | 0)); + } + result.push(flatten(row)); + } + return result; + } + function checkVectorTypeAndReturnLength(vec) { + var s = size(vec); + if (s.length === 1) { + // 1D vector + return s[0]; + } else if (s.length === 2) { + // 2D vector + if (s[0] === 1) { + // row vector + return s[1]; + } else if (s[1] === 1) { + // col vector + return s[0]; + } else { + throw new TypeError('At least one of the arguments is not a vector.'); + } + } else { + throw new TypeError('Only one- or two-dimensional vectors are supported.'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ones.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ones.js new file mode 100644 index 0000000..c836440 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/ones.js @@ -0,0 +1,123 @@ +import { isBigNumber } from '../../utils/is.js'; +import { isInteger } from '../../utils/number.js'; +import { resize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'ones'; +var dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +export var createOnes = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Create a matrix filled with ones. The created matrix can have one or + * multiple dimensions. + * + * Syntax: + * + * math.ones(m) + * math.ones(m, format) + * math.ones(m, n) + * math.ones(m, n, format) + * math.ones([m, n]) + * math.ones([m, n], format) + * math.ones([m, n, p, ...]) + * math.ones([m, n, p, ...], format) + * + * Examples: + * + * math.ones() // returns [] + * math.ones(3) // returns [1, 1, 1] + * math.ones(3, 2) // returns [[1, 1], [1, 1], [1, 1]] + * math.ones(3, 2, 'dense') // returns Dense Matrix [[1, 1], [1, 1], [1, 1]] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.ones(math.size(A)) // returns [[1, 1, 1], [1, 1, 1]] + * + * See also: + * + * zeros, identity, size, range + * + * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Array | Matrix | number} A matrix filled with ones + */ + return typed('ones', { + '': function _() { + return config.matrix === 'Array' ? _ones([]) : _ones([], 'default'); + }, + // math.ones(m, n, p, ..., format) + // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this + '...number | BigNumber | string': function number__BigNumber__string(size) { + var last = size[size.length - 1]; + if (typeof last === 'string') { + var format = size.pop(); + return _ones(size, format); + } else if (config.matrix === 'Array') { + return _ones(size); + } else { + return _ones(size, 'default'); + } + }, + Array: _ones, + Matrix: function Matrix(size) { + var format = size.storage(); + return _ones(size.valueOf(), format); + }, + 'Array | Matrix, string': function Array__Matrix_string(size, format) { + return _ones(size.valueOf(), format); + } + }); + + /** + * Create an Array or Matrix with ones + * @param {Array} size + * @param {string} [format='default'] + * @return {Array | Matrix} + * @private + */ + function _ones(size, format) { + var hasBigNumbers = _normalize(size); + var defaultValue = hasBigNumbers ? new BigNumber(1) : 1; + _validate(size); + if (format) { + // return a matrix + var m = matrix(format); + if (size.length > 0) { + return m.resize(size, defaultValue); + } + return m; + } else { + // return an Array + var arr = []; + if (size.length > 0) { + return resize(arr, size, defaultValue); + } + return arr; + } + } + + // replace BigNumbers with numbers, returns true if size contained BigNumbers + function _normalize(size) { + var hasBigNumbers = false; + size.forEach(function (value, index, arr) { + if (isBigNumber(value)) { + hasBigNumbers = true; + arr[index] = value.toNumber(); + } + }); + return hasBigNumbers; + } + + // validate arguments + function _validate(size) { + size.forEach(function (value) { + if (typeof value !== 'number' || !isInteger(value) || value < 0) { + throw new Error('Parameters in function ones must be positive integers'); + } + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/partitionSelect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/partitionSelect.js new file mode 100644 index 0000000..d7ecf86 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/partitionSelect.js @@ -0,0 +1,143 @@ +import { isMatrix } from '../../utils/is.js'; +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'partitionSelect'; +var dependencies = ['typed', 'isNumeric', 'isNaN', 'compare']; +export var createPartitionSelect = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isNumeric, + isNaN, + compare + } = _ref; + var asc = compare; + var desc = (a, b) => -compare(a, b); + + /** + * Partition-based selection of an array or 1D matrix. + * Will find the kth smallest value, and mutates the input array. + * Uses Quickselect. + * + * Syntax: + * + * math.partitionSelect(x, k) + * math.partitionSelect(x, k, compare) + * + * Examples: + * + * math.partitionSelect([5, 10, 1], 2) // returns 10 + * math.partitionSelect(['C', 'B', 'A', 'D'], 1, math.compareText) // returns 'B' + * + * function sortByLength (a, b) { + * return a.length - b.length + * } + * math.partitionSelect(['Langdon', 'Tom', 'Sara'], 2, sortByLength) // returns 'Langdon' + * + * // the input array is mutated + * arr = [5, 2, 1] + * math.partitionSelect(arr, 0) // returns 1, arr is now: [1, 2, 5] + * math.partitionSelect(arr, 1, 'desc') // returns 2, arr is now: [5, 2, 1] + * + * See also: + * + * sort + * + * @param {Matrix | Array} x A one dimensional matrix or array to sort + * @param {Number} k The kth smallest value to be retrieved zero-based index + * @param {Function | 'asc' | 'desc'} [compare='asc'] + * An optional comparator function. The function is called as + * `compare(a, b)`, and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. + * @return {*} Returns the kth lowest value. + */ + return typed(name, { + 'Array | Matrix, number': function Array__Matrix_number(x, k) { + return _partitionSelect(x, k, asc); + }, + 'Array | Matrix, number, string': function Array__Matrix_number_string(x, k, compare) { + if (compare === 'asc') { + return _partitionSelect(x, k, asc); + } else if (compare === 'desc') { + return _partitionSelect(x, k, desc); + } else { + throw new Error('Compare string must be "asc" or "desc"'); + } + }, + 'Array | Matrix, number, function': _partitionSelect + }); + function _partitionSelect(x, k, compare) { + if (!isInteger(k) || k < 0) { + throw new Error('k must be a non-negative integer'); + } + if (isMatrix(x)) { + var size = x.size(); + if (size.length > 1) { + throw new Error('Only one dimensional matrices supported'); + } + return quickSelect(x.valueOf(), k, compare); + } + if (Array.isArray(x)) { + return quickSelect(x, k, compare); + } + } + + /** + * Quickselect algorithm. + * Code adapted from: + * https://blog.teamleadnet.com/2012/07/quick-select-algorithm-find-kth-element.html + * + * @param {Array} arr + * @param {Number} k + * @param {Function} compare + * @private + */ + function quickSelect(arr, k, compare) { + if (k >= arr.length) { + throw new Error('k out of bounds'); + } + + // check for NaN values since these can cause an infinite while loop + for (var i = 0; i < arr.length; i++) { + if (isNumeric(arr[i]) && isNaN(arr[i])) { + return arr[i]; // return NaN + } + } + var from = 0; + var to = arr.length - 1; + + // if from == to we reached the kth element + while (from < to) { + var r = from; + var w = to; + var pivot = arr[Math.floor(Math.random() * (to - from + 1)) + from]; + + // stop if the reader and writer meets + while (r < w) { + // arr[r] >= pivot + if (compare(arr[r], pivot) >= 0) { + // put the large values at the end + var tmp = arr[w]; + arr[w] = arr[r]; + arr[r] = tmp; + --w; + } else { + // the value is smaller than the pivot, skip + ++r; + } + } + + // if we stepped up (r++) we need to step one down (arr[r] > pivot) + if (compare(arr[r], pivot) > 0) { + --r; + } + + // the r pointer is on the end of the first k elements + if (k <= r) { + to = r; + } else { + from = r + 1; + } + } + return arr[k]; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/pinv.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/pinv.js new file mode 100644 index 0000000..de4b3b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/pinv.js @@ -0,0 +1,179 @@ +import { isMatrix } from '../../utils/is.js'; +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { format } from '../../utils/string.js'; +import { clone } from '../../utils/object.js'; +var name = 'pinv'; +var dependencies = ['typed', 'matrix', 'inv', 'deepEqual', 'equal', 'dotDivide', 'dot', 'ctranspose', 'divideScalar', 'multiply', 'add', 'Complex']; +export var createPinv = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + inv, + deepEqual, + equal, + dotDivide, + dot, + ctranspose, + divideScalar, + multiply, + add, + Complex + } = _ref; + /** + * Calculate the Moore–Penrose inverse of a matrix. + * + * Syntax: + * + * math.pinv(x) + * + * Examples: + * + * math.pinv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]] + * math.pinv([[1, 0], [0, 1], [0, 1]]) // returns [[1, 0, 0], [0, 0.5, 0.5]] + * math.pinv(4) // returns 0.25 + * + * See also: + * + * inv + * + * @param {number | Complex | Array | Matrix} x Matrix to be inversed + * @return {number | Complex | Array | Matrix} The inverse of `x`. + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(x) { + var size = isMatrix(x) ? x.size() : arraySize(x); + switch (size.length) { + case 1: + // vector + if (_isZeros(x)) return ctranspose(x); // null vector + if (size[0] === 1) { + return inv(x); // invertible matrix + } else { + return dotDivide(ctranspose(x), dot(x, x)); + } + case 2: + // two dimensional array + { + if (_isZeros(x)) return ctranspose(x); // zero matrixx + var rows = size[0]; + var cols = size[1]; + if (rows === cols) { + try { + return inv(x); // invertible matrix + } catch (err) { + if (err instanceof Error && err.message.match(/Cannot calculate inverse, determinant is zero/)) { + // Expected + } else { + throw err; + } + } + } + if (isMatrix(x)) { + return matrix(_pinv(x.valueOf(), rows, cols), x.storage()); + } else { + // return an Array + return _pinv(x, rows, cols); + } + } + default: + // multi dimensional array + throw new RangeError('Matrix must be two dimensional ' + '(size: ' + format(size) + ')'); + } + }, + any: function any(x) { + // scalar + if (equal(x, 0)) return clone(x); // zero + return divideScalar(1, x); + } + }); + + /** + * Calculate the Moore–Penrose inverse of a matrix + * @param {Array[]} mat A matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {Array[]} pinv Pseudoinverse matrix + * @private + */ + function _pinv(mat, rows, cols) { + var { + C, + F + } = _rankFact(mat, rows, cols); // TODO: Use SVD instead (may improve precision) + var Cpinv = multiply(inv(multiply(ctranspose(C), C)), ctranspose(C)); + var Fpinv = multiply(ctranspose(F), inv(multiply(F, ctranspose(F)))); + return multiply(Fpinv, Cpinv); + } + + /** + * Calculate the reduced row echelon form of a matrix + * + * Modified from https://rosettacode.org/wiki/Reduced_row_echelon_form + * + * @param {Array[]} mat A matrix + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {Array[]} Reduced row echelon form + * @private + */ + function _rref(mat, rows, cols) { + var M = clone(mat); + var lead = 0; + for (var r = 0; r < rows; r++) { + if (cols <= lead) { + return M; + } + var i = r; + while (_isZero(M[i][lead])) { + i++; + if (rows === i) { + i = r; + lead++; + if (cols === lead) { + return M; + } + } + } + [M[i], M[r]] = [M[r], M[i]]; + var val = M[r][lead]; + for (var j = 0; j < cols; j++) { + M[r][j] = dotDivide(M[r][j], val); + } + for (var _i = 0; _i < rows; _i++) { + if (_i === r) continue; + val = M[_i][lead]; + for (var _j = 0; _j < cols; _j++) { + M[_i][_j] = add(M[_i][_j], multiply(-1, multiply(val, M[r][_j]))); + } + } + lead++; + } + return M; + } + + /** + * Calculate the rank factorization of a matrix + * + * @param {Array[]} mat A matrix (M) + * @param {number} rows Number of rows + * @param {number} cols Number of columns + * @return {{C: Array, F: Array}} rank factorization where M = C F + * @private + */ + function _rankFact(mat, rows, cols) { + var rref = _rref(mat, rows, cols); + var C = mat.map((_, i) => _.filter((_, j) => j < rows && !_isZero(dot(rref[j], rref[j])))); + var F = rref.filter((_, i) => !_isZero(dot(rref[i], rref[i]))); + return { + C, + F + }; + } + function _isZero(x) { + return equal(add(x, Complex(1, 1)), add(0, Complex(1, 1))); + } + function _isZeros(arr) { + return deepEqual(add(arr, Complex(1, 1)), add(multiply(arr, 0), Complex(1, 1))); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/range.js new file mode 100644 index 0000000..06e6eb5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/range.js @@ -0,0 +1,182 @@ +import { factory } from '../../utils/factory.js'; +import { noBignumber, noMatrix } from '../../utils/noop.js'; +var name = 'range'; +var dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']; +export var createRange = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + bignumber, + smaller, + smallerEq, + larger, + largerEq, + add, + isPositive + } = _ref; + /** + * Create an array from a range. + * By default, the range end is excluded. This can be customized by providing + * an extra parameter `includeEnd`. + * + * Syntax: + * + * math.range(str [, includeEnd]) // Create a range from a string, + * // where the string contains the + * // start, optional step, and end, + * // separated by a colon. + * math.range(start, end [, includeEnd]) // Create a range with start and + * // end and a step size of 1. + * math.range(start, end, step [, includeEnd]) // Create a range with start, step, + * // and end. + * + * Where: + * + * - `str: string` + * A string 'start:end' or 'start:step:end' + * - `start: {number | BigNumber | Unit}` + * Start of the range + * - `end: number | BigNumber | Unit` + * End of the range, excluded by default, included when parameter includeEnd=true + * - `step: number | BigNumber | Unit` + * Step size. Default value is 1. + * - `includeEnd: boolean` + * Option to specify whether to include the end or not. False by default. + * + * Examples: + * + * math.range(2, 6) // [2, 3, 4, 5] + * math.range(2, -3, -1) // [2, 1, 0, -1, -2] + * math.range('2:1:6') // [2, 3, 4, 5] + * math.range(2, 6, true) // [2, 3, 4, 5, 6] + * math.range(math.unit(2, 'm'), math.unit(-3, 'm'), math.unit(-1, 'm')) // [2 m, 1 m, 0 m , -1 m, -2 m] + * + * See also: + * + * ones, zeros, size, subset + * + * @param {*} args Parameters describing the ranges `start`, `end`, and optional `step`. + * @return {Array | Matrix} range + */ + return typed(name, { + // TODO: simplify signatures when typed-function supports default values and optional arguments + + // TODO: a number or boolean should not be converted to string here + string: _strRange, + 'string, boolean': _strRange, + 'number, number': function number_number(start, end) { + return _out(_range(start, end, 1, false)); + }, + 'number, number, number': function number_number_number(start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'number, number, boolean': function number_number_boolean(start, end, includeEnd) { + return _out(_range(start, end, 1, includeEnd)); + }, + 'number, number, number, boolean': function number_number_number_boolean(start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(start, end) { + var BigNumber = start.constructor; + return _out(_range(start, end, new BigNumber(1), false)); + }, + 'BigNumber, BigNumber, BigNumber': function BigNumber_BigNumber_BigNumber(start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'BigNumber, BigNumber, boolean': function BigNumber_BigNumber_boolean(start, end, includeEnd) { + var BigNumber = start.constructor; + return _out(_range(start, end, new BigNumber(1), includeEnd)); + }, + 'BigNumber, BigNumber, BigNumber, boolean': function BigNumber_BigNumber_BigNumber_boolean(start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + }, + 'Unit, Unit, Unit': function Unit_Unit_Unit(start, end, step) { + return _out(_range(start, end, step, false)); + }, + 'Unit, Unit, Unit, boolean': function Unit_Unit_Unit_boolean(start, end, step, includeEnd) { + return _out(_range(start, end, step, includeEnd)); + } + }); + function _out(arr) { + if (config.matrix === 'Matrix') { + return matrix ? matrix(arr) : noMatrix(); + } + return arr; + } + function _strRange(str, includeEnd) { + var r = _parse(str); + if (!r) { + throw new SyntaxError('String "' + str + '" is no valid range'); + } + if (config.number === 'BigNumber') { + if (bignumber === undefined) { + noBignumber(); + } + return _out(_range(bignumber(r.start), bignumber(r.end), bignumber(r.step)), includeEnd); + } else { + return _out(_range(r.start, r.end, r.step, includeEnd)); + } + } + + /** + * Create a range with numbers or BigNumbers + * @param {number | BigNumber | Unit} start + * @param {number | BigNumber | Unit} end + * @param {number | BigNumber | Unit} step + * @param {boolean} includeEnd + * @returns {Array} range + * @private + */ + function _range(start, end, step, includeEnd) { + var array = []; + var ongoing = isPositive(step) ? includeEnd ? smallerEq : smaller : includeEnd ? largerEq : larger; + var x = start; + while (ongoing(x, end)) { + array.push(x); + x = add(x, step); + } + return array; + } + + /** + * Parse a string into a range, + * The string contains the start, optional step, and end, separated by a colon. + * If the string does not contain a valid range, null is returned. + * For example str='0:2:11'. + * @param {string} str + * @return {{start: number, end: number, step: number} | null} range Object containing properties start, end, step + * @private + */ + function _parse(str) { + var args = str.split(':'); + + // number + var nums = args.map(function (arg) { + // use Number and not parseFloat as Number returns NaN on invalid garbage in the string + return Number(arg); + }); + var invalid = nums.some(function (num) { + return isNaN(num); + }); + if (invalid) { + return null; + } + switch (nums.length) { + case 2: + return { + start: nums[0], + end: nums[1], + step: 1 + }; + case 3: + return { + start: nums[0], + end: nums[2], + step: nums[1] + }; + default: + return null; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/reshape.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/reshape.js new file mode 100644 index 0000000..5ffb0fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/reshape.js @@ -0,0 +1,63 @@ +import { reshape as arrayReshape } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'reshape'; +var dependencies = ['typed', 'isInteger', 'matrix']; +export var createReshape = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isInteger + } = _ref; + /** + * Reshape a multi dimensional array to fit the specified dimensions + * + * Syntax: + * + * math.reshape(x, sizes) + * + * Examples: + * + * math.reshape([1, 2, 3, 4, 5, 6], [2, 3]) + * // returns Array [[1, 2, 3], [4, 5, 6]] + * + * math.reshape([[1, 2], [3, 4]], [1, 4]) + * // returns Array [[1, 2, 3, 4]] + * + * math.reshape([[1, 2], [3, 4]], [4]) + * // returns Array [1, 2, 3, 4] + * + * const x = math.matrix([1, 2, 3, 4, 5, 6, 7, 8]) + * math.reshape(x, [2, 2, 2]) + * // returns Matrix [[[1, 2], [3, 4]], [[5, 6], [7, 8]]] + * + * math.reshape([1, 2, 3, 4], [-1, 2]) + * // returns Matrix [[1, 2], [3, 4]] + * + * See also: + * + * size, squeeze, resize + * + * @param {Array | Matrix | *} x Matrix to be reshaped + * @param {number[]} sizes One dimensional array with integral sizes for + * each dimension. One -1 is allowed as wildcard, + * which calculates this dimension automatically. + * + * @return {* | Array | Matrix} A reshaped clone of matrix `x` + * + * @throws {TypeError} If `sizes` does not contain solely integers + * @throws {DimensionError} If the product of the new dimension sizes does + * not equal that of the old ones + */ + return typed(name, { + 'Matrix, Array': function Matrix_Array(x, sizes) { + return x.reshape(sizes, true); + }, + 'Array, Array': function Array_Array(x, sizes) { + sizes.forEach(function (size) { + if (!isInteger(size)) { + throw new TypeError('Invalid size for dimension: ' + size); + } + }); + return arrayReshape(x, sizes); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/resize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/resize.js new file mode 100644 index 0000000..754da28 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/resize.js @@ -0,0 +1,120 @@ +import { isBigNumber, isMatrix } from '../../utils/is.js'; +import { DimensionError } from '../../error/DimensionError.js'; +import { ArgumentsError } from '../../error/ArgumentsError.js'; +import { isInteger } from '../../utils/number.js'; +import { format } from '../../utils/string.js'; +import { clone } from '../../utils/object.js'; +import { resize as arrayResize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'resize'; +var dependencies = ['config', 'matrix']; +export var createResize = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + config, + matrix + } = _ref; + /** + * Resize a matrix + * + * Syntax: + * + * math.resize(x, size) + * math.resize(x, size, defaultValue) + * + * Examples: + * + * math.resize([1, 2, 3, 4, 5], [3]) // returns Array [1, 2, 3] + * math.resize([1, 2, 3], [5], 0) // returns Array [1, 2, 3, 0, 0] + * math.resize(2, [2, 3], 0) // returns Matrix [[2, 0, 0], [0, 0, 0]] + * math.resize("hello", [8], "!") // returns string 'hello!!!' + * + * See also: + * + * size, squeeze, subset, reshape + * + * @param {Array | Matrix | *} x Matrix to be resized + * @param {Array | Matrix} size One dimensional array with numbers + * @param {number | string} [defaultValue=0] Zero by default, except in + * case of a string, in that case + * defaultValue = ' ' + * @return {* | Array | Matrix} A resized clone of matrix `x` + */ + // TODO: rework resize to a typed-function + return function resize(x, size, defaultValue) { + if (arguments.length !== 2 && arguments.length !== 3) { + throw new ArgumentsError('resize', arguments.length, 2, 3); + } + if (isMatrix(size)) { + size = size.valueOf(); // get Array + } + if (isBigNumber(size[0])) { + // convert bignumbers to numbers + size = size.map(function (value) { + return !isBigNumber(value) ? value : value.toNumber(); + }); + } + + // check x is a Matrix + if (isMatrix(x)) { + // use optimized matrix implementation, return copy + return x.resize(size, defaultValue, true); + } + if (typeof x === 'string') { + // resize string + return _resizeString(x, size, defaultValue); + } + + // check result should be a matrix + var asMatrix = Array.isArray(x) ? false : config.matrix !== 'Array'; + if (size.length === 0) { + // output a scalar + while (Array.isArray(x)) { + x = x[0]; + } + return clone(x); + } else { + // output an array/matrix + if (!Array.isArray(x)) { + x = [x]; + } + x = clone(x); + var res = arrayResize(x, size, defaultValue); + return asMatrix ? matrix(res) : res; + } + }; + + /** + * Resize a string + * @param {string} str + * @param {number[]} size + * @param {string} [defaultChar=' '] + * @private + */ + function _resizeString(str, size, defaultChar) { + if (defaultChar !== undefined) { + if (typeof defaultChar !== 'string' || defaultChar.length !== 1) { + throw new TypeError('Single character expected as defaultValue'); + } + } else { + defaultChar = ' '; + } + if (size.length !== 1) { + throw new DimensionError(size.length, 1); + } + var len = size[0]; + if (typeof len !== 'number' || !isInteger(len)) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + format(size) + ')'); + } + if (str.length > len) { + return str.substring(0, len); + } else if (str.length < len) { + var res = str; + for (var i = 0, ii = len - str.length; i < ii; i++) { + res += defaultChar; + } + return res; + } else { + return str; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotate.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotate.js new file mode 100644 index 0000000..72f0ef8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotate.js @@ -0,0 +1,71 @@ +import { factory } from '../../utils/factory.js'; +import { arraySize } from '../../utils/array.js'; +var name = 'rotate'; +var dependencies = ['typed', 'multiply', 'rotationMatrix']; +export var createRotate = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + multiply, + rotationMatrix + } = _ref; + /** + * Rotate a vector of size 1x2 counter-clockwise by a given angle + * Rotate a vector of size 1x3 counter-clockwise by a given angle around the given axis + * + * Syntax: + * + * math.rotate(w, theta) + * math.rotate(w, theta, v) + * + * Examples: + * + * math.rotate([11, 12], math.pi / 2) // returns [-12, 11] + * math.rotate(matrix([11, 12]), math.pi / 2) // returns [-12, 11] + * + * math.rotate([1, 0, 0], unit('90deg'), [0, 0, 1]) // returns [0, 1, 0] + * math.rotate(matrix([1, 0, 0]), unit('90deg'), [0, 0, 1]) // returns Matrix [0, 1, 0] + * + * math.rotate([1, 0], math.complex(1 + i)) // returns [cos(1 + i) - sin(1 + i), sin(1 + i) + cos(1 + i)] + * + * See also: + * + * matrix, rotationMatrix + * + * @param {Array | Matrix} w Vector to rotate + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @return {Array | Matrix} Multiplication of the rotation matrix and w + */ + return typed(name, { + 'Array , number | BigNumber | Complex | Unit': function Array__number__BigNumber__Complex__Unit(w, theta) { + _validateSize(w, 2); + var matrixRes = multiply(rotationMatrix(theta), w); + return matrixRes.toArray(); + }, + 'Matrix , number | BigNumber | Complex | Unit': function Matrix__number__BigNumber__Complex__Unit(w, theta) { + _validateSize(w, 2); + return multiply(rotationMatrix(theta), w); + }, + 'Array, number | BigNumber | Complex | Unit, Array | Matrix': function Array_number__BigNumber__Complex__Unit_Array__Matrix(w, theta, v) { + _validateSize(w, 3); + var matrixRes = multiply(rotationMatrix(theta, v), w); + return matrixRes; + }, + 'Matrix, number | BigNumber | Complex | Unit, Array | Matrix': function Matrix_number__BigNumber__Complex__Unit_Array__Matrix(w, theta, v) { + _validateSize(w, 3); + return multiply(rotationMatrix(theta, v), w); + } + }); + function _validateSize(v, expectedSize) { + var actualSize = Array.isArray(v) ? arraySize(v) : v.size(); + if (actualSize.length > 2) { + throw new RangeError("Vector must be of dimensions 1x".concat(expectedSize)); + } + if (actualSize.length === 2 && actualSize[1] !== 1) { + throw new RangeError("Vector must be of dimensions 1x".concat(expectedSize)); + } + if (actualSize[0] !== expectedSize) { + throw new RangeError("Vector must be of dimensions 1x".concat(expectedSize)); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotationMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotationMatrix.js new file mode 100644 index 0000000..1d91610 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/rotationMatrix.js @@ -0,0 +1,160 @@ +import { isBigNumber } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'rotationMatrix'; +var dependencies = ['typed', 'config', 'multiplyScalar', 'addScalar', 'unaryMinus', 'norm', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix', 'cos', 'sin']; +export var createRotationMatrix = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + multiplyScalar, + addScalar, + unaryMinus, + norm, + BigNumber, + matrix, + DenseMatrix, + SparseMatrix, + cos, + sin + } = _ref; + /** + * Create a 2-dimensional counter-clockwise rotation matrix (2x2) for a given angle (expressed in radians). + * Create a 2-dimensional counter-clockwise rotation matrix (3x3) by a given angle (expressed in radians) around a given axis (1x3). + * + * Syntax: + * + * math.rotationMatrix(theta) + * math.rotationMatrix(theta, format) + * math.rotationMatrix(theta, [v]) + * math.rotationMatrix(theta, [v], format) + * + * Examples: + * + * math.rotationMatrix(math.pi / 2) // returns [[0, -1], [1, 0]] + * math.rotationMatrix(math.bignumber(1)) // returns [[bignumber(cos(1)), bignumber(-sin(1))], [bignumber(sin(1)), bignumber(cos(1))]] + * math.rotationMatrix(math.complex(1 + i)) // returns [[cos(1 + i), -sin(1 + i)], [sin(1 + i), cos(1 + i)]] + * math.rotationMatrix(math.unit('1rad')) // returns [[cos(1), -sin(1)], [sin(1), cos(1)]] + * + * math.rotationMatrix(math.pi / 2, [0, 1, 0]) // returns [[0, 0, 1], [0, 1, 0], [-1, 0, 0]] + * math.rotationMatrix(math.pi / 2, matrix([0, 1, 0])) // returns matrix([[0, 0, 1], [0, 1, 0], [-1, 0, 0]]) + * + * + * See also: + * + * matrix, cos, sin + * + * + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @param {string} [format] Result Matrix storage format + * @return {Array | Matrix} Rotation matrix + */ + + return typed(name, { + '': function _() { + return config.matrix === 'Matrix' ? matrix([]) : []; + }, + string: function string(format) { + return matrix(format); + }, + 'number | BigNumber | Complex | Unit': function number__BigNumber__Complex__Unit(theta) { + return _rotationMatrix2x2(theta, config.matrix === 'Matrix' ? 'dense' : undefined); + }, + 'number | BigNumber | Complex | Unit, string': function number__BigNumber__Complex__Unit_string(theta, format) { + return _rotationMatrix2x2(theta, format); + }, + 'number | BigNumber | Complex | Unit, Array': function number__BigNumber__Complex__Unit_Array(theta, v) { + var matrixV = matrix(v); + _validateVector(matrixV); + return _rotationMatrix3x3(theta, matrixV, undefined); + }, + 'number | BigNumber | Complex | Unit, Matrix': function number__BigNumber__Complex__Unit_Matrix(theta, v) { + _validateVector(v); + var storageType = v.storage() || (config.matrix === 'Matrix' ? 'dense' : undefined); + return _rotationMatrix3x3(theta, v, storageType); + }, + 'number | BigNumber | Complex | Unit, Array, string': function number__BigNumber__Complex__Unit_Array_string(theta, v, format) { + var matrixV = matrix(v); + _validateVector(matrixV); + return _rotationMatrix3x3(theta, matrixV, format); + }, + 'number | BigNumber | Complex | Unit, Matrix, string': function number__BigNumber__Complex__Unit_Matrix_string(theta, v, format) { + _validateVector(v); + return _rotationMatrix3x3(theta, v, format); + } + }); + + /** + * Returns 2x2 matrix of 2D rotation of angle theta + * + * @param {number | BigNumber | Complex | Unit} theta The rotation angle + * @param {string} format The result Matrix storage format + * @returns {Matrix} + * @private + */ + function _rotationMatrix2x2(theta, format) { + var Big = isBigNumber(theta); + var minusOne = Big ? new BigNumber(-1) : -1; + var cosTheta = cos(theta); + var sinTheta = sin(theta); + var data = [[cosTheta, multiplyScalar(minusOne, sinTheta)], [sinTheta, cosTheta]]; + return _convertToFormat(data, format); + } + function _validateVector(v) { + var size = v.size(); + if (size.length < 1 || size[0] !== 3) { + throw new RangeError('Vector must be of dimensions 1x3'); + } + } + function _mul(array) { + return array.reduce((p, curr) => multiplyScalar(p, curr)); + } + function _convertToFormat(data, format) { + if (format) { + if (format === 'sparse') { + return new SparseMatrix(data); + } + if (format === 'dense') { + return new DenseMatrix(data); + } + throw new TypeError("Unknown matrix type \"".concat(format, "\"")); + } + return data; + } + + /** + * Returns a 3x3 matrix of rotation of angle theta around vector v + * + * @param {number | BigNumber | Complex | Unit} theta The rotation angle + * @param {Matrix} v The rotation axis vector + * @param {string} format The storage format of the resulting matrix + * @returns {Matrix} + * @private + */ + function _rotationMatrix3x3(theta, v, format) { + var normV = norm(v); + if (normV === 0) { + throw new RangeError('Rotation around zero vector'); + } + var Big = isBigNumber(theta) ? BigNumber : null; + var one = Big ? new Big(1) : 1; + var minusOne = Big ? new Big(-1) : -1; + var vx = Big ? new Big(v.get([0]) / normV) : v.get([0]) / normV; + var vy = Big ? new Big(v.get([1]) / normV) : v.get([1]) / normV; + var vz = Big ? new Big(v.get([2]) / normV) : v.get([2]) / normV; + var c = cos(theta); + var oneMinusC = addScalar(one, unaryMinus(c)); + var s = sin(theta); + var r11 = addScalar(c, _mul([vx, vx, oneMinusC])); + var r12 = addScalar(_mul([vx, vy, oneMinusC]), _mul([minusOne, vz, s])); + var r13 = addScalar(_mul([vx, vz, oneMinusC]), _mul([vy, s])); + var r21 = addScalar(_mul([vx, vy, oneMinusC]), _mul([vz, s])); + var r22 = addScalar(c, _mul([vy, vy, oneMinusC])); + var r23 = addScalar(_mul([vy, vz, oneMinusC]), _mul([minusOne, vx, s])); + var r31 = addScalar(_mul([vx, vz, oneMinusC]), _mul([minusOne, vy, s])); + var r32 = addScalar(_mul([vy, vz, oneMinusC]), _mul([vx, s])); + var r33 = addScalar(c, _mul([vz, vz, oneMinusC])); + var data = [[r11, r12, r13], [r21, r22, r23], [r31, r32, r33]]; + return _convertToFormat(data, format); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/row.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/row.js new file mode 100644 index 0000000..cdfed13 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/row.js @@ -0,0 +1,59 @@ +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { validateIndex } from '../../utils/array.js'; +var name = 'row'; +var dependencies = ['typed', 'Index', 'matrix', 'range']; +export var createRow = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Index, + matrix, + range + } = _ref; + /** + * Return a row from a Matrix. + * + * Syntax: + * + * math.row(value, index) + * + * Example: + * + * // get a row + * const d = [[1, 2], [3, 4]] + * math.row(d, 1) // returns [[3, 4]] + * + * See also: + * + * column + * + * @param {Array | Matrix } value An array or matrix + * @param {number} row The index of the row + * @return {Array | Matrix} The retrieved row + */ + return typed(name, { + 'Matrix, number': _row, + 'Array, number': function Array_number(value, row) { + return _row(matrix(clone(value)), row).valueOf(); + } + }); + + /** + * Retrieve a row of a matrix + * @param {Matrix } value A matrix + * @param {number} row The index of the row + * @return {Matrix} The retrieved row + */ + function _row(value, row) { + // check dimensions + if (value.size().length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + validateIndex(row, value.size()[0]); + var columnRange = range(0, value.size()[1]); + var index = new Index(row, columnRange); + var result = value.subset(index); + return isMatrix(result) ? result : matrix([[result]]); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/size.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/size.js new file mode 100644 index 0000000..50355c5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/size.js @@ -0,0 +1,48 @@ +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { noMatrix } from '../../utils/noop.js'; +var name = 'size'; +var dependencies = ['typed', 'config', '?matrix']; +export var createSize = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix + } = _ref; + /** + * Calculate the size of a matrix or scalar. + * + * Syntax: + * + * math.size(x) + * + * Examples: + * + * math.size(2.3) // returns [] + * math.size('hello world') // returns [11] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.size(A) // returns [2, 3] + * math.size(math.range(1,6).toArray()) // returns [5] + * + * See also: + * + * count, resize, squeeze, subset + * + * @param {boolean | number | Complex | Unit | string | Array | Matrix} x A matrix + * @return {Array | Matrix} A vector with size of `x`. + */ + return typed(name, { + Matrix: function Matrix(x) { + return x.create(x.size(), 'number'); + }, + Array: arraySize, + string: function string(x) { + return config.matrix === 'Array' ? [x.length] : matrix([x.length], 'dense', 'number'); + }, + 'number | Complex | BigNumber | Unit | boolean | null': function number__Complex__BigNumber__Unit__boolean__null(x) { + // scalar + return config.matrix === 'Array' ? [] : matrix ? matrix([], 'dense', 'number') : noMatrix(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sort.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sort.js new file mode 100644 index 0000000..48c7f29 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sort.js @@ -0,0 +1,113 @@ +import { arraySize as size } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'sort'; +var dependencies = ['typed', 'matrix', 'compare', 'compareNatural']; +export var createSort = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + compare, + compareNatural + } = _ref; + var compareAsc = compare; + var compareDesc = (a, b) => -compare(a, b); + + /** + * Sort the items in a matrix. + * + * Syntax: + * + * math.sort(x) + * math.sort(x, compare) + * + * Examples: + * + * math.sort([5, 10, 1]) // returns [1, 5, 10] + * math.sort(['C', 'B', 'A', 'D'], math.compareNatural) + * // returns ['A', 'B', 'C', 'D'] + * + * function sortByLength (a, b) { + * return a.length - b.length + * } + * math.sort(['Langdon', 'Tom', 'Sara'], sortByLength) + * // returns ['Tom', 'Sara', 'Langdon'] + * + * See also: + * + * filter, forEach, map, compare, compareNatural + * + * @param {Matrix | Array} x A one dimensional matrix or array to sort + * @param {Function | 'asc' | 'desc' | 'natural'} [compare='asc'] + * An optional _comparator function or name. The function is called as + * `compare(a, b)`, and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. + * @return {Matrix | Array} Returns the sorted matrix. + */ + return typed(name, { + Array: function Array(x) { + _arrayIsVector(x); + return x.sort(compareAsc); + }, + Matrix: function Matrix(x) { + _matrixIsVector(x); + return matrix(x.toArray().sort(compareAsc), x.storage()); + }, + 'Array, function': function Array_function(x, _comparator) { + _arrayIsVector(x); + return x.sort(_comparator); + }, + 'Matrix, function': function Matrix_function(x, _comparator) { + _matrixIsVector(x); + return matrix(x.toArray().sort(_comparator), x.storage()); + }, + 'Array, string': function Array_string(x, order) { + _arrayIsVector(x); + return x.sort(_comparator(order)); + }, + 'Matrix, string': function Matrix_string(x, order) { + _matrixIsVector(x); + return matrix(x.toArray().sort(_comparator(order)), x.storage()); + } + }); + + /** + * Get the comparator for given order ('asc', 'desc', 'natural') + * @param {'asc' | 'desc' | 'natural'} order + * @return {Function} Returns a _comparator function + */ + function _comparator(order) { + if (order === 'asc') { + return compareAsc; + } else if (order === 'desc') { + return compareDesc; + } else if (order === 'natural') { + return compareNatural; + } else { + throw new Error('String "asc", "desc", or "natural" expected'); + } + } + + /** + * Validate whether an array is one dimensional + * Throws an error when this is not the case + * @param {Array} array + * @private + */ + function _arrayIsVector(array) { + if (size(array).length !== 1) { + throw new Error('One dimensional array expected'); + } + } + + /** + * Validate whether a matrix is one dimensional + * Throws an error when this is not the case + * @param {Matrix} matrix + * @private + */ + function _matrixIsVector(matrix) { + if (matrix.size().length !== 1) { + throw new Error('One dimensional matrix expected'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sqrtm.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sqrtm.js new file mode 100644 index 0000000..8c5aa94 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/sqrtm.js @@ -0,0 +1,99 @@ +import { isMatrix } from '../../utils/is.js'; +import { format } from '../../utils/string.js'; +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'sqrtm'; +var dependencies = ['typed', 'abs', 'add', 'multiply', 'map', 'sqrt', 'subtract', 'inv', 'size', 'max', 'identity']; +export var createSqrtm = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + add, + multiply, + map, + sqrt, + subtract, + inv, + size, + max, + identity + } = _ref; + var _maxIterations = 1e3; + var _tolerance = 1e-6; + + /** + * Calculate the principal square root matrix using the Denman–Beavers iterative method + * + * https://en.wikipedia.org/wiki/Square_root_of_a_matrix#By_Denman–Beavers_iteration + * + * @param {Array | Matrix} A The square matrix `A` + * @return {Array | Matrix} The principal square root of matrix `A` + * @private + */ + function _denmanBeavers(A) { + var error; + var iterations = 0; + var Y = A; + var Z = identity(size(A)); + do { + var Yk = Y; + Y = multiply(0.5, add(Yk, inv(Z))); + Z = multiply(0.5, add(Z, inv(Yk))); + error = max(abs(subtract(Y, Yk))); + if (error > _tolerance && ++iterations > _maxIterations) { + throw new Error('computing square root of matrix: iterative method could not converge'); + } + } while (error > _tolerance); + return Y; + } + + /** + * Calculate the principal square root of a square matrix. + * The principal square root matrix `X` of another matrix `A` is such that `X * X = A`. + * + * https://en.wikipedia.org/wiki/Square_root_of_a_matrix + * + * Syntax: + * + * math.sqrtm(A) + * + * Examples: + * + * math.sqrtm([[33, 24], [48, 57]]) // returns [[5, 2], [4, 7]] + * + * See also: + * + * sqrt, pow + * + * @param {Array | Matrix} A The square matrix `A` + * @return {Array | Matrix} The principal square root of matrix `A` + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(A) { + var size = isMatrix(A) ? A.size() : arraySize(A); + switch (size.length) { + case 1: + // Single element Array | Matrix + if (size[0] === 1) { + return map(A, sqrt); + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + case 2: + { + // Two-dimensional Array | Matrix + var rows = size[0]; + var cols = size[1]; + if (rows === cols) { + return _denmanBeavers(A); + } else { + throw new RangeError('Matrix must be square ' + '(size: ' + format(size) + ')'); + } + } + default: + // Multi dimensional array + throw new RangeError('Matrix must be at most two dimensional ' + '(size: ' + format(size) + ')'); + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/squeeze.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/squeeze.js new file mode 100644 index 0000000..c40e713 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/squeeze.js @@ -0,0 +1,53 @@ +import { clone } from '../../utils/object.js'; +import { squeeze as arraySqueeze } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'squeeze'; +var dependencies = ['typed']; +export var createSqueeze = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Squeeze a matrix, remove inner and outer singleton dimensions from a matrix. + * + * Syntax: + * + * math.squeeze(x) + * + * Examples: + * + * math.squeeze([3]) // returns 3 + * math.squeeze([[3]]) // returns 3 + * + * const A = math.zeros(3, 1) // returns [[0], [0], [0]] (size 3x1) + * math.squeeze(A) // returns [0, 0, 0] (size 3) + * + * const B = math.zeros(1, 3) // returns [[0, 0, 0]] (size 1x3) + * math.squeeze(B) // returns [0, 0, 0] (size 3) + * + * // only inner and outer dimensions are removed + * const C = math.zeros(2, 1, 3) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3) + * math.squeeze(C) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3) + * + * See also: + * + * subset + * + * @param {Matrix | Array} x Matrix to be squeezed + * @return {Matrix | Array} Squeezed matrix + */ + return typed(name, { + Array: function Array(x) { + return arraySqueeze(clone(x)); + }, + Matrix: function Matrix(x) { + var res = arraySqueeze(x.toArray()); + // FIXME: return the same type of matrix as the input + return Array.isArray(res) ? x.create(res, x.datatype()) : res; + }, + any: function any(x) { + // scalar + return clone(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/subset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/subset.js new file mode 100644 index 0000000..df44b6d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/subset.js @@ -0,0 +1,273 @@ +import { isIndex } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { isEmptyIndex, validateIndex, validateIndexSourceSize } from '../../utils/array.js'; +import { getSafeProperty, setSafeProperty } from '../../utils/customs.js'; +import { DimensionError } from '../../error/DimensionError.js'; +import { factory } from '../../utils/factory.js'; +var name = 'subset'; +var dependencies = ['typed', 'matrix', 'zeros', 'add']; +export var createSubset = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + zeros, + add + } = _ref; + /** + * Get or set a subset of a matrix or string. + * + * Syntax: + * math.subset(value, index) // retrieve a subset + * math.subset(value, index, replacement [, defaultValue]) // replace a subset + * + * Examples: + * + * // get a subset + * const d = [[1, 2], [3, 4]] + * math.subset(d, math.index(1, 0)) // returns 3 + * math.subset(d, math.index([0, 1], 1)) // returns [[2], [4]] + * math.subset(d, math.index([false, true], 0)) // returns [[3]] + * + * // replace a subset + * const e = [] + * const f = math.subset(e, math.index(0, [0, 2]), [5, 6]) // f = [[5, 0, 6]] + * const g = math.subset(f, math.index(1, 1), 7, 0) // g = [[5, 0, 6], [0, 7, 0]] + * math.subset(g, math.index([false, true], 1), 8) // returns [[5, 0, 6], [0, 8, 0]] + * + * // get submatrix using ranges + * const M = [ + * [1,2,3], + * [4,5,6], + * [7,8,9] + * ] + * math.subset(M, math.index(math.range(0,2), math.range(0,3))) // [[1, 2, 3], [4, 5, 6]] + * + * See also: + * + * size, resize, squeeze, index + * + * @param {Array | Matrix | string} matrix An array, matrix, or string + * @param {Index} index + * For each dimension of the target, specifies an index or a list of + * indices to fetch or set. `subset` uses the cartesian product of + * the indices specified in each dimension. + * @param {*} [replacement] An array, matrix, or scalar. + * If provided, the subset is replaced with replacement. + * If not provided, the subset is returned + * @param {*} [defaultValue=undefined] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * math.matrix elements will be left undefined. + * @return {Array | Matrix | string} Either the retrieved subset or the updated matrix. + */ + + return typed(name, { + // get subset + 'Matrix, Index': function Matrix_Index(value, index) { + if (isEmptyIndex(index)) { + return matrix(); + } + validateIndexSourceSize(value, index); + return value.subset(index); + }, + 'Array, Index': typed.referTo('Matrix, Index', function (subsetRef) { + return function (value, index) { + var subsetResult = subsetRef(matrix(value), index); + return index.isScalar() ? subsetResult : subsetResult.valueOf(); + }; + }), + 'Object, Index': _getObjectProperty, + 'string, Index': _getSubstring, + // set subset + 'Matrix, Index, any, any': function Matrix_Index_any_any(value, index, replacement, defaultValue) { + if (isEmptyIndex(index)) { + return value; + } + validateIndexSourceSize(value, index); + return value.clone().subset(index, _broadcastReplacement(replacement, index), defaultValue); + }, + 'Array, Index, any, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement, defaultValue) { + var subsetResult = subsetRef(matrix(value), index, replacement, defaultValue); + return subsetResult.isMatrix ? subsetResult.valueOf() : subsetResult; + }; + }), + 'Array, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement) { + return subsetRef(matrix(value), index, replacement, undefined).valueOf(); + }; + }), + 'Matrix, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) { + return function (value, index, replacement) { + return subsetRef(value, index, replacement, undefined); + }; + }), + 'string, Index, string': _setSubstring, + 'string, Index, string, string': _setSubstring, + 'Object, Index, any': _setObjectProperty + }); + + /** + * Broadcasts a replacment value to be the same size as index + * @param {number | BigNumber | Array | Matrix} replacement Replacement value to try to broadcast + * @param {*} index Index value + * @returns broadcasted replacement that matches the size of index + */ + + function _broadcastReplacement(replacement, index) { + if (typeof replacement === 'string') { + throw new Error('can\'t boradcast a string'); + } + if (index._isScalar) { + return replacement; + } + var indexSize = index.size(); + if (indexSize.every(d => d > 0)) { + try { + return add(replacement, zeros(indexSize)); + } catch (error) { + return replacement; + } + } else { + return replacement; + } + } +}); + +/** + * Retrieve a subset of a string + * @param {string} str string from which to get a substring + * @param {Index} index An index or list of indices (character positions) + * @returns {string} substring + * @private + */ +function _getSubstring(str, index) { + if (!isIndex(index)) { + // TODO: better error message + throw new TypeError('Index expected'); + } + if (isEmptyIndex(index)) { + return ''; + } + validateIndexSourceSize(Array.from(str), index); + if (index.size().length !== 1) { + throw new DimensionError(index.size().length, 1); + } + + // validate whether the range is out of range + var strLen = str.length; + validateIndex(index.min()[0], strLen); + validateIndex(index.max()[0], strLen); + var range = index.dimension(0); + var substr = ''; + range.forEach(function (v) { + substr += str.charAt(v); + }); + return substr; +} + +/** + * Replace a substring in a string + * @param {string} str string to be replaced + * @param {Index} index An index or list of indices (character positions) + * @param {string} replacement Replacement string + * @param {string} [defaultValue] Default value to be used when resizing + * the string. is ' ' by default + * @returns {string} result + * @private + */ +function _setSubstring(str, index, replacement, defaultValue) { + if (!index || index.isIndex !== true) { + // TODO: better error message + throw new TypeError('Index expected'); + } + if (isEmptyIndex(index)) { + return str; + } + validateIndexSourceSize(Array.from(str), index); + if (index.size().length !== 1) { + throw new DimensionError(index.size().length, 1); + } + if (defaultValue !== undefined) { + if (typeof defaultValue !== 'string' || defaultValue.length !== 1) { + throw new TypeError('Single character expected as defaultValue'); + } + } else { + defaultValue = ' '; + } + var range = index.dimension(0); + var len = range.size()[0]; + if (len !== replacement.length) { + throw new DimensionError(range.size()[0], replacement.length); + } + + // validate whether the range is out of range + var strLen = str.length; + validateIndex(index.min()[0]); + validateIndex(index.max()[0]); + + // copy the string into an array with characters + var chars = []; + for (var i = 0; i < strLen; i++) { + chars[i] = str.charAt(i); + } + range.forEach(function (v, i) { + chars[v] = replacement.charAt(i[0]); + }); + + // initialize undefined characters with a space + if (chars.length > strLen) { + for (var _i = strLen - 1, _len = chars.length; _i < _len; _i++) { + if (!chars[_i]) { + chars[_i] = defaultValue; + } + } + } + return chars.join(''); +} + +/** + * Retrieve a property from an object + * @param {Object} object + * @param {Index} index + * @return {*} Returns the value of the property + * @private + */ +function _getObjectProperty(object, index) { + if (isEmptyIndex(index)) { + return undefined; + } + if (index.size().length !== 1) { + throw new DimensionError(index.size(), 1); + } + var key = index.dimension(0); + if (typeof key !== 'string') { + throw new TypeError('String expected as index to retrieve an object property'); + } + return getSafeProperty(object, key); +} + +/** + * Set a property on an object + * @param {Object} object + * @param {Index} index + * @param {*} replacement + * @return {*} Returns the updated object + * @private + */ +function _setObjectProperty(object, index, replacement) { + if (isEmptyIndex(index)) { + return object; + } + if (index.size().length !== 1) { + throw new DimensionError(index.size(), 1); + } + var key = index.dimension(0); + if (typeof key !== 'string') { + throw new TypeError('String expected as index to retrieve an object property'); + } + + // clone the object, and apply the property to the clone + var updated = clone(object); + setSafeProperty(updated, key, replacement); + return updated; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/trace.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/trace.js new file mode 100644 index 0000000..1d94b48 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/trace.js @@ -0,0 +1,128 @@ +import { clone } from '../../utils/object.js'; +import { format } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +var name = 'trace'; +var dependencies = ['typed', 'matrix', 'add']; +export var createTrace = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + add + } = _ref; + /** + * Calculate the trace of a matrix: the sum of the elements on the main + * diagonal of a square matrix. + * + * Syntax: + * + * math.trace(x) + * + * Examples: + * + * math.trace([[1, 2], [3, 4]]) // returns 5 + * + * const A = [ + * [1, 2, 3], + * [-1, 2, 3], + * [2, 0, 3] + * ] + * math.trace(A) // returns 6 + * + * See also: + * + * diag + * + * @param {Array | Matrix} x A matrix + * + * @return {number} The trace of `x` + */ + return typed('trace', { + Array: function _arrayTrace(x) { + // use dense matrix implementation + return _denseTrace(matrix(x)); + }, + SparseMatrix: _sparseTrace, + DenseMatrix: _denseTrace, + any: clone + }); + function _denseTrace(m) { + // matrix size & data + var size = m._size; + var data = m._data; + + // process dimensions + switch (size.length) { + case 1: + // vector + if (size[0] === 1) { + // return data[0] + return clone(data[0]); + } + throw new RangeError('Matrix must be square (size: ' + format(size) + ')'); + case 2: + { + // two dimensional + var rows = size[0]; + var cols = size[1]; + if (rows === cols) { + // calulate sum + var sum = 0; + // loop diagonal + for (var i = 0; i < rows; i++) { + sum = add(sum, data[i][i]); + } + // return trace + return sum; + } else { + throw new RangeError('Matrix must be square (size: ' + format(size) + ')'); + } + } + default: + // multi dimensional + throw new RangeError('Matrix must be two dimensional (size: ' + format(size) + ')'); + } + } + function _sparseTrace(m) { + // matrix arrays + var values = m._values; + var index = m._index; + var ptr = m._ptr; + var size = m._size; + // check dimensions + var rows = size[0]; + var columns = size[1]; + // matrix must be square + if (rows === columns) { + // calulate sum + var sum = 0; + // check we have data (avoid looping columns) + if (values.length > 0) { + // loop columns + for (var j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = ptr[j]; + var k1 = ptr[j + 1]; + // loop k within [k0, k1[ + for (var k = k0; k < k1; k++) { + // row index + var i = index[k]; + // check row + if (i === j) { + // accumulate value + sum = add(sum, values[k]); + // exit loop + break; + } + if (i > j) { + // exit loop, no value on the diagonal for column j + break; + } + } + } + } + // return trace + return sum; + } + throw new RangeError('Matrix must be square (size: ' + format(size) + ')'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/transpose.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/transpose.js new file mode 100644 index 0000000..c786b67 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/transpose.js @@ -0,0 +1,160 @@ +import { clone } from '../../utils/object.js'; +import { format } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +var name = 'transpose'; +var dependencies = ['typed', 'matrix']; +export var createTranspose = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix + } = _ref; + /** + * Transpose a matrix. All values of the matrix are reflected over its + * main diagonal. Only applicable to two dimensional matrices containing + * a vector (i.e. having size `[1,n]` or `[n,1]`). One dimensional + * vectors and scalars return the input unchanged. + * + * Syntax: + * + * math.transpose(x) + * + * Examples: + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.transpose(A) // returns [[1, 4], [2, 5], [3, 6]] + * + * See also: + * + * diag, inv, subset, squeeze + * + * @param {Array | Matrix} x Matrix to be transposed + * @return {Array | Matrix} The transposed matrix + */ + return typed(name, { + Array: x => transposeMatrix(matrix(x)).valueOf(), + Matrix: transposeMatrix, + any: clone // scalars + }); + function transposeMatrix(x) { + // matrix size + var size = x.size(); + + // result + var c; + + // process dimensions + switch (size.length) { + case 1: + // vector + c = x.clone(); + break; + case 2: + { + // rows and columns + var rows = size[0]; + var columns = size[1]; + + // check columns + if (columns === 0) { + // throw exception + throw new RangeError('Cannot transpose a 2D matrix with no columns (size: ' + format(size) + ')'); + } + + // process storage format + switch (x.storage()) { + case 'dense': + c = _denseTranspose(x, rows, columns); + break; + case 'sparse': + c = _sparseTranspose(x, rows, columns); + break; + } + } + break; + default: + // multi dimensional + throw new RangeError('Matrix must be a vector or two dimensional (size: ' + format(size) + ')'); + } + return c; + } + function _denseTranspose(m, rows, columns) { + // matrix array + var data = m._data; + // transposed matrix data + var transposed = []; + var transposedRow; + // loop columns + for (var j = 0; j < columns; j++) { + // initialize row + transposedRow = transposed[j] = []; + // loop rows + for (var i = 0; i < rows; i++) { + // set data + transposedRow[i] = clone(data[i][j]); + } + } + // return matrix + return m.createDenseMatrix({ + data: transposed, + size: [columns, rows], + datatype: m._datatype + }); + } + function _sparseTranspose(m, rows, columns) { + // matrix arrays + var values = m._values; + var index = m._index; + var ptr = m._ptr; + // result matrices + var cvalues = values ? [] : undefined; + var cindex = []; + var cptr = []; + // row counts + var w = []; + for (var x = 0; x < rows; x++) { + w[x] = 0; + } + // vars + var p, l, j; + // loop values in matrix + for (p = 0, l = index.length; p < l; p++) { + // number of values in row + w[index[p]]++; + } + // cumulative sum + var sum = 0; + // initialize cptr with the cummulative sum of row counts + for (var i = 0; i < rows; i++) { + // update cptr + cptr.push(sum); + // update sum + sum += w[i]; + // update w + w[i] = cptr[i]; + } + // update cptr + cptr.push(sum); + // loop columns + for (j = 0; j < columns; j++) { + // values & index in column + for (var k0 = ptr[j], k1 = ptr[j + 1], k = k0; k < k1; k++) { + // C values & index + var q = w[index[k]]++; + // C[j, i] = A[i, j] + cindex[q] = j; + // check we need to process values (pattern matrix) + if (values) { + cvalues[q] = clone(values[k]); + } + } + } + // return matrix + return m.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [columns, rows], + datatype: m._datatype + }); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/zeros.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/zeros.js new file mode 100644 index 0000000..5c19506 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/matrix/zeros.js @@ -0,0 +1,123 @@ +import { isBigNumber } from '../../utils/is.js'; +import { isInteger } from '../../utils/number.js'; +import { resize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'zeros'; +var dependencies = ['typed', 'config', 'matrix', 'BigNumber']; +export var createZeros = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + BigNumber + } = _ref; + /** + * Create a matrix filled with zeros. The created matrix can have one or + * multiple dimensions. + * + * Syntax: + * + * math.zeros(m) + * math.zeros(m, format) + * math.zeros(m, n) + * math.zeros(m, n, format) + * math.zeros([m, n]) + * math.zeros([m, n], format) + * + * Examples: + * + * math.zeros() // returns [] + * math.zeros(3) // returns [0, 0, 0] + * math.zeros(3, 2) // returns [[0, 0], [0, 0], [0, 0]] + * math.zeros(3, 'dense') // returns [0, 0, 0] + * + * const A = [[1, 2, 3], [4, 5, 6]] + * math.zeros(math.size(A)) // returns [[0, 0, 0], [0, 0, 0]] + * + * See also: + * + * ones, identity, size, range + * + * @param {...(number|BigNumber) | Array} size The size of each dimension of the matrix + * @param {string} [format] The Matrix storage format + * + * @return {Array | Matrix} A matrix filled with zeros + */ + return typed(name, { + '': function _() { + return config.matrix === 'Array' ? _zeros([]) : _zeros([], 'default'); + }, + // math.zeros(m, n, p, ..., format) + // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this + '...number | BigNumber | string': function number__BigNumber__string(size) { + var last = size[size.length - 1]; + if (typeof last === 'string') { + var format = size.pop(); + return _zeros(size, format); + } else if (config.matrix === 'Array') { + return _zeros(size); + } else { + return _zeros(size, 'default'); + } + }, + Array: _zeros, + Matrix: function Matrix(size) { + var format = size.storage(); + return _zeros(size.valueOf(), format); + }, + 'Array | Matrix, string': function Array__Matrix_string(size, format) { + return _zeros(size.valueOf(), format); + } + }); + + /** + * Create an Array or Matrix with zeros + * @param {Array} size + * @param {string} [format='default'] + * @return {Array | Matrix} + * @private + */ + function _zeros(size, format) { + var hasBigNumbers = _normalize(size); + var defaultValue = hasBigNumbers ? new BigNumber(0) : 0; + _validate(size); + if (format) { + // return a matrix + var m = matrix(format); + if (size.length > 0) { + return m.resize(size, defaultValue); + } + return m; + } else { + // return an Array + var arr = []; + if (size.length > 0) { + return resize(arr, size, defaultValue); + } + return arr; + } + } + + // replace BigNumbers with numbers, returns true if size contained BigNumbers + function _normalize(size) { + var hasBigNumbers = false; + size.forEach(function (value, index, arr) { + if (isBigNumber(value)) { + hasBigNumbers = true; + arr[index] = value.toNumber(); + } + }); + return hasBigNumbers; + } + + // validate arguments + function _validate(size) { + size.forEach(function (value) { + if (typeof value !== 'number' || !isInteger(value) || value < 0) { + throw new Error('Parameters in function zeros must be positive integers'); + } + }); + } +}); + +// TODO: zeros contains almost the same code as ones. Reuse this? \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/numeric/solveODE.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/numeric/solveODE.js new file mode 100644 index 0000000..367c42e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/numeric/solveODE.js @@ -0,0 +1,284 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +import { isUnit, isNumber, isBigNumber } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'solveODE'; +var dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'max', 'map', 'abs', 'isPositive', 'isNegative', 'larger', 'smaller', 'matrix', 'bignumber', 'unaryMinus']; +export var createSolveODE = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + subtract, + multiply, + divide, + max, + map, + abs, + isPositive, + isNegative, + larger, + smaller, + matrix, + bignumber, + unaryMinus + } = _ref; + /** + * Numerical Integration of Ordinary Differential Equations + * + * Two variable step methods are provided: + * - "RK23": Bogacki–Shampine method + * - "RK45": Dormand-Prince method RK5(4)7M (default) + * + * The arguments are expected as follows. + * + * - `func` should be the forcing function `f(t, y)` + * - `tspan` should be a vector of two numbers or units `[tStart, tEnd]` + * - `y0` the initial state values, should be a scalar or a flat array + * - `options` should be an object with the following information: + * - `method` ('RK45'): ['RK23', 'RK45'] + * - `tol` (1e-3): Numeric tolerance of the method, the solver keeps the error estimates less than this value + * - `firstStep`: Initial step size + * - `minStep`: minimum step size of the method + * - `maxStep`: maximum step size of the method + * - `minDelta` (0.2): minimum ratio of change for the step + * - `maxDelta` (5): maximum ratio of change for the step + * - `maxIter` (1e4): maximum number of iterations + * + * The returned value is an object with `{t, y}` please note that even though `t` means time, it can represent any other independant variable like `x`: + * - `t` an array of size `[n]` + * - `y` the states array can be in two ways + * - **if `y0` is a scalar:** returns an array-like of size `[n]` + * - **if `y0` is a flat array-like of size [m]:** returns an array like of size `[n, m]` + * + * Syntax: + * + * math.solveODE(func, tspan, y0) + * math.solveODE(func, tspan, y0, options) + * + * Examples: + * + * function func(t, y) {return y} + * const tspan = [0, 4] + * const y0 = 1 + * math.solveODE(func, tspan, y0) + * math.solveODE(func, tspan, [1, 2]) + * math.solveODE(func, tspan, y0, { method:"RK23", maxStep:0.1 }) + * + * See also: + * + * derivative, simplifyCore + * + * @param {function} func The forcing function f(t,y) + * @param {Array | Matrix} tspan The time span + * @param {number | BigNumber | Unit | Array | Matrix} y0 The initial value + * @param {Object} [options] Optional configuration options + * @return {Object} Return an object with t and y values as arrays + */ + + function _rk(butcherTableau) { + // generates an adaptive runge kutta method from it's butcher tableau + + return function (f, tspan, y0, options) { + // adaptive runge kutta methods + var wrongTSpan = !(tspan.length === 2 && (tspan.every(isNumOrBig) || tspan.every(isUnit))); + if (wrongTSpan) { + throw new Error('"tspan" must be an Array of two numeric values or two units [tStart, tEnd]'); + } + var t0 = tspan[0]; // initial time + var tf = tspan[1]; // final time + var isForwards = larger(tf, t0); + var firstStep = options.firstStep; + if (firstStep !== undefined && !isPositive(firstStep)) { + throw new Error('"firstStep" must be positive'); + } + var maxStep = options.maxStep; + if (maxStep !== undefined && !isPositive(maxStep)) { + throw new Error('"maxStep" must be positive'); + } + var minStep = options.minStep; + if (minStep && isNegative(minStep)) { + throw new Error('"minStep" must be positive or zero'); + } + var timeVars = [t0, tf, firstStep, minStep, maxStep].filter(x => x !== undefined); + if (!(timeVars.every(isNumOrBig) || timeVars.every(isUnit))) { + throw new Error('Inconsistent type of "t" dependant variables'); + } + var steps = 1; // divide time in this number of steps + var tol = options.tol ? options.tol : 1e-4; // define a tolerance (must be an option) + var minDelta = options.minDelta ? options.minDelta : 0.2; + var maxDelta = options.maxDelta ? options.maxDelta : 5; + var maxIter = options.maxIter ? options.maxIter : 10000; // stop inifite evaluation if something goes wrong + var hasBigNumbers = [t0, tf, ...y0, maxStep, minStep].some(isBigNumber); + var [a, c, b, bp] = hasBigNumbers ? [bignumber(butcherTableau.a), bignumber(butcherTableau.c), bignumber(butcherTableau.b), bignumber(butcherTableau.bp)] : [butcherTableau.a, butcherTableau.c, butcherTableau.b, butcherTableau.bp]; + var h = firstStep ? isForwards ? firstStep : unaryMinus(firstStep) : divide(subtract(tf, t0), steps); // define the first step size + var t = [t0]; // start the time array + var y = [y0]; // start the solution array + + var deltaB = subtract(b, bp); // b - bp + + var n = 0; + var iter = 0; + var ongoing = _createOngoing(isForwards); + var trimStep = _createTrimStep(isForwards); + // iterate unitil it reaches either the final time or maximum iterations + while (ongoing(t[n], tf)) { + var k = []; + + // trim the time step so that it doesn't overshoot + h = trimStep(t[n], tf, h); + + // calculate the first value of k + k.push(f(t[n], y[n])); + + // calculate the rest of the values of k + for (var i = 1; i < c.length; ++i) { + k.push(f(add(t[n], multiply(c[i], h)), add(y[n], multiply(h, a[i], k)))); + } + + // estimate the error by comparing solutions of different orders + var TE = max(abs(map(multiply(deltaB, k), X => isUnit(X) ? X.value : X))); + if (TE < tol && tol / TE > 1 / 4) { + // push solution if within tol + t.push(add(t[n], h)); + y.push(add(y[n], multiply(h, b, k))); + n++; + } + + // estimate the delta value that will affect the step size + var delta = 0.84 * (tol / TE) ** (1 / 5); + if (smaller(delta, minDelta)) { + delta = minDelta; + } else if (larger(delta, maxDelta)) { + delta = maxDelta; + } + delta = hasBigNumbers ? bignumber(delta) : delta; + h = multiply(h, delta); + if (maxStep && larger(abs(h), maxStep)) { + h = isForwards ? maxStep : unaryMinus(maxStep); + } else if (minStep && smaller(abs(h), minStep)) { + h = isForwards ? minStep : unaryMinus(minStep); + } + iter++; + if (iter > maxIter) { + throw new Error('Maximum number of iterations reached, try changing options'); + } + } + return { + t, + y + }; + }; + } + function _rk23(f, tspan, y0, options) { + // Bogacki–Shampine method + + // Define the butcher table + var a = [[], [1 / 2], [0, 3 / 4], [2 / 9, 1 / 3, 4 / 9]]; + var c = [null, 1 / 2, 3 / 4, 1]; + var b = [2 / 9, 1 / 3, 4 / 9, 0]; + var bp = [7 / 24, 1 / 4, 1 / 3, 1 / 8]; + var butcherTableau = { + a, + c, + b, + bp + }; + + // Solve an adaptive step size rk method + return _rk(butcherTableau)(f, tspan, y0, options); + } + function _rk45(f, tspan, y0, options) { + // Dormand Prince method + + // Define the butcher tableau + var a = [[], [1 / 5], [3 / 40, 9 / 40], [44 / 45, -56 / 15, 32 / 9], [19372 / 6561, -25360 / 2187, 64448 / 6561, -212 / 729], [9017 / 3168, -355 / 33, 46732 / 5247, 49 / 176, -5103 / 18656], [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84]]; + var c = [null, 1 / 5, 3 / 10, 4 / 5, 8 / 9, 1, 1]; + var b = [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84, 0]; + var bp = [5179 / 57600, 0, 7571 / 16695, 393 / 640, -92097 / 339200, 187 / 2100, 1 / 40]; + var butcherTableau = { + a, + c, + b, + bp + }; + + // Solve an adaptive step size rk method + return _rk(butcherTableau)(f, tspan, y0, options); + } + function _solveODE(f, tspan, y0, opt) { + var method = opt.method ? opt.method : 'RK45'; + var methods = { + RK23: _rk23, + RK45: _rk45 + }; + if (method.toUpperCase() in methods) { + var methodOptions = _objectSpread({}, opt); // clone the options object + delete methodOptions.method; // delete the method as it won't be needed + return methods[method.toUpperCase()](f, tspan, y0, methodOptions); + } else { + // throw an error indicating there is no such method + var methodsWithQuotes = Object.keys(methods).map(x => "\"".concat(x, "\"")); + // generates a string of methods like: "BDF", "RK23" and "RK45" + var availableMethodsString = "".concat(methodsWithQuotes.slice(0, -1).join(', '), " and ").concat(methodsWithQuotes.slice(-1)); + throw new Error("Unavailable method \"".concat(method, "\". Available methods are ").concat(availableMethodsString)); + } + } + function _createOngoing(isForwards) { + // returns the correct function to test if it's still iterating + return isForwards ? smaller : larger; + } + function _createTrimStep(isForwards) { + var outOfBounds = isForwards ? larger : smaller; + return function (t, tf, h) { + var next = add(t, h); + return outOfBounds(next, tf) ? subtract(tf, t) : h; + }; + } + function isNumOrBig(x) { + // checks if it's a number or bignumber + return isBigNumber(x) || isNumber(x); + } + function _matrixSolveODE(f, T, y0, options) { + // receives matrices and returns matrices + var sol = _solveODE(f, T.toArray(), y0.toArray(), options); + return { + t: matrix(sol.t), + y: matrix(sol.y) + }; + } + return typed('solveODE', { + 'function, Array, Array, Object': _solveODE, + 'function, Matrix, Matrix, Object': _matrixSolveODE, + 'function, Array, Array': (f, T, y0) => _solveODE(f, T, y0, {}), + 'function, Matrix, Matrix': (f, T, y0) => _matrixSolveODE(f, T, y0, {}), + 'function, Array, number | BigNumber | Unit': (f, T, y0) => { + var sol = _solveODE(f, T, [y0], {}); + return { + t: sol.t, + y: sol.y.map(Y => Y[0]) + }; + }, + 'function, Matrix, number | BigNumber | Unit': (f, T, y0) => { + var sol = _solveODE(f, T.toArray(), [y0], {}); + return { + t: matrix(sol.t), + y: matrix(sol.y.map(Y => Y[0])) + }; + }, + 'function, Array, number | BigNumber | Unit, Object': (f, T, y0, options) => { + var sol = _solveODE(f, T, [y0], options); + return { + t: sol.t, + y: sol.y.map(Y => Y[0]) + }; + }, + 'function, Matrix, number | BigNumber | Unit, Object': (f, T, y0, options) => { + var sol = _solveODE(f, T.toArray(), [y0], options); + return { + t: matrix(sol.t), + y: matrix(sol.y.map(Y => Y[0])) + }; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinations.js new file mode 100644 index 0000000..cb3ac43 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinations.js @@ -0,0 +1,69 @@ +import { factory } from '../../utils/factory.js'; +import { combinationsNumber } from '../../plain/number/combinations.js'; +var name = 'combinations'; +var dependencies = ['typed']; +export var createCombinations = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the number of ways of picking `k` unordered outcomes from `n` + * possibilities. + * + * Combinations only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.combinations(n, k) + * + * Examples: + * + * math.combinations(7, 5) // returns 21 + * + * See also: + * + * combinationsWithRep, permutations, factorial + * + * @param {number | BigNumber} n Total number of objects in the set + * @param {number | BigNumber} k Number of objects in the subset + * @return {number | BigNumber} Number of possible combinations. + */ + return typed(name, { + 'number, number': combinationsNumber, + 'BigNumber, BigNumber': function BigNumber_BigNumber(n, k) { + var BigNumber = n.constructor; + var result, i; + var nMinusk = n.minus(k); + var one = new BigNumber(1); + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (k.gt(n)) { + throw new TypeError('k must be less than n in function combinations'); + } + result = one; + if (k.lt(nMinusk)) { + for (i = one; i.lte(nMinusk); i = i.plus(one)) { + result = result.times(k.plus(i)).dividedBy(i); + } + } else { + for (i = one; i.lte(k); i = i.plus(one)) { + result = result.times(nMinusk.plus(i)).dividedBy(i); + } + } + return result; + } + + // TODO: implement support for collection in combinations + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinationsWithRep.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinationsWithRep.js new file mode 100644 index 0000000..e6ab046 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/combinationsWithRep.js @@ -0,0 +1,84 @@ +import { factory } from '../../utils/factory.js'; +import { isInteger } from '../../utils/number.js'; +import { product } from '../../utils/product.js'; +var name = 'combinationsWithRep'; +var dependencies = ['typed']; +export var createCombinationsWithRep = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the number of ways of picking `k` unordered outcomes from `n` + * possibilities, allowing individual outcomes to be repeated more than once. + * + * CombinationsWithRep only takes integer arguments. + * The following condition must be enforced: k <= n + k -1. + * + * Syntax: + * + * math.combinationsWithRep(n, k) + * + * Examples: + * + * math.combinationsWithRep(7, 5) // returns 462 + * + * See also: + * + * combinations, permutations, factorial + * + * @param {number | BigNumber} n Total number of objects in the set + * @param {number | BigNumber} k Number of objects in the subset + * @return {number | BigNumber} Number of possible combinations with replacement. + */ + return typed(name, { + 'number, number': function number_number(n, k) { + if (!isInteger(n) || n < 0) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (!isInteger(k) || k < 0) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (n < 1) { + throw new TypeError('k must be less than or equal to n + k - 1'); + } + if (k < n - 1) { + var _prodrange = product(n, n + k - 1); + return _prodrange / product(1, k); + } + var prodrange = product(k + 1, n + k - 1); + return prodrange / product(1, n - 1); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(n, k) { + var BigNumber = n.constructor; + var result, i; + var one = new BigNumber(1); + var nMinusOne = n.minus(one); + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function combinationsWithRep'); + } + if (n.lt(one)) { + throw new TypeError('k must be less than or equal to n + k - 1 in function combinationsWithRep'); + } + result = one; + if (k.lt(nMinusOne)) { + for (i = one; i.lte(nMinusOne); i = i.plus(one)) { + result = result.times(k.plus(i)).dividedBy(i); + } + } else { + for (i = one; i.lte(k); i = i.plus(one)) { + result = result.times(nMinusOne.plus(i)).dividedBy(i); + } + } + return result; + } + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/factorial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/factorial.js new file mode 100644 index 0000000..3cfd21d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/factorial.js @@ -0,0 +1,47 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'factorial'; +var dependencies = ['typed', 'gamma']; +export var createFactorial = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + gamma + } = _ref; + /** + * Compute the factorial of a value + * + * Factorial only supports an integer value as argument. + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.factorial(n) + * + * Examples: + * + * math.factorial(5) // returns 120 + * math.factorial(3) // returns 6 + * + * See also: + * + * combinations, combinationsWithRep, gamma, permutations + * + * @param {number | BigNumber | Array | Matrix} n An integer number + * @return {number | BigNumber | Array | Matrix} The factorial of `n` + */ + return typed(name, { + number: function number(n) { + if (n < 0) { + throw new Error('Value must be non-negative'); + } + return gamma(n + 1); + }, + BigNumber: function BigNumber(n) { + if (n.isNegative()) { + throw new Error('Value must be non-negative'); + } + return gamma(n.plus(1)); + }, + 'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/gamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/gamma.js new file mode 100644 index 0000000..dce043b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/gamma.js @@ -0,0 +1,120 @@ +import { factory } from '../../utils/factory.js'; +import { gammaG, gammaNumber, gammaP } from '../../plain/number/index.js'; +var name = 'gamma'; +var dependencies = ['typed', 'config', 'multiplyScalar', 'pow', 'BigNumber', 'Complex']; +export var createGamma = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + multiplyScalar, + pow, + BigNumber: _BigNumber, + Complex + } = _ref; + /** + * Compute the gamma function of a value using Lanczos approximation for + * small values, and an extended Stirling approximation for large values. + * + * To avoid confusion with the matrix Gamma function, this function does + * not apply to matrices. + * + * Syntax: + * + * math.gamma(n) + * + * Examples: + * + * math.gamma(5) // returns 24 + * math.gamma(-0.5) // returns -3.5449077018110335 + * math.gamma(math.i) // returns -0.15494982830180973 - 0.49801566811835596i + * + * See also: + * + * combinations, factorial, permutations + * + * @param {number | BigNumber | Complex} n A real or complex number + * @return {number | BigNumber | Complex} The gamma of `n` + */ + + function gammaComplex(n) { + if (n.im === 0) { + return gammaNumber(n.re); + } + + // Lanczos approximation doesn't work well with real part lower than 0.5 + // So reflection formula is required + if (n.re < 0.5) { + // Euler's reflection formula + // gamma(1-z) * gamma(z) = PI / sin(PI * z) + // real part of Z should not be integer [sin(PI) == 0 -> 1/0 - undefined] + // thanks to imperfect sin implementation sin(PI * n) != 0 + // we can safely use it anyway + var _t = new Complex(1 - n.re, -n.im); + var r = new Complex(Math.PI * n.re, Math.PI * n.im); + return new Complex(Math.PI).div(r.sin()).div(gammaComplex(_t)); + } + + // Lanczos approximation + // z -= 1 + n = new Complex(n.re - 1, n.im); + + // x = gammaPval[0] + var x = new Complex(gammaP[0], 0); + // for (i, gammaPval) in enumerate(gammaP): + for (var i = 1; i < gammaP.length; ++i) { + // x += gammaPval / (z + i) + var gammaPval = new Complex(gammaP[i], 0); + x = x.add(gammaPval.div(n.add(i))); + } + // t = z + gammaG + 0.5 + var t = new Complex(n.re + gammaG + 0.5, n.im); + + // y = sqrt(2 * pi) * t ** (z + 0.5) * exp(-t) * x + var twoPiSqrt = Math.sqrt(2 * Math.PI); + var tpow = t.pow(n.add(0.5)); + var expt = t.neg().exp(); + + // y = [x] * [sqrt(2 * pi)] * [t ** (z + 0.5)] * [exp(-t)] + return x.mul(twoPiSqrt).mul(tpow).mul(expt); + } + return typed(name, { + number: gammaNumber, + Complex: gammaComplex, + BigNumber: function BigNumber(n) { + if (n.isInteger()) { + return n.isNegative() || n.isZero() ? new _BigNumber(Infinity) : bigFactorial(n.minus(1)); + } + if (!n.isFinite()) { + return new _BigNumber(n.isNegative() ? NaN : Infinity); + } + throw new Error('Integer BigNumber expected'); + } + }); + + /** + * Calculate factorial for a BigNumber + * @param {BigNumber} n + * @returns {BigNumber} Returns the factorial of n + */ + function bigFactorial(n) { + if (n < 8) { + return new _BigNumber([1, 1, 2, 6, 24, 120, 720, 5040][n]); + } + var precision = config.precision + (Math.log(n.toNumber()) | 0); + var Big = _BigNumber.clone({ + precision + }); + if (n % 2 === 1) { + return n.times(bigFactorial(new _BigNumber(n - 1))); + } + var p = n; + var prod = new Big(n); + var sum = n.toNumber(); + while (p > 2) { + p -= 2; + sum += p; + prod = prod.times(sum); + } + return new _BigNumber(prod.toPrecision(_BigNumber.precision)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/kldivergence.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/kldivergence.js new file mode 100644 index 0000000..ed4c4de --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/kldivergence.js @@ -0,0 +1,77 @@ +import { factory } from '../../utils/factory.js'; +var name = 'kldivergence'; +var dependencies = ['typed', 'matrix', 'divide', 'sum', 'multiply', 'map', 'dotDivide', 'log', 'isNumeric']; +export var createKldivergence = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + divide, + sum, + multiply, + map, + dotDivide, + log, + isNumeric + } = _ref; + /** + * Calculate the Kullback-Leibler (KL) divergence between two distributions + * + * Syntax: + * + * math.kldivergence(x, y) + * + * Examples: + * + * math.kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5]) //returns 0.24376698773121153 + * + * + * @param {Array | Matrix} q First vector + * @param {Array | Matrix} p Second vector + * @return {number} Returns distance between q and p + */ + return typed(name, { + 'Array, Array': function Array_Array(q, p) { + return _kldiv(matrix(q), matrix(p)); + }, + 'Matrix, Array': function Matrix_Array(q, p) { + return _kldiv(q, matrix(p)); + }, + 'Array, Matrix': function Array_Matrix(q, p) { + return _kldiv(matrix(q), p); + }, + 'Matrix, Matrix': function Matrix_Matrix(q, p) { + return _kldiv(q, p); + } + }); + function _kldiv(q, p) { + var plength = p.size().length; + var qlength = q.size().length; + if (plength > 1) { + throw new Error('first object must be one dimensional'); + } + if (qlength > 1) { + throw new Error('second object must be one dimensional'); + } + if (plength !== qlength) { + throw new Error('Length of two vectors must be equal'); + } + + // Before calculation, apply normalization + var sumq = sum(q); + if (sumq === 0) { + throw new Error('Sum of elements in first object must be non zero'); + } + var sump = sum(p); + if (sump === 0) { + throw new Error('Sum of elements in second object must be non zero'); + } + var qnorm = divide(q, sum(q)); + var pnorm = divide(p, sum(p)); + var result = sum(multiply(qnorm, map(dotDivide(qnorm, pnorm), x => log(x)))); + if (isNumeric(result)) { + return result; + } else { + return Number.NaN; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/lgamma.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/lgamma.js new file mode 100644 index 0000000..4d45914 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/lgamma.js @@ -0,0 +1,137 @@ +/* eslint-disable no-loss-of-precision */ + +// References +// ---------- +// [1] Hare, "Computing the Principal Branch of log-Gamma", Journal of Algorithms, 1997. +// [2] https://math.stackexchange.com/questions/1338753/how-do-i-calculate-values-for-gamma-function-with-complex-arguments + +import { lgammaNumber, lnSqrt2PI } from '../../plain/number/index.js'; +import { factory } from '../../utils/factory.js'; +import { copysign } from '../../utils/number.js'; +var name = 'lgamma'; +var dependencies = ['Complex', 'typed']; +export var createLgamma = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Complex, + typed + } = _ref; + // Stirling series is non-convergent, we need to use the recurrence `lgamma(z) = lgamma(z+1) - log z` to get + // sufficient accuracy. + // + // These two values are copied from Scipy implementation: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L37 + var SMALL_RE = 7; + var SMALL_IM = 7; + + /** + * The coefficients are B[2*n]/(2*n*(2*n - 1)) where B[2*n] is the (2*n)th Bernoulli number. See (1.1) in [1]. + * + * If you cannot access the paper, can also get these values from the formula in [2]. + * + * 1 / 12 = 0.00833333333333333333333333333333 + * 1 / 360 = 0.00277777777777777777777777777778 + * ... + * 3617 / 133400 = 0.02955065359477124183006535947712 + */ + var coeffs = [-2.955065359477124183e-2, 6.4102564102564102564e-3, -1.9175269175269175269e-3, 8.4175084175084175084e-4, -5.952380952380952381e-4, 7.9365079365079365079e-4, -2.7777777777777777778e-3, 8.3333333333333333333e-2]; + + /** + * Logarithm of the gamma function for real, positive numbers and complex numbers, + * using Lanczos approximation for numbers and Stirling series for complex numbers. + * + * Syntax: + * + * math.lgamma(n) + * + * Examples: + * + * math.lgamma(5) // returns 3.178053830347945 + * math.lgamma(0) // returns Infinity + * math.lgamma(-0.5) // returns NaN + * math.lgamma(math.i) // returns -0.6509231993018536 - 1.8724366472624294i + * + * See also: + * + * gamma + * + * @param {number | Complex} n A real or complex number + * @return {number | Complex} The log gamma of `n` + */ + return typed(name, { + number: lgammaNumber, + Complex: lgammaComplex, + BigNumber: function BigNumber() { + throw new Error("mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber"); + } + }); + function lgammaComplex(n) { + var TWOPI = 6.2831853071795864769252842; // 2*pi + var LOGPI = 1.1447298858494001741434262; // log(pi) + + var REFLECTION = 0.1; + if (n.isNaN()) { + return new Complex(NaN, NaN); + } else if (n.im === 0) { + return new Complex(lgammaNumber(n.re), 0); + } else if (n.re >= SMALL_RE || Math.abs(n.im) >= SMALL_IM) { + return lgammaStirling(n); + } else if (n.re <= REFLECTION) { + // Reflection formula. see Proposition 3.1 in [1] + var tmp = copysign(TWOPI, n.im) * Math.floor(0.5 * n.re + 0.25); + var a = n.mul(Math.PI).sin().log(); + var b = lgammaComplex(new Complex(1 - n.re, -n.im)); + return new Complex(LOGPI, tmp).sub(a).sub(b); + } else if (n.im >= 0) { + return lgammaRecurrence(n); + } else { + return lgammaRecurrence(n.conjugate()).conjugate(); + } + } + function lgammaStirling(z) { + // formula ref in [2] + // computation ref: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L101 + + // left part + + // x (log(x) - 1) + 1/2 (log(2PI) - log(x)) + // => (x - 0.5) * log(x) - x + log(2PI) / 2 + var leftPart = z.sub(0.5).mul(z.log()).sub(z).add(lnSqrt2PI); + + // right part + + var rz = new Complex(1, 0).div(z); + var rzz = rz.div(z); + var a = coeffs[0]; + var b = coeffs[1]; + var r = 2 * rzz.re; + var s = rzz.re * rzz.re + rzz.im * rzz.im; + for (var i = 2; i < 8; i++) { + var tmp = b; + b = -s * a + coeffs[i]; + a = r * a + tmp; + } + var rightPart = rz.mul(rzz.mul(a).add(b)); + + // plus left and right + + return leftPart.add(rightPart); + } + function lgammaRecurrence(z) { + // computation ref: + // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L78 + + var signflips = 0; + var sb = 0; + var shiftprod = z; + z = z.add(1); + while (z.re <= SMALL_RE) { + shiftprod = shiftprod.mul(z); + var nsb = shiftprod.im < 0 ? 1 : 0; + if (nsb !== 0 && sb === 0) signflips++; + sb = nsb; + z = z.add(1); + } + return lgammaStirling(z).sub(shiftprod.log()).sub(new Complex(0, signflips * 2 * Math.PI * 1)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/multinomial.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/multinomial.js new file mode 100644 index 0000000..76f2ae5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/multinomial.js @@ -0,0 +1,50 @@ +import { deepForEach } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'multinomial'; +var dependencies = ['typed', 'add', 'divide', 'multiply', 'factorial', 'isInteger', 'isPositive']; +export var createMultinomial = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + divide, + multiply, + factorial, + isInteger, + isPositive + } = _ref; + /** + * Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. + * + * multinomial takes one array of integers as an argument. + * The following condition must be enforced: every ai <= 0 + * + * Syntax: + * + * math.multinomial(a) // a is an array type + * + * Examples: + * + * math.multinomial([1,2,1]) // returns 12 + * + * See also: + * + * combinations, factorial + * + * @param {number[] | BigNumber[]} a Integer numbers of objects in the subset + * @return {Number | BigNumber} Multinomial coefficient. + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(a) { + var sum = 0; + var denom = 1; + deepForEach(a, function (ai) { + if (!isInteger(ai) || !isPositive(ai)) { + throw new TypeError('Positive integer value expected in function multinomial'); + } + sum = add(sum, ai); + denom = multiply(denom, factorial(ai)); + }); + return divide(factorial(sum), denom); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/permutations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/permutations.js new file mode 100644 index 0000000..8373396 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/permutations.js @@ -0,0 +1,78 @@ +import { isInteger } from '../../utils/number.js'; +import { product } from '../../utils/product.js'; +import { factory } from '../../utils/factory.js'; +var name = 'permutations'; +var dependencies = ['typed', 'factorial']; +export var createPermutations = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + factorial + } = _ref; + /** + * Compute the number of ways of obtaining an ordered subset of `k` elements + * from a set of `n` elements. + * + * Permutations only takes integer arguments. + * The following condition must be enforced: k <= n. + * + * Syntax: + * + * math.permutations(n) + * math.permutations(n, k) + * + * Examples: + * + * math.permutations(5) // 120 + * math.permutations(5, 3) // 60 + * + * See also: + * + * combinations, combinationsWithRep, factorial + * + * @param {number | BigNumber} n The number of objects in total + * @param {number | BigNumber} [k] The number of objects in the subset + * @return {number | BigNumber} The number of permutations + */ + return typed(name, { + 'number | BigNumber': factorial, + 'number, number': function number_number(n, k) { + if (!isInteger(n) || n < 0) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (!isInteger(k) || k < 0) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (k > n) { + throw new TypeError('second argument k must be less than or equal to first argument n'); + } + // Permute n objects, k at a time + return product(n - k + 1, n); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(n, k) { + var result, i; + if (!isPositiveInteger(n) || !isPositiveInteger(k)) { + throw new TypeError('Positive integer value expected in function permutations'); + } + if (k.gt(n)) { + throw new TypeError('second argument k must be less than or equal to first argument n'); + } + var one = n.mul(0).add(1); + result = one; + for (i = n.minus(k).plus(1); i.lte(n); i = i.plus(1)) { + result = result.times(i); + } + return result; + } + + // TODO: implement support for collection in permutations + }); +}); + +/** + * Test whether BigNumber n is a positive integer + * @param {BigNumber} n + * @returns {boolean} isPositiveInteger + */ +function isPositiveInteger(n) { + return n.isInteger() && n.gte(0); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/pickRandom.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/pickRandom.js new file mode 100644 index 0000000..b11c95c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/pickRandom.js @@ -0,0 +1,150 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { isMatrix, isNumber } from '../../utils/is.js'; +import { createRng } from './util/seededRNG.js'; +var name = 'pickRandom'; +var dependencies = ['typed', 'config', '?on']; +export var createPickRandom = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + var rng = createRng(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = createRng(curr.randomSeed); + } + }); + } + + /** + * Random pick one or more values from a one dimensional array. + * Array elements are picked using a random function with uniform or weighted distribution. + * + * Syntax: + * + * math.pickRandom(array) + * math.pickRandom(array, number) + * math.pickRandom(array, weights) + * math.pickRandom(array, number, weights) + * math.pickRandom(array, weights, number) + * math.pickRandom(array, { weights, number, elementWise }) + * + * Examples: + * + * math.pickRandom([3, 6, 12, 2]) // returns one of the values in the array + * math.pickRandom([3, 6, 12, 2], 2) // returns an array of two of the values in the array + * math.pickRandom([3, 6, 12, 2], { number: 2 }) // returns an array of two of the values in the array + * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1]) // returns one of the values in the array with weighted distribution + * math.pickRandom([3, 6, 12, 2], 2, [1, 3, 2, 1]) // returns an array of two of the values in the array with weighted distribution + * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1], 2) // returns an array of two of the values in the array with weighted distribution + * + * math.pickRandom([{x: 1.0, y: 2.0}, {x: 1.1, y: 2.0}], { elementWise: false }) + * // returns one of the items in the array + * + * See also: + * + * random, randomInt + * + * @param {Array | Matrix} array A one dimensional array + * @param {Int} number An int or float + * @param {Array | Matrix} weights An array of ints or floats + * @return {number | Array} Returns a single random value from array when number is undefined. + * Returns an array with the configured number of elements when number is defined. + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(possibles) { + return _pickRandom(possibles, {}); + }, + 'Array | Matrix, Object': function Array__Matrix_Object(possibles, options) { + return _pickRandom(possibles, options); + }, + 'Array | Matrix, number': function Array__Matrix_number(possibles, number) { + return _pickRandom(possibles, { + number + }); + }, + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(possibles, weights) { + return _pickRandom(possibles, { + weights + }); + }, + 'Array | Matrix, Array | Matrix, number': function Array__Matrix_Array__Matrix_number(possibles, weights, number) { + return _pickRandom(possibles, { + number, + weights + }); + }, + 'Array | Matrix, number, Array | Matrix': function Array__Matrix_number_Array__Matrix(possibles, number, weights) { + return _pickRandom(possibles, { + number, + weights + }); + } + }); + + /** + * @param {Array | Matrix} possibles + * @param {{ + * number?: number, + * weights?: Array | Matrix, + * elementWise: boolean + * }} options + * @returns {number | Array} + * @private + */ + function _pickRandom(possibles, _ref2) { + var { + number, + weights, + elementWise = true + } = _ref2; + var single = typeof number === 'undefined'; + if (single) { + number = 1; + } + var createMatrix = isMatrix(possibles) ? possibles.create : isMatrix(weights) ? weights.create : null; + possibles = possibles.valueOf(); // get Array + if (weights) { + weights = weights.valueOf(); // get Array + } + if (elementWise === true) { + possibles = flatten(possibles); + weights = flatten(weights); + } + var totalWeights = 0; + if (typeof weights !== 'undefined') { + if (weights.length !== possibles.length) { + throw new Error('Weights must have the same length as possibles'); + } + for (var i = 0, len = weights.length; i < len; i++) { + if (!isNumber(weights[i]) || weights[i] < 0) { + throw new Error('Weights must be an array of positive numbers'); + } + totalWeights += weights[i]; + } + } + var length = possibles.length; + var result = []; + var pick; + while (result.length < number) { + if (typeof weights === 'undefined') { + pick = possibles[Math.floor(rng() * length)]; + } else { + var randKey = rng() * totalWeights; + for (var _i = 0, _len = possibles.length; _i < _len; _i++) { + randKey -= weights[_i]; + if (randKey < 0) { + pick = possibles[_i]; + break; + } + } + } + result.push(pick); + } + return single ? result[0] : createMatrix ? createMatrix(result) : result; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/random.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/random.js new file mode 100644 index 0000000..dc2b5ff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/random.js @@ -0,0 +1,96 @@ +import { factory } from '../../utils/factory.js'; +import { isMatrix } from '../../utils/is.js'; +import { createRng } from './util/seededRNG.js'; +import { randomMatrix } from './util/randomMatrix.js'; +var name = 'random'; +var dependencies = ['typed', 'config', '?on']; +export var createRandom = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + var rng = createRng(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = createRng(curr.randomSeed); + } + }); + } + + /** + * Return a random number larger or equal to `min` and smaller than `max` + * using a uniform distribution. + * + * Syntax: + * + * math.random() // generate a random number between 0 and 1 + * math.random(max) // generate a random number between 0 and max + * math.random(min, max) // generate a random number between min and max + * math.random(size) // generate a matrix with random numbers between 0 and 1 + * math.random(size, max) // generate a matrix with random numbers between 0 and max + * math.random(size, min, max) // generate a matrix with random numbers between min and max + * + * Examples: + * + * math.random() // returns a random number between 0 and 1 + * math.random(100) // returns a random number between 0 and 100 + * math.random(30, 40) // returns a random number between 30 and 40 + * math.random([2, 3]) // returns a 2x3 matrix with random numbers between 0 and 1 + * + * See also: + * + * randomInt, pickRandom + * + * @param {Array | Matrix} [size] If provided, an array or matrix with given + * size and filled with random values is returned + * @param {number} [min] Minimum boundary for the random value, included + * @param {number} [max] Maximum boundary for the random value, excluded + * @return {number | Array | Matrix} A random number + */ + return typed(name, { + '': () => _random(0, 1), + number: max => _random(0, max), + 'number, number': (min, max) => _random(min, max), + 'Array | Matrix': size => _randomMatrix(size, 0, 1), + 'Array | Matrix, number': (size, max) => _randomMatrix(size, 0, max), + 'Array | Matrix, number, number': (size, min, max) => _randomMatrix(size, min, max) + }); + function _randomMatrix(size, min, max) { + var res = randomMatrix(size.valueOf(), () => _random(min, max)); + return isMatrix(size) ? size.create(res, 'number') : res; + } + function _random(min, max) { + return min + rng() * (max - min); + } +}); + +// number only implementation of random, no matrix support +// TODO: there is quite some duplicate code in both createRandom and createRandomNumber, can we improve that? +export var createRandomNumber = /* #__PURE__ */factory(name, ['typed', 'config', '?on'], _ref2 => { + var { + typed, + config, + on, + matrix + } = _ref2; + // seeded pseudo random number generator1 + var rng = createRng(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = createRng(curr.randomSeed); + } + }); + } + return typed(name, { + '': () => _random(0, 1), + number: max => _random(0, max), + 'number, number': (min, max) => _random(min, max) + }); + function _random(min, max) { + return min + rng() * (max - min); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/randomInt.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/randomInt.js new file mode 100644 index 0000000..7e83618 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/randomInt.js @@ -0,0 +1,67 @@ +import { factory } from '../../utils/factory.js'; +import { randomMatrix } from './util/randomMatrix.js'; +import { createRng } from './util/seededRNG.js'; +import { isMatrix } from '../../utils/is.js'; +var name = 'randomInt'; +var dependencies = ['typed', 'config', '?on']; +export var createRandomInt = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + on + } = _ref; + // seeded pseudo random number generator + var rng = createRng(config.randomSeed); + if (on) { + on('config', function (curr, prev) { + if (curr.randomSeed !== prev.randomSeed) { + rng = createRng(curr.randomSeed); + } + }); + } + + /** + * Return a random integer number larger or equal to `min` and smaller than `max` + * using a uniform distribution. + * + * Syntax: + * + * math.randomInt() // generate a random integer between 0 and 1 + * math.randomInt(max) // generate a random integer between 0 and max + * math.randomInt(min, max) // generate a random integer between min and max + * math.randomInt(size) // generate a matrix with random integer between 0 and 1 + * math.randomInt(size, max) // generate a matrix with random integer between 0 and max + * math.randomInt(size, min, max) // generate a matrix with random integer between min and max + * + * Examples: + * + * math.randomInt(100) // returns a random integer between 0 and 100 + * math.randomInt(30, 40) // returns a random integer between 30 and 40 + * math.randomInt([2, 3]) // returns a 2x3 matrix with random integers between 0 and 1 + * + * See also: + * + * random, pickRandom + * + * @param {Array | Matrix} [size] If provided, an array or matrix with given + * size and filled with random values is returned + * @param {number} [min] Minimum boundary for the random value, included + * @param {number} [max] Maximum boundary for the random value, excluded + * @return {number | Array | Matrix} A random integer value + */ + return typed(name, { + '': () => _randomInt(0, 1), + number: max => _randomInt(0, max), + 'number, number': (min, max) => _randomInt(min, max), + 'Array | Matrix': size => _randomIntMatrix(size, 0, 1), + 'Array | Matrix, number': (size, max) => _randomIntMatrix(size, 0, max), + 'Array | Matrix, number, number': (size, min, max) => _randomIntMatrix(size, min, max) + }); + function _randomIntMatrix(size, min, max) { + var res = randomMatrix(size.valueOf(), () => _randomInt(min, max)); + return isMatrix(size) ? size.create(res, 'number') : res; + } + function _randomInt(min, max) { + return Math.floor(min + rng() * (max - min)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/randomMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/randomMatrix.js new file mode 100644 index 0000000..385f991 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/randomMatrix.js @@ -0,0 +1,20 @@ +/** + * This is a util function for generating a random matrix recursively. + * @param {number[]} size + * @param {function} random + * @returns {Array} + */ +export function randomMatrix(size, random) { + var data = []; + size = size.slice(0); + if (size.length > 1) { + for (var i = 0, length = size.shift(); i < length; i++) { + data.push(randomMatrix(size, random)); + } + } else { + for (var _i = 0, _length = size.shift(); _i < _length; _i++) { + data.push(random()); + } + } + return data; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/seededRNG.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/seededRNG.js new file mode 100644 index 0000000..9da3f78 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/probability/util/seededRNG.js @@ -0,0 +1,19 @@ +import seedrandom from 'seedrandom'; +var singletonRandom = /* #__PURE__ */seedrandom(Date.now()); +export function createRng(randomSeed) { + var random; + + // create a new random generator with given seed + function setSeed(seed) { + random = seed === null ? singletonRandom : seedrandom(String(seed)); + } + + // initialize a seeded pseudo random number generator with config's random seed + setSeed(randomSeed); + + // wrapper function so the rng can be updated via generator + function rng() { + return random(); + } + return rng; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compare.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compare.js new file mode 100644 index 0000000..f579a8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compare.js @@ -0,0 +1,114 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'compare'; +var dependencies = ['typed', 'config', 'matrix', 'equalScalar', 'BigNumber', 'Fraction', 'DenseMatrix', 'concat']; +export var createCompare = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + equalScalar, + matrix, + BigNumber, + Fraction, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo05xSfSf = createMatAlgo05xSfSf({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y. + * + * x and y are considered equal when the relative difference between x and y + * is smaller than the configured absTol and relTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.compare(x, y) + * + * Examples: + * + * math.compare(6, 1) // returns 1 + * math.compare(2, 3) // returns -1 + * math.compare(7, 7) // returns 0 + * math.compare('10', '2') // returns 1 + * math.compare('1000', '1e3') // returns 0 + * + * const a = math.unit('5 cm') + * const b = math.unit('40 mm') + * math.compare(a, b) // returns 1 + * + * math.compare(2, [1, 2, 3]) // returns [1, 0, -1] + * + * See also: + * + * equal, unequal, smaller, smallerEq, larger, largerEq, compareNatural, compareText + * + * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} y Second value to compare + * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, createCompareNumber({ + typed, + config + }), { + 'boolean, boolean': function boolean_boolean(x, y) { + return x === y ? 0 : x > y ? 1 : -1; + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return bigNearlyEqual(x, y, config.relTol, config.absTol) ? new BigNumber(0) : new BigNumber(x.cmp(y)); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x === y ? 0n : x > y ? 1n : -1n; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return new Fraction(x.compare(y)); + }, + 'Complex, Complex': function Complex_Complex() { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo05xSfSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createCompareNumber = /* #__PURE__ */factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return nearlyEqual(x, y, config.relTol, config.absTol) ? 0 : x > y ? 1 : -1; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareNatural.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareNatural.js new file mode 100644 index 0000000..04394fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareNatural.js @@ -0,0 +1,274 @@ +import naturalSort from 'javascript-natural-sort'; +import { isDenseMatrix, isSparseMatrix, typeOf } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'compareNatural'; +var dependencies = ['typed', 'compare']; +export var createCompareNatural = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + compare + } = _ref; + var compareBooleans = compare.signatures['boolean,boolean']; + + /** + * Compare two values of any type in a deterministic, natural way. + * + * For numeric values, the function works the same as `math.compare`. + * For types of values that can't be compared mathematically, + * the function compares in a natural way. + * + * For numeric values, x and y are considered equal when the relative + * difference between x and y is smaller than the configured relTol and absTol. + * The function cannot be used to compare values smaller than + * approximately 2.22e-16. + * + * For Complex numbers, first the real parts are compared. If equal, + * the imaginary parts are compared. + * + * Strings are compared with a natural sorting algorithm, which + * orders strings in a "logic" way following some heuristics. + * This differs from the function `compare`, which converts the string + * into a numeric value and compares that. The function `compareText` + * on the other hand compares text lexically. + * + * Arrays and Matrices are compared value by value until there is an + * unequal pair of values encountered. Objects are compared by sorted + * keys until the keys or their values are unequal. + * + * Syntax: + * + * math.compareNatural(x, y) + * + * Examples: + * + * math.compareNatural(6, 1) // returns 1 + * math.compareNatural(2, 3) // returns -1 + * math.compareNatural(7, 7) // returns 0 + * + * math.compareNatural('10', '2') // returns 1 + * math.compareText('10', '2') // returns -1 + * math.compare('10', '2') // returns 1 + * + * math.compareNatural('Answer: 10', 'Answer: 2') // returns 1 + * math.compareText('Answer: 10', 'Answer: 2') // returns -1 + * math.compare('Answer: 10', 'Answer: 2') + * // Error: Cannot convert "Answer: 10" to a number + * + * const a = math.unit('5 cm') + * const b = math.unit('40 mm') + * math.compareNatural(a, b) // returns 1 + * + * const c = math.complex('2 + 3i') + * const d = math.complex('2 + 4i') + * math.compareNatural(c, d) // returns -1 + * + * math.compareNatural([1, 2, 4], [1, 2, 3]) // returns 1 + * math.compareNatural([1, 2, 3], [1, 2]) // returns 1 + * math.compareNatural([1, 5], [1, 2, 3]) // returns 1 + * math.compareNatural([1, 2], [1, 2]) // returns 0 + * + * math.compareNatural({a: 2}, {a: 4}) // returns -1 + * + * See also: + * + * compare, compareText + * + * @param {*} x First value to compare + * @param {*} y Second value to compare + * @return {number} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, { + 'any, any': _compareNatural + }); // just to check # args + + function _compareNatural(x, y) { + var typeX = typeOf(x); + var typeY = typeOf(y); + var c; + + // numeric types + if ((typeX === 'number' || typeX === 'BigNumber' || typeX === 'Fraction') && (typeY === 'number' || typeY === 'BigNumber' || typeY === 'Fraction')) { + c = compare(x, y); + if (c.toString() !== '0') { + // c can be number, BigNumber, or Fraction + return c > 0 ? 1 : -1; // return a number + } else { + return naturalSort(typeX, typeY); + } + } + + // matrix types + var matTypes = ['Array', 'DenseMatrix', 'SparseMatrix']; + if (matTypes.includes(typeX) || matTypes.includes(typeY)) { + c = compareMatricesAndArrays(_compareNatural, x, y); + if (c !== 0) { + return c; + } else { + return naturalSort(typeX, typeY); + } + } + + // in case of different types, order by name of type, i.e. 'BigNumber' < 'Complex' + if (typeX !== typeY) { + return naturalSort(typeX, typeY); + } + if (typeX === 'Complex') { + return compareComplexNumbers(x, y); + } + if (typeX === 'Unit') { + if (x.equalBase(y)) { + return _compareNatural(x.value, y.value); + } + + // compare by units + return compareArrays(_compareNatural, x.formatUnits(), y.formatUnits()); + } + if (typeX === 'boolean') { + return compareBooleans(x, y); + } + if (typeX === 'string') { + return naturalSort(x, y); + } + if (typeX === 'Object') { + return compareObjects(_compareNatural, x, y); + } + if (typeX === 'null') { + return 0; + } + if (typeX === 'undefined') { + return 0; + } + + // this should not occur... + throw new TypeError('Unsupported type of value "' + typeX + '"'); + } + + /** + * Compare mixed matrix/array types, by converting to same-shaped array. + * This comparator is non-deterministic regarding input types. + * @param {Array | SparseMatrix | DenseMatrix | *} x + * @param {Array | SparseMatrix | DenseMatrix | *} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareMatricesAndArrays(compareNatural, x, y) { + if (isSparseMatrix(x) && isSparseMatrix(y)) { + return compareArrays(compareNatural, x.toJSON().values, y.toJSON().values); + } + if (isSparseMatrix(x)) { + // note: convert to array is expensive + return compareMatricesAndArrays(compareNatural, x.toArray(), y); + } + if (isSparseMatrix(y)) { + // note: convert to array is expensive + return compareMatricesAndArrays(compareNatural, x, y.toArray()); + } + + // convert DenseArray into Array + if (isDenseMatrix(x)) { + return compareMatricesAndArrays(compareNatural, x.toJSON().data, y); + } + if (isDenseMatrix(y)) { + return compareMatricesAndArrays(compareNatural, x, y.toJSON().data); + } + + // convert scalars to array + if (!Array.isArray(x)) { + return compareMatricesAndArrays(compareNatural, [x], y); + } + if (!Array.isArray(y)) { + return compareMatricesAndArrays(compareNatural, x, [y]); + } + return compareArrays(compareNatural, x, y); + } + + /** + * Compare two Arrays + * + * - First, compares value by value + * - Next, if all corresponding values are equal, + * look at the length: longest array will be considered largest + * + * @param {Array} x + * @param {Array} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareArrays(compareNatural, x, y) { + // compare each value + for (var i = 0, ii = Math.min(x.length, y.length); i < ii; i++) { + var v = compareNatural(x[i], y[i]); + if (v !== 0) { + return v; + } + } + + // compare the size of the arrays + if (x.length > y.length) { + return 1; + } + if (x.length < y.length) { + return -1; + } + + // both Arrays have equal size and content + return 0; + } + + /** + * Compare two objects + * + * - First, compare sorted property names + * - Next, compare the property values + * + * @param {Object} x + * @param {Object} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + function compareObjects(compareNatural, x, y) { + var keysX = Object.keys(x); + var keysY = Object.keys(y); + + // compare keys + keysX.sort(naturalSort); + keysY.sort(naturalSort); + var c = compareArrays(compareNatural, keysX, keysY); + if (c !== 0) { + return c; + } + + // compare values + for (var i = 0; i < keysX.length; i++) { + var v = compareNatural(x[keysX[i]], y[keysY[i]]); + if (v !== 0) { + return v; + } + } + return 0; + } +}); + +/** + * Compare two complex numbers, `x` and `y`: + * + * - First, compare the real values of `x` and `y` + * - If equal, compare the imaginary values of `x` and `y` + * + * @params {Complex} x + * @params {Complex} y + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ +function compareComplexNumbers(x, y) { + if (x.re > y.re) { + return 1; + } + if (x.re < y.re) { + return -1; + } + if (x.im > y.im) { + return 1; + } + if (x.im < y.im) { + return -1; + } + return 0; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareText.js new file mode 100644 index 0000000..4f25378 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareText.js @@ -0,0 +1,57 @@ +import { compareText as _compareText } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'compareText'; +var dependencies = ['typed', 'matrix', 'concat']; +_compareText.signature = 'any, any'; +export var createCompareText = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + concat + } = _ref; + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Compare two strings lexically. Comparison is case sensitive. + * Returns 1 when x > y, -1 when x < y, and 0 when x == y. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.compareText(x, y) + * + * Examples: + * + * math.compareText('B', 'A') // returns 1 + * math.compareText('2', '10') // returns 1 + * math.compare('2', '10') // returns -1 + * math.compareNatural('2', '10') // returns -1 + * + * math.compareText('B', ['A', 'B', 'C']) // returns [1, 0, -1] + * + * See also: + * + * equal, equalText, compare, compareNatural + * + * @param {string | Array | DenseMatrix} x First string to compare + * @param {string | Array | DenseMatrix} y Second string to compare + * @return {number | Array | DenseMatrix} Returns the result of the comparison: + * 1 when x > y, -1 when x < y, and 0 when x == y. + */ + return typed(name, _compareText, matrixAlgorithmSuite({ + elop: _compareText, + Ds: true + })); +}); +export var createCompareTextNumber = /* #__PURE__ */factory(name, ['typed'], _ref2 => { + var { + typed + } = _ref2; + return typed(name, _compareText); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareUnits.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareUnits.js new file mode 100644 index 0000000..b3f2dda --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/compareUnits.js @@ -0,0 +1,14 @@ +import { factory } from '../../utils/factory.js'; +export var createCompareUnits = /* #__PURE__ */factory('compareUnits', ['typed'], _ref => { + var { + typed + } = _ref; + return { + 'Unit, Unit': typed.referToSelf(self => (x, y) => { + if (!x.equalBase(y)) { + throw new Error('Cannot compare units with different base'); + } + return typed.find(self, [x.valueType(), y.valueType()])(x.value, y.value); + }) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/deepEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/deepEqual.js new file mode 100644 index 0000000..36f1db1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/deepEqual.js @@ -0,0 +1,74 @@ +import { factory } from '../../utils/factory.js'; +var name = 'deepEqual'; +var dependencies = ['typed', 'equal']; +export var createDeepEqual = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equal + } = _ref; + /** + * Test element wise whether two matrices are equal. + * The function accepts both matrices and scalar values. + * + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.deepEqual(x, y) + * + * Examples: + * + * math.deepEqual(2, 4) // returns false + * + * a = [2, 5, 1] + * b = [2, 7, 1] + * + * math.deepEqual(a, b) // returns false + * math.equal(a, b) // returns [true, false, true] + * + * See also: + * + * equal, unequal + * + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First matrix to compare + * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second matrix to compare + * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} + * Returns true when the input matrices have the same size and each of their elements is equal. + */ + return typed(name, { + 'any, any': function any_any(x, y) { + return _deepEqual(x.valueOf(), y.valueOf()); + } + }); + + /** + * Test whether two arrays have the same size and all elements are equal + * @param {Array | *} x + * @param {Array | *} y + * @return {boolean} Returns true if both arrays are deep equal + */ + function _deepEqual(x, y) { + if (Array.isArray(x)) { + if (Array.isArray(y)) { + var len = x.length; + if (len !== y.length) { + return false; + } + for (var i = 0; i < len; i++) { + if (!_deepEqual(x[i], y[i])) { + return false; + } + } + return true; + } else { + return false; + } + } else { + if (Array.isArray(y)) { + return false; + } else { + return equal(x, y); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equal.js new file mode 100644 index 0000000..f0b7211 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equal.js @@ -0,0 +1,110 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'equal'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']; +export var createEqual = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Test whether two values are equal. + * + * The function tests whether the relative difference between x and y is + * smaller than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * In case of complex numbers, x.re must equal y.re, and x.im must equal y.im. + * + * Values `null` and `undefined` are compared strictly, thus `null` is only + * equal to `null` and nothing else, and `undefined` is only equal to + * `undefined` and nothing else. Strings are compared by their numerical value. + * + * Syntax: + * + * math.equal(x, y) + * + * Examples: + * + * math.equal(2 + 2, 3) // returns false + * math.equal(2 + 2, 4) // returns true + * + * const a = math.unit('50 cm') + * const b = math.unit('5 m') + * math.equal(a, b) // returns true + * + * const c = [2, 5, 1] + * const d = [2, 7, 1] + * + * math.equal(c, d) // returns [true, false, true] + * math.deepEqual(c, d) // returns false + * + * math.equal("1000", "1e3") // returns true + * math.equal(0, null) // returns false + * + * See also: + * + * unequal, smaller, smallerEq, larger, largerEq, compare, deepEqual, equalText + * + * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | boolean | Complex | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the compared values are equal, else returns false + */ + return typed(name, createEqualNumber({ + typed, + equalScalar + }), matrixAlgorithmSuite({ + elop: equalScalar, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createEqualNumber = factory(name, ['typed', 'equalScalar'], _ref2 => { + var { + typed, + equalScalar + } = _ref2; + return typed(name, { + 'any, any': function any_any(x, y) { + // strict equality for null and undefined? + if (x === null) { + return y === null; + } + if (y === null) { + return x === null; + } + if (x === undefined) { + return y === undefined; + } + if (y === undefined) { + return x === undefined; + } + return equalScalar(x, y); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalScalar.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalScalar.js new file mode 100644 index 0000000..4d545d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalScalar.js @@ -0,0 +1,56 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { complexEquals } from '../../utils/complex.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'equalScalar'; +var dependencies = ['typed', 'config']; +export var createEqualScalar = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config + } = _ref; + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Test whether two scalar values are nearly equal. + * + * @param {number | BigNumber | bigint | Fraction | boolean | Complex | Unit} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Complex} y Second value to compare + * @return {boolean} Returns true when the compared values are equal, else returns false + * @private + */ + return typed(name, { + 'boolean, boolean': function boolean_boolean(x, y) { + return x === y; + }, + 'number, number': function number_number(x, y) { + return nearlyEqual(x, y, config.relTol, config.absTol); + }, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.eq(y) || bigNearlyEqual(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x === y; + }, + 'Fraction, Fraction': function Fraction_Fraction(x, y) { + return x.equals(y); + }, + 'Complex, Complex': function Complex_Complex(x, y) { + return complexEquals(x, y, config.relTol, config.absTol); + } + }, compareUnits); +}); +export var createEqualScalarNumber = factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return nearlyEqual(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalText.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalText.js new file mode 100644 index 0000000..56f8206 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/equalText.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +var name = 'equalText'; +var dependencies = ['typed', 'compareText', 'isZero']; +export var createEqualText = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + compareText, + isZero + } = _ref; + /** + * Check equality of two strings. Comparison is case sensitive. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.equalText(x, y) + * + * Examples: + * + * math.equalText('Hello', 'Hello') // returns true + * math.equalText('a', 'A') // returns false + * math.equal('2e3', '2000') // returns true + * math.equalText('2e3', '2000') // returns false + * + * math.equalText('B', ['A', 'B', 'C']) // returns [false, true, false] + * + * See also: + * + * equal, compareText, compare, compareNatural + * + * @param {string | Array | DenseMatrix} x First string to compare + * @param {string | Array | DenseMatrix} y Second string to compare + * @return {number | Array | DenseMatrix} Returns true if the values are equal, and false if not. + */ + return typed(name, { + 'any, any': function any_any(x, y) { + return isZero(compareText(x, y)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/larger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/larger.js new file mode 100644 index 0000000..d9ff020 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/larger.js @@ -0,0 +1,99 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'larger'; +var dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +export var createLarger = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Test whether value x is larger than y. + * + * The function returns true when x is larger than y and the relative + * difference between x and y is larger than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.larger(x, y) + * + * Examples: + * + * math.larger(2, 3) // returns false + * math.larger(5, 2 + 2) // returns true + * + * const a = math.unit('5 cm') + * const b = math.unit('2 inch') + * math.larger(a, b) // returns false + * + * See also: + * + * equal, unequal, smaller, smallerEq, largerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is larger than y, else returns false + */ + return typed(name, createLargerNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x > y, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.gt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x > y, + 'Fraction, Fraction': (x, y) => x.compare(y) === 1, + 'Complex, Complex': function Complex_Complex() { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createLargerNumber = /* #__PURE__ */factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return x > y && !nearlyEqual(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/largerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/largerEq.js new file mode 100644 index 0000000..b2105e6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/largerEq.js @@ -0,0 +1,97 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'largerEq'; +var dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +export var createLargerEq = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Test whether value x is larger or equal to y. + * + * The function returns true when x is larger than y or the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.largerEq(x, y) + * + * Examples: + * + * math.larger(2, 1 + 1) // returns false + * math.largerEq(2, 1 + 1) // returns true + * + * See also: + * + * equal, unequal, smaller, smallerEq, larger, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is larger or equal to y, else returns false + */ + return typed(name, createLargerEqNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x >= y, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.gte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': function bigint_bigint(x, y) { + return x >= y; + }, + 'Fraction, Fraction': (x, y) => x.compare(y) !== -1, + 'Complex, Complex': function Complex_Complex() { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createLargerEqNumber = /* #__PURE__ */factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return x >= y || nearlyEqual(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smaller.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smaller.js new file mode 100644 index 0000000..22227bc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smaller.js @@ -0,0 +1,99 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'smaller'; +var dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +export var createSmaller = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Test whether value x is smaller than y. + * + * The function returns true when x is smaller than y and the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.smaller(x, y) + * + * Examples: + * + * math.smaller(2, 3) // returns true + * math.smaller(5, 2 * 2) // returns false + * + * const a = math.unit('5 cm') + * const b = math.unit('2 inch') + * math.smaller(a, b) // returns true + * + * See also: + * + * equal, unequal, smallerEq, smaller, smallerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false + */ + return typed(name, createSmallerNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x < y, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.lt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x < y, + 'Fraction, Fraction': (x, y) => x.compare(y) === -1, + 'Complex, Complex': function Complex_Complex(x, y) { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createSmallerNumber = /* #__PURE__ */factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return x < y && !nearlyEqual(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smallerEq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smallerEq.js new file mode 100644 index 0000000..bc049c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/smallerEq.js @@ -0,0 +1,95 @@ +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +import { createCompareUnits } from './compareUnits.js'; +var name = 'smallerEq'; +var dependencies = ['typed', 'config', 'matrix', 'DenseMatrix', 'concat']; +export var createSmallerEq = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + var compareUnits = createCompareUnits({ + typed + }); + + /** + * Test whether value x is smaller or equal to y. + * + * The function returns true when x is smaller than y or the relative + * difference between x and y is smaller than the configured relTol and absTol. The + * function cannot be used to compare values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * Strings are compared by their numerical value. + * + * Syntax: + * + * math.smallerEq(x, y) + * + * Examples: + * + * math.smaller(1 + 2, 3) // returns false + * math.smallerEq(1 + 2, 3) // returns true + * + * See also: + * + * equal, unequal, smaller, larger, largerEq, compare + * + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare + * @param {number | BigNumber | bigint | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false + */ + return typed(name, createSmallerEqNumber({ + typed, + config + }), { + 'boolean, boolean': (x, y) => x <= y, + 'BigNumber, BigNumber': function BigNumber_BigNumber(x, y) { + return x.lte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol); + }, + 'bigint, bigint': (x, y) => x <= y, + 'Fraction, Fraction': (x, y) => x.compare(y) !== 1, + 'Complex, Complex': function Complex_Complex() { + throw new TypeError('No ordering relation is defined for complex numbers'); + } + }, compareUnits, matrixAlgorithmSuite({ + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); +}); +export var createSmallerEqNumber = /* #__PURE__ */factory(name, ['typed', 'config'], _ref2 => { + var { + typed, + config + } = _ref2; + return typed(name, { + 'number, number': function number_number(x, y) { + return x <= y || nearlyEqual(x, y, config.relTol, config.absTol); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/unequal.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/unequal.js new file mode 100644 index 0000000..271146d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/relational/unequal.js @@ -0,0 +1,113 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'unequal'; +var dependencies = ['typed', 'config', 'equalScalar', 'matrix', 'DenseMatrix', 'concat']; +export var createUnequal = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + equalScalar, + matrix, + DenseMatrix, + concat + } = _ref; + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo07xSSf = createMatAlgo07xSSf({ + typed, + DenseMatrix + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Test whether two values are unequal. + * + * The function tests whether the relative difference between x and y is + * larger than the configured relTol and absTol. The function cannot be used to compare + * values smaller than approximately 2.22e-16. + * + * For matrices, the function is evaluated element wise. + * In case of complex numbers, x.re must unequal y.re, or x.im must unequal y.im. + * Strings are compared by their numerical value. + * + * Values `null` and `undefined` are compared strictly, thus `null` is unequal + * with everything except `null`, and `undefined` is unequal with everything + * except `undefined`. + * + * Syntax: + * + * math.unequal(x, y) + * + * Examples: + * + * math.unequal(2 + 2, 3) // returns true + * math.unequal(2 + 2, 4) // returns false + * + * const a = math.unit('50 cm') + * const b = math.unit('5 m') + * math.unequal(a, b) // returns false + * + * const c = [2, 5, 1] + * const d = [2, 7, 1] + * + * math.unequal(c, d) // returns [false, true, false] + * math.deepEqual(c, d) // returns false + * + * math.unequal(0, null) // returns true + * See also: + * + * equal, deepEqual, smaller, smallerEq, larger, largerEq, compare + * + * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} x First value to compare + * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} y Second value to compare + * @return {boolean | Array | Matrix} Returns true when the compared values are unequal, else returns false + */ + return typed(name, createUnequalNumber({ + typed, + equalScalar + }), matrixAlgorithmSuite({ + elop: _unequal, + SS: matAlgo07xSSf, + DS: matAlgo03xDSf, + Ss: matAlgo12xSfs + })); + function _unequal(x, y) { + return !equalScalar(x, y); + } +}); +export var createUnequalNumber = factory(name, ['typed', 'equalScalar'], _ref2 => { + var { + typed, + equalScalar + } = _ref2; + return typed(name, { + 'any, any': function any_any(x, y) { + // strict equality for null and undefined? + if (x === null) { + return y !== null; + } + if (y === null) { + return x !== null; + } + if (x === undefined) { + return y !== undefined; + } + if (y === undefined) { + return x !== undefined; + } + return !equalScalar(x, y); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setCartesian.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setCartesian.js new file mode 100644 index 0000000..275d0d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setCartesian.js @@ -0,0 +1,58 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setCartesian'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +export var createSetCartesian = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the cartesian product of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays + * and the values will be sorted in ascending order before the operation. + * + * Syntax: + * + * math.setCartesian(set1, set2) + * + * Examples: + * + * math.setCartesian([1, 2], [3, 4]) // returns [[1, 3], [1, 4], [2, 3], [2, 4]] + * math.setCartesian([4, 3], [2, 1]) // returns [[3, 1], [3, 2], [4, 1], [4, 2]] + * + * See also: + * + * setUnion, setIntersect, setDifference, setPowerset + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The cartesian product of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + var result = []; + if (subset(size(a1), new Index(0)) !== 0 && subset(size(a2), new Index(0)) !== 0) { + // if any of them is empty, return empty + var b1 = flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural); + var b2 = flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural); + result = []; + for (var i = 0; i < b1.length; i++) { + for (var j = 0; j < b2.length; j++) { + result.push([b1[i], b2[j]]); + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return result; + } + // return a matrix otherwise + return new DenseMatrix(result); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDifference.js new file mode 100644 index 0000000..94688d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDifference.js @@ -0,0 +1,71 @@ +import { flatten, generalize, identify } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setDifference'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +export var createSetDifference = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the difference of two (multi)sets: every element of set1, that is not the element of set2. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setDifference(set1, set2) + * + * Examples: + * + * math.setDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2] + * math.setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2] + * + * See also: + * + * setUnion, setIntersect, setSymDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The difference of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + var result; + if (subset(size(a1), new Index(0)) === 0) { + // empty-anything=empty + result = []; + } else if (subset(size(a2), new Index(0)) === 0) { + // anything-empty=anything + return flatten(a1.toArray()); + } else { + var b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + var b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + result = []; + var inb2; + for (var i = 0; i < b1.length; i++) { + inb2 = false; + for (var j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + inb2 = true; + break; + } + } + if (!inb2) { + result.push(b1[i]); + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return generalize(result); + } + // return a matrix otherwise + return new DenseMatrix(generalize(result)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDistinct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDistinct.js new file mode 100644 index 0000000..a4f9abd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setDistinct.js @@ -0,0 +1,57 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setDistinct'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +export var createSetDistinct = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Collect the distinct elements of a multiset. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setDistinct(set) + * + * Examples: + * + * math.setDistinct([1, 1, 1, 2, 2, 3]) // returns [1, 2, 3] + * + * See also: + * + * setMultiplicity + * + * @param {Array | Matrix} a A multiset + * @return {Array | Matrix} A set containing the distinc elements of the multiset + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(a) { + var result; + if (subset(size(a), new Index(0)) === 0) { + // if empty, return empty + result = []; + } else { + var b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + result = []; + result.push(b[0]); + for (var i = 1; i < b.length; i++) { + if (compareNatural(b[i], b[i - 1]) !== 0) { + result.push(b[i]); + } + } + } + // return an array, if the input was an array + if (Array.isArray(a)) { + return result; + } + // return a matrix otherwise + return new DenseMatrix(result); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIntersect.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIntersect.js new file mode 100644 index 0000000..f88e1a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIntersect.js @@ -0,0 +1,63 @@ +import { flatten, generalize, identify } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setIntersect'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']; +export var createSetIntersect = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index, + DenseMatrix + } = _ref; + /** + * Create the intersection of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setIntersect(set1, set2) + * + * Examples: + * + * math.setIntersect([1, 2, 3, 4], [3, 4, 5, 6]) // returns [3, 4] + * math.setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [3, 4] + * + * See also: + * + * setUnion, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The intersection of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + var result; + if (subset(size(a1), new Index(0)) === 0 || subset(size(a2), new Index(0)) === 0) { + // of any of them is empty, return empty + result = []; + } else { + var b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + var b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + result = []; + for (var i = 0; i < b1.length; i++) { + for (var j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + result.push(b1[i]); + break; + } + } + } + } + // return an array, if both inputs were arrays + if (Array.isArray(a1) && Array.isArray(a2)) { + return generalize(result); + } + // return a matrix otherwise + return new DenseMatrix(generalize(result)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIsSubset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIsSubset.js new file mode 100644 index 0000000..a1b353e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setIsSubset.js @@ -0,0 +1,62 @@ +import { flatten, identify } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setIsSubset'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +export var createSetIsSubset = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Check whether a (multi)set is a subset of another (multi)set. (Every element of set1 is the element of set2.) + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setIsSubset(set1, set2) + * + * Examples: + * + * math.setIsSubset([1, 2], [3, 4, 5, 6]) // returns false + * math.setIsSubset([3, 4], [3, 4, 5, 6]) // returns true + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {boolean} Returns true when a1 is a subset of a2, returns false otherwise + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // empty is a subset of anything + return true; + } else if (subset(size(a2), new Index(0)) === 0) { + // anything is not a subset of empty + return false; + } + var b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)); + var b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)); + var inb2; + for (var i = 0; i < b1.length; i++) { + inb2 = false; + for (var j = 0; j < b2.length; j++) { + if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { + // the identifier is always a decimal int + inb2 = true; + break; + } + } + if (inb2 === false) { + return false; + } + } + return true; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setMultiplicity.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setMultiplicity.js new file mode 100644 index 0000000..57dc237 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setMultiplicity.js @@ -0,0 +1,50 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setMultiplicity'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +export var createSetMultiplicity = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Count the multiplicity of an element in a multiset. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setMultiplicity(element, set) + * + * Examples: + * + * math.setMultiplicity(1, [1, 2, 2, 4]) // returns 1 + * math.setMultiplicity(2, [1, 2, 2, 4]) // returns 2 + * + * See also: + * + * setDistinct, setSize + * + * @param {number | BigNumber | Fraction | Complex} e An element in the multiset + * @param {Array | Matrix} a A multiset + * @return {number} The number of how many times the multiset contains the element + */ + return typed(name, { + 'number | BigNumber | Fraction | Complex, Array | Matrix': function number__BigNumber__Fraction__Complex_Array__Matrix(e, a) { + if (subset(size(a), new Index(0)) === 0) { + // if empty, return 0 + return 0; + } + var b = flatten(Array.isArray(a) ? a : a.toArray()); + var count = 0; + for (var i = 0; i < b.length; i++) { + if (compareNatural(b[i], e) === 0) { + count++; + } + } + return count; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setPowerset.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setPowerset.js new file mode 100644 index 0000000..0cdfd83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setPowerset.js @@ -0,0 +1,75 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setPowerset'; +var dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']; +export var createSetPowerset = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + subset, + compareNatural, + Index + } = _ref; + /** + * Create the powerset of a (multi)set. (The powerset contains very possible subsets of a (multi)set.) + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setPowerset(set) + * + * Examples: + * + * math.setPowerset([1, 2, 3]) // returns [[], [1], [2], [3], [1, 2], [1, 3], [2, 3], [1, 2, 3]] + * + * See also: + * + * setCartesian + * + * @param {Array | Matrix} a A (multi)set + * @return {Array} The powerset of the (multi)set + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(a) { + if (subset(size(a), new Index(0)) === 0) { + // if empty, return empty + return []; + } + var b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + var result = []; + var number = 0; + while (number.toString(2).length <= b.length) { + result.push(_subset(b, number.toString(2).split('').reverse())); + number++; + } + // can not return a matrix, because of the different size of the subarrays + return _sort(result); + } + }); + + // create subset + function _subset(array, bitarray) { + var result = []; + for (var i = 0; i < bitarray.length; i++) { + if (bitarray[i] === '1') { + result.push(array[i]); + } + } + return result; + } + + // sort subsests by length + function _sort(array) { + var temp = []; + for (var i = array.length - 1; i > 0; i--) { + for (var j = 0; j < i; j++) { + if (array[j].length > array[j + 1].length) { + temp = array[j]; + array[j] = array[j + 1]; + array[j + 1] = temp; + } + } + } + return array; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSize.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSize.js new file mode 100644 index 0000000..3d374eb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSize.js @@ -0,0 +1,51 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setSize'; +var dependencies = ['typed', 'compareNatural']; +export var createSetSize = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + compareNatural + } = _ref; + /** + * Count the number of elements of a (multi)set. When a second parameter is 'true', count only the unique values. + * A multi-dimension array will be converted to a single-dimension array before the operation. + * + * Syntax: + * + * math.setSize(set) + * math.setSize(set, unique) + * + * Examples: + * + * math.setSize([1, 2, 2, 4]) // returns 4 + * math.setSize([1, 2, 2, 4], true) // returns 3 + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a A multiset + * @param {boolean} [unique] If true, only the unique values are counted. False by default + * @return {number} The number of elements of the (multi)set + */ + return typed(name, { + 'Array | Matrix': function Array__Matrix(a) { + return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length; + }, + 'Array | Matrix, boolean': function Array__Matrix_boolean(a, unique) { + if (unique === false || a.length === 0) { + return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length; + } else { + var b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural); + var count = 1; + for (var i = 1; i < b.length; i++) { + if (compareNatural(b[i], b[i - 1]) !== 0) { + count++; + } + } + return count; + } + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSymDifference.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSymDifference.js new file mode 100644 index 0000000..4c8fa96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setSymDifference.js @@ -0,0 +1,48 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setSymDifference'; +var dependencies = ['typed', 'size', 'concat', 'subset', 'setDifference', 'Index']; +export var createSetSymDifference = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + concat, + subset, + setDifference, + Index + } = _ref; + /** + * Create the symmetric difference of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setSymDifference(set1, set2) + * + * Examples: + * + * math.setSymDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 5, 6] + * math.setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 5, 6] + * + * See also: + * + * setUnion, setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The symmetric difference of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // if any of them is empty, return the other one + return flatten(a2); + } else if (subset(size(a2), new Index(0)) === 0) { + return flatten(a1); + } + var b1 = flatten(a1); + var b2 = flatten(a2); + return concat(setDifference(b1, b2), setDifference(b2, b1)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setUnion.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setUnion.js new file mode 100644 index 0000000..d069770 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/set/setUnion.js @@ -0,0 +1,49 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'setUnion'; +var dependencies = ['typed', 'size', 'concat', 'subset', 'setIntersect', 'setSymDifference', 'Index']; +export var createSetUnion = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + size, + concat, + subset, + setIntersect, + setSymDifference, + Index + } = _ref; + /** + * Create the union of two (multi)sets. + * Multi-dimension arrays will be converted to single-dimension arrays before the operation. + * + * Syntax: + * + * math.setUnion(set1, set2) + * + * Examples: + * + * math.setUnion([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 3, 4, 5, 6] + * math.setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 3, 4, 5, 6] + * + * See also: + * + * setIntersect, setDifference + * + * @param {Array | Matrix} a1 A (multi)set + * @param {Array | Matrix} a2 A (multi)set + * @return {Array | Matrix} The union of two (multi)sets + */ + return typed(name, { + 'Array | Matrix, Array | Matrix': function Array__Matrix_Array__Matrix(a1, a2) { + if (subset(size(a1), new Index(0)) === 0) { + // if any of them is empty, return the other one + return flatten(a2); + } else if (subset(size(a2), new Index(0)) === 0) { + return flatten(a1); + } + var b1 = flatten(a1); + var b2 = flatten(a2); + return concat(setSymDifference(b1, b2), setIntersect(b1, b2)); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/freqz.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/freqz.js new file mode 100644 index 0000000..0e58161 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/freqz.js @@ -0,0 +1,115 @@ +import { factory } from '../../utils/factory.js'; +var name = 'freqz'; +var dependencies = ['typed', 'add', 'multiply', 'Complex', 'divide', 'matrix']; +export var createFreqz = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + multiply, + Complex, + divide, + matrix + } = _ref; + /** + * Calculates the frequency response of a filter given its numerator and denominator coefficients. + * + * Syntax: + * math.freqz(b, a) + * math.freqz(b, a, w) + * + * Examples: + * math.freqz([1, 2], [1, 2, 3], 4) // returns { h: [0.5 + 0i, 0.4768589245763655 + 0.2861153547458193i, 0.25000000000000006 + 0.75i, -0.770976571635189 + 0.4625859429811135i], w: [0, 0.7853981633974483, 1.5707963267948966, 2.356194490192345 ] } + * math.freqz([1, 2], [1, 2, 3], [0, 1]) // returns { h: [0.5 + 0i, 0.45436781 + 0.38598051i], w: [0, 1] } + * + * See also: + * zpk2tf + * + * @param {Array.} b The numerator coefficients of the filter. + * @param {Array.} a The denominator coefficients of the filter. + * @param {Array.} [w] A vector of frequencies (in radians/sample) at which the frequency response is to be computed or the number of points to compute (if a number is not provided, the default is 512 points) + * @returns {Object} An object with two properties: h, a vector containing the complex frequency response, and w, a vector containing the normalized frequencies (in radians/sample) at which the response was computed. + * + * + */ + return typed(name, { + 'Array, Array': function Array_Array(b, a) { + var w = createBins(512); + return _freqz(b, a, w); + }, + 'Array, Array, Array': function Array_Array_Array(b, a, w) { + return _freqz(b, a, w); + }, + 'Array, Array, number': function Array_Array_number(b, a, w) { + if (w < 0) { + throw new Error('w must be a positive number'); + } + var w2 = createBins(w); + return _freqz(b, a, w2); + }, + 'Matrix, Matrix': function Matrix_Matrix(b, a) { + // console.log('here') + var _w = createBins(512); + var { + w, + h + } = _freqz(b.valueOf(), a.valueOf(), _w); + return { + w: matrix(w), + h: matrix(h) + }; + }, + 'Matrix, Matrix, Matrix': function Matrix_Matrix_Matrix(b, a, w) { + var { + h + } = _freqz(b.valueOf(), a.valueOf(), w.valueOf()); + return { + h: matrix(h), + w: matrix(w) + }; + }, + 'Matrix, Matrix, number': function Matrix_Matrix_number(b, a, w) { + if (w < 0) { + throw new Error('w must be a positive number'); + } + var _w = createBins(w); + var { + h + } = _freqz(b.valueOf(), a.valueOf(), _w); + return { + h: matrix(h), + w: matrix(_w) + }; + } + }); + function _freqz(b, a, w) { + var num = []; + var den = []; + for (var i = 0; i < w.length; i++) { + var sumNum = Complex(0, 0); + var sumDen = Complex(0, 0); + for (var j = 0; j < b.length; j++) { + sumNum = add(sumNum, multiply(b[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i])))); + } + for (var _j = 0; _j < a.length; _j++) { + sumDen = add(sumDen, multiply(a[_j], Complex(Math.cos(-_j * w[i]), Math.sin(-_j * w[i])))); + } + num.push(sumNum); + den.push(sumDen); + } + var h = []; + for (var _i = 0; _i < num.length; _i++) { + h.push(divide(num[_i], den[_i])); + } + return { + h, + w + }; + } + function createBins(n) { + var bins = []; + for (var i = 0; i < n; i++) { + bins.push(i / n * Math.PI); + } + return bins; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/zpk2tf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/zpk2tf.js new file mode 100644 index 0000000..e378c83 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/signal/zpk2tf.js @@ -0,0 +1,82 @@ +import { factory } from '../../utils/factory.js'; +var name = 'zpk2tf'; +var dependencies = ['typed', 'add', 'multiply', 'Complex', 'number']; +export var createZpk2tf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + multiply, + Complex, + number + } = _ref; + /** + * Compute the transfer function of a zero-pole-gain model. + * + * Syntax: + * math.zpk2tf(z, p, k) + * + * Examples: + * math.zpk2tf([1, 2], [-1, -2], 1) // returns [[1, -3, 2], [1, 3, 2]] + * + * See also: + * freqz + * + * @param {Array} z Array of zeros values + * @param {Array} p Array of poles values + * @param {number} k Gain value + * @return {Array} Two dimensional array containing the numerator (first row) and denominator (second row) polynomials + * + */ + return typed(name, { + 'Array,Array,number': function ArrayArrayNumber(z, p, k) { + return _zpk2tf(z, p, k); + }, + 'Array,Array': function ArrayArray(z, p) { + return _zpk2tf(z, p, 1); + }, + 'Matrix,Matrix,number': function MatrixMatrixNumber(z, p, k) { + return _zpk2tf(z.valueOf(), p.valueOf(), k); + }, + 'Matrix,Matrix': function MatrixMatrix(z, p) { + return _zpk2tf(z.valueOf(), p.valueOf(), 1); + } + }); + function _zpk2tf(z, p, k) { + // if z is bignumber, convert it to number + if (z.some(el => el.type === 'BigNumber')) { + z = z.map(el => number(el)); + } + // if p is bignumber, convert it to number + if (p.some(el => el.type === 'BigNumber')) { + p = p.map(el => number(el)); + } + var num = [Complex(1, 0)]; + var den = [Complex(1, 0)]; + for (var i = 0; i < z.length; i++) { + var zero = z[i]; + if (typeof zero === 'number') zero = Complex(zero, 0); + num = _multiply(num, [Complex(1, 0), Complex(-zero.re, -zero.im)]); + } + for (var _i = 0; _i < p.length; _i++) { + var pole = p[_i]; + if (typeof pole === 'number') pole = Complex(pole, 0); + den = _multiply(den, [Complex(1, 0), Complex(-pole.re, -pole.im)]); + } + for (var _i2 = 0; _i2 < num.length; _i2++) { + num[_i2] = multiply(num[_i2], k); + } + return [num, den]; + } + function _multiply(a, b) { + var c = []; + for (var i = 0; i < a.length + b.length - 1; i++) { + c[i] = Complex(0, 0); + for (var j = 0; j < a.length; j++) { + if (i - j >= 0 && i - j < b.length) { + c[i] = add(c[i], multiply(a[j], b[i - j])); + } + } + } + return c; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/erf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/erf.js new file mode 100644 index 0000000..194a879 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/erf.js @@ -0,0 +1,155 @@ +/* eslint-disable no-loss-of-precision */ + +import { deepMap } from '../../utils/collection.js'; +import { sign } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'erf'; +var dependencies = ['typed']; +export var createErf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Compute the erf function of a value using a rational Chebyshev + * approximations for different intervals of x. + * + * This is a translation of W. J. Cody's Fortran implementation from 1987 + * ( https://www.netlib.org/specfun/erf ). See the AMS publication + * "Rational Chebyshev Approximations for the Error Function" by W. J. Cody + * for an explanation of this process. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.erf(x) + * + * Examples: + * + * math.erf(0.2) // returns 0.22270258921047847 + * math.erf(-0.5) // returns -0.5204998778130465 + * math.erf(4) // returns 0.9999999845827421 + * + * See also: + * zeta + * + * @param {number | Array | Matrix} x A real number + * @return {number | Array | Matrix} The erf of `x` + */ + return typed('name', { + number: function number(x) { + var y = Math.abs(x); + if (y >= MAX_NUM) { + return sign(x); + } + if (y <= THRESH) { + return sign(x) * erf1(y); + } + if (y <= 4.0) { + return sign(x) * (1 - erfc2(y)); + } + return sign(x) * (1 - erfc3(y)); + }, + 'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self)) + + // TODO: For complex numbers, use the approximation for the Faddeeva function + // from "More Efficient Computation of the Complex Error Function" (AMS) + }); + + /** + * Approximates the error function erf() for x <= 0.46875 using this function: + * n + * erf(x) = x * sum (p_j * x^(2j)) / (q_j * x^(2j)) + * j=0 + */ + function erf1(y) { + var ysq = y * y; + var xnum = P[0][4] * ysq; + var xden = ysq; + var i; + for (i = 0; i < 3; i += 1) { + xnum = (xnum + P[0][i]) * ysq; + xden = (xden + Q[0][i]) * ysq; + } + return y * (xnum + P[0][3]) / (xden + Q[0][3]); + } + + /** + * Approximates the complement of the error function erfc() for + * 0.46875 <= x <= 4.0 using this function: + * n + * erfc(x) = e^(-x^2) * sum (p_j * x^j) / (q_j * x^j) + * j=0 + */ + function erfc2(y) { + var xnum = P[1][8] * y; + var xden = y; + var i; + for (i = 0; i < 7; i += 1) { + xnum = (xnum + P[1][i]) * y; + xden = (xden + Q[1][i]) * y; + } + var result = (xnum + P[1][7]) / (xden + Q[1][7]); + var ysq = parseInt(y * 16) / 16; + var del = (y - ysq) * (y + ysq); + return Math.exp(-ysq * ysq) * Math.exp(-del) * result; + } + + /** + * Approximates the complement of the error function erfc() for x > 4.0 using + * this function: + * + * erfc(x) = (e^(-x^2) / x) * [ 1/sqrt(pi) + + * n + * 1/(x^2) * sum (p_j * x^(-2j)) / (q_j * x^(-2j)) ] + * j=0 + */ + function erfc3(y) { + var ysq = 1 / (y * y); + var xnum = P[2][5] * ysq; + var xden = ysq; + var i; + for (i = 0; i < 4; i += 1) { + xnum = (xnum + P[2][i]) * ysq; + xden = (xden + Q[2][i]) * ysq; + } + var result = ysq * (xnum + P[2][4]) / (xden + Q[2][4]); + result = (SQRPI - result) / y; + ysq = parseInt(y * 16) / 16; + var del = (y - ysq) * (y + ysq); + return Math.exp(-ysq * ysq) * Math.exp(-del) * result; + } +}); + +/** + * Upper bound for the first approximation interval, 0 <= x <= THRESH + * @constant + */ +var THRESH = 0.46875; + +/** + * Constant used by W. J. Cody's Fortran77 implementation to denote sqrt(pi) + * @constant + */ +var SQRPI = 5.6418958354775628695e-1; + +/** + * Coefficients for each term of the numerator sum (p_j) for each approximation + * interval (see W. J. Cody's paper for more details) + * @constant + */ +var P = [[3.16112374387056560e00, 1.13864154151050156e02, 3.77485237685302021e02, 3.20937758913846947e03, 1.85777706184603153e-1], [5.64188496988670089e-1, 8.88314979438837594e00, 6.61191906371416295e01, 2.98635138197400131e02, 8.81952221241769090e02, 1.71204761263407058e03, 2.05107837782607147e03, 1.23033935479799725e03, 2.15311535474403846e-8], [3.05326634961232344e-1, 3.60344899949804439e-1, 1.25781726111229246e-1, 1.60837851487422766e-2, 6.58749161529837803e-4, 1.63153871373020978e-2]]; + +/** + * Coefficients for each term of the denominator sum (q_j) for each approximation + * interval (see W. J. Cody's paper for more details) + * @constant + */ +var Q = [[2.36012909523441209e01, 2.44024637934444173e02, 1.28261652607737228e03, 2.84423683343917062e03], [1.57449261107098347e01, 1.17693950891312499e02, 5.37181101862009858e02, 1.62138957456669019e03, 3.29079923573345963e03, 4.36261909014324716e03, 3.43936767414372164e03, 1.23033935480374942e03], [2.56852019228982242e00, 1.87295284992346047e00, 5.27905102951428412e-1, 6.05183413124413191e-2, 2.33520497626869185e-3]]; + +/** + * Maximum/minimum safe numbers to input to erf() (in ES6+, this number is + * Number.[MAX|MIN]_SAFE_INTEGER). erf() for all numbers beyond this limit will + * return 1 + */ +var MAX_NUM = Math.pow(2, 53); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/zeta.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/zeta.js new file mode 100644 index 0000000..59562d3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/special/zeta.js @@ -0,0 +1,148 @@ +import { factory } from '../../utils/factory.js'; +var name = 'zeta'; +var dependencies = ['typed', 'config', 'multiply', 'pow', 'divide', 'factorial', 'equal', 'smallerEq', 'isNegative', 'gamma', 'sin', 'subtract', 'add', '?Complex', '?BigNumber', 'pi']; +export var createZeta = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + multiply, + pow, + divide, + factorial, + equal, + smallerEq, + isNegative, + gamma, + sin, + subtract, + add, + Complex, + BigNumber: _BigNumber, + pi + } = _ref; + /** + * Compute the Riemann Zeta function of a value using an infinite series for + * all of the complex plane using Riemann's Functional equation. + * + * Based off the paper by Xavier Gourdon and Pascal Sebah + * ( http://numbers.computation.free.fr/Constants/Miscellaneous/zetaevaluations.pdf ) + * + * Implementation and slight modification by Anik Patel + * + * Note: the implementation is accurate up to about 6 digits. + * + * Syntax: + * + * math.zeta(n) + * + * Examples: + * + * math.zeta(5) // returns 1.0369277551433895 + * math.zeta(-0.5) // returns -0.2078862249773449 + * math.zeta(math.i) // returns 0.0033002236853253153 - 0.4181554491413212i + * + * See also: + * erf + * + * @param {number | Complex | BigNumber} s A Real, Complex or BigNumber parameter to the Riemann Zeta Function + * @return {number | Complex | BigNumber} The Riemann Zeta of `s` + */ + return typed(name, { + number: s => zetaNumeric(s, value => value, () => 20), + BigNumber: s => zetaNumeric(s, value => new _BigNumber(value), () => { + // relTol is for example 1e-12. Extract the positive exponent 12 from that + return Math.abs(Math.log10(config.relTol)); + }), + Complex: zetaComplex + }); + + /** + * @param {number | BigNumber} s + * @param {(value: number) => number | BigNumber} createValue + * @param {(value: number | BigNumber | Complex) => number} determineDigits + * @returns {number | BigNumber} + */ + function zetaNumeric(s, createValue, determineDigits) { + if (equal(s, 0)) { + return createValue(-0.5); + } + if (equal(s, 1)) { + return createValue(NaN); + } + if (!isFinite(s)) { + return isNegative(s) ? createValue(NaN) : createValue(1); + } + return zeta(s, createValue, determineDigits, s => s); + } + + /** + * @param {Complex} s + * @returns {Complex} + */ + function zetaComplex(s) { + if (s.re === 0 && s.im === 0) { + return new Complex(-0.5); + } + if (s.re === 1) { + return new Complex(NaN, NaN); + } + if (s.re === Infinity && s.im === 0) { + return new Complex(1); + } + if (s.im === Infinity || s.re === -Infinity) { + return new Complex(NaN, NaN); + } + return zeta(s, value => value, s => Math.round(1.3 * 15 + 0.9 * Math.abs(s.im)), s => s.re); + } + + /** + * @param {number | BigNumber | Complex} s + * @param {(value: number) => number | BigNumber | Complex} createValue + * @param {(value: number | BigNumber | Complex) => number} determineDigits + * @param {(value: number | BigNumber | Complex) => number} getRe + * @returns {*|number} + */ + function zeta(s, createValue, determineDigits, getRe) { + var n = determineDigits(s); + if (getRe(s) > -(n - 1) / 2) { + return f(s, createValue(n), createValue); + } else { + // Function Equation for reflection to x < 1 + var c = multiply(pow(2, s), pow(createValue(pi), subtract(s, 1))); + c = multiply(c, sin(multiply(divide(createValue(pi), 2), s))); + c = multiply(c, gamma(subtract(1, s))); + return multiply(c, zeta(subtract(1, s), createValue, determineDigits, getRe)); + } + } + + /** + * Calculate a portion of the sum + * @param {number | BigNumber} k a positive integer + * @param {number | BigNumber} n a positive integer + * @return {number} the portion of the sum + **/ + function d(k, n) { + var S = k; + for (var j = k; smallerEq(j, n); j = add(j, 1)) { + var factor = divide(multiply(factorial(add(n, subtract(j, 1))), pow(4, j)), multiply(factorial(subtract(n, j)), factorial(multiply(2, j)))); + S = add(S, factor); + } + return multiply(n, S); + } + + /** + * Calculate the positive Riemann Zeta function + * @param {number} s a real or complex number with s.re > 1 + * @param {number} n a positive integer + * @param {(number) => number | BigNumber | Complex} createValue + * @return {number} Riemann Zeta of s + **/ + function f(s, n, createValue) { + var c = divide(1, multiply(d(createValue(0), n), subtract(1, pow(2, subtract(1, s))))); + var S = createValue(0); + for (var k = createValue(1); smallerEq(k, n); k = add(k, 1)) { + S = add(S, divide(multiply((-1) ** (k - 1), d(k, n)), pow(k, s))); + } + return multiply(c, S); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/corr.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/corr.js new file mode 100644 index 0000000..0d03357 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/corr.js @@ -0,0 +1,84 @@ +import { factory } from '../../utils/factory.js'; +var name = 'corr'; +var dependencies = ['typed', 'matrix', 'mean', 'sqrt', 'sum', 'add', 'subtract', 'multiply', 'pow', 'divide']; +export var createCorr = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + sqrt, + sum, + add, + subtract, + multiply, + pow, + divide + } = _ref; + /** + * Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated. + * + * Syntax: + * + * math.corr(A, B) + * + * Examples: + * + * math.corr([1, 2, 3, 4, 5], [4, 5, 6, 7, 8]) // returns 1 + * math.corr([1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]) //returns 0.9569941688503644 + * math.corr([[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]],[[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]]) // returns [1,1] + * + * See also: + * + * median, mean, min, max, sum, prod, std, variance + * + * @param {Array | Matrix} A The first array or matrix to compute correlation coefficient + * @param {Array | Matrix} B The second array or matrix to compute correlation coefficient + * @return {*} The correlation coefficient + */ + return typed(name, { + 'Array, Array': function Array_Array(A, B) { + return _corr(A, B); + }, + 'Matrix, Matrix': function Matrix_Matrix(A, B) { + var res = _corr(A.toArray(), B.toArray()); + return Array.isArray(res) ? matrix(res) : res; + } + }); + /** + * Calculate the correlation coefficient between two arrays or matrices. + * @param {Array | Matrix} A + * @param {Array | Matrix} B + * @return {*} correlation coefficient + * @private + */ + function _corr(A, B) { + var correlations = []; + if (Array.isArray(A[0]) && Array.isArray(B[0])) { + if (A.length !== B.length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same length.'); + } + for (var i = 0; i < A.length; i++) { + if (A[i].length !== B[i].length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.'); + } + correlations.push(correlation(A[i], B[i])); + } + return correlations; + } else { + if (A.length !== B.length) { + throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.'); + } + return correlation(A, B); + } + } + function correlation(A, B) { + var n = A.length; + var sumX = sum(A); + var sumY = sum(B); + var sumXY = A.reduce((acc, x, index) => add(acc, multiply(x, B[index])), 0); + var sumXSquare = sum(A.map(x => pow(x, 2))); + var sumYSquare = sum(B.map(y => pow(y, 2))); + var numerator = subtract(multiply(n, sumXY), multiply(sumX, sumY)); + var denominator = sqrt(multiply(subtract(multiply(n, sumXSquare), pow(sumX, 2)), subtract(multiply(n, sumYSquare), pow(sumY, 2)))); + return divide(numerator, denominator); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/cumsum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/cumsum.js new file mode 100644 index 0000000..1e7cc36 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/cumsum.js @@ -0,0 +1,123 @@ +import { containsCollections } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { _switch } from '../../utils/switch.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +import { arraySize } from '../../utils/array.js'; +import { IndexError } from '../../error/IndexError.js'; +var name = 'cumsum'; +var dependencies = ['typed', 'add', 'unaryPlus']; +export var createCumSum = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + unaryPlus + } = _ref; + /** + * Compute the cumulative sum of a matrix or a list with values. + * In case of a (multi dimensional) array or matrix, the cumulative sums + * along a specified dimension (defaulting to the first) will be calculated. + * + * Syntax: + * + * math.cumsum(a, b, c, ...) + * math.cumsum(A) + * + * Examples: + * + * math.cumsum(2, 1, 4, 3) // returns [2, 3, 7, 10] + * math.cumsum([2, 1, 4, 3]) // returns [2, 3, 7, 10] + * math.cumsum([[1, 2], [3, 4]]) // returns [[1, 2], [4, 6]] + * math.cumsum([[1, 2], [3, 4]], 0) // returns [[1, 2], [4, 6]] + * math.cumsum([[1, 2], [3, 4]], 1) // returns [[1, 3], [3, 7]] + * math.cumsum([[2, 5], [4, 3], [1, 7]]) // returns [[2, 5], [6, 8], [7, 15]] + * + * See also: + * + * mean, median, min, max, prod, std, variance, sum + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The cumulative sum of all values + */ + return typed(name, { + // sum([a, b, c, d, ...]) + Array: _cumsum, + Matrix: function Matrix(matrix) { + return matrix.create(_cumsum(matrix.valueOf(), matrix.datatype())); + }, + // sum([a, b, c, d, ...], dim) + 'Array, number | BigNumber': _ncumSumDim, + 'Matrix, number | BigNumber': function Matrix_number__BigNumber(matrix, dim) { + return matrix.create(_ncumSumDim(matrix.valueOf(), dim), matrix.datatype()); + }, + // cumsum(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('All values expected to be scalar in function cumsum'); + } + return _cumsum(args); + } + }); + + /** + * Recursively calculate the cumulative sum of an n-dimensional array + * @param {Array} array + * @return {number} cumsum + * @private + */ + function _cumsum(array) { + try { + return _cumsummap(array); + } catch (err) { + throw improveErrorMessage(err, name); + } + } + function _cumsummap(array) { + if (array.length === 0) { + return []; + } + var sums = [unaryPlus(array[0])]; // unaryPlus converts to number if need be + for (var i = 1; i < array.length; ++i) { + // Must use add below and not addScalar for the case of summing a + // 2+-dimensional array along the 0th dimension (the row vectors, + // or higher-d analogues, are literally added to each other). + sums.push(add(sums[i - 1], array[i])); + } + return sums; + } + function _ncumSumDim(array, dim) { + var size = arraySize(array); + if (dim < 0 || dim >= size.length) { + // TODO: would be more clear when throwing a DimensionError here + throw new IndexError(dim, size.length); + } + try { + return _cumsumDimensional(array, dim); + } catch (err) { + throw improveErrorMessage(err, name); + } + } + + /* Possible TODO: Refactor _reduce in collection.js to be able to work here as well */ + function _cumsumDimensional(mat, dim) { + var i, ret, tran; + if (dim <= 0) { + var initialValue = mat[0][0]; + if (!Array.isArray(initialValue)) { + return _cumsummap(mat); + } else { + tran = _switch(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _cumsumDimensional(tran[i], dim - 1); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _cumsumDimensional(mat[i], dim - 1); + } + return ret; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mad.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mad.js new file mode 100644 index 0000000..96e096a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mad.js @@ -0,0 +1,64 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'mad'; +var dependencies = ['typed', 'abs', 'map', 'median', 'subtract']; +export var createMad = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + abs, + map, + median, + subtract + } = _ref; + /** + * Compute the median absolute deviation of a matrix or a list with values. + * The median absolute deviation is defined as the median of the absolute + * deviations from the median. + * + * Syntax: + * + * math.mad(a, b, c, ...) + * math.mad(A) + * + * Examples: + * + * math.mad(10, 20, 30) // returns 10 + * math.mad([1, 2, 3]) // returns 1 + * math.mad([[1, 2, 3], [4, 5, 6]]) // returns 1.5 + * + * See also: + * + * median, mean, std, abs + * + * @param {Array | Matrix} array + * A single matrix or multiple scalar values. + * @return {*} The median absolute deviation. + */ + return typed(name, { + // mad([a, b, c, d, ...]) + 'Array | Matrix': _mad, + // mad(a, b, c, d, ...) + '...': function _(args) { + return _mad(args); + } + }); + function _mad(array) { + array = flatten(array.valueOf()); + if (array.length === 0) { + throw new Error('Cannot calculate median absolute deviation (mad) of an empty array'); + } + try { + var med = median(array); + return median(map(array, function (value) { + return abs(subtract(value, med)); + })); + } catch (err) { + if (err instanceof TypeError && err.message.includes('median')) { + throw new TypeError(err.message.replace('median', 'mad')); + } else { + throw improveErrorMessage(err, 'mad'); + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/max.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/max.js new file mode 100644 index 0000000..45514d7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/max.js @@ -0,0 +1,105 @@ +import { deepForEach, reduce, containsCollections } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'max'; +var dependencies = ['typed', 'config', 'numeric', 'larger']; +export var createMax = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + numeric, + larger + } = _ref; + /** + * Compute the maximum value of a matrix or a list with values. + * In case of a multidimensional array, the maximum of the flattened array + * will be calculated. When `dim` is provided, the maximum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.max(a, b, c, ...) + * math.max(A) + * math.max(A, dimension) + * + * Examples: + * + * math.max(2, 1, 4, 3) // returns 4 + * math.max([2, 1, 4, 3]) // returns 4 + * + * // maximum over a specified dimension (zero-based) + * math.max([[2, 5], [4, 3], [1, 7]], 0) // returns [4, 7] + * math.max([[2, 5], [4, 3], [1, 7]], 1) // returns [5, 4, 7] + * + * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1 + * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5 + * + * See also: + * + * mean, median, min, prod, std, sum, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The maximum value + */ + return typed(name, { + // max([a, b, c, d, ...]) + 'Array | Matrix': _max, + // max([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function Array__Matrix_number__BigNumber(array, dim) { + return reduce(array, dim.valueOf(), _largest); + }, + // max(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('Scalar values expected in function max'); + } + return _max(args); + } + }); + + /** + * Return the largest of two values + * @param {*} x + * @param {*} y + * @returns {*} Returns x when x is largest, or y when y is largest + * @private + */ + function _largest(x, y) { + try { + return larger(x, y) ? x : y; + } catch (err) { + throw improveErrorMessage(err, 'max', y); + } + } + + /** + * Recursively calculate the maximum value in an n-dimensional array + * @param {Array} array + * @return {number} max + * @private + */ + function _max(array) { + var res; + deepForEach(array, function (value) { + try { + if (isNaN(value) && typeof value === 'number') { + res = NaN; + } else if (res === undefined || larger(value, res)) { + res = value; + } + } catch (err) { + throw improveErrorMessage(err, 'max', value); + } + }); + if (res === undefined) { + throw new Error('Cannot calculate max of an empty array'); + } + + // make sure returning numeric value: parse a string into a numeric value + if (typeof res === 'string') { + res = numeric(res, safeNumberType(res, config)); + } + return res; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mean.js new file mode 100644 index 0000000..62d910f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mean.js @@ -0,0 +1,94 @@ +import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'; +import { arraySize } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'mean'; +var dependencies = ['typed', 'add', 'divide']; +export var createMean = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + divide + } = _ref; + /** + * Compute the mean value of matrix or a list with values. + * In case of a multidimensional array, the mean of the flattened array + * will be calculated. When `dim` is provided, the maximum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.mean(a, b, c, ...) + * math.mean(A) + * math.mean(A, dimension) + * + * Examples: + * + * math.mean(2, 1, 4, 3) // returns 2.5 + * math.mean([1, 2.7, 3.2, 4]) // returns 2.725 + * + * math.mean([[2, 5], [6, 3], [1, 7]], 0) // returns [3, 5] + * math.mean([[2, 5], [6, 3], [1, 7]], 1) // returns [3.5, 4.5, 4] + * + * See also: + * + * median, min, max, sum, prod, std, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The mean of all values + */ + return typed(name, { + // mean([a, b, c, d, ...]) + 'Array | Matrix': _mean, + // mean([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': _nmeanDim, + // mean(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('Scalar values expected in function mean'); + } + return _mean(args); + } + }); + + /** + * Calculate the mean value in an n-dimensional array, returning a + * n-1 dimensional array + * @param {Array} array + * @param {number} dim + * @return {number} mean + * @private + */ + function _nmeanDim(array, dim) { + try { + var sum = reduce(array, dim, add); + var s = Array.isArray(array) ? arraySize(array) : array.size(); + return divide(sum, s[dim]); + } catch (err) { + throw improveErrorMessage(err, 'mean'); + } + } + + /** + * Recursively calculate the mean value in an n-dimensional array + * @param {Array} array + * @return {number} mean + * @private + */ + function _mean(array) { + var sum; + var num = 0; + deepForEach(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + num++; + } catch (err) { + throw improveErrorMessage(err, 'mean', value); + } + }); + if (num === 0) { + throw new Error('Cannot calculate the mean of an empty array'); + } + return divide(sum, num); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/median.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/median.js new file mode 100644 index 0000000..12e65a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/median.js @@ -0,0 +1,108 @@ +import { containsCollections } from '../../utils/collection.js'; +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'median'; +var dependencies = ['typed', 'add', 'divide', 'compare', 'partitionSelect']; +export var createMedian = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + divide, + compare, + partitionSelect + } = _ref; + /** + * Recursively calculate the median of an n-dimensional array + * @param {Array} array + * @return {Number} median + * @private + */ + function _median(array) { + try { + array = flatten(array.valueOf()); + var num = array.length; + if (num === 0) { + throw new Error('Cannot calculate median of an empty array'); + } + if (num % 2 === 0) { + // even: return the average of the two middle values + var mid = num / 2 - 1; + var right = partitionSelect(array, mid + 1); + + // array now partitioned at mid + 1, take max of left part + var left = array[mid]; + for (var i = 0; i < mid; ++i) { + if (compare(array[i], left) > 0) { + left = array[i]; + } + } + return middle2(left, right); + } else { + // odd: return the middle value + var m = partitionSelect(array, (num - 1) / 2); + return middle(m); + } + } catch (err) { + throw improveErrorMessage(err, 'median'); + } + } + + // helper function to type check the middle value of the array + var middle = typed({ + 'number | BigNumber | Complex | Unit': function number__BigNumber__Complex__Unit(value) { + return value; + } + }); + + // helper function to type check the two middle value of the array + var middle2 = typed({ + 'number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit': function number__BigNumber__Complex__Unit_number__BigNumber__Complex__Unit(left, right) { + return divide(add(left, right), 2); + } + }); + + /** + * Compute the median of a matrix or a list with values. The values are + * sorted and the middle value is returned. In case of an even number of + * values, the average of the two middle values is returned. + * Supported types of values are: Number, BigNumber, Unit + * + * In case of a (multi dimensional) array or matrix, the median of all + * elements will be calculated. + * + * Syntax: + * + * math.median(a, b, c, ...) + * math.median(A) + * + * Examples: + * + * math.median(5, 2, 7) // returns 5 + * math.median([3, -1, 5, 7]) // returns 4 + * + * See also: + * + * mean, min, max, sum, prod, std, variance, quantileSeq + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The median + */ + return typed(name, { + // median([a, b, c, d, ...]) + 'Array | Matrix': _median, + // median([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function Array__Matrix_number__BigNumber(array, dim) { + // TODO: implement median(A, dim) + throw new Error('median(A, dim) is not yet supported'); + // return reduce(arguments[0], arguments[1], ...) + }, + // median(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('Scalar values expected in function median'); + } + return _median(args); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/min.js new file mode 100644 index 0000000..27c255c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/min.js @@ -0,0 +1,105 @@ +import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'min'; +var dependencies = ['typed', 'config', 'numeric', 'smaller']; +export var createMin = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + numeric, + smaller + } = _ref; + /** + * Compute the minimum value of a matrix or a list of values. + * In case of a multidimensional array, the minimum of the flattened array + * will be calculated. When `dim` is provided, the minimum over the selected + * dimension will be calculated. Parameter `dim` is zero-based. + * + * Syntax: + * + * math.min(a, b, c, ...) + * math.min(A) + * math.min(A, dimension) + * + * Examples: + * + * math.min(2, 1, 4, 3) // returns 1 + * math.min([2, 1, 4, 3]) // returns 1 + * + * // minimum over a specified dimension (zero-based) + * math.min([[2, 5], [4, 3], [1, 7]], 0) // returns [1, 3] + * math.min([[2, 5], [4, 3], [1, 7]], 1) // returns [2, 3, 1] + * + * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1 + * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5 + * + * See also: + * + * mean, median, max, prod, std, sum, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The minimum value + */ + return typed(name, { + // min([a, b, c, d, ...]) + 'Array | Matrix': _min, + // min([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function Array__Matrix_number__BigNumber(array, dim) { + return reduce(array, dim.valueOf(), _smallest); + }, + // min(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('Scalar values expected in function min'); + } + return _min(args); + } + }); + + /** + * Return the smallest of two values + * @param {*} x + * @param {*} y + * @returns {*} Returns x when x is smallest, or y when y is smallest + * @private + */ + function _smallest(x, y) { + try { + return smaller(x, y) ? x : y; + } catch (err) { + throw improveErrorMessage(err, 'min', y); + } + } + + /** + * Recursively calculate the minimum value in an n-dimensional array + * @param {Array} array + * @return {number} min + * @private + */ + function _min(array) { + var min; + deepForEach(array, function (value) { + try { + if (isNaN(value) && typeof value === 'number') { + min = NaN; + } else if (min === undefined || smaller(value, min)) { + min = value; + } + } catch (err) { + throw improveErrorMessage(err, 'min', value); + } + }); + if (min === undefined) { + throw new Error('Cannot calculate min of an empty array'); + } + + // make sure returning numeric value: parse a string into a numeric value + if (typeof min === 'string') { + min = numeric(min, safeNumberType(min, config)); + } + return min; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mode.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mode.js new file mode 100644 index 0000000..00c433a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/mode.js @@ -0,0 +1,76 @@ +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +var name = 'mode'; +var dependencies = ['typed', 'isNaN', 'isNumeric']; +export var createMode = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isNaN, + isNumeric + } = _ref; + /** + * Computes the mode of a set of numbers or a list with values(numbers or characters). + * If there are multiple modes, it returns a list of those values. + * + * Syntax: + * + * math.mode(a, b, c, ...) + * math.mode(A) + * + * Examples: + * + * math.mode(2, 1, 4, 3, 1) // returns [1] + * math.mode([1, 2.7, 3.2, 4, 2.7]) // returns [2.7] + * math.mode(1, 4, 6, 1, 6) // returns [1, 6] + * math.mode('a','a','b','c') // returns ["a"] + * math.mode(1, 1.5, 'abc') // returns [1, 1.5, "abc"] + * + * See also: + * + * median, + * mean + * + * @param {... *} args A single matrix + * @return {*} The mode of all values + */ + return typed(name, { + 'Array | Matrix': _mode, + '...': function _(args) { + return _mode(args); + } + }); + + /** + * Calculates the mode in an 1-dimensional array + * @param {Array} values + * @return {Array} mode + * @private + */ + function _mode(values) { + values = flatten(values.valueOf()); + var num = values.length; + if (num === 0) { + throw new Error('Cannot calculate mode of an empty array'); + } + var count = {}; + var mode = []; + var max = 0; + for (var i = 0; i < values.length; i++) { + var value = values[i]; + if (isNumeric(value) && isNaN(value)) { + throw new Error('Cannot calculate mode of an array containing NaN values'); + } + if (!(value in count)) { + count[value] = 0; + } + count[value]++; + if (count[value] === max) { + mode.push(value); + } else if (count[value] > max) { + max = count[value]; + mode = [value]; + } + } + return mode; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/prod.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/prod.js new file mode 100644 index 0000000..208357f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/prod.js @@ -0,0 +1,79 @@ +import { deepForEach } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'prod'; +var dependencies = ['typed', 'config', 'multiplyScalar', 'numeric']; +export var createProd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + multiplyScalar, + numeric + } = _ref; + /** + * Compute the product of a matrix or a list with values. + * In case of a multidimensional array or matrix, the sum of all + * elements will be calculated. + * + * Syntax: + * + * math.prod(a, b, c, ...) + * math.prod(A) + * + * Examples: + * + * math.multiply(2, 3) // returns 6 + * math.prod(2, 3) // returns 6 + * math.prod(2, 3, 4) // returns 24 + * math.prod([2, 3, 4]) // returns 24 + * math.prod([[2, 5], [4, 3]]) // returns 120 + * + * See also: + * + * mean, median, min, max, sum, std, variance + * + * @param {... *} args A single matrix or or multiple scalar values + * @return {*} The product of all values + */ + return typed(name, { + // prod([a, b, c, d, ...]) + 'Array | Matrix': _prod, + // prod([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': function Array__Matrix_number__BigNumber(array, dim) { + // TODO: implement prod(A, dim) + throw new Error('prod(A, dim) is not yet supported'); + // return reduce(arguments[0], arguments[1], math.prod) + }, + // prod(a, b, c, d, ...) + '...': function _(args) { + return _prod(args); + } + }); + + /** + * Recursively calculate the product of an n-dimensional array + * @param {Array} array + * @return {number} prod + * @private + */ + function _prod(array) { + var prod; + deepForEach(array, function (value) { + try { + prod = prod === undefined ? value : multiplyScalar(prod, value); + } catch (err) { + throw improveErrorMessage(err, 'prod', value); + } + }); + + // make sure returning numeric value: parse a string into a numeric value + if (typeof prod === 'string') { + prod = numeric(prod, safeNumberType(prod, config)); + } + if (prod === undefined) { + throw new Error('Cannot calculate prod of an empty array'); + } + return prod; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/quantileSeq.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/quantileSeq.js new file mode 100644 index 0000000..86e102f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/quantileSeq.js @@ -0,0 +1,166 @@ +import { isNumber } from '../../utils/is.js'; +import { flatten } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { createApply } from '../matrix/apply.js'; +var name = 'quantileSeq'; +var dependencies = ['typed', '?bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']; +export var createQuantileSeq = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + bignumber, + add, + subtract, + divide, + multiply, + partitionSelect, + compare, + isInteger, + smaller, + smallerEq, + larger + } = _ref; + var apply = createApply({ + typed, + isInteger + }); + + /** + * Compute the prob order quantile of a matrix or a list with values. + * The sequence is sorted and the middle value is returned. + * Supported types of sequence values are: Number, BigNumber, Unit + * Supported types of probability are: Number, BigNumber + * + * In case of a multidimensional array or matrix, the prob order quantile + * of all elements will be calculated. + * + * Syntax: + * + * math.quantileSeq(A, prob[, sorted]) + * math.quantileSeq(A, [prob1, prob2, ...][, sorted]) + * math.quantileSeq(A, N[, sorted]) + * + * Examples: + * + * math.quantileSeq([3, -1, 5, 7], 0.5) // returns 4 + * math.quantileSeq([3, -1, 5, 7], [1/3, 2/3]) // returns [3, 5] + * math.quantileSeq([3, -1, 5, 7], 2) // returns [3, 5] + * math.quantileSeq([-1, 3, 5, 7], 0.5, true) // returns 4 + * + * See also: + * + * median, mean, min, max, sum, prod, std, variance + * + * @param {Array, Matrix} data A single matrix or Array + * @param {Number, BigNumber, Array} probOrN prob is the order of the quantile, while N is + * the amount of evenly distributed steps of + * probabilities; only one of these options can + * be provided + * @param {Boolean} sorted=false is data sorted in ascending order + * @return {Number, BigNumber, Unit, Array} Quantile(s) + */ + return typed(name, { + 'Array | Matrix, number | BigNumber': (data, p) => _quantileSeqProbNumber(data, p, false), + 'Array | Matrix, number | BigNumber, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbNumber), + 'Array | Matrix, number | BigNumber, boolean': _quantileSeqProbNumber, + 'Array | Matrix, number | BigNumber, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbNumber), + 'Array | Matrix, Array | Matrix': (data, p) => _quantileSeqProbCollection(data, p, false), + 'Array | Matrix, Array | Matrix, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbCollection), + 'Array | Matrix, Array | Matrix, boolean': _quantileSeqProbCollection, + 'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbCollection) + }); + function _quantileSeqDim(data, prob, sorted, dim, fn) { + return apply(data, dim, x => fn(x, prob, sorted)); + } + function _quantileSeqProbNumber(data, probOrN, sorted) { + var probArr; + var dataArr = data.valueOf(); + if (smaller(probOrN, 0)) { + throw new Error('N/prob must be non-negative'); + } + if (smallerEq(probOrN, 1)) { + // quantileSeq([a, b, c, d, ...], prob[,sorted]) + return isNumber(probOrN) ? _quantileSeq(dataArr, probOrN, sorted) : bignumber(_quantileSeq(dataArr, probOrN, sorted)); + } + if (larger(probOrN, 1)) { + // quantileSeq([a, b, c, d, ...], N[,sorted]) + if (!isInteger(probOrN)) { + throw new Error('N must be a positive integer'); + } + + // largest possible Array length is 2^32-1 + // 2^32 < 10^15, thus safe conversion guaranteed + if (larger(probOrN, 4294967295)) { + throw new Error('N must be less than or equal to 2^32-1, as that is the maximum length of an Array'); + } + var nPlusOne = add(probOrN, 1); + probArr = []; + for (var i = 0; smaller(i, probOrN); i++) { + var prob = divide(i + 1, nPlusOne); + probArr.push(_quantileSeq(dataArr, prob, sorted)); + } + return isNumber(probOrN) ? probArr : bignumber(probArr); + } + } + + /** + * Calculate the prob order quantile of an n-dimensional array. + * + * @param {Array, Matrix} array + * @param {Array, Matrix} prob + * @param {Boolean} sorted + * @return {Number, BigNumber, Unit} prob order quantile + * @private + */ + + function _quantileSeqProbCollection(data, probOrN, sorted) { + var dataArr = data.valueOf(); + // quantileSeq([a, b, c, d, ...], [prob1, prob2, ...][,sorted]) + var probOrNArr = probOrN.valueOf(); + var probArr = []; + for (var i = 0; i < probOrNArr.length; ++i) { + probArr.push(_quantileSeq(dataArr, probOrNArr[i], sorted)); + } + return probArr; + } + + /** + * Calculate the prob order quantile of an n-dimensional array. + * + * @param {Array} array + * @param {Number, BigNumber} prob + * @param {Boolean} sorted + * @return {Number, BigNumber, Unit} prob order quantile + * @private + */ + function _quantileSeq(array, prob, sorted) { + var flat = flatten(array); + var len = flat.length; + if (len === 0) { + throw new Error('Cannot calculate quantile of an empty sequence'); + } + var index = isNumber(prob) ? prob * (len - 1) : prob.times(len - 1); + var integerPart = isNumber(prob) ? Math.floor(index) : index.floor().toNumber(); + var fracPart = isNumber(prob) ? index % 1 : index.minus(integerPart); + if (isInteger(index)) { + return sorted ? flat[index] : partitionSelect(flat, isNumber(prob) ? index : index.valueOf()); + } + var left; + var right; + if (sorted) { + left = flat[integerPart]; + right = flat[integerPart + 1]; + } else { + right = partitionSelect(flat, integerPart + 1); + + // max of partition is kth largest + left = flat[integerPart]; + for (var i = 0; i < integerPart; ++i) { + if (compare(flat[i], left) > 0) { + left = flat[i]; + } + } + } + // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1] + return add(multiply(left, subtract(1, fracPart)), multiply(right, fracPart)); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/std.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/std.js new file mode 100644 index 0000000..25c6536 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/std.js @@ -0,0 +1,97 @@ +import { factory } from '../../utils/factory.js'; +import { isCollection } from '../../utils/is.js'; +var name = 'std'; +var dependencies = ['typed', 'map', 'sqrt', 'variance']; +export var createStd = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + map, + sqrt, + variance + } = _ref; + /** + * Compute the standard deviation of a matrix or a list with values. + * The standard deviations is defined as the square root of the variance: + * `std(A) = sqrt(variance(A))`. + * In case of a (multi dimensional) array or matrix, the standard deviation + * over all elements will be calculated by default, unless an axis is specified + * in which case the standard deviation will be computed along that axis. + * + * Additionally, it is possible to compute the standard deviation along the rows + * or columns of a matrix by specifying the dimension as the second argument. + * + * Optionally, the type of normalization can be specified as the final + * parameter. The parameter `normalization` can be one of the following values: + * + * - 'unbiased' (default) The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * + * + * Syntax: + * + * math.std(a, b, c, ...) + * math.std(A) + * math.std(A, normalization) + * math.std(A, dimension) + * math.std(A, dimension, normalization) + * + * Examples: + * + * math.std(2, 4, 6) // returns 2 + * math.std([2, 4, 6, 8]) // returns 2.581988897471611 + * math.std([2, 4, 6, 8], 'uncorrected') // returns 2.23606797749979 + * math.std([2, 4, 6, 8], 'biased') // returns 2 + * + * math.std([[1, 2, 3], [4, 5, 6]]) // returns 1.8708286933869707 + * math.std([[1, 2, 3], [4, 6, 8]], 0) // returns [2.1213203435596424, 2.8284271247461903, 3.5355339059327378] + * math.std([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 2] + * math.std([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.7071067811865476, 1.4142135623730951] + * + * See also: + * + * mean, median, max, min, prod, sum, variance + * + * @param {Array | Matrix} array + * A single matrix or or multiple scalar values + * @param {string} [normalization='unbiased'] + * Determines how to normalize the variance. + * Choose 'unbiased' (default), 'uncorrected', or 'biased'. + * @param dimension {number | BigNumber} + * Determines the axis to compute the standard deviation for a matrix + * @return {*} The standard deviation + */ + return typed(name, { + // std([a, b, c, d, ...]) + 'Array | Matrix': _std, + // std([a, b, c, d, ...], normalization) + 'Array | Matrix, string': _std, + // std([a, b, c, c, ...], dim) + 'Array | Matrix, number | BigNumber': _std, + // std([a, b, c, c, ...], dim, normalization) + 'Array | Matrix, number | BigNumber, string': _std, + // std(a, b, c, d, ...) + '...': function _(args) { + return _std(args); + } + }); + function _std(array, normalization) { + if (array.length === 0) { + throw new SyntaxError('Function std requires one or more parameters (0 provided)'); + } + try { + var v = variance.apply(null, arguments); + if (isCollection(v)) { + return map(v, sqrt); + } else { + return sqrt(v); + } + } catch (err) { + if (err instanceof TypeError && err.message.includes(' variance')) { + throw new TypeError(err.message.replace(' variance', ' std')); + } else { + throw err; + } + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/sum.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/sum.js new file mode 100644 index 0000000..661e373 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/sum.js @@ -0,0 +1,85 @@ +import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { safeNumberType } from '../../utils/number.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var name = 'sum'; +var dependencies = ['typed', 'config', 'add', 'numeric']; +export var createSum = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + add, + numeric + } = _ref; + /** + * Compute the sum of a matrix or a list with values. + * In case of a multidimensional array or matrix, the sum of all + * elements will be calculated. + * + * Syntax: + * + * math.sum(a, b, c, ...) + * math.sum(A) + * math.sum(A, dimension) + * + * Examples: + * + * math.sum(2, 1, 4, 3) // returns 10 + * math.sum([2, 1, 4, 3]) // returns 10 + * math.sum([[2, 5], [4, 3], [1, 7]]) // returns 22 + * + * See also: + * + * mean, median, min, max, prod, std, variance, cumsum + * + * @param {... *} args A single matrix or multiple scalar values + * @return {*} The sum of all values + */ + return typed(name, { + // sum([a, b, c, d, ...]) + 'Array | Matrix': _sum, + // sum([a, b, c, d, ...], dim) + 'Array | Matrix, number | BigNumber': _nsumDim, + // sum(a, b, c, d, ...) + '...': function _(args) { + if (containsCollections(args)) { + throw new TypeError('Scalar values expected in function sum'); + } + return _sum(args); + } + }); + + /** + * Recursively calculate the sum of an n-dimensional array + * @param {Array | Matrix} array + * @return {number} sum + * @private + */ + function _sum(array) { + var sum; + deepForEach(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + } catch (err) { + throw improveErrorMessage(err, 'sum', value); + } + }); + + // make sure returning numeric value: parse a string into a numeric value + if (sum === undefined) { + sum = numeric(0, config.number); + } + if (typeof sum === 'string') { + sum = numeric(sum, safeNumberType(sum, config)); + } + return sum; + } + function _nsumDim(array, dim) { + try { + var sum = reduce(array, dim, add); + return sum; + } catch (err) { + throw improveErrorMessage(err, 'sum'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/utils/improveErrorMessage.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/utils/improveErrorMessage.js new file mode 100644 index 0000000..9ef8737 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/utils/improveErrorMessage.js @@ -0,0 +1,25 @@ +import { typeOf } from '../../../utils/is.js'; + +/** + * Improve error messages for statistics functions. Errors are typically + * thrown in an internally used function like larger, causing the error + * not to mention the function (like max) which is actually used by the user. + * + * @param {Error} err + * @param {String} fnName + * @param {*} [value] + * @return {Error} + */ +export function improveErrorMessage(err, fnName, value) { + // TODO: add information with the index (also needs transform in expression parser) + var details; + if (String(err).includes('Unexpected type')) { + details = arguments.length > 2 ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')' : ' (type: ' + err.data.actual + ')'; + return new TypeError('Cannot calculate ' + fnName + ', unexpected type of argument' + details); + } + if (String(err).includes('complex numbers')) { + details = arguments.length > 2 ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')' : ''; + return new TypeError('Cannot calculate ' + fnName + ', no ordering relation is defined for complex numbers' + details); + } + return err; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/variance.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/variance.js new file mode 100644 index 0000000..14c6ed2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/statistics/variance.js @@ -0,0 +1,153 @@ +import { deepForEach } from '../../utils/collection.js'; +import { isBigNumber } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { improveErrorMessage } from './utils/improveErrorMessage.js'; +var DEFAULT_NORMALIZATION = 'unbiased'; +var name = 'variance'; +var dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']; +export var createVariance = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + add, + subtract, + multiply, + divide, + apply, + isNaN + } = _ref; + /** + * Compute the variance of a matrix or a list with values. + * In case of a multidimensional array or matrix, the variance over all + * elements will be calculated. + * + * Additionally, it is possible to compute the variance along the rows + * or columns of a matrix by specifying the dimension as the second argument. + * + * Optionally, the type of normalization can be specified as the final + * parameter. The parameter `normalization` can be one of the following values: + * + * - 'unbiased' (default) The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * + * + * Note that older browser may not like the variable name `var`. In that + * case, the function can be called as `math['var'](...)` instead of + * `math.var(...)`. + * + * Syntax: + * + * math.variance(a, b, c, ...) + * math.variance(A) + * math.variance(A, normalization) + * math.variance(A, dimension) + * math.variance(A, dimension, normalization) + * + * Examples: + * + * math.variance(2, 4, 6) // returns 4 + * math.variance([2, 4, 6, 8]) // returns 6.666666666666667 + * math.variance([2, 4, 6, 8], 'uncorrected') // returns 5 + * math.variance([2, 4, 6, 8], 'biased') // returns 4 + * + * math.variance([[1, 2, 3], [4, 5, 6]]) // returns 3.5 + * math.variance([[1, 2, 3], [4, 6, 8]], 0) // returns [4.5, 8, 12.5] + * math.variance([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 4] + * math.variance([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.5, 2] + * + * See also: + * + * mean, median, max, min, prod, std, sum + * + * @param {Array | Matrix} array + * A single matrix or or multiple scalar values + * @param {string} [normalization='unbiased'] + * Determines how to normalize the variance. + * Choose 'unbiased' (default), 'uncorrected', or 'biased'. + * @param dimension {number | BigNumber} + * Determines the axis to compute the variance for a matrix + * @return {*} The variance + */ + return typed(name, { + // variance([a, b, c, d, ...]) + 'Array | Matrix': function Array__Matrix(array) { + return _var(array, DEFAULT_NORMALIZATION); + }, + // variance([a, b, c, d, ...], normalization) + 'Array | Matrix, string': _var, + // variance([a, b, c, c, ...], dim) + 'Array | Matrix, number | BigNumber': function Array__Matrix_number__BigNumber(array, dim) { + return _varDim(array, dim, DEFAULT_NORMALIZATION); + }, + // variance([a, b, c, c, ...], dim, normalization) + 'Array | Matrix, number | BigNumber, string': _varDim, + // variance(a, b, c, d, ...) + '...': function _(args) { + return _var(args, DEFAULT_NORMALIZATION); + } + }); + + /** + * Recursively calculate the variance of an n-dimensional array + * @param {Array} array + * @param {string} normalization + * Determines how to normalize the variance: + * - 'unbiased' The sum of squared errors is divided by (n - 1) + * - 'uncorrected' The sum of squared errors is divided by n + * - 'biased' The sum of squared errors is divided by (n + 1) + * @return {number | BigNumber} variance + * @private + */ + function _var(array, normalization) { + var sum; + var num = 0; + if (array.length === 0) { + throw new SyntaxError('Function variance requires one or more parameters (0 provided)'); + } + + // calculate the mean and number of elements + deepForEach(array, function (value) { + try { + sum = sum === undefined ? value : add(sum, value); + num++; + } catch (err) { + throw improveErrorMessage(err, 'variance', value); + } + }); + if (num === 0) throw new Error('Cannot calculate variance of an empty array'); + var mean = divide(sum, num); + + // calculate the variance + sum = undefined; + deepForEach(array, function (value) { + var diff = subtract(value, mean); + sum = sum === undefined ? multiply(diff, diff) : add(sum, multiply(diff, diff)); + }); + if (isNaN(sum)) { + return sum; + } + switch (normalization) { + case 'uncorrected': + return divide(sum, num); + case 'biased': + return divide(sum, num + 1); + case 'unbiased': + { + var zero = isBigNumber(sum) ? sum.mul(0) : 0; + return num === 1 ? zero : divide(sum, num - 1); + } + default: + throw new Error('Unknown normalization "' + normalization + '". ' + 'Choose "unbiased" (default), "uncorrected", or "biased".'); + } + } + function _varDim(array, dim, normalization) { + try { + if (array.length === 0) { + throw new SyntaxError('Function variance requires one or more parameters (0 provided)'); + } + return apply(array, dim, x => _var(x, normalization)); + } catch (err) { + throw improveErrorMessage(err, 'variance'); + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/bin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/bin.js new file mode 100644 index 0000000..3a7ced1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/bin.js @@ -0,0 +1,44 @@ +import { factory } from '../../utils/factory.js'; +var name = 'bin'; +var dependencies = ['typed', 'format']; + +/** + * Format a number as binary. + * + * Syntax: + * + * math.bin(value) + * + * Examples: + * + * //the following outputs "0b10" + * math.bin(2) + * + * See also: + * + * oct + * hex + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ +export var createBin = factory(name, dependencies, _ref => { + var { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function number__BigNumber(n) { + return format(n, { + notation: 'bin' + }); + }, + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(n, wordSize) { + return format(n, { + notation: 'bin', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/format.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/format.js new file mode 100644 index 0000000..8ee59cc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/format.js @@ -0,0 +1,131 @@ +import { format as formatString } from '../../utils/string.js'; +import { factory } from '../../utils/factory.js'; +var name = 'format'; +var dependencies = ['typed']; +export var createFormat = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Format a value of any type into a string. + * + * Syntax: + * + * math.format(value) + * math.format(value, options) + * math.format(value, precision) + * math.format(value, callback) + * + * Where: + * + * - `value: *` + * The value to be formatted + * - `options: Object` + * An object with formatting options. Available options: + * - `notation: string` + * Number notation. Choose from: + * - `'fixed'` + * Always use regular number notation. + * For example `'123.40'` and `'14000000'` + * - `'exponential'` + * Always use exponential notation. + * For example `'1.234e+2'` and `'1.4e+7'` + * - `'engineering'` + * Always use engineering notation: always have exponential notation, + * and select the exponent to be a multiple of `3`. + * For example `'123.4e+0'` and `'14.0e+6'` + * - `'auto'` (default) + * Regular number notation for numbers having an absolute value between + * `lower` and `upper` bounds, and uses exponential notation elsewhere. + * Lower bound is included, upper bound is excluded. + * For example `'123.4'` and `'1.4e7'`. + * - `'bin'`, `'oct'`, or `'hex'` + * Format the number using binary, octal, or hexadecimal notation. + * For example `'0b1101'` and `'0x10fe'`. + * - `wordSize: number | BigNumber` + * The word size in bits to use for formatting in binary, octal, or + * hexadecimal notation. To be used only with `'bin'`, `'oct'`, or `'hex'` + * values for `notation` option. When this option is defined the value + * is formatted as a signed twos complement integer of the given word + * size and the size suffix is appended to the output. + * For example `format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'`. + * Default value is undefined. + * - `precision: number | BigNumber` + * Limit the number of digits of the formatted value. + * For regular numbers, must be a number between `0` and `16`. + * For bignumbers, the maximum depends on the configured precision, + * see function `config()`. + * In case of notations `'exponential'`, `'engineering'`, and `'auto'`, + * `precision` defines the total number of significant digits returned. + * In case of notation `'fixed'`, `precision` defines the number of + * significant digits after the decimal point. + * `precision` is undefined by default. + * - `lowerExp: number` + * Exponent determining the lower boundary for formatting a value with + * an exponent when `notation='auto'`. Default value is `-3`. + * - `upperExp: number` + * Exponent determining the upper boundary for formatting a value with + * an exponent when `notation='auto'`. Default value is `5`. + * - `fraction: string`. Available values: `'ratio'` (default) or `'decimal'`. + * For example `format(fraction(1, 3))` will output `'1/3'` when `'ratio'` + * is configured, and will output `'0.(3)'` when `'decimal'` is configured. + * - `truncate: number`. Specifies the maximum allowed length of the + * returned string. If it had been longer, the excess characters + * are deleted and replaced with `'...'`. + * - `callback: function` + * A custom formatting function, invoked for all numeric elements in `value`, + * for example all elements of a matrix, or the real and imaginary + * parts of a complex number. This callback can be used to override the + * built-in numeric notation with any type of formatting. Function `callback` + * is called with `value` as parameter and must return a string. + * + * When `value` is an Object: + * + * - When the object contains a property `format` being a function, this function + * is invoked as `value.format(options)` and the result is returned. + * - When the object has its own `toString` method, this method is invoked + * and the result is returned. + * - In other cases the function will loop over all object properties and + * return JSON object notation like '{"a": 2, "b": 3}'. + * + * When value is a function: + * + * - When the function has a property `syntax`, it returns this + * syntax description. + * - In other cases, a string `'function'` is returned. + * + * Examples: + * + * math.format(6.4) // returns '6.4' + * math.format(1240000) // returns '1.24e+6' + * math.format(1/3) // returns '0.3333333333333333' + * math.format(1/3, 3) // returns '0.333' + * math.format(21385, 2) // returns '21000' + * math.format(12e8, {notation: 'fixed'}) // returns '1200000000' + * math.format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000' + * math.format(52.8, {notation: 'exponential'}) // returns '5.28e+1' + * math.format(12400, {notation: 'engineering'}) // returns '12.4e+3' + * math.format(2000, {lowerExp: -2, upperExp: 2}) // returns '2e+3' + * + * function formatCurrency(value) { + * // return currency notation with two digits: + * return '$' + value.toFixed(2) + * + * // you could also use math.format inside the callback: + * // return '$' + math.format(value, {notation: 'fixed', precision: 2}) + * } + * math.format([2.1, 3, 0.016], formatCurrency) // returns '[$2.10, $3.00, $0.02]' + * + * See also: + * + * print + * + * @param {*} value Value to be stringified + * @param {Object | Function | number} [options] Formatting options + * @return {string} The formatted value + */ + return typed(name, { + any: formatString, + 'any, Object | function | number | BigNumber': formatString + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/hex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/hex.js new file mode 100644 index 0000000..67e8c78 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/hex.js @@ -0,0 +1,43 @@ +import { factory } from '../../utils/factory.js'; +var name = 'hex'; +var dependencies = ['typed', 'format']; + +/** + * Format a number as hexadecimal. + * + * Syntax: + * + * math.hex(value) + * + * Examples: + * + * math.hex(240) // returns "0xF0" + * + * See also: + * + * oct + * bin + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ +export var createHex = factory(name, dependencies, _ref => { + var { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function number__BigNumber(n) { + return format(n, { + notation: 'hex' + }); + }, + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(n, wordSize) { + return format(n, { + notation: 'hex', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/oct.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/oct.js new file mode 100644 index 0000000..673fd50 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/oct.js @@ -0,0 +1,45 @@ +import { factory } from '../../utils/factory.js'; +var name = 'oct'; +var dependencies = ['typed', 'format']; + +/** + * Format a number as octal. + * + * Syntax: + * + * math.oct(value) + * + * Examples: + * + * //the following outputs "0o70" + * math.oct(56) + * + * See also: + * + * bin + * hex + * + * @param {number | BigNumber} value Value to be stringified + * @param {number | BigNumber} wordSize Optional word size (see `format`) + * @return {string} The formatted value + */ + +export var createOct = factory(name, dependencies, _ref => { + var { + typed, + format + } = _ref; + return typed(name, { + 'number | BigNumber': function number__BigNumber(n) { + return format(n, { + notation: 'oct' + }); + }, + 'number | BigNumber, number | BigNumber': function number__BigNumber_number__BigNumber(n, wordSize) { + return format(n, { + notation: 'oct', + wordSize + }); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/print.js new file mode 100644 index 0000000..1f452e3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/string/print.js @@ -0,0 +1,90 @@ +import { format } from '../../utils/string.js'; +import { isString } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { printTemplate } from '../../utils/print.js'; +var name = 'print'; +var dependencies = ['typed']; +export var createPrint = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Interpolate values into a string template. + * + * Syntax: + * + * math.print(template, values) + * math.print(template, values, precision) + * math.print(template, values, options) + * + * Example usage: + * + * // the following outputs: 'Lucy is 5 years old' + * math.print('Lucy is $age years old', {age: 5}) + * + * // the following outputs: 'The value of pi is 3.141592654' + * math.print('The value of pi is $pi', {pi: math.pi}, 10) + * + * // the following outputs: 'hello Mary! The date is 2013-03-23' + * math.print('Hello $user.name! The date is $date', { + * user: { + * name: 'Mary', + * }, + * date: new Date(2013, 2, 23).toISOString().substring(0, 10) + * }) + * + * // the following outputs: 'My favorite fruits are apples and bananas !' + * math.print('My favorite fruits are $0 and $1 !', [ + * 'apples', + * 'bananas' + * ]) + * + * See also: + * + * format + * + * @param {string} template A string containing variable placeholders. + * @param {Object | Array | Matrix} values An object or array containing variables + * which will be filled in in the template. + * @param {number | Object} [options] Formatting options, + * or the number of digits to format numbers. + * See function math.format for a description + * of all options. + * @return {string} Interpolated string + */ + return typed(name, { + // note: Matrix will be converted automatically to an Array + 'string, Object | Array': _print, + 'string, Object | Array, number | Object': _print + }); +}); + +/** + * Interpolate values into a string template. + * @param {string} template + * @param {Object} values + * @param {number | Object} [options] + * @returns {string} Interpolated string + * @private + */ +function _print(template, values, options) { + return template.replace(printTemplate, function (original, key) { + var keys = key.split('.'); + var value = values[keys.shift()]; + if (value !== undefined && value.isMatrix) { + value = value.toArray(); + } + while (keys.length && value !== undefined) { + var k = keys.shift(); + value = k ? value[k] : value + '.'; + } + if (value !== undefined) { + if (!isString(value)) { + return format(value, options); + } else { + return value; + } + } + return original; + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acos.js new file mode 100644 index 0000000..e54c0ae --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acos.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +var name = 'acos'; +var dependencies = ['typed', 'config', 'Complex']; +export var createAcos = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex + } = _ref; + /** + * Calculate the inverse cosine of a value. + * + * To avoid confusion with the matrix arccosine, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acos(x) + * + * Examples: + * + * math.acos(0.5) // returns number 1.0471975511965979 + * math.acos(math.cos(1.5)) // returns number 1.5 + * + * math.acos(2) // returns Complex 0 + 1.3169578969248166 i + * + * See also: + * + * cos, atan, asin + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc cosine of x + */ + return typed(name, { + number: function number(x) { + if (x >= -1 && x <= 1 || config.predictable) { + return Math.acos(x); + } else { + return new Complex(x, 0).acos(); + } + }, + Complex: function Complex(x) { + return x.acos(); + }, + BigNumber: function BigNumber(x) { + return x.acos(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acosh.js new file mode 100644 index 0000000..11887a0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acosh.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +import { acoshNumber } from '../../plain/number/index.js'; +var name = 'acosh'; +var dependencies = ['typed', 'config', 'Complex']; +export var createAcosh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex + } = _ref; + /** + * Calculate the hyperbolic arccos of a value, + * defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.acosh(x) + * + * Examples: + * + * math.acosh(1.5) // returns 0.9624236501192069 + * + * See also: + * + * cosh, asinh, atanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccosine of x + */ + return typed(name, { + number: function number(x) { + if (x >= 1 || config.predictable) { + return acoshNumber(x); + } + if (x <= -1) { + return new Complex(Math.log(Math.sqrt(x * x - 1) - x), Math.PI); + } + return new Complex(x, 0).acosh(); + }, + Complex: function Complex(x) { + return x.acosh(); + }, + BigNumber: function BigNumber(x) { + return x.acosh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acot.js new file mode 100644 index 0000000..7f1a03b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acot.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +import { acotNumber } from '../../plain/number/index.js'; +var name = 'acot'; +var dependencies = ['typed', 'BigNumber']; +export var createAcot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the inverse cotangent of a value, defined as `acot(x) = atan(1/x)`. + * + * To avoid confusion with the matrix arccotanget, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acot(x) + * + * Examples: + * + * math.acot(0.5) // returns number 1.1071487177940904 + * math.acot(2) // returns number 0.4636476090008061 + * math.acot(math.cot(1.5)) // returns number 1.5 + * + * See also: + * + * cot, atan + * + * @param {number | BigNumber| Complex} x Function input + * @return {number | BigNumber| Complex} The arc cotangent of x + */ + return typed(name, { + number: acotNumber, + Complex: function Complex(x) { + return x.acot(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).atan(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acoth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acoth.js new file mode 100644 index 0000000..08461c0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acoth.js @@ -0,0 +1,48 @@ +import { factory } from '../../utils/factory.js'; +import { acothNumber } from '../../plain/number/index.js'; +var name = 'acoth'; +var dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +export var createAcoth = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the inverse hyperbolic tangent of a value, + * defined as `acoth(x) = atanh(1/x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`. + * + * To avoid confusion with the matrix inverse hyperbolic tangent, this + * function does not apply to matrices. + * + * Syntax: + * + * math.acoth(x) + * + * Examples: + * + * math.acoth(0.5) // returns 0.8047189562170503 + * + * See also: + * + * acsch, asech + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccotangent of x + */ + return typed(name, { + number: function number(x) { + if (x >= 1 || x <= -1 || config.predictable) { + return acothNumber(x); + } + return new Complex(x, 0).acoth(); + }, + Complex: function Complex(x) { + return x.acoth(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).atanh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsc.js new file mode 100644 index 0000000..b2c09a2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsc.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +import { acscNumber } from '../../plain/number/index.js'; +var name = 'acsc'; +var dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +export var createAcsc = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`. + * + * To avoid confusion with the matrix arccosecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.acsc(x) + * + * Examples: + * + * math.acsc(2) // returns 0.5235987755982989 + * math.acsc(0.5) // returns Complex 1.5707963267948966 -1.3169578969248166i + * math.acsc(math.csc(1.5)) // returns number ~1.5 + * + * See also: + * + * csc, asin, asec + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc cosecant of x + */ + return typed(name, { + number: function number(x) { + if (x <= -1 || x >= 1 || config.predictable) { + return acscNumber(x); + } + return new Complex(x, 0).acsc(); + }, + Complex: function Complex(x) { + return x.acsc(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).asin(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsch.js new file mode 100644 index 0000000..8e97e4a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/acsch.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +import { acschNumber } from '../../plain/number/index.js'; +var name = 'acsch'; +var dependencies = ['typed', 'BigNumber']; +export var createAcsch = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the inverse hyperbolic cosecant of a value, + * defined as `acsch(x) = asinh(1/x) = ln(1/x + sqrt(1/x^2 + 1))`. + * + * To avoid confusion with the matrix inverse hyperbolic cosecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.acsch(x) + * + * Examples: + * + * math.acsch(0.5) // returns 1.4436354751788103 + * + * See also: + * + * asech, acoth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arccosecant of x + */ + return typed(name, { + number: acschNumber, + Complex: function Complex(x) { + return x.acsch(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).asinh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asec.js new file mode 100644 index 0000000..09c0857 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asec.js @@ -0,0 +1,50 @@ +import { factory } from '../../utils/factory.js'; +import { asecNumber } from '../../plain/number/index.js'; +var name = 'asec'; +var dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +export var createAsec = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the inverse secant of a value. Defined as `asec(x) = acos(1/x)`. + * + * To avoid confusion with the matrix arcsecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.asec(x) + * + * Examples: + * + * math.asec(2) // returns 1.0471975511965979 + * math.asec(math.sec(1.5)) // returns 1.5 + * + * math.asec(0.5) // returns Complex 0 + 1.3169578969248166i + * + * See also: + * + * acos, acot, acsc + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc secant of x + */ + return typed(name, { + number: function number(x) { + if (x <= -1 || x >= 1 || config.predictable) { + return asecNumber(x); + } + return new Complex(x, 0).asec(); + }, + Complex: function Complex(x) { + return x.asec(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).acos(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asech.js new file mode 100644 index 0000000..0141b7f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asech.js @@ -0,0 +1,53 @@ +import { factory } from '../../utils/factory.js'; +import { asechNumber } from '../../plain/number/index.js'; +var name = 'asech'; +var dependencies = ['typed', 'config', 'Complex', 'BigNumber']; +export var createAsech = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the hyperbolic arcsecant of a value, + * defined as `asech(x) = acosh(1/x) = ln(sqrt(1/x^2 - 1) + 1/x)`. + * + * To avoid confusion with the matrix hyperbolic arcsecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.asech(x) + * + * Examples: + * + * math.asech(0.5) // returns 1.3169578969248166 + * + * See also: + * + * acsch, acoth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arcsecant of x + */ + return typed(name, { + number: function number(x) { + if (x <= 1 && x >= -1 || config.predictable) { + var xInv = 1 / x; + if (xInv > 0 || config.predictable) { + return asechNumber(x); + } + var ret = Math.sqrt(xInv * xInv - 1); + return new Complex(Math.log(ret - xInv), Math.PI); + } + return new Complex(x, 0).asech(); + }, + Complex: function Complex(x) { + return x.asech(); + }, + BigNumber: function BigNumber(x) { + return new _BigNumber(1).div(x).acosh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asin.js new file mode 100644 index 0000000..bc2c5b0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asin.js @@ -0,0 +1,49 @@ +import { factory } from '../../utils/factory.js'; +var name = 'asin'; +var dependencies = ['typed', 'config', 'Complex']; +export var createAsin = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex + } = _ref; + /** + * Calculate the inverse sine of a value. + * + * To avoid confusion with the matric arcsine, this function does not apply + * to matrices. + * + * Syntax: + * + * math.asin(x) + * + * Examples: + * + * math.asin(0.5) // returns number 0.5235987755982989 + * math.asin(math.sin(1.5)) // returns number ~1.5 + * + * math.asin(2) // returns Complex 1.5707963267948966 -1.3169578969248166i + * + * See also: + * + * sin, atan, acos + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc sine of x + */ + return typed(name, { + number: function number(x) { + if (x >= -1 && x <= 1 || config.predictable) { + return Math.asin(x); + } else { + return new Complex(x, 0).asin(); + } + }, + Complex: function Complex(x) { + return x.asin(); + }, + BigNumber: function BigNumber(x) { + return x.asin(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asinh.js new file mode 100644 index 0000000..0f88069 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/asinh.js @@ -0,0 +1,40 @@ +import { factory } from '../../utils/factory.js'; +import { asinhNumber } from '../../plain/number/index.js'; +var name = 'asinh'; +var dependencies = ['typed']; +export var createAsinh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the hyperbolic arcsine of a value, + * defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`. + * + * To avoid confusion with the matrix hyperbolic arcsine, this function + * does not apply to matrices. + * + * Syntax: + * + * math.asinh(x) + * + * Examples: + * + * math.asinh(0.5) // returns 0.48121182505960347 + * + * See also: + * + * acosh, atanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arcsine of x + */ + return typed('asinh', { + number: asinhNumber, + Complex: function Complex(x) { + return x.asinh(); + }, + BigNumber: function BigNumber(x) { + return x.asinh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan.js new file mode 100644 index 0000000..bf11823 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +var name = 'atan'; +var dependencies = ['typed']; +export var createAtan = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the inverse tangent of a value. + * + * To avoid confusion with matrix arctangent, this function does not apply + * to matrices. + * + * Syntax: + * + * math.atan(x) + * + * Examples: + * + * math.atan(0.5) // returns number 0.4636476090008061 + * math.atan(2) // returns number 1.1071487177940904 + * math.atan(math.tan(1.5)) // returns number 1.5 + * + * See also: + * + * tan, asin, acos + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} The arc tangent of x + */ + return typed('atan', { + number: function number(x) { + return Math.atan(x); + }, + Complex: function Complex(x) { + return x.atan(); + }, + BigNumber: function BigNumber(x) { + return x.atan(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan2.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan2.js new file mode 100644 index 0000000..41a4c87 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atan2.js @@ -0,0 +1,89 @@ +import { factory } from '../../utils/factory.js'; +import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'; +import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'; +import { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'; +import { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'; +import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'atan2'; +var dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'DenseMatrix', 'concat']; +export var createAtan2 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + equalScalar, + BigNumber, + DenseMatrix, + concat + } = _ref; + var matAlgo02xDS0 = createMatAlgo02xDS0({ + typed, + equalScalar + }); + var matAlgo03xDSf = createMatAlgo03xDSf({ + typed + }); + var matAlgo09xS0Sf = createMatAlgo09xS0Sf({ + typed, + equalScalar + }); + var matAlgo11xS0s = createMatAlgo11xS0s({ + typed, + equalScalar + }); + var matAlgo12xSfs = createMatAlgo12xSfs({ + typed, + DenseMatrix + }); + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Calculate the inverse tangent function with two arguments, y/x. + * By providing two arguments, the right quadrant of the computed angle can be + * determined. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.atan2(y, x) + * + * Examples: + * + * math.atan2(2, 2) / math.pi // returns number 0.25 + * + * const angle = math.unit(60, 'deg') // returns Unit 60 deg + * const x = math.cos(angle) + * const y = math.sin(angle) + * + * math.atan(2) // returns number 1.1071487177940904 + * + * See also: + * + * tan, atan, sin, cos + * + * @param {number | Array | Matrix} y Second dimension + * @param {number | Array | Matrix} x First dimension + * @return {number | Array | Matrix} Four-quadrant inverse tangent + */ + return typed(name, { + 'number, number': Math.atan2, + // Complex numbers doesn't seem to have a reasonable implementation of + // atan2(). Even Matlab removed the support, after they only calculated + // the atan only on base of the real part of the numbers and ignored + // the imaginary. + + 'BigNumber, BigNumber': (y, x) => BigNumber.atan2(y, x) + }, matrixAlgorithmSuite({ + scalar: 'number | BigNumber', + SS: matAlgo09xS0Sf, + DS: matAlgo03xDSf, + SD: matAlgo02xDS0, + Ss: matAlgo11xS0s, + sS: matAlgo12xSfs + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atanh.js new file mode 100644 index 0000000..ce7624a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/atanh.js @@ -0,0 +1,47 @@ +import { factory } from '../../utils/factory.js'; +import { atanhNumber } from '../../plain/number/index.js'; +var name = 'atanh'; +var dependencies = ['typed', 'config', 'Complex']; +export var createAtanh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config, + Complex + } = _ref; + /** + * Calculate the hyperbolic arctangent of a value, + * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`. + * + * To avoid confusion with the matrix hyperbolic arctangent, this function + * does not apply to matrices. + * + * Syntax: + * + * math.atanh(x) + * + * Examples: + * + * math.atanh(0.5) // returns 0.5493061443340549 + * + * See also: + * + * acosh, asinh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic arctangent of x + */ + return typed(name, { + number: function number(x) { + if (x <= 1 && x >= -1 || config.predictable) { + return atanhNumber(x); + } + return new Complex(x, 0).atanh(); + }, + Complex: function Complex(x) { + return x.atanh(); + }, + BigNumber: function BigNumber(x) { + return x.atanh(); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cos.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cos.js new file mode 100644 index 0000000..d027a6a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cos.js @@ -0,0 +1,44 @@ +import { factory } from '../../utils/factory.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'cos'; +var dependencies = ['typed']; +export var createCos = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the cosine of a value. + * + * To avoid confusion with the matrix cosine, this function does not + * apply to matrices. + * + * Syntax: + * + * math.cos(x) + * + * Examples: + * + * math.cos(2) // returns number -0.4161468365471422 + * math.cos(math.pi / 4) // returns number 0.7071067811865475 + * math.cos(math.unit(180, 'deg')) // returns number -1 + * math.cos(math.unit(60, 'deg')) // returns number 0.5 + * + * const angle = 0.2 + * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1 + * + * See also: + * + * cos, tan + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Cosine of x + */ + return typed(name, { + number: Math.cos, + 'Complex | BigNumber': x => x.cos() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cosh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cosh.js new file mode 100644 index 0000000..831409f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cosh.js @@ -0,0 +1,35 @@ +import { factory } from '../../utils/factory.js'; +import { cosh as coshNumber } from '../../utils/number.js'; +var name = 'cosh'; +var dependencies = ['typed']; +export var createCosh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the hyperbolic cosine of a value, + * defined as `cosh(x) = 1/2 * (exp(x) + exp(-x))`. + * + * To avoid confusion with the matrix hyperbolic cosine, this function does + * not apply to matrices. + * + * Syntax: + * + * math.cosh(x) + * + * Examples: + * + * math.cosh(0.5) // returns number 1.1276259652063807 + * + * See also: + * + * sinh, tanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cosine of x + */ + return typed(name, { + number: coshNumber, + 'Complex | BigNumber': x => x.cosh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cot.js new file mode 100644 index 0000000..c597776 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/cot.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +import { cotNumber } from '../../plain/number/index.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'cot'; +var dependencies = ['typed', 'BigNumber']; +export var createCot = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the cotangent of a value. Defined as `cot(x) = 1 / tan(x)`. + * + * To avoid confusion with the matrix cotangent, this function does not + * apply to matrices. + * + * Syntax: + * + * math.cot(x) + * + * Examples: + * + * math.cot(2) // returns number -0.45765755436028577 + * 1 / math.tan(2) // returns number -0.45765755436028577 + * + * See also: + * + * tan, sec, csc + * + * @param {number | Complex | Unit | Array | Matrix} x Function input + * @return {number | Complex | Array | Matrix} Cotangent of x + */ + return typed(name, { + number: cotNumber, + Complex: x => x.cot(), + BigNumber: x => new _BigNumber(1).div(x.tan()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/coth.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/coth.js new file mode 100644 index 0000000..0ec6b42 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/coth.js @@ -0,0 +1,39 @@ +import { factory } from '../../utils/factory.js'; +import { cothNumber } from '../../plain/number/index.js'; +var name = 'coth'; +var dependencies = ['typed', 'BigNumber']; +export var createCoth = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the hyperbolic cotangent of a value, + * defined as `coth(x) = 1 / tanh(x)`. + * + * To avoid confusion with the matrix hyperbolic cotangent, this function + * does not apply to matrices. + * + * Syntax: + * + * math.coth(x) + * + * Examples: + * + * // coth(x) = 1 / tanh(x) + * math.coth(2) // returns 1.0373147207275482 + * 1 / math.tanh(2) // returns 1.0373147207275482 + * + * See also: + * + * sinh, tanh, cosh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cotangent of x + */ + return typed(name, { + number: cothNumber, + Complex: x => x.coth(), + BigNumber: x => new _BigNumber(1).div(x.tanh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csc.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csc.js new file mode 100644 index 0000000..295f377 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csc.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +import { cscNumber } from '../../plain/number/index.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'csc'; +var dependencies = ['typed', 'BigNumber']; +export var createCsc = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the cosecant of a value, defined as `csc(x) = 1/sin(x)`. + * + * To avoid confusion with the matrix cosecant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.csc(x) + * + * Examples: + * + * math.csc(2) // returns number 1.099750170294617 + * 1 / math.sin(2) // returns number 1.099750170294617 + * + * See also: + * + * sin, sec, cot + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Cosecant of x + */ + return typed(name, { + number: cscNumber, + Complex: x => x.csc(), + BigNumber: x => new _BigNumber(1).div(x.sin()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csch.js new file mode 100644 index 0000000..869a32e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/csch.js @@ -0,0 +1,39 @@ +import { factory } from '../../utils/factory.js'; +import { cschNumber } from '../../plain/number/index.js'; +var name = 'csch'; +var dependencies = ['typed', 'BigNumber']; +export var createCsch = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the hyperbolic cosecant of a value, + * defined as `csch(x) = 1 / sinh(x)`. + * + * To avoid confusion with the matrix hyperbolic cosecant, this function + * does not apply to matrices. + * + * Syntax: + * + * math.csch(x) + * + * Examples: + * + * // csch(x) = 1/ sinh(x) + * math.csch(0.5) // returns 1.9190347513349437 + * 1 / math.sinh(0.5) // returns 1.9190347513349437 + * + * See also: + * + * sinh, sech, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic cosecant of x + */ + return typed(name, { + number: cschNumber, + Complex: x => x.csch(), + BigNumber: x => new _BigNumber(1).div(x.sinh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sec.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sec.js new file mode 100644 index 0000000..e8f5376 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sec.js @@ -0,0 +1,42 @@ +import { factory } from '../../utils/factory.js'; +import { secNumber } from '../../plain/number/index.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'sec'; +var dependencies = ['typed', 'BigNumber']; +export var createSec = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the secant of a value, defined as `sec(x) = 1/cos(x)`. + * + * To avoid confusion with the matrix secant, this function does not + * apply to matrices. + * + * Syntax: + * + * math.sec(x) + * + * Examples: + * + * math.sec(2) // returns number -2.4029979617223822 + * 1 / math.cos(2) // returns number -2.4029979617223822 + * + * See also: + * + * cos, csc, cot + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Secant of x + */ + return typed(name, { + number: secNumber, + Complex: x => x.sec(), + BigNumber: x => new _BigNumber(1).div(x.cos()) + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sech.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sech.js new file mode 100644 index 0000000..8caa808 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sech.js @@ -0,0 +1,39 @@ +import { factory } from '../../utils/factory.js'; +import { sechNumber } from '../../plain/number/index.js'; +var name = 'sech'; +var dependencies = ['typed', 'BigNumber']; +export var createSech = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber: _BigNumber + } = _ref; + /** + * Calculate the hyperbolic secant of a value, + * defined as `sech(x) = 1 / cosh(x)`. + * + * To avoid confusion with the matrix hyperbolic secant, this function does + * not apply to matrices. + * + * Syntax: + * + * math.sech(x) + * + * Examples: + * + * // sech(x) = 1/ cosh(x) + * math.sech(0.5) // returns 0.886818883970074 + * 1 / math.cosh(0.5) // returns 0.886818883970074 + * + * See also: + * + * cosh, csch, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic secant of x + */ + return typed(name, { + number: sechNumber, + Complex: x => x.sech(), + BigNumber: x => new _BigNumber(1).div(x.cosh()) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sin.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sin.js new file mode 100644 index 0000000..890d266 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sin.js @@ -0,0 +1,44 @@ +import { factory } from '../../utils/factory.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'sin'; +var dependencies = ['typed']; +export var createSin = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the sine of a value. + * + * To avoid confusion with the matrix sine, this function does not apply + * to matrices. + * + * Syntax: + * + * math.sin(x) + * + * Examples: + * + * math.sin(2) // returns number 0.9092974268256813 + * math.sin(math.pi / 4) // returns number 0.7071067811865475 + * math.sin(math.unit(90, 'deg')) // returns number 1 + * math.sin(math.unit(30, 'deg')) // returns number 0.5 + * + * const angle = 0.2 + * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1 + * + * See also: + * + * cos, tan + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Sine of x + */ + return typed(name, { + number: Math.sin, + 'Complex | BigNumber': x => x.sin() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sinh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sinh.js new file mode 100644 index 0000000..8b2c08c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/sinh.js @@ -0,0 +1,35 @@ +import { factory } from '../../utils/factory.js'; +import { sinhNumber } from '../../plain/number/index.js'; +var name = 'sinh'; +var dependencies = ['typed']; +export var createSinh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the hyperbolic sine of a value, + * defined as `sinh(x) = 1/2 * (exp(x) - exp(-x))`. + * + * To avoid confusion with the matrix hyperbolic sine, this function does + * not apply to matrices. + * + * Syntax: + * + * math.sinh(x) + * + * Examples: + * + * math.sinh(0.5) // returns number 0.5210953054937474 + * + * See also: + * + * cosh, tanh + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic sine of x + */ + return typed(name, { + number: sinhNumber, + 'Complex | BigNumber': x => x.sinh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tan.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tan.js new file mode 100644 index 0000000..7419e95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tan.js @@ -0,0 +1,41 @@ +import { factory } from '../../utils/factory.js'; +import { createTrigUnit } from './trigUnit.js'; +var name = 'tan'; +var dependencies = ['typed']; +export var createTan = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + var trigUnit = createTrigUnit({ + typed + }); + + /** + * Calculate the tangent of a value. `tan(x)` is equal to `sin(x) / cos(x)`. + * + * To avoid confusion with the matrix tangent, this function does not apply + * to matrices. + * + * Syntax: + * + * math.tan(x) + * + * Examples: + * + * math.tan(0.5) // returns number 0.5463024898437905 + * math.sin(0.5) / math.cos(0.5) // returns number 0.5463024898437905 + * math.tan(math.pi / 4) // returns number 1 + * math.tan(math.unit(45, 'deg')) // returns number 1 + * + * See also: + * + * atan, sin, cos + * + * @param {number | BigNumber | Complex | Unit} x Function input + * @return {number | BigNumber | Complex} Tangent of x + */ + return typed(name, { + number: Math.tan, + 'Complex | BigNumber': x => x.tan() + }, trigUnit); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tanh.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tanh.js new file mode 100644 index 0000000..d73aa80 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/tanh.js @@ -0,0 +1,38 @@ +import { factory } from '../../utils/factory.js'; +import { tanh as _tanh } from '../../utils/number.js'; +var name = 'tanh'; +var dependencies = ['typed']; +export var createTanh = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Calculate the hyperbolic tangent of a value, + * defined as `tanh(x) = (exp(2 * x) - 1) / (exp(2 * x) + 1)`. + * + * To avoid confusion with matrix hyperbolic tangent, this function does + * not apply to matrices. + * + * Syntax: + * + * math.tanh(x) + * + * Examples: + * + * // tanh(x) = sinh(x) / cosh(x) = 1 / coth(x) + * math.tanh(0.5) // returns 0.46211715726000974 + * math.sinh(0.5) / math.cosh(0.5) // returns 0.46211715726000974 + * 1 / math.coth(0.5) // returns 0.46211715726000974 + * + * See also: + * + * sinh, cosh, coth + * + * @param {number | BigNumber | Complex} x Function input + * @return {number | BigNumber | Complex} Hyperbolic tangent of x + */ + return typed('tanh', { + number: _tanh, + 'Complex | BigNumber': x => x.tanh() + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/trigUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/trigUnit.js new file mode 100644 index 0000000..ebb5411 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/trigonometry/trigUnit.js @@ -0,0 +1,14 @@ +import { factory } from '../../utils/factory.js'; +export var createTrigUnit = /* #__PURE__ */factory('trigUnit', ['typed'], _ref => { + var { + typed + } = _ref; + return { + Unit: typed.referToSelf(self => x => { + if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) { + throw new TypeError('Unit in function cot is no angle'); + } + return typed.find(self, x.valueType())(x.value); + }) + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/unit/to.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/unit/to.js new file mode 100644 index 0000000..f11a865 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/unit/to.js @@ -0,0 +1,46 @@ +import { factory } from '../../utils/factory.js'; +import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'; +var name = 'to'; +var dependencies = ['typed', 'matrix', 'concat']; +export var createTo = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix, + concat + } = _ref; + var matrixAlgorithmSuite = createMatrixAlgorithmSuite({ + typed, + matrix, + concat + }); + + /** + * Change the unit of a value. + * + * For matrices, the function is evaluated element wise. + * + * Syntax: + * + * math.to(x, unit) + * + * Examples: + * + * math.to(math.unit('2 inch'), 'cm') // returns Unit 5.08 cm + * math.to(math.unit('2 inch'), math.unit('cm')) // returns Unit 5.08 cm + * math.to(math.unit(16, 'bytes'), 'bits') // returns Unit 128 bits + * + * See also: + * + * unit + * + * @param {Unit | Array | Matrix} x The unit to be converted. + * @param {Unit | Array | Matrix} unit New unit. Can be a string like "cm" + * or a unit without value. + * @return {Unit | Array | Matrix} value with changed, fixed unit. + */ + return typed(name, { + 'Unit, Unit | string': (x, unit) => x.to(unit) + }, matrixAlgorithmSuite({ + Ds: true + })); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/clone.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/clone.js new file mode 100644 index 0000000..db81566 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/clone.js @@ -0,0 +1,30 @@ +import { clone as objectClone } from '../../utils/object.js'; +import { factory } from '../../utils/factory.js'; +var name = 'clone'; +var dependencies = ['typed']; +export var createClone = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Clone an object. Will make a deep copy of the data. + * + * Syntax: + * + * math.clone(x) + * + * Examples: + * + * math.clone(3.5) // returns number 3.5 + * math.clone(math.complex('2-4i')) // returns Complex 2 - 4i + * math.clone(math.unit(45, 'deg')) // returns Unit 45 deg + * math.clone([[1, 2], [3, 4]]) // returns Array [[1, 2], [3, 4]] + * math.clone("hello world") // returns string "hello world" + * + * @param {*} x Object to be cloned + * @return {*} A clone of object x + */ + return typed(name, { + any: objectClone + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/hasNumericValue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/hasNumericValue.js new file mode 100644 index 0000000..99d7fb7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/hasNumericValue.js @@ -0,0 +1,50 @@ +import { factory } from '../../utils/factory.js'; +var name = 'hasNumericValue'; +var dependencies = ['typed', 'isNumeric']; +export var createHasNumericValue = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + isNumeric + } = _ref; + /** + * Test whether a value is an numeric value. + * + * In case of a string, true is returned if the string contains a numeric value. + * + * Syntax: + * + * math.hasNumericValue(x) + * + * Examples: + * + * math.hasNumericValue(2) // returns true + * math.hasNumericValue('2') // returns true + * math.isNumeric('2') // returns false + * math.hasNumericValue(0) // returns true + * math.hasNumericValue(math.bignumber('500')) // returns true + * math.hasNumericValue(math.bigint('42')) // returns true + * math.hasNumericValue(42n) // returns true + * math.hasNumericValue(math.fraction(4)) // returns true + * math.hasNumericValue(math.complex('2-4i')) // returns false + * math.hasNumericValue(false) // returns true + * math.hasNumericValue([2.3, 'foo', false]) // returns [true, false, true] + * + * See also: + * + * isZero, isPositive, isNegative, isInteger, isNumeric + * + * @param {*} x Value to be tested + * @return {boolean} Returns true when `x` is a `number`, `BigNumber`, + * `Fraction`, `Boolean`, or a `String` containing number. Returns false for other types. + * Throws an error in case of unknown types. + */ + return typed(name, { + boolean: () => true, + string: function string(x) { + return x.trim().length > 0 && !isNaN(Number(x)); + }, + any: function any(x) { + return isNumeric(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isInteger.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isInteger.js new file mode 100644 index 0000000..239fafd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isInteger.js @@ -0,0 +1,54 @@ +import { deepMap } from '../../utils/collection.js'; +import { isInteger as isIntegerNumber } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'isInteger'; +var dependencies = ['typed']; +export var createIsInteger = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Test whether a value is an integer number. + * The function supports `number`, `BigNumber`, and `Fraction`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isInteger(x) + * + * Examples: + * + * math.isInteger(2) // returns true + * math.isInteger(0) // returns true + * math.isInteger(0.5) // returns false + * math.isInteger(math.bignumber(500)) // returns true + * math.isInteger(math.fraction(4)) // returns true + * math.isInteger('3') // returns true + * math.isInteger([3, 0.5, -2]) // returns [true, false, true] + * math.isInteger(math.complex('2-4i')) // throws an error + * + * See also: + * + * isNumeric, isPositive, isNegative, isZero + * + * @param {number | BigNumber | bigint | Fraction | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` contains a numeric, integer value. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: isIntegerNumber, + // TODO: what to do with isInteger(add(0.1, 0.2)) ? + + BigNumber: function BigNumber(x) { + return x.isInt(); + }, + bigint: function bigint(x) { + return true; + }, + Fraction: function Fraction(x) { + return x.d === 1 && isFinite(x.n); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNaN.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNaN.js new file mode 100644 index 0000000..30935d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNaN.js @@ -0,0 +1,58 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { isNaNNumber } from '../../plain/number/index.js'; +var name = 'isNaN'; +var dependencies = ['typed']; +export var createIsNaN = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Test whether a value is NaN (not a number). + * The function supports types `number`, `BigNumber`, `Fraction`, `Unit` and `Complex`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNaN(x) + * + * Examples: + * + * math.isNaN(3) // returns false + * math.isNaN(NaN) // returns true + * math.isNaN(0) // returns false + * math.isNaN(math.bignumber(NaN)) // returns true + * math.isNaN(math.bignumber(0)) // returns false + * math.isNaN(math.fraction(-2, 5)) // returns false + * math.isNaN('-2') // returns false + * math.isNaN([2, 0, -3, NaN]) // returns [false, false, false, true] + * + * See also: + * + * isNumeric, isNegative, isPositive, isZero, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is NaN. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: isNaNNumber, + BigNumber: function BigNumber(x) { + return x.isNaN(); + }, + bigint: function bigint(x) { + return false; + }, + Fraction: function Fraction(x) { + return false; + }, + Complex: function Complex(x) { + return x.isNaN(); + }, + Unit: function Unit(x) { + return Number.isNaN(x.value); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNegative.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNegative.js new file mode 100644 index 0000000..692b361 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNegative.js @@ -0,0 +1,52 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { isNegativeNumber } from '../../plain/number/index.js'; +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +var name = 'isNegative'; +var dependencies = ['typed', 'config']; +export var createIsNegative = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config + } = _ref; + /** + * Test whether a value is negative: smaller than zero. + * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNegative(x) + * + * Examples: + * + * math.isNegative(3) // returns false + * math.isNegative(-2) // returns true + * math.isNegative(0) // returns false + * math.isNegative(-0) // returns false + * math.isNegative(math.bignumber(2)) // returns false + * math.isNegative(math.fraction(-2, 5)) // returns true + * math.isNegative('-2') // returns true + * math.isNegative([2, 0, -3]) // returns [false, false, true] + * + * See also: + * + * isNumeric, isPositive, isZero, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isNegativeNumber(x), + BigNumber: x => bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol) ? false : x.isNeg() && !x.isZero() && !x.isNaN(), + bigint: x => x < 0n, + Fraction: x => x.s < 0, + // It's enough to decide on the sign + + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNumeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNumeric.js new file mode 100644 index 0000000..8e99aff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isNumeric.js @@ -0,0 +1,44 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'isNumeric'; +var dependencies = ['typed']; +export var createIsNumeric = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Test whether a value is an numeric value. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isNumeric(x) + * + * Examples: + * + * math.isNumeric(2) // returns true + * math.isNumeric('2') // returns false + * math.hasNumericValue('2') // returns true + * math.isNumeric(0) // returns true + * math.isNumeric(math.bignumber('42')) // returns true + * math.isNumeric(math.bigint('42')) // returns true + * math.isNumeric(math.fraction(4)) // returns true + * math.isNumeric(math.complex('2-4i')) // returns false + * math.isNumeric([2.3, 'foo', false]) // returns [true, false, true] + * + * See also: + * + * isZero, isPositive, isNegative, isInteger, hasNumericValue + * + * @param {*} x Value to be tested + * @return {boolean} Returns true when `x` is a `number`, `BigNumber`, + * `Fraction`, or `boolean`. Returns false for other types. + * Throws an error in case of unknown types. + */ + return typed(name, { + 'number | BigNumber | bigint | Fraction | boolean': () => true, + 'Complex | Unit | string | null | undefined | Node': () => false, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPositive.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPositive.js new file mode 100644 index 0000000..443a2a8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPositive.js @@ -0,0 +1,52 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +import { isPositiveNumber } from '../../plain/number/index.js'; +import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'; +import { nearlyEqual } from '../../utils/number.js'; +var name = 'isPositive'; +var dependencies = ['typed', 'config']; +export var createIsPositive = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + config + } = _ref; + /** + * Test whether a value is positive: larger than zero. + * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isPositive(x) + * + * Examples: + * + * math.isPositive(3) // returns true + * math.isPositive(-2) // returns false + * math.isPositive(0) // returns false + * math.isPositive(-0) // returns false + * math.isPositive(0.5) // returns true + * math.isPositive(math.bignumber(2)) // returns true + * math.isPositive(math.fraction(-2, 5)) // returns false + * math.isPositive(math.fraction(1, 3)) // returns true + * math.isPositive('2') // returns true + * math.isPositive([2, 0, -3]) // returns [true, false, false] + * + * See also: + * + * isNumeric, isZero, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isPositiveNumber(x), + BigNumber: x => bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol) ? false : !x.isNeg() && !x.isZero() && !x.isNaN(), + bigint: x => x > 0n, + Fraction: x => x.s > 0 && x.n > 0, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPrime.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPrime.js new file mode 100644 index 0000000..04b92f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isPrime.js @@ -0,0 +1,130 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'isPrime'; +var dependencies = ['typed']; +export var createIsPrime = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Test whether a value is prime: has no divisors other than itself and one. + * The function supports type `number`, `bignumber`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isPrime(x) + * + * Examples: + * + * math.isPrime(3) // returns true + * math.isPrime(-2) // returns false + * math.isPrime(0) // returns false + * math.isPrime(-0) // returns false + * math.isPrime(0.5) // returns false + * math.isPrime('2') // returns true + * math.isPrime([2, 17, 100]) // returns [true, true, false] + * + * See also: + * + * isNumeric, isZero, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is larger than zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + number: function number(x) { + if (x <= 3) { + return x > 1; + } + if (x % 2 === 0 || x % 3 === 0) { + return false; + } + for (var i = 5; i * i <= x; i += 6) { + if (x % i === 0 || x % (i + 2) === 0) { + return false; + } + } + return true; + }, + bigint: function bigint(x) { + if (x <= 3n) { + return x > 1n; + } + if (x % 2n === 0n || x % 3n === 0n) { + return false; + } + for (var i = 5n; i * i <= x; i += 6n) { + if (x % i === 0n || x % (i + 2n) === 0n) { + return false; + } + } + return true; + }, + BigNumber: function BigNumber(n) { + if (n.lte(3)) return n.gt(1); + if (n.mod(2).eq(0) || n.mod(3).eq(0)) return false; + if (n.lt(Math.pow(2, 32))) { + var x = n.toNumber(); + for (var i = 5; i * i <= x; i += 6) { + if (x % i === 0 || x % (i + 2) === 0) { + return false; + } + } + return true; + } + function modPow(base, exponent, modulus) { + // exponent can be huge, use non-recursive variant + var accumulator = 1; + while (!exponent.eq(0)) { + if (exponent.mod(2).eq(0)) { + exponent = exponent.div(2); + base = base.mul(base).mod(modulus); + } else { + exponent = exponent.sub(1); + accumulator = base.mul(accumulator).mod(modulus); + } + } + return accumulator; + } + + // https://en.wikipedia.org/wiki/Miller%E2%80%93Rabin_primality_test#Deterministic_variants + var Decimal = n.constructor.clone({ + precision: n.toFixed(0).length * 2 + }); + n = new Decimal(n); + var r = 0; + var d = n.sub(1); + while (d.mod(2).eq(0)) { + d = d.div(2); + r += 1; + } + var bases = null; + // https://en.wikipedia.org/wiki/Miller–Rabin_primality_test#Testing_against_small_sets_of_bases + if (n.lt('3317044064679887385961981')) { + bases = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41].filter(x => x < n); + } else { + var max = Math.min(n.toNumber() - 2, Math.floor(2 * Math.pow(n.toFixed(0).length * Math.log(10), 2))); + bases = []; + for (var _i = 2; _i <= max; _i += 1) { + bases.push(max); + } + } + for (var _i2 = 0; _i2 < bases.length; _i2 += 1) { + var a = bases[_i2]; + var adn = modPow(n.sub(n).add(a), d, n); + if (!adn.eq(1)) { + for (var _i3 = 0, _x = adn; !_x.eq(n.sub(1)); _i3 += 1, _x = _x.mul(_x).mod(n)) { + if (_i3 === r - 1) { + return false; + } + } + } + } + return true; + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isZero.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isZero.js new file mode 100644 index 0000000..726ea7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/isZero.js @@ -0,0 +1,49 @@ +import { deepMap } from '../../utils/collection.js'; +import { factory } from '../../utils/factory.js'; +var name = 'isZero'; +var dependencies = ['typed', 'equalScalar']; +export var createIsZero = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Test whether a value is zero. + * The function can check for zero for types `number`, `BigNumber`, `Fraction`, + * `Complex`, and `Unit`. + * + * The function is evaluated element-wise in case of Array or Matrix input. + * + * Syntax: + * + * math.isZero(x) + * + * Examples: + * + * math.isZero(0) // returns true + * math.isZero(2) // returns false + * math.isZero(0.5) // returns false + * math.isZero(math.bignumber(0)) // returns true + * math.isZero(math.fraction(0)) // returns true + * math.isZero(math.fraction(1,3)) // returns false + * math.isZero(math.complex('2 - 4i')) // returns false + * math.isZero(math.complex('0i')) // returns true + * math.isZero('0') // returns true + * math.isZero('2') // returns false + * math.isZero([2, 0, -3]) // returns [false, true, false] + * + * See also: + * + * isNumeric, isPositive, isNegative, isInteger + * + * @param {number | BigNumber | bigint | Complex | Fraction | Unit | Array | Matrix} x Value to be tested + * @return {boolean} Returns true when `x` is zero. + * Throws an error in case of an unknown data type. + */ + return typed(name, { + 'number | BigNumber | Complex | Fraction': x => equalScalar(x, 0), + bigint: x => x === 0n, + Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)), + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/numeric.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/numeric.js new file mode 100644 index 0000000..3ffaa81 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/numeric.js @@ -0,0 +1,75 @@ +import { typeOf } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { noBignumber, noFraction } from '../../utils/noop.js'; +var name = 'numeric'; +var dependencies = ['number', '?bignumber', '?fraction']; +export var createNumeric = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + number: _number, + bignumber, + fraction + } = _ref; + var validInputTypes = { + string: true, + number: true, + BigNumber: true, + Fraction: true + }; + + // Load the conversion functions for each output type + var validOutputTypes = { + number: x => _number(x), + BigNumber: bignumber ? x => bignumber(x) : noBignumber, + bigint: x => BigInt(x), + Fraction: fraction ? x => fraction(x) : noFraction + }; + + /** + * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction. + * + * Syntax: + * + * math.numeric(x) + * + * Examples: + * + * math.numeric('4') // returns 4 + * math.numeric('4', 'number') // returns 4 + * math.numeric('4', 'bigint') // returns 4n + * math.numeric('4', 'BigNumber') // returns BigNumber 4 + * math.numeric('4', 'Fraction') // returns Fraction 4 + * math.numeric(4, 'Fraction') // returns Fraction 4 + * math.numeric(math.fraction(2, 5), 'number') // returns 0.4 + * + * See also: + * + * number, fraction, bignumber, bigint, string, format + * + * @param {string | number | BigNumber | bigint | Fraction } value + * A numeric value or a string containing a numeric value + * @param {string} outputType + * Desired numeric output type. + * Available values: 'number', 'BigNumber', or 'Fraction' + * @return {number | BigNumber | bigint | Fraction} + * Returns an instance of the numeric in the requested type + */ + return function numeric(value) { + var outputType = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'number'; + var check = arguments.length > 2 ? arguments[2] : undefined; + if (check !== undefined) { + throw new SyntaxError('numeric() takes one or two arguments'); + } + var inputType = typeOf(value); + if (!(inputType in validInputTypes)) { + throw new TypeError('Cannot convert ' + value + ' of type "' + inputType + '"; valid input types are ' + Object.keys(validInputTypes).join(', ')); + } + if (!(outputType in validOutputTypes)) { + throw new TypeError('Cannot convert ' + value + ' to type "' + outputType + '"; valid output types are ' + Object.keys(validOutputTypes).join(', ')); + } + if (outputType === inputType) { + return value; + } else { + return validOutputTypes[outputType](value); + } + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/typeOf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/typeOf.js new file mode 100644 index 0000000..c20d278 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/function/utils/typeOf.js @@ -0,0 +1,65 @@ +import { factory } from '../../utils/factory.js'; +import { typeOf as _typeOf } from '../../utils/is.js'; +var name = 'typeOf'; +var dependencies = ['typed']; +export var createTypeOf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Determine the type of an entity. + * + * Syntax: + * + * math.typeOf(x) + * + * Examples: + * + * // This list is intended to include all relevant types, for testing + * // purposes: + * math.typeOf(3.5) // returns 'number' + * math.typeOf(42n) // returns 'bigint' + * math.typeOf(math.complex('2-4i')) // returns 'Complex' + * math.typeOf(math.unit('45 deg')) // returns 'Unit' + * math.typeOf('hello world') // returns 'string' + * math.typeOf(null) // returns 'null' + * math.typeOf(true) // returns 'boolean' + * math.typeOf([1, 2, 3]) // returns 'Array' + * math.typeOf(new Date()) // returns 'Date' + * math.typeOf(function () {}) // returns 'function' + * math.typeOf({a: 2, b: 3}) // returns 'Object' + * math.typeOf(/a regexp/) // returns 'RegExp' + * math.typeOf(undefined) // returns 'undefined' + * math.typeOf(math.bignumber('23e99')) // returns 'BigNumber' + * math.typeOf(math.chain(2)) // returns 'Chain' + * math.typeOf(math.fraction(1, 3)) // returns 'Fraction' + * math.typeOf(math.help('sqrt')) // returns 'Help' + * math.typeOf(math.index(1, 3)) // returns 'Index' + * math.typeOf(math.matrix([[1],[3]])) // returns 'DenseMatrix' + * math.typeOf(math.matrix([],'sparse')) // returns 'SparseMatrix' + * math.typeOf(new math.Range(0, 10)) // returns 'Range' + * math.typeOf(math.evaluate('a=2\na')) // returns 'ResultSet' + * math.typeOf(math.parse('A[2]')) // returns 'AccessorNode' + * math.typeOf(math.parse('[1,2,3]')) // returns 'ArrayNode' + * math.typeOf(math.parse('x=2')) // returns 'AssignmentNode' + * math.typeOf(math.parse('a=2; b=3')) // returns 'BlockNode' + * math.typeOf(math.parse('x<0?-1:1')) // returns 'ConditionalNode' + * math.typeOf(math.parse('2.3')) // returns 'ConstantNode' + * math.typeOf(math.parse('f(x)=x^2')) // returns 'FunctionAssignmentNode' + * math.typeOf(math.parse('sqrt(4)')) // returns 'FunctionNode' + * math.typeOf(math.parse('A[2]').index) // returns 'IndexNode' + * math.typeOf(math.parse('{a:2}')) // returns 'ObjectNode' + * math.typeOf(math.parse('(2+3)')) // returns 'ParenthesisNode' + * math.typeOf(math.parse('1:10')) // returns 'RangeNode' + * math.typeOf(math.parse('a + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy + * of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/index.js new file mode 100644 index 0000000..7e74c6c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/index.js @@ -0,0 +1 @@ +export * from './entry/mainAny.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/replacer.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/replacer.js new file mode 100644 index 0000000..2bed9f3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/replacer.js @@ -0,0 +1,33 @@ +import { factory } from '../utils/factory.js'; +var name = 'replacer'; +var dependencies = []; +export var createReplacer = /* #__PURE__ */factory(name, dependencies, () => { + /** + * Stringify data types into their JSON representation. + * Most data types can be serialized using their `.toJSON` method, + * but not all, for example the number `Infinity`. For these cases you have + * to use the replacer. Example usage: + * + * JSON.stringify([2, Infinity], math.replacer) + * + * @param {string} key + * @param {*} value + * @returns {*} Returns the replaced object + */ + return function replacer(key, value) { + // the numeric values Infinitiy, -Infinity, and NaN cannot be serialized to JSON + if (typeof value === 'number' && (!isFinite(value) || isNaN(value))) { + return { + mathjs: 'number', + value: String(value) + }; + } + if (typeof value === 'bigint') { + return { + mathjs: 'bigint', + value: String(value) + }; + } + return value; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/reviver.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/reviver.js new file mode 100644 index 0000000..982218a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/json/reviver.js @@ -0,0 +1,21 @@ +import { factory } from '../utils/factory.js'; +var name = 'reviver'; +var dependencies = ['classes']; +export var createReviver = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + classes + } = _ref; + /** + * Instantiate mathjs data types from their JSON representation + * @param {string} key + * @param {*} value + * @returns {*} Returns the revived object + */ + return function reviver(key, value) { + var constructor = classes[value && value.mathjs]; + if (constructor && typeof constructor.fromJSON === 'function') { + return constructor.fromJSON(value); + } + return value; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/number.js new file mode 100644 index 0000000..5181f6c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/number.js @@ -0,0 +1 @@ +export * from './entry/mainNumber.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/arithmetic.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/arithmetic.js new file mode 100644 index 0000000..2cf9080 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/arithmetic.js @@ -0,0 +1,22 @@ +var signature1 = 'BigNumber'; +var signature2 = 'BigNumber, BigNumber'; +export function absBigNumber(a) { + return a.abs(); +} +absBigNumber.signature = signature1; +export function addBigNumber(a, b) { + return a.add(b); +} +addBigNumber.signature = signature2; +export function subtractBigNumber(a, b) { + return a.sub(b); +} +subtractBigNumber.signature = signature2; +export function multiplyBigNumber(a, b) { + return a.mul(b); +} +multiplyBigNumber.signature = signature2; +export function divideBigNumber(a, b) { + return a.div(b); +} +divideBigNumber.signature = signature2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/index.js new file mode 100644 index 0000000..a60ccf4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/bignumber/index.js @@ -0,0 +1,9 @@ +import Decimal from 'decimal.js'; +export * from './arithmetic.js'; + +// TODO: this is ugly. Instead, be able to pass your own isBigNumber function to typed? +var BigNumber = Decimal.clone(); +BigNumber.prototype.isBigNumber = true; +export function bignumber(x) { + return new BigNumber(x); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/arithmetic.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/arithmetic.js new file mode 100644 index 0000000..d47fd95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/arithmetic.js @@ -0,0 +1,303 @@ +import { cbrt, expm1, isInteger, log10, log1p, log2, sign, toFixed } from '../../utils/number.js'; +var n1 = 'number'; +var n2 = 'number, number'; +export function absNumber(a) { + return Math.abs(a); +} +absNumber.signature = n1; +export function addNumber(a, b) { + return a + b; +} +addNumber.signature = n2; +export function subtractNumber(a, b) { + return a - b; +} +subtractNumber.signature = n2; +export function multiplyNumber(a, b) { + return a * b; +} +multiplyNumber.signature = n2; +export function divideNumber(a, b) { + return a / b; +} +divideNumber.signature = n2; +export function unaryMinusNumber(x) { + return -x; +} +unaryMinusNumber.signature = n1; +export function unaryPlusNumber(x) { + return x; +} +unaryPlusNumber.signature = n1; +export function cbrtNumber(x) { + return cbrt(x); +} +cbrtNumber.signature = n1; +export function cubeNumber(x) { + return x * x * x; +} +cubeNumber.signature = n1; +export function expNumber(x) { + return Math.exp(x); +} +expNumber.signature = n1; +export function expm1Number(x) { + return expm1(x); +} +expm1Number.signature = n1; + +/** + * Calculate gcd for numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the greatest common denominator of a and b + */ +export function gcdNumber(a, b) { + if (!isInteger(a) || !isInteger(b)) { + throw new Error('Parameters in function gcd must be integer numbers'); + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + var r; + while (b !== 0) { + r = a % b; + a = b; + b = r; + } + return a < 0 ? -a : a; +} +gcdNumber.signature = n2; + +/** + * Calculate lcm for two numbers + * @param {number} a + * @param {number} b + * @returns {number} Returns the least common multiple of a and b + */ +export function lcmNumber(a, b) { + if (!isInteger(a) || !isInteger(b)) { + throw new Error('Parameters in function lcm must be integer numbers'); + } + if (a === 0 || b === 0) { + return 0; + } + + // https://en.wikipedia.org/wiki/Euclidean_algorithm + // evaluate lcm here inline to reduce overhead + var t; + var prod = a * b; + while (b !== 0) { + t = b; + b = a % t; + a = t; + } + return Math.abs(prod / a); +} +lcmNumber.signature = n2; + +/** + * Calculate the logarithm of a value, optionally to a given base. + * @param {number} x + * @param {number | null | undefined} base + * @return {number} + */ +export function logNumber(x, y) { + if (y) { + return Math.log(x) / Math.log(y); + } + return Math.log(x); +} + +/** + * Calculate the 10-base logarithm of a number + * @param {number} x + * @return {number} + */ +export function log10Number(x) { + return log10(x); +} +log10Number.signature = n1; + +/** + * Calculate the 2-base logarithm of a number + * @param {number} x + * @return {number} + */ +export function log2Number(x) { + return log2(x); +} +log2Number.signature = n1; + +/** + * Calculate the natural logarithm of a `number+1` + * @param {number} x + * @returns {number} + */ +export function log1pNumber(x) { + return log1p(x); +} +log1pNumber.signature = n1; + +/** + * Calculate the modulus of two numbers + * @param {number} x + * @param {number} y + * @returns {number} res + * @private + */ +export function modNumber(x, y) { + // We don't use JavaScript's % operator here as this doesn't work + // correctly for x < 0 and x === 0 + // see https://en.wikipedia.org/wiki/Modulo_operation + return y === 0 ? x : x - y * Math.floor(x / y); +} +modNumber.signature = n2; + +/** + * Calculate the nth root of a, solve x^root == a + * http://rosettacode.org/wiki/Nth_root#JavaScript + * @param {number} a + * @param {number} [2] root + * @private + */ +export function nthRootNumber(a) { + var root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 2; + var inv = root < 0; + if (inv) { + root = -root; + } + if (root === 0) { + throw new Error('Root must be non-zero'); + } + if (a < 0 && Math.abs(root) % 2 !== 1) { + throw new Error('Root must be odd when a is negative.'); + } + + // edge cases zero and infinity + if (a === 0) { + return inv ? Infinity : 0; + } + if (!isFinite(a)) { + return inv ? 0 : a; + } + var x = Math.pow(Math.abs(a), 1 / root); + // If a < 0, we require that root is an odd integer, + // so (-1) ^ (1/root) = -1 + x = a < 0 ? -x : x; + return inv ? 1 / x : x; + + // Very nice algorithm, but fails with nthRoot(-2, 3). + // Newton's method has some well-known problems at times: + // https://en.wikipedia.org/wiki/Newton%27s_method#Failure_analysis + /* + let x = 1 // Initial guess + let xPrev = 1 + let i = 0 + const iMax = 10000 + do { + const delta = (a / Math.pow(x, root - 1) - x) / root + xPrev = x + x = x + delta + i++ + } + while (xPrev !== x && i < iMax) + if (xPrev !== x) { + throw new Error('Function nthRoot failed to converge') + } + return inv ? 1 / x : x + */ +} +export function signNumber(x) { + return sign(x); +} +signNumber.signature = n1; +export function sqrtNumber(x) { + return Math.sqrt(x); +} +sqrtNumber.signature = n1; +export function squareNumber(x) { + return x * x; +} +squareNumber.signature = n1; + +/** + * Calculate xgcd for two numbers + * @param {number} a + * @param {number} b + * @return {number} result + * @private + */ +export function xgcdNumber(a, b) { + // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm + var t; // used to swap two variables + var q; // quotient + var r; // remainder + var x = 0; + var lastx = 1; + var y = 1; + var lasty = 0; + if (!isInteger(a) || !isInteger(b)) { + throw new Error('Parameters in function xgcd must be integer numbers'); + } + while (b) { + q = Math.floor(a / b); + r = a - q * b; + t = x; + x = lastx - q * x; + lastx = t; + t = y; + y = lasty - q * y; + lasty = t; + a = b; + b = r; + } + var res; + if (a < 0) { + res = [-a, -lastx, -lasty]; + } else { + res = [a, a ? lastx : 0, lasty]; + } + return res; +} +xgcdNumber.signature = n2; + +/** + * Calculates the power of x to y, x^y, for two numbers. + * @param {number} x + * @param {number} y + * @return {number} res + */ +export function powNumber(x, y) { + // x^Infinity === 0 if -1 < x < 1 + // A real number 0 is returned instead of complex(0) + if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) { + return 0; + } + return Math.pow(x, y); +} +powNumber.signature = n2; + +/** + * round a number to the given number of decimals, or to zero if decimals is + * not provided + * @param {number} value + * @param {number} decimals number of decimals, between 0 and 15 (0 by default) + * @return {number} roundedValue + */ +export function roundNumber(value) { + var decimals = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; + if (!isInteger(decimals) || decimals < 0 || decimals > 15) { + throw new Error('Number of decimals in function round must be an integer from 0 to 15 inclusive'); + } + return parseFloat(toFixed(value, decimals)); +} + +/** + * Calculate the norm of a number, the absolute value. + * @param {number} x + * @return {number} + */ +export function normNumber(x) { + return Math.abs(x); +} +normNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/bitwise.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/bitwise.js new file mode 100644 index 0000000..0d21693 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/bitwise.js @@ -0,0 +1,52 @@ +import { isInteger } from '../../utils/number.js'; +var n1 = 'number'; +var n2 = 'number, number'; +export function bitAndNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function bitAnd'); + } + return x & y; +} +bitAndNumber.signature = n2; +export function bitNotNumber(x) { + if (!isInteger(x)) { + throw new Error('Integer expected in function bitNot'); + } + return ~x; +} +bitNotNumber.signature = n1; +export function bitOrNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function bitOr'); + } + return x | y; +} +bitOrNumber.signature = n2; +export function bitXorNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function bitXor'); + } + return x ^ y; +} +bitXorNumber.signature = n2; +export function leftShiftNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function leftShift'); + } + return x << y; +} +leftShiftNumber.signature = n2; +export function rightArithShiftNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function rightArithShift'); + } + return x >> y; +} +rightArithShiftNumber.signature = n2; +export function rightLogShiftNumber(x, y) { + if (!isInteger(x) || !isInteger(y)) { + throw new Error('Integers expected in function rightLogShift'); + } + return x >>> y; +} +rightLogShiftNumber.signature = n2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/combinations.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/combinations.js new file mode 100644 index 0000000..a102eed --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/combinations.js @@ -0,0 +1,33 @@ +import { isInteger } from '../../utils/number.js'; +import { product } from '../../utils/product.js'; +export function combinationsNumber(n, k) { + if (!isInteger(n) || n < 0) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (!isInteger(k) || k < 0) { + throw new TypeError('Positive integer value expected in function combinations'); + } + if (k > n) { + throw new TypeError('k must be less than or equal to n'); + } + var nMinusk = n - k; + var answer = 1; + var firstnumerator = k < nMinusk ? nMinusk + 1 : k + 1; + var nextdivisor = 2; + var lastdivisor = k < nMinusk ? k : nMinusk; + // balance multiplications and divisions to try to keep intermediate values + // in exact-integer range as long as possible + for (var nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) { + answer *= nextnumerator; + while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) { + answer /= nextdivisor; + ++nextdivisor; + } + } + // for big n, k, floating point may have caused weirdness in remainder + if (nextdivisor <= lastdivisor) { + answer /= product(nextdivisor, lastdivisor); + } + return answer; +} +combinationsNumber.signature = 'number, number'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/constants.js new file mode 100644 index 0000000..a544965 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/constants.js @@ -0,0 +1,4 @@ +export var pi = Math.PI; +export var tau = 2 * Math.PI; +export var e = Math.E; +export var phi = 1.6180339887498948; // eslint-disable-line no-loss-of-precision \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/index.js new file mode 100644 index 0000000..769d9fc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/index.js @@ -0,0 +1,9 @@ +export * from './arithmetic.js'; +export * from './bitwise.js'; +export * from './combinations.js'; +export * from './constants.js'; +export * from './logical.js'; +export * from './relational.js'; +export * from './probability.js'; +export * from './trigonometry.js'; +export * from './utils.js'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/logical.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/logical.js new file mode 100644 index 0000000..61f2d60 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/logical.js @@ -0,0 +1,18 @@ +var n1 = 'number'; +var n2 = 'number, number'; +export function notNumber(x) { + return !x; +} +notNumber.signature = n1; +export function orNumber(x, y) { + return !!(x || y); +} +orNumber.signature = n2; +export function xorNumber(x, y) { + return !!x !== !!y; +} +xorNumber.signature = n2; +export function andNumber(x, y) { + return !!(x && y); +} +andNumber.signature = n2; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/probability.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/probability.js new file mode 100644 index 0000000..16a8be0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/probability.js @@ -0,0 +1,75 @@ +/* eslint-disable no-loss-of-precision */ + +import { isInteger } from '../../utils/number.js'; +import { product } from '../../utils/product.js'; +export function gammaNumber(n) { + var x; + if (isInteger(n)) { + if (n <= 0) { + return isFinite(n) ? Infinity : NaN; + } + if (n > 171) { + return Infinity; // Will overflow + } + return product(1, n - 1); + } + if (n < 0.5) { + return Math.PI / (Math.sin(Math.PI * n) * gammaNumber(1 - n)); + } + if (n >= 171.35) { + return Infinity; // will overflow + } + if (n > 85.0) { + // Extended Stirling Approx + var twoN = n * n; + var threeN = twoN * n; + var fourN = threeN * n; + var fiveN = fourN * n; + return Math.sqrt(2 * Math.PI / n) * Math.pow(n / Math.E, n) * (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) - 571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) + 5246819 / (75246796800 * fiveN * n)); + } + --n; + x = gammaP[0]; + for (var i = 1; i < gammaP.length; ++i) { + x += gammaP[i] / (n + i); + } + var t = n + gammaG + 0.5; + return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x; +} +gammaNumber.signature = 'number'; + +// TODO: comment on the variables g and p + +export var gammaG = 4.7421875; +export var gammaP = [0.99999999999999709182, 57.156235665862923517, -59.597960355475491248, 14.136097974741747174, -0.49191381609762019978, 0.33994649984811888699e-4, 0.46523628927048575665e-4, -0.98374475304879564677e-4, 0.15808870322491248884e-3, -0.21026444172410488319e-3, 0.21743961811521264320e-3, -0.16431810653676389022e-3, 0.84418223983852743293e-4, -0.26190838401581408670e-4, 0.36899182659531622704e-5]; + +// lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code + +// log(2 * pi) / 2 +export var lnSqrt2PI = 0.91893853320467274178; +export var lgammaG = 5; // Lanczos parameter "g" +export var lgammaN = 7; // Range of coefficients "n" + +export var lgammaSeries = [1.000000000190015, 76.18009172947146, -86.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5]; +export function lgammaNumber(n) { + if (n < 0) return NaN; + if (n === 0) return Infinity; + if (!isFinite(n)) return n; + if (n < 0.5) { + // Use Euler's reflection formula: + // gamma(z) = PI / (sin(PI * z) * gamma(1 - z)) + return Math.log(Math.PI / Math.sin(Math.PI * n)) - lgammaNumber(1 - n); + } + + // Compute the logarithm of the Gamma function using the Lanczos method + + n = n - 1; + var base = n + lgammaG + 0.5; // Base of the Lanczos exponential + var sum = lgammaSeries[0]; + + // We start with the terms that have the smallest coefficients and largest denominator + for (var i = lgammaN - 1; i >= 1; i--) { + sum += lgammaSeries[i] / (n + i); + } + return lnSqrt2PI + (n + 0.5) * Math.log(base) - base + Math.log(sum); +} +lgammaNumber.signature = 'number'; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/relational.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/relational.js new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/trigonometry.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/trigonometry.js new file mode 100644 index 0000000..6a49a62 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/trigonometry.js @@ -0,0 +1,112 @@ +import { acosh, asinh, atanh, cosh, sign, sinh, tanh } from '../../utils/number.js'; +var n1 = 'number'; +var n2 = 'number, number'; +export function acosNumber(x) { + return Math.acos(x); +} +acosNumber.signature = n1; +export function acoshNumber(x) { + return acosh(x); +} +acoshNumber.signature = n1; +export function acotNumber(x) { + return Math.atan(1 / x); +} +acotNumber.signature = n1; +export function acothNumber(x) { + return isFinite(x) ? (Math.log((x + 1) / x) + Math.log(x / (x - 1))) / 2 : 0; +} +acothNumber.signature = n1; +export function acscNumber(x) { + return Math.asin(1 / x); +} +acscNumber.signature = n1; +export function acschNumber(x) { + var xInv = 1 / x; + return Math.log(xInv + Math.sqrt(xInv * xInv + 1)); +} +acschNumber.signature = n1; +export function asecNumber(x) { + return Math.acos(1 / x); +} +asecNumber.signature = n1; +export function asechNumber(x) { + var xInv = 1 / x; + var ret = Math.sqrt(xInv * xInv - 1); + return Math.log(ret + xInv); +} +asechNumber.signature = n1; +export function asinNumber(x) { + return Math.asin(x); +} +asinNumber.signature = n1; +export function asinhNumber(x) { + return asinh(x); +} +asinhNumber.signature = n1; +export function atanNumber(x) { + return Math.atan(x); +} +atanNumber.signature = n1; +export function atan2Number(y, x) { + return Math.atan2(y, x); +} +atan2Number.signature = n2; +export function atanhNumber(x) { + return atanh(x); +} +atanhNumber.signature = n1; +export function cosNumber(x) { + return Math.cos(x); +} +cosNumber.signature = n1; +export function coshNumber(x) { + return cosh(x); +} +coshNumber.signature = n1; +export function cotNumber(x) { + return 1 / Math.tan(x); +} +cotNumber.signature = n1; +export function cothNumber(x) { + var e = Math.exp(2 * x); + return (e + 1) / (e - 1); +} +cothNumber.signature = n1; +export function cscNumber(x) { + return 1 / Math.sin(x); +} +cscNumber.signature = n1; +export function cschNumber(x) { + // consider values close to zero (+/-) + if (x === 0) { + return Number.POSITIVE_INFINITY; + } else { + return Math.abs(2 / (Math.exp(x) - Math.exp(-x))) * sign(x); + } +} +cschNumber.signature = n1; +export function secNumber(x) { + return 1 / Math.cos(x); +} +secNumber.signature = n1; +export function sechNumber(x) { + return 2 / (Math.exp(x) + Math.exp(-x)); +} +sechNumber.signature = n1; +export function sinNumber(x) { + return Math.sin(x); +} +sinNumber.signature = n1; +export function sinhNumber(x) { + return sinh(x); +} +sinhNumber.signature = n1; +export function tanNumber(x) { + return Math.tan(x); +} +tanNumber.signature = n1; +export function tanhNumber(x) { + return tanh(x); +} +tanhNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/utils.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/utils.js new file mode 100644 index 0000000..fec97d5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/plain/number/utils.js @@ -0,0 +1,22 @@ +import { isInteger } from '../../utils/number.js'; +var n1 = 'number'; +export function isIntegerNumber(x) { + return isInteger(x); +} +isIntegerNumber.signature = n1; +export function isNegativeNumber(x) { + return x < 0; +} +isNegativeNumber.signature = n1; +export function isPositiveNumber(x) { + return x > 0; +} +isPositiveNumber.signature = n1; +export function isZeroNumber(x) { + return x === 0; +} +isZeroNumber.signature = n1; +export function isNaNNumber(x) { + return Number.isNaN(x); +} +isNaNNumber.signature = n1; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bigint.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bigint.js new file mode 100644 index 0000000..1432a5a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bigint.js @@ -0,0 +1,65 @@ +import { factory } from '../utils/factory.js'; +import { deepMap } from '../utils/collection.js'; +var name = 'bigint'; +var dependencies = ['typed']; +export var createBigint = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Create a bigint or convert a string, boolean, or unit to a bigint. + * When value is a matrix, all elements will be converted to bigint. + * + * Syntax: + * + * math.bigint(value) + * + * Examples: + * + * math.bigint(2) // returns 2n + * math.bigint('123') // returns 123n + * math.bigint(true) // returns 1n + * math.bigint([true, false, true, true]) // returns [1n, 0n, 1n, 1n] + * + * See also: + * + * number, bignumber, boolean, complex, index, matrix, string, unit + * + * @param {string | number | BigNumber | bigint | Fraction | boolean | Array | Matrix | null} [value] Value to be converted + * @return {bigint | Array | Matrix} The created bigint + */ + var bigint = typed('bigint', { + '': function _() { + return 0n; + }, + bigint: function bigint(x) { + return x; + }, + number: function number(x) { + return BigInt(x.toFixed()); + }, + BigNumber: function BigNumber(x) { + return BigInt(x.round().toString()); + }, + Fraction: function Fraction(x) { + return BigInt(x.valueOf().toFixed()); + }, + 'string | boolean': function string__boolean(x) { + return BigInt(x); + }, + null: function _null(x) { + return 0n; + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); + + // reviver function to parse a JSON object like: + // + // {"mathjs":"bigint","value":"123"} + // + // into a bigint 123n + bigint.fromJSON = function (json) { + return BigInt(json.value); + }; + return bigint; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/BigNumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/BigNumber.js new file mode 100644 index 0000000..4465c8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/BigNumber.js @@ -0,0 +1,57 @@ +import Decimal from 'decimal.js'; +import { factory } from '../../utils/factory.js'; +var name = 'BigNumber'; +var dependencies = ['?on', 'config']; +export var createBigNumberClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + on, + config + } = _ref; + var BigNumber = Decimal.clone({ + precision: config.precision, + modulo: Decimal.EUCLID + }); + BigNumber.prototype = Object.create(BigNumber.prototype); + + /** + * Attach type information + */ + BigNumber.prototype.type = 'BigNumber'; + BigNumber.prototype.isBigNumber = true; + + /** + * Get a JSON representation of a BigNumber containing + * type information + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "BigNumber", "value": "0.2"}` + */ + BigNumber.prototype.toJSON = function () { + return { + mathjs: 'BigNumber', + value: this.toString() + }; + }; + + /** + * Instantiate a BigNumber from a JSON object + * @param {Object} json a JSON object structured as: + * `{"mathjs": "BigNumber", "value": "0.2"}` + * @return {BigNumber} + */ + BigNumber.fromJSON = function (json) { + return new BigNumber(json.value); + }; + if (on) { + // listen for changed in the configuration, automatically apply changed precision + on('config', function (curr, prev) { + if (curr.precision !== prev.precision) { + BigNumber.config({ + precision: curr.precision + }); + } + }); + } + return BigNumber; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/function/bignumber.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/function/bignumber.js new file mode 100644 index 0000000..7c36f8e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/bignumber/function/bignumber.js @@ -0,0 +1,82 @@ +import { factory } from '../../../utils/factory.js'; +import { deepMap } from '../../../utils/collection.js'; +var name = 'bignumber'; +var dependencies = ['typed', 'BigNumber']; +export var createBignumber = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + BigNumber + } = _ref; + /** + * Create a BigNumber, which can store numbers with arbitrary precision. + * When a matrix is provided, all elements will be converted to BigNumber. + * + * Syntax: + * + * math.bignumber(x) + * + * Examples: + * + * 0.1 + 0.2 // returns number 0.30000000000000004 + * math.bignumber(0.1) + math.bignumber(0.2) // returns BigNumber 0.3 + * + * + * 7.2e500 // returns number Infinity + * math.bignumber('7.2e500') // returns BigNumber 7.2e500 + * + * See also: + * + * number, bigint, boolean, complex, index, matrix, string, unit + * + * @param {number | string | Fraction | BigNumber | bigint | Array | Matrix | boolean | null} [value] Value for the big number, + * 0 by default. + * @returns {BigNumber} The created bignumber + */ + return typed('bignumber', { + '': function _() { + return new BigNumber(0); + }, + number: function number(x) { + // convert to string to prevent errors in case of >15 digits + return new BigNumber(x + ''); + }, + string: function string(x) { + var wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/); + if (wordSizeSuffixMatch) { + // x has a word size suffix + var size = wordSizeSuffixMatch[2]; + var n = BigNumber(wordSizeSuffixMatch[1]); + var twoPowSize = new BigNumber(2).pow(Number(size)); + if (n.gt(twoPowSize.sub(1))) { + throw new SyntaxError("String \"".concat(x, "\" is out of range")); + } + var twoPowSizeSubOne = new BigNumber(2).pow(Number(size) - 1); + if (n.gte(twoPowSizeSubOne)) { + return n.sub(twoPowSize); + } else { + return n; + } + } + return new BigNumber(x); + }, + BigNumber: function BigNumber(x) { + // we assume a BigNumber is immutable + return x; + }, + bigint: function bigint(x) { + return new BigNumber(x.toString()); + }, + Unit: typed.referToSelf(self => x => { + var clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + Fraction: function Fraction(x) { + return new BigNumber(x.n).div(x.d).times(x.s); + }, + null: function _null(x) { + return new BigNumber(0); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/boolean.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/boolean.js new file mode 100644 index 0000000..7f18b21 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/boolean.js @@ -0,0 +1,70 @@ +import { factory } from '../utils/factory.js'; +import { deepMap } from '../utils/collection.js'; +var name = 'boolean'; +var dependencies = ['typed']; +export var createBoolean = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Create a boolean or convert a string or number to a boolean. + * In case of a number, `true` is returned for non-zero numbers, and `false` in + * case of zero. + * Strings can be `'true'` or `'false'`, or can contain a number. + * When value is a matrix, all elements will be converted to boolean. + * + * Syntax: + * + * math.boolean(x) + * + * Examples: + * + * math.boolean(0) // returns false + * math.boolean(1) // returns true + * math.boolean(-3) // returns true + * math.boolean('true') // returns true + * math.boolean('false') // returns false + * math.boolean([1, 0, 1, 1]) // returns [true, false, true, true] + * + * See also: + * + * bignumber, complex, index, matrix, string, unit + * + * @param {string | number | boolean | Array | Matrix | null} value A value of any type + * @return {boolean | Array | Matrix} The boolean value + */ + return typed(name, { + '': function _() { + return false; + }, + boolean: function boolean(x) { + return x; + }, + number: function number(x) { + return !!x; + }, + null: function _null(x) { + return false; + }, + BigNumber: function BigNumber(x) { + return !x.isZero(); + }, + string: function string(x) { + // try case insensitive + var lcase = x.toLowerCase(); + if (lcase === 'true') { + return true; + } else if (lcase === 'false') { + return false; + } + + // test whether value is a valid number + var num = Number(x); + if (x !== '' && !isNaN(num)) { + return !!num; + } + throw new Error('Cannot convert "' + x + '" to a boolean'); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/Chain.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/Chain.js new file mode 100644 index 0000000..1f27638 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/Chain.js @@ -0,0 +1,213 @@ +import { isChain } from '../../utils/is.js'; +import { format } from '../../utils/string.js'; +import { hasOwnProperty, lazy } from '../../utils/object.js'; +import { factory } from '../../utils/factory.js'; +var name = 'Chain'; +var dependencies = ['?on', 'math', 'typed']; +export var createChainClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + on, + math, + typed + } = _ref; + /** + * @constructor Chain + * Wrap any value in a chain, allowing to perform chained operations on + * the value. + * + * All methods available in the math.js library can be called upon the chain, + * and then will be evaluated with the value itself as first argument. + * The chain can be closed by executing chain.done(), which will return + * the final value. + * + * The Chain has a number of special functions: + * - done() Finalize the chained operation and return the + * chain's value. + * - valueOf() The same as done() + * - toString() Returns a string representation of the chain's value. + * + * @param {*} [value] + */ + function Chain(value) { + if (!(this instanceof Chain)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (isChain(value)) { + this.value = value.value; + } else { + this.value = value; + } + } + + /** + * Attach type information + */ + Chain.prototype.type = 'Chain'; + Chain.prototype.isChain = true; + + /** + * Close the chain. Returns the final value. + * Does the same as method valueOf() + * @returns {*} value + */ + Chain.prototype.done = function () { + return this.value; + }; + + /** + * Close the chain. Returns the final value. + * Does the same as method done() + * @returns {*} value + */ + Chain.prototype.valueOf = function () { + return this.value; + }; + + /** + * Get a string representation of the value in the chain + * @returns {string} + */ + Chain.prototype.toString = function () { + return format(this.value); + }; + + /** + * Get a JSON representation of the chain + * @returns {Object} + */ + Chain.prototype.toJSON = function () { + return { + mathjs: 'Chain', + value: this.value + }; + }; + + /** + * Instantiate a Chain from its JSON representation + * @param {Object} json An object structured like + * `{"mathjs": "Chain", value: ...}`, + * where mathjs is optional + * @returns {Chain} + */ + Chain.fromJSON = function (json) { + return new Chain(json.value); + }; + + /** + * Create a proxy method for the chain + * @param {string} name + * @param {Function} fn The function to be proxied + * If fn is no function, it is silently ignored. + * @private + */ + function createProxy(name, fn) { + if (typeof fn === 'function') { + Chain.prototype[name] = chainify(fn); + } + } + + /** + * Create a proxy method for the chain + * @param {string} name + * @param {function} resolver The function resolving with the + * function to be proxied + * @private + */ + function createLazyProxy(name, resolver) { + lazy(Chain.prototype, name, function outerResolver() { + var fn = resolver(); + if (typeof fn === 'function') { + return chainify(fn); + } + return undefined; // if not a function, ignore + }); + } + + /** + * Make a function chainable + * @param {function} fn + * @return {Function} chain function + * @private + */ + function chainify(fn) { + return function () { + // Here, `this` will be the context of a Chain instance + if (arguments.length === 0) { + return new Chain(fn(this.value)); + } + var args = [this.value]; + for (var i = 0; i < arguments.length; i++) { + args[i + 1] = arguments[i]; + } + if (typed.isTypedFunction(fn)) { + var sigObject = typed.resolve(fn, args); + // We want to detect if a rest parameter has matched across the + // value in the chain and the current arguments of this call. + // That is the case if and only if the matching signature has + // exactly one parameter (which then must be a rest parameter + // as it is matching at least two actual arguments). + if (sigObject.params.length === 1) { + throw new Error('chain function ' + fn.name + ' cannot match rest parameter between chain value and additional arguments.'); + } + return new Chain(sigObject.implementation.apply(fn, args)); + } + return new Chain(fn.apply(fn, args)); + }; + } + + /** + * Create a proxy for a single method, or an object with multiple methods. + * Example usage: + * + * Chain.createProxy('add', function add (x, y) {...}) + * Chain.createProxy({ + * add: function add (x, y) {...}, + * subtract: function subtract (x, y) {...} + * } + * + * @param {string | Object} arg0 A name (string), or an object with + * functions + * @param {*} [arg1] A function, when arg0 is a name + */ + Chain.createProxy = function (arg0, arg1) { + if (typeof arg0 === 'string') { + // createProxy(name, value) + createProxy(arg0, arg1); + } else { + var _loop = function _loop(_name) { + if (hasOwnProperty(arg0, _name) && excludedNames[_name] === undefined) { + createLazyProxy(_name, () => arg0[_name]); + } + }; + // createProxy(values) + for (var _name in arg0) { + _loop(_name); + } + } + }; + var excludedNames = { + expression: true, + docs: true, + type: true, + classes: true, + json: true, + error: true, + isChain: true // conflicts with the property isChain of a Chain instance + }; + + // create proxy for everything that is in math.js + Chain.createProxy(math); + + // register on the import event, automatically add a proxy for every imported function. + if (on) { + on('import', function (name, resolver, path) { + if (!path) { + // an imported function (not a data type or something special) + createLazyProxy(name, resolver); + } + }); + } + return Chain; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/function/chain.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/function/chain.js new file mode 100644 index 0000000..50e5e2f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/chain/function/chain.js @@ -0,0 +1,52 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'chain'; +var dependencies = ['typed', 'Chain']; +export var createChain = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Chain + } = _ref; + /** + * Wrap any value in a chain, allowing to perform chained operations on + * the value. + * + * All methods available in the math.js library can be called upon the chain, + * and then will be evaluated with the value itself as first argument. + * The chain can be closed by executing `chain.done()`, which returns + * the final value. + * + * The chain has a number of special functions: + * + * - `done()` Finalize the chain and return the chain's value. + * - `valueOf()` The same as `done()` + * - `toString()` Executes `math.format()` onto the chain's value, returning + * a string representation of the value. + * + * Syntax: + * + * math.chain(value) + * + * Examples: + * + * math.chain(3) + * .add(4) + * .subtract(2) + * .done() // 5 + * + * math.chain( [[1, 2], [3, 4]] ) + * .subset(math.index(0, 0), 8) + * .multiply(3) + * .done() // [[24, 6], [9, 12]] + * + * @param {*} [value] A value of any type on which to start a chained operation. + * @return {math.Chain} The created chain + */ + return typed(name, { + '': function _() { + return new Chain(); + }, + any: function any(value) { + return new Chain(value); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/Complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/Complex.js new file mode 100644 index 0000000..4346872 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/Complex.js @@ -0,0 +1,194 @@ +import Complex from 'complex.js'; +import { format } from '../../utils/number.js'; +import { isNumber, isUnit } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +var name = 'Complex'; +var dependencies = []; +export var createComplexClass = /* #__PURE__ */factory(name, dependencies, () => { + /** + * Attach type information + */ + Object.defineProperty(Complex, 'name', { + value: 'Complex' + }); + Complex.prototype.constructor = Complex; + Complex.prototype.type = 'Complex'; + Complex.prototype.isComplex = true; + + /** + * Get a JSON representation of the complex number + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Complex", "re": 2, "im": 3}` + */ + Complex.prototype.toJSON = function () { + return { + mathjs: 'Complex', + re: this.re, + im: this.im + }; + }; + + /* + * Return the value of the complex number in polar notation + * The angle phi will be set in the interval of [-pi, pi]. + * @return {{r: number, phi: number}} Returns and object with properties r and phi. + */ + Complex.prototype.toPolar = function () { + return { + r: this.abs(), + phi: this.arg() + }; + }; + + /** + * Get a string representation of the complex number, + * with optional formatting options. + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @return {string} str + */ + Complex.prototype.format = function (options) { + var str = ''; + var im = this.im; + var re = this.re; + var strRe = format(this.re, options); + var strIm = format(this.im, options); + + // round either re or im when smaller than the configured precision + var precision = isNumber(options) ? options : options ? options.precision : null; + if (precision !== null) { + var epsilon = Math.pow(10, -precision); + if (Math.abs(re / im) < epsilon) { + re = 0; + } + if (Math.abs(im / re) < epsilon) { + im = 0; + } + } + if (im === 0) { + // real value + str = strRe; + } else if (re === 0) { + // purely complex value + if (im === 1) { + str = 'i'; + } else if (im === -1) { + str = '-i'; + } else { + str = strIm + 'i'; + } + } else { + // complex value + if (im < 0) { + if (im === -1) { + str = strRe + ' - i'; + } else { + str = strRe + ' - ' + strIm.substring(1) + 'i'; + } + } else { + if (im === 1) { + str = strRe + ' + i'; + } else { + str = strRe + ' + ' + strIm + 'i'; + } + } + } + return str; + }; + + /** + * Create a complex number from polar coordinates + * + * Usage: + * + * Complex.fromPolar(r: number, phi: number) : Complex + * Complex.fromPolar({r: number, phi: number}) : Complex + * + * @param {*} args... + * @return {Complex} + */ + Complex.fromPolar = function (args) { + switch (arguments.length) { + case 1: + { + var arg = arguments[0]; + if (typeof arg === 'object') { + return Complex(arg); + } else { + throw new TypeError('Input has to be an object with r and phi keys.'); + } + } + case 2: + { + var r = arguments[0]; + var phi = arguments[1]; + if (isNumber(r)) { + if (isUnit(phi) && phi.hasBase('ANGLE')) { + // convert unit to a number in radians + phi = phi.toNumber('rad'); + } + if (isNumber(phi)) { + return new Complex({ + r, + phi + }); + } + throw new TypeError('Phi is not a number nor an angle unit.'); + } else { + throw new TypeError('Radius r is not a number.'); + } + } + default: + throw new SyntaxError('Wrong number of arguments in function fromPolar'); + } + }; + Complex.prototype.valueOf = Complex.prototype.toString; + + /** + * Create a Complex number from a JSON object + * @param {Object} json A JSON Object structured as + * {"mathjs": "Complex", "re": 2, "im": 3} + * All properties are optional, default values + * for `re` and `im` are 0. + * @return {Complex} Returns a new Complex number + */ + Complex.fromJSON = function (json) { + return new Complex(json); + }; + + /** + * Compare two complex numbers, `a` and `b`: + * + * - Returns 1 when the real part of `a` is larger than the real part of `b` + * - Returns -1 when the real part of `a` is smaller than the real part of `b` + * - Returns 1 when the real parts are equal + * and the imaginary part of `a` is larger than the imaginary part of `b` + * - Returns -1 when the real parts are equal + * and the imaginary part of `a` is smaller than the imaginary part of `b` + * - Returns 0 when both real and imaginary parts are equal. + * + * @params {Complex} a + * @params {Complex} b + * @returns {number} Returns the comparison result: -1, 0, or 1 + */ + Complex.compare = function (a, b) { + if (a.re > b.re) { + return 1; + } + if (a.re < b.re) { + return -1; + } + if (a.im > b.im) { + return 1; + } + if (a.im < b.im) { + return -1; + } + return 0; + }; + return Complex; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/function/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/function/complex.js new file mode 100644 index 0000000..feb10bd --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/complex/function/complex.js @@ -0,0 +1,85 @@ +import { factory } from '../../../utils/factory.js'; +import { deepMap } from '../../../utils/collection.js'; +var name = 'complex'; +var dependencies = ['typed', 'Complex']; +export var createComplex = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Complex + } = _ref; + /** + * Create a complex value or convert a value to a complex value. + * + * Syntax: + * + * math.complex() // creates a complex value with zero + * // as real and imaginary part. + * math.complex(re : number, im : string) // creates a complex value with provided + * // values for real and imaginary part. + * math.complex(re : number) // creates a complex value with provided + * // real value and zero imaginary part. + * math.complex(complex : Complex) // clones the provided complex value. + * math.complex(arg : string) // parses a string into a complex value. + * math.complex(array : Array) // converts the elements of the array + * // or matrix element wise into a + * // complex value. + * math.complex({re: number, im: number}) // creates a complex value with provided + * // values for real an imaginary part. + * math.complex({r: number, phi: number}) // creates a complex value with provided + * // polar coordinates + * + * Examples: + * + * const a = math.complex(3, -4) // a = Complex 3 - 4i + * a.re = 5 // a = Complex 5 - 4i + * const i = a.im // Number -4 + * const b = math.complex('2 + 6i') // Complex 2 + 6i + * const c = math.complex() // Complex 0 + 0i + * const d = math.add(a, b) // Complex 5 + 2i + * + * See also: + * + * bignumber, boolean, index, matrix, number, string, unit + * + * @param {* | Array | Matrix} [args] + * Arguments specifying the real and imaginary part of the complex number + * @return {Complex | Array | Matrix} Returns a complex value + */ + return typed('complex', { + '': function _() { + return Complex.ZERO; + }, + number: function number(x) { + return new Complex(x, 0); + }, + 'number, number': function number_number(re, im) { + return new Complex(re, im); + }, + // TODO: this signature should be redundant + 'BigNumber, BigNumber': function BigNumber_BigNumber(re, im) { + return new Complex(re.toNumber(), im.toNumber()); + }, + Fraction: function Fraction(x) { + return new Complex(x.valueOf(), 0); + }, + Complex: function Complex(x) { + return x.clone(); + }, + string: function string(x) { + return Complex(x); // for example '2 + 3i' + }, + null: function _null(x) { + return Complex(0); + }, + Object: function Object(x) { + if ('re' in x && 'im' in x) { + return new Complex(x.re, x.im); + } + if ('r' in x && 'phi' in x || 'abs' in x && 'arg' in x) { + return new Complex(x); + } + throw new Error('Expected object with properties (re and im) or (r and phi) or (abs and arg)'); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/Fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/Fraction.js new file mode 100644 index 0000000..b8bad96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/Fraction.js @@ -0,0 +1,41 @@ +import Fraction from 'fraction.js'; +import { factory } from '../../utils/factory.js'; +var name = 'Fraction'; +var dependencies = []; +export var createFractionClass = /* #__PURE__ */factory(name, dependencies, () => { + /** + * Attach type information + */ + Object.defineProperty(Fraction, 'name', { + value: 'Fraction' + }); + Fraction.prototype.constructor = Fraction; + Fraction.prototype.type = 'Fraction'; + Fraction.prototype.isFraction = true; + + /** + * Get a JSON representation of a Fraction containing type information + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Fraction", "n": 3, "d": 8}` + */ + Fraction.prototype.toJSON = function () { + return { + mathjs: 'Fraction', + n: this.s * this.n, + d: this.d + }; + }; + + /** + * Instantiate a Fraction from a JSON object + * @param {Object} json a JSON object structured as: + * `{"mathjs": "Fraction", "n": 3, "d": 8}` + * @return {BigNumber} + */ + Fraction.fromJSON = function (json) { + return new Fraction(json); + }; + return Fraction; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/function/fraction.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/function/fraction.js new file mode 100644 index 0000000..a5c36c8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/fraction/function/fraction.js @@ -0,0 +1,82 @@ +import { factory } from '../../../utils/factory.js'; +import { deepMap } from '../../../utils/collection.js'; +var name = 'fraction'; +var dependencies = ['typed', 'Fraction']; +export var createFraction = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Fraction + } = _ref; + /** + * Create a fraction or convert a value to a fraction. + * + * With one numeric argument, produces the closest rational approximation to the + * input. + * With two arguments, the first is the numerator and the second is the denominator, + * and creates the corresponding fraction. Both numerator and denominator must be + * integers. + * With one object argument, looks for the integer numerator as the value of property + * 'n' and the integer denominator as the value of property 'd'. + * With a matrix argument, creates a matrix of the same shape with entries + * converted into fractions. + * + * Syntax: + * math.fraction(value) + * math.fraction(numerator, denominator) + * math.fraction({n: numerator, d: denominator}) + * math.fraction(matrix: Array | Matrix) + * + * Examples: + * + * math.fraction(6.283) // returns Fraction 6283/1000 + * math.fraction(1, 3) // returns Fraction 1/3 + * math.fraction('2/3') // returns Fraction 2/3 + * math.fraction({n: 2, d: 3}) // returns Fraction 2/3 + * math.fraction([0.2, 0.25, 1.25]) // returns Array [1/5, 1/4, 5/4] + * math.fraction(4, 5.1) // throws Error: Parameters must be integer + * + * See also: + * + * bignumber, number, string, unit + * + * @param {number | string | Fraction | BigNumber | bigint | Unit | Array | Matrix} [args] + * Arguments specifying the value, or numerator and denominator of + * the fraction + * @return {Fraction | Array | Matrix} Returns a fraction + */ + return typed('fraction', { + number: function number(x) { + if (!isFinite(x) || isNaN(x)) { + throw new Error(x + ' cannot be represented as a fraction'); + } + return new Fraction(x); + }, + string: function string(x) { + return new Fraction(x); + }, + 'number, number': function number_number(numerator, denominator) { + return new Fraction(numerator, denominator); + }, + null: function _null(x) { + return new Fraction(0); + }, + BigNumber: function BigNumber(x) { + return new Fraction(x.toString()); + }, + bigint: function bigint(x) { + return new Fraction(x.toString()); + }, + Fraction: function Fraction(x) { + return x; // fractions are immutable + }, + Unit: typed.referToSelf(self => x => { + var clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + Object: function Object(x) { + return new Fraction(x); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/DenseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/DenseMatrix.js new file mode 100644 index 0000000..2124007 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/DenseMatrix.js @@ -0,0 +1,971 @@ +// deno-lint-ignore-file no-this-alias +import { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'; +import { arraySize, getArrayDataType, processSizesWildcard, reshape, resize, unsqueeze, validate, validateIndex, broadcastTo, get } from '../../utils/array.js'; +import { format } from '../../utils/string.js'; +import { isInteger } from '../../utils/number.js'; +import { clone, deepStrictEqual } from '../../utils/object.js'; +import { DimensionError } from '../../error/DimensionError.js'; +import { factory } from '../../utils/factory.js'; +import { optimizeCallback } from '../../utils/optimizeCallback.js'; +var name = 'DenseMatrix'; +var dependencies = ['Matrix']; +export var createDenseMatrixClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + Matrix + } = _ref; + /** + * Dense Matrix implementation. A regular, dense matrix, supporting multi-dimensional matrices. This is the default matrix type. + * @class DenseMatrix + * @enum {{ value, index: number[] }} + */ + function DenseMatrix(data, datatype) { + if (!(this instanceof DenseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !isString(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if (isMatrix(data)) { + // check data is a DenseMatrix + if (data.type === 'DenseMatrix') { + // clone data & size + this._data = clone(data._data); + this._size = clone(data._size); + this._datatype = datatype || data._datatype; + } else { + // build data from existing matrix + this._data = data.toArray(); + this._size = data.size(); + this._datatype = datatype || data._datatype; + } + } else if (data && isArray(data.data) && isArray(data.size)) { + // initialize fields from JSON representation + this._data = data.data; + this._size = data.size; + // verify the dimensions of the array + validate(this._data, this._size); + this._datatype = datatype || data.datatype; + } else if (isArray(data)) { + // replace nested Matrices with Arrays + this._data = preprocess(data); + // get the dimensions of the array + this._size = arraySize(this._data); + // verify the dimensions of the array, TODO: compute size while processing array + validate(this._data, this._size); + // data type unknown + this._datatype = datatype; + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + typeOf(data) + ')'); + } else { + // nothing provided + this._data = []; + this._size = [0]; + this._datatype = datatype; + } + } + DenseMatrix.prototype = new Matrix(); + + /** + * Create a new DenseMatrix + */ + DenseMatrix.prototype.createDenseMatrix = function (data, datatype) { + return new DenseMatrix(data, datatype); + }; + + /** + * Attach type information + */ + Object.defineProperty(DenseMatrix, 'name', { + value: 'DenseMatrix' + }); + DenseMatrix.prototype.constructor = DenseMatrix; + DenseMatrix.prototype.type = 'DenseMatrix'; + DenseMatrix.prototype.isDenseMatrix = true; + + /** + * Get the matrix type + * + * Usage: + * const matrixType = matrix.getDataType() // retrieves the matrix type + * + * @memberOf DenseMatrix + * @return {string} type information; if multiple types are found from the Matrix, it will return "mixed" + */ + DenseMatrix.prototype.getDataType = function () { + return getArrayDataType(this._data, typeOf); + }; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @memberof DenseMatrix + * @return {string} The storage format. + */ + DenseMatrix.prototype.storage = function () { + return 'dense'; + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @memberof DenseMatrix + * @return {string} The datatype. + */ + DenseMatrix.prototype.datatype = function () { + return this._datatype; + }; + + /** + * Create a new DenseMatrix + * @memberof DenseMatrix + * @param {Array} data + * @param {string} [datatype] + */ + DenseMatrix.prototype.create = function (data, datatype) { + return new DenseMatrix(data, datatype); + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @memberof DenseMatrix + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + DenseMatrix.prototype.subset = function (index, replacement, defaultValue) { + switch (arguments.length) { + case 1: + return _get(this, index); + + // intentional fall through + case 2: + case 3: + return _set(this, index, replacement, defaultValue); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + + /** + * Get a single element from the matrix. + * @memberof DenseMatrix + * @param {number[]} index Zero-based index + * @return {*} value + */ + DenseMatrix.prototype.get = function (index) { + return get(this._data, index); + }; + + /** + * Replace a single element in the matrix. + * @memberof DenseMatrix + * @param {number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {DenseMatrix} self + */ + DenseMatrix.prototype.set = function (index, value, defaultValue) { + if (!isArray(index)) { + throw new TypeError('Array expected'); + } + if (index.length < this._size.length) { + throw new DimensionError(index.length, this._size.length, '<'); + } + var i, ii, indexI; + + // enlarge matrix when needed + var size = index.map(function (i) { + return i + 1; + }); + _fit(this, size, defaultValue); + + // traverse over the dimensions + var data = this._data; + for (i = 0, ii = index.length - 1; i < ii; i++) { + indexI = index[i]; + validateIndex(indexI, data.length); + data = data[indexI]; + } + + // set new value + indexI = index[index.length - 1]; + validateIndex(indexI, data.length); + data[indexI] = value; + return this; + }; + + /** + * Get a submatrix of this matrix + * @memberof DenseMatrix + * @param {DenseMatrix} matrix + * @param {Index} index Zero-based index + * @private + */ + function _get(matrix, index) { + if (!isIndex(index)) { + throw new TypeError('Invalid index'); + } + var isScalar = index.isScalar(); + if (isScalar) { + // return a scalar + return matrix.get(index.min()); + } else { + // validate dimensions + var size = index.size(); + if (size.length !== matrix._size.length) { + throw new DimensionError(size.length, matrix._size.length); + } + + // validate if any of the ranges in the index is out of range + var min = index.min(); + var max = index.max(); + for (var i = 0, ii = matrix._size.length; i < ii; i++) { + validateIndex(min[i], matrix._size[i]); + validateIndex(max[i], matrix._size[i]); + } + + // retrieve submatrix + // TODO: more efficient when creating an empty matrix and setting _data and _size manually + return new DenseMatrix(_getSubmatrix(matrix._data, index, size.length, 0), matrix._datatype); + } + } + + /** + * Recursively get a submatrix of a multi dimensional matrix. + * Index is not checked for correct number or length of dimensions. + * @memberof DenseMatrix + * @param {Array} data + * @param {Index} index + * @param {number} dims Total number of dimensions + * @param {number} dim Current dimension + * @return {Array} submatrix + * @private + */ + function _getSubmatrix(data, index, dims, dim) { + var last = dim === dims - 1; + var range = index.dimension(dim); + if (last) { + return range.map(function (i) { + validateIndex(i, data.length); + return data[i]; + }).valueOf(); + } else { + return range.map(function (i) { + validateIndex(i, data.length); + var child = data[i]; + return _getSubmatrix(child, index, dims, dim + 1); + }).valueOf(); + } + } + + /** + * Replace a submatrix in this matrix + * Indexes are zero-based. + * @memberof DenseMatrix + * @param {DenseMatrix} matrix + * @param {Index} index + * @param {DenseMatrix | Array | *} submatrix + * @param {*} defaultValue Default value, filled in on new entries when + * the matrix is resized. + * @return {DenseMatrix} matrix + * @private + */ + function _set(matrix, index, submatrix, defaultValue) { + if (!index || index.isIndex !== true) { + throw new TypeError('Invalid index'); + } + + // get index size and check whether the index contains a single value + var iSize = index.size(); + var isScalar = index.isScalar(); + + // calculate the size of the submatrix, and convert it into an Array if needed + var sSize; + if (isMatrix(submatrix)) { + sSize = submatrix.size(); + submatrix = submatrix.valueOf(); + } else { + sSize = arraySize(submatrix); + } + if (isScalar) { + // set a scalar + + // check whether submatrix is a scalar + if (sSize.length !== 0) { + throw new TypeError('Scalar expected'); + } + matrix.set(index.min(), submatrix, defaultValue); + } else { + // set a submatrix + + // broadcast submatrix + if (!deepStrictEqual(sSize, iSize)) { + try { + if (sSize.length === 0) { + submatrix = broadcastTo([submatrix], iSize); + } else { + submatrix = broadcastTo(submatrix, iSize); + } + sSize = arraySize(submatrix); + } catch (_unused) {} + } + + // validate dimensions + if (iSize.length < matrix._size.length) { + throw new DimensionError(iSize.length, matrix._size.length, '<'); + } + if (sSize.length < iSize.length) { + // calculate number of missing outer dimensions + var i = 0; + var outer = 0; + while (iSize[i] === 1 && sSize[i] === 1) { + i++; + } + while (iSize[i] === 1) { + outer++; + i++; + } + + // unsqueeze both outer and inner dimensions + submatrix = unsqueeze(submatrix, iSize.length, outer, sSize); + } + + // check whether the size of the submatrix matches the index size + if (!deepStrictEqual(iSize, sSize)) { + throw new DimensionError(iSize, sSize, '>'); + } + + // enlarge matrix when needed + var size = index.max().map(function (i) { + return i + 1; + }); + _fit(matrix, size, defaultValue); + + // insert the sub matrix + var dims = iSize.length; + var dim = 0; + _setSubmatrix(matrix._data, index, submatrix, dims, dim); + } + return matrix; + } + + /** + * Replace a submatrix of a multi dimensional matrix. + * @memberof DenseMatrix + * @param {Array} data + * @param {Index} index + * @param {Array} submatrix + * @param {number} dims Total number of dimensions + * @param {number} dim + * @private + */ + function _setSubmatrix(data, index, submatrix, dims, dim) { + var last = dim === dims - 1; + var range = index.dimension(dim); + if (last) { + range.forEach(function (dataIndex, subIndex) { + validateIndex(dataIndex); + data[dataIndex] = submatrix[subIndex[0]]; + }); + } else { + range.forEach(function (dataIndex, subIndex) { + validateIndex(dataIndex); + _setSubmatrix(data[dataIndex], index, submatrix[subIndex[0]], dims, dim + 1); + }); + } + } + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @memberof DenseMatrix + * @param {number[] || Matrix} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + DenseMatrix.prototype.resize = function (size, defaultValue, copy) { + // validate arguments + if (!isCollection(size)) { + throw new TypeError('Array or Matrix expected'); + } + + // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector + var sizeArray = size.valueOf().map(value => { + return Array.isArray(value) && value.length === 1 ? value[0] : value; + }); + + // matrix to resize + var m = copy ? this.clone() : this; + // resize matrix + return _resize(m, sizeArray, defaultValue); + }; + function _resize(matrix, size, defaultValue) { + // check size + if (size.length === 0) { + // first value in matrix + var v = matrix._data; + // go deep + while (isArray(v)) { + v = v[0]; + } + return v; + } + // resize matrix + matrix._size = size.slice(0); // copy the array + matrix._data = resize(matrix._data, matrix._size, defaultValue); + // return matrix + return matrix; + } + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * NOTE: This might be better suited to copy by default, instead of modifying + * in place. For now, it operates in place to remain consistent with + * resize(). + * + * @memberof DenseMatrix + * @param {number[]} size The new size the matrix should have. + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + DenseMatrix.prototype.reshape = function (size, copy) { + var m = copy ? this.clone() : this; + m._data = reshape(m._data, size); + var currentLength = m._size.reduce((length, size) => length * size); + m._size = processSizesWildcard(size, currentLength); + return m; + }; + + /** + * Enlarge the matrix when it is smaller than given size. + * If the matrix is larger or equal sized, nothing is done. + * @memberof DenseMatrix + * @param {DenseMatrix} matrix The matrix to be resized + * @param {number[]} size + * @param {*} defaultValue Default value, filled in on new entries. + * @private + */ + function _fit(matrix, size, defaultValue) { + var + // copy the array + newSize = matrix._size.slice(0); + var changed = false; + + // add dimensions when needed + while (newSize.length < size.length) { + newSize.push(0); + changed = true; + } + + // enlarge size when needed + for (var i = 0, ii = size.length; i < ii; i++) { + if (size[i] > newSize[i]) { + newSize[i] = size[i]; + changed = true; + } + } + if (changed) { + // resize only when size is changed + _resize(matrix, newSize, defaultValue); + } + } + + /** + * Create a clone of the matrix + * @memberof DenseMatrix + * @return {DenseMatrix} clone + */ + DenseMatrix.prototype.clone = function () { + var m = new DenseMatrix({ + data: clone(this._data), + size: clone(this._size), + datatype: this._datatype + }); + return m; + }; + + /** + * Retrieve the size of the matrix. + * @memberof DenseMatrix + * @returns {number[]} size + */ + DenseMatrix.prototype.size = function () { + return this._size.slice(0); // return a clone of _size + }; + + /** + * Applies a callback function to a reference to each element of the matrix + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: an array, an integer index to that + * array, and the Matrix being traversed. + */ + DenseMatrix.prototype._forEach = function (callback) { + // matrix instance + var me = this; + var s = me.size(); + + // if there is only one dimension, just loop through it + if (s.length === 1) { + for (var i = 0; i < s[0]; i++) { + callback(me._data, i, [i]); + } + return; + } + + // keep track of the current index permutation + var index = Array(s.length).fill(0); + + // store a reference of each dimension of the matrix for faster access + var data = Array(s.length - 1); + var last = data.length - 1; + data[0] = me._data[0]; + for (var _i = 0; _i < last; _i++) { + data[_i + 1] = data[_i][0]; + } + index[last] = -1; + while (true) { + var _i2 = void 0; + for (_i2 = last; _i2 >= 0; _i2--) { + // march index to the next permutation + index[_i2]++; + if (index[_i2] === s[_i2]) { + index[_i2] = 0; + continue; + } + + // update references to matrix dimensions + data[_i2] = _i2 === 0 ? me._data[index[_i2]] : data[_i2 - 1][index[_i2]]; + for (var j = _i2; j < last; j++) { + data[j + 1] = data[j][0]; + } + + // loop through the last dimension and map each value + for (var _j = 0; _j < s[data.length]; _j++) { + index[data.length] = _j; + callback(data[last], _j, index.slice(0)); + } + break; + } + if (_i2 === -1) { + break; + } + } + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * + * @return {DenseMatrix} matrix + */ + DenseMatrix.prototype.map = function (callback) { + var me = this; + var result = new DenseMatrix(me); + var fastCallback = optimizeCallback(callback, me._data, 'map'); + result._forEach(function (arr, i, index) { + arr[i] = fastCallback(arr[i], index, me); + }); + return result; + }; + + /** + * Execute a callback function on each entry of the matrix. + * @memberof DenseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + */ + DenseMatrix.prototype.forEach = function (callback) { + var me = this; + var fastCallback = optimizeCallback(callback, me._data, 'map'); + me._forEach(function (arr, i, index) { + fastCallback(arr[i], index, me); + }); + }; + + /** + * Iterate over the matrix elements + * @return {Iterable<{ value, index: number[] }>} + */ + DenseMatrix.prototype[Symbol.iterator] = function* () { + var _recurse = function* recurse(value, index) { + if (isArray(value)) { + for (var i = 0; i < value.length; i++) { + yield* _recurse(value[i], index.concat(i)); + } + } else { + yield { + value, + index + }; + } + }; + yield* _recurse(this._data, []); + }; + + /** + * Returns an array containing the rows of a 2D matrix + * @returns {Array} + */ + DenseMatrix.prototype.rows = function () { + var result = []; + var s = this.size(); + if (s.length !== 2) { + throw new TypeError('Rows can only be returned for a 2D matrix.'); + } + var data = this._data; + for (var row of data) { + result.push(new DenseMatrix([row], this._datatype)); + } + return result; + }; + + /** + * Returns an array containing the columns of a 2D matrix + * @returns {Array} + */ + DenseMatrix.prototype.columns = function () { + var _this = this; + var result = []; + var s = this.size(); + if (s.length !== 2) { + throw new TypeError('Rows can only be returned for a 2D matrix.'); + } + var data = this._data; + var _loop = function _loop(i) { + var col = data.map(row => [row[i]]); + result.push(new DenseMatrix(col, _this._datatype)); + }; + for (var i = 0; i < s[1]; i++) { + _loop(i); + } + return result; + }; + + /** + * Create an Array with a copy of the data of the DenseMatrix + * @memberof DenseMatrix + * @returns {Array} array + */ + DenseMatrix.prototype.toArray = function () { + return clone(this._data); + }; + + /** + * Get the primitive value of the DenseMatrix: a multidimensional array + * @memberof DenseMatrix + * @returns {Array} array + */ + DenseMatrix.prototype.valueOf = function () { + return this._data; + }; + + /** + * Get a string representation of the matrix, with optional formatting options. + * @memberof DenseMatrix + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + DenseMatrix.prototype.format = function (options) { + return format(this._data, options); + }; + + /** + * Get a string representation of the matrix + * @memberof DenseMatrix + * @returns {string} str + */ + DenseMatrix.prototype.toString = function () { + return format(this._data); + }; + + /** + * Get a JSON representation of the matrix + * @memberof DenseMatrix + * @returns {Object} + */ + DenseMatrix.prototype.toJSON = function () { + return { + mathjs: 'DenseMatrix', + data: this._data, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Get the kth Matrix diagonal. + * + * @memberof DenseMatrix + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved. + * + * @returns {Matrix} The matrix with the diagonal values. + */ + DenseMatrix.prototype.diagonal = function (k) { + // validate k if any + if (k) { + // convert BigNumber to a number + if (isBigNumber(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!isNumber(k) || !isInteger(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + var kSuper = k > 0 ? k : 0; + var kSub = k < 0 ? -k : 0; + + // rows & columns + var rows = this._size[0]; + var columns = this._size[1]; + + // number diagonal values + var n = Math.min(rows - kSub, columns - kSuper); + + // x is a matrix get diagonal from matrix + var data = []; + + // loop rows + for (var i = 0; i < n; i++) { + data[i] = this._data[i + kSub][i + kSuper]; + } + + // create DenseMatrix + return new DenseMatrix({ + data, + size: [n], + datatype: this._datatype + }); + }; + + /** + * Create a diagonal matrix. + * + * @memberof DenseMatrix + * @param {Array} size The matrix size. + * @param {number | Matrix | Array } value The values for the diagonal. + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in. + * @param {number} [defaultValue] The default value for non-diagonal + * @param {string} [datatype] The datatype for the diagonal + * + * @returns {DenseMatrix} + */ + DenseMatrix.diagonal = function (size, value, k, defaultValue) { + if (!isArray(size)) { + throw new TypeError('Array expected, size parameter'); + } + if (size.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // map size & validate + size = size.map(function (s) { + // check it is a big number + if (isBigNumber(s)) { + // convert it + s = s.toNumber(); + } + // validate arguments + if (!isNumber(s) || !isInteger(s) || s < 1) { + throw new Error('Size values must be positive integers'); + } + return s; + }); + + // validate k if any + if (k) { + // convert BigNumber to a number + if (isBigNumber(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!isNumber(k) || !isInteger(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + var kSuper = k > 0 ? k : 0; + var kSub = k < 0 ? -k : 0; + + // rows and columns + var rows = size[0]; + var columns = size[1]; + + // number of non-zero items + var n = Math.min(rows - kSub, columns - kSuper); + + // value extraction function + var _value; + + // check value + if (isArray(value)) { + // validate array + if (value.length !== n) { + // number of values in array must be n + throw new Error('Invalid value array length'); + } + // define function + _value = function _value(i) { + // return value @ i + return value[i]; + }; + } else if (isMatrix(value)) { + // matrix size + var ms = value.size(); + // validate matrix + if (ms.length !== 1 || ms[0] !== n) { + // number of values in array must be n + throw new Error('Invalid matrix length'); + } + // define function + _value = function _value(i) { + // return value @ i + return value.get([i]); + }; + } else { + // define function + _value = function _value() { + // return value + return value; + }; + } + + // discover default value if needed + if (!defaultValue) { + // check first value in array + defaultValue = isBigNumber(_value(0)) ? _value(0).mul(0) // trick to create a BigNumber with value zero + : 0; + } + + // empty array + var data = []; + + // check we need to resize array + if (size.length > 0) { + // resize array + data = resize(data, size, defaultValue); + // fill diagonal + for (var d = 0; d < n; d++) { + data[d + kSub][d + kSuper] = _value(d); + } + } + + // create DenseMatrix + return new DenseMatrix({ + data, + size: [rows, columns] + }); + }; + + /** + * Generate a matrix from a JSON object + * @memberof DenseMatrix + * @param {Object} json An object structured like + * `{"mathjs": "DenseMatrix", data: [], size: []}`, + * where mathjs is optional + * @returns {DenseMatrix} + */ + DenseMatrix.fromJSON = function (json) { + return new DenseMatrix(json); + }; + + /** + * Swap rows i and j in Matrix. + * + * @memberof DenseMatrix + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + DenseMatrix.prototype.swapRows = function (i, j) { + // check index + if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) { + throw new Error('Row index must be positive integers'); + } + // check dimensions + if (this._size.length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + // validate index + validateIndex(i, this._size[0]); + validateIndex(j, this._size[0]); + + // swap rows + DenseMatrix._swapRows(i, j, this._data); + // return current instance + return this; + }; + + /** + * Swap rows i and j in Dense Matrix data structure. + * + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * @param {Array} data Matrix data + */ + DenseMatrix._swapRows = function (i, j, data) { + // swap values i <-> j + var vi = data[i]; + data[i] = data[j]; + data[j] = vi; + }; + + /** + * Preprocess data, which can be an Array or DenseMatrix with nested Arrays and + * Matrices. Clones all (nested) Arrays, and replaces all nested Matrices with Arrays + * @memberof DenseMatrix + * @param {Array | Matrix} data + * @return {Array} data + */ + function preprocess(data) { + if (isMatrix(data)) { + return preprocess(data.valueOf()); + } + if (isArray(data)) { + return data.map(preprocess); + } + return data; + } + return DenseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/FibonacciHeap.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/FibonacciHeap.js new file mode 100644 index 0000000..b1c2f71 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/FibonacciHeap.js @@ -0,0 +1,351 @@ +import { factory } from '../../utils/factory.js'; +var name = 'FibonacciHeap'; +var dependencies = ['smaller', 'larger']; +export var createFibonacciHeapClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + smaller, + larger + } = _ref; + var oneOverLogPhi = 1.0 / Math.log((1.0 + Math.sqrt(5.0)) / 2.0); + + /** + * Fibonacci Heap implementation, used interally for Matrix math. + * @class FibonacciHeap + * @constructor FibonacciHeap + */ + function FibonacciHeap() { + if (!(this instanceof FibonacciHeap)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + + // initialize fields + this._minimum = null; + this._size = 0; + } + + /** + * Attach type information + */ + FibonacciHeap.prototype.type = 'FibonacciHeap'; + FibonacciHeap.prototype.isFibonacciHeap = true; + + /** + * Inserts a new data element into the heap. No heap consolidation is + * performed at this time, the new node is simply inserted into the root + * list of this heap. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.insert = function (key, value) { + // create node + var node = { + key, + value, + degree: 0 + }; + // check we have a node in the minimum + if (this._minimum) { + // minimum node + var minimum = this._minimum; + // update left & right of node + node.left = minimum; + node.right = minimum.right; + minimum.right = node; + node.right.left = node; + // update minimum node in heap if needed + if (smaller(key, minimum.key)) { + // node has a smaller key, use it as minimum + this._minimum = node; + } + } else { + // set left & right + node.left = node; + node.right = node; + // this is the first node + this._minimum = node; + } + // increment number of nodes in heap + this._size++; + // return node + return node; + }; + + /** + * Returns the number of nodes in heap. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.size = function () { + return this._size; + }; + + /** + * Removes all elements from this heap. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.clear = function () { + this._minimum = null; + this._size = 0; + }; + + /** + * Returns true if the heap is empty, otherwise false. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.isEmpty = function () { + return this._size === 0; + }; + + /** + * Extracts the node with minimum key from heap. Amortized running + * time: O(log n). + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.extractMinimum = function () { + // node to remove + var node = this._minimum; + // check we have a minimum + if (node === null) { + return node; + } + // current minimum + var minimum = this._minimum; + // get number of children + var numberOfChildren = node.degree; + // pointer to the first child + var x = node.child; + // for each child of node do... + while (numberOfChildren > 0) { + // store node in right side + var tempRight = x.right; + // remove x from child list + x.left.right = x.right; + x.right.left = x.left; + // add x to root list of heap + x.left = minimum; + x.right = minimum.right; + minimum.right = x; + x.right.left = x; + // set Parent[x] to null + x.parent = null; + x = tempRight; + numberOfChildren--; + } + // remove node from root list of heap + node.left.right = node.right; + node.right.left = node.left; + // update minimum + if (node === node.right) { + // empty + minimum = null; + } else { + // update minimum + minimum = node.right; + // we need to update the pointer to the root with minimum key + minimum = _findMinimumNode(minimum, this._size); + } + // decrement size of heap + this._size--; + // update minimum + this._minimum = minimum; + // return node + return node; + }; + + /** + * Removes a node from the heap given the reference to the node. The trees + * in the heap will be consolidated, if necessary. This operation may fail + * to remove the correct element if there are nodes with key value -Infinity. + * Running time: O(log n) amortized. + * @memberof FibonacciHeap + */ + FibonacciHeap.prototype.remove = function (node) { + // decrease key value + this._minimum = _decreaseKey(this._minimum, node, -1); + // remove the smallest + this.extractMinimum(); + }; + + /** + * Decreases the key value for a heap node, given the new value to take on. + * The structure of the heap may be changed and will not be consolidated. + * Running time: O(1) amortized. + * @memberof FibonacciHeap + */ + function _decreaseKey(minimum, node, key) { + // set node key + node.key = key; + // get parent node + var parent = node.parent; + if (parent && smaller(node.key, parent.key)) { + // remove node from parent + _cut(minimum, node, parent); + // remove all nodes from parent to the root parent + _cascadingCut(minimum, parent); + } + // update minimum node if needed + if (smaller(node.key, minimum.key)) { + minimum = node; + } + // return minimum + return minimum; + } + + /** + * The reverse of the link operation: removes node from the child list of parent. + * This method assumes that min is non-null. Running time: O(1). + * @memberof FibonacciHeap + */ + function _cut(minimum, node, parent) { + // remove node from parent children and decrement Degree[parent] + node.left.right = node.right; + node.right.left = node.left; + parent.degree--; + // reset y.child if necessary + if (parent.child === node) { + parent.child = node.right; + } + // remove child if degree is 0 + if (parent.degree === 0) { + parent.child = null; + } + // add node to root list of heap + node.left = minimum; + node.right = minimum.right; + minimum.right = node; + node.right.left = node; + // set parent[node] to null + node.parent = null; + // set mark[node] to false + node.mark = false; + } + + /** + * Performs a cascading cut operation. This cuts node from its parent and then + * does the same for its parent, and so on up the tree. + * Running time: O(log n); O(1) excluding the recursion. + * @memberof FibonacciHeap + */ + function _cascadingCut(minimum, node) { + // store parent node + var parent = node.parent; + // if there's a parent... + if (!parent) { + return; + } + // if node is unmarked, set it marked + if (!node.mark) { + node.mark = true; + } else { + // it's marked, cut it from parent + _cut(minimum, node, parent); + // cut its parent as well + _cascadingCut(parent); + } + } + + /** + * Make the first node a child of the second one. Running time: O(1) actual. + * @memberof FibonacciHeap + */ + var _linkNodes = function _linkNodes(node, parent) { + // remove node from root list of heap + node.left.right = node.right; + node.right.left = node.left; + // make node a Child of parent + node.parent = parent; + if (!parent.child) { + parent.child = node; + node.right = node; + node.left = node; + } else { + node.left = parent.child; + node.right = parent.child.right; + parent.child.right = node; + node.right.left = node; + } + // increase degree[parent] + parent.degree++; + // set mark[node] false + node.mark = false; + }; + function _findMinimumNode(minimum, size) { + // to find trees of the same degree efficiently we use an array of length O(log n) in which we keep a pointer to one root of each degree + var arraySize = Math.floor(Math.log(size) * oneOverLogPhi) + 1; + // create list with initial capacity + var array = new Array(arraySize); + // find the number of root nodes. + var numRoots = 0; + var x = minimum; + if (x) { + numRoots++; + x = x.right; + while (x !== minimum) { + numRoots++; + x = x.right; + } + } + // vars + var y; + // For each node in root list do... + while (numRoots > 0) { + // access this node's degree.. + var d = x.degree; + // get next node + var next = x.right; + // check if there is a node already in array with the same degree + while (true) { + // get node with the same degree is any + y = array[d]; + if (!y) { + break; + } + // make one node with the same degree a child of the other, do this based on the key value. + if (larger(x.key, y.key)) { + var temp = y; + y = x; + x = temp; + } + // make y a child of x + _linkNodes(y, x); + // we have handled this degree, go to next one. + array[d] = null; + d++; + } + // save this node for later when we might encounter another of the same degree. + array[d] = x; + // move forward through list. + x = next; + numRoots--; + } + // Set min to null (effectively losing the root list) and reconstruct the root list from the array entries in array[]. + minimum = null; + // loop nodes in array + for (var i = 0; i < arraySize; i++) { + // get current node + y = array[i]; + if (!y) { + continue; + } + // check if we have a linked list + if (minimum) { + // First remove node from root list. + y.left.right = y.right; + y.right.left = y.left; + // now add to root list, again. + y.left = minimum; + y.right = minimum.right; + minimum.right = y; + y.right.left = y; + // check if this is a new min. + if (smaller(y.key, minimum.key)) { + minimum = y; + } + } else { + minimum = y; + } + } + return minimum; + } + return FibonacciHeap; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/ImmutableDenseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/ImmutableDenseMatrix.js new file mode 100644 index 0000000..d12b9bf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/ImmutableDenseMatrix.js @@ -0,0 +1,221 @@ +import { isArray, isMatrix, isString, typeOf } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { factory } from '../../utils/factory.js'; +var name = 'ImmutableDenseMatrix'; +var dependencies = ['smaller', 'DenseMatrix']; +export var createImmutableDenseMatrixClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + smaller, + DenseMatrix + } = _ref; + function ImmutableDenseMatrix(data, datatype) { + if (!(this instanceof ImmutableDenseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !isString(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if (isMatrix(data) || isArray(data)) { + // use DenseMatrix implementation + var matrix = new DenseMatrix(data, datatype); + // internal structures + this._data = matrix._data; + this._size = matrix._size; + this._datatype = matrix._datatype; + this._min = null; + this._max = null; + } else if (data && isArray(data.data) && isArray(data.size)) { + // initialize fields from JSON representation + this._data = data.data; + this._size = data.size; + this._datatype = data.datatype; + this._min = typeof data.min !== 'undefined' ? data.min : null; + this._max = typeof data.max !== 'undefined' ? data.max : null; + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + typeOf(data) + ')'); + } else { + // nothing provided + this._data = []; + this._size = [0]; + this._datatype = datatype; + this._min = null; + this._max = null; + } + } + ImmutableDenseMatrix.prototype = new DenseMatrix(); + + /** + * Attach type information + */ + ImmutableDenseMatrix.prototype.type = 'ImmutableDenseMatrix'; + ImmutableDenseMatrix.prototype.isImmutableDenseMatrix = true; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @param {Index} index + * @param {Array | ImmutableDenseMatrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + ImmutableDenseMatrix.prototype.subset = function (index) { + switch (arguments.length) { + case 1: + { + // use base implementation + var m = DenseMatrix.prototype.subset.call(this, index); + // check result is a matrix + if (isMatrix(m)) { + // return immutable matrix + return new ImmutableDenseMatrix({ + data: m._data, + size: m._size, + datatype: m._datatype + }); + } + return m; + } + // intentional fall through + case 2: + case 3: + throw new Error('Cannot invoke set subset on an Immutable Matrix instance'); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + + /** + * Replace a single element in the matrix. + * @param {Number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {ImmutableDenseMatrix} self + */ + ImmutableDenseMatrix.prototype.set = function () { + throw new Error('Cannot invoke set on an Immutable Matrix instance'); + }; + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @param {Number[]} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + ImmutableDenseMatrix.prototype.resize = function () { + throw new Error('Cannot invoke resize on an Immutable Matrix instance'); + }; + + /** + * Disallows reshaping in favor of immutability. + * + * @throws {Error} Operation not allowed + */ + ImmutableDenseMatrix.prototype.reshape = function () { + throw new Error('Cannot invoke reshape on an Immutable Matrix instance'); + }; + + /** + * Create a clone of the matrix + * @return {ImmutableDenseMatrix} clone + */ + ImmutableDenseMatrix.prototype.clone = function () { + return new ImmutableDenseMatrix({ + data: clone(this._data), + size: clone(this._size), + datatype: this._datatype + }); + }; + + /** + * Get a JSON representation of the matrix + * @returns {Object} + */ + ImmutableDenseMatrix.prototype.toJSON = function () { + return { + mathjs: 'ImmutableDenseMatrix', + data: this._data, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Generate a matrix from a JSON object + * @param {Object} json An object structured like + * `{"mathjs": "ImmutableDenseMatrix", data: [], size: []}`, + * where mathjs is optional + * @returns {ImmutableDenseMatrix} + */ + ImmutableDenseMatrix.fromJSON = function (json) { + return new ImmutableDenseMatrix(json); + }; + + /** + * Swap rows i and j in Matrix. + * + * @param {Number} i Matrix row index 1 + * @param {Number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + ImmutableDenseMatrix.prototype.swapRows = function () { + throw new Error('Cannot invoke swapRows on an Immutable Matrix instance'); + }; + + /** + * Calculate the minimum value in the set + * @return {Number | undefined} min + */ + ImmutableDenseMatrix.prototype.min = function () { + // check min has been calculated before + if (this._min === null) { + // minimum + var m = null; + // compute min + this.forEach(function (v) { + if (m === null || smaller(v, m)) { + m = v; + } + }); + this._min = m !== null ? m : undefined; + } + return this._min; + }; + + /** + * Calculate the maximum value in the set + * @return {Number | undefined} max + */ + ImmutableDenseMatrix.prototype.max = function () { + // check max has been calculated before + if (this._max === null) { + // maximum + var m = null; + // compute max + this.forEach(function (v) { + if (m === null || smaller(m, v)) { + m = v; + } + }); + this._max = m !== null ? m : undefined; + } + return this._max; + }; + return ImmutableDenseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Matrix.js new file mode 100644 index 0000000..055b4c9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Matrix.js @@ -0,0 +1,242 @@ +import { factory } from '../../utils/factory.js'; +var name = 'Matrix'; +var dependencies = []; +export var createMatrixClass = /* #__PURE__ */factory(name, dependencies, () => { + /** + * @constructor Matrix + * + * A Matrix is a wrapper around an Array. A matrix can hold a multi dimensional + * array. A matrix can be constructed as: + * + * let matrix = math.matrix(data) + * + * Matrix contains the functions to resize, get and set values, get the size, + * clone the matrix and to convert the matrix to a vector, array, or scalar. + * Furthermore, one can iterate over the matrix using map and forEach. + * The internal Array of the Matrix can be accessed using the function valueOf. + * + * Example usage: + * + * let matrix = math.matrix([[1, 2], [3, 4]]) + * matix.size() // [2, 2] + * matrix.resize([3, 2], 5) + * matrix.valueOf() // [[1, 2], [3, 4], [5, 5]] + * matrix.subset([1,2]) // 3 (indexes are zero-based) + * + */ + function Matrix() { + if (!(this instanceof Matrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + } + + /** + * Attach type information + */ + Matrix.prototype.type = 'Matrix'; + Matrix.prototype.isMatrix = true; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @return {string} The storage format. + */ + Matrix.prototype.storage = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke storage on a Matrix interface'); + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @return {string} The datatype. + */ + Matrix.prototype.datatype = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke datatype on a Matrix interface'); + }; + + /** + * Create a new Matrix With the type of the current matrix instance + * @param {Array | Object} data + * @param {string} [datatype] + */ + Matrix.prototype.create = function (data, datatype) { + throw new Error('Cannot invoke create on a Matrix interface'); + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + Matrix.prototype.subset = function (index, replacement, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke subset on a Matrix interface'); + }; + + /** + * Get a single element from the matrix. + * @param {number[]} index Zero-based index + * @return {*} value + */ + Matrix.prototype.get = function (index) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke get on a Matrix interface'); + }; + + /** + * Replace a single element in the matrix. + * @param {number[]} index Zero-based index + * @param {*} value + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be left undefined. + * @return {Matrix} self + */ + Matrix.prototype.set = function (index, value, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke set on a Matrix interface'); + }; + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @param {number[]} size The new size the matrix should have. + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + Matrix.prototype.resize = function (size, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke resize on a Matrix interface'); + }; + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * @param {number[]} size The new size the matrix should have. + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + Matrix.prototype.reshape = function (size, defaultValue) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke reshape on a Matrix interface'); + }; + + /** + * Create a clone of the matrix + * @return {Matrix} clone + */ + Matrix.prototype.clone = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke clone on a Matrix interface'); + }; + + /** + * Retrieve the size of the matrix. + * @returns {number[]} size + */ + Matrix.prototype.size = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke size on a Matrix interface'); + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {Matrix} matrix + */ + Matrix.prototype.map = function (callback, skipZeros) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke map on a Matrix interface'); + }; + + /** + * Execute a callback function on each entry of the matrix. + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + */ + Matrix.prototype.forEach = function (callback) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke forEach on a Matrix interface'); + }; + + /** + * Iterate over the matrix elements + * @return {Iterable<{ value, index: number[] }>} + */ + Matrix.prototype[Symbol.iterator] = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot iterate a Matrix interface'); + }; + + /** + * Create an Array with a copy of the data of the Matrix + * @returns {Array} array + */ + Matrix.prototype.toArray = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke toArray on a Matrix interface'); + }; + + /** + * Get the primitive value of the Matrix: a multidimensional array + * @returns {Array} array + */ + Matrix.prototype.valueOf = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke valueOf on a Matrix interface'); + }; + + /** + * Get a string representation of the matrix, with optional formatting options. + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + Matrix.prototype.format = function (options) { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke format on a Matrix interface'); + }; + + /** + * Get a string representation of the matrix + * @returns {string} str + */ + Matrix.prototype.toString = function () { + // must be implemented by each of the Matrix implementations + throw new Error('Cannot invoke toString on a Matrix interface'); + }; + return Matrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/MatrixIndex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/MatrixIndex.js new file mode 100644 index 0000000..a2ca88a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/MatrixIndex.js @@ -0,0 +1,298 @@ +import { isArray, isMatrix, isRange } from '../../utils/is.js'; +import { clone } from '../../utils/object.js'; +import { isInteger } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'Index'; +var dependencies = ['ImmutableDenseMatrix', 'getMatrixDataType']; +export var createIndexClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + ImmutableDenseMatrix, + getMatrixDataType + } = _ref; + /** + * Create an index. An Index can store ranges and sets for multiple dimensions. + * Matrix.get, Matrix.set, and math.subset accept an Index as input. + * + * Usage: + * const index = new Index(range1, range2, matrix1, array1, ...) + * + * Where each parameter can be any of: + * A number + * A string (containing a name of an object property) + * An instance of Range + * An Array with the Set values + * An Array with Booleans + * A Matrix with the Set values + * A Matrix with Booleans + * + * The parameters start, end, and step must be integer numbers. + * + * @class Index + * @Constructor Index + * @param {...*} ranges + */ + function Index(ranges) { + if (!(this instanceof Index)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this._dimensions = []; + this._sourceSize = []; + this._isScalar = true; + for (var i = 0, ii = arguments.length; i < ii; i++) { + var arg = arguments[i]; + var argIsArray = isArray(arg); + var argIsMatrix = isMatrix(arg); + var sourceSize = null; + if (isRange(arg)) { + this._dimensions.push(arg); + this._isScalar = false; + } else if (argIsArray || argIsMatrix) { + // create matrix + var m = void 0; + if (getMatrixDataType(arg) === 'boolean') { + if (argIsArray) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg).valueOf()); + if (argIsMatrix) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg._data).valueOf()); + sourceSize = arg.valueOf().length; + } else { + m = _createImmutableMatrix(arg.valueOf()); + } + this._dimensions.push(m); + // size + var size = m.size(); + // scalar + if (size.length !== 1 || size[0] !== 1 || sourceSize !== null) { + this._isScalar = false; + } + } else if (typeof arg === 'number') { + this._dimensions.push(_createImmutableMatrix([arg])); + } else if (typeof arg === 'string') { + // object property (arguments.count should be 1) + this._dimensions.push(arg); + } else { + throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range'); + } + this._sourceSize.push(sourceSize); + // TODO: implement support for wildcard '*' + } + } + + /** + * Attach type information + */ + Index.prototype.type = 'Index'; + Index.prototype.isIndex = true; + function _createImmutableMatrix(arg) { + // loop array elements + for (var i = 0, l = arg.length; i < l; i++) { + if (typeof arg[i] !== 'number' || !isInteger(arg[i])) { + throw new TypeError('Index parameters must be positive integer numbers'); + } + } + // create matrix + return new ImmutableDenseMatrix(arg); + } + + /** + * Create a clone of the index + * @memberof Index + * @return {Index} clone + */ + Index.prototype.clone = function () { + var index = new Index(); + index._dimensions = clone(this._dimensions); + index._isScalar = this._isScalar; + index._sourceSize = this._sourceSize; + return index; + }; + + /** + * Create an index from an array with ranges/numbers + * @memberof Index + * @param {Array.} ranges + * @return {Index} index + * @private + */ + Index.create = function (ranges) { + var index = new Index(); + Index.apply(index, ranges); + return index; + }; + + /** + * Retrieve the size of the index, the number of elements for each dimension. + * @memberof Index + * @returns {number[]} size + */ + Index.prototype.size = function () { + var size = []; + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + var d = this._dimensions[i]; + size[i] = typeof d === 'string' ? 1 : d.size()[0]; + } + return size; + }; + + /** + * Get the maximum value for each of the indexes ranges. + * @memberof Index + * @returns {number[]} max + */ + Index.prototype.max = function () { + var values = []; + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + var range = this._dimensions[i]; + values[i] = typeof range === 'string' ? range : range.max(); + } + return values; + }; + + /** + * Get the minimum value for each of the indexes ranges. + * @memberof Index + * @returns {number[]} min + */ + Index.prototype.min = function () { + var values = []; + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + var range = this._dimensions[i]; + values[i] = typeof range === 'string' ? range : range.min(); + } + return values; + }; + + /** + * Loop over each of the ranges of the index + * @memberof Index + * @param {Function} callback Called for each range with a Range as first + * argument, the dimension as second, and the + * index object as third. + */ + Index.prototype.forEach = function (callback) { + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + callback(this._dimensions[i], i, this); + } + }; + + /** + * Retrieve the dimension for the given index + * @memberof Index + * @param {Number} dim Number of the dimension + * @returns {Range | null} range + */ + Index.prototype.dimension = function (dim) { + return this._dimensions[dim] || null; + }; + + /** + * Test whether this index contains an object property + * @returns {boolean} Returns true if the index is an object property + */ + Index.prototype.isObjectProperty = function () { + return this._dimensions.length === 1 && typeof this._dimensions[0] === 'string'; + }; + + /** + * Returns the object property name when the Index holds a single object property, + * else returns null + * @returns {string | null} + */ + Index.prototype.getObjectProperty = function () { + return this.isObjectProperty() ? this._dimensions[0] : null; + }; + + /** + * Test whether this index contains only a single value. + * + * This is the case when the index is created with only scalar values as ranges, + * not for ranges resolving into a single value. + * @memberof Index + * @return {boolean} isScalar + */ + Index.prototype.isScalar = function () { + return this._isScalar; + }; + + /** + * Expand the Index into an array. + * For example new Index([0,3], [2,7]) returns [[0,1,2], [2,3,4,5,6]] + * @memberof Index + * @returns {Array} array + */ + Index.prototype.toArray = function () { + var array = []; + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + var dimension = this._dimensions[i]; + array.push(typeof dimension === 'string' ? dimension : dimension.toArray()); + } + return array; + }; + + /** + * Get the primitive value of the Index, a two dimensional array. + * Equivalent to Index.toArray(). + * @memberof Index + * @returns {Array} array + */ + Index.prototype.valueOf = Index.prototype.toArray; + + /** + * Get the string representation of the index, for example '[2:6]' or '[0:2:10, 4:7, [1,2,3]]' + * @memberof Index + * @returns {String} str + */ + Index.prototype.toString = function () { + var strings = []; + for (var i = 0, ii = this._dimensions.length; i < ii; i++) { + var dimension = this._dimensions[i]; + if (typeof dimension === 'string') { + strings.push(JSON.stringify(dimension)); + } else { + strings.push(dimension.toString()); + } + } + return '[' + strings.join(', ') + ']'; + }; + + /** + * Get a JSON representation of the Index + * @memberof Index + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Index", "ranges": [{"mathjs": "Range", start: 0, end: 10, step:1}, ...]}` + */ + Index.prototype.toJSON = function () { + return { + mathjs: 'Index', + dimensions: this._dimensions + }; + }; + + /** + * Instantiate an Index from a JSON object + * @memberof Index + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Index", "dimensions": [{"mathjs": "Range", start: 0, end: 10, step:1}, ...]}` + * @return {Index} + */ + Index.fromJSON = function (json) { + return Index.create(json.dimensions); + }; + return Index; +}, { + isClass: true +}); + +/** + * Receives an array of booleans and returns an array of Numbers for Index + * @param {Array} booleanArrayIndex An array of booleans + * @return {Array} A set of numbers ready for index + */ +function _booleansArrayToNumbersForIndex(booleanArrayIndex) { + // gets an array of booleans and returns an array of numbers + var indexOfNumbers = []; + booleanArrayIndex.forEach((bool, idx) => { + if (bool) { + indexOfNumbers.push(idx); + } + }); + return indexOfNumbers; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Range.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Range.js new file mode 100644 index 0000000..967d367 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Range.js @@ -0,0 +1,304 @@ +import { isBigNumber } from '../../utils/is.js'; +import { format, sign } from '../../utils/number.js'; +import { factory } from '../../utils/factory.js'; +var name = 'Range'; +var dependencies = []; +export var createRangeClass = /* #__PURE__ */factory(name, dependencies, () => { + /** + * Create a range. A range has a start, step, and end, and contains functions + * to iterate over the range. + * + * A range can be constructed as: + * + * const range = new Range(start, end) + * const range = new Range(start, end, step) + * + * To get the result of the range: + * range.forEach(function (x) { + * console.log(x) + * }) + * range.map(function (x) { + * return math.sin(x) + * }) + * range.toArray() + * + * Example usage: + * + * const c = new Range(2, 6) // 2:1:5 + * c.toArray() // [2, 3, 4, 5] + * const d = new Range(2, -3, -1) // 2:-1:-2 + * d.toArray() // [2, 1, 0, -1, -2] + * + * @class Range + * @constructor Range + * @param {number} start included lower bound + * @param {number} end excluded upper bound + * @param {number} [step] step size, default value is 1 + */ + function Range(start, end, step) { + if (!(this instanceof Range)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + var hasStart = start !== null && start !== undefined; + var hasEnd = end !== null && end !== undefined; + var hasStep = step !== null && step !== undefined; + if (hasStart) { + if (isBigNumber(start)) { + start = start.toNumber(); + } else if (typeof start !== 'number') { + throw new TypeError('Parameter start must be a number'); + } + } + if (hasEnd) { + if (isBigNumber(end)) { + end = end.toNumber(); + } else if (typeof end !== 'number') { + throw new TypeError('Parameter end must be a number'); + } + } + if (hasStep) { + if (isBigNumber(step)) { + step = step.toNumber(); + } else if (typeof step !== 'number') { + throw new TypeError('Parameter step must be a number'); + } + } + this.start = hasStart ? parseFloat(start) : 0; + this.end = hasEnd ? parseFloat(end) : 0; + this.step = hasStep ? parseFloat(step) : 1; + } + + /** + * Attach type information + */ + Range.prototype.type = 'Range'; + Range.prototype.isRange = true; + + /** + * Parse a string into a range, + * The string contains the start, optional step, and end, separated by a colon. + * If the string does not contain a valid range, null is returned. + * For example str='0:2:11'. + * @memberof Range + * @param {string} str + * @return {Range | null} range + */ + Range.parse = function (str) { + if (typeof str !== 'string') { + return null; + } + var args = str.split(':'); + var nums = args.map(function (arg) { + return parseFloat(arg); + }); + var invalid = nums.some(function (num) { + return isNaN(num); + }); + if (invalid) { + return null; + } + switch (nums.length) { + case 2: + return new Range(nums[0], nums[1]); + case 3: + return new Range(nums[0], nums[2], nums[1]); + default: + return null; + } + }; + + /** + * Create a clone of the range + * @return {Range} clone + */ + Range.prototype.clone = function () { + return new Range(this.start, this.end, this.step); + }; + + /** + * Retrieve the size of the range. + * Returns an array containing one number, the number of elements in the range. + * @memberof Range + * @returns {number[]} size + */ + Range.prototype.size = function () { + var len = 0; + var start = this.start; + var step = this.step; + var end = this.end; + var diff = end - start; + if (sign(step) === sign(diff)) { + len = Math.ceil(diff / step); + } else if (diff === 0) { + len = 0; + } + if (isNaN(len)) { + len = 0; + } + return [len]; + }; + + /** + * Calculate the minimum value in the range + * @memberof Range + * @return {number | undefined} min + */ + Range.prototype.min = function () { + var size = this.size()[0]; + if (size > 0) { + if (this.step > 0) { + // positive step + return this.start; + } else { + // negative step + return this.start + (size - 1) * this.step; + } + } else { + return undefined; + } + }; + + /** + * Calculate the maximum value in the range + * @memberof Range + * @return {number | undefined} max + */ + Range.prototype.max = function () { + var size = this.size()[0]; + if (size > 0) { + if (this.step > 0) { + // positive step + return this.start + (size - 1) * this.step; + } else { + // negative step + return this.start; + } + } else { + return undefined; + } + }; + + /** + * Execute a callback function for each value in the range. + * @memberof Range + * @param {function} callback The callback method is invoked with three + * parameters: the value of the element, the index + * of the element, and the Range being traversed. + */ + Range.prototype.forEach = function (callback) { + var x = this.start; + var step = this.step; + var end = this.end; + var i = 0; + if (step > 0) { + while (x < end) { + callback(x, [i], this); + x += step; + i++; + } + } else if (step < 0) { + while (x > end) { + callback(x, [i], this); + x += step; + i++; + } + } + }; + + /** + * Execute a callback function for each value in the Range, and return the + * results as an array + * @memberof Range + * @param {function} callback The callback method is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @returns {Array} array + */ + Range.prototype.map = function (callback) { + var array = []; + this.forEach(function (value, index, obj) { + array[index[0]] = callback(value, index, obj); + }); + return array; + }; + + /** + * Create an Array with a copy of the Ranges data + * @memberof Range + * @returns {Array} array + */ + Range.prototype.toArray = function () { + var array = []; + this.forEach(function (value, index) { + array[index[0]] = value; + }); + return array; + }; + + /** + * Get the primitive value of the Range, a one dimensional array + * @memberof Range + * @returns {Array} array + */ + Range.prototype.valueOf = function () { + // TODO: implement a caching mechanism for range.valueOf() + return this.toArray(); + }; + + /** + * Get a string representation of the range, with optional formatting options. + * Output is formatted as 'start:step:end', for example '2:6' or '0:0.2:11' + * @memberof Range + * @param {Object | number | function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + Range.prototype.format = function (options) { + var str = format(this.start, options); + if (this.step !== 1) { + str += ':' + format(this.step, options); + } + str += ':' + format(this.end, options); + return str; + }; + + /** + * Get a string representation of the range. + * @memberof Range + * @returns {string} + */ + Range.prototype.toString = function () { + return this.format(); + }; + + /** + * Get a JSON representation of the range + * @memberof Range + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Range", "start": 2, "end": 4, "step": 1}` + */ + Range.prototype.toJSON = function () { + return { + mathjs: 'Range', + start: this.start, + end: this.end, + step: this.step + }; + }; + + /** + * Instantiate a Range from a JSON object + * @memberof Range + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Range", "start": 2, "end": 4, "step": 1}` + * @return {Range} + */ + Range.fromJSON = function (json) { + return new Range(json.start, json.end, json.step); + }; + return Range; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Spa.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Spa.js new file mode 100644 index 0000000..20f2750 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/Spa.js @@ -0,0 +1,136 @@ +import { factory } from '../../utils/factory.js'; +var name = 'Spa'; +var dependencies = ['addScalar', 'equalScalar', 'FibonacciHeap']; +export var createSpaClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + addScalar, + equalScalar, + FibonacciHeap + } = _ref; + /** + * An ordered Sparse Accumulator is a representation for a sparse vector that includes a dense array + * of the vector elements and an ordered list of non-zero elements. + */ + function Spa() { + if (!(this instanceof Spa)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + + // allocate vector, TODO use typed arrays + this._values = []; + this._heap = new FibonacciHeap(); + } + + /** + * Attach type information + */ + Spa.prototype.type = 'Spa'; + Spa.prototype.isSpa = true; + + /** + * Set the value for index i. + * + * @param {number} i The index + * @param {number | BigNumber | Complex} The value at index i + */ + Spa.prototype.set = function (i, v) { + // check we have a value @ i + if (!this._values[i]) { + // insert in heap + var node = this._heap.insert(i, v); + // set the value @ i + this._values[i] = node; + } else { + // update the value @ i + this._values[i].value = v; + } + }; + Spa.prototype.get = function (i) { + var node = this._values[i]; + if (node) { + return node.value; + } + return 0; + }; + Spa.prototype.accumulate = function (i, v) { + // node @ i + var node = this._values[i]; + if (!node) { + // insert in heap + node = this._heap.insert(i, v); + // initialize value + this._values[i] = node; + } else { + // accumulate value + node.value = addScalar(node.value, v); + } + }; + Spa.prototype.forEach = function (from, to, callback) { + // references + var heap = this._heap; + var values = this._values; + // nodes + var nodes = []; + // node with minimum key, save it + var node = heap.extractMinimum(); + if (node) { + nodes.push(node); + } + // extract nodes from heap (ordered) + while (node && node.key <= to) { + // check it is in range + if (node.key >= from) { + // check value is not zero + if (!equalScalar(node.value, 0)) { + // invoke callback + callback(node.key, node.value, this); + } + } + // extract next node, save it + node = heap.extractMinimum(); + if (node) { + nodes.push(node); + } + } + // reinsert all nodes in heap + for (var i = 0; i < nodes.length; i++) { + // current node + var n = nodes[i]; + // insert node in heap + node = heap.insert(n.key, n.value); + // update values + values[node.key] = node; + } + }; + Spa.prototype.swap = function (i, j) { + // node @ i and j + var nodei = this._values[i]; + var nodej = this._values[j]; + // check we need to insert indeces + if (!nodei && nodej) { + // insert in heap + nodei = this._heap.insert(i, nodej.value); + // remove from heap + this._heap.remove(nodej); + // set values + this._values[i] = nodei; + this._values[j] = undefined; + } else if (nodei && !nodej) { + // insert in heap + nodej = this._heap.insert(j, nodei.value); + // remove from heap + this._heap.remove(nodei); + // set values + this._values[j] = nodej; + this._values[i] = undefined; + } else if (nodei && nodej) { + // swap values + var v = nodei.value; + nodei.value = nodej.value; + nodej.value = v; + } + }; + return Spa; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/SparseMatrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/SparseMatrix.js new file mode 100644 index 0000000..d7233f4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/SparseMatrix.js @@ -0,0 +1,1486 @@ +import { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'; +import { isInteger } from '../../utils/number.js'; +import { format } from '../../utils/string.js'; +import { clone, deepStrictEqual } from '../../utils/object.js'; +import { arraySize, getArrayDataType, processSizesWildcard, unsqueeze, validateIndex } from '../../utils/array.js'; +import { factory } from '../../utils/factory.js'; +import { DimensionError } from '../../error/DimensionError.js'; +import { optimizeCallback } from '../../utils/optimizeCallback.js'; +var name = 'SparseMatrix'; +var dependencies = ['typed', 'equalScalar', 'Matrix']; +export var createSparseMatrixClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar, + Matrix + } = _ref; + /** + * Sparse Matrix implementation. This type implements + * a [Compressed Column Storage](https://en.wikipedia.org/wiki/Sparse_matrix#Compressed_sparse_column_(CSC_or_CCS)) + * format for two-dimensional sparse matrices. + * @class SparseMatrix + */ + function SparseMatrix(data, datatype) { + if (!(this instanceof SparseMatrix)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + if (datatype && !isString(datatype)) { + throw new Error('Invalid datatype: ' + datatype); + } + if (isMatrix(data)) { + // create from matrix + _createFromMatrix(this, data, datatype); + } else if (data && isArray(data.index) && isArray(data.ptr) && isArray(data.size)) { + // initialize fields + this._values = data.values; + this._index = data.index; + this._ptr = data.ptr; + this._size = data.size; + this._datatype = datatype || data.datatype; + } else if (isArray(data)) { + // create from array + _createFromArray(this, data, datatype); + } else if (data) { + // unsupported type + throw new TypeError('Unsupported type of data (' + typeOf(data) + ')'); + } else { + // nothing provided + this._values = []; + this._index = []; + this._ptr = [0]; + this._size = [0, 0]; + this._datatype = datatype; + } + } + function _createFromMatrix(matrix, source, datatype) { + // check matrix type + if (source.type === 'SparseMatrix') { + // clone arrays + matrix._values = source._values ? clone(source._values) : undefined; + matrix._index = clone(source._index); + matrix._ptr = clone(source._ptr); + matrix._size = clone(source._size); + matrix._datatype = datatype || source._datatype; + } else { + // build from matrix data + _createFromArray(matrix, source.valueOf(), datatype || source._datatype); + } + } + function _createFromArray(matrix, data, datatype) { + // initialize fields + matrix._values = []; + matrix._index = []; + matrix._ptr = []; + matrix._datatype = datatype; + // discover rows & columns, do not use math.size() to avoid looping array twice + var rows = data.length; + var columns = 0; + + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + if (isString(datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, datatype); + } + + // check we have rows (empty array) + if (rows > 0) { + // column index + var j = 0; + do { + // store pointer to values index + matrix._ptr.push(matrix._index.length); + // loop rows + for (var i = 0; i < rows; i++) { + // current row + var row = data[i]; + // check row is an array + if (isArray(row)) { + // update columns if needed (only on first column) + if (j === 0 && columns < row.length) { + columns = row.length; + } + // check row has column + if (j < row.length) { + // value + var v = row[j]; + // check value != 0 + if (!eq(v, zero)) { + // store value + matrix._values.push(v); + // index + matrix._index.push(i); + } + } + } else { + // update columns if needed (only on first column) + if (j === 0 && columns < 1) { + columns = 1; + } + // check value != 0 (row is a scalar) + if (!eq(row, zero)) { + // store value + matrix._values.push(row); + // index + matrix._index.push(i); + } + } + } + // increment index + j++; + } while (j < columns); + } + // store number of values in ptr + matrix._ptr.push(matrix._index.length); + // size + matrix._size = [rows, columns]; + } + SparseMatrix.prototype = new Matrix(); + + /** + * Create a new SparseMatrix + */ + SparseMatrix.prototype.createSparseMatrix = function (data, datatype) { + return new SparseMatrix(data, datatype); + }; + + /** + * Attach type information + */ + Object.defineProperty(SparseMatrix, 'name', { + value: 'SparseMatrix' + }); + SparseMatrix.prototype.constructor = SparseMatrix; + SparseMatrix.prototype.type = 'SparseMatrix'; + SparseMatrix.prototype.isSparseMatrix = true; + + /** + * Get the matrix type + * + * Usage: + * const matrixType = matrix.getDataType() // retrieves the matrix type + * + * @memberOf SparseMatrix + * @return {string} type information; if multiple types are found from the Matrix, it will return "mixed" + */ + SparseMatrix.prototype.getDataType = function () { + return getArrayDataType(this._values, typeOf); + }; + + /** + * Get the storage format used by the matrix. + * + * Usage: + * const format = matrix.storage() // retrieve storage format + * + * @memberof SparseMatrix + * @return {string} The storage format. + */ + SparseMatrix.prototype.storage = function () { + return 'sparse'; + }; + + /** + * Get the datatype of the data stored in the matrix. + * + * Usage: + * const format = matrix.datatype() // retrieve matrix datatype + * + * @memberof SparseMatrix + * @return {string} The datatype. + */ + SparseMatrix.prototype.datatype = function () { + return this._datatype; + }; + + /** + * Create a new SparseMatrix + * @memberof SparseMatrix + * @param {Array} data + * @param {string} [datatype] + */ + SparseMatrix.prototype.create = function (data, datatype) { + return new SparseMatrix(data, datatype); + }; + + /** + * Get the matrix density. + * + * Usage: + * const density = matrix.density() // retrieve matrix density + * + * @memberof SparseMatrix + * @return {number} The matrix density. + */ + SparseMatrix.prototype.density = function () { + // rows & columns + var rows = this._size[0]; + var columns = this._size[1]; + // calculate density + return rows !== 0 && columns !== 0 ? this._index.length / (rows * columns) : 0; + }; + + /** + * Get a subset of the matrix, or replace a subset of the matrix. + * + * Usage: + * const subset = matrix.subset(index) // retrieve subset + * const value = matrix.subset(index, replacement) // replace subset + * + * @memberof SparseMatrix + * @param {Index} index + * @param {Array | Matrix | *} [replacement] + * @param {*} [defaultValue=0] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be filled with zeros. + */ + SparseMatrix.prototype.subset = function (index, replacement, defaultValue) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke subset on a Pattern only matrix'); + } + + // check arguments + switch (arguments.length) { + case 1: + return _getsubset(this, index); + + // intentional fall through + case 2: + case 3: + return _setsubset(this, index, replacement, defaultValue); + default: + throw new SyntaxError('Wrong number of arguments'); + } + }; + function _getsubset(matrix, idx) { + // check idx + if (!isIndex(idx)) { + throw new TypeError('Invalid index'); + } + var isScalar = idx.isScalar(); + if (isScalar) { + // return a scalar + return matrix.get(idx.min()); + } + // validate dimensions + var size = idx.size(); + if (size.length !== matrix._size.length) { + throw new DimensionError(size.length, matrix._size.length); + } + + // vars + var i, ii, k, kk; + + // validate if any of the ranges in the index is out of range + var min = idx.min(); + var max = idx.max(); + for (i = 0, ii = matrix._size.length; i < ii; i++) { + validateIndex(min[i], matrix._size[i]); + validateIndex(max[i], matrix._size[i]); + } + + // matrix arrays + var mvalues = matrix._values; + var mindex = matrix._index; + var mptr = matrix._ptr; + + // rows & columns dimensions for result matrix + var rows = idx.dimension(0); + var columns = idx.dimension(1); + + // workspace & permutation vector + var w = []; + var pv = []; + + // loop rows in resulting matrix + rows.forEach(function (i, r) { + // update permutation vector + pv[i] = r[0]; + // mark i in workspace + w[i] = true; + }); + + // result matrix arrays + var values = mvalues ? [] : undefined; + var index = []; + var ptr = []; + + // loop columns in result matrix + columns.forEach(function (j) { + // update ptr + ptr.push(index.length); + // loop values in column j + for (k = mptr[j], kk = mptr[j + 1]; k < kk; k++) { + // row + i = mindex[k]; + // check row is in result matrix + if (w[i] === true) { + // push index + index.push(pv[i]); + // check we need to process values + if (values) { + values.push(mvalues[k]); + } + } + } + }); + // update ptr + ptr.push(index.length); + + // return matrix + return new SparseMatrix({ + values, + index, + ptr, + size, + datatype: matrix._datatype + }); + } + function _setsubset(matrix, index, submatrix, defaultValue) { + // check index + if (!index || index.isIndex !== true) { + throw new TypeError('Invalid index'); + } + + // get index size and check whether the index contains a single value + var iSize = index.size(); + var isScalar = index.isScalar(); + + // calculate the size of the submatrix, and convert it into an Array if needed + var sSize; + if (isMatrix(submatrix)) { + // submatrix size + sSize = submatrix.size(); + // use array representation + submatrix = submatrix.toArray(); + } else { + // get submatrix size (array, scalar) + sSize = arraySize(submatrix); + } + + // check index is a scalar + if (isScalar) { + // verify submatrix is a scalar + if (sSize.length !== 0) { + throw new TypeError('Scalar expected'); + } + // set value + matrix.set(index.min(), submatrix, defaultValue); + } else { + // validate dimensions, index size must be one or two dimensions + if (iSize.length !== 1 && iSize.length !== 2) { + throw new DimensionError(iSize.length, matrix._size.length, '<'); + } + + // check submatrix and index have the same dimensions + if (sSize.length < iSize.length) { + // calculate number of missing outer dimensions + var i = 0; + var outer = 0; + while (iSize[i] === 1 && sSize[i] === 1) { + i++; + } + while (iSize[i] === 1) { + outer++; + i++; + } + // unsqueeze both outer and inner dimensions + submatrix = unsqueeze(submatrix, iSize.length, outer, sSize); + } + + // check whether the size of the submatrix matches the index size + if (!deepStrictEqual(iSize, sSize)) { + throw new DimensionError(iSize, sSize, '>'); + } + + // insert the sub matrix + if (iSize.length === 1) { + // if the replacement index only has 1 dimension, go trough each one and set its value + var range = index.dimension(0); + range.forEach(function (dataIndex, subIndex) { + validateIndex(dataIndex); + matrix.set([dataIndex, 0], submatrix[subIndex[0]], defaultValue); + }); + } else { + // if the replacement index has 2 dimensions, go through each one and set the value in the correct index + var firstDimensionRange = index.dimension(0); + var secondDimensionRange = index.dimension(1); + firstDimensionRange.forEach(function (firstDataIndex, firstSubIndex) { + validateIndex(firstDataIndex); + secondDimensionRange.forEach(function (secondDataIndex, secondSubIndex) { + validateIndex(secondDataIndex); + matrix.set([firstDataIndex, secondDataIndex], submatrix[firstSubIndex[0]][secondSubIndex[0]], defaultValue); + }); + }); + } + } + return matrix; + } + + /** + * Get a single element from the matrix. + * @memberof SparseMatrix + * @param {number[]} index Zero-based index + * @return {*} value + */ + SparseMatrix.prototype.get = function (index) { + if (!isArray(index)) { + throw new TypeError('Array expected'); + } + if (index.length !== this._size.length) { + throw new DimensionError(index.length, this._size.length); + } + + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke get on a Pattern only matrix'); + } + + // row and column + var i = index[0]; + var j = index[1]; + + // check i, j are valid + validateIndex(i, this._size[0]); + validateIndex(j, this._size[1]); + + // find value index + var k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); + // check k is prior to next column k and it is in the correct row + if (k < this._ptr[j + 1] && this._index[k] === i) { + return this._values[k]; + } + return 0; + }; + + /** + * Replace a single element in the matrix. + * @memberof SparseMatrix + * @param {number[]} index Zero-based index + * @param {*} v + * @param {*} [defaultValue] Default value, filled in on new entries when + * the matrix is resized. If not provided, + * new matrix elements will be set to zero. + * @return {SparseMatrix} self + */ + SparseMatrix.prototype.set = function (index, v, defaultValue) { + if (!isArray(index)) { + throw new TypeError('Array expected'); + } + if (index.length !== this._size.length) { + throw new DimensionError(index.length, this._size.length); + } + + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke set on a Pattern only matrix'); + } + + // row and column + var i = index[0]; + var j = index[1]; + + // rows & columns + var rows = this._size[0]; + var columns = this._size[1]; + + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + if (isString(this._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [this._datatype, this._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, this._datatype); + } + + // check we need to resize matrix + if (i > rows - 1 || j > columns - 1) { + // resize matrix + _resize(this, Math.max(i + 1, rows), Math.max(j + 1, columns), defaultValue); + // update rows & columns + rows = this._size[0]; + columns = this._size[1]; + } + + // check i, j are valid + validateIndex(i, rows); + validateIndex(j, columns); + + // find value index + var k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); + // check k is prior to next column k and it is in the correct row + if (k < this._ptr[j + 1] && this._index[k] === i) { + // check value != 0 + if (!eq(v, zero)) { + // update value + this._values[k] = v; + } else { + // remove value from matrix + _remove(k, j, this._values, this._index, this._ptr); + } + } else { + if (!eq(v, zero)) { + // insert value @ (i, j) + _insert(k, i, j, v, this._values, this._index, this._ptr); + } + } + return this; + }; + function _getValueIndex(i, top, bottom, index) { + // check row is on the bottom side + if (bottom - top === 0) { + return bottom; + } + // loop rows [top, bottom[ + for (var r = top; r < bottom; r++) { + // check we found value index + if (index[r] === i) { + return r; + } + } + // we did not find row + return top; + } + function _remove(k, j, values, index, ptr) { + // remove value @ k + values.splice(k, 1); + index.splice(k, 1); + // update pointers + for (var x = j + 1; x < ptr.length; x++) { + ptr[x]--; + } + } + function _insert(k, i, j, v, values, index, ptr) { + // insert value + values.splice(k, 0, v); + // update row for k + index.splice(k, 0, i); + // update column pointers + for (var x = j + 1; x < ptr.length; x++) { + ptr[x]++; + } + } + + /** + * Resize the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (resize in place). + * + * @memberof SparseMatrix + * @param {number[] | Matrix} size The new size the matrix should have. + * Since sparse matrices are always two-dimensional, + * size must be two numbers in either an array or a matrix + * @param {*} [defaultValue=0] Default value, filled in on new entries. + * If not provided, the matrix elements will + * be filled with zeros. + * @param {boolean} [copy] Return a resized copy of the matrix + * + * @return {Matrix} The resized matrix + */ + SparseMatrix.prototype.resize = function (size, defaultValue, copy) { + // validate arguments + if (!isCollection(size)) { + throw new TypeError('Array or Matrix expected'); + } + + // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector + var sizeArray = size.valueOf().map(value => { + return Array.isArray(value) && value.length === 1 ? value[0] : value; + }); + if (sizeArray.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // check sizes + sizeArray.forEach(function (value) { + if (!isNumber(value) || !isInteger(value) || value < 0) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + format(sizeArray) + ')'); + } + }); + + // matrix to resize + var m = copy ? this.clone() : this; + // resize matrix + return _resize(m, sizeArray[0], sizeArray[1], defaultValue); + }; + function _resize(matrix, rows, columns, defaultValue) { + // value to insert at the time of growing matrix + var value = defaultValue || 0; + + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + if (isString(matrix._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, matrix._datatype); + // convert value to the same datatype + value = typed.convert(value, matrix._datatype); + } + + // should we insert the value? + var ins = !eq(value, zero); + + // old columns and rows + var r = matrix._size[0]; + var c = matrix._size[1]; + var i, j, k; + + // check we need to increase columns + if (columns > c) { + // loop new columns + for (j = c; j < columns; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._values.length; + // check we need to insert matrix._values + if (ins) { + // loop rows + for (i = 0; i < r; i++) { + // add new matrix._values + matrix._values.push(value); + // update matrix._index + matrix._index.push(i); + } + } + } + // store number of matrix._values in matrix._ptr + matrix._ptr[columns] = matrix._values.length; + } else if (columns < c) { + // truncate matrix._ptr + matrix._ptr.splice(columns + 1, c - columns); + // truncate matrix._values and matrix._index + matrix._values.splice(matrix._ptr[columns], matrix._values.length); + matrix._index.splice(matrix._ptr[columns], matrix._index.length); + } + // update columns + c = columns; + + // check we need to increase rows + if (rows > r) { + // check we have to insert values + if (ins) { + // inserts + var n = 0; + // loop columns + for (j = 0; j < c; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._ptr[j] + n; + // where to insert matrix._values + k = matrix._ptr[j + 1] + n; + // pointer + var p = 0; + // loop new rows, initialize pointer + for (i = r; i < rows; i++, p++) { + // add value + matrix._values.splice(k + p, 0, value); + // update matrix._index + matrix._index.splice(k + p, 0, i); + // increment inserts + n++; + } + } + // store number of matrix._values in matrix._ptr + matrix._ptr[c] = matrix._values.length; + } + } else if (rows < r) { + // deletes + var d = 0; + // loop columns + for (j = 0; j < c; j++) { + // update matrix._ptr for current column + matrix._ptr[j] = matrix._ptr[j] - d; + // where matrix._values start for next column + var k0 = matrix._ptr[j]; + var k1 = matrix._ptr[j + 1] - d; + // loop matrix._index + for (k = k0; k < k1; k++) { + // row + i = matrix._index[k]; + // check we need to delete value and matrix._index + if (i > rows - 1) { + // remove value + matrix._values.splice(k, 1); + // remove item from matrix._index + matrix._index.splice(k, 1); + // increase deletes + d++; + } + } + } + // update matrix._ptr for current column + matrix._ptr[j] = matrix._values.length; + } + // update matrix._size + matrix._size[0] = rows; + matrix._size[1] = columns; + // return matrix + return matrix; + } + + /** + * Reshape the matrix to the given size. Returns a copy of the matrix when + * `copy=true`, otherwise return the matrix itself (reshape in place). + * + * NOTE: This might be better suited to copy by default, instead of modifying + * in place. For now, it operates in place to remain consistent with + * resize(). + * + * @memberof SparseMatrix + * @param {number[]} sizes The new size the matrix should have. + * Since sparse matrices are always two-dimensional, + * size must be two numbers in either an array or a matrix + * @param {boolean} [copy] Return a reshaped copy of the matrix + * + * @return {Matrix} The reshaped matrix + */ + SparseMatrix.prototype.reshape = function (sizes, copy) { + // validate arguments + if (!isArray(sizes)) { + throw new TypeError('Array expected'); + } + if (sizes.length !== 2) { + throw new Error('Sparse matrices can only be reshaped in two dimensions'); + } + + // check sizes + sizes.forEach(function (value) { + if (!isNumber(value) || !isInteger(value) || value <= -2 || value === 0) { + throw new TypeError('Invalid size, must contain positive integers or -1 ' + '(size: ' + format(sizes) + ')'); + } + }); + var currentLength = this._size[0] * this._size[1]; + sizes = processSizesWildcard(sizes, currentLength); + var newLength = sizes[0] * sizes[1]; + + // m * n must not change + if (currentLength !== newLength) { + throw new Error('Reshaping sparse matrix will result in the wrong number of elements'); + } + + // matrix to reshape + var m = copy ? this.clone() : this; + + // return unchanged if the same shape + if (this._size[0] === sizes[0] && this._size[1] === sizes[1]) { + return m; + } + + // Convert to COO format (generate a column index) + var colIndex = []; + for (var i = 0; i < m._ptr.length; i++) { + for (var j = 0; j < m._ptr[i + 1] - m._ptr[i]; j++) { + colIndex.push(i); + } + } + + // Clone the values array + var values = m._values.slice(); + + // Clone the row index array + var rowIndex = m._index.slice(); + + // Transform the (row, column) indices + for (var _i = 0; _i < m._index.length; _i++) { + var r1 = rowIndex[_i]; + var c1 = colIndex[_i]; + var flat = r1 * m._size[1] + c1; + colIndex[_i] = flat % sizes[1]; + rowIndex[_i] = Math.floor(flat / sizes[1]); + } + + // Now reshaping is supposed to preserve the row-major order, BUT these sparse matrices are stored + // in column-major order, so we have to reorder the value array now. One option is to use a multisort, + // sorting several arrays based on some other array. + + // OR, we could easily just: + + // 1. Remove all values from the matrix + m._values.length = 0; + m._index.length = 0; + m._ptr.length = sizes[1] + 1; + m._size = sizes.slice(); + for (var _i2 = 0; _i2 < m._ptr.length; _i2++) { + m._ptr[_i2] = 0; + } + + // 2. Re-insert all elements in the proper order (simplified code from SparseMatrix.prototype.set) + // This step is probably the most time-consuming + for (var h = 0; h < values.length; h++) { + var _i3 = rowIndex[h]; + var _j = colIndex[h]; + var v = values[h]; + var k = _getValueIndex(_i3, m._ptr[_j], m._ptr[_j + 1], m._index); + _insert(k, _i3, _j, v, m._values, m._index, m._ptr); + } + + // The value indices are inserted out of order, but apparently that's... still OK? + + return m; + }; + + /** + * Create a clone of the matrix + * @memberof SparseMatrix + * @return {SparseMatrix} clone + */ + SparseMatrix.prototype.clone = function () { + var m = new SparseMatrix({ + values: this._values ? clone(this._values) : undefined, + index: clone(this._index), + ptr: clone(this._ptr), + size: clone(this._size), + datatype: this._datatype + }); + return m; + }; + + /** + * Retrieve the size of the matrix. + * @memberof SparseMatrix + * @returns {number[]} size + */ + SparseMatrix.prototype.size = function () { + return this._size.slice(0); // copy the Array + }; + + /** + * Create a new matrix with the results of the callback function executed on + * each entry of the matrix. + * @memberof SparseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {SparseMatrix} matrix + */ + SparseMatrix.prototype.map = function (callback, skipZeros) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke map on a Pattern only matrix'); + } + // matrix instance + var me = this; + // rows and columns + var rows = this._size[0]; + var columns = this._size[1]; + var fastCallback = optimizeCallback(callback, me, 'map'); + // invoke callback + var invoke = function invoke(v, i, j) { + // invoke callback + return fastCallback(v, [i, j], me); + }; + // invoke _map + return _map(this, 0, rows - 1, 0, columns - 1, invoke, skipZeros); + }; + + /** + * Create a new matrix with the results of the callback function executed on the interval + * [minRow..maxRow, minColumn..maxColumn]. + */ + function _map(matrix, minRow, maxRow, minColumn, maxColumn, callback, skipZeros) { + // result arrays + var values = []; + var index = []; + var ptr = []; + + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + if (isString(matrix._datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, matrix._datatype); + } + + // invoke callback + var invoke = function invoke(v, x, y) { + // invoke callback + var value = callback(v, x, y); + // check value != 0 + if (!eq(value, zero)) { + // store value + values.push(value); + // index + index.push(x); + } + }; + // loop columns + for (var j = minColumn; j <= maxColumn; j++) { + // store pointer to values index + ptr.push(values.length); + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = matrix._ptr[j]; + var k1 = matrix._ptr[j + 1]; + if (skipZeros) { + // loop k within [k0, k1[ + for (var k = k0; k < k1; k++) { + // row index + var i = matrix._index[k]; + // check i is in range + if (i >= minRow && i <= maxRow) { + // value @ k + invoke(matrix._values[k], i - minRow, j - minColumn); + } + } + } else { + // create a cache holding all defined values + var _values = {}; + for (var _k = k0; _k < k1; _k++) { + var _i4 = matrix._index[_k]; + _values[_i4] = matrix._values[_k]; + } + + // loop over all rows (indexes can be unordered so we can't use that), + // and either read the value or zero + for (var _i5 = minRow; _i5 <= maxRow; _i5++) { + var value = _i5 in _values ? _values[_i5] : 0; + invoke(value, _i5 - minRow, j - minColumn); + } + } + } + + // store number of values in ptr + ptr.push(values.length); + // return sparse matrix + return new SparseMatrix({ + values, + index, + ptr, + size: [maxRow - minRow + 1, maxColumn - minColumn + 1] + }); + } + + /** + * Execute a callback function on each entry of the matrix. + * @memberof SparseMatrix + * @param {Function} callback The callback function is invoked with three + * parameters: the value of the element, the index + * of the element, and the Matrix being traversed. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * If false, the indices are guaranteed to be in order, + * if true, the indices can be unordered. + */ + SparseMatrix.prototype.forEach = function (callback, skipZeros) { + // check it is a pattern matrix + if (!this._values) { + throw new Error('Cannot invoke forEach on a Pattern only matrix'); + } + // matrix instance + var me = this; + // rows and columns + var rows = this._size[0]; + var columns = this._size[1]; + var fastCallback = optimizeCallback(callback, me, 'forEach'); + // loop columns + for (var j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = this._ptr[j]; + var k1 = this._ptr[j + 1]; + if (skipZeros) { + // loop k within [k0, k1[ + for (var k = k0; k < k1; k++) { + // row index + var i = this._index[k]; + + // value @ k + fastCallback(this._values[k], [i, j], me); + } + } else { + // create a cache holding all defined values + var values = {}; + for (var _k2 = k0; _k2 < k1; _k2++) { + var _i6 = this._index[_k2]; + values[_i6] = this._values[_k2]; + } + + // loop over all rows (indexes can be unordered so we can't use that), + // and either read the value or zero + for (var _i7 = 0; _i7 < rows; _i7++) { + var value = _i7 in values ? values[_i7] : 0; + fastCallback(value, [_i7, j], me); + } + } + } + }; + + /** + * Iterate over the matrix elements, skipping zeros + * @return {Iterable<{ value, index: number[] }>} + */ + SparseMatrix.prototype[Symbol.iterator] = function* () { + if (!this._values) { + throw new Error('Cannot iterate a Pattern only matrix'); + } + var columns = this._size[1]; + for (var j = 0; j < columns; j++) { + var k0 = this._ptr[j]; + var k1 = this._ptr[j + 1]; + for (var k = k0; k < k1; k++) { + // row index + var i = this._index[k]; + yield { + value: this._values[k], + index: [i, j] + }; + } + } + }; + + /** + * Create an Array with a copy of the data of the SparseMatrix + * @memberof SparseMatrix + * @returns {Array} array + */ + SparseMatrix.prototype.toArray = function () { + return _toArray(this._values, this._index, this._ptr, this._size, true); + }; + + /** + * Get the primitive value of the SparseMatrix: a two dimensions array + * @memberof SparseMatrix + * @returns {Array} array + */ + SparseMatrix.prototype.valueOf = function () { + return _toArray(this._values, this._index, this._ptr, this._size, false); + }; + function _toArray(values, index, ptr, size, copy) { + // rows and columns + var rows = size[0]; + var columns = size[1]; + // result + var a = []; + // vars + var i, j; + // initialize array + for (i = 0; i < rows; i++) { + a[i] = []; + for (j = 0; j < columns; j++) { + a[i][j] = 0; + } + } + + // loop columns + for (j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = ptr[j]; + var k1 = ptr[j + 1]; + // loop k within [k0, k1[ + for (var k = k0; k < k1; k++) { + // row index + i = index[k]; + // set value (use one for pattern matrix) + a[i][j] = values ? copy ? clone(values[k]) : values[k] : 1; + } + } + return a; + } + + /** + * Get a string representation of the matrix, with optional formatting options. + * @memberof SparseMatrix + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ + SparseMatrix.prototype.format = function (options) { + // rows and columns + var rows = this._size[0]; + var columns = this._size[1]; + // density + var density = this.density(); + // rows & columns + var str = 'Sparse Matrix [' + format(rows, options) + ' x ' + format(columns, options) + '] density: ' + format(density, options) + '\n'; + // loop columns + for (var j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = this._ptr[j]; + var k1 = this._ptr[j + 1]; + // loop k within [k0, k1[ + for (var k = k0; k < k1; k++) { + // row index + var i = this._index[k]; + // append value + str += '\n (' + format(i, options) + ', ' + format(j, options) + ') ==> ' + (this._values ? format(this._values[k], options) : 'X'); + } + } + return str; + }; + + /** + * Get a string representation of the matrix + * @memberof SparseMatrix + * @returns {string} str + */ + SparseMatrix.prototype.toString = function () { + return format(this.toArray()); + }; + + /** + * Get a JSON representation of the matrix + * @memberof SparseMatrix + * @returns {Object} + */ + SparseMatrix.prototype.toJSON = function () { + return { + mathjs: 'SparseMatrix', + values: this._values, + index: this._index, + ptr: this._ptr, + size: this._size, + datatype: this._datatype + }; + }; + + /** + * Get the kth Matrix diagonal. + * + * @memberof SparseMatrix + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved. + * + * @returns {Matrix} The matrix vector with the diagonal values. + */ + SparseMatrix.prototype.diagonal = function (k) { + // validate k if any + if (k) { + // convert BigNumber to a number + if (isBigNumber(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!isNumber(k) || !isInteger(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + var kSuper = k > 0 ? k : 0; + var kSub = k < 0 ? -k : 0; + + // rows & columns + var rows = this._size[0]; + var columns = this._size[1]; + + // number diagonal values + var n = Math.min(rows - kSub, columns - kSuper); + + // diagonal arrays + var values = []; + var index = []; + var ptr = []; + // initial ptr value + ptr[0] = 0; + // loop columns + for (var j = kSuper; j < columns && values.length < n; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = this._ptr[j]; + var k1 = this._ptr[j + 1]; + // loop x within [k0, k1[ + for (var x = k0; x < k1; x++) { + // row index + var i = this._index[x]; + // check row + if (i === j - kSuper + kSub) { + // value on this column + values.push(this._values[x]); + // store row + index[values.length - 1] = i - kSub; + // exit loop + break; + } + } + } + // close ptr + ptr.push(values.length); + // return matrix + return new SparseMatrix({ + values, + index, + ptr, + size: [n, 1] + }); + }; + + /** + * Generate a matrix from a JSON object + * @memberof SparseMatrix + * @param {Object} json An object structured like + * `{"mathjs": "SparseMatrix", "values": [], "index": [], "ptr": [], "size": []}`, + * where mathjs is optional + * @returns {SparseMatrix} + */ + SparseMatrix.fromJSON = function (json) { + return new SparseMatrix(json); + }; + + /** + * Create a diagonal matrix. + * + * @memberof SparseMatrix + * @param {Array} size The matrix size. + * @param {number | Array | Matrix } value The values for the diagonal. + * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in. + * @param {number} [defaultValue] The default value for non-diagonal + * @param {string} [datatype] The Matrix datatype, values must be of this datatype. + * + * @returns {SparseMatrix} + */ + SparseMatrix.diagonal = function (size, value, k, defaultValue, datatype) { + if (!isArray(size)) { + throw new TypeError('Array expected, size parameter'); + } + if (size.length !== 2) { + throw new Error('Only two dimensions matrix are supported'); + } + + // map size & validate + size = size.map(function (s) { + // check it is a big number + if (isBigNumber(s)) { + // convert it + s = s.toNumber(); + } + // validate arguments + if (!isNumber(s) || !isInteger(s) || s < 1) { + throw new Error('Size values must be positive integers'); + } + return s; + }); + + // validate k if any + if (k) { + // convert BigNumber to a number + if (isBigNumber(k)) { + k = k.toNumber(); + } + // is must be an integer + if (!isNumber(k) || !isInteger(k)) { + throw new TypeError('The parameter k must be an integer number'); + } + } else { + // default value + k = 0; + } + + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + if (isString(datatype)) { + // find signature that matches (datatype, datatype) + eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; + // convert 0 to the same datatype + zero = typed.convert(0, datatype); + } + var kSuper = k > 0 ? k : 0; + var kSub = k < 0 ? -k : 0; + + // rows and columns + var rows = size[0]; + var columns = size[1]; + + // number of non-zero items + var n = Math.min(rows - kSub, columns - kSuper); + + // value extraction function + var _value; + + // check value + if (isArray(value)) { + // validate array + if (value.length !== n) { + // number of values in array must be n + throw new Error('Invalid value array length'); + } + // define function + _value = function _value(i) { + // return value @ i + return value[i]; + }; + } else if (isMatrix(value)) { + // matrix size + var ms = value.size(); + // validate matrix + if (ms.length !== 1 || ms[0] !== n) { + // number of values in array must be n + throw new Error('Invalid matrix length'); + } + // define function + _value = function _value(i) { + // return value @ i + return value.get([i]); + }; + } else { + // define function + _value = function _value() { + // return value + return value; + }; + } + + // create arrays + var values = []; + var index = []; + var ptr = []; + + // loop items + for (var j = 0; j < columns; j++) { + // number of rows with value + ptr.push(values.length); + // diagonal index + var i = j - kSuper; + // check we need to set diagonal value + if (i >= 0 && i < n) { + // get value @ i + var v = _value(i); + // check for zero + if (!eq(v, zero)) { + // column + index.push(i + kSub); + // add value + values.push(v); + } + } + } + // last value should be number of values + ptr.push(values.length); + // create SparseMatrix + return new SparseMatrix({ + values, + index, + ptr, + size: [rows, columns] + }); + }; + + /** + * Swap rows i and j in Matrix. + * + * @memberof SparseMatrix + * @param {number} i Matrix row index 1 + * @param {number} j Matrix row index 2 + * + * @return {Matrix} The matrix reference + */ + SparseMatrix.prototype.swapRows = function (i, j) { + // check index + if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) { + throw new Error('Row index must be positive integers'); + } + // check dimensions + if (this._size.length !== 2) { + throw new Error('Only two dimensional matrix is supported'); + } + // validate index + validateIndex(i, this._size[0]); + validateIndex(j, this._size[0]); + + // swap rows + SparseMatrix._swapRows(i, j, this._size[1], this._values, this._index, this._ptr); + // return current instance + return this; + }; + + /** + * Loop rows with data in column j. + * + * @param {number} j Column + * @param {Array} values Matrix values + * @param {Array} index Matrix row indeces + * @param {Array} ptr Matrix column pointers + * @param {Function} callback Callback function invoked for every row in column j + */ + SparseMatrix._forEachRow = function (j, values, index, ptr, callback) { + // indeces for column j + var k0 = ptr[j]; + var k1 = ptr[j + 1]; + + // loop + for (var k = k0; k < k1; k++) { + // invoke callback + callback(index[k], values[k]); + } + }; + + /** + * Swap rows x and y in Sparse Matrix data structures. + * + * @param {number} x Matrix row index 1 + * @param {number} y Matrix row index 2 + * @param {number} columns Number of columns in matrix + * @param {Array} values Matrix values + * @param {Array} index Matrix row indeces + * @param {Array} ptr Matrix column pointers + */ + SparseMatrix._swapRows = function (x, y, columns, values, index, ptr) { + // loop columns + for (var j = 0; j < columns; j++) { + // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1] + var k0 = ptr[j]; + var k1 = ptr[j + 1]; + // find value index @ x + var kx = _getValueIndex(x, k0, k1, index); + // find value index @ x + var ky = _getValueIndex(y, k0, k1, index); + // check both rows exist in matrix + if (kx < k1 && ky < k1 && index[kx] === x && index[ky] === y) { + // swap values (check for pattern matrix) + if (values) { + var v = values[kx]; + values[kx] = values[ky]; + values[ky] = v; + } + // next column + continue; + } + // check x row exist & no y row + if (kx < k1 && index[kx] === x && (ky >= k1 || index[ky] !== y)) { + // value @ x (check for pattern matrix) + var vx = values ? values[kx] : undefined; + // insert value @ y + index.splice(ky, 0, y); + if (values) { + values.splice(ky, 0, vx); + } + // remove value @ x (adjust array index if needed) + index.splice(ky <= kx ? kx + 1 : kx, 1); + if (values) { + values.splice(ky <= kx ? kx + 1 : kx, 1); + } + // next column + continue; + } + // check y row exist & no x row + if (ky < k1 && index[ky] === y && (kx >= k1 || index[kx] !== x)) { + // value @ y (check for pattern matrix) + var vy = values ? values[ky] : undefined; + // insert value @ x + index.splice(kx, 0, x); + if (values) { + values.splice(kx, 0, vy); + } + // remove value @ y (adjust array index if needed) + index.splice(kx <= ky ? ky + 1 : ky, 1); + if (values) { + values.splice(kx <= ky ? ky + 1 : ky, 1); + } + } + } + }; + return SparseMatrix; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/index.js new file mode 100644 index 0000000..3630756 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/index.js @@ -0,0 +1,64 @@ +import { isBigNumber, isMatrix, isArray } from '../../../utils/is.js'; +import { factory } from '../../../utils/factory.js'; +var name = 'index'; +var dependencies = ['typed', 'Index']; +export var createIndex = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Index + } = _ref; + /** + * Create an index. An Index can store ranges having start, step, and end + * for multiple dimensions. + * Matrix.get, Matrix.set, and math.subset accept an Index as input. + * + * Syntax: + * + * math.index(range1, range2, ...) + * + * Where each range can be any of: + * + * - A number + * - A string for getting/setting an object property + * - An instance of `Range` + * - A one-dimensional Array or a Matrix with numbers or booleans + * + * Indexes must be zero-based, integer numbers. + * + * Examples: + * + * const b = [1, 2, 3, 4, 5] + * math.subset(b, math.index([1, 2, 3])) // returns [2, 3, 4] + * math.subset(b, math.index([false, true, true, true, false])) // returns [2, 3, 4] + * + * const a = math.matrix([[1, 2], [3, 4]]) + * a.subset(math.index(0, 1)) // returns 2 + * a.subset(math.index(0, [false, true])) // returns 2 + * + * See also: + * + * bignumber, boolean, complex, matrix, number, string, unit + * + * @param {...*} ranges Zero or more ranges or numbers. + * @return {Index} Returns the created index + */ + return typed(name, { + '...number | string | BigNumber | Range | Array | Matrix': function number__string__BigNumber__Range__Array__Matrix(args) { + var ranges = args.map(function (arg) { + if (isBigNumber(arg)) { + return arg.toNumber(); // convert BigNumber to Number + } else if (isArray(arg) || isMatrix(arg)) { + return arg.map(function (elem) { + // convert BigNumber to Number + return isBigNumber(elem) ? elem.toNumber() : elem; + }); + } else { + return arg; + } + }); + var res = new Index(); + Index.apply(res, ranges); + return res; + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/matrix.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/matrix.js new file mode 100644 index 0000000..c234c7a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/matrix.js @@ -0,0 +1,82 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'matrix'; +var dependencies = ['typed', 'Matrix', 'DenseMatrix', 'SparseMatrix']; +export var createMatrix = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Matrix, + DenseMatrix, + SparseMatrix + } = _ref; + /** + * Create a Matrix. The function creates a new `math.Matrix` object from + * an `Array`. A Matrix has utility functions to manipulate the data in the + * matrix, like getting the size and getting or setting values in the matrix. + * Supported storage formats are 'dense' and 'sparse'. + * + * Syntax: + * + * math.matrix() // creates an empty matrix using default storage format (dense). + * math.matrix(data) // creates a matrix with initial data using default storage format (dense). + * math.matrix('dense') // creates an empty matrix using the given storage format. + * math.matrix(data, 'dense') // creates a matrix with initial data using the given storage format. + * math.matrix(data, 'sparse') // creates a sparse matrix with initial data. + * math.matrix(data, 'sparse', 'number') // creates a sparse matrix with initial data, number data type. + * + * Examples: + * + * let m = math.matrix([[1, 2], [3, 4]]) + * m.size() // Array [2, 2] + * m.resize([3, 2], 5) + * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]] + * m.get([1, 0]) // number 3 + * + * See also: + * + * bignumber, boolean, complex, index, number, string, unit, sparse + * + * @param {Array | Matrix} [data] A multi dimensional array + * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'` + * @param {string} [datatype] Type of the values + * + * @return {Matrix} The created matrix + */ + return typed(name, { + '': function _() { + return _create([]); + }, + string: function string(format) { + return _create([], format); + }, + 'string, string': function string_string(format, datatype) { + return _create([], format, datatype); + }, + Array: function Array(data) { + return _create(data); + }, + Matrix: function Matrix(data) { + return _create(data, data.storage()); + }, + 'Array | Matrix, string': _create, + 'Array | Matrix, string, string': _create + }); + + /** + * Create a new Matrix with given storage format + * @param {Array} data + * @param {string} [format] + * @param {string} [datatype] + * @returns {Matrix} Returns a new Matrix + * @private + */ + function _create(data, format, datatype) { + // get storage format constructor + if (format === 'dense' || format === 'default' || format === undefined) { + return new DenseMatrix(data, datatype); + } + if (format === 'sparse') { + return new SparseMatrix(data, datatype); + } + throw new TypeError('Unknown matrix type ' + JSON.stringify(format) + '.'); + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/sparse.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/sparse.js new file mode 100644 index 0000000..8fa3bc0 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/function/sparse.js @@ -0,0 +1,56 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'sparse'; +var dependencies = ['typed', 'SparseMatrix']; +export var createSparse = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + SparseMatrix + } = _ref; + /** + * Create a Sparse Matrix. The function creates a new `math.Matrix` object from + * an `Array`. A Matrix has utility functions to manipulate the data in the + * matrix, like getting the size and getting or setting values in the matrix. + * Note that a Sparse Matrix is always 2-dimensional, so for example if + * you create one from a plain array of _n_ numbers, you get an _n_ by 1 + * Sparse "column vector". + * + * Syntax: + * + * math.sparse() // creates an empty sparse matrix. + * math.sparse(data) // creates a sparse matrix with initial data. + * math.sparse(data, 'number') // creates a sparse matrix with initial data, number datatype. + * + * Examples: + * + * let m = math.sparse([[1, 2], [3, 4]]) + * m.size() // Array [2, 2] + * m.resize([3, 2], 5) + * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]] + * m.get([1, 0]) // number 3 + * let v = math.sparse([0, 0, 1]) + * v.size() // Array [3, 1] + * v.get([2, 0]) // number 1 + * + * See also: + * + * bignumber, boolean, complex, index, number, string, unit, matrix + * + * @param {Array | Matrix} [data] A two dimensional array + * + * @return {Matrix} The created matrix + */ + return typed(name, { + '': function _() { + return new SparseMatrix([]); + }, + string: function string(datatype) { + return new SparseMatrix([], datatype); + }, + 'Array | Matrix': function Array__Matrix(data) { + return new SparseMatrix(data); + }, + 'Array | Matrix, string': function Array__Matrix_string(data, datatype) { + return new SparseMatrix(data, datatype); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/broadcast.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/broadcast.js new file mode 100644 index 0000000..4afb20e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/broadcast.js @@ -0,0 +1,40 @@ +import { broadcastSizes, broadcastTo } from '../../../utils/array.js'; +import { deepStrictEqual } from '../../../utils/object.js'; + +/** +* Broadcasts two matrices, and return both in an array +* It checks if it's possible with broadcasting rules +* +* @param {Matrix} A First Matrix +* @param {Matrix} B Second Matrix +* +* @return {Matrix[]} [ broadcastedA, broadcastedB ] +*/ + +export function broadcast(A, B) { + if (deepStrictEqual(A.size(), B.size())) { + // If matrices have the same size return them + return [A, B]; + } + + // calculate the broadcasted sizes + var newSize = broadcastSizes(A.size(), B.size()); + + // return the array with the two broadcasted matrices + return [A, B].map(M => _broadcastTo(M, newSize)); +} + +/** + * Broadcasts a matrix to the given size. + * + * @param {Matrix} M - The matrix to be broadcasted. + * @param {number[]} size - The desired size of the broadcasted matrix. + * @returns {Matrix} The broadcasted matrix. + * @throws {Error} If the size parameter is not an array of numbers. + */ +function _broadcastTo(M, size) { + if (deepStrictEqual(M.size(), size)) { + return M; + } + return M.create(broadcastTo(M.valueOf(), size), M.datatype()); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo01xDSid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo01xDSid.js new file mode 100644 index 0000000..327948c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo01xDSid.js @@ -0,0 +1,112 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo01xDSid'; +var dependencies = ['typed']; +export var createMatAlgo01xDSid = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij). + * Callback function invoked NNZ times (number of nonzero items in SparseMatrix). + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ Dij ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (S) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function algorithm1(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + var adata = denseMatrix._data; + var asize = denseMatrix._size; + var adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + var bvalues = sparseMatrix._values; + var bindex = sparseMatrix._index; + var bptr = sparseMatrix._ptr; + var bsize = sparseMatrix._size; + var bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // process data types + var dt = typeof adt === 'string' && adt !== 'mixed' && adt === bdt ? adt : undefined; + // callback function + var cf = dt ? typed.find(callback, [dt, dt]) : callback; + + // vars + var i, j; + + // result (DenseMatrix) + var cdata = []; + // initialize c + for (i = 0; i < rows; i++) { + cdata[i] = []; + } + + // workspace + var x = []; + // marks indicating we have a value in x for a given column + var w = []; + + // loop columns in b + for (j = 0; j < columns; j++) { + // column mark + var mark = j + 1; + // values in column j + for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // update workspace + x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + // mark i as updated + w[i] = mark; + } + // loop rows + for (i = 0; i < rows; i++) { + // check row is in workspace + if (w[i] === mark) { + // c[i][j] was already calculated + cdata[i][j] = x[i]; + } else { + // item does not exist in S + cdata[i][j] = adata[i][j]; + } + } + } + + // return dense matrix + return denseMatrix.createDenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo02xDS0.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo02xDS0.js new file mode 100644 index 0000000..82e4042 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo02xDS0.js @@ -0,0 +1,116 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo02xDS0'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo02xDS0 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij). + * Callback function invoked NNZ times (number of nonzero items in SparseMatrix). + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (S) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function matAlgo02xDS0(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + var adata = denseMatrix._data; + var asize = denseMatrix._size; + var adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + var bvalues = sparseMatrix._values; + var bindex = sparseMatrix._index; + var bptr = sparseMatrix._ptr; + var bsize = sparseMatrix._size; + var bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result (SparseMatrix) + var cvalues = []; + var cindex = []; + var cptr = []; + + // loop columns in b + for (var j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // values in column j + for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + var i = bindex[k]; + // update C(i,j) + var cij = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + // check for nonzero + if (!eq(cij, zero)) { + // push i & v + cindex.push(i); + cvalues.push(cij); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return sparseMatrix.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo03xDSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo03xDSf.js new file mode 100644 index 0000000..b06d8b7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo03xDSf.js @@ -0,0 +1,122 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo03xDSf'; +var dependencies = ['typed']; +export var createMatAlgo03xDSf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Iterates over SparseMatrix items and invokes the callback function f(Dij, Sij). + * Callback function invoked M*N times. + * + * + * ┌ f(Dij, Sij) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ f(Dij, 0) ; otherwise + * + * + * @param {Matrix} denseMatrix The DenseMatrix instance (D) + * @param {Matrix} sparseMatrix The SparseMatrix instance (C) + * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j) + * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij) + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571 + */ + return function matAlgo03xDSf(denseMatrix, sparseMatrix, callback, inverse) { + // dense matrix arrays + var adata = denseMatrix._data; + var asize = denseMatrix._size; + var adt = denseMatrix._datatype || denseMatrix.getDataType(); + // sparse matrix arrays + var bvalues = sparseMatrix._values; + var bindex = sparseMatrix._index; + var bptr = sparseMatrix._ptr; + var bsize = sparseMatrix._size; + var bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!bvalues) { + throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result (DenseMatrix) + var cdata = []; + + // initialize dense matrix + for (var z = 0; z < rows; z++) { + // initialize row + cdata[z] = []; + } + + // workspace + var x = []; + // marks indicating we have a value in x for a given column + var w = []; + + // loop columns in b + for (var j = 0; j < columns; j++) { + // column mark + var mark = j + 1; + // values in column j + for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + var i = bindex[k]; + // update workspace + x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); + w[i] = mark; + } + // process workspace + for (var y = 0; y < rows; y++) { + // check we have a calculated value for current row + if (w[y] === mark) { + // use calculated value + cdata[y][j] = x[y]; + } else { + // calculate value + cdata[y][j] = inverse ? cf(zero, adata[y][j]) : cf(adata[y][j], zero); + } + } + } + + // return dense matrix + return denseMatrix.createDenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo04xSidSid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo04xSidSid.js new file mode 100644 index 0000000..ee1ce13 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo04xSidSid.js @@ -0,0 +1,179 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo04xSidSid'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo04xSidSid = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0 + * └ B(i,j) ; A(i,j) === 0 + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo04xSidSid(a, b, callback) { + // sparse matrix arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = avalues && bvalues ? [] : undefined; + var cindex = []; + var cptr = []; + + // workspace + var xa = avalues && bvalues ? [] : undefined; + var xb = avalues && bvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + var wa = []; + var wb = []; + + // vars + var i, j, k, k0, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + var mark = j + 1; + // loop A(:,j) + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // update c + cindex.push(i); + // update workspace + wa[i] = mark; + // check we need to process values + if (xa) { + xa[i] = avalues[k]; + } + } + // loop B(:,j) + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // check row exists in A + if (wa[i] === mark) { + // update record in xa @ i + if (xa) { + // invoke callback + var v = cf(xa[i], bvalues[k]); + // check for zero + if (!eq(v, zero)) { + // update workspace + xa[i] = v; + } else { + // remove mark (index will be removed later) + wa[i] = null; + } + } + } else { + // update c + cindex.push(i); + // update workspace + wb[i] = mark; + // check we need to process values + if (xb) { + xb[i] = bvalues[k]; + } + } + } + // check we need to process values (non pattern matrix) + if (xa && xb) { + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // check workspace has value @ i + if (wa[i] === mark) { + // push value (Aij != 0 || (Aij != 0 && Bij != 0)) + cvalues[k] = xa[i]; + // increment pointer + k++; + } else if (wb[i] === mark) { + // push value (bij != 0) + cvalues[k] = xb[i]; + // increment pointer + k++; + } else { + // remove index @ k + cindex.splice(k, 1); + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo05xSfSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo05xSfSf.js new file mode 100644 index 0000000..e28e182 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo05xSfSf.js @@ -0,0 +1,171 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo05xSfSf'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo05xSfSf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 || B(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo05xSfSf(a, b, callback) { + // sparse matrix arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = avalues && bvalues ? [] : undefined; + var cindex = []; + var cptr = []; + + // workspaces + var xa = cvalues ? [] : undefined; + var xb = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + var wa = []; + var wb = []; + + // vars + var i, j, k, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + var mark = j + 1; + // loop values A(:,j) + for (k = aptr[j], k1 = aptr[j + 1]; k < k1; k++) { + // row + i = aindex[k]; + // push index + cindex.push(i); + // update workspace + wa[i] = mark; + // check we need to process values + if (xa) { + xa[i] = avalues[k]; + } + } + // loop values B(:,j) + for (k = bptr[j], k1 = bptr[j + 1]; k < k1; k++) { + // row + i = bindex[k]; + // check row existed in A + if (wa[i] !== mark) { + // push index + cindex.push(i); + } + // update workspace + wb[i] = mark; + // check we need to process values + if (xb) { + xb[i] = bvalues[k]; + } + } + // check we need to process values (non pattern matrix) + if (cvalues) { + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // marks + var wai = wa[i]; + var wbi = wb[i]; + // check Aij or Bij are nonzero + if (wai === mark || wbi === mark) { + // matrix values @ i,j + var va = wai === mark ? xa[i] : zero; + var vb = wbi === mark ? xb[i] : zero; + // Cij + var vc = cf(va, vb); + // check for zero + if (!eq(vc, zero)) { + // push value + cvalues.push(vc); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo06xS0S0.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo06xS0S0.js new file mode 100644 index 0000000..974ec52 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo06xS0S0.js @@ -0,0 +1,153 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +import { scatter } from '../../../utils/collection.js'; +var name = 'matAlgo06xS0S0'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo06xS0S0 = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked (Anz U Bnz) times, where Anz and Bnz are the nonzero elements in both matrices. + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo06xS0S0(a, b, callback) { + // sparse matrix arrays + var avalues = a._values; + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bvalues = b._values; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = avalues && bvalues ? [] : undefined; + var cindex = []; + var cptr = []; + + // workspaces + var x = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + var w = []; + // marks indicating value in a given row has been updated + var u = []; + + // loop columns + for (var j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + var mark = j + 1; + // scatter the values of A(:,j) into workspace + scatter(a, j, w, x, u, mark, cindex, cf); + // scatter the values of B(:,j) into workspace + scatter(b, j, w, x, u, mark, cindex, cf); + // check we need to process values (non pattern matrix) + if (x) { + // initialize first index in j + var k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + var i = cindex[k]; + // check function was invoked on current row (Aij !=0 && Bij != 0) + if (u[i] === mark) { + // value @ i + var v = x[i]; + // check for zero value + if (!eq(v, zero)) { + // push value + cvalues.push(v); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } else { + // initialize first index in j + var p = cptr[j]; + // loop index in j + while (p < cindex.length) { + // row + var r = cindex[p]; + // check function was invoked on current row (Aij !=0 && Bij != 0) + if (u[r] !== mark) { + // remove value @ i, do not increment pointer + cindex.splice(p, 1); + } else { + // increment pointer + p++; + } + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo07xSSf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo07xSSf.js new file mode 100644 index 0000000..71d12b1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo07xSSf.js @@ -0,0 +1,119 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo07xSSf'; +var dependencies = ['typed', 'DenseMatrix']; +export var createMatAlgo07xSSf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B items (zero and nonzero) and invokes the callback function f(Aij, Bij). + * Callback function invoked MxN times. + * + * C(i,j) = f(Aij, Bij) + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} DenseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo07xSSf(a, b, callback) { + // sparse matrix arrays + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // vars + var i, j; + + // result arrays + var cdata = []; + // initialize c + for (i = 0; i < rows; i++) { + cdata[i] = []; + } + + // workspaces + var xa = []; + var xb = []; + // marks indicating we have a value in x for a given column + var wa = []; + var wb = []; + + // loop columns + for (j = 0; j < columns; j++) { + // columns mark + var mark = j + 1; + // scatter the values of A(:,j) into workspace + _scatter(a, j, wa, xa, mark); + // scatter the values of B(:,j) into workspace + _scatter(b, j, wb, xb, mark); + // loop rows + for (i = 0; i < rows; i++) { + // matrix values @ i,j + var va = wa[i] === mark ? xa[i] : zero; + var vb = wb[i] === mark ? xb[i] : zero; + // invoke callback + cdata[i][j] = cf(va, vb); + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; + function _scatter(m, j, w, x, mark) { + // a arrays + var values = m._values; + var index = m._index; + var ptr = m._ptr; + // loop values in column j + for (var k = ptr[j], k1 = ptr[j + 1]; k < k1; k++) { + // row + var i = index[k]; + // update workspace + w[i] = mark; + x[i] = values[k]; + } + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo08xS0Sid.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo08xS0Sid.js new file mode 100644 index 0000000..4fb4909 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo08xS0Sid.js @@ -0,0 +1,154 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo08xS0Sid'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo08xS0Sid = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij). + * Callback function invoked MAX(NNZA, NNZB) times + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0 + * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0 && B(i,j) === 0 + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo08xS0Sid(a, b, callback) { + // sparse matrix arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // sparse matrix cannot be a Pattern matrix + if (!avalues || !bvalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrices'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = []; + var cindex = []; + var cptr = []; + + // workspace + var x = []; + // marks indicating we have a value in x for a given column + var w = []; + + // vars + var k, k0, k1, i; + + // loop columns + for (var j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // columns mark + var mark = j + 1; + // loop values in a + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // mark workspace + w[i] = mark; + // set value + x[i] = avalues[k]; + // add index + cindex.push(i); + } + // loop values in b + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // check value exists in workspace + if (w[i] === mark) { + // evaluate callback + x[i] = cf(x[i], bvalues[k]); + } + } + // initialize first index in j + k = cptr[j]; + // loop index in j + while (k < cindex.length) { + // row + i = cindex[k]; + // value @ i + var v = x[i]; + // check for zero value + if (!eq(v, zero)) { + // push value + cvalues.push(v); + // increment pointer + k++; + } else { + // remove value @ i, do not increment pointer + cindex.splice(k, 1); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo09xS0Sf.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo09xS0Sf.js new file mode 100644 index 0000000..0677453 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo09xS0Sf.js @@ -0,0 +1,142 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo09xS0Sf'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo09xS0Sf = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix A and invokes the callback function f(Aij, Bij). + * Callback function invoked NZA times, number of nonzero elements in A. + * + * + * ┌ f(Aij, Bij) ; A(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} a The SparseMatrix instance (A) + * @param {Matrix} b The SparseMatrix instance (B) + * @param {Function} callback The f(Aij,Bij) operation to invoke + * + * @return {Matrix} SparseMatrix (C) + * + * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294 + */ + return function matAlgo09xS0Sf(a, b, callback) { + // sparse matrix arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + var asize = a._size; + var adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType(); + // sparse matrix arrays + var bvalues = b._values; + var bindex = b._index; + var bptr = b._ptr; + var bsize = b._size; + var bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType(); + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // check rows & columns + if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = avalues && bvalues ? [] : undefined; + var cindex = []; + var cptr = []; + + // workspaces + var x = cvalues ? [] : undefined; + // marks indicating we have a value in x for a given column + var w = []; + + // vars + var i, j, k, k0, k1; + + // loop columns + for (j = 0; j < columns; j++) { + // update cptr + cptr[j] = cindex.length; + // column mark + var mark = j + 1; + // check we need to process values + if (x) { + // loop B(:,j) + for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) { + // row + i = bindex[k]; + // update workspace + w[i] = mark; + x[i] = bvalues[k]; + } + } + // loop A(:,j) + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check we need to process values + if (x) { + // b value @ i,j + var vb = w[i] === mark ? x[i] : zero; + // invoke f + var vc = cf(avalues[k], vb); + // check zero value + if (!eq(vc, zero)) { + // push index + cindex.push(i); + // push value + cvalues.push(vc); + } + } else { + // push index + cindex.push(i); + } + } + } + // update cptr + cptr[columns] = cindex.length; + + // return sparse matrix + return a.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo10xSids.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo10xSids.js new file mode 100644 index 0000000..0c6a632 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo10xSids.js @@ -0,0 +1,105 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'matAlgo10xSids'; +var dependencies = ['typed', 'DenseMatrix']; +export var createMatAlgo10xSids = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked NZ times (number of nonzero items in S). + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ b ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo10xSids(s, b, callback, inverse) { + // sparse matrix arrays + var avalues = s._values; + var aindex = s._index; + var aptr = s._ptr; + var asize = s._size; + var adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cdata = []; + + // workspaces + var x = []; + // marks indicating we have a value in x for a given column + var w = []; + + // loop columns + for (var j = 0; j < columns; j++) { + // columns mark + var mark = j + 1; + // values in j + for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + var r = aindex[k]; + // update workspace + x[r] = avalues[k]; + w[r] = mark; + } + // loop rows + for (var i = 0; i < rows; i++) { + // initialize C on first column + if (j === 0) { + // create row array + cdata[i] = []; + } + // check sparse matrix has a value @ i,j + if (w[i] === mark) { + // invoke callback, update C + cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b); + } else { + // dense matrix value @ i, j + cdata[i][j] = b; + } + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo11xS0s.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo11xS0s.js new file mode 100644 index 0000000..08b0997 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo11xS0s.js @@ -0,0 +1,103 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'matAlgo11xS0s'; +var dependencies = ['typed', 'equalScalar']; +export var createMatAlgo11xS0s = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + equalScalar + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked NZ times (number of nonzero items in S). + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ 0 ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} SparseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo11xS0s(s, b, callback, inverse) { + // sparse matrix arrays + var avalues = s._values; + var aindex = s._index; + var aptr = s._ptr; + var asize = s._size; + var adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // equal signature to use + var eq = equalScalar; + // zero value + var zero = 0; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // find signature that matches (dt, dt) + eq = typed.find(equalScalar, [dt, dt]); + // convert 0 to the same datatype + zero = typed.convert(0, dt); + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cvalues = []; + var cindex = []; + var cptr = []; + + // loop columns + for (var j = 0; j < columns; j++) { + // initialize ptr + cptr[j] = cindex.length; + // values in j + for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + var i = aindex[k]; + // invoke callback + var v = inverse ? cf(b, avalues[k]) : cf(avalues[k], b); + // check value is zero + if (!eq(v, zero)) { + // push index & value + cindex.push(i); + cvalues.push(v); + } + } + } + // update ptr + cptr[columns] = cindex.length; + + // return sparse matrix + return s.createSparseMatrix({ + values: cvalues, + index: cindex, + ptr: cptr, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo12xSfs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo12xSfs.js new file mode 100644 index 0000000..d702faa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo12xSfs.js @@ -0,0 +1,105 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'matAlgo12xSfs'; +var dependencies = ['typed', 'DenseMatrix']; +export var createMatAlgo12xSfs = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + DenseMatrix + } = _ref; + /** + * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b). + * Callback function invoked MxN times. + * + * + * ┌ f(Sij, b) ; S(i,j) !== 0 + * C(i,j) = ┤ + * └ f(0, b) ; otherwise + * + * + * @param {Matrix} s The SparseMatrix instance (S) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813 + */ + return function matAlgo12xSfs(s, b, callback, inverse) { + // sparse matrix arrays + var avalues = s._values; + var aindex = s._index; + var aptr = s._ptr; + var asize = s._size; + var adt = s._datatype; + + // sparse matrix cannot be a Pattern matrix + if (!avalues) { + throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value'); + } + + // rows & columns + var rows = asize[0]; + var columns = asize[1]; + + // datatype + var dt; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // result arrays + var cdata = []; + + // workspaces + var x = []; + // marks indicating we have a value in x for a given column + var w = []; + + // loop columns + for (var j = 0; j < columns; j++) { + // columns mark + var mark = j + 1; + // values in j + for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + var r = aindex[k]; + // update workspace + x[r] = avalues[k]; + w[r] = mark; + } + // loop rows + for (var i = 0; i < rows; i++) { + // initialize C on first column + if (j === 0) { + // create row array + cdata[i] = []; + } + // check sparse matrix has a value @ i,j + if (w[i] === mark) { + // invoke callback, update C + cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b); + } else { + // dense matrix value @ i, j + cdata[i][j] = inverse ? cf(b, 0) : cf(0, b); + } + } + } + + // return dense matrix + return new DenseMatrix({ + data: cdata, + size: [rows, columns], + datatype: dt + }); + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo13xDD.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo13xDD.js new file mode 100644 index 0000000..afd55fa --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo13xDD.js @@ -0,0 +1,94 @@ +import { factory } from '../../../utils/factory.js'; +import { DimensionError } from '../../../error/DimensionError.js'; +var name = 'matAlgo13xDD'; +var dependencies = ['typed']; +export var createMatAlgo13xDD = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, Bij..z). + * Callback function invoked MxN times. + * + * C(i,j,...z) = f(Aij..z, Bij..z) + * + * @param {Matrix} a The DenseMatrix instance (A) + * @param {Matrix} b The DenseMatrix instance (B) + * @param {Function} callback The f(Aij..z,Bij..z) operation to invoke + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97658658 + */ + return function matAlgo13xDD(a, b, callback) { + // a arrays + var adata = a._data; + var asize = a._size; + var adt = a._datatype; + // b arrays + var bdata = b._data; + var bsize = b._size; + var bdt = b._datatype; + // c arrays + var csize = []; + + // validate dimensions + if (asize.length !== bsize.length) { + throw new DimensionError(asize.length, bsize.length); + } + + // validate each one of the dimension sizes + for (var s = 0; s < asize.length; s++) { + // must match + if (asize[s] !== bsize[s]) { + throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')'); + } + // update dimension in c + csize[s] = asize[s]; + } + + // datatype + var dt; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string' && adt === bdt) { + // datatype + dt = adt; + // callback + cf = typed.find(callback, [dt, dt]); + } + + // populate cdata, iterate through dimensions + var cdata = csize.length > 0 ? _iterate(cf, 0, csize, csize[0], adata, bdata) : []; + + // c matrix + return a.createDenseMatrix({ + data: cdata, + size: csize, + datatype: dt + }); + }; + + // recursive function + function _iterate(f, level, s, n, av, bv) { + // initialize array for this level + var cv = []; + // check we reach the last level + if (level === s.length - 1) { + // loop arrays in last level + for (var i = 0; i < n; i++) { + // invoke callback and store value + cv[i] = f(av[i], bv[i]); + } + } else { + // iterate current level + for (var j = 0; j < n; j++) { + // iterate next level + cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv[j]); + } + } + return cv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo14xDs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo14xDs.js new file mode 100644 index 0000000..7c54e55 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matAlgo14xDs.js @@ -0,0 +1,76 @@ +import { factory } from '../../../utils/factory.js'; +import { clone } from '../../../utils/object.js'; +var name = 'matAlgo14xDs'; +var dependencies = ['typed']; +export var createMatAlgo14xDs = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, b). + * Callback function invoked MxN times. + * + * C(i,j,...z) = f(Aij..z, b) + * + * @param {Matrix} a The DenseMatrix instance (A) + * @param {Scalar} b The Scalar value + * @param {Function} callback The f(Aij..z,b) operation to invoke + * @param {boolean} inverse A true value indicates callback should be invoked f(b,Aij..z) + * + * @return {Matrix} DenseMatrix (C) + * + * https://github.com/josdejong/mathjs/pull/346#issuecomment-97659042 + */ + return function matAlgo14xDs(a, b, callback, inverse) { + // a arrays + var adata = a._data; + var asize = a._size; + var adt = a._datatype; + + // datatype + var dt; + // callback signature to use + var cf = callback; + + // process data types + if (typeof adt === 'string') { + // datatype + dt = adt; + // convert b to the same datatype + b = typed.convert(b, dt); + // callback + cf = typed.find(callback, [dt, dt]); + } + + // populate cdata, iterate through dimensions + var cdata = asize.length > 0 ? _iterate(cf, 0, asize, asize[0], adata, b, inverse) : []; + + // c matrix + return a.createDenseMatrix({ + data: cdata, + size: clone(asize), + datatype: dt + }); + }; + + // recursive function + function _iterate(f, level, s, n, av, bv, inverse) { + // initialize array for this level + var cv = []; + // check we reach the last level + if (level === s.length - 1) { + // loop arrays in last level + for (var i = 0; i < n; i++) { + // invoke callback and store value + cv[i] = inverse ? f(bv, av[i]) : f(av[i], bv); + } + } else { + // iterate current level + for (var j = 0; j < n; j++) { + // iterate next level + cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv, inverse); + } + } + return cv; + } +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matrixAlgorithmSuite.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matrixAlgorithmSuite.js new file mode 100644 index 0000000..1814a79 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/matrix/utils/matrixAlgorithmSuite.js @@ -0,0 +1,152 @@ +import { factory } from '../../../utils/factory.js'; +import { extend } from '../../../utils/object.js'; +import { createMatAlgo13xDD } from './matAlgo13xDD.js'; +import { createMatAlgo14xDs } from './matAlgo14xDs.js'; +import { broadcast } from './broadcast.js'; +var name = 'matrixAlgorithmSuite'; +var dependencies = ['typed', 'matrix']; +export var createMatrixAlgorithmSuite = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + matrix + } = _ref; + var matAlgo13xDD = createMatAlgo13xDD({ + typed + }); + var matAlgo14xDs = createMatAlgo14xDs({ + typed + }); + + /** + * Return a signatures object with the usual boilerplate of + * matrix algorithms, based on a plain options object with the + * following properties: + * elop: function -- the elementwise operation to use, defaults to self + * SS: function -- the algorithm to apply for two sparse matrices + * DS: function -- the algorithm to apply for a dense and a sparse matrix + * SD: function -- algo for a sparse and a dense; defaults to SD flipped + * Ss: function -- the algorithm to apply for a sparse matrix and scalar + * sS: function -- algo for scalar and sparse; defaults to Ss flipped + * scalar: string -- typed-function type for scalars, defaults to 'any' + * + * If Ss is not specified, no matrix-scalar signatures are generated. + * + * @param {object} options + * @return {Object} signatures + */ + return function matrixAlgorithmSuite(options) { + var elop = options.elop; + var SD = options.SD || options.DS; + var matrixSignatures; + if (elop) { + // First the dense ones + matrixSignatures = { + 'DenseMatrix, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(x, y), elop), + 'Array, Array': (x, y) => matAlgo13xDD(...broadcast(matrix(x), matrix(y)), elop).valueOf(), + 'Array, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(matrix(x), y), elop), + 'DenseMatrix, Array': (x, y) => matAlgo13xDD(...broadcast(x, matrix(y)), elop) + }; + // Now incorporate sparse matrices + if (options.SS) { + matrixSignatures['SparseMatrix, SparseMatrix'] = (x, y) => options.SS(...broadcast(x, y), elop, false); + } + if (options.DS) { + matrixSignatures['DenseMatrix, SparseMatrix'] = (x, y) => options.DS(...broadcast(x, y), elop, false); + matrixSignatures['Array, SparseMatrix'] = (x, y) => options.DS(...broadcast(matrix(x), y), elop, false); + } + if (SD) { + matrixSignatures['SparseMatrix, DenseMatrix'] = (x, y) => SD(...broadcast(y, x), elop, true); + matrixSignatures['SparseMatrix, Array'] = (x, y) => SD(...broadcast(matrix(y), x), elop, true); + } + } else { + // No elop, use this + // First the dense ones + matrixSignatures = { + 'DenseMatrix, DenseMatrix': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...broadcast(x, y), self); + }), + 'Array, Array': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...broadcast(matrix(x), matrix(y)), self).valueOf(); + }), + 'Array, DenseMatrix': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...broadcast(matrix(x), y), self); + }), + 'DenseMatrix, Array': typed.referToSelf(self => (x, y) => { + return matAlgo13xDD(...broadcast(x, matrix(y)), self); + }) + }; + // Now incorporate sparse matrices + if (options.SS) { + matrixSignatures['SparseMatrix, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.SS(...broadcast(x, y), self, false); + }); + } + if (options.DS) { + matrixSignatures['DenseMatrix, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.DS(...broadcast(x, y), self, false); + }); + matrixSignatures['Array, SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return options.DS(...broadcast(matrix(x), y), self, false); + }); + } + if (SD) { + matrixSignatures['SparseMatrix, DenseMatrix'] = typed.referToSelf(self => (x, y) => { + return SD(...broadcast(y, x), self, true); + }); + matrixSignatures['SparseMatrix, Array'] = typed.referToSelf(self => (x, y) => { + return SD(...broadcast(matrix(y), x), self, true); + }); + } + } + + // Now add the scalars + var scalar = options.scalar || 'any'; + var Ds = options.Ds || options.Ss; + if (Ds) { + if (elop) { + matrixSignatures['DenseMatrix,' + scalar] = (x, y) => matAlgo14xDs(x, y, elop, false); + matrixSignatures[scalar + ', DenseMatrix'] = (x, y) => matAlgo14xDs(y, x, elop, true); + matrixSignatures['Array,' + scalar] = (x, y) => matAlgo14xDs(matrix(x), y, elop, false).valueOf(); + matrixSignatures[scalar + ', Array'] = (x, y) => matAlgo14xDs(matrix(y), x, elop, true).valueOf(); + } else { + matrixSignatures['DenseMatrix,' + scalar] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(x, y, self, false); + }); + matrixSignatures[scalar + ', DenseMatrix'] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(y, x, self, true); + }); + matrixSignatures['Array,' + scalar] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(matrix(x), y, self, false).valueOf(); + }); + matrixSignatures[scalar + ', Array'] = typed.referToSelf(self => (x, y) => { + return matAlgo14xDs(matrix(y), x, self, true).valueOf(); + }); + } + } + var sS = options.sS !== undefined ? options.sS : options.Ss; + if (elop) { + if (options.Ss) { + matrixSignatures['SparseMatrix,' + scalar] = (x, y) => options.Ss(x, y, elop, false); + } + if (sS) { + matrixSignatures[scalar + ', SparseMatrix'] = (x, y) => sS(y, x, elop, true); + } + } else { + if (options.Ss) { + matrixSignatures['SparseMatrix,' + scalar] = typed.referToSelf(self => (x, y) => { + return options.Ss(x, y, self, false); + }); + } + if (sS) { + matrixSignatures[scalar + ', SparseMatrix'] = typed.referToSelf(self => (x, y) => { + return sS(y, x, self, true); + }); + } + } + // Also pull in the scalar signatures if the operator is a typed function + if (elop && elop.signatures) { + extend(matrixSignatures, elop.signatures); + } + return matrixSignatures; + }; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/number.js new file mode 100644 index 0000000..b45212f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/number.js @@ -0,0 +1,150 @@ +import { factory } from '../utils/factory.js'; +import { deepMap } from '../utils/collection.js'; +var name = 'number'; +var dependencies = ['typed']; + +/** + * Separates the radix, integer part, and fractional part of a non decimal number string + * @param {string} input string to parse + * @returns {object} the parts of the string or null if not a valid input + */ +function getNonDecimalNumberParts(input) { + var nonDecimalWithRadixMatch = input.match(/(0[box])([0-9a-fA-F]*)\.([0-9a-fA-F]*)/); + if (nonDecimalWithRadixMatch) { + var radix = { + '0b': 2, + '0o': 8, + '0x': 16 + }[nonDecimalWithRadixMatch[1]]; + var integerPart = nonDecimalWithRadixMatch[2]; + var fractionalPart = nonDecimalWithRadixMatch[3]; + return { + input, + radix, + integerPart, + fractionalPart + }; + } else { + return null; + } +} + +/** + * Makes a number from a radix, and integer part, and a fractional part + * @param {parts} [x] parts of the number string (from getNonDecimalNumberParts) + * @returns {number} the number + */ +function makeNumberFromNonDecimalParts(parts) { + var n = parseInt(parts.integerPart, parts.radix); + var f = 0; + for (var i = 0; i < parts.fractionalPart.length; i++) { + var digitValue = parseInt(parts.fractionalPart[i], parts.radix); + f += digitValue / Math.pow(parts.radix, i + 1); + } + var result = n + f; + if (isNaN(result)) { + throw new SyntaxError('String "' + parts.input + '" is not a valid number'); + } + return result; +} +export var createNumber = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Create a number or convert a string, boolean, or unit to a number. + * When value is a matrix, all elements will be converted to number. + * + * Syntax: + * + * math.number(value) + * math.number(unit, valuelessUnit) + * + * Examples: + * + * math.number(2) // returns number 2 + * math.number('7.2') // returns number 7.2 + * math.number(true) // returns number 1 + * math.number([true, false, true, true]) // returns [1, 0, 1, 1] + * math.number(math.unit('52cm'), 'm') // returns 0.52 + * + * See also: + * + * bignumber, bigint, boolean, numeric, complex, index, matrix, string, unit + * + * @param {string | number | BigNumber | Fraction | boolean | Array | Matrix | Unit | null} [value] Value to be converted + * @param {Unit | string} [valuelessUnit] A valueless unit, used to convert a unit to a number + * @return {number | Array | Matrix} The created number + */ + var number = typed('number', { + '': function _() { + return 0; + }, + number: function number(x) { + return x; + }, + string: function string(x) { + if (x === 'NaN') return NaN; + var nonDecimalNumberParts = getNonDecimalNumberParts(x); + if (nonDecimalNumberParts) { + return makeNumberFromNonDecimalParts(nonDecimalNumberParts); + } + var size = 0; + var wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/); + if (wordSizeSuffixMatch) { + // x includes a size suffix like 0xffffi32, so we extract + // the suffix and remove it from x + size = Number(wordSizeSuffixMatch[2]); + x = wordSizeSuffixMatch[1]; + } + var num = Number(x); + if (isNaN(num)) { + throw new SyntaxError('String "' + x + '" is not a valid number'); + } + if (wordSizeSuffixMatch) { + // x is a signed bin, oct, or hex literal + // num is the value of string x if x is interpreted as unsigned + if (num > 2 ** size - 1) { + // literal is too large for size suffix + throw new SyntaxError("String \"".concat(x, "\" is out of range")); + } + // check if the bit at index size - 1 is set and if so do the twos complement + if (num >= 2 ** (size - 1)) { + num = num - 2 ** size; + } + } + return num; + }, + BigNumber: function BigNumber(x) { + return x.toNumber(); + }, + bigint: function bigint(x) { + return Number(x); + }, + Fraction: function Fraction(x) { + return x.valueOf(); + }, + Unit: typed.referToSelf(self => x => { + var clone = x.clone(); + clone.value = self(x.value); + return clone; + }), + null: function _null(x) { + return 0; + }, + 'Unit, string | Unit': function Unit_string__Unit(unit, valuelessUnit) { + return unit.toNumber(valuelessUnit); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); + + // reviver function to parse a JSON object like: + // + // {"mathjs":"number","value":"2.3"} + // + // into a number 2.3 + number.fromJSON = function (json) { + return parseFloat(json.value); + }; + return number; +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/resultset/ResultSet.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/resultset/ResultSet.js new file mode 100644 index 0000000..d693aa6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/resultset/ResultSet.js @@ -0,0 +1,68 @@ +import { factory } from '../../utils/factory.js'; +var name = 'ResultSet'; +var dependencies = []; +export var createResultSet = /* #__PURE__ */factory(name, dependencies, () => { + /** + * A ResultSet contains a list or results + * @class ResultSet + * @param {Array} entries + * @constructor ResultSet + */ + function ResultSet(entries) { + if (!(this instanceof ResultSet)) { + throw new SyntaxError('Constructor must be called with the new operator'); + } + this.entries = entries || []; + } + + /** + * Attach type information + */ + ResultSet.prototype.type = 'ResultSet'; + ResultSet.prototype.isResultSet = true; + + /** + * Returns the array with results hold by this ResultSet + * @memberof ResultSet + * @returns {Array} entries + */ + ResultSet.prototype.valueOf = function () { + return this.entries; + }; + + /** + * Returns the stringified results of the ResultSet + * @memberof ResultSet + * @returns {string} string + */ + ResultSet.prototype.toString = function () { + return '[' + this.entries.join(', ') + ']'; + }; + + /** + * Get a JSON representation of the ResultSet + * @memberof ResultSet + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "ResultSet", "entries": [...]}` + */ + ResultSet.prototype.toJSON = function () { + return { + mathjs: 'ResultSet', + entries: this.entries + }; + }; + + /** + * Instantiate a ResultSet from a JSON object + * @memberof ResultSet + * @param {Object} json A JSON object structured as: + * `{"mathjs": "ResultSet", "entries": [...]}` + * @return {ResultSet} + */ + ResultSet.fromJSON = function (json) { + return new ResultSet(json.entries); + }; + return ResultSet; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/string.js new file mode 100644 index 0000000..05e8564 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/string.js @@ -0,0 +1,54 @@ +import { factory } from '../utils/factory.js'; +import { deepMap } from '../utils/collection.js'; +import { format } from '../utils/number.js'; +var name = 'string'; +var dependencies = ['typed']; +export var createString = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Create a string or convert any object into a string. + * Elements of Arrays and Matrices are processed element wise. + * + * Syntax: + * + * math.string(value) + * + * Examples: + * + * math.string(4.2) // returns string '4.2' + * math.string(math.complex(3, 2) // returns string '3 + 2i' + * + * const u = math.unit(5, 'km') + * math.string(u.to('m')) // returns string '5000 m' + * + * math.string([true, false]) // returns ['true', 'false'] + * + * See also: + * + * bignumber, boolean, complex, index, matrix, number, unit + * + * @param {* | Array | Matrix | null} [value] A value to convert to a string + * @return {string | Array | Matrix} The created string + */ + return typed(name, { + '': function _() { + return ''; + }, + number: format, + null: function _null(x) { + return 'null'; + }, + boolean: function boolean(x) { + return x + ''; + }, + string: function string(x) { + return x; + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)), + any: function any(x) { + return String(x); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/Unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/Unit.js new file mode 100644 index 0000000..a40487a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/Unit.js @@ -0,0 +1,3881 @@ +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +import _extends from "@babel/runtime/helpers/extends"; +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +import { isComplex, isUnit, typeOf } from '../../utils/is.js'; +import { factory } from '../../utils/factory.js'; +import { memoize } from '../../utils/function.js'; +import { endsWith } from '../../utils/string.js'; +import { clone, hasOwnProperty } from '../../utils/object.js'; +import { createBigNumberPi as createPi } from '../../utils/bignumber/constants.js'; +var name = 'Unit'; +var dependencies = ['?on', 'config', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'abs', 'fix', 'round', 'equal', 'isNumeric', 'format', 'number', 'Complex', 'BigNumber', 'Fraction']; +export var createUnitClass = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + on, + config, + addScalar, + subtractScalar, + multiplyScalar, + divideScalar, + pow, + abs, + fix, + round, + equal, + isNumeric, + format, + number: _number, + Complex, + BigNumber: _BigNumber, + Fraction: _Fraction + } = _ref; + var toNumber = _number; + /** + * A unit can be constructed in the following ways: + * + * const a = new Unit(value, valuelessUnit) + * const b = new Unit(null, valuelessUnit) + * const c = Unit.parse(str) + * + * Example usage: + * + * const a = new Unit(5, 'cm') // 50 mm + * const b = Unit.parse('23 kg') // 23 kg + * const c = math.in(a, new Unit(null, 'm') // 0.05 m + * const d = new Unit(9.81, "m/s^2") // 9.81 m/s^2 + * + * @class Unit + * @constructor Unit + * @param {number | BigNumber | Fraction | Complex | boolean} [value] A value like 5.2 + * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like "cm" + */ + function Unit(value, valuelessUnit) { + if (!(this instanceof Unit)) { + throw new Error('Constructor must be called with the new operator'); + } + if (!(value === null || value === undefined || isNumeric(value) || isComplex(value))) { + throw new TypeError('First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined'); + } + this.fixPrefix = false; // if true, function format will not search for the + // best prefix but leave it as initially provided. + // fixPrefix is set true by the method Unit.to + + // The justification behind this is that if the constructor is explicitly called, + // the caller wishes the units to be returned exactly as supplied. + this.skipAutomaticSimplification = true; + if (valuelessUnit === undefined) { + this.units = []; + this.dimensions = BASE_DIMENSIONS.map(x => 0); + } else if (typeof valuelessUnit === 'string') { + var u = Unit.parse(valuelessUnit); + this.units = u.units; + this.dimensions = u.dimensions; + } else if (isUnit(valuelessUnit) && valuelessUnit.value === null) { + // clone from valuelessUnit + this.fixPrefix = valuelessUnit.fixPrefix; + this.skipAutomaticSimplification = valuelessUnit.skipAutomaticSimplification; + this.dimensions = valuelessUnit.dimensions.slice(0); + this.units = valuelessUnit.units.map(u => _extends({}, u)); + } else { + throw new TypeError('Second parameter in Unit constructor must be a string or valueless Unit'); + } + this.value = this._normalize(value); + } + + /** + * Attach type information + */ + Object.defineProperty(Unit, 'name', { + value: 'Unit' + }); + Unit.prototype.constructor = Unit; + Unit.prototype.type = 'Unit'; + Unit.prototype.isUnit = true; + + // private variables and functions for the Unit parser + var text, index, c; + function skipWhitespace() { + while (c === ' ' || c === '\t') { + next(); + } + } + function isDigitDot(c) { + return c >= '0' && c <= '9' || c === '.'; + } + function isDigit(c) { + return c >= '0' && c <= '9'; + } + function next() { + index++; + c = text.charAt(index); + } + function revert(oldIndex) { + index = oldIndex; + c = text.charAt(index); + } + function parseNumber() { + var number = ''; + var oldIndex = index; + if (c === '+') { + next(); + } else if (c === '-') { + number += c; + next(); + } + if (!isDigitDot(c)) { + // a + or - must be followed by a digit + revert(oldIndex); + return null; + } + + // get number, can have a single dot + if (c === '.') { + number += c; + next(); + if (!isDigit(c)) { + // this is no legal number, it is just a dot + revert(oldIndex); + return null; + } + } else { + while (isDigit(c)) { + number += c; + next(); + } + if (c === '.') { + number += c; + next(); + } + } + while (isDigit(c)) { + number += c; + next(); + } + + // check for exponential notation like "2.3e-4" or "1.23e50" + if (c === 'E' || c === 'e') { + // The grammar branches here. This could either be part of an exponent or the start of a unit that begins with the letter e, such as "4exabytes" + + var tentativeNumber = ''; + var tentativeIndex = index; + tentativeNumber += c; + next(); + if (c === '+' || c === '-') { + tentativeNumber += c; + next(); + } + + // Scientific notation MUST be followed by an exponent (otherwise we assume it is not scientific notation) + if (!isDigit(c)) { + // The e or E must belong to something else, so return the number without the e or E. + revert(tentativeIndex); + return number; + } + + // We can now safely say that this is scientific notation. + number = number + tentativeNumber; + while (isDigit(c)) { + number += c; + next(); + } + } + return number; + } + function parseUnit() { + var unitName = ''; + + // Alphanumeric characters only; matches [a-zA-Z0-9] + while (isDigit(c) || Unit.isValidAlpha(c)) { + unitName += c; + next(); + } + + // Must begin with [a-zA-Z] + var firstC = unitName.charAt(0); + if (Unit.isValidAlpha(firstC)) { + return unitName; + } else { + return null; + } + } + function parseCharacter(toFind) { + if (c === toFind) { + next(); + return toFind; + } else { + return null; + } + } + + /** + * Parse a string into a unit. The value of the unit is parsed as number, + * BigNumber, or Fraction depending on the math.js config setting `number`. + * + * Throws an exception if the provided string does not contain a valid unit or + * cannot be parsed. + * @memberof Unit + * @param {string} str A string like "5.2 inch", "4e2 cm/s^2" + * @return {Unit} unit + */ + Unit.parse = function (str, options) { + options = options || {}; + text = str; + index = -1; + c = ''; + if (typeof text !== 'string') { + throw new TypeError('Invalid argument in Unit.parse, string expected'); + } + var unit = new Unit(); + unit.units = []; + var powerMultiplierCurrent = 1; + var expectingUnit = false; + + // A unit should follow this pattern: + // [number] ...[ [*/] unit[^number] ] + // unit[^number] ... [ [*/] unit[^number] ] + + // Rules: + // number is any floating point number. + // unit is any alphanumeric string beginning with an alpha. Units with names like e3 should be avoided because they look like the exponent of a floating point number! + // The string may optionally begin with a number. + // Each unit may optionally be followed by ^number. + // Whitespace or a forward slash is recommended between consecutive units, although the following technically is parseable: + // 2m^2kg/s^2 + // it is not good form. If a unit starts with e, then it could be confused as a floating point number: + // 4erg + + next(); + skipWhitespace(); + + // Optional number at the start of the string + var valueStr = parseNumber(); + var value = null; + if (valueStr) { + if (config.number === 'BigNumber') { + value = new _BigNumber(valueStr); + } else if (config.number === 'Fraction') { + try { + // not all numbers can be turned in Fractions, for example very small numbers not + value = new _Fraction(valueStr); + } catch (err) { + value = parseFloat(valueStr); + } + } else { + // number + value = parseFloat(valueStr); + } + skipWhitespace(); // Whitespace is not required here + + // handle multiplication or division right after the value, like '1/s' + if (parseCharacter('*')) { + powerMultiplierCurrent = 1; + expectingUnit = true; + } else if (parseCharacter('/')) { + powerMultiplierCurrent = -1; + expectingUnit = true; + } + } + + // Stack to keep track of powerMultipliers applied to each parentheses group + var powerMultiplierStack = []; + + // Running product of all elements in powerMultiplierStack + var powerMultiplierStackProduct = 1; + while (true) { + skipWhitespace(); + + // Check for and consume opening parentheses, pushing powerMultiplierCurrent to the stack + // A '(' will always appear directly before a unit. + while (c === '(') { + powerMultiplierStack.push(powerMultiplierCurrent); + powerMultiplierStackProduct *= powerMultiplierCurrent; + powerMultiplierCurrent = 1; + next(); + skipWhitespace(); + } + + // Is there something here? + var uStr = void 0; + if (c) { + var oldC = c; + uStr = parseUnit(); + if (uStr === null) { + throw new SyntaxError('Unexpected "' + oldC + '" in "' + text + '" at index ' + index.toString()); + } + } else { + // End of input. + break; + } + + // Verify the unit exists and get the prefix (if any) + var res = _findUnit(uStr); + if (res === null) { + // Unit not found. + throw new SyntaxError('Unit "' + uStr + '" not found.'); + } + var power = powerMultiplierCurrent * powerMultiplierStackProduct; + // Is there a "^ number"? + skipWhitespace(); + if (parseCharacter('^')) { + skipWhitespace(); + var p = parseNumber(); + if (p === null) { + // No valid number found for the power! + throw new SyntaxError('In "' + str + '", "^" must be followed by a floating-point number'); + } + power *= p; + } + + // Add the unit to the list + unit.units.push({ + unit: res.unit, + prefix: res.prefix, + power + }); + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + unit.dimensions[i] += (res.unit.dimensions[i] || 0) * power; + } + + // Check for and consume closing parentheses, popping from the stack. + // A ')' will always follow a unit. + skipWhitespace(); + while (c === ')') { + if (powerMultiplierStack.length === 0) { + throw new SyntaxError('Unmatched ")" in "' + text + '" at index ' + index.toString()); + } + powerMultiplierStackProduct /= powerMultiplierStack.pop(); + next(); + skipWhitespace(); + } + + // "*" and "/" should mean we are expecting something to come next. + // Is there a forward slash? If so, negate powerMultiplierCurrent. The next unit or paren group is in the denominator. + expectingUnit = false; + if (parseCharacter('*')) { + // explicit multiplication + powerMultiplierCurrent = 1; + expectingUnit = true; + } else if (parseCharacter('/')) { + // division + powerMultiplierCurrent = -1; + expectingUnit = true; + } else { + // implicit multiplication + powerMultiplierCurrent = 1; + } + + // Replace the unit into the auto unit system + if (res.unit.base) { + var baseDim = res.unit.base.key; + UNIT_SYSTEMS.auto[baseDim] = { + unit: res.unit, + prefix: res.prefix + }; + } + } + + // Has the string been entirely consumed? + skipWhitespace(); + if (c) { + throw new SyntaxError('Could not parse: "' + str + '"'); + } + + // Is there a trailing slash? + if (expectingUnit) { + throw new SyntaxError('Trailing characters: "' + str + '"'); + } + + // Is the parentheses stack empty? + if (powerMultiplierStack.length !== 0) { + throw new SyntaxError('Unmatched "(" in "' + text + '"'); + } + + // Are there any units at all? + if (unit.units.length === 0 && !options.allowNoUnits) { + throw new SyntaxError('"' + str + '" contains no units'); + } + unit.value = value !== undefined ? unit._normalize(value) : null; + return unit; + }; + + /** + * create a copy of this unit + * @memberof Unit + * @return {Unit} Returns a cloned version of the unit + */ + Unit.prototype.clone = function () { + var unit = new Unit(); + unit.fixPrefix = this.fixPrefix; + unit.skipAutomaticSimplification = this.skipAutomaticSimplification; + unit.value = clone(this.value); + unit.dimensions = this.dimensions.slice(0); + unit.units = []; + for (var i = 0; i < this.units.length; i++) { + unit.units[i] = {}; + for (var p in this.units[i]) { + if (hasOwnProperty(this.units[i], p)) { + unit.units[i][p] = this.units[i][p]; + } + } + } + return unit; + }; + + /** + * Return the type of the value of this unit + * + * @memberof Unit + * @return {string} type of the value of the unit + */ + Unit.prototype.valueType = function () { + return typeOf(this.value); + }; + + /** + * Return whether the unit is derived (such as m/s, or cm^2, but not N) + * @memberof Unit + * @return {boolean} True if the unit is derived + * @private + */ + Unit.prototype._isDerived = function () { + if (this.units.length === 0) { + return false; + } + return this.units.length > 1 || Math.abs(this.units[0].power - 1.0) > 1e-15; + }; + + /** + * Normalize a value, based on its currently set unit(s) + * @memberof Unit + * @param {number | BigNumber | Fraction | boolean} value + * @return {number | BigNumber | Fraction | boolean} normalized value + * @private + */ + Unit.prototype._normalize = function (value) { + if (value === null || value === undefined || this.units.length === 0) { + return value; + } + var res = value; + var convert = Unit._getNumberConverter(typeOf(value)); // convert to Fraction or BigNumber if needed + + for (var i = 0; i < this.units.length; i++) { + var unitValue = convert(this.units[i].unit.value); + var unitPrefixValue = convert(this.units[i].prefix.value); + var unitPower = convert(this.units[i].power); + res = multiplyScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower)); + } + return res; + }; + + /** + * Denormalize a value, based on its currently set unit(s) + * @memberof Unit + * @param {number} value + * @param {number} [prefixValue] Optional prefix value to be used (ignored if this is a derived unit) + * @return {number} denormalized value + * @private + */ + Unit.prototype._denormalize = function (value, prefixValue) { + if (value === null || value === undefined || this.units.length === 0) { + return value; + } + var res = value; + var convert = Unit._getNumberConverter(typeOf(value)); // convert to Fraction or BigNumber if needed + + for (var i = 0; i < this.units.length; i++) { + var unitValue = convert(this.units[i].unit.value); + var unitPrefixValue = convert(this.units[i].prefix.value); + var unitPower = convert(this.units[i].power); + res = divideScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower)); + } + return res; + }; + + /** + * Find a unit from a string + * @memberof Unit + * @param {string} str A string like 'cm' or 'inch' + * @returns {Object | null} result When found, an object with fields unit and + * prefix is returned. Else, null is returned. + * @private + */ + var _findUnit = memoize(str => { + // First, match units names exactly. For example, a user could define 'mm' as 10^-4 m, which is silly, but then we would want 'mm' to match the user-defined unit. + if (hasOwnProperty(UNITS, str)) { + var unit = UNITS[str]; + var prefix = unit.prefixes['']; + return { + unit, + prefix + }; + } + for (var _name in UNITS) { + if (hasOwnProperty(UNITS, _name)) { + if (endsWith(str, _name)) { + var _unit = UNITS[_name]; + var prefixLen = str.length - _name.length; + var prefixName = str.substring(0, prefixLen); + var _prefix = hasOwnProperty(_unit.prefixes, prefixName) ? _unit.prefixes[prefixName] : undefined; + if (_prefix !== undefined) { + // store unit, prefix, and value + return { + unit: _unit, + prefix: _prefix + }; + } + } + } + } + return null; + }, { + hasher: args => args[0], + limit: 100 + }); + + /** + * Test if the given expression is a unit. + * The unit can have a prefix but cannot have a value. + * @memberof Unit + * @param {string} name A string to be tested whether it is a value less unit. + * The unit can have prefix, like "cm" + * @return {boolean} true if the given string is a unit + */ + Unit.isValuelessUnit = function (name) { + return _findUnit(name) !== null; + }; + + /** + * check if this unit has given base unit + * If this unit is a derived unit, this will ALWAYS return false, since by definition base units are not derived. + * @memberof Unit + * @param {BASE_UNIT | string | undefined} base + */ + Unit.prototype.hasBase = function (base) { + if (typeof base === 'string') { + base = BASE_UNITS[base]; + } + if (!base) { + return false; + } + + // All dimensions must be the same + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + if (Math.abs((this.dimensions[i] || 0) - (base.dimensions[i] || 0)) > 1e-12) { + return false; + } + } + return true; + }; + + /** + * Check if this unit has a base or bases equal to another base or bases + * For derived units, the exponent on each base also must match + * @memberof Unit + * @param {Unit} other + * @return {boolean} true if equal base + */ + Unit.prototype.equalBase = function (other) { + // All dimensions must be the same + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + if (Math.abs((this.dimensions[i] || 0) - (other.dimensions[i] || 0)) > 1e-12) { + return false; + } + } + return true; + }; + + /** + * Check if this unit equals another unit + * @memberof Unit + * @param {Unit} other + * @return {boolean} true if both units are equal + */ + Unit.prototype.equals = function (other) { + return this.equalBase(other) && equal(this.value, other.value); + }; + + /** + * Multiply this unit with another one or with a scalar + * @memberof Unit + * @param {Unit} other + * @return {Unit} product of this unit and the other unit + */ + Unit.prototype.multiply = function (_other) { + var res = this.clone(); + var other = isUnit(_other) ? _other : new Unit(_other); + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) + (other.dimensions[i] || 0); + } + + // Append other's units list onto res + for (var _i = 0; _i < other.units.length; _i++) { + // Make a shallow copy of every unit + var inverted = _objectSpread({}, other.units[_i]); + res.units.push(inverted); + } + + // If at least one operand has a value, then the result should also have a value + if (this.value !== null || other.value !== null) { + var valThis = this.value === null ? this._normalize(1) : this.value; + var valOther = other.value === null ? other._normalize(1) : other.value; + res.value = multiplyScalar(valThis, valOther); + } else { + res.value = null; + } + if (isUnit(_other)) { + res.skipAutomaticSimplification = false; + } + return getNumericIfUnitless(res); + }; + + /** + * Divide a number by this unit + * + * @memberof Unit + * @param {numeric} numerator + * @param {unit} result of dividing numerator by this unit + */ + Unit.prototype.divideInto = function (numerator) { + return new Unit(numerator).divide(this); + }; + + /** + * Divide this unit by another one + * @memberof Unit + * @param {Unit | numeric} other + * @return {Unit} result of dividing this unit by the other unit + */ + Unit.prototype.divide = function (_other) { + var res = this.clone(); + var other = isUnit(_other) ? _other : new Unit(_other); + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) - (other.dimensions[i] || 0); + } + + // Invert and append other's units list onto res + for (var _i2 = 0; _i2 < other.units.length; _i2++) { + // Make a shallow copy of every unit + var inverted = _objectSpread(_objectSpread({}, other.units[_i2]), {}, { + power: -other.units[_i2].power + }); + res.units.push(inverted); + } + + // If at least one operand has a value, the result should have a value + if (this.value !== null || other.value !== null) { + var valThis = this.value === null ? this._normalize(1) : this.value; + var valOther = other.value === null ? other._normalize(1) : other.value; + res.value = divideScalar(valThis, valOther); + } else { + res.value = null; + } + if (isUnit(_other)) { + res.skipAutomaticSimplification = false; + } + return getNumericIfUnitless(res); + }; + + /** + * Calculate the power of a unit + * @memberof Unit + * @param {number | Fraction | BigNumber} p + * @returns {Unit} The result: this^p + */ + Unit.prototype.pow = function (p) { + var res = this.clone(); + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + // Dimensions arrays may be of different lengths. Default to 0. + res.dimensions[i] = (this.dimensions[i] || 0) * p; + } + + // Adjust the power of each unit in the list + for (var _i3 = 0; _i3 < res.units.length; _i3++) { + res.units[_i3].power *= p; + } + if (res.value !== null) { + res.value = pow(res.value, p); + + // only allow numeric output, we don't want to return a Complex number + // if (!isNumeric(res.value)) { + // res.value = NaN + // } + // Update: Complex supported now + } else { + res.value = null; + } + res.skipAutomaticSimplification = false; + return getNumericIfUnitless(res); + }; + + /** + * Return the numeric value of this unit if it is dimensionless, has a value, and config.predictable == false; or the original unit otherwise + * @param {Unit} unit + * @returns {number | Fraction | BigNumber | Unit} The numeric value of the unit if conditions are met, or the original unit otherwise + */ + function getNumericIfUnitless(unit) { + if (unit.equalBase(BASE_UNITS.NONE) && unit.value !== null && !config.predictable) { + return unit.value; + } else { + return unit; + } + } + + /** + * Calculate the absolute value of a unit + * @memberof Unit + * @param {number | Fraction | BigNumber} x + * @returns {Unit} The result: |x|, absolute value of x + */ + Unit.prototype.abs = function () { + var ret = this.clone(); + if (ret.value !== null) { + if (ret._isDerived() || ret.units.length === 0 || ret.units[0].unit.offset === 0) { + ret.value = abs(ret.value); + } else { + // To give the correct, but unexpected, results for units with an offset. + // For example, abs(-283.15 degC) = -263.15 degC !!! + // We must take the offset into consideration here + var convert = ret._numberConverter(); // convert to Fraction or BigNumber if needed + var unitValue = convert(ret.units[0].unit.value); + var nominalOffset = convert(ret.units[0].unit.offset); + var unitOffset = multiplyScalar(unitValue, nominalOffset); + ret.value = subtractScalar(abs(addScalar(ret.value, unitOffset)), unitOffset); + } + } + for (var i in ret.units) { + if (ret.units[i].unit.name === 'VA' || ret.units[i].unit.name === 'VAR') { + ret.units[i].unit = UNITS.W; + } + } + return ret; + }; + + /** + * Convert the unit to a specific unit name. + * @memberof Unit + * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like "cm" + * @returns {Unit} Returns a clone of the unit with a fixed prefix and unit. + */ + Unit.prototype.to = function (valuelessUnit) { + var value = this.value === null ? this._normalize(1) : this.value; + var other; + if (typeof valuelessUnit === 'string') { + other = Unit.parse(valuelessUnit); + } else if (isUnit(valuelessUnit)) { + other = valuelessUnit.clone(); + } else { + throw new Error('String or Unit expected as parameter'); + } + if (!this.equalBase(other)) { + throw new Error("Units do not match ('".concat(other.toString(), "' != '").concat(this.toString(), "')")); + } + if (other.value !== null) { + throw new Error('Cannot convert to a unit with a value'); + } + if (this.value === null || this._isDerived() || this.units.length === 0 || other.units.length === 0 || this.units[0].unit.offset === other.units[0].unit.offset) { + other.value = clone(value); + } else { + /* Need to adjust value by difference in offset to convert */ + var convert = Unit._getNumberConverter(typeOf(value)); // convert to Fraction or BigNumber if needed + + var thisUnitValue = this.units[0].unit.value; + var thisNominalOffset = this.units[0].unit.offset; + var thisUnitOffset = multiplyScalar(thisUnitValue, thisNominalOffset); + var otherUnitValue = other.units[0].unit.value; + var otherNominalOffset = other.units[0].unit.offset; + var otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset); + other.value = addScalar(value, convert(subtractScalar(thisUnitOffset, otherUnitOffset))); + } + other.fixPrefix = true; + other.skipAutomaticSimplification = true; + return other; + }; + + /** + * Return the value of the unit when represented with given valueless unit + * @memberof Unit + * @param {string | Unit} valuelessUnit For example 'cm' or 'inch' + * @return {number} Returns the unit value as number. + */ + // TODO: deprecate Unit.toNumber? It's always better to use toNumeric + Unit.prototype.toNumber = function (valuelessUnit) { + return toNumber(this.toNumeric(valuelessUnit)); + }; + + /** + * Return the value of the unit in the original numeric type + * @memberof Unit + * @param {string | Unit} valuelessUnit For example 'cm' or 'inch' + * @return {number | BigNumber | Fraction} Returns the unit value + */ + Unit.prototype.toNumeric = function (valuelessUnit) { + var other; + if (valuelessUnit) { + // Allow getting the numeric value without converting to a different unit + other = this.to(valuelessUnit); + } else { + other = this.clone(); + } + if (other._isDerived() || other.units.length === 0) { + return other._denormalize(other.value); + } else { + return other._denormalize(other.value, other.units[0].prefix.value); + } + }; + + /** + * Get a string representation of the unit. + * @memberof Unit + * @return {string} + */ + Unit.prototype.toString = function () { + return this.format(); + }; + + /** + * Get a JSON representation of the unit + * @memberof Unit + * @returns {Object} Returns a JSON object structured as: + * `{"mathjs": "Unit", "value": 2, "unit": "cm", "fixPrefix": false}` + */ + Unit.prototype.toJSON = function () { + return { + mathjs: 'Unit', + value: this._denormalize(this.value), + unit: this.units.length > 0 ? this.formatUnits() : null, + fixPrefix: this.fixPrefix + }; + }; + + /** + * Instantiate a Unit from a JSON object + * @memberof Unit + * @param {Object} json A JSON object structured as: + * `{"mathjs": "Unit", "value": 2, "unit": "cm", "fixPrefix": false}` + * @return {Unit} + */ + Unit.fromJSON = function (json) { + var _json$unit; + var unit = new Unit(json.value, (_json$unit = json.unit) !== null && _json$unit !== void 0 ? _json$unit : undefined); + unit.fixPrefix = json.fixPrefix || false; + return unit; + }; + + /** + * Returns the string representation of the unit. + * @memberof Unit + * @return {string} + */ + Unit.prototype.valueOf = Unit.prototype.toString; + + /** + * Simplify this Unit's unit list and return a new Unit with the simplified list. + * The returned Unit will contain a list of the "best" units for formatting. + */ + Unit.prototype.simplify = function () { + var ret = this.clone(); + var proposedUnitList = []; + + // Search for a matching base + var matchingBase; + for (var key in currentUnitSystem) { + if (hasOwnProperty(currentUnitSystem, key)) { + if (ret.hasBase(BASE_UNITS[key])) { + matchingBase = key; + break; + } + } + } + if (matchingBase === 'NONE') { + ret.units = []; + } else { + var matchingUnit; + if (matchingBase) { + // Does the unit system have a matching unit? + if (hasOwnProperty(currentUnitSystem, matchingBase)) { + matchingUnit = currentUnitSystem[matchingBase]; + } + } + if (matchingUnit) { + ret.units = [{ + unit: matchingUnit.unit, + prefix: matchingUnit.prefix, + power: 1.0 + }]; + } else { + // Multiple units or units with powers are formatted like this: + // 5 (kg m^2) / (s^3 mol) + // Build an representation from the base units of the current unit system + var missingBaseDim = false; + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + var baseDim = BASE_DIMENSIONS[i]; + if (Math.abs(ret.dimensions[i] || 0) > 1e-12) { + if (hasOwnProperty(currentUnitSystem, baseDim)) { + proposedUnitList.push({ + unit: currentUnitSystem[baseDim].unit, + prefix: currentUnitSystem[baseDim].prefix, + power: ret.dimensions[i] || 0 + }); + } else { + missingBaseDim = true; + } + } + } + + // Is the proposed unit list "simpler" than the existing one? + if (proposedUnitList.length < ret.units.length && !missingBaseDim) { + // Replace this unit list with the proposed list + ret.units = proposedUnitList; + } + } + } + return ret; + }; + + /** + * Returns a new Unit in the SI system with the same value as this one + */ + Unit.prototype.toSI = function () { + var ret = this.clone(); + var proposedUnitList = []; + + // Multiple units or units with powers are formatted like this: + // 5 (kg m^2) / (s^3 mol) + // Build an representation from the base units of the SI unit system + for (var i = 0; i < BASE_DIMENSIONS.length; i++) { + var baseDim = BASE_DIMENSIONS[i]; + if (Math.abs(ret.dimensions[i] || 0) > 1e-12) { + if (hasOwnProperty(UNIT_SYSTEMS.si, baseDim)) { + proposedUnitList.push({ + unit: UNIT_SYSTEMS.si[baseDim].unit, + prefix: UNIT_SYSTEMS.si[baseDim].prefix, + power: ret.dimensions[i] || 0 + }); + } else { + throw new Error('Cannot express custom unit ' + baseDim + ' in SI units'); + } + } + } + + // Replace this unit list with the proposed list + ret.units = proposedUnitList; + ret.fixPrefix = true; + ret.skipAutomaticSimplification = true; + if (this.value !== null) { + ret.value = null; + return this.to(ret); + } + return ret; + }; + + /** + * Get a string representation of the units of this Unit, without the value. The unit list is formatted as-is without first being simplified. + * @memberof Unit + * @return {string} + */ + Unit.prototype.formatUnits = function () { + var strNum = ''; + var strDen = ''; + var nNum = 0; + var nDen = 0; + for (var i = 0; i < this.units.length; i++) { + if (this.units[i].power > 0) { + nNum++; + strNum += ' ' + this.units[i].prefix.name + this.units[i].unit.name; + if (Math.abs(this.units[i].power - 1.0) > 1e-15) { + strNum += '^' + this.units[i].power; + } + } else if (this.units[i].power < 0) { + nDen++; + } + } + if (nDen > 0) { + for (var _i4 = 0; _i4 < this.units.length; _i4++) { + if (this.units[_i4].power < 0) { + if (nNum > 0) { + strDen += ' ' + this.units[_i4].prefix.name + this.units[_i4].unit.name; + if (Math.abs(this.units[_i4].power + 1.0) > 1e-15) { + strDen += '^' + -this.units[_i4].power; + } + } else { + strDen += ' ' + this.units[_i4].prefix.name + this.units[_i4].unit.name; + strDen += '^' + this.units[_i4].power; + } + } + } + } + // Remove leading " " + strNum = strNum.substr(1); + strDen = strDen.substr(1); + + // Add parans for better copy/paste back into evaluate, for example, or for better pretty print formatting + if (nNum > 1 && nDen > 0) { + strNum = '(' + strNum + ')'; + } + if (nDen > 1 && nNum > 0) { + strDen = '(' + strDen + ')'; + } + var str = strNum; + if (nNum > 0 && nDen > 0) { + str += ' / '; + } + str += strDen; + return str; + }; + + /** + * Get a string representation of the Unit, with optional formatting options. + * @memberof Unit + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @return {string} + */ + Unit.prototype.format = function (options) { + // Simplfy the unit list, unless it is valueless or was created directly in the + // constructor or as the result of to or toSI + var simp = this.skipAutomaticSimplification || this.value === null ? this.clone() : this.simplify(); + + // Apply some custom logic for handling VA and VAR. The goal is to express the value of the unit as a real value, if possible. Otherwise, use a real-valued unit instead of a complex-valued one. + var isImaginary = false; + if (typeof simp.value !== 'undefined' && simp.value !== null && isComplex(simp.value)) { + // TODO: Make this better, for example, use relative magnitude of re and im rather than absolute + isImaginary = Math.abs(simp.value.re) < 1e-14; + } + for (var i in simp.units) { + if (hasOwnProperty(simp.units, i)) { + if (simp.units[i].unit) { + if (simp.units[i].unit.name === 'VA' && isImaginary) { + simp.units[i].unit = UNITS.VAR; + } else if (simp.units[i].unit.name === 'VAR' && !isImaginary) { + simp.units[i].unit = UNITS.VA; + } + } + } + } + + // Now apply the best prefix + // Units must have only one unit and not have the fixPrefix flag set + if (simp.units.length === 1 && !simp.fixPrefix) { + // Units must have integer powers, otherwise the prefix will change the + // outputted value by not-an-integer-power-of-ten + if (Math.abs(simp.units[0].power - Math.round(simp.units[0].power)) < 1e-14) { + // Apply the best prefix + simp.units[0].prefix = simp._bestPrefix(); + } + } + var value = simp._denormalize(simp.value); + var str = simp.value !== null ? format(value, options || {}) : ''; + var unitStr = simp.formatUnits(); + if (simp.value && isComplex(simp.value)) { + str = '(' + str + ')'; // Surround complex values with ( ) to enable better parsing + } + if (unitStr.length > 0 && str.length > 0) { + str += ' '; + } + str += unitStr; + return str; + }; + + /** + * Calculate the best prefix using current value. + * @memberof Unit + * @returns {Object} prefix + * @private + */ + Unit.prototype._bestPrefix = function () { + if (this.units.length !== 1) { + throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!'); + } + if (Math.abs(this.units[0].power - Math.round(this.units[0].power)) >= 1e-14) { + throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!'); + } + + // find the best prefix value (resulting in the value of which + // the absolute value of the log10 is closest to zero, + // though with a little offset of 1.2 for nicer values: you get a + // sequence 1mm 100mm 500mm 0.6m 1m 10m 100m 500m 0.6km 1km ... + + // Note: the units value can be any numeric type, but to find the best + // prefix it's enough to work with limited precision of a regular number + // Update: using mathjs abs since we also allow complex numbers + var absValue = this.value !== null ? abs(this.value) : 0; + var absUnitValue = abs(this.units[0].unit.value); + var bestPrefix = this.units[0].prefix; + if (absValue === 0) { + return bestPrefix; + } + var power = this.units[0].power; + var bestDiff = Math.log(absValue / Math.pow(bestPrefix.value * absUnitValue, power)) / Math.LN10 - 1.2; + if (bestDiff > -2.200001 && bestDiff < 1.800001) return bestPrefix; // Allow the original prefix + bestDiff = Math.abs(bestDiff); + var prefixes = this.units[0].unit.prefixes; + for (var p in prefixes) { + if (hasOwnProperty(prefixes, p)) { + var prefix = prefixes[p]; + if (prefix.scientific) { + var diff = Math.abs(Math.log(absValue / Math.pow(prefix.value * absUnitValue, power)) / Math.LN10 - 1.2); + if (diff < bestDiff || diff === bestDiff && prefix.name.length < bestPrefix.name.length) { + // choose the prefix with the smallest diff, or if equal, choose the one + // with the shortest name (can happen with SHORTLONG for example) + bestPrefix = prefix; + bestDiff = diff; + } + } + } + } + return bestPrefix; + }; + + /** + * Returns an array of units whose sum is equal to this unit + * @memberof Unit + * @param {Array} [parts] An array of strings or valueless units. + * + * Example: + * + * const u = new Unit(1, 'm') + * u.splitUnit(['feet', 'inch']) + * [ 3 feet, 3.3700787401575 inch ] + * + * @return {Array} An array of units. + */ + Unit.prototype.splitUnit = function (parts) { + var x = this.clone(); + var ret = []; + for (var i = 0; i < parts.length; i++) { + // Convert x to the requested unit + x = x.to(parts[i]); + if (i === parts.length - 1) break; + + // Get the numeric value of this unit + var xNumeric = x.toNumeric(); + + // Check to see if xNumeric is nearly equal to an integer, + // since fix can incorrectly round down if there is round-off error + var xRounded = round(xNumeric); + var xFixed = void 0; + var isNearlyEqual = equal(xRounded, xNumeric); + if (isNearlyEqual) { + xFixed = xRounded; + } else { + xFixed = fix(x.toNumeric()); + } + var y = new Unit(xFixed, parts[i].toString()); + ret.push(y); + x = subtractScalar(x, y); + } + + // This little bit fixes a bug where the remainder should be 0 but is a little bit off. + // But instead of comparing x, the remainder, with zero--we will compare the sum of + // all the parts so far with the original value. If they are nearly equal, + // we set the remainder to 0. + var testSum = 0; + for (var _i5 = 0; _i5 < ret.length; _i5++) { + testSum = addScalar(testSum, ret[_i5].value); + } + if (equal(testSum, this.value)) { + x.value = 0; + } + ret.push(x); + return ret; + }; + var PREFIXES = { + NONE: { + '': { + name: '', + value: 1, + scientific: true + } + }, + SHORT: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e1, + scientific: false + }, + h: { + name: 'h', + value: 1e2, + scientific: false + }, + k: { + name: 'k', + value: 1e3, + scientific: true + }, + M: { + name: 'M', + value: 1e6, + scientific: true + }, + G: { + name: 'G', + value: 1e9, + scientific: true + }, + T: { + name: 'T', + value: 1e12, + scientific: true + }, + P: { + name: 'P', + value: 1e15, + scientific: true + }, + E: { + name: 'E', + value: 1e18, + scientific: true + }, + Z: { + name: 'Z', + value: 1e21, + scientific: true + }, + Y: { + name: 'Y', + value: 1e24, + scientific: true + }, + R: { + name: 'R', + value: 1e27, + scientific: true + }, + Q: { + name: 'Q', + value: 1e30, + scientific: true + }, + d: { + name: 'd', + value: 1e-1, + scientific: false + }, + c: { + name: 'c', + value: 1e-2, + scientific: false + }, + m: { + name: 'm', + value: 1e-3, + scientific: true + }, + u: { + name: 'u', + value: 1e-6, + scientific: true + }, + n: { + name: 'n', + value: 1e-9, + scientific: true + }, + p: { + name: 'p', + value: 1e-12, + scientific: true + }, + f: { + name: 'f', + value: 1e-15, + scientific: true + }, + a: { + name: 'a', + value: 1e-18, + scientific: true + }, + z: { + name: 'z', + value: 1e-21, + scientific: true + }, + y: { + name: 'y', + value: 1e-24, + scientific: true + }, + r: { + name: 'r', + value: 1e-27, + scientific: true + }, + q: { + name: 'q', + value: 1e-30, + scientific: true + } + }, + LONG: { + '': { + name: '', + value: 1, + scientific: true + }, + deca: { + name: 'deca', + value: 1e1, + scientific: false + }, + hecto: { + name: 'hecto', + value: 1e2, + scientific: false + }, + kilo: { + name: 'kilo', + value: 1e3, + scientific: true + }, + mega: { + name: 'mega', + value: 1e6, + scientific: true + }, + giga: { + name: 'giga', + value: 1e9, + scientific: true + }, + tera: { + name: 'tera', + value: 1e12, + scientific: true + }, + peta: { + name: 'peta', + value: 1e15, + scientific: true + }, + exa: { + name: 'exa', + value: 1e18, + scientific: true + }, + zetta: { + name: 'zetta', + value: 1e21, + scientific: true + }, + yotta: { + name: 'yotta', + value: 1e24, + scientific: true + }, + ronna: { + name: 'ronna', + value: 1e27, + scientific: true + }, + quetta: { + name: 'quetta', + value: 1e30, + scientific: true + }, + deci: { + name: 'deci', + value: 1e-1, + scientific: false + }, + centi: { + name: 'centi', + value: 1e-2, + scientific: false + }, + milli: { + name: 'milli', + value: 1e-3, + scientific: true + }, + micro: { + name: 'micro', + value: 1e-6, + scientific: true + }, + nano: { + name: 'nano', + value: 1e-9, + scientific: true + }, + pico: { + name: 'pico', + value: 1e-12, + scientific: true + }, + femto: { + name: 'femto', + value: 1e-15, + scientific: true + }, + atto: { + name: 'atto', + value: 1e-18, + scientific: true + }, + zepto: { + name: 'zepto', + value: 1e-21, + scientific: true + }, + yocto: { + name: 'yocto', + value: 1e-24, + scientific: true + }, + ronto: { + name: 'ronto', + value: 1e-27, + scientific: true + }, + quecto: { + name: 'quecto', + value: 1e-30, + scientific: true + } + }, + SQUARED: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e2, + scientific: false + }, + h: { + name: 'h', + value: 1e4, + scientific: false + }, + k: { + name: 'k', + value: 1e6, + scientific: true + }, + M: { + name: 'M', + value: 1e12, + scientific: true + }, + G: { + name: 'G', + value: 1e18, + scientific: true + }, + T: { + name: 'T', + value: 1e24, + scientific: true + }, + P: { + name: 'P', + value: 1e30, + scientific: true + }, + E: { + name: 'E', + value: 1e36, + scientific: true + }, + Z: { + name: 'Z', + value: 1e42, + scientific: true + }, + Y: { + name: 'Y', + value: 1e48, + scientific: true + }, + R: { + name: 'R', + value: 1e54, + scientific: true + }, + Q: { + name: 'Q', + value: 1e60, + scientific: true + }, + d: { + name: 'd', + value: 1e-2, + scientific: false + }, + c: { + name: 'c', + value: 1e-4, + scientific: false + }, + m: { + name: 'm', + value: 1e-6, + scientific: true + }, + u: { + name: 'u', + value: 1e-12, + scientific: true + }, + n: { + name: 'n', + value: 1e-18, + scientific: true + }, + p: { + name: 'p', + value: 1e-24, + scientific: true + }, + f: { + name: 'f', + value: 1e-30, + scientific: true + }, + a: { + name: 'a', + value: 1e-36, + scientific: true + }, + z: { + name: 'z', + value: 1e-42, + scientific: true + }, + y: { + name: 'y', + value: 1e-48, + scientific: true + }, + r: { + name: 'r', + value: 1e-54, + scientific: true + }, + q: { + name: 'q', + value: 1e-60, + scientific: true + } + }, + CUBIC: { + '': { + name: '', + value: 1, + scientific: true + }, + da: { + name: 'da', + value: 1e3, + scientific: false + }, + h: { + name: 'h', + value: 1e6, + scientific: false + }, + k: { + name: 'k', + value: 1e9, + scientific: true + }, + M: { + name: 'M', + value: 1e18, + scientific: true + }, + G: { + name: 'G', + value: 1e27, + scientific: true + }, + T: { + name: 'T', + value: 1e36, + scientific: true + }, + P: { + name: 'P', + value: 1e45, + scientific: true + }, + E: { + name: 'E', + value: 1e54, + scientific: true + }, + Z: { + name: 'Z', + value: 1e63, + scientific: true + }, + Y: { + name: 'Y', + value: 1e72, + scientific: true + }, + R: { + name: 'R', + value: 1e81, + scientific: true + }, + Q: { + name: 'Q', + value: 1e90, + scientific: true + }, + d: { + name: 'd', + value: 1e-3, + scientific: false + }, + c: { + name: 'c', + value: 1e-6, + scientific: false + }, + m: { + name: 'm', + value: 1e-9, + scientific: true + }, + u: { + name: 'u', + value: 1e-18, + scientific: true + }, + n: { + name: 'n', + value: 1e-27, + scientific: true + }, + p: { + name: 'p', + value: 1e-36, + scientific: true + }, + f: { + name: 'f', + value: 1e-45, + scientific: true + }, + a: { + name: 'a', + value: 1e-54, + scientific: true + }, + z: { + name: 'z', + value: 1e-63, + scientific: true + }, + y: { + name: 'y', + value: 1e-72, + scientific: true + }, + r: { + name: 'r', + value: 1e-81, + scientific: true + }, + q: { + name: 'q', + value: 1e-90, + scientific: true + } + }, + BINARY_SHORT_SI: { + '': { + name: '', + value: 1, + scientific: true + }, + k: { + name: 'k', + value: 1e3, + scientific: true + }, + M: { + name: 'M', + value: 1e6, + scientific: true + }, + G: { + name: 'G', + value: 1e9, + scientific: true + }, + T: { + name: 'T', + value: 1e12, + scientific: true + }, + P: { + name: 'P', + value: 1e15, + scientific: true + }, + E: { + name: 'E', + value: 1e18, + scientific: true + }, + Z: { + name: 'Z', + value: 1e21, + scientific: true + }, + Y: { + name: 'Y', + value: 1e24, + scientific: true + } + }, + BINARY_SHORT_IEC: { + '': { + name: '', + value: 1, + scientific: true + }, + Ki: { + name: 'Ki', + value: 1024, + scientific: true + }, + Mi: { + name: 'Mi', + value: Math.pow(1024, 2), + scientific: true + }, + Gi: { + name: 'Gi', + value: Math.pow(1024, 3), + scientific: true + }, + Ti: { + name: 'Ti', + value: Math.pow(1024, 4), + scientific: true + }, + Pi: { + name: 'Pi', + value: Math.pow(1024, 5), + scientific: true + }, + Ei: { + name: 'Ei', + value: Math.pow(1024, 6), + scientific: true + }, + Zi: { + name: 'Zi', + value: Math.pow(1024, 7), + scientific: true + }, + Yi: { + name: 'Yi', + value: Math.pow(1024, 8), + scientific: true + } + }, + BINARY_LONG_SI: { + '': { + name: '', + value: 1, + scientific: true + }, + kilo: { + name: 'kilo', + value: 1e3, + scientific: true + }, + mega: { + name: 'mega', + value: 1e6, + scientific: true + }, + giga: { + name: 'giga', + value: 1e9, + scientific: true + }, + tera: { + name: 'tera', + value: 1e12, + scientific: true + }, + peta: { + name: 'peta', + value: 1e15, + scientific: true + }, + exa: { + name: 'exa', + value: 1e18, + scientific: true + }, + zetta: { + name: 'zetta', + value: 1e21, + scientific: true + }, + yotta: { + name: 'yotta', + value: 1e24, + scientific: true + } + }, + BINARY_LONG_IEC: { + '': { + name: '', + value: 1, + scientific: true + }, + kibi: { + name: 'kibi', + value: 1024, + scientific: true + }, + mebi: { + name: 'mebi', + value: Math.pow(1024, 2), + scientific: true + }, + gibi: { + name: 'gibi', + value: Math.pow(1024, 3), + scientific: true + }, + tebi: { + name: 'tebi', + value: Math.pow(1024, 4), + scientific: true + }, + pebi: { + name: 'pebi', + value: Math.pow(1024, 5), + scientific: true + }, + exi: { + name: 'exi', + value: Math.pow(1024, 6), + scientific: true + }, + zebi: { + name: 'zebi', + value: Math.pow(1024, 7), + scientific: true + }, + yobi: { + name: 'yobi', + value: Math.pow(1024, 8), + scientific: true + } + }, + BTU: { + '': { + name: '', + value: 1, + scientific: true + }, + MM: { + name: 'MM', + value: 1e6, + scientific: true + } + } + }; + PREFIXES.SHORTLONG = _extends({}, PREFIXES.SHORT, PREFIXES.LONG); + PREFIXES.BINARY_SHORT = _extends({}, PREFIXES.BINARY_SHORT_SI, PREFIXES.BINARY_SHORT_IEC); + PREFIXES.BINARY_LONG = _extends({}, PREFIXES.BINARY_LONG_SI, PREFIXES.BINARY_LONG_IEC); + + /* Internally, each unit is represented by a value and a dimension array. The elements of the dimensions array have the following meaning: + * Index Dimension + * ----- --------- + * 0 Length + * 1 Mass + * 2 Time + * 3 Current + * 4 Temperature + * 5 Luminous intensity + * 6 Amount of substance + * 7 Angle + * 8 Bit (digital) + * For example, the unit "298.15 K" is a pure temperature and would have a value of 298.15 and a dimension array of [0, 0, 0, 0, 1, 0, 0, 0, 0]. The unit "1 cal / (gm °C)" can be written in terms of the 9 fundamental dimensions as [length^2] / ([time^2] * [temperature]), and would a value of (after conversion to SI) 4184.0 and a dimensions array of [2, 0, -2, 0, -1, 0, 0, 0, 0]. + * + */ + + var BASE_DIMENSIONS = ['MASS', 'LENGTH', 'TIME', 'CURRENT', 'TEMPERATURE', 'LUMINOUS_INTENSITY', 'AMOUNT_OF_SUBSTANCE', 'ANGLE', 'BIT']; + var BASE_UNITS = { + NONE: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 0] + }, + MASS: { + dimensions: [1, 0, 0, 0, 0, 0, 0, 0, 0] + }, + LENGTH: { + dimensions: [0, 1, 0, 0, 0, 0, 0, 0, 0] + }, + TIME: { + dimensions: [0, 0, 1, 0, 0, 0, 0, 0, 0] + }, + CURRENT: { + dimensions: [0, 0, 0, 1, 0, 0, 0, 0, 0] + }, + TEMPERATURE: { + dimensions: [0, 0, 0, 0, 1, 0, 0, 0, 0] + }, + LUMINOUS_INTENSITY: { + dimensions: [0, 0, 0, 0, 0, 1, 0, 0, 0] + }, + AMOUNT_OF_SUBSTANCE: { + dimensions: [0, 0, 0, 0, 0, 0, 1, 0, 0] + }, + FORCE: { + dimensions: [1, 1, -2, 0, 0, 0, 0, 0, 0] + }, + SURFACE: { + dimensions: [0, 2, 0, 0, 0, 0, 0, 0, 0] + }, + VOLUME: { + dimensions: [0, 3, 0, 0, 0, 0, 0, 0, 0] + }, + ENERGY: { + dimensions: [1, 2, -2, 0, 0, 0, 0, 0, 0] + }, + POWER: { + dimensions: [1, 2, -3, 0, 0, 0, 0, 0, 0] + }, + PRESSURE: { + dimensions: [1, -1, -2, 0, 0, 0, 0, 0, 0] + }, + ELECTRIC_CHARGE: { + dimensions: [0, 0, 1, 1, 0, 0, 0, 0, 0] + }, + ELECTRIC_CAPACITANCE: { + dimensions: [-1, -2, 4, 2, 0, 0, 0, 0, 0] + }, + ELECTRIC_POTENTIAL: { + dimensions: [1, 2, -3, -1, 0, 0, 0, 0, 0] + }, + ELECTRIC_RESISTANCE: { + dimensions: [1, 2, -3, -2, 0, 0, 0, 0, 0] + }, + ELECTRIC_INDUCTANCE: { + dimensions: [1, 2, -2, -2, 0, 0, 0, 0, 0] + }, + ELECTRIC_CONDUCTANCE: { + dimensions: [-1, -2, 3, 2, 0, 0, 0, 0, 0] + }, + MAGNETIC_FLUX: { + dimensions: [1, 2, -2, -1, 0, 0, 0, 0, 0] + }, + MAGNETIC_FLUX_DENSITY: { + dimensions: [1, 0, -2, -1, 0, 0, 0, 0, 0] + }, + FREQUENCY: { + dimensions: [0, 0, -1, 0, 0, 0, 0, 0, 0] + }, + ANGLE: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 1, 0] + }, + BIT: { + dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 1] + } + }; + for (var key in BASE_UNITS) { + if (hasOwnProperty(BASE_UNITS, key)) { + BASE_UNITS[key].key = key; + } + } + var BASE_UNIT_NONE = {}; + var UNIT_NONE = { + name: '', + base: BASE_UNIT_NONE, + value: 1, + offset: 0, + dimensions: BASE_DIMENSIONS.map(x => 0) + }; + var UNITS = { + // length + meter: { + name: 'meter', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + inch: { + name: 'inch', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0254, + offset: 0 + }, + foot: { + name: 'foot', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.3048, + offset: 0 + }, + yard: { + name: 'yard', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.9144, + offset: 0 + }, + mile: { + name: 'mile', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1609.344, + offset: 0 + }, + link: { + name: 'link', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.201168, + offset: 0 + }, + rod: { + name: 'rod', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 5.0292, + offset: 0 + }, + chain: { + name: 'chain', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 20.1168, + offset: 0 + }, + angstrom: { + name: 'angstrom', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1e-10, + offset: 0 + }, + m: { + name: 'm', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + in: { + name: 'in', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0254, + offset: 0 + }, + ft: { + name: 'ft', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.3048, + offset: 0 + }, + yd: { + name: 'yd', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.9144, + offset: 0 + }, + mi: { + name: 'mi', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 1609.344, + offset: 0 + }, + li: { + name: 'li', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.201168, + offset: 0 + }, + rd: { + name: 'rd', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 5.029210, + offset: 0 + }, + ch: { + name: 'ch', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 20.1168, + offset: 0 + }, + mil: { + name: 'mil', + base: BASE_UNITS.LENGTH, + prefixes: PREFIXES.NONE, + value: 0.0000254, + offset: 0 + }, + // 1/1000 inch + + // Surface + m2: { + name: 'm2', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.SQUARED, + value: 1, + offset: 0 + }, + sqin: { + name: 'sqin', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.00064516, + offset: 0 + }, + // 645.16 mm2 + sqft: { + name: 'sqft', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.09290304, + offset: 0 + }, + // 0.09290304 m2 + sqyd: { + name: 'sqyd', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 0.83612736, + offset: 0 + }, + // 0.83612736 m2 + sqmi: { + name: 'sqmi', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 2589988.110336, + offset: 0 + }, + // 2.589988110336 km2 + sqrd: { + name: 'sqrd', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 25.29295, + offset: 0 + }, + // 25.29295 m2 + sqch: { + name: 'sqch', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 404.6873, + offset: 0 + }, + // 404.6873 m2 + sqmil: { + name: 'sqmil', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 6.4516e-10, + offset: 0 + }, + // 6.4516 * 10^-10 m2 + acre: { + name: 'acre', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 4046.86, + offset: 0 + }, + // 4046.86 m2 + hectare: { + name: 'hectare', + base: BASE_UNITS.SURFACE, + prefixes: PREFIXES.NONE, + value: 10000, + offset: 0 + }, + // 10000 m2 + + // Volume + m3: { + name: 'm3', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.CUBIC, + value: 1, + offset: 0 + }, + L: { + name: 'L', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + // litre + l: { + name: 'l', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + // litre + litre: { + name: 'litre', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.LONG, + value: 0.001, + offset: 0 + }, + cuin: { + name: 'cuin', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 1.6387064e-5, + offset: 0 + }, + // 1.6387064e-5 m3 + cuft: { + name: 'cuft', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.028316846592, + offset: 0 + }, + // 28.316 846 592 L + cuyd: { + name: 'cuyd', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.764554857984, + offset: 0 + }, + // 764.554 857 984 L + teaspoon: { + name: 'teaspoon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000005, + offset: 0 + }, + // 5 mL + tablespoon: { + name: 'tablespoon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000015, + offset: 0 + }, + // 15 mL + // {name: 'cup', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.000240, offset: 0}, // 240 mL // not possible, we have already another cup + drop: { + name: 'drop', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 5e-8, + offset: 0 + }, + // 0.05 mL = 5e-8 m3 + gtt: { + name: 'gtt', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 5e-8, + offset: 0 + }, + // 0.05 mL = 5e-8 m3 + + // Liquid volume + minim: { + name: 'minim', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000000061611519921875, + offset: 0 + }, + // 1/61440 gallons + fluiddram: { + name: 'fluiddram', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0000036966911953125, + offset: 0 + }, + // 1/1024 gallons + fluidounce: { + name: 'fluidounce', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0000295735295625, + offset: 0 + }, + // 1/128 gallons + gill: { + name: 'gill', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.00011829411825, + offset: 0 + }, + // 1/32 gallons + cc: { + name: 'cc', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 1e-6, + offset: 0 + }, + // 1e-6 L + cup: { + name: 'cup', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.0002365882365, + offset: 0 + }, + // 1/16 gallons + pint: { + name: 'pint', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000473176473, + offset: 0 + }, + // 1/8 gallons + quart: { + name: 'quart', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.000946352946, + offset: 0 + }, + // 1/4 gallons + gallon: { + name: 'gallon', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.003785411784, + offset: 0 + }, + // 3.785411784 L + beerbarrel: { + name: 'beerbarrel', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.117347765304, + offset: 0 + }, + // 31 gallons + oilbarrel: { + name: 'oilbarrel', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.158987294928, + offset: 0 + }, + // 42 gallons + hogshead: { + name: 'hogshead', + base: BASE_UNITS.VOLUME, + prefixes: PREFIXES.NONE, + value: 0.238480942392, + offset: 0 + }, + // 63 gallons + + // Mass + g: { + name: 'g', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 0.001, + offset: 0 + }, + gram: { + name: 'gram', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.LONG, + value: 0.001, + offset: 0 + }, + ton: { + name: 'ton', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 907.18474, + offset: 0 + }, + t: { + name: 't', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.SHORT, + value: 1000, + offset: 0 + }, + tonne: { + name: 'tonne', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.LONG, + value: 1000, + offset: 0 + }, + grain: { + name: 'grain', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 64.79891e-6, + offset: 0 + }, + dram: { + name: 'dram', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 1.7718451953125e-3, + offset: 0 + }, + ounce: { + name: 'ounce', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 28.349523125e-3, + offset: 0 + }, + poundmass: { + name: 'poundmass', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 453.59237e-3, + offset: 0 + }, + hundredweight: { + name: 'hundredweight', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 45.359237, + offset: 0 + }, + stick: { + name: 'stick', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 115e-3, + offset: 0 + }, + stone: { + name: 'stone', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 6.35029318, + offset: 0 + }, + gr: { + name: 'gr', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 64.79891e-6, + offset: 0 + }, + dr: { + name: 'dr', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 1.7718451953125e-3, + offset: 0 + }, + oz: { + name: 'oz', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 28.349523125e-3, + offset: 0 + }, + lbm: { + name: 'lbm', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 453.59237e-3, + offset: 0 + }, + cwt: { + name: 'cwt', + base: BASE_UNITS.MASS, + prefixes: PREFIXES.NONE, + value: 45.359237, + offset: 0 + }, + // Time + s: { + name: 's', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + min: { + name: 'min', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 60, + offset: 0 + }, + h: { + name: 'h', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3600, + offset: 0 + }, + second: { + name: 'second', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + sec: { + name: 'sec', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + minute: { + name: 'minute', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 60, + offset: 0 + }, + hour: { + name: 'hour', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3600, + offset: 0 + }, + day: { + name: 'day', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 86400, + offset: 0 + }, + week: { + name: 'week', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 7 * 86400, + offset: 0 + }, + month: { + name: 'month', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 2629800, + // 1/12th of Julian year + offset: 0 + }, + year: { + name: 'year', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 31557600, + // Julian year + offset: 0 + }, + decade: { + name: 'decade', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 315576000, + // Julian decade + offset: 0 + }, + century: { + name: 'century', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 3155760000, + // Julian century + offset: 0 + }, + millennium: { + name: 'millennium', + base: BASE_UNITS.TIME, + prefixes: PREFIXES.NONE, + value: 31557600000, + // Julian millennium + offset: 0 + }, + // Frequency + hertz: { + name: 'Hertz', + base: BASE_UNITS.FREQUENCY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0, + reciprocal: true + }, + Hz: { + name: 'Hz', + base: BASE_UNITS.FREQUENCY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0, + reciprocal: true + }, + // Angle + rad: { + name: 'rad', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + radian: { + name: 'radian', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // deg = rad / (2*pi) * 360 = rad / 0.017453292519943295769236907684888 + deg: { + name: 'deg', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + degree: { + name: 'degree', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // grad = rad / (2*pi) * 400 = rad / 0.015707963267948966192313216916399 + grad: { + name: 'grad', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.SHORT, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + gradian: { + name: 'gradian', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.LONG, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // cycle = rad / (2*pi) = rad / 6.2831853071795864769252867665793 + cycle: { + name: 'cycle', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // arcsec = rad / (3600 * (360 / 2 * pi)) = rad / 0.0000048481368110953599358991410235795 + arcsec: { + name: 'arcsec', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // arcmin = rad / (60 * (360 / 2 * pi)) = rad / 0.00029088820866572159615394846141477 + arcmin: { + name: 'arcmin', + base: BASE_UNITS.ANGLE, + prefixes: PREFIXES.NONE, + value: null, + // will be filled in by calculateAngleValues() + offset: 0 + }, + // Electric current + A: { + name: 'A', + base: BASE_UNITS.CURRENT, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + ampere: { + name: 'ampere', + base: BASE_UNITS.CURRENT, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // Temperature + // K(C) = °C + 273.15 + // K(F) = (°F + 459.67) * (5 / 9) + // K(R) = °R * (5 / 9) + K: { + name: 'K', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + degC: { + name: 'degC', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 273.15 + }, + degF: { + name: 'degF', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: new _Fraction(5, 9), + offset: 459.67 + }, + degR: { + name: 'degR', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.SHORT, + value: new _Fraction(5, 9), + offset: 0 + }, + kelvin: { + name: 'kelvin', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + celsius: { + name: 'celsius', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 273.15 + }, + fahrenheit: { + name: 'fahrenheit', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: new _Fraction(5, 9), + offset: 459.67 + }, + rankine: { + name: 'rankine', + base: BASE_UNITS.TEMPERATURE, + prefixes: PREFIXES.LONG, + value: new _Fraction(5, 9), + offset: 0 + }, + // amount of substance + mol: { + name: 'mol', + base: BASE_UNITS.AMOUNT_OF_SUBSTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + mole: { + name: 'mole', + base: BASE_UNITS.AMOUNT_OF_SUBSTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // luminous intensity + cd: { + name: 'cd', + base: BASE_UNITS.LUMINOUS_INTENSITY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + candela: { + name: 'candela', + base: BASE_UNITS.LUMINOUS_INTENSITY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + // TODO: units STERADIAN + // {name: 'sr', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0}, + // {name: 'steradian', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0}, + + // Force + N: { + name: 'N', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + newton: { + name: 'newton', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + dyn: { + name: 'dyn', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.SHORT, + value: 0.00001, + offset: 0 + }, + dyne: { + name: 'dyne', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 0.00001, + offset: 0 + }, + lbf: { + name: 'lbf', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 4.4482216152605, + offset: 0 + }, + poundforce: { + name: 'poundforce', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 4.4482216152605, + offset: 0 + }, + kip: { + name: 'kip', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.LONG, + value: 4448.2216, + offset: 0 + }, + kilogramforce: { + name: 'kilogramforce', + base: BASE_UNITS.FORCE, + prefixes: PREFIXES.NONE, + value: 9.80665, + offset: 0 + }, + // Energy + J: { + name: 'J', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + joule: { + name: 'joule', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + erg: { + name: 'erg', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORTLONG, + // Both kiloerg and kerg are acceptable + value: 1e-7, + offset: 0 + }, + Wh: { + name: 'Wh', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 3600, + offset: 0 + }, + BTU: { + name: 'BTU', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.BTU, + value: 1055.05585262, + offset: 0 + }, + eV: { + name: 'eV', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.SHORT, + value: 1.602176565e-19, + offset: 0 + }, + electronvolt: { + name: 'electronvolt', + base: BASE_UNITS.ENERGY, + prefixes: PREFIXES.LONG, + value: 1.602176565e-19, + offset: 0 + }, + // Power + W: { + name: 'W', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + watt: { + name: 'watt', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + hp: { + name: 'hp', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.NONE, + value: 745.6998715386, + offset: 0 + }, + // Electrical power units + VAR: { + name: 'VAR', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: Complex.I, + offset: 0 + }, + VA: { + name: 'VA', + base: BASE_UNITS.POWER, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Pressure + Pa: { + name: 'Pa', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + psi: { + name: 'psi', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 6894.75729276459, + offset: 0 + }, + atm: { + name: 'atm', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 101325, + offset: 0 + }, + bar: { + name: 'bar', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.SHORTLONG, + value: 100000, + offset: 0 + }, + torr: { + name: 'torr', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 133.322, + offset: 0 + }, + mmHg: { + name: 'mmHg', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 133.322, + offset: 0 + }, + mmH2O: { + name: 'mmH2O', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 9.80665, + offset: 0 + }, + cmH2O: { + name: 'cmH2O', + base: BASE_UNITS.PRESSURE, + prefixes: PREFIXES.NONE, + value: 98.0665, + offset: 0 + }, + // Electric charge + coulomb: { + name: 'coulomb', + base: BASE_UNITS.ELECTRIC_CHARGE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + C: { + name: 'C', + base: BASE_UNITS.ELECTRIC_CHARGE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric capacitance + farad: { + name: 'farad', + base: BASE_UNITS.ELECTRIC_CAPACITANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + F: { + name: 'F', + base: BASE_UNITS.ELECTRIC_CAPACITANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric potential + volt: { + name: 'volt', + base: BASE_UNITS.ELECTRIC_POTENTIAL, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + V: { + name: 'V', + base: BASE_UNITS.ELECTRIC_POTENTIAL, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric resistance + ohm: { + name: 'ohm', + base: BASE_UNITS.ELECTRIC_RESISTANCE, + prefixes: PREFIXES.SHORTLONG, + // Both Mohm and megaohm are acceptable + value: 1, + offset: 0 + }, + /* + * Unicode breaks in browsers if charset is not specified + Ω: { + name: 'Ω', + base: BASE_UNITS.ELECTRIC_RESISTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + */ + // Electric inductance + henry: { + name: 'henry', + base: BASE_UNITS.ELECTRIC_INDUCTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + H: { + name: 'H', + base: BASE_UNITS.ELECTRIC_INDUCTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Electric conductance + siemens: { + name: 'siemens', + base: BASE_UNITS.ELECTRIC_CONDUCTANCE, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + S: { + name: 'S', + base: BASE_UNITS.ELECTRIC_CONDUCTANCE, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Magnetic flux + weber: { + name: 'weber', + base: BASE_UNITS.MAGNETIC_FLUX, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + Wb: { + name: 'Wb', + base: BASE_UNITS.MAGNETIC_FLUX, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Magnetic flux density + tesla: { + name: 'tesla', + base: BASE_UNITS.MAGNETIC_FLUX_DENSITY, + prefixes: PREFIXES.LONG, + value: 1, + offset: 0 + }, + T: { + name: 'T', + base: BASE_UNITS.MAGNETIC_FLUX_DENSITY, + prefixes: PREFIXES.SHORT, + value: 1, + offset: 0 + }, + // Binary + b: { + name: 'b', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_SHORT, + value: 1, + offset: 0 + }, + bits: { + name: 'bits', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_LONG, + value: 1, + offset: 0 + }, + B: { + name: 'B', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_SHORT, + value: 8, + offset: 0 + }, + bytes: { + name: 'bytes', + base: BASE_UNITS.BIT, + prefixes: PREFIXES.BINARY_LONG, + value: 8, + offset: 0 + } + }; + + // aliases (formerly plurals) + // note that ALIASES is only used at creation to create more entries in UNITS by copying the aliased units + var ALIASES = { + meters: 'meter', + inches: 'inch', + feet: 'foot', + yards: 'yard', + miles: 'mile', + links: 'link', + rods: 'rod', + chains: 'chain', + angstroms: 'angstrom', + lt: 'l', + litres: 'litre', + liter: 'litre', + liters: 'litre', + teaspoons: 'teaspoon', + tablespoons: 'tablespoon', + minims: 'minim', + fldr: 'fluiddram', + fluiddrams: 'fluiddram', + floz: 'fluidounce', + fluidounces: 'fluidounce', + gi: 'gill', + gills: 'gill', + cp: 'cup', + cups: 'cup', + pt: 'pint', + pints: 'pint', + qt: 'quart', + quarts: 'quart', + gal: 'gallon', + gallons: 'gallon', + bbl: 'beerbarrel', + beerbarrels: 'beerbarrel', + obl: 'oilbarrel', + oilbarrels: 'oilbarrel', + hogsheads: 'hogshead', + gtts: 'gtt', + grams: 'gram', + tons: 'ton', + tonnes: 'tonne', + grains: 'grain', + drams: 'dram', + ounces: 'ounce', + poundmasses: 'poundmass', + hundredweights: 'hundredweight', + sticks: 'stick', + lb: 'lbm', + lbs: 'lbm', + kips: 'kip', + kgf: 'kilogramforce', + acres: 'acre', + hectares: 'hectare', + sqfeet: 'sqft', + sqyard: 'sqyd', + sqmile: 'sqmi', + sqmiles: 'sqmi', + mmhg: 'mmHg', + mmh2o: 'mmH2O', + cmh2o: 'cmH2O', + seconds: 'second', + secs: 'second', + minutes: 'minute', + mins: 'minute', + hours: 'hour', + hr: 'hour', + hrs: 'hour', + days: 'day', + weeks: 'week', + months: 'month', + years: 'year', + decades: 'decade', + centuries: 'century', + millennia: 'millennium', + hertz: 'hertz', + radians: 'radian', + degrees: 'degree', + gradians: 'gradian', + cycles: 'cycle', + arcsecond: 'arcsec', + arcseconds: 'arcsec', + arcminute: 'arcmin', + arcminutes: 'arcmin', + BTUs: 'BTU', + watts: 'watt', + joules: 'joule', + amperes: 'ampere', + amps: 'ampere', + amp: 'ampere', + coulombs: 'coulomb', + volts: 'volt', + ohms: 'ohm', + farads: 'farad', + webers: 'weber', + teslas: 'tesla', + electronvolts: 'electronvolt', + moles: 'mole', + bit: 'bits', + byte: 'bytes' + }; + + /** + * Calculate the values for the angle units. + * Value is calculated as number or BigNumber depending on the configuration + * @param {{number: 'number' | 'BigNumber'}} config + */ + function calculateAngleValues(config) { + if (config.number === 'BigNumber') { + var pi = createPi(_BigNumber); + UNITS.rad.value = new _BigNumber(1); + UNITS.deg.value = pi.div(180); // 2 * pi / 360 + UNITS.grad.value = pi.div(200); // 2 * pi / 400 + UNITS.cycle.value = pi.times(2); // 2 * pi + UNITS.arcsec.value = pi.div(648000); // 2 * pi / 360 / 3600 + UNITS.arcmin.value = pi.div(10800); // 2 * pi / 360 / 60 + } else { + // number + UNITS.rad.value = 1; + UNITS.deg.value = Math.PI / 180; // 2 * pi / 360 + UNITS.grad.value = Math.PI / 200; // 2 * pi / 400 + UNITS.cycle.value = Math.PI * 2; // 2 * pi + UNITS.arcsec.value = Math.PI / 648000; // 2 * pi / 360 / 3600 + UNITS.arcmin.value = Math.PI / 10800; // 2 * pi / 360 / 60 + } + + // copy to the full names of the angles + UNITS.radian.value = UNITS.rad.value; + UNITS.degree.value = UNITS.deg.value; + UNITS.gradian.value = UNITS.grad.value; + } + + // apply the angle values now + calculateAngleValues(config); + if (on) { + // recalculate the values on change of configuration + on('config', function (curr, prev) { + if (curr.number !== prev.number) { + calculateAngleValues(curr); + } + }); + } + + /** + * A unit system is a set of dimensionally independent base units plus a set of derived units, formed by multiplication and division of the base units, that are by convention used with the unit system. + * A user perhaps could issue a command to select a preferred unit system, or use the default (see below). + * Auto unit system: The default unit system is updated on the fly anytime a unit is parsed. The corresponding unit in the default unit system is updated, so that answers are given in the same units the user supplies. + */ + var UNIT_SYSTEMS = { + si: { + // Base units + NONE: { + unit: UNIT_NONE, + prefix: PREFIXES.NONE[''] + }, + LENGTH: { + unit: UNITS.m, + prefix: PREFIXES.SHORT[''] + }, + MASS: { + unit: UNITS.g, + prefix: PREFIXES.SHORT.k + }, + TIME: { + unit: UNITS.s, + prefix: PREFIXES.SHORT[''] + }, + CURRENT: { + unit: UNITS.A, + prefix: PREFIXES.SHORT[''] + }, + TEMPERATURE: { + unit: UNITS.K, + prefix: PREFIXES.SHORT[''] + }, + LUMINOUS_INTENSITY: { + unit: UNITS.cd, + prefix: PREFIXES.SHORT[''] + }, + AMOUNT_OF_SUBSTANCE: { + unit: UNITS.mol, + prefix: PREFIXES.SHORT[''] + }, + ANGLE: { + unit: UNITS.rad, + prefix: PREFIXES.SHORT[''] + }, + BIT: { + unit: UNITS.bits, + prefix: PREFIXES.SHORT[''] + }, + // Derived units + FORCE: { + unit: UNITS.N, + prefix: PREFIXES.SHORT[''] + }, + ENERGY: { + unit: UNITS.J, + prefix: PREFIXES.SHORT[''] + }, + POWER: { + unit: UNITS.W, + prefix: PREFIXES.SHORT[''] + }, + PRESSURE: { + unit: UNITS.Pa, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CHARGE: { + unit: UNITS.C, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CAPACITANCE: { + unit: UNITS.F, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_POTENTIAL: { + unit: UNITS.V, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_RESISTANCE: { + unit: UNITS.ohm, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_INDUCTANCE: { + unit: UNITS.H, + prefix: PREFIXES.SHORT[''] + }, + ELECTRIC_CONDUCTANCE: { + unit: UNITS.S, + prefix: PREFIXES.SHORT[''] + }, + MAGNETIC_FLUX: { + unit: UNITS.Wb, + prefix: PREFIXES.SHORT[''] + }, + MAGNETIC_FLUX_DENSITY: { + unit: UNITS.T, + prefix: PREFIXES.SHORT[''] + }, + FREQUENCY: { + unit: UNITS.Hz, + prefix: PREFIXES.SHORT[''] + } + } + }; + + // Clone to create the other unit systems + UNIT_SYSTEMS.cgs = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + UNIT_SYSTEMS.cgs.LENGTH = { + unit: UNITS.m, + prefix: PREFIXES.SHORT.c + }; + UNIT_SYSTEMS.cgs.MASS = { + unit: UNITS.g, + prefix: PREFIXES.SHORT[''] + }; + UNIT_SYSTEMS.cgs.FORCE = { + unit: UNITS.dyn, + prefix: PREFIXES.SHORT[''] + }; + UNIT_SYSTEMS.cgs.ENERGY = { + unit: UNITS.erg, + prefix: PREFIXES.NONE[''] + }; + // there are wholly 4 unique cgs systems for electricity and magnetism, + // so let's not worry about it unless somebody complains + + UNIT_SYSTEMS.us = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + UNIT_SYSTEMS.us.LENGTH = { + unit: UNITS.ft, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.MASS = { + unit: UNITS.lbm, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.TEMPERATURE = { + unit: UNITS.degF, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.FORCE = { + unit: UNITS.lbf, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.ENERGY = { + unit: UNITS.BTU, + prefix: PREFIXES.BTU[''] + }; + UNIT_SYSTEMS.us.POWER = { + unit: UNITS.hp, + prefix: PREFIXES.NONE[''] + }; + UNIT_SYSTEMS.us.PRESSURE = { + unit: UNITS.psi, + prefix: PREFIXES.NONE[''] + }; + + // Add additional unit systems here. + + // Choose a unit system to seed the auto unit system. + UNIT_SYSTEMS.auto = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); + + // Set the current unit system + var currentUnitSystem = UNIT_SYSTEMS.auto; + + /** + * Set a unit system for formatting derived units. + * @memberof Unit + * @param {string} [name] The name of the unit system. + */ + Unit.setUnitSystem = function (name) { + if (hasOwnProperty(UNIT_SYSTEMS, name)) { + currentUnitSystem = UNIT_SYSTEMS[name]; + } else { + throw new Error('Unit system ' + name + ' does not exist. Choices are: ' + Object.keys(UNIT_SYSTEMS).join(', ')); + } + }; + + /** + * Return the current unit system. + * @memberof Unit + * @return {string} The current unit system. + */ + Unit.getUnitSystem = function () { + for (var _key in UNIT_SYSTEMS) { + if (hasOwnProperty(UNIT_SYSTEMS, _key)) { + if (UNIT_SYSTEMS[_key] === currentUnitSystem) { + return _key; + } + } + } + }; + + /** + * Converters to convert from number to an other numeric type like BigNumber + * or Fraction + */ + Unit.typeConverters = { + BigNumber: function BigNumber(x) { + if (x !== null && x !== void 0 && x.isFraction) return new _BigNumber(x.n).div(x.d).times(x.s); + return new _BigNumber(x + ''); // stringify to prevent constructor error + }, + Fraction: function Fraction(x) { + return new _Fraction(x); + }, + Complex: function Complex(x) { + return x; + }, + number: function number(x) { + if (x !== null && x !== void 0 && x.isFraction) return _number(x); + return x; + } + }; + + /** + * Retrieve the right converter function corresponding with this unit's + * value + * + * @memberof Unit + * @return {Function} + */ + Unit.prototype._numberConverter = function () { + var convert = Unit.typeConverters[this.valueType()]; + if (convert) { + return convert; + } + throw new TypeError('Unsupported Unit value type "' + this.valueType() + '"'); + }; + + /** + * Retrieve the right convertor function corresponding with the type + * of provided exampleValue. + * + * @param {string} type A string 'number', 'BigNumber', or 'Fraction' + * In case of an unknown type, + * @return {Function} + */ + Unit._getNumberConverter = function (type) { + if (!Unit.typeConverters[type]) { + throw new TypeError('Unsupported type "' + type + '"'); + } + return Unit.typeConverters[type]; + }; + + // Add dimensions to each built-in unit + for (var _key2 in UNITS) { + if (hasOwnProperty(UNITS, _key2)) { + var unit = UNITS[_key2]; + unit.dimensions = unit.base.dimensions; + } + } + + // Create aliases + for (var _name2 in ALIASES) { + if (hasOwnProperty(ALIASES, _name2)) { + var _unit2 = UNITS[ALIASES[_name2]]; + var alias = {}; + for (var _key3 in _unit2) { + if (hasOwnProperty(_unit2, _key3)) { + alias[_key3] = _unit2[_key3]; + } + } + alias.name = _name2; + UNITS[_name2] = alias; + } + } + + /** + * Checks if a character is a valid latin letter (upper or lower case). + * Note that this function can be overridden, for example to allow support of other alphabets. + * @memberof Unit + * @param {string} c Tested character + * @return {boolean} true if the character is a latin letter + */ + Unit.isValidAlpha = function isValidAlpha(c) { + return /^[a-zA-Z]$/.test(c); + }; + function assertUnitNameIsValid(name) { + for (var i = 0; i < name.length; i++) { + c = name.charAt(i); + if (i === 0 && !Unit.isValidAlpha(c)) { + throw new Error('Invalid unit name (must begin with alpha character): "' + name + '"'); + } + if (i > 0 && !(Unit.isValidAlpha(c) || isDigit(c))) { + throw new Error('Invalid unit name (only alphanumeric characters are allowed): "' + name + '"'); + } + } + } + + /** + * Wrapper around createUnitSingle. + * Example: + * createUnit( { + * foo: { + * prefixes: 'long', + * baseName: 'essence-of-foo' + * }, + * bar: '40 foo', + * baz: { + * definition: '1 bar/hour', + * prefixes: 'long' + * } + * }, + * { + * override: true + * }) + * @memberof Unit + * @param {object} obj Object map. Each key becomes a unit which is defined by its value. + * @param {object} options + * @return {Unit} the last created unit + */ + Unit.createUnit = function (obj, options) { + if (typeof obj !== 'object') { + throw new TypeError("createUnit expects first parameter to be of type 'Object'"); + } + + // Remove all units and aliases we are overriding + if (options && options.override) { + for (var _key4 in obj) { + if (hasOwnProperty(obj, _key4)) { + Unit.deleteUnit(_key4); + } + if (obj[_key4].aliases) { + for (var i = 0; i < obj[_key4].aliases.length; i++) { + Unit.deleteUnit(obj[_key4].aliases[i]); + } + } + } + } + + // TODO: traverse multiple times until all units have been added + var lastUnit; + for (var _key5 in obj) { + if (hasOwnProperty(obj, _key5)) { + lastUnit = Unit.createUnitSingle(_key5, obj[_key5]); + } + } + return lastUnit; + }; + + /** + * Create a user-defined unit and register it with the Unit type. + * Example: + * createUnitSingle('knot', '0.514444444 m/s') + * + * @memberof Unit + * @param {string} name The name of the new unit. Must be unique. Example: 'knot' + * @param {string | Unit | object} definition Definition of the unit in terms + * of existing units. For example, '0.514444444 m / s'. Can be a Unit, a string, + * or an Object. If an Object, may have the following properties: + * - definition {string | Unit} The definition of this unit. + * - prefixes {string} "none", "short", "long", "binary_short", or "binary_long". + * The default is "none". + * - aliases {Array} Array of strings. Example: ['knots', 'kt', 'kts'] + * - offset {Numeric} An offset to apply when converting from the unit. For + * example, the offset for celsius is 273.15 and the offset for farhenheit + * is 459.67. Default is 0. + * - baseName {string} If the unit's dimension does not match that of any other + * base unit, the name of the newly create base unit. Otherwise, this property + * has no effect. + * + * @return {Unit} + */ + Unit.createUnitSingle = function (name, obj) { + if (typeof obj === 'undefined' || obj === null) { + obj = {}; + } + if (typeof name !== 'string') { + throw new TypeError("createUnitSingle expects first parameter to be of type 'string'"); + } + + // Check collisions with existing units + if (hasOwnProperty(UNITS, name)) { + throw new Error('Cannot create unit "' + name + '": a unit with that name already exists'); + } + + // TODO: Validate name for collisions with other built-in functions (like abs or cos, for example), and for acceptable variable names. For example, '42' is probably not a valid unit. Nor is '%', since it is also an operator. + + assertUnitNameIsValid(name); + var defUnit = null; // The Unit from which the new unit will be created. + var aliases = []; + var offset = 0; + var definition; + var prefixes; + var baseName; + if (obj && obj.type === 'Unit') { + defUnit = obj.clone(); + } else if (typeof obj === 'string') { + if (obj !== '') { + definition = obj; + } + } else if (typeof obj === 'object') { + definition = obj.definition; + prefixes = obj.prefixes; + offset = obj.offset; + baseName = obj.baseName; + if (obj.aliases) { + aliases = obj.aliases.valueOf(); // aliases could be a Matrix, so convert to Array + } + } else { + throw new TypeError('Cannot create unit "' + name + '" from "' + obj.toString() + '": expecting "string" or "Unit" or "Object"'); + } + if (aliases) { + for (var i = 0; i < aliases.length; i++) { + if (hasOwnProperty(UNITS, aliases[i])) { + throw new Error('Cannot create alias "' + aliases[i] + '": a unit with that name already exists'); + } + } + } + if (definition && typeof definition === 'string' && !defUnit) { + try { + defUnit = Unit.parse(definition, { + allowNoUnits: true + }); + } catch (ex) { + ex.message = 'Could not create unit "' + name + '" from "' + definition + '": ' + ex.message; + throw ex; + } + } else if (definition && definition.type === 'Unit') { + defUnit = definition.clone(); + } + aliases = aliases || []; + offset = offset || 0; + if (prefixes && prefixes.toUpperCase) { + prefixes = PREFIXES[prefixes.toUpperCase()] || PREFIXES.NONE; + } else { + prefixes = PREFIXES.NONE; + } + + // If defUnit is null, it is because the user did not + // specify a defintion. So create a new base dimension. + var newUnit = {}; + if (!defUnit) { + // Add a new base dimension + baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo + if (BASE_DIMENSIONS.indexOf(baseName) >= 0) { + throw new Error('Cannot create new base unit "' + name + '": a base unit with that name already exists (and cannot be overridden)'); + } + BASE_DIMENSIONS.push(baseName); + + // Push 0 onto existing base units + for (var b in BASE_UNITS) { + if (hasOwnProperty(BASE_UNITS, b)) { + BASE_UNITS[b].dimensions[BASE_DIMENSIONS.length - 1] = 0; + } + } + + // Add the new base unit + var newBaseUnit = { + dimensions: [] + }; + for (var _i6 = 0; _i6 < BASE_DIMENSIONS.length; _i6++) { + newBaseUnit.dimensions[_i6] = 0; + } + newBaseUnit.dimensions[BASE_DIMENSIONS.length - 1] = 1; + newBaseUnit.key = baseName; + BASE_UNITS[baseName] = newBaseUnit; + newUnit = { + name, + value: 1, + dimensions: BASE_UNITS[baseName].dimensions.slice(0), + prefixes, + offset, + base: BASE_UNITS[baseName] + }; + currentUnitSystem[baseName] = { + unit: newUnit, + prefix: PREFIXES.NONE[''] + }; + } else { + newUnit = { + name, + value: defUnit.value, + dimensions: defUnit.dimensions.slice(0), + prefixes, + offset + }; + + // Create a new base if no matching base exists + var anyMatch = false; + for (var _i7 in BASE_UNITS) { + if (hasOwnProperty(BASE_UNITS, _i7)) { + var match = true; + for (var j = 0; j < BASE_DIMENSIONS.length; j++) { + if (Math.abs((newUnit.dimensions[j] || 0) - (BASE_UNITS[_i7].dimensions[j] || 0)) > 1e-12) { + match = false; + break; + } + } + if (match) { + anyMatch = true; + newUnit.base = BASE_UNITS[_i7]; + break; + } + } + } + if (!anyMatch) { + baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo + // Add the new base unit + var _newBaseUnit = { + dimensions: defUnit.dimensions.slice(0) + }; + _newBaseUnit.key = baseName; + BASE_UNITS[baseName] = _newBaseUnit; + currentUnitSystem[baseName] = { + unit: newUnit, + prefix: PREFIXES.NONE[''] + }; + newUnit.base = BASE_UNITS[baseName]; + } + } + Unit.UNITS[name] = newUnit; + for (var _i8 = 0; _i8 < aliases.length; _i8++) { + var aliasName = aliases[_i8]; + var _alias = {}; + for (var _key6 in newUnit) { + if (hasOwnProperty(newUnit, _key6)) { + _alias[_key6] = newUnit[_key6]; + } + } + _alias.name = aliasName; + Unit.UNITS[aliasName] = _alias; + } + + // delete the memoization cache because we created a new unit + delete _findUnit.cache; + return new Unit(null, name); + }; + Unit.deleteUnit = function (name) { + delete Unit.UNITS[name]; + + // delete the memoization cache because we deleted a unit + delete _findUnit.cache; + }; + + // expose arrays with prefixes, dimensions, units, systems + Unit.PREFIXES = PREFIXES; + Unit.BASE_DIMENSIONS = BASE_DIMENSIONS; + Unit.BASE_UNITS = BASE_UNITS; + Unit.UNIT_SYSTEMS = UNIT_SYSTEMS; + Unit.UNITS = UNITS; + return Unit; +}, { + isClass: true +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/createUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/createUnit.js new file mode 100644 index 0000000..5c4624f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/createUnit.js @@ -0,0 +1,79 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'createUnit'; +var dependencies = ['typed', 'Unit']; +export var createCreateUnit = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Unit + } = _ref; + /** + * Create a user-defined unit and register it with the Unit type. + * + * Syntax: + * + * math.createUnit({ + * baseUnit1: { + * aliases: [string, ...] + * prefixes: object + * }, + * unit2: { + * definition: string, + * aliases: [string, ...] + * prefixes: object, + * offset: number + * }, + * unit3: string // Shortcut + * }) + * + * // Another shortcut: + * math.createUnit(string, unit : string, [object]) + * + * Examples: + * + * math.createUnit('foo') + * math.createUnit('knot', {definition: '0.514444444 m/s', aliases: ['knots', 'kt', 'kts']}) + * math.createUnit('mph', '1 mile/hour') + * math.createUnit('km', math.unit(1000, 'm')) + * + * @param {string} name The name of the new unit. Must be unique. Example: 'knot' + * @param {string, UnitDefinition, Unit} definition Definition of the unit in terms of existing units. For example, '0.514444444 m / s'. + * @param {Object} options (optional) An object containing any of the following properties: + * - `prefixes {string}` "none", "short", "long", "binary_short", or "binary_long". The default is "none". + * - `aliases {Array}` Array of strings. Example: ['knots', 'kt', 'kts'] + * - `offset {Numeric}` An offset to apply when converting from the unit. For example, the offset for celsius is 273.15. Default is 0. + * + * See also: + * + * unit + * + * @return {Unit} The new unit + */ + return typed(name, { + // General function signature. First parameter is an object where each property is the definition of a new unit. The object keys are the unit names and the values are the definitions. The values can be objects, strings, or Units. If a property is an empty object or an empty string, a new base unit is created. The second parameter is the options. + 'Object, Object': function Object_Object(obj, options) { + return Unit.createUnit(obj, options); + }, + // Same as above but without the options. + Object: function Object(obj) { + return Unit.createUnit(obj, {}); + }, + // Shortcut method for creating one unit. + 'string, Unit | string | Object, Object': function string_Unit__string__Object_Object(name, def, options) { + var obj = {}; + obj[name] = def; + return Unit.createUnit(obj, options); + }, + // Same as above but without the options. + 'string, Unit | string | Object': function string_Unit__string__Object(name, def) { + var obj = {}; + obj[name] = def; + return Unit.createUnit(obj, {}); + }, + // Without a definition, creates a base unit. + string: function string(name) { + var obj = {}; + obj[name] = {}; + return Unit.createUnit(obj, {}); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/splitUnit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/splitUnit.js new file mode 100644 index 0000000..f89e59e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/splitUnit.js @@ -0,0 +1,32 @@ +import { factory } from '../../../utils/factory.js'; +var name = 'splitUnit'; +var dependencies = ['typed']; +export var createSplitUnit = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed + } = _ref; + /** + * Split a unit in an array of units whose sum is equal to the original unit. + * + * Syntax: + * + * math.splitUnit(unit: Unit, parts: Array.) + * + * Example: + * + * math.splitUnit(new Unit(1, 'm'), ['feet', 'inch']) + * // [ 3 feet, 3.3700787401575 inch ] + * + * See also: + * + * unit + * + * @param {Array} [parts] An array of strings or valueless units. + * @return {Array} An array of units. + */ + return typed(name, { + 'Unit, Array': function Unit_Array(unit, parts) { + return unit.splitUnit(parts); + } + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/unit.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/unit.js new file mode 100644 index 0000000..612d68a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/function/unit.js @@ -0,0 +1,60 @@ +import { factory } from '../../../utils/factory.js'; +import { deepMap } from '../../../utils/collection.js'; +var name = 'unit'; +var dependencies = ['typed', 'Unit']; + +// This function is named createUnitFunction to prevent a naming conflict with createUnit +export var createUnitFunction = /* #__PURE__ */factory(name, dependencies, _ref => { + var { + typed, + Unit + } = _ref; + /** + * Create a unit. Depending on the passed arguments, the function + * will create and return a new math.Unit object. + * When a matrix is provided, all elements will be converted to units. + * + * Syntax: + * + * math.unit(unit : string) + * math.unit(value : number, valuelessUnit : Unit) + * math.unit(value : number, valuelessUnit : string) + * + * Examples: + * + * const kph = math.unit('km/h') // returns Unit km/h (valueless) + * const v = math.unit(25, kph) // returns Unit 25 km/h + * const a = math.unit(5, 'cm') // returns Unit 50 mm + * const b = math.unit('23 kg') // returns Unit 23 kg + * a.to('m') // returns Unit 0.05 m + * + * See also: + * + * bignumber, boolean, complex, index, matrix, number, string, createUnit + * + * @param {* | Array | Matrix} args A number and unit. + * @return {Unit | Array | Matrix} The created unit + */ + + return typed(name, { + Unit: function Unit(x) { + return x.clone(); + }, + string: function string(x) { + if (Unit.isValuelessUnit(x)) { + return new Unit(null, x); // a pure unit + } + return Unit.parse(x, { + allowNoUnits: true + }); // a unit with value, like '5cm' + }, + 'number | BigNumber | Fraction | Complex, string | Unit': function number__BigNumber__Fraction__Complex_string__Unit(value, unit) { + return new Unit(value, unit); + }, + 'number | BigNumber | Fraction': function number__BigNumber__Fraction(value) { + // dimensionless + return new Unit(value); + }, + 'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)) + }); +}); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/physicalConstants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/physicalConstants.js new file mode 100644 index 0000000..6e65b38 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/type/unit/physicalConstants.js @@ -0,0 +1,101 @@ +import { factory } from '../../utils/factory.js'; + +// Source: https://en.wikipedia.org/wiki/Physical_constant + +// Universal constants +export var createSpeedOfLight = /* #__PURE__ */unitFactory('speedOfLight', '299792458', 'm s^-1'); +export var createGravitationConstant = /* #__PURE__ */unitFactory('gravitationConstant', '6.67430e-11', 'm^3 kg^-1 s^-2'); +export var createPlanckConstant = /* #__PURE__ */unitFactory('planckConstant', '6.62607015e-34', 'J s'); +export var createReducedPlanckConstant = /* #__PURE__ */unitFactory('reducedPlanckConstant', '1.0545718176461565e-34', 'J s'); + +// Electromagnetic constants +export var createMagneticConstant = /* #__PURE__ */unitFactory('magneticConstant', '1.25663706212e-6', 'N A^-2'); +export var createElectricConstant = /* #__PURE__ */unitFactory('electricConstant', '8.8541878128e-12', 'F m^-1'); +export var createVacuumImpedance = /* #__PURE__ */unitFactory('vacuumImpedance', '376.730313667', 'ohm'); +export var createCoulomb = /* #__PURE__ */unitFactory('coulomb', '8.987551792261171e9', 'N m^2 C^-2'); +export var createElementaryCharge = /* #__PURE__ */unitFactory('elementaryCharge', '1.602176634e-19', 'C'); +export var createBohrMagneton = /* #__PURE__ */unitFactory('bohrMagneton', '9.2740100783e-24', 'J T^-1'); +export var createConductanceQuantum = /* #__PURE__ */unitFactory('conductanceQuantum', '7.748091729863649e-5', 'S'); +export var createInverseConductanceQuantum = /* #__PURE__ */unitFactory('inverseConductanceQuantum', '12906.403729652257', 'ohm'); +export var createMagneticFluxQuantum = /* #__PURE__ */unitFactory('magneticFluxQuantum', '2.0678338484619295e-15', 'Wb'); +export var createNuclearMagneton = /* #__PURE__ */unitFactory('nuclearMagneton', '5.0507837461e-27', 'J T^-1'); +export var createKlitzing = /* #__PURE__ */unitFactory('klitzing', '25812.807459304513', 'ohm'); +export var createJosephson = /* #__PURE__ */unitFactory('josephson', '4.835978484169836e14 Hz V', 'Hz V^-1'); // TODO: support for Hz needed + +// Atomic and nuclear constants +export var createBohrRadius = /* #__PURE__ */unitFactory('bohrRadius', '5.29177210903e-11', 'm'); +export var createClassicalElectronRadius = /* #__PURE__ */unitFactory('classicalElectronRadius', '2.8179403262e-15', 'm'); +export var createElectronMass = /* #__PURE__ */unitFactory('electronMass', '9.1093837015e-31', 'kg'); +export var createFermiCoupling = /* #__PURE__ */unitFactory('fermiCoupling', '1.1663787e-5', 'GeV^-2'); +export var createFineStructure = numberFactory('fineStructure', 7.2973525693e-3); +export var createHartreeEnergy = /* #__PURE__ */unitFactory('hartreeEnergy', '4.3597447222071e-18', 'J'); +export var createProtonMass = /* #__PURE__ */unitFactory('protonMass', '1.67262192369e-27', 'kg'); +export var createDeuteronMass = /* #__PURE__ */unitFactory('deuteronMass', '3.3435830926e-27', 'kg'); +export var createNeutronMass = /* #__PURE__ */unitFactory('neutronMass', '1.6749271613e-27', 'kg'); +export var createQuantumOfCirculation = /* #__PURE__ */unitFactory('quantumOfCirculation', '3.6369475516e-4', 'm^2 s^-1'); +export var createRydberg = /* #__PURE__ */unitFactory('rydberg', '10973731.568160', 'm^-1'); +export var createThomsonCrossSection = /* #__PURE__ */unitFactory('thomsonCrossSection', '6.6524587321e-29', 'm^2'); +export var createWeakMixingAngle = numberFactory('weakMixingAngle', 0.22290); +export var createEfimovFactor = numberFactory('efimovFactor', 22.7); + +// Physico-chemical constants +export var createAtomicMass = /* #__PURE__ */unitFactory('atomicMass', '1.66053906660e-27', 'kg'); +export var createAvogadro = /* #__PURE__ */unitFactory('avogadro', '6.02214076e23', 'mol^-1'); +export var createBoltzmann = /* #__PURE__ */unitFactory('boltzmann', '1.380649e-23', 'J K^-1'); +export var createFaraday = /* #__PURE__ */unitFactory('faraday', '96485.33212331001', 'C mol^-1'); +export var createFirstRadiation = /* #__PURE__ */unitFactory('firstRadiation', '3.7417718521927573e-16', 'W m^2'); +// TODO spectralRadiance = 1.1910429723971881e-16 W m^2 sr^-1 +export var createLoschmidt = /* #__PURE__ */unitFactory('loschmidt', '2.686780111798444e25', 'm^-3'); +export var createGasConstant = /* #__PURE__ */unitFactory('gasConstant', '8.31446261815324', 'J K^-1 mol^-1'); +export var createMolarPlanckConstant = /* #__PURE__ */unitFactory('molarPlanckConstant', '3.990312712893431e-10', 'J s mol^-1'); +export var createMolarVolume = /* #__PURE__ */unitFactory('molarVolume', '0.022413969545014137', 'm^3 mol^-1'); +export var createSackurTetrode = numberFactory('sackurTetrode', -1.16487052358); +export var createSecondRadiation = /* #__PURE__ */unitFactory('secondRadiation', '0.014387768775039337', 'm K'); +export var createStefanBoltzmann = /* #__PURE__ */unitFactory('stefanBoltzmann', '5.67037441918443e-8', 'W m^-2 K^-4'); +export var createWienDisplacement = /* #__PURE__ */unitFactory('wienDisplacement', '2.897771955e-3', 'm K'); + +// Adopted values +export var createMolarMass = /* #__PURE__ */unitFactory('molarMass', '0.99999999965e-3', 'kg mol^-1'); +export var createMolarMassC12 = /* #__PURE__ */unitFactory('molarMassC12', '11.9999999958e-3', 'kg mol^-1'); +export var createGravity = /* #__PURE__ */unitFactory('gravity', '9.80665', 'm s^-2'); +// atm is defined in Unit.js + +// Natural units +export var createPlanckLength = /* #__PURE__ */unitFactory('planckLength', '1.616255e-35', 'm'); +export var createPlanckMass = /* #__PURE__ */unitFactory('planckMass', '2.176435e-8', 'kg'); +export var createPlanckTime = /* #__PURE__ */unitFactory('planckTime', '5.391245e-44', 's'); +export var createPlanckCharge = /* #__PURE__ */unitFactory('planckCharge', '1.87554603778e-18', 'C'); +export var createPlanckTemperature = /* #__PURE__ */unitFactory('planckTemperature', '1.416785e+32', 'K'); + +// helper function to create a factory function which creates a physical constant, +// a Unit with either a number value or a BigNumber value depending on the configuration +function unitFactory(name, valueStr, unitStr) { + var dependencies = ['config', 'Unit', 'BigNumber']; + return factory(name, dependencies, _ref => { + var { + config, + Unit, + BigNumber + } = _ref; + // Note that we can parse into number or BigNumber. + // We do not parse into Fractions as that doesn't make sense: we would lose precision of the values + // Therefore we dont use Unit.parse() + var value = config.number === 'BigNumber' ? new BigNumber(valueStr) : parseFloat(valueStr); + var unit = new Unit(value, unitStr); + unit.fixPrefix = true; + return unit; + }); +} + +// helper function to create a factory function which creates a numeric constant, +// either a number or BigNumber depending on the configuration +function numberFactory(name, value) { + var dependencies = ['config', 'BigNumber']; + return factory(name, dependencies, _ref2 => { + var { + config, + BigNumber + } = _ref2; + return config.number === 'BigNumber' ? new BigNumber(value) : value; + }); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/array.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/array.js new file mode 100644 index 0000000..106f25f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/array.js @@ -0,0 +1,837 @@ +import _extends from "@babel/runtime/helpers/extends"; +import { isInteger } from './number.js'; +import { isNumber, isBigNumber, isArray, isString } from './is.js'; +import { format } from './string.js'; +import { DimensionError } from '../error/DimensionError.js'; +import { IndexError } from '../error/IndexError.js'; +import { deepStrictEqual } from './object.js'; + +/** + * Calculate the size of a multi dimensional array. + * This function checks the size of the first entry, it does not validate + * whether all dimensions match. (use function `validate` for that) + * @param {Array} x + * @Return {Number[]} size + */ +export function arraySize(x) { + var s = []; + while (Array.isArray(x)) { + s.push(x.length); + x = x[0]; + } + return s; +} + +/** + * Recursively validate whether each element in a multi dimensional array + * has a size corresponding to the provided size array. + * @param {Array} array Array to be validated + * @param {number[]} size Array with the size of each dimension + * @param {number} dim Current dimension + * @throws DimensionError + * @private + */ +function _validate(array, size, dim) { + var i; + var len = array.length; + if (len !== size[dim]) { + throw new DimensionError(len, size[dim]); + } + if (dim < size.length - 1) { + // recursively validate each child array + var dimNext = dim + 1; + for (i = 0; i < len; i++) { + var child = array[i]; + if (!Array.isArray(child)) { + throw new DimensionError(size.length - 1, size.length, '<'); + } + _validate(array[i], size, dimNext); + } + } else { + // last dimension. none of the childs may be an array + for (i = 0; i < len; i++) { + if (Array.isArray(array[i])) { + throw new DimensionError(size.length + 1, size.length, '>'); + } + } + } +} + +/** + * Validate whether each element in a multi dimensional array has + * a size corresponding to the provided size array. + * @param {Array} array Array to be validated + * @param {number[]} size Array with the size of each dimension + * @throws DimensionError + */ +export function validate(array, size) { + var isScalar = size.length === 0; + if (isScalar) { + // scalar + if (Array.isArray(array)) { + throw new DimensionError(array.length, 0); + } + } else { + // array + _validate(array, size, 0); + } +} + +/** + * Validate whether the source of the index matches the size of the Array + * @param {Array | Matrix} array Array to be validated + * @param {Index} index Index with the source information to validate + * @throws DimensionError + */ +export function validateIndexSourceSize(value, index) { + var valueSize = value.isMatrix ? value._size : arraySize(value); + var sourceSize = index._sourceSize; + // checks if the source size is not null and matches the valueSize + sourceSize.forEach((sourceDim, i) => { + if (sourceDim !== null && sourceDim !== valueSize[i]) { + throw new DimensionError(sourceDim, valueSize[i]); + } + }); +} + +/** + * Test whether index is an integer number with index >= 0 and index < length + * when length is provided + * @param {number} index Zero-based index + * @param {number} [length] Length of the array + */ +export function validateIndex(index, length) { + if (index !== undefined) { + if (!isNumber(index) || !isInteger(index)) { + throw new TypeError('Index must be an integer (value: ' + index + ')'); + } + if (index < 0 || typeof length === 'number' && index >= length) { + throw new IndexError(index, length); + } + } +} + +/** + * Test if and index has empty values + * @param {number} index Zero-based index + */ +export function isEmptyIndex(index) { + for (var i = 0; i < index._dimensions.length; ++i) { + var dimension = index._dimensions[i]; + if (dimension._data && isArray(dimension._data)) { + if (dimension._size[0] === 0) { + return true; + } + } else if (dimension.isRange) { + if (dimension.start === dimension.end) { + return true; + } + } else if (isString(dimension)) { + if (dimension.length === 0) { + return true; + } + } + } + return false; +} + +/** + * Resize a multi dimensional array. The resized array is returned. + * @param {Array | number} array Array to be resized + * @param {number[]} size Array with the size of each dimension + * @param {*} [defaultValue=0] Value to be filled in in new entries, + * zero by default. Specify for example `null`, + * to clearly see entries that are not explicitly + * set. + * @return {Array} array The resized array + */ +export function resize(array, size, defaultValue) { + // check the type of the arguments + if (!Array.isArray(size)) { + throw new TypeError('Array expected'); + } + if (size.length === 0) { + throw new Error('Resizing to scalar is not supported'); + } + + // check whether size contains positive integers + size.forEach(function (value) { + if (!isNumber(value) || !isInteger(value) || value < 0) { + throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + format(size) + ')'); + } + }); + + // convert number to an array + if (isNumber(array) || isBigNumber(array)) { + array = [array]; + } + + // recursively resize the array + var _defaultValue = defaultValue !== undefined ? defaultValue : 0; + _resize(array, size, 0, _defaultValue); + return array; +} + +/** + * Recursively resize a multi dimensional array + * @param {Array} array Array to be resized + * @param {number[]} size Array with the size of each dimension + * @param {number} dim Current dimension + * @param {*} [defaultValue] Value to be filled in in new entries, + * undefined by default. + * @private + */ +function _resize(array, size, dim, defaultValue) { + var i; + var elem; + var oldLen = array.length; + var newLen = size[dim]; + var minLen = Math.min(oldLen, newLen); + + // apply new length + array.length = newLen; + if (dim < size.length - 1) { + // non-last dimension + var dimNext = dim + 1; + + // resize existing child arrays + for (i = 0; i < minLen; i++) { + // resize child array + elem = array[i]; + if (!Array.isArray(elem)) { + elem = [elem]; // add a dimension + array[i] = elem; + } + _resize(elem, size, dimNext, defaultValue); + } + + // create new child arrays + for (i = minLen; i < newLen; i++) { + // get child array + elem = []; + array[i] = elem; + + // resize new child array + _resize(elem, size, dimNext, defaultValue); + } + } else { + // last dimension + + // remove dimensions of existing values + for (i = 0; i < minLen; i++) { + while (Array.isArray(array[i])) { + array[i] = array[i][0]; + } + } + + // fill new elements with the default value + for (i = minLen; i < newLen; i++) { + array[i] = defaultValue; + } + } +} + +/** + * Re-shape a multi dimensional array to fit the specified dimensions + * @param {Array} array Array to be reshaped + * @param {number[]} sizes List of sizes for each dimension + * @returns {Array} Array whose data has been formatted to fit the + * specified dimensions + * + * @throws {DimensionError} If the product of the new dimension sizes does + * not equal that of the old ones + */ +export function reshape(array, sizes) { + var flatArray = flatten(array); + var currentLength = flatArray.length; + if (!Array.isArray(array) || !Array.isArray(sizes)) { + throw new TypeError('Array expected'); + } + if (sizes.length === 0) { + throw new DimensionError(0, currentLength, '!='); + } + sizes = processSizesWildcard(sizes, currentLength); + var newLength = product(sizes); + if (currentLength !== newLength) { + throw new DimensionError(newLength, currentLength, '!='); + } + try { + return _reshape(flatArray, sizes); + } catch (e) { + if (e instanceof DimensionError) { + throw new DimensionError(newLength, currentLength, '!='); + } + throw e; + } +} + +/** + * Replaces the wildcard -1 in the sizes array. + * @param {number[]} sizes List of sizes for each dimension. At most on wildcard. + * @param {number} currentLength Number of elements in the array. + * @throws {Error} If more than one wildcard or unable to replace it. + * @returns {number[]} The sizes array with wildcard replaced. + */ +export function processSizesWildcard(sizes, currentLength) { + var newLength = product(sizes); + var processedSizes = sizes.slice(); + var WILDCARD = -1; + var wildCardIndex = sizes.indexOf(WILDCARD); + var isMoreThanOneWildcard = sizes.indexOf(WILDCARD, wildCardIndex + 1) >= 0; + if (isMoreThanOneWildcard) { + throw new Error('More than one wildcard in sizes'); + } + var hasWildcard = wildCardIndex >= 0; + var canReplaceWildcard = currentLength % newLength === 0; + if (hasWildcard) { + if (canReplaceWildcard) { + processedSizes[wildCardIndex] = -currentLength / newLength; + } else { + throw new Error('Could not replace wildcard, since ' + currentLength + ' is no multiple of ' + -newLength); + } + } + return processedSizes; +} + +/** + * Computes the product of all array elements. + * @param {number[]} array Array of factors + * @returns {number} Product of all elements + */ +function product(array) { + return array.reduce((prev, curr) => prev * curr, 1); +} + +/** + * Iteratively re-shape a multi dimensional array to fit the specified dimensions + * @param {Array} array Array to be reshaped + * @param {number[]} sizes List of sizes for each dimension + * @returns {Array} Array whose data has been formatted to fit the + * specified dimensions + */ + +function _reshape(array, sizes) { + // testing if there are enough elements for the requested shape + var tmpArray = array; + var tmpArray2; + // for each dimensions starting by the last one and ignoring the first one + for (var sizeIndex = sizes.length - 1; sizeIndex > 0; sizeIndex--) { + var size = sizes[sizeIndex]; + tmpArray2 = []; + + // aggregate the elements of the current tmpArray in elements of the requested size + var length = tmpArray.length / size; + for (var i = 0; i < length; i++) { + tmpArray2.push(tmpArray.slice(i * size, (i + 1) * size)); + } + // set it as the new tmpArray for the next loop turn or for return + tmpArray = tmpArray2; + } + return tmpArray; +} + +/** + * Squeeze a multi dimensional array + * @param {Array} array + * @param {Array} [size] + * @returns {Array} returns the array itself + */ +export function squeeze(array, size) { + var s = size || arraySize(array); + + // squeeze outer dimensions + while (Array.isArray(array) && array.length === 1) { + array = array[0]; + s.shift(); + } + + // find the first dimension to be squeezed + var dims = s.length; + while (s[dims - 1] === 1) { + dims--; + } + + // squeeze inner dimensions + if (dims < s.length) { + array = _squeeze(array, dims, 0); + s.length = dims; + } + return array; +} + +/** + * Recursively squeeze a multi dimensional array + * @param {Array} array + * @param {number} dims Required number of dimensions + * @param {number} dim Current dimension + * @returns {Array | *} Returns the squeezed array + * @private + */ +function _squeeze(array, dims, dim) { + var i, ii; + if (dim < dims) { + var next = dim + 1; + for (i = 0, ii = array.length; i < ii; i++) { + array[i] = _squeeze(array[i], dims, next); + } + } else { + while (Array.isArray(array)) { + array = array[0]; + } + } + return array; +} + +/** + * Unsqueeze a multi dimensional array: add dimensions when missing + * + * Paramter `size` will be mutated to match the new, unqueezed matrix size. + * + * @param {Array} array + * @param {number} dims Desired number of dimensions of the array + * @param {number} [outer] Number of outer dimensions to be added + * @param {Array} [size] Current size of array. + * @returns {Array} returns the array itself + * @private + */ +export function unsqueeze(array, dims, outer, size) { + var s = size || arraySize(array); + + // unsqueeze outer dimensions + if (outer) { + for (var i = 0; i < outer; i++) { + array = [array]; + s.unshift(1); + } + } + + // unsqueeze inner dimensions + array = _unsqueeze(array, dims, 0); + while (s.length < dims) { + s.push(1); + } + return array; +} + +/** + * Recursively unsqueeze a multi dimensional array + * @param {Array} array + * @param {number} dims Required number of dimensions + * @param {number} dim Current dimension + * @returns {Array | *} Returns the squeezed array + * @private + */ +function _unsqueeze(array, dims, dim) { + var i, ii; + if (Array.isArray(array)) { + var next = dim + 1; + for (i = 0, ii = array.length; i < ii; i++) { + array[i] = _unsqueeze(array[i], dims, next); + } + } else { + for (var d = dim; d < dims; d++) { + array = [array]; + } + } + return array; +} +/** + * Flatten a multi dimensional array, put all elements in a one dimensional + * array + * @param {Array} array A multi dimensional array + * @return {Array} The flattened array (1 dimensional) + */ +export function flatten(array) { + if (!Array.isArray(array)) { + // if not an array, return as is + return array; + } + var flat = []; + array.forEach(function callback(value) { + if (Array.isArray(value)) { + value.forEach(callback); // traverse through sub-arrays recursively + } else { + flat.push(value); + } + }); + return flat; +} + +/** + * A safe map + * @param {Array} array + * @param {function} callback + */ +export function map(array, callback) { + return Array.prototype.map.call(array, callback); +} + +/** + * A safe forEach + * @param {Array} array + * @param {function} callback + */ +export function forEach(array, callback) { + Array.prototype.forEach.call(array, callback); +} + +/** + * A safe filter + * @param {Array} array + * @param {function} callback + */ +export function filter(array, callback) { + if (arraySize(array).length !== 1) { + throw new Error('Only one dimensional matrices supported'); + } + return Array.prototype.filter.call(array, callback); +} + +/** + * Filter values in a callback given a regular expression + * @param {Array} array + * @param {RegExp} regexp + * @return {Array} Returns the filtered array + * @private + */ +export function filterRegExp(array, regexp) { + if (arraySize(array).length !== 1) { + throw new Error('Only one dimensional matrices supported'); + } + return Array.prototype.filter.call(array, entry => regexp.test(entry)); +} + +/** + * A safe join + * @param {Array} array + * @param {string} separator + */ +export function join(array, separator) { + return Array.prototype.join.call(array, separator); +} + +/** + * Assign a numeric identifier to every element of a sorted array + * @param {Array} a An array + * @return {Array} An array of objects containing the original value and its identifier + */ +export function identify(a) { + if (!Array.isArray(a)) { + throw new TypeError('Array input expected'); + } + if (a.length === 0) { + return a; + } + var b = []; + var count = 0; + b[0] = { + value: a[0], + identifier: 0 + }; + for (var i = 1; i < a.length; i++) { + if (a[i] === a[i - 1]) { + count++; + } else { + count = 0; + } + b.push({ + value: a[i], + identifier: count + }); + } + return b; +} + +/** + * Remove the numeric identifier from the elements + * @param {array} a An array + * @return {array} An array of values without identifiers + */ +export function generalize(a) { + if (!Array.isArray(a)) { + throw new TypeError('Array input expected'); + } + if (a.length === 0) { + return a; + } + var b = []; + for (var i = 0; i < a.length; i++) { + b.push(a[i].value); + } + return b; +} + +/** + * Check the datatype of a given object + * This is a low level implementation that should only be used by + * parent Matrix classes such as SparseMatrix or DenseMatrix + * This method does not validate Array Matrix shape + * @param {Array} array + * @param {function} typeOf Callback function to use to determine the type of a value + * @return {string} + */ +export function getArrayDataType(array, typeOf) { + var type; // to hold type info + var length = 0; // to hold length value to ensure it has consistent sizes + + for (var i = 0; i < array.length; i++) { + var item = array[i]; + var _isArray = Array.isArray(item); + + // Saving the target matrix row size + if (i === 0 && _isArray) { + length = item.length; + } + + // If the current item is an array but the length does not equal the targetVectorSize + if (_isArray && item.length !== length) { + return undefined; + } + var itemType = _isArray ? getArrayDataType(item, typeOf) // recurse into a nested array + : typeOf(item); + if (type === undefined) { + type = itemType; // first item + } else if (type !== itemType) { + return 'mixed'; + } else { + // we're good, everything has the same type so far + } + } + return type; +} + +/** + * Return the last item from an array + * @param {array} + * @returns {*} + */ +export function last(array) { + return array[array.length - 1]; +} + +/** + * Get all but the last element of array. + * @param {array} + * @returns {*} + */ +export function initial(array) { + return array.slice(0, array.length - 1); +} + +/** + * Recursively concatenate two matrices. + * The contents of the matrices is not cloned. + * @param {Array} a Multi dimensional array + * @param {Array} b Multi dimensional array + * @param {number} concatDim The dimension on which to concatenate (zero-based) + * @param {number} dim The current dim (zero-based) + * @return {Array} c The concatenated matrix + * @private + */ +function concatRecursive(a, b, concatDim, dim) { + if (dim < concatDim) { + // recurse into next dimension + if (a.length !== b.length) { + throw new DimensionError(a.length, b.length); + } + var c = []; + for (var i = 0; i < a.length; i++) { + c[i] = concatRecursive(a[i], b[i], concatDim, dim + 1); + } + return c; + } else { + // concatenate this dimension + return a.concat(b); + } +} + +/** + * Concatenates many arrays in the specified direction + * @param {...Array} arrays All the arrays to concatenate + * @param {number} concatDim The dimension on which to concatenate (zero-based) + * @returns +*/ +export function concat() { + var arrays = Array.prototype.slice.call(arguments, 0, -1); + var concatDim = Array.prototype.slice.call(arguments, -1); + if (arrays.length === 1) { + return arrays[0]; + } + if (arrays.length > 1) { + return arrays.slice(1).reduce(function (A, B) { + return concatRecursive(A, B, concatDim, 0); + }, arrays[0]); + } else { + throw new Error('Wrong number of arguments in function concat'); + } +} + +/** + * Receives two or more sizes and get's the broadcasted size for both. + * @param {...number[]} sizes Sizes to broadcast together + * @returns + */ +export function broadcastSizes() { + for (var _len = arguments.length, sizes = new Array(_len), _key = 0; _key < _len; _key++) { + sizes[_key] = arguments[_key]; + } + var dimensions = sizes.map(s => s.length); + var N = Math.max(...dimensions); + var sizeMax = new Array(N).fill(null); + // check for every size + for (var i = 0; i < sizes.length; i++) { + var size = sizes[i]; + var dim = dimensions[i]; + for (var j = 0; j < dim; j++) { + var n = N - dim + j; + if (size[j] > sizeMax[n]) { + sizeMax[n] = size[j]; + } + } + } + for (var _i = 0; _i < sizes.length; _i++) { + checkBroadcastingRules(sizes[_i], sizeMax); + } + return sizeMax; +} + +/** + * Checks if it's possible to broadcast a size to another size + * @param {number[]} size The size of the array to check + * @param {number[]} toSize The size of the array to validate if it can be broadcasted to + */ +export function checkBroadcastingRules(size, toSize) { + var N = toSize.length; + var dim = size.length; + for (var j = 0; j < dim; j++) { + var n = N - dim + j; + if (size[j] < toSize[n] && size[j] > 1 || size[j] > toSize[n]) { + throw new Error("shape missmatch: missmatch is found in arg with shape (".concat(size, ") not possible to broadcast dimension ").concat(dim, " with size ").concat(size[j], " to size ").concat(toSize[n])); + } + } +} + +/** + * Broadcasts a single array to a certain size + * @param {array} array Array to be broadcasted + * @param {number[]} toSize Size to broadcast the array + * @returns The broadcasted array + */ +export function broadcastTo(array, toSize) { + var Asize = arraySize(array); + if (deepStrictEqual(Asize, toSize)) { + return array; + } + checkBroadcastingRules(Asize, toSize); + var broadcastedSize = broadcastSizes(Asize, toSize); + var N = broadcastedSize.length; + var paddedSize = [...Array(N - Asize.length).fill(1), ...Asize]; + var A = clone(array); + // reshape A if needed to make it ready for concat + if (Asize.length < N) { + A = reshape(A, paddedSize); + Asize = arraySize(A); + } + + // stretches the array on each dimension to make it the same size as index + for (var dim = 0; dim < N; dim++) { + if (Asize[dim] < broadcastedSize[dim]) { + A = stretch(A, broadcastedSize[dim], dim); + Asize = arraySize(A); + } + } + return A; +} + +/** + * Broadcasts arrays and returns the broadcasted arrays in an array + * @param {...Array | any} arrays + * @returns + */ +export function broadcastArrays() { + for (var _len2 = arguments.length, arrays = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + arrays[_key2] = arguments[_key2]; + } + if (arrays.length === 0) { + throw new Error('Insuficient number of argumnets in function broadcastArrays'); + } + if (arrays.length === 1) { + return arrays[0]; + } + var sizes = arrays.map(function (array) { + return arraySize(array); + }); + var broadcastedSize = broadcastSizes(...sizes); + var broadcastedArrays = []; + arrays.forEach(function (array) { + broadcastedArrays.push(broadcastTo(array, broadcastedSize)); + }); + return broadcastedArrays; +} + +/** + * stretches a matrix up to a certain size in a certain dimension + * @param {Array} arrayToStretch + * @param {number[]} sizeToStretch + * @param {number} dimToStretch + * @returns + */ +export function stretch(arrayToStretch, sizeToStretch, dimToStretch) { + return concat(...Array(sizeToStretch).fill(arrayToStretch), dimToStretch); +} + +/** +* Retrieves a single element from an array given an index. +* +* @param {Array} array - The array from which to retrieve the value. +* @param {Array} idx - An array of indices specifying the position of the desired element in each dimension. +* @returns {*} - The value at the specified position in the array. +* +* @example +* const arr = [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]; +* const index = [1, 0, 1]; +* console.log(getValue(arr, index)); // 6 +*/ +export function get(array, index) { + if (!Array.isArray(array)) { + throw new Error('Array expected'); + } + var size = arraySize(array); + if (index.length !== size.length) { + throw new DimensionError(index.length, size.length); + } + for (var x = 0; x < index.length; x++) { + validateIndex(index[x], size[x]); + } + return index.reduce((acc, curr) => acc[curr], array); +} + +/** + * Recursive function to map a multi-dimensional array. + * + * @param {*} value - The current value being processed in the array. + * @param {Array} index - The index of the current value being processed in the array. + * @param {Array} array - The array being processed. + * @param {Function} callback - Function that produces the element of the new Array, taking three arguments: the value of the element, the index of the element, and the Array being processed. + * @returns {*} The new array with each element being the result of the callback function. + */ +export function recurse(value, index, array, callback) { + if (Array.isArray(value)) { + return value.map(function (child, i) { + // we create a copy of the index array and append the new index value + return recurse(child, index.concat(i), array, callback); + }); + } else { + // invoke the callback function with the right number of arguments + return callback(value, index, array); + } +} + +/** + * Deep clones a multidimensional array + * @param {Array} array + * @returns cloned array + */ +export function clone(array) { + return _extends([], array); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/bitwise.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/bitwise.js new file mode 100644 index 0000000..dbcc60c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/bitwise.js @@ -0,0 +1,399 @@ +/** + * Bitwise and for Bignumbers + * + * Special Cases: + * N & n = N + * n & 0 = 0 + * n & -1 = n + * n & n = n + * I & I = I + * -I & -I = -I + * I & -I = 0 + * I & n = n + * I & -n = I + * -I & n = 0 + * -I & -n = -I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` & `y`, is fully precise + * @private + */ +export function bitAndBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitAnd'); + } + var BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.eq(-1) || x.eq(y)) { + return x; + } + if (y.isZero() || x.eq(-1)) { + return y; + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !y.isFinite()) { + if (x.isNegative() === y.isNegative()) { + return x; + } + return new BigNumber(0); + } + if (!x.isFinite()) { + if (y.isNegative()) { + return x; + } + if (x.isNegative()) { + return new BigNumber(0); + } + return y; + } + if (!y.isFinite()) { + if (x.isNegative()) { + return y; + } + if (y.isNegative()) { + return new BigNumber(0); + } + return x; + } + } + return bitwise(x, y, function (a, b) { + return a & b; + }); +} + +/** + * Bitwise not + * @param {BigNumber} x + * @return {BigNumber} Result of ~`x`, fully precise + * + */ +export function bitNotBigNumber(x) { + if (x.isFinite() && !x.isInteger()) { + throw new Error('Integer expected in function bitNot'); + } + var BigNumber = x.constructor; + var prevPrec = BigNumber.precision; + BigNumber.config({ + precision: 1E9 + }); + var result = x.plus(new BigNumber(1)); + result.s = -result.s || null; + BigNumber.config({ + precision: prevPrec + }); + return result; +} + +/** + * Bitwise OR for BigNumbers + * + * Special Cases: + * N | n = N + * n | 0 = n + * n | -1 = -1 + * n | n = n + * I | I = I + * -I | -I = -I + * I | -n = -1 + * I | -I = -1 + * I | n = I + * -I | n = -I + * -I | -n = -n + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` | `y`, fully precise + */ +export function bitOrBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitOr'); + } + var BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + var negOne = new BigNumber(-1); + if (x.isZero() || y.eq(negOne) || x.eq(y)) { + return y; + } + if (y.isZero() || x.eq(negOne)) { + return x; + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !x.isNegative() && y.isNegative() || x.isNegative() && !y.isNegative() && !y.isFinite()) { + return negOne; + } + if (x.isNegative() && y.isNegative()) { + return x.isFinite() ? x : y; + } + return x.isFinite() ? y : x; + } + return bitwise(x, y, function (a, b) { + return a | b; + }); +} + +/** + * Applies bitwise function to numbers + * @param {BigNumber} x + * @param {BigNumber} y + * @param {function (a, b)} func + * @return {BigNumber} + */ +export function bitwise(x, y, func) { + var BigNumber = x.constructor; + var xBits, yBits; + var xSign = +(x.s < 0); + var ySign = +(y.s < 0); + if (xSign) { + xBits = decCoefficientToBinaryString(bitNotBigNumber(x)); + for (var i = 0; i < xBits.length; ++i) { + xBits[i] ^= 1; + } + } else { + xBits = decCoefficientToBinaryString(x); + } + if (ySign) { + yBits = decCoefficientToBinaryString(bitNotBigNumber(y)); + for (var _i = 0; _i < yBits.length; ++_i) { + yBits[_i] ^= 1; + } + } else { + yBits = decCoefficientToBinaryString(y); + } + var minBits, maxBits, minSign; + if (xBits.length <= yBits.length) { + minBits = xBits; + maxBits = yBits; + minSign = xSign; + } else { + minBits = yBits; + maxBits = xBits; + minSign = ySign; + } + var shortLen = minBits.length; + var longLen = maxBits.length; + var expFuncVal = func(xSign, ySign) ^ 1; + var outVal = new BigNumber(expFuncVal ^ 1); + var twoPower = new BigNumber(1); + var two = new BigNumber(2); + var prevPrec = BigNumber.precision; + BigNumber.config({ + precision: 1E9 + }); + while (shortLen > 0) { + if (func(minBits[--shortLen], maxBits[--longLen]) === expFuncVal) { + outVal = outVal.plus(twoPower); + } + twoPower = twoPower.times(two); + } + while (longLen > 0) { + if (func(minSign, maxBits[--longLen]) === expFuncVal) { + outVal = outVal.plus(twoPower); + } + twoPower = twoPower.times(two); + } + BigNumber.config({ + precision: prevPrec + }); + if (expFuncVal === 0) { + outVal.s = -outVal.s; + } + return outVal; +} + +/* Extracted from decimal.js, and edited to specialize. */ +function decCoefficientToBinaryString(x) { + // Convert to string + var a = x.d; // array with digits + var r = a[0] + ''; + for (var i = 1; i < a.length; ++i) { + var s = a[i] + ''; + for (var z = 7 - s.length; z--;) { + s = '0' + s; + } + r += s; + } + var j = r.length; + while (r.charAt(j) === '0') { + j--; + } + var xe = x.e; + var str = r.slice(0, j + 1 || 1); + var strL = str.length; + if (xe > 0) { + if (++xe > strL) { + // Append zeros. + xe -= strL; + while (xe--) { + str += '0'; + } + } else if (xe < strL) { + str = str.slice(0, xe) + '.' + str.slice(xe); + } + } + + // Convert from base 10 (decimal) to base 2 + var arr = [0]; + for (var _i2 = 0; _i2 < str.length;) { + var arrL = arr.length; + while (arrL--) { + arr[arrL] *= 10; + } + arr[0] += parseInt(str.charAt(_i2++)); // convert to int + for (var _j = 0; _j < arr.length; ++_j) { + if (arr[_j] > 1) { + if (arr[_j + 1] === null || arr[_j + 1] === undefined) { + arr[_j + 1] = 0; + } + arr[_j + 1] += arr[_j] >> 1; + arr[_j] &= 1; + } + } + } + return arr.reverse(); +} + +/** + * Bitwise XOR for BigNumbers + * + * Special Cases: + * N ^ n = N + * n ^ 0 = n + * n ^ n = 0 + * n ^ -1 = ~n + * I ^ n = I + * I ^ -n = -I + * I ^ -I = -1 + * -I ^ n = -I + * -I ^ -n = I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` ^ `y`, fully precise + * + */ +export function bitXor(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function bitXor'); + } + var BigNumber = x.constructor; + if (x.isNaN() || y.isNaN()) { + return new BigNumber(NaN); + } + if (x.isZero()) { + return y; + } + if (y.isZero()) { + return x; + } + if (x.eq(y)) { + return new BigNumber(0); + } + var negOne = new BigNumber(-1); + if (x.eq(negOne)) { + return bitNotBigNumber(y); + } + if (y.eq(negOne)) { + return bitNotBigNumber(x); + } + if (!x.isFinite() || !y.isFinite()) { + if (!x.isFinite() && !y.isFinite()) { + return negOne; + } + return new BigNumber(x.isNegative() === y.isNegative() ? Infinity : -Infinity); + } + return bitwise(x, y, function (a, b) { + return a ^ b; + }); +} + +/** + * Bitwise left shift + * + * Special Cases: + * n << -n = N + * n << N = N + * N << n = N + * n << 0 = n + * 0 << n = 0 + * I << I = N + * I << n = I + * n << I = I + * + * @param {BigNumber} x + * @param {BigNumber} y + * @return {BigNumber} Result of `x` << `y` + * + */ +export function leftShiftBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function leftShift'); + } + var BigNumber = x.constructor; + if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.isZero()) { + return x; + } + if (!x.isFinite() && !y.isFinite()) { + return new BigNumber(NaN); + } + + // Math.pow(2, y) is fully precise for y < 55, and fast + if (y.lt(55)) { + return x.times(Math.pow(2, y.toNumber()) + ''); + } + return x.times(new BigNumber(2).pow(y)); +} + +/* + * Special Cases: + * n >> -n = N + * n >> N = N + * N >> n = N + * I >> I = N + * n >> 0 = n + * I >> n = I + * -I >> n = -I + * -I >> I = -I + * n >> I = I + * -n >> I = -1 + * 0 >> n = 0 + * + * @param {BigNumber} value + * @param {BigNumber} value + * @return {BigNumber} Result of `x` >> `y` + * + */ +export function rightArithShiftBigNumber(x, y) { + if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) { + throw new Error('Integers expected in function rightArithShift'); + } + var BigNumber = x.constructor; + if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) { + return new BigNumber(NaN); + } + if (x.isZero() || y.isZero()) { + return x; + } + if (!y.isFinite()) { + if (x.isNegative()) { + return new BigNumber(-1); + } + if (!x.isFinite()) { + return new BigNumber(NaN); + } + return new BigNumber(0); + } + + // Math.pow(2, y) is fully precise for y < 55, and fast + if (y.lt(55)) { + return x.div(Math.pow(2, y.toNumber()) + '').floor(); + } + return x.div(new BigNumber(2).pow(y)).floor(); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/constants.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/constants.js new file mode 100644 index 0000000..aa69b29 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/constants.js @@ -0,0 +1,57 @@ +import { memoize } from '../function.js'; + +/** + * Calculate BigNumber e + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns e + */ +export var createBigNumberE = memoize(function (BigNumber) { + return new BigNumber(1).exp(); +}, { + hasher +}); + +/** + * Calculate BigNumber golden ratio, phi = (1+sqrt(5))/2 + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns phi + */ +export var createBigNumberPhi = memoize(function (BigNumber) { + return new BigNumber(1).plus(new BigNumber(5).sqrt()).div(2); +}, { + hasher +}); + +/** + * Calculate BigNumber pi. + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns pi + */ +export var createBigNumberPi = memoize(function (BigNumber) { + return BigNumber.acos(-1); +}, { + hasher +}); + +/** + * Calculate BigNumber tau, tau = 2 * pi + * @param {function} BigNumber BigNumber constructor + * @returns {BigNumber} Returns tau + */ +export var createBigNumberTau = memoize(function (BigNumber) { + return createBigNumberPi(BigNumber).times(2); +}, { + hasher +}); + +/** + * Create a hash for a BigNumber constructor function. The created has is + * the configured precision + * @param {Array} args Supposed to contain a single entry with + * a BigNumber constructor + * @return {number} precision + * @private + */ +function hasher(args) { + return args[0].precision; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/formatter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/formatter.js new file mode 100644 index 0000000..d7d3adf --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/formatter.js @@ -0,0 +1,243 @@ +import { isBigNumber, isNumber } from '../is.js'; +import { isInteger, normalizeFormatOptions } from '../number.js'; + +/** + * Formats a BigNumber in a given base + * @param {BigNumber} n + * @param {number} base + * @param {number} size + * @returns {string} + */ +function formatBigNumberToBase(n, base, size) { + var BigNumberCtor = n.constructor; + var big2 = new BigNumberCtor(2); + var suffix = ''; + if (size) { + if (size < 1) { + throw new Error('size must be in greater than 0'); + } + if (!isInteger(size)) { + throw new Error('size must be an integer'); + } + if (n.greaterThan(big2.pow(size - 1).sub(1)) || n.lessThan(big2.pow(size - 1).mul(-1))) { + throw new Error("Value must be in range [-2^".concat(size - 1, ", 2^").concat(size - 1, "-1]")); + } + if (!n.isInteger()) { + throw new Error('Value must be an integer'); + } + if (n.lessThan(0)) { + n = n.add(big2.pow(size)); + } + suffix = "i".concat(size); + } + switch (base) { + case 2: + return "".concat(n.toBinary()).concat(suffix); + case 8: + return "".concat(n.toOctal()).concat(suffix); + case 16: + return "".concat(n.toHexadecimal()).concat(suffix); + default: + throw new Error("Base ".concat(base, " not supported ")); + } +} + +/** + * Convert a BigNumber to a formatted string representation. + * + * Syntax: + * + * format(value) + * format(value, options) + * format(value, precision) + * format(value, fn) + * + * Where: + * + * {number} value The value to be formatted + * {Object} options An object with formatting options. Available options: + * {string} notation + * Number notation. Choose from: + * 'fixed' Always use regular number notation. + * For example '123.40' and '14000000' + * 'exponential' Always use exponential notation. + * For example '1.234e+2' and '1.4e+7' + * 'auto' (default) Regular number notation for numbers + * having an absolute value between + * `lower` and `upper` bounds, and uses + * exponential notation elsewhere. + * Lower bound is included, upper bound + * is excluded. + * For example '123.4' and '1.4e7'. + * 'bin', 'oct, or + * 'hex' Format the number using binary, octal, + * or hexadecimal notation. + * For example '0b1101' and '0x10fe'. + * {number} wordSize The word size in bits to use for formatting + * in binary, octal, or hexadecimal notation. + * To be used only with 'bin', 'oct', or 'hex' + * values for 'notation' option. When this option + * is defined the value is formatted as a signed + * twos complement integer of the given word size + * and the size suffix is appended to the output. + * For example + * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'. + * Default value is undefined. + * {number} precision A number between 0 and 16 to round + * the digits of the number. + * In case of notations 'exponential', + * 'engineering', and 'auto', + * `precision` defines the total + * number of significant digits returned. + * In case of notation 'fixed', + * `precision` defines the number of + * significant digits after the decimal + * point. + * `precision` is undefined by default. + * {number} lowerExp Exponent determining the lower boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `-3`. + * {number} upperExp Exponent determining the upper boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `5`. + * {Function} fn A custom formatting function. Can be used to override the + * built-in notations. Function `fn` is called with `value` as + * parameter and must return a string. Is useful for example to + * format all values inside a matrix in a particular way. + * + * Examples: + * + * format(6.4) // '6.4' + * format(1240000) // '1.24e6' + * format(1/3) // '0.3333333333333333' + * format(1/3, 3) // '0.333' + * format(21385, 2) // '21000' + * format(12e8, {notation: 'fixed'}) // returns '1200000000' + * format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000' + * format(52.8, {notation: 'exponential'}) // returns '5.28e+1' + * format(12400, {notation: 'engineering'}) // returns '12.400e+3' + * + * @param {BigNumber} value + * @param {Object | Function | number | BigNumber} [options] + * @return {string} str The formatted value + */ +export function format(value, options) { + if (typeof options === 'function') { + // handle format(value, fn) + return options(value); + } + + // handle special cases + if (!value.isFinite()) { + return value.isNaN() ? 'NaN' : value.gt(0) ? 'Infinity' : '-Infinity'; + } + var { + notation, + precision, + wordSize + } = normalizeFormatOptions(options); + + // handle the various notations + switch (notation) { + case 'fixed': + return toFixed(value, precision); + case 'exponential': + return toExponential(value, precision); + case 'engineering': + return toEngineering(value, precision); + case 'bin': + return formatBigNumberToBase(value, 2, wordSize); + case 'oct': + return formatBigNumberToBase(value, 8, wordSize); + case 'hex': + return formatBigNumberToBase(value, 16, wordSize); + case 'auto': + { + // determine lower and upper bound for exponential notation. + // TODO: implement support for upper and lower to be BigNumbers themselves + var lowerExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.lowerExp, -3); + var upperExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.upperExp, 5); + + // handle special case zero + if (value.isZero()) return '0'; + + // determine whether or not to output exponential notation + var str; + var rounded = value.toSignificantDigits(precision); + var exp = rounded.e; + if (exp >= lowerExp && exp < upperExp) { + // normal number notation + str = rounded.toFixed(); + } else { + // exponential notation + str = toExponential(value, precision); + } + + // remove trailing zeros after the decimal point + return str.replace(/((\.\d*?)(0+))($|e)/, function () { + var digits = arguments[2]; + var e = arguments[4]; + return digits !== '.' ? digits + e : e; + }); + } + default: + throw new Error('Unknown notation "' + notation + '". ' + 'Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.'); + } +} + +/** + * Format a BigNumber in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3' + * @param {BigNumber} value + * @param {number} [precision] Optional number of significant figures to return. + */ +export function toEngineering(value, precision) { + // find nearest lower multiple of 3 for exponent + var e = value.e; + var newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3; + + // find difference in exponents, and calculate the value without exponent + var valueWithoutExp = value.mul(Math.pow(10, -newExp)); + var valueStr = valueWithoutExp.toPrecision(precision); + if (valueStr.includes('e')) { + var BigNumber = value.constructor; + valueStr = new BigNumber(valueStr).toFixed(); + } + return valueStr + 'e' + (e >= 0 ? '+' : '') + newExp.toString(); +} + +/** + * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3' + * @param {BigNumber} value + * @param {number} [precision] Number of digits in formatted output. + * If not provided, the maximum available digits + * is used. + * @returns {string} str + */ +export function toExponential(value, precision) { + if (precision !== undefined) { + return value.toExponential(precision - 1); // Note the offset of one + } else { + return value.toExponential(); + } +} + +/** + * Format a number with fixed notation. + * @param {BigNumber} value + * @param {number} [precision=undefined] Optional number of decimals after the + * decimal point. Undefined by default. + */ +export function toFixed(value, precision) { + return value.toFixed(precision); +} +function _toNumberOrDefault(value, defaultValue) { + if (isNumber(value)) { + return value; + } else if (isBigNumber(value)) { + return value.toNumber(); + } else { + return defaultValue; + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/nearlyEqual.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/nearlyEqual.js new file mode 100644 index 0000000..8e4a455 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/bignumber/nearlyEqual.js @@ -0,0 +1,39 @@ +/** + * Compares two BigNumbers. + * @param {BigNumber} a - First value to compare + * @param {BigNumber} b - Second value to compare + * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0. + * @param {number} [absTol=0] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0. + * @returns {boolean} whether the two numbers are nearly equal + * @throws {Error} If `relTol` is less than or equal to 0. + * @throws {Error} If `absTol` is less than 0. + * + * @example + * nearlyEqual(1.000000001, 1.0, 1e-9); // true + * nearlyEqual(1.000000002, 1.0, 0); // false + * nearlyEqual(1.0, 1.009, undefined, 0.02); // true + * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true + */ +export function nearlyEqual(a, b) { + var relTol = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1e-9; + var absTol = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; + if (relTol <= 0) { + throw new Error('Relative tolerance must be greater than 0'); + } + if (absTol < 0) { + throw new Error('Absolute tolerance must be at least 0'); + } + // NaN + if (a.isNaN() || b.isNaN()) { + return false; + } + if (!a.isFinite() || !b.isFinite()) { + return a.eq(b); + } + // use "==" operator, handles infinities + if (a.eq(b)) { + return true; + } + // abs(a-b) <= max(relTol * max(abs(a), abs(b)), absTol) + return a.minus(b).abs().lte(a.constructor.max(a.constructor.max(a.abs(), b.abs()).mul(relTol), absTol)); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/collection.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/collection.js new file mode 100644 index 0000000..040c8c3 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/collection.js @@ -0,0 +1,177 @@ +import { isCollection, isMatrix } from './is.js'; +import { IndexError } from '../error/IndexError.js'; +import { arraySize } from './array.js'; +import { _switch } from './switch.js'; + +/** + * Test whether an array contains collections + * @param {Array} array + * @returns {boolean} Returns true when the array contains one or multiple + * collections (Arrays or Matrices). Returns false otherwise. + */ +export function containsCollections(array) { + for (var i = 0; i < array.length; i++) { + if (isCollection(array[i])) { + return true; + } + } + return false; +} + +/** + * Recursively loop over all elements in a given multi dimensional array + * and invoke the callback on each of the elements. + * @param {Array | Matrix} array + * @param {Function} callback The callback method is invoked with one + * parameter: the current element in the array + */ +export function deepForEach(array, callback) { + if (isMatrix(array)) { + array = array.valueOf(); + } + for (var i = 0, ii = array.length; i < ii; i++) { + var value = array[i]; + if (Array.isArray(value)) { + deepForEach(value, callback); + } else { + callback(value); + } + } +} + +/** + * Execute the callback function element wise for each element in array and any + * nested array + * Returns an array with the results + * @param {Array | Matrix} array + * @param {Function} callback The callback is called with two parameters: + * value1 and value2, which contain the current + * element of both arrays. + * @param {boolean} [skipZeros] Invoke callback function for non-zero values only. + * + * @return {Array | Matrix} res + */ +export function deepMap(array, callback, skipZeros) { + if (array && typeof array.map === 'function') { + // TODO: replace array.map with a for loop to improve performance + return array.map(function (x) { + return deepMap(x, callback, skipZeros); + }); + } else { + return callback(array); + } +} + +/** + * Reduce a given matrix or array to a new matrix or + * array with one less dimension, applying the given + * callback in the selected dimension. + * @param {Array | Matrix} mat + * @param {number} dim + * @param {Function} callback + * @return {Array | Matrix} res + */ +export function reduce(mat, dim, callback) { + var size = Array.isArray(mat) ? arraySize(mat) : mat.size(); + if (dim < 0 || dim >= size.length) { + // TODO: would be more clear when throwing a DimensionError here + throw new IndexError(dim, size.length); + } + if (isMatrix(mat)) { + return mat.create(_reduce(mat.valueOf(), dim, callback), mat.datatype()); + } else { + return _reduce(mat, dim, callback); + } +} + +/** + * Recursively reduce a matrix + * @param {Array} mat + * @param {number} dim + * @param {Function} callback + * @returns {Array} ret + * @private + */ +function _reduce(mat, dim, callback) { + var i, ret, val, tran; + if (dim <= 0) { + if (!Array.isArray(mat[0])) { + val = mat[0]; + for (i = 1; i < mat.length; i++) { + val = callback(val, mat[i]); + } + return val; + } else { + tran = _switch(mat); + ret = []; + for (i = 0; i < tran.length; i++) { + ret[i] = _reduce(tran[i], dim - 1, callback); + } + return ret; + } + } else { + ret = []; + for (i = 0; i < mat.length; i++) { + ret[i] = _reduce(mat[i], dim - 1, callback); + } + return ret; + } +} + +// TODO: document function scatter +export function scatter(a, j, w, x, u, mark, cindex, f, inverse, update, value) { + // a arrays + var avalues = a._values; + var aindex = a._index; + var aptr = a._ptr; + + // vars + var k, k0, k1, i; + + // check we need to process values (pattern matrix) + if (x) { + // values in j + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check value exists in current j + if (w[i] !== mark) { + // i is new entry in j + w[i] = mark; + // add i to pattern of C + cindex.push(i); + // x(i) = A, check we need to call function this time + if (update) { + // copy value to workspace calling callback function + x[i] = inverse ? f(avalues[k], value) : f(value, avalues[k]); + // function was called on current row + u[i] = mark; + } else { + // copy value to workspace + x[i] = avalues[k]; + } + } else { + // i exists in C already + x[i] = inverse ? f(avalues[k], x[i]) : f(x[i], avalues[k]); + // function was called on current row + u[i] = mark; + } + } + } else { + // values in j + for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) { + // row + i = aindex[k]; + // check value exists in current j + if (w[i] !== mark) { + // i is new entry in j + w[i] = mark; + // add i to pattern of C + cindex.push(i); + } else { + // indicate function was called on current row + u[i] = mark; + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/complex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/complex.js new file mode 100644 index 0000000..301c521 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/complex.js @@ -0,0 +1,14 @@ +import { nearlyEqual } from './number.js'; + +/** + * Test whether two complex values are equal provided a given relTol and absTol. + * Does not use or change the global Complex.EPSILON setting + * @param {Complex} x - The first complex number for comparison. + * @param {Complex} y - The second complex number for comparison. + * @param {number} relTol - The relative tolerance for comparison. + * @param {number} absTol - The absolute tolerance for comparison. + * @returns {boolean} - Returns true if the two complex numbers are equal within the given tolerances, otherwise returns false. + */ +export function complexEquals(x, y, relTol, absTol) { + return nearlyEqual(x.re, y.re, relTol, absTol) && nearlyEqual(x.im, y.im, relTol, absTol); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/customs.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/customs.js new file mode 100644 index 0000000..40d18c6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/customs.js @@ -0,0 +1,147 @@ +import { hasOwnProperty } from './object.js'; + +/** + * Get a property of a plain object + * Throws an error in case the object is not a plain object or the + * property is not defined on the object itself + * @param {Object} object + * @param {string} prop + * @return {*} Returns the property value when safe + */ +function getSafeProperty(object, prop) { + // only allow getting safe properties of a plain object + if (isSafeProperty(object, prop)) { + return object[prop]; + } + if (typeof object[prop] === 'function' && isSafeMethod(object, prop)) { + throw new Error('Cannot access method "' + prop + '" as a property'); + } + throw new Error('No access to property "' + prop + '"'); +} + +/** + * Set a property on a plain object. + * Throws an error in case the object is not a plain object or the + * property would override an inherited property like .constructor or .toString + * @param {Object} object + * @param {string} prop + * @param {*} value + * @return {*} Returns the value + */ +// TODO: merge this function into access.js? +function setSafeProperty(object, prop, value) { + // only allow setting safe properties of a plain object + if (isSafeProperty(object, prop)) { + object[prop] = value; + return value; + } + throw new Error('No access to property "' + prop + '"'); +} + +/** + * Test whether a property is safe to use on an object or Array. + * For example .toString and .constructor are not safe + * @param {Object | Array} object + * @param {string} prop + * @return {boolean} Returns true when safe + */ +function isSafeProperty(object, prop) { + if (!isPlainObject(object) && !Array.isArray(object)) { + return false; + } + // SAFE: whitelisted + // e.g length + if (hasOwnProperty(safeNativeProperties, prop)) { + return true; + } + // UNSAFE: inherited from Object prototype + // e.g constructor + if (prop in Object.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Object.prototype is a root object + return false; + } + // UNSAFE: inherited from Function prototype + // e.g call, apply + if (prop in Function.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Function.prototype is a root object + return false; + } + return true; +} + +/** + * Validate whether a method is safe. + * Throws an error when that's not the case. + * @param {Object} object + * @param {string} method + * @return {function} Returns the method when valid + */ +function getSafeMethod(object, method) { + if (!isSafeMethod(object, method)) { + throw new Error('No access to method "' + method + '"'); + } + return object[method]; +} + +/** + * Check whether a method is safe. + * Throws an error when that's not the case (for example for `constructor`). + * @param {Object} object + * @param {string} method + * @return {boolean} Returns true when safe, false otherwise + */ +function isSafeMethod(object, method) { + if (object === null || object === undefined || typeof object[method] !== 'function') { + return false; + } + // UNSAFE: ghosted + // e.g overridden toString + // Note that IE10 doesn't support __proto__ and we can't do this check there. + if (hasOwnProperty(object, method) && Object.getPrototypeOf && method in Object.getPrototypeOf(object)) { + return false; + } + // SAFE: whitelisted + // e.g toString + if (hasOwnProperty(safeNativeMethods, method)) { + return true; + } + // UNSAFE: inherited from Object prototype + // e.g constructor + if (method in Object.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Object.prototype is a root object + return false; + } + // UNSAFE: inherited from Function prototype + // e.g call, apply + if (method in Function.prototype) { + // 'in' is used instead of hasOwnProperty for nodejs v0.10 + // which is inconsistent on root prototypes. It is safe + // here because Function.prototype is a root object + return false; + } + return true; +} +function isPlainObject(object) { + return typeof object === 'object' && object && object.constructor === Object; +} +var safeNativeProperties = { + length: true, + name: true +}; +var safeNativeMethods = { + toString: true, + valueOf: true, + toLocaleString: true +}; +export { getSafeProperty }; +export { setSafeProperty }; +export { isSafeProperty }; +export { getSafeMethod }; +export { isSafeMethod }; +export { isPlainObject }; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/emitter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/emitter.js new file mode 100644 index 0000000..d9c1fca --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/emitter.js @@ -0,0 +1,18 @@ +import Emitter from 'tiny-emitter'; + +/** + * Extend given object with emitter functions `on`, `off`, `once`, `emit` + * @param {Object} obj + * @return {Object} obj + */ +export function mixin(obj) { + // create event emitter + var emitter = new Emitter(); + + // bind methods to obj (we don't want to expose the emitter.e Array...) + obj.on = emitter.on.bind(emitter); + obj.off = emitter.off.bind(emitter); + obj.once = emitter.once.bind(emitter); + obj.emit = emitter.emit.bind(emitter); + return obj; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/factory.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/factory.js new file mode 100644 index 0000000..0e0a25c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/factory.js @@ -0,0 +1,126 @@ +import { pickShallow } from './object.js'; + +/** + * Create a factory function, which can be used to inject dependencies. + * + * The created functions are memoized, a consecutive call of the factory + * with the exact same inputs will return the same function instance. + * The memoized cache is exposed on `factory.cache` and can be cleared + * if needed. + * + * Example: + * + * const name = 'log' + * const dependencies = ['config', 'typed', 'divideScalar', 'Complex'] + * + * export const createLog = factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => { + * // ... create the function log here and return it + * } + * + * @param {string} name Name of the function to be created + * @param {string[]} dependencies The names of all required dependencies + * @param {function} create Callback function called with an object with all dependencies + * @param {Object} [meta] Optional object with meta information that will be attached + * to the created factory function as property `meta`. + * @returns {function} + */ +export function factory(name, dependencies, create, meta) { + function assertAndCreate(scope) { + // we only pass the requested dependencies to the factory function + // to prevent functions to rely on dependencies that are not explicitly + // requested. + var deps = pickShallow(scope, dependencies.map(stripOptionalNotation)); + assertDependencies(name, dependencies, scope); + return create(deps); + } + assertAndCreate.isFactory = true; + assertAndCreate.fn = name; + assertAndCreate.dependencies = dependencies.slice().sort(); + if (meta) { + assertAndCreate.meta = meta; + } + return assertAndCreate; +} + +/** + * Sort all factories such that when loading in order, the dependencies are resolved. + * + * @param {Array} factories + * @returns {Array} Returns a new array with the sorted factories. + */ +export function sortFactories(factories) { + var factoriesByName = {}; + factories.forEach(factory => { + factoriesByName[factory.fn] = factory; + }); + function containsDependency(factory, dependency) { + // TODO: detect circular references + if (isFactory(factory)) { + if (factory.dependencies.includes(dependency.fn || dependency.name)) { + return true; + } + if (factory.dependencies.some(d => containsDependency(factoriesByName[d], dependency))) { + return true; + } + } + return false; + } + var sorted = []; + function addFactory(factory) { + var index = 0; + while (index < sorted.length && !containsDependency(sorted[index], factory)) { + index++; + } + sorted.splice(index, 0, factory); + } + + // sort regular factory functions + factories.filter(isFactory).forEach(addFactory); + + // sort legacy factory functions AFTER the regular factory functions + factories.filter(factory => !isFactory(factory)).forEach(addFactory); + return sorted; +} + +// TODO: comment or cleanup if unused in the end +export function create(factories) { + var scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + sortFactories(factories).forEach(factory => factory(scope)); + return scope; +} + +/** + * Test whether an object is a factory. This is the case when it has + * properties name, dependencies, and a function create. + * @param {*} obj + * @returns {boolean} + */ +export function isFactory(obj) { + return typeof obj === 'function' && typeof obj.fn === 'string' && Array.isArray(obj.dependencies); +} + +/** + * Assert that all dependencies of a list with dependencies are available in the provided scope. + * + * Will throw an exception when there are dependencies missing. + * + * @param {string} name Name for the function to be created. Used to generate a useful error message + * @param {string[]} dependencies + * @param {Object} scope + */ +export function assertDependencies(name, dependencies, scope) { + var allDefined = dependencies.filter(dependency => !isOptionalDependency(dependency)) // filter optionals + .every(dependency => scope[dependency] !== undefined); + if (!allDefined) { + var missingDependencies = dependencies.filter(dependency => scope[dependency] === undefined); + + // TODO: create a custom error class for this, a MathjsError or something like that + throw new Error("Cannot create function \"".concat(name, "\", ") + "some dependencies are missing: ".concat(missingDependencies.map(d => "\"".concat(d, "\"")).join(', '), ".")); + } +} +export function isOptionalDependency(dependency) { + return dependency && dependency[0] === '?'; +} +export function stripOptionalNotation(dependency) { + return dependency && dependency[0] === '?' ? dependency.slice(1) : dependency; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/function.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/function.js new file mode 100644 index 0000000..c217b49 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/function.js @@ -0,0 +1,86 @@ +// function utils + +import { lruQueue } from './lruQueue.js'; + +/** + * Memoize a given function by caching the computed result. + * The cache of a memoized function can be cleared by deleting the `cache` + * property of the function. + * + * @param {function} fn The function to be memoized. + * Must be a pure function. + * @param {Object} [options] + * @param {function(args: Array): string} [options.hasher] + * A custom hash builder. Is JSON.stringify by default. + * @param {number | undefined} [options.limit] + * Maximum number of values that may be cached. Undefined indicates + * unlimited (default) + * @return {function} Returns the memoized function + */ +export function memoize(fn) { + var { + hasher, + limit + } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + limit = limit == null ? Number.POSITIVE_INFINITY : limit; + hasher = hasher == null ? JSON.stringify : hasher; + return function memoize() { + if (typeof memoize.cache !== 'object') { + memoize.cache = { + values: new Map(), + lru: lruQueue(limit || Number.POSITIVE_INFINITY) + }; + } + var args = []; + for (var i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; + } + var hash = hasher(args); + if (memoize.cache.values.has(hash)) { + memoize.cache.lru.hit(hash); + return memoize.cache.values.get(hash); + } + var newVal = fn.apply(fn, args); + memoize.cache.values.set(hash, newVal); + memoize.cache.values.delete(memoize.cache.lru.hit(hash)); + return newVal; + }; +} + +/** + * Memoize a given function by caching all results and the arguments, + * and comparing against the arguments of previous results before + * executing again. + * This is less performant than `memoize` which calculates a hash, + * which is very fast to compare. Use `memoizeCompare` only when it is + * not possible to create a unique serializable hash from the function + * arguments. + * The isEqual function must compare two sets of arguments + * and return true when equal (can be a deep equality check for example). + * @param {function} fn + * @param {function(a: *, b: *) : boolean} isEqual + * @returns {function} + */ +export function memoizeCompare(fn, isEqual) { + var memoize = function memoize() { + var args = []; + for (var i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; + } + for (var c = 0; c < memoize.cache.length; c++) { + var cached = memoize.cache[c]; + if (isEqual(args, cached.args)) { + // TODO: move this cache entry to the top so recently used entries move up? + return cached.res; + } + } + var res = fn.apply(fn, args); + memoize.cache.unshift({ + args, + res + }); + return res; + }; + memoize.cache = []; + return memoize; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/is.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/is.js new file mode 100644 index 0000000..b0ac39b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/is.js @@ -0,0 +1,195 @@ +// type checks for all known types +// +// note that: +// +// - check by duck-typing on a property like `isUnit`, instead of checking instanceof. +// instanceof cannot be used because that would not allow to pass data from +// one instance of math.js to another since each has it's own instance of Unit. +// - check the `isUnit` property via the constructor, so there will be no +// matches for "fake" instances like plain objects with a property `isUnit`. +// That is important for security reasons. +// - It must not be possible to override the type checks used internally, +// for security reasons, so these functions are not exposed in the expression +// parser. + +import { ObjectWrappingMap } from './map.js'; +export function isNumber(x) { + return typeof x === 'number'; +} +export function isBigNumber(x) { + if (!x || typeof x !== 'object' || typeof x.constructor !== 'function') { + return false; + } + if (x.isBigNumber === true && typeof x.constructor.prototype === 'object' && x.constructor.prototype.isBigNumber === true) { + return true; + } + if (typeof x.constructor.isDecimal === 'function' && x.constructor.isDecimal(x) === true) { + return true; + } + return false; +} +export function isBigInt(x) { + return typeof x === 'bigint'; +} +export function isComplex(x) { + return x && typeof x === 'object' && Object.getPrototypeOf(x).isComplex === true || false; +} +export function isFraction(x) { + return x && typeof x === 'object' && Object.getPrototypeOf(x).isFraction === true || false; +} +export function isUnit(x) { + return x && x.constructor.prototype.isUnit === true || false; +} +export function isString(x) { + return typeof x === 'string'; +} +export var isArray = Array.isArray; +export function isMatrix(x) { + return x && x.constructor.prototype.isMatrix === true || false; +} + +/** + * Test whether a value is a collection: an Array or Matrix + * @param {*} x + * @returns {boolean} isCollection + */ +export function isCollection(x) { + return Array.isArray(x) || isMatrix(x); +} +export function isDenseMatrix(x) { + return x && x.isDenseMatrix && x.constructor.prototype.isMatrix === true || false; +} +export function isSparseMatrix(x) { + return x && x.isSparseMatrix && x.constructor.prototype.isMatrix === true || false; +} +export function isRange(x) { + return x && x.constructor.prototype.isRange === true || false; +} +export function isIndex(x) { + return x && x.constructor.prototype.isIndex === true || false; +} +export function isBoolean(x) { + return typeof x === 'boolean'; +} +export function isResultSet(x) { + return x && x.constructor.prototype.isResultSet === true || false; +} +export function isHelp(x) { + return x && x.constructor.prototype.isHelp === true || false; +} +export function isFunction(x) { + return typeof x === 'function'; +} +export function isDate(x) { + return x instanceof Date; +} +export function isRegExp(x) { + return x instanceof RegExp; +} +export function isObject(x) { + return !!(x && typeof x === 'object' && x.constructor === Object && !isComplex(x) && !isFraction(x)); +} + +/** + * Returns `true` if the passed object appears to be a Map (i.e. duck typing). + * + * Methods looked for are `get`, `set`, `keys` and `has`. + * + * @param {Map | object} object + * @returns + */ +export function isMap(object) { + // We can use the fast instanceof, or a slower duck typing check. + // The duck typing method needs to cover enough methods to not be confused with DenseMatrix. + if (!object) { + return false; + } + return object instanceof Map || object instanceof ObjectWrappingMap || typeof object.set === 'function' && typeof object.get === 'function' && typeof object.keys === 'function' && typeof object.has === 'function'; +} +export function isPartitionedMap(object) { + return isMap(object) && isMap(object.a) && isMap(object.b); +} +export function isObjectWrappingMap(object) { + return isMap(object) && isObject(object.wrappedObject); +} +export function isNull(x) { + return x === null; +} +export function isUndefined(x) { + return x === undefined; +} +export function isAccessorNode(x) { + return x && x.isAccessorNode === true && x.constructor.prototype.isNode === true || false; +} +export function isArrayNode(x) { + return x && x.isArrayNode === true && x.constructor.prototype.isNode === true || false; +} +export function isAssignmentNode(x) { + return x && x.isAssignmentNode === true && x.constructor.prototype.isNode === true || false; +} +export function isBlockNode(x) { + return x && x.isBlockNode === true && x.constructor.prototype.isNode === true || false; +} +export function isConditionalNode(x) { + return x && x.isConditionalNode === true && x.constructor.prototype.isNode === true || false; +} +export function isConstantNode(x) { + return x && x.isConstantNode === true && x.constructor.prototype.isNode === true || false; +} + +/* Very specialized: returns true for those nodes which in the numerator of + a fraction means that the division in that fraction has precedence over implicit + multiplication, e.g. -2/3 x parses as (-2/3) x and 3/4 x parses as (3/4) x but + 6!/8 x parses as 6! / (8x). It is located here because it is shared between + parse.js and OperatorNode.js (for parsing and printing, respectively). + + This should *not* be exported from mathjs, unlike most of the tests here. + Its name does not start with 'is' to prevent utils/snapshot.js from thinking + it should be exported. +*/ +export function rule2Node(node) { + return isConstantNode(node) || isOperatorNode(node) && node.args.length === 1 && isConstantNode(node.args[0]) && '-+~'.includes(node.op); +} +export function isFunctionAssignmentNode(x) { + return x && x.isFunctionAssignmentNode === true && x.constructor.prototype.isNode === true || false; +} +export function isFunctionNode(x) { + return x && x.isFunctionNode === true && x.constructor.prototype.isNode === true || false; +} +export function isIndexNode(x) { + return x && x.isIndexNode === true && x.constructor.prototype.isNode === true || false; +} +export function isNode(x) { + return x && x.isNode === true && x.constructor.prototype.isNode === true || false; +} +export function isObjectNode(x) { + return x && x.isObjectNode === true && x.constructor.prototype.isNode === true || false; +} +export function isOperatorNode(x) { + return x && x.isOperatorNode === true && x.constructor.prototype.isNode === true || false; +} +export function isParenthesisNode(x) { + return x && x.isParenthesisNode === true && x.constructor.prototype.isNode === true || false; +} +export function isRangeNode(x) { + return x && x.isRangeNode === true && x.constructor.prototype.isNode === true || false; +} +export function isRelationalNode(x) { + return x && x.isRelationalNode === true && x.constructor.prototype.isNode === true || false; +} +export function isSymbolNode(x) { + return x && x.isSymbolNode === true && x.constructor.prototype.isNode === true || false; +} +export function isChain(x) { + return x && x.constructor.prototype.isChain === true || false; +} +export function typeOf(x) { + var t = typeof x; + if (t === 'object') { + if (x === null) return 'null'; + if (isBigNumber(x)) return 'BigNumber'; // Special: weird mashup with Decimal + if (x.constructor && x.constructor.name) return x.constructor.name; + return 'Object'; // just in case + } + return t; // can be 'string', 'number', 'boolean', 'function', 'bigint', ... +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/latex.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/latex.js new file mode 100644 index 0000000..7a9b302 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/latex.js @@ -0,0 +1,487 @@ +/* eslint no-template-curly-in-string: "off" */ + +import escapeLatexLib from 'escape-latex'; +import { hasOwnProperty } from './object.js'; +export var latexSymbols = { + // GREEK LETTERS + Alpha: 'A', + alpha: '\\alpha', + Beta: 'B', + beta: '\\beta', + Gamma: '\\Gamma', + gamma: '\\gamma', + Delta: '\\Delta', + delta: '\\delta', + Epsilon: 'E', + epsilon: '\\epsilon', + varepsilon: '\\varepsilon', + Zeta: 'Z', + zeta: '\\zeta', + Eta: 'H', + eta: '\\eta', + Theta: '\\Theta', + theta: '\\theta', + vartheta: '\\vartheta', + Iota: 'I', + iota: '\\iota', + Kappa: 'K', + kappa: '\\kappa', + varkappa: '\\varkappa', + Lambda: '\\Lambda', + lambda: '\\lambda', + Mu: 'M', + mu: '\\mu', + Nu: 'N', + nu: '\\nu', + Xi: '\\Xi', + xi: '\\xi', + Omicron: 'O', + omicron: 'o', + Pi: '\\Pi', + pi: '\\pi', + varpi: '\\varpi', + Rho: 'P', + rho: '\\rho', + varrho: '\\varrho', + Sigma: '\\Sigma', + sigma: '\\sigma', + varsigma: '\\varsigma', + Tau: 'T', + tau: '\\tau', + Upsilon: '\\Upsilon', + upsilon: '\\upsilon', + Phi: '\\Phi', + phi: '\\phi', + varphi: '\\varphi', + Chi: 'X', + chi: '\\chi', + Psi: '\\Psi', + psi: '\\psi', + Omega: '\\Omega', + omega: '\\omega', + // logic + true: '\\mathrm{True}', + false: '\\mathrm{False}', + // other + i: 'i', + // TODO use \i ?? + inf: '\\infty', + Inf: '\\infty', + infinity: '\\infty', + Infinity: '\\infty', + oo: '\\infty', + lim: '\\lim', + undefined: '\\mathbf{?}' +}; +export var latexOperators = { + transpose: '^\\top', + ctranspose: '^H', + factorial: '!', + pow: '^', + dotPow: '.^\\wedge', + // TODO find ideal solution + unaryPlus: '+', + unaryMinus: '-', + bitNot: '\\~', + // TODO find ideal solution + not: '\\neg', + multiply: '\\cdot', + divide: '\\frac', + // TODO how to handle that properly? + dotMultiply: '.\\cdot', + // TODO find ideal solution + dotDivide: '.:', + // TODO find ideal solution + mod: '\\mod', + add: '+', + subtract: '-', + to: '\\rightarrow', + leftShift: '<<', + rightArithShift: '>>', + rightLogShift: '>>>', + equal: '=', + unequal: '\\neq', + smaller: '<', + larger: '>', + smallerEq: '\\leq', + largerEq: '\\geq', + bitAnd: '\\&', + bitXor: '\\underline{|}', + bitOr: '|', + and: '\\wedge', + xor: '\\veebar', + or: '\\vee' +}; +export var latexFunctions = { + // arithmetic + abs: { + 1: '\\left|${args[0]}\\right|' + }, + add: { + 2: "\\left(${args[0]}".concat(latexOperators.add, "${args[1]}\\right)") + }, + cbrt: { + 1: '\\sqrt[3]{${args[0]}}' + }, + ceil: { + 1: '\\left\\lceil${args[0]}\\right\\rceil' + }, + cube: { + 1: '\\left(${args[0]}\\right)^3' + }, + divide: { + 2: '\\frac{${args[0]}}{${args[1]}}' + }, + dotDivide: { + 2: "\\left(${args[0]}".concat(latexOperators.dotDivide, "${args[1]}\\right)") + }, + dotMultiply: { + 2: "\\left(${args[0]}".concat(latexOperators.dotMultiply, "${args[1]}\\right)") + }, + dotPow: { + 2: "\\left(${args[0]}".concat(latexOperators.dotPow, "${args[1]}\\right)") + }, + exp: { + 1: '\\exp\\left(${args[0]}\\right)' + }, + expm1: "\\left(e".concat(latexOperators.pow, "{${args[0]}}-1\\right)"), + fix: { + 1: '\\mathrm{${name}}\\left(${args[0]}\\right)' + }, + floor: { + 1: '\\left\\lfloor${args[0]}\\right\\rfloor' + }, + gcd: '\\gcd\\left(${args}\\right)', + hypot: '\\hypot\\left(${args}\\right)', + log: { + 1: '\\ln\\left(${args[0]}\\right)', + 2: '\\log_{${args[1]}}\\left(${args[0]}\\right)' + }, + log10: { + 1: '\\log_{10}\\left(${args[0]}\\right)' + }, + log1p: { + 1: '\\ln\\left(${args[0]}+1\\right)', + 2: '\\log_{${args[1]}}\\left(${args[0]}+1\\right)' + }, + log2: '\\log_{2}\\left(${args[0]}\\right)', + mod: { + 2: "\\left(${args[0]}".concat(latexOperators.mod, "${args[1]}\\right)") + }, + multiply: { + 2: "\\left(${args[0]}".concat(latexOperators.multiply, "${args[1]}\\right)") + }, + norm: { + 1: '\\left\\|${args[0]}\\right\\|', + 2: undefined // use default template + }, + nthRoot: { + 2: '\\sqrt[${args[1]}]{${args[0]}}' + }, + nthRoots: { + 2: '\\{y : $y^{args[1]} = {${args[0]}}\\}' + }, + pow: { + 2: "\\left(${args[0]}\\right)".concat(latexOperators.pow, "{${args[1]}}") + }, + round: { + 1: '\\left\\lfloor${args[0]}\\right\\rceil', + 2: undefined // use default template + }, + sign: { + 1: '\\mathrm{${name}}\\left(${args[0]}\\right)' + }, + sqrt: { + 1: '\\sqrt{${args[0]}}' + }, + square: { + 1: '\\left(${args[0]}\\right)^2' + }, + subtract: { + 2: "\\left(${args[0]}".concat(latexOperators.subtract, "${args[1]}\\right)") + }, + unaryMinus: { + 1: "".concat(latexOperators.unaryMinus, "\\left(${args[0]}\\right)") + }, + unaryPlus: { + 1: "".concat(latexOperators.unaryPlus, "\\left(${args[0]}\\right)") + }, + // bitwise + bitAnd: { + 2: "\\left(${args[0]}".concat(latexOperators.bitAnd, "${args[1]}\\right)") + }, + bitNot: { + 1: latexOperators.bitNot + '\\left(${args[0]}\\right)' + }, + bitOr: { + 2: "\\left(${args[0]}".concat(latexOperators.bitOr, "${args[1]}\\right)") + }, + bitXor: { + 2: "\\left(${args[0]}".concat(latexOperators.bitXor, "${args[1]}\\right)") + }, + leftShift: { + 2: "\\left(${args[0]}".concat(latexOperators.leftShift, "${args[1]}\\right)") + }, + rightArithShift: { + 2: "\\left(${args[0]}".concat(latexOperators.rightArithShift, "${args[1]}\\right)") + }, + rightLogShift: { + 2: "\\left(${args[0]}".concat(latexOperators.rightLogShift, "${args[1]}\\right)") + }, + // combinatorics + bellNumbers: { + 1: '\\mathrm{B}_{${args[0]}}' + }, + catalan: { + 1: '\\mathrm{C}_{${args[0]}}' + }, + stirlingS2: { + 2: '\\mathrm{S}\\left(${args}\\right)' + }, + // complex + arg: { + 1: '\\arg\\left(${args[0]}\\right)' + }, + conj: { + 1: '\\left(${args[0]}\\right)^*' + }, + im: { + 1: '\\Im\\left\\lbrace${args[0]}\\right\\rbrace' + }, + re: { + 1: '\\Re\\left\\lbrace${args[0]}\\right\\rbrace' + }, + // logical + and: { + 2: "\\left(${args[0]}".concat(latexOperators.and, "${args[1]}\\right)") + }, + not: { + 1: latexOperators.not + '\\left(${args[0]}\\right)' + }, + or: { + 2: "\\left(${args[0]}".concat(latexOperators.or, "${args[1]}\\right)") + }, + xor: { + 2: "\\left(${args[0]}".concat(latexOperators.xor, "${args[1]}\\right)") + }, + // matrix + cross: { + 2: '\\left(${args[0]}\\right)\\times\\left(${args[1]}\\right)' + }, + ctranspose: { + 1: "\\left(${args[0]}\\right)".concat(latexOperators.ctranspose) + }, + det: { + 1: '\\det\\left(${args[0]}\\right)' + }, + dot: { + 2: '\\left(${args[0]}\\cdot${args[1]}\\right)' + }, + expm: { + 1: '\\exp\\left(${args[0]}\\right)' + }, + inv: { + 1: '\\left(${args[0]}\\right)^{-1}' + }, + pinv: { + 1: '\\left(${args[0]}\\right)^{+}' + }, + sqrtm: { + 1: "{${args[0]}}".concat(latexOperators.pow, "{\\frac{1}{2}}") + }, + trace: { + 1: '\\mathrm{tr}\\left(${args[0]}\\right)' + }, + transpose: { + 1: "\\left(${args[0]}\\right)".concat(latexOperators.transpose) + }, + // probability + combinations: { + 2: '\\binom{${args[0]}}{${args[1]}}' + }, + combinationsWithRep: { + 2: '\\left(\\!\\!{\\binom{${args[0]}}{${args[1]}}}\\!\\!\\right)' + }, + factorial: { + 1: "\\left(${args[0]}\\right)".concat(latexOperators.factorial) + }, + gamma: { + 1: '\\Gamma\\left(${args[0]}\\right)' + }, + lgamma: { + 1: '\\ln\\Gamma\\left(${args[0]}\\right)' + }, + // relational + equal: { + 2: "\\left(${args[0]}".concat(latexOperators.equal, "${args[1]}\\right)") + }, + larger: { + 2: "\\left(${args[0]}".concat(latexOperators.larger, "${args[1]}\\right)") + }, + largerEq: { + 2: "\\left(${args[0]}".concat(latexOperators.largerEq, "${args[1]}\\right)") + }, + smaller: { + 2: "\\left(${args[0]}".concat(latexOperators.smaller, "${args[1]}\\right)") + }, + smallerEq: { + 2: "\\left(${args[0]}".concat(latexOperators.smallerEq, "${args[1]}\\right)") + }, + unequal: { + 2: "\\left(${args[0]}".concat(latexOperators.unequal, "${args[1]}\\right)") + }, + // special + erf: { + 1: 'erf\\left(${args[0]}\\right)' + }, + // statistics + max: '\\max\\left(${args}\\right)', + min: '\\min\\left(${args}\\right)', + variance: '\\mathrm{Var}\\left(${args}\\right)', + // trigonometry + acos: { + 1: '\\cos^{-1}\\left(${args[0]}\\right)' + }, + acosh: { + 1: '\\cosh^{-1}\\left(${args[0]}\\right)' + }, + acot: { + 1: '\\cot^{-1}\\left(${args[0]}\\right)' + }, + acoth: { + 1: '\\coth^{-1}\\left(${args[0]}\\right)' + }, + acsc: { + 1: '\\csc^{-1}\\left(${args[0]}\\right)' + }, + acsch: { + 1: '\\mathrm{csch}^{-1}\\left(${args[0]}\\right)' + }, + asec: { + 1: '\\sec^{-1}\\left(${args[0]}\\right)' + }, + asech: { + 1: '\\mathrm{sech}^{-1}\\left(${args[0]}\\right)' + }, + asin: { + 1: '\\sin^{-1}\\left(${args[0]}\\right)' + }, + asinh: { + 1: '\\sinh^{-1}\\left(${args[0]}\\right)' + }, + atan: { + 1: '\\tan^{-1}\\left(${args[0]}\\right)' + }, + atan2: { + 2: '\\mathrm{atan2}\\left(${args}\\right)' + }, + atanh: { + 1: '\\tanh^{-1}\\left(${args[0]}\\right)' + }, + cos: { + 1: '\\cos\\left(${args[0]}\\right)' + }, + cosh: { + 1: '\\cosh\\left(${args[0]}\\right)' + }, + cot: { + 1: '\\cot\\left(${args[0]}\\right)' + }, + coth: { + 1: '\\coth\\left(${args[0]}\\right)' + }, + csc: { + 1: '\\csc\\left(${args[0]}\\right)' + }, + csch: { + 1: '\\mathrm{csch}\\left(${args[0]}\\right)' + }, + sec: { + 1: '\\sec\\left(${args[0]}\\right)' + }, + sech: { + 1: '\\mathrm{sech}\\left(${args[0]}\\right)' + }, + sin: { + 1: '\\sin\\left(${args[0]}\\right)' + }, + sinh: { + 1: '\\sinh\\left(${args[0]}\\right)' + }, + tan: { + 1: '\\tan\\left(${args[0]}\\right)' + }, + tanh: { + 1: '\\tanh\\left(${args[0]}\\right)' + }, + // unit + to: { + 2: "\\left(${args[0]}".concat(latexOperators.to, "${args[1]}\\right)") + }, + // utils + numeric: function numeric(node, options) { + // Not sure if this is strictly right but should work correctly for the vast majority of use cases. + return node.args[0].toTex(); + }, + // type + number: { + 0: '0', + 1: '\\left(${args[0]}\\right)', + 2: '\\left(\\left(${args[0]}\\right)${args[1]}\\right)' + }, + string: { + 0: '\\mathtt{""}', + 1: '\\mathrm{string}\\left(${args[0]}\\right)' + }, + bignumber: { + 0: '0', + 1: '\\left(${args[0]}\\right)' + }, + bigint: { + 0: '0', + 1: '\\left(${args[0]}\\right)' + }, + complex: { + 0: '0', + 1: '\\left(${args[0]}\\right)', + 2: "\\left(\\left(${args[0]}\\right)+".concat(latexSymbols.i, "\\cdot\\left(${args[1]}\\right)\\right)") + }, + matrix: { + 0: '\\begin{bmatrix}\\end{bmatrix}', + 1: '\\left(${args[0]}\\right)', + 2: '\\left(${args[0]}\\right)' + }, + sparse: { + 0: '\\begin{bsparse}\\end{bsparse}', + 1: '\\left(${args[0]}\\right)' + }, + unit: { + 1: '\\left(${args[0]}\\right)', + 2: '\\left(\\left(${args[0]}\\right)${args[1]}\\right)' + } +}; +export var defaultTemplate = '\\mathrm{${name}}\\left(${args}\\right)'; +var latexUnits = { + deg: '^\\circ' +}; +export function escapeLatex(string) { + return escapeLatexLib(string, { + preserveFormatting: true + }); +} + +// @param {string} name +// @param {boolean} isUnit +export function toSymbol(name, isUnit) { + isUnit = typeof isUnit === 'undefined' ? false : isUnit; + if (isUnit) { + if (hasOwnProperty(latexUnits, name)) { + return latexUnits[name]; + } + return '\\mathrm{' + escapeLatex(name) + '}'; + } + if (hasOwnProperty(latexSymbols, name)) { + return latexSymbols[name]; + } + return escapeLatex(name); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/log.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/log.js new file mode 100644 index 0000000..4d265f1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/log.js @@ -0,0 +1,16 @@ +/** + * Log a console.warn message only once + */ +export var warnOnce = (() => { + var messages = {}; + return function warnOnce() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + var message = args.join(', '); + if (!messages[message]) { + messages[message] = true; + console.warn('Warning:', ...args); + } + }; +})(); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/lruQueue.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/lruQueue.js new file mode 100644 index 0000000..9498439 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/lruQueue.js @@ -0,0 +1,51 @@ +// (c) 2018, Mariusz Nowak +// SPDX-License-Identifier: ISC +// Derived from https://github.com/medikoo/lru-queue +export function lruQueue(limit) { + var size = 0; + var base = 1; + var queue = Object.create(null); + var map = Object.create(null); + var index = 0; + var del = function del(id) { + var oldIndex = map[id]; + if (!oldIndex) return; + delete queue[oldIndex]; + delete map[id]; + --size; + if (base !== oldIndex) return; + if (!size) { + index = 0; + base = 1; + return; + } + while (!Object.prototype.hasOwnProperty.call(queue, ++base)) {/* empty */} + }; + limit = Math.abs(limit); + return { + hit: function hit(id) { + var oldIndex = map[id]; + var nuIndex = ++index; + queue[nuIndex] = id; + map[id] = nuIndex; + if (!oldIndex) { + ++size; + if (size <= limit) return undefined; + id = queue[base]; + del(id); + return id; + } + delete queue[oldIndex]; + if (base !== oldIndex) return undefined; + while (!Object.prototype.hasOwnProperty.call(queue, ++base)) {/* empty */} + return undefined; + }, + delete: del, + clear: function clear() { + size = index = 0; + base = 1; + queue = Object.create(null); + map = Object.create(null); + } + }; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/map.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/map.js new file mode 100644 index 0000000..f44fbba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/map.js @@ -0,0 +1,203 @@ +import { getSafeProperty, isSafeProperty, setSafeProperty } from './customs.js'; +import { isMap, isObject } from './is.js'; + +/** + * A map facade on a bare object. + * + * The small number of methods needed to implement a scope, + * forwarding on to the SafeProperty functions. Over time, the codebase + * will stop using this method, as all objects will be Maps, rather than + * more security prone objects. + */ +export class ObjectWrappingMap { + constructor(object) { + this.wrappedObject = object; + this[Symbol.iterator] = this.entries; + } + keys() { + return Object.keys(this.wrappedObject).filter(key => this.has(key)).values(); + } + get(key) { + return getSafeProperty(this.wrappedObject, key); + } + set(key, value) { + setSafeProperty(this.wrappedObject, key, value); + return this; + } + has(key) { + return isSafeProperty(this.wrappedObject, key) && key in this.wrappedObject; + } + entries() { + return mapIterator(this.keys(), key => [key, this.get(key)]); + } + forEach(callback) { + for (var key of this.keys()) { + callback(this.get(key), key, this); + } + } + delete(key) { + if (isSafeProperty(this.wrappedObject, key)) { + delete this.wrappedObject[key]; + } + } + clear() { + for (var key of this.keys()) { + this.delete(key); + } + } + get size() { + return Object.keys(this.wrappedObject).length; + } +} + +/** + * Create a map with two partitions: a and b. + * The set with bKeys determines which keys/values are read/written to map b, + * all other values are read/written to map a + * + * For example: + * + * const a = new Map() + * const b = new Map() + * const p = new PartitionedMap(a, b, new Set(['x', 'y'])) + * + * In this case, values `x` and `y` are read/written to map `b`, + * all other values are read/written to map `a`. + */ +export class PartitionedMap { + /** + * @param {Map} a + * @param {Map} b + * @param {Set} bKeys + */ + constructor(a, b, bKeys) { + this.a = a; + this.b = b; + this.bKeys = bKeys; + this[Symbol.iterator] = this.entries; + } + get(key) { + return this.bKeys.has(key) ? this.b.get(key) : this.a.get(key); + } + set(key, value) { + if (this.bKeys.has(key)) { + this.b.set(key, value); + } else { + this.a.set(key, value); + } + return this; + } + has(key) { + return this.b.has(key) || this.a.has(key); + } + keys() { + return new Set([...this.a.keys(), ...this.b.keys()])[Symbol.iterator](); + } + entries() { + return mapIterator(this.keys(), key => [key, this.get(key)]); + } + forEach(callback) { + for (var key of this.keys()) { + callback(this.get(key), key, this); + } + } + delete(key) { + return this.bKeys.has(key) ? this.b.delete(key) : this.a.delete(key); + } + clear() { + this.a.clear(); + this.b.clear(); + } + get size() { + return [...this.keys()].length; + } +} + +/** + * Create a new iterator that maps over the provided iterator, applying a mapping function to each item + */ +function mapIterator(it, callback) { + return { + next: () => { + var n = it.next(); + return n.done ? n : { + value: callback(n.value), + done: false + }; + } + }; +} + +/** + * Creates an empty map, or whatever your platform's polyfill is. + * + * @returns an empty Map or Map like object. + */ +export function createEmptyMap() { + return new Map(); +} + +/** + * Creates a Map from the given object. + * + * @param { Map | { [key: string]: unknown } | undefined } mapOrObject + * @returns + */ +export function createMap(mapOrObject) { + if (!mapOrObject) { + return createEmptyMap(); + } + if (isMap(mapOrObject)) { + return mapOrObject; + } + if (isObject(mapOrObject)) { + return new ObjectWrappingMap(mapOrObject); + } + throw new Error('createMap can create maps from objects or Maps'); +} + +/** + * Unwraps a map into an object. + * + * @param {Map} map + * @returns { [key: string]: unknown } + */ +export function toObject(map) { + if (map instanceof ObjectWrappingMap) { + return map.wrappedObject; + } + var object = {}; + for (var key of map.keys()) { + var value = map.get(key); + setSafeProperty(object, key, value); + } + return object; +} + +/** + * Copies the contents of key-value pairs from each `objects` in to `map`. + * + * Object is `objects` can be a `Map` or object. + * + * This is the `Map` analog to `Object.assign`. + */ +export function assign(map) { + for (var _len = arguments.length, objects = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + objects[_key - 1] = arguments[_key]; + } + for (var args of objects) { + if (!args) { + continue; + } + if (isMap(args)) { + for (var key of args.keys()) { + map.set(key, args.get(key)); + } + } else if (isObject(args)) { + for (var _key2 of Object.keys(args)) { + map.set(_key2, args[_key2]); + } + } + } + return map; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/noop.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/noop.js new file mode 100644 index 0000000..dd6e5d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/noop.js @@ -0,0 +1,15 @@ +export function noBignumber() { + throw new Error('No "bignumber" implementation available'); +} +export function noFraction() { + throw new Error('No "fraction" implementation available'); +} +export function noMatrix() { + throw new Error('No "matrix" implementation available'); +} +export function noIndex() { + throw new Error('No "index" implementation available'); +} +export function noSubset() { + throw new Error('No "matrix" implementation available'); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/number.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/number.js new file mode 100644 index 0000000..3414cf6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/number.js @@ -0,0 +1,737 @@ +import { isBigNumber, isNumber, isObject } from './is.js'; + +/** + * @typedef {{sign: '+' | '-' | '', coefficients: number[], exponent: number}} SplitValue + */ + +/** + * Check if a number is integer + * @param {number | boolean} value + * @return {boolean} isInteger + */ +export function isInteger(value) { + if (typeof value === 'boolean') { + return true; + } + return isFinite(value) ? value === Math.round(value) : false; +} + +/** + * Check if a string contains an integer + * @param {string} str + * @return {boolean} isInteger + */ +export function isIntegerStr(str) { + // regex matching strings like "123" and "-123" + return /^-?\d+$/.test(str); +} + +/** + * Ensure the number type is compatible with the provided value. + * If not, return 'number' instead. + * + * For example: + * + * safeNumberType('2.3', { number: 'bigint', numberFallback: 'number' }) + * + * will return 'number' and not 'bigint' because trying to create a bigint with + * value 2.3 would throw an exception. + * + * @param {string} numberStr + * @param {{ + * number: 'number' | 'BigNumber' | 'bigint' | 'Fraction' + * numberFallback: 'number' | 'BigNumber' + * }} config + * @returns {'number' | 'BigNumber' | 'bigint' | 'Fraction'} + */ +export function safeNumberType(numberStr, config) { + if (config.number === 'bigint' && !isIntegerStr(numberStr)) { + return config.numberFallback; + } + return config.number; +} + +/** + * Calculate the sign of a number + * @param {number} x + * @returns {number} + */ +export var sign = Math.sign || function (x) { + if (x > 0) { + return 1; + } else if (x < 0) { + return -1; + } else { + return 0; + } +}; + +/** + * Calculate the base-2 logarithm of a number + * @param {number} x + * @returns {number} + */ +export var log2 = Math.log2 || function log2(x) { + return Math.log(x) / Math.LN2; +}; + +/** + * Calculate the base-10 logarithm of a number + * @param {number} x + * @returns {number} + */ +export var log10 = Math.log10 || function log10(x) { + return Math.log(x) / Math.LN10; +}; + +/** + * Calculate the natural logarithm of a number + 1 + * @param {number} x + * @returns {number} + */ +export var log1p = Math.log1p || function (x) { + return Math.log(x + 1); +}; + +/** + * Calculate cubic root for a number + * + * Code from es6-shim.js: + * https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1564-L1577 + * + * @param {number} x + * @returns {number} Returns the cubic root of x + */ +export var cbrt = Math.cbrt || function cbrt(x) { + if (x === 0) { + return x; + } + var negate = x < 0; + var result; + if (negate) { + x = -x; + } + if (isFinite(x)) { + result = Math.exp(Math.log(x) / 3); + // from https://en.wikipedia.org/wiki/Cube_root#Numerical_methods + result = (x / (result * result) + 2 * result) / 3; + } else { + result = x; + } + return negate ? -result : result; +}; + +/** + * Calculates exponentiation minus 1 + * @param {number} x + * @return {number} res + */ +export var expm1 = Math.expm1 || function expm1(x) { + return x >= 2e-4 || x <= -2e-4 ? Math.exp(x) - 1 : x + x * x / 2 + x * x * x / 6; +}; + +/** + * Formats a number in a given base + * @param {number} n + * @param {number} base + * @param {number} size + * @returns {string} + */ +function formatNumberToBase(n, base, size) { + var prefixes = { + 2: '0b', + 8: '0o', + 16: '0x' + }; + var prefix = prefixes[base]; + var suffix = ''; + if (size) { + if (size < 1) { + throw new Error('size must be in greater than 0'); + } + if (!isInteger(size)) { + throw new Error('size must be an integer'); + } + if (n > 2 ** (size - 1) - 1 || n < -(2 ** (size - 1))) { + throw new Error("Value must be in range [-2^".concat(size - 1, ", 2^").concat(size - 1, "-1]")); + } + if (!isInteger(n)) { + throw new Error('Value must be an integer'); + } + if (n < 0) { + n = n + 2 ** size; + } + suffix = "i".concat(size); + } + var sign = ''; + if (n < 0) { + n = -n; + sign = '-'; + } + return "".concat(sign).concat(prefix).concat(n.toString(base)).concat(suffix); +} + +/** + * Convert a number to a formatted string representation. + * + * Syntax: + * + * format(value) + * format(value, options) + * format(value, precision) + * format(value, fn) + * + * Where: + * + * {number} value The value to be formatted + * {Object} options An object with formatting options. Available options: + * {string} notation + * Number notation. Choose from: + * 'fixed' Always use regular number notation. + * For example '123.40' and '14000000' + * 'exponential' Always use exponential notation. + * For example '1.234e+2' and '1.4e+7' + * 'engineering' Always use engineering notation. + * For example '123.4e+0' and '14.0e+6' + * 'auto' (default) Regular number notation for numbers + * having an absolute value between + * `lowerExp` and `upperExp` bounds, and + * uses exponential notation elsewhere. + * Lower bound is included, upper bound + * is excluded. + * For example '123.4' and '1.4e7'. + * 'bin', 'oct, or + * 'hex' Format the number using binary, octal, + * or hexadecimal notation. + * For example '0b1101' and '0x10fe'. + * {number} wordSize The word size in bits to use for formatting + * in binary, octal, or hexadecimal notation. + * To be used only with 'bin', 'oct', or 'hex' + * values for 'notation' option. When this option + * is defined the value is formatted as a signed + * twos complement integer of the given word size + * and the size suffix is appended to the output. + * For example + * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'. + * Default value is undefined. + * {number} precision A number between 0 and 16 to round + * the digits of the number. + * In case of notations 'exponential', + * 'engineering', and 'auto', + * `precision` defines the total + * number of significant digits returned. + * In case of notation 'fixed', + * `precision` defines the number of + * significant digits after the decimal + * point. + * `precision` is undefined by default, + * not rounding any digits. + * {number} lowerExp Exponent determining the lower boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `-3`. + * {number} upperExp Exponent determining the upper boundary + * for formatting a value with an exponent + * when `notation='auto`. + * Default value is `5`. + * {Function} fn A custom formatting function. Can be used to override the + * built-in notations. Function `fn` is called with `value` as + * parameter and must return a string. Is useful for example to + * format all values inside a matrix in a particular way. + * + * Examples: + * + * format(6.4) // '6.4' + * format(1240000) // '1.24e6' + * format(1/3) // '0.3333333333333333' + * format(1/3, 3) // '0.333' + * format(21385, 2) // '21000' + * format(12.071, {notation: 'fixed'}) // '12' + * format(2.3, {notation: 'fixed', precision: 2}) // '2.30' + * format(52.8, {notation: 'exponential'}) // '5.28e+1' + * format(12345678, {notation: 'engineering'}) // '12.345678e+6' + * + * @param {number} value + * @param {Object | Function | number} [options] + * @return {string} str The formatted value + */ +export function format(value, options) { + if (typeof options === 'function') { + // handle format(value, fn) + return options(value); + } + + // handle special cases + if (value === Infinity) { + return 'Infinity'; + } else if (value === -Infinity) { + return '-Infinity'; + } else if (isNaN(value)) { + return 'NaN'; + } + var { + notation, + precision, + wordSize + } = normalizeFormatOptions(options); + + // handle the various notations + switch (notation) { + case 'fixed': + return toFixed(value, precision); + case 'exponential': + return toExponential(value, precision); + case 'engineering': + return toEngineering(value, precision); + case 'bin': + return formatNumberToBase(value, 2, wordSize); + case 'oct': + return formatNumberToBase(value, 8, wordSize); + case 'hex': + return formatNumberToBase(value, 16, wordSize); + case 'auto': + // remove trailing zeros after the decimal point + return toPrecision(value, precision, options).replace(/((\.\d*?)(0+))($|e)/, function () { + var digits = arguments[2]; + var e = arguments[4]; + return digits !== '.' ? digits + e : e; + }); + default: + throw new Error('Unknown notation "' + notation + '". ' + 'Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.'); + } +} + +/** + * Normalize format options into an object: + * { + * notation: string, + * precision: number | undefined, + * wordSize: number | undefined + * } + */ +export function normalizeFormatOptions(options) { + // default values for options + var notation = 'auto'; + var precision; + var wordSize; + if (options !== undefined) { + if (isNumber(options)) { + precision = options; + } else if (isBigNumber(options)) { + precision = options.toNumber(); + } else if (isObject(options)) { + if (options.precision !== undefined) { + precision = _toNumberOrThrow(options.precision, () => { + throw new Error('Option "precision" must be a number or BigNumber'); + }); + } + if (options.wordSize !== undefined) { + wordSize = _toNumberOrThrow(options.wordSize, () => { + throw new Error('Option "wordSize" must be a number or BigNumber'); + }); + } + if (options.notation) { + notation = options.notation; + } + } else { + throw new Error('Unsupported type of options, number, BigNumber, or object expected'); + } + } + return { + notation, + precision, + wordSize + }; +} + +/** + * Split a number into sign, coefficients, and exponent + * @param {number | string} value + * @return {SplitValue} + * Returns an object containing sign, coefficients, and exponent + */ +export function splitNumber(value) { + // parse the input value + var match = String(value).toLowerCase().match(/^(-?)(\d+\.?\d*)(e([+-]?\d+))?$/); + if (!match) { + throw new SyntaxError('Invalid number ' + value); + } + var sign = match[1]; + var digits = match[2]; + var exponent = parseFloat(match[4] || '0'); + var dot = digits.indexOf('.'); + exponent += dot !== -1 ? dot - 1 : digits.length - 1; + var coefficients = digits.replace('.', '') // remove the dot (must be removed before removing leading zeros) + .replace(/^0*/, function (zeros) { + // remove leading zeros, add their count to the exponent + exponent -= zeros.length; + return ''; + }).replace(/0*$/, '') // remove trailing zeros + .split('').map(function (d) { + return parseInt(d); + }); + if (coefficients.length === 0) { + coefficients.push(0); + exponent++; + } + return { + sign, + coefficients, + exponent + }; +} + +/** + * Format a number in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3' + * @param {number | string} value + * @param {number} [precision] Optional number of significant figures to return. + */ +export function toEngineering(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + var split = splitNumber(value); + var rounded = roundDigits(split, precision); + var e = rounded.exponent; + var c = rounded.coefficients; + + // find nearest lower multiple of 3 for exponent + var newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3; + if (isNumber(precision)) { + // add zeroes to give correct sig figs + while (precision > c.length || e - newExp + 1 > c.length) { + c.push(0); + } + } else { + // concatenate coefficients with necessary zeros + // add zeros if necessary (for example: 1e+8 -> 100e+6) + var missingZeros = Math.abs(e - newExp) - (c.length - 1); + for (var i = 0; i < missingZeros; i++) { + c.push(0); + } + } + + // find difference in exponents + var expDiff = Math.abs(e - newExp); + var decimalIdx = 1; + + // push decimal index over by expDiff times + while (expDiff > 0) { + decimalIdx++; + expDiff--; + } + + // if all coefficient values are zero after the decimal point and precision is unset, don't add a decimal value. + // otherwise concat with the rest of the coefficients + var decimals = c.slice(decimalIdx).join(''); + var decimalVal = isNumber(precision) && decimals.length || decimals.match(/[1-9]/) ? '.' + decimals : ''; + var str = c.slice(0, decimalIdx).join('') + decimalVal + 'e' + (e >= 0 ? '+' : '') + newExp.toString(); + return rounded.sign + str; +} + +/** + * Format a number with fixed notation. + * @param {number | string} value + * @param {number} [precision=undefined] Optional number of decimals after the + * decimal point. null by default. + */ +export function toFixed(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + var splitValue = splitNumber(value); + var rounded = typeof precision === 'number' ? roundDigits(splitValue, splitValue.exponent + 1 + precision) : splitValue; + var c = rounded.coefficients; + var p = rounded.exponent + 1; // exponent may have changed + + // append zeros if needed + var pp = p + (precision || 0); + if (c.length < pp) { + c = c.concat(zeros(pp - c.length)); + } + + // prepend zeros if needed + if (p < 0) { + c = zeros(-p + 1).concat(c); + p = 1; + } + + // insert a dot if needed + if (p < c.length) { + c.splice(p, 0, p === 0 ? '0.' : '.'); + } + return rounded.sign + c.join(''); +} + +/** + * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3' + * @param {number | string} value + * @param {number} [precision] Number of digits in formatted output. + * If not provided, the maximum available digits + * is used. + */ +export function toExponential(value, precision) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + + // round if needed, else create a clone + var split = splitNumber(value); + var rounded = precision ? roundDigits(split, precision) : split; + var c = rounded.coefficients; + var e = rounded.exponent; + + // append zeros if needed + if (c.length < precision) { + c = c.concat(zeros(precision - c.length)); + } + + // format as `C.CCCe+EEE` or `C.CCCe-EEE` + var first = c.shift(); + return rounded.sign + first + (c.length > 0 ? '.' + c.join('') : '') + 'e' + (e >= 0 ? '+' : '') + e; +} + +/** + * Format a number with a certain precision + * @param {number | string} value + * @param {number} [precision=undefined] Optional number of digits. + * @param {{lowerExp: number | undefined, upperExp: number | undefined}} [options] + * By default: + * lowerExp = -3 (incl) + * upper = +5 (excl) + * @return {string} + */ +export function toPrecision(value, precision, options) { + if (isNaN(value) || !isFinite(value)) { + return String(value); + } + + // determine lower and upper bound for exponential notation. + var lowerExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.lowerExp, -3); + var upperExp = _toNumberOrDefault(options === null || options === void 0 ? void 0 : options.upperExp, 5); + var split = splitNumber(value); + var rounded = precision ? roundDigits(split, precision) : split; + if (rounded.exponent < lowerExp || rounded.exponent >= upperExp) { + // exponential notation + return toExponential(value, precision); + } else { + var c = rounded.coefficients; + var e = rounded.exponent; + + // append trailing zeros + if (c.length < precision) { + c = c.concat(zeros(precision - c.length)); + } + + // append trailing zeros + // TODO: simplify the next statement + c = c.concat(zeros(e - c.length + 1 + (c.length < precision ? precision - c.length : 0))); + + // prepend zeros + c = zeros(-e).concat(c); + var dot = e > 0 ? e : 0; + if (dot < c.length - 1) { + c.splice(dot + 1, 0, '.'); + } + return rounded.sign + c.join(''); + } +} + +/** + * Round the number of digits of a number * + * @param {SplitValue} split A value split with .splitNumber(value) + * @param {number} precision A positive integer + * @return {SplitValue} + * Returns an object containing sign, coefficients, and exponent + * with rounded digits + */ +export function roundDigits(split, precision) { + // create a clone + var rounded = { + sign: split.sign, + coefficients: split.coefficients, + exponent: split.exponent + }; + var c = rounded.coefficients; + + // prepend zeros if needed + while (precision <= 0) { + c.unshift(0); + rounded.exponent++; + precision++; + } + if (c.length > precision) { + var removed = c.splice(precision, c.length - precision); + if (removed[0] >= 5) { + var i = precision - 1; + c[i]++; + while (c[i] === 10) { + c.pop(); + if (i === 0) { + c.unshift(0); + rounded.exponent++; + i++; + } + i--; + c[i]++; + } + } + } + return rounded; +} + +/** + * Create an array filled with zeros. + * @param {number} length + * @return {Array} + */ +function zeros(length) { + var arr = []; + for (var i = 0; i < length; i++) { + arr.push(0); + } + return arr; +} + +/** + * Count the number of significant digits of a number. + * + * For example: + * 2.34 returns 3 + * 0.0034 returns 2 + * 120.5e+30 returns 4 + * + * @param {number} value + * @return {number} digits Number of significant digits + */ +export function digits(value) { + return value.toExponential().replace(/e.*$/, '') // remove exponential notation + .replace(/^0\.?0*|\./, '') // remove decimal point and leading zeros + .length; +} + +/** + * Minimum number added to one that makes the result different than one + */ +export var DBL_EPSILON = Number.EPSILON || 2.2204460492503130808472633361816E-16; + +/** + * Compares two floating point numbers. + * @param {number} a - First value to compare + * @param {number} b - Second value to compare + * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0. + * @param {number} [absTol=1e-12] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0. + * @return {boolean} whether the two numbers are nearly equal + * + * @throws {Error} If `relTol` is less than or equal to 0. + * @throws {Error} If `absTol` is less than 0. + * + * @example + * nearlyEqual(1.000000001, 1.0, 1e-8); // true + * nearlyEqual(1.000000002, 1.0, 0); // false + * nearlyEqual(1.0, 1.009, undefined, 0.01); // true + * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true + */ +export function nearlyEqual(a, b) { + var relTol = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1e-8; + var absTol = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; + if (relTol <= 0) { + throw new Error('Relative tolerance must be greater than 0'); + } + if (absTol < 0) { + throw new Error('Absolute tolerance must be at least 0'); + } + + // NaN + if (isNaN(a) || isNaN(b)) { + return false; + } + if (!isFinite(a) || !isFinite(b)) { + return a === b; + } + if (a === b) { + return true; + } + + // abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol) + return Math.abs(a - b) <= Math.max(relTol * Math.max(Math.abs(a), Math.abs(b)), absTol); +} + +/** + * Calculate the hyperbolic arccos of a number + * @param {number} x + * @return {number} + */ +export var acosh = Math.acosh || function (x) { + return Math.log(Math.sqrt(x * x - 1) + x); +}; +export var asinh = Math.asinh || function (x) { + return Math.log(Math.sqrt(x * x + 1) + x); +}; + +/** + * Calculate the hyperbolic arctangent of a number + * @param {number} x + * @return {number} + */ +export var atanh = Math.atanh || function (x) { + return Math.log((1 + x) / (1 - x)) / 2; +}; + +/** + * Calculate the hyperbolic cosine of a number + * @param {number} x + * @returns {number} + */ +export var cosh = Math.cosh || function (x) { + return (Math.exp(x) + Math.exp(-x)) / 2; +}; + +/** + * Calculate the hyperbolic sine of a number + * @param {number} x + * @returns {number} + */ +export var sinh = Math.sinh || function (x) { + return (Math.exp(x) - Math.exp(-x)) / 2; +}; + +/** + * Calculate the hyperbolic tangent of a number + * @param {number} x + * @returns {number} + */ +export var tanh = Math.tanh || function (x) { + var e = Math.exp(2 * x); + return (e - 1) / (e + 1); +}; + +/** + * Returns a value with the magnitude of x and the sign of y. + * @param {number} x + * @param {number} y + * @returns {number} + */ +export function copysign(x, y) { + var signx = x > 0 ? true : x < 0 ? false : 1 / x === Infinity; + var signy = y > 0 ? true : y < 0 ? false : 1 / y === Infinity; + return signx ^ signy ? -x : x; +} +function _toNumberOrThrow(value, onError) { + if (isNumber(value)) { + return value; + } else if (isBigNumber(value)) { + return value.toNumber(); + } else { + onError(); + } +} +function _toNumberOrDefault(value, defaultValue) { + if (isNumber(value)) { + return value; + } else if (isBigNumber(value)) { + return value.toNumber(); + } else { + return defaultValue; + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/object.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/object.js new file mode 100644 index 0000000..173229e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/object.js @@ -0,0 +1,372 @@ +import { isBigNumber, isObject } from './is.js'; + +/** + * Clone an object + * + * clone(x) + * + * Can clone any primitive type, array, and object. + * If x has a function clone, this function will be invoked to clone the object. + * + * @param {*} x + * @return {*} clone + */ +export function clone(x) { + var type = typeof x; + + // immutable primitive types + if (type === 'number' || type === 'bigint' || type === 'string' || type === 'boolean' || x === null || x === undefined) { + return x; + } + + // use clone function of the object when available + if (typeof x.clone === 'function') { + return x.clone(); + } + + // array + if (Array.isArray(x)) { + return x.map(function (value) { + return clone(value); + }); + } + if (x instanceof Date) return new Date(x.valueOf()); + if (isBigNumber(x)) return x; // bignumbers are immutable + + // object + if (isObject(x)) { + return mapObject(x, clone); + } + throw new TypeError("Cannot clone: unknown type of value (value: ".concat(x, ")")); +} + +/** + * Apply map to all properties of an object + * @param {Object} object + * @param {function} callback + * @return {Object} Returns a copy of the object with mapped properties + */ +export function mapObject(object, callback) { + var clone = {}; + for (var key in object) { + if (hasOwnProperty(object, key)) { + clone[key] = callback(object[key]); + } + } + return clone; +} + +/** + * Extend object a with the properties of object b + * @param {Object} a + * @param {Object} b + * @return {Object} a + */ +export function extend(a, b) { + for (var prop in b) { + if (hasOwnProperty(b, prop)) { + a[prop] = b[prop]; + } + } + return a; +} + +/** + * Deep extend an object a with the properties of object b + * @param {Object} a + * @param {Object} b + * @returns {Object} + */ +export function deepExtend(a, b) { + // TODO: add support for Arrays to deepExtend + if (Array.isArray(b)) { + throw new TypeError('Arrays are not supported by deepExtend'); + } + for (var prop in b) { + // We check against prop not being in Object.prototype or Function.prototype + // to prevent polluting for example Object.__proto__. + if (hasOwnProperty(b, prop) && !(prop in Object.prototype) && !(prop in Function.prototype)) { + if (b[prop] && b[prop].constructor === Object) { + if (a[prop] === undefined) { + a[prop] = {}; + } + if (a[prop] && a[prop].constructor === Object) { + deepExtend(a[prop], b[prop]); + } else { + a[prop] = b[prop]; + } + } else if (Array.isArray(b[prop])) { + throw new TypeError('Arrays are not supported by deepExtend'); + } else { + a[prop] = b[prop]; + } + } + } + return a; +} + +/** + * Deep test equality of all fields in two pairs of arrays or objects. + * Compares values and functions strictly (ie. 2 is not the same as '2'). + * @param {Array | Object} a + * @param {Array | Object} b + * @returns {boolean} + */ +export function deepStrictEqual(a, b) { + var prop, i, len; + if (Array.isArray(a)) { + if (!Array.isArray(b)) { + return false; + } + if (a.length !== b.length) { + return false; + } + for (i = 0, len = a.length; i < len; i++) { + if (!deepStrictEqual(a[i], b[i])) { + return false; + } + } + return true; + } else if (typeof a === 'function') { + return a === b; + } else if (a instanceof Object) { + if (Array.isArray(b) || !(b instanceof Object)) { + return false; + } + for (prop in a) { + // noinspection JSUnfilteredForInLoop + if (!(prop in b) || !deepStrictEqual(a[prop], b[prop])) { + return false; + } + } + for (prop in b) { + // noinspection JSUnfilteredForInLoop + if (!(prop in a)) { + return false; + } + } + return true; + } else { + return a === b; + } +} + +/** + * Recursively flatten a nested object. + * @param {Object} nestedObject + * @return {Object} Returns the flattened object + */ +export function deepFlatten(nestedObject) { + var flattenedObject = {}; + _deepFlatten(nestedObject, flattenedObject); + return flattenedObject; +} + +// helper function used by deepFlatten +function _deepFlatten(nestedObject, flattenedObject) { + for (var prop in nestedObject) { + if (hasOwnProperty(nestedObject, prop)) { + var value = nestedObject[prop]; + if (typeof value === 'object' && value !== null) { + _deepFlatten(value, flattenedObject); + } else { + flattenedObject[prop] = value; + } + } + } +} + +/** + * Test whether the current JavaScript engine supports Object.defineProperty + * @returns {boolean} returns true if supported + */ +export function canDefineProperty() { + // test needed for broken IE8 implementation + try { + if (Object.defineProperty) { + Object.defineProperty({}, 'x', { + get: function get() { + return null; + } + }); + return true; + } + } catch (e) {} + return false; +} + +/** + * Attach a lazy loading property to a constant. + * The given function `fn` is called once when the property is first requested. + * + * @param {Object} object Object where to add the property + * @param {string} prop Property name + * @param {Function} valueResolver Function returning the property value. Called + * without arguments. + */ +export function lazy(object, prop, valueResolver) { + var _uninitialized = true; + var _value; + Object.defineProperty(object, prop, { + get: function get() { + if (_uninitialized) { + _value = valueResolver(); + _uninitialized = false; + } + return _value; + }, + set: function set(value) { + _value = value; + _uninitialized = false; + }, + configurable: true, + enumerable: true + }); +} + +/** + * Traverse a path into an object. + * When a namespace is missing, it will be created + * @param {Object} object + * @param {string | string[]} path A dot separated string like 'name.space' + * @return {Object} Returns the object at the end of the path + */ +export function traverse(object, path) { + if (path && typeof path === 'string') { + return traverse(object, path.split('.')); + } + var obj = object; + if (path) { + for (var i = 0; i < path.length; i++) { + var key = path[i]; + if (!(key in obj)) { + obj[key] = {}; + } + obj = obj[key]; + } + } + return obj; +} + +/** + * A safe hasOwnProperty + * @param {Object} object + * @param {string} property + */ +export function hasOwnProperty(object, property) { + return object && Object.hasOwnProperty.call(object, property); +} + +/** + * Test whether an object is a factory. a factory has fields: + * + * - factory: function (type: Object, config: Object, load: function, typed: function [, math: Object]) (required) + * - name: string (optional) + * - path: string A dot separated path (optional) + * - math: boolean If true (false by default), the math namespace is passed + * as fifth argument of the factory function + * + * @param {*} object + * @returns {boolean} + */ +export function isLegacyFactory(object) { + return object && typeof object.factory === 'function'; +} + +/** + * Get a nested property from an object + * @param {Object} object + * @param {string | string[]} path + * @returns {Object} + */ +export function get(object, path) { + if (typeof path === 'string') { + if (isPath(path)) { + return get(object, path.split('.')); + } else { + return object[path]; + } + } + var child = object; + for (var i = 0; i < path.length; i++) { + var key = path[i]; + child = child ? child[key] : undefined; + } + return child; +} + +/** + * Set a nested property in an object + * Mutates the object itself + * If the path doesn't exist, it will be created + * @param {Object} object + * @param {string | string[]} path + * @param {*} value + * @returns {Object} + */ +export function set(object, path, value) { + if (typeof path === 'string') { + if (isPath(path)) { + return set(object, path.split('.'), value); + } else { + object[path] = value; + return object; + } + } + var child = object; + for (var i = 0; i < path.length - 1; i++) { + var key = path[i]; + if (child[key] === undefined) { + child[key] = {}; + } + child = child[key]; + } + if (path.length > 0) { + var lastKey = path[path.length - 1]; + child[lastKey] = value; + } + return object; +} + +/** + * Create an object composed of the picked object properties + * @param {Object} object + * @param {string[]} properties + * @param {function} [transform] Optional value to transform a value when picking it + * @return {Object} + */ +export function pick(object, properties, transform) { + var copy = {}; + for (var i = 0; i < properties.length; i++) { + var key = properties[i]; + var value = get(object, key); + if (value !== undefined) { + set(copy, key, transform ? transform(value, key) : value); + } + } + return copy; +} + +/** + * Shallow version of pick, creating an object composed of the picked object properties + * but not for nested properties + * @param {Object} object + * @param {string[]} properties + * @return {Object} + */ +export function pickShallow(object, properties) { + var copy = {}; + for (var i = 0; i < properties.length; i++) { + var key = properties[i]; + var value = object[key]; + if (value !== undefined) { + copy[key] = value; + } + } + return copy; +} + +// helper function to test whether a string contains a path like 'user.name' +function isPath(str) { + return str.includes('.'); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/optimizeCallback.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/optimizeCallback.js new file mode 100644 index 0000000..888d4e5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/optimizeCallback.js @@ -0,0 +1,88 @@ +import typed from 'typed-function'; +import { get, arraySize } from './array.js'; +import { typeOf as _typeOf } from './is.js'; + +/** + * Simplifies a callback function by reducing its complexity and potentially improving its performance. + * + * @param {Function} callback The original callback function to simplify. + * @param {Array|Matrix} array The array that will be used with the callback function. + * @param {string} name The name of the function that is using the callback. + * @returns {Function} Returns a simplified version of the callback function. + */ +export function optimizeCallback(callback, array, name) { + if (typed.isTypedFunction(callback)) { + var firstIndex = (array.isMatrix ? array.size() : arraySize(array)).map(() => 0); + var firstValue = array.isMatrix ? array.get(firstIndex) : get(array, firstIndex); + var hasSingleSignature = Object.keys(callback.signatures).length === 1; + var numberOfArguments = _findNumberOfArguments(callback, firstValue, firstIndex, array); + var fastCallback = hasSingleSignature ? Object.values(callback.signatures)[0] : callback; + if (numberOfArguments >= 1 && numberOfArguments <= 3) { + return function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + return _tryFunctionWithArgs(fastCallback, args.slice(0, numberOfArguments), name, callback.name); + }; + } + return function () { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + return _tryFunctionWithArgs(fastCallback, args, name, callback.name); + }; + } + return callback; +} +function _findNumberOfArguments(callback, value, index, array) { + var testArgs = [value, index, array]; + for (var i = 3; i > 0; i--) { + var args = testArgs.slice(0, i); + if (typed.resolve(callback, args) !== null) { + return i; + } + } +} + +/** + * @param {function} func The selected function taken from one of the signatures of the callback function + * @param {Array} args List with arguments to apply to the selected signature + * @param {string} mappingFnName the name of the function that is using the callback + * @param {string} callbackName the name of the callback function + * @returns {*} Returns the return value of the invoked signature + * @throws {TypeError} Throws an error when no matching signature was found + */ +function _tryFunctionWithArgs(func, args, mappingFnName, callbackName) { + try { + return func(...args); + } catch (err) { + _createCallbackError(err, args, mappingFnName, callbackName); + } +} + +/** + * Creates and throws a detailed TypeError when a callback function fails. + * + * @param {Error} err The original error thrown by the callback function. + * @param {Array} args The arguments that were passed to the callback function. + * @param {string} mappingFnName The name of the function that is using the callback. + * @param {string} callbackName The name of the callback function. + * @throws {TypeError} Throws a detailed TypeError with enriched error message. + */ +function _createCallbackError(err, args, mappingFnName, callbackName) { + var _err$data; + // Enrich the error message so the user understands that it took place inside the callback function + if (err instanceof TypeError && ((_err$data = err.data) === null || _err$data === void 0 ? void 0 : _err$data.category) === 'wrongType') { + var argsDesc = []; + argsDesc.push("value: ".concat(_typeOf(args[0]))); + if (args.length >= 2) { + argsDesc.push("index: ".concat(_typeOf(args[1]))); + } + if (args.length >= 3) { + argsDesc.push("array: ".concat(_typeOf(args[2]))); + } + throw new TypeError("Function ".concat(mappingFnName, " cannot apply callback arguments ") + "".concat(callbackName, "(").concat(argsDesc.join(', '), ") at index ").concat(JSON.stringify(args[1]))); + } else { + throw new TypeError("Function ".concat(mappingFnName, " cannot apply callback arguments ") + "to function ".concat(callbackName, ": ").concat(err.message)); + } +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/print.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/print.js new file mode 100644 index 0000000..05e9b8d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/print.js @@ -0,0 +1 @@ +export var printTemplate = /\$([\w.]+)/g; \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/product.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/product.js new file mode 100644 index 0000000..6986783 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/product.js @@ -0,0 +1,14 @@ +/** @param {number} i + * @param {number} n + * @returns {number} product of i to n + */ +export function product(i, n) { + if (n < i) { + return 1; + } + if (n === i) { + return n; + } + var half = n + i >> 1; // divide (n + i) by 2 and truncate to integer + return product(i, half) * product(half + 1, n); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/scope.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/scope.js new file mode 100644 index 0000000..5b306d9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/scope.js @@ -0,0 +1,18 @@ +import { ObjectWrappingMap, PartitionedMap } from './map.js'; + +/** + * Create a new scope which can access the parent scope, + * but does not affect it when written. This is suitable for variable definitions + * within a block node, or function definition. + * + * If parent scope has a createSubScope method, it delegates to that. Otherwise, + * creates an empty map, and copies the parent scope to it, adding in + * the remaining `args`. + * + * @param {Map} parentScope + * @param {Object} args + * @returns {PartitionedMap} + */ +export function createSubScope(parentScope, args) { + return new PartitionedMap(parentScope, new ObjectWrappingMap(args), new Set(Object.keys(args))); +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/snapshot.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/snapshot.js new file mode 100644 index 0000000..41cd414 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/snapshot.js @@ -0,0 +1,227 @@ +import _extends from "@babel/runtime/helpers/extends"; +import _defineProperty from "@babel/runtime/helpers/defineProperty"; +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +/** + * This file contains helper methods to create expected snapshot structures + * of both instance and ES6 exports. + * + * The files are located here and not under /test or /tools so it's transpiled + * into ES5 code under /lib and can be used straight by node.js + */ +import assert from 'assert'; +import * as allIsFunctions from './is.js'; +import { create } from '../core/create.js'; +import { endsWith } from './string.js'; +export var validateTypeOf = allIsFunctions.typeOf; +export function validateBundle(expectedBundleStructure, bundle) { + var originalWarn = console.warn; + console.warn = function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + if (args.join(' ').includes('is moved to') && args.join(' ').includes('Please use the new location instead')) { + // Ignore warnings like: + // Warning: math.type.isNumber is moved to math.isNumber in v6.0.0. Please use the new location instead. + return; + } + originalWarn.apply(console, args); + }; + try { + var issues = []; + + // see whether all expected functions and objects are there + traverse(expectedBundleStructure, (expectedType, path) => { + var actualValue = get(bundle, path); + var actualType = validateTypeOf(actualValue); + var message = actualType === 'undefined' ? 'Missing entry in bundle. ' + "Path: ".concat(JSON.stringify(path), ", expected type: ").concat(expectedType, ", actual type: ").concat(actualType) : 'Unexpected entry type in bundle. ' + "Path: ".concat(JSON.stringify(path), ", expected type: ").concat(expectedType, ", actual type: ").concat(actualType); + if (actualType !== expectedType) { + issues.push({ + actualType, + expectedType, + message + }); + console.warn(message); + } + }); + + // see whether there are any functions or objects that shouldn't be there + traverse(bundle, (actualValue, path) => { + var actualType = validateTypeOf(actualValue); + var expectedType = get(expectedBundleStructure, path) || 'undefined'; + + // FIXME: ugly to have these special cases + if (path.join('.').includes('docs.')) { + // ignore the contents of docs + return; + } + if (path.join('.').includes('all.')) { + // ignore the contents of all dependencies + return; + } + var message = expectedType === 'undefined' ? 'Unknown entry in bundle. ' + 'Is there a new function added which is missing in this snapshot test? ' + "Path: ".concat(JSON.stringify(path), ", expected type: ").concat(expectedType, ", actual type: ").concat(actualType) : 'Unexpected entry type in bundle. ' + "Path: ".concat(JSON.stringify(path), ", expected type: ").concat(expectedType, ", actual type: ").concat(actualType); + if (actualType !== expectedType) { + issues.push({ + actualType, + expectedType, + message + }); + console.warn(message); + } + }); + + // assert on the first issue (if any) + if (issues.length > 0) { + var { + actualType, + expectedType, + message + } = issues[0]; + console.warn("".concat(issues.length, " bundle issues found")); + assert.strictEqual(actualType, expectedType, message); + } + } finally { + console.warn = originalWarn; + } +} + +/** + * Based on an object with factory functions, create the expected + * structures for ES6 export and a mathjs instance. + * @param {Object} factories + * @return {{expectedInstanceStructure: Object, expectedES6Structure: Object}} + */ +export function createSnapshotFromFactories(factories) { + var math = create(factories); + var allFactoryFunctions = {}; + var allFunctionsConstantsClasses = {}; + var allFunctionsConstants = {}; + var allTransformFunctions = {}; + var allDependencyCollections = {}; + var allClasses = {}; + var allNodeClasses = {}; + Object.keys(factories).forEach(factoryName => { + var factory = factories[factoryName]; + var name = factory.fn; + var isTransformFunction = factory.meta && factory.meta.isTransformFunction; + var isClass = !isLowerCase(name[0]) && validateTypeOf(math[name]) === 'function'; + var dependenciesName = factory.fn + (isTransformFunction ? 'Transform' : '') + 'Dependencies'; + allFactoryFunctions[factoryName] = 'function'; + allFunctionsConstantsClasses[name] = validateTypeOf(math[name]); + allDependencyCollections[dependenciesName] = 'Object'; + if (isTransformFunction) { + allTransformFunctions[name] = 'function'; + } + if (isClass) { + if (endsWith(name, 'Node')) { + allNodeClasses[name] = 'function'; + } else { + allClasses[name] = 'function'; + } + } else { + allFunctionsConstants[name] = validateTypeOf(math[name]); + } + }); + var embeddedDocs = {}; + Object.keys(factories).forEach(factoryName => { + var factory = factories[factoryName]; + var name = factory.fn; + if (isLowerCase(factory.fn[0])) { + // ignore class names starting with upper case + embeddedDocs[name] = 'Object'; + } + }); + embeddedDocs = exclude(embeddedDocs, ['equalScalar', 'apply', 'addScalar', 'subtractScalar', 'multiplyScalar', 'print', 'divideScalar', 'parse', 'compile', 'parser', 'chain', 'reviver', 'replacer']); + var allTypeChecks = {}; + Object.keys(allIsFunctions).forEach(name => { + if (name.indexOf('is') === 0) { + allTypeChecks[name] = 'function'; + } + }); + var allErrorClasses = { + ArgumentsError: 'function', + DimensionError: 'function', + IndexError: 'function' + }; + var expectedInstanceStructure = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, allFunctionsConstantsClasses), {}, { + on: 'function', + off: 'function', + once: 'function', + emit: 'function', + import: 'function', + config: 'function', + create: 'function', + factory: 'function' + }, allTypeChecks), allErrorClasses), {}, { + expression: { + transform: _objectSpread({}, allTransformFunctions), + mathWithTransform: _objectSpread(_objectSpread({}, exclude(allFunctionsConstants, ['chain'])), {}, { + config: 'function' + }) + } + }); + var expectedES6Structure = _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, exclude(allFunctionsConstantsClasses, ['E', 'false', 'Infinity', 'NaN', 'null', 'PI', 'true'])), {}, { + create: 'function', + config: 'function', + factory: 'function', + _true: 'boolean', + _false: 'boolean', + _null: 'null', + _Infinity: 'number', + _NaN: 'number' + }, allTypeChecks), allErrorClasses), allDependencyCollections), allFactoryFunctions), {}, { + docs: embeddedDocs + }); + return { + expectedInstanceStructure, + expectedES6Structure + }; +} +function traverse(obj) { + var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (value, path) => {}; + var path = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : []; + // FIXME: ugly to have these special cases + if (path.length > 0 && path[0].includes('Dependencies')) { + // special case for objects holding a collection of dependencies + callback(obj, path); + } else if (validateTypeOf(obj) === 'Array') { + obj.map((item, index) => traverse(item, callback, path.concat(index))); + } else if (validateTypeOf(obj) === 'Object') { + Object.keys(obj).forEach(key => { + // FIXME: ugly to have these special cases + // ignore special case of deprecated docs + if (key === 'docs' && path.join('.') === 'expression') { + return; + } + traverse(obj[key], callback, path.concat(key)); + }); + } else { + callback(obj, path); + } +} +function get(object, path) { + var child = object; + for (var i = 0; i < path.length; i++) { + var key = path[i]; + child = child ? child[key] : undefined; + } + return child; +} + +/** + * Create a copy of the provided `object` and delete + * all properties listed in `excludedProperties` + * @param {Object} object + * @param {string[]} excludedProperties + * @return {Object} + */ +function exclude(object, excludedProperties) { + var strippedObject = _extends({}, object); + excludedProperties.forEach(excludedProperty => { + delete strippedObject[excludedProperty]; + }); + return strippedObject; +} +function isLowerCase(text) { + return typeof text === 'string' && text.toLowerCase() === text; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/string.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/string.js new file mode 100644 index 0000000..96c6334 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/string.js @@ -0,0 +1,194 @@ +import { isBigNumber, isString, typeOf } from './is.js'; +import { format as formatNumber } from './number.js'; +import { format as formatBigNumber } from './bignumber/formatter.js'; + +/** + * Check if a text ends with a certain string. + * @param {string} text + * @param {string} search + */ +export function endsWith(text, search) { + var start = text.length - search.length; + var end = text.length; + return text.substring(start, end) === search; +} + +/** + * Format a value of any type into a string. + * + * Usage: + * math.format(value) + * math.format(value, precision) + * math.format(value, options) + * + * When value is a function: + * + * - When the function has a property `syntax`, it returns this + * syntax description. + * - In other cases, a string `'function'` is returned. + * + * When `value` is an Object: + * + * - When the object contains a property `format` being a function, this + * function is invoked as `value.format(options)` and the result is returned. + * - When the object has its own `toString` method, this method is invoked + * and the result is returned. + * - In other cases the function will loop over all object properties and + * return JSON object notation like '{"a": 2, "b": 3}'. + * + * Example usage: + * math.format(2/7) // '0.2857142857142857' + * math.format(math.pi, 3) // '3.14' + * math.format(new Complex(2, 3)) // '2 + 3i' + * math.format('hello') // '"hello"' + * + * @param {*} value Value to be stringified + * @param {Object | number | Function} [options] + * Formatting options. See src/utils/number.js:format for a + * description of the available options controlling number output. + * This generic "format" also supports the option property `truncate: NN` + * giving the maximum number NN of characters to return (if there would + * have been more, they are deleted and replaced by an ellipsis). + * @return {string} str + */ +export function format(value, options) { + var result = _format(value, options); + if (options && typeof options === 'object' && 'truncate' in options && result.length > options.truncate) { + return result.substring(0, options.truncate - 3) + '...'; + } + return result; +} +function _format(value, options) { + if (typeof value === 'number') { + return formatNumber(value, options); + } + if (isBigNumber(value)) { + return formatBigNumber(value, options); + } + + // note: we use unsafe duck-typing here to check for Fractions, this is + // ok here since we're only invoking toString or concatenating its values + if (looksLikeFraction(value)) { + if (!options || options.fraction !== 'decimal') { + // output as ratio, like '1/3' + return value.s * value.n + '/' + value.d; + } else { + // output as decimal, like '0.(3)' + return value.toString(); + } + } + if (Array.isArray(value)) { + return formatArray(value, options); + } + if (isString(value)) { + return stringify(value); + } + if (typeof value === 'function') { + return value.syntax ? String(value.syntax) : 'function'; + } + if (value && typeof value === 'object') { + if (typeof value.format === 'function') { + return value.format(options); + } else if (value && value.toString(options) !== {}.toString()) { + // this object has a non-native toString method, use that one + return value.toString(options); + } else { + var entries = Object.keys(value).map(key => { + return stringify(key) + ': ' + format(value[key], options); + }); + return '{' + entries.join(', ') + '}'; + } + } + return String(value); +} + +/** + * Stringify a value into a string enclosed in double quotes. + * Unescaped double quotes and backslashes inside the value are escaped. + * @param {*} value + * @return {string} + */ +export function stringify(value) { + var text = String(value); + var escaped = ''; + var i = 0; + while (i < text.length) { + var c = text.charAt(i); + escaped += c in controlCharacters ? controlCharacters[c] : c; + i++; + } + return '"' + escaped + '"'; +} +var controlCharacters = { + '"': '\\"', + '\\': '\\\\', + '\b': '\\b', + '\f': '\\f', + '\n': '\\n', + '\r': '\\r', + '\t': '\\t' +}; + +/** + * Escape special HTML characters + * @param {*} value + * @return {string} + */ +export function escape(value) { + var text = String(value); + text = text.replace(/&/g, '&').replace(/"/g, '"').replace(/'/g, ''').replace(//g, '>'); + return text; +} + +/** + * Recursively format an n-dimensional matrix + * Example output: "[[1, 2], [3, 4]]" + * @param {Array} array + * @param {Object | number | Function} [options] Formatting options. See + * lib/utils/number:format for a + * description of the available + * options. + * @returns {string} str + */ +function formatArray(array, options) { + if (Array.isArray(array)) { + var str = '['; + var len = array.length; + for (var i = 0; i < len; i++) { + if (i !== 0) { + str += ', '; + } + str += formatArray(array[i], options); + } + str += ']'; + return str; + } else { + return format(array, options); + } +} + +/** + * Check whether a value looks like a Fraction (unsafe duck-type check) + * @param {*} value + * @return {boolean} + */ +function looksLikeFraction(value) { + return value && typeof value === 'object' && typeof value.s === 'number' && typeof value.n === 'number' && typeof value.d === 'number' || false; +} + +/** + * Compare two strings + * @param {string} x + * @param {string} y + * @returns {number} + */ +export function compareText(x, y) { + // we don't want to convert numbers to string, only accept string input + if (!isString(x)) { + throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + typeOf(x) + ', index: 0)'); + } + if (!isString(y)) { + throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + typeOf(y) + ', index: 1)'); + } + return x === y ? 0 : x > y ? 1 : -1; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/switch.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/switch.js new file mode 100644 index 0000000..3d70271 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/utils/switch.js @@ -0,0 +1,20 @@ +/** + * Transpose a matrix + * @param {Array} mat + * @returns {Array} ret + * @private + */ +export function _switch(mat) { + var I = mat.length; + var J = mat[0].length; + var i, j; + var ret = []; + for (j = 0; j < J; j++) { + var tmp = []; + for (i = 0; i < I; i++) { + tmp.push(mat[i][j]); + } + ret.push(tmp); + } + return ret; +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/version.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/version.js new file mode 100644 index 0000000..abd1465 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/lib/esm/version.js @@ -0,0 +1,3 @@ +export var version = '13.2.0'; +// Note: This file is automatically generated when building math.js. +// Changes made in this file will be overwritten. \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/package.json new file mode 100644 index 0000000..7148bdb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/package.json @@ -0,0 +1,170 @@ +{ + "name": "mathjs", + "version": "13.2.0", + "description": "Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser with support for symbolic computation, comes with a large set of built-in functions and constants, and offers an integrated solution to work with different data types like numbers, big numbers, complex numbers, fractions, units, and matrices.", + "author": "Jos de Jong (https://github.com/josdejong)", + "homepage": "https://mathjs.org", + "repository": { + "type": "git", + "url": "https://github.com/josdejong/mathjs.git" + }, + "license": "Apache-2.0", + "keywords": [ + "math", + "mathematics", + "functions", + "numeric", + "algebra", + "parser", + "expression", + "number", + "bignumber", + "complex", + "fraction", + "matrix", + "unit" + ], + "dependencies": { + "@babel/runtime": "^7.25.6", + "complex.js": "^2.1.1", + "decimal.js": "^10.4.3", + "escape-latex": "^1.2.0", + "fraction.js": "^4.3.7", + "javascript-natural-sort": "^0.7.1", + "seedrandom": "^3.0.5", + "tiny-emitter": "^2.1.0", + "typed-function": "^4.2.1" + }, + "devDependencies": { + "@babel/core": "7.25.2", + "@babel/plugin-transform-object-assign": "7.24.7", + "@babel/plugin-transform-optional-catch-binding": "7.24.7", + "@babel/plugin-transform-runtime": "7.25.4", + "@babel/preset-env": "7.25.4", + "@babel/register": "7.24.6", + "@types/assert": "1.5.10", + "@types/mocha": "10.0.8", + "@typescript-eslint/eslint-plugin": "7.16.1", + "@typescript-eslint/parser": "7.16.1", + "assert": "2.1.0", + "babel-loader": "9.2.1", + "benchmark": "2.1.4", + "c8": "10.1.2", + "codecov": "3.8.3", + "core-js": "3.38.1", + "del": "7.1.0", + "dtslint": "4.2.1", + "eslint": "8.57.0", + "eslint-config-prettier": "9.1.0", + "eslint-config-standard": "17.1.0", + "eslint-plugin-import": "2.30.0", + "eslint-plugin-mocha": "10.5.0", + "eslint-plugin-n": "16.6.2", + "eslint-plugin-prettier": "5.2.1", + "eslint-plugin-promise": "6.6.0", + "expect-type": "0.20.0", + "expr-eval": "2.0.2", + "fancy-log": "2.0.0", + "glob": "11.0.0", + "gulp": "5.0.0", + "gulp-babel": "8.0.0", + "handlebars": "4.7.8", + "jsep": "1.3.9", + "karma": "6.4.4", + "karma-browserstack-launcher": "1.6.0", + "karma-firefox-launcher": "2.1.3", + "karma-mocha": "2.0.1", + "karma-mocha-reporter": "2.2.5", + "karma-webpack": "5.0.1", + "mkdirp": "3.0.1", + "mocha": "10.7.3", + "mocha-junit-reporter": "2.2.1", + "ndarray": "1.0.19", + "ndarray-determinant": "1.0.0", + "ndarray-gemm": "1.0.0", + "ndarray-ops": "1.2.2", + "ndarray-pack": "1.2.1", + "numericjs": "1.2.6", + "pad-right": "0.2.2", + "prettier": "3.3.3", + "process": "0.11.10", + "sinon": "19.0.2", + "sylvester": "0.0.21", + "ts-node": "10.9.2", + "typescript": "5.5.4", + "webpack": "5.95.0", + "zeros": "1.0.0" + }, + "type": "module", + "main": "./lib/cjs", + "types": "./types/index.d.ts", + "module": "./lib/esm", + "unpkg": "./lib/browser/math.js", + "jsdelivr": "./lib/browser/math.js", + "exports": { + ".": { + "types": "./types/index.d.ts", + "import": "./lib/esm/index.js", + "require": "./lib/cjs/index.js" + }, + "./number": { + "types": "./types/index.d.ts", + "import": "./lib/esm/number.js", + "require": "./lib/cjs/number.js" + }, + "./lib/esm/number": { + "types": "./types/index.d.ts", + "import": "./lib/esm/number.js", + "require": "./lib/cjs/number.js" + }, + "./package.json": "./package.json", + "./lib/browser/math.js": "./lib/browser/math.js", + "./lib/browser/math.js.map": "./lib/browser/math.js.map" + }, + "files": [ + "bin", + "lib", + "types", + "LICENSE", + "NOTICE", + "README.md", + "HISTORY.md", + "CONTRIBUTING.md" + ], + "directories": { + "bin": "./bin", + "lib": "./lib" + }, + "scripts": { + "build": "gulp && npm run update-authors", + "build-and-test": "npm run build && npm run test:all && npm run lint", + "build:clean": "gulp clean", + "build:docs": "gulp docs", + "compile": "gulp compile", + "watch": "gulp watch", + "lint": "eslint --cache --max-warnings 0 src/ test/ types/", + "format": "npm run lint -- --fix", + "validate:ascii": "gulp validate:ascii", + "test": "npm run test:src && npm run lint", + "test:src": "mocha test/unit-tests", + "test:generated": "mocha test/generated-code-tests", + "test:node": "mocha test/node-tests/*.test.js test/node-tests/**/*.test.js", + "test:all": "npm run test:src && npm run test:generated && npm run test:node && npm run test:types", + "test:browser": "karma start test/browser-test-config/local-karma.js", + "test:browserstack": "karma start test/browser-test-config/browserstack-karma.js", + "test:types": " tsc -p ./tsconfig.json && node --loader ts-node/esm ./test/typescript-tests/testTypes.ts", + "coverage": "c8 --reporter=lcov --reporter=text-summary mocha test/unit-tests && echo \"\nDetailed coverage report is available at ./coverage/lcov-report/index.html\"", + "prepublishOnly": "npm run test:all && npm run lint", + "update-authors": "node ./tools/update-authors.js" + }, + "bin": { + "mathjs": "./bin/cli.js" + }, + "engines": { + "node": ">= 18" + }, + "bugs": { + "url": "https://github.com/josdejong/mathjs/issues" + }, + "sideEffects": false +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/EXPLANATION.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/EXPLANATION.md new file mode 100644 index 0000000..8f83778 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/EXPLANATION.md @@ -0,0 +1,66 @@ +# Mathjs TypeScript types + +The code base of Mathjs is written in JavaScript. The TypeScript definitions are maintained separately. + +## Library structure + +The over all structure is: + +- The library exports the core function `create` which creates a MathJS instance and returns `MathJsInstance`. +- Mathjs has a special function `chain`, which allows you to use the functions in a chained way, like `chain(2).add(3).done()`. The function `chain` returns an interface `MathJsChain`, which contains all mathjs functions and constants as a method. Unlike the static functions, these methods are defined with the chain instance `this` as first argument. +- The library exports collections with factory functions of all functions and their dependencies. To create an instance of the function `add`, one can do `create(addDependencies)` for example. To import all functions, one can do `create(all)`. +- The library also returns a static instance, which can directly be used like `import { add } from 'mathjs'`. + +## Defining the types of a new function + +Maintaining the TypeScript types is done manually. When adding a function, one has to create the following TypeScript definitions: + +1. Add a normal definition inside `interface MathJsInstance {...}` +2. Add a chained definition inside `interface MathJsChain {...}` +3. Add a static definition inside `export const {...} : MathJsInstance` +4. Add a dependencies definition inside `export const {...} : Record` + +For exampe for the function `add`, we can have the following definitions: + +```ts +// instance +export interface MathJsInstance extends MathJsFactory { + //... + add(x: T, y: T): T + //... +} + +// chain +export interface MathJsChain { + //... + add(this: MathJsChain, y: T): MathJsChain + //... +} + +// static +export const { + // ... + add, + // ... +} : MathJsInstance + + +// dependencies +export const { + // ... + addDependencies, + // ... +} : Record +``` + +## Testing the type definitions + +The types are defined in `types/index.d.ts`. + +The tests for the type definitions are located in `test/typescript-types/testTypes.ts`. + +To run the tests for the type definitions: + +``` +npm run test:types +``` diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/index.d.ts b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/index.d.ts new file mode 100644 index 0000000..16f4d16 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/index.d.ts @@ -0,0 +1,7260 @@ +import { Decimal } from 'decimal.js' + +export as namespace math + +export type NoLiteralType = T extends number + ? number + : T extends string + ? string + : T extends boolean + ? boolean + : T + +// TODO: introduce generics for MathCollection, MathMatrix, and MathArray +export type MathNumericType = number | BigNumber | bigint | Fraction | Complex +export type MathScalarType = MathNumericType | Unit +export type MathArray = MathNumericType[] | MathNumericType[][] // TODO: MathArray can also contain Unit +export type MathCollection = MathArray | Matrix +export type MathType = MathScalarType | MathCollection +export type MathExpression = string | string[] | MathCollection + +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export type FactoryFunction = (scope: any) => T + +// FactoryFunctionMap can be nested; all nested objects will be flattened +export interface FactoryFunctionMap { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + [key: string]: FactoryFunction | FactoryFunctionMap +} + +/** Available options for parse */ +export interface ParseOptions { + /** a set of custom nodes */ + nodes?: Record +} +/** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(). + * + * Note the evaluating arbitrary expressions may involve security risks, + * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information. + * + * Syntax: + * + * math.parse(expr) + * math.parse(expr, options) + * math.parse([expr1, expr2, expr3, ...]) + * math.parse([expr1, expr2, expr3, ...], options) + * + * Example: + * + * const node1 = math.parse('sqrt(3^2 + 4^2)') + * node1.compile().evaluate() // 5 + * + * let scope = {a:3, b:4} + * const node2 = math.parse('a * b') // 12 + * const code2 = node2.compile() + * code2.evaluate(scope) // 12 + * scope.a = 5 + * code2.evaluate(scope) // 20 + * + * const nodes = math.parse(['a = 3', 'b = 4', 'a * b']) + * nodes[2].compile().evaluate() // 12 + * + * See also: + * + * evaluate, compile + */ +export interface ParseFunction { + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(); + * + * @param expr Expression to be parsed + * @param options Available options + * @returns A node + */ + (expr: MathExpression, options?: ParseOptions): MathNode + + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(); + * + * @param exprs Expressions to be parsed + * @param options Available options + * @returns An array of nodes + */ + (exprs: MathExpression[], options?: ParseOptions): MathNode[] + + /** + * Checks whether the current character `c` is a valid alpha character: + * + * - A latin letter (upper or lower case) Ascii: a-z, A-Z + * - An underscore Ascii: _ + * - A dollar sign Ascii: $ + * - A latin letter with accents Unicode: \u00C0 - \u02AF + * - A greek letter Unicode: \u0370 - \u03FF + * - A mathematical alphanumeric symbol Unicode: \u{1D400} - \u{1D7FF} excluding invalid code points + * + * The previous and next characters are needed to determine whether + * this character is part of a unicode surrogate pair. + * + * @param c Current character in the expression + * @param cPrev Previous character + * @param cNext Next character + */ + isAlpha(c: string, cPrev: string, cNext: string): boolean + /** + * Test whether a character is a valid latin, greek, or letter-like character + * + * @param c + */ + isValidLatinOrGreek(c: string): boolean + /** + * Test whether two given 16 bit characters form a surrogate pair of a + * unicode math symbol. + * + * https://unicode-table.com/en/ + * https://www.wikiwand.com/en/Mathematical_operators_and_symbols_in_Unicode + * + * Note: In ES6 will be unicode aware: + * https://stackoverflow.com/questions/280712/javascript-unicode-regexes + * https://mathiasbynens.be/notes/es6-unicode-regex + * + * @param high + * @param low + */ + isValidMathSymbol(high: string, low: string): boolean + /** + * Check whether given character c is a white space character: space, tab, or enter + * + * @param c + * @param nestingLevel + */ + isWhitespace(c: string, nestingLevel: number): boolean + /** + * Test whether the character c is a decimal mark (dot). + * This is the case when it's not the start of a delimiter '.*', './', or '.^' + * + * @param c + * @param cNext + */ + isDecimalMark(c: string, cNext: string): boolean + /** + * checks if the given char c is a digit or dot + * + * @param c a string with one character + */ + isDigitDot(c: string): boolean + /** + * checks if the given char c is a digit + * + * @param c a string with one character + */ + isDigit(c: string): boolean + /** + * checks if the given char c is a hex digit + * + * @param c a string with one character + */ + isHexDigit(c: string): boolean +} + +export interface NodeCtor { + new (): MathNode +} + +export interface AccessorNode + extends MathNode { + type: 'AccessorNode' + isAccessorNode: true + object: TObject + index: IndexNode + name: string +} +export interface AccessorNodeCtor { + new ( + object: TObject, + index: IndexNode + ): AccessorNode +} + +export interface ArrayNode + extends MathNode { + type: 'ArrayNode' + isArrayNode: true + items: [...TItems] +} +export interface ArrayNodeCtor { + new ( + items: [...TItems] + ): ArrayNode +} + +export interface AssignmentNode + extends MathNode { + type: 'AssignmentNode' + isAssignmentNode: true + object: SymbolNode | AccessorNode + index: IndexNode | null + value: TValue + name: string +} +export interface AssignmentNodeCtor { + new ( + object: SymbolNode, + value: TValue + ): AssignmentNode + new ( + object: SymbolNode | AccessorNode, + index: IndexNode, + value: TValue + ): AssignmentNode +} + +export interface BlockNode extends MathNode { + type: 'BlockNode' + isBlockNode: true + blocks: Array<{ node: TNode; visible: boolean }> +} +export interface BlockNodeCtor { + new ( + arr: Array<{ node: TNode } | { node: TNode; visible: boolean }> + ): BlockNode +} + +export interface ConditionalNode< + TCond extends MathNode = MathNode, + TTrueNode extends MathNode = MathNode, + TFalseNode extends MathNode = MathNode +> extends MathNode { + type: 'ConditionalNode' + isConditionalNode: boolean + condition: TCond + trueExpr: TTrueNode + falseExpr: TFalseNode +} +export interface ConditionalNodeCtor { + new < + TCond extends MathNode = MathNode, + TTrueNode extends MathNode = MathNode, + TFalseNode extends MathNode = MathNode + >( + condition: TCond, + trueExpr: TTrueNode, + falseExpr: TFalseNode + ): ConditionalNode +} + +export interface ConstantNode< + TValue extends + | string + | number + | boolean + | null + | undefined + | bigint + | BigNumber + | Fraction = number +> extends MathNode { + type: 'ConstantNode' + isConstantNode: true + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: TValue +} + +export interface ConstantNodeCtor { + new < + TValue extends + | string + | number + | boolean + | null + | undefined + | bigint + | BigNumber + | Fraction = string + >( + value: TValue + ): ConstantNode +} + +export interface FunctionAssignmentNode + extends MathNode { + type: 'FunctionAssignmentNode' + isFunctionAssignmentNode: true + name: string + params: string[] + expr: TExpr +} +export interface FunctionAssignmentNodeCtor { + new ( + name: string, + params: string[], + expr: TExpr + ): FunctionAssignmentNode +} + +export interface FunctionNode< + TFn = SymbolNode, + TArgs extends MathNode[] = MathNode[] +> extends MathNode { + type: 'FunctionNode' + isFunctionNode: true + fn: TFn + args: [...TArgs] +} +export interface FunctionNodeCtor { + new ( + fn: TFn, + args: [...TArgs] + ): FunctionNode + // eslint-disable-next-line @typescript-eslint/no-explicit-any + onUndefinedFunction: (name: string) => any +} + +export interface IndexNode + extends MathNode { + type: 'IndexNode' + isIndexNode: true + dimensions: [...TDims] + dotNotation: boolean +} +export interface IndexNodeCtor { + new (dimensions: [...TDims]): IndexNode + new ( + dimensions: [...TDims], + dotNotation: boolean + ): IndexNode +} + +export interface ObjectNode< + TProps extends Record = Record +> extends MathNode { + type: 'ObjectNode' + isObjectNode: true + properties: TProps +} +export interface ObjectNodeCtor { + new = Record>( + properties: TProps + ): ObjectNode +} + +export type OperatorNodeMap = { + xor: 'xor' + and: 'and' + or: 'or' + bitOr: '|' + bitXor: '^|' + bitAnd: '&' + equal: '==' + unequal: '!=' + smaller: '<' + larger: '>' + smallerEq: '<=' + largerEq: '>=' + leftShift: '<<' + rightArithShift: '>>' + rightLogShift: '>>>' + to: 'to' + add: '+' + subtract: '-' + multiply: '*' + divide: '/' + dotMultiply: '.*' + dotDivide: './' + mod: 'mod' + unaryPlus: '+' + unaryMinus: '-' + bitNot: '~' + not: 'not' + pow: '^' + dotPow: '.^' + factorial: '!' +} + +export type OperatorNodeOp = OperatorNodeMap[keyof OperatorNodeMap] +export type OperatorNodeFn = keyof OperatorNodeMap + +export interface OperatorNode< + TOp extends OperatorNodeMap[TFn] = never, + TFn extends OperatorNodeFn = never, + TArgs extends MathNode[] = MathNode[] +> extends MathNode { + type: 'OperatorNode' + isOperatorNode: true + op: TOp + fn: TFn + args: [...TArgs] + implicit: boolean + isUnary(): boolean + isBinary(): boolean +} + +export interface OperatorNodeCtor extends MathNode { + new < + TOp extends OperatorNodeMap[TFn], + TFn extends OperatorNodeFn, + TArgs extends MathNode[] + >( + op: TOp, + fn: TFn, + args: [...TArgs], + implicit?: boolean + ): OperatorNode +} +export interface ParenthesisNode + extends MathNode { + type: 'ParenthesisNode' + isParenthesisNode: true + content: TContent +} +export interface ParenthesisNodeCtor { + new (content: TContent): ParenthesisNode +} + +export interface RangeNode< + TStart extends MathNode = MathNode, + TEnd extends MathNode = MathNode, + TStep extends MathNode = MathNode +> extends MathNode { + type: 'RangeNode' + isRangeNode: true + start: TStart + end: TEnd + step: TStep | null +} +export interface RangeNodeCtor { + new < + TStart extends MathNode = MathNode, + TEnd extends MathNode = MathNode, + TStep extends MathNode = MathNode + >( + start: TStart, + end: TEnd, + step?: TStep + ): RangeNode +} + +export interface RelationalNode + extends MathNode { + type: 'RelationalNode' + isRelationalNode: true + conditionals: string[] + params: [...TParams] +} +export interface RelationalNodeCtor { + new ( + conditionals: string[], + params: [...TParams] + ): RelationalNode +} + +export interface SymbolNode extends MathNode { + type: 'SymbolNode' + isSymbolNode: true + name: string +} +export interface SymbolNodeCtor { + new (name: string): SymbolNode + // eslint-disable-next-line @typescript-eslint/no-explicit-any + onUndefinedSymbol: (name: string) => any +} + +/** + * @deprecated since version 11.3. Prefer `MathNode` instead + */ +export type MathNodeCommon = MathNode + +export type MathJsFunctionName = keyof MathJsInstance + +export interface LUDecomposition { + L: MathCollection + U: MathCollection + p: number[] +} + +export interface SLUDecomposition extends LUDecomposition { + q: number[] +} + +export interface QRDecomposition { + Q: MathCollection + R: MathCollection +} + +export interface SchurDecomposition { + U: MathCollection + T: MathCollection +} + +export interface FractionDefinition { + a: number + b: number +} + +export interface MathJsInstance extends MathJsFactory { + e: number + pi: number + i: number + Infinity: number + LN2: number + LN10: number + LOG2E: number + LOG10E: number + NaN: number + phi: number + SQRT1_2: number + SQRT2: number + tau: number + + // Class-like constructors + Node: NodeCtor + AccessorNode: AccessorNodeCtor + ArrayNode: ArrayNodeCtor + AssignmentNode: AssignmentNodeCtor + BlockNode: BlockNodeCtor + ConditionalNode: ConditionalNodeCtor + ConstantNode: ConstantNodeCtor + FunctionAssignmentNode: FunctionAssignmentNodeCtor + FunctionNode: FunctionNodeCtor + IndexNode: IndexNodeCtor + ObjectNode: ObjectNodeCtor + OperatorNode: OperatorNodeCtor + ParenthesisNode: ParenthesisNodeCtor + RangeNode: RangeNodeCtor + RelationalNode: RelationalNodeCtor + SymbolNode: SymbolNodeCtor + + Unit: UnitCtor + Matrix: MatrixCtor + + /** + * If null were to be included in this interface, it would be + * auto-suggested as an import in VSCode. This causes issues because + * `null` is not a valid label. + * + * @see https://github.com/josdejong/mathjs/issues/2019 + */ + // null: number; + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + uninitialized: any + version: string + + expression: MathNode + + /** + * Returns reviver function that can be used as reviver in JSON.parse function. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + reviver(): (key: any, value: any) => any + + /** + * Returns replacer function that can be used as replacer in JSON.stringify function. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + replacer(): (key: any, value: any) => any + + /************************************************************************* + * Core functions + ************************************************************************/ + + /** + * Set configuration options for math.js, and get current options. Will + * emit a ‘config’ event, with arguments (curr, prev, changes). + * @param options Available options: {number} relTol Minimum relative + * difference between two compared values, used by all comparison + * functions. {number} absTol Minimum absolute + * difference between two compared values, used by all comparison + * functions. {string} matrix A string ‘Matrix’ (default) or ‘Array’. + * {string} number A string ‘number’ (default), ‘BigNumber’, or + * ‘Fraction’ {number} precision The number of significant digits for + * BigNumbers. Not applicable for Numbers. {string} parenthesis How to + * display parentheses in LaTeX and string output. {string} randomSeed + * Random seed for seeded pseudo random number generator. Set to null to + * randomly seed. + * @returns Returns the current configuration + */ + config: (options: ConfigOptions) => ConfigOptions + /** + * Create a typed-function which checks the types of the arguments and + * can match them against multiple provided signatures. The + * typed-function automatically converts inputs in order to find a + * matching signature. Typed functions throw informative errors in case + * of wrong input arguments. + * @param name Optional name for the typed-function + * @param signatures Object with one or multiple function signatures + * @returns The created typed-function. + */ + typed: ( + name: string, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + signatures: Record any> + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ) => (...args: any[]) => any + + /************************************************************************* + * Construction functions + ************************************************************************/ + + /** + * Create a BigNumber, which can store numbers with arbitrary precision. + * When a matrix is provided, all elements will be converted to + * BigNumber. + * @param x Value for the big number, 0 by default. + * @returns The created bignumber + */ + bignumber( + x?: number | string | Fraction | BigNumber | bigint | Unit | boolean | null + ): BigNumber + bignumber(x: T): T + + /** + * Create a bigint, which can store integers with arbitrary precision. + * When a matrix is provided, all elements will be converted to + * bigint. + * @param x Value for the integer, 0 by default. + * @returns The created bigint + */ + bigint( + x?: number | string | Fraction | BigNumber | bigint | boolean | null + ): bigint + bigint(x: T): T + + /** + * Create a boolean or convert a string or number to a boolean. In case + * of a number, true is returned for non-zero numbers, and false in case + * of zero. Strings can be 'true' or 'false', or can contain a number. + * When value is a matrix, all elements will be converted to boolean. + * @param x A value of any type + * @returns The boolean value + */ + boolean(x: string | number | boolean | null): boolean + boolean(x: MathCollection): MathCollection + + /** + * Wrap any value in a chain, allowing to perform chained operations on + * the value. All methods available in the math.js library can be called + * upon the chain, and then will be evaluated with the value itself as + * first argument. The chain can be closed by executing chain.done(), + * which returns the final value. The chain has a number of special + * functions: done() Finalize the chain and return the chain's value. + * valueOf() The same as done() toString() Executes math.format() onto + * the chain's value, returning a string representation of the value. + * @param value A value of any type on which to start a chained + * operation. + * @returns The created chain + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + chain(value?: TValue): MathJsChain + + /** + * Create a complex value or convert a value to a complex value. + * @param args Arguments specifying the real and imaginary part of the + * complex number + * @returns Returns a complex value + */ + complex(arg?: MathNumericType | string | PolarCoordinates): Complex + complex(arg?: MathCollection): MathCollection + /** + * @param re Argument specifying the real part of the complex number + * @param im Argument specifying the imaginary part of the complex + * number + * @returns Returns a complex value + */ + complex(re: number, im: number): Complex + + /** + * Create a user-defined unit and register it with the Unit type. + * @param name The name of the new unit. Must be unique. Example: ‘knot’ + * @param definition Definition of the unit in terms of existing units. + * For example, ‘0.514444444 m / s’. + * @param options (optional) An object containing any of the following + * properties:
    - prefixes {string} “none”, “short”, “long”, + * “binary_short”, or “binary_long”. The default is “none”.
    - + * aliases {Array} Array of strings. Example: [‘knots’, ‘kt’, + * ‘kts’]
    - offset {Numeric} An offset to apply when converting from + * the unit. For example, the offset for celsius is 273.15. Default is + * 0. + * @returns The new unit + */ + createUnit( + name: string, + definition?: string | UnitDefinition | Unit, + options?: CreateUnitOptions + ): Unit + /** + * Create a user-defined unit and register it with the Unit type. + * @param units Definition of the unit + * @param options + * @returns The new unit + */ + createUnit( + units: Record, + options?: CreateUnitOptions + ): Unit + + /** + * Create a fraction convert a value to a fraction. + * @param value Arguments specifying the numerator and denominator of the + * fraction + * @returns Returns a fraction + */ + fraction( + value: + | number + | string + | BigNumber + | bigint + | Unit + | Fraction + | FractionDefinition + ): Fraction + fraction(values: MathCollection): MathCollection + /** + * @param numerator Argument specifying the numerator of the fraction + * @param denominator Argument specifying the denominator of the + * fraction + * @returns Returns a fraction + */ + fraction(numerator: number, denominator: number): Fraction + + /** + * Create an index. An Index can store ranges having start, step, and + * end for multiple dimensions. Matrix.get, Matrix.set, and math.subset + * accept an Index as input. + * @param ranges Zero or more ranges or numbers. + * @returns Returns the created index + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + index(...ranges: any[]): Index + + /** + * Create a Matrix. The function creates a new math.type.Matrix object + * from an Array. A Matrix has utility functions to manipulate the data + * in the matrix, like getting the size and getting or setting values in + * the matrix. Supported storage formats are 'dense' and 'sparse'. + * @param format The Matrix storage format + * @returns The created Matrix + */ + matrix(format?: 'sparse' | 'dense'): Matrix + /** + * @param data A multi dimensional array + * @param format The Matrix storage format + * @param dataType The Matrix data type + * @returns The created Matrix + */ + matrix( + data: MathCollection | string[], + format?: 'sparse' | 'dense', + dataType?: string + ): Matrix + + /** + * Create a number or convert a string, boolean, or unit to a number. + * When value is a matrix, all elements will be converted to number. + * @param value Value to be converted + * @returns The created number + */ + number( + value?: + | string + | number + | BigNumber + | bigint + | Fraction + | boolean + | Unit + | null + ): number + number(value?: MathCollection): number | MathCollection + /** + * @param value Value to be converted + * @param valuelessUnit A valueless unit, used to convert a unit to a + * number + * @returns The created number + */ + number(unit: Unit, valuelessUnit: Unit | string): number + + /** + * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction. + * @param value The value to be converted + * @param outputType The desired numeric output type + */ + numeric( + value: string | number | BigNumber | bigint | Fraction, + outputType: 'number' + ): number + numeric( + value: string | number | BigNumber | bigint | Fraction, + outputType: 'BigNumber' + ): BigNumber + numeric( + value: string | number | BigNumber | bigint | Fraction, + outputType: 'bigint' + ): bigint + numeric( + value: string | number | BigNumber | bigint | Fraction, + outputType: 'Fraction' + ): Fraction + + /** + * Create a Sparse Matrix. The function creates a new math.type.Matrix + * object from an Array. A Matrix has utility functions to manipulate + * the data in the matrix, like getting the size and getting or setting + * values in the matrix. + * @param data A two dimensional array + * @param dataType Sparse Matrix data type + * @returns The created matrix + */ + sparse(data?: MathCollection, dataType?: string): Matrix + + /** + * Split a unit in an array of units whose sum is equal to the original + * unit. + * @param unit A unit to be split + * @param parts An array of strings or valueless units + * @returns An array of units + */ + splitUnit(unit: Unit, parts: Unit[]): Unit[] + + /** + * Create a string or convert any object into a string. Elements of + * Arrays and Matrices are processed element wise. + * @param value A value to convert to a string + * @returns The created string + */ + string(value: MathNumericType | string | Unit | null): string + string(value: MathCollection): MathCollection + + /** + * Create a unit. Depending on the passed arguments, the function will + * create and return a new math.type.Unit object. When a matrix is + * provided, all elements will be converted to units. + * @param unit The unit to be created + * @returns The created unit + */ + unit(unit: string): Unit + /** + * @param unit The unit to be created + * @returns The created unit + */ + unit(unit: Unit): Unit + /** + * @param value The value of the unit to be created + * @param unit The unit to be created + * @returns The created unit + */ + unit(value: MathNumericType, unit: string): Unit + unit(value: MathCollection, unit: string): Unit[] + + /************************************************************************* + * Expression functions + ************************************************************************/ + + /** + * Parse and compile an expression. Returns a an object with a function + * evaluate([scope]) to evaluate the compiled expression. + * @param expr The expression to be compiled + * @returns An object with the compiled expression + */ + compile(expr: MathExpression): EvalFunction + /** + * @param exprs The expressions to be compiled + * @returns An array of objects with the compiled expressions + */ + compile(exprs: MathExpression[]): EvalFunction[] + + // TODO properly type this + /** + * Evaluate an expression. + * @param expr The expression to be evaluated + * @param scope Scope to read/write variables + * @returns The result of the expression + */ + evaluate( + expr: MathExpression | Matrix, + scope?: object + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ): any + evaluate( + expr: MathExpression[], + scope?: object + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ): any[] + + /** + * Retrieve help on a function or data type. Help files are retrieved + * from the documentation in math.expression.docs. + * @param search A function or function name for which to get help + * @returns A help object + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + help(search: () => any): Help + + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(); + */ + parse: ParseFunction + + /** + * Create a parser. The function creates a new math.expression.Parser + * object. + * @returns A Parser object + */ + parser(): Parser + + /************************************************************************* + * Algebra functions + ************************************************************************/ + /** + * @param expr The expression to differentiate + * @param variable The variable over which to differentiate + * @param options There is one option available, simplify, which is true + * by default. When false, output will not be simplified. + * @returns The derivative of expr + */ + derivative( + expr: MathNode | string, + variable: MathNode | string, + options?: { simplify: boolean } + ): MathNode + + /** + * Solves the linear equation system by forwards substitution. Matrix + * must be a lower triangular matrix. + * @param L A N x N matrix or array (L) + * @param b A column vector with the b values + * @returns A column vector with the linear system solution (x) + */ + lsolve(L: Matrix, b: MathCollection): Matrix + lsolve(L: MathArray, b: MathCollection): MathArray + + /** + * Calculate the Matrix LU decomposition with partial pivoting. Matrix A + * is decomposed in two matrices (L, U) and a row permutation vector p + * where A[p,:] = L * U + * @param A A two dimensional matrix or array for which to get the LUP + * decomposition. + * @returns The lower triangular matrix, the upper triangular matrix and + * the permutation matrix. + */ + lup(A?: MathCollection): LUDecomposition + + /** + * Solves the linear system A * x = b where A is an [n x n] matrix and b + * is a [n] column vector. + * @param A Invertible Matrix or the Matrix LU decomposition + * @param b Column Vector + * @param order The Symbolic Ordering and Analysis order, see slu for + * details. Matrix must be a SparseMatrix + * @param threshold Partial pivoting threshold (1 for partial pivoting), + * see slu for details. Matrix must be a SparseMatrix. + * @returns Column vector with the solution to the linear system A * x = + * b + */ + lusolve( + A: Matrix, + b: MathCollection, + order?: number, + threshold?: number + ): Matrix + + lusolve( + A: MathArray, + b: MathCollection, + order?: number, + threshold?: number + ): MathArray + + lusolve(A: LUDecomposition, b: MathCollection): Matrix + + /* Finds the roots of a polynomial of degree three or less. Coefficients are given constant first + * followed by linear and higher powers in order; coefficients beyond the degree of the polynomial + * need not be specified. + * @param {number|Complex} constantCoeff + * @param {number|Complex} linearCoeff + * @param {number|Complex} quadraticCoeff + * @param {number|Complex} cubicCoeff + * @returns {Array} array of roots of specified polynomial + */ + polynomialRoot( + constantCoeff: number | Complex, + linearCoeff: number | Complex, + quadraticCoeff?: number | Complex, + cubicCoeff?: number | Complex + ): (number | Complex)[] + + /** + * Calculate the Matrix QR decomposition. Matrix A is decomposed in two + * matrices (Q, R) where Q is an orthogonal matrix and R is an upper + * triangular matrix. + * @param A A two dimensional matrix or array for which to get the QR + * decomposition. + * @returns Q: the orthogonal matrix and R: the upper triangular matrix + */ + qr(A: MathCollection): QRDecomposition + + rationalize( + expr: MathNode | string, + optional?: object | boolean, + detailed?: false + ): MathNode + /** + * Transform a rationalizable expression in a rational fraction. If + * rational fraction is one variable polynomial then converts the + * numerator and denominator in canonical form, with decreasing + * exponents, returning the coefficients of numerator. + * @param expr The expression to check if is a polynomial expression + * @param optional scope of expression or true for already evaluated + * rational expression at input + * @param detailed optional True if return an object, false if return + * expression node (default) + * @returns The rational polynomial of expr + */ + rationalize( + expr: MathNode | string, + optional?: object | boolean, + detailed?: true + ): { + expression: MathNode | string + variables: string[] + coefficients: MathType[] + } + + /** + * Simplify an expression tree. + * @param expr The expression to be simplified + * @param [rules] (optional) A list of rules are applied to an expression, repeating + * over the list until no further changes are made. It’s possible to + * pass a custom set of rules to the function as second argument. A rule + * can be specified as an object, string, or function. + * @param [scope] (optional) Scope to variables + * @param [options] (optional) An object with simplify options + * @returns Returns the simplified form of expr + */ + simplify: Simplify + + simplifyConstant(expr: MathNode | string, options?: SimplifyOptions): MathNode + simplifyCore(expr: MathNode | string, options?: SimplifyOptions): MathNode + + /** + * Gives the number of “leaf nodes” in the parse tree of the given + * expression. A leaf node is one that has no subexpressions, essentially + * either a symbol or a constant. Note that `5!` has just one leaf, the `5`; + * the unary factorial operator does not add a leaf. On the other hand, + * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves. + */ + leafCount(expr: MathNode): number + + /** + * Replaces variable nodes with their scoped values + * @param node Tree to replace variable nodes in + * @param scope Scope to read/write variables + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + resolve(node: MathNode | string, scope?: Record): MathNode + resolve( + node: (MathNode | string)[], + // eslint-disable-next-line @typescript-eslint/no-explicit-any + scope?: Record + ): MathNode[] + // eslint-disable-next-line @typescript-eslint/no-explicit-any + resolve(node: Matrix, scope?: Record): Matrix + + /** + * Calculate the Sparse Matrix LU decomposition with full pivoting. + * Sparse Matrix A is decomposed in two matrices (L, U) and two + * permutation vectors (pinv, q) where P * A * Q = L * U + * @param A A two dimensional sparse matrix for which to get the LU + * decomposition. + * @param order The Symbolic Ordering and Analysis order: 0 - Natural + * ordering, no permutation vector q is returned 1 - Matrix must be + * square, symbolic ordering and analisis is performed on M = A + A' 2 - + * Symbolic ordering and analysis is performed on M = A' * A. Dense + * columns from A' are dropped, A recreated from A'. This is appropriate + * for LU factorization of non-symmetric matrices. 3 - Symbolic ordering + * and analysis is performed on M = A' * A. This is best used for LU + * factorization is matrix M has no dense rows. A dense row is a row + * with more than 10*sqr(columns) entries. + * @param threshold Partial pivoting threshold (1 for partial pivoting) + * @returns The lower triangular matrix, the upper triangular matrix and + * the permutation vectors. + */ + slu(A: Matrix, order: number, threshold: number): SLUDecomposition + + /** + * Solves the linear equation system by backward substitution. Matrix + * must be an upper triangular matrix. U * x = b + * @param U A N x N matrix or array (U) + * @param b A column vector with the b values + * @returns A column vector with the linear system solution (x) + */ + usolve(U: Matrix, b: MathCollection): Matrix + usolve(U: MathArray, b: MathCollection): MathArray + + /************************************************************************* + * Arithmetic functions + ************************************************************************/ + + /** + * Calculate the absolute value of a number. For matrices, the function + * is evaluated element wise. + * @param x A number or matrix for which to get the absolute value + * @returns Absolute value of x + */ + abs(x: T): T + + /** + * Add two values, x + y. For matrices, the function is evaluated + * element wise. + * @param x First value to add + * @param y Second value to add + * @returns Sum of x and y + */ + add(x: T, y: T): T + add(...values: T[]): T + add(x: MathType, y: MathType): MathType + add(...values: MathType[]): MathType + + /** + * Calculate the cubic root of a value. + * @param x Value for which to calculate the cubic root. + * @param allRoots Optional, false by default. Only applicable when x is + * a number or complex number. If true, all complex roots are returned, + * if false (default) the principal root is returned. + * @returns Returns the cubic root of x + */ + cbrt(x: Complex, allRoots?: boolean): Complex + cbrt(x: T): T + + // Rounding functions, grouped for similarity, even though it breaks + // the alphabetic order among arithmetic functions. + + /** + * Round a value towards plus infinity If x is complex, both real and + * imaginary part are rounded towards plus infinity. For matrices, the + * function is evaluated element wise. + * @param x Number to be rounded + * @param n Number of decimals Default value: 0. + * @returns Rounded value + */ + ceil( + x: T, + n?: number | BigNumber + ): NoLiteralType + ceil(x: MathNumericType, n: U): U + + /** + * Round a value towards zero. For matrices, the function is evaluated + * element wise. + * @param x Number to be rounded + * @param n Number of decimals Default value: 0. + * @returns Rounded value + */ + fix( + x: T, + n?: number | BigNumber + ): NoLiteralType + fix(x: MathNumericType, n: U): U + + /** + * Round a value towards minus infinity. For matrices, the function is + * evaluated element wise. + * @param x Number to be rounded + * @param n Number of decimals Default value: 0. + * @returns Rounded value + */ + floor( + x: T, + n?: number | BigNumber + ): NoLiteralType + floor(x: MathNumericType, n: U): U + + /** + * Round a value towards the nearest integer. For matrices, the function + * is evaluated element wise. + * @param x Number to be rounded + * @param n Number of decimals Default value: 0. + * @returns Rounded value of x + */ + round( + x: T, + n?: number | BigNumber + ): NoLiteralType + round(x: MathNumericType, n: U): U + round(x: U, unit: Unit): U + round(x: Unit, unit: Unit): Unit + round(x: Unit, n: number | BigNumber, unit: Unit): Unit + round(x: U, n: number | BigNumber, unit: Unit): U + + // End of group of rounding functions + + /** + * Compute the cube of a value, x * x * x. For matrices, the function is + * evaluated element wise. + * @param x Number for which to calculate the cube + * @returns Cube of x + */ + cube(x: T): T + + /** + * Divide two values, x / y. To divide matrices, x is multiplied with + * the inverse of y: x * inv(y). + * @param x Numerator + * @param y Denominator + * @returns Quotient, x / y + */ + divide(x: Unit, y: Unit): Unit | number + divide(x: Unit, y: number): Unit + divide(x: number, y: number): number + divide(x: MathType, y: MathType): MathType + + /** + * Divide two matrices element wise. The function accepts both matrices + * and scalar values. + * @param x Numerator + * @param y Denominator + * @returns Quotient, x ./ y + */ + dotDivide(x: T, y: MathType): T + dotDivide(x: MathType, y: T): T + dotDivide(x: Unit, y: MathType): Unit + dotDivide(x: MathType, y: Unit): Unit + dotDivide(x: MathNumericType, y: MathNumericType): MathNumericType + + /** + * Multiply two matrices element wise. The function accepts both + * matrices and scalar values. + * @param x Left hand value + * @param y Right hand value + * @returns Multiplication of x and y + */ + dotMultiply(x: T, y: MathType): T + dotMultiply(x: MathType, y: T): T + dotMultiply(x: Unit, y: MathType): Unit + dotMultiply(x: MathType, y: Unit): Unit + dotMultiply(x: MathNumericType, y: MathNumericType): MathNumericType + + /** + * Calculates the power of x to y element wise. + * @param x The base + * @param y The exponent + * @returns The value of x to the power y + */ + dotPow(x: T, y: MathType): T + + /** + * Calculate the exponent of a value. For matrices, the function is + * evaluated element wise. + * @param x A number or matrix to exponentiate + * @returns Exponent of x + */ + exp(x: T): T + + /** + * Calculate the value of subtracting 1 from the exponential value. For + * matrices, the function is evaluated element wise. + * @param x A number or matrix to apply expm1 + * @returns Exponent of x + */ + expm1(x: T): T + + /** + * Calculate the greatest common divisor for two or more values or + * arrays. For matrices, the function is evaluated element wise. + * @param args Two or more integer numbers + * @returns The greatest common divisor + */ + gcd(...args: T[]): T + gcd(args: T[]): T + + /** + * Calculate the hypotenuse of a list with values. The hypotenuse is + * defined as: hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...) For + * matrix input, the hypotenuse is calculated for all values in the + * matrix. + * @param args A list with numeric values or an Array or Matrix. Matrix + * and Array input is flattened and returns a single number for the + * whole matrix. + * @returns Returns the hypothenuse of the input values. + */ + hypot(...args: T[]): T + hypot(args: T[]): T + + /** + * Calculate the least common multiple for two or more values or arrays. + * lcm is defined as: lcm(a, b) = abs(a * b) / gcd(a, b) For matrices, + * the function is evaluated element wise. + * @param a An integer number + * @param b An integer number + * @returns The least common multiple + */ + lcm(a: T, b: T): T + + /** + * Calculate the logarithm of a value. + * @param x Value for which to calculate the logarithm. + * @param base Optional base for the logarithm. If not provided, the + * natural logarithm of x is calculated. Default value: e. + * @returns Returns the logarithm of x + */ + log( + x: T, + base?: number | BigNumber | Complex + ): NoLiteralType + + /** + * Calculate the 10-base of a value. This is the same as calculating + * log(x, 10). For matrices, the function is evaluated element wise. + * @param x Value for which to calculate the logarithm. + * @returns Returns the 10-base logarithm of x + */ + log10(x: T): T + + /** + * Calculate the logarithm of a value+1. For matrices, the function is + * evaluated element wise. + * @param x Value for which to calculate the logarithm. + * @returns Returns the logarithm of x+1 + */ + log1p( + x: T, + base?: number | BigNumber | Complex + ): T + + /** + * Calculate the 2-base of a value. This is the same as calculating + * log(x, 2). For matrices, the function is evaluated element wise. + * @param x Value for which to calculate the logarithm. + * @returns Returns the 2-base logarithm of x + */ + log2(x: T): T + + /** + * Calculates the modulus, the remainder of an integer division. For + * matrices, the function is evaluated element wise. The modulus is + * defined as: x - y * floor(x / y) + * @see http://en.wikipedia.org/wiki/Modulo_operation. + * @param x Dividend + * @param y Divisor + * @returns Returns the remainder of x divided by y + */ + mod( + x: T, + y: number | BigNumber | bigint | Fraction | MathCollection + ): NoLiteralType + + /** + * Multiply two values, x * y. The result is squeezed. For matrices, the + * matrix product is calculated. + * @param x The first value to multiply + * @param y The second value to multiply + * @returns Multiplication of x and y + */ + + multiply(x: T, y: MathType): Matrix + multiply(x: MathType, y: T): Matrix + + multiply(x: T, y: T[]): T + multiply(x: T[], y: T): T + multiply(x: T, y: T): T + multiply(x: Unit, y: Unit): Unit + multiply(x: number, y: number): number + multiply(x: MathType, y: MathType): MathType + multiply(...values: T[]): T + multiply(...values: MathType[]): MathType + + /** + * Calculate the norm of a number, vector or matrix. The second + * parameter p is optional. If not provided, it defaults to 2. + * @param x Value for which to calculate the norm + * @param p Vector space. Supported numbers include Infinity and + * -Infinity. Supported strings are: 'inf', '-inf', and 'fro' (The + * Frobenius norm) Default value: 2. + * @returns the p-norm + */ + norm( + x: number | BigNumber | Complex | MathCollection, + p?: number | BigNumber | string + ): number | BigNumber + + /** + * Calculate the nth root of a value. The principal nth root of a + * positive real number A, is the positive real solution of the equation + * x^root = A For matrices, the function is evaluated element wise. + * @param a Value for which to calculate the nth root + * @param root The root. Default value: 2. + * @return The nth root of a + */ + nthRoot( + a: number | BigNumber | MathCollection | Complex, + root?: number | BigNumber + ): number | Complex | MathCollection + + /** + * Calculates the power of x to y, x ^ y. Matrix exponentiation is + * supported for square matrices x, and positive integer exponents y. + * @param x The base + * @param y The exponent + * @returns x to the power y + */ + pow(x: MathType, y: number | BigNumber | bigint | Complex): MathType + + /** + * Compute the sign of a value. The sign of a value x is: 1 when x > 1 + * -1 when x < 0 0 when x == 0 For matrices, the function is evaluated + * element wise. + * @param x The number for which to determine the sign + * @returns The sign of x + */ + sign(x: T): T + + /** + * Calculate the square root of a value. For matrices, use either + * sqrtm for the matrix square root, or map(M, sqrt) to take the + * square root element wise. + * @param x Value for which to calculate the square root + * @returns Returns the square root of x + */ + sqrt(x: number): number | Complex + sqrt(x: T): T + + /** + * Compute the square of a value, x * x. + * @param x Number for which to calculate the square + * @returns Squared value + */ + square(x: T): T + + /** + * Subtract two values, x - y. For matrices, the function is evaluated + * element wise. + * @param x Initial value + * @param y Value to subtract from x + * @returns Subtraction of x and y + */ + subtract(x: T, y: T): T + subtract(x: MathType, y: MathType): MathType + + /** + * Inverse the sign of a value, apply a unary minus operation. For + * matrices, the function is evaluated element wise. Boolean values and + * strings will be converted to a number. For complex numbers, both real + * and complex value are inverted. + * @param x Number to be inverted + * @returns Retursn the value with inverted sign + */ + unaryMinus(x: T): T + + /** + * Unary plus operation. Boolean values and strings will be converted to + * a number, numeric values will be returned as is. For matrices, the + * function is evaluated element wise. + * @param x Input value + * @returns Returns the input value when numeric, converts to a number + * when input is non-numeric. + */ + unaryPlus(x: T): T + + /** + * Calculate the extended greatest common divisor for two values. See + * http://en.wikipedia.org/wiki/Extended_Euclidean_algorithm. + * @param a An integer number + * @param b An integer number + * @returns Returns an array containing 3 integers [div, m, n] where div + * = gcd(a, b) and a*m + b*n = div + */ + xgcd(a: number | BigNumber, b: number | BigNumber): MathArray + + /************************************************************************* + * Bitwise functions + ************************************************************************/ + + /** + * Bitwise AND two values, x & y. For matrices, the function is + * evaluated element wise. + * @param x First value to and + * @param y Second value to and + * @returns AND of x and y + */ + bitAnd( + x: T, + y: number | BigNumber | bigint | MathCollection + ): NoLiteralType + + /** + * Bitwise NOT value, ~x. For matrices, the function is evaluated + * element wise. For units, the function is evaluated on the best prefix + * base. + * @param x Value to not + * @returns NOT of x + */ + bitNot(x: T): T + + /** + * Bitwise OR two values, x | y. For matrices, the function is evaluated + * element wise. For units, the function is evaluated on the lowest + * print base. + * @param x First value to or + * @param y Second value to or + * @returns OR of x and y + */ + bitOr(x: T, y: T): T + + /** + * Bitwise XOR two values, x ^ y. For matrices, the function is + * evaluated element wise. + * @param x First value to xor + * @param y Second value to xor + * @returns XOR of x and y + */ + bitXor( + x: T, + y: number | BigNumber | bigint | MathCollection + ): NoLiteralType + + /** + * Bitwise left logical shift of a value x by y number of bits, x << y. + * For matrices, the function is evaluated element wise. For units, the + * function is evaluated on the best prefix base. + * @param x Value to be shifted + * @param y Amount of shifts + * @returns x shifted left y times + */ + leftShift( + x: T, + y: number | BigNumber | bigint + ): NoLiteralType + + /** + * Bitwise right arithmetic shift of a value x by y number of bits, x >> + * y. For matrices, the function is evaluated element wise. For units, + * the function is evaluated on the best prefix base. + * @param x Value to be shifted + * @param y Amount of shifts + * @returns x sign-filled shifted right y times + */ + rightArithShift( + x: T, + y: number | BigNumber | bigint + ): NoLiteralType + + /** + * Bitwise right logical shift of value x by y number of bits, x >>> y. + * For matrices, the function is evaluated element wise. For units, the + * function is evaluated on the best prefix base. + * @param x Value to be shifted + * @param y Amount of shifts + * @returns x zero-filled shifted right y times + */ + rightLogShift( + x: T, + y: number + ): NoLiteralType + + /************************************************************************* + * Combinatorics functions + ************************************************************************/ + + /** + * The Bell Numbers count the number of partitions of a set. A partition + * is a pairwise disjoint subset of S whose union is S. bellNumbers only + * takes integer arguments. The following condition must be enforced: n + * >= 0 + * @param n Total number of objects in the set + * @returns B(n) + */ + bellNumbers(n: T): T + + /** + * The Catalan Numbers enumerate combinatorial structures of many + * different types. catalan only takes integer arguments. The following + * condition must be enforced: n >= 0 + * @param n nth Catalan number + * @returns Cn(n) + */ + catalan(n: T): T + + /** + * The composition counts of n into k parts. Composition only takes + * integer arguments. The following condition must be enforced: k <= n. + * @param n Total number of objects in the set + * @param k Number of objects in the subset + * @returns Returns the composition counts of n into k parts. + */ + composition( + n: T, + k: number | BigNumber + ): NoLiteralType + + /** + * The Stirling numbers of the second kind, counts the number of ways to + * partition a set of n labelled objects into k nonempty unlabelled + * subsets. stirlingS2 only takes integer arguments. The following + * condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = + * 1 + * @param n Total number of objects in the set + * @param k Number of objects in the subset + * @returns S(n,k) + */ + stirlingS2( + n: T, + k: number | BigNumber + ): NoLiteralType + + /************************************************************************* + * Complex functions + ************************************************************************/ + + /** + * Compute the argument of a complex value. For a complex number a + bi, + * the argument is computed as atan2(b, a). For matrices, the function + * is evaluated element wise. + * @param x A complex number or array with complex numbers + * @returns The argument of x + */ + arg(x: number | Complex): number + arg(x: BigNumber | Complex): BigNumber + arg(x: T): T + + /** + * Compute the complex conjugate of a complex value. If x = a+bi, the + * complex conjugate of x is a - bi. For matrices, the function is + * evaluated element wise. + * @param x A complex number or array with complex numbers + * @returns The complex conjugate of x + */ + conj( + x: T + ): NoLiteralType + + /** + * Get the imaginary part of a complex number. For a complex number a + + * bi, the function returns b. For matrices, the function is evaluated + * element wise. + * @param x A complex number or array with complex numbers + * @returns The imaginary part of x + */ + im(x: MathJsChain): MathJsChain + im(x: MathJsChain): MathJsChain + + /** + * Get the real part of a complex number. For a complex number a + bi, + * the function returns a. For matrices, the function is evaluated + * element wise. + * @param x A complex number or array of complex numbers + * @returns The real part of x + */ + re(x: MathJsChain): MathJsChain + re(x: MathJsChain): MathJsChain + + /************************************************************************* + * Geometry functions + ************************************************************************/ + + /** + * Calculates: The eucledian distance between two points in 2 and 3 + * dimensional spaces. Distance between point and a line in 2 and 3 + * dimensional spaces. Pairwise distance between a set of 2D or 3D + * points NOTE: When substituting coefficients of a line(a, b and c), + * use ax + by + c = 0 instead of ax + by = c For parametric equation of + * a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, + * c) + * @param x Coordinates of the first point + * @param y Coordinates of the second point OR coefficients of a line in 3D OR first end-point of a line if the calculation is for distance between point and a line in 2D + * @param z Coordinates of second end-point of a line if the calculation is for distance between point and a line in 2D + * @returns Returns the distance from two/three points + */ + distance( + x: MathCollection | object, + y: MathCollection | object, + z?: MathCollection | object + ): number | BigNumber + + /** + * Calculates the point of intersection of two lines in two or three + * dimensions and of a line and a plane in three dimensions. The inputs + * are in the form of arrays or 1 dimensional matrices. The line + * intersection functions return null if the lines do not meet. Note: + * Fill the plane coefficients as x + y + z = c and not as x + y + z + c + * = 0. + * @param w Co-ordinates of first end-point of first line + * @param x Co-ordinates of second end-point of first line + * @param y Co-ordinates of first end-point of second line OR + * Coefficients of the plane's equation + * @param z Co-ordinates of second end-point of second line OR null if + * the calculation is for line and plane + * @returns Returns the point of intersection of lines/lines-planes + */ + intersect( + w: MathCollection, + x: MathCollection, + y: MathCollection, + z?: MathCollection + ): MathArray + + /************************************************************************* + * Logical functions + ************************************************************************/ + + /** + * Logical and. Test whether two values are both defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param x First value to and + * @param y Second value to and + * @returns Returns true when both inputs are defined with a + * nonzero/nonempty value. + */ + and( + x: number | BigNumber | bigint | Complex | Unit | MathCollection, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): boolean | MathCollection + + /** + * Logical not. Flips boolean value of a given parameter. For matrices, + * the function is evaluated element wise. + * @param x First value to not + * @returns Returns true when input is a zero or empty value. + */ + not( + x: number | BigNumber | bigint | Complex | Unit | MathCollection + ): boolean | MathCollection + + /** + * Logical or. Test if at least one value is defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param x First value to or + * @param y Second value to or + * @returns Returns true when one of the inputs is defined with a + * nonzero/nonempty value. + */ + or( + x: number | BigNumber | bigint | Complex | Unit | MathCollection, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): boolean | MathCollection + + /** + * Logical xor. Test whether one and only one value is defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param x First value to xor + * @param y Second value to xor + * @returns Returns true when one and only one input is defined with a + * nonzero/nonempty value. + */ + xor( + x: number | BigNumber | bigint | Complex | Unit | MathCollection, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): boolean | MathCollection + + /************************************************************************* + * Matrix functions + ************************************************************************/ + + /** + * Apply a function that maps an array to a scalar along a given axis of a + * matrix or array. Returns a new matrix or array with one less dimension + * than the input. + * @param array The input Matrix + * @param dim The dimension along which the callback is applied + * @param callback The callback function that is applied. This Function should take an + * array or 1-d matrix as an input and return a number. + * @returns The residual matrix with the function applied over some dimension. + */ + apply( + array: T, + dim: number, + callback: (array: MathCollection) => number + ): T + + /** + * Concatenate two or more matrices. dim: number is a zero-based + * dimension over which to concatenate the matrices. By default the last + * dimension of the matrices. + * @param args Two or more matrices + * @returns Concatenated matrix + */ + concat(...args: Array): MathCollection + + /** + * Calculate the cross product for two vectors in three dimensional + * space. The cross product of A = [a1, a2, a3] and B =[b1, b2, b3] is + * defined as: cross(A, B) = [ a2 * b3 - a3 * b2, a3 * b1 - a1 * b3, a1 + * * b2 - a2 * b1 ] + * @param x First vector + * @param y Second vector + * @returns Returns the cross product of x and y + */ + cross(x: MathCollection, y: MathCollection): MathCollection + + /** + * Calculate the determinant of a matrix. + * @param x A Matrix + * @returns the determinant of x + */ + det(x: MathCollection): number + + /** + * Create a diagonal matrix or retrieve the diagonal of a matrix. When x + * is a vector, a matrix with vector x on the diagonal will be returned. + * When x is a two dimensional matrix, the matrixes kth diagonal will be + * returned as vector. When k is positive, the values are placed on the + * super diagonal. When k is negative, the values are placed on the sub + * diagonal. + * @param X A two dimensional matrix or a vector + * @param k The diagonal where the vector will be filled in or + * retrieved. Default value: 0. + * @param format The matrix storage format. Default value: 'dense'. + * @returns Diagonal matrix from input vector, or diagonal from input + * matrix + */ + diag(X: MathCollection, format?: string): Matrix + diag( + X: MathCollection, + k: number | BigNumber, + format?: string + ): MathCollection + + /** + * Calculate the dot product of two vectors. The dot product of A = [a1, + * a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] is defined as: dot(A, + * B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn + * @param x First vector + * @param y Second vector + * @returns Returns the dot product of x and y + */ + dot(x: MathCollection, y: MathCollection): number + + /** + * Compute eigenvalues and eigenvectors of a matrix. + * The eigenvalues are sorted by their absolute value, ascending. + * An eigenvalue with multiplicity k will be listed k times. + * The eigenvectors are returned as an array of objects, each with a + * `value` and a `vector`. If the algorithm fails to converge, + * it will throw an error – in that case, however, you may still find useful + * information in err.values and err.vectors + * @param x Matrix to be diagonalized + * @param prec Precision, default value: 1e-15 + * @returns Object containing an array of eigenvalues and a matrix with eigenvectors as columns. + */ + eigs( + x: MathCollection, + opts?: + | number + | BigNumber + | { precision?: number | BigNumber; eigenvectors?: true } + ): { + values: MathCollection + eigenvectors: { + value: number | BigNumber + vector: MathCollection + }[] + } + eigs( + x: MathCollection, + opts: { eigenvectors: false; precision?: number | BigNumber } + ): { values: MathCollection } + /** + * Compute the matrix exponential, expm(A) = e^A. The matrix must be + * square. Not to be confused with exp(a), which performs element-wise + * exponentiation. The exponential is calculated using the Padé + * approximant with scaling and squaring; see “Nineteen Dubious Ways to + * Compute the Exponential of a Matrix,” by Moler and Van Loan. + * @param x A square matrix + * @returns The exponential of x + */ + expm(x: Matrix): Matrix + + /** + * Solves the real-valued Sylvester equation AX-XB=C for X, where A, B and C are + * matrices of appropriate dimensions, being A and B squared. The method used is + * the Bartels-Stewart algorithm. + * https://en.wikipedia.org/wiki/Sylvester_equation + * @param A Matrix A + * @param B Matrix B + * @param C Matrix C + * @returns Matrix X, solving the Sylvester equation + */ + sylvester( + A: MathCollection, + B: MathCollection, + C: MathCollection + ): MathCollection + + /** + * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal + * and T is upper quasi-triangular. + * https://en.wikipedia.org/wiki/Schur_decomposition + * @param A Matrix A + * @returns Object containing both matrix U and T of the Schur Decomposition A=UTU' + */ + schur(A: MathCollection): SchurDecomposition + + /** + * Solves the Continuous-time Lyapunov equation AP+PA'=Q for P, where Q is a positive semidefinite + * matrix. + * https://en.wikipedia.org/wiki/Lyapunov_equation + * @param A Matrix A + * @param Q Matrix Q + * @returns Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q + */ + lyap(A: MathCollection, Q: MathCollection): MathCollection + + /** + * Create a 2-dimensional identity matrix with size m x n or n x n. The + * matrix has ones on the diagonal and zeros elsewhere. + * @param size The size for the matrix + * @param format The Matrix storage format + * @returns A matrix with ones on the diagonal + */ + identity( + size: number | number[] | MathCollection, + format?: string + ): MathCollection | number + /** + * @param m The x dimension for the matrix + * @param n The y dimension for the matrix + * @param format The Matrix storage format + * @returns A matrix with ones on the diagonal + */ + identity(m: number, n: number, format?: string): MathCollection | number + + /** + * Filter the items in an array or one dimensional matrix. + * @param x A one dimensional matrix or array to filter + * @param test A function or regular expression to test items. All + * entries for which test returns true are returned. When test is a + * function, it is invoked with three parameters: the value of the + * element, the index of the element, and the matrix/array being + * traversed. The function must return a boolean. + */ + filter( + x: MathCollection | string[], + test: + | (( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + index: any, + matrix: MathCollection | string[] + ) => boolean) + | RegExp + ): MathCollection + + /** + * Flatten a multi dimensional matrix into a single dimensional matrix. + * @param x Matrix to be flattened + * @returns Returns the flattened matrix + */ + flatten(x: T): T + + /** + * Iterate over all elements of a matrix/array, and executes the given + * callback function. + * @param x The matrix to iterate on. + * @param callback The callback function is invoked with three + * parameters: the value of the element, the index of the element, and + * the Matrix/array being traversed. + */ + forEach( + x: T, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (value: any, index: any, matrix: T) => void + ): void + + /** + * Calculate the inverse of a square matrix. + * @param x Matrix to be inversed + * @returns The inverse of x + */ + inv(x: T): NoLiteralType + + /** + * Calculate the Kronecker product of two matrices or vectors + * @param x First vector + * @param y Second vector + * @returns Returns the Kronecker product of x and y + */ + kron(x: MathCollection, y: MathCollection): Matrix + + /** + * Iterate over all elements of a matrix/array, and executes the given + * callback function. + * @param x The matrix to iterate on. + * @param callback The callback function is invoked with three + * parameters: the value of the element, the index of the element, and + * the Matrix/array being traversed. + * @returns Transformed map of x + */ + map( + x: T, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (value: any, index: number[], matrix: T) => MathType | string + ): T + + /** + * Iterate over all elements of multiple matrices/arrays, and executes the given + * callback function. + * @param x The first matrix to iterate on. + * @param args The rest of the matrices and at the end the callback function is invoked with multiple + * parameters: the values of the elements, the indices of the elements, and + * the matrices/arrays being traversed. + * @returns Transformed map of matrices + */ + map( + x: T, + ...args: Array< + | T + | (( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ...args: Array + ) => MathType | string) + > + ): T + + /** + * Create a matrix filled with ones. The created matrix can have one or + * multiple dimensions. + * @param size The size of each dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with ones + */ + ones( + size?: number | number[] | BigNumber | BigNumber[], + format?: string + ): MathCollection + /** + * @param m The x dimension of the matrix + * @param n The y dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with ones + */ + ones( + m: number | BigNumber, + n: number | BigNumber, + format?: string + ): MathCollection + /** + * @param m The x dimension of the matrix + * @param n The y dimension of the matrix + * @param p The z dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with ones + */ + ones( + m: number | BigNumber, + n: number | BigNumber, + p: number | BigNumber, + format?: string + ): MathCollection + /** Actually ones can take an arbitrary number of dimensions before the + ** optional format, not sure how to write that in TypeScript + **/ + + /** + * Partition-based selection of an array or 1D matrix. Will find the kth + * smallest value, and mutates the input array. Uses Quickselect. + * @param x A one dimensional matrix or array to sort + * @param k The kth smallest value to be retrieved; zero-based index + * @param compare An optional comparator function. The function is + * called as compare(a, b), and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. Default value: 'asc'. + * @returns Returns the kth lowest value. + */ + partitionSelect( + x: MathCollection, + k: number, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compare?: 'asc' | 'desc' | ((a: any, b: any) => number) + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ): any + + /** + * Calculate the Moore–Penrose inverse of a matrix. + * @param x Matrix to be inversed + * @return The inverse of `x`. + */ + pinv(x: T): T + + /** + * Create an array from a range. By default, the range end is excluded. + * This can be customized by providing an extra parameter includeEnd. + * @param str A string 'start:end' or 'start:step:end' + * @param start Start of the range + * @param end End of the range, excluded by default, included when + * parameter includeEnd=true + * @param step Step size. Default value is 1. + * @param includeEnd: Option to specify whether to include the end or + * not. False by default + * @returns Parameters describing the ranges start, end, and optional + * step. + */ + range(str: string, includeEnd?: boolean): Matrix + range( + start: number | BigNumber, + end: number | BigNumber, + includeEnd?: boolean + ): Matrix + range( + start: number | BigNumber | Unit, + end: number | BigNumber | Unit, + step: number | BigNumber | Unit, + includeEnd?: boolean + ): Matrix + + /** + * Reshape a multi dimensional array to fit the specified dimensions + * @param x Matrix to be reshaped + * @param sizes One dimensional array with integral sizes for each + * dimension + * @returns A reshaped clone of matrix x + */ + reshape(x: T, sizes: number[]): T + + /** + * Resize a matrix + * @param x Matrix to be resized + * @param size One dimensional array with numbers + * @param defaultValue Zero by default, except in case of a string, in + * that case defaultValue = ' ' Default value: 0. + * @returns A resized clone of matrix x + */ + resize( + x: T, + size: MathCollection, + defaultValue?: number | string + ): T + + /** + * Return a Rotation Matrix for a given angle in radians + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @param {string} [format] Result Matrix storage format. Default value: 'dense'. + * @return {Matrix} Rotation Matrix + */ + rotationMatrix( + theta?: number | BigNumber | Complex | Unit, + axis?: T, + format?: 'sparse' | 'dense' + ): T + + /** + * Return a row from a Matrix. + * @param value An array or matrix + * @param row The index of the row + * @returns The retrieved row + */ + row(value: T, row: number): T + + /** + * Return a column from a Matrix. + * @param value An array or matrix + * @param column The index of the column + * @returns The retrieved column + */ + column(value: T, column: number): T + + /** + * Return a rotated matrix. + * @param {Array | Matrix} w Vector to rotate + * @param {number | BigNumber | Complex | Unit} theta Rotation angle + * @param {Array | Matrix} [v] Rotation axis + * @return {Array | Matrix} Multiplication of the rotation matrix and w + */ + rotate( + w: T, + theta: number | BigNumber | Complex | Unit, + v?: T + ): T + + /** + * Calculate the size of a matrix or scalar. + * @param A matrix + * @returns A vector with the size of x + */ + size( + x: boolean | number | Complex | Unit | string | MathCollection + ): MathCollection + + /** + * Sort the items in a matrix + * @param x A one dimensional matrix or array to sort + * @param compare An optional _comparator function or name. The function + * is called as compare(a, b), and must return 1 when a > b, -1 when a < + * b, and 0 when a == b. Default value: ‘asc’ + * @returns Returns the sorted matrix + */ + sort( + x: T, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compare: ((a: any, b: any) => number) | 'asc' | 'desc' | 'natural' + ): T + + /** + * Calculate the principal square root of a square matrix. The principal + * square root matrix X of another matrix A is such that X * X = A. + * @param A The square matrix A + * @returns The principal square root of matrix A + */ + sqrtm(A: T): T + + /** + * Squeeze a matrix, remove inner and outer singleton dimensions from a + * matrix. + * @param x Matrix to be squeezed + * @returns Squeezed matrix + */ + squeeze(x: T): T + + /** + * Get or set a subset of a matrix or string. + * @param value An array, matrix, or string + * @param index For each dimension, an index or list of indices to get or set. + * @param replacement An array, matrix, or scalar. If provided, the + * subset is replaced with replacement. If not provided, the subset is + * returned + * @param defaultValue Default value, filled in on new entries when the + * matrix is resized. If not provided, math.matrix elements will be left + * undefined. Default value: undefined. + * @returns Either the retrieved subset or the updated matrix + */ + subset( + value: T, + index: Index, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + replacement?: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + defaultValue?: any + ): T + + /** + * Calculate the trace of a matrix: the sum of the elements on the main + * diagonal of a square matrix. + * @param x A matrix + * @returns The trace of x + */ + trace(x: MathCollection): number + + /** + * Transpose a matrix. All values of the matrix are reflected over its + * main diagonal. Only two dimensional matrices are supported. + * @param x Matrix to be transposed + * @returns The transposed matrix + */ + transpose(x: T): T + + /** + * Create a matrix filled with zeros. The created matrix can have one or + * multiple dimensions. + * @param size The size of each dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with zeros + */ + zeros( + size?: number | number[] | BigNumber | BigNumber[], + format?: string + ): MathCollection + /** + * @param m The x dimension of the matrix + * @param n The y dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with zeros + */ + zeros( + m: number | BigNumber, + n: number | BigNumber, + format?: string + ): MathCollection + /** + * @param m The x dimension of the matrix + * @param n The y dimension of the matrix + * @param p The z dimension of the matrix + * @param format The matrix storage format + * @returns A matrix filled with zeros + */ + zeros( + m: number | BigNumber, + n: number | BigNumber, + p: number | BigNumber, + format?: string + ): MathCollection + /** Actually zeros can take any number of dimensions before the + ** optional format, not sure how to write that in TypeScript + **/ + + /** + * Calculate N-dimensional Fourier transform + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + fft(arr: T): T + + /** + * Calculate N-dimensional inverse Fourier transform + * @param {Array | Matrix} arr An array or matrix + * @return {Array | Matrix} N-dimensional Fourier transformation of the array + */ + ifft(arr: T): T + + /************************************************************************* + * Probability functions + ************************************************************************/ + + /** + * Compute the number of ways of picking k unordered outcomes from n + * possibilities. Combinations only takes integer arguments. The + * following condition must be enforced: k <= n. + * @param n Total number of objects in the set + * @param k Number of objects in the subset + * @returns Number of possible combinations + */ + combinations( + n: T, + k: number | BigNumber + ): NoLiteralType + + /** + * Compute the factorial of a value Factorial only supports an integer + * value as argument. For matrices, the function is evaluated element + * wise. + * @param n An integer number + * @returns The factorial of n + */ + factorial( + n: T + ): NoLiteralType + + /** + * Compute the gamma function of a value using Lanczos approximation for + * small values, and an extended Stirling approximation for large + * values. + * @param n A real or complex number + * @returns The gamma of n + */ + gamma(n: T): NoLiteralType + + /** + * Calculate the Kullback-Leibler (KL) divergence between two + * distributions + * @param q First vector + * @param p Second vector + * @returns Returns disance between q and p + */ + kldivergence(q: MathCollection, p: MathCollection): number + + /** + * Compute the log gamma function of a value, using Lanczos approximation for numbers and Stirling series for complex numbers. + * @param n A real or complex number + * @returns The log gamma of `n` + */ + lgamma(n: T): NoLiteralType + + /** + * Multinomial Coefficients compute the number of ways of picking a1, + * a2, ..., ai unordered outcomes from n possibilities. multinomial + * takes one array of integers as an argument. The following condition + * must be enforced: every ai <= 0 + * @param a Integer number of objects in the subset + * @returns multinomial coefficent + */ + multinomial(a: T[]): NoLiteralType + + /** + * Compute the number of ways of obtaining an ordered subset of k + * elements from a set of n elements. Permutations only takes integer + * arguments. The following condition must be enforced: k <= n. + * @param n The number of objects in total + * @param k The number of objects in the subset + * @returns The number of permutations + */ + permutations( + n: T, + k?: number | BigNumber + ): NoLiteralType + + /** + * Random pick a value from a one dimensional array. Array element is + * picked using a random function with uniform distribution. + * @param array A one dimensional array + * @param number An int or float + * @param weights An array of ints or floats + * @returns Returns a single random value from array when number is undefined. + * Returns an array with the configured number of elements when number is defined. + */ + pickRandom(array: T[]): T + pickRandom(array: T[], number: number): T[] + pickRandom(array: T[], number: number, weights: number[]): T[] + + /** + * Return a random number larger or equal to min and smaller than max + * using a uniform distribution. + * @param size If provided, an array or matrix with given size and + * filled with random values is returned + * @param min Minimum boundary for the random value, included + * @param max Maximum boundary for the random value, excluded + * @returns A random number + */ + random(min?: number, max?: number): number + random(size: T, min?: number, max?: number): T + + /** + * Return a random integer number larger or equal to min and smaller + * than max using a uniform distribution. + * @param size If provided, an array or matrix with given size and + * filled with random values is returned + * @param min Minimum boundary for the random value, included + * @param max Maximum boundary for the random value, excluded + * @returns A random number + */ + randomInt(min: number, max?: number): number + randomInt(size: T, min?: number, max?: number): T + + /************************************************************************* + * Relational functions + ************************************************************************/ + + /** + * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x + * == y. x and y are considered equal when the relative difference + * between x and y is smaller than the configured relTol and absTol. The function + * cannot be used to compare values smaller than approximately 2.22e-16. + * For matrices, the function is evaluated element wise. + * @param x First value to compare + * @param y Second value to compare + * @returns Returns the result of the comparison: 1 when x > y, -1 when + * x < y, and 0 when x == y. + */ + compare( + x: MathType | string, + y: MathType | string + ): number | BigNumber | Fraction | MathCollection + + /** + * Compare two values of any type in a deterministic, natural way. For + * numeric values, the function works the same as math.compare. For + * types of values that can’t be compared mathematically, the function + * compares in a natural way. + * @param x First value to compare + * @param y Second value to compare + * @returns Returns the result of the comparison: 1 when x > y, -1 when + * x < y, and 0 when x == y. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compareNatural(x: any, y: any): number + + /** + * Compare two strings lexically. Comparison is case sensitive. Returns + * 1 when x > y, -1 when x < y, and 0 when x == y. For matrices, the + * function is evaluated element wise. + * @param x First string to compare + * @param y Second string to compare + * @returns Returns the result of the comparison: 1 when x > y, -1 when + * x < y, and 0 when x == y. + */ + compareText( + x: string | MathCollection, + y: string | MathCollection + ): number | MathCollection + + /** + * Test element wise whether two matrices are equal. The function + * accepts both matrices and scalar values. + * @param x First matrix to compare + * @param y Second amtrix to compare + * @returns Returns true when the input matrices have the same size and + * each of their elements is equal. + */ + deepEqual(x: MathType, y: MathType): MathType + + /** + * Test whether two values are equal. + * + * The function tests whether the relative difference between x and y is + * smaller than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. For matrices, the + * function is evaluated element wise. In case of complex numbers, x.re + * must equal y.re, and x.im must equal y.im. Values null and undefined + * are compared strictly, thus null is only equal to null and nothing + * else, and undefined is only equal to undefined and nothing else. + * @param x First value to compare + * @param y Second value to compare + * @returns Returns true when the compared values are equal, else + * returns false + */ + equal(x: MathType | string, y: MathType | string): boolean | MathCollection + + /** + * Check equality of two strings. Comparison is case sensitive. For + * matrices, the function is evaluated element wise. + * @param x First string to compare + * @param y Second string to compare + * @returns Returns true if the values are equal, and false if not. + */ + equalText( + x: string | MathCollection, + y: string | MathCollection + ): number | MathCollection + + /** + * Test whether value x is larger than y. The function returns true when + * x is larger than y and the relative difference between x and y is + * larger than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. For matrices, the + * function is evaluated element wise. + * @param x First value to compare + * @param y Second value to vcompare + * @returns Returns true when x is larger than y, else returns false + */ + larger(x: MathType | string, y: MathType | string): boolean | MathCollection + + /** + * Test whether value x is larger or equal to y. The function returns + * true when x is larger than y or the relative difference between x and + * y is smaller than the configured relTol and absTol. The function cannot be used + * to compare values smaller than approximately 2.22e-16. For matrices, + * the function is evaluated element wise. + * @param x First value to compare + * @param y Second value to vcompare + * @returns Returns true when x is larger than or equal to y, else + * returns false + */ + largerEq(x: MathType | string, y: MathType | string): boolean | MathCollection + + /** + * Test whether value x is smaller than y. The function returns true + * when x is smaller than y and the relative difference between x and y + * is smaller than the configured relTol and absTol. The function cannot be used + * to compare values smaller than approximately 2.22e-16. For matrices, + * the function is evaluated element wise. + * @param x First value to compare + * @param y Second value to vcompare + * @returns Returns true when x is smaller than y, else returns false + */ + smaller(x: MathType | string, y: MathType | string): boolean | MathCollection + + /** + * Test whether value x is smaller or equal to y. The function returns + * true when x is smaller than y or the relative difference between x + * and y is smaller than the configured relTol and absTol. The function cannot be + * used to compare values smaller than approximately 2.22e-16. For + * matrices, the function is evaluated element wise. + * @param x First value to compare + * @param y Second value to vcompare + * @returns Returns true when x is smaller than or equal to y, else + * returns false + */ + smallerEq( + x: MathType | string, + y: MathType | string + ): boolean | MathCollection + + /** + * Determines if two expressions are symbolically equal, i.e. one is the + * result of valid algebraic manipulations on the other. + * @param {Node} expr1 The first expression to compare + * @param {Node} expr2 The second expression to compare + * @param {Object} [options] Optional option object, passed to simplify + * @returns {boolean} Returns true if a valid manipulation making the + * expressions equal is found. + */ + symbolicEqual( + expr1: MathNode, + expr2: MathNode, + options?: SimplifyOptions + ): boolean + + /** + * Test whether two values are unequal. The function tests whether the + * relative difference between x and y is larger than the configured + * relTol and absTol. The function cannot be used to compare values smaller than + * approximately 2.22e-16. For matrices, the function is evaluated + * element wise. In case of complex numbers, x.re must unequal y.re, or + * x.im must unequal y.im. Values null and undefined are compared + * strictly, thus null is unequal with everything except null, and + * undefined is unequal with everything except undefined. + * @param x First value to compare + * @param y Second value to vcompare + * @returns Returns true when the compared values are unequal, else + * returns false + */ + unequal(x: MathType | string, y: MathType | string): boolean | MathCollection + + /************************************************************************* + * Set functions + ************************************************************************/ + + /** + * Create the cartesian product of two (multi)sets. Multi-dimension + * arrays will be converted to single-dimension arrays and the values + * will be sorted in ascending order before the operation. + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns The cartesian product of two (multi)sets + */ + setCartesian(a1: T, a2: MathCollection): T + + /** + * Create the difference of two (multi)sets: every element of set1, that + * is not the element of set2. Multi-dimension arrays will be converted + * to single-dimension arrays before the operation + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns The difference of two (multi)sets + */ + setDifference(a1: T, a2: MathCollection): T + + /** + * Collect the distinct elements of a multiset. A multi-dimension array + * will be converted to a single-dimension array before the operation. + * @param a A multiset + * @returns A set containing the distinct elements of the multiset + */ + setDistinct(a: T): T + + /** + * Create the intersection of two (multi)sets. Multi-dimension arrays + * will be converted to single-dimension arrays before the operation. + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns The intersection of two (multi)sets + */ + setIntersect(a1: T, a2: MathCollection): T + + /** + * Check whether a (multi)set is a subset of another (multi)set. (Every + * element of set1 is the element of set2.) Multi-dimension arrays will + * be converted to single-dimension arrays before the operation. + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns True if a1 is subset of a2, else false + */ + setIsSubset(a1: MathCollection, a2: MathCollection): boolean + + /** + * Count the multiplicity of an element in a multiset. A multi-dimension + * array will be converted to a single-dimension array before the + * operation. + * @param e An element in the multiset + * @param a A multiset + * @returns The number of how many times the multiset contains the + * element + */ + setMultiplicity(e: MathNumericType, a: MathCollection): number + + /** + * Create the powerset of a (multi)set. (The powerset contains very + * possible subsets of a (multi)set.) A multi-dimension array will be + * converted to a single-dimension array before the operation. + * @param a A multiset + * @returns The powerset of the (multi)set + */ + setPowerset(a: T): T + + /** + * Count the number of elements of a (multi)set. When a second parameter + * is ‘true’, count only the unique values. A multi-dimension array will + * be converted to a single-dimension array before the operation. + * @param a A multiset + * @returns The number of elements of the (multi)set + */ + setSize(a: MathCollection): number + + /** + * Create the symmetric difference of two (multi)sets. Multi-dimension + * arrays will be converted to single-dimension arrays before the + * operation. + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns The symmetric difference of two (multi)sets + */ + setSymDifference(a1: T, a2: MathCollection): T + + /** + * Create the union of two (multi)sets. Multi-dimension arrays will be + * converted to single-dimension arrays before the operation. + * @param a1 A (multi)set + * @param a2 A (multi)set + * @returns The union of two (multi)sets + */ + setUnion(a1: T, a2: MathCollection): T + + /************************************************************************* + * Signal functions + ************************************************************************/ + /** + * Compute the transfer function of a zero-pole-gain model. + * @param z Zeroes of the model + * @param p Poles of the model + * @param k Gain of the model + * @returns The transfer function as array of numerator and denominator + */ + zpk2tf(z: T, p: T, k?: number): T + + /** + * Calculates the frequency response of a filter given its numerator and denominator coefficients. + * @param b The numerator polynomial of the filter + * @param a The denominator polynomial of the filter + * @param w The range of frequencies in which the response is to be calculated + * @returns The frequency response + * + */ + freqz(b: T, a: T, w?: number | T): { w: T; h: T } + + /************************************************************************* + * Special functions + ************************************************************************/ + + /** + * Compute the erf function of a value using a rational Chebyshev + * approximations for different intervals of x. + * @param x A real number + * @returns The erf of x + */ + erf(x: T): NoLiteralType + + /** + * Compute the Riemann Zeta function of a value using an infinite series + * and Riemann's Functional equation. + * @param s A real, complex or BigNumber + * @returns The Riemann Zeta of s + */ + zeta(s: T): T + + /************************************************************************* + * Statistics functions + ************************************************************************/ + + /** + * Compute the median absolute deviation of a matrix or a list with + * values. The median absolute deviation is defined as the median of the + * absolute deviations from the median. + * @param array A single matrix or multiple scalar values. + * @returns The median absolute deviation + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + mad(array: MathCollection): any + + /** + * Compute the maximum value of a matrix or a list with values. In case + * of a multi dimensional array, the maximum of the flattened array will + * be calculated. When dim is provided, the maximum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param args Multiple scalar values + * @returns The maximum value + */ + max(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The maximum value + */ + max(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @param dimension The maximum over the selected dimension + * @returns The maximum value + */ + max( + A: T[] | T[][], + dimension?: number | BigNumber + ): T + /** + * @param A A single matrix + * @param dimension The maximum over the selected dimension + * @returns The maximum value + */ + max(A: MathCollection, dimension?: number | BigNumber): MathScalarType + + /** + * Compute the mean value of matrix or a list with values. In case of a + * multi dimensional array, the mean of the flattened array will be + * calculated. When dim is provided, the maximum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param args Multiple scalar values + * @returns The mean of all values + */ + mean(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The mean value + */ + mean(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @param dimension The mean over the selected dimension + * @returns The mean value + */ + mean( + A: T[] | T[][], + dimension?: number | BigNumber + ): T + /** + * @param A A single matrix + * @param dimension The mean over the selected dimension + * @returns The mean value + */ + mean(A: MathCollection, dimension?: number | BigNumber): MathScalarType + + /** + * Compute the median of a matrix or a list with values. The values are + * sorted and the middle value is returned. In case of an even number of + * values, the average of the two middle values is returned. Supported + * types of values are: Number, BigNumber, Unit In case of a (multi + * dimensional) array or matrix, the median of all elements will be + * calculated. + * @param args Multiple scalar values + * @returns The median value + */ + median(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The median value + */ + median(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @returns The median value + */ + median(A: T[] | T[][]): T + /** + * @param A A single matrix + * @returns The median value + */ + median(A: MathCollection): MathScalarType + + /** + * Compute the minimum value of a matrix or a list of values. In case of + * a multi dimensional array, the minimum of the flattened array will be + * calculated. When dim is provided, the minimum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param args multiple scalar values + * @returns The minimum value + */ + min(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The minimum value + */ + min(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @param dimension The minimum over the selected dimension + * @returns The minimum value + */ + min( + A: T[] | T[][], + dimension?: number | BigNumber + ): T + /** + * @param A A single matrix + * @param dimension The minimum over the selected dimension + * @returns The minimum value + */ + min(A: MathCollection, dimension?: number | BigNumber): MathScalarType + + /** + * Computes the mode of a set of numbers or a list with values(numbers + * or characters). If there are more than one modes, it returns a list + * of those values. + * @param args Multiple scalar values + * @returns The mode of all values + */ + mode(...args: T[]): T[] + /** + * @param args Multiple scalar values + * @returns The mode of all values + */ + mode(...args: MathScalarType[]): MathScalarType[] + /** + * @param A A single matrix + * @returns The mode value + */ + mode(A: T[] | T[][]): T[] + /** + * @param A A single matrix + * @returns The mode of all values + */ + mode(A: MathCollection): MathScalarType[] + + /** + * Compute the product of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the sum of all elements will be + * calculated. + * @param args Multiple scalar values + * @returns The product of all values + */ + prod(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The product of all values + */ + prod(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @returns The product of all values + */ + prod(A: T[] | T[][]): T + /** + * @param A A single matrix + * @returns The product of all values + */ + prod(A: MathCollection): MathScalarType + + /** + * @param A A single matrix + * @param probOrN prob is the order of the quantile, while N is the + * amount of evenly distributed steps of probabilities; only one of + * these options can be provided + * @param sorted =false is data sorted in ascending order + * @returns Quantile(s) + */ + quantileSeq( + A: T[] | T[][], + prob: number | BigNumber, + sorted?: boolean + ): T + /** + * Compute the prob order quantile of a matrix or a list with values. + * The sequence is sorted and the middle value is returned. Supported + * types of sequence values are: Number, BigNumber, Unit Supported types + * of probability are: Number, BigNumber In case of a (multi + * dimensional) array or matrix, the prob order quantile of all elements + * will be calculated. + * @param A A single matrix or array + * @param probOrN prob is the order of the quantile, while N is the + * amount of evenly distributed steps of probabilities; only one of + * these options can be provided + * @param sorted =false is data sorted in ascending order + * @returns Quantile(s) + */ + quantileSeq( + A: MathCollection, + prob: number | BigNumber | MathArray, + sorted?: boolean + ): MathScalarType | MathArray + + /** + * Compute the standard deviation of a matrix or a list with values. The + * standard deviations is defined as the square root of the variance: + * std(A) = sqrt(variance(A)). In case of a (multi dimensional) array or + * matrix, the standard deviation over all elements will be calculated. + * Optionally, the type of normalization can be specified as second + * parameter. The parameter normalization can be one of the following + * values: 'unbiased' (default) The sum of squared errors is divided by + * (n - 1) 'uncorrected' The sum of squared errors is divided by n + * 'biased' The sum of squared errors is divided by (n + 1) + * @param args variadic argument of number to calculate standard deviation + * @returns The standard deviation + */ + std(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The standard deviation + */ + std(...args: MathScalarType[]): MathScalarType + /** + * Compute the standard deviation of a matrix or a list with values. The + * standard deviations is defined as the square root of the variance: + * std(A) = sqrt(variance(A)). In case of a (multi dimensional) array or + * matrix, the standard deviation over all elements will be calculated. + * Optionally, the type of normalization can be specified as second + * parameter. The parameter normalization can be one of the following + * values: 'unbiased' (default) The sum of squared errors is divided by + * (n - 1) 'uncorrected' The sum of squared errors is divided by n + * 'biased' The sum of squared errors is divided by (n + 1) + * @param array A single matrix to compute standard deviation. + * @param dimension A dimension to calculate standard deviation + * @param normalization Determines how to normalize the variance. Choose + * ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. Default value: + * ‘unbiased’. + * @returns The standard deviation array + */ + std( + array: MathCollection, + dimension?: number, + normalization?: 'unbiased' | 'uncorrected' | 'biased' + ): MathNumericType[] + /** + * Compute the standard deviation of a matrix or a list with values. The + * standard deviations is defined as the square root of the variance: + * std(A) = sqrt(variance(A)). In case of a (multi dimensional) array or + * matrix, the standard deviation over all elements will be calculated. + * Optionally, the type of normalization can be specified as second + * parameter. The parameter normalization can be one of the following + * values: 'unbiased' (default) The sum of squared errors is divided by + * (n - 1) 'uncorrected' The sum of squared errors is divided by n + * 'biased' The sum of squared errors is divided by (n + 1) + * @param array A single matrix or multiple scalar values + * @param normalization Determines how to normalize the variance. Choose + * ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. Default value: + * ‘unbiased’. + * @returns The standard deviation + */ + std( + array: MathCollection, + normalization: 'unbiased' | 'uncorrected' | 'biased' + ): MathNumericType + + /** + * Compute the sum of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the sum of all elements will be + * calculated. + * @param args A single matrix or multiple scalar values + * @returns The sum of all values + */ + sum(...args: T[]): T + /** + * @param args Multiple scalar values + * @returns The sum of all values + */ + sum(...args: MathScalarType[]): MathScalarType + /** + * @param A A single matrix + * @param dimension The sum over the selected dimension + * @returns The sum of all values + */ + sum( + A: T[] | T[][], + dimension?: number | BigNumber + ): T + /** + * @param A A single matrix + * @param dimension The sum over the selected dimension + * @returns The sum of all values + */ + sum(A: MathCollection, dimension?: number | BigNumber): MathScalarType + + /** + * Count the number of elements of a matrix, array or string. + * @param x A matrix, array or string. + * @returns The number of members passed in parameters + */ + count(x: MathCollection | string): number + + /** + * Compute the cumulative sum of a matrix or a list with values. + * In case of a (multi dimensional) array or matrix, the cumulative sums + * along a specified dimension (defaulting to the first) will be calculated. + * @param args A single matrix or multiple scalar values + * @returns The cumulative sums of the the values. + */ + cumsum(...args: MathType[]): MathType[] + /** + * @param array A single matrix + * @param dim The dimension along which to sum (defaults to 0) + * @returns The cumulative sums along the given dimension + */ + cumsum(array: MathCollection, dim?: number): MathCollection + + /** + * Compute the variance of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the variance over all elements + * will be calculated. Optionally, the type of normalization can be + * specified as second parameter. The parameter normalization can be one + * of the following values: 'unbiased' (default) The sum of squared + * errors is divided by (n - 1) 'uncorrected' The sum of squared errors + * is divided by n 'biased' The sum of squared errors is divided by (n + + * 1) Note that older browser may not like the variable name var. In + * that case, the function can be called as math['var'](...) instead of + * math.variance(...). + * @param args A single matrix or multiple scalar values + * @returns The variance + */ + variance(...args: MathNumericType[]): MathNumericType + /** + * Compute the variance of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the variance over all elements + * will be calculated. Optionally, the type of normalization can be + * specified as second parameter. The parameter normalization can be one + * of the following values: 'unbiased' (default) The sum of squared + * errors is divided by (n - 1) 'uncorrected' The sum of squared errors + * is divided by n 'biased' The sum of squared errors is divided by (n + + * 1) Note that older browser may not like the variable name var. In + * that case, the function can be called as math['var'](...) instead of + * math.variance(...). + * @param array A matrix to compute variance. + * @param dimension A dimension to compute variance on + * @param normalization normalization Determines how to normalize the + * variance. Choose ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. + * Default value: ‘unbiased’. + * @returns variance matrix. + */ + variance( + array: MathCollection, + dimension?: number, + normalization?: 'unbiased' | 'uncorrected' | 'biased' + ): MathNumericType[] + /** + * @param array A single matrix + * @param normalization normalization Determines how to normalize the + * variance. Choose ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. + * Default value: ‘unbiased’. + * @returns The variance + */ + variance( + array: MathCollection, + normalization: 'unbiased' | 'uncorrected' | 'biased' + ): MathNumericType + + /** + * Calculate the correlation coefficient between two matrix. + * @param {Array | Matrix} x The first array or matrix to compute correlation coefficient + * @param {Array | Matrix} y The second array or matrix to compute correlation coefficient + * @returns correlation coefficient + */ + corr(x: MathCollection, y: MathCollection): MathType + + /************************************************************************* + * String functions + ************************************************************************/ + + /** + * Format a value of any type into a string. + * @param value The value to be formatted + * @param options An object with formatting options. + * @param callback A custom formatting function, invoked for all numeric + * elements in value, for example all elements of a matrix, or the real + * and imaginary parts of a complex number. This callback can be used to + * override the built-in numeric notation with any type of formatting. + * Function callback is called with value as parameter and must return a + * string. + * @see http://mathjs.org/docs/reference/functions/format.html + * @returns The formatted value + */ + format( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + options?: FormatOptions | number | BigNumber | ((item: any) => string), + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback?: (value: any) => string + ): string + + /** + * Interpolate values into a string template. + * @param template A string containing variable placeholders. + * @param values An object containing variables which will be filled in + * in the template. + * @param precision Number of digits to format numbers. If not provided, + * the value will not be rounded. + * @param options Formatting options, or the number of digits to format + * numbers. See function math.format for a description of all options. + * @returns Interpolated string + */ + print( + template: string, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + values: any, + precision?: number, + options?: number | object + ): void + + /************************************************************************* + * Trigonometry functions + ************************************************************************/ + + /** + * Calculate the inverse cosine of a value. + * @param x Function input + * @returns The arc cosine of x + */ + acos(x: number): number | Complex + acos(x: T): T + + /** + * Calculate the hyperbolic arccos of a value, defined as acosh(x) = + * ln(sqrt(x^2 - 1) + x). + * @param x Function input + * @returns The hyperbolic arccosine of x + */ + acosh(x: number): number | Complex + acosh(x: T): T + + /** + * Calculate the inverse cotangent of a value. + * @param x Function input + * @returns The arc cotangent of x + */ + acot(x: number): number + acot(x: T): T + + /** + * Calculate the inverse hyperbolic tangent of a value, defined as acoth(x) + * = (ln((x+1)/x) + ln(x/(x-1))) / 2. + * @param x Function input + * @returns The inverse hyperbolic tangent of x + */ + acoth(x: number): number + acoth(x: T): T + + /** + * Calculate the inverse cosecant of a value. + * @param x Function input + * @returns The arc cosecant of x + */ + acsc(x: number): number | Complex + acsc(x: T): T + + /** + * Calculate the inverse hyperbolic cosecant of a value, defined as acsch(x) + * = ln(1/x + sqrt(1/x^2 + 1)). + * @param x Function input + * @returns The inverse hyperbolic cosecant of x + */ + acsch(x: number): number + acsch(x: T): T + + /** + * Calculate the inverse secant of a value. + * @param x Function input + * @returns The arc secant of x + */ + asec(x: number): number | Complex + asec(x: T): T + + /** + * Calculate the hyperbolic arcsecant of a value, defined as asech(x) = + * ln(sqrt(1/x^2 - 1) + 1/x). + * @param x Function input + * @returns The hyperbolic arcsecant of x + */ + asech(x: number): number | Complex + asech(x: T): T + + /** + * Calculate the inverse sine of a value. + * @param x Function input + * @returns The arc sine of x + */ + asin(x: number): number | Complex + asin(x: T): T + + /** + * Calculate the hyperbolic arcsine of a value, defined as asinh(x) = + * ln(x + sqrt(x^2 + 1)). + * @param x Function input + * @returns The hyperbolic arcsine of x + */ + asinh(x: T): T + + /** + * Calculate the inverse tangent of a value. + * @param x Function input + * @returns The arc tangent of x + */ + atan(x: T): T + + /** + * Calculate the inverse tangent function with two arguments, y/x. By + * providing two arguments, the right quadrant of the computed angle can + * be determined. For matrices, the function is evaluated element wise. + * @param x Function input + * @returns Four quadrant inverse tangent + */ + atan2(y: T, x: T): T + + /** + * Calculate the hyperbolic arctangent of a value, defined as atanh(x) = + * ln((1 + x)/(1 - x)) / 2. + * @param x Function input + * @returns The hyperbolic arctangent of x + */ + atanh(x: number): number | Complex + atanh(x: T): T + + /** + * Calculate the cosine of a value. + * @param x Function input + * @returns The cosine of x + */ + cos(x: number | Unit): number + cos(x: T): T + + /** + * Calculate the hyperbolic cosine of a value, defined as cosh(x) = 1/2 + * * (exp(x) + exp(-x)). + * @param x Function input + * @returns The hyperbolic cosine of x + */ + cosh(x: number | Unit): number + cosh(x: T): T + + /** + * Calculate the cotangent of a value. cot(x) is defined as 1 / tan(x). + * @param x Function input + * @returns The cotangent of x + */ + cot(x: number | Unit): number + cot(x: T): T + + /** + * Calculate the hyperbolic cotangent of a value, defined as coth(x) = 1 + * / tanh(x). + * @param x Function input + * @returns The hyperbolic cotangent of x + */ + coth(x: number | Unit): number + coth(x: T): T + + /** + * Calculate the cosecant of a value, defined as csc(x) = 1/sin(x). + * @param x Function input + * @returns The cosecant hof x + */ + csc(x: number | Unit): number + csc(x: T): T + + /** + * Calculate the hyperbolic cosecant of a value, defined as csch(x) = 1 + * / sinh(x). + * @param x Function input + * @returns The hyperbolic cosecant of x + */ + csch(x: number | Unit): number + csch(x: T): T + + /** + * Calculate the secant of a value, defined as sec(x) = 1/cos(x). + * @param x Function input + * @returns The secant of x + */ + sec(x: number | Unit): number + sec(x: T): T + + /** + * Calculate the hyperbolic secant of a value, defined as sech(x) = 1 / + * cosh(x). + * @param x Function input + * @returns The hyperbolic secant of x + */ + sech(x: number | Unit): number + sech(x: T): T + + /** + * Calculate the sine of a value. + * @param x Function input + * @returns The sine of x + */ + sin(x: number | Unit): number + sin(x: T): T + + /** + * Calculate the hyperbolic sine of a value, defined as sinh(x) = 1/2 * + * (exp(x) - exp(-x)). + * @param x Function input + * @returns The hyperbolic sine of x + */ + sinh(x: number | Unit): number + sinh(x: T): T + + /** + * Calculate the tangent of a value. tan(x) is equal to sin(x) / cos(x). + * @param x Function input + * @returns The tangent of x + */ + tan(x: number | Unit): number + tan(x: T): T + + /** + * Calculate the hyperbolic tangent of a value, defined as tanh(x) = + * (exp(2 * x) - 1) / (exp(2 * x) + 1). + * @param x Function input + * @returns The hyperbolic tangent of x + */ + tanh(x: number | Unit): number + tanh(x: T): T + + /************************************************************************* + * Unit functions + ************************************************************************/ + + /** + * Change the unit of a value. For matrices, the function is evaluated + * element wise. + * @param x The unit to be converted. + * @param unit New unit. Can be a string like "cm" or a unit without + * value. + * @returns Value with changed, fixed unit + */ + to(x: Unit | MathCollection, unit: Unit | string): Unit | MathCollection + + /************************************************************************* + * Utils + ************************************************************************/ + isNumber(x: unknown): x is number + + isBigNumber(x: unknown): x is BigNumber + + isBigInt(x: unknown): x is bigint + + isComplex(x: unknown): x is Complex + + isFraction(x: unknown): x is Fraction + + isUnit(x: unknown): x is Unit + + isString(x: unknown): x is string + + isArray: ArrayConstructor['isArray'] + + isMatrix(x: unknown): x is Matrix + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + isCollection(x: unknown): x is Matrix | any[] + + isDenseMatrix(x: unknown): x is Matrix + + isSparseMatrix(x: unknown): x is Matrix + + isRange(x: unknown): boolean + + isIndex(x: unknown): x is Index + + isBoolean(x: unknown): x is boolean + + isResultSet(x: unknown): boolean + + isHelp(x: unknown): x is Help + + isFunction(x: unknown): boolean + + isDate(x: unknown): x is Date + + isRegExp(x: unknown): x is RegExp + + isObject(x: unknown): boolean + + isMap(x: unknown): x is Map + + isPartitionedMap(x: unknown): x is PartitionedMap + + isObjectWrappingMap( + x: unknown + ): x is ObjectWrappingMap + + isNull(x: unknown): x is null + + isUndefined(x: unknown): x is undefined + + isAccessorNode(x: unknown): x is AccessorNode + + isArrayNode(x: unknown): x is ArrayNode + + isAssignmentNode(x: unknown): x is AssignmentNode + + isBlockNode(x: unknown): x is BlockNode + + isConditionalNode(x: unknown): x is ConditionalNode + + isConstantNode(x: unknown): x is ConstantNode + + isFunctionAssignmentNode(x: unknown): x is FunctionAssignmentNode + + isFunctionNode(x: unknown): x is FunctionNode + + isIndexNode(x: unknown): x is IndexNode + + isNode(x: unknown): x is MathNode + + isObjectNode(x: unknown): x is ObjectNode + + isOperatorNode(x: unknown): x is OperatorNode + + isParenthesisNode(x: unknown): x is ParenthesisNode + + isRangeNode(x: unknown): x is RangeNode + + isRelationalNode(x: unknown): x is RelationalNode + + isSymbolNode(x: unknown): x is SymbolNode + + isChain(x: unknown): x is MathJsChain + + /************************************************************************* + * Functions -> Utils + ************************************************************************/ + + /** + * Clone an object. + * @param x Object to be cloned + * @returns A clone of object x + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + clone(x: TType): TType + + /** + * Test whether a value is an numeric value. In case of a string, + * true is returned if the string contains a numeric value. + * @param x Value to be tested + * @returns Returns true when x is a number, BigNumber, bigint, Fraction, Boolean, or a String containing number. + * Returns false for other types. + * Throws an error in case of unknown types. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + hasNumericValue(x: any): boolean | boolean[] + + /** + * Test whether a value is an integer number. The function supports + * number, BigNumber, and Fraction. The function is evaluated + * element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x contains a numeric, integer value. + * Throws an error in case of an unknown data type. + */ + isInteger(x: number | BigNumber | Fraction | MathCollection): boolean + + /** + * Test whether a value is NaN (not a number). The function supports + * types number, BigNumber, Fraction, Unit and Complex. The function is + * evaluated element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is NaN. Throws an error in case of an + * unknown data type. + */ + isNaN( + x: number | BigNumber | bigint | Fraction | MathCollection | Unit + ): boolean + + /** + * Test whether a value is negative: smaller than zero. The function + * supports types number, BigNumber, Fraction, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is larger than zero. Throws an error in + * case of an unknown data type. + */ + isNegative( + x: number | BigNumber | bigint | Fraction | MathCollection | Unit + ): boolean + + /** + * Test whether a value is an numeric value. The function is evaluated + * element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is a number, BigNumber, bigint, Fraction, or + * boolean. Returns false for other types. Throws an error in case of + * unknown types. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + isNumeric(x: any): x is number | BigNumber | bigint | Fraction | boolean + + /** + * Test whether a value is positive: larger than zero. The function + * supports types number, BigNumber, Fraction, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is larger than zero. Throws an error in + * case of an unknown data type. + */ + isPositive( + x: number | BigNumber | bigint | Fraction | MathCollection | Unit + ): boolean + + /** + * Test whether a value is prime: has no divisors other than itself and + * one. The function supports type number, bignumber. The function is + * evaluated element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is larger than zero. Throws an error in + * case of an unknown data type. + */ + isPrime(x: number | BigNumber | MathCollection): boolean + + /** + * Test whether a value is zero. The function can check for zero for + * types number, BigNumber, Fraction, Complex, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + * @param x Value to be tested + * @returns Returns true when x is zero. Throws an error in case of an + * unknown data type. + */ + isZero(x: MathType): boolean + + /** + * Determine the type of a variable. + * @param x The variable for which to test the type + * @returns Returns the name of the type. Primitive types are lower + * case, non-primitive types are upper-camel-case. For example ‘number’, + * ‘string’, ‘Array’, ‘Date’. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + typeOf(x: any): string + + /** + * Import functions from an object or a module + * To avoid errors when using one of the imported functions extend module like this: + * + * @example + * // imported_math_functions.ts + * declare module 'mathjs' { + * interface MathJsInterface { + * hello(a: number): number; + * } + * } + * + * @param object An object with functions to be imported. + * @param options An object with import options. + */ + import(object: ImportObject | ImportObject[], options?: ImportOptions): void +} + +/** + * @deprecated since v12.0.0. The interface MathJsStatic has been renamed to MathJsInstance + */ +export type MathJsStatic = MathJsInstance + +/** + * @deprecated since v12.0.0. Use MathJsFactory instead and import dependency maps directly from the library + */ +export type FactoryDependencies = void + +/************************************************************************* + * Factory and Dependencies + ************************************************************************/ +export interface MathJsFactory { + create: ( + factories: FactoryFunctionMap, + config?: ConfigOptions + ) => MathJsInstance + + factory: ( + name: string, + dependencies: TDeps, + create: ( + injected: Pick> + ) => T, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + meta?: any + ) => FactoryFunction +} + +export const { + all, + typedDependencies, + ResultSetDependencies, + BigNumberDependencies, + ComplexDependencies, + FractionDependencies, + RangeDependencies, + MatrixDependencies, + DenseMatrixDependencies, + cloneDependencies, + isIntegerDependencies, + isNegativeDependencies, + isNumericDependencies, + hasNumericValueDependencies, + isPositiveDependencies, + isZeroDependencies, + isNaNDependencies, + typeOfDependencies, + typeofDependencies, + equalScalarDependencies, + SparseMatrixDependencies, + numberDependencies, + stringDependencies, + booleanDependencies, + bignumberDependencies, + complexDependencies, + fractionDependencies, + matrixDependencies, + splitUnitDependencies, + unaryMinusDependencies, + unaryPlusDependencies, + absDependencies, + applyDependencies, + addScalarDependencies, + cbrtDependencies, + ceilDependencies, + cubeDependencies, + expDependencies, + expm1Dependencies, + fixDependencies, + floorDependencies, + gcdDependencies, + lcmDependencies, + log10Dependencies, + log2Dependencies, + modDependencies, + multiplyScalarDependencies, + multiplyDependencies, + nthRootDependencies, + signDependencies, + sqrtDependencies, + squareDependencies, + subtractDependencies, + xgcdDependencies, + dotMultiplyDependencies, + bitAndDependencies, + bitNotDependencies, + bitOrDependencies, + bitXorDependencies, + argDependencies, + conjDependencies, + imDependencies, + reDependencies, + notDependencies, + orDependencies, + xorDependencies, + concatDependencies, + columnDependencies, + crossDependencies, + diagDependencies, + eyeDependencies, + filterDependencies, + flattenDependencies, + forEachDependencies, + getMatrixDataTypeDependencies, + identityDependencies, + kronDependencies, + mapDependencies, + onesDependencies, + rangeDependencies, + reshapeDependencies, + resizeDependencies, + rowDependencies, + sizeDependencies, + squeezeDependencies, + subsetDependencies, + transposeDependencies, + ctransposeDependencies, + zerosDependencies, + erfDependencies, + modeDependencies, + prodDependencies, + formatDependencies, + printDependencies, + toDependencies, + isPrimeDependencies, + numericDependencies, + divideScalarDependencies, + powDependencies, + roundDependencies, + logDependencies, + log1pDependencies, + nthRootsDependencies, + dotPowDependencies, + dotDivideDependencies, + lsolveDependencies, + usolveDependencies, + leftShiftDependencies, + rightArithShiftDependencies, + rightLogShiftDependencies, + andDependencies, + compareDependencies, + compareNaturalDependencies, + compareTextDependencies, + equalDependencies, + equalTextDependencies, + smallerDependencies, + smallerEqDependencies, + largerDependencies, + largerEqDependencies, + deepEqualDependencies, + unequalDependencies, + partitionSelectDependencies, + sortDependencies, + maxDependencies, + minDependencies, + ImmutableDenseMatrixDependencies, + IndexDependencies, + FibonacciHeapDependencies, + SpaDependencies, + UnitDependencies, + unitDependencies, + sparseDependencies, + createUnitDependencies, + acosDependencies, + acoshDependencies, + acotDependencies, + acothDependencies, + acscDependencies, + acschDependencies, + asecDependencies, + asechDependencies, + asinDependencies, + asinhDependencies, + atanDependencies, + atan2Dependencies, + atanhDependencies, + cosDependencies, + coshDependencies, + cotDependencies, + cothDependencies, + cscDependencies, + cschDependencies, + secDependencies, + sechDependencies, + sinDependencies, + sinhDependencies, + tanDependencies, + tanhDependencies, + setCartesianDependencies, + setDifferenceDependencies, + setDistinctDependencies, + setIntersectDependencies, + setIsSubsetDependencies, + setMultiplicityDependencies, + setPowersetDependencies, + setSizeDependencies, + setSymDifferenceDependencies, + setUnionDependencies, + zpk2tfDependencies, + freqzDependencies, + addDependencies, + hypotDependencies, + normDependencies, + dotDependencies, + traceDependencies, + indexDependencies, + NodeDependencies, + AccessorNodeDependencies, + ArrayNodeDependencies, + AssignmentNodeDependencies, + BlockNodeDependencies, + ConditionalNodeDependencies, + ConstantNodeDependencies, + FunctionAssignmentNodeDependencies, + IndexNodeDependencies, + ObjectNodeDependencies, + OperatorNodeDependencies, + ParenthesisNodeDependencies, + RangeNodeDependencies, + RelationalNodeDependencies, + SymbolNodeDependencies, + FunctionNodeDependencies, + parseDependencies, + compileDependencies, + evaluateDependencies, + evalDependencies, + ParserDependencies, + parserDependencies, + lupDependencies, + qrDependencies, + sluDependencies, + lusolveDependencies, + HelpDependencies, + ChainDependencies, + helpDependencies, + chainDependencies, + detDependencies, + invDependencies, + expmDependencies, + sqrtmDependencies, + sylvesterDependencies, + schurDependencies, + lyapDependencies, + divideDependencies, + distanceDependencies, + intersectDependencies, + sumDependencies, + meanDependencies, + medianDependencies, + madDependencies, + varianceDependencies, + varDependencies, + quantileSeqDependencies, + stdDependencies, + combinationsDependencies, + gammaDependencies, + factorialDependencies, + kldivergenceDependencies, + multinomialDependencies, + permutationsDependencies, + pickRandomDependencies, + randomDependencies, + randomIntDependencies, + stirlingS2Dependencies, + bellNumbersDependencies, + catalanDependencies, + compositionDependencies, + simplifyDependencies, + derivativeDependencies, + rationalizeDependencies, + reviverDependencies, + eDependencies, + EDependencies, + falseDependencies, + iDependencies, + InfinityDependencies, + LN10Dependencies, + LN2Dependencies, + LOG10EDependencies, + LOG2EDependencies, + NaNDependencies, + nullDependencies, + phiDependencies, + piDependencies, + PIDependencies, + SQRT1_2Dependencies, + SQRT2Dependencies, + tauDependencies, + trueDependencies, + versionDependencies, + atomicMassDependencies, + avogadroDependencies, + bohrMagnetonDependencies, + bohrRadiusDependencies, + boltzmannDependencies, + classicalElectronRadiusDependencies, + conductanceQuantumDependencies, + coulombDependencies, + deuteronMassDependencies, + efimovFactorDependencies, + electricConstantDependencies, + electronMassDependencies, + elementaryChargeDependencies, + faradayDependencies, + fermiCouplingDependencies, + fineStructureDependencies, + firstRadiationDependencies, + gasConstantDependencies, + gravitationConstantDependencies, + gravityDependencies, + hartreeEnergyDependencies, + inverseConductanceQuantumDependencies, + klitzingDependencies, + loschmidtDependencies, + magneticConstantDependencies, + magneticFluxQuantumDependencies, + molarMassDependencies, + molarMassC12Dependencies, + molarPlanckConstantDependencies, + molarVolumeDependencies, + neutronMassDependencies, + nuclearMagnetonDependencies, + planckChargeDependencies, + planckConstantDependencies, + planckLengthDependencies, + planckMassDependencies, + planckTemperatureDependencies, + planckTimeDependencies, + protonMassDependencies, + quantumOfCirculationDependencies, + reducedPlanckConstantDependencies, + rydbergDependencies, + sackurTetrodeDependencies, + secondRadiationDependencies, + speedOfLightDependencies, + stefanBoltzmannDependencies, + thomsonCrossSectionDependencies, + vacuumImpedanceDependencies, + weakMixingAngleDependencies, + wienDisplacementDependencies, + applyTransformDependencies, + columnTransformDependencies, + filterTransformDependencies, + forEachTransformDependencies, + indexTransformDependencies, + mapTransformDependencies, + maxTransformDependencies, + meanTransformDependencies, + minTransformDependencies, + rangeTransformDependencies, + rowTransformDependencies, + subsetTransformDependencies, + concatTransformDependencies, + stdTransformDependencies, + sumTransformDependencies, + varianceTransformDependencies +}: Record + +export interface Matrix { + type: string + storage(): string + datatype(): string + create(data: MathArray, datatype?: string): void + density(): number + // eslint-disable-next-line @typescript-eslint/no-explicit-any + subset(index: Index, replacement?: any, defaultValue?: any): Matrix + apply( + dim: number, + callback: (array: MathCollection) => number + ): MathCollection + // eslint-disable-next-line @typescript-eslint/no-explicit-any + get(index: number[]): any + // eslint-disable-next-line @typescript-eslint/no-explicit-any + set(index: number[], value: any, defaultValue?: number | string): Matrix + resize(size: MathCollection, defaultValue?: number | string): Matrix + clone(): Matrix + size(): number[] + map( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (a: any, b: number[], c: Matrix) => any, + skipZeros?: boolean + ): Matrix + forEach( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (a: any, b: number[], c: Matrix) => void, + skipZeros?: boolean + ): void + toArray(): MathArray + valueOf(): MathArray + format( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + options?: FormatOptions | number | BigNumber | ((value: any) => string) + ): string + toString(): string + // eslint-disable-next-line @typescript-eslint/no-explicit-any + toJSON(): any + // eslint-disable-next-line @typescript-eslint/no-explicit-any + diagonal(k?: number | BigNumber): any[] + swapRows(i: number, j: number): Matrix +} + +export interface MatrixCtor { + new (): Matrix +} + +// eslint-disable-next-line @typescript-eslint/no-empty-interface +export interface BigNumber extends Decimal {} + +export interface Fraction { + s: number + n: number + d: number +} + +export interface Complex { + re: number + im: number + clone(): Complex + equals(other: Complex): boolean + format(precision?: number): string + fromJSON(json: object): Complex + fromPolar(polar: object): Complex + fromPolar(r: number, phi: number): Complex + toJSON(): object + toPolar(): PolarCoordinates + toString(): string + compare(a: Complex, b: Complex): number +} + +export interface PolarCoordinates { + r: number + phi: number +} + +export interface MathJSON { + mathjs?: string + value: number + unit: string + fixPrefix?: boolean +} + +export interface BaseUnit { + dimensions: number[] + key: string +} + +export interface UnitComponent { + power: number + prefix: string + unit: { + name: string + base: BaseUnit + prefixes: Record + value: number + offset: number + dimensions: number[] + } +} + +export interface UnitPrefix { + name: string + value: number + scientific: boolean +} + +export interface Unit { + valueOf(): string + clone(): Unit + hasBase(base: BaseUnit | string | undefined): boolean + equalBase(unit: Unit): boolean + equals(unit: Unit): boolean + multiply(unit: Unit): Unit + divide(unit: Unit): Unit | number + pow(unit: Unit): Unit + abs(unit: Unit): Unit + to(unit: string): Unit + toNumber(unit?: string): number + toNumeric(unit?: string): number | Fraction | BigNumber + toSI(): Unit + toString(): string + toJSON(): MathJSON + formatUnits(): string + format(options: FormatOptions): string + simplify(): Unit + splitUnit(parts: ReadonlyArray): Unit[] + + units: UnitComponent[] + dimensions: number[] + value: number + fixPrefix: boolean + skipAutomaticSimplification: true +} + +export type UnitSystemName = 'si' | 'cgs' | 'us' | 'auto' + +export interface UnitStatic { + PREFIXES: Record + BASE_DIMENSIONS: string[] + BASE_UNITS: Record + UNIT_SYSTEMS: Record< + UnitSystemName, + Record + > + UNITS: Record + parse(str: string): Unit + isValuelessUnit(name: string): boolean + fromJSON(json: MathJSON): Unit + isValidAlpha(c: string): boolean + createUnit( + obj: Record, + options?: { override: boolean } + ): Unit + createUnitSingle( + name: string, + definition: string | Unit | UnitDefinition + ): Unit + getUnitSystem(): UnitSystemName + setUnitSystem(name: UnitSystemName): void +} + +export interface UnitCtor extends UnitStatic { + new ( + value: number | BigNumber | Fraction | Complex | boolean, + name: string + ): Unit +} + +export interface CreateUnitOptions { + prefixes?: 'none' | 'short' | 'long' | 'binary_short' | 'binary_long' + aliases?: string[] + offset?: number + override?: boolean +} + +export type SimplifyContext = Partial< + Record< + OperatorNodeFn, + { + trivial: boolean + total: boolean + commutative: boolean + associative: boolean + } + > +> + +export interface SimplifyOptions { + /** A boolean which is `true` by default. */ + exactFractions?: boolean + /** + * When `exactFractions` is true, a fraction will be returned only + * when both numerator and denominator are smaller than `fractionsLimit`. + * Default value is 10000. + */ + fractionsLimit?: number + /** A boolean which is `false` by default. */ + consoleDebug?: boolean + /** + * gives properties of each operator, which determine what simplifications + * are allowed. Properties are commutative, associative, total (whether + * the operation is defined for all arguments), and trivial (whether + * the operation applied to a single argument leaves that argument + * unchanged). + */ + context?: SimplifyContext +} + +export type SimplifyRule = + | { + l: string + r: string + repeat?: boolean + assuming?: SimplifyContext + imposeContext?: SimplifyContext + } + | { + s: string + repeat?: boolean + assuming?: SimplifyContext + imposeContext?: SimplifyContext + } + | string + | ((node: MathNode) => MathNode) + +export interface Simplify { + (expr: MathNode | string): MathNode + ( + expr: MathNode | string, + rules: SimplifyRule[], + scope?: object, + options?: SimplifyOptions + ): MathNode + (expr: MathNode | string, scope: object, options?: SimplifyOptions): MathNode + + rules: SimplifyRule[] +} + +export interface UnitDefinition { + definition?: string | Unit + prefixes?: string + offset?: number + aliases?: string[] + baseName?: string +} + +// eslint-disable-next-line @typescript-eslint/no-empty-interface +export interface Index {} + +export interface PartitionedMap { + a: Map + b: Map +} + +export interface ObjectWrappingMap { + wrappedObject: Record +} + +export interface EvalFunction { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + evaluate(scope?: any): any +} + +export interface MathNode { + isNode: true + comment: string + type: string + + isUpdateNode?: boolean + + /** + * Create a shallow clone of the node. The node itself is cloned, its + * childs are not cloned. + */ + clone(): this + /** + * Create a deep clone of the node. Both the node as well as all its + * childs are cloned recursively. + */ + cloneDeep(): this + /** + * Compile an expression into optimized JavaScript code. compile returns + * an object with a function evaluate([scope]) to evaluate. Example: + */ + compile(): EvalFunction + /** + * Compile and eval an expression, this is the equivalent of doing + * node.compile().evaluate(scope). Example: + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + evaluate(expr?: any): any + /** + * Test whether this node equals an other node. Does a deep comparison + * of the values of both nodes. + */ + equals(other: MathNode): boolean + /** + * + * Filter nodes in an expression tree. The callback function is called + * as callback(node: MathNode, path: string, parent: MathNode) : boolean + * for every node in the tree, and must return a boolean. The function + * filter returns an array with nodes for which the test returned true. + * Parameter path is a string containing a relative JSON Path. + * + * Example: + * + * ``` + * var node = math.parse('x^2 + x/4 + 3*y'); + * var filtered = node.filter(function (node) { + * return node.isSymbolMathNode && node.name == 'x'; + * }); + * // returns an array with two entries: two SymbolMathNodes 'x' + * ``` + * + * The callback function is called as callback(node: MathNode, path: + * string, parent: MathNode) : boolean for every node in the tree, and + * must return a boolean. The function filter returns an array with + * nodes for which the test returned true. Parameter path is a string + * containing a relative JSON Path. + * @return Returns an array with nodes for which test returned true + */ + filter( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (node: MathNode, path: string, parent: MathNode) => any + ): MathNode[] + + /** + * [forEach description] + */ + forEach( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (node: MathNode, path: string, parent: MathNode) => void + ): void + + /** + * Transform a node. Creates a new MathNode having it’s child's be the + * results of calling the provided callback function for each of the + * child's of the original node. The callback function is called as + * `callback(child: MathNode, path: string, parent: MathNode)` and must + * return a MathNode. Parameter path is a string containing a relative + * JSON Path. + * + * + * See also transform, which is a recursive version of map. + */ + map( + callback: (node: MathNode, path: string, parent: MathNode) => MathNode + ): MathNode + + /** + * Get a HTML representation of the parsed expression. + */ + toHTML(options?: object): string + + /** + * Get a string representation of the parsed expression. This is not + * exactly the same as the original input. + */ + toString(options?: object): string + + /** + * Get a LaTeX representation of the expression. + */ + toTex(options?: object): string + + /** + * Recursively transform an expression tree via a transform function. + * Similar to Array.map, but recursively executed on all nodes in the + * expression tree. The callback function is a mapping function + * accepting a node, and returning a replacement for the node or the + * original node. Function callback is called as callback(node: + * MathNode, path: string, parent: MathNode) for every node in the tree, + * and must return a MathNode. Parameter path is a string containing a + * relative JSON Path. + * + * For example, to replace all nodes of type SymbolMathNode having name + * ‘x’ with a ConstantMathNode with value 3: + * ```js + * var node = math.parse('x^2 + 5*x'); + * var transformed = node.transform(function (node, path, parent) { + * if (node.SymbolMathNode && node.name == 'x') { + * return new math.expression.node.ConstantMathNode(3); + * } + * else { + * return node; + * } + * }); + * transformed.toString(); // returns '(3 ^ 2) + (5 * 3)' + * ``` + */ + transform( + callback: (node: this, path: string, parent: MathNode) => TResult + ): TResult + + /** + * `traverse(callback)` + * + * Recursively traverse all nodes in a node tree. Executes given + * callback for this node and each of its child nodes. Similar to + * Array.forEach, except recursive. The callback function is a mapping + * function accepting a node, and returning a replacement for the node + * or the original node. Function callback is called as callback(node: + * MathNode, path: string, parent: MathNode) for every node in the tree. + * Parameter path is a string containing a relative JSON Path. Example: + * + * ``` + * var node = math.parse('3 * x + 2'); + * node.traverse(function (node, path, parent) { + * switch (node.type) { + * case 'OperatorMathNode': console.log(node.type, node.op); break; + * case 'ConstantMathNode': console.log(node.type, node.value); break; + * case 'SymbolMathNode': console.log(node.type, node.name); break; + * default: console.log(node.type); + * } + * }); + * // outputs: + * // OperatorMathNode + + * // OperatorMathNode * + * // ConstantMathNode 3 + * // SymbolMathNode x + * // ConstantMathNode 2 + * ``` + */ + traverse( + callback: (node: MathNode, path: string, parent: MathNode) => void + ): void +} + +export interface Parser { + /** + * Evaluate an expression. Returns the result of the expression. + * @param expr The expression to evaluate + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + evaluate(expr: string | string[]): any + /** + * Retrieve a variable or function from the parser’s scope. + * @param name The name of the variable or function to be retrieved + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + get(name: string): any + /** + * Retrieve an object with all defined variables in the parser’s scope. + * @returns An object with all defined variables + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + getAll(): { [key: string]: any } + /** + * Retrieve a map with all defined variables in the parser’s scope. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + getAllAsMap(): Map + /** + * Set a variable or function in the parser’s scope. + * @param name The name of the variable or function to be set + * @param value The value of the variable or function to be set + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + set: (name: string, value: any) => void + /** + * Remove a variable or function from the parser’s scope. + * @param name The name of the variable or function to be removed + */ + remove: (name: string) => void + /** + * Completely clear the parser’s scope. + */ + clear: () => void +} + +export interface Distribution { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + random(size: any, min?: any, max?: any): any + // eslint-disable-next-line @typescript-eslint/no-explicit-any + randomInt(min: any, max?: any): any + // eslint-disable-next-line @typescript-eslint/no-explicit-any + pickRandom(array: any): any +} + +export interface FormatOptions { + /** + * Number notation. Choose from: 'fixed' Always use regular number + * notation. For example '123.40' and '14000000' 'exponential' Always + * use exponential notation. For example '1.234e+2' and '1.4e+7' 'auto' + * (default) Regular number notation for numbers having an absolute + * value between lower and upper bounds, and uses exponential notation + * elsewhere. Lower bound is included, upper bound is excluded. For + * example '123.4' and '1.4e7'. + */ + notation?: + | 'fixed' + | 'exponential' + | 'engineering' + | 'auto' + | 'hex' + | 'bin' + | 'oct' + + /** + * A number between 0 and 16 to round the digits of the number. In case + * of notations 'exponential' and 'auto', precision defines the total + * number of significant digits returned and is undefined by default. In + * case of notation 'fixed', precision defines the number of significant + * digits after the decimal point, and is 0 by default. + */ + precision?: number | BigNumber + + /** + * Exponent determining the lower boundary for formatting a value with + * an exponent when notation='auto. Default value is -3. + */ + lowerExp?: number | BigNumber + + /** + * Exponent determining the upper boundary for formatting a value with + * an exponent when notation='auto. Default value is 5. + */ + upperExp?: number | BigNumber + + /** + * Available values: 'ratio' (default) or 'decimal'. For example + * format(fraction(1, 3)) will output '1/3' when 'ratio' is configured, + * and will output 0.(3) when 'decimal' is configured. + */ + fraction?: string + + /** + * The word size in bits to use for formatting in binary, octal, or + * hexadecimal notation. To be used only with `'bin'`, `'oct'`, or `'hex'` + * values for `notation` option. When this option is defined the value + * is formatted as a signed twos complement integer of the given word + * size and the size suffix is appended to the output. + */ + wordSize?: number | BigNumber +} + +export interface Help { + toString(): string + toJSON(): string +} + +export interface ConfigOptions { + relTol?: number + absTol?: number + /** + * @deprecated Use `relTol` and `absTol` instead + */ + epsilon?: number + matrix?: 'Matrix' | 'Array' + number?: 'number' | 'BigNumber' | 'bigint' | 'Fraction' + numberFallback?: 'number' | 'BigNumber' + precision?: number + predictable?: boolean + randomSeed?: string | null +} + +export interface MathJsChain { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + done(): TValue + + /************************************************************************* + * Construction functions + ************************************************************************/ + + /** + * Create a BigNumber, which can store numbers with arbitrary precision. + * When a matrix is provided, all elements will be converted to + * BigNumber. + */ + bignumber( + this: MathJsChain< + number | string | Fraction | BigNumber | bigint | Unit | boolean | null + > + ): MathJsChain + bignumber(this: MathJsChain): MathJsChain + + /** + * Create a bigint, which can store integers with arbitrary precision. + * When a matrix is provided, all elements will be converted to bigint. + */ + bigint( + this: MathJsChain< + number | string | Fraction | BigNumber | bigint | boolean | null + > + ): MathJsChain + bigint(this: MathJsChain): MathJsChain + + /** + * Create a boolean or convert a string or number to a boolean. In case + * of a number, true is returned for non-zero numbers, and false in case + * of zero. Strings can be 'true' or 'false', or can contain a number. + * When value is a matrix, all elements will be converted to boolean. + */ + boolean( + this: MathJsChain + ): MathJsChain + boolean(this: MathJsChain): MathJsChain + + /** + * Create a complex value or convert a value to a complex value. + * @param im Argument specifying the imaginary part of the complex + * number + */ + complex( + this: MathJsChain, + im?: number + ): MathJsChain + complex(this: MathJsChain): MathJsChain + + /** + * Create a user-defined unit and register it with the Unit type. + * @param definition Definition of the unit in terms of existing units. + * For example, ‘0.514444444 m / s’. + * @param options (optional) An object containing any of the following + * properties:
    - prefixes {string} “none”, “short”, “long”, + * “binary_short”, or “binary_long”. The default is “none”.
    - + * aliases {Array} Array of strings. Example: [‘knots’, ‘kt’, + * ‘kts’]
    - offset {Numeric} An offset to apply when converting from + * the unit. For example, the offset for celsius is 273.15. Default is + * 0. + */ + createUnit( + this: MathJsChain, + definition?: string | UnitDefinition | Unit, + options?: CreateUnitOptions + ): MathJsChain + /** + * Create a user-defined unit and register it with the Unit type. + * @param options (optional) An object containing any of the following + * properties:
    - prefixes {string} “none”, “short”, “long”, + * “binary_short”, or “binary_long”. The default is “none”.
    - + * aliases {Array} Array of strings. Example: [‘knots’, ‘kt’, + * ‘kts’]
    - offset {Numeric} An offset to apply when converting from + * the unit. For example, the offset for celsius is 273.15. Default is + * 0. + */ + createUnit( + this: MathJsChain>, + options?: CreateUnitOptions + ): MathJsChain + + /** + * Create a fraction convert a value to a fraction. + * @param denominator Argument specifying the denominator of the + * fraction + */ + fraction( + this: MathJsChain< + | number + | string + | BigNumber + | bigint + | Unit + | Fraction + | FractionDefinition + >, + denominator?: number + ): MathJsChain + fraction(this: MathJsChain): MathJsChain + + /** + * Create an index. An Index can store ranges having start, step, and + * end for multiple dimensions. Matrix.get, Matrix.set, and math.subset + * accept an Index as input. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + index(this: MathJsChain): MathJsChain + + /** + * Create a Matrix. The function creates a new math.type.Matrix object + * from an Array. A Matrix has utility functions to manipulate the data + * in the matrix, like getting the size and getting or setting values in + * the matrix. Supported storage formats are 'dense' and 'sparse'. + */ + matrix( + this: MathJsChain, + format?: 'sparse' | 'dense', + dataType?: string + ): MathJsChain + + /** + * Create a number or convert a string, boolean, or unit to a number. + * When value is a matrix, all elements will be converted to number. + * @param valuelessUnit A valueless unit, used to convert a unit to a + * number + */ + number( + this: MathJsChain< + string | number | BigNumber | bigint | Fraction | boolean | Unit | null + >, + valuelessUnit?: Unit | string + ): MathJsChain + number( + this: MathJsChain, + valuelessUnit?: Unit | string + ): MathJsChain + + /** + * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction. + * @param outputType The desired numeric output type + */ + numeric( + this: MathJsChain, + outputType: 'number' + ): MathJsChain + numeric( + this: MathJsChain, + outputType: 'BigNumber' + ): MathJsChain + numeric( + this: MathJsChain, + outputType: 'bigint' + ): MathJsChain + numeric( + this: MathJsChain, + outputType: 'Fraction' + ): MathJsChain + + /** + * Create a Sparse Matrix. The function creates a new math.type.Matrix + * object from an Array. A Matrix has utility functions to manipulate + * the data in the matrix, like getting the size and getting or setting + * values in the matrix. + * @param dataType Sparse Matrix data type + */ + sparse( + this: MathJsChain, + dataType?: string + ): MathJsChain + + /** + * Split a unit in an array of units whose sum is equal to the original + * unit. + * @param parts An array of strings or valueless units + */ + splitUnit(this: MathJsChain, parts: Unit[]): MathJsChain + + /** + * Create a string or convert any object into a string. Elements of + * Arrays and Matrices are processed element wise. + */ + string( + this: MathJsChain + ): MathJsChain + string(this: MathJsChain): MathJsChain + + /** + * Create a unit. Depending on the passed arguments, the function will + * create and return a new math.type.Unit object. When a matrix is + * provided, all elements will be converted to units. + * @param unit The unit to be created + */ + unit(this: MathJsChain, unit?: string): MathJsChain + unit(this: MathJsChain, unit?: string): MathJsChain + unit(this: MathJsChain, unit?: string): MathJsChain + + /************************************************************************* + * Expression functions + ************************************************************************/ + + /** + * Parse and compile an expression. Returns a an object with a function + * evaluate([scope]) to evaluate the compiled expression. + */ + compile(this: MathJsChain): MathJsChain + + // TODO properly type this + /** + * Evaluate an expression. + * @param scope Scope to read/write variables + */ + evaluate( + this: MathJsChain, + scope?: object + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ): MathJsChain + evaluate( + this: MathJsChain, + scope?: object + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ): MathJsChain + + /** + * Retrieve help on a function or data type. Help files are retrieved + * from the documentation in math.expression.docs. + */ + help(this: MathJsChain): MathJsChain + + /** + * @param options Available options: nodes - a set of custome nodes + */ + parse( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + options?: any + ): MathJsChain + + /** + * Parse an expression. Returns a node tree, which can be evaluated by + * invoking node.evaluate(); + * @param options Available options: nodes - a set of custome nodes + */ + parse( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + options?: any + ): MathJsChain + + /** + * Replaces variable nodes with their scoped values + * @param scope Scope to read/write variables + */ + resolve( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + scope?: Record + ): MathJsChain + resolve( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + scope?: Record + ): MathJsChain + + /************************************************************************* + * Algebra functions + ************************************************************************/ + /** + * @param variable The variable over which to differentiate + * @param options There is one option available, simplify, which is true + * by default. When false, output will not be simplified. + */ + derivative( + this: MathJsChain, + variable: MathNode | string, + options?: { simplify: boolean } + ): MathJsChain + + /** + * Solves the linear equation system by forwards substitution. Matrix + * must be a lower triangular matrix. + * @param b A column vector with the b values + */ + lsolve(this: MathJsChain, b: MathCollection): MathJsChain + lsolve( + this: MathJsChain, + b: MathCollection + ): MathJsChain + + /** + * Calculate the Matrix LU decomposition with partial pivoting. Matrix A + * is decomposed in two matrices (L, U) and a row permutation vector p + * where A[p,:] = L * U + */ + lup(this: MathJsChain): MathJsChain + + /** + * Solves the linear system A * x = b where A is an [n x n] matrix and b + * is a [n] column vector. + * @param b Column Vector + * @param order The Symbolic Ordering and Analysis order, see slu for + * details. Matrix must be a SparseMatrix + * @param threshold Partial pivoting threshold (1 for partial pivoting), + * see slu for details. Matrix must be a SparseMatrix. + */ + lusolve( + this: MathJsChain, + b: MathCollection, + order?: number, + threshold?: number + ): MathJsChain + + lusolve( + this: MathJsChain, + b: MathCollection, + order?: number, + threshold?: number + ): MathJsChain + + lusolve( + this: MathJsChain, + b: MathCollection + ): MathJsChain + + /** + * Calculate the Matrix QR decomposition. Matrix A is decomposed in two + * matrices (Q, R) where Q is an orthogonal matrix and R is an upper + * triangular matrix. + */ + qr(this: MathJsChain): MathJsChain + + /** + * Transform a rationalizable expression in a rational fraction. If + * rational fraction is one variable polynomial then converts the + * numerator and denominator in canonical form, with decreasing + * exponents, returning the coefficients of numerator. + * @param optional scope of expression or true for already evaluated + * rational expression at input + * @param detailed optional True if return an object, false if return + * expression node (default) + */ + rationalize( + this: MathJsChain, + optional?: object | boolean, + detailed?: boolean + ): MathJsChain + + /** + * Simplify an expression tree. + * @param rules A list of rules are applied to an expression, repeating + * over the list until no further changes are made. It’s possible to + * pass a custom set of rules to the function as second argument. A rule + * can be specified as an object, string, or function. + * @param scope Scope to variables + * @param options Options to configure the behavior of simplify + */ + simplify( + this: MathJsChain, + rules?: SimplifyRule[], + scope?: Map | object, + options?: SimplifyOptions + ): MathJsChain + + simplifyConstant( + this: MathJsChain, + options?: SimplifyOptions + ): MathJsChain + simplifyCore( + this: MathJsChain, + options?: SimplifyOptions + ): MathJsChain + + /** + * Gives the number of “leaf nodes” in the parse tree of the given + * expression. A leaf node is one that has no subexpressions, essentially + * either a symbol or a constant. Note that `5!` has just one leaf, the `5`; + * the unary factorial operator does not add a leaf. On the other hand, + * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves. + */ + leafCount(this: MathJsChain): MathJsChain + + /** + * Calculate the Sparse Matrix LU decomposition with full pivoting. + * Sparse Matrix A is decomposed in two matrices (L, U) and two + * permutation vectors (pinv, q) where P * A * Q = L * U + * @param order The Symbolic Ordering and Analysis order: 0 - Natural + * ordering, no permutation vector q is returned 1 - Matrix must be + * square, symbolic ordering and analisis is performed on M = A + A' 2 - + * Symbolic ordering and analysis is performed on M = A' * A. Dense + * columns from A' are dropped, A recreated from A'. This is appropriate + * for LU factorization of non-symmetric matrices. 3 - Symbolic ordering + * and analysis is performed on M = A' * A. This is best used for LU + * factorization is matrix M has no dense rows. A dense row is a row + * with more than 10*sqr(columns) entries. + * @param threshold Partial pivoting threshold (1 for partial pivoting) + */ + slu( + this: MathJsChain, + order: number, + threshold: number + ): MathJsChain + + /** + * Solves the linear equation system by backward substitution. Matrix + * must be an upper triangular matrix. U * x = b + * @param b A column vector with the b values + */ + usolve(this: MathJsChain, b: MathCollection): MathJsChain + usolve( + this: MathJsChain, + b: MathCollection + ): MathJsChain + + /************************************************************************* + * Arithmetic functions + ************************************************************************/ + + /** + * Calculate the absolute value of a number. For matrices, the function + * is evaluated element wise. + */ + abs(this: MathJsChain): MathJsChain + + /** + * Add two values, x + y. For matrices, the function is evaluated + * element wise. + * @param y Second value to add + */ + add(this: MathJsChain, y: T): MathJsChain + add(this: MathJsChain, y: MathType): MathJsChain + + /** + * Apply a function that maps an array to a scalar along a given axis of the + * matrix or array. Returns a new matrix or array with one less dimension + * than the input. + * @param dim The dimension along which the callback is applied + * @param callback The callback function that is applied. This Function should take an + * array or 1-d matrix as an input and return a number. + * @returns The residual matrix with the function applied over some dimension. + */ + apply( + this: MathJsChain, + dim: number, + callback: (array: Array | Matrix) => number + ): MathJsChain + + /** + * Calculate the cubic root of a value. For matrices, the function is + * evaluated element wise. + * @param allRoots Optional, false by default. Only applicable when x is + * a number or complex number. If true, all complex roots are returned, + * if false (default) the principal root is returned. + */ + cbrt( + this: MathJsChain, + allRoots?: boolean + ): MathJsChain + + // Rounding functions grouped for similarity + + /** + * Round a value towards plus infinity If x is complex, both real and + * imaginary part are rounded towards plus infinity. For matrices, the + * function is evaluated element wise. + * @param n Number of decimals Default value: 0. + */ + ceil( + this: MathJsChain, + n?: number | BigNumber | MathCollection + ): MathJsChain + + /** + * Round a value towards zero. For matrices, the function is evaluated + * element wise. + * @param n Number of decimals Default value: 0. + */ + fix( + this: MathJsChain, + n?: number | BigNumber | MathCollection + ): MathJsChain + + /** + * Round a value towards minus infinity. For matrices, the function is + * evaluated element wise. + * @param n Number of decimals Default value: 0. + */ + floor( + this: MathJsChain, + n?: number | BigNumber | MathCollection + ): MathJsChain + + /** + * Round a value towards the nearest integer. For matrices, the function + * is evaluated element wise. + * @param n Number of decimals Default value: 0. + */ + round( + this: MathJsChain, + n?: number | BigNumber | MathCollection + ): MathJsChain + round( + this: MathJsChain, + n: U + ): MathJsChain + round(this: MathJsChain, unit: Unit): MathJsChain + round( + this: MathJsChain, + unit: Unit + ): MathJsChain + round( + this: MathJsChain, + n: number | BigNumber, + unit: Unit + ): MathJsChain + round( + this: MathJsChain, + n: number | BigNumber, + unit: Unit + ): MathJsChain + + // End of rounding group + + /** + * Compute the cube of a value, x * x * x. For matrices, the function is + * evaluated element wise. + */ + cube(this: MathJsChain): MathJsChain + + /** + * Divide two values, x / y. To divide matrices, x is multiplied with + * the inverse of y: x * inv(y). + * @param y Denominator + */ + divide(this: MathJsChain, y: Unit): MathJsChain + divide(this: MathJsChain, y: number): MathJsChain + divide(this: MathJsChain, y: number): MathJsChain + divide(this: MathJsChain, y: MathType): MathJsChain + + /** + * Divide two matrices element wise. The function accepts both matrices + * and scalar values. + * @param y Denominator + */ + dotDivide( + this: MathJsChain, + y: MathType + ): MathJsChain + dotDivide( + this: MathJsChain, + y: T + ): MathJsChain + dotDivide(this: MathJsChain, y: MathType): MathJsChain + dotDivide(this: MathJsChain, y: Unit): MathJsChain + dotDivide( + this: MathJsChain, + y: MathNumericType + ): MathJsChain + + /** + * Multiply two matrices element wise. The function accepts both + * matrices and scalar values. + * @param y Right hand value + */ + dotMultiply( + this: MathJsChain, + y: MathType + ): MathJsChain + dotMultiply( + this: MathJsChain, + y: T + ): MathJsChain + dotMultiply(this: MathJsChain, y: MathType): MathJsChain + dotMultiply(this: MathJsChain, y: Unit): MathJsChain + dotMultiply( + this: MathJsChain, + y: MathNumericType + ): MathJsChain + + /** + * Calculates the power of x to y element wise. + * @param y The exponent + */ + dotPow(this: MathJsChain, y: MathType): MathJsChain + + /** + * Calculate the exponent of a value. For matrices, the function is + * evaluated element wise. + */ + exp( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the value of subtracting 1 from the exponential value. For + * matrices, the function is evaluated element wise. + */ + expm1( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the greatest common divisor for two or more values or + * arrays. For matrices, the function is evaluated element wise. + */ + gcd( + this: MathJsChain, + ...args: T[] + ): MathJsChain + + /** + * Calculate the hypotenuse of a list with values. The hypotenuse is + * defined as: hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...) For + * matrix input, the hypotenuse is calculated for all values in the + * matrix. + */ + hypot(this: MathJsChain): MathJsChain + + /** + * Calculate the least common multiple for two or more values or arrays. + * lcm is defined as: lcm(a, b) = abs(a * b) / gcd(a, b) For matrices, + * the function is evaluated element wise. + * @param b An integer number + */ + lcm( + this: MathJsChain, + b: T + ): MathJsChain + + /** + * Calculate the logarithm of a value. For matrices, the function is + * evaluated element wise. + * @param base Optional base for the logarithm. If not provided, the + * natural logarithm of x is calculated. Default value: e. + */ + log( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain> + + /** + * Calculate the 10-base of a value. This is the same as calculating + * log(x, 10). For matrices, the function is evaluated element wise. + */ + + log10( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the logarithm of a value+1. For matrices, the function is + * evaluated element wise. + */ + log1p( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain + log1p( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain + log1p( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain + log1p( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain + log1p( + this: MathJsChain, + base?: number | BigNumber | Complex + ): MathJsChain + + /** + * Calculate the 2-base of a value. This is the same as calculating + * log(x, 2). For matrices, the function is evaluated element wise. + */ + + log2( + this: MathJsChain + ): MathJsChain + + /** + * Calculates the modulus, the remainder of an integer division. For + * matrices, the function is evaluated element wise. The modulus is + * defined as: x - y * floor(x / y) + * @see http://en.wikipedia.org/wiki/Modulo_operation. + * @param y Divisor + */ + mod( + this: MathJsChain, + y: number | BigNumber | bigint | Fraction | MathCollection + ): MathJsChain> + + /** + * Multiply two values, x * y. The result is squeezed. For matrices, the + * matrix product is calculated. + * @param y The second value to multiply + */ + multiply( + this: MathJsChain, + y: MathType + ): MathJsChain + multiply(this: MathJsChain, y: Unit): MathJsChain + multiply(this: MathJsChain, y: number): MathJsChain + multiply(this: MathJsChain, y: MathType): MathJsChain + + /** + * Calculate the norm of a number, vector or matrix. The second + * parameter p is optional. If not provided, it defaults to 2. + * @param p Vector space. Supported numbers include Infinity and + * -Infinity. Supported strings are: 'inf', '-inf', and 'fro' (The + * Frobenius norm) Default value: 2. + */ + norm( + this: MathJsChain, + p?: number | BigNumber | string + ): MathJsChain + + /** + * Calculate the nth root of a value. The principal nth root of a + * positive real number A, is the positive real solution of the equation + * x^root = A For matrices, the function is evaluated element wise. + * @param root The root. Default value: 2. + */ + nthRoot( + this: MathJsChain, + root?: number | BigNumber + ): MathJsChain + + /** + * Calculates the power of x to y, x ^ y. Matrix exponentiation is + * supported for square matrices x, and positive integer exponents y. + * @param y The exponent + */ + pow( + this: MathJsChain, + y: number | BigNumber | bigint | Complex + ): MathJsChain + + /** + * Compute the sign of a value. The sign of a value x is: 1 when x > 1 + * -1 when x < 0 0 when x == 0 For matrices, the function is evaluated + * element wise. + * @param x The number for which to determine the sign + * @returns The sign of x + */ + sign(this: MathJsChain): MathJsChain + + /** + * Calculate the square root of a value. For matrices, the function is + * evaluated element wise. + */ + + sqrt( + this: MathJsChain + ): MathJsChain + + /** + * Compute the square of a value, x * x. For matrices, the function is + * evaluated element wise. + */ + + square(this: MathJsChain): MathJsChain + + /** + * Subtract two values, x - y. For matrices, the function is evaluated + * element wise. + * @param y Value to subtract from x + */ + subtract(this: MathJsChain, y: T): MathJsChain + + /** + * Inverse the sign of a value, apply a unary minus operation. For + * matrices, the function is evaluated element wise. Boolean values and + * strings will be converted to a number. For complex numbers, both real + * and complex value are inverted. + */ + + unaryMinus(this: MathJsChain): MathJsChain + + /** + * Unary plus operation. Boolean values and strings will be converted to + * a number, numeric values will be returned as is. For matrices, the + * function is evaluated element wise. + */ + + unaryPlus(this: MathJsChain): MathJsChain + + /** + * Calculate the extended greatest common divisor for two values. See + * http://en.wikipedia.org/wiki/Extended_Euclidean_algorithm. + * @param b An integer number + */ + xgcd( + this: MathJsChain, + b: number | BigNumber + ): MathJsChain + + /** + * Count the number of elements of a matrix, array or string. + */ + count(this: MathJsChain): MathJsChain + count(this: MathJsChain): MathJsChain + + /** + * Compute the sum of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the sum of all elements will be + * calculated. + */ + sum( + this: MathJsChain> + ): MathJsChain + sum(this: MathJsChain): MathJsChain + /************************************************************************* + * Bitwise functions + ************************************************************************/ + + /** + * Bitwise AND two values, x & y. For matrices, the function is + * evaluated element wise. + * @param y Second value to and + */ + bitAnd( + this: MathJsChain, + y: number | BigNumber | bigint | MathCollection + ): MathJsChain> + + /** + * Bitwise NOT value, ~x. For matrices, the function is evaluated + * element wise. For units, the function is evaluated on the best prefix + * base. + */ + + bitNot( + this: MathJsChain + ): MathJsChain + + /** + * Bitwise OR two values, x | y. For matrices, the function is evaluated + * element wise. For units, the function is evaluated on the lowest + * print base. + * @param y Second value to or + */ + bitOr( + this: MathJsChain, + y: T + ): MathJsChain + + /** + * Bitwise XOR two values, x ^ y. For matrices, the function is + * evaluated element wise. + * @param y Second value to xor + */ + bitXor( + this: MathJsChain, + y: number | BigNumber | bigint | MathCollection + ): MathJsChain> + + /** + * Bitwise left logical shift of a value x by y number of bits, x << y. + * For matrices, the function is evaluated element wise. For units, the + * function is evaluated on the best prefix base. + * @param y Amount of shifts + */ + leftShift( + this: MathJsChain, + y: number | BigNumber | bigint + ): MathJsChain> + + /** + * Bitwise right arithmetic shift of a value x by y number of bits, x >> + * y. For matrices, the function is evaluated element wise. For units, + * the function is evaluated on the best prefix base. + * @param y Amount of shifts + */ + rightArithShift( + this: MathJsChain, + y: number | BigNumber | bigint + ): MathJsChain> + + /** + * Bitwise right logical shift of value x by y number of bits, x >>> y. + * For matrices, the function is evaluated element wise. For units, the + * function is evaluated on the best prefix base. + * @param y Amount of shifts + */ + rightLogShift( + this: MathJsChain, + y: number + ): MathJsChain> + + /************************************************************************* + * Combinatorics functions + ************************************************************************/ + + /** + * The Bell Numbers count the number of partitions of a set. A partition + * is a pairwise disjoint subset of S whose union is S. bellNumbers only + * takes integer arguments. The following condition must be enforced: n + * >= 0 + */ + + bellNumbers(this: MathJsChain): MathJsChain + bellNumbers(this: MathJsChain): MathJsChain + + /** + * The Catalan Numbers enumerate combinatorial structures of many + * different types. catalan only takes integer arguments. The following + * condition must be enforced: n >= 0 + */ + + catalan(this: MathJsChain): MathJsChain + catalan(this: MathJsChain): MathJsChain + + /** + * The composition counts of n into k parts. Composition only takes + * integer arguments. The following condition must be enforced: k <= n. + * @param k Number of objects in the subset + */ + composition( + this: MathJsChain, + k: number | BigNumber + ): MathJsChain> + + /** + * The Stirling numbers of the second kind, counts the number of ways to + * partition a set of n labelled objects into k nonempty unlabelled + * subsets. stirlingS2 only takes integer arguments. The following + * condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = + * 1 + * @param k Number of objects in the subset + */ + stirlingS2( + this: MathJsChain, + k: number | BigNumber + ): MathJsChain> + + /************************************************************************* + * Complex functions + ************************************************************************/ + + /** + * Compute the argument of a complex value. For a complex number a + bi, + * the argument is computed as atan2(b, a). For matrices, the function + * is evaluated element wise. + */ + + arg(this: MathJsChain): MathJsChain + arg(this: MathJsChain): MathJsChain + arg(this: MathJsChain): MathJsChain + arg(this: MathJsChain): MathJsChain + + /** + * Compute the complex conjugate of a complex value. If x = a+bi, the + * complex conjugate of x is a - bi. For matrices, the function is + * evaluated element wise. + */ + conj( + this: MathJsChain + ): MathJsChain> + + /** + * Get the imaginary part of a complex number. For a complex number a + + * bi, the function returns b. For matrices, the function is evaluated + * element wise. + */ + im(this: MathJsChain): MathJsChain + im(this: MathJsChain): MathJsChain + im(this: MathJsChain): MathJsChain + + /** + * Get the real part of a complex number. For a complex number a + bi, + * the function returns a. For matrices, the function is evaluated + * element wise. + */ + re(this: MathJsChain): MathJsChain + re(this: MathJsChain): MathJsChain + re(this: MathJsChain): MathJsChain + + /************************************************************************* + * Geometry functions + ************************************************************************/ + + /** + * Calculates: The eucledian distance between two points in 2 and 3 + * dimensional spaces. Distance between point and a line in 2 and 3 + * dimensional spaces. Pairwise distance between a set of 2D or 3D + * points NOTE: When substituting coefficients of a line(a, b and c), + * use ax + by + c = 0 instead of ax + by = c For parametric equation of + * a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, + * c) + * @param y Coordinates of the second point + */ + distance( + this: MathJsChain, + y: MathCollection | object + ): MathJsChain + + /** + * Calculates the point of intersection of two lines in two or three + * dimensions and of a line and a plane in three dimensions. The inputs + * are in the form of arrays or 1 dimensional matrices. The line + * intersection functions return null if the lines do not meet. Note: + * Fill the plane coefficients as x + y + z = c and not as x + y + z + c + * = 0. + * @param x Co-ordinates of second end-point of first line + * @param y Co-ordinates of first end-point of second line OR + * Coefficients of the plane's equation + * @param z Co-ordinates of second end-point of second line OR null if + * the calculation is for line and plane + */ + intersect( + this: MathJsChain, + x: MathCollection, + y: MathCollection, + z?: MathCollection + ): MathJsChain + + /************************************************************************* + * Logical functions + ************************************************************************/ + + /** + * Logical and. Test whether two values are both defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param y Second value to and + */ + and( + this: MathJsChain< + number | BigNumber | bigint | Complex | Unit | MathCollection + >, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): MathJsChain + + /** + * Logical not. Flips boolean value of a given parameter. For matrices, + * the function is evaluated element wise. + */ + not( + this: MathJsChain< + number | BigNumber | bigint | Complex | Unit | MathCollection + > + ): MathJsChain + + /** + * Logical or. Test if at least one value is defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param y Second value to or + */ + or( + this: MathJsChain< + number | BigNumber | bigint | Complex | Unit | MathCollection + >, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): MathJsChain + + /** + * Logical xor. Test whether one and only one value is defined with a + * nonzero/nonempty value. For matrices, the function is evaluated + * element wise. + * @param y Second value to xor + */ + xor( + this: MathJsChain< + number | BigNumber | bigint | Complex | Unit | MathCollection + >, + y: number | BigNumber | bigint | Complex | Unit | MathCollection + ): MathJsChain + + /************************************************************************* + * Matrix functions + ************************************************************************/ + + /** + * Concatenate two or more matrices. dim: number is a zero-based + * dimension over which to concatenate the matrices. By default the last + * dimension of the matrices. + */ + + concat( + this: MathJsChain> + ): MathJsChain + + /** + * Calculate the cross product for two vectors in three dimensional + * space. The cross product of A = [a1, a2, a3] and B =[b1, b2, b3] is + * defined as: cross(A, B) = [ a2 * b3 - a3 * b2, a3 * b1 - a1 * b3, a1 + * * b2 - a2 * b1 ] + * @param y Second vector + */ + cross( + this: MathJsChain, + y: MathCollection + ): MathJsChain + + /** + * Calculate the determinant of a matrix. + */ + + det(this: MathJsChain): MathJsChain + + /** + * Create a diagonal matrix or retrieve the diagonal of a matrix. When x + * is a vector, a matrix with vector x on the diagonal will be returned. + * When x is a two dimensional matrix, the matrixes kth diagonal will be + * returned as vector. When k is positive, the values are placed on the + * super diagonal. When k is negative, the values are placed on the sub + * diagonal. + * @param k The diagonal where the vector will be filled in or + * retrieved. Default value: 0. + * @param format The matrix storage format. Default value: 'dense'. + */ + diag(this: MathJsChain, format?: string): MathJsChain + diag( + this: MathJsChain, + k: number | BigNumber, + format?: string + ): MathJsChain + + /** + * Calculate the dot product of two vectors. The dot product of A = [a1, + * a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] is defined as: dot(A, + * B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn + * @param y Second vector + */ + dot(this: MathJsChain, y: MathCollection): MathJsChain + + /** + * Compute the matrix exponential, expm(A) = e^A. The matrix must be + * square. Not to be confused with exp(a), which performs element-wise + * exponentiation. The exponential is calculated using the Padé + * approximant with scaling and squaring; see “Nineteen Dubious Ways to + * Compute the Exponential of a Matrix,” by Moler and Van Loan. + */ + + expm(this: MathJsChain): MathJsChain + + /** + * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal + * and T is upper quasi-triangular. + * https://en.wikipedia.org/wiki/Schur_decomposition + * @returns Object containing both matrix U and T of the Schur Decomposition A=UTU' + */ + schur(this: MathJsChain): SchurDecomposition + + /** + * Solves the Continuous-time Lyapunov equation AP+PA'=Q for P, where Q is a positive semidefinite + * matrix. + * https://en.wikipedia.org/wiki/Lyapunov_equation + * @param Q Matrix Q + * @returns Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q + */ + lyap( + this: MathJsChain, + Q: MathCollection + ): MathJsChain + + /** + * Create a 2-dimensional identity matrix with size m x n or n x n. The + * matrix has ones on the diagonal and zeros elsewhere. + * @param format The Matrix storage format + */ + identity( + this: MathJsChain, + format?: string + ): MathJsChain + + /** + * @param n The y dimension for the matrix + * @param format The Matrix storage format + */ + identity( + this: MathJsChain, + n: number, + format?: string + ): MathJsChain + + /** + * Filter the items in an array or one dimensional matrix. + */ + filter( + this: MathJsChain, + test: + | (( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + index: any, + matrix: MathCollection | string[] + ) => boolean) + | RegExp + ): MathJsChain + + /** + * Flatten a multi dimensional matrix into a single dimensional matrix. + */ + + flatten(x: MathJsChain): MathJsChain + + /** + * Iterate over all elements of a matrix/array, and executes the given + * callback function. + */ + forEach( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (value: any, index: any, matrix: T) => void + ): void + + /** + * Calculate the inverse of a square matrix. + */ + + inv( + this: MathJsChain + ): MathJsChain> + + /** + * Calculate the Kronecker product of two matrices or vectors + * @param y Second vector + */ + kron( + this: MathJsChain, + y: MathCollection + ): MathJsChain + + /** + * Iterate over all elements of a matrix/array, and executes the given + * callback function. + * @param callback The callback function is invoked with three + * parameters: the value of the element, the index of the element, and + * the Matrix/array being traversed. + */ + map( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback: (value: any, index: any, matrix: T) => MathType | string + ): MathJsChain + + /** + * Create a matrix filled with ones. The created matrix can have one or + * multiple dimensions. + * @param format The matrix storage format + */ + ones( + this: MathJsChain, + format?: string + ): MathJsChain + + /** + * Partition-based selection of an array or 1D matrix. Will find the kth + * smallest value, and mutates the input array. Uses Quickselect. + * @param k The kth smallest value to be retrieved; zero-based index + * @param compare An optional comparator function. The function is + * called as compare(a, b), and must return 1 when a > b, -1 when a < b, + * and 0 when a == b. Default value: 'asc'. + */ + partitionSelect( + this: MathJsChain, + k: number, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compare?: 'asc' | 'desc' | ((a: any, b: any) => number) + ): MathJsChain + + /** + * Create an array from a range. By default, the range end is excluded. + * This can be customized by providing an extra parameter includeEnd. + * @param end End of the range, excluded by default, included when + * parameter includeEnd=true + * @param step Step size. Default value is 1. + * @param includeEnd: Option to specify whether to include the end or + * not. False by default + */ + range(this: MathJsChain, includeEnd?: boolean): MathJsChain + range( + this: MathJsChain, + end: number | BigNumber, + includeEnd?: boolean + ): MathJsChain + range( + this: MathJsChain, + end: number | BigNumber | Unit, + step: number | BigNumber | Unit, + includeEnd?: boolean + ): MathJsChain + + /** + * Reshape a multi dimensional array to fit the specified dimensions + * @param sizes One dimensional array with integral sizes for each + * dimension + */ + reshape( + this: MathJsChain, + sizes: number[] + ): MathJsChain + + /** + * Resize a matrix + * @param size One dimensional array with numbers + * @param defaultValue Zero by default, except in case of a string, in + * that case defaultValue = ' ' Default value: 0. + */ + resize( + this: MathJsChain, + size: MathCollection, + defaultValue?: number | string + ): MathJsChain + + /** + * Calculate the size of a matrix or scalar. + */ + size( + this: MathJsChain< + boolean | number | Complex | Unit | string | MathCollection + > + ): MathJsChain + + /** + * Sort the items in a matrix + * @param compare An optional _comparator function or name. The function + * is called as compare(a, b), and must return 1 when a > b, -1 when a < + * b, and 0 when a == b. Default value: ‘asc’ + */ + sort( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compare: ((a: any, b: any) => number) | 'asc' | 'desc' | 'natural' + ): MathJsChain + + /** + * Calculate the principal square root of a square matrix. The principal + * square root matrix X of another matrix A is such that X * X = A. + */ + + sqrtm(A: MathJsChain): MathJsChain + + /** + * Squeeze a matrix, remove inner and outer singleton dimensions from a + * matrix. + */ + + squeeze(x: MathJsChain): MathJsChain + + /** + * Get or set a subset of a matrix or string. + * @param index For each dimension, an index or list of indices to get or set + * @param replacement An array, matrix, or scalar. If provided, the + * subset is replaced with replacement. If not provided, the subset is + * returned + * @param defaultValue Default value, filled in on new entries when the + * matrix is resized. If not provided, math.matrix elements will be left + * undefined. Default value: undefined. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + subset( + this: MathJsChain, + index: Index, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + replacement?: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + defaultValue?: any + ): MathJsChain + + /** + * Calculate the trace of a matrix: the sum of the elements on the main + * diagonal of a square matrix. + */ + + trace(this: MathJsChain): MathJsChain + + /** + * Transpose a matrix. All values of the matrix are reflected over its + * main diagonal. Only two dimensional matrices are supported. + */ + + transpose(x: MathJsChain): MathJsChain + + /** + * Create a matrix filled with zeros. The created matrix can have one or + * multiple dimensions. + * @param format The matrix storage format + * @returns A matrix filled with zeros + */ + zeros( + this: MathJsChain, + format?: string + ): MathJsChain + + /************************************************************************* + * Probability functions + ************************************************************************/ + + /** + * Compute the number of ways of picking k unordered outcomes from n + * possibilities. Combinations only takes integer arguments. The + * following condition must be enforced: k <= n. + * @param k Number of objects in the subset + */ + combinations( + n: MathJsChain, + k: number | BigNumber + ): MathJsChain> + + /** + * Compute the factorial of a value Factorial only supports an integer + * value as argument. For matrices, the function is evaluated element + * wise. + */ + + factorial( + n: MathJsChain + ): MathJsChain> + + /** + * Compute the gamma function of a value using Lanczos approximation for + * small values, and an extended Stirling approximation for large + * values. For matrices, the function is evaluated element wise. + */ + + gamma( + n: MathJsChain + ): MathJsChain> + + /** + * Calculate the Kullback-Leibler (KL) divergence between two + * distributions + * @param p Second vector + */ + kldivergence( + this: MathJsChain, + p: MathCollection + ): MathJsChain + + /** + * Multinomial Coefficients compute the number of ways of picking a1, + * a2, ..., ai unordered outcomes from n possibilities. multinomial + * takes one array of integers as an argument. The following condition + * must be enforced: every ai <= 0 + */ + + multinomial( + a: MathJsChain + ): MathJsChain> + + /** + * Compute the number of ways of obtaining an ordered subset of k + * elements from a set of n elements. Permutations only takes integer + * arguments. The following condition must be enforced: k <= n. + * @param k The number of objects in the subset + */ + permutations( + n: MathJsChain, + k?: number | BigNumber + ): MathJsChain> + + /** + * Random pick a value from a one dimensional array. Array element is + * picked using a random function with uniform distribution. + * @param number An int or float + * @param weights An array of ints or floats + */ + pickRandom(this: MathJsChain): MathJsChain + pickRandom(this: MathJsChain, number: number): MathJsChain + pickRandom( + this: MathJsChain, + number: number, + weights: number[] + ): MathJsChain + + /** + * Return a random number larger or equal to min and smaller than max + * using a uniform distribution. + * @param min Minimum boundary for the random value, included + * @param max Maximum boundary for the random value, excluded + */ + random(this: MathJsChain, max?: number): MathJsChain + + // tslint:disable-next-line unified-signatures + random( + this: MathJsChain, + min?: number, + max?: number + ): MathJsChain + + /** + * Return a random integer number larger or equal to min and smaller + * than max using a uniform distribution. + * @param min Minimum boundary for the random value, included + * @param max Maximum boundary for the random value, excluded + */ + randomInt( + this: MathJsChain, + max?: number + ): MathJsChain + randomInt( + this: MathJsChain, + max?: number + ): MathJsChain + // tslint:disable-next-line unified-signatures + randomInt( + this: MathJsChain, + min: number, + max: number + ): MathJsChain + + /************************************************************************* + * Relational functions + ************************************************************************/ + + /** + * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x + * == y. x and y are considered equal when the relative difference + * between x and y is smaller than the configured relTol and absTol. The function + * cannot be used to compare values smaller than approximately 2.22e-16. + * For matrices, the function is evaluated element wise. + * @param y Second value to compare + */ + compare( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Compare two values of any type in a deterministic, natural way. For + * numeric values, the function works the same as math.compare. For + * types of values that can’t be compared mathematically, the function + * compares in a natural way. + * @param y Second value to compare + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + compareNatural(this: MathJsChain, y: any): MathJsChain + + /** + * Compare two strings lexically. Comparison is case sensitive. Returns + * 1 when x > y, -1 when x < y, and 0 when x == y. For matrices, the + * function is evaluated element wise. + * @param y Second string to compare + */ + compareText( + this: MathJsChain, + y: string | MathCollection + ): MathJsChain + + /** + * Test element wise whether two matrices are equal. The function + * accepts both matrices and scalar values. + * @param y Second amtrix to compare + */ + deepEqual(this: MathJsChain, y: MathType): MathJsChain + + /** + * Test whether two values are equal. + * + * The function tests whether the relative difference between x and y is + * smaller than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. For matrices, the + * function is evaluated element wise. In case of complex numbers, x.re + * must equal y.re, and x.im must equal y.im. Values null and undefined + * are compared strictly, thus null is only equal to null and nothing + * else, and undefined is only equal to undefined and nothing else. + * @param y Second value to compare + */ + equal( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Check equality of two strings. Comparison is case sensitive. For + * matrices, the function is evaluated element wise. + * @param y Second string to compare + */ + equalText( + this: MathJsChain, + y: string | MathCollection + ): MathJsChain + + /** + * Test whether value x is larger than y. The function returns true when + * x is larger than y and the relative difference between x and y is + * larger than the configured relTol and absTol. The function cannot be used to + * compare values smaller than approximately 2.22e-16. For matrices, the + * function is evaluated element wise. + * @param y Second value to compare + */ + larger( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Test whether value x is larger or equal to y. The function returns + * true when x is larger than y or the relative difference between x and + * y is smaller than the configured relTol and absTol. The function cannot be used + * to compare values smaller than approximately 2.22e-16. For matrices, + * the function is evaluated element wise. + * @param y Second value to vcompare + */ + largerEq( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Test whether value x is smaller than y. The function returns true + * when x is smaller than y and the relative difference between x and y + * is smaller than the configured relTol and absTol. The function cannot be used + * to compare values smaller than approximately 2.22e-16. For matrices, + * the function is evaluated element wise. + * @param y Second value to vcompare + */ + smaller( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Test whether value x is smaller or equal to y. The function returns + * true when x is smaller than y or the relative difference between x + * and y is smaller than the configured relTol and absTol. The function cannot be + * used to compare values smaller than approximately 2.22e-16. For + * matrices, the function is evaluated element wise. + * @param y Second value to compare + */ + smallerEq( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /** + * Determines if two expressions are symbolically equal, i.e. one is the + * result of valid algebraic manipulations on the other. + * @param {Node} expr2 The second expression to compare + * @param {Object} [options] Optional option object, passed to simplify + * @returns {boolean} Returns true if a valid manipulation making the + * expressions equal is found. + */ + symbolicEqual( + this: MathJsChain, + expr2: MathNode, + options?: SimplifyOptions + ): MathJsChain + + /** + * Test whether two values are unequal. The function tests whether the + * relative difference between x and y is larger than the configured + * relTol and absTol. The function cannot be used to compare values smaller than + * approximately 2.22e-16. For matrices, the function is evaluated + * element wise. In case of complex numbers, x.re must unequal y.re, or + * x.im must unequal y.im. Values null and undefined are compared + * strictly, thus null is unequal with everything except null, and + * undefined is unequal with everything except undefined. + * @param y Second value to vcompare + */ + unequal( + this: MathJsChain, + y: MathType | string + ): MathJsChain + + /************************************************************************* + * Set functions + ************************************************************************/ + + /** + * Create the cartesian product of two (multi)sets. Multi-dimension + * arrays will be converted to single-dimension arrays and the values + * will be sorted in ascending order before the operation. + * @param a2 A (multi)set + */ + setCartesian( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /** + * Create the difference of two (multi)sets: every element of set1, that + * is not the element of set2. Multi-dimension arrays will be converted + * to single-dimension arrays before the operation + * @param a2 A (multi)set + */ + setDifference( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /** + * Collect the distinct elements of a multiset. A multi-dimension array + * will be converted to a single-dimension array before the operation. + */ + + setDistinct(a: MathJsChain): MathJsChain + + /** + * Create the intersection of two (multi)sets. Multi-dimension arrays + * will be converted to single-dimension arrays before the operation. + * @param a2 A (multi)set + */ + setIntersect( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /** + * Check whether a (multi)set is a subset of another (multi)set. (Every + * element of set1 is the element of set2.) Multi-dimension arrays will + * be converted to single-dimension arrays before the operation. + * @param a2 A (multi)set + */ + setIsSubset( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /** + * Count the multiplicity of an element in a multiset. A multi-dimension + * array will be converted to a single-dimension array before the + * operation. + * @param a A multiset + */ + setMultiplicity( + e: MathJsChain, + a: MathCollection + ): MathJsChain + + /** + * Create the powerset of a (multi)set. (The powerset contains very + * possible subsets of a (multi)set.) A multi-dimension array will be + * converted to a single-dimension array before the operation. + */ + + setPowerset(a: MathJsChain): MathJsChain + + /** + * Count the number of elements of a (multi)set. When a second parameter + * is ‘true’, count only the unique values. A multi-dimension array will + * be converted to a single-dimension array before the operation. + */ + + setSize(this: MathJsChain): MathJsChain + + /** + * Create the symmetric difference of two (multi)sets. Multi-dimension + * arrays will be converted to single-dimension arrays before the + * operation. + * @param a2 A (multi)set + */ + setSymDifference( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /** + * Create the union of two (multi)sets. Multi-dimension arrays will be + * converted to single-dimension arrays before the operation. + * @param a2 A (multi)set + */ + setUnion( + this: MathJsChain, + a2: MathCollection + ): MathJsChain + + /************************************************************************* + * Signal functions + ************************************************************************/ + /** + * Compute the transfer function of a zero-pole-gain model. + */ + zpk2tf( + this: MathJsChain, // chained variable will be used as z + p: T, + k?: number + ): MathJsChain + + /** + * Calculates the frequency response of a filter given its numerator and denominator coefficients. + */ + freqz( + this: MathJsChain, + a: T, + w?: T | number + ): MathJsChain<{ w: T; h: T }> + + /************************************************************************* + * Special functions + ************************************************************************/ + + /** + * Compute the erf function of a value using a rational Chebyshev + * approximations for different intervals of x. + */ + erf( + this: MathJsChain + ): MathJsChain> + + /** + * Compute the Riemann Zeta function of a value using an infinite series + * and Riemann's Functional equation. + */ + zeta( + this: MathJsChain + ): MathJsChain + + /************************************************************************* + * Statistics functions + ************************************************************************/ + + /** + * Compute the median absolute deviation of a matrix or a list with + * values. The median absolute deviation is defined as the median of the + * absolute deviations from the median. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + mad(this: MathJsChain): MathJsChain + + /** + * Compute the maximum value of a matrix or a list with values. In case + * of a multi dimensional array, the maximum of the flattened array will + * be calculated. When dim is provided, the maximum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param dim The maximum over the selected dimension + */ + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + max(this: MathJsChain, dim?: number): MathJsChain + // eslint-disable-next-line @typescript-eslint/no-explicit-any + max(this: MathJsChain, dim?: number): MathJsChain + + /** + * Compute the mean value of matrix or a list with values. In case of a + * multi dimensional array, the mean of the flattened array will be + * calculated. When dim is provided, the maximum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param dim The mean over the selected dimension + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + mean(this: MathJsChain, dim?: number): MathJsChain + // eslint-disable-next-line @typescript-eslint/no-explicit-any + mean(this: MathJsChain, dim?: number): MathJsChain + + /** + * Compute the median of a matrix or a list with values. The values are + * sorted and the middle value is returned. In case of an even number of + * values, the average of the two middle values is returned. Supported + * types of values are: Number, BigNumber, Unit In case of a (multi + * dimensional) array or matrix, the median of all elements will be + * calculated. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + median(this: MathJsChain, dim?: number): MathJsChain + // eslint-disable-next-line @typescript-eslint/no-explicit-any + median(this: MathJsChain, dim?: number): MathJsChain + + /** + * Compute the minimum value of a matrix or a list of values. In case of + * a multi dimensional array, the minimum of the flattened array will be + * calculated. When dim is provided, the minimum over the selected + * dimension will be calculated. Parameter dim is zero-based. + * @param dim The minimum over the selected dimension + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + min(this: MathJsChain): MathJsChain + // eslint-disable-next-line @typescript-eslint/no-explicit-any + min(this: MathJsChain, dim?: number): MathJsChain + + /** + * Computes the mode of a set of numbers or a list with values(numbers + * or characters). If there are more than one modes, it returns a list + * of those values. + */ + + mode(this: MathJsChain): MathJsChain + + /** + * Compute the product of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the sum of all elements will be + * calculated. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + prod(this: MathJsChain): MathJsChain + + /** + * Compute the prob order quantile of a matrix or a list with values. + * The sequence is sorted and the middle value is returned. Supported + * types of sequence values are: Number, BigNumber, Unit Supported types + * of probability are: Number, BigNumber In case of a (multi + * dimensional) array or matrix, the prob order quantile of all elements + * will be calculated. + * @param probOrN prob is the order of the quantile, while N is the + * amount of evenly distributed steps of probabilities; only one of + * these options can be provided + * @param sorted =false is data sorted in ascending order + */ + quantileSeq( + A: MathJsChain, + prob: number | BigNumber | MathArray, + sorted?: boolean + ): MathJsChain + + /** + * Compute the standard deviation of a matrix or a list with values. The + * standard deviations is defined as the square root of the variance: + * std(A) = sqrt(variance(A)). In case of a (multi dimensional) array or + * matrix, the standard deviation over all elements will be calculated. + * Optionally, the type of normalization can be specified as second + * parameter. The parameter normalization can be one of the following + * values: 'unbiased' (default) The sum of squared errors is divided by + * (n - 1) 'uncorrected' The sum of squared errors is divided by n + * 'biased' The sum of squared errors is divided by (n + 1) + * @param dim A dimension to compute standard deviation. + * @param normalization Determines how to normalize the variance. Choose + * ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. Default value: + * ‘unbiased’. + * @returns The standard deviation + */ + std( + this: MathJsChain, + dim?: number, + normalization?: 'unbiased' | 'uncorrected' | 'biased' + ): MathJsChain + + /** + * Compute the standard deviation of a matrix or a list with values. The + * standard deviations is defined as the square root of the variance: + * std(A) = sqrt(variance(A)). In case of a (multi dimensional) array or + * matrix, the standard deviation over all elements will be calculated. + * Optionally, the type of normalization can be specified as second + * parameter. The parameter normalization can be one of the following + * values: 'unbiased' (default) The sum of squared errors is divided by + * (n - 1) 'uncorrected' The sum of squared errors is divided by n + * 'biased' The sum of squared errors is divided by (n + 1) + * @param normalization Determines how to normalize the variance. Choose + * ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. Default value: + * ‘unbiased’. + * @returns The standard deviation + */ + std( + this: MathJsChain, + dimension?: number, + normalization?: 'unbiased' | 'uncorrected' | 'biased' + ): MathJsChain + + /** + * Compute the sum of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the sum of all elements will be + * calculated. + */ + std( + this: MathJsChain, + normalization: 'unbiased' | 'uncorrected' | 'biased' + ): MathJsChain + + /** + * Compute the variance of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the variance over all elements + * will be calculated. Optionally, the type of normalization can be + * specified as second parameter. The parameter normalization can be one + * of the following values: 'unbiased' (default) The sum of squared + * errors is divided by (n - 1) 'uncorrected' The sum of squared errors + * is divided by n 'biased' The sum of squared errors is divided by (n + + * 1) Note that older browser may not like the variable name var. In + * that case, the function can be called as math['var'](...) instead of + * math.variance(...). + * @param dim a dimension to compute variance. + * @param normalization normalization Determines how to normalize the + * variance. Choose ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. + * Default value: ‘unbiased’. + * @returns The variance + */ + variance( + this: MathJsChain>> + ): MathJsChain + + /** + * Compute the variance of a matrix or a list with values. In case of a + * (multi dimensional) array or matrix, the variance over all elements + * will be calculated. Optionally, the type of normalization can be + * specified as second parameter. The parameter normalization can be one + * of the following values: 'unbiased' (default) The sum of squared + * errors is divided by (n - 1) 'uncorrected' The sum of squared errors + * is divided by n 'biased' The sum of squared errors is divided by (n + + * 1) Note that older browser may not like the variable name var. In + * that case, the function can be called as math['var'](...) instead of + * math.variance(...). + * @param normalization normalization Determines how to normalize the + * variance. Choose ‘unbiased’ (default), ‘uncorrected’, or ‘biased’. + * Default value: ‘unbiased’. + * @returns The variance + */ + variance( + this: MathJsChain, + dimension?: number, + normalization?: 'unbiased' | 'uncorrected' | 'biased' + ): MathJsChain + + variance( + this: MathJsChain, + normalization: 'unbiased' | 'uncorrected' | 'biased' + ): MathJsChain + + /************************************************************************* + * String functions + ************************************************************************/ + + /** + * Format a value of any type into a string. + * @param options An object with formatting options. + * @param callback A custom formatting function, invoked for all numeric + * elements in value, for example all elements of a matrix, or the real + * and imaginary parts of a complex number. This callback can be used to + * override the built-in numeric notation with any type of formatting. + * Function callback is called with value as parameter and must return a + * string. + * @see http://mathjs.org/docs/reference/functions/format.html + */ + format( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + value: any, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + options?: FormatOptions | number | ((item: any) => string), + // eslint-disable-next-line @typescript-eslint/no-explicit-any + callback?: (value: any) => string + ): MathJsChain + + /** + * Interpolate values into a string template. + * @param values An object containing variables which will be filled in + * in the template. + * @param precision Number of digits to format numbers. If not provided, + * the value will not be rounded. + * @param options Formatting options, or the number of digits to format + * numbers. See function math.format for a description of all options. + */ + print( + this: MathJsChain, + // eslint-disable-next-line @typescript-eslint/no-explicit-any + values: any, + precision?: number, + options?: number | object + ): MathJsChain + + /************************************************************************* + * Trigonometry functions + ************************************************************************/ + + /** + * Calculate the inverse cosine of a value. For matrices, the function + * is evaluated element wise. + */ + + acos( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic arccos of a value, defined as acosh(x) = + * ln(sqrt(x^2 - 1) + x). For matrices, the function is evaluated + * element wise. + */ + + acosh( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse cotangent of a value. For matrices, the + * function is evaluated element wise. + */ + + acot( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse hyperbolic tangent of a value, defined as acoth(x) + * = (ln((x+1)/x) + ln(x/(x-1))) / 2. For matrices, the function is + * evaluated element wise. + */ + + acoth( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse cosecant of a value. For matrices, the function + * is evaluated element wise. + */ + + acsc( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse hyperbolic cosecant of a value, defined as acsch(x) + * = ln(1/x + sqrt(1/x^2 + 1)). For matrices, the function is evaluated + * element wise. + */ + + acsch( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse secant of a value. For matrices, the function + * is evaluated element wise. + */ + + asec( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic arcsecant of a value, defined as asech(x) = + * ln(sqrt(1/x^2 - 1) + 1/x). For matrices, the function is evaluated + * element wise. + */ + + asech( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse sine of a value. For matrices, the function is + * evaluated element wise. + */ + + asin( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic arcsine of a value, defined as asinh(x) = + * ln(x + sqrt(x^2 + 1)). For matrices, the function is evaluated + * element wise. + */ + + asinh( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse tangent of a value. For matrices, the function + * is evaluated element wise. + */ + + atan( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the inverse tangent function with two arguments, y/x. By + * providing two arguments, the right quadrant of the computed angle can + * be determined. For matrices, the function is evaluated element wise. + */ + + atan2( + this: MathJsChain, + x: number + ): MathJsChain + + /** + * Calculate the hyperbolic arctangent of a value, defined as atanh(x) = + * ln((1 + x)/(1 - x)) / 2. For matrices, the function is evaluated + * element wise. + */ + + atanh( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the cosine of a value. For matrices, the function is + * evaluated element wise. + */ + + cos( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic cosine of a value, defined as cosh(x) = 1/2 + * * (exp(x) + exp(-x)). For matrices, the function is evaluated element + * wise. + */ + + cosh( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the cotangent of a value. cot(x) is defined as 1 / tan(x). + * For matrices, the function is evaluated element wise. + */ + + cot( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic cotangent of a value, defined as coth(x) = 1 + * / tanh(x). For matrices, the function is evaluated element wise. + */ + + coth( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the cosecant of a value, defined as csc(x) = 1/sin(x). For + * matrices, the function is evaluated element wise. + */ + + csc( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic cosecant of a value, defined as csch(x) = 1 + * / sinh(x). For matrices, the function is evaluated element wise. + */ + + csch( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the secant of a value, defined as sec(x) = 1/cos(x). For + * matrices, the function is evaluated element wise. + */ + + sec( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic secant of a value, defined as sech(x) = 1 / + * cosh(x). For matrices, the function is evaluated element wise. + */ + + sech( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the sine of a value. For matrices, the function is + * evaluated element wise. + */ + + sin( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic sine of a value, defined as sinh(x) = 1/2 * + * (exp(x) - exp(-x)). For matrices, the function is evaluated element + * wise. + */ + + sinh( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the tangent of a value. tan(x) is equal to sin(x) / cos(x). + * For matrices, the function is evaluated element wise. + */ + + tan( + this: MathJsChain + ): MathJsChain + + /** + * Calculate the hyperbolic tangent of a value, defined as tanh(x) = + * (exp(2 * x) - 1) / (exp(2 * x) + 1). For matrices, the function is + * evaluated element wise. + */ + + tanh( + this: MathJsChain + ): MathJsChain + + /************************************************************************* + * Unit functions + ************************************************************************/ + + /** + * Change the unit of a value. For matrices, the function is evaluated + * element wise. + * @param unit New unit. Can be a string like "cm" or a unit without + * value. + */ + to( + this: MathJsChain, + unit: Unit | string + ): MathJsChain + + /************************************************************************* + * Utils functions + ************************************************************************/ + + /** + * Clone an object. + */ + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + clone(this: MathJsChain): MathJsChain + + /** + * Test whether a value is an integer number. The function supports + * number, BigNumber, and Fraction. The function is evaluated + * element-wise in case of Array or Matrix input. + */ + + isInteger( + this: MathJsChain + ): MathJsChain + + /** + * Test whether a value is NaN (not a number). The function supports + * types number, BigNumber, Fraction, Unit and Complex. The function is + * evaluated element-wise in case of Array or Matrix input. + */ + + isNaN( + this: MathJsChain + ): MathJsChain + + /** + * Test whether a value is negative: smaller than zero. The function + * supports types number, BigNumber, Fraction, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + */ + + isNegative( + this: MathJsChain + ): MathJsChain + + /** + * Test whether a value is a numeric value. The function is evaluated + * element-wise in case of Array or Matrix input. + */ + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + isNumeric(this: MathJsChain): MathJsChain + + /** + * Test whether a value is positive: larger than zero. The function + * supports types number, BigNumber, Fraction, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + */ + + isPositive( + this: MathJsChain< + number | BigNumber | bigint | Fraction | MathCollection | Unit + > + ): MathJsChain + + /** + * Test whether a value is prime: has no divisors other than itself and + * one. The function supports type number, bignumber. The function is + * evaluated element-wise in case of Array or Matrix input. + */ + + isPrime( + this: MathJsChain + ): MathJsChain + + /** + * Test whether a value is zero. The function can check for zero for + * types number, BigNumber, Fraction, Complex, and Unit. The function is + * evaluated element-wise in case of Array or Matrix input. + */ + + isZero(this: MathJsChain): MathJsChain + + /** + * Determine the type of a variable. + */ + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + typeOf(this: MathJsChain): MathJsChain +} + +export interface ImportOptions { + override?: boolean + silent?: boolean + wrap?: boolean +} + +export interface ImportObject { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + [key: string]: any +} + +export const { + // config // Don't export config: no config available in the static instance + + // core functions + create, + factory, + typed, + + // constants + e, + pi, + i, + // Infinity // not needed: is available as global variable too + LN2, + LN10, + LOG2E, + LOG10E, + // NaN, // not needed: is available as global variable too + phi, + SQRT1_2, + SQRT2, + tau, + + // Class-like constructors + Node, + AccessorNode, + ArrayNode, + AssignmentNode, + BlockNode, + ConditionalNode, + ConstantNode, + FunctionAssignmentNode, + FunctionNode, + IndexNode, + ObjectNode, + OperatorNode, + ParenthesisNode, + RangeNode, + RelationalNode, + SymbolNode, + Matrix, + Unit, + + uninitialized, + version, + expression, + reviver, + replacer, + + bignumber, + boolean, + chain, + complex, + createUnit, + fraction, + index, + matrix, + number, + sparse, + splitUnit, + string, + unit, + compile, + evaluate, + help, + parse, + parser, + + // algebra + derivative, + lsolve, + lup, + lusolve, + polynomialRoot, + qr, + rationalize, + simplify, + simplifyConstant, + simplifyCore, + symbolicEqual, + leafCount, + resolve, + slu, + usolve, + + // arithmetic functions + abs, + add, + cbrt, + ceil, + fix, + floor, + round, + cube, + divide, + dotDivide, + dotMultiply, + dotPow, + exp, + expm1, + gcd, + hypot, + lcm, + log, + log10, + log1p, + log2, + mod, + multiply, + norm, + nthRoot, + pow, + sign, + sqrt, + square, + subtract, + unaryMinus, + unaryPlus, + xgcd, + + // bitwise + bitAnd, + bitNot, + bitOr, + bitXor, + leftShift, + rightArithShift, + rightLogShift, + + // combinatorics + bellNumbers, + catalan, + composition, + stirlingS2, + + // complex + arg, + conj, + im, + re, + + // geometry + distance, + intersect, + + // logical + and, + not, + or, + xor, + + // matrix functions + apply, + concat, + cross, + det, + diag, + dot, + eigs, + expm, + sylvester, + schur, + lyap, + identity, + filter, + flatten, + forEach, + inv, + kron, + map, + ones, + partitionSelect, + pinv, + range, + reshape, + resize, + rotationMatrix, + row, + column, + rotate, + size, + sort, + sqrtm, + squeeze, + subset, + trace, + transpose, + zeros, + fft, + ifft, + + // probability + combinations, + factorial, + gamma, + kldivergence, + lgamma, + multinomial, + permutations, + pickRandom, + random, + randomInt, + + // relational functions + compare, + compareNatural, + compareText, + deepEqual, + equal, + equalText, + larger, + largerEq, + smaller, + smallerEq, + unequal, + + // set functions + setCartesian, + setDifference, + setDistinct, + setIntersect, + setIsSubset, + setMultiplicity, + setPowerset, + setSize, + setSymDifference, + setUnion, + + // special functions + zpk2tf, + freqz, + erf, + zeta, + + // Statistics functions + mad, + max, + mean, + median, + min, + mode, + prod, + quantileSeq, + std, + sum, + count, + cumsum, + variance, + corr, + + // String functions + format, + print, + + // Trigonometry functions + acos, + acosh, + acot, + acoth, + acsc, + acsch, + asec, + asech, + asin, + asinh, + atan, + atan2, + atanh, + cos, + cosh, + cot, + coth, + csc, + csch, + sec, + sech, + sin, + sinh, + tan, + tanh, + + // unit functions + to, + + // util functions + isNumber, + isBigNumber, + isComplex, + isFraction, + isUnit, + isString, + isArray, + isMatrix, + isCollection, + isDenseMatrix, + isSparseMatrix, + isRange, + isIndex, + isBoolean, + isResultSet, + isHelp, + isFunction, + isDate, + isRegExp, + isObject, + isNull, + isUndefined, + isAccessorNode, + isArrayNode, + isAssignmentNode, + isBlockNode, + isConditionalNode, + isConstantNode, + isFunctionAssignmentNode, + isFunctionNode, + isIndexNode, + isNode, + isObjectNode, + isOperatorNode, + isParenthesisNode, + isRangeNode, + isRelationalNode, + isSymbolNode, + isChain, + clone, + hasNumericValue, + isInteger, + isNaN, + isNegative, + isNumeric, + isPositive, + isPrime, + isZero, + typeOf +}: MathJsInstance diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/tslint.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/tslint.json new file mode 100644 index 0000000..422bfa8 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/mathjs/types/tslint.json @@ -0,0 +1,6 @@ +{ + "extends": "dtslint/dtslint.json", + "rules": { + "no-redundant-jsdoc": false + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/LICENSE b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/LICENSE new file mode 100644 index 0000000..cde61b6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2014-present, Facebook, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/README.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/README.md new file mode 100644 index 0000000..e8702ba --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/README.md @@ -0,0 +1,31 @@ +# regenerator-runtime + +Standalone runtime for +[Regenerator](https://github.com/facebook/regenerator)-compiled generator +and `async` functions. + +To import the runtime as a module (recommended), either of the following +import styles will work: +```js +// CommonJS +const regeneratorRuntime = require("regenerator-runtime"); + +// ECMAScript 2015 +import regeneratorRuntime from "regenerator-runtime"; +``` + +To ensure that `regeneratorRuntime` is defined globally, either of the +following styles will work: +```js +// CommonJS +require("regenerator-runtime/runtime"); + +// ECMAScript 2015 +import "regenerator-runtime/runtime.js"; +``` + +To get the absolute file system path of `runtime.js`, evaluate the +following expression: +```js +require("regenerator-runtime/path").path +``` diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/package.json new file mode 100644 index 0000000..503086f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/package.json @@ -0,0 +1,19 @@ +{ + "name": "regenerator-runtime", + "author": "Ben Newman ", + "description": "Runtime for Regenerator-compiled generator and async functions.", + "version": "0.14.1", + "main": "runtime.js", + "keywords": [ + "regenerator", + "runtime", + "generator", + "async" + ], + "sideEffects": true, + "repository": { + "type": "git", + "url": "https://github.com/facebook/regenerator/tree/main/packages/runtime" + }, + "license": "MIT" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/path.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/path.js new file mode 100644 index 0000000..ced878b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/path.js @@ -0,0 +1,11 @@ +/** + * Copyright (c) 2014-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +exports.path = require("path").join( + __dirname, + "runtime.js" +); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/runtime.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/runtime.js new file mode 100644 index 0000000..5593ca5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/regenerator-runtime/runtime.js @@ -0,0 +1,761 @@ +/** + * Copyright (c) 2014-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +var runtime = (function (exports) { + "use strict"; + + var Op = Object.prototype; + var hasOwn = Op.hasOwnProperty; + var defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }; + var undefined; // More compressible than void 0. + var $Symbol = typeof Symbol === "function" ? Symbol : {}; + var iteratorSymbol = $Symbol.iterator || "@@iterator"; + var asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator"; + var toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; + + function define(obj, key, value) { + Object.defineProperty(obj, key, { + value: value, + enumerable: true, + configurable: true, + writable: true + }); + return obj[key]; + } + try { + // IE 8 has a broken Object.defineProperty that only works on DOM objects. + define({}, ""); + } catch (err) { + define = function(obj, key, value) { + return obj[key] = value; + }; + } + + function wrap(innerFn, outerFn, self, tryLocsList) { + // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator. + var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator; + var generator = Object.create(protoGenerator.prototype); + var context = new Context(tryLocsList || []); + + // The ._invoke method unifies the implementations of the .next, + // .throw, and .return methods. + defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }); + + return generator; + } + exports.wrap = wrap; + + // Try/catch helper to minimize deoptimizations. Returns a completion + // record like context.tryEntries[i].completion. This interface could + // have been (and was previously) designed to take a closure to be + // invoked without arguments, but in all the cases we care about we + // already have an existing method we want to call, so there's no need + // to create a new function object. We can even get away with assuming + // the method takes exactly one argument, since that happens to be true + // in every case, so we don't have to touch the arguments object. The + // only additional allocation required is the completion record, which + // has a stable shape and so hopefully should be cheap to allocate. + function tryCatch(fn, obj, arg) { + try { + return { type: "normal", arg: fn.call(obj, arg) }; + } catch (err) { + return { type: "throw", arg: err }; + } + } + + var GenStateSuspendedStart = "suspendedStart"; + var GenStateSuspendedYield = "suspendedYield"; + var GenStateExecuting = "executing"; + var GenStateCompleted = "completed"; + + // Returning this object from the innerFn has the same effect as + // breaking out of the dispatch switch statement. + var ContinueSentinel = {}; + + // Dummy constructor functions that we use as the .constructor and + // .constructor.prototype properties for functions that return Generator + // objects. For full spec compliance, you may wish to configure your + // minifier not to mangle the names of these two functions. + function Generator() {} + function GeneratorFunction() {} + function GeneratorFunctionPrototype() {} + + // This is a polyfill for %IteratorPrototype% for environments that + // don't natively support it. + var IteratorPrototype = {}; + define(IteratorPrototype, iteratorSymbol, function () { + return this; + }); + + var getProto = Object.getPrototypeOf; + var NativeIteratorPrototype = getProto && getProto(getProto(values([]))); + if (NativeIteratorPrototype && + NativeIteratorPrototype !== Op && + hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) { + // This environment has a native %IteratorPrototype%; use it instead + // of the polyfill. + IteratorPrototype = NativeIteratorPrototype; + } + + var Gp = GeneratorFunctionPrototype.prototype = + Generator.prototype = Object.create(IteratorPrototype); + GeneratorFunction.prototype = GeneratorFunctionPrototype; + defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: true }); + defineProperty( + GeneratorFunctionPrototype, + "constructor", + { value: GeneratorFunction, configurable: true } + ); + GeneratorFunction.displayName = define( + GeneratorFunctionPrototype, + toStringTagSymbol, + "GeneratorFunction" + ); + + // Helper for defining the .next, .throw, and .return methods of the + // Iterator interface in terms of a single ._invoke method. + function defineIteratorMethods(prototype) { + ["next", "throw", "return"].forEach(function(method) { + define(prototype, method, function(arg) { + return this._invoke(method, arg); + }); + }); + } + + exports.isGeneratorFunction = function(genFun) { + var ctor = typeof genFun === "function" && genFun.constructor; + return ctor + ? ctor === GeneratorFunction || + // For the native GeneratorFunction constructor, the best we can + // do is to check its .name property. + (ctor.displayName || ctor.name) === "GeneratorFunction" + : false; + }; + + exports.mark = function(genFun) { + if (Object.setPrototypeOf) { + Object.setPrototypeOf(genFun, GeneratorFunctionPrototype); + } else { + genFun.__proto__ = GeneratorFunctionPrototype; + define(genFun, toStringTagSymbol, "GeneratorFunction"); + } + genFun.prototype = Object.create(Gp); + return genFun; + }; + + // Within the body of any async function, `await x` is transformed to + // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test + // `hasOwn.call(value, "__await")` to determine if the yielded value is + // meant to be awaited. + exports.awrap = function(arg) { + return { __await: arg }; + }; + + function AsyncIterator(generator, PromiseImpl) { + function invoke(method, arg, resolve, reject) { + var record = tryCatch(generator[method], generator, arg); + if (record.type === "throw") { + reject(record.arg); + } else { + var result = record.arg; + var value = result.value; + if (value && + typeof value === "object" && + hasOwn.call(value, "__await")) { + return PromiseImpl.resolve(value.__await).then(function(value) { + invoke("next", value, resolve, reject); + }, function(err) { + invoke("throw", err, resolve, reject); + }); + } + + return PromiseImpl.resolve(value).then(function(unwrapped) { + // When a yielded Promise is resolved, its final value becomes + // the .value of the Promise<{value,done}> result for the + // current iteration. + result.value = unwrapped; + resolve(result); + }, function(error) { + // If a rejected Promise was yielded, throw the rejection back + // into the async generator function so it can be handled there. + return invoke("throw", error, resolve, reject); + }); + } + } + + var previousPromise; + + function enqueue(method, arg) { + function callInvokeWithMethodAndArg() { + return new PromiseImpl(function(resolve, reject) { + invoke(method, arg, resolve, reject); + }); + } + + return previousPromise = + // If enqueue has been called before, then we want to wait until + // all previous Promises have been resolved before calling invoke, + // so that results are always delivered in the correct order. If + // enqueue has not been called before, then it is important to + // call invoke immediately, without waiting on a callback to fire, + // so that the async generator function has the opportunity to do + // any necessary setup in a predictable way. This predictability + // is why the Promise constructor synchronously invokes its + // executor callback, and why async functions synchronously + // execute code before the first await. Since we implement simple + // async functions in terms of async generators, it is especially + // important to get this right, even though it requires care. + previousPromise ? previousPromise.then( + callInvokeWithMethodAndArg, + // Avoid propagating failures to Promises returned by later + // invocations of the iterator. + callInvokeWithMethodAndArg + ) : callInvokeWithMethodAndArg(); + } + + // Define the unified helper method that is used to implement .next, + // .throw, and .return (see defineIteratorMethods). + defineProperty(this, "_invoke", { value: enqueue }); + } + + defineIteratorMethods(AsyncIterator.prototype); + define(AsyncIterator.prototype, asyncIteratorSymbol, function () { + return this; + }); + exports.AsyncIterator = AsyncIterator; + + // Note that simple async functions are implemented on top of + // AsyncIterator objects; they just return a Promise for the value of + // the final result produced by the iterator. + exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) { + if (PromiseImpl === void 0) PromiseImpl = Promise; + + var iter = new AsyncIterator( + wrap(innerFn, outerFn, self, tryLocsList), + PromiseImpl + ); + + return exports.isGeneratorFunction(outerFn) + ? iter // If outerFn is a generator, return the full iterator. + : iter.next().then(function(result) { + return result.done ? result.value : iter.next(); + }); + }; + + function makeInvokeMethod(innerFn, self, context) { + var state = GenStateSuspendedStart; + + return function invoke(method, arg) { + if (state === GenStateExecuting) { + throw new Error("Generator is already running"); + } + + if (state === GenStateCompleted) { + if (method === "throw") { + throw arg; + } + + // Be forgiving, per GeneratorResume behavior specified since ES2015: + // ES2015 spec, step 3: https://262.ecma-international.org/6.0/#sec-generatorresume + // Latest spec, step 2: https://tc39.es/ecma262/#sec-generatorresume + return doneResult(); + } + + context.method = method; + context.arg = arg; + + while (true) { + var delegate = context.delegate; + if (delegate) { + var delegateResult = maybeInvokeDelegate(delegate, context); + if (delegateResult) { + if (delegateResult === ContinueSentinel) continue; + return delegateResult; + } + } + + if (context.method === "next") { + // Setting context._sent for legacy support of Babel's + // function.sent implementation. + context.sent = context._sent = context.arg; + + } else if (context.method === "throw") { + if (state === GenStateSuspendedStart) { + state = GenStateCompleted; + throw context.arg; + } + + context.dispatchException(context.arg); + + } else if (context.method === "return") { + context.abrupt("return", context.arg); + } + + state = GenStateExecuting; + + var record = tryCatch(innerFn, self, context); + if (record.type === "normal") { + // If an exception is thrown from innerFn, we leave state === + // GenStateExecuting and loop back for another invocation. + state = context.done + ? GenStateCompleted + : GenStateSuspendedYield; + + if (record.arg === ContinueSentinel) { + continue; + } + + return { + value: record.arg, + done: context.done + }; + + } else if (record.type === "throw") { + state = GenStateCompleted; + // Dispatch the exception by looping back around to the + // context.dispatchException(context.arg) call above. + context.method = "throw"; + context.arg = record.arg; + } + } + }; + } + + // Call delegate.iterator[context.method](context.arg) and handle the + // result, either by returning a { value, done } result from the + // delegate iterator, or by modifying context.method and context.arg, + // setting context.delegate to null, and returning the ContinueSentinel. + function maybeInvokeDelegate(delegate, context) { + var methodName = context.method; + var method = delegate.iterator[methodName]; + if (method === undefined) { + // A .throw or .return when the delegate iterator has no .throw + // method, or a missing .next method, always terminate the + // yield* loop. + context.delegate = null; + + // Note: ["return"] must be used for ES3 parsing compatibility. + if (methodName === "throw" && delegate.iterator["return"]) { + // If the delegate iterator has a return method, give it a + // chance to clean up. + context.method = "return"; + context.arg = undefined; + maybeInvokeDelegate(delegate, context); + + if (context.method === "throw") { + // If maybeInvokeDelegate(context) changed context.method from + // "return" to "throw", let that override the TypeError below. + return ContinueSentinel; + } + } + if (methodName !== "return") { + context.method = "throw"; + context.arg = new TypeError( + "The iterator does not provide a '" + methodName + "' method"); + } + + return ContinueSentinel; + } + + var record = tryCatch(method, delegate.iterator, context.arg); + + if (record.type === "throw") { + context.method = "throw"; + context.arg = record.arg; + context.delegate = null; + return ContinueSentinel; + } + + var info = record.arg; + + if (! info) { + context.method = "throw"; + context.arg = new TypeError("iterator result is not an object"); + context.delegate = null; + return ContinueSentinel; + } + + if (info.done) { + // Assign the result of the finished delegate to the temporary + // variable specified by delegate.resultName (see delegateYield). + context[delegate.resultName] = info.value; + + // Resume execution at the desired location (see delegateYield). + context.next = delegate.nextLoc; + + // If context.method was "throw" but the delegate handled the + // exception, let the outer generator proceed normally. If + // context.method was "next", forget context.arg since it has been + // "consumed" by the delegate iterator. If context.method was + // "return", allow the original .return call to continue in the + // outer generator. + if (context.method !== "return") { + context.method = "next"; + context.arg = undefined; + } + + } else { + // Re-yield the result returned by the delegate method. + return info; + } + + // The delegate iterator is finished, so forget it and continue with + // the outer generator. + context.delegate = null; + return ContinueSentinel; + } + + // Define Generator.prototype.{next,throw,return} in terms of the + // unified ._invoke helper method. + defineIteratorMethods(Gp); + + define(Gp, toStringTagSymbol, "Generator"); + + // A Generator should always return itself as the iterator object when the + // @@iterator function is called on it. Some browsers' implementations of the + // iterator prototype chain incorrectly implement this, causing the Generator + // object to not be returned from this call. This ensures that doesn't happen. + // See https://github.com/facebook/regenerator/issues/274 for more details. + define(Gp, iteratorSymbol, function() { + return this; + }); + + define(Gp, "toString", function() { + return "[object Generator]"; + }); + + function pushTryEntry(locs) { + var entry = { tryLoc: locs[0] }; + + if (1 in locs) { + entry.catchLoc = locs[1]; + } + + if (2 in locs) { + entry.finallyLoc = locs[2]; + entry.afterLoc = locs[3]; + } + + this.tryEntries.push(entry); + } + + function resetTryEntry(entry) { + var record = entry.completion || {}; + record.type = "normal"; + delete record.arg; + entry.completion = record; + } + + function Context(tryLocsList) { + // The root entry object (effectively a try statement without a catch + // or a finally block) gives us a place to store values thrown from + // locations where there is no enclosing try statement. + this.tryEntries = [{ tryLoc: "root" }]; + tryLocsList.forEach(pushTryEntry, this); + this.reset(true); + } + + exports.keys = function(val) { + var object = Object(val); + var keys = []; + for (var key in object) { + keys.push(key); + } + keys.reverse(); + + // Rather than returning an object with a next method, we keep + // things simple and return the next function itself. + return function next() { + while (keys.length) { + var key = keys.pop(); + if (key in object) { + next.value = key; + next.done = false; + return next; + } + } + + // To avoid creating an additional object, we just hang the .value + // and .done properties off the next function object itself. This + // also ensures that the minifier will not anonymize the function. + next.done = true; + return next; + }; + }; + + function values(iterable) { + if (iterable != null) { + var iteratorMethod = iterable[iteratorSymbol]; + if (iteratorMethod) { + return iteratorMethod.call(iterable); + } + + if (typeof iterable.next === "function") { + return iterable; + } + + if (!isNaN(iterable.length)) { + var i = -1, next = function next() { + while (++i < iterable.length) { + if (hasOwn.call(iterable, i)) { + next.value = iterable[i]; + next.done = false; + return next; + } + } + + next.value = undefined; + next.done = true; + + return next; + }; + + return next.next = next; + } + } + + throw new TypeError(typeof iterable + " is not iterable"); + } + exports.values = values; + + function doneResult() { + return { value: undefined, done: true }; + } + + Context.prototype = { + constructor: Context, + + reset: function(skipTempReset) { + this.prev = 0; + this.next = 0; + // Resetting context._sent for legacy support of Babel's + // function.sent implementation. + this.sent = this._sent = undefined; + this.done = false; + this.delegate = null; + + this.method = "next"; + this.arg = undefined; + + this.tryEntries.forEach(resetTryEntry); + + if (!skipTempReset) { + for (var name in this) { + // Not sure about the optimal order of these conditions: + if (name.charAt(0) === "t" && + hasOwn.call(this, name) && + !isNaN(+name.slice(1))) { + this[name] = undefined; + } + } + } + }, + + stop: function() { + this.done = true; + + var rootEntry = this.tryEntries[0]; + var rootRecord = rootEntry.completion; + if (rootRecord.type === "throw") { + throw rootRecord.arg; + } + + return this.rval; + }, + + dispatchException: function(exception) { + if (this.done) { + throw exception; + } + + var context = this; + function handle(loc, caught) { + record.type = "throw"; + record.arg = exception; + context.next = loc; + + if (caught) { + // If the dispatched exception was caught by a catch block, + // then let that catch block handle the exception normally. + context.method = "next"; + context.arg = undefined; + } + + return !! caught; + } + + for (var i = this.tryEntries.length - 1; i >= 0; --i) { + var entry = this.tryEntries[i]; + var record = entry.completion; + + if (entry.tryLoc === "root") { + // Exception thrown outside of any try block that could handle + // it, so set the completion value of the entire function to + // throw the exception. + return handle("end"); + } + + if (entry.tryLoc <= this.prev) { + var hasCatch = hasOwn.call(entry, "catchLoc"); + var hasFinally = hasOwn.call(entry, "finallyLoc"); + + if (hasCatch && hasFinally) { + if (this.prev < entry.catchLoc) { + return handle(entry.catchLoc, true); + } else if (this.prev < entry.finallyLoc) { + return handle(entry.finallyLoc); + } + + } else if (hasCatch) { + if (this.prev < entry.catchLoc) { + return handle(entry.catchLoc, true); + } + + } else if (hasFinally) { + if (this.prev < entry.finallyLoc) { + return handle(entry.finallyLoc); + } + + } else { + throw new Error("try statement without catch or finally"); + } + } + } + }, + + abrupt: function(type, arg) { + for (var i = this.tryEntries.length - 1; i >= 0; --i) { + var entry = this.tryEntries[i]; + if (entry.tryLoc <= this.prev && + hasOwn.call(entry, "finallyLoc") && + this.prev < entry.finallyLoc) { + var finallyEntry = entry; + break; + } + } + + if (finallyEntry && + (type === "break" || + type === "continue") && + finallyEntry.tryLoc <= arg && + arg <= finallyEntry.finallyLoc) { + // Ignore the finally entry if control is not jumping to a + // location outside the try/catch block. + finallyEntry = null; + } + + var record = finallyEntry ? finallyEntry.completion : {}; + record.type = type; + record.arg = arg; + + if (finallyEntry) { + this.method = "next"; + this.next = finallyEntry.finallyLoc; + return ContinueSentinel; + } + + return this.complete(record); + }, + + complete: function(record, afterLoc) { + if (record.type === "throw") { + throw record.arg; + } + + if (record.type === "break" || + record.type === "continue") { + this.next = record.arg; + } else if (record.type === "return") { + this.rval = this.arg = record.arg; + this.method = "return"; + this.next = "end"; + } else if (record.type === "normal" && afterLoc) { + this.next = afterLoc; + } + + return ContinueSentinel; + }, + + finish: function(finallyLoc) { + for (var i = this.tryEntries.length - 1; i >= 0; --i) { + var entry = this.tryEntries[i]; + if (entry.finallyLoc === finallyLoc) { + this.complete(entry.completion, entry.afterLoc); + resetTryEntry(entry); + return ContinueSentinel; + } + } + }, + + "catch": function(tryLoc) { + for (var i = this.tryEntries.length - 1; i >= 0; --i) { + var entry = this.tryEntries[i]; + if (entry.tryLoc === tryLoc) { + var record = entry.completion; + if (record.type === "throw") { + var thrown = record.arg; + resetTryEntry(entry); + } + return thrown; + } + } + + // The context.catch method must only be called with a location + // argument that corresponds to a known catch block. + throw new Error("illegal catch attempt"); + }, + + delegateYield: function(iterable, resultName, nextLoc) { + this.delegate = { + iterator: values(iterable), + resultName: resultName, + nextLoc: nextLoc + }; + + if (this.method === "next") { + // Deliberately forget the last sent value so that we don't + // accidentally pass it on to the delegate. + this.arg = undefined; + } + + return ContinueSentinel; + } + }; + + // Regardless of whether this script is executing as a CommonJS module + // or not, return the runtime object so that we can declare the variable + // regeneratorRuntime in the outer scope, which allows this module to be + // injected easily by `bin/regenerator --include-runtime script.js`. + return exports; + +}( + // If this script is executing as a CommonJS module, use module.exports + // as the regeneratorRuntime namespace. Otherwise create a new empty + // object. Either way, the resulting object will be used to initialize + // the regeneratorRuntime variable at the top of this file. + typeof module === "object" ? module.exports : {} +)); + +try { + regeneratorRuntime = runtime; +} catch (accidentalStrictMode) { + // This module should not be running in strict mode, so the above + // assignment should always work unless something is misconfigured. Just + // in case runtime.js accidentally runs in strict mode, in modern engines + // we can explicitly access globalThis. In older engines we can escape + // strict mode using a global Function call. This could conceivably fail + // if a Content Security Policy forbids using Function, but in that case + // the proper solution is to fix the accidental strict mode problem. If + // you've misconfigured your bundler to force strict mode and applied a + // CSP to forbid Function, and you're not willing to fix either of those + // problems, please detail your unique predicament in a GitHub issue. + if (typeof globalThis === "object") { + globalThis.regeneratorRuntime = runtime; + } else { + Function("r", "regeneratorRuntime = r")(runtime); + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.coveralls.yml b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.coveralls.yml new file mode 100644 index 0000000..9160059 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.coveralls.yml @@ -0,0 +1 @@ +service_name: travis-ci diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nvmrc b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nvmrc new file mode 100644 index 0000000..1e8b314 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nvmrc @@ -0,0 +1 @@ +6 diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json new file mode 100644 index 0000000..63d7513 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json @@ -0,0 +1 @@ +{"/home/davidbau/git/seedrandom/seedrandom.js":{"path":"/home/davidbau/git/seedrandom/seedrandom.js","statementMap":{"0":{"start":{"line":25,"column":0},"end":{"line":253,"column":2}},"1":{"start":{"line":30,"column":12},"end":{"line":30,"column":15}},"2":{"start":{"line":31,"column":13},"end":{"line":31,"column":14}},"3":{"start":{"line":32,"column":13},"end":{"line":32,"column":15}},"4":{"start":{"line":33,"column":14},"end":{"line":33,"column":22}},"5":{"start":{"line":34,"column":17},"end":{"line":34,"column":40}},"6":{"start":{"line":35,"column":19},"end":{"line":35,"column":38}},"7":{"start":{"line":36,"column":15},"end":{"line":36,"column":31}},"8":{"start":{"line":37,"column":11},"end":{"line":37,"column":20}},"9":{"start":{"line":45,"column":12},"end":{"line":45,"column":14}},"10":{"start":{"line":46,"column":2},"end":{"line":46,"column":68}},"11":{"start":{"line":49,"column":18},"end":{"line":51,"column":48}},"12":{"start":{"line":54,"column":13},"end":{"line":54,"column":26}},"13":{"start":{"line":58,"column":13},"end":{"line":73,"column":3}},"14":{"start":{"line":59,"column":12},"end":{"line":59,"column":26}},"15":{"start":{"line":60,"column":12},"end":{"line":60,"column":22}},"16":{"start":{"line":61,"column":12},"end":{"line":61,"column":13}},"17":{"start":{"line":62,"column":4},"end":{"line":66,"column":5}},"18":{"start":{"line":63,"column":6},"end":{"line":63,"column":26}},"19":{"start":{"line":64,"column":6},"end":{"line":64,"column":17}},"20":{"start":{"line":65,"column":6},"end":{"line":65,"column":20}},"21":{"start":{"line":67,"column":4},"end":{"line":71,"column":5}},"22":{"start":{"line":68,"column":6},"end":{"line":68,"column":13}},"23":{"start":{"line":69,"column":6},"end":{"line":69,"column":13}},"24":{"start":{"line":70,"column":6},"end":{"line":70,"column":15}},"25":{"start":{"line":72,"column":4},"end":{"line":72,"column":23}},"26":{"start":{"line":75,"column":2},"end":{"line":75,"column":51}},"27":{"start":{"line":75,"column":28},"end":{"line":75,"column":49}},"28":{"start":{"line":76,"column":2},"end":{"line":76,"column":61}},"29":{"start":{"line":76,"column":28},"end":{"line":76,"column":59}},"30":{"start":{"line":77,"column":2},"end":{"line":77,"column":21}},"31":{"start":{"line":80,"column":2},"end":{"line":80,"column":33}},"32":{"start":{"line":83,"column":2},"end":{"line":103,"column":17}},"33":{"start":{"line":85,"column":8},"end":{"line":90,"column":9}},"34":{"start":{"line":87,"column":10},"end":{"line":87,"column":45}},"35":{"start":{"line":87,"column":25},"end":{"line":87,"column":43}},"36":{"start":{"line":89,"column":10},"end":{"line":89,"column":60}},"37":{"start":{"line":89,"column":36},"end":{"line":89,"column":58}},"38":{"start":{"line":94,"column":8},"end":{"line":98,"column":25}},"39":{"start":{"line":94,"column":28},"end":{"line":94,"column":49}},"40":{"start":{"line":94,"column":50},"end":{"line":94,"column":62}},"41":{"start":{"line":98,"column":13},"end":{"line":98,"column":25}},"42":{"start":{"line":117,"column":18},"end":{"line":117,"column":28}},"43":{"start":{"line":118,"column":11},"end":{"line":118,"column":15}},"44":{"start":{"line":118,"column":21},"end":{"line":118,"column":22}},"45":{"start":{"line":118,"column":28},"end":{"line":118,"column":43}},"46":{"start":{"line":118,"column":49},"end":{"line":118,"column":58}},"47":{"start":{"line":121,"column":2},"end":{"line":121,"column":36}},"48":{"start":{"line":121,"column":17},"end":{"line":121,"column":34}},"49":{"start":{"line":124,"column":2},"end":{"line":126,"column":3}},"50":{"start":{"line":125,"column":4},"end":{"line":125,"column":15}},"51":{"start":{"line":127,"column":2},"end":{"line":130,"column":3}},"52":{"start":{"line":128,"column":4},"end":{"line":128,"column":60}},"53":{"start":{"line":129,"column":4},"end":{"line":129,"column":13}},"54":{"start":{"line":133,"column":2},"end":{"line":146,"column":12}},"55":{"start":{"line":135,"column":15},"end":{"line":135,"column":16}},"56":{"start":{"line":136,"column":12},"end":{"line":136,"column":16}},"57":{"start":{"line":136,"column":22},"end":{"line":136,"column":26}},"58":{"start":{"line":136,"column":32},"end":{"line":136,"column":36}},"59":{"start":{"line":137,"column":4},"end":{"line":140,"column":5}},"60":{"start":{"line":138,"column":6},"end":{"line":138,"column":32}},"61":{"start":{"line":139,"column":6},"end":{"line":139,"column":78}},"62":{"start":{"line":141,"column":4},"end":{"line":141,"column":13}},"63":{"start":{"line":141,"column":14},"end":{"line":141,"column":23}},"64":{"start":{"line":142,"column":4},"end":{"line":142,"column":13}},"65":{"start":{"line":154,"column":2},"end":{"line":154,"column":12}},"66":{"start":{"line":155,"column":2},"end":{"line":155,"column":12}},"67":{"start":{"line":156,"column":2},"end":{"line":156,"column":20}},"68":{"start":{"line":157,"column":2},"end":{"line":157,"column":11}},"69":{"start":{"line":165,"column":15},"end":{"line":165,"column":17}},"70":{"start":{"line":165,"column":26},"end":{"line":165,"column":36}},"71":{"start":{"line":166,"column":2},"end":{"line":170,"column":3}},"72":{"start":{"line":167,"column":4},"end":{"line":169,"column":5}},"73":{"start":{"line":168,"column":6},"end":{"line":168,"column":70}},"74":{"start":{"line":168,"column":12},"end":{"line":168,"column":55}},"75":{"start":{"line":171,"column":2},"end":{"line":171,"column":71}},"76":{"start":{"line":180,"column":19},"end":{"line":180,"column":28}},"77":{"start":{"line":180,"column":41},"end":{"line":180,"column":42}},"78":{"start":{"line":181,"column":2},"end":{"line":184,"column":3}},"79":{"start":{"line":182,"column":4},"end":{"line":183,"column":74}},"80":{"start":{"line":185,"column":2},"end":{"line":185,"column":23}},"81":{"start":{"line":194,"column":2},"end":{"line":208,"column":3}},"82":{"start":{"line":196,"column":4},"end":{"line":202,"column":5}},"83":{"start":{"line":198,"column":6},"end":{"line":198,"column":23}},"84":{"start":{"line":200,"column":6},"end":{"line":200,"column":34}},"85":{"start":{"line":201,"column":6},"end":{"line":201,"column":62}},"86":{"start":{"line":203,"column":4},"end":{"line":203,"column":25}},"87":{"start":{"line":205,"column":18},"end":{"line":205,"column":34}},"88":{"start":{"line":206,"column":18},"end":{"line":206,"column":44}},"89":{"start":{"line":207,"column":4},"end":{"line":207,"column":71}},"90":{"start":{"line":216,"column":2},"end":{"line":216,"column":41}},"91":{"start":{"line":226,"column":0},"end":{"line":226,"column":28}},"92":{"start":{"line":232,"column":0},"end":{"line":243,"column":1}},"93":{"start":{"line":233,"column":2},"end":{"line":233,"column":30}},"94":{"start":{"line":235,"column":2},"end":{"line":237,"column":17}},"95":{"start":{"line":236,"column":4},"end":{"line":236,"column":35}},"96":{"start":{"line":238,"column":7},"end":{"line":243,"column":1}},"97":{"start":{"line":239,"column":2},"end":{"line":239,"column":44}},"98":{"start":{"line":239,"column":22},"end":{"line":239,"column":40}},"99":{"start":{"line":242,"column":2},"end":{"line":242,"column":38}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":25,"column":1},"end":{"line":25,"column":2}},"loc":{"start":{"line":25,"column":31},"end":{"line":247,"column":1}},"line":25},"1":{"name":"seedrandom","decl":{"start":{"line":44,"column":9},"end":{"line":44,"column":19}},"loc":{"start":{"line":44,"column":45},"end":{"line":104,"column":1}},"line":44},"2":{"name":"(anonymous_2)","decl":{"start":{"line":58,"column":13},"end":{"line":58,"column":14}},"loc":{"start":{"line":58,"column":24},"end":{"line":73,"column":3}},"line":58},"3":{"name":"(anonymous_3)","decl":{"start":{"line":75,"column":15},"end":{"line":75,"column":16}},"loc":{"start":{"line":75,"column":26},"end":{"line":75,"column":51}},"line":75},"4":{"name":"(anonymous_4)","decl":{"start":{"line":76,"column":15},"end":{"line":76,"column":16}},"loc":{"start":{"line":76,"column":26},"end":{"line":76,"column":61}},"line":76},"5":{"name":"(anonymous_5)","decl":{"start":{"line":84,"column":6},"end":{"line":84,"column":7}},"loc":{"start":{"line":84,"column":48},"end":{"line":99,"column":7}},"line":84},"6":{"name":"(anonymous_6)","decl":{"start":{"line":89,"column":23},"end":{"line":89,"column":24}},"loc":{"start":{"line":89,"column":34},"end":{"line":89,"column":60}},"line":89},"7":{"name":"ARC4","decl":{"start":{"line":116,"column":9},"end":{"line":116,"column":13}},"loc":{"start":{"line":116,"column":19},"end":{"line":147,"column":1}},"line":116},"8":{"name":"(anonymous_8)","decl":{"start":{"line":133,"column":10},"end":{"line":133,"column":11}},"loc":{"start":{"line":133,"column":26},"end":{"line":146,"column":3}},"line":133},"9":{"name":"copy","decl":{"start":{"line":153,"column":9},"end":{"line":153,"column":13}},"loc":{"start":{"line":153,"column":20},"end":{"line":158,"column":1}},"line":153},"10":{"name":"flatten","decl":{"start":{"line":164,"column":9},"end":{"line":164,"column":16}},"loc":{"start":{"line":164,"column":29},"end":{"line":172,"column":1}},"line":164},"11":{"name":"mixkey","decl":{"start":{"line":179,"column":9},"end":{"line":179,"column":15}},"loc":{"start":{"line":179,"column":27},"end":{"line":186,"column":1}},"line":179},"12":{"name":"autoseed","decl":{"start":{"line":193,"column":9},"end":{"line":193,"column":17}},"loc":{"start":{"line":193,"column":20},"end":{"line":209,"column":1}},"line":193},"13":{"name":"tostring","decl":{"start":{"line":215,"column":9},"end":{"line":215,"column":17}},"loc":{"start":{"line":215,"column":21},"end":{"line":217,"column":1}},"line":215},"14":{"name":"(anonymous_14)","decl":{"start":{"line":239,"column":9},"end":{"line":239,"column":10}},"loc":{"start":{"line":239,"column":20},"end":{"line":239,"column":42}},"line":239}},"branchMap":{"0":{"loc":{"start":{"line":46,"column":12},"end":{"line":46,"column":67}},"type":"cond-expr","locations":[{"start":{"line":46,"column":32},"end":{"line":46,"column":49}},{"start":{"line":46,"column":53},"end":{"line":46,"column":66}}],"line":46},"1":{"loc":{"start":{"line":46,"column":53},"end":{"line":46,"column":66}},"type":"binary-expr","locations":[{"start":{"line":46,"column":53},"end":{"line":46,"column":60}},{"start":{"line":46,"column":64},"end":{"line":46,"column":66}}],"line":46},"2":{"loc":{"start":{"line":50,"column":4},"end":{"line":51,"column":38}},"type":"cond-expr","locations":[{"start":{"line":50,"column":22},"end":{"line":50,"column":44}},{"start":{"line":51,"column":4},"end":{"line":51,"column":38}}],"line":50},"3":{"loc":{"start":{"line":51,"column":4},"end":{"line":51,"column":38}},"type":"cond-expr","locations":[{"start":{"line":51,"column":21},"end":{"line":51,"column":31}},{"start":{"line":51,"column":34},"end":{"line":51,"column":38}}],"line":51},"4":{"loc":{"start":{"line":83,"column":10},"end":{"line":99,"column":7}},"type":"binary-expr","locations":[{"start":{"line":83,"column":10},"end":{"line":83,"column":22}},{"start":{"line":83,"column":26},"end":{"line":83,"column":34}},{"start":{"line":84,"column":6},"end":{"line":99,"column":7}}],"line":83},"5":{"loc":{"start":{"line":85,"column":8},"end":{"line":90,"column":9}},"type":"if","locations":[{"start":{"line":85,"column":8},"end":{"line":90,"column":9}},{"start":{"line":85,"column":8},"end":{"line":90,"column":9}}],"line":85},"6":{"loc":{"start":{"line":87,"column":10},"end":{"line":87,"column":45}},"type":"if","locations":[{"start":{"line":87,"column":10},"end":{"line":87,"column":45}},{"start":{"line":87,"column":10},"end":{"line":87,"column":45}}],"line":87},"7":{"loc":{"start":{"line":94,"column":8},"end":{"line":98,"column":25}},"type":"if","locations":[{"start":{"line":94,"column":8},"end":{"line":98,"column":25}},{"start":{"line":94,"column":8},"end":{"line":98,"column":25}}],"line":94},"8":{"loc":{"start":{"line":102,"column":2},"end":{"line":102,"column":55}},"type":"cond-expr","locations":[{"start":{"line":102,"column":24},"end":{"line":102,"column":38}},{"start":{"line":102,"column":42},"end":{"line":102,"column":54}}],"line":102},"9":{"loc":{"start":{"line":121,"column":2},"end":{"line":121,"column":36}},"type":"if","locations":[{"start":{"line":121,"column":2},"end":{"line":121,"column":36}},{"start":{"line":121,"column":2},"end":{"line":121,"column":36}}],"line":121},"10":{"loc":{"start":{"line":166,"column":2},"end":{"line":170,"column":3}},"type":"if","locations":[{"start":{"line":166,"column":2},"end":{"line":170,"column":3}},{"start":{"line":166,"column":2},"end":{"line":170,"column":3}}],"line":166},"11":{"loc":{"start":{"line":166,"column":6},"end":{"line":166,"column":30}},"type":"binary-expr","locations":[{"start":{"line":166,"column":6},"end":{"line":166,"column":11}},{"start":{"line":166,"column":15},"end":{"line":166,"column":30}}],"line":166},"12":{"loc":{"start":{"line":171,"column":10},"end":{"line":171,"column":69}},"type":"cond-expr","locations":[{"start":{"line":171,"column":26},"end":{"line":171,"column":32}},{"start":{"line":171,"column":35},"end":{"line":171,"column":69}}],"line":171},"13":{"loc":{"start":{"line":171,"column":35},"end":{"line":171,"column":69}},"type":"cond-expr","locations":[{"start":{"line":171,"column":53},"end":{"line":171,"column":56}},{"start":{"line":171,"column":59},"end":{"line":171,"column":69}}],"line":171},"14":{"loc":{"start":{"line":196,"column":4},"end":{"line":202,"column":5}},"type":"if","locations":[{"start":{"line":196,"column":4},"end":{"line":202,"column":5}},{"start":{"line":196,"column":4},"end":{"line":202,"column":5}}],"line":196},"15":{"loc":{"start":{"line":196,"column":8},"end":{"line":196,"column":52}},"type":"binary-expr","locations":[{"start":{"line":196,"column":8},"end":{"line":196,"column":18}},{"start":{"line":196,"column":23},"end":{"line":196,"column":51}}],"line":196},"16":{"loc":{"start":{"line":201,"column":7},"end":{"line":201,"column":39}},"type":"binary-expr","locations":[{"start":{"line":201,"column":7},"end":{"line":201,"column":20}},{"start":{"line":201,"column":24},"end":{"line":201,"column":39}}],"line":201},"17":{"loc":{"start":{"line":206,"column":18},"end":{"line":206,"column":44}},"type":"binary-expr","locations":[{"start":{"line":206,"column":18},"end":{"line":206,"column":25}},{"start":{"line":206,"column":29},"end":{"line":206,"column":44}}],"line":206},"18":{"loc":{"start":{"line":232,"column":0},"end":{"line":243,"column":1}},"type":"if","locations":[{"start":{"line":232,"column":0},"end":{"line":243,"column":1}},{"start":{"line":232,"column":0},"end":{"line":243,"column":1}}],"line":232},"19":{"loc":{"start":{"line":232,"column":4},"end":{"line":232,"column":49}},"type":"binary-expr","locations":[{"start":{"line":232,"column":4},"end":{"line":232,"column":31}},{"start":{"line":232,"column":35},"end":{"line":232,"column":49}}],"line":232},"20":{"loc":{"start":{"line":238,"column":7},"end":{"line":243,"column":1}},"type":"if","locations":[{"start":{"line":238,"column":7},"end":{"line":243,"column":1}},{"start":{"line":238,"column":7},"end":{"line":243,"column":1}}],"line":238},"21":{"loc":{"start":{"line":238,"column":11},"end":{"line":238,"column":54}},"type":"binary-expr","locations":[{"start":{"line":238,"column":11},"end":{"line":238,"column":40}},{"start":{"line":238,"column":44},"end":{"line":238,"column":54}}],"line":238},"22":{"loc":{"start":{"line":250,"column":2},"end":{"line":250,"column":45}},"type":"cond-expr","locations":[{"start":{"line":250,"column":34},"end":{"line":250,"column":38}},{"start":{"line":250,"column":41},"end":{"line":250,"column":45}}],"line":250}},"s":{"0":6,"1":6,"2":6,"3":6,"4":6,"5":6,"6":6,"7":6,"8":6,"9":23,"10":23,"11":23,"12":23,"13":23,"14":3694,"15":3694,"16":3694,"17":3694,"18":3917,"19":3917,"20":3917,"21":3694,"22":9249,"23":9249,"24":9249,"25":3694,"26":23,"27":1025,"28":23,"29":4100001,"30":23,"31":23,"32":23,"33":20,"34":4,"35":2,"36":4,"37":2,"38":20,"39":1,"40":1,"41":19,"42":23,"43":23,"44":23,"45":23,"46":23,"47":23,"48":1,"49":23,"50":5888,"51":23,"52":5888,"53":5888,"54":23,"55":4108660,"56":4108660,"57":4108660,"58":4108660,"59":4108660,"60":16436073,"61":16436073,"62":4108660,"63":4108660,"64":4108660,"65":4,"66":4,"67":4,"68":4,"69":32,"70":32,"71":32,"72":4,"73":9,"74":9,"75":32,"76":52,"77":52,"78":52,"79":7735,"80":52,"81":4,"82":4,"83":3,"84":1,"85":1,"86":3,"87":1,"88":1,"89":1,"90":81,"91":6,"92":6,"93":6,"94":6,"95":6,"96":0,"97":0,"98":0,"99":0},"f":{"0":6,"1":23,"2":3694,"3":1025,"4":4100001,"5":20,"6":2,"7":23,"8":4108660,"9":4,"10":32,"11":52,"12":4,"13":81,"14":0},"b":{"0":[1,22],"1":[22,11],"2":[2,21],"3":[4,17],"4":[23,21,20],"5":[4,16],"6":[2,2],"7":[1,19],"8":[4,19],"9":[1,22],"10":[4,28],"11":[32,32],"12":[3,29],"13":[23,6],"14":[3,1],"15":[4,3],"16":[1,1],"17":[1,0],"18":[6,0],"19":[6,6],"20":[0,0],"21":[0,0],"22":[0,6]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"51713684804e6a2df630b16f82a817311168866e","contentHash":"8249b27b9573baed43d58f17ab1b4f20f9b703bbe06145f517fc6c05c6b6cfa4"},"/home/davidbau/git/seedrandom/lib/xor128.js":{"path":"/home/davidbau/git/seedrandom/lib/xor128.js","statementMap":{"0":{"start":{"line":4,"column":0},"end":{"line":79,"column":2}},"1":{"start":{"line":7,"column":11},"end":{"line":7,"column":15}},"2":{"start":{"line":7,"column":27},"end":{"line":7,"column":29}},"3":{"start":{"line":9,"column":2},"end":{"line":9,"column":11}},"4":{"start":{"line":10,"column":2},"end":{"line":10,"column":11}},"5":{"start":{"line":11,"column":2},"end":{"line":11,"column":11}},"6":{"start":{"line":12,"column":2},"end":{"line":12,"column":11}},"7":{"start":{"line":15,"column":2},"end":{"line":21,"column":4}},"8":{"start":{"line":16,"column":12},"end":{"line":16,"column":31}},"9":{"start":{"line":17,"column":4},"end":{"line":17,"column":16}},"10":{"start":{"line":18,"column":4},"end":{"line":18,"column":16}},"11":{"start":{"line":19,"column":4},"end":{"line":19,"column":16}},"12":{"start":{"line":20,"column":4},"end":{"line":20,"column":49}},"13":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"14":{"start":{"line":25,"column":4},"end":{"line":25,"column":16}},"15":{"start":{"line":28,"column":4},"end":{"line":28,"column":20}},"16":{"start":{"line":32,"column":2},"end":{"line":35,"column":3}},"17":{"start":{"line":32,"column":15},"end":{"line":32,"column":16}},"18":{"start":{"line":33,"column":4},"end":{"line":33,"column":38}},"19":{"start":{"line":34,"column":4},"end":{"line":34,"column":14}},"20":{"start":{"line":39,"column":2},"end":{"line":39,"column":12}},"21":{"start":{"line":40,"column":2},"end":{"line":40,"column":12}},"22":{"start":{"line":41,"column":2},"end":{"line":41,"column":12}},"23":{"start":{"line":42,"column":2},"end":{"line":42,"column":12}},"24":{"start":{"line":43,"column":2},"end":{"line":43,"column":11}},"25":{"start":{"line":47,"column":11},"end":{"line":47,"column":27}},"26":{"start":{"line":48,"column":14},"end":{"line":48,"column":32}},"27":{"start":{"line":49,"column":13},"end":{"line":49,"column":67}},"28":{"start":{"line":49,"column":26},"end":{"line":49,"column":65}},"29":{"start":{"line":50,"column":2},"end":{"line":57,"column":4}},"30":{"start":{"line":51,"column":4},"end":{"line":55,"column":27}},"31":{"start":{"line":52,"column":16},"end":{"line":52,"column":32}},"32":{"start":{"line":53,"column":16},"end":{"line":53,"column":47}},"33":{"start":{"line":54,"column":19},"end":{"line":54,"column":42}},"34":{"start":{"line":56,"column":4},"end":{"line":56,"column":18}},"35":{"start":{"line":58,"column":2},"end":{"line":58,"column":23}},"36":{"start":{"line":59,"column":2},"end":{"line":59,"column":20}},"37":{"start":{"line":60,"column":2},"end":{"line":63,"column":3}},"38":{"start":{"line":61,"column":4},"end":{"line":61,"column":51}},"39":{"start":{"line":61,"column":35},"end":{"line":61,"column":51}},"40":{"start":{"line":62,"column":4},"end":{"line":62,"column":52}},"41":{"start":{"line":62,"column":30},"end":{"line":62,"column":50}},"42":{"start":{"line":64,"column":2},"end":{"line":64,"column":14}},"43":{"start":{"line":67,"column":0},"end":{"line":73,"column":1}},"44":{"start":{"line":68,"column":2},"end":{"line":68,"column":24}},"45":{"start":{"line":69,"column":7},"end":{"line":73,"column":1}},"46":{"start":{"line":70,"column":2},"end":{"line":70,"column":38}},"47":{"start":{"line":70,"column":22},"end":{"line":70,"column":34}},"48":{"start":{"line":72,"column":2},"end":{"line":72,"column":21}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":4,"column":1},"end":{"line":4,"column":2}},"loc":{"start":{"line":4,"column":34},"end":{"line":75,"column":1}},"line":4},"1":{"name":"XorGen","decl":{"start":{"line":6,"column":9},"end":{"line":6,"column":15}},"loc":{"start":{"line":6,"column":22},"end":{"line":36,"column":1}},"line":6},"2":{"name":"(anonymous_2)","decl":{"start":{"line":15,"column":12},"end":{"line":15,"column":13}},"loc":{"start":{"line":15,"column":23},"end":{"line":21,"column":3}},"line":15},"3":{"name":"copy","decl":{"start":{"line":38,"column":9},"end":{"line":38,"column":13}},"loc":{"start":{"line":38,"column":20},"end":{"line":44,"column":1}},"line":38},"4":{"name":"impl","decl":{"start":{"line":46,"column":9},"end":{"line":46,"column":13}},"loc":{"start":{"line":46,"column":26},"end":{"line":65,"column":1}},"line":46},"5":{"name":"(anonymous_5)","decl":{"start":{"line":49,"column":13},"end":{"line":49,"column":14}},"loc":{"start":{"line":49,"column":24},"end":{"line":49,"column":67}},"line":49},"6":{"name":"(anonymous_6)","decl":{"start":{"line":50,"column":16},"end":{"line":50,"column":17}},"loc":{"start":{"line":50,"column":27},"end":{"line":57,"column":3}},"line":50},"7":{"name":"(anonymous_7)","decl":{"start":{"line":62,"column":17},"end":{"line":62,"column":18}},"loc":{"start":{"line":62,"column":28},"end":{"line":62,"column":52}},"line":62},"8":{"name":"(anonymous_8)","decl":{"start":{"line":70,"column":9},"end":{"line":70,"column":10}},"loc":{"start":{"line":70,"column":20},"end":{"line":70,"column":36}},"line":70}},"branchMap":{"0":{"loc":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"type":"if","locations":[{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},{"start":{"line":23,"column":2},"end":{"line":29,"column":3}}],"line":23},"1":{"loc":{"start":{"line":48,"column":14},"end":{"line":48,"column":32}},"type":"binary-expr","locations":[{"start":{"line":48,"column":14},"end":{"line":48,"column":18}},{"start":{"line":48,"column":22},"end":{"line":48,"column":32}}],"line":48},"2":{"loc":{"start":{"line":60,"column":2},"end":{"line":63,"column":3}},"type":"if","locations":[{"start":{"line":60,"column":2},"end":{"line":63,"column":3}},{"start":{"line":60,"column":2},"end":{"line":63,"column":3}}],"line":60},"3":{"loc":{"start":{"line":61,"column":4},"end":{"line":61,"column":51}},"type":"if","locations":[{"start":{"line":61,"column":4},"end":{"line":61,"column":51}},{"start":{"line":61,"column":4},"end":{"line":61,"column":51}}],"line":61},"4":{"loc":{"start":{"line":67,"column":0},"end":{"line":73,"column":1}},"type":"if","locations":[{"start":{"line":67,"column":0},"end":{"line":73,"column":1}},{"start":{"line":67,"column":0},"end":{"line":73,"column":1}}],"line":67},"5":{"loc":{"start":{"line":67,"column":4},"end":{"line":67,"column":28}},"type":"binary-expr","locations":[{"start":{"line":67,"column":4},"end":{"line":67,"column":10}},{"start":{"line":67,"column":14},"end":{"line":67,"column":28}}],"line":67},"6":{"loc":{"start":{"line":69,"column":7},"end":{"line":73,"column":1}},"type":"if","locations":[{"start":{"line":69,"column":7},"end":{"line":73,"column":1}},{"start":{"line":69,"column":7},"end":{"line":73,"column":1}}],"line":69},"7":{"loc":{"start":{"line":69,"column":11},"end":{"line":69,"column":31}},"type":"binary-expr","locations":[{"start":{"line":69,"column":11},"end":{"line":69,"column":17}},{"start":{"line":69,"column":21},"end":{"line":69,"column":31}}],"line":69},"8":{"loc":{"start":{"line":77,"column":2},"end":{"line":77,"column":39}},"type":"binary-expr","locations":[{"start":{"line":77,"column":2},"end":{"line":77,"column":29}},{"start":{"line":77,"column":33},"end":{"line":77,"column":39}}],"line":77},"9":{"loc":{"start":{"line":78,"column":2},"end":{"line":78,"column":41}},"type":"binary-expr","locations":[{"start":{"line":78,"column":2},"end":{"line":78,"column":31}},{"start":{"line":78,"column":35},"end":{"line":78,"column":41}}],"line":78}},"s":{"0":1,"1":3,"2":3,"3":3,"4":3,"5":3,"6":3,"7":3,"8":4105327,"9":4105327,"10":4105327,"11":4105327,"12":4105327,"13":3,"14":2,"15":1,"16":3,"17":3,"18":198,"19":198,"20":2,"21":2,"22":2,"23":2,"24":2,"25":3,"26":3,"27":3,"28":4102054,"29":3,"30":1025,"31":1025,"32":1025,"33":1025,"34":1025,"35":3,"36":3,"37":3,"38":2,"39":1,"40":2,"41":1,"42":3,"43":1,"44":1,"45":0,"46":0,"47":0,"48":0},"f":{"0":1,"1":3,"2":4105327,"3":2,"4":3,"5":4102054,"6":1025,"7":1,"8":0},"b":{"0":[2,1],"1":[3,2],"2":[2,1],"3":[1,1],"4":[1,0],"5":[1,1],"6":[0,0],"7":[0,0],"8":[1,1],"9":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"42c805c53b8a22e4d141f90ddecc8031ba21211b","contentHash":"2bd5b1ea82454991d6453cdd05e909475478ffed8cf6dd0ce02556ae981256d8"},"/home/davidbau/git/seedrandom/lib/xorwow.js":{"path":"/home/davidbau/git/seedrandom/lib/xorwow.js","statementMap":{"0":{"start":{"line":4,"column":0},"end":{"line":84,"column":2}},"1":{"start":{"line":7,"column":11},"end":{"line":7,"column":15}},"2":{"start":{"line":7,"column":27},"end":{"line":7,"column":29}},"3":{"start":{"line":10,"column":2},"end":{"line":15,"column":4}},"4":{"start":{"line":11,"column":13},"end":{"line":11,"column":32}},"5":{"start":{"line":12,"column":4},"end":{"line":12,"column":16}},"6":{"start":{"line":12,"column":17},"end":{"line":12,"column":29}},"7":{"start":{"line":12,"column":30},"end":{"line":12,"column":42}},"8":{"start":{"line":12,"column":43},"end":{"line":12,"column":55}},"9":{"start":{"line":13,"column":4},"end":{"line":14,"column":58}},"10":{"start":{"line":17,"column":2},"end":{"line":17,"column":11}},"11":{"start":{"line":18,"column":2},"end":{"line":18,"column":11}},"12":{"start":{"line":19,"column":2},"end":{"line":19,"column":11}},"13":{"start":{"line":20,"column":2},"end":{"line":20,"column":11}},"14":{"start":{"line":21,"column":2},"end":{"line":21,"column":11}},"15":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"16":{"start":{"line":25,"column":4},"end":{"line":25,"column":16}},"17":{"start":{"line":28,"column":4},"end":{"line":28,"column":20}},"18":{"start":{"line":32,"column":2},"end":{"line":38,"column":3}},"19":{"start":{"line":32,"column":15},"end":{"line":32,"column":16}},"20":{"start":{"line":33,"column":4},"end":{"line":33,"column":38}},"21":{"start":{"line":34,"column":4},"end":{"line":36,"column":5}},"22":{"start":{"line":35,"column":6},"end":{"line":35,"column":37}},"23":{"start":{"line":37,"column":4},"end":{"line":37,"column":14}},"24":{"start":{"line":42,"column":2},"end":{"line":42,"column":12}},"25":{"start":{"line":43,"column":2},"end":{"line":43,"column":12}},"26":{"start":{"line":44,"column":2},"end":{"line":44,"column":12}},"27":{"start":{"line":45,"column":2},"end":{"line":45,"column":12}},"28":{"start":{"line":46,"column":2},"end":{"line":46,"column":12}},"29":{"start":{"line":47,"column":2},"end":{"line":47,"column":12}},"30":{"start":{"line":48,"column":2},"end":{"line":48,"column":11}},"31":{"start":{"line":52,"column":11},"end":{"line":52,"column":27}},"32":{"start":{"line":53,"column":14},"end":{"line":53,"column":32}},"33":{"start":{"line":54,"column":13},"end":{"line":54,"column":67}},"34":{"start":{"line":54,"column":26},"end":{"line":54,"column":65}},"35":{"start":{"line":55,"column":2},"end":{"line":62,"column":4}},"36":{"start":{"line":56,"column":4},"end":{"line":60,"column":27}},"37":{"start":{"line":57,"column":16},"end":{"line":57,"column":32}},"38":{"start":{"line":58,"column":16},"end":{"line":58,"column":47}},"39":{"start":{"line":59,"column":19},"end":{"line":59,"column":42}},"40":{"start":{"line":61,"column":4},"end":{"line":61,"column":18}},"41":{"start":{"line":63,"column":2},"end":{"line":63,"column":23}},"42":{"start":{"line":64,"column":2},"end":{"line":64,"column":20}},"43":{"start":{"line":65,"column":2},"end":{"line":68,"column":3}},"44":{"start":{"line":66,"column":4},"end":{"line":66,"column":51}},"45":{"start":{"line":66,"column":35},"end":{"line":66,"column":51}},"46":{"start":{"line":67,"column":4},"end":{"line":67,"column":52}},"47":{"start":{"line":67,"column":30},"end":{"line":67,"column":50}},"48":{"start":{"line":69,"column":2},"end":{"line":69,"column":14}},"49":{"start":{"line":72,"column":0},"end":{"line":78,"column":1}},"50":{"start":{"line":73,"column":2},"end":{"line":73,"column":24}},"51":{"start":{"line":74,"column":7},"end":{"line":78,"column":1}},"52":{"start":{"line":75,"column":2},"end":{"line":75,"column":38}},"53":{"start":{"line":75,"column":22},"end":{"line":75,"column":34}},"54":{"start":{"line":77,"column":2},"end":{"line":77,"column":21}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":4,"column":1},"end":{"line":4,"column":2}},"loc":{"start":{"line":4,"column":34},"end":{"line":80,"column":1}},"line":4},"1":{"name":"XorGen","decl":{"start":{"line":6,"column":9},"end":{"line":6,"column":15}},"loc":{"start":{"line":6,"column":22},"end":{"line":39,"column":1}},"line":6},"2":{"name":"(anonymous_2)","decl":{"start":{"line":10,"column":12},"end":{"line":10,"column":13}},"loc":{"start":{"line":10,"column":23},"end":{"line":15,"column":3}},"line":10},"3":{"name":"copy","decl":{"start":{"line":41,"column":9},"end":{"line":41,"column":13}},"loc":{"start":{"line":41,"column":20},"end":{"line":49,"column":1}},"line":41},"4":{"name":"impl","decl":{"start":{"line":51,"column":9},"end":{"line":51,"column":13}},"loc":{"start":{"line":51,"column":26},"end":{"line":70,"column":1}},"line":51},"5":{"name":"(anonymous_5)","decl":{"start":{"line":54,"column":13},"end":{"line":54,"column":14}},"loc":{"start":{"line":54,"column":24},"end":{"line":54,"column":67}},"line":54},"6":{"name":"(anonymous_6)","decl":{"start":{"line":55,"column":16},"end":{"line":55,"column":17}},"loc":{"start":{"line":55,"column":27},"end":{"line":62,"column":3}},"line":55},"7":{"name":"(anonymous_7)","decl":{"start":{"line":67,"column":17},"end":{"line":67,"column":18}},"loc":{"start":{"line":67,"column":28},"end":{"line":67,"column":52}},"line":67},"8":{"name":"(anonymous_8)","decl":{"start":{"line":75,"column":9},"end":{"line":75,"column":10}},"loc":{"start":{"line":75,"column":20},"end":{"line":75,"column":36}},"line":75}},"branchMap":{"0":{"loc":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"type":"if","locations":[{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},{"start":{"line":23,"column":2},"end":{"line":29,"column":3}}],"line":23},"1":{"loc":{"start":{"line":34,"column":4},"end":{"line":36,"column":5}},"type":"if","locations":[{"start":{"line":34,"column":4},"end":{"line":36,"column":5}},{"start":{"line":34,"column":4},"end":{"line":36,"column":5}}],"line":34},"2":{"loc":{"start":{"line":53,"column":14},"end":{"line":53,"column":32}},"type":"binary-expr","locations":[{"start":{"line":53,"column":14},"end":{"line":53,"column":18}},{"start":{"line":53,"column":22},"end":{"line":53,"column":32}}],"line":53},"3":{"loc":{"start":{"line":65,"column":2},"end":{"line":68,"column":3}},"type":"if","locations":[{"start":{"line":65,"column":2},"end":{"line":68,"column":3}},{"start":{"line":65,"column":2},"end":{"line":68,"column":3}}],"line":65},"4":{"loc":{"start":{"line":66,"column":4},"end":{"line":66,"column":51}},"type":"if","locations":[{"start":{"line":66,"column":4},"end":{"line":66,"column":51}},{"start":{"line":66,"column":4},"end":{"line":66,"column":51}}],"line":66},"5":{"loc":{"start":{"line":72,"column":0},"end":{"line":78,"column":1}},"type":"if","locations":[{"start":{"line":72,"column":0},"end":{"line":78,"column":1}},{"start":{"line":72,"column":0},"end":{"line":78,"column":1}}],"line":72},"6":{"loc":{"start":{"line":72,"column":4},"end":{"line":72,"column":28}},"type":"binary-expr","locations":[{"start":{"line":72,"column":4},"end":{"line":72,"column":10}},{"start":{"line":72,"column":14},"end":{"line":72,"column":28}}],"line":72},"7":{"loc":{"start":{"line":74,"column":7},"end":{"line":78,"column":1}},"type":"if","locations":[{"start":{"line":74,"column":7},"end":{"line":78,"column":1}},{"start":{"line":74,"column":7},"end":{"line":78,"column":1}}],"line":74},"8":{"loc":{"start":{"line":74,"column":11},"end":{"line":74,"column":31}},"type":"binary-expr","locations":[{"start":{"line":74,"column":11},"end":{"line":74,"column":17}},{"start":{"line":74,"column":21},"end":{"line":74,"column":31}}],"line":74},"9":{"loc":{"start":{"line":82,"column":2},"end":{"line":82,"column":39}},"type":"binary-expr","locations":[{"start":{"line":82,"column":2},"end":{"line":82,"column":29}},{"start":{"line":82,"column":33},"end":{"line":82,"column":39}}],"line":82},"10":{"loc":{"start":{"line":83,"column":2},"end":{"line":83,"column":41}},"type":"binary-expr","locations":[{"start":{"line":83,"column":2},"end":{"line":83,"column":31}},{"start":{"line":83,"column":35},"end":{"line":83,"column":41}}],"line":83}},"s":{"0":1,"1":3,"2":3,"3":3,"4":4105327,"5":4105327,"6":4105327,"7":4105327,"8":4105327,"9":4105327,"10":3,"11":3,"12":3,"13":3,"14":3,"15":3,"16":2,"17":1,"18":3,"19":3,"20":198,"21":198,"22":3,"23":198,"24":2,"25":2,"26":2,"27":2,"28":2,"29":2,"30":2,"31":3,"32":3,"33":3,"34":4102054,"35":3,"36":1025,"37":1025,"38":1025,"39":1025,"40":1025,"41":3,"42":3,"43":3,"44":2,"45":1,"46":2,"47":1,"48":3,"49":1,"50":1,"51":0,"52":0,"53":0,"54":0},"f":{"0":1,"1":3,"2":4105327,"3":2,"4":3,"5":4102054,"6":1025,"7":1,"8":0},"b":{"0":[2,1],"1":[3,195],"2":[3,2],"3":[2,1],"4":[1,1],"5":[1,0],"6":[1,1],"7":[0,0],"8":[0,0],"9":[1,1],"10":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"279728a54e5ce9face1abbf1b1093f69bd5e2cef","contentHash":"870bba719eee59f28e0160645190fa7eda491db1be3c64600c523d0b510d2000"},"/home/davidbau/git/seedrandom/lib/xorshift7.js":{"path":"/home/davidbau/git/seedrandom/lib/xorshift7.js","statementMap":{"0":{"start":{"line":6,"column":0},"end":{"line":96,"column":2}},"1":{"start":{"line":9,"column":11},"end":{"line":9,"column":15}},"2":{"start":{"line":12,"column":2},"end":{"line":23,"column":4}},"3":{"start":{"line":14,"column":12},"end":{"line":14,"column":16}},"4":{"start":{"line":14,"column":22},"end":{"line":14,"column":26}},"5":{"start":{"line":15,"column":4},"end":{"line":15,"column":13}},"6":{"start":{"line":15,"column":14},"end":{"line":15,"column":29}},"7":{"start":{"line":15,"column":30},"end":{"line":15,"column":48}},"8":{"start":{"line":16,"column":4},"end":{"line":16,"column":23}},"9":{"start":{"line":16,"column":24},"end":{"line":16,"column":44}},"10":{"start":{"line":17,"column":4},"end":{"line":17,"column":23}},"11":{"start":{"line":17,"column":24},"end":{"line":17,"column":43}},"12":{"start":{"line":18,"column":4},"end":{"line":18,"column":23}},"13":{"start":{"line":18,"column":24},"end":{"line":18,"column":42}},"14":{"start":{"line":19,"column":4},"end":{"line":19,"column":23}},"15":{"start":{"line":19,"column":24},"end":{"line":19,"column":42}},"16":{"start":{"line":19,"column":43},"end":{"line":19,"column":61}},"17":{"start":{"line":20,"column":4},"end":{"line":20,"column":13}},"18":{"start":{"line":21,"column":4},"end":{"line":21,"column":23}},"19":{"start":{"line":22,"column":4},"end":{"line":22,"column":13}},"20":{"start":{"line":26,"column":18},"end":{"line":26,"column":20}},"21":{"start":{"line":28,"column":4},"end":{"line":38,"column":5}},"22":{"start":{"line":30,"column":6},"end":{"line":30,"column":22}},"23":{"start":{"line":33,"column":6},"end":{"line":33,"column":23}},"24":{"start":{"line":34,"column":6},"end":{"line":37,"column":7}},"25":{"start":{"line":35,"column":8},"end":{"line":36,"column":56}},"26":{"start":{"line":40,"column":4},"end":{"line":40,"column":35}},"27":{"start":{"line":40,"column":25},"end":{"line":40,"column":35}},"28":{"start":{"line":41,"column":4},"end":{"line":41,"column":42}},"29":{"start":{"line":42,"column":4},"end":{"line":42,"column":45}},"30":{"start":{"line":42,"column":16},"end":{"line":42,"column":30}},"31":{"start":{"line":42,"column":36},"end":{"line":42,"column":45}},"32":{"start":{"line":44,"column":4},"end":{"line":44,"column":13}},"33":{"start":{"line":45,"column":4},"end":{"line":45,"column":13}},"34":{"start":{"line":48,"column":4},"end":{"line":50,"column":5}},"35":{"start":{"line":49,"column":6},"end":{"line":49,"column":16}},"36":{"start":{"line":53,"column":2},"end":{"line":53,"column":17}},"37":{"start":{"line":57,"column":2},"end":{"line":57,"column":20}},"38":{"start":{"line":58,"column":2},"end":{"line":58,"column":12}},"39":{"start":{"line":59,"column":2},"end":{"line":59,"column":11}},"40":{"start":{"line":63,"column":2},"end":{"line":63,"column":39}},"41":{"start":{"line":63,"column":20},"end":{"line":63,"column":39}},"42":{"start":{"line":64,"column":11},"end":{"line":64,"column":27}},"43":{"start":{"line":65,"column":14},"end":{"line":65,"column":32}},"44":{"start":{"line":66,"column":13},"end":{"line":66,"column":67}},"45":{"start":{"line":66,"column":26},"end":{"line":66,"column":65}},"46":{"start":{"line":67,"column":2},"end":{"line":74,"column":4}},"47":{"start":{"line":68,"column":4},"end":{"line":72,"column":27}},"48":{"start":{"line":69,"column":16},"end":{"line":69,"column":32}},"49":{"start":{"line":70,"column":16},"end":{"line":70,"column":47}},"50":{"start":{"line":71,"column":19},"end":{"line":71,"column":42}},"51":{"start":{"line":73,"column":4},"end":{"line":73,"column":18}},"52":{"start":{"line":75,"column":2},"end":{"line":75,"column":23}},"53":{"start":{"line":76,"column":2},"end":{"line":76,"column":20}},"54":{"start":{"line":77,"column":2},"end":{"line":80,"column":3}},"55":{"start":{"line":78,"column":4},"end":{"line":78,"column":33}},"56":{"start":{"line":78,"column":17},"end":{"line":78,"column":33}},"57":{"start":{"line":79,"column":4},"end":{"line":79,"column":52}},"58":{"start":{"line":79,"column":30},"end":{"line":79,"column":50}},"59":{"start":{"line":81,"column":2},"end":{"line":81,"column":14}},"60":{"start":{"line":84,"column":0},"end":{"line":90,"column":1}},"61":{"start":{"line":85,"column":2},"end":{"line":85,"column":24}},"62":{"start":{"line":86,"column":7},"end":{"line":90,"column":1}},"63":{"start":{"line":87,"column":2},"end":{"line":87,"column":38}},"64":{"start":{"line":87,"column":22},"end":{"line":87,"column":34}},"65":{"start":{"line":89,"column":2},"end":{"line":89,"column":24}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":6,"column":1},"end":{"line":6,"column":2}},"loc":{"start":{"line":6,"column":34},"end":{"line":92,"column":1}},"line":6},"1":{"name":"XorGen","decl":{"start":{"line":8,"column":9},"end":{"line":8,"column":15}},"loc":{"start":{"line":8,"column":22},"end":{"line":54,"column":1}},"line":8},"2":{"name":"(anonymous_2)","decl":{"start":{"line":12,"column":12},"end":{"line":12,"column":13}},"loc":{"start":{"line":12,"column":23},"end":{"line":23,"column":3}},"line":12},"3":{"name":"init","decl":{"start":{"line":25,"column":11},"end":{"line":25,"column":15}},"loc":{"start":{"line":25,"column":26},"end":{"line":51,"column":3}},"line":25},"4":{"name":"copy","decl":{"start":{"line":56,"column":9},"end":{"line":56,"column":13}},"loc":{"start":{"line":56,"column":20},"end":{"line":60,"column":1}},"line":56},"5":{"name":"impl","decl":{"start":{"line":62,"column":9},"end":{"line":62,"column":13}},"loc":{"start":{"line":62,"column":26},"end":{"line":82,"column":1}},"line":62},"6":{"name":"(anonymous_6)","decl":{"start":{"line":66,"column":13},"end":{"line":66,"column":14}},"loc":{"start":{"line":66,"column":24},"end":{"line":66,"column":67}},"line":66},"7":{"name":"(anonymous_7)","decl":{"start":{"line":67,"column":16},"end":{"line":67,"column":17}},"loc":{"start":{"line":67,"column":27},"end":{"line":74,"column":3}},"line":67},"8":{"name":"(anonymous_8)","decl":{"start":{"line":79,"column":17},"end":{"line":79,"column":18}},"loc":{"start":{"line":79,"column":28},"end":{"line":79,"column":52}},"line":79},"9":{"name":"(anonymous_9)","decl":{"start":{"line":87,"column":9},"end":{"line":87,"column":10}},"loc":{"start":{"line":87,"column":20},"end":{"line":87,"column":36}},"line":87}},"branchMap":{"0":{"loc":{"start":{"line":28,"column":4},"end":{"line":38,"column":5}},"type":"if","locations":[{"start":{"line":28,"column":4},"end":{"line":38,"column":5}},{"start":{"line":28,"column":4},"end":{"line":38,"column":5}}],"line":28},"1":{"loc":{"start":{"line":41,"column":16},"end":{"line":41,"column":35}},"type":"binary-expr","locations":[{"start":{"line":41,"column":16},"end":{"line":41,"column":21}},{"start":{"line":41,"column":25},"end":{"line":41,"column":35}}],"line":41},"2":{"loc":{"start":{"line":42,"column":4},"end":{"line":42,"column":45}},"type":"if","locations":[{"start":{"line":42,"column":4},"end":{"line":42,"column":45}},{"start":{"line":42,"column":4},"end":{"line":42,"column":45}}],"line":42},"3":{"loc":{"start":{"line":63,"column":2},"end":{"line":63,"column":39}},"type":"if","locations":[{"start":{"line":63,"column":2},"end":{"line":63,"column":39}},{"start":{"line":63,"column":2},"end":{"line":63,"column":39}}],"line":63},"4":{"loc":{"start":{"line":65,"column":14},"end":{"line":65,"column":32}},"type":"binary-expr","locations":[{"start":{"line":65,"column":14},"end":{"line":65,"column":18}},{"start":{"line":65,"column":22},"end":{"line":65,"column":32}}],"line":65},"5":{"loc":{"start":{"line":77,"column":2},"end":{"line":80,"column":3}},"type":"if","locations":[{"start":{"line":77,"column":2},"end":{"line":80,"column":3}},{"start":{"line":77,"column":2},"end":{"line":80,"column":3}}],"line":77},"6":{"loc":{"start":{"line":78,"column":4},"end":{"line":78,"column":33}},"type":"if","locations":[{"start":{"line":78,"column":4},"end":{"line":78,"column":33}},{"start":{"line":78,"column":4},"end":{"line":78,"column":33}}],"line":78},"7":{"loc":{"start":{"line":84,"column":0},"end":{"line":90,"column":1}},"type":"if","locations":[{"start":{"line":84,"column":0},"end":{"line":90,"column":1}},{"start":{"line":84,"column":0},"end":{"line":90,"column":1}}],"line":84},"8":{"loc":{"start":{"line":84,"column":4},"end":{"line":84,"column":28}},"type":"binary-expr","locations":[{"start":{"line":84,"column":4},"end":{"line":84,"column":10}},{"start":{"line":84,"column":14},"end":{"line":84,"column":28}}],"line":84},"9":{"loc":{"start":{"line":86,"column":7},"end":{"line":90,"column":1}},"type":"if","locations":[{"start":{"line":86,"column":7},"end":{"line":90,"column":1}},{"start":{"line":86,"column":7},"end":{"line":90,"column":1}}],"line":86},"10":{"loc":{"start":{"line":86,"column":11},"end":{"line":86,"column":31}},"type":"binary-expr","locations":[{"start":{"line":86,"column":11},"end":{"line":86,"column":17}},{"start":{"line":86,"column":21},"end":{"line":86,"column":31}}],"line":86},"11":{"loc":{"start":{"line":94,"column":2},"end":{"line":94,"column":39}},"type":"binary-expr","locations":[{"start":{"line":94,"column":2},"end":{"line":94,"column":29}},{"start":{"line":94,"column":33},"end":{"line":94,"column":39}}],"line":94},"12":{"loc":{"start":{"line":95,"column":2},"end":{"line":95,"column":41}},"type":"binary-expr","locations":[{"start":{"line":95,"column":2},"end":{"line":95,"column":31}},{"start":{"line":95,"column":35},"end":{"line":95,"column":41}}],"line":95}},"s":{"0":1,"1":3,"2":3,"3":4105897,"4":4105897,"5":4105897,"6":4105897,"7":4105897,"8":4105897,"9":4105897,"10":4105897,"11":4105897,"12":4105897,"13":4105897,"14":4105897,"15":4105897,"16":4105897,"17":4105897,"18":4105897,"19":4105897,"20":3,"21":3,"22":2,"23":1,"24":1,"25":6,"26":3,"27":16,"28":3,"29":3,"30":2,"31":1,"32":3,"33":3,"34":3,"35":768,"36":3,"37":2,"38":2,"39":2,"40":3,"41":0,"42":3,"43":3,"44":3,"45":4102054,"46":3,"47":1025,"48":1025,"49":1025,"50":1025,"51":1025,"52":3,"53":3,"54":3,"55":2,"56":1,"57":2,"58":1,"59":3,"60":1,"61":1,"62":0,"63":0,"64":0,"65":0},"f":{"0":1,"1":3,"2":4105897,"3":3,"4":2,"5":3,"6":4102054,"7":1025,"8":1,"9":0},"b":{"0":[2,1],"1":[19,17],"2":[2,1],"3":[0,3],"4":[3,2],"5":[2,1],"6":[1,1],"7":[1,0],"8":[1,1],"9":[0,0],"10":[0,0],"11":[1,1],"12":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"131ac72069e0ca2a2df6aae06f4b2d31b91187b5","contentHash":"4aba94be2ce998b353804abdbf2962ed421abbc77501066348025b6fa45b856d"},"/home/davidbau/git/seedrandom/lib/xor4096.js":{"path":"/home/davidbau/git/seedrandom/lib/xor4096.js","statementMap":{"0":{"start":{"line":26,"column":0},"end":{"line":146,"column":2}},"1":{"start":{"line":29,"column":11},"end":{"line":29,"column":15}},"2":{"start":{"line":32,"column":2},"end":{"line":49,"column":4}},"3":{"start":{"line":33,"column":12},"end":{"line":33,"column":16}},"4":{"start":{"line":34,"column":12},"end":{"line":34,"column":16}},"5":{"start":{"line":34,"column":22},"end":{"line":34,"column":26}},"6":{"start":{"line":36,"column":4},"end":{"line":36,"column":36}},"7":{"start":{"line":38,"column":4},"end":{"line":38,"column":26}},"8":{"start":{"line":39,"column":4},"end":{"line":39,"column":31}},"9":{"start":{"line":40,"column":4},"end":{"line":40,"column":17}},"10":{"start":{"line":41,"column":4},"end":{"line":41,"column":17}},"11":{"start":{"line":42,"column":4},"end":{"line":42,"column":18}},"12":{"start":{"line":43,"column":4},"end":{"line":43,"column":18}},"13":{"start":{"line":45,"column":4},"end":{"line":45,"column":21}},"14":{"start":{"line":46,"column":4},"end":{"line":46,"column":13}},"15":{"start":{"line":48,"column":4},"end":{"line":48,"column":38}},"16":{"start":{"line":52,"column":27},"end":{"line":52,"column":29}},"17":{"start":{"line":52,"column":39},"end":{"line":52,"column":42}},"18":{"start":{"line":53,"column":4},"end":{"line":62,"column":5}},"19":{"start":{"line":55,"column":6},"end":{"line":55,"column":15}},"20":{"start":{"line":56,"column":6},"end":{"line":56,"column":18}},"21":{"start":{"line":59,"column":6},"end":{"line":59,"column":25}},"22":{"start":{"line":60,"column":6},"end":{"line":60,"column":12}},"23":{"start":{"line":61,"column":6},"end":{"line":61,"column":43}},"24":{"start":{"line":64,"column":4},"end":{"line":78,"column":5}},"25":{"start":{"line":66,"column":6},"end":{"line":66,"column":61}},"26":{"start":{"line":66,"column":16},"end":{"line":66,"column":61}},"27":{"start":{"line":68,"column":6},"end":{"line":68,"column":25}},"28":{"start":{"line":68,"column":19},"end":{"line":68,"column":25}},"29":{"start":{"line":69,"column":6},"end":{"line":69,"column":19}},"30":{"start":{"line":70,"column":6},"end":{"line":70,"column":20}},"31":{"start":{"line":71,"column":6},"end":{"line":71,"column":18}},"32":{"start":{"line":72,"column":6},"end":{"line":72,"column":20}},"33":{"start":{"line":73,"column":6},"end":{"line":77,"column":7}},"34":{"start":{"line":74,"column":8},"end":{"line":74,"column":33}},"35":{"start":{"line":75,"column":8},"end":{"line":75,"column":36}},"36":{"start":{"line":76,"column":8},"end":{"line":76,"column":33}},"37":{"start":{"line":80,"column":4},"end":{"line":82,"column":5}},"38":{"start":{"line":81,"column":6},"end":{"line":81,"column":47}},"39":{"start":{"line":86,"column":4},"end":{"line":86,"column":12}},"40":{"start":{"line":87,"column":4},"end":{"line":95,"column":5}},"41":{"start":{"line":88,"column":6},"end":{"line":88,"column":28}},"42":{"start":{"line":89,"column":6},"end":{"line":89,"column":33}},"43":{"start":{"line":90,"column":6},"end":{"line":90,"column":19}},"44":{"start":{"line":91,"column":6},"end":{"line":91,"column":19}},"45":{"start":{"line":92,"column":6},"end":{"line":92,"column":20}},"46":{"start":{"line":93,"column":6},"end":{"line":93,"column":20}},"47":{"start":{"line":94,"column":6},"end":{"line":94,"column":19}},"48":{"start":{"line":97,"column":4},"end":{"line":97,"column":13}},"49":{"start":{"line":98,"column":4},"end":{"line":98,"column":13}},"50":{"start":{"line":99,"column":4},"end":{"line":99,"column":13}},"51":{"start":{"line":102,"column":2},"end":{"line":102,"column":17}},"52":{"start":{"line":106,"column":2},"end":{"line":106,"column":12}},"53":{"start":{"line":107,"column":2},"end":{"line":107,"column":12}},"54":{"start":{"line":108,"column":2},"end":{"line":108,"column":20}},"55":{"start":{"line":109,"column":2},"end":{"line":109,"column":11}},"56":{"start":{"line":113,"column":2},"end":{"line":113,"column":39}},"57":{"start":{"line":113,"column":20},"end":{"line":113,"column":39}},"58":{"start":{"line":114,"column":11},"end":{"line":114,"column":27}},"59":{"start":{"line":115,"column":14},"end":{"line":115,"column":32}},"60":{"start":{"line":116,"column":13},"end":{"line":116,"column":67}},"61":{"start":{"line":116,"column":26},"end":{"line":116,"column":65}},"62":{"start":{"line":117,"column":2},"end":{"line":124,"column":4}},"63":{"start":{"line":118,"column":4},"end":{"line":122,"column":27}},"64":{"start":{"line":119,"column":16},"end":{"line":119,"column":32}},"65":{"start":{"line":120,"column":16},"end":{"line":120,"column":47}},"66":{"start":{"line":121,"column":19},"end":{"line":121,"column":42}},"67":{"start":{"line":123,"column":4},"end":{"line":123,"column":18}},"68":{"start":{"line":125,"column":2},"end":{"line":125,"column":23}},"69":{"start":{"line":126,"column":2},"end":{"line":126,"column":20}},"70":{"start":{"line":127,"column":2},"end":{"line":130,"column":3}},"71":{"start":{"line":128,"column":4},"end":{"line":128,"column":33}},"72":{"start":{"line":128,"column":17},"end":{"line":128,"column":33}},"73":{"start":{"line":129,"column":4},"end":{"line":129,"column":52}},"74":{"start":{"line":129,"column":30},"end":{"line":129,"column":50}},"75":{"start":{"line":131,"column":2},"end":{"line":131,"column":14}},"76":{"start":{"line":134,"column":0},"end":{"line":140,"column":1}},"77":{"start":{"line":135,"column":2},"end":{"line":135,"column":24}},"78":{"start":{"line":136,"column":7},"end":{"line":140,"column":1}},"79":{"start":{"line":137,"column":2},"end":{"line":137,"column":38}},"80":{"start":{"line":137,"column":22},"end":{"line":137,"column":34}},"81":{"start":{"line":139,"column":2},"end":{"line":139,"column":22}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":26,"column":1},"end":{"line":26,"column":2}},"loc":{"start":{"line":26,"column":34},"end":{"line":142,"column":1}},"line":26},"1":{"name":"XorGen","decl":{"start":{"line":28,"column":9},"end":{"line":28,"column":15}},"loc":{"start":{"line":28,"column":22},"end":{"line":103,"column":1}},"line":28},"2":{"name":"(anonymous_2)","decl":{"start":{"line":32,"column":12},"end":{"line":32,"column":13}},"loc":{"start":{"line":32,"column":23},"end":{"line":49,"column":3}},"line":32},"3":{"name":"init","decl":{"start":{"line":51,"column":11},"end":{"line":51,"column":15}},"loc":{"start":{"line":51,"column":26},"end":{"line":100,"column":3}},"line":51},"4":{"name":"copy","decl":{"start":{"line":105,"column":9},"end":{"line":105,"column":13}},"loc":{"start":{"line":105,"column":20},"end":{"line":110,"column":1}},"line":105},"5":{"name":"impl","decl":{"start":{"line":112,"column":9},"end":{"line":112,"column":13}},"loc":{"start":{"line":112,"column":26},"end":{"line":132,"column":1}},"line":112},"6":{"name":"(anonymous_6)","decl":{"start":{"line":116,"column":13},"end":{"line":116,"column":14}},"loc":{"start":{"line":116,"column":24},"end":{"line":116,"column":67}},"line":116},"7":{"name":"(anonymous_7)","decl":{"start":{"line":117,"column":16},"end":{"line":117,"column":17}},"loc":{"start":{"line":117,"column":27},"end":{"line":124,"column":3}},"line":117},"8":{"name":"(anonymous_8)","decl":{"start":{"line":129,"column":17},"end":{"line":129,"column":18}},"loc":{"start":{"line":129,"column":28},"end":{"line":129,"column":52}},"line":129},"9":{"name":"(anonymous_9)","decl":{"start":{"line":137,"column":9},"end":{"line":137,"column":10}},"loc":{"start":{"line":137,"column":20},"end":{"line":137,"column":36}},"line":137}},"branchMap":{"0":{"loc":{"start":{"line":53,"column":4},"end":{"line":62,"column":5}},"type":"if","locations":[{"start":{"line":53,"column":4},"end":{"line":62,"column":5}},{"start":{"line":53,"column":4},"end":{"line":62,"column":5}}],"line":53},"1":{"loc":{"start":{"line":66,"column":6},"end":{"line":66,"column":61}},"type":"if","locations":[{"start":{"line":66,"column":6},"end":{"line":66,"column":61}},{"start":{"line":66,"column":6},"end":{"line":66,"column":61}}],"line":66},"2":{"loc":{"start":{"line":68,"column":6},"end":{"line":68,"column":25}},"type":"if","locations":[{"start":{"line":68,"column":6},"end":{"line":68,"column":25}},{"start":{"line":68,"column":6},"end":{"line":68,"column":25}}],"line":68},"3":{"loc":{"start":{"line":73,"column":6},"end":{"line":77,"column":7}},"type":"if","locations":[{"start":{"line":73,"column":6},"end":{"line":77,"column":7}},{"start":{"line":73,"column":6},"end":{"line":77,"column":7}}],"line":73},"4":{"loc":{"start":{"line":76,"column":12},"end":{"line":76,"column":32}},"type":"cond-expr","locations":[{"start":{"line":76,"column":23},"end":{"line":76,"column":28}},{"start":{"line":76,"column":31},"end":{"line":76,"column":32}}],"line":76},"5":{"loc":{"start":{"line":80,"column":4},"end":{"line":82,"column":5}},"type":"if","locations":[{"start":{"line":80,"column":4},"end":{"line":82,"column":5}},{"start":{"line":80,"column":4},"end":{"line":82,"column":5}}],"line":80},"6":{"loc":{"start":{"line":81,"column":9},"end":{"line":81,"column":33}},"type":"binary-expr","locations":[{"start":{"line":81,"column":9},"end":{"line":81,"column":13}},{"start":{"line":81,"column":17},"end":{"line":81,"column":28}},{"start":{"line":81,"column":32},"end":{"line":81,"column":33}}],"line":81},"7":{"loc":{"start":{"line":113,"column":2},"end":{"line":113,"column":39}},"type":"if","locations":[{"start":{"line":113,"column":2},"end":{"line":113,"column":39}},{"start":{"line":113,"column":2},"end":{"line":113,"column":39}}],"line":113},"8":{"loc":{"start":{"line":115,"column":14},"end":{"line":115,"column":32}},"type":"binary-expr","locations":[{"start":{"line":115,"column":14},"end":{"line":115,"column":18}},{"start":{"line":115,"column":22},"end":{"line":115,"column":32}}],"line":115},"9":{"loc":{"start":{"line":127,"column":2},"end":{"line":130,"column":3}},"type":"if","locations":[{"start":{"line":127,"column":2},"end":{"line":130,"column":3}},{"start":{"line":127,"column":2},"end":{"line":130,"column":3}}],"line":127},"10":{"loc":{"start":{"line":128,"column":4},"end":{"line":128,"column":33}},"type":"if","locations":[{"start":{"line":128,"column":4},"end":{"line":128,"column":33}},{"start":{"line":128,"column":4},"end":{"line":128,"column":33}}],"line":128},"11":{"loc":{"start":{"line":134,"column":0},"end":{"line":140,"column":1}},"type":"if","locations":[{"start":{"line":134,"column":0},"end":{"line":140,"column":1}},{"start":{"line":134,"column":0},"end":{"line":140,"column":1}}],"line":134},"12":{"loc":{"start":{"line":134,"column":4},"end":{"line":134,"column":28}},"type":"binary-expr","locations":[{"start":{"line":134,"column":4},"end":{"line":134,"column":10}},{"start":{"line":134,"column":14},"end":{"line":134,"column":28}}],"line":134},"13":{"loc":{"start":{"line":136,"column":7},"end":{"line":140,"column":1}},"type":"if","locations":[{"start":{"line":136,"column":7},"end":{"line":140,"column":1}},{"start":{"line":136,"column":7},"end":{"line":140,"column":1}}],"line":136},"14":{"loc":{"start":{"line":136,"column":11},"end":{"line":136,"column":31}},"type":"binary-expr","locations":[{"start":{"line":136,"column":11},"end":{"line":136,"column":17}},{"start":{"line":136,"column":21},"end":{"line":136,"column":31}}],"line":136},"15":{"loc":{"start":{"line":144,"column":2},"end":{"line":144,"column":39}},"type":"binary-expr","locations":[{"start":{"line":144,"column":2},"end":{"line":144,"column":29}},{"start":{"line":144,"column":33},"end":{"line":144,"column":39}}],"line":144},"16":{"loc":{"start":{"line":145,"column":2},"end":{"line":145,"column":41}},"type":"binary-expr","locations":[{"start":{"line":145,"column":2},"end":{"line":145,"column":31}},{"start":{"line":145,"column":35},"end":{"line":145,"column":41}}],"line":145}},"s":{"0":1,"1":3,"2":3,"3":4105129,"4":4105129,"5":4105129,"6":4105129,"7":4105129,"8":4105129,"9":4105129,"10":4105129,"11":4105129,"12":4105129,"13":4105129,"14":4105129,"15":4105129,"16":3,"17":3,"18":3,"19":2,"20":2,"21":1,"22":1,"23":1,"24":3,"25":480,"26":160,"27":480,"28":3,"29":480,"30":480,"31":480,"32":480,"33":480,"34":384,"35":384,"36":384,"37":3,"38":0,"39":3,"40":3,"41":1536,"42":1536,"43":1536,"44":1536,"45":1536,"46":1536,"47":1536,"48":3,"49":3,"50":3,"51":3,"52":2,"53":2,"54":2,"55":2,"56":3,"57":0,"58":3,"59":3,"60":3,"61":4102054,"62":3,"63":1025,"64":1025,"65":1025,"66":1025,"67":1025,"68":3,"69":3,"70":3,"71":2,"72":1,"73":2,"74":1,"75":3,"76":1,"77":1,"78":0,"79":0,"80":0,"81":0},"f":{"0":1,"1":3,"2":4105129,"3":3,"4":2,"5":3,"6":4102054,"7":1025,"8":1,"9":0},"b":{"0":[2,1],"1":[160,320],"2":[3,477],"3":[384,96],"4":[0,384],"5":[0,3],"6":[0,0,0],"7":[0,3],"8":[3,2],"9":[2,1],"10":[1,1],"11":[1,0],"12":[1,1],"13":[0,0],"14":[0,0],"15":[1,1],"16":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"5de096409f62b3565b1ce6d3136eb46f59ce3abe","contentHash":"2e41775c8739abfedd52237d6d32ba6c6ccbf9e10e6721c3a313ec1d67788df4"},"/home/davidbau/git/seedrandom/lib/tychei.js":{"path":"/home/davidbau/git/seedrandom/lib/tychei.js","statementMap":{"0":{"start":{"line":5,"column":0},"end":{"line":101,"column":2}},"1":{"start":{"line":8,"column":11},"end":{"line":8,"column":15}},"2":{"start":{"line":8,"column":27},"end":{"line":8,"column":29}},"3":{"start":{"line":11,"column":2},"end":{"line":21,"column":4}},"4":{"start":{"line":12,"column":12},"end":{"line":12,"column":16}},"5":{"start":{"line":12,"column":22},"end":{"line":12,"column":26}},"6":{"start":{"line":12,"column":32},"end":{"line":12,"column":36}},"7":{"start":{"line":12,"column":42},"end":{"line":12,"column":46}},"8":{"start":{"line":13,"column":4},"end":{"line":13,"column":34}},"9":{"start":{"line":14,"column":4},"end":{"line":14,"column":20}},"10":{"start":{"line":15,"column":4},"end":{"line":15,"column":34}},"11":{"start":{"line":16,"column":4},"end":{"line":16,"column":20}},"12":{"start":{"line":17,"column":4},"end":{"line":17,"column":42}},"13":{"start":{"line":18,"column":4},"end":{"line":18,"column":27}},"14":{"start":{"line":19,"column":4},"end":{"line":19,"column":38}},"15":{"start":{"line":20,"column":4},"end":{"line":20,"column":30}},"16":{"start":{"line":39,"column":2},"end":{"line":39,"column":11}},"17":{"start":{"line":40,"column":2},"end":{"line":40,"column":11}},"18":{"start":{"line":41,"column":2},"end":{"line":41,"column":24}},"19":{"start":{"line":42,"column":2},"end":{"line":42,"column":20}},"20":{"start":{"line":44,"column":2},"end":{"line":51,"column":3}},"21":{"start":{"line":46,"column":4},"end":{"line":46,"column":36}},"22":{"start":{"line":47,"column":4},"end":{"line":47,"column":20}},"23":{"start":{"line":50,"column":4},"end":{"line":50,"column":20}},"24":{"start":{"line":54,"column":2},"end":{"line":57,"column":3}},"25":{"start":{"line":54,"column":15},"end":{"line":54,"column":16}},"26":{"start":{"line":55,"column":4},"end":{"line":55,"column":38}},"27":{"start":{"line":56,"column":4},"end":{"line":56,"column":14}},"28":{"start":{"line":61,"column":2},"end":{"line":61,"column":12}},"29":{"start":{"line":62,"column":2},"end":{"line":62,"column":12}},"30":{"start":{"line":63,"column":2},"end":{"line":63,"column":12}},"31":{"start":{"line":64,"column":2},"end":{"line":64,"column":12}},"32":{"start":{"line":65,"column":2},"end":{"line":65,"column":11}},"33":{"start":{"line":69,"column":11},"end":{"line":69,"column":27}},"34":{"start":{"line":70,"column":14},"end":{"line":70,"column":32}},"35":{"start":{"line":71,"column":13},"end":{"line":71,"column":67}},"36":{"start":{"line":71,"column":26},"end":{"line":71,"column":65}},"37":{"start":{"line":72,"column":2},"end":{"line":79,"column":4}},"38":{"start":{"line":73,"column":4},"end":{"line":77,"column":27}},"39":{"start":{"line":74,"column":16},"end":{"line":74,"column":32}},"40":{"start":{"line":75,"column":16},"end":{"line":75,"column":47}},"41":{"start":{"line":76,"column":19},"end":{"line":76,"column":42}},"42":{"start":{"line":78,"column":4},"end":{"line":78,"column":18}},"43":{"start":{"line":80,"column":2},"end":{"line":80,"column":23}},"44":{"start":{"line":81,"column":2},"end":{"line":81,"column":20}},"45":{"start":{"line":82,"column":2},"end":{"line":85,"column":3}},"46":{"start":{"line":83,"column":4},"end":{"line":83,"column":51}},"47":{"start":{"line":83,"column":35},"end":{"line":83,"column":51}},"48":{"start":{"line":84,"column":4},"end":{"line":84,"column":52}},"49":{"start":{"line":84,"column":30},"end":{"line":84,"column":50}},"50":{"start":{"line":86,"column":2},"end":{"line":86,"column":14}},"51":{"start":{"line":89,"column":0},"end":{"line":95,"column":1}},"52":{"start":{"line":90,"column":2},"end":{"line":90,"column":24}},"53":{"start":{"line":91,"column":7},"end":{"line":95,"column":1}},"54":{"start":{"line":92,"column":2},"end":{"line":92,"column":38}},"55":{"start":{"line":92,"column":22},"end":{"line":92,"column":34}},"56":{"start":{"line":94,"column":2},"end":{"line":94,"column":21}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":5,"column":1},"end":{"line":5,"column":2}},"loc":{"start":{"line":5,"column":34},"end":{"line":97,"column":1}},"line":5},"1":{"name":"XorGen","decl":{"start":{"line":7,"column":9},"end":{"line":7,"column":15}},"loc":{"start":{"line":7,"column":22},"end":{"line":58,"column":1}},"line":7},"2":{"name":"(anonymous_2)","decl":{"start":{"line":11,"column":12},"end":{"line":11,"column":13}},"loc":{"start":{"line":11,"column":23},"end":{"line":21,"column":3}},"line":11},"3":{"name":"copy","decl":{"start":{"line":60,"column":9},"end":{"line":60,"column":13}},"loc":{"start":{"line":60,"column":20},"end":{"line":66,"column":1}},"line":60},"4":{"name":"impl","decl":{"start":{"line":68,"column":9},"end":{"line":68,"column":13}},"loc":{"start":{"line":68,"column":26},"end":{"line":87,"column":1}},"line":68},"5":{"name":"(anonymous_5)","decl":{"start":{"line":71,"column":13},"end":{"line":71,"column":14}},"loc":{"start":{"line":71,"column":24},"end":{"line":71,"column":67}},"line":71},"6":{"name":"(anonymous_6)","decl":{"start":{"line":72,"column":16},"end":{"line":72,"column":17}},"loc":{"start":{"line":72,"column":27},"end":{"line":79,"column":3}},"line":72},"7":{"name":"(anonymous_7)","decl":{"start":{"line":84,"column":17},"end":{"line":84,"column":18}},"loc":{"start":{"line":84,"column":28},"end":{"line":84,"column":52}},"line":84},"8":{"name":"(anonymous_8)","decl":{"start":{"line":92,"column":9},"end":{"line":92,"column":10}},"loc":{"start":{"line":92,"column":20},"end":{"line":92,"column":36}},"line":92}},"branchMap":{"0":{"loc":{"start":{"line":44,"column":2},"end":{"line":51,"column":3}},"type":"if","locations":[{"start":{"line":44,"column":2},"end":{"line":51,"column":3}},{"start":{"line":44,"column":2},"end":{"line":51,"column":3}}],"line":44},"1":{"loc":{"start":{"line":70,"column":14},"end":{"line":70,"column":32}},"type":"binary-expr","locations":[{"start":{"line":70,"column":14},"end":{"line":70,"column":18}},{"start":{"line":70,"column":22},"end":{"line":70,"column":32}}],"line":70},"2":{"loc":{"start":{"line":82,"column":2},"end":{"line":85,"column":3}},"type":"if","locations":[{"start":{"line":82,"column":2},"end":{"line":85,"column":3}},{"start":{"line":82,"column":2},"end":{"line":85,"column":3}}],"line":82},"3":{"loc":{"start":{"line":83,"column":4},"end":{"line":83,"column":51}},"type":"if","locations":[{"start":{"line":83,"column":4},"end":{"line":83,"column":51}},{"start":{"line":83,"column":4},"end":{"line":83,"column":51}}],"line":83},"4":{"loc":{"start":{"line":89,"column":0},"end":{"line":95,"column":1}},"type":"if","locations":[{"start":{"line":89,"column":0},"end":{"line":95,"column":1}},{"start":{"line":89,"column":0},"end":{"line":95,"column":1}}],"line":89},"5":{"loc":{"start":{"line":89,"column":4},"end":{"line":89,"column":28}},"type":"binary-expr","locations":[{"start":{"line":89,"column":4},"end":{"line":89,"column":10}},{"start":{"line":89,"column":14},"end":{"line":89,"column":28}}],"line":89},"6":{"loc":{"start":{"line":91,"column":7},"end":{"line":95,"column":1}},"type":"if","locations":[{"start":{"line":91,"column":7},"end":{"line":95,"column":1}},{"start":{"line":91,"column":7},"end":{"line":95,"column":1}}],"line":91},"7":{"loc":{"start":{"line":91,"column":11},"end":{"line":91,"column":31}},"type":"binary-expr","locations":[{"start":{"line":91,"column":11},"end":{"line":91,"column":17}},{"start":{"line":91,"column":21},"end":{"line":91,"column":31}}],"line":91},"8":{"loc":{"start":{"line":99,"column":2},"end":{"line":99,"column":39}},"type":"binary-expr","locations":[{"start":{"line":99,"column":2},"end":{"line":99,"column":29}},{"start":{"line":99,"column":33},"end":{"line":99,"column":39}}],"line":99},"9":{"loc":{"start":{"line":100,"column":2},"end":{"line":100,"column":41}},"type":"binary-expr","locations":[{"start":{"line":100,"column":2},"end":{"line":100,"column":31}},{"start":{"line":100,"column":35},"end":{"line":100,"column":41}}],"line":100}},"s":{"0":1,"1":3,"2":3,"3":3,"4":4105195,"5":4105195,"6":4105195,"7":4105195,"8":4105195,"9":4105195,"10":4105195,"11":4105195,"12":4105195,"13":4105195,"14":4105195,"15":4105195,"16":3,"17":3,"18":3,"19":3,"20":3,"21":2,"22":2,"23":1,"24":3,"25":3,"26":66,"27":66,"28":2,"29":2,"30":2,"31":2,"32":2,"33":3,"34":3,"35":3,"36":4102054,"37":3,"38":1025,"39":1025,"40":1025,"41":1025,"42":1025,"43":3,"44":3,"45":3,"46":2,"47":1,"48":2,"49":1,"50":3,"51":1,"52":1,"53":0,"54":0,"55":0,"56":0},"f":{"0":1,"1":3,"2":4105195,"3":2,"4":3,"5":4102054,"6":1025,"7":1,"8":0},"b":{"0":[2,1],"1":[3,2],"2":[2,1],"3":[1,1],"4":[1,0],"5":[1,1],"6":[0,0],"7":[0,0],"8":[1,1],"9":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"3875c0e0fa564e9ae68114bde64afc883b7c9ca0","contentHash":"00c6380ad151ad19433a64fdc0b4051c1a7ee0af16dc43e971860cc64ce62b05"},"/home/davidbau/git/seedrandom/lib/alea.js":{"path":"/home/davidbau/git/seedrandom/lib/alea.js","statementMap":{"0":{"start":{"line":28,"column":0},"end":{"line":112,"column":2}},"1":{"start":{"line":31,"column":11},"end":{"line":31,"column":15}},"2":{"start":{"line":31,"column":24},"end":{"line":31,"column":30}},"3":{"start":{"line":33,"column":2},"end":{"line":38,"column":4}},"4":{"start":{"line":34,"column":12},"end":{"line":34,"column":59}},"5":{"start":{"line":35,"column":4},"end":{"line":35,"column":18}},"6":{"start":{"line":36,"column":4},"end":{"line":36,"column":18}},"7":{"start":{"line":37,"column":4},"end":{"line":37,"column":38}},"8":{"start":{"line":41,"column":2},"end":{"line":41,"column":11}},"9":{"start":{"line":42,"column":2},"end":{"line":42,"column":20}},"10":{"start":{"line":43,"column":2},"end":{"line":43,"column":20}},"11":{"start":{"line":44,"column":2},"end":{"line":44,"column":20}},"12":{"start":{"line":45,"column":2},"end":{"line":45,"column":22}},"13":{"start":{"line":46,"column":2},"end":{"line":46,"column":32}},"14":{"start":{"line":46,"column":19},"end":{"line":46,"column":30}},"15":{"start":{"line":47,"column":2},"end":{"line":47,"column":22}},"16":{"start":{"line":48,"column":2},"end":{"line":48,"column":32}},"17":{"start":{"line":48,"column":19},"end":{"line":48,"column":30}},"18":{"start":{"line":49,"column":2},"end":{"line":49,"column":22}},"19":{"start":{"line":50,"column":2},"end":{"line":50,"column":32}},"20":{"start":{"line":50,"column":19},"end":{"line":50,"column":30}},"21":{"start":{"line":51,"column":2},"end":{"line":51,"column":14}},"22":{"start":{"line":55,"column":2},"end":{"line":55,"column":12}},"23":{"start":{"line":56,"column":2},"end":{"line":56,"column":14}},"24":{"start":{"line":57,"column":2},"end":{"line":57,"column":14}},"25":{"start":{"line":58,"column":2},"end":{"line":58,"column":14}},"26":{"start":{"line":59,"column":2},"end":{"line":59,"column":11}},"27":{"start":{"line":63,"column":11},"end":{"line":63,"column":25}},"28":{"start":{"line":64,"column":14},"end":{"line":64,"column":32}},"29":{"start":{"line":65,"column":13},"end":{"line":65,"column":20}},"30":{"start":{"line":66,"column":2},"end":{"line":66,"column":67}},"31":{"start":{"line":66,"column":28},"end":{"line":66,"column":65}},"32":{"start":{"line":67,"column":2},"end":{"line":69,"column":4}},"33":{"start":{"line":68,"column":4},"end":{"line":68,"column":69}},"34":{"start":{"line":70,"column":2},"end":{"line":70,"column":20}},"35":{"start":{"line":71,"column":2},"end":{"line":74,"column":3}},"36":{"start":{"line":72,"column":4},"end":{"line":72,"column":51}},"37":{"start":{"line":72,"column":35},"end":{"line":72,"column":51}},"38":{"start":{"line":73,"column":4},"end":{"line":73,"column":52}},"39":{"start":{"line":73,"column":30},"end":{"line":73,"column":50}},"40":{"start":{"line":75,"column":2},"end":{"line":75,"column":14}},"41":{"start":{"line":79,"column":10},"end":{"line":79,"column":20}},"42":{"start":{"line":81,"column":13},"end":{"line":94,"column":3}},"43":{"start":{"line":82,"column":4},"end":{"line":82,"column":24}},"44":{"start":{"line":83,"column":4},"end":{"line":92,"column":5}},"45":{"start":{"line":83,"column":17},"end":{"line":83,"column":18}},"46":{"start":{"line":84,"column":6},"end":{"line":84,"column":30}},"47":{"start":{"line":85,"column":14},"end":{"line":85,"column":37}},"48":{"start":{"line":86,"column":6},"end":{"line":86,"column":18}},"49":{"start":{"line":87,"column":6},"end":{"line":87,"column":13}},"50":{"start":{"line":88,"column":6},"end":{"line":88,"column":13}},"51":{"start":{"line":89,"column":6},"end":{"line":89,"column":18}},"52":{"start":{"line":90,"column":6},"end":{"line":90,"column":13}},"53":{"start":{"line":91,"column":6},"end":{"line":91,"column":27}},"54":{"start":{"line":93,"column":4},"end":{"line":93,"column":46}},"55":{"start":{"line":96,"column":2},"end":{"line":96,"column":14}},"56":{"start":{"line":100,"column":0},"end":{"line":106,"column":1}},"57":{"start":{"line":101,"column":2},"end":{"line":101,"column":24}},"58":{"start":{"line":102,"column":7},"end":{"line":106,"column":1}},"59":{"start":{"line":103,"column":2},"end":{"line":103,"column":38}},"60":{"start":{"line":103,"column":22},"end":{"line":103,"column":34}},"61":{"start":{"line":105,"column":2},"end":{"line":105,"column":19}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":28,"column":1},"end":{"line":28,"column":2}},"loc":{"start":{"line":28,"column":34},"end":{"line":108,"column":1}},"line":28},"1":{"name":"Alea","decl":{"start":{"line":30,"column":9},"end":{"line":30,"column":13}},"loc":{"start":{"line":30,"column":20},"end":{"line":52,"column":1}},"line":30},"2":{"name":"(anonymous_2)","decl":{"start":{"line":33,"column":12},"end":{"line":33,"column":13}},"loc":{"start":{"line":33,"column":23},"end":{"line":38,"column":3}},"line":33},"3":{"name":"copy","decl":{"start":{"line":54,"column":9},"end":{"line":54,"column":13}},"loc":{"start":{"line":54,"column":20},"end":{"line":60,"column":1}},"line":54},"4":{"name":"impl","decl":{"start":{"line":62,"column":9},"end":{"line":62,"column":13}},"loc":{"start":{"line":62,"column":26},"end":{"line":76,"column":1}},"line":62},"5":{"name":"(anonymous_5)","decl":{"start":{"line":66,"column":15},"end":{"line":66,"column":16}},"loc":{"start":{"line":66,"column":26},"end":{"line":66,"column":67}},"line":66},"6":{"name":"(anonymous_6)","decl":{"start":{"line":67,"column":16},"end":{"line":67,"column":17}},"loc":{"start":{"line":67,"column":27},"end":{"line":69,"column":3}},"line":67},"7":{"name":"(anonymous_7)","decl":{"start":{"line":73,"column":17},"end":{"line":73,"column":18}},"loc":{"start":{"line":73,"column":28},"end":{"line":73,"column":52}},"line":73},"8":{"name":"Mash","decl":{"start":{"line":78,"column":9},"end":{"line":78,"column":13}},"loc":{"start":{"line":78,"column":16},"end":{"line":97,"column":1}},"line":78},"9":{"name":"(anonymous_9)","decl":{"start":{"line":81,"column":13},"end":{"line":81,"column":14}},"loc":{"start":{"line":81,"column":28},"end":{"line":94,"column":3}},"line":81},"10":{"name":"(anonymous_10)","decl":{"start":{"line":103,"column":9},"end":{"line":103,"column":10}},"loc":{"start":{"line":103,"column":20},"end":{"line":103,"column":36}},"line":103}},"branchMap":{"0":{"loc":{"start":{"line":46,"column":2},"end":{"line":46,"column":32}},"type":"if","locations":[{"start":{"line":46,"column":2},"end":{"line":46,"column":32}},{"start":{"line":46,"column":2},"end":{"line":46,"column":32}}],"line":46},"1":{"loc":{"start":{"line":48,"column":2},"end":{"line":48,"column":32}},"type":"if","locations":[{"start":{"line":48,"column":2},"end":{"line":48,"column":32}},{"start":{"line":48,"column":2},"end":{"line":48,"column":32}}],"line":48},"2":{"loc":{"start":{"line":50,"column":2},"end":{"line":50,"column":32}},"type":"if","locations":[{"start":{"line":50,"column":2},"end":{"line":50,"column":32}},{"start":{"line":50,"column":2},"end":{"line":50,"column":32}}],"line":50},"3":{"loc":{"start":{"line":64,"column":14},"end":{"line":64,"column":32}},"type":"binary-expr","locations":[{"start":{"line":64,"column":14},"end":{"line":64,"column":18}},{"start":{"line":64,"column":22},"end":{"line":64,"column":32}}],"line":64},"4":{"loc":{"start":{"line":71,"column":2},"end":{"line":74,"column":3}},"type":"if","locations":[{"start":{"line":71,"column":2},"end":{"line":74,"column":3}},{"start":{"line":71,"column":2},"end":{"line":74,"column":3}}],"line":71},"5":{"loc":{"start":{"line":72,"column":4},"end":{"line":72,"column":51}},"type":"if","locations":[{"start":{"line":72,"column":4},"end":{"line":72,"column":51}},{"start":{"line":72,"column":4},"end":{"line":72,"column":51}}],"line":72},"6":{"loc":{"start":{"line":100,"column":0},"end":{"line":106,"column":1}},"type":"if","locations":[{"start":{"line":100,"column":0},"end":{"line":106,"column":1}},{"start":{"line":100,"column":0},"end":{"line":106,"column":1}}],"line":100},"7":{"loc":{"start":{"line":100,"column":4},"end":{"line":100,"column":28}},"type":"binary-expr","locations":[{"start":{"line":100,"column":4},"end":{"line":100,"column":10}},{"start":{"line":100,"column":14},"end":{"line":100,"column":28}}],"line":100},"8":{"loc":{"start":{"line":102,"column":7},"end":{"line":106,"column":1}},"type":"if","locations":[{"start":{"line":102,"column":7},"end":{"line":106,"column":1}},{"start":{"line":102,"column":7},"end":{"line":106,"column":1}}],"line":102},"9":{"loc":{"start":{"line":102,"column":11},"end":{"line":102,"column":31}},"type":"binary-expr","locations":[{"start":{"line":102,"column":11},"end":{"line":102,"column":17}},{"start":{"line":102,"column":21},"end":{"line":102,"column":31}}],"line":102},"10":{"loc":{"start":{"line":110,"column":2},"end":{"line":110,"column":39}},"type":"binary-expr","locations":[{"start":{"line":110,"column":2},"end":{"line":110,"column":29}},{"start":{"line":110,"column":33},"end":{"line":110,"column":39}}],"line":110},"11":{"loc":{"start":{"line":111,"column":2},"end":{"line":111,"column":41}},"type":"binary-expr","locations":[{"start":{"line":111,"column":2},"end":{"line":111,"column":31}},{"start":{"line":111,"column":35},"end":{"line":111,"column":41}}],"line":111}},"s":{"0":1,"1":3,"2":3,"3":3,"4":4105129,"5":4105129,"6":4105129,"7":4105129,"8":3,"9":3,"10":3,"11":3,"12":3,"13":3,"14":1,"15":3,"16":3,"17":3,"18":3,"19":3,"20":0,"21":3,"22":2,"23":2,"24":2,"25":2,"26":2,"27":3,"28":3,"29":3,"30":3,"31":1025,"32":3,"33":1025,"34":3,"35":3,"36":2,"37":1,"38":2,"39":1,"40":3,"41":3,"42":3,"43":18,"44":18,"45":18,"46":33,"47":33,"48":33,"49":33,"50":33,"51":33,"52":33,"53":33,"54":18,"55":3,"56":1,"57":1,"58":0,"59":0,"60":0,"61":0},"f":{"0":1,"1":3,"2":4105129,"3":2,"4":3,"5":1025,"6":1025,"7":1,"8":3,"9":18,"10":0},"b":{"0":[1,2],"1":[3,0],"2":[0,3],"3":[3,2],"4":[2,1],"5":[1,1],"6":[1,0],"7":[1,1],"8":[0,0],"9":[0,0],"10":[1,1],"11":[1,0]},"_coverageSchema":"43e27e138ebf9cfc5966b082cf9a028302ed4184","hash":"b70bcb8438fd8d93267e4355bb97ec0e15c51502","contentHash":"026d994d4bc0afeb3f977bb09d4e6284476ab12f7a5be78bdde751602626af54"}} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json new file mode 100644 index 0000000..d596d96 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json @@ -0,0 +1 @@ +{"uuid":"f02e18a9-b1c7-4946-836e-c3dbfb9635a3","parent":null,"pid":8128,"argv":["/home/davidbau/.nvm/versions/node/v11.9.0/bin/node","/home/davidbau/git/seedrandom/node_modules/mocha/bin/_mocha","test/cryptotest.js","test/nodetest.js","test/prngtest.js"],"execArgv":[],"cwd":"/home/davidbau/git/seedrandom","time":1568716532937,"ppid":8121,"root":"23c2e786-6463-4b5a-9042-75ea3257640f","coverageFilename":"/home/davidbau/git/seedrandom/.nyc_output/f02e18a9-b1c7-4946-836e-c3dbfb9635a3.json","files":["/home/davidbau/git/seedrandom/seedrandom.js","/home/davidbau/git/seedrandom/lib/xor128.js","/home/davidbau/git/seedrandom/lib/xorwow.js","/home/davidbau/git/seedrandom/lib/xorshift7.js","/home/davidbau/git/seedrandom/lib/xor4096.js","/home/davidbau/git/seedrandom/lib/tychei.js","/home/davidbau/git/seedrandom/lib/alea.js"]} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/index.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/index.json new file mode 100644 index 0000000..f67865c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.nyc_output/processinfo/index.json @@ -0,0 +1 @@ +{"processes":{"f02e18a9-b1c7-4946-836e-c3dbfb9635a3":{"parent":null,"children":[]}},"files":{"/home/davidbau/git/seedrandom/seedrandom.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/xor128.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/xorwow.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/xorshift7.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/xor4096.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/tychei.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"],"/home/davidbau/git/seedrandom/lib/alea.js":["f02e18a9-b1c7-4946-836e-c3dbfb9635a3"]},"externalIds":{}} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.travis.yml b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.travis.yml new file mode 100644 index 0000000..6852ab1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/.travis.yml @@ -0,0 +1,8 @@ +language: node_js +sudo: false +node_js: +- '7' +- '8' +- '9' +- '10' +- '11' diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/Gruntfile.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/Gruntfile.js new file mode 100644 index 0000000..41585ec --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/Gruntfile.js @@ -0,0 +1,97 @@ +module.exports = function(grunt) { + "use strict"; + + grunt.initConfig({ + pkg: grunt.file.readJSON("package.json"), + copy: { + browsertest: { + files: [ + { expand: true, cwd: 'node_modules/qunit/qunit', src: 'qunit.*' , + dest: 'test/lib'}, + { expand: true, cwd: 'node_modules/requirejs', src: 'require.js', + dest: 'test/lib'} + ], + } + }, + uglify: { + all: { + files: { + "<%= pkg.name %>.min.js": [ "<%= pkg.name %>.js" ], + "lib/alea.min.js": [ "lib/alea.js" ], + "lib/tychei.min.js": [ "lib/tychei.js" ], + "lib/xor4096.min.js": [ "lib/xor4096.js" ], + "lib/xorshift7.min.js": [ "lib/xorshift7.js" ], + "lib/xorwow.min.js": [ "lib/xorwow.js" ], + "lib/xor128.min.js": [ "lib/xor128.js" ] + }, + options: { + preserveComments: false, + report: "min", + output: { + ascii_only: true + } + } + } + }, + qunit: { + options: { + noGlobals: true, + httpBase: 'http://localhost:8192' + }, + all: ["test/*.html"] + }, + connect: { + server: { + options: { + port: 8192, + base: '.' + } + } + }, + browserify: { + test: { + files: { + 'test/browserified.js': ['test/nodetest.js'], + }, + options: { + ignore: ['requirejs', 'process'], + alias: { + 'assert': './test/qunitassert.js' + } + } + } + }, + mocha_nyc: { + coverage: { + src: 'test/*test.js' + }, + coveralls: { + src: 'test/*test.js', + options: { + coverage: true + } + } + }, + release: { + options: { + bump: false + } + } + }); + + grunt.event.on('coverage', require('coveralls').handleInput); + + grunt.loadNpmTasks('grunt-contrib-copy'); + grunt.loadNpmTasks('grunt-contrib-connect'); + grunt.loadNpmTasks('grunt-contrib-qunit'); + grunt.loadNpmTasks('grunt-contrib-uglify'); + grunt.loadNpmTasks('grunt-mocha-nyc'); + grunt.loadNpmTasks('grunt-release'); + grunt.loadNpmTasks('grunt-browserify'); + + grunt.registerTask("test", ["copy:browsertest", "browserify", + "connect", "qunit", "mocha_nyc:coverage"]); + grunt.registerTask("default", ["uglify", "test"]); + grunt.registerTask("travis", ["default", "mocha_nyc:coveralls"]); +}; + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/README.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/README.md new file mode 100644 index 0000000..9518915 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/README.md @@ -0,0 +1,322 @@ +seedrandom.js +============= +[![Build Status](https://travis-ci.org/davidbau/seedrandom.svg?branch=master)](https://travis-ci.org/davidbau/seedrandom) +[![NPM version](https://badge.fury.io/js/seedrandom.svg)](http://badge.fury.io/js/seedrandom) +[![Bower version](https://badge.fury.io/bo/seedrandom.svg)](http://badge.fury.io/bo/seedrandom) + +Seeded random number generator for JavaScript. + +Version 3.0.5 + +Author: David Bau + +Date: 2019-09-14 + +Can be used as a plain script, a Node.js module or an AMD module. + + +Script tag usage +---------------- + +```html + +``` + +```js +// Make a predictable pseudorandom number generator. +var myrng = new Math.seedrandom('hello.'); +console.log(myrng()); // Always 0.9282578795792454 +console.log(myrng()); // Always 0.3752569768646784 + +// Use "quick" to get only 32 bits of randomness in a float. +console.log(myrng.quick()); // Always 0.7316977467853576 + +// Use "int32" to get a 32 bit (signed) integer +console.log(myrng.int32()); // Always 1966374204 + +// Calling seedrandom with no arguments creates an ARC4-based PRNG +// that is autoseeded using the current time, dom state, and other +// accumulated local entropy. +var prng = new Math.seedrandom(); +console.log(prng()); // Reasonably unpredictable. + +// Seeds using the given explicit seed mixed with accumulated entropy. +prng = new Math.seedrandom('added entropy.', { entropy: true }); +console.log(prng()); // As unpredictable as added entropy. + +// Warning: if you call Math.seedrandom without `new`, it replaces +// Math.random with the predictable new Math.seedrandom(...), as follows: +Math.seedrandom('hello.'); +console.log(Math.random()); // Always 0.9282578795792454 +console.log(Math.random()); // Always 0.3752569768646784 + +``` + +**Note**: calling `Math.seedrandom('constant')` without `new` will make +`Math.random()` predictable globally, which is intended to be useful for +derandomizing code for testing, but should not be done in a production library. +If you need a local seeded PRNG, use `myrng = new Math.seedrandom('seed')` +instead. For example, [cryptico](https://www.npmjs.com/package/cryptico), +an RSA encryption package, [uses the wrong form]( +https://github.com/wwwtyro/cryptico/blob/9291ece6/api.js#L264), +and thus secretly makes `Math.random()` perfectly predictable. +The cryptico library (and any other library that does this) +should not be trusted in a security-sensitive application. + + +Other Fast PRNG Algorithms +-------------------------- + +The package includes some other fast PRNGs. To use Johannes Baagøe's +extremely fast Alea PRNG: + + +```html + +``` + +```js +// Use alea for Johannes Baagøe's clever and fast floating-point RNG. +var arng = new alea('hello.'); + +// By default provides 32 bits of randomness in a float. +console.log(arng()); // Always 0.4783254903741181 + +// Use "double" to get 56 bits of randomness. +console.log(arng.double()); // Always 0.8297006866124559 + +// Use "int32" to get a 32 bit (signed) integer. +console.log(arng.int32()); // Always 1076136327 +``` + +Besides alea, there are several other faster PRNGs available. +Note that none of these fast PRNGs provide autoseeding: you +need to provide your own seed (or use the default autoseeded +seedrandom to make a seed). + +|PRNG name | Time vs native | Period | Author | +|-----------|----------------|-------------|----------------------| +|`alea` | 1.95 ns, 0.9x | ~2^116 | Baagøe | +|`xor128` | 2.04 ns, 0.9x | 2^128-1 | Marsaglia | +|`tychei` | 2.32 ns, 1.1x | ~2^127 | Neves/Araujo (ChaCha)| +|`xorwow` | 2.40 ns, 1.1x | 2^192-2^32 | Marsaglia | +|`xor4096` | 2.40 ns, 1.1x | 2^4096-2^32 | Brent (xorgens) | +|`xorshift7`| 2.64 ns, 1.3x | 2^256-1 | Panneton/L'ecuyer | +|`quick` | 3.80 ns, 1.8x | ~2^1600 | Bau (ARC4) | + +(Timings were done on node v0.12.2 on a single-core Google Compute Engine +instance. `quick` is just the 32-bit version of the RC4-based PRNG +originally packaged with seedrandom.) + + +CJS / Node.js usage +------------------- + +``` +npm install seedrandom +``` + +```js +// Local PRNG: does not affect Math.random. +var seedrandom = require('seedrandom'); +var rng = seedrandom('hello.'); +console.log(rng()); // Always 0.9282578795792454 + +// Global PRNG: set Math.random. +seedrandom('hello.', { global: true }); +console.log(Math.random()); // Always 0.9282578795792454 + +// Autoseeded ARC4-based PRNG. +rng = seedrandom(); +console.log(rng()); // Reasonably unpredictable. + +// Mixing accumulated entropy. +rng = seedrandom('added entropy.', { entropy: true }); +console.log(rng()); // As unpredictable as added entropy. + +// Using alternate algorithms, as listed above. +var rng2 = seedrandom.xor4096('hello.') +console.log(rng2()); +``` + +Starting in version 3, when using via require('seedrandom'), the global +`Math.seedrandom` is no longer available. + + +Require.js usage +---------------- + +Similar to Node.js usage: + +``` +bower install seedrandom +``` + +``` +require(['seedrandom'], function(seedrandom) { + var rng = seedrandom('hello.'); + console.log(rng()); // Always 0.9282578795792454 +}); +``` + + +Network seeding +--------------- + +```html + + + + + + +``` + +Reseeding using user input +-------------------------- + +```js +var seed = Math.seedrandom(); // Use prng with an automatic seed. +document.write(Math.random()); // Pretty much unpredictable x. + +var rng = new Math.seedrandom(seed); // A new prng with the same seed. +document.write(rng()); // Repeat the 'unpredictable' x. + +function reseed(event, count) { // Define a custom entropy collector. + var t = []; + function w(e) { + t.push([e.pageX, e.pageY, +new Date]); + if (t.length < count) { return; } + document.removeEventListener(event, w); + Math.seedrandom(t, { entropy: true }); + } + document.addEventListener(event, w); +} +reseed('mousemove', 100); // Reseed after 100 mouse moves. +``` + +The "pass" option can be used to get both the prng and the seed. +The following returns both an autoseeded prng and the seed as an object, +without mutating Math.random: + +```js +var obj = Math.seedrandom(null, { pass: function(prng, seed) { + return { random: prng, seed: seed }; +}}); +``` + + +Saving and Restoring PRNG state +------------------------------- + +```js +var seedrandom = Math.seedrandom; +var saveable = seedrandom("secret-seed", {state: true}); +for (var j = 0; j < 1e5; ++j) saveable(); +var saved = saveable.state(); +var replica = seedrandom("", {state: saved}); +assert(replica() == saveable()); +``` + +In normal use the prng is opaque and its internal state cannot be accessed. +However, if the "state" option is specified, the prng gets a state() method +that returns a plain object the can be used to reconstruct a prng later in +the same state (by passing that saved object back as the state option). + + +Version notes +------------- + +The random number sequence is the same as version 1.0 for string seeds. + +* Version 2.0 changed the sequence for non-string seeds. +* Version 2.1 speeds seeding and uses window.crypto to autoseed if present. +* Version 2.2 alters non-crypto autoseeding to sweep up entropy from plugins. +* Version 2.3 adds support for "new", module loading, and a null seed arg. +* Version 2.3.1 adds a build environment, module packaging, and tests. +* Version 2.3.4 fixes bugs on IE8, and switches to MIT license. +* Version 2.3.6 adds a readable options object argument. +* Version 2.3.10 adds support for node.js crypto (contributed by ctd1500). +* Version 2.3.11 adds an option to load and save internal state. +* Version 2.4.0 adds implementations of several other fast PRNGs. +* Version 2.4.2 adds an implementation of Baagoe's very fast Alea PRNG. +* Version 2.4.3 ignores nodejs crypto when under browserify. +* Version 2.4.4 avoids strict mode problem with global this reference. +* Version 3.0.1 removes Math.seedrandom for require('seedrandom') users. +* Version 3.0.3 updates package.json for CDN entrypoints. +* Version 3.0.5 removes eval to avoid triggering content-security policy. + +The standard ARC4 key scheduler cycles short keys, which means that +seedrandom('ab') is equivalent to seedrandom('abab') and 'ababab'. +Therefore it is a good idea to add a terminator to avoid trivial +equivalences on short string seeds, e.g., Math.seedrandom(str + '\0'). +Starting with version 2.0, a terminator is added automatically for +non-string seeds, so seeding with the number 111 is the same as seeding +with '111\0'. + +When seedrandom() is called with zero args or a null seed, it uses a +seed drawn from the browser crypto object if present. If there is no +crypto support, seedrandom() uses the current time, the native rng, +and a walk of several DOM objects to collect a few bits of entropy. + +Each time the one- or two-argument forms of seedrandom are called, +entropy from the passed seed is accumulated in a pool to help generate +future seeds for the zero- and two-argument forms of seedrandom. + +On speed - This javascript implementation of Math.random() is several +times slower than the built-in Math.random() because it is not native +code, but that is typically fast enough. Some details (timings on +Chrome 25 on a 2010 vintage macbook): + +* seeded Math.random() - avg less than 0.0002 milliseconds per call +* seedrandom('explicit.') - avg less than 0.2 milliseconds per call +* seedrandom('explicit.', true) - avg less than 0.2 milliseconds per call +* seedrandom() with crypto - avg less than 0.2 milliseconds per call + +Autoseeding without crypto is somewhat slow, about 20-30 milliseconds on +a 2012 windows 7 1.5ghz i5 laptop, as seen on Firefox 19, IE 10, and Opera. +Seeded rng calls themselves are fast across these browsers, with slowest +numbers on Opera at about 0.0005 ms per seeded Math.random(). + + +LICENSE (MIT) +------------- + +Copyright 2019 David Bau. + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/bower.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/bower.json new file mode 100644 index 0000000..8e62b3a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/bower.json @@ -0,0 +1,16 @@ +{ + "name": "seedrandom", + "description": "Seeded random number generator for Javascript.", + "main": "seedrandom.js", + "license": "MIT", + "keywords": [ + "random", + "seed", + "crypto" + ], + "ignore": [], + "devDependencies": { + "qunit": "latest", + "requirejs": "latest" + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/component.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/component.json new file mode 100644 index 0000000..43fea29 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/component.json @@ -0,0 +1,10 @@ +{ + "name": "seedrandom", + "version": "3.0.0", + "description": "Seeded random number generator for Javascript", + "repository": "davidbau/seedrandom", + "main": "seedrandom.js", + "scripts": [ "seedrandom.js" ], + "keywords": [ "random", "seed", "crypto" ], + "license": "MIT" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/coverage.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/coverage.json new file mode 100644 index 0000000..9e9657b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/coverage.json @@ -0,0 +1 @@ +{"/home/davidbau/git/seedrandom/seedrandom.js":{"path":"/home/davidbau/git/seedrandom/seedrandom.js","s":{"1":6,"2":6,"3":1,"4":23,"5":23,"6":23,"7":23,"8":23,"9":3694,"10":3694,"11":3918,"12":3918,"13":3918,"14":3694,"15":9252,"16":9252,"17":9252,"18":3694,"19":23,"20":1025,"21":23,"22":4100001,"23":23,"24":23,"25":23,"26":20,"27":4,"28":2,"29":4,"30":2,"31":20,"32":1,"33":1,"34":19,"35":1,"36":23,"37":23,"38":1,"39":23,"40":5888,"41":23,"42":5888,"43":5888,"44":23,"45":4108661,"46":4108661,"47":16436074,"48":16436074,"49":4108661,"50":4108661,"51":4108661,"52":1,"53":4,"54":4,"55":4,"56":4,"57":1,"58":174,"59":174,"60":8,"61":151,"62":151,"63":174,"64":1,"65":52,"66":52,"67":46040,"68":52,"69":1,"70":4,"71":4,"72":4,"73":3,"74":1,"75":1,"76":3,"77":1,"78":1,"79":1,"80":81,"81":6,"82":6,"83":6,"84":6,"85":6,"86":0,"87":0,"88":0,"89":0},"b":{"1":[1,22],"2":[22,11],"3":[2,21],"4":[4,17],"5":[23,21,20],"6":[4,16],"7":[2,2],"8":[1,19],"9":[4,19],"10":[1,22],"11":[8,166],"12":[174,56],"13":[8,166],"14":[29,137],"15":[3,1],"16":[4,3],"17":[1,1],"18":[1,0],"19":[6,0],"20":[6,6],"21":[0,0],"22":[0,0]},"f":{"1":6,"2":23,"3":3694,"4":1025,"5":4100001,"6":20,"7":2,"8":23,"9":4108661,"10":4,"11":174,"12":52,"13":4,"14":81,"15":0},"fnMap":{"1":{"name":"(anonymous_1)","line":25,"loc":{"start":{"line":25,"column":1},"end":{"line":25,"column":23}}},"2":{"name":"seedrandom","line":47,"loc":{"start":{"line":47,"column":0},"end":{"line":47,"column":45}}},"3":{"name":"(anonymous_3)","line":61,"loc":{"start":{"line":61,"column":13},"end":{"line":61,"column":24}}},"4":{"name":"(anonymous_4)","line":78,"loc":{"start":{"line":78,"column":15},"end":{"line":78,"column":26}}},"5":{"name":"(anonymous_5)","line":79,"loc":{"start":{"line":79,"column":15},"end":{"line":79,"column":26}}},"6":{"name":"(anonymous_6)","line":87,"loc":{"start":{"line":87,"column":6},"end":{"line":87,"column":48}}},"7":{"name":"(anonymous_7)","line":92,"loc":{"start":{"line":92,"column":23},"end":{"line":92,"column":34}}},"8":{"name":"ARC4","line":119,"loc":{"start":{"line":119,"column":0},"end":{"line":119,"column":19}}},"9":{"name":"(anonymous_9)","line":136,"loc":{"start":{"line":136,"column":10},"end":{"line":136,"column":26}}},"10":{"name":"copy","line":156,"loc":{"start":{"line":156,"column":0},"end":{"line":156,"column":20}}},"11":{"name":"flatten","line":167,"loc":{"start":{"line":167,"column":0},"end":{"line":167,"column":29}}},"12":{"name":"mixkey","line":182,"loc":{"start":{"line":182,"column":0},"end":{"line":182,"column":27}}},"13":{"name":"autoseed","line":196,"loc":{"start":{"line":196,"column":0},"end":{"line":196,"column":20}}},"14":{"name":"tostring","line":218,"loc":{"start":{"line":218,"column":0},"end":{"line":218,"column":21}}},"15":{"name":"(anonymous_15)","line":242,"loc":{"start":{"line":242,"column":9},"end":{"line":242,"column":20}}}},"statementMap":{"1":{"start":{"line":25,"column":0},"end":{"line":253,"column":2}},"2":{"start":{"line":32,"column":0},"end":{"line":41,"column":15}},"3":{"start":{"line":47,"column":0},"end":{"line":107,"column":1}},"4":{"start":{"line":48,"column":2},"end":{"line":48,"column":15}},"5":{"start":{"line":49,"column":2},"end":{"line":49,"column":68}},"6":{"start":{"line":52,"column":2},"end":{"line":54,"column":49}},"7":{"start":{"line":57,"column":2},"end":{"line":57,"column":27}},"8":{"start":{"line":61,"column":2},"end":{"line":76,"column":4}},"9":{"start":{"line":62,"column":4},"end":{"line":64,"column":14}},"10":{"start":{"line":65,"column":4},"end":{"line":69,"column":5}},"11":{"start":{"line":66,"column":6},"end":{"line":66,"column":26}},"12":{"start":{"line":67,"column":6},"end":{"line":67,"column":17}},"13":{"start":{"line":68,"column":6},"end":{"line":68,"column":20}},"14":{"start":{"line":70,"column":4},"end":{"line":74,"column":5}},"15":{"start":{"line":71,"column":6},"end":{"line":71,"column":13}},"16":{"start":{"line":72,"column":6},"end":{"line":72,"column":13}},"17":{"start":{"line":73,"column":6},"end":{"line":73,"column":15}},"18":{"start":{"line":75,"column":4},"end":{"line":75,"column":23}},"19":{"start":{"line":78,"column":2},"end":{"line":78,"column":51}},"20":{"start":{"line":78,"column":28},"end":{"line":78,"column":49}},"21":{"start":{"line":79,"column":2},"end":{"line":79,"column":61}},"22":{"start":{"line":79,"column":28},"end":{"line":79,"column":59}},"23":{"start":{"line":80,"column":2},"end":{"line":80,"column":21}},"24":{"start":{"line":83,"column":2},"end":{"line":83,"column":33}},"25":{"start":{"line":86,"column":2},"end":{"line":106,"column":17}},"26":{"start":{"line":88,"column":8},"end":{"line":93,"column":9}},"27":{"start":{"line":90,"column":10},"end":{"line":90,"column":45}},"28":{"start":{"line":90,"column":25},"end":{"line":90,"column":43}},"29":{"start":{"line":92,"column":10},"end":{"line":92,"column":60}},"30":{"start":{"line":92,"column":36},"end":{"line":92,"column":58}},"31":{"start":{"line":97,"column":8},"end":{"line":101,"column":25}},"32":{"start":{"line":97,"column":28},"end":{"line":97,"column":49}},"33":{"start":{"line":97,"column":50},"end":{"line":97,"column":62}},"34":{"start":{"line":101,"column":13},"end":{"line":101,"column":25}},"35":{"start":{"line":119,"column":0},"end":{"line":150,"column":1}},"36":{"start":{"line":120,"column":2},"end":{"line":121,"column":59}},"37":{"start":{"line":124,"column":2},"end":{"line":124,"column":36}},"38":{"start":{"line":124,"column":17},"end":{"line":124,"column":34}},"39":{"start":{"line":127,"column":2},"end":{"line":129,"column":3}},"40":{"start":{"line":128,"column":4},"end":{"line":128,"column":15}},"41":{"start":{"line":130,"column":2},"end":{"line":133,"column":3}},"42":{"start":{"line":131,"column":4},"end":{"line":131,"column":60}},"43":{"start":{"line":132,"column":4},"end":{"line":132,"column":13}},"44":{"start":{"line":136,"column":2},"end":{"line":149,"column":12}},"45":{"start":{"line":138,"column":4},"end":{"line":139,"column":37}},"46":{"start":{"line":140,"column":4},"end":{"line":143,"column":5}},"47":{"start":{"line":141,"column":6},"end":{"line":141,"column":32}},"48":{"start":{"line":142,"column":6},"end":{"line":142,"column":78}},"49":{"start":{"line":144,"column":4},"end":{"line":144,"column":13}},"50":{"start":{"line":144,"column":14},"end":{"line":144,"column":23}},"51":{"start":{"line":145,"column":4},"end":{"line":145,"column":13}},"52":{"start":{"line":156,"column":0},"end":{"line":161,"column":1}},"53":{"start":{"line":157,"column":2},"end":{"line":157,"column":12}},"54":{"start":{"line":158,"column":2},"end":{"line":158,"column":12}},"55":{"start":{"line":159,"column":2},"end":{"line":159,"column":20}},"56":{"start":{"line":160,"column":2},"end":{"line":160,"column":11}},"57":{"start":{"line":167,"column":0},"end":{"line":175,"column":1}},"58":{"start":{"line":168,"column":2},"end":{"line":168,"column":44}},"59":{"start":{"line":169,"column":2},"end":{"line":173,"column":3}},"60":{"start":{"line":170,"column":4},"end":{"line":172,"column":5}},"61":{"start":{"line":171,"column":6},"end":{"line":171,"column":70}},"62":{"start":{"line":171,"column":12},"end":{"line":171,"column":55}},"63":{"start":{"line":174,"column":2},"end":{"line":174,"column":71}},"64":{"start":{"line":182,"column":0},"end":{"line":189,"column":1}},"65":{"start":{"line":183,"column":2},"end":{"line":183,"column":43}},"66":{"start":{"line":184,"column":2},"end":{"line":187,"column":3}},"67":{"start":{"line":185,"column":4},"end":{"line":186,"column":74}},"68":{"start":{"line":188,"column":2},"end":{"line":188,"column":23}},"69":{"start":{"line":196,"column":0},"end":{"line":212,"column":1}},"70":{"start":{"line":197,"column":2},"end":{"line":211,"column":3}},"71":{"start":{"line":198,"column":4},"end":{"line":198,"column":12}},"72":{"start":{"line":199,"column":4},"end":{"line":205,"column":5}},"73":{"start":{"line":201,"column":6},"end":{"line":201,"column":23}},"74":{"start":{"line":203,"column":6},"end":{"line":203,"column":34}},"75":{"start":{"line":204,"column":6},"end":{"line":204,"column":62}},"76":{"start":{"line":206,"column":4},"end":{"line":206,"column":25}},"77":{"start":{"line":208,"column":4},"end":{"line":209,"column":45}},"78":{"start":{"line":210,"column":4},"end":{"line":210,"column":71}},"79":{"start":{"line":218,"column":0},"end":{"line":220,"column":1}},"80":{"start":{"line":219,"column":2},"end":{"line":219,"column":41}},"81":{"start":{"line":229,"column":0},"end":{"line":229,"column":28}},"82":{"start":{"line":235,"column":0},"end":{"line":246,"column":1}},"83":{"start":{"line":236,"column":2},"end":{"line":236,"column":30}},"84":{"start":{"line":238,"column":2},"end":{"line":240,"column":17}},"85":{"start":{"line":239,"column":4},"end":{"line":239,"column":35}},"86":{"start":{"line":241,"column":7},"end":{"line":246,"column":1}},"87":{"start":{"line":242,"column":2},"end":{"line":242,"column":44}},"88":{"start":{"line":242,"column":22},"end":{"line":242,"column":40}},"89":{"start":{"line":245,"column":2},"end":{"line":245,"column":38}}},"branchMap":{"1":{"line":49,"type":"cond-expr","locations":[{"start":{"line":49,"column":32},"end":{"line":49,"column":49}},{"start":{"line":49,"column":53},"end":{"line":49,"column":66}}]},"2":{"line":49,"type":"binary-expr","locations":[{"start":{"line":49,"column":53},"end":{"line":49,"column":60}},{"start":{"line":49,"column":64},"end":{"line":49,"column":66}}]},"3":{"line":53,"type":"cond-expr","locations":[{"start":{"line":53,"column":22},"end":{"line":53,"column":44}},{"start":{"line":54,"column":4},"end":{"line":54,"column":38}}]},"4":{"line":54,"type":"cond-expr","locations":[{"start":{"line":54,"column":21},"end":{"line":54,"column":31}},{"start":{"line":54,"column":34},"end":{"line":54,"column":38}}]},"5":{"line":86,"type":"binary-expr","locations":[{"start":{"line":86,"column":10},"end":{"line":86,"column":22}},{"start":{"line":86,"column":26},"end":{"line":86,"column":34}},{"start":{"line":87,"column":6},"end":{"line":102,"column":7}}]},"6":{"line":88,"type":"if","locations":[{"start":{"line":88,"column":8},"end":{"line":88,"column":8}},{"start":{"line":88,"column":8},"end":{"line":88,"column":8}}]},"7":{"line":90,"type":"if","locations":[{"start":{"line":90,"column":10},"end":{"line":90,"column":10}},{"start":{"line":90,"column":10},"end":{"line":90,"column":10}}]},"8":{"line":97,"type":"if","locations":[{"start":{"line":97,"column":8},"end":{"line":97,"column":8}},{"start":{"line":97,"column":8},"end":{"line":97,"column":8}}]},"9":{"line":105,"type":"cond-expr","locations":[{"start":{"line":105,"column":24},"end":{"line":105,"column":38}},{"start":{"line":105,"column":42},"end":{"line":105,"column":54}}]},"10":{"line":124,"type":"if","locations":[{"start":{"line":124,"column":2},"end":{"line":124,"column":2}},{"start":{"line":124,"column":2},"end":{"line":124,"column":2}}]},"11":{"line":169,"type":"if","locations":[{"start":{"line":169,"column":2},"end":{"line":169,"column":2}},{"start":{"line":169,"column":2},"end":{"line":169,"column":2}}]},"12":{"line":169,"type":"binary-expr","locations":[{"start":{"line":169,"column":6},"end":{"line":169,"column":11}},{"start":{"line":169,"column":15},"end":{"line":169,"column":30}}]},"13":{"line":174,"type":"cond-expr","locations":[{"start":{"line":174,"column":26},"end":{"line":174,"column":32}},{"start":{"line":174,"column":35},"end":{"line":174,"column":69}}]},"14":{"line":174,"type":"cond-expr","locations":[{"start":{"line":174,"column":53},"end":{"line":174,"column":56}},{"start":{"line":174,"column":59},"end":{"line":174,"column":69}}]},"15":{"line":199,"type":"if","locations":[{"start":{"line":199,"column":4},"end":{"line":199,"column":4}},{"start":{"line":199,"column":4},"end":{"line":199,"column":4}}]},"16":{"line":199,"type":"binary-expr","locations":[{"start":{"line":199,"column":8},"end":{"line":199,"column":18}},{"start":{"line":199,"column":23},"end":{"line":199,"column":51}}]},"17":{"line":204,"type":"binary-expr","locations":[{"start":{"line":204,"column":7},"end":{"line":204,"column":20}},{"start":{"line":204,"column":24},"end":{"line":204,"column":39}}]},"18":{"line":209,"type":"binary-expr","locations":[{"start":{"line":209,"column":18},"end":{"line":209,"column":25}},{"start":{"line":209,"column":29},"end":{"line":209,"column":44}}]},"19":{"line":235,"type":"if","locations":[{"start":{"line":235,"column":0},"end":{"line":235,"column":0}},{"start":{"line":235,"column":0},"end":{"line":235,"column":0}}]},"20":{"line":235,"type":"binary-expr","locations":[{"start":{"line":235,"column":4},"end":{"line":235,"column":31}},{"start":{"line":235,"column":35},"end":{"line":235,"column":49}}]},"21":{"line":241,"type":"if","locations":[{"start":{"line":241,"column":7},"end":{"line":241,"column":7}},{"start":{"line":241,"column":7},"end":{"line":241,"column":7}}]},"22":{"line":241,"type":"binary-expr","locations":[{"start":{"line":241,"column":11},"end":{"line":241,"column":40}},{"start":{"line":241,"column":44},"end":{"line":241,"column":54}}]}}},"/home/davidbau/git/seedrandom/lib/xor128.js":{"path":"/home/davidbau/git/seedrandom/lib/xor128.js","s":{"1":1,"2":1,"3":3,"4":3,"5":3,"6":3,"7":3,"8":3,"9":4105327,"10":4105327,"11":4105327,"12":4105327,"13":4105327,"14":3,"15":2,"16":1,"17":3,"18":198,"19":198,"20":1,"21":2,"22":2,"23":2,"24":2,"25":2,"26":1,"27":3,"28":4102054,"29":3,"30":1025,"31":1025,"32":1025,"33":3,"34":3,"35":3,"36":2,"37":1,"38":2,"39":1,"40":3,"41":1,"42":1,"43":0,"44":0,"45":0,"46":0},"b":{"1":[2,1],"2":[3,2],"3":[2,1],"4":[1,1],"5":[1,0],"6":[1,1],"7":[0,0],"8":[0,0],"9":[1,1],"10":[1,0]},"f":{"1":1,"2":3,"3":4105327,"4":2,"5":3,"6":4102054,"7":1025,"8":1,"9":0},"fnMap":{"1":{"name":"(anonymous_1)","line":4,"loc":{"start":{"line":4,"column":1},"end":{"line":4,"column":34}}},"2":{"name":"XorGen","line":6,"loc":{"start":{"line":6,"column":0},"end":{"line":6,"column":22}}},"3":{"name":"(anonymous_3)","line":15,"loc":{"start":{"line":15,"column":12},"end":{"line":15,"column":23}}},"4":{"name":"copy","line":38,"loc":{"start":{"line":38,"column":0},"end":{"line":38,"column":20}}},"5":{"name":"impl","line":46,"loc":{"start":{"line":46,"column":0},"end":{"line":46,"column":26}}},"6":{"name":"(anonymous_6)","line":49,"loc":{"start":{"line":49,"column":13},"end":{"line":49,"column":24}}},"7":{"name":"(anonymous_7)","line":50,"loc":{"start":{"line":50,"column":16},"end":{"line":50,"column":27}}},"8":{"name":"(anonymous_8)","line":62,"loc":{"start":{"line":62,"column":17},"end":{"line":62,"column":28}}},"9":{"name":"(anonymous_9)","line":70,"loc":{"start":{"line":70,"column":9},"end":{"line":70,"column":20}}}},"statementMap":{"1":{"start":{"line":4,"column":0},"end":{"line":79,"column":2}},"2":{"start":{"line":6,"column":0},"end":{"line":36,"column":1}},"3":{"start":{"line":7,"column":2},"end":{"line":7,"column":30}},"4":{"start":{"line":9,"column":2},"end":{"line":9,"column":11}},"5":{"start":{"line":10,"column":2},"end":{"line":10,"column":11}},"6":{"start":{"line":11,"column":2},"end":{"line":11,"column":11}},"7":{"start":{"line":12,"column":2},"end":{"line":12,"column":11}},"8":{"start":{"line":15,"column":2},"end":{"line":21,"column":4}},"9":{"start":{"line":16,"column":4},"end":{"line":16,"column":32}},"10":{"start":{"line":17,"column":4},"end":{"line":17,"column":16}},"11":{"start":{"line":18,"column":4},"end":{"line":18,"column":16}},"12":{"start":{"line":19,"column":4},"end":{"line":19,"column":16}},"13":{"start":{"line":20,"column":4},"end":{"line":20,"column":49}},"14":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"15":{"start":{"line":25,"column":4},"end":{"line":25,"column":16}},"16":{"start":{"line":28,"column":4},"end":{"line":28,"column":20}},"17":{"start":{"line":32,"column":2},"end":{"line":35,"column":3}},"18":{"start":{"line":33,"column":4},"end":{"line":33,"column":38}},"19":{"start":{"line":34,"column":4},"end":{"line":34,"column":14}},"20":{"start":{"line":38,"column":0},"end":{"line":44,"column":1}},"21":{"start":{"line":39,"column":2},"end":{"line":39,"column":12}},"22":{"start":{"line":40,"column":2},"end":{"line":40,"column":12}},"23":{"start":{"line":41,"column":2},"end":{"line":41,"column":12}},"24":{"start":{"line":42,"column":2},"end":{"line":42,"column":12}},"25":{"start":{"line":43,"column":2},"end":{"line":43,"column":11}},"26":{"start":{"line":46,"column":0},"end":{"line":65,"column":1}},"27":{"start":{"line":47,"column":2},"end":{"line":49,"column":68}},"28":{"start":{"line":49,"column":26},"end":{"line":49,"column":65}},"29":{"start":{"line":50,"column":2},"end":{"line":57,"column":4}},"30":{"start":{"line":51,"column":4},"end":{"line":55,"column":27}},"31":{"start":{"line":52,"column":6},"end":{"line":54,"column":43}},"32":{"start":{"line":56,"column":4},"end":{"line":56,"column":18}},"33":{"start":{"line":58,"column":2},"end":{"line":58,"column":23}},"34":{"start":{"line":59,"column":2},"end":{"line":59,"column":20}},"35":{"start":{"line":60,"column":2},"end":{"line":63,"column":3}},"36":{"start":{"line":61,"column":4},"end":{"line":61,"column":51}},"37":{"start":{"line":61,"column":35},"end":{"line":61,"column":51}},"38":{"start":{"line":62,"column":4},"end":{"line":62,"column":52}},"39":{"start":{"line":62,"column":30},"end":{"line":62,"column":50}},"40":{"start":{"line":64,"column":2},"end":{"line":64,"column":14}},"41":{"start":{"line":67,"column":0},"end":{"line":73,"column":1}},"42":{"start":{"line":68,"column":2},"end":{"line":68,"column":24}},"43":{"start":{"line":69,"column":7},"end":{"line":73,"column":1}},"44":{"start":{"line":70,"column":2},"end":{"line":70,"column":38}},"45":{"start":{"line":70,"column":22},"end":{"line":70,"column":34}},"46":{"start":{"line":72,"column":2},"end":{"line":72,"column":21}}},"branchMap":{"1":{"line":23,"type":"if","locations":[{"start":{"line":23,"column":2},"end":{"line":23,"column":2}},{"start":{"line":23,"column":2},"end":{"line":23,"column":2}}]},"2":{"line":48,"type":"binary-expr","locations":[{"start":{"line":48,"column":14},"end":{"line":48,"column":18}},{"start":{"line":48,"column":22},"end":{"line":48,"column":32}}]},"3":{"line":60,"type":"if","locations":[{"start":{"line":60,"column":2},"end":{"line":60,"column":2}},{"start":{"line":60,"column":2},"end":{"line":60,"column":2}}]},"4":{"line":61,"type":"if","locations":[{"start":{"line":61,"column":4},"end":{"line":61,"column":4}},{"start":{"line":61,"column":4},"end":{"line":61,"column":4}}]},"5":{"line":67,"type":"if","locations":[{"start":{"line":67,"column":0},"end":{"line":67,"column":0}},{"start":{"line":67,"column":0},"end":{"line":67,"column":0}}]},"6":{"line":67,"type":"binary-expr","locations":[{"start":{"line":67,"column":4},"end":{"line":67,"column":10}},{"start":{"line":67,"column":14},"end":{"line":67,"column":28}}]},"7":{"line":69,"type":"if","locations":[{"start":{"line":69,"column":7},"end":{"line":69,"column":7}},{"start":{"line":69,"column":7},"end":{"line":69,"column":7}}]},"8":{"line":69,"type":"binary-expr","locations":[{"start":{"line":69,"column":11},"end":{"line":69,"column":17}},{"start":{"line":69,"column":21},"end":{"line":69,"column":31}}]},"9":{"line":77,"type":"binary-expr","locations":[{"start":{"line":77,"column":2},"end":{"line":77,"column":29}},{"start":{"line":77,"column":33},"end":{"line":77,"column":39}}]},"10":{"line":78,"type":"binary-expr","locations":[{"start":{"line":78,"column":2},"end":{"line":78,"column":31}},{"start":{"line":78,"column":35},"end":{"line":78,"column":41}}]}}},"/home/davidbau/git/seedrandom/lib/xorwow.js":{"path":"/home/davidbau/git/seedrandom/lib/xorwow.js","s":{"1":1,"2":1,"3":3,"4":3,"5":4105327,"6":4105327,"7":4105327,"8":4105327,"9":4105327,"10":4105327,"11":3,"12":3,"13":3,"14":3,"15":3,"16":3,"17":2,"18":1,"19":3,"20":198,"21":198,"22":3,"23":198,"24":1,"25":2,"26":2,"27":2,"28":2,"29":2,"30":2,"31":2,"32":1,"33":3,"34":4102054,"35":3,"36":1025,"37":1025,"38":1025,"39":3,"40":3,"41":3,"42":2,"43":1,"44":2,"45":1,"46":3,"47":1,"48":1,"49":0,"50":0,"51":0,"52":0},"b":{"1":[2,1],"2":[3,195],"3":[3,2],"4":[2,1],"5":[1,1],"6":[1,0],"7":[1,1],"8":[0,0],"9":[0,0],"10":[1,1],"11":[1,0]},"f":{"1":1,"2":3,"3":4105327,"4":2,"5":3,"6":4102054,"7":1025,"8":1,"9":0},"fnMap":{"1":{"name":"(anonymous_1)","line":4,"loc":{"start":{"line":4,"column":1},"end":{"line":4,"column":34}}},"2":{"name":"XorGen","line":6,"loc":{"start":{"line":6,"column":0},"end":{"line":6,"column":22}}},"3":{"name":"(anonymous_3)","line":10,"loc":{"start":{"line":10,"column":12},"end":{"line":10,"column":23}}},"4":{"name":"copy","line":41,"loc":{"start":{"line":41,"column":0},"end":{"line":41,"column":20}}},"5":{"name":"impl","line":51,"loc":{"start":{"line":51,"column":0},"end":{"line":51,"column":26}}},"6":{"name":"(anonymous_6)","line":54,"loc":{"start":{"line":54,"column":13},"end":{"line":54,"column":24}}},"7":{"name":"(anonymous_7)","line":55,"loc":{"start":{"line":55,"column":16},"end":{"line":55,"column":27}}},"8":{"name":"(anonymous_8)","line":67,"loc":{"start":{"line":67,"column":17},"end":{"line":67,"column":28}}},"9":{"name":"(anonymous_9)","line":75,"loc":{"start":{"line":75,"column":9},"end":{"line":75,"column":20}}}},"statementMap":{"1":{"start":{"line":4,"column":0},"end":{"line":84,"column":2}},"2":{"start":{"line":6,"column":0},"end":{"line":39,"column":1}},"3":{"start":{"line":7,"column":2},"end":{"line":7,"column":30}},"4":{"start":{"line":10,"column":2},"end":{"line":15,"column":4}},"5":{"start":{"line":11,"column":4},"end":{"line":11,"column":34}},"6":{"start":{"line":12,"column":4},"end":{"line":12,"column":16}},"7":{"start":{"line":12,"column":17},"end":{"line":12,"column":29}},"8":{"start":{"line":12,"column":30},"end":{"line":12,"column":42}},"9":{"start":{"line":12,"column":43},"end":{"line":12,"column":55}},"10":{"start":{"line":13,"column":4},"end":{"line":14,"column":58}},"11":{"start":{"line":17,"column":2},"end":{"line":17,"column":11}},"12":{"start":{"line":18,"column":2},"end":{"line":18,"column":11}},"13":{"start":{"line":19,"column":2},"end":{"line":19,"column":11}},"14":{"start":{"line":20,"column":2},"end":{"line":20,"column":11}},"15":{"start":{"line":21,"column":2},"end":{"line":21,"column":11}},"16":{"start":{"line":23,"column":2},"end":{"line":29,"column":3}},"17":{"start":{"line":25,"column":4},"end":{"line":25,"column":16}},"18":{"start":{"line":28,"column":4},"end":{"line":28,"column":20}},"19":{"start":{"line":32,"column":2},"end":{"line":38,"column":3}},"20":{"start":{"line":33,"column":4},"end":{"line":33,"column":38}},"21":{"start":{"line":34,"column":4},"end":{"line":36,"column":5}},"22":{"start":{"line":35,"column":6},"end":{"line":35,"column":37}},"23":{"start":{"line":37,"column":4},"end":{"line":37,"column":14}},"24":{"start":{"line":41,"column":0},"end":{"line":49,"column":1}},"25":{"start":{"line":42,"column":2},"end":{"line":42,"column":12}},"26":{"start":{"line":43,"column":2},"end":{"line":43,"column":12}},"27":{"start":{"line":44,"column":2},"end":{"line":44,"column":12}},"28":{"start":{"line":45,"column":2},"end":{"line":45,"column":12}},"29":{"start":{"line":46,"column":2},"end":{"line":46,"column":12}},"30":{"start":{"line":47,"column":2},"end":{"line":47,"column":12}},"31":{"start":{"line":48,"column":2},"end":{"line":48,"column":11}},"32":{"start":{"line":51,"column":0},"end":{"line":70,"column":1}},"33":{"start":{"line":52,"column":2},"end":{"line":54,"column":68}},"34":{"start":{"line":54,"column":26},"end":{"line":54,"column":65}},"35":{"start":{"line":55,"column":2},"end":{"line":62,"column":4}},"36":{"start":{"line":56,"column":4},"end":{"line":60,"column":27}},"37":{"start":{"line":57,"column":6},"end":{"line":59,"column":43}},"38":{"start":{"line":61,"column":4},"end":{"line":61,"column":18}},"39":{"start":{"line":63,"column":2},"end":{"line":63,"column":23}},"40":{"start":{"line":64,"column":2},"end":{"line":64,"column":20}},"41":{"start":{"line":65,"column":2},"end":{"line":68,"column":3}},"42":{"start":{"line":66,"column":4},"end":{"line":66,"column":51}},"43":{"start":{"line":66,"column":35},"end":{"line":66,"column":51}},"44":{"start":{"line":67,"column":4},"end":{"line":67,"column":52}},"45":{"start":{"line":67,"column":30},"end":{"line":67,"column":50}},"46":{"start":{"line":69,"column":2},"end":{"line":69,"column":14}},"47":{"start":{"line":72,"column":0},"end":{"line":78,"column":1}},"48":{"start":{"line":73,"column":2},"end":{"line":73,"column":24}},"49":{"start":{"line":74,"column":7},"end":{"line":78,"column":1}},"50":{"start":{"line":75,"column":2},"end":{"line":75,"column":38}},"51":{"start":{"line":75,"column":22},"end":{"line":75,"column":34}},"52":{"start":{"line":77,"column":2},"end":{"line":77,"column":21}}},"branchMap":{"1":{"line":23,"type":"if","locations":[{"start":{"line":23,"column":2},"end":{"line":23,"column":2}},{"start":{"line":23,"column":2},"end":{"line":23,"column":2}}]},"2":{"line":34,"type":"if","locations":[{"start":{"line":34,"column":4},"end":{"line":34,"column":4}},{"start":{"line":34,"column":4},"end":{"line":34,"column":4}}]},"3":{"line":53,"type":"binary-expr","locations":[{"start":{"line":53,"column":14},"end":{"line":53,"column":18}},{"start":{"line":53,"column":22},"end":{"line":53,"column":32}}]},"4":{"line":65,"type":"if","locations":[{"start":{"line":65,"column":2},"end":{"line":65,"column":2}},{"start":{"line":65,"column":2},"end":{"line":65,"column":2}}]},"5":{"line":66,"type":"if","locations":[{"start":{"line":66,"column":4},"end":{"line":66,"column":4}},{"start":{"line":66,"column":4},"end":{"line":66,"column":4}}]},"6":{"line":72,"type":"if","locations":[{"start":{"line":72,"column":0},"end":{"line":72,"column":0}},{"start":{"line":72,"column":0},"end":{"line":72,"column":0}}]},"7":{"line":72,"type":"binary-expr","locations":[{"start":{"line":72,"column":4},"end":{"line":72,"column":10}},{"start":{"line":72,"column":14},"end":{"line":72,"column":28}}]},"8":{"line":74,"type":"if","locations":[{"start":{"line":74,"column":7},"end":{"line":74,"column":7}},{"start":{"line":74,"column":7},"end":{"line":74,"column":7}}]},"9":{"line":74,"type":"binary-expr","locations":[{"start":{"line":74,"column":11},"end":{"line":74,"column":17}},{"start":{"line":74,"column":21},"end":{"line":74,"column":31}}]},"10":{"line":82,"type":"binary-expr","locations":[{"start":{"line":82,"column":2},"end":{"line":82,"column":29}},{"start":{"line":82,"column":33},"end":{"line":82,"column":39}}]},"11":{"line":83,"type":"binary-expr","locations":[{"start":{"line":83,"column":2},"end":{"line":83,"column":31}},{"start":{"line":83,"column":35},"end":{"line":83,"column":41}}]}}},"/home/davidbau/git/seedrandom/lib/xorshift7.js":{"path":"/home/davidbau/git/seedrandom/lib/xorshift7.js","s":{"1":1,"2":1,"3":3,"4":3,"5":4105897,"6":4105897,"7":4105897,"8":4105897,"9":4105897,"10":4105897,"11":4105897,"12":4105897,"13":4105897,"14":4105897,"15":4105897,"16":4105897,"17":4105897,"18":4105897,"19":4105897,"20":4105897,"21":1,"22":3,"23":3,"24":2,"25":1,"26":1,"27":6,"28":3,"29":16,"30":3,"31":3,"32":2,"33":1,"34":3,"35":3,"36":3,"37":768,"38":3,"39":1,"40":2,"41":2,"42":2,"43":1,"44":3,"45":0,"46":3,"47":4102054,"48":3,"49":1025,"50":1025,"51":1025,"52":3,"53":3,"54":3,"55":2,"56":1,"57":2,"58":1,"59":3,"60":1,"61":1,"62":0,"63":0,"64":0,"65":0},"b":{"1":[2,1],"2":[19,17],"3":[2,1],"4":[0,3],"5":[3,2],"6":[2,1],"7":[1,1],"8":[1,0],"9":[1,1],"10":[0,0],"11":[0,0],"12":[1,1],"13":[1,0]},"f":{"1":1,"2":3,"3":4105897,"4":3,"5":2,"6":3,"7":4102054,"8":1025,"9":1,"10":0},"fnMap":{"1":{"name":"(anonymous_1)","line":6,"loc":{"start":{"line":6,"column":1},"end":{"line":6,"column":34}}},"2":{"name":"XorGen","line":8,"loc":{"start":{"line":8,"column":0},"end":{"line":8,"column":22}}},"3":{"name":"(anonymous_3)","line":12,"loc":{"start":{"line":12,"column":12},"end":{"line":12,"column":23}}},"4":{"name":"init","line":25,"loc":{"start":{"line":25,"column":2},"end":{"line":25,"column":26}}},"5":{"name":"copy","line":56,"loc":{"start":{"line":56,"column":0},"end":{"line":56,"column":20}}},"6":{"name":"impl","line":62,"loc":{"start":{"line":62,"column":0},"end":{"line":62,"column":26}}},"7":{"name":"(anonymous_7)","line":66,"loc":{"start":{"line":66,"column":13},"end":{"line":66,"column":24}}},"8":{"name":"(anonymous_8)","line":67,"loc":{"start":{"line":67,"column":16},"end":{"line":67,"column":27}}},"9":{"name":"(anonymous_9)","line":79,"loc":{"start":{"line":79,"column":17},"end":{"line":79,"column":28}}},"10":{"name":"(anonymous_10)","line":87,"loc":{"start":{"line":87,"column":9},"end":{"line":87,"column":20}}}},"statementMap":{"1":{"start":{"line":6,"column":0},"end":{"line":96,"column":2}},"2":{"start":{"line":8,"column":0},"end":{"line":54,"column":1}},"3":{"start":{"line":9,"column":2},"end":{"line":9,"column":16}},"4":{"start":{"line":12,"column":2},"end":{"line":23,"column":4}},"5":{"start":{"line":14,"column":4},"end":{"line":14,"column":36}},"6":{"start":{"line":15,"column":4},"end":{"line":15,"column":13}},"7":{"start":{"line":15,"column":14},"end":{"line":15,"column":29}},"8":{"start":{"line":15,"column":30},"end":{"line":15,"column":48}},"9":{"start":{"line":16,"column":4},"end":{"line":16,"column":23}},"10":{"start":{"line":16,"column":24},"end":{"line":16,"column":44}},"11":{"start":{"line":17,"column":4},"end":{"line":17,"column":23}},"12":{"start":{"line":17,"column":24},"end":{"line":17,"column":43}},"13":{"start":{"line":18,"column":4},"end":{"line":18,"column":23}},"14":{"start":{"line":18,"column":24},"end":{"line":18,"column":42}},"15":{"start":{"line":19,"column":4},"end":{"line":19,"column":23}},"16":{"start":{"line":19,"column":24},"end":{"line":19,"column":42}},"17":{"start":{"line":19,"column":43},"end":{"line":19,"column":61}},"18":{"start":{"line":20,"column":4},"end":{"line":20,"column":13}},"19":{"start":{"line":21,"column":4},"end":{"line":21,"column":23}},"20":{"start":{"line":22,"column":4},"end":{"line":22,"column":13}},"21":{"start":{"line":25,"column":2},"end":{"line":51,"column":3}},"22":{"start":{"line":26,"column":4},"end":{"line":26,"column":21}},"23":{"start":{"line":28,"column":4},"end":{"line":38,"column":5}},"24":{"start":{"line":30,"column":6},"end":{"line":30,"column":22}},"25":{"start":{"line":33,"column":6},"end":{"line":33,"column":23}},"26":{"start":{"line":34,"column":6},"end":{"line":37,"column":7}},"27":{"start":{"line":35,"column":8},"end":{"line":36,"column":56}},"28":{"start":{"line":40,"column":4},"end":{"line":40,"column":35}},"29":{"start":{"line":40,"column":25},"end":{"line":40,"column":35}},"30":{"start":{"line":41,"column":4},"end":{"line":41,"column":42}},"31":{"start":{"line":42,"column":4},"end":{"line":42,"column":45}},"32":{"start":{"line":42,"column":16},"end":{"line":42,"column":30}},"33":{"start":{"line":42,"column":36},"end":{"line":42,"column":45}},"34":{"start":{"line":44,"column":4},"end":{"line":44,"column":13}},"35":{"start":{"line":45,"column":4},"end":{"line":45,"column":13}},"36":{"start":{"line":48,"column":4},"end":{"line":50,"column":5}},"37":{"start":{"line":49,"column":6},"end":{"line":49,"column":16}},"38":{"start":{"line":53,"column":2},"end":{"line":53,"column":17}},"39":{"start":{"line":56,"column":0},"end":{"line":60,"column":1}},"40":{"start":{"line":57,"column":2},"end":{"line":57,"column":20}},"41":{"start":{"line":58,"column":2},"end":{"line":58,"column":12}},"42":{"start":{"line":59,"column":2},"end":{"line":59,"column":11}},"43":{"start":{"line":62,"column":0},"end":{"line":82,"column":1}},"44":{"start":{"line":63,"column":2},"end":{"line":63,"column":39}},"45":{"start":{"line":63,"column":20},"end":{"line":63,"column":39}},"46":{"start":{"line":64,"column":2},"end":{"line":66,"column":68}},"47":{"start":{"line":66,"column":26},"end":{"line":66,"column":65}},"48":{"start":{"line":67,"column":2},"end":{"line":74,"column":4}},"49":{"start":{"line":68,"column":4},"end":{"line":72,"column":27}},"50":{"start":{"line":69,"column":6},"end":{"line":71,"column":43}},"51":{"start":{"line":73,"column":4},"end":{"line":73,"column":18}},"52":{"start":{"line":75,"column":2},"end":{"line":75,"column":23}},"53":{"start":{"line":76,"column":2},"end":{"line":76,"column":20}},"54":{"start":{"line":77,"column":2},"end":{"line":80,"column":3}},"55":{"start":{"line":78,"column":4},"end":{"line":78,"column":33}},"56":{"start":{"line":78,"column":17},"end":{"line":78,"column":33}},"57":{"start":{"line":79,"column":4},"end":{"line":79,"column":52}},"58":{"start":{"line":79,"column":30},"end":{"line":79,"column":50}},"59":{"start":{"line":81,"column":2},"end":{"line":81,"column":14}},"60":{"start":{"line":84,"column":0},"end":{"line":90,"column":1}},"61":{"start":{"line":85,"column":2},"end":{"line":85,"column":24}},"62":{"start":{"line":86,"column":7},"end":{"line":90,"column":1}},"63":{"start":{"line":87,"column":2},"end":{"line":87,"column":38}},"64":{"start":{"line":87,"column":22},"end":{"line":87,"column":34}},"65":{"start":{"line":89,"column":2},"end":{"line":89,"column":24}}},"branchMap":{"1":{"line":28,"type":"if","locations":[{"start":{"line":28,"column":4},"end":{"line":28,"column":4}},{"start":{"line":28,"column":4},"end":{"line":28,"column":4}}]},"2":{"line":41,"type":"binary-expr","locations":[{"start":{"line":41,"column":16},"end":{"line":41,"column":21}},{"start":{"line":41,"column":25},"end":{"line":41,"column":35}}]},"3":{"line":42,"type":"if","locations":[{"start":{"line":42,"column":4},"end":{"line":42,"column":4}},{"start":{"line":42,"column":4},"end":{"line":42,"column":4}}]},"4":{"line":63,"type":"if","locations":[{"start":{"line":63,"column":2},"end":{"line":63,"column":2}},{"start":{"line":63,"column":2},"end":{"line":63,"column":2}}]},"5":{"line":65,"type":"binary-expr","locations":[{"start":{"line":65,"column":14},"end":{"line":65,"column":18}},{"start":{"line":65,"column":22},"end":{"line":65,"column":32}}]},"6":{"line":77,"type":"if","locations":[{"start":{"line":77,"column":2},"end":{"line":77,"column":2}},{"start":{"line":77,"column":2},"end":{"line":77,"column":2}}]},"7":{"line":78,"type":"if","locations":[{"start":{"line":78,"column":4},"end":{"line":78,"column":4}},{"start":{"line":78,"column":4},"end":{"line":78,"column":4}}]},"8":{"line":84,"type":"if","locations":[{"start":{"line":84,"column":0},"end":{"line":84,"column":0}},{"start":{"line":84,"column":0},"end":{"line":84,"column":0}}]},"9":{"line":84,"type":"binary-expr","locations":[{"start":{"line":84,"column":4},"end":{"line":84,"column":10}},{"start":{"line":84,"column":14},"end":{"line":84,"column":28}}]},"10":{"line":86,"type":"if","locations":[{"start":{"line":86,"column":7},"end":{"line":86,"column":7}},{"start":{"line":86,"column":7},"end":{"line":86,"column":7}}]},"11":{"line":86,"type":"binary-expr","locations":[{"start":{"line":86,"column":11},"end":{"line":86,"column":17}},{"start":{"line":86,"column":21},"end":{"line":86,"column":31}}]},"12":{"line":94,"type":"binary-expr","locations":[{"start":{"line":94,"column":2},"end":{"line":94,"column":29}},{"start":{"line":94,"column":33},"end":{"line":94,"column":39}}]},"13":{"line":95,"type":"binary-expr","locations":[{"start":{"line":95,"column":2},"end":{"line":95,"column":31}},{"start":{"line":95,"column":35},"end":{"line":95,"column":41}}]}}},"/home/davidbau/git/seedrandom/lib/xor4096.js":{"path":"/home/davidbau/git/seedrandom/lib/xor4096.js","s":{"1":1,"2":1,"3":3,"4":3,"5":4105129,"6":4105129,"7":4105129,"8":4105129,"9":4105129,"10":4105129,"11":4105129,"12":4105129,"13":4105129,"14":4105129,"15":4105129,"16":1,"17":3,"18":3,"19":2,"20":2,"21":1,"22":1,"23":1,"24":3,"25":480,"26":160,"27":480,"28":3,"29":480,"30":480,"31":480,"32":480,"33":480,"34":384,"35":384,"36":384,"37":3,"38":0,"39":3,"40":3,"41":1536,"42":1536,"43":1536,"44":1536,"45":1536,"46":1536,"47":1536,"48":3,"49":3,"50":3,"51":3,"52":1,"53":2,"54":2,"55":2,"56":2,"57":1,"58":3,"59":0,"60":3,"61":4102054,"62":3,"63":1025,"64":1025,"65":1025,"66":3,"67":3,"68":3,"69":2,"70":1,"71":2,"72":1,"73":3,"74":1,"75":1,"76":0,"77":0,"78":0,"79":0},"b":{"1":[2,1],"2":[160,320],"3":[3,477],"4":[384,96],"5":[0,384],"6":[0,3],"7":[0,0,0],"8":[0,3],"9":[3,2],"10":[2,1],"11":[1,1],"12":[1,0],"13":[1,1],"14":[0,0],"15":[0,0],"16":[1,1],"17":[1,0]},"f":{"1":1,"2":3,"3":4105129,"4":3,"5":2,"6":3,"7":4102054,"8":1025,"9":1,"10":0},"fnMap":{"1":{"name":"(anonymous_1)","line":26,"loc":{"start":{"line":26,"column":1},"end":{"line":26,"column":34}}},"2":{"name":"XorGen","line":28,"loc":{"start":{"line":28,"column":0},"end":{"line":28,"column":22}}},"3":{"name":"(anonymous_3)","line":32,"loc":{"start":{"line":32,"column":12},"end":{"line":32,"column":23}}},"4":{"name":"init","line":51,"loc":{"start":{"line":51,"column":2},"end":{"line":51,"column":26}}},"5":{"name":"copy","line":105,"loc":{"start":{"line":105,"column":0},"end":{"line":105,"column":20}}},"6":{"name":"impl","line":112,"loc":{"start":{"line":112,"column":0},"end":{"line":112,"column":26}}},"7":{"name":"(anonymous_7)","line":116,"loc":{"start":{"line":116,"column":13},"end":{"line":116,"column":24}}},"8":{"name":"(anonymous_8)","line":117,"loc":{"start":{"line":117,"column":16},"end":{"line":117,"column":27}}},"9":{"name":"(anonymous_9)","line":129,"loc":{"start":{"line":129,"column":17},"end":{"line":129,"column":28}}},"10":{"name":"(anonymous_10)","line":137,"loc":{"start":{"line":137,"column":9},"end":{"line":137,"column":20}}}},"statementMap":{"1":{"start":{"line":26,"column":0},"end":{"line":146,"column":2}},"2":{"start":{"line":28,"column":0},"end":{"line":103,"column":1}},"3":{"start":{"line":29,"column":2},"end":{"line":29,"column":16}},"4":{"start":{"line":32,"column":2},"end":{"line":49,"column":4}},"5":{"start":{"line":33,"column":4},"end":{"line":34,"column":33}},"6":{"start":{"line":36,"column":4},"end":{"line":36,"column":36}},"7":{"start":{"line":38,"column":4},"end":{"line":38,"column":26}},"8":{"start":{"line":39,"column":4},"end":{"line":39,"column":31}},"9":{"start":{"line":40,"column":4},"end":{"line":40,"column":17}},"10":{"start":{"line":41,"column":4},"end":{"line":41,"column":17}},"11":{"start":{"line":42,"column":4},"end":{"line":42,"column":18}},"12":{"start":{"line":43,"column":4},"end":{"line":43,"column":18}},"13":{"start":{"line":45,"column":4},"end":{"line":45,"column":21}},"14":{"start":{"line":46,"column":4},"end":{"line":46,"column":13}},"15":{"start":{"line":48,"column":4},"end":{"line":48,"column":38}},"16":{"start":{"line":51,"column":2},"end":{"line":100,"column":3}},"17":{"start":{"line":52,"column":4},"end":{"line":52,"column":43}},"18":{"start":{"line":53,"column":4},"end":{"line":62,"column":5}},"19":{"start":{"line":55,"column":6},"end":{"line":55,"column":15}},"20":{"start":{"line":56,"column":6},"end":{"line":56,"column":18}},"21":{"start":{"line":59,"column":6},"end":{"line":59,"column":25}},"22":{"start":{"line":60,"column":6},"end":{"line":60,"column":12}},"23":{"start":{"line":61,"column":6},"end":{"line":61,"column":43}},"24":{"start":{"line":64,"column":4},"end":{"line":78,"column":5}},"25":{"start":{"line":66,"column":6},"end":{"line":66,"column":61}},"26":{"start":{"line":66,"column":16},"end":{"line":66,"column":61}},"27":{"start":{"line":68,"column":6},"end":{"line":68,"column":25}},"28":{"start":{"line":68,"column":19},"end":{"line":68,"column":25}},"29":{"start":{"line":69,"column":6},"end":{"line":69,"column":19}},"30":{"start":{"line":70,"column":6},"end":{"line":70,"column":20}},"31":{"start":{"line":71,"column":6},"end":{"line":71,"column":18}},"32":{"start":{"line":72,"column":6},"end":{"line":72,"column":20}},"33":{"start":{"line":73,"column":6},"end":{"line":77,"column":7}},"34":{"start":{"line":74,"column":8},"end":{"line":74,"column":33}},"35":{"start":{"line":75,"column":8},"end":{"line":75,"column":36}},"36":{"start":{"line":76,"column":8},"end":{"line":76,"column":33}},"37":{"start":{"line":80,"column":4},"end":{"line":82,"column":5}},"38":{"start":{"line":81,"column":6},"end":{"line":81,"column":47}},"39":{"start":{"line":86,"column":4},"end":{"line":86,"column":12}},"40":{"start":{"line":87,"column":4},"end":{"line":95,"column":5}},"41":{"start":{"line":88,"column":6},"end":{"line":88,"column":28}},"42":{"start":{"line":89,"column":6},"end":{"line":89,"column":33}},"43":{"start":{"line":90,"column":6},"end":{"line":90,"column":19}},"44":{"start":{"line":91,"column":6},"end":{"line":91,"column":19}},"45":{"start":{"line":92,"column":6},"end":{"line":92,"column":20}},"46":{"start":{"line":93,"column":6},"end":{"line":93,"column":20}},"47":{"start":{"line":94,"column":6},"end":{"line":94,"column":19}},"48":{"start":{"line":97,"column":4},"end":{"line":97,"column":13}},"49":{"start":{"line":98,"column":4},"end":{"line":98,"column":13}},"50":{"start":{"line":99,"column":4},"end":{"line":99,"column":13}},"51":{"start":{"line":102,"column":2},"end":{"line":102,"column":17}},"52":{"start":{"line":105,"column":0},"end":{"line":110,"column":1}},"53":{"start":{"line":106,"column":2},"end":{"line":106,"column":12}},"54":{"start":{"line":107,"column":2},"end":{"line":107,"column":12}},"55":{"start":{"line":108,"column":2},"end":{"line":108,"column":20}},"56":{"start":{"line":109,"column":2},"end":{"line":109,"column":11}},"57":{"start":{"line":112,"column":0},"end":{"line":132,"column":1}},"58":{"start":{"line":113,"column":2},"end":{"line":113,"column":39}},"59":{"start":{"line":113,"column":20},"end":{"line":113,"column":39}},"60":{"start":{"line":114,"column":2},"end":{"line":116,"column":68}},"61":{"start":{"line":116,"column":26},"end":{"line":116,"column":65}},"62":{"start":{"line":117,"column":2},"end":{"line":124,"column":4}},"63":{"start":{"line":118,"column":4},"end":{"line":122,"column":27}},"64":{"start":{"line":119,"column":6},"end":{"line":121,"column":43}},"65":{"start":{"line":123,"column":4},"end":{"line":123,"column":18}},"66":{"start":{"line":125,"column":2},"end":{"line":125,"column":23}},"67":{"start":{"line":126,"column":2},"end":{"line":126,"column":20}},"68":{"start":{"line":127,"column":2},"end":{"line":130,"column":3}},"69":{"start":{"line":128,"column":4},"end":{"line":128,"column":33}},"70":{"start":{"line":128,"column":17},"end":{"line":128,"column":33}},"71":{"start":{"line":129,"column":4},"end":{"line":129,"column":52}},"72":{"start":{"line":129,"column":30},"end":{"line":129,"column":50}},"73":{"start":{"line":131,"column":2},"end":{"line":131,"column":14}},"74":{"start":{"line":134,"column":0},"end":{"line":140,"column":1}},"75":{"start":{"line":135,"column":2},"end":{"line":135,"column":24}},"76":{"start":{"line":136,"column":7},"end":{"line":140,"column":1}},"77":{"start":{"line":137,"column":2},"end":{"line":137,"column":38}},"78":{"start":{"line":137,"column":22},"end":{"line":137,"column":34}},"79":{"start":{"line":139,"column":2},"end":{"line":139,"column":22}}},"branchMap":{"1":{"line":53,"type":"if","locations":[{"start":{"line":53,"column":4},"end":{"line":53,"column":4}},{"start":{"line":53,"column":4},"end":{"line":53,"column":4}}]},"2":{"line":66,"type":"if","locations":[{"start":{"line":66,"column":6},"end":{"line":66,"column":6}},{"start":{"line":66,"column":6},"end":{"line":66,"column":6}}]},"3":{"line":68,"type":"if","locations":[{"start":{"line":68,"column":6},"end":{"line":68,"column":6}},{"start":{"line":68,"column":6},"end":{"line":68,"column":6}}]},"4":{"line":73,"type":"if","locations":[{"start":{"line":73,"column":6},"end":{"line":73,"column":6}},{"start":{"line":73,"column":6},"end":{"line":73,"column":6}}]},"5":{"line":76,"type":"cond-expr","locations":[{"start":{"line":76,"column":23},"end":{"line":76,"column":28}},{"start":{"line":76,"column":31},"end":{"line":76,"column":32}}]},"6":{"line":80,"type":"if","locations":[{"start":{"line":80,"column":4},"end":{"line":80,"column":4}},{"start":{"line":80,"column":4},"end":{"line":80,"column":4}}]},"7":{"line":81,"type":"binary-expr","locations":[{"start":{"line":81,"column":9},"end":{"line":81,"column":13}},{"start":{"line":81,"column":17},"end":{"line":81,"column":28}},{"start":{"line":81,"column":32},"end":{"line":81,"column":33}}]},"8":{"line":113,"type":"if","locations":[{"start":{"line":113,"column":2},"end":{"line":113,"column":2}},{"start":{"line":113,"column":2},"end":{"line":113,"column":2}}]},"9":{"line":115,"type":"binary-expr","locations":[{"start":{"line":115,"column":14},"end":{"line":115,"column":18}},{"start":{"line":115,"column":22},"end":{"line":115,"column":32}}]},"10":{"line":127,"type":"if","locations":[{"start":{"line":127,"column":2},"end":{"line":127,"column":2}},{"start":{"line":127,"column":2},"end":{"line":127,"column":2}}]},"11":{"line":128,"type":"if","locations":[{"start":{"line":128,"column":4},"end":{"line":128,"column":4}},{"start":{"line":128,"column":4},"end":{"line":128,"column":4}}]},"12":{"line":134,"type":"if","locations":[{"start":{"line":134,"column":0},"end":{"line":134,"column":0}},{"start":{"line":134,"column":0},"end":{"line":134,"column":0}}]},"13":{"line":134,"type":"binary-expr","locations":[{"start":{"line":134,"column":4},"end":{"line":134,"column":10}},{"start":{"line":134,"column":14},"end":{"line":134,"column":28}}]},"14":{"line":136,"type":"if","locations":[{"start":{"line":136,"column":7},"end":{"line":136,"column":7}},{"start":{"line":136,"column":7},"end":{"line":136,"column":7}}]},"15":{"line":136,"type":"binary-expr","locations":[{"start":{"line":136,"column":11},"end":{"line":136,"column":17}},{"start":{"line":136,"column":21},"end":{"line":136,"column":31}}]},"16":{"line":144,"type":"binary-expr","locations":[{"start":{"line":144,"column":2},"end":{"line":144,"column":29}},{"start":{"line":144,"column":33},"end":{"line":144,"column":39}}]},"17":{"line":145,"type":"binary-expr","locations":[{"start":{"line":145,"column":2},"end":{"line":145,"column":31}},{"start":{"line":145,"column":35},"end":{"line":145,"column":41}}]}}},"/home/davidbau/git/seedrandom/lib/tychei.js":{"path":"/home/davidbau/git/seedrandom/lib/tychei.js","s":{"1":1,"2":1,"3":3,"4":3,"5":4105195,"6":4105195,"7":4105195,"8":4105195,"9":4105195,"10":4105195,"11":4105195,"12":4105195,"13":4105195,"14":3,"15":3,"16":3,"17":3,"18":3,"19":2,"20":2,"21":1,"22":3,"23":66,"24":66,"25":1,"26":2,"27":2,"28":2,"29":2,"30":2,"31":1,"32":3,"33":4102054,"34":3,"35":1025,"36":1025,"37":1025,"38":3,"39":3,"40":3,"41":2,"42":1,"43":2,"44":1,"45":3,"46":1,"47":1,"48":0,"49":0,"50":0,"51":0},"b":{"1":[2,1],"2":[3,2],"3":[2,1],"4":[1,1],"5":[1,0],"6":[1,1],"7":[0,0],"8":[0,0],"9":[1,1],"10":[1,0]},"f":{"1":1,"2":3,"3":4105195,"4":2,"5":3,"6":4102054,"7":1025,"8":1,"9":0},"fnMap":{"1":{"name":"(anonymous_1)","line":5,"loc":{"start":{"line":5,"column":1},"end":{"line":5,"column":34}}},"2":{"name":"XorGen","line":7,"loc":{"start":{"line":7,"column":0},"end":{"line":7,"column":22}}},"3":{"name":"(anonymous_3)","line":11,"loc":{"start":{"line":11,"column":12},"end":{"line":11,"column":23}}},"4":{"name":"copy","line":60,"loc":{"start":{"line":60,"column":0},"end":{"line":60,"column":20}}},"5":{"name":"impl","line":68,"loc":{"start":{"line":68,"column":0},"end":{"line":68,"column":26}}},"6":{"name":"(anonymous_6)","line":71,"loc":{"start":{"line":71,"column":13},"end":{"line":71,"column":24}}},"7":{"name":"(anonymous_7)","line":72,"loc":{"start":{"line":72,"column":16},"end":{"line":72,"column":27}}},"8":{"name":"(anonymous_8)","line":84,"loc":{"start":{"line":84,"column":17},"end":{"line":84,"column":28}}},"9":{"name":"(anonymous_9)","line":92,"loc":{"start":{"line":92,"column":9},"end":{"line":92,"column":20}}}},"statementMap":{"1":{"start":{"line":5,"column":0},"end":{"line":101,"column":2}},"2":{"start":{"line":7,"column":0},"end":{"line":58,"column":1}},"3":{"start":{"line":8,"column":2},"end":{"line":8,"column":30}},"4":{"start":{"line":11,"column":2},"end":{"line":21,"column":4}},"5":{"start":{"line":12,"column":4},"end":{"line":12,"column":47}},"6":{"start":{"line":13,"column":4},"end":{"line":13,"column":34}},"7":{"start":{"line":14,"column":4},"end":{"line":14,"column":20}},"8":{"start":{"line":15,"column":4},"end":{"line":15,"column":34}},"9":{"start":{"line":16,"column":4},"end":{"line":16,"column":20}},"10":{"start":{"line":17,"column":4},"end":{"line":17,"column":42}},"11":{"start":{"line":18,"column":4},"end":{"line":18,"column":27}},"12":{"start":{"line":19,"column":4},"end":{"line":19,"column":38}},"13":{"start":{"line":20,"column":4},"end":{"line":20,"column":30}},"14":{"start":{"line":39,"column":2},"end":{"line":39,"column":11}},"15":{"start":{"line":40,"column":2},"end":{"line":40,"column":11}},"16":{"start":{"line":41,"column":2},"end":{"line":41,"column":24}},"17":{"start":{"line":42,"column":2},"end":{"line":42,"column":20}},"18":{"start":{"line":44,"column":2},"end":{"line":51,"column":3}},"19":{"start":{"line":46,"column":4},"end":{"line":46,"column":36}},"20":{"start":{"line":47,"column":4},"end":{"line":47,"column":20}},"21":{"start":{"line":50,"column":4},"end":{"line":50,"column":20}},"22":{"start":{"line":54,"column":2},"end":{"line":57,"column":3}},"23":{"start":{"line":55,"column":4},"end":{"line":55,"column":38}},"24":{"start":{"line":56,"column":4},"end":{"line":56,"column":14}},"25":{"start":{"line":60,"column":0},"end":{"line":66,"column":1}},"26":{"start":{"line":61,"column":2},"end":{"line":61,"column":12}},"27":{"start":{"line":62,"column":2},"end":{"line":62,"column":12}},"28":{"start":{"line":63,"column":2},"end":{"line":63,"column":12}},"29":{"start":{"line":64,"column":2},"end":{"line":64,"column":12}},"30":{"start":{"line":65,"column":2},"end":{"line":65,"column":11}},"31":{"start":{"line":68,"column":0},"end":{"line":87,"column":1}},"32":{"start":{"line":69,"column":2},"end":{"line":71,"column":68}},"33":{"start":{"line":71,"column":26},"end":{"line":71,"column":65}},"34":{"start":{"line":72,"column":2},"end":{"line":79,"column":4}},"35":{"start":{"line":73,"column":4},"end":{"line":77,"column":27}},"36":{"start":{"line":74,"column":6},"end":{"line":76,"column":43}},"37":{"start":{"line":78,"column":4},"end":{"line":78,"column":18}},"38":{"start":{"line":80,"column":2},"end":{"line":80,"column":23}},"39":{"start":{"line":81,"column":2},"end":{"line":81,"column":20}},"40":{"start":{"line":82,"column":2},"end":{"line":85,"column":3}},"41":{"start":{"line":83,"column":4},"end":{"line":83,"column":51}},"42":{"start":{"line":83,"column":35},"end":{"line":83,"column":51}},"43":{"start":{"line":84,"column":4},"end":{"line":84,"column":52}},"44":{"start":{"line":84,"column":30},"end":{"line":84,"column":50}},"45":{"start":{"line":86,"column":2},"end":{"line":86,"column":14}},"46":{"start":{"line":89,"column":0},"end":{"line":95,"column":1}},"47":{"start":{"line":90,"column":2},"end":{"line":90,"column":24}},"48":{"start":{"line":91,"column":7},"end":{"line":95,"column":1}},"49":{"start":{"line":92,"column":2},"end":{"line":92,"column":38}},"50":{"start":{"line":92,"column":22},"end":{"line":92,"column":34}},"51":{"start":{"line":94,"column":2},"end":{"line":94,"column":21}}},"branchMap":{"1":{"line":44,"type":"if","locations":[{"start":{"line":44,"column":2},"end":{"line":44,"column":2}},{"start":{"line":44,"column":2},"end":{"line":44,"column":2}}]},"2":{"line":70,"type":"binary-expr","locations":[{"start":{"line":70,"column":14},"end":{"line":70,"column":18}},{"start":{"line":70,"column":22},"end":{"line":70,"column":32}}]},"3":{"line":82,"type":"if","locations":[{"start":{"line":82,"column":2},"end":{"line":82,"column":2}},{"start":{"line":82,"column":2},"end":{"line":82,"column":2}}]},"4":{"line":83,"type":"if","locations":[{"start":{"line":83,"column":4},"end":{"line":83,"column":4}},{"start":{"line":83,"column":4},"end":{"line":83,"column":4}}]},"5":{"line":89,"type":"if","locations":[{"start":{"line":89,"column":0},"end":{"line":89,"column":0}},{"start":{"line":89,"column":0},"end":{"line":89,"column":0}}]},"6":{"line":89,"type":"binary-expr","locations":[{"start":{"line":89,"column":4},"end":{"line":89,"column":10}},{"start":{"line":89,"column":14},"end":{"line":89,"column":28}}]},"7":{"line":91,"type":"if","locations":[{"start":{"line":91,"column":7},"end":{"line":91,"column":7}},{"start":{"line":91,"column":7},"end":{"line":91,"column":7}}]},"8":{"line":91,"type":"binary-expr","locations":[{"start":{"line":91,"column":11},"end":{"line":91,"column":17}},{"start":{"line":91,"column":21},"end":{"line":91,"column":31}}]},"9":{"line":99,"type":"binary-expr","locations":[{"start":{"line":99,"column":2},"end":{"line":99,"column":29}},{"start":{"line":99,"column":33},"end":{"line":99,"column":39}}]},"10":{"line":100,"type":"binary-expr","locations":[{"start":{"line":100,"column":2},"end":{"line":100,"column":31}},{"start":{"line":100,"column":35},"end":{"line":100,"column":41}}]}}},"/home/davidbau/git/seedrandom/lib/alea.js":{"path":"/home/davidbau/git/seedrandom/lib/alea.js","s":{"1":1,"2":1,"3":3,"4":3,"5":4105129,"6":4105129,"7":4105129,"8":4105129,"9":3,"10":3,"11":3,"12":3,"13":3,"14":3,"15":1,"16":3,"17":3,"18":3,"19":3,"20":3,"21":0,"22":3,"23":1,"24":2,"25":2,"26":2,"27":2,"28":2,"29":1,"30":3,"31":3,"32":1025,"33":3,"34":1025,"35":3,"36":3,"37":2,"38":1,"39":2,"40":1,"41":3,"42":1,"43":3,"44":3,"45":18,"46":18,"47":33,"48":33,"49":33,"50":33,"51":33,"52":33,"53":33,"54":33,"55":18,"56":3,"57":1,"58":1,"59":0,"60":0,"61":0,"62":0},"b":{"1":[1,2],"2":[3,0],"3":[0,3],"4":[3,2],"5":[2,1],"6":[1,1],"7":[1,0],"8":[1,1],"9":[0,0],"10":[0,0],"11":[1,1],"12":[1,0]},"f":{"1":1,"2":3,"3":4105129,"4":2,"5":3,"6":1025,"7":1025,"8":1,"9":3,"10":18,"11":0},"fnMap":{"1":{"name":"(anonymous_1)","line":28,"loc":{"start":{"line":28,"column":1},"end":{"line":28,"column":34}}},"2":{"name":"Alea","line":30,"loc":{"start":{"line":30,"column":0},"end":{"line":30,"column":20}}},"3":{"name":"(anonymous_3)","line":33,"loc":{"start":{"line":33,"column":12},"end":{"line":33,"column":23}}},"4":{"name":"copy","line":54,"loc":{"start":{"line":54,"column":0},"end":{"line":54,"column":20}}},"5":{"name":"impl","line":62,"loc":{"start":{"line":62,"column":0},"end":{"line":62,"column":26}}},"6":{"name":"(anonymous_6)","line":66,"loc":{"start":{"line":66,"column":15},"end":{"line":66,"column":26}}},"7":{"name":"(anonymous_7)","line":67,"loc":{"start":{"line":67,"column":16},"end":{"line":67,"column":27}}},"8":{"name":"(anonymous_8)","line":73,"loc":{"start":{"line":73,"column":17},"end":{"line":73,"column":28}}},"9":{"name":"Mash","line":78,"loc":{"start":{"line":78,"column":0},"end":{"line":78,"column":16}}},"10":{"name":"(anonymous_10)","line":81,"loc":{"start":{"line":81,"column":13},"end":{"line":81,"column":28}}},"11":{"name":"(anonymous_11)","line":103,"loc":{"start":{"line":103,"column":9},"end":{"line":103,"column":20}}}},"statementMap":{"1":{"start":{"line":28,"column":0},"end":{"line":112,"column":2}},"2":{"start":{"line":30,"column":0},"end":{"line":52,"column":1}},"3":{"start":{"line":31,"column":2},"end":{"line":31,"column":31}},"4":{"start":{"line":33,"column":2},"end":{"line":38,"column":4}},"5":{"start":{"line":34,"column":4},"end":{"line":34,"column":60}},"6":{"start":{"line":35,"column":4},"end":{"line":35,"column":18}},"7":{"start":{"line":36,"column":4},"end":{"line":36,"column":18}},"8":{"start":{"line":37,"column":4},"end":{"line":37,"column":38}},"9":{"start":{"line":41,"column":2},"end":{"line":41,"column":11}},"10":{"start":{"line":42,"column":2},"end":{"line":42,"column":20}},"11":{"start":{"line":43,"column":2},"end":{"line":43,"column":20}},"12":{"start":{"line":44,"column":2},"end":{"line":44,"column":20}},"13":{"start":{"line":45,"column":2},"end":{"line":45,"column":22}},"14":{"start":{"line":46,"column":2},"end":{"line":46,"column":32}},"15":{"start":{"line":46,"column":19},"end":{"line":46,"column":30}},"16":{"start":{"line":47,"column":2},"end":{"line":47,"column":22}},"17":{"start":{"line":48,"column":2},"end":{"line":48,"column":32}},"18":{"start":{"line":48,"column":19},"end":{"line":48,"column":30}},"19":{"start":{"line":49,"column":2},"end":{"line":49,"column":22}},"20":{"start":{"line":50,"column":2},"end":{"line":50,"column":32}},"21":{"start":{"line":50,"column":19},"end":{"line":50,"column":30}},"22":{"start":{"line":51,"column":2},"end":{"line":51,"column":14}},"23":{"start":{"line":54,"column":0},"end":{"line":60,"column":1}},"24":{"start":{"line":55,"column":2},"end":{"line":55,"column":12}},"25":{"start":{"line":56,"column":2},"end":{"line":56,"column":14}},"26":{"start":{"line":57,"column":2},"end":{"line":57,"column":14}},"27":{"start":{"line":58,"column":2},"end":{"line":58,"column":14}},"28":{"start":{"line":59,"column":2},"end":{"line":59,"column":11}},"29":{"start":{"line":62,"column":0},"end":{"line":76,"column":1}},"30":{"start":{"line":63,"column":2},"end":{"line":65,"column":21}},"31":{"start":{"line":66,"column":2},"end":{"line":66,"column":67}},"32":{"start":{"line":66,"column":28},"end":{"line":66,"column":65}},"33":{"start":{"line":67,"column":2},"end":{"line":69,"column":4}},"34":{"start":{"line":68,"column":4},"end":{"line":68,"column":69}},"35":{"start":{"line":70,"column":2},"end":{"line":70,"column":20}},"36":{"start":{"line":71,"column":2},"end":{"line":74,"column":3}},"37":{"start":{"line":72,"column":4},"end":{"line":72,"column":51}},"38":{"start":{"line":72,"column":35},"end":{"line":72,"column":51}},"39":{"start":{"line":73,"column":4},"end":{"line":73,"column":52}},"40":{"start":{"line":73,"column":30},"end":{"line":73,"column":50}},"41":{"start":{"line":75,"column":2},"end":{"line":75,"column":14}},"42":{"start":{"line":78,"column":0},"end":{"line":97,"column":1}},"43":{"start":{"line":79,"column":2},"end":{"line":79,"column":21}},"44":{"start":{"line":81,"column":2},"end":{"line":94,"column":4}},"45":{"start":{"line":82,"column":4},"end":{"line":82,"column":24}},"46":{"start":{"line":83,"column":4},"end":{"line":92,"column":5}},"47":{"start":{"line":84,"column":6},"end":{"line":84,"column":30}},"48":{"start":{"line":85,"column":6},"end":{"line":85,"column":38}},"49":{"start":{"line":86,"column":6},"end":{"line":86,"column":18}},"50":{"start":{"line":87,"column":6},"end":{"line":87,"column":13}},"51":{"start":{"line":88,"column":6},"end":{"line":88,"column":13}},"52":{"start":{"line":89,"column":6},"end":{"line":89,"column":18}},"53":{"start":{"line":90,"column":6},"end":{"line":90,"column":13}},"54":{"start":{"line":91,"column":6},"end":{"line":91,"column":27}},"55":{"start":{"line":93,"column":4},"end":{"line":93,"column":46}},"56":{"start":{"line":96,"column":2},"end":{"line":96,"column":14}},"57":{"start":{"line":100,"column":0},"end":{"line":106,"column":1}},"58":{"start":{"line":101,"column":2},"end":{"line":101,"column":24}},"59":{"start":{"line":102,"column":7},"end":{"line":106,"column":1}},"60":{"start":{"line":103,"column":2},"end":{"line":103,"column":38}},"61":{"start":{"line":103,"column":22},"end":{"line":103,"column":34}},"62":{"start":{"line":105,"column":2},"end":{"line":105,"column":19}}},"branchMap":{"1":{"line":46,"type":"if","locations":[{"start":{"line":46,"column":2},"end":{"line":46,"column":2}},{"start":{"line":46,"column":2},"end":{"line":46,"column":2}}]},"2":{"line":48,"type":"if","locations":[{"start":{"line":48,"column":2},"end":{"line":48,"column":2}},{"start":{"line":48,"column":2},"end":{"line":48,"column":2}}]},"3":{"line":50,"type":"if","locations":[{"start":{"line":50,"column":2},"end":{"line":50,"column":2}},{"start":{"line":50,"column":2},"end":{"line":50,"column":2}}]},"4":{"line":64,"type":"binary-expr","locations":[{"start":{"line":64,"column":14},"end":{"line":64,"column":18}},{"start":{"line":64,"column":22},"end":{"line":64,"column":32}}]},"5":{"line":71,"type":"if","locations":[{"start":{"line":71,"column":2},"end":{"line":71,"column":2}},{"start":{"line":71,"column":2},"end":{"line":71,"column":2}}]},"6":{"line":72,"type":"if","locations":[{"start":{"line":72,"column":4},"end":{"line":72,"column":4}},{"start":{"line":72,"column":4},"end":{"line":72,"column":4}}]},"7":{"line":100,"type":"if","locations":[{"start":{"line":100,"column":0},"end":{"line":100,"column":0}},{"start":{"line":100,"column":0},"end":{"line":100,"column":0}}]},"8":{"line":100,"type":"binary-expr","locations":[{"start":{"line":100,"column":4},"end":{"line":100,"column":10}},{"start":{"line":100,"column":14},"end":{"line":100,"column":28}}]},"9":{"line":102,"type":"if","locations":[{"start":{"line":102,"column":7},"end":{"line":102,"column":7}},{"start":{"line":102,"column":7},"end":{"line":102,"column":7}}]},"10":{"line":102,"type":"binary-expr","locations":[{"start":{"line":102,"column":11},"end":{"line":102,"column":17}},{"start":{"line":102,"column":21},"end":{"line":102,"column":31}}]},"11":{"line":110,"type":"binary-expr","locations":[{"start":{"line":110,"column":2},"end":{"line":110,"column":29}},{"start":{"line":110,"column":33},"end":{"line":110,"column":39}}]},"12":{"line":111,"type":"binary-expr","locations":[{"start":{"line":111,"column":2},"end":{"line":111,"column":31}},{"start":{"line":111,"column":35},"end":{"line":111,"column":41}}]}}}} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/base.css b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/base.css new file mode 100644 index 0000000..f418035 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/base.css @@ -0,0 +1,224 @@ +body, html { + margin:0; padding: 0; + height: 100%; +} +body { + font-family: Helvetica Neue, Helvetica, Arial; + font-size: 14px; + color:#333; +} +.small { font-size: 12px; } +*, *:after, *:before { + -webkit-box-sizing:border-box; + -moz-box-sizing:border-box; + box-sizing:border-box; + } +h1 { font-size: 20px; margin: 0;} +h2 { font-size: 14px; } +pre { + font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace; + margin: 0; + padding: 0; + -moz-tab-size: 2; + -o-tab-size: 2; + tab-size: 2; +} +a { color:#0074D9; text-decoration:none; } +a:hover { text-decoration:underline; } +.strong { font-weight: bold; } +.space-top1 { padding: 10px 0 0 0; } +.pad2y { padding: 20px 0; } +.pad1y { padding: 10px 0; } +.pad2x { padding: 0 20px; } +.pad2 { padding: 20px; } +.pad1 { padding: 10px; } +.space-left2 { padding-left:55px; } +.space-right2 { padding-right:20px; } +.center { text-align:center; } +.clearfix { display:block; } +.clearfix:after { + content:''; + display:block; + height:0; + clear:both; + visibility:hidden; + } +.fl { float: left; } +@media only screen and (max-width:640px) { + .col3 { width:100%; max-width:100%; } + .hide-mobile { display:none!important; } +} + +.quiet { + color: #7f7f7f; + color: rgba(0,0,0,0.5); +} +.quiet a { opacity: 0.7; } + +.fraction { + font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace; + font-size: 10px; + color: #555; + background: #E8E8E8; + padding: 4px 5px; + border-radius: 3px; + vertical-align: middle; +} + +div.path a:link, div.path a:visited { color: #333; } +table.coverage { + border-collapse: collapse; + margin: 10px 0 0 0; + padding: 0; +} + +table.coverage td { + margin: 0; + padding: 0; + vertical-align: top; +} +table.coverage td.line-count { + text-align: right; + padding: 0 5px 0 20px; +} +table.coverage td.line-coverage { + text-align: right; + padding-right: 10px; + min-width:20px; +} + +table.coverage td span.cline-any { + display: inline-block; + padding: 0 5px; + width: 100%; +} +.missing-if-branch { + display: inline-block; + margin-right: 5px; + border-radius: 3px; + position: relative; + padding: 0 4px; + background: #333; + color: yellow; +} + +.skip-if-branch { + display: none; + margin-right: 10px; + position: relative; + padding: 0 4px; + background: #ccc; + color: white; +} +.missing-if-branch .typ, .skip-if-branch .typ { + color: inherit !important; +} +.coverage-summary { + border-collapse: collapse; + width: 100%; +} +.coverage-summary tr { border-bottom: 1px solid #bbb; } +.keyline-all { border: 1px solid #ddd; } +.coverage-summary td, .coverage-summary th { padding: 10px; } +.coverage-summary tbody { border: 1px solid #bbb; } +.coverage-summary td { border-right: 1px solid #bbb; } +.coverage-summary td:last-child { border-right: none; } +.coverage-summary th { + text-align: left; + font-weight: normal; + white-space: nowrap; +} +.coverage-summary th.file { border-right: none !important; } +.coverage-summary th.pct { } +.coverage-summary th.pic, +.coverage-summary th.abs, +.coverage-summary td.pct, +.coverage-summary td.abs { text-align: right; } +.coverage-summary td.file { white-space: nowrap; } +.coverage-summary td.pic { min-width: 120px !important; } +.coverage-summary tfoot td { } + +.coverage-summary .sorter { + height: 10px; + width: 7px; + display: inline-block; + margin-left: 0.5em; + background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent; +} +.coverage-summary .sorted .sorter { + background-position: 0 -20px; +} +.coverage-summary .sorted-desc .sorter { + background-position: 0 -10px; +} +.status-line { height: 10px; } +/* yellow */ +.cbranch-no { background: yellow !important; color: #111; } +/* dark red */ +.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 } +.low .chart { border:1px solid #C21F39 } +.highlighted, +.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{ + background: #C21F39 !important; +} +/* medium red */ +.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE } +/* light red */ +.low, .cline-no { background:#FCE1E5 } +/* light green */ +.high, .cline-yes { background:rgb(230,245,208) } +/* medium green */ +.cstat-yes { background:rgb(161,215,106) } +/* dark green */ +.status-line.high, .high .cover-fill { background:rgb(77,146,33) } +.high .chart { border:1px solid rgb(77,146,33) } +/* dark yellow (gold) */ +.status-line.medium, .medium .cover-fill { background: #f9cd0b; } +.medium .chart { border:1px solid #f9cd0b; } +/* light yellow */ +.medium { background: #fff4c2; } + +.cstat-skip { background: #ddd; color: #111; } +.fstat-skip { background: #ddd; color: #111 !important; } +.cbranch-skip { background: #ddd !important; color: #111; } + +span.cline-neutral { background: #eaeaea; } + +.coverage-summary td.empty { + opacity: .5; + padding-top: 4px; + padding-bottom: 4px; + line-height: 1; + color: #888; +} + +.cover-fill, .cover-empty { + display:inline-block; + height: 12px; +} +.chart { + line-height: 0; +} +.cover-empty { + background: white; +} +.cover-full { + border-right: none !important; +} +pre.prettyprint { + border: none !important; + padding: 0 !important; + margin: 0 !important; +} +.com { color: #999 !important; } +.ignore-none { color: #999; font-weight: normal; } + +.wrapper { + min-height: 100%; + height: auto !important; + height: 100%; + margin: 0 auto -48px; +} +.footer, .push { + height: 48px; +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/block-navigation.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/block-navigation.js new file mode 100644 index 0000000..c7ff5a5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/block-navigation.js @@ -0,0 +1,79 @@ +/* eslint-disable */ +var jumpToCode = (function init() { + // Classes of code we would like to highlight in the file view + var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no']; + + // Elements to highlight in the file listing view + var fileListingElements = ['td.pct.low']; + + // We don't want to select elements that are direct descendants of another match + var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > ` + + // Selecter that finds elements on the page to which we can jump + var selector = + fileListingElements.join(', ') + + ', ' + + notSelector + + missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b` + + // The NodeList of matching elements + var missingCoverageElements = document.querySelectorAll(selector); + + var currentIndex; + + function toggleClass(index) { + missingCoverageElements + .item(currentIndex) + .classList.remove('highlighted'); + missingCoverageElements.item(index).classList.add('highlighted'); + } + + function makeCurrent(index) { + toggleClass(index); + currentIndex = index; + missingCoverageElements.item(index).scrollIntoView({ + behavior: 'smooth', + block: 'center', + inline: 'center' + }); + } + + function goToPrevious() { + var nextIndex = 0; + if (typeof currentIndex !== 'number' || currentIndex === 0) { + nextIndex = missingCoverageElements.length - 1; + } else if (missingCoverageElements.length > 1) { + nextIndex = currentIndex - 1; + } + + makeCurrent(nextIndex); + } + + function goToNext() { + var nextIndex = 0; + + if ( + typeof currentIndex === 'number' && + currentIndex < missingCoverageElements.length - 1 + ) { + nextIndex = currentIndex + 1; + } + + makeCurrent(nextIndex); + } + + return function jump(event) { + switch (event.which) { + case 78: // n + case 74: // j + goToNext(); + break; + case 66: // b + case 75: // k + case 80: // p + goToPrevious(); + break; + } + }; +})(); +window.addEventListener('keydown', jumpToCode); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/index.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/index.html new file mode 100644 index 0000000..6109d95 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/index.html @@ -0,0 +1,110 @@ + + + + Code coverage report for All files + + + + + + + +
    +
    +

    + All files +

    +
    +
    + 93.21% + Statements + 439/471 +
    +
    + 73.2% + Branches + 142/194 +
    +
    + 90.41% + Functions + 66/73 +
    +
    + 94.44% + Lines + 374/396 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    FileStatementsBranchesFunctionsLines
    seedrandom
    96%96/10085.11%40/4793.33%14/1596.39%80/83
    seedrandom/lib
    92.45%343/37169.39%102/14789.66%52/5893.93%294/313
    +
    +
    +
    + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.css b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.css new file mode 100644 index 0000000..b317a7c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.css @@ -0,0 +1 @@ +.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.js new file mode 100644 index 0000000..b322523 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/prettify.js @@ -0,0 +1,2 @@ +/* eslint-disable */ +window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/index.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/index.html new file mode 100644 index 0000000..7c99c88 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/index.html @@ -0,0 +1,97 @@ + + + + Code coverage report for seedrandom + + + + + + + +
    +
    +

    + All files seedrandom +

    +
    +
    + 96% + Statements + 96/100 +
    +
    + 85.11% + Branches + 40/47 +
    +
    + 93.33% + Functions + 14/15 +
    +
    + 96.39% + Lines + 80/83 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    FileStatementsBranchesFunctionsLines
    seedrandom.js
    96%96/10085.11%40/4793.33%14/1596.39%80/83
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/alea.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/alea.js.html new file mode 100644 index 0000000..584d7c2 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/alea.js.html @@ -0,0 +1,411 @@ + + + + Code coverage report for seedrandom/lib/alea.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib alea.js +

    +
    +
    + 91.94% + Statements + 57/62 +
    +
    + 66.67% + Branches + 16/24 +
    +
    + 90.91% + Functions + 10/11 +
    +
    + 94.34% + Lines + 50/53 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104 +105 +106 +107 +108 +109 +110 +111 +112 +113 +114 +115  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +1x +  +  +3x +  +3x +4105129x +4105129x +4105129x +4105129x +  +  +  +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +3x +  +  +  +2x +2x +2x +2x +2x +  +  +  +3x +3x +3x +1025x +3x +1025x +  +3x +3x +2x +2x +  +3x +  +  +  +3x +  +3x +18x +18x +33x +33x +33x +33x +33x +33x +33x +33x +  +18x +  +  +3x +  +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  +  +  + 
    // A port of an algorithm by Johannes Baagøe <baagoe@baagoe.com>, 2010
    +// http://baagoe.com/en/RandomMusings/javascript/
    +// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror
    +// Original work is under MIT license -
    + 
    +// Copyright (C) 2010 by Johannes Baagøe <baagoe@baagoe.org>
    +//
    +// Permission is hereby granted, free of charge, to any person obtaining a copy
    +// of this software and associated documentation files (the "Software"), to deal
    +// in the Software without restriction, including without limitation the rights
    +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    +// copies of the Software, and to permit persons to whom the Software is
    +// furnished to do so, subject to the following conditions:
    +//
    +// The above copyright notice and this permission notice shall be included in
    +// all copies or substantial portions of the Software.
    +//
    +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    +// THE SOFTWARE.
    + 
    + 
    + 
    +(function(global, module, define) {
    + 
    +function Alea(seed) {
    +  var me = this, mash = Mash();
    + 
    +  me.next = function() {
    +    var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32
    +    me.s0 = me.s1;
    +    me.s1 = me.s2;
    +    return me.s2 = t - (me.c = t | 0);
    +  };
    + 
    +  // Apply the seeding algorithm from Baagoe.
    +  me.c = 1;
    +  me.s0 = mash(' ');
    +  me.s1 = mash(' ');
    +  me.s2 = mash(' ');
    +  me.s0 -= mash(seed);
    +  if (me.s0 < 0) { me.s0 += 1; }
    +  me.s1 -= mash(seed);
    +  Eif (me.s1 < 0) { me.s1 += 1; }
    +  me.s2 -= mash(seed);
    +  Iif (me.s2 < 0) { me.s2 += 1; }
    +  mash = null;
    +}
    + 
    +function copy(f, t) {
    +  t.c = f.c;
    +  t.s0 = f.s0;
    +  t.s1 = f.s1;
    +  t.s2 = f.s2;
    +  return t;
    +}
    + 
    +function impl(seed, opts) {
    +  var xg = new Alea(seed),
    +      state = opts && opts.state,
    +      prng = xg.next;
    +  prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }
    +  prng.double = function() {
    +    return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53
    +  };
    +  prng.quick = prng;
    +  if (state) {
    +    if (typeof(state) == 'object') copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +function Mash() {
    +  var n = 0xefc8249d;
    + 
    +  var mash = function(data) {
    +    data = String(data);
    +    for (var i = 0; i < data.length; i++) {
    +      n += data.charCodeAt(i);
    +      var h = 0.02519603282416938 * n;
    +      n = h >>> 0;
    +      h -= n;
    +      h *= n;
    +      n = h >>> 0;
    +      h -= n;
    +      n += h * 0x100000000; // 2^32
    +    }
    +    return (n >>> 0) * 2.3283064365386963e-10; // 2^-32
    +  };
    + 
    +  return mash;
    +}
    + 
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.alea = impl;
    +}
    + 
    +})(
    +  this,
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    + 
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/index.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/index.html new file mode 100644 index 0000000..4986a5b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/index.html @@ -0,0 +1,162 @@ + + + + Code coverage report for seedrandom/lib + + + + + + + +
    +
    +

    + All files seedrandom/lib +

    +
    +
    + 92.45% + Statements + 343/371 +
    +
    + 69.39% + Branches + 102/147 +
    +
    + 89.66% + Functions + 52/58 +
    +
    + 93.93% + Lines + 294/313 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    FileStatementsBranchesFunctionsLines
    alea.js
    91.94%57/6266.67%16/2490.91%10/1194.34%50/53
    tychei.js
    92.98%53/5770%14/2088.89%8/993.75%45/48
    xor128.js
    91.84%45/4970%14/2088.89%8/993.02%40/43
    xor4096.js
    92.68%76/8265.71%23/3590%9/1094.52%69/73
    xorshift7.js
    92.42%61/6673.08%19/2690%9/1094%47/50
    xorwow.js
    92.73%51/5572.73%16/2288.89%8/993.48%43/46
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/tychei.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/tychei.js.html new file mode 100644 index 0000000..29c3483 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/tychei.js.html @@ -0,0 +1,378 @@ + + + + Code coverage report for seedrandom/lib/tychei.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib tychei.js +

    +
    +
    + 92.98% + Statements + 53/57 +
    +
    + 70% + Branches + 14/20 +
    +
    + 88.89% + Functions + 8/9 +
    +
    + 93.75% + Lines + 45/48 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104  +  +  +  +1x +  +  +3x +  +  +3x +4105195x +4105195x +4105195x +4105195x +4105195x +4105195x +4105195x +4105195x +4105195x +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +3x +3x +3x +3x +  +3x +  +2x +2x +  +  +1x +  +  +  +3x +66x +66x +  +  +  +  +2x +2x +2x +2x +2x +  +  +  +3x +3x +4102054x +3x +1025x +1025x +1025x +1025x +  +1025x +  +3x +3x +3x +2x +2x +  +3x +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  +  +  + 
    // A Javascript implementaion of the "Tyche-i" prng algorithm by
    +// Samuel Neves and Filipe Araujo.
    +// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf
    + 
    +(function(global, module, define) {
    + 
    +function XorGen(seed) {
    +  var me = this, strseed = '';
    + 
    +  // Set up generator function.
    +  me.next = function() {
    +    var b = me.b, c = me.c, d = me.d, a = me.a;
    +    b = (b << 25) ^ (b >>> 7) ^ c;
    +    c = (c - d) | 0;
    +    d = (d << 24) ^ (d >>> 8) ^ a;
    +    a = (a - b) | 0;
    +    me.b = b = (b << 20) ^ (b >>> 12) ^ c;
    +    me.c = c = (c - d) | 0;
    +    me.d = (d << 16) ^ (c >>> 16) ^ a;
    +    return me.a = (a - b) | 0;
    +  };
    + 
    +  /* The following is non-inverted tyche, which has better internal
    +   * bit diffusion, but which is about 25% slower than tyche-i in JS.
    +  me.next = function() {
    +    var a = me.a, b = me.b, c = me.c, d = me.d;
    +    a = (me.a + me.b | 0) >>> 0;
    +    d = me.d ^ a; d = d << 16 ^ d >>> 16;
    +    c = me.c + d | 0;
    +    b = me.b ^ c; b = b << 12 ^ d >>> 20;
    +    me.a = a = a + b | 0;
    +    d = d ^ a; me.d = d = d << 8 ^ d >>> 24;
    +    me.c = c = c + d | 0;
    +    b = b ^ c;
    +    return me.b = (b << 7 ^ b >>> 25);
    +  }
    +  */
    + 
    +  me.a = 0;
    +  me.b = 0;
    +  me.c = 2654435769 | 0;
    +  me.d = 1367130551;
    + 
    +  if (seed === Math.floor(seed)) {
    +    // Integer seed.
    +    me.a = (seed / 0x100000000) | 0;
    +    me.b = seed | 0;
    +  } else {
    +    // String seed.
    +    strseed += seed;
    +  }
    + 
    +  // Mix in string seed, then discard an initial batch of 64 values.
    +  for (var k = 0; k < strseed.length + 20; k++) {
    +    me.b ^= strseed.charCodeAt(k) | 0;
    +    me.next();
    +  }
    +}
    + 
    +function copy(f, t) {
    +  t.a = f.a;
    +  t.b = f.b;
    +  t.c = f.c;
    +  t.d = f.d;
    +  return t;
    +};
    + 
    +function impl(seed, opts) {
    +  var xg = new XorGen(seed),
    +      state = opts && opts.state,
    +      prng = function() { return (xg.next() >>> 0) / 0x100000000; };
    +  prng.double = function() {
    +    do {
    +      var top = xg.next() >>> 11,
    +          bot = (xg.next() >>> 0) / 0x100000000,
    +          result = (top + bot) / (1 << 21);
    +    } while (result === 0);
    +    return result;
    +  };
    +  prng.int32 = xg.next;
    +  prng.quick = prng;
    +  if (state) {
    +    if (typeof(state) == 'object') copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.tychei = impl;
    +}
    + 
    +})(
    +  this,
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    + 
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor128.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor128.js.html new file mode 100644 index 0000000..77ec76f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor128.js.html @@ -0,0 +1,312 @@ + + + + Code coverage report for seedrandom/lib/xor128.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib xor128.js +

    +
    +
    + 91.84% + Statements + 45/49 +
    +
    + 70% + Branches + 14/20 +
    +
    + 88.89% + Functions + 8/9 +
    +
    + 93.02% + Lines + 40/43 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82  +  +  +1x +  +  +3x +  +3x +3x +3x +3x +  +  +3x +4105327x +4105327x +4105327x +4105327x +4105327x +  +  +3x +  +2x +  +  +1x +  +  +  +3x +198x +198x +  +  +  +  +2x +2x +2x +2x +2x +  +  +  +3x +3x +4102054x +3x +1025x +1025x +1025x +1025x +  +1025x +  +3x +3x +3x +2x +2x +  +3x +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  +  +  + 
    // A Javascript implementaion of the "xor128" prng algorithm by
    +// George Marsaglia.  See http://www.jstatsoft.org/v08/i14/paper
    + 
    +(function(global, module, define) {
    + 
    +function XorGen(seed) {
    +  var me = this, strseed = '';
    + 
    +  me.x = 0;
    +  me.y = 0;
    +  me.z = 0;
    +  me.w = 0;
    + 
    +  // Set up generator function.
    +  me.next = function() {
    +    var t = me.x ^ (me.x << 11);
    +    me.x = me.y;
    +    me.y = me.z;
    +    me.z = me.w;
    +    return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);
    +  };
    + 
    +  if (seed === (seed | 0)) {
    +    // Integer seed.
    +    me.x = seed;
    +  } else {
    +    // String seed.
    +    strseed += seed;
    +  }
    + 
    +  // Mix in string seed, then discard an initial batch of 64 values.
    +  for (var k = 0; k < strseed.length + 64; k++) {
    +    me.x ^= strseed.charCodeAt(k) | 0;
    +    me.next();
    +  }
    +}
    + 
    +function copy(f, t) {
    +  t.x = f.x;
    +  t.y = f.y;
    +  t.z = f.z;
    +  t.w = f.w;
    +  return t;
    +}
    + 
    +function impl(seed, opts) {
    +  var xg = new XorGen(seed),
    +      state = opts && opts.state,
    +      prng = function() { return (xg.next() >>> 0) / 0x100000000; };
    +  prng.double = function() {
    +    do {
    +      var top = xg.next() >>> 11,
    +          bot = (xg.next() >>> 0) / 0x100000000,
    +          result = (top + bot) / (1 << 21);
    +    } while (result === 0);
    +    return result;
    +  };
    +  prng.int32 = xg.next;
    +  prng.quick = prng;
    +  if (state) {
    +    if (typeof(state) == 'object') copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.xor128 = impl;
    +}
    + 
    +})(
    +  this,
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    + 
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor4096.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor4096.js.html new file mode 100644 index 0000000..a9b085b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xor4096.js.html @@ -0,0 +1,507 @@ + + + + Code coverage report for seedrandom/lib/xor4096.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib xor4096.js +

    +
    +
    + 92.68% + Statements + 76/82 +
    +
    + 65.71% + Branches + 23/35 +
    +
    + 90% + Functions + 9/10 +
    +
    + 94.52% + Lines + 69/73 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104 +105 +106 +107 +108 +109 +110 +111 +112 +113 +114 +115 +116 +117 +118 +119 +120 +121 +122 +123 +124 +125 +126 +127 +128 +129 +130 +131 +132 +133 +134 +135 +136 +137 +138 +139 +140 +141 +142 +143 +144 +145 +146 +147  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +1x +  +  +3x +  +  +3x +4105129x +4105129x +  +4105129x +  +4105129x +4105129x +4105129x +4105129x +4105129x +4105129x +  +4105129x +4105129x +  +4105129x +  +  +  +3x +3x +  +2x +2x +  +  +1x +1x +1x +  +  +3x +  +480x +  +480x +480x +480x +480x +480x +480x +384x +384x +384x +  +  +  +3x +  +  +  +  +  +3x +3x +1536x +1536x +1536x +1536x +1536x +1536x +1536x +  +  +3x +3x +3x +  +  +3x +  +  +  +2x +2x +2x +2x +  +  +  +3x +3x +3x +4102054x +3x +1025x +1025x +1025x +1025x +  +1025x +  +3x +3x +3x +2x +2x +  +3x +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  + 
    // A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.
    +//
    +// This fast non-cryptographic random number generator is designed for
    +// use in Monte-Carlo algorithms. It combines a long-period xorshift
    +// generator with a Weyl generator, and it passes all common batteries
    +// of stasticial tests for randomness while consuming only a few nanoseconds
    +// for each prng generated.  For background on the generator, see Brent's
    +// paper: "Some long-period random number generators using shifts and xors."
    +// http://arxiv.org/pdf/1004.3115v1.pdf
    +//
    +// Usage:
    +//
    +// var xor4096 = require('xor4096');
    +// random = xor4096(1);                        // Seed with int32 or string.
    +// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.
    +// assert.equal(random.int32(), 1806534897);   // signed int32, 32 bits.
    +//
    +// For nonzero numeric keys, this impelementation provides a sequence
    +// identical to that by Brent's xorgens 3 implementaion in C.  This
    +// implementation also provides for initalizing the generator with
    +// string seeds, or for saving and restoring the state of the generator.
    +//
    +// On Chrome, this prng benchmarks about 2.1 times slower than
    +// Javascript's built-in Math.random().
    + 
    +(function(global, module, define) {
    + 
    +function XorGen(seed) {
    +  var me = this;
    + 
    +  // Set up generator function.
    +  me.next = function() {
    +    var w = me.w,
    +        X = me.X, i = me.i, t, v;
    +    // Update Weyl generator.
    +    me.w = w = (w + 0x61c88647) | 0;
    +    // Update xor generator.
    +    v = X[(i + 34) & 127];
    +    t = X[i = ((i + 1) & 127)];
    +    v ^= v << 13;
    +    t ^= t << 17;
    +    v ^= v >>> 15;
    +    t ^= t >>> 12;
    +    // Update Xor generator array state.
    +    v = X[i] = v ^ t;
    +    me.i = i;
    +    // Result is the combination.
    +    return (v + (w ^ (w >>> 16))) | 0;
    +  };
    + 
    +  function init(me, seed) {
    +    var t, v, i, j, w, X = [], limit = 128;
    +    if (seed === (seed | 0)) {
    +      // Numeric seeds initialize v, which is used to generates X.
    +      v = seed;
    +      seed = null;
    +    } else {
    +      // String seeds are mixed into v and X one character at a time.
    +      seed = seed + '\0';
    +      v = 0;
    +      limit = Math.max(limit, seed.length);
    +    }
    +    // Initialize circular array and weyl value.
    +    for (i = 0, j = -32; j < limit; ++j) {
    +      // Put the unicode characters into the array, and shuffle them.
    +      if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);
    +      // After 32 shuffles, take v as the starting w value.
    +      if (j === 0) w = v;
    +      v ^= v << 10;
    +      v ^= v >>> 15;
    +      v ^= v << 4;
    +      v ^= v >>> 13;
    +      if (j >= 0) {
    +        w = (w + 0x61c88647) | 0;     // Weyl.
    +        t = (X[j & 127] ^= (v + w));  // Combine xor and weyl to init array.
    +        i = (0 == t) ? i + 1 : 0;     // Count zeroes.
    +      }
    +    }
    +    // We have detected all zeroes; make the key nonzero.
    +    Iif (i >= 128) {
    +      X[(seed && seed.length || 0) & 127] = -1;
    +    }
    +    // Run the generator 512 times to further mix the state before using it.
    +    // Factoring this as a function slows the main generator, so it is just
    +    // unrolled here.  The weyl generator is not advanced while warming up.
    +    i = 127;
    +    for (j = 4 * 128; j > 0; --j) {
    +      v = X[(i + 34) & 127];
    +      t = X[i = ((i + 1) & 127)];
    +      v ^= v << 13;
    +      t ^= t << 17;
    +      v ^= v >>> 15;
    +      t ^= t >>> 12;
    +      X[i] = v ^ t;
    +    }
    +    // Storing state as object members is faster than using closure variables.
    +    me.w = w;
    +    me.X = X;
    +    me.i = i;
    +  }
    + 
    +  init(me, seed);
    +}
    + 
    +function copy(f, t) {
    +  t.i = f.i;
    +  t.w = f.w;
    +  t.X = f.X.slice();
    +  return t;
    +};
    + 
    +function impl(seed, opts) {
    +  Iif (seed == null) seed = +(new Date);
    +  var xg = new XorGen(seed),
    +      state = opts && opts.state,
    +      prng = function() { return (xg.next() >>> 0) / 0x100000000; };
    +  prng.double = function() {
    +    do {
    +      var top = xg.next() >>> 11,
    +          bot = (xg.next() >>> 0) / 0x100000000,
    +          result = (top + bot) / (1 << 21);
    +    } while (result === 0);
    +    return result;
    +  };
    +  prng.int32 = xg.next;
    +  prng.quick = prng;
    +  if (state) {
    +    if (state.X) copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.xor4096 = impl;
    +}
    + 
    +})(
    +  this,                                     // window object or global
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorshift7.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorshift7.js.html new file mode 100644 index 0000000..e50230c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorshift7.js.html @@ -0,0 +1,360 @@ + + + + Code coverage report for seedrandom/lib/xorshift7.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib xorshift7.js +

    +
    +
    + 92.42% + Statements + 61/66 +
    +
    + 73.08% + Branches + 19/26 +
    +
    + 90% + Functions + 9/10 +
    +
    + 94% + Lines + 47/50 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98  +  +  +  +  +1x +  +  +3x +  +  +3x +  +4105897x +4105897x +4105897x +4105897x +4105897x +4105897x +4105897x +4105897x +4105897x +  +  +  +3x +  +3x +  +2x +  +  +1x +1x +6x +  +  +  +  +16x +3x +3x +  +3x +3x +  +  +3x +768x +  +  +  +3x +  +  +  +2x +2x +2x +  +  +  +3x +3x +3x +4102054x +3x +1025x +1025x +1025x +1025x +  +1025x +  +3x +3x +3x +2x +2x +  +3x +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  +  + 
    // A Javascript implementaion of the "xorshift7" algorithm by
    +// François Panneton and Pierre L'ecuyer:
    +// "On the Xorgshift Random Number Generators"
    +// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf
    + 
    +(function(global, module, define) {
    + 
    +function XorGen(seed) {
    +  var me = this;
    + 
    +  // Set up generator function.
    +  me.next = function() {
    +    // Update xor generator.
    +    var X = me.x, i = me.i, t, v, w;
    +    t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);
    +    t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);
    +    t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);
    +    t = X[(i + 4) & 7]; v ^= t ^ (t << 7);
    +    t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);
    +    X[i] = v;
    +    me.i = (i + 1) & 7;
    +    return v;
    +  };
    + 
    +  function init(me, seed) {
    +    var j, w, X = [];
    + 
    +    if (seed === (seed | 0)) {
    +      // Seed state array using a 32-bit integer.
    +      w = X[0] = seed;
    +    } else {
    +      // Seed state using a string.
    +      seed = '' + seed;
    +      for (j = 0; j < seed.length; ++j) {
    +        X[j & 7] = (X[j & 7] << 15) ^
    +            (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);
    +      }
    +    }
    +    // Enforce an array length of 8, not all zeroes.
    +    while (X.length < 8) X.push(0);
    +    for (j = 0; j < 8 && X[j] === 0; ++j);
    +    if (j == 8) w = X[7] = -1; else w = X[j];
    + 
    +    me.x = X;
    +    me.i = 0;
    + 
    +    // Discard an initial 256 values.
    +    for (j = 256; j > 0; --j) {
    +      me.next();
    +    }
    +  }
    + 
    +  init(me, seed);
    +}
    + 
    +function copy(f, t) {
    +  t.x = f.x.slice();
    +  t.i = f.i;
    +  return t;
    +}
    + 
    +function impl(seed, opts) {
    +  Iif (seed == null) seed = +(new Date);
    +  var xg = new XorGen(seed),
    +      state = opts && opts.state,
    +      prng = function() { return (xg.next() >>> 0) / 0x100000000; };
    +  prng.double = function() {
    +    do {
    +      var top = xg.next() >>> 11,
    +          bot = (xg.next() >>> 0) / 0x100000000,
    +          result = (top + bot) / (1 << 21);
    +    } while (result === 0);
    +    return result;
    +  };
    +  prng.int32 = xg.next;
    +  prng.quick = prng;
    +  if (state) {
    +    if (state.x) copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.xorshift7 = impl;
    +}
    + 
    +})(
    +  this,
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorwow.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorwow.js.html new file mode 100644 index 0000000..3c8d5a7 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/lib/xorwow.js.html @@ -0,0 +1,327 @@ + + + + Code coverage report for seedrandom/lib/xorwow.js + + + + + + + +
    +
    +

    + All files / seedrandom/lib xorwow.js +

    +
    +
    + 92.73% + Statements + 51/55 +
    +
    + 72.73% + Branches + 16/22 +
    +
    + 88.89% + Functions + 8/9 +
    +
    + 93.48% + Lines + 43/46 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87  +  +  +1x +  +  +3x +  +  +3x +4105327x +4105327x +4105327x +  +  +  +3x +3x +3x +3x +3x +  +3x +  +2x +  +  +1x +  +  +  +3x +198x +198x +3x +  +198x +  +  +  +  +2x +2x +2x +2x +2x +2x +2x +  +  +  +3x +3x +4102054x +3x +1025x +1025x +1025x +1025x +  +1025x +  +3x +3x +3x +2x +2x +  +3x +  +  +1x +1x +  +  +  +  +  +  +  +  +  +  +  +  +  + 
    // A Javascript implementaion of the "xorwow" prng algorithm by
    +// George Marsaglia.  See http://www.jstatsoft.org/v08/i14/paper
    + 
    +(function(global, module, define) {
    + 
    +function XorGen(seed) {
    +  var me = this, strseed = '';
    + 
    +  // Set up generator function.
    +  me.next = function() {
    +    var t = (me.x ^ (me.x >>> 2));
    +    me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;
    +    return (me.d = (me.d + 362437 | 0)) +
    +       (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;
    +  };
    + 
    +  me.x = 0;
    +  me.y = 0;
    +  me.z = 0;
    +  me.w = 0;
    +  me.v = 0;
    + 
    +  if (seed === (seed | 0)) {
    +    // Integer seed.
    +    me.x = seed;
    +  } else {
    +    // String seed.
    +    strseed += seed;
    +  }
    + 
    +  // Mix in string seed, then discard an initial batch of 64 values.
    +  for (var k = 0; k < strseed.length + 64; k++) {
    +    me.x ^= strseed.charCodeAt(k) | 0;
    +    if (k == strseed.length) {
    +      me.d = me.x << 10 ^ me.x >>> 4;
    +    }
    +    me.next();
    +  }
    +}
    + 
    +function copy(f, t) {
    +  t.x = f.x;
    +  t.y = f.y;
    +  t.z = f.z;
    +  t.w = f.w;
    +  t.v = f.v;
    +  t.d = f.d;
    +  return t;
    +}
    + 
    +function impl(seed, opts) {
    +  var xg = new XorGen(seed),
    +      state = opts && opts.state,
    +      prng = function() { return (xg.next() >>> 0) / 0x100000000; };
    +  prng.double = function() {
    +    do {
    +      var top = xg.next() >>> 11,
    +          bot = (xg.next() >>> 0) / 0x100000000,
    +          result = (top + bot) / (1 << 21);
    +    } while (result === 0);
    +    return result;
    +  };
    +  prng.int32 = xg.next;
    +  prng.quick = prng;
    +  if (state) {
    +    if (typeof(state) == 'object') copy(state, xg);
    +    prng.state = function() { return copy(xg, {}); }
    +  }
    +  return prng;
    +}
    + 
    +Eif (module && module.exports) {
    +  module.exports = impl;
    +} else if (define && define.amd) {
    +  define(function() { return impl; });
    +} else {
    +  this.xorwow = impl;
    +}
    + 
    +})(
    +  this,
    +  (typeof module) == 'object' && module,    // present in node.js
    +  (typeof define) == 'function' && define   // present with an AMD loader
    +);
    + 
    + 
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/seedrandom.js.html b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/seedrandom.js.html new file mode 100644 index 0000000..ca72564 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/seedrandom/seedrandom.js.html @@ -0,0 +1,828 @@ + + + + Code coverage report for seedrandom/seedrandom.js + + + + + + + +
    +
    +

    + All files / seedrandom seedrandom.js +

    +
    +
    + 96% + Statements + 96/100 +
    +
    + 85.11% + Branches + 40/47 +
    +
    + 93.33% + Functions + 14/15 +
    +
    + 96.39% + Lines + 80/83 +
    +
    +

    + Press n or j to go to the next uncovered block, b, p or k for the previous block. +

    +
    +
    +
    
    +
    +
    1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +80 +81 +82 +83 +84 +85 +86 +87 +88 +89 +90 +91 +92 +93 +94 +95 +96 +97 +98 +99 +100 +101 +102 +103 +104 +105 +106 +107 +108 +109 +110 +111 +112 +113 +114 +115 +116 +117 +118 +119 +120 +121 +122 +123 +124 +125 +126 +127 +128 +129 +130 +131 +132 +133 +134 +135 +136 +137 +138 +139 +140 +141 +142 +143 +144 +145 +146 +147 +148 +149 +150 +151 +152 +153 +154 +155 +156 +157 +158 +159 +160 +161 +162 +163 +164 +165 +166 +167 +168 +169 +170 +171 +172 +173 +174 +175 +176 +177 +178 +179 +180 +181 +182 +183 +184 +185 +186 +187 +188 +189 +190 +191 +192 +193 +194 +195 +196 +197 +198 +199 +200 +201 +202 +203 +204 +205 +206 +207 +208 +209 +210 +211 +212 +213 +214 +215 +216 +217 +218 +219 +220 +221 +222 +223 +224 +225 +226 +227 +228 +229 +230 +231 +232 +233 +234 +235 +236 +237 +238 +239 +240 +241 +242 +243 +244 +245 +246 +247 +248 +249 +250 +251 +252 +253 +254  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +6x +  +  +  +  +6x +6x +6x +6x +6x +6x +6x +6x +  +  +  +  +  +  +  +23x +23x +  +  +23x +  +  +  +  +23x +  +  +  +23x +3694x +3694x +3694x +3694x +3917x +3917x +3917x +  +3694x +9249x +9249x +9249x +  +3694x +  +  +1025x +4100001x +23x +  +  +23x +  +  +23x +  +20x +  +4x +  +4x +  +  +  +  +20x +  +  +  +19x +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +23x +23x +  +  +23x +  +  +23x +5888x +  +23x +5888x +5888x +  +  +  +23x +  +4108660x +4108660x +4108660x +16436073x +16436073x +  +4108660x +4108660x +  +  +  +  +  +  +  +  +  +  +  +4x +4x +4x +4x +  +  +  +  +  +  +  +32x +32x +4x +9x +  +  +32x +  +  +  +  +  +  +  +  +52x +52x +7735x +  +  +52x +  +  +  +  +  +  +  +  +4x +  +4x +  +3x +  +1x +1x +  +3x +  +1x +1x +1x +  +  +  +  +  +  +  +  +81x +  +  +  +  +  +  +  +  +  +6x +  +  +  +  +  +6x +6x +  +6x +6x +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  +  + 
    /*
    +Copyright 2019 David Bau.
    + 
    +Permission is hereby granted, free of charge, to any person obtaining
    +a copy of this software and associated documentation files (the
    +"Software"), to deal in the Software without restriction, including
    +without limitation the rights to use, copy, modify, merge, publish,
    +distribute, sublicense, and/or sell copies of the Software, and to
    +permit persons to whom the Software is furnished to do so, subject to
    +the following conditions:
    + 
    +The above copyright notice and this permission notice shall be
    +included in all copies or substantial portions of the Software.
    + 
    +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
    +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
    +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
    +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
    +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
    +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
    +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
    + 
    +*/
    + 
    +(function (global, pool, math) {
    +//
    +// The following constants are related to IEEE 754 limits.
    +//
    + 
    +var width = 256,        // each RC4 output is 0 <= x < 256
    +    chunks = 6,         // at least six RC4 outputs for each double
    +    digits = 52,        // there are 52 significant digits in a double
    +    rngname = 'random', // rngname: name for Math.random and Math.seedrandom
    +    startdenom = math.pow(width, chunks),
    +    significance = math.pow(2, digits),
    +    overflow = significance * 2,
    +    mask = width - 1,
    +    nodecrypto;         // node.js crypto module, initialized at the bottom.
    + 
    +//
    +// seedrandom()
    +// This is the seedrandom function described above.
    +//
    +function seedrandom(seed, options, callback) {
    +  var key = [];
    +  options = (options == true) ? { entropy: true } : (options || {});
    + 
    +  // Flatten the seed string or build one from local entropy if needed.
    +  var shortseed = mixkey(flatten(
    +    options.entropy ? [seed, tostring(pool)] :
    +    (seed == null) ? autoseed() : seed, 3), key);
    + 
    +  // Use the seed to initialize an ARC4 generator.
    +  var arc4 = new ARC4(key);
    + 
    +  // This function returns a random double in [0, 1) that contains
    +  // randomness in every bit of the mantissa of the IEEE 754 value.
    +  var prng = function() {
    +    var n = arc4.g(chunks),             // Start with a numerator n < 2 ^ 48
    +        d = startdenom,                 //   and denominator d = 2 ^ 48.
    +        x = 0;                          //   and no 'extra last byte'.
    +    while (n < significance) {          // Fill up all significant digits by
    +      n = (n + x) * width;              //   shifting numerator and
    +      d *= width;                       //   denominator and generating a
    +      x = arc4.g(1);                    //   new least-significant-byte.
    +    }
    +    while (n >= overflow) {             // To avoid rounding up, before adding
    +      n /= 2;                           //   last byte, shift everything
    +      d /= 2;                           //   right using integer math until
    +      x >>>= 1;                         //   we have exactly the desired bits.
    +    }
    +    return (n + x) / d;                 // Form the number within [0, 1).
    +  };
    + 
    +  prng.int32 = function() { return arc4.g(4) | 0; }
    +  prng.quick = function() { return arc4.g(4) / 0x100000000; }
    +  prng.double = prng;
    + 
    +  // Mix the randomness into accumulated entropy.
    +  mixkey(tostring(arc4.S), pool);
    + 
    +  // Calling convention: what to return as a function of prng, seed, is_math.
    +  return (options.pass || callback ||
    +      function(prng, seed, is_math_call, state) {
    +        if (state) {
    +          // Load the arc4 state from the given state if it has an S array.
    +          if (state.S) { copy(state, arc4); }
    +          // Only provide the .state method if requested via options.state.
    +          prng.state = function() { return copy(arc4, {}); }
    +        }
    + 
    +        // If called as a method of Math (Math.seedrandom()), mutate
    +        // Math.random because that is how seedrandom.js has worked since v1.0.
    +        if (is_math_call) { math[rngname] = prng; return seed; }
    + 
    +        // Otherwise, it is a newer calling convention, so return the
    +        // prng directly.
    +        else return prng;
    +      })(
    +  prng,
    +  shortseed,
    +  'global' in options ? options.global : (this == math),
    +  options.state);
    +}
    + 
    +//
    +// ARC4
    +//
    +// An ARC4 implementation.  The constructor takes a key in the form of
    +// an array of at most (width) integers that should be 0 <= x < (width).
    +//
    +// The g(count) method returns a pseudorandom integer that concatenates
    +// the next (count) outputs from ARC4.  Its return value is a number x
    +// that is in the range 0 <= x < (width ^ count).
    +//
    +function ARC4(key) {
    +  var t, keylen = key.length,
    +      me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];
    + 
    +  // The empty key [] is treated as [0].
    +  if (!keylen) { key = [keylen++]; }
    + 
    +  // Set up S using the standard key scheduling algorithm.
    +  while (i < width) {
    +    s[i] = i++;
    +  }
    +  for (i = 0; i < width; i++) {
    +    s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];
    +    s[j] = t;
    +  }
    + 
    +  // The "g" method returns the next (count) outputs as one number.
    +  (me.g = function(count) {
    +    // Using instance members instead of closure state nearly doubles speed.
    +    var t, r = 0,
    +        i = me.i, j = me.j, s = me.S;
    +    while (count--) {
    +      t = s[i = mask & (i + 1)];
    +      r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];
    +    }
    +    me.i = i; me.j = j;
    +    return r;
    +    // For robust unpredictability, the function call below automatically
    +    // discards an initial batch of values.  This is called RC4-drop[256].
    +    // See http://google.com/search?q=rsa+fluhrer+response&btnI
    +  })(width);
    +}
    + 
    +//
    +// copy()
    +// Copies internal state of ARC4 to or from a plain object.
    +//
    +function copy(f, t) {
    +  t.i = f.i;
    +  t.j = f.j;
    +  t.S = f.S.slice();
    +  return t;
    +};
    + 
    +//
    +// flatten()
    +// Converts an object tree to nested arrays of strings.
    +//
    +function flatten(obj, depth) {
    +  var result = [], typ = (typeof obj), prop;
    +  if (depth && typ == 'object') {
    +    for (prop in obj) {
    +      try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}
    +    }
    +  }
    +  return (result.length ? result : typ == 'string' ? obj : obj + '\0');
    +}
    + 
    +//
    +// mixkey()
    +// Mixes a string seed into a key that is an array of integers, and
    +// returns a shortened string seed that is equivalent to the result key.
    +//
    +function mixkey(seed, key) {
    +  var stringseed = seed + '', smear, j = 0;
    +  while (j < stringseed.length) {
    +    key[mask & j] =
    +      mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));
    +  }
    +  return tostring(key);
    +}
    + 
    +//
    +// autoseed()
    +// Returns an object for autoseeding, using window.crypto and Node crypto
    +// module if available.
    +//
    +function autoseed() {
    +  try {
    +    var out;
    +    if (nodecrypto && (out = nodecrypto.randomBytes)) {
    +      // The use of 'out' to remember randomBytes makes tight minified code.
    +      out = out(width);
    +    } else {
    +      out = new Uint8Array(width);
    +      (global.crypto || global.msCrypto).getRandomValues(out);
    +    }
    +    return tostring(out);
    +  } catch (e) {
    +    var browser = global.navigator,
    +        plugins = browser && browser.plugins;
    +    return [+new Date, global, plugins, global.screen, tostring(pool)];
    +  }
    +}
    + 
    +//
    +// tostring()
    +// Converts an array of charcodes to a string
    +//
    +function tostring(a) {
    +  return String.fromCharCode.apply(0, a);
    +}
    + 
    +//
    +// When seedrandom.js is loaded, we immediately mix a few bits
    +// from the built-in RNG into the entropy pool.  Because we do
    +// not want to interfere with deterministic PRNG state later,
    +// seedrandom will not call math.random on its own again after
    +// initialization.
    +//
    +mixkey(math.random(), pool);
    + 
    +//
    +// Nodejs and AMD support: export the implementation as a module using
    +// either convention.
    +//
    +Eif ((typeof module) == 'object' && module.exports) {
    +  module.exports = seedrandom;
    +  // When in node.js, try using crypto package for autoseeding.
    +  try {
    +    nodecrypto = require('crypto');
    +  } catch (ex) {}
    +} else if ((typeof define) == 'function' && define.amd) {
    +  define(function() { return seedrandom; });
    +} else {
    +  // When included as a plain script, set up Math.seedrandom global.
    +  math['seed' + rngname] = seedrandom;
    +}
    + 
    + 
    +// End anonymous scope, and pass initial values.
    +})(
    +  // global: `self` in browsers (including strict mode and web workers),
    +  // otherwise `this` in Node and other environments
    +  (typeof self !== 'undefined') ? self : this,
    +  [],     // pool: entropy pool starts empty
    +  Math    // math: package containing random, pow, and seedrandom
    +);
    + 
    +
    +
    + + + + + + + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sort-arrow-sprite.png b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sort-arrow-sprite.png new file mode 100644 index 0000000..03f704a Binary files /dev/null and b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sort-arrow-sprite.png differ diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sorter.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sorter.js new file mode 100644 index 0000000..16de10c --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov-report/sorter.js @@ -0,0 +1,170 @@ +/* eslint-disable */ +var addSorting = (function() { + 'use strict'; + var cols, + currentSort = { + index: 0, + desc: false + }; + + // returns the summary table element + function getTable() { + return document.querySelector('.coverage-summary'); + } + // returns the thead element of the summary table + function getTableHeader() { + return getTable().querySelector('thead tr'); + } + // returns the tbody element of the summary table + function getTableBody() { + return getTable().querySelector('tbody'); + } + // returns the th element for nth column + function getNthColumn(n) { + return getTableHeader().querySelectorAll('th')[n]; + } + + // loads all columns + function loadColumns() { + var colNodes = getTableHeader().querySelectorAll('th'), + colNode, + cols = [], + col, + i; + + for (i = 0; i < colNodes.length; i += 1) { + colNode = colNodes[i]; + col = { + key: colNode.getAttribute('data-col'), + sortable: !colNode.getAttribute('data-nosort'), + type: colNode.getAttribute('data-type') || 'string' + }; + cols.push(col); + if (col.sortable) { + col.defaultDescSort = col.type === 'number'; + colNode.innerHTML = + colNode.innerHTML + ''; + } + } + return cols; + } + // attaches a data attribute to every tr element with an object + // of data values keyed by column name + function loadRowData(tableRow) { + var tableCols = tableRow.querySelectorAll('td'), + colNode, + col, + data = {}, + i, + val; + for (i = 0; i < tableCols.length; i += 1) { + colNode = tableCols[i]; + col = cols[i]; + val = colNode.getAttribute('data-value'); + if (col.type === 'number') { + val = Number(val); + } + data[col.key] = val; + } + return data; + } + // loads all row data + function loadData() { + var rows = getTableBody().querySelectorAll('tr'), + i; + + for (i = 0; i < rows.length; i += 1) { + rows[i].data = loadRowData(rows[i]); + } + } + // sorts the table using the data for the ith column + function sortByIndex(index, desc) { + var key = cols[index].key, + sorter = function(a, b) { + a = a.data[key]; + b = b.data[key]; + return a < b ? -1 : a > b ? 1 : 0; + }, + finalSorter = sorter, + tableBody = document.querySelector('.coverage-summary tbody'), + rowNodes = tableBody.querySelectorAll('tr'), + rows = [], + i; + + if (desc) { + finalSorter = function(a, b) { + return -1 * sorter(a, b); + }; + } + + for (i = 0; i < rowNodes.length; i += 1) { + rows.push(rowNodes[i]); + tableBody.removeChild(rowNodes[i]); + } + + rows.sort(finalSorter); + + for (i = 0; i < rows.length; i += 1) { + tableBody.appendChild(rows[i]); + } + } + // removes sort indicators for current column being sorted + function removeSortIndicators() { + var col = getNthColumn(currentSort.index), + cls = col.className; + + cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, ''); + col.className = cls; + } + // adds sort indicators for current column being sorted + function addSortIndicators() { + getNthColumn(currentSort.index).className += currentSort.desc + ? ' sorted-desc' + : ' sorted'; + } + // adds event listeners for all sorter widgets + function enableUI() { + var i, + el, + ithSorter = function ithSorter(i) { + var col = cols[i]; + + return function() { + var desc = col.defaultDescSort; + + if (currentSort.index === i) { + desc = !currentSort.desc; + } + sortByIndex(i, desc); + removeSortIndicators(); + currentSort.index = i; + currentSort.desc = desc; + addSortIndicators(); + }; + }; + for (i = 0; i < cols.length; i += 1) { + if (cols[i].sortable) { + // add the click event handler on the th so users + // dont have to click on those tiny arrows + el = getNthColumn(i).querySelector('.sorter').parentElement; + if (el.addEventListener) { + el.addEventListener('click', ithSorter(i)); + } else { + el.attachEvent('onclick', ithSorter(i)); + } + } + } + } + // adds sorting functionality to the UI + return function() { + if (!getTable()) { + return; + } + cols = loadColumns(); + loadData(); + addSortIndicators(); + enableUI(); + }; +})(); + +window.addEventListener('load', addSorting); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov.info b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov.info new file mode 100644 index 0000000..bf8175d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/coverage/lcov.info @@ -0,0 +1,799 @@ +TN: +SF:/home/davidbau/git/seedrandom/seedrandom.js +FN:25,(anonymous_0) +FN:44,seedrandom +FN:58,(anonymous_2) +FN:75,(anonymous_3) +FN:76,(anonymous_4) +FN:84,(anonymous_5) +FN:89,(anonymous_6) +FN:116,ARC4 +FN:133,(anonymous_8) +FN:153,copy +FN:164,flatten +FN:179,mixkey +FN:193,autoseed +FN:215,tostring +FN:239,(anonymous_14) +FNF:15 +FNH:14 +FNDA:6,(anonymous_0) +FNDA:23,seedrandom +FNDA:3694,(anonymous_2) +FNDA:1025,(anonymous_3) +FNDA:4100001,(anonymous_4) +FNDA:20,(anonymous_5) +FNDA:2,(anonymous_6) +FNDA:23,ARC4 +FNDA:4108660,(anonymous_8) +FNDA:4,copy +FNDA:32,flatten +FNDA:52,mixkey +FNDA:4,autoseed +FNDA:81,tostring +FNDA:0,(anonymous_14) +DA:25,6 +DA:30,6 +DA:31,6 +DA:32,6 +DA:33,6 +DA:34,6 +DA:35,6 +DA:36,6 +DA:37,6 +DA:45,23 +DA:46,23 +DA:49,23 +DA:54,23 +DA:58,23 +DA:59,3694 +DA:60,3694 +DA:61,3694 +DA:62,3694 +DA:63,3917 +DA:64,3917 +DA:65,3917 +DA:67,3694 +DA:68,9249 +DA:69,9249 +DA:70,9249 +DA:72,3694 +DA:75,1025 +DA:76,4100001 +DA:77,23 +DA:80,23 +DA:83,23 +DA:85,20 +DA:87,4 +DA:89,4 +DA:94,20 +DA:98,19 +DA:117,23 +DA:118,23 +DA:121,23 +DA:124,23 +DA:125,5888 +DA:127,23 +DA:128,5888 +DA:129,5888 +DA:133,23 +DA:135,4108660 +DA:136,4108660 +DA:137,4108660 +DA:138,16436073 +DA:139,16436073 +DA:141,4108660 +DA:142,4108660 +DA:154,4 +DA:155,4 +DA:156,4 +DA:157,4 +DA:165,32 +DA:166,32 +DA:167,4 +DA:168,9 +DA:171,32 +DA:180,52 +DA:181,52 +DA:182,7735 +DA:185,52 +DA:194,4 +DA:196,4 +DA:198,3 +DA:200,1 +DA:201,1 +DA:203,3 +DA:205,1 +DA:206,1 +DA:207,1 +DA:216,81 +DA:226,6 +DA:232,6 +DA:233,6 +DA:235,6 +DA:236,6 +DA:238,0 +DA:239,0 +DA:242,0 +LF:83 +LH:80 +BRDA:46,0,0,1 +BRDA:46,0,1,22 +BRDA:46,1,0,22 +BRDA:46,1,1,11 +BRDA:50,2,0,2 +BRDA:50,2,1,21 +BRDA:51,3,0,4 +BRDA:51,3,1,17 +BRDA:83,4,0,23 +BRDA:83,4,1,21 +BRDA:83,4,2,20 +BRDA:85,5,0,4 +BRDA:85,5,1,16 +BRDA:87,6,0,2 +BRDA:87,6,1,2 +BRDA:94,7,0,1 +BRDA:94,7,1,19 +BRDA:102,8,0,4 +BRDA:102,8,1,19 +BRDA:121,9,0,1 +BRDA:121,9,1,22 +BRDA:166,10,0,4 +BRDA:166,10,1,28 +BRDA:166,11,0,32 +BRDA:166,11,1,32 +BRDA:171,12,0,3 +BRDA:171,12,1,29 +BRDA:171,13,0,23 +BRDA:171,13,1,6 +BRDA:196,14,0,3 +BRDA:196,14,1,1 +BRDA:196,15,0,4 +BRDA:196,15,1,3 +BRDA:201,16,0,1 +BRDA:201,16,1,1 +BRDA:206,17,0,1 +BRDA:206,17,1,0 +BRDA:232,18,0,6 +BRDA:232,18,1,0 +BRDA:232,19,0,6 +BRDA:232,19,1,6 +BRDA:238,20,0,0 +BRDA:238,20,1,0 +BRDA:238,21,0,0 +BRDA:238,21,1,0 +BRDA:250,22,0,0 +BRDA:250,22,1,6 +BRF:47 +BRH:40 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/alea.js +FN:28,(anonymous_0) +FN:30,Alea +FN:33,(anonymous_2) +FN:54,copy +FN:62,impl +FN:66,(anonymous_5) +FN:67,(anonymous_6) +FN:73,(anonymous_7) +FN:78,Mash +FN:81,(anonymous_9) +FN:103,(anonymous_10) +FNF:11 +FNH:10 +FNDA:1,(anonymous_0) +FNDA:3,Alea +FNDA:4105129,(anonymous_2) +FNDA:2,copy +FNDA:3,impl +FNDA:1025,(anonymous_5) +FNDA:1025,(anonymous_6) +FNDA:1,(anonymous_7) +FNDA:3,Mash +FNDA:18,(anonymous_9) +FNDA:0,(anonymous_10) +DA:28,1 +DA:31,3 +DA:33,3 +DA:34,4105129 +DA:35,4105129 +DA:36,4105129 +DA:37,4105129 +DA:41,3 +DA:42,3 +DA:43,3 +DA:44,3 +DA:45,3 +DA:46,3 +DA:47,3 +DA:48,3 +DA:49,3 +DA:50,3 +DA:51,3 +DA:55,2 +DA:56,2 +DA:57,2 +DA:58,2 +DA:59,2 +DA:63,3 +DA:64,3 +DA:65,3 +DA:66,1025 +DA:67,3 +DA:68,1025 +DA:70,3 +DA:71,3 +DA:72,2 +DA:73,2 +DA:75,3 +DA:79,3 +DA:81,3 +DA:82,18 +DA:83,18 +DA:84,33 +DA:85,33 +DA:86,33 +DA:87,33 +DA:88,33 +DA:89,33 +DA:90,33 +DA:91,33 +DA:93,18 +DA:96,3 +DA:100,1 +DA:101,1 +DA:102,0 +DA:103,0 +DA:105,0 +LF:53 +LH:50 +BRDA:46,0,0,1 +BRDA:46,0,1,2 +BRDA:48,1,0,3 +BRDA:48,1,1,0 +BRDA:50,2,0,0 +BRDA:50,2,1,3 +BRDA:64,3,0,3 +BRDA:64,3,1,2 +BRDA:71,4,0,2 +BRDA:71,4,1,1 +BRDA:72,5,0,1 +BRDA:72,5,1,1 +BRDA:100,6,0,1 +BRDA:100,6,1,0 +BRDA:100,7,0,1 +BRDA:100,7,1,1 +BRDA:102,8,0,0 +BRDA:102,8,1,0 +BRDA:102,9,0,0 +BRDA:102,9,1,0 +BRDA:110,10,0,1 +BRDA:110,10,1,1 +BRDA:111,11,0,1 +BRDA:111,11,1,0 +BRF:24 +BRH:16 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/tychei.js +FN:5,(anonymous_0) +FN:7,XorGen +FN:11,(anonymous_2) +FN:60,copy +FN:68,impl +FN:71,(anonymous_5) +FN:72,(anonymous_6) +FN:84,(anonymous_7) +FN:92,(anonymous_8) +FNF:9 +FNH:8 +FNDA:1,(anonymous_0) +FNDA:3,XorGen +FNDA:4105195,(anonymous_2) +FNDA:2,copy +FNDA:3,impl +FNDA:4102054,(anonymous_5) +FNDA:1025,(anonymous_6) +FNDA:1,(anonymous_7) +FNDA:0,(anonymous_8) +DA:5,1 +DA:8,3 +DA:11,3 +DA:12,4105195 +DA:13,4105195 +DA:14,4105195 +DA:15,4105195 +DA:16,4105195 +DA:17,4105195 +DA:18,4105195 +DA:19,4105195 +DA:20,4105195 +DA:39,3 +DA:40,3 +DA:41,3 +DA:42,3 +DA:44,3 +DA:46,2 +DA:47,2 +DA:50,1 +DA:54,3 +DA:55,66 +DA:56,66 +DA:61,2 +DA:62,2 +DA:63,2 +DA:64,2 +DA:65,2 +DA:69,3 +DA:70,3 +DA:71,4102054 +DA:72,3 +DA:73,1025 +DA:74,1025 +DA:75,1025 +DA:76,1025 +DA:78,1025 +DA:80,3 +DA:81,3 +DA:82,3 +DA:83,2 +DA:84,2 +DA:86,3 +DA:89,1 +DA:90,1 +DA:91,0 +DA:92,0 +DA:94,0 +LF:48 +LH:45 +BRDA:44,0,0,2 +BRDA:44,0,1,1 +BRDA:70,1,0,3 +BRDA:70,1,1,2 +BRDA:82,2,0,2 +BRDA:82,2,1,1 +BRDA:83,3,0,1 +BRDA:83,3,1,1 +BRDA:89,4,0,1 +BRDA:89,4,1,0 +BRDA:89,5,0,1 +BRDA:89,5,1,1 +BRDA:91,6,0,0 +BRDA:91,6,1,0 +BRDA:91,7,0,0 +BRDA:91,7,1,0 +BRDA:99,8,0,1 +BRDA:99,8,1,1 +BRDA:100,9,0,1 +BRDA:100,9,1,0 +BRF:20 +BRH:14 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/xor128.js +FN:4,(anonymous_0) +FN:6,XorGen +FN:15,(anonymous_2) +FN:38,copy +FN:46,impl +FN:49,(anonymous_5) +FN:50,(anonymous_6) +FN:62,(anonymous_7) +FN:70,(anonymous_8) +FNF:9 +FNH:8 +FNDA:1,(anonymous_0) +FNDA:3,XorGen +FNDA:4105327,(anonymous_2) +FNDA:2,copy +FNDA:3,impl +FNDA:4102054,(anonymous_5) +FNDA:1025,(anonymous_6) +FNDA:1,(anonymous_7) +FNDA:0,(anonymous_8) +DA:4,1 +DA:7,3 +DA:9,3 +DA:10,3 +DA:11,3 +DA:12,3 +DA:15,3 +DA:16,4105327 +DA:17,4105327 +DA:18,4105327 +DA:19,4105327 +DA:20,4105327 +DA:23,3 +DA:25,2 +DA:28,1 +DA:32,3 +DA:33,198 +DA:34,198 +DA:39,2 +DA:40,2 +DA:41,2 +DA:42,2 +DA:43,2 +DA:47,3 +DA:48,3 +DA:49,4102054 +DA:50,3 +DA:51,1025 +DA:52,1025 +DA:53,1025 +DA:54,1025 +DA:56,1025 +DA:58,3 +DA:59,3 +DA:60,3 +DA:61,2 +DA:62,2 +DA:64,3 +DA:67,1 +DA:68,1 +DA:69,0 +DA:70,0 +DA:72,0 +LF:43 +LH:40 +BRDA:23,0,0,2 +BRDA:23,0,1,1 +BRDA:48,1,0,3 +BRDA:48,1,1,2 +BRDA:60,2,0,2 +BRDA:60,2,1,1 +BRDA:61,3,0,1 +BRDA:61,3,1,1 +BRDA:67,4,0,1 +BRDA:67,4,1,0 +BRDA:67,5,0,1 +BRDA:67,5,1,1 +BRDA:69,6,0,0 +BRDA:69,6,1,0 +BRDA:69,7,0,0 +BRDA:69,7,1,0 +BRDA:77,8,0,1 +BRDA:77,8,1,1 +BRDA:78,9,0,1 +BRDA:78,9,1,0 +BRF:20 +BRH:14 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/xor4096.js +FN:26,(anonymous_0) +FN:28,XorGen +FN:32,(anonymous_2) +FN:51,init +FN:105,copy +FN:112,impl +FN:116,(anonymous_6) +FN:117,(anonymous_7) +FN:129,(anonymous_8) +FN:137,(anonymous_9) +FNF:10 +FNH:9 +FNDA:1,(anonymous_0) +FNDA:3,XorGen +FNDA:4105129,(anonymous_2) +FNDA:3,init +FNDA:2,copy +FNDA:3,impl +FNDA:4102054,(anonymous_6) +FNDA:1025,(anonymous_7) +FNDA:1,(anonymous_8) +FNDA:0,(anonymous_9) +DA:26,1 +DA:29,3 +DA:32,3 +DA:33,4105129 +DA:34,4105129 +DA:36,4105129 +DA:38,4105129 +DA:39,4105129 +DA:40,4105129 +DA:41,4105129 +DA:42,4105129 +DA:43,4105129 +DA:45,4105129 +DA:46,4105129 +DA:48,4105129 +DA:52,3 +DA:53,3 +DA:55,2 +DA:56,2 +DA:59,1 +DA:60,1 +DA:61,1 +DA:64,3 +DA:66,480 +DA:68,480 +DA:69,480 +DA:70,480 +DA:71,480 +DA:72,480 +DA:73,480 +DA:74,384 +DA:75,384 +DA:76,384 +DA:80,3 +DA:81,0 +DA:86,3 +DA:87,3 +DA:88,1536 +DA:89,1536 +DA:90,1536 +DA:91,1536 +DA:92,1536 +DA:93,1536 +DA:94,1536 +DA:97,3 +DA:98,3 +DA:99,3 +DA:102,3 +DA:106,2 +DA:107,2 +DA:108,2 +DA:109,2 +DA:113,3 +DA:114,3 +DA:115,3 +DA:116,4102054 +DA:117,3 +DA:118,1025 +DA:119,1025 +DA:120,1025 +DA:121,1025 +DA:123,1025 +DA:125,3 +DA:126,3 +DA:127,3 +DA:128,2 +DA:129,2 +DA:131,3 +DA:134,1 +DA:135,1 +DA:136,0 +DA:137,0 +DA:139,0 +LF:73 +LH:69 +BRDA:53,0,0,2 +BRDA:53,0,1,1 +BRDA:66,1,0,160 +BRDA:66,1,1,320 +BRDA:68,2,0,3 +BRDA:68,2,1,477 +BRDA:73,3,0,384 +BRDA:73,3,1,96 +BRDA:76,4,0,0 +BRDA:76,4,1,384 +BRDA:80,5,0,0 +BRDA:80,5,1,3 +BRDA:81,6,0,0 +BRDA:81,6,1,0 +BRDA:81,6,2,0 +BRDA:113,7,0,0 +BRDA:113,7,1,3 +BRDA:115,8,0,3 +BRDA:115,8,1,2 +BRDA:127,9,0,2 +BRDA:127,9,1,1 +BRDA:128,10,0,1 +BRDA:128,10,1,1 +BRDA:134,11,0,1 +BRDA:134,11,1,0 +BRDA:134,12,0,1 +BRDA:134,12,1,1 +BRDA:136,13,0,0 +BRDA:136,13,1,0 +BRDA:136,14,0,0 +BRDA:136,14,1,0 +BRDA:144,15,0,1 +BRDA:144,15,1,1 +BRDA:145,16,0,1 +BRDA:145,16,1,0 +BRF:35 +BRH:23 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/xorshift7.js +FN:6,(anonymous_0) +FN:8,XorGen +FN:12,(anonymous_2) +FN:25,init +FN:56,copy +FN:62,impl +FN:66,(anonymous_6) +FN:67,(anonymous_7) +FN:79,(anonymous_8) +FN:87,(anonymous_9) +FNF:10 +FNH:9 +FNDA:1,(anonymous_0) +FNDA:3,XorGen +FNDA:4105897,(anonymous_2) +FNDA:3,init +FNDA:2,copy +FNDA:3,impl +FNDA:4102054,(anonymous_6) +FNDA:1025,(anonymous_7) +FNDA:1,(anonymous_8) +FNDA:0,(anonymous_9) +DA:6,1 +DA:9,3 +DA:12,3 +DA:14,4105897 +DA:15,4105897 +DA:16,4105897 +DA:17,4105897 +DA:18,4105897 +DA:19,4105897 +DA:20,4105897 +DA:21,4105897 +DA:22,4105897 +DA:26,3 +DA:28,3 +DA:30,2 +DA:33,1 +DA:34,1 +DA:35,6 +DA:40,16 +DA:41,3 +DA:42,3 +DA:44,3 +DA:45,3 +DA:48,3 +DA:49,768 +DA:53,3 +DA:57,2 +DA:58,2 +DA:59,2 +DA:63,3 +DA:64,3 +DA:65,3 +DA:66,4102054 +DA:67,3 +DA:68,1025 +DA:69,1025 +DA:70,1025 +DA:71,1025 +DA:73,1025 +DA:75,3 +DA:76,3 +DA:77,3 +DA:78,2 +DA:79,2 +DA:81,3 +DA:84,1 +DA:85,1 +DA:86,0 +DA:87,0 +DA:89,0 +LF:50 +LH:47 +BRDA:28,0,0,2 +BRDA:28,0,1,1 +BRDA:41,1,0,19 +BRDA:41,1,1,17 +BRDA:42,2,0,2 +BRDA:42,2,1,1 +BRDA:63,3,0,0 +BRDA:63,3,1,3 +BRDA:65,4,0,3 +BRDA:65,4,1,2 +BRDA:77,5,0,2 +BRDA:77,5,1,1 +BRDA:78,6,0,1 +BRDA:78,6,1,1 +BRDA:84,7,0,1 +BRDA:84,7,1,0 +BRDA:84,8,0,1 +BRDA:84,8,1,1 +BRDA:86,9,0,0 +BRDA:86,9,1,0 +BRDA:86,10,0,0 +BRDA:86,10,1,0 +BRDA:94,11,0,1 +BRDA:94,11,1,1 +BRDA:95,12,0,1 +BRDA:95,12,1,0 +BRF:26 +BRH:19 +end_of_record +TN: +SF:/home/davidbau/git/seedrandom/lib/xorwow.js +FN:4,(anonymous_0) +FN:6,XorGen +FN:10,(anonymous_2) +FN:41,copy +FN:51,impl +FN:54,(anonymous_5) +FN:55,(anonymous_6) +FN:67,(anonymous_7) +FN:75,(anonymous_8) +FNF:9 +FNH:8 +FNDA:1,(anonymous_0) +FNDA:3,XorGen +FNDA:4105327,(anonymous_2) +FNDA:2,copy +FNDA:3,impl +FNDA:4102054,(anonymous_5) +FNDA:1025,(anonymous_6) +FNDA:1,(anonymous_7) +FNDA:0,(anonymous_8) +DA:4,1 +DA:7,3 +DA:10,3 +DA:11,4105327 +DA:12,4105327 +DA:13,4105327 +DA:17,3 +DA:18,3 +DA:19,3 +DA:20,3 +DA:21,3 +DA:23,3 +DA:25,2 +DA:28,1 +DA:32,3 +DA:33,198 +DA:34,198 +DA:35,3 +DA:37,198 +DA:42,2 +DA:43,2 +DA:44,2 +DA:45,2 +DA:46,2 +DA:47,2 +DA:48,2 +DA:52,3 +DA:53,3 +DA:54,4102054 +DA:55,3 +DA:56,1025 +DA:57,1025 +DA:58,1025 +DA:59,1025 +DA:61,1025 +DA:63,3 +DA:64,3 +DA:65,3 +DA:66,2 +DA:67,2 +DA:69,3 +DA:72,1 +DA:73,1 +DA:74,0 +DA:75,0 +DA:77,0 +LF:46 +LH:43 +BRDA:23,0,0,2 +BRDA:23,0,1,1 +BRDA:34,1,0,3 +BRDA:34,1,1,195 +BRDA:53,2,0,3 +BRDA:53,2,1,2 +BRDA:65,3,0,2 +BRDA:65,3,1,1 +BRDA:66,4,0,1 +BRDA:66,4,1,1 +BRDA:72,5,0,1 +BRDA:72,5,1,0 +BRDA:72,6,0,1 +BRDA:72,6,1,1 +BRDA:74,7,0,0 +BRDA:74,7,1,0 +BRDA:74,8,0,0 +BRDA:74,8,1,0 +BRDA:82,9,0,1 +BRDA:82,9,1,1 +BRDA:83,10,0,1 +BRDA:83,10,1,0 +BRF:22 +BRH:16 +end_of_record diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/index.js new file mode 100644 index 0000000..513669a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/index.js @@ -0,0 +1,60 @@ +// A library of seedable RNGs implemented in Javascript. +// +// Usage: +// +// var seedrandom = require('seedrandom'); +// var random = seedrandom(1); // or any seed. +// var x = random(); // 0 <= x < 1. Every bit is random. +// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness. + +// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe. +// Period: ~2^116 +// Reported to pass all BigCrush tests. +var alea = require('./lib/alea'); + +// xor128, a pure xor-shift generator by George Marsaglia. +// Period: 2^128-1. +// Reported to fail: MatrixRank and LinearComp. +var xor128 = require('./lib/xor128'); + +// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl. +// Period: 2^192-2^32 +// Reported to fail: CollisionOver, SimpPoker, and LinearComp. +var xorwow = require('./lib/xorwow'); + +// xorshift7, by François Panneton and Pierre L'ecuyer, takes +// a different approach: it adds robustness by allowing more shifts +// than Marsaglia's original three. It is a 7-shift generator +// with 256 bits, that passes BigCrush with no systmatic failures. +// Period 2^256-1. +// No systematic BigCrush failures reported. +var xorshift7 = require('./lib/xorshift7'); + +// xor4096, by Richard Brent, is a 4096-bit xor-shift with a +// very long period that also adds a Weyl generator. It also passes +// BigCrush with no systematic failures. Its long period may +// be useful if you have many generators and need to avoid +// collisions. +// Period: 2^4128-2^32. +// No systematic BigCrush failures reported. +var xor4096 = require('./lib/xor4096'); + +// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random +// number generator derived from ChaCha, a modern stream cipher. +// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf +// Period: ~2^127 +// No systematic BigCrush failures reported. +var tychei = require('./lib/tychei'); + +// The original ARC4-based prng included in this library. +// Period: ~2^1600 +var sr = require('./seedrandom'); + +sr.alea = alea; +sr.xor128 = xor128; +sr.xorwow = xorwow; +sr.xorshift7 = xorshift7; +sr.xor4096 = xor4096; +sr.tychei = tychei; + +module.exports = sr; diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.js new file mode 100644 index 0000000..478b956 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.js @@ -0,0 +1,114 @@ +// A port of an algorithm by Johannes Baagøe , 2010 +// http://baagoe.com/en/RandomMusings/javascript/ +// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror +// Original work is under MIT license - + +// Copyright (C) 2010 by Johannes Baagøe +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +// THE SOFTWARE. + + + +(function(global, module, define) { + +function Alea(seed) { + var me = this, mash = Mash(); + + me.next = function() { + var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32 + me.s0 = me.s1; + me.s1 = me.s2; + return me.s2 = t - (me.c = t | 0); + }; + + // Apply the seeding algorithm from Baagoe. + me.c = 1; + me.s0 = mash(' '); + me.s1 = mash(' '); + me.s2 = mash(' '); + me.s0 -= mash(seed); + if (me.s0 < 0) { me.s0 += 1; } + me.s1 -= mash(seed); + if (me.s1 < 0) { me.s1 += 1; } + me.s2 -= mash(seed); + if (me.s2 < 0) { me.s2 += 1; } + mash = null; +} + +function copy(f, t) { + t.c = f.c; + t.s0 = f.s0; + t.s1 = f.s1; + t.s2 = f.s2; + return t; +} + +function impl(seed, opts) { + var xg = new Alea(seed), + state = opts && opts.state, + prng = xg.next; + prng.int32 = function() { return (xg.next() * 0x100000000) | 0; } + prng.double = function() { + return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53 + }; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +function Mash() { + var n = 0xefc8249d; + + var mash = function(data) { + data = String(data); + for (var i = 0; i < data.length; i++) { + n += data.charCodeAt(i); + var h = 0.02519603282416938 * n; + n = h >>> 0; + h -= n; + h *= n; + n = h >>> 0; + h -= n; + n += h * 0x100000000; // 2^32 + } + return (n >>> 0) * 2.3283064365386963e-10; // 2^-32 + }; + + return mash; +} + + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.alea = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.min.js new file mode 100644 index 0000000..be30a46 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/alea.min.js @@ -0,0 +1 @@ +!function(n,t,e){function u(n){var t=this,e=function(){var s=4022871197;return function(n){n=String(n);for(var t=0;t>>0,s=(e*=s)>>>0,s+=4294967296*(e-=s)}return 2.3283064365386963e-10*(s>>>0)}}();t.next=function(){var n=2091639*t.s0+2.3283064365386963e-10*t.c;return t.s0=t.s1,t.s1=t.s2,t.s2=n-(t.c=0|n)},t.c=1,t.s0=e(" "),t.s1=e(" "),t.s2=e(" "),t.s0-=e(n),t.s0<0&&(t.s0+=1),t.s1-=e(n),t.s1<0&&(t.s1+=1),t.s2-=e(n),t.s2<0&&(t.s2+=1),e=null}function o(n,t){return t.c=n.c,t.s0=n.s0,t.s1=n.s1,t.s2=n.s2,t}function s(n,t){var e=new u(n),s=t&&t.state,r=e.next;return r.int32=function(){return 4294967296*e.next()|0},r.double=function(){return r()+11102230246251565e-32*(2097152*r()|0)},r.quick=r,s&&("object"==typeof s&&o(s,e),r.state=function(){return o(e,{})}),r}t&&t.exports?t.exports=s:e&&e.amd?e(function(){return s}):this.alea=s}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/crypto.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/crypto.js new file mode 100644 index 0000000..18ee91f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/crypto.js @@ -0,0 +1,11 @@ +// mimic a subset of node's crypto API for the browser + +function randomBytes(width) { + var out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + return out; +} + +module.exports = { + randomBytes: randomBytes +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.js new file mode 100644 index 0000000..3d0ddd4 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.js @@ -0,0 +1,103 @@ +// A Javascript implementaion of the "Tyche-i" prng algorithm by +// Samuel Neves and Filipe Araujo. +// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var b = me.b, c = me.c, d = me.d, a = me.a; + b = (b << 25) ^ (b >>> 7) ^ c; + c = (c - d) | 0; + d = (d << 24) ^ (d >>> 8) ^ a; + a = (a - b) | 0; + me.b = b = (b << 20) ^ (b >>> 12) ^ c; + me.c = c = (c - d) | 0; + me.d = (d << 16) ^ (c >>> 16) ^ a; + return me.a = (a - b) | 0; + }; + + /* The following is non-inverted tyche, which has better internal + * bit diffusion, but which is about 25% slower than tyche-i in JS. + me.next = function() { + var a = me.a, b = me.b, c = me.c, d = me.d; + a = (me.a + me.b | 0) >>> 0; + d = me.d ^ a; d = d << 16 ^ d >>> 16; + c = me.c + d | 0; + b = me.b ^ c; b = b << 12 ^ d >>> 20; + me.a = a = a + b | 0; + d = d ^ a; me.d = d = d << 8 ^ d >>> 24; + me.c = c = c + d | 0; + b = b ^ c; + return me.b = (b << 7 ^ b >>> 25); + } + */ + + me.a = 0; + me.b = 0; + me.c = 2654435769 | 0; + me.d = 1367130551; + + if (seed === Math.floor(seed)) { + // Integer seed. + me.a = (seed / 0x100000000) | 0; + me.b = seed | 0; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 20; k++) { + me.b ^= strseed.charCodeAt(k) | 0; + me.next(); + } +} + +function copy(f, t) { + t.a = f.a; + t.b = f.b; + t.c = f.c; + t.d = f.d; + return t; +}; + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.tychei = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.min.js new file mode 100644 index 0000000..fa24abb --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/tychei.min.js @@ -0,0 +1 @@ +!function(t,n,e){function u(t){var r=this,n="";r.next=function(){var t=r.b,n=r.c,e=r.d,o=r.a;return t=t<<25^t>>>7^n,n=n-e|0,e=e<<24^e>>>8^o,o=o-t|0,r.b=t=t<<20^t>>>12^n,r.c=n=n-e|0,r.d=e<<16^n>>>16^o,r.a=o-t|0},r.a=0,r.b=0,r.c=-1640531527,r.d=1367130551,t===Math.floor(t)?(r.a=t/4294967296|0,r.b=0|t):n+=t;for(var e=0;e>>0)/4294967296}var o=new u(t),r=n&&n.state;return e.double=function(){do{var t=((o.next()>>>11)+(o.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},e.int32=o.next,e.quick=e,r&&("object"==typeof r&&c(r,o),e.state=function(){return c(o,{})}),e}n&&n.exports?n.exports=o:e&&e.amd?e(function(){return o}):this.tychei=o}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.js new file mode 100644 index 0000000..c461934 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.js @@ -0,0 +1,81 @@ +// A Javascript implementaion of the "xor128" prng algorithm by +// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + + // Set up generator function. + me.next = function() { + var t = me.x ^ (me.x << 11); + me.x = me.y; + me.y = me.z; + me.z = me.w; + return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8); + }; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + me.next(); + } +} + +function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + return t; +} + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xor128 = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.min.js new file mode 100644 index 0000000..bd60553 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor128.min.js @@ -0,0 +1 @@ +!function(t,n,e){function u(t){var n=this,e="";n.x=0,n.y=0,n.z=0,n.w=0,n.next=function(){var t=n.x^n.x<<11;return n.x=n.y,n.y=n.z,n.z=n.w,n.w^=n.w>>>19^t^t>>>8},t===(0|t)?n.x=t:e+=t;for(var o=0;o>>0)/4294967296}var o=new u(t),r=n&&n.state;return e.double=function(){do{var t=((o.next()>>>11)+(o.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},e.int32=o.next,e.quick=e,r&&("object"==typeof r&&i(r,o),e.state=function(){return i(o,{})}),e}n&&n.exports?n.exports=o:e&&e.amd?e(function(){return o}):this.xor128=o}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.js new file mode 100644 index 0000000..6adf19f --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.js @@ -0,0 +1,146 @@ +// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm. +// +// This fast non-cryptographic random number generator is designed for +// use in Monte-Carlo algorithms. It combines a long-period xorshift +// generator with a Weyl generator, and it passes all common batteries +// of stasticial tests for randomness while consuming only a few nanoseconds +// for each prng generated. For background on the generator, see Brent's +// paper: "Some long-period random number generators using shifts and xors." +// http://arxiv.org/pdf/1004.3115v1.pdf +// +// Usage: +// +// var xor4096 = require('xor4096'); +// random = xor4096(1); // Seed with int32 or string. +// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits. +// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits. +// +// For nonzero numeric keys, this impelementation provides a sequence +// identical to that by Brent's xorgens 3 implementaion in C. This +// implementation also provides for initalizing the generator with +// string seeds, or for saving and restoring the state of the generator. +// +// On Chrome, this prng benchmarks about 2.1 times slower than +// Javascript's built-in Math.random(). + +(function(global, module, define) { + +function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + var w = me.w, + X = me.X, i = me.i, t, v; + // Update Weyl generator. + me.w = w = (w + 0x61c88647) | 0; + // Update xor generator. + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + // Update Xor generator array state. + v = X[i] = v ^ t; + me.i = i; + // Result is the combination. + return (v + (w ^ (w >>> 16))) | 0; + }; + + function init(me, seed) { + var t, v, i, j, w, X = [], limit = 128; + if (seed === (seed | 0)) { + // Numeric seeds initialize v, which is used to generates X. + v = seed; + seed = null; + } else { + // String seeds are mixed into v and X one character at a time. + seed = seed + '\0'; + v = 0; + limit = Math.max(limit, seed.length); + } + // Initialize circular array and weyl value. + for (i = 0, j = -32; j < limit; ++j) { + // Put the unicode characters into the array, and shuffle them. + if (seed) v ^= seed.charCodeAt((j + 32) % seed.length); + // After 32 shuffles, take v as the starting w value. + if (j === 0) w = v; + v ^= v << 10; + v ^= v >>> 15; + v ^= v << 4; + v ^= v >>> 13; + if (j >= 0) { + w = (w + 0x61c88647) | 0; // Weyl. + t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array. + i = (0 == t) ? i + 1 : 0; // Count zeroes. + } + } + // We have detected all zeroes; make the key nonzero. + if (i >= 128) { + X[(seed && seed.length || 0) & 127] = -1; + } + // Run the generator 512 times to further mix the state before using it. + // Factoring this as a function slows the main generator, so it is just + // unrolled here. The weyl generator is not advanced while warming up. + i = 127; + for (j = 4 * 128; j > 0; --j) { + v = X[(i + 34) & 127]; + t = X[i = ((i + 1) & 127)]; + v ^= v << 13; + t ^= t << 17; + v ^= v >>> 15; + t ^= t >>> 12; + X[i] = v ^ t; + } + // Storing state as object members is faster than using closure variables. + me.w = w; + me.X = X; + me.i = i; + } + + init(me, seed); +} + +function copy(f, t) { + t.i = f.i; + t.w = f.w; + t.X = f.X.slice(); + return t; +}; + +function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.X) copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xor4096 = impl; +} + +})( + this, // window object or global + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.min.js new file mode 100644 index 0000000..fee9f8a --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xor4096.min.js @@ -0,0 +1 @@ +!function(n,t,e){function o(n){var o=this;o.next=function(){var n,t,e=o.w,r=o.X,i=o.i;return o.w=e=e+1640531527|0,t=r[i+34&127],n=r[i=i+1&127],t^=t<<13,n^=n<<17,t^=t>>>15,n^=n>>>12,t=r[i]=t^n,o.i=i,t+(e^e>>>16)|0},function(n,t){var e,r,i,o,u,f=[],c=128;for(t===(0|t)?(r=t,t=null):(t+="\0",r=0,c=Math.max(c,t.length)),i=0,o=-32;o>>15,r^=r<<4,r^=r>>>13,0<=o&&(u=u+1640531527|0,i=0==(e=f[127&o]^=r+u)?i+1:0);for(128<=i&&(f[127&(t&&t.length||0)]=-1),i=127,o=512;0>>15,e^=e>>>12,f[i]=r^e;n.w=u,n.X=f,n.i=i}(o,n)}function u(n,t){return t.i=n.i,t.w=n.w,t.X=n.X.slice(),t}function r(n,t){null==n&&(n=+new Date);function e(){return(r.next()>>>0)/4294967296}var r=new o(n),i=t&&t.state;return e.double=function(){do{var n=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===n);return n},e.int32=r.next,e.quick=e,i&&(i.X&&u(i,r),e.state=function(){return u(r,{})}),e}t&&t.exports?t.exports=r:e&&e.amd?e(function(){return r}):this.xor4096=r}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.js new file mode 100644 index 0000000..b7e5151 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.js @@ -0,0 +1,97 @@ +// A Javascript implementaion of the "xorshift7" algorithm by +// François Panneton and Pierre L'ecuyer: +// "On the Xorgshift Random Number Generators" +// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf + +(function(global, module, define) { + +function XorGen(seed) { + var me = this; + + // Set up generator function. + me.next = function() { + // Update xor generator. + var X = me.x, i = me.i, t, v, w; + t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24); + t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10); + t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3); + t = X[(i + 4) & 7]; v ^= t ^ (t << 7); + t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9); + X[i] = v; + me.i = (i + 1) & 7; + return v; + }; + + function init(me, seed) { + var j, w, X = []; + + if (seed === (seed | 0)) { + // Seed state array using a 32-bit integer. + w = X[0] = seed; + } else { + // Seed state using a string. + seed = '' + seed; + for (j = 0; j < seed.length; ++j) { + X[j & 7] = (X[j & 7] << 15) ^ + (seed.charCodeAt(j) + X[(j + 1) & 7] << 13); + } + } + // Enforce an array length of 8, not all zeroes. + while (X.length < 8) X.push(0); + for (j = 0; j < 8 && X[j] === 0; ++j); + if (j == 8) w = X[7] = -1; else w = X[j]; + + me.x = X; + me.i = 0; + + // Discard an initial 256 values. + for (j = 256; j > 0; --j) { + me.next(); + } + } + + init(me, seed); +} + +function copy(f, t) { + t.x = f.x.slice(); + t.i = f.i; + return t; +} + +function impl(seed, opts) { + if (seed == null) seed = +(new Date); + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (state.x) copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xorshift7 = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.min.js new file mode 100644 index 0000000..c6db5f6 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorshift7.min.js @@ -0,0 +1 @@ +!function(n,t,e){function o(n){var i=this;i.next=function(){var n,t,e=i.x,r=i.i;return n=e[r],t=(n^=n>>>7)^n<<24,t^=(n=e[r+1&7])^n>>>10,t^=(n=e[r+3&7])^n>>>3,t^=(n=e[r+4&7])^n<<7,n=e[r+7&7],t^=(n^=n<<13)^n<<9,e[r]=t,i.i=r+1&7,t},function(n,t){var e,r=[];if(t===(0|t))r[0]=t;else for(t=""+t,e=0;e>>0)/4294967296}var r=new o(n),i=t&&t.state;return e.double=function(){do{var n=((r.next()>>>11)+(r.next()>>>0)/4294967296)/(1<<21)}while(0===n);return n},e.int32=r.next,e.quick=e,i&&(i.x&&u(i,r),e.state=function(){return u(r,{})}),e}t&&t.exports?t.exports=r:e&&e.amd?e(function(){return r}):this.xorshift7=r}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.js new file mode 100644 index 0000000..79d5e44 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.js @@ -0,0 +1,86 @@ +// A Javascript implementaion of the "xorwow" prng algorithm by +// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper + +(function(global, module, define) { + +function XorGen(seed) { + var me = this, strseed = ''; + + // Set up generator function. + me.next = function() { + var t = (me.x ^ (me.x >>> 2)); + me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v; + return (me.d = (me.d + 362437 | 0)) + + (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0; + }; + + me.x = 0; + me.y = 0; + me.z = 0; + me.w = 0; + me.v = 0; + + if (seed === (seed | 0)) { + // Integer seed. + me.x = seed; + } else { + // String seed. + strseed += seed; + } + + // Mix in string seed, then discard an initial batch of 64 values. + for (var k = 0; k < strseed.length + 64; k++) { + me.x ^= strseed.charCodeAt(k) | 0; + if (k == strseed.length) { + me.d = me.x << 10 ^ me.x >>> 4; + } + me.next(); + } +} + +function copy(f, t) { + t.x = f.x; + t.y = f.y; + t.z = f.z; + t.w = f.w; + t.v = f.v; + t.d = f.d; + return t; +} + +function impl(seed, opts) { + var xg = new XorGen(seed), + state = opts && opts.state, + prng = function() { return (xg.next() >>> 0) / 0x100000000; }; + prng.double = function() { + do { + var top = xg.next() >>> 11, + bot = (xg.next() >>> 0) / 0x100000000, + result = (top + bot) / (1 << 21); + } while (result === 0); + return result; + }; + prng.int32 = xg.next; + prng.quick = prng; + if (state) { + if (typeof(state) == 'object') copy(state, xg); + prng.state = function() { return copy(xg, {}); } + } + return prng; +} + +if (module && module.exports) { + module.exports = impl; +} else if (define && define.amd) { + define(function() { return impl; }); +} else { + this.xorwow = impl; +} + +})( + this, + (typeof module) == 'object' && module, // present in node.js + (typeof define) == 'function' && define // present with an AMD loader +); + + diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.min.js new file mode 100644 index 0000000..be1c626 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/lib/xorwow.min.js @@ -0,0 +1 @@ +!function(t,n,e){function u(t){var n=this,e="";n.next=function(){var t=n.x^n.x>>>2;return n.x=n.y,n.y=n.z,n.z=n.w,n.w=n.v,(n.d=n.d+362437|0)+(n.v=n.v^n.v<<4^t^t<<1)|0},n.x=0,n.y=0,n.z=0,n.w=0,t===((n.v=0)|t)?n.x=t:e+=t;for(var o=0;o>>4),n.next()}function x(t,n){return n.x=t.x,n.y=t.y,n.z=t.z,n.w=t.w,n.v=t.v,n.d=t.d,n}function o(t,n){function e(){return(o.next()>>>0)/4294967296}var o=new u(t),r=n&&n.state;return e.double=function(){do{var t=((o.next()>>>11)+(o.next()>>>0)/4294967296)/(1<<21)}while(0===t);return t},e.int32=o.next,e.quick=e,r&&("object"==typeof r&&x(r,o),e.state=function(){return x(o,{})}),e}n&&n.exports?n.exports=o:e&&e.amd?e(function(){return o}):this.xorwow=o}(0,"object"==typeof module&&module,"function"==typeof define&&define); \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/package.json new file mode 100644 index 0000000..86aad13 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/package.json @@ -0,0 +1,60 @@ +{ + "name": "seedrandom", + "version": "3.0.5", + "description": "Seeded random number generator for Javascript.", + "main": "index.js", + "jsdelivr": "seedrandom.min.js", + "unpkg": "seedrandom.min.js", + "keywords": [ + "seed", + "random", + "crypto" + ], + "scripts": { + "test": "grunt travis" + }, + "repository": { + "type": "git", + "url": "git://github.com/davidbau/seedrandom.git" + }, + "author": "David Bau", + "license": "MIT", + "bugs": { + "url": "https://github.com/davidbau/seedrandom/issues" + }, + "homepage": "http://davidbau.com/archives/2010/01/30/random_seeds_coded_hints_and_quintillions.html", + "config": { + "blanket": { + "pattern": [ + "seedrandom.js", + "lib/alea.js", + "lib/xor128.js", + "lib/xorwow.js", + "lib/xorshift7.js", + "lib/tychei.js", + "lib/xor4096.js" + ] + } + }, + "browser": { + "crypto": false + }, + "devDependencies": { + "blanket": "latest", + "coveralls": "latest", + "grunt": "latest", + "grunt-browserify": "latest", + "grunt-release": "davidbau/grunt-release", + "grunt-cli": "latest", + "grunt-contrib-connect": "latest", + "grunt-contrib-copy": "latest", + "grunt-contrib-qunit": "latest", + "grunt-contrib-uglify": "latest", + "grunt-mocha-nyc": "latest", + "mocha": "latest", + "nyc": "latest", + "proxyquire": "latest", + "qunit": "latest", + "requirejs": "latest" + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.js new file mode 100644 index 0000000..12d7ee1 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.js @@ -0,0 +1,253 @@ +/* +Copyright 2019 David Bau. + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +*/ + +(function (global, pool, math) { +// +// The following constants are related to IEEE 754 limits. +// + +var width = 256, // each RC4 output is 0 <= x < 256 + chunks = 6, // at least six RC4 outputs for each double + digits = 52, // there are 52 significant digits in a double + rngname = 'random', // rngname: name for Math.random and Math.seedrandom + startdenom = math.pow(width, chunks), + significance = math.pow(2, digits), + overflow = significance * 2, + mask = width - 1, + nodecrypto; // node.js crypto module, initialized at the bottom. + +// +// seedrandom() +// This is the seedrandom function described above. +// +function seedrandom(seed, options, callback) { + var key = []; + options = (options == true) ? { entropy: true } : (options || {}); + + // Flatten the seed string or build one from local entropy if needed. + var shortseed = mixkey(flatten( + options.entropy ? [seed, tostring(pool)] : + (seed == null) ? autoseed() : seed, 3), key); + + // Use the seed to initialize an ARC4 generator. + var arc4 = new ARC4(key); + + // This function returns a random double in [0, 1) that contains + // randomness in every bit of the mantissa of the IEEE 754 value. + var prng = function() { + var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48 + d = startdenom, // and denominator d = 2 ^ 48. + x = 0; // and no 'extra last byte'. + while (n < significance) { // Fill up all significant digits by + n = (n + x) * width; // shifting numerator and + d *= width; // denominator and generating a + x = arc4.g(1); // new least-significant-byte. + } + while (n >= overflow) { // To avoid rounding up, before adding + n /= 2; // last byte, shift everything + d /= 2; // right using integer math until + x >>>= 1; // we have exactly the desired bits. + } + return (n + x) / d; // Form the number within [0, 1). + }; + + prng.int32 = function() { return arc4.g(4) | 0; } + prng.quick = function() { return arc4.g(4) / 0x100000000; } + prng.double = prng; + + // Mix the randomness into accumulated entropy. + mixkey(tostring(arc4.S), pool); + + // Calling convention: what to return as a function of prng, seed, is_math. + return (options.pass || callback || + function(prng, seed, is_math_call, state) { + if (state) { + // Load the arc4 state from the given state if it has an S array. + if (state.S) { copy(state, arc4); } + // Only provide the .state method if requested via options.state. + prng.state = function() { return copy(arc4, {}); } + } + + // If called as a method of Math (Math.seedrandom()), mutate + // Math.random because that is how seedrandom.js has worked since v1.0. + if (is_math_call) { math[rngname] = prng; return seed; } + + // Otherwise, it is a newer calling convention, so return the + // prng directly. + else return prng; + })( + prng, + shortseed, + 'global' in options ? options.global : (this == math), + options.state); +} + +// +// ARC4 +// +// An ARC4 implementation. The constructor takes a key in the form of +// an array of at most (width) integers that should be 0 <= x < (width). +// +// The g(count) method returns a pseudorandom integer that concatenates +// the next (count) outputs from ARC4. Its return value is a number x +// that is in the range 0 <= x < (width ^ count). +// +function ARC4(key) { + var t, keylen = key.length, + me = this, i = 0, j = me.i = me.j = 0, s = me.S = []; + + // The empty key [] is treated as [0]. + if (!keylen) { key = [keylen++]; } + + // Set up S using the standard key scheduling algorithm. + while (i < width) { + s[i] = i++; + } + for (i = 0; i < width; i++) { + s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))]; + s[j] = t; + } + + // The "g" method returns the next (count) outputs as one number. + (me.g = function(count) { + // Using instance members instead of closure state nearly doubles speed. + var t, r = 0, + i = me.i, j = me.j, s = me.S; + while (count--) { + t = s[i = mask & (i + 1)]; + r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))]; + } + me.i = i; me.j = j; + return r; + // For robust unpredictability, the function call below automatically + // discards an initial batch of values. This is called RC4-drop[256]. + // See http://google.com/search?q=rsa+fluhrer+response&btnI + })(width); +} + +// +// copy() +// Copies internal state of ARC4 to or from a plain object. +// +function copy(f, t) { + t.i = f.i; + t.j = f.j; + t.S = f.S.slice(); + return t; +}; + +// +// flatten() +// Converts an object tree to nested arrays of strings. +// +function flatten(obj, depth) { + var result = [], typ = (typeof obj), prop; + if (depth && typ == 'object') { + for (prop in obj) { + try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {} + } + } + return (result.length ? result : typ == 'string' ? obj : obj + '\0'); +} + +// +// mixkey() +// Mixes a string seed into a key that is an array of integers, and +// returns a shortened string seed that is equivalent to the result key. +// +function mixkey(seed, key) { + var stringseed = seed + '', smear, j = 0; + while (j < stringseed.length) { + key[mask & j] = + mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++)); + } + return tostring(key); +} + +// +// autoseed() +// Returns an object for autoseeding, using window.crypto and Node crypto +// module if available. +// +function autoseed() { + try { + var out; + if (nodecrypto && (out = nodecrypto.randomBytes)) { + // The use of 'out' to remember randomBytes makes tight minified code. + out = out(width); + } else { + out = new Uint8Array(width); + (global.crypto || global.msCrypto).getRandomValues(out); + } + return tostring(out); + } catch (e) { + var browser = global.navigator, + plugins = browser && browser.plugins; + return [+new Date, global, plugins, global.screen, tostring(pool)]; + } +} + +// +// tostring() +// Converts an array of charcodes to a string +// +function tostring(a) { + return String.fromCharCode.apply(0, a); +} + +// +// When seedrandom.js is loaded, we immediately mix a few bits +// from the built-in RNG into the entropy pool. Because we do +// not want to interfere with deterministic PRNG state later, +// seedrandom will not call math.random on its own again after +// initialization. +// +mixkey(math.random(), pool); + +// +// Nodejs and AMD support: export the implementation as a module using +// either convention. +// +if ((typeof module) == 'object' && module.exports) { + module.exports = seedrandom; + // When in node.js, try using crypto package for autoseeding. + try { + nodecrypto = require('crypto'); + } catch (ex) {} +} else if ((typeof define) == 'function' && define.amd) { + define(function() { return seedrandom; }); +} else { + // When included as a plain script, set up Math.seedrandom global. + math['seed' + rngname] = seedrandom; +} + + +// End anonymous scope, and pass initial values. +})( + // global: `self` in browsers (including strict mode and web workers), + // otherwise `this` in Node and other environments + (typeof self !== 'undefined') ? self : this, + [], // pool: entropy pool starts empty + Math // math: package containing random, pow, and seedrandom +); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.min.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.min.js new file mode 100644 index 0000000..56e1afc --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/seedrandom/seedrandom.min.js @@ -0,0 +1 @@ +!function(f,a,c){var s,l=256,p="random",d=c.pow(l,6),g=c.pow(2,52),y=2*g,h=l-1;function n(n,t,r){function e(){for(var n=u.g(6),t=d,r=0;n>>=1;return(n+r)/t}var o=[],i=j(function n(t,r){var e,o=[],i=typeof t;if(r&&"object"==i)for(e in t)try{o.push(n(t[e],r-1))}catch(n){}return o.length?o:"string"==i?t:t+"\0"}((t=1==t?{entropy:!0}:t||{}).entropy?[n,S(a)]:null==n?function(){try{var n;return s&&(n=s.randomBytes)?n=n(l):(n=new Uint8Array(l),(f.crypto||f.msCrypto).getRandomValues(n)),S(n)}catch(n){var t=f.navigator,r=t&&t.plugins;return[+new Date,f,r,f.screen,S(a)]}}():n,3),o),u=new m(o);return e.int32=function(){return 0|u.g(4)},e.quick=function(){return u.g(4)/4294967296},e.double=e,j(S(u.S),a),(t.pass||r||function(n,t,r,e){return e&&(e.S&&v(e,u),n.state=function(){return v(u,{})}),r?(c[p]=n,t):n})(e,i,"global"in t?t.global:this==c,t.state)}function m(n){var t,r=n.length,u=this,e=0,o=u.i=u.j=0,i=u.S=[];for(r||(n=[r++]);e dist/tinyemitter.js -s TinyEmitter && echo 'Bundled'", + "minify": "node_modules/.bin/uglifyjs dist/tinyemitter.js -o dist/tinyemitter.min.js -m && echo 'Minified'", + "build": "npm test && npm run bundle && npm run minify", + "size": "node_modules/.bin/uglifyjs index.js -o minified.js -m && ls -l && rm minified.js" + }, + "repository": { + "type": "git", + "url": "https://github.com/scottcorgan/tiny-emitter.git" + }, + "keywords": [ + "event", + "emitter", + "pubsub", + "tiny", + "events", + "bind" + ], + "author": "Scott Corgan", + "license": "MIT", + "bugs": { + "url": "https://github.com/scottcorgan/tiny-emitter/issues" + }, + "devDependencies": { + "@tap-format/spec": "0.2.0", + "browserify": "11.2.0", + "tape": "4.2.1", + "testling": "1.7.1", + "uglify-js": "2.5.0" + }, + "testling": { + "files": [ + "test/index.js" + ], + "browsers": [ + "iexplore/10.0", + "iexplore/9.0", + "firefox/16..latest", + "chrome/22..latest", + "safari/5.1..latest", + "ipad/6.0..latest", + "iphone/6.0..latest", + "android-browser/4.2..latest" + ] + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/test/index.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/test/index.js new file mode 100644 index 0000000..7f95f62 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/test/index.js @@ -0,0 +1,217 @@ +var Emitter = require('../index'); +var emitter = require('../instance'); +var test = require('tape'); + +test('subscribes to an event', function (t) { + var emitter = new Emitter(); + emitter.on('test', function () {}); + + t.equal(emitter.e.test.length, 1, 'subscribed to event'); + t.end(); +}); + +test('subscribes to an event with context', function (t) { + var emitter = new Emitter(); + var context = { + contextValue: true + }; + + emitter.on('test', function () { + t.ok(this.contextValue, 'is in context'); + t.end(); + }, context); + + emitter.emit('test'); +}); + +test('subscibes only once to an event', function (t) { + var emitter = new Emitter(); + + emitter.once('test', function () { + t.notOk(emitter.e.test, 'removed event from list'); + t.end(); + }); + + emitter.emit('test'); +}); + +test('keeps context when subscribed only once', function (t) { + var emitter = new Emitter(); + var context = { + contextValue: true + }; + + emitter.once('test', function () { + t.ok(this.contextValue, 'is in context'); + t.notOk(emitter.e.test, 'not subscribed anymore'); + t.end(); + }, context); + + emitter.emit('test'); +}); + +test('emits an event', function (t) { + var emitter = new Emitter(); + + emitter.on('test', function () { + t.ok(true, 'triggered event'); + t.end(); + }); + + emitter.emit('test'); +}); + +test('passes all arguments to event listener', function (t) { + var emitter = new Emitter(); + + emitter.on('test', function (arg1, arg2) { + t.equal(arg1, 'arg1', 'passed the first argument'); + t.equal(arg2, 'arg2', 'passed the second argument'); + t.end(); + }); + + emitter.emit('test', 'arg1', 'arg2'); +}); + +test('unsubscribes from all events with name', function (t) { + var emitter = new Emitter(); + emitter.on('test', function () { + t.fail('should not get called'); + }); + emitter.off('test'); + emitter.emit('test') + + process.nextTick(function () { + t.end(); + }); +}); + +test('unsubscribes single event with name and callback', function (t) { + var emitter = new Emitter(); + var fn = function () { + t.fail('should not get called'); + } + + emitter.on('test', fn); + emitter.off('test', fn); + emitter.emit('test') + + process.nextTick(function () { + t.end(); + }); +}); + +// Test added by https://github.com/lazd +// From PR: https://github.com/scottcorgan/tiny-emitter/pull/6 +test('unsubscribes single event with name and callback when subscribed twice', function (t) { + var emitter = new Emitter(); + var fn = function () { + t.fail('should not get called'); + }; + + emitter.on('test', fn); + emitter.on('test', fn); + + emitter.off('test', fn); + emitter.emit('test'); + + process.nextTick(function () { + t.notOk(emitter.e['test'], 'removes all events'); + t.end(); + }); +}); + +test('unsubscribes single event with name and callback when subscribed twice out of order', function (t) { + var emitter = new Emitter(); + var calls = 0; + var fn = function () { + t.fail('should not get called'); + }; + var fn2 = function () { + calls++; + }; + + emitter.on('test', fn); + emitter.on('test', fn2); + emitter.on('test', fn); + emitter.off('test', fn); + emitter.emit('test'); + + process.nextTick(function () { + t.equal(calls, 1, 'callback was called'); + t.end(); + }); +}); + +test('removes an event inside another event', function (t) { + var emitter = new Emitter(); + + emitter.on('test', function () { + t.equal(emitter.e.test.length, 1, 'event is still in list'); + + emitter.off('test'); + + t.notOk(emitter.e.test, 0, 'event is gone from list'); + t.end(); + }); + + emitter.emit('test'); +}); + +test('event is emitted even if unsubscribed in the event callback', function (t) { + var emitter = new Emitter(); + var calls = 0; + var fn = function () { + calls += 1; + emitter.off('test', fn); + }; + + emitter.on('test', fn); + + emitter.on('test', function () { + calls += 1; + }); + + emitter.on('test', function () { + calls += 1; + }); + + process.nextTick(function () { + t.equal(calls, 3, 'all callbacks were called'); + t.end(); + }); + + emitter.emit('test'); +}); + +test('calling off before any events added does nothing', function (t) { + var emitter = new Emitter(); + emitter.off('test', function () {}); + t.end(); +}); + +test('emitting event that has not been subscribed to yet', function (t) { + var emitter = new Emitter(); + + emitter.emit('some-event', 'some message'); + t.end(); +}); + +test('unsubscribes single event with name and callback which was subscribed once', function (t) { + var emitter = new Emitter(); + var fn = function () { + t.fail('event not unsubscribed'); + } + + emitter.once('test', fn); + emitter.off('test', fn); + emitter.emit('test'); + + t.end(); +}); + +test('exports an instance', function (t) { + t.ok(emitter, 'exports an instance') + t.ok(emitter instanceof Emitter, 'an instance of the Emitter class'); + t.end(); +}); diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/yarn.lock b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/yarn.lock new file mode 100644 index 0000000..730a024 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/tiny-emitter/yarn.lock @@ -0,0 +1,1857 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@tap-format/exit@0.2.0": + version "0.2.0" + resolved "https://registry.yarnpkg.com/@tap-format/exit/-/exit-0.2.0.tgz#b58736bc55d30802c012c5adfca51b47040310cd" + dependencies: + ramda "^0.18.0" + rx "^4.0.7" + +"@tap-format/failures@0.2.0": + version "0.2.0" + resolved "https://registry.yarnpkg.com/@tap-format/failures/-/failures-0.2.0.tgz#bb6f5edc3bc3c57c62885bc7c214cc7abdfc2a07" + dependencies: + chalk "^1.1.1" + diff "^2.2.1" + figures "^1.4.0" + ramda "^0.18.0" + rx "^4.0.7" + +"@tap-format/parser@0.2.0": + version "0.2.0" + resolved "https://registry.yarnpkg.com/@tap-format/parser/-/parser-0.2.0.tgz#bdc1d95e694781157593283bb3c3fec132a3115d" + dependencies: + duplexer "^0.1.1" + js-yaml "^3.4.6" + ramda "^0.18.0" + readable-stream "^2.0.4" + rx "^4.0.7" + rx-node "^1.0.1" + split "^1.0.0" + +"@tap-format/results@0.2.0": + version "0.2.0" + resolved "https://registry.yarnpkg.com/@tap-format/results/-/results-0.2.0.tgz#192d64ac41f146fa2722db1c0a22ed80478f54fd" + dependencies: + chalk "^1.1.1" + hirestime "^1.0.6" + pretty-ms "^2.1.0" + rx "^4.0.7" + +"@tap-format/spec@0.2.0": + version "0.2.0" + resolved "https://registry.yarnpkg.com/@tap-format/spec/-/spec-0.2.0.tgz#93f7d2f0dcefe526b4776800b9bd7f80db5aaec7" + dependencies: + "@tap-format/exit" "0.2.0" + "@tap-format/failures" "0.2.0" + "@tap-format/parser" "0.2.0" + "@tap-format/results" "0.2.0" + chalk "^1.1.1" + figures "^1.4.0" + rx "^4.0.7" + +Base64@~0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/Base64/-/Base64-0.2.1.tgz#ba3a4230708e186705065e66babdd4c35cf60028" + +JSONStream@^1.0.3: + version "1.3.2" + resolved "https://registry.yarnpkg.com/JSONStream/-/JSONStream-1.3.2.tgz#c102371b6ec3a7cf3b847ca00c20bb0fce4c6dea" + dependencies: + jsonparse "^1.2.0" + through ">=2.2.7 <3" + +JSONStream@~0.6.4: + version "0.6.4" + resolved "https://registry.yarnpkg.com/JSONStream/-/JSONStream-0.6.4.tgz#4b2c8063f8f512787b2375f7ee9db69208fa2dcb" + dependencies: + jsonparse "0.0.5" + through "~2.2.7" + +JSONStream@~0.7.1: + version "0.7.4" + resolved "https://registry.yarnpkg.com/JSONStream/-/JSONStream-0.7.4.tgz#734290e41511eea7c2cfe151fbf9a563a97b9786" + dependencies: + jsonparse "0.0.5" + through ">=2.2.7 <3" + +acorn-node@^1.2.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/acorn-node/-/acorn-node-1.3.0.tgz#5f86d73346743810ef1269b901dbcbded020861b" + dependencies: + acorn "^5.4.1" + xtend "^4.0.1" + +acorn@^2.7.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-2.7.0.tgz#ab6e7d9d886aaca8b085bc3312b79a198433f0e7" + +acorn@^4.0.3: + version "4.0.13" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-4.0.13.tgz#105495ae5361d697bd195c825192e1ad7f253787" + +acorn@^5.2.1, acorn@^5.4.1: + version "5.4.1" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-5.4.1.tgz#fdc58d9d17f4a4e98d102ded826a9b9759125102" + +amdefine@>=0.0.4: + version "1.0.1" + resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" + +ansi-regex@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" + +ansi-styles@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" + +argparse@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" + dependencies: + sprintf-js "~1.0.2" + +asn1.js@^4.0.0: + version "4.10.1" + resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-4.10.1.tgz#b9c2bf5805f1e64aadeed6df3a2bfafb5a73f5a0" + dependencies: + bn.js "^4.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + +assert@~1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/assert/-/assert-1.1.2.tgz#adaa04c46bb58c6dd1f294da3eb26e6228eb6e44" + dependencies: + util "0.10.3" + +assert@~1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/assert/-/assert-1.3.0.tgz#03939a622582a812cc202320a0b9a56c9b815849" + dependencies: + util "0.10.3" + +astw@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/astw/-/astw-2.2.0.tgz#7bd41784d32493987aeb239b6b4e1c57a873b917" + dependencies: + acorn "^4.0.3" + +async@~0.2.6: + version "0.2.10" + resolved "https://registry.yarnpkg.com/async/-/async-0.2.10.tgz#b6bbe0b0674b9d719708ca38de8c237cb526c3d1" + +balanced-match@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" + +base64-js@0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-0.0.2.tgz#024f0f72afa25b75f9c0ee73cd4f55ec1bed9784" + +base64-js@0.0.8, base64-js@~0.0.4: + version "0.0.8" + resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-0.0.8.tgz#1101e9544f4a76b1bc3b26d452ca96d7a35e7978" + +bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.1.1, bn.js@^4.4.0: + version "4.11.8" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.11.8.tgz#2cde09eb5ee341f484746bb0309b3253b1b1442f" + +bops@0.0.6: + version "0.0.6" + resolved "https://registry.yarnpkg.com/bops/-/bops-0.0.6.tgz#082d1d55fa01e60dbdc2ebc2dba37f659554cf3a" + dependencies: + base64-js "0.0.2" + to-utf8 "0.0.1" + +bouncy@~3.2.0: + version "3.2.2" + resolved "https://registry.yarnpkg.com/bouncy/-/bouncy-3.2.2.tgz#82ab4ad7beae05890eed54b9af3c45394b185dc7" + dependencies: + optimist "~0.3.5" + through "~2.3.4" + +brace-expansion@^1.0.0, brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +brorand@^1.0.1: + version "1.1.0" + resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" + +browser-launcher@~0.3.2: + version "0.3.5" + resolved "https://registry.yarnpkg.com/browser-launcher/-/browser-launcher-0.3.5.tgz#d9a3663fa064d8155044991c00e61dbcb6730a16" + dependencies: + headless "~0.1.3" + merge "~1.0.0" + minimist "0.0.5" + mkdirp "~0.3.3" + plist "0.2.1" + xtend "^4.0.0" + +browser-pack@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/browser-pack/-/browser-pack-5.0.1.tgz#4197719b20c6e0aaa09451c5111e53efb6fbc18d" + dependencies: + JSONStream "^1.0.3" + combine-source-map "~0.6.1" + defined "^1.0.0" + through2 "^1.0.0" + umd "^3.0.0" + +browser-pack@~2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/browser-pack/-/browser-pack-2.0.1.tgz#5d1c527f56c582677411c4db2a128648ff6bf150" + dependencies: + JSONStream "~0.6.4" + combine-source-map "~0.3.0" + through "~2.3.4" + +browser-resolve@^1.7.0, browser-resolve@^1.7.1: + version "1.11.2" + resolved "https://registry.yarnpkg.com/browser-resolve/-/browser-resolve-1.11.2.tgz#8ff09b0a2c421718a1051c260b32e48f442938ce" + dependencies: + resolve "1.1.7" + +browser-resolve@~1.2.1, browser-resolve@~1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/browser-resolve/-/browser-resolve-1.2.4.tgz#59ae7820a82955ecd32f5fb7c468ac21c4723806" + dependencies: + resolve "0.6.3" + +browserify-aes@^1.0.0, browserify-aes@^1.0.4: + version "1.1.1" + resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.1.1.tgz#38b7ab55edb806ff2dcda1a7f1620773a477c49f" + dependencies: + buffer-xor "^1.0.3" + cipher-base "^1.0.0" + create-hash "^1.1.0" + evp_bytestokey "^1.0.3" + inherits "^2.0.1" + safe-buffer "^5.0.1" + +browserify-cipher@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.0.tgz#9988244874bf5ed4e28da95666dcd66ac8fc363a" + dependencies: + browserify-aes "^1.0.4" + browserify-des "^1.0.0" + evp_bytestokey "^1.0.0" + +browserify-des@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.0.tgz#daa277717470922ed2fe18594118a175439721dd" + dependencies: + cipher-base "^1.0.1" + des.js "^1.0.0" + inherits "^2.0.1" + +browserify-rsa@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.0.1.tgz#21e0abfaf6f2029cf2fafb133567a701d4135524" + dependencies: + bn.js "^4.1.0" + randombytes "^2.0.1" + +browserify-sign@^4.0.0: + version "4.0.4" + resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.0.4.tgz#aa4eb68e5d7b658baa6bf6a57e630cbd7a93d298" + dependencies: + bn.js "^4.1.1" + browserify-rsa "^4.0.0" + create-hash "^1.1.0" + create-hmac "^1.1.2" + elliptic "^6.0.0" + inherits "^2.0.1" + parse-asn1 "^5.0.0" + +browserify-zlib@~0.1.2: + version "0.1.4" + resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.1.4.tgz#bb35f8a519f600e0fa6b8485241c979d0141fb2d" + dependencies: + pako "~0.2.0" + +browserify@11.2.0: + version "11.2.0" + resolved "https://registry.yarnpkg.com/browserify/-/browserify-11.2.0.tgz#a11bb9dd209d79572b813f7eeeaf828a5f5c0e4e" + dependencies: + JSONStream "^1.0.3" + assert "~1.3.0" + browser-pack "^5.0.0" + browser-resolve "^1.7.1" + browserify-zlib "~0.1.2" + buffer "^3.0.0" + builtins "~0.0.3" + commondir "0.0.1" + concat-stream "~1.4.1" + console-browserify "^1.1.0" + constants-browserify "~0.0.1" + crypto-browserify "^3.0.0" + defined "^1.0.0" + deps-sort "^1.3.7" + domain-browser "~1.1.0" + duplexer2 "~0.0.2" + events "~1.0.0" + glob "^4.0.5" + has "^1.0.0" + htmlescape "^1.1.0" + https-browserify "~0.0.0" + inherits "~2.0.1" + insert-module-globals "^6.4.1" + isarray "0.0.1" + labeled-stream-splicer "^1.0.0" + module-deps "^3.7.11" + os-browserify "~0.1.1" + parents "^1.0.1" + path-browserify "~0.0.0" + process "~0.11.0" + punycode "^1.3.2" + querystring-es3 "~0.2.0" + read-only-stream "^1.1.1" + readable-stream "^2.0.2" + resolve "^1.1.4" + shasum "^1.0.0" + shell-quote "~0.0.1" + stream-browserify "^2.0.0" + stream-http "^1.2.0" + string_decoder "~0.10.0" + subarg "^1.0.0" + syntax-error "^1.1.1" + through2 "^1.0.0" + timers-browserify "^1.0.1" + tty-browserify "~0.0.0" + url "~0.10.1" + util "~0.10.1" + vm-browserify "~0.0.1" + xtend "^4.0.0" + +browserify@3.x.x: + version "3.46.1" + resolved "https://registry.yarnpkg.com/browserify/-/browserify-3.46.1.tgz#2c2e4a7f2f408178e78c223b5b57b37c2185ad8e" + dependencies: + JSONStream "~0.7.1" + assert "~1.1.0" + browser-pack "~2.0.0" + browser-resolve "~1.2.1" + browserify-zlib "~0.1.2" + buffer "~2.1.4" + builtins "~0.0.3" + commondir "0.0.1" + concat-stream "~1.4.1" + console-browserify "~1.0.1" + constants-browserify "~0.0.1" + crypto-browserify "~1.0.9" + deep-equal "~0.1.0" + defined "~0.0.0" + deps-sort "~0.1.1" + derequire "~0.8.0" + domain-browser "~1.1.0" + duplexer "~0.1.1" + events "~1.0.0" + glob "~3.2.8" + http-browserify "~1.3.1" + https-browserify "~0.0.0" + inherits "~2.0.1" + insert-module-globals "~6.0.0" + module-deps "~2.0.0" + os-browserify "~0.1.1" + parents "~0.0.1" + path-browserify "~0.0.0" + process "^0.7.0" + punycode "~1.2.3" + querystring-es3 "0.2.0" + resolve "~0.6.1" + shallow-copy "0.0.1" + shell-quote "~0.0.1" + stream-browserify "~0.1.0" + stream-combiner "~0.0.2" + string_decoder "~0.0.0" + subarg "0.0.1" + syntax-error "~1.1.0" + through2 "~0.4.1" + timers-browserify "~1.0.1" + tty-browserify "~0.0.0" + umd "~2.0.0" + url "~0.10.1" + util "~0.10.1" + vm-browserify "~0.0.1" + xtend "^3.0.0" + +buffer-xor@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" + +buffer@^3.0.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-3.6.0.tgz#a72c936f77b96bf52f5f7e7b467180628551defb" + dependencies: + base64-js "0.0.8" + ieee754 "^1.1.4" + isarray "^1.0.0" + +buffer@~2.1.4: + version "2.1.13" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-2.1.13.tgz#c88838ebf79f30b8b4a707788470bea8a62c2355" + dependencies: + base64-js "~0.0.4" + ieee754 "~1.1.1" + +builtin-status-codes@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-1.0.0.tgz#30637ee262978ac07174e16d7f82f0ad06e085ad" + +builtins@~0.0.3: + version "0.0.7" + resolved "https://registry.yarnpkg.com/builtins/-/builtins-0.0.7.tgz#355219cd6cf18dbe7c01cc7fd2dce765cfdc549a" + +callsite@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/callsite/-/callsite-1.0.0.tgz#280398e5d664bd74038b6f0905153e6e8af1bc20" + +camelcase@^1.0.2: + version "1.2.1" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" + +chalk@^1.1.1: + version "1.1.3" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98" + dependencies: + ansi-styles "^2.2.1" + escape-string-regexp "^1.0.2" + has-ansi "^2.0.0" + strip-ansi "^3.0.0" + supports-color "^2.0.0" + +cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +combine-source-map@~0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/combine-source-map/-/combine-source-map-0.3.0.tgz#d9e74f593d9cd43807312cb5d846d451efaa9eb7" + dependencies: + convert-source-map "~0.3.0" + inline-source-map "~0.3.0" + source-map "~0.1.31" + +combine-source-map@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/combine-source-map/-/combine-source-map-0.6.1.tgz#9b4a09c316033d768e0f11e029fa2730e079ad96" + dependencies: + convert-source-map "~1.1.0" + inline-source-map "~0.5.0" + lodash.memoize "~3.0.3" + source-map "~0.4.2" + +commondir@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/commondir/-/commondir-0.0.1.tgz#89f00fdcd51b519c578733fec563e6a6da7f5be2" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + +concat-stream@~0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-0.1.1.tgz#d7f4e278b90cfc4f0f3ef77fe4c03b40eb3f7900" + +concat-stream@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.0.1.tgz#018b18bc1c7d073a2dc82aa48442341a2c4dd79f" + dependencies: + bops "0.0.6" + +concat-stream@~1.4.1, concat-stream@~1.4.5: + version "1.4.10" + resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.4.10.tgz#acc3bbf5602cb8cc980c6ac840fa7d8603e3ef36" + dependencies: + inherits "~2.0.1" + readable-stream "~1.1.9" + typedarray "~0.0.5" + +console-browserify@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.1.0.tgz#f0241c45730a9fc6323b206dbf38edc741d0bb10" + dependencies: + date-now "^0.1.4" + +console-browserify@~1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.0.3.tgz#d3898d2c3a93102f364197f8874b4f92b5286a8e" + +constants-browserify@~0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-0.0.1.tgz#92577db527ba6c4cf0a4568d84bc031f441e21f2" + +convert-source-map@~0.3.0: + version "0.3.5" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-0.3.5.tgz#f1d802950af7dd2631a1febe0596550c86ab3190" + +convert-source-map@~1.1.0: + version "1.1.3" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.1.3.tgz#4829c877e9fe49b3161f3bf3673888e204699860" + +core-util-is@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" + +create-ecdh@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.0.tgz#888c723596cdf7612f6498233eebd7a35301737d" + dependencies: + bn.js "^4.1.0" + elliptic "^6.0.0" + +create-hash@^1.1.0, create-hash@^1.1.2: + version "1.1.3" + resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.1.3.tgz#606042ac8b9262750f483caddab0f5819172d8fd" + dependencies: + cipher-base "^1.0.1" + inherits "^2.0.1" + ripemd160 "^2.0.0" + sha.js "^2.4.0" + +create-hmac@^1.1.0, create-hmac@^1.1.2, create-hmac@^1.1.4: + version "1.1.6" + resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.6.tgz#acb9e221a4e17bdb076e90657c42b93e3726cf06" + dependencies: + cipher-base "^1.0.3" + create-hash "^1.1.0" + inherits "^2.0.1" + ripemd160 "^2.0.0" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +crypto-browserify@^3.0.0: + version "3.12.0" + resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec" + dependencies: + browserify-cipher "^1.0.0" + browserify-sign "^4.0.0" + create-ecdh "^4.0.0" + create-hash "^1.1.0" + create-hmac "^1.1.0" + diffie-hellman "^5.0.0" + inherits "^2.0.1" + pbkdf2 "^3.0.3" + public-encrypt "^4.0.0" + randombytes "^2.0.0" + randomfill "^1.0.3" + +crypto-browserify@~1.0.9: + version "1.0.9" + resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-1.0.9.tgz#cc5449685dfb85eb11c9828acc7cb87ab5bbfcc0" + +date-now@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/date-now/-/date-now-0.1.4.tgz#eaf439fd4d4848ad74e5cc7dbef200672b9e345b" + +decamelize@^1.0.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" + +deep-equal@~0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-0.0.0.tgz#99679d3bbd047156fcd450d3d01eeb9068691e83" + +deep-equal@~0.1.0: + version "0.1.2" + resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-0.1.2.tgz#b246c2b80a570a47c11be1d9bd1070ec878b87ce" + +deep-equal@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-1.0.1.tgz#f5d260292b660e084eff4cdbc9f08ad3247448b5" + +define-properties@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.2.tgz#83a73f2fea569898fb737193c8f873caf6d45c94" + dependencies: + foreach "^2.0.5" + object-keys "^1.0.8" + +defined@^1.0.0, defined@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/defined/-/defined-1.0.0.tgz#c98d9bcef75674188e110969151199e39b1fa693" + +defined@~0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/defined/-/defined-0.0.0.tgz#f35eea7d705e933baf13b2f03b3f83d921403b3e" + +deps-sort@^1.3.7: + version "1.3.9" + resolved "https://registry.yarnpkg.com/deps-sort/-/deps-sort-1.3.9.tgz#29dfff53e17b36aecae7530adbbbf622c2ed1a71" + dependencies: + JSONStream "^1.0.3" + shasum "^1.0.0" + subarg "^1.0.0" + through2 "^1.0.0" + +deps-sort@~0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/deps-sort/-/deps-sort-0.1.2.tgz#daa2fb614a17c9637d801e2f55339ae370f3611a" + dependencies: + JSONStream "~0.6.4" + minimist "~0.0.1" + through "~2.3.4" + +derequire@~0.8.0: + version "0.8.0" + resolved "https://registry.yarnpkg.com/derequire/-/derequire-0.8.0.tgz#c1f7f1da2cede44adede047378f03f444e9c4c0d" + dependencies: + esprima-fb "^3001.1.0-dev-harmony-fb" + esrefactor "~0.1.0" + estraverse "~1.5.0" + +des.js@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.0.0.tgz#c074d2e2aa6a8a9a07dbd61f9a15c2cd83ec8ecc" + dependencies: + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + +detective@^4.0.0: + version "4.7.1" + resolved "https://registry.yarnpkg.com/detective/-/detective-4.7.1.tgz#0eca7314338442febb6d65da54c10bb1c82b246e" + dependencies: + acorn "^5.2.1" + defined "^1.0.0" + +detective@~3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/detective/-/detective-3.1.0.tgz#77782444ab752b88ca1be2e9d0a0395f1da25eed" + dependencies: + escodegen "~1.1.0" + esprima-fb "3001.1.0-dev-harmony-fb" + +diff@^2.2.1: + version "2.2.3" + resolved "https://registry.yarnpkg.com/diff/-/diff-2.2.3.tgz#60eafd0d28ee906e4e8ff0a52c1229521033bf99" + +diffie-hellman@^5.0.0: + version "5.0.2" + resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.2.tgz#b5835739270cfe26acf632099fded2a07f209e5e" + dependencies: + bn.js "^4.1.0" + miller-rabin "^4.0.0" + randombytes "^2.0.0" + +domain-browser@~1.1.0: + version "1.1.7" + resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.1.7.tgz#867aa4b093faa05f1de08c06f4d7b21fdf8698bc" + +duplexer2@0.0.2, duplexer2@~0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/duplexer2/-/duplexer2-0.0.2.tgz#c614dcf67e2fb14995a91711e5a617e8a60a31db" + dependencies: + readable-stream "~1.1.9" + +duplexer@^0.1.1, duplexer@~0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.1.tgz#ace6ff808c1ce66b57d1ebf97977acb02334cfc1" + +ecstatic@~0.4.5: + version "0.4.13" + resolved "https://registry.yarnpkg.com/ecstatic/-/ecstatic-0.4.13.tgz#9cb6eaffe211b9c84efb3f553cde2c3002717b29" + dependencies: + ent "0.0.x" + mime "1.2.x" + optimist "~0.3.5" + +elliptic@^6.0.0: + version "6.4.0" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.4.0.tgz#cac9af8762c85836187003c8dfe193e5e2eae5df" + dependencies: + bn.js "^4.4.0" + brorand "^1.0.1" + hash.js "^1.0.0" + hmac-drbg "^1.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + minimalistic-crypto-utils "^1.0.0" + +ent@0.0.x, ent@~0.0.5: + version "0.0.7" + resolved "https://registry.yarnpkg.com/ent/-/ent-0.0.7.tgz#835d4e7f9e7a8d4921c692e9010ec976da5e9949" + +es-abstract@^1.5.0: + version "1.10.0" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.10.0.tgz#1ecb36c197842a00d8ee4c2dfd8646bb97d60864" + dependencies: + es-to-primitive "^1.1.1" + function-bind "^1.1.1" + has "^1.0.1" + is-callable "^1.1.3" + is-regex "^1.0.4" + +es-to-primitive@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.1.1.tgz#45355248a88979034b6792e19bb81f2b7975dd0d" + dependencies: + is-callable "^1.1.1" + is-date-object "^1.0.1" + is-symbol "^1.0.1" + +escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + +escodegen@~1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.1.0.tgz#c663923f6e20aad48d0c0fa49f31c6d4f49360cf" + dependencies: + esprima "~1.0.4" + estraverse "~1.5.0" + esutils "~1.0.0" + optionalDependencies: + source-map "~0.1.30" + +escope@~0.0.13: + version "0.0.16" + resolved "https://registry.yarnpkg.com/escope/-/escope-0.0.16.tgz#418c7a0afca721dafe659193fd986283e746538f" + dependencies: + estraverse ">= 0.0.2" + +esprima-fb@3001.1.0-dev-harmony-fb, esprima-fb@^3001.1.0-dev-harmony-fb: + version "3001.1.0-dev-harmony-fb" + resolved "https://registry.yarnpkg.com/esprima-fb/-/esprima-fb-3001.0001.0000-dev-harmony-fb.tgz#b77d37abcd38ea0b77426bb8bc2922ce6b426411" + +esprima@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.0.tgz#4499eddcd1110e0b218bacf2fa7f7f59f55ca804" + +esprima@~1.0.2, esprima@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-1.0.4.tgz#9f557e08fc3b4d26ece9dd34f8fbf476b62585ad" + +esrefactor@~0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/esrefactor/-/esrefactor-0.1.0.tgz#d142795a282339ab81e936b5b7a21b11bf197b13" + dependencies: + escope "~0.0.13" + esprima "~1.0.2" + estraverse "~0.0.4" + +"estraverse@>= 0.0.2": + version "4.2.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.2.0.tgz#0dee3fed31fcd469618ce7342099fc1afa0bdb13" + +estraverse@~0.0.4: + version "0.0.4" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-0.0.4.tgz#01a0932dfee574684a598af5a67c3bf9b6428db2" + +estraverse@~1.5.0: + version "1.5.1" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-1.5.1.tgz#867a3e8e58a9f84618afb6c2ddbcd916b7cbaf71" + +esutils@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-1.0.0.tgz#8151d358e20c8acc7fb745e7472c0025fe496570" + +events@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/events/-/events-1.0.2.tgz#75849dcfe93d10fb057c30055afdbd51d06a8e24" + +evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" + dependencies: + md5.js "^1.3.4" + safe-buffer "^5.1.1" + +figures@^1.4.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/figures/-/figures-1.7.0.tgz#cbe1e3affcf1cd44b80cadfed28dc793a9701d2e" + dependencies: + escape-string-regexp "^1.0.5" + object-assign "^4.1.0" + +foreach@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/foreach/-/foreach-2.0.5.tgz#0bee005018aeb260d0a3af3ae658dd0136ec1b99" + +function-bind@^1.0.2, function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" + +function-bind@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.0.2.tgz#c2873b69c5e6d7cefae47d2555172926c8c2e05e" + +glob@^4.0.5: + version "4.5.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-4.5.3.tgz#c6cb73d3226c1efef04de3c56d012f03377ee15f" + dependencies: + inflight "^1.0.4" + inherits "2" + minimatch "^2.0.1" + once "^1.3.0" + +glob@~3.2.1, glob@~3.2.8: + version "3.2.11" + resolved "https://registry.yarnpkg.com/glob/-/glob-3.2.11.tgz#4a973f635b9190f715d10987d5c00fd2815ebe3d" + dependencies: + inherits "2" + minimatch "0.3" + +glob@~5.0.3: + version "5.0.15" + resolved "https://registry.yarnpkg.com/glob/-/glob-5.0.15.tgz#1bc936b9e02f4a603fcc222ecf7633d30b8b93b1" + dependencies: + inflight "^1.0.4" + inherits "2" + minimatch "2 || 3" + once "^1.3.0" + path-is-absolute "^1.0.0" + +has-ansi@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91" + dependencies: + ansi-regex "^2.0.0" + +has@^1.0.0, has@^1.0.1, has@~1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/has/-/has-1.0.1.tgz#8461733f538b0837c9361e39a9ab9e9704dc2f28" + dependencies: + function-bind "^1.0.2" + +hash-base@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-2.0.2.tgz#66ea1d856db4e8a5470cadf6fce23ae5244ef2e1" + dependencies: + inherits "^2.0.1" + +hash-base@^3.0.0: + version "3.0.4" + resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.0.4.tgz#5fc8686847ecd73499403319a6b0a3f3f6ae4918" + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +hash.js@^1.0.0, hash.js@^1.0.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.3.tgz#340dedbe6290187151c1ea1d777a3448935df846" + dependencies: + inherits "^2.0.3" + minimalistic-assert "^1.0.0" + +headless@~0.1.3: + version "0.1.7" + resolved "https://registry.yarnpkg.com/headless/-/headless-0.1.7.tgz#6e62fae668947f88184d5c156ede7c5695a7e9c8" + +hirestime@^1.0.6: + version "1.0.7" + resolved "https://registry.yarnpkg.com/hirestime/-/hirestime-1.0.7.tgz#2d5271ea84356cec3f25da8c56a9402f8fc0a700" + +hmac-drbg@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" + dependencies: + hash.js "^1.0.3" + minimalistic-assert "^1.0.0" + minimalistic-crypto-utils "^1.0.1" + +htmlescape@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/htmlescape/-/htmlescape-1.1.1.tgz#3a03edc2214bca3b66424a3e7959349509cb0351" + +http-browserify@~1.3.1: + version "1.3.2" + resolved "https://registry.yarnpkg.com/http-browserify/-/http-browserify-1.3.2.tgz#b562c34479349a690d7a6597df495aefa8c604f5" + dependencies: + Base64 "~0.2.0" + inherits "~2.0.1" + +https-browserify@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-0.0.1.tgz#3f91365cabe60b77ed0ebba24b454e3e09d95a82" + +ieee754@^1.1.4, ieee754@~1.1.1: + version "1.1.8" + resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.8.tgz#be33d40ac10ef1926701f6f08a2d86fbfd1ad3e4" + +indexof@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d" + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: + version "2.0.3" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" + +inherits@2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1" + +inline-source-map@~0.3.0: + version "0.3.1" + resolved "https://registry.yarnpkg.com/inline-source-map/-/inline-source-map-0.3.1.tgz#a528b514e689fce90db3089e870d92f527acb5eb" + dependencies: + source-map "~0.3.0" + +inline-source-map@~0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/inline-source-map/-/inline-source-map-0.5.0.tgz#4a4c5dd8e4fb5e9b3cda60c822dfadcaee66e0af" + dependencies: + source-map "~0.4.0" + +insert-module-globals@^6.4.1: + version "6.6.3" + resolved "https://registry.yarnpkg.com/insert-module-globals/-/insert-module-globals-6.6.3.tgz#20638e29a30f9ed1ca2e3a825fbc2cba5246ddfc" + dependencies: + JSONStream "^1.0.3" + combine-source-map "~0.6.1" + concat-stream "~1.4.1" + is-buffer "^1.1.0" + lexical-scope "^1.2.0" + process "~0.11.0" + through2 "^1.0.0" + xtend "^4.0.0" + +insert-module-globals@~6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/insert-module-globals/-/insert-module-globals-6.0.0.tgz#ee8aeb9dee16819e33aa14588a558824af0c15dc" + dependencies: + JSONStream "~0.7.1" + concat-stream "~1.4.1" + lexical-scope "~1.1.0" + process "~0.6.0" + through "~2.3.4" + xtend "^3.0.0" + +is-buffer@^1.1.0: + version "1.1.6" + resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" + +is-callable@^1.1.1, is-callable@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.1.3.tgz#86eb75392805ddc33af71c92a0eedf74ee7604b2" + +is-date-object@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.1.tgz#9aa20eb6aeebbff77fbd33e74ca01b33581d3a16" + +is-finite@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-finite/-/is-finite-1.0.2.tgz#cc6677695602be550ef11e8b4aa6305342b6d0aa" + dependencies: + number-is-nan "^1.0.0" + +is-regex@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.0.4.tgz#5517489b547091b0930e095654ced25ee97e9491" + dependencies: + has "^1.0.1" + +is-symbol@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.1.tgz#3cc59f00025194b6ab2e38dbae6689256b660572" + +isarray@0.0.1, isarray@~0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" + +isarray@^1.0.0, isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" + +js-yaml@^3.4.6: + version "3.10.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.10.0.tgz#2e78441646bd4682e963f22b6e92823c309c62dc" + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +json-stable-stringify@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-0.0.1.tgz#611c23e814db375527df851193db59dd2af27f45" + dependencies: + jsonify "~0.0.0" + +jsonify@~0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.0.tgz#2c74b6ee41d93ca51b7b5aaee8f503631d252a73" + +jsonparse@0.0.5: + version "0.0.5" + resolved "https://registry.yarnpkg.com/jsonparse/-/jsonparse-0.0.5.tgz#330542ad3f0a654665b778f3eb2d9a9fa507ac64" + +jsonparse@^1.2.0: + version "1.3.1" + resolved "https://registry.yarnpkg.com/jsonparse/-/jsonparse-1.3.1.tgz#3f4dae4a91fac315f71062f8521cc239f1366280" + +labeled-stream-splicer@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/labeled-stream-splicer/-/labeled-stream-splicer-1.0.2.tgz#4615331537784981e8fd264e1f3a434c4e0ddd65" + dependencies: + inherits "^2.0.1" + isarray "~0.0.1" + stream-splicer "^1.1.0" + +lexical-scope@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/lexical-scope/-/lexical-scope-1.2.0.tgz#fcea5edc704a4b3a8796cdca419c3a0afaf22df4" + dependencies: + astw "^2.0.0" + +lexical-scope@~1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/lexical-scope/-/lexical-scope-1.1.1.tgz#debac1067435f1359d90fcfd9e94bcb2ee47b2bf" + dependencies: + astw "^2.0.0" + +lodash.memoize@~3.0.3: + version "3.0.4" + resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-3.0.4.tgz#2dcbd2c287cbc0a55cc42328bd0c736150d53e3f" + +lru-cache@2: + version "2.7.3" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-2.7.3.tgz#6d4524e8b955f95d4f5b58851ce21dd72fb4e952" + +md5.js@^1.3.4: + version "1.3.4" + resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.4.tgz#e9bdbde94a20a5ac18b04340fc5764d5b09d901d" + dependencies: + hash-base "^3.0.0" + inherits "^2.0.1" + +merge@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/merge/-/merge-1.0.0.tgz#b443ab46d837c491e6222056ab0f7933ecb3568f" + +miller-rabin@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d" + dependencies: + bn.js "^4.0.0" + brorand "^1.0.1" + +mime@1.2.x: + version "1.2.11" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.2.11.tgz#58203eed86e3a5ef17aed2b7d9ebd47f0a60dd10" + +minimalistic-assert@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.0.tgz#702be2dda6b37f4836bcb3f5db56641b64a1d3d3" + +minimalistic-crypto-utils@^1.0.0, minimalistic-crypto-utils@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" + +minimatch@0.3: + version "0.3.0" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-0.3.0.tgz#275d8edaac4f1bb3326472089e7949c8394699dd" + dependencies: + lru-cache "2" + sigmund "~1.0.0" + +"minimatch@2 || 3": + version "3.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" + dependencies: + brace-expansion "^1.1.7" + +minimatch@^2.0.1: + version "2.0.10" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-2.0.10.tgz#8d087c39c6b38c001b97fca7ce6d0e1e80afbac7" + dependencies: + brace-expansion "^1.0.0" + +minimist@0.0.5: + version "0.0.5" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.5.tgz#d7aa327bcecf518f9106ac6b8f003fa3bcea8566" + +minimist@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" + +minimist@~0.0.1, minimist@~0.0.7, minimist@~0.0.9: + version "0.0.10" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.10.tgz#de3f98543dbf96082be48ad1a0c7cda836301dcf" + +mkdirp@~0.3.3: + version "0.3.5" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.3.5.tgz#de3e5f8961c88c787ee1368df849ac4413eca8d7" + +module-deps@^3.7.11: + version "3.9.1" + resolved "https://registry.yarnpkg.com/module-deps/-/module-deps-3.9.1.tgz#ea75caf9199090d25b0d5512b5acacb96e7f87f3" + dependencies: + JSONStream "^1.0.3" + browser-resolve "^1.7.0" + concat-stream "~1.4.5" + defined "^1.0.0" + detective "^4.0.0" + duplexer2 "0.0.2" + inherits "^2.0.1" + parents "^1.0.0" + readable-stream "^1.1.13" + resolve "^1.1.3" + stream-combiner2 "~1.0.0" + subarg "^1.0.0" + through2 "^1.0.0" + xtend "^4.0.0" + +module-deps@~2.0.0: + version "2.0.6" + resolved "https://registry.yarnpkg.com/module-deps/-/module-deps-2.0.6.tgz#b999321c73ac33580f00712c0f3075fdca42563f" + dependencies: + JSONStream "~0.7.1" + browser-resolve "~1.2.4" + concat-stream "~1.4.5" + detective "~3.1.0" + duplexer2 "0.0.2" + inherits "~2.0.1" + minimist "~0.0.9" + parents "0.0.2" + readable-stream "^1.0.27-1" + resolve "~0.6.3" + stream-combiner "~0.1.0" + through2 "~0.4.1" + +number-is-nan@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" + +object-assign@^4.1.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + +object-inspect@~0.1.3: + version "0.1.3" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-0.1.3.tgz#d05a65c2e34fe8225d9fda2e484e4e47b7e2f490" + dependencies: + tape "~1.0.4" + +object-inspect@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.0.2.tgz#a97885b553e575eb4009ebc09bdda9b1cd21979a" + +object-keys@^1.0.4, object-keys@^1.0.8: + version "1.0.11" + resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.0.11.tgz#c54601778ad560f1142ce0e01bcca8b56d13426d" + +object-keys@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-0.4.0.tgz#28a6aae7428dd2c3a92f3d95f21335dd204e0336" + +once@^1.3.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + dependencies: + wrappy "1" + +optimist@~0.3.5: + version "0.3.7" + resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.3.7.tgz#c90941ad59e4273328923074d2cf2e7cbc6ec0d9" + dependencies: + wordwrap "~0.0.2" + +optimist@~0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.5.2.tgz#85c8c1454b3315e4a78947e857b1df033450bfbc" + dependencies: + wordwrap "~0.0.2" + +ordered-emitter@~0.1.0: + version "0.1.1" + resolved "https://registry.yarnpkg.com/ordered-emitter/-/ordered-emitter-0.1.1.tgz#aa20bdafbdcc1631834a350f68b4ef8eb34eed7b" + +os-browserify@~0.1.1: + version "0.1.2" + resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.1.2.tgz#49ca0293e0b19590a5f5de10c7f265a617d8fe54" + +pako@~0.2.0: + version "0.2.9" + resolved "https://registry.yarnpkg.com/pako/-/pako-0.2.9.tgz#f3f7522f4ef782348da8161bad9ecfd51bf83a75" + +parents@0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/parents/-/parents-0.0.2.tgz#67147826e497d40759aaf5ba4c99659b6034d302" + +parents@^1.0.0, parents@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parents/-/parents-1.0.1.tgz#fedd4d2bf193a77745fe71e371d73c3307d9c751" + dependencies: + path-platform "~0.11.15" + +parents@~0.0.1: + version "0.0.3" + resolved "https://registry.yarnpkg.com/parents/-/parents-0.0.3.tgz#fa212f024d9fa6318dbb6b4ce676c8be493b9c43" + dependencies: + path-platform "^0.0.1" + +parse-asn1@^5.0.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.0.tgz#37c4f9b7ed3ab65c74817b5f2480937fbf97c712" + dependencies: + asn1.js "^4.0.0" + browserify-aes "^1.0.0" + create-hash "^1.1.0" + evp_bytestokey "^1.0.0" + pbkdf2 "^3.0.3" + +parse-ms@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parse-ms/-/parse-ms-1.0.1.tgz#56346d4749d78f23430ca0c713850aef91aa361d" + +path-browserify@~0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.0.tgz#a0b870729aae214005b7d5032ec2cbbb0fb4451a" + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + +path-parse@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.5.tgz#3c1adf871ea9cd6c9431b6ea2bd74a0ff055c4c1" + +path-platform@^0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/path-platform/-/path-platform-0.0.1.tgz#b5585d7c3c463d89aa0060d86611cf1afd617e2a" + +path-platform@~0.11.15: + version "0.11.15" + resolved "https://registry.yarnpkg.com/path-platform/-/path-platform-0.11.15.tgz#e864217f74c36850f0852b78dc7bf7d4a5721bf2" + +pbkdf2@^3.0.3: + version "3.0.14" + resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.0.14.tgz#a35e13c64799b06ce15320f459c230e68e73bade" + dependencies: + create-hash "^1.1.2" + create-hmac "^1.1.4" + ripemd160 "^2.0.1" + safe-buffer "^5.0.1" + sha.js "^2.4.8" + +plist@0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/plist/-/plist-0.2.1.tgz#f3a3de07885d773e66d8a96782f1bec28cf2b2d0" + dependencies: + sax "0.1.x" + +plur@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/plur/-/plur-1.0.0.tgz#db85c6814f5e5e5a3b49efc28d604fec62975156" + +pretty-ms@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/pretty-ms/-/pretty-ms-2.1.0.tgz#4257c256df3fb0b451d6affaab021884126981dc" + dependencies: + is-finite "^1.0.1" + parse-ms "^1.0.0" + plur "^1.0.0" + +process-nextick-args@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.0.tgz#a37d732f4271b4ab1ad070d35508e8290788ffaa" + +process@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/process/-/process-0.7.0.tgz#c52208161a34adf3812344ae85d3e6150469389d" + +process@~0.11.0: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + +process@~0.5.1: + version "0.5.2" + resolved "https://registry.yarnpkg.com/process/-/process-0.5.2.tgz#1638d8a8e34c2f440a91db95ab9aeb677fc185cf" + +process@~0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/process/-/process-0.6.0.tgz#7dd9be80ffaaedd4cb628f1827f1cbab6dc0918f" + +public-encrypt@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.0.tgz#39f699f3a46560dd5ebacbca693caf7c65c18cc6" + dependencies: + bn.js "^4.1.0" + browserify-rsa "^4.0.0" + create-hash "^1.1.0" + parse-asn1 "^5.0.0" + randombytes "^2.0.1" + +punycode@1.3.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" + +punycode@^1.3.2: + version "1.4.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" + +punycode@~1.2.3: + version "1.2.4" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.2.4.tgz#54008ac972aec74175def9cba6df7fa9d3918740" + +querystring-es3@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.0.tgz#c365a08a69c443accfeb3a9deab35e3f0abaa476" + +querystring-es3@~0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" + +querystring@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620" + +ramda@^0.18.0: + version "0.18.0" + resolved "https://registry.yarnpkg.com/ramda/-/ramda-0.18.0.tgz#c6e3c5d4b9ab1f7906727fdeeb039152a85d4db3" + +randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5: + version "2.0.6" + resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.0.6.tgz#d302c522948588848a8d300c932b44c24231da80" + dependencies: + safe-buffer "^5.1.0" + +randomfill@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458" + dependencies: + randombytes "^2.0.5" + safe-buffer "^5.1.0" + +read-only-stream@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/read-only-stream/-/read-only-stream-1.1.1.tgz#5da77c799ed1388d3ef88a18471bb5924f8a0ba1" + dependencies: + readable-stream "^1.0.31" + readable-wrap "^1.0.0" + +"readable-stream@>=1.1.13-1 <1.2.0-0", readable-stream@^1.0.27-1, readable-stream@^1.0.31, readable-stream@^1.1.13, readable-stream@^1.1.13-1, readable-stream@~1.1.9: + version "1.1.14" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9" + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "0.0.1" + string_decoder "~0.10.x" + +readable-stream@^2.0.2, readable-stream@^2.0.4: + version "2.3.4" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.4.tgz#c946c3f47fa7d8eabc0b6150f4a12f69a4574071" + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.3" + isarray "~1.0.0" + process-nextick-args "~2.0.0" + safe-buffer "~5.1.1" + string_decoder "~1.0.3" + util-deprecate "~1.0.1" + +readable-stream@~1.0.17: + version "1.0.34" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.0.34.tgz#125820e34bc842d2f2aaafafe4c2916ee32c157c" + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "0.0.1" + string_decoder "~0.10.x" + +readable-wrap@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/readable-wrap/-/readable-wrap-1.0.0.tgz#3b5a211c631e12303a54991c806c17e7ae206bff" + dependencies: + readable-stream "^1.1.13-1" + +resolve@0.6.3, resolve@~0.6.1, resolve@~0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-0.6.3.tgz#dd957982e7e736debdf53b58a4dd91754575dd46" + +resolve@1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.1.7.tgz#203114d82ad2c5ed9e8e0411b3932875e889e97b" + +resolve@^1.1.3, resolve@^1.1.4: + version "1.5.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.5.0.tgz#1f09acce796c9a762579f31b2c1cc4c3cddf9f36" + dependencies: + path-parse "^1.0.5" + +resolve@~0.3.0: + version "0.3.1" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-0.3.1.tgz#34c63447c664c70598d1c9b126fc43b2a24310a4" + +resolve@~0.4.0: + version "0.4.3" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-0.4.3.tgz#dcadad202e7cacc2467e3a38800211f42f9c13df" + +resumer@~0.0.0: + version "0.0.0" + resolved "https://registry.yarnpkg.com/resumer/-/resumer-0.0.0.tgz#f1e8f461e4064ba39e82af3cdc2a8c893d076759" + dependencies: + through "~2.3.4" + +rfile@~1.0, rfile@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/rfile/-/rfile-1.0.0.tgz#59708cf90ca1e74c54c3cfc5c36fdb9810435261" + dependencies: + callsite "~1.0.0" + resolve "~0.3.0" + +ripemd160@^2.0.0, ripemd160@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.1.tgz#0f4584295c53a3628af7e6d79aca21ce57d1c6e7" + dependencies: + hash-base "^2.0.0" + inherits "^2.0.1" + +ruglify@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/ruglify/-/ruglify-1.0.0.tgz#dc8930e2a9544a274301cc9972574c0d0986b675" + dependencies: + rfile "~1.0" + uglify-js "~2.2" + +rx-node@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/rx-node/-/rx-node-1.0.2.tgz#151240725a79e857360ab06cc626799965e094de" + dependencies: + rx "*" + +rx@*, rx@^4.0.7: + version "4.1.0" + resolved "https://registry.yarnpkg.com/rx/-/rx-4.1.0.tgz#a5f13ff79ef3b740fe30aa803fb09f98805d4782" + +safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@~5.1.0, safe-buffer@~5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853" + +sax@0.1.x: + version "0.1.5" + resolved "https://registry.yarnpkg.com/sax/-/sax-0.1.5.tgz#d1829a6120fa01665eb4dbff6c43f29fd6d61471" + +sha.js@^2.4.0, sha.js@^2.4.8, sha.js@~2.4.4: + version "2.4.10" + resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.10.tgz#b1fde5cd7d11a5626638a07c604ab909cfa31f9b" + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +shallow-copy@0.0.1, shallow-copy@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/shallow-copy/-/shallow-copy-0.0.1.tgz#415f42702d73d810330292cc5ee86eae1a11a170" + +shasum@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/shasum/-/shasum-1.0.2.tgz#e7012310d8f417f4deb5712150e5678b87ae565f" + dependencies: + json-stable-stringify "~0.0.0" + sha.js "~2.4.4" + +shell-quote@~0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-0.0.1.tgz#1a41196f3c0333c482323593d6886ecf153dd986" + +shell-quote@~1.3.1: + version "1.3.3" + resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.3.3.tgz#07b8826f427c052511e8b5627639e172596e8e4b" + +sigmund@~1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/sigmund/-/sigmund-1.0.1.tgz#3ff21f198cad2175f9f3b781853fd94d0d19b590" + +source-map@0.1.34: + version "0.1.34" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.34.tgz#a7cfe89aec7b1682c3b198d0acfb47d7d090566b" + dependencies: + amdefine ">=0.0.4" + +source-map@~0.1.30, source-map@~0.1.31, source-map@~0.1.7: + version "0.1.43" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.43.tgz#c24bc146ca517c1471f5dacbe2571b2b7f9e3346" + dependencies: + amdefine ">=0.0.4" + +source-map@~0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.3.0.tgz#8586fb9a5a005e5b501e21cd18b6f21b457ad1f9" + dependencies: + amdefine ">=0.0.4" + +source-map@~0.4.0, source-map@~0.4.2: + version "0.4.4" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b" + dependencies: + amdefine ">=0.0.4" + +source-map@~0.5.1: + version "0.5.7" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" + +split@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/split/-/split-1.0.1.tgz#605bd9be303aa59fb35f9229fbea0ddec9ea07d9" + dependencies: + through "2" + +split@~0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/split/-/split-0.1.2.tgz#f0710744c453d551fc7143ead983da6014e336cc" + dependencies: + through "1" + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" + +stream-browserify@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.1.tgz#66266ee5f9bdb9940a4e4514cafb43bb71e5c9db" + dependencies: + inherits "~2.0.1" + readable-stream "^2.0.2" + +stream-browserify@~0.1.0: + version "0.1.3" + resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-0.1.3.tgz#95cf1b369772e27adaf46352265152689c6c4be9" + dependencies: + inherits "~2.0.1" + process "~0.5.1" + +stream-combiner2@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/stream-combiner2/-/stream-combiner2-1.0.2.tgz#ba72a6b50cbfabfa950fc8bc87604bd01eb60671" + dependencies: + duplexer2 "~0.0.2" + through2 "~0.5.1" + +stream-combiner@~0.0.2: + version "0.0.4" + resolved "https://registry.yarnpkg.com/stream-combiner/-/stream-combiner-0.0.4.tgz#4d5e433c185261dde623ca3f44c586bcf5c4ad14" + dependencies: + duplexer "~0.1.1" + +stream-combiner@~0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/stream-combiner/-/stream-combiner-0.1.0.tgz#0dc389a3c203f8f4d56368f95dde52eb9269b5be" + dependencies: + duplexer "~0.1.1" + through "~2.3.4" + +stream-http@^1.2.0: + version "1.7.1" + resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-1.7.1.tgz#d3d2a6e14c36a38b9dafb199aee7bbc570519978" + dependencies: + builtin-status-codes "^1.0.0" + foreach "^2.0.5" + indexof "0.0.1" + inherits "^2.0.1" + object-keys "^1.0.4" + xtend "^4.0.0" + +stream-splicer@^1.1.0: + version "1.3.2" + resolved "https://registry.yarnpkg.com/stream-splicer/-/stream-splicer-1.3.2.tgz#3c0441be15b9bf4e226275e6dc83964745546661" + dependencies: + indexof "0.0.1" + inherits "^2.0.1" + isarray "~0.0.1" + readable-stream "^1.1.13-1" + readable-wrap "^1.0.0" + through2 "^1.0.0" + +string.prototype.trim@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.1.2.tgz#d04de2c89e137f4d7d206f086b5ed2fae6be8cea" + dependencies: + define-properties "^1.1.2" + es-abstract "^1.5.0" + function-bind "^1.0.2" + +string_decoder@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.0.1.tgz#f5472d0a8d1650ec823752d24e6fd627b39bf141" + +string_decoder@~0.10.0, string_decoder@~0.10.x: + version "0.10.31" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" + +string_decoder@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.0.3.tgz#0fc67d7c141825de94282dd536bec6b9bce860ab" + dependencies: + safe-buffer "~5.1.0" + +strip-ansi@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" + dependencies: + ansi-regex "^2.0.0" + +subarg@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/subarg/-/subarg-0.0.1.tgz#3d56b07dacfbc45bbb63f7672b43b63e46368e3a" + dependencies: + minimist "~0.0.7" + +subarg@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/subarg/-/subarg-1.0.0.tgz#f62cf17581e996b48fc965699f54c06ae268b8d2" + dependencies: + minimist "^1.1.0" + +supports-color@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" + +syntax-error@^1.1.1: + version "1.4.0" + resolved "https://registry.yarnpkg.com/syntax-error/-/syntax-error-1.4.0.tgz#2d9d4ff5c064acb711594a3e3b95054ad51d907c" + dependencies: + acorn-node "^1.2.0" + +syntax-error@~1.1.0: + version "1.1.6" + resolved "https://registry.yarnpkg.com/syntax-error/-/syntax-error-1.1.6.tgz#b4549706d386cc1c1dc7c2423f18579b6cade710" + dependencies: + acorn "^2.7.0" + +tap-finished@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/tap-finished/-/tap-finished-0.0.1.tgz#08b5b543fdc04830290c6c561279552e71c4bd67" + dependencies: + tap-parser "~0.2.0" + through "~2.3.4" + +tap-parser@~0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/tap-parser/-/tap-parser-0.2.1.tgz#8e1e823f2114ee21d032e2f31e4fb642a296f50b" + dependencies: + split "~0.1.2" + +tape@4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/tape/-/tape-4.2.1.tgz#1a0ed63cc86bfaa84ebb3bb311f09d8520416216" + dependencies: + deep-equal "~1.0.0" + defined "~1.0.0" + function-bind "~1.0.2" + glob "~5.0.3" + has "~1.0.1" + inherits "~2.0.1" + object-inspect "~1.0.0" + resumer "~0.0.0" + string.prototype.trim "^1.1.1" + through "~2.3.4" + +tape@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/tape/-/tape-1.0.4.tgz#e2e8e5c6dd3f00fdc2a5e4514f62fc221e59f9c4" + dependencies: + deep-equal "~0.0.0" + defined "~0.0.0" + jsonify "~0.0.0" + through "~2.3.4" + +testling@1.7.1: + version "1.7.1" + resolved "https://registry.yarnpkg.com/testling/-/testling-1.7.1.tgz#bfcfa877c8b15dd28d920692c03d8d64ca47874e" + dependencies: + bouncy "~3.2.0" + browser-launcher "~0.3.2" + browserify "3.x.x" + concat-stream "~1.0.0" + ecstatic "~0.4.5" + ent "~0.0.5" + glob "~3.2.1" + jsonify "~0.0.0" + object-inspect "~0.1.3" + optimist "~0.5.2" + resolve "~0.4.0" + shallow-copy "~0.0.0" + shell-quote "~1.3.1" + tap-finished "~0.0.0" + win-spawn "~2.0.0" + xhr-write-stream "~0.1.2" + +through2@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/through2/-/through2-1.1.1.tgz#0847cbc4449f3405574dbdccd9bb841b83ac3545" + dependencies: + readable-stream ">=1.1.13-1 <1.2.0-0" + xtend ">=4.0.0 <4.1.0-0" + +through2@~0.4.1: + version "0.4.2" + resolved "https://registry.yarnpkg.com/through2/-/through2-0.4.2.tgz#dbf5866031151ec8352bb6c4db64a2292a840b9b" + dependencies: + readable-stream "~1.0.17" + xtend "~2.1.1" + +through2@~0.5.1: + version "0.5.1" + resolved "https://registry.yarnpkg.com/through2/-/through2-0.5.1.tgz#dfdd012eb9c700e2323fd334f38ac622ab372da7" + dependencies: + readable-stream "~1.0.17" + xtend "~3.0.0" + +through@1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/through/-/through-1.1.2.tgz#344a5425a3773314ca7e0eb6512fbafaf76c0bfe" + +through@2, "through@>=2.2.7 <3", through@~2.3.4: + version "2.3.8" + resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" + +through@~2.2.7: + version "2.2.7" + resolved "https://registry.yarnpkg.com/through/-/through-2.2.7.tgz#6e8e21200191d4eb6a99f6f010df46aa1c6eb2bd" + +timers-browserify@^1.0.1: + version "1.4.2" + resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-1.4.2.tgz#c9c58b575be8407375cb5e2462dacee74359f41d" + dependencies: + process "~0.11.0" + +timers-browserify@~1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-1.0.3.tgz#ffba70c9c12eed916fd67318e629ac6f32295551" + dependencies: + process "~0.5.1" + +to-utf8@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/to-utf8/-/to-utf8-0.0.1.tgz#d17aea72ff2fba39b9e43601be7b3ff72e089852" + +tty-browserify@~0.0.0: + version "0.0.1" + resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.1.tgz#3f05251ee17904dfd0677546670db9651682b811" + +typedarray@~0.0.5: + version "0.0.6" + resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" + +uglify-js@2.5.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.5.0.tgz#4ab5d65a4730ecb7a4fb62d3f499e2054d98fba1" + dependencies: + async "~0.2.6" + source-map "~0.5.1" + uglify-to-browserify "~1.0.0" + yargs "~3.5.4" + +uglify-js@~2.2: + version "2.2.5" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.2.5.tgz#a6e02a70d839792b9780488b7b8b184c095c99c7" + dependencies: + optimist "~0.3.5" + source-map "~0.1.7" + +uglify-js@~2.4.0: + version "2.4.24" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.4.24.tgz#fad5755c1e1577658bb06ff9ab6e548c95bebd6e" + dependencies: + async "~0.2.6" + source-map "0.1.34" + uglify-to-browserify "~1.0.0" + yargs "~3.5.4" + +uglify-to-browserify@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" + +umd@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/umd/-/umd-3.0.1.tgz#8ae556e11011f63c2596708a8837259f01b3d60e" + +umd@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/umd/-/umd-2.0.0.tgz#749683b0d514728ae0e1b6195f5774afc0ad4f8f" + dependencies: + rfile "~1.0.0" + ruglify "~1.0.0" + through "~2.3.4" + uglify-js "~2.4.0" + +url@~0.10.1: + version "0.10.3" + resolved "https://registry.yarnpkg.com/url/-/url-0.10.3.tgz#021e4d9c7705f21bbf37d03ceb58767402774c64" + dependencies: + punycode "1.3.2" + querystring "0.2.0" + +util-deprecate@~1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + +util@0.10.3, util@~0.10.1: + version "0.10.3" + resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" + dependencies: + inherits "2.0.1" + +vm-browserify@~0.0.1: + version "0.0.4" + resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-0.0.4.tgz#5d7ea45bbef9e4a6ff65f95438e0a87c357d5a73" + dependencies: + indexof "0.0.1" + +win-spawn@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/win-spawn/-/win-spawn-2.0.0.tgz#397a29130ec98d0aa0bc86baa4621393effd0b07" + +window-size@0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d" + +wordwrap@0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" + +wordwrap@~0.0.2: + version "0.0.3" + resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + +xhr-write-stream@~0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/xhr-write-stream/-/xhr-write-stream-0.1.2.tgz#e357848e0d039b411fdd5b3bf81be47ee5ce26aa" + dependencies: + concat-stream "~0.1.0" + ordered-emitter "~0.1.0" + +"xtend@>=4.0.0 <4.1.0-0", xtend@^4.0.0, xtend@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" + +xtend@^3.0.0, xtend@~3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-3.0.0.tgz#5cce7407baf642cba7becda568111c493f59665a" + +xtend@~2.1.1: + version "2.1.2" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-2.1.2.tgz#6efecc2a4dad8e6962c4901b337ce7ba87b5d28b" + dependencies: + object-keys "~0.4.0" + +yargs@~3.5.4: + version "3.5.4" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.5.4.tgz#d8aff8f665e94c34bd259bdebd1bfaf0ddd35361" + dependencies: + camelcase "^1.0.2" + decamelize "^1.0.0" + window-size "0.1.0" + wordwrap "0.0.2" diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/LICENSE b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/LICENSE new file mode 100644 index 0000000..ce81010 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-2024 Jos de Jong + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/README.md b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/README.md new file mode 100644 index 0000000..d05204e --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/README.md @@ -0,0 +1,605 @@ +# typed-function + +[![Version](https://img.shields.io/npm/v/typed-function.svg)](https://www.npmjs.com/package/typed-function) +[![Downloads](https://img.shields.io/npm/dm/typed-function.svg)](https://www.npmjs.com/package/typed-function) +[![Build Status](https://github.com/josdejong/typed-function/workflows/Node.js%20CI/badge.svg)](https://github.com/josdejong/typed-function/actions) + +Move type checking logic and type conversions outside of your function in a +flexible, organized way. Automatically throw informative errors in case of +wrong input arguments. + + +## Features + +typed-function has the following features: + +- Runtime type-checking of input arguments. +- Automatic type conversion of arguments. +- Compose typed functions with multiple signatures. +- Supports union types, any type, and variable arguments. +- Detailed error messaging. + +Supported environments: node.js, Chrome, Firefox, Safari, Opera, IE11+. + + +## Why? + +In JavaScript, functions can be called with any number and any type of arguments. +When writing a function, the easiest way is to just assume that the function +will be called with the correct input. This leaves the function's behavior on +invalid input undefined. The function may throw some error, or worse, +it may silently fail or return wrong results. Typical errors are +*TypeError: undefined is not a function* or *TypeError: Cannot call method +'request' of undefined*. These error messages are not very helpful. It can be +hard to debug them, as they can be the result of a series of nested function +calls manipulating and propagating invalid or incomplete data. + +Often, JavaScript developers add some basic type checking where it is important, +using checks like `typeof fn === 'function'`, `date instanceof Date`, and +`Array.isArray(arr)`. For functions supporting multiple signatures, +the type checking logic can grow quite a bit, and distract from the actual +logic of the function. + +For functions dealing with a considerable amount of type checking and conversion +logic, or functions facing a public API, it can be very useful to use the +`typed-function` module to handle the type-checking logic. This way: + +- Users of the function get useful and consistent error messages when using + the function wrongly. +- The function cannot silently fail or silently give wrong results due to + invalid input. +- Correct type of input is assured inside the function. The function's code + becomes easier to understand as it only contains the actual function logic. + Lower level utility functions called by the type-checked function can + possibly be kept simpler as they don't need to do additional type checking. + +It's important however not to *overuse* type checking: + +- Locking down the type of input that a function accepts can unnecessarily + limit its flexibility. Keep functions as flexible and forgiving as possible, + follow the + [robustness principle](http://en.wikipedia.org/wiki/Robustness_principle) + here: "be liberal in what you accept and conservative in what you send" + (Postel's law). +- There is no need to apply type checking to *all* functions. It may be + enough to apply type checking to one tier of public facing functions. +- There is a performance penalty involved for all type checking, so applying + it everywhere can unnecessarily worsen the performance. + + +## Load + +Install via npm: + + npm install typed-function + + +## Usage + +Here are some usage examples. More examples are available in the +[/examples](/examples) folder. + +```js +import typed from 'typed-function' + +// create a typed function +var fn1 = typed({ + 'number, string': function (a, b) { + return 'a is a number, b is a string'; + } +}); + +// create a typed function with multiple types per argument (type union) +var fn2 = typed({ + 'string, number | boolean': function (a, b) { + return 'a is a string, b is a number or a boolean'; + } +}); + +// create a typed function with any type argument +var fn3 = typed({ + 'string, any': function (a, b) { + return 'a is a string, b can be anything'; + } +}); + +// create a typed function with multiple signatures +var fn4 = typed({ + 'number': function (a) { + return 'a is a number'; + }, + 'number, boolean': function (a, b) { + return 'a is a number, b is a boolean'; + }, + 'number, number': function (a, b) { + return 'a is a number, b is a number'; + } +}); + +// create a typed function from a plain function with signature +function fnPlain (a, b) { + return 'a is a number, b is a string'; +} + +fnPlain.signature = 'number, string'; +var fn5 = typed(fnPlain); + +// use the functions +console.log(fn1(2, 'foo')); // outputs 'a is a number, b is a string' +console.log(fn4(2)); // outputs 'a is a number' + +// calling the function with a non-supported type signature will throw an error +try { + fn2('hello', 'world'); +} catch (err) { + console.log(err.toString()); + // outputs: TypeError: Unexpected type of argument. + // Expected: number or boolean, actual: string, index: 1. +} +``` + + +## Types + +typed-function has the following built-in types: + +- `null` +- `boolean` +- `number` +- `string` +- `Function` +- `Array` +- `Date` +- `RegExp` +- `Object` + +The following type expressions are supported: + +- Multiple arguments: `string, number, Function` +- Union types: `number | string` +- Variable arguments: `...number` +- Any type: `any` + +### Dispatch + +When a typed function is called, an implementation with a matching signature +is called, where conversions may be applied to actual arguments in order to +find a match. + +Among all matching signatures, the one to execute is chosen by the following +preferences, in order of priority: + +* one that does not have an `...any` parameter +* one with the fewest `any` parameters +* one that does not use conversions to match a rest parameter +* one with the fewest conversions needed to match overall +* one with no rest parameter +* If there's a rest parameter, the one with the most non-rest parameters +* The one with the largest number of preferred parameters +* The one with the earliest preferred parameter + +When this process gets to the point of comparing individual parameters, +the preference between parameters is determined by the following, in +priority order: + +* All specific types are preferred to the 'any' type +* All directly matching types are preferred to conversions +* Types earlier in the list of known types are preferred +* Among conversions, ones earlier in the list are preferred + +If none of these aspects produces a preference, then in those contexts in +which Array.sort is stable, the order implementations were listed when +the typed-function was created breaks the tie. Otherwise the dispatch may +select any of the "tied" implementations. + +## API + +### Construction + +``` +typed([name: string], ...Object.|function) +``` +A typed function can be constructed from an optional name and any number of +(additional) arguments that supply the implementations for various +signatures. Each of these further arguments must be one of the following: + +- An object with one or multiple signatures, i.e. a plain object + with string keys, each of which names a signature, and functions as + the values of those keys. + +- A previously constructed typed function, in which case all of its + signatures and corresponding implementations are merged into the new + typed function. + +- A plain function with a `signature` property whose value is a string + giving that function's signature. + +The name, if specified, must be the first argument. If not specified, the new +typed-function's name is inherited from the arguments it is composed from, +as long as any that have names agree with one another. + +If the same signature is specified by the collection of arguments more than +once with different implementations, an error will be thrown. + +#### Properties and methods of a typed function `fn` + +- `fn.name : string` + + The name of the typed function, if one was assigned at creation; otherwise, + the value of this property is the empty string. + +- `fn.signatures : Object.` + + The value of this property is a plain object. Its keys are the string + signatures on which this typed function `fn` is directly defined + (without conversions). The value for each key is the function `fn` + will call when its arguments match that signature. This property may + differ from the similar object used to create the typed function, + in that the originally provided signatures are parsed into a canonical, + more usable form: union types are split into their constituents where + possible, whitespace in the signature strings is removed, etc. + +- `fn.toString() : string` + + Returns human-readable code showing exactly what the function does. + Mostly for debugging purposes. + +### Methods of the typed package + +- `typed.convert(value: *, type: string) : *` + + Convert a value to another type. Only applicable when conversions have + been added with `typed.addConversion()` and/or `typed.addConversions()` + (see below in the method list). + Example: + + ```js + typed.addConversion({ + from: 'number', + to: 'string', + convert: function (x) { + return +x; + } + }); + + var str = typed.convert(2.3, 'string'); // '2.3' + ``` + +- `typed.create() : function` + + Create a new, isolated instance of typed-function. Example: + + ```js + import typed from 'typed-function.mjs'; // default instance + const typed2 = typed.create(); // a second instance + ``` + + This would allow you, for example, to have two different type hierarchies + for different purposes. + +- `typed.resolve(fn: typed-function, argList: Array): signature-object` + + Find the specific signature and implementation that the typed function + `fn` will call if invoked on the argument list `argList`. Returns null if + there is no matching signature. The returned signature object has + properties `params`, `test`, `fn`, and `implementation`. The difference + between the last two properties is that `fn` is the original function + supplied at typed-function creation time, whereas `implementation` is + ready to be called on this specific argList, in that it will first + perform any necessary conversions and gather arguments up into "rest" + parameters as needed. + + Thus, in the case that arguments `a0`,`a1`,`a2` (say) do match one of + the signatures of this typed function `fn`, then `fn(a0, a1, a2)` + (in a context in which `this` will be, say, `t`) does exactly the same + thing as + + `typed.resolve(fn, [a0,a1,a2]).implementation.apply(t, [a0,a1,a2])`. + + But `resolve` is useful if you want to interpose any other operation + (such as bookkeeping or additional custom error checking) between + signature selection and execution dispatch. + +- `typed.findSignature(fn: typed-function, signature: string | Array, options: object) : signature-object` + + Find the signature object (as returned by `typed.resolve` above), but + based on the specification of a signature (given either as a + comma-separated string of parameter types, or an Array of strings giving + the parameter types), rather than based on an example argument list. + + The optional third argument, is a plain object giving options controlling + the search. Currently, the only implemented option is `exact`, which if + true (defaults to false), limits the search to exact type matches, + i.e. signatures for which no conversion functions need to be called in + order to apply the function. + + Throws an error if the signature is not found. + +- `typed.find(fn: typed-function, signature: string | Array, options: object) : function` + + Convenience method that returns just the implementation from the + signature object produced by `typed.findSignature(fn, signature, options)`. + + For example: + + ```js + var fn = typed(...); + var f = typed.find(fn, ['number', 'string']); + var f = typed.find(fn, 'number, string', 'exact'); + ``` + +- `typed.referTo(...string, callback: (resolvedFunctions: ...function) => function)` + + Within the definition of a typed-function, resolve references to one or + multiple signatures of the typed-function itself. This looks like: + + ``` + typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) { + // ... use the resolved signatures fn1, fn2, ... + }); + ``` + + Example usage: + + ```js + const fn = typed({ + 'number': function (value) { + return 'Input was a number: ' + value; + }, + 'boolean': function (value) { + return 'Input was a boolean: ' + value; + }, + 'string': typed.referTo('number', 'boolean', (fnNumber, fnBoolean) => { + return function fnString(value) { + // here we use the signatures of the typed-function directly: + if (value === 'true') { + return fnBoolean(true); + } + if (value === 'false') { + return fnBoolean(false); + } + return fnNumber(parseFloat(value)); + } + }) + }); + ``` + + See also `typed.referToSelf(callback)`. + +- `typed.referToSelf(callback: (self) => function)` + + Refer to the typed-function itself. This can be used for recursive calls. + Calls to self will incur the overhead of fully re-dispatching the + typed-function. If the signature that needs to be invoked is already known, + you can use `typed.referTo(...)` instead for better performance. + + > In `typed-function@2` it was possible to use `this(...)` to reference the typed-function itself. In `typed-function@v3`, such usage is replaced with the `typed.referTo(...)` and `typed.referToSelf(...)` methods. Typed-functions are unbound in `typed-function@v3` and can be bound to another context if needed. + +- `typed.isTypedFunction(entity: any): boolean` + + Return true if the given entity appears to be a typed function + (created by any instance of typed-function), and false otherwise. It + tests for the presence of a particular property on the entity, + and so could be deceived by another object with the same property, although + the property is chosen so that's unlikely to happen unintentionally. + +- `typed.addType(type: {name: string, test: function, [, beforeObjectTest=true]): void` + + Add a new type. A type object contains a name and a test function. + The order of the types determines in which order function arguments are + type-checked, so for performance it's important to put the most used types + first. Also, if one type is contained in another, it should likely precede + it in the type order so that it won't be masked in type testing. + + Example: + + ```js + function Person(...) { + ... + } + + Person.prototype.isPerson = true; + + typed.addType({ + name: 'Person', + test: function (x) { + return x && x.isPerson === true; + } + }); + ``` + + By default, the new type will be inserted before the `Object` test + because the `Object` test also matches arrays and classes and hence + `typed-function` would never reach the new type. When `beforeObjectTest` + is `false`, the new type will be added at the end of all tests. + +- `typed.addTypes(types: TypeDef[] [, before = 'any']): void` + + Adds an list of new types. Each entry of the `types` array is an object + like the `type` argument to `typed.addType`. The optional `before` argument + is similar to `typed.addType` as well, except it should be the name of an + arbitrary type that has already been added (rather than just a boolean flag) + +- `typed.clear(): void` + + Removes all types and conversions from the typed instance. Note that any + typed-functions created before a call to `clear` will still operate, but + they may prouce unintelligible messages in case of type mismatch errors. + +- `typed.addConversion(conversion: {from: string, to: string, convert: function}, options?: { override: boolean }) : void` + + Add a new conversion. + + ```js + typed.addConversion({ + from: 'boolean', + to: 'number', + convert: function (x) { + return +x; + }); + ``` + + Note that any typed functions created before this conversion is added will + not have their arguments undergo this new conversion automatically, so it is + best to add all of your desired automatic conversions before defining any + typed functions. + +- `typed.addConversions(conversions: ConversionDef[], options?: { override: boolean }): void` + + Convenience method that adds a list of conversions. Each element in the + `conversions` array should be an object like the `conversion` argument of + `typed.addConversion`. + +- `typed.removeConversion(conversion: ConversionDef): void` + + Removes a single existing conversion. An error is thrown if there is no + conversion from and to the given types with a strictly equal convert + function as supplied in this call. + +- `typed.clearConversions(): void` + + Removes all conversions from the typed instance (leaving the types alone). + +- `typed.createError(name: string, args: Array., signatures: Array.): TypeError` + + Generates a custom error object reporting the problem with calling + the typed function of the given `name` with the given `signatures` on the + actual arguments `args`. Note the error object has an extra property `data` + giving the details of the problem. This method is primarily useful in + writing your own handler for a type mismatch (see the `typed.onMismatch` + property below), in case you have tried to recover but end up deciding + you want to throw the error that the default handler would have. + +### Properties + +- `typed.onMismatch: function` + + The handler called when a typed-function call fails to match with any + of its signatures. The handler is called with three arguments: the name + of the typed function being called, the actual argument list, and an array + of the signatures for the typed function being called. (Each signature is + an object with property 'signature' giving the actual signature and\ + property 'fn' giving the raw function for that signature.) The default + value of `onMismatch` is `typed.throwMismatchError`. + + This can be useful if you have a collection of functions and have common + behavior for any invalid call. For example, you might just want to log + the problem and continue: + + ``` + const myErrorLog = []; + typed.onMismatch = (name, args, signatures) => { + myErrorLog.push(`Invalid call of ${name} with ${args.length} arguments.`); + return null; + }; + typed.sqrt(9); // assuming definition as above, will return 3 + typed.sqrt([]); // no error will be thrown; will return null. + console.log(`There have been ${myErrorLog.length} invalid calls.`) + ``` + + Note that there is only one `onMismatch` handler at a time; assigning a + new value discards the previous handler. To restore the default behavior, + just assign `typed.onMismatch = typed.throwMismatchError`. + + Finally note that this handler fires whenever _any_ typed function call + does not match any of its signatures. You can in effect define such a + "handler" for a _single_ typed function by simply specifying an + implementation for the `...` signature: + + ``` + const lenOrNothing = typed({ + string: s => s.length, + '...': () => 0 + }); + console.log(lenOrNothing('Hello, world!')) // Output: 13 + console.log(lenOrNothing(57, 'varieties')) // Output: 0 + ``` + +- `typed.warnAgainstDeprecatedThis: boolean` + + Since `typed-function` v3, self-referencing a typed function using + `this(...)` or `this.signatures` has been deprecated and replaced with + the functions `typed.referTo` and `typed.referToSelf`. By default, all + function bodies will be scanned against this deprecated usage pattern and + an error will be thrown when encountered. To disable this validation step, + change this option to `false`. + +### Recursion + +The `this` keyword can be used to self-reference the typed-function: + +```js +var sqrt = typed({ + 'number': function (value) { + return Math.sqrt(value); + }, + 'string': function (value) { + // on the following line we self reference the typed-function using "this" + return this(parseInt(value, 10)); + } +}); + +// use the typed function +console.log(sqrt('9')); // output: 3 +``` + + +## Roadmap + +### Version 4 + +- Extend function signatures: + - Optional arguments like `'[number], array'` or like `number=, array` + - Nullable arguments like `'?Object'` +- Allow conversions to fail (for example string to number is not always + possible). Call this `fallible` or `optional`? + +### Version 5 + +- Extend function signatures: + - Constants like `'"linear" | "cubic"'`, `'0..10'`, etc. + - Object definitions like `'{name: string, age: number}'` + - Object definitions like `'Object.'` + - Array definitions like `'Array.'` +- Improve performance of both generating a typed function as well as + the performance and memory footprint of a typed function. + + +## Test + +To test the library, run: + + npm test + + +## Code style and linting + +The library is using the [standardjs](https://standardjs.com/) coding style. + +To test the code style, run: + + npm run lint + +To automatically fix most of the styling issues, run: + + npm run format + + +## Publish + +1. Describe the changes in `HISTORY.md` +2. Increase the version number in `package.json` +3. Test and build: + ``` + npm install + npm run build-and-test + ``` +4. Verify whether the generated output works correctly by opening + `./test/browserEsmBuild.html` in your browser. +5. Commit the changes +6. Merge `develop` into `master`, and push `master` +7. Create a git tag, and push this +8. publish the library: + ``` + npm publish + ``` diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs new file mode 100644 index 0000000..bc5bac5 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs @@ -0,0 +1,1907 @@ +function ok() { + return true; +} +function notOk() { + return false; +} +function undef() { + return undefined; +} +const NOT_TYPED_FUNCTION = 'Argument is not a typed-function.'; + +/** + * @typedef {{ + * params: Param[], + * fn: function, + * test: function, + * implementation: function + * }} Signature + * + * @typedef {{ + * types: Type[], + * hasAny: boolean, + * hasConversion: boolean, + * restParam: boolean + * }} Param + * + * @typedef {{ + * name: string, + * typeIndex: number, + * test: function, + * isAny: boolean, + * conversion?: ConversionDef, + * conversionIndex: number, + * }} Type + * + * @typedef {{ + * from: string, + * to: string, + * convert: function (*) : * + * }} ConversionDef + * + * @typedef {{ + * name: string, + * test: function(*) : boolean, + * isAny?: boolean + * }} TypeDef + */ + +/** + * @returns {() => function} + */ +function create() { + // data type tests + + /** + * Returns true if the argument is a non-null "plain" object + */ + function isPlainObject(x) { + return typeof x === 'object' && x !== null && x.constructor === Object; + } + const _types = [{ + name: 'number', + test: function (x) { + return typeof x === 'number'; + } + }, { + name: 'string', + test: function (x) { + return typeof x === 'string'; + } + }, { + name: 'boolean', + test: function (x) { + return typeof x === 'boolean'; + } + }, { + name: 'Function', + test: function (x) { + return typeof x === 'function'; + } + }, { + name: 'Array', + test: Array.isArray + }, { + name: 'Date', + test: function (x) { + return x instanceof Date; + } + }, { + name: 'RegExp', + test: function (x) { + return x instanceof RegExp; + } + }, { + name: 'Object', + test: isPlainObject + }, { + name: 'null', + test: function (x) { + return x === null; + } + }, { + name: 'undefined', + test: function (x) { + return x === undefined; + } + }]; + const anyType = { + name: 'any', + test: ok, + isAny: true + }; + + // Data structures to track the types. As these are local variables in + // create(), each typed universe will get its own copy, but the variables + // will only be accessible through the (closures of the) functions supplied + // as properties of the typed object, not directly. + // These will be initialized in clear() below + let typeMap; // primary store of all types + let typeList; // Array of just type names, for the sake of ordering + + // And similar data structures for the type conversions: + let nConversions = 0; + // the actual conversions are stored on a property of the destination types + + // This is a temporary object, will be replaced with a function at the end + let typed = { + createCount: 0 + }; + + /** + * Takes a type name and returns the corresponding official type object + * for that type. + * + * @param {string} typeName + * @returns {TypeDef} type + */ + function findType(typeName) { + const type = typeMap.get(typeName); + if (type) { + return type; + } + // Remainder is error handling + let message = 'Unknown type "' + typeName + '"'; + const name = typeName.toLowerCase(); + let otherName; + for (otherName of typeList) { + if (otherName.toLowerCase() === name) { + message += '. Did you mean "' + otherName + '" ?'; + break; + } + } + throw new TypeError(message); + } + + /** + * Adds an array `types` of type definitions to this typed instance. + * Each type definition should be an object with properties: + * 'name' - a string giving the name of the type; 'test' - function + * returning a boolean that tests membership in the type; and optionally + * 'isAny' - true only for the 'any' type. + * + * The second optional argument, `before`, gives the name of a type that + * these types should be added before. The new types are added in the + * order specified. + * @param {TypeDef[]} types + * @param {string | boolean} [beforeSpec='any'] before + */ + function addTypes(types) { + let beforeSpec = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any'; + const beforeIndex = beforeSpec ? findType(beforeSpec).index : typeList.length; + const newTypes = []; + for (let i = 0; i < types.length; ++i) { + if (!types[i] || typeof types[i].name !== 'string' || typeof types[i].test !== 'function') { + throw new TypeError('Object with properties {name: string, test: function} expected'); + } + const typeName = types[i].name; + if (typeMap.has(typeName)) { + throw new TypeError('Duplicate type name "' + typeName + '"'); + } + newTypes.push(typeName); + typeMap.set(typeName, { + name: typeName, + test: types[i].test, + isAny: types[i].isAny, + index: beforeIndex + i, + conversionsTo: [] // Newly added type can't have any conversions to it + }); + } + // update the typeList + const affectedTypes = typeList.slice(beforeIndex); + typeList = typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes); + // Fix the indices + for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) { + typeMap.get(typeList[i]).index = i; + } + } + + /** + * Removes all types and conversions from this typed instance. + * May cause previously constructed typed-functions to throw + * strange errors when they are called with types that do not + * match any of their signatures. + */ + function clear() { + typeMap = new Map(); + typeList = []; + nConversions = 0; + addTypes([anyType], false); + } + + // initialize the types to the default list + clear(); + addTypes(_types); + + /** + * Removes all conversions, leaving the types alone. + */ + function clearConversions() { + let typeName; + for (typeName of typeList) { + typeMap.get(typeName).conversionsTo = []; + } + nConversions = 0; + } + + /** + * Find the type names that match a value. + * @param {*} value + * @return {string[]} Array of names of types for which + * the type test matches the value. + */ + function findTypeNames(value) { + const matches = typeList.filter(name => { + const type = typeMap.get(name); + return !type.isAny && type.test(value); + }); + if (matches.length) { + return matches; + } + return ['any']; + } + + /** + * Check if an entity is a typed function created by any instance + * @param {any} entity + * @returns {boolean} + */ + function isTypedFunction(entity) { + return entity && typeof entity === 'function' && '_typedFunctionData' in entity; + } + + /** + * Find a specific signature from a (composed) typed function, for example: + * + * typed.findSignature(fn, ['number', 'string']) + * typed.findSignature(fn, 'number, string') + * typed.findSignature(fn, 'number,string', {exact: true}) + * + * This function findSignature will by default return the best match to + * the given signature, possibly employing type conversions. + * + * The (optional) third argument is a plain object giving options + * controlling the signature search. Currently the only implemented + * option is `exact`: if specified as true (default is false), only + * exact matches will be returned (i.e. signatures for which `fn` was + * directly defined). Note that a (possibly different) type matching + * `any`, or one or more instances of TYPE matching `...TYPE` are + * considered exact matches in this regard, as no conversions are used. + * + * This function returns a "signature" object, as does `typed.resolve()`, + * which is a plain object with four keys: `params` (the array of parameters + * for this signature), `fn` (the originally supplied function for this + * signature), `test` (a generated function that determines if an argument + * list matches this signature, and `implementation` (the function to call + * on a matching argument list, that performs conversions if necessary and + * then calls the originally supplied function). + * + * @param {Function} fn A typed-function + * @param {string | string[]} signature + * Signature to be found, can be an array or a comma separated string. + * @param {object} options Controls the signature search as documented + * @return {{ params: Param[], fn: function, test: function, implementation: function }} + * Returns the matching signature, or throws an error when no signature + * is found. + */ + function findSignature(fn, signature, options) { + if (!isTypedFunction(fn)) { + throw new TypeError(NOT_TYPED_FUNCTION); + } + + // Canonicalize input + const exact = options && options.exact; + const stringSignature = Array.isArray(signature) ? signature.join(',') : signature; + const params = parseSignature(stringSignature); + const canonicalSignature = stringifyParams(params); + + // First hope we get lucky and exactly match a signature + if (!exact || canonicalSignature in fn.signatures) { + // OK, we can check the internal signatures + const match = fn._typedFunctionData.signatureMap.get(canonicalSignature); + if (match) { + return match; + } + } + + // Oh well, we did not; so we have to go back and check the parameters + // one by one, in order to catch things like `any` and rest params. + // Note here we can assume there is at least one parameter, because + // the empty signature would have matched successfully above. + const nParams = params.length; + let remainingSignatures; + if (exact) { + remainingSignatures = []; + let name; + for (name in fn.signatures) { + remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name)); + } + } else { + remainingSignatures = fn._typedFunctionData.signatures; + } + for (let i = 0; i < nParams; ++i) { + const want = params[i]; + const filteredSignatures = []; + let possibility; + for (possibility of remainingSignatures) { + const have = getParamAtIndex(possibility.params, i); + if (!have || want.restParam && !have.restParam) { + continue; + } + if (!have.hasAny) { + // have to check all of the wanted types are available + const haveTypes = paramTypeSet(have); + if (want.types.some(wtype => !haveTypes.has(wtype.name))) { + continue; + } + } + // OK, this looks good + filteredSignatures.push(possibility); + } + remainingSignatures = filteredSignatures; + if (remainingSignatures.length === 0) break; + } + // Return the first remaining signature that was totally matched: + let candidate; + for (candidate of remainingSignatures) { + if (candidate.params.length <= nParams) { + return candidate; + } + } + throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))'); + } + + /** + * Find the proper function to call for a specific signature from + * a (composed) typed function, for example: + * + * typed.find(fn, ['number', 'string']) + * typed.find(fn, 'number, string') + * typed.find(fn, 'number,string', {exact: true}) + * + * This function find will by default return the best match to + * the given signature, possibly employing type conversions (and returning + * a function that will perform those conversions as needed). The + * (optional) third argument is a plain object giving options contolling + * the signature search. Currently only the option `exact` is implemented, + * which defaults to "false". If `exact` is specified as true, then only + * exact matches will be returned (i.e. signatures for which `fn` was + * directly defined). Uses of `any` and `...TYPE` are considered exact if + * no conversions are necessary to apply the corresponding function. + * + * @param {Function} fn A typed-function + * @param {string | string[]} signature + * Signature to be found, can be an array or a comma separated string. + * @param {object} options Controls the signature match as documented + * @return {function} + * Returns the function to call for the given signature, or throws an + * error if no match is found. + */ + function find(fn, signature, options) { + return findSignature(fn, signature, options).implementation; + } + + /** + * Convert a given value to another data type, specified by type name. + * + * @param {*} value + * @param {string} typeName + */ + function convert(value, typeName) { + // check conversion is needed + const type = findType(typeName); + if (type.test(value)) { + return value; + } + const conversions = type.conversionsTo; + if (conversions.length === 0) { + throw new Error('There are no conversions to ' + typeName + ' defined.'); + } + for (let i = 0; i < conversions.length; i++) { + const fromType = findType(conversions[i].from); + if (fromType.test(value)) { + return conversions[i].convert(value); + } + } + throw new Error('Cannot convert ' + value + ' to ' + typeName); + } + + /** + * Stringify parameters in a normalized way + * @param {Param[]} params + * @param {string} [','] separator + * @return {string} + */ + function stringifyParams(params) { + let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ','; + return params.map(p => p.name).join(separator); + } + + /** + * Parse a parameter, like "...number | boolean" + * @param {string} param + * @return {Param} param + */ + function parseParam(param) { + const restParam = param.indexOf('...') === 0; + const types = !restParam ? param : param.length > 3 ? param.slice(3) : 'any'; + const typeDefs = types.split('|').map(s => findType(s.trim())); + let hasAny = false; + let paramName = restParam ? '...' : ''; + const exactTypes = typeDefs.map(function (type) { + hasAny = type.isAny || hasAny; + paramName += type.name + '|'; + return { + name: type.name, + typeIndex: type.index, + test: type.test, + isAny: type.isAny, + conversion: null, + conversionIndex: -1 + }; + }); + return { + types: exactTypes, + name: paramName.slice(0, -1), + // remove trailing '|' from above + hasAny, + hasConversion: false, + restParam + }; + } + + /** + * Expands a parsed parameter with the types available from currently + * defined conversions. + * @param {Param} param + * @return {Param} param + */ + function expandParam(param) { + const typeNames = param.types.map(t => t.name); + const matchingConversions = availableConversions(typeNames); + let hasAny = param.hasAny; + let newName = param.name; + const convertibleTypes = matchingConversions.map(function (conversion) { + const type = findType(conversion.from); + hasAny = type.isAny || hasAny; + newName += '|' + conversion.from; + return { + name: conversion.from, + typeIndex: type.index, + test: type.test, + isAny: type.isAny, + conversion, + conversionIndex: conversion.index + }; + }); + return { + types: param.types.concat(convertibleTypes), + name: newName, + hasAny, + hasConversion: convertibleTypes.length > 0, + restParam: param.restParam + }; + } + + /** + * Return the set of type names in a parameter. + * Caches the result for efficiency + * + * @param {Param} param + * @return {Set} typenames + */ + function paramTypeSet(param) { + if (!param.typeSet) { + param.typeSet = new Set(); + param.types.forEach(type => param.typeSet.add(type.name)); + } + return param.typeSet; + } + + /** + * Parse a signature with comma separated parameters, + * like "number | boolean, ...string" + * + * @param {string} signature + * @return {Param[]} params + */ + function parseSignature(rawSignature) { + const params = []; + if (typeof rawSignature !== 'string') { + throw new TypeError('Signatures must be strings'); + } + const signature = rawSignature.trim(); + if (signature === '') { + return params; + } + const rawParams = signature.split(','); + for (let i = 0; i < rawParams.length; ++i) { + const parsedParam = parseParam(rawParams[i].trim()); + if (parsedParam.restParam && i !== rawParams.length - 1) { + throw new SyntaxError('Unexpected rest parameter "' + rawParams[i] + '": ' + 'only allowed for the last parameter'); + } + // if invalid, short-circuit (all the types may have been filtered) + if (parsedParam.types.length === 0) { + return null; + } + params.push(parsedParam); + } + return params; + } + + /** + * Test whether a set of params contains a restParam + * @param {Param[]} params + * @return {boolean} Returns true when the last parameter is a restParam + */ + function hasRestParam(params) { + const param = last(params); + return param ? param.restParam : false; + } + + /** + * Create a type test for a single parameter, which can have one or multiple + * types. + * @param {Param} param + * @return {function(x: *) : boolean} Returns a test function + */ + function compileTest(param) { + if (!param || param.types.length === 0) { + // nothing to do + return ok; + } else if (param.types.length === 1) { + return findType(param.types[0].name).test; + } else if (param.types.length === 2) { + const test0 = findType(param.types[0].name).test; + const test1 = findType(param.types[1].name).test; + return function or(x) { + return test0(x) || test1(x); + }; + } else { + // param.types.length > 2 + const tests = param.types.map(function (type) { + return findType(type.name).test; + }); + return function or(x) { + for (let i = 0; i < tests.length; i++) { + if (tests[i](x)) { + return true; + } + } + return false; + }; + } + } + + /** + * Create a test for all parameters of a signature + * @param {Param[]} params + * @return {function(args: Array<*>) : boolean} + */ + function compileTests(params) { + let tests, test0, test1; + if (hasRestParam(params)) { + // variable arguments like '...number' + tests = initial(params).map(compileTest); + const varIndex = tests.length; + const lastTest = compileTest(last(params)); + const testRestParam = function (args) { + for (let i = varIndex; i < args.length; i++) { + if (!lastTest(args[i])) { + return false; + } + } + return true; + }; + return function testArgs(args) { + for (let i = 0; i < tests.length; i++) { + if (!tests[i](args[i])) { + return false; + } + } + return testRestParam(args) && args.length >= varIndex + 1; + }; + } else { + // no variable arguments + if (params.length === 0) { + return function testArgs(args) { + return args.length === 0; + }; + } else if (params.length === 1) { + test0 = compileTest(params[0]); + return function testArgs(args) { + return test0(args[0]) && args.length === 1; + }; + } else if (params.length === 2) { + test0 = compileTest(params[0]); + test1 = compileTest(params[1]); + return function testArgs(args) { + return test0(args[0]) && test1(args[1]) && args.length === 2; + }; + } else { + // arguments.length > 2 + tests = params.map(compileTest); + return function testArgs(args) { + for (let i = 0; i < tests.length; i++) { + if (!tests[i](args[i])) { + return false; + } + } + return args.length === tests.length; + }; + } + } + } + + /** + * Find the parameter at a specific index of a Params list. + * Handles rest parameters. + * @param {Param[]} params + * @param {number} index + * @return {Param | null} Returns the matching parameter when found, + * null otherwise. + */ + function getParamAtIndex(params, index) { + return index < params.length ? params[index] : hasRestParam(params) ? last(params) : null; + } + + /** + * Get all type names of a parameter + * @param {Params[]} params + * @param {number} index + * @return {string[]} Returns an array with type names + */ + function getTypeSetAtIndex(params, index) { + const param = getParamAtIndex(params, index); + if (!param) { + return new Set(); + } + return paramTypeSet(param); + } + + /** + * Test whether a type is an exact type or conversion + * @param {Type} type + * @return {boolean} Returns true when + */ + function isExactType(type) { + return type.conversion === null || type.conversion === undefined; + } + + /** + * Helper function for creating error messages: create an array with + * all available types on a specific argument index. + * @param {Signature[]} signatures + * @param {number} index + * @return {string[]} Returns an array with available types + */ + function mergeExpectedParams(signatures, index) { + const typeSet = new Set(); + signatures.forEach(signature => { + const paramSet = getTypeSetAtIndex(signature.params, index); + let name; + for (name of paramSet) { + typeSet.add(name); + } + }); + return typeSet.has('any') ? ['any'] : Array.from(typeSet); + } + + /** + * Create + * @param {string} name The name of the function + * @param {array.<*>} args The actual arguments passed to the function + * @param {Signature[]} signatures A list with available signatures + * @return {TypeError} Returns a type error with additional data + * attached to it in the property `data` + */ + function createError(name, args, signatures) { + let err, expected; + const _name = name || 'unnamed'; + + // test for wrong type at some index + let matchingSignatures = signatures; + let index; + for (index = 0; index < args.length; index++) { + const nextMatchingDefs = []; + matchingSignatures.forEach(signature => { + const param = getParamAtIndex(signature.params, index); + const test = compileTest(param); + if ((index < signature.params.length || hasRestParam(signature.params)) && test(args[index])) { + nextMatchingDefs.push(signature); + } + }); + if (nextMatchingDefs.length === 0) { + // no matching signatures anymore, throw error "wrong type" + expected = mergeExpectedParams(matchingSignatures, index); + if (expected.length > 0) { + const actualTypes = findTypeNames(args[index]); + err = new TypeError('Unexpected type of argument in function ' + _name + ' (expected: ' + expected.join(' or ') + ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')'); + err.data = { + category: 'wrongType', + fn: _name, + index, + actual: actualTypes, + expected + }; + return err; + } + } else { + matchingSignatures = nextMatchingDefs; + } + } + + // test for too few arguments + const lengths = matchingSignatures.map(function (signature) { + return hasRestParam(signature.params) ? Infinity : signature.params.length; + }); + if (args.length < Math.min.apply(null, lengths)) { + expected = mergeExpectedParams(matchingSignatures, index); + err = new TypeError('Too few arguments in function ' + _name + ' (expected: ' + expected.join(' or ') + ', index: ' + args.length + ')'); + err.data = { + category: 'tooFewArgs', + fn: _name, + index: args.length, + expected + }; + return err; + } + + // test for too many arguments + const maxLength = Math.max.apply(null, lengths); + if (args.length > maxLength) { + err = new TypeError('Too many arguments in function ' + _name + ' (expected: ' + maxLength + ', actual: ' + args.length + ')'); + err.data = { + category: 'tooManyArgs', + fn: _name, + index: args.length, + expectedLength: maxLength + }; + return err; + } + + // Generic error + const argTypes = []; + for (let i = 0; i < args.length; ++i) { + argTypes.push(findTypeNames(args[i]).join('|')); + } + err = new TypeError('Arguments of type "' + argTypes.join(', ') + '" do not match any of the defined signatures of function ' + _name + '.'); + err.data = { + category: 'mismatch', + actual: argTypes + }; + return err; + } + + /** + * Find the lowest index of all exact types of a parameter (no conversions) + * @param {Param} param + * @return {number} Returns the index of the lowest type in typed.types + */ + function getLowestTypeIndex(param) { + let min = typeList.length + 1; + for (let i = 0; i < param.types.length; i++) { + if (isExactType(param.types[i])) { + min = Math.min(min, param.types[i].typeIndex); + } + } + return min; + } + + /** + * Find the lowest index of the conversion of all types of the parameter + * having a conversion + * @param {Param} param + * @return {number} Returns the lowest index of the conversions of this type + */ + function getLowestConversionIndex(param) { + let min = nConversions + 1; + for (let i = 0; i < param.types.length; i++) { + if (!isExactType(param.types[i])) { + min = Math.min(min, param.types[i].conversionIndex); + } + } + return min; + } + + /** + * Compare two params + * @param {Param} param1 + * @param {Param} param2 + * @return {number} returns -1 when param1 must get a lower + * index than param2, 1 when the opposite, + * or zero when both are equal + */ + function compareParams(param1, param2) { + // We compare a number of metrics on a param in turn: + // 1) 'any' parameters are the least preferred + if (param1.hasAny) { + if (!param2.hasAny) { + return 1; + } + } else if (param2.hasAny) { + return -1; + } + + // 2) Prefer non-rest to rest parameters + if (param1.restParam) { + if (!param2.restParam) { + return 1; + } + } else if (param2.restParam) { + return -1; + } + + // 3) Prefer exact type match to conversions + if (param1.hasConversion) { + if (!param2.hasConversion) { + return 1; + } + } else if (param2.hasConversion) { + return -1; + } + + // 4) Prefer lower type index: + const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2); + if (typeDiff < 0) { + return -1; + } + if (typeDiff > 0) { + return 1; + } + + // 5) Prefer lower conversion index + const convDiff = getLowestConversionIndex(param1) - getLowestConversionIndex(param2); + if (convDiff < 0) { + return -1; + } + if (convDiff > 0) { + return 1; + } + + // Don't have a basis for preference + return 0; + } + + /** + * Compare two signatures + * @param {Signature} signature1 + * @param {Signature} signature2 + * @return {number} returns a negative number when param1 must get a lower + * index than param2, a positive number when the opposite, + * or zero when both are equal + */ + function compareSignatures(signature1, signature2) { + const pars1 = signature1.params; + const pars2 = signature2.params; + const last1 = last(pars1); + const last2 = last(pars2); + const hasRest1 = hasRestParam(pars1); + const hasRest2 = hasRestParam(pars2); + // We compare a number of metrics on signatures in turn: + // 1) An "any rest param" is least preferred + if (hasRest1 && last1.hasAny) { + if (!hasRest2 || !last2.hasAny) { + return 1; + } + } else if (hasRest2 && last2.hasAny) { + return -1; + } + + // 2) Minimize the number of 'any' parameters + let any1 = 0; + let conv1 = 0; + let par; + for (par of pars1) { + if (par.hasAny) ++any1; + if (par.hasConversion) ++conv1; + } + let any2 = 0; + let conv2 = 0; + for (par of pars2) { + if (par.hasAny) ++any2; + if (par.hasConversion) ++conv2; + } + if (any1 !== any2) { + return any1 - any2; + } + + // 3) A conversion rest param is less preferred + if (hasRest1 && last1.hasConversion) { + if (!hasRest2 || !last2.hasConversion) { + return 1; + } + } else if (hasRest2 && last2.hasConversion) { + return -1; + } + + // 4) Minimize the number of conversions + if (conv1 !== conv2) { + return conv1 - conv2; + } + + // 5) Prefer no rest param + if (hasRest1) { + if (!hasRest2) { + return 1; + } + } else if (hasRest2) { + return -1; + } + + // 6) Prefer shorter with rest param, longer without + const lengthCriterion = (pars1.length - pars2.length) * (hasRest1 ? -1 : 1); + if (lengthCriterion !== 0) { + return lengthCriterion; + } + + // Signatures are identical in each of the above metrics. + // In particular, they are the same length. + // We can therefore compare the parameters one by one. + // First we count which signature has more preferred parameters. + const comparisons = []; + let tc = 0; + for (let i = 0; i < pars1.length; ++i) { + const thisComparison = compareParams(pars1[i], pars2[i]); + comparisons.push(thisComparison); + tc += thisComparison; + } + if (tc !== 0) { + return tc; + } + + // They have the same number of preferred parameters, so go by the + // earliest parameter in which we have a preference. + // In other words, dispatch is driven somewhat more by earlier + // parameters than later ones. + let c; + for (c of comparisons) { + if (c !== 0) { + return c; + } + } + + // It's a tossup: + return 0; + } + + /** + * Produce a list of all conversions from distinct types to one of + * the given types. + * + * @param {string[]} typeNames + * @return {ConversionDef[]} Returns the conversions that are available + * resulting in any given type (if any) + */ + function availableConversions(typeNames) { + if (typeNames.length === 0) { + return []; + } + const types = typeNames.map(findType); + if (typeNames.length > 1) { + types.sort((t1, t2) => t1.index - t2.index); + } + let matches = types[0].conversionsTo; + if (typeNames.length === 1) { + return matches; + } + matches = matches.concat([]); // shallow copy the matches + // Since the types are now in index order, we just want the first + // occurrence of any from type: + const knownTypes = new Set(typeNames); + for (let i = 1; i < types.length; ++i) { + let newMatch; + for (newMatch of types[i].conversionsTo) { + if (!knownTypes.has(newMatch.from)) { + matches.push(newMatch); + knownTypes.add(newMatch.from); + } + } + } + return matches; + } + + /** + * Preprocess arguments before calling the original function: + * - if needed convert the parameters + * - in case of rest parameters, move the rest parameters into an Array + * @param {Param[]} params + * @param {function} fn + * @return {function} Returns a wrapped function + */ + function compileArgsPreprocessing(params, fn) { + let fnConvert = fn; + + // TODO: can we make this wrapper function smarter/simpler? + + if (params.some(p => p.hasConversion)) { + const restParam = hasRestParam(params); + const compiledConversions = params.map(compileArgConversion); + fnConvert = function convertArgs() { + const args = []; + const last = restParam ? arguments.length - 1 : arguments.length; + for (let i = 0; i < last; i++) { + args[i] = compiledConversions[i](arguments[i]); + } + if (restParam) { + args[last] = arguments[last].map(compiledConversions[last]); + } + return fn.apply(this, args); + }; + } + let fnPreprocess = fnConvert; + if (hasRestParam(params)) { + const offset = params.length - 1; + fnPreprocess = function preprocessRestParams() { + return fnConvert.apply(this, slice(arguments, 0, offset).concat([slice(arguments, offset)])); + }; + } + return fnPreprocess; + } + + /** + * Compile conversion for a parameter to the right type + * @param {Param} param + * @return {function} Returns the wrapped function that will convert arguments + * + */ + function compileArgConversion(param) { + let test0, test1, conversion0, conversion1; + const tests = []; + const conversions = []; + param.types.forEach(function (type) { + if (type.conversion) { + tests.push(findType(type.conversion.from).test); + conversions.push(type.conversion.convert); + } + }); + + // create optimized conversion functions depending on the number of conversions + switch (conversions.length) { + case 0: + return function convertArg(arg) { + return arg; + }; + case 1: + test0 = tests[0]; + conversion0 = conversions[0]; + return function convertArg(arg) { + if (test0(arg)) { + return conversion0(arg); + } + return arg; + }; + case 2: + test0 = tests[0]; + test1 = tests[1]; + conversion0 = conversions[0]; + conversion1 = conversions[1]; + return function convertArg(arg) { + if (test0(arg)) { + return conversion0(arg); + } + if (test1(arg)) { + return conversion1(arg); + } + return arg; + }; + default: + return function convertArg(arg) { + for (let i = 0; i < conversions.length; i++) { + if (tests[i](arg)) { + return conversions[i](arg); + } + } + return arg; + }; + } + } + + /** + * Split params with union types in to separate params. + * + * For example: + * + * splitParams([['Array', 'Object'], ['string', 'RegExp']) + * // returns: + * // [ + * // ['Array', 'string'], + * // ['Array', 'RegExp'], + * // ['Object', 'string'], + * // ['Object', 'RegExp'] + * // ] + * + * @param {Param[]} params + * @return {Param[]} + */ + function splitParams(params) { + function _splitParams(params, index, paramsSoFar) { + if (index < params.length) { + const param = params[index]; + let resultingParams = []; + if (param.restParam) { + // split the types of a rest parameter in two: + // one with only exact types, and one with exact types and conversions + const exactTypes = param.types.filter(isExactType); + if (exactTypes.length < param.types.length) { + resultingParams.push({ + types: exactTypes, + name: '...' + exactTypes.map(t => t.name).join('|'), + hasAny: exactTypes.some(t => t.isAny), + hasConversion: false, + restParam: true + }); + } + resultingParams.push(param); + } else { + // split all the types of a regular parameter into one type per param + resultingParams = param.types.map(function (type) { + return { + types: [type], + name: type.name, + hasAny: type.isAny, + hasConversion: type.conversion, + restParam: false + }; + }); + } + + // recurse over the groups with types + return flatMap(resultingParams, function (nextParam) { + return _splitParams(params, index + 1, paramsSoFar.concat([nextParam])); + }); + } else { + // we've reached the end of the parameters. + return [paramsSoFar]; + } + } + return _splitParams(params, 0, []); + } + + /** + * Test whether two param lists represent conflicting signatures + * @param {Param[]} params1 + * @param {Param[]} params2 + * @return {boolean} Returns true when the signatures conflict, false otherwise. + */ + function conflicting(params1, params2) { + const ii = Math.max(params1.length, params2.length); + for (let i = 0; i < ii; i++) { + const typeSet1 = getTypeSetAtIndex(params1, i); + const typeSet2 = getTypeSetAtIndex(params2, i); + let overlap = false; + let name; + for (name of typeSet2) { + if (typeSet1.has(name)) { + overlap = true; + break; + } + } + if (!overlap) { + return false; + } + } + const len1 = params1.length; + const len2 = params2.length; + const restParam1 = hasRestParam(params1); + const restParam2 = hasRestParam(params2); + return restParam1 ? restParam2 ? len1 === len2 : len2 >= len1 : restParam2 ? len1 >= len2 : len1 === len2; + } + + /** + * Helper function for `resolveReferences` that returns a copy of + * functionList wihe any prior resolutions cleared out, in case we are + * recycling signatures from a prior typed function construction. + * + * @param {Array.} functionList + * @return {Array.} + */ + function clearResolutions(functionList) { + return functionList.map(fn => { + if (isReferToSelf(fn)) { + return referToSelf(fn.referToSelf.callback); + } + if (isReferTo(fn)) { + return makeReferTo(fn.referTo.references, fn.referTo.callback); + } + return fn; + }); + } + + /** + * Take a list of references, a list of functions functionList, and a + * signatureMap indexing signatures into functionList, and return + * the list of resolutions, or a false-y value if they don't all + * resolve in a valid way (yet). + * + * @param {string[]} references + * @param {Array} signatureMap + * @return {function[] | false} resolutions + */ + function collectResolutions(references, functionList, signatureMap) { + const resolvedReferences = []; + let reference; + for (reference of references) { + let resolution = signatureMap[reference]; + if (typeof resolution !== 'number') { + throw new TypeError('No definition for referenced signature "' + reference + '"'); + } + resolution = functionList[resolution]; + if (typeof resolution !== 'function') { + return false; + } + resolvedReferences.push(resolution); + } + return resolvedReferences; + } + + /** + * Resolve any references in the functionList for the typed function + * itself. The signatureMap tells which index in the functionList a + * given signature should be mapped to (for use in resolving typed.referTo) + * and self provides the destions of a typed.referToSelf. + * + * @param {Array} functionList + * @param {Object.} signatureMap + * @param {function} self The typed-function itself + * @return {Array} The list of resolved functions + */ + function resolveReferences(functionList, signatureMap, self) { + const resolvedFunctions = clearResolutions(functionList); + const isResolved = new Array(resolvedFunctions.length).fill(false); + let leftUnresolved = true; + while (leftUnresolved) { + leftUnresolved = false; + let nothingResolved = true; + for (let i = 0; i < resolvedFunctions.length; ++i) { + if (isResolved[i]) continue; + const fn = resolvedFunctions[i]; + if (isReferToSelf(fn)) { + resolvedFunctions[i] = fn.referToSelf.callback(self); + // Preserve reference in case signature is reused someday: + resolvedFunctions[i].referToSelf = fn.referToSelf; + isResolved[i] = true; + nothingResolved = false; + } else if (isReferTo(fn)) { + const resolvedReferences = collectResolutions(fn.referTo.references, resolvedFunctions, signatureMap); + if (resolvedReferences) { + resolvedFunctions[i] = fn.referTo.callback.apply(this, resolvedReferences); + // Preserve reference in case signature is reused someday: + resolvedFunctions[i].referTo = fn.referTo; + isResolved[i] = true; + nothingResolved = false; + } else { + leftUnresolved = true; + } + } + } + if (nothingResolved && leftUnresolved) { + throw new SyntaxError('Circular reference detected in resolving typed.referTo'); + } + } + return resolvedFunctions; + } + + /** + * Validate whether any of the function bodies contains a self-reference + * usage like `this(...)` or `this.signatures`. This self-referencing is + * deprecated since typed-function v3. It has been replaced with + * the functions typed.referTo and typed.referToSelf. + * @param {Object.} signaturesMap + */ + function validateDeprecatedThis(signaturesMap) { + // TODO: remove this deprecation warning logic some day (it's introduced in v3) + + // match occurrences like 'this(' and 'this.signatures' + const deprecatedThisRegex = /\bthis(\(|\.signatures\b)/; + Object.keys(signaturesMap).forEach(signature => { + const fn = signaturesMap[signature]; + if (deprecatedThisRegex.test(fn.toString())) { + throw new SyntaxError('Using `this` to self-reference a function ' + 'is deprecated since typed-function@3. ' + 'Use typed.referTo and typed.referToSelf instead.'); + } + }); + } + + /** + * Create a typed function + * @param {String} name The name for the typed function + * @param {Object.} rawSignaturesMap + * An object with one or + * multiple signatures as key, and the + * function corresponding to the + * signature as value. + * @return {function} Returns the created typed function. + */ + function createTypedFunction(name, rawSignaturesMap) { + typed.createCount++; + if (Object.keys(rawSignaturesMap).length === 0) { + throw new SyntaxError('No signatures provided'); + } + if (typed.warnAgainstDeprecatedThis) { + validateDeprecatedThis(rawSignaturesMap); + } + + // Main processing loop for signatures + const parsedParams = []; + const originalFunctions = []; + const signaturesMap = {}; + const preliminarySignatures = []; // may have duplicates from conversions + let signature; + for (signature in rawSignaturesMap) { + // A) Protect against polluted Object prototype: + if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) { + continue; + } + // B) Parse the signature + const params = parseSignature(signature); + if (!params) continue; + // C) Check for conflicts + parsedParams.forEach(function (pp) { + if (conflicting(pp, params)) { + throw new TypeError('Conflicting signatures "' + stringifyParams(pp) + '" and "' + stringifyParams(params) + '".'); + } + }); + parsedParams.push(params); + // D) Store the provided function and add conversions + const functionIndex = originalFunctions.length; + originalFunctions.push(rawSignaturesMap[signature]); + const conversionParams = params.map(expandParam); + // E) Split the signatures and collect them up + let sp; + for (sp of splitParams(conversionParams)) { + const spName = stringifyParams(sp); + preliminarySignatures.push({ + params: sp, + name: spName, + fn: functionIndex + }); + if (sp.every(p => !p.hasConversion)) { + signaturesMap[spName] = functionIndex; + } + } + } + preliminarySignatures.sort(compareSignatures); + + // Note the forward reference to theTypedFn + const resolvedFunctions = resolveReferences(originalFunctions, signaturesMap, theTypedFn); + + // Fill in the proper function for each signature + let s; + for (s in signaturesMap) { + if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) { + signaturesMap[s] = resolvedFunctions[signaturesMap[s]]; + } + } + const signatures = []; + const internalSignatureMap = new Map(); // benchmarks faster than object + for (s of preliminarySignatures) { + // Note it's only safe to eliminate duplicates like this + // _after_ the signature sorting step above; otherwise we might + // remove the wrong one. + if (!internalSignatureMap.has(s.name)) { + s.fn = resolvedFunctions[s.fn]; + signatures.push(s); + internalSignatureMap.set(s.name, s); + } + } + + // we create a highly optimized checks for the first couple of signatures with max 2 arguments + const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params); + const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params); + const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params); + const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params); + const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params); + const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params); + const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5; + + // compile the tests + for (let i = 0; i < signatures.length; ++i) { + signatures[i].test = compileTests(signatures[i].params); + } + const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk; + const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk; + const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk; + const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk; + const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk; + const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk; + const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk; + const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk; + const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk; + const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk; + const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk; + const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk; + + // compile the functions + for (let i = 0; i < signatures.length; ++i) { + signatures[i].implementation = compileArgsPreprocessing(signatures[i].params, signatures[i].fn); + } + const fn0 = ok0 ? signatures[0].implementation : undef; + const fn1 = ok1 ? signatures[1].implementation : undef; + const fn2 = ok2 ? signatures[2].implementation : undef; + const fn3 = ok3 ? signatures[3].implementation : undef; + const fn4 = ok4 ? signatures[4].implementation : undef; + const fn5 = ok5 ? signatures[5].implementation : undef; + const len0 = ok0 ? signatures[0].params.length : -1; + const len1 = ok1 ? signatures[1].params.length : -1; + const len2 = ok2 ? signatures[2].params.length : -1; + const len3 = ok3 ? signatures[3].params.length : -1; + const len4 = ok4 ? signatures[4].params.length : -1; + const len5 = ok5 ? signatures[5].params.length : -1; + + // simple and generic, but also slow + const iStart = allOk ? 6 : 0; + const iEnd = signatures.length; + // de-reference ahead for execution speed: + const tests = signatures.map(s => s.test); + const fns = signatures.map(s => s.implementation); + const generic = function generic() { + 'use strict'; + + for (let i = iStart; i < iEnd; i++) { + if (tests[i](arguments)) { + return fns[i].apply(this, arguments); + } + } + return typed.onMismatch(name, arguments, signatures); + }; + + // create the typed function + // fast, specialized version. Falls back to the slower, generic one if needed + function theTypedFn(arg0, arg1) { + 'use strict'; + + if (arguments.length === len0 && test00(arg0) && test01(arg1)) { + return fn0.apply(this, arguments); + } + if (arguments.length === len1 && test10(arg0) && test11(arg1)) { + return fn1.apply(this, arguments); + } + if (arguments.length === len2 && test20(arg0) && test21(arg1)) { + return fn2.apply(this, arguments); + } + if (arguments.length === len3 && test30(arg0) && test31(arg1)) { + return fn3.apply(this, arguments); + } + if (arguments.length === len4 && test40(arg0) && test41(arg1)) { + return fn4.apply(this, arguments); + } + if (arguments.length === len5 && test50(arg0) && test51(arg1)) { + return fn5.apply(this, arguments); + } + return generic.apply(this, arguments); + } + + // attach name the typed function + try { + Object.defineProperty(theTypedFn, 'name', { + value: name + }); + } catch (err) { + // old browsers do not support Object.defineProperty and some don't support setting the name property + // the function name is not essential for the functioning, it's mostly useful for debugging, + // so it's fine to have unnamed functions. + } + + // attach signatures to the function. + // This property is close to the original collection of signatures + // used to create the typed-function, just with unions split: + theTypedFn.signatures = signaturesMap; + + // Store internal data for functions like resolve, find, etc. + // Also serves as the flag that this is a typed-function + theTypedFn._typedFunctionData = { + signatures, + signatureMap: internalSignatureMap + }; + return theTypedFn; + } + + /** + * Action to take on mismatch + * @param {string} name Name of function that was attempted to be called + * @param {Array} args Actual arguments to the call + * @param {Array} signatures Known signatures of the named typed-function + */ + function _onMismatch(name, args, signatures) { + throw createError(name, args, signatures); + } + + /** + * Return all but the last items of an array or function Arguments + * @param {Array | Arguments} arr + * @return {Array} + */ + function initial(arr) { + return slice(arr, 0, arr.length - 1); + } + + /** + * return the last item of an array or function Arguments + * @param {Array | Arguments} arr + * @return {*} + */ + function last(arr) { + return arr[arr.length - 1]; + } + + /** + * Slice an array or function Arguments + * @param {Array | Arguments | IArguments} arr + * @param {number} start + * @param {number} [end] + * @return {Array} + */ + function slice(arr, start, end) { + return Array.prototype.slice.call(arr, start, end); + } + + /** + * Return the first item from an array for which test(arr[i]) returns true + * @param {Array} arr + * @param {function} test + * @return {* | undefined} Returns the first matching item + * or undefined when there is no match + */ + function findInArray(arr, test) { + for (let i = 0; i < arr.length; i++) { + if (test(arr[i])) { + return arr[i]; + } + } + return undefined; + } + + /** + * Flat map the result invoking a callback for every item in an array. + * https://gist.github.com/samgiles/762ee337dff48623e729 + * @param {Array} arr + * @param {function} callback + * @return {Array} + */ + function flatMap(arr, callback) { + return Array.prototype.concat.apply([], arr.map(callback)); + } + + /** + * Create a reference callback to one or multiple signatures + * + * Syntax: + * + * typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) { + * // ... + * }) + * + * @returns {{referTo: {references: string[], callback}}} + */ + function referTo() { + const references = initial(arguments).map(s => stringifyParams(parseSignature(s))); + const callback = last(arguments); + if (typeof callback !== 'function') { + throw new TypeError('Callback function expected as last argument'); + } + return makeReferTo(references, callback); + } + function makeReferTo(references, callback) { + return { + referTo: { + references, + callback + } + }; + } + + /** + * Create a reference callback to the typed-function itself + * + * @param {(self: function) => function} callback + * @returns {{referToSelf: { callback: function }}} + */ + function referToSelf(callback) { + if (typeof callback !== 'function') { + throw new TypeError('Callback function expected as first argument'); + } + return { + referToSelf: { + callback + } + }; + } + + /** + * Test whether something is a referTo object, holding a list with reference + * signatures and a callback. + * + * @param {Object | function} objectOrFn + * @returns {boolean} + */ + function isReferTo(objectOrFn) { + return objectOrFn && typeof objectOrFn.referTo === 'object' && Array.isArray(objectOrFn.referTo.references) && typeof objectOrFn.referTo.callback === 'function'; + } + + /** + * Test whether something is a referToSelf object, holding a callback where + * to pass `self`. + * + * @param {Object | function} objectOrFn + * @returns {boolean} + */ + function isReferToSelf(objectOrFn) { + return objectOrFn && typeof objectOrFn.referToSelf === 'object' && typeof objectOrFn.referToSelf.callback === 'function'; + } + + /** + * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw + * an error in case (C). + * + * @param { string | undefined } nameSoFar + * @param { string | undefined } newName + * @returns { string } updated name + */ + function checkName(nameSoFar, newName) { + if (!nameSoFar) { + return newName; + } + if (newName && newName !== nameSoFar) { + const err = new Error('Function names do not match (expected: ' + nameSoFar + ', actual: ' + newName + ')'); + err.data = { + actual: newName, + expected: nameSoFar + }; + throw err; + } + return nameSoFar; + } + + /** + * Retrieve the implied name from an object with signature keys + * and function values, checking whether all value names match + * + * @param { {string: function} } obj + */ + function getObjectName(obj) { + let name; + for (const key in obj) { + // Only pay attention to own properties, and only if their values + // are typed functions or functions with a signature property + if (Object.prototype.hasOwnProperty.call(obj, key) && (isTypedFunction(obj[key]) || typeof obj[key].signature === 'string')) { + name = checkName(name, obj[key].name); + } + } + return name; + } + + /** + * Copy all of the signatures from the second argument into the first, + * which is modified by side effect, checking for conflicts + * + * @param {Object.} dest + * @param {Object.} source + */ + function mergeSignatures(dest, source) { + let key; + for (key in source) { + if (Object.prototype.hasOwnProperty.call(source, key)) { + if (key in dest) { + if (source[key] !== dest[key]) { + const err = new Error('Signature "' + key + '" is defined twice'); + err.data = { + signature: key, + sourceFunction: source[key], + destFunction: dest[key] + }; + throw err; + } + // else: both signatures point to the same function, that's fine + } + dest[key] = source[key]; + } + } + } + const saveTyped = typed; + + /** + * Originally the main function was a typed function itself, but then + * it might not be able to generate error messages if the client + * replaced the type system with different names. + * + * Main entry: typed([name], functions/objects with signatures...) + * + * Assembles and returns a new typed-function from the given items + * that provide signatures and implementations, each of which may be + * * a plain object mapping (string) signatures to implementing functions, + * * a previously constructed typed function, or + * * any other single function with a string-valued property `signature`. + * The name of the resulting typed-function will be given by the + * string-valued name argument if present, or if not, by the name + * of any of the arguments that have one, as long as any that do are + * consistent with each other. If no name is specified, the name will be + * an empty string. + * + * @param {string} maybeName [optional] + * @param {(function|object)[]} signature providers + * @returns {typed-function} + */ + typed = function (maybeName) { + const named = typeof maybeName === 'string'; + const start = named ? 1 : 0; + let name = named ? maybeName : ''; + const allSignatures = {}; + for (let i = start; i < arguments.length; ++i) { + const item = arguments[i]; + let theseSignatures = {}; + let thisName; + if (typeof item === 'function') { + thisName = item.name; + if (typeof item.signature === 'string') { + // Case 1: Ordinary function with a string 'signature' property + theseSignatures[item.signature] = item; + } else if (isTypedFunction(item)) { + // Case 2: Existing typed function + theseSignatures = item.signatures; + } + } else if (isPlainObject(item)) { + // Case 3: Plain object, assume keys = signatures, values = functions + theseSignatures = item; + if (!named) { + thisName = getObjectName(item); + } + } + if (Object.keys(theseSignatures).length === 0) { + const err = new TypeError('Argument to \'typed\' at index ' + i + ' is not a (typed) function, ' + 'nor an object with signatures as keys and functions as values.'); + err.data = { + index: i, + argument: item + }; + throw err; + } + if (!named) { + name = checkName(name, thisName); + } + mergeSignatures(allSignatures, theseSignatures); + } + return createTypedFunction(name || '', allSignatures); + }; + typed.create = create; + typed.createCount = saveTyped.createCount; + typed.onMismatch = _onMismatch; + typed.throwMismatchError = _onMismatch; + typed.createError = createError; + typed.clear = clear; + typed.clearConversions = clearConversions; + typed.addTypes = addTypes; + typed._findType = findType; // For unit testing only + typed.referTo = referTo; + typed.referToSelf = referToSelf; + typed.convert = convert; + typed.findSignature = findSignature; + typed.find = find; + typed.isTypedFunction = isTypedFunction; + typed.warnAgainstDeprecatedThis = true; + + /** + * add a type (convenience wrapper for typed.addTypes) + * @param {{name: string, test: function}} type + * @param {boolean} [beforeObjectTest=true] + * If true, the new test will be inserted before + * the test with name 'Object' (if any), since + * tests for Object match Array and classes too. + */ + typed.addType = function (type, beforeObjectTest) { + let before = 'any'; + if (beforeObjectTest !== false && typeMap.has('Object')) { + before = 'Object'; + } + typed.addTypes([type], before); + }; + + /** + * Verify that the ConversionDef conversion has a valid format. + * + * @param {conversionDef} conversion + * @return {void} + * @throws {TypeError|SyntaxError} + */ + function _validateConversion(conversion) { + if (!conversion || typeof conversion.from !== 'string' || typeof conversion.to !== 'string' || typeof conversion.convert !== 'function') { + throw new TypeError('Object with properties {from: string, to: string, convert: function} expected'); + } + if (conversion.to === conversion.from) { + throw new SyntaxError('Illegal to define conversion from "' + conversion.from + '" to itself.'); + } + } + + /** + * Add a conversion + * + * @param {ConversionDef} conversion + * @param {{override: boolean}} [options] + * @returns {void} + * @throws {TypeError} + */ + typed.addConversion = function (conversion) { + let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : { + override: false + }; + _validateConversion(conversion); + const to = findType(conversion.to); + const existing = to.conversionsTo.find(other => other.from === conversion.from); + if (existing) { + if (options && options.override) { + typed.removeConversion({ + from: existing.from, + to: conversion.to, + convert: existing.convert + }); + } else { + throw new Error('There is already a conversion from "' + conversion.from + '" to "' + to.name + '"'); + } + } + to.conversionsTo.push({ + from: conversion.from, + convert: conversion.convert, + index: nConversions++ + }); + }; + + /** + * Convenience wrapper to call addConversion on each conversion in a list. + * + * @param {ConversionDef[]} conversions + * @param {{override: boolean}} [options] + * @returns {void} + * @throws {TypeError} + */ + typed.addConversions = function (conversions, options) { + conversions.forEach(conversion => typed.addConversion(conversion, options)); + }; + + /** + * Remove the specified conversion. The format is the same as for + * addConversion, and the convert function must match or an error + * is thrown. + * + * @param {{from: string, to: string, convert: function}} conversion + * @returns {void} + * @throws {TypeError|SyntaxError|Error} + */ + typed.removeConversion = function (conversion) { + _validateConversion(conversion); + const to = findType(conversion.to); + const existingConversion = findInArray(to.conversionsTo, c => c.from === conversion.from); + if (!existingConversion) { + throw new Error('Attempt to remove nonexistent conversion from ' + conversion.from + ' to ' + conversion.to); + } + if (existingConversion.convert !== conversion.convert) { + throw new Error('Conversion to remove does not match existing conversion'); + } + const index = to.conversionsTo.indexOf(existingConversion); + to.conversionsTo.splice(index, 1); + }; + + /** + * Produce the specific signature that a typed function + * will execute on the given arguments. Here, a "signature" is an + * object with properties 'params', 'test', 'fn', and 'implementation'. + * This last property is a function that converts params as necessary + * and then calls 'fn'. Returns null if there is no matching signature. + * @param {typed-function} tf + * @param {any[]} argList + * @returns {{params: string, test: function, fn: function, implementation: function}} + */ + typed.resolve = function (tf, argList) { + if (!isTypedFunction(tf)) { + throw new TypeError(NOT_TYPED_FUNCTION); + } + const sigs = tf._typedFunctionData.signatures; + for (let i = 0; i < sigs.length; ++i) { + if (sigs[i].test(argList)) { + return sigs[i]; + } + } + return null; + }; + return typed; +} +export default create(); +//# sourceMappingURL=typed-function.mjs.map \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs.map b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs.map new file mode 100644 index 0000000..5ba6e4d --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/esm/typed-function.mjs.map @@ -0,0 +1 @@ +{"version":3,"file":"typed-function.mjs","names":["ok","notOk","undef","undefined","NOT_TYPED_FUNCTION","create","isPlainObject","x","constructor","Object","_types","name","test","Array","isArray","Date","RegExp","anyType","isAny","typeMap","typeList","nConversions","typed","createCount","findType","typeName","type","get","message","toLowerCase","otherName","TypeError","addTypes","types","beforeSpec","arguments","length","beforeIndex","index","newTypes","i","has","push","set","conversionsTo","affectedTypes","slice","concat","clear","Map","clearConversions","findTypeNames","value","matches","filter","isTypedFunction","entity","findSignature","fn","signature","options","exact","stringSignature","join","params","parseSignature","canonicalSignature","stringifyParams","signatures","match","_typedFunctionData","signatureMap","nParams","remainingSignatures","want","filteredSignatures","possibility","have","getParamAtIndex","restParam","hasAny","haveTypes","paramTypeSet","some","wtype","candidate","find","implementation","convert","conversions","Error","fromType","from","separator","map","p","parseParam","param","indexOf","typeDefs","split","s","trim","paramName","exactTypes","typeIndex","conversion","conversionIndex","hasConversion","expandParam","typeNames","t","matchingConversions","availableConversions","newName","convertibleTypes","typeSet","Set","forEach","add","rawSignature","rawParams","parsedParam","SyntaxError","hasRestParam","last","compileTest","test0","test1","or","tests","compileTests","initial","varIndex","lastTest","testRestParam","args","testArgs","getTypeSetAtIndex","isExactType","mergeExpectedParams","paramSet","createError","err","expected","_name","matchingSignatures","nextMatchingDefs","actualTypes","data","category","actual","lengths","Infinity","Math","min","apply","maxLength","max","expectedLength","argTypes","getLowestTypeIndex","getLowestConversionIndex","compareParams","param1","param2","typeDiff","convDiff","compareSignatures","signature1","signature2","pars1","pars2","last1","last2","hasRest1","hasRest2","any1","conv1","par","any2","conv2","lengthCriterion","comparisons","tc","thisComparison","c","sort","t1","t2","knownTypes","newMatch","compileArgsPreprocessing","fnConvert","compiledConversions","compileArgConversion","convertArgs","fnPreprocess","offset","preprocessRestParams","conversion0","conversion1","convertArg","arg","splitParams","_splitParams","paramsSoFar","resultingParams","flatMap","nextParam","conflicting","params1","params2","ii","typeSet1","typeSet2","overlap","len1","len2","restParam1","restParam2","clearResolutions","functionList","isReferToSelf","referToSelf","callback","isReferTo","makeReferTo","referTo","references","collectResolutions","resolvedReferences","reference","resolution","resolveReferences","self","resolvedFunctions","isResolved","fill","leftUnresolved","nothingResolved","validateDeprecatedThis","signaturesMap","deprecatedThisRegex","keys","toString","createTypedFunction","rawSignaturesMap","warnAgainstDeprecatedThis","parsedParams","originalFunctions","preliminarySignatures","prototype","hasOwnProperty","call","pp","functionIndex","conversionParams","sp","spName","every","theTypedFn","internalSignatureMap","ok0","ok1","ok2","ok3","ok4","ok5","allOk","test00","test10","test20","test30","test40","test50","test01","test11","test21","test31","test41","test51","fn0","fn1","fn2","fn3","fn4","fn5","len0","len3","len4","len5","iStart","iEnd","fns","generic","onMismatch","arg0","arg1","defineProperty","_onMismatch","arr","start","end","findInArray","objectOrFn","checkName","nameSoFar","getObjectName","obj","key","mergeSignatures","dest","source","sourceFunction","destFunction","saveTyped","maybeName","named","allSignatures","item","theseSignatures","thisName","argument","throwMismatchError","_findType","addType","beforeObjectTest","before","_validateConversion","to","addConversion","override","existing","other","removeConversion","addConversions","existingConversion","splice","resolve","tf","argList","sigs"],"sources":["../../src/typed-function.mjs"],"sourcesContent":["function ok () {\n return true\n}\n\nfunction notOk () {\n return false\n}\n\nfunction undef () {\n return undefined\n}\n\nconst NOT_TYPED_FUNCTION = 'Argument is not a typed-function.'\n\n/**\n * @typedef {{\n * params: Param[],\n * fn: function,\n * test: function,\n * implementation: function\n * }} Signature\n *\n * @typedef {{\n * types: Type[],\n * hasAny: boolean,\n * hasConversion: boolean,\n * restParam: boolean\n * }} Param\n *\n * @typedef {{\n * name: string,\n * typeIndex: number,\n * test: function,\n * isAny: boolean,\n * conversion?: ConversionDef,\n * conversionIndex: number,\n * }} Type\n *\n * @typedef {{\n * from: string,\n * to: string,\n * convert: function (*) : *\n * }} ConversionDef\n *\n * @typedef {{\n * name: string,\n * test: function(*) : boolean,\n * isAny?: boolean\n * }} TypeDef\n */\n\n/**\n * @returns {() => function}\n */\nfunction create () {\n // data type tests\n\n /**\n * Returns true if the argument is a non-null \"plain\" object\n */\n function isPlainObject (x) {\n return typeof x === 'object' && x !== null && x.constructor === Object\n }\n\n const _types = [\n { name: 'number', test: function (x) { return typeof x === 'number' } },\n { name: 'string', test: function (x) { return typeof x === 'string' } },\n { name: 'boolean', test: function (x) { return typeof x === 'boolean' } },\n { name: 'Function', test: function (x) { return typeof x === 'function' } },\n { name: 'Array', test: Array.isArray },\n { name: 'Date', test: function (x) { return x instanceof Date } },\n { name: 'RegExp', test: function (x) { return x instanceof RegExp } },\n { name: 'Object', test: isPlainObject },\n { name: 'null', test: function (x) { return x === null } },\n { name: 'undefined', test: function (x) { return x === undefined } }\n ]\n\n const anyType = {\n name: 'any',\n test: ok,\n isAny: true\n }\n\n // Data structures to track the types. As these are local variables in\n // create(), each typed universe will get its own copy, but the variables\n // will only be accessible through the (closures of the) functions supplied\n // as properties of the typed object, not directly.\n // These will be initialized in clear() below\n let typeMap // primary store of all types\n let typeList // Array of just type names, for the sake of ordering\n\n // And similar data structures for the type conversions:\n let nConversions = 0\n // the actual conversions are stored on a property of the destination types\n\n // This is a temporary object, will be replaced with a function at the end\n let typed = { createCount: 0 }\n\n /**\n * Takes a type name and returns the corresponding official type object\n * for that type.\n *\n * @param {string} typeName\n * @returns {TypeDef} type\n */\n function findType (typeName) {\n const type = typeMap.get(typeName)\n if (type) {\n return type\n }\n // Remainder is error handling\n let message = 'Unknown type \"' + typeName + '\"'\n const name = typeName.toLowerCase()\n let otherName\n for (otherName of typeList) {\n if (otherName.toLowerCase() === name) {\n message += '. Did you mean \"' + otherName + '\" ?'\n break\n }\n }\n throw new TypeError(message)\n }\n\n /**\n * Adds an array `types` of type definitions to this typed instance.\n * Each type definition should be an object with properties:\n * 'name' - a string giving the name of the type; 'test' - function\n * returning a boolean that tests membership in the type; and optionally\n * 'isAny' - true only for the 'any' type.\n *\n * The second optional argument, `before`, gives the name of a type that\n * these types should be added before. The new types are added in the\n * order specified.\n * @param {TypeDef[]} types\n * @param {string | boolean} [beforeSpec='any'] before\n */\n function addTypes (types, beforeSpec = 'any') {\n const beforeIndex = beforeSpec\n ? findType(beforeSpec).index\n : typeList.length\n const newTypes = []\n for (let i = 0; i < types.length; ++i) {\n if (!types[i] || typeof types[i].name !== 'string' ||\n typeof types[i].test !== 'function') {\n throw new TypeError('Object with properties {name: string, test: function} expected')\n }\n const typeName = types[i].name\n if (typeMap.has(typeName)) {\n throw new TypeError('Duplicate type name \"' + typeName + '\"')\n }\n newTypes.push(typeName)\n typeMap.set(typeName, {\n name: typeName,\n test: types[i].test,\n isAny: types[i].isAny,\n index: beforeIndex + i,\n conversionsTo: [] // Newly added type can't have any conversions to it\n })\n }\n // update the typeList\n const affectedTypes = typeList.slice(beforeIndex)\n typeList =\n typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes)\n // Fix the indices\n for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) {\n typeMap.get(typeList[i]).index = i\n }\n }\n\n /**\n * Removes all types and conversions from this typed instance.\n * May cause previously constructed typed-functions to throw\n * strange errors when they are called with types that do not\n * match any of their signatures.\n */\n function clear () {\n typeMap = new Map()\n typeList = []\n nConversions = 0\n addTypes([anyType], false)\n }\n\n // initialize the types to the default list\n clear()\n addTypes(_types)\n\n /**\n * Removes all conversions, leaving the types alone.\n */\n function clearConversions () {\n let typeName\n for (typeName of typeList) {\n typeMap.get(typeName).conversionsTo = []\n }\n nConversions = 0\n }\n\n /**\n * Find the type names that match a value.\n * @param {*} value\n * @return {string[]} Array of names of types for which\n * the type test matches the value.\n */\n function findTypeNames (value) {\n const matches = typeList.filter(name => {\n const type = typeMap.get(name)\n return !type.isAny && type.test(value)\n })\n if (matches.length) {\n return matches\n }\n return ['any']\n }\n\n /**\n * Check if an entity is a typed function created by any instance\n * @param {any} entity\n * @returns {boolean}\n */\n function isTypedFunction (entity) {\n return entity && typeof entity === 'function' &&\n '_typedFunctionData' in entity\n }\n\n /**\n * Find a specific signature from a (composed) typed function, for example:\n *\n * typed.findSignature(fn, ['number', 'string'])\n * typed.findSignature(fn, 'number, string')\n * typed.findSignature(fn, 'number,string', {exact: true})\n *\n * This function findSignature will by default return the best match to\n * the given signature, possibly employing type conversions.\n *\n * The (optional) third argument is a plain object giving options\n * controlling the signature search. Currently the only implemented\n * option is `exact`: if specified as true (default is false), only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Note that a (possibly different) type matching\n * `any`, or one or more instances of TYPE matching `...TYPE` are\n * considered exact matches in this regard, as no conversions are used.\n *\n * This function returns a \"signature\" object, as does `typed.resolve()`,\n * which is a plain object with four keys: `params` (the array of parameters\n * for this signature), `fn` (the originally supplied function for this\n * signature), `test` (a generated function that determines if an argument\n * list matches this signature, and `implementation` (the function to call\n * on a matching argument list, that performs conversions if necessary and\n * then calls the originally supplied function).\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature search as documented\n * @return {{ params: Param[], fn: function, test: function, implementation: function }}\n * Returns the matching signature, or throws an error when no signature\n * is found.\n */\n function findSignature (fn, signature, options) {\n if (!isTypedFunction(fn)) {\n throw new TypeError(NOT_TYPED_FUNCTION)\n }\n\n // Canonicalize input\n const exact = options && options.exact\n const stringSignature = Array.isArray(signature)\n ? signature.join(',')\n : signature\n const params = parseSignature(stringSignature)\n const canonicalSignature = stringifyParams(params)\n\n // First hope we get lucky and exactly match a signature\n if (!exact || canonicalSignature in fn.signatures) {\n // OK, we can check the internal signatures\n const match =\n fn._typedFunctionData.signatureMap.get(canonicalSignature)\n if (match) {\n return match\n }\n }\n\n // Oh well, we did not; so we have to go back and check the parameters\n // one by one, in order to catch things like `any` and rest params.\n // Note here we can assume there is at least one parameter, because\n // the empty signature would have matched successfully above.\n const nParams = params.length\n let remainingSignatures\n if (exact) {\n remainingSignatures = []\n let name\n for (name in fn.signatures) {\n remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name))\n }\n } else {\n remainingSignatures = fn._typedFunctionData.signatures\n }\n for (let i = 0; i < nParams; ++i) {\n const want = params[i]\n const filteredSignatures = []\n let possibility\n for (possibility of remainingSignatures) {\n const have = getParamAtIndex(possibility.params, i)\n if (!have || (want.restParam && !have.restParam)) {\n continue\n }\n if (!have.hasAny) {\n // have to check all of the wanted types are available\n const haveTypes = paramTypeSet(have)\n if (want.types.some(wtype => !haveTypes.has(wtype.name))) {\n continue\n }\n }\n // OK, this looks good\n filteredSignatures.push(possibility)\n }\n remainingSignatures = filteredSignatures\n if (remainingSignatures.length === 0) break\n }\n // Return the first remaining signature that was totally matched:\n let candidate\n for (candidate of remainingSignatures) {\n if (candidate.params.length <= nParams) {\n return candidate\n }\n }\n\n throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))')\n }\n\n /**\n * Find the proper function to call for a specific signature from\n * a (composed) typed function, for example:\n *\n * typed.find(fn, ['number', 'string'])\n * typed.find(fn, 'number, string')\n * typed.find(fn, 'number,string', {exact: true})\n *\n * This function find will by default return the best match to\n * the given signature, possibly employing type conversions (and returning\n * a function that will perform those conversions as needed). The\n * (optional) third argument is a plain object giving options contolling\n * the signature search. Currently only the option `exact` is implemented,\n * which defaults to \"false\". If `exact` is specified as true, then only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Uses of `any` and `...TYPE` are considered exact if\n * no conversions are necessary to apply the corresponding function.\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature match as documented\n * @return {function}\n * Returns the function to call for the given signature, or throws an\n * error if no match is found.\n */\n function find (fn, signature, options) {\n return findSignature(fn, signature, options).implementation\n }\n\n /**\n * Convert a given value to another data type, specified by type name.\n *\n * @param {*} value\n * @param {string} typeName\n */\n function convert (value, typeName) {\n // check conversion is needed\n const type = findType(typeName)\n if (type.test(value)) {\n return value\n }\n const conversions = type.conversionsTo\n if (conversions.length === 0) {\n throw new Error(\n 'There are no conversions to ' + typeName + ' defined.')\n }\n for (let i = 0; i < conversions.length; i++) {\n const fromType = findType(conversions[i].from)\n if (fromType.test(value)) {\n return conversions[i].convert(value)\n }\n }\n\n throw new Error('Cannot convert ' + value + ' to ' + typeName)\n }\n\n /**\n * Stringify parameters in a normalized way\n * @param {Param[]} params\n * @param {string} [','] separator\n * @return {string}\n */\n function stringifyParams (params, separator = ',') {\n return params.map(p => p.name).join(separator)\n }\n\n /**\n * Parse a parameter, like \"...number | boolean\"\n * @param {string} param\n * @return {Param} param\n */\n function parseParam (param) {\n const restParam = param.indexOf('...') === 0\n const types = (!restParam)\n ? param\n : (param.length > 3)\n ? param.slice(3)\n : 'any'\n\n const typeDefs = types.split('|').map(s => findType(s.trim()))\n\n let hasAny = false\n let paramName = restParam ? '...' : ''\n\n const exactTypes = typeDefs.map(function (type) {\n hasAny = type.isAny || hasAny\n paramName += type.name + '|'\n\n return {\n name: type.name,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion: null,\n conversionIndex: -1\n }\n })\n\n return {\n types: exactTypes,\n name: paramName.slice(0, -1), // remove trailing '|' from above\n hasAny,\n hasConversion: false,\n restParam\n }\n }\n\n /**\n * Expands a parsed parameter with the types available from currently\n * defined conversions.\n * @param {Param} param\n * @return {Param} param\n */\n function expandParam (param) {\n const typeNames = param.types.map(t => t.name)\n const matchingConversions = availableConversions(typeNames)\n let hasAny = param.hasAny\n let newName = param.name\n\n const convertibleTypes = matchingConversions.map(function (conversion) {\n const type = findType(conversion.from)\n hasAny = type.isAny || hasAny\n newName += '|' + conversion.from\n\n return {\n name: conversion.from,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion,\n conversionIndex: conversion.index\n }\n })\n\n return {\n types: param.types.concat(convertibleTypes),\n name: newName,\n hasAny,\n hasConversion: convertibleTypes.length > 0,\n restParam: param.restParam\n }\n }\n\n /**\n * Return the set of type names in a parameter.\n * Caches the result for efficiency\n *\n * @param {Param} param\n * @return {Set} typenames\n */\n function paramTypeSet (param) {\n if (!param.typeSet) {\n param.typeSet = new Set()\n param.types.forEach(type => param.typeSet.add(type.name))\n }\n return param.typeSet\n }\n\n /**\n * Parse a signature with comma separated parameters,\n * like \"number | boolean, ...string\"\n *\n * @param {string} signature\n * @return {Param[]} params\n */\n function parseSignature (rawSignature) {\n const params = []\n if (typeof rawSignature !== 'string') {\n throw new TypeError('Signatures must be strings')\n }\n const signature = rawSignature.trim()\n if (signature === '') {\n return params\n }\n\n const rawParams = signature.split(',')\n for (let i = 0; i < rawParams.length; ++i) {\n const parsedParam = parseParam(rawParams[i].trim())\n if (parsedParam.restParam && (i !== rawParams.length - 1)) {\n throw new SyntaxError(\n 'Unexpected rest parameter \"' + rawParams[i] + '\": ' +\n 'only allowed for the last parameter')\n }\n // if invalid, short-circuit (all the types may have been filtered)\n if (parsedParam.types.length === 0) {\n return null\n }\n params.push(parsedParam)\n }\n\n return params\n }\n\n /**\n * Test whether a set of params contains a restParam\n * @param {Param[]} params\n * @return {boolean} Returns true when the last parameter is a restParam\n */\n function hasRestParam (params) {\n const param = last(params)\n return param ? param.restParam : false\n }\n\n /**\n * Create a type test for a single parameter, which can have one or multiple\n * types.\n * @param {Param} param\n * @return {function(x: *) : boolean} Returns a test function\n */\n function compileTest (param) {\n if (!param || param.types.length === 0) {\n // nothing to do\n return ok\n } else if (param.types.length === 1) {\n return findType(param.types[0].name).test\n } else if (param.types.length === 2) {\n const test0 = findType(param.types[0].name).test\n const test1 = findType(param.types[1].name).test\n return function or (x) {\n return test0(x) || test1(x)\n }\n } else { // param.types.length > 2\n const tests = param.types.map(function (type) {\n return findType(type.name).test\n })\n return function or (x) {\n for (let i = 0; i < tests.length; i++) {\n if (tests[i](x)) {\n return true\n }\n }\n return false\n }\n }\n }\n\n /**\n * Create a test for all parameters of a signature\n * @param {Param[]} params\n * @return {function(args: Array<*>) : boolean}\n */\n function compileTests (params) {\n let tests, test0, test1\n\n if (hasRestParam(params)) {\n // variable arguments like '...number'\n tests = initial(params).map(compileTest)\n const varIndex = tests.length\n const lastTest = compileTest(last(params))\n const testRestParam = function (args) {\n for (let i = varIndex; i < args.length; i++) {\n if (!lastTest(args[i])) {\n return false\n }\n }\n return true\n }\n\n return function testArgs (args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false\n }\n }\n return testRestParam(args) && (args.length >= varIndex + 1)\n }\n } else {\n // no variable arguments\n if (params.length === 0) {\n return function testArgs (args) {\n return args.length === 0\n }\n } else if (params.length === 1) {\n test0 = compileTest(params[0])\n return function testArgs (args) {\n return test0(args[0]) && args.length === 1\n }\n } else if (params.length === 2) {\n test0 = compileTest(params[0])\n test1 = compileTest(params[1])\n return function testArgs (args) {\n return test0(args[0]) && test1(args[1]) && args.length === 2\n }\n } else { // arguments.length > 2\n tests = params.map(compileTest)\n return function testArgs (args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false\n }\n }\n return args.length === tests.length\n }\n }\n }\n }\n\n /**\n * Find the parameter at a specific index of a Params list.\n * Handles rest parameters.\n * @param {Param[]} params\n * @param {number} index\n * @return {Param | null} Returns the matching parameter when found,\n * null otherwise.\n */\n function getParamAtIndex (params, index) {\n return index < params.length\n ? params[index]\n : hasRestParam(params) ? last(params) : null\n }\n\n /**\n * Get all type names of a parameter\n * @param {Params[]} params\n * @param {number} index\n * @return {string[]} Returns an array with type names\n */\n function getTypeSetAtIndex (params, index) {\n const param = getParamAtIndex(params, index)\n if (!param) {\n return new Set()\n }\n return paramTypeSet(param)\n }\n\n /**\n * Test whether a type is an exact type or conversion\n * @param {Type} type\n * @return {boolean} Returns true when\n */\n function isExactType (type) {\n return type.conversion === null || type.conversion === undefined\n }\n\n /**\n * Helper function for creating error messages: create an array with\n * all available types on a specific argument index.\n * @param {Signature[]} signatures\n * @param {number} index\n * @return {string[]} Returns an array with available types\n */\n function mergeExpectedParams (signatures, index) {\n const typeSet = new Set()\n signatures.forEach(signature => {\n const paramSet = getTypeSetAtIndex(signature.params, index)\n let name\n for (name of paramSet) {\n typeSet.add(name)\n }\n })\n\n return typeSet.has('any') ? ['any'] : Array.from(typeSet)\n }\n\n /**\n * Create\n * @param {string} name The name of the function\n * @param {array.<*>} args The actual arguments passed to the function\n * @param {Signature[]} signatures A list with available signatures\n * @return {TypeError} Returns a type error with additional data\n * attached to it in the property `data`\n */\n function createError (name, args, signatures) {\n let err, expected\n const _name = name || 'unnamed'\n\n // test for wrong type at some index\n let matchingSignatures = signatures\n let index\n for (index = 0; index < args.length; index++) {\n const nextMatchingDefs = []\n matchingSignatures.forEach(signature => {\n const param = getParamAtIndex(signature.params, index)\n const test = compileTest(param)\n if ((index < signature.params.length ||\n hasRestParam(signature.params)) &&\n test(args[index])) {\n nextMatchingDefs.push(signature)\n }\n })\n\n if (nextMatchingDefs.length === 0) {\n // no matching signatures anymore, throw error \"wrong type\"\n expected = mergeExpectedParams(matchingSignatures, index)\n if (expected.length > 0) {\n const actualTypes = findTypeNames(args[index])\n\n err = new TypeError('Unexpected type of argument in function ' + _name +\n ' (expected: ' + expected.join(' or ') +\n ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')')\n err.data = {\n category: 'wrongType',\n fn: _name,\n index,\n actual: actualTypes,\n expected\n }\n return err\n }\n } else {\n matchingSignatures = nextMatchingDefs\n }\n }\n\n // test for too few arguments\n const lengths = matchingSignatures.map(function (signature) {\n return hasRestParam(signature.params)\n ? Infinity\n : signature.params.length\n })\n if (args.length < Math.min.apply(null, lengths)) {\n expected = mergeExpectedParams(matchingSignatures, index)\n err = new TypeError('Too few arguments in function ' + _name +\n ' (expected: ' + expected.join(' or ') +\n ', index: ' + args.length + ')')\n err.data = {\n category: 'tooFewArgs',\n fn: _name,\n index: args.length,\n expected\n }\n return err\n }\n\n // test for too many arguments\n const maxLength = Math.max.apply(null, lengths)\n if (args.length > maxLength) {\n err = new TypeError('Too many arguments in function ' + _name +\n ' (expected: ' + maxLength + ', actual: ' + args.length + ')')\n err.data = {\n category: 'tooManyArgs',\n fn: _name,\n index: args.length,\n expectedLength: maxLength\n }\n return err\n }\n\n // Generic error\n const argTypes = []\n for (let i = 0; i < args.length; ++i) {\n argTypes.push(findTypeNames(args[i]).join('|'))\n }\n err = new TypeError('Arguments of type \"' + argTypes.join(', ') +\n '\" do not match any of the defined signatures of function ' + _name + '.')\n err.data = {\n category: 'mismatch',\n actual: argTypes\n }\n return err\n }\n\n /**\n * Find the lowest index of all exact types of a parameter (no conversions)\n * @param {Param} param\n * @return {number} Returns the index of the lowest type in typed.types\n */\n function getLowestTypeIndex (param) {\n let min = typeList.length + 1\n\n for (let i = 0; i < param.types.length; i++) {\n if (isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].typeIndex)\n }\n }\n\n return min\n }\n\n /**\n * Find the lowest index of the conversion of all types of the parameter\n * having a conversion\n * @param {Param} param\n * @return {number} Returns the lowest index of the conversions of this type\n */\n function getLowestConversionIndex (param) {\n let min = nConversions + 1\n\n for (let i = 0; i < param.types.length; i++) {\n if (!isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].conversionIndex)\n }\n }\n\n return min\n }\n\n /**\n * Compare two params\n * @param {Param} param1\n * @param {Param} param2\n * @return {number} returns -1 when param1 must get a lower\n * index than param2, 1 when the opposite,\n * or zero when both are equal\n */\n function compareParams (param1, param2) {\n // We compare a number of metrics on a param in turn:\n // 1) 'any' parameters are the least preferred\n if (param1.hasAny) {\n if (!param2.hasAny) {\n return 1\n }\n } else if (param2.hasAny) {\n return -1\n }\n\n // 2) Prefer non-rest to rest parameters\n if (param1.restParam) {\n if (!param2.restParam) {\n return 1\n }\n } else if (param2.restParam) {\n return -1\n }\n\n // 3) Prefer exact type match to conversions\n if (param1.hasConversion) {\n if (!param2.hasConversion) {\n return 1\n }\n } else if (param2.hasConversion) {\n return -1\n }\n\n // 4) Prefer lower type index:\n const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2)\n if (typeDiff < 0) {\n return -1\n }\n if (typeDiff > 0) {\n return 1\n }\n\n // 5) Prefer lower conversion index\n const convDiff =\n getLowestConversionIndex(param1) - getLowestConversionIndex(param2)\n if (convDiff < 0) {\n return -1\n }\n if (convDiff > 0) {\n return 1\n }\n\n // Don't have a basis for preference\n return 0\n }\n\n /**\n * Compare two signatures\n * @param {Signature} signature1\n * @param {Signature} signature2\n * @return {number} returns a negative number when param1 must get a lower\n * index than param2, a positive number when the opposite,\n * or zero when both are equal\n */\n function compareSignatures (signature1, signature2) {\n const pars1 = signature1.params\n const pars2 = signature2.params\n const last1 = last(pars1)\n const last2 = last(pars2)\n const hasRest1 = hasRestParam(pars1)\n const hasRest2 = hasRestParam(pars2)\n // We compare a number of metrics on signatures in turn:\n // 1) An \"any rest param\" is least preferred\n if (hasRest1 && last1.hasAny) {\n if (!hasRest2 || !last2.hasAny) {\n return 1\n }\n } else if (hasRest2 && last2.hasAny) {\n return -1\n }\n\n // 2) Minimize the number of 'any' parameters\n let any1 = 0\n let conv1 = 0\n let par\n for (par of pars1) {\n if (par.hasAny) ++any1\n if (par.hasConversion) ++conv1\n }\n let any2 = 0\n let conv2 = 0\n for (par of pars2) {\n if (par.hasAny) ++any2\n if (par.hasConversion) ++conv2\n }\n if (any1 !== any2) {\n return any1 - any2\n }\n\n // 3) A conversion rest param is less preferred\n if (hasRest1 && last1.hasConversion) {\n if (!hasRest2 || !last2.hasConversion) {\n return 1\n }\n } else if (hasRest2 && last2.hasConversion) {\n return -1\n }\n\n // 4) Minimize the number of conversions\n if (conv1 !== conv2) {\n return conv1 - conv2\n }\n\n // 5) Prefer no rest param\n if (hasRest1) {\n if (!hasRest2) {\n return 1\n }\n } else if (hasRest2) {\n return -1\n }\n\n // 6) Prefer shorter with rest param, longer without\n const lengthCriterion =\n (pars1.length - pars2.length) * (hasRest1 ? -1 : 1)\n if (lengthCriterion !== 0) {\n return lengthCriterion\n }\n\n // Signatures are identical in each of the above metrics.\n // In particular, they are the same length.\n // We can therefore compare the parameters one by one.\n // First we count which signature has more preferred parameters.\n const comparisons = []\n let tc = 0\n for (let i = 0; i < pars1.length; ++i) {\n const thisComparison = compareParams(pars1[i], pars2[i])\n comparisons.push(thisComparison)\n tc += thisComparison\n }\n if (tc !== 0) {\n return tc\n }\n\n // They have the same number of preferred parameters, so go by the\n // earliest parameter in which we have a preference.\n // In other words, dispatch is driven somewhat more by earlier\n // parameters than later ones.\n let c\n for (c of comparisons) {\n if (c !== 0) {\n return c\n }\n }\n\n // It's a tossup:\n return 0\n }\n\n /**\n * Produce a list of all conversions from distinct types to one of\n * the given types.\n *\n * @param {string[]} typeNames\n * @return {ConversionDef[]} Returns the conversions that are available\n * resulting in any given type (if any)\n */\n function availableConversions (typeNames) {\n if (typeNames.length === 0) {\n return []\n }\n const types = typeNames.map(findType)\n if (typeNames.length > 1) {\n types.sort((t1, t2) => t1.index - t2.index)\n }\n let matches = types[0].conversionsTo\n if (typeNames.length === 1) {\n return matches\n }\n\n matches = matches.concat([]) // shallow copy the matches\n // Since the types are now in index order, we just want the first\n // occurrence of any from type:\n const knownTypes = new Set(typeNames)\n for (let i = 1; i < types.length; ++i) {\n let newMatch\n for (newMatch of types[i].conversionsTo) {\n if (!knownTypes.has(newMatch.from)) {\n matches.push(newMatch)\n knownTypes.add(newMatch.from)\n }\n }\n }\n\n return matches\n }\n\n /**\n * Preprocess arguments before calling the original function:\n * - if needed convert the parameters\n * - in case of rest parameters, move the rest parameters into an Array\n * @param {Param[]} params\n * @param {function} fn\n * @return {function} Returns a wrapped function\n */\n function compileArgsPreprocessing (params, fn) {\n let fnConvert = fn\n\n // TODO: can we make this wrapper function smarter/simpler?\n\n if (params.some(p => p.hasConversion)) {\n const restParam = hasRestParam(params)\n const compiledConversions = params.map(compileArgConversion)\n\n fnConvert = function convertArgs () {\n const args = []\n const last = restParam ? arguments.length - 1 : arguments.length\n for (let i = 0; i < last; i++) {\n args[i] = compiledConversions[i](arguments[i])\n }\n if (restParam) {\n args[last] = arguments[last].map(compiledConversions[last])\n }\n\n return fn.apply(this, args)\n }\n }\n\n let fnPreprocess = fnConvert\n if (hasRestParam(params)) {\n const offset = params.length - 1\n\n fnPreprocess = function preprocessRestParams () {\n return fnConvert.apply(this,\n slice(arguments, 0, offset).concat([slice(arguments, offset)]))\n }\n }\n\n return fnPreprocess\n }\n\n /**\n * Compile conversion for a parameter to the right type\n * @param {Param} param\n * @return {function} Returns the wrapped function that will convert arguments\n *\n */\n function compileArgConversion (param) {\n let test0, test1, conversion0, conversion1\n const tests = []\n const conversions = []\n\n param.types.forEach(function (type) {\n if (type.conversion) {\n tests.push(findType(type.conversion.from).test)\n conversions.push(type.conversion.convert)\n }\n })\n\n // create optimized conversion functions depending on the number of conversions\n switch (conversions.length) {\n case 0:\n return function convertArg (arg) {\n return arg\n }\n\n case 1:\n test0 = tests[0]\n conversion0 = conversions[0]\n return function convertArg (arg) {\n if (test0(arg)) {\n return conversion0(arg)\n }\n return arg\n }\n\n case 2:\n test0 = tests[0]\n test1 = tests[1]\n conversion0 = conversions[0]\n conversion1 = conversions[1]\n return function convertArg (arg) {\n if (test0(arg)) {\n return conversion0(arg)\n }\n if (test1(arg)) {\n return conversion1(arg)\n }\n return arg\n }\n\n default:\n return function convertArg (arg) {\n for (let i = 0; i < conversions.length; i++) {\n if (tests[i](arg)) {\n return conversions[i](arg)\n }\n }\n return arg\n }\n }\n }\n\n /**\n * Split params with union types in to separate params.\n *\n * For example:\n *\n * splitParams([['Array', 'Object'], ['string', 'RegExp'])\n * // returns:\n * // [\n * // ['Array', 'string'],\n * // ['Array', 'RegExp'],\n * // ['Object', 'string'],\n * // ['Object', 'RegExp']\n * // ]\n *\n * @param {Param[]} params\n * @return {Param[]}\n */\n function splitParams (params) {\n function _splitParams (params, index, paramsSoFar) {\n if (index < params.length) {\n const param = params[index]\n let resultingParams = []\n\n if (param.restParam) {\n // split the types of a rest parameter in two:\n // one with only exact types, and one with exact types and conversions\n const exactTypes = param.types.filter(isExactType)\n if (exactTypes.length < param.types.length) {\n resultingParams.push({\n types: exactTypes,\n name: '...' + exactTypes.map(t => t.name).join('|'),\n hasAny: exactTypes.some(t => t.isAny),\n hasConversion: false,\n restParam: true\n })\n }\n resultingParams.push(param)\n } else {\n // split all the types of a regular parameter into one type per param\n resultingParams = param.types.map(function (type) {\n return {\n types: [type],\n name: type.name,\n hasAny: type.isAny,\n hasConversion: type.conversion,\n restParam: false\n }\n })\n }\n\n // recurse over the groups with types\n return flatMap(resultingParams, function (nextParam) {\n return _splitParams(params, index + 1, paramsSoFar.concat([nextParam]))\n })\n } else {\n // we've reached the end of the parameters.\n return [paramsSoFar]\n }\n }\n\n return _splitParams(params, 0, [])\n }\n\n /**\n * Test whether two param lists represent conflicting signatures\n * @param {Param[]} params1\n * @param {Param[]} params2\n * @return {boolean} Returns true when the signatures conflict, false otherwise.\n */\n function conflicting (params1, params2) {\n const ii = Math.max(params1.length, params2.length)\n\n for (let i = 0; i < ii; i++) {\n const typeSet1 = getTypeSetAtIndex(params1, i)\n const typeSet2 = getTypeSetAtIndex(params2, i)\n let overlap = false\n let name\n for (name of typeSet2) {\n if (typeSet1.has(name)) {\n overlap = true\n break\n }\n }\n if (!overlap) {\n return false\n }\n }\n\n const len1 = params1.length\n const len2 = params2.length\n const restParam1 = hasRestParam(params1)\n const restParam2 = hasRestParam(params2)\n\n return restParam1\n ? restParam2 ? (len1 === len2) : (len2 >= len1)\n : restParam2 ? (len1 >= len2) : (len1 === len2)\n }\n\n /**\n * Helper function for `resolveReferences` that returns a copy of\n * functionList wihe any prior resolutions cleared out, in case we are\n * recycling signatures from a prior typed function construction.\n *\n * @param {Array.} functionList\n * @return {Array.}\n */\n function clearResolutions (functionList) {\n return functionList.map(fn => {\n if (isReferToSelf(fn)) {\n return referToSelf(fn.referToSelf.callback)\n }\n if (isReferTo(fn)) {\n return makeReferTo(fn.referTo.references, fn.referTo.callback)\n }\n return fn\n })\n }\n\n /**\n * Take a list of references, a list of functions functionList, and a\n * signatureMap indexing signatures into functionList, and return\n * the list of resolutions, or a false-y value if they don't all\n * resolve in a valid way (yet).\n *\n * @param {string[]} references\n * @param {Array} signatureMap\n * @return {function[] | false} resolutions\n */\n function collectResolutions (references, functionList, signatureMap) {\n const resolvedReferences = []\n let reference\n for (reference of references) {\n let resolution = signatureMap[reference]\n if (typeof resolution !== 'number') {\n throw new TypeError(\n 'No definition for referenced signature \"' + reference + '\"')\n }\n resolution = functionList[resolution]\n if (typeof resolution !== 'function') {\n return false\n }\n resolvedReferences.push(resolution)\n }\n return resolvedReferences\n }\n\n /**\n * Resolve any references in the functionList for the typed function\n * itself. The signatureMap tells which index in the functionList a\n * given signature should be mapped to (for use in resolving typed.referTo)\n * and self provides the destions of a typed.referToSelf.\n *\n * @param {Array} functionList\n * @param {Object.} signatureMap\n * @param {function} self The typed-function itself\n * @return {Array} The list of resolved functions\n */\n function resolveReferences (functionList, signatureMap, self) {\n const resolvedFunctions = clearResolutions(functionList)\n const isResolved = new Array(resolvedFunctions.length).fill(false)\n let leftUnresolved = true\n while (leftUnresolved) {\n leftUnresolved = false\n let nothingResolved = true\n for (let i = 0; i < resolvedFunctions.length; ++i) {\n if (isResolved[i]) continue\n const fn = resolvedFunctions[i]\n\n if (isReferToSelf(fn)) {\n resolvedFunctions[i] = fn.referToSelf.callback(self)\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referToSelf = fn.referToSelf\n isResolved[i] = true\n nothingResolved = false\n } else if (isReferTo(fn)) {\n const resolvedReferences = collectResolutions(\n fn.referTo.references, resolvedFunctions, signatureMap)\n if (resolvedReferences) {\n resolvedFunctions[i] =\n fn.referTo.callback.apply(this, resolvedReferences)\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referTo = fn.referTo\n isResolved[i] = true\n nothingResolved = false\n } else {\n leftUnresolved = true\n }\n }\n }\n\n if (nothingResolved && leftUnresolved) {\n throw new SyntaxError(\n 'Circular reference detected in resolving typed.referTo')\n }\n }\n\n return resolvedFunctions\n }\n\n /**\n * Validate whether any of the function bodies contains a self-reference\n * usage like `this(...)` or `this.signatures`. This self-referencing is\n * deprecated since typed-function v3. It has been replaced with\n * the functions typed.referTo and typed.referToSelf.\n * @param {Object.} signaturesMap\n */\n function validateDeprecatedThis (signaturesMap) {\n // TODO: remove this deprecation warning logic some day (it's introduced in v3)\n\n // match occurrences like 'this(' and 'this.signatures'\n const deprecatedThisRegex = /\\bthis(\\(|\\.signatures\\b)/\n\n Object.keys(signaturesMap).forEach(signature => {\n const fn = signaturesMap[signature]\n\n if (deprecatedThisRegex.test(fn.toString())) {\n throw new SyntaxError('Using `this` to self-reference a function ' +\n 'is deprecated since typed-function@3. ' +\n 'Use typed.referTo and typed.referToSelf instead.')\n }\n })\n }\n\n /**\n * Create a typed function\n * @param {String} name The name for the typed function\n * @param {Object.} rawSignaturesMap\n * An object with one or\n * multiple signatures as key, and the\n * function corresponding to the\n * signature as value.\n * @return {function} Returns the created typed function.\n */\n function createTypedFunction (name, rawSignaturesMap) {\n typed.createCount++\n\n if (Object.keys(rawSignaturesMap).length === 0) {\n throw new SyntaxError('No signatures provided')\n }\n\n if (typed.warnAgainstDeprecatedThis) {\n validateDeprecatedThis(rawSignaturesMap)\n }\n\n // Main processing loop for signatures\n const parsedParams = []\n const originalFunctions = []\n const signaturesMap = {}\n const preliminarySignatures = [] // may have duplicates from conversions\n let signature\n for (signature in rawSignaturesMap) {\n // A) Protect against polluted Object prototype:\n if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) {\n continue\n }\n // B) Parse the signature\n const params = parseSignature(signature)\n if (!params) continue\n // C) Check for conflicts\n parsedParams.forEach(function (pp) {\n if (conflicting(pp, params)) {\n throw new TypeError('Conflicting signatures \"' +\n stringifyParams(pp) + '\" and \"' +\n stringifyParams(params) + '\".')\n }\n })\n parsedParams.push(params)\n // D) Store the provided function and add conversions\n const functionIndex = originalFunctions.length\n originalFunctions.push(rawSignaturesMap[signature])\n const conversionParams = params.map(expandParam)\n // E) Split the signatures and collect them up\n let sp\n for (sp of splitParams(conversionParams)) {\n const spName = stringifyParams(sp)\n preliminarySignatures.push(\n { params: sp, name: spName, fn: functionIndex })\n if (sp.every(p => !p.hasConversion)) {\n signaturesMap[spName] = functionIndex\n }\n }\n }\n\n preliminarySignatures.sort(compareSignatures)\n\n // Note the forward reference to theTypedFn\n const resolvedFunctions =\n resolveReferences(originalFunctions, signaturesMap, theTypedFn)\n\n // Fill in the proper function for each signature\n let s\n for (s in signaturesMap) {\n if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) {\n signaturesMap[s] = resolvedFunctions[signaturesMap[s]]\n }\n }\n const signatures = []\n const internalSignatureMap = new Map() // benchmarks faster than object\n for (s of preliminarySignatures) {\n // Note it's only safe to eliminate duplicates like this\n // _after_ the signature sorting step above; otherwise we might\n // remove the wrong one.\n if (!internalSignatureMap.has(s.name)) {\n s.fn = resolvedFunctions[s.fn]\n signatures.push(s)\n internalSignatureMap.set(s.name, s)\n }\n }\n\n // we create a highly optimized checks for the first couple of signatures with max 2 arguments\n const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params)\n const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params)\n const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params)\n const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params)\n const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params)\n const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params)\n const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5\n\n // compile the tests\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].test = compileTests(signatures[i].params)\n }\n\n const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk\n const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk\n const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk\n const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk\n const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk\n const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk\n\n const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk\n const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk\n const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk\n const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk\n const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk\n const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk\n\n // compile the functions\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].implementation =\n compileArgsPreprocessing(signatures[i].params, signatures[i].fn)\n }\n\n const fn0 = ok0 ? signatures[0].implementation : undef\n const fn1 = ok1 ? signatures[1].implementation : undef\n const fn2 = ok2 ? signatures[2].implementation : undef\n const fn3 = ok3 ? signatures[3].implementation : undef\n const fn4 = ok4 ? signatures[4].implementation : undef\n const fn5 = ok5 ? signatures[5].implementation : undef\n\n const len0 = ok0 ? signatures[0].params.length : -1\n const len1 = ok1 ? signatures[1].params.length : -1\n const len2 = ok2 ? signatures[2].params.length : -1\n const len3 = ok3 ? signatures[3].params.length : -1\n const len4 = ok4 ? signatures[4].params.length : -1\n const len5 = ok5 ? signatures[5].params.length : -1\n\n // simple and generic, but also slow\n const iStart = allOk ? 6 : 0\n const iEnd = signatures.length\n // de-reference ahead for execution speed:\n const tests = signatures.map(s => s.test)\n const fns = signatures.map(s => s.implementation)\n const generic = function generic () {\n 'use strict'\n\n for (let i = iStart; i < iEnd; i++) {\n if (tests[i](arguments)) {\n return fns[i].apply(this, arguments)\n }\n }\n\n return typed.onMismatch(name, arguments, signatures)\n }\n\n // create the typed function\n // fast, specialized version. Falls back to the slower, generic one if needed\n function theTypedFn (arg0, arg1) {\n 'use strict'\n\n if (arguments.length === len0 && test00(arg0) && test01(arg1)) { return fn0.apply(this, arguments) }\n if (arguments.length === len1 && test10(arg0) && test11(arg1)) { return fn1.apply(this, arguments) }\n if (arguments.length === len2 && test20(arg0) && test21(arg1)) { return fn2.apply(this, arguments) }\n if (arguments.length === len3 && test30(arg0) && test31(arg1)) { return fn3.apply(this, arguments) }\n if (arguments.length === len4 && test40(arg0) && test41(arg1)) { return fn4.apply(this, arguments) }\n if (arguments.length === len5 && test50(arg0) && test51(arg1)) { return fn5.apply(this, arguments) }\n\n return generic.apply(this, arguments)\n }\n\n // attach name the typed function\n try {\n Object.defineProperty(theTypedFn, 'name', { value: name })\n } catch (err) {\n // old browsers do not support Object.defineProperty and some don't support setting the name property\n // the function name is not essential for the functioning, it's mostly useful for debugging,\n // so it's fine to have unnamed functions.\n }\n\n // attach signatures to the function.\n // This property is close to the original collection of signatures\n // used to create the typed-function, just with unions split:\n theTypedFn.signatures = signaturesMap\n\n // Store internal data for functions like resolve, find, etc.\n // Also serves as the flag that this is a typed-function\n theTypedFn._typedFunctionData = {\n signatures,\n signatureMap: internalSignatureMap\n }\n\n return theTypedFn\n }\n\n /**\n * Action to take on mismatch\n * @param {string} name Name of function that was attempted to be called\n * @param {Array} args Actual arguments to the call\n * @param {Array} signatures Known signatures of the named typed-function\n */\n function _onMismatch (name, args, signatures) {\n throw createError(name, args, signatures)\n }\n\n /**\n * Return all but the last items of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {Array}\n */\n function initial (arr) {\n return slice(arr, 0, arr.length - 1)\n }\n\n /**\n * return the last item of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {*}\n */\n function last (arr) {\n return arr[arr.length - 1]\n }\n\n /**\n * Slice an array or function Arguments\n * @param {Array | Arguments | IArguments} arr\n * @param {number} start\n * @param {number} [end]\n * @return {Array}\n */\n function slice (arr, start, end) {\n return Array.prototype.slice.call(arr, start, end)\n }\n\n /**\n * Return the first item from an array for which test(arr[i]) returns true\n * @param {Array} arr\n * @param {function} test\n * @return {* | undefined} Returns the first matching item\n * or undefined when there is no match\n */\n function findInArray (arr, test) {\n for (let i = 0; i < arr.length; i++) {\n if (test(arr[i])) {\n return arr[i]\n }\n }\n return undefined\n }\n\n /**\n * Flat map the result invoking a callback for every item in an array.\n * https://gist.github.com/samgiles/762ee337dff48623e729\n * @param {Array} arr\n * @param {function} callback\n * @return {Array}\n */\n function flatMap (arr, callback) {\n return Array.prototype.concat.apply([], arr.map(callback))\n }\n\n /**\n * Create a reference callback to one or multiple signatures\n *\n * Syntax:\n *\n * typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) {\n * // ...\n * })\n *\n * @returns {{referTo: {references: string[], callback}}}\n */\n function referTo () {\n const references =\n initial(arguments).map(s => stringifyParams(parseSignature(s)))\n const callback = last(arguments)\n\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as last argument')\n }\n\n return makeReferTo(references, callback)\n }\n\n function makeReferTo (references, callback) {\n return { referTo: { references, callback } }\n }\n\n /**\n * Create a reference callback to the typed-function itself\n *\n * @param {(self: function) => function} callback\n * @returns {{referToSelf: { callback: function }}}\n */\n function referToSelf (callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as first argument')\n }\n\n return { referToSelf: { callback } }\n }\n\n /**\n * Test whether something is a referTo object, holding a list with reference\n * signatures and a callback.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferTo (objectOrFn) {\n return objectOrFn &&\n typeof objectOrFn.referTo === 'object' &&\n Array.isArray(objectOrFn.referTo.references) &&\n typeof objectOrFn.referTo.callback === 'function'\n }\n\n /**\n * Test whether something is a referToSelf object, holding a callback where\n * to pass `self`.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferToSelf (objectOrFn) {\n return objectOrFn &&\n typeof objectOrFn.referToSelf === 'object' &&\n typeof objectOrFn.referToSelf.callback === 'function'\n }\n\n /**\n * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw\n * an error in case (C).\n *\n * @param { string | undefined } nameSoFar\n * @param { string | undefined } newName\n * @returns { string } updated name\n */\n function checkName (nameSoFar, newName) {\n if (!nameSoFar) {\n return newName\n }\n if (newName && newName !== nameSoFar) {\n const err = new Error('Function names do not match (expected: ' +\n nameSoFar + ', actual: ' + newName + ')')\n err.data = { actual: newName, expected: nameSoFar }\n throw err\n }\n return nameSoFar\n }\n\n /**\n * Retrieve the implied name from an object with signature keys\n * and function values, checking whether all value names match\n *\n * @param { {string: function} } obj\n */\n function getObjectName (obj) {\n let name\n for (const key in obj) {\n // Only pay attention to own properties, and only if their values\n // are typed functions or functions with a signature property\n if (Object.prototype.hasOwnProperty.call(obj, key) &&\n (isTypedFunction(obj[key]) ||\n typeof obj[key].signature === 'string')) {\n name = checkName(name, obj[key].name)\n }\n }\n return name\n }\n\n /**\n * Copy all of the signatures from the second argument into the first,\n * which is modified by side effect, checking for conflicts\n *\n * @param {Object.} dest\n * @param {Object.} source\n */\n function mergeSignatures (dest, source) {\n let key\n for (key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n if (key in dest) {\n if (source[key] !== dest[key]) {\n const err = new Error('Signature \"' + key + '\" is defined twice')\n err.data = {\n signature: key,\n sourceFunction: source[key],\n destFunction: dest[key]\n }\n throw err\n }\n // else: both signatures point to the same function, that's fine\n }\n dest[key] = source[key]\n }\n }\n }\n\n const saveTyped = typed\n\n /**\n * Originally the main function was a typed function itself, but then\n * it might not be able to generate error messages if the client\n * replaced the type system with different names.\n *\n * Main entry: typed([name], functions/objects with signatures...)\n *\n * Assembles and returns a new typed-function from the given items\n * that provide signatures and implementations, each of which may be\n * * a plain object mapping (string) signatures to implementing functions,\n * * a previously constructed typed function, or\n * * any other single function with a string-valued property `signature`.\n\n * The name of the resulting typed-function will be given by the\n * string-valued name argument if present, or if not, by the name\n * of any of the arguments that have one, as long as any that do are\n * consistent with each other. If no name is specified, the name will be\n * an empty string.\n *\n * @param {string} maybeName [optional]\n * @param {(function|object)[]} signature providers\n * @returns {typed-function}\n */\n typed = function (maybeName) {\n const named = typeof maybeName === 'string'\n const start = named ? 1 : 0\n let name = named ? maybeName : ''\n const allSignatures = {}\n for (let i = start; i < arguments.length; ++i) {\n const item = arguments[i]\n let theseSignatures = {}\n let thisName\n if (typeof item === 'function') {\n thisName = item.name\n if (typeof item.signature === 'string') {\n // Case 1: Ordinary function with a string 'signature' property\n theseSignatures[item.signature] = item\n } else if (isTypedFunction(item)) {\n // Case 2: Existing typed function\n theseSignatures = item.signatures\n }\n } else if (isPlainObject(item)) {\n // Case 3: Plain object, assume keys = signatures, values = functions\n theseSignatures = item\n if (!named) {\n thisName = getObjectName(item)\n }\n }\n\n if (Object.keys(theseSignatures).length === 0) {\n const err = new TypeError(\n 'Argument to \\'typed\\' at index ' + i + ' is not a (typed) function, ' +\n 'nor an object with signatures as keys and functions as values.')\n err.data = { index: i, argument: item }\n throw err\n }\n\n if (!named) {\n name = checkName(name, thisName)\n }\n mergeSignatures(allSignatures, theseSignatures)\n }\n\n return createTypedFunction(name || '', allSignatures)\n }\n\n typed.create = create\n typed.createCount = saveTyped.createCount\n typed.onMismatch = _onMismatch\n typed.throwMismatchError = _onMismatch\n typed.createError = createError\n typed.clear = clear\n typed.clearConversions = clearConversions\n typed.addTypes = addTypes\n typed._findType = findType // For unit testing only\n typed.referTo = referTo\n typed.referToSelf = referToSelf\n typed.convert = convert\n typed.findSignature = findSignature\n typed.find = find\n typed.isTypedFunction = isTypedFunction\n typed.warnAgainstDeprecatedThis = true\n\n /**\n * add a type (convenience wrapper for typed.addTypes)\n * @param {{name: string, test: function}} type\n * @param {boolean} [beforeObjectTest=true]\n * If true, the new test will be inserted before\n * the test with name 'Object' (if any), since\n * tests for Object match Array and classes too.\n */\n typed.addType = function (type, beforeObjectTest) {\n let before = 'any'\n if (beforeObjectTest !== false && typeMap.has('Object')) {\n before = 'Object'\n }\n typed.addTypes([type], before)\n }\n\n /**\n * Verify that the ConversionDef conversion has a valid format.\n *\n * @param {conversionDef} conversion\n * @return {void}\n * @throws {TypeError|SyntaxError}\n */\n function _validateConversion (conversion) {\n if (!conversion ||\n typeof conversion.from !== 'string' ||\n typeof conversion.to !== 'string' ||\n typeof conversion.convert !== 'function') {\n throw new TypeError('Object with properties {from: string, to: string, convert: function} expected')\n }\n if (conversion.to === conversion.from) {\n throw new SyntaxError(\n 'Illegal to define conversion from \"' + conversion.from +\n '\" to itself.')\n }\n }\n\n /**\n * Add a conversion\n *\n * @param {ConversionDef} conversion\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversion = function (conversion, options = { override: false }) {\n _validateConversion(conversion)\n\n const to = findType(conversion.to)\n const existing = to.conversionsTo.find((other) => other.from === conversion.from)\n\n if (existing) {\n if (options && options.override) {\n typed.removeConversion({ from: existing.from, to: conversion.to, convert: existing.convert })\n } else {\n throw new Error(\n 'There is already a conversion from \"' + conversion.from + '\" to \"' +\n to.name + '\"')\n }\n }\n\n to.conversionsTo.push({\n from: conversion.from,\n convert: conversion.convert,\n index: nConversions++\n })\n }\n\n /**\n * Convenience wrapper to call addConversion on each conversion in a list.\n *\n * @param {ConversionDef[]} conversions\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversions = function (conversions, options) {\n conversions.forEach(conversion => typed.addConversion(conversion, options))\n }\n\n /**\n * Remove the specified conversion. The format is the same as for\n * addConversion, and the convert function must match or an error\n * is thrown.\n *\n * @param {{from: string, to: string, convert: function}} conversion\n * @returns {void}\n * @throws {TypeError|SyntaxError|Error}\n */\n typed.removeConversion = function (conversion) {\n _validateConversion(conversion)\n const to = findType(conversion.to)\n const existingConversion =\n findInArray(to.conversionsTo, c => (c.from === conversion.from))\n if (!existingConversion) {\n throw new Error(\n 'Attempt to remove nonexistent conversion from ' + conversion.from +\n ' to ' + conversion.to)\n }\n if (existingConversion.convert !== conversion.convert) {\n throw new Error(\n 'Conversion to remove does not match existing conversion')\n }\n const index = to.conversionsTo.indexOf(existingConversion)\n to.conversionsTo.splice(index, 1)\n }\n\n /**\n * Produce the specific signature that a typed function\n * will execute on the given arguments. Here, a \"signature\" is an\n * object with properties 'params', 'test', 'fn', and 'implementation'.\n * This last property is a function that converts params as necessary\n * and then calls 'fn'. Returns null if there is no matching signature.\n * @param {typed-function} tf\n * @param {any[]} argList\n * @returns {{params: string, test: function, fn: function, implementation: function}}\n */\n typed.resolve = function (tf, argList) {\n if (!isTypedFunction(tf)) {\n throw new TypeError(NOT_TYPED_FUNCTION)\n }\n const sigs = tf._typedFunctionData.signatures\n for (let i = 0; i < sigs.length; ++i) {\n if (sigs[i].test(argList)) {\n return sigs[i]\n }\n }\n return null\n }\n\n return typed\n}\n\nexport default create()\n"],"mappings":"AAAA,SAASA,EAAEA,CAAA,EAAI;EACb,OAAO,IAAI;AACb;AAEA,SAASC,KAAKA,CAAA,EAAI;EAChB,OAAO,KAAK;AACd;AAEA,SAASC,KAAKA,CAAA,EAAI;EAChB,OAAOC,SAAS;AAClB;AAEA,MAAMC,kBAAkB,GAAG,mCAAmC;;AAE9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAASC,MAAMA,CAAA,EAAI;EACjB;;EAEA;AACF;AACA;EACE,SAASC,aAAaA,CAAEC,CAAC,EAAE;IACzB,OAAO,OAAOA,CAAC,KAAK,QAAQ,IAAIA,CAAC,KAAK,IAAI,IAAIA,CAAC,CAACC,WAAW,KAAKC,MAAM;EACxE;EAEA,MAAMC,MAAM,GAAG,CACb;IAAEC,IAAI,EAAE,QAAQ;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAO,OAAOA,CAAC,KAAK,QAAQ;IAAC;EAAE,CAAC,EACvE;IAAEI,IAAI,EAAE,QAAQ;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAO,OAAOA,CAAC,KAAK,QAAQ;IAAC;EAAE,CAAC,EACvE;IAAEI,IAAI,EAAE,SAAS;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAO,OAAOA,CAAC,KAAK,SAAS;IAAC;EAAE,CAAC,EACzE;IAAEI,IAAI,EAAE,UAAU;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAO,OAAOA,CAAC,KAAK,UAAU;IAAC;EAAE,CAAC,EAC3E;IAAEI,IAAI,EAAE,OAAO;IAAEC,IAAI,EAAEC,KAAK,CAACC;EAAQ,CAAC,EACtC;IAAEH,IAAI,EAAE,MAAM;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAOA,CAAC,YAAYQ,IAAI;IAAC;EAAE,CAAC,EACjE;IAAEJ,IAAI,EAAE,QAAQ;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAOA,CAAC,YAAYS,MAAM;IAAC;EAAE,CAAC,EACrE;IAAEL,IAAI,EAAE,QAAQ;IAAEC,IAAI,EAAEN;EAAc,CAAC,EACvC;IAAEK,IAAI,EAAE,MAAM;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAOA,CAAC,KAAK,IAAI;IAAC;EAAE,CAAC,EAC1D;IAAEI,IAAI,EAAE,WAAW;IAAEC,IAAI,EAAE,SAAAA,CAAUL,CAAC,EAAE;MAAE,OAAOA,CAAC,KAAKJ,SAAS;IAAC;EAAE,CAAC,CACrE;EAED,MAAMc,OAAO,GAAG;IACdN,IAAI,EAAE,KAAK;IACXC,IAAI,EAAEZ,EAAE;IACRkB,KAAK,EAAE;EACT,CAAC;;EAED;EACA;EACA;EACA;EACA;EACA,IAAIC,OAAO,EAAC;EACZ,IAAIC,QAAQ,EAAC;;EAEb;EACA,IAAIC,YAAY,GAAG,CAAC;EACpB;;EAEA;EACA,IAAIC,KAAK,GAAG;IAAEC,WAAW,EAAE;EAAE,CAAC;;EAE9B;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,QAAQA,CAAEC,QAAQ,EAAE;IAC3B,MAAMC,IAAI,GAAGP,OAAO,CAACQ,GAAG,CAACF,QAAQ,CAAC;IAClC,IAAIC,IAAI,EAAE;MACR,OAAOA,IAAI;IACb;IACA;IACA,IAAIE,OAAO,GAAG,gBAAgB,GAAGH,QAAQ,GAAG,GAAG;IAC/C,MAAMd,IAAI,GAAGc,QAAQ,CAACI,WAAW,CAAC,CAAC;IACnC,IAAIC,SAAS;IACb,KAAKA,SAAS,IAAIV,QAAQ,EAAE;MAC1B,IAAIU,SAAS,CAACD,WAAW,CAAC,CAAC,KAAKlB,IAAI,EAAE;QACpCiB,OAAO,IAAI,kBAAkB,GAAGE,SAAS,GAAG,KAAK;QACjD;MACF;IACF;IACA,MAAM,IAAIC,SAAS,CAACH,OAAO,CAAC;EAC9B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASI,QAAQA,CAAEC,KAAK,EAAsB;IAAA,IAApBC,UAAU,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAhC,SAAA,GAAAgC,SAAA,MAAG,KAAK;IAC1C,MAAME,WAAW,GAAGH,UAAU,GAC1BV,QAAQ,CAACU,UAAU,CAAC,CAACI,KAAK,GAC1BlB,QAAQ,CAACgB,MAAM;IACnB,MAAMG,QAAQ,GAAG,EAAE;IACnB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGP,KAAK,CAACG,MAAM,EAAE,EAAEI,CAAC,EAAE;MACrC,IAAI,CAACP,KAAK,CAACO,CAAC,CAAC,IAAI,OAAOP,KAAK,CAACO,CAAC,CAAC,CAAC7B,IAAI,KAAK,QAAQ,IAChD,OAAOsB,KAAK,CAACO,CAAC,CAAC,CAAC5B,IAAI,KAAK,UAAU,EAAE;QACrC,MAAM,IAAImB,SAAS,CAAC,gEAAgE,CAAC;MACvF;MACA,MAAMN,QAAQ,GAAGQ,KAAK,CAACO,CAAC,CAAC,CAAC7B,IAAI;MAC9B,IAAIQ,OAAO,CAACsB,GAAG,CAAChB,QAAQ,CAAC,EAAE;QACzB,MAAM,IAAIM,SAAS,CAAC,uBAAuB,GAAGN,QAAQ,GAAG,GAAG,CAAC;MAC/D;MACAc,QAAQ,CAACG,IAAI,CAACjB,QAAQ,CAAC;MACvBN,OAAO,CAACwB,GAAG,CAAClB,QAAQ,EAAE;QACpBd,IAAI,EAAEc,QAAQ;QACdb,IAAI,EAAEqB,KAAK,CAACO,CAAC,CAAC,CAAC5B,IAAI;QACnBM,KAAK,EAAEe,KAAK,CAACO,CAAC,CAAC,CAACtB,KAAK;QACrBoB,KAAK,EAAED,WAAW,GAAGG,CAAC;QACtBI,aAAa,EAAE,EAAE,CAAC;MACpB,CAAC,CAAC;IACJ;IACA;IACA,MAAMC,aAAa,GAAGzB,QAAQ,CAAC0B,KAAK,CAACT,WAAW,CAAC;IACjDjB,QAAQ,GACNA,QAAQ,CAAC0B,KAAK,CAAC,CAAC,EAAET,WAAW,CAAC,CAACU,MAAM,CAACR,QAAQ,CAAC,CAACQ,MAAM,CAACF,aAAa,CAAC;IACvE;IACA,KAAK,IAAIL,CAAC,GAAGH,WAAW,GAAGE,QAAQ,CAACH,MAAM,EAAEI,CAAC,GAAGpB,QAAQ,CAACgB,MAAM,EAAE,EAAEI,CAAC,EAAE;MACpErB,OAAO,CAACQ,GAAG,CAACP,QAAQ,CAACoB,CAAC,CAAC,CAAC,CAACF,KAAK,GAAGE,CAAC;IACpC;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASQ,KAAKA,CAAA,EAAI;IAChB7B,OAAO,GAAG,IAAI8B,GAAG,CAAC,CAAC;IACnB7B,QAAQ,GAAG,EAAE;IACbC,YAAY,GAAG,CAAC;IAChBW,QAAQ,CAAC,CAACf,OAAO,CAAC,EAAE,KAAK,CAAC;EAC5B;;EAEA;EACA+B,KAAK,CAAC,CAAC;EACPhB,QAAQ,CAACtB,MAAM,CAAC;;EAEhB;AACF;AACA;EACE,SAASwC,gBAAgBA,CAAA,EAAI;IAC3B,IAAIzB,QAAQ;IACZ,KAAKA,QAAQ,IAAIL,QAAQ,EAAE;MACzBD,OAAO,CAACQ,GAAG,CAACF,QAAQ,CAAC,CAACmB,aAAa,GAAG,EAAE;IAC1C;IACAvB,YAAY,GAAG,CAAC;EAClB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAAS8B,aAAaA,CAAEC,KAAK,EAAE;IAC7B,MAAMC,OAAO,GAAGjC,QAAQ,CAACkC,MAAM,CAAC3C,IAAI,IAAI;MACtC,MAAMe,IAAI,GAAGP,OAAO,CAACQ,GAAG,CAAChB,IAAI,CAAC;MAC9B,OAAO,CAACe,IAAI,CAACR,KAAK,IAAIQ,IAAI,CAACd,IAAI,CAACwC,KAAK,CAAC;IACxC,CAAC,CAAC;IACF,IAAIC,OAAO,CAACjB,MAAM,EAAE;MAClB,OAAOiB,OAAO;IAChB;IACA,OAAO,CAAC,KAAK,CAAC;EAChB;;EAEA;AACF;AACA;AACA;AACA;EACE,SAASE,eAAeA,CAAEC,MAAM,EAAE;IAChC,OAAOA,MAAM,IAAI,OAAOA,MAAM,KAAK,UAAU,IAC3C,oBAAoB,IAAIA,MAAM;EAClC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,aAAaA,CAAEC,EAAE,EAAEC,SAAS,EAAEC,OAAO,EAAE;IAC9C,IAAI,CAACL,eAAe,CAACG,EAAE,CAAC,EAAE;MACxB,MAAM,IAAI3B,SAAS,CAAC3B,kBAAkB,CAAC;IACzC;;IAEA;IACA,MAAMyD,KAAK,GAAGD,OAAO,IAAIA,OAAO,CAACC,KAAK;IACtC,MAAMC,eAAe,GAAGjD,KAAK,CAACC,OAAO,CAAC6C,SAAS,CAAC,GAC5CA,SAAS,CAACI,IAAI,CAAC,GAAG,CAAC,GACnBJ,SAAS;IACb,MAAMK,MAAM,GAAGC,cAAc,CAACH,eAAe,CAAC;IAC9C,MAAMI,kBAAkB,GAAGC,eAAe,CAACH,MAAM,CAAC;;IAElD;IACA,IAAI,CAACH,KAAK,IAAIK,kBAAkB,IAAIR,EAAE,CAACU,UAAU,EAAE;MACjD;MACA,MAAMC,KAAK,GACTX,EAAE,CAACY,kBAAkB,CAACC,YAAY,CAAC5C,GAAG,CAACuC,kBAAkB,CAAC;MAC5D,IAAIG,KAAK,EAAE;QACT,OAAOA,KAAK;MACd;IACF;;IAEA;IACA;IACA;IACA;IACA,MAAMG,OAAO,GAAGR,MAAM,CAAC5B,MAAM;IAC7B,IAAIqC,mBAAmB;IACvB,IAAIZ,KAAK,EAAE;MACTY,mBAAmB,GAAG,EAAE;MACxB,IAAI9D,IAAI;MACR,KAAKA,IAAI,IAAI+C,EAAE,CAACU,UAAU,EAAE;QAC1BK,mBAAmB,CAAC/B,IAAI,CAACgB,EAAE,CAACY,kBAAkB,CAACC,YAAY,CAAC5C,GAAG,CAAChB,IAAI,CAAC,CAAC;MACxE;IACF,CAAC,MAAM;MACL8D,mBAAmB,GAAGf,EAAE,CAACY,kBAAkB,CAACF,UAAU;IACxD;IACA,KAAK,IAAI5B,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGgC,OAAO,EAAE,EAAEhC,CAAC,EAAE;MAChC,MAAMkC,IAAI,GAAGV,MAAM,CAACxB,CAAC,CAAC;MACtB,MAAMmC,kBAAkB,GAAG,EAAE;MAC7B,IAAIC,WAAW;MACf,KAAKA,WAAW,IAAIH,mBAAmB,EAAE;QACvC,MAAMI,IAAI,GAAGC,eAAe,CAACF,WAAW,CAACZ,MAAM,EAAExB,CAAC,CAAC;QACnD,IAAI,CAACqC,IAAI,IAAKH,IAAI,CAACK,SAAS,IAAI,CAACF,IAAI,CAACE,SAAU,EAAE;UAChD;QACF;QACA,IAAI,CAACF,IAAI,CAACG,MAAM,EAAE;UAChB;UACA,MAAMC,SAAS,GAAGC,YAAY,CAACL,IAAI,CAAC;UACpC,IAAIH,IAAI,CAACzC,KAAK,CAACkD,IAAI,CAACC,KAAK,IAAI,CAACH,SAAS,CAACxC,GAAG,CAAC2C,KAAK,CAACzE,IAAI,CAAC,CAAC,EAAE;YACxD;UACF;QACF;QACA;QACAgE,kBAAkB,CAACjC,IAAI,CAACkC,WAAW,CAAC;MACtC;MACAH,mBAAmB,GAAGE,kBAAkB;MACxC,IAAIF,mBAAmB,CAACrC,MAAM,KAAK,CAAC,EAAE;IACxC;IACA;IACA,IAAIiD,SAAS;IACb,KAAKA,SAAS,IAAIZ,mBAAmB,EAAE;MACrC,IAAIY,SAAS,CAACrB,MAAM,CAAC5B,MAAM,IAAIoC,OAAO,EAAE;QACtC,OAAOa,SAAS;MAClB;IACF;IAEA,MAAM,IAAItD,SAAS,CAAC,kCAAkC,IAAI2B,EAAE,CAAC/C,IAAI,IAAI,SAAS,CAAC,GAAG,GAAG,GAAGwD,eAAe,CAACH,MAAM,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC;EAC/H;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASsB,IAAIA,CAAE5B,EAAE,EAAEC,SAAS,EAAEC,OAAO,EAAE;IACrC,OAAOH,aAAa,CAACC,EAAE,EAAEC,SAAS,EAAEC,OAAO,CAAC,CAAC2B,cAAc;EAC7D;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASC,OAAOA,CAAEpC,KAAK,EAAE3B,QAAQ,EAAE;IACjC;IACA,MAAMC,IAAI,GAAGF,QAAQ,CAACC,QAAQ,CAAC;IAC/B,IAAIC,IAAI,CAACd,IAAI,CAACwC,KAAK,CAAC,EAAE;MACpB,OAAOA,KAAK;IACd;IACA,MAAMqC,WAAW,GAAG/D,IAAI,CAACkB,aAAa;IACtC,IAAI6C,WAAW,CAACrD,MAAM,KAAK,CAAC,EAAE;MAC5B,MAAM,IAAIsD,KAAK,CACb,8BAA8B,GAAGjE,QAAQ,GAAG,WAAW,CAAC;IAC5D;IACA,KAAK,IAAIe,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGiD,WAAW,CAACrD,MAAM,EAAEI,CAAC,EAAE,EAAE;MAC3C,MAAMmD,QAAQ,GAAGnE,QAAQ,CAACiE,WAAW,CAACjD,CAAC,CAAC,CAACoD,IAAI,CAAC;MAC9C,IAAID,QAAQ,CAAC/E,IAAI,CAACwC,KAAK,CAAC,EAAE;QACxB,OAAOqC,WAAW,CAACjD,CAAC,CAAC,CAACgD,OAAO,CAACpC,KAAK,CAAC;MACtC;IACF;IAEA,MAAM,IAAIsC,KAAK,CAAC,iBAAiB,GAAGtC,KAAK,GAAG,MAAM,GAAG3B,QAAQ,CAAC;EAChE;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAAS0C,eAAeA,CAAEH,MAAM,EAAmB;IAAA,IAAjB6B,SAAS,GAAA1D,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAhC,SAAA,GAAAgC,SAAA,MAAG,GAAG;IAC/C,OAAO6B,MAAM,CAAC8B,GAAG,CAACC,CAAC,IAAIA,CAAC,CAACpF,IAAI,CAAC,CAACoD,IAAI,CAAC8B,SAAS,CAAC;EAChD;;EAEA;AACF;AACA;AACA;AACA;EACE,SAASG,UAAUA,CAAEC,KAAK,EAAE;IAC1B,MAAMlB,SAAS,GAAGkB,KAAK,CAACC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC;IAC5C,MAAMjE,KAAK,GAAI,CAAC8C,SAAS,GACrBkB,KAAK,GACJA,KAAK,CAAC7D,MAAM,GAAG,CAAC,GACb6D,KAAK,CAACnD,KAAK,CAAC,CAAC,CAAC,GACd,KAAK;IAEb,MAAMqD,QAAQ,GAAGlE,KAAK,CAACmE,KAAK,CAAC,GAAG,CAAC,CAACN,GAAG,CAACO,CAAC,IAAI7E,QAAQ,CAAC6E,CAAC,CAACC,IAAI,CAAC,CAAC,CAAC,CAAC;IAE9D,IAAItB,MAAM,GAAG,KAAK;IAClB,IAAIuB,SAAS,GAAGxB,SAAS,GAAG,KAAK,GAAG,EAAE;IAEtC,MAAMyB,UAAU,GAAGL,QAAQ,CAACL,GAAG,CAAC,UAAUpE,IAAI,EAAE;MAC9CsD,MAAM,GAAGtD,IAAI,CAACR,KAAK,IAAI8D,MAAM;MAC7BuB,SAAS,IAAI7E,IAAI,CAACf,IAAI,GAAG,GAAG;MAE5B,OAAO;QACLA,IAAI,EAAEe,IAAI,CAACf,IAAI;QACf8F,SAAS,EAAE/E,IAAI,CAACY,KAAK;QACrB1B,IAAI,EAAEc,IAAI,CAACd,IAAI;QACfM,KAAK,EAAEQ,IAAI,CAACR,KAAK;QACjBwF,UAAU,EAAE,IAAI;QAChBC,eAAe,EAAE,CAAC;MACpB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO;MACL1E,KAAK,EAAEuE,UAAU;MACjB7F,IAAI,EAAE4F,SAAS,CAACzD,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;MAAE;MAC9BkC,MAAM;MACN4B,aAAa,EAAE,KAAK;MACpB7B;IACF,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAAS8B,WAAWA,CAAEZ,KAAK,EAAE;IAC3B,MAAMa,SAAS,GAAGb,KAAK,CAAChE,KAAK,CAAC6D,GAAG,CAACiB,CAAC,IAAIA,CAAC,CAACpG,IAAI,CAAC;IAC9C,MAAMqG,mBAAmB,GAAGC,oBAAoB,CAACH,SAAS,CAAC;IAC3D,IAAI9B,MAAM,GAAGiB,KAAK,CAACjB,MAAM;IACzB,IAAIkC,OAAO,GAAGjB,KAAK,CAACtF,IAAI;IAExB,MAAMwG,gBAAgB,GAAGH,mBAAmB,CAAClB,GAAG,CAAC,UAAUY,UAAU,EAAE;MACrE,MAAMhF,IAAI,GAAGF,QAAQ,CAACkF,UAAU,CAACd,IAAI,CAAC;MACtCZ,MAAM,GAAGtD,IAAI,CAACR,KAAK,IAAI8D,MAAM;MAC7BkC,OAAO,IAAI,GAAG,GAAGR,UAAU,CAACd,IAAI;MAEhC,OAAO;QACLjF,IAAI,EAAE+F,UAAU,CAACd,IAAI;QACrBa,SAAS,EAAE/E,IAAI,CAACY,KAAK;QACrB1B,IAAI,EAAEc,IAAI,CAACd,IAAI;QACfM,KAAK,EAAEQ,IAAI,CAACR,KAAK;QACjBwF,UAAU;QACVC,eAAe,EAAED,UAAU,CAACpE;MAC9B,CAAC;IACH,CAAC,CAAC;IAEF,OAAO;MACLL,KAAK,EAAEgE,KAAK,CAAChE,KAAK,CAACc,MAAM,CAACoE,gBAAgB,CAAC;MAC3CxG,IAAI,EAAEuG,OAAO;MACblC,MAAM;MACN4B,aAAa,EAAEO,gBAAgB,CAAC/E,MAAM,GAAG,CAAC;MAC1C2C,SAAS,EAAEkB,KAAK,CAAClB;IACnB,CAAC;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASG,YAAYA,CAAEe,KAAK,EAAE;IAC5B,IAAI,CAACA,KAAK,CAACmB,OAAO,EAAE;MAClBnB,KAAK,CAACmB,OAAO,GAAG,IAAIC,GAAG,CAAC,CAAC;MACzBpB,KAAK,CAAChE,KAAK,CAACqF,OAAO,CAAC5F,IAAI,IAAIuE,KAAK,CAACmB,OAAO,CAACG,GAAG,CAAC7F,IAAI,CAACf,IAAI,CAAC,CAAC;IAC3D;IACA,OAAOsF,KAAK,CAACmB,OAAO;EACtB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASnD,cAAcA,CAAEuD,YAAY,EAAE;IACrC,MAAMxD,MAAM,GAAG,EAAE;IACjB,IAAI,OAAOwD,YAAY,KAAK,QAAQ,EAAE;MACpC,MAAM,IAAIzF,SAAS,CAAC,4BAA4B,CAAC;IACnD;IACA,MAAM4B,SAAS,GAAG6D,YAAY,CAAClB,IAAI,CAAC,CAAC;IACrC,IAAI3C,SAAS,KAAK,EAAE,EAAE;MACpB,OAAOK,MAAM;IACf;IAEA,MAAMyD,SAAS,GAAG9D,SAAS,CAACyC,KAAK,CAAC,GAAG,CAAC;IACtC,KAAK,IAAI5D,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGiF,SAAS,CAACrF,MAAM,EAAE,EAAEI,CAAC,EAAE;MACzC,MAAMkF,WAAW,GAAG1B,UAAU,CAACyB,SAAS,CAACjF,CAAC,CAAC,CAAC8D,IAAI,CAAC,CAAC,CAAC;MACnD,IAAIoB,WAAW,CAAC3C,SAAS,IAAKvC,CAAC,KAAKiF,SAAS,CAACrF,MAAM,GAAG,CAAE,EAAE;QACzD,MAAM,IAAIuF,WAAW,CACnB,6BAA6B,GAAGF,SAAS,CAACjF,CAAC,CAAC,GAAG,KAAK,GACpD,qCAAqC,CAAC;MAC1C;MACA;MACA,IAAIkF,WAAW,CAACzF,KAAK,CAACG,MAAM,KAAK,CAAC,EAAE;QAClC,OAAO,IAAI;MACb;MACA4B,MAAM,CAACtB,IAAI,CAACgF,WAAW,CAAC;IAC1B;IAEA,OAAO1D,MAAM;EACf;;EAEA;AACF;AACA;AACA;AACA;EACE,SAAS4D,YAAYA,CAAE5D,MAAM,EAAE;IAC7B,MAAMiC,KAAK,GAAG4B,IAAI,CAAC7D,MAAM,CAAC;IAC1B,OAAOiC,KAAK,GAAGA,KAAK,CAAClB,SAAS,GAAG,KAAK;EACxC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAAS+C,WAAWA,CAAE7B,KAAK,EAAE;IAC3B,IAAI,CAACA,KAAK,IAAIA,KAAK,CAAChE,KAAK,CAACG,MAAM,KAAK,CAAC,EAAE;MACtC;MACA,OAAOpC,EAAE;IACX,CAAC,MAAM,IAAIiG,KAAK,CAAChE,KAAK,CAACG,MAAM,KAAK,CAAC,EAAE;MACnC,OAAOZ,QAAQ,CAACyE,KAAK,CAAChE,KAAK,CAAC,CAAC,CAAC,CAACtB,IAAI,CAAC,CAACC,IAAI;IAC3C,CAAC,MAAM,IAAIqF,KAAK,CAAChE,KAAK,CAACG,MAAM,KAAK,CAAC,EAAE;MACnC,MAAM2F,KAAK,GAAGvG,QAAQ,CAACyE,KAAK,CAAChE,KAAK,CAAC,CAAC,CAAC,CAACtB,IAAI,CAAC,CAACC,IAAI;MAChD,MAAMoH,KAAK,GAAGxG,QAAQ,CAACyE,KAAK,CAAChE,KAAK,CAAC,CAAC,CAAC,CAACtB,IAAI,CAAC,CAACC,IAAI;MAChD,OAAO,SAASqH,EAAEA,CAAE1H,CAAC,EAAE;QACrB,OAAOwH,KAAK,CAACxH,CAAC,CAAC,IAAIyH,KAAK,CAACzH,CAAC,CAAC;MAC7B,CAAC;IACH,CAAC,MAAM;MAAE;MACP,MAAM2H,KAAK,GAAGjC,KAAK,CAAChE,KAAK,CAAC6D,GAAG,CAAC,UAAUpE,IAAI,EAAE;QAC5C,OAAOF,QAAQ,CAACE,IAAI,CAACf,IAAI,CAAC,CAACC,IAAI;MACjC,CAAC,CAAC;MACF,OAAO,SAASqH,EAAEA,CAAE1H,CAAC,EAAE;QACrB,KAAK,IAAIiC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG0F,KAAK,CAAC9F,MAAM,EAAEI,CAAC,EAAE,EAAE;UACrC,IAAI0F,KAAK,CAAC1F,CAAC,CAAC,CAACjC,CAAC,CAAC,EAAE;YACf,OAAO,IAAI;UACb;QACF;QACA,OAAO,KAAK;MACd,CAAC;IACH;EACF;;EAEA;AACF;AACA;AACA;AACA;EACE,SAAS4H,YAAYA,CAAEnE,MAAM,EAAE;IAC7B,IAAIkE,KAAK,EAAEH,KAAK,EAAEC,KAAK;IAEvB,IAAIJ,YAAY,CAAC5D,MAAM,CAAC,EAAE;MACxB;MACAkE,KAAK,GAAGE,OAAO,CAACpE,MAAM,CAAC,CAAC8B,GAAG,CAACgC,WAAW,CAAC;MACxC,MAAMO,QAAQ,GAAGH,KAAK,CAAC9F,MAAM;MAC7B,MAAMkG,QAAQ,GAAGR,WAAW,CAACD,IAAI,CAAC7D,MAAM,CAAC,CAAC;MAC1C,MAAMuE,aAAa,GAAG,SAAAA,CAAUC,IAAI,EAAE;QACpC,KAAK,IAAIhG,CAAC,GAAG6F,QAAQ,EAAE7F,CAAC,GAAGgG,IAAI,CAACpG,MAAM,EAAEI,CAAC,EAAE,EAAE;UAC3C,IAAI,CAAC8F,QAAQ,CAACE,IAAI,CAAChG,CAAC,CAAC,CAAC,EAAE;YACtB,OAAO,KAAK;UACd;QACF;QACA,OAAO,IAAI;MACb,CAAC;MAED,OAAO,SAASiG,QAAQA,CAAED,IAAI,EAAE;QAC9B,KAAK,IAAIhG,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG0F,KAAK,CAAC9F,MAAM,EAAEI,CAAC,EAAE,EAAE;UACrC,IAAI,CAAC0F,KAAK,CAAC1F,CAAC,CAAC,CAACgG,IAAI,CAAChG,CAAC,CAAC,CAAC,EAAE;YACtB,OAAO,KAAK;UACd;QACF;QACA,OAAO+F,aAAa,CAACC,IAAI,CAAC,IAAKA,IAAI,CAACpG,MAAM,IAAIiG,QAAQ,GAAG,CAAE;MAC7D,CAAC;IACH,CAAC,MAAM;MACL;MACA,IAAIrE,MAAM,CAAC5B,MAAM,KAAK,CAAC,EAAE;QACvB,OAAO,SAASqG,QAAQA,CAAED,IAAI,EAAE;UAC9B,OAAOA,IAAI,CAACpG,MAAM,KAAK,CAAC;QAC1B,CAAC;MACH,CAAC,MAAM,IAAI4B,MAAM,CAAC5B,MAAM,KAAK,CAAC,EAAE;QAC9B2F,KAAK,GAAGD,WAAW,CAAC9D,MAAM,CAAC,CAAC,CAAC,CAAC;QAC9B,OAAO,SAASyE,QAAQA,CAAED,IAAI,EAAE;UAC9B,OAAOT,KAAK,CAACS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAIA,IAAI,CAACpG,MAAM,KAAK,CAAC;QAC5C,CAAC;MACH,CAAC,MAAM,IAAI4B,MAAM,CAAC5B,MAAM,KAAK,CAAC,EAAE;QAC9B2F,KAAK,GAAGD,WAAW,CAAC9D,MAAM,CAAC,CAAC,CAAC,CAAC;QAC9BgE,KAAK,GAAGF,WAAW,CAAC9D,MAAM,CAAC,CAAC,CAAC,CAAC;QAC9B,OAAO,SAASyE,QAAQA,CAAED,IAAI,EAAE;UAC9B,OAAOT,KAAK,CAACS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAIR,KAAK,CAACQ,IAAI,CAAC,CAAC,CAAC,CAAC,IAAIA,IAAI,CAACpG,MAAM,KAAK,CAAC;QAC9D,CAAC;MACH,CAAC,MAAM;QAAE;QACP8F,KAAK,GAAGlE,MAAM,CAAC8B,GAAG,CAACgC,WAAW,CAAC;QAC/B,OAAO,SAASW,QAAQA,CAAED,IAAI,EAAE;UAC9B,KAAK,IAAIhG,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG0F,KAAK,CAAC9F,MAAM,EAAEI,CAAC,EAAE,EAAE;YACrC,IAAI,CAAC0F,KAAK,CAAC1F,CAAC,CAAC,CAACgG,IAAI,CAAChG,CAAC,CAAC,CAAC,EAAE;cACtB,OAAO,KAAK;YACd;UACF;UACA,OAAOgG,IAAI,CAACpG,MAAM,KAAK8F,KAAK,CAAC9F,MAAM;QACrC,CAAC;MACH;IACF;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAAS0C,eAAeA,CAAEd,MAAM,EAAE1B,KAAK,EAAE;IACvC,OAAOA,KAAK,GAAG0B,MAAM,CAAC5B,MAAM,GACxB4B,MAAM,CAAC1B,KAAK,CAAC,GACbsF,YAAY,CAAC5D,MAAM,CAAC,GAAG6D,IAAI,CAAC7D,MAAM,CAAC,GAAG,IAAI;EAChD;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAAS0E,iBAAiBA,CAAE1E,MAAM,EAAE1B,KAAK,EAAE;IACzC,MAAM2D,KAAK,GAAGnB,eAAe,CAACd,MAAM,EAAE1B,KAAK,CAAC;IAC5C,IAAI,CAAC2D,KAAK,EAAE;MACV,OAAO,IAAIoB,GAAG,CAAC,CAAC;IAClB;IACA,OAAOnC,YAAY,CAACe,KAAK,CAAC;EAC5B;;EAEA;AACF;AACA;AACA;AACA;EACE,SAAS0C,WAAWA,CAAEjH,IAAI,EAAE;IAC1B,OAAOA,IAAI,CAACgF,UAAU,KAAK,IAAI,IAAIhF,IAAI,CAACgF,UAAU,KAAKvG,SAAS;EAClE;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASyI,mBAAmBA,CAAExE,UAAU,EAAE9B,KAAK,EAAE;IAC/C,MAAM8E,OAAO,GAAG,IAAIC,GAAG,CAAC,CAAC;IACzBjD,UAAU,CAACkD,OAAO,CAAC3D,SAAS,IAAI;MAC9B,MAAMkF,QAAQ,GAAGH,iBAAiB,CAAC/E,SAAS,CAACK,MAAM,EAAE1B,KAAK,CAAC;MAC3D,IAAI3B,IAAI;MACR,KAAKA,IAAI,IAAIkI,QAAQ,EAAE;QACrBzB,OAAO,CAACG,GAAG,CAAC5G,IAAI,CAAC;MACnB;IACF,CAAC,CAAC;IAEF,OAAOyG,OAAO,CAAC3E,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG5B,KAAK,CAAC+E,IAAI,CAACwB,OAAO,CAAC;EAC3D;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAAS0B,WAAWA,CAAEnI,IAAI,EAAE6H,IAAI,EAAEpE,UAAU,EAAE;IAC5C,IAAI2E,GAAG,EAAEC,QAAQ;IACjB,MAAMC,KAAK,GAAGtI,IAAI,IAAI,SAAS;;IAE/B;IACA,IAAIuI,kBAAkB,GAAG9E,UAAU;IACnC,IAAI9B,KAAK;IACT,KAAKA,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGkG,IAAI,CAACpG,MAAM,EAAEE,KAAK,EAAE,EAAE;MAC5C,MAAM6G,gBAAgB,GAAG,EAAE;MAC3BD,kBAAkB,CAAC5B,OAAO,CAAC3D,SAAS,IAAI;QACtC,MAAMsC,KAAK,GAAGnB,eAAe,CAACnB,SAAS,CAACK,MAAM,EAAE1B,KAAK,CAAC;QACtD,MAAM1B,IAAI,GAAGkH,WAAW,CAAC7B,KAAK,CAAC;QAC/B,IAAI,CAAC3D,KAAK,GAAGqB,SAAS,CAACK,MAAM,CAAC5B,MAAM,IAClCwF,YAAY,CAACjE,SAAS,CAACK,MAAM,CAAC,KAC9BpD,IAAI,CAAC4H,IAAI,CAAClG,KAAK,CAAC,CAAC,EAAE;UACnB6G,gBAAgB,CAACzG,IAAI,CAACiB,SAAS,CAAC;QAClC;MACF,CAAC,CAAC;MAEF,IAAIwF,gBAAgB,CAAC/G,MAAM,KAAK,CAAC,EAAE;QACjC;QACA4G,QAAQ,GAAGJ,mBAAmB,CAACM,kBAAkB,EAAE5G,KAAK,CAAC;QACzD,IAAI0G,QAAQ,CAAC5G,MAAM,GAAG,CAAC,EAAE;UACvB,MAAMgH,WAAW,GAAGjG,aAAa,CAACqF,IAAI,CAAClG,KAAK,CAAC,CAAC;UAE9CyG,GAAG,GAAG,IAAIhH,SAAS,CAAC,0CAA0C,GAAGkH,KAAK,GACpE,cAAc,GAAGD,QAAQ,CAACjF,IAAI,CAAC,MAAM,CAAC,GACtC,YAAY,GAAGqF,WAAW,CAACrF,IAAI,CAAC,KAAK,CAAC,GAAG,WAAW,GAAGzB,KAAK,GAAG,GAAG,CAAC;UACrEyG,GAAG,CAACM,IAAI,GAAG;YACTC,QAAQ,EAAE,WAAW;YACrB5F,EAAE,EAAEuF,KAAK;YACT3G,KAAK;YACLiH,MAAM,EAAEH,WAAW;YACnBJ;UACF,CAAC;UACD,OAAOD,GAAG;QACZ;MACF,CAAC,MAAM;QACLG,kBAAkB,GAAGC,gBAAgB;MACvC;IACF;;IAEA;IACA,MAAMK,OAAO,GAAGN,kBAAkB,CAACpD,GAAG,CAAC,UAAUnC,SAAS,EAAE;MAC1D,OAAOiE,YAAY,CAACjE,SAAS,CAACK,MAAM,CAAC,GACjCyF,QAAQ,GACR9F,SAAS,CAACK,MAAM,CAAC5B,MAAM;IAC7B,CAAC,CAAC;IACF,IAAIoG,IAAI,CAACpG,MAAM,GAAGsH,IAAI,CAACC,GAAG,CAACC,KAAK,CAAC,IAAI,EAAEJ,OAAO,CAAC,EAAE;MAC/CR,QAAQ,GAAGJ,mBAAmB,CAACM,kBAAkB,EAAE5G,KAAK,CAAC;MACzDyG,GAAG,GAAG,IAAIhH,SAAS,CAAC,gCAAgC,GAAGkH,KAAK,GAC1D,cAAc,GAAGD,QAAQ,CAACjF,IAAI,CAAC,MAAM,CAAC,GACtC,WAAW,GAAGyE,IAAI,CAACpG,MAAM,GAAG,GAAG,CAAC;MAClC2G,GAAG,CAACM,IAAI,GAAG;QACTC,QAAQ,EAAE,YAAY;QACtB5F,EAAE,EAAEuF,KAAK;QACT3G,KAAK,EAAEkG,IAAI,CAACpG,MAAM;QAClB4G;MACF,CAAC;MACD,OAAOD,GAAG;IACZ;;IAEA;IACA,MAAMc,SAAS,GAAGH,IAAI,CAACI,GAAG,CAACF,KAAK,CAAC,IAAI,EAAEJ,OAAO,CAAC;IAC/C,IAAIhB,IAAI,CAACpG,MAAM,GAAGyH,SAAS,EAAE;MAC3Bd,GAAG,GAAG,IAAIhH,SAAS,CAAC,iCAAiC,GAAGkH,KAAK,GAC3D,cAAc,GAAGY,SAAS,GAAG,YAAY,GAAGrB,IAAI,CAACpG,MAAM,GAAG,GAAG,CAAC;MAChE2G,GAAG,CAACM,IAAI,GAAG;QACTC,QAAQ,EAAE,aAAa;QACvB5F,EAAE,EAAEuF,KAAK;QACT3G,KAAK,EAAEkG,IAAI,CAACpG,MAAM;QAClB2H,cAAc,EAAEF;MAClB,CAAC;MACD,OAAOd,GAAG;IACZ;;IAEA;IACA,MAAMiB,QAAQ,GAAG,EAAE;IACnB,KAAK,IAAIxH,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGgG,IAAI,CAACpG,MAAM,EAAE,EAAEI,CAAC,EAAE;MACpCwH,QAAQ,CAACtH,IAAI,CAACS,aAAa,CAACqF,IAAI,CAAChG,CAAC,CAAC,CAAC,CAACuB,IAAI,CAAC,GAAG,CAAC,CAAC;IACjD;IACAgF,GAAG,GAAG,IAAIhH,SAAS,CAAC,qBAAqB,GAAGiI,QAAQ,CAACjG,IAAI,CAAC,IAAI,CAAC,GAC7D,2DAA2D,GAAGkF,KAAK,GAAG,GAAG,CAAC;IAC5EF,GAAG,CAACM,IAAI,GAAG;MACTC,QAAQ,EAAE,UAAU;MACpBC,MAAM,EAAES;IACV,CAAC;IACD,OAAOjB,GAAG;EACZ;;EAEA;AACF;AACA;AACA;AACA;EACE,SAASkB,kBAAkBA,CAAEhE,KAAK,EAAE;IAClC,IAAI0D,GAAG,GAAGvI,QAAQ,CAACgB,MAAM,GAAG,CAAC;IAE7B,KAAK,IAAII,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGyD,KAAK,CAAChE,KAAK,CAACG,MAAM,EAAEI,CAAC,EAAE,EAAE;MAC3C,IAAImG,WAAW,CAAC1C,KAAK,CAAChE,KAAK,CAACO,CAAC,CAAC,CAAC,EAAE;QAC/BmH,GAAG,GAAGD,IAAI,CAACC,GAAG,CAACA,GAAG,EAAE1D,KAAK,CAAChE,KAAK,CAACO,CAAC,CAAC,CAACiE,SAAS,CAAC;MAC/C;IACF;IAEA,OAAOkD,GAAG;EACZ;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASO,wBAAwBA,CAAEjE,KAAK,EAAE;IACxC,IAAI0D,GAAG,GAAGtI,YAAY,GAAG,CAAC;IAE1B,KAAK,IAAImB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGyD,KAAK,CAAChE,KAAK,CAACG,MAAM,EAAEI,CAAC,EAAE,EAAE;MAC3C,IAAI,CAACmG,WAAW,CAAC1C,KAAK,CAAChE,KAAK,CAACO,CAAC,CAAC,CAAC,EAAE;QAChCmH,GAAG,GAAGD,IAAI,CAACC,GAAG,CAACA,GAAG,EAAE1D,KAAK,CAAChE,KAAK,CAACO,CAAC,CAAC,CAACmE,eAAe,CAAC;MACrD;IACF;IAEA,OAAOgD,GAAG;EACZ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASQ,aAAaA,CAAEC,MAAM,EAAEC,MAAM,EAAE;IACtC;IACA;IACA,IAAID,MAAM,CAACpF,MAAM,EAAE;MACjB,IAAI,CAACqF,MAAM,CAACrF,MAAM,EAAE;QAClB,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIqF,MAAM,CAACrF,MAAM,EAAE;MACxB,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,IAAIoF,MAAM,CAACrF,SAAS,EAAE;MACpB,IAAI,CAACsF,MAAM,CAACtF,SAAS,EAAE;QACrB,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIsF,MAAM,CAACtF,SAAS,EAAE;MAC3B,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,IAAIqF,MAAM,CAACxD,aAAa,EAAE;MACxB,IAAI,CAACyD,MAAM,CAACzD,aAAa,EAAE;QACzB,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIyD,MAAM,CAACzD,aAAa,EAAE;MAC/B,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,MAAM0D,QAAQ,GAAGL,kBAAkB,CAACG,MAAM,CAAC,GAAGH,kBAAkB,CAACI,MAAM,CAAC;IACxE,IAAIC,QAAQ,GAAG,CAAC,EAAE;MAChB,OAAO,CAAC,CAAC;IACX;IACA,IAAIA,QAAQ,GAAG,CAAC,EAAE;MAChB,OAAO,CAAC;IACV;;IAEA;IACA,MAAMC,QAAQ,GACZL,wBAAwB,CAACE,MAAM,CAAC,GAAGF,wBAAwB,CAACG,MAAM,CAAC;IACrE,IAAIE,QAAQ,GAAG,CAAC,EAAE;MAChB,OAAO,CAAC,CAAC;IACX;IACA,IAAIA,QAAQ,GAAG,CAAC,EAAE;MAChB,OAAO,CAAC;IACV;;IAEA;IACA,OAAO,CAAC;EACV;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,iBAAiBA,CAAEC,UAAU,EAAEC,UAAU,EAAE;IAClD,MAAMC,KAAK,GAAGF,UAAU,CAACzG,MAAM;IAC/B,MAAM4G,KAAK,GAAGF,UAAU,CAAC1G,MAAM;IAC/B,MAAM6G,KAAK,GAAGhD,IAAI,CAAC8C,KAAK,CAAC;IACzB,MAAMG,KAAK,GAAGjD,IAAI,CAAC+C,KAAK,CAAC;IACzB,MAAMG,QAAQ,GAAGnD,YAAY,CAAC+C,KAAK,CAAC;IACpC,MAAMK,QAAQ,GAAGpD,YAAY,CAACgD,KAAK,CAAC;IACpC;IACA;IACA,IAAIG,QAAQ,IAAIF,KAAK,CAAC7F,MAAM,EAAE;MAC5B,IAAI,CAACgG,QAAQ,IAAI,CAACF,KAAK,CAAC9F,MAAM,EAAE;QAC9B,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIgG,QAAQ,IAAIF,KAAK,CAAC9F,MAAM,EAAE;MACnC,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,IAAIiG,IAAI,GAAG,CAAC;IACZ,IAAIC,KAAK,GAAG,CAAC;IACb,IAAIC,GAAG;IACP,KAAKA,GAAG,IAAIR,KAAK,EAAE;MACjB,IAAIQ,GAAG,CAACnG,MAAM,EAAE,EAAEiG,IAAI;MACtB,IAAIE,GAAG,CAACvE,aAAa,EAAE,EAAEsE,KAAK;IAChC;IACA,IAAIE,IAAI,GAAG,CAAC;IACZ,IAAIC,KAAK,GAAG,CAAC;IACb,KAAKF,GAAG,IAAIP,KAAK,EAAE;MACjB,IAAIO,GAAG,CAACnG,MAAM,EAAE,EAAEoG,IAAI;MACtB,IAAID,GAAG,CAACvE,aAAa,EAAE,EAAEyE,KAAK;IAChC;IACA,IAAIJ,IAAI,KAAKG,IAAI,EAAE;MACjB,OAAOH,IAAI,GAAGG,IAAI;IACpB;;IAEA;IACA,IAAIL,QAAQ,IAAIF,KAAK,CAACjE,aAAa,EAAE;MACnC,IAAI,CAACoE,QAAQ,IAAI,CAACF,KAAK,CAAClE,aAAa,EAAE;QACrC,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIoE,QAAQ,IAAIF,KAAK,CAAClE,aAAa,EAAE;MAC1C,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,IAAIsE,KAAK,KAAKG,KAAK,EAAE;MACnB,OAAOH,KAAK,GAAGG,KAAK;IACtB;;IAEA;IACA,IAAIN,QAAQ,EAAE;MACZ,IAAI,CAACC,QAAQ,EAAE;QACb,OAAO,CAAC;MACV;IACF,CAAC,MAAM,IAAIA,QAAQ,EAAE;MACnB,OAAO,CAAC,CAAC;IACX;;IAEA;IACA,MAAMM,eAAe,GACnB,CAACX,KAAK,CAACvI,MAAM,GAAGwI,KAAK,CAACxI,MAAM,KAAK2I,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACrD,IAAIO,eAAe,KAAK,CAAC,EAAE;MACzB,OAAOA,eAAe;IACxB;;IAEA;IACA;IACA;IACA;IACA,MAAMC,WAAW,GAAG,EAAE;IACtB,IAAIC,EAAE,GAAG,CAAC;IACV,KAAK,IAAIhJ,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGmI,KAAK,CAACvI,MAAM,EAAE,EAAEI,CAAC,EAAE;MACrC,MAAMiJ,cAAc,GAAGtB,aAAa,CAACQ,KAAK,CAACnI,CAAC,CAAC,EAAEoI,KAAK,CAACpI,CAAC,CAAC,CAAC;MACxD+I,WAAW,CAAC7I,IAAI,CAAC+I,cAAc,CAAC;MAChCD,EAAE,IAAIC,cAAc;IACtB;IACA,IAAID,EAAE,KAAK,CAAC,EAAE;MACZ,OAAOA,EAAE;IACX;;IAEA;IACA;IACA;IACA;IACA,IAAIE,CAAC;IACL,KAAKA,CAAC,IAAIH,WAAW,EAAE;MACrB,IAAIG,CAAC,KAAK,CAAC,EAAE;QACX,OAAOA,CAAC;MACV;IACF;;IAEA;IACA,OAAO,CAAC;EACV;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASzE,oBAAoBA,CAAEH,SAAS,EAAE;IACxC,IAAIA,SAAS,CAAC1E,MAAM,KAAK,CAAC,EAAE;MAC1B,OAAO,EAAE;IACX;IACA,MAAMH,KAAK,GAAG6E,SAAS,CAAChB,GAAG,CAACtE,QAAQ,CAAC;IACrC,IAAIsF,SAAS,CAAC1E,MAAM,GAAG,CAAC,EAAE;MACxBH,KAAK,CAAC0J,IAAI,CAAC,CAACC,EAAE,EAAEC,EAAE,KAAKD,EAAE,CAACtJ,KAAK,GAAGuJ,EAAE,CAACvJ,KAAK,CAAC;IAC7C;IACA,IAAIe,OAAO,GAAGpB,KAAK,CAAC,CAAC,CAAC,CAACW,aAAa;IACpC,IAAIkE,SAAS,CAAC1E,MAAM,KAAK,CAAC,EAAE;MAC1B,OAAOiB,OAAO;IAChB;IAEAA,OAAO,GAAGA,OAAO,CAACN,MAAM,CAAC,EAAE,CAAC,EAAC;IAC7B;IACA;IACA,MAAM+I,UAAU,GAAG,IAAIzE,GAAG,CAACP,SAAS,CAAC;IACrC,KAAK,IAAItE,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGP,KAAK,CAACG,MAAM,EAAE,EAAEI,CAAC,EAAE;MACrC,IAAIuJ,QAAQ;MACZ,KAAKA,QAAQ,IAAI9J,KAAK,CAACO,CAAC,CAAC,CAACI,aAAa,EAAE;QACvC,IAAI,CAACkJ,UAAU,CAACrJ,GAAG,CAACsJ,QAAQ,CAACnG,IAAI,CAAC,EAAE;UAClCvC,OAAO,CAACX,IAAI,CAACqJ,QAAQ,CAAC;UACtBD,UAAU,CAACvE,GAAG,CAACwE,QAAQ,CAACnG,IAAI,CAAC;QAC/B;MACF;IACF;IAEA,OAAOvC,OAAO;EAChB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAAS2I,wBAAwBA,CAAEhI,MAAM,EAAEN,EAAE,EAAE;IAC7C,IAAIuI,SAAS,GAAGvI,EAAE;;IAElB;;IAEA,IAAIM,MAAM,CAACmB,IAAI,CAACY,CAAC,IAAIA,CAAC,CAACa,aAAa,CAAC,EAAE;MACrC,MAAM7B,SAAS,GAAG6C,YAAY,CAAC5D,MAAM,CAAC;MACtC,MAAMkI,mBAAmB,GAAGlI,MAAM,CAAC8B,GAAG,CAACqG,oBAAoB,CAAC;MAE5DF,SAAS,GAAG,SAASG,WAAWA,CAAA,EAAI;QAClC,MAAM5D,IAAI,GAAG,EAAE;QACf,MAAMX,IAAI,GAAG9C,SAAS,GAAG5C,SAAS,CAACC,MAAM,GAAG,CAAC,GAAGD,SAAS,CAACC,MAAM;QAChE,KAAK,IAAII,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGqF,IAAI,EAAErF,CAAC,EAAE,EAAE;UAC7BgG,IAAI,CAAChG,CAAC,CAAC,GAAG0J,mBAAmB,CAAC1J,CAAC,CAAC,CAACL,SAAS,CAACK,CAAC,CAAC,CAAC;QAChD;QACA,IAAIuC,SAAS,EAAE;UACbyD,IAAI,CAACX,IAAI,CAAC,GAAG1F,SAAS,CAAC0F,IAAI,CAAC,CAAC/B,GAAG,CAACoG,mBAAmB,CAACrE,IAAI,CAAC,CAAC;QAC7D;QAEA,OAAOnE,EAAE,CAACkG,KAAK,CAAC,IAAI,EAAEpB,IAAI,CAAC;MAC7B,CAAC;IACH;IAEA,IAAI6D,YAAY,GAAGJ,SAAS;IAC5B,IAAIrE,YAAY,CAAC5D,MAAM,CAAC,EAAE;MACxB,MAAMsI,MAAM,GAAGtI,MAAM,CAAC5B,MAAM,GAAG,CAAC;MAEhCiK,YAAY,GAAG,SAASE,oBAAoBA,CAAA,EAAI;QAC9C,OAAON,SAAS,CAACrC,KAAK,CAAC,IAAI,EACzB9G,KAAK,CAACX,SAAS,EAAE,CAAC,EAAEmK,MAAM,CAAC,CAACvJ,MAAM,CAAC,CAACD,KAAK,CAACX,SAAS,EAAEmK,MAAM,CAAC,CAAC,CAAC,CAAC;MACnE,CAAC;IACH;IAEA,OAAOD,YAAY;EACrB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASF,oBAAoBA,CAAElG,KAAK,EAAE;IACpC,IAAI8B,KAAK,EAAEC,KAAK,EAAEwE,WAAW,EAAEC,WAAW;IAC1C,MAAMvE,KAAK,GAAG,EAAE;IAChB,MAAMzC,WAAW,GAAG,EAAE;IAEtBQ,KAAK,CAAChE,KAAK,CAACqF,OAAO,CAAC,UAAU5F,IAAI,EAAE;MAClC,IAAIA,IAAI,CAACgF,UAAU,EAAE;QACnBwB,KAAK,CAACxF,IAAI,CAAClB,QAAQ,CAACE,IAAI,CAACgF,UAAU,CAACd,IAAI,CAAC,CAAChF,IAAI,CAAC;QAC/C6E,WAAW,CAAC/C,IAAI,CAAChB,IAAI,CAACgF,UAAU,CAAClB,OAAO,CAAC;MAC3C;IACF,CAAC,CAAC;;IAEF;IACA,QAAQC,WAAW,CAACrD,MAAM;MACxB,KAAK,CAAC;QACJ,OAAO,SAASsK,UAAUA,CAAEC,GAAG,EAAE;UAC/B,OAAOA,GAAG;QACZ,CAAC;MAEH,KAAK,CAAC;QACJ5E,KAAK,GAAGG,KAAK,CAAC,CAAC,CAAC;QAChBsE,WAAW,GAAG/G,WAAW,CAAC,CAAC,CAAC;QAC5B,OAAO,SAASiH,UAAUA,CAAEC,GAAG,EAAE;UAC/B,IAAI5E,KAAK,CAAC4E,GAAG,CAAC,EAAE;YACd,OAAOH,WAAW,CAACG,GAAG,CAAC;UACzB;UACA,OAAOA,GAAG;QACZ,CAAC;MAEH,KAAK,CAAC;QACJ5E,KAAK,GAAGG,KAAK,CAAC,CAAC,CAAC;QAChBF,KAAK,GAAGE,KAAK,CAAC,CAAC,CAAC;QAChBsE,WAAW,GAAG/G,WAAW,CAAC,CAAC,CAAC;QAC5BgH,WAAW,GAAGhH,WAAW,CAAC,CAAC,CAAC;QAC5B,OAAO,SAASiH,UAAUA,CAAEC,GAAG,EAAE;UAC/B,IAAI5E,KAAK,CAAC4E,GAAG,CAAC,EAAE;YACd,OAAOH,WAAW,CAACG,GAAG,CAAC;UACzB;UACA,IAAI3E,KAAK,CAAC2E,GAAG,CAAC,EAAE;YACd,OAAOF,WAAW,CAACE,GAAG,CAAC;UACzB;UACA,OAAOA,GAAG;QACZ,CAAC;MAEH;QACE,OAAO,SAASD,UAAUA,CAAEC,GAAG,EAAE;UAC/B,KAAK,IAAInK,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGiD,WAAW,CAACrD,MAAM,EAAEI,CAAC,EAAE,EAAE;YAC3C,IAAI0F,KAAK,CAAC1F,CAAC,CAAC,CAACmK,GAAG,CAAC,EAAE;cACjB,OAAOlH,WAAW,CAACjD,CAAC,CAAC,CAACmK,GAAG,CAAC;YAC5B;UACF;UACA,OAAOA,GAAG;QACZ,CAAC;IACL;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,WAAWA,CAAE5I,MAAM,EAAE;IAC5B,SAAS6I,YAAYA,CAAE7I,MAAM,EAAE1B,KAAK,EAAEwK,WAAW,EAAE;MACjD,IAAIxK,KAAK,GAAG0B,MAAM,CAAC5B,MAAM,EAAE;QACzB,MAAM6D,KAAK,GAAGjC,MAAM,CAAC1B,KAAK,CAAC;QAC3B,IAAIyK,eAAe,GAAG,EAAE;QAExB,IAAI9G,KAAK,CAAClB,SAAS,EAAE;UACnB;UACA;UACA,MAAMyB,UAAU,GAAGP,KAAK,CAAChE,KAAK,CAACqB,MAAM,CAACqF,WAAW,CAAC;UAClD,IAAInC,UAAU,CAACpE,MAAM,GAAG6D,KAAK,CAAChE,KAAK,CAACG,MAAM,EAAE;YAC1C2K,eAAe,CAACrK,IAAI,CAAC;cACnBT,KAAK,EAAEuE,UAAU;cACjB7F,IAAI,EAAE,KAAK,GAAG6F,UAAU,CAACV,GAAG,CAACiB,CAAC,IAAIA,CAAC,CAACpG,IAAI,CAAC,CAACoD,IAAI,CAAC,GAAG,CAAC;cACnDiB,MAAM,EAAEwB,UAAU,CAACrB,IAAI,CAAC4B,CAAC,IAAIA,CAAC,CAAC7F,KAAK,CAAC;cACrC0F,aAAa,EAAE,KAAK;cACpB7B,SAAS,EAAE;YACb,CAAC,CAAC;UACJ;UACAgI,eAAe,CAACrK,IAAI,CAACuD,KAAK,CAAC;QAC7B,CAAC,MAAM;UACL;UACA8G,eAAe,GAAG9G,KAAK,CAAChE,KAAK,CAAC6D,GAAG,CAAC,UAAUpE,IAAI,EAAE;YAChD,OAAO;cACLO,KAAK,EAAE,CAACP,IAAI,CAAC;cACbf,IAAI,EAAEe,IAAI,CAACf,IAAI;cACfqE,MAAM,EAAEtD,IAAI,CAACR,KAAK;cAClB0F,aAAa,EAAElF,IAAI,CAACgF,UAAU;cAC9B3B,SAAS,EAAE;YACb,CAAC;UACH,CAAC,CAAC;QACJ;;QAEA;QACA,OAAOiI,OAAO,CAACD,eAAe,EAAE,UAAUE,SAAS,EAAE;UACnD,OAAOJ,YAAY,CAAC7I,MAAM,EAAE1B,KAAK,GAAG,CAAC,EAAEwK,WAAW,CAAC/J,MAAM,CAAC,CAACkK,SAAS,CAAC,CAAC,CAAC;QACzE,CAAC,CAAC;MACJ,CAAC,MAAM;QACL;QACA,OAAO,CAACH,WAAW,CAAC;MACtB;IACF;IAEA,OAAOD,YAAY,CAAC7I,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;EACpC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASkJ,WAAWA,CAAEC,OAAO,EAAEC,OAAO,EAAE;IACtC,MAAMC,EAAE,GAAG3D,IAAI,CAACI,GAAG,CAACqD,OAAO,CAAC/K,MAAM,EAAEgL,OAAO,CAAChL,MAAM,CAAC;IAEnD,KAAK,IAAII,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG6K,EAAE,EAAE7K,CAAC,EAAE,EAAE;MAC3B,MAAM8K,QAAQ,GAAG5E,iBAAiB,CAACyE,OAAO,EAAE3K,CAAC,CAAC;MAC9C,MAAM+K,QAAQ,GAAG7E,iBAAiB,CAAC0E,OAAO,EAAE5K,CAAC,CAAC;MAC9C,IAAIgL,OAAO,GAAG,KAAK;MACnB,IAAI7M,IAAI;MACR,KAAKA,IAAI,IAAI4M,QAAQ,EAAE;QACrB,IAAID,QAAQ,CAAC7K,GAAG,CAAC9B,IAAI,CAAC,EAAE;UACtB6M,OAAO,GAAG,IAAI;UACd;QACF;MACF;MACA,IAAI,CAACA,OAAO,EAAE;QACZ,OAAO,KAAK;MACd;IACF;IAEA,MAAMC,IAAI,GAAGN,OAAO,CAAC/K,MAAM;IAC3B,MAAMsL,IAAI,GAAGN,OAAO,CAAChL,MAAM;IAC3B,MAAMuL,UAAU,GAAG/F,YAAY,CAACuF,OAAO,CAAC;IACxC,MAAMS,UAAU,GAAGhG,YAAY,CAACwF,OAAO,CAAC;IAExC,OAAOO,UAAU,GACbC,UAAU,GAAIH,IAAI,KAAKC,IAAI,GAAKA,IAAI,IAAID,IAAK,GAC7CG,UAAU,GAAIH,IAAI,IAAIC,IAAI,GAAKD,IAAI,KAAKC,IAAK;EACnD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASG,gBAAgBA,CAAEC,YAAY,EAAE;IACvC,OAAOA,YAAY,CAAChI,GAAG,CAACpC,EAAE,IAAI;MAC5B,IAAIqK,aAAa,CAACrK,EAAE,CAAC,EAAE;QACrB,OAAOsK,WAAW,CAACtK,EAAE,CAACsK,WAAW,CAACC,QAAQ,CAAC;MAC7C;MACA,IAAIC,SAAS,CAACxK,EAAE,CAAC,EAAE;QACjB,OAAOyK,WAAW,CAACzK,EAAE,CAAC0K,OAAO,CAACC,UAAU,EAAE3K,EAAE,CAAC0K,OAAO,CAACH,QAAQ,CAAC;MAChE;MACA,OAAOvK,EAAE;IACX,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAAS4K,kBAAkBA,CAAED,UAAU,EAAEP,YAAY,EAAEvJ,YAAY,EAAE;IACnE,MAAMgK,kBAAkB,GAAG,EAAE;IAC7B,IAAIC,SAAS;IACb,KAAKA,SAAS,IAAIH,UAAU,EAAE;MAC5B,IAAII,UAAU,GAAGlK,YAAY,CAACiK,SAAS,CAAC;MACxC,IAAI,OAAOC,UAAU,KAAK,QAAQ,EAAE;QAClC,MAAM,IAAI1M,SAAS,CACjB,0CAA0C,GAAGyM,SAAS,GAAG,GAAG,CAAC;MACjE;MACAC,UAAU,GAAGX,YAAY,CAACW,UAAU,CAAC;MACrC,IAAI,OAAOA,UAAU,KAAK,UAAU,EAAE;QACpC,OAAO,KAAK;MACd;MACAF,kBAAkB,CAAC7L,IAAI,CAAC+L,UAAU,CAAC;IACrC;IACA,OAAOF,kBAAkB;EAC3B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASG,iBAAiBA,CAAEZ,YAAY,EAAEvJ,YAAY,EAAEoK,IAAI,EAAE;IAC5D,MAAMC,iBAAiB,GAAGf,gBAAgB,CAACC,YAAY,CAAC;IACxD,MAAMe,UAAU,GAAG,IAAIhO,KAAK,CAAC+N,iBAAiB,CAACxM,MAAM,CAAC,CAAC0M,IAAI,CAAC,KAAK,CAAC;IAClE,IAAIC,cAAc,GAAG,IAAI;IACzB,OAAOA,cAAc,EAAE;MACrBA,cAAc,GAAG,KAAK;MACtB,IAAIC,eAAe,GAAG,IAAI;MAC1B,KAAK,IAAIxM,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGoM,iBAAiB,CAACxM,MAAM,EAAE,EAAEI,CAAC,EAAE;QACjD,IAAIqM,UAAU,CAACrM,CAAC,CAAC,EAAE;QACnB,MAAMkB,EAAE,GAAGkL,iBAAiB,CAACpM,CAAC,CAAC;QAE/B,IAAIuL,aAAa,CAACrK,EAAE,CAAC,EAAE;UACrBkL,iBAAiB,CAACpM,CAAC,CAAC,GAAGkB,EAAE,CAACsK,WAAW,CAACC,QAAQ,CAACU,IAAI,CAAC;UACpD;UACAC,iBAAiB,CAACpM,CAAC,CAAC,CAACwL,WAAW,GAAGtK,EAAE,CAACsK,WAAW;UACjDa,UAAU,CAACrM,CAAC,CAAC,GAAG,IAAI;UACpBwM,eAAe,GAAG,KAAK;QACzB,CAAC,MAAM,IAAId,SAAS,CAACxK,EAAE,CAAC,EAAE;UACxB,MAAM6K,kBAAkB,GAAGD,kBAAkB,CAC3C5K,EAAE,CAAC0K,OAAO,CAACC,UAAU,EAAEO,iBAAiB,EAAErK,YAAY,CAAC;UACzD,IAAIgK,kBAAkB,EAAE;YACtBK,iBAAiB,CAACpM,CAAC,CAAC,GAClBkB,EAAE,CAAC0K,OAAO,CAACH,QAAQ,CAACrE,KAAK,CAAC,IAAI,EAAE2E,kBAAkB,CAAC;YACrD;YACAK,iBAAiB,CAACpM,CAAC,CAAC,CAAC4L,OAAO,GAAG1K,EAAE,CAAC0K,OAAO;YACzCS,UAAU,CAACrM,CAAC,CAAC,GAAG,IAAI;YACpBwM,eAAe,GAAG,KAAK;UACzB,CAAC,MAAM;YACLD,cAAc,GAAG,IAAI;UACvB;QACF;MACF;MAEA,IAAIC,eAAe,IAAID,cAAc,EAAE;QACrC,MAAM,IAAIpH,WAAW,CACnB,wDAAwD,CAAC;MAC7D;IACF;IAEA,OAAOiH,iBAAiB;EAC1B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASK,sBAAsBA,CAAEC,aAAa,EAAE;IAC9C;;IAEA;IACA,MAAMC,mBAAmB,GAAG,2BAA2B;IAEvD1O,MAAM,CAAC2O,IAAI,CAACF,aAAa,CAAC,CAAC5H,OAAO,CAAC3D,SAAS,IAAI;MAC9C,MAAMD,EAAE,GAAGwL,aAAa,CAACvL,SAAS,CAAC;MAEnC,IAAIwL,mBAAmB,CAACvO,IAAI,CAAC8C,EAAE,CAAC2L,QAAQ,CAAC,CAAC,CAAC,EAAE;QAC3C,MAAM,IAAI1H,WAAW,CAAC,4CAA4C,GAChE,wCAAwC,GACxC,kDAAkD,CAAC;MACvD;IACF,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAAS2H,mBAAmBA,CAAE3O,IAAI,EAAE4O,gBAAgB,EAAE;IACpDjO,KAAK,CAACC,WAAW,EAAE;IAEnB,IAAId,MAAM,CAAC2O,IAAI,CAACG,gBAAgB,CAAC,CAACnN,MAAM,KAAK,CAAC,EAAE;MAC9C,MAAM,IAAIuF,WAAW,CAAC,wBAAwB,CAAC;IACjD;IAEA,IAAIrG,KAAK,CAACkO,yBAAyB,EAAE;MACnCP,sBAAsB,CAACM,gBAAgB,CAAC;IAC1C;;IAEA;IACA,MAAME,YAAY,GAAG,EAAE;IACvB,MAAMC,iBAAiB,GAAG,EAAE;IAC5B,MAAMR,aAAa,GAAG,CAAC,CAAC;IACxB,MAAMS,qBAAqB,GAAG,EAAE,EAAC;IACjC,IAAIhM,SAAS;IACb,KAAKA,SAAS,IAAI4L,gBAAgB,EAAE;MAClC;MACA,IAAI,CAAC9O,MAAM,CAACmP,SAAS,CAACC,cAAc,CAACC,IAAI,CAACP,gBAAgB,EAAE5L,SAAS,CAAC,EAAE;QACtE;MACF;MACA;MACA,MAAMK,MAAM,GAAGC,cAAc,CAACN,SAAS,CAAC;MACxC,IAAI,CAACK,MAAM,EAAE;MACb;MACAyL,YAAY,CAACnI,OAAO,CAAC,UAAUyI,EAAE,EAAE;QACjC,IAAI7C,WAAW,CAAC6C,EAAE,EAAE/L,MAAM,CAAC,EAAE;UAC3B,MAAM,IAAIjC,SAAS,CAAC,0BAA0B,GAC5CoC,eAAe,CAAC4L,EAAE,CAAC,GAAG,SAAS,GAC/B5L,eAAe,CAACH,MAAM,CAAC,GAAG,IAAI,CAAC;QACnC;MACF,CAAC,CAAC;MACFyL,YAAY,CAAC/M,IAAI,CAACsB,MAAM,CAAC;MACzB;MACA,MAAMgM,aAAa,GAAGN,iBAAiB,CAACtN,MAAM;MAC9CsN,iBAAiB,CAAChN,IAAI,CAAC6M,gBAAgB,CAAC5L,SAAS,CAAC,CAAC;MACnD,MAAMsM,gBAAgB,GAAGjM,MAAM,CAAC8B,GAAG,CAACe,WAAW,CAAC;MAChD;MACA,IAAIqJ,EAAE;MACN,KAAKA,EAAE,IAAItD,WAAW,CAACqD,gBAAgB,CAAC,EAAE;QACxC,MAAME,MAAM,GAAGhM,eAAe,CAAC+L,EAAE,CAAC;QAClCP,qBAAqB,CAACjN,IAAI,CACxB;UAAEsB,MAAM,EAAEkM,EAAE;UAAEvP,IAAI,EAAEwP,MAAM;UAAEzM,EAAE,EAAEsM;QAAc,CAAC,CAAC;QAClD,IAAIE,EAAE,CAACE,KAAK,CAACrK,CAAC,IAAI,CAACA,CAAC,CAACa,aAAa,CAAC,EAAE;UACnCsI,aAAa,CAACiB,MAAM,CAAC,GAAGH,aAAa;QACvC;MACF;IACF;IAEAL,qBAAqB,CAAChE,IAAI,CAACnB,iBAAiB,CAAC;;IAE7C;IACA,MAAMoE,iBAAiB,GACrBF,iBAAiB,CAACgB,iBAAiB,EAAER,aAAa,EAAEmB,UAAU,CAAC;;IAEjE;IACA,IAAIhK,CAAC;IACL,KAAKA,CAAC,IAAI6I,aAAa,EAAE;MACvB,IAAIzO,MAAM,CAACmP,SAAS,CAACC,cAAc,CAACC,IAAI,CAACZ,aAAa,EAAE7I,CAAC,CAAC,EAAE;QAC1D6I,aAAa,CAAC7I,CAAC,CAAC,GAAGuI,iBAAiB,CAACM,aAAa,CAAC7I,CAAC,CAAC,CAAC;MACxD;IACF;IACA,MAAMjC,UAAU,GAAG,EAAE;IACrB,MAAMkM,oBAAoB,GAAG,IAAIrN,GAAG,CAAC,CAAC,EAAC;IACvC,KAAKoD,CAAC,IAAIsJ,qBAAqB,EAAE;MAC/B;MACA;MACA;MACA,IAAI,CAACW,oBAAoB,CAAC7N,GAAG,CAAC4D,CAAC,CAAC1F,IAAI,CAAC,EAAE;QACrC0F,CAAC,CAAC3C,EAAE,GAAGkL,iBAAiB,CAACvI,CAAC,CAAC3C,EAAE,CAAC;QAC9BU,UAAU,CAAC1B,IAAI,CAAC2D,CAAC,CAAC;QAClBiK,oBAAoB,CAAC3N,GAAG,CAAC0D,CAAC,CAAC1F,IAAI,EAAE0F,CAAC,CAAC;MACrC;IACF;;IAEA;IACA,MAAMkK,GAAG,GAAGnM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAMwM,GAAG,GAAGpM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAMyM,GAAG,GAAGrM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAM0M,GAAG,GAAGtM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAM2M,GAAG,GAAGvM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAM4M,GAAG,GAAGxM,UAAU,CAAC,CAAC,CAAC,IAAIA,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,IAAI,CAAC,IAAI,CAACwF,YAAY,CAACxD,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC;IACpG,MAAM6M,KAAK,GAAGN,GAAG,IAAIC,GAAG,IAAIC,GAAG,IAAIC,GAAG,IAAIC,GAAG,IAAIC,GAAG;;IAEpD;IACA,KAAK,IAAIpO,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG4B,UAAU,CAAChC,MAAM,EAAE,EAAEI,CAAC,EAAE;MAC1C4B,UAAU,CAAC5B,CAAC,CAAC,CAAC5B,IAAI,GAAGuH,YAAY,CAAC/D,UAAU,CAAC5B,CAAC,CAAC,CAACwB,MAAM,CAAC;IACzD;IAEA,MAAM8M,MAAM,GAAGP,GAAG,GAAGzI,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAM8Q,MAAM,GAAGP,GAAG,GAAG1I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAM+Q,MAAM,GAAGP,GAAG,GAAG3I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMgR,MAAM,GAAGP,GAAG,GAAG5I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMiR,MAAM,GAAGP,GAAG,GAAG7I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMkR,MAAM,GAAGP,GAAG,GAAG9I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IAEjE,MAAMmR,MAAM,GAAGb,GAAG,GAAGzI,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMoR,MAAM,GAAGb,GAAG,GAAG1I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMqR,MAAM,GAAGb,GAAG,GAAG3I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMsR,MAAM,GAAGb,GAAG,GAAG5I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMuR,MAAM,GAAGb,GAAG,GAAG7I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;IACjE,MAAMwR,MAAM,GAAGb,GAAG,GAAG9I,WAAW,CAAC1D,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG/D,KAAK;;IAEjE;IACA,KAAK,IAAIuC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG4B,UAAU,CAAChC,MAAM,EAAE,EAAEI,CAAC,EAAE;MAC1C4B,UAAU,CAAC5B,CAAC,CAAC,CAAC+C,cAAc,GAC1ByG,wBAAwB,CAAC5H,UAAU,CAAC5B,CAAC,CAAC,CAACwB,MAAM,EAAEI,UAAU,CAAC5B,CAAC,CAAC,CAACkB,EAAE,CAAC;IACpE;IAEA,MAAMgO,GAAG,GAAGnB,GAAG,GAAGnM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IACtD,MAAMyR,GAAG,GAAGnB,GAAG,GAAGpM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IACtD,MAAM0R,GAAG,GAAGnB,GAAG,GAAGrM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IACtD,MAAM2R,GAAG,GAAGnB,GAAG,GAAGtM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IACtD,MAAM4R,GAAG,GAAGnB,GAAG,GAAGvM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IACtD,MAAM6R,GAAG,GAAGnB,GAAG,GAAGxM,UAAU,CAAC,CAAC,CAAC,CAACmB,cAAc,GAAGrF,KAAK;IAEtD,MAAM8R,IAAI,GAAGzB,GAAG,GAAGnM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;IACnD,MAAMqL,IAAI,GAAG+C,GAAG,GAAGpM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;IACnD,MAAMsL,IAAI,GAAG+C,GAAG,GAAGrM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;IACnD,MAAM6P,IAAI,GAAGvB,GAAG,GAAGtM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;IACnD,MAAM8P,IAAI,GAAGvB,GAAG,GAAGvM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;IACnD,MAAM+P,IAAI,GAAGvB,GAAG,GAAGxM,UAAU,CAAC,CAAC,CAAC,CAACJ,MAAM,CAAC5B,MAAM,GAAG,CAAC,CAAC;;IAEnD;IACA,MAAMgQ,MAAM,GAAGvB,KAAK,GAAG,CAAC,GAAG,CAAC;IAC5B,MAAMwB,IAAI,GAAGjO,UAAU,CAAChC,MAAM;IAC9B;IACA,MAAM8F,KAAK,GAAG9D,UAAU,CAAC0B,GAAG,CAACO,CAAC,IAAIA,CAAC,CAACzF,IAAI,CAAC;IACzC,MAAM0R,GAAG,GAAGlO,UAAU,CAAC0B,GAAG,CAACO,CAAC,IAAIA,CAAC,CAACd,cAAc,CAAC;IACjD,MAAMgN,OAAO,GAAG,SAASA,OAAOA,CAAA,EAAI;MAClC,YAAY;;MAEZ,KAAK,IAAI/P,CAAC,GAAG4P,MAAM,EAAE5P,CAAC,GAAG6P,IAAI,EAAE7P,CAAC,EAAE,EAAE;QAClC,IAAI0F,KAAK,CAAC1F,CAAC,CAAC,CAACL,SAAS,CAAC,EAAE;UACvB,OAAOmQ,GAAG,CAAC9P,CAAC,CAAC,CAACoH,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;QACtC;MACF;MAEA,OAAOb,KAAK,CAACkR,UAAU,CAAC7R,IAAI,EAAEwB,SAAS,EAAEiC,UAAU,CAAC;IACtD,CAAC;;IAED;IACA;IACA,SAASiM,UAAUA,CAAEoC,IAAI,EAAEC,IAAI,EAAE;MAC/B,YAAY;;MAEZ,IAAIvQ,SAAS,CAACC,MAAM,KAAK4P,IAAI,IAAIlB,MAAM,CAAC2B,IAAI,CAAC,IAAIrB,MAAM,CAACsB,IAAI,CAAC,EAAE;QAAE,OAAOhB,GAAG,CAAC9H,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MACnG,IAAIA,SAAS,CAACC,MAAM,KAAKqL,IAAI,IAAIsD,MAAM,CAAC0B,IAAI,CAAC,IAAIpB,MAAM,CAACqB,IAAI,CAAC,EAAE;QAAE,OAAOf,GAAG,CAAC/H,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MACnG,IAAIA,SAAS,CAACC,MAAM,KAAKsL,IAAI,IAAIsD,MAAM,CAACyB,IAAI,CAAC,IAAInB,MAAM,CAACoB,IAAI,CAAC,EAAE;QAAE,OAAOd,GAAG,CAAChI,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MACnG,IAAIA,SAAS,CAACC,MAAM,KAAK6P,IAAI,IAAIhB,MAAM,CAACwB,IAAI,CAAC,IAAIlB,MAAM,CAACmB,IAAI,CAAC,EAAE;QAAE,OAAOb,GAAG,CAACjI,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MACnG,IAAIA,SAAS,CAACC,MAAM,KAAK8P,IAAI,IAAIhB,MAAM,CAACuB,IAAI,CAAC,IAAIjB,MAAM,CAACkB,IAAI,CAAC,EAAE;QAAE,OAAOZ,GAAG,CAAClI,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MACnG,IAAIA,SAAS,CAACC,MAAM,KAAK+P,IAAI,IAAIhB,MAAM,CAACsB,IAAI,CAAC,IAAIhB,MAAM,CAACiB,IAAI,CAAC,EAAE;QAAE,OAAOX,GAAG,CAACnI,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;MAAC;MAEnG,OAAOoQ,OAAO,CAAC3I,KAAK,CAAC,IAAI,EAAEzH,SAAS,CAAC;IACvC;;IAEA;IACA,IAAI;MACF1B,MAAM,CAACkS,cAAc,CAACtC,UAAU,EAAE,MAAM,EAAE;QAAEjN,KAAK,EAAEzC;MAAK,CAAC,CAAC;IAC5D,CAAC,CAAC,OAAOoI,GAAG,EAAE;MACZ;MACA;MACA;IAAA;;IAGF;IACA;IACA;IACAsH,UAAU,CAACjM,UAAU,GAAG8K,aAAa;;IAErC;IACA;IACAmB,UAAU,CAAC/L,kBAAkB,GAAG;MAC9BF,UAAU;MACVG,YAAY,EAAE+L;IAChB,CAAC;IAED,OAAOD,UAAU;EACnB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASuC,WAAWA,CAAEjS,IAAI,EAAE6H,IAAI,EAAEpE,UAAU,EAAE;IAC5C,MAAM0E,WAAW,CAACnI,IAAI,EAAE6H,IAAI,EAAEpE,UAAU,CAAC;EAC3C;;EAEA;AACF;AACA;AACA;AACA;EACE,SAASgE,OAAOA,CAAEyK,GAAG,EAAE;IACrB,OAAO/P,KAAK,CAAC+P,GAAG,EAAE,CAAC,EAAEA,GAAG,CAACzQ,MAAM,GAAG,CAAC,CAAC;EACtC;;EAEA;AACF;AACA;AACA;AACA;EACE,SAASyF,IAAIA,CAAEgL,GAAG,EAAE;IAClB,OAAOA,GAAG,CAACA,GAAG,CAACzQ,MAAM,GAAG,CAAC,CAAC;EAC5B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASU,KAAKA,CAAE+P,GAAG,EAAEC,KAAK,EAAEC,GAAG,EAAE;IAC/B,OAAOlS,KAAK,CAAC+O,SAAS,CAAC9M,KAAK,CAACgN,IAAI,CAAC+C,GAAG,EAAEC,KAAK,EAAEC,GAAG,CAAC;EACpD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,WAAWA,CAAEH,GAAG,EAAEjS,IAAI,EAAE;IAC/B,KAAK,IAAI4B,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGqQ,GAAG,CAACzQ,MAAM,EAAEI,CAAC,EAAE,EAAE;MACnC,IAAI5B,IAAI,CAACiS,GAAG,CAACrQ,CAAC,CAAC,CAAC,EAAE;QAChB,OAAOqQ,GAAG,CAACrQ,CAAC,CAAC;MACf;IACF;IACA,OAAOrC,SAAS;EAClB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAAS6M,OAAOA,CAAE6F,GAAG,EAAE5E,QAAQ,EAAE;IAC/B,OAAOpN,KAAK,CAAC+O,SAAS,CAAC7M,MAAM,CAAC6G,KAAK,CAAC,EAAE,EAAEiJ,GAAG,CAAC/M,GAAG,CAACmI,QAAQ,CAAC,CAAC;EAC5D;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASG,OAAOA,CAAA,EAAI;IAClB,MAAMC,UAAU,GACdjG,OAAO,CAACjG,SAAS,CAAC,CAAC2D,GAAG,CAACO,CAAC,IAAIlC,eAAe,CAACF,cAAc,CAACoC,CAAC,CAAC,CAAC,CAAC;IACjE,MAAM4H,QAAQ,GAAGpG,IAAI,CAAC1F,SAAS,CAAC;IAEhC,IAAI,OAAO8L,QAAQ,KAAK,UAAU,EAAE;MAClC,MAAM,IAAIlM,SAAS,CAAC,6CAA6C,CAAC;IACpE;IAEA,OAAOoM,WAAW,CAACE,UAAU,EAAEJ,QAAQ,CAAC;EAC1C;EAEA,SAASE,WAAWA,CAAEE,UAAU,EAAEJ,QAAQ,EAAE;IAC1C,OAAO;MAAEG,OAAO,EAAE;QAAEC,UAAU;QAAEJ;MAAS;IAAE,CAAC;EAC9C;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASD,WAAWA,CAAEC,QAAQ,EAAE;IAC9B,IAAI,OAAOA,QAAQ,KAAK,UAAU,EAAE;MAClC,MAAM,IAAIlM,SAAS,CAAC,8CAA8C,CAAC;IACrE;IAEA,OAAO;MAAEiM,WAAW,EAAE;QAAEC;MAAS;IAAE,CAAC;EACtC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,SAASA,CAAE+E,UAAU,EAAE;IAC9B,OAAOA,UAAU,IACf,OAAOA,UAAU,CAAC7E,OAAO,KAAK,QAAQ,IACtCvN,KAAK,CAACC,OAAO,CAACmS,UAAU,CAAC7E,OAAO,CAACC,UAAU,CAAC,IAC5C,OAAO4E,UAAU,CAAC7E,OAAO,CAACH,QAAQ,KAAK,UAAU;EACrD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASF,aAAaA,CAAEkF,UAAU,EAAE;IAClC,OAAOA,UAAU,IACf,OAAOA,UAAU,CAACjF,WAAW,KAAK,QAAQ,IAC1C,OAAOiF,UAAU,CAACjF,WAAW,CAACC,QAAQ,KAAK,UAAU;EACzD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,SAASiF,SAASA,CAAEC,SAAS,EAAEjM,OAAO,EAAE;IACtC,IAAI,CAACiM,SAAS,EAAE;MACd,OAAOjM,OAAO;IAChB;IACA,IAAIA,OAAO,IAAIA,OAAO,KAAKiM,SAAS,EAAE;MACpC,MAAMpK,GAAG,GAAG,IAAIrD,KAAK,CAAC,yCAAyC,GAC7DyN,SAAS,GAAG,YAAY,GAAGjM,OAAO,GAAG,GAAG,CAAC;MAC3C6B,GAAG,CAACM,IAAI,GAAG;QAAEE,MAAM,EAAErC,OAAO;QAAE8B,QAAQ,EAAEmK;MAAU,CAAC;MACnD,MAAMpK,GAAG;IACX;IACA,OAAOoK,SAAS;EAClB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,SAASC,aAAaA,CAAEC,GAAG,EAAE;IAC3B,IAAI1S,IAAI;IACR,KAAK,MAAM2S,GAAG,IAAID,GAAG,EAAE;MACrB;MACA;MACA,IAAI5S,MAAM,CAACmP,SAAS,CAACC,cAAc,CAACC,IAAI,CAACuD,GAAG,EAAEC,GAAG,CAAC,KAC/C/P,eAAe,CAAC8P,GAAG,CAACC,GAAG,CAAC,CAAC,IACxB,OAAOD,GAAG,CAACC,GAAG,CAAC,CAAC3P,SAAS,KAAK,QAAQ,CAAC,EAAE;QAC3ChD,IAAI,GAAGuS,SAAS,CAACvS,IAAI,EAAE0S,GAAG,CAACC,GAAG,CAAC,CAAC3S,IAAI,CAAC;MACvC;IACF;IACA,OAAOA,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAAS4S,eAAeA,CAAEC,IAAI,EAAEC,MAAM,EAAE;IACtC,IAAIH,GAAG;IACP,KAAKA,GAAG,IAAIG,MAAM,EAAE;MAClB,IAAIhT,MAAM,CAACmP,SAAS,CAACC,cAAc,CAACC,IAAI,CAAC2D,MAAM,EAAEH,GAAG,CAAC,EAAE;QACrD,IAAIA,GAAG,IAAIE,IAAI,EAAE;UACf,IAAIC,MAAM,CAACH,GAAG,CAAC,KAAKE,IAAI,CAACF,GAAG,CAAC,EAAE;YAC7B,MAAMvK,GAAG,GAAG,IAAIrD,KAAK,CAAC,aAAa,GAAG4N,GAAG,GAAG,oBAAoB,CAAC;YACjEvK,GAAG,CAACM,IAAI,GAAG;cACT1F,SAAS,EAAE2P,GAAG;cACdI,cAAc,EAAED,MAAM,CAACH,GAAG,CAAC;cAC3BK,YAAY,EAAEH,IAAI,CAACF,GAAG;YACxB,CAAC;YACD,MAAMvK,GAAG;UACX;UACA;QACF;QACAyK,IAAI,CAACF,GAAG,CAAC,GAAGG,MAAM,CAACH,GAAG,CAAC;MACzB;IACF;EACF;EAEA,MAAMM,SAAS,GAAGtS,KAAK;;EAEvB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EAEEA,KAAK,GAAG,SAAAA,CAAUuS,SAAS,EAAE;IAC3B,MAAMC,KAAK,GAAG,OAAOD,SAAS,KAAK,QAAQ;IAC3C,MAAMf,KAAK,GAAGgB,KAAK,GAAG,CAAC,GAAG,CAAC;IAC3B,IAAInT,IAAI,GAAGmT,KAAK,GAAGD,SAAS,GAAG,EAAE;IACjC,MAAME,aAAa,GAAG,CAAC,CAAC;IACxB,KAAK,IAAIvR,CAAC,GAAGsQ,KAAK,EAAEtQ,CAAC,GAAGL,SAAS,CAACC,MAAM,EAAE,EAAEI,CAAC,EAAE;MAC7C,MAAMwR,IAAI,GAAG7R,SAAS,CAACK,CAAC,CAAC;MACzB,IAAIyR,eAAe,GAAG,CAAC,CAAC;MACxB,IAAIC,QAAQ;MACZ,IAAI,OAAOF,IAAI,KAAK,UAAU,EAAE;QAC9BE,QAAQ,GAAGF,IAAI,CAACrT,IAAI;QACpB,IAAI,OAAOqT,IAAI,CAACrQ,SAAS,KAAK,QAAQ,EAAE;UACtC;UACAsQ,eAAe,CAACD,IAAI,CAACrQ,SAAS,CAAC,GAAGqQ,IAAI;QACxC,CAAC,MAAM,IAAIzQ,eAAe,CAACyQ,IAAI,CAAC,EAAE;UAChC;UACAC,eAAe,GAAGD,IAAI,CAAC5P,UAAU;QACnC;MACF,CAAC,MAAM,IAAI9D,aAAa,CAAC0T,IAAI,CAAC,EAAE;QAC9B;QACAC,eAAe,GAAGD,IAAI;QACtB,IAAI,CAACF,KAAK,EAAE;UACVI,QAAQ,GAAGd,aAAa,CAACY,IAAI,CAAC;QAChC;MACF;MAEA,IAAIvT,MAAM,CAAC2O,IAAI,CAAC6E,eAAe,CAAC,CAAC7R,MAAM,KAAK,CAAC,EAAE;QAC7C,MAAM2G,GAAG,GAAG,IAAIhH,SAAS,CACvB,iCAAiC,GAAGS,CAAC,GAAG,8BAA8B,GACtE,gEAAgE,CAAC;QACnEuG,GAAG,CAACM,IAAI,GAAG;UAAE/G,KAAK,EAAEE,CAAC;UAAE2R,QAAQ,EAAEH;QAAK,CAAC;QACvC,MAAMjL,GAAG;MACX;MAEA,IAAI,CAAC+K,KAAK,EAAE;QACVnT,IAAI,GAAGuS,SAAS,CAACvS,IAAI,EAAEuT,QAAQ,CAAC;MAClC;MACAX,eAAe,CAACQ,aAAa,EAAEE,eAAe,CAAC;IACjD;IAEA,OAAO3E,mBAAmB,CAAC3O,IAAI,IAAI,EAAE,EAAEoT,aAAa,CAAC;EACvD,CAAC;EAEDzS,KAAK,CAACjB,MAAM,GAAGA,MAAM;EACrBiB,KAAK,CAACC,WAAW,GAAGqS,SAAS,CAACrS,WAAW;EACzCD,KAAK,CAACkR,UAAU,GAAGI,WAAW;EAC9BtR,KAAK,CAAC8S,kBAAkB,GAAGxB,WAAW;EACtCtR,KAAK,CAACwH,WAAW,GAAGA,WAAW;EAC/BxH,KAAK,CAAC0B,KAAK,GAAGA,KAAK;EACnB1B,KAAK,CAAC4B,gBAAgB,GAAGA,gBAAgB;EACzC5B,KAAK,CAACU,QAAQ,GAAGA,QAAQ;EACzBV,KAAK,CAAC+S,SAAS,GAAG7S,QAAQ,EAAC;EAC3BF,KAAK,CAAC8M,OAAO,GAAGA,OAAO;EACvB9M,KAAK,CAAC0M,WAAW,GAAGA,WAAW;EAC/B1M,KAAK,CAACkE,OAAO,GAAGA,OAAO;EACvBlE,KAAK,CAACmC,aAAa,GAAGA,aAAa;EACnCnC,KAAK,CAACgE,IAAI,GAAGA,IAAI;EACjBhE,KAAK,CAACiC,eAAe,GAAGA,eAAe;EACvCjC,KAAK,CAACkO,yBAAyB,GAAG,IAAI;;EAEtC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACElO,KAAK,CAACgT,OAAO,GAAG,UAAU5S,IAAI,EAAE6S,gBAAgB,EAAE;IAChD,IAAIC,MAAM,GAAG,KAAK;IAClB,IAAID,gBAAgB,KAAK,KAAK,IAAIpT,OAAO,CAACsB,GAAG,CAAC,QAAQ,CAAC,EAAE;MACvD+R,MAAM,GAAG,QAAQ;IACnB;IACAlT,KAAK,CAACU,QAAQ,CAAC,CAACN,IAAI,CAAC,EAAE8S,MAAM,CAAC;EAChC,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;EACE,SAASC,mBAAmBA,CAAE/N,UAAU,EAAE;IACxC,IAAI,CAACA,UAAU,IACb,OAAOA,UAAU,CAACd,IAAI,KAAK,QAAQ,IACnC,OAAOc,UAAU,CAACgO,EAAE,KAAK,QAAQ,IACjC,OAAOhO,UAAU,CAAClB,OAAO,KAAK,UAAU,EAAE;MAC1C,MAAM,IAAIzD,SAAS,CAAC,+EAA+E,CAAC;IACtG;IACA,IAAI2E,UAAU,CAACgO,EAAE,KAAKhO,UAAU,CAACd,IAAI,EAAE;MACrC,MAAM,IAAI+B,WAAW,CACnB,qCAAqC,GAAGjB,UAAU,CAACd,IAAI,GACvD,cAAc,CAAC;IACnB;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEtE,KAAK,CAACqT,aAAa,GAAG,UAAUjO,UAAU,EAAiC;IAAA,IAA/B9C,OAAO,GAAAzB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAhC,SAAA,GAAAgC,SAAA,MAAG;MAAEyS,QAAQ,EAAE;IAAM,CAAC;IACvEH,mBAAmB,CAAC/N,UAAU,CAAC;IAE/B,MAAMgO,EAAE,GAAGlT,QAAQ,CAACkF,UAAU,CAACgO,EAAE,CAAC;IAClC,MAAMG,QAAQ,GAAGH,EAAE,CAAC9R,aAAa,CAAC0C,IAAI,CAAEwP,KAAK,IAAKA,KAAK,CAAClP,IAAI,KAAKc,UAAU,CAACd,IAAI,CAAC;IAEjF,IAAIiP,QAAQ,EAAE;MACZ,IAAIjR,OAAO,IAAIA,OAAO,CAACgR,QAAQ,EAAE;QAC/BtT,KAAK,CAACyT,gBAAgB,CAAC;UAAEnP,IAAI,EAAEiP,QAAQ,CAACjP,IAAI;UAAE8O,EAAE,EAAEhO,UAAU,CAACgO,EAAE;UAAElP,OAAO,EAAEqP,QAAQ,CAACrP;QAAQ,CAAC,CAAC;MAC/F,CAAC,MAAM;QACL,MAAM,IAAIE,KAAK,CACb,sCAAsC,GAAGgB,UAAU,CAACd,IAAI,GAAG,QAAQ,GACnE8O,EAAE,CAAC/T,IAAI,GAAG,GAAG,CAAC;MAClB;IACF;IAEA+T,EAAE,CAAC9R,aAAa,CAACF,IAAI,CAAC;MACpBkD,IAAI,EAAEc,UAAU,CAACd,IAAI;MACrBJ,OAAO,EAAEkB,UAAU,CAAClB,OAAO;MAC3BlD,KAAK,EAAEjB,YAAY;IACrB,CAAC,CAAC;EACJ,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,KAAK,CAAC0T,cAAc,GAAG,UAAUvP,WAAW,EAAE7B,OAAO,EAAE;IACrD6B,WAAW,CAAC6B,OAAO,CAACZ,UAAU,IAAIpF,KAAK,CAACqT,aAAa,CAACjO,UAAU,EAAE9C,OAAO,CAAC,CAAC;EAC7E,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEtC,KAAK,CAACyT,gBAAgB,GAAG,UAAUrO,UAAU,EAAE;IAC7C+N,mBAAmB,CAAC/N,UAAU,CAAC;IAC/B,MAAMgO,EAAE,GAAGlT,QAAQ,CAACkF,UAAU,CAACgO,EAAE,CAAC;IAClC,MAAMO,kBAAkB,GACtBjC,WAAW,CAAC0B,EAAE,CAAC9R,aAAa,EAAE8I,CAAC,IAAKA,CAAC,CAAC9F,IAAI,KAAKc,UAAU,CAACd,IAAK,CAAC;IAClE,IAAI,CAACqP,kBAAkB,EAAE;MACvB,MAAM,IAAIvP,KAAK,CACb,gDAAgD,GAAGgB,UAAU,CAACd,IAAI,GAClE,MAAM,GAAGc,UAAU,CAACgO,EAAE,CAAC;IAC3B;IACA,IAAIO,kBAAkB,CAACzP,OAAO,KAAKkB,UAAU,CAAClB,OAAO,EAAE;MACrD,MAAM,IAAIE,KAAK,CACb,yDAAyD,CAAC;IAC9D;IACA,MAAMpD,KAAK,GAAGoS,EAAE,CAAC9R,aAAa,CAACsD,OAAO,CAAC+O,kBAAkB,CAAC;IAC1DP,EAAE,CAAC9R,aAAa,CAACsS,MAAM,CAAC5S,KAAK,EAAE,CAAC,CAAC;EACnC,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEhB,KAAK,CAAC6T,OAAO,GAAG,UAAUC,EAAE,EAAEC,OAAO,EAAE;IACrC,IAAI,CAAC9R,eAAe,CAAC6R,EAAE,CAAC,EAAE;MACxB,MAAM,IAAIrT,SAAS,CAAC3B,kBAAkB,CAAC;IACzC;IACA,MAAMkV,IAAI,GAAGF,EAAE,CAAC9Q,kBAAkB,CAACF,UAAU;IAC7C,KAAK,IAAI5B,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG8S,IAAI,CAAClT,MAAM,EAAE,EAAEI,CAAC,EAAE;MACpC,IAAI8S,IAAI,CAAC9S,CAAC,CAAC,CAAC5B,IAAI,CAACyU,OAAO,CAAC,EAAE;QACzB,OAAOC,IAAI,CAAC9S,CAAC,CAAC;MAChB;IACF;IACA,OAAO,IAAI;EACb,CAAC;EAED,OAAOlB,KAAK;AACd;AAEA,eAAejB,MAAM,CAAC,CAAC","ignoreList":[]} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/package.json new file mode 100644 index 0000000..5bbefff --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/package.json @@ -0,0 +1,3 @@ +{ + "type": "commonjs" +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js new file mode 100644 index 0000000..6f777a9 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js @@ -0,0 +1,1915 @@ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : + typeof define === 'function' && define.amd ? define(factory) : + (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global["'typed'"] = factory()); +})(this, (function () { 'use strict'; + + function ok() { + return true; + } + function notOk() { + return false; + } + function undef() { + return undefined; + } + const NOT_TYPED_FUNCTION = 'Argument is not a typed-function.'; + + /** + * @typedef {{ + * params: Param[], + * fn: function, + * test: function, + * implementation: function + * }} Signature + * + * @typedef {{ + * types: Type[], + * hasAny: boolean, + * hasConversion: boolean, + * restParam: boolean + * }} Param + * + * @typedef {{ + * name: string, + * typeIndex: number, + * test: function, + * isAny: boolean, + * conversion?: ConversionDef, + * conversionIndex: number, + * }} Type + * + * @typedef {{ + * from: string, + * to: string, + * convert: function (*) : * + * }} ConversionDef + * + * @typedef {{ + * name: string, + * test: function(*) : boolean, + * isAny?: boolean + * }} TypeDef + */ + + /** + * @returns {() => function} + */ + function create() { + // data type tests + + /** + * Returns true if the argument is a non-null "plain" object + */ + function isPlainObject(x) { + return typeof x === 'object' && x !== null && x.constructor === Object; + } + const _types = [{ + name: 'number', + test: function (x) { + return typeof x === 'number'; + } + }, { + name: 'string', + test: function (x) { + return typeof x === 'string'; + } + }, { + name: 'boolean', + test: function (x) { + return typeof x === 'boolean'; + } + }, { + name: 'Function', + test: function (x) { + return typeof x === 'function'; + } + }, { + name: 'Array', + test: Array.isArray + }, { + name: 'Date', + test: function (x) { + return x instanceof Date; + } + }, { + name: 'RegExp', + test: function (x) { + return x instanceof RegExp; + } + }, { + name: 'Object', + test: isPlainObject + }, { + name: 'null', + test: function (x) { + return x === null; + } + }, { + name: 'undefined', + test: function (x) { + return x === undefined; + } + }]; + const anyType = { + name: 'any', + test: ok, + isAny: true + }; + + // Data structures to track the types. As these are local variables in + // create(), each typed universe will get its own copy, but the variables + // will only be accessible through the (closures of the) functions supplied + // as properties of the typed object, not directly. + // These will be initialized in clear() below + let typeMap; // primary store of all types + let typeList; // Array of just type names, for the sake of ordering + + // And similar data structures for the type conversions: + let nConversions = 0; + // the actual conversions are stored on a property of the destination types + + // This is a temporary object, will be replaced with a function at the end + let typed = { + createCount: 0 + }; + + /** + * Takes a type name and returns the corresponding official type object + * for that type. + * + * @param {string} typeName + * @returns {TypeDef} type + */ + function findType(typeName) { + const type = typeMap.get(typeName); + if (type) { + return type; + } + // Remainder is error handling + let message = 'Unknown type "' + typeName + '"'; + const name = typeName.toLowerCase(); + let otherName; + for (otherName of typeList) { + if (otherName.toLowerCase() === name) { + message += '. Did you mean "' + otherName + '" ?'; + break; + } + } + throw new TypeError(message); + } + + /** + * Adds an array `types` of type definitions to this typed instance. + * Each type definition should be an object with properties: + * 'name' - a string giving the name of the type; 'test' - function + * returning a boolean that tests membership in the type; and optionally + * 'isAny' - true only for the 'any' type. + * + * The second optional argument, `before`, gives the name of a type that + * these types should be added before. The new types are added in the + * order specified. + * @param {TypeDef[]} types + * @param {string | boolean} [beforeSpec='any'] before + */ + function addTypes(types) { + let beforeSpec = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any'; + const beforeIndex = beforeSpec ? findType(beforeSpec).index : typeList.length; + const newTypes = []; + for (let i = 0; i < types.length; ++i) { + if (!types[i] || typeof types[i].name !== 'string' || typeof types[i].test !== 'function') { + throw new TypeError('Object with properties {name: string, test: function} expected'); + } + const typeName = types[i].name; + if (typeMap.has(typeName)) { + throw new TypeError('Duplicate type name "' + typeName + '"'); + } + newTypes.push(typeName); + typeMap.set(typeName, { + name: typeName, + test: types[i].test, + isAny: types[i].isAny, + index: beforeIndex + i, + conversionsTo: [] // Newly added type can't have any conversions to it + }); + } + // update the typeList + const affectedTypes = typeList.slice(beforeIndex); + typeList = typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes); + // Fix the indices + for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) { + typeMap.get(typeList[i]).index = i; + } + } + + /** + * Removes all types and conversions from this typed instance. + * May cause previously constructed typed-functions to throw + * strange errors when they are called with types that do not + * match any of their signatures. + */ + function clear() { + typeMap = new Map(); + typeList = []; + nConversions = 0; + addTypes([anyType], false); + } + + // initialize the types to the default list + clear(); + addTypes(_types); + + /** + * Removes all conversions, leaving the types alone. + */ + function clearConversions() { + let typeName; + for (typeName of typeList) { + typeMap.get(typeName).conversionsTo = []; + } + nConversions = 0; + } + + /** + * Find the type names that match a value. + * @param {*} value + * @return {string[]} Array of names of types for which + * the type test matches the value. + */ + function findTypeNames(value) { + const matches = typeList.filter(name => { + const type = typeMap.get(name); + return !type.isAny && type.test(value); + }); + if (matches.length) { + return matches; + } + return ['any']; + } + + /** + * Check if an entity is a typed function created by any instance + * @param {any} entity + * @returns {boolean} + */ + function isTypedFunction(entity) { + return entity && typeof entity === 'function' && '_typedFunctionData' in entity; + } + + /** + * Find a specific signature from a (composed) typed function, for example: + * + * typed.findSignature(fn, ['number', 'string']) + * typed.findSignature(fn, 'number, string') + * typed.findSignature(fn, 'number,string', {exact: true}) + * + * This function findSignature will by default return the best match to + * the given signature, possibly employing type conversions. + * + * The (optional) third argument is a plain object giving options + * controlling the signature search. Currently the only implemented + * option is `exact`: if specified as true (default is false), only + * exact matches will be returned (i.e. signatures for which `fn` was + * directly defined). Note that a (possibly different) type matching + * `any`, or one or more instances of TYPE matching `...TYPE` are + * considered exact matches in this regard, as no conversions are used. + * + * This function returns a "signature" object, as does `typed.resolve()`, + * which is a plain object with four keys: `params` (the array of parameters + * for this signature), `fn` (the originally supplied function for this + * signature), `test` (a generated function that determines if an argument + * list matches this signature, and `implementation` (the function to call + * on a matching argument list, that performs conversions if necessary and + * then calls the originally supplied function). + * + * @param {Function} fn A typed-function + * @param {string | string[]} signature + * Signature to be found, can be an array or a comma separated string. + * @param {object} options Controls the signature search as documented + * @return {{ params: Param[], fn: function, test: function, implementation: function }} + * Returns the matching signature, or throws an error when no signature + * is found. + */ + function findSignature(fn, signature, options) { + if (!isTypedFunction(fn)) { + throw new TypeError(NOT_TYPED_FUNCTION); + } + + // Canonicalize input + const exact = options && options.exact; + const stringSignature = Array.isArray(signature) ? signature.join(',') : signature; + const params = parseSignature(stringSignature); + const canonicalSignature = stringifyParams(params); + + // First hope we get lucky and exactly match a signature + if (!exact || canonicalSignature in fn.signatures) { + // OK, we can check the internal signatures + const match = fn._typedFunctionData.signatureMap.get(canonicalSignature); + if (match) { + return match; + } + } + + // Oh well, we did not; so we have to go back and check the parameters + // one by one, in order to catch things like `any` and rest params. + // Note here we can assume there is at least one parameter, because + // the empty signature would have matched successfully above. + const nParams = params.length; + let remainingSignatures; + if (exact) { + remainingSignatures = []; + let name; + for (name in fn.signatures) { + remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name)); + } + } else { + remainingSignatures = fn._typedFunctionData.signatures; + } + for (let i = 0; i < nParams; ++i) { + const want = params[i]; + const filteredSignatures = []; + let possibility; + for (possibility of remainingSignatures) { + const have = getParamAtIndex(possibility.params, i); + if (!have || want.restParam && !have.restParam) { + continue; + } + if (!have.hasAny) { + // have to check all of the wanted types are available + const haveTypes = paramTypeSet(have); + if (want.types.some(wtype => !haveTypes.has(wtype.name))) { + continue; + } + } + // OK, this looks good + filteredSignatures.push(possibility); + } + remainingSignatures = filteredSignatures; + if (remainingSignatures.length === 0) break; + } + // Return the first remaining signature that was totally matched: + let candidate; + for (candidate of remainingSignatures) { + if (candidate.params.length <= nParams) { + return candidate; + } + } + throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))'); + } + + /** + * Find the proper function to call for a specific signature from + * a (composed) typed function, for example: + * + * typed.find(fn, ['number', 'string']) + * typed.find(fn, 'number, string') + * typed.find(fn, 'number,string', {exact: true}) + * + * This function find will by default return the best match to + * the given signature, possibly employing type conversions (and returning + * a function that will perform those conversions as needed). The + * (optional) third argument is a plain object giving options contolling + * the signature search. Currently only the option `exact` is implemented, + * which defaults to "false". If `exact` is specified as true, then only + * exact matches will be returned (i.e. signatures for which `fn` was + * directly defined). Uses of `any` and `...TYPE` are considered exact if + * no conversions are necessary to apply the corresponding function. + * + * @param {Function} fn A typed-function + * @param {string | string[]} signature + * Signature to be found, can be an array or a comma separated string. + * @param {object} options Controls the signature match as documented + * @return {function} + * Returns the function to call for the given signature, or throws an + * error if no match is found. + */ + function find(fn, signature, options) { + return findSignature(fn, signature, options).implementation; + } + + /** + * Convert a given value to another data type, specified by type name. + * + * @param {*} value + * @param {string} typeName + */ + function convert(value, typeName) { + // check conversion is needed + const type = findType(typeName); + if (type.test(value)) { + return value; + } + const conversions = type.conversionsTo; + if (conversions.length === 0) { + throw new Error('There are no conversions to ' + typeName + ' defined.'); + } + for (let i = 0; i < conversions.length; i++) { + const fromType = findType(conversions[i].from); + if (fromType.test(value)) { + return conversions[i].convert(value); + } + } + throw new Error('Cannot convert ' + value + ' to ' + typeName); + } + + /** + * Stringify parameters in a normalized way + * @param {Param[]} params + * @param {string} [','] separator + * @return {string} + */ + function stringifyParams(params) { + let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ','; + return params.map(p => p.name).join(separator); + } + + /** + * Parse a parameter, like "...number | boolean" + * @param {string} param + * @return {Param} param + */ + function parseParam(param) { + const restParam = param.indexOf('...') === 0; + const types = !restParam ? param : param.length > 3 ? param.slice(3) : 'any'; + const typeDefs = types.split('|').map(s => findType(s.trim())); + let hasAny = false; + let paramName = restParam ? '...' : ''; + const exactTypes = typeDefs.map(function (type) { + hasAny = type.isAny || hasAny; + paramName += type.name + '|'; + return { + name: type.name, + typeIndex: type.index, + test: type.test, + isAny: type.isAny, + conversion: null, + conversionIndex: -1 + }; + }); + return { + types: exactTypes, + name: paramName.slice(0, -1), + // remove trailing '|' from above + hasAny, + hasConversion: false, + restParam + }; + } + + /** + * Expands a parsed parameter with the types available from currently + * defined conversions. + * @param {Param} param + * @return {Param} param + */ + function expandParam(param) { + const typeNames = param.types.map(t => t.name); + const matchingConversions = availableConversions(typeNames); + let hasAny = param.hasAny; + let newName = param.name; + const convertibleTypes = matchingConversions.map(function (conversion) { + const type = findType(conversion.from); + hasAny = type.isAny || hasAny; + newName += '|' + conversion.from; + return { + name: conversion.from, + typeIndex: type.index, + test: type.test, + isAny: type.isAny, + conversion, + conversionIndex: conversion.index + }; + }); + return { + types: param.types.concat(convertibleTypes), + name: newName, + hasAny, + hasConversion: convertibleTypes.length > 0, + restParam: param.restParam + }; + } + + /** + * Return the set of type names in a parameter. + * Caches the result for efficiency + * + * @param {Param} param + * @return {Set} typenames + */ + function paramTypeSet(param) { + if (!param.typeSet) { + param.typeSet = new Set(); + param.types.forEach(type => param.typeSet.add(type.name)); + } + return param.typeSet; + } + + /** + * Parse a signature with comma separated parameters, + * like "number | boolean, ...string" + * + * @param {string} signature + * @return {Param[]} params + */ + function parseSignature(rawSignature) { + const params = []; + if (typeof rawSignature !== 'string') { + throw new TypeError('Signatures must be strings'); + } + const signature = rawSignature.trim(); + if (signature === '') { + return params; + } + const rawParams = signature.split(','); + for (let i = 0; i < rawParams.length; ++i) { + const parsedParam = parseParam(rawParams[i].trim()); + if (parsedParam.restParam && i !== rawParams.length - 1) { + throw new SyntaxError('Unexpected rest parameter "' + rawParams[i] + '": ' + 'only allowed for the last parameter'); + } + // if invalid, short-circuit (all the types may have been filtered) + if (parsedParam.types.length === 0) { + return null; + } + params.push(parsedParam); + } + return params; + } + + /** + * Test whether a set of params contains a restParam + * @param {Param[]} params + * @return {boolean} Returns true when the last parameter is a restParam + */ + function hasRestParam(params) { + const param = last(params); + return param ? param.restParam : false; + } + + /** + * Create a type test for a single parameter, which can have one or multiple + * types. + * @param {Param} param + * @return {function(x: *) : boolean} Returns a test function + */ + function compileTest(param) { + if (!param || param.types.length === 0) { + // nothing to do + return ok; + } else if (param.types.length === 1) { + return findType(param.types[0].name).test; + } else if (param.types.length === 2) { + const test0 = findType(param.types[0].name).test; + const test1 = findType(param.types[1].name).test; + return function or(x) { + return test0(x) || test1(x); + }; + } else { + // param.types.length > 2 + const tests = param.types.map(function (type) { + return findType(type.name).test; + }); + return function or(x) { + for (let i = 0; i < tests.length; i++) { + if (tests[i](x)) { + return true; + } + } + return false; + }; + } + } + + /** + * Create a test for all parameters of a signature + * @param {Param[]} params + * @return {function(args: Array<*>) : boolean} + */ + function compileTests(params) { + let tests, test0, test1; + if (hasRestParam(params)) { + // variable arguments like '...number' + tests = initial(params).map(compileTest); + const varIndex = tests.length; + const lastTest = compileTest(last(params)); + const testRestParam = function (args) { + for (let i = varIndex; i < args.length; i++) { + if (!lastTest(args[i])) { + return false; + } + } + return true; + }; + return function testArgs(args) { + for (let i = 0; i < tests.length; i++) { + if (!tests[i](args[i])) { + return false; + } + } + return testRestParam(args) && args.length >= varIndex + 1; + }; + } else { + // no variable arguments + if (params.length === 0) { + return function testArgs(args) { + return args.length === 0; + }; + } else if (params.length === 1) { + test0 = compileTest(params[0]); + return function testArgs(args) { + return test0(args[0]) && args.length === 1; + }; + } else if (params.length === 2) { + test0 = compileTest(params[0]); + test1 = compileTest(params[1]); + return function testArgs(args) { + return test0(args[0]) && test1(args[1]) && args.length === 2; + }; + } else { + // arguments.length > 2 + tests = params.map(compileTest); + return function testArgs(args) { + for (let i = 0; i < tests.length; i++) { + if (!tests[i](args[i])) { + return false; + } + } + return args.length === tests.length; + }; + } + } + } + + /** + * Find the parameter at a specific index of a Params list. + * Handles rest parameters. + * @param {Param[]} params + * @param {number} index + * @return {Param | null} Returns the matching parameter when found, + * null otherwise. + */ + function getParamAtIndex(params, index) { + return index < params.length ? params[index] : hasRestParam(params) ? last(params) : null; + } + + /** + * Get all type names of a parameter + * @param {Params[]} params + * @param {number} index + * @return {string[]} Returns an array with type names + */ + function getTypeSetAtIndex(params, index) { + const param = getParamAtIndex(params, index); + if (!param) { + return new Set(); + } + return paramTypeSet(param); + } + + /** + * Test whether a type is an exact type or conversion + * @param {Type} type + * @return {boolean} Returns true when + */ + function isExactType(type) { + return type.conversion === null || type.conversion === undefined; + } + + /** + * Helper function for creating error messages: create an array with + * all available types on a specific argument index. + * @param {Signature[]} signatures + * @param {number} index + * @return {string[]} Returns an array with available types + */ + function mergeExpectedParams(signatures, index) { + const typeSet = new Set(); + signatures.forEach(signature => { + const paramSet = getTypeSetAtIndex(signature.params, index); + let name; + for (name of paramSet) { + typeSet.add(name); + } + }); + return typeSet.has('any') ? ['any'] : Array.from(typeSet); + } + + /** + * Create + * @param {string} name The name of the function + * @param {array.<*>} args The actual arguments passed to the function + * @param {Signature[]} signatures A list with available signatures + * @return {TypeError} Returns a type error with additional data + * attached to it in the property `data` + */ + function createError(name, args, signatures) { + let err, expected; + const _name = name || 'unnamed'; + + // test for wrong type at some index + let matchingSignatures = signatures; + let index; + for (index = 0; index < args.length; index++) { + const nextMatchingDefs = []; + matchingSignatures.forEach(signature => { + const param = getParamAtIndex(signature.params, index); + const test = compileTest(param); + if ((index < signature.params.length || hasRestParam(signature.params)) && test(args[index])) { + nextMatchingDefs.push(signature); + } + }); + if (nextMatchingDefs.length === 0) { + // no matching signatures anymore, throw error "wrong type" + expected = mergeExpectedParams(matchingSignatures, index); + if (expected.length > 0) { + const actualTypes = findTypeNames(args[index]); + err = new TypeError('Unexpected type of argument in function ' + _name + ' (expected: ' + expected.join(' or ') + ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')'); + err.data = { + category: 'wrongType', + fn: _name, + index, + actual: actualTypes, + expected + }; + return err; + } + } else { + matchingSignatures = nextMatchingDefs; + } + } + + // test for too few arguments + const lengths = matchingSignatures.map(function (signature) { + return hasRestParam(signature.params) ? Infinity : signature.params.length; + }); + if (args.length < Math.min.apply(null, lengths)) { + expected = mergeExpectedParams(matchingSignatures, index); + err = new TypeError('Too few arguments in function ' + _name + ' (expected: ' + expected.join(' or ') + ', index: ' + args.length + ')'); + err.data = { + category: 'tooFewArgs', + fn: _name, + index: args.length, + expected + }; + return err; + } + + // test for too many arguments + const maxLength = Math.max.apply(null, lengths); + if (args.length > maxLength) { + err = new TypeError('Too many arguments in function ' + _name + ' (expected: ' + maxLength + ', actual: ' + args.length + ')'); + err.data = { + category: 'tooManyArgs', + fn: _name, + index: args.length, + expectedLength: maxLength + }; + return err; + } + + // Generic error + const argTypes = []; + for (let i = 0; i < args.length; ++i) { + argTypes.push(findTypeNames(args[i]).join('|')); + } + err = new TypeError('Arguments of type "' + argTypes.join(', ') + '" do not match any of the defined signatures of function ' + _name + '.'); + err.data = { + category: 'mismatch', + actual: argTypes + }; + return err; + } + + /** + * Find the lowest index of all exact types of a parameter (no conversions) + * @param {Param} param + * @return {number} Returns the index of the lowest type in typed.types + */ + function getLowestTypeIndex(param) { + let min = typeList.length + 1; + for (let i = 0; i < param.types.length; i++) { + if (isExactType(param.types[i])) { + min = Math.min(min, param.types[i].typeIndex); + } + } + return min; + } + + /** + * Find the lowest index of the conversion of all types of the parameter + * having a conversion + * @param {Param} param + * @return {number} Returns the lowest index of the conversions of this type + */ + function getLowestConversionIndex(param) { + let min = nConversions + 1; + for (let i = 0; i < param.types.length; i++) { + if (!isExactType(param.types[i])) { + min = Math.min(min, param.types[i].conversionIndex); + } + } + return min; + } + + /** + * Compare two params + * @param {Param} param1 + * @param {Param} param2 + * @return {number} returns -1 when param1 must get a lower + * index than param2, 1 when the opposite, + * or zero when both are equal + */ + function compareParams(param1, param2) { + // We compare a number of metrics on a param in turn: + // 1) 'any' parameters are the least preferred + if (param1.hasAny) { + if (!param2.hasAny) { + return 1; + } + } else if (param2.hasAny) { + return -1; + } + + // 2) Prefer non-rest to rest parameters + if (param1.restParam) { + if (!param2.restParam) { + return 1; + } + } else if (param2.restParam) { + return -1; + } + + // 3) Prefer exact type match to conversions + if (param1.hasConversion) { + if (!param2.hasConversion) { + return 1; + } + } else if (param2.hasConversion) { + return -1; + } + + // 4) Prefer lower type index: + const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2); + if (typeDiff < 0) { + return -1; + } + if (typeDiff > 0) { + return 1; + } + + // 5) Prefer lower conversion index + const convDiff = getLowestConversionIndex(param1) - getLowestConversionIndex(param2); + if (convDiff < 0) { + return -1; + } + if (convDiff > 0) { + return 1; + } + + // Don't have a basis for preference + return 0; + } + + /** + * Compare two signatures + * @param {Signature} signature1 + * @param {Signature} signature2 + * @return {number} returns a negative number when param1 must get a lower + * index than param2, a positive number when the opposite, + * or zero when both are equal + */ + function compareSignatures(signature1, signature2) { + const pars1 = signature1.params; + const pars2 = signature2.params; + const last1 = last(pars1); + const last2 = last(pars2); + const hasRest1 = hasRestParam(pars1); + const hasRest2 = hasRestParam(pars2); + // We compare a number of metrics on signatures in turn: + // 1) An "any rest param" is least preferred + if (hasRest1 && last1.hasAny) { + if (!hasRest2 || !last2.hasAny) { + return 1; + } + } else if (hasRest2 && last2.hasAny) { + return -1; + } + + // 2) Minimize the number of 'any' parameters + let any1 = 0; + let conv1 = 0; + let par; + for (par of pars1) { + if (par.hasAny) ++any1; + if (par.hasConversion) ++conv1; + } + let any2 = 0; + let conv2 = 0; + for (par of pars2) { + if (par.hasAny) ++any2; + if (par.hasConversion) ++conv2; + } + if (any1 !== any2) { + return any1 - any2; + } + + // 3) A conversion rest param is less preferred + if (hasRest1 && last1.hasConversion) { + if (!hasRest2 || !last2.hasConversion) { + return 1; + } + } else if (hasRest2 && last2.hasConversion) { + return -1; + } + + // 4) Minimize the number of conversions + if (conv1 !== conv2) { + return conv1 - conv2; + } + + // 5) Prefer no rest param + if (hasRest1) { + if (!hasRest2) { + return 1; + } + } else if (hasRest2) { + return -1; + } + + // 6) Prefer shorter with rest param, longer without + const lengthCriterion = (pars1.length - pars2.length) * (hasRest1 ? -1 : 1); + if (lengthCriterion !== 0) { + return lengthCriterion; + } + + // Signatures are identical in each of the above metrics. + // In particular, they are the same length. + // We can therefore compare the parameters one by one. + // First we count which signature has more preferred parameters. + const comparisons = []; + let tc = 0; + for (let i = 0; i < pars1.length; ++i) { + const thisComparison = compareParams(pars1[i], pars2[i]); + comparisons.push(thisComparison); + tc += thisComparison; + } + if (tc !== 0) { + return tc; + } + + // They have the same number of preferred parameters, so go by the + // earliest parameter in which we have a preference. + // In other words, dispatch is driven somewhat more by earlier + // parameters than later ones. + let c; + for (c of comparisons) { + if (c !== 0) { + return c; + } + } + + // It's a tossup: + return 0; + } + + /** + * Produce a list of all conversions from distinct types to one of + * the given types. + * + * @param {string[]} typeNames + * @return {ConversionDef[]} Returns the conversions that are available + * resulting in any given type (if any) + */ + function availableConversions(typeNames) { + if (typeNames.length === 0) { + return []; + } + const types = typeNames.map(findType); + if (typeNames.length > 1) { + types.sort((t1, t2) => t1.index - t2.index); + } + let matches = types[0].conversionsTo; + if (typeNames.length === 1) { + return matches; + } + matches = matches.concat([]); // shallow copy the matches + // Since the types are now in index order, we just want the first + // occurrence of any from type: + const knownTypes = new Set(typeNames); + for (let i = 1; i < types.length; ++i) { + let newMatch; + for (newMatch of types[i].conversionsTo) { + if (!knownTypes.has(newMatch.from)) { + matches.push(newMatch); + knownTypes.add(newMatch.from); + } + } + } + return matches; + } + + /** + * Preprocess arguments before calling the original function: + * - if needed convert the parameters + * - in case of rest parameters, move the rest parameters into an Array + * @param {Param[]} params + * @param {function} fn + * @return {function} Returns a wrapped function + */ + function compileArgsPreprocessing(params, fn) { + let fnConvert = fn; + + // TODO: can we make this wrapper function smarter/simpler? + + if (params.some(p => p.hasConversion)) { + const restParam = hasRestParam(params); + const compiledConversions = params.map(compileArgConversion); + fnConvert = function convertArgs() { + const args = []; + const last = restParam ? arguments.length - 1 : arguments.length; + for (let i = 0; i < last; i++) { + args[i] = compiledConversions[i](arguments[i]); + } + if (restParam) { + args[last] = arguments[last].map(compiledConversions[last]); + } + return fn.apply(this, args); + }; + } + let fnPreprocess = fnConvert; + if (hasRestParam(params)) { + const offset = params.length - 1; + fnPreprocess = function preprocessRestParams() { + return fnConvert.apply(this, slice(arguments, 0, offset).concat([slice(arguments, offset)])); + }; + } + return fnPreprocess; + } + + /** + * Compile conversion for a parameter to the right type + * @param {Param} param + * @return {function} Returns the wrapped function that will convert arguments + * + */ + function compileArgConversion(param) { + let test0, test1, conversion0, conversion1; + const tests = []; + const conversions = []; + param.types.forEach(function (type) { + if (type.conversion) { + tests.push(findType(type.conversion.from).test); + conversions.push(type.conversion.convert); + } + }); + + // create optimized conversion functions depending on the number of conversions + switch (conversions.length) { + case 0: + return function convertArg(arg) { + return arg; + }; + case 1: + test0 = tests[0]; + conversion0 = conversions[0]; + return function convertArg(arg) { + if (test0(arg)) { + return conversion0(arg); + } + return arg; + }; + case 2: + test0 = tests[0]; + test1 = tests[1]; + conversion0 = conversions[0]; + conversion1 = conversions[1]; + return function convertArg(arg) { + if (test0(arg)) { + return conversion0(arg); + } + if (test1(arg)) { + return conversion1(arg); + } + return arg; + }; + default: + return function convertArg(arg) { + for (let i = 0; i < conversions.length; i++) { + if (tests[i](arg)) { + return conversions[i](arg); + } + } + return arg; + }; + } + } + + /** + * Split params with union types in to separate params. + * + * For example: + * + * splitParams([['Array', 'Object'], ['string', 'RegExp']) + * // returns: + * // [ + * // ['Array', 'string'], + * // ['Array', 'RegExp'], + * // ['Object', 'string'], + * // ['Object', 'RegExp'] + * // ] + * + * @param {Param[]} params + * @return {Param[]} + */ + function splitParams(params) { + function _splitParams(params, index, paramsSoFar) { + if (index < params.length) { + const param = params[index]; + let resultingParams = []; + if (param.restParam) { + // split the types of a rest parameter in two: + // one with only exact types, and one with exact types and conversions + const exactTypes = param.types.filter(isExactType); + if (exactTypes.length < param.types.length) { + resultingParams.push({ + types: exactTypes, + name: '...' + exactTypes.map(t => t.name).join('|'), + hasAny: exactTypes.some(t => t.isAny), + hasConversion: false, + restParam: true + }); + } + resultingParams.push(param); + } else { + // split all the types of a regular parameter into one type per param + resultingParams = param.types.map(function (type) { + return { + types: [type], + name: type.name, + hasAny: type.isAny, + hasConversion: type.conversion, + restParam: false + }; + }); + } + + // recurse over the groups with types + return flatMap(resultingParams, function (nextParam) { + return _splitParams(params, index + 1, paramsSoFar.concat([nextParam])); + }); + } else { + // we've reached the end of the parameters. + return [paramsSoFar]; + } + } + return _splitParams(params, 0, []); + } + + /** + * Test whether two param lists represent conflicting signatures + * @param {Param[]} params1 + * @param {Param[]} params2 + * @return {boolean} Returns true when the signatures conflict, false otherwise. + */ + function conflicting(params1, params2) { + const ii = Math.max(params1.length, params2.length); + for (let i = 0; i < ii; i++) { + const typeSet1 = getTypeSetAtIndex(params1, i); + const typeSet2 = getTypeSetAtIndex(params2, i); + let overlap = false; + let name; + for (name of typeSet2) { + if (typeSet1.has(name)) { + overlap = true; + break; + } + } + if (!overlap) { + return false; + } + } + const len1 = params1.length; + const len2 = params2.length; + const restParam1 = hasRestParam(params1); + const restParam2 = hasRestParam(params2); + return restParam1 ? restParam2 ? len1 === len2 : len2 >= len1 : restParam2 ? len1 >= len2 : len1 === len2; + } + + /** + * Helper function for `resolveReferences` that returns a copy of + * functionList wihe any prior resolutions cleared out, in case we are + * recycling signatures from a prior typed function construction. + * + * @param {Array.} functionList + * @return {Array.} + */ + function clearResolutions(functionList) { + return functionList.map(fn => { + if (isReferToSelf(fn)) { + return referToSelf(fn.referToSelf.callback); + } + if (isReferTo(fn)) { + return makeReferTo(fn.referTo.references, fn.referTo.callback); + } + return fn; + }); + } + + /** + * Take a list of references, a list of functions functionList, and a + * signatureMap indexing signatures into functionList, and return + * the list of resolutions, or a false-y value if they don't all + * resolve in a valid way (yet). + * + * @param {string[]} references + * @param {Array} signatureMap + * @return {function[] | false} resolutions + */ + function collectResolutions(references, functionList, signatureMap) { + const resolvedReferences = []; + let reference; + for (reference of references) { + let resolution = signatureMap[reference]; + if (typeof resolution !== 'number') { + throw new TypeError('No definition for referenced signature "' + reference + '"'); + } + resolution = functionList[resolution]; + if (typeof resolution !== 'function') { + return false; + } + resolvedReferences.push(resolution); + } + return resolvedReferences; + } + + /** + * Resolve any references in the functionList for the typed function + * itself. The signatureMap tells which index in the functionList a + * given signature should be mapped to (for use in resolving typed.referTo) + * and self provides the destions of a typed.referToSelf. + * + * @param {Array} functionList + * @param {Object.} signatureMap + * @param {function} self The typed-function itself + * @return {Array} The list of resolved functions + */ + function resolveReferences(functionList, signatureMap, self) { + const resolvedFunctions = clearResolutions(functionList); + const isResolved = new Array(resolvedFunctions.length).fill(false); + let leftUnresolved = true; + while (leftUnresolved) { + leftUnresolved = false; + let nothingResolved = true; + for (let i = 0; i < resolvedFunctions.length; ++i) { + if (isResolved[i]) continue; + const fn = resolvedFunctions[i]; + if (isReferToSelf(fn)) { + resolvedFunctions[i] = fn.referToSelf.callback(self); + // Preserve reference in case signature is reused someday: + resolvedFunctions[i].referToSelf = fn.referToSelf; + isResolved[i] = true; + nothingResolved = false; + } else if (isReferTo(fn)) { + const resolvedReferences = collectResolutions(fn.referTo.references, resolvedFunctions, signatureMap); + if (resolvedReferences) { + resolvedFunctions[i] = fn.referTo.callback.apply(this, resolvedReferences); + // Preserve reference in case signature is reused someday: + resolvedFunctions[i].referTo = fn.referTo; + isResolved[i] = true; + nothingResolved = false; + } else { + leftUnresolved = true; + } + } + } + if (nothingResolved && leftUnresolved) { + throw new SyntaxError('Circular reference detected in resolving typed.referTo'); + } + } + return resolvedFunctions; + } + + /** + * Validate whether any of the function bodies contains a self-reference + * usage like `this(...)` or `this.signatures`. This self-referencing is + * deprecated since typed-function v3. It has been replaced with + * the functions typed.referTo and typed.referToSelf. + * @param {Object.} signaturesMap + */ + function validateDeprecatedThis(signaturesMap) { + // TODO: remove this deprecation warning logic some day (it's introduced in v3) + + // match occurrences like 'this(' and 'this.signatures' + const deprecatedThisRegex = /\bthis(\(|\.signatures\b)/; + Object.keys(signaturesMap).forEach(signature => { + const fn = signaturesMap[signature]; + if (deprecatedThisRegex.test(fn.toString())) { + throw new SyntaxError('Using `this` to self-reference a function ' + 'is deprecated since typed-function@3. ' + 'Use typed.referTo and typed.referToSelf instead.'); + } + }); + } + + /** + * Create a typed function + * @param {String} name The name for the typed function + * @param {Object.} rawSignaturesMap + * An object with one or + * multiple signatures as key, and the + * function corresponding to the + * signature as value. + * @return {function} Returns the created typed function. + */ + function createTypedFunction(name, rawSignaturesMap) { + typed.createCount++; + if (Object.keys(rawSignaturesMap).length === 0) { + throw new SyntaxError('No signatures provided'); + } + if (typed.warnAgainstDeprecatedThis) { + validateDeprecatedThis(rawSignaturesMap); + } + + // Main processing loop for signatures + const parsedParams = []; + const originalFunctions = []; + const signaturesMap = {}; + const preliminarySignatures = []; // may have duplicates from conversions + let signature; + for (signature in rawSignaturesMap) { + // A) Protect against polluted Object prototype: + if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) { + continue; + } + // B) Parse the signature + const params = parseSignature(signature); + if (!params) continue; + // C) Check for conflicts + parsedParams.forEach(function (pp) { + if (conflicting(pp, params)) { + throw new TypeError('Conflicting signatures "' + stringifyParams(pp) + '" and "' + stringifyParams(params) + '".'); + } + }); + parsedParams.push(params); + // D) Store the provided function and add conversions + const functionIndex = originalFunctions.length; + originalFunctions.push(rawSignaturesMap[signature]); + const conversionParams = params.map(expandParam); + // E) Split the signatures and collect them up + let sp; + for (sp of splitParams(conversionParams)) { + const spName = stringifyParams(sp); + preliminarySignatures.push({ + params: sp, + name: spName, + fn: functionIndex + }); + if (sp.every(p => !p.hasConversion)) { + signaturesMap[spName] = functionIndex; + } + } + } + preliminarySignatures.sort(compareSignatures); + + // Note the forward reference to theTypedFn + const resolvedFunctions = resolveReferences(originalFunctions, signaturesMap, theTypedFn); + + // Fill in the proper function for each signature + let s; + for (s in signaturesMap) { + if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) { + signaturesMap[s] = resolvedFunctions[signaturesMap[s]]; + } + } + const signatures = []; + const internalSignatureMap = new Map(); // benchmarks faster than object + for (s of preliminarySignatures) { + // Note it's only safe to eliminate duplicates like this + // _after_ the signature sorting step above; otherwise we might + // remove the wrong one. + if (!internalSignatureMap.has(s.name)) { + s.fn = resolvedFunctions[s.fn]; + signatures.push(s); + internalSignatureMap.set(s.name, s); + } + } + + // we create a highly optimized checks for the first couple of signatures with max 2 arguments + const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params); + const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params); + const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params); + const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params); + const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params); + const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params); + const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5; + + // compile the tests + for (let i = 0; i < signatures.length; ++i) { + signatures[i].test = compileTests(signatures[i].params); + } + const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk; + const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk; + const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk; + const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk; + const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk; + const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk; + const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk; + const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk; + const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk; + const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk; + const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk; + const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk; + + // compile the functions + for (let i = 0; i < signatures.length; ++i) { + signatures[i].implementation = compileArgsPreprocessing(signatures[i].params, signatures[i].fn); + } + const fn0 = ok0 ? signatures[0].implementation : undef; + const fn1 = ok1 ? signatures[1].implementation : undef; + const fn2 = ok2 ? signatures[2].implementation : undef; + const fn3 = ok3 ? signatures[3].implementation : undef; + const fn4 = ok4 ? signatures[4].implementation : undef; + const fn5 = ok5 ? signatures[5].implementation : undef; + const len0 = ok0 ? signatures[0].params.length : -1; + const len1 = ok1 ? signatures[1].params.length : -1; + const len2 = ok2 ? signatures[2].params.length : -1; + const len3 = ok3 ? signatures[3].params.length : -1; + const len4 = ok4 ? signatures[4].params.length : -1; + const len5 = ok5 ? signatures[5].params.length : -1; + + // simple and generic, but also slow + const iStart = allOk ? 6 : 0; + const iEnd = signatures.length; + // de-reference ahead for execution speed: + const tests = signatures.map(s => s.test); + const fns = signatures.map(s => s.implementation); + const generic = function generic() { + + for (let i = iStart; i < iEnd; i++) { + if (tests[i](arguments)) { + return fns[i].apply(this, arguments); + } + } + return typed.onMismatch(name, arguments, signatures); + }; + + // create the typed function + // fast, specialized version. Falls back to the slower, generic one if needed + function theTypedFn(arg0, arg1) { + + if (arguments.length === len0 && test00(arg0) && test01(arg1)) { + return fn0.apply(this, arguments); + } + if (arguments.length === len1 && test10(arg0) && test11(arg1)) { + return fn1.apply(this, arguments); + } + if (arguments.length === len2 && test20(arg0) && test21(arg1)) { + return fn2.apply(this, arguments); + } + if (arguments.length === len3 && test30(arg0) && test31(arg1)) { + return fn3.apply(this, arguments); + } + if (arguments.length === len4 && test40(arg0) && test41(arg1)) { + return fn4.apply(this, arguments); + } + if (arguments.length === len5 && test50(arg0) && test51(arg1)) { + return fn5.apply(this, arguments); + } + return generic.apply(this, arguments); + } + + // attach name the typed function + try { + Object.defineProperty(theTypedFn, 'name', { + value: name + }); + } catch (err) { + // old browsers do not support Object.defineProperty and some don't support setting the name property + // the function name is not essential for the functioning, it's mostly useful for debugging, + // so it's fine to have unnamed functions. + } + + // attach signatures to the function. + // This property is close to the original collection of signatures + // used to create the typed-function, just with unions split: + theTypedFn.signatures = signaturesMap; + + // Store internal data for functions like resolve, find, etc. + // Also serves as the flag that this is a typed-function + theTypedFn._typedFunctionData = { + signatures, + signatureMap: internalSignatureMap + }; + return theTypedFn; + } + + /** + * Action to take on mismatch + * @param {string} name Name of function that was attempted to be called + * @param {Array} args Actual arguments to the call + * @param {Array} signatures Known signatures of the named typed-function + */ + function _onMismatch(name, args, signatures) { + throw createError(name, args, signatures); + } + + /** + * Return all but the last items of an array or function Arguments + * @param {Array | Arguments} arr + * @return {Array} + */ + function initial(arr) { + return slice(arr, 0, arr.length - 1); + } + + /** + * return the last item of an array or function Arguments + * @param {Array | Arguments} arr + * @return {*} + */ + function last(arr) { + return arr[arr.length - 1]; + } + + /** + * Slice an array or function Arguments + * @param {Array | Arguments | IArguments} arr + * @param {number} start + * @param {number} [end] + * @return {Array} + */ + function slice(arr, start, end) { + return Array.prototype.slice.call(arr, start, end); + } + + /** + * Return the first item from an array for which test(arr[i]) returns true + * @param {Array} arr + * @param {function} test + * @return {* | undefined} Returns the first matching item + * or undefined when there is no match + */ + function findInArray(arr, test) { + for (let i = 0; i < arr.length; i++) { + if (test(arr[i])) { + return arr[i]; + } + } + return undefined; + } + + /** + * Flat map the result invoking a callback for every item in an array. + * https://gist.github.com/samgiles/762ee337dff48623e729 + * @param {Array} arr + * @param {function} callback + * @return {Array} + */ + function flatMap(arr, callback) { + return Array.prototype.concat.apply([], arr.map(callback)); + } + + /** + * Create a reference callback to one or multiple signatures + * + * Syntax: + * + * typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) { + * // ... + * }) + * + * @returns {{referTo: {references: string[], callback}}} + */ + function referTo() { + const references = initial(arguments).map(s => stringifyParams(parseSignature(s))); + const callback = last(arguments); + if (typeof callback !== 'function') { + throw new TypeError('Callback function expected as last argument'); + } + return makeReferTo(references, callback); + } + function makeReferTo(references, callback) { + return { + referTo: { + references, + callback + } + }; + } + + /** + * Create a reference callback to the typed-function itself + * + * @param {(self: function) => function} callback + * @returns {{referToSelf: { callback: function }}} + */ + function referToSelf(callback) { + if (typeof callback !== 'function') { + throw new TypeError('Callback function expected as first argument'); + } + return { + referToSelf: { + callback + } + }; + } + + /** + * Test whether something is a referTo object, holding a list with reference + * signatures and a callback. + * + * @param {Object | function} objectOrFn + * @returns {boolean} + */ + function isReferTo(objectOrFn) { + return objectOrFn && typeof objectOrFn.referTo === 'object' && Array.isArray(objectOrFn.referTo.references) && typeof objectOrFn.referTo.callback === 'function'; + } + + /** + * Test whether something is a referToSelf object, holding a callback where + * to pass `self`. + * + * @param {Object | function} objectOrFn + * @returns {boolean} + */ + function isReferToSelf(objectOrFn) { + return objectOrFn && typeof objectOrFn.referToSelf === 'object' && typeof objectOrFn.referToSelf.callback === 'function'; + } + + /** + * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw + * an error in case (C). + * + * @param { string | undefined } nameSoFar + * @param { string | undefined } newName + * @returns { string } updated name + */ + function checkName(nameSoFar, newName) { + if (!nameSoFar) { + return newName; + } + if (newName && newName !== nameSoFar) { + const err = new Error('Function names do not match (expected: ' + nameSoFar + ', actual: ' + newName + ')'); + err.data = { + actual: newName, + expected: nameSoFar + }; + throw err; + } + return nameSoFar; + } + + /** + * Retrieve the implied name from an object with signature keys + * and function values, checking whether all value names match + * + * @param { {string: function} } obj + */ + function getObjectName(obj) { + let name; + for (const key in obj) { + // Only pay attention to own properties, and only if their values + // are typed functions or functions with a signature property + if (Object.prototype.hasOwnProperty.call(obj, key) && (isTypedFunction(obj[key]) || typeof obj[key].signature === 'string')) { + name = checkName(name, obj[key].name); + } + } + return name; + } + + /** + * Copy all of the signatures from the second argument into the first, + * which is modified by side effect, checking for conflicts + * + * @param {Object.} dest + * @param {Object.} source + */ + function mergeSignatures(dest, source) { + let key; + for (key in source) { + if (Object.prototype.hasOwnProperty.call(source, key)) { + if (key in dest) { + if (source[key] !== dest[key]) { + const err = new Error('Signature "' + key + '" is defined twice'); + err.data = { + signature: key, + sourceFunction: source[key], + destFunction: dest[key] + }; + throw err; + } + // else: both signatures point to the same function, that's fine + } + dest[key] = source[key]; + } + } + } + const saveTyped = typed; + + /** + * Originally the main function was a typed function itself, but then + * it might not be able to generate error messages if the client + * replaced the type system with different names. + * + * Main entry: typed([name], functions/objects with signatures...) + * + * Assembles and returns a new typed-function from the given items + * that provide signatures and implementations, each of which may be + * * a plain object mapping (string) signatures to implementing functions, + * * a previously constructed typed function, or + * * any other single function with a string-valued property `signature`. + * The name of the resulting typed-function will be given by the + * string-valued name argument if present, or if not, by the name + * of any of the arguments that have one, as long as any that do are + * consistent with each other. If no name is specified, the name will be + * an empty string. + * + * @param {string} maybeName [optional] + * @param {(function|object)[]} signature providers + * @returns {typed-function} + */ + typed = function (maybeName) { + const named = typeof maybeName === 'string'; + const start = named ? 1 : 0; + let name = named ? maybeName : ''; + const allSignatures = {}; + for (let i = start; i < arguments.length; ++i) { + const item = arguments[i]; + let theseSignatures = {}; + let thisName; + if (typeof item === 'function') { + thisName = item.name; + if (typeof item.signature === 'string') { + // Case 1: Ordinary function with a string 'signature' property + theseSignatures[item.signature] = item; + } else if (isTypedFunction(item)) { + // Case 2: Existing typed function + theseSignatures = item.signatures; + } + } else if (isPlainObject(item)) { + // Case 3: Plain object, assume keys = signatures, values = functions + theseSignatures = item; + if (!named) { + thisName = getObjectName(item); + } + } + if (Object.keys(theseSignatures).length === 0) { + const err = new TypeError('Argument to \'typed\' at index ' + i + ' is not a (typed) function, ' + 'nor an object with signatures as keys and functions as values.'); + err.data = { + index: i, + argument: item + }; + throw err; + } + if (!named) { + name = checkName(name, thisName); + } + mergeSignatures(allSignatures, theseSignatures); + } + return createTypedFunction(name || '', allSignatures); + }; + typed.create = create; + typed.createCount = saveTyped.createCount; + typed.onMismatch = _onMismatch; + typed.throwMismatchError = _onMismatch; + typed.createError = createError; + typed.clear = clear; + typed.clearConversions = clearConversions; + typed.addTypes = addTypes; + typed._findType = findType; // For unit testing only + typed.referTo = referTo; + typed.referToSelf = referToSelf; + typed.convert = convert; + typed.findSignature = findSignature; + typed.find = find; + typed.isTypedFunction = isTypedFunction; + typed.warnAgainstDeprecatedThis = true; + + /** + * add a type (convenience wrapper for typed.addTypes) + * @param {{name: string, test: function}} type + * @param {boolean} [beforeObjectTest=true] + * If true, the new test will be inserted before + * the test with name 'Object' (if any), since + * tests for Object match Array and classes too. + */ + typed.addType = function (type, beforeObjectTest) { + let before = 'any'; + if (beforeObjectTest !== false && typeMap.has('Object')) { + before = 'Object'; + } + typed.addTypes([type], before); + }; + + /** + * Verify that the ConversionDef conversion has a valid format. + * + * @param {conversionDef} conversion + * @return {void} + * @throws {TypeError|SyntaxError} + */ + function _validateConversion(conversion) { + if (!conversion || typeof conversion.from !== 'string' || typeof conversion.to !== 'string' || typeof conversion.convert !== 'function') { + throw new TypeError('Object with properties {from: string, to: string, convert: function} expected'); + } + if (conversion.to === conversion.from) { + throw new SyntaxError('Illegal to define conversion from "' + conversion.from + '" to itself.'); + } + } + + /** + * Add a conversion + * + * @param {ConversionDef} conversion + * @param {{override: boolean}} [options] + * @returns {void} + * @throws {TypeError} + */ + typed.addConversion = function (conversion) { + let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : { + override: false + }; + _validateConversion(conversion); + const to = findType(conversion.to); + const existing = to.conversionsTo.find(other => other.from === conversion.from); + if (existing) { + if (options && options.override) { + typed.removeConversion({ + from: existing.from, + to: conversion.to, + convert: existing.convert + }); + } else { + throw new Error('There is already a conversion from "' + conversion.from + '" to "' + to.name + '"'); + } + } + to.conversionsTo.push({ + from: conversion.from, + convert: conversion.convert, + index: nConversions++ + }); + }; + + /** + * Convenience wrapper to call addConversion on each conversion in a list. + * + * @param {ConversionDef[]} conversions + * @param {{override: boolean}} [options] + * @returns {void} + * @throws {TypeError} + */ + typed.addConversions = function (conversions, options) { + conversions.forEach(conversion => typed.addConversion(conversion, options)); + }; + + /** + * Remove the specified conversion. The format is the same as for + * addConversion, and the convert function must match or an error + * is thrown. + * + * @param {{from: string, to: string, convert: function}} conversion + * @returns {void} + * @throws {TypeError|SyntaxError|Error} + */ + typed.removeConversion = function (conversion) { + _validateConversion(conversion); + const to = findType(conversion.to); + const existingConversion = findInArray(to.conversionsTo, c => c.from === conversion.from); + if (!existingConversion) { + throw new Error('Attempt to remove nonexistent conversion from ' + conversion.from + ' to ' + conversion.to); + } + if (existingConversion.convert !== conversion.convert) { + throw new Error('Conversion to remove does not match existing conversion'); + } + const index = to.conversionsTo.indexOf(existingConversion); + to.conversionsTo.splice(index, 1); + }; + + /** + * Produce the specific signature that a typed function + * will execute on the given arguments. Here, a "signature" is an + * object with properties 'params', 'test', 'fn', and 'implementation'. + * This last property is a function that converts params as necessary + * and then calls 'fn'. Returns null if there is no matching signature. + * @param {typed-function} tf + * @param {any[]} argList + * @returns {{params: string, test: function, fn: function, implementation: function}} + */ + typed.resolve = function (tf, argList) { + if (!isTypedFunction(tf)) { + throw new TypeError(NOT_TYPED_FUNCTION); + } + const sigs = tf._typedFunctionData.signatures; + for (let i = 0; i < sigs.length; ++i) { + if (sigs[i].test(argList)) { + return sigs[i]; + } + } + return null; + }; + return typed; + } + var typedFunction = create(); + + return typedFunction; + +})); +//# sourceMappingURL=typed-function.js.map diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js.map b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js.map new file mode 100644 index 0000000..6752d70 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/lib/umd/typed-function.js.map @@ -0,0 +1 @@ +{"version":3,"file":"typed-function.js","sources":["../esm/typed-function.mjs"],"sourcesContent":["function ok() {\n return true;\n}\nfunction notOk() {\n return false;\n}\nfunction undef() {\n return undefined;\n}\nconst NOT_TYPED_FUNCTION = 'Argument is not a typed-function.';\n\n/**\n * @typedef {{\n * params: Param[],\n * fn: function,\n * test: function,\n * implementation: function\n * }} Signature\n *\n * @typedef {{\n * types: Type[],\n * hasAny: boolean,\n * hasConversion: boolean,\n * restParam: boolean\n * }} Param\n *\n * @typedef {{\n * name: string,\n * typeIndex: number,\n * test: function,\n * isAny: boolean,\n * conversion?: ConversionDef,\n * conversionIndex: number,\n * }} Type\n *\n * @typedef {{\n * from: string,\n * to: string,\n * convert: function (*) : *\n * }} ConversionDef\n *\n * @typedef {{\n * name: string,\n * test: function(*) : boolean,\n * isAny?: boolean\n * }} TypeDef\n */\n\n/**\n * @returns {() => function}\n */\nfunction create() {\n // data type tests\n\n /**\n * Returns true if the argument is a non-null \"plain\" object\n */\n function isPlainObject(x) {\n return typeof x === 'object' && x !== null && x.constructor === Object;\n }\n const _types = [{\n name: 'number',\n test: function (x) {\n return typeof x === 'number';\n }\n }, {\n name: 'string',\n test: function (x) {\n return typeof x === 'string';\n }\n }, {\n name: 'boolean',\n test: function (x) {\n return typeof x === 'boolean';\n }\n }, {\n name: 'Function',\n test: function (x) {\n return typeof x === 'function';\n }\n }, {\n name: 'Array',\n test: Array.isArray\n }, {\n name: 'Date',\n test: function (x) {\n return x instanceof Date;\n }\n }, {\n name: 'RegExp',\n test: function (x) {\n return x instanceof RegExp;\n }\n }, {\n name: 'Object',\n test: isPlainObject\n }, {\n name: 'null',\n test: function (x) {\n return x === null;\n }\n }, {\n name: 'undefined',\n test: function (x) {\n return x === undefined;\n }\n }];\n const anyType = {\n name: 'any',\n test: ok,\n isAny: true\n };\n\n // Data structures to track the types. As these are local variables in\n // create(), each typed universe will get its own copy, but the variables\n // will only be accessible through the (closures of the) functions supplied\n // as properties of the typed object, not directly.\n // These will be initialized in clear() below\n let typeMap; // primary store of all types\n let typeList; // Array of just type names, for the sake of ordering\n\n // And similar data structures for the type conversions:\n let nConversions = 0;\n // the actual conversions are stored on a property of the destination types\n\n // This is a temporary object, will be replaced with a function at the end\n let typed = {\n createCount: 0\n };\n\n /**\n * Takes a type name and returns the corresponding official type object\n * for that type.\n *\n * @param {string} typeName\n * @returns {TypeDef} type\n */\n function findType(typeName) {\n const type = typeMap.get(typeName);\n if (type) {\n return type;\n }\n // Remainder is error handling\n let message = 'Unknown type \"' + typeName + '\"';\n const name = typeName.toLowerCase();\n let otherName;\n for (otherName of typeList) {\n if (otherName.toLowerCase() === name) {\n message += '. Did you mean \"' + otherName + '\" ?';\n break;\n }\n }\n throw new TypeError(message);\n }\n\n /**\n * Adds an array `types` of type definitions to this typed instance.\n * Each type definition should be an object with properties:\n * 'name' - a string giving the name of the type; 'test' - function\n * returning a boolean that tests membership in the type; and optionally\n * 'isAny' - true only for the 'any' type.\n *\n * The second optional argument, `before`, gives the name of a type that\n * these types should be added before. The new types are added in the\n * order specified.\n * @param {TypeDef[]} types\n * @param {string | boolean} [beforeSpec='any'] before\n */\n function addTypes(types) {\n let beforeSpec = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any';\n const beforeIndex = beforeSpec ? findType(beforeSpec).index : typeList.length;\n const newTypes = [];\n for (let i = 0; i < types.length; ++i) {\n if (!types[i] || typeof types[i].name !== 'string' || typeof types[i].test !== 'function') {\n throw new TypeError('Object with properties {name: string, test: function} expected');\n }\n const typeName = types[i].name;\n if (typeMap.has(typeName)) {\n throw new TypeError('Duplicate type name \"' + typeName + '\"');\n }\n newTypes.push(typeName);\n typeMap.set(typeName, {\n name: typeName,\n test: types[i].test,\n isAny: types[i].isAny,\n index: beforeIndex + i,\n conversionsTo: [] // Newly added type can't have any conversions to it\n });\n }\n // update the typeList\n const affectedTypes = typeList.slice(beforeIndex);\n typeList = typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes);\n // Fix the indices\n for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) {\n typeMap.get(typeList[i]).index = i;\n }\n }\n\n /**\n * Removes all types and conversions from this typed instance.\n * May cause previously constructed typed-functions to throw\n * strange errors when they are called with types that do not\n * match any of their signatures.\n */\n function clear() {\n typeMap = new Map();\n typeList = [];\n nConversions = 0;\n addTypes([anyType], false);\n }\n\n // initialize the types to the default list\n clear();\n addTypes(_types);\n\n /**\n * Removes all conversions, leaving the types alone.\n */\n function clearConversions() {\n let typeName;\n for (typeName of typeList) {\n typeMap.get(typeName).conversionsTo = [];\n }\n nConversions = 0;\n }\n\n /**\n * Find the type names that match a value.\n * @param {*} value\n * @return {string[]} Array of names of types for which\n * the type test matches the value.\n */\n function findTypeNames(value) {\n const matches = typeList.filter(name => {\n const type = typeMap.get(name);\n return !type.isAny && type.test(value);\n });\n if (matches.length) {\n return matches;\n }\n return ['any'];\n }\n\n /**\n * Check if an entity is a typed function created by any instance\n * @param {any} entity\n * @returns {boolean}\n */\n function isTypedFunction(entity) {\n return entity && typeof entity === 'function' && '_typedFunctionData' in entity;\n }\n\n /**\n * Find a specific signature from a (composed) typed function, for example:\n *\n * typed.findSignature(fn, ['number', 'string'])\n * typed.findSignature(fn, 'number, string')\n * typed.findSignature(fn, 'number,string', {exact: true})\n *\n * This function findSignature will by default return the best match to\n * the given signature, possibly employing type conversions.\n *\n * The (optional) third argument is a plain object giving options\n * controlling the signature search. Currently the only implemented\n * option is `exact`: if specified as true (default is false), only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Note that a (possibly different) type matching\n * `any`, or one or more instances of TYPE matching `...TYPE` are\n * considered exact matches in this regard, as no conversions are used.\n *\n * This function returns a \"signature\" object, as does `typed.resolve()`,\n * which is a plain object with four keys: `params` (the array of parameters\n * for this signature), `fn` (the originally supplied function for this\n * signature), `test` (a generated function that determines if an argument\n * list matches this signature, and `implementation` (the function to call\n * on a matching argument list, that performs conversions if necessary and\n * then calls the originally supplied function).\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature search as documented\n * @return {{ params: Param[], fn: function, test: function, implementation: function }}\n * Returns the matching signature, or throws an error when no signature\n * is found.\n */\n function findSignature(fn, signature, options) {\n if (!isTypedFunction(fn)) {\n throw new TypeError(NOT_TYPED_FUNCTION);\n }\n\n // Canonicalize input\n const exact = options && options.exact;\n const stringSignature = Array.isArray(signature) ? signature.join(',') : signature;\n const params = parseSignature(stringSignature);\n const canonicalSignature = stringifyParams(params);\n\n // First hope we get lucky and exactly match a signature\n if (!exact || canonicalSignature in fn.signatures) {\n // OK, we can check the internal signatures\n const match = fn._typedFunctionData.signatureMap.get(canonicalSignature);\n if (match) {\n return match;\n }\n }\n\n // Oh well, we did not; so we have to go back and check the parameters\n // one by one, in order to catch things like `any` and rest params.\n // Note here we can assume there is at least one parameter, because\n // the empty signature would have matched successfully above.\n const nParams = params.length;\n let remainingSignatures;\n if (exact) {\n remainingSignatures = [];\n let name;\n for (name in fn.signatures) {\n remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name));\n }\n } else {\n remainingSignatures = fn._typedFunctionData.signatures;\n }\n for (let i = 0; i < nParams; ++i) {\n const want = params[i];\n const filteredSignatures = [];\n let possibility;\n for (possibility of remainingSignatures) {\n const have = getParamAtIndex(possibility.params, i);\n if (!have || want.restParam && !have.restParam) {\n continue;\n }\n if (!have.hasAny) {\n // have to check all of the wanted types are available\n const haveTypes = paramTypeSet(have);\n if (want.types.some(wtype => !haveTypes.has(wtype.name))) {\n continue;\n }\n }\n // OK, this looks good\n filteredSignatures.push(possibility);\n }\n remainingSignatures = filteredSignatures;\n if (remainingSignatures.length === 0) break;\n }\n // Return the first remaining signature that was totally matched:\n let candidate;\n for (candidate of remainingSignatures) {\n if (candidate.params.length <= nParams) {\n return candidate;\n }\n }\n throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))');\n }\n\n /**\n * Find the proper function to call for a specific signature from\n * a (composed) typed function, for example:\n *\n * typed.find(fn, ['number', 'string'])\n * typed.find(fn, 'number, string')\n * typed.find(fn, 'number,string', {exact: true})\n *\n * This function find will by default return the best match to\n * the given signature, possibly employing type conversions (and returning\n * a function that will perform those conversions as needed). The\n * (optional) third argument is a plain object giving options contolling\n * the signature search. Currently only the option `exact` is implemented,\n * which defaults to \"false\". If `exact` is specified as true, then only\n * exact matches will be returned (i.e. signatures for which `fn` was\n * directly defined). Uses of `any` and `...TYPE` are considered exact if\n * no conversions are necessary to apply the corresponding function.\n *\n * @param {Function} fn A typed-function\n * @param {string | string[]} signature\n * Signature to be found, can be an array or a comma separated string.\n * @param {object} options Controls the signature match as documented\n * @return {function}\n * Returns the function to call for the given signature, or throws an\n * error if no match is found.\n */\n function find(fn, signature, options) {\n return findSignature(fn, signature, options).implementation;\n }\n\n /**\n * Convert a given value to another data type, specified by type name.\n *\n * @param {*} value\n * @param {string} typeName\n */\n function convert(value, typeName) {\n // check conversion is needed\n const type = findType(typeName);\n if (type.test(value)) {\n return value;\n }\n const conversions = type.conversionsTo;\n if (conversions.length === 0) {\n throw new Error('There are no conversions to ' + typeName + ' defined.');\n }\n for (let i = 0; i < conversions.length; i++) {\n const fromType = findType(conversions[i].from);\n if (fromType.test(value)) {\n return conversions[i].convert(value);\n }\n }\n throw new Error('Cannot convert ' + value + ' to ' + typeName);\n }\n\n /**\n * Stringify parameters in a normalized way\n * @param {Param[]} params\n * @param {string} [','] separator\n * @return {string}\n */\n function stringifyParams(params) {\n let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ',';\n return params.map(p => p.name).join(separator);\n }\n\n /**\n * Parse a parameter, like \"...number | boolean\"\n * @param {string} param\n * @return {Param} param\n */\n function parseParam(param) {\n const restParam = param.indexOf('...') === 0;\n const types = !restParam ? param : param.length > 3 ? param.slice(3) : 'any';\n const typeDefs = types.split('|').map(s => findType(s.trim()));\n let hasAny = false;\n let paramName = restParam ? '...' : '';\n const exactTypes = typeDefs.map(function (type) {\n hasAny = type.isAny || hasAny;\n paramName += type.name + '|';\n return {\n name: type.name,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion: null,\n conversionIndex: -1\n };\n });\n return {\n types: exactTypes,\n name: paramName.slice(0, -1),\n // remove trailing '|' from above\n hasAny,\n hasConversion: false,\n restParam\n };\n }\n\n /**\n * Expands a parsed parameter with the types available from currently\n * defined conversions.\n * @param {Param} param\n * @return {Param} param\n */\n function expandParam(param) {\n const typeNames = param.types.map(t => t.name);\n const matchingConversions = availableConversions(typeNames);\n let hasAny = param.hasAny;\n let newName = param.name;\n const convertibleTypes = matchingConversions.map(function (conversion) {\n const type = findType(conversion.from);\n hasAny = type.isAny || hasAny;\n newName += '|' + conversion.from;\n return {\n name: conversion.from,\n typeIndex: type.index,\n test: type.test,\n isAny: type.isAny,\n conversion,\n conversionIndex: conversion.index\n };\n });\n return {\n types: param.types.concat(convertibleTypes),\n name: newName,\n hasAny,\n hasConversion: convertibleTypes.length > 0,\n restParam: param.restParam\n };\n }\n\n /**\n * Return the set of type names in a parameter.\n * Caches the result for efficiency\n *\n * @param {Param} param\n * @return {Set} typenames\n */\n function paramTypeSet(param) {\n if (!param.typeSet) {\n param.typeSet = new Set();\n param.types.forEach(type => param.typeSet.add(type.name));\n }\n return param.typeSet;\n }\n\n /**\n * Parse a signature with comma separated parameters,\n * like \"number | boolean, ...string\"\n *\n * @param {string} signature\n * @return {Param[]} params\n */\n function parseSignature(rawSignature) {\n const params = [];\n if (typeof rawSignature !== 'string') {\n throw new TypeError('Signatures must be strings');\n }\n const signature = rawSignature.trim();\n if (signature === '') {\n return params;\n }\n const rawParams = signature.split(',');\n for (let i = 0; i < rawParams.length; ++i) {\n const parsedParam = parseParam(rawParams[i].trim());\n if (parsedParam.restParam && i !== rawParams.length - 1) {\n throw new SyntaxError('Unexpected rest parameter \"' + rawParams[i] + '\": ' + 'only allowed for the last parameter');\n }\n // if invalid, short-circuit (all the types may have been filtered)\n if (parsedParam.types.length === 0) {\n return null;\n }\n params.push(parsedParam);\n }\n return params;\n }\n\n /**\n * Test whether a set of params contains a restParam\n * @param {Param[]} params\n * @return {boolean} Returns true when the last parameter is a restParam\n */\n function hasRestParam(params) {\n const param = last(params);\n return param ? param.restParam : false;\n }\n\n /**\n * Create a type test for a single parameter, which can have one or multiple\n * types.\n * @param {Param} param\n * @return {function(x: *) : boolean} Returns a test function\n */\n function compileTest(param) {\n if (!param || param.types.length === 0) {\n // nothing to do\n return ok;\n } else if (param.types.length === 1) {\n return findType(param.types[0].name).test;\n } else if (param.types.length === 2) {\n const test0 = findType(param.types[0].name).test;\n const test1 = findType(param.types[1].name).test;\n return function or(x) {\n return test0(x) || test1(x);\n };\n } else {\n // param.types.length > 2\n const tests = param.types.map(function (type) {\n return findType(type.name).test;\n });\n return function or(x) {\n for (let i = 0; i < tests.length; i++) {\n if (tests[i](x)) {\n return true;\n }\n }\n return false;\n };\n }\n }\n\n /**\n * Create a test for all parameters of a signature\n * @param {Param[]} params\n * @return {function(args: Array<*>) : boolean}\n */\n function compileTests(params) {\n let tests, test0, test1;\n if (hasRestParam(params)) {\n // variable arguments like '...number'\n tests = initial(params).map(compileTest);\n const varIndex = tests.length;\n const lastTest = compileTest(last(params));\n const testRestParam = function (args) {\n for (let i = varIndex; i < args.length; i++) {\n if (!lastTest(args[i])) {\n return false;\n }\n }\n return true;\n };\n return function testArgs(args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return testRestParam(args) && args.length >= varIndex + 1;\n };\n } else {\n // no variable arguments\n if (params.length === 0) {\n return function testArgs(args) {\n return args.length === 0;\n };\n } else if (params.length === 1) {\n test0 = compileTest(params[0]);\n return function testArgs(args) {\n return test0(args[0]) && args.length === 1;\n };\n } else if (params.length === 2) {\n test0 = compileTest(params[0]);\n test1 = compileTest(params[1]);\n return function testArgs(args) {\n return test0(args[0]) && test1(args[1]) && args.length === 2;\n };\n } else {\n // arguments.length > 2\n tests = params.map(compileTest);\n return function testArgs(args) {\n for (let i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return args.length === tests.length;\n };\n }\n }\n }\n\n /**\n * Find the parameter at a specific index of a Params list.\n * Handles rest parameters.\n * @param {Param[]} params\n * @param {number} index\n * @return {Param | null} Returns the matching parameter when found,\n * null otherwise.\n */\n function getParamAtIndex(params, index) {\n return index < params.length ? params[index] : hasRestParam(params) ? last(params) : null;\n }\n\n /**\n * Get all type names of a parameter\n * @param {Params[]} params\n * @param {number} index\n * @return {string[]} Returns an array with type names\n */\n function getTypeSetAtIndex(params, index) {\n const param = getParamAtIndex(params, index);\n if (!param) {\n return new Set();\n }\n return paramTypeSet(param);\n }\n\n /**\n * Test whether a type is an exact type or conversion\n * @param {Type} type\n * @return {boolean} Returns true when\n */\n function isExactType(type) {\n return type.conversion === null || type.conversion === undefined;\n }\n\n /**\n * Helper function for creating error messages: create an array with\n * all available types on a specific argument index.\n * @param {Signature[]} signatures\n * @param {number} index\n * @return {string[]} Returns an array with available types\n */\n function mergeExpectedParams(signatures, index) {\n const typeSet = new Set();\n signatures.forEach(signature => {\n const paramSet = getTypeSetAtIndex(signature.params, index);\n let name;\n for (name of paramSet) {\n typeSet.add(name);\n }\n });\n return typeSet.has('any') ? ['any'] : Array.from(typeSet);\n }\n\n /**\n * Create\n * @param {string} name The name of the function\n * @param {array.<*>} args The actual arguments passed to the function\n * @param {Signature[]} signatures A list with available signatures\n * @return {TypeError} Returns a type error with additional data\n * attached to it in the property `data`\n */\n function createError(name, args, signatures) {\n let err, expected;\n const _name = name || 'unnamed';\n\n // test for wrong type at some index\n let matchingSignatures = signatures;\n let index;\n for (index = 0; index < args.length; index++) {\n const nextMatchingDefs = [];\n matchingSignatures.forEach(signature => {\n const param = getParamAtIndex(signature.params, index);\n const test = compileTest(param);\n if ((index < signature.params.length || hasRestParam(signature.params)) && test(args[index])) {\n nextMatchingDefs.push(signature);\n }\n });\n if (nextMatchingDefs.length === 0) {\n // no matching signatures anymore, throw error \"wrong type\"\n expected = mergeExpectedParams(matchingSignatures, index);\n if (expected.length > 0) {\n const actualTypes = findTypeNames(args[index]);\n err = new TypeError('Unexpected type of argument in function ' + _name + ' (expected: ' + expected.join(' or ') + ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')');\n err.data = {\n category: 'wrongType',\n fn: _name,\n index,\n actual: actualTypes,\n expected\n };\n return err;\n }\n } else {\n matchingSignatures = nextMatchingDefs;\n }\n }\n\n // test for too few arguments\n const lengths = matchingSignatures.map(function (signature) {\n return hasRestParam(signature.params) ? Infinity : signature.params.length;\n });\n if (args.length < Math.min.apply(null, lengths)) {\n expected = mergeExpectedParams(matchingSignatures, index);\n err = new TypeError('Too few arguments in function ' + _name + ' (expected: ' + expected.join(' or ') + ', index: ' + args.length + ')');\n err.data = {\n category: 'tooFewArgs',\n fn: _name,\n index: args.length,\n expected\n };\n return err;\n }\n\n // test for too many arguments\n const maxLength = Math.max.apply(null, lengths);\n if (args.length > maxLength) {\n err = new TypeError('Too many arguments in function ' + _name + ' (expected: ' + maxLength + ', actual: ' + args.length + ')');\n err.data = {\n category: 'tooManyArgs',\n fn: _name,\n index: args.length,\n expectedLength: maxLength\n };\n return err;\n }\n\n // Generic error\n const argTypes = [];\n for (let i = 0; i < args.length; ++i) {\n argTypes.push(findTypeNames(args[i]).join('|'));\n }\n err = new TypeError('Arguments of type \"' + argTypes.join(', ') + '\" do not match any of the defined signatures of function ' + _name + '.');\n err.data = {\n category: 'mismatch',\n actual: argTypes\n };\n return err;\n }\n\n /**\n * Find the lowest index of all exact types of a parameter (no conversions)\n * @param {Param} param\n * @return {number} Returns the index of the lowest type in typed.types\n */\n function getLowestTypeIndex(param) {\n let min = typeList.length + 1;\n for (let i = 0; i < param.types.length; i++) {\n if (isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].typeIndex);\n }\n }\n return min;\n }\n\n /**\n * Find the lowest index of the conversion of all types of the parameter\n * having a conversion\n * @param {Param} param\n * @return {number} Returns the lowest index of the conversions of this type\n */\n function getLowestConversionIndex(param) {\n let min = nConversions + 1;\n for (let i = 0; i < param.types.length; i++) {\n if (!isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].conversionIndex);\n }\n }\n return min;\n }\n\n /**\n * Compare two params\n * @param {Param} param1\n * @param {Param} param2\n * @return {number} returns -1 when param1 must get a lower\n * index than param2, 1 when the opposite,\n * or zero when both are equal\n */\n function compareParams(param1, param2) {\n // We compare a number of metrics on a param in turn:\n // 1) 'any' parameters are the least preferred\n if (param1.hasAny) {\n if (!param2.hasAny) {\n return 1;\n }\n } else if (param2.hasAny) {\n return -1;\n }\n\n // 2) Prefer non-rest to rest parameters\n if (param1.restParam) {\n if (!param2.restParam) {\n return 1;\n }\n } else if (param2.restParam) {\n return -1;\n }\n\n // 3) Prefer exact type match to conversions\n if (param1.hasConversion) {\n if (!param2.hasConversion) {\n return 1;\n }\n } else if (param2.hasConversion) {\n return -1;\n }\n\n // 4) Prefer lower type index:\n const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2);\n if (typeDiff < 0) {\n return -1;\n }\n if (typeDiff > 0) {\n return 1;\n }\n\n // 5) Prefer lower conversion index\n const convDiff = getLowestConversionIndex(param1) - getLowestConversionIndex(param2);\n if (convDiff < 0) {\n return -1;\n }\n if (convDiff > 0) {\n return 1;\n }\n\n // Don't have a basis for preference\n return 0;\n }\n\n /**\n * Compare two signatures\n * @param {Signature} signature1\n * @param {Signature} signature2\n * @return {number} returns a negative number when param1 must get a lower\n * index than param2, a positive number when the opposite,\n * or zero when both are equal\n */\n function compareSignatures(signature1, signature2) {\n const pars1 = signature1.params;\n const pars2 = signature2.params;\n const last1 = last(pars1);\n const last2 = last(pars2);\n const hasRest1 = hasRestParam(pars1);\n const hasRest2 = hasRestParam(pars2);\n // We compare a number of metrics on signatures in turn:\n // 1) An \"any rest param\" is least preferred\n if (hasRest1 && last1.hasAny) {\n if (!hasRest2 || !last2.hasAny) {\n return 1;\n }\n } else if (hasRest2 && last2.hasAny) {\n return -1;\n }\n\n // 2) Minimize the number of 'any' parameters\n let any1 = 0;\n let conv1 = 0;\n let par;\n for (par of pars1) {\n if (par.hasAny) ++any1;\n if (par.hasConversion) ++conv1;\n }\n let any2 = 0;\n let conv2 = 0;\n for (par of pars2) {\n if (par.hasAny) ++any2;\n if (par.hasConversion) ++conv2;\n }\n if (any1 !== any2) {\n return any1 - any2;\n }\n\n // 3) A conversion rest param is less preferred\n if (hasRest1 && last1.hasConversion) {\n if (!hasRest2 || !last2.hasConversion) {\n return 1;\n }\n } else if (hasRest2 && last2.hasConversion) {\n return -1;\n }\n\n // 4) Minimize the number of conversions\n if (conv1 !== conv2) {\n return conv1 - conv2;\n }\n\n // 5) Prefer no rest param\n if (hasRest1) {\n if (!hasRest2) {\n return 1;\n }\n } else if (hasRest2) {\n return -1;\n }\n\n // 6) Prefer shorter with rest param, longer without\n const lengthCriterion = (pars1.length - pars2.length) * (hasRest1 ? -1 : 1);\n if (lengthCriterion !== 0) {\n return lengthCriterion;\n }\n\n // Signatures are identical in each of the above metrics.\n // In particular, they are the same length.\n // We can therefore compare the parameters one by one.\n // First we count which signature has more preferred parameters.\n const comparisons = [];\n let tc = 0;\n for (let i = 0; i < pars1.length; ++i) {\n const thisComparison = compareParams(pars1[i], pars2[i]);\n comparisons.push(thisComparison);\n tc += thisComparison;\n }\n if (tc !== 0) {\n return tc;\n }\n\n // They have the same number of preferred parameters, so go by the\n // earliest parameter in which we have a preference.\n // In other words, dispatch is driven somewhat more by earlier\n // parameters than later ones.\n let c;\n for (c of comparisons) {\n if (c !== 0) {\n return c;\n }\n }\n\n // It's a tossup:\n return 0;\n }\n\n /**\n * Produce a list of all conversions from distinct types to one of\n * the given types.\n *\n * @param {string[]} typeNames\n * @return {ConversionDef[]} Returns the conversions that are available\n * resulting in any given type (if any)\n */\n function availableConversions(typeNames) {\n if (typeNames.length === 0) {\n return [];\n }\n const types = typeNames.map(findType);\n if (typeNames.length > 1) {\n types.sort((t1, t2) => t1.index - t2.index);\n }\n let matches = types[0].conversionsTo;\n if (typeNames.length === 1) {\n return matches;\n }\n matches = matches.concat([]); // shallow copy the matches\n // Since the types are now in index order, we just want the first\n // occurrence of any from type:\n const knownTypes = new Set(typeNames);\n for (let i = 1; i < types.length; ++i) {\n let newMatch;\n for (newMatch of types[i].conversionsTo) {\n if (!knownTypes.has(newMatch.from)) {\n matches.push(newMatch);\n knownTypes.add(newMatch.from);\n }\n }\n }\n return matches;\n }\n\n /**\n * Preprocess arguments before calling the original function:\n * - if needed convert the parameters\n * - in case of rest parameters, move the rest parameters into an Array\n * @param {Param[]} params\n * @param {function} fn\n * @return {function} Returns a wrapped function\n */\n function compileArgsPreprocessing(params, fn) {\n let fnConvert = fn;\n\n // TODO: can we make this wrapper function smarter/simpler?\n\n if (params.some(p => p.hasConversion)) {\n const restParam = hasRestParam(params);\n const compiledConversions = params.map(compileArgConversion);\n fnConvert = function convertArgs() {\n const args = [];\n const last = restParam ? arguments.length - 1 : arguments.length;\n for (let i = 0; i < last; i++) {\n args[i] = compiledConversions[i](arguments[i]);\n }\n if (restParam) {\n args[last] = arguments[last].map(compiledConversions[last]);\n }\n return fn.apply(this, args);\n };\n }\n let fnPreprocess = fnConvert;\n if (hasRestParam(params)) {\n const offset = params.length - 1;\n fnPreprocess = function preprocessRestParams() {\n return fnConvert.apply(this, slice(arguments, 0, offset).concat([slice(arguments, offset)]));\n };\n }\n return fnPreprocess;\n }\n\n /**\n * Compile conversion for a parameter to the right type\n * @param {Param} param\n * @return {function} Returns the wrapped function that will convert arguments\n *\n */\n function compileArgConversion(param) {\n let test0, test1, conversion0, conversion1;\n const tests = [];\n const conversions = [];\n param.types.forEach(function (type) {\n if (type.conversion) {\n tests.push(findType(type.conversion.from).test);\n conversions.push(type.conversion.convert);\n }\n });\n\n // create optimized conversion functions depending on the number of conversions\n switch (conversions.length) {\n case 0:\n return function convertArg(arg) {\n return arg;\n };\n case 1:\n test0 = tests[0];\n conversion0 = conversions[0];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg);\n }\n return arg;\n };\n case 2:\n test0 = tests[0];\n test1 = tests[1];\n conversion0 = conversions[0];\n conversion1 = conversions[1];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg);\n }\n if (test1(arg)) {\n return conversion1(arg);\n }\n return arg;\n };\n default:\n return function convertArg(arg) {\n for (let i = 0; i < conversions.length; i++) {\n if (tests[i](arg)) {\n return conversions[i](arg);\n }\n }\n return arg;\n };\n }\n }\n\n /**\n * Split params with union types in to separate params.\n *\n * For example:\n *\n * splitParams([['Array', 'Object'], ['string', 'RegExp'])\n * // returns:\n * // [\n * // ['Array', 'string'],\n * // ['Array', 'RegExp'],\n * // ['Object', 'string'],\n * // ['Object', 'RegExp']\n * // ]\n *\n * @param {Param[]} params\n * @return {Param[]}\n */\n function splitParams(params) {\n function _splitParams(params, index, paramsSoFar) {\n if (index < params.length) {\n const param = params[index];\n let resultingParams = [];\n if (param.restParam) {\n // split the types of a rest parameter in two:\n // one with only exact types, and one with exact types and conversions\n const exactTypes = param.types.filter(isExactType);\n if (exactTypes.length < param.types.length) {\n resultingParams.push({\n types: exactTypes,\n name: '...' + exactTypes.map(t => t.name).join('|'),\n hasAny: exactTypes.some(t => t.isAny),\n hasConversion: false,\n restParam: true\n });\n }\n resultingParams.push(param);\n } else {\n // split all the types of a regular parameter into one type per param\n resultingParams = param.types.map(function (type) {\n return {\n types: [type],\n name: type.name,\n hasAny: type.isAny,\n hasConversion: type.conversion,\n restParam: false\n };\n });\n }\n\n // recurse over the groups with types\n return flatMap(resultingParams, function (nextParam) {\n return _splitParams(params, index + 1, paramsSoFar.concat([nextParam]));\n });\n } else {\n // we've reached the end of the parameters.\n return [paramsSoFar];\n }\n }\n return _splitParams(params, 0, []);\n }\n\n /**\n * Test whether two param lists represent conflicting signatures\n * @param {Param[]} params1\n * @param {Param[]} params2\n * @return {boolean} Returns true when the signatures conflict, false otherwise.\n */\n function conflicting(params1, params2) {\n const ii = Math.max(params1.length, params2.length);\n for (let i = 0; i < ii; i++) {\n const typeSet1 = getTypeSetAtIndex(params1, i);\n const typeSet2 = getTypeSetAtIndex(params2, i);\n let overlap = false;\n let name;\n for (name of typeSet2) {\n if (typeSet1.has(name)) {\n overlap = true;\n break;\n }\n }\n if (!overlap) {\n return false;\n }\n }\n const len1 = params1.length;\n const len2 = params2.length;\n const restParam1 = hasRestParam(params1);\n const restParam2 = hasRestParam(params2);\n return restParam1 ? restParam2 ? len1 === len2 : len2 >= len1 : restParam2 ? len1 >= len2 : len1 === len2;\n }\n\n /**\n * Helper function for `resolveReferences` that returns a copy of\n * functionList wihe any prior resolutions cleared out, in case we are\n * recycling signatures from a prior typed function construction.\n *\n * @param {Array.} functionList\n * @return {Array.}\n */\n function clearResolutions(functionList) {\n return functionList.map(fn => {\n if (isReferToSelf(fn)) {\n return referToSelf(fn.referToSelf.callback);\n }\n if (isReferTo(fn)) {\n return makeReferTo(fn.referTo.references, fn.referTo.callback);\n }\n return fn;\n });\n }\n\n /**\n * Take a list of references, a list of functions functionList, and a\n * signatureMap indexing signatures into functionList, and return\n * the list of resolutions, or a false-y value if they don't all\n * resolve in a valid way (yet).\n *\n * @param {string[]} references\n * @param {Array} signatureMap\n * @return {function[] | false} resolutions\n */\n function collectResolutions(references, functionList, signatureMap) {\n const resolvedReferences = [];\n let reference;\n for (reference of references) {\n let resolution = signatureMap[reference];\n if (typeof resolution !== 'number') {\n throw new TypeError('No definition for referenced signature \"' + reference + '\"');\n }\n resolution = functionList[resolution];\n if (typeof resolution !== 'function') {\n return false;\n }\n resolvedReferences.push(resolution);\n }\n return resolvedReferences;\n }\n\n /**\n * Resolve any references in the functionList for the typed function\n * itself. The signatureMap tells which index in the functionList a\n * given signature should be mapped to (for use in resolving typed.referTo)\n * and self provides the destions of a typed.referToSelf.\n *\n * @param {Array} functionList\n * @param {Object.} signatureMap\n * @param {function} self The typed-function itself\n * @return {Array} The list of resolved functions\n */\n function resolveReferences(functionList, signatureMap, self) {\n const resolvedFunctions = clearResolutions(functionList);\n const isResolved = new Array(resolvedFunctions.length).fill(false);\n let leftUnresolved = true;\n while (leftUnresolved) {\n leftUnresolved = false;\n let nothingResolved = true;\n for (let i = 0; i < resolvedFunctions.length; ++i) {\n if (isResolved[i]) continue;\n const fn = resolvedFunctions[i];\n if (isReferToSelf(fn)) {\n resolvedFunctions[i] = fn.referToSelf.callback(self);\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referToSelf = fn.referToSelf;\n isResolved[i] = true;\n nothingResolved = false;\n } else if (isReferTo(fn)) {\n const resolvedReferences = collectResolutions(fn.referTo.references, resolvedFunctions, signatureMap);\n if (resolvedReferences) {\n resolvedFunctions[i] = fn.referTo.callback.apply(this, resolvedReferences);\n // Preserve reference in case signature is reused someday:\n resolvedFunctions[i].referTo = fn.referTo;\n isResolved[i] = true;\n nothingResolved = false;\n } else {\n leftUnresolved = true;\n }\n }\n }\n if (nothingResolved && leftUnresolved) {\n throw new SyntaxError('Circular reference detected in resolving typed.referTo');\n }\n }\n return resolvedFunctions;\n }\n\n /**\n * Validate whether any of the function bodies contains a self-reference\n * usage like `this(...)` or `this.signatures`. This self-referencing is\n * deprecated since typed-function v3. It has been replaced with\n * the functions typed.referTo and typed.referToSelf.\n * @param {Object.} signaturesMap\n */\n function validateDeprecatedThis(signaturesMap) {\n // TODO: remove this deprecation warning logic some day (it's introduced in v3)\n\n // match occurrences like 'this(' and 'this.signatures'\n const deprecatedThisRegex = /\\bthis(\\(|\\.signatures\\b)/;\n Object.keys(signaturesMap).forEach(signature => {\n const fn = signaturesMap[signature];\n if (deprecatedThisRegex.test(fn.toString())) {\n throw new SyntaxError('Using `this` to self-reference a function ' + 'is deprecated since typed-function@3. ' + 'Use typed.referTo and typed.referToSelf instead.');\n }\n });\n }\n\n /**\n * Create a typed function\n * @param {String} name The name for the typed function\n * @param {Object.} rawSignaturesMap\n * An object with one or\n * multiple signatures as key, and the\n * function corresponding to the\n * signature as value.\n * @return {function} Returns the created typed function.\n */\n function createTypedFunction(name, rawSignaturesMap) {\n typed.createCount++;\n if (Object.keys(rawSignaturesMap).length === 0) {\n throw new SyntaxError('No signatures provided');\n }\n if (typed.warnAgainstDeprecatedThis) {\n validateDeprecatedThis(rawSignaturesMap);\n }\n\n // Main processing loop for signatures\n const parsedParams = [];\n const originalFunctions = [];\n const signaturesMap = {};\n const preliminarySignatures = []; // may have duplicates from conversions\n let signature;\n for (signature in rawSignaturesMap) {\n // A) Protect against polluted Object prototype:\n if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) {\n continue;\n }\n // B) Parse the signature\n const params = parseSignature(signature);\n if (!params) continue;\n // C) Check for conflicts\n parsedParams.forEach(function (pp) {\n if (conflicting(pp, params)) {\n throw new TypeError('Conflicting signatures \"' + stringifyParams(pp) + '\" and \"' + stringifyParams(params) + '\".');\n }\n });\n parsedParams.push(params);\n // D) Store the provided function and add conversions\n const functionIndex = originalFunctions.length;\n originalFunctions.push(rawSignaturesMap[signature]);\n const conversionParams = params.map(expandParam);\n // E) Split the signatures and collect them up\n let sp;\n for (sp of splitParams(conversionParams)) {\n const spName = stringifyParams(sp);\n preliminarySignatures.push({\n params: sp,\n name: spName,\n fn: functionIndex\n });\n if (sp.every(p => !p.hasConversion)) {\n signaturesMap[spName] = functionIndex;\n }\n }\n }\n preliminarySignatures.sort(compareSignatures);\n\n // Note the forward reference to theTypedFn\n const resolvedFunctions = resolveReferences(originalFunctions, signaturesMap, theTypedFn);\n\n // Fill in the proper function for each signature\n let s;\n for (s in signaturesMap) {\n if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) {\n signaturesMap[s] = resolvedFunctions[signaturesMap[s]];\n }\n }\n const signatures = [];\n const internalSignatureMap = new Map(); // benchmarks faster than object\n for (s of preliminarySignatures) {\n // Note it's only safe to eliminate duplicates like this\n // _after_ the signature sorting step above; otherwise we might\n // remove the wrong one.\n if (!internalSignatureMap.has(s.name)) {\n s.fn = resolvedFunctions[s.fn];\n signatures.push(s);\n internalSignatureMap.set(s.name, s);\n }\n }\n\n // we create a highly optimized checks for the first couple of signatures with max 2 arguments\n const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params);\n const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params);\n const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params);\n const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params);\n const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params);\n const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params);\n const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5;\n\n // compile the tests\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].test = compileTests(signatures[i].params);\n }\n const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk;\n const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk;\n const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk;\n const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk;\n const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk;\n const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk;\n const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk;\n const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk;\n const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk;\n const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk;\n const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk;\n const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk;\n\n // compile the functions\n for (let i = 0; i < signatures.length; ++i) {\n signatures[i].implementation = compileArgsPreprocessing(signatures[i].params, signatures[i].fn);\n }\n const fn0 = ok0 ? signatures[0].implementation : undef;\n const fn1 = ok1 ? signatures[1].implementation : undef;\n const fn2 = ok2 ? signatures[2].implementation : undef;\n const fn3 = ok3 ? signatures[3].implementation : undef;\n const fn4 = ok4 ? signatures[4].implementation : undef;\n const fn5 = ok5 ? signatures[5].implementation : undef;\n const len0 = ok0 ? signatures[0].params.length : -1;\n const len1 = ok1 ? signatures[1].params.length : -1;\n const len2 = ok2 ? signatures[2].params.length : -1;\n const len3 = ok3 ? signatures[3].params.length : -1;\n const len4 = ok4 ? signatures[4].params.length : -1;\n const len5 = ok5 ? signatures[5].params.length : -1;\n\n // simple and generic, but also slow\n const iStart = allOk ? 6 : 0;\n const iEnd = signatures.length;\n // de-reference ahead for execution speed:\n const tests = signatures.map(s => s.test);\n const fns = signatures.map(s => s.implementation);\n const generic = function generic() {\n 'use strict';\n\n for (let i = iStart; i < iEnd; i++) {\n if (tests[i](arguments)) {\n return fns[i].apply(this, arguments);\n }\n }\n return typed.onMismatch(name, arguments, signatures);\n };\n\n // create the typed function\n // fast, specialized version. Falls back to the slower, generic one if needed\n function theTypedFn(arg0, arg1) {\n 'use strict';\n\n if (arguments.length === len0 && test00(arg0) && test01(arg1)) {\n return fn0.apply(this, arguments);\n }\n if (arguments.length === len1 && test10(arg0) && test11(arg1)) {\n return fn1.apply(this, arguments);\n }\n if (arguments.length === len2 && test20(arg0) && test21(arg1)) {\n return fn2.apply(this, arguments);\n }\n if (arguments.length === len3 && test30(arg0) && test31(arg1)) {\n return fn3.apply(this, arguments);\n }\n if (arguments.length === len4 && test40(arg0) && test41(arg1)) {\n return fn4.apply(this, arguments);\n }\n if (arguments.length === len5 && test50(arg0) && test51(arg1)) {\n return fn5.apply(this, arguments);\n }\n return generic.apply(this, arguments);\n }\n\n // attach name the typed function\n try {\n Object.defineProperty(theTypedFn, 'name', {\n value: name\n });\n } catch (err) {\n // old browsers do not support Object.defineProperty and some don't support setting the name property\n // the function name is not essential for the functioning, it's mostly useful for debugging,\n // so it's fine to have unnamed functions.\n }\n\n // attach signatures to the function.\n // This property is close to the original collection of signatures\n // used to create the typed-function, just with unions split:\n theTypedFn.signatures = signaturesMap;\n\n // Store internal data for functions like resolve, find, etc.\n // Also serves as the flag that this is a typed-function\n theTypedFn._typedFunctionData = {\n signatures,\n signatureMap: internalSignatureMap\n };\n return theTypedFn;\n }\n\n /**\n * Action to take on mismatch\n * @param {string} name Name of function that was attempted to be called\n * @param {Array} args Actual arguments to the call\n * @param {Array} signatures Known signatures of the named typed-function\n */\n function _onMismatch(name, args, signatures) {\n throw createError(name, args, signatures);\n }\n\n /**\n * Return all but the last items of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {Array}\n */\n function initial(arr) {\n return slice(arr, 0, arr.length - 1);\n }\n\n /**\n * return the last item of an array or function Arguments\n * @param {Array | Arguments} arr\n * @return {*}\n */\n function last(arr) {\n return arr[arr.length - 1];\n }\n\n /**\n * Slice an array or function Arguments\n * @param {Array | Arguments | IArguments} arr\n * @param {number} start\n * @param {number} [end]\n * @return {Array}\n */\n function slice(arr, start, end) {\n return Array.prototype.slice.call(arr, start, end);\n }\n\n /**\n * Return the first item from an array for which test(arr[i]) returns true\n * @param {Array} arr\n * @param {function} test\n * @return {* | undefined} Returns the first matching item\n * or undefined when there is no match\n */\n function findInArray(arr, test) {\n for (let i = 0; i < arr.length; i++) {\n if (test(arr[i])) {\n return arr[i];\n }\n }\n return undefined;\n }\n\n /**\n * Flat map the result invoking a callback for every item in an array.\n * https://gist.github.com/samgiles/762ee337dff48623e729\n * @param {Array} arr\n * @param {function} callback\n * @return {Array}\n */\n function flatMap(arr, callback) {\n return Array.prototype.concat.apply([], arr.map(callback));\n }\n\n /**\n * Create a reference callback to one or multiple signatures\n *\n * Syntax:\n *\n * typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) {\n * // ...\n * })\n *\n * @returns {{referTo: {references: string[], callback}}}\n */\n function referTo() {\n const references = initial(arguments).map(s => stringifyParams(parseSignature(s)));\n const callback = last(arguments);\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as last argument');\n }\n return makeReferTo(references, callback);\n }\n function makeReferTo(references, callback) {\n return {\n referTo: {\n references,\n callback\n }\n };\n }\n\n /**\n * Create a reference callback to the typed-function itself\n *\n * @param {(self: function) => function} callback\n * @returns {{referToSelf: { callback: function }}}\n */\n function referToSelf(callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback function expected as first argument');\n }\n return {\n referToSelf: {\n callback\n }\n };\n }\n\n /**\n * Test whether something is a referTo object, holding a list with reference\n * signatures and a callback.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferTo(objectOrFn) {\n return objectOrFn && typeof objectOrFn.referTo === 'object' && Array.isArray(objectOrFn.referTo.references) && typeof objectOrFn.referTo.callback === 'function';\n }\n\n /**\n * Test whether something is a referToSelf object, holding a callback where\n * to pass `self`.\n *\n * @param {Object | function} objectOrFn\n * @returns {boolean}\n */\n function isReferToSelf(objectOrFn) {\n return objectOrFn && typeof objectOrFn.referToSelf === 'object' && typeof objectOrFn.referToSelf.callback === 'function';\n }\n\n /**\n * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw\n * an error in case (C).\n *\n * @param { string | undefined } nameSoFar\n * @param { string | undefined } newName\n * @returns { string } updated name\n */\n function checkName(nameSoFar, newName) {\n if (!nameSoFar) {\n return newName;\n }\n if (newName && newName !== nameSoFar) {\n const err = new Error('Function names do not match (expected: ' + nameSoFar + ', actual: ' + newName + ')');\n err.data = {\n actual: newName,\n expected: nameSoFar\n };\n throw err;\n }\n return nameSoFar;\n }\n\n /**\n * Retrieve the implied name from an object with signature keys\n * and function values, checking whether all value names match\n *\n * @param { {string: function} } obj\n */\n function getObjectName(obj) {\n let name;\n for (const key in obj) {\n // Only pay attention to own properties, and only if their values\n // are typed functions or functions with a signature property\n if (Object.prototype.hasOwnProperty.call(obj, key) && (isTypedFunction(obj[key]) || typeof obj[key].signature === 'string')) {\n name = checkName(name, obj[key].name);\n }\n }\n return name;\n }\n\n /**\n * Copy all of the signatures from the second argument into the first,\n * which is modified by side effect, checking for conflicts\n *\n * @param {Object.} dest\n * @param {Object.} source\n */\n function mergeSignatures(dest, source) {\n let key;\n for (key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n if (key in dest) {\n if (source[key] !== dest[key]) {\n const err = new Error('Signature \"' + key + '\" is defined twice');\n err.data = {\n signature: key,\n sourceFunction: source[key],\n destFunction: dest[key]\n };\n throw err;\n }\n // else: both signatures point to the same function, that's fine\n }\n dest[key] = source[key];\n }\n }\n }\n const saveTyped = typed;\n\n /**\n * Originally the main function was a typed function itself, but then\n * it might not be able to generate error messages if the client\n * replaced the type system with different names.\n *\n * Main entry: typed([name], functions/objects with signatures...)\n *\n * Assembles and returns a new typed-function from the given items\n * that provide signatures and implementations, each of which may be\n * * a plain object mapping (string) signatures to implementing functions,\n * * a previously constructed typed function, or\n * * any other single function with a string-valued property `signature`.\n * The name of the resulting typed-function will be given by the\n * string-valued name argument if present, or if not, by the name\n * of any of the arguments that have one, as long as any that do are\n * consistent with each other. If no name is specified, the name will be\n * an empty string.\n *\n * @param {string} maybeName [optional]\n * @param {(function|object)[]} signature providers\n * @returns {typed-function}\n */\n typed = function (maybeName) {\n const named = typeof maybeName === 'string';\n const start = named ? 1 : 0;\n let name = named ? maybeName : '';\n const allSignatures = {};\n for (let i = start; i < arguments.length; ++i) {\n const item = arguments[i];\n let theseSignatures = {};\n let thisName;\n if (typeof item === 'function') {\n thisName = item.name;\n if (typeof item.signature === 'string') {\n // Case 1: Ordinary function with a string 'signature' property\n theseSignatures[item.signature] = item;\n } else if (isTypedFunction(item)) {\n // Case 2: Existing typed function\n theseSignatures = item.signatures;\n }\n } else if (isPlainObject(item)) {\n // Case 3: Plain object, assume keys = signatures, values = functions\n theseSignatures = item;\n if (!named) {\n thisName = getObjectName(item);\n }\n }\n if (Object.keys(theseSignatures).length === 0) {\n const err = new TypeError('Argument to \\'typed\\' at index ' + i + ' is not a (typed) function, ' + 'nor an object with signatures as keys and functions as values.');\n err.data = {\n index: i,\n argument: item\n };\n throw err;\n }\n if (!named) {\n name = checkName(name, thisName);\n }\n mergeSignatures(allSignatures, theseSignatures);\n }\n return createTypedFunction(name || '', allSignatures);\n };\n typed.create = create;\n typed.createCount = saveTyped.createCount;\n typed.onMismatch = _onMismatch;\n typed.throwMismatchError = _onMismatch;\n typed.createError = createError;\n typed.clear = clear;\n typed.clearConversions = clearConversions;\n typed.addTypes = addTypes;\n typed._findType = findType; // For unit testing only\n typed.referTo = referTo;\n typed.referToSelf = referToSelf;\n typed.convert = convert;\n typed.findSignature = findSignature;\n typed.find = find;\n typed.isTypedFunction = isTypedFunction;\n typed.warnAgainstDeprecatedThis = true;\n\n /**\n * add a type (convenience wrapper for typed.addTypes)\n * @param {{name: string, test: function}} type\n * @param {boolean} [beforeObjectTest=true]\n * If true, the new test will be inserted before\n * the test with name 'Object' (if any), since\n * tests for Object match Array and classes too.\n */\n typed.addType = function (type, beforeObjectTest) {\n let before = 'any';\n if (beforeObjectTest !== false && typeMap.has('Object')) {\n before = 'Object';\n }\n typed.addTypes([type], before);\n };\n\n /**\n * Verify that the ConversionDef conversion has a valid format.\n *\n * @param {conversionDef} conversion\n * @return {void}\n * @throws {TypeError|SyntaxError}\n */\n function _validateConversion(conversion) {\n if (!conversion || typeof conversion.from !== 'string' || typeof conversion.to !== 'string' || typeof conversion.convert !== 'function') {\n throw new TypeError('Object with properties {from: string, to: string, convert: function} expected');\n }\n if (conversion.to === conversion.from) {\n throw new SyntaxError('Illegal to define conversion from \"' + conversion.from + '\" to itself.');\n }\n }\n\n /**\n * Add a conversion\n *\n * @param {ConversionDef} conversion\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversion = function (conversion) {\n let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n override: false\n };\n _validateConversion(conversion);\n const to = findType(conversion.to);\n const existing = to.conversionsTo.find(other => other.from === conversion.from);\n if (existing) {\n if (options && options.override) {\n typed.removeConversion({\n from: existing.from,\n to: conversion.to,\n convert: existing.convert\n });\n } else {\n throw new Error('There is already a conversion from \"' + conversion.from + '\" to \"' + to.name + '\"');\n }\n }\n to.conversionsTo.push({\n from: conversion.from,\n convert: conversion.convert,\n index: nConversions++\n });\n };\n\n /**\n * Convenience wrapper to call addConversion on each conversion in a list.\n *\n * @param {ConversionDef[]} conversions\n * @param {{override: boolean}} [options]\n * @returns {void}\n * @throws {TypeError}\n */\n typed.addConversions = function (conversions, options) {\n conversions.forEach(conversion => typed.addConversion(conversion, options));\n };\n\n /**\n * Remove the specified conversion. The format is the same as for\n * addConversion, and the convert function must match or an error\n * is thrown.\n *\n * @param {{from: string, to: string, convert: function}} conversion\n * @returns {void}\n * @throws {TypeError|SyntaxError|Error}\n */\n typed.removeConversion = function (conversion) {\n _validateConversion(conversion);\n const to = findType(conversion.to);\n const existingConversion = findInArray(to.conversionsTo, c => c.from === conversion.from);\n if (!existingConversion) {\n throw new Error('Attempt to remove nonexistent conversion from ' + conversion.from + ' to ' + conversion.to);\n }\n if (existingConversion.convert !== conversion.convert) {\n throw new Error('Conversion to remove does not match existing conversion');\n }\n const index = to.conversionsTo.indexOf(existingConversion);\n to.conversionsTo.splice(index, 1);\n };\n\n /**\n * Produce the specific signature that a typed function\n * will execute on the given arguments. Here, a \"signature\" is an\n * object with properties 'params', 'test', 'fn', and 'implementation'.\n * This last property is a function that converts params as necessary\n * and then calls 'fn'. Returns null if there is no matching signature.\n * @param {typed-function} tf\n * @param {any[]} argList\n * @returns {{params: string, test: function, fn: function, implementation: function}}\n */\n typed.resolve = function (tf, argList) {\n if (!isTypedFunction(tf)) {\n throw new TypeError(NOT_TYPED_FUNCTION);\n }\n const sigs = tf._typedFunctionData.signatures;\n for (let i = 0; i < sigs.length; ++i) {\n if (sigs[i].test(argList)) {\n return sigs[i];\n }\n }\n return null;\n };\n return typed;\n}\nexport default create();\n//# sourceMappingURL=typed-function.mjs.map"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/package.json new file mode 100644 index 0000000..e168d7b --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/node_modules/typed-function/package.json @@ -0,0 +1,65 @@ +{ + "name": "typed-function", + "version": "4.2.1", + "description": "Type checking for JavaScript functions", + "author": "Jos de Jong (https://github.com/josdejong)", + "contributors": [ + "Glen Whitney (https://github.com/gwhitney)", + "Luke Gumbley (https://github.com/luke-gumbley)" + ], + "homepage": "https://github.com/josdejong/typed-function", + "repository": { + "type": "git", + "url": "https://github.com/josdejong/typed-function.git" + }, + "keywords": [ + "typed", + "function", + "arguments", + "compose", + "types" + ], + "type": "module", + "main": "lib/umd/typed-function.js", + "module": "lib/esm/typed-function.mjs", + "browser": "lib/umd/typed-function.js", + "scripts": { + "test": "mocha test --recursive", + "test:lib": "mocha test test-lib --recursive", + "build": "npm-run-all build:**", + "build:clean": "del-cli lib", + "build:esm": "babel src --out-dir lib/esm --out-file-extension .mjs --source-maps --config-file ./babel.config.json", + "build:umd": "rollup lib/esm/typed-function.mjs --format umd --name 'typed' --sourcemap --output.file lib/umd/typed-function.js && cpy tools/cjs/package.json lib/umd --flat", + "build-and-test": "npm run lint && npm run build && npm run test:lib", + "lint": "eslint --cache src/**/*.mjs test/**/*.mjs test-lib/**/*.mjs", + "format": "npm run lint -- --fix", + "coverage": "c8 --reporter=lcov --reporter=text-summary mocha test --recursive && echo \"\nCoverage report is available at ./coverage/lcov-report/index.html\"", + "prepublishOnly": "npm run build-and-test" + }, + "engines": { + "node": ">= 18" + }, + "devDependencies": { + "@babel/cli": "7.24.6", + "@babel/preset-env": "7.24.6", + "benchmark": "2.1.4", + "c8": "9.1.0", + "cpy-cli": "5.0.0", + "del-cli": "5.1.0", + "eslint": "8.56.0", + "eslint-config-standard": "17.1.0", + "eslint-plugin-import": "2.29.1", + "eslint-plugin-n": "16.6.2", + "eslint-plugin-promise": "6.2.0", + "mocha": "10.4.0", + "npm-run-all": "4.1.5", + "pad-right": "0.2.2", + "rollup": "4.18.0" + }, + "files": [ + "README.md", + "LICENSE.md", + "lib" + ], + "license": "MIT" +} \ No newline at end of file diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package-lock.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package-lock.json new file mode 100644 index 0000000..0d48ada --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package-lock.json @@ -0,0 +1,102 @@ +{ + "name": "2024.-10.-22", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "2024.-10.-22", + "version": "1.0.0", + "license": "ISC", + "dependencies": { + "mathjs": "^13.2.0" + } + }, + "node_modules/@babel/runtime": { + "version": "7.25.7", + "license": "MIT", + "dependencies": { + "regenerator-runtime": "^0.14.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/complex.js": { + "version": "2.3.0", + "license": "MIT", + "engines": { + "node": "*" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/rawify" + } + }, + "node_modules/decimal.js": { + "version": "10.4.3", + "license": "MIT" + }, + "node_modules/escape-latex": { + "version": "1.2.0", + "license": "MIT" + }, + "node_modules/fraction.js": { + "version": "4.3.7", + "license": "MIT", + "engines": { + "node": "*" + }, + "funding": { + "type": "patreon", + "url": "https://github.com/sponsors/rawify" + } + }, + "node_modules/javascript-natural-sort": { + "version": "0.7.1", + "license": "MIT" + }, + "node_modules/mathjs": { + "version": "13.2.0", + "resolved": "https://registry.npmjs.org/mathjs/-/mathjs-13.2.0.tgz", + "integrity": "sha512-P5PZoiUX2Tkghkv3tsSqlK0B9My/ErKapv1j6wdxd0MOrYQ30cnGE4LH/kzYB2gA5rN46Njqc4cFgJjaxgijoQ==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime": "^7.25.6", + "complex.js": "^2.1.1", + "decimal.js": "^10.4.3", + "escape-latex": "^1.2.0", + "fraction.js": "^4.3.7", + "javascript-natural-sort": "^0.7.1", + "seedrandom": "^3.0.5", + "tiny-emitter": "^2.1.0", + "typed-function": "^4.2.1" + }, + "bin": { + "mathjs": "bin/cli.js" + }, + "engines": { + "node": ">= 18" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.14.1", + "license": "MIT" + }, + "node_modules/seedrandom": { + "version": "3.0.5", + "license": "MIT" + }, + "node_modules/tiny-emitter": { + "version": "2.1.0", + "license": "MIT" + }, + "node_modules/typed-function": { + "version": "4.2.1", + "license": "MIT", + "engines": { + "node": ">= 18" + } + } + } +} diff --git a/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package.json b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package.json new file mode 100644 index 0000000..134dd77 --- /dev/null +++ b/Suli/13.b/Frontend/Node.Js/2024. 10. 22/package.json @@ -0,0 +1,15 @@ +{ + "name": "2024.-10.-22", + "version": "1.0.0", + "main": "index.js", + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "keywords": [], + "author": "", + "license": "ISC", + "description": "", + "dependencies": { + "mathjs": "^13.2.0" + } +} diff --git a/Suli/13.b/ProgaOra b/Suli/13.b/ProgaOra new file mode 160000 index 0000000..e328bf3 --- /dev/null +++ b/Suli/13.b/ProgaOra @@ -0,0 +1 @@ +Subproject commit e328bf3c49f7be41a3cf9120621f868fb751d471 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 17.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 17.txt new file mode 100644 index 0000000..1486f6c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2023. 10. 17.txt @@ -0,0 +1,25 @@ +Label +Target attribútummal Alt + N billentyűkombinációval a megadott elemre helyezhetjük a fókuszt (ez esetben a textBox1-re). + +CheckBox és RadioButton +Kiválasztható értékek egyszerű bevitele. CheckBox (jelölőnégyzet), RadioButton (választógomb). A CheckBox és a RadioButton is a ButtonBase osztály leszármazottjai. +A jelölőnégyzet egy vagy több egymástól független beállítás közötti választást teszik lehetővé. IsEnabled: Módosítható-e a beáálítása (alapértelmezetten True), IsChecked: Ki van-e alapból választva a beállítás (alapértelmezetten False). + +Egyéb vezérlők +Ezek a vezérlők nem rendelkeznek Content tulajdonsággal. Pl. Image, vagy a TextBlock. + +TextBox +Szöveg bevitelére és megjelenítésére alkalmas vezérlő. Amennyiben csak szöveg megjelenítésére szeretnénk használni, az IsReadOnly tulajdonság értékét True-ra állítani. Textwrapping: Beírt szöveg tördelése (automatikus tördelés a Wrappel lehet). VerticalScrollBarVisibility: tulajdonság Visible érték beállításával megjelenik a ScrollBar. + +TextBlock +Kisebb mennyiségű szöveg megjelenítésére alkalmas. Nem támogatja a gyorsbillentyűk használatát (Ctrl + C, Ctrl + V, stb.). + +ListBox +A ListBox vezérlővel alapértelmezés szerint egy elem kiválasztására van lehetőség. +SelectedIndex: Az kiválasztott elem indexét adja vissza. +SelectedItem: A kiválasztott elem nevét adja vissza. +IsSelected: Pozitív értékű, amennyiben az aktuális elem kijelölt állapotban van. +Single: Egy elem kiválasztását teszi lehetővé. +Multiple: Több elem kiválasztását teszi lehetővé az adott ListBoxon belül. +Extended: Több elem kiválasztását teszi lehetővé, viszont a Ctrl gomb lenyomásával több ListBox elemét is ki lehet választani. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 11.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 11.txt new file mode 100644 index 0000000..c734cbe --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 11.txt @@ -0,0 +1,12 @@ +LINQ alapműveletek + +A LINQ to Objects az IEnumerable IEnumerable interfészeket megvalósító (foreach ciklussal bejárható) kollekciók esetén működnek. A megvalósítás a System.Linq névtérben kapott helyet, amit alapvetően nem kell használatba vennünk. + +Lambda szintaxis: elemek.Where(i => i.x > 10).Select(i => i.x); +Query szintaxis: var eredmeny = from elem in elemek + where elem.x > 10 + select elem.x; + +OrderBy: Növekvő sorrendbe rendezi a listát +OrderByDescending: Csökkenő sorrendbe rendezi a listát + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 13.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 13.txt new file mode 100644 index 0000000..345043d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 13.txt @@ -0,0 +1,23 @@ +A lambda kifejezés szintaxisa látható módon jelen esetben sokkal egyszerűbb, mivel csak azt kell megadnunk, hogy mi szerint rendezünk csoportba, az eredmény pedig már a csoportok sorozata lesz. Egy csoport egy kulcsból (Key) és az elemekből áll. A kulcs a csoportosítási változó típusát veszi fel, az elemek pedig a kiválasztási elemek lesznek. A példából látható, hogy a csoportok bejárásához két foreach ciklus szükséges. + +A join műveleteknek több fajtája van. Objektumok esetén legkönnyebben az inner join művelet valósítható meg. Ez két típus metszetét jelenti. + +A példában látható módon az összekapcsolás első lépése a szokásos változó hivatkozás az első kollekcióból, majd jön a join kulcsszó, ami után szintén egy változót hivatkozunk be a második kollekcióból. Ezután meg kell adni az összekapcsolási feltételt. Ezt az on után kell megtenni. Jelen esetben itt az a feltételünk, hogy az Y változóknak meg kell egyeznie. Az összekapcsoláshoz minden esetben valamiféle egyenlőségre kell visszavezetnünk a feltételt. A feltétel közepén az Equals kulcsszónak kell állnia. + +Lambda szintaxis esetén a Join metódus első paramétere a kapcsolni kívánt kollekció. Ezt követi két összekapcsolási kulcs kiválasztás. Az első kiválasztás az első kollekcióra érvényes, amin hívtuk a Join metódust, a második pedig a kapcsolni kívánt kollekcióra érvényes. Az utolsó paraméter pedig az eredmény leképezést valósítja meg. + + +LINQ Sorozat és elem műveletek + +A most következő műveletek csak lambda esetében használható: + +Kihagyás és megadott számú elem kiválasztása: + +Ha elemeket szeretnénk kihagyni egy kollekcióból, akkor a Skip(), metódust alkalmazhatjuk. Ennek paramétereként a kihagyandó elemek számát kell megadnunk. Ha pedig csak egy adott mennyiségű elemet szeretnénk kiválasztani, akkor a Take() metódust alkalmazhatjuk. Ennek paramétere szintén egész szám, ami a kiválasztandó elemek számát adja meg. Mindkét metódus esetén, ha kifutna az eredeti kollekció méretéből, akkor egy üres kollekciót kapunk. + +First(): Az első elemet adja vissza. Ha nincs, akkor hibát dob. +FirstOfDefault(): Az első elemet adja vissza. Ha nincs, akkor egy alapértelmezett értéket ad vissza. + +ElementAt(): A kollekció egy adott elemét adja vissza. Bemenetként az elem sorszámát várja, és hibát dob, ha nem létezik a megadott sorszámmal elem. +var eredmeny = elemek.FirstOrDefault(i => i.Y == 99) +var eredmeny2 = elemek.Last(i => i.Y == 1) \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 18.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 18.txt new file mode 100644 index 0000000..6de784f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 18.txt @@ -0,0 +1,5 @@ +A using használata + +A using kulcsszó C#-ban egy speciális konstrukció, amely biztosítja, hogy egy adott erőforrás, mint például fájl vagy hálózati kapcsolat, automatikusan felszabaduljon, miután nincs már rá szükség. A using blokkot tipikusan olyan erőforrások kezelésére, amelyek implementálják az IDisposable interfészt. + +A usingot arra használjuk, hogy biztosítjuk az erőforrások, például fájlok, adatbázis kapcsolatok. \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 19.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 19.txt new file mode 100644 index 0000000..7a84e70 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 09. 19.txt @@ -0,0 +1,27 @@ +DistinctBy(): Azonos elemeket lehet kiszűrni egy összetett adattípusból. +var egyediX = elemek.DistinctBy(i => i.X) + +Count(): Megszámolja azokat az elemeket, amelyekre a feltétel igazzá válik. +var parosX = elemek.Count(i => i.X%2 == 0) + +Any(): Igaz értéket ad vissza, ha van elem az összetett adattípusunkban. Feltétel megadása esetén azt figyeli meg, hogy a felételnek megfelelő elem létezik-e. + +Min(), Max(), Avg(): Minimum, maximum, átlagszámolás. +var avg = elemek.Avg(i => i.X * i.Y) + +Unió: +var union = ints1.Union(ints2) + +Metszet: +var intersect = ints1.Intersect(ints2) + +Csak egyik listában van: +var except = ints1.Except(ints2) + +Concat(): Két lista elemeinek összefűzésére használható. Ismétlődést nem szűr. +var concat = a.Concat(b); + +Zip(): Tuple formában összefűz egy elemet az egyik listából, egy elemet a másik listából. +var result = a.Zip(b) + +Chunk(): Egy listát a Chunk()-ba megadott számú kisebb listákra szedi szét. \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 10.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 10.txt new file mode 100644 index 0000000..ccb17c0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 10.txt @@ -0,0 +1,38 @@ +WPF + +A Windows Presentation Foundation (WPF) a Windows Form utódjának tekinthető asztali alkalmazások fejlesztése terén. Az egyik legnagyobb és egyben legfontosabb különbség, hogy az alkalmazás megjelenéséért felelős kód elkülönül az alkalamzás funkcionalitását leíró kódtól. A WPF GDI/GDI+ helyett DirectX-et használ. Emiatt tetszőleges típusú felhasználói felületet hozhatunk létre. Tervezhető akár komplex háromdimenziós grafika is, de üzleti alkalmazások esetében is kiaknázhatóak a gazdag grafikai hatások. A DirectX már nem a CPU, hanem a GPU erőforrásait használja. Raszter grafika helyett már vektor alapúak az elemek. Emiatt az egyes elemek tetszőlegesen átméretezhetőek. Továbbá kevesebb helyet foglalnak. Viszont továbbra is használja a raszter grafikát. + +Előnyei: + Dokumentum és nyomtatás + Biztonság, hozzáférhetőség és lokalizáció + Együttműködést kínál a következővel: Windows Űrlapvezérlők + A Direct3D-t grafikus alkalmazásokban használják, ahol a teljesítmény fontos + A megjelenítéshez a videókártyát használja + A vektor-alapú grafika lehetővé teszi az alkalmazás méretezését minőségromlás nélkül + A WBF támogatja a lebegőpontos logikai pixelrendszert és a 32 bites ARGB színt + Stílusok és vezérlősablonok újradefiniálása + Nemzetközi betűtípusok építése összetett betűtípusokból + A WPF szövegmegjelenítés segít a ClearType technolósgia előnyeinek kihasználásában + Lehetővé teszi az előre rendelt szöveg gyorsítótárazási technikájának használatát a videómemóriában + Erőforrás-alapú megközelítés minden vezérléshez + A bemutató időzítőit a WPF inicializálja és kezeli + A videó és az animáció közötti kapcsolat szintén támogatott + A WPF-ben a stílus olyan tulajdonságok halmaza, amelyeket a vizuális megjelenítéshez használt tartalomra kell alkalmazni + A WPF sablonjai segítenek a dokumentum UI értékének megváltoztatásában + A parancsok az események elvontabb és lazábban kapcsolt változatai + A WPF parancsok támogatása csökkent a megírandó kód mennyiségét + +A WPF többrétegű architektúrájának legfelső szintjén a PresentationFramework.dll áll. Ezt használjuk fejlesztés közben, itt vannak implementálva a különböző vezérlők (Button, Border,...) stílusok, stb. PresentationFramework.dll számára az alaposztályokat (UIElement, Visual, stb.) a PresentationCore.dll biztosítja. Ezekből az osztályból származnak többek között a formák (shape) és a vezérlők (controls). A WindowsBase.dll a WPF alapvető működéséhez szükséges objektumosztályokat tartalmazza. A WPF névterei a System.Windows névtérben helyezkednek el. + +System.Object + +A WPF összes osztálya a System.Object-ből származik. A WPF legfontosabb komponensei a PresentationFramework, PresentationCore és a milcore, tartalmazzák a WPF legfontosabb kódrészleteit. Ezek között a milcore az egyetlen nem menedzselt kódban írt komponens. + +XAML + +XAML (eXtensible Application Markup Language) egy XML alapú deklaratív jelölőnyelv, amely a .NET keretrendszer modelljébe illeszkedve leegyszerűsíti a grafikus felhasználói felület (GUI) kialakítását. XAML deklaratív nyelv nyelvtani szabályrendszere nagyon egyszerű. Általános tervezési alapelve, hogy a XAML dokumentum minden eleme - kivéve, ha egy attribútumot definiál + +A XAML előnyei: + Elválasztja a front-end megjelenést a háttér logikától + A legegyszerűbb módszer a felhasználói felületek ábrázolására + Hatékonyan dolgozik az eszközökkel \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 16.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 16.txt new file mode 100644 index 0000000..84be1a5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 16.txt @@ -0,0 +1,2 @@ +Canvas +A canvas (vászon) pixel pontosan megadott elrendezést tesz lehetővé, ideális fix méretű alkalmazások elkészítéséhez. A Canvas-on elhelyezett elemek pozícióját a Top - Left és a Bottom - Right tulajdonságával tehetjük meg. \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 18.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 18.txt new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 24.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 24.txt new file mode 100644 index 0000000..b232779 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 10. 24.txt @@ -0,0 +1,21 @@ +Image +Az Image kép megjelenítésre szolgál. Legfontosabb tulajdonsága a Source. Lehet URI-t, vagy relatív hivatkozással megadni a kép forrását. Stretch beállításai: + None: A kép az eredeti méretében jelenik meg. Levágja a képnek azon részét, ami nem fér rá a kijelölt területre. + FIll: Kitölti a képel a kijelölt területet, nem figyeli az eredeti méretarányokat, a kép torzulhat. + Uniform: A méretarány megtartásával tölti ki a képpel a kijelölt területet. + UniformToFill: Teljesen kitölti a képpel a kijelölt terültetet a méretarány megtartásával. + +Slider +A csúszkák egy beállítás értékének megadását teszik lehetővé egy megadott értéktartományon belül. +Slider beállításai: + IsDirectionReserved: Alapértelmezés szerint a csúszka bal oldalához van rendelve a minimum érték, és a jobb oldalához a maximum. Amennyiben ez a beállítás True, megcserélődnek az oldalak értékei. + IsEnabled: A csúszka engedélyezését vagy letiltását teszi lehetővé. + LargeChange: PageUp, PageDown gombokhoz lehet beállítani a lépésközt. + Maximum: A csúszka maximális értéke. + Minimum: A csúszka minimális értéke. + Orientation: A csúszka orientációja állítható be vele. + SmallChange: A kurzormozgatóhoz rendelt lépésköz állítható be vele. + Value: Az aktuális érték. + +Menu +A Menu tulajdonképpen lehetővé teszi a leggyakrabban használt parancsok hierarchikus elrendezését. diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 13.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 13.txt new file mode 100644 index 0000000..45f24ae --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 13.txt @@ -0,0 +1,41 @@ +Algoritmusok + +A problémamegoldás menete: +Valós problémák -> + +Algoritmus: +Az algoritmus egy hatékony eljárás egy feladat vagy probléma. + + +Algoritmusok futásidő elemzése +Futási idő: egy bizonyos bemenetre a végrehajtott (gépfüggetlen) alapműveletek vagy "lépések" száma. +A lépésszám pontos meghatározása helyett általában elegendő lépésszám nagyságrendjének meghatározása, és ebből már (kis óvatossággal) következtetni lehet arra, hogy az algoritmus mennyire hatékony, avagy hogyan fog viselkedni nagyobb értékekre. + +Aszimptotikus hatékonyság: +Ha a bemenet mérete elég nagy, akkor az algoritmus futási idejének csak a nagyságrendje érdekes. + +Az O (Ordó) jelölés: +A O jelölést arra használjuk, ahogy a futási idő növekedését aszimptotikusan alulról és felülről konstant távolságra behatároljuk. +Például a bináris keresés futási ideje legrosszabb esetben O(log2n), helytelen lenne azt állítani, hogy a bináris keresés futási ideje O(log2n) minden esetben. +A bináris keresés futási ideje soha nem rosszabb, mint O(log2n), de van, amikor ennél jobb. + +Jó lenne egy olyan aszimptotikus jelölés, ami azt fejezné ki, hogy "a futási idő maximum ennyivelnő, de ennél korábban is nőhet." Erre használjuk az "O" jelölést. +Ha a futási idő O(f(n)), akkor elég nagy n esetén a futási idő maximum k*f(n) valamilyen konstans k érték mellett. Az O(f(n)) futási időt így kell elképzelni. +Azt mondjuk "f(n) ordója" vagy egyszerűen "O(f(n)) (kiejtésben használatos még az ordó(f(n)) is). Az O jelölést aszimptotikus felső korlátként használjuk, mivel a futási időt felülről korlátozza, ha az input mérete elég nagy. + +Most már minden esetben jellemezni tudjuk a bináris keresés futási idejét. Mondhatjuk azt, hogy a bináris keresés mindig legfeljebb O(log2n) idő alatt lefut. Egy ennél erősebb állítással kijelenthetjük, hogy a legrosszabb esetben a futási idő O(log2n). De egy mindent magába foglaló állítás az lesz, amikor azt mondjuk, hogy a bináris keresés futási ideje O(log2n). + +Tömb +A tömb egy olyan adatszerkezet, amely menet közben nem méretezhető át. Tehát ha új elemeket szeretnénk egy meglévő tömbhöz adni, az csak úgy fog működni, hogy létrehozunk egy új tömböt, ami az új elemek és a meglévő elemek tárolására alkalmas, ezután pedig bemásoljuk a meglévő elemeket és az új elemeket a teljesen új tömbünkbe. +Tömbökben referencia típusokat is alkalmazhatunk, viszont ebben az esetben nem elég példányosítani a tömböt, az egyes elemeket is példányosítani kell, mivel ebben az esetben a tömb csak az objektumra mutató referenciát tárolja, így példányosítás nélkül a tömb elemeinek értéke null lesz. + +Az osztályokat ben muszáj a konstruktuk segítségével példányosítani. Erre célra vezették be a nyelvben az Object Initializer szintaxist, amivel egy osztály adattagjai úgy adhatók meg, mint egy tömb elemei. +Ez akkor jön jól, ha van egy osztályunk, amely adattagokkal rendelkezik de a konstruktor az objektum minden adattagjának beállításához nagyon összetett és komplikált lenne. Ebben az esetben nem érdemes konstruktort írni. Az objektum inicializáló szintaxis a következő: + +var objektum = new Osztaly() +{ + Adattag1 = érték, + Adattag2 = érték, + Adattag3 = érték +}; +Ez a szintaxis csak olyan adattagok esetén alkalmazható, amelyek publikusan is írhatóak. Egyéb védelmi szinttel rendelkező adattagok nem írhatóak ezzel a módszerrel. Ezen adattagok beállítására továbbra is a konstruktor szintaxis használható. \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 15.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 15.txt new file mode 100644 index 0000000..7f03977 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Elmélet/2024. 11. 15.txt @@ -0,0 +1,21 @@ +Adatstruktúra interfészek + +A kollekcióhoz kapcsolódó interfészek közül az egyik legfontosabb az IEnumerable interfész. Ez teszi lehetővé, hogy mindegyik. + + +Az absztrakció következő szintje az IReadOnlyCollection és ICollection interfészek. Az ICollection egy módosítható kollekciót ír le, aminek az elemei törölhetőek és bővíthetőek. Az IReadOnlyCollection pedig egy olyant, amiből csak olvasni tudunk, de tudjuk az elemek számát. + +Az olyan típusok esetén, mint a lista, halmaz és asszociatív tömb kapunk speciális interfészeket, mind olvasható és módosítható változatban is. + + +Láncolt lista + +A tömb adatszerkezet kiváló ha előre tudjuk, hogy mennyi elemre van szükségünk. A bővítés csak úgy lehetséges, hogy létrehozzuk egy újabb tömböt, aminek a mérete a hozzáadandó elemek számával meg van növelve. Az új tömbbe átmásoljuk a tömb elemeit, majd az új tömbhöz hozzáadjuk az új elemeket. Végezetül pedig töröljük az eredeti tömböt. + +Az algoritmus leírásából kiolvasható, hogy ez nem éppen ideális, mivel a sebességre igen negatív hatással van a másolás. Továbbá a másolás folyamán egy rövid időre duplázódik a programunk memóriahasználata. + +Egy sokkal jobb megoldás lehet nagy mennyíségú, előre nem ismert számú adat tárolására a láncolt lista szerkezet. + +A láncolt lista egy eleme két részből épül fel. Egyrészt tartalmazza a tárolni kívánt adatot, vagy adatokat és tartalmaz egy olyan mutatót, ami a lista egy másik elemét mutatja. Ha referencia a következő elemre nem létezik, akkor a lánc végén vagyunk. + +A láncolt lista a dinamikus tömbökhoöz képest hátránya a közbülső elemek elérhetőségéből ered. Míg egy tömb esetén ha tudjuk, hogy a k. elemet szeretnénk elérni, akkor a tömb idnexelésével rögtön hozzáférhetünk ehhez az adathoz, addig a láncolt listában a lista elejéről indulva a mutatókon keresztül addig kell lépkedni, míg a k. elemhez nem érünk. A véletlenszerű lista elem megtalálása a lista hosszávak arányos időt igényel. \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..8b55b10 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/9af9df76-b18f-4996-a4a3-30b613a936d1.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/9af9df76-b18f-4996-a4a3-30b613a936d1.vsidx new file mode 100644 index 0000000..211b5c6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/9af9df76-b18f-4996-a4a3-30b613a936d1.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 new file mode 100644 index 0000000..1f944e6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.suo new file mode 100644 index 0000000..645b126 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/DocumentLayout.json new file mode 100644 index 0000000..20d87ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/2024. 09. 05/v17/DocumentLayout.json @@ -0,0 +1,57 @@ +{ + "Version": 1, + "WorkspaceRootPath": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}|2024. 09. 05\\2024. 09. 05.csproj|d:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\h\u00E1zi\\2024. 09. 05\\2024. 09. 05\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}|2024. 09. 05\\2024. 09. 05.csproj|solutionrelative:2024. 09. 05\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}|2024. 09. 05\\2024. 09. 05.csproj|D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\2024. 09. 05\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}|2024. 09. 05\\2024. 09. 05.csproj|solutionrelative:2024. 09. 05\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{b1e99781-ab81-11d0-b683-00aa00a3ee26}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Form1.cs [Design]", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\2024. 09. 05\\Form1.cs", + "RelativeDocumentMoniker": "2024. 09. 05\\Form1.cs", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\2024. 09. 05\\Form1.cs [Design]", + "RelativeToolTip": "2024. 09. 05\\Form1.cs [Design]", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-05T13:04:44.27Z", + "EditorCaption": " [Design]" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Form1.cs", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\2024. 09. 05\\Form1.cs", + "RelativeDocumentMoniker": "2024. 09. 05\\Form1.cs", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 05\\2024. 09. 05\\Form1.cs", + "RelativeToolTip": "2024. 09. 05\\Form1.cs", + "ViewState": "AQIAAEYAAAAAAAAAAAAmwBkAAAB3AAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-05T12:44:05.461Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin new file mode 100644 index 0000000..90e3949 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin new file mode 100644 index 0000000..f5a4c81 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.strings.v8.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.strings.v8.bin new file mode 100644 index 0000000..39ba6a2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.strings.v8.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05.sln new file mode 100644 index 0000000..48752ce --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 05", "2024. 09. 05\2024. 09. 05.csproj", "{A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}.Debug|Any CPU.Build.0 = Debug|Any CPU + {A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}.Release|Any CPU.ActiveCfg = Release|Any CPU + {A64E42E8-5A02-427D-9AC0-CA5A7A4AFBAA}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {002E4944-0EFA-4DE7-AD06-8827CEC46B35} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj new file mode 100644 index 0000000..8804d8f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._09._05 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user new file mode 100644 index 0000000..3a34caa --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Dolgozok.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Dolgozok.cs new file mode 100644 index 0000000..7e02cf4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Dolgozok.cs @@ -0,0 +1,17 @@ +class Dolgozok +{ + public string Nev { get; set; } + public string Nem { get; set; } + public string Reszleg { get; set; } + public int Belepes { get; set; } + public int Ber { get; set; } + + public Dolgozok(string nev, string nem, string reszleg, int belepes, int ber) + { + Nev = nev; + Nem = nem; + Belepes = belepes; + Reszleg = reszleg; + Ber = ber; + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.Designer.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.Designer.cs new file mode 100644 index 0000000..3687aef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.Designer.cs @@ -0,0 +1,159 @@ +namespace _2024._09._05 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + WorkersLabel = new Label(); + AverageWageLabel = new Label(); + label3 = new Label(); + label4 = new Label(); + SixthTaskLabel = new Label(); + SectionTextBox = new TextBox(); + HighestWageButton = new Button(); + WorkersListBox = new ListBox(); + StatisticsListBox = new ListBox(); + SuspendLayout(); + // + // WorkersLabel + // + WorkersLabel.AutoSize = true; + WorkersLabel.Location = new Point(10, 14); + WorkersLabel.Name = "WorkersLabel"; + WorkersLabel.Size = new Size(99, 15); + WorkersLabel.TabIndex = 0; + WorkersLabel.Text = "Dolgozók száma: "; + // + // AverageWageLabel + // + AverageWageLabel.AutoSize = true; + AverageWageLabel.Location = new Point(33, 164); + AverageWageLabel.Name = "AverageWageLabel"; + AverageWageLabel.Size = new Size(133, 15); + AverageWageLabel.TabIndex = 1; + AverageWageLabel.Text = "4. Feladat: Bérek átlaga: "; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(33, 264); + label3.Name = "label3"; + label3.Size = new Size(115, 15); + label3.TabIndex = 2; + label3.Text = "7. Feladat: Statisztika"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(33, 206); + label4.Name = "label4"; + label4.Size = new Size(124, 15); + label4.TabIndex = 3; + label4.Text = "Kérem a részleg nevét:"; + // + // SixthTaskLabel + // + SixthTaskLabel.AutoSize = true; + SixthTaskLabel.Location = new Point(560, 244); + SixthTaskLabel.Name = "SixthTaskLabel"; + SixthTaskLabel.Size = new Size(63, 15); + SixthTaskLabel.TabIndex = 4; + SixthTaskLabel.Text = "6. Feladat: "; + // + // SectionTextBox + // + SectionTextBox.Location = new Point(249, 204); + SectionTextBox.Margin = new Padding(3, 2, 3, 2); + SectionTextBox.Name = "SectionTextBox"; + SectionTextBox.Size = new Size(233, 23); + SectionTextBox.TabIndex = 5; + // + // HighestWageButton + // + HighestWageButton.Location = new Point(560, 202); + HighestWageButton.Margin = new Padding(3, 2, 3, 2); + HighestWageButton.Name = "HighestWageButton"; + HighestWageButton.Size = new Size(262, 25); + HighestWageButton.TabIndex = 6; + HighestWageButton.Text = "Legnagyobb bérrel rendelkező dolgozó"; + HighestWageButton.UseVisualStyleBackColor = true; + HighestWageButton.Click += HighestWageButton_Click; + // + // WorkersListBox + // + WorkersListBox.FormattingEnabled = true; + WorkersListBox.ItemHeight = 15; + WorkersListBox.Location = new Point(150, 14); + WorkersListBox.Margin = new Padding(3, 2, 3, 2); + WorkersListBox.Name = "WorkersListBox"; + WorkersListBox.Size = new Size(434, 124); + WorkersListBox.TabIndex = 7; + // + // StatisticsListBox + // + StatisticsListBox.FormattingEnabled = true; + StatisticsListBox.ItemHeight = 15; + StatisticsListBox.Location = new Point(33, 292); + StatisticsListBox.Margin = new Padding(3, 2, 3, 2); + StatisticsListBox.Name = "StatisticsListBox"; + StatisticsListBox.Size = new Size(322, 124); + StatisticsListBox.TabIndex = 8; + // + // Form1 + // + AutoScaleDimensions = new SizeF(7F, 15F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(952, 429); + Controls.Add(StatisticsListBox); + Controls.Add(WorkersListBox); + Controls.Add(HighestWageButton); + Controls.Add(SectionTextBox); + Controls.Add(SixthTaskLabel); + Controls.Add(label4); + Controls.Add(label3); + Controls.Add(AverageWageLabel); + Controls.Add(WorkersLabel); + Margin = new Padding(3, 2, 3, 2); + Name = "Form1"; + Text = "Kérem a részleg nevét:"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label WorkersLabel; + private Label AverageWageLabel; + private Label label3; + private Label label4; + private Label SixthTaskLabel; + private TextBox SectionTextBox; + private Button HighestWageButton; + private ListBox WorkersListBox; + private ListBox StatisticsListBox; + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.cs new file mode 100644 index 0000000..ffbe7c9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.cs @@ -0,0 +1,101 @@ +namespace _2024._09._05 +{ + public partial class Form1 : Form + { + List dataList = new List(); + public Form1() + { + InitializeComponent(); + + //2. feladat + StreamReader sr = new StreamReader("berek2020.txt"); + string[] line = sr.ReadLine().Split(";"); + + while (!sr.EndOfStream) + { + line = sr.ReadLine().Split(";"); + Dolgozok dolgozok = new Dolgozok(line[0], line[1], line[2], Convert.ToInt32(line[3]), Convert.ToInt32(line[4])); + dataList.Add(dolgozok); + } + + sr.Close(); + + foreach (var worker in dataList) + { + WorkersListBox.Items.Add($"{worker.Nev}\t{worker.Nem}\t{worker.Reszleg}\t{worker.Belepes}\t{worker.Ber}"); + } + + + //3. feladat + WorkersLabel.Text += $" {dataList.Count} f"; + + + //4. feladat + double wage = 0; + + foreach (var worker in dataList) + { + wage += worker.Ber; + } + + AverageWageLabel.Text += $"{Math.Round(wage / dataList.Count / 1000, 1)} eFt"; + + + //7. feladat + Dictionary statisztika = new Dictionary(); + foreach (var worker in dataList) + { + if (statisztika.ContainsKey(worker.Reszleg)) + { + statisztika[worker.Reszleg]++; + } + + else + { + statisztika[worker.Reszleg] = 1; + } + } + + foreach (var reszleg in statisztika) + { + StatisticsListBox.Items.Add($"{reszleg.Key} - {reszleg.Value} f"); + } + } + + private void HighestWageButton_Click(object sender, EventArgs e) + { + //6. feladat + int highestWage = 0; + foreach (var worker in dataList) + { + if (worker.Reszleg.Equals(SectionTextBox.Text)) + { + if (worker.Ber > highestWage) + { + highestWage = worker.Ber; + } + } + } + + if (highestWage > 0) + { + foreach (var worker in dataList) + { + if (worker.Ber == highestWage) + { + SixthTaskLabel.Text = $"6. Feladat: A legtbbet keres dolgoz a rszlegen\n" + + $"Nv: {worker.Nev}\n" + + $"Nem: {worker.Nem}\n" + + $"Belps: {worker.Belepes}\n" + + $"Br: {worker.Ber} Forint"; + } + } + } + + else + { + SixthTaskLabel.Text = $"6. Feladat: A megadott rszleg nem ltezik a cgnl!"; + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.resx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Program.cs new file mode 100644 index 0000000..adf5cb3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._09._05 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.deps.json new file mode 100644 index 0000000..e7948ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 09. 05/1.0.0": { + "runtime": { + "2024. 09. 05.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 05/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.dll new file mode 100644 index 0000000..383aa5a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.exe new file mode 100644 index 0000000..e41c993 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.pdb new file mode 100644 index 0000000..46429b7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.runtimeconfig.json new file mode 100644 index 0000000..f9988b2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/2024. 09. 05.runtimeconfig.json @@ -0,0 +1,15 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ] + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/berek2020.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/berek2020.txt new file mode 100644 index 0000000..cc63c35 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/bin/Debug/net6.0-windows/berek2020.txt @@ -0,0 +1,171 @@ +Név;Neme;Részleg;Belépés;Bér +Beri Dániel;férfi;beszerzés;1979;222943 +Csavar Pista;férfi;pénzügy;1995;234074 +Lakatos Pál;férfi;beszerzés;1986;159538 +Devon Mihály;férfi;asztalosműhely;2007;161533 +Él Ilona;nő;beszerzés;1982;299865 +Gábor Gizella;nő;értékesítés;2003;181108 +Kálvin Ödömér;férfi;lakatosműhely;1976;321959 +Kolompár Gáspár;férfi;asztalosműhely;2003;253794 +Sörös Sándor;férfi;lakatosműhely;2012;202216 +Léc Elek;férfi;asztalosműhely;2001;220506 +Vonal Deodát;férfi;beszerzés;1997;187753 +Sipos Gábor;férfi;karbantartás;1982;185714 +Szigeti Sándor;férfi;karbantartás;1971;315764 +Volga Olga;nő;szerelőműhely;2009;197090 +Körte Vilmos;férfi;szerelőműhely;2016;256051 +Nagy Zoltán;nő;személyzeti;1979;167928 +Sunyi Béla;férfi;karbantartás;2010;294523 +Tiszai József;férfi;szerelőműhely;2001;305412 +Fül Elek;férfi;értékesítés;2017;112590 +Puli Sándor;férfi;lakatosműhely;1984;122782 +Seres András;férfi;értékesítés;1985;214497 +Vígh József;férfi;pénzügy;1986;202335 +Alsófalvi Amália;nő;asztalosműhely;2017;130090 +Mayer Tamás;férfi;pénzügy;1998;169054 +Végh József;férfi;karbantartás;1999;187443 +Szokai Kinga;nő;értékesítés;2000;101498 +Kondor Katalin;nő;pénzügy;2013;287247 +Kovács János;férfi;beszerzés;1993;346023 +Fityeházi Ágoston;férfi;személyzeti;2017;306860 +Karap Béla;férfi;pénzügy;1974;191443 +Pán Péter;férfi;beszerzés;2017;189096 +Pintér Sándor;férfi;pénzügy;1977;212158 +Sarkadi Csaba;férfi;személyzeti;1992;275338 +Horváth Dezső;férfi;pénzügy;1991;338631 +Kónya Anett;nő;értékesítés;1992;186852 +Pataki Aladár;férfi;szerelőműhely;2003;241873 +William Clinton;férfi;karbantartás;2004;285206 +Céhes Eszter;nő;pénzügy;2012;296289 +Gaz Julianna;nő;értékesítés;2006;131620 +Tóth Imre;férfi;asztalosműhely;1988;285381 +Higli Jolán;nő;lakatosműhely;1987;170292 +Égerházi Zsanett;nő;asztalosműhely;1993;295283 +Lakodalom Lajos;férfi;szerelőműhely;1970;229541 +Nem Tamás;férfi;karbantartás;2016;220554 +Németh Noémi;nő;karbantartás;1983;282454 +Kiss Csilla;nő;beszerzés;2009;337231 +Lapos Elemér;férfi;lakatosműhely;1972;306860 +Szokai Barbara;nő;pénzügy;2013;184629 +Károly Zoltán;férfi;értékesítés;1984;139730 +Kozlovszky Jenő;férfi;asztalosműhely;2018;248206 +Kuti Kamilla;nő;karbantartás;1977;281336 +Présinger Tamás;férfi;beszerzés;2001;297147 +Szokai Kinga;nő;beszerzés;1979;295981 +Kovács Béla;férfi;szerelőműhely;2005;269895 +Rizi Gizi;nő;szerelőműhely;2016;343616 +Vagyok Ibolya;nő;karbantartás;2000;212096 +Dávid Ilona;nő;értékesítés;1970;115651 +Turpis Imre;férfi;szerelőműhely;1999;455582 +Világi Virág;nő;beszerzés;1999;347147 +Gerecsény Eszter;nő;szerelőműhely;1975;260777 +Győri Tímea;nő;szerelőműhely;2014;140646 +Kiss Ágnes;nő;lakatosműhely;1969;125803 +Kovács Helga;nő;pénzügy;1985;325358 +Morvay Levente;férfi;személyzeti;2011;476449 +Szűcs Gábor;férfi;személyzeti;1975;265928 +Varga Dóra;nő;karbantartás;2009;144949 +Zsák Judit;nő;pénzügy;2006;222083 +Nagy Kálmán;férfi;lakatosműhely;1979;279136 +Szalacsi Sándor;férfi;karbantartás;1977;184545 +Tavi József;férfi;szerelőműhely;1979;372182 +Torgyán Andrea;nő;pénzügy;2015;461167 +Bomberra Krisztina;nő;pénzügy;2018;232925 +Fehér Jakab;férfi;értékesítés;1973;241893 +Szabó Péter;férfi;pénzügy;2010;226231 +Torgyán Attila;férfi;szerelőműhely;1987;342561 +Kárai Kata;nő;pénzügy;1994;122245 +Kötö Irma;nő;lakatosműhely;1990;284049 +Nem János;férfi;pénzügy;1990;143081 +Presser Gábor;férfi;értékesítés;2016;173758 +Szép Kálmán;férfi;szerelőműhely;1986;170663 +Azér Lázár;férfi;lakatosműhely;1995;290729 +Faragó Viktor;férfi;szerelőműhely;1970;292099 +Kicsi Misi;férfi;szerelőműhely;1978;186715 +Németh Sára;nő;karbantartás;1985;253524 +Polgár Jenő;férfi;karbantartás;1987;264165 +Szabó Balázs;férfi;személyzeti;1983;351304 +Fritz Attila;férfi;pénzügy;1969;267901 +Kodály Zoltán;férfi;értékesítés;1975;482961 +Pastinszky Tamás;férfi;személyzeti;2006;325980 +Czeczei Zsolt;férfi;beszerzés;1981;452042 +Habos Helén;nő;szerelőműhely;2004;264754 +Hegedűs Ilona;nő;szerelőműhely;1981;198774 +Kecskés Mária;nő;szerelőműhely;1978;149959 +Kovács Beáta;nő;személyzeti;2013;386887 +Prezma Aurora;nő;pénzügy;1991;137207 +Sörös Leopold;férfi;lakatosműhely;1972;329999 +Bodor Enikő;nő;pénzügy;2012;274781 +Kolompár Frigyes;férfi;lakatosműhely;1978;343403 +Makrai Dezső;férfi;szerelőműhely;2016;218725 +Morvay Jenő;férfi;pénzügy;1972;297254 +Éliás Tóbiás;férfi;pénzügy;1998;303102 +Halász Júlia;nő;szerelőműhely;2003;122520 +Kiss Borbála;nő;lakatosműhely;1971;159775 +Czeczei Zsolt;férfi;pénzügy;2005;386026 +Szabó Attila;férfi;karbantartás;2006;211794 +Budai Antal;férfi;értékesítés;2017;144107 +Dávid Izaura;nő;személyzeti;1989;300039 +Horváth Kinga;nő;karbantartás;1969;184889 +Mekk Elek Tihamér;férfi;szerelőműhely;1988;268099 +Nájt Mihály;férfi;asztalosműhely;2004;344839 +Szabó Dénes;férfi;értékesítés;2004;269537 +Fritz Géza;férfi;beszerzés;2009;288983 +Gomb Sára;nő;pénzügy;1995;313310 +Méh Erika;nő;pénzügy;2011;246126 +Víz Gizella;nő;pénzügy;2012;104223 +Fogarasi Árpád;férfi;karbantartás;1996;307855 +Hűtő Béla;férfi;pénzügy;1988;426139 +Kiss Rozália;nő;szerelőműhely;1982;248843 +Kun Béla;férfi;karbantartás;1969;265384 +Lepési Mária;nő;lakatosműhely;2006;227066 +Mária Terézia;nő;pénzügy;1987;376465 +Balogh Éva;nő;értékesítés;1983;522899 +Kapros Lajos;férfi;szerelőműhely;2006;200943 +Nehéz Teréz;nő;szerelőműhely;1973;228999 +Bán Mihály;férfi;asztalosműhely;1983;191563 +Inger Rozália;nő;pénzügy;1989;344391 +Magyar Erzsébet;nő;személyzeti;1973;287814 +Nagy Gyula;férfi;lakatosműhely;1981;211530 +Szabó Éva;nő;karbantartás;2005;182674 +Takács Lilla;nő;pénzügy;2002;325866 +Czeczei András;férfi;pénzügy;2005;205444 +Gép Béla;férfi;pénzügy;1980;277660 +Gulág Tóbiás;férfi;beszerzés;2013;109873 +Medgyessi Pál;férfi;asztalosműhely;1999;282749 +Wesselényi Brúnó;férfi;beszerzés;1975;130108 +Alsófalvi Amália;nő;asztalosműhely;1998;343647 +Sarkadi Csaba;férfi;pénzügy;1976;230294 +Asztal Sándor;férfi;pénzügy;1970;231754 +Prézli János;férfi;pénzügy;2016;169183 +Brazil Béla;férfi;asztalosműhely;2001;299524 +Határ Hugó;férfi;szerelőműhely;1980;256155 +Varga Tamás;férfi;karbantartás;1988;213615 +Balogh Gábor;férfi;asztalosműhely;1988;193119 +Barna Ágota;nő;értékesítés;1985;252032 +Béna Béla;férfi;szerelőműhely;1972;186064 +Bödön Ödön;férfi;szerelőműhely;1993;166483 +Takács Nándor;férfi;beszerzés;2007;343382 +Vaal Máté;férfi;pénzügy;1969;220726 +Gold Mária;nő;asztalosműhely;1998;286186 +Lakatos Lujza;nő;asztalosműhely;2005;316271 +Ormosi Teréz;nő;asztalosműhely;1971;104671 +Sipos Károly;férfi;karbantartás;2002;278778 +Tóth Gyula;férfi;személyzeti;1981;261433 +Átlagos Ákos;férfi;szerelőműhely;1983;219531 +Fekete Frigyes;férfi;asztalosműhely;1997;130135 +Farkas Károly;férfi;lakatosműhely;1995;209343 +Nagy Antal;férfi;karbantartás;1986;309611 +Oláh Gáspár;férfi;karbantartás;1988;137158 +Öregh Amália;nő;személyzeti;2016;315782 +Somogyi Erika;nő;karbantartás;2016;193363 +Izmos Vilmos;férfi;szerelőműhely;2011;298796 +Kovács János;férfi;asztalosműhely;1986;212865 +Pokol Petúnia;nő;beszerzés;1973;256368 +Bak Dániel;férfi;pénzügy;1983;496106 +Fekete Andrea;nő;értékesítés;1989;124880 +Gáspár Olga;nő;karbantartás;2010;298381 +Ináncsi József;férfi;karbantartás;2001;199721 +Szabó András;férfi;beszerzés;2009;269287 +Erdős Árpád;férfi;szerelőműhely;2009;220353 +Kiss Jenő;férfi;karbantartás;1973;324666 \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json new file mode 100644 index 0000000..9ade65f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "projectName": "2024. 09. 05", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs new file mode 100644 index 0000000..a53f0ab --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache new file mode 100644 index 0000000..4a580de --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e37d6ebc7bba2acb34d6d151c81e51ae7478db6c diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5f69be7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._05 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache new file mode 100644 index 0000000..1009a04 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..000258c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +c06243c4f37cef546f7822ef1344299314756fd4 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..825d058 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.FileListAbsolute.txt @@ -0,0 +1,32 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\_2024._09._05.Form1.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.csproj.GenerateResource.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\refint\2024. 09. 05.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\ref\2024. 09. 05.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.exe +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.deps.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.runtimeconfig.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\bin\Debug\net6.0-windows\2024. 09. 05.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\_2024._09._05.Form1.resources +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.csproj.GenerateResource.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.AssemblyInfoInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.AssemblyInfo.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.csproj.CoreCompileInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\refint\2024. 09. 05.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\2024. 09. 05.genruntimeconfig.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 05\2024. 09. 05\obj\Debug\net6.0-windows\ref\2024. 09. 05.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.GenerateResource.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.GenerateResource.cache new file mode 100644 index 0000000..ebae87f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.csproj.GenerateResource.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.dll new file mode 100644 index 0000000..383aa5a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.genruntimeconfig.cache new file mode 100644 index 0000000..3027b94 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.genruntimeconfig.cache @@ -0,0 +1 @@ +b4a759604068983e56b7e3eeb32e78eb5c6a679b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.pdb new file mode 100644 index 0000000..46429b7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/_2024._09._05.Form1.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/_2024._09._05.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/_2024._09._05.Form1.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/apphost.exe new file mode 100644 index 0000000..e41c993 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/ref/2024. 09. 05.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/ref/2024. 09. 05.dll new file mode 100644 index 0000000..a159627 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/ref/2024. 09. 05.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/refint/2024. 09. 05.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/refint/2024. 09. 05.dll new file mode 100644 index 0000000..a159627 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/refint/2024. 09. 05.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.assets.json new file mode 100644 index 0000000..7e66a71 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "projectName": "2024. 09. 05", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache new file mode 100644 index 0000000..55c6268 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "nUtJbwPeAue6vz97SopVII5ixDvjQAIHurpGL3kjapTRB+JG9Qk8dqsCTzBjVtH7N3WhDQNmIcIA7EBcu8SScg==", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Házi\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/Programozás feladat GUI.pdf b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/Programozás feladat GUI.pdf new file mode 100644 index 0000000..c7cb86f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/2024. 09. 05/Programozás feladat GUI.pdf differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..4cedf65 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/70f136d0-db40-424d-a446-5e2472fcb6c2.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/70f136d0-db40-424d-a446-5e2472fcb6c2.vsidx new file mode 100644 index 0000000..b6b8fe0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/70f136d0-db40-424d-a446-5e2472fcb6c2.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/7642c2c6-b5c3-4f21-a511-6c8ce71434cd.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/7642c2c6-b5c3-4f21-a511-6c8ce71434cd.vsidx new file mode 100644 index 0000000..42e2465 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/7642c2c6-b5c3-4f21-a511-6c8ce71434cd.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/86f0565f-2774-461d-9deb-29175af99cd0.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/86f0565f-2774-461d-9deb-29175af99cd0.vsidx new file mode 100644 index 0000000..7882ce9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/86f0565f-2774-461d-9deb-29175af99cd0.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/f9ba0a45-dc62-4a25-8715-1610feb50577.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/f9ba0a45-dc62-4a25-8715-1610feb50577.vsidx new file mode 100644 index 0000000..4678af9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/FileContentIndex/f9ba0a45-dc62-4a25-8715-1610feb50577.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.futdcache.v2 new file mode 100644 index 0000000..0db347e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.suo new file mode 100644 index 0000000..aae39f9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..c11ebcf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.backup.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|c:\\users\\adamtoth\\source\\repos\\dolgozat_2024. 09. 12_gui\\dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|solutionrelative:dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|c:\\users\\adamtoth\\source\\repos\\dolgozat_2024. 09. 12_gui\\dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|solutionrelative:dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Form1.cs", + "DocumentMoniker": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeDocumentMoniker": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ToolTip": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeToolTip": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ViewState": "AgIAAB4AAAAAAAAAAIA3wC8AAABKAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-12T07:42:55.237Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Form1.cs [Design]", + "DocumentMoniker": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeDocumentMoniker": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ToolTip": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs [Design]", + "RelativeToolTip": "Dolgozat_2024. 09. 12_GUI\\Form1.cs [Design]", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-12T07:38:21.175Z", + "EditorCaption": " [Design]" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.json new file mode 100644 index 0000000..2180d18 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/Dolgozat_2024. 09. 12_GUI/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|c:\\users\\adamtoth\\source\\repos\\dolgozat_2024. 09. 12_gui\\dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|solutionrelative:dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|c:\\users\\adamtoth\\source\\repos\\dolgozat_2024. 09. 12_gui\\dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form", + "RelativeMoniker": "D:0:0:{2B055CA2-C1B3-4444-9040-0CFD576B938E}|Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj|solutionrelative:dolgozat_2024. 09. 12_gui\\form1.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}|Form" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Form1.cs", + "DocumentMoniker": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeDocumentMoniker": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ToolTip": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeToolTip": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ViewState": "AgIAAB4AAAAAAAAAAIA3wCwAAAAJAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-12T07:42:55.237Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Form1.cs [Design]", + "DocumentMoniker": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "RelativeDocumentMoniker": "Dolgozat_2024. 09. 12_GUI\\Form1.cs", + "ToolTip": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Form1.cs [Design]", + "RelativeToolTip": "Dolgozat_2024. 09. 12_GUI\\Form1.cs [Design]", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-12T07:38:21.175Z", + "EditorCaption": " [Design]" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.metadata.v9.bin new file mode 100644 index 0000000..2086576 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.projects.v9.bin new file mode 100644 index 0000000..ad23047 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.strings.v9.bin new file mode 100644 index 0000000..1ec00c7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/.vs/ProjectEvaluation/dolgozat_2024. 09. 12_gui.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.sln new file mode 100644 index 0000000..a144668 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35222.181 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Dolgozat_2024. 09. 12_GUI", "Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI.csproj", "{2B055CA2-C1B3-4444-9040-0CFD576B938E}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {2B055CA2-C1B3-4444-9040-0CFD576B938E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {2B055CA2-C1B3-4444-9040-0CFD576B938E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {2B055CA2-C1B3-4444-9040-0CFD576B938E}.Release|Any CPU.ActiveCfg = Release|Any CPU + {2B055CA2-C1B3-4444-9040-0CFD576B938E}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {1B6C41F8-437A-43B2-A765-D340BB5FCC23} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj new file mode 100644 index 0000000..67b79f1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + Dolgozat_2024._09._12_GUI + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Eredmeny.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Eredmeny.cs new file mode 100644 index 0000000..32d18bd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Eredmeny.cs @@ -0,0 +1,25 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Xml.Linq; + +namespace Dolgozat_2024._09._12 +{ + class Eredmeny + { + public int Kor { get; set; } + public int Ido { get; set; } + public Futo Versenyzo { get; set; } + List futok = new List(); + + + public Eredmeny(int kor, int ido, Futo versenyzo) + { + Kor = kor; + Ido = ido; + Versenyzo = versenyzo; + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.Designer.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.Designer.cs new file mode 100644 index 0000000..f739d63 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.Designer.cs @@ -0,0 +1,298 @@ +namespace Dolgozat_2024._09._12_GUI +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + menuStrip1 = new MenuStrip(); + fájlToolStripMenuItem = new ToolStripMenuItem(); + megnyitásToolStripMenuItem = new ToolStripMenuItem(); + kilépésToolStripMenuItem = new ToolStripMenuItem(); + label1 = new Label(); + listBox1 = new ListBox(); + label2 = new Label(); + groupBox1 = new GroupBox(); + textBox6 = new TextBox(); + textBox5 = new TextBox(); + textBox4 = new TextBox(); + textBox3 = new TextBox(); + textBox2 = new TextBox(); + textBox1 = new TextBox(); + label8 = new Label(); + label7 = new Label(); + label6 = new Label(); + label5 = new Label(); + label4 = new Label(); + label3 = new Label(); + button1 = new Button(); + listBox2 = new ListBox(); + menuStrip1.SuspendLayout(); + groupBox1.SuspendLayout(); + SuspendLayout(); + // + // menuStrip1 + // + menuStrip1.Items.AddRange(new ToolStripItem[] { fájlToolStripMenuItem }); + menuStrip1.Location = new Point(0, 0); + menuStrip1.Name = "menuStrip1"; + menuStrip1.Size = new Size(878, 24); + menuStrip1.TabIndex = 0; + menuStrip1.Text = "menuStrip1"; + // + // fájlToolStripMenuItem + // + fájlToolStripMenuItem.DropDownItems.AddRange(new ToolStripItem[] { megnyitásToolStripMenuItem, kilépésToolStripMenuItem }); + fájlToolStripMenuItem.Name = "fájlToolStripMenuItem"; + fájlToolStripMenuItem.Size = new Size(37, 20); + fájlToolStripMenuItem.Text = "Fájl"; + // + // megnyitásToolStripMenuItem + // + megnyitásToolStripMenuItem.Name = "megnyitásToolStripMenuItem"; + megnyitásToolStripMenuItem.Size = new Size(180, 22); + megnyitásToolStripMenuItem.Text = "Megnyitás"; + // + // kilépésToolStripMenuItem + // + kilépésToolStripMenuItem.Name = "kilépésToolStripMenuItem"; + kilépésToolStripMenuItem.Size = new Size(180, 22); + kilépésToolStripMenuItem.Text = "Kilépés"; + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI", 20.25F, FontStyle.Bold, GraphicsUnit.Point, 238); + label1.ForeColor = SystemColors.HotTrack; + label1.Location = new Point(243, 61); + label1.Name = "label1"; + label1.Size = new Size(338, 37); + label1.TabIndex = 1; + label1.Text = "Maratonváltó versenyzői"; + // + // listBox1 + // + listBox1.FormattingEnabled = true; + listBox1.ItemHeight = 15; + listBox1.Location = new Point(78, 158); + listBox1.Name = "listBox1"; + listBox1.Size = new Size(247, 364); + listBox1.TabIndex = 2; + listBox1.SelectedIndexChanged += listBox1_SelectedIndexChanged; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(78, 140); + label2.Name = "label2"; + label2.Size = new Size(70, 15); + label2.TabIndex = 3; + label2.Text = "Futók listája"; + // + // groupBox1 + // + groupBox1.Controls.Add(textBox6); + groupBox1.Controls.Add(textBox5); + groupBox1.Controls.Add(textBox4); + groupBox1.Controls.Add(textBox3); + groupBox1.Controls.Add(textBox2); + groupBox1.Controls.Add(textBox1); + groupBox1.Controls.Add(label8); + groupBox1.Controls.Add(label7); + groupBox1.Controls.Add(label6); + groupBox1.Controls.Add(label5); + groupBox1.Controls.Add(label4); + groupBox1.Controls.Add(label3); + groupBox1.Location = new Point(515, 158); + groupBox1.Name = "groupBox1"; + groupBox1.Size = new Size(303, 204); + groupBox1.TabIndex = 4; + groupBox1.TabStop = false; + groupBox1.Text = "Kiválasztott futó adatai"; + // + // textBox6 + // + textBox6.Location = new Point(185, 168); + textBox6.Name = "textBox6"; + textBox6.Size = new Size(102, 23); + textBox6.TabIndex = 11; + // + // textBox5 + // + textBox5.Location = new Point(185, 139); + textBox5.Name = "textBox5"; + textBox5.Size = new Size(102, 23); + textBox5.TabIndex = 10; + // + // textBox4 + // + textBox4.Location = new Point(185, 110); + textBox4.Name = "textBox4"; + textBox4.Size = new Size(102, 23); + textBox4.TabIndex = 9; + // + // textBox3 + // + textBox3.Location = new Point(185, 82); + textBox3.Name = "textBox3"; + textBox3.Size = new Size(102, 23); + textBox3.TabIndex = 8; + // + // textBox2 + // + textBox2.Location = new Point(185, 55); + textBox2.Name = "textBox2"; + textBox2.Size = new Size(102, 23); + textBox2.TabIndex = 7; + // + // textBox1 + // + textBox1.Location = new Point(61, 28); + textBox1.Name = "textBox1"; + textBox1.Size = new Size(226, 23); + textBox1.TabIndex = 6; + // + // label8 + // + label8.AutoSize = true; + label8.Location = new Point(6, 172); + label8.Name = "label8"; + label8.Size = new Size(74, 15); + label8.TabIndex = 5; + label8.Text = "Köridő (mp):"; + // + // label7 + // + label7.AutoSize = true; + label7.Location = new Point(6, 142); + label7.Name = "label7"; + label7.Size = new Size(133, 15); + label7.TabIndex = 4; + label7.Text = "Hányadik körben futott:"; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(6, 113); + label6.Name = "label6"; + label6.Size = new Size(82, 15); + label6.TabIndex = 3; + label6.Text = "Csapat száma:"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(6, 85); + label5.Name = "label5"; + label5.Size = new Size(153, 15); + label5.TabIndex = 2; + label5.Text = "Születési év és hó (éééé.hh):"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(6, 58); + label4.Name = "label4"; + label4.Size = new Size(63, 15); + label4.TabIndex = 1; + label4.Text = "Rajtszáma:"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(6, 31); + label3.Name = "label3"; + label3.Size = new Size(31, 15); + label3.TabIndex = 0; + label3.Text = "Név:"; + // + // button1 + // + button1.Location = new Point(576, 368); + button1.Name = "button1"; + button1.Size = new Size(203, 23); + button1.TabIndex = 5; + button1.Text = "Csapattársak"; + button1.UseVisualStyleBackColor = true; + button1.Click += button1_Click; + // + // listBox2 + // + listBox2.FormattingEnabled = true; + listBox2.ItemHeight = 15; + listBox2.Location = new Point(515, 397); + listBox2.Name = "listBox2"; + listBox2.Size = new Size(303, 109); + listBox2.TabIndex = 6; + // + // Form1 + // + AutoScaleDimensions = new SizeF(7F, 15F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(878, 617); + Controls.Add(listBox2); + Controls.Add(button1); + Controls.Add(groupBox1); + Controls.Add(label2); + Controls.Add(listBox1); + Controls.Add(label1); + Controls.Add(menuStrip1); + Name = "Form1"; + Text = "Form1"; + menuStrip1.ResumeLayout(false); + menuStrip1.PerformLayout(); + groupBox1.ResumeLayout(false); + groupBox1.PerformLayout(); + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private MenuStrip menuStrip1; + private ToolStripMenuItem fájlToolStripMenuItem; + private ToolStripMenuItem megnyitásToolStripMenuItem; + private ToolStripMenuItem kilépésToolStripMenuItem; + private Label label1; + private ListBox listBox1; + private Label label2; + private GroupBox groupBox1; + private Label label5; + private Label label4; + private Label label3; + private Label label7; + private Label label6; + private Label label8; + private TextBox textBox5; + private TextBox textBox4; + private TextBox textBox3; + private TextBox textBox2; + private TextBox textBox1; + private TextBox textBox6; + private Button button1; + private ListBox listBox2; + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.cs new file mode 100644 index 0000000..07cfa93 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.cs @@ -0,0 +1,55 @@ +using Dolgozat_2024._09._12; + +namespace Dolgozat_2024._09._12_GUI +{ + public partial class Form1 : Form + { + List futok = new List(); + public Form1() + { + InitializeComponent(); + StreamReader sr = new StreamReader("maratonvalto.csv"); + string[] line = sr.ReadLine().Split(";"); + + while (!sr.EndOfStream) + { + line = sr.ReadLine().Split(";"); + Futo futo = new Futo(Convert.ToInt32(line[0]), line[1], Convert.ToInt32(line[2]), Convert.ToInt32(line[3]), Convert.ToInt32(line[4]), Convert.ToInt32(line[5])); + Eredmeny eredmeny = new Eredmeny(Convert.ToInt32(line[6]), Convert.ToInt32(line[7]), futo); + futok.Add(eredmeny); + listBox1.Items.Add(line[1]); + } + + sr.Close(); + + + } + + private void listBox1_SelectedIndexChanged(object sender, EventArgs e) + { + foreach (var futo in futok) + { + if (listBox1.SelectedItem.ToString().Equals(futo.Versenyzo.Fnev)) + { + textBox1.Text = futo.Versenyzo.Fnev; + textBox2.Text = futo.Versenyzo.Fid.ToString(); + textBox3.Text = $"{futo.Versenyzo.Szulev}-{futo.Versenyzo.Szulho}"; + textBox4.Text = futo.Versenyzo.Csapat.ToString(); + textBox5.Text = futo.Kor.ToString(); + textBox6.Text = futo.Ido.ToString(); + } + } + } + + private void button1_Click(object sender, EventArgs e) + { + foreach (var futo in futok) + { + if (futo.Versenyzo.Csapat == int.Parse(textBox4.Text) && !futo.Versenyzo.Fnev.Equals(textBox1.Text)) + { + listBox2.Items.Add(futo.Versenyzo.Fnev); + } + } + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.resx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.resx new file mode 100644 index 0000000..b48baf1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Form1.resx @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + 17, 17 + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Futo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Futo.cs new file mode 100644 index 0000000..56b7961 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Futo.cs @@ -0,0 +1,29 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace Dolgozat_2024._09._12 +{ + class Futo + { + public int Fid { get; set; } + public string Fnev { get; set; } + public int Szulev { get; set; } + public int Szulho { get; set; } + public int Csapat { get; set; } + public int Ffi { get; set; } + + + public Futo(int fid, string fnev, int szulev, int szulho, int csapat, int ffi) + { + Fid = fid; + Fnev = fnev; + Szulev = szulev; + Szulho = szulho; + Csapat = csapat; + Ffi = ffi; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Program.cs new file mode 100644 index 0000000..1f02a5b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/Program.cs @@ -0,0 +1,17 @@ +namespace Dolgozat_2024._09._12_GUI +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.deps.json new file mode 100644 index 0000000..c5ce472 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "Dolgozat_2024. 09. 12_GUI/1.0.0": { + "runtime": { + "Dolgozat_2024. 09. 12_GUI.dll": {} + } + } + } + }, + "libraries": { + "Dolgozat_2024. 09. 12_GUI/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll new file mode 100644 index 0000000..479d3cb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.exe new file mode 100644 index 0000000..e64b4a4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb new file mode 100644 index 0000000..95db446 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/maratonvalto.csv b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/maratonvalto.csv new file mode 100644 index 0000000..94ac665 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/bin/Debug/net8.0-windows/maratonvalto.csv @@ -0,0 +1,313 @@ +fid;fnev;szulev;szulho;csapat;ffi;kor;ido +1131;Fazekas Györgyi;1969;8;113;0;1;2073 +1321;Lukács Benjámin;1976;6;132;1;1;2013 +1311;Fodor Gizella;1985;12;131;0;1;2217 +1101;Vincze Tímea;1996;7;110;0;1;1911 +1151;Faragó Balázs;1968;11;115;1;1;2942 +1341;Pintér Olga;1986;4;134;0;1;2873 +1111;Horváth Ferenc;1985;3;111;1;1;2631 +1021;Szalai Szilvia;1971;7;102;0;1;2795 +1401;Sándor Alex;1981;3;140;1;1;2690 +1371;Magyar Benjámin;1986;3;137;1;1;2041 +1121;Varga Károly;1986;6;112;1;1;3043 +1421;Kocsis Benjamin;1972;12;142;1;1;2993 +1051;Orsós Brigitta;1993;7;105;0;1;2527 +1281;Pintér Lóránt;1990;9;128;1;1;2114 +1461;Bodnár Petra;1984;11;146;0;1;2341 +1191;Faragó Virág;1970;6;119;0;1;2318 +1141;Király Richárd;1973;1;114;1;1;1703 +1291;Dobos Luca;1966;9;129;0;1;3041 +1201;Váradi Benedek;1982;1;120;1;1;2429 +1351;Gáspár Klaudia;1982;9;135;0;1;2761 +1491;Nemes Dominik;1989;9;149;1;1;2877 +1481;Nemes Gyula;1990;4;148;1;1;1814 +1301;Fodor Renátó;1969;5;130;1;1;2888 +1061;Kerekes Zalán;1992;10;106;1;1;2412 +1411;Székely Rozália;1969;11;141;0;1;2144 +1361;Szalai Ágnes;1968;5;136;0;1;2768 +1171;Végh Mónika;1992;4;117;0;1;1881 +1271;Pásztor Barnabás;1993;4;127;1;1;2408 +1261;Oláh Mátyás;1992;8;126;1;1;2622 +1211;Veres Richárd;1975;11;121;1;1;2992 +1031;Végh Marcell;1998;3;103;1;1;2140 +1181;Borbély Klára;1991;2;118;0;1;2303 +1471;Gulyás Richárd;1999;12;147;1;1;2429 +1241;Péter Szabolcs;1989;5;124;1;1;1913 +1431;Orsós Albert;1977;11;143;1;1;2559 +1251;Simon Róza;1982;11;125;0;1;1985 +1511;Faragó Lilla;1989;4;151;0;1;2951 +1441;Orosz Andrea;1973;11;144;0;1;2209 +1451;Gál Veronika;1974;10;145;0;1;1988 +1221;Illés Csongor;1978;11;122;1;1;2931 +1011;Balla Anikó;1988;1;101;0;1;2267 +1161;Soós Csaba;1972;5;116;1;1;2563 +1081;Gulyás Lili;1998;12;108;0;1;1728 +1331;Sipos Géza;1998;6;133;1;1;2062 +1501;Balogh Győző;1979;5;150;1;1;2577 +1381;Dobos Virág;1973;8;138;0;1;2126 +1071;Balogh Richárd;1974;5;107;1;1;2213 +1091;Hegedűs Beáta;1968;7;109;0;1;2007 +1231;Magyar Mihály;1976;6;123;1;1;2531 +1001;Kelemen Dezső;1977;7;100;1;1;2720 +1041;Bálint Eszter;1970;11;104;0;1;2312 +1391;Biró Csilla;1997;3;139;0;1;2854 +1422;Dobos Martin;1973;4;142;1;2;2201 +1072;Horváth Dénes;1977;6;107;1;2;2129 +1122;Vincze Róbert;1973;9;112;1;2;2993 +1092;Péter Elek;1990;4;109;1;2;2721 +1452;Szőke Dorina;1999;2;145;0;2;2315 +1312;Sipos Szabolcs;1992;11;131;1;2;2128 +1112;Bogdán Katalin;1983;10;111;0;2;1740 +1352;Kocsis Marcell;1993;4;135;1;2;2896 +1192;Szilágyi Anikó;1975;1;119;0;2;2884 +1182;Szűcs Klára;1999;9;118;0;2;2545 +1412;Kovács Vivien;1986;1;141;0;2;2556 +1222;Szalai Renáta;1968;6;122;0;2;2890 +1512;Somogyi Marcell;1996;7;151;1;2;1999 +1282;Borbély Brigitta;1974;1;128;0;2;1880 +1492;Gulyás Aranka;1967;5;149;0;2;2396 +1162;László Bertalan;1970;2;116;1;2;2379 +1032;Hegedűs Dorina;1992;4;103;0;2;2914 +1372;Pásztor Györgyi;1975;5;137;0;2;2059 +1102;Halász Dorina;1990;4;110;0;2;2614 +1402;Balogh Brigitta;1984;10;140;0;2;2197 +1442;Oláh Marcell;1985;10;144;1;2;2011 +1302;Mészáros Gergely;1980;3;130;1;2;1984 +1002;Váradi Mariann;1992;2;100;0;2;1708 +1242;Kovács Ervin;1982;5;124;1;2;2262 +1392;Gulyás Ervin;1979;1;139;1;2;2391 +1132;Barta Lóránt;1970;8;113;1;2;2914 +1172;Lukács Zita;1994;9;117;0;2;2351 +1362;Oláh Ida;1997;9;136;0;2;2809 +1472;Szilágyi János;1996;5;147;1;2;2408 +1432;Molnár Szabolcs;1985;9;143;1;2;1898 +1332;Kocsis Tibor;1974;1;133;1;2;2883 +1022;Németh Klára;1997;1;102;0;2;2733 +1322;Szőke Szabolcs;1966;8;132;1;2;2045 +1292;Vass Mátyás;1983;6;129;1;2;3003 +1502;Tamás Klaudia;1990;1;150;0;2;2262 +1342;Faragó Jolán;1982;9;134;0;2;1888 +1042;Fazekas Gizella;1991;2;104;0;2;2240 +1252;Nemes Mária;1987;7;125;0;2;2876 +1382;Balázs Pál;1980;8;138;1;2;2614 +1212;Gáspár Péter;1985;2;121;1;2;2487 +1082;Veres Kitti;1972;12;108;0;2;2277 +1232;Halász József;1971;12;123;1;2;2149 +1012;Molnár Rudolf;1980;5;101;1;2;2227 +1062;Antal Gergő;1997;5;106;1;2;2905 +1202;Tamás János;1984;8;120;1;2;3066 +1142;Veres Olga;1987;3;114;0;2;2618 +1152;Varga Márta;1972;3;115;0;2;1744 +1262;Gál Viktória;1969;1;126;0;2;1934 +1052;Major Róbert;1971;1;105;1;2;2458 +1272;Veres Petra;1990;9;127;0;2;2680 +1482;Puskás János;1986;11;148;1;2;2796 +1462;Takács Réka;1984;10;146;0;2;1883 +1383;Tamás Gergő;1976;8;138;1;3;2114 +1063;Sipos Benjámin;1970;9;106;1;3;3084 +1363;Barta Júlia;1989;8;136;0;3;3068 +1173;Kocsis György;1998;6;117;1;3;2181 +1293;Fodor Alex;1992;2;129;1;3;1750 +1433;Somogyi Márk;1969;6;143;1;3;2871 +1423;Nemes József;1972;8;142;1;3;2535 +1353;Orbán Gergő;1995;9;135;1;3;1825 +1473;Orosz Ildikó;1978;9;147;0;3;2202 +1513;Faragó Dávid;1973;10;151;1;3;2312 +1133;Lengyel Tivadar;1976;2;113;1;3;2718 +1013;Magyar Szabolcs;1998;9;101;1;3;2031 +1143;Fazekas Réka;1976;6;114;0;3;2533 +1273;Nagy Mariann;1977;3;127;0;3;2200 +1463;Novák Júlia;1992;10;146;0;3;1717 +1113;Halász Marcell;1967;8;111;1;3;2416 +1393;Sándor Lili;1973;9;139;0;3;2965 +1253;Biró Zsigmond;1988;12;125;1;3;2850 +1233;Szilágyi Emese;1967;6;123;0;3;2117 +1313;Gál Terézia;1985;7;131;0;3;2774 +1283;Deák Gizella;1991;8;128;0;3;2467 +1303;Nemes Anikó;1972;11;130;0;3;1854 +1483;Major Virág;1970;1;148;0;3;2113 +1333;Varga Ervin;1994;12;133;1;3;1765 +1453;Sándor Terézia;1974;3;145;0;3;2426 +1443;Bodnár Beatrix;1989;10;144;0;3;2145 +1103;Budai Klára;1995;11;110;0;3;1710 +1183;Fehér Csongor;1978;7;118;1;3;2118 +1053;Király Tibor;1974;12;105;1;3;2418 +1243;Szalai Renátó;1977;5;124;1;3;2709 +1403;Vincze Szilvia;1971;10;140;0;3;2182 +1043;Kovács Bence;1984;1;104;1;3;1702 +1023;Szilágyi Roland;1989;1;102;1;3;2035 +1373;Szücs Richárd;1993;3;137;1;3;2977 +1193;Pataki Kevin;1992;4;119;1;3;2304 +1163;Antal Erika;1985;4;116;0;3;1985 +1493;Vincze Beáta;1995;6;149;0;3;2187 +1503;Katona Barbara;1993;10;150;0;3;2118 +1413;Kozma Richárd;1989;1;141;1;3;2807 +1093;Király Anita;1998;11;109;0;3;2784 +1263;Vincze Barnabás;1977;12;126;1;3;2688 +1323;Péter Tünde;1975;7;132;0;3;2061 +1213;Papp Bernadett;1998;3;121;0;3;1985 +1033;Szekeres Hajnalka;1976;11;103;0;3;2028 +1223;Varga Ilona;1989;5;122;0;3;2052 +1123;Horváth Alex;1984;1;112;1;3;2371 +1343;Veres János;1992;5;134;1;3;2614 +1153;Gáspár Barnabás;1982;1;115;1;3;2998 +1203;Pintér Zsófia;1991;6;120;0;3;1797 +1083;Balog Attila;1988;11;108;1;3;2991 +1003;László Szilvia;1990;8;100;0;3;2168 +1073;Takács Gergely;1977;1;107;1;3;2804 +1374;Varga Henrik;1995;5;137;1;4;1845 +1144;Fehér Karolina;1981;4;114;0;4;2763 +1034;Novák Kitti;1996;1;103;0;4;2036 +1274;Kelemen Dorina;1975;2;127;0;4;1942 +1054;Tamás Máté;1973;8;105;1;4;2007 +1214;Juhász Balázs;1972;4;121;1;4;2149 +1444;Pintér Beáta;1981;7;144;0;4;2838 +1364;Orsós Mihály;1983;2;136;1;4;2061 +1304;Major Zoltán;1993;9;130;1;4;2997 +1434;Kocsis Márta;1992;6;143;0;4;1993 +1284;Pap Lajos;1970;1;128;1;4;2853 +1084;Vincze Zsolt;1969;12;108;1;4;2735 +1074;Sipos Fanni;1967;6;107;0;4;2794 +1404;Rácz Júlia;1991;5;140;0;4;2885 +1064;Simon Brigitta;1971;10;106;0;4;2783 +1464;Kocsis Dániel;1966;3;146;1;4;2235 +1504;Németh János;1966;12;150;1;4;1824 +1324;Pap Enikő;1966;5;132;0;4;2951 +1244;Sándor Zsombor;1992;3;124;1;4;2025 +1484;Puskás Júlia;1978;11;148;0;4;2358 +1334;Szekeres Csongor;1991;6;133;1;4;2188 +1224;Papp András;1974;2;122;1;4;2622 +1154;Vörös Ábel;1986;7;115;1;4;2599 +1131;Fazekas Györgyi;1969;8;113;0;4;1949 +1124;Váradi Andor;1976;5;112;1;4;2344 +1194;Pásztor Lili;1969;7;119;0;4;2853 +1454;Németh Henrik;1997;6;145;1;4;2253 +1294;Pál Rita;1976;1;129;0;4;2637 +1094;Vincze Jolán;1989;9;109;0;4;2971 +1174;Vincze Nándor;1971;12;117;1;4;2141 +1004;Bognár Sándor;1969;6;100;1;4;2671 +1414;Oláh Júlia;1992;8;141;0;4;2968 +1264;Budai Dorina;1996;2;126;0;4;1805 +1424;Kiss Anikó;1981;7;142;0;4;3015 +1104;Pataki Zoltán;1970;7;110;1;4;1936 +1204;László Csilla;1980;5;120;0;4;2895 +1044;Tóth Antal;1968;6;104;1;4;2304 +1314;Török Kornél;1988;4;131;1;4;2938 +1014;Bodnár Renáta;1985;5;101;0;4;2396 +1514;Antal Klaudia;1980;3;151;0;4;2914 +1344;Novák Henrik;1995;9;134;1;4;2296 +1491;Nemes Dominik;1989;9;149;1;4;1882 +1384;Kovács Györgyi;1978;8;138;0;4;1763 +1164;Sipos Zita;1972;4;116;0;4;1737 +1024;Szalai Fanni;1967;12;102;0;4;2496 +1354;Török Renáta;1985;4;135;0;4;2362 +1394;Csonka András;1978;4;139;1;4;1795 +1234;Hegedüs Anikó;1997;2;123;0;4;2604 +1184;Farkas Henrik;1996;11;118;1;4;2148 +1254;Végh Renáta;1986;11;125;0;4;1852 +1114;László Róza;1972;4;111;0;4;2253 +1474;Mészáros Éva;1994;5;147;0;4;2096 +1171;Végh Mónika;1992;4;117;0;5;2538 +1295;Kelemen Béla;1984;11;129;1;5;1943 +1395;Bodnár Ildikó;1981;11;139;0;5;1869 +1235;Deák Csilla;1975;8;123;0;5;2315 +1075;Deák Luca;1977;9;107;0;5;2848 +1215;Varga Klára;1984;2;121;0;5;2451 +1515;Pál Dezső;1973;5;151;1;5;2904 +1505;Gál Renáta;1997;9;150;0;5;2450 +1375;Nagy Renáta;1993;7;137;0;5;2851 +1435;Deák Edit;1994;12;143;0;5;2000 +1385;Pataki Emil;1987;9;138;1;5;2349 +1415;Balázs Barna;1967;7;141;1;5;2795 +1185;Fodor Dénes;1977;10;118;1;5;2535 +1325;Budai Tibor;1996;8;132;1;5;2820 +1365;Soós Réka;1973;11;136;0;5;2101 +1195;Hajdu Julianna;1992;3;119;0;5;2064 +1105;Major Erika;1979;11;110;0;5;1771 +1065;Fazekas Csilla;1998;5;106;0;5;2211 +1475;Vincze Pál;1984;6;147;1;5;1847 +1265;Magyar Lilla;1971;1;126;0;5;2697 +1165;Veres Gergő;1992;2;116;1;5;2898 +1025;Király Zsombor;1997;1;102;1;5;1714 +1005;Rácz Melinda;1976;1;100;0;5;2081 +1045;Váradi József;1999;7;104;1;5;1883 +1345;Pál Olga;1987;7;134;0;5;3056 +1155;Király Zita;1981;3;115;0;5;2688 +1225;Sipos Martin;1999;5;122;1;5;2920 +1052;Major Róbert;1971;1;105;1;5;3005 +1285;Fazekas Arnold;1995;3;128;1;5;2953 +1255;Varga Klaudia;1984;12;125;0;5;2109 +1305;Dudás Dezső;1974;1;130;1;5;1940 +1275;Rácz Olga;1968;11;127;0;5;2592 +1492;Gulyás Aranka;1967;5;149;0;5;2915 +1335;Váradi Vilmos;1974;1;133;1;5;2640 +1465;Barta Olga;1984;7;146;0;5;2696 +1125;Fekete Mariann;1984;2;112;0;5;2114 +1355;Major Evelin;1993;6;135;0;5;3060 +1445;Takács Ervin;1982;3;144;1;5;1776 +1015;Csonka Júlia;1981;9;101;0;5;2720 +1035;Deák Ákos;1985;7;103;1;5;2025 +1315;Végh Lóránt;1974;3;131;1;5;2704 +1205;Szücs Ágnes;1979;4;120;0;5;2574 +1425;Mészáros Balázs;1995;6;142;1;5;2028 +1115;Fehér Milán;1984;2;111;1;5;2087 +1085;Balogh György;1973;9;108;1;5;2240 +1145;Bogdán Kitti;1966;1;114;0;5;1747 +1405;Szabó Martin;1981;10;140;1;5;2410 +1485;Székely Dorina;1986;8;148;0;5;2662 +1132;Barta Lóránt;1970;8;113;1;5;3057 +1455;Hegedüs Erika;1966;9;145;0;5;3069 +1095;Vincze Klára;1971;7;109;0;5;2933 +1245;Kelemen Alex;1987;4;124;1;5;2970 +1326;Katona Viktória;1968;6;132;0;6;2469 +1506;Pataki Roland;1996;2;150;1;6;2502 +1026;Szabó Marcell;1981;11;102;1;6;2328 +1376;Fodor Szilvia;1985;8;137;0;6;2705 +1256;Péter Zsuzsanna;1981;4;125;0;6;2723 +1094;Vincze Jolán;1989;9;109;0;6;1795 +1493;Vincze Beáta;1995;6;149;0;6;2375 +1086;Gáspár Balázs;1986;9;108;1;6;2623 +1196;Lakatos Norbert;1981;4;119;1;6;1854 +1016;Bakos Györgyi;1969;8;101;0;6;2113 +1106;Boros György;1989;5;110;1;6;1898 +1516;Szekeres Szilvia;1991;4;151;0;6;2233 +1392;Gulyás Ervin;1979;1;139;1;6;2125 +1216;Fodor Patrik;1987;5;121;1;6;1715 +1146;Csonka Mariann;1995;2;114;0;6;1758 +1336;Farkas Piroska;1968;12;133;0;6;2737 +1243;Szalai Renátó;1977;5;124;1;6;2699 +1423;Nemes József;1972;8;142;1;6;3037 +1133;Lengyel Tivadar;1976;2;113;1;6;1784 +1386;Antal Balázs;1993;9;138;1;6;2633 +1151;Faragó Balázs;1968;11;115;1;6;2980 +1174;Vincze Nándor;1971;12;117;1;6;1761 +1222;Szalai Renáta;1968;6;122;0;6;2118 +1236;Varga Júlia;1971;3;123;0;6;1865 +1456;Jakab Zsigmond;1978;1;145;1;6;2565 +1046;Csonka János;1976;10;104;1;6;2392 +1436;Vörös Csongor;1971;8;143;1;6;3008 +1003;László Szilvia;1990;8;100;0;6;2325 +1166;Molnár Olivér;1969;6;116;1;6;2442 +1066;Szilágyi András;1988;11;106;1;6;2756 +1266;Simon Renáta;1987;4;126;0;6;2765 +1036;Deák Szabolcs;1993;11;103;1;6;3022 +1296;Barna Irma;1987;2;129;0;6;2640 +1466;Balla Milán;1983;5;146;1;6;1839 +1276;Somogyi Szilvia;1972;3;127;0;6;2024 +1316;Váradi Kitti;1986;6;131;0;6;2691 +1486;Szőke Dániel;1996;11;148;1;6;1895 +1286;Pál Arnold;1971;4;128;1;6;2177 +1406;Borbély Ildikó;1980;1;140;0;6;2343 +1306;Barta Brigitta;1992;2;130;0;6;1922 +1476;Vass Martin;1966;11;147;1;6;3005 +1446;Horváth Júlia;1976;4;144;0;6;3095 +1182;Szűcs Klára;1999;9;118;0;6;2528 +1203;Pintér Zsófia;1991;6;120;0;6;2713 +1416;Jónás János;1979;12;141;1;6;1871 +1126;Budai Nikoletta;1990;1;112;0;6;1815 +1116;Deák Ágnes;1997;3;111;0;6;3047 +1346;Szücs János;1989;9;134;1;6;2779 +1051;Orsós Brigitta;1993;7;105;0;6;3060 +1076;Péter Brigitta;1973;6;107;0;6;2961 +1366;Balog Beáta;1979;10;136;0;6;3017 +1352;Kocsis Marcell;1993;4;135;1;6;2588 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfo.cs new file mode 100644 index 0000000..aae358b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("Dolgozat_2024. 09. 12_GUI")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("Dolgozat_2024. 09. 12_GUI")] +[assembly: System.Reflection.AssemblyTitleAttribute("Dolgozat_2024. 09. 12_GUI")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfoInputs.cache new file mode 100644 index 0000000..8930811 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +15c88363a0d63a26bf0f296e7ee5a00ef0eaa4b8754886e974a5402504d6a33d diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..adc59ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,19 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = Dolgozat_2024._09._12_GUI +build_property.ProjectDir = C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.assets.cache new file mode 100644 index 0000000..6abe03f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..d0db690 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +06e5807ac27937ba0edb8f14632e5a2581ff4dfe423f511bc84826206da2f4fa diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..4c96bd8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.FileListAbsolute.txt @@ -0,0 +1,16 @@ +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\bin\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.exe +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\bin\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.deps.json +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\bin\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.runtimeconfig.json +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\bin\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.dll +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\bin\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.pdb +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024._09._12_GUI.Form1.resources +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.csproj.GenerateResource.cache +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.GeneratedMSBuildEditorConfig.editorconfig +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.AssemblyInfoInputs.cache +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.AssemblyInfo.cs +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.csproj.CoreCompileInputs.cache +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.dll +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\refint\Dolgozat_2024. 09. 12_GUI.dll +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.pdb +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\Dolgozat_2024. 09. 12_GUI.genruntimeconfig.cache +C:\Users\adamtoth\source\repos\Dolgozat_2024. 09. 12_GUI\Dolgozat_2024. 09. 12_GUI\obj\Debug\net8.0-windows\ref\Dolgozat_2024. 09. 12_GUI.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.GenerateResource.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.GenerateResource.cache new file mode 100644 index 0000000..e365f10 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.csproj.GenerateResource.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.runtimeconfig.json new file mode 100644 index 0000000..409fab6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\adamtoth\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\adamtoth\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll new file mode 100644 index 0000000..479d3cb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.genruntimeconfig.cache new file mode 100644 index 0000000..18ba2ce --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.genruntimeconfig.cache @@ -0,0 +1 @@ +d0ddaee545304f4986f4f66e608b1ea8861ec3e39f6d9eb422bc59b620bcfa31 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb new file mode 100644 index 0000000..95db446 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024. 09. 12_GUI.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024._09._12_GUI.Form1.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024._09._12_GUI.Form1.resources new file mode 100644 index 0000000..6c05a97 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/Dolgozat_2024._09._12_GUI.Form1.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..e64b4a4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/ref/Dolgozat_2024. 09. 12_GUI.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/ref/Dolgozat_2024. 09. 12_GUI.dll new file mode 100644 index 0000000..73cfb5b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/ref/Dolgozat_2024. 09. 12_GUI.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/refint/Dolgozat_2024. 09. 12_GUI.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/refint/Dolgozat_2024. 09. 12_GUI.dll new file mode 100644 index 0000000..73cfb5b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Debug/net8.0-windows/refint/Dolgozat_2024. 09. 12_GUI.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.dgspec.json new file mode 100644 index 0000000..0d64d86 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj": {} + }, + "projects": { + "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj", + "projectName": "Dolgozat_2024. 09. 12_GUI", + "projectPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj", + "packagesPath": "C:\\Users\\adamtoth\\.nuget\\packages\\", + "outputPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\adamtoth\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.props new file mode 100644 index 0000000..c2a0d8b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\adamtoth\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/Dolgozat_2024. 09. 12_GUI.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.assets.json new file mode 100644 index 0000000..4c9936e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\adamtoth\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj", + "projectName": "Dolgozat_2024. 09. 12_GUI", + "projectPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj", + "packagesPath": "C:\\Users\\adamtoth\\.nuget\\packages\\", + "outputPath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\adamtoth\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.nuget.cache new file mode 100644 index 0000000..d124b97 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Házi/Dolgozat_2024. 09. 12_GUI/Dolgozat_2024. 09. 12_GUI/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "EUKKBI8ekEc=", + "success": true, + "projectFilePath": "C:\\Users\\adamtoth\\source\\repos\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI\\Dolgozat_2024. 09. 12_GUI.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..2cf0f69 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/FileContentIndex/b83c2ed9-b81a-426e-b458-b42fad1fffd0.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/FileContentIndex/b83c2ed9-b81a-426e-b458-b42fad1fffd0.vsidx new file mode 100644 index 0000000..aa8fd1d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/FileContentIndex/b83c2ed9-b81a-426e-b458-b42fad1fffd0.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.futdcache.v2 new file mode 100644 index 0000000..baa2cdb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.suo new file mode 100644 index 0000000..b512abf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..3724870 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.backup.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|f:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2023. 11. 14_feladat2\\2023. 11. 14_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|solutionrelative:2023. 11. 14_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|f:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2023. 11. 14_feladat2\\2023. 11. 14_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|solutionrelative:2023. 11. 14_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2023. 11. 14_Feladat2\\MainWindow.xaml", + "ToolTip": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2023. 11. 14_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-11-14T07:50:46.309Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "RelativeToolTip": "2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "ViewState": "AgIAACAAAAAAAAAAAAAywDAAAAA7AAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-11-14T07:50:46.144Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.json new file mode 100644 index 0000000..6123522 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/2023. 11. 14_Feladat2/v17/DocumentLayout.json @@ -0,0 +1,60 @@ +{ + "Version": 1, + "WorkspaceRootPath": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|f:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2023. 11. 14_feladat2\\2023. 11. 14_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|solutionrelative:2023. 11. 14_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|f:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2023. 11. 14_feladat2\\2023. 11. 14_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{61591E7C-489C-4FCD-B9D6-DBD283EDD933}|2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj|solutionrelative:2023. 11. 14_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2023. 11. 14_Feladat2\\MainWindow.xaml", + "ToolTip": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2023. 11. 14_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-11-14T07:50:46.309Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "F:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "RelativeToolTip": "2023. 11. 14_Feladat2\\MainWindow.xaml.cs", + "ViewState": "AgIAACAAAAAAAAAAAAAywDAAAAA7AAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-11-14T07:50:46.144Z" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.metadata.v9.bin new file mode 100644 index 0000000..03f16d6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.projects.v9.bin new file mode 100644 index 0000000..13d9f7c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.strings.v9.bin new file mode 100644 index 0000000..e017d0a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/.vs/ProjectEvaluation/2023. 11. 14_feladat2.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.sln new file mode 100644 index 0000000..b5367c5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2023. 11. 14_Feladat2", "2023. 11. 14_Feladat2\2023. 11. 14_Feladat2.csproj", "{61591E7C-489C-4FCD-B9D6-DBD283EDD933}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {61591E7C-489C-4FCD-B9D6-DBD283EDD933}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {61591E7C-489C-4FCD-B9D6-DBD283EDD933}.Debug|Any CPU.Build.0 = Debug|Any CPU + {61591E7C-489C-4FCD-B9D6-DBD283EDD933}.Release|Any CPU.ActiveCfg = Release|Any CPU + {61591E7C-489C-4FCD-B9D6-DBD283EDD933}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {254F72F3-C698-4FA0-BC40-672D2C8AF88E} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj new file mode 100644 index 0000000..71be052 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2023._11._14_Feladat2 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml new file mode 100644 index 0000000..f2a9373 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml.cs new file mode 100644 index 0000000..5a98e97 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2023._11._14_Feladat2 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml new file mode 100644 index 0000000..005d384 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml @@ -0,0 +1,31 @@ + + + + + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml.cs new file mode 100644 index 0000000..dec93d6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/MainWindow.xaml.cs @@ -0,0 +1,53 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2023._11._14_Feladat2 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + + for (int i = 1; i < 41; i++) + { + ComboBoxX.Items.Add(i); + } + } + + private void Hozzaad_Button_Click(object sender, RoutedEventArgs e) + { + if (ComboBoxX.SelectedItem == null) + { + MessageBox.Show("Válasszon egy napot!", "Hiba", MessageBoxButton.OK, MessageBoxImage.Error); + return; + } + + if (int.Parse(Elkeszitett_TextBox.Text) < 0 || int.Parse(Eladott_TextBox.Text) < 0) + { + MessageBox.Show("Negatív számot nem adhat meg!", "Hiba", MessageBoxButton.OK, MessageBoxImage.Error); + return; + } + + if (int.Parse(Elkeszitett_TextBox.Text) < int.Parse(Eladott_TextBox.Text)) + { + MessageBox.Show("Túl sok az eladott angyalka!", "Hiba", MessageBoxButton.OK, MessageBoxImage.Error); + return; + } + + ListBoxX.Items.Add($"{ComboBoxX.SelectedValue}.nap\t +{Elkeszitett_TextBox.Text}\t -{Eladott_TextBox.Text}\t =\t {int.Parse(Elkeszitett_TextBox.Text) - int.Parse(Eladott_TextBox.Text)}"); + ComboBoxX.Items.Remove(ComboBoxX.SelectedValue); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.deps.json new file mode 100644 index 0000000..97b11db --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2023. 11. 14_Feladat2/1.0.0": { + "runtime": { + "2023. 11. 14_Feladat2.dll": {} + } + } + } + }, + "libraries": { + "2023. 11. 14_Feladat2/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll new file mode 100644 index 0000000..6d49ba1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.exe new file mode 100644 index 0000000..9620796 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb new file mode 100644 index 0000000..898ee6f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/bin/Debug/net8.0-windows/2023. 11. 14_Feladat2.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..99b7277 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj": {} + }, + "projects": { + "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj", + "projectName": "2023. 11. 14_Feladat2", + "projectPath": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/2023. 11. 14_Feladat2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.assets.cache new file mode 100644 index 0000000..4462780 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..793060a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +14ea52b88d78286aaffb2ab4e357a41dedc158fdeb67ff03320fe3363c282680 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..dbd889c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\bin\Debug\net8.0-windows\2023. 11. 14_Feladat2.exe +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\bin\Debug\net8.0-windows\2023. 11. 14_Feladat2.deps.json +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\bin\Debug\net8.0-windows\2023. 11. 14_Feladat2.runtimeconfig.json +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\bin\Debug\net8.0-windows\2023. 11. 14_Feladat2.dll +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\bin\Debug\net8.0-windows\2023. 11. 14_Feladat2.pdb +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\MainWindow.g.cs +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\App.g.cs +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2_MarkupCompile.cache +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2_MarkupCompile.lref +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\MainWindow.baml +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.g.resources +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.GeneratedMSBuildEditorConfig.editorconfig +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.AssemblyInfoInputs.cache +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.AssemblyInfo.cs +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.csproj.CoreCompileInputs.cache +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.dll +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\refint\2023. 11. 14_Feladat2.dll +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.pdb +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\2023. 11. 14_Feladat2.genruntimeconfig.cache +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\ref\2023. 11. 14_Feladat2.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll new file mode 100644 index 0000000..6d49ba1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.g.resources new file mode 100644 index 0000000..27c7ed7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.genruntimeconfig.cache new file mode 100644 index 0000000..ba47792 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.genruntimeconfig.cache @@ -0,0 +1 @@ +5600447320b42dd61a767b56ac0f3aa9db7674a8c76170e9c56ff2bc563a247f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb new file mode 100644 index 0000000..898ee6f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.assets.cache new file mode 100644 index 0000000..afbc4f2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_02kzynov_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.assets.cache new file mode 100644 index 0000000..7d9b172 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_03ixqbfe_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.assets.cache new file mode 100644 index 0000000..a27d188 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_2q510rhr_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.assets.cache new file mode 100644 index 0000000..3d3fa9a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_55f5iqyo_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.assets.cache new file mode 100644 index 0000000..b3dca59 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5l0xea5y_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.assets.cache new file mode 100644 index 0000000..91d1e25 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_5rhkxsdu_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.cache new file mode 100644 index 0000000..58a63c6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.cache @@ -0,0 +1,20 @@ +2023. 11. 14_Feladat2 + + +winexe +C# +.cs +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\ +_2023._11._14_Feladat2 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\App.xaml +11407045341 + +4825087605 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.cache new file mode 100644 index 0000000..01bc182 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2023. 11. 14_Feladat2 +1.0.0.0 + +winexe +C# +.cs +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\obj\Debug\net8.0-windows\ +_2023._11._14_Feladat2 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\App.xaml +11407045341 + +61870082998 +198-556154604 +MainWindow.xaml; + +True + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.lref new file mode 100644 index 0000000..b4a7359 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.i.lref @@ -0,0 +1,4 @@ + + +FF:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.lref new file mode 100644 index 0000000..b4a7359 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FF:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.assets.cache new file mode 100644 index 0000000..39b4118 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ad3zdzne_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.assets.cache new file mode 100644 index 0000000..bd05eef Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_adwlw5fj_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.assets.cache new file mode 100644 index 0000000..59a5faa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_bsks2wkr_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.assets.cache new file mode 100644 index 0000000..99feb92 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_cooa21h2_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.assets.cache new file mode 100644 index 0000000..1d6c1d7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_d2xz4eb5_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.assets.cache new file mode 100644 index 0000000..e9c9269 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_exkc01s5_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.assets.cache new file mode 100644 index 0000000..278c920 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_f2vb2ofg_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.assets.cache new file mode 100644 index 0000000..b0150c0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_h15wgqyo_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.assets.cache new file mode 100644 index 0000000..334c703 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_i3c4jxff_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.assets.cache new file mode 100644 index 0000000..c22e673 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_ijzguqm3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.assets.cache new file mode 100644 index 0000000..81b9c30 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k4ff0ozs_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.assets.cache new file mode 100644 index 0000000..0930afc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_k5iyeosq_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.assets.cache new file mode 100644 index 0000000..94399e7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_mrt0qvct_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.assets.cache new file mode 100644 index 0000000..e979f10 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_my20hfdl_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.assets.cache new file mode 100644 index 0000000..42c91e0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_na1mwfsy_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.assets.cache new file mode 100644 index 0000000..430d7b1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_nswks35p_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.assets.cache new file mode 100644 index 0000000..4637cf6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_o1a3riw5_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.assets.cache new file mode 100644 index 0000000..6945605 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_oehw0jez_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.assets.cache new file mode 100644 index 0000000..857d6e6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qavemka0_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.assets.cache new file mode 100644 index 0000000..79be8b6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qpocghm0_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.assets.cache new file mode 100644 index 0000000..fab0843 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_qvc14yqm_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.assets.cache new file mode 100644 index 0000000..a507088 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_r0trefh3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.assets.cache new file mode 100644 index 0000000..6ed8b3c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_slfhukyj_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.assets.cache new file mode 100644 index 0000000..bebdf07 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_sp5wic5j_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.assets.cache new file mode 100644 index 0000000..39b41e3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_t2rlhe5k_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.assets.cache new file mode 100644 index 0000000..5391c04 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_wtollyy5_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.assets.cache new file mode 100644 index 0000000..aaf83e1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_yqajl3dc_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..fccf94f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2023. 11. 14_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..6df1d92 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e8aa058f4352252d39081dc2c1a7f584f2041e29df418bf27357a366ee9162a6 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..b5fa4d3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2023._11._14_Feladat2 +build_property.ProjectDir = F:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2023. 11. 14_Feladat2\2023. 11. 14_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.assets.cache new file mode 100644 index 0000000..9430908 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/2023. 11. 14_Feladat2_z2lbtw2l_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..4ddd177 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "9C18169889A6FA3B408B447A4259D6AC82B36F2D" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2023._11._14_Feladat2; + + +namespace _2023._11._14_Feladat2 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2023._11._14_Feladat2.App app = new _2023._11._14_Feladat2.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..4ddd177 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "9C18169889A6FA3B408B447A4259D6AC82B36F2D" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2023._11._14_Feladat2; + + +namespace _2023._11._14_Feladat2 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2023._11._14_Feladat2.App app = new _2023._11._14_Feladat2.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..899d1e5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..96a9cbc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,140 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "199DB6731E1F19CEF572A256E11CE2F13C6585FE" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2023._11._14_Feladat2; + + +namespace _2023._11._14_Feladat2 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 22 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox ComboBoxX; + + #line default + #line hidden + + + #line 25 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Elkeszitett_TextBox; + + #line default + #line hidden + + + #line 27 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Eladott_TextBox; + + #line default + #line hidden + + + #line 28 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Hozzaad_Button; + + #line default + #line hidden + + + #line 29 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ListBox ListBoxX; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2023. 11. 14_Feladat2;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.ComboBoxX = ((System.Windows.Controls.ComboBox)(target)); + return; + case 2: + this.Elkeszitett_TextBox = ((System.Windows.Controls.TextBox)(target)); + return; + case 3: + this.Eladott_TextBox = ((System.Windows.Controls.TextBox)(target)); + return; + case 4: + this.Hozzaad_Button = ((System.Windows.Controls.Button)(target)); + + #line 28 "..\..\..\MainWindow.xaml" + this.Hozzaad_Button.Click += new System.Windows.RoutedEventHandler(this.Hozzaad_Button_Click); + + #line default + #line hidden + return; + case 5: + this.ListBoxX = ((System.Windows.Controls.ListBox)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..05b36ff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,140 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "199DB6731E1F19CEF572A256E11CE2F13C6585FE" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2023._11._14_Feladat2; + + +namespace _2023._11._14_Feladat2 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 22 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox ComboBoxX; + + #line default + #line hidden + + + #line 25 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Elkeszitett_TextBox; + + #line default + #line hidden + + + #line 27 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Eladott_TextBox; + + #line default + #line hidden + + + #line 28 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Hozzaad_Button; + + #line default + #line hidden + + + #line 29 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ListBox ListBoxX; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2023. 11. 14_Feladat2;V1.0.0.0;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.ComboBoxX = ((System.Windows.Controls.ComboBox)(target)); + return; + case 2: + this.Elkeszitett_TextBox = ((System.Windows.Controls.TextBox)(target)); + return; + case 3: + this.Eladott_TextBox = ((System.Windows.Controls.TextBox)(target)); + return; + case 4: + this.Hozzaad_Button = ((System.Windows.Controls.Button)(target)); + + #line 28 "..\..\..\MainWindow.xaml" + this.Hozzaad_Button.Click += new System.Windows.RoutedEventHandler(this.Hozzaad_Button_Click); + + #line default + #line hidden + return; + case 5: + this.ListBoxX = ((System.Windows.Controls.ListBox)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..9620796 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/ref/2023. 11. 14_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/ref/2023. 11. 14_Feladat2.dll new file mode 100644 index 0000000..8c6101c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/ref/2023. 11. 14_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/refint/2023. 11. 14_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/refint/2023. 11. 14_Feladat2.dll new file mode 100644 index 0000000..8c6101c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/Debug/net8.0-windows/refint/2023. 11. 14_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.assets.json new file mode 100644 index 0000000..ff5becc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj", + "projectName": "2023. 11. 14_Feladat2", + "projectPath": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.nuget.cache new file mode 100644 index 0000000..2968510 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2023. 11. 14_Feladat2/2023. 11. 14_Feladat2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "PFhu24JWp3c=", + "success": true, + "projectFilePath": "F:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2\\2023. 11. 14_Feladat2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..3819dbf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/FileContentIndex/e7b802eb-4452-4269-9ce9-4d41989dabd9.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/FileContentIndex/e7b802eb-4452-4269-9ce9-4d41989dabd9.vsidx new file mode 100644 index 0000000..7a5b4f8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/FileContentIndex/e7b802eb-4452-4269-9ce9-4d41989dabd9.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.futdcache.v2 new file mode 100644 index 0000000..0ca9197 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.suo new file mode 100644 index 0000000..6323a5f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/DocumentLayout.json new file mode 100644 index 0000000..80cf573 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/2024. 09. 04/v17/DocumentLayout.json @@ -0,0 +1,58 @@ +{ + "Version": 1, + "WorkspaceRootPath": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 04\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{10FBA065-8087-4D79-96B2-826474D9567F}|2024. 09. 04\\2024. 09. 04.csproj|d:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\h\u00E1zi\\2024. 09. 04\\2024. 09. 04\\orszag.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{10FBA065-8087-4D79-96B2-826474D9567F}|2024. 09. 04\\2024. 09. 04.csproj|solutionrelative:2024. 09. 04\\orszag.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{10FBA065-8087-4D79-96B2-826474D9567F}|2024. 09. 04\\2024. 09. 04.csproj|d:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\h\u00E1zi\\2024. 09. 04\\2024. 09. 04\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{10FBA065-8087-4D79-96B2-826474D9567F}|2024. 09. 04\\2024. 09. 04.csproj|solutionrelative:2024. 09. 04\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{b1e99781-ab81-11d0-b683-00aa00a3ee26}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Program.cs", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 04\\2024. 09. 04\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 04\\Program.cs", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 04\\2024. 09. 04\\Program.cs", + "RelativeToolTip": "2024. 09. 04\\Program.cs", + "ViewState": "AQIAABMAAAAAAAAAAAA2wCEAAAAAAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-04T18:36:55.236Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Orszag.cs", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 04\\2024. 09. 04\\Orszag.cs", + "RelativeDocumentMoniker": "2024. 09. 04\\Orszag.cs", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\H\u00E1zi\\2024. 09. 04\\2024. 09. 04\\Orszag.cs", + "RelativeToolTip": "2024. 09. 04\\Orszag.cs", + "ViewState": "AQIAACIAAAAAAAAAAIA3wCYAAAAoAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-04T18:36:55.208Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.metadata.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.metadata.v7.bin new file mode 100644 index 0000000..0e0ad21 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.metadata.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.projects.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.projects.v7.bin new file mode 100644 index 0000000..0bf6866 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.projects.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.strings.v8.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.strings.v8.bin new file mode 100644 index 0000000..1438930 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/.vs/ProjectEvaluation/2024. 09. 04.strings.v8.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04.sln new file mode 100644 index 0000000..4c17217 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 04", "2024. 09. 04\2024. 09. 04.csproj", "{10FBA065-8087-4D79-96B2-826474D9567F}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {10FBA065-8087-4D79-96B2-826474D9567F}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {10FBA065-8087-4D79-96B2-826474D9567F}.Debug|Any CPU.Build.0 = Debug|Any CPU + {10FBA065-8087-4D79-96B2-826474D9567F}.Release|Any CPU.ActiveCfg = Release|Any CPU + {10FBA065-8087-4D79-96B2-826474D9567F}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {559B2CA6-2EE8-49A6-83D3-344F8047915A} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/2024. 09. 04.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/2024. 09. 04.csproj new file mode 100644 index 0000000..25e52a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/2024. 09. 04.csproj @@ -0,0 +1,11 @@ + + + + Exe + net6.0 + _2024._09._04 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Orszag.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Orszag.cs new file mode 100644 index 0000000..edfe77c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Orszag.cs @@ -0,0 +1,65 @@ +class Orszag +{ + public List Orszagnev { get; private set; } + public List Terulet { get; private set; } + public List Nepesseg { get; private set; } + public List Fovaros { get; private set; } + public List FovarosNepesseg { get; private set; } + + public Orszag(List orszagnev, List terulet, List nepesseg, List fovaros, List fovarosNepesseg) + { + Orszagnev = orszagnev; + Terulet = terulet; + Nepesseg = nepesseg; + Fovaros = fovaros; + FovarosNepesseg = fovarosNepesseg; + } + + public void Nepsuruseg(string orszagnev) + { + int terulet = Terulet[Orszagnev.IndexOf(orszagnev)]; + int nepesseg = Nepesseg[Orszagnev.IndexOf(orszagnev)]; + int nepsuruseg = nepesseg / terulet; + Console.WriteLine($"{orszagnev} népsűrűsége {nepsuruseg} fő/km^2."); + } + + public void Kulonbseg() + { + int nepessegKina = Nepesseg[Orszagnev.IndexOf("Kína")]; + int nepessegIndia = Nepesseg[Orszagnev.IndexOf("India")]; + Console.WriteLine($"Kínában a lakosság {nepessegKina - nepessegIndia} fővel volt több."); + } + + public void Legnagyobb3() + { + List originalNepesseg = new List(Nepesseg); + Nepesseg.Sort(); + Nepesseg.Reverse(); + int nepessegSzam = Nepesseg[2]; + Nepesseg = new List(originalNepesseg); + string orszag = Orszagnev[Nepesseg.IndexOf(nepessegSzam)]; + Console.WriteLine($"A harmadik legnépesebb ország: {orszag}, a lakosság {nepessegSzam}."); + } + + public void Szazalek30() + { + List orszagNevek = new List(); + for (int i = 0; i < Nepesseg.Count; i++) + { + double nepesseg = Nepesseg[i]; + double fovarosNepessege = FovarosNepesseg[i] * 1000; + double eredmeny = (fovarosNepessege / nepesseg * 100); + if (eredmeny > 30) + { + orszagNevek.Add(Orszagnev[i]); + } + } + + Console.WriteLine(string.Join(", ", orszagNevek)); + } + + public override string ToString() + { + return ""; + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Program.cs new file mode 100644 index 0000000..6d6e417 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/Program.cs @@ -0,0 +1,43 @@ +namespace _2024._09._04 +{ + internal class Program + { + static void Main(string[] args) + { + var lines = File.ReadLines("adatok-utf8.txt"); + List orszag = new List(); + List terulet = new List(); + List nepesseg = new List(); + List fovaros = new List(); + List fovarosNepessege = new List(); + + foreach (string line in lines) + { + string[] data = line.Split(";"); + orszag.Add(data[0]); + terulet.Add(int.Parse(data[1])); + nepesseg.Add(int.Parse(data[2])); + fovaros.Add(data[3]); + fovarosNepessege.Add(int.Parse(data[4])); + } + + Orszag orszagok = new Orszag(orszag, terulet, nepesseg, fovaros, fovarosNepessege); + + Console.WriteLine("3. feladat"); + Console.WriteLine($"A beolvasott országok száma {orszagok.Orszagnev}."); + + Console.WriteLine("4. feladat"); + orszagok.Nepsuruseg(Console.ReadLine()); + + Console.WriteLine("5. feladat"); + orszagok.Kulonbseg(); + + Console.WriteLine("6. feladat"); + orszagok.Legnagyobb3(); + + Console.WriteLine("7. feladat"); + orszagok.Szazalek30(); + + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.deps.json new file mode 100644 index 0000000..3fcd026 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 09. 04/1.0.0": { + "runtime": { + "2024. 09. 04.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 04/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.dll new file mode 100644 index 0000000..69022aa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.exe new file mode 100644 index 0000000..7e74ecc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.pdb new file mode 100644 index 0000000..ca9a9d5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.runtimeconfig.json new file mode 100644 index 0000000..4986d16 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/2024. 09. 04.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/adatok-utf8.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/adatok-utf8.txt new file mode 100644 index 0000000..0768323 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/bin/Debug/net6.0/adatok-utf8.txt @@ -0,0 +1,49 @@ +Görögország;132000;10640000;Athén;3154 +Románia;238400;19120000;Bukarest;1812 +Ausztria;83900;8960000;Bécs;1915 +Lengyelország;312700;3775000;Varsó;1776 +Belgium;30500;11590000;Brüsszel;2065 +Bulgária;110400;6880000;Szófia;1277 +Ciprus;9300;900000;Nicosia;270 +Csehország;78900;10510000;Prága;1299 +Dánia;42900;5860000;Koppenhága;1334 +Észtország;45400;1330000;Tallinn;441 +Finnország;336900;5540000;Helsinki;1292 +Franciaország;551500;67750000;Párizs;10958 +Hollandia;41500;17530000;Amszterdam;1140 +Horvátország;56600;3960000;Zágráb;685 +Írország;69800;5030000;Dublin;1215 +Lettország;64600;1880000;Riga;634 +Litvánia;65300;2800000;Vilnius;538 +Luxemburg;2600;640000;Luxembourg;120 +Magyarország;93000;9710000;Budapest;1764 +Málta;300;520000;Valletta;213 +Németország;357600;83200000;Berlin;3557 +Olaszország;302100;59110000;Róma;4234 +Portugália;92200;10330000;Lisszabon;2942 +Spanyolország;506000;47420000;Madrid;6559 +Svédország;438600;10420000;Stockholm;1608 +Szlovákia;49000;5450000;Pozsony;433 +Szlovénia;20300;2110000;Ljubljana;287 +Egyesült Királyság;244400;67330000;London;9177 +Izland;103000;370000;Reykjavík;216 +Észak-Macedónia;25700;1950000;Szkopje;590 +Montenegró;13900;620000;Podgorica;177 +Norvégia;323800;5410000;Osló;1027 +Oroszország;17098200;143450000;Moszkva;12476 +Svájc;41300;8700000;Bern;426 +Szerbia;88400;6830000;Belgrád;1394 +Törökország;783600;84150000;Ankara;5018 +India;3287300;1393410000;Új-Delhi;29399 +Izrael;22100;9360000;Jeruzsálem;919 +Japán;377900;125680000;Tokió;37435 +Kína;9600000;1412360000;Peking;20036 +Koreai Köztársaság;100400;51740000;Szöul;9962 +Dél-afrikai Köztársaság;1221000;60040000;Pretoriap;2473 +Egyiptom;1002000;104260000;Kairó;20485 +Brazília;8510300;213990000;Brasilia;4559 +Egyesült Államok;9833500;331890000;Washington, D.C.;5265 +Kanada;9984700;38250000;Ottawa;1378 +Mexikó;1964400;130260000;Mexikóváros;21672 +Ausztrália;7692000;25740000;Canberra;453 +Új-Zéland;268100;5120000;Wellington;413 \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.dgspec.json new file mode 100644 index 0000000..f1887ce --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj", + "projectName": "2024. 09. 04", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/2024. 09. 04.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfo.cs new file mode 100644 index 0000000..03cec42 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 04")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 04")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 04")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfoInputs.cache new file mode 100644 index 0000000..7fd2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +83059848c0ce6ac725a28d7ac0a7ae31b2036f6b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..783c944 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net6.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._04 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.assets.cache new file mode 100644 index 0000000..262b1ab Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..018ebb7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +cfcc0b962f2d738e1c7c0280005c1da4a3dbc433 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..2ccae5e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.csproj.FileListAbsolute.txt @@ -0,0 +1,28 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\refint\2024. 09. 04.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\ref\2024. 09. 04.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.exe +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.deps.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.runtimeconfig.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\bin\Debug\net6.0\2024. 09. 04.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.GeneratedMSBuildEditorConfig.editorconfig +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.AssemblyInfoInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.AssemblyInfo.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.csproj.CoreCompileInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\refint\2024. 09. 04.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\2024. 09. 04.genruntimeconfig.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Házi\2024. 09. 04\2024. 09. 04\obj\Debug\net6.0\ref\2024. 09. 04.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.dll new file mode 100644 index 0000000..69022aa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.genruntimeconfig.cache new file mode 100644 index 0000000..418eb11 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.genruntimeconfig.cache @@ -0,0 +1 @@ +1d4f1a20d4a3c499abb43eeeb3f0b5b6f175ecf1 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.pdb new file mode 100644 index 0000000..ca9a9d5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/2024. 09. 04.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/apphost.exe new file mode 100644 index 0000000..7e74ecc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/ref/2024. 09. 04.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/ref/2024. 09. 04.dll new file mode 100644 index 0000000..a16c764 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/ref/2024. 09. 04.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/refint/2024. 09. 04.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/refint/2024. 09. 04.dll new file mode 100644 index 0000000..a16c764 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/Debug/net6.0/refint/2024. 09. 04.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.assets.json new file mode 100644 index 0000000..f3cf746 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net6.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj", + "projectName": "2024. 09. 04", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.nuget.cache new file mode 100644 index 0000000..e9d5765 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/2024. 09. 04/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "mYKEM/DRHHn/VXYJV3WISNnzhsSMzX/IRHu2yIiKbVeVmMsmFSze0BQsQSr7I69aEHQ4cOoZElt77UlD7CEHbQ==", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 04\\2024. 09. 04\\2024. 09. 04.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/Gyakorlás.pdf b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/Gyakorlás.pdf new file mode 100644 index 0000000..92d6406 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/Gyakorlás.pdf differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-1250.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-1250.txt new file mode 100644 index 0000000..8a43f65 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-1250.txt @@ -0,0 +1,50 @@ +Orszg;Terlet;Npessg;Fvros;Fvros npessge +Grgorszg;132000;1064g;Athn;3154 +Romnia;238400;1912g;Bukarest;1812 +Ausztria;83900;8960000;Bcs;1915 +Lengyelorszg;312700;3775g;Vars;1776 +Belgium;30500;11590000;Brsszel;2065 +Bulgria;110400;6880000;Szfia;1277 +Ciprus;9300;900000;Nicosia;270 +Csehorszg;78900;10510000;Prga;1299 +Dnia;42900;5860000;Koppenhga;1334 +sztorszg;45400;1330000;Tallinn;441 +Finnorszg;336900;5540000;Helsinki;1292 +Franciaorszg;551500;67750000;Prizs;10958 +Hollandia;41500;17530000;Amszterdam;1140 +Horvtorszg;56600;3960000;Zgrb;685 +rorszg;69800;5030000;Dublin;1215 +Lettorszg;64600;1880000;Riga;634 +Litvnia;65300;2800000;Vilnius;538 +Luxemburg;2600;640000;Luxembourg;120 +Magyarorszg;93000;9710000;Budapest;1764 +Mlta;300;520000;Valletta;213 +Nmetorszg;357600;83200000;Berlin;3557 +Olaszorszg;302100;59110000;Rma;4234 +Portuglia;92200;10330000;Lisszabon;2942 +Spanyolorszg;506000;47420000;Madrid;6559 +Svdorszg;438600;10420000;Stockholm;1608 +Szlovkia;49000;5450000;Pozsony;433 +Szlovnia;20300;2110000;Ljubljana;287 +Egyeslt Kirlysg;244400;67330000;London;9177 +Izland;103000;370000;Reykjavk;216 +szak-Macednia;25700;1950000;Szkopje;590 +Montenegr;13900;620000;Podgorica;177 +Norvgia;323800;5410000;Osl;1027 +Oroszorszg;17098200;143450000;Moszkva;12476 +Svjc;41300;8700000;Bern;426 +Szerbia;88400;6830000;Belgrd;1394 +Trkorszg;783600;84150000;Ankara;5018 +India;3287300;1393410000;j-Delhi;29399 +Izrael;22100;9360000;Jeruzslem;919 +Japn;377900;125680000;Toki;37435 +Kna;9600000;1412360000;Peking;20036 +Koreai Kztrsasg;100400;51740000;Szul;9962 +Dl-afrikai Kztrsasg;1221000;60040000;Pretoriap;2473 +Egyiptom;1002000;104260000;Kair;20485 +Brazlia;8510300;213990000;Brasilia;4559 +Egyeslt llamok;9833500;331890000;Washington, D.C.;5265 +Kanada;9984700;38250000;Ottawa;1378 +Mexik;1964400;130260000;Mexikvros;21672 +Ausztrlia;7692000;25740000;Canberra;453 +j-Zland;268100;5120000;Wellington;413 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-utf8.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-utf8.txt new file mode 100644 index 0000000..5838ca4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/adatok-utf8.txt @@ -0,0 +1,50 @@ +Ország;Terület;Népesség;Főváros;Főváros népessége +Görögország;132000;1064g;Athén;3154 +Románia;238400;1912g;Bukarest;1812 +Ausztria;83900;8960000;Bécs;1915 +Lengyelország;312700;3775g;Varsó;1776 +Belgium;30500;11590000;Brüsszel;2065 +Bulgária;110400;6880000;Szófia;1277 +Ciprus;9300;900000;Nicosia;270 +Csehország;78900;10510000;Prága;1299 +Dánia;42900;5860000;Koppenhága;1334 +Észtország;45400;1330000;Tallinn;441 +Finnország;336900;5540000;Helsinki;1292 +Franciaország;551500;67750000;Párizs;10958 +Hollandia;41500;17530000;Amszterdam;1140 +Horvátország;56600;3960000;Zágráb;685 +Írország;69800;5030000;Dublin;1215 +Lettország;64600;1880000;Riga;634 +Litvánia;65300;2800000;Vilnius;538 +Luxemburg;2600;640000;Luxembourg;120 +Magyarország;93000;9710000;Budapest;1764 +Málta;300;520000;Valletta;213 +Németország;357600;83200000;Berlin;3557 +Olaszország;302100;59110000;Róma;4234 +Portugália;92200;10330000;Lisszabon;2942 +Spanyolország;506000;47420000;Madrid;6559 +Svédország;438600;10420000;Stockholm;1608 +Szlovákia;49000;5450000;Pozsony;433 +Szlovénia;20300;2110000;Ljubljana;287 +Egyesült Királyság;244400;67330000;London;9177 +Izland;103000;370000;Reykjavík;216 +Észak-Macedónia;25700;1950000;Szkopje;590 +Montenegró;13900;620000;Podgorica;177 +Norvégia;323800;5410000;Osló;1027 +Oroszország;17098200;143450000;Moszkva;12476 +Svájc;41300;8700000;Bern;426 +Szerbia;88400;6830000;Belgrád;1394 +Törökország;783600;84150000;Ankara;5018 +India;3287300;1393410000;Új-Delhi;29399 +Izrael;22100;9360000;Jeruzsálem;919 +Japán;377900;125680000;Tokió;37435 +Kína;9600000;1412360000;Peking;20036 +Koreai Köztársaság;100400;51740000;Szöul;9962 +Dél-afrikai Köztársaság;1221000;60040000;Pretoriap;2473 +Egyiptom;1002000;104260000;Kairó;20485 +Brazília;8510300;213990000;Brasilia;4559 +Egyesült Államok;9833500;331890000;Washington, D.C.;5265 +Kanada;9984700;38250000;Ottawa;1378 +Mexikó;1964400;130260000;Mexikóváros;21672 +Ausztrália;7692000;25740000;Canberra;453 +Új-Zéland;268100;5120000;Wellington;413 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/csharp.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/csharp.txt new file mode 100644 index 0000000..657e47d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 04/Gyakorlás/csharp.txt @@ -0,0 +1,28 @@ +class Orszag +{ + public string Orszagnev { get; private set; } + public int Terulet { get; private set; } + public int Nepesseg { get; private set; } + public string Fovaros { get; private set; } + public int FovarosNepesseg { get; private set; } + + public Orszag(string orszagnev, int terulet, int nepesseg, string fovaros, int fovarosNepesseg) + { + Orszagnev = orszagnev; + Terulet = terulet; + Nepesseg = nepesseg; + Fovaros = fovaros; + FovarosNepesseg = fovarosNepesseg; + } + + public Orszag(string sor) + { + // Ebben a konstruktorban is elvégezheti az adatsor felbontását! + // Ha nem ezt választja, akkor törölje ezt a konstruktort! + } + + public override string ToString() + { + return ""; + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..ace3f86 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1bf8b279-7bb1-47a8-b1b3-591701b49918.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1bf8b279-7bb1-47a8-b1b3-591701b49918.vsidx new file mode 100644 index 0000000..3dd27b3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1bf8b279-7bb1-47a8-b1b3-591701b49918.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1d1e0a27-9b0b-42dc-98fa-03744aaab8ba.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1d1e0a27-9b0b-42dc-98fa-03744aaab8ba.vsidx new file mode 100644 index 0000000..0e4939c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/1d1e0a27-9b0b-42dc-98fa-03744aaab8ba.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/241b2ab1-c674-4b01-8e41-125845b9cca7.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/241b2ab1-c674-4b01-8e41-125845b9cca7.vsidx new file mode 100644 index 0000000..34110e5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/FileContentIndex/241b2ab1-c674-4b01-8e41-125845b9cca7.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.futdcache.v2 new file mode 100644 index 0000000..f381916 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.suo new file mode 100644 index 0000000..a333319 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/2024. 09. 05 - 2/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.metadata.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.metadata.v7.bin new file mode 100644 index 0000000..4e92d6c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.metadata.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.projects.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.projects.v7.bin new file mode 100644 index 0000000..cea414f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/.vs/ProjectEvaluation/2024. 09. 05 - 2.projects.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2.sln new file mode 100644 index 0000000..55177fd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 05 - 2", "2024. 09. 05 - 2\2024. 09. 05 - 2.csproj", "{20F0588A-4B01-4758-B57B-513D24C59A76}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {20F0588A-4B01-4758-B57B-513D24C59A76}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {20F0588A-4B01-4758-B57B-513D24C59A76}.Debug|Any CPU.Build.0 = Debug|Any CPU + {20F0588A-4B01-4758-B57B-513D24C59A76}.Release|Any CPU.ActiveCfg = Release|Any CPU + {20F0588A-4B01-4758-B57B-513D24C59A76}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {39715DF0-F9E8-4B96-8B2F-80FEBF53D41D} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/2024. 09. 05 - 2.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/2024. 09. 05 - 2.csproj new file mode 100644 index 0000000..bd08de0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/2024. 09. 05 - 2.csproj @@ -0,0 +1,11 @@ + + + + Exe + net6.0 + _2024._09._05___2 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Dolgozok.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Dolgozok.cs new file mode 100644 index 0000000..9bdcaa8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Dolgozok.cs @@ -0,0 +1,122 @@ +class Dolgozok +{ + public string Nev { get; private set; } + public string Nem { get; private set; } + public string Reszleg { get; private set; } + public int Belepes { get; private set; } + public int Ber { get; private set; } + List dataList; + + public Dolgozok(string nev, string nem, string reszleg, int belepes, int ber) + { + Nev = nev; + Nem = nem; + Belepes = belepes; + Reszleg = reszleg; + Ber = ber; + } + + public Dolgozok() + { + dataList = new List(); + StreamReader sr = new StreamReader("berek2020.txt"); + string[] line = sr.ReadLine().Split(";"); + + while(!sr.EndOfStream) + { + line = sr.ReadLine().Split(";"); + Dolgozok dolgozok = new Dolgozok(Nev = line[0], Nem = line[1], Reszleg = line[2], Belepes = Convert.ToInt32(line[3]), Ber = Convert.ToInt32(line[4])); + dataList.Add(dolgozok); + } + + sr.Close(); + } + + public void Feladat3() + { + Console.WriteLine($"3. Feladat: Dolgozók száma: {dataList.Count} fő"); + } + + public void Feladat4() + { + double berek = 0; + foreach (var line in dataList) + { + berek += line.Ber; + } + + Console.WriteLine($"4. Feladat: Bérek átlaga: {Math.Round(berek / dataList.Count / 1000, 1)} eFt"); + } + + public string Bekeres() + { + Console.Write("Kérem a részleg nevét: "); + return Console.ReadLine(); + } + + public void Feladat6() + { + string reszleg = Bekeres(); + int legnagyobbFizetes = 0; + + foreach (var line in dataList) + { + if (line.Reszleg == reszleg && line.Ber > legnagyobbFizetes) + { + legnagyobbFizetes = line.Ber; + } + } + + foreach (var line in dataList) + { + if (legnagyobbFizetes == line.Ber) + { + Console.WriteLine("6. Feladat: A legtöbbet kereső dolgozó a megadott részlegen"); + Console.WriteLine($" Név: {line.Nev}"); + Console.WriteLine($" Neme: {line.Nem}"); + Console.WriteLine($" Belépés: {line.Belepes}"); + Console.WriteLine($" Bér: {line.Ber} Forint"); + } + } + } + + public void Statisztika() + { + List reszlegek = new List(); + Dictionary statisztika = new Dictionary(); + foreach (var line in dataList) + { + if (reszlegek.Contains(line.Reszleg)) + { + continue; + } + + else + { + reszlegek.Add(line.Reszleg); + } + } + + foreach (var item in reszlegek) + { + statisztika.Add(item, 0); + } + + foreach (var line in dataList) + { + statisztika[line.Reszleg] += 1; + } + + Console.WriteLine("7. Feladat: Statisztika"); + + foreach (KeyValuePair item in statisztika) + { + Console.WriteLine($"\t{item.Key}: {item.Value} fő"); + } + } + + public override string ToString() + { + return ""; + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Program.cs new file mode 100644 index 0000000..a4b5cac --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Program.cs @@ -0,0 +1,14 @@ +namespace _2024._09._05___2 +{ + internal class Program + { + static void Main(string[] args) + { + Dolgozok dolgozok = new Dolgozok(); + dolgozok.Feladat3(); + dolgozok.Feladat4(); + dolgozok.Feladat6(); + dolgozok.Statisztika(); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat GUI.pdf b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat GUI.pdf new file mode 100644 index 0000000..c7cb86f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat GUI.pdf differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat.pdf b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat.pdf new file mode 100644 index 0000000..6cc713d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/Programozás feladat/Programozás feladat.pdf differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.deps.json new file mode 100644 index 0000000..c3bd3c4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 09. 05 - 2/1.0.0": { + "runtime": { + "2024. 09. 05 - 2.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 05 - 2/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.dll new file mode 100644 index 0000000..301e38a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.exe new file mode 100644 index 0000000..1cb1031 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.pdb new file mode 100644 index 0000000..a4d4923 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.runtimeconfig.json new file mode 100644 index 0000000..4986d16 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/2024. 09. 05 - 2.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/berek2020.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/berek2020.txt new file mode 100644 index 0000000..cc63c35 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/bin/Debug/net6.0/berek2020.txt @@ -0,0 +1,171 @@ +Név;Neme;Részleg;Belépés;Bér +Beri Dániel;férfi;beszerzés;1979;222943 +Csavar Pista;férfi;pénzügy;1995;234074 +Lakatos Pál;férfi;beszerzés;1986;159538 +Devon Mihály;férfi;asztalosműhely;2007;161533 +Él Ilona;nő;beszerzés;1982;299865 +Gábor Gizella;nő;értékesítés;2003;181108 +Kálvin Ödömér;férfi;lakatosműhely;1976;321959 +Kolompár Gáspár;férfi;asztalosműhely;2003;253794 +Sörös Sándor;férfi;lakatosműhely;2012;202216 +Léc Elek;férfi;asztalosműhely;2001;220506 +Vonal Deodát;férfi;beszerzés;1997;187753 +Sipos Gábor;férfi;karbantartás;1982;185714 +Szigeti Sándor;férfi;karbantartás;1971;315764 +Volga Olga;nő;szerelőműhely;2009;197090 +Körte Vilmos;férfi;szerelőműhely;2016;256051 +Nagy Zoltán;nő;személyzeti;1979;167928 +Sunyi Béla;férfi;karbantartás;2010;294523 +Tiszai József;férfi;szerelőműhely;2001;305412 +Fül Elek;férfi;értékesítés;2017;112590 +Puli Sándor;férfi;lakatosműhely;1984;122782 +Seres András;férfi;értékesítés;1985;214497 +Vígh József;férfi;pénzügy;1986;202335 +Alsófalvi Amália;nő;asztalosműhely;2017;130090 +Mayer Tamás;férfi;pénzügy;1998;169054 +Végh József;férfi;karbantartás;1999;187443 +Szokai Kinga;nő;értékesítés;2000;101498 +Kondor Katalin;nő;pénzügy;2013;287247 +Kovács János;férfi;beszerzés;1993;346023 +Fityeházi Ágoston;férfi;személyzeti;2017;306860 +Karap Béla;férfi;pénzügy;1974;191443 +Pán Péter;férfi;beszerzés;2017;189096 +Pintér Sándor;férfi;pénzügy;1977;212158 +Sarkadi Csaba;férfi;személyzeti;1992;275338 +Horváth Dezső;férfi;pénzügy;1991;338631 +Kónya Anett;nő;értékesítés;1992;186852 +Pataki Aladár;férfi;szerelőműhely;2003;241873 +William Clinton;férfi;karbantartás;2004;285206 +Céhes Eszter;nő;pénzügy;2012;296289 +Gaz Julianna;nő;értékesítés;2006;131620 +Tóth Imre;férfi;asztalosműhely;1988;285381 +Higli Jolán;nő;lakatosműhely;1987;170292 +Égerházi Zsanett;nő;asztalosműhely;1993;295283 +Lakodalom Lajos;férfi;szerelőműhely;1970;229541 +Nem Tamás;férfi;karbantartás;2016;220554 +Németh Noémi;nő;karbantartás;1983;282454 +Kiss Csilla;nő;beszerzés;2009;337231 +Lapos Elemér;férfi;lakatosműhely;1972;306860 +Szokai Barbara;nő;pénzügy;2013;184629 +Károly Zoltán;férfi;értékesítés;1984;139730 +Kozlovszky Jenő;férfi;asztalosműhely;2018;248206 +Kuti Kamilla;nő;karbantartás;1977;281336 +Présinger Tamás;férfi;beszerzés;2001;297147 +Szokai Kinga;nő;beszerzés;1979;295981 +Kovács Béla;férfi;szerelőműhely;2005;269895 +Rizi Gizi;nő;szerelőműhely;2016;343616 +Vagyok Ibolya;nő;karbantartás;2000;212096 +Dávid Ilona;nő;értékesítés;1970;115651 +Turpis Imre;férfi;szerelőműhely;1999;455582 +Világi Virág;nő;beszerzés;1999;347147 +Gerecsény Eszter;nő;szerelőműhely;1975;260777 +Győri Tímea;nő;szerelőműhely;2014;140646 +Kiss Ágnes;nő;lakatosműhely;1969;125803 +Kovács Helga;nő;pénzügy;1985;325358 +Morvay Levente;férfi;személyzeti;2011;476449 +Szűcs Gábor;férfi;személyzeti;1975;265928 +Varga Dóra;nő;karbantartás;2009;144949 +Zsák Judit;nő;pénzügy;2006;222083 +Nagy Kálmán;férfi;lakatosműhely;1979;279136 +Szalacsi Sándor;férfi;karbantartás;1977;184545 +Tavi József;férfi;szerelőműhely;1979;372182 +Torgyán Andrea;nő;pénzügy;2015;461167 +Bomberra Krisztina;nő;pénzügy;2018;232925 +Fehér Jakab;férfi;értékesítés;1973;241893 +Szabó Péter;férfi;pénzügy;2010;226231 +Torgyán Attila;férfi;szerelőműhely;1987;342561 +Kárai Kata;nő;pénzügy;1994;122245 +Kötö Irma;nő;lakatosműhely;1990;284049 +Nem János;férfi;pénzügy;1990;143081 +Presser Gábor;férfi;értékesítés;2016;173758 +Szép Kálmán;férfi;szerelőműhely;1986;170663 +Azér Lázár;férfi;lakatosműhely;1995;290729 +Faragó Viktor;férfi;szerelőműhely;1970;292099 +Kicsi Misi;férfi;szerelőműhely;1978;186715 +Németh Sára;nő;karbantartás;1985;253524 +Polgár Jenő;férfi;karbantartás;1987;264165 +Szabó Balázs;férfi;személyzeti;1983;351304 +Fritz Attila;férfi;pénzügy;1969;267901 +Kodály Zoltán;férfi;értékesítés;1975;482961 +Pastinszky Tamás;férfi;személyzeti;2006;325980 +Czeczei Zsolt;férfi;beszerzés;1981;452042 +Habos Helén;nő;szerelőműhely;2004;264754 +Hegedűs Ilona;nő;szerelőműhely;1981;198774 +Kecskés Mária;nő;szerelőműhely;1978;149959 +Kovács Beáta;nő;személyzeti;2013;386887 +Prezma Aurora;nő;pénzügy;1991;137207 +Sörös Leopold;férfi;lakatosműhely;1972;329999 +Bodor Enikő;nő;pénzügy;2012;274781 +Kolompár Frigyes;férfi;lakatosműhely;1978;343403 +Makrai Dezső;férfi;szerelőműhely;2016;218725 +Morvay Jenő;férfi;pénzügy;1972;297254 +Éliás Tóbiás;férfi;pénzügy;1998;303102 +Halász Júlia;nő;szerelőműhely;2003;122520 +Kiss Borbála;nő;lakatosműhely;1971;159775 +Czeczei Zsolt;férfi;pénzügy;2005;386026 +Szabó Attila;férfi;karbantartás;2006;211794 +Budai Antal;férfi;értékesítés;2017;144107 +Dávid Izaura;nő;személyzeti;1989;300039 +Horváth Kinga;nő;karbantartás;1969;184889 +Mekk Elek Tihamér;férfi;szerelőműhely;1988;268099 +Nájt Mihály;férfi;asztalosműhely;2004;344839 +Szabó Dénes;férfi;értékesítés;2004;269537 +Fritz Géza;férfi;beszerzés;2009;288983 +Gomb Sára;nő;pénzügy;1995;313310 +Méh Erika;nő;pénzügy;2011;246126 +Víz Gizella;nő;pénzügy;2012;104223 +Fogarasi Árpád;férfi;karbantartás;1996;307855 +Hűtő Béla;férfi;pénzügy;1988;426139 +Kiss Rozália;nő;szerelőműhely;1982;248843 +Kun Béla;férfi;karbantartás;1969;265384 +Lepési Mária;nő;lakatosműhely;2006;227066 +Mária Terézia;nő;pénzügy;1987;376465 +Balogh Éva;nő;értékesítés;1983;522899 +Kapros Lajos;férfi;szerelőműhely;2006;200943 +Nehéz Teréz;nő;szerelőműhely;1973;228999 +Bán Mihály;férfi;asztalosműhely;1983;191563 +Inger Rozália;nő;pénzügy;1989;344391 +Magyar Erzsébet;nő;személyzeti;1973;287814 +Nagy Gyula;férfi;lakatosműhely;1981;211530 +Szabó Éva;nő;karbantartás;2005;182674 +Takács Lilla;nő;pénzügy;2002;325866 +Czeczei András;férfi;pénzügy;2005;205444 +Gép Béla;férfi;pénzügy;1980;277660 +Gulág Tóbiás;férfi;beszerzés;2013;109873 +Medgyessi Pál;férfi;asztalosműhely;1999;282749 +Wesselényi Brúnó;férfi;beszerzés;1975;130108 +Alsófalvi Amália;nő;asztalosműhely;1998;343647 +Sarkadi Csaba;férfi;pénzügy;1976;230294 +Asztal Sándor;férfi;pénzügy;1970;231754 +Prézli János;férfi;pénzügy;2016;169183 +Brazil Béla;férfi;asztalosműhely;2001;299524 +Határ Hugó;férfi;szerelőműhely;1980;256155 +Varga Tamás;férfi;karbantartás;1988;213615 +Balogh Gábor;férfi;asztalosműhely;1988;193119 +Barna Ágota;nő;értékesítés;1985;252032 +Béna Béla;férfi;szerelőműhely;1972;186064 +Bödön Ödön;férfi;szerelőműhely;1993;166483 +Takács Nándor;férfi;beszerzés;2007;343382 +Vaal Máté;férfi;pénzügy;1969;220726 +Gold Mária;nő;asztalosműhely;1998;286186 +Lakatos Lujza;nő;asztalosműhely;2005;316271 +Ormosi Teréz;nő;asztalosműhely;1971;104671 +Sipos Károly;férfi;karbantartás;2002;278778 +Tóth Gyula;férfi;személyzeti;1981;261433 +Átlagos Ákos;férfi;szerelőműhely;1983;219531 +Fekete Frigyes;férfi;asztalosműhely;1997;130135 +Farkas Károly;férfi;lakatosműhely;1995;209343 +Nagy Antal;férfi;karbantartás;1986;309611 +Oláh Gáspár;férfi;karbantartás;1988;137158 +Öregh Amália;nő;személyzeti;2016;315782 +Somogyi Erika;nő;karbantartás;2016;193363 +Izmos Vilmos;férfi;szerelőműhely;2011;298796 +Kovács János;férfi;asztalosműhely;1986;212865 +Pokol Petúnia;nő;beszerzés;1973;256368 +Bak Dániel;férfi;pénzügy;1983;496106 +Fekete Andrea;nő;értékesítés;1989;124880 +Gáspár Olga;nő;karbantartás;2010;298381 +Ináncsi József;férfi;karbantartás;2001;199721 +Szabó András;férfi;beszerzés;2009;269287 +Erdős Árpád;férfi;szerelőműhely;2009;220353 +Kiss Jenő;férfi;karbantartás;1973;324666 \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8ea38d8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.dgspec.json @@ -0,0 +1,63 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj", + "projectName": "2024. 09. 05 - 2", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/2024. 09. 05 - 2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfo.cs new file mode 100644 index 0000000..8871cef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 05 - 2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 05 - 2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 05 - 2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..402838f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +b1199e69d6371c0f331a97f1fa1fc13cf92c7d6e diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..73dec31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,11 @@ +is_global = true +build_property.TargetFramework = net6.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._05___2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.assets.cache new file mode 100644 index 0000000..e29ee8e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..3fea110 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +cf33727aeab7db73c5337dbfa16db3a91757476a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..bf09da1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\bin\Debug\net6.0\2024. 09. 05 - 2.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\bin\Debug\net6.0\2024. 09. 05 - 2.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\bin\Debug\net6.0\2024. 09. 05 - 2.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\bin\Debug\net6.0\2024. 09. 05 - 2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\bin\Debug\net6.0\2024. 09. 05 - 2.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\refint\2024. 09. 05 - 2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\2024. 09. 05 - 2.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05 - 2\2024. 09. 05 - 2\obj\Debug\net6.0\ref\2024. 09. 05 - 2.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.dll new file mode 100644 index 0000000..301e38a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.genruntimeconfig.cache new file mode 100644 index 0000000..5fd53c7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.genruntimeconfig.cache @@ -0,0 +1 @@ +0b58361289be7fc1831bc235c5168f78412d85c5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.pdb new file mode 100644 index 0000000..a4d4923 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/2024. 09. 05 - 2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/apphost.exe new file mode 100644 index 0000000..1cb1031 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/ref/2024. 09. 05 - 2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/ref/2024. 09. 05 - 2.dll new file mode 100644 index 0000000..8be6e69 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/ref/2024. 09. 05 - 2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/refint/2024. 09. 05 - 2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/refint/2024. 09. 05 - 2.dll new file mode 100644 index 0000000..8be6e69 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/Debug/net6.0/refint/2024. 09. 05 - 2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.assets.json new file mode 100644 index 0000000..ef35cd51 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.assets.json @@ -0,0 +1,68 @@ +{ + "version": 3, + "targets": { + "net6.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj", + "projectName": "2024. 09. 05 - 2", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.nuget.cache new file mode 100644 index 0000000..9db5553 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05 - 2/2024. 09. 05 - 2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "wwiOVUMEV0CQhQW8hyQAKJQg3igY6BOcUky4tZetchWxtg9zD4YhyNFIt49Y/fIymYQrb0fQWbmatzAg55VYow==", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05 - 2\\2024. 09. 05 - 2\\2024. 09. 05 - 2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..97c3aec Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/1349a842-c5cf-4a44-b346-a80cab4b3b87.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/1349a842-c5cf-4a44-b346-a80cab4b3b87.vsidx new file mode 100644 index 0000000..03f6932 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/1349a842-c5cf-4a44-b346-a80cab4b3b87.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/698bf14f-3ad0-44e2-a03b-4a685299a010.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/698bf14f-3ad0-44e2-a03b-4a685299a010.vsidx new file mode 100644 index 0000000..0224380 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/FileContentIndex/698bf14f-3ad0-44e2-a03b-4a685299a010.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 new file mode 100644 index 0000000..a9dd908 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.suo new file mode 100644 index 0000000..fd4fc2a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/2024. 09. 05/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin new file mode 100644 index 0000000..5b15dc6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.metadata.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin new file mode 100644 index 0000000..c97c981 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/.vs/ProjectEvaluation/2024. 09. 05.projects.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05.sln new file mode 100644 index 0000000..6293dc1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 05", "2024. 09. 05\2024. 09. 05.csproj", "{6D2B488D-1193-486B-B6F5-78BB70C861D8}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {6D2B488D-1193-486B-B6F5-78BB70C861D8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {6D2B488D-1193-486B-B6F5-78BB70C861D8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {6D2B488D-1193-486B-B6F5-78BB70C861D8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {6D2B488D-1193-486B-B6F5-78BB70C861D8}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {17C2C41D-0C94-4B2D-925F-D2C3D0586804} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj new file mode 100644 index 0000000..8804d8f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net6.0-windows + _2024._09._05 + enable + true + enable + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user new file mode 100644 index 0000000..7814ea2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/2024. 09. 05.csproj.user @@ -0,0 +1,8 @@ + + + + + Form + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.Designer.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.Designer.cs new file mode 100644 index 0000000..b503261 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.Designer.cs @@ -0,0 +1,213 @@ +namespace _2024._09._05 +{ + partial class Form1 + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + label1 = new Label(); + label2 = new Label(); + label3 = new Label(); + label4 = new Label(); + label5 = new Label(); + label6 = new Label(); + CountryTextBox = new TextBox(); + AreaTextBox = new TextBox(); + PopulationTextBox = new TextBox(); + CapitalCityTextBox = new TextBox(); + CapitalCityPopulationTextBox = new TextBox(); + label7 = new Label(); + SaveButton = new Button(); + ExitButton = new Button(); + SuspendLayout(); + // + // label1 + // + label1.AutoSize = true; + label1.Font = new Font("Segoe UI", 18F, FontStyle.Regular, GraphicsUnit.Point); + label1.Location = new Point(258, 9); + label1.Name = "label1"; + label1.Size = new Size(261, 41); + label1.TabIndex = 0; + label1.Text = "Új ország felvétele"; + // + // label2 + // + label2.AutoSize = true; + label2.Location = new Point(143, 108); + label2.Name = "label2"; + label2.Size = new Size(58, 20); + label2.TabIndex = 1; + label2.Text = "Ország:"; + // + // label3 + // + label3.AutoSize = true; + label3.Location = new Point(143, 150); + label3.Name = "label3"; + label3.Size = new Size(57, 20); + label3.TabIndex = 2; + label3.Text = "Terület:"; + // + // label4 + // + label4.AutoSize = true; + label4.Location = new Point(124, 191); + label4.Name = "label4"; + label4.Size = new Size(77, 20); + label4.TabIndex = 3; + label4.Text = "Népesség:"; + // + // label5 + // + label5.AutoSize = true; + label5.Location = new Point(138, 239); + label5.Name = "label5"; + label5.Size = new Size(63, 20); + label5.TabIndex = 4; + label5.Text = "Főváros:"; + // + // label6 + // + label6.AutoSize = true; + label6.Location = new Point(69, 280); + label6.Name = "label6"; + label6.Size = new Size(132, 20); + label6.TabIndex = 5; + label6.Text = "Főváros lakossága:"; + // + // CountryTextBox + // + CountryTextBox.Location = new Point(224, 105); + CountryTextBox.Name = "CountryTextBox"; + CountryTextBox.Size = new Size(235, 27); + CountryTextBox.TabIndex = 6; + CountryTextBox.Text = "Chile"; + // + // AreaTextBox + // + AreaTextBox.Location = new Point(224, 147); + AreaTextBox.Name = "AreaTextBox"; + AreaTextBox.Size = new Size(235, 27); + AreaTextBox.TabIndex = 7; + AreaTextBox.Text = "756950"; + // + // PopulationTextBox + // + PopulationTextBox.Location = new Point(224, 191); + PopulationTextBox.Name = "PopulationTextBox"; + PopulationTextBox.Size = new Size(235, 27); + PopulationTextBox.TabIndex = 8; + PopulationTextBox.Text = "19458000"; + // + // CapitalCityTextBox + // + CapitalCityTextBox.Location = new Point(224, 236); + CapitalCityTextBox.Name = "CapitalCityTextBox"; + CapitalCityTextBox.Size = new Size(235, 27); + CapitalCityTextBox.TabIndex = 9; + CapitalCityTextBox.Text = "Santiago"; + // + // CapitalCityPopulationTextBox + // + CapitalCityPopulationTextBox.Location = new Point(224, 277); + CapitalCityPopulationTextBox.Name = "CapitalCityPopulationTextBox"; + CapitalCityPopulationTextBox.Size = new Size(235, 27); + CapitalCityPopulationTextBox.TabIndex = 10; + CapitalCityPopulationTextBox.Text = "6257516"; + // + // label7 + // + label7.AutoSize = true; + label7.Font = new Font("Segoe UI", 13.8F, FontStyle.Regular, GraphicsUnit.Point); + label7.Location = new Point(224, 366); + label7.Name = "label7"; + label7.Size = new Size(317, 31); + label7.TabIndex = 11; + label7.Text = "Kérem, adja meg az adatokat!"; + // + // SaveButton + // + SaveButton.Location = new Point(609, 99); + SaveButton.Name = "SaveButton"; + SaveButton.Size = new Size(92, 71); + SaveButton.TabIndex = 12; + SaveButton.Text = "Mentés"; + SaveButton.UseVisualStyleBackColor = true; + // + // ExitButton + // + ExitButton.Location = new Point(706, 410); + ExitButton.Name = "ExitButton"; + ExitButton.Size = new Size(82, 28); + ExitButton.TabIndex = 13; + ExitButton.Text = "Kilépés"; + ExitButton.UseVisualStyleBackColor = true; + ExitButton.Click += ExitButton_Click; + // + // Form1 + // + AutoScaleDimensions = new SizeF(8F, 20F); + AutoScaleMode = AutoScaleMode.Font; + ClientSize = new Size(800, 450); + Controls.Add(ExitButton); + Controls.Add(SaveButton); + Controls.Add(label7); + Controls.Add(CapitalCityPopulationTextBox); + Controls.Add(CapitalCityTextBox); + Controls.Add(PopulationTextBox); + Controls.Add(AreaTextBox); + Controls.Add(CountryTextBox); + Controls.Add(label6); + Controls.Add(label5); + Controls.Add(label4); + Controls.Add(label3); + Controls.Add(label2); + Controls.Add(label1); + Name = "Form1"; + Text = "Form1"; + ResumeLayout(false); + PerformLayout(); + } + + #endregion + + private Label label1; + private Label label2; + private Label label3; + private Label label4; + private Label label5; + private Label label6; + private TextBox CountryTextBox; + private TextBox AreaTextBox; + private TextBox PopulationTextBox; + private TextBox CapitalCityTextBox; + private TextBox CapitalCityPopulationTextBox; + private Label label7; + private Button SaveButton; + private Button ExitButton; + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.cs new file mode 100644 index 0000000..246fd9a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.cs @@ -0,0 +1,15 @@ +namespace _2024._09._05 +{ + public partial class Form1 : Form + { + public Form1() + { + InitializeComponent(); + } + + private void ExitButton_Click(object sender, EventArgs e) + { + + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.resx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.resx new file mode 100644 index 0000000..af32865 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Form1.resx @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Program.cs new file mode 100644 index 0000000..adf5cb3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._09._05 +{ + internal static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + // To customize application configuration such as set high DPI settings or default font, + // see https://aka.ms/applicationconfiguration. + ApplicationConfiguration.Initialize(); + Application.Run(new Form1()); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json new file mode 100644 index 0000000..5d73f8d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.dgspec.json @@ -0,0 +1,66 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "projectName": "2024. 09. 05", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props new file mode 100644 index 0000000..496e714 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.7.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/2024. 09. 05.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs new file mode 100644 index 0000000..a53f0ab --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 05")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache new file mode 100644 index 0000000..4a580de --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +e37d6ebc7bba2acb34d6d151c81e51ae7478db6c diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..c50f3d7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,17 @@ +is_global = true +build_property.ApplicationManifest = +build_property.StartupObject = +build_property.ApplicationDefaultFont = +build_property.ApplicationHighDpiMode = +build_property.ApplicationUseCompatibleTextRendering = +build_property.ApplicationVisualStyles = +build_property.TargetFramework = net6.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._05 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 05\2024. 09. 05\ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs new file mode 100644 index 0000000..84bbb89 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.GlobalUsings.g.cs @@ -0,0 +1,10 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Drawing; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; +global using global::System.Windows.Forms; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache new file mode 100644 index 0000000..7de1a27 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json new file mode 100644 index 0000000..706cdfa --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json new file mode 100644 index 0000000..5c09524 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/Debug/net6.0-windows/2024. 09. 05.designer.runtimeconfig.json @@ -0,0 +1,22 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "6.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\gamin\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\gamin\\.nuget\\packages" + ], + "configProperties": { + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.assets.json new file mode 100644 index 0000000..9a0defb --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.assets.json @@ -0,0 +1,71 @@ +{ + "version": 3, + "targets": { + "net6.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "projectName": "2024. 09. 05", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + } + }, + "frameworks": { + "net6.0-windows7.0": { + "targetAlias": "net6.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WindowsForms": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\7.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache new file mode 100644 index 0000000..2ddaf37 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 05/2024. 09. 05/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "hH36jF+LED5rSLumNEuhbLZwAzWxIGQKbcGFUdtsiSv1ivydkNd+P3tXWvEdgnCrOeJ9mvP4sErHPJJgvkh2Mg==", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 05\\2024. 09. 05\\2024. 09. 05.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..7ee9ada Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/FileContentIndex/a2134a40-1488-4a97-9231-3ed81951c59c.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/FileContentIndex/a2134a40-1488-4a97-9231-3ed81951c59c.vsidx new file mode 100644 index 0000000..b081eaa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/FileContentIndex/a2134a40-1488-4a97-9231-3ed81951c59c.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.futdcache.v2 new file mode 100644 index 0000000..fc51427 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.suo new file mode 100644 index 0000000..fa7c784 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/DocumentLayout.json new file mode 100644 index 0000000..bf03aae --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/2024. 09. 06/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 06\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{27E26337-C33B-49FF-815D-2046EAC99D80}|2024. 09. 06\\2024. 09. 06.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 06\\2024. 09. 06\\hegyek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{27E26337-C33B-49FF-815D-2046EAC99D80}|2024. 09. 06\\2024. 09. 06.csproj|solutionrelative:2024. 09. 06\\hegyek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{27E26337-C33B-49FF-815D-2046EAC99D80}|2024. 09. 06\\2024. 09. 06.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 06\\2024. 09. 06\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{27E26337-C33B-49FF-815D-2046EAC99D80}|2024. 09. 06\\2024. 09. 06.csproj|solutionrelative:2024. 09. 06\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Hegyek.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 06\\2024. 09. 06\\Hegyek.cs", + "RelativeDocumentMoniker": "2024. 09. 06\\Hegyek.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 06\\2024. 09. 06\\Hegyek.cs", + "RelativeToolTip": "2024. 09. 06\\Hegyek.cs", + "ViewState": "AgIAAHsAAAAAAAAAAAA0wIQAAAAxAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-06T08:00:31.042Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 06\\2024. 09. 06\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 06\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 06\\2024. 09. 06\\Program.cs", + "RelativeToolTip": "2024. 09. 06\\Program.cs", + "ViewState": "AQIAAAAAAAAAAAAAAAAAAA0AAAAeAAAA", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-06T07:58:35.539Z" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v7.bin new file mode 100644 index 0000000..1f7cea2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v9.bin new file mode 100644 index 0000000..9a1a3fc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v7.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v7.bin new file mode 100644 index 0000000..fda1d92 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v7.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v9.bin new file mode 100644 index 0000000..592ad00 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.strings.v9.bin new file mode 100644 index 0000000..de1b386 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/.vs/ProjectEvaluation/2024. 09. 06.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06.sln new file mode 100644 index 0000000..dce04bb --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.7.34024.191 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 06", "2024. 09. 06\2024. 09. 06.csproj", "{27E26337-C33B-49FF-815D-2046EAC99D80}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {27E26337-C33B-49FF-815D-2046EAC99D80}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {27E26337-C33B-49FF-815D-2046EAC99D80}.Debug|Any CPU.Build.0 = Debug|Any CPU + {27E26337-C33B-49FF-815D-2046EAC99D80}.Release|Any CPU.ActiveCfg = Release|Any CPU + {27E26337-C33B-49FF-815D-2046EAC99D80}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {F32F6D86-1B4F-4B4B-9731-B6FC7D13C8A0} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/2024. 09. 06.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/2024. 09. 06.csproj new file mode 100644 index 0000000..607c329 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/2024. 09. 06.csproj @@ -0,0 +1,11 @@ + + + + Exe + net6.0 + _2024._09._06 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Hegyek.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Hegyek.cs new file mode 100644 index 0000000..946f209 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Hegyek.cs @@ -0,0 +1,146 @@ +class Hegyek +{ + public string Hegycsucs { get; private set; } + public string Hegyseg { get; private set; } + public int Magassag { get; private set; } + List hegyekList = new List(); + + public Hegyek(string hegycsucs, string hegyseg, int magassag) + { + Hegycsucs = hegycsucs; + Hegyseg = hegyseg; + Magassag = magassag; + } + + public Hegyek() + { + StreamReader sr = new StreamReader("hegyekMO.txt"); + string[] sor = sr.ReadLine().Split(";"); + + while (!sr.EndOfStream) + { + sor = sr.ReadLine().Split(";"); + Hegyek hegyek = new Hegyek(sor[0], sor[1], Convert.ToInt32(sor[2])); + hegyekList.Add(hegyek); + } + } + + public void Feladat3() + { + Console.WriteLine($"3. feladat: Hegycsúcsok száma: {hegyekList.Count} db"); + } + + public void Feladat4() + { + double magassag = 0; + + foreach (var hegy in hegyekList) + { + magassag += hegy.Magassag; + } + + Console.WriteLine($"4. feladat: Hegycsúcsok átlagos magassága: {Math.Round(magassag / hegyekList.Count, 2)} m"); + } + + public void Feladat5() + { + int legmagasabb = 0; + + foreach (var hegy in hegyekList) + { + if (hegy.Magassag > legmagasabb) + { + legmagasabb = hegy.Magassag; + } + } + + foreach (var hegy in hegyekList) + { + if (hegy.Magassag == legmagasabb) + { + Console.WriteLine("5. feladat: A legmagasabb hegycsúcs adatai:"); + Console.WriteLine($"\tNév: {hegy.Hegycsucs}"); + Console.WriteLine($"\tHegység: {hegy.Hegyseg}"); + Console.WriteLine($"\tNév: {hegy.Magassag} m"); + break; + } + } + } + + public void Feladat6() + { + Console.Write("6. feladat: Kérek egy magasságot: "); + int bekertMagassag = Convert.ToInt32(Console.ReadLine()); + + foreach (var hegy in hegyekList) + { + if (hegy.Magassag > bekertMagassag) + { + Console.WriteLine($"\tVan {bekertMagassag} m-nél magasabb hegycsúcs, a(z) {hegy.Hegycsucs}"); + break; + } + } + + } + + public void Feladat7() + { + int hegycsucsLab3000 = 0; + + foreach (var hegy in hegyekList) + { + if (hegy.Magassag * 3.280839895 > 3000) + { + hegycsucsLab3000++; + } + } + + Console.WriteLine($"7. feladat: 3000 lábnál magasabb hegycsúcsok száma: {hegycsucsLab3000}"); + } + + public void Feladat8() + { + Dictionary statisztika = new Dictionary(); + + foreach (var hegy in hegyekList) + { + if (statisztika.ContainsKey(hegy.Hegyseg)) + { + statisztika[hegy.Hegyseg]++; + } + + else + { + statisztika[hegy.Hegyseg] = 1; + } + } + + Console.WriteLine("8. feladat: Hegység statisztika"); + + foreach (var item in statisztika) + { + Console.WriteLine($"\t{item.Key}: {item.Value} db"); + } + } + + public void Feladat9() + { + StreamWriter sw = new StreamWriter("bukk-videk.txt"); + sw.WriteLine("Hegycsúcs neve;Magasság lábban"); + + foreach (var hegy in hegyekList) + { + if (hegy.Hegyseg.Equals("Bükk-vidék")) + { + sw.WriteLine($"{hegy.Hegycsucs};{Math.Round(hegy.Magassag * 3.280839895, 1)}"); + } + } + + sw.Close(); + } + + public override string ToString() + { + return ""; + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Program.cs new file mode 100644 index 0000000..890c9cd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._09._06 +{ + internal class Program + { + static void Main(string[] args) + { + Hegyek hegyek = new Hegyek(); + hegyek.Feladat3(); + hegyek.Feladat4(); + hegyek.Feladat5(); + hegyek.Feladat6(); + hegyek.Feladat7(); + hegyek.Feladat8(); + hegyek.Feladat9(); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.deps.json new file mode 100644 index 0000000..8e44cf9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v6.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v6.0": { + "2024. 09. 06/1.0.0": { + "runtime": { + "2024. 09. 06.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 06/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.dll new file mode 100644 index 0000000..3efdf3f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.exe new file mode 100644 index 0000000..0479a59 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.pdb new file mode 100644 index 0000000..206faaf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.runtimeconfig.json new file mode 100644 index 0000000..4986d16 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/2024. 09. 06.runtimeconfig.json @@ -0,0 +1,9 @@ +{ + "runtimeOptions": { + "tfm": "net6.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "6.0.0" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/bukk-videk.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/bukk-videk.txt new file mode 100644 index 0000000..cd4b536 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/bukk-videk.txt @@ -0,0 +1,61 @@ +Hegycsúcs neve;Magasság lábban +Bálvány;3136,5 +Büszkés-hegy;3123,4 +Cserepes-kő;2700,1 +Csikorgó;2552,5 +Esztea-fő;2614,8 +Fekete-Sár-bérc;3051,2 +Felső-Borovnyák (2);3057,7 +Felső-Borovnyák (1);3100,4 +Fodor-hegy;3054,5 +Füstös-kő-bérc;2992,1 +Három-kő;2965,9 +Hegyes-kő;2598,4 +Hosszú-bérc;2690,3 +Huta-bérc;3018,4 +Ispán-hegy;2992,1 +Istállós-kő;3143 +Kerek-hegy;2713,3 +Kerek-hegy;2591,9 +Kerek-réti-fő;2887,1 +Kis-kő-hát;3080,7 +Kis-Sár-bérc;3034,8 +Kis-tanya;3005,2 +Kis-Virágos-hegy;2847,8 +Kőris-hegy;3097,1 +Kőrös-bérc;3136,5 +Közép-bérc (1);2647,6 +Közép-bérc (2);2637,8 +Kukocsó-hegy;3087,3 +Küllő-hegy;2949,5 +Leány-hegy;2926,5 +Messzelátó;2805,1 +Nagy-Csipkés-tető;2851 +Nagy-Csipkés-tető (3);2765,7 +Nagy-Dél (1);2693,6 +Nagy-Dél (2);2621,4 +Nagy-Dél (3);2582 +Nagy-Hárs;2755,9 +Nagy-Kopasz;2962,6 +Nagy-kő-hát (1);3103,7 +Nagy-kő-hát (2);3070,9 +Nagy-Kőris;2696,9 +Nyárju-hegy (1);2916,7 +Nyárju-hegy (2);2903,5 +Őr-kő (2);2805,1 +Őr-kő (1);2887,1 +Pes-kő;2811,7 +Sándor-hegy;2854,3 +Semmi-bérc;2972,4 +Szilvási-kő;3152,9 +Tányéros-töbör;3143 +Tar-kő;3116,8 +Vargai-Kurta-bérc (1);2693,6 +Vargai-Kurta-bérc (2);2687 +Veres-Sár-bérc;2992,1 +Virágos-sár (2);3116,8 +Virágos-Sár-hegy;3133,2 +Zsérci-Nagy-Dél (1);2883,9 +Zsérci-Nagy-Dél (2);2877,3 +Zsérci-Nagy-Dél (3);2818,2 +Zsérci-Nagy-Dél (4);2788,7 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/hegyekMo.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/hegyekMo.txt new file mode 100644 index 0000000..d430d3c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/bin/Debug/net6.0/hegyekMo.txt @@ -0,0 +1,101 @@ +Hegycsúcs neve;Hegység;Magasság +Ágasvár;Mátra;789 +Bálvány;Bükk-vidék;956 +Büszkés-hegy;Bükk-vidék;952 +Cserepes-kő;Bükk-vidék;823 +Csikorgó;Bükk-vidék;778 +Csóványos;Börzsöny;938 +Darázs-hegy;Mátra;834 +Esztea-fő;Bükk-vidék;797 +Fekete-Sár-bérc;Bükk-vidék;930 +Felső-Borovnyák (2);Bükk-vidék;932 +Felső-Borovnyák (1);Bükk-vidék;945 +Fodor-hegy;Bükk-vidék;931 +Füstös-kő-bérc;Bükk-vidék;912 +Galya-tető;Mátra;964 +Galya-vár;Mátra;837 +Gergely-hegy;Zempléni-hegység;783 +Győr-hegy;Mátra;831 +Hangyás-bérc (1);Börzsöny;863 +Hangyás-bérc (2);Börzsöny;854 +Hármas-határ-hegy;Kőszegi-hegység;795 +Három-kő;Bükk-vidék;904 +Hegyes-kő;Bükk-vidék;792 +Hermanház-tető;Zempléni-hegység;884 +Hidas-bérc;Mátra;971 +Hosszú-bérc;Bükk-vidék;820 +Huta-bérc;Bükk-vidék;920 +Írott-kő;Kőszegi-hegység;882 +Ispán-hegy;Bükk-vidék;912 +Istállós-kő;Bükk-vidék;958 +Kékes;Mátra;1014 +Kerek-hegy;Bükk-vidék;827 +Kerek-hegy;Bükk-vidék;790 +Kerek-réti-fő;Bükk-vidék;880 +Kis-Átal-kő;Mátra;787 +Kis-kő;Mátra;787 +Kis-kő-hát;Bükk-vidék;939 +Kis-Sár-bérc;Bükk-vidék;925 +Kis-Sas-kő;Mátra;830 +Kis-tanya;Bükk-vidék;916 +Kis-Virágos-hegy;Bükk-vidék;868 +Korom-bérc;Börzsöny;825 +Kőris-hegy;Bükk-vidék;944 +Kőrös-bérc;Bükk-vidék;956 +Köves-orom;Mátra;787 +Közép-bérc (1);Bükk-vidék;807 +Közép-bérc (2);Bükk-vidék;804 +Kukocsó-hegy;Bükk-vidék;941 +Kút-hegy;Mátra;878 +Küllő-hegy;Bükk-vidék;899 +Leány-hegy;Bükk-vidék;892 +Legyendi-galya;Mátra;936 +Magos-fa;Börzsöny;916 +Messzelátó;Bükk-vidék;855 +Mogyorós-orom;Mátra;838 +Muzsla;Mátra;806 +Nagy-Átal-kő;Mátra;823 +Nagy-Csipkés-tető;Bükk-vidék;869 +Nagy-Csipkés-tető (3);Bükk-vidék;843 +Nagy-Dél (1);Bükk-vidék;821 +Nagy-Dél (2);Bükk-vidék;799 +Nagy-Dél (3);Bükk-vidék;787 +Nagy-Hárs;Bükk-vidék;840 +Nagy-Hideg-hegy;Börzsöny;864 +Nagy-Inóc;Börzsöny;826 +Nagy-Kopasz;Bükk-vidék;903 +Nagy-kő-hát (1);Bükk-vidék;946 +Nagy-kő-hát (2);Bükk-vidék;936 +Nagy-Kőris;Bükk-vidék;822 +Nagy-Milic;Zempléni-hegység;895 +Nyárju-hegy (1);Bükk-vidék;889 +Nyárju-hegy (2);Bükk-vidék;885 +Nyesett-vár;Mátra;813 +Őr-kő (2);Bükk-vidék;855 +Őr-kő (1);Bükk-vidék;880 +Pes-kő;Bükk-vidék;857 +Péter hegyese;Mátra;960 +Piszkés-tető;Mátra;944 +Pogányvár;Börzsöny;823 +Remete-hegy;Zempléni-hegység;894 +Sándor-hegy;Bükk-vidék;870 +Sas-kő;Mátra;898 +Semmi-bérc;Bükk-vidék;906 +Som-tető;Mátra;783 +Szilvási-kő;Bükk-vidék;961 +Tányéros-töbör;Bükk-vidék;958 +Tar-kő;Bükk-vidék;950 +Teréz-hegy;Mátra;792 +Tót-hegyes;Mátra;814 +Tölgyes-bérc;Mátra;799 +Vadkert-tető;Mátra;834 +Vargai-Kurta-bérc (1);Bükk-vidék;821 +Vargai-Kurta-bérc (2);Bükk-vidék;819 +Varsa-tető;Börzsöny;871 +Veres-Sár-bérc;Bükk-vidék;912 +Virágos-sár (2);Bükk-vidék;950 +Virágos-Sár-hegy;Bükk-vidék;955 +Zsérci-Nagy-Dél (1);Bükk-vidék;879 +Zsérci-Nagy-Dél (2);Bükk-vidék;877 +Zsérci-Nagy-Dél (3);Bükk-vidék;859 +Zsérci-Nagy-Dél (4);Bükk-vidék;850 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.dgspec.json new file mode 100644 index 0000000..0fb426d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.dgspec.json @@ -0,0 +1,86 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj", + "projectName": "2024. 09. 06", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "downloadDependencies": [ + { + "name": "Microsoft.AspNetCore.App.Ref", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.NETCore.App.Host.win-x64", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.NETCore.App.Ref", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.WindowsDesktop.App.Ref", + "version": "[6.0.33, 6.0.33]" + } + ], + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400\\RuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/2024. 09. 06.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs new file mode 100644 index 0000000..ed92695 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/.NETCoreApp,Version=v6.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v6.0", FrameworkDisplayName = ".NET 6.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfo.cs new file mode 100644 index 0000000..de59c51 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 06")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 06")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 06")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfoInputs.cache new file mode 100644 index 0000000..b8eff73 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +61e5000941210ffdb4be51f6c8b04fd60c4cf83e779f907fc74ec3ced8174327 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..d77418f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net6.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._06 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.assets.cache new file mode 100644 index 0000000..bbe7a23 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..f59c5de --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +0005acdcd01e16ce9e9a04815b137ea547a6f824 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..c210e55 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\bin\Debug\net6.0\2024. 09. 06.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\bin\Debug\net6.0\2024. 09. 06.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\bin\Debug\net6.0\2024. 09. 06.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\bin\Debug\net6.0\2024. 09. 06.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\bin\Debug\net6.0\2024. 09. 06.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\refint\2024. 09. 06.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\2024. 09. 06.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 06\2024. 09. 06\obj\Debug\net6.0\ref\2024. 09. 06.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.dll new file mode 100644 index 0000000..3efdf3f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.genruntimeconfig.cache new file mode 100644 index 0000000..989cea5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.genruntimeconfig.cache @@ -0,0 +1 @@ +bd6047e4b8e3e150f984017be755bfa9ce63abcc diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.pdb new file mode 100644 index 0000000..206faaf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/2024. 09. 06.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/apphost.exe new file mode 100644 index 0000000..0479a59 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/ref/2024. 09. 06.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/ref/2024. 09. 06.dll new file mode 100644 index 0000000..6c60382 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/ref/2024. 09. 06.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/refint/2024. 09. 06.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/refint/2024. 09. 06.dll new file mode 100644 index 0000000..6c60382 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/Debug/net6.0/refint/2024. 09. 06.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.assets.json new file mode 100644 index 0000000..8203bbd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.assets.json @@ -0,0 +1,91 @@ +{ + "version": 3, + "targets": { + "net6.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net6.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj", + "projectName": "2024. 09. 06", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net6.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net6.0": { + "targetAlias": "net6.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "downloadDependencies": [ + { + "name": "Microsoft.AspNetCore.App.Ref", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.NETCore.App.Host.win-x64", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.NETCore.App.Ref", + "version": "[6.0.33, 6.0.33]" + }, + { + "name": "Microsoft.WindowsDesktop.App.Ref", + "version": "[6.0.33, 6.0.33]" + } + ], + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400\\RuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.nuget.cache new file mode 100644 index 0000000..2d7102a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/2024. 09. 06/obj/project.nuget.cache @@ -0,0 +1,13 @@ +{ + "version": 2, + "dgSpecHash": "UX4dp5H382s=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 06\\2024. 09. 06\\2024. 09. 06.csproj", + "expectedPackageFiles": [ + "C:\\Users\\Adam\\.nuget\\packages\\microsoft.windowsdesktop.app.ref\\6.0.33\\microsoft.windowsdesktop.app.ref.6.0.33.nupkg.sha512", + "C:\\Users\\Adam\\.nuget\\packages\\microsoft.netcore.app.ref\\6.0.33\\microsoft.netcore.app.ref.6.0.33.nupkg.sha512", + "C:\\Users\\Adam\\.nuget\\packages\\microsoft.aspnetcore.app.ref\\6.0.33\\microsoft.aspnetcore.app.ref.6.0.33.nupkg.sha512", + "C:\\Users\\Adam\\.nuget\\packages\\microsoft.netcore.app.host.win-x64\\6.0.33\\microsoft.netcore.app.host.win-x64.6.0.33.nupkg.sha512" + ], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/Gyakorlás.pdf b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/Gyakorlás.pdf new file mode 100644 index 0000000..78c37d4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/Gyakorlás.pdf differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/hegyekMo.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/hegyekMo.txt new file mode 100644 index 0000000..d430d3c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 06/Gyakorlás/hegyekMo.txt @@ -0,0 +1,101 @@ +Hegycsúcs neve;Hegység;Magasság +Ágasvár;Mátra;789 +Bálvány;Bükk-vidék;956 +Büszkés-hegy;Bükk-vidék;952 +Cserepes-kő;Bükk-vidék;823 +Csikorgó;Bükk-vidék;778 +Csóványos;Börzsöny;938 +Darázs-hegy;Mátra;834 +Esztea-fő;Bükk-vidék;797 +Fekete-Sár-bérc;Bükk-vidék;930 +Felső-Borovnyák (2);Bükk-vidék;932 +Felső-Borovnyák (1);Bükk-vidék;945 +Fodor-hegy;Bükk-vidék;931 +Füstös-kő-bérc;Bükk-vidék;912 +Galya-tető;Mátra;964 +Galya-vár;Mátra;837 +Gergely-hegy;Zempléni-hegység;783 +Győr-hegy;Mátra;831 +Hangyás-bérc (1);Börzsöny;863 +Hangyás-bérc (2);Börzsöny;854 +Hármas-határ-hegy;Kőszegi-hegység;795 +Három-kő;Bükk-vidék;904 +Hegyes-kő;Bükk-vidék;792 +Hermanház-tető;Zempléni-hegység;884 +Hidas-bérc;Mátra;971 +Hosszú-bérc;Bükk-vidék;820 +Huta-bérc;Bükk-vidék;920 +Írott-kő;Kőszegi-hegység;882 +Ispán-hegy;Bükk-vidék;912 +Istállós-kő;Bükk-vidék;958 +Kékes;Mátra;1014 +Kerek-hegy;Bükk-vidék;827 +Kerek-hegy;Bükk-vidék;790 +Kerek-réti-fő;Bükk-vidék;880 +Kis-Átal-kő;Mátra;787 +Kis-kő;Mátra;787 +Kis-kő-hát;Bükk-vidék;939 +Kis-Sár-bérc;Bükk-vidék;925 +Kis-Sas-kő;Mátra;830 +Kis-tanya;Bükk-vidék;916 +Kis-Virágos-hegy;Bükk-vidék;868 +Korom-bérc;Börzsöny;825 +Kőris-hegy;Bükk-vidék;944 +Kőrös-bérc;Bükk-vidék;956 +Köves-orom;Mátra;787 +Közép-bérc (1);Bükk-vidék;807 +Közép-bérc (2);Bükk-vidék;804 +Kukocsó-hegy;Bükk-vidék;941 +Kút-hegy;Mátra;878 +Küllő-hegy;Bükk-vidék;899 +Leány-hegy;Bükk-vidék;892 +Legyendi-galya;Mátra;936 +Magos-fa;Börzsöny;916 +Messzelátó;Bükk-vidék;855 +Mogyorós-orom;Mátra;838 +Muzsla;Mátra;806 +Nagy-Átal-kő;Mátra;823 +Nagy-Csipkés-tető;Bükk-vidék;869 +Nagy-Csipkés-tető (3);Bükk-vidék;843 +Nagy-Dél (1);Bükk-vidék;821 +Nagy-Dél (2);Bükk-vidék;799 +Nagy-Dél (3);Bükk-vidék;787 +Nagy-Hárs;Bükk-vidék;840 +Nagy-Hideg-hegy;Börzsöny;864 +Nagy-Inóc;Börzsöny;826 +Nagy-Kopasz;Bükk-vidék;903 +Nagy-kő-hát (1);Bükk-vidék;946 +Nagy-kő-hát (2);Bükk-vidék;936 +Nagy-Kőris;Bükk-vidék;822 +Nagy-Milic;Zempléni-hegység;895 +Nyárju-hegy (1);Bükk-vidék;889 +Nyárju-hegy (2);Bükk-vidék;885 +Nyesett-vár;Mátra;813 +Őr-kő (2);Bükk-vidék;855 +Őr-kő (1);Bükk-vidék;880 +Pes-kő;Bükk-vidék;857 +Péter hegyese;Mátra;960 +Piszkés-tető;Mátra;944 +Pogányvár;Börzsöny;823 +Remete-hegy;Zempléni-hegység;894 +Sándor-hegy;Bükk-vidék;870 +Sas-kő;Mátra;898 +Semmi-bérc;Bükk-vidék;906 +Som-tető;Mátra;783 +Szilvási-kő;Bükk-vidék;961 +Tányéros-töbör;Bükk-vidék;958 +Tar-kő;Bükk-vidék;950 +Teréz-hegy;Mátra;792 +Tót-hegyes;Mátra;814 +Tölgyes-bérc;Mátra;799 +Vadkert-tető;Mátra;834 +Vargai-Kurta-bérc (1);Bükk-vidék;821 +Vargai-Kurta-bérc (2);Bükk-vidék;819 +Varsa-tető;Börzsöny;871 +Veres-Sár-bérc;Bükk-vidék;912 +Virágos-sár (2);Bükk-vidék;950 +Virágos-Sár-hegy;Bükk-vidék;955 +Zsérci-Nagy-Dél (1);Bükk-vidék;879 +Zsérci-Nagy-Dél (2);Bükk-vidék;877 +Zsérci-Nagy-Dél (3);Bükk-vidék;859 +Zsérci-Nagy-Dél (4);Bükk-vidék;850 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..91f1988 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/90202256-3a89-482a-94fd-d1c35a97a547.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/90202256-3a89-482a-94fd-d1c35a97a547.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/90202256-3a89-482a-94fd-d1c35a97a547.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/968d6c64-a086-40e1-97e4-165d58c84218.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/968d6c64-a086-40e1-97e4-165d58c84218.vsidx new file mode 100644 index 0000000..3674b94 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/FileContentIndex/968d6c64-a086-40e1-97e4-165d58c84218.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.futdcache.v2 new file mode 100644 index 0000000..3071472 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.suo new file mode 100644 index 0000000..6ddccdc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..f7702f4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.backup.json @@ -0,0 +1,37 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{1095ED91-73D5-4631-99F5-E459A83D9212}|2024. 09. 11\\2024. 09. 11.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 11\\2024. 09. 11\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{1095ED91-73D5-4631-99F5-E459A83D9212}|2024. 09. 11\\2024. 09. 11.csproj|solutionrelative:2024. 09. 11\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\2024. 09. 11\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 11\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\2024. 09. 11\\Program.cs", + "RelativeToolTip": "2024. 09. 11\\Program.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAAAgAAAAwAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-11T10:29:21.029Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.json new file mode 100644 index 0000000..f7702f4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/.vs/2024. 09. 11/v17/DocumentLayout.json @@ -0,0 +1,37 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{1095ED91-73D5-4631-99F5-E459A83D9212}|2024. 09. 11\\2024. 09. 11.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 11\\2024. 09. 11\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{1095ED91-73D5-4631-99F5-E459A83D9212}|2024. 09. 11\\2024. 09. 11.csproj|solutionrelative:2024. 09. 11\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\2024. 09. 11\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 11\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 11\\2024. 09. 11\\Program.cs", + "RelativeToolTip": "2024. 09. 11\\Program.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAAAgAAAAwAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-11T10:29:21.029Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11.sln new file mode 100644 index 0000000..9d3c1b0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 11", "2024. 09. 11\2024. 09. 11.csproj", "{1095ED91-73D5-4631-99F5-E459A83D9212}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {1095ED91-73D5-4631-99F5-E459A83D9212}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {1095ED91-73D5-4631-99F5-E459A83D9212}.Debug|Any CPU.Build.0 = Debug|Any CPU + {1095ED91-73D5-4631-99F5-E459A83D9212}.Release|Any CPU.ActiveCfg = Release|Any CPU + {1095ED91-73D5-4631-99F5-E459A83D9212}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {A3B83911-2A59-457C-A89B-EE0F39F49FC1} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/2024. 09. 11.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/2024. 09. 11.csproj new file mode 100644 index 0000000..6c4f8f6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/2024. 09. 11.csproj @@ -0,0 +1,11 @@ + + + + Exe + net8.0 + _2024._09._11 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/Program.cs new file mode 100644 index 0000000..377b6bd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/Program.cs @@ -0,0 +1,17 @@ +namespace _2024._09._11 +{ + internal class Program + { + static void Main(string[] args) + { + var elemek = new List() { 9, 10, 11, 12, 13, 14, 15, 16, }; + + var eredmeny = elemek.OrderBy(i => i); + + foreach (var item in eredmeny) + { + Console.WriteLine(item); + } + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.deps.json new file mode 100644 index 0000000..03ecc58 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 09. 11/1.0.0": { + "runtime": { + "2024. 09. 11.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 11/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.dll new file mode 100644 index 0000000..ae4fd01 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.exe new file mode 100644 index 0000000..7a93b4f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.pdb new file mode 100644 index 0000000..19f5ecb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.runtimeconfig.json new file mode 100644 index 0000000..becfaea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/bin/Debug/net8.0/2024. 09. 11.runtimeconfig.json @@ -0,0 +1,12 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": false + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d9b055a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.dgspec.json @@ -0,0 +1,68 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj", + "projectName": "2024. 09. 11", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.props new file mode 100644 index 0000000..26ce372 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/2024. 09. 11.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfo.cs new file mode 100644 index 0000000..d09c5a1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 11")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 11")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 11")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfoInputs.cache new file mode 100644 index 0000000..5eff21e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +54f709968a970aee11296426d2f9497651816593584211c1ba053ec5f84e9853 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..46cda61 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._11 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.assets.cache new file mode 100644 index 0000000..af76c7f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..a5e9833 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +10133e68dbd6a39f7ecf863927228a7758c2c38886c0f799e72352d0fdc80f4d diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..55d471d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\bin\Debug\net8.0\2024. 09. 11.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\bin\Debug\net8.0\2024. 09. 11.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\bin\Debug\net8.0\2024. 09. 11.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\bin\Debug\net8.0\2024. 09. 11.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\bin\Debug\net8.0\2024. 09. 11.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\refint\2024. 09. 11.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\2024. 09. 11.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 11\2024. 09. 11\obj\Debug\net8.0\ref\2024. 09. 11.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.dll new file mode 100644 index 0000000..ae4fd01 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.genruntimeconfig.cache new file mode 100644 index 0000000..4c640cf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.genruntimeconfig.cache @@ -0,0 +1 @@ +f310ed07f455dbbff3b9b329c25b17a06533c0746cc6b16d361b6658c1fb76da diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.pdb new file mode 100644 index 0000000..19f5ecb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/2024. 09. 11.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/apphost.exe new file mode 100644 index 0000000..7a93b4f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/ref/2024. 09. 11.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/ref/2024. 09. 11.dll new file mode 100644 index 0000000..586176b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/ref/2024. 09. 11.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/refint/2024. 09. 11.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/refint/2024. 09. 11.dll new file mode 100644 index 0000000..586176b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/Debug/net8.0/refint/2024. 09. 11.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.assets.json new file mode 100644 index 0000000..8a76160 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.assets.json @@ -0,0 +1,73 @@ +{ + "version": 3, + "targets": { + "net8.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj", + "projectName": "2024. 09. 11", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.nuget.cache new file mode 100644 index 0000000..7f9888d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 11/2024. 09. 11/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "l2baCPW7jxY=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 11\\2024. 09. 11\\2024. 09. 11.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..b5c2cc1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/7ae2a99b-3dd9-4c13-9c9c-1935d5eec16f.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/7ae2a99b-3dd9-4c13-9c9c-1935d5eec16f.vsidx new file mode 100644 index 0000000..1e2d61b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/7ae2a99b-3dd9-4c13-9c9c-1935d5eec16f.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/a7f04ba8-549e-4184-9295-ea30e3ec6d92.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/a7f04ba8-549e-4184-9295-ea30e3ec6d92.vsidx new file mode 100644 index 0000000..4266101 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/a7f04ba8-549e-4184-9295-ea30e3ec6d92.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/dcae7f7a-2f72-44fc-b42a-8b2866320d1b.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/dcae7f7a-2f72-44fc-b42a-8b2866320d1b.vsidx new file mode 100644 index 0000000..06e1655 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/FileContentIndex/dcae7f7a-2f72-44fc-b42a-8b2866320d1b.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.futdcache.v2 new file mode 100644 index 0000000..797f334 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.suo new file mode 100644 index 0000000..0dcf493 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..42f4b37 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.backup.json @@ -0,0 +1,68 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\pelda2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\pelda2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\pelda.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\pelda.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Pelda2.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda2.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Pelda2.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda2.cs", + "RelativeToolTip": "2024. 09. 13\\Pelda2.cs", + "ViewState": "AgIAAAYAAAAAAAAAAAAAAAoAAAAUAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T08:53:55.943Z" + }, + { + "$type": "Document", + "DocumentIndex": 2, + "Title": "Pelda.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Pelda.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda.cs", + "RelativeToolTip": "2024. 09. 13\\Pelda.cs", + "ViewState": "AgIAAAUAAAAAAAAAAAAQwBQAAAAAAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T07:58:42.354Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Program.cs", + "RelativeToolTip": "2024. 09. 13\\Program.cs", + "ViewState": "AgIAACIAAAAAAAAAAAA0wDMAAAAiAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T07:56:35.715Z" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.json new file mode 100644 index 0000000..e055120 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/2024. 09. 13/v17/DocumentLayout.json @@ -0,0 +1,69 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\pelda2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\pelda2.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 13\\2024. 09. 13\\pelda.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{25430571-F31F-472E-9CEC-6FE4759D14C8}|2024. 09. 13\\2024. 09. 13.csproj|solutionrelative:2024. 09. 13\\pelda.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Pelda2.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda2.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Pelda2.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda2.cs", + "RelativeToolTip": "2024. 09. 13\\Pelda2.cs", + "ViewState": "AgIAAAYAAAAAAAAAAAAAAAoAAAAUAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T08:53:55.943Z" + }, + { + "$type": "Document", + "DocumentIndex": 2, + "Title": "Pelda.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Pelda.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Pelda.cs", + "RelativeToolTip": "2024. 09. 13\\Pelda.cs", + "ViewState": "AgIAAAUAAAAAAAAAAAAQwBQAAAAAAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T07:58:42.354Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 13\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 13\\2024. 09. 13\\Program.cs", + "RelativeToolTip": "2024. 09. 13\\Program.cs", + "ViewState": "AgIAACgAAAAAAAAAAAA0wDMAAAAiAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-13T07:56:35.715Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.metadata.v9.bin new file mode 100644 index 0000000..9ba459a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.projects.v9.bin new file mode 100644 index 0000000..c311cc7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.strings.v9.bin new file mode 100644 index 0000000..b3ced56 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/.vs/ProjectEvaluation/2024. 09. 13.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13.sln new file mode 100644 index 0000000..b0cb2a5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 13", "2024. 09. 13\2024. 09. 13.csproj", "{25430571-F31F-472E-9CEC-6FE4759D14C8}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {25430571-F31F-472E-9CEC-6FE4759D14C8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {25430571-F31F-472E-9CEC-6FE4759D14C8}.Debug|Any CPU.Build.0 = Debug|Any CPU + {25430571-F31F-472E-9CEC-6FE4759D14C8}.Release|Any CPU.ActiveCfg = Release|Any CPU + {25430571-F31F-472E-9CEC-6FE4759D14C8}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {8A64738C-4CAE-4BAB-B698-7F6020F4883C} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/2024. 09. 13.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/2024. 09. 13.csproj new file mode 100644 index 0000000..82a327b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/2024. 09. 13.csproj @@ -0,0 +1,11 @@ + + + + Exe + net8.0 + _2024._09._13 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda.cs new file mode 100644 index 0000000..67f4fbf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._13 +{ + class Pelda + { + public int X { get; set; } + public int Y { get; set; } + + public Pelda(int x, int y) + { + X = x; + Y = y; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda2.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda2.cs new file mode 100644 index 0000000..d4b4941 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Pelda2.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._13 +{ + class Pelda2 + { + public int Z { get; set; } + public int Y { get; set; } + + public Pelda2(int z, int y) + { + Z = z; + Y = y; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Program.cs new file mode 100644 index 0000000..e7e540c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/Program.cs @@ -0,0 +1,56 @@ +namespace _2024._09._13 +{ + internal class Program + { + static void Main(string[] args) + { + var elemek = new List() + { + new Pelda (33, 11), + new Pelda (88, 12), + new Pelda (44, 11), + new Pelda (7, 12), + new Pelda (9, 11), + + }; + + var elemek2 = new List() + { + new Pelda2 (33, 11), + new Pelda2 (88, 12), + new Pelda2 (44, 11), + new Pelda2 (7, 12), + new Pelda2 (9, 11), + + }; + + var eredmeny2 = elemek + .GroupBy(i => i.Y); + + var eredmeny3 = elemek + .Join(elemek2, i => i.Y, j => j.Y, (i, j) => new + { + X = i.X, + Y = i.Y, + Z = j.Z + }); + + //foreach (var group in eredmeny2) + //{ + //foreach (var item in group) + //{ + //Console.WriteLine($"{item.X}, {item.Y}"); + //} + //} + + //foreach (var item in eredmeny3 ) + //{ + //Console.WriteLine($"{item.X}, {item.Y}, {item.Z}"); + //} + + var test = elemek.Skip(2).Take(3); + Console.WriteLine(test); + + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.deps.json new file mode 100644 index 0000000..3fc798a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 09. 13/1.0.0": { + "runtime": { + "2024. 09. 13.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 13/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.dll new file mode 100644 index 0000000..af3f34e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.exe new file mode 100644 index 0000000..383ed70 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.pdb new file mode 100644 index 0000000..84e60ca Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.runtimeconfig.json new file mode 100644 index 0000000..becfaea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/bin/Debug/net8.0/2024. 09. 13.runtimeconfig.json @@ -0,0 +1,12 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": false + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.dgspec.json new file mode 100644 index 0000000..941f9c8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.dgspec.json @@ -0,0 +1,68 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj", + "projectName": "2024. 09. 13", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.props new file mode 100644 index 0000000..26ce372 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\gamin\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/2024. 09. 13.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfo.cs new file mode 100644 index 0000000..8474802 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 13")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 13")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 13")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfoInputs.cache new file mode 100644 index 0000000..11cced8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +ac3261001b2e4c0549617ba80d70f6bd655617e43807ce33b0eb2cf218f507ce diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..5603e15 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._13 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.assets.cache new file mode 100644 index 0000000..9f71845 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..793045e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +bd7b283118f32a9c0b7a3e0457c73265a3b786e5ea6108eb8f67fd3614042d55 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..5fea8ac --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\bin\Debug\net8.0\2024. 09. 13.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\bin\Debug\net8.0\2024. 09. 13.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\bin\Debug\net8.0\2024. 09. 13.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\bin\Debug\net8.0\2024. 09. 13.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\bin\Debug\net8.0\2024. 09. 13.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\refint\2024. 09. 13.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\2024. 09. 13.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 13\2024. 09. 13\obj\Debug\net8.0\ref\2024. 09. 13.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.dll new file mode 100644 index 0000000..af3f34e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.genruntimeconfig.cache new file mode 100644 index 0000000..a17edc5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.genruntimeconfig.cache @@ -0,0 +1 @@ +6592c30c435e0f61112241528e6ddf402014470268d46d4d2208f6da444e9031 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.pdb new file mode 100644 index 0000000..84e60ca Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/2024. 09. 13.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/apphost.exe new file mode 100644 index 0000000..383ed70 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/ref/2024. 09. 13.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/ref/2024. 09. 13.dll new file mode 100644 index 0000000..4352a51 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/ref/2024. 09. 13.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/refint/2024. 09. 13.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/refint/2024. 09. 13.dll new file mode 100644 index 0000000..4352a51 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/Debug/net8.0/refint/2024. 09. 13.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.assets.json new file mode 100644 index 0000000..142f8dd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.assets.json @@ -0,0 +1,73 @@ +{ + "version": 3, + "targets": { + "net8.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0": [] + }, + "packageFolders": { + "C:\\Users\\gamin\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj", + "projectName": "2024. 09. 13", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj", + "packagesPath": "C:\\Users\\gamin\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\gamin\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.nuget.cache new file mode 100644 index 0000000..04a80d5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 13/2024. 09. 13/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "raY+fZ3RrPg=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 13\\2024. 09. 13\\2024. 09. 13.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..6576455 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3b6a2357-33ae-4939-838e-9ee12f060647.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3b6a2357-33ae-4939-838e-9ee12f060647.vsidx new file mode 100644 index 0000000..517879b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3b6a2357-33ae-4939-838e-9ee12f060647.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3f7dcc4c-aa8e-4b8c-ba48-9e703f8e8bdd.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3f7dcc4c-aa8e-4b8c-ba48-9e703f8e8bdd.vsidx new file mode 100644 index 0000000..e263120 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/3f7dcc4c-aa8e-4b8c-ba48-9e703f8e8bdd.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/5dd2991f-8b1f-4f12-92bf-9ec21e891e13.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/5dd2991f-8b1f-4f12-92bf-9ec21e891e13.vsidx new file mode 100644 index 0000000..6dde0d1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/FileContentIndex/5dd2991f-8b1f-4f12-92bf-9ec21e891e13.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.futdcache.v2 new file mode 100644 index 0000000..12a2dcf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.suo new file mode 100644 index 0000000..3f00e8a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..52c7f36 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.backup.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 19\\2024. 09. 19\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|solutionrelative:2024. 09. 19\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 19\\2024. 09. 19\\termekek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|solutionrelative:2024. 09. 19\\termekek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Termekek.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Termekek.cs", + "RelativeDocumentMoniker": "2024. 09. 19\\Termekek.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Termekek.cs", + "RelativeToolTip": "2024. 09. 19\\Termekek.cs", + "ViewState": "AgIAAAgAAAAAAAAAAIA1wBEAAAAMAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-19T07:20:26.659Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 19\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Program.cs", + "RelativeToolTip": "2024. 09. 19\\Program.cs", + "ViewState": "AgIAACIAAAAAAAAAAAAywC4AAAANAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-19T06:54:22.91Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.json new file mode 100644 index 0000000..eae7720 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/2024. 09. 19/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 19\\2024. 09. 19\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|solutionrelative:2024. 09. 19\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 19\\2024. 09. 19\\termekek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}|2024. 09. 19\\2024. 09. 19.csproj|solutionrelative:2024. 09. 19\\termekek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Termekek.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Termekek.cs", + "RelativeDocumentMoniker": "2024. 09. 19\\Termekek.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Termekek.cs", + "RelativeToolTip": "2024. 09. 19\\Termekek.cs", + "ViewState": "AgIAAAgAAAAAAAAAAIA1wBEAAAAMAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-19T07:20:26.659Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 19\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 19\\2024. 09. 19\\Program.cs", + "RelativeToolTip": "2024. 09. 19\\Program.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAAC4AAAANAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-19T06:54:22.91Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.metadata.v9.bin new file mode 100644 index 0000000..64bd7a1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.projects.v9.bin new file mode 100644 index 0000000..a9cad49 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.strings.v9.bin new file mode 100644 index 0000000..0855880 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/.vs/ProjectEvaluation/2024. 09. 19.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19.sln new file mode 100644 index 0000000..7a37c71 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 19", "2024. 09. 19\2024. 09. 19.csproj", "{8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}.Debug|Any CPU.Build.0 = Debug|Any CPU + {8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}.Release|Any CPU.ActiveCfg = Release|Any CPU + {8A45F795-6F2D-45B4-8A1D-AD4FCDF2AA70}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {71BFE852-B808-4304-B366-0AC48AE220DE} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/2024. 09. 19.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/2024. 09. 19.csproj new file mode 100644 index 0000000..3070a83 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/2024. 09. 19.csproj @@ -0,0 +1,11 @@ + + + + Exe + net8.0 + _2024._09._19 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Alkalmazottak.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Alkalmazottak.cs new file mode 100644 index 0000000..52a474e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Alkalmazottak.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._19 +{ + class Alkalmazottak + { + public string Nev { get; set; } + public int Fizetes { get; set; } + + public Alkalmazottak(string nev, int fizetes) + { + Nev = nev; + Fizetes = fizetes; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Program.cs new file mode 100644 index 0000000..3e3f0c7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Program.cs @@ -0,0 +1,52 @@ +namespace _2024._09._19 +{ + internal class Program + { + static void Main(string[] args) + { + List alkalmazottakLista = new List(); + using (StreamReader sr = new StreamReader("alkalmazottak.txt")) + { + string[] sor = sr.ReadLine().Split(","); + while (!sr.EndOfStream) + { + sor = sr.ReadLine().Split(","); + Alkalmazottak alkalmazottak = new Alkalmazottak(sor[0], int.Parse(sor[1])); + alkalmazottakLista.Add(alkalmazottak); + } + } + + Console.WriteLine($"Az összesített fizetés: {alkalmazottakLista.Sum(i => i.Fizetes)}"); + Console.WriteLine($"Az átlagfizetés: {alkalmazottakLista.Average(i => i.Fizetes)}"); + + List termekekLista = new List(); + + using (StreamReader sr = new StreamReader("termekek.csv")) + { + string[] sor = sr.ReadLine().Split(";"); + while (!sr.EndOfStream) + { + sor = sr.ReadLine().Split(";"); + Termekek termekek = new Termekek(sor); + termekekLista.Add(termekek); + } + } + var osszesTermek = termekekLista.Select(i => i.Nev); + var hanyTermek = termekekLista + .GroupBy(i => i.Kategoria) + .Select(j => new { Ktg = j.Key, Db = j.Count() }); + Console.WriteLine("Az összes termék:"); + foreach (var elem in osszesTermek) + { + Console.WriteLine($"\t{elem}"); + } + + foreach (var elem in hanyTermek) + { + Console.WriteLine($"{elem.Ktg}: {elem.Db}"); + } + Console.WriteLine($"A legolcsóbb termék: {termekekLista.Min(i => i.Ar)} Ft"); + Console.WriteLine($"A legdrágább termék: {termekekLista.Max(i => i.Ar)} Ft"); + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Termekek.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Termekek.cs new file mode 100644 index 0000000..7e37565 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/Termekek.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._19 +{ + class Termekek + { + public string Nev { get; set; } + public string Kategoria { get; set; } + public int Ar { get; set; } + + public Termekek(string[] sor) + { + Nev = sor[0]; + Kategoria = sor[1]; + Ar = int.Parse(sor[2]); + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.deps.json new file mode 100644 index 0000000..2a4f90a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 09. 19/1.0.0": { + "runtime": { + "2024. 09. 19.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 19/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.dll new file mode 100644 index 0000000..8d18c0e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.exe new file mode 100644 index 0000000..a861eb4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.pdb new file mode 100644 index 0000000..752d693 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.runtimeconfig.json new file mode 100644 index 0000000..becfaea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/2024. 09. 19.runtimeconfig.json @@ -0,0 +1,12 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": false + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/alkalmazottak.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/alkalmazottak.txt new file mode 100644 index 0000000..a0a77dd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/alkalmazottak.txt @@ -0,0 +1,18 @@ +Név,Fizetés +Kiss Péter,300000 +Nagy László,400000 +Szabó Erika,350000 +Tóth Gábor,500000 +Molnár András,280000 +Varga Judit,450000 +Farkas Béla,370000 +Balogh Ágnes,330000 +Kovács Dóra,380000 +Boros Anikó,410000 +Lukács Gábor,430000 +Horváth István,295000 +Vörös Anna,310000 +Veres Katalin,470000 +Fekete Csaba,440000 +Fehér Levente,360000 +Simon László,300000 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/termekek.csv b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/termekek.csv new file mode 100644 index 0000000..403cd2d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/bin/Debug/net8.0/termekek.csv @@ -0,0 +1,18 @@ +Név;Kategória;Ár +Laptop;Elektronikai eszközök;900000 +Egér;Elektronikai eszközök;2000 +Szék;Bútorok;50000 +Asztal;Bútorok;150000 +Ceruza;Irodai eszközök;200 +Nyomtató;Elektronikai eszközök;30000 +Toll;Irodai eszközök;300 +Polc;Bútorok;10000 +Lámpa;Bútorok;7000 +Hűtőszekrény;Elektronikai eszközök;120000 +Tűzőgép;Irodai eszközök;800 +Számítógép;Elektronikai eszközök;150000 +Fotel;Bútorok;20000 +Papír;Irodai eszközök;100 +Tányér;Konyhai eszközök;5000 +Bögre;Konyhai eszközök;600 +Serpenyő;Konyhai eszközök;4000 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.dgspec.json new file mode 100644 index 0000000..677601c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.dgspec.json @@ -0,0 +1,68 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj", + "projectName": "2024. 09. 19", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/2024. 09. 19.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfo.cs new file mode 100644 index 0000000..ff5eeb0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 19")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 19")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 19")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfoInputs.cache new file mode 100644 index 0000000..2d7578d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +119e5b97f6302a72082a5019a6d3df3b5792a2286a747d107129dce6fc14fde2 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..f73ef79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._19 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.assets.cache new file mode 100644 index 0000000..584bf3e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..47965b8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +f1f3fe43544ff5f62046539061035b30a08040cec0ecc1d75e47820d79d2969f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..fccf885 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\bin\Debug\net8.0\2024. 09. 19.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\bin\Debug\net8.0\2024. 09. 19.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\bin\Debug\net8.0\2024. 09. 19.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\bin\Debug\net8.0\2024. 09. 19.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\bin\Debug\net8.0\2024. 09. 19.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\refint\2024. 09. 19.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\2024. 09. 19.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 19\2024. 09. 19\obj\Debug\net8.0\ref\2024. 09. 19.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.dll new file mode 100644 index 0000000..8d18c0e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.genruntimeconfig.cache new file mode 100644 index 0000000..86c42a3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.genruntimeconfig.cache @@ -0,0 +1 @@ +751779377822e149beb7990d454881c631021e6692705e5e72f61b267e0e7bfd diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.pdb new file mode 100644 index 0000000..752d693 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/2024. 09. 19.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/apphost.exe new file mode 100644 index 0000000..a861eb4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/ref/2024. 09. 19.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/ref/2024. 09. 19.dll new file mode 100644 index 0000000..8b3511b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/ref/2024. 09. 19.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/refint/2024. 09. 19.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/refint/2024. 09. 19.dll new file mode 100644 index 0000000..8b3511b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/Debug/net8.0/refint/2024. 09. 19.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.assets.json new file mode 100644 index 0000000..33fad9a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.assets.json @@ -0,0 +1,73 @@ +{ + "version": 3, + "targets": { + "net8.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj", + "projectName": "2024. 09. 19", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.nuget.cache new file mode 100644 index 0000000..079cefc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 19/2024. 09. 19/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "dSruerAsvnU=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 19\\2024. 09. 19\\2024. 09. 19.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..26d1368 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/0687a96e-05b9-4705-bf09-70db31a1ad2e.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/0687a96e-05b9-4705-bf09-70db31a1ad2e.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/0687a96e-05b9-4705-bf09-70db31a1ad2e.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/076eb542-add3-489d-8b57-f32b26cda22c.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/076eb542-add3-489d-8b57-f32b26cda22c.vsidx new file mode 100644 index 0000000..f0d4994 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/076eb542-add3-489d-8b57-f32b26cda22c.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/de695f5a-8761-41dd-8f6b-d3db395523a7.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/de695f5a-8761-41dd-8f6b-d3db395523a7.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/FileContentIndex/de695f5a-8761-41dd-8f6b-d3db395523a7.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.futdcache.v2 new file mode 100644 index 0000000..838b9b1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.suo new file mode 100644 index 0000000..0b4e708 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..482f24e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.backup.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 20\\2024. 09. 20\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|solutionrelative:2024. 09. 20\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 20\\2024. 09. 20\\tanulok.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|solutionrelative:2024. 09. 20\\tanulok.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Tanulok.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Tanulok.cs", + "RelativeDocumentMoniker": "2024. 09. 20\\Tanulok.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Tanulok.cs", + "RelativeToolTip": "2024. 09. 20\\Tanulok.cs", + "ViewState": "AgIAAAcAAAAAAAAAAAAQwBAAAAAgAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-20T07:52:29.404Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 20\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Program.cs", + "RelativeToolTip": "2024. 09. 20\\Program.cs", + "ViewState": "AgIAABAAAAAAAAAAAAA0wAkAAAANAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-20T07:51:55.022Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.json new file mode 100644 index 0000000..25436ed --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/2024. 09. 20/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 20\\2024. 09. 20\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|solutionrelative:2024. 09. 20\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 20\\2024. 09. 20\\tanulok.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{412DB1D6-DFB9-4712-934F-EE73F949176D}|2024. 09. 20\\2024. 09. 20.csproj|solutionrelative:2024. 09. 20\\tanulok.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Tanulok.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Tanulok.cs", + "RelativeDocumentMoniker": "2024. 09. 20\\Tanulok.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Tanulok.cs", + "RelativeToolTip": "2024. 09. 20\\Tanulok.cs", + "ViewState": "AgIAAAcAAAAAAAAAAAAQwBAAAAAgAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-20T07:52:29.404Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 20\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 20\\2024. 09. 20\\Program.cs", + "RelativeToolTip": "2024. 09. 20\\Program.cs", + "ViewState": "AgIAAA0AAAAAAAAAAAA0wAkAAAANAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-20T07:51:55.022Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.metadata.v9.bin new file mode 100644 index 0000000..d842426 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.projects.v9.bin new file mode 100644 index 0000000..b3a42c0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.strings.v9.bin new file mode 100644 index 0000000..53a6c68 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/.vs/ProjectEvaluation/2024. 09. 20.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20.sln new file mode 100644 index 0000000..0273819 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 20", "2024. 09. 20\2024. 09. 20.csproj", "{412DB1D6-DFB9-4712-934F-EE73F949176D}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {412DB1D6-DFB9-4712-934F-EE73F949176D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {412DB1D6-DFB9-4712-934F-EE73F949176D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {412DB1D6-DFB9-4712-934F-EE73F949176D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {412DB1D6-DFB9-4712-934F-EE73F949176D}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {26943A30-554F-4CB5-A45D-964145815AD4} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/2024. 09. 20.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/2024. 09. 20.csproj new file mode 100644 index 0000000..763c467 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/2024. 09. 20.csproj @@ -0,0 +1,11 @@ + + + + Exe + net8.0 + _2024._09._20 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Program.cs new file mode 100644 index 0000000..e29072a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Program.cs @@ -0,0 +1,33 @@ +namespace _2024._09._20 +{ + internal class Program + { + static void Main(string[] args) + { + List tanulokLista = new List(); + + using (StreamReader sw = new StreamReader("tanulok.txt")) + { + string[] sor = sw.ReadLine().Split(","); + while (!sw.EndOfStream) + { + sor = sw.ReadLine().Split(","); + Tanulok tanulok = new Tanulok(sor[0], int.Parse(sor[1])); + tanulokLista.Add(tanulok); + } + } + + var mennyi50Felett = tanulokLista.Where(i => i.Eredmeny > 50).Count(); + Console.WriteLine($"Ennyien értek el 50 pont feletti eredményt: {mennyi50Felett}"); + + Console.WriteLine($"A pontszámok átlaga: {Math.Round(tanulokLista.Average(i => i.Eredmeny), 2)}"); + + var rendezes = tanulokLista.OrderByDescending(i => i.Eredmeny).Take(3); + Console.WriteLine("Legjobb 3 tanuló:"); + foreach (var elem in rendezes) + { + Console.WriteLine($"\t{elem.Nev}: {elem.Eredmeny}"); + } + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Tanulok.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Tanulok.cs new file mode 100644 index 0000000..145832b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/Tanulok.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._20 +{ + class Tanulok + { + public string Nev { get; set; } + public int Eredmeny { get; set; } + + public Tanulok(string nev, int eredmeny) + { + Nev = nev; + Eredmeny = eredmeny; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.deps.json new file mode 100644 index 0000000..f3f51e0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 09. 20/1.0.0": { + "runtime": { + "2024. 09. 20.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 20/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.dll new file mode 100644 index 0000000..05c881f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.exe new file mode 100644 index 0000000..22d0a5c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.pdb new file mode 100644 index 0000000..01ddfe9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.runtimeconfig.json new file mode 100644 index 0000000..becfaea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/2024. 09. 20.runtimeconfig.json @@ -0,0 +1,12 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": false + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/tanulok.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/tanulok.txt new file mode 100644 index 0000000..7b048fa --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/bin/Debug/net8.0/tanulok.txt @@ -0,0 +1,18 @@ +Név,Eredmény +Kovács Péter,85 +Szabó Réka,45 +Nagy Ádám,92 +Varga Anna,76 +Tóth Levente,54 +Kiss Gergely,88 +Farkas Boglárka,62 +Molnár Dávid,71 +Horváth Csenge,89 +Fehér Balázs,58 +Kovács László,75 +Varga Tamás,63 +Boros Ákos,91 +Veres Kitti,87 +Szabó Máté,59 +Nagy Vivien,92 +Tóth Emese,73 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.dgspec.json new file mode 100644 index 0000000..e8de7ea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.dgspec.json @@ -0,0 +1,68 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj", + "projectName": "2024. 09. 20", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/2024. 09. 20.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfo.cs new file mode 100644 index 0000000..89ef2bc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 20")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 20")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 20")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfoInputs.cache new file mode 100644 index 0000000..8478eba --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +a56ac8471ab12153bac25425ce2e21834dd41acde5bfa62fd9e089fd01499759 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..9af5ba9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._20 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.assets.cache new file mode 100644 index 0000000..104cfb6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..6c0fe64 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +4129b79750889009152df07d3b22161557e006e5daf3a55251b862dd892a50f7 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..c980064 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\bin\Debug\net8.0\2024. 09. 20.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\bin\Debug\net8.0\2024. 09. 20.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\bin\Debug\net8.0\2024. 09. 20.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\bin\Debug\net8.0\2024. 09. 20.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\bin\Debug\net8.0\2024. 09. 20.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\refint\2024. 09. 20.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\2024. 09. 20.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 20\2024. 09. 20\obj\Debug\net8.0\ref\2024. 09. 20.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.dll new file mode 100644 index 0000000..05c881f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.genruntimeconfig.cache new file mode 100644 index 0000000..2253309 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.genruntimeconfig.cache @@ -0,0 +1 @@ +210519dc4ea811fe4e26b82460400ca1cfd7d954781acd6c33b5de82ffce25b2 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.pdb new file mode 100644 index 0000000..01ddfe9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/2024. 09. 20.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/apphost.exe new file mode 100644 index 0000000..22d0a5c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/ref/2024. 09. 20.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/ref/2024. 09. 20.dll new file mode 100644 index 0000000..87f1930 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/ref/2024. 09. 20.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/refint/2024. 09. 20.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/refint/2024. 09. 20.dll new file mode 100644 index 0000000..87f1930 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/Debug/net8.0/refint/2024. 09. 20.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.assets.json new file mode 100644 index 0000000..fcbbc38 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.assets.json @@ -0,0 +1,73 @@ +{ + "version": 3, + "targets": { + "net8.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj", + "projectName": "2024. 09. 20", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.nuget.cache new file mode 100644 index 0000000..0699c98 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 20/2024. 09. 20/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "yW8p2RXK3JA=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 20\\2024. 09. 20\\2024. 09. 20.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..ffe72c5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/2f931885-9c46-4dd5-8359-6080a55f0447.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/2f931885-9c46-4dd5-8359-6080a55f0447.vsidx new file mode 100644 index 0000000..52fff3c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/2f931885-9c46-4dd5-8359-6080a55f0447.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/36346b6b-5684-40bd-be9c-17252dd5531c.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/36346b6b-5684-40bd-be9c-17252dd5531c.vsidx new file mode 100644 index 0000000..6a8df24 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/FileContentIndex/36346b6b-5684-40bd-be9c-17252dd5531c.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.futdcache.v2 new file mode 100644 index 0000000..6c41a0a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.suo new file mode 100644 index 0000000..8542751 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..1c04217 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.backup.json @@ -0,0 +1,54 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 25\\2024. 09. 25\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|solutionrelative:2024. 09. 25\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 25\\2024. 09. 25\\konyvek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|solutionrelative:2024. 09. 25\\konyvek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Konyvek.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Konyvek.cs", + "RelativeDocumentMoniker": "2024. 09. 25\\Konyvek.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Konyvek.cs", + "RelativeToolTip": "2024. 09. 25\\Konyvek.cs", + "ViewState": "AgIAAAYAAAAAAAAAAAAAABMAAAAJAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-25T09:56:06.516Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 25\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Program.cs", + "RelativeToolTip": "2024. 09. 25\\Program.cs", + "ViewState": "AgIAAA0AAAAAAAAAAAA0wBoAAABMAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-25T09:54:43.672Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.json new file mode 100644 index 0000000..2ee038a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/2024. 09. 25/v17/DocumentLayout.json @@ -0,0 +1,54 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 25\\2024. 09. 25\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|solutionrelative:2024. 09. 25\\program.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 09. 25\\2024. 09. 25\\konyvek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{605E8ED3-B878-4D5C-841A-6F3D53C10B89}|2024. 09. 25\\2024. 09. 25.csproj|solutionrelative:2024. 09. 25\\konyvek.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "Konyvek.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Konyvek.cs", + "RelativeDocumentMoniker": "2024. 09. 25\\Konyvek.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Konyvek.cs", + "RelativeToolTip": "2024. 09. 25\\Konyvek.cs", + "ViewState": "AgIAAAgAAAAAAAAAAAA5wBMAAAAJAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-25T09:56:06.516Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "Program.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Program.cs", + "RelativeDocumentMoniker": "2024. 09. 25\\Program.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 09. 25\\2024. 09. 25\\Program.cs", + "RelativeToolTip": "2024. 09. 25\\Program.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAABgAAABNAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-09-25T09:54:43.672Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.metadata.v9.bin new file mode 100644 index 0000000..e25b8b7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.projects.v9.bin new file mode 100644 index 0000000..2e0a576 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.strings.v9.bin new file mode 100644 index 0000000..6a61a7b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/.vs/ProjectEvaluation/2024. 09. 25.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25.sln new file mode 100644 index 0000000..25f2cb7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 09. 25", "2024. 09. 25\2024. 09. 25.csproj", "{605E8ED3-B878-4D5C-841A-6F3D53C10B89}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {605E8ED3-B878-4D5C-841A-6F3D53C10B89}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {605E8ED3-B878-4D5C-841A-6F3D53C10B89}.Debug|Any CPU.Build.0 = Debug|Any CPU + {605E8ED3-B878-4D5C-841A-6F3D53C10B89}.Release|Any CPU.ActiveCfg = Release|Any CPU + {605E8ED3-B878-4D5C-841A-6F3D53C10B89}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {19CD217B-9988-48A6-94C9-6291D1447F59} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/2024. 09. 25.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/2024. 09. 25.csproj new file mode 100644 index 0000000..cc8cf82 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/2024. 09. 25.csproj @@ -0,0 +1,11 @@ + + + + Exe + net8.0 + _2024._09._25 + enable + enable + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Konyvek.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Konyvek.cs new file mode 100644 index 0000000..976e181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Konyvek.cs @@ -0,0 +1,22 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace _2024._09._25 +{ + class Konyvek + { + public string Cim { get; set; } + public string Szerzo { get; set; } + public int Ar { get; set; } + + public Konyvek(string cim, string szerzo, int ar) + { + Cim = cim; + Szerzo = szerzo; + Ar = ar; + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Program.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Program.cs new file mode 100644 index 0000000..7707eed --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/Program.cs @@ -0,0 +1,35 @@ +namespace _2024._09._25 +{ + internal class Program + { + static void Main(string[] args) + { + List konyvekLista = new List(); + StreamReader sr = new StreamReader("konyvek.csv"); + string[] line = sr.ReadLine().Split(";"); + + while (!sr.EndOfStream) + { + line = sr.ReadLine().Split(";"); + Konyvek konyvek = new Konyvek(line[0], line[1], int.Parse(line[2])); + konyvekLista.Add(konyvek); + } + + var kiiras1 = konyvekLista.Select(i => i.Cim); + foreach (var i in kiiras1) + { + Console.WriteLine(i); + } + + var kiiras2 = konyvekLista.Where(i => i.Ar > 2000).Count(); + Console.WriteLine($"Ennyi 2000 Ft feletti könyv van: {kiiras2} db"); + + var kiiras3 = konyvekLista.OrderByDescending(i => i.Ar).Take(5); + foreach (var i in kiiras3) + { + Console.WriteLine($"Cím: {i.Cim}, szerző: {i.Szerzo}, ár: {i.Ar} Ft"); + } + + } + } +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.deps.json new file mode 100644 index 0000000..83f43ac --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 09. 25/1.0.0": { + "runtime": { + "2024. 09. 25.dll": {} + } + } + } + }, + "libraries": { + "2024. 09. 25/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.dll new file mode 100644 index 0000000..27eb6d9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.exe new file mode 100644 index 0000000..0806ef2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.pdb new file mode 100644 index 0000000..0de1038 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.runtimeconfig.json new file mode 100644 index 0000000..becfaea --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/2024. 09. 25.runtimeconfig.json @@ -0,0 +1,12 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "framework": { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": false + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/konyvek.csv b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/konyvek.csv new file mode 100644 index 0000000..a54e2cd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/bin/Debug/net8.0/konyvek.csv @@ -0,0 +1,17 @@ +Cím;Szerző;Ár +Az arany ember;Jókai Mór;1000 +Egri csillagok;Gárdonyi Géza;1500 +Pál utcai fiúk;Molnár Ferenc;2000 +Tüskevár;Fekete István;2500 +A kőszívű ember fiai;Jókai Mór;3000 +Légy jó mindhalálig;Móricz Zsigmond;1200 +Sorstalanság;Kertész Imre;1800 +Ábel a rengetegben;Tamási Áron;2200 +Rokonok;Móricz Zsigmond;2400 +Az ötödik pecsét;Sánta Ferenc;1400 +Idő van;Örkény István;1600 +A Pál utcai fiúk;Molnár Ferenc;1900 +Csillagok háborúja;Lucas George;2500 +1984;Orwell George;2600 +Száz év magány;Garcia Marquez;2800 +Harry Potter és a bölcsek köve;Rowling J.K.;3500 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.dgspec.json new file mode 100644 index 0000000..27a0507 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.dgspec.json @@ -0,0 +1,68 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj", + "projectName": "2024. 09. 25", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/2024. 09. 25.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfo.cs new file mode 100644 index 0000000..9f537ca --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfo.cs @@ -0,0 +1,23 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 09. 25")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 09. 25")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 09. 25")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfoInputs.cache new file mode 100644 index 0000000..1dcf499 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2a082c4303eb0c820e4d810e1e3b526c52a4fa0dc1db9f72f1c9b23d6c74ab8b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..e895b9c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0 +build_property.TargetPlatformMinVersion = +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._09._25 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GlobalUsings.g.cs new file mode 100644 index 0000000..8578f3d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.GlobalUsings.g.cs @@ -0,0 +1,8 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.IO; +global using global::System.Linq; +global using global::System.Net.Http; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.assets.cache new file mode 100644 index 0000000..c93ad95 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..6e74e22 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +a2bb621b217a9e99ccd121bb9fd2e8eb627fc983d24e7f3378882444ea7f4a29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..0a41b9f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.csproj.FileListAbsolute.txt @@ -0,0 +1,14 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\bin\Debug\net8.0\2024. 09. 25.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\bin\Debug\net8.0\2024. 09. 25.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\bin\Debug\net8.0\2024. 09. 25.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\bin\Debug\net8.0\2024. 09. 25.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\bin\Debug\net8.0\2024. 09. 25.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\refint\2024. 09. 25.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\2024. 09. 25.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 09. 25\2024. 09. 25\obj\Debug\net8.0\ref\2024. 09. 25.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.dll new file mode 100644 index 0000000..27eb6d9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.genruntimeconfig.cache new file mode 100644 index 0000000..f577251 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.genruntimeconfig.cache @@ -0,0 +1 @@ +5a9766901ad52f794ca982cd262c83ae5bb4aad33744d0c808dbd6569a65dbf4 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.pdb new file mode 100644 index 0000000..0de1038 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/2024. 09. 25.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/apphost.exe new file mode 100644 index 0000000..0806ef2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/ref/2024. 09. 25.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/ref/2024. 09. 25.dll new file mode 100644 index 0000000..1a72f61 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/ref/2024. 09. 25.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/refint/2024. 09. 25.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/refint/2024. 09. 25.dll new file mode 100644 index 0000000..1a72f61 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/Debug/net8.0/refint/2024. 09. 25.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.assets.json new file mode 100644 index 0000000..26a4070 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.assets.json @@ -0,0 +1,73 @@ +{ + "version": 3, + "targets": { + "net8.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj", + "projectName": "2024. 09. 25", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0": { + "targetAlias": "net8.0", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.nuget.cache new file mode 100644 index 0000000..100f29d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 09. 25/2024. 09. 25/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "cEVjf4s2DpQ=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 09. 25\\2024. 09. 25\\2024. 09. 25.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..5d6f700 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/15bd4bf3-269a-44e9-a870-000a89ec5500.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/15bd4bf3-269a-44e9-a870-000a89ec5500.vsidx new file mode 100644 index 0000000..e68f34c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/15bd4bf3-269a-44e9-a870-000a89ec5500.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/208958c5-63f7-467f-a87d-689ecff424db.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/208958c5-63f7-467f-a87d-689ecff424db.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/208958c5-63f7-467f-a87d-689ecff424db.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/b9e001de-78ef-40ab-8a75-6dc7ab991acc.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/b9e001de-78ef-40ab-8a75-6dc7ab991acc.vsidx new file mode 100644 index 0000000..83ce46f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/FileContentIndex/b9e001de-78ef-40ab-8a75-6dc7ab991acc.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.futdcache.v2 new file mode 100644 index 0000000..0ab3ea8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.suo new file mode 100644 index 0000000..70dc8b5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..32f4fc7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.backup.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 16\\2024. 10. 16\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|solutionrelative:2024. 10. 16\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 16\\2024. 10. 16\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|solutionrelative:2024. 10. 16\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 16\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 16\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-16T10:44:24.08Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 16\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 16\\MainWindow.xaml.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-16T10:22:15.921Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.json new file mode 100644 index 0000000..32f4fc7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/2024. 10. 16/v17/DocumentLayout.json @@ -0,0 +1,53 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 16\\2024. 10. 16\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|solutionrelative:2024. 10. 16\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 16\\2024. 10. 16\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{9E782DBF-24CF-405D-840A-25A13494AA80}|2024. 10. 16\\2024. 10. 16.csproj|solutionrelative:2024. 10. 16\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 0, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedWidth": 200, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 16\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 16\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-16T10:44:24.08Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 16\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 16\\2024. 10. 16\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 16\\MainWindow.xaml.cs", + "ViewState": "AgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-16T10:22:15.921Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.metadata.v9.bin new file mode 100644 index 0000000..737cca8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.projects.v9.bin new file mode 100644 index 0000000..0bfbf46 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.strings.v9.bin new file mode 100644 index 0000000..468fc9b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/.vs/ProjectEvaluation/2024. 10. 16.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16.sln new file mode 100644 index 0000000..8a17556 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 16", "2024. 10. 16\2024. 10. 16.csproj", "{9E782DBF-24CF-405D-840A-25A13494AA80}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {9E782DBF-24CF-405D-840A-25A13494AA80}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {9E782DBF-24CF-405D-840A-25A13494AA80}.Debug|Any CPU.Build.0 = Debug|Any CPU + {9E782DBF-24CF-405D-840A-25A13494AA80}.Release|Any CPU.ActiveCfg = Release|Any CPU + {9E782DBF-24CF-405D-840A-25A13494AA80}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {B4941C80-0CB8-428B-9CCE-781B12F57A75} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj new file mode 100644 index 0000000..8f6c313 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._10._16 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/2024. 10. 16.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml new file mode 100644 index 0000000..8795ffc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml.cs new file mode 100644 index 0000000..bd0403f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._16 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml new file mode 100644 index 0000000..aaae13e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml @@ -0,0 +1,23 @@ + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml.cs new file mode 100644 index 0000000..056c498 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/MainWindow.xaml.cs @@ -0,0 +1,24 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._16 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.deps.json new file mode 100644 index 0000000..f79931c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 16/1.0.0": { + "runtime": { + "2024. 10. 16.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 16/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.dll new file mode 100644 index 0000000..a42763b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.exe new file mode 100644 index 0000000..cf5d33e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.pdb new file mode 100644 index 0000000..3f3aa99 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/bin/Debug/net8.0-windows/2024. 10. 16.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8d52867 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj", + "projectName": "2024. 10. 16", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/2024. 10. 16.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.assets.cache new file mode 100644 index 0000000..521b154 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..2f9a56f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +371f8b13a10aaeea9e9a14d7822d95706bedb52165b70fa13f146a189aabdd0a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..e3584d8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\bin\Debug\net8.0-windows\2024. 10. 16.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\bin\Debug\net8.0-windows\2024. 10. 16.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\bin\Debug\net8.0-windows\2024. 10. 16.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\bin\Debug\net8.0-windows\2024. 10. 16.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\bin\Debug\net8.0-windows\2024. 10. 16.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\refint\2024. 10. 16.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\2024. 10. 16.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\ref\2024. 10. 16.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.dll new file mode 100644 index 0000000..a42763b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.g.resources new file mode 100644 index 0000000..7c08078 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.genruntimeconfig.cache new file mode 100644 index 0000000..c9cd853 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.genruntimeconfig.cache @@ -0,0 +1 @@ +dec837c34da7d59b03a7c8669d8fcf6f8259d3f79e22c3ebe2041d9e8631226d diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.pdb new file mode 100644 index 0000000..3f3aa99 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.assets.cache new file mode 100644 index 0000000..4ea0082 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_1oqnqasa_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.assets.cache new file mode 100644 index 0000000..75e0345 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_5gxigkbv_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.cache new file mode 100644 index 0000000..bc61de0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 16 + + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\ +_2024._10._16 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\App.xaml +11407045341 + +417649841 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.i.cache new file mode 100644 index 0000000..74c57d0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 16 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\obj\Debug\net8.0-windows\ +_2024._10._16 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\App.xaml +11407045341 + +61561794017 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.lref new file mode 100644 index 0000000..a417bad --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.assets.cache new file mode 100644 index 0000000..54e5596 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_cibvqehe_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.assets.cache new file mode 100644 index 0000000..f3b20a8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_dq321iob_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.assets.cache new file mode 100644 index 0000000..9aa1e6e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_efea5hjd_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.assets.cache new file mode 100644 index 0000000..f0e6d15 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_h4daadh1_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.assets.cache new file mode 100644 index 0000000..0b59fd2 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_keyorm4v_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.assets.cache new file mode 100644 index 0000000..da5c682 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_p3ctsnpk_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.assets.cache new file mode 100644 index 0000000..0374baa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_s2sabnvb_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..31ad03c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 16")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9252890 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +26e093d1c87175bebd17b872bd79dc39d9c539f32b21d8f300a8dccdcec9961b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..0229234 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._16 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 16\2024. 10. 16\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.assets.cache new file mode 100644 index 0000000..566d3c5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/2024. 10. 16_zhqhejfa_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..90f13e2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "BA686A13540B8DFA856EC6A3CBDC26981A8BFACF" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._16; + + +namespace _2024._10._16 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._16.App app = new _2024._10._16.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..90f13e2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "BA686A13540B8DFA856EC6A3CBDC26981A8BFACF" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._16; + + +namespace _2024._10._16 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._16.App app = new _2024._10._16.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..0a1bcd1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..5a55412 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,90 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "5D0E2D8CE8EC9452D98CB3430F3E2A476AD6CB41" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._16; + + +namespace _2024._10._16 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 16 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button nyomoGombStackPanel; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 16;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.nyomoGombStackPanel = ((System.Windows.Controls.Button)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..5a55412 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,90 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "5D0E2D8CE8EC9452D98CB3430F3E2A476AD6CB41" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._16; + + +namespace _2024._10._16 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 16 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button nyomoGombStackPanel; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 16;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.nyomoGombStackPanel = ((System.Windows.Controls.Button)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..cf5d33e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/ref/2024. 10. 16.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/ref/2024. 10. 16.dll new file mode 100644 index 0000000..7f51b78 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/ref/2024. 10. 16.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/refint/2024. 10. 16.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/refint/2024. 10. 16.dll new file mode 100644 index 0000000..7f51b78 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/Debug/net8.0-windows/refint/2024. 10. 16.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.assets.json new file mode 100644 index 0000000..b241275 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj", + "projectName": "2024. 10. 16", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.nuget.cache new file mode 100644 index 0000000..baf483a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "easvOKBXies=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 16\\2024. 10. 16\\2024. 10. 16.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/osz.jpg b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/osz.jpg new file mode 100644 index 0000000..40c6ee1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 16/2024. 10. 16/osz.jpg differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..0ccae03 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/FileContentIndex/88aeae99-de68-42b9-b0d4-f1523528bc56.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/FileContentIndex/88aeae99-de68-42b9-b0d4-f1523528bc56.vsidx new file mode 100644 index 0000000..ea1a787 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/FileContentIndex/88aeae99-de68-42b9-b0d4-f1523528bc56.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.futdcache.v2 new file mode 100644 index 0000000..81f5a67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.suo new file mode 100644 index 0000000..5ee4bd7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..e0aa37d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.backup.json @@ -0,0 +1,67 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 17\\2024. 10. 17\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|solutionrelative:2024. 10. 17\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 17\\2024. 10. 17\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|solutionrelative:2024. 10. 17\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 1, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 17\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml*", + "RelativeToolTip": "2024. 10. 17\\MainWindow.xaml*", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-17T07:44:57.388Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 17\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 17\\MainWindow.xaml.cs", + "ViewState": "AgIAABoAAAAAAAAAAAAywCkAAAAZAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-17T05:53:27.345Z", + "EditorCaption": "" + } + ] + }, + { + "DockedHeight": 61, + "SelectedChildIndex": -1, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.json new file mode 100644 index 0000000..3c04f29 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/2024. 10. 17/v17/DocumentLayout.json @@ -0,0 +1,50 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 17\\2024. 10. 17\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{EB6A7F92-79EC-4845-889F-49026286E4CB}|2024. 10. 17\\2024. 10. 17.csproj|solutionrelative:2024. 10. 17\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 0, + "Children": [ + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 17\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 17\\2024. 10. 17\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 17\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-17T07:44:57.388Z", + "EditorCaption": "" + } + ] + }, + { + "DockedHeight": 61, + "SelectedChildIndex": -1, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.metadata.v9.bin new file mode 100644 index 0000000..38a2ac3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.projects.v9.bin new file mode 100644 index 0000000..bca7ddb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.strings.v9.bin new file mode 100644 index 0000000..8da6e97 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/.vs/ProjectEvaluation/2024. 10. 17.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17.sln new file mode 100644 index 0000000..165fbcf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 17", "2024. 10. 17\2024. 10. 17.csproj", "{EB6A7F92-79EC-4845-889F-49026286E4CB}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {EB6A7F92-79EC-4845-889F-49026286E4CB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {EB6A7F92-79EC-4845-889F-49026286E4CB}.Debug|Any CPU.Build.0 = Debug|Any CPU + {EB6A7F92-79EC-4845-889F-49026286E4CB}.Release|Any CPU.ActiveCfg = Release|Any CPU + {EB6A7F92-79EC-4845-889F-49026286E4CB}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {E549EE40-D3F5-4FE3-AE12-D26927659BFF} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj new file mode 100644 index 0000000..63c83c6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._10._17 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/2024. 10. 17.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml new file mode 100644 index 0000000..66a11ce --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml.cs new file mode 100644 index 0000000..e7d1ad5 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._17 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/MainWindow.xaml new file mode 100644 index 0000000..26ffbed --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 17/2024. 10. 17/MainWindow.xaml @@ -0,0 +1,58 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + Körte + Alma + Szőlő + Narancs + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/MainWindow.xaml.cs new file mode 100644 index 0000000..3becfac --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/MainWindow.xaml.cs @@ -0,0 +1,30 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._18 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + + private void Button_Click(object sender, RoutedEventArgs e) + { + Cimke.Content = "Csá"; + Gomb.Content = "Szia"; + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.deps.json new file mode 100644 index 0000000..a5de4d0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 18/1.0.0": { + "runtime": { + "2024. 10. 18.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 18/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.dll new file mode 100644 index 0000000..129e65b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.exe new file mode 100644 index 0000000..5a06aa4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.pdb new file mode 100644 index 0000000..7b547bd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/bin/Debug/net8.0-windows/2024. 10. 18.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d81ef76 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "projectName": "2024. 10. 18", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d81ef76 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "projectName": "2024. 10. 18", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_14ceh0qa_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d81ef76 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "projectName": "2024. 10. 18", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/2024. 10. 18_tth31nzt_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.assets.cache new file mode 100644 index 0000000..99e4c51 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..1c08925 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +a04905c07f6dcc6af2461e2302610837a36cb2b4c482fc44a8a19aa4835a8aba diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..e11fd83 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\bin\Debug\net8.0-windows\2024. 10. 18.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\bin\Debug\net8.0-windows\2024. 10. 18.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\bin\Debug\net8.0-windows\2024. 10. 18.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\bin\Debug\net8.0-windows\2024. 10. 18.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\bin\Debug\net8.0-windows\2024. 10. 18.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\refint\2024. 10. 18.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\2024. 10. 18.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\ref\2024. 10. 18.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.dll new file mode 100644 index 0000000..129e65b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.g.resources new file mode 100644 index 0000000..fba99ca Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.genruntimeconfig.cache new file mode 100644 index 0000000..9399c9c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.genruntimeconfig.cache @@ -0,0 +1 @@ +408dc2c57db5dc67ff9c0993a64d3dfb3c02253452c8c8f45807f0fca7b19746 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.pdb new file mode 100644 index 0000000..7b547bd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.assets.cache new file mode 100644 index 0000000..e7aeab9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0h3nwkyk_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.assets.cache new file mode 100644 index 0000000..aeb9e51 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_0rnefhne_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.assets.cache new file mode 100644 index 0000000..70d4973 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_14ceh0qa_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.cache new file mode 100644 index 0000000..fb4db70 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 18 + + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\ +_2024._10._18 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\App.xaml +11407045341 + +4-51817005 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.cache new file mode 100644 index 0000000..926892b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 18 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\obj\Debug\net8.0-windows\ +_2024._10._18 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\App.xaml +11407045341 + +61491981081 +198-556154604 +MainWindow.xaml; + +True + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.lref new file mode 100644 index 0000000..1ab06e7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.i.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.lref new file mode 100644 index 0000000..1ab06e7 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.assets.cache new file mode 100644 index 0000000..df93fe3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_aaqyxpky_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.assets.cache new file mode 100644 index 0000000..b7a9d4c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_bgm5dk4m_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.assets.cache new file mode 100644 index 0000000..85b7d99 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ca0xwn5b_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.assets.cache new file mode 100644 index 0000000..496ced7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_febs4ilq_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.assets.cache new file mode 100644 index 0000000..76db5fc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_nh0mdgpl_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.assets.cache new file mode 100644 index 0000000..3186299 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_tth31nzt_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..5039855 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..9137e52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +3fb4a9b9c644810e1340f6b09d7d81fbfb114af8fa67addfe30d461c7da74c26 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..3373c52 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18\2024. 10. 18\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.assets.cache new file mode 100644 index 0000000..c616799 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/2024. 10. 18_ujsze4t4_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..208cfba --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "A609D03BEF5AEE21F42D7E89F3B711EF81B1FF8E" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18; + + +namespace _2024._10._18 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._18.App app = new _2024._10._18.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..208cfba --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "A609D03BEF5AEE21F42D7E89F3B711EF81B1FF8E" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18; + + +namespace _2024._10._18 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._18.App app = new _2024._10._18.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..5bbeeca Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..632ed80 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,124 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "3A208E4E9E6640DD001B65CFB4F512CA80471785" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18; + + +namespace _2024._10._18 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 10 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Label Cimke; + + #line default + #line hidden + + + #line 11 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Gomb; + + #line default + #line hidden + + + #line 12 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Kilepes; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.Cimke = ((System.Windows.Controls.Label)(target)); + return; + case 2: + this.Gomb = ((System.Windows.Controls.Button)(target)); + + #line 11 "..\..\..\MainWindow.xaml" + this.Gomb.Click += new System.Windows.RoutedEventHandler(this.Button_Click); + + #line default + #line hidden + return; + case 3: + this.Kilepes = ((System.Windows.Controls.Button)(target)); + + #line 12 "..\..\..\MainWindow.xaml" + this.Kilepes.Click += new System.Windows.RoutedEventHandler(this.Kilepes_Click); + + #line default + #line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..99170b1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,122 @@ +// Updated by XamlIntelliSenseFileGenerator 2024. 10. 18. 10:04:24 +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "3A208E4E9E6640DD001B65CFB4F512CA80471785" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18; + + +namespace _2024._10._18 +{ + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector + { + + +#line 10 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Label Cimke; + +#line default +#line hidden + + +#line 11 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Gomb; + +#line default +#line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() + { + if (_contentLoaded) + { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18;component/mainwindow.xaml", System.UriKind.Relative); + +#line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + +#line default +#line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) + { + switch (connectionId) + { + case 1: + this.Cimke = ((System.Windows.Controls.Label)(target)); + return; + case 2: + this.Gomb = ((System.Windows.Controls.Button)(target)); + +#line 11 "..\..\..\MainWindow.xaml" + this.Gomb.Click += new System.Windows.RoutedEventHandler(this.Button_Click); + +#line default +#line hidden + return; + case 3: + this.Kilepes = ((System.Windows.Controls.Button)(target)); + +#line 12 "..\..\..\MainWindow.xaml" + this.Kilepes.Click += new System.Windows.RoutedEventHandler(this.Kilepes_Click); + +#line default +#line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..5a06aa4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/ref/2024. 10. 18.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/ref/2024. 10. 18.dll new file mode 100644 index 0000000..7778b71 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/ref/2024. 10. 18.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/refint/2024. 10. 18.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/refint/2024. 10. 18.dll new file mode 100644 index 0000000..7778b71 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/Debug/net8.0-windows/refint/2024. 10. 18.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.assets.json new file mode 100644 index 0000000..99cb436 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "projectName": "2024. 10. 18", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.nuget.cache new file mode 100644 index 0000000..ec63fa1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18/2024. 10. 18/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "y/VA8yB8CEc=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18\\2024. 10. 18\\2024. 10. 18.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..31d7347 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/84689d3e-0ae7-4efd-ba62-0ccd1e91389d.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/84689d3e-0ae7-4efd-ba62-0ccd1e91389d.vsidx new file mode 100644 index 0000000..77d27ed Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/84689d3e-0ae7-4efd-ba62-0ccd1e91389d.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/de3fb650-f320-4222-9d55-b3d9818b3be7.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/de3fb650-f320-4222-9d55-b3d9818b3be7.vsidx new file mode 100644 index 0000000..4deb788 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/FileContentIndex/de3fb650-f320-4222-9d55-b3d9818b3be7.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.futdcache.v2 new file mode 100644 index 0000000..c001e52 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.suo new file mode 100644 index 0000000..917d02d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..74298cb --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.backup.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat1\\2024. 10. 18_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|solutionrelative:2024. 10. 18_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat1\\2024. 10. 18_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|solutionrelative:2024. 10. 18_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat1\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 18_Feladat1\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-18T08:43:32.778Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "ViewState": "AgIAABIAAAAAAAAAAAAqwB8AAAA3AAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-18T08:43:32.641Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.json new file mode 100644 index 0000000..4d633cf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/.vs/2024. 10. 18_Feladat1/v17/DocumentLayout.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat1\\2024. 10. 18_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|solutionrelative:2024. 10. 18_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat1\\2024. 10. 18_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{81745627-E95A-400C-849C-1AE2F717A9BB}|2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj|solutionrelative:2024. 10. 18_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 3, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat1\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 18_Feladat1\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-18T08:43:32.778Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 18_Feladat1\\MainWindow.xaml.cs", + "ViewState": "AgIAABIAAAAAAAAAAAAQwB8AAAA3AAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-18T08:43:32.641Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.sln new file mode 100644 index 0000000..132f540 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 18_Feladat1", "2024. 10. 18_Feladat1\2024. 10. 18_Feladat1.csproj", "{81745627-E95A-400C-849C-1AE2F717A9BB}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {81745627-E95A-400C-849C-1AE2F717A9BB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {81745627-E95A-400C-849C-1AE2F717A9BB}.Debug|Any CPU.Build.0 = Debug|Any CPU + {81745627-E95A-400C-849C-1AE2F717A9BB}.Release|Any CPU.ActiveCfg = Release|Any CPU + {81745627-E95A-400C-849C-1AE2F717A9BB}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {3DE2B4A8-F034-4DEF-8EA7-E1863B082367} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj new file mode 100644 index 0000000..9d7b012 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._10._18_Feladat1 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml new file mode 100644 index 0000000..c806968 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml.cs new file mode 100644 index 0000000..6a7ba55 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._18_Feladat1 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml new file mode 100644 index 0000000..6721c5c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml @@ -0,0 +1,18 @@ + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml.cs new file mode 100644 index 0000000..653ad3b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/MainWindow.xaml.cs @@ -0,0 +1,35 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._18_Feladat1 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + + private void Hozzaadas_Click(object sender, RoutedEventArgs e) + { + Teendok.Items.Add(Teendo.Text); + Teendo.Text = ""; + } + + private void Eltavolitas_Click(object sender, RoutedEventArgs e) + { + Teendok.Items.Remove(Teendok.SelectedItem); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.deps.json new file mode 100644 index 0000000..eeb7131 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 18_Feladat1/1.0.0": { + "runtime": { + "2024. 10. 18_Feladat1.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 18_Feladat1/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll new file mode 100644 index 0000000..2b06f6a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.exe new file mode 100644 index 0000000..77af8dd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb new file mode 100644 index 0000000..f2cd860 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/bin/Debug/net8.0-windows/2024. 10. 18_Feladat1.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.dgspec.json new file mode 100644 index 0000000..4e11658 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj", + "projectName": "2024. 10. 18_Feladat1", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/2024. 10. 18_Feladat1.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.assets.cache new file mode 100644 index 0000000..8a762a4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..6e956e9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +f318b3244c80ce73cc7e4fb26eac4050a0f124f9c51aac11cc2a4be0f2da933e diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..a074213 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\bin\Debug\net8.0-windows\2024. 10. 18_Feladat1.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\bin\Debug\net8.0-windows\2024. 10. 18_Feladat1.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\bin\Debug\net8.0-windows\2024. 10. 18_Feladat1.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\bin\Debug\net8.0-windows\2024. 10. 18_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\bin\Debug\net8.0-windows\2024. 10. 18_Feladat1.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\refint\2024. 10. 18_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\2024. 10. 18_Feladat1.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\ref\2024. 10. 18_Feladat1.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll new file mode 100644 index 0000000..2b06f6a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.g.resources new file mode 100644 index 0000000..609a0b9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.genruntimeconfig.cache new file mode 100644 index 0000000..a7e6d4d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.genruntimeconfig.cache @@ -0,0 +1 @@ +6bbbb1ad7a70fd938b9132f25af7a9093cbad04fd497093b89a8442bd2258f24 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb new file mode 100644 index 0000000..f2cd860 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.assets.cache new file mode 100644 index 0000000..856cb37 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_3xwi5ha3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.assets.cache new file mode 100644 index 0000000..94ea621 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_5qhcviav_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.cache new file mode 100644 index 0000000..3517339 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 18_Feladat1 + + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\ +_2024._10._18_Feladat1 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\App.xaml +11407045341 + +4389842654 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.i.cache new file mode 100644 index 0000000..6042ba6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 18_Feladat1 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\obj\Debug\net8.0-windows\ +_2024._10._18_Feladat1 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\App.xaml +11407045341 + +6-59778433 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.lref new file mode 100644 index 0000000..2bf6c19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.assets.cache new file mode 100644 index 0000000..1780768 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_jjd1d0gg_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.assets.cache new file mode 100644 index 0000000..399409f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_mvfrhv5g_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.assets.cache new file mode 100644 index 0000000..ccebff4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_oxiy50t3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.assets.cache new file mode 100644 index 0000000..a6722b3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_qmzh01s3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.assets.cache new file mode 100644 index 0000000..b08fb8b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_sgoxmmh0_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.assets.cache new file mode 100644 index 0000000..8543bed Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_u1kswy3h_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.assets.cache new file mode 100644 index 0000000..407648c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_us5ikju2_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..4e31f43 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..95a0a2a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +6ed9d86ba9a89a6aa25f46ced17b5cad8ccfcd19927814e8db94a5056881257f diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..eeefab3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat1\2024. 10. 18_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.assets.cache new file mode 100644 index 0000000..ba7351e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/2024. 10. 18_Feladat1_yefwhcgb_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..9ee05eb --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "0E9AFB304015FC5B00E62D8CA63662DDC661D819" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat1; + + +namespace _2024._10._18_Feladat1 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._18_Feladat1.App app = new _2024._10._18_Feladat1.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..9ee05eb --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "0E9AFB304015FC5B00E62D8CA63662DDC661D819" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat1; + + +namespace _2024._10._18_Feladat1 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._18_Feladat1.App app = new _2024._10._18_Feladat1.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..b2ab0f1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..a46ad66 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,135 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "B21EE6FC84A4C2058C48B748A4C54612DEEC0C29" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat1; + + +namespace _2024._10._18_Feladat1 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 12 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Teendo; + + #line default + #line hidden + + + #line 13 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ListBox Teendok; + + #line default + #line hidden + + + #line 14 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Hozzaadas; + + #line default + #line hidden + + + #line 15 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Eltavolitas; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18_Feladat1;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.Teendo = ((System.Windows.Controls.TextBox)(target)); + return; + case 2: + this.Teendok = ((System.Windows.Controls.ListBox)(target)); + return; + case 3: + this.Hozzaadas = ((System.Windows.Controls.Button)(target)); + + #line 14 "..\..\..\MainWindow.xaml" + this.Hozzaadas.Click += new System.Windows.RoutedEventHandler(this.Hozzaadas_Click); + + #line default + #line hidden + return; + case 4: + this.Eltavolitas = ((System.Windows.Controls.Button)(target)); + + #line 15 "..\..\..\MainWindow.xaml" + this.Eltavolitas.Click += new System.Windows.RoutedEventHandler(this.Eltavolitas_Click); + + #line default + #line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..a46ad66 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,135 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "B21EE6FC84A4C2058C48B748A4C54612DEEC0C29" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat1; + + +namespace _2024._10._18_Feladat1 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 12 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Teendo; + + #line default + #line hidden + + + #line 13 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ListBox Teendok; + + #line default + #line hidden + + + #line 14 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Hozzaadas; + + #line default + #line hidden + + + #line 15 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Button Eltavolitas; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18_Feladat1;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.Teendo = ((System.Windows.Controls.TextBox)(target)); + return; + case 2: + this.Teendok = ((System.Windows.Controls.ListBox)(target)); + return; + case 3: + this.Hozzaadas = ((System.Windows.Controls.Button)(target)); + + #line 14 "..\..\..\MainWindow.xaml" + this.Hozzaadas.Click += new System.Windows.RoutedEventHandler(this.Hozzaadas_Click); + + #line default + #line hidden + return; + case 4: + this.Eltavolitas = ((System.Windows.Controls.Button)(target)); + + #line 15 "..\..\..\MainWindow.xaml" + this.Eltavolitas.Click += new System.Windows.RoutedEventHandler(this.Eltavolitas_Click); + + #line default + #line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..77af8dd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat1.dll new file mode 100644 index 0000000..0f5bff0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat1.dll new file mode 100644 index 0000000..0f5bff0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.assets.json new file mode 100644 index 0000000..8d96c0a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj", + "projectName": "2024. 10. 18_Feladat1", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.nuget.cache new file mode 100644 index 0000000..73a07f2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat1/2024. 10. 18_Feladat1/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "jkvYcQmtlPg=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1\\2024. 10. 18_Feladat1.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2.zip b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2.zip new file mode 100644 index 0000000..5d7d663 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2.zip differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..48948c9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/5d0c51f7-9149-4cd6-85a4-5f4da0bba7cc.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/5d0c51f7-9149-4cd6-85a4-5f4da0bba7cc.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/5d0c51f7-9149-4cd6-85a4-5f4da0bba7cc.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/b1429b61-32a7-42e1-a0f4-7d45402f87a8.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/b1429b61-32a7-42e1-a0f4-7d45402f87a8.vsidx new file mode 100644 index 0000000..ee39e66 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/b1429b61-32a7-42e1-a0f4-7d45402f87a8.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/bd377cd5-4e01-4c29-8d08-768471a16889.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/bd377cd5-4e01-4c29-8d08-768471a16889.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/bd377cd5-4e01-4c29-8d08-768471a16889.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/ca5fc258-029f-448b-8ba4-3bbd0dd8d35e.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/ca5fc258-029f-448b-8ba4-3bbd0dd8d35e.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/ca5fc258-029f-448b-8ba4-3bbd0dd8d35e.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/f2dd27be-122a-41ff-b5eb-b75795f94094.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/f2dd27be-122a-41ff-b5eb-b75795f94094.vsidx new file mode 100644 index 0000000..5a34472 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/FileContentIndex/f2dd27be-122a-41ff-b5eb-b75795f94094.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.futdcache.v2 new file mode 100644 index 0000000..a90a2e8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.suo new file mode 100644 index 0000000..36c49cf Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..14ea22d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.backup.json @@ -0,0 +1,57 @@ +{ + "Version": 1, + "WorkspaceRootPath": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\\u00D3rai\\2024. 10. 18_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|d:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\\u00F3rai\\2024. 10. 18_feladat2\\2024. 10. 18_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|solutionrelative:2024. 10. 18_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|d:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\\u00F3rai\\2024. 10. 18_feladat2\\2024. 10. 18_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|solutionrelative:2024. 10. 18_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{b1e99781-ab81-11d0-b683-00aa00a3ee26}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat2\\MainWindow.xaml", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 18_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-18T09:11:12.74Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "D:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "ViewState": "AgIAABgAAAAAAAAAAAAowCUAAADJAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-18T09:11:12.61Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.json new file mode 100644 index 0000000..5bf27d1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/.vs/2024. 10. 18_Feladat2/v17/DocumentLayout.json @@ -0,0 +1,60 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat2\\2024. 10. 18_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|solutionrelative:2024. 10. 18_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 18_feladat2\\2024. 10. 18_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{4871377B-6A0E-4AF6-9945-58FABA876875}|2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj|solutionrelative:2024. 10. 18_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 3, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat2\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 18_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-18T09:11:12.74Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 18_Feladat2\\MainWindow.xaml.cs", + "ViewState": "AgIAABgAAAAAAAAAAAAowCUAAADJAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-18T09:11:12.61Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.sln new file mode 100644 index 0000000..b0fb41f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 18_Feladat2", "2024. 10. 18_Feladat2\2024. 10. 18_Feladat2.csproj", "{4871377B-6A0E-4AF6-9945-58FABA876875}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {4871377B-6A0E-4AF6-9945-58FABA876875}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {4871377B-6A0E-4AF6-9945-58FABA876875}.Debug|Any CPU.Build.0 = Debug|Any CPU + {4871377B-6A0E-4AF6-9945-58FABA876875}.Release|Any CPU.ActiveCfg = Release|Any CPU + {4871377B-6A0E-4AF6-9945-58FABA876875}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {2A3C1A7A-B925-4FCD-A5C2-B5B9A50E926A} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj new file mode 100644 index 0000000..eb6c40c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._10._18_Feladat2 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml new file mode 100644 index 0000000..eaf0c5a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml.cs new file mode 100644 index 0000000..6b8bf0e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._18_Feladat2 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml new file mode 100644 index 0000000..1e5a79e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml.cs new file mode 100644 index 0000000..5898949 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/MainWindow.xaml.cs @@ -0,0 +1,50 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._18_Feladat2 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + + private void Button_Click(object sender, RoutedEventArgs e) + { + Dictionary> d = new Dictionary>() + { + { "EUR", new Dictionary{ { "EUR", 1 }, { "HUF", 400.15 }, { "USD", 1.09 } } }, + { "HUF", new Dictionary{ { "EUR", 0.0025 }, { "HUF", 1 }, { "USD", 0.0027 } } }, + { "USD", new Dictionary{ { "EUR", 0.92 }, { "HUF", 368.18 }, { "USD", 1 } } } + }; + + var fromSelectedItem = (ComboBoxItem)FromCurrency.SelectedItem; + var toSelectedItem = (ComboBoxItem)ToCurrency.SelectedItem; + + if (fromSelectedItem != null && toSelectedItem != null && Mennyiseg.Text != "") + { + Kiiras.Content = $"Az eredmény: {toSelectedItem.Content.ToString()} {(Convert.ToInt32(Mennyiseg.Text) * d[fromSelectedItem.Content.ToString()][toSelectedItem.Content.ToString()]).ToString("#,0.##")}"; + Mennyiseg.Text = ""; + FromCurrency.SelectedItem = null; + ToCurrency.SelectedItem = null; + } + else + { + Kiiras.Content = $"Nincs kiválasztva minden érték!"; + } + + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.deps.json new file mode 100644 index 0000000..8bd176e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 18_Feladat2/1.0.0": { + "runtime": { + "2024. 10. 18_Feladat2.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 18_Feladat2/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll new file mode 100644 index 0000000..aaf335e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.exe new file mode 100644 index 0000000..f19b21e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb new file mode 100644 index 0000000..0692d9f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/bin/Debug/net8.0-windows/2024. 10. 18_Feladat2.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.dgspec.json new file mode 100644 index 0000000..cf4a0c6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "projectName": "2024. 10. 18_Feladat2", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..46c97c3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": {} + }, + "projects": { + "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "projectName": "2024. 10. 18_Feladat2", + "projectPath": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..46c97c3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": {} + }, + "projects": { + "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "projectName": "2024. 10. 18_Feladat2", + "projectPath": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "D:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..817aa31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.assets.cache new file mode 100644 index 0000000..314562d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..f66b7b9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +a480c42a86eae179141a6bcd54c2618611c4b280f2a0297a551d741d56aabf6b diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..6c53a18 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.csproj.FileListAbsolute.txt @@ -0,0 +1,40 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\refint\2024. 10. 18_Feladat2.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\ref\2024. 10. 18_Feladat2.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.exe +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.deps.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.runtimeconfig.json +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\bin\Debug\net8.0-windows\2024. 10. 18_Feladat2.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\MainWindow.g.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\App.g.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2_MarkupCompile.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2_MarkupCompile.lref +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\MainWindow.baml +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.g.resources +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.GeneratedMSBuildEditorConfig.editorconfig +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.AssemblyInfoInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.AssemblyInfo.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.csproj.CoreCompileInputs.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\refint\2024. 10. 18_Feladat2.dll +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.pdb +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\2024. 10. 18_Feladat2.genruntimeconfig.cache +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\ref\2024. 10. 18_Feladat2.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll new file mode 100644 index 0000000..aaf335e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.g.resources new file mode 100644 index 0000000..81be48a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.genruntimeconfig.cache new file mode 100644 index 0000000..20b7de4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.genruntimeconfig.cache @@ -0,0 +1 @@ +102817e93fb2d8a0638a8ea9306da6b573d15b92a0f0d91e42a3422344b80267 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb new file mode 100644 index 0000000..0692d9f Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.assets.cache new file mode 100644 index 0000000..3ff9650 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0hoykpdt_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.assets.cache new file mode 100644 index 0000000..170351d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0lv1c5zk_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.assets.cache new file mode 100644 index 0000000..e38aee8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_0qpj1wtk_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.assets.cache new file mode 100644 index 0000000..c7d1572 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1o3z5cqd_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.assets.cache new file mode 100644 index 0000000..3b4ac90 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_1sulklu3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.assets.cache new file mode 100644 index 0000000..e3efee7 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3ripgxtt_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.assets.cache new file mode 100644 index 0000000..1209ab8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_3rxq04aq_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.assets.cache new file mode 100644 index 0000000..bdc5f5a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_453utqlw_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.cache new file mode 100644 index 0000000..ba11943 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 18_Feladat2 + + +winexe +C# +.cs +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\ +_2024._10._18_Feladat2 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\App.xaml +11407045341 + +4-289699954 +1981124507420 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.i.cache new file mode 100644 index 0000000..3d74389 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 18_Feladat2 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\obj\Debug\net8.0-windows\ +_2024._10._18_Feladat2 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\App.xaml +11407045341 + +6936500015 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.lref new file mode 100644 index 0000000..cedeca1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FD:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.assets.cache new file mode 100644 index 0000000..c06ef10 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_acmmf3dq_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.assets.cache new file mode 100644 index 0000000..877a721 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_af5l2qid_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.assets.cache new file mode 100644 index 0000000..32f40fb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_au3k3r2w_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.assets.cache new file mode 100644 index 0000000..0d1847e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bwuberzy_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.assets.cache new file mode 100644 index 0000000..b4e2441 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_bxhy2kgi_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..817aa31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.assets.cache new file mode 100644 index 0000000..8fe6c33 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dc4czuql_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.assets.cache new file mode 100644 index 0000000..0f8e543 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_dxy33siz_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..817aa31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.assets.cache new file mode 100644 index 0000000..85d478c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_e24y1vb2_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.assets.cache new file mode 100644 index 0000000..3e1474c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ebuuacsz_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.assets.cache new file mode 100644 index 0000000..8b12b2b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ed0eos4a_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.assets.cache new file mode 100644 index 0000000..3997271 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_fhulbr2l_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..817aa31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.assets.cache new file mode 100644 index 0000000..36decea Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_hea2jfr1_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.assets.cache new file mode 100644 index 0000000..4b11e4b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_i23k4t2y_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.assets.cache new file mode 100644 index 0000000..dcaea7a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j2i55pnb_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.assets.cache new file mode 100644 index 0000000..e9e2f75 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_j5g1ouma_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.assets.cache new file mode 100644 index 0000000..5a25f9d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_jgpohj1c_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.assets.cache new file mode 100644 index 0000000..35b79b4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_lfbrlh50_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.assets.cache new file mode 100644 index 0000000..2e341df Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_mx50acyl_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.assets.cache new file mode 100644 index 0000000..9f577bb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_o0leen23_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.assets.cache new file mode 100644 index 0000000..65c57f6 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_q4xlt5rk_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.assets.cache new file mode 100644 index 0000000..fa0edf4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qe41r32t_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.assets.cache new file mode 100644 index 0000000..012b0e5 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_qtpprsuh_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.assets.cache new file mode 100644 index 0000000..9984182 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_r1eojpix_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.assets.cache new file mode 100644 index 0000000..123c036 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_spol1zef_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.assets.cache new file mode 100644 index 0000000..1e08607 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_sunkdwdu_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.assets.cache new file mode 100644 index 0000000..7d90718 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_szvliafy_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.assets.cache new file mode 100644 index 0000000..b8292b8 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_u2ydvry3_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.assets.cache new file mode 100644 index 0000000..ec01fe0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_um31hzhn_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.assets.cache new file mode 100644 index 0000000..d2065d1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_vdi3pqlv_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.assets.cache new file mode 100644 index 0000000..f366a2a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_w3foja33_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.assets.cache new file mode 100644 index 0000000..fd5607e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wefoqoqc_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.assets.cache new file mode 100644 index 0000000..7662398 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wehc4c2p_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..817aa31 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.assets.cache new file mode 100644 index 0000000..7f6a381 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_wmk4jgr4_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.assets.cache new file mode 100644 index 0000000..e5a1dd4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_xr2ljfeg_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.assets.cache new file mode 100644 index 0000000..df5446b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_ygkzs34p_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..030e463 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 18_Feladat2")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..56c5a46 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +9a1876b709c41dced26d637d74631d40291cef2f15fcc9dd5eca90ed0366faa9 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..cb0f501 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._18_Feladat2 +build_property.ProjectDir = D:\Suli\13.b\Programozás (Tusjak Brigitta)\Órai\2024. 10. 18_Feladat2\2024. 10. 18_Feladat2\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.assets.cache new file mode 100644 index 0000000..768c99c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/2024. 10. 18_Feladat2_zxrne1fd_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..90fe097 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "890668EB98C185BFB181300D9A68A43F75BC59F4" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat2; + + +namespace _2024._10._18_Feladat2 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.10.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.10.0")] + public static void Main() { + _2024._10._18_Feladat2.App app = new _2024._10._18_Feladat2.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..33feebf --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "890668EB98C185BFB181300D9A68A43F75BC59F4" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat2; + + +namespace _2024._10._18_Feladat2 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._18_Feladat2.App app = new _2024._10._18_Feladat2.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..fe714bb Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..452d12f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,131 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "D4FD7274F095F4571733AFE8D90404FC348E19F0" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat2; + + +namespace _2024._10._18_Feladat2 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 14 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox FromCurrency; + + #line default + #line hidden + + + #line 22 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox ToCurrency; + + #line default + #line hidden + + + #line 30 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Mennyiseg; + + #line default + #line hidden + + + #line 33 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Label Kiiras; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.10.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18_Feladat2;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.10.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.FromCurrency = ((System.Windows.Controls.ComboBox)(target)); + return; + case 2: + this.ToCurrency = ((System.Windows.Controls.ComboBox)(target)); + return; + case 3: + this.Mennyiseg = ((System.Windows.Controls.TextBox)(target)); + return; + case 4: + + #line 32 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.Button)(target)).Click += new System.Windows.RoutedEventHandler(this.Button_Click); + + #line default + #line hidden + return; + case 5: + this.Kiiras = ((System.Windows.Controls.Label)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..93fb9a0 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,131 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "D4FD7274F095F4571733AFE8D90404FC348E19F0" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._18_Feladat2; + + +namespace _2024._10._18_Feladat2 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 14 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox FromCurrency; + + #line default + #line hidden + + + #line 22 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.ComboBox ToCurrency; + + #line default + #line hidden + + + #line 30 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.TextBox Mennyiseg; + + #line default + #line hidden + + + #line 33 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Label Kiiras; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 18_Feladat2;V1.0.0.0;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.FromCurrency = ((System.Windows.Controls.ComboBox)(target)); + return; + case 2: + this.ToCurrency = ((System.Windows.Controls.ComboBox)(target)); + return; + case 3: + this.Mennyiseg = ((System.Windows.Controls.TextBox)(target)); + return; + case 4: + + #line 32 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.Button)(target)).Click += new System.Windows.RoutedEventHandler(this.Button_Click); + + #line default + #line hidden + return; + case 5: + this.Kiiras = ((System.Windows.Controls.Label)(target)); + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..f19b21e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat2.dll new file mode 100644 index 0000000..45b9de1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/ref/2024. 10. 18_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat2.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat2.dll new file mode 100644 index 0000000..45b9de1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/Debug/net8.0-windows/refint/2024. 10. 18_Feladat2.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.assets.json new file mode 100644 index 0000000..17b000e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "projectName": "2024. 10. 18_Feladat2", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.nuget.cache new file mode 100644 index 0000000..59c3213 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 18_Feladat2/2024. 10. 18_Feladat2/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "30C3ls3Qb4E=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2\\2024. 10. 18_Feladat2.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..78d9f8e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/2547c7a3-d40a-405d-840c-0f09eb86c17a.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/2547c7a3-d40a-405d-840c-0f09eb86c17a.vsidx new file mode 100644 index 0000000..c4892dd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/2547c7a3-d40a-405d-840c-0f09eb86c17a.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/354bb96e-2a6c-4a6a-938e-9e912d5cddcf.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/354bb96e-2a6c-4a6a-938e-9e912d5cddcf.vsidx new file mode 100644 index 0000000..420514b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/354bb96e-2a6c-4a6a-938e-9e912d5cddcf.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/dd1dfe64-15ee-4e17-a776-11955c8f20b8.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/dd1dfe64-15ee-4e17-a776-11955c8f20b8.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/FileContentIndex/dd1dfe64-15ee-4e17-a776-11955c8f20b8.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.futdcache.v2 new file mode 100644 index 0000000..c5014aa Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.suo new file mode 100644 index 0000000..1b99d11 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..088edec --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.backup.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24\\2024. 10. 24\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|solutionrelative:2024. 10. 24\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24\\2024. 10. 24\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|solutionrelative:2024. 10. 24\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T06:02:15.493Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 24\\MainWindow.xaml.cs", + "ViewState": "AgIAABMAAAAAAAAAAAAIwBcAAAAWAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T06:02:14.146Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.json new file mode 100644 index 0000000..088edec --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/.vs/2024. 10. 24/v17/DocumentLayout.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24\\2024. 10. 24\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|solutionrelative:2024. 10. 24\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24\\2024. 10. 24\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}|2024. 10. 24\\2024. 10. 24.csproj|solutionrelative:2024. 10. 24\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T06:02:15.493Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24\\2024. 10. 24\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 24\\MainWindow.xaml.cs", + "ViewState": "AgIAABMAAAAAAAAAAAAIwBcAAAAWAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T06:02:14.146Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24.sln new file mode 100644 index 0000000..686c627 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 24", "2024. 10. 24\2024. 10. 24.csproj", "{E549C5EE-798C-44FB-A2A3-DD7E52FFA917}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {E549C5EE-798C-44FB-A2A3-DD7E52FFA917}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E549C5EE-798C-44FB-A2A3-DD7E52FFA917}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E549C5EE-798C-44FB-A2A3-DD7E52FFA917}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E549C5EE-798C-44FB-A2A3-DD7E52FFA917}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {DCC00770-11BB-4574-AABE-ABB1C4E702E8} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj new file mode 100644 index 0000000..ff35e70 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj @@ -0,0 +1,12 @@ + + + + WinExe + net8.0-windows + _2024._10._24 + enable + enable + true + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/2024. 10. 24.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml new file mode 100644 index 0000000..c019724 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml.cs new file mode 100644 index 0000000..e087d90 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._24 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml new file mode 100644 index 0000000..1948ee9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + Új dokumentum + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml.cs new file mode 100644 index 0000000..6cb4828 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/MainWindow.xaml.cs @@ -0,0 +1,34 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._24 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + + private void Kilepes_Click(object sender, RoutedEventArgs e) + { + Application.Current.Shutdown(); + } + + private void Programrol_Click(object sender, RoutedEventArgs e) + { + MessageBox.Show("Programozási technikák"); + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.deps.json new file mode 100644 index 0000000..4a43b4a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 24/1.0.0": { + "runtime": { + "2024. 10. 24.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 24/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.dll new file mode 100644 index 0000000..c8d6392 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.exe new file mode 100644 index 0000000..6f6d051 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.pdb new file mode 100644 index 0000000..88cbfe0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/bin/Debug/net8.0-windows/2024. 10. 24.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/lion.jpg b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/lion.jpg new file mode 100644 index 0000000..9f0fda1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/lion.jpg differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8539485 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "projectName": "2024. 10. 24", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8539485 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "projectName": "2024. 10. 24", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_5tsiymhy_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.dgspec.json new file mode 100644 index 0000000..8539485 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "projectName": "2024. 10. 24", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/2024. 10. 24_ejuhnox4_wpftmp.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.assets.cache new file mode 100644 index 0000000..a2ab78a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..9bdf0ca --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +2b4a91885fb27cd75775b7ec97a13cb5836045f0f2026675d4e9968a42b6f336 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..60d9d58 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\bin\Debug\net8.0-windows\2024. 10. 24.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\bin\Debug\net8.0-windows\2024. 10. 24.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\bin\Debug\net8.0-windows\2024. 10. 24.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\bin\Debug\net8.0-windows\2024. 10. 24.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\bin\Debug\net8.0-windows\2024. 10. 24.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\refint\2024. 10. 24.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\2024. 10. 24.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\ref\2024. 10. 24.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.dll new file mode 100644 index 0000000..c8d6392 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.g.resources new file mode 100644 index 0000000..6528cc3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.genruntimeconfig.cache new file mode 100644 index 0000000..be25c3b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.genruntimeconfig.cache @@ -0,0 +1 @@ +2216e0c62b9b68ef5f7986eea7244b2f0a875d0f1af0bd7252709b87ec428ace diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.pdb new file mode 100644 index 0000000..88cbfe0 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.assets.cache new file mode 100644 index 0000000..84c81ec Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_1kf5xigi_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.assets.cache new file mode 100644 index 0000000..6bcb6ce Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_2oiemi1g_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.assets.cache new file mode 100644 index 0000000..aa68a67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_5tsiymhy_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.cache new file mode 100644 index 0000000..61fcb98 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 24 + + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\ +_2024._10._24 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\App.xaml +11407045341 + +4226144111 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.i.cache new file mode 100644 index 0000000..4c97b7b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 24 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\obj\Debug\net8.0-windows\ +_2024._10._24 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\App.xaml +11407045341 + +6-306504842 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.lref new file mode 100644 index 0000000..3ad8a63 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.assets.cache new file mode 100644 index 0000000..3250a90 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_a0xbcy2i_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.assets.cache new file mode 100644 index 0000000..4dbecc9 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_ejuhnox4_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.assets.cache new file mode 100644 index 0000000..603bb01 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_kqyrrmse_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.assets.cache new file mode 100644 index 0000000..fb532b3 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_rgmycv2m_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.assets.cache new file mode 100644 index 0000000..8c48ed4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_s0ig1ebl_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.assets.cache new file mode 100644 index 0000000..fb4e18b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_und4r4ni_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.assets.cache new file mode 100644 index 0000000..7afa892 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_z2z3skiy_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..c9d4e1e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..02c2197 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +2dfff5353ee771a2df3b133f0d095e288674a54af55bdf548dc07a82754ff82a diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..dd6ecc3 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24\2024. 10. 24\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.assets.cache new file mode 100644 index 0000000..d96410a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/2024. 10. 24_zqbrrgpo_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..e6bebd8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "50600EE370C4138320872510D73601C0FBEB3C77" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24; + + +namespace _2024._10._24 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._24.App app = new _2024._10._24.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..e6bebd8 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "50600EE370C4138320872510D73601C0FBEB3C77" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24; + + +namespace _2024._10._24 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._24.App app = new _2024._10._24.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..7b1943c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..fb0a817 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,106 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "D1AABA5051E79A3A6E15DEDEFFB8DA3E21133EE4" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24; + + +namespace _2024._10._24 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 10 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Slider csuszka1; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 24;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.csuszka1 = ((System.Windows.Controls.Slider)(target)); + return; + case 2: + + #line 49 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.MenuItem)(target)).Click += new System.Windows.RoutedEventHandler(this.Kilepes_Click); + + #line default + #line hidden + return; + case 3: + + #line 58 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.MenuItem)(target)).Click += new System.Windows.RoutedEventHandler(this.Programrol_Click); + + #line default + #line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..fb0a817 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,106 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "D1AABA5051E79A3A6E15DEDEFFB8DA3E21133EE4" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24; + + +namespace _2024._10._24 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + + #line 10 "..\..\..\MainWindow.xaml" + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1823:AvoidUnusedPrivateFields")] + internal System.Windows.Controls.Slider csuszka1; + + #line default + #line hidden + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 24;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + switch (connectionId) + { + case 1: + this.csuszka1 = ((System.Windows.Controls.Slider)(target)); + return; + case 2: + + #line 49 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.MenuItem)(target)).Click += new System.Windows.RoutedEventHandler(this.Kilepes_Click); + + #line default + #line hidden + return; + case 3: + + #line 58 "..\..\..\MainWindow.xaml" + ((System.Windows.Controls.MenuItem)(target)).Click += new System.Windows.RoutedEventHandler(this.Programrol_Click); + + #line default + #line hidden + return; + } + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..6f6d051 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/ref/2024. 10. 24.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/ref/2024. 10. 24.dll new file mode 100644 index 0000000..affaa52 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/ref/2024. 10. 24.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/refint/2024. 10. 24.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/refint/2024. 10. 24.dll new file mode 100644 index 0000000..affaa52 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/Debug/net8.0-windows/refint/2024. 10. 24.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.assets.json new file mode 100644 index 0000000..db719e2 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "projectName": "2024. 10. 24", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.nuget.cache new file mode 100644 index 0000000..2f3967d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24/2024. 10. 24/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "qsYvIP7PcG8=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24\\2024. 10. 24\\2024. 10. 24.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..850e261 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/3987d3ba-2d4d-4a5e-9f96-fb0d0c8bd85a.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/3987d3ba-2d4d-4a5e-9f96-fb0d0c8bd85a.vsidx new file mode 100644 index 0000000..481cc6a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/3987d3ba-2d4d-4a5e-9f96-fb0d0c8bd85a.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/4c206328-9c53-40cf-bce2-fb2609197245.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/4c206328-9c53-40cf-bce2-fb2609197245.vsidx new file mode 100644 index 0000000..2438d05 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/4c206328-9c53-40cf-bce2-fb2609197245.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/5971469b-d3c4-4919-99c3-9f98d2450350.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/5971469b-d3c4-4919-99c3-9f98d2450350.vsidx new file mode 100644 index 0000000..18065d1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/5971469b-d3c4-4919-99c3-9f98d2450350.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/8af6a714-53b4-41ac-bc55-ea34d189534a.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/8af6a714-53b4-41ac-bc55-ea34d189534a.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/8af6a714-53b4-41ac-bc55-ea34d189534a.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/f184c8af-65bb-4850-8691-1d3e2ba85696.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/f184c8af-65bb-4850-8691-1d3e2ba85696.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/FileContentIndex/f184c8af-65bb-4850-8691-1d3e2ba85696.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.futdcache.v2 new file mode 100644 index 0000000..c08e80a Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.suo new file mode 100644 index 0000000..9efa4fd Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..3ed7505 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.backup.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat1\\2024. 10. 24_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|solutionrelative:2024. 10. 24_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + }, + { + "AbsoluteMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat1\\2024. 10. 24_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|solutionrelative:2024. 10. 24_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 2, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat1\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24_Feladat1\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T07:04:30.567Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "ViewState": "AgIAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T07:04:30.425Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.json new file mode 100644 index 0000000..fecda58 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/2024. 10. 24_Feladat1/v17/DocumentLayout.json @@ -0,0 +1,61 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat1\\2024. 10. 24_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|solutionrelative:2024. 10. 24_feladat1\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat1\\2024. 10. 24_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{031BA684-8860-43DD-9E99-29D4ACFD168B}|2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj|solutionrelative:2024. 10. 24_feladat1\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 3, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat1\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24_Feladat1\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T07:04:30.567Z", + "EditorCaption": "" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 24_Feladat1\\MainWindow.xaml.cs", + "ViewState": "AgIAAAwAAAAAAAAAAAAAABkAAAAMAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T07:04:30.425Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.metadata.v9.bin new file mode 100644 index 0000000..126d75c Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.projects.v9.bin new file mode 100644 index 0000000..3165b45 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.strings.v9.bin new file mode 100644 index 0000000..f438e82 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/.vs/ProjectEvaluation/2024. 10. 24_feladat1.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.sln new file mode 100644 index 0000000..c68dec4 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 24_Feladat1", "2024. 10. 24_Feladat1\2024. 10. 24_Feladat1.csproj", "{031BA684-8860-43DD-9E99-29D4ACFD168B}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {031BA684-8860-43DD-9E99-29D4ACFD168B}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {031BA684-8860-43DD-9E99-29D4ACFD168B}.Debug|Any CPU.Build.0 = Debug|Any CPU + {031BA684-8860-43DD-9E99-29D4ACFD168B}.Release|Any CPU.ActiveCfg = Release|Any CPU + {031BA684-8860-43DD-9E99-29D4ACFD168B}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {9AF9718D-6B4B-4D81-88F7-BA7C173E6810} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj new file mode 100644 index 0000000..844eb5b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj @@ -0,0 +1,20 @@ + + + + WinExe + net8.0-windows + _2024._10._24_Feladat1 + enable + enable + true + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml new file mode 100644 index 0000000..97edb9f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml @@ -0,0 +1,8 @@ + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml.cs new file mode 100644 index 0000000..2ba4269 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._24_Feladat1 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml new file mode 100644 index 0000000..5f99610 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml @@ -0,0 +1,17 @@ + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml.cs new file mode 100644 index 0000000..bfbaf19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/MainWindow.xaml.cs @@ -0,0 +1,29 @@ +using System.Text; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace _2024._10._24_Feladat1 +{ + /// + /// Interaction logic for MainWindow.xaml + /// + public partial class MainWindow : Window + { + public MainWindow() + { + InitializeComponent(); + } + + private void Slider_ValueChanged(object sender, RoutedEventArgs e) + { + + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.deps.json new file mode 100644 index 0000000..72b871d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.deps.json @@ -0,0 +1,23 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": { + "2024. 10. 24_Feladat1/1.0.0": { + "runtime": { + "2024. 10. 24_Feladat1.dll": {} + } + } + } + }, + "libraries": { + "2024. 10. 24_Feladat1/1.0.0": { + "type": "project", + "serviceable": false, + "sha512": "" + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll new file mode 100644 index 0000000..0ae3691 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.exe new file mode 100644 index 0000000..9c2419e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb new file mode 100644 index 0000000..0af0e7d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.runtimeconfig.json new file mode 100644 index 0000000..1dc0145 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/2024. 10. 24_Feladat1.runtimeconfig.json @@ -0,0 +1,18 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/lion.jpg b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/lion.jpg new file mode 100644 index 0000000..9f0fda1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/bin/Debug/net8.0-windows/lion.jpg differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/lion.jpg b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/lion.jpg new file mode 100644 index 0000000..9f0fda1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/lion.jpg differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.dgspec.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.dgspec.json new file mode 100644 index 0000000..d1f055b --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.dgspec.json @@ -0,0 +1,71 @@ +{ + "format": 1, + "restore": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj": {} + }, + "projects": { + "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj", + "projectName": "2024. 10. 24_Feladat1", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.props b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.props new file mode 100644 index 0000000..dd3a5ee --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.props @@ -0,0 +1,15 @@ + + + + True + NuGet + $(MSBuildThisFileDirectory)project.assets.json + $(UserProfile)\.nuget\packages\ + C:\Users\Adam\.nuget\packages\ + PackageReference + 6.11.0 + + + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.targets b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.targets new file mode 100644 index 0000000..3dc06ef --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/2024. 10. 24_Feladat1.csproj.nuget.g.targets @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs new file mode 100644 index 0000000..2217181 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/.NETCoreApp,Version=v8.0.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETCoreApp,Version=v8.0", FrameworkDisplayName = ".NET 8.0")] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.assets.cache new file mode 100644 index 0000000..44f7355 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.CoreCompileInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.CoreCompileInputs.cache new file mode 100644 index 0000000..8273408 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.CoreCompileInputs.cache @@ -0,0 +1 @@ +e07f70d24754058904b371eee333bc48d2790c34c30dff2151a158ac16071768 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.FileListAbsolute.txt b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..12c50da --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.csproj.FileListAbsolute.txt @@ -0,0 +1,20 @@ +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\bin\Debug\net8.0-windows\2024. 10. 24_Feladat1.exe +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\bin\Debug\net8.0-windows\2024. 10. 24_Feladat1.deps.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\bin\Debug\net8.0-windows\2024. 10. 24_Feladat1.runtimeconfig.json +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\bin\Debug\net8.0-windows\2024. 10. 24_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\bin\Debug\net8.0-windows\2024. 10. 24_Feladat1.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\MainWindow.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\App.g.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1_MarkupCompile.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1_MarkupCompile.lref +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\MainWindow.baml +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.g.resources +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.GeneratedMSBuildEditorConfig.editorconfig +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.AssemblyInfoInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.AssemblyInfo.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.csproj.CoreCompileInputs.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\refint\2024. 10. 24_Feladat1.dll +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.pdb +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\2024. 10. 24_Feladat1.genruntimeconfig.cache +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\ref\2024. 10. 24_Feladat1.dll diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.deps.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.deps.json new file mode 100644 index 0000000..8599efd --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.deps.json @@ -0,0 +1,11 @@ +{ + "runtimeTarget": { + "name": ".NETCoreApp,Version=v8.0", + "signature": "" + }, + "compilationOptions": {}, + "targets": { + ".NETCoreApp,Version=v8.0": {} + }, + "libraries": {} +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.runtimeconfig.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.runtimeconfig.json new file mode 100644 index 0000000..fa47aff --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.designer.runtimeconfig.json @@ -0,0 +1,23 @@ +{ + "runtimeOptions": { + "tfm": "net8.0", + "frameworks": [ + { + "name": "Microsoft.NETCore.App", + "version": "8.0.0" + }, + { + "name": "Microsoft.WindowsDesktop.App", + "version": "8.0.0" + } + ], + "additionalProbingPaths": [ + "C:\\Users\\Adam\\.dotnet\\store\\|arch|\\|tfm|", + "C:\\Users\\Adam\\.nuget\\packages" + ], + "configProperties": { + "System.Runtime.Serialization.EnableUnsafeBinaryFormatterSerialization": true, + "Microsoft.NETCore.DotNetHostPolicy.SetAppPaths": true + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll new file mode 100644 index 0000000..0ae3691 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.g.resources b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.g.resources new file mode 100644 index 0000000..cbc4267 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.g.resources differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.genruntimeconfig.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.genruntimeconfig.cache new file mode 100644 index 0000000..263741d --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.genruntimeconfig.cache @@ -0,0 +1 @@ +8f0af3a99d039597161b181c58d77f4753731d4d0062d903b8d2cbcad8c74481 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb new file mode 100644 index 0000000..0af0e7d Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1.pdb differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.assets.cache new file mode 100644 index 0000000..28982fc Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_2bpall2w_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.assets.cache new file mode 100644 index 0000000..0cc7307 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_3pjdlxui_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.cache new file mode 100644 index 0000000..6db2eb9 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.cache @@ -0,0 +1,20 @@ +2024. 10. 24_Feladat1 + + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\ +_2024._10._24_Feladat1 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\App.xaml +11407045341 + +4-1384976255 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.i.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.i.cache new file mode 100644 index 0000000..40c3a5f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.i.cache @@ -0,0 +1,20 @@ +2024. 10. 24_Feladat1 +1.0.0.0 + +winexe +C# +.cs +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\obj\Debug\net8.0-windows\ +_2024._10._24_Feladat1 +none +false +TRACE;DEBUG;NET;NET8_0;NETCOREAPP +E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\App.xaml +11407045341 + +6-195427233 +198-556154604 +MainWindow.xaml; + +False + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.lref b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.lref new file mode 100644 index 0000000..770166e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_MarkupCompile.lref @@ -0,0 +1,4 @@ + + +FE:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\MainWindow.xaml;; + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.assets.cache new file mode 100644 index 0000000..6f1cc44 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ankkqtir_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.assets.cache new file mode 100644 index 0000000..9f06784 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_imbshtth_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.assets.cache new file mode 100644 index 0000000..7eb1757 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_janudijf_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.assets.cache new file mode 100644 index 0000000..f717581 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_l1grkm0d_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.assets.cache new file mode 100644 index 0000000..1996f9e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_obvqy304_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.assets.cache new file mode 100644 index 0000000..520c614 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_ulnhknzd_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.assets.cache new file mode 100644 index 0000000..d5afe55 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_v0p3vpcm_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfo.cs new file mode 100644 index 0000000..803ef19 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfo.cs @@ -0,0 +1,25 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Reflection; + +[assembly: System.Reflection.AssemblyCompanyAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")] +[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")] +[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")] +[assembly: System.Reflection.AssemblyProductAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyTitleAttribute("2024. 10. 24_Feladat1")] +[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")] +[assembly: System.Runtime.Versioning.TargetPlatformAttribute("Windows7.0")] +[assembly: System.Runtime.Versioning.SupportedOSPlatformAttribute("Windows7.0")] + +// Generated by the MSBuild WriteCodeFragment class. + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfoInputs.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfoInputs.cache new file mode 100644 index 0000000..bda9919 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.AssemblyInfoInputs.cache @@ -0,0 +1 @@ +c0f2f84f9ef9b3ddab8a2be1948fe0ad22d192525eca9f9935b0660f0d73cac5 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig new file mode 100644 index 0000000..bd8fb79 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GeneratedMSBuildEditorConfig.editorconfig @@ -0,0 +1,13 @@ +is_global = true +build_property.TargetFramework = net8.0-windows +build_property.TargetPlatformMinVersion = 7.0 +build_property.UsingMicrosoftNETSdkWeb = +build_property.ProjectTypeGuids = +build_property.InvariantGlobalization = +build_property.PlatformNeutralAssembly = +build_property.EnforceExtendedAnalyzerRules = +build_property._SupportedPlatformList = Linux,macOS,Windows +build_property.RootNamespace = _2024._10._24_Feladat1 +build_property.ProjectDir = E:\Suli\13.b\Programozás (Tusjak Brigitta)\Gyakorlat\Órai\2024. 10. 24_Feladat1\2024. 10. 24_Feladat1\ +build_property.EnableComHosting = +build_property.EnableGeneratedComInterfaceComImportInterop = diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GlobalUsings.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GlobalUsings.g.cs new file mode 100644 index 0000000..08bb19f --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.GlobalUsings.g.cs @@ -0,0 +1,6 @@ +// +global using global::System; +global using global::System.Collections.Generic; +global using global::System.Linq; +global using global::System.Threading; +global using global::System.Threading.Tasks; diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.assets.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.assets.cache new file mode 100644 index 0000000..8017384 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.assets.cache differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.csproj.BuildWithSkipAnalyzers b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/2024. 10. 24_Feladat1_wx2nhgwc_wpftmp.csproj.BuildWithSkipAnalyzers new file mode 100644 index 0000000..e69de29 diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.cs new file mode 100644 index 0000000..432f4ec --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "409DA9851769EDDB405CFE43C582DD0A0C69DD1B" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24_Feladat1; + + +namespace _2024._10._24_Feladat1 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._24_Feladat1.App app = new _2024._10._24_Feladat1.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs new file mode 100644 index 0000000..432f4ec --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/App.g.i.cs @@ -0,0 +1,71 @@ +#pragma checksum "..\..\..\App.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "409DA9851769EDDB405CFE43C582DD0A0C69DD1B" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24_Feladat1; + + +namespace _2024._10._24_Feladat1 { + + + /// + /// App + /// + public partial class App : System.Windows.Application { + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + + #line 5 "..\..\..\App.xaml" + this.StartupUri = new System.Uri("MainWindow.xaml", System.UriKind.Relative); + + #line default + #line hidden + } + + /// + /// Application Entry Point. + /// + [System.STAThreadAttribute()] + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public static void Main() { + _2024._10._24_Feladat1.App app = new _2024._10._24_Feladat1.App(); + app.InitializeComponent(); + app.Run(); + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml new file mode 100644 index 0000000..28a9738 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.baml differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs new file mode 100644 index 0000000..b447172 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.cs @@ -0,0 +1,76 @@ +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "DE155B377046DA39CCC4D351E9DC7F1ED3C44351" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24_Feladat1; + + +namespace _2024._10._24_Feladat1 { + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector { + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() { + if (_contentLoaded) { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 24_Feladat1;component/mainwindow.xaml", System.UriKind.Relative); + + #line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + + #line default + #line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) { + this._contentLoaded = true; + } + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs new file mode 100644 index 0000000..c94d722 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/MainWindow.g.i.cs @@ -0,0 +1,85 @@ +// Updated by XamlIntelliSenseFileGenerator 2024. 10. 24. 9:52:31 +#pragma checksum "..\..\..\MainWindow.xaml" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "DE155B377046DA39CCC4D351E9DC7F1ED3C44351" +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +using System; +using System.Diagnostics; +using System.Windows; +using System.Windows.Automation; +using System.Windows.Controls; +using System.Windows.Controls.Primitives; +using System.Windows.Controls.Ribbon; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Ink; +using System.Windows.Input; +using System.Windows.Markup; +using System.Windows.Media; +using System.Windows.Media.Animation; +using System.Windows.Media.Effects; +using System.Windows.Media.Imaging; +using System.Windows.Media.Media3D; +using System.Windows.Media.TextFormatting; +using System.Windows.Navigation; +using System.Windows.Shapes; +using System.Windows.Shell; +using _2024._10._24_Feladat1; + + +namespace _2024._10._24_Feladat1 +{ + + + /// + /// MainWindow + /// + public partial class MainWindow : System.Windows.Window, System.Windows.Markup.IComponentConnector + { + + private bool _contentLoaded; + + /// + /// InitializeComponent + /// + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + public void InitializeComponent() + { + if (_contentLoaded) + { + return; + } + _contentLoaded = true; + System.Uri resourceLocater = new System.Uri("/2024. 10. 24_Feladat1;component/mainwindow.xaml", System.UriKind.Relative); + +#line 1 "..\..\..\MainWindow.xaml" + System.Windows.Application.LoadComponent(this, resourceLocater); + +#line default +#line hidden + } + + [System.Diagnostics.DebuggerNonUserCodeAttribute()] + [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "8.0.8.0")] + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Design", "CA1033:InterfaceMethodsShouldBeCallableByChildTypes")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Maintainability", "CA1502:AvoidExcessiveComplexity")] + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] + void System.Windows.Markup.IComponentConnector.Connect(int connectionId, object target) + { + this._contentLoaded = true; + } + + internal System.Windows.Controls.Image Lion; + internal System.Windows.Controls.Slider csuszka; + } +} + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/apphost.exe b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/apphost.exe new file mode 100644 index 0000000..9c2419e Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/apphost.exe differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 24_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 24_Feladat1.dll new file mode 100644 index 0000000..7d86647 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/ref/2024. 10. 24_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 24_Feladat1.dll b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 24_Feladat1.dll new file mode 100644 index 0000000..7d86647 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/Debug/net8.0-windows/refint/2024. 10. 24_Feladat1.dll differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.assets.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.assets.json new file mode 100644 index 0000000..2bd1774 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.assets.json @@ -0,0 +1,76 @@ +{ + "version": 3, + "targets": { + "net8.0-windows7.0": {} + }, + "libraries": {}, + "projectFileDependencyGroups": { + "net8.0-windows7.0": [] + }, + "packageFolders": { + "C:\\Users\\Adam\\.nuget\\packages\\": {} + }, + "project": { + "version": "1.0.0", + "restore": { + "projectUniqueName": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj", + "projectName": "2024. 10. 24_Feladat1", + "projectPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj", + "packagesPath": "C:\\Users\\Adam\\.nuget\\packages\\", + "outputPath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\obj\\", + "projectStyle": "PackageReference", + "configFilePaths": [ + "C:\\Users\\Adam\\AppData\\Roaming\\NuGet\\NuGet.Config", + "C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config" + ], + "originalTargetFrameworks": [ + "net8.0-windows" + ], + "sources": { + "C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {}, + "https://api.nuget.org/v3/index.json": {} + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "projectReferences": {} + } + }, + "warningProperties": { + "warnAsError": [ + "NU1605" + ] + }, + "restoreAuditProperties": { + "enableAudit": "true", + "auditLevel": "low", + "auditMode": "direct" + } + }, + "frameworks": { + "net8.0-windows7.0": { + "targetAlias": "net8.0-windows", + "imports": [ + "net461", + "net462", + "net47", + "net471", + "net472", + "net48", + "net481" + ], + "assetTargetFallback": true, + "warn": true, + "frameworkReferences": { + "Microsoft.NETCore.App": { + "privateAssets": "all" + }, + "Microsoft.WindowsDesktop.App.WPF": { + "privateAssets": "none" + } + }, + "runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\8.0.400/PortableRuntimeIdentifierGraph.json" + } + } + } +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.nuget.cache b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.nuget.cache new file mode 100644 index 0000000..c4dbc6a --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat1/2024. 10. 24_Feladat1/obj/project.nuget.cache @@ -0,0 +1,8 @@ +{ + "version": 2, + "dgSpecHash": "F32dnZyHoY8=", + "success": true, + "projectFilePath": "E:\\Suli\\13.b\\Programozás (Tusjak Brigitta)\\Gyakorlat\\Órai\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1\\2024. 10. 24_Feladat1.csproj", + "expectedPackageFiles": [], + "logs": [] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/DesignTimeBuild/.dtbcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/DesignTimeBuild/.dtbcache.v2 new file mode 100644 index 0000000..82e1188 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/DesignTimeBuild/.dtbcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/18def06a-3e28-4c8e-95c1-ffbb95ba55f7.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/18def06a-3e28-4c8e-95c1-ffbb95ba55f7.vsidx new file mode 100644 index 0000000..8b4f830 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/18def06a-3e28-4c8e-95c1-ffbb95ba55f7.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/74ae50b0-7c5f-4a1d-8d45-f8f13f139583.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/74ae50b0-7c5f-4a1d-8d45-f8f13f139583.vsidx new file mode 100644 index 0000000..70aef67 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/74ae50b0-7c5f-4a1d-8d45-f8f13f139583.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/84b66c1b-78f0-4996-a821-4c57e1867747.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/84b66c1b-78f0-4996-a821-4c57e1867747.vsidx new file mode 100644 index 0000000..d441d60 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/84b66c1b-78f0-4996-a821-4c57e1867747.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/d51e6912-9261-4eeb-b432-17c28a4fe0ba.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/d51e6912-9261-4eeb-b432-17c28a4fe0ba.vsidx new file mode 100644 index 0000000..b423a18 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/d51e6912-9261-4eeb-b432-17c28a4fe0ba.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/e37bb9f0-96ad-49d1-8de8-b51e75d26037.vsidx b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/e37bb9f0-96ad-49d1-8de8-b51e75d26037.vsidx new file mode 100644 index 0000000..ef6da0b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/FileContentIndex/e37bb9f0-96ad-49d1-8de8-b51e75d26037.vsidx differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.futdcache.v2 b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.futdcache.v2 new file mode 100644 index 0000000..647301b Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.futdcache.v2 differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.suo b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.suo new file mode 100644 index 0000000..7750db4 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/.suo differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.backup.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.backup.json new file mode 100644 index 0000000..a7c8968 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.backup.json @@ -0,0 +1,60 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat2\\2024. 10. 24_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|solutionrelative:2024. 10. 24_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat2\\2024. 10. 24_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|solutionrelative:2024. 10. 24_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 3, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat2\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T07:54:06.049Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml.cs*", + "RelativeToolTip": "2024. 10. 24_Feladat2\\MainWindow.xaml.cs*", + "ViewState": "AgIAABIAAAAAAAAAAAAAACIAAAAnAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T07:54:05.959Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.json b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.json new file mode 100644 index 0000000..cb4da0c --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/2024. 10. 24_Feladat2/v17/DocumentLayout.json @@ -0,0 +1,60 @@ +{ + "Version": 1, + "WorkspaceRootPath": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\", + "Documents": [ + { + "AbsoluteMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat2\\2024. 10. 24_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}", + "RelativeMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|solutionrelative:2024. 10. 24_feladat2\\mainwindow.xaml.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}" + }, + { + "AbsoluteMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|e:\\suli\\13.b\\programoz\u00E1s (tusjak brigitta)\\gyakorlat\\\u00F3rai\\2024. 10. 24_feladat2\\2024. 10. 24_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}", + "RelativeMoniker": "D:0:0:{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}|2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2.csproj|solutionrelative:2024. 10. 24_feladat2\\mainwindow.xaml||{F11ACC28-31D1-4C80-A34B-F4E09D3D753C}" + } + ], + "DocumentGroupContainers": [ + { + "Orientation": 1, + "VerticalTabListWidth": 256, + "DocumentGroups": [ + { + "DockedHeight": 303, + "SelectedChildIndex": 3, + "Children": [ + { + "$type": "Bookmark", + "Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}" + }, + { + "$type": "Bookmark", + "Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}" + }, + { + "$type": "Document", + "DocumentIndex": 1, + "Title": "MainWindow.xaml", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat2\\MainWindow.xaml", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml", + "RelativeToolTip": "2024. 10. 24_Feladat2\\MainWindow.xaml", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.003549|", + "WhenOpened": "2024-10-24T07:54:06.049Z" + }, + { + "$type": "Document", + "DocumentIndex": 0, + "Title": "MainWindow.xaml.cs", + "DocumentMoniker": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "RelativeDocumentMoniker": "2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "ToolTip": "E:\\Suli\\13.b\\Programoz\u00E1s (Tusjak Brigitta)\\Gyakorlat\\\u00D3rai\\2024. 10. 24_Feladat2\\2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "RelativeToolTip": "2024. 10. 24_Feladat2\\MainWindow.xaml.cs", + "ViewState": "AgIAABUAAAAAAAAAAAA3wCIAAAAnAAAAAAAAAA==", + "Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|", + "WhenOpened": "2024-10-24T07:54:05.959Z", + "EditorCaption": "" + } + ] + } + ] + } + ] +} \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.metadata.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.metadata.v9.bin new file mode 100644 index 0000000..846d932 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.metadata.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.projects.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.projects.v9.bin new file mode 100644 index 0000000..9db6e69 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.projects.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.strings.v9.bin b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.strings.v9.bin new file mode 100644 index 0000000..ac6dcb1 Binary files /dev/null and b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/.vs/ProjectEvaluation/2024. 10. 24_feladat2.strings.v9.bin differ diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.sln b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.sln new file mode 100644 index 0000000..6dd11e1 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35303.130 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "2024. 10. 24_Feladat2", "2024. 10. 24_Feladat2\2024. 10. 24_Feladat2.csproj", "{D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D1A2A0B5-4F00-4141-8A6A-C4388722DA6D}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {31929466-FC33-466E-8D9E-D065EB83A8A4} + EndGlobalSection +EndGlobal diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj new file mode 100644 index 0000000..a4ef40e --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj @@ -0,0 +1,24 @@ + + + + WinExe + net8.0-windows + _2024._10._24_Feladat2 + enable + enable + true + + + + + + + + + + + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj.user b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj.user new file mode 100644 index 0000000..644b0a6 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2.csproj.user @@ -0,0 +1,14 @@ + + + + + + Designer + + + + + Designer + + + \ No newline at end of file diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml new file mode 100644 index 0000000..b752270 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml @@ -0,0 +1,9 @@ + + + + + diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml.cs new file mode 100644 index 0000000..2fca884 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/App.xaml.cs @@ -0,0 +1,14 @@ +using System.Configuration; +using System.Data; +using System.Windows; + +namespace _2024._10._24_Feladat2 +{ + /// + /// Interaction logic for App.xaml + /// + public partial class App : Application + { + } + +} diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/AssemblyInfo.cs b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/AssemblyInfo.cs new file mode 100644 index 0000000..b0ec827 --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/AssemblyInfo.cs @@ -0,0 +1,10 @@ +using System.Windows; + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located + //(used if a resource is not found in the page, + // or application resource dictionaries) + ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located + //(used if a resource is not found in the page, + // app, or any theme specific resource dictionaries) +)] diff --git a/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/MainWindow.xaml b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/MainWindow.xaml new file mode 100644 index 0000000..bb266bc --- /dev/null +++ b/Suli/13.b/Programozás (Tusjak Brigitta)/Gyakorlat/Órai/2024. 10. 24_Feladat2/2024. 10. 24_Feladat2/MainWindow.xaml @@ -0,0 +1,26 @@ + + + + + + + + + + + + + +
+ + Get professional support for this package with a Tidelift subscription + +
+ + Tidelift helps make open source sustainable for maintainers while giving companies
assurances about security, maintenance, and licensing for their dependencies. +
+